[hibernate-commits] Hibernate SVN: r18776 - in core/trunk/documentation/manual: src/main/docbook/en-US and 15 other directories.

hibernate-commits at lists.jboss.org hibernate-commits at lists.jboss.org
Thu Feb 11 02:04:15 EST 2010


Author: rwilding
Date: 2010-02-11 02:04:06 -0500 (Thu, 11 Feb 2010)
New Revision: 18776

Modified:
   core/trunk/documentation/manual/pom.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/author_group.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/architecture.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/association_mapping.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/basic_mapping.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/batch.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/best_practices.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/bibliography.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/collection_mapping.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/component_mapping.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/configuration.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/events.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/example_mappings.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/example_parentchild.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/example_weblog.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/filters.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/inheritance_mapping.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/performance.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/persistent_classes.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/portability.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/preface.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/query_criteria.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/query_hql.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/query_sql.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/session_api.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/toolset_guide.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/transactions.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/tutorial.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/content/xml.xml
   core/trunk/documentation/manual/src/main/docbook/en-US/legal_notice.xml
   core/trunk/documentation/manual/src/main/docbook/es-ES/Hibernate_Reference.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/author_group.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/architecture.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/association_mapping.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/basic_mapping.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/batch.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/best_practices.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/bibliography.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/collection_mapping.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/component_mapping.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/configuration.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/events.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/example_mappings.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/example_parentchild.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/example_weblog.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/filters.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/inheritance_mapping.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/performance.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/persistent_classes.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/portability.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/preface.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/query_criteria.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/query_hql.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/query_sql.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/session_api.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/toolset_guide.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/transactions.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/tutorial.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/content/xml.po
   core/trunk/documentation/manual/src/main/docbook/es-ES/legal_notice.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/Hibernate_Reference.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/author_group.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/architecture.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/association_mapping.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/basic_mapping.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/batch.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/best_practices.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/bibliography.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/collection_mapping.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/component_mapping.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/configuration.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/events.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/example_mappings.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/example_parentchild.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/example_weblog.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/filters.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/inheritance_mapping.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/performance.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/persistent_classes.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/portability.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/preface.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/query_criteria.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/query_hql.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/query_sql.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/session_api.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/toolset_guide.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/transactions.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/tutorial.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/content/xml.po
   core/trunk/documentation/manual/src/main/docbook/fr-FR/legal_notice.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/Hibernate_Reference.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/author_group.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/architecture.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/association_mapping.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/basic_mapping.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/batch.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/best_practices.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/bibliography.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/collection_mapping.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/component_mapping.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/configuration.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/events.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/example_mappings.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/example_parentchild.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/example_weblog.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/filters.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/inheritance_mapping.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/performance.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/persistent_classes.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/portability.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/preface.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/query_criteria.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/query_hql.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/query_sql.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/session_api.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/toolset_guide.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/transactions.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/tutorial.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/content/xml.po
   core/trunk/documentation/manual/src/main/docbook/ja-JP/legal_notice.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/Hibernate_Reference.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/author_group.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/architecture.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/association_mapping.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/basic_mapping.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/batch.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/best_practices.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/bibliography.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/collection_mapping.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/component_mapping.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/configuration.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/events.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/example_mappings.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/example_parentchild.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/example_weblog.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/filters.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/inheritance_mapping.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/performance.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/persistent_classes.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/portability.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/preface.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/query_criteria.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/query_hql.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/query_sql.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/session_api.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/toolset_guide.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/transactions.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/tutorial.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/content/xml.po
   core/trunk/documentation/manual/src/main/docbook/ko-KR/legal_notice.po
   core/trunk/documentation/manual/src/main/docbook/pot/Hibernate_Reference.pot
   core/trunk/documentation/manual/src/main/docbook/pot/author_group.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/architecture.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/association_mapping.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/basic_mapping.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/batch.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/best_practices.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/bibliography.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/collection_mapping.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/component_mapping.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/configuration.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/events.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/example_mappings.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/example_parentchild.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/example_weblog.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/filters.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/inheritance_mapping.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/performance.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/persistent_classes.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/portability.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/preface.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/query_criteria.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/query_hql.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/query_sql.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/session_api.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/toolset_guide.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/transactions.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/tutorial.pot
   core/trunk/documentation/manual/src/main/docbook/pot/content/xml.pot
   core/trunk/documentation/manual/src/main/docbook/pot/legal_notice.pot
   core/trunk/documentation/manual/src/main/docbook/pt-BR/Hibernate_Reference.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/author_group.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/architecture.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/association_mapping.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/basic_mapping.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/batch.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/best_practices.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/bibliography.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/collection_mapping.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/component_mapping.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/configuration.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/events.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/example_mappings.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/example_parentchild.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/example_weblog.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/filters.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/inheritance_mapping.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/performance.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/persistent_classes.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/portability.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/preface.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/query_criteria.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/query_hql.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/query_sql.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/session_api.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/toolset_guide.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/transactions.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/tutorial.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/content/xml.po
   core/trunk/documentation/manual/src/main/docbook/pt-BR/legal_notice.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/Hibernate_Reference.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/author_group.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/architecture.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/association_mapping.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/basic_mapping.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/batch.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/best_practices.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/bibliography.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/collection_mapping.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/component_mapping.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/configuration.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/events.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/example_mappings.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/example_parentchild.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/example_weblog.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/filters.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/inheritance_mapping.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/performance.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/persistent_classes.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/portability.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/preface.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/query_criteria.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/query_hql.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/query_sql.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/session_api.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/toolset_guide.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/transactions.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/tutorial.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/content/xml.po
   core/trunk/documentation/manual/src/main/docbook/zh-CN/legal_notice.po
Log:
'converted docs for publican compatibility and added translations from Core 3.3.2.GA branch'


Modified: core/trunk/documentation/manual/pom.xml
===================================================================
--- core/trunk/documentation/manual/pom.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/pom.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -38,13 +38,13 @@
                 </executions>
 
                 <configuration>
-                    <sourceDocumentName>Hibernate_Reference.xml</sourceDocumentName>
+                    <sourceDocumentName>HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.xml</sourceDocumentName>
                     <masterTranslation>en-US</masterTranslation>
                     <translations>
                         <translation>es-ES</translation>
                         <translation>fr-FR</translation>
                         <translation>ja-JP</translation>
-                        <translation>ko-KR</translation>
+                        <!-- <translation>ko-KR</translation> -->
                         <translation>pt-BR</translation>
                         <translation>zh-CN</translation>
                     </translations>

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/author_group.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/author_group.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/author_group.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,3 +1,4 @@
+<?xml version='1.0' encoding='UTF-8' ?>
 <!--
   ~ Hibernate, Relational Persistence for Idiomatic Java
   ~
@@ -21,8 +22,8 @@
   ~ 51 Franklin Street, Fifth Floor
   ~ Boston, MA  02110-1301  USA
   -->
-<!DOCTYPE authorgroup PUBLIC "-//OASIS//DTD DocBook XML V4.3//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
-
+<!DOCTYPE authorgroup PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+]>
 <authorgroup>
    <author>
       <firstname>Gavin</firstname>

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/architecture.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/architecture.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/architecture.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,13 +23,17 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="architecture">
 
     <title>Architecture</title>
 
-    <sect1 id="architecture-overview" revision="1">
+    <section id="architecture-overview" revision="1">
         <title>Overview</title>
         
         <para>
@@ -38,10 +42,10 @@
 
         <mediaobject>
             <imageobject role="fo">
-                <imagedata fileref="../images/overview.svg" format="SVG" align="center"/>
+                <imagedata fileref="images/overview.svg" format="SVG" align="center"/>
             </imageobject>
             <imageobject role="html">
-                <imagedata fileref="../images/overview.png" format="PNG" align="center"/>
+                <imagedata fileref="images/overview.png" format="PNG" align="center"/>
             </imageobject>
         </mediaobject>
 
@@ -64,10 +68,10 @@
 
         <mediaobject>
             <imageobject role="fo">
-                <imagedata fileref="../images/lite.svg" format="SVG" align="center"/>
+                <imagedata fileref="images/lite.svg" format="SVG" align="center"/>
             </imageobject>
             <imageobject role="html">
-                <imagedata fileref="../images/lite.png" format="PNG" align="center"/>
+                <imagedata fileref="images/lite.png" format="PNG" align="center"/>
             </imageobject>
         </mediaobject>
 
@@ -78,10 +82,10 @@
 
         <mediaobject>
             <imageobject role="fo">
-                <imagedata fileref="../images/full_cream.svg" format="SVG" align="center"/>
+                <imagedata fileref="images/full_cream.svg" format="SVG" align="center"/>
             </imageobject>
             <imageobject role="html">
-                <imagedata fileref="../images/full_cream.png" format="PNG" align="center"/>
+                <imagedata fileref="images/full_cream.png" format="PNG" align="center"/>
             </imageobject>
         </mediaobject>
 
@@ -185,9 +189,9 @@
             <literal>Transaction</literal>/<literal>TransactionFactory</literal> and/or
             <literal>ConnectionProvider</literal> APIs to communicate with JTA or JDBC directly.
         </para>
-    </sect1>
+    </section>
 
-    <sect1 id="architecture-states" revision="1">
+    <section id="architecture-states" revision="1">
         <title>Instance states</title>
         <para>
             An instance of a persistent class can be in one of three different states. These states are
@@ -235,9 +239,9 @@
                 </listitem>
             </varlistentry>
         </variablelist>
-    </sect1>    
+    </section>    
 
-    <sect1 id="architecture-jmx" revision="1">
+    <section id="architecture-jmx" revision="1">
         <title>JMX Integration</title>
 
         <para>
@@ -285,17 +289,17 @@
             Another feature available as a JMX service is runtime Hibernate statistics. See
             <xref linkend="configuration-optional-statistics"/> for more information.
         </para>
-    </sect1>
+    </section>
 
-    <sect1 id="architecture-jca" revision="1">
+    <section id="architecture-jca" revision="1">
         <title>JCA Support</title>
         <para>
             Hibernate can also be configured as a JCA connector. Please see the website for more
             information. Please note, however, that at this stage Hibernate JCA support is under development.
         </para>
-    </sect1>
+    </section>
 
-    <sect1 id="architecture-current-session" revision="2">
+    <section id="architecture-current-session" revision="2">
         <title>Contextual sessions</title>
         <para>
             Most applications using Hibernate need some form of "contextual" session, where a given
@@ -379,7 +383,7 @@
             short names: "jta", "thread", and "managed".
         </para>
         
-    </sect1>
+    </section>
 
 </chapter>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/association_mapping.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/association_mapping.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/association_mapping.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,13 +23,17 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="associations">
 
     <title>Association Mappings</title>
 
-    <sect1 id="assoc-intro" revision="1">
+    <section id="assoc-intro" revision="1">
         <title>Introduction</title>
         
         <para>
@@ -52,12 +56,12 @@
         	nullability constraints.
         </para>
         
-    </sect1>
+    </section>
 
-    <sect1 id="assoc-unidirectional" revision="1">
+    <section id="assoc-unidirectional" revision="1">
         <title>Unidirectional associations</title>
         
-        <sect2 id="assoc-unidirectional-m21">
+        <section id="assoc-unidirectional-m21">
         <title>Many-to-one</title>
         
         <para>
@@ -84,9 +88,9 @@
 create table Address ( addressId bigint not null primary key )
         ]]></programlisting>
         
-        </sect2>
+        </section>
 
-        <sect2 id="assoc-unidirectional-121">
+        <section id="assoc-unidirectional-121">
         <title>One-to-one</title>
         
         <para>
@@ -139,9 +143,9 @@
 create table Address ( personId bigint not null primary key )
         ]]></programlisting>
         
-        </sect2>
+        </section>
         
-        <sect2 id="assoc-unidirectional-12m">
+        <section id="assoc-unidirectional-12m">
         <title>One-to-many</title>
         
         <para>
@@ -174,14 +178,14 @@
           You should instead use a join table for this kind of association.
         </para>
         
-        </sect2>
+        </section>
     
-    </sect1>
+    </section>
 
-    <sect1 id="assoc-unidirectional-join" revision="1">
+    <section id="assoc-unidirectional-join" revision="1">
         <title>Unidirectional associations with join tables</title>
         
-        <sect2 id="assoc-unidirectional-join-12m">
+        <section id="assoc-unidirectional-join-12m">
         <title>One-to-many</title>
         
         <para>
@@ -213,9 +217,9 @@
 create table Address ( addressId bigint not null primary key )
         ]]></programlisting>
         
-        </sect2>
+        </section>
 
-        <sect2 id="assoc-unidirectional-join-m21">
+        <section id="assoc-unidirectional-join-m21">
         <title>Many-to-one</title>
         
         <para>
@@ -247,9 +251,9 @@
 create table Address ( addressId bigint not null primary key )
         ]]></programlisting>
         
-        </sect2>
+        </section>
 
-        <sect2 id="assoc-unidirectional-join-121">
+        <section id="assoc-unidirectional-join-121">
         <title>One-to-one</title>
         
         <para>
@@ -283,9 +287,9 @@
 create table Address ( addressId bigint not null primary key )
         ]]></programlisting>
         
-        </sect2>
+        </section>
 
-        <sect2 id="assoc-unidirectional-join-m2m">
+        <section id="assoc-unidirectional-join-m2m">
         <title>Many-to-many</title>
         
         <para>
@@ -314,14 +318,14 @@
 create table Address ( addressId bigint not null primary key )
         ]]></programlisting>
         
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
-    <sect1 id="assoc-bidirectional" revision="1">
+    <section id="assoc-bidirectional" revision="1">
         <title>Bidirectional associations</title>
         
-        <sect2 id="assoc-bidirectional-m21" revision="2">
+        <section id="assoc-bidirectional-m21" revision="2">
         <title>one-to-many / many-to-one</title>
         
         <para>
@@ -392,9 +396,9 @@
                 element.
             </para>
 
-        </sect2>
+        </section>
         
-        <sect2 id="assoc-bidirectional-121">
+        <section id="assoc-bidirectional-121">
         <title>One-to-one</title>
         
         <para>
@@ -450,14 +454,14 @@
 create table Address ( personId bigint not null primary key )
         ]]></programlisting>
         
-        </sect2>
+        </section>
         
-    </sect1>
+    </section>
 
-    <sect1 id="assoc-bidirectional-join" revision="1">
+    <section id="assoc-bidirectional-join" revision="1">
         <title>Bidirectional associations with join tables</title>
         
-        <sect2 id="assoc-bidirectional-join-12m">
+        <section id="assoc-bidirectional-join-12m">
         <title>one-to-many / many-to-one</title>
         
         <para>
@@ -498,9 +502,9 @@
 create table Address ( addressId bigint not null primary key )
         ]]></programlisting>
         
-        </sect2>
+        </section>
 
-         <sect2 id="assoc-bidirectional-join-121">
+         <section id="assoc-bidirectional-join-121">
         <title>one to one</title>
         
         <para>
@@ -544,9 +548,9 @@
 create table Address ( addressId bigint not null primary key )
         ]]></programlisting>
 
-        </sect2>
+        </section>
         
-        <sect2 id="assoc-bidirectional-join-m2m" revision="1">
+        <section id="assoc-bidirectional-join-m2m" revision="1">
         <title>Many-to-many</title>
         
         <para>
@@ -581,11 +585,11 @@
 create table Address ( addressId bigint not null primary key )
         ]]></programlisting>
         
-        </sect2>
+        </section>
         
-    </sect1>
+    </section>
     
-    <sect1 id="assoc-complex">
+    <section id="assoc-complex">
         <title>More complex association mappings</title>
         
         <para>
@@ -644,7 +648,7 @@
             to handle these kinds of cases using HQL or a criteria query.
         </para>
 
-    </sect1>
+    </section>
 
 </chapter>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/basic_mapping.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/basic_mapping.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/basic_mapping.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,12 +23,16 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="mapping">
     <title>Basic O/R Mapping</title>
 
-    <sect1 id="mapping-declaration" revision="2">
+    <section id="mapping-declaration" revision="2">
         <title>Mapping declaration</title>
 
         <para>
@@ -48,7 +52,8 @@
             Here is an example mapping:
         </para>
 
-        <programlisting id="mapping-declaration-ex1" role="XML"><![CDATA[<?xml version="1.0"?>
+
+        <programlisting role="XML"><![CDATA[<?xml version="1.0"?>
 <!DOCTYPE hibernate-mapping PUBLIC
       "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
           "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">
@@ -123,7 +128,7 @@
 
 
 
-        <sect2 id="mapping-declaration-doctype" revision="3">
+        <section id="mapping-declaration-doctype" revision="3">
             <title>Doctype</title>
 
             <para>
@@ -135,7 +140,7 @@
                 classpath.
             </para>
 
-            <sect3 id="mapping-declaration-entity-resolution">
+            <section id="mapping-declaration-entity-resolution">
                 <title>EntityResolver</title>
                 <para>
                     Hibernate will first attempt to resolve DTDs in its classpath.
@@ -166,29 +171,17 @@
                 <para>
                     The following is an example of utilizing user namespacing:
                 </para>
-                <programlisting role="XML"><![CDATA[<?xml version="1.0"?>
-<!DOCTYPE hibernate-mapping PUBLIC
-        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
-        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd" [
-    <!ENTITY types SYSTEM "classpath://your/domain/types.xml">
-]>
-
-<hibernate-mapping package="your.domain">
-    <class name="MyEntity">
-        <id name="id" type="my-custom-id-type">
-            ...
-        </id>
-    <class>
-    &types;
-</hibernate-mapping>]]></programlisting>
+                <programlisting language="XML" role="XML">
+<xi:include parse="text" href="../extras/namespacing.xml_sample" xmlns:xi="http://www.w3.org/2001/XInclude" />
+</programlisting>
                 <para>
                     Where <literal>types.xml</literal> is a resource in the <literal>your.domain</literal>
                     package and contains a custom <link linkend="mapping-types-custom">typedef</link>.
                 </para>
-            </sect3>
-        </sect2>
+            </section>
+        </section>
 
-        <sect2 id="mapping-declaration-mapping" revision="3">
+        <section id="mapping-declaration-mapping" revision="3">
             <title>Hibernate-mapping</title>
 
             <para>
@@ -284,9 +277,9 @@
                  <literal>Animal.hbm.xml</literal>.
              </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-class" revision="3">
+        <section id="mapping-declaration-class" revision="3">
             <title>Class</title>
 
             <para>
@@ -601,9 +594,9 @@
                 a nested mapping element.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-id" revision="4">
+        <section id="mapping-declaration-id" revision="4">
             <title>id</title>
 
             <para>
@@ -679,7 +672,7 @@
                 legacy data with composite keys. Its use is strongly discouraged for anything else.
             </para>
 
-            <sect3 id="mapping-declaration-id-generator" revision="2">
+            <section id="mapping-declaration-id-generator" revision="2">
                 <title>Generator</title>
 
                 <para>
@@ -829,9 +822,9 @@
                     </variablelist>
 
                 </para>
-            </sect3>
+            </section>
 
-            <sect3 id="mapping-declaration-id-hilo" revision="1">
+            <section id="mapping-declaration-id-hilo" revision="1">
                 <title>Hi/lo algorithm</title>
                 <para>
                     The <literal>hilo</literal> and <literal>seqhilo</literal> generators provide two alternate
@@ -861,9 +854,9 @@
                     server datasource to obtain connections enlisted with JTA, you must configure
                     the <literal>hibernate.transaction.manager_lookup_class</literal>.
                 </para>
-            </sect3>
+            </section>
 
-            <sect3 id="mapping-declaration-id-uuid">
+            <section id="mapping-declaration-id-uuid">
                 <title>UUID algorithm</title>
                 <para>
                     The UUID contains: IP address, startup time of the JVM that is accurate to a quarter
@@ -871,9 +864,9 @@
                     possible to obtain a MAC address or memory address from Java code, so this is
                     the best option without using JNI.
                 </para>
-            </sect3>
+            </section>
 
-            <sect3 id="mapping-declaration-id-sequences">
+            <section id="mapping-declaration-id-sequences">
             <title>Identity columns and sequences</title>
                 <para>
                     For databases that support identity columns (DB2, MySQL, Sybase, MS SQL), you
@@ -898,9 +891,9 @@
                     choose from the <literal>identity</literal>, <literal>sequence</literal> and
                     <literal>hilo</literal> strategies.
                 </para>
-            </sect3>
+            </section>
 
-            <sect3 id="mapping-declaration-id-assigned">
+            <section id="mapping-declaration-id-assigned">
                 <title>Assigned identifiers</title>
                 <para>
                     If you want the application to assign identifiers, as opposed to having
@@ -918,9 +911,9 @@
                     there is a version or timestamp property, or you define
                     <literal>Interceptor.isUnsaved()</literal>.
                 </para>
-            </sect3>
+            </section>
 
-            <sect3 id="mapping-declaration-id-select">
+            <section id="mapping-declaration-id-select">
                 <title>Primary keys assigned by triggers</title>
                 <para>
                     Hibernate does not generate DDL with triggers. It is for legacy schemas only.
@@ -939,11 +932,11 @@
                     whose value is generated by a trigger.
                 </para>
 
-            </sect3>
+            </section>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-id-enhanced">
+        <section id="mapping-declaration-id-enhanced">
             <title>Enhanced identifier generators</title>
 
             <para>
@@ -1070,9 +1063,9 @@
                     </listitem>
                 </itemizedlist>
             </para>
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-id-enhanced-optimizers">
+        <section id="mapping-declaration-id-enhanced-optimizers">
             <title>Identifier generator optimization</title>
             <para>
                 For identifier generators that store values in the database, it is inefficient for them to hit the
@@ -1107,9 +1100,9 @@
                     </listitem>
                 </itemizedlist>
             </para>
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-compositeid" revision="3">
+        <section id="mapping-declaration-compositeid" revision="3">
             <title>composite-id</title>
 
             <programlisting role="XML"><![CDATA[<composite-id
@@ -1224,9 +1217,9 @@
                 for almost all applications.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-discriminator" revision="3">
+        <section id="mapping-declaration-discriminator" revision="3">
             <title>Discriminator</title>
 
             <para>
@@ -1312,9 +1305,9 @@
     formula="case when CLASS_TYPE in ('a', 'b', 'c') then 0 else 1 end"
     type="integer"/>]]></programlisting>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-version" revision="4">
+        <section id="mapping-declaration-version" revision="4">
             <title>Version (optional)</title>
 
             <para>
@@ -1407,9 +1400,9 @@
                 problems with transitive reattachment in Hibernate. It is especially useful for people
                 using assigned identifiers or composite keys</emphasis>.
             </para>
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-timestamp" revision="4" >
+        <section id="mapping-declaration-timestamp" revision="4" >
             <title>Timestamp (optional)</title>
 
             <para>
@@ -1499,10 +1492,10 @@
 		</para>
 	</note>            
 		
-        </sect2>
+        </section>
 
 
-        <sect2 id="mapping-declaration-property" revision="4">
+        <section id="mapping-declaration-property" revision="4">
             <title>Property</title>
 
             <para>
@@ -1695,9 +1688,9 @@
                 if you do not want to use the attribute.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-manytoone" revision="5">
+        <section id="mapping-declaration-manytoone" revision="5">
             <title>Many-to-one</title>
 
             <para>
@@ -1908,9 +1901,9 @@
 
            <programlisting role="XML"><![CDATA[<many-to-one name="owner" property-ref="identity.ssn" column="OWNER_SSN"/>]]></programlisting>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-onetoone" revision="3">
+        <section id="mapping-declaration-onetoone" revision="3">
             <title>One-to-one</title>
 
             <para>
@@ -2084,9 +2077,9 @@
 
            <programlisting role="XML"><![CDATA[<one-to-one name="employee" class="Employee" property-ref="person"/>]]></programlisting>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-naturalid">
+        <section id="mapping-declaration-naturalid">
             <title>Natural-id</title>
 
             <programlisting role="XML"><![CDATA[<natural-id mutable="true|false"/>
@@ -2122,9 +2115,9 @@
                 </listitem>
             </itemizedlist>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-component" revision="2">
+        <section id="mapping-declaration-component" revision="2">
             <title>Component and dynamic-component</title>
 
             <para>
@@ -2233,9 +2226,9 @@
                 <xref linkend="components-dynamic"/> for more information.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-properties" revision="2">
+        <section id="mapping-declaration-properties" revision="2">
             <title>Properties</title>
 
             <para>
@@ -2336,9 +2329,9 @@
                 legacy data is not recommended.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-subclass" revision="4">
+        <section id="mapping-declaration-subclass" revision="4">
             <title>Subclass</title>
 
             <para>
@@ -2407,9 +2400,9 @@
                 For information about inheritance mappings see <xref linkend="inheritance"/>.
             </para>
 
-        </sect2>
+        </section>
 
-         <sect2 id="mapping-declaration-joinedsubclass" revision="3">
+         <section id="mapping-declaration-joinedsubclass" revision="3">
             <title>Joined-subclass</title>
 
             <para>
@@ -2514,9 +2507,9 @@
                  For information about inheritance mappings see <xref linkend="inheritance"/>.
              </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-unionsubclass" revision="2">
+        <section id="mapping-declaration-unionsubclass" revision="2">
            <title>Union-subclass</title>
 
            <para>
@@ -2590,9 +2583,9 @@
                 For information about inheritance mappings see <xref linkend="inheritance"/>.
             </para>
 
-        </sect2>
+        </section>
 
-   	<sect2 id="mapping-declaration-join" revision="3">
+   	<section id="mapping-declaration-join" revision="3">
             <title>Join</title>
 
             <para>
@@ -2696,9 +2689,9 @@
                 explained later.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-declaration-key">
+        <section id="mapping-declaration-key">
             <title>Key</title>                             
 
             <para>                                                                
@@ -2786,9 +2779,9 @@
                 <literal>&lt;key not-null="true"&gt;</literal>.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-column" revision="5">
+        <section id="mapping-column" revision="5">
            <title>Column and formula elements</title>
            <para>
                Mapping elements which accept a <literal>column</literal> attribute will alternatively
@@ -2833,9 +2826,9 @@
     <formula>'MAILING'</formula>
 </many-to-one>]]></programlisting>
 
-    </sect2>
+    </section>
 
-        <sect2 id="mapping-declaration-import">
+        <section id="mapping-declaration-import">
             <title>Import</title>
 
             <para>
@@ -2871,9 +2864,9 @@
                 </calloutlist>
             </programlistingco>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-types-anymapping" revision="2">
+        <section id="mapping-types-anymapping" revision="2">
             <title>Any</title>
 
             <para>
@@ -2965,14 +2958,14 @@
                 </calloutlist>
             </programlistingco>
 
-      </sect2>
+      </section>
 
-    </sect1>
+    </section>
 
-    <sect1 id="mapping-types">
+    <section id="mapping-types">
         <title>Hibernate types</title>
 
-        <sect2 id="mapping-types-entitiesvalues" revision="1">
+        <section id="mapping-types-entitiesvalues" revision="1">
             <title>Entities and values</title>
 
             <para>
@@ -3037,9 +3030,9 @@
                 With the exception of collections, all built-in Hibernate types support null semantics.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-types-basictypes" revision="3">
+        <section id="mapping-types-basictypes" revision="3">
             <title>Basic value types</title>
 
             <para>
@@ -3193,9 +3186,9 @@
                 represents the <literal>string</literal> type.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="mapping-types-custom" revision="2">
+        <section id="mapping-types-custom" revision="2">
             <title>Custom value types</title>
 
             <para>
@@ -3281,11 +3274,11 @@
                 monetary values are represented.
             </para>
 
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
-    <sect1 id="mapping-entityname">
+    <section id="mapping-entityname">
         <title>Mapping a class more than once</title>
         <para>
             It is possible to provide more than one mapping for a particular persistent class. In this
@@ -3318,9 +3311,9 @@
             <literal>class</literal>.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="mapping-quotedidentifiers">
+    <section id="mapping-quotedidentifiers">
             <title>SQL quoted identifiers</title>
             <para>
                 You can force Hibernate to quote an identifier in the generated SQL by enclosing the table or
@@ -3335,17 +3328,17 @@
     ...
 </class>]]></programlisting>
 
-    </sect1>
+    </section>
 
 
-   	<sect1 id="mapping-alternatives">
+   	<section id="mapping-alternatives">
    	<title>Metadata alternatives</title>
 
    	<para>
    	    XML does not suit all users so there are some alternative ways to define O/R mapping metadata in Hibernate.
    	</para>
 
-    <sect2 id="mapping-xdoclet">
+    <section id="mapping-xdoclet">
         <title>Using XDoclet markup</title>
 
         <para>
@@ -3464,9 +3457,9 @@
             See the Hibernate website for more examples of XDoclet and Hibernate.
         </para>
 
-    </sect2>
+    </section>
 
-    <sect2 id="mapping-annotations" revision="2">
+    <section id="mapping-annotations" revision="2">
         <title>Using JDK 5.0 Annotations</title>
 
         <para>
@@ -3515,10 +3508,10 @@
         </para>
 	</note>
 
-    </sect2>
-    </sect1>
+    </section>
+    </section>
 
-    <sect1 id="mapping-generated" revision="1">
+    <section id="mapping-generated" revision="1">
         <title>Generated properties</title>
         <para>
             Generated properties are properties that have their values generated by the
@@ -3552,9 +3545,9 @@
 		    <literal>always</literal>: the property value is generated both
 		    on insert and on update.
 	    </para>
-    </sect1>
+    </section>
 
-    <sect1 id="mapping-column-read-and-write" revision="1">
+    <section id="mapping-column-read-and-write" revision="1">
         <title>Column read and write expressions</title>
         <para>
             Hibernate allows you to customize the SQL it uses to read and write the values
@@ -3590,9 +3583,9 @@
             The <literal>write</literal> expression, if specified, must contain exactly one '?' placeholder
             for the value.
         </para>
-    </sect1>
+    </section>
 
-    <sect1 id="mapping-database-object">
+    <section id="mapping-database-object">
         <title>Auxiliary database objects</title>
         <para>
             Auxiliary database objects allow for the CREATE and DROP of arbitrary database objects. In conjunction with
@@ -3637,6 +3630,6 @@
         <dialect-scope name="org.hibernate.dialect.Oracle10gDialect"/>
     </database-object>
 </hibernate-mapping>]]></programlisting>
-    </sect1>
+    </section>
 </chapter>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/batch.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/batch.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/batch.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="batch">
     <title>Batch processing</title>
     
@@ -75,7 +79,7 @@
         <literal>CacheMode</literal> to disable interaction with the second-level cache.
     </para>
 
-    <sect1 id="batch-inserts">
+    <section id="batch-inserts">
         <title>Batch inserts</title>
 
         <para>
@@ -100,9 +104,9 @@
 tx.commit();
 session.close();]]></programlisting>
 
-    </sect1>
+    </section>
 
-    <sect1 id="batch-update" >
+    <section id="batch-update" >
         <title>Batch updates</title>
 
         <para>
@@ -131,9 +135,9 @@
 tx.commit();
 session.close();]]></programlisting>
 
-    </sect1>
+    </section>
     
-    <sect1 id="batch-statelesssession">
+    <section id="batch-statelesssession">
         <title>The StatelessSession interface</title>
         <para>
             Alternatively, Hibernate provides a command-oriented API that can be used for 
@@ -180,9 +184,9 @@
             interface.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="batch-direct" revision="3">
+    <section id="batch-direct" revision="3">
         <title>DML-style operations</title>
 
         <para>
@@ -372,6 +376,6 @@
 tx.commit();
 session.close();]]></programlisting>
 
-    </sect1>
+    </section>
 
 </chapter>

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/best_practices.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/best_practices.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/best_practices.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="best-practices" revision="3">
     <title>Best Practices</title>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/bibliography.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/bibliography.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/bibliography.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,3 +1,4 @@
+<?xml version='1.0' encoding="UTF-8"?>
 <!--
   ~ Hibernate, Relational Persistence for Idiomatic Java
   ~
@@ -21,8 +22,12 @@
   ~ 51 Franklin Street, Fifth Floor
   ~ Boston, MA  02110-1301  USA
   -->
-<!DOCTYPE bibliography PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <bibliography>
     <title>References</title>
 
@@ -72,4 +77,4 @@
         </publisher>
     </biblioentry>
 
-</bibliography>
\ No newline at end of file
+</bibliography>

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/collection_mapping.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/collection_mapping.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/collection_mapping.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,12 +23,16 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="collections">
     <title>Collection mapping</title>
 
-    <sect1 id="collections-persistent" revision="3">
+    <section id="collections-persistent" revision="3">
         <title>Persistent collections</title>
         
         <para>
@@ -99,9 +103,9 @@
             the semantics of bidirectional associations (these are discussed later).
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="collections-mapping" revision="4">
+    <section id="collections-mapping" revision="4">
         <title>Collection mappings</title>
 
         <tip>
@@ -270,7 +274,7 @@
             </calloutlist>
         </programlistingco>
 
-        <sect2 id="collections-foreignkeys" >
+        <section id="collections-foreignkeys" >
            <title>Collection foreign keys</title>
     
             <para>
@@ -301,9 +305,9 @@
                 element.
             </para>
             
-        </sect2>
+        </section>
         
-        <sect2 id="collections-elements" >
+        <section id="collections-elements" >
             <title>Collection elements</title>
     
             <para>
@@ -324,9 +328,9 @@
                 associations.
             </para>
             
-        </sect2>
+        </section>
         
-        <sect2 id="collections-indexed">
+        <section id="collections-indexed">
             <title>Indexed collections</title>
     
             <para>
@@ -439,9 +443,9 @@
                 optionally sorted or ordered.
             </para>
             
-        </sect2>
+        </section>
 
-    <sect2 id="collections-ofvalues" revision="2">
+    <section id="collections-ofvalues" revision="2">
         <title>Collections of values and many-to-many associations</title>
 
         <para>
@@ -643,9 +647,9 @@
     </composite-element>
 </list>]]></programlisting>
 
-    </sect2>
+    </section>
 
-    <sect2 id="collections-onetomany">
+    <section id="collections-onetomany">
         <title>One-to-many associations</title>
 
         <para>
@@ -740,14 +744,14 @@
     <map-key formula="partName"/>
     <one-to-many class="Part"/>
 </map>]]></programlisting>
-    </sect2>
+    </section>
     
-    </sect1>
+    </section>
 
-    <sect1 id="collections-advancedmappings">
+    <section id="collections-advancedmappings">
         <title>Advanced collection mappings</title>
 
-    <sect2 id="collections-sorted" revision="2">
+    <section id="collections-sorted" revision="2">
         <title>Sorted collections</title>
 
         <para>
@@ -814,9 +818,9 @@
 
         <programlisting role="JAVA"><![CDATA[sortedUsers = s.createFilter( group.getUsers(), "order by this.name" ).list();]]></programlisting>
 
-    </sect2>
+    </section>
 
-     <sect2 id="collections-bidirectional" revision="1">
+     <section id="collections-bidirectional" revision="1">
         <title>Bidirectional associations</title>
 
         <para>
@@ -925,9 +929,9 @@
             affect the operation of cascades as these are orthogonal concepts.
         </para>
 
-    </sect2>
+    </section>
 
-    <sect2 id="collections-indexedbidirectional">
+    <section id="collections-indexedbidirectional">
         <title>Bidirectional associations with indexed collections</title>
         <para>
             A bidirectional association where one end is represented as a <literal>&lt;list&gt;</literal>
@@ -993,9 +997,9 @@
            updates to the foreign key. <!--TODO: Does this really result in some unnecessary update statements?-->
        </para>
 
-    </sect2>
+    </section>
     
-    <sect2 id="collections-ternary">
+    <section id="collections-ternary">
         <title>Ternary associations</title>
 
         <para>
@@ -1024,9 +1028,9 @@
             A final alternative is to use composite elements, which will be discussed later. 
         </para>
         
-    </sect2>
+    </section>
     
-    <sect2 id="collections-idbag" revision="1">
+    <section id="collections-idbag" revision="1">
         <title><literal>Using an &lt;idbag&gt;</literal></title>
 
         <para>
@@ -1070,13 +1074,13 @@
             strategy is not supported for <literal>&lt;idbag&gt;</literal> collection identifiers.
         </para>
 
-    </sect2>
+    </section>
 
-    </sect1>
+    </section>
     
     <!--undocumenting this stuff -->
     
-    <!--sect1 id="collections-heterogeneous">
+    <!--section id="collections-heterogeneous">
         <title>Heterogeneous Associations</title>
 
         <para>
@@ -1086,9 +1090,9 @@
             rarely, if ever.
         </para>
 
-    </sect1-->
+    </section-->
 
-    <sect1 id="collections-example" revision="1">
+    <section id="collections-example" revision="1">
         <title>Collection examples</title>
 
         <para>
@@ -1264,6 +1268,6 @@
             in the next chapter.
         </para>
 
-    </sect1>
+    </section>
 
 </chapter>

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/component_mapping.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/component_mapping.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/component_mapping.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="components">
     <title>Component Mapping</title>
 
@@ -33,7 +37,7 @@
         throughout Hibernate.
     </para>
 
-    <sect1 id="components-dependentobjects" revision="2" >
+    <section id="components-dependentobjects" revision="2" >
         <title>Dependent objects</title>
 
         <para>
@@ -157,9 +161,9 @@
     </component>
 </class>]]></programlisting>
 
-    </sect1>
+    </section>
 
-    <sect1 id="components-incollections" revision="1">
+    <section id="components-incollections" revision="1">
         <title>Collections of dependent objects</title>
 
         <para>
@@ -258,9 +262,9 @@
             associations to other entities.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="components-asmapindex">
+    <section id="components-asmapindex">
         <title>Components as Map indices</title>
 
         <para>
@@ -269,9 +273,9 @@
             <literal>hashCode()</literal> and <literal>equals()</literal> correctly on
             the component class.
         </para>
-    </sect1>
+    </section>
 
-    <sect1 id="components-compositeid" revision="1">
+    <section id="components-compositeid" revision="1">
         <title>Components as composite identifiers</title>
 
         <para>
@@ -409,9 +413,9 @@
     </set>
 </class>]]></programlisting>
 
-    </sect1>
+    </section>
 
-    <sect1 id="components-dynamic" revision="1">
+    <section id="components-dynamic" revision="1">
         <title>Dynamic components</title>
 
         <para>
@@ -433,6 +437,6 @@
             configuration-time metamodel via the <literal>Configuration</literal> object.
         </para>
 
-    </sect1>
+    </section>
 
 </chapter>

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/configuration.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/configuration.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/configuration.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="session-configuration" revision="1">
     <title>Configuration</title>
     
@@ -36,7 +40,7 @@
         the various options. Simply put the example file in your classpath and customize it to suit your needs.
     </para>
 
-    <sect1 id="configuration-programmatic" revision="1">
+    <section id="configuration-programmatic" revision="1">
         <title>Programmatic configuration</title>
 
         <para>
@@ -122,9 +126,9 @@
             be discarded once a <literal>SessionFactory</literal> is created.
         </para>
 
-    </sect1>
+    </section>
     
-    <sect1 id="configuration-sessionfactory">
+    <section id="configuration-sessionfactory">
         <title>Obtaining a SessionFactory</title>
 
         <para>
@@ -141,9 +145,9 @@
             one database.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="configuration-hibernatejdbc" revision="1">
+    <section id="configuration-hibernatejdbc" revision="1">
         <title>JDBC connections</title>
 
         <para>
@@ -248,7 +252,8 @@
             The following is an example <filename>hibernate.properties</filename> file for c3p0:
         </para>
 
-        <programlisting id="c3p0-configuration" revision="1"><![CDATA[hibernate.connection.driver_class = org.postgresql.Driver
+       
+        <programlisting><![CDATA[hibernate.connection.driver_class = org.postgresql.Driver
 hibernate.connection.url = jdbc:postgresql://localhost/mydatabase
 hibernate.connection.username = myuser
 hibernate.connection.password = secret
@@ -349,9 +354,9 @@
             custom implementation via the <property>hibernate.connection.provider_class</property> property.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="configuration-optional" revision="1">
+    <section id="configuration-optional" revision="1">
         <title>Optional configuration properties</title>
         
         <para>
@@ -360,9 +365,9 @@
         </para>
 
         <para>
-        	<warning><emphasis>Some of these properties are "system-level" only.</emphasis>  System-level properties can
+        	<warning><para><emphasis>Some of these properties are "system-level" only.</emphasis>  System-level properties can
             be set only via <literal>java -Dproperty=value</literal> or <filename>hibernate.properties</filename>. They
-            <emphasis>cannot</emphasis> be set by the other techniques described above.</warning>
+            <emphasis>cannot</emphasis> be set by the other techniques described above.</para></warning>
         </para>
 
         <table frame="topbot" id="configuration-optional-properties" revision="8">
@@ -1040,7 +1045,7 @@
             </tgroup>
         </table>
 
-        <sect2 id="configuration-optional-dialects" revision="1">
+        <section id="configuration-optional-dialects" revision="1">
             <title>SQL Dialects</title>
 
             <para>
@@ -1137,9 +1142,9 @@
                 </tgroup>
             </table>
 
-        </sect2>
+        </section>
 
-        <sect2 id="configuration-optional-outerjoin" revision="4">
+        <section id="configuration-optional-outerjoin" revision="4">
             <title>Outer Join Fetching</title>
 
             <para>
@@ -1163,9 +1168,9 @@
                 See <xref linkend="performance-fetching"/> for more information.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="configuration-optional-binarystreams" revision="1">
+        <section id="configuration-optional-binarystreams" revision="1">
             <title>Binary Streams</title>
 
             <para>
@@ -1176,9 +1181,9 @@
                 <emphasis>This is a system-level setting only.</emphasis>
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="configuration-optional-cacheprovider" revision="2">
+        <section id="configuration-optional-cacheprovider" revision="2">
             <title>Second-level and query cache</title>
 
             <para>
@@ -1188,9 +1193,9 @@
                 more information.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="configuration-optional-querysubstitution">
+        <section id="configuration-optional-querysubstitution">
             <title>Query Language Substitution</title>
 
             <para>
@@ -1211,9 +1216,9 @@
                 This would allow you to rename the SQL <literal>LOWER</literal> function.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="configuration-optional-statistics" revision="2">
+        <section id="configuration-optional-statistics" revision="2">
             <title>Hibernate statistics</title>
 
             <para>
@@ -1224,10 +1229,10 @@
                 <literal>org.hibernate.stats</literal> for more information.
             </para>
 
-        </sect2>
-    </sect1>
+        </section>
+    </section>
 
-    <sect1 id="configuration-logging">
+    <section id="configuration-logging">
         <title>Logging</title>
 
         <para>
@@ -1320,9 +1325,9 @@
         </para>
                        
         
-    </sect1>
+    </section>
 
-    <sect1 id="configuration-namingstrategy">
+    <section id="configuration-namingstrategy">
         <title>Implementing a <literal>NamingStrategy</literal></title>
 
         <para>
@@ -1355,9 +1360,9 @@
             strategy that might be a useful starting point for some applications.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="configuration-xmlconfig" revision="2">
+    <section id="configuration-xmlconfig" revision="2">
         <title>XML configuration file</title>
 
         <para>
@@ -1428,9 +1433,9 @@
     .configure("catdb.cfg.xml")
     .buildSessionFactory();]]></programlisting>
 
-    </sect1>
+    </section>
 
-    <sect1 id="configuration-j2ee" revision="1">
+    <section id="configuration-j2ee" revision="1">
         <title>J2EE Application Server integration</title>
 
         <para>
@@ -1493,7 +1498,7 @@
             application server shows "connection containment" exceptions.
         </para>
 
-        <sect2 id="configuration-optional-transactionstrategy" revision="3">
+        <section id="configuration-optional-transactionstrategy" revision="3">
             <title>Transaction strategy configuration</title>
 
             <para>
@@ -1608,9 +1613,9 @@
                 </tgroup>
             </table>
 
-        </sect2>
+        </section>
 
-        <sect2 id="configuration-optional-jndi" revision="3">
+        <section id="configuration-optional-jndi" revision="3">
             <title>JNDI-bound <literal>SessionFactory</literal></title>
 
             <para>
@@ -1656,15 +1661,15 @@
                 class is also a convenient way to startup Hibernate&mdash;see chapter 1.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="configuration-j2ee-currentsession" revision="4">
+        <section id="configuration-j2ee-currentsession" revision="4">
             <title>Current Session context management with JTA</title>
 
             <para>
                 The easiest way to handle <literal>Sessions</literal> and transactions is
                 Hibernate's automatic "current" <literal>Session</literal> management.
-                For a discussion of contextual sessions see <link linkend="architecture-current-session"></link>.
+                For a discussion of contextual sessions see <xref linkend="architecture-current-session"/>.
                 Using the <literal>"jta"</literal> session context, if there is no Hibernate
                 <literal>Session</literal> associated with the current JTA transaction, one will
 	            be started and associated with that JTA transaction the first time you call
@@ -1681,9 +1686,9 @@
 	            demarcation with CMT is preferred.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="configuration-j2ee-jmx" revision="1">
+        <section id="configuration-j2ee-jmx" revision="1">
             <title>JMX deployment</title>
 
             <para>
@@ -1754,9 +1759,9 @@
                 documentation for more information about JMX service and EJB deployment.
             </para>
 
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
 </chapter>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/events.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/events.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/events.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="events">
     <title>Interceptors and events</title>
 
@@ -34,7 +38,7 @@
         functionality and the extension of Hibernate functionality.
     </para>
 
-    <sect1 id="objectstate-interceptors" revision="3">
+    <section id="objectstate-interceptors" revision="3">
         <title>Interceptors</title>
 
         <para>
@@ -160,9 +164,9 @@
     
         <programlisting role="JAVA"><![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]></programlisting>
 
-    </sect1>
+    </section>
 
-     <sect1 id="objectstate-events" revision="4">
+     <section id="objectstate-events" revision="4">
         <title>Event system</title>
 
         <para>
@@ -249,9 +253,9 @@
             or off during configuration.
         </para>
 
-    </sect1>
+    </section>
     
-    <sect1 id="objectstate-decl-security" revision="2">
+    <section id="objectstate-decl-security" revision="2">
         <title>Hibernate declarative security</title>
         <para>
             Usually, declarative security in Hibernate applications is managed in a session facade
@@ -286,7 +290,7 @@
             The role names are the roles understood by your JACC provider.
         </para>
        
-    </sect1>
+    </section>
 
 </chapter>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/example_mappings.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/example_mappings.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/example_mappings.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="example-mappings">
     <title>Example: Various Mappings</title>
    
@@ -33,7 +37,7 @@
         This chapters explores some more complex association mappings.
     </para>
     
-    <sect1 id="example-mappings-emp">
+    <section id="example-mappings-emp">
         <title>Employer/Employee</title>
 
         <para>
@@ -46,10 +50,10 @@
 
         <mediaobject>
             <imageobject role="html">
-                <imagedata fileref="../images/EmployerEmployee.png" format="PNG" align="center" />
+                <imagedata fileref="images/EmployerEmployee.png" format="PNG" align="center" />
             </imageobject>
             <imageobject role="fo">
-                <imagedata fileref="../images/EmployerEmployee.png" format="PNG" align="center" width="17cm" />
+                <imagedata fileref="images/EmployerEmployee.png" format="PNG" align="center" width="17cm" />
             </imageobject>
         </mediaobject>
         
@@ -144,9 +148,9 @@
 create sequence employment_id_seq
 create sequence employer_id_seq]]></programlisting>
 
-    </sect1>
+    </section>
     
-    <sect1 id="example-mappings-authorwork">
+    <section id="example-mappings-authorwork">
         <title>Author/Work</title>
 
         <para>
@@ -160,10 +164,10 @@
 
         <mediaobject>
             <imageobject role="html">
-                <imagedata fileref="../images/AuthorWork.png" format="PNG" align="center" />
+                <imagedata fileref="images/AuthorWork.png" format="PNG" align="center" />
             </imageobject>
             <imageobject role="fo">
-                <imagedata fileref="../images/AuthorWork.png" format="PNG" align="center" width="17cm" />
+                <imagedata fileref="images/AuthorWork.png" format="PNG" align="center" width="17cm" />
             </imageobject>
         </mediaobject>
         
@@ -266,9 +270,9 @@
 alter table author_work
     add constraint author_workFK1 foreign key (work_id) references works]]></programlisting>
 
-    </sect1>
+    </section>
 
-    <sect1 id="example-mappings-customerorderproduct">
+    <section id="example-mappings-customerorderproduct">
         <title>Customer/Order/Product</title>
 
         <para>
@@ -284,10 +288,10 @@
 
         <mediaobject>
             <imageobject role="html">
-                <imagedata fileref="../images/CustomerOrderProduct.png" format="PNG" align="center" />
+                <imagedata fileref="images/CustomerOrderProduct.png" format="PNG" align="center" />
             </imageobject>
             <imageobject role="fo">
-                <imagedata fileref="../images/CustomerOrderProduct.png" format="PNG" align="center" width="17cm" />
+                <imagedata fileref="images/CustomerOrderProduct.png" format="PNG" align="center" width="17cm" />
             </imageobject>
         </mediaobject>
         
@@ -374,9 +378,9 @@
 alter table line_items
     add constraint line_itemsFK1 foreign key (order_id) references orders]]></programlisting>
 
-    </sect1>
+    </section>
     
-    <sect1 id="misc">
+    <section id="misc">
         <title>Miscellaneous example mappings</title>
         
         <para>
@@ -387,7 +391,7 @@
         
       <!--  <<para>TODO: put words around this stuff</para>-->
         
-        <sect2 id="example-mappings-typed-onetone">
+        <section id="example-mappings-typed-onetone">
             <title>"Typed" one-to-one association</title>
 <programlisting role="XML"><![CDATA[<class name="Person">
     <id name="name"/>
@@ -415,9 +419,9 @@
     <property name="state"/>
     <property name="zip"/>
 </class>]]></programlisting>
-        </sect2>
+        </section>
         
-        <sect2 id="example-mappings-composite-key">
+        <section id="example-mappings-composite-key">
             <title>Composite key example</title>
 <programlisting role="XML"><![CDATA[<class name="Customer">
 
@@ -532,9 +536,9 @@
     </property>
     
 </class>]]></programlisting>
-        </sect2>
+        </section>
         
-        <sect2 id="example-mappings-composite-key-manytomany">
+        <section id="example-mappings-composite-key-manytomany">
             <title>Many-to-many with shared composite key attribute</title>
 <programlisting role="XML"><![CDATA[<class name="User" table="`User`">
     <composite-id>
@@ -571,9 +575,9 @@
     </set>
 </class>
 ]]></programlisting>
-        </sect2>
+        </section>
 
-        <sect2 id="example-mappings-content-discrimination">
+        <section id="example-mappings-content-discrimination">
             <title>Content based discrimination</title>
 <programlisting role="XML"><![CDATA[<class name="Person"
     discriminator-value="P">
@@ -625,9 +629,9 @@
     </subclass>
     
 </class>]]></programlisting>
-        </sect2>
+        </section>
 
-        <sect2 id="example-mappings-association-alternatekeys" revision="2">
+        <section id="example-mappings-association-alternatekeys" revision="2">
             <title>Associations on alternate keys</title>
 <programlisting role="XML"><![CDATA[<class name="Person">
     
@@ -678,9 +682,9 @@
     <property name="type" not-null="true"/>
     
 </class>]]></programlisting>
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
 </chapter>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/example_parentchild.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/example_parentchild.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/example_parentchild.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="example-parentchild">
     <title>Example: Parent/Child</title>
 
@@ -41,7 +45,7 @@
         
     </para>
     
-    <sect1 id="example-parentchild-collections">
+    <section id="example-parentchild-collections">
         <title>A note about collections</title>
 
         <para>
@@ -82,9 +86,9 @@
             child is bound to the life cycle of the parent.
         </para>
     
-    </sect1>
+    </section>
 
-    <sect1 id="example-parentchild-bidir">
+    <section id="example-parentchild-bidir">
         <title>Bidirectional one-to-many</title>
 
         <para>
@@ -195,9 +199,9 @@
 session.save(c);
 session.flush();]]></programlisting>
 
-     </sect1>
+     </section>
      
-     <sect1 id="example-parentchild-cascades">
+     <section id="example-parentchild-cascades">
          <title>Cascading life cycle</title>
      
          <para>
@@ -268,9 +272,9 @@
              <literal>setParent()</literal>.
          </para>
                
-     </sect1>
+     </section>
      
-     <sect1 id="example-parentchild-update">
+     <section id="example-parentchild-update">
          <title>Cascades and <literal>unsaved-value</literal></title>
      
          <para>
@@ -306,9 +310,9 @@
              row exists.
          </para>
 
-     </sect1>
+     </section>
 
-     <sect1 id="example-parentchild-conclusion">
+     <section id="example-parentchild-conclusion">
          <title>Conclusion</title>
 
          <para>
@@ -323,6 +327,6 @@
              cannot own collections and they should not be the child of any entity other than the unique parent.
          </para>
      
-     </sect1>
+     </section>
      
 </chapter>

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/example_weblog.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/example_weblog.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/example_weblog.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,12 +23,16 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="example-weblog">
     <title>Example: Weblog Application</title>
 
-    <sect1 id="example-weblog-classes">
+    <section id="example-weblog-classes">
         <title>Persistent Classes</title>
 
         <para>
@@ -110,9 +114,9 @@
     }
 }]]></programlisting>
 
-    </sect1>
+    </section>
 
-    <sect1 id="example-weblog-mappings">
+    <section id="example-weblog-mappings">
         <title>Hibernate Mappings</title>
 
         <para>
@@ -203,9 +207,9 @@
 
 </hibernate-mapping>]]></programlisting>
 
-    </sect1>
+    </section>
     
-    <sect1 id="example-weblog-code">
+    <section id="example-weblog-code">
         <title>Hibernate Code</title>
 
         <para>
@@ -451,7 +455,7 @@
     }
 }]]></programlisting>
 
-    </sect1>
+    </section>
 
 </chapter>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/filters.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/filters.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/filters.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="filters">
     <title>Filtering data</title>
     
@@ -34,7 +38,7 @@
         enabled or disabled for a particular Hibernate session.
     </para>
 
-    <sect1 id="objectstate-filters" revision="1">
+    <section id="objectstate-filters" revision="1">
         <title>Hibernate filters</title>
 
         <para>
@@ -167,7 +171,7 @@
             particular case.
         </para>
 
-    </sect1>
+    </section>
 
 </chapter>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/inheritance_mapping.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/inheritance_mapping.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/inheritance_mapping.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,12 +23,16 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="inheritance">
     <title>Inheritance mapping</title>
 
-    <sect1 id="inheritance-strategies" revision="3">
+    <section id="inheritance-strategies" revision="3">
         <title>The three strategies</title>
 
         <para>
@@ -99,7 +103,7 @@
  </hibernate-mapping>]]></programlisting>
 
 
-        <sect2 id="inheritance-tableperclass" >
+        <section id="inheritance-tableperclass" >
         <title>Table per class hierarchy</title>
 
         <para>
@@ -134,9 +138,9 @@
             cannot have <literal>NOT NULL</literal> constraints.
         </para>
         
-        </sect2>
+        </section>
 
-        <sect2 id="inheritance-tablepersubclass">
+        <section id="inheritance-tablepersubclass">
         <title>Table per subclass</title>
 
         <para>
@@ -170,9 +174,9 @@
             is actually a one-to-one association.
         </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="inheritance-tablepersubclass-discriminator" revision="2">
+        <section id="inheritance-tablepersubclass-discriminator" revision="2">
         <title>Table per subclass: using a discriminator</title>
 
         <para>
@@ -221,9 +225,9 @@
             outer join when querying the superclass.
         </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="inheritance-mixing-tableperclass-tablepersubclass">
+        <section id="inheritance-mixing-tableperclass-tablepersubclass">
         <title>Mixing table per class hierarchy with table per subclass</title>
 
         <para>
@@ -260,9 +264,9 @@
 
         <programlisting role="XML"><![CDATA[<many-to-one name="payment" column="PAYMENT_ID" class="Payment"/>]]></programlisting>
     
-        </sect2>
+        </section>
 
-        <sect2 id="inheritance-tableperconcrete" revision="2">
+        <section id="inheritance-tableperconcrete" revision="2">
         <title>Table per concrete class</title>
 
         <para>
@@ -309,9 +313,9 @@
             of the superclass.
         </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="inheritance-tableperconcreate-polymorphism">
+        <section id="inheritance-tableperconcreate-polymorphism">
         <title>Table per concrete class using implicit polymorphism</title>
 
         <para>
@@ -349,7 +353,7 @@
             using XML entities
             (for example, <literal>[ &lt;!ENTITY allproperties SYSTEM "allproperties.xml"&gt; ]</literal>
             in the <literal>DOCTYPE</literal> declaration and 
-            <literal>&amp;allproperties;</literal> in the mapping).
+            <literal>&amp;allproperties&semi;</literal> in the mapping).
         </para>
         
         <para>
@@ -370,9 +374,9 @@
     <column name="PAYMENT_ID"/>
 </any>]]></programlisting>
            
-        </sect2>
+        </section>
 
-        <sect2 id="inheritance-mixingpolymorphism">
+        <section id="inheritance-mixingpolymorphism">
         <title>Mixing implicit polymorphism with other inheritance mappings</title>
 
         <para>
@@ -421,11 +425,11 @@
             not instances of <literal>NonelectronicTransaction</literal>.
         </para>
         
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
-    <sect1 id="inheritance-limitations">
+    <section id="inheritance-limitations">
         <title>Limitations</title>
 
         <para>
@@ -514,6 +518,6 @@
             </tgroup>
         </table>
 
-    </sect1>
+    </section>
 
 </chapter>

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/performance.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/performance.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/performance.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,12 +23,16 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="performance">
     <title>Improving performance</title>
 
-    <sect1 id="performance-fetching" revision="2">
+    <section id="performance-fetching" revision="2">
         <title>Fetching strategies</title>
 
         <para>
@@ -139,7 +143,7 @@
             in any detached instance of a particular class.
         </para>
  
-        <sect2 id="performance-fetching-lazy">
+        <section id="performance-fetching-lazy">
             <title>Working with lazy associations</title>
             
             <para>
@@ -198,9 +202,9 @@
                 collections.
             </para>
         
-        </sect2>
+        </section>
         
-        <sect2 id="performance-fetching-custom" revision="4">
+        <section id="performance-fetching-custom" revision="4">
             <title>Tuning fetch strategies</title>
             
             <para>
@@ -278,9 +282,9 @@
                 second-level cache.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="performance-fetching-proxies" revision="2">
+        <section id="performance-fetching-proxies" revision="2">
             <title>Single-ended association proxies</title>
 
             <para>
@@ -427,9 +431,9 @@
                 will result in immediate proxy initialization.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="performance-fetching-initialization" revision="1">
+        <section id="performance-fetching-initialization" revision="1">
             <title>Initializing collections and proxies</title>
 
             <para>
@@ -521,9 +525,9 @@
 
             <programlisting role="JAVA"><![CDATA[s.createFilter( lazyCollection, "").setFirstResult(0).setMaxResults(10).list();]]></programlisting>
 
-        </sect2>
+        </section>
 
-        <sect2 id="performance-fetching-batch">
+        <section id="performance-fetching-batch">
             <title>Using batch fetching</title>
 
             <para>
@@ -575,9 +579,9 @@
                 <emphasis>materialized path</emphasis> might be a better option for read-mostly trees.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="performance-fetching-subselect">
+        <section id="performance-fetching-subselect">
             <title>Using subselect fetching</title>
 
             <para>
@@ -588,9 +592,9 @@
             
             <!-- TODO: Write more about this -->
 
-        </sect2>
+        </section>
 
-        <sect2 id="performance-fetching-profiles">
+        <section id="performance-fetching-profiles">
             <title>Fetch profiles</title>
 
             <para>
@@ -657,9 +661,9 @@
                 styles.  See <ulink url="http://opensource.atlassian.com/projects/hibernate/browse/HHH-3414">HHH-3414</ulink>
                 for details.
             </para>
-        </sect2>
+        </section>
 
-        <sect2 id="performance-fetching-lazyproperties">
+        <section id="performance-fetching-lazyproperties">
             <title>Using lazy property fetching</title>
 
             <para>
@@ -721,10 +725,10 @@
                 properties</literal> in HQL.
             </para>
 
-        </sect2>
-    </sect1>
+        </section>
+    </section>
 
-    <sect1 id="performance-cache" revision="1">
+    <section id="performance-cache" revision="1">
         <title>The Second Level Cache</title>
 
         <para>
@@ -809,7 +813,7 @@
             </tgroup>
         </table>
 
-        <sect2 id="performance-cache-mapping" revision="2">
+        <section id="performance-cache-mapping" revision="2">
             <title>Cache mappings</title>
 
             <para>
@@ -865,9 +869,9 @@
                 The <literal>usage</literal> attribute specifies a <emphasis>cache concurrency strategy</emphasis>.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="performance-cache-readonly">
+        <section id="performance-cache-readonly">
             <title>Strategy: read only</title>
 
             <para>
@@ -881,10 +885,10 @@
     ....
 </class>]]></programlisting>
 
-        </sect2>
+        </section>
 
 
-        <sect2 id="performance-cache-readwrite">
+        <section id="performance-cache-readwrite">
             <title>Strategy: read/write</title>
 
             <para>
@@ -907,9 +911,9 @@
     </set>
 </class>]]></programlisting>
 
-        </sect2>
+        </section>
 
-        <sect2 id="performance-cache-nonstrict">
+        <section id="performance-cache-nonstrict">
             <title>Strategy: nonstrict read/write</title>
 
             <para>
@@ -921,9 +925,9 @@
                 <literal>Session.close()</literal> or <literal>Session.disconnect()</literal> is called.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="performance-cache-transactional">
+        <section id="performance-cache-transactional">
             <title>Strategy: transactional</title>
 
             <para>
@@ -932,9 +936,9 @@
                 specify <literal>hibernate.transaction.manager_lookup_class</literal>. 
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="performance-cache-compat-matrix">
+        <section id="performance-cache-compat-matrix">
             <title>Cache-provider/concurrency-strategy compatibility</title>
 
             <important>
@@ -1011,11 +1015,11 @@
                 </tgroup>
             </table>
 
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
-    <sect1 id="performance-sessioncache" revision="2">
+    <section id="performance-sessioncache" revision="2">
         <title>Managing the caches</title>
 
         <para>
@@ -1109,9 +1113,9 @@
         <programlisting><![CDATA[hibernate.generate_statistics true
 hibernate.cache.use_structured_entries true]]></programlisting>       
                 
-    </sect1>
+    </section>
 
-    <sect1 id="performance-querycache" revision="1">
+    <section id="performance-querycache" revision="1">
         <title>The Query Cache</title>
 
         <para>
@@ -1119,7 +1123,7 @@
             frequently with the same parameters.
         </para>
 
-        <sect2 id="performance-querycache-enable">
+        <section id="performance-querycache-enable">
             <title>Enabling query caching</title>
             <para>
                 Caching of query results introduces some overhead in terms of your applications normal
@@ -1175,9 +1179,9 @@
                     collection caching).
                 </para>
             </note>
-        </sect2>
+        </section>
 
-        <sect2 id="performance-querycache-regions">
+        <section id="performance-querycache-regions">
             <title>Query cache regions</title>
             <para>
                 If you require fine-grained control over query cache expiration policies, you can
@@ -1201,10 +1205,10 @@
                 efficient alternative to bulk eviction of the region via
                 <literal>org.hibernate.SessionFactory.evictQueries()</literal>.
             </para>
-        </sect2>
-    </sect1>
+        </section>
+    </section>
 
-    <sect1 id="performance-collections">
+    <section id="performance-collections">
         <title>Understanding Collection performance</title>
 
         <para>
@@ -1213,7 +1217,7 @@
             collections at runtime.
         </para>
 
-        <sect2 id="performance-collections-taxonomy">
+        <section id="performance-collections-taxonomy">
             <title>Taxonomy</title>
 
             <para>Hibernate defines three basic kinds of collections:</para>
@@ -1290,9 +1294,9 @@
                 collection.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="performance-collections-mostefficientupdate">
+        <section id="performance-collections-mostefficientupdate">
             <title>Lists, maps, idbags and sets are the most efficient collections to update</title>
 
             <para>
@@ -1325,9 +1329,9 @@
                 considerations of collection update performance simply do not apply.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="performance-collections-mostefficentinverse">
+        <section id="performance-collections-mostefficentinverse">
             <title>Bags and lists are the most efficient inverse collections</title>
 
             <para>
@@ -1346,9 +1350,9 @@
 p.getChildren().add(c);  //no need to fetch the collection!
 sess.flush();]]></programlisting>
 
-        </sect2>
+        </section>
 
-        <sect2 id="performance-collections-oneshotdelete">
+        <section id="performance-collections-oneshotdelete">
             <title>One shot delete</title>
 
             <para>
@@ -1395,11 +1399,11 @@
                 One-shot-delete does not apply to collections mapped <literal>inverse="true"</literal>.
             </para>
 
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
-    <sect1 id="performance-monitoring" revision="1">
+    <section id="performance-monitoring" revision="1">
         <title>Monitoring performance</title>
 
         <para>
@@ -1408,7 +1412,7 @@
             Statistics in Hibernate are available per <literal>SessionFactory</literal>.
         </para>
 
-        <sect2 id="performance-monitoring-sf" revision="2">
+        <section id="performance-monitoring-sf" revision="2">
             <title>Monitoring a SessionFactory</title>
 
             <para>
@@ -1469,9 +1473,9 @@
                 method.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="performance-monitoring-metrics" revision="1">
+        <section id="performance-monitoring-metrics" revision="1">
             <title>Metrics</title>
 
             <para>
@@ -1542,8 +1546,8 @@
                 <literal>getSecondLevelCacheRegionNames()</literal>.
             </para>
 
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
 </chapter>

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/persistent_classes.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/persistent_classes.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/persistent_classes.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="persistent-classes" revision="2">
     <title>Persistent Classes</title>
 
@@ -43,7 +47,7 @@
         ways (using trees of <literal>Map</literal> instances, for example).
     </para>
 
-    <sect1 id="persistent-classes-pojo">
+    <section id="persistent-classes-pojo">
         <title>A simple POJO example</title>
 
         <para>
@@ -134,7 +138,7 @@
         </para>
 
 
-        <sect2 id="persistent-classes-pojo-constructor" revision="1">
+        <section id="persistent-classes-pojo-constructor" revision="1">
             <title>Implement a no-argument constructor</title>
 
             <para>
@@ -144,9 +148,9 @@
                 default constructor with at least <emphasis>package</emphasis> visibility for runtime proxy 
                 generation in Hibernate.
             </para>
-        </sect2>
+        </section>
 
-        <sect2 id="persistent-classes-pojo-identifier" revision="2">
+        <section id="persistent-classes-pojo-identifier" revision="2">
             <title>Provide an identifier property (optional)</title>
 
             <para>
@@ -191,9 +195,9 @@
                 We recommend that you declare consistently-named identifier properties on persistent
                 classes and that you use a nullable (i.e., non-primitive) type.
             </para>
-        </sect2>
+        </section>
 
-        <sect2 id="persistent-classes-pojo-final">
+        <section id="persistent-classes-pojo-final">
             <title>Prefer non-final classes (optional)</title>
             <para>
                 A central feature of Hibernate, <emphasis>proxies</emphasis>, depends upon the
@@ -210,9 +214,9 @@
                 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"</literal>.
             </para>
-        </sect2>
+        </section>
         
-        <sect2 id="persistent-classes-pojo-accessors" revision="2">
+        <section id="persistent-classes-pojo-accessors" revision="2">
             <title>Declare accessors and mutators for persistent fields (optional)</title>
 
             <para>
@@ -231,11 +235,11 @@
                 <literal>private</literal> get / set pair.
             </para>
 
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
-    <sect1 id="persistent-classes-inheritance">
+    <section id="persistent-classes-inheritance">
         <title>Implementing inheritance</title>
 
         <para>
@@ -255,9 +259,9 @@
                 this.name=name;
         }
 }]]></programlisting>
-    </sect1>
+    </section>
 
-    <sect1 id="persistent-classes-equalshashcode" revision="1">
+    <section id="persistent-classes-equalshashcode" revision="1">
         <title>Implementing <literal>equals()</literal> and <literal>hashCode()</literal></title>
 
         <para>
@@ -340,9 +344,9 @@
             candidates for a business key.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="persistent-classes-dynamicmodels">
+    <section id="persistent-classes-dynamicmodels">
         <title>Dynamic models</title>
 
         
@@ -485,9 +489,9 @@
             in <xref linkend="xml"/>.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="persistent-classes-tuplizers" revision="1">
+    <section id="persistent-classes-tuplizers" revision="1">
         <title>Tuplizers</title>
 
         <para>
@@ -554,10 +558,10 @@
 }]]></programlisting>
 
 
-    </sect1>
+    </section>
 
 
-    <sect1 id="persistent-classes-entity-name-resolver" revision="0">
+    <section id="persistent-classes-entity-name-resolver" revision="0">
         <title>EntityNameResolvers</title>
 
         <para>
@@ -701,7 +705,7 @@
                 </listitem>
             </orderedlist>
         </para>
-    </sect1>
+    </section>
 
 </chapter>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/portability.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/portability.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/portability.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -20,12 +20,17 @@
   ~ 51 Franklin Street, Fifth Floor
   ~ Boston, MA  02110-1301  USA
   -->
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
 
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
+
+]>
+
 <chapter id="portability">
     <title>Database Portability Considerations</title>
 
-    <sect1 id="portability-basics">
+    <section id="portability-basics">
         <title>Portability Basics</title>
 
         <para>
@@ -36,9 +41,9 @@
             the exact scenario, the basic idea is that you want Hibernate to help you run against any number
             of databases without changes to your code, and ideally without any changes to the mapping metadata.
         </para>
-    </sect1>
+    </section>
 
-    <sect1 id="portability-dialect">
+    <section id="portability-dialect">
         <title>Dialect</title>
 
         <para>
@@ -49,9 +54,9 @@
             of dialects for many of the most popular databases.  If you find that your particular database is
             not among them, it is not terribly difficult to write your own.
         </para>
-    </sect1>
+    </section>
 
-    <sect1 id="portability-dialectresolver">
+    <section id="portability-dialectresolver">
         <title>Dialect resolution</title>
 
         <para>
@@ -92,9 +97,9 @@
             <constant>DIALECT_RESOLVERS</constant> constant on
             <classname>org.hibernate.cfg.Environment</classname>).
         </para>
-    </sect1>
+    </section>
 
-    <sect1 id="portability-idgen">
+    <section id="portability-idgen">
         <title>Identifier generation</title>
 
         <para>
@@ -148,9 +153,9 @@
             <classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname> mimics the behavior of
             a sequence on databases which do not support sequences by using a table.
         </para>
-    </sect1>
+    </section>
 
-    <sect1 id="portability-functions">
+    <section id="portability-functions">
         <title>Database functions</title>
 
         <warning>
@@ -181,9 +186,9 @@
                 </para>
             </important>
         </para>
-    </sect1>
+    </section>
 
-    <sect1 id="portability-types">
+    <section id="portability-types">
         <title>Type mappings</title>
 
         <para>
@@ -192,13 +197,13 @@
 
         <!--
             todo :
-        <sect2 id="portability-types-lobs">
+        <section id="portability-types-lobs">
             <title>BLOB/CLOB mappings</title>
-        </sect2>
+        </section>
 
-        <sect2 id="portability-types-bool">
+        <section id="portability-types-bool">
             <title>Boolean mappings</title>
-        </sect2>
+        </section>
         -->
-    </sect1>
-</chapter>
\ No newline at end of file
+    </section>
+</chapter>

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/preface.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/preface.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/preface.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE preface PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <preface id="preface">
     <title>Preface</title>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/query_criteria.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/query_criteria.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/query_criteria.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="querycriteria">
     <title>Criteria Queries</title>
 
@@ -32,7 +36,7 @@
         Hibernate features an intuitive, extensible criteria query API.
     </para>
     
-    <sect1 id="querycriteria-creating">
+    <section id="querycriteria-creating">
         <title>Creating a <literal>Criteria</literal> instance</title>
 
         <para>
@@ -45,9 +49,9 @@
 crit.setMaxResults(50);
 List cats = crit.list();]]></programlisting>
 
-    </sect1>
+    </section>
      
-    <sect1 id="querycriteria-narrowing">
+    <section id="querycriteria-narrowing">
         <title>Narrowing the result set</title>
 
         <para>
@@ -117,9 +121,9 @@
     .add( Property.forName("name").in( new String[] { "Fritz", "Izi", "Pk" } ) )
     .list();]]></programlisting>
     
-   </sect1>
+   </section>
      
-    <sect1 id="querycriteria-ordering">
+    <section id="querycriteria-ordering">
         <title>Ordering the results</title>
 
         <para>
@@ -140,9 +144,9 @@
     .setMaxResults(50)
     .list();]]></programlisting>
     
-    </sect1>
+    </section>
     
-    <sect1 id="querycriteria-associations" revision="2">
+    <section id="querycriteria-associations" revision="2">
         <title>Associations</title>
 
         <para>
@@ -224,9 +228,9 @@
 	<para>
 		Thirdly, in memory; the lists would need to be joined manually.
 	</para>
-    </sect1>
+    </section>
     
-    <sect1 id="querycriteria-dynamicfetching" revision="1">
+    <section id="querycriteria-dynamicfetching" revision="1">
         <title>Dynamic association fetching</title>
 
         <para>
@@ -245,9 +249,9 @@
             by outer join. See <xref linkend="performance-fetching"/> for more information.
         </para>
     
-    </sect1>
+    </section>
      
-    <sect1 id="querycriteria-examples">
+    <section id="querycriteria-examples">
         <title>Example queries</title>
 
         <para>
@@ -290,9 +294,9 @@
         .add( Example.create( cat.getMate() ) )
     .list();]]></programlisting>
     
-    </sect1>
+    </section>
     
-    <sect1 id="querycriteria-projection">
+    <section id="querycriteria-projection">
         <title>Projections, aggregation and grouping</title>
         <para>
             The class <literal>org.hibernate.criterion.Projections</literal> is a
@@ -384,9 +388,9 @@
     .addOrder( Order.desc("avgWeight") )
     .list();]]></programlisting>
     
-    </sect1>
+    </section>
     
-    <sect1 id="querycriteria-detachedqueries">
+    <section id="querycriteria-detachedqueries">
         <title>Detached queries and subqueries</title>
         <para>
             The <literal>DetachedCriteria</literal> class allows you to create a query outside the scope 
@@ -431,13 +435,13 @@
     .add( Property.forName("weight").gt(avgWeightForSex) )
     .list();]]></programlisting>
 
-    </sect1>
+    </section>
 
         <!--TODO: ResultSetTransformer + aliasing. AliasToBeanTransformer allow returning arbitrary 
                   user objects - similar to setResultClass in JDO2. General use of ResultTransformer 
                   could also be explained. -->
                
-    <sect1 id="query-criteria-naturalid">
+    <section id="query-criteria-naturalid">
         <title>Queries by natural identifier</title>
         
         <para>
@@ -483,6 +487,6 @@
     ).setCacheable(true)
     .uniqueResult();]]></programlisting>
             
-    </sect1>
+    </section>
     
 </chapter>

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/query_hql.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/query_hql.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/query_hql.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="queryhql" revision="1">
     <title>HQL: The Hibernate Query Language</title>
 
@@ -34,7 +38,7 @@
         and understands notions like inheritance, polymorphism and association.
     </para>
 
-    <sect1 id="queryhql-casesensitivity">
+    <section id="queryhql-casesensitivity">
         <title>Case Sensitivity</title>
 
         <para>
@@ -53,9 +57,9 @@
             more readable, but this convention is unsuitable for queries embedded in Java code.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="queryhql-from">
+    <section id="queryhql-from">
         <title>The from clause</title>
 
         <para>
@@ -101,9 +105,9 @@
             (e.g. <literal>domesticCat</literal>).
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="queryhql-joins" revision="2">
+    <section id="queryhql-joins" revision="2">
         <title>Associations and joins</title>
 
         <para>
@@ -213,9 +217,9 @@
         <programlisting><![CDATA[from Document fetch all properties order by name]]></programlisting>
         <programlisting><![CDATA[from Document doc fetch all properties where lower(doc.name) like '%cats%']]></programlisting>
 
-    </sect1>
+    </section>
 
-    <sect1 id="queryhql-joins-forms">
+    <section id="queryhql-joins-forms">
         <title>Forms of join syntax</title>
 
 	    <para>
@@ -235,9 +239,9 @@
 	    </para>
 
         <programlisting><![CDATA[from Cat as cat where cat.mate.name like '%s%']]></programlisting>
-	</sect1>
+	</section>
 
-    <sect1 id="queryhql-identifier-property">
+    <section id="queryhql-identifier-property">
         <title>Referring to identifier property</title>
 
         <para>
@@ -274,9 +278,9 @@
         </para>
 	</important>  
 
-  </sect1>
+  </section>
 
-    <sect1 id="queryhql-select">
+    <section id="queryhql-select">
         <title>The select clause</title>
 
         <para>
@@ -351,9 +355,9 @@
             This query returns a <literal>Map</literal> from aliases to selected values.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="queryhql-aggregation">
+    <section id="queryhql-aggregation">
         <title>Aggregate functions</title>
 
         <para>
@@ -416,9 +420,9 @@
 
 select count(distinct cat.name), count(cat) from Cat cat]]></programlisting>
 
-    </sect1>
+    </section>
 
-    <sect1 id="queryhql-polymorphism">
+    <section id="queryhql-polymorphism">
         <title>Polymorphic queries</title>
 
         <para>
@@ -450,9 +454,9 @@
             It also means you cannot call these queries using <literal>Query.scroll()</literal>.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="queryhql-where" revision="1">
+    <section id="queryhql-where" revision="1">
         <title>The where clause</title>
 
         <para>
@@ -577,9 +581,9 @@
             would refer to the values of completely different database columns in the above query.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="queryhql-expressions">
+    <section id="queryhql-expressions">
         <title>Expressions</title>
 
         <para>
@@ -870,9 +874,9 @@
             AND cust.current_order = o.id
     )]]></programlisting>
 
-    </sect1>
+    </section>
 
-    <sect1 id="queryhql-ordering">
+    <section id="queryhql-ordering">
         <title>The order by clause</title>
 
         <para>
@@ -886,9 +890,9 @@
             The optional <literal>asc</literal> or <literal>desc</literal> indicate ascending or descending order
             respectively.
         </para>
-    </sect1>
+    </section>
 
-    <sect1 id="queryhql-grouping" revision="1">
+    <section id="queryhql-grouping" revision="1">
         <title>The group by clause</title>
 
         <para>
@@ -934,9 +938,9 @@
             non-aggregated properties explicitly.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="queryhql-subqueries" revision="3">
+    <section id="queryhql-subqueries" revision="3">
         <title>Subqueries</title>
 
         <para>
@@ -977,9 +981,9 @@
             <xref linkend="queryhql-tuple"/> for more information.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="queryhql-examples">
+    <section id="queryhql-examples">
         <title>HQL examples</title>
 
         <para>
@@ -1100,9 +1104,9 @@
     and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, PaymentStatus.UNPAID)
 order by account.type.sortOrder, account.accountNumber, payment.dueDate]]></programlisting>
 
-   </sect1>
+   </section>
 
-    <sect1 id="queryhql-bulk" revision="2">
+    <section id="queryhql-bulk" revision="2">
         <title>Bulk update and delete</title>
 
         <para>
@@ -1110,9 +1114,9 @@
             <literal>insert ... select ...</literal> statements.
             See <xref linkend="batch-direct"/> for more information.
         </para>
-    </sect1>
+    </section>
 
-    <sect1 id="queryhql-tipstricks">
+    <section id="queryhql-tipstricks">
         <title>Tips &amp; Tricks</title>
 
         <para>
@@ -1190,9 +1194,9 @@
 
         <programlisting role="JAVA"><![CDATA[( (Integer) session.createQuery("select count(*) from ....").iterate().next() ).intValue();]]></programlisting>
 
-    </sect1>
+    </section>
 
-    <sect1 id="queryhql-components">
+    <section id="queryhql-components">
         <title>Components</title>
 
         <para>
@@ -1221,9 +1225,9 @@
         <para>
             Another common use of components is in <link linkend="queryhql-tuple">row value constructors</link>.
         </para>
-    </sect1>
+    </section>
 
-    <sect1 id="queryhql-tuple">
+    <section id="queryhql-tuple">
         <title>Row value constructor syntax</title>
 
         <para>
@@ -1263,7 +1267,7 @@
             be dependent upon the ordering of the component sub-properties in the metadata.
         </para>
 
-    </sect1>
+    </section>
 
 </chapter>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/query_sql.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/query_sql.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/query_sql.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="querysql" revision="2">
   <title>Native SQL</title>
 
@@ -37,7 +41,7 @@
   <para>Hibernate3 allows you to specify handwritten SQL, including stored
   procedures, for all create, update, delete, and load operations.</para>
 
-  <sect1 id="querysql-creating" revision="4">
+  <section id="querysql-creating" revision="4">
     <title>Using a <literal>SQLQuery</literal></title>
 
     <para>Execution of native SQL queries is controlled via the
@@ -45,7 +49,7 @@
     <literal>Session.createSQLQuery()</literal>. The following sections describe how
     to use this API for querying.</para>
 
-    <sect2>
+    <section>
       <title>Scalar queries</title>
 
       <para>The most basic SQL query is to get a list of scalars
@@ -108,9 +112,9 @@
       not mapped, or does not result in the expected type, it is possible to
       customize it via calls to <literal>registerHibernateType</literal> in
       the Dialect.</para>
-    </sect2>
+    </section>
 
-    <sect2>
+    <section>
       <title>Entity queries</title>
 
       <para>The above queries were all about returning scalar values,
@@ -150,9 +154,9 @@
 ]]></programlisting>
 
       <para>This will allow cat.getDog() to function properly.</para>
-    </sect2>
+    </section>
 
-    <sect2>
+    <section>
       <title>Handling associations and collections</title>
 
       <para>It is possible to eagerly join in the <literal>Dog</literal> to
@@ -183,9 +187,9 @@
             enhance the sql queries to make them usable in Hibernate. Problems can arise when returning
             multiple entities of the same type or when the default alias/column names are not enough.
         </para>
-    </sect2>
+    </section>
 
-    <sect2>
+    <section>
       <title>Returning multiple entities</title>
 
       <para>Until now, the result set column names are assumed to be the same
@@ -251,7 +255,7 @@
         .addEntity("mother", Cat.class).list()
 ]]></programlisting>
 
-      <sect3 id="querysql-aliasreferences" revision="2">
+      <section id="querysql-aliasreferences" revision="2">
         <title>Alias and property references</title>
 
         <para>In most cases the above alias injection is needed. For
@@ -368,10 +372,10 @@
             </tbody>
           </tgroup>
         </table>
-      </sect3>
-    </sect2>
+      </section>
+    </section>
 
-    <sect2>
+    <section>
       <title>Returning non-managed entities</title>
 
       <para>It is possible to apply a ResultTransformer to native SQL queries, allowing it to return non-managed entities.</para>
@@ -395,17 +399,17 @@
         The above query will return a list of <literal>CatDTO</literal> which has been instantiated and injected the values of NAME and BIRTHNAME into its corresponding
         properties or fields.
         </para>
-    </sect2>
+    </section>
 
-    <sect2>
+    <section>
       <title>Handling inheritance</title>
 
       <para>Native SQL queries which query for entities that are mapped as part
       of an inheritance must include all properties for the baseclass and all
       its subclasses.</para>
-    </sect2>
+    </section>
 
-    <sect2>
+    <section>
       <title>Parameters</title>
 
       <para>Native SQL queries support positional as well as named
@@ -416,13 +420,13 @@
      
 query = sess.createSQLQuery("SELECT * FROM CATS WHERE NAME like :name").addEntity(Cat.class);
 List pusList = query.setString("name", "Pus%").list();          ]]></programlisting>
-    </sect2>
+    </section>
     
     
         
-  </sect1>
+  </section>
 
-  <sect1 id="querysql-namedqueries" revision="3">
+  <section id="querysql-namedqueries" revision="3">
     <title>Named SQL queries</title>
 
     <para>Named SQL queries can be defined in the mapping document and called
@@ -509,7 +513,7 @@
     .setResultSetMapping("catAndKitten")
     .list();]]></programlisting>
 
-    <sect2 id="propertyresults">
+    <section id="propertyresults">
       <title>Using return-property to explicitly specify column/alias
       names</title>
 
@@ -560,9 +564,9 @@
       <para>If your mapping has a discriminator you must use
       <literal>&lt;return-discriminator&gt;</literal> to specify the
       discriminator column.</para>
-    </sect2>
+    </section>
 
-    <sect2 id="sp_query" revision="1">
+    <section id="sp_query" revision="1">
       <title>Using stored procedures for querying</title>
 
       <para>Hibernate3 provides support for queries via stored procedures
@@ -607,7 +611,7 @@
       entities. <literal>&lt;return-join&gt;</literal> and
       <literal>&lt;load-collection&gt;</literal> are not supported.</para>
 
-      <sect3 id="querysql-limits-storedprocedures" revision="1">
+      <section id="querysql-limits-storedprocedures" revision="1">
         <title>Rules/limitations for using stored procedures</title>
 
         <para>You cannot use stored procedures with Hibernate unless you follow some procedure/function
@@ -655,11 +659,11 @@
             requirement.</para>
           </listitem>
         </itemizedlist>
-      </sect3>
-    </sect2>
-  </sect1>
+      </section>
+    </section>
+  </section>
 
-  <sect1 id="querysql-cud">
+  <section id="querysql-cud">
     <title>Custom SQL for create, update and delete</title>
 
     <para>Hibernate3 can use custom SQL for create, update, and delete operations.
@@ -731,9 +735,9 @@
     return SQL%ROWCOUNT;
 
 END updatePerson;]]></programlisting>
-  </sect1>
+  </section>
 
-  <sect1 id="querysql-load">
+  <section id="querysql-load">
     <title>Custom SQL for loading</title>
 
     <para>You can also declare your own SQL (or HQL) queries for entity
@@ -792,5 +796,5 @@
         ON pers.ID = emp.PERSON_ID
     WHERE ID=?
 </sql-query>]]></programlisting>
-  </sect1>
+  </section>
 </chapter>

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/session_api.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/session_api.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/session_api.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="objectstate">
     <title>Working with objects</title>
 
@@ -44,7 +48,7 @@
         relevant for the application developer when tuning the performance of the system.
     </para>
 
-    <sect1 id="objectstate-overview">
+    <section id="objectstate-overview">
         <title>Hibernate object states</title>
 
         <para>
@@ -95,9 +99,9 @@
             trigger a transition) in more detail.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="objectstate-makingpersistent" revision="1">
+    <section id="objectstate-makingpersistent" revision="1">
         <title>Making objects persistent</title>
 
         <para>
@@ -177,9 +181,9 @@
             Transitive persistence is discussed later in this chapter.
         </para>
         
-    </sect1>
+    </section>
 
-    <sect1 id="objectstate-loading">
+    <section id="objectstate-loading">
         <title>Loading an object</title>
 
         <para>
@@ -259,9 +263,9 @@
             <xref linkend="performance-fetching"/>.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="objectstate-querying" revision="1">
+    <section id="objectstate-querying" revision="1">
         <title>Querying</title>
 
         <para>
@@ -273,7 +277,7 @@
             optional support from Hibernate for result set conversion into objects.
         </para>
 
-        <sect2 id="objectstate-querying-executing" revision="1">
+        <section id="objectstate-querying-executing" revision="1">
             <title>Executing queries</title>
 
             <para>
@@ -318,7 +322,7 @@
                 these duplicates through a <literal>Set</literal>.
             </para>
 
-            <sect3 id="objectstate-querying-executing-iterate">
+            <section id="objectstate-querying-executing-iterate">
                 <title>Iterating results</title>
 
                 <para>
@@ -345,9 +349,9 @@
         break;
     }
 }]]></programlisting>
-            </sect3>
+            </section>
             
-            <sect3 id="objectstate-querying-executing-tuples">
+            <section id="objectstate-querying-executing-tuples">
                 <title>Queries that return tuples</title>
 
                 <para>
@@ -367,9 +371,9 @@
     ....
 }]]></programlisting>
 
-            </sect3>
+            </section>
 
-            <sect3 id="objectstate-querying-executing-scalar" revision="1">
+            <section id="objectstate-querying-executing-scalar" revision="1">
                 <title>Scalar results</title>
 
                 <para>
@@ -392,9 +396,9 @@
     .....
 }]]></programlisting>
 
-            </sect3>
+            </section>
 
-            <sect3 id="objectstate-querying-executing-parameters">
+            <section id="objectstate-querying-executing-parameters">
                 <title>Bind parameters</title>
 
                 <para>
@@ -442,9 +446,9 @@
 q.setParameterList("namesList", names);
 List cats = q.list();]]></programlisting>
 
-            </sect3>
+            </section>
 
-            <sect3 id="objectstate-querying-executing-pagination">
+            <section id="objectstate-querying-executing-pagination">
                 <title>Pagination</title>
 
                 <para>
@@ -463,9 +467,9 @@
                     SQL of your DBMS.
                 </para>
 
-            </sect3>
+            </section>
 
-            <sect3 id="objectstate-querying-executing-scrolling">
+            <section id="objectstate-querying-executing-scrolling">
                 <title>Scrollable iteration</title>
 
                 <para>
@@ -503,9 +507,9 @@
                     if you need offline pagination functionality.
                 </para>
 
-            </sect3>
+            </section>
 
-            <sect3 id="objectstate-querying-executing-named" revision="1">
+            <section id="objectstate-querying-executing-named" revision="1">
                 <title>Externalizing named queries</title>
 
                 <para>
@@ -543,11 +547,11 @@
                     <literal>eg.Cat.ByNameAndMaximumWeight</literal>.
                 </para>
 
-            </sect3>
+            </section>
 
-        </sect2>
+        </section>
 
-        <sect2 id="objectstate-filtering" revision="1">
+        <section id="objectstate-filtering" revision="1">
             <title>Filtering collections</title>
             <para>
                 A collection <emphasis>filter</emphasis> is a special type of query that can be applied to
@@ -588,9 +592,9 @@
     .setFirstResult(0).setMaxResults(10)
     .list();]]></programlisting>
 
-        </sect2>
+        </section>
 
-        <sect2 id="objecstate-querying-criteria" revision="1">
+        <section id="objecstate-querying-criteria" revision="1">
            <title>Criteria queries</title>
 
             <para>
@@ -609,9 +613,9 @@
                 API are discussed in more detail in <xref linkend="querycriteria"/>.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="objectstate-querying-nativesql" revision="2">
+        <section id="objectstate-querying-nativesql" revision="2">
             <title>Queries in native SQL</title>
 
             <para>
@@ -639,11 +643,11 @@
                 <xref linkend="querysql"/>.
             </para>
 
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
-    <sect1 id="objectstate-modifying" revision="1">
+    <section id="objectstate-modifying" revision="1">
         <title>Modifying persistent objects</title>
 
         <para>
@@ -682,9 +686,9 @@
         </para>
 </important>
 
-    </sect1>
+    </section>
 
-    <sect1 id="objectstate-detached" revision="2">
+    <section id="objectstate-detached" revision="2">
         <title>Modifying detached objects</title>
 
         <para>
@@ -757,9 +761,9 @@
             Other models for long units of work are discussed in <xref linkend="transactions-optimistic"/>.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="objectstate-saveorupdate">
+    <section id="objectstate-saveorupdate">
         <title>Automatic state detection</title>
 
         <para>
@@ -895,9 +899,9 @@
             </listitem>
         </itemizedlist>
 
-    </sect1>
+    </section>
 
-    <sect1 id="objectstate-deleting" revision="1">
+    <section id="objectstate-deleting" revision="1">
         <title>Deleting persistent objects</title>
 
         <para>
@@ -917,9 +921,9 @@
             children.
         </para>
 
-    </sect1>
+    </section>
     
-    <sect1 id="objectstate-replicating" revision="1">
+    <section id="objectstate-replicating" revision="1">
     	<title>Replicating object between two different datastores</title>
     	
     	<para>
@@ -981,9 +985,9 @@
             rolling back changes made during non-ACID transactions and more.
         </para>
     	
-    </sect1>
+    </section>
 
-    <sect1 id="objectstate-flushing">
+    <section id="objectstate-flushing">
         <title>Flushing the Session</title>
 
         <para>
@@ -1094,9 +1098,9 @@
             behavior, we discuss it in <xref linkend="transactions"/>.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="objectstate-transitive" revision="1">
+    <section id="objectstate-transitive" revision="1">
         <title>Transitive persistence</title>
 
         <para>
@@ -1248,9 +1252,9 @@
             <literal>Session</literal>.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="objectstate-metadata">
+    <section id="objectstate-metadata">
         <title>Using metadata</title>
 
         <para>
@@ -1282,7 +1286,7 @@
     }
 }]]></programlisting>
         
-    </sect1>
+    </section>
 
 </chapter>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/toolset_guide.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/toolset_guide.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/toolset_guide.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="toolsetguide" revision="2">
     <title>Toolset Guide</title>
 
@@ -75,7 +79,7 @@
         be used from "inside" Hibernate.
     </para>
 
-    <sect1 id="toolsetguide-s1" revision="2">
+    <section id="toolsetguide-s1" revision="2">
         <title>Automatic schema generation</title>
 
         <para>
@@ -95,7 +99,7 @@
             First, you must customize your mapping files to improve the generated schema. The next section covers schema customization.  
         </para>
 
-        <sect2 id="toolsetguide-s1-2" revision="3">
+        <section id="toolsetguide-s1-2" revision="3">
             <title>Customizing the schema</title>
 
             <para>
@@ -304,9 +308,9 @@
                 DDL where supported.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="toolsetguide-s1-3" revision="2">
+        <section id="toolsetguide-s1-3" revision="2">
             <title>Running the tool</title>
 
             <para>
@@ -384,9 +388,9 @@
             <programlisting role="JAVA"><![CDATA[Configuration cfg = ....;
 new SchemaExport(cfg).create(false, true);]]></programlisting>
 
-        </sect2>
+        </section>
 
-        <sect2 id="toolsetguide-s1-4">
+        <section id="toolsetguide-s1-4">
             <title>Properties</title>
 
             <para>
@@ -445,9 +449,9 @@
                 </tgroup>
             </table>
 
-        </sect2>
+        </section>
 
-        <sect2 id="toolsetguide-s1-5">
+        <section id="toolsetguide-s1-5">
             <title>Using Ant</title>
 
             <para>
@@ -472,9 +476,9 @@
     </schemaexport>
 </target>]]></programlisting>
 
-        </sect2>
+        </section>
 
-        <sect2 id="toolsetguide-s1-6" revision="2">
+        <section id="toolsetguide-s1-6" revision="2">
             <title>Incremental schema updates</title>
 
             <para>
@@ -531,9 +535,9 @@
             <programlisting role="JAVA"><![CDATA[Configuration cfg = ....;
 new SchemaUpdate(cfg).execute(false);]]></programlisting>
 
-        </sect2>
+        </section>
 
-        <sect2 id="toolsetguide-s1-7">
+        <section id="toolsetguide-s1-7">
             <title>Using Ant for incremental schema updates</title>
 
             <para>
@@ -554,9 +558,9 @@
     </schemaupdate>
 </target>]]></programlisting>
 
-        </sect2>
+        </section>
 
-        <sect2 id="toolsetguide-s1-8" revision="1">
+        <section id="toolsetguide-s1-8" revision="1">
             <title>Schema validation</title>
 
             <para>
@@ -606,9 +610,9 @@
             <programlisting role="JAVA"><![CDATA[Configuration cfg = ....;
 new SchemaValidator(cfg).validate();]]></programlisting>
 
-        </sect2>
+        </section>
 
-        <sect2 id="toolsetguide-s1-9">
+        <section id="toolsetguide-s1-9">
             <title>Using Ant for schema validation</title>
 
             <para>
@@ -628,9 +632,9 @@
     </schemavalidator>
 </target>]]></programlisting>
 
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
 </chapter>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/transactions.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/transactions.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/transactions.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="transactions" revision="2">
     <title>Transactions and Concurrency</title>
 
@@ -56,7 +60,7 @@
         <literal>Session</literal>, as well as database transactions and long conversations.
     </para>
 
-    <sect1 id="transactions-basics" revision="1">
+    <section id="transactions-basics" revision="1">
         <title>Session and transaction scopes</title>
 
         <para>
@@ -88,7 +92,7 @@
             database transaction boundaries? These questions are addressed in the following sections.
         </para>
 
-        <sect2 id="transactions-basics-uow" revision="1">
+        <section id="transactions-basics-uow" revision="1">
             <title>Unit of work</title>
 
             <para>
@@ -167,9 +171,9 @@
                 this <emphasis>Open Session in View</emphasis> pattern.
              </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="transactions-basics-apptx" revision="1">
+        <section id="transactions-basics-apptx" revision="1">
             <title>Long conversations</title>
 
             <para>
@@ -261,9 +265,9 @@
                 These disadvantages are discussed later in this chapter in the context of optimistic concurrency control.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="transactions-basics-identity">
+        <section id="transactions-basics-identity">
             <title>Considering object identity</title>
 
             <para>
@@ -328,9 +332,9 @@
                 a Hibernate issue, but simply how Java object identity and equality has to be implemented.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="transactions-basics-issues">
+        <section id="transactions-basics-issues">
             <title>Common issues</title>
 
              <para>
@@ -378,11 +382,11 @@
                 </listitem>
             </itemizedlist>
 
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
-    <sect1 id="transactions-demarcation">
+    <section id="transactions-demarcation">
         <title>Database transaction demarcation</title>
 
         <para>
@@ -447,7 +451,7 @@
         </para>
 
 
-        <sect2 id="transactions-demarcation-nonmanaged" revision="2">
+        <section id="transactions-demarcation-nonmanaged" revision="2">
             <title>Non-managed environment</title>
 
             <para>
@@ -520,9 +524,9 @@
                 <literal>hibernate.current_session_context_class</literal>.
             </para>
             
-        </sect2>
+        </section>
 
-        <sect2 id="transactions-demarcation-jta" revision="3">
+        <section id="transactions-demarcation-jta" revision="3">
             <title>Using JTA</title>
 
             <para>
@@ -623,9 +627,9 @@
                 <literal>iterate()</literal> from the JTA or CMT code.)
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="transactions-demarcation-exceptions">
+        <section id="transactions-demarcation-exceptions">
             <title>Exception handling</title>
 
             <para>
@@ -698,9 +702,9 @@
                 </listitem>
             </itemizedlist>
 
-        </sect2>
+        </section>
 
-        <sect2 id="transactions-demarcation-timeout">
+        <section id="transactions-demarcation-timeout">
             <title>Transaction timeout</title>
 
             <para>
@@ -741,11 +745,11 @@
                 where transaction timeouts must be defined declaratively.
             </para>
             
-        </sect2>
+        </section>
         
-    </sect1>
+    </section>
 
-    <sect1 id="transactions-optimistic">
+    <section id="transactions-optimistic">
         <title>Optimistic concurrency control</title>
 
         <para>
@@ -758,7 +762,7 @@
             also has the benefit of preventing lost updates in single database transactions.
         </para>
 
-        <sect2 id="transactions-optimistic-manual">
+        <section id="transactions-optimistic-manual">
             <title>Application version checking</title>
 
             <para>
@@ -805,9 +809,9 @@
                 as the design paradigm.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="transactions-optimistic-longsession">
+        <section id="transactions-optimistic-longsession">
             <title>Extended session and automatic versioning</title>
 
             <para>
@@ -883,9 +887,9 @@
                 for this. See the Hibernate Wiki for examples.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="transactions-optimistic-detached">
+        <section id="transactions-optimistic-detached">
             <title>Detached objects and automatic versioning</title>
 
             <para>
@@ -915,9 +919,9 @@
                 caches) if you are sure that the object has not been modified.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="transactions-optimistic-customizing">
+        <section id="transactions-optimistic-customizing">
             <title>Customizing automatic versioning</title>
 
             <para>
@@ -958,11 +962,11 @@
                 the instance to ensure that changes did occur before updating the row.
             </para>
 
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
-    <sect1 id="transactions-locking">
+    <section id="transactions-locking">
         <title>Pessimistic locking</title>
 
         <para>
@@ -1062,9 +1066,9 @@
             portable.
         </para>
 
-    </sect1>
+    </section>
 
-    <sect1 id="transactions-connection-release">
+    <section id="transactions-connection-release">
         <title>Connection release modes</title>
 
         <para>
@@ -1147,7 +1151,7 @@
             </listitem>
         </itemizedlist>
 
-    </sect1>
+    </section>
 
 </chapter>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/tutorial.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/tutorial.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/tutorial.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -24,8 +24,11 @@
   -->
 
 <!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
-        <!ENTITY mdash "-">
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
+<!ENTITY mdash "-">
 ]>
+        
 
 <chapter id="tutorial">
     <title>Tutorial</title>
@@ -55,7 +58,7 @@
         </para>
     </note>
 
-    <sect1 id="tutorial-firstapp">
+    <section id="tutorial-firstapp">
         <title>Part 1 - The first Hibernate Application</title>
 
         <para>
@@ -72,7 +75,7 @@
             </para>
         </note>
 
-        <sect2 id="tutorial-firstapp-setup">
+        <section id="tutorial-firstapp-setup">
             <title>Setup</title>
 
             <para>
@@ -155,10 +158,10 @@
             <para>
                 Save this file as <filename>pom.xml</filename> in the project root directory.
             </para>
-        </sect2>
+        </section>
 
 
-        <sect2 id="tutorial-firstapp-firstclass">
+        <section id="tutorial-firstapp-firstclass">
             <title>The first class</title>
             
             <para>
@@ -238,9 +241,9 @@
                 Save this file to the <filename>src/main/java/org/hibernate/tutorial/domain</filename>
                 directory.
             </para>
-        </sect2>
+        </section>
 
-        <sect2 id="tutorial-firstapp-mapping">
+        <section id="tutorial-firstapp-mapping">
             <title>The mapping file</title>
 
             <para>
@@ -414,9 +417,9 @@
                 <filename>src/main/resources/org/hibernate/tutorial/domain/Event.hbm.xml</filename>.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="tutorial-firstapp-configuration" revision="2">
+        <section id="tutorial-firstapp-configuration" revision="2">
             <title>Hibernate configuration</title>
 
             <para>
@@ -542,9 +545,9 @@
                 <filename>src/main/resources</filename> directory.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="tutorial-firstapp-mvn" revision="1">
+        <section id="tutorial-firstapp-mvn" revision="1">
             <title>Building with Maven</title>
 
             <para>
@@ -575,9 +578,9 @@
 [INFO] Final Memory: 5M/547M
 [INFO] ------------------------------------------------------------------------]]></programlisting>
 
-        </sect2>
+        </section>
 
-        <sect2 id="tutorial-firstapp-helpers" revision="3">
+        <section id="tutorial-firstapp-helpers" revision="3">
             <title>Startup and helpers</title>
 
             <para>
@@ -665,9 +668,9 @@
                 Hibernate.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="tutorial-firstapp-workingpersistence" revision="5">
+        <section id="tutorial-firstapp-workingpersistence" revision="5">
             <title>Loading and storing objects</title>
 
             <para>
@@ -855,11 +858,11 @@
                 <command>mvn exec:java -Dexec.mainClass="org.hibernate.tutorial.EventManager" -Dexec.args="list"</command>
             </para>
 
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
-    <sect1 id="tutorial-associations">
+    <section id="tutorial-associations">
         <title>Part 2 - Mapping associations</title>
 
         <para>
@@ -869,7 +872,7 @@
             which they participate.
         </para>
 
-        <sect2 id="tutorial-associations-mappinguser" revision="1">
+        <section id="tutorial-associations-mappinguser" revision="1">
             <title>Mapping the Person class</title>
 
             <para>
@@ -928,9 +931,9 @@
                 behavior.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="tutorial-associations-unidirset" revision="3">
+        <section id="tutorial-associations-unidirset" revision="3">
             <title>A unidirectional Set-based association</title>
 
             <para>
@@ -1019,9 +1022,9 @@
                                                   |_____________|
  ]]></programlisting>
 
-        </sect2>
+        </section>
 
-        <sect2 id="tutorial-associations-working" revision="2">
+        <section id="tutorial-associations-working" revision="2">
             <title>Working the association</title>
 
             <para>
@@ -1140,9 +1143,9 @@
                 entities, but looks almost the same in Java.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="tutorial-associations-valuecollections">
+        <section id="tutorial-associations-valuecollections">
             <title>Collection of values</title>
 
             <para>
@@ -1232,9 +1235,9 @@
                 optimize this with an eager fetch.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="tutorial-associations-bidirectional" revision="1">
+        <section id="tutorial-associations-bidirectional" revision="1">
             <title>Bi-directional associations</title>
 
             <para>
@@ -1291,9 +1294,9 @@
                 understand once you see how the bi-directional link between our two entities is created.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="tutorial-associations-usingbidir">
+        <section id="tutorial-associations-usingbidir">
             <title>Working bi-directional links</title>
 
             <para>
@@ -1347,11 +1350,11 @@
                 and in many-to-many association you can select either side.
             </para>
 
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
-    <sect1 id="tutorial-webapp">
+    <section id="tutorial-webapp">
         <title>Part 3 - The EventManager web application</title>
 
         <para>
@@ -1361,7 +1364,7 @@
             database, and it provides an HTML form to enter new events.
         </para>
 
-        <sect2 id="tutorial-webapp-servlet" revision="2">
+        <section id="tutorial-webapp-servlet" revision="2">
             <title>Writing the basic servlet</title>
 
             <para>
@@ -1441,9 +1444,9 @@
                 as you consider rendering your view in JSP, not in a servlet.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="tutorial-webapp-processing" revision="1">
+        <section id="tutorial-webapp-processing" revision="1">
             <title>Processing and rendering</title>
 
             <para>
@@ -1551,9 +1554,9 @@
                 examples.
             </para>
 
-        </sect2>
+        </section>
 
-        <sect2 id="tutorial-webapp-deploy">
+        <section id="tutorial-webapp-deploy">
             <title>Deploying and testing</title>
 
             <para>
@@ -1602,11 +1605,11 @@
                 is called) and to get the detailed output if any exceptions occurs.
             </para>
 
-        </sect2>
+        </section>
 
-    </sect1>
+    </section>
 
-    <sect1 id="tutorial-summary" revision="1">
+    <section id="tutorial-summary" revision="1">
         <title>Summary</title>
 
         <para>
@@ -1615,6 +1618,6 @@
             <ulink url="http://hibernate.org">website</ulink>.
         </para>
 
-    </sect1>
+    </section>
 
 </chapter>

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/content/xml.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/content/xml.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/content/xml.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -23,8 +23,12 @@
   ~ Boston, MA  02110-1301  USA
   -->
 
-<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
+<!ENTITY % BOOK_ENTITIES SYSTEM "../HIBERNATE_-_Relational_Persistence_for_Idiomatic_Java.ent">
+%BOOK_ENTITIES;
 
+]>
+
 <chapter id="xml">
     <title>XML Mapping</title>
 
@@ -33,7 +37,7 @@
         active development.
     </emphasis></para>
 
-    <sect1 id="xml-intro" revision="1">
+    <section id="xml-intro" revision="1">
         <title>Working with XML data</title>
 
         <para>
@@ -64,7 +68,7 @@
             it can be used to map just the XML.
         </para>
         
-        <sect2 id="xml-intro-mapping">
+        <section id="xml-intro-mapping">
             <title>Specifying XML and class mapping together</title>
 
             <para>
@@ -91,9 +95,9 @@
     ...
     
 </class>]]></programlisting>
-        </sect2>
+        </section>
         
-        <sect2 id="xml-onlyxml">
+        <section id="xml-onlyxml">
             <title>Specifying only an XML mapping</title>
 
             <para>
@@ -130,11 +134,11 @@
                 are purely logical constructs that can be referred to in HQL queries.
             </para>
 
-        </sect2>
+        </section>
         
-     </sect1>
+     </section>
      
-    <sect1 id="xml-mapping" revision="1">
+    <section id="xml-mapping" revision="1">
         <title>XML mapping metadata</title>
 
         <para>
@@ -256,10 +260,10 @@
     ...
 </customer>]]></programlisting>
        
-    </sect1>
+    </section>
     
     
-    <sect1 id="xml-manipulation" revision="1">
+    <section id="xml-manipulation" revision="1">
         <title>Manipulating XML data</title>
         
         <para>
@@ -307,7 +311,7 @@
             operation.
         </para>
        
-    </sect1>
+    </section>
      
 </chapter>
 

Modified: core/trunk/documentation/manual/src/main/docbook/en-US/legal_notice.xml
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/en-US/legal_notice.xml	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/en-US/legal_notice.xml	2010-02-11 07:04:06 UTC (rev 18776)
@@ -22,8 +22,9 @@
   ~ 51 Franklin Street, Fifth Floor
   ~ Boston, MA  02110-1301  USA
   -->
-<!DOCTYPE legalnotice PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
+<!DOCTYPE legalnotice PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN" "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
 
+]>
 <legalnotice id="Legal_Notice">
     <title>Legal Notice</title>
     <para>

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/Hibernate_Reference.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/Hibernate_Reference.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/Hibernate_Reference.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,32 +1,30 @@
+# SOME DESCRIPTIVE TITLE.
+# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+#
 #, fuzzy
 msgid ""
 msgstr ""
+"Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-23 18:41+0000\n"
+"POT-Creation-Date: 2010-02-11T05:38:14\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Content-Type: text/plain; charset=UTF-8\n"
+"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: Hibernate_Reference.xml:35
 #, no-c-format
 msgid "HIBERNATE - Relational Persistence for Idiomatic Java"
-msgstr "HIBERNATE - Persistencia Relacional para Java Idiom&#x00e1;tico"
+msgstr ""
 
 #. Tag: subtitle
-#: Hibernate_Reference.xml:36
 #, no-c-format
 msgid "Hibernate Reference Documentation"
-msgstr "Documentaci&#x00f3;n de Referencia de Hibernate"
+msgstr ""
 
-#. Tag: holder
-#: Hibernate_Reference.xml:51
+#. Tag: releaseinfo
 #, no-c-format
-msgid "&copyrightHolder;"
-msgstr "&copyrightHolder;"
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+msgid "&versionNumber;"
+msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/author_group.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/author_group.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/author_group.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -5,7 +5,7 @@
 msgstr ""
 "Project-Id-Version: Branch 3_3\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-16 18:47+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: 2009-06-16 18:47+0000\n"
 "Last-Translator: Automatically generated\n"
 "Language-Team: none\n"
@@ -13,209 +13,137 @@
 "Content-Type: text/plain; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
-#. Tag: author
-#: author_group.xml:27
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Gavin</firstname> <surname>King</surname>"
+msgid "Gavin"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:31
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Christian</firstname> <surname>Bauer</surname>"
+msgid "Christian"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:35
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Max</firstname> <othername>Rydahl</othername> <surname>Andersen</"
-"surname>"
+msgid "Max"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:40
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<author><firstname>Emmanuel</firstname> <surname>Bernard</surname></author>"
+msgid "Emmanuel"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:44
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Steve</firstname> <surname>Ebersole</surname>"
+msgid "Steve"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:49
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>James</firstname> <surname>Cobb</surname>"
+msgid "James"
 msgstr ""
 
-#. Tag: shortaffil
-#: author_group.xml:53 author_group.xml:60
+#. Tag: firstname
 #, no-c-format
-msgid "Graphic Design"
+msgid "Cheyenne"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:56
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Cheyenne</firstname> <surname>Weaver</surname>"
+msgid "Vincent"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:69
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<othername><![CDATA[Bernardo Antonio Buffa Colom&#x00e9]]></othername> "
-"<email>kreimer at bbs.frc.utn.edu.ar</email>"
+msgid "Sebastien"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:79
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Vincent</firstname> <surname>Ricard</surname>"
+msgid "Michael"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:83
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Sebastien</firstname> <surname>Cesbron</surname>"
+msgid "Baptiste"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:87
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Michael</firstname> <surname>Courcy</surname>"
+msgid "Anthony"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:91
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Vincent</firstname> <surname>Giguère</surname>"
+msgid "Alvaro"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:95
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Baptiste</firstname> <surname>Mathus</surname>"
+msgid "Anderson"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:99
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<othercredit><firstname>Emmanuel</firstname> <surname>Bernard</surname></"
-"othercredit>"
+msgid "Daniel Vieira"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:103
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Anthony</firstname> <surname>Patricio</surname>"
+msgid "Francisco"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:113
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Alvaro</firstname> <surname>Netto</surname> "
-"<email>alvaronetto at cetip.com.br</email>"
+msgid "Gamarra"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:118
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Anderson</firstname> <surname>Braulio</surname> "
-"<email>andersonbraulio at gmail.com</email>"
+msgid "Luiz Carlos"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:123
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Daniel Vieira</firstname> <surname>Costa</surname> "
-"<email>danielvc at gmail.com</email>"
+msgid "Marcel"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:128
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Francisco</firstname> <surname>gamarra</surname> <email>francisco."
-"gamarra at gmail.com</email>"
+msgid "Paulo"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:133
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Gamarra</firstname> <email>mauricio.gamarra at gmail.com</email>"
+msgid "Pablo L."
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:137
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Luiz Carlos</firstname> <surname>Rodrigues</surname> "
-"<email>luizcarlos_rodrigues at yahoo.com.br</email>"
+msgid "Renato"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:142
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Marcel</firstname> <surname>Castelo</surname> <email>marcel."
-"castelo at gmail.com</email>"
+msgid "Rogério"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:147
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Paulo</firstname> <surname>César</surname> <email>paulocol at gmail."
-"com</email>"
+msgid "Wanderson"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:152
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Pablo L.</firstname> <surname>de Miranda</surname> "
-"<email>pablolmiranda at gmail.com</email>"
+msgid "Cao"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:157
+#. Tag: orgname
 #, no-c-format
-msgid ""
-"<firstname>Renato</firstname> <surname>Deggau</surname> <email>rdeggau at gmail."
-"com</email>"
+msgid "RedSaga"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:162
+#. Tag: contrib
 #, no-c-format
-msgid ""
-"<firstname>Rogério</firstname> <surname>Araújo</surname> "
-"<email>rgildoaraujo at yahoo.com.br</email>"
+msgid "Translation Lead"
 msgstr ""
-
-#. Tag: othercredit
-#: author_group.xml:167
-#, no-c-format
-msgid ""
-"<firstname>Wanderson</firstname> <surname>Siqueira</surname> "
-"<email>wandersonxs at gmail.com</email>"
-msgstr ""
-
-#. Tag: othercredit
-#: author_group.xml:178
-#, no-c-format
-msgid ""
-"<firstname>Cao</firstname> <surname>Xiaogang</surname> <affiliation> "
-"<orgname>RedSaga</orgname> </affiliation> <contrib>Translation Lead</"
-"contrib> <email>caoxg at yahoo.com</email>"
-msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/architecture.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/architecture.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/architecture.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,99 +1,102 @@
-#, fuzzy
+# translation of architecture.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: architecture\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2010-01-04 10:30+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: architecture.xml:30
 #, no-c-format
 msgid "Architecture"
 msgstr "Arquitectura"
 
 #. Tag: title
-#: architecture.xml:33
 #, no-c-format
 msgid "Overview"
-msgstr "Visi&#x00f3;n General"
+msgstr "Sinopsis"
 
 #. Tag: para
-#: architecture.xml:35
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The diagram below provides a high-level view of the Hibernate architecture:"
-msgstr "Una visi&#x00f3;n a (muy) alto nivel de la arquitectura de Hibernate:"
+msgstr ""
+"El diagrama a continuación brinda una perspectiva a alto nivel de la "
+"arquitectura de Hibernate:"
 
 #. Tag: para
-#: architecture.xml:50
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We do not have the scope in this document to provide a more detailed view of "
 "all the runtime architectures available; Hibernate is flexible and supports "
 "several different approaches. We will, however, show the two extremes: "
 "\"minimal\" architecture and \"comprehensive\" architecture."
 msgstr ""
-"Nos gustar&#x00ed;a mostrar una vista m&#x00e1;s detallada de la "
-"arquitectura de tiempo de ejecuci&#x00f3;n. Desafortunadamente, Hibernate es "
-"flexible y soporta diferentes enfoques. Mostraremos los dos extremos. En la "
-"arquitectura \"sencilla\", es la aplicaci&#x00f3;n la que provee su propias "
-"conexiones JDBC y gestiona sus propias transacciones. Este enfoque usa un "
-"m&#x00ed;nimo subconjunto de la API de Hibernate:"
+"Este documento no incluye una sinopsis detallada de la arquitecturas en "
+"tiempo de ejecución disponibles; Hibernate es flexible y soporta diferentes "
+"enfoques. Sin embargo, mostraremos los dos extremos: la arquitectura \"mínima"
+"\" y la arquitectura \"completa\"."
 
 #. Tag: para
-#: architecture.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This next diagram illustrates how Hibernate utilizes database and "
 "configuration data to provide persistence services, and persistent objects, "
 "to the application."
 msgstr ""
-"Este diagrama muestra a Hibernate usando la base de datos y los datos de "
-"configuraci&#x00f3;n para proveer servicios de persistencia (y objetos "
-"persistentes) a la aplicaci&#x00f3;n."
+"Este diagrama ilustra la manera en que Hibernate utiliza la base de datos y "
+"los datos de configuración para proporcionar servicios de persistencia y "
+"objetos persistentes a la aplicación."
 
 #. Tag: para
-#: architecture.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The \"minimal\" architecture has the application provide its own JDBC "
 "connections and manage its own transactions. This approach uses a minimal "
 "subset of Hibernate's APIs:"
 msgstr ""
-"Nos gustar&#x00ed;a mostrar una vista m&#x00e1;s detallada de la "
-"arquitectura de tiempo de ejecuci&#x00f3;n. Desafortunadamente, Hibernate es "
-"flexible y soporta diferentes enfoques. Mostraremos los dos extremos. En la "
-"arquitectura \"sencilla\", es la aplicaci&#x00f3;n la que provee su propias "
-"conexiones JDBC y gestiona sus propias transacciones. Este enfoque usa un "
-"m&#x00ed;nimo subconjunto de la API de Hibernate:"
+"La arquitectura \"mínima\" hace que la aplicación proporcione sus propias "
+"conexiones JDBC y que administre sus propias transacciones. Este enfoque "
+"utiliza un subgrupo mínimo de las APIs de Hibernate:"
 
 #. Tag: para
-#: architecture.xml:78
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The \"comprehensive\" architecture abstracts the application away from the "
 "underlying JDBC/JTA APIs and allows Hibernate to manage the details."
 msgstr ""
-"La arquitectura \"full cream\" abstrae a la aplicaci&#x00f3;n de las APIs de "
-"JDBC/JTA y deja que Hibernate se encargue de los detalles."
+"La arquitectura \"completa\" abstrae la aplicación de las APIs de JDBC/JTA y "
+"permite que Hibernate se encargue de los detalles."
 
 #. Tag: para
-#: architecture.xml:92
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here are some definitions of the objects depicted in the diagrams:"
-msgstr "He aqu&#x00ed; algunas definiciones de los objetos en los diagramas:"
+msgstr "He aquí algunas definiciones de los objetos en los diagramas: "
 
 #. Tag: term
-#: architecture.xml:97
 #, no-c-format
 msgid "SessionFactory (<literal>org.hibernate.SessionFactory</literal>)"
 msgstr "SessionFactory (<literal>org.hibernate.SessionFactory</literal>)"
 
 #. Tag: para
-#: architecture.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A threadsafe, immutable cache of compiled mappings for a single database. A "
 "factory for <literal>Session</literal> and a client of "
@@ -101,21 +104,19 @@
 "hold an optional (second-level) cache of data that is reusable between "
 "transactions at a process, or cluster, level."
 msgstr ""
-"Cach&#x00e9; threadsafe (inmutable) de mapeos compilados para una sola base "
-"de datos. Es una f&#x00e1;brica de <literal>Session</literal> y un cliente "
-"de <literal>ConnectionProvider</literal>. Opcionalmente, puede mantener una "
-"cach&#x00e9; (de segundo nivel) de datos reusables entre transacciones, a un "
-"nivel de proceso o de cluster."
+"Un caché threadsafe (inmutable) de mapeos compilados para una sola base de "
+"datos. Una fábrica de <literal>Session</literal> y un cliente de "
+"<literal>ConnectionProvider</literal>, <literal>SessionFactory</literal> "
+"puede mantener un caché opcional (de segundo nivel) de datos reusables entre "
+"transacciones a nivel de proceso o de clúster."
 
 #. Tag: term
-#: architecture.xml:109
 #, no-c-format
 msgid "Session (<literal>org.hibernate.Session</literal>)"
 msgstr "Session (<literal>org.hibernate.Session</literal>)"
 
 #. Tag: para
-#: architecture.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A single-threaded, short-lived object representing a conversation between "
 "the application and the persistent store. It wraps a JDBC connection and is "
@@ -123,22 +124,20 @@
 "holds a mandatory first-level cache of persistent objects that are used when "
 "navigating the object graph or looking up objects by identifier."
 msgstr ""
-"Objeto mono-hebra, de corta vida que representa una conversaci&#x00f3;n "
-"entre la aplicaci&#x00f3;n y el almacenamiento persistente. Envuelve una "
-"conexi&#x00f3;n JDBC. Es una f&#x00e1;brica de <literal>Transaction</"
-"literal>. Mantiene una cach&#x00e9; requerida (de primer nivel) de objetos "
-"persistentes, usada mientras se navega el grafo de objetos o se recuperen "
-"objetos por identificador."
+"Un objeto mono-hebra, de corta vida que representa una conversación entre la "
+"aplicación y el almacenamiento persistente. Envuelve una conexión JDBC y es "
+"una fábrica de <literal>Transaction</literal>. <literal>Session</literal> "
+"mantiene un caché requerido de primer nivel de objetos persistentes, que se "
+"utiliza cuando se navega el gráfico de objetos o mientras se buscan objetos "
+"por identificador."
 
 #. Tag: term
-#: architecture.xml:121
 #, no-c-format
 msgid "Persistent objects and collections"
 msgstr "Objetos y colecciones persistentes"
 
 #. Tag: para
-#: architecture.xml:123
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Short-lived, single threaded objects containing persistent state and "
 "business function. These can be ordinary JavaBeans/POJOs. They are "
@@ -147,45 +146,39 @@
 "in any application layer (for example, directly as data transfer objects to "
 "and from presentation)."
 msgstr ""
-"Objetos de corta vida, mono-hebra conteniendo estado persistente y "
-"funci&#x00f3;nalidad de negocio. Estos pueden ser JavaBeans/POJOs (Plain Old "
-"Java Objects, o sea, cualquier objeto Java), la &#x00fa;nica cosa especial "
-"en ellos es que estan asociados actualmente con una (y s&#x00f3;lo una) "
-"<literal>Session</literal>. Tan pronto como la <literal>Session</literal> "
-"sea cerrada, ser&#x00e1;n separados y estar&#x00e1;n libres para ser usados "
-"en cualquier capa de aplicaci&#x00f3;n. (por ejemplo, directamente como "
-"objetos de transferencia de datos hacia y desde la capa de presentaci&#x00f3;"
-"n)."
+"Objetos de corta vida, mono-hebra contienen un estado persistente así como "
+"una funcionalidad empresarial. Estos pueden ser JavaBeans/POJOs normales. "
+"Estos se encuentran asociados con exactamente una <literal>Session</"
+"literal>. Tan pronto como la <literal>Session</literal> se cierre, serán "
+"separados y estarán libres para utilizarlos en cualquier capa de aplicación, "
+"(por ejemplo, directamente como objetos de transferencia de datos hacia y "
+"desde la presentación)."
 
 #. Tag: term
-#: architecture.xml:133
 #, no-c-format
 msgid "Transient and detached objects and collections"
 msgstr "Objetos y colecciones transitorios y separados"
 
 #. Tag: para
-#: architecture.xml:135
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Instances of persistent classes that are not currently associated with a "
 "<literal>Session</literal>. They may have been instantiated by the "
 "application and not yet persisted, or they may have been instantiated by a "
 "closed <literal>Session</literal>."
 msgstr ""
-"Instancias de clases persistentes que no estan acutualmente asociadas con "
-"una <literal>Session</literal>. Pueden haber sido instanciadas por la "
-"aplicaci&#x00f3;n y (a&#x00fa;n) no haber sido hechas persistentes, o pueden "
-"haber sido instanciadas por una <literal>Session</literal> cerrada."
+"Instancias de clases persistentes que no se encuentran actualmente asociadas "
+"con una <literal>Session</literal>. Pueden haber sido instanciadas por la "
+"aplicación y aún no haber sido persistidas, o pueden haber sido instanciadas "
+"por una <literal>Session</literal> cerrada."
 
 #. Tag: term
-#: architecture.xml:144
 #, no-c-format
 msgid "Transaction (<literal>org.hibernate.Transaction</literal>)"
 msgstr "Transaction (<literal>org.hibernate.Transaction</literal>)"
 
 #. Tag: para
-#: architecture.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "(Optional) A single-threaded, short-lived object used by the application to "
 "specify atomic units of work. It abstracts the application from the "
@@ -194,16 +187,15 @@
 "transaction demarcation, either using the underlying API or "
 "<literal>Transaction</literal>, is never optional."
 msgstr ""
-"(Opcional) Un objeto de corta vida, mono-hebra, usado por la aplicaci&#x00f3;"
-"n para especificar unidades at&#x00f3;micas de trabajo. Abstrae a la "
-"aplicaci&#x00f3;n de las subyacentes transacciones JDBC, JTA o CORBA. En "
-"algunos casos, una <literal>Session</literal> puede extenderse sobre varias "
-"<literal>Transaction</literal>s. Sin embargo, la demarcaci&#x00f3;n de la "
-"transacci&#x00f3;n, ya sea usando la API subyacente o <literal>Transaction</"
-"literal>, nunca es opcional!"
+"(Opcional) Un objeto de corta vida, mono-hebra que la aplicación utiliza "
+"para especificar unidades atómicas de trabajo. Abstrae la aplicación de las "
+"transacciones subyacentes JDBC, JTA o CORBA. En algunos casos, una "
+"<literal>Session</literal> puede extenderse sobre varias "
+"<literal>Transaction</literal>es. Sin embargo, la demarcación de la "
+"transacción, ya sea utilizando la API subyacente o <literal>Transaction</"
+"literal>, nunca es opcional."
 
 #. Tag: term
-#: architecture.xml:157
 #, no-c-format
 msgid ""
 "ConnectionProvider (<literal>org.hibernate.connection.ConnectionProvider</"
@@ -213,22 +205,19 @@
 "literal>)"
 
 #. Tag: para
-#: architecture.xml:159
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "(Optional) A factory for, and pool of, JDBC connections. It abstracts the "
 "application from underlying <literal>Datasource</literal> or "
 "<literal>DriverManager</literal>. It is not exposed to application, but it "
 "can be extended and/or implemented by the developer."
 msgstr ""
-"(Opcional) Una f&#x00e1;brica (y pool) de conexiones JDBC. Abstrae a la "
-"aplicaci&#x00f3;n del <literal>Datasource</literal> o "
-"<literal>DriverManager</literal> subyacente. No se expone a la "
-"aplicaci&#x00f3;n, pero puede ser extendido/implementado por el "
-"desarrollador."
+"(Opcional) Una fábrica y pool de conexiones JDBC. Abstrae a la aplicación "
+"del <literal>Datasource</literal> o <literal>DriverManager</literal> "
+"subyacente. No se expone a la aplicación, pero puede ser extendido/"
+"implementado por el desarrollador."
 
 #. Tag: term
-#: architecture.xml:167
 #, no-c-format
 msgid ""
 "TransactionFactory (<literal>org.hibernate.TransactionFactory</literal>)"
@@ -236,59 +225,52 @@
 "TransactionFactory (<literal>org.hibernate.TransactionFactory</literal>)"
 
 #. Tag: para
-#: architecture.xml:169
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "(Optional) A factory for <literal>Transaction</literal> instances. It is not "
 "exposed to the application, but it can be extended and/or implemented by the "
 "developer."
 msgstr ""
-"(Opcional) Una f&#x00e1;brica de instancias de <literal>Transaction</"
-"literal>. No se expone a la aplicaci&#x00f3;n, pero puede ser extendido/"
-"implementado por el desarrollador."
+"(Opcional) Una fábrica de instancias de <literal>Transaction</literal>. No "
+"se expone a la aplicación pero puede ser extendido/implementado por el "
+"desarrollador. "
 
-#. Tag: emphasis
-#: architecture.xml:176
-#, no-c-format
-msgid "Extension Interfaces"
-msgstr "Interfaces de Extensi&#x00f3;n"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<emphasis>Extension Interfaces</emphasis>"
+msgstr "<emphasis>Interfaces de extensión</emphasis>"
 
 #. Tag: para
-#: architecture.xml:178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate offers a range of optional extension interfaces you can implement "
 "to customize the behavior of your persistence layer. See the API "
 "documentation for details."
 msgstr ""
-"Hibernate ofrece muchas interfaces de extensi&#x00f3;n opcional que puedes "
-"implementar para modificar a medida el comportamiento de tu capa de "
-"persistencia. Para m&#x00e1;s detalles, mira la documentaci&#x00f3;n de la "
-"API."
+"Hibernate ofrece un rango de interfaces de extensión opcionales que puede "
+"implementar para personalizar el comportamiento de su capa de persistencia. "
+"Para obtener más detalles, vea la documentación de la API."
 
 #. Tag: para
-#: architecture.xml:187
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Given a \"minimal\" architecture, the application bypasses the "
 "<literal>Transaction</literal>/<literal>TransactionFactory</literal> and/or "
 "<literal>ConnectionProvider</literal> APIs to communicate with JTA or JDBC "
 "directly."
 msgstr ""
-"Dada una arquitectura \"sencilla\", la aplicaci&#x00f3;n pasa por alto las "
-"APIs de <literal>Transaction</literal>/<literal>TransactionFactory</literal> "
-"y/o <literal>ConnectionProvider</literal>, para hablar directamente a JTA o "
-"JDBC."
+"Dada una arquitectura \"sencilla\", la aplicación evita las APIs de "
+"<literal>Transaction</literal>/<literal>TransactionFactory</literal> y/o "
+"<literal>ConnectionProvider</literal>, para comunicarse directamente con JTA "
+"o JDBC."
 
 #. Tag: title
-#: architecture.xml:195
 #, no-c-format
 msgid "Instance states"
 msgstr "Estados de instancia"
 
 #. Tag: para
-#: architecture.xml:196
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of a persistent class can be in one of three different states. "
 "These states are defined in relation to a <emphasis>persistence context</"
@@ -296,35 +278,32 @@
 "persistence context. The three different states are as follows:"
 msgstr ""
 "Una instancia de una clase persistente puede estar en uno de tres estados "
-"diferentes, definidos respecto de su <emphasis>contexto de persistencia</"
-"emphasis>. El objeto <literal>Session</literal> de Hibernate es el contexto "
-"de persistencia:"
+"diferentes. Estos estados se definen con respecto a su <emphasis>contexto de "
+"persistencia</emphasis>. El objeto <literal>Session</literal> de Hibernate "
+"es el contexto de persistencia. Los tres estados diferentes son los "
+"siguientes:"
 
 #. Tag: term
-#: architecture.xml:204
 #, no-c-format
 msgid "transient"
 msgstr "transitorio"
 
 #. Tag: para
-#: architecture.xml:206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The instance is not associated with any persistence context. It has no "
 "persistent identity or primary key value."
 msgstr ""
-"La instancia no est&#x00e1; y nunca estuvo asociada con un contexto de "
-"persistencia. No tiene identidad persistente (valor de clave primaria)."
+"La instancia no está asociada con un contexto de persistencia. No tiene "
+"identidad persistente o valor de clave principal."
 
 #. Tag: term
-#: architecture.xml:214
 #, no-c-format
 msgid "persistent"
 msgstr "persistente"
 
 #. Tag: para
-#: architecture.xml:216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The instance is currently associated with a persistence context. It has a "
 "persistent identity (primary key value) and can have a corresponding row in "
@@ -332,22 +311,20 @@
 "<emphasis>guarantees</emphasis> that persistent identity is equivalent to "
 "Java identity in relation to the in-memory location of the object."
 msgstr ""
-"La instancia est&#x00e1; actualmente asociada con un contexto de "
-"persistencia. Tiene una identidad persistente (valor de clave primaria) y, "
-"quiz&#x00e1;s, una fila correspondiente en la base de datos. Para un "
-"contexto de persistencia en particular, Hibernate <emphasis>garantiza</"
-"emphasis> que la identidad persistente es equivalente a la identidad Java "
-"(localizaci&#x00f3;n en memoria del objeto)."
+"La instancia se encuentra actualmente asociada con un contexto de "
+"persistencia. Tiene una identidad persistente (valor de clave principal) y "
+"puede tener una fila correspondiente en la base de datos. Para un contexto "
+"de persistencia en particular, Hibernate <emphasis>garantiza</emphasis> que "
+"la identidad persistente es equivalente a la identidad Java en relación con "
+"la ubicación del objeto."
 
 #. Tag: term
-#: architecture.xml:228
 #, no-c-format
 msgid "detached"
 msgstr "separado"
 
 #. Tag: para
-#: architecture.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The instance was once associated with a persistence context, but that "
 "context was closed, or the instance was serialized to another process. It "
@@ -355,49 +332,44 @@
 "For detached instances, Hibernate does not guarantee the relationship "
 "between persistent identity and Java identity."
 msgstr ""
-"La instancia estuvo una vez asociada con un contexto de persistencia, pero "
-"ese contexto fue cerrado, o la instancia fue serializada a otro proceso. "
-"Tiene una identidad persistente y, quiz&#x00e1;s, una fila correspondiente "
-"en la base de datos. Para las instancias separadas, Hibernate no establece "
-"ninguna garant&#x00ed;a sobre la relaci&#x00f3;n entre identidad persistente "
-"e identidad Java."
+"La instancia estuvo alguna vez asociada con un contexto de persistencia, "
+"pero ese contexto se cerró, o la instancia fue serializada a otro proceso. "
+"Tiene una identidad persistente y puede tener una fila correspondiente en la "
+"base de datos. Para las instancias separadas, Hibernate no establece ninguna "
+"garantía sobre la relación entre identidad persistente e identidad Java."
 
 #. Tag: title
-#: architecture.xml:245
 #, no-c-format
 msgid "JMX Integration"
-msgstr "Integraci&#x00f3;n JMX"
+msgstr "Integración JMX"
 
 #. Tag: para
-#: architecture.xml:247
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "JMX is the J2EE standard for the management of Java components. Hibernate "
 "can be managed via a JMX standard service. AN MBean implementation is "
 "provided in the distribution: <literal>org.hibernate.jmx.HibernateService</"
 "literal>."
 msgstr ""
-"JMX es el est&#x00e1;ndar J2EE para la gesti&#x00f3;n de componentes Java. "
-"Hibernate puede ser gestionado por medio de un servicio est&#x00e1;ndar JMX. "
-"Proveemos una implementaci&#x00f3;n de MBean en la distribuci&#x00f3;n, "
-"<literal>org.hibernate.jmx.HibernateService</literal>."
+"JMX es el estándar J2EE para la gestión de componentes Java. Hibernate se "
+"puede administrar por medio de un servicio estándar JMX. Brindamos una "
+"implementación de MBean en la distribución: <literal>org.hibernate.jmx."
+"HibernateService</literal>."
 
 #. Tag: para
-#: architecture.xml:253
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For an example of how to deploy Hibernate as a JMX service on the JBoss "
 "Application Server, please see the JBoss User Guide. JBoss AS also provides "
 "these benefits if you deploy using JMX:"
 msgstr ""
-"Para ejemplo de c&#x00f3;mo desplegar Hibernate como un servicio JMX en un "
-"Servidor de Aplicaciones JBoss, por favor, mira la Gu&#x00ed;a del Usuario "
-"de JBoss. En JBoss AS, tienes adem&#x00e1;s estos beneficios si despliegas "
-"usando JMX:"
+"Para ver un ejemplo de cómo desplegar Hibernate como un servicio JMX en un "
+"servidor de aplicaciones JBoss, por favor, refiérase al manual del usuario "
+"de JBoss. JBoss AS también proporciona estos beneficios si despliega "
+"utilizando JMX:"
 
 #. Tag: para
-#: architecture.xml:261
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Session Management</emphasis>: the Hibernate <literal>Session</"
 "literal>'s life cycle can be automatically bound to the scope of a JTA "
@@ -409,20 +381,18 @@
 "the <literal>HibernateContext</literal> to access a <literal>Session</"
 "literal>."
 msgstr ""
-"<emphasis>Gesti&#x00f3;n de Sesi&#x00f3;n:</emphasis> El ciclo de vida de la "
-"<literal>Session</literal> de Hibernate puede estar autom&#x00e1;ticamente "
-"ligado al &#x00e1;mbito de una transacci&#x00f3;n JTA. Esto significa que ya "
-"no tienes que abrir ni cerrar la <literal>Session</literal> manualmente, "
-"esto pasa a ser trabajo de un interceptor EJB de JBoss. Adem&#x00e1;s "
-"tampoco tienes que preocuparte m&#x00e1;s de la demarcaci&#x00f3;n de la "
-"transacci&#x00f3;n (a menos que que quieras escribir una capa de persitencia "
-"portable, por supuesto, usa la API de <literal>Transaction</literal> de "
-"Hibernate para esto). Para acceder a una <literal>Session</literal> llama al "
-"<literal>HibernateContext</literal>."
+"<emphasis>Administración de Sesión:</emphasis> El ciclo de vida de la "
+"<literal>Session</literal> de Hibernate puede estar ligado automáticamente "
+"al ámbito de una transacción JTA. Esto significa que ya no tiene que abrir "
+"ni cerrar la <literal>Session</literal> manualmente, esto pasa a ser el "
+"trabajo de un interceptor EJB de JBoss. Además tampoco tiene que preocuparse "
+"más de la demarcación de la transacción en su código (a menos de que quiera "
+"escribir una capa de persitencia portátil, utilice la API de "
+"<literal>Transaction</literal> de Hibernate para hacer esto). Para acceder a "
+"una <literal>Session</literal> llame al <literal>HibernateContext</literal>."
 
 #. Tag: para
-#: architecture.xml:273
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>HAR deployment</emphasis>: the Hibernate JMX service is deployed "
 "using a JBoss service deployment descriptor in an EAR and/or SAR file, as it "
@@ -432,63 +402,56 @@
 "deployment, JBoss will automatically detect all mapping files in your HAR "
 "file."
 msgstr ""
-"<emphasis>Despliegue de HAR:</emphasis> Usualmente despliegas el servicio "
-"JMX de Hibernate usando un descriptor de despliegue de servicio de JBoss (en "
-"un fichero EAR y/o SAR), que soporta todas las opciones de "
-"configuraci&#x00f3;n usuales de una <literal>SessionFactory</literal> de "
-"Hibernate. Sin embargo, todav&#x00ed;a tienes que nombrar todos tus ficheros "
-"de mapeo en el descriptor de despliegue. Si decides usar el depliegue de HAR "
-"opcional, JBoss detectar&#x00e1; autom&#x00e1;ticamente todos los ficheros "
-"de mapeo en tu fichero HAR."
+"<emphasis>Despliegue HAR:</emphasis>: el servicio JMX de Hibernate se "
+"implementa usando un descriptor de despliegue de servicio de JBoss en un "
+"archivo EAR y/o SAR, que soporta todas las opciones de configuración usuales "
+"de una <literal>SessionFactory</literal> de Hibernate. Sin embargo, todavía "
+"tiene que nombrar todos sus archivos de mapeo en el descriptor de "
+"despliegue. Si utiliza el depliegue HAR opcional, JBoss detectará "
+"automáticamente todos los archivos de mapeo en su archivo HAR."
 
 #. Tag: para
-#: architecture.xml:284
 #, no-c-format
 msgid ""
 "Consult the JBoss AS user guide for more information about these options."
 msgstr ""
-"Para m&#x00e1;s informaci&#x00f3;n sobre estas opciones, consulta la "
-"Gu&#x00ed;a de Usuario del JBoss AS."
+"Para más información sobre estas opciones, consulte el Manual de Usuario de "
+"JBoss AS."
 
 #. Tag: para
-#: architecture.xml:288
 #, fuzzy, no-c-format
 msgid ""
 "Another feature available as a JMX service is runtime Hibernate statistics. "
-"See <xref linkend=\"configuration-optional-statistics\"/> for more "
+"See <xref linkend=\"configuration-optional-statistics\" /> for more "
 "information."
 msgstr ""
-"Otra funcionalidad disponible como un servicio JMX son las estad&#x00ed;"
-"sticas en tiempo de ejecuci&#x00f3;n de Hibernate. Mira <xref linkend="
-"\"configuration-optional-statistics\"/>."
+"Otra funcionalidad disponible como un servicio de JMX son las estadísticas "
+"en tiempo de ejecución de Hibernate. Consulte <xref linkend=\"configuration-"
+"optional-statistics\" /> para obtener mayor información."
 
 #. Tag: title
-#: architecture.xml:295
 #, no-c-format
 msgid "JCA Support"
-msgstr "Soporte JCA:"
+msgstr "Soporte JCA"
 
 #. Tag: para
-#: architecture.xml:296
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate can also be configured as a JCA connector. Please see the website "
 "for more information. Please note, however, that at this stage Hibernate JCA "
 "support is under development."
 msgstr ""
-"Hiberate puede adem&#x00e1;s ser configurado como un conector JCA. Por favor "
-"mira el sitio web para m&#x00e1;s detalles. Por favor ten en cuenta que el "
-"soporte de JCA de Hibernate est&#x00e1; a&#x00fa;n considerado experimental."
+"Hibernate también puede ser configurado como un conector JCA. Por favor "
+"refiérase al sitio web para encontrar más detalles. Sin embargo, tenga en "
+"cuenta que el soporte de JCA de Hibernate aún está bajo desarrollo."
 
 #. Tag: title
-#: architecture.xml:303
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Contextual sessions"
-msgstr "UNTRANSLATED! Contextual Sessions"
+msgstr "Sesiones contextuales"
 
 #. Tag: para
-#: architecture.xml:304
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Most applications using Hibernate need some form of \"contextual\" session, "
 "where a given session is in effect throughout the scope of a given context. "
@@ -500,19 +463,20 @@
 "utilized third-party frameworks, such as Spring or Pico, which provided "
 "proxy/interception-based contextual sessions."
 msgstr ""
-"Most applications using Hibernate need some form of \"contextual\" sessions, "
-"where a given session is in effect throughout the scope of a given context. "
-"However, across applications the definition of what constitutes a context is "
-"typically different; and different contexts define different scopes to the "
-"notion of current. Applications using Hibernate prior to version 3.0 tended "
-"to utilize either home-grown <literal>ThreadLocal</literal>-based contextual "
-"sessions, helper classes such as <literal>HibernateUtil</literal>, or "
-"utilized third-party frameworks (such as Spring or Pico) which provided "
-"proxy/interception-based contextual sessions."
+"La mayoría de las aplicaciones que utilizan Hibernate necesitan alguna forma "
+"de sesiones \"contextuales\", en donde una sesión dada se encuentra en "
+"efecto en todo el campo de acción de un contexto dado. Sin embargo, a través "
+"de las aplicaciones la definición de lo que constituye un contexto es "
+"usualmente diferente y diferentes contextos definen diferentes campos de "
+"acción para la noción de actual. Las aplicaciones que utiliza Hibernate "
+"antes de la version 3.0 tienden a utilizar ya sea sesiones contextuales con "
+"base <literal>ThreadLocal</literal> desarrollados en casa, las clases "
+"ayudantes tales como <literal>HibernateUtil</literal>, o enfoques de "
+"terceros utilizados, como Spring o Pico, los cuales brindaban sesiones "
+"contextuales con base proxy/intercepción."
 
 #. Tag: para
-#: architecture.xml:313
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Starting with version 3.0.1, Hibernate added the <literal>SessionFactory."
 "getCurrentSession()</literal> method. Initially, this assumed usage of "
@@ -524,20 +488,20 @@
 "deployed into a <literal>J2EE</literal> container. Based on that, the "
 "<literal>JTA</literal>-based contextual sessions are all you need to use."
 msgstr ""
-"Starting with version 3.0.1, Hibernate added the <literal>SessionFactory."
-"getCurrentSession()</literal> method. Initially, this assumed usage of "
-"<literal>JTA</literal> transactions, where the <literal>JTA</literal> "
-"transaction defined both the scope and context of a current session. The "
-"Hibernate team maintains that, given the maturity of the numerous stand-"
-"alone <literal>JTA TransactionManager</literal> implementations out there, "
-"most (if not all) applications should be using <literal>JTA</literal> "
-"transaction management whether or not they are deployed into a "
-"<literal>J2EE</literal> container. Based on that, the <literal>JTA</literal>-"
-"based contextual sessions is all you should ever need to use."
+"Comenzando con la version 3.0.1, Hibernate agregó el método "
+"<literal>SessionFactory.getCurrentSession()</literal>. Inicialmente, este "
+"asumió la utilización de las transacciones <literal>JTA</literal>, en donde "
+"la transacción <literal>JTA</literal> definia tanto el contexto como el "
+"campo de acción de una sesión actual. Dada la madurez de númerosas "
+"implementaciones <literal>JTA TransactionManager</literal> autónomas "
+"existentes, la mayoría, si no es que todas, las aplicaciones deberían "
+"utilizar la administración de transacciones <literal>JTA</literal> en el "
+"caso de que se deplieguen o no en un contenedor <literal>J2EE</literal>. Con "
+"base en esto, las sesiones contextuales basadas en <literal>JTA</literal> es "
+"todo lo que usted necesita utilizar."
 
 #. Tag: para
-#: architecture.xml:323
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, as of version 3.1, the processing behind <literal>SessionFactory."
 "getCurrentSession()</literal> is now pluggable. To that end, a new extension "
@@ -546,16 +510,16 @@
 "current_session_context_class</literal>, have been added to allow "
 "pluggability of the scope and context of defining current sessions."
 msgstr ""
-"However, as of version 3.1, the processing behind <literal>SessionFactory."
-"getCurrentSession()</literal> is now pluggable. To that end, a new extension "
-"interface (<literal>org.hibernate.context.CurrentSessionContext</literal>) "
-"and a new configuration parameter (<literal>hibernate."
-"current_session_context_class</literal>) have been added to allow "
-"pluggability of the scope and context of defining current sessions."
+"Sin embargo, desde la versión 3.1, el procesamiento detrás de "
+"<literal>SessionFactory.getCurrentSession()</literal> ahora es conectable. "
+"Para ese fin, se ha añadido una nueva interfaz de extensión, <literal>org."
+"hibernate.context.CurrentSessionContext</literal>, y un nuevo parámetro de "
+"configuración, <literal>hibernate.current_session_context_class</literal> "
+"para permitir la conexión del campo de acción y el contexto de definición de "
+"las sesiones actuales."
 
 #. Tag: para
-#: architecture.xml:330
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "See the Javadocs for the <literal>org.hibernate.context."
 "CurrentSessionContext</literal> interface for a detailed discussion of its "
@@ -564,54 +528,51 @@
 "contextual session. Out-of-the-box, Hibernate comes with three "
 "implementations of this interface:"
 msgstr ""
-"See the Javadocs for the <literal>org.hibernate.context."
-"CurrentSessionContext</literal> interface for a detailed discussion of its "
-"contract. It defines a single method, <literal>currentSession()</literal>, "
-"by which the implementation is responsible for tracking the current "
-"contextual session. Out-of-the-box, Hibernate comes with three "
-"implementations of this interface."
+"Refiérase a los Javadocs para la interfaz <literal>org.hibernate.context."
+"CurrentSessionContext</literal> para poder ver una discusión detallada de su "
+"contrato. Define un método único, <literal>currentSession()</literal>, por "
+"medio del cual la implementación es responsable de rastrear la sesión "
+"contextual actual. Tal como viene empacada, Hibernate incluye tres "
+"implementaciones de esta interfaz:"
 
 #. Tag: para
-#: architecture.xml:340
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.context.JTASessionContext</literal>: current sessions "
 "are tracked and scoped by a <literal>JTA</literal> transaction. The "
 "processing here is exactly the same as in the older JTA-only approach. See "
 "the Javadocs for details."
 msgstr ""
-"<literal>org.hibernate.context.JTASessionContext</literal> - current "
-"sessions are tracked and scoped by a <literal>JTA</literal> transaction. The "
-"processing here is exactly the same as in the older JTA-only approach. See "
-"the Javadocs for details."
+"<literal>org.hibernate.context.JTASessionContext</literal>: una transacción "
+"<literal>JTA</literal> rastrea y asume las sesiones actuales. Aquí el "
+"procesamiento es exactamente el mismo que en el enfoque más antiguo de JTA-"
+"sólamente. Refiérase a los Javadocs para obtener más información."
 
 #. Tag: para
-#: architecture.xml:348
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.context.ThreadLocalSessionContext</literal>:current "
 "sessions are tracked by thread of execution. See the Javadocs for details."
 msgstr ""
-"<literal>org.hibernate.context.ThreadLocalSessionContext</literal> - current "
-"sessions are tracked by thread of execution. Again, see the Javadocs for "
-"details."
+"<literal>org.hibernate.context.ThreadLocalSessionContext</literal>: las "
+"sesiones actuales son rastreadas por un hilo de ejecución. Consulte los "
+"Javadocs para obtener más detalles."
 
 #. Tag: para
-#: architecture.xml:354
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.context.ManagedSessionContext</literal>: current "
 "sessions are tracked by thread of execution. However, you are responsible to "
 "bind and unbind a <literal>Session</literal> instance with static methods on "
 "this class: it does not open, flush, or close a <literal>Session</literal>."
 msgstr ""
-"<literal>org.hibernate.context.ManagedSessionContext</literal> - current "
-"sessions are tracked by thread of execution. However, you are responsible to "
-"bind and unbind a <literal>Session</literal> instance with static methods on "
-"this class, it does never open, flush, or close a <literal>Session</literal>."
+"<literal>org.hibernate.context.ManagedSessionContext</literal>: las sesiones "
+"actuales son rastreadas por un hilo de ejecución. Sin embargo, usted es "
+"responsable de vincular y desvincular una instancia <literal>Session</"
+"literal> con métodos estáticos en esta clase: no abre, vacia o cierra una "
+"<literal>Session</literal>."
 
 #. Tag: para
-#: architecture.xml:363
 #, fuzzy, no-c-format
 msgid ""
 "The first two implementations provide a \"one session - one database "
@@ -624,24 +585,26 @@
 "utilize the JTA interfaces to demarcate transactions. If you execute in an "
 "EJB container that supports CMT, transaction boundaries are defined "
 "declaratively and you do not need any transaction or session demarcation "
-"operations in your code. Refer to <xref linkend=\"transactions\"/> for more "
+"operations in your code. Refer to <xref linkend=\"transactions\" /> for more "
 "information and code examples."
 msgstr ""
-"The first two implementations provide a \"one session - one database "
-"transaction\" programming model, also known and used as <emphasis>session-"
-"per-request</emphasis>. The beginning and end of a Hibernate session is "
-"defined by the duration of a database transaction. If you use programatic "
-"transaction demarcation in plain JSE without JTA, you are adviced to use the "
-"Hibernate <literal>Transaction</literal> API to hide the underlying "
-"transaction system from your code. If you use JTA, use the JTA interfaces to "
-"demarcate transactions. If you execute in an EJB container that supports "
-"CMT, transaction boundaries are defined declaratively and you don't need any "
-"transaction or session demarcation operations in your code. Refer to <xref "
-"linkend=\"transactions\"/> for more information and code examples."
+"Las primeras dos implementaciones brindan un modelo de programación \"una "
+"sesión - una transacción de la base de datos\". También conocido y utilizado "
+"como una <emphasis>sesión-por-petición</emphasis>. El inicio y el final de "
+"una sesión Hibernate se define por la duración de una transacción de una "
+"base de datos. Si utiliza la demarcación de transacción programática en JSE "
+"sencillo sin JTA, se le aconseja que utilice el API <literal>Transaction</"
+"literal> de Hibernate para esconder el sistema de transacción subyacente de "
+"su código. Si utiliza JTA, utilice las interfaces JTA para demarcar "
+"transacciones. Si utiliza JTA, puede utilizar las interfaces JTA para "
+"demarcar transacciones. Si ejecuta en un contenedor EJB que soporta CMT, los "
+"límites de la transacción están definidos declarativamente y no necesita "
+"ninguna operación de demarcación de sesión o transacción en su código. "
+"Consulte <xref linkend=\"transactions\" /> para obtener más información y "
+"ejemplos de código."
 
 #. Tag: para
-#: architecture.xml:375
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>hibernate.current_session_context_class</literal> configuration "
 "parameter defines which <literal>org.hibernate.context."
@@ -654,19 +617,13 @@
 "however, there are three corresponding short names: \"jta\", \"thread\", and "
 "\"managed\"."
 msgstr ""
-"The <literal>hibernate.current_session_context_class</literal> configuration "
-"parameter defines which <literal>org.hibernate.context."
-"CurrentSessionContext</literal> implementation should be used. Note that for "
-"backwards compatibility, if this config param is not set but a <literal>org."
-"hibernate.transaction.TransactionManagerLookup</literal> is configured, "
-"Hibernate will use the <literal>org.hibernate.context.JTASessionContext</"
-"literal>. Typically, the value of this parameter would just name the "
-"implementation class to use; for the three out-of-the-box implementations, "
-"however, there are three corresponding short names, \"jta\", \"thread\", and "
-"\"managed\"."
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+"El parámetro de configuración <literal>hibernate."
+"current_session_context_class</literal> define cuales implementaciones "
+"<literal>org.hibernate.context.CurrentSessionContext</literal> deben "
+"utilizarse. Para compatibilidad con versiones anteriores, si este parámetro "
+"de configuración no está establecido pero si tiene configurado un "
+"<literal>org.hibernate.transaction.TransactionManagerLookup</literal>, "
+"Hibernate utilizará el <literal>org.hibernate.context.JTASessionContext</"
+"literal>. Usualmente el valor de este parámetro sólamente nombraría la clase "
+"de implementación a utilizar. Sin embargo, para las tres implementaciones "
+"incluídas existen tress nombres cortos: \"jta\", \"thread\" y \"managed\"."

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/association_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/association_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/association_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,27 +1,40 @@
-#, fuzzy
+# translation of association_mapping.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# 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: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2009-11-09 12:44+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: association_mapping.xml:30
 #, no-c-format
 msgid "Association Mappings"
-msgstr "Mapeos de Asociaci&#x00f3;n"
+msgstr "Mapeos de asociación"
 
 #. Tag: title
-#: association_mapping.xml:33
 #, no-c-format
 msgid "Introduction"
-msgstr "Introducci&#x00f3;n"
+msgstr "Introducción"
 
 #. Tag: para
-#: association_mapping.xml:35
-#, fuzzy, no-c-format
+#, 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, "
@@ -29,684 +42,173 @@
 "use <literal>Person</literal> and <literal>Address</literal> in all the "
 "examples."
 msgstr ""
-"Los mapeos de asociaci&#x00f3;n son frecuentemente las cosas mas dif&#x00ed;"
-"ciles de hacer correctamente. En esta secci&#x00f3;n iremos a trav&#x00e9;s "
-"de los casos can&#x00f3;nicos uno a uno, comenzando con los mapeos "
-"unidireccionales, y considerando luego los casos bidireccionales. Usaremos "
-"<literal>Person</literal> y <literal>Address</literal> en todos los ejemplos."
+"Los mapeos de asociación son frecuentemente lo más difícil de implementar "
+"correctamente. En esta sección revisaremos algunos casos canónicos uno por "
+"uno, comenzando con los mapeos unidireccionales y luego considerando los "
+"casos bidireccionales. Vamos a utilizar <literal>Person</literal> y "
+"<literal>Address</literal> en todos los ejemplos."
 
 #. Tag: para
-#: association_mapping.xml:43
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Associations will be classified by multiplicity and whether or not they map "
 "to an intervening join table."
 msgstr ""
-"Clasificaremos las asociaciones por cuanto mapeen o no a una tabla de "
-"uni&#x00f3;n interviniente, y por su multiplicidad."
+"Vamos a clasificar las asociaciones en cuanto su multiplicidad y a si mapean "
+"o no a una tabla de unión interviniente."
 
 #. Tag: para
-#: association_mapping.xml:48
-#, fuzzy, no-c-format
+#, 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 ""
-"Las claves for&#x00e1;neas que aceptan valores nulos (en adelante, "
-"nullables) no son consideradas una buena pr&#x00e1;ctica en el modelado "
-"tradicional de datos, as&#x00ed; que todos nuestros ejemplos usan claves "
-"for&#x00e1;neas no nullables. Esto no es un requerimiento de Hibernate, y "
-"todos los mapeos funcionar&#x00e1;n si quitas las restricciones de "
+"Las claves foráneas que aceptan valores nulos no se consideran como una "
+"buena práctica en el modelado tradicional de datos, así que todos nuestros "
+"ejemplos utilizan claves foráneas no nulas. Esto no es un requisito de "
+"Hibernate y todos los mapeos funcionarán si quita las restricciones de "
 "nulabilidad."
 
 #. Tag: title
-#: association_mapping.xml:58
 #, no-c-format
 msgid "Unidirectional associations"
 msgstr "Asociaciones Unidireccionales"
 
 #. Tag: title
-#: association_mapping.xml:61 association_mapping.xml:132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Many-to-one"
-msgstr "muchos a uno"
+msgstr "Many-to-one"
 
 #. Tag: para
-#: association_mapping.xml:63
 #, no-c-format
 msgid ""
 "A <emphasis>unidirectional many-to-one association</emphasis> is the most "
 "common kind of unidirectional association."
 msgstr ""
-"Una <emphasis>asociaci&#x00f3;n unidireccional muchos-a-uno</emphasis> es el "
-"tipo m&#x00e1;s com&#x00fa;n de asociaciones unidireccionales."
+"Una <emphasis>asociación unidireccional muchos-a-uno</emphasis> es el tipo "
+"de asociación unidireccional más común."
 
-#. Tag: programlisting
-#: association_mapping.xml:68
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-
-#. Tag: programlisting
-#: association_mapping.xml:69 association_mapping.xml:185
-#, no-c-format
-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"
-"        ]]>"
-
 #. Tag: title
-#: association_mapping.xml:74 association_mapping.xml:145
-#: association_mapping.xml:210
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "One-to-one"
-msgstr "uno a uno"
+msgstr "Uno-a-uno"
 
 #. Tag: para
-#: association_mapping.xml:76
 #, no-c-format
 msgid ""
 "A <emphasis>unidirectional one-to-one association on a foreign key</"
 "emphasis> is almost identical. The only difference is the column unique "
 "constraint."
 msgstr ""
-"Una <emphasis>asociaci&#x00f3;n unidireccional uno-a-uno en una clave "
-"primaria</emphasis> es casi id&#x00e9;ntica. La &#x00fa;nica diferencia es "
-"la restricci&#x00f3;n de unicidad de la columna."
+"Una <emphasis>asociación unidireccional uno-a-uno en una clave foránea</"
+"emphasis> es casi idéntica. La única diferencia es la restricción de "
+"unicidad de la columna."
 
-#. Tag: programlisting
-#: association_mapping.xml:81
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-
-#. Tag: programlisting
-#: association_mapping.xml:82 association_mapping.xml:218
-#, no-c-format
-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"
-"        ]]>"
-
-#. Tag: para
-#: association_mapping.xml:84
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>unidirectional one-to-one association on a primary key</"
 "emphasis> usually uses a special id generator In this example, however, we "
 "have reversed the direction of the association:"
 msgstr ""
-"Usualmente, una <emphasis>asociaci&#x00f3;n unidireccional uno-a-uno en una "
-"clave primaria</emphasis> usa un generador de id especial. (Observa que "
-"hemos invertido el sentido de la asociaci&#x00f3;n en este ejemplo)."
+"Usualmente, una <emphasis>asociación unidireccional uno-a-uno en una clave "
+"principal</emphasis> utiliza un generador de id especial. Sin embargo, hemos "
+"invertido la dirección de la asociación:"
 
-#. Tag: programlisting
-#: association_mapping.xml:90
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" constrained=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" constrained=\"true\"/>\n"
-"</class>]]>"
-
-#. Tag: programlisting
-#: association_mapping.xml:91 association_mapping.xml:226
-#, no-c-format
-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"
-"        ]]>"
-
 #. Tag: title
-#: association_mapping.xml:96 association_mapping.xml:118
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "One-to-many"
-msgstr "uno a muchos"
+msgstr "Uno-a-muchos"
 
 #. Tag: para
-#: association_mapping.xml:98
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>unidirectional one-to-many association on a foreign key</"
 "emphasis> is an unusual case, and is not recommended."
 msgstr ""
-"Una <emphasis>asociaci&#x00f3;n unidireccional uno-a-muchos en una clave "
-"for&#x00e1;nea</emphasis> es un caso muy inusual, y realmente no est&#x00e1; "
-"recomendada."
+"Una <emphasis>asociación unidireccional uno-a-muchos en una clave foránea</"
+"emphasis> es un caso muy inusual y no se recomienda."
 
-#. Tag: programlisting
-#: association_mapping.xml:103
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\">\n"
-"        <key column=\"personId\" \n"
-"            not-null=\"true\"/>\n"
-"        <one-to-many class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\">\n"
-"        <key column=\"personId\" \n"
-"            not-null=\"true\"/>\n"
-"        <one-to-many class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-
-#. Tag: programlisting
-#: association_mapping.xml:104
-#, no-c-format
-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"
-"        ]]>"
-
 #. Tag: para
-#: association_mapping.xml:106
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You should instead use a join table for this kind of association."
 msgstr ""
-"Creemos que es mejor usar una tabla de uni&#x00f3;n para este tipo de "
-"asociaci&#x00f3;n."
+"En lugar debe utilizar una tabla de unión para esta clase de asociación."
 
 #. Tag: title
-#: association_mapping.xml:115
 #, no-c-format
 msgid "Unidirectional associations with join tables"
-msgstr "Asociaciones unidireccionales con tablas de uni&#x00f3;n"
+msgstr "Asociaciones unidireccionales con tablas de unión"
 
 #. Tag: para
-#: association_mapping.xml:120
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>unidirectional one-to-many association on a join table</"
 "emphasis> is the preferred option. Specifying <literal>unique=\"true\"</"
 "literal>, changes the multiplicity from many-to-many to one-to-many."
 msgstr ""
-"Una <emphasis>asociaci&#x00f3;n unidireccional uno-a-muchos en una tabla de "
-"uni&#x00f3;n</emphasis> es m&#x00e1;s preferible. Observa que especificando "
-"<literal>unique=\"true\"</literal>, hemos cambiado la multiplicidad de "
-"muchos-a-muchos a uno-a-muchos."
+"Se prefiere una <emphasis>asociación unidireccional uno-a-muchos en una "
+"tabla de unión</emphasis> . El especificar <literal>unique=\"true\"</"
+"literal>, cambia la multiplicidad de muchos-a-muchos a uno-a-muchos."
 
-#. Tag: programlisting
-#: association_mapping.xml:126
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-
-#. Tag: programlisting
-#: association_mapping.xml:127
-#, no-c-format
-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"
-"        ]]>"
-
-#. Tag: para
-#: association_mapping.xml:134
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>unidirectional many-to-one association on a join table</"
 "emphasis> is common when the association is optional. For example:"
 msgstr ""
-"Una <emphasis>asociaci&#x00f3;n unidireccional muchos-a-uno en una tabla de "
-"uni&#x00f3;n</emphasis> es bastante com&#x00fa;n cuando la asociaci&#x00f3;n "
-"es opcional."
+"Una <emphasis>asociación unidireccional muchos-a-uno en una tabla de unión</"
+"emphasis> es común cuando la asociación es opcional. Por ejemplo:"
 
-#. Tag: programlisting
-#: association_mapping.xml:139
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-
-#. Tag: programlisting
-#: association_mapping.xml:140
-#, no-c-format
-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"
-"        ]]>"
-
-#. Tag: para
-#: association_mapping.xml:147
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>unidirectional one-to-one association on a join table</emphasis> "
 "is possible, but extremely unusual."
 msgstr ""
-"Una <emphasis>asociaci&#x00f3;n unidireccional uno-a-uno en una tabla de "
-"uni&#x00f3;n</emphasis> es inusual en extremo, pero posible."
+"Una <emphasis>asociación unidireccional uno-a-uno en una tabla de unión</"
+"emphasis> es extremadamente inusual, pero es posible. "
 
-#. Tag: programlisting
-#: association_mapping.xml:152
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-
-#. Tag: programlisting
-#: association_mapping.xml:153 association_mapping.xml:258
-#, no-c-format
-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"
-"        ]]>"
-
 #. Tag: title
-#: association_mapping.xml:158 association_mapping.xml:263
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Many-to-many"
-msgstr "muchos a muchos"
+msgstr "Muchos-a-muchos"
 
 #. Tag: para
-#: association_mapping.xml:160
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, here is an example of a <emphasis>unidirectional many-to-many "
 "association</emphasis>."
 msgstr ""
-"Finalmente, tenemos una <emphasis>asociaci&#x00f3;n unidireccional muchos-a-"
-"muchos</emphasis>"
+"Finalmente, este es un ejemplo de una <emphasis>asociación unidireccional "
+"muchos-a-muchos</emphasis>."
 
-#. Tag: programlisting
-#: association_mapping.xml:164
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-
-#. Tag: programlisting
-#: association_mapping.xml:165 association_mapping.xml:271
-#, no-c-format
-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"
-"        ]]>"
-
 #. Tag: title
-#: association_mapping.xml:172
 #, no-c-format
 msgid "Bidirectional associations"
-msgstr "Asociaciones Bidireccionales"
+msgstr "Asociaciones bidireccionales"
 
 #. Tag: title
-#: association_mapping.xml:175 association_mapping.xml:236
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "one-to-many / many-to-one"
-msgstr "uno a muchos / muchos a uno"
+msgstr "uno-a-muchos / muchos-a-uno"
 
 #. Tag: para
-#: association_mapping.xml:177
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional many-to-one association</emphasis> is the most "
 "common kind of association. The following example illustrates the standard "
 "parent/child relationship."
 msgstr ""
-"Una <emphasis>asociaci&#x00f3;n bidireccional muchos-a-uno</emphasis> es el "
-"tipo m&#x00e1;s com&#x00fa;n de asociaci&#x00f3;n. (Esta es la relaci&#x00f3;"
-"n est&#x00e1;ndar padre/hijo.)"
+"Una <emphasis>asociación bidireccional muchos-a-uno</emphasis> es el tipo de "
+"asociación más común. El siguiente ejemplo ilustra la relación estándar "
+"padre/hijo."
 
-#. Tag: programlisting
-#: association_mapping.xml:183
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <one-to-many class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <one-to-many class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
-
-#. Tag: para
-#: association_mapping.xml:187
-#, fuzzy, no-c-format
-msgid ""
 "If you use a <literal>List</literal>, or other indexed collection, set the "
 "<literal>key</literal> column of the foreign key to <literal>not null</"
 "literal>. Hibernate will manage the association from the collections side to "
@@ -714,62 +216,16 @@
 "by setting <literal>update=\"false\"</literal> and <literal>insert=\"false"
 "\"</literal>:"
 msgstr ""
-"UNTRANSLATED! If you use a <literal>List</literal> (or other indexed "
-"collection) you need to set the <literal>key</literal> column of the foreign "
-"key to <literal>not null</literal>, and let Hibernate manage the association "
-"from the collections side to maintain the index of each element (making the "
-"other side virtually inverse by setting <literal>update=\"false\"</literal> "
-"and <literal>insert=\"false\"</literal>):"
+"Si utiliza un <literal>List</literal>, u otra colección con índice, "
+"configure la columna <literal>key</literal> de la clave foránea como "
+"<literal>not null</literal>. Hibernate administrará la asociación del lado "
+"de las colecciones para mantener el índice de cada elemento, haciendo del "
+"otro lado virtualmente inverso al establecer <literal>update=\"false\"</"
+"literal> y <literal>insert=\"false\"</literal>:"
 
-#. Tag: programlisting
-#: association_mapping.xml:195
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"   <id name=\"id\"/>\n"
-"   ...\n"
-"   <many-to-one name=\"address\"\n"
-"      column=\"addressId\"\n"
-"      not-null=\"true\"\n"
-"      insert=\"false\"\n"
-"      update=\"false\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"   <id name=\"id\"/>\n"
-"   ...\n"
-"   <list name=\"people\">\n"
-"      <key column=\"addressId\" not-null=\"true\"/>\n"
-"      <list-index column=\"peopleIdx\"/>\n"
-"      <one-to-many class=\"Person\"/>\n"
-"   </list>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"                        <id name=\"id\"/>\n"
-"                        ...\n"
-"                        <many-to-one name=\"address\"\n"
-"                                     column=\"addressId\"\n"
-"                                     not-null=\"true\"\n"
-"                                     insert=\"false\"\n"
-"                                     update=\"false\"/>\n"
-"                </class>\n"
-"                \n"
-"                <class name=\"Address\">\n"
-"                        <id name=\"id\"/>\n"
-"                        ...\n"
-"                        <list name=\"people\">\n"
-"                                <key column=\"addressId\" not-null=\"true\"/"
-">\n"
-"                                <list-index column=\"peopleIdx\"/>\n"
-"                                <one-to-many class=\"Person\"/>\n"
-"                        </list>\n"
-"                </class>]]>"
-
-#. Tag: para
-#: association_mapping.xml:197
-#, fuzzy, no-c-format
-msgid ""
 "If the underlying foreign key column is <literal>NOT NULL</literal>, it is "
 "important that you define <literal>not-null=\"true\"</literal> on the "
 "<literal>&lt;key&gt;</literal> element of the collection mapping. Do not "
@@ -777,356 +233,79 @@
 "<literal>&lt;column&gt;</literal> element, but on the <literal>&lt;key&gt;</"
 "literal> element."
 msgstr ""
-"UNTRANSLATED! It is important that you define <literal>not-null=\"true\"</"
-"literal> on the <literal>&lt;key&gt;</literal> element of the collection "
-"mapping if the underlying foreign key column is <literal>NOT NULL</literal>. "
-"Don't only declare <literal>not-null=\"true\"</literal> on a possible nested "
-"<literal>&lt;column&gt;</literal> element, but on the <literal>&lt;key&gt;</"
-"literal> element."
+"Es importante que defina <literal>not-null=\"true\"</literal> en el elemento "
+"<literal>&lt;key&gt;</literal> del mapeo de la colección si la columna de la "
+"clave foránea es <literal>NOT NULL</literal>. No declare sólamente "
+"<literal>not-null=\"true\"</literal> en un elemento <literal>&lt;column&gt;</"
+"literal> posiblemente anidado sino en el elemento <literal>&lt;key&gt;</"
+"literal>. "
 
 #. Tag: para
-#: association_mapping.xml:212
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional one-to-one association on a foreign key</emphasis> "
 "is common:"
 msgstr ""
-"Una <emphasis>asociaci&#x00f3;n bidireccional uno-a-uno en una clave "
-"for&#x00e1;nea</emphasis> es bastante com&#x00fa;n."
+"Una <emphasis>asociación bidireccional uno-a-uno en una clave foránea</"
+"emphasis> es común:"
 
-#. Tag: programlisting
-#: association_mapping.xml:217
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"   <one-to-one name=\"person\" \n"
-"        property-ref=\"address\"/>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"   <one-to-one name=\"person\" \n"
-"        property-ref=\"address\"/>\n"
-"</class>]]>"
-
-#. Tag: para
-#: association_mapping.xml:220
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>bidirectional one-to-one association on a primary key</emphasis> "
 "uses the special id generator:"
 msgstr ""
-"Una <emphasis>asociaci&#x00f3;n bidireccional uno-a-uno en una clave "
-"primaria</emphasis> usa el generador de id especial."
+"Una <emphasis>asociación bidireccional uno-a-uno en una clave primaria</"
+"emphasis> utiliza el generador de id especial:"
 
-#. Tag: programlisting
-#: association_mapping.xml:225
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <one-to-one name=\"address\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" \n"
-"        constrained=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <one-to-one name=\"address\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" \n"
-"        constrained=\"true\"/>\n"
-"</class>]]>"
-
 #. Tag: title
-#: association_mapping.xml:233
 #, no-c-format
 msgid "Bidirectional associations with join tables"
-msgstr "Asociaciones bidireccionales con tablas de uni&#x00f3;n"
+msgstr "Asociaciones bidireccionales con tablas de unión"
 
 #. Tag: para
-#: association_mapping.xml:238
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is an example of a <emphasis>bidirectional one-to-many "
 "association on a join table</emphasis>. The <literal>inverse=\"true\"</"
 "literal> can go on either end of the association, on the collection, or on "
 "the join."
 msgstr ""
-"Una <emphasis>asociaci&#x00f3;n bidireccional uno-a-muchos en una tabla de "
-"uni&#x00f3;n</emphasis>. Observa que el <literal>inverse=\"true\"</literal> "
-"puede ir a cualquier lado de la asociaci&#x00f3;n, en la colecci&#x00f3;n, o "
-"en la uni&#x00f3;n."
+"El siguiente es un ejemplo de una <emphasis>asociación bidireccional uno-a-"
+"muchos en una tabla de unión</emphasis>. El <literal>inverse=\"true\"</"
+"literal> puede ir en cualquier lado de la asociación, en la colección, o en "
+"la unión."
 
-#. Tag: programlisting
-#: association_mapping.xml:244
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" \n"
-"        table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        inverse=\"true\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-one name=\"person\"\n"
-"            column=\"personId\"\n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" \n"
-"        table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        inverse=\"true\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-one name=\"person\"\n"
-"            column=\"personId\"\n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
-
-#. Tag: programlisting
-#: association_mapping.xml:245
-#, no-c-format
-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"
-"        ]]>"
-
 #. Tag: title
-#: association_mapping.xml:250
 #, no-c-format
 msgid "one to one"
 msgstr "uno a uno"
 
 #. Tag: para
-#: association_mapping.xml:252
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional one-to-one association on a join table</emphasis> "
 "is possible, but extremely unusual."
 msgstr ""
-"Una <emphasis>asociaci&#x00f3;n bidireccional uno-a-uno en una tabla de "
-"uni&#x00f3;n</emphasis> es inusual en extremo, pero posible."
+"Una <emphasis>asociación bidireccional uno-a-uno en una tabla de unión</"
+"emphasis> es extremadamente inusual, pero es posible. "
 
-#. Tag: programlisting
-#: association_mapping.xml:257
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\"\n"
-"        inverse=\"true\">\n"
-"        <key column=\"addressId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"person\"\n"
-"            column=\"personId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\"\n"
-"        inverse=\"true\">\n"
-"        <key column=\"addressId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"personId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
-
-#. Tag: para
-#: association_mapping.xml:265
-#, fuzzy, no-c-format
-msgid ""
 "Here is an example of a <emphasis>bidirectional many-to-many association</"
 "emphasis>."
 msgstr ""
-"Finalmente, tenemos una <emphasis>asociaci&#x00f3;n bidireccional muchos-a-"
+"Este es un ejemplo de una <emphasis>asociación bidireccional muchos-a-"
 "muchos</emphasis>."
 
-#. Tag: programlisting
-#: association_mapping.xml:269
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-many column=\"personId\"\n"
-"            class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-many column=\"personId\"\n"
-"            class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
-
 #. Tag: title
-#: association_mapping.xml:278
 #, no-c-format
 msgid "More complex association mappings"
-msgstr "UNTRANSLATED! More complex association mappings"
+msgstr "Mapeos de asociación más complejos"
 
 #. Tag: para
-#: association_mapping.xml:280
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "More complex association joins are <emphasis>extremely</emphasis> rare. "
 "Hibernate handles more complex situations by using SQL fragments embedded in "
@@ -1135,73 +314,25 @@
 "<literal>effectiveEndDate</literal> and <literal>effectiveStartDate</"
 "literal>columns, it would be mapped as follows:"
 msgstr ""
-"More complex association joins are <emphasis>extremely</emphasis> rare. "
-"Hibernate makes it possible to handle more complex situations using SQL "
-"fragments embedded in the mapping document. For example, if a table with "
-"historical account information data defines <literal>accountNumber</"
-"literal>, <literal>effectiveEndDate</literal> and "
-"<literal>effectiveStartDate</literal>columns, mapped as follows:"
+"Uniones de asociación más complejas son <emphasis>extremadamente</emphasis> "
+"raras. Hibernate maneja situaciones más complejas utilizando fragmentos SQL "
+"incluidos en el documento de mapeo. Por ejemplo, si una tabla con datos "
+"históricos de información de cuenta define las columnas "
+"<literal>accountNumber</literal>, <literal>effectiveEndDate</literal> y "
+"<literal>effectiveStartDate</literal>, se mapearían así:"
 
-#. Tag: programlisting
-#: association_mapping.xml:289
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<properties name=\"currentAccountKey\">\n"
-"    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
-"    <property name=\"currentAccount\" type=\"boolean\">\n"
-"        <formula>case when effectiveEndDate is null then 1 else 0 end</"
-"formula>\n"
-"    </property>\n"
-"</properties>\n"
-"<property name=\"effectiveEndDate\" type=\"date\"/>\n"
-"<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
-msgstr ""
-"<![CDATA[<properties name=\"currentAccountKey\">\n"
-"                            <property name=\"accountNumber\" type=\"string\" "
-"not-null=\"true\"/>\n"
-"                            <property name=\"currentAccount\" type=\"boolean"
-"\">\n"
-"                                    <formula>case when effectiveEndDate is "
-"null then 1 else 0 end</formula>\n"
-"                            </property>\n"
-"                    </properties>\n"
-"                    <property name=\"effectiveEndDate\" type=\"date\"/>\n"
-"                    <property name=\"effectiveStateDate\" type=\"date\" not-"
-"null=\"true\"/>]]>"
-
-#. Tag: para
-#: association_mapping.xml:291
-#, fuzzy, no-c-format
-msgid ""
 "You can then map an association to the <emphasis>current</emphasis> "
 "instance, the one with null <literal>effectiveEndDate</literal>, by using:"
 msgstr ""
-"Then we can map an association to the <emphasis>current</emphasis> instance "
-"(the one with null <literal>effectiveEndDate</literal>) using:"
+"Entonces puede mapear una asociación a la instancia <emphasis>actual</"
+"emphasis>, la que tiene <literal>effectiveEndDate</literal> nulo, utilizando:"
 
-#. Tag: programlisting
-#: association_mapping.xml:296
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
-"        property-ref=\"currentAccountKey\"\n"
-"        class=\"AccountInfo\">\n"
-"    <column name=\"accountNumber\"/>\n"
-"    <formula>'1'</formula>\n"
-"</many-to-one>]]>"
-msgstr ""
-"<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
-"                                                  property-ref="
-"\"currentAccountKey\"\n"
-"                                                  class=\"AccountInfo\">\n"
-"                            <column name=\"accountNumber\"/>\n"
-"                            <formula>'1'</formula>\n"
-"                    </many-to-one>]]>"
-
-#. Tag: para
-#: association_mapping.xml:298
-#, fuzzy, no-c-format
-msgid ""
 "In a more complex example, imagine that the association between "
 "<literal>Employee</literal> and <literal>Organization</literal> is "
 "maintained in an <literal>Employment</literal> table full of historical "
@@ -1209,55 +340,806 @@
 "emphasis> employer, the one with the most recent <literal>startDate</"
 "literal>, could be mapped in the following way:"
 msgstr ""
-"In a more complex example, imagine that the association between "
-"<literal>Employee</literal> and <literal>Organization</literal> is "
-"maintained in an <literal>Employment</literal> table full of historical "
-"employment data. Then an association to the employee's <emphasis>most "
-"recent</emphasis> employer (the one with the most recent <literal>startDate</"
-"literal>) might be mapped this way:"
+"En un ejemplo más complejo, imagínese que la asociación entre "
+"<literal>Employee</literal> y <literal>Organization</literal> se mantienen "
+"en una tabla <literal>Employment</literal> llena de datos históricos de "
+"empleo. Entonces se puede mapear una asociación al empleador <emphasis>más "
+"reciente</emphasis> del empleado, el que tiene la <literal>startDate</"
+"literal> más reciente, de esta manera:"
 
-#. Tag: programlisting
-#: association_mapping.xml:306
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<join>\n"
-"    <key column=\"employeeId\"/>\n"
-"    <subselect>\n"
-"        select employeeId, orgId \n"
-"        from Employments \n"
-"        group by orgId \n"
-"        having startDate = max(startDate)\n"
-"    </subselect>\n"
-"    <many-to-one name=\"mostRecentEmployer\" \n"
-"            class=\"Organization\" \n"
-"            column=\"orgId\"/>\n"
-"</join>]]>"
-msgstr ""
-"<![CDATA[<join>\n"
-"                            <key column=\"employeeId\"/>\n"
-"                            <subselect>\n"
-"                                    select employeeId, orgId \n"
-"                                    from Employments \n"
-"                                    group by orgId \n"
-"                                    having startDate = max(startDate)\n"
-"                            </subselect>\n"
-"                            <many-to-one name=\"mostRecentEmployer\" \n"
-"                                         class=\"Organization\" \n"
-"                                         column=\"orgId\"/>\n"
-"                    </join>]]>"
-
-#. Tag: para
-#: association_mapping.xml:308
-#, fuzzy, 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 ""
-"You can get quite creative with this functionality, but it is usually more "
-"practical to handle these kinds of cases using HQL or a criteria query."
+"Esta funcionalidad le permite cierto grado de creatividad y flexibilidad, "
+"pero usualmente es más práctico manejar esta clase de casos utilizando HQL o "
+"una petición de criterio."
 
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
 
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" constrained=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        <one-to-many class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        <one-to-many class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <one-to-many class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <one-to-many class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <many-to-one name=\"address\"\n"
+#~ "      column=\"addressId\"\n"
+#~ "      not-null=\"true\"\n"
+#~ "      insert=\"false\"\n"
+#~ "      update=\"false\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <list name=\"people\">\n"
+#~ "      <key column=\"addressId\" not-null=\"true\"/>\n"
+#~ "      <list-index column=\"peopleIdx\"/>\n"
+#~ "      <one-to-many class=\"Person\"/>\n"
+#~ "   </list>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <many-to-one name=\"address\"\n"
+#~ "      column=\"addressId\"\n"
+#~ "      not-null=\"true\"\n"
+#~ "      insert=\"false\"\n"
+#~ "      update=\"false\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <list name=\"people\">\n"
+#~ "      <key column=\"addressId\" not-null=\"true\"/>\n"
+#~ "      <list-index column=\"peopleIdx\"/>\n"
+#~ "      <one-to-many class=\"Person\"/>\n"
+#~ "   </list>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "   <one-to-one name=\"person\" \n"
+#~ "        property-ref=\"address\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "   <one-to-one name=\"person\" \n"
+#~ "        property-ref=\"address\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"address\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" \n"
+#~ "        constrained=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"address\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" \n"
+#~ "        constrained=\"true\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        inverse=\"true\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        inverse=\"true\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\"\n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"addressId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\"\n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"addressId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-many column=\"personId\"\n"
+#~ "            class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-many column=\"personId\"\n"
+#~ "            class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<properties name=\"currentAccountKey\">\n"
+#~ "    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
+#~ "    <property name=\"currentAccount\" type=\"boolean\">\n"
+#~ "        <formula>case when effectiveEndDate is null then 1 else 0 end</"
+#~ "formula>\n"
+#~ "    </property>\n"
+#~ "</properties>\n"
+#~ "<property name=\"effectiveEndDate\" type=\"date\"/>\n"
+#~ "<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<properties name=\"currentAccountKey\">\n"
+#~ "    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
+#~ "    <property name=\"currentAccount\" type=\"boolean\">\n"
+#~ "        <formula>case when effectiveEndDate is null then 1 else 0 end</"
+#~ "formula>\n"
+#~ "    </property>\n"
+#~ "</properties>\n"
+#~ "<property name=\"effectiveEndDate\" type=\"date\"/>\n"
+#~ "<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
+#~ "        property-ref=\"currentAccountKey\"\n"
+#~ "        class=\"AccountInfo\">\n"
+#~ "    <column name=\"accountNumber\"/>\n"
+#~ "    <formula>'1'</formula>\n"
+#~ "</many-to-one>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
+#~ "        property-ref=\"currentAccountKey\"\n"
+#~ "        class=\"AccountInfo\">\n"
+#~ "    <column name=\"accountNumber\"/>\n"
+#~ "    <formula>'1'</formula>\n"
+#~ "</many-to-one>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<join>\n"
+#~ "    <key column=\"employeeId\"/>\n"
+#~ "    <subselect>\n"
+#~ "        select employeeId, orgId \n"
+#~ "        from Employments \n"
+#~ "        group by orgId \n"
+#~ "        having startDate = max(startDate)\n"
+#~ "    </subselect>\n"
+#~ "    <many-to-one name=\"mostRecentEmployer\" \n"
+#~ "            class=\"Organization\" \n"
+#~ "            column=\"orgId\"/>\n"
+#~ "</join>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<join>\n"
+#~ "    <key column=\"employeeId\"/>\n"
+#~ "    <subselect>\n"
+#~ "        select employeeId, orgId \n"
+#~ "        from Employments \n"
+#~ "        group by orgId \n"
+#~ "        having startDate = max(startDate)\n"
+#~ "    </subselect>\n"
+#~ "    <many-to-one name=\"mostRecentEmployer\" \n"
+#~ "            class=\"Organization\" \n"
+#~ "            column=\"orgId\"/>\n"
+#~ "</join>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/basic_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/basic_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/basic_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,217 +1,91 @@
-#, fuzzy
+# translation of basic_mapping.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: basic_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-05 17:34+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: basic_mapping.xml:29
 #, no-c-format
 msgid "Basic O/R Mapping"
-msgstr "Mapeo O/R B&#x00e1;sico"
+msgstr "Mapeo O/R Básico"
 
 #. Tag: title
-#: basic_mapping.xml:32
 #, no-c-format
 msgid "Mapping declaration"
-msgstr "Declaraci&#x00f3;n de mapeo"
+msgstr "Declaración de mapeo"
 
 #. Tag: para
-#: basic_mapping.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Object/relational mappings are usually defined in an XML document. The "
 "mapping document is designed to be readable and hand-editable. The mapping "
 "language is Java-centric, meaning that mappings are constructed around "
 "persistent class declarations and not table declarations."
 msgstr ""
-"Los mapeos objeto/relacional se definen usualmente en un documento XML. El "
-"documento de mapeo est&#x00e1; dise&#x00f1;ado para ser le&#x00ed;ble y "
-"editable a mano. El lenguaje de mapeo es Java-c&#x00e9;ntrico, o sea que los "
-"mapeos se construyen alrededor de declaraciones de clases persistentes, no "
-"declaraciones de tablas."
+"Los mapeos objeto/relacional usualmente se definen en un documento XML. El "
+"documento de mapeo está diseñado para que se pueda leer y editar a mano. El "
+"lenguaje de mapeo está centrado en Java, lo que significa que los mapeos se "
+"construyen alrededor de declaraciones de clases persistentes y no alrededor "
+"de declaraciones de tablas."
 
 #. Tag: para
-#: basic_mapping.xml:41
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please note that even though many Hibernate users choose to write the XML by "
 "hand, a number of tools exist to generate the mapping document. These "
 "include XDoclet, Middlegen and AndroMDA."
 msgstr ""
-"Observa que, incluso aunque muchos usuarios de Hibernate eligen escribir el "
-"XML a mano, existe una cantidad de herramientas para generar el documento de "
-"mapeo, incluyendo XDoclet, Middlegen y AndroMDA."
+"Observe que, incluso aunque muchos de los usuarios de Hibernate eligen "
+"escribir el XML a mano, existe un número de herramientas para generar el "
+"documento de mapeo, incluyendo XDoclet, Middlegen y AndroMDA. "
 
 #. Tag: para
-#: basic_mapping.xml:47
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is an example mapping:"
-msgstr "Comencemos por un mapeo de ejemplo:"
+msgstr "Este es un ejemplo de mapeo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:51
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"      \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"          \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"        <class name=\"Cat\"\n"
-"            table=\"cats\"\n"
-"            discriminator-value=\"C\">\n"
-"\n"
-"                <id name=\"id\">\n"
-"                        <generator class=\"native\"/>\n"
-"                </id>\n"
-"\n"
-"                <discriminator column=\"subclass\"\n"
-"                     type=\"character\"/>\n"
-"\n"
-"                <property name=\"weight\"/>\n"
-"\n"
-"                <property name=\"birthdate\"\n"
-"                    type=\"date\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"color\"\n"
-"                    type=\"eg.types.ColorUserType\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"sex\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"litterId\"\n"
-"                    column=\"litterId\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <many-to-one name=\"mother\"\n"
-"                    column=\"mother_id\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <set name=\"kittens\"\n"
-"                    inverse=\"true\"\n"
-"                    order-by=\"litter_id\">\n"
-"                        <key column=\"mother_id\"/>\n"
-"                        <one-to-many class=\"Cat\"/>\n"
-"                </set>\n"
-"\n"
-"                <subclass name=\"DomesticCat\"\n"
-"                    discriminator-value=\"D\">\n"
-"\n"
-"                        <property name=\"name\"\n"
-"                            type=\"string\"/>\n"
-"\n"
-"                </subclass>\n"
-"\n"
-"        </class>\n"
-"\n"
-"        <class name=\"Dog\">\n"
-"                <!-- mapping for Dog could go here -->\n"
-"        </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"      \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"          \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"        <class name=\"Cat\" \n"
-"            table=\"cats\"\n"
-"            discriminator-value=\"C\">\n"
-"                \n"
-"                <id name=\"id\">\n"
-"                        <generator class=\"native\"/>\n"
-"                </id>\n"
-"\n"
-"                <discriminator column=\"subclass\" \n"
-"                     type=\"character\"/>\n"
-"\n"
-"                <property name=\"weight\"/>\n"
-"\n"
-"                <property name=\"birthdate\"\n"
-"                    type=\"date\" \n"
-"                    not-null=\"true\" \n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"color\"\n"
-"                    type=\"eg.types.ColorUserType\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"sex\"\n"
-"                    not-null=\"true\" \n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"litterId\"\n"
-"                    column=\"litterId\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <many-to-one name=\"mother\"\n"
-"                    column=\"mother_id\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <set name=\"kittens\"\n"
-"                    inverse=\"true\"\n"
-"                    order-by=\"litter_id\">\n"
-"                        <key column=\"mother_id\"/>\n"
-"                        <one-to-many class=\"Cat\"/>\n"
-"                </set>\n"
-"\n"
-"                <subclass name=\"DomesticCat\"\n"
-"                    discriminator-value=\"D\">\n"
-"\n"
-"                        <property name=\"name\" \n"
-"                            type=\"string\"/>\n"
-"\n"
-"                </subclass>\n"
-"\n"
-"        </class>\n"
-"\n"
-"        <class name=\"Dog\">\n"
-"                <!-- mapping for Dog could go here -->\n"
-"        </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:53
-#, fuzzy, no-c-format
-msgid ""
 "We will now discuss the content of the mapping document. We will only "
 "describe, however, the document elements and attributes that are used by "
 "Hibernate at runtime. The mapping document also contains some extra optional "
 "attributes and elements that affect the database schemas exported by the "
 "schema export tool (for example, the <literal> not-null</literal> attribute)."
 msgstr ""
-"Discutiremos ahora el contenido del documento de mapeo. Describiremos "
-"s&#x00f3;lo los elementos y atributos que son usados por Hibernate en tiempo "
-"de ejecuci&#x00f3;n. El documento de mapeo contiene adem&#x00e1;s algunos "
-"atributos y elementos extra opcionales que afectan los esquemas de base de "
-"datos exportados por la herramienta de exportaci&#x00f3;n de esquemas. (Por "
-"ejemplo, el atributo <literal>not-null</literal>.)"
+"Ahora vamos a discutir el contenido del documento de mapeo. Sólamente "
+"describiremos los elementos y atributos del documento que Hibernate utiliza "
+"en tiempo de ejecución. El documento de mapeo también comprende algunos "
+"atributos y elementos extra opcionales que afectan los esquemas de la base "
+"de datos exportados por la herramienta de exportación de esquemas (por "
+"ejemplo, el atributo <literal>not-null</literal>)."
 
 #. Tag: title
-#: basic_mapping.xml:64
 #, no-c-format
 msgid "Doctype"
 msgstr "Doctype"
 
 #. Tag: para
-#: basic_mapping.xml:66
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All XML mappings should declare the doctype shown. The actual DTD can be "
 "found at the URL above, in the directory <literal>hibernate-x.x.x/src/org/"
@@ -220,23 +94,21 @@
 "lookups of the DTD using an Internet connection, check the DTD declaration "
 "against the contents of your classpath."
 msgstr ""
-"Todos los mapeos XML deben declarar el doctype mostrado. El DTD actual puede "
-"ser encontrado en el URL mencionado arriba, en el directorio "
-"<literal>hibernate-x.x.x/src/org/hibernate</literal>, o en "
-"<literal>hibernate3.jar</literal>. Hibernate siempre buscar&#x00e1; el DTD "
-"primero en el classpath. Si experimentas b&#x00fa;squedas del DTD usando una "
-"conexi&#x00f3;n de Internet, chequea tu declaraci&#x00f3;n de DTD contra la "
-"contenida en el classpath."
+"Todos los mapeos XML deben declarar el tipo de documento que se muestra. El "
+"DTD en sí se puede encontrar en la URL mencionada anteriormente, en el "
+"directorio <literal>hibernate-x.x.x/src/org/hibernate </literal>, o en "
+"<literal>hibernate3.jar</literal>. Hibernate siempre buscará el DTD primero "
+"en la ruta de clase. Si el DTD realiza búsquedas utilizando una conexión de "
+"Internet, verifique que su declaración DTD frente al contenido de su ruta de "
+"clase."
 
 #. Tag: title
-#: basic_mapping.xml:76
 #, no-c-format
 msgid "EntityResolver"
-msgstr "UNTRANSLATED! EntityResolver"
+msgstr "EntityResolver"
 
 #. Tag: para
-#: basic_mapping.xml:77
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will first attempt to resolve DTDs in its classpath. It does this "
 "is by registering a custom <literal>org.xml.sax.EntityResolver</literal> "
@@ -244,30 +116,28 @@
 "custom <literal>EntityResolver</literal> recognizes two different systemId "
 "namespaces:"
 msgstr ""
-"As mentioned previously, Hibernate will first attempt to resolve DTDs in its "
-"classpath. The manner in which it does this is by registering a custom "
-"<literal>org.xml.sax.EntityResolver</literal> implementation with the "
-"SAXReader it uses to read in the xml files. This custom "
-"<literal>EntityResolver</literal> recognizes two different systemId "
-"namespaces."
+"Hibernate tratará primero de resolver los DTDs en su ruta de clase. La "
+"manera en que lo hace es registrando una implementación <literal>org.xml.sax."
+"EntityResolver</literal> personalizada con el SAXReader que utiliza para "
+"leer los archivos xml. Este <literal>EntityResolver</literal> personalizado "
+"reconoce dos diferentes espacios de nombre del identificador del sistema."
 
 #. Tag: para
-#: basic_mapping.xml:85
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "a <literal>hibernate namespace</literal> is recognized whenever the resolver "
 "encounters a systemId starting with <literal>http://hibernate.sourceforge."
 "net/</literal>. The resolver attempts to resolve these entities via the "
 "classloader which loaded the Hibernate classes."
 msgstr ""
-"a <literal>hibernate namespace</literal> is recognized whenever the resolver "
-"encounteres a systemId starting with <literal>http://hibernate.sourceforge."
-"net/</literal>; the resolver attempts to resolve these entities via the "
-"classlaoder which loaded the Hibernate classes."
+"un <literal>hibernate namespace</literal> se reconoce cuando el resolvedor "
+"se encuentra con un identificador de sistema que inicia por <literal>http://"
+"hibernate.sourceforge.net/</literal>. El resolvedor intenta resolver estas "
+"entidades por medio del cargador de clases, el cual cargó las clases de "
+"Hibernate."
 
 #. Tag: para
-#: basic_mapping.xml:94
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "a <literal>user namespace</literal> is recognized whenever the resolver "
 "encounters a systemId using a <literal>classpath://</literal> URL protocol. "
@@ -275,80 +145,36 @@
 "thread context classloader and (2) the classloader which loaded the "
 "Hibernate classes."
 msgstr ""
-"a <literal>user namespace</literal> is recognized whenever the resolver "
-"encounteres a systemId using a <literal>classpath://</literal> URL protocol; "
-"the resolver will attempt to resolve these entities via (1) the current "
-"thread context classloader and (2) the classloader which loaded the "
-"Hibernate classes."
+"un <literal>user namespace</literal> se reconoce cuando el resolvedor se "
+"encuentra con un identificador del sistema utilizando un protocolo URL "
+"<literal>classpath://</literal>. El resolvedor intentará resolver estas "
+"entidades por medio de (1) el cargador de clase del contexto del hilo actual "
+"y (2) el cargador de clase, el cual cargó las clases de Hibernate."
 
 #. Tag: para
-#: basic_mapping.xml:103
-#, fuzzy, no-c-format
-msgid "The following is an example of utilizing user namespacing:"
-msgstr "An example of utilizing user namespacing:"
-
-#. Tag: programlisting
-#: basic_mapping.xml:106
 #, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\" [\n"
-"    <!ENTITY types SYSTEM \"classpath://your/domain/types.xml\">\n"
-"]>\n"
-"\n"
-"<hibernate-mapping package=\"your.domain\">\n"
-"    <class name=\"MyEntity\">\n"
-"        <id name=\"id\" type=\"my-custom-id-type\">\n"
-"            ...\n"
-"        </id>\n"
-"    <class>\n"
-"    &types;\n"
-"</hibernate-mapping>]]>"
+msgid "The following is an example of utilizing user namespacing:"
 msgstr ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"                            <!DOCTYPE hibernate-mapping PUBLIC\n"
-"                                      \"-//Hibernate/Hibernate Mapping DTD "
-"3.0//EN\"\n"
-"                                      \"http://hibernate.sourceforge.net/"
-"hibernate-mapping-3.0.dtd\" [\n"
-"                                      <!ENTITY types SYSTEM \"classpath://"
-"your/domain/types.xml\">\n"
-"                                      ]>\n"
-"                                      \n"
-"                                      <hibernate-mapping package=\"your."
-"domain\">\n"
-"                                              <class name=\"MyEntity\">\n"
-"                                                      <id name=\"id\" type="
-"\"my-custom-id-type\">\n"
-"                                                              ...\n"
-"                                                      </id>\n"
-"                                                      <class>\n"
-"                                                              &types;\n"
-"                                                      </hibernate-mapping>]]>"
+"Este es un ejemplo de la utilización de los espacios de nombre del usuario: "
 
 #. Tag: para
-#: basic_mapping.xml:107
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Where <literal>types.xml</literal> is a resource in the <literal>your."
 "domain</literal> package and contains a custom <link linkend=\"mapping-types-"
 "custom\">typedef</link>."
 msgstr ""
-"Where <literal>types.xml</literal> is a resource in the <literal>your."
-"domain</literal> package and contains a custom <link linkend=\"mapping-types-"
-"custom\">typedef</link>."
+"En donde <literal>types.xml</literal> es un recurso en el paquete "
+"<literal>your.domain</literal> y comprende un <xref linkend=\"mapping-types-"
+"custom\" /> personalizado."
 
 #. Tag: title
-#: basic_mapping.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Hibernate-mapping"
-msgstr "hibernate-mapping"
+msgstr "Mapeo de Hibernate "
 
 #. Tag: para
-#: basic_mapping.xml:117
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This element has several optional attributes. The <literal>schema</literal> "
 "and <literal>catalog</literal> attributes specify that tables referred to in "
@@ -361,131 +187,97 @@
 "literal> attribute allows you to use unqualified class names in the query "
 "language."
 msgstr ""
-"Este elemento tiene muchos atributos opcionales. Los atributos "
+"Este elemento tiene varios atributos opcionales. Los atributos "
 "<literal>schema</literal> y <literal>catalog</literal> especifican que las "
-"tablas a las que se refiere en el mapeo pertenecen al esquema y/o cat&#x00e1;"
-"logo mencionado(s). De especificarse, los nombres de tablas ser&#x00e1;n "
-"cualificados por el nombre de esquema y cat&#x00e1;logo dados. De omitirse, "
-"los nombres de tablas no ser&#x00e1;n cualificados. El atributo "
-"<literal>default-cascade</literal> especifica qu&#x00e9; estilo de cascada "
-"debe asumirse para las propiedades y colecciones que no especifican un "
-"atributo <literal>cascade</literal>. El atributo <literal>auto-import</"
-"literal> nos permite usar nombres de clase sin cualificar en el lenguaje de "
-"consulta, por defecto."
+"tablas a las que se refiere en este mapeo pertenecen al esquema y/o catálogo "
+"mencionado(s). De especificarse, los nombres de tablas serán calificados por "
+"el nombre del esquema y del catálogo dados. De omitirse, los nombres de las "
+"tablas no serán calificados. El atributo <literal>default-cascade</literal> "
+"especifica qué estilo de cascada se debe asumir para las propiedades y "
+"colecciones que no especifican un atributo <literal>cascade</literal>. Por "
+"defecto, el atributo <literal>auto-import</literal> nos permite utilizar "
+"nombres de clase sin calificar en el lenguaje de consulta."
 
-#. Tag: programlisting
-#: basic_mapping.xml:138
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping\n"
-"         schema=\"schemaName\"\n"
-"         catalog=\"catalogName\"\n"
-"         default-cascade=\"cascade_style\"\n"
-"         default-access=\"field|property|ClassName\"\n"
-"         default-lazy=\"true|false\"\n"
-"         auto-import=\"true|false\"\n"
-"         package=\"package.name\"\n"
-" />]]>"
-msgstr ""
-"<![CDATA[<hibernate-mapping\n"
-"         schema=\"schemaName\"\n"
-"         catalog=\"catalogName\"\n"
-"         default-cascade=\"cascade_style\"\n"
-"         default-access=\"field|property|ClassName\"\n"
-"         default-lazy=\"true|false\"\n"
-"         auto-import=\"true|false\"\n"
-"         package=\"package.name\"\n"
-" />]]>"
-
 #. Tag: para
-#: basic_mapping.xml:141
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>schema</literal> (optional): the name of a database schema."
 msgstr ""
 "<literal>schema</literal> (opcional): El nombre de un esquema de la base de "
-"datos."
+"datos. "
 
 #. Tag: para
-#: basic_mapping.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>catalog</literal> (optional): the name of a database catalog."
 msgstr ""
-"<literal>catalog</literal> (opcional): El nombre de un cat&#x00e1;logo de la "
-"base de datos."
+"<literal>catalog</literal> (opcional): El nombre de un catálogo de la base "
+"de datos. "
 
 #. Tag: para
-#: basic_mapping.xml:151
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>default-cascade</literal> (optional - defaults to <literal>none</"
 "literal>): a default cascade style."
 msgstr ""
-"<literal>default-cascade</literal> (opcional - por defecto a <literal>none</"
-"literal>): Un estilo de cascada por defecto."
+"<literal>default-cascade</literal> (opcional - por defecto es <literal>none</"
+"literal>): Un estilo de cascada por defecto. "
 
 #. Tag: para
-#: basic_mapping.xml:157
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>default-access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate should use for accessing all properties. "
 "It can be a custom implementation of <literal>PropertyAccessor</literal>."
 msgstr ""
-"<literal>default-access</literal> (opcional - por defecto a "
-"<literal>property</literal>): La estrategia que Hibernate debe usar para "
-"acceder a todas las propiedades. Puede ser una implementaci&#x00f3;n "
-"personalizada de <literal>PropertyAccessor</literal>."
+"<literal>default-access</literal> (opcional - por defecto es "
+"<literal>property</literal>): La estrategia que Hibernate debe utilizar para "
+"acceder a todas las propiedades. Puede ser una implementación personalizada "
+"de <literal>PropertyAccessor</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:164
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>default-lazy</literal> (optional - defaults to <literal>true</"
 "literal>): the default value for unspecified <literal>lazy</literal> "
 "attributes of class and collection mappings."
 msgstr ""
-"<literal>default-lazy</literal> (opcional - por defecto a <literal>true</"
+"<literal>default-lazy</literal> (opcional - por defecto es <literal>true</"
 "literal>): El valor por defecto para los atributos <literal>lazy</literal> "
-"de mapeos de clase y colleci&#x00f3;n no especificados."
+"no especificados de mapeos de clase y de colección."
 
 #. Tag: para
-#: basic_mapping.xml:171
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>auto-import</literal> (optional - defaults to <literal>true</"
 "literal>): specifies whether we can use unqualified class names of classes "
 "in this mapping in the query language."
 msgstr ""
-"<literal>auto-import</literal> (opcional - por defecto a <literal>true</"
-"literal>): Especifica si podemos usar nombres de clases no cualificados (de "
-"clases en este mapeo) en el lenguaje de consulta."
+"<literal>auto-import</literal> (opcional - por defecto es <literal>true</"
+"literal>): Especifica si podemos utilizar nombres de clases no calificados "
+"de clases en este mapeo en el lenguaje de consulta."
 
 #. Tag: para
-#: basic_mapping.xml:178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>package</literal> (optional): specifies a package prefix to use for "
 "unqualified class names in the mapping document."
 msgstr ""
-"<literal>package</literal> (opcional): Especifica un prefijo de paquete a "
-"asumir para los nombres no cualificados de clase en el documento de mapeo."
+"<literal>package</literal> (opcional): Especifica un prefijo de paquete que "
+"se debe utilizar para los nombres de clase no calificados en el documento de "
+"mapeo."
 
 #. Tag: para
-#: basic_mapping.xml:186
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you have two persistent classes with the same unqualified name, you "
 "should set <literal>auto-import=\"false\"</literal>. An exception will "
 "result if you attempt to assign two classes to the same \"imported\" name."
 msgstr ""
-"Si tienes dos clases persistentes con el mismo nombre (sin cualificar), "
-"debes establecer <literal>auto-import=\"false\"</literal>. Hibernate "
-"lanzar&#x00e1; una excepci&#x00f3;n si intentas asignar dos clases al mismo "
-"nombre \"importado\"."
+"Si tiene dos clases persistentes con el mismo nombre (sin calificar), debe "
+"establecer <literal>auto-import=\"false\"</literal>. Se presentará una "
+"excepción si usted intenta asignar dos clases al mismo nombre \"importado\"."
 
 #. Tag: para
-#: basic_mapping.xml:192
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>hibernate-mapping</literal> element allows you to nest several "
 "persistent <literal>&lt;class&gt;</literal> mappings, as shown above. It is, "
@@ -495,193 +287,126 @@
 "literal>, <literal>Dog.hbm.xml</literal>, or if using inheritance, "
 "<literal>Animal.hbm.xml</literal>."
 msgstr ""
-"Observa que el elemento <literal>hibernate-mapping</literal> te permite "
-"anidar muchos mapeos <literal>&lt;class&gt;</literal> persistentes, como se "
-"muestra arriba. Sin embargo, es una buena pr&#x00e1;ctica (y se espera de "
-"algunas herramientas) mapear s&#x00f3;lo a una sola clase persistente (o a "
-"una sola jerarqu&#x00ed;a de clases) en un fichero de mapeo y nombrarlo "
-"despu&#x00e9;s de la superclase persistente; por ejemplo, <literal>Cat.hbm."
-"xml</literal>, <literal>Dog.hbm.xml</literal>, o, si se usa herencia, "
-"<literal>Animal.hbm.xml</literal>."
+"El elemento <literal>hibernate-mapping</literal> le permite anidar varios "
+"mapeos <literal>&lt;class&gt;</literal> persistentes, como se mostró "
+"anteriormente. Sin embargo, es una buena práctica (y algunas herramientas "
+"esperan) que mapee sólamente una clase persistente, o a una sóla jerarquía "
+"de clases, en un archivo de mapeo y nombrarlo como la superclase "
+"persistente. Por ejemplo, <literal>Cat.hbm.xml</literal>, <literal>Dog.hbm."
+"xml</literal>, o si utiliza herencia, <literal>Animal.hbm.xml</literal>."
 
 #. Tag: title
-#: basic_mapping.xml:205
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Class"
-msgstr "subclass"
+msgstr "Clase"
 
 #. Tag: para
-#: basic_mapping.xml:207
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can declare a persistent class using the <literal>class</literal> "
 "element. For example:"
 msgstr ""
-"Puedes declarar una clase persistente usando el elemento <literal>class</"
-"literal>:"
+"Puede declarar una clase persistente utilizando el elemento <literal>class</"
+"literal>. Por ejemplo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:235
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class\n"
-"        name=\"ClassName\"\n"
-"        table=\"tableName\"\n"
-"        discriminator-value=\"discriminator_value\"\n"
-"        mutable=\"true|false\"\n"
-"        schema=\"owner\"\n"
-"        catalog=\"catalog\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        select-before-update=\"true|false\"\n"
-"        polymorphism=\"implicit|explicit\"\n"
-"        where=\"arbitrary sql where condition\"\n"
-"        persister=\"PersisterClass\"\n"
-"        batch-size=\"N\"\n"
-"        optimistic-lock=\"none|version|dirty|all\"\n"
-"        lazy=\"true|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        check=\"arbitrary sql check condition\"\n"
-"        rowid=\"rowid\"\n"
-"        subselect=\"SQL expression\"\n"
-"        abstract=\"true|false\"\n"
-"        node=\"element-name\"\n"
-"/>]]>"
-msgstr ""
-"<![CDATA[<class\n"
-"        name=\"ClassName\"\n"
-"        table=\"tableName\"\n"
-"        discriminator-value=\"discriminator_value\"\n"
-"        mutable=\"true|false\"\n"
-"        schema=\"owner\"\n"
-"        catalog=\"catalog\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        select-before-update=\"true|false\"\n"
-"        polymorphism=\"implicit|explicit\"\n"
-"        where=\"arbitrary sql where condition\"\n"
-"        persister=\"PersisterClass\"\n"
-"        batch-size=\"N\"\n"
-"        optimistic-lock=\"none|version|dirty|all\"\n"
-"        lazy=\"true|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        check=\"arbitrary sql check condition\"\n"
-"        rowid=\"rowid\"\n"
-"        subselect=\"SQL expression\"\n"
-"        abstract=\"true|false\"\n"
-"        node=\"element-name\"\n"
-"/>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:238
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal> (optional): the fully qualified Java class name of "
 "the persistent class or interface. If this attribute is missing, it is "
 "assumed that the mapping is for a non-POJO entity."
 msgstr ""
-"<literal>name</literal> (opcional): El nombre completamente cualificado de "
-"la clase Java persistente (o interface). Si este atributo es omitido, se "
-"asume que el mapeo es para una entidad non-POJO."
+"<literal>name</literal> (opcional): El nombre completamente calificado de la "
+"clase Java persistente (o interfaz). Si se omite este atributo, se asume que "
+"el mapeo es para una entidad que no es POJO."
 
 #. Tag: para
-#: basic_mapping.xml:245
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>table</literal> (optional - defaults to the unqualified class "
 "name): the name of its database table."
 msgstr ""
-"<literal>table</literal> (opcional - por defecto al nombre no cualificado de "
-"la clase): El nombre de su tabla en base de datos."
+"<literal>table</literal> (opcional - por defecto es el nombre de la clase no "
+"calificado): El nombre de su tabla en la base de datos."
 
 #. Tag: para
-#: basic_mapping.xml:251
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>discriminator-value</literal> (optional - defaults to the class "
 "name): a value that distinguishes individual subclasses that is used for "
 "polymorphic behavior. Acceptable values include <literal>null</literal> and "
 "<literal>not null</literal>."
 msgstr ""
-"<literal>discriminator-value</literal> (opcional - por defecto al nombre de "
-"la clase): Un valor que distingue subclases individuales, usado para el "
-"comportamiento polim&#x00f3;rfico. Los valores aceptables incluyen "
-"<literal>null</literal> y <literal>not null</literal>."
+"<literal>discriminator-value</literal> (opcional - predeterminado al nombre "
+"de la clase): Un valor que distingue subclases individuales, usado para el "
+"comportamiento polimórfico. Los valores aceptables incluyen <literal>null</"
+"literal> y <literal>not null</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>true</literal>): "
 "specifies that instances of the class are (not) mutable."
 msgstr ""
-"<literal>mutable</literal> (opcional, por defecto a <literal>true</"
-"literal>): Especifica que las instancias de la clase (no) son mutables."
+"<literal>mutable</literal> (opcional, por defecto es <literal>true</"
+"literal>): Especifica que las instancias de la clase (no) son mutables. "
 
 #. Tag: para
-#: basic_mapping.xml:264 basic_mapping.xml:2231
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>schema</literal> (optional): overrides the schema name specified by "
 "the root <literal>&lt;hibernate-mapping&gt;</literal> element."
 msgstr ""
-"<literal>schema</literal> (opcional): Sobreescribe el nombre de esquema "
-"especificado por el elemento ra&#x00ed;z <literal>&lt;hibernate-mapping&gt;</"
-"literal>."
+"<literal>schema</literal> (opcional): Sobrescribe el nombre del esquema "
+"especificado por el elemento raíz <literal>&lt;hibernate-mapping&gt;</"
+"literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:270 basic_mapping.xml:2237
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>catalog</literal> (optional): overrides the catalog name specified "
 "by the root <literal>&lt;hibernate-mapping&gt;</literal> element."
 msgstr ""
-"<literal>catalog</literal> (opcional): Sobreescribe el nombre de cat&#x00e1;"
-"logo especificado por el elemento ra&#x00ed;z <literal>&lt;hibernate-"
-"mapping&gt;</literal>."
+"<literal>catalog</literal> (opcional): Sobrescribe el nombre del catálogo "
+"especificado por el elemento raíz <literal>&lt;hibernate-mapping&gt;</"
+"literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:276
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies an interface to use for lazy "
 "initializing proxies. You can specify the name of the class itself."
 msgstr ""
-"<literal>proxy</literal> (opcional): Especifica una interface a usar para "
-"proxies de inicializaci&#x00f3;n perezosa. Puedes especificar el nombre "
-"mismo de la clase."
+"<literal>proxy</literal> (opcional): Especifica una interfaz a utilizar para "
+"los proxies de inicialización perezosa. Puede especificar el nombre mismo de "
+"la clase. "
 
 #. Tag: para
-#: basic_mapping.xml:282
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>dynamic-update</literal> (optional - defaults to <literal>false</"
 "literal>): specifies that <literal>UPDATE</literal> SQL should be generated "
 "at runtime and can contain only those columns whose values have changed."
 msgstr ""
-"<literal>dynamic-update</literal> (opcional, por defecto a <literal>false</"
+"<literal>dynamic-update</literal> (opcional, por defecto es <literal>false</"
 "literal>): Especifica que el SQL <literal>UPDATE</literal> debe ser generado "
-"en tiempo de ejecuci&#x00f3;n y contener solamente aquellas columnas cuyo "
-"valor haya cambiado."
+"en tiempo de ejecución y puede contener sólamente aquellas columnas cuyos "
+"valores hayan cambiado. "
 
 #. Tag: para
-#: basic_mapping.xml:289
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>dynamic-insert</literal> (optional - defaults to <literal>false</"
 "literal>): specifies that <literal>INSERT</literal> SQL should be generated "
 "at runtime and contain only the columns whose values are not null."
 msgstr ""
-"<literal>dynamic-insert</literal> (opcional, por defecto a <literal>false</"
+"<literal>dynamic-insert</literal> (opcional, por defecto es <literal>false</"
 "literal>): Especifica que el SQL <literal>INSERT</literal> debe ser generado "
-"en tiempo de ejecuci&#x00f3;n y contener solamente aquellas columnas cuyo "
-"valores no son nulos."
+"en tiempo de ejecución y debe contener sólamente aquellas columnas cuyos "
+"valores no son nulos. "
 
 #. Tag: para
-#: basic_mapping.xml:296
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>select-before-update</literal> (optional - defaults to "
 "<literal>false</literal>): specifies that Hibernate should <emphasis>never</"
@@ -691,115 +416,106 @@
 "Hibernate perform an extra SQL <literal>SELECT</literal> to determine if an "
 "<literal>UPDATE</literal> is actually required."
 msgstr ""
-"<literal>select-before-update</literal> (opcional, por defecto a "
+"<literal>select-before-update</literal> (opcional, por defecto es "
 "<literal>false</literal>): Especifica que Hibernate <emphasis>nunca</"
-"emphasis> debe realizar un SQL <literal>UPDATE</literal> a menos que se "
-"tenga certeza que un objeto haya sido modificado realmente. En ciertos "
-"casos, (realmente, s&#x00f3;lo cuando un objeto transitorio ha sido asociado "
-"con una sesi&#x00f3;n nueva usando <literal>update()</literal>), esto "
-"significa que Hibernate realizar&#x00e1; una SQL <literal>SELECT</literal> "
-"extra para determinar si un <literal>UPDATE</literal> es realmente requerido."
+"emphasis> debe realizar un <literal>UPDATE</literal> SQL a menos de que se "
+"tenga certeza de que realmente se haya modificado un objeto. Sólo cuando un "
+"objeto transitorio ha sido asociado con una sesión nueva utilizando "
+"<literal>update()</literal>), Hibernate realizará una SQL <literal>SELECT</"
+"literal> extra para determinar si realmente se necesita un <literal>UPDATE</"
+"literal>."
 
 #. Tag: para
-#: basic_mapping.xml:306
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>polymorphism</literal> (optional - defaults to <literal>implicit</"
 "literal>): determines whether implicit or explicit query polymorphism is "
 "used."
 msgstr ""
-"<literal>polymorphism</literal> (opcional, por defecto a <literal>implicit</"
-"literal>): Determina si se usa polimorfismo de consulta impl&#x00ed;cito o "
-"expl&#x00ed;cito."
+"<literal>polymorphism</literal> (opcional, por defecto es <literal>implicit</"
+"literal>): Determina si se utiliza polimorfismo de consulta implícito o "
+"explícito. "
 
 #. Tag: para
-#: basic_mapping.xml:312
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>where</literal> (optional): specifies an arbitrary SQL "
 "<literal>WHERE</literal> condition to be used when retrieving objects of "
 "this class."
 msgstr ""
-"<literal>where</literal> (opcional) especifica una condici&#x00f3;n SQL "
-"<literal>WHERE</literal> arbitraria paraa ser usada al recuperar objetos de "
-"esta clase."
+"<literal>where</literal> (opcional) especifica una condición SQL "
+"<literal>WHERE</literal> arbitraria para utilizarla en la recuperación de "
+"objetos de esta clase. "
 
 #. Tag: para
-#: basic_mapping.xml:318
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>persister</literal> (optional): specifies a custom "
 "<literal>ClassPersister</literal>."
 msgstr ""
 "<literal>persister</literal> (opcional): Especifica un "
-"<literal>ClassPersister</literal> personalizado."
+"<literal>ClassPersister</literal> personalizado. "
 
 #. Tag: para
-#: basic_mapping.xml:323
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>batch-size</literal> (optional - defaults to <literal>1</literal>): "
 "specifies a \"batch size\" for fetching instances of this class by "
 "identifier."
 msgstr ""
-"<literal>batch-size</literal> (opcional, por defecto a <literal>1</literal>) "
-"especifica un \"tama&#x00f1;o de lote\" para traer instancias de esta clase "
-"por identificador."
+"<literal>batch-size</literal> (opcional, por defecto es <literal>1</"
+"literal>) especifica un \"tamaño de lote\" para buscar instancias de esta "
+"clase por identificador."
 
 #. Tag: para
-#: basic_mapping.xml:329
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>version</"
 "literal>): determines the optimistic locking strategy."
 msgstr ""
-"<literal>optimistic-lock</literal> (opcional, por defecto a "
-"<literal>version</literal>): Determina la estrategia optimista de bloqueo."
+"<literal>optimistic-lock</literal> (opcional, por defecto es "
+"<literal>version</literal>): Determina la estrategia optimista de bloqueo. "
 
 #. Tag: para
-#: basic_mapping.xml:335
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional): lazy fetching can be disabled by setting "
 "<literal>lazy=\"false\"</literal>."
 msgstr ""
-"<literal>lazy</literal> (opcional): La recuperaci&#x00f3;n perezosa puede "
-"ser deshabilitada por completo estableciendo <literal>lazy=\"false\"</"
-"literal>."
+"<literal>lazy</literal> (opcional): La recuperación perezosa se puede "
+"deshabilitar por completo al establecer <literal>lazy=\"false\"</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:341
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>entity-name</literal> (optional - defaults to the class name): "
 "Hibernate3 allows a class to be mapped multiple times, potentially to "
 "different tables. It also allows entity mappings that are represented by "
 "Maps or XML at the Java level. In these cases, you should provide an "
 "explicit arbitrary name for the entity. See <xref linkend=\"persistent-"
-"classes-dynamicmodels\"/> and <xref linkend=\"xml\"/> for more information."
+"classes-dynamicmodels\" /> and <xref linkend=\"xml\" /> for more information."
 msgstr ""
-"<literal>entity-name</literal> (opcional): Hibernate3 permite que una clase "
-"sea mapeada varias veces (potencialmente a tablas diferentes), y permite que "
-"los mapeos de entidad sean representados por Maps o XML al nivel de Java. En "
-"estos casos, debes proveer un nombre expl&#x00ed;cito arbitrario para la "
-"entidad. Para m&#x00e1;s informaci&#x00f3;n, mira <xref linkend=\"persistent-"
-"classes-dynamicmodels\"/> y <xref linkend=\"xml\"/>."
+"<literal>entity-name</literal> (opcional - por defecto es el nombre de la "
+"clase): Hibernate3 permite mapear una clase varias veces, potencialmente a "
+"tablas diferentes. También permite que los mapeos de entidad sean "
+"representados por Maps o XML al nivel de Java. En estos casos, debe "
+"proporcionar un nombre explícito arbitrario para la entidad. Para obtener "
+"más información consulte <xref linkend=\"persistent-classes-dynamicmodels\" /"
+"> y <xref linkend=\"xml\" />."
 
 #. Tag: para
-#: basic_mapping.xml:351
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>check</literal> (optional): an SQL expression used to generate a "
 "multi-row <emphasis>check</emphasis> constraint for automatic schema "
 "generation."
 msgstr ""
-"<literal>check</literal> (opcional): Una expresi&#x00f3;n SQL usada para "
-"generar una restricci&#x00f3;n <emphasis>check</emphasis> multi-fila para la "
-"generaci&#x00f3;n autom&#x00e1;tica de esquema."
+"<literal>check</literal> (opcional): Una expresión SQL utilizada para "
+"generar una restricción <emphasis>check</emphasis> multi-filas para la "
+"generación automática de esquemas."
 
 #. Tag: para
-#: basic_mapping.xml:357
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>rowid</literal> (optional): Hibernate can use ROWIDs on databases. "
 "On Oracle, for example, Hibernate can use the <literal>rowid</literal> extra "
@@ -807,39 +523,36 @@
 "literal>. A ROWID is an implementation detail and represents the physical "
 "location of a stored tuple."
 msgstr ""
-"<literal>rowid</literal> (opcional): Hibernate puede usar los llamados "
-"ROWIDs en las bases de datos que los soporten. Por ejemplo, en Oracle, "
-"Hibernate puede usar la columna extra <literal>rowid</literal> para "
-"actualizaciones r&#x00e1;pidas si estableces esta opci&#x00f3;n a "
-"<literal>rowid</literal>. Un ROWID es un detalle de implementaci&#x00f3;n y "
-"representa la posici&#x00f3;n f&#x00ed;sica de la tupla almacenada."
+"<literal>rowid</literal> (opcional): Hibernate puede utilizar los llamados "
+"ROWIDs en las bases de datos. Por ejemplo, en Oracle, Hibernate puede "
+"utilizar la columna extra <literal>rowid</literal> para actualizaciones "
+"rápidas si usted establece esta opción como <literal>rowid</literal>. Un "
+"ROWID es un detalle de implementación y representa la posición física de la "
+"tupla almacenada."
 
 #. Tag: para
-#: basic_mapping.xml:364
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>subselect</literal> (optional): maps an immutable and read-only "
 "entity to a database subselect. This is useful if you want to have a view "
 "instead of a base table. See below for more information."
 msgstr ""
 "<literal>subselect</literal> (opcional): Mapea una entidad inmutable y de "
-"s&#x00f3;lo lectura a una subselect de base de datos. Es &#x00fa;til si "
-"quieres tener una vista en vez de una tabla base, pero no tienes vistas. "
-"Mira debajo para m&#x00e1;s informaci&#x00f3;n."
+"sólo lectura a una subselección de base de datos. Es útil si quiere tener "
+"una vista en vez de una tabla base. Vea a continuación para obtener más "
+"información."
 
 #. Tag: para
-#: basic_mapping.xml:371
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>abstract</literal> (optional): is used to mark abstract "
 "superclasses in <literal>&lt;union-subclass&gt;</literal> hierarchies."
 msgstr ""
-"<literal>abstract</literal> (opcional): Usado para marcar superclases "
-"abstractas en jerarqu&#x00ed;as <literal>&lt;union-subclass&gt;</literal>."
+"<literal>abstract</literal> (opcional): Utilizado para marcar superclases "
+"abstractas en las jerarquías <literal>&lt;union-subclass&gt;</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:379
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is acceptable for the named persistent class to be an interface. You can "
 "declare implementing classes of that interface using the <literal>&lt;"
@@ -848,27 +561,25 @@
 "<literal>e.g.Foo$Bar</literal>."
 msgstr ""
 "Es perfectamente aceptable que la clase persistente mencionada sea una "
-"interface. Entonces declarar&#x00ed;as clases que implementan esa interface "
-"usando el elemento <literal>&lt;subclass&gt;</literal>. Puedes persistir "
-"cualquier clase interna <emphasis>est&#x00e1;tica</emphasis>. Debes "
-"especificar el nombre de la clase usando la forma est&#x00e1;ndar. Por "
-"ejemplo, <literal>eg.Foo$Bar</literal>."
+"interfaz. Puede declarar clases que implementan esa interfaz utilizando el "
+"elemento <literal>&lt;subclass&gt;</literal>. Puede persistir cualquier "
+"clase interna <emphasis>estática</emphasis>. Debe especificar el nombre de "
+"la clase utilizando la forma estándar, por ejemplo, <literal>e.g.Foo$Bar</"
+"literal>."
 
 #. Tag: para
-#: basic_mapping.xml:386
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Immutable classes, <literal>mutable=\"false\"</literal>, cannot be updated "
 "or deleted by the application. This allows Hibernate to make some minor "
 "performance optimizations."
 msgstr ""
 "Las clases inmutables, <literal>mutable=\"false\"</literal>, no pueden ser "
-"actualizadas o borradas por la aplicaci&#x00f3;n. Esto permite a Hibernate "
-"hacer ciertas optimizaciones menores de rendimiento."
+"actualizadas o borradas por la aplicación. Esto le permite a Hibernate "
+"realizar ciertas optimizaciones menores de rendimiento. "
 
 #. Tag: para
-#: basic_mapping.xml:391
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The optional <literal>proxy</literal> attribute enables lazy initialization "
 "of persistent instances of the class. Hibernate will initially return CGLIB "
@@ -876,16 +587,14 @@
 "when a method of the proxy is invoked. See \"Initializing collections and "
 "proxies\" below."
 msgstr ""
-"El atributo opcional <literal>proxy</literal> habilita la "
-"inicializaci&#x00f3;n postergada de instancias persistentes de la clase. "
-"Hibernate inicialmente retornar&#x00e1; proxies CGLIB que implementan la "
-"interface mencionada. El objeto persistente real ser&#x00e1; cargado cuando "
-"se invoque un m&#x00e9;todo del proxy. Mira \"Proxies para "
-"Inicializaci&#x00f3;n Postergada\" debajo."
+"El atributo opcional <literal>proxy</literal> activa la inicialización "
+"perezosa de instancias persistentes de la clase. Hibernate inicialmente "
+"retornará proxies CGLIB que implementan la interfaz mencionada. El objeto "
+"persistente real será cargado cuando se invoque un método del proxy. Vea "
+"\"Inicialización de colecciones y proxies\" a continuación."
 
 #. Tag: para
-#: basic_mapping.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Implicit</emphasis> polymorphism means that instances of the class "
 "will be returned by a query that names any superclass or implemented "
@@ -901,26 +610,24 @@
 "table This allows a \"lightweight\" class that contains a subset of the "
 "table columns."
 msgstr ""
-"Por polimorfismo <emphasis>impl&#x00ed;cito</emphasis> se entiende que las "
-"instancias de la clase ser&#x00e1;n devueltas por una consulta que mencione "
-"cualquier superclase, o interface implementada, o la clase misma; y que las "
-"instancias de cualquier subclase de la clase ser&#x00e1;n devueltas por una "
-"clase que mencione a la clase en s&#x00ed;. Por polimorfismo "
-"<emphasis>expl&#x00ed;cito</emphasis> se entiende que instancias de la clase "
-"ser&#x00e1;n devueltas s&#x00f3;lo por consultas que mencionen expl&#x00ed;"
-"citamente la clase; y que las consultas que mencionen la clase "
-"devolver&#x00e1;n s&#x00f3;lo instancias de subclases mapeadas dentro de "
-"esta declaraci&#x00f3;n <literal>&lt;class&gt;</literal> como una "
-"<literal>&lt;subclass&gt;</literal> o <literal>&lt;joined-subclass&gt;</"
-"literal>. Para la mayor&#x00ed;a de los prop&#x00f3;sitos el defecto, "
-"<literal>polymorphism=\"implicit\"</literal>, resulta apropiado. El "
-"polimorfismo expl&#x00ed;cito es &#x00fa;til cuando dos clases diferentes "
-"est&#x00e1;n mapeadas a la misma tabla (esto permite tener una clase "
-"\"liviana\" que contenga un subconjunto de columnas de la tabla)."
+"Por polimorfismo <emphasis>implícito</emphasis> se entiende que las "
+"instancias de la clase serán devueltas por una consulta que mencione "
+"cualquier superclase, o interfaz implementada, o la clase misma; y que las "
+"instancias de cualquier subclase de la clase serán retornadas por una "
+"petición que nombra a la clase misma. Por polimorfismo <emphasis>explícito</"
+"emphasis> se entiende que las instancias de la clase serán devueltas sólo "
+"por consultas que mencionen explícitamente la clase. Las consultas que "
+"mencionen la clase retornarán sólo instancias de subclases mapeadas dentro "
+"de esta declaración <literal>&lt;class&gt;</literal> como una <literal>&lt;"
+"subclass&gt;</literal> o <literal>&lt;joined-subclass&gt;</literal>. Para la "
+"mayoría de los propósitos el valor por defecto, <literal>polymorphism="
+"\"implicit\"</literal>, resulta apropiado. El polimorfismo explícito es útil "
+"cuando dos clases diferentes se encuentran mapeadas a la misma tabla. Esto "
+"permite tener una clase \"liviana\" que contenga un subconjunto de columnas "
+"de la tabla."
 
 #. Tag: para
-#: basic_mapping.xml:410
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>persister</literal> attribute lets you customize the "
 "persistence strategy used for the class. You can, for example, specify your "
@@ -931,19 +638,18 @@
 "files or LDAP. See <literal>org.hibernate.test.CustomPersister</literal> for "
 "a simple example of \"persistence\" to a <literal>Hashtable</literal>."
 msgstr ""
-"El atributo <literal>persister</literal> te permite personalizar la "
-"estrategia de persistencia para la clase. Puedes, por ejemplo, especificar "
-"tu propia subclase de <literal>org.hibernate.persister.EntityPersister</"
-"literal> o incluso puedes proveer una implementaci&#x00f3;n completamente "
-"nueva de la interface <literal>org.hibernate.persister.ClassPersister</"
-"literal> que implemente la persistencia por medio, por ejemplo, de llamadas "
-"a procedimientos almacenados, serializaci&#x00f3;n a ficheros planos o LDAP. "
-"Para un ejemplo simple (de persistencia a una <literal>Hashtable</literal>) "
-"mira <literal>org.hibernate.test.CustomPersister</literal>."
+"El atributo <literal>persister</literal> le permite personalizar la "
+"estrategia de persistencia para la clase. Por ejemplo, puede especificar su "
+"propia subclase de <literal>org.hibernate.persister.EntityPersister</"
+"literal>, o incluso puede proporcionar una implementación completamente "
+"nueva de la interfaz <literal>org.hibernate.persister.ClassPersister</"
+"literal> que implemente, por ejemplo, la persistencia por medio de llamadas "
+"a procedimientos almacenados, serialización a archivos planos o LDAP. Para "
+"ver un ejemplo simple (de \"persistencia\" a una <literal>Hashtable</"
+"literal>) consulte <literal>org.hibernate.test.CustomPersister</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:421
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>dynamic-update</literal> and <literal>dynamic-insert</literal> "
 "settings are not inherited by subclasses, so they can also be specified on "
@@ -951,86 +657,76 @@
 "literal> elements. Although these settings can increase performance in some "
 "cases, they can actually decrease performance in others."
 msgstr ""
-"Observa que los valores de <literal>dynamic-update</literal> y "
-"<literal>dynamic-insert</literal> no son heredados por las subclases y por "
-"lo tanto deben especificarse en los elementos <literal>&lt;subclass&gt;</"
-"literal> o <literal>&lt;joined-subclass&gt;</literal>. Estos ajustes pueden "
-"incrementar el rendimiento en algunos casos, pero podr&#x00ed;an mermarlo en "
-"otros. Ten juicio en su uso."
+"Los valores de <literal>dynamic-update</literal> y <literal>dynamic-insert</"
+"literal> no son heredados por las subclases y por lo tanto deben "
+"especificarse en los elementos <literal>&lt;subclass&gt;</literal> o "
+"<literal>&lt;joined-subclass&gt;</literal>. Aunque en algunos casos, estos "
+"ajustes pueden incrementar el rendimiento, de hecho en otros casos, podrían "
+"disminuirlo."
 
 #. Tag: para
-#: basic_mapping.xml:429
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use of <literal>select-before-update</literal> will usually decrease "
 "performance. It is useful to prevent a database update trigger being called "
 "unnecessarily if you reattach a graph of detached instances to a "
 "<literal>Session</literal>."
 msgstr ""
-"Generalmente el uso de <literal>select-before-update</literal> "
-"disminuir&#x00e1; el rendimiento. Es muy &#x00fa;til prevenir que se llame "
-"innecesariamente a un disparador de actualizaci&#x00f3;n de base de datos al "
-"volver a unir un grafo de instancias separadas a una <literal>Session</"
-"literal>."
+"El uso de <literal>select-before-update</literal> disminuirá el rendimiento. "
+"Es muy útil prevenir que se llame innecesariamente a un disparador de "
+"actualización de la base de datos al volver a unir un gráfico de instancias "
+"separadas a una <literal>Session</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:435
 #, no-c-format
 msgid ""
 "If you enable <literal>dynamic-update</literal>, you will have a choice of "
 "optimistic locking strategies:"
 msgstr ""
-"Si habilitas <literal>dynamic-update</literal>, tendr&#x00e1;s opci&#x00f3;n "
-"de estrategias de bloqueo optimistas:"
+"Si activa <literal>dynamic-update</literal>, usted tendrá la opción de "
+"estrategias de bloqueo optimistas:"
 
 #. Tag: para
-#: basic_mapping.xml:441
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>version</literal>: check the version/timestamp columns"
 msgstr ""
-"<literal>version</literal> chequea las columnas de versi&#x00f3;n/timestamp"
+"<literal>version</literal>: chequea las columnas de versión/sello de fecha"
 
 #. Tag: para
-#: basic_mapping.xml:446
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>all</literal>: check all columns"
-msgstr "<literal>all</literal> chequea todas las columnas"
+msgstr "<literal>all</literal>: chequea todas las columnas"
 
 #. Tag: para
-#: basic_mapping.xml:451
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>dirty</literal>: check the changed columns, allowing some "
 "concurrent updates"
 msgstr ""
-"<literal>dirty</literal> chequea las columnas modificadas, permitiendo "
+"<literal>dirty</literal>: chequea las columnas modificadas permitiendo "
 "algunas actualizaciones concurrentes"
 
 #. Tag: para
-#: basic_mapping.xml:456
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>none</literal>: do not use optimistic locking"
-msgstr "<literal>none</literal> no usa bloqueo optimista"
+msgstr "<literal>none</literal>: no utilice bloqueo optimista"
 
 #. Tag: para
-#: basic_mapping.xml:461
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is <emphasis>strongly</emphasis> recommended that you use version/"
 "timestamp columns for optimistic locking with Hibernate. This strategy "
 "optimizes performance and correctly handles modifications made to detached "
 "instances (i.e. when <literal>Session.merge()</literal> is used)."
 msgstr ""
-"Recomendamos <emphasis>muy</emphasis> fuertemente que uses columnas de "
-"versi&#x00f3;n/timestamp para bloqueo optimista con Hibernate. Esta es la "
-"estrategia &#x00f3;ptima con respecto al rendimiento y es la &#x00fa;nica "
-"estrategia que maneja correctamente las modificaciones hechas a las "
-"instancias separadas. (por ejemplo, cuando se usa <literal>Session.merge()</"
-"literal>)."
+"Le recomendamos <emphasis>mucho</emphasis> que utilice columnas de versión/"
+"sello de fecha para el bloqueo optimista con Hibernate. Esta estrategia "
+"optimiza el rendimiento y maneja correctamente las modificaciones realizadas "
+"a las instancias separadas, (por ejemplo, cuando se utiliza <literal>Session."
+"merge()</literal>)."
 
 #. Tag: para
-#: basic_mapping.xml:468
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is no difference between a view and a base table for a Hibernate "
 "mapping. This is transparent at the database level, although some DBMS do "
@@ -1040,66 +736,33 @@
 "given SQL subselect expression:"
 msgstr ""
 "Para un mapeo de Hibernate, no hay diferencia entre una vista y una tabla "
-"base. Como se supone esto es transparente a nivel de base de datos (observa "
-"que algunos DBMS no soportan correctamente las vistas, especialmente con las "
-"actualizaciones). A veces quieres usar una vista, pero no puedes crear una "
-"en la base de datos (por ejemplo, con un esquema heredado). En este caso, "
-"puedes mapear una entidad inmutable de s&#x00f3;lo lectura a una "
-"expresi&#x00f3;n de subconsulta SQL dada."
+"base. Esto es transparente a nivel de base de datos, aunque algunos DBMS no "
+"soportan correctamente las vistas, especialmente con las actualizaciones. A "
+"veces usted quiere utilizar una vista, pero no puede crear una en la base de "
+"datos (por ejemplo, con un esquema heredado). En este caso, usted puede "
+"mapear una entidad inmutable de sólo lectura a una expresión de subconsulta "
+"SQL dada."
 
-#. Tag: programlisting
-#: basic_mapping.xml:476
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Summary\">\n"
-"    <subselect>\n"
-"        select item.name, max(bid.amount), count(*)\n"
-"        from item\n"
-"        join bid on bid.item_id = item.id\n"
-"        group by item.name\n"
-"    </subselect>\n"
-"    <synchronize table=\"item\"/>\n"
-"    <synchronize table=\"bid\"/>\n"
-"    <id name=\"name\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Summary\">\n"
-"    <subselect>\n"
-"        select item.name, max(bid.amount), count(*)\n"
-"        from item\n"
-"        join bid on bid.item_id = item.id\n"
-"        group by item.name\n"
-"    </subselect>\n"
-"    <synchronize table=\"item\"/>\n"
-"    <synchronize table=\"bid\"/>\n"
-"    <id name=\"name\"/>\n"
-"    ...\n"
-"</class>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:478
-#, fuzzy, no-c-format
-msgid ""
 "Declare the tables to synchronize this entity with, ensuring that auto-flush "
 "happens correctly and that queries against the derived entity do not return "
 "stale data. The <literal>&lt;subselect&gt;</literal> is available both as an "
 "attribute and a nested mapping element."
 msgstr ""
-"Declara las tablas con las que sincronizar esta entidad, asegurando que el "
-"auto-flush ocurre correctamente, y que las consultas contra la entidad "
-"derivada no devuelven datos desactualizados. El <literal>&lt;subselect&gt;</"
-"literal> est&#x00e1; disponible tanto como un atributo o como un elemento "
-"anidado de mapeo."
+"Declara las tablas con las cuales se debe sincronizar esta entidad, "
+"asegurándose de que el auto-vaciado ocurra correctamente y que las consultas "
+"frente a la entidad derivada no devuelvan datos desactualizados. El "
+"<literal>&lt;subselect&gt;</literal> se encuentra disponible tanto como un "
+"atributo y como un elemento anidado de mapeo."
 
 #. Tag: title
-#: basic_mapping.xml:488
 #, no-c-format
-msgid "<title>id</title>"
-msgstr "<title>id</title>"
+msgid "id"
+msgstr "id"
 
 #. Tag: para
-#: basic_mapping.xml:490
 #, no-c-format
 msgid ""
 "Mapped classes <emphasis>must</emphasis> declare the primary key column of "
@@ -1108,94 +771,62 @@
 "literal> element defines the mapping from that property to the primary key "
 "column."
 msgstr ""
-"Las clases mapeadas <emphasis>deben</emphasis> declarar la columna de clave "
-"primaria de la tabla de la base de datos. En la mayor&#x00ed;a de los casos "
-"tendr&#x00e1; tambi&#x00e9;n una propiedad estilo Javabeans que tenga el "
-"identificador &#x00fa;nico de una instancia. El elemento <literal>&lt;id&gt;"
-"</literal> define el mapeo de esa propiedad a la columna de clave primaria."
+"Las clases mapeadas <emphasis>tienen</emphasis> que declarar la columna de "
+"clave primaria de la tabla de la base de datos. La mayoría de las clases "
+"también tendrán una propiedad de estilo Javabeans que tenga el identificador "
+"único de una instancia. El elemento <literal>&lt;id&gt;</literal> define el "
+"mapeo de esa propiedad a la columna de clave primaria."
 
-#. Tag: programlisting
-#: basic_mapping.xml:505
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id\n"
-"        name=\"propertyName\"\n"
-"        type=\"typename\"\n"
-"        column=\"column_name\"\n"
-"        unsaved-value=\"null|any|none|undefined|id_value\"\n"
-"        access=\"field|property|ClassName\">\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"\n"
-"        <generator class=\"generatorClass\"/>\n"
-"</id>]]>"
-msgstr ""
-"<![CDATA[<id\n"
-"        name=\"propertyName\"\n"
-"        type=\"typename\"\n"
-"        column=\"column_name\"\n"
-"        unsaved-value=\"null|any|none|undefined|id_value\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\">\n"
-"\n"
-"        <generator class=\"generatorClass\"/>\n"
-"</id>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:508
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal> (optional): the name of the identifier property."
 msgstr ""
 "<literal>name</literal> (opcional): El nombre de la propiedad del "
-"indentificador."
+"identificador. s"
 
 #. Tag: para
-#: basic_mapping.xml:513 basic_mapping.xml:1351
 #, no-c-format
 msgid ""
 "<literal>type</literal> (optional): a name that indicates the Hibernate type."
 msgstr ""
-"<literal>type</literal> (opcional): un nombre que indica el nobre Hibernate."
+"<literal>type</literal> (opcional): un nombre que indica el tipo de "
+"Hibernate."
 
 #. Tag: para
-#: basic_mapping.xml:518
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of the primary key column."
 msgstr ""
-"<literal>column</literal> (opcional - por defecto al nombre de la "
-"propiedad): El nombre de la columna de clave primaria."
+"<literal>column</literal> (opcional - por defecto es el nombre de la "
+"propiedad): El nombre de la columna de la clave principal."
 
 #. Tag: para
-#: basic_mapping.xml:524
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to a \"sensible\" "
 "value): an identifier property value that indicates an instance is newly "
 "instantiated (unsaved), distinguishing it from detached instances that were "
 "saved or loaded in a previous session."
 msgstr ""
-"<literal>unsaved-value</literal> (opcional - por defecto al valor \"sensible"
-"\"): Una valor de la propiedad identificadora que indica que una instancia "
-"est&#x00e1; reci&#x00e9;n instanciada (sin salvar), distingui&#x00e9;ndola "
-"de instancias separadas que fueran salvadas o cargadas en una sesi&#x00f3;n "
-"previa."
+"<literal>unsaved-value</literal> (opcional - por defecto es un valor "
+"\"sensible\"): Un valor de la propiedad identificadora que indica que una "
+"instancia está recién instanciada (sin guardar), distinguiéndola de las "
+"instancias separadas que fueron guardadas o cargadas en una sesión previa."
 
 #. Tag: para
-#: basic_mapping.xml:532
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate should use for accessing the property "
 "value."
 msgstr ""
-"<literal>access</literal> (opcional - por defecto a <literal>property</"
-"literal>): La estrategia que Hibernate debe usar para acceder al valor de la "
-"propiedad."
+"<literal>access</literal> (opcional - por defecto es <literal>property</"
+"literal>): La estrategia que Hibernate debe utilizar para acceder al valor "
+"de la propiedad. "
 
 #. Tag: para
-#: basic_mapping.xml:540
 #, no-c-format
 msgid ""
 "If the <literal>name</literal> attribute is missing, it is assumed that the "
@@ -1205,36 +836,31 @@
 "tiene propiedad identificadora."
 
 #. Tag: para
-#: basic_mapping.xml:545
 #, no-c-format
 msgid ""
 "The <literal>unsaved-value</literal> attribute is almost never needed in "
 "Hibernate3."
 msgstr ""
-"El atributo <literal>unsaved-value</literal> es importante! Si la propiedad "
-"identificadora de tu clase no tiene por defecto el valor por defecto normal "
-"de Java (null o cero), entonces debes especificar el valor por defecto real."
+"El atributo <literal>unsaved-value</literal> casi nunca se necesita en "
+"Hibernate3."
 
 #. Tag: para
-#: basic_mapping.xml:549
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is an alternative <literal>&lt;composite-id&gt;</literal> declaration "
 "that allows access to legacy data with composite keys. Its use is strongly "
 "discouraged for anything else."
 msgstr ""
-"Hay una declaraci&#x00f3;n <literal>&lt;composite-id&gt;</literal> "
-"alternativa para permitir acceso a datos heredados con claves compuestas. "
-"Desalentamos fuertemente su uso para cualquier otra cosa."
+"Hay una declaración <literal>&lt;composite-id&gt;</literal> opcional para "
+"permitir acceso a los datos heredados con claves compuestas. Le disuadimos "
+"seriamente de su utilización para cualquier otra cosa."
 
 #. Tag: title
-#: basic_mapping.xml:555
 #, no-c-format
 msgid "Generator"
-msgstr "Generator"
+msgstr "Generador"
 
 #. Tag: para
-#: basic_mapping.xml:557
 #, no-c-format
 msgid ""
 "The optional <literal>&lt;generator&gt;</literal> child element names a Java "
@@ -1244,53 +870,33 @@
 "literal> element."
 msgstr ""
 "El elemento hijo opcional <literal>&lt;generator&gt;</literal> nombra una "
-"clase Java usada en generar identificadores &#x00fa;nicos para instancias de "
-"la clase persistente. De requerirse alg&#x00fa;n par&#x00e1;metro para "
-"configurar o inicializar la instancia del generador, se pasa usando el "
-"elemento <literal>&lt;param&gt;</literal>."
+"clase Java utilizada para generar identificadores únicos para instancias de "
+"la clase persistente. De requerirse algún parámetro para configurar o "
+"inicializar la instancia del generador, se pasa utilizando el elemento "
+"<literal>&lt;param&gt;</literal>."
 
-#. Tag: programlisting
-#: basic_mapping.xml:564
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"org.hibernate.id.TableHiLoGenerator\">\n"
-"                <param name=\"table\">uid_table</param>\n"
-"                <param name=\"column\">next_hi_value_column</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"org.hibernate.id.TableHiLoGenerator\">\n"
-"                <param name=\"table\">uid_table</param>\n"
-"                <param name=\"column\">next_hi_value_column</param>\n"
-"        </generator>\n"
-"</id>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:566
-#, fuzzy, no-c-format
-msgid ""
 "All generators implement the interface <literal>org.hibernate.id."
 "IdentifierGenerator</literal>. This is a very simple interface. Some "
 "applications can choose to provide their own specialized implementations, "
 "however, Hibernate provides a range of built-in implementations. The "
 "shortcut names for the built-in generators are as follows:"
 msgstr ""
-"Todos los generadores implementan la interface <literal>org.hibernate.id."
-"IdentifierGenerator</literal>. Esta es una interface muy simple; algunas "
-"aplicaciones pueden escoger proveer sus propias implementaciones "
+"Todos los generadores implementan la interfaz <literal>org.hibernate.id."
+"IdentifierGenerator</literal>. Esta es una interfaz muy simple. Algunas "
+"aplicaciones pueden decidir brindar sus propias implementaciones "
 "especializadas. Sin embargo, Hibernate provee un rango de implementaciones "
-"prefabricadas. Hay nombres alias de atajo para los generadores prefabricados:"
+"ya incorporadas. Los nombres de atajo para los generadores incorporados son "
+"los siguientes:"
 
-#. Tag: literal
-#: basic_mapping.xml:574
+#. Tag: term
 #, no-c-format
-msgid "increment"
-msgstr "increment"
+msgid "<literal>increment</literal>"
+msgstr "<literal>increment</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:576
 #, no-c-format
 msgid ""
 "generates identifiers of type <literal>long</literal>, <literal>short</"
@@ -1299,18 +905,16 @@
 "cluster.</emphasis>"
 msgstr ""
 "genera indentificadores de tipo <literal>long</literal>, <literal>short</"
-"literal> o <literal>int</literal> que s&#x00f3;lo son &#x00fa;nicos cuando "
-"ning&#x00fa;n otro proceso est&#x00e1; insertando datos en la misma tabla. "
-"<emphasis>No usar en un cluster.</emphasis>"
+"literal> o <literal>int</literal> que sólamente son únicos cuando ningún "
+"otro proceso está insertando datos en la misma tabla. <emphasis>No lo "
+"utilice en un clúster.</emphasis>"
 
-#. Tag: literal
-#: basic_mapping.xml:585
+#. Tag: term
 #, no-c-format
-msgid "identity"
-msgstr "identity"
+msgid "<literal>identity</literal>"
+msgstr "<literal>identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:587
 #, no-c-format
 msgid ""
 "supports identity columns in DB2, MySQL, MS SQL Server, Sybase and "
@@ -1321,14 +925,12 @@
 "HypersonicSQL. El identificador devuelto es de tipo <literal>long</literal>, "
 "<literal>short</literal> o <literal>int</literal>."
 
-#. Tag: literal
-#: basic_mapping.xml:595
+#. Tag: term
 #, no-c-format
-msgid "sequence"
-msgstr "sequence"
+msgid "<literal>sequence</literal>"
+msgstr "<literal>sequence</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:597
 #, no-c-format
 msgid ""
 "uses a sequence in DB2, PostgreSQL, Oracle, SAP DB, McKoi or a generator in "
@@ -1339,14 +941,12 @@
 "en Interbase. El identificador devuelto es de tipo <literal>long</literal>, "
 "<literal>short</literal> o <literal>int</literal>."
 
-#. Tag: literal
-#: basic_mapping.xml:605
+#. Tag: term
 #, no-c-format
-msgid "hilo"
-msgstr "hilo"
+msgid "<literal>hilo</literal>"
+msgstr "<literal>hilo</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:607
 #, no-c-format
 msgid ""
 "uses a hi/lo algorithm to efficiently generate identifiers of type "
@@ -1356,71 +956,63 @@
 "hi/lo algorithm generates identifiers that are unique only for a particular "
 "database."
 msgstr ""
-"usa un algoritmo alto/bajo para generar eficientemente identificadores de "
-"tipo <literal>long</literal>, <literal>short</literal> o <literal>int</"
+"utiliza un algoritmo alto/bajo para generar eficientemente identificadores "
+"de tipo <literal>long</literal>, <literal>short</literal> o <literal>int</"
 "literal>, dada una tabla y columna como fuente de valores altos (por defecto "
 "<literal>hibernate_unique_key</literal> y <literal>next_hi</literal> "
 "respectivamente). El algoritmo alto/bajo genera identificadores que son "
-"&#x00fa;nicos s&#x00f3;lo para una base de datos particular."
+"únicos sólamente para una base de datos particular."
 
-#. Tag: literal
-#: basic_mapping.xml:617
+#. Tag: term
 #, no-c-format
-msgid "seqhilo"
-msgstr "seqhilo"
+msgid "<literal>seqhilo</literal>"
+msgstr "<literal>seqhilo</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:619
 #, no-c-format
 msgid ""
 "uses a hi/lo algorithm to efficiently generate identifiers of type "
 "<literal>long</literal>, <literal>short</literal> or <literal>int</literal>, "
 "given a named database sequence."
 msgstr ""
-"usa un algoritmo alto/bajo para generar eficientemente identificadores de "
-"tipo <literal>long</literal>, <literal>short</literal> o <literal>int</"
+"utiliza un algoritmo alto/bajo para generar eficientemente identificadores "
+"de tipo <literal>long</literal>, <literal>short</literal> o <literal>int</"
 "literal>, dada una secuencia de base de datos."
 
-#. Tag: literal
-#: basic_mapping.xml:627
+#. Tag: term
 #, no-c-format
-msgid "uuid"
-msgstr "uuid"
+msgid "<literal>uuid</literal>"
+msgstr "<literal>uuid</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:629
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "uses a 128-bit UUID algorithm to generate identifiers of type string that "
 "are unique within a network (the IP address is used). The UUID is encoded as "
 "a string of 32 hexadecimal digits in length."
 msgstr ""
-"usa un algoritmo UUID de 128 bits para generar identificadore de tipo "
-"cadena, &#x00fa;nicos en una ref (se usa la direcc&#x00f3;n IP). El UUID se "
-"codifica como una cadena hexadecimal de 32 d&#x00ed;gitos de largo."
+"utiliza un algoritmo UUID de 128 bits para generar identificadores de tipo "
+"cadena, únicos dentro de una red (se utiliza la direccón IP). El UUID se "
+"codifica como una cadena hexadecimal de 32 dígitos de largo."
 
-#. Tag: literal
-#: basic_mapping.xml:637
+#. Tag: term
 #, no-c-format
-msgid "guid"
-msgstr "guid"
+msgid "<literal>guid</literal>"
+msgstr "<literal>guid</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:639
 #, no-c-format
 msgid "uses a database-generated GUID string on MS SQL Server and MySQL."
 msgstr ""
-"usa una cadena GUID generada por base de datos en MS SQL Server y MySQL."
+"utiliza una cadena GUID generada por base de datos en MS SQL Server y MySQL."
 
-#. Tag: literal
-#: basic_mapping.xml:645
+#. Tag: term
 #, no-c-format
-msgid "native"
-msgstr "native"
+msgid "<literal>native</literal>"
+msgstr "<literal>native</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:647
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "selects <literal>identity</literal>, <literal>sequence</literal> or "
 "<literal>hilo</literal> depending upon the capabilities of the underlying "
@@ -1428,70 +1020,62 @@
 msgstr ""
 "selecciona <literal>identity</literal>, <literal>sequence</literal> o "
 "<literal>hilo</literal> dependiendo de las capacidades de la base de datos "
-"subyacente."
+"subyacente. "
 
-#. Tag: literal
-#: basic_mapping.xml:655
+#. Tag: term
 #, no-c-format
-msgid "assigned"
-msgstr "assigned"
+msgid "<literal>assigned</literal>"
+msgstr "<literal>assigned</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:657
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "lets the application assign an identifier to the object before <literal>save"
 "()</literal> is called. This is the default strategy if no <literal>&lt;"
 "generator&gt;</literal> element is specified."
 msgstr ""
-"deja a la aplicaci&#x00f3;n asignar un identificador al objeto antes de que "
-"se llame a <literal>save()</literal>. Esta es la estrategia por defecto si "
-"no se especifica un elemento <literal>&lt;generator&gt;</literal>."
+"deja a la aplicación asignar un identificador al objeto antes de que se "
+"llame a <literal>save()</literal>. Esta es la estrategia por defecto si no "
+"se especifica un elemento <literal>&lt;generator&gt;</literal>. "
 
-#. Tag: literal
-#: basic_mapping.xml:665
+#. Tag: term
 #, no-c-format
-msgid "select"
-msgstr "select"
+msgid "<literal>select</literal>"
+msgstr "<literal>select</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:667
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "retrieves a primary key, assigned by a database trigger, by selecting the "
 "row by some unique key and retrieving the primary key value."
 msgstr ""
-"recupera una clave primaria asignada por un disparador de base de datos "
-"seleccionando la fila por alguna clave &#x00fa;nica y recuperando el valor "
-"de la clave primaria."
+"recupera una clave principal asignada por un disparador de base de datos "
+"seleccionando la fila por alguna clave única y recuperando el valor de la "
+"clave principal."
 
-#. Tag: literal
-#: basic_mapping.xml:674
+#. Tag: term
 #, no-c-format
-msgid "foreign"
-msgstr "foreign"
+msgid "<literal>foreign</literal>"
+msgstr "<literal>foreign</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:676
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "uses the identifier of another associated object. It is usually used in "
 "conjunction with a <literal>&lt;one-to-one&gt;</literal> primary key "
 "association."
 msgstr ""
-"usa el identificador de otro objeto asociado. Generalmente usado en "
-"conjunc&#x00f3;n a una asociac&#x00f3;n de clave primaria <literal>&lt;uno-a-"
-"uno&gt;</literal>"
+"utiliza el identificador de otro objeto asociado. Generalmente se usa en "
+"conjunto cón a una asociación de clave principal <literal>&lt;one-to-one&gt;"
+"</literal>."
 
-#. Tag: literal
-#: basic_mapping.xml:683
+#. Tag: term
 #, no-c-format
-msgid "sequence-identity"
-msgstr "UNTRANSLATED! sequence-identity"
+msgid "<literal>sequence-identity</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:685
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "a specialized sequence generation strategy that utilizes a database sequence "
 "for the actual value generation, but combines this with JDBC3 "
@@ -1500,22 +1084,22 @@
 "drivers targeted for JDK 1.4. Comments on these insert statements are "
 "disabled due to a bug in the Oracle drivers."
 msgstr ""
-"a specialized sequence generation strategy which utilizes a database "
-"sequence for the actual value generation, but combines this with JDBC3 "
-"getGeneratedKeys to actually return the generated identifier value as part "
-"of the insert statement execution. This strategy is only known to be "
-"supported on Oracle 10g drivers targetted for JDK 1.4. Note comments on "
-"these insert statements are disabled due to a bug in the Oracle drivers."
+"una estrategia de generación de secuencias especilizadas que utiliza una "
+"secuencia de base de datos para el valor real de la generación, pero combina "
+"esto junto con JDBC3 getGeneratedKeys para devolver el valor del "
+"identificador generado como parte de la ejecución de la declaración de "
+"inserción. Esta estrategia está soportada sólamente en los controladores 10g "
+"de Oracle destinados para JDK1.4. Los comentarios en estas declaraciones de "
+"inserción están desactivados debido a un error en los controladores de "
+"Oracle."
 
 #. Tag: title
-#: basic_mapping.xml:702
 #, no-c-format
 msgid "Hi/lo algorithm"
 msgstr "Algoritmo alto/bajo"
 
 #. Tag: para
-#: basic_mapping.xml:703
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>hilo</literal> and <literal>seqhilo</literal> generators "
 "provide two alternate implementations of the hi/lo algorithm. The first "
@@ -1523,97 +1107,53 @@
 "available \"hi\" value. Where supported, the second uses an Oracle-style "
 "sequence."
 msgstr ""
-"Los generadores <literal>hilo</literal> y <literal>seqhilo</literal> proveen "
-"dos implementaciones alternativas del algoritmo alto/bajo, un enfoque "
-"favorito en generaci&#x00f3;n de identificadores. La primera "
-"implementaci&#x00f3;n requiere de una tabla \"especial\" de base de datos "
-"para tener el siguiente valor \"alto\" disponible. La segunda usa una "
-"secuencia del estilo de Oracle (donde se soporte)."
+"Los generadores <literal>hilo</literal> y <literal>seqhilo</literal> brindan "
+"dos implementaciones opcionales del algoritmo alto/bajo. La primera "
+"implementación necesita de una tabla \"especial\" de base de datos para "
+"tener el siguiente valor \"alto\" disponible. La segunda utiliza una "
+"secuencia del estilo de Oracle, donde se encuentre soportada."
 
-#. Tag: programlisting
-#: basic_mapping.xml:710
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"hilo\">\n"
-"                <param name=\"table\">hi_value</param>\n"
-"                <param name=\"column\">next_value</param>\n"
-"                <param name=\"max_lo\">100</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"hilo\">\n"
-"                <param name=\"table\">hi_value</param>\n"
-"                <param name=\"column\">next_value</param>\n"
-"                <param name=\"max_lo\">100</param>\n"
-"        </generator>\n"
-"</id>]]>"
-
-#. Tag: programlisting
-#: basic_mapping.xml:712
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"seqhilo\">\n"
-"                <param name=\"sequence\">hi_value</param>\n"
-"                <param name=\"max_lo\">100</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"seqhilo\">\n"
-"                <param name=\"sequence\">hi_value</param>\n"
-"                <param name=\"max_lo\">100</param>\n"
-"        </generator>\n"
-"</id>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:714
-#, fuzzy, no-c-format
-msgid ""
 "Unfortunately, you cannot use <literal>hilo</literal> when supplying your "
 "own <literal>Connection</literal> to Hibernate. When Hibernate uses an "
 "application server datasource to obtain connections enlisted with JTA, you "
 "must configure the <literal>hibernate.transaction.manager_lookup_class</"
 "literal>."
 msgstr ""
-"Desafortunadamente, no puedes usar <literal>hilo</literal> cuando le proveas "
-"tu propia <literal>Connection</literal> a Hibernate. Cuando Hibernate "
-"est&#x00e1; usando un datasource del servidor de aplicaciones para obtener "
-"conexiones alistadas con JTA, debes configurar correctamente el "
+"Desafortunadamente, no puede utilizar <literal>hilo</literal> cuando le "
+"provea su propia <literal>Connection</literal> a Hibernate. Cuando Hibernate "
+"está utilizando una fuente de datos del servidor de aplicaciones para "
+"obtener conexiones alistadas con JTA, usted tiene que configurar el "
 "<literal>hibernate.transaction.manager_lookup_class</literal>."
 
 #. Tag: title
-#: basic_mapping.xml:723
 #, no-c-format
 msgid "UUID algorithm"
 msgstr "Algoritmo UUID"
 
 #. Tag: para
-#: basic_mapping.xml:724
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The UUID contains: IP address, startup time of the JVM that is accurate to a "
 "quarter second, system time and a counter value that is unique within the "
 "JVM. It is not possible to obtain a MAC address or memory address from Java "
 "code, so this is the best option without using JNI."
 msgstr ""
-"El UUID contiene: la direcci&#x00f3;n IP, el instante de arranque de la JVM "
-"(con una precisi&#x00f3;n de un cuarto de segundo), el tiempo de sistema y "
-"un valor de contador (&#x00fa;nico en la JVM). No es posible obtener una "
-"direcci&#x00f3;n MAC o una direcci&#x00f3;n de memoria desde c&#x00f3;digo "
-"Java, as&#x00ed; que esto es lo mejor que podemos hacer sin usar JNI."
+"El UUID contiene: la dirección IP, el tiempo de iniciación de la MVJ, con "
+"una precisión de un cuarto de segundo, el tiempo de sistema y un valor de "
+"contador (único en la MVJ). No es posible obtener una dirección MAC o una "
+"dirección de memoria desde el código Java, así que esto es la mejor opción "
+"sin tener que utilizar JNI."
 
 #. Tag: title
-#: basic_mapping.xml:733
 #, no-c-format
 msgid "Identity columns and sequences"
 msgstr "Columnas de identidad y secuencias"
 
 #. Tag: para
-#: basic_mapping.xml:734
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For databases that support identity columns (DB2, MySQL, Sybase, MS SQL), "
 "you can use <literal>identity</literal> key generation. For databases that "
@@ -1622,65 +1162,32 @@
 "strategies require two SQL queries to insert a new object. For example:"
 msgstr ""
 "Para las bases de datos que soportan columnas de identidad (DB2, MySQL, "
-"Sybase, MS SQL), puedes usar generaci&#x00f3;n de claves <literal>identity</"
-"literal>. Para las bases de datos que soportan secuencias (DB2, Oracle, "
-"PostgreSQL, Interbase, McKoi, SAP DB) puedes usar la generaci&#x00f3;n de "
-"claves del estilo <literal>sequence</literal>. Ambas estrategias requieren "
-"dos consultas SQL para insertar un nuevo objeto."
+"Sybase, MS SQL), puede utilizar generación de claves <literal>identity</"
+"literal>. Para las bases de datos que soportan las secuencias (DB2, Oracle, "
+"PostgreSQL, Interbase, McKoi, SAP DB) puede utilizar la generación de claves "
+"del estilo <literal>sequence</literal>. Ambas estrategias requieren dos "
+"consultas SQL para insertar un nuevo objeto. Por ejemplo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:742
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-"        <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">person_id_sequence</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-"        <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">person_id_sequence</param>\n"
-"        </generator>\n"
-"</id>]]>"
-
-#. Tag: programlisting
-#: basic_mapping.xml:744
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\" unsaved-value=\"0"
-"\">\n"
-"        <generator class=\"identity\"/>\n"
-"</id>]]>"
-msgstr ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\" unsaved-value=\"0"
-"\">\n"
-"        <generator class=\"identity\"/>\n"
-"</id>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:746
-#, fuzzy, no-c-format
-msgid ""
 "For cross-platform development, the <literal>native</literal> strategy will, "
 "depending on the capabilities of the underlying database, choose from the "
 "<literal>identity</literal>, <literal>sequence</literal> and <literal>hilo</"
 "literal> strategies."
 msgstr ""
-"Para desarrollos multiplataforma, la estrategia <literal>native</literal> "
-"eiligir&#x00e1; de entre las estrategias <literal>identity</literal>, "
-"<literal>sequence</literal> y <literal>hilo</literal>, dependiendo de las "
-"capacidades de la base de datos subyacentes."
+"Para desarrollos a través de plataformas, la estrategia <literal>native</"
+"literal> eligirá entre las estrategias <literal>identity</literal>, "
+"<literal>sequence</literal> e <literal>hilo</literal>, dependiendo de las "
+"capacidades de la base de datos subyacente."
 
 #. Tag: title
-#: basic_mapping.xml:754
 #, no-c-format
 msgid "Assigned identifiers"
 msgstr "Identificadores asignados"
 
 #. Tag: para
-#: basic_mapping.xml:755
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want the application to assign identifiers, as opposed to having "
 "Hibernate generate them, you can use the <literal>assigned</literal> "
@@ -1690,17 +1197,16 @@
 "behavior if you do not specify a <literal>&lt;generator&gt;</literal> "
 "element."
 msgstr ""
-"Si quieres que la aplicaci&#x00f3;n asigne los identificadores (en "
-"contraposici&#x00f3;n a que los genere Hibernate), puedes usar el generador "
-"<literal>assigned</literal>. Este generador especial usar&#x00e1; el valor "
-"identificador ya asignado a la propiedad identificadora del objeto. Este "
-"generador se usa cuandola clave primaria es una clave natural en vez de una "
-"clave sustituta. Este es el comportamiento por defecto si no especificas un "
+"Si quiere que la aplicación asigne los identificadores, en contraposición a "
+"que los genere Hibernate, puede utilizar el generador <literal>assigned</"
+"literal>. Este generador especial utilizará el valor identificador ya "
+"asignado a la propiedad identificadora del objeto. Este generador se utiliza "
+"cuando la clave principal es una clave natural en vez de una clave "
+"sustituta. Este es el comportamiento por defecto si no especifica un "
 "elemento <literal>&lt;generator&gt;</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:764
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>assigned</literal> generator makes Hibernate use "
 "<literal>unsaved-value=\"undefined\"</literal>. This forces Hibernate to go "
@@ -1708,65 +1214,45 @@
 "there is a version or timestamp property, or you define <literal>Interceptor."
 "isUnsaved()</literal>."
 msgstr ""
-"Elegir el generador <literal>assigned</literal> hace que Hibernate use "
-"<literal>unsaved-value=\"undefined\"</literal>, forzando a Hibernate a ir a "
-"la base de datos para determinar si una instancia es transitoria o separada, "
-"a menos que haya una propiedad de versi&#x00f3;n o timestamp, o que tu "
-"definas <literal>Interceptor.isUnsaved()</literal>."
+"El generador <literal>assigned</literal> hace que Hibernate utilice "
+"<literal>unsaved-value=\"undefined\"</literal>. Esto fuerza a Hibernate a ir "
+"a la base de datos para determinar si una instancia es transitoria o "
+"separada, a menos de que haya una propiedad de versión o sello de fecha, o "
+"que usted defina <literal>Interceptor.isUnsaved()</literal>."
 
 #. Tag: title
-#: basic_mapping.xml:774
 #, no-c-format
 msgid "Primary keys assigned by triggers"
 msgstr "Claves primarias asignadas por disparadores"
 
 #. Tag: para
-#: basic_mapping.xml:775
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate does not generate DDL with triggers. It is for legacy schemas only."
 msgstr ""
-"Para esquemas heredados solamente (Hibernate no genera DDL con disparadores)."
+"Hibernate no genera DDL con disparadores. Es para los esquemas heredados "
+"sólamente."
 
-#. Tag: programlisting
-#: basic_mapping.xml:779
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-"        <generator class=\"select\">\n"
-"                <param name=\"key\">socialSecurityNumber</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-"        <generator class=\"select\">\n"
-"                <param name=\"key\">socialSecurityNumber</param>\n"
-"        </generator>\n"
-"</id>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:781
-#, fuzzy, no-c-format
-msgid ""
 "In the above example, there is a unique valued property named "
 "<literal>socialSecurityNumber</literal>. It is defined by the class, as a "
 "natural key and a surrogate key named <literal>person_id</literal>, whose "
 "value is generated by a trigger."
 msgstr ""
-"En el ejemplo de arriba, hay una propiedad &#x00e1;nica llamada "
-"<literal>socialSecurityNumber</literal> definida por la clase, como una "
-"clave natural, y una clave sustituta llamada <literal>person_id</literal> "
-"cuyo valor es generado por un disparador."
+"En el ejemplo anterior, hay una propiedad única llamada "
+"<literal>socialSecurityNumber</literal>, Esta está definida por la clase, "
+"como una clave natural y una clave sustituta llamada <literal>person_id</"
+"literal>, cuyo valor es generado por un disparador."
 
 #. Tag: title
-#: basic_mapping.xml:793
 #, no-c-format
 msgid "Enhanced identifier generators"
-msgstr "Enhanced identifier generators"
+msgstr "Generadores mejorados del identificador"
 
 #. Tag: para
-#: basic_mapping.xml:795
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Starting with release 3.2.3, there are 2 new generators which represent a re-"
 "thinking of 2 different aspects of identifier generation. The first aspect "
@@ -1776,17 +1262,18 @@
 "the named generators described above, starting in 3.3.x. However, they are "
 "included in the current releases and can be referenced by FQN."
 msgstr ""
-"Starting with release 3.2.3, there are 2 new generators which represent a re-"
-"thinking of 2 different aspects of identifier generation. The first aspect "
-"is database portability; the second is optimization (not having to query the "
-"database for every request for a new identifier value). These two new "
-"generators are intended to take the place of some of the named generators "
-"described above (starting in 3.3.x); however, they are included in the "
-"current releases and can be referenced by FQN."
+"Desde el lanzamiento 3.2.3, hay 2 nuevos generadores, los cuales representan "
+"una nueva reflexión sobre dos aspectos diferentes de la generación del "
+"identificador. El primer aspecto es qúe tan portátil es la base de datos; el "
+"segudno es la optimización. La optimización significa que no tiene que "
+"preguntarle a la base de datos por toda petición de un nuevo valor "
+"identificador. Estos dos nuevos generadores tienen el propósito de tomar el "
+"lugar de algunos de los generadores nombrados que describimos anteriormente, "
+"empezando por 3.3.x. Sin embargo, están incluídos en los lanzamientos "
+"actuales y puede ser referenciados por FQN."
 
 #. Tag: para
-#: basic_mapping.xml:803
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The first of these new generators is <literal>org.hibernate.id.enhanced."
 "SequenceStyleGenerator</literal> which is intended, firstly, as a "
@@ -1805,99 +1292,96 @@
 "with its table-based generators. This generator has a number of "
 "configuration parameters:"
 msgstr ""
-"The first of these new generators is <literal>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</literal> which is intended firstly as a replacement "
-"for the <literal>sequence</literal> generator and secondly as a better "
-"portability generator than <literal>native</literal> (because "
-"<literal>native</literal> (generally) chooses between <literal>identity</"
-"literal> and <literal>sequence</literal> which have largely different "
-"semantics which can cause subtle isssues in applications eyeing "
-"portability). <literal>org.hibernate.id.enhanced.SequenceStyleGenerator</"
-"literal> however achieves portability in a different manner. It chooses "
-"between using a table or a sequence in the database to store its "
-"incrementing values depending on the capabilities of the dialect being used. "
-"The difference between this and <literal>native</literal> is that table-"
-"based and sequence-based storage have the same exact semantic (in fact "
-"sequences are exactly what Hibernate tries to emmulate with its table-based "
-"generators). This generator has a number of configuration parameters:"
+"El primero de estos nuevos generadores es <literal>org.hibernate.id.enhanced."
+"SequenceStyleGenerator</literal>, el cual tiene el propósito, primero, de "
+"ser el reemplazo para el generador <literal>sequence</literal> y segundo, de "
+"ser un generador de portabilidad mejor que <literal>native</literal>. Esto "
+"se debe a que <literal>native</literal> generalmente escoge entre "
+"<literal>identity</literal> y <literal>sequence</literal>, los cuales tienen "
+"una gran diferencia semántica que puede crear problemas sutiles en las "
+"aplicaciones mirando la portabilidad. Sin embargo, <literal>org.hibernate.id."
+"enhanced.SequenceStyleGenerator</literal>, logra la portabilidad de una "
+"manera diferente. Escoge entre una tabla o una secuencia en la base de datos "
+"para almacenar sus valores en subida, dependiendo de las capacidades del "
+"dialecto que se está utilizando. La diferencia enter esto y <literal>native</"
+"literal> es que el almacenamiento basado en tablas y secuencias tienen la "
+"misma semántica. De hecho, las secuencias son exactamente lo que Hibernate "
+"trata de emular con sus generadores basados en tablas. Este generador tiene "
+"un número de parámetros de configuración:"
 
 #. Tag: para
-#: basic_mapping.xml:817
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>sequence_name</literal> (optional, defaults to "
 "<literal>hibernate_sequence</literal>): the name of the sequence or table to "
 "be used."
 msgstr ""
-"<literal>sequence_name</literal> (optional, defaults to "
-"<literal>hibernate_sequence</literal>): The name of the sequence (or table) "
-"to be used."
+"<literal>sequence_name</literal> (opcional, por defecto es "
+"<literal>hibernate_sequence</literal>): el nombre de la secuencia o la tabla "
+"a utilizar."
 
 #. Tag: para
-#: basic_mapping.xml:823
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>initial_value</literal> (optional, defaults to <literal>1</"
 "literal>): the initial value to be retrieved from the sequence/table. In "
 "sequence creation terms, this is analogous to the clause typically named "
 "\"STARTS WITH\"."
 msgstr ""
-"<literal>initial_value</literal> (optional, defaults to <literal>1</"
-"literal>): The initial value to be retrieved from the sequence/table. In "
-"sequence creation terms, this is analogous to the clause typical named "
-"\"STARTS WITH\"."
+"<literal>initial_value</literal> (opcional, por defecto es <literal>1</"
+"literal>): el valor inicial a recuperarse de la secuencia/tabla. En términos "
+"de creación de secuencias, esto es análogo a la cláusula que usualmente se "
+"llama \"STARTS WITH\"."
 
 #. Tag: para
-#: basic_mapping.xml:830
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>increment_size</literal> (optional - defaults to <literal>1</"
 "literal>): the value by which subsequent calls to the sequence/table should "
 "differ. In sequence creation terms, this is analogous to the clause "
 "typically named \"INCREMENT BY\"."
 msgstr ""
-"<literal>increment_size</literal> (optional, defaults to <literal>1</"
-"literal>): The value by which subsequent calls to the sequence/table should "
-"differ. In sequence creation terms, this is analogous to the clause typical "
-"named \"INCREMENT BY\"."
+"<literal>increment_size</literal> (opcional - por defecto es <literal>1</"
+"literal>): el valor por el cual las llamadas subsecuentes a la secuencia/"
+"tabla deben diferir. En términos de creación de secuencias, esto es análogo "
+"a la cláusula que usualmente se llama \"INCREMENT BY\"."
 
 #. Tag: para
-#: basic_mapping.xml:837
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>force_table_use</literal> (optional - defaults to <literal>false</"
 "literal>): should we force the use of a table as the backing structure even "
 "though the dialect might support sequence?"
 msgstr ""
-"<literal>force_table_use</literal> (optional, defaults to <literal>false</"
-"literal>): Should we force the use of a table as the backing structure even "
-"though the dialect might support sequence?"
+"<literal>force_table_use</literal> (opcional - por defecto es "
+"<literal>false</literal>): ¿debemos forzar el uso de una tabla como la "
+"estructura de respaldo aunque puede que el dialecto soporte la secuencia?"
 
 #. Tag: para
-#: basic_mapping.xml:844
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>value_column</literal> (optional - defaults to <literal>next_val</"
 "literal>): only relevant for table structures, it is the name of the column "
 "on the table which is used to hold the value."
 msgstr ""
-"<literal>value_column</literal> (optional, defaults to <literal>next_val</"
-"literal>): Only relevant for table structures! The name of the column on the "
-"table which is used to hold the value."
+"<literal>value_column</literal> (opcional - por defecto es "
+"<literal>next_val</literal>): solo es relevante para estructuras de tablas, "
+"es el nombre de la columna en la tabla, la cual se usa para mantener el "
+"valor."
 
 #. Tag: para
-#: basic_mapping.xml:851
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimizer</literal> (optional - defaults to <literal>none</"
-"literal>): See"
+"literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\" /"
+">"
 msgstr ""
-"<literal>optimizer</literal> (optional, defaults to <literal>none</"
-"literal>): See"
+"<literal>optimizer</literal> (opcional - por defecto es <literal>none</"
+"literal>): Consulte <xref linkend=\"mapping-declaration-id-enhanced-"
+"optimizers\" />"
 
 #. Tag: para
-#: basic_mapping.xml:858
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The second of these new generators is <literal>org.hibernate.id.enhanced."
 "TableGenerator</literal>, which is intended, firstly, as a replacement for "
@@ -1910,147 +1394,138 @@
 "multiple distinctly keyed rows. This generator has a number of configuration "
 "parameters:"
 msgstr ""
-"The second of these new generators is <literal>org.hibernate.id.enhanced."
-"TableGenerator</literal> which is intended firstly as a replacement for the "
-"<literal>table</literal> generator (although it actually functions much more "
-"like <literal>org.hibernate.id.MultipleHiLoPerTableGenerator</literal>) and "
-"secondly as a re-implementation of <literal>org.hibernate.id."
-"MultipleHiLoPerTableGenerator</literal> utilizing the notion of pluggable "
-"optimiziers. Essentially this generator defines a table capable of holding a "
-"number of different increment values simultaneously by using multiple "
-"distinctly keyed rows. This generator has a number of configuration "
-"parameters:"
+"El segundo de estos nuevos generadores es <literal>org.hibernate.id.enhanced."
+"TableGenerator</literal>, el cual tiene el propósito, primero, de reemplazar "
+"el generador <literal>table</literal>, auqnue de hecho funciona como "
+"<literal>org.hibernate.id.MultipleHiLoPerTableGenerator</literal>, y "
+"segundo, como una re-implementación de <literal>org.hibernate.id."
+"MultipleHiLoPerTableGenerator</literal> que utiliza la noción de los "
+"optimizadores enchufables. Esencialmente, este generador define una tabla "
+"capaz de mantener un número de valores de incremento diferentes de manera "
+"simultánea usando múltiples filas tecleadas claramente. Este generador tiene "
+"un número de parámetros de configuración:"
 
 #. Tag: para
-#: basic_mapping.xml:868
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>table_name</literal> (optional - defaults to "
 "<literal>hibernate_sequences</literal>): the name of the table to be used."
 msgstr ""
-"<literal>table_name</literal> (optional, defaults to "
-"<literal>hibernate_sequences</literal>): The name of the table to be used."
+"<literal>table_name</literal> (opcional - por defecto es "
+"<literal>hibernate_sequences</literal>): el nombre de la tabla a utilizar."
 
 #. Tag: para
-#: basic_mapping.xml:874
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>value_column_name</literal> (optional - defaults to "
 "<literal>next_val</literal>): the name of the column on the table that is "
 "used to hold the value."
 msgstr ""
-"<literal>value_column_name</literal> (optional, defaults to "
-"<literal>next_val</literal>): The name of the column on the table which is "
-"used to hold the value."
+"<literal>value_column_name</literal> (opcional - por defecto es "
+"<literal>next_val</literal>): el nombre de la columna en la tabla que se "
+"utiliza para mantener el valor."
 
 #. Tag: para
-#: basic_mapping.xml:880
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>segment_column_name</literal> (optional - defaults to "
 "<literal>sequence_name</literal>): the name of the column on the table that "
 "is used to hold the \"segment key\". This is the value which identifies "
 "which increment value to use."
 msgstr ""
-"<literal>segment_column_name</literal> (optional, defaults to "
-"<literal>sequence_name</literal>): The name of the column on the table which "
-"is used to hold the \"segement key\". This is the value which distinctly "
-"identifies which increment value to use."
+"<literal>segment_column_name</literal> (opcional - por defecto es "
+"<literal>sequence_name</literal>): el nombre de la columna en la tabla que "
+"se utiliza para mantener la \"llave segmento\". Este es el valor que "
+"identifica que valor de incremento utilizar."
 
 #. Tag: para
-#: basic_mapping.xml:887
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>segment_value</literal> (optional - defaults to <literal>default</"
 "literal>): The \"segment key\" value for the segment from which we want to "
 "pull increment values for this generator."
 msgstr ""
-"<literal>segment_value</literal> (optional, defaults to <literal>default</"
-"literal>): The \"segment key\" value for the segment from which we want to "
-"pull increment values for this generator."
+"<literal>segment_value</literal> (opcional - por defecto es "
+"<literal>default</literal>): El valor \"llave segmento\" para el segmento "
+"desde el cual queremos sacar los valores de incremento para este generador."
 
 #. Tag: para
-#: basic_mapping.xml:894
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>segment_value_length</literal> (optional - defaults to "
 "<literal>255</literal>): Used for schema generation; the column size to "
 "create this segment key column."
 msgstr ""
-"<literal>segment_value_length</literal> (optional, defaults to <literal>255</"
-"literal>): Used for schema generation; the column size to create this "
-"segment key column."
+"<literal>segment_value_length</literal> (opcional - por defecto es "
+"<literal>255</literal>): Se utiliza para la generación de esquemas; el "
+"tamaño de la columna a crear esta columna de llave de segmento."
 
 #. Tag: para
-#: basic_mapping.xml:900
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>initial_value</literal> (optional - defaults to <literal>1</"
 "literal>): The initial value to be retrieved from the table."
 msgstr ""
-"<literal>initial_value</literal> (optional, defaults to <literal>1</"
-"literal>): The initial value to be retrieved from the table."
+"<literal>initial_value</literal> (opcional - por defecto es <literal>1</"
+"literal>): El valor inicial a recuperar de la tabla."
 
 #. Tag: para
-#: basic_mapping.xml:906
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>increment_size</literal> (optional - defaults to <literal>1</"
 "literal>): The value by which subsequent calls to the table should differ."
 msgstr ""
-"<literal>increment_size</literal> (optional, defaults to <literal>1</"
-"literal>): The value by which subsequent calls to the table should differ."
+"<literal>increment_size</literal> (opcional - por defecto es <literal>1</"
+"literal>): El valor por el cual deben diferir las llamadas subsecuentes a la "
+"tabla."
 
 #. Tag: para
-#: basic_mapping.xml:912
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimizer</literal> (optional - defaults to <literal></literal>): "
-"See"
+"See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\" />"
 msgstr ""
-"<literal>optimizer</literal> (optional, defaults to <literal></literal>): See"
+"<literal>optimizer</literal> (opcional - por defecto es <literal></"
+"literal>): Consulte <xref linkend=\"mapping-declaration-id-enhanced-"
+"optimizers\" />"
 
 #. Tag: title
-#: basic_mapping.xml:922
 #, no-c-format
 msgid "Identifier generator optimization"
-msgstr "Identifier generator optimization"
+msgstr "Optimización del generador del identificador"
 
 #. Tag: para
-#: basic_mapping.xml:923
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For identifier generators that store values in the database, it is "
 "inefficient for them to hit the database on each and every call to generate "
 "a new identifier value. Instead, you can group a bunch of them in memory and "
 "only hit the database when you have exhausted your in-memory value group. "
 "This is the role of the pluggable optimizers. Currently only the two "
-"enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced\"/> "
+"enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced\" /> "
 "support this operation."
 msgstr ""
-"For identifier generators which store values in the database, it is "
-"inefficient for them to hit the database on each and every call to generate "
-"a new identifier value. Instead, you'd ideally want to group a bunch of them "
-"in memory and only hit the database when you have exhausted your in-memory "
-"value group. This is the role of the pluggable optimizers. Currently only "
-"the two enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced"
-"\"/> support this notion."
+"Para los generadores del identificador que almacenan valores en la base de "
+"datos, es ineficiente el acceder a la base de datos en toda llamada para "
+"generar un nuevo valor identificador. En lugar, puede agrupar una serie de "
+"ellos en la memoria y solo acceder a la base de datos cuando haya acabado su "
+"grupo de valores en memoria. Este es el papel de los optimizadores "
+"enchufables. Actualmente solo los dos generadores mejorados (<xref linkend="
+"\"mapping-declaration-id-enhanced\" />) soportan esta operación."
 
 #. Tag: para
-#: basic_mapping.xml:931
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>none</literal> (generally this is the default if no optimizer was "
 "specified): this will not perform any optimizations and hit the database for "
 "each and every request."
 msgstr ""
-"<literal>none</literal> (generally this is the default if no optimizer was "
-"specified): This says to not perform any optimizations, and hit the database "
-"each and every request."
+"<literal>none</literal> (generalmente este el es valor predeterminado si no "
+"se especifica un optimizador): esto no realizará ninguna optimización y "
+"accederá a la base de datos para toda petición."
 
 #. Tag: para
-#: basic_mapping.xml:937
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>hilo</literal>: applies a hi/lo algorithm around the database "
 "retrieved values. The values from the database for this optimizer are "
@@ -2059,16 +1534,15 @@
 "<literal>increment_size</literal> is multiplied by that value in memory to "
 "define a group \"hi value\"."
 msgstr ""
-"<literal>hilo</literal>: applies a hi/lo algorithm around the database "
-"retrieved values. The values from the database for this optimizer are "
-"expected to be sequential. The values retrieved from the database structure "
-"for this optimizer indicates the \"group number\"; the "
-"<literal>increment_size</literal> is multiplied by that value in memory to "
-"define a group \"hi value\"."
+"<literal>hilo</literal>: aplica un algoritmo hi/lo a los valores recuperados "
+"de la base de datos. Se espera que los valores de la base de datos para este "
+"optimizador sean secuenciales. Los valores recuperados de la estructura de "
+"la base de datos para este optimizador indican el \"número del grupo\". El "
+"<literal>increment_size</literal> se multiplica por ese valor en la memoria "
+"para definir un grupo \"hi value\"."
 
 #. Tag: para
-#: basic_mapping.xml:946
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>pooled</literal>: as with the case of <literal>hilo</literal>, this "
 "optimizer attempts to minimize the number of hits to the database. Here, "
@@ -2077,96 +1551,47 @@
 "memory grouping algorithm. Here, <literal>increment_size</literal> refers to "
 "the values coming from the database."
 msgstr ""
-"<literal>pooled</literal>: like was discussed for <literal>hilo</literal>, "
-"this optimizers attempts to minimize the number of hits to the database. "
-"Here, however, we simply store the starting value for the \"next group\" "
-"into the database structure rather than a sequential value in combination "
-"with an in-memory grouping algorithm. <literal>increment_size</literal> here "
-"refers to the values coming from the database."
+"<literal>pooled</literal>: como en el caso de <literal>hilo</literal>, este "
+"optimizador trata de minimizar el número de hits a la base de datos. Sin "
+"embargo, aquí simplemente almacenamos el valor inicial para el \"siguiente "
+"grupo\" en la estructura de la base de datos en lugar de un valor secuencial "
+"en combinación con un algoritmo de agrupamiento en-memoria. Aquí, "
+"<literal>increment_size</literal> ser refiere a los valores que provienen de "
+"la base de datos."
 
 #. Tag: title
-#: basic_mapping.xml:959
 #, no-c-format
 msgid "composite-id"
 msgstr "composite-id"
 
-#. Tag: programlisting
-#: basic_mapping.xml:961
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<composite-id\n"
-"        name=\"propertyName\"\n"
-"        class=\"ClassName\"\n"
-"        mapped=\"true|false\"\n"
-"        access=\"field|property|ClassName\">\n"
-"        node=\"element-name|.\"\n"
-"\n"
-"        <key-property name=\"propertyName\" type=\"typename\" column="
-"\"column_name\"/>\n"
-"        <key-many-to-one name=\"propertyName class=\"ClassName\" column="
-"\"column_name\"/>\n"
-"        ......\n"
-"</composite-id>]]>"
-msgstr ""
-"<![CDATA[<composite-id\n"
-"        name=\"propertyName\"\n"
-"        class=\"ClassName\"\n"
-"        unsaved-value=\"undefined|any|none\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        node=\"element-name|.\">\n"
-"\n"
-"        <key-property name=\"propertyName\" type=\"typename\" column="
-"\"column_name\"/>\n"
-"        <key-many-to-one name=\"propertyName class=\"ClassName\" column="
-"\"column_name\"/>\n"
-"        ......\n"
-"</composite-id>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:963
-#, fuzzy, no-c-format
-msgid ""
 "A table with a composite key can be mapped with multiple properties of the "
 "class as identifier properties. The <literal>&lt;composite-id&gt;</literal> "
 "element accepts <literal>&lt;key-property&gt;</literal> property mappings "
 "and <literal>&lt;key-many-to-one&gt;</literal> mappings as child elements."
 msgstr ""
-"Para una tabla con clave compuesta, puedes mapear m&#x00fa;ltiples "
-"propiedades de la clase como propiedades identificadoras. El elemento "
-"<literal>&lt;composite-id&gt;</literal> acepta los mapeos de propiedad "
-"<literal>&lt;key-property&gt;</literal> y los mapeos <literal>&lt;key-many-"
-"to-one&gt;</literal> como elementos hijo."
+"Una tabla con clave compuesta se puede mapear con múltiples propiedades de "
+"la clase como propiedades identificadoras. El elemento <literal>&lt;"
+"composite-id&gt;</literal> acepta los mapeos de propiedad <literal>&lt;key-"
+"property&gt;</literal> y los mapeos <literal>&lt;key-many-to-one&gt;</"
+"literal> como elementos hijos."
 
-#. Tag: programlisting
-#: basic_mapping.xml:970
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<composite-id>\n"
-"        <key-property name=\"medicareNumber\"/>\n"
-"        <key-property name=\"dependent\"/>\n"
-"</composite-id>]]>"
-msgstr ""
-"<![CDATA[<composite-id>\n"
-"        <key-property name=\"medicareNumber\"/>\n"
-"        <key-property name=\"dependent\"/>\n"
-"</composite-id>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:972
-#, fuzzy, no-c-format
-msgid ""
 "The persistent class <emphasis>must</emphasis> override <literal>equals()</"
 "literal> and <literal>hashCode()</literal> to implement composite identifier "
 "equality. It must also implement <literal>Serializable</literal>."
 msgstr ""
-"Tu clase persistente <emphasis>debe</emphasis> sobreescribir <literal>equals"
-"()</literal> y <literal>hashCode()</literal> para implementar igualdad de "
-"identificador compuesto. Debe tambi&#x00e9;n implementar "
+"La clase persistente <emphasis>tiene</emphasis> que sobrescribir "
+"<literal>equals()</literal> y <literal>hashCode()</literal> para implementar "
+"la igualdad del identificador compuesto. También tiene que implementar "
 "<literal>Serializable</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:978
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Unfortunately, this approach means that a persistent object is its own "
 "identifier. There is no convenient \"handle\" other than the object itself. "
@@ -2176,18 +1601,15 @@
 "<emphasis>embedded</emphasis> composite identifier, and discourage it for "
 "serious applications."
 msgstr ""
-"Desafortunadamente, este enfoque de identificadores compuestos significa que "
-"un objeto persistente es su propio identificador. No existe otra \"asa\" "
-"conveniente m&#x00e1;s que el objeto mismo. Debes instanciar una instancia "
-"de la clase misma y poblar sus propiedades identificadoras antes que puedas "
-"<literal>load()</literal> el estado persistente asociado a una clave "
-"compuesta. Describiremos un enfoque mucho m&#x00e1;s conveniente donde el "
-"identificador compuesto est&#x00e1; implementado como una clase separada en "
-"<xref linkend=\"components-compositeid\"/>. Los atributos descriptos debajo "
-"solamente se aplican a este enfoque alternativo:"
+"Desafortunadamente, este enfoque significa que un objeto persistente es su "
+"propio identificador. No existe otra \"asa\" conveniente más que el objeto "
+"mismo. Debe instanciar una instancia de la clase persistente y poblar sus "
+"propiedades identificadoras antes de que pueda <literal>load()</literal> el "
+"estado persistente asociado a una clave compuesta. Este enfoque lo "
+"denominamos un identificador compuesto <emphasis>incluído</emphasis> y no lo "
+"recomendamos para aplicaciones serias."
 
 #. Tag: para
-#: basic_mapping.xml:987
 #, no-c-format
 msgid ""
 "A second approach is what we call a <emphasis>mapped</emphasis> composite "
@@ -2195,29 +1617,15 @@
 "composite-id&gt;</literal> element are duplicated on both the persistent "
 "class and a separate identifier class."
 msgstr ""
-"A second approach is what we call a <emphasis>mapped</emphasis> composite "
-"identifier, where the identifier properties named inside the <literal>&lt;"
-"composite-id&gt;</literal> element are duplicated on both the persistent "
-"class and a separate identifier class."
+"Un segundo enfoque es lo que denominamos un identificador compuesto "
+"<emphasis>mapeado</emphasis>, en donde las propiedades del identificador "
+"nombradas dentro del elemento <literal>&lt;composite-id&gt;</literal> son "
+"duplicadas tanto en la clase persistente como en la clase identificadora "
+"separada."
 
-#. Tag: programlisting
-#: basic_mapping.xml:993
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<composite-id class=\"MedicareId\" mapped=\"true\">\n"
-"        <key-property name=\"medicareNumber\"/>\n"
-"        <key-property name=\"dependent\"/>\n"
-"</composite-id>]]>"
-msgstr ""
-"<![CDATA[<composite-id class=\"MedicareId\" mapped=\"true\">\n"
-"                            <key-property name=\"medicareNumber\"/>\n"
-"                            <key-property name=\"dependent\"/>\n"
-"                    </composite-id>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:995
-#, fuzzy, no-c-format
-msgid ""
 "In this example, both the composite identifier class, <literal>MedicareId</"
 "literal>, and the entity class itself have properties named "
 "<literal>medicareNumber</literal> and <literal>dependent</literal>. The "
@@ -2225,115 +1633,106 @@
 "<literal>hashCode()</literal> and implement <literal>Serializable</literal>. "
 "The main disadvantage of this approach is code duplication."
 msgstr ""
-"In this example, both the composite identifier class, <literal>MedicareId</"
-"literal>, and the entity class itself have properties named "
-"<literal>medicareNumber</literal> and <literal>dependent</literal>. The "
-"identifier class must override <literal>equals()</literal> and "
-"<literal>hashCode()</literal> and implement. <literal>Serializable</"
-"literal>. The disadvantage of this approach is quite obvious&mdash;code "
-"duplication."
+"En este ejemplo, tanto la clase identificadora compuesta "
+"<literal>MedicareId</literal> como la clase de entidad misma tienen "
+"propiedades denominadas <literal>medicareNumber</literal> y "
+"<literal>dependent</literal>. La clase identificadora tiene que sobrescribir "
+"<literal>equals()</literal> y <literal>hashCode()</literal> e implementar "
+"<literal>Serializable</literal>. La desventaja principal de este enfoque es "
+"la duplicación de código."
 
 #. Tag: para
-#: basic_mapping.xml:1004
 #, no-c-format
 msgid ""
 "The following attributes are used to specify a mapped composite identifier:"
 msgstr ""
-"The following attributes are used to specify a mapped composite identifier:"
+"Los siguientes atributos se utilizan para especificar un identificador "
+"compuesto mapeado:"
 
 #. Tag: para
-#: basic_mapping.xml:1010
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mapped</literal> (optional - defaults to <literal>false</literal>): "
 "indicates that a mapped composite identifier is used, and that the contained "
 "property mappings refer to both the entity class and the composite "
 "identifier class."
 msgstr ""
-"<literal>mapped</literal> (optional, defaults to <literal>false</literal>): "
-"indicates that a mapped composite identifier is used, and that the contained "
-"property mappings refer to both the entity class and the composite "
-"identifier class."
+"<literal>mapped</literal> (opcional, por defecto es <literal>false</"
+"literal>): indica que se utiliza un identificador compuesto mapeado y que "
+"los mapeos de propiedad contenidos se refieren tanto a la clase de entidad "
+"como a la clase identificadora compuesta. "
 
 #. Tag: para
-#: basic_mapping.xml:1018
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - but required for a mapped composite "
 "identifier): the class used as a composite identifier."
 msgstr ""
-"<literal>class</literal> (optional, but required for a mapped composite "
-"identifier): The class used as a composite identifier."
+"<literal>class</literal> (opcional, pero requerida por un identificador "
+"compuesto mapeado): La clase se utiliza como un identificador compuesto. "
 
 #. Tag: para
-#: basic_mapping.xml:1025
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will describe a third, even more convenient approach, where the composite "
 "identifier is implemented as a component class in <xref linkend=\"components-"
-"compositeid\"/>. The attributes described below apply only to this "
+"compositeid\" />. The attributes described below apply only to this "
 "alternative approach:"
 msgstr ""
-"We will describe a third, even more convenient approach where the composite "
-"identifier is implemented as a component class in <xref linkend=\"components-"
-"compositeid\"/>. The attributes described below apply only to this "
-"alternative approach:"
+"Vamos a decribir un tercer enfoque, aún más práctico, en donde se implementa "
+"el identificador compuesto como una clase componente en <xref linkend="
+"\"components-compositeid\"/>. Los atributos descritos a continuación "
+"sólamente aplican a este enfoque alternativo:"
 
 #. Tag: para
-#: basic_mapping.xml:1033
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal> (optional - required for this approach): a property "
 "of component type that holds the composite identifier. Please see chapter 9 "
 "for more information."
 msgstr ""
-"<literal>name</literal> (opcional): Una propiedad de tipo componente que "
-"tiene el identificador compuesto (ver siguiente secci&#x00f3;n)."
+"<literal>name</literal> (opcional, se necesita para este enfoque): Una "
+"propiedad de tipo componente que tiene el identificador compuesto. Consulte "
+"el capítulo 9 para obtener mayor información. "
 
 #. Tag: para
-#: basic_mapping.xml:1039 basic_mapping.xml:1260 basic_mapping.xml:1372
-#: basic_mapping.xml:1561 basic_mapping.xml:1735 basic_mapping.xml:1905
-#: basic_mapping.xml:2484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate uses for accessing the property value."
 msgstr ""
-"<literal>access</literal> (opcional - por defecto a <literal>property</"
-"literal>): La estrategia que Hibernate debe usar para acceder al valor de la "
+"<literal>access</literal> (opcional - por defecto es <literal>property</"
+"literal>): La estrategia que Hibernate utiliza para acceder al valor de la "
 "propiedad."
 
 #. Tag: para
-#: basic_mapping.xml:1045
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
 "determined by reflection): the component class used as a composite "
 "identifier. Please see the next section for more information."
 msgstr ""
-"<literal>class</literal> (opcional - por defecto al tipo de la propiedad "
-"determinado por reflecci&#x00f3;n): La clase del componente usado como "
-"identificador compuesto (ver siguiente secci&#x00f3;n)."
+"<literal>class</literal> (opcional - por defecto es el tipo de propiedad "
+"determinado por la reflección): la clase componente utilizada como un "
+"identificador compuesto. Vea la siguiente sección para obtener mayor "
+"información."
 
 #. Tag: para
-#: basic_mapping.xml:1052
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The third approach, an <emphasis>identifier component</emphasis>, is "
 "recommended for almost all applications."
 msgstr ""
-"This third approach, an <emphasis>identifier component</emphasis> is the one "
-"we recommend for almost all applications."
+"Este tercer enfoque, un <emphasis>componente identificador</emphasis> es el "
+"que recomendamos para casi todas las aplicaciones. "
 
 #. Tag: title
-#: basic_mapping.xml:1060
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Discriminator"
-msgstr "discriminator"
+msgstr "Discriminador"
 
 #. Tag: para
-#: basic_mapping.xml:1062
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;discriminator&gt;</literal> element is required for "
 "polymorphic persistence using the table-per-class-hierarchy mapping "
@@ -2345,150 +1744,109 @@
 "<literal>boolean</literal>, <literal>yes_no</literal>, <literal>true_false</"
 "literal>."
 msgstr ""
-"El elemento <literal>&lt;discriminator&gt;</literal> es requerido para la "
-"persistencia polim&#x00f3;rfica usando la estrategia de mapeo de tabla-por-"
-"jerarqu&#x00ed;a-de-clases y declara una columna discriminadora de la tabla. "
-"La columna discriminidora contiene valores de marca que le dicen a la capa "
-"de persistencia qu&#x00e9; subclase instanciar para una fila en particular. "
-"Un conjunto restringido de tipos puede ser usado: <literal>string</literal>, "
+"Se necesita el elemento <literal>&lt;discriminator&gt;</literal> para la "
+"persistencia polimórfica utilizando la estrategia de mapeo de tabla-por-"
+"jerarquía-de-clases. Declara una columna discriminadora de la tabla. La "
+"columna discriminidora contiene valores de marca que le dicen a la capa de "
+"persistencia qué subclase instanciar para una fila en particular. Se puede "
+"utilizar un conjunto restringido de tipos: <literal>string</literal>, "
 "<literal>character</literal>, <literal>integer</literal>, <literal>byte</"
 "literal>, <literal>short</literal>, <literal>boolean</literal>, "
 "<literal>yes_no</literal>, <literal>true_false</literal>."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1080
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<discriminator\n"
-"        column=\"discriminator_column\"\n"
-"        type=\"discriminator_type\"\n"
-"        force=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        formula=\"arbitrary sql expression\"\n"
-"/>]]>"
-msgstr ""
-"<![CDATA[<discriminator\n"
-"        column=\"discriminator_column\"\n"
-"        type=\"discriminator_type\"\n"
-"        force=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        formula=\"arbitrary sql expression\"\n"
-"/>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:1083
-#, fuzzy, no-c-format
-msgid ""
 "<literal>column</literal> (optional - defaults to <literal>class</literal>): "
 "the name of the discriminator column."
 msgstr ""
-"<literal>column</literal> (opcional - por defecto a <literal>class</"
-"literal>) el nombre de la columna discriminadora."
+"<literal>column</literal> (opcional - por defecto es <literal>class</"
+"literal>) el nombre de la columna discriminadora. "
 
 #. Tag: para
-#: basic_mapping.xml:1089
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>type</literal> (optional - defaults to <literal>string</literal>): "
 "a name that indicates the Hibernate type"
 msgstr ""
-"<literal>type</literal> (opcional - por defecto a <literal>string</literal>) "
-"un nombre que indique el tipo Hibernate"
+"<literal>type</literal> (opcional - por defecto es <literal>string</"
+"literal>) un nombre que indica el tipo Hibernate. "
 
 #. Tag: para
-#: basic_mapping.xml:1095
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>force</literal> (optional - defaults to <literal>false</literal>): "
 "\"forces\" Hibernate to specify the allowed discriminator values, even when "
 "retrieving all instances of the root class."
 msgstr ""
-"<literal>force</literal> (optconal - por defecto a <literal>false</literal>) "
-"\"fuerza\" a Hibernate a especificar valores discriminadores permitidos "
-"incluso cuando se recuperan todas las instancias de la clase ra&#x00ed;z."
+"<literal>force</literal> (opcional - por defecto es <literal>false</"
+"literal>) \"fuerza\" a Hibernate para especificar los valores "
+"discriminadores permitidos incluso cuando se recuperan todas las instancias "
+"de la clase raíz. "
 
 #. Tag: para
-#: basic_mapping.xml:1102
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>insert</literal> (optional - defaults to <literal>true</literal>): "
 "set this to <literal>false</literal> if your discriminator column is also "
 "part of a mapped composite identifier. It tells Hibernate not to include the "
 "column in SQL <literal>INSERTs</literal>."
 msgstr ""
-"<literal>insert</literal> (opcional - por defecto a <literal>true</literal>) "
-"establezca este a <literal>false</literal> si tu columna discriminadora es "
-"tambi&#x00e9;n parte de un identificador mapeado compuesto. (Le dice a "
-"Hibernate que no incluya la columna en los SQL <literal>INSERT</literal>s.)"
+"<literal>insert</literal> (opcional - por defecto es <literal>true</"
+"literal>): establecido como <literal>false</literal> si su columna "
+"discriminadora también es parte de un identificador mapeado compuesto. Lle "
+"dice a Hibernate que no incluya la columna en los SQLs <literal>INSERT</"
+"literal>."
 
 #. Tag: para
-#: basic_mapping.xml:1110
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an arbitrary SQL expression that is "
 "executed when a type has to be evaluated. It allows content-based "
 "discrimination."
 msgstr ""
-"<literal>formula</literal> (opcional) una expresi&#x00f3;n SQL arbitraria "
-"que es ejecutada cuando un tipo tenga que ser evaluado. Permite "
-"dicriminaci&#x00f3;n basada en el contenido."
+"<literal>formula</literal> (opcional): una expresión SQL arbitraria que se "
+"ejecuta cuando se tenga que evaluar un tipo. Permite la discriminación con "
+"base en el contenido."
 
 #. Tag: para
-#: basic_mapping.xml:1118
 #, no-c-format
 msgid ""
 "Actual values of the discriminator column are specified by the "
 "<literal>discriminator-value</literal> attribute of the <literal>&lt;"
 "class&gt;</literal> and <literal>&lt;subclass&gt;</literal> elements."
 msgstr ""
-"Los valores reales de la columna discriminadora est&#x00e1;n especificados "
-"por el atributo <literal>discriminator-value</literal> de los elementos "
+"Los valores reales de la columna discriminadora están especificados por el "
+"atributo <literal>discriminator-value</literal> de los elementos "
 "<literal>&lt;class&gt;</literal> y <literal>&lt;subclass&gt;</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:1124
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>force</literal> attribute is only useful if the table contains "
 "rows with \"extra\" discriminator values that are not mapped to a persistent "
 "class. This will not usually be the case."
 msgstr ""
-"El atributo <literal>force</literal> es (s&#x00f3;lo) &#x00fa;til si la "
-"tabla contiene filas con valores discriminadores \"extra\" que no est&#x00e1;"
-"n mapeados a la clase persistente. Generalmente este no es el caso."
+"El atributo <literal>force</literal> es sólamente útil si la tabla contiene "
+"filas con valores discriminadores \"extra\" que no estén mapeados a una "
+"clase persistente. Generalmente este no es el caso."
 
 #. Tag: para
-#: basic_mapping.xml:1130
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>formula</literal> attribute allows you to declare an arbitrary "
 "SQL expression that will be used to evaluate the type of a row. For example:"
 msgstr ""
-"Usando el atributo <literal>formula</literal> puedes declarar una "
-"expresi&#x00f3;n SQL arbitraria que ser&#x00e1; usada para evaluar el tipo "
-"de una fila:"
+"El atributo <literal>formula</literal> le permite declarar una expresión SQL "
+"arbitraria que será utilizada para evaluar el tipo de una fila. Por ejemplo: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1135
-#, no-c-format
-msgid ""
-"<![CDATA[<discriminator\n"
-"    formula=\"case when CLASS_TYPE in ('a', 'b', 'c') then 0 else 1 end\"\n"
-"    type=\"integer\"/>]]>"
-msgstr ""
-"<![CDATA[<discriminator\n"
-"    formula=\"case when CLASS_TYPE in ('a', 'b', 'c') then 0 else 1 end\"\n"
-"    type=\"integer\"/>]]>"
-
 #. Tag: title
-#: basic_mapping.xml:1140
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Version (optional)"
-msgstr "version (opcional)"
+msgstr "Versión (opcional)"
 
 #. Tag: para
-#: basic_mapping.xml:1142
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;version&gt;</literal> element is optional and indicates "
 "that the table contains versioned data. This is particularly useful if you "
@@ -2496,76 +1854,47 @@
 "information:"
 msgstr ""
 "El elemento <literal>&lt;version&gt;</literal> es opcional e indica que la "
-"tabla contiene datos versionados. Esto es particularmente &#x00fa;til si "
-"planeas usar <emphasis>transacciones largas</emphasis> (ver debajo)."
+"tabla contiene datos versionados. Esto es particularmente útil si planea "
+"utilizar <emphasis>transacciones largas</emphasis>. Vea a continuación para "
+"obtener mayor información:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1158
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<version\n"
-"        column=\"version_column\"\n"
-"        name=\"propertyName\"\n"
-"        type=\"typename\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unsaved-value=\"null|negative|undefined\"\n"
-"        generated=\"never|always\"\n"
-"        insert=\"true|false\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"/>]]>"
-msgstr ""
-"<![CDATA[<version\n"
-"        column=\"version_column\"\n"
-"        name=\"propertyName\"\n"
-"        type=\"typename\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unsaved-value=\"null|negative|undefined\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"/>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:1161
-#, fuzzy, no-c-format
-msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of the column holding the version number."
 msgstr ""
-"<literal>column</literal> (opcional - por defecto al nombre de la "
-"propiedad): El nombre de la columna que tiene el n&#x00fa;mero de "
-"versi&#x00f3;n."
+"<literal>column</literal> (opcional - por defecto es el nombre de la "
+"propiedad): El nombre de la columna que tiene el número de la versión."
 
 #. Tag: para
-#: basic_mapping.xml:1167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal>: the name of a property of the persistent class."
 msgstr ""
-"<literal>name</literal>: El nombre de una propiedad de la clase persistente."
+"<literal>name</literal>: El nombre de una propiedad de la clase persistente. "
 
 #. Tag: para
-#: basic_mapping.xml:1172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>type</literal> (optional - defaults to <literal>integer</literal>): "
 "the type of the version number."
 msgstr ""
-"<literal>type</literal> (opcional - por defecto a <literal>integer</"
-"literal>): El tipo del n&#x00fa;.mero de vesi&#x00f3;n."
+"<literal>type</literal> (opcional - por defecto es <literal>integer</"
+"literal>): El tipo del número de la versión. "
 
 #. Tag: para
-#: basic_mapping.xml:1178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate uses to access the property value."
 msgstr ""
-"<literal>access</literal> (opcional - por defecto a <literal>property</"
-"literal>): La estrategia que Hibernate debe usar para acceder al valor de la "
-"propiedad."
+"<literal>access</literal> (opcional - por defecto es <literal>property</"
+"literal>): La estrategia que Hibernate utiliza para acceder al valor de la "
+"propiedad. "
 
 #. Tag: para
-#: basic_mapping.xml:1184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to <literal>undefined</"
 "literal>): a version property value that indicates that an instance is newly "
@@ -2573,15 +1902,14 @@
 "saved or loaded in a previous session. <literal>Undefined</literal> "
 "specifies that the identifier property value should be used."
 msgstr ""
-"<literal>unsaved-value</literal> (opcional - por defecto a "
-"<literal>undefined</literal>): Un valor de la propiedad de versi&#x00f3;n "
-"que indica que una instancia est&#x00e1; reci&#x00e9;n instanciada (sin "
-"guardar), distingui&#x00e9;ndola de instancias separadas que fueran "
-"guardadas o cargadas en una sesi&#x00f3;n previa. (<literal>undefined</"
-"literal> especifica que debe usarse el valor de la propiedad identificadora.)"
+"<literal>unsaved-value</literal> (opcional - por defecto es "
+"<literal>undefined</literal>): Un valor de la propiedad de versión que "
+"indica que una instancia se encuentra recién instanciada (sin guardar), "
+"distinguiéndola de las instancias separadas que se guardaron o se cargaron "
+"en una sesión previa. <literal>undefined</literal> especifica que se debe "
+"utilizar el valor de la propiedad identificadora."
 
 #. Tag: para
-#: basic_mapping.xml:1193
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2589,41 +1917,38 @@
 "database. See the discussion of <link linkend=\"mapping-generated"
 "\">generated properties</link> for more information."
 msgstr ""
-"UNTRANSLATED! <literal>generated</literal> (optional - defaults to "
-"<literal>never</literal>): Specifies that this version property value is "
-"actually generated by the database. See the discussion of <link linkend="
-"\"mapping-generated\">generated properties</link>."
+"<literal>generated</literal> (opcional - por defecto es <literal>never</"
+"literal>): Especifica que este valor de la propiedad de la versión es "
+"generado por la base de datos. Vea la discusión de <xref linkend=\"mapping-"
+"generated\" /> para obtener mayor información."
 
 #. Tag: para
-#: basic_mapping.xml:1200
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>insert</literal> (optional - defaults to <literal>true</literal>): "
 "specifies whether the version column should be included in SQL insert "
 "statements. It can be set to <literal>false</literal> if the database column "
 "is defined with a default value of <literal>0</literal>."
 msgstr ""
-"UNTRANSLATED! <literal>insert</literal> (optional - defaults to "
-"<literal>true</literal>): Specifies whether the version column should be "
-"included in SQL insert statements. May be set to <literal>false</literal> if "
-"and only if the database column is defined with a default value of "
-"<literal>0</literal>."
+"<literal>insert</literal> (opcional - por defectos es <literal>true</"
+"literal>): Especifica si la columna de la versión debe incluirse en las "
+"declaraciones de inserción SQL. Se puede configurar como <literal>false</"
+"literal> si la columna de la base de datos se define con un valor "
+"predeterminado de <literal>0</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:1210
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Version numbers can be of Hibernate type <literal>long</literal>, "
 "<literal>integer</literal>, <literal>short</literal>, <literal>timestamp</"
 "literal> or <literal>calendar</literal>."
 msgstr ""
-"Los n&#x00fa;meros de versi&#x00f3;n deben ser de tipo <literal>long</"
-"literal>, <literal>integer</literal>, <literal>short</literal>, "
-"<literal>timestamp</literal> o <literal>calendar</literal> de Hibernate."
+"Los números de versión pueden ser de tipo Hibernate <literal>long</literal>, "
+"<literal>integer</literal>, <literal>short</literal>, <literal>timestamp</"
+"literal> o <literal>calendar</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:1215
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A version or timestamp property should never be null for a detached "
 "instance. Hibernate will detect any instance with a null version or "
@@ -2633,24 +1958,22 @@
 "reattachment in Hibernate. It is especially useful for people using assigned "
 "identifiers or composite keys</emphasis>."
 msgstr ""
-"Una propiedad de versi&#x00f3;n o timestamp nunca debe ser nula para una "
-"instancia separada, de modo que Hibernate detectar&#x00e1; cualquier "
-"instancia con una versi&#x00f3;n o timestamp nulo como transitoria, sin "
-"importar qu&#x00e9; otras estrategias <literal>unsaved-value</literal> se "
-"hayan especificado. <emphasis>Declarar una propiedad de vers&#x00f3;n o "
-"timestamp nulable es una forma f&#x00e1;cil de evitar cualquier problema con "
-"la re-uni&#x00f3;n transitiva en Hibernate, especialmente &#x00fa;til para "
-"que usa identificadores asignados o claves compuestas!</emphasis>"
+"Una propiedad de versión o de sello de fecha nunca debe ser nula para una "
+"instancia separada. Hibernate detectará cualquier instancia con una versión "
+"o sello de fecha nulo como transitoria, sin importar qué otras estrategias "
+"<literal>unsaved-value</literal> se hayan especificado. <emphasis>El "
+"declarar una propiedad de versión o sello de fecha nulable es una forma "
+"fácil de evitar cualquier problema con la re-unión transitiva en Hibernate. "
+"Es especialmente útil para la gente que utiliza identificadores asignados o "
+"claves compuestas</emphasis>."
 
 #. Tag: title
-#: basic_mapping.xml:1226
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Timestamp (optional)"
-msgstr "timestamp (opcional)"
+msgstr "Timestamp (opcional)"
 
 #. Tag: para
-#: basic_mapping.xml:1228
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The optional <literal>&lt;timestamp&gt;</literal> element indicates that the "
 "table contains timestamped data. This provides an alternative to versioning. "
@@ -2658,47 +1981,22 @@
 "sometimes the application might use the timestamps in other ways."
 msgstr ""
 "El elemento opcional <literal>&lt;timestamp&gt;</literal> indica que la "
-"tabla contiene datos con sellos de tiempo. Esto esta concebido como una "
-"alternativa al versionado. Los timestamps (sellos de tiempo) son por su "
-"naturaleza una implementaci&#x00f3;n menos segura de bloqueo optimista. Sin "
-"embrago, a veces la aplicaci&#x00f3;n puede usar los timestamps en otras "
-"formas."
+"tabla contiene datos con sellos de fecha. Esto brinda una alternativa al "
+"versionado. Los sellos de tiempo (timestamps) son por naturaleza una "
+"implementación menos segura del bloqueo optimista. Sin embargo, a veces la "
+"aplicación puede usar los sellos de fecha de otras maneras."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1244
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<timestamp\n"
-"        column=\"timestamp_column\"\n"
-"        name=\"propertyName\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unsaved-value=\"null|undefined\"\n"
-"        source=\"vm|db\"\n"
-"        generated=\"never|always\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"/>]]>"
-msgstr ""
-"<![CDATA[<timestamp\n"
-"        column=\"timestamp_column\"\n"
-"        name=\"propertyName\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unsaved-value=\"null|undefined\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"/>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:1247
-#, fuzzy, no-c-format
-msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of a column holding the timestamp."
 msgstr ""
-"<literal>column</literal> (opcional - por defecto al nombre de la "
-"propiedad): El nombre de una columna que tiene el timestamp."
+"<literal>column</literal> (opcional - por defecto es el nombre de la "
+"propiedad): El nombre de una columna que tiene el sello de fecha. "
 
 #. Tag: para
-#: basic_mapping.xml:1253
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal>: the name of a JavaBeans style property of Java type "
 "<literal>Date</literal> or <literal>Timestamp</literal> of the persistent "
@@ -2706,11 +2004,10 @@
 msgstr ""
 "<literal>name</literal>: El nombre de una propiedad del estilo JavaBeans de "
 "tipo Java <literal>Date</literal> o <literal>Timestamp</literal> de la clase "
-"persistente."
+"persistente. "
 
 #. Tag: para
-#: basic_mapping.xml:1266
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to <literal>null</"
 "literal>): a version property value that indicates that an instance is newly "
@@ -2718,16 +2015,15 @@
 "saved or loaded in a previous session. <literal>Undefined</literal> "
 "specifies that the identifier property value should be used."
 msgstr ""
-"<literal>unsaved-value</literal> (opcional - por defecto a <literal>null</"
-"literal>): Un valor de propiedad de versi&#x00f3;n que indica que una "
-"instancia est&#x00e1; reci&#x00e9;n instanciada (sin guardar), "
-"distingui&#x00e9;ndola de instancias separadas que hayan sido guardadas o "
-"cargadas en una sesi&#x00f3;n previa. (<literal>undefined</literal> "
-"especifica que debe usarse el valor de la propiedad identificadora.)"
+"<literal>unsaved-value</literal> (opcional - por defecto es <literal>null</"
+"literal>): Un valor de propiedad de versión que indica que una instancia "
+"está recién instanciada (sin guardar), distinguiéndola de instancias "
+"separadas que hayan sido guardadas o cargadas en una sesión previa. "
+"<literal>Undefined</literal> especifica que debe utilizarse el valor de la "
+"propiedad identificadora."
 
 #. Tag: para
-#: basic_mapping.xml:1275
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>source</literal> (optional - defaults to <literal>vm</literal>): "
 "Where should Hibernate retrieve the timestamp value from? From the database, "
@@ -2738,17 +2034,17 @@
 "timestamp. Others may also be unsafe for usage in locking due to lack of "
 "precision (Oracle 8, for example)."
 msgstr ""
-"UNTRANSLATED! <literal>source</literal> (optional - defaults to <literal>vm</"
-"literal>): From where should Hibernate retrieve the timestamp value? From "
-"the database, or from the current JVM? Database-based timestamps incur an "
-"overhead because Hibernate must hit the database in order to determine the "
-"\"next value\", but will be safer for use in clustered environments. Note "
-"also, that not all <literal>Dialect</literal>s are known to support "
-"retrieving of the database's current timestamp, while others might be unsafe "
-"for usage in locking due to lack of precision (Oracle 8 for example)."
+"<literal>source</literal> (opcional - por defecto es <literal>vm</literal>): "
+"¿Desde dónde debe recuperar Hibernate el valor del sello de fecha? ¿Desde la "
+"base de datos o desde la MVJ actual? Los sellos de fecha con base en la base "
+"de datos provocan un gasto general debido a que Hibernate tiene que llegar "
+"hasta la base de datos para poder determinar el \"siguiente valor\". Es más "
+"seguro utilizarlo en entornos con clústers. No todos los <literal>Dialects</"
+"literal> soportan la recuperación del sello de fecha actual de la base de "
+"datos. Los otros pueden ser poco seguros para utilizarlos como bloqueo "
+"debido a la falta de precisión (por ejemplo, Oracle 8)."
 
 #. Tag: para
-#: basic_mapping.xml:1287
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2756,116 +2052,66 @@
 "generated by the database. See the discussion of <link linkend=\"mapping-"
 "generated\">generated properties</link> for more information."
 msgstr ""
-"UNTRANSLATED! <literal>generated</literal> (optional - defaults to "
-"<literal>never</literal>): Specifies that this timestamp property value is "
-"actually generated by the database. See the discussion of <link linkend="
-"\"mapping-generated\">generated properties</link>."
+"<literal>generated</literal> (opcional - por defecto es <literal>never</"
+"literal>): Especifica que este valor de la propiedad del sello de fecha en "
+"realidad es generado por la base de datos. Vea la discusión de <xref linkend="
+"\"mapping-generated\" /> para obtener mayor información."
 
 #. Tag: title
-#: basic_mapping.xml:1298 basic_mapping.xml:2890
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Nota"
 
 #. Tag: para
-#: basic_mapping.xml:1299
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>&lt;Timestamp&gt;</literal> is equivalent to <literal>&lt;version "
 "type=\"timestamp\"&gt;</literal>. And <literal>&lt;timestamp source=\"db"
 "\"&gt;</literal> is equivalent to <literal>&lt;version type=\"dbtimestamp"
 "\"&gt;</literal>"
 msgstr ""
-"Note that <literal>&lt;timestamp&gt;</literal> is equivalent to <literal>&lt;"
-"version type=\"timestamp\"&gt;</literal>."
+"<literal>&lt;Timestamp&gt;</literal> es equivalente a <literal>&lt;version "
+"type=\"timestamp\"&gt;</literal>. Y <literal>&lt;timestamp source=\"db\"&gt;"
+"</literal> es equivalente a <literal>&lt;version type=\"dbtimestamp\"&gt;</"
+"literal>."
 
 #. Tag: title
-#: basic_mapping.xml:1311
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Property"
-msgstr "property"
+msgstr "Propiedad"
 
 #. Tag: para
-#: basic_mapping.xml:1313
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;property&gt;</literal> element declares a persistent "
 "JavaBean style property of the class."
 msgstr ""
 "El elemento <literal>&lt;property&gt;</literal> declara una propiedad "
-"persistente estilo JavaBean de la clase."
+"persistente estilo JavaBean de la clase. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1335
-#, no-c-format
-msgid ""
-"<![CDATA[<property\n"
-"        name=\"propertyName\"\n"
-"        column=\"column_name\"\n"
-"        type=\"typename\"\n"
-"        update=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        formula=\"arbitrary SQL expression\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        lazy=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        not-null=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        generated=\"never|insert|always\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        index=\"index_name\"\n"
-"        unique_key=\"unique_key_id\"\n"
-"        length=\"L\"\n"
-"        precision=\"P\"\n"
-"        scale=\"S\"\n"
-"/>]]>"
-msgstr ""
-"<![CDATA[<property\n"
-"        name=\"propertyName\"\n"
-"        column=\"column_name\"\n"
-"        type=\"typename\"\n"
-"        update=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        formula=\"arbitrary SQL expression\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        lazy=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        not-null=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        index=\"index_name\"\n"
-"        unique_key=\"unique_key_id\"\n"
-"        length=\"L\"\n"
-"        precision=\"P\"\n"
-"        scale=\"S\"\n"
-"/>]]>"
-
 #. Tag: para
-#: basic_mapping.xml:1338
 #, no-c-format
 msgid ""
 "<literal>name</literal>: the name of the property, with an initial lowercase "
 "letter."
 msgstr ""
 "<literal>name</literal>: el nombre de la propiedad, con la letra inicial en "
-"min&#x00fa;sculas."
+"minúscula."
 
 #. Tag: para
-#: basic_mapping.xml:1344
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of the mapped database table column. This can also be specified by "
 "nested <literal>&lt;column&gt;</literal> element(s)."
 msgstr ""
-"<literal>column</literal> (opcional - por defecto al nombre de la "
-"propiedad): el nombre de la columna de tabla de base de datos mapeada. Esto "
-"puede tambi&#x00e9;n ser especificado con elemento(s) <literal>&lt;column&gt;"
-"</literal> anidado(s)."
+"<literal>column</literal> (opcional - por defecto es el nombre de la "
+"propiedad): El nombre de la columna de la tabla de base de datos mapeada. "
+"Esto se puede especificar también con los elemento(s) anidado(s) "
+"<literal>&lt;column&gt;</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:1356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update, insert</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that the mapped columns should be included in SQL "
@@ -2874,79 +2120,71 @@
 "whose value is initialized from some other property that maps to the same "
 "column(s), or by a trigger or other application."
 msgstr ""
-"<literal>update, insert</literal> (opcional - por defecto a <literal>true</"
-"literal>) : especifica que las columnas mapeadas deben ser inclu&#x00ed;das "
-"en las sentencias SQL <literal>UPDATE</literal> y/o <literal>INSERT</"
-"literal> . Especificando ambas a <literal>false</literal> permite una "
-"propiedad \"derivada\" cuyo valor es inicializado desde alguna otra "
-"propiedad que mapee a la misma columna (o columnas) o por un disparador u "
-"otra aplicaci&#x00f3;n."
+"<literal>update, insert</literal> (opcional - por defecto es <literal>true</"
+"literal>): Especifica que las columnas mapeadas deben ser incluídas en las "
+"declaraciones SQL <literal>UPDATE</literal> y/o <literal>INSERT</literal> . "
+"Especificando ambas como <literal>false</literal> permite una propiedad "
+"\"derivada\", cuyo valor se inicia desde alguna otra propiedad que mapee a "
+"la misma columna (o columnas) o por un disparador u otra aplicación."
 
 #. Tag: para
-#: basic_mapping.xml:1365
 #, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an SQL expression that defines the "
 "value for a <emphasis>computed</emphasis> property. Computed properties do "
 "not have a column mapping of their own."
 msgstr ""
-"<literal>formula</literal> (opcional): una expresi&#x00f3;n SQL que define "
-"el valor para una propiedad <emphasis>computada</emphasis>. Las propiedades "
+"<literal>formula</literal> (opcional): una expresión SQL que define el valor "
+"para una propiedad <emphasis>computada</emphasis>. Las propiedades "
 "computadas no tienen una columna mapeada propia."
 
 #. Tag: para
-#: basic_mapping.xml:1378
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>false</literal>): "
 "specifies that this property should be fetched lazily when the instance "
 "variable is first accessed. It requires build-time bytecode instrumentation."
 msgstr ""
-"<literal>lazy</literal> (opcional - por defecto a <literal>false</literal>): "
-"Especifica que esta propiedad debe ser tra&#x00ed;da perezosamente cuando la "
-"variable de instancia sea accedida por primera vez (requiere "
-"instrumentaci&#x00f3;n en tiempo de compilaci&#x00f3;n)."
+"<literal>lazy</literal> (opcional - por defecto es <literal>false</"
+"literal>): Especifica que se debe recuperar perezosamente esta propiedad "
+"cuando se acceda por primera vez la variable de instancia. Requiere "
+"instrumentación de código byte en tiempo de compilación."
 
 #. Tag: para
-#: basic_mapping.xml:1385
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): enables the DDL generation of a unique "
 "constraint for the columns. Also, allow this to be the target of a "
 "<literal>property-ref</literal>."
 msgstr ""
-"<literal>unique</literal> (opcional): Habilita la generaci&#x00f3; DDL de "
-"una restricci&#x00f3;n de unicidad para las columnas. Adem&#x00e1;s, permite "
-"que &#x00e9;sta sea un blanco objetivo de una <literal>property-ref</"
-"literal>."
+"<literal>unique</literal> (opcional): Activa la generación DDL de una "
+"restricción de unicidad para las columnas. Además, permite que ésta sea el "
+"objetivo de una <literal>property-ref</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:1392
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): enables the DDL generation of a "
 "nullability constraint for the columns."
 msgstr ""
-"<literal>not-null</literal> (opcional): Habilita la generaci&#x00f3; DDL de "
-"una restricci&#x00f3;n de nulabilidad para las columnas."
+"<literal>not-null</literal> (opcional): Activa la generación DDL de una "
+"restricción de nulabilidad para las columnas. "
 
 #. Tag: para
-#: basic_mapping.xml:1398 basic_mapping.xml:1581
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to this property do or do not require "
 "acquisition of the optimistic lock. In other words, it determines if a "
 "version increment should occur when this property is dirty."
 msgstr ""
-"<literal>optimistic-lock</literal> (opcional - por defecto a <literal>true</"
-"literal>): Especifica que las actualizaciones a esta propiedad requieran o "
-"no de la obtenci&#x000f3;n de un bloqueo optimista. En otras palabras, "
-"determina si debe ocurrir un incremento de versi&#x00f3;n cuando la "
-"propiedad este sucia (desactualizada)."
+"<literal>optimistic-lock</literal> (opcional - por defecto es <literal>true</"
+"literal>): Especifica que las actualizaciones a esta propiedad requieren o "
+"no de la obtención de un bloqueo optimista. En otras palabras, determina si "
+"debe ocurrir un incremento de versión cuando la propiedad se encuentre "
+"desactualizada."
 
 #. Tag: para
-#: basic_mapping.xml:1406
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2954,59 +2192,53 @@
 "database. See the discussion of <link linkend=\"mapping-generated"
 "\">generated properties</link> for more information."
 msgstr ""
-"UNTRANSLATED! <literal>generated</literal> (optional - defaults to "
-"<literal>never</literal>): Specifies that this property value is actually "
-"generated by the database. See the discussion of <link linkend=\"mapping-"
-"generated\">generated properties</link>."
+"<literal>generated</literal> (opcional - por defecto es <literal>never</"
+"literal>): Especifica que este valor de la propiedad es de hecho generado "
+"por la base de datos. Vea la discusión de <xref linkend=\"mapping-generated"
+"\" /> para obtener mayor información. "
 
 #. Tag: para
-#: basic_mapping.xml:1415
 #, no-c-format
 msgid "<emphasis>typename</emphasis> could be:"
-msgstr "<emphasis>typename</emphasis> puede ser:"
+msgstr "<emphasis>escribanombre</emphasis> puede ser:"
 
 #. Tag: para
-#: basic_mapping.xml:1421
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The name of a Hibernate basic type: <literal>integer, string, character, "
 "date, timestamp, float, binary, serializable, object, blob</literal> etc."
 msgstr ""
-"El nombre de un tipo b&#x00e1;sico Hibernate (por ejemplo, <literal>integer, "
-"string, character, date, timestamp, float, binary, serializable, object, "
-"blob</literal>)."
+"El nombre de un tipo básico de Hibernate: <literal>integer, string, "
+"character, date, timestamp, float, binary, serializable, object, blob</"
+"literal>, etc."
 
 #. Tag: para
-#: basic_mapping.xml:1427
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The name of a Java class with a default basic type: <literal>int, float, "
 "char, java.lang.String, java.util.Date, java.lang.Integer, java.sql.Clob</"
 "literal> etc."
 msgstr ""
-"El nombre de una clase Java de tipo b&#x00e1;sico (por ejemplo, "
-"<literal>int, float, char, java.lang.String, java.util.Date, java.lang."
-"Integer, java.sql.Clob</literal>)."
+"El nombre de una clase Java con un tipo básico predeterminado: <literal>int, "
+"float, char, java.lang.String, java.util.Date, java.lang.Integer, java.sql."
+"Clob</literal>, etc."
 
 #. Tag: para
-#: basic_mapping.xml:1433
 #, no-c-format
 msgid "The name of a serializable Java class."
 msgstr "El nombre de una clase Java serializable."
 
 #. Tag: para
-#: basic_mapping.xml:1438
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The class name of a custom type: <literal>com.illflow.type.MyCustomType</"
 "literal> etc."
 msgstr ""
-"El nombre de un tipo personalizado (por ejemplo, <literal>com.illflow.type."
-"MyCustomType</literal>)."
+"El nombre declase de un tipo personalizado: <literal>com.illflow.type."
+"MyCustomType</literal> etc."
 
 #. Tag: para
-#: basic_mapping.xml:1444
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you do not specify a type, Hibernate will use reflection upon the named "
 "property and guess the correct Hibernate type. Hibernate will attempt to "
@@ -3016,18 +2248,16 @@
 "DATE</literal> and <literal>Hibernate.TIMESTAMP</literal>, or to specify a "
 "custom type."
 msgstr ""
-"Si no especificas un tipo, Hibernate usar&#x00e1; reflecci&#x00f3;n sobre la "
-"propiedad mencionada para deducir el tipo Hibernate correcto. Hibernate "
-"intentar&#x00e1; interpretar el nombre de la clase de retorno del getter de "
-"la propiedad usando las reglas 2, 3 y 4 en ese orden. Sin embargo, esto no "
-"siempre suficiente. En ciertos casos, necesitar&#x00e1;s a&#x00fa;n el "
-"atributo <literal>type</literal>. (Por ejemplo, para distinguir entre "
-"<literal>Hibernate.DATE</literal> y <literal>Hibernate.TIMESTAMP</literal>, "
-"o especificar un tipo personalizado.)"
+"Si no especifica un tipo, Hibernate utilizará reflección sobre la propiedad "
+"mencionada para deducir el tipo Hibernate correcto. Hibernate intentará "
+"interpretar el nombre de la clase de retorno del getter de la propiedad "
+"utilizando las reglas 2, 3 y 4 en ese mismo orden. En algunos casos "
+"necesitará el atributo <literal>type</literal>. Por ejemplo, para distinguir "
+"entre <literal>Hibernate.DATE</literal> y <literal>Hibernate.TIMESTAMP</"
+"literal>, o especificar un tipo personalizado."
 
 #. Tag: para
-#: basic_mapping.xml:1454
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>access</literal> attribute allows you to control how Hibernate "
 "accesses the property at runtime. By default, Hibernate will call the "
@@ -3037,190 +2267,106 @@
 "a class that implements the interface <literal>org.hibernate.property."
 "PropertyAccessor</literal>."
 msgstr ""
-"El atributo <literal>access</literal> te deja controlar c&#x00f3;mo "
-"Hibernate acceder&#x00e1; a la propiedad en tiempo de ejecuci&#x00f3;n. Por "
-"defecto, Hibernate llamar&#x00e1; al par de getter/setter de la propiedad. "
-"Si especificas <literal>access=\"field\"</literal>, Hibernate se "
-"saltar&#x00e1; el par get/set y acceder&#x00e1; al campo directamente usando "
-"reflecci&#x00f3;n. Puedes especificar tu propia estrategia de acceso a la "
-"propiedad mencionando una clase que implemente la interface <literal>org."
-"hibernate.property.PropertyAccessor</literal>."
+"El atributo <literal>access</literal> le permite controlar el cómo Hibernate "
+"accederá a la propiedad en tiempo de ejecución. Por defecto, Hibernate "
+"llamará al par de getter/setter de la propiedad. Si usted especifica "
+"<literal>access=\"field\"</literal>, Hibernate se saltará el par get/set y "
+"accederá al campo directamente utilizando reflección. Puede especificar su "
+"propia estrategia de acceso a la propiedad mencionando una clase que "
+"implemente la interfaz <literal>org.hibernate.property.PropertyAccessor</"
+"literal>."
 
 #. Tag: para
-#: basic_mapping.xml:1463
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A powerful feature is derived properties. These properties are by definition "
 "read-only. The property value is computed at load time. You declare the "
 "computation as an SQL expression. This then translates to a <literal>SELECT</"
 "literal> clause subquery in the SQL query that loads an instance:"
 msgstr ""
-"Una aspecto especialmente poderoso son las propiedades derivadas. Estas "
-"propiedades son por definici&#x00f3;n de s&#x00f3;lo lectura, el valor de la "
-"propiedad es computado en tiempo de carga. Tu declaras la computaci&#x00f3;n "
-"como una expresi&#x00f3;n SQL, y &#x00e9;sta se traduce a cl&#x00e1;usula de "
-"subconsulta <literal>SELECT</literal> en la consulta SQL que cargue una "
-"instancia:"
+"Una funcionalidad especialmente poderosa son las propiedades derivadas. "
+"Estas propiedades son, por definición, de sólo lectura. El valor de la "
+"propiedad se computa en tiempo de carga. Usted declara la computación como "
+"una expresión SQL y ésta se traduce como una cláusula de subconsulta "
+"<literal>SELECT</literal> en la consulta SQL que carga una instancia:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1470
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"<property name=\"totalPrice\"\n"
-"    formula=\"( SELECT SUM (li.quantity*p.price) FROM LineItem li, Product "
-"p\n"
-"                WHERE li.productId = p.productId\n"
-"                AND li.customerId = customerId\n"
-"                AND li.orderNumber = orderNumber )\"/>]]>"
-msgstr ""
-"<![CDATA[\n"
-"<property name=\"totalPrice\"\n"
-"    formula=\"( SELECT SUM (li.quantity*p.price) FROM LineItem li, Product "
-"p\n"
-"                WHERE li.productId = p.productId\n"
-"                AND li.customerId = customerId\n"
-"                AND li.orderNumber = orderNumber )\"/>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:1472
-#, fuzzy, no-c-format
-msgid ""
 "You can reference the entity table by not declaring an alias on a particular "
 "column. This would be <literal>customerId</literal> in the given example. "
 "You can also use the nested <literal>&lt;formula&gt;</literal> mapping "
 "element if you do not want to use the attribute."
 msgstr ""
-"Observa que puedes referenciar la propia tabla de las entidades sin declarar "
-"un alias o una columna particular (<literal>customerId</literal> en el "
-"ejemplo dado). Observa adem&#x00e1;s que puedes usar el elemento anidado de "
-"mapeo <literal>&lt;formula&gt;</literal> si no te gusta usar el atributo."
+"Puede referenciar la tabla de las entidades sin declarar un alias o una "
+"columna particular. En el ejemplo dado sería <literal>customerId</literal>. "
+"También puede utilizar el elemento anidado de mapeo <literal>&lt;formula&gt;"
+"</literal> si no quiere utilizar el atributo."
 
 #. Tag: title
-#: basic_mapping.xml:1482
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Many-to-one"
-msgstr "many-to-one"
+msgstr "Many-to-one"
 
 #. Tag: para
-#: basic_mapping.xml:1484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An ordinary association to another persistent class is declared using a "
 "<literal>many-to-one</literal> element. The relational model is a many-to-"
 "one association; a foreign key in one table is referencing the primary key "
 "column(s) of the target table."
 msgstr ""
-"Una asociaci&#x00f3;n ordinaria a otra clase persistente se declara usando "
-"el elemento <literal>many-to-one</literal>. El modelo relacional es una "
-"asociaci&#x00f3;n muchos-a-uno: una clave for&#x00e1;nea en una tabla "
-"est&#x00e1; referenciando la columna (o columnas) de la clave primaria de la "
-"tabla objetivo."
+"Una asociación ordinaria a otra clase persistente se declara utilizando el "
+"elemento <literal>many-to-one</literal>. El modelo relacional es una "
+"asociación muchos-a-uno; una clave foránea en una tabla referencia la "
+"columna (o columnas) de la clave principal de la tabla destino."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1512
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one\n"
-"        name=\"propertyName\"\n"
-"        column=\"column_name\"\n"
-"        class=\"ClassName\"\n"
-"        cascade=\"cascade_style\"\n"
-"        fetch=\"join|select\"\n"
-"        update=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unique=\"true|false\"\n"
-"        not-null=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        lazy=\"proxy|no-proxy|false\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        formula=\"arbitrary SQL expression\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        embed-xml=\"true|false\"\n"
-"        index=\"index_name\"\n"
-"        unique_key=\"unique_key_id\"\n"
-"        foreign-key=\"foreign_key_name\"\n"
-"/>]]>"
-msgstr ""
-"<![CDATA[<many-to-one\n"
-"        name=\"propertyName\"\n"
-"        column=\"column_name\"\n"
-"        class=\"ClassName\"\n"
-"        cascade=\"cascade_style\"\n"
-"        fetch=\"join|select\"\n"
-"        update=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unique=\"true|false\"\n"
-"        not-null=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        lazy=\"true|proxy|false\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        formula=\"cualquier expresi&#x00f3;n SQL\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        embed-xml=\"true|false\"\n"
-"        index=\"index_name\"\n"
-"        unique_key=\"unique_key_id\"\n"
-"        foreign-key=\"foreign_key_name\"\n"
-"/>]]>"
-
 #. Tag: para
-#: basic_mapping.xml:1515 basic_mapping.xml:1696 basic_mapping.xml:1882
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>name</literal>: the name of the property."
-msgstr "<literal>name</literal>: El nombre de la propiedad."
+msgstr "<literal>name</literal>: El nombre de la propiedad. "
 
 #. Tag: para
-#: basic_mapping.xml:1520 basic_mapping.xml:2311
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>column</literal> (optional): the name of the foreign key column. "
 "This can also be specified by nested <literal>&lt;column&gt;</literal> "
 "element(s)."
 msgstr ""
-"<literal>column</literal> (opcional): El nombre de la columna clave "
-"for&#x00e1;nea. Tambi&#x00e9;n puede ser especificado por uno o varios "
-"elementos anidados <literal>&lt;column&gt;</literal>."
+"<literal>column</literal> (opcional): El nombre de la columna de la clave "
+"foránea. Esto también se puede especificar por medio de uno o varios "
+"elementos anidados <literal>&lt;column&gt;</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:1527 basic_mapping.xml:1701
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
 "determined by reflection): the name of the associated class."
 msgstr ""
-"<literal>class</literal> (opcional - por defecto al tipo de la propiedad "
-"determinado por reflecci&#x00f3;n): El nombre de la clase asociada."
+"<literal>class</literal> (opcional - por defecto es el tipo de la propiedad "
+"determinado por reflección): El nombre de la clase asociada. "
 
 #. Tag: para
-#: basic_mapping.xml:1533 basic_mapping.xml:1707
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional): specifies which operations should be "
 "cascaded from the parent object to the associated object."
 msgstr ""
-"<literal>cascade</literal> (opcional) especifica qu&#x00e9; operaciones "
-"deben ir en cascada desde el objeto padre al objeto asociado."
+"<literal>cascade</literal> (opcional) especifica qué operaciones deben ir en "
+"cascada desde el objeto padre hasta el objeto asociado. "
 
 #. Tag: para
-#: basic_mapping.xml:1539 basic_mapping.xml:1722
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional - defaults to <literal>select</literal>): "
 "chooses between outer-join fetching or sequential select fetching."
 msgstr ""
-"<literal>fetch</literal> (opcional - por defecto a 1<literal>select</"
-"literal>): Escoge entre recuperaci&#x00f3;n outer-join o por selecci&#x00f3;"
-"n secuencial."
+"<literal>fetch</literal> (opcional - por defecto es <literal>select</"
+"literal>): Escoge entre la recuperación de unión exterior (outer-join) o la "
+"recuperación por selección secuencial."
 
 #. Tag: para
-#: basic_mapping.xml:1545
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update, insert</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that the mapped columns should be included in SQL "
@@ -3229,55 +2375,49 @@
 "association whose value is initialized from another property that maps to "
 "the same column(s), or by a trigger or other application."
 msgstr ""
-"<literal>update, insert</literal> (opcional - por defecto a <literal>true</"
-"literal>) especifica que las columnas mapeadas deben ser inclu&#x00ed;das en "
-"las sentencias SQL <literal>UPDATE</literal> y/o <literal>INSERT</literal>. "
-"Establecer ambas a <literal>false</literal> permite una asociaci&#x00f3;n "
+"<literal>update, insert</literal> (opcional - por defecto es <literal>true</"
+"literal>) especifica que las columnas mapeadas deben ser incluídas en las "
+"declaraciones SQL <literal>UPDATE</literal> y/o <literal>INSERT</literal>. "
+"El establecer ambas como <literal>false</literal> permite una asociación "
 "puramente \"derivada\" cuyo valor es inicializado desde alguna otra "
-"propiedad que mapea a las misma columna (o columnas), o por un disparador, o "
-"por otra aplicaci&#x00f3;n."
+"propiedad que mapea a la misma columna (o columnas), por un disparador o por "
+"otra aplicación."
 
 #. Tag: para
-#: basic_mapping.xml:1554
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): the name of a property of the "
 "associated class that is joined to this foreign key. If not specified, the "
 "primary key of the associated class is used."
 msgstr ""
-"<literal>property-ref</literal>: (opcional) El nombre de la propiedad de la "
-"clase asociada que est&#x00e1; unida a la clave for&#x00e1;nea. Si no se "
-"especifica, se usa la clave primaria de la clase asociada."
+"<literal>property-ref</literal>: (opcional): El nombre de una propiedad de "
+"la clase asociada que se encuentra unida a su llave foránea. Si no se "
+"especifica, se utiliza la llave principal de la clase asociada."
 
 #. Tag: para
-#: basic_mapping.xml:1567
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): enables the DDL generation of a unique "
 "constraint for the foreign-key column. By allowing this to be the target of "
 "a <literal>property-ref</literal>, you can make the association multiplicity "
 "one-to-one."
 msgstr ""
-"<literal>unique</literal> (opcional): Habilita la generaci&#x00f3;n DDL de "
-"una restricci&#x00f3;n de unicidad para la columna de clave for&#x00e1;nea. "
-"Adem&#x00e1;s, permite que &#x00e9;sta sea el objetivo de una "
-"<literal>property-ref</literal>. Esto hace efectivamente la multiplicidad de "
-"la asociaci&#x00f3;n uno a uno."
+"<literal>unique</literal> (opcional): Activa la generación DDL de una "
+"restricción de unicidad para la columna de clave foránea. Además, permite "
+"que éste sea el objetivo de una <literal>property-ref</literal>. puede hacer "
+"que la asociación sea de multiplicidad uno-a-uno."
 
 #. Tag: para
-#: basic_mapping.xml:1575
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): enables the DDL generation of a "
 "nullability constraint for the foreign key columns."
 msgstr ""
-"<literal>not-null</literal> (opcional): Habilita la generaci&#x00f3;n DDL de "
-"una restricci&#x00f3;n de nulabilidad para las columnas de clave for&#x00e1;"
-"nea."
+"<literal>not-null</literal> (opcional): Activa la generación DDL de una "
+"restricción de nulabilidad para las columnas de clave foránea. "
 
 #. Tag: para
-#: basic_mapping.xml:1589
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>proxy</literal>): "
 "by default, single point associations are proxied. <literal>lazy=\"no-proxy"
@@ -3286,51 +2426,47 @@
 "instrumentation. <literal>lazy=\"false\"</literal> specifies that the "
 "association will always be eagerly fetched."
 msgstr ""
-"<literal>lazy</literal> (opcional - por defecto a <literal>proxy</literal>): "
-"Por defecto, las asociaciones de punto &#x00fa;nico van con proxies. "
-"<literal>lazy=\"true\"</literal> especifica que esta propiedad debe ser "
-"tra&#x00ed;da perezosamente cuando la variable de instancia sea accedida por "
-"primera vez (requiere instrumentaci&#x00f3;n del bytecode en tiempo de "
-"compilaci&#x00f3;n). <literal>lazy=\"false\"</literal> especifica que la "
-"asociaci&#x00f3;n siempre ser&#x00e1; recuperada tempranamente."
+"<literal>lazy</literal> (opcional - por defecto es <literal>proxy</"
+"literal>): Por defecto, las asociaciones de punto único van con proxies. "
+"<literal>lazy=\"no-proxy\"</literal> especifica que esta propiedad debe ser "
+"recuperada perezosamente cuando se acceda por primera vez a la variable de "
+"instancia. Requiere instrumentación del código byte en tiempo de "
+"compilación. <literal>lazy=\"false\"</literal> especifica que la asociación "
+"siempre será recuperada tempranamente."
 
 #. Tag: para
-#: basic_mapping.xml:1599
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-found</literal> (optional - defaults to <literal>exception</"
 "literal>): specifies how foreign keys that reference missing rows will be "
 "handled. <literal>ignore</literal> will treat a missing row as a null "
 "association."
 msgstr ""
-"<literal>not-found</literal> (opcional - por defecto a <literal>exception</"
-"literal>): Especifica c&#x00f3;mo deben manejarse las claves for&#x00e1;neas "
-"que referencien filas inexistentes: <literal>ignore</literal> tratar&#x00e1; "
-"una fila perdida como una asociaci&#x00f3;n nula."
+"<literal>not-found</literal> (opcional - por defecto es <literal>exception</"
+"literal>): Especifica cómo se manejarán las claves foráneas que referencian "
+"las filas que hacen falta. <literal>ignore</literal> tratará una fila "
+"perdida como una asociación nula."
 
 #. Tag: para
-#: basic_mapping.xml:1606 basic_mapping.xml:1760
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>entity-name</literal> (optional): the entity name of the associated "
 "class."
 msgstr ""
 "<literal>entity-name</literal> (opcional): El nombre de entidad de la clase "
-"asociada."
+"asociada. "
 
 #. Tag: para
-#: basic_mapping.xml:1611
 #, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an SQL expression that defines the "
 "value for a <emphasis>computed</emphasis> foreign key."
 msgstr ""
-"<literal>formula</literal> (opcional): una expresi&#x00f3;n SQL que define "
-"el valor para una clave for&#x00e1;nea <emphasis>computada</emphasis>."
+"<literal>formula</literal> (opcional): una expresión SQL que define el valor "
+"para una clave foránea <emphasis>computada</emphasis>."
 
 #. Tag: para
-#: basic_mapping.xml:1619
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Setting a value of the <literal>cascade</literal> attribute to any "
 "meaningful value other than <literal>none</literal> will propagate certain "
@@ -3340,44 +2476,33 @@
 "second, special values: <literal>delete-orphan</literal>; and third,"
 "<literal>all</literal> comma-separated combinations of operation names: "
 "<literal>cascade=\"persist,merge,evict\"</literal> or <literal>cascade=\"all,"
-"delete-orphan\"</literal>. See <xref linkend=\"objectstate-transitive\"/> "
+"delete-orphan\"</literal>. See <xref linkend=\"objectstate-transitive\" /> "
 "for a full explanation. Note that single valued, many-to-one and one-to-one, "
 "associations do not support orphan delete."
 msgstr ""
-"Establecer el valor del atributo <literal>cascade</literal> a cualquier "
-"valor significativo distinto de <literal>none</literal> propagar&#x00e1; "
-"ciertas operaciones al objeto asociado. Los valores significativos son los "
-"nombres de las operaciones b&#x00e1;sicas de Hibernate, <literal>persist, "
-"merge, delete, save-update, evict, replicate, lock, refresh</literal>, "
-"as&#x00ed; como los valores especiales <literal>delete-orphan</literal> y "
-"<literal>all</literal> y combinaciones de operaciones separadas por coma, "
-"por ejemplo, <literal>cascade=\"persist,merge,evict\"</literal> o "
-"<literal>cascade=\"all,delete-orphan\"</literal>. Para una explicaci&#x00f3;"
-"n completa, ver <xref linkend=\"objectstate-transitive\"/>."
+"Establecer el valor del atributo <literal>cascade</literal> con cualquier "
+"valor significativo diferente de <literal>none</literal> propagará ciertas "
+"operaciones al objeto asociado. Los valores significativos están divididos "
+"en tres categorías. Primero, las operaciones básicas, las cuales incluyen: "
+"<literal>persist, merge, delete, save-update, evict, replicate, lock y "
+"refresh</literal>; segundo, los valores especiales <literal>delete-orphan</"
+"literal> y tercero, <literal>all</literal> y las combinaciones de "
+"operaciones separadas por comas: <literal>cascade=\"persist,merge,evict\"</"
+"literal> o <literal>cascade=\"all,delete-orphan\"</literal>. Consulte <xref "
+"linkend=\"objectstate-transitive\" /> y allí encontrará una explicación "
+"completa. Observe que las asociaciones con valores únicos, asociaciones "
+"muchos-a-uno y uno-a-uno no soportan el borrado de huérfanos."
 
 #. Tag: para
-#: basic_mapping.xml:1632
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Here is an example of a typical <literal>many-to-one</literal> declaration:"
 msgstr ""
-"Una declaraci&#x00f3;n t&#x00ed;pica <literal>muchos-a-uno</literal> se "
-"parece a esto:"
+"Este es un ejemplo de una declaración típica <literal>muchos-a-uno</literal>:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1636
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"product\" class=\"Product\" column=\"PRODUCT_ID"
-"\"/>]]>"
-msgstr ""
-"<![CDATA[<many-to-one name=\"product\" class=\"Product\" column=\"PRODUCT_ID"
-"\"/>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:1638
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>property-ref</literal> attribute should only be used for "
 "mapping legacy data where a foreign key refers to a unique key of the "
 "associated table other than the primary key. This is a complicated and "
@@ -3386,133 +2511,61 @@
 "<literal>unique</literal> attribute controls Hibernate's DDL generation with "
 "the SchemaExport tool."
 msgstr ""
-"El atributo <literal>property-ref</literal> debe ser usado solamente para el "
-"mapeo de datos heredados donde una clave for&#x00e1;nea referencia una clave "
-"&#x00fa;nica de la tabla asociada, distinta de la clave primaria. Este es un "
-"modelo relacional feo. Por ejemplo, sup&#x00f3;n que la clase "
-"<literal>Product</literal> tuviera un n&#x00fa;mero &#x00fa;nico serial que "
-"no es la clave primaria. (El atributo <literal>unique</literal> controla la "
-"generaci&#x00f3;n de DDL con la herramienta SchemaExport.)"
+"El atributo <literal>property-ref</literal> se debe utilizar sólamente para "
+"el mapeo de datos heredados donde una clave foránea referencia una clave "
+"única de la tabla asociada, distinta de la clave principal. Este es un "
+"modelo relacional complicado y confuso. Por ejemplo, si la clase "
+"<literal>Product</literal> tuviera un número único serial que no es la clave "
+"principal, el atributo <literal>unique</literal> controla la generación de "
+"DDL de Hibernate con la herramienta SchemaExport."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1647
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"serialNumber\" unique=\"true\" type=\"string\" "
-"column=\"SERIAL_NUMBER\"/>]]>"
-msgstr ""
-"<![CDATA[<property name=\"serialNumber\" unique=\"true\" type=\"string\" "
-"column=\"SERIAL_NUMBER\"/>]]>"
-
 #. Tag: para
-#: basic_mapping.xml:1649
 #, no-c-format
 msgid "Then the mapping for <literal>OrderItem</literal> might use:"
-msgstr ""
-"Entonces el mapeo para <literal>OrderItem</literal> deber&#x00ed;a usar:"
+msgstr "Entonces el mapeo para <literal>OrderItem</literal> puede utilizar:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1653
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"product\" property-ref=\"serialNumber\" column="
-"\"PRODUCT_SERIAL_NUMBER\"/>]]>"
-msgstr ""
-"<![CDATA[<many-to-one name=\"product\" property-ref=\"serialNumber\" column="
-"\"PRODUCT_SERIAL_NUMBER\"/>]]>"
-
 #. Tag: para
-#: basic_mapping.xml:1655
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This is not encouraged, however."
-msgstr "Sin embargo, esto no esta ciertamente alentado."
+msgstr "Sin embargo, esto ciertamente no se aconseja. "
 
 #. Tag: para
-#: basic_mapping.xml:1659
 #, no-c-format
 msgid ""
 "If the referenced unique key comprises multiple properties of the associated "
 "entity, you should map the referenced properties inside a named <literal>&lt;"
 "properties&gt;</literal> element."
 msgstr ""
-"Si la clave &#x00fa;nica referenciada abarca m&#x00fa;ltiples propiedades de "
-"la entidad asociada, debes mapear las propiedades dentro de un elemento "
+"Si la clave única referenciada abarca múltiples propiedades de la entidad "
+"asociada, debe mapear las propiedades dentro de un elemento nombrado "
 "<literal>&lt;properties&gt;</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:1664
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the referenced unique key is the property of a component, you can specify "
 "a property path:"
-msgstr "UNTRANSLATED!"
-
-#. Tag: programlisting
-#: basic_mapping.xml:1668
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"owner\" property-ref=\"identity.ssn\" column="
-"\"OWNER_SSN\"/>]]>"
 msgstr ""
-"<![CDATA[<many-to-one name=\"owner\" property-ref=\"identity.ssn\" column="
-"\"OWNER_SSN\"/>]]>"
+"Si la clave única referenciada es propiedad de un componente, usted puede "
+"especificar una ruta de propiedad: "
 
 #. Tag: title
-#: basic_mapping.xml:1673
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "One-to-one"
-msgstr "one-to-one"
+msgstr "One-to-one"
 
 #. Tag: para
-#: basic_mapping.xml:1675
 #, no-c-format
 msgid ""
 "A one-to-one association to another persistent class is declared using a "
 "<literal>one-to-one</literal> element."
 msgstr ""
-"Una asociaci&#x00f3;n uno-a-uno a otra clase persistente se declara usando "
-"un elemento <literal>one-to-one</literal>."
+"Una asociación uno-a-uno (one-to-one) a otra clase persistente se declara "
+"utilizando un elemento <literal>one-to-one</literal>."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1693
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<one-to-one\n"
-"        name=\"propertyName\"\n"
-"        class=\"ClassName\"\n"
-"        cascade=\"cascade_style\"\n"
-"        constrained=\"true|false\"\n"
-"        fetch=\"join|select\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        formula=\"any SQL expression\"\n"
-"        lazy=\"proxy|no-proxy|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        embed-xml=\"true|false\"\n"
-"        foreign-key=\"foreign_key_name\"\n"
-"/>]]>"
-msgstr ""
-"<![CDATA[<one-to-one\n"
-"        name=\"propertyName\"\n"
-"        class=\"ClassName\"\n"
-"        cascade=\"cascade_style\"\n"
-"        constrained=\"true|false\"\n"
-"        fetch=\"join|select\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        formula=\"cualquier expresi&#x00f3;n SQL\"\n"
-"        lazy=\"true|proxy|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        embed-xml=\"true|false\"\n"
-"        foreign-key=\"foreign_key_name\"\n"
-"/>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:1713
-#, fuzzy, no-c-format
-msgid ""
 "<literal>constrained</literal> (optional): specifies that a foreign key "
 "constraint on the primary key of the mapped table and references the table "
 "of the associated class. This option affects the order in which <literal>save"
@@ -3520,29 +2573,26 @@
 "whether the association can be proxied. It is also used by the schema export "
 "tool."
 msgstr ""
-"<literal>constrained</literal> (opcional) especifica que una "
-"restricci&#x00f3;n de clave for&#x00e1;nea de la tabla mapeada referencia a "
-"la tabla de la clase asociada. Esta opci&#x00f3;n afecta el orden en que van "
-"en cascada <literal>save()</literal> y <literal>delete()</literal>, y "
-"determina cu&#x00e1;ndo la asociaci&#x00f3;n pueden ser virtualizados por "
-"proxies (es tambi&#x00e9;n usado por la herramienta de exportaci&#x00f3;n de "
-"esquemas)."
+"<literal>constrained</literal> (opcional): especifica que una restricción de "
+"clave foránea en la clave principal de la tabla mapeada referencia la tabla "
+"de la clase asociada. Esta opción afecta el orden en que van en la cascada "
+"<literal>save()</literal> y <literal>delete()</literal> y determina si la "
+"asociación puede ser virtualizada por proxies. La herramienta de exportación "
+"de esquemas también lo utiliza."
 
 #. Tag: para
-#: basic_mapping.xml:1728
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): the name of a property of the "
 "associated class that is joined to the primary key of this class. If not "
 "specified, the primary key of the associated class is used."
 msgstr ""
-"<literal>property-ref</literal>: (opcional) El nombre de una propiedad de la "
-"clase asociada que est&#x00e9; unida a la clave primaria de esta clase. Si "
-"no se especifica, se usa la clave primaria de la clase asociada."
+"<literal>property-ref</literal> (opcional): El nombre de una propiedad de la "
+"clase asociada que esté unida a la clave principal de esta clase. Si no se "
+"especifica, se utiliza la clave principal de la clase asociada."
 
 #. Tag: para
-#: basic_mapping.xml:1741
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): almost all one-to-one associations "
 "map to the primary key of the owning entity. If this is not the case, you "
@@ -3551,14 +2601,13 @@
 "example."
 msgstr ""
 "<literal>formula</literal> (opcional): Casi todas las asociaciones uno-a-uno "
-"mapean a la clave primaria de la entidad propietaria. En el raro caso en que "
-"este no sea el caso, puedes especificar alguna otra columna, o columnas, o "
-"expresi&#x00f3;n para unir usando una f&#x00f3;rmula SQL. (Para un ejemplo "
-"ver <literal>org.hibernate.test.onetooneformula</literal>)."
+"mapean a la clave principal de la entidad propietaria. Si este no es el "
+"caso, puede especificar otra columna, o columnas, o una expresión para unir "
+"utilizando una fórmula SQL. Para un obtener un ejemplo consulte <literal>org."
+"hibernate.test.onetooneformula</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:1749
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>proxy</literal>): "
 "by default, single point associations are proxied. <literal>lazy=\"no-proxy"
@@ -3569,200 +2618,106 @@
 "<literal>constrained=\"false\"</literal>, proxying is impossible and "
 "Hibernate will eagerly fetch the association</emphasis>."
 msgstr ""
-"<literal>lazy</literal> (opcional - por defecto a <literal>proxy</literal>): "
-"Por defecto, las asociaciones de punto &#x00fa;nico van con proxies. "
-"<literal>lazy=\"true\"</literal> especifica que esta propiedad debe ser "
-"tra&#x00ed;da perezosamente cuando la variable de instancia sea accedida por "
-"primera vez (requiere instrumentaci&#x00f3;n del bytecode en tiempo de "
-"compilaci&#x00f3;n). <literal>lazy=\"false\"</literal> especifica que la "
-"asociaci&#x00f3;n siempre ser&#x00e1; recuperada tempranamente. "
-"<emphasis>Observa que si <literal>constrained=\"false\"</literal>, la "
-"aplicaci&#x00f3;n de proxies es imposible e Hibernate traer&#x00e1; temprano "
-"la asociaci&#x00f3;n!</emphasis>"
+"<literal>lazy</literal> (opcional - por defecto es <literal>proxy</"
+"literal>): Por defecto, las asociaciones de punto único van con proxies. "
+"<literal>lazy=\"no-proxy\"</literal> especifica que esta propiedad debe ser "
+"traída perezosamente cuando se acceda por primera vez la variable de "
+"instancia. Requiere instrumentación del código byte en tiempo de "
+"compilación. <literal>lazy=\"false\"</literal> especifica que la asociación "
+"siempre será recuperada tempranamente. <emphasis>Observe que si "
+"<literal>constrained=\"false\"</literal>, la aplicación de proxies es "
+"imposible e Hibernate recuperará tempranamente la asociación</emphasis>."
 
 #. Tag: para
-#: basic_mapping.xml:1767
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "There are two varieties of one-to-one associations:"
-msgstr "Hay dos variedades de asociaciones uno-a-uno:"
+msgstr "Existen dos variedades de asociaciones uno-a-uno: "
 
 #. Tag: para
-#: basic_mapping.xml:1771
 #, no-c-format
 msgid "primary key associations"
 msgstr "asociaciones de clave primaria"
 
 #. Tag: para
-#: basic_mapping.xml:1774
 #, no-c-format
 msgid "unique foreign key associations"
-msgstr "asociaciones de clave for&#x00e1;neas &#x00fa;nica"
+msgstr "asociaciones de clave foránea única"
 
 #. Tag: para
-#: basic_mapping.xml:1779
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Primary key associations do not need an extra table column. If two rows are "
 "related by the association, then the two table rows share the same primary "
 "key value. To relate two objects by a primary key association, ensure that "
 "they are assigned the same identifier value."
 msgstr ""
-"Las asociaciones de clave primaria no necesitan una columna de tabla extra; "
-"si dos filas est&#x00e1;n relacionadas por la asociaci&#x00f3;n entonces las "
-"dos filas de tablas comparten el mismo valor de clave primaria. Por lo "
-"tanto, si quieres que dos objetos est&#x00e9;n relacionados por una "
-"asociaci&#x00f3;n de clave primaria, debes asegurarte que se les asigne el "
-"mismo valor de identificador!"
+"Las asociaciones de claves principales no necesitan una columna extra de la "
+"tabla. Si dos filas están relacionadas por la asociación entonces las dos "
+"filas de tablas comparten el mismo valor de clave principal. Para que dos "
+"objetos estén relacionados por una asociación de clave principal, asegúrese "
+"de que se les asigne el mismo valor de identificador."
 
 #. Tag: para
-#: basic_mapping.xml:1786
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For a primary key association, add the following mappings to "
 "<literal>Employee</literal> and <literal>Person</literal> respectively:"
 msgstr ""
-"Para una asociaci&#x00f3;n de clave primaria, a&#x00f1;ade los siguientes "
-"mapeos a <literal>Employee</literal> y <literal>Person</literal>, "
-"respectivamente."
+"Para una asociación de clave principal, agregue los siguientes mapeos a "
+"<literal>Employee</literal> y <literal>Person</literal> respectivamente:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1791
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[<one-to-one name=\"person\" class=\"Person\"/>]]>"
-msgstr "<![CDATA[<one-to-one name=\"person\" class=\"Person\"/>]]>"
-
-#. Tag: programlisting
-#: basic_mapping.xml:1792
-#, no-c-format
 msgid ""
-"<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" constrained=\"true"
-"\"/>]]>"
-msgstr ""
-"<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" constrained=\"true"
-"\"/>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:1794
-#, fuzzy, no-c-format
-msgid ""
 "Ensure that the primary keys of the related rows in the PERSON and EMPLOYEE "
 "tables are equal. You use a special Hibernate identifier generation strategy "
 "called <literal>foreign</literal>:"
 msgstr ""
-"Ahora debemos asegurarnos que las claves primarias de las filas relacionadas "
-"en las tablas PERSON y EMPLOYEE sean iguales. Usamos una estrategia especial "
-"de generaci&#x00f3;n de identificador de Hibernate llamada <literal>foreign</"
+"Asegúrese de que las claves principales de las filas relacionadas en las "
+"tablas PERSON y EMPLOYEE sean iguales. Utilizamos una estrategia especial de "
+"generación de identificador de Hibernate denominada <literal>foreign</"
 "literal>:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1800
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"person\" table=\"PERSON\">\n"
-"    <id name=\"id\" column=\"PERSON_ID\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">employee</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    ...\n"
-"    <one-to-one name=\"employee\"\n"
-"        class=\"Employee\"\n"
-"        constrained=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"person\" table=\"PERSON\">\n"
-"    <id name=\"id\" column=\"PERSON_ID\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">employee</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    ...\n"
-"    <one-to-one name=\"employee\"\n"
-"        class=\"Employee\"\n"
-"        constrained=\"true\"/>\n"
-"</class>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:1802
-#, fuzzy, no-c-format
-msgid ""
 "A newly saved instance of <literal>Person</literal> is assigned the same "
 "primary key value as the <literal>Employee</literal> instance referred with "
 "the <literal>employee</literal> property of that <literal>Person</literal>."
 msgstr ""
-"A una instancia reci&#x00e9;n salvada de <literal>Person</literal> se le "
-"asigna entonces el mismo valor de clave primaria con que la instancia "
+"A una instancia recién guardada de <literal>Person</literal> se le asigna el "
+"mismo valor de clave principal que se le asignó a la instancia "
 "<literal>Employee</literal> referida por la propiedad <literal>employee</"
-"literal> de esta <literal>Person</literal>."
+"literal> de esa <literal>Person</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:1808
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, a foreign key with a unique constraint, from "
 "<literal>Employee</literal> to <literal>Person</literal>, can be expressed "
 "as:"
 msgstr ""
-"Alternativamente, una clave for&#x00e1;nea con una restricci&#x00f3;n de "
-"unicidad, desde <literal>Employee</literal> a <literal>Person</literal>, "
-"puede ser expresada como:"
+"Opcionalmente, una clave foránea con una restricción de unicidad, desde "
+"<literal>Employee</literal> a <literal>Person</literal>, se puede expresar "
+"como:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1813
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"person\" class=\"Person\" column=\"PERSON_ID\" "
-"unique=\"true\"/>]]>"
-msgstr ""
-"<![CDATA[<many-to-one name=\"person\" class=\"Person\" column=\"PERSON_ID\" "
-"unique=\"true\"/>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:1815
-#, fuzzy, no-c-format
-msgid ""
 "This association can be made bidirectional by adding the following to the "
 "<literal>Person</literal> mapping:"
 msgstr ""
-"Y esta asociaci&#x00f3;n puede hacerse bidireccional agregando lo siguiente "
-"al mapeo de <literal>Person</literal> :"
+"Esta asociación puede hacerse bidireccional agregando lo siguiente al mapeo "
+"de <literal>Person</literal>:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1820
-#, no-c-format
-msgid ""
-"<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" property-ref="
-"\"person\"/>]]>"
-msgstr ""
-"<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" property-ref="
-"\"person\"/>]]>"
-
 #. Tag: title
-#: basic_mapping.xml:1825
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Natural-id"
-msgstr "natural-id"
+msgstr "Natural-id"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1827
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<natural-id mutable=\"true|false\"/>\n"
-"        <property ... />\n"
-"        <many-to-one ... />\n"
-"        ......\n"
-"</natural-id>]]>"
-msgstr ""
-"<![CDATA[<natural-id mutable=\"true|false\"/>\n"
-"        <property ... />\n"
-"        <many-to-one ... />\n"
-"        ......\n"
-"</natural-id>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:1829
-#, fuzzy, no-c-format
-msgid ""
 "Although we recommend the use of surrogate keys as primary keys, you should "
 "try to identify natural keys for all entities. A natural key is a property "
 "or combination of properties that is unique and non-null. It is also "
@@ -3771,58 +2726,52 @@
 "unique key and nullability constraints and, as a result, your mapping will "
 "be more self-documenting."
 msgstr ""
-"Aunque recomendamos el uso de claves delegadas como claves primarias, "
-"todav&#x00ed;a debes intentar identificar claves naturales para todas las "
-"entidades. Una clave natural es una propiedad o combinaci&#x00f3;n de "
-"propiedades que es &#x00fa;nica y no nula. Si adem&#x00e1;s es inmutable, "
-"mejor a&#x00fa;n. Mapea las propiedades de la clave natural dentro del "
-"elemento <literal>&lt;natural-id&gt;</literal>. Hibernate generar&#x00e1; "
-"las restricciones de clave &#x00fa;nica y nulabilidad necesarias, y tu mapeo "
-"ser&#x00e1; m&#x00e1;s auto-documentado."
+"Aunque recomendamos el uso de claves delegadas como claves principales, debe "
+"tratar de identificar claves naturales para todas las entidades. Una clave "
+"natural es una propiedad o combinación de propiedades que es única y no "
+"nula. También es inmutable. Mapea las propiedades de la clave natural dentro "
+"del elemento <literal>&lt;natural-id&gt;</literal>. Hibernate generará las "
+"restricciones de nulabilidad y de clave única necesarias y su mapeo será más "
+"auto-documentado."
 
 #. Tag: para
-#: basic_mapping.xml:1838
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you implement <literal>equals()</literal> and "
 "<literal>hashCode()</literal> to compare the natural key properties of the "
 "entity."
 msgstr ""
-"Recomendamos fuertemente que implementes <literal>equals()</literal> y "
+"Le recomendamos bastante que implemente <literal>equals()</literal> y "
 "<literal>hashCode()</literal> para comparar las propiedades de clave natural "
-"de la entidad."
+"de la entidad. "
 
 #. Tag: para
-#: basic_mapping.xml:1843
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This mapping is not intended for use with entities that have natural primary "
 "keys."
 msgstr ""
-"Este mapeo no est&#x00e1; concebido para usar con entidades con claves "
-"primarias naturales."
+"Este mapeo no está concebido para la utilización con entidades que tienen "
+"claves principales naturales."
 
 #. Tag: para
-#: basic_mapping.xml:1849
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>false</"
 "literal>): by default, natural identifier properties are assumed to be "
 "immutable (constant)."
 msgstr ""
-"<literal>mutable</literal> (opcional, por defecto a <literal>false</"
+"<literal>mutable</literal> (opcional - por defecto es <literal>false</"
 "literal>): Por defecto, se asume que las propiedades de identificadores "
 "naturales son inmutables (constantes)."
 
 #. Tag: title
-#: basic_mapping.xml:1859
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Component and dynamic-component"
-msgstr "component, dynamic-component"
+msgstr "Componente y componente dinámico"
 
 #. Tag: para
-#: basic_mapping.xml:1861
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element maps properties of a child "
 "object to columns of the table of a parent class. Components can, in turn, "
@@ -3830,131 +2779,83 @@
 "\" examples below:"
 msgstr ""
 "El elemento <literal>&lt;component&gt;</literal> mapea propiedades de un "
-"objeto hijo a columnas de la tabla de la clase padre. Los componentes pueden "
-"a su vez declarar sus propias propiedades, componentes o colecciones. Ver "
-"debajo \"Componentes\"."
+"objeto hijo a columnas de la tabla de la clase padre. Los componentes "
+"pueden, a su vez, declarar sus propias propiedades, componentes o "
+"colecciones. Vea a continuación los \"componentes\":"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1879
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<component\n"
-"        name=\"propertyName\"\n"
-"        class=\"className\"\n"
-"        insert=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        lazy=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        node=\"element-name|.\"\n"
-">\n"
-"\n"
-"        <property ...../>\n"
-"        <many-to-one .... />\n"
-"        ........\n"
-"</component>]]>"
-msgstr ""
-"<![CDATA[<component \n"
-"        name=\"propertyName\" \n"
-"        class=\"className\"\n"
-"        insert=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        lazy=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        node=\"element-name|.\"\n"
-">\n"
-"        \n"
-"        <property ...../>\n"
-"        <many-to-one .... />\n"
-"        ........\n"
-"</component>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:1887
-#, fuzzy, no-c-format
-msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
 "determined by reflection): the name of the component (child) class."
 msgstr ""
-"<literal>class</literal> (opcional - por defecto al tipo de la propiedad "
-"determinado por reflecci&#x00f3;n): El nombre de la clase del componente "
-"(hijo)."
+"<literal>class</literal> (opcional - por defecto es el tipo de la propiedad "
+"determinado por reflección): El nombre de la clase del componente (hijo). "
 
 #. Tag: para
-#: basic_mapping.xml:1893 basic_mapping.xml:1982
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>insert</literal>: do the mapped columns appear in SQL "
 "<literal>INSERTs</literal>?"
 msgstr ""
-"<literal>insert</literal>: Aparecen las columnas mapeadas en "
-"<literal>INSERT</literal>s SQL?"
+"<literal>insert</literal>: ¿Las columnas mapeadas aparacen en "
+"<literal>INSERTs</literal> SQL? "
 
 #. Tag: para
-#: basic_mapping.xml:1899 basic_mapping.xml:1988
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update</literal>: do the mapped columns appear in SQL "
 "<literal>UPDATEs</literal>?"
 msgstr ""
-"<literal>update</literal>: Aparecen las columnas mapeadas en "
-"<literal>UPDATE</literal>s SQL?"
+"<literal>update</literal>: ¿Las columnas mapeadas aparacen en "
+"<literal>UPDATEs</literal> SQL?"
 
 #. Tag: para
-#: basic_mapping.xml:1911
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>false</literal>): "
 "specifies that this component should be fetched lazily when the instance "
 "variable is first accessed. It requires build-time bytecode instrumentation."
 msgstr ""
-"<literal>lazy</literal> (opcional - por defecto a <literal>false</literal>): "
-"Especifica que este componente debe ser recuperado perezosamente cuando la "
-"variable de instancia sea accedida por primera vez (requiere "
-"instrumentaci&#x00f3;n de bytecode en tiempo de compilaci&#x00f3;n)."
+"<literal>lazy</literal> (opcional - por defecto es <literal>false</"
+"literal>): Especifica que este componente debe ser recuperado perezosamente "
+"cuando se acceda a la variable de instancia por primera vez. Requiere "
+"instrumentación de código byte en tiempo de compilación."
 
 #. Tag: para
-#: basic_mapping.xml:1918
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to this component either do or do not "
 "require acquisition of the optimistic lock. It determines if a version "
 "increment should occur when this property is dirty."
 msgstr ""
-"<literal>optimistic-lock</literal> (opcional - por defecto a <literal>true</"
-"literal>): Especifica si las actualizaciones de este componente requieren o "
-"no la adquisici&#x00f3;n de un bloqueo optimista. En otras palabras, "
-"determina si debe ocurrir un incremento de versi&#x00f3;n cuando esta "
-"propiedad est&#x00e1; desactualizada."
+"<literal>optimistic-lock</literal> (opcional - por defecto es <literal>true</"
+"literal>): Especifica que las actualizaciones de este componente requieren o "
+"no la adquisición de un bloqueo optimista. Determina si debe ocurrir un "
+"incremento de versión cuando esta propiedad se encuentra desactualizada."
 
 #. Tag: para
-#: basic_mapping.xml:1926 basic_mapping.xml:2002
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional - defaults to <literal>false</literal>): "
 "specifies that a unique constraint exists upon all mapped columns of the "
 "component."
 msgstr ""
-"<literal>unique</literal> (opcional - por defecto a <literal>false</"
-"literal>): Especifica que existe una restricci&#x00f3;n de unicidad sobre "
-"todas las columnas mapeadas del componente."
+"<literal>unique</literal> (opcional - por defecto es <literal>false</"
+"literal>): Especifica que existe una restricción de unicidad sobre todas las "
+"columnas mapeadas del componente."
 
 #. Tag: para
-#: basic_mapping.xml:1935
 #, no-c-format
 msgid ""
 "The child <literal>&lt;property&gt;</literal> tags map properties of the "
 "child class to table columns."
 msgstr ""
 "Las etiquetas hijas <literal>&lt;property&gt;</literal> mapean propiedades "
-"de la clase hija columnas de la tabla."
+"de la clase hija a las columnas de la tabla."
 
 #. Tag: para
-#: basic_mapping.xml:1940
 #, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element allows a <literal>&lt;"
@@ -3963,31 +2864,28 @@
 msgstr ""
 "El elemento <literal>&lt;component&gt;</literal> permite un subelemento "
 "<literal>&lt;parent&gt;</literal> que mapea una propiedad de la clase del "
-"componente como una referencia de regreso a la entidad contenedora."
+"componente como una referencia a la entidad contenedora."
 
 #. Tag: para
-#: basic_mapping.xml:1946
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;dynamic-component&gt;</literal> element allows a "
 "<literal>Map</literal> to be mapped as a component, where the property names "
-"refer to keys of the map. See <xref linkend=\"components-dynamic\"/> for "
+"refer to keys of the map. See <xref linkend=\"components-dynamic\" /> for "
 "more information."
 msgstr ""
 "El elemento <literal>&lt;dynamic-component&gt;</literal> permite que un "
-"<literal>Map</literal> sea mapeado como un componente, donde los nombres de "
-"las propiedades se corresponden a las claves del mapa, ver <xref linkend="
-"\"components-dynamic\"/>."
+"<literal>Map</literal> sea mapeado como un componente, en donde los nombres "
+"de las propiedades se refieran a las claves del mapeo. Consulte <xref "
+"linkend=\"components-dynamic\" /> para obtener mayor información. "
 
 #. Tag: title
-#: basic_mapping.xml:1955
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Properties"
-msgstr "properties"
+msgstr "Propiedades"
 
 #. Tag: para
-#: basic_mapping.xml:1957
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;properties&gt;</literal> element allows the definition of a "
 "named, logical grouping of the properties of a class. The most important use "
@@ -3995,70 +2893,36 @@
 "target of a <literal>property-ref</literal>. It is also a convenient way to "
 "define a multi-column unique constraint. For example:"
 msgstr ""
-"El elemento <literal>&lt;properties&gt;</literal> permite la definici&#x00f3;"
-"n de un grupo de propiedades l&#x00f3;gico con nombre de una clase. El uso "
-"m&#x00e1;s importante de la contrucci&#x00f3;n es que permite que una "
-"combinaci&#x00f3;n de propiedades sea objetivo de una <literal>property-ref</"
-"literal>. Es tambi&#x00e9;n una forma conveniente de definir una "
-"restricci&#x00f3;n de unicidad multicolumna."
+"El elemento <literal>&lt;properties&gt;</literal> permite la definición de "
+"un grupo de propiedades lógico con nombre de una clase. El uso más "
+"importante de la contrucción es que permite que una combinación de "
+"propiedades sea el objetivo de una <literal>property-ref</literal>. También "
+"es una forma práctica de definir una restricción de unicidad multicolumna. "
+"Por ejemplo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1973
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<properties\n"
-"        name=\"logicalName\"\n"
-"        insert=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-">\n"
-"\n"
-"        <property ...../>\n"
-"        <many-to-one .... />\n"
-"        ........\n"
-"</properties>]]>"
-msgstr ""
-"<![CDATA[<properties \n"
-"        name=\"logicalName\" \n"
-"        insert=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-">\n"
-"        \n"
-"        <property ...../>\n"
-"        <many-to-one .... />\n"
-"        ........\n"
-"</properties>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:1976
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal>: the logical name of the grouping. It is "
 "<emphasis>not</emphasis> an actual property name."
 msgstr ""
-"<literal>name</literal>: El nombre l&#x00f3;gico del agrupamiento - "
-"<emphasis>no</emphasis> un nombre de propiedad real."
+"<literal>name</literal>: El nombre lógico del agrupamiento. <emphasis>No</"
+"emphasis> es un nombre de propiedad."
 
 #. Tag: para
-#: basic_mapping.xml:1994
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to these properties either do or do not "
 "require acquisition of the optimistic lock. It determines if a version "
 "increment should occur when these properties are dirty."
 msgstr ""
-"<literal>optimistic-lock</literal> (opcional - por defecto a <literal>true</"
-"literal>): Especifica si las actualizaciones de estas propiedades requieren "
-"o no de la adquisici&#x00f3;n de un bloqueo optimista. En otras palabras, "
-"determina si debe ocurrir un incremento de versi&#x00f3;n cuando estas "
-"propiedades est&#x00e1;n desactualizadas."
+"<literal>optimistic-lock</literal> (opcional - por defecto es <literal>true</"
+"literal>): Especifica que las actualizaciones de estas propiedades requieren "
+"o no de la adquisición de un bloqueo optimista. Determina si debe ocurrir un "
+"incremento de versión cuando estas propiedades están desactualizadas."
 
 #. Tag: para
-#: basic_mapping.xml:2011
 #, no-c-format
 msgid ""
 "For example, if we have the following <literal>&lt;properties&gt;</literal> "
@@ -4067,167 +2931,80 @@
 "Por ejemplo, si tenemos el siguiente mapeo de <literal>&lt;properties&gt;</"
 "literal>:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2015
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"personNumber\"/>\n"
-"\n"
-"    ...\n"
-"    <properties name=\"name\"\n"
-"            unique=\"true\" update=\"false\">\n"
-"        <property name=\"firstName\"/>\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"lastName\"/>\n"
-"    </properties>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"personNumber\"/>\n"
-"    ...\n"
-"    <properties name=\"name\" \n"
-"            unique=\"true\" update=\"false\">\n"
-"        <property name=\"firstName\"/>\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"lastName\"/>\n"
-"    </properties>\n"
-"</class>]]>"
-
 #. Tag: para
-#: basic_mapping.xml:2017
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You might have some legacy data association that refers to this unique key "
 "of the <literal>Person</literal> table, instead of to the primary key:"
 msgstr ""
-"Entonces puede que tengamos alguna asociaci&#x00f3;n de datos heredados que "
-"se refiera a esta clave &#x00fa;nica de la tabla de <literal>Person</"
-"literal>, en vez de la clave primaria:"
+"Puede que tenga alguna asociación de datos heredados que se refiera a esta "
+"clave única de la tabla de <literal>Person</literal>, en lugar de la clave "
+"principal:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2022
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"person\"\n"
-"         class=\"Person\" property-ref=\"name\">\n"
-"    <column name=\"firstName\"/>\n"
-"    <column name=\"initial\"/>\n"
-"    <column name=\"lastName\"/>\n"
-"</many-to-one>]]>"
-msgstr ""
-"<![CDATA[<many-to-one name=\"person\" \n"
-"         class=\"Person\" property-ref=\"name\">\n"
-"    <column name=\"firstName\"/>\n"
-"    <column name=\"initial\"/>\n"
-"    <column name=\"lastName\"/>\n"
-"</many-to-one>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:2024
-#, fuzzy, no-c-format
-msgid ""
 "The use of this outside the context of mapping legacy data is not "
 "recommended."
 msgstr ""
 "No recomendamos el uso de este tipo de cosas fuera del contexto del mapeo de "
-"datos heredados."
+"datos heredados. "
 
 #. Tag: title
-#: basic_mapping.xml:2032
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Subclass"
-msgstr "subclass"
+msgstr "Subclase"
 
 #. Tag: para
-#: basic_mapping.xml:2034
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Polymorphic persistence requires the declaration of each subclass of the "
 "root persistent class. For the table-per-class-hierarchy mapping strategy, "
 "the <literal>&lt;subclass&gt;</literal> declaration is used. For example:"
 msgstr ""
-"Finalmente, la persistencia polim&#x00f3;rfica requiere la declaraci&#x00f3;"
-"n de la clase persistente ra&#x00ed;z. Para la estrategia de mapeo tabla-por-"
-"jerarqu&#x00ed;a-de-clases, se usa la declaraci&#x00f3;n de <literal>&lt;"
-"subclass&gt;</literal>."
+"La persistencia polimórfica requiere la declaración de cada subclase de la "
+"clase persistente raíz. Para la estrategia de mapeo tabla-por-jerarquía-de-"
+"clases, se utiliza la declaración <literal>&lt;subclass&gt;</literal>. Por "
+"ejemplo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2047
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<subclass\n"
-"        name=\"ClassName\"\n"
-"        discriminator-value=\"discriminator_value\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\"\n"
-"        extends=\"SuperclassName\">\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</subclass>]]>"
-msgstr ""
-"<![CDATA[<subclass\n"
-"        name=\"ClassName\"\n"
-"        discriminator-value=\"discriminator_value\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\">\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</subclass>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:2050 basic_mapping.xml:2108 basic_mapping.xml:2171
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal>: the fully qualified class name of the subclass."
 msgstr ""
-"<literal>name</literal>: El nombre de clase cualificado completamente de la "
-"subclase."
+"<literal>name</literal>: El nombre de clase completamente calificado de la "
+"subclase. "
 
 #. Tag: para
-#: basic_mapping.xml:2055
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>discriminator-value</literal> (optional - defaults to the class "
 "name): a value that distinguishes individual subclasses."
 msgstr ""
-"<literal>discriminator-value</literal> (opcional - por defecto al nombre de "
-"la clase): Un valor que distingue a subclases individuales."
+"<literal>discriminator-value</literal> (opcional - por defecto es el nombre "
+"de la clase): Un valor que distingue subclases individuales. "
 
 #. Tag: para
-#: basic_mapping.xml:2061
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies a class or interface used for "
 "lazy initializing proxies."
 msgstr ""
-"<literal>proxy</literal> (opcional): Especifica una clase o interface a usar "
-"para proxies de inicializaci&#x00f3;n perezosa."
+"<literal>proxy</literal> (opcional): Especifica una clase o interfaz que se "
+"utiliza para proxies de inicialización perezosa."
 
 #. Tag: para
-#: basic_mapping.xml:2067
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>true</literal>): "
 "setting <literal>lazy=\"false\"</literal> disables the use of lazy fetching."
 msgstr ""
-"<literal>lazy</literal> (opcional, por defecto a <literal>true</literal>): "
-"Establecer <literal>lazy=\"false\"</literal> deshabilita el uso de "
-"recuperaci&#x00f3;n perezosa."
+"<literal>lazy</literal> (opcional, por defecto es <literal>true</literal>): "
+"El establecer <literal>lazy=\"false\"</literal> desactiva el uso de la "
+"recuperación perezosa. "
 
 #. Tag: para
-#: basic_mapping.xml:2075
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Each subclass declares its own persistent properties and subclasses. "
 "<literal>&lt;version&gt;</literal> and <literal>&lt;id&gt;</literal> "
@@ -4235,208 +3012,84 @@
 "a hierarchy must define a unique <literal>discriminator-value</literal>. If "
 "this is not specified, the fully qualified Java class name is used."
 msgstr ""
-"UNTRANSLATED! Each subclass should declare its own persistent properties and "
-"subclasses. <literal>&lt;version&gt;</literal> and <literal>&lt;id&gt;</"
-"literal> properties are assumed to be inherited from the root class. Each "
-"subclass in a heirarchy must define a unique <literal>discriminator-value</"
-"literal>. If none is specified, the fully qualified Java class name is used."
+"Cada subclase debe declarar sus propias propiedades persistentes y "
+"subclases. Se asume que las propiedades <literal>&lt;version&gt;</literal> y "
+"<literal>&lt;id&gt;</literal> son heredadas de la clase raíz. Cada subclase "
+"en una jerarquía tiene que definir un <literal>discriminator-value</literal> "
+"único. Si no se especifica ninguno entonces se utiliza el nombre "
+"completamente calificado de clase Java."
 
 #. Tag: para
-#: basic_mapping.xml:2083 basic_mapping.xml:2141 basic_mapping.xml:2199
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"For information about inheritance mappings see <xref linkend=\"inheritance\"/"
-">."
+"For information about inheritance mappings see <xref linkend=\"inheritance"
+"\" />."
 msgstr ""
-"Para informaci&#x00f3;n acerca de mapeos de herencia, ver <xref linkend="
-"\"inheritance\"/>."
+"Para obtener información acerca de los mapeos de herencias consulte <xref "
+"linkend=\"inheritance\" />."
 
 #. Tag: title
-#: basic_mapping.xml:2090
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Joined-subclass"
-msgstr "joined-subclass"
+msgstr "joined-subclass "
 
 #. Tag: para
-#: basic_mapping.xml:2092
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Each subclass can also be mapped to its own table. This is called the table-"
 "per-subclass mapping strategy. An inherited state is retrieved by joining "
 "with the table of the superclass. To do this you use the <literal>&lt;joined-"
 "subclass&gt;</literal> element. For example:"
 msgstr ""
-"Alternativamente, cada subclase puede ser mapeada a su propia tabla "
-"(estrategia de mapeo tabla-por-subclase). El estado heredado se recupera "
-"uniendo con la tabla de la superclase. Usamos el elemento <literal>&lt;"
-"joined-subclass&gt;</literal>."
+"Se puede mapear cada subclase a su propia tabla. Esto se llama una "
+"estrategia de mapeo tabla-por-subclase. El estado heredado se recupera "
+"uniendo con la tabla de la superclase. Para hacer esto utilice elemento "
+"<literal>&lt;joined-subclass&gt;</literal>. Por ejemplo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2105
-#, no-c-format
-msgid ""
-"<![CDATA[<joined-subclass\n"
-"        name=\"ClassName\"\n"
-"        table=\"tablename\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        schema=\"schema\"\n"
-"        catalog=\"catalog\"\n"
-"        extends=\"SuperclassName\"\n"
-"        persister=\"ClassName\"\n"
-"        subselect=\"SQL expression\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\">\n"
-"\n"
-"        <key .... >\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</joined-subclass>]]>"
-msgstr ""
-"<![CDATA[<joined-subclass\n"
-"        name=\"ClassName\"\n"
-"        table=\"tablename\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        schema=\"schema\"\n"
-"        catalog=\"catalog\"\n"
-"        extends=\"SuperclassName\"\n"
-"        persister=\"ClassName\"\n"
-"        subselect=\"SQL expression\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\">\n"
-"\n"
-"        <key .... >\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</joined-subclass>]]>"
-
 #. Tag: para
-#: basic_mapping.xml:2113 basic_mapping.xml:2176
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>table</literal>: the name of the subclass table."
-msgstr "<literal>table</literal>: El nombre de tabla de la subclase."
+msgstr "<literal>table</literal>: El nombre de tabla de la subclase. "
 
 #. Tag: para
-#: basic_mapping.xml:2118 basic_mapping.xml:2181
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies a class or interface to use "
 "for lazy initializing proxies."
 msgstr ""
-"<literal>proxy</literal> (opcional): Especifica una clase o interface a usar "
-"para proxies de inicializaci&#x00f3;n perezosa."
+"<literal>proxy</literal> (opcional): Especifica una clase o interfaz que se "
+"debe utilizar para proxies de inicialización perezosa. "
 
 #. Tag: para
-#: basic_mapping.xml:2124 basic_mapping.xml:2187
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional, defaults to <literal>true</literal>): "
 "setting <literal>lazy=\"false\"</literal> disables the use of lazy fetching."
 msgstr ""
-"<literal>lazy</literal> (opcional, por defecto a <literal>true</literal>): "
-"Establecer <literal>lazy=\"false\"</literal> deshabilita el uso de "
-"recuperaci&#x00f3;n perezosa."
+"<literal>lazy</literal> (opcional, por defecto es <literal>true</literal>): "
+"El establecer <literal>lazy=\"false\"</literal> desactiva el uso de la "
+"recuperación perezosa. "
 
 #. Tag: para
-#: basic_mapping.xml:2132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A discriminator column is not required for this mapping strategy. Each "
 "subclass must, however, declare a table column holding the object identifier "
 "using the <literal>&lt;key&gt;</literal> element. The mapping at the start "
 "of the chapter would then be re-written as:"
 msgstr ""
-"No se requiere de una columna discriminadora para esta estrategia de mapeo. "
-"Cada subclase debe, sin embargo, declarar una columna de tabla que tenga el "
-"identificador del objeto usando el elemento <literal>&lt;key&gt;</literal>. "
-"El mapeo del comienzo del cap&#x00ed;tulo deber&#x00ed;a ser reescrito como:"
+"No se necesita una columna discriminadora para esta estrategia de mapeo. Sin "
+"embargo, cada subclase debe declarar una columna de tabla que tenga el "
+"identificador del objeto utilizando el elemento <literal>&lt;key&gt;</"
+"literal>. El mapeo mencionado al comienzo del capítulo se reescribiría así:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2139
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"        <class name=\"Cat\" table=\"CATS\">\n"
-"                <id name=\"id\" column=\"uid\" type=\"long\">\n"
-"                        <generator class=\"hilo\"/>\n"
-"                </id>\n"
-"                <property name=\"birthdate\" type=\"date\"/>\n"
-"                <property name=\"color\" not-null=\"true\"/>\n"
-"                <property name=\"sex\" not-null=\"true\"/>\n"
-"                <property name=\"weight\"/>\n"
-"                <many-to-one name=\"mate\"/>\n"
-"                <set name=\"kittens\">\n"
-"                        <key column=\"MOTHER\"/>\n"
-"                        <one-to-many class=\"Cat\"/>\n"
-"                </set>\n"
-"                <joined-subclass name=\"DomesticCat\" table=\"DOMESTIC_CATS"
-"\">\n"
-"                    <key column=\"CAT\"/>\n"
-"                    <property name=\"name\" type=\"string\"/>\n"
-"                </joined-subclass>\n"
-"        </class>\n"
-"\n"
-"        <class name=\"eg.Dog\">\n"
-"                <!-- mapping for Dog could go here -->\n"
-"        </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"        <class name=\"Cat\" table=\"CATS\">\n"
-"                <id name=\"id\" column=\"uid\" type=\"long\">\n"
-"                        <generator class=\"hilo\"/>\n"
-"                </id>\n"
-"                <property name=\"birthdate\" type=\"date\"/>\n"
-"                <property name=\"color\" not-null=\"true\"/>\n"
-"                <property name=\"sex\" not-null=\"true\"/>\n"
-"                <property name=\"weight\"/>\n"
-"                <many-to-one name=\"mate\"/>\n"
-"                <set name=\"kittens\">\n"
-"                        <key column=\"MOTHER\"/>\n"
-"                        <one-to-many class=\"Cat\"/>\n"
-"                </set>\n"
-"                <joined-subclass name=\"DomesticCat\" table=\"DOMESTIC_CATS"
-"\">\n"
-"                    <key column=\"CAT\"/>\n"
-"                    <property name=\"name\" type=\"string\"/>\n"
-"                </joined-subclass>\n"
-"        </class>\n"
-"\n"
-"        <class name=\"eg.Dog\">\n"
-"                <!-- mapping for Dog could go here -->\n"
-"        </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-
 #. Tag: title
-#: basic_mapping.xml:2148
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Union-subclass"
-msgstr "union-subclass"
+msgstr "Union-subclass"
 
 #. Tag: para
-#: basic_mapping.xml:2150
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A third option is to map only the concrete classes of an inheritance "
 "hierarchy to tables. This is called the table-per-concrete-class strategy. "
@@ -4448,127 +3101,47 @@
 "need to use the <literal>&lt;union-subclass&gt;</literal> mapping. For "
 "example:"
 msgstr ""
-"Una tercera opci&#x00f3;n es mapear s&#x00f3;lo las clases concretas de una "
-"jerarqu&#x00ed;a de clases a tablas, (la estrategia tabla-por-clase-"
-"concreta) donde cada tabla define todo el estado persistente de la clase, "
-"incluyendo el estado heredado. En Hibernate, no es absolutamente necesario "
-"mapear dichas jerarqu&#x00ed;as de herencia. Puedes simplemente mapear cada "
-"clase con una declaraci&#x00f3;n <literal>&lt;class&gt;</literal> separada. "
-"Sin embargo, si deseas usar asociaciones polim&#x00f3;rficas (por ejemplo, "
-"una asociaci&#x00f3;n a la superclase de tu jerarqu&#x00ed;a), debes usar el "
-"mapeo <literal>&lt;union-subclass&gt;</literal>."
+"Una tercera opción es mapear sólo las clases concretas de una jerarquía de "
+"herencia a tablas. Esta se llama la estrategia clase concreta por tabla). "
+"Cada tabla define todos los estados persistentes de la clase, incluyendo el "
+"estado heredado. En Hibernate, no es necesario mapear dichas jerarquías de "
+"herencia. Puede mapear cada clase con una declaración <literal>&lt;class&gt;"
+"</literal> separada. Sin embargo, si desea utilizar asociaciones "
+"polimórficas (por ejemplo, una asociación a la superclase de su jerarquía), "
+"necesita utilizar el mapeo <literal>&lt;union-subclass&gt;</literal>. Por "
+"ejemplo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2168
-#, no-c-format
-msgid ""
-"<![CDATA[<union-subclass\n"
-"        name=\"ClassName\"\n"
-"        table=\"tablename\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        schema=\"schema\"\n"
-"        catalog=\"catalog\"\n"
-"        extends=\"SuperclassName\"\n"
-"        abstract=\"true|false\"\n"
-"        persister=\"ClassName\"\n"
-"        subselect=\"SQL expression\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\">\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</union-subclass>]]>"
-msgstr ""
-"<![CDATA[<union-subclass\n"
-"        name=\"ClassName\"\n"
-"        table=\"tablename\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        schema=\"schema\"\n"
-"        catalog=\"catalog\"\n"
-"        extends=\"SuperclassName\"\n"
-"        abstract=\"true|false\"\n"
-"        persister=\"ClassName\"\n"
-"        subselect=\"SQL expression\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\">\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</union-subclass>]]>"
-
 #. Tag: para
-#: basic_mapping.xml:2195
 #, no-c-format
 msgid ""
 "No discriminator column or key column is required for this mapping strategy."
 msgstr ""
-"No se requiere columna o columna clave discriminadora para esta estrategia "
-"de mapeo."
+"No se necesita una columna o una columna clave discriminadora para esta "
+"estrategia de mapeo."
 
 #. Tag: title
-#: basic_mapping.xml:2206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Join"
-msgstr "join"
+msgstr "Join"
 
 #. Tag: para
-#: basic_mapping.xml:2208
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Using the <literal>&lt;join&gt;</literal> element, it is possible to map "
 "properties of one class to several tables that have a one-to-one "
 "relationship. For example:"
 msgstr ""
-"Usando el elemento <literal>&lt;join&gt;</literal>, es posible mapear "
-"propiedades de una clase a varias tablas."
+"Al utilizar el elemento <literal>&lt;join&gt;</literal>, es posible mapear "
+"las propiedades de una clase a varias tablas que tengan una relación uno-a-"
+"uno. Por ejemplo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2222
-#, no-c-format
-msgid ""
-"<![CDATA[<join\n"
-"        table=\"tablename\"\n"
-"        schema=\"owner\"\n"
-"        catalog=\"catalog\"\n"
-"        fetch=\"join|select\"\n"
-"        inverse=\"true|false\"\n"
-"        optional=\"true|false\">\n"
-"\n"
-"        <key ... />\n"
-"\n"
-"        <property ... />\n"
-"        ...\n"
-"</join>]]>"
-msgstr ""
-"<![CDATA[<join\n"
-"        table=\"tablename\"\n"
-"        schema=\"owner\"\n"
-"        catalog=\"catalog\"\n"
-"        fetch=\"join|select\"\n"
-"        inverse=\"true|false\"\n"
-"        optional=\"true|false\">\n"
-"        \n"
-"        <key ... />\n"
-"        \n"
-"        <property ... />\n"
-"        ...\n"
-"</join>]]>"
-
 #. Tag: para
-#: basic_mapping.xml:2226
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>table</literal>: the name of the joined table."
-msgstr "<literal>table</literal>: El nombre de la clase unida."
+msgstr "<literal>table</literal>: El nombre de la tabla unida. "
 
 #. Tag: para
-#: basic_mapping.xml:2243
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional - defaults to <literal>join</literal>): "
 "if set to <literal>join</literal>, the default, Hibernate will use an inner "
@@ -4580,206 +3153,140 @@
 "instance of the subclass. Inner joins will still be used to retrieve a "
 "<literal>&lt;join&gt;</literal> defined by the class and its superclasses."
 msgstr ""
-"<literal>fetch</literal> (opcional - por defecto a <literal>join</literal>): "
-"Si se establece a <literal>join</literal>, por defecto, Hibernate "
-"usar&#x00e1; una uni&#x00f3;n interior (inner join) para recuperar un "
-"<literal>&lt;join&gt;</literal> definido por una clase o sus superclases y "
-"una uni&#x00f3;n externa (outer join) para un <literal>&lt;join&gt;</"
-"literal> definido por una subclase. Si se establece a <literal>select</"
-"literal>, entonces Hibernate usar&#x00e1; una select secuencial para un "
-"<literal>&lt;join&gt;</literal> definido en una subclase, que ser&#x00e1; "
-"publicada s&#x00f3;lo si una fila resulta representar una instancia de la "
-"subclase. Las uniones interiores todav&#x00ed;a ser&#x00e1;n usados para "
-"recuperar un <literal>&lt;join&gt;</literal> definido por la clase y sus "
-"superclases."
+"<literal>fetch</literal> (opcional - por defecto es <literal>join</"
+"literal>): Si se establece como <literal>join</literal>, por defecto, "
+"Hibernate utilizará una unión interior (inner join) para recuperar un "
+"<literal>&lt;join&gt;</literal> definido por una clase o sus superclases. "
+"Utilizará una unión externa (outer join) para un <literal>&lt;join&gt;</"
+"literal> definido por una subclase. Si se establece como <literal>select</"
+"literal>, entonces Hibernate utilizará una selección secuencial para un "
+"<literal>&lt;join&gt;</literal> definido en una subclase. Esto se publicará "
+"sólamente si una fila representa una instancia de la subclase. Las uniones "
+"interiores todavía serán utilizadas para recuperar un <literal>&lt;join&gt;</"
+"literal> definido por la clase y sus superclases."
 
 #. Tag: para
-#: basic_mapping.xml:2256
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>inverse</literal> (optional - defaults to <literal>false</"
 "literal>): if enabled, Hibernate will not insert or update the properties "
 "defined by this join."
 msgstr ""
-"<literal>inverse</literal> (opcional - por defecto a <literal>false</"
-"literal>): De habilitarse, Hibernate no intentar&#x00e1; insertar o "
-"actualizar las propiedades definidas por esta uni&#x00f3;n."
+"<literal>inverse</literal> (opcional - por defecto es <literal>false</"
+"literal>): De activarse, Hibernate no tratará de insertar o actualizar las "
+"propiedades definidas por esta unión. "
 
 #. Tag: para
-#: basic_mapping.xml:2263
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optional</literal> (optional - defaults to <literal>false</"
 "literal>): if enabled, Hibernate will insert a row only if the properties "
 "defined by this join are non-null. It will always use an outer join to "
 "retrieve the properties."
 msgstr ""
-"<literal>optional</literal> (opcional - por defecto a <literal>false</"
-"literal>): De habilitarse, Hibernate insertar&#x00e1; una fila s&#x00f3;lo "
-"si las propiedades definidas por esta uni&#x00f3;n son no nulas y siempre "
-"usar&#x00e1; una uni&#x00f3;n externa para recuperar las propiedades."
+"<literal>optional</literal> (opcional - por defecto es <literal>false</"
+"literal>): De activarse, Hibernate insertará una fila sólo si las "
+"propiedades definidas por esta unión son no-nulas. Siempre utilizará una "
+"unión externa para recuperar las propiedades."
 
 #. Tag: para
-#: basic_mapping.xml:2272
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For example, address information for a person can be mapped to a separate "
 "table while preserving value type semantics for all properties:"
 msgstr ""
-"Por ejemplo, la informaci&#x00f3;n domiciliaria de una persona puede ser "
-"mapeada a una tabla separada (preservando a la vez la sem&#x00e1;ntica de "
-"tipo de valor para todas las propiedades):"
+"Por ejemplo, la información domiciliaria de una persona se puede mapear a "
+"una tabla separada, preservando a la vez la semántica de tipo de valor para "
+"todas las propiedades:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2277
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\"\n"
-"    table=\"PERSON\">\n"
-"\n"
-"    <id name=\"id\" column=\"PERSON_ID\">...</id>\n"
-"\n"
-"    <join table=\"ADDRESS\">\n"
-"        <key column=\"ADDRESS_ID\"/>\n"
-"        <property name=\"address\"/>\n"
-"        <property name=\"zip\"/>\n"
-"        <property name=\"country\"/>\n"
-"    </join>\n"
-"    ...]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\"\n"
-"    table=\"PERSON\">\n"
-"\n"
-"    <id name=\"id\" column=\"PERSON_ID\">...</id>\n"
-"\n"
-"    <join table=\"ADDRESS\">\n"
-"        <key column=\"ADDRESS_ID\"/>\n"
-"        <property name=\"address\"/>\n"
-"        <property name=\"zip\"/>\n"
-"        <property name=\"country\"/>\n"
-"    </join>\n"
-"    ...]]>"
-
-#. Tag: para
-#: basic_mapping.xml:2279
-#, fuzzy, no-c-format
-msgid ""
 "This feature is often only useful for legacy data models. We recommend fewer "
 "tables than classes and a fine-grained domain model. However, it is useful "
 "for switching between inheritance mapping strategies in a single hierarchy, "
 "as explained later."
 msgstr ""
-"Esta funcionalidad es a menudo solamente &#x00fa;til para modelos de datos "
-"heredados; recomendamos menos tablas que clases un modelo de dominio "
-"m&#x00e1;s granularizado. Sin embargo, es &#x00fa;til para cambiar entre "
-"estrategias de mapeo de herencias en una misma jerarqu&#x00ed;a, como se "
-"explica luego."
+"Con frecuencia, esta funcionalidad sólamente es útil para los modelos de "
+"datos heredados. Recomendamos menos tablas que clases y un modelo de dominio "
+"más detallado. Sin embargo, es útil para cambiar entre estrategias de mapeo "
+"de herencias en una misma jerarquía, como se explica más adelante."
 
 #. Tag: title
-#: basic_mapping.xml:2289
-#, fuzzy, no-c-format
-msgid "<title>Key</title>"
-msgstr "<title>key</title>"
+#, no-c-format
+msgid "Key"
+msgstr "Key"
 
 #. Tag: para
-#: basic_mapping.xml:2291
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;key&gt;</literal> element has featured a few times within "
 "this guide. It appears anywhere the parent mapping element defines a join to "
 "a new table that references the primary key of the original table. It also "
 "defines the foreign key in the joined table:"
 msgstr ""
-"Hasta ahora hemos visto el elemento <literal>&lt;key&gt;</literal> pocas "
-"veces. Aparece en cualquier sitio en que el elemento padre de mapeo defina "
-"una uni&#x00f3;n a una nueva tabla, y define la clave for&#x00e1;nea en la "
-"tabla unida, que referencia la clave primaria de la tabla original."
+"Hasta ahora hemos visto el elemento <literal>&lt;key&gt;</literal> unas "
+"cuantas veces. Aparece en cualquier sitio en que el elemento padre de mapeo "
+"defina una unión a una nueva tabla que referencie la clave principal de la "
+"tabla original. También define la clave foránea en la tabla unida:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2307
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<key\n"
-"        column=\"columnname\"\n"
-"        on-delete=\"noaction|cascade\"\n"
-"        property-ref=\"propertyName\"\n"
-"        not-null=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"/>]]>"
-msgstr ""
-"<![CDATA[<key\n"
-"        column=\"columnname\"\n"
-"        on-delete=\"noaction|cascade\"\n"
-"        property-ref=\"propertyName\"\n"
-"        not-null=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"/>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:2318
-#, fuzzy, no-c-format
-msgid ""
 "<literal>on-delete</literal> (optional - defaults to <literal>noaction</"
 "literal>): specifies whether the foreign key constraint has database-level "
 "cascade delete enabled."
 msgstr ""
-"<literal>on-delete</literal> (opcional, por defecto a <literal>noaction</"
-"literal>): Especifica si la restricci&#x00f3;n de clave for&#x00e1;nea tiene "
-"el borrado en cascada habilitado a nivel de base de datos."
+"<literal>on-delete</literal> (opcional - por defecto es <literal>noaction</"
+"literal>): Especifica si la restricción de clave foránea tiene el borrado en "
+"cascada activado a nivel de base de datos."
 
 #. Tag: para
-#: basic_mapping.xml:2325
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): specifies that the foreign key "
 "refers to columns that are not the primary key of the original table. It is "
 "provided for legacy data."
 msgstr ""
-"<literal>property-ref</literal> (opcional): Especifica que la clave "
-"for&#x00e1;nea referencia columnas que no son del la clave primaria de la "
-"tabla original. (Provisto para datos heredados.)"
+"<literal>property-ref</literal> (opcional): Especifica que la clave foránea "
+"referencia columnas que no son la clave principal de la tabla original. Se "
+"proporciona para los datos heredados."
 
 #. Tag: para
-#: basic_mapping.xml:2332
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): specifies that the foreign key "
 "columns are not nullable. This is implied whenever the foreign key is also "
 "part of the primary key."
 msgstr ""
 "<literal>not-null</literal> (opcional): Especifica que las columnas de la "
-"clave for&#x00e1;nea son no nulables (esto est&#x00e1; implicado si la clave "
-"for&#x00e1;nea es tambi&#x00e9;n parte de la clave primaria)."
+"clave foránea son no nulables. Esto se implica cuando la clave foránea "
+"también es parte de la clave principal."
 
 #. Tag: para
-#: basic_mapping.xml:2339
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update</literal> (optional): specifies that the foreign key should "
 "never be updated. This is implied whenever the foreign key is also part of "
 "the primary key."
 msgstr ""
-"<literal>update</literal> (opcional): Especifica que la clave for&#x00e1;nea "
-"nunca debe ser actualizada (esto est&#x00e1; implicado si la clave "
-"for&#x00e1;nea es tambi&#x00e9;n parte de la clave primaria)."
+"<literal>update</literal> (opcional): Especifica que la clave foránea nunca "
+"se debe actualizar. Esto se implica cuando la clave foránea también es parte "
+"de la clave principal."
 
 #. Tag: para
-#: basic_mapping.xml:2346
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): specifies that the foreign key should "
 "have a unique constraint. This is implied whenever the foreign key is also "
 "the primary key."
 msgstr ""
-"<literal>unique</literal> (opcional): Especifica que la clave for&#x00e1;nea "
-"debe tener una restricci&#x00f3;n de unicidad (esto est&#x00e1; implicado si "
-"la clave for&#x00e1;nea es tambi&#x00e9;n la clave primaria)."
+"<literal>unique</literal> (opcional): Especifica que la clave foránea debe "
+"tener una restricción de . Esto se implica cuando la clave foránea también "
+"es la clave principal."
 
 #. Tag: para
-#: basic_mapping.xml:2354
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For systems where delete performance is important, we recommend that all "
 "keys should be defined <literal>on-delete=\"cascade\"</literal>. Hibernate "
@@ -4788,17 +3295,15 @@
 "that this feature bypasses Hibernate's usual optimistic locking strategy for "
 "versioned data."
 msgstr ""
-"Recomendamos que, para los sistemas en donde el rendimiento sea importante, "
-"todas las claves deben ser definidas <literal>on-delete=\"cascade\"</"
-"literal>, e Hibernate usar&#x00e1; una restricci&#x00f3;n <literal>ON "
-"CASCADE DELETE</literal> a nivel de base de datos, en vez de muchas "
-"sentencias <literal>DELETE</literal> individuales. Ten en cuenta que esta "
-"funcionalidad se salta la habitual estrategia de bloqueo optimista de "
-"Hibernate para datos versionados."
+"Para los sistemas en donde el rendimiento es importante, todas las claves "
+"deben ser definidas <literal>on-delete=\"cascade\"</literal>. Hibernate "
+"utiliza una restricción <literal>ON CASCADE DELETE</literal> a nivel de base "
+"de datos, en vez de muchas declaraciones <literal>DELETE</literal> "
+"individuales. Tenga en cuenta que esta funcionalidad evita la estrategia de "
+"bloqueo optimista normal de Hibernate para datos versionados."
 
 #. Tag: para
-#: basic_mapping.xml:2362
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>not-null</literal> and <literal>update</literal> attributes are "
 "useful when mapping a unidirectional one-to-many association. If you map a "
@@ -4807,103 +3312,58 @@
 "null=\"true\"&gt;</literal>."
 msgstr ""
 "Los atributos <literal>not-null</literal> y <literal>update</literal> son "
-"&#x00fa;tiles al mapear una asociaci&#x00f3;n uno a muchos unidireccional. "
-"Si mapeas una uno a muchos unidireccional a una clave for&#x00e1;nea no "
-"nulable, <emphasis>debes</emphasis> declarar la columna clave usando "
-"<literal>&lt;key not-null=\"true\"&gt;</literal>."
+"útiles al mapear una asociación uno a muchos unidireccional. Si mapea una "
+"unidireccional uno a muchos a una clave foránea no nulable, <emphasis>tiene</"
+"emphasis> que declarar la columna clave utilizando <literal>&lt;key not-null="
+"\"true\"&gt;</literal>. "
 
 #. Tag: title
-#: basic_mapping.xml:2372
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Column and formula elements"
-msgstr "los elementos column y formula"
+msgstr "Los elementos columna y fórmula"
 
 #. Tag: para
-#: basic_mapping.xml:2373
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Mapping elements which accept a <literal>column</literal> attribute will "
 "alternatively accept a <literal>&lt;column&gt;</literal> subelement. "
 "Likewise, <literal>&lt;formula&gt;</literal> is an alternative to the "
 "<literal>formula</literal> attribute. For example:"
 msgstr ""
-"Cualquier elemento de mapeo que acepte un atributo <literal>column</literal> "
-"aceptar&#x00e1; alternativamente un subelemento <literal>&lt;column&gt;</"
-"literal>. De forma similar, <literal>&lt;formula&gt;</literal> es una "
-"alternativa al atributo <literal>formula</literal>."
+"Los elementos de mapeo que acepten un atributo <literal>column</literal> "
+"aceptarán opcionalmente un subelemento <literal>&lt;column&gt;</literal>. De "
+"manera similar, <literal>&lt;formula&gt;</literal> es una alternativa al "
+"atributo <literal>formula</literal>. Por ejemplo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2379
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<column\n"
-"        name=\"column_name\"\n"
-"        length=\"N\"\n"
-"        precision=\"N\"\n"
-"        scale=\"N\"\n"
-"        not-null=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        unique-key=\"multicolumn_unique_key_name\"\n"
-"        index=\"index_name\"\n"
-"        sql-type=\"sql_type_name\"\n"
-"        check=\"SQL expression\"\n"
-"        default=\"SQL expression\"/>]]>"
+"Most of the attributes on <literal>column</literal> provide a means of "
+"tailoring the DDL during automatic schema generation. The <literal>read</"
+"literal> and <literal>write</literal> attributes allow you to specify custom "
+"SQL that Hibernate will use to access the column's value. For more on this, "
+"see the discussion of <link linkend=\"mapping-column-read-and-write\">column "
+"read and write expressions</link>."
 msgstr ""
-"<![CDATA[<column\n"
-"        name=\"column_name\"\n"
-"        length=\"N\"\n"
-"        precision=\"N\"\n"
-"        scale=\"N\"\n"
-"        not-null=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        unique-key=\"multicolumn_unique_key_name\"\n"
-"        index=\"index_name\"\n"
-"        sql-type=\"sql_type_name\"\n"
-"        check=\"SQL expression\"/>]]>"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2381
-#, no-c-format
-msgid "<![CDATA[<formula>SQL expression</formula>]]>"
-msgstr "<![CDATA[<formula>expresi&#x00f3;n SQL</formula>]]>"
-
 #. Tag: para
-#: basic_mapping.xml:2383
 #, fuzzy, no-c-format
 msgid ""
-"<literal>column</literal> and <literal>formula</literal> attributes can even "
-"be combined within the same property or association mapping to express, for "
-"example, exotic join conditions."
+"The <literal>column</literal> and <literal>formula</literal> elements can "
+"even be combined within the same property or association mapping to express, "
+"for example, exotic join conditions."
 msgstr ""
-"Los atributos <literal>column</literal> y <literal>formula</literal> pueden "
-"incluso ser combinados dentro del mismo mapeo de propiedad o asociaci&#x00f3;"
-"n para expresar, por ejemplo, condiciones de uni&#x00f3;n ex&#x00f3;ticas."
+"Los atributos <literal>column</literal> y <literal>formula</literal> incluso "
+"se pueden combinar dentro del mismo mapeo de propiedad o asociación para "
+"expresar, por ejemplo, condiciones de unión exóticas."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2389
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"homeAddress\" class=\"Address\"\n"
-"        insert=\"false\" update=\"false\">\n"
-"    <column name=\"person_id\" not-null=\"true\" length=\"10\"/>\n"
-"    <formula>'MAILING'</formula>\n"
-"</many-to-one>]]>"
-msgstr ""
-"<![CDATA[<many-to-one name=\"homeAddress\" class=\"Address\"\n"
-"        insert=\"false\" update=\"false\">\n"
-"    <column name=\"person_id\" not-null=\"true\" length=\"10\"/>\n"
-"    <formula>'MAILING'</formula>\n"
-"</many-to-one>]]>"
-
 #. Tag: title
-#: basic_mapping.xml:2394
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Import"
-msgstr "import"
+msgstr "Import"
 
 #. Tag: para
-#: basic_mapping.xml:2396
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your application has two persistent classes with the same name, and you "
 "do not want to specify the fully qualified package name in Hibernate "
@@ -4911,61 +3371,36 @@
 "<literal>auto-import=\"true\"</literal>. You can also import classes and "
 "interfaces that are not explicitly mapped:"
 msgstr ""
-"Sup&#x00f3;n que tu aplicaci&#x00f3;n tiene dos clases persistentes con el "
-"mismo nombre, y no quieres especificar el nombre completamenta cualificado "
-"(paquete) en las consultas Hibernate. Las clases pueden ser \"importadas\" "
-"expl&#x00ed;citamente, en vez de confiar en <literal>auto-import=\"true\"</"
-"literal>. Puedes incluso importar clases e interfaces que no est&#x00e9;n "
-"mapeadas expl&#x00ed;citamente."
+"Si su aplicación tiene dos clases persistentes con el mismo nombre y no "
+"quiere especificar el nombre del paquete completamenta calificado en las "
+"consultas Hibernate, las clases pueden ser \"importadas\" explícitamente, en "
+"lugar de depender de <literal>auto-import=\"true\"</literal>. Incluso puede "
+"importar clases e interfaces que no estén mapeadas explícitamente:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2403
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[<import class=\"java.lang.Object\" rename=\"Universe\"/>]]>"
-msgstr "<![CDATA[<import class=\"java.lang.Object\" rename=\"Universe\"/>]]>"
-
-#. Tag: programlisting
-#: basic_mapping.xml:2410
-#, no-c-format
 msgid ""
-"<![CDATA[<import\n"
-"        class=\"ClassName\"\n"
-"        rename=\"ShortName\"\n"
-"/>]]>"
-msgstr ""
-"<![CDATA[<import\n"
-"        class=\"ClassName\"\n"
-"        rename=\"ShortName\"\n"
-"/>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:2413
-#, fuzzy, no-c-format
-msgid ""
 "<literal>class</literal>: the fully qualified class name of any Java class."
 msgstr ""
-"<literal>class</literal>: El nombre de clase completamente cualificado de "
-"cualquier clase Java."
+"<literal>class</literal>: El nombre de clase completamente calificado de "
+"cualquier clase Java. "
 
 #. Tag: para
-#: basic_mapping.xml:2418
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>rename</literal> (optional - defaults to the unqualified class "
 "name): a name that can be used in the query language."
 msgstr ""
-"<literal>rename</literal> (opcional - por defecto al nombre de clase sin "
-"cualificar): Un nombre que ser&#x00e1; usado en el leguaje de consulta."
+"<literal>rename</literal> (opcional - por defecto es el nombre de clase sin "
+"calificar): Un nombre que se puede utilizar en el lenguaje de consulta."
 
 #. Tag: title
-#: basic_mapping.xml:2429
-#, fuzzy, no-c-format
-msgid "<title>Any</title>"
-msgstr "<title>any</title>"
+#, no-c-format
+msgid "Any"
+msgstr "Any"
 
 #. Tag: para
-#: basic_mapping.xml:2431
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is one more type of property mapping. The <literal>&lt;any&gt;</"
 "literal> mapping element defines a polymorphic association to classes from "
@@ -4976,20 +3411,17 @@
 "mapping polymorphic associations and you should use this only in special "
 "cases. For example, for audit logs, user session data, etc."
 msgstr ""
-"Hay un tipo m&#x00e1;s de mapeo de propiedad. El elemento de mapeo "
-"<literal>&lt;any&gt;</literal> define una asociaci&#x00e1;n polim&#x00f3;"
-"rfica a clases desde m&#x00fa;ltiples tablas. Este tipo de mapeo siempre "
-"requiere m&#x00e1;s de una columna. La primera columna contiene el tipo de "
-"la entidad asociada. Las columnas restantes contienen el identificador. Es "
-"imposible especificar una restricci&#x00f3;n de clave for&#x00e1;nea para "
-"este tipo de asociaci&#x00f3;n, por lo que esto ciertamente no est&#x00e1; "
-"concebido como la forma habitual de mapear asociaciones (polim&#x00f3;"
-"rficas). S&#x00f3;lo debes usar esto en casos muy especiales (por ejemplo, "
-"trazas de auditor&#x00e9;a, datos de sesi&#x00f3;n de usuario, etc)."
+"Hay un tipo más de mapeo de propiedad. El elemento de mapeo <literal>&lt;"
+"any&gt;</literal> define una asociación polimórfica a clases desde múltiples "
+"tablas. Este tipo de mapeo necesita más de una columna. La primera columna "
+"contiene el tipo de la entidad asociada. Las columnas restantes contienen el "
+"identificador. Es imposible especificar una restricción de clave foránea "
+"para este tipo de asociación. Esta no es la manera usual de mapear "
+"asociaciones polimórficas y sólamente debe usar esto en casos especiales. "
+"Por ejemplo, para registros de auditoría, datos de sesión de usuario, etc."
 
 #. Tag: para
-#: basic_mapping.xml:2441
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>meta-type</literal> attribute allows the application to specify "
 "a custom type that maps database column values to persistent classes that "
@@ -4997,138 +3429,74 @@
 "literal>. You must specify the mapping from values of the meta-type to class "
 "names."
 msgstr ""
-"El atributo <literal>meta-type</literal> permite a la aplicaci&#x00f3;n "
-"especificar un tipo personalizado que mapee columnas de base de datos a "
-"clases persistentes que tengan propiedades identificadoras del tipo "
-"especificado por <literal>id-type</literal>. Debes especificar el mapeo de "
-"valores del meta-type a nombres de clase."
+"El atributo <literal>meta-type</literal> le permite especificar a la "
+"aplicación un tipo personalizado que mapea los valores de columnas de la "
+"base de datos a clases persistentes que tengan propiedades identificadoras "
+"del tipo especificado por <literal>id-type</literal>. Tiene que especificar "
+"el mapeo de valores del meta-tipo a nombres de clase."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2448
-#, no-c-format
-msgid ""
-"<![CDATA[<any name=\"being\" id-type=\"long\" meta-type=\"string\">\n"
-"    <meta-value value=\"TBL_ANIMAL\" class=\"Animal\"/>\n"
-"    <meta-value value=\"TBL_HUMAN\" class=\"Human\"/>\n"
-"    <meta-value value=\"TBL_ALIEN\" class=\"Alien\"/>\n"
-"    <column name=\"table_name\"/>\n"
-"    <column name=\"id\"/>\n"
-"</any>]]>"
-msgstr ""
-"<![CDATA[<any name=\"being\" id-type=\"long\" meta-type=\"string\">\n"
-"    <meta-value value=\"TBL_ANIMAL\" class=\"Animal\"/>\n"
-"    <meta-value value=\"TBL_HUMAN\" class=\"Human\"/>\n"
-"    <meta-value value=\"TBL_ALIEN\" class=\"Alien\"/>\n"
-"    <column name=\"table_name\"/>\n"
-"    <column name=\"id\"/>\n"
-"</any>]]>"
-
-#. Tag: programlisting
-#: basic_mapping.xml:2459
-#, no-c-format
-msgid ""
-"<![CDATA[<any\n"
-"        name=\"propertyName\"\n"
-"        id-type=\"idtypename\"\n"
-"        meta-type=\"metatypename\"\n"
-"        cascade=\"cascade_style\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        optimistic-lock=\"true|false\"\n"
-">\n"
-"        <meta-value ... />\n"
-"        <meta-value ... />\n"
-"        .....\n"
-"        <column .... />\n"
-"        <column .... />\n"
-"        .....\n"
-"</any>]]>"
-msgstr ""
-"<![CDATA[<any\n"
-"        name=\"propertyName\"\n"
-"        id-type=\"idtypename\"\n"
-"        meta-type=\"metatypename\"\n"
-"        cascade=\"cascade_style\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        optimistic-lock=\"true|false\"\n"
-">\n"
-"        <meta-value ... />\n"
-"        <meta-value ... />\n"
-"        .....\n"
-"        <column .... />\n"
-"        <column .... />\n"
-"        .....\n"
-"</any>]]>"
-
 #. Tag: para
-#: basic_mapping.xml:2462
 #, no-c-format
 msgid "<literal>name</literal>: the property name."
 msgstr "<literal>name</literal>: el nombre de la propiedad."
 
 #. Tag: para
-#: basic_mapping.xml:2467
 #, no-c-format
 msgid "<literal>id-type</literal>: the identifier type."
 msgstr "<literal>id-type</literal>: el tipo del identificador."
 
 #. Tag: para
-#: basic_mapping.xml:2472
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>meta-type</literal> (optional - defaults to <literal>string</"
 "literal>): any type that is allowed for a discriminator mapping."
 msgstr ""
-"<literal>meta-type</literal> (opcional - por defecto a <literal>string</"
-"literal>): Cualquier tipo que sea permitido para un mapeo de discriminador."
+"<literal>meta-type</literal> (opcional - por defecto es <literal>string</"
+"literal>): Cualquier tipo que se permita para un mapeo discriminador."
 
 #. Tag: para
-#: basic_mapping.xml:2478
 #, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional- defaults to <literal>none</literal>): "
 "the cascade style."
 msgstr ""
-"<literal>cascade</literal> (opcional- por defecto a <literal>none</"
+"<literal>cascade</literal> (opcional- por defecto es <literal>none</"
 "literal>): el estilo de cascada."
 
 #. Tag: para
-#: basic_mapping.xml:2490
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to this property either do or do not "
 "require acquisition of the optimistic lock. It defines whether a version "
 "increment should occur if this property is dirty."
 msgstr ""
-"<literal>optimistic-lock</literal> (opcional - por defecto a <literal>true</"
+"<literal>optimistic-lock</literal> (opcional - por defecto es <literal>true</"
 "literal>): Especifica si las actualizaciones de esta propiedad requieren o "
-"no de la adquisici&#x00f3;n del bloqueo optimista. En otras palabras, "
-"determina si debe ocurrir un incremento de versi&#x00f3;n cuando esta "
-"propiedad est&#x00e1; desactualizada."
+"no de la adquisición del bloqueo optimista. Define si debe ocurrir un "
+"incremento de versión cuando esta propiedad está desactualizada."
 
 #. Tag: title
-#: basic_mapping.xml:2505
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Hibernate types"
-msgstr "Tipos de Hibernate"
+msgstr "Tipos de Hibernate "
 
 #. Tag: title
-#: basic_mapping.xml:2508
 #, no-c-format
 msgid "Entities and values"
 msgstr "Entidades y Valores"
 
 #. Tag: para
-#: basic_mapping.xml:2510
 #, no-c-format
 msgid ""
 "In relation to the persistence service, Java language-level objects are "
 "classified into two groups:"
 msgstr ""
+"En relación con el servicio de persistencia, los objetos a nivel de lenguaje "
+"Java se clasifican en dos grupos:"
 
 #. Tag: para
-#: basic_mapping.xml:2515
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An <emphasis>entity</emphasis> exists independently of any other objects "
 "holding references to the entity. Contrast this with the usual Java model, "
@@ -5140,20 +3508,19 @@
 "large systems. Entities support circular and shared references. They can "
 "also be versioned."
 msgstr ""
-"Una <emphasis>entidad</emphasis> existe independientemente de cualquier "
-"otros objetos que referencien a la entidad. Contrasta esto con el model "
-"habitual de Java donde un objeto desreferenciado es recolectado como basura. "
-"Las entidades deben ser salvadas y borradas expl&#x00ed;citamente (excepto "
-"que las grabaciones y borrados puedan ser <emphasis>tratados en cascada</"
-"emphasis> desde una entidad padre a sus hijos). Esto es diferente al modelo "
-"de persistencia de objetos por alcance - y se corresponde m&#x00e1;s de "
-"cerca a c&#x00f3;mo los objetos de aplicaci&#x00f3;n son usados "
-"habitualmente en grandes sistemas. Las entidades soportan referencias "
-"circulares y compartidas, que tambi&#x00e9; pueden ser versionadas."
+"Una <emphasis>entidad</emphasis> existe independientemente de cualquier otro "
+"objeto que referencie a la entidad. Compare esto con el modelo habitual de "
+"Java en donde un objeto no referenciado es recolectado como basura. Las "
+"entidades deben ser guardadas y borradas explícitamente. Sin embargo, los "
+"grabados y borrados se pueden <emphasis>tratar en cascada</emphasis> desde "
+"una entidad padre a sus hijos. Esto es diferente al modelo de persistencia "
+"de objetos por alcance (ODMG) y corresponde más a cómo se utilizan "
+"habitualmente los objetos de aplicación en sistemas grandes. Las entidades "
+"soportan referencias circulares y compartidas, que también pueden ser "
+"versionadas."
 
 #. Tag: para
-#: basic_mapping.xml:2526
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An entity's persistent state consists of references to other entities and "
 "instances of <emphasis>value</emphasis> types. Values are primitives: "
@@ -5165,20 +3532,18 @@
 "no independent identity, so they cannot be shared by two entities or "
 "collections."
 msgstr ""
-"El estado persistente de una entidad consiste en referencias a otras "
+"El estado persistente de una entidad consta de las referencias a otras "
 "entidades e instancias de tipo <emphasis>valor</emphasis>. Los valores son "
-"primitivos, colecciones (no lo que est&#x00e1; dentro de la colecci&#x00f3;"
-"n), componentes y ciertos objetos inmutables. A diferencia de las entidades, "
-"los valores (en particular las colecciones y los componentes) <emphasis>son</"
-"emphasis> hechos persitentes y borrados por alcance. Como los objetos valor "
-"(y primitivos) son persistidos y borrados junto a sus entidades "
-"contenedoras, no pueden ser versionados independientemente. Los valores no "
-"tienen identidad independiente, por los que no pueden ser compartidos por "
-"dos entidades o colleciones."
+"primitivos: colecciones (no lo que está dentro de la colección), componentes "
+"y ciertos objetos inmutables. A diferencia de las entidades, los valores en "
+"particular las colecciones y los componentes, <emphasis>son</emphasis> "
+"persistidos y borrados por alcance. Como los objetos valor y primitivos son "
+"persistidos y borrados junto con sus entidades contenedoras, no se pueden "
+"versionar independientemente. Los valores no tienen identidad independiente, "
+"por lo que dos entidades o colleciones no los pueden compartir."
 
 #. Tag: para
-#: basic_mapping.xml:2537
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Until now, we have been using the term \"persistent class\" to refer to "
 "entities. We will continue to do that. Not all user-defined classes with a "
@@ -5192,32 +3557,28 @@
 "single instance of that class, while composition or aggregation usually "
 "translates to a value type."
 msgstr ""
-"Hasta ahora, hemos estado usando el t&#x00e9;rmino \"clase persistente\" "
-"para referirnos a entidades. Continuaremos haci&#x00e9;ndolo. Hablando "
-"estrictamente, sin embargo, no todas la clases con estado persistente "
-"definidas por el usuario son entidades. Un <emphasis>componente</emphasis> "
-"es una clase definida por el usuario con sem&#x00e1;ntica de valor. Una "
-"propiedad Java de tipo <literal>java.lang.String</literal> tambi&#x00e9;n "
-"tiene sem&#x00e1;ntica de valor. Dada esta definici&#x00f3;n, podemos decir "
-"que todos los tipo (clases) provistos por el JDK tienen una sem&#x00e1;ntica "
-"de tipo valor en Java, mientras que los tipos definidos por el usuario "
-"pueden ser mapeados con sem&#x00e1;ntica de tipo valor o de entidad. La "
-"desici&#x00f3;n corre por cuenta del desarrollador de la aplicaci&#x00f3;n. "
-"Un buen consejo para una clase entidad en un modelo de dominio son las "
-"referencias compartidas a una sola instancia de esa clase, mientras que la "
-"composici&#x00f3;n o agregaci&#x00f3;n usualmente se traducen a un tipo de "
-"valor."
+"Hasta ahora, hemos estado utilizando el término \"clase persistente\" para "
+"referirnos a entidades. Continuaremos haciéndolo así. Sin embargo, no todas "
+"la clases con estado persistente definidas por el usuario son entidades. Un "
+"<emphasis>componente</emphasis> es una clase definida por el usuario con "
+"semántica de valor. Una propiedad Java de tipo <literal>java.lang.String</"
+"literal> también tiene semántica de valor. Dada esta definición, podemos "
+"decir que todos los tipo (clases) provistos por el JDK tienen una semántica "
+"de tipo valor en Java, mientras que los tipos definidos por el usuario se "
+"pueden mapear con semántica de tipo valor o de entidad. La desición corre "
+"por cuenta del desarrollador de la aplicación. Una clase entidad en un "
+"modelo de dominio son las referencias compartidas a una sola instancia de "
+"esa clase, mientras que la composición o agregación usualmente se traducen a "
+"un tipo de valor."
 
 #. Tag: para
-#: basic_mapping.xml:2551
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "We will revisit both concepts throughout this reference guide."
 msgstr ""
-"Volveremos a visitar ambos conceptos a lo largo de la documentaci&#x00f3;n."
+"Volveremos a revisar ambos conceptos a lo largo de este manual de referencia."
 
 #. Tag: para
-#: basic_mapping.xml:2555
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The challenge is to map the Java type system, and the developers' definition "
 "of entities and value types, to the SQL/database type system. The bridge "
@@ -5230,57 +3591,51 @@
 "for standard JDK value types out of the box. You can write your own mapping "
 "types and implement your own custom conversion strategies."
 msgstr ""
-"EL desaf&#x00ed;o es mapear el sistema de tipos de Java (y la "
-"definici&#x00f3;n de entidades y tipos de valor de los desarrolladores) al "
-"sistema de tipos de SQL/base de datos. EL puente entre ambos sistemas es "
-"provisto por Hibernate: para las entidades usamos <literal>&lt;class&gt;</"
-"literal>, <literal>&lt;subclass&gt;</literal>, etc. Para los tipos de valor "
-"usamos <literal>&lt;property&gt;</literal>, <literal>&lt;component&gt;</"
-"literal>, etc, usualmente con un atributo <literal>type</literal>. El valor "
-"de este atributo es el nombre de un <emphasis>tipo de mapeo</emphasis> de "
-"Hibernate. Hibernate provee de f&#x00e1;brica muchos mapeos (para tipos de "
-"valores del JDK est&#x00e1;ndar). Puedes escribir tus propios mapeos de "
-"tipo, as&#x00ed; como implementar tus estrategias de conversi&#x00f3;n "
-"personalizadas, como veremos luego."
+"EL desafío es mapear el sistema de tipos de Java ( la definición de "
+"entidades y tipos de valor de los desarrolladores al sistema de tipos de SQL/"
+"la base de datos. El puente entre ambos sistemas lo brinda Hibernate. Para "
+"las entidades utilizamos <literal>&lt;class&gt;</literal>, <literal>&lt;"
+"subclass&gt;</literal>, etc. Para los tipos de valor utilizamos <literal>&lt;"
+"property&gt;</literal>, <literal>&lt;component&gt;</literal>, etc, "
+"usualmente con un atributo <literal>type</literal>. El valor de este "
+"atributo es el nombre de un <emphasis>tipo de mapeo</emphasis> de Hibernate. "
+"Hibernate proporciona un rango de mapeos para tipos de valores del JDK "
+"estándar. Puede escribir sus propios mapeos de tipo e implementar sus "
+"estrategias de conversión personalizadas."
 
 #. Tag: para
-#: basic_mapping.xml:2568
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "With the exception of collections, all built-in Hibernate types support null "
 "semantics."
 msgstr ""
-"Todos los tipos prefabricados de Hibernate soportan sem&#x00e1;ntica de "
-"nulos excepto las colecciones."
+"Todos los tipos incorporados de Hibernate soportan la semántica de nulos, a "
+"excepción de las colecciones."
 
 #. Tag: title
-#: basic_mapping.xml:2575
 #, no-c-format
 msgid "Basic value types"
-msgstr "Tipos de valores b&#x00e1;sicos"
+msgstr "Tipos de valores básicos"
 
 #. Tag: para
-#: basic_mapping.xml:2577
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The built-in <emphasis>basic mapping types</emphasis> can be roughly "
 "categorized into the following:"
 msgstr ""
-"Los <emphasis>tipos de mapeo b&#x00e1;sicos</emphasis> prefabricados pueden "
-"ser categorizado a grandes rasgos en:"
+"Los <emphasis>tipos de mapeo básicos</emphasis> incorporados se pueden "
+"categorizar así:"
 
-#. Tag: literal
-#: basic_mapping.xml:2582
+#. Tag: term
 #, no-c-format
 msgid ""
-"integer, long, short, float, double, character, byte, boolean, yes_no, "
-"true_false"
+"<literal>integer, long, short, float, double, character, byte, boolean, "
+"yes_no, true_false</literal>"
 msgstr ""
-"integer, long, short, float, double, character, byte, boolean, yes_no, "
-"true_false"
+"<literal>integer, long, short, float, double, character, byte, boolean, "
+"yes_no, true_false</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2585
 #, no-c-format
 msgid ""
 "Type mappings from Java primitives or wrapper classes to appropriate (vendor-"
@@ -5288,19 +3643,17 @@
 "<literal>true_false</literal> are all alternative encodings for a Java "
 "<literal>boolean</literal> or <literal>java.lang.Boolean</literal>."
 msgstr ""
-"Mapeos de tipos primitivos de Java o clases de envoltura a la tipos de "
-"columna SQL (espec&#x00ed;cifica del vendedor). <literal>boolean, yes_no</"
-"literal> y <literal>true_false</literal> son codificaciones alternativas a "
+"Mapeos de tipos de primitivos de Java o de clases de envoltura a los tipos "
+"de columna SQL (específica del vendedor). <literal>boolean, yes_no</literal> "
+"y <literal>true_false</literal> son codificaciones alternativas a "
 "<literal>boolean</literal> de Java o <literal>java.lang.Boolean</literal>."
 
-#. Tag: literal
-#: basic_mapping.xml:2594
+#. Tag: term
 #, no-c-format
-msgid "string"
-msgstr "string"
+msgid "<literal>string</literal>"
+msgstr "<literal>string</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2596
 #, no-c-format
 msgid ""
 "A type mapping from <literal>java.lang.String</literal> to <literal>VARCHAR</"
@@ -5309,14 +3662,12 @@
 "Un mapeo del tipo <literal>java.lang.String</literal> a <literal>VARCHAR</"
 "literal> (u Oracle <literal>VAARCHAR2</literal>)."
 
-#. Tag: literal
-#: basic_mapping.xml:2603
+#. Tag: term
 #, no-c-format
-msgid "date, time, timestamp"
-msgstr "date, time, timestamp"
+msgid "<literal>date, time, timestamp</literal>"
+msgstr "<literal>date, time, timestamp</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2605
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Date</literal> and its subclasses to "
@@ -5327,31 +3678,26 @@
 "tipos SQL <literal>DATE</literal>, <literal>TIME</literal> y "
 "<literal>TIMESTAMP</literal> (o equivalente)."
 
-#. Tag: literal
-#: basic_mapping.xml:2613
+#. Tag: term
 #, no-c-format
-msgid "calendar, calendar_date"
-msgstr "calendar, calendar_date"
+msgid "<literal>calendar, calendar_date</literal>"
+msgstr "<literal>calendar, calendar_date</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2615
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Calendar</literal> to SQL types "
 "<literal>TIMESTAMP</literal> and <literal>DATE</literal> (or equivalent)."
 msgstr ""
-"Mapeos de tipo desde <literal>java.util.Date</literal> y sus subclases a "
-"tipos SQL <literal>TIMESTAMP</literal> y <literal>DATE</literal> (o "
-"equivalente)."
+"Mapeos de tipo desde <literal>java.util.Date</literal> y tipos SQL "
+"<literal>TIMESTAMP</literal> y <literal>DATE</literal> (o equivalente)."
 
-#. Tag: literal
-#: basic_mapping.xml:2623
+#. Tag: term
 #, no-c-format
-msgid "big_decimal, big_integer"
-msgstr "big_decimal, big_integer"
+msgid "<literal>big_decimal, big_integer</literal>"
+msgstr "<literal>big_decimal, big_integer</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2625
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.math.BigDecimal</literal> and <literal>java."
@@ -5362,14 +3708,12 @@
 "math.BigInteger</literal> a <literal>NUMERIC</literal> (o <literal>NUMBER</"
 "literal> de Oracle)."
 
-#. Tag: literal
-#: basic_mapping.xml:2633
+#. Tag: term
 #, no-c-format
-msgid "locale, timezone, currency"
-msgstr "locale, timezone, currency"
+msgid "<literal>locale, timezone, currency</literal>"
+msgstr "<literal>locale, timezone, currency</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2635
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Locale</literal>, <literal>java.util."
@@ -5383,17 +3727,15 @@
 "TimeZone</literal> y <literal>java.util.Currency</literal> a "
 "<literal>VARCHAR</literal> (o <literal>VARCHAR2</literal> de Oracle). Las "
 "instancias de <literal>Locale</literal> y <literal>Currency</literal> son "
-"mapeadas a sus c&#x00f3;digos ISO. Las instancias de <literal>TimeZone</"
-"literal> son mapeadas a sus <literal>ID</literal>."
+"mapeadas a sus códigos ISO. Las instancias de <literal>TimeZone</literal> "
+"son mapeadas a sus <literal>ID</literal>."
 
-#. Tag: literal
-#: basic_mapping.xml:2647
-#, fuzzy, no-c-format
-msgid "class"
-msgstr "subclass"
+#. Tag: term
+#, no-c-format
+msgid "<literal>class</literal>"
+msgstr "<literal>class</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2649
 #, no-c-format
 msgid ""
 "A type mapping from <literal>java.lang.Class</literal> to <literal>VARCHAR</"
@@ -5402,64 +3744,56 @@
 msgstr ""
 "Un mapeo de tipo <literal>java.lang.Class</literal> a <literal>VARCHAR</"
 "literal> (o <literal>VARCHAR2</literal> de Oracle). Una <literal>Class</"
-"literal> es mapeara a su nombre completamente cualificado."
+"literal> es mapeada a su nombre completamente calificado."
 
-#. Tag: literal
-#: basic_mapping.xml:2657
+#. Tag: term
 #, no-c-format
-msgid "binary"
-msgstr "binary"
+msgid "<literal>binary</literal>"
+msgstr "<literal>binary</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2659
 #, no-c-format
 msgid "Maps byte arrays to an appropriate SQL binary type."
 msgstr "Mapea arreglos de bytes a un tipo binario SQL apropiado."
 
-#. Tag: literal
-#: basic_mapping.xml:2665
+#. Tag: term
 #, no-c-format
-msgid "text"
-msgstr "text"
+msgid "<literal>text</literal>"
+msgstr "<literal>text</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2667
 #, no-c-format
 msgid ""
 "Maps long Java strings to a SQL <literal>CLOB</literal> or <literal>TEXT</"
 "literal> type."
 msgstr ""
-"Mapea cadenas largas Java al tipo SQL <literal>CLOB</literal> o "
+"Mapea cadenas largas de Java al tipo SQL <literal>CLOB</literal> o "
 "<literal>TEXT</literal>."
 
-#. Tag: literal
-#: basic_mapping.xml:2674
+#. Tag: term
 #, no-c-format
-msgid "serializable"
-msgstr "serializable"
+msgid "<literal>serializable</literal>"
+msgstr "<literal>serializable</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2676
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Maps serializable Java types to an appropriate SQL binary type. You can also "
 "indicate the Hibernate type <literal>serializable</literal> with the name of "
 "a serializable Java class or interface that does not default to a basic type."
 msgstr ""
-"Mapea tipos serializables Java a un tipo binario SQL apropiado. Puedes "
-"adem&#x00e1;s indicar el tipo <literal>serializable</literal> de Hibernate "
-"con el nombre de una clase o interface serializable Java que no sea por "
-"defecto un tipo b&#x00e1;sico."
+"Mapea tipos serializables Java a un tipo binario SQL apropiado. También "
+"puede indicar el tipo <literal>serializable</literal> de Hibernate con el "
+"nombre de una clase o interfaz serializable Java que no sea por defecto un "
+"tipo básico. "
 
-#. Tag: literal
-#: basic_mapping.xml:2685
+#. Tag: term
 #, no-c-format
-msgid "clob, blob"
-msgstr "clob, blob"
+msgid "<literal>clob, blob</literal>"
+msgstr "<literal>clob, blob</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2687
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Type mappings for the JDBC classes <literal>java.sql.Clob</literal> and "
 "<literal>java.sql.Blob</literal>. These types can be inconvenient for some "
@@ -5468,23 +3802,21 @@
 msgstr ""
 "Mapeos de tipo para las clases JDBC <literal>java.sql.Clob</literal> y "
 "<literal>java.sql.Blob</literal>. Estos tipos pueden ser inconvenientes para "
-"algunas aplicaciones, pues el objeto blob o clob no puede ser reusado fuera "
-"de una transacci&#x00f3;n (Adem&#x00e1;s, el soporte del driver suele ser "
-"malo e inconsistente)."
+"algunas aplicaciones, pues el objeto blob o clob no pueden ser reusados "
+"fuera de una transacción. Además, el soporte del controlador suele ser malo "
+"e inconsistente."
 
-#. Tag: literal
-#: basic_mapping.xml:2697
+#. Tag: term
 #, no-c-format
 msgid ""
-"imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
-"imm_serializable, imm_binary"
+"<literal>imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
+"imm_serializable, imm_binary</literal>"
 msgstr ""
-"UNTRANSLATED! imm_date, imm_time, imm_timestamp, imm_calendar, "
-"imm_calendar_date, imm_serializable, imm_binary"
+"<literal>imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
+"imm_serializable, imm_binary</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2701
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Type mappings for what are considered mutable Java types. This is where "
 "Hibernate makes certain optimizations appropriate only for immutable Java "
@@ -5494,30 +3826,28 @@
 "have that change made persistent, the application must assign a new, "
 "nonidentical, object to the property."
 msgstr ""
-"Type mappings for what are usually considered mutable Java types, where "
-"Hibernate makes certain optimizations appropriate only for immutable Java "
-"types, and the application treats the object as immutable. For example, you "
-"should not call <literal>Date.setTime()</literal> for an instance mapped as "
-"<literal>imm_timestamp</literal>. To change the value of the property, and "
-"have that change made persistent, the application must assign a new "
-"(nonidentical) object to the property."
+"Los mapeos de tipo para lo que usualmente se considera tipos Java mutables. "
+"Aquí es donde Hibernate realiza ciertas optimizaciones apropiadas sólamente "
+"para tipos Java inmutables y la aplicación trata el objeto como inmutable. "
+"Por ejemplo, no debe llamar <literal>Date.setTime()</literal> para una "
+"instancia mapeada como <literal>imm_timestamp</literal>. Para cambiar el "
+"valor de la propiedad y hacer que ese cambio sea persistente, la aplicación "
+"tiene que asignar un objeto nuevo, no idéntico, a la propiedad."
 
 #. Tag: para
-#: basic_mapping.xml:2716
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Unique identifiers of entities and collections can be of any basic type "
 "except <literal>binary</literal>, <literal>blob</literal> and <literal>clob</"
 "literal>. Composite identifiers are also allowed. See below for more "
 "information."
 msgstr ""
-"Los identificadores &#x00fa;nicos de entidades y collecciones pueden ser de "
-"cualquier tipo b&#x00e1;sico excepto <literal>binary</literal>, "
-"<literal>blob</literal> y <literal>clob</literal>. (Los identificadores "
-"compuestos est&#x00e1;n tambi&#x00e9;n permitidos, ver debajo.)"
+"Los identificadores únicos de entidades y colecciones pueden ser de "
+"cualquier tipo básico excepto <literal>binary</literal>, <literal>blob</"
+"literal> y <literal>clob</literal>. Los identificadores compuestos también "
+"están permitidos, a continuación encontrará mayor información."
 
 #. Tag: para
-#: basic_mapping.xml:2722
 #, no-c-format
 msgid ""
 "The basic value types have corresponding <literal>Type</literal> constants "
@@ -5525,20 +3855,18 @@
 "<literal>Hibernate.STRING</literal> represents the <literal>string</literal> "
 "type."
 msgstr ""
-"Los tipos de valor b&#x00e1;sicos tienen sus constantes <literal>Type</"
-"literal> correspondientes definidas en <literal>org.hibernate.Hibernate</"
-"literal>. Por ejemplo, <literal>Hibernate.STRING</literal> representa el "
-"tipo <literal>string</literal>."
+"Los tipos de valor básicos tienen sus constantes <literal>Type</literal> "
+"correspondientes definidas en <literal>org.hibernate.Hibernate</literal>. "
+"Por ejemplo, <literal>Hibernate.STRING</literal> representa el tipo "
+"<literal>string</literal>."
 
 #. Tag: title
-#: basic_mapping.xml:2731
 #, no-c-format
 msgid "Custom value types"
 msgstr "Tipos de valor personalizados"
 
 #. Tag: para
-#: basic_mapping.xml:2733
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is relatively easy for developers to create their own value types. For "
 "example, you might want to persist properties of type <literal>java.lang."
@@ -5550,20 +3878,19 @@
 "that is persisted to the columns <literal>FIRST_NAME</literal>, "
 "<literal>INITIAL</literal>, <literal>SURNAME</literal>."
 msgstr ""
-"Es relativamente f&#x00e1;cil para los desarrolladores crear sus propios "
-"tipos de valor. Por ejemplo, podr&#x00ed;as querer persistir propiedades del "
-"tipo <literal>java.lang.BigInteger</literal> a columnas <literal>VARCHAR</"
-"literal>. Hibernate no provee un tipo de f&#x00e1;brica para esto. Pero los "
-"tipos personalizados no est&#x00e1;n limitados a mapear una propiedad (o "
-"elemento de colecci&#x00f3;n) a una sola columna de tabla. As&#x00ed;, por "
-"ejemplo, podr&#x00ed;as tener una propiedad Java <literal>getName()</"
-"literal>/<literal>setName()</literal> de tipo <literal>java.lang.String</"
-"literal> que fuera persistida a las columnas <literal>FIRST_NAME</literal>, "
-"<literal>INITIAL</literal>, <literal>SURNAME</literal>."
+"Es relativamente fácil para los desarrolladores crear sus propios tipos de "
+"valor. Por ejemplo, puede que quiera persistir propiedades del tipo "
+"<literal>java.lang.BigInteger</literal> a columnas <literal>VARCHAR</"
+"literal>. Hibernate no provee un tipo incorporado para esto. Los tipos "
+"personalizados no están limitados a mapear una propiedad o elemento de "
+"colección a una sola columna de tabla. Así, por ejemplo, podría tener una "
+"propiedad Java <literal>getName()</literal>/<literal>setName()</literal> de "
+"tipo <literal>java.lang.String</literal> que es persistida a las columnas "
+"<literal>FIRST_NAME</literal>, <literal>INITIAL</literal>, <literal>SURNAME</"
+"literal>."
 
 #. Tag: para
-#: basic_mapping.xml:2744
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To implement a custom type, implement either <literal>org.hibernate."
 "UserType</literal> or <literal>org.hibernate.CompositeUserType</literal> and "
@@ -5571,40 +3898,22 @@
 "<literal>org.hibernate.test.DoubleStringType</literal> to see the kind of "
 "things that are possible."
 msgstr ""
-"Para implementar un tipo personalizado, implementa bien <literal>org."
-"hibernate.UserType</literal> o <literal>org.hibernate.CompositeUserType</"
-"literal> y declara las propiedades usando el nombre de clase completamente "
-"cualificado del tipo. Revisa <literal>org.hibernate.test.DoubleStringType</"
-"literal> para ver qu&#x00e9; tipo de cosas son posibles."
+"Para implementar un tipo personalizado, implemente <literal>org.hibernate."
+"UserType</literal> o <literal>org.hibernate.CompositeUserType</literal> y "
+"declare las propiedades utilizando el nombre de clase completamente "
+"calificado del tipo. Revise <literal>org.hibernate.test.DoubleStringType</"
+"literal> para ver qué clases de cosas son posibles. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2752
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"twoStrings\" type=\"org.hibernate.test."
-"DoubleStringType\">\n"
-"    <column name=\"first_string\"/>\n"
-"    <column name=\"second_string\"/>\n"
-"</property>]]>"
-msgstr ""
-"<![CDATA[<property name=\"twoStrings\" type=\"org.hibernate.test."
-"DoubleStringType\">\n"
-"    <column name=\"first_string\"/>\n"
-"    <column name=\"second_string\"/>\n"
-"</property>]]>"
-
 #. Tag: para
-#: basic_mapping.xml:2754
 #, no-c-format
 msgid ""
 "Notice the use of <literal>&lt;column&gt;</literal> tags to map a property "
 "to multiple columns."
 msgstr ""
-"Observa el uso de etiquetas <literal>&lt;column&gt;</literal> para mapear "
-"una propiedad a m&#x00fa;ltiples columnas."
+"Observe el uso de etiquetas <literal>&lt;column&gt;</literal> para mapear "
+"una propiedad a múltiples columnas."
 
 #. Tag: para
-#: basic_mapping.xml:2759
 #, no-c-format
 msgid ""
 "The <literal>CompositeUserType</literal>, <literal>EnhancedUserType</"
@@ -5614,12 +3923,11 @@
 msgstr ""
 "Las interfaces <literal>CompositeUserType</literal>, "
 "<literal>EnhancedUserType</literal>, <literal>UserCollectionType</literal>, "
-"y <literal>UserVersionType</literal> proveen soporte a usos m&#x00e1;s "
+"y <literal>UserVersionType</literal> brindan soporte para usos más "
 "especializados."
 
 #. Tag: para
-#: basic_mapping.xml:2765
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can even supply parameters to a <literal>UserType</literal> in the "
 "mapping file. To do this, your <literal>UserType</literal> must implement "
@@ -5627,43 +3935,26 @@
 "To supply parameters to your custom type, you can use the <literal>&lt;"
 "type&gt;</literal> element in your mapping files."
 msgstr ""
-"Puedes incluso proveer de par&#x00e1;metros a un <literal>UserType</literal> "
-"en el fichero de mapeo. Para hacer esto, tu <literal>UserType</literal> debe "
-"implementar la interface <literal>org.hibernate.usertype.ParameterizedType</"
-"literal>. Para proveer de par&#x00e1;metros a tu tipo personalizado, puedes "
-"usar el elemento <literal>&lt;type&gt;</literal> en tus ficheros de mapeo."
+"Incluso usted puede proporcionar parámetros a un <literal>UserType</literal> "
+"en el archivo de mapeo. Para hacer esto, su <literal>UserType</literal> "
+"tiene que implementar la interfaz <literal>org.hibernate.usertype."
+"ParameterizedType</literal>. Para brindar parámetros a su tipo "
+"personalizado, puede utilizar el elemento <literal>&lt;type&gt;</literal> en "
+"sus archivos de mapeo. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2773
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"priority\">\n"
-"    <type name=\"com.mycompany.usertypes.DefaultValueIntegerType\">\n"
-"        <param name=\"default\">0</param>\n"
-"    </type>\n"
-"</property>]]>"
-msgstr ""
-"<![CDATA[<property name=\"priority\">\n"
-"    <type name=\"com.mycompany.usertypes.DefaultValueIntegerType\">\n"
-"        <param name=\"default\">0</param>\n"
-"    </type>\n"
-"</property>]]>"
-
 #. Tag: para
-#: basic_mapping.xml:2775
 #, no-c-format
 msgid ""
 "The <literal>UserType</literal> can now retrieve the value for the parameter "
 "named <literal>default</literal> from the <literal>Properties</literal> "
 "object passed to it."
 msgstr ""
-"Ahora el <literal>UserType</literal> puede recuperar el valor del par&#x00e1;"
-"metro llamado <literal>default</literal> del objeto <literal>Properties</"
+"Ahora el <literal>UserType</literal> puede recuperar el valor del parámetro "
+"denominado <literal>default</literal> del objeto <literal>Properties</"
 "literal> que se le pasa."
 
 #. Tag: para
-#: basic_mapping.xml:2780
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you regularly use a certain <literal>UserType</literal>, it is useful to "
 "define a shorter name for it. You can do this using the <literal>&lt;"
@@ -5671,46 +3962,24 @@
 "can also contain a list of default parameter values if the type is "
 "parameterized."
 msgstr ""
-"Si usas cierto <literal>UserType</literal> muy frecuentemente, puede ser "
-"&#x00fa;til definir un nombre corto para &#x00e9;. Puedes hacer esto usando "
+"Si utiliza cierto <literal>UserType</literal> muy frecuentemente, puede ser "
+"útil el definir un nombre más corto para este. Puede hacer esto utilizando "
 "el elemento <literal>&lt;typedef&gt;</literal>. Los typedefs asignan un "
-"nombre a un tipo personalizado, y pueden tambi&#x00e9;n contener una lista "
-"de valores por defecto de par&#x00e1;metros si el tipo fuese parametrizado."
+"nombre a un tipo personalizado y también pueden contener una lista de "
+"valores predeterminados de parámetros si el tipo se encuentra parametrizado."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2787
-#, no-c-format
-msgid ""
-"<![CDATA[<typedef class=\"com.mycompany.usertypes.DefaultValueIntegerType\" "
-"name=\"default_zero\">\n"
-"    <param name=\"default\">0</param>\n"
-"</typedef>]]>"
-msgstr ""
-"<![CDATA[<typedef class=\"com.mycompany.usertypes.DefaultValueIntegerType\" "
-"name=\"default_zero\">\n"
-"    <param name=\"default\">0</param>\n"
-"</typedef>]]>"
-
-#. Tag: programlisting
-#: basic_mapping.xml:2789
-#, no-c-format
-msgid "<![CDATA[<property name=\"priority\" type=\"default_zero\"/>]]>"
-msgstr "<![CDATA[<property name=\"priority\" type=\"default_zero\"/>]]>"
-
 #. Tag: para
-#: basic_mapping.xml:2791
 #, no-c-format
 msgid ""
 "It is also possible to override the parameters supplied in a typedef on a "
 "case-by-case basis by using type parameters on the property mapping."
 msgstr ""
-"tambi&#x00e9;n es posible sobrescribir los par&#x00e1;metros provistos en un "
-"typedef sobre una base caso por caso usando par&#x00e1;metros de tipo en el "
-"mapeo de la propiedad."
+"También es posible sobrescribir los parámetros provistos en un typedef sobre "
+"una base de caso por caso utilizando parámetros de tipo en el mapeo de la "
+"propiedad."
 
 #. Tag: para
-#: basic_mapping.xml:2796
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Even though Hibernate's rich range of built-in types and support for "
 "components means you will rarely need to use a custom type, it is considered "
@@ -5721,26 +3990,24 @@
 "is abstraction. With a custom type, your mapping documents would be "
 "protected against changes to the way monetary values are represented."
 msgstr ""
-"Aunque el rico espectro de tipos prefabricados y soporte de componentes de "
-"Hibernate significa que raramente <emphasis>necesites</emphasis> usar un "
-"tipo personalizado; sin embargo se considera una buena forma usar tipos "
-"personalizados para clases (no-entidades) que aparezcan frecuentemente en tu "
-"aplicaci&#x00f3;n. Por ejemplo, una clase <literal>MonetaryAmount</literal> "
-"es una buena candidata para un <literal>CompositeUserType</literal>, incluso "
-"cuando puede ser facilmente mapeada como un componente. Un motivo para esto "
-"es la abstracci&#x00f3;n. Con un tipo personalizado, tus documentos de mapeo "
-"estar&#x00e1; impermeabilizados contra posibles cambios futuros en la forma "
-"de representar valores monetarios."
+"Aunque el amplio espectro de tipos incorporados y de soporte para los "
+"componentes de Hibernate significa que necesitará usar un tipo personalizado "
+"muy raramente, se considera como una buena práctica el utilizar tipos "
+"personalizados para clases no-entidades que aparezcan frecuentemente en su "
+"aplicación. Por ejemplo, una clase <literal>MonetaryAmount</literal> es una "
+"buena candidata para un <literal>CompositeUserType</literal>, incluso cuando "
+"puede ser fácilmente mapeada como un componente. Un razón para esto es la "
+"abstracción. Con un tipo personalizado, sus documentos de mapeo estarán "
+"protegidos contra posibles cambios futuros en la forma de representar "
+"valores monetarios."
 
 #. Tag: title
-#: basic_mapping.xml:2812
 #, no-c-format
 msgid "Mapping a class more than once"
-msgstr "Mapeando una clase m&#x00e1;s de una vez"
+msgstr "Mapeo de una clase más de una vez"
 
 #. Tag: para
-#: basic_mapping.xml:2813
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to provide more than one mapping for a particular persistent "
 "class. In this case, you must specify an <emphasis>entity name</emphasis> to "
@@ -5749,73 +4016,30 @@
 "entity name when working with persistent objects, when writing queries, or "
 "when mapping associations to the named entity."
 msgstr ""
-"Es posible proveer m&#x00e1;s de un mapeo para una clase persistente en "
-"particular. En este caso debes especificar un <emphasis>nombre de entidad</"
-"emphasis> para desambiguar entr las instancias de las dos entidades "
-"mapeadas. (Por defectom, el nombre de la entidad es el mismo que el nombre "
-"de la clase.) Hibernate te deja especificar el nombre de entidad al trabajar "
-"con objetos persistentes, al escribir consultas, o al mapear asociaciones a "
-"la entidad mencionada."
+"Es posible proporcionar más de un mapeo para una clase persistente en "
+"particular. En este caso usted debe especificar un <emphasis>nombre de "
+"entidad</emphasis> para aclarar entre las instancias de las dos entidades "
+"mapeadas. Por defecto, el nombre de la entidad es el mismo que el nombre de "
+"la clase. Hibernate le deja especificar el nombre de entidad al trabajar con "
+"objetos persistentes, al escribir consultas, o al mapear asociaciones a la "
+"entidad mencionada."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2821
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Contract\" table=\"Contracts\"\n"
-"        entity-name=\"CurrentContract\">\n"
-"    ...\n"
-"    <set name=\"history\" inverse=\"true\"\n"
-"            order-by=\"effectiveEndDate desc\">\n"
-"        <key column=\"currentContractId\"/>\n"
-"        <one-to-many entity-name=\"HistoricalContract\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Contract\" table=\"ContractHistory\"\n"
-"        entity-name=\"HistoricalContract\">\n"
-"    ...\n"
-"    <many-to-one name=\"currentContract\"\n"
-"            column=\"currentContractId\"\n"
-"            entity-name=\"CurrentContract\"/>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Contract\" table=\"Contracts\" \n"
-"        entity-name=\"CurrentContract\">\n"
-"    ...\n"
-"    <set name=\"history\" inverse=\"true\" \n"
-"            order-by=\"effectiveEndDate desc\">\n"
-"        <key column=\"currentContractId\"/>\n"
-"        <one-to-many entity-name=\"HistoricalContract\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Contract\" table=\"ContractHistory\" \n"
-"        entity-name=\"HistoricalContract\">\n"
-"    ...\n"
-"    <many-to-one name=\"currentContract\" \n"
-"            column=\"currentContractId\" \n"
-"            entity-name=\"CurrentContract\"/>\n"
-"</class>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:2823
-#, fuzzy, no-c-format
-msgid ""
 "Associations are now specified using <literal>entity-name</literal> instead "
 "of <literal>class</literal>."
 msgstr ""
-"Observa c&#x00f3;mo las asociaciones ahora se especifican usando "
-"<literal>entity-name</literal> en vez de <literal>class</literal>."
+"Las asociaciones ahora se especifican utilizando <literal>entity-name</"
+"literal> en lugar de <literal>class</literal>."
 
 #. Tag: title
-#: basic_mapping.xml:2831
 #, no-c-format
 msgid "SQL quoted identifiers"
-msgstr "identificadores SQL encomillados"
+msgstr "Identificadores SQL en comillas"
 
 #. Tag: para
-#: basic_mapping.xml:2832
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can force Hibernate to quote an identifier in the generated SQL by "
 "enclosing the table or column name in backticks in the mapping document. "
@@ -5823,55 +4047,33 @@
 "literal>. This is usually double quotes, but the SQL Server uses brackets "
 "and MySQL uses backticks."
 msgstr ""
-"Puedes forzar a Hibernate a encomillar un identificador en el SQL generado "
-"encerrando el nombre de tabla o columna entre backticks en el documento de "
-"mapeo. Hibernate usar&#x00e1; el estilo de encomillado para el "
-"<literal>Dialect</literal> SQL (usualmente comillas dobles, excepto "
-"corchetes para SQL Server y backsticks para MySQL)."
+"Puede forzar a Hibernate a que utilice comillas con un identificador en el "
+"SQL generado encerrando el nombre de tabla o de columna entre comillas "
+"sencillas en el documento de mapeo. Hibernate utilizará el estilo de "
+"comillas para el <literal>Dialect</literal> SQL. Usualmente comillas dobles, "
+"a excepción de corchetes para SQL Server y comillas sencillas para MySQL."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2839
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"LineItem\" table=\"`Line Item`\">\n"
-"    <id name=\"id\" column=\"`Item Id`\"/><generator class=\"assigned\"/></"
-"id>\n"
-"    <property name=\"itemNumber\" column=\"`Item #`\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"LineItem\" table=\"`Line Item`\">\n"
-"    <id name=\"id\" column=\"`Item Id`\"/><generator class=\"assigned\"/></"
-"id>\n"
-"    <property name=\"itemNumber\" column=\"`Item #`\"/>\n"
-"    ...\n"
-"</class>]]>"
-
 #. Tag: title
-#: basic_mapping.xml:2845
 #, no-c-format
 msgid "Metadata alternatives"
 msgstr "Alternativas de metadatos"
 
 #. Tag: para
-#: basic_mapping.xml:2847
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "XML does not suit all users so there are some alternative ways to define O/R "
 "mapping metadata in Hibernate."
 msgstr ""
-"XML no es para todos, as&#x00e1; que hay algunas formas alternativas de "
+"XML no es para todo el mundo, así que hay algunas formas opcionales de "
 "definir metadatos de mapeo O/R en Hibernate."
 
 #. Tag: title
-#: basic_mapping.xml:2852
 #, no-c-format
 msgid "Using XDoclet markup"
-msgstr "Usando marcado de XDoclet"
+msgstr "Utilización de marcado de XDoclet"
 
 #. Tag: para
-#: basic_mapping.xml:2854
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Many Hibernate users prefer to embed mapping information directly in "
 "sourcecode using XDoclet <literal>@hibernate.tags</literal>. We do not cover "
@@ -5879,244 +4081,26 @@
 "XDoclet. However, we include the following example of the <literal>Cat</"
 "literal> class with XDoclet mappings:"
 msgstr ""
-"Muchos usuarios de Hibernate prefieren embeber la informaci&#x00f3;n de "
-"mapeo directamente en el c&#x00f3;digo fuente usando las <literal>@hibernate."
-"etiquetas</literal> XDoclet. No cubriremos este enfoque en este documento, "
-"pues estrictamente es considerado parte de XDoclet. Sin embargo, "
-"inclu&#x00ed;mos el siguiente ejemplo de la clase <literal>Cat</literal> con "
-"mapeos XDoclet."
+"Muchos usuarios de Hibernate prefieren incluir la información de mapeo "
+"directamente en el código fuente usando las <literal>@hibernate.tags</"
+"literal> XDoclet. No abordaremos este enfoque en este manual de referencia "
+"ya que se considera como parte de XDoclet. Sin embargo, incluímos el "
+"siguiente ejemplo de la clase <literal>Cat</literal> con los mapeos XDoclet:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2861
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"import java.util.Date;\n"
-"\n"
-"/**\n"
-" * @hibernate.class\n"
-" *  table=\"CATS\"\n"
-" */\n"
-"public class Cat {\n"
-"    private Long id; // identifier\n"
-"    private Date birthdate;\n"
-"    private Cat mother;\n"
-"    private Set kittens\n"
-"    private Color color;\n"
-"    private char sex;\n"
-"    private float weight;\n"
-"\n"
-"    /*\n"
-"     * @hibernate.id\n"
-"     *  generator-class=\"native\"\n"
-"     *  column=\"CAT_ID\"\n"
-"     */\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"    private void setId(Long id) {\n"
-"        this.id=id;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.many-to-one\n"
-"     *  column=\"PARENT_ID\"\n"
-"     */\n"
-"    public Cat getMother() {\n"
-"        return mother;\n"
-"    }\n"
-"    void setMother(Cat mother) {\n"
-"        this.mother = mother;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"BIRTH_DATE\"\n"
-"     */\n"
-"    public Date getBirthdate() {\n"
-"        return birthdate;\n"
-"    }\n"
-"    void setBirthdate(Date date) {\n"
-"        birthdate = date;\n"
-"    }\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"WEIGHT\"\n"
-"     */\n"
-"    public float getWeight() {\n"
-"        return weight;\n"
-"    }\n"
-"    void setWeight(float weight) {\n"
-"        this.weight = weight;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"COLOR\"\n"
-"     *  not-null=\"true\"\n"
-"     */\n"
-"    public Color getColor() {\n"
-"        return color;\n"
-"    }\n"
-"    void setColor(Color color) {\n"
-"        this.color = color;\n"
-"    }\n"
-"    /**\n"
-"     * @hibernate.set\n"
-"     *  inverse=\"true\"\n"
-"     *  order-by=\"BIRTH_DATE\"\n"
-"     * @hibernate.collection-key\n"
-"     *  column=\"PARENT_ID\"\n"
-"     * @hibernate.collection-one-to-many\n"
-"     */\n"
-"    public Set getKittens() {\n"
-"        return kittens;\n"
-"    }\n"
-"    void setKittens(Set kittens) {\n"
-"        this.kittens = kittens;\n"
-"    }\n"
-"    // addKitten not needed by Hibernate\n"
-"    public void addKitten(Cat kitten) {\n"
-"        kittens.add(kitten);\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"SEX\"\n"
-"     *  not-null=\"true\"\n"
-"     *  update=\"false\"\n"
-"     */\n"
-"    public char getSex() {\n"
-"        return sex;\n"
-"    }\n"
-"    void setSex(char sex) {\n"
-"        this.sex=sex;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"import java.util.Date;\n"
-"\n"
-"/**\n"
-" * @hibernate.class\n"
-" *  table=\"CATS\"\n"
-" */\n"
-"public class Cat {\n"
-"    private Long id; // identifier\n"
-"    private Date birthdate;\n"
-"    private Cat mother;\n"
-"    private Set kittens\n"
-"    private Color color;\n"
-"    private char sex;\n"
-"    private float weight;\n"
-"\n"
-"    /*\n"
-"     * @hibernate.id\n"
-"     *  generator-class=\"native\"\n"
-"     *  column=\"CAT_ID\"\n"
-"     */\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"    private void setId(Long id) {\n"
-"        this.id=id;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.many-to-one\n"
-"     *  column=\"PARENT_ID\"\n"
-"     */\n"
-"    public Cat getMother() {\n"
-"        return mother;\n"
-"    }\n"
-"    void setMother(Cat mother) {\n"
-"        this.mother = mother;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"BIRTH_DATE\"\n"
-"     */\n"
-"    public Date getBirthdate() {\n"
-"        return birthdate;\n"
-"    }\n"
-"    void setBirthdate(Date date) {\n"
-"        birthdate = date;\n"
-"    }\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"WEIGHT\"\n"
-"     */\n"
-"    public float getWeight() {\n"
-"        return weight;\n"
-"    }\n"
-"    void setWeight(float weight) {\n"
-"        this.weight = weight;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"COLOR\"\n"
-"     *  not-null=\"true\"\n"
-"     */\n"
-"    public Color getColor() {\n"
-"        return color;\n"
-"    }\n"
-"    void setColor(Color color) {\n"
-"        this.color = color;\n"
-"    }\n"
-"    /**\n"
-"     * @hibernate.set\n"
-"     *  inverse=\"true\"\n"
-"     *  order-by=\"BIRTH_DATE\"\n"
-"     * @hibernate.collection-key\n"
-"     *  column=\"PARENT_ID\"\n"
-"     * @hibernate.collection-one-to-many\n"
-"     */\n"
-"    public Set getKittens() {\n"
-"        return kittens;\n"
-"    }\n"
-"    void setKittens(Set kittens) {\n"
-"        this.kittens = kittens;\n"
-"    }\n"
-"    // addKitten not needed by Hibernate\n"
-"    public void addKitten(Cat kitten) {\n"
-"        kittens.add(kitten);\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"SEX\"\n"
-"     *  not-null=\"true\"\n"
-"     *  update=\"false\"\n"
-"     */\n"
-"    public char getSex() {\n"
-"        return sex;\n"
-"    }\n"
-"    void setSex(char sex) {\n"
-"        this.sex=sex;\n"
-"    }\n"
-"}]]>"
-
 #. Tag: para
-#: basic_mapping.xml:2863
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "See the Hibernate website for more examples of XDoclet and Hibernate."
 msgstr ""
-"Para m&#x00e1;s ejemplos de XDoclet e Hibernate ver en el sitio web de "
-"Hibernate."
+"Para obtener más ejemplos de XDoclet e Hibernate consulte el sitio web de "
+"Hibernate. "
 
 #. Tag: title
-#: basic_mapping.xml:2870
 #, no-c-format
 msgid "Using JDK 5.0 Annotations"
-msgstr "Usando anotaciones JDK 5.0"
+msgstr "Utlización de Anotaciones JDK 5.0"
 
 #. Tag: para
-#: basic_mapping.xml:2872
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "JDK 5.0 introduced XDoclet-style annotations at the language level that are "
 "type-safe and checked at compile time. This mechanism is more powerful than "
@@ -6129,98 +4113,43 @@
 "<emphasis>Hibernate Annotations</emphasis> package as a separate download. "
 "Both EJB3 (JSR-220) and Hibernate3 metadata is supported."
 msgstr ""
-"El JDK 5.0 introdujo anotaciones del estilo XDoclet a nivel del lenguaje, "
-"con chequeo seguro de tipos en tiempo de compilaci&#x00f3;n. Este mecanismo "
-"es m&#x00e1;s potente y que las anotaciones XDoclet, y mejor soportado por "
-"herramientas e IDEs. IntelliJ IDEA, por ejemplo, soporta auto-"
-"compleci&#x00f3;n y resaltado de sintaxis de anotaciones JDK 5.0. La nueva "
-"revisi&#x00f3;n de la especificaci&#x00f3;n de EJB (JSR-220) usa anotaciones "
-"JDK 5.0 como el mecanismo primario de metadatos para beans de entidad. "
-"Hibernate3 implementa el <literal>EntityManager</literal> del JSR-220 (la "
-"API de persistencia), y el soporte para metadatos de mapeo est&#x00e1; "
-"disponible v&#x00ed;a el paquete <emphasis>Hibernate Annotations</emphasis>, "
-"como una descarga por separado. Tanto metadatos de EJB3 (JSR-220) como de "
-"Hibernate3 est&#x00e1;n soportados."
+"JDK 5.0 introdujo anotaciones del estilo XDoclet a nivel del lenguaje con "
+"chequeo seguro de tipos en tiempo de compilación. Este mecanismo es más "
+"potente que las anotaciones XDoclet y es mejor soportado por herramientas e "
+"IDEs. IntelliJ IDEA, por ejemplo, soporta auto-completación además de "
+"resalte de sintaxis de las anotaciones JDK 5.0. La nueva revisión de la "
+"especificación de EJB (JSR-220) utiliza anotaciones JDK 5.0 como el "
+"mecanismo principal de metadatos para beans de entidad. Hibernate3 "
+"implementa el <literal>EntityManager</literal> del JSR-220 (la API de "
+"persistencia). El soporte para metadatos de mapeo está disponible por medio "
+"del paquete <emphasis>Anotaciones de Hibernate</emphasis>, como una descarga "
+"separada. Tanto los metadatos de EJB3 (JSR-220) como de Hibernate3 se "
+"encuentran soportados."
 
 #. Tag: para
-#: basic_mapping.xml:2883
 #, no-c-format
 msgid "This is an example of a POJO class annotated as an EJB entity bean:"
 msgstr ""
 "Este es un ejemplo de una clase POJO anotada como un bean de entidad EJB:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2887
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[@Entity(access = AccessType.FIELD)\n"
-"public class Customer implements Serializable {\n"
-"\n"
-"    @Id;\n"
-"    Long id;\n"
-"\n"
-"    String firstName;\n"
-"    String lastName;\n"
-"    Date birthday;\n"
-"\n"
-"    @Transient\n"
-"    Integer age;\n"
-"\n"
-"    @Embedded\n"
-"    private Address homeAddress;\n"
-"\n"
-"    @OneToMany(cascade=CascadeType.ALL)\n"
-"    @JoinColumn(name=\"CUSTOMER_ID\")\n"
-"    Set<Order> orders;\n"
-"\n"
-"    // Getter/setter and business methods\n"
-"}]]>"
-msgstr ""
-"<![CDATA[@Entity(access = AccessType.FIELD)\n"
-"public class Customer implements Serializable {\n"
-"\n"
-"    @Id;\n"
-"    Long id;\n"
-"\n"
-"    String firstName;\n"
-"    String lastName;\n"
-"    Date birthday;\n"
-"\n"
-"    @Transient\n"
-"    Integer age;\n"
-"\n"
-"    @Embedded\n"
-"    private Address homeAddress;\n"
-"\n"
-"    @OneToMany(cascade=CascadeType.ALL)\n"
-"\n"
-"    @JoinColumn(name=\"CUSTOMER_ID\")\n"
-"    Set<Order> orders;\n"
-"\n"
-"    // Getter/setter and business methods\n"
-"}]]>"
-
-#. Tag: para
-#: basic_mapping.xml:2891
-#, fuzzy, no-c-format
-msgid ""
 "Support for JDK 5.0 Annotations (and JSR-220) is currently under "
 "development. Please refer to the Hibernate Annotations module for more "
 "details."
 msgstr ""
-"Ten en cuenta que el soporte a anotaciones JDK 5.0 (y JSR-220) es "
-"todav&#x00ed;a un trabajo en progreso y no completado. Por favor, para "
-"m&#x00e1;s detalles refi&#x00e9;rete al modulo de Anotaciones de Hibernate."
+"El soporte para las anotaciones JDK 5.0 (y JSR-220) todavía se encuentra en "
+"progreso. Para obtener más información consulte al módulo de anotaciones de "
+"Hibernate."
 
 #. Tag: title
-#: basic_mapping.xml:2901
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Generated properties"
-msgstr "UNTRANSLATED! Generated Properties"
+msgstr "Propiedades generadas"
 
 #. Tag: para
-#: basic_mapping.xml:2902
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Generated properties are properties that have their values generated by the "
 "database. Typically, Hibernate applications needed to <literal>refresh</"
@@ -6230,17 +4159,16 @@
 "an SQL INSERT or UPDATE for an entity that has defined generated properties, "
 "it immediately issues a select afterwards to retrieve the generated values."
 msgstr ""
-"Generated properties are properties which have their values generated by the "
-"database. Typically, Hibernate applications needed to <literal>refresh</"
-"literal> objects which contain any properties for which the database was "
-"generating values. Marking properties as generated, however, lets the "
-"application delegate this responsibility to Hibernate. Essentially, whenever "
-"Hibernate issues an SQL INSERT or UPDATE for an entity which has defined "
-"generated properties, it immediately issues a select afterwards to retrieve "
-"the generated values."
+"Las propiedades generadas son propiedades cuyos valores son generados por la "
+"base de datos. Usualmente, las aplicaciones de Hibernate necesitaban "
+"<literal>refrescar</literal> los objetos que contenian cualquier propiedad "
+"para la cual la base de datos generará valores. Sin embargo, el marcar "
+"propiedades como generadas deja que la aplicación delegue esta "
+"responsabilidad a Hibernate. Cuando Hibernate emite un INSERT or UPDATE SQL "
+"para una entidad la cual ha definido propiedades generadas, inmediatamente "
+"emite un select para recuperar los valores generados."
 
 #. Tag: para
-#: basic_mapping.xml:2911
 #, fuzzy, no-c-format
 msgid ""
 "Properties marked as generated must additionally be non-insertable and non-"
@@ -6249,24 +4177,21 @@
 "and <link linkend=\"mapping-declaration-property\">simple properties</link>, "
 "can be marked as generated."
 msgstr ""
-"Properties marked as generated must additionally be non-insertable and non-"
-"updateable. Only <link linkend=\"mapping-declaration-version\">versions</"
-"link>, <link linkend=\"mapping-declaration-timestamp\">timestamps</link>, "
-"and <link linkend=\"mapping-declaration-property\">simple properties</link> "
-"can be marked as generated."
+"Las propiedades marcadas como generadas tienen que ser además no insertables "
+"y no actualizables. Sólamente las <xref linkend=\"mapping-declaration-version"
+"\" />, <xref linkend=\"mapping-declaration-timestamp\" /> y <xref linkend="
+"\"mapping-declaration-property\" /> se pueden marcar como generadas."
 
 #. Tag: para
-#: basic_mapping.xml:2918
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>never</literal> (the default): the given property value is not "
 "generated within the database."
 msgstr ""
-"<literal>never</literal> (the default) - means that the given property value "
-"is not generated within the database."
+"<literal>never</literal> (por defecto): el valor dado de la propiedad no es "
+"generado dentro de la base de datos."
 
 #. Tag: para
-#: basic_mapping.xml:2922
 #, fuzzy, no-c-format
 msgid ""
 "<literal>insert</literal>: the given property value is generated on insert, "
@@ -6276,32 +4201,73 @@
 "\">timestamp</link> properties can be marked as generated, this option is "
 "not available."
 msgstr ""
-"<literal>insert</literal> - states that the given property value is "
-"generated on insert, but is not regenerated on subsequent updates. Things "
-"like created-date would fall into this category. Note that even thought "
-"<link linkend=\"mapping-declaration-version\">version</link> and <link "
-"linkend=\"mapping-declaration-timestamp\">timestamp</link> properties can be "
-"marked as generated, this option is not available there..."
+"<literal>insert</literal>: el valor dado de la propiedad es generado en "
+"insert, pero no es regenerado en actualizaciones posteriores. Las "
+"propiedades como fecha-creada (created-date) se encuentran dentro de esta "
+"categoría. Aunque las propiedades <xref linkend=\"mapping-declaration-version"
+"\" /> y <xref linkend=\"mapping-declaration-timestamp\" /> se pueden marcar "
+"como generadas, esta opción no se encuentra disponible."
 
 #. Tag: para
-#: basic_mapping.xml:2930
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>always</literal>: the property value is generated both on insert "
 "and on update."
 msgstr ""
-"<literal>always</literal> - states that the property value is generated both "
-"on insert and on update."
+"<literal>always</literal>: el valor de la propiedad es generado tanto en "
+"insert como en update."
 
 #. Tag: title
-#: basic_mapping.xml:2937
-#, fuzzy, no-c-format
+#, no-c-format
+msgid "Column read and write expressions"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Hibernate allows you to customize the SQL it uses to read and write the "
+"values of columns mapped to <link linkend=\"mapping-declaration-property"
+"\">simple properties</link>. For example, if your database provides a set of "
+"data encryption functions, you can invoke them for individual columns like "
+"this: <programlisting role=\"XML\">&lt;property name=\"creditCardNumber"
+"\"&gt; &lt;column name=\"credit_card_num\" read=\"decrypt(credit_card_num)\" "
+"write=\"encrypt(?)\"/&gt; &lt;/property&gt;</programlisting>"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Hibernate applies the custom expressions automatically whenever the property "
+"is referenced in a query. This functionality is similar to a derived-"
+"property <literal>formula</literal> with two differences:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"The property is backed by one or more columns that are exported as part of "
+"automatic schema generation."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "The property is read-write, not read-only."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"The <literal>write</literal> expression, if specified, must contain exactly "
+"one '?' placeholder for the value."
+msgstr ""
+
+#. Tag: title
+#, no-c-format
 msgid "Auxiliary database objects"
-msgstr "UNTRANSLATED! Auxiliary Database Objects"
+msgstr "Objetos de bases de datos auxiliares"
 
 #. Tag: para
-#: basic_mapping.xml:2938
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Auxiliary database objects allow for the CREATE and DROP of arbitrary "
 "database objects. In conjunction with Hibernate's schema evolution tools, "
@@ -6312,154 +4278,43 @@
 "example, ALTERs, INSERTS, etc.). There are essentially two modes for "
 "defining auxiliary database objects:"
 msgstr ""
-"Allows CREATE and DROP of arbitrary database objects, in conjunction with "
-"Hibernate's schema evolution tools, to provide the ability to fully define a "
-"user schema within the Hibernate mapping files. Although designed "
-"specifically for creating and dropping things like triggers or stored "
-"procedures, really any SQL command that can be run via a <literal>java.sql."
-"Statement.execute()</literal> method is valid here (ALTERs, INSERTS, etc). "
-"There are essentially two modes for defining auxiliary database objects..."
+"Los objetos de bases de datos auxiliares permiten la creación - CREATE - y "
+"eliminación - DROP - de objetos de bases de datos arbitrarios. Junto con las "
+"herramientas de evolución del esquema de Hibernate, tienen la habilidad de "
+"definir de manera completa el esquema de un usuario dentro de los archivos "
+"de mapeo de Hibernate. Aunque están diseñados específicamente para crear y "
+"eliminar cosas como disparadores - triggers- o procedimientos almacenados, "
+"realmente cualquier comando SQL se puede ejecutar por medio de un método "
+"<literal>java.sql.Statement.execute()</literal> aquí es válido (por ejemplo, "
+"ALTERs, INSERTS, etc). Básicamente, hay dos modos para definir objetos de "
+"bases de datos auxiliares:"
 
 #. Tag: para
-#: basic_mapping.xml:2947
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The first mode is to explicitly list the CREATE and DROP commands in the "
 "mapping file:"
 msgstr ""
-"The first mode is to explicitly list the CREATE and DROP commands out in the "
-"mapping file:"
+"El primer modo es para numerar explícitamente los comandos CREATE y DROP en "
+"el archivo de mapeo: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2951
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <create>CREATE TRIGGER my_trigger ...</create>\n"
-"        <drop>DROP TRIGGER my_trigger</drop>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<hibernate-mapping>\n"
-"                            ...\n"
-"                            <database-object>\n"
-"                                    <create>CREATE TRIGGER my_trigger ...</"
-"create>\n"
-"                                    <drop>DROP TRIGGER my_trigger</drop>\n"
-"                            </database-object>\n"
-"                    </hibernate-mapping>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:2952
-#, fuzzy, no-c-format
-msgid ""
 "The second mode is to supply a custom class that constructs the CREATE and "
 "DROP commands. This custom class must implement the <literal>org.hibernate."
 "mapping.AuxiliaryDatabaseObject</literal> interface."
 msgstr ""
-"The second mode is to supply a custom class which knows how to construct the "
-"CREATE and DROP commands. This custom class must implement the <literal>org."
-"hibernate.mapping.AuxiliaryDatabaseObject</literal> interface."
+"El segundo modo es para proporcionar una clase personalizada que construye "
+"los comandos CREATE y DROP. Esta clase personalizada tiene que implementar "
+"la interfaz <literal>org.hibernate.mapping.AuxiliaryDatabaseObject</literal>."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2957
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <definition class=\"MyTriggerDefinition\"/>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<hibernate-mapping>\n"
-"                            ...\n"
-"                            <database-object>\n"
-"                                    <definition class=\"MyTriggerDefinition"
-"\"/>\n"
-"                            </database-object>\n"
-"                    </hibernate-mapping>]]>"
-
-#. Tag: para
-#: basic_mapping.xml:2958
-#, fuzzy, no-c-format
-msgid ""
 "Additionally, these database objects can be optionally scoped so that they "
 "only apply when certain dialects are used."
 msgstr ""
-"Additionally, these database objects can be optionally scoped such that they "
-"only apply when certain dialects are used."
-
-#. Tag: programlisting
-#: basic_mapping.xml:2962
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <definition class=\"MyTriggerDefinition\"/>\n"
-"        <dialect-scope name=\"org.hibernate.dialect.Oracle9iDialect\"/>\n"
-"        <dialect-scope name=\"org.hibernate.dialect.Oracle10gDialect\"/>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<hibernate-mapping>\n"
-"                            ...\n"
-"                            <database-object>\n"
-"                                    <definition class=\"MyTriggerDefinition"
-"\"/>\n"
-"                                    <dialect-scope name=\"org.hibernate."
-"dialect.Oracle9Dialect\"/>\n"
-"                                    <dialect-scope name=\"org.hibernate."
-"dialect.OracleDialect\"/>\n"
-"                            </database-object>\n"
-"                    </hibernate-mapping>]]>"
-
-#~ msgid "<title>class</title>"
-#~ msgstr "<title>class</title>"
-
-#~ msgid ""
-#~ "<literal>type</literal> (optional): A name that indicates the Hibernate "
-#~ "type."
-#~ msgstr ""
-#~ "<literal>type</literal> (opcional): Un nombre que indica el tipo "
-#~ "Hibernate."
-
-#~ msgid ""
-#~ "<literal>cascade</literal> (optional): Specifies which operations should "
-#~ "be cascaded from the parent object to the associated object."
-#~ msgstr ""
-#~ "<literal>cascade</literal> (opcional): Especifica qu&#x00e9; operaciones "
-#~ "deben ir en cascada desde el objeto padre al objeto asociado"
-
-#~ msgid ""
-#~ "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
-#~ "literal>): Specifies that updates to this property do or do not require "
-#~ "acquisition of the optimistic lock. In other words, dertermines if a "
-#~ "version increment should occur when this property is dirty."
-#~ msgstr ""
-#~ "<literal>optimistic-lock</literal> (opcional - por defecto a "
-#~ "<literal>true</literal>): Especifica que las actualizaciones a esta "
-#~ "propiedad requieran o no la obtenci&#x00f3;n del bloqueo optimista. En "
-#~ "otras palabras, determina si debe darse un incremento de versi&#x00f3;n "
-#~ "cuando esta propiedad est&#x00e9; desactualizada."
-
-#~ msgid ""
-#~ "To understand the behaviour of various Java language-level objects with "
-#~ "respect to the persistence service, we need to classify them into two "
-#~ "groups:"
-#~ msgstr ""
-#~ "Para entender el comportamiento de varios objetos a nivel de lenguaje "
-#~ "Java con respecto al servicio de persistencia, necesitamos clasificarlos "
-#~ "en dos grupos:"
-
-#~ msgid "<literal>class</literal>"
-#~ msgstr "<literal>class</literal>"
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+"Adicionalmente, estos objetos de la base de datos se pueden incluir de "
+"manera opcional de forma que aplique sólamente cuando se utilicen ciertos "
+"dialectos. "

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/batch.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/batch.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/batch.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,249 +1,140 @@
-#, fuzzy
+# translation of batch.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: batch\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-07 10:48+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: batch.xml:29
 #, no-c-format
 msgid "Batch processing"
 msgstr "Procesamiento por lotes"
 
 #. Tag: para
-#: batch.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A naive approach to inserting 100,000 rows in the database using Hibernate "
 "might look like this:"
 msgstr ""
-"Un enfoque ingenuo para insertar 100.000 filas en la base de datos usando "
-"Hibernate podría verse así:"
+"Un enfoque ingenuo para insertar 100.000 filas en la base de datos "
+"utilizando Hibernate puede verse así: "
 
-#. Tag: programlisting
-#: batch.xml:36
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"}\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"}\n"
-"tx.commit();\n"
-"session.close();]]>"
-
-#. Tag: para
-#: batch.xml:38
-#, fuzzy, no-c-format
-msgid ""
 "This would fall over with an <literal>OutOfMemoryException</literal> "
 "somewhere around the 50,000th row. That is because Hibernate caches all the "
 "newly inserted <literal>Customer</literal> instances in the session-level "
 "cache. In this chapter we will show you how to avoid this problem."
 msgstr ""
-"Esto podría caer sobre una <literal>OutOfMemoryException</literal> en algún "
-"sitio cerca de la fila 50.000. Esto es porque Hibernate tiene en caché todas "
-"las instancias de <literal>Customer</literal> recién instanciadas en el "
-"caché de nivel de sesión."
+"Esto podría caer dentro de una <literal>OutOfMemoryException</literal> en "
+"algún sitio cerca de la fila 50.000. Esto se debe a que Hibernate tiene en "
+"caché todas las instancias de <literal>Customer</literal> recién insertadas "
+"en el caché de nivel de sesión. En este capítulo le vamos a mostrar cómo "
+"evitar este problema."
 
 #. Tag: para
-#: batch.xml:45
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are undertaking batch processing you will need to enable the use of "
 "JDBC batching. This is absolutely essential if you want to achieve optimal "
 "performance. Set the JDBC batch size to a reasonable number (10-50, for "
 "example):"
 msgstr ""
-"En este capítulo te mostraremos cómo evitar este problema. Primero, sin "
-"embargo, si estás haciendo procesamiento por lotes (batch processing), es "
-"absolutamente crítico que habilites el uso de loteo JDBC, si pretendes "
-"lograr un rendimiento razonable. Establece el tamaño de lote JDBC a un "
-"número razonable (digamos 10-50):"
+"Si está realizando un procesamiento por lotes (batch processing), es "
+"necesario que habilite el uso del lote JDBC. Esto es esencial si quiere "
+"lograr un rendimiento óptimo. Establezca el tamaño de lote JDBC con un "
+"número razonable (por ejemplo, 10-50):"
 
-#. Tag: programlisting
-#: batch.xml:52
-#, no-c-format
-msgid "<![CDATA[hibernate.jdbc.batch_size 20]]>"
-msgstr "<![CDATA[hibernate.jdbc.batch_size 20]]>"
-
 #. Tag: para
-#: batch.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate disables insert batching at the JDBC level transparently if you "
 "use an <literal>identity</literal> identifier generator."
 msgstr ""
-"UNTRANSLATED! Note that Hibernate disables insert batching at the JDBC level "
-"transparently if you use an <literal>identiy</literal> identifier generator."
+"Hibernate desactiva el lote de inserción a nivel de JDBC de forma "
+"transparente si usted utiliza un generador de identificador "
+"<literal>identiy</literal>."
 
 #. Tag: para
-#: batch.xml:59
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also do this kind of work in a process where interaction with the "
 "second-level cache is completely disabled:"
 msgstr ""
-"Podrías además querer hacer este tipo de trabajo en un proceso donde la "
-"interacción con el caché de segundo nivel esté completamente deshabilitado:"
+"También puede realizar este tipo de trabajo en un proceso en donde la "
+"interacción con el caché de segundo nivel se encuentre completamente "
+"desactivado:"
 
-#. Tag: programlisting
-#: batch.xml:64
-#, no-c-format
-msgid "<![CDATA[hibernate.cache.use_second_level_cache false]]>"
-msgstr "<![CDATA[hibernate.cache.use_second_level_cache false]]>"
-
 #. Tag: para
-#: batch.xml:66
 #, no-c-format
 msgid ""
 "However, this is not absolutely necessary, since we can explicitly set the "
 "<literal>CacheMode</literal> to disable interaction with the second-level "
 "cache."
 msgstr ""
-"UNTRANSLATED! However, this is not absolutely necessary, since we can "
-"explicitly set the <literal>CacheMode</literal> to disable interaction with "
-"the second-level cache."
+"Sin embargo, esto no es absolutamente necesario ya que podemos establecer "
+"explícitamente el <literal>CacheMode</literal> para descativar la "
+"interacción con el caché de segundo nivel."
 
 #. Tag: title
-#: batch.xml:72
 #, no-c-format
 msgid "Batch inserts"
-msgstr "Inserciones en lote"
+msgstr "Inserciones de lotes"
 
 #. Tag: para
-#: batch.xml:74
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When making new objects persistent <literal>flush()</literal> and then "
 "<literal>clear()</literal> the session regularly in order to control the "
 "size of the first-level cache."
 msgstr ""
-"Al hacer persistentes objetos nuevos, debes limpiar con <literal>flush()</"
-"literal> y llamar a <literal>clear()</literal> en la sesión regularmente, "
-"para controlar el tamaño del caché de primer nivel."
+"Al hacer persistentes los objetos nuevos es necesario que realice "
+"<literal>flush()</literal> y luego <literal>clear()</literal> en la sesión "
+"regularmente para controlar el tamaño del caché de primer nivel."
 
-#. Tag: programlisting
-#: batch.xml:80
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"    if ( i % 20 == 0 ) { //20, same as the JDBC batch size\n"
-"        //flush a batch of inserts and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"    if ( i % 20 == 0 ) { //20, same as the JDBC batch size\n"
-"        //flush a batch of inserts and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-
 #. Tag: title
-#: batch.xml:85
 #, no-c-format
 msgid "Batch updates"
-msgstr "Actualizaciones en lote"
+msgstr "Actualizaciones de lotes update/delete en masa"
 
 #. Tag: para
-#: batch.xml:87
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For retrieving and updating data, the same ideas apply. In addition, you "
 "need to use <literal>scroll()</literal> to take advantage of server-side "
 "cursors for queries that return many rows of data."
 msgstr ""
-"Para recuperar y actualizar datos se aplican las mismas ideas. "
-"Adicionalmente, necesitas usar <literal>scroll()</literal> para sacar "
-"ventaja de los cursores del lado del servidor en consultas que devuelvan "
-"muchas filas de datos."
+"Para recuperar y actualizar datos se aplican las mismas ideas. Además, "
+"necesita utilizar <literal>scroll()</literal> para sacar ventaja de los "
+"cursores del lado del servidor en consultas que retornen muchas filas de "
+"datos."
 
-#. Tag: programlisting
-#: batch.xml:93
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-"    .setCacheMode(CacheMode.IGNORE)\n"
-"    .scroll(ScrollMode.FORWARD_ONLY);\n"
-"int count=0;\n"
-"while ( customers.next() ) {\n"
-"    Customer customer = (Customer) customers.get(0);\n"
-"    customer.updateStuff(...);\n"
-"    if ( ++count % 20 == 0 ) {\n"
-"        //flush a batch of updates and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-"    .setCacheMode(CacheMode.IGNORE)\n"
-"    .scroll(ScrollMode.FORWARD_ONLY);\n"
-"int count=0;\n"
-"while ( customers.next() ) {\n"
-"    Customer customer = (Customer) customers.get(0);\n"
-"    customer.updateStuff(...);\n"
-"    if ( ++count % 20 == 0 ) {\n"
-"        //flush a batch of updates and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-
 #. Tag: title
-#: batch.xml:98
 #, no-c-format
 msgid "The StatelessSession interface"
-msgstr "UNTRANSLATED! The StatelessSession interface"
+msgstr "La interfaz de Sesión sin Estado"
 
 #. Tag: para
-#: batch.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, Hibernate provides a command-oriented API that can be used "
 "for streaming data to and from the database in the form of detached objects. "
@@ -259,74 +150,35 @@
 "effects. A stateless session is a lower-level abstraction that is much "
 "closer to the underlying JDBC."
 msgstr ""
-"Alternatively, Hibernate provides a command-oriented API that may be used "
-"for streaming data to and from the database in the form of detached objects. "
-"A <literal>StatelessSession</literal> has no persistence context associated "
-"with it and does not provide many of the higher-level life cycle semantics. "
-"In particular, a stateless session does not implement a first-level cache "
-"nor interact with any second-level or query cache. It does not implement "
-"transactional write-behind or automatic dirty checking. Operations performed "
-"using a stateless session do not ever cascade to associated instances. "
-"Collections are ignored by a stateless session. Operations performed via a "
-"stateless session bypass Hibernate's event model and interceptors. Stateless "
-"sessions are vulnerable to data aliasing effects, due to the lack of a first-"
-"level cache. A stateless session is a lower-level abstraction, much closer "
-"to the underlying JDBC."
+"Opcionalmente, Hibernate proporciona una API orientada a comandos que se "
+"puede utilizar para datos que concurren desde y hacia la base de datos en "
+"forma de objetos separados. Un <literal>StatelessSession</literal> no tiene "
+"un contexto de persistencia asociado con él y no proporciona mucha de la "
+"semántica a un alto nivel de ciclo de vida. En particular, una sesión sin "
+"estado no implementa un caché en primer nivel y tampoco interactúa con "
+"cachés de segundo nivel o de peticiones. No implementa escritura-retrasada "
+"transaccional o chequeo de desactualizaciones automático. Las operaciones "
+"realizadas con la utilización de una sesión sin estado nunca usan cascadas "
+"para las instancias asociadas. La sesión sin estado ignora las colecciones. "
+"Las operaciones llevadas a cabo por una sesión sin estado ignoran el modelo "
+"de evento y los interceptores de Hibernte. Las sesiones sin estado son "
+"vulnerables a efectos de sobrenombamiento de datos debido a la falta de un "
+"caché de primer nivel. Una sesión sin estado es una abstracción en un nivel "
+"más bajo, mucho más cerca del JDBC subyacente."
 
-#. Tag: programlisting
-#: batch.xml:114
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[StatelessSession session = sessionFactory.openStatelessSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-"    .scroll(ScrollMode.FORWARD_ONLY);\n"
-"while ( customers.next() ) {\n"
-"    Customer customer = (Customer) customers.get(0);\n"
-"    customer.updateStuff(...);\n"
-"    session.update(customer);\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-"<![CDATA[StatelessSession session = sessionFactory.openStatelessSession();\n"
-"                                                      Transaction tx = "
-"session.beginTransaction();\n"
-"                                                      \n"
-"                                                      ScrollableResults "
-"customers = session.getNamedQuery(\"GetCustomers\")\n"
-"                                                      .scroll(ScrollMode."
-"FORWARD_ONLY);\n"
-"                                                      while ( customers.next"
-"() ) {\n"
-"                                                      Customer customer = "
-"(Customer) customers.get(0);\n"
-"                                                      customer.updateStuff"
-"(...);\n"
-"                                                      session.update"
-"(customer);\n"
-"                                                      }\n"
-"                                                      \n"
-"                                                      tx.commit();\n"
-"                                                      session.close();]]>"
-
-#. Tag: para
-#: batch.xml:116
-#, fuzzy, no-c-format
-msgid ""
 "In this code example, the <literal>Customer</literal> instances returned by "
 "the query are immediately detached. They are never associated with any "
 "persistence context."
 msgstr ""
-"Note that in this code example, the <literal>Customer</literal> instances "
-"returned by the query are immediately detached. They are never associated "
-"with any persistence context."
+"En este código de ejemplo, las instancias <literal>Customer</literal> "
+"retornadas por la petición se separan inmediatamente. Nunca se asocian con "
+"ningún contexto de persistencia."
 
 #. Tag: para
-#: batch.xml:122
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>insert(), update()</literal> and <literal>delete()</literal> "
 "operations defined by the <literal>StatelessSession</literal> interface are "
@@ -336,23 +188,21 @@
 "<literal>save(), saveOrUpdate()</literal> and <literal>delete()</literal> "
 "operations defined by the <literal>Session</literal> interface."
 msgstr ""
-"The <literal>insert(), update()</literal> and <literal>delete()</literal> "
-"operations defined by the <literal>StatelessSession</literal> interface are "
-"considered to be direct database row-level operations, which result in "
-"immediate execution of a SQL <literal>INSERT, UPDATE</literal> or "
-"<literal>DELETE</literal> respectively. Thus, they have very different "
-"semantics to the <literal>save(), saveOrUpdate()</literal> and "
-"<literal>delete()</literal> operations defined by the <literal>Session</"
-"literal> interface."
+"Las operaciones <literal>insert(), update()</literal> y <literal>delete()</"
+"literal> definidas por la interfaz <literal>StatelessSession</literal> son "
+"consideradas como operaciones directas a nivel de filas de la base de datos. "
+"Esto resulta en una ejecución inmediata de un <literal>INSERT, UPDATE</"
+"literal> SQL o <literal>DELETE</literal> respectivamente. Tienen una "
+"semántica diferente a la de las operaciones <literal>save(), saveOrUpdate()</"
+"literal> y <literal>delete()</literal> definidas por la interfaz "
+"<literal>Session</literal>. "
 
 #. Tag: title
-#: batch.xml:135
 #, no-c-format
 msgid "DML-style operations"
-msgstr "update/delete en masa"
+msgstr "Operaciones de estilo DML"
 
 #. Tag: para
-#: batch.xml:137
 #, fuzzy, no-c-format
 msgid ""
 "As already discussed, automatic and transparent object/relational mapping is "
@@ -365,122 +215,82 @@
 "is performed through the Hibernate Query Language (<link linkend=\"queryhql"
 "\">HQL</link>)."
 msgstr ""
-"Como ya se ha discutido, el mapeo objeto/relacional automático y "
-"transparente se refiere al manejo de estado de objetos. Esto implica que el "
-"estado del objeto está disponible en memoria, por lo tanto actualizar o "
-"borrar (usando <literal>UPDATE</literal> y <literal>DELETE</literal> de SQL) "
-"datos directamente en la base de datos no afectará el estado en memoria. Sin "
-"embargo, Hibernate provee métodos para la ejecución de sentencias del estilo "
-"de <literal>UPDATE</literal> y <literal>DELETE</literal> de SQL que se "
-"realizan a través del Lenguaje de Consulta de Hibernate (Hibernate Query "
-"Language o <xref linkend=\"queryhql\"/>HQL)."
+"Como se discutió anteriormente, el mapeo objeto/relacional transparente se "
+"refiere a la administración del estado de objetos. El estado del objeto está "
+"disponible en la memoria. Por lo tanto al manipular datos directamente en la "
+"base de datos (utilizando <literal>Data Manipulation Language</literal> "
+"(DML) las declaraciones: <literal>INSERT</literal>, <literal>UPDATE</"
+"literal>, <literal>DELETE</literal>) no afectará el estado en la memoria. "
+"Sin embargo, Hibernate brinda métodos para la ejecución de declaraciones en "
+"masa DML del estilo de SQL, las cuales se realizan por medio del Lenguaje de "
+"Consulta de Hibernate (<xref linkend=\"queryhql\" />)."
 
 #. Tag: para
-#: batch.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The pseudo-syntax for <literal>UPDATE</literal> and <literal>DELETE</"
 "literal> statements is: <literal>( UPDATE | DELETE ) FROM? EntityName (WHERE "
 "where_conditions)?</literal>."
 msgstr ""
-"La pseudo-sintáxis para sentencias <literal>UPDATE</literal> y "
-"<literal>DELETE</literal> es: <literal>( UPDATE | DELETE ) FROM? ClassName "
-"(WHERE WHERE_CONDITIONS)?</literal>. Algunos puntos a tener en cuenta:"
+"La pseudo-sintáxis para las declaraciones <literal>UPDATE</literal> y "
+"<literal>DELETE</literal> es: <literal>( UPDATE | DELETE ) FROM? EntityName "
+"(WHERE where_conditions)?</literal>."
 
 #. Tag: para
-#: batch.xml:151
 #, no-c-format
 msgid "Some points to note:"
-msgstr ""
+msgstr "Algunos puntos a observar:"
 
 #. Tag: para
-#: batch.xml:157
 #, no-c-format
 msgid "In the from-clause, the FROM keyword is optional"
 msgstr "En la cláusula-from, la palabra clave FROM es opcional"
 
 #. Tag: para
-#: batch.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There can only be a single entity named in the from-clause. It can, however, "
 "be aliased. If the entity name is aliased, then any property references must "
 "be qualified using that alias. If the entity name is not aliased, then it is "
 "illegal for any property references to be qualified."
 msgstr ""
-"There can only be a single entity named in the from-clause; it can "
-"optionally be aliased. If the entity name is aliased, then any property "
-"references must be qualified using that alias; if the entity name is not "
-"aliased, then it is illegal for any property references to be qualified."
+"Sólamente puede haber una entidad mencionada en la cláusula-from y puede "
+"tener un alias. Si el nombre de la entidad tiene un alias entonces cualquier "
+"referencia a la propiedad tiene que ser calificada utilizando ese alias. Si "
+"el nombre de la entidad no tiene un alias entonces es ilegal calificar "
+"cualquier referencia de la propiedad."
 
 #. Tag: para
-#: batch.xml:170
 #, fuzzy, no-c-format
 msgid ""
 "No <link linkend=\"queryhql-joins-forms\">joins</link>, either implicit or "
 "explicit, can be specified in a bulk HQL query. Sub-queries can be used in "
 "the where-clause, where the subqueries themselves may contain joins."
 msgstr ""
-"No <link linkend=\"queryhql-joins-forms\">joins</link> (either implicit or "
-"explicit) can be specified in a bulk HQL query. Sub-queries may be used in "
-"the where-clause; the subqueries, themselves, may contain joins."
+"No se puede especificar ningún <xref linkend=\"queryhql-joins-forms\" />, ya "
+"sea implícito o explícito, en una consulta masiva de HQL. Se pueden utilizar "
+"subconsultas en la cláusula-where y en donde las subconsultas pueden "
+"contener joins en sí mismas. "
 
 #. Tag: para
-#: batch.xml:177
 #, no-c-format
 msgid "The where-clause is also optional."
-msgstr "La cláusula-where es también opcional."
+msgstr "La cláusula-where también es opcional."
 
 #. Tag: para
-#: batch.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As an example, to execute an HQL <literal>UPDATE</literal>, use the "
 "<literal>Query.executeUpdate()</literal> method. The method is named for "
 "those familiar with JDBC's <literal>PreparedStatement.executeUpdate()</"
 "literal>:"
 msgstr ""
-"Como un ejemplo, para ejecutar un <literal>UPDATE</literal> HQL, usa el "
-"método <literal>Query.executeUpdate()</literal>(the method is named for "
-"those familiar with JDBC's <literal>PreparedStatement.executeUpdate()</"
-"literal>):"
+"Como ejemplo, para ejecutar un <literal>UPDATE</literal> de HQL, utilice el "
+"método <literal>Query.executeUpdate()</literal>. El método es nombrado para "
+"aquellos familiarizados con el <literal>PreparedStatement.executeUpdate()</"
+"literal> de JDBC:"
 
-#. Tag: programlisting
-#: batch.xml:189
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlUpdate = \"update Customer c set c.name = :newName where c.name = :"
-"oldName\";\n"
-"// or String hqlUpdate = \"update Customer set name = :newName where name = :"
-"oldName\";\n"
-"int updatedEntities = s.createQuery( hqlUpdate )\n"
-"        .setString( \"newName\", newName )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"                                         Transaction tx = session."
-"beginTransaction();\n"
-"                                         \n"
-"                                         String hqlUpdate = \"update "
-"Customer c set c.name = :newName where c.name = :oldName\";\n"
-"                                         // or String hqlUpdate = \"update "
-"Customer set name = :newName where name = :oldName\";\n"
-"                                         int updatedEntities = s.createQuery"
-"( hqlUpdate )\n"
-"                                         .setString( \"newName\", newName )\n"
-"                                         .setString( \"oldName\", oldName )\n"
-"                                         .executeUpdate();\n"
-"                                         tx.commit();\n"
-"                                         session.close();]]>"
-
 #. Tag: para
-#: batch.xml:191
 #, fuzzy, no-c-format
 msgid ""
 "In keeping with the EJB3 specification, HQL <literal>UPDATE</literal> "
@@ -493,95 +303,39 @@
 "<literal>VERSIONED</literal> keyword after the <literal>UPDATE</literal> "
 "keyword."
 msgstr ""
-"HQL <literal>UPDATE</literal> statements, by default do not effect the <link "
-"linkend=\"mapping-declaration-version\">version</link> or the <link linkend="
-"\"mapping-declaration-timestamp\">timestamp</link> property values for the "
-"affected entities; this is in keeping with the EJB3 specification. However, "
-"you can force Hibernate to properly reset the <literal>version</literal> or "
-"<literal>timestamp</literal> property values through the use of a "
-"<literal>versioned update</literal>. This is achieved by adding the "
-"<literal>VERSIONED</literal> keyword after the <literal>UPDATE</literal> "
-"keyword."
+"Para mantenerse de acuerdo con la especificación de EJB3, las declaraciones "
+"<literal>UPDATE</literal> de HQL, por defecto no afectan la <xref linkend="
+"\"mapping-declaration-version\" /> o los valores de propiedad <xref linkend="
+"\"mapping-declaration-timestamp\" /> para las entidades afectadas. Sin "
+"embargo, puede obligar a Hibernate a poner en cero apropiadamente los "
+"valores de propiedad <literal>version</literal> o <literal>timestamp</"
+"literal> por medio de la utilización de un <literal>versioned update</"
+"literal>. Esto se logra añadiendo la palabra clave <literal>VERSIONED</"
+"literal> después de la palabra clave <literal>UPDATE</literal>."
 
-#. Tag: programlisting
-#: batch.xml:201
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"String hqlVersionedUpdate = \"update versioned Customer set name = :newName "
-"where name = :oldName\";\n"
-"int updatedEntities = s.createQuery( hqlUpdate )\n"
-"        .setString( \"newName\", newName )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"                                         Transaction tx = session."
-"beginTransaction();\n"
-"                                         String hqlVersionedUpdate = "
-"\"update versioned Customer set name = :newName where name = :oldName\";\n"
-"                                         int updatedEntities = s.createQuery"
-"( hqlUpdate )\n"
-"                                         .setString( \"newName\", newName )\n"
-"                                         .setString( \"oldName\", oldName )\n"
-"                                         .executeUpdate();\n"
-"                                         tx.commit();\n"
-"                                         session.close();]]>"
-
-#. Tag: para
-#: batch.xml:203
-#, fuzzy, no-c-format
-msgid ""
 "Custom version types, <literal>org.hibernate.usertype.UserVersionType</"
 "literal>, are not allowed in conjunction with a <literal>update versioned</"
 "literal> statement."
 msgstr ""
-"Note that custom version types (<literal>org.hibernate.usertype."
-"UserVersionType</literal>) are not allowed in conjunction with a "
-"<literal>update versioned</literal> statement."
+"Observe que los tipos de versiones personalizados (<literal>org.hibernate."
+"usertype.UserVersionType</literal>) no están permitidos en conjunto con una "
+"declaración <literal>update versioned</literal>."
 
 #. Tag: para
-#: batch.xml:208
 #, no-c-format
 msgid ""
 "To execute an HQL <literal>DELETE</literal>, use the same <literal>Query."
 "executeUpdate()</literal> method:"
 msgstr ""
-"Para ejecutar un <literal>DELETE</literal> HQL, usa el mismo método "
+"Para ejecutar un <literal>DELETE</literal> HQL, utilice el mismo método "
 "<literal>Query.executeUpdate()</literal>:"
 
-#. Tag: programlisting
-#: batch.xml:213
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlDelete = \"delete Customer c where c.name = :oldName\";\n"
-"// or String hqlDelete = \"delete Customer where name = :oldName\";\n"
-"int deletedEntities = s.createQuery( hqlDelete )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"        Transaction tx = session.beginTransaction();\n"
-"\n"
-"        String hqlDelete = \"delete Customer where name = :oldName\";\n"
-"        int deletedEntities = s.createQuery( hqlDelete )\n"
-"                            .setString( \"oldName\", oldName )\n"
-"                            .executeUpdate();\n"
-"        tx.commit();\n"
-"        session.close();]]>"
-
-#. Tag: para
-#: batch.xml:215
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>int</literal> value returned by the <literal>Query.executeUpdate"
 "()</literal> method indicates the number of entities effected by the "
 "operation. This may or may not correlate to the number of rows effected in "
@@ -593,40 +347,39 @@
 "which that subclass is mapped, but also the \"root\" table and potentially "
 "joined-subclass tables further down the inheritance hierarchy."
 msgstr ""
-"El valor <literal>int</literal> devuelto por el método <literal>Query."
+"El valor <literal>int</literal> retornado por el método <literal>Query."
 "executeUpdate()</literal> indica el número de entidades afectadas por la "
-"operación. Considera que esto puede o no correlacionarse al número de filas "
-"afectadas en la base de datos. Una operación masiva HQL podría resultar en "
-"que se ejecuten múltiples sentencias de SQL reales, para joined-subclass, "
-"por ejemplo. El número devuelto indica el número de entidades reales "
-"afectadas por la sentencia. Volviendo al ejemplo de joined-subclass, un "
-"borrado contra una de las subclases puede resultar realmente en borrados "
-"contra no sólo la tabla a la que está mapeada esa subclase, sino también la "
-"tabla \"raíz\" y potencialmente tablas de joined-subclass más debajo en la "
-"jerarquía de herencia."
+"operación. Considere que esto puede estar correlacionado o no con el número "
+"de filas afectadas en la base de datos. Una operación masiva de HQL puede "
+"llegar a causar que se ejecuten múltiples declaraciones SQL reales, por "
+"ejemplo, para una subclase-joined. El número retornado indica el número de "
+"entidades realmente afectadas por la declaración. De vuelta al ejemplo de la "
+"subclase joined, un borrado contra una de las subclases puede resultar, de "
+"hecho, en borrados de no sólamente la tabla a la cual esa subclase esta "
+"mapeada, sino también la tabla \"raíz\" y potencialmente las tablas de "
+"subclases joined hasta la jerarquía de herencia."
 
 #. Tag: para
-#: batch.xml:226
 #, no-c-format
 msgid ""
 "The pseudo-syntax for <literal>INSERT</literal> statements is: "
 "<literal>INSERT INTO EntityName properties_list select_statement</literal>. "
 "Some points to note:"
 msgstr ""
-"Ten en cuenta que existen actualmente unas pocas limitaciones con las "
-"operaciones HQL masivas, que serán atendidas en lanzamientos futuros; "
-"consulta la hoja de ruta de JIRA para más detalles."
+"La pseudo-sintáxis para las declaraciones <literal>INSERT</literal> es: "
+"<literal>INSERT INTO EntityName properties_list select_statement</literal>. "
+"Algunos puntos que se deben observar son:"
 
 #. Tag: para
-#: batch.xml:234
 #, no-c-format
 msgid ""
 "Only the INSERT INTO ... SELECT ... form is supported; not the INSERT "
 "INTO ... VALUES ... form."
 msgstr ""
+"Sólamente se soporta la forma INSERT INTO ... SELECT ..., no la forma INSERT "
+"INTO ... VALUES ..."
 
 #. Tag: para
-#: batch.xml:237
 #, no-c-format
 msgid ""
 "The properties_list is analogous to the <literal>column specification</"
@@ -636,9 +389,16 @@
 "are not allowed and subclass properties do not make sense. In other words, "
 "<literal>INSERT</literal> statements are inherently non-polymorphic."
 msgstr ""
+"La lista de propiedades (properties_list) es análoga a la <literal>column "
+"speficiation</literal> en la declaración <literal>INSERT</literal> de SQL. "
+"Para las entidades involucradas en la herencia mapeada, sólamente las "
+"propiedades definidas directamente en ese nivel de clase dado se pueden "
+"utlizar en la lista de propiedades. Las propiedades de la superclase no "
+"están permitidas, y las propiedaeds de la subclase no tienen sentido. Es "
+"decir, las declaraciones <literal>INSERT</literal> son inherentemente no-"
+"polimórficas."
 
 #. Tag: para
-#: batch.xml:247
 #, no-c-format
 msgid ""
 "select_statement can be any valid HQL select query, with the caveat that the "
@@ -652,9 +412,19 @@
 "TimestampType</literal>, even though the database might not make a "
 "distinction or might be able to handle the conversion."
 msgstr ""
+"select_statement puede ser cualquier consulta select de HQL válida con la "
+"advertencia de que los tipos de retorno coincidan con los tipos esperados "
+"por el insert. Actualmente, esto se verifica durante la compilación de la "
+"consulta en vez de permitir que se relegue la verificación a la base de "
+"datos. Sin embargo, esto puede crear problemas entre los <literal>Type</"
+"literal>s de Hibernate, los cuales son <emphasis>equivalentes</emphasis> y "
+"no <emphasis>iguales</emphasis>. Esto puede crear problemas con las uniones "
+"mal hechas entre una propiedad definida como un <literal>org.hibernate.type."
+"DateType</literal> y una propiedad definida como una <literal>org.hibernate."
+"type.TimestampType</literal>, aunque puede que la base de datos no distinga "
+"o no pueda manejar la conversión."
 
 #. Tag: para
-#: batch.xml:259
 #, no-c-format
 msgid ""
 "For the id property, the insert statement gives you two options. You can "
@@ -671,9 +441,22 @@
 "TableHiLoGenerator</literal>, which cannot be used because it does not "
 "expose a selectable way to get its values."
 msgstr ""
+"Para la propiedad id, la declaración insert le da dos opciones. Puede "
+"especificar explícitamente la propiedad id en la lista de propiedades "
+"(properties_list ) (en tal caso su valor se toma de la expresión de "
+"selección correspondiente) o se omite de la lista de propiedades (en tal "
+"caso se utiliza un valor generado). Esta última opción sólamente está "
+"disponible cuando se utilizan generadores de id que operan en la base de "
+"datos, intentando utilizar esta opción con cualquier generador de tipo \"en "
+"memoria\" provocará una excepción durante el análisis sintáctico. Note que "
+"para los propósitos de esta discusión, los generadores en la base de datos "
+"son considerados <literal>org.hibernate.id.SequenceGenerator</literal> (y "
+"sus subclases) y cualquier implementador de <literal>org.hibernate.id."
+"PostInsertIdentifierGenerator</literal>. La excepción más importante aquí es "
+"<literal>org.hibernate.id.TableHiLoGenerator</literal>, la cual no se puede "
+"utilizar ya que no expone una manera selectiva de obtener sus valores."
 
 #. Tag: para
-#: batch.xml:274
 #, no-c-format
 msgid ""
 "For properties mapped as either <literal>version</literal> or "
@@ -683,32 +466,18 @@
 "from the properties_list, in which case the <literal>seed value</literal> "
 "defined by the <literal>org.hibernate.type.VersionType</literal> is used."
 msgstr ""
+"Para las propiedades mapeadas como <literal>version</literal> o "
+"<literal>timestamp</literal>, la declaración insert le da dos opciones. "
+"Puede especificar la propiedad en la lista de propiedades (en tal caso su "
+"valor se toma de las expresiones de selección correspondientes) o se omite "
+"de la lista de propiedades (en tal caso se utiliza el <literal>seed value</"
+"literal> definido por el <literal>org.hibernate.type.VersionType</literal>)."
 
 #. Tag: para
-#: batch.xml:284
 #, no-c-format
 msgid ""
 "The following is an example of an HQL <literal>INSERT</literal> statement "
 "execution:"
 msgstr ""
-
-#. Tag: programlisting
-#: batch.xml:288
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlInsert = \"insert into DelinquentAccount (id, name) select c.id, c."
-"name from Customer c where ...\";\n"
-"int createdEntities = s.createQuery( hqlInsert )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+"Un ejemplo de la ejecución de la declaración <literal>INSERT</literal> de "
+"HQL:"

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/best_practices.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/best_practices.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/best_practices.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,30 +1,43 @@
-#, fuzzy
+# translation of best_practices.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: best_practices\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-11-09 09:46+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: best_practices.xml:29
 #, no-c-format
 msgid "Best Practices"
-msgstr "Mejores Pr&#x00e1;cticas"
+msgstr "Prácticas recomendadas"
 
 #. Tag: term
-#: best_practices.xml:33
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Write fine-grained classes and map them using <literal>&lt;component&gt;</"
 "literal>:"
 msgstr ""
-"Escribe clase finamente granularizadas y mapealas usando <literal>&lt;"
-"component&gt;</literal>."
+"Escriba las clases detalladas y mapéelas utilizando <literal>&lt;"
+"component&gt;</literal>:"
 
 #. Tag: para
-#: best_practices.xml:35
 #, no-c-format
 msgid ""
 "Use an <literal>Address</literal> class to encapsulate <literal>street</"
@@ -32,38 +45,34 @@
 "<literal>postcode</literal>. This encourages code reuse and simplifies "
 "refactoring."
 msgstr ""
-"Usa una clase <literal>Direcci&#x00f3;n</literal> para encapsular "
+"Utilice una clase <literal>Dirección</literal> para encapsular "
 "<literal>calle</literal>, <literal>distrito</literal>, <literal>estado</"
-"literal>, <literal>c&#x00f3;digo postal</literal>. Esto alienta la "
-"reutilizaci&#x00f3;n de c&#x00f3;digo y simplifica el refactoring."
+"literal>, <literal>código postal</literal>. Esto promueve la reutilización "
+"de código y simplifica la refabricación."
 
 #. Tag: term
-#: best_practices.xml:43
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Declare identifier properties on persistent classes:"
-msgstr "Declara las propiedades identificadoras en clases persistentes."
+msgstr "Declare las propiedades identificadoras en clases persistentes:"
 
 #. Tag: para
-#: best_practices.xml:45
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate makes identifier properties optional. There are a range of reasons "
 "why you should use them. We recommend that identifiers be 'synthetic', that "
 "is, generated with no business meaning."
 msgstr ""
-"Hibernate hace opcionales las propiedades identificadoras. Existen todo tipo "
-"de razones por las que debes usarlas. Recomendamos que los identificadores "
-"sean 'sint&#x00e9;ticos' (generados, sin ning&#x00fa;n significado de "
-"negocio)."
+"Las propiedades identificadoras son opcionales en Hibernate. Existe todo "
+"tipo de razones por las que debe usarlas. Recomendamos que los "
+"identificadores sean 'sintéticos', es decir, generados sin ningún "
+"significado empresarial."
 
 #. Tag: term
-#: best_practices.xml:53
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Identify natural keys:"
-msgstr "Identifica las claves naturales."
+msgstr "Identifique las llaves naturales:"
 
 #. Tag: para
-#: best_practices.xml:55
 #, no-c-format
 msgid ""
 "Identify natural keys for all entities, and map them using <literal>&lt;"
@@ -71,108 +80,95 @@
 "<literal>hashCode()</literal> to compare the properties that make up the "
 "natural key."
 msgstr ""
-"Identifica las claves naturales de todas las entidades, y mapealas usando "
-"<literal>&lt;natural-id&gt;</literal>. Implementa <literal>equals()</"
+"Identifique las claves naturales de todas las entidades, y mapéelas usando "
+"<literal>&lt;natural-id&gt;</literal>. Implemente <literal>equals()</"
 "literal> y <literal>hashCode()</literal> para comparar las propiedades que "
 "componen la clave natural."
 
 #. Tag: term
-#: best_practices.xml:63
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Place each class mapping in its own file:"
-msgstr "Coloca cada mapeo de clase en su propio fichero."
+msgstr "Coloque cada mapeo de clase en su propio fichero:"
 
 #. Tag: para
-#: best_practices.xml:65
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not use a single monolithic mapping document. Map <literal>com.eg.Foo</"
 "literal> in the file <literal>com/eg/Foo.hbm.xml</literal>. This makes "
 "sense, particularly in a team environment."
 msgstr ""
-"No uses un solo documento monol&#x00ed;tico de mapeo. Mapea <literal>com.eg."
-"Foo</literal> en el fichero <literal>com/eg/Foo.hbm.xml</literal>. Esto "
-"tiene sentido particularmente en un ambiente de equipo."
+"No use un sólo documento monolítico de mapeo. Mapee <literal>com.eg.Foo</"
+"literal> en el archivo <literal>com/eg/Foo.hbm.xml</literal>. Esto tiene "
+"sentido particularmente en un entorno de equipo."
 
 #. Tag: term
-#: best_practices.xml:73
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Load mappings as resources:"
-msgstr "Carga los mapeos como recursos."
+msgstr "Cargue los mapeos como recursos:"
 
 #. Tag: para
-#: best_practices.xml:75
 #, no-c-format
 msgid "Deploy the mappings along with the classes they map."
-msgstr "Despliega los mapeos junto a las clases que mapean."
+msgstr "Despliegue los mapeos junto a las clases que mapean."
 
 #. Tag: term
-#: best_practices.xml:81
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Consider externalizing query strings:"
-msgstr "Considera externalizar las cadenas de consulta."
+msgstr "Considere el externalizar las cadenas de petición:"
 
 #. Tag: para
-#: best_practices.xml:83
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is recommended if your queries call non-ANSI-standard SQL functions. "
 "Externalizing the query strings to mapping files will make the application "
 "more portable."
 msgstr ""
-"Esta es una buena pr&#x00e1;ctica si tus consultas llaman a funciones SQL "
-"que no son del est&#x00e1;ndar ANSI. Externalizar las cadenas de consulta a "
-"ficheros de mapeo har&#x00e1; la aplicaci&#x00f3;n m&#x00e1;s portable."
+"Esta es una buena práctica si sus consultas llaman a funciones SQL que no "
+"son del estándar ANSI. Externalizar las cadenas de consulta a archivos de "
+"mapeo hará la aplicación más portátil. "
 
 #. Tag: term
-#: best_practices.xml:91
 #, no-c-format
 msgid "Use bind variables."
-msgstr "Usa variables de ligado."
+msgstr "Use variables de vinculación."
 
 #. Tag: para
-#: best_practices.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As in JDBC, always replace non-constant values by \"?\". Do not use string "
 "manipulation to bind a non-constant value in a query. You should also "
 "consider using named parameters in queries."
 msgstr ""
-"Igual que en JDBC, siempre remplaza valores no constantes con \"?\". &#x00a1;"
-"Nunca uses manipulaci&#x00f3;n de cadenas para ligar un valor no constante "
-"en una consulta! Incluso mejor, considera usar par&#x00e1;metros con nombre "
-"en las consultas."
+"Al igual que en JDBC, siempre remplace los valores no constantes con \"?\". "
+"No use la manipulación de cadenas para enlazar un valor no constante en una "
+"consulta. También considere utilizar parámetros con nombre en las consultas."
 
 #. Tag: term
-#: best_practices.xml:101
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Do not manage your own JDBC connections:"
-msgstr "No manejes tus propias conexiones JDBC."
+msgstr "No administre sus propias conexiones JDBC:"
 
 #. Tag: para
-#: best_practices.xml:103
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate allows the application to manage JDBC connections, but his "
 "approach should be considered a last-resort. If you cannot use the built-in "
 "connection providers, consider providing your own implementation of "
 "<literal>org.hibernate.connection.ConnectionProvider</literal>."
 msgstr ""
-"Hibernate deja a la aplicaci&#x00f3;n administre las conexiones JDBC. Este "
-"enfoque debe considerarse como &#x00fa;ltimo recurso. Si no puedes usar los "
-"provedores de conexi&#x00f3;n prefabricados, considera prover tu propia "
-"implementaci&#x00f3;n de <literal>org.hibernate.connection."
-"ConnectionProvider</literal>."
+"Hibernate deja a la aplicación administrar las conexiones JDBC, pero este "
+"enfoque debe considerarse como el último recurso. Si no puede utilizar los "
+"provedores de conexión incorporados, considere proveer su propia "
+"implementación de <literal>org.hibernate.connection.ConnectionProvider</"
+"literal>."
 
 #. Tag: term
-#: best_practices.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Consider using a custom type:"
-msgstr "Considera usar un tipo personalizado."
+msgstr "Considere utilizar un tipo personalizado:"
 
 #. Tag: para
-#: best_practices.xml:113
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Suppose you have a Java type from a library that needs to be persisted but "
 "does not provide the accessors needed to map it as a component. You should "
@@ -180,49 +176,45 @@
 "approach frees the application code from implementing transformations to/"
 "from a Hibernate type."
 msgstr ""
-"Sup&#x00f3;n que tienes un tipo Java, digamos de alguna biblioteca, que "
-"necesita hacerse persistente pero no provee los m&#x00e9;todos de acceso "
-"necesarios para mapearlo como un componente. Debes considerar implementar "
-"<literal>org.hibernate.UserType</literal>. Este enfoque libera al c&#x00f3;"
-"digo de aplicaci&#x00f3;n de implementar transformaciones a / desde un tipo "
-"Hibernate."
+"Supónga que tiene un tipo Java de una biblioteca, que necesita hacerse "
+"persistente pero que no provee los métodos de acceso necesarios para "
+"mapearlo como un componente. Debe considerar el implementar <literal>org."
+"hibernate.UserType</literal>. Este enfoque libera al código de aplicación de "
+"implementar transformaciones a/desde un tipo Hibernate."
 
 #. Tag: term
-#: best_practices.xml:122
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Use hand-coded JDBC in bottlenecks:"
-msgstr "Usa JDBC codificado a mano en cuellos de botella."
+msgstr "Utilice JDBC codificado a mano cuando se encuentre atascado:"
 
 #. Tag: para
-#: best_practices.xml:124
 #, fuzzy, no-c-format
 msgid ""
 "In performance-critical areas of the system, some kinds of operations might "
 "benefit from direct JDBC. Do not assume, however, that JDBC is necessarily "
 "faster. Please wait until you <emphasis>know</emphasis> something is a "
 "bottleneck. If you need to use direct JDBC, you can open a Hibernate "
-"<literal>Session</literal> and usingfile:///usr/share/doc/HTML/en-US/index."
-"html that JDBC connection. This way you can still use the same transaction "
-"strategy and underlying connection provider."
+"<literal>Session</literal>, wrap your JDBC operation as a <literal>org."
+"hibernate.jdbc.Work</literal> object and using that JDBC connection. This "
+"way you can still use the same transaction strategy and underlying "
+"connection provider."
 msgstr ""
-"En &#x00e1;reas del sistema de rendimiento cr&#x00ed;tico, algunos tipos de "
-"operaciones podr&#x00ed;an beneficiarse del JDBC directo. Pero por favor, "
-"espero hasta que <emphasis>sepas</emphasis> que algo es un cuello de "
-"botella. Y no asumas que el JDBC directo es necesariamente m&#x00e1;s "
-"r&#x00e1;pido. Si necesitas usar JDBC directo, podr&#x00ed;a ser valioso "
-"abrir una <literal>Session</literal> de Hibernate y usar esa conexi&#x00f3;n "
-"JDBC. De esta forma puedes usar a&#x00fa;n la misma estrategia de "
-"transacci&#x00f3;n y el mismo proveedor de conexiones subyacente."
+"En áreas de rendimiento crítico del sistema, algunos tipos de operaciones "
+"podrían beneficiarse del JDBC directo. Sin embargo, no asuma que el JDBC "
+"directo es necesariamente más rápido. Por favor, espere hasta que "
+"<emphasis>sepa</emphasis> que se encuentra realmente atascado. Si necesita "
+"utilizar JDBC directo, puede abrir una <literal>Session</literal> de "
+"Hibernate y usar esa conexión JDBC file:///usr/share/doc/HTML/en-US/index."
+"html. De esta manera puede usar aún la misma estrategia de transacción y el "
+"mismo proveedor de conexiones subyacente."
 
 #. Tag: term
-#: best_practices.xml:134
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Understand <literal>Session</literal> flushing:"
-msgstr "Comprende la limpieza (flushing) de <literal>Session</literal>."
+msgstr "Comprenda el vaciado de <literal>Session</literal>:"
 
 #. Tag: para
-#: best_practices.xml:136
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes the Session synchronizes its persistent state with the database. "
 "Performance will be affected if this process occurs too often. You can "
@@ -230,22 +222,20 @@
 "even by changing the order of queries and other operations within a "
 "particular transaction."
 msgstr ""
-"De vez en cuando la sesi&#x00f3;n sincroniza su estado persistente con la "
-"base de datos. El rendimiento se ver&#x00e1; afectado si este proceso ocurre "
-"demasiado frecuentemente. A veces puedes minimizar limpieza innecesaria "
-"deshabilitando la limpieza autom&#x00e1;tica o incluso cambiando el orden de "
-"las consultas u otras operaciones en una transacci&#x00f3;n en particular."
+"A veces la sesión sincroniza su estado persistente con la base de datos. El "
+"rendimiento se verá afectado si este proceso ocurre con demasiada "
+"frecuencia. A veces puede minimizar el vaciado innecesario deshabilitando el "
+"vaciado automático o incluso cambiando el orden de las consultas u otras "
+"operaciones en una transacción en particular."
 
 #. Tag: term
-#: best_practices.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "In a three tiered architecture, consider using detached objects:"
 msgstr ""
-"En una aplicaci&#x00f3;n en tres gradas, considera usar objetos separados."
+"En una arquitectura con tres niveles considere el utilizar objetos separados:"
 
 #. Tag: para
-#: best_practices.xml:147
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When using a servlet/session bean architecture, you can pass persistent "
 "objects loaded in the session bean to and from the servlet/JSP layer. Use a "
@@ -253,23 +243,21 @@
 "or <literal>Session.saveOrUpdate()</literal> to synchronize objects with the "
 "database."
 msgstr ""
-"Al usar una arquitectura de servlet / sesi&#x00f3;n, puedes pasar objetos "
-"persistentes en el bean de sesi&#x00f3;n hacia y desde la capa de servlet / "
-"JSP. Usa una sesi&#x00f3;n nueva para atender el servicio de cada "
-"petici&#x00f3;n. Usa <literal>Session.merge()</literal> o <literal>Session."
-"saveOrUpdate()</literal> para sincronizar los objetos con la base de datos."
+"Al usar una arquitectura de servlet/sesión, puede pasar objetos persistentes "
+"en el bean de sesión hacia y desde la capa del servlet/JSP. Use una sesión "
+"nueva para atender el servicio de cada petición. Use <literal>Session.merge()"
+"</literal> o <literal>Session.saveOrUpdate()</literal> para sincronizar los "
+"objetos con la base de datos."
 
 #. Tag: term
-#: best_practices.xml:156
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "In a two tiered architecture, consider using long persistence contexts:"
 msgstr ""
-"En una arquitectura en dos gradas, considera usar contexto de persistencia "
-"largos."
+"En una arquitectura con dos niveles considere el utilizar contextos largos "
+"de persistencia:"
 
 #. Tag: para
-#: best_practices.xml:158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Database Transactions have to be as short as possible for best scalability. "
 "However, it is often necessary to implement long running "
@@ -284,31 +272,27 @@
 "across more than one application transaction or you will be working with "
 "stale data."
 msgstr ""
-"Las transacciones de base de datos tienen que ser tan cortas como sea "
-"posible. Sin embargo, frecuentemente es necesario implementar "
-"<emphasis>transacciones de aplicaci&#x00f3;n</emphasis> ejecut&#x00e1;ndose "
-"en largo, una sola unidad de trabajo desde el punto de vista de un usuario. "
-"Una transacci&#x00f3;n de aplicaci&#x00f3;n puede abarcar muchos ciclos "
-"petici&#x00f3;n/respuesta del cliente. Es com&#x00fa;n usar objetos "
-"separados para implementar transacciones de aplicaci&#x00f3;n. Una "
-"alternativa, extremadamente apropiada en arquitecturas en dos gradas, es "
-"mantener un solo contacto de persistencia abierto (sesi&#x00f3;n) para todo "
-"el ciclo de vida de la transacci&#x00f3;n de aplicaci&#x00f3;n y simplemente "
-"desconectar de la conexi&#x00f3;n JDBC al final de cada petici&#x00f3;n, y "
-"reconectar al comienzo de la petici&#x00f3;n subsecuente. Nunca compartas "
-"una &#x00fa;nica sesi&#x00f3;n a trav&#x00e9;s de m&#x00e1;s de una "
-"transacci&#x00f3;n de aplicaci&#x00f3;n, o estar&#x00e1;s trabajando con "
-"datos añejos."
+"Las transacciones de la base de datos tienen que ser tan cortas como sea "
+"posible para obtener una mejor escalabilidad. Sin embargo, con frecuencia es "
+"necesario implementar <emphasis>transacciones de aplicación</emphasis> de "
+"larga ejecución, una sola unidad de trabajo desde el punto de vista de un "
+"usuario. Una transacción de aplicación puede abarcar muchos ciclos de "
+"petición/respuesta del cliente. Es común usar objetos separados para "
+"implementar transacciones de aplicación. Una alternativa apropiada en "
+"arquitecturas de dos niveles, es mantener una sesión de un sólo contacto de "
+"persistencia abierto para todo el ciclo de vida de la transacción de "
+"aplicación. Luego simplemente desconectar de la conexión JDBC al final de "
+"cada petición y reconectar al comienzo de la petición subsecuente. Nunca "
+"comparta una sesión única a través de más de una transacción de aplicación o "
+"estará trabajando con datos desactualizados."
 
 #. Tag: term
-#: best_practices.xml:172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Do not treat exceptions as recoverable:"
-msgstr "No trates la excepciones como recuperables."
+msgstr "No trate las excepciones como recuperables:"
 
 #. Tag: para
-#: best_practices.xml:174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is more of a necessary practice than a \"best\" practice. When an "
 "exception occurs, roll back the <literal>Transaction</literal> and close the "
@@ -318,24 +302,21 @@
 "instance with the given identifier exists on the database; use "
 "<literal>Session.get()</literal> or a query instead."
 msgstr ""
-"Esto es m&#x00e1;s una pr&#x00e1;ctica necesaria que una \"mejor\" pr&#x00e1;"
-"ctica. Cuando ocurra una excepci&#x00f3;n, deshaz (rollback) la "
-"<literal>Transaction</literal> y cierra la <literal>Session</literal>. Si no "
-"lo haces, Hibernate no puede garantizar que el estado en memoria representa "
-"con exactitud el estado persistente. Como un caso especial de esto, no uses "
-"<literal>Session.load()</literal> para determinar si una instancia con el "
-"identificador dado existe en la base de datos. En cambio, usa "
-"<literal>Session.get()</literal> o una consulta."
+"Esto es más bien una práctica necesaria más que una práctica \"recomendada"
+"\". Cuando ocurra una excepción, deshaga la <literal>Transaction</literal> y "
+"cierre la <literal>Session</literal>. Si no lo hace, Hibernate no puede "
+"garantizar que el estado en memoria representa con exactitud el estado "
+"persistente. Por ejemplo, no utilice <literal>Session.load()</literal> para "
+"determinar si una instancia con el identificador dado existe en la base de "
+"datos; en cambio, use <literal>Session.get()</literal> o una consulta."
 
 #. Tag: term
-#: best_practices.xml:184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Prefer lazy fetching for associations:"
-msgstr "Prefiere la recuperaci&#x00f3;n perezosa para las asociaciones."
+msgstr "Prefiera una recuperación perezosa para las asociaciones:"
 
 #. Tag: para
-#: best_practices.xml:186
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use eager fetching sparingly. Use proxies and lazy collections for most "
 "associations to classes that are not likely to be completely held in the "
@@ -345,30 +326,27 @@
 "to a particular use case, use a query with a <literal>left join fetch</"
 "literal>."
 msgstr ""
-"Usa escasamente la recuperaci&#x00f3;n temprana. Usa proxies y colecciones "
-"perezosas para la mayor&#x00ed;a de asociaciones a clases probablemente no "
-"est&#x00e9;n mantenidas en el cach&#x00e9; de segundo nivel. Para las "
-"asociaciones a clases en cach&#x00e9;, donde hay una probabilidad de acceso "
-"a cach&#x00e9; extremadamente alta, deshabilita expl&#x00ed;citamente la "
-"recuperaci&#x00f3;n temprana usando <literal>lazy=\"false\"</literal>. "
-"Cuando sea apropiada la recuperaci&#x00f3;n por uni&#x00f3;n (join fetching) "
-"para un caso de uso en particular, usa una consulta con un <literal>left "
-"join fetch</literal>."
+"No utilice con frecuencia la recuperación temprana. Use proxies y "
+"colecciones perezosas para la mayoría de asociaciones a clases que "
+"probablemente no se encuentren en el caché de segundo nivel. Para las "
+"asociaciones a clases en caché, donde hay una probabilidad de acceso a caché "
+"extremadamente alta, deshabilite explícitamente la recuperación temprana "
+"usando <literal>lazy=\"false\"</literal>. Cuando la recuperación por unión "
+"sea apropiada para un caso de uso en particular, utilice una consulta con un "
+"<literal>left join fetch</literal>."
 
 #. Tag: term
-#: best_practices.xml:196
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use the <emphasis>open session in view</emphasis> pattern, or a disciplined "
 "<emphasis>assembly phase</emphasis> to avoid problems with unfetched data:"
 msgstr ""
-"Usa el patr&#x00f3;n <emphasis>sesi&#x00f3;n abierta en vista</emphasis>, o "
-"una <emphasis>fase de ensamblado</emphasis> disciplinada para evitar "
-"problemas con datos no recuperados."
+"Use el patrón de <emphasis>sesión abierta en vista</emphasis> o una "
+"<emphasis>fase de ensamblado</emphasis> disciplinada para evitar problemas "
+"con datos no recuperados."
 
 #. Tag: para
-#: best_practices.xml:201
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate frees the developer from writing tedious <emphasis>Data Transfer "
 "Objects</emphasis> (DTO). In a traditional EJB architecture, DTOs serve dual "
@@ -383,31 +361,28 @@
 "objects. This is not a limitation of Hibernate. It is a fundamental "
 "requirement of safe transactional data access."
 msgstr ""
-"Hibernate liberal al desarrollador de escribir <emphasis>Objetos de "
-"Transferencia de Datos (Data Transfer Objects)</emphasis> (DTO). En una "
-"arquitectura tradicional de EJB, los DTOs tienen un prop&#x00f3;sito doble: "
-"primero, atacan el problema que los beans de entidad no son serializables. "
-"Segundo, definen impl&#x00ed;citamente una fase de ensamblado cuando se "
-"recuperan y se forman (marshalling) todos los datos a usar por la vista en "
-"los DTOs antes de devolver el control a la grada de presentaci&#x00f3;n. "
-"Hibernate elimina el primer prop&#x00f3;sito. Sin embargo, a&#x00fa;n "
-"necesitas una fase de ensamblado (piensa en tus m&#x00e9;todos de negocio "
-"como si tuviesen un contrato estricto con la grada de presentaci&#x00f3;n "
-"sobre qu&#x00e9; datos est&#x00e1;n disponibles en los objetos separados) a "
-"menos que est&#x00e9;s preparado para tener el contexto de persistencia (la "
-"sesi&#x00f3;n) abierto a trav&#x00e9;s del proceso de renderizaci&#x00f3;n "
-"de la vista. &#x00a1;Esta no es una limitaci&#x00f3;n de Hibernate! Es un "
+"Hibernate libera al desarrollador de escribir tediosos <emphasis>objetos de "
+"transferencia de datos (DTO del inglés Data Transfer Objects)</emphasis>. En "
+"una arquitectura tradicional de EJB, los DTOs tienen un propósito doble: "
+"primero, atacan el problema de que los beans de entidad no son "
+"serializables. Segundo, definen implícitamente una fase de ensamblado cuando "
+"se recuperan y se forman (marshalling) todos los datos a usar por la vista "
+"en los DTOs antes de devolver el control al nivel de presentación. Hibernate "
+"elimina el primer propósito. Sin embargo, aún necesita una fase de "
+"ensamblado a menos de que esté preparado para tener el contexto de "
+"persistencia (la sesión) abierto a través del proceso de entrega de la "
+"vista. Piense en sus métodos empresariales como si tuviesen un contrato "
+"estricto con el nivel de presentación sobre qué datos están disponibles en "
+"los objetos separados. Esta no es una limitación de Hibernate. Este es un "
 "requerimiento fundamental de acceso seguro a datos transaccionales."
 
 #. Tag: term
-#: best_practices.xml:215
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Consider abstracting your business logic from Hibernate:"
-msgstr "Considera abstraer tu l&#x00f3;gica de negocio de Hibernate"
+msgstr "Considere abstraer su lógica empresarial de Hibernate:"
 
 #. Tag: para
-#: best_practices.xml:217
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hide Hibernate data-access code behind an interface. Combine the "
 "<emphasis>DAO</emphasis> and <emphasis>Thread Local Session</emphasis> "
@@ -416,23 +391,21 @@
 "however, intended for \"sufficiently large\" applications. It is not "
 "appropriate for an application with five tables."
 msgstr ""
-"Oculta el c&#x00f3;digo de acceso a datos (Hibernate) detr&#x00e1;s de una "
-"interface. Combina los patrones <emphasis>DAO</emphasis> y "
-"<emphasis>Sesi&#x00f3;n de Hebra Local</emphasis>. Incluso puedes tener "
-"algunas clases hechas persistentes por JDBC escrito a mano, asociadas a "
-"Hibernate por medio de un <literal>UserType</literal>. (Este consejo "
-"est&#x00e1; pensado para aplicaciones \"suficientemente grandes\"; &#x00a1;"
-"no es apropiado para una aplicaci&#x00f3;n con cinco tablas!)"
+"Oculte el código de acceso a datos de Hibernate detrás de una interfaz. "
+"Combine los patrones <emphasis>DAO</emphasis> y <emphasis>sesión local de "
+"hilo</emphasis>. Incluso puede hacer algunas clases persistentes por medio "
+"de JDBC escrito a mano, asociadas a Hibernate por medio de un "
+"<literal>UserType</literal>. Sin embargo, este consejo va para las "
+"aplicaciones \"suficientemente grandes\". No es apropiado para una "
+"aplicación con cinco tablas."
 
 #. Tag: term
-#: best_practices.xml:227
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Do not use exotic association mappings:"
-msgstr "No uses mapeos de asociaci&#x00f3;n ex&#x00f3;ticos."
+msgstr "No utilice mapeos de asociación exóticos:"
 
 #. Tag: para
-#: best_practices.xml:229
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Practical test cases for real many-to-many associations are rare. Most of "
 "the time you need additional information stored in the \"link table\". In "
@@ -442,33 +415,24 @@
 "association style."
 msgstr ""
 "Son raros los casos de uso de asociaciones reales muchos-a-muchos. La mayor "
-"parte del tiempo necesitas informaci&#x00f3;n adicional almacenada en una "
-"\"tabla de enlace\". En este caso, es mucho mejor usar dos asociaciones uno-"
-"a-muchos a una clase de enlace intermedia. De hecho, pensamos que la "
-"mayor&#x00ed;a de asociaciones son uno-a-muchos y muchos-a-uno, debes ser "
-"cuidadoso al usr cualquier otro estilo de asociaci&#x00f3;n y preguntarte si "
-"es realmente necesario."
+"parte del tiempo necesita información adicional almacenada en una \"tabla de "
+"enlace\". En este caso, es mucho mejor usar dos asociaciones uno-a-muchos a "
+"una clase de enlace intermedio. De hecho, la mayoría de las asociaciones son "
+"uno-a-muchos y muchos-a-uno. Por esta razón, debe tener cuidado al utilizar "
+"cualquier otro estilo de asociación."
 
 #. Tag: term
-#: best_practices.xml:239
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Prefer bidirectional associations:"
-msgstr "Prefiere las asociaciones bidireccionales."
+msgstr "Prefiera las asociaciones bidireccionales:"
 
 #. Tag: para
-#: best_practices.xml:241
 #, no-c-format
 msgid ""
 "Unidirectional associations are more difficult to query. In a large "
 "application, almost all associations must be navigable in both directions in "
 "queries."
 msgstr ""
-"Las asociaciones unidireccionales son m&#x00e1;s dif&#x00ed;ciles de "
-"consultar. En una aplicaci&#x00f3;n grande, casi todas las asociaciones "
-"deben ser navegables en ambas direcciones en consultas."
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+"Las asociaciones unidireccionales son más difíciles de consultar. En una "
+"aplicación grande, casi todas las asociaciones deben ser navegables en ambas "
+"direcciones en consultas."

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/bibliography.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/bibliography.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/bibliography.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -5,7 +5,7 @@
 msgstr ""
 "Project-Id-Version: Branch 3_3\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: 2009-06-10 21:02+0000\n"
 "Last-Translator: Automatically generated\n"
 "Language-Team: none\n"
@@ -14,55 +14,36 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: bibliography.xml:27
 #, no-c-format
 msgid "References"
 msgstr ""
 
 #. Tag: title
-#: bibliography.xml:31
 #, no-c-format
 msgid "Patterns of Enterprise Application Architecture"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:34
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Martin</firstname> <surname>Fowler</surname>"
+msgid "Martin"
 msgstr ""
 
-#. Tag: holder
-#: bibliography.xml:41
-#, no-c-format
-msgid "Pearson Education, Inc."
-msgstr ""
-
 #. Tag: title
-#: bibliography.xml:50
 #, no-c-format
 msgid "Java Persistence with Hibernate"
 msgstr ""
 
 #. Tag: subtitle
-#: bibliography.xml:51
 #, no-c-format
 msgid "Second Edition of Hibernate in Action"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:57
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Christian</firstname> <surname>Bauer</surname>"
+msgid "Christian"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:61
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Gavin</firstname> <surname>King</surname>"
+msgid "Gavin"
 msgstr ""
-
-#. Tag: holder
-#: bibliography.xml:68
-#, no-c-format
-msgid "Manning Publications Co."
-msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/collection_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/collection_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/collection_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,62 +1,50 @@
-#, fuzzy
+# translation of collection_mapping.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: collection_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2010-01-07 09:44+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: collection_mapping.xml:29
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Collection mapping"
-msgstr "Mapeos de colecci&#x00f3;n"
+msgstr "Mapeos de colección "
 
 #. Tag: title
-#: collection_mapping.xml:32
 #, no-c-format
 msgid "Persistent collections"
 msgstr "Colecciones persistentes"
 
 #. Tag: para
-#: collection_mapping.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate requires that persistent collection-valued fields be declared as "
 "an interface type. For example:"
 msgstr ""
-"Hibernate requiere que los campos valuados en colecci&#x00f3;n persistentes "
-"sean declarados como un tipo de interface, por ejemplo:"
+"Hibernate requiere que los campos valuados en colección persistente se "
+"declaren como un tipo de interfaz. Por ejemplo:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:39
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[public class Product {\n"
-"    private String serialNumber;\n"
-"    private Set parts = new HashSet();\n"
-"    \n"
-"    public Set getParts() { return parts; }\n"
-"    void setParts(Set parts) { this.parts = parts; }\n"
-"    public String getSerialNumber() { return serialNumber; }\n"
-"    void setSerialNumber(String sn) { serialNumber = sn; }\n"
-"}]]>"
-msgstr ""
-"<![CDATA[public class Product {\n"
-"    private String serialNumber;\n"
-"    private Set parts = new HashSet();\n"
-"    \n"
-"    public Set getParts() { return parts; }\n"
-"    void setParts(Set parts) { this.parts = parts; }\n"
-"    public String getSerialNumber() { return serialNumber; }\n"
-"    void setSerialNumber(String sn) { serialNumber = sn; }\n"
-"}]]>"
-
-#. Tag: para
-#: collection_mapping.xml:41
-#, fuzzy, no-c-format
-msgid ""
 "The actual interface might be <literal>java.util.Set</literal>, "
 "<literal>java.util.Collection</literal>, <literal>java.util.List</literal>, "
 "<literal>java.util.Map</literal>, <literal>java.util.SortedSet</literal>, "
@@ -64,17 +52,15 @@
 "like\" means you will have to write an implementation of <literal>org."
 "hibernate.usertype.UserCollectionType</literal>.)"
 msgstr ""
-"La interface real podr&#x00ed;a ser <literal>java.util.Set</literal>, "
-"<literal>java.util.Collection</literal>, <literal>java.util.List</literal>, "
-"<literal>java.util.Map</literal>, <literal>java.util.SortedSet</literal>, "
-"<literal>java.util.SortedMap</literal> o ... lo que te guste! (Donde \"lo "
-"que te guste\" significa que tendr&#x00e1;s que escribir una "
-"implementaci&#x00f3;n de <literal>org.hibernate.usertype.UserCollectionType</"
-"literal>.)"
+"La interfaz real puede ser <literal>java.util.Set</literal>, <literal>java."
+"util.Collection</literal>, <literal>java.util.List</literal>, <literal>java."
+"util.Map</literal>, <literal>java.util.SortedSet</literal>, <literal>java."
+"util.SortedMap</literal> o lo que usted quiera (donde \"lo que usted quiera"
+"\" significa que tendrá que escribir una implementación de <literal>org."
+"hibernate.usertype.UserCollectionType</literal>)."
 
 #. Tag: para
-#: collection_mapping.xml:50
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Notice how the instance variable was initialized with an instance of "
 "<literal>HashSet</literal>. This is the best way to initialize collection "
@@ -84,43 +70,17 @@
 "an instance of Hibernate's own implementation of <literal>Set</literal>. Be "
 "aware of the following errors:"
 msgstr ""
-"Nota c&#x00f3;mo hemos inicializado la variable de instancia de "
-"<literal>HashSet</literal>. Esta es la mejor forma de inicializar "
-"propiedades valuadas en colecci&#x00f3;n de instancias reci&#x00e9;n "
-"instanciadas (no persistentes). Cuando haces persistente la instancia - "
-"llamando a <literal>persist()</literal>, por ejemplo - Hibernate realmente "
-"remplazar&#x00e1; el <literal>HashSet</literal> con una instancia de una "
-"implementaci&#x00f3;n de <literal>Set</literal> propia de Hibernate. Observa "
-"errores como este:"
+"Note cómo se inicializó la variable de instancia con una instancia de "
+"<literal>HashSet</literal>. Esta es la mejor forma de inicializar las "
+"propiedades valuadas en colección de instancias recién instanciadas (no "
+"persistentes). Cuando hace persistente la instancia, llamando a "
+"<literal>persist()</literal>, por ejemplo, Hibernate realmente remplazará el "
+"<literal>HashSet</literal> con una instancia de una implementación de "
+"<literal>Set</literal> propia de Hibernate. Observe los siguientes errores:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:60
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Cat cat = new DomesticCat();\n"
-"Cat kitten = new DomesticCat();\n"
-"....\n"
-"Set kittens = new HashSet();\n"
-"kittens.add(kitten);\n"
-"cat.setKittens(kittens);\n"
-"session.persist(cat);\n"
-"kittens = cat.getKittens(); // Okay, kittens collection is a Set\n"
-"(HashSet) cat.getKittens(); // Error!]]>"
-msgstr ""
-"<![CDATA[Cat cat = new DomesticCat();\n"
-"Cat kitten = new DomesticCat();\n"
-"....\n"
-"Set kittens = new HashSet();\n"
-"kittens.add(kitten);\n"
-"cat.setKittens(kittens);\n"
-"session.persist(cat);\n"
-"kittens = cat.getKittens(); // Okay, kittens collection is a Set\n"
-"(HashSet) cat.getKittens(); // Error!]]>"
-
-#. Tag: para
-#: collection_mapping.xml:62
-#, fuzzy, no-c-format
-msgid ""
 "The persistent collections injected by Hibernate behave like "
 "<literal>HashMap</literal>, <literal>HashSet</literal>, <literal>TreeMap</"
 "literal>, <literal>TreeSet</literal> or <literal>ArrayList</literal>, "
@@ -129,11 +89,10 @@
 "Las colecciones persistentes inyectadas por Hibernate se comportan como "
 "<literal>HashMap</literal>, <literal>HashSet</literal>, <literal>TreeMap</"
 "literal>, <literal>TreeSet</literal> o <literal>ArrayList</literal>, "
-"dependiendo del tipo de interface."
+"dependiendo del tipo de interfaz. "
 
 #. Tag: para
-#: collection_mapping.xml:69
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collections instances have the usual behavior of value types. They are "
 "automatically persisted when referenced by a persistent object and are "
@@ -144,85 +103,57 @@
 "properties do not support null value semantics. Hibernate does not "
 "distinguish between a null collection reference and an empty collection."
 msgstr ""
-"Las instancias de colecciones tienen el comportamiento usual de tipos de "
-"valor. Son autom&#x00e1;ticamente persistidas al ser referenciadas por un "
-"objeto persistente y autom&#x00e1;ticamente borradas al desreferenciarse. Si "
-"una colecci&#x00f3;n es pasada de un objeto persistente a otro, sus "
-"elementos ser&#x00ed;an movidos de una tabla a otra. Dos entidades pueden no "
-"compartir una referencia a la misma instancia de colecci&#x00f3;n. Debido al "
-"modelo relacional subyacente, las propiedades valuadas en colecci&#x00f3;n "
-"no soportan la sem&#x00e1;ntica de valor nulo. Hibernate no distingue entre "
-"una referencia de colecci&#x00f3;n nula y una colecci&#x00f3;n vac&#x00ed;a."
+"Las instancias de colecciones tienen el comportamiento usual de los tipos de "
+"valor. Son automáticamente persistidas al ser referenciadas por un objeto "
+"persistente y se borran automáticamente al desreferenciarse. Si una "
+"colección se pasa de un objeto persistente a otro, puede que sus elementos "
+"se muevan de una tabla a otra. Dos entidades no pueden compartir una "
+"referencia a la misma instancia de colección. Debido al modelo relacional "
+"subyacente, las propiedades valuadas en colección no soportan la semántica "
+"de valor nulo. Hibernate no distingue entre una referencia de colección nula "
+"y una colección vacía."
 
 #. Tag: para
-#: collection_mapping.xml:80
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use persistent collections the same way you use ordinary Java collections. "
 "However, please ensure you understand the semantics of bidirectional "
 "associations (these are discussed later)."
 msgstr ""
-"No debes tener que preocuparte demasiado por esto. Usa las colecciones "
-"persistentes de la misma forma en que usas colecciones de Java ordinarias. "
-"S&#x00f3;lo aseg&#x00fa;rate que entiendes la sem&#x00e1;ntica de las "
-"asociaciones bidireccionales (discutida luego)."
+"Utilice las colecciones persistentes de la misma forma en que utiliza "
+"colecciones de Java ordinarias. Sin embargo, asegúrese de que entiende la "
+"semántica de las asociaciones bidireccionales (se discuten más adelante)."
 
 #. Tag: title
-#: collection_mapping.xml:89
 #, no-c-format
 msgid "Collection mappings"
-msgstr "Mapeos de colecci&#x00f3;n"
+msgstr "Mapeos de colección"
 
 #. Tag: para
-#: collection_mapping.xml:92
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are quite a range of mappings that can be generated for collections "
 "that cover many common relational models. We suggest you experiment with the "
 "schema generation tool so that you understand how various mapping "
 "declarations translate to database tables."
 msgstr ""
-"Hay absolutamente un rango de mapeos que pueden ser generados para "
-"colecciones, cubriendo muchos modelos relacionales comunes. Te sugerimos que "
-"experimentes con la herramienta de generaci&#x00f3;n de esquemas para "
-"obtener una idea de c&#x00f3;mo varias declaraciones de mapeo se traducen a "
-"tablas de base de datos."
+"Hay bastantes rangos de mapeos que se pueden generar para colecciones que "
+"cubren muchos modelos relacionales comúnes. Le recomendamos que experimente "
+"con la herramienta de generación de esquemas para comprender cómo se "
+"traducen varias declaraciones de mapeo a tablas de bases de datos."
 
 #. Tag: para
-#: collection_mapping.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The Hibernate mapping element used for mapping a collection depends upon the "
 "type of interface. For example, a <literal>&lt;set&gt;</literal> element is "
 "used for mapping properties of type <literal>Set</literal>."
 msgstr ""
-"El elemento de mapeo de Hibernate usado para mapear una colecci&#x00f3;n "
-"depende del tipo de la interface. Por ejemplom un elemento <literal>&lt;"
-"set&gt;</literal> se usa para mapear propiedades de tipo <literal>Set</"
-"literal>."
+"El elemento de mapeo de Hibernate usado para mapear una colección depende "
+"del tipo de la interfaz. Por ejemplo, un elemento <literal>&lt;set&gt;</"
+"literal> se utiliza para mapear propiedades de tipo <literal>Set</literal>. "
 
-#. Tag: programlisting
-#: collection_mapping.xml:105
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Product\">\n"
-"    <id name=\"serialNumber\" column=\"productSerialNumber\"/>\n"
-"    <set name=\"parts\">\n"
-"        <key column=\"productSerialNumber\" not-null=\"true\"/>\n"
-"        <one-to-many class=\"Part\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Product\">\n"
-"    <id name=\"serialNumber\" column=\"productSerialNumber\"/>\n"
-"    <set name=\"parts\">\n"
-"        <key column=\"productSerialNumber\" not-null=\"true\"/>\n"
-"        <one-to-many class=\"Part\"/>\n"
-"    </set>\n"
-"</class>]]>"
-
 #. Tag: para
-#: collection_mapping.xml:107
 #, no-c-format
 msgid ""
 "Apart from <literal>&lt;set&gt;</literal>, there is also <literal>&lt;"
@@ -231,93 +162,38 @@
 "array&gt;</literal> mapping elements. The <literal>&lt;map&gt;</literal> "
 "element is representative:"
 msgstr ""
-"Aparte de <literal>&lt;set&gt;</literal>, existen adem&#x00e1;s los "
-"elementos de mapeo <literal>&lt;list&gt;</literal>, <literal>&lt;map&gt;</"
-"literal>, <literal>&lt;bag&gt;</literal>, <literal>&lt;array&gt;</literal> y "
+"Aparte de <literal>&lt;set&gt;</literal>, existen además los elementos de "
+"mapeo <literal>&lt;list&gt;</literal>, <literal>&lt;map&gt;</literal>, "
+"<literal>&lt;bag&gt;</literal>, <literal>&lt;array&gt;</literal> y "
 "<literal>&lt;primitive-array&gt;</literal>. El elemento <literal>&lt;map&gt;"
 "</literal> es representativo:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:132
-#, no-c-format
-msgid ""
-"<![CDATA[<map\n"
-"    name=\"propertyName\"\n"
-"    table=\"table_name\"\n"
-"    schema=\"schema_name\"\n"
-"    lazy=\"true|extra|false\"\n"
-"    inverse=\"true|false\"\n"
-"    cascade=\"all|none|save-update|delete|all-delete-orphan|delete-orphan\"\n"
-"    sort=\"unsorted|natural|comparatorClass\"\n"
-"    order-by=\"column_name asc|desc\"\n"
-"    where=\"arbitrary sql where condition\"\n"
-"    fetch=\"join|select|subselect\"\n"
-"    batch-size=\"N\"\n"
-"    access=\"field|property|ClassName\"\n"
-"    optimistic-lock=\"true|false\"\n"
-"    mutable=\"true|false\"\n"
-"    node=\"element-name|.\"\n"
-"    embed-xml=\"true|false\"\n"
-">\n"
-"\n"
-"    <key .... />\n"
-"    <map-key .... />\n"
-"    <element .... />\n"
-"</map>]]>"
-msgstr ""
-"<![CDATA[<map\n"
-"    name=\"propertyName\"\n"
-"    table=\"table_name\"\n"
-"    schema=\"schema_name\"\n"
-"    lazy=\"true|false\"\n"
-"    inverse=\"true|false\"\n"
-"    cascade=\"all|none|save-update|delete|all-delete-orphan\"\n"
-"    sort=\"unsorted|natural|comparatorClass\"\n"
-"    order-by=\"column_name asc|desc\"\n"
-"    where=\"arbitrary sql where condition\"\n"
-"    fetch=\"join|select|subselect\"\n"
-"    batch-size=\"N\"\n"
-"    access=\"field|property|ClassName\"\n"
-"    optimistic-lock=\"true|false\"\n"
-"    node=\"element-name|.\"\n"
-"    embed-xml=\"true|false\"\n"
-">\n"
-"\n"
-"    <key .... />\n"
-"    <map-key .... />\n"
-"    <element .... />\n"
-"</map>]]>"
-
 #. Tag: para
-#: collection_mapping.xml:135
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>name</literal>: the collection property name"
-msgstr "<literal>name</literal> el nombre de la propiedad de colecci&#x00f3;n"
+msgstr "<literal>name</literal>: el nombre de la propiedad de colección"
 
 #. Tag: para
-#: collection_mapping.xml:140
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>table</literal> (optional - defaults to property name): the name of "
 "the collection table. It is not used for one-to-many associations."
 msgstr ""
-"<literal>table</literal> (opcional - por defecto al nombre de la propiedad) "
-"el nombre de la tabla de colecii&#x00f3;n (no usado para asociaciones uno-a-"
-"muchos)"
+"<literal>table</literal> (opcional - por defecto es el nombre de la "
+"propiedad): el nombre de la tabla de colección. No se utiliza para "
+"asociaciones uno-a-muchos."
 
 #. Tag: para
-#: collection_mapping.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>schema</literal> (optional): the name of a table schema to override "
 "the schema declared on the root element"
 msgstr ""
-"<literal>schema</literal> (opcional) el nombre de un esquema de tablas para "
-"sobrescribir el esquema declarado en el elemento ra&#x00ed;z"
+"<literal>schema</literal> (opcional): el nombre de un esquema de tablas para "
+"sobrescribir el esquema declarado en el elemento raíz"
 
 #. Tag: para
-#: collection_mapping.xml:152
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>true</literal>): "
 "disables lazy fetching and specifies that the association is always eagerly "
@@ -325,144 +201,133 @@
 "operations do not initialize the collection. This is suitable for large "
 "collections."
 msgstr ""
-"<literal>lazy</literal> (opcional - por defecto a <literal>true</literal>) "
-"puede ser usado para deshabilitar la recuperaci&#x00f3;n perezosa y "
-"especificar que la asociaci&#x00f3;n es siempre recuperada tempranamente (no "
-"disponible para arrays)"
+"<literal>lazy</literal> (opcional - por defecto es <literal>true</literal>): "
+"deshabilita la recuperación perezosa y especifica que la asociación siempre "
+"es recuperada tempranamente. También se puede utilizar para activar una "
+"recuperación \"extra-perezoza\", en donde la mayoría de las operaciones no "
+"inicializan la colección. Esto es apropiado para colecciones grandes."
 
 #. Tag: para
-#: collection_mapping.xml:161
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>inverse</literal> (optional - defaults to <literal>false</"
 "literal>): marks this collection as the \"inverse\" end of a bidirectional "
 "association."
 msgstr ""
-"<literal>inverse</literal> (opcional - por defecto a <literal>false</"
-"literal>) marca esta colecci&#x00f3;n como el extremo \"inverso\" de una "
-"asociaci&#x00f3;n bidireccional."
+"<literal>inverse</literal> (opcional - por defecto es <literal>false</"
+"literal>): marca esta colección como el extremo \"inverso\" de una "
+"asociación bidireccional."
 
 #. Tag: para
-#: collection_mapping.xml:167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional - defaults to <literal>none</literal>): "
 "enables operations to cascade to child entities."
 msgstr ""
-"<literal>cascade</literal> (opcional - por defecto a <literal>none</"
-"literal>) habilita operaciones en cascada a entidades hijas"
+"<literal>cascade</literal> (opcional - por defecto es <literal>none</"
+"literal>): habilita operaciones en cascada para entidades hijas."
 
 #. Tag: para
-#: collection_mapping.xml:173
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>sort</literal> (optional): specifies a sorted collection with "
 "<literal>natural</literal> sort order or a given comparator class."
 msgstr ""
-"<literal>sort</literal> (opcional) especifica una colecci&#x00f3;n con "
-"ordenamiento <literal>natural</literal>, o una clase comparadora dada"
+"<literal>sort</literal> (opcional): especifica una colección con "
+"ordenamiento <literal>natural</literal>, o una clase comparadora dada."
 
 #. Tag: para
-#: collection_mapping.xml:179
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>order-by</literal> (optional, JDK1.4 only): specifies a table "
 "column or columns that define the iteration order of the <literal>Map</"
 "literal>, <literal>Set</literal> or bag, together with an optional "
 "<literal>asc</literal> or <literal>desc</literal>."
 msgstr ""
-"<literal>order-by</literal> (opcional, s&#x00f3;lo JDK1.4) especifica una "
-"columna de tabla (o columnas) que definen el orden de iteraci&#x00f3;n del "
-"<literal>Map</literal>, <literal>Set</literal> o bag, junto a un "
+"<literal>order-by</literal> (opcional, sólamente en JDK1.4): especifica una "
+"columna de tabla o columnas que definen el orden de iteración del "
+"<literal>Map</literal>, <literal>Set</literal> o bag junto con un "
 "<literal>asc</literal> o <literal>desc</literal> opcional."
 
 #. Tag: para
-#: collection_mapping.xml:186
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>where</literal> (optional): specifies an arbitrary SQL "
 "<literal>WHERE</literal> condition that is used when retrieving or removing "
 "the collection. This is useful if the collection needs to contain only a "
 "subset of the available data."
 msgstr ""
-"<literal>where</literal> (opcional) especifica una condici&#x00f3;n "
-"<literal>WHERE</literal> de SQL arbitrario para ser usada al recuperar o "
-"quitar la colecci&#x00f3;n (&#x00fa;til si la colecci&#x00f3;n debe contener "
-"s&#x00f3;lo un subconjunto de los datos disponibles)"
+"<literal>where</literal> (opcional): especifica una condición "
+"<literal>WHERE</literal> de SQL arbitraria que se utiliza al recuperar o "
+"quitar la colección. Esto es útil si la colección debe contener sólamente un "
+"subconjunto de los datos disponibles."
 
 #. Tag: para
-#: collection_mapping.xml:193
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional, defaults to <literal>select</literal>): "
 "chooses between outer-join fetching, fetching by sequential select, and "
 "fetching by sequential subselect."
 msgstr ""
-"<literal>fetch</literal> (opcional, por defecto a <literal>select</literal>) "
-"Elige entre recuperaci&#x00f3;n por uni&#x00f3;n externa (outer-join), "
-"recuperar por selecci&#x00f3;n secuencial, y recuperaci&#x00f3;n por "
-"subselecci&#x00f3;n secuencial."
+"<literal>fetch</literal> (opcional, por defecto es <literal>select</"
+"literal>): Elige entre la recuperación por unión externa (outer-join), la "
+"recuperación por selección secuencial y la recuperación por subselección "
+"secuencial."
 
 #. Tag: para
-#: collection_mapping.xml:200
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>batch-size</literal> (optional, defaults to <literal>1</literal>): "
 "specifies a \"batch size\" for lazily fetching instances of this collection."
 msgstr ""
-"<literal>batch-size</literal> (opcional, por defecto a <literal>1</literal>) "
-"especifica un \"tama&#x00f1;o de lote\" para la recuperar perezosamente "
-"instancias de esta colecci&#x00f3;n."
+"<literal>batch-size</literal> (opcional, por defecto es <literal>1</"
+"literal>): especifica un \"tamaño de lote\" para recuperar perezosamente "
+"instancias de esta colección."
 
 #. Tag: para
-#: collection_mapping.xml:206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate uses for accessing the collection property "
 "value."
 msgstr ""
-"<literal>access</literal> (opcional - por defecto a <literal>property</"
-"literal>): La estrategia que debe usar Hibernate para acceder al valor de la "
-"propiedad."
+"<literal>access</literal> (opcional - por defecto es <literal>property</"
+"literal>): La estrategia que Hibernate utiliza para acceder al valor de la "
+"propiedad de colección."
 
 #. Tag: para
-#: collection_mapping.xml:212
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that changes to the state of the collection results in "
 "increments of the owning entity's version. For one-to-many associations you "
 "may want to disable this setting."
 msgstr ""
-"<literal>optimistic-lock</literal> (opcional - por defecto a <literal>true</"
-"literal>): Especifica que los cambios de estado de la colecci&#x00f3;n "
-"resultan en incrementos de versi&#x00f3;n de la entidad due&#x00f1;a. (Para "
-"asociaciones uno a muchos, frecuentemente es razonable deshabilitar esta "
-"opci&#x00f3;n.)"
+"<literal>optimistic-lock</literal> (opcional - por defecto es <literal>true</"
+"literal>): Especifica que los cambios de estado de la colección causan "
+"incrementos de la versión de la entidad dueña. Para asociaciones uno a "
+"muchos, es posible que quiera deshabilitar esta opción."
 
 #. Tag: para
-#: collection_mapping.xml:220
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>true</literal>): "
 "a value of <literal>false</literal> specifies that the elements of the "
 "collection never change. This allows for minor performance optimization in "
 "some cases."
 msgstr ""
-"<literal>mutable</literal> (optional - defaults to <literal>true</literal>): "
-"A value of <literal>false</literal> specifies that the elements of the "
-"collection never change (a minor performance optimization in some cases)."
+"<literal>mutable</literal> (opcional - por defectos es <literal>true</"
+"literal>): Un valor <literal>false</literal> especifica que los elementos de "
+"la colección nunca cambian. En algunos casos, esto permite una pequeña "
+"optimización de rendimiento."
 
 #. Tag: title
-#: collection_mapping.xml:230
 #, no-c-format
 msgid "Collection foreign keys"
-msgstr "Claves for&#x00e1;neas de collecci&#x00f3;n"
+msgstr "Claves foráneas de colección"
 
 #. Tag: para
-#: collection_mapping.xml:232
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collection instances are distinguished in the database by the foreign key of "
 "the entity that owns the collection. This foreign key is referred to as the "
@@ -470,69 +335,50 @@
 "table. The collection key column is mapped by the <literal>&lt;key&gt;</"
 "literal> element."
 msgstr ""
-"Las instancias de colecci&#x00f3;n se distinguen en la base de datos por la "
-"clave for&#x00e1;nea de la entidad que posee la colecci&#x00f3;n. Se hace "
-"referencia a esta clave for&#x00e1;nea como la <emphasis>columna clave de "
-"colecci&#x00f3;n</emphasis> (o columnas) de la tabla de colecci&#x00f3;n. La "
-"columna clave de la colecci&#x00f3;n es mapeada por el elemento <literal>&lt;"
-"key&gt;</literal>."
+"Las instancias de colección se distinguen en la base de datos por la clave "
+"foránea de la entidad que posee la colección. Se hace referencia a esta "
+"clave foránea como la <emphasis>columna clave de colección</emphasis> o "
+"columnas de la tabla de colección. El elemento <literal>&lt;key&gt;</"
+"literal> mapea la columna clave de la colección."
 
 #. Tag: para
-#: collection_mapping.xml:240
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There can be a nullability constraint on the foreign key column. For most "
 "collections, this is implied. For unidirectional one-to-many associations, "
 "the foreign key column is nullable by default, so you may need to specify "
 "<literal>not-null=\"true\"</literal>."
 msgstr ""
-"Puede haber una restricci&#x00f3;n de nulabilidad sobre la columna de clave "
-"for&#x00e1;nea. Para la mayor&#x00ed;a de colecciones, esto est&#x00e1; "
-"implicado. Para asociaciones unidireccionales uno a muchos, la columna de "
-"clave for&#x00e1;nea es nulable por defecto, de modo que podr&#x00ed;as "
-"necesitar especificar <literal>not-null=\"true\"</literal>."
+"Puede haber una restricción de nulabilidad sobre la columna de clave "
+"foránea. Para la mayoría de las colecciones, esto es implícito. Para "
+"asociaciones unidireccionales uno-a-muchos, la columna de clave foránea es "
+"nulable por defecto, de modo que puede que necesite especificar <literal>not-"
+"null=\"true\"</literal>."
 
-#. Tag: programlisting
-#: collection_mapping.xml:247
-#, no-c-format
-msgid "<![CDATA[<key column=\"productSerialNumber\" not-null=\"true\"/>]]>"
-msgstr "<![CDATA[<key column=\"productSerialNumber\" not-null=\"true\"/>]]>"
-
 #. Tag: para
-#: collection_mapping.xml:249
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The foreign key constraint can use <literal>ON DELETE CASCADE</literal>."
 msgstr ""
-"La restricci&#x00f3;n de clave for&#x00e1;nea puede usar <literal>ON DELETE "
-"CASCADE</literal>."
+"La restricción de clave foránea puede utilizar <literal>ON DELETE CASCADE</"
+"literal>."
 
-#. Tag: programlisting
-#: collection_mapping.xml:253
-#, no-c-format
-msgid "<![CDATA[<key column=\"productSerialNumber\" on-delete=\"cascade\"/>]]>"
-msgstr ""
-"<![CDATA[<key column=\"productSerialNumber\" on-delete=\"cascade\"/>]]>"
-
 #. Tag: para
-#: collection_mapping.xml:255
 #, no-c-format
 msgid ""
 "See the previous chapter for a full definition of the <literal>&lt;key&gt;</"
 "literal> element."
 msgstr ""
-"Mira el cap&#x00ed;tulo anterior por una definici&#x00f3;n completa del "
-"elemento <literal>&lt;key&gt;</literal>."
+"Vea el capítulo anterior para obtener una definición completa del elemento "
+"<literal>&lt;key&gt;</literal>."
 
 #. Tag: title
-#: collection_mapping.xml:263
 #, no-c-format
 msgid "Collection elements"
-msgstr "Elementos de collecci&#x00f3;n"
+msgstr "Elementos de collección"
 
 #. Tag: para
-#: collection_mapping.xml:265
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collections can contain almost any other Hibernate type, including: basic "
 "types, custom types, components and references to other entities. This is an "
@@ -542,18 +388,16 @@
 "latter case, only the \"link\" between the two objects is considered to be a "
 "state held by the collection."
 msgstr ""
-"Las colecciones pueden contener casi cualquier tipo de Hibernate, incluyendo "
-"todos los tipos b&#x00e1;sicos, componentes, y por supuesto, referencias a "
-"otras entidades. Esta es una distinci&#x00f3;n importante: un objeto en una "
-"colecci&#x00f3;n puede ser manejado con una sem&#x00e1;ntica de \"valor"
-"\" (su ciclo de vida depende completamente del propietario de la "
-"colecci&#x00f3;n) o podr&#x00ed;a ser una referencia a otra entidad, con su "
-"propio ciclo de vida. En el &#x00fa;ltimo caso, s&#x00f3;lo el estado del "
-"\"enlace\" entre los dos objetos se considera mantenido por la "
-"colecci&#x00f3;n."
+"Las colecciones pueden contener casi cualquier tipo de Hibernate, "
+"incluyendo: los tipos básicos, personalizados, componentes y referencias a "
+"otras entidades. Esta es una diferencia importante. Un objeto en una "
+"colección puede ser manejado con una semántica de \"valor\" (su ciclo de "
+"vida depende completamente del propietario de la colección) o podría ser una "
+"referencia a otra entidad, con su propio ciclo de vida. En el último caso, "
+"sólamente el \"enlace\" entre los dos objetos se considera como un estado "
+"mantenido por la colección."
 
 #. Tag: para
-#: collection_mapping.xml:274
 #, no-c-format
 msgid ""
 "The contained type is referred to as the <emphasis>collection element type</"
@@ -564,22 +408,20 @@
 "value semantics, the next two are used to map entity associations."
 msgstr ""
 "Se hace referencia al tipo contenido como el <emphasis>tipo de elemento de "
-"la colecci&#x00f3;n</emphasis>. Los elementos de colecci&#x00f3;n son "
-"mapeados por <literal>&lt;element&gt;</literal> o <literal>&lt;composite-"
-"element&gt;</literal>, o en el caso de referencias de entidades, con "
-"<literal>&lt;one-to-many&gt;</literal> o <literal>&lt;many-to-many&gt;</"
-"literal>. Las dos primeras mapean elementos con sem&#x00e1;ntica de valor, "
-"los dos siguientes son usados para mapear asociaciones de entidades."
+"la colección</emphasis>. Los elementos de colección son mapeados por "
+"<literal>&lt;element&gt;</literal> o <literal>&lt;composite-element&gt;</"
+"literal>, o en el caso de referencias de entidades, con <literal>&lt;one-to-"
+"many&gt;</literal> o <literal>&lt;many-to-many&gt;</literal>. Las dos "
+"primeras mapean elementos con semántica de valor, los dos siguientes se "
+"utilizan para mapear asociaciones de entidades."
 
 #. Tag: title
-#: collection_mapping.xml:286
 #, no-c-format
 msgid "Indexed collections"
 msgstr "Colecciones indexadas"
 
 #. Tag: para
-#: collection_mapping.xml:288
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All collection mappings, except those with set and bag semantics, need an "
 "<emphasis>index column</emphasis> in the collection table. An index column "
@@ -593,553 +435,357 @@
 "index&gt;</literal> element. The mapped column contains sequential integers "
 "that are numbered from zero by default."
 msgstr ""
-"Todos los mapeos de colecci&#x00f3;n, excepto aquellos con sem&#x00e1;ntica "
-"de set o bag, necesitan una <emphasis>columna &#x00ed;ndice</emphasis> en la "
-"tabla de colecci&#x00f3;n, una columna que mapea a un &#x00ed;ndice de "
-"array, o &#x00ed;ndice de <literal>List</literal>, o clave de <literal>Map</"
-"literal>. El &#x00ed;ndice de un <literal>Map</literal> puede ser de "
-"cualquier tipo b&#x00e1;sico, mapeado con <literal>&lt;map-key&gt;</"
-"literal>, o puede ser una referencia de entidad, mapeada con <literal>&lt;"
-"map-key-many-to-many&gt;</literal>, o puede ser un tipo compuesto, mapeado "
-"con <literal>&lt;composite-map-key&gt;</literal>. El &#x00ed;ndice de un "
-"array o lista es siempre de tipo <literal>integer</literal> y se mapea "
-"usando el elemento <literal>&lt;list-index&gt;</literal>. La columna mapeada "
-"contiene enteros secuenciales (numerados desde cero, por defecto)."
+"Todos los mapeos de colección, excepto aquellos con semántica de set o bag, "
+"necesitan una <emphasis>columna índice</emphasis> en la tabla de colección. "
+"Una columna índice es una columna que mapea a un índice de array o índice de "
+"<literal>List</literal> o llave de <literal>Map</literal>. El índice de un "
+"<literal>Map</literal> puede ser de cualquier tipo básico, mapeado con "
+"<literal>&lt;map-key&gt;</literal>. Puede ser una referencia de entidad "
+"mapeada con <literal>&lt;map-key-many-to-many&gt;</literal>, o puede ser un "
+"tipo compuesto mapeado con <literal>&lt;composite-map-key&gt;</literal>. El "
+"índice de un array o lista es siempre de tipo <literal>integer</literal> y "
+"se mapea utilizando el elemento <literal>&lt;list-index&gt;</literal>. La "
+"columna mapeada contiene enteros secuenciales numerados desde cero, por "
+"defecto."
 
-#. Tag: sect2
-#: collection_mapping.xml:299
-#, fuzzy, no-c-format
+#. Tag: para
+#, no-c-format
 msgid ""
-"<programlistingco> <areaspec> <area id=\"index1\" coords=\"2 45\"/> <area id="
-"\"index2\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA[<list-"
-"index \n"
-"        column=\"column_name\"\n"
-"        base=\"0|1|...\"/>]]></programlisting> <calloutlist> <callout "
-"arearefs=\"index1\"> <para> <literal>column_name</literal> (required): the "
-"name of the column holding the collection index values. </para> </callout> "
-"<callout arearefs=\"index1\"> <para> <literal>base</literal> (optional - "
-"defaults to <literal>0</literal>): the value of the index column that "
-"corresponds to the first element of the list or array. </para> </callout> </"
-"calloutlist> </programlistingco> <programlistingco> <areaspec> <area id="
-"\"mapkey1\" coords=\"2 45\"/> <area id=\"mapkey2\" coords=\"3 45\"/> <area "
-"id=\"mapkey3\" coords=\"4 45\"/> </areaspec> <programlisting><![CDATA[<map-"
-"key \n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        type=\"type_name\"\n"
-"        node=\"@attribute-name\"\n"
-"        length=\"N\"/>]]></programlisting> <calloutlist> <callout arearefs="
-"\"mapkey1\"> <para> <literal>column</literal> (optional): the name of the "
-"column holding the collection index values. </para> </callout> <callout "
-"arearefs=\"mapkey2\"> <para> <literal>formula</literal> (optional): a SQL "
-"formula used to evaluate the key of the map. </para> </callout> <callout "
-"arearefs=\"mapkey3\"> <para> <literal>type</literal> (required): the type of "
-"the map keys. </para> </callout> </calloutlist> </programlistingco> "
-"<programlistingco> <areaspec> <area id=\"indexmanytomany1\" coords=\"2 45\"/"
-"> <area id=\"indexmanytomany2\" coords=\"3 45\"/> <area id=\"indexmanytomany3"
-"\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA[<map-key-many-to-"
-"many\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        class=\"ClassName\"\n"
-"/>]]></programlisting> <calloutlist> <callout arearefs=\"indexmanytomany1\"> "
-"<para> <literal>column</literal> (optional): the name of the foreign key "
-"column for the collection index values. </para> </callout> <callout arearefs="
-"\"indexmanytomany2\"> <para> <literal>formula</literal> (optional): a SQ "
-"formula used to evaluate the foreign key of the map key. </para> </callout> "
-"<callout arearefs=\"indexmanytomany3\"> <para> <literal>class</literal> "
-"(required): the entity class used as the map key. </para> </callout> </"
-"calloutlist> </programlistingco>"
+"<literal>column_name</literal> (required): the name of the column holding "
+"the collection index values."
 msgstr ""
-"<programlistingco> <areaspec> <area id=\"index1\" coords=\"2 45\"/> <area id="
-"\"index2\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA[<list-"
-"index \n"
-"        column=\"column_name\"\n"
-"        base=\"0|1|...\"/>]]></programlisting> <calloutlist> <callout "
-"arearefs=\"index1\"> <para> <literal>column_name</literal> (requerido): El "
-"nombre de la columna que tiene los valores &#x00ed;ndice de la "
-"colecci&#x00f3;n. </para> </callout> <callout arearefs=\"index1\"> <para> "
-"<literal>base</literal> (opcional, por defecto a <literal>0</literal>): El "
-"valor de la columna &#x00ed;ndice que corresponde al primer elemento de la "
-"lista o array. </para> </callout> </calloutlist> </programlistingco> "
-"<programlistingco> <areaspec> <area id=\"mapkey1\" coords=\"2 45\"/> <area "
-"id=\"mapkey2\" coords=\"3 45\"/> <area id=\"mapkey3\" coords=\"4 45\"/> </"
-"areaspec> <programlisting><![CDATA[<map-key \n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        type=\"type_name\"\n"
-"        node=\"@attribute-name\"\n"
-"        length=\"N\"/>]]></programlisting> <calloutlist> <callout arearefs="
-"\"mapkey1\"> <para> <literal>column</literal> (opcional): El nombre de la "
-"columna que tiene los valores &#x00ed;ndice de la colecci&#x00f3;n. </para> "
-"</callout> <callout arearefs=\"mapkey2\"> <para> <literal>formula</literal> "
-"(opcional): Una f&#x00f3;rmula SQL usada para evaluar la clave del mapa. </"
-"para> </callout> <callout arearefs=\"mapkey3\"> <para> <literal>type</"
-"literal> (requerido): el tipo de las claves del mapa. </para> </callout> </"
-"calloutlist> </programlistingco> <programlistingco> <areaspec> <area id="
-"\"indexmanytomany1\" coords=\"2 45\"/> <area id=\"indexmanytomany2\" coords="
-"\"3 45\"/> <area id=\"indexmanytomany3\" coords=\"3 45\"/> </areaspec> "
-"<programlisting><![CDATA[<map-key-many-to-many\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        class=\"ClassName\"\n"
-"/>]]></programlisting> <calloutlist> <callout arearefs=\"indexmanytomany1\"> "
-"<para> <literal>column</literal> (opcional): El nombre de la columna clave "
-"for&#x00e1;nea para los valores &#x00ed;ndice de la colecci&#x00f3;n. </"
-"para> </callout> <callout arearefs=\"indexmanytomany2\"> <para> "
-"<literal>formula</literal> (opcional): Una f&#x00f3;rmula SQL usada para "
-"evaluar la clave for&#x00e1;nea de la clave del mapa. </para> </callout> "
-"<callout arearefs=\"indexmanytomany3\"> <para> <literal>class</literal> "
-"(requerido): La clase de entidad usada como clave del mapa. </para> </"
-"callout> </calloutlist> </programlistingco>"
+"<literal>column_name</literal> (requerido): el nombre de la columna que "
+"tiene los valores del índice de la colección."
 
 #. Tag: para
-#: collection_mapping.xml:380
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
+"<literal>base</literal> (optional - defaults to <literal>0</literal>): the "
+"value of the index column that corresponds to the first element of the list "
+"or array."
+msgstr ""
+"<literal>base</literal> (opcional - por defecto es <literal>0</literal>): el "
+"valor de la columna índice que corresponde al primer elemento de la lista o "
+"el array."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>column</literal> (optional): the name of the column holding the "
+"collection index values."
+msgstr ""
+"<literal>column</literal> (opcional): el nombre de la columna que tiene los "
+"valores del índice de colecciones."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>formula</literal> (optional): a SQL formula used to evaluate the "
+"key of the map."
+msgstr ""
+"<literal>formula</literal> (opcional): una fórmula SQL que se usa para "
+"evaluar la clave del mapa."
+
+#. Tag: para
+#, no-c-format
+msgid "<literal>type</literal> (required): the type of the map keys."
+msgstr "<literal>type</literal> (requerido): el tipo de las claves del mapa."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>column</literal> (optional): the name of the foreign key column for "
+"the collection index values."
+msgstr ""
+"<literal>column</literal> (opcional): el nombre de la columna de la clave "
+"foránea para los valores del índice de la colección."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>formula</literal> (optional): a SQ formula used to evaluate the "
+"foreign key of the map key."
+msgstr ""
+"<literal>formula</literal> (opcional): una fórmula SQ utilizada para evaluar "
+"la clave foránea de la clave de mapeos."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>class</literal> (required): the entity class used as the map key."
+msgstr ""
+"<literal>class</literal> (requerido): La clase de entidad que se usa como la "
+"clave mapeada. "
+
+#. Tag: para
+#, no-c-format
+msgid ""
 "If your table does not have an index column, and you still wish to use "
 "<literal>List</literal> as the property type, you can map the property as a "
 "Hibernate <emphasis>&lt;bag&gt;</emphasis>. A bag does not retain its order "
 "when it is retrieved from the database, but it can be optionally sorted or "
 "ordered."
 msgstr ""
-"Si tu tabla no tiene una columna &#x00ed;ndice, y deseas a&#x00fa;n usar "
-"<literal>List</literal> como tipo de propiedad, debes mapear la propiedad "
+"Si su tabla no tiene una columna índice y todavía desea utilizar "
+"<literal>List</literal> como tipo de propiedad, puede mapear la propiedad "
 "como un <emphasis>&lt;bag&gt;</emphasis> de Hibernate. Un bag (bolsa) no "
 "retiene su orden al ser recuperado de la base de datos, pero puede ser "
-"ordenado o clasificado opcionalmente."
+"ordenado o clasificado de manera opcional."
 
 #. Tag: title
-#: collection_mapping.xml:390
 #, no-c-format
 msgid "Collections of values and many-to-many associations"
 msgstr "Colecciones de valores y asociaciones muchos-a-muchos"
 
 #. Tag: para
-#: collection_mapping.xml:392
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Any collection of values or many-to-many associations requires a dedicated "
 "<emphasis>collection table</emphasis> with a foreign key column or columns, "
 "<emphasis>collection element column</emphasis> or columns, and possibly an "
 "index column or columns."
 msgstr ""
-"Cualquier colecci&#x00f3;n de valores o asociaci&#x00f3;n muchos a muchos "
-"requiere una <emphasis>tabla de colecci&#x00f3;n</emphasis> dedicada con una "
-"columna o columnas de clave for&#x00e1;nea, <emphasis>columna de elemento de "
-"colecci&#x00f3;n</emphasis> o columnas y posiblemente una columna o columnas "
-"&#x00ed;ndice."
+"Cualquier colección de valores o asociación muchos-a-muchos requiere una "
+"<emphasis>tabla de colección</emphasis> dedicada con una columna o columnas "
+"de clave foránea, <emphasis>columna de elemento de colección</emphasis> o "
+"columnas y posiblemente una columna o columnas índices."
 
 #. Tag: para
-#: collection_mapping.xml:399
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For a collection of values use the <literal>&lt;element&gt;</literal> tag. "
 "For example:"
 msgstr ""
-"Para una colecci&#x00f3;n de valores, usamos la etiqueta <literal>&lt;"
-"element&gt;</literal>."
+"Para una colección de valores utilice la etiqueta <literal>&lt;element&gt;</"
+"literal>. Por ejemplo:"
 
-#. Tag: sect2
-#: collection_mapping.xml:401
-#, fuzzy, no-c-format
+#. Tag: para
+#, no-c-format
 msgid ""
-"<programlistingco> <areaspec> <area id=\"element1b\" coords=\"2 50\"/> <area "
-"id=\"element2b\" coords=\"3 50\"/> <area id=\"element3b\" coords=\"4 50\"/> "
-"</areaspec> <programlisting><![CDATA[<element\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        type=\"typename\"\n"
-"        length=\"L\"\n"
-"        precision=\"P\"\n"
-"        scale=\"S\"\n"
-"        not-null=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        node=\"element-name\"\n"
-"/>]]></programlisting> <calloutlist> <callout arearefs=\"element1b\"> <para> "
 "<literal>column</literal> (optional): the name of the column holding the "
-"collection element values. </para> </callout> <callout arearefs=\"element2b"
-"\"> <para> <literal>formula</literal> (optional): an SQL formula used to "
-"evaluate the element. </para> </callout> <callout arearefs=\"element3b\"> "
-"<para> <literal>type</literal> (required): the type of the collection "
-"element. </para> </callout> </calloutlist> </programlistingco> <para> A "
-"<emphasis>many-to-many association</emphasis> is specified using the "
-"<literal>&lt;many-to-many&gt;</literal> element. </para> <programlistingco> "
-"<areaspec> <area id=\"manytomany1\" coords=\"2 60\"/> <area id=\"manytomany2"
-"\" coords=\"3 60\"/> <area id=\"manytomany3\" coords=\"4 60\"/> <area id="
-"\"manytomany4\" coords=\"5 60\"/> <area id=\"manytomany5\" coords=\"6 60\"/> "
-"<area id=\"manytomany6\" coords=\"7 60\"/> <area id=\"manytomany7\" coords="
-"\"8 60\"/> <area id=\"manytomany8\" coords=\"9 60\"/> </areaspec> "
-"<programlisting><![CDATA[<many-to-many\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        class=\"ClassName\"\n"
-"        fetch=\"select|join\"\n"
-"        unique=\"true|false\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        node=\"element-name\"\n"
-"        embed-xml=\"true|false\"\n"
-"    />]]></programlisting> <calloutlist> <callout arearefs=\"manytomany1\"> "
-"<para> <literal>column</literal> (optional): the name of the element foreign "
-"key column. </para> </callout> <callout arearefs=\"manytomany2\"> <para> "
-"<literal>formula</literal> (optional): an SQL formula used to evaluate the "
-"element foreign key value. </para> </callout> <callout arearefs=\"manytomany3"
-"\"> <para> <literal>class</literal> (required): the name of the associated "
-"class. </para> </callout> <callout arearefs=\"manytomany4\"> <para> "
-"<literal>fetch</literal> (optional - defaults to <literal>join</literal>): "
-"enables outer-join or sequential select fetching for this association. This "
-"is a special case; for full eager fetching in a single <literal>SELECT</"
-"literal> of an entity and its many-to-many relationships to other entities, "
-"you would enable <literal>join</literal> fetching,not only of the collection "
-"itself, but also with this attribute on the <literal>&lt;many-to-many&gt;</"
-"literal> nested element. </para> </callout> <callout arearefs=\"manytomany5"
-"\"> <para> <literal>unique</literal> (optional): enables the DDL generation "
-"of a unique constraint for the foreign-key column. This makes the "
-"association multiplicity effectively one-to-many. </para> </callout> "
-"<callout arearefs=\"manytomany6\"> <para> <literal>not-found</literal> "
-"(optional - defaults to <literal>exception</literal>): specifies how foreign "
-"keys that reference missing rows will be handled: <literal>ignore</literal> "
-"will treat a missing row as a null association. </para> </callout> <callout "
-"arearefs=\"manytomany7\"> <para> <literal>entity-name</literal> (optional): "
-"the entity name of the associated class, as an alternative to "
-"<literal>class</literal>. </para> </callout> <callout arearefs=\"manytomany8"
-"\"> <para> <literal>property-ref</literal> (optional): the name of a "
-"property of the associated class that is joined to this foreign key. If not "
-"specified, the primary key of the associated class is used. </para> </"
-"callout> </calloutlist> </programlistingco>"
+"collection element values."
 msgstr ""
-"<programlistingco> <areaspec> <area id=\"element1b\" coords=\"2 50\"/> <area "
-"id=\"element2b\" coords=\"3 50\"/> <area id=\"element3b\" coords=\"4 50\"/> "
-"</areaspec> <programlisting><![CDATA[<element\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        type=\"typename\"\n"
-"        length=\"L\"\n"
-"        precision=\"P\"\n"
-"        scale=\"S\"\n"
-"        not-null=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        node=\"element-name\"\n"
-"/>]]></programlisting> <calloutlist> <callout arearefs=\"element1b\"> <para> "
-"<literal>column</literal> (opcional): El nombre de la columna que tiene los "
-"valores de los elementos de la colecci&#x00f3;n. </para> </callout> <callout "
-"arearefs=\"element2b\"> <para> <literal>formula</literal> (opcional): Una "
-"f&#x00f3;rmula SQL usada para evaluar el elemento. </para> </callout> "
-"<callout arearefs=\"element3b\"> <para> <literal>type</literal> (requerido): "
-"El tipo del elemento de colecci&#x00f3;n. </para> </callout> </calloutlist> "
-"</programlistingco> <para> Una <emphasis>asociaci&#x00f3;n muchos-a-muchos</"
-"emphasis> se especifica usando el elemento <literal>&lt;many-to-many&gt;</"
-"literal>. </para> <programlistingco> <areaspec> <area id=\"manytomany1\" "
-"coords=\"2 60\"/> <area id=\"manytomany2\" coords=\"3 60\"/> <area id="
-"\"manytomany3\" coords=\"4 60\"/> <area id=\"manytomany4\" coords=\"5 60\"/> "
-"<area id=\"manytomany5\" coords=\"6 60\"/> <area id=\"manytomany6\" coords="
-"\"7 60\"/> <area id=\"manytomany7\" coords=\"8 60\"/> </areaspec> "
-"<programlisting><![CDATA[<many-to-many\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        class=\"ClassName\"\n"
-"        fetch=\"select|join\"\n"
-"        unique=\"true|false\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\"\n"
-"        embed-xml=\"true|false\"\n"
-"    />]]></programlisting> <calloutlist> <callout arearefs=\"manytomany1\"> "
-"<para> <literal>column</literal> (opcional): El nombre de la columna de "
-"clave for&#x00e1;nea del elemento. </para> </callout> <callout arearefs="
-"\"manytomany2\"> <para> <literal>formula</literal> (opcional): Una f&#x00f3;"
-"rmula SQL opcional usada para evaluar el valor de clave for&#x00e1;nea del "
-"elemento. </para> </callout> <callout arearefs=\"manytomany3\"> <para> "
-"<literal>class</literal> (requerido): El nombre de la clase asociada. </"
-"para> </callout> <callout arearefs=\"manytomany4\"> <para> <literal>fetch</"
-"literal> (opcional - por defecto a <literal>join</literal>): habilita la "
-"recuperaci&#x00f3;n por uni&#x00f3;n externa o selecci&#x00f3;n secuencial "
-"para esta asociaci&#x00f3;n. Este es un caso especial; para una "
-"recuperaci&#x00f3;n completamente temprana (en un solo <literal>SELECT</"
-"literal>) de una entidad y sus relaciones muchos-a-muchos a otras entidades, "
-"deber&#x00ed;as habilitar la recuperaci&#x00f3;n <literal>join</literal> no "
-"s&#x00f3;lo de la colecci&#x00f3;n misma, sino tambi&#x00e9;n con este "
-"atributo en el elemento anidado <literal>&lt;many-to-many&gt;</literal>. </"
-"para> </callout> <callout arearefs=\"manytomany5\"> <para> <literal>unique</"
-"literal> (opcional): Habilita la generaci&#x00f3;n DDL de una "
-"restricci&#x00f3;n de unicidad para la columna clave for&#x00e1;nea. Esto "
-"hace la multiplicidad de la asociaci&#x00f3;n efectivamente uno a muchos. </"
-"para> </callout> <callout arearefs=\"manytomany6\"> <para> <literal>not-"
-"found</literal> (opcional - por defecto a <literal>exception</literal>): "
-"Especifica c&#x00f3;mo ser&#x00e1;n manejadas las claves for&#x00e1;neas que "
-"referencian filas perdidas: <literal>ignore</literal> tratar&#x00e1; una "
-"fila perdida como una asociaci&#x00f3;n nula. </para> </callout> <callout "
-"arearefs=\"manytomany7\"> <para> <literal>entity-name</literal> (opcional): "
-"El nombre de entidad de la clase asociada, como una alternativa a "
-"<literal>class</literal>. </para> </callout> <callout arearefs=\"manytomany8"
-"\"> <para> UNTRANSLATED! <literal>property-ref</literal>: (optional) The "
-"name of a property of the associated class that is joined to this foreign "
-"key. If not specified, the primary key of the associated class is used. </"
-"para> </callout> </calloutlist> </programlistingco>"
+"<literal>column</literal> (opcional): el nombre de la columna que tiene los "
+"valores de los elementos de la colección."
 
 #. Tag: para
-#: collection_mapping.xml:506
 #, no-c-format
-msgid "Here are some examples."
+msgid ""
+"<literal>formula</literal> (optional): an SQL formula used to evaluate the "
+"element."
 msgstr ""
+"<literal>formula</literal> (opcional): una fórmula SQL utilizada para "
+"evaluar el elemento."
 
 #. Tag: para
-#: collection_mapping.xml:509
 #, no-c-format
-msgid "A set of strings:"
+msgid "<literal>type</literal> (required): the type of the collection element."
 msgstr ""
+"<literal>type</literal> (requerido): el tipo del elemento de colección."
 
-#. Tag: programlisting
-#: collection_mapping.xml:513
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"names\" table=\"person_names\">\n"
-"    <key column=\"person_id\"/>\n"
-"    <element column=\"person_name\" type=\"string\"/>\n"
-"</set>]]>"
+"A <emphasis>many-to-many association</emphasis> is specified using the "
+"<literal>&lt;many-to-many&gt;</literal> element."
 msgstr ""
-"<![CDATA[<set name=\"names\" table=\"person_names\">\n"
-"    <key column=\"person_id\"/>\n"
-"    <element column=\"person_name\" type=\"string\"/>\n"
-"</set>]]>"
+"Una <emphasis>asociación muchos-a-muchos</emphasis> se especifica usando el "
+"elemento <literal>&lt;many-to-many&gt;</literal>."
 
 #. Tag: para
-#: collection_mapping.xml:515
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"A bag containing integers with an iteration order determined by the "
-"<literal>order-by</literal> attribute:"
+"<literal>column</literal> (optional): the name of the element foreign key "
+"column."
 msgstr ""
-"Un bag conteniendo enteros (con un orden de iteraci&#x00f3;n determinado por "
-"el atributo <literal>order-by</literal>):"
+"<literal>column</literal> (opcional): el nombre de la columna de clave "
+"foránea elemento."
 
-#. Tag: programlisting
-#: collection_mapping.xml:520
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<bag name=\"sizes\" \n"
-"        table=\"item_sizes\" \n"
-"        order-by=\"size asc\">\n"
-"    <key column=\"item_id\"/>\n"
-"    <element column=\"size\" type=\"integer\"/>\n"
-"</bag>]]>"
+"<literal>formula</literal> (optional): an SQL formula used to evaluate the "
+"element foreign key value."
 msgstr ""
-"<![CDATA[<bag name=\"sizes\" \n"
-"        table=\"item_sizes\" \n"
-"        order-by=\"size asc\">\n"
-"    <key column=\"item_id\"/>\n"
-"    <element column=\"size\" type=\"integer\"/>\n"
-"</bag>]]>"
+"<literal>formula</literal> (opcional): una fórmula SQL utilizada para "
+"evaluar el valor de la clave foránea elemento."
 
 #. Tag: para
-#: collection_mapping.xml:522
-#, fuzzy, no-c-format
-msgid "An array of entities, in this case, a many-to-many association:"
+#, no-c-format
+msgid "<literal>class</literal> (required): the name of the associated class."
+msgstr "<literal>class</literal> (requerido): El nombre de la clase asociada. "
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>fetch</literal> (optional - defaults to <literal>join</literal>): "
+"enables outer-join or sequential select fetching for this association. This "
+"is a special case; for full eager fetching in a single <literal>SELECT</"
+"literal> of an entity and its many-to-many relationships to other entities, "
+"you would enable <literal>join</literal> fetching,not only of the collection "
+"itself, but also with this attribute on the <literal>&lt;many-to-many&gt;</"
+"literal> nested element."
 msgstr ""
-"Un array de entidades - en este caso, una asociaci&#x00f3;n muchos a muchos:"
+"<literal>fetch</literal> (opcional - por defecto es <literal>join</"
+"literal>): habilita la búsqueda de selects secuenciales o de unión externa "
+"para esta asociación. Este es un caso especial; para búsqueda temprana "
+"completa en un solo <literal>SELECT</literal> de una entidad y sus "
+"relaciones muchos-a-muchos con otras entidades, habilitaría la búsqueda "
+"<literal>join</literal>,no solo de la colección misma, si no también con "
+"este atributo en el elemento anidado <literal>&lt;many-to-many&gt;</literal>."
 
-#. Tag: programlisting
-#: collection_mapping.xml:526
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<array name=\"addresses\" \n"
-"        table=\"PersonAddress\" \n"
-"        cascade=\"persist\">\n"
-"    <key column=\"personId\"/>\n"
-"    <list-index column=\"sortOrder\"/>\n"
-"    <many-to-many column=\"addressId\" class=\"Address\"/>\n"
-"</array>]]>"
+"<literal>unique</literal> (optional): enables the DDL generation of a unique "
+"constraint for the foreign-key column. This makes the association "
+"multiplicity effectively one-to-many."
 msgstr ""
-"<![CDATA[<array name=\"addresses\" \n"
-"        table=\"PersonAddress\" \n"
-"        cascade=\"persist\">\n"
-"    <key column=\"personId\"/>\n"
-"    <list-index column=\"sortOrder\"/>\n"
-"    <many-to-many column=\"addressId\" class=\"Address\"/>\n"
-"</array>]]>"
+"<literal>unique</literal> (opcional): habilita la generación DDL de una "
+"restricción única para la columna de la clave foránea. Esto hace la "
+"multiplicidad de la asociación efectivamente uno-a-muchos."
 
 #. Tag: para
-#: collection_mapping.xml:528
 #, no-c-format
-msgid "A map from string indices to dates:"
-msgstr "Un mapa de &#x00ed;ndices de cadenas a fechas:"
+msgid ""
+"<literal>not-found</literal> (optional - defaults to <literal>exception</"
+"literal>): specifies how foreign keys that reference missing rows will be "
+"handled: <literal>ignore</literal> will treat a missing row as a null "
+"association."
+msgstr ""
+"<literal>not-found</literal> (opcional - por defecto es <literal>exception</"
+"literal>): Especifica cómo serán manejadas las claves foráneas que hacen "
+"referencia a filas que falten: <literal>ignore</literal> tratará una fila "
+"que falte como una asociación nula."
 
-#. Tag: programlisting
-#: collection_mapping.xml:532
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<map name=\"holidays\" \n"
-"        table=\"holidays\" \n"
-"        schema=\"dbo\" \n"
-"        order-by=\"hol_name asc\">\n"
-"    <key column=\"id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date\" type=\"date\"/>\n"
-"</map>]]>"
+"<literal>entity-name</literal> (optional): the entity name of the associated "
+"class, as an alternative to <literal>class</literal>."
 msgstr ""
-"<![CDATA[<map name=\"holidays\" \n"
-"        table=\"holidays\" \n"
-"        schema=\"dbo\" \n"
-"        order-by=\"hol_name asc\">\n"
-"    <key column=\"id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date\" type=\"date\"/>\n"
-"</map>]]>"
+"<literal>entity-name</literal> (opcional): El nombre de entidad de la clase "
+"asociada como una alternativa para <literal>class</literal>. "
 
 #. Tag: para
-#: collection_mapping.xml:534
-#, fuzzy, no-c-format
-msgid "A list of components (this is discussed in the next chapter):"
+#, no-c-format
+msgid ""
+"<literal>property-ref</literal> (optional): the name of a property of the "
+"associated class that is joined to this foreign key. If not specified, the "
+"primary key of the associated class is used."
 msgstr ""
-"Una lista de componentes (discutidos en el pr&#x00f3;ximo cap&#x00ed;tulo):"
+"<literal>property-ref</literal> (opcional): el nombre de una propiedad de la "
+"clase asociada que está unida a esta clave foránea. Si no se especifica "
+"entonces se utiliza la clave principal de la clase asociada."
 
-#. Tag: programlisting
-#: collection_mapping.xml:538
+#. Tag: para
 #, no-c-format
+msgid "Here are some examples."
+msgstr "Aquí tiene algunos ejemplos:"
+
+#. Tag: para
+#, no-c-format
+msgid "A set of strings:"
+msgstr "Un grupo de cadenas:"
+
+#. Tag: para
+#, no-c-format
 msgid ""
-"<![CDATA[<list name=\"carComponents\" \n"
-"        table=\"CarComponents\">\n"
-"    <key column=\"carId\"/>\n"
-"    <list-index column=\"sortOrder\"/>\n"
-"    <composite-element class=\"CarComponent\">\n"
-"        <property name=\"price\"/>\n"
-"        <property name=\"type\"/>\n"
-"        <property name=\"serialNumber\" column=\"serialNum\"/>\n"
-"    </composite-element>\n"
-"</list>]]>"
+"A bag containing integers with an iteration order determined by the "
+"<literal>order-by</literal> attribute:"
 msgstr ""
-"<![CDATA[<list name=\"carComponents\" \n"
-"        table=\"CarComponents\">\n"
-"    <key column=\"carId\"/>\n"
-"    <list-index column=\"sortOrder\"/>\n"
-"    <composite-element class=\"CarComponent\">\n"
-"        <property name=\"price\"/>\n"
-"        <property name=\"type\"/>\n"
-"        <property name=\"serialNumber\" column=\"serialNum\"/>\n"
-"    </composite-element>\n"
-"</list>]]>"
+"Un bag que contiene enteros con un orden de iteración determinado por el "
+"atributo <literal>order-by</literal>:"
 
+#. Tag: para
+#, no-c-format
+msgid "An array of entities, in this case, a many-to-many association:"
+msgstr "Una lista de entidades, en este caso, una asociación muchos-a-muchos:"
+
+#. Tag: para
+#, no-c-format
+msgid "A map from string indices to dates:"
+msgstr "Un mapeo de índices de cadenas a fechas:"
+
+#. Tag: para
+#, no-c-format
+msgid "A list of components (this is discussed in the next chapter):"
+msgstr "Una lista de componentes (se discuten en el siguiente capítulo):"
+
 #. Tag: title
-#: collection_mapping.xml:543
 #, no-c-format
 msgid "One-to-many associations"
 msgstr "Asociaciones uno-a-muchos"
 
 #. Tag: para
-#: collection_mapping.xml:545
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>one-to-many association</emphasis> links the tables of two "
 "classes via a foreign key with no intervening collection table. This mapping "
 "loses certain semantics of normal Java collections:"
 msgstr ""
-"Una <emphasis>asociaci&#x00f3;n uno a muchos</emphasis> enlaza las tablas de "
-"dos clases por medio de una clave for&#x00e1;nea, sin intervenci&#x00f3;n de "
-"tabla de colecci&#x00f3;n alguna. Este mapeo pierde cierta sem&#x00e1;ntica "
-"de colecciones Java normales:"
+"Una <emphasis>asociación uno-a-muchos</emphasis> enlaza las tablas de dos "
+"clases por medio de una clave foránea, sin intervención de tabla de "
+"colección alguna. Este mapeo pierde cierta semántica de colecciones Java "
+"normales: "
 
 #. Tag: para
-#: collection_mapping.xml:553
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of the contained entity class cannot belong to more than one "
 "instance of the collection."
 msgstr ""
-"Una instancia de la clase entidad contenida no puede pertenecer a m&#x00e1;s "
-"de una instancia de la colecci&#x00f3;n."
+"Una instancia de la clase entidad contenida no puede pertenecer a más de una "
+"instancia de la colección. "
 
 #. Tag: para
-#: collection_mapping.xml:559
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of the contained entity class cannot appear at more than one "
 "value of the collection index."
 msgstr ""
-"Una instancia de la clase entidad contenida no puede aparecer en m&#x00e1;s "
-"de un valor del &#x00ed;ndice de colecci&#x00f3;n."
+"Una instancia de la clase entidad contenida no puede aparecer en más de un "
+"valor del índice de colección. "
 
 #. Tag: para
-#: collection_mapping.xml:566
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An association from <literal>Product</literal> to <literal>Part</literal> "
 "requires the existence of a foreign key column and possibly an index column "
 "to the <literal>Part</literal> table. A <literal>&lt;one-to-many&gt;</"
 "literal> tag indicates that this is a one-to-many association."
 msgstr ""
-"Una asociaci&#x00f3;n de <literal>Product</literal> a <literal>Part</"
-"literal> requiere la existencia de una columna clave for&#x00e1;nea y "
-"posiblemente una columna &#x00ed;ndice a la tabla <literal>Part</literal>. "
-"Una etiqueta <literal>&lt;one-to-many&gt;</literal> indica que &#x00e9;sta "
-"es una asociaci&#x00f3;n uno a muchos."
+"Una asociación de <literal>Product</literal> a <literal>Part</literal> "
+"requiere la existencia de una columna clave foránea y posiblemente una "
+"columna índice a la tabla <literal>Part</literal>. Una etiqueta <literal>&lt;"
+"one-to-many&gt;</literal> indica que ésta es una asociación uno-a-muchos."
 
-#. Tag: programlisting
-#: collection_mapping.xml:579
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<one-to-many \n"
-"        class=\"ClassName\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\"\n"
-"        embed-xml=\"true|false\"\n"
-"    />]]>"
-msgstr ""
-"<![CDATA[<one-to-many \n"
-"        class=\"ClassName\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\"\n"
-"        embed-xml=\"true|false\"\n"
-"    />]]>"
-
-#. Tag: para
-#: collection_mapping.xml:582
-#, fuzzy, no-c-format
-msgid "<literal>class</literal> (required): the name of the associated class."
-msgstr "<literal>class</literal> (requerido): El nombre de la clase asociada."
-
-#. Tag: para
-#: collection_mapping.xml:587
-#, fuzzy, no-c-format
-msgid ""
 "<literal>not-found</literal> (optional - defaults to <literal>exception</"
 "literal>): specifies how cached identifiers that reference missing rows will "
 "be handled. <literal>ignore</literal> will treat a missing row as a null "
 "association."
 msgstr ""
-"<literal>not-found</literal> (opcional - por defecto a <literal>exception</"
-"literal>): Especifica c&#x00f3;mo ser&#x00e1;n manejados los identificadores "
-"en cach&#x00e9; que referencien filas perdidas: <literal>ignore</literal> "
-"tratar&#x00e1; una fila perdida como una asociaci&#x00f3;n nula."
+"<literal>not-found</literal> (opcional - por defecto es <literal>exception</"
+"literal>): Especifica cómo serán manejados los identificadores en caché que "
+"referencien filas perdidas. <literal>ignore</literal> tratará una fila "
+"perdida como una asociación nula."
 
 #. Tag: para
-#: collection_mapping.xml:594
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"<literal>entity-name</literal> (optional): the entity name of the associated "
-"class, as an alternative to <literal>class</literal>."
-msgstr ""
-"<literal>entity-name</literal> (opcional): El nombre de entidad de la clase "
-"asociada, como una alternativa a <literal>class</literal>."
-
-#. Tag: para
-#: collection_mapping.xml:602
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>&lt;one-to-many&gt;</literal> element does not need to declare "
 "any columns. Nor is it necessary to specify the <literal>table</literal> "
 "name anywhere."
 msgstr ""
-"Observa que el elemento <literal>&lt;one-to-many&gt;</literal> no necesita "
-"declarar ninguna columna. Ni es necesario especificar el nombre de "
-"<literal>table</literal> en ning&#x00fa;n sitio."
+"El elemento <literal>&lt;one-to-many&gt;</literal> no necesita declarar "
+"ninguna columna. Ni es necesario especificar el nombre de <literal>table</"
+"literal> en ningún sitio."
 
 #. Tag: para
-#: collection_mapping.xml:609
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the foreign key column of a <literal>&lt;one-to-many&gt;</literal> "
 "association is declared <literal>NOT NULL</literal>, you must declare the "
@@ -1148,59 +794,37 @@
 "mapping marked <literal>inverse=\"true\"</literal>. See the discussion of "
 "bidirectional associations later in this chapter for more information."
 msgstr ""
-"<emphasis>Nota muy importante:</emphasis> Si la columna clave for&#x00e1;nea "
-"de una asociaci&#x00f3;n <literal>&lt;one-to-many&gt;</literal> es declarada "
-"<literal>NOT NULL</literal>, debes declarar el mapeo de <literal>&lt;key&gt;"
-"</literal> <literal>not-null=\"true\"</literal> o <emphasis>usar una "
-"asociaci&#x00f3;n bidireccional</emphasis> con el mapeo de colecci&#x00f3;n "
-"marcado <literal>inverse=\"true\"</literal>. Ver la discusi&#x00f3;n sobre "
-"asociaciones bidireccionales m&#x00e1;s adelante en este cap&#x00ed;tulo."
+"Si la columna de la clave foránea de una asociación <literal>&lt;one-to-"
+"many&gt;</literal> se declara <literal>NOT NULL</literal>, debe declarar el "
+"mapeo de <literal>&lt;key&gt;</literal><literal>not-null=\"true\"</literal> "
+"o <emphasis> utilizar una asociación bidireccional</emphasis> con el mapeo "
+"de colección marcado <literal>inverse=\"true\"</literal>. Vea la discusión "
+"sobre asociaciones bidireccionales más adelante en este capítulo para "
+"obtener mayor información."
 
 #. Tag: para
-#: collection_mapping.xml:619
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following example shows a map of <literal>Part</literal> entities by "
 "name, where <literal>partName</literal> is a persistent property of "
 "<literal>Part</literal>. Notice the use of a formula-based index:"
 msgstr ""
-"Este ejemplo muestra un mapa de entidades <literal>Part</literal> por nombre "
-"(donde <literal>partName</literal> es una propiedad persistente de "
-"<literal>Part</literal>). Observa el uso de un &#x00ed;ndice basado en "
-"f&#x00f3;rmula."
+"El siguiente ejemplo muestra un mapeo de entidades <literal>Part</literal> "
+"por nombre, en donde <literal>partName</literal> es una propiedad "
+"persistente de <literal>Part</literal>. Observe el uso de un índice basado "
+"en fórmula:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:625
-#, no-c-format
-msgid ""
-"<![CDATA[<map name=\"parts\"\n"
-"        cascade=\"all\">\n"
-"    <key column=\"productId\" not-null=\"true\"/>\n"
-"    <map-key formula=\"partName\"/>\n"
-"    <one-to-many class=\"Part\"/>\n"
-"</map>]]>"
-msgstr ""
-"<![CDATA[<map name=\"parts\"\n"
-"        cascade=\"all\">\n"
-"    <key column=\"productId\" not-null=\"true\"/>\n"
-"    <map-key formula=\"partName\"/>\n"
-"    <one-to-many class=\"Part\"/>\n"
-"</map>]]>"
-
 #. Tag: title
-#: collection_mapping.xml:631
 #, no-c-format
 msgid "Advanced collection mappings"
-msgstr "Mapeos de colecci&#x00f3;n avanzados"
+msgstr "Mapeos de colección avanzados"
 
 #. Tag: title
-#: collection_mapping.xml:634
 #, no-c-format
 msgid "Sorted collections"
 msgstr "Colecciones ordenadas"
 
 #. Tag: para
-#: collection_mapping.xml:636
 #, no-c-format
 msgid ""
 "Hibernate supports collections implementing <literal>java.util.SortedMap</"
@@ -1208,41 +832,10 @@
 "comparator in the mapping file:"
 msgstr ""
 "Hibernate soporta colecciones implementando <literal>java.util.SortedMap</"
-"literal> y <literal>java.util.SortedSet</literal>. Debes especificar un "
-"comparador en el fichero de mapeo:"
+"literal> y <literal>java.util.SortedSet</literal>. Tiene que especificar un "
+"comparador en el archivo de mapeo:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:641
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"aliases\" \n"
-"            table=\"person_aliases\" \n"
-"            sort=\"natural\">\n"
-"    <key column=\"person\"/>\n"
-"    <element column=\"name\" type=\"string\"/>\n"
-"</set>\n"
-"\n"
-"<map name=\"holidays\" sort=\"my.custom.HolidayComparator\">\n"
-"    <key column=\"year_id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date\" type=\"date\"/>\n"
-"</map>]]>"
-msgstr ""
-"<![CDATA[<set name=\"aliases\" \n"
-"            table=\"person_aliases\" \n"
-"            sort=\"natural\">\n"
-"    <key column=\"person\"/>\n"
-"    <element column=\"name\" type=\"string\"/>\n"
-"</set>\n"
-"\n"
-"<map name=\"holidays\" sort=\"my.custom.HolidayComparator\">\n"
-"    <key column=\"year_id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date\" type=\"date\"/>\n"
-"</map>]]>"
-
 #. Tag: para
-#: collection_mapping.xml:643
 #, no-c-format
 msgid ""
 "Allowed values of the <literal>sort</literal> attribute are "
@@ -1254,7 +847,6 @@
 "clase que implemente <literal>java.util.Comparator</literal>."
 
 #. Tag: para
-#: collection_mapping.xml:649
 #, no-c-format
 msgid ""
 "Sorted collections actually behave like <literal>java.util.TreeSet</literal> "
@@ -1264,8 +856,7 @@
 "TreeSet</literal> o <literal>java.util.TreeMap</literal>."
 
 #. Tag: para
-#: collection_mapping.xml:654
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want the database itself to order the collection elements, use the "
 "<literal>order-by</literal> attribute of <literal>set</literal>, "
@@ -1274,315 +865,149 @@
 "<literal>LinkedHashSet</literal> or <literal>LinkedHashMap</literal>. This "
 "performs the ordering in the SQL query and not in the memory."
 msgstr ""
-"Si quieres que la misma base de datos ordene los elementos de colecci&#x00f3;"
-"n usa el atributo <literal>order-by</literal> de los mapeos <literal>set</"
-"literal>, <literal>bag</literal> o <literal>map</literal>. Esta "
-"soluci&#x00f3;n est&#x00e1; disponible s&#x00f3;lo bajo el JDK 1.4 o "
-"superior (est&#x00e1; implementado usando <literal>LinkedHashSet</literal> o "
-"<literal>LinkedHashMap</literal>). Esto realiza la ordenaci&#x00f3;n en la "
-"consulta SQL, no en memoria."
+"Si quiere que la misma base de datos ordene los elementos de la colección, "
+"utilice el atributo <literal>order-by</literal> de los mapeos <literal>set</"
+"literal>, <literal>bag</literal> o <literal>map</literal>. Esta solución "
+"está disponible sólamente bajo el JDK 1.4 o superior y se implementa "
+"utilizando <literal>LinkedHashSet</literal> o <literal>LinkedHashMap</"
+"literal>. Este realiza la ordenación en la consulta SQL y no en memoria."
 
-#. Tag: programlisting
-#: collection_mapping.xml:663
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"aliases\" table=\"person_aliases\" order-by=\"lower"
-"(name) asc\">\n"
-"    <key column=\"person\"/>\n"
-"    <element column=\"name\" type=\"string\"/>\n"
-"</set>\n"
-"\n"
-"<map name=\"holidays\" order-by=\"hol_date, hol_name\">\n"
-"    <key column=\"year_id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date type=\"date\"/>\n"
-"</map>]]>"
-msgstr ""
-"<![CDATA[<set name=\"aliases\" table=\"person_aliases\" order-by=\"lower"
-"(name) asc\">\n"
-"    <key column=\"person\"/>\n"
-"    <element column=\"name\" type=\"string\"/>\n"
-"</set>\n"
-"\n"
-"<map name=\"holidays\" order-by=\"hol_date, hol_name\">\n"
-"    <key column=\"year_id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date type=\"date\"/>\n"
-"</map>]]>"
-
 #. Tag: title
-#: collection_mapping.xml:666
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Nota"
 
 #. Tag: para
-#: collection_mapping.xml:667
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The value of the <literal>order-by</literal> attribute is an SQL ordering, "
 "not an HQL ordering."
 msgstr ""
-"Observa que el valor del atributo <literal>order-by</literal> es una "
-"ordenaci&#x00f3;n SQL, no una ordenaci&#x00f3;n HQL!"
+"El valor del atributo <literal>order-by</literal> es una ordenación SQL, no "
+"una ordenación HQL."
 
 #. Tag: para
-#: collection_mapping.xml:673
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Associations can even be sorted by arbitrary criteria at runtime using a "
 "collection <literal>filter()</literal>:"
 msgstr ""
-"Las asociaciones pueden incluso ser ordenadas por alg&#x00fa;n criterio "
-"arbitrario en tiempo de ejecuci&#x00f3;n usando un <literal>filter()</"
-"literal> de colecci&#x00f3;n."
+"Las asociaciones pueden incluso ser ordenadas por algún criterio arbitrario "
+"en tiempo de ejecución utilizando un <literal>filter()</literal> de "
+"colección:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:678
-#, no-c-format
-msgid ""
-"<![CDATA[sortedUsers = s.createFilter( group.getUsers(), \"order by this.name"
-"\" ).list();]]>"
-msgstr ""
-"<![CDATA[sortedUsers = s.createFilter( group.getUsers(), \"order by this.name"
-"\" ).list();]]>"
-
 #. Tag: title
-#: collection_mapping.xml:683
 #, no-c-format
 msgid "Bidirectional associations"
 msgstr "Asociaciones bidireccionales"
 
 #. Tag: para
-#: collection_mapping.xml:685
 #, no-c-format
 msgid ""
 "A <emphasis>bidirectional association</emphasis> allows navigation from both "
 "\"ends\" of the association. Two kinds of bidirectional association are "
 "supported:"
 msgstr ""
-"Una <emphasis>asociaci&#x00f3;n bidireccional</emphasis> permite la "
-"nevegaci&#x00f3;n desde ambos \"extremos\" de la asociaci&#x00f3;n. Son "
-"soportados dos tipos de asociaci&#x00f3;n bidireccional:"
+"Una <emphasis>asociación bidireccional</emphasis> permite la navegación "
+"desde ambos \"extremos\" de la asociación. Se soportan dos tipos de "
+"asociación bidireccional:"
 
 #. Tag: term
-#: collection_mapping.xml:692
 #, no-c-format
 msgid "one-to-many"
 msgstr "uno-a-muchos"
 
 #. Tag: para
-#: collection_mapping.xml:694
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "set or bag valued at one end and single-valued at the other"
-msgstr "set o bag valorados en un extremo, monovaluados al otro"
+msgstr "conjunto o bag valorados en un lado, monovaluados en el otro"
 
 #. Tag: term
-#: collection_mapping.xml:700
 #, no-c-format
 msgid "many-to-many"
 msgstr "muchos-a-muchos"
 
 #. Tag: para
-#: collection_mapping.xml:702
 #, no-c-format
 msgid "set or bag valued at both ends"
-msgstr "set o bag valorados a ambos extremos"
+msgstr "set o bag valorados en ambos extremos"
 
 #. Tag: para
-#: collection_mapping.xml:711
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can specify a bidirectional many-to-many association by mapping two many-"
 "to-many associations to the same database table and declaring one end as "
 "<emphasis>inverse</emphasis>. You cannot select an indexed collection."
 msgstr ""
-"Puedes especificar una asociaci&#x00f3;n bidireccional muchos-a-muchos "
-"simplemente mapeando dos asociaciones muchos-a-muchos a la misma tabla de "
-"base de datos y declarando un extremo como <emphasis>inverse</emphasis> "
-"(cu&#x00e1;l de ellos es tu elecci&#x00f3;n, pero no puede ser una "
-"colecci&#x00f3;n indexada)."
+"Puede especificar una asociación bidireccional muchos-a-muchos simplemente "
+"mapeando dos asociaciones muchos-a-muchos a la misma tabla de base de datos "
+"y declarando un extremo como <emphasis>inverso</emphasis> (cuál de ellos, "
+"usted escoge, pero no puede ser una colección indexada)."
 
 #. Tag: para
-#: collection_mapping.xml:718
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Here is an example of a bidirectional many-to-many association that "
 "illustrates how each category can have many items and each item can be in "
 "many categories:"
 msgstr ""
-"He aqu&#x00ed; un ejemplo de una asociaci&#x00f3;n bidireccional muchos-a-"
-"muchos; cada categor&#x00ed;a puede tener muchos &#x00ed;tems y cada &#x00ed;"
-"tem puede estar en muchas categor&#x00ed;as:"
+"He aquí un ejemplo de una asociación bidireccional muchos-a-muchos que "
+"ilustra la manera en que cada categoría puede tener muchos ítems y cada ítem "
+"puede estar en muchas categorías:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:723
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Category\">\n"
-"    <id name=\"id\" column=\"CATEGORY_ID\"/>\n"
-"    ...\n"
-"    <bag name=\"items\" table=\"CATEGORY_ITEM\">\n"
-"        <key column=\"CATEGORY_ID\"/>\n"
-"        <many-to-many class=\"Item\" column=\"ITEM_ID\"/>\n"
-"    </bag>\n"
-"</class>\n"
-"\n"
-"<class name=\"Item\">\n"
-"    <id name=\"id\" column=\"ITEM_ID\"/>\n"
-"    ...\n"
-"\n"
-"    <!-- inverse end -->\n"
-"    <bag name=\"categories\" table=\"CATEGORY_ITEM\" inverse=\"true\">\n"
-"        <key column=\"ITEM_ID\"/>\n"
-"        <many-to-many class=\"Category\" column=\"CATEGORY_ID\"/>\n"
-"    </bag>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Category\">\n"
-"    <id name=\"id\" column=\"CATEGORY_ID\"/>\n"
-"    ...\n"
-"    <bag name=\"items\" table=\"CATEGORY_ITEM\">\n"
-"        <key column=\"CATEGORY_ID\"/>\n"
-"        <many-to-many class=\"Item\" column=\"ITEM_ID\"/>\n"
-"    </bag>\n"
-"</class>\n"
-"\n"
-"<class name=\"Item\">\n"
-"    <id name=\"id\" column=\"ITEM_ID\"/>\n"
-"    ...\n"
-"\n"
-"    <!-- inverse end -->\n"
-"    <bag name=\"categories\" table=\"CATEGORY_ITEM\" inverse=\"true\">\n"
-"        <key column=\"ITEM_ID\"/>\n"
-"        <many-to-many class=\"Category\" column=\"CATEGORY_ID\"/>\n"
-"    </bag>\n"
-"</class>]]>"
-
-#. Tag: para
-#: collection_mapping.xml:725
-#, fuzzy, no-c-format
-msgid ""
 "Changes made only to the inverse end of the association are <emphasis>not</"
 "emphasis> persisted. This means that Hibernate has two representations in "
 "memory for every bidirectional association: one link from A to B and another "
 "link from B to A. This is easier to understand if you think about the Java "
 "object model and how a many-to-many relationship in Javais created:"
 msgstr ""
-"Los cambios hechos s&#x00f3;lo al extremo inverso de la asociaci&#x00f3;n "
+"Los cambios realizados sólamente al extremo inverso de la asociación "
 "<emphasis>no</emphasis> son persistidos. Esto significa que Hibernate tiene "
-"dos representaciones en memoria para cada asociaci&#x00f3;n bidireccional, "
-"una enlaza de A a B y otra enlaza de B a A. Esto es m&#x00e1;s f&#x00e1;cil "
-"de entender si piensas en el modelo de objetos de Java y c&#x00f3;mo creamos "
-"una relaci&#x00f3;n muchos-a-muchos en Java:"
+"dos representaciones en memoria para cada asociación bidireccional: un "
+"enlace de A a B y otro enlace de B a A. Esto es más fácil de entender si "
+"piensa en el modelo de objetos de Java y cómo creamos una relación muchos-a-"
+"muchos en Java:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:733
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"category.getItems().add(item);          // The category now \"knows\" about "
-"the relationship\n"
-"item.getCategories().add(category);     // The item now \"knows\" about the "
-"relationship\n"
-"\n"
-"session.persist(item);                   // The relationship won't be "
-"saved!\n"
-"session.persist(category);               // The relationship will be saved]]>"
-msgstr ""
-"<![CDATA[\n"
-"category.getItems().add(item);          // The category now \"knows\" about "
-"the relationship\n"
-"item.getCategories().add(category);     // The item now \"knows\" about the "
-"relationship\n"
-"\n"
-"session.persist(item);                   // The relationship won't be "
-"saved!\n"
-"session.persist(category);               // The relationship will be saved]]>"
-
 #. Tag: para
-#: collection_mapping.xml:735
 #, no-c-format
 msgid ""
 "The non-inverse side is used to save the in-memory representation to the "
 "database."
 msgstr ""
-"El lado no-inverso se usa para salvar la representaci&#x00f3;n en memoria a "
-"la base de datos."
+"El lado no-inverso se utiliza para guardar la representación en memoria a la "
+"base de datos."
 
 #. Tag: para
-#: collection_mapping.xml:739
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can define a bidirectional one-to-many association by mapping a one-to-"
 "many association to the same table column(s) as a many-to-one association "
 "and declaring the many-valued end <literal>inverse=\"true\"</literal>."
 msgstr ""
-"Puedes definir una asociaci&#x00f3;n bidireccional uno-a-muchos mapeando una "
-"asociaci&#x00f3;n uno-a-muchos a la misma columna (o columnas) de tabla como "
-"una asociaci&#x00f3;n muchos-a-uno y declarando el extremo multivaluado "
+"Puede definir una asociación bidireccional uno-a-muchos mapeando una "
+"asociación uno-a-muchos a la misma columna (o columnas) de tabla como una "
+"asociación muchos-a-uno y declarando el extremo multivaluado "
 "<literal>inverse=\"true\"</literal>."
 
-#. Tag: programlisting
-#: collection_mapping.xml:745
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <set name=\"children\" inverse=\"true\">\n"
-"        <key column=\"parent_id\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <set name=\"children\" inverse=\"true\">\n"
-"        <key column=\"parent_id\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"eg.Child\">\n"
-"    <id name=\"id\" column=\"id\"/>\n"
-"    ....\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-
-#. Tag: para
-#: collection_mapping.xml:747
-#, fuzzy, no-c-format
-msgid ""
 "Mapping one end of an association with <literal>inverse=\"true\"</literal> "
 "does not affect the operation of cascades as these are orthogonal concepts."
 msgstr ""
-"Mapear un extremo de una asociaci&#x00f3;n con <literal>inverse=\"true\"</"
-"literal> no afecta la operaci&#x00f3;n de cascadas; &#x00e9;stos son "
-"conceptos ortogonales!"
+"Mapear un extremo de una asociación con <literal>inverse=\"true\"</literal> "
+"no afecta la operación de cascadas ay que éstos son conceptos ortogonales."
 
 #. Tag: title
-#: collection_mapping.xml:755
 #, no-c-format
 msgid "Bidirectional associations with indexed collections"
 msgstr "Asociaciones bidireccionales con colecciones indexadas"
 
 #. Tag: para
-#: collection_mapping.xml:756
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A bidirectional association where one end is represented as a <literal>&lt;"
 "list&gt;</literal> or <literal>&lt;map&gt;</literal>, requires special "
@@ -1590,217 +1015,75 @@
 "index column you can use <literal>inverse=\"true\"</literal> on the "
 "collection mapping:"
 msgstr ""
-"Requiere especial consideraci&#x00f3;n una asociaci&#x00f3;n bidireccional "
-"donde un extremo est&#x00e9; representado como una <literal>&lt;list&gt;</"
-"literal> o <literal>&lt;map&gt;</literal>. Si hay una propiedad de la clase "
-"hija que mapee a la columna &#x00ed;ndice, no hay problema, podemos seguir "
-"usando <literal>inverse=\"true\"</literal> en el mapeo de la colecci&#x00f3;"
-"n:"
+"Requiere especial atención una asociación bidireccional en donde un extremo "
+"esté representado como una <literal>&lt;list&gt;</literal> o <literal>&lt;"
+"map&gt;</literal>. Si hay una propiedad de la clase hija que mapee a la "
+"columna índice, puede utilizar <literal>inverse=\"true\"</literal> en el "
+"mapeo de la colección:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:763
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <map name=\"children\" inverse=\"true\">\n"
-"        <key column=\"parent_id\"/>\n"
-"        <map-key column=\"name\" \n"
-"            type=\"string\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </map>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <property name=\"name\" \n"
-"        not-null=\"true\"/>\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <map name=\"children\" inverse=\"true\">\n"
-"        <key column=\"parent_id\"/>\n"
-"        <map-key column=\"name\" \n"
-"            type=\"string\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </map>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <property name=\"name\" \n"
-"        not-null=\"true\"/>\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-
-#. Tag: para
-#: collection_mapping.xml:765
-#, fuzzy, no-c-format
-msgid ""
 "If there is no such property on the child class, the association cannot be "
 "considered truly bidirectional. That is, there is information available at "
 "one end of the association that is not available at the other end. In this "
 "case, you cannot map the collection <literal>inverse=\"true\"</literal>. "
 "Instead, you could use the following mapping:"
 msgstr ""
-"Pero, si no existe tal proiedad en la clase hija, no podemos pensar en la "
-"asociaci&#x00f3;n como verdaderamente bidireccional (hay informaci&#x00f3;n "
-"en un extremo de la asociaci&#x00f3;n que no est&#x00e1; disponible en el "
-"otro extremo). En este caso, no podemos mapear la colecci&#x00f3;n con "
-"<literal>inverse=\"true\"</literal>. En cambio, podr&#x00ed;amos usar el "
-"siguiente mapeo:"
+"Si no existe tal propiedad en la clase hija, no podemos considerar la "
+"asociación como verdaderamente bidireccional. Es decir, hay información en "
+"un extremo de la asociación que no está disponible en el otro extremo. En "
+"este caso, no puede mapear la colección con <literal>inverse=\"true\"</"
+"literal>. En cambio, puede usar el siguiente mapeo:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:772
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <map name=\"children\">\n"
-"        <key column=\"parent_id\"\n"
-"            not-null=\"true\"/>\n"
-"        <map-key column=\"name\" \n"
-"            type=\"string\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </map>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        insert=\"false\"\n"
-"        update=\"false\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <map name=\"children\">\n"
-"        <key column=\"parent_id\"\n"
-"            not-null=\"true\"/>\n"
-"        <map-key column=\"name\" \n"
-"            type=\"string\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </map>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        insert=\"false\"\n"
-"        update=\"false\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-
 #. Tag: para
-#: collection_mapping.xml:774
 #, fuzzy, no-c-format
 msgid ""
 "Note that in this mapping, the collection-valued end of the association is "
 "responsible for updates to the foreign key."
 msgstr ""
-"Nota que, en este mapeo, el extremo de la asociaci&#x00f3;n valuado en "
-"colecci&#x00f3;n es responsable de las actualizaciones a la clave for&#x00e1;"
-"nea."
+"Note que en este mapeo, el extremo de la asociación valuado en colección es "
+"responsable de las actualizaciones de la clave foránea."
 
 #. Tag: title
-#: collection_mapping.xml:782
 #, no-c-format
 msgid "Ternary associations"
 msgstr "Asociaciones ternarias"
 
 #. Tag: para
-#: collection_mapping.xml:784
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are three possible approaches to mapping a ternary association. One "
 "approach is to use a <literal>Map</literal> with an association as its index:"
 msgstr ""
-"Hay tres enfoques posibles para mapear una asociaci&#x00f3;n ternaria. Una "
-"es usar un <literal>Map</literal> con una asociaci&#x00f3;n como su &#x00ed;"
-"ndice:"
+"Hay tres enfoques posibles para mapear una asociación ternaria. Una es "
+"utilizar un <literal>Map</literal> con una asociación como su índice: "
 
-#. Tag: programlisting
-#: collection_mapping.xml:789
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<map name=\"contracts\">\n"
-"    <key column=\"employer_id\" not-null=\"true\"/>\n"
-"    <map-key-many-to-many column=\"employee_id\" class=\"Employee\"/>\n"
-"    <one-to-many class=\"Contract\"/>\n"
-"</map>]]>"
-msgstr ""
-"<![CDATA[<map name=\"contracts\">\n"
-"    <key column=\"employer_id\" not-null=\"true\"/>\n"
-"    <map-key-many-to-many column=\"employee_id\" class=\"Employee\"/>\n"
-"    <one-to-many class=\"Contract\"/>\n"
-"</map>]]>"
-
-#. Tag: programlisting
-#: collection_mapping.xml:791
-#, no-c-format
-msgid ""
-"<![CDATA[<map name=\"connections\">\n"
-"    <key column=\"incoming_node_id\"/>\n"
-"    <map-key-many-to-many column=\"outgoing_node_id\" class=\"Node\"/>\n"
-"    <many-to-many column=\"connection_id\" class=\"Connection\"/>\n"
-"</map>]]>"
-msgstr ""
-"<![CDATA[<map name=\"connections\">\n"
-"    <key column=\"incoming_node_id\"/>\n"
-"    <map-key-many-to-many column=\"outgoing_node_id\" class=\"Node\"/>\n"
-"    <many-to-many column=\"connection_id\" class=\"Connection\"/>\n"
-"</map>]]>"
-
-#. Tag: para
-#: collection_mapping.xml:793
-#, fuzzy, no-c-format
-msgid ""
 "A second approach is to remodel the association as an entity class. This is "
 "the most common approach."
 msgstr ""
-"Un segundo enfoque es simplemente remodelar la asociaci&#x00f3;n como una "
-"clase de entidad. Este es el enfoque que usamos m&#x00e1;s comunmente."
+"Un segundo enfoque es remodelar la asociación como una clase de entidad. "
+"Este es el enfoque más común."
 
 #. Tag: para
-#: collection_mapping.xml:798
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A final alternative is to use composite elements, which will be discussed "
 "later."
 msgstr ""
-"Una alternativa final es usar elementos compuestos, que discutiremos "
-"m&#x00e1;s adelante."
+"La última opción es utilizar elementos compuestos que discutiremos más "
+"adelante."
 
-#. Tag: literal
-#: collection_mapping.xml:805
-#, no-c-format
-msgid "Using an &lt;idbag&gt;"
-msgstr "Usando un &lt;idbag&gt;"
+#. Tag: title
+#, fuzzy, no-c-format
+msgid "<literal>Using an &lt;idbag&gt;</literal>"
+msgstr "<literal>Utilización de un &lt;idbag&gt;</literal>"
 
 #. Tag: para
-#: collection_mapping.xml:807
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The majority of the many-to-many associations and collections of values "
 "shown previously all map to tables with composite keys, even though it has "
@@ -1811,486 +1094,146 @@
 "feature that allows you to map many-to-many associations and collections of "
 "values to a table with a surrogate key."
 msgstr ""
-"Si has adoptado completamente nuestra visi&#x00f3;n de que las claves "
-"compuestas son una cosa mala y que las entidades deben tener identificadores "
-"sit&#x00e9;ticos (claves delegadas), entonces podr&#x00ed;as encontrar un "
-"poco raro que todas las asociaciones muchos a muchos y las colecciones de "
-"valores que hemos mostrado hasta ahora mapeen a tablas con claves "
-"compuestas! Ahora, este punto es discutible; una tabla de pura "
-"asociaci&#x00f3;n no parece beneficiarse demasiado de una clave delegada "
-"(aunque s&#x00ed; <emphasis>podr&#x00ed;a</emphasis> una colecci&#x00f3;n de "
-"valores compuestos). Sin embargo, Hibernate provee una funcionalidad que te "
-"permite mapear asociaciones muchos a muchos y colecciones de valores a una "
-"tabla con una clave delegada."
+"La mayoría de las asociaciones muchos-a-muchos y las colecciones de valores "
+"que hemos mostrado hasta ahora mapean a tablas con claves compuestas, aunque "
+"se ha sugerido que las entidades deben tener identificadores sintéticos "
+"(llaves sustitutas). Una tabla de pura asociación no parece beneficiarse "
+"mucho de una llave sustituta, aunque sí <emphasis>podría</emphasis> "
+"beneficiarse una colección de valores compuestos. Es por esto que Hibernate "
+"brinda una funcionalidad que le permite mapear asociaciones muchos a muchos "
+"y colecciones de valores a una tabla con una llave sustituta."
 
 #. Tag: para
-#: collection_mapping.xml:817
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;idbag&gt;</literal> element lets you map a <literal>List</"
 "literal> (or <literal>Collection</literal>) with bag semantics. For example:"
 msgstr ""
-"El elemento <literal>&lt;idbag&gt;</literal> te permite mapear una "
-"<literal>List</literal> (o <literal>Collection</literal>) con sem&#x00e1;"
-"ntica de bag."
+"El elemento <literal>&lt;idbag&gt;</literal> le permite mapear una "
+"<literal>List</literal> (o <literal>Collection</literal>) con semántica de "
+"bag. Por ejemplo:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:822
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<idbag name=\"lovers\" table=\"LOVERS\">\n"
-"    <collection-id column=\"ID\" type=\"long\">\n"
-"        <generator class=\"sequence\"/>\n"
-"    </collection-id>\n"
-"    <key column=\"PERSON1\"/>\n"
-"    <many-to-many column=\"PERSON2\" class=\"Person\" fetch=\"join\"/>\n"
-"</idbag>]]>"
-msgstr ""
-"<![CDATA[<idbag name=\"lovers\" table=\"LOVERS\">\n"
-"    <collection-id column=\"ID\" type=\"long\">\n"
-"        <generator class=\"sequence\"/>\n"
-"    </collection-id>\n"
-"    <key column=\"PERSON1\"/>\n"
-"    <many-to-many column=\"PERSON2\" class=\"Person\" fetch=\"join\"/>\n"
-"</idbag>]]>"
-
-#. Tag: para
-#: collection_mapping.xml:824
-#, fuzzy, no-c-format
-msgid ""
 "An <literal>&lt;idbag&gt;</literal> has a synthetic id generator, just like "
 "an entity class. A different surrogate key is assigned to each collection "
 "row. Hibernate does not, however, provide any mechanism for discovering the "
 "surrogate key value of a particular row."
 msgstr ""
-"Como puedes ver, un <literal>&lt;idbag&gt;</literal> tiene un generador de "
-"id sint&#x00e9;tico, igual que una clase de entidad! Una clave delegada "
-"diferente se asigna a cada fila de la colecci&#x00f3;n. Hibernate no provee "
-"ning&#x00fa;n mecanismo para descubrir el valor de clave delegada de una "
-"fila en particular, sin embargo."
+"Un <literal>&lt;idbag&gt;</literal> tiene un generador de id sintético, al "
+"igual que una clase de entidad. Se asigna una clave delegada diferente a "
+"cada fila de la colección. Sin embargo, Hibernate no proporciona ningún "
+"mecanismo para descubrir el valor de la clave delegada de una fila en "
+"particular."
 
 #. Tag: para
-#: collection_mapping.xml:831
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The update performance of an <literal>&lt;idbag&gt;</literal> supersedes a "
 "regular <literal>&lt;bag&gt;</literal>. Hibernate can locate individual rows "
 "efficiently and update or delete them individually, similar to a list, map "
 "or set."
 msgstr ""
-"Observa que el rendimiento de actualizaci&#x00f3;n de un <literal>&lt;"
-"idbag&gt;</literal> es <emphasis>mucho</emphasis> mejor que el de un "
-"<literal>&lt;bag&gt;</literal> regular! Hibernate puede localizar filas "
-"individuales eficientemente y actualizarlas o borrarlas individualmente, "
-"igual que si fuese una lista, mapa o conjunto."
+"El rendimiento de actualización de un <literal>&lt;idbag&gt;</literal> es "
+"mucho mejor que el de un <literal>&lt;bag&gt;</literal> normal. Hibernate "
+"puede localizar filas individuales eficientemente y actualizarlas o "
+"borrarlas individualmente, al igual que si fuese una lista, mapa o conjunto."
 
 #. Tag: para
-#: collection_mapping.xml:837
 #, no-c-format
 msgid ""
 "In the current implementation, the <literal>native</literal> identifier "
 "generation strategy is not supported for <literal>&lt;idbag&gt;</literal> "
 "collection identifiers."
 msgstr ""
-"En la implementaci&#x00f3;n actual, la estrategia de generaci&#x00f3;n de "
-"identificador <literal>native</literal> no est&#x00e1; soportada para "
-"identificadores de colecciones <literal>&lt;idbag&gt;</literal>."
+"En la implementación actual, la estrategia de generación de identificador "
+"<literal>native</literal> no se encuentra soportada para identificadores de "
+"colecciones <literal>&lt;idbag&gt;</literal>."
 
 #. Tag: title
-#: collection_mapping.xml:861
 #, no-c-format
 msgid "Collection examples"
-msgstr "Ejemplos de colecci&#x00f3;n"
+msgstr "Ejemplos de colección"
 
 #. Tag: para
-#: collection_mapping.xml:863
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This section covers collection examples."
-msgstr "Ejemplos de colecci&#x00f3;n"
+msgstr "Esta sección cubre los ejemplos de colección. "
 
 #. Tag: para
-#: collection_mapping.xml:867
 #, no-c-format
 msgid ""
 "The following class has a collection of <literal>Child</literal> instances:"
 msgstr ""
+"La siguiente clase tiene una colección de instancias <literal>Child</"
+"literal>:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:871
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"\n"
-"public class Parent {\n"
-"    private long id;\n"
-"    private Set children;\n"
-"\n"
-"    public long getId() { return id; }\n"
-"    private void setId(long id) { this.id=id; }\n"
-"\n"
-"    private Set getChildren() { return children; }\n"
-"    private void setChildren(Set children) { this.children=children; }\n"
-"\n"
-"    ....\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"\n"
-"public class Parent {\n"
-"    private long id;\n"
-"    private Set children;\n"
-"\n"
-"    public long getId() { return id; }\n"
-"    private void setId(long id) { this.id=id; }\n"
-"\n"
-"    private Set getChildren() { return children; }\n"
-"    private void setChildren(Set children) { this.children=children; }\n"
-"\n"
-"    ....\n"
-"    ....\n"
-"}]]>"
-
-#. Tag: para
-#: collection_mapping.xml:873
-#, fuzzy, no-c-format
-msgid ""
 "If each child has, at most, one parent, the most natural mapping is a one-to-"
 "many association:"
 msgstr ""
-"tiene una colecci&#x00f3;n de instancias de <literal>Child</literal>. Si "
-"cada hijo tiene como mucho un padre, el mapeo m&#x00e1;s natural es una "
-"asociaci&#x00f3;n uno-a-muchos:"
+"Si cada hijo tiene como mucho un padre, el mapeo más natural es una "
+"asociación uno-a-muchos:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:879
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-
 #. Tag: para
-#: collection_mapping.xml:881
 #, no-c-format
 msgid "This maps to the following table definitions:"
-msgstr "Esto mapea a las siguientes definiciones de tablas:"
+msgstr "Esto mapea a las siguientes definiciones de tabla:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:885
-#, no-c-format
-msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null primary key, name varchar(255), "
-"parent_id bigint )\n"
-"alter table child add constraint childfk0 (parent_id) references parent]]>"
-msgstr ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null primary key, name varchar(255), "
-"parent_id bigint )\n"
-"alter table child add constraint childfk0 (parent_id) references parent]]>"
-
 #. Tag: para
-#: collection_mapping.xml:887
 #, no-c-format
 msgid ""
 "If the parent is <emphasis>required</emphasis>, use a bidirectional one-to-"
 "many association:"
 msgstr ""
-"Si el padre es <emphasis>requerido</emphasis>, usa una asociaci&#x00f3;n "
+"Si el padre es <emphasis>requerido</emphasis>, utilice una asociación "
 "bidireccional uno-a-muchos:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:892
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\" inverse=\"true\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"        <many-to-one name=\"parent\" class=\"Parent\" column=\"parent_id\" "
-"not-null=\"true\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\" inverse=\"true\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"        <many-to-one name=\"parent\" class=\"Parent\" column=\"parent_id\" "
-"not-null=\"true\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-
 #. Tag: para
-#: collection_mapping.xml:894
 #, no-c-format
 msgid "Notice the <literal>NOT NULL</literal> constraint:"
-msgstr "Observa la restricci&#x00f3;n <literal>NOT NULL</literal>:"
+msgstr "Observe la restricción <literal>NOT NULL</literal>:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:898
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null\n"
-"                     primary key,\n"
-"                     name varchar(255),\n"
-"                     parent_id bigint not null )\n"
-"alter table child add constraint childfk0 (parent_id) references parent]]>"
-msgstr ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null\n"
-"                     primary key,\n"
-"                     name varchar(255),\n"
-"                     parent_id bigint not null )\n"
-"alter table child add constraint childfk0 (parent_id) references parent]]>"
-
-#. Tag: para
-#: collection_mapping.xml:900
-#, fuzzy, no-c-format
-msgid ""
 "Alternatively, if this association must be unidirectional you can declare "
 "the <literal>NOT NULL</literal> constraint on the <literal>&lt;key&gt;</"
 "literal> mapping:"
 msgstr ""
-"Alternativamente, si absolutamente insistes que esta asociaci&#x00f3;n debe "
-"ser unidireccional, puedes declarar la restricci&#x00f3;n <literal>NOT NULL</"
-"literal> en el mapeo de <literal>&lt;key&gt;</literal>:"
+"Opcionalmente, si esta asociación debe ser unidireccional, puede declarar la "
+"restricción <literal>NOT NULL</literal> en el mapeo de <literal>&lt;key&gt;</"
+"literal>:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:906
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\">\n"
-"            <key column=\"parent_id\" not-null=\"true\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\">\n"
-"            <key column=\"parent_id\" not-null=\"true\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-
-#. Tag: para
-#: collection_mapping.xml:908
-#, fuzzy, no-c-format
-msgid ""
 "On the other hand, if a child has multiple parents, a many-to-many "
 "association is appropriate:"
 msgstr ""
-"En la otra mano, si un hijo pudiera tener m&#x00fa;ltiples padres, "
-"ser&#x00ed;a apropiada una asociaci&#x00f3;n muchos-a-muchos:"
+"Por otro lado, si un hijo tiene múltiples padres, una asociación muchos-a-"
+"muchos es apropiada:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:913
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\" table=\"childset\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <many-to-many class=\"Child\" column=\"child_id\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\" table=\"childset\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <many-to-many class=\"Child\" column=\"child_id\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-
 #. Tag: para
-#: collection_mapping.xml:915
 #, no-c-format
 msgid "Table definitions:"
 msgstr "Definiciones de tabla:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:919
-#, no-c-format
-msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null primary key, name varchar(255) )\n"
-"create table childset ( parent_id bigint not null,\n"
-"                        child_id bigint not null,\n"
-"                        primary key ( parent_id, child_id ) )\n"
-"alter table childset add constraint childsetfk0 (parent_id) references "
-"parent\n"
-"alter table childset add constraint childsetfk1 (child_id) references child]]"
-">"
-msgstr ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null primary key, name varchar(255) )\n"
-"create table childset ( parent_id bigint not null,\n"
-"                        child_id bigint not null,\n"
-"                        primary key ( parent_id, child_id ) )\n"
-"alter table childset add constraint childsetfk0 (parent_id) references "
-"parent\n"
-"alter table childset add constraint childsetfk1 (child_id) references child]]"
-">"
-
 #. Tag: para
-#: collection_mapping.xml:921
 #, fuzzy, no-c-format
 msgid ""
 "For more examples and a complete explanation of a parent/child relationship "
-"mapping, see <xref linkend=\"example-parentchild\"/> for more information."
+"mapping, see <xref linkend=\"example-parentchild\" /> for more information."
 msgstr ""
-"Para m&#x00e1;s ejemplos y un paseo completo a trav&#x00e9;s del mapeo de "
-"relaciones padre/hijo, ver <xref linkend=\"example-parentchild\"/>."
+"Para ver más ejemplos y encontrar una explicación completa sobre el mapeo de "
+"relaciones padre/hijo, consulte el <xref linkend=\"example-parentchild\" /> "
+"para obtener mayor información."
 
 #. Tag: para
-#: collection_mapping.xml:926
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Even more complex association mappings are covered in the next chapter."
 msgstr ""
-"Son posibles mapeos de asociaci&#x00f3;n a&#x00fa;n m&#x00e1;s complejos. "
-"Catalogaremos todas las posibilidades en el pr&#x00f3;ximo cap&#x00ed;tulo."
-
-#~ msgid "Collection Mapping"
-#~ msgstr "Mapeo de Colecciones"
-
-#~ msgid "Some examples, first, a set of strings:"
-#~ msgstr "Algunos ejemplos, primero, un conjunto de cadenas:"
-
-#~ msgid ""
-#~ "The previous sections are pretty confusing. So lets look at an example. "
-#~ "This class:"
-#~ msgstr ""
-#~ "Las secciones previas son bastantes confusas. As&#x00ed; que miremos un "
-#~ "ejemplo. Esta clase:"
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+"En el próximo capítulo abordaremos los mapeos de asociaciones más complejas."

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/component_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/component_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/component_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,38 +1,49 @@
-#, fuzzy
+# translation of component_mapping.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: component_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-11-06 10:15+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: component_mapping.xml:29
 #, no-c-format
 msgid "Component Mapping"
-msgstr "Mapeo de Componentes"
+msgstr "Mapeo de componentes"
 
 #. Tag: para
-#: component_mapping.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The notion of a <emphasis>component</emphasis> is re-used in several "
 "different contexts and purposes throughout Hibernate."
 msgstr ""
-"La noci&#x00f3;n de un <emphasis>componente</emphasis> es reusada en muchos "
-"contextos diferentes, para prop&#x00f3;sitos diferentes, a trav&#x00e9;s de "
-"Hibernate."
+"La noción de un <emphasis>componente</emphasis> se reutiliza en muchos "
+"contextos diferentes, para propósitos diferentes a través de Hibernate."
 
 #. Tag: title
-#: component_mapping.xml:37
 #, no-c-format
 msgid "Dependent objects"
 msgstr "Objetos dependientes"
 
 #. Tag: para
-#: component_mapping.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A component is a contained object that is persisted as a value type and not "
 "an entity reference. The term \"component\" refers to the object-oriented "
@@ -40,184 +51,41 @@
 "you can model a person like this:"
 msgstr ""
 "Un componente es un objeto contenido que es persistido como un tipo de "
-"valor, no una referencia de entidad. El t&#x00e9;rmino \"componente\" hace "
-"referencia a la noci&#x00f3;n orientada a objetos de composici&#x00f3;n (no "
-"a componentes a nivel de arquitectura). Por ejemplo, podr&#x00ed;as modelar "
-"una persona como:"
+"valor, no una referencia de entidad. El término \"componente\" hace "
+"referencia a la noción orientada a objetos de composición y no a componentes "
+"a nivel de arquitectura. Por ejemplo, puede modelar una persona así:"
 
-#. Tag: programlisting
-#: component_mapping.xml:45
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[public class Person {\n"
-"    private java.util.Date birthday;\n"
-"    private Name name;\n"
-"    private String key;\n"
-"    public String getKey() {\n"
-"        return key;\n"
-"    }\n"
-"    private void setKey(String key) {\n"
-"        this.key=key;\n"
-"    }\n"
-"    public java.util.Date getBirthday() {\n"
-"        return birthday;\n"
-"    }\n"
-"    public void setBirthday(java.util.Date birthday) {\n"
-"        this.birthday = birthday;\n"
-"    }\n"
-"    public Name getName() {\n"
-"        return name;\n"
-"    }\n"
-"    public void setName(Name name) {\n"
-"        this.name = name;\n"
-"    }\n"
-"    ......\n"
-"    ......\n"
-"}]]>"
-msgstr ""
-"<![CDATA[public class Person {\n"
-"    private java.util.Date birthday;\n"
-"    private Name name;\n"
-"    private String key;\n"
-"    public String getKey() {\n"
-"        return key;\n"
-"    }\n"
-"    private void setKey(String key) {\n"
-"        this.key=key;\n"
-"    }\n"
-"    public java.util.Date getBirthday() {\n"
-"        return birthday;\n"
-"    }\n"
-"    public void setBirthday(java.util.Date birthday) {\n"
-"        this.birthday = birthday;\n"
-"    }\n"
-"    public Name getName() {\n"
-"        return name;\n"
-"    }\n"
-"    public void setName(Name name) {\n"
-"        this.name = name;\n"
-"    }\n"
-"    ......\n"
-"    ......\n"
-"}]]>"
-
-#. Tag: programlisting
-#: component_mapping.xml:47
-#, no-c-format
-msgid ""
-"<![CDATA[public class Name {\n"
-"    char initial;\n"
-"    String first;\n"
-"    String last;\n"
-"    public String getFirst() {\n"
-"        return first;\n"
-"    }\n"
-"    void setFirst(String first) {\n"
-"        this.first = first;\n"
-"    }\n"
-"    public String getLast() {\n"
-"        return last;\n"
-"    }\n"
-"    void setLast(String last) {\n"
-"        this.last = last;\n"
-"    }\n"
-"    public char getInitial() {\n"
-"        return initial;\n"
-"    }\n"
-"    void setInitial(char initial) {\n"
-"        this.initial = initial;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-"<![CDATA[public class Name {\n"
-"    char initial;\n"
-"    String first;\n"
-"    String last;\n"
-"    public String getFirst() {\n"
-"        return first;\n"
-"    }\n"
-"    void setFirst(String first) {\n"
-"        this.first = first;\n"
-"    }\n"
-"    public String getLast() {\n"
-"        return last;\n"
-"    }\n"
-"    void setLast(String last) {\n"
-"        this.last = last;\n"
-"    }\n"
-"    public char getInitial() {\n"
-"        return initial;\n"
-"    }\n"
-"    void setInitial(char initial) {\n"
-"        this.initial = initial;\n"
-"    }\n"
-"}]]>"
-
-#. Tag: para
-#: component_mapping.xml:49
-#, fuzzy, no-c-format
-msgid ""
 "Now <literal>Name</literal> can be persisted as a component of "
 "<literal>Person</literal>. <literal>Name</literal> defines getter and setter "
 "methods for its persistent properties, but it does not need to declare any "
 "interfaces or identifier properties."
 msgstr ""
 "Ahora <literal>Name</literal> puede ser persistido como un componente de "
-"<literal>Person</literal>. Observa que <literal>Name</literal> define "
-"m&#x00e9;todos getter y setter para sus propiedades persistentes, pero no "
-"necesita declarar ninguna interface ni propiedades identificadoras."
+"<literal>Person</literal>. <literal>Name</literal> define métodos getter y "
+"setter para sus propiedades persistentes, pero no necesita declarar ninguna "
+"interfaz ni propiedades identificadoras."
 
 #. Tag: para
-#: component_mapping.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Our Hibernate mapping would look like this:"
-msgstr "Nuestro mapeo de Hibernate se ver&#x00ed;a as&#x00ed;:"
+msgstr "Nuestro mapeo de Hibernate se vería así: "
 
-#. Tag: programlisting
-#: component_mapping.xml:60
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-"    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    <property name=\"birthday\" type=\"date\"/>\n"
-"    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
-"optional -->\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </component>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-"    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-"        <generator class=\"uuid.hex\"/>\n"
-"    </id>\n"
-"    <property name=\"birthday\" type=\"date\"/>\n"
-"    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
-"optional -->\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </component>\n"
-"</class>]]>"
-
 #. Tag: para
-#: component_mapping.xml:62
 #, no-c-format
 msgid ""
 "The person table would have the columns <literal>pid</literal>, "
 "<literal>birthday</literal>, <literal>initial</literal>, <literal>first</"
 "literal> and <literal>last</literal>."
 msgstr ""
-"La tabla person tendr&#x00ed;a las columnas <literal>pid</literal>, "
+"La tabla person tendría las columnas <literal>pid</literal>, "
 "<literal>birthday</literal>, <literal>initial</literal>, <literal>first</"
 "literal> y <literal>last</literal>."
 
 #. Tag: para
-#: component_mapping.xml:70
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Like value types, components do not support shared references. In other "
 "words, two persons could have the same name, but the two person objects "
@@ -229,30 +97,27 @@
 msgstr ""
 "Como todos los tipos de valor, los componentes no soportan referencias "
 "compartidas. En otras palabras, dos personas pueden tener el mismo nombre, "
-"pero los dos objetos persona contendr&#x00ed;an dos objetos nombre "
-"independientes, s&#x00f3;lo \"iguales\" en valor. La sem&#x00e1;ntica de "
-"valor nulo de un componente es <emphasis>ad hoc</emphasis>. Cuando se "
-"recargue el objeto contenedor, Hibernate asumir&#x00e1; que si todas las "
-"columnas del componente son nulas, el componente entero es nulo. Esto debe "
-"estar bien para la mayor&#x00ed;a de prop&#x00f3;sitos."
+"pero los dos objetos persona contendrían dos objetos nombre independientes, "
+"sólamente \"iguales\" en valor. La semántica de valor nulo de un componente "
+"es <emphasis>ad hoc</emphasis>. Cuando se recargue el objeto contenedor, "
+"Hibernate asumirá que si todas las columnas del componente son nulas, el "
+"componente entero es nulo. Esto es apropiado para la mayoría de propósitos."
 
 #. Tag: para
-#: component_mapping.xml:78
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The properties of a component can be of any Hibernate type (collections, "
 "many-to-one associations, other components, etc). Nested components should "
 "<emphasis>not</emphasis> be considered an exotic usage. Hibernate is "
 "intended to support a fine-grained object model."
 msgstr ""
-"Las propiedades de un componentes pueden ser de cualquier tipo de Hibernate "
-"(colecciones, muchos-a-uno, asociaciones, otros componentes, etc). Los "
-"componentes anidados <emphasis>no</emphasis> deben ser considerados un uso "
-"ex&#x00f3;tico. Hibernate est&#x00e1; concebido para soportar un modelo de "
-"objetos granularizado en fino."
+"Las propiedades de un componente pueden ser de cualquier tipo de Hibernate "
+"(colecciones, asociaciones muchos-a-uno, otros componentes, etc). Los "
+"componentes anidados <emphasis>no</emphasis> deben ser considerados como un "
+"uso exótico. Hibernate está concebido para soportar un modelo de objetos muy "
+"detallado."
 
 #. Tag: para
-#: component_mapping.xml:85
 #, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element allows a <literal>&lt;"
@@ -260,98 +125,40 @@
 "as a reference back to the containing entity."
 msgstr ""
 "El elemento <literal>&lt;component&gt;</literal> permite un subelemento "
-"<literal>&lt;parent&gt;</literal> que mapee una propiedad de la clase del "
-"componente como una referencia de regreso a la entidad contenedora."
+"<literal>&lt;parent&gt;</literal> que mapea una propiedad de la clase del "
+"componente como una referencia a la entidad contenedora."
 
-#. Tag: programlisting
-#: component_mapping.xml:91
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-"    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    <property name=\"birthday\" type=\"date\"/>\n"
-"    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
-"        <parent name=\"namedPerson\"/> <!-- reference back to the Person --"
-">\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </component>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-"    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-"        <generator class=\"uuid.hex\"/>\n"
-"    </id>\n"
-"    <property name=\"birthday\" type=\"date\"/>\n"
-"    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
-"        <parent name=\"namedPerson\"/> <!-- reference back to the Person --"
-">\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </component>\n"
-"</class>]]>"
-
 #. Tag: title
-#: component_mapping.xml:96
 #, no-c-format
 msgid "Collections of dependent objects"
 msgstr "Colecciones de objetos dependientes"
 
 #. Tag: para
-#: component_mapping.xml:98
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collections of components are supported (e.g. an array of type "
 "<literal>Name</literal>). Declare your component collection by replacing the "
 "<literal>&lt;element&gt;</literal> tag with a <literal>&lt;composite-"
 "element&gt;</literal> tag:"
 msgstr ""
-"Las colecciones de componentes est&#x00e1;n soportadas (por ejemplo, un "
-"array de tipo <literal>Name</literal>). Declara tu colecci&#x00f3;n de "
-"componentes remplazando la etiqueta <literal>&lt;element&gt;</literal> por "
-"una etiqueta <literal>&lt;composite-element&gt;</literal>."
+"Las colecciones de componentes se encuentran soportadas (por ejemplo, un "
+"array de tipo <literal>Name</literal>). Declare su colección de componentes "
+"remplazando la etiqueta <literal>&lt;element&gt;</literal> por una etiqueta "
+"<literal>&lt;composite-element&gt;</literal>:"
 
-#. Tag: programlisting
-#: component_mapping.xml:105
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
-"    <key column=\"id\"/>\n"
-"    <composite-element class=\"eg.Name\"> <!-- class attribute required -->\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </composite-element>\n"
-"</set>]]>"
-msgstr ""
-"<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
-"    <key column=\"id\"/>\n"
-"    <composite-element class=\"eg.Name\"> <!-- class attribute required -->\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </composite-element>\n"
-"</set>]]>"
-
-#. Tag: para
-#: component_mapping.xml:108
-#, fuzzy, no-c-format
-msgid ""
 "If you define a <literal>Set</literal> of composite elements, it is "
 "important to implement <literal>equals()</literal> and <literal>hashCode()</"
 "literal> correctly."
 msgstr ""
-"Nota: si defines un <literal>Set</literal> de elementos compuestos, es muy "
+"Si define un <literal>Set</literal> de elementos compuestos, es muy "
 "importante implementar <literal>equals()</literal> y <literal>hashCode()</"
-"literal> correctamente."
+"literal> de manera correcta."
 
 #. Tag: para
-#: component_mapping.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Composite elements can contain components but not collections. If your "
 "composite element contains components, use the <literal>&lt;nested-composite-"
@@ -362,18 +169,16 @@
 "model and persistence semantics are still slightly different."
 msgstr ""
 "Los elementos compuestos pueden contener componentes pero no colecciones. Si "
-"tu elemento compuesto contiene a su vez componentes, usa la etiqueta "
-"<literal>&lt;nested-composite-element&gt;</literal>. Este es un caso "
-"bastante ex&#x00f3;tico - una colecci&#x00f3;n de componentes que a su vez "
-"tienen componentes. A esta altura debes estar pregunt&#x00e1;ndote si una "
-"asociaci&#x00f3;n uno-a-muchos es m&#x00e1;s apropiada. Intenta remodelar el "
-"elemento compuesto como una entidad - pero observa que aunque el modelo Java "
-"es el mismo, el modelo relacional y la sem&#x00e1;ntica de persistencia "
-"siguen siendo ligeramente diferentes."
+"su elemento compuesto contiene a su vez componentes, use la etiqueta "
+"<literal>&lt;nested-composite-element&gt;</literal>. Este es un caso de una "
+"colección de componentes que a su vez tienen componentes. Se debe estar "
+"preguntando si una asociación uno-a-muchos es más apropiada. Remodele el "
+"elemento compuesto como una entidad - pero observe que aunque el modelo Java "
+"es el mismo, el modelo relacional y la semántica de persistencia siguen "
+"siendo ligeramente diferentes."
 
 #. Tag: para
-#: component_mapping.xml:127
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A composite element mapping does not support null-able properties if you are "
 "using a <literal>&lt;set&gt;</literal>. There is no separate primary key "
@@ -383,18 +188,17 @@
 "element or choose a <literal>&lt;list&gt;</literal>, <literal>&lt;map&gt;</"
 "literal>, <literal>&lt;bag&gt;</literal> or <literal>&lt;idbag&gt;</literal>."
 msgstr ""
-"Por favor observa que un mapeo de elemento compuesto no soporta propiedades "
-"nulables si est&#x00e1;s usando un <literal>&lt;set&gt;</literal>. Hibernate "
-"tiene que usar cada columna para identificar un registro al borrar objetos "
-"(no hay una columna clave primaria separada en la tabla del elemento "
-"compuesto), lo que es imposible con valores nulos. Tienes que, o bien usar "
-"s&#x00f3;lo propiedades no nulas en un elemento compuesto o elegir un "
-"<literal>&lt;list&gt;</literal>, <literal>&lt;map&gt;</literal>, "
-"<literal>&lt;bag&gt;</literal> o <literal>&lt;idbag&gt;</literal>."
+"Un mapeo de elemento compuesto no soporta propiedades nulables si está "
+"utilizando un <literal>&lt;set&gt;</literal>. No hay una columna clave "
+"principal separada en la tabla del elemento compuesto. Hibernate utiliza el "
+"valor de cada columna para identificar un registro al borrar objetos, lo "
+"cual es imposible con valores nulos. Tiene que usar sólo propiedades no "
+"nulas en un elemento compuesto o elegir un <literal>&lt;list&gt;</literal>, "
+"<literal>&lt;map&gt;</literal>, <literal>&lt;bag&gt;</literal> o "
+"<literal>&lt;idbag&gt;</literal>."
 
 #. Tag: para
-#: component_mapping.xml:138
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A special case of a composite element is a composite element with a nested "
 "<literal>&lt;many-to-one&gt;</literal> element. This mapping allows you to "
@@ -405,188 +209,115 @@
 "<literal>quantity</literal> are properties of the association:"
 msgstr ""
 "Un caso especial de un elemento compuesto es un elemento compuesto con un "
-"elemento anidado <literal>&lt;many-to-one&gt;</literal>. Un mapeo como este "
-"te permite mapear columnas extra de una tabla de asociaci&#x00f3;n muchos-a-"
-"muchos a la clase del elemento compuesto. La siguiente es una "
-"asociaci&#x00f3;n muchos-a-muchos de <literal>Order</literal> a "
-"<literal>Item</literal> donde <literal>purchaseDate</literal>, "
-"<literal>price</literal> y <literal>quantity</literal> son propiedades de la "
-"asociaci&#x00f3;n:"
+"elemento anidado <literal>&lt;many-to-one&gt;</literal>. Este mapeo le "
+"permite mapear columnas extra de una tabla de asociación muchos-a-muchos a "
+"la clase del elemento compuesto. La siguiente es una asociación muchos-a-"
+"muchos de <literal>Order</literal> a <literal>Item</literal>, donde "
+"<literal>purchaseDate</literal>, <literal>price</literal> y "
+"<literal>quantity</literal> son propiedades de la asociación:"
 
-#. Tag: programlisting
-#: component_mapping.xml:148
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"eg.Order\" .... >\n"
-"    ....\n"
-"    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-"        <key column=\"order_id\">\n"
-"        <composite-element class=\"eg.Purchase\">\n"
-"            <property name=\"purchaseDate\"/>\n"
-"            <property name=\"price\"/>\n"
-"            <property name=\"quantity\"/>\n"
-"            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class "
-"attribute is optional -->\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"eg.Order\" .... >\n"
-"    ....\n"
-"    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-"        <key column=\"order_id\">\n"
-"        <composite-element class=\"eg.Purchase\">\n"
-"            <property name=\"purchaseDate\"/>\n"
-"            <property name=\"price\"/>\n"
-"            <property name=\"quantity\"/>\n"
-"            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class "
-"attribute is optional -->\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-
-#. Tag: para
-#: component_mapping.xml:150
-#, fuzzy, no-c-format
-msgid ""
 "There cannot be a reference to the purchase on the other side for "
 "bidirectional association navigation. Components are value types and do not "
 "allow shared references. A single <literal>Purchase</literal> can be in the "
 "set of an <literal>Order</literal>, but it cannot be referenced by the "
 "<literal>Item</literal> at the same time."
 msgstr ""
-"Por supuesto, no puede haber una referencia a la compra del otro lado para "
-"la navegaci&#x00f3;n bidireccional de la asociaci&#x00f3;n. Recuerda que los "
-"componentes son tipos de valor no permiten referencias compartidas. Una sola "
-"<literal>Purchase</literal> puede estar en el conjunto de una "
-"<literal>Order</literal>, pero no puede ser referenciada por el "
-"<literal>Item</literal> al mismo tiempo."
+"No puede haber una referencia a la compra del otro lado para la navegación "
+"bidireccional de la asociación. Los componentes son tipos de valor y no "
+"permiten referencias compartidas. Una sola <literal>Purchase</literal> puede "
+"estar en el conjunto de una <literal>Order</literal>, pero no puede ser "
+"referenciada por el <literal>Item</literal> al mismo tiempo."
 
 #. Tag: para
-#: component_mapping.xml:158
 #, no-c-format
 msgid "Even ternary (or quaternary, etc) associations are possible:"
 msgstr "Incluso son posibles las asociaciones ternarias (o cuaternarias, etc):"
 
-#. Tag: programlisting
-#: component_mapping.xml:160
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"eg.Order\" .... >\n"
-"    ....\n"
-"    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-"        <key column=\"order_id\">\n"
-"        <composite-element class=\"eg.OrderLine\">\n"
-"            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
-"            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"eg.Order\" .... >\n"
-"    ....\n"
-"    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-"        <key column=\"order_id\">\n"
-"        <composite-element class=\"eg.OrderLine\">\n"
-"            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
-"            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-
-#. Tag: para
-#: component_mapping.xml:162
-#, fuzzy, no-c-format
-msgid ""
 "Composite elements can appear in queries using the same syntax as "
 "associations to other entities."
 msgstr ""
 "Los elementos compuestos pueden aparecer en consultas usando la misma "
-"sint&#x00e1;xis que las asociaciones a otras entidades."
+"sintáxis que las asociaciones a otras entidades. "
 
 #. Tag: title
-#: component_mapping.xml:170
 #, no-c-format
 msgid "Components as Map indices"
-msgstr "Componentes como &#x00ed;ndices de Map"
+msgstr "Componentes como índices de Mapeo"
 
 #. Tag: para
-#: component_mapping.xml:172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;composite-map-key&gt;</literal> element allows you to map a "
 "component class as the key of a <literal>Map</literal>. Ensure that you "
 "override <literal>hashCode()</literal> and <literal>equals()</literal> "
 "correctly on the component class."
 msgstr ""
-"El elemento <literal>&lt;composite-map-key&gt;</literal> te permite mapear "
-"una clase componente como la clave de un <literal>Map</literal>. Aseg&#x00fa;"
-"rate que sobrescribes <literal>hashCode()</literal> y <literal>equals()</"
-"literal> correctamente en la clase componente."
+"El elemento <literal>&lt;composite-map-key&gt;</literal> le permite mapear "
+"una clase componente como la clave de un <literal>Map</literal>. Asegúrese "
+"de sobrescribir <literal>hashCode()</literal> y <literal>equals()</literal> "
+"correctamente en la clase componente. "
 
 #. Tag: title
-#: component_mapping.xml:181
 #, no-c-format
 msgid "Components as composite identifiers"
 msgstr "Componentes como identificadores compuestos"
 
 #. Tag: para
-#: component_mapping.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can use a component as an identifier of an entity class. Your component "
 "class must satisfy certain requirements:"
 msgstr ""
-"Puedes usar un componente como un identidicador de una clase entidad. Tu "
-"clase componente debe satisfacer ciertos requerimientos:"
+"Puede utilizar un componente como un identidicador de una clase entidad. Su "
+"clase componente tiene que satisfacer ciertos requerimientos: "
 
 #. Tag: para
-#: component_mapping.xml:190
 #, no-c-format
 msgid "It must implement <literal>java.io.Serializable</literal>."
-msgstr "Debe implementar <literal>java.io.Serializable</literal>."
+msgstr "Tiene que implementar <literal>java.io.Serializable</literal>."
 
 #. Tag: para
-#: component_mapping.xml:195
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It must re-implement <literal>equals()</literal> and <literal>hashCode()</"
 "literal> consistently with the database's notion of composite key equality."
 msgstr ""
-"Debe re-implementar <literal>equals()</literal> y <literal>hashCode()</"
-"literal>, consistentemente con la noci&#x00f3;n de base de datos de igualdad "
-"de clave compuesta."
+"Tiene que re-implementar <literal>equals()</literal> y <literal>hashCode()</"
+"literal>, consistentemente con la noción de la base de datos de igualdad de "
+"clave compuesta."
 
 #. Tag: title
-#: component_mapping.xml:204
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Nota"
 
 #. Tag: para
-#: component_mapping.xml:205
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In Hibernate3, although the second requirement is not an absolutely hard "
 "requirement of Hibernate, it is recommended."
 msgstr ""
-"Nota: en Hibernat3, el segundo requerimiento no es absolutamente un "
-"requerimiento r&#x00ed;gido de Hibernate. Pero de todas formas, h&#x00e1;zlo."
+"En Hibernate3, aunque el segundo requerimiento no es un requerimiento "
+"absolutamente rígido de Hibernate, en todo caso se recomienda."
 
 #. Tag: para
-#: component_mapping.xml:211
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You cannot use an <literal>IdentifierGenerator</literal> to generate "
 "composite keys. Instead the application must assign its own identifiers."
 msgstr ""
-"No puedes usar un <literal>IdentifierGenerator</literal> para generar claves "
-"compuestas. La aplicaci&#x00f3;n debe, en cambio, asignar sus propios "
-"identificadores."
+"No puede utilizar un <literal>IdentifierGenerator</literal> para generar "
+"claves compuestas. En cambio, la aplicación debe asignar sus propios "
+"identificadores. "
 
 #. Tag: para
-#: component_mapping.xml:216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use the <literal>&lt;composite-id&gt;</literal> tag, with nested "
 "<literal>&lt;key-property&gt;</literal> elements, in place of the usual "
@@ -594,244 +325,80 @@
 "<literal>OrderLine</literal> class has a primary key that depends upon the "
 "(composite) primary key of <literal>Order</literal>."
 msgstr ""
-"Usa la etiqueta <literal>&lt;composite-id&gt;</literal> (con elementos "
-"anidados <literal>&lt;key-property&gt;</literal>) en lugar de la usual "
-"declaraci&#x00f3;n <literal>&lt;id&gt;</literal>. Por ejemplo, la clase "
-"<literal>OrderLine</literal> tiene una clave primaria que depende de la "
-"clave primaria (compuesta) de <literal>Order</literal>."
+"Use la etiqueta <literal>&lt;composite-id&gt;</literal>, con elementos "
+"anidados <literal>&lt;key-property&gt;</literal>, en lugar de la declaración "
+"usual <literal>&lt;id&gt;</literal>. Por ejemplo, la clase "
+"<literal>OrderLine</literal> tiene una clave principal que depende de la "
+"clave principal (compuesta) de <literal>Order</literal>."
 
-#. Tag: programlisting
-#: component_mapping.xml:224
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"OrderLine\">\n"
-"    \n"
-"    <composite-id name=\"id\" class=\"OrderLineId\">\n"
-"        <key-property name=\"lineId\"/>\n"
-"        <key-property name=\"orderId\"/>\n"
-"        <key-property name=\"customerId\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"name\"/>\n"
-"    \n"
-"    <many-to-one name=\"order\" class=\"Order\"\n"
-"            insert=\"false\" update=\"false\">\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </many-to-one>\n"
-"    ....\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"OrderLine\">\n"
-"    \n"
-"    <composite-id name=\"id\" class=\"OrderLineId\">\n"
-"        <key-property name=\"lineId\"/>\n"
-"        <key-property name=\"orderId\"/>\n"
-"        <key-property name=\"customerId\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"name\"/>\n"
-"    \n"
-"    <many-to-one name=\"order\" class=\"Order\"\n"
-"            insert=\"false\" update=\"false\">\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </many-to-one>\n"
-"    ....\n"
-"    \n"
-"</class>]]>"
-
-#. Tag: para
-#: component_mapping.xml:226
-#, fuzzy, no-c-format
-msgid ""
 "Any foreign keys referencing the <literal>OrderLine</literal> table are now "
 "composite. Declare this in your mappings for other classes. An association "
 "to <literal>OrderLine</literal> is mapped like this:"
 msgstr ""
-"Ahora, cualquier clave for&#x00e1;nea que referencie la tabla de "
-"<literal>OrderLine</literal> es tambi&#x00e9;n compuesta. Debes declarar "
-"esto en tus mapeos de otras clases. Una asociaci&#x00f3;n a "
-"<literal>OrderLine</literal> ser&#x00ed;a mapeado as&#x00ed;:"
+"Cualquier clave foránea que referencie la tabla de <literal>OrderLine</"
+"literal> también es compuesta. Declare esto en sus mapeos de otras clases. "
+"Una asociación a <literal>OrderLine</literal> se mapea así:"
 
-#. Tag: programlisting
-#: component_mapping.xml:232
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
-"<!-- the \"class\" attribute is optional, as usual -->\n"
-"    <column name=\"lineId\"/>\n"
-"    <column name=\"orderId\"/>\n"
-"    <column name=\"customerId\"/>\n"
-"</many-to-one>]]>"
-msgstr ""
-"<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
-"<!-- the \"class\" attribute is optional, as usual -->\n"
-"    <column name=\"lineId\"/>\n"
-"    <column name=\"orderId\"/>\n"
-"    <column name=\"customerId\"/>\n"
-"</many-to-one>]]>"
-
 #. Tag: para
-#: component_mapping.xml:235
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The <literal>column</literal> element is an alternative to the "
 "<literal>column</literal> attribute everywhere. Using the <literal>column</"
 "literal> element just gives more declaration options, which are mostly "
 "useful when utilizing <literal>hbm2ddl</literal>"
 msgstr ""
+"La etiqueta <literal>&lt;column&gt;</literal> es una alternativa al atributo "
+"<literal>column</literal> en cualquier sitio."
 
 #. Tag: para
-#: component_mapping.xml:244
 #, no-c-format
 msgid ""
 "A <literal>many-to-many</literal> association to <literal>OrderLine</"
 "literal> also uses the composite foreign key:"
 msgstr ""
-"Una asociaci&#x00f3;n <literal>muchos-a-muchos</literal> a "
-"<literal>OrderLine</literal> tambi&#x00e9;n usa la clave for&#x00e1;nea "
-"compuesta:"
+"Una asociación <literal>muchos-a-muchos</literal> a <literal>OrderLine</"
+"literal> también usa la clave foránea compuesta:"
 
-#. Tag: programlisting
-#: component_mapping.xml:249
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"undeliveredOrderLines\">\n"
-"    <key column name=\"warehouseId\"/>\n"
-"    <many-to-many class=\"OrderLine\">\n"
-"        <column name=\"lineId\"/>\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </many-to-many>\n"
-"</set>]]>"
-msgstr ""
-"<![CDATA[<set name=\"undeliveredOrderLines\">\n"
-"    <key column name=\"warehouseId\"/>\n"
-"    <many-to-many class=\"OrderLine\">\n"
-"        <column name=\"lineId\"/>\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </many-to-many>\n"
-"</set>]]>"
-
 #. Tag: para
-#: component_mapping.xml:251
 #, no-c-format
 msgid ""
 "The collection of <literal>OrderLine</literal>s in <literal>Order</literal> "
 "would use:"
 msgstr ""
-"La colecci&#x00f3;n de <literal>OrderLine</literal>s en <literal>Order</"
-"literal> usar&#x00ed;a:"
+"La colección de <literal>OrderLine</literal>s en <literal>Order</literal> "
+"utilizaría: "
 
-#. Tag: programlisting
-#: component_mapping.xml:256
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
-"    <key>\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </key>\n"
-"    <one-to-many class=\"OrderLine\"/>\n"
-"</set>]]>"
-msgstr ""
-"<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
-"    <key>\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </key>\n"
-"    <one-to-many class=\"OrderLine\"/>\n"
-"</set>]]>"
-
 #. Tag: para
-#: component_mapping.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The <literal>&lt;one-to-many&gt;</literal> element declares no columns."
 msgstr ""
-"(El elemento <literal>&lt;one-to-many&gt;</literal>, como es usual, no "
-"declara columnas.)"
+"El elemento <literal>&lt;one-to-many&gt;</literal> declara ninguna columna."
 
 #. Tag: para
-#: component_mapping.xml:262
 #, no-c-format
 msgid ""
 "If <literal>OrderLine</literal> itself owns a collection, it also has a "
 "composite foreign key."
 msgstr ""
-"Si <literal>OrderLine</literal> posee una colecci&#x00f3;n por s&#x00ed; "
-"misma, tiene tambi&#x00e9;n una clave for&#x00e1;nea compuesta."
+"Si <literal>OrderLine</literal> posee una colección por sí misma, tiene "
+"también una clave foránea compuesta."
 
-#. Tag: programlisting
-#: component_mapping.xml:267
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"OrderLine\">\n"
-"    ....\n"
-"    ....\n"
-"    <list name=\"deliveryAttempts\">\n"
-"        <key>   <!-- a collection inherits the composite key type -->\n"
-"            <column name=\"lineId\"/>\n"
-"            <column name=\"orderId\"/>\n"
-"            <column name=\"customerId\"/>\n"
-"        </key>\n"
-"        <list-index column=\"attemptId\" base=\"1\"/>\n"
-"        <composite-element class=\"DeliveryAttempt\">\n"
-"            ...\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"OrderLine\">\n"
-"    ....\n"
-"    ....\n"
-"    <list name=\"deliveryAttempts\">\n"
-"        <key>   <!-- a collection inherits the composite key type -->\n"
-"            <column name=\"lineId\"/>\n"
-"            <column name=\"orderId\"/>\n"
-"            <column name=\"customerId\"/>\n"
-"        </key>\n"
-"        <list-index column=\"attemptId\" base=\"1\"/>\n"
-"        <composite-element class=\"DeliveryAttempt\">\n"
-"            ...\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-
 #. Tag: title
-#: component_mapping.xml:272
 #, no-c-format
 msgid "Dynamic components"
-msgstr "Componentes din&#x00e1;micos"
+msgstr "Componentes dinámicos"
 
 #. Tag: para
-#: component_mapping.xml:274
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can also map a property of type <literal>Map</literal>:"
-msgstr "Puedes incluso mapear una propiedad de tipo <literal>Map</literal>:"
+msgstr "También puede mapear una propiedad del tipo <literal>Map</literal>:"
 
-#. Tag: programlisting
-#: component_mapping.xml:278
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<dynamic-component name=\"userAttributes\">\n"
-"    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
-"    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
-"    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
-"</dynamic-component>]]>"
-msgstr ""
-"<![CDATA[<dynamic-component name=\"userAttributes\">\n"
-"    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
-"    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
-"    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
-"</dynamic-component>]]>"
-
-#. Tag: para
-#: component_mapping.xml:280
-#, fuzzy, no-c-format
-msgid ""
 "The semantics of a <literal>&lt;dynamic-component&gt;</literal> mapping are "
 "identical to <literal>&lt;component&gt;</literal>. The advantage of this "
 "kind of mapping is the ability to determine the actual properties of the "
@@ -840,25 +407,378 @@
 "You can also access, and change, Hibernate's configuration-time metamodel "
 "via the <literal>Configuration</literal> object."
 msgstr ""
-"La sem&#x00e1;ntica de un mapeo <literal>&lt;dynamic-component&gt;</literal> "
-"es &#x00ed;dentica a la de <literal>&lt;component&gt;</literal>. La ventaja "
-"de este tipo de mapeos es la habilidad para determinar las propiedades "
-"reales del bean en tiempo de despliegue, s&#x00f3;lo con editar el documento "
-"de mapeo. La manipulaci&#x00f3;n del documento de mapeo en tiempo de "
-"ejecuci&#x00f3;n es tambi&#x00e9;n posible, usando un analizador DOM. "
-"Incluso mejor, puedes acceder (y cambiar) el metamodelo de tiempo de "
-"configuraci&#x00f3;n de Hibernate por medio del objeto "
+"La semántica de un mapeo <literal>&lt;dynamic-component&gt;</literal> es "
+"ídentica a la de <literal>&lt;component&gt;</literal>. La ventaja de este "
+"tipo de mapeos es la habilidad para determinar las propiedades reales del "
+"bean en tiempo de despliegue, sólo con editar el documento de mapeo. La "
+"manipulación del documento de mapeo en tiempo de ejecución también es "
+"posible, usando un analizador DOM. También puede acceder y cambiar el "
+"metamodelo de tiempo de configuración de Hibernate por medio del objeto "
 "<literal>Configuration</literal>."
 
 #~ msgid ""
-#~ "(Note that the <literal>&lt;column&gt;</literal> tag is an alternative to "
-#~ "the <literal>column</literal> attribute everywhere.)"
+#~ "<![CDATA[public class Person {\n"
+#~ "    private java.util.Date birthday;\n"
+#~ "    private Name name;\n"
+#~ "    private String key;\n"
+#~ "    public String getKey() {\n"
+#~ "        return key;\n"
+#~ "    }\n"
+#~ "    private void setKey(String key) {\n"
+#~ "        this.key=key;\n"
+#~ "    }\n"
+#~ "    public java.util.Date getBirthday() {\n"
+#~ "        return birthday;\n"
+#~ "    }\n"
+#~ "    public void setBirthday(java.util.Date birthday) {\n"
+#~ "        this.birthday = birthday;\n"
+#~ "    }\n"
+#~ "    public Name getName() {\n"
+#~ "        return name;\n"
+#~ "    }\n"
+#~ "    public void setName(Name name) {\n"
+#~ "        this.name = name;\n"
+#~ "    }\n"
+#~ "    ......\n"
+#~ "    ......\n"
+#~ "}]]>"
 #~ msgstr ""
-#~ "(Nota que la etiqueta <literal>&lt;column&gt;</literal> es una "
-#~ "alternativa al atributo <literal>column</literal> en cualquier sitio.)"
+#~ "<![CDATA[public class Person {\n"
+#~ "    private java.util.Date birthday;\n"
+#~ "    private Name name;\n"
+#~ "    private String key;\n"
+#~ "    public String getKey() {\n"
+#~ "        return key;\n"
+#~ "    }\n"
+#~ "    private void setKey(String key) {\n"
+#~ "        this.key=key;\n"
+#~ "    }\n"
+#~ "    public java.util.Date getBirthday() {\n"
+#~ "        return birthday;\n"
+#~ "    }\n"
+#~ "    public void setBirthday(java.util.Date birthday) {\n"
+#~ "        this.birthday = birthday;\n"
+#~ "    }\n"
+#~ "    public Name getName() {\n"
+#~ "        return name;\n"
+#~ "    }\n"
+#~ "    public void setName(Name name) {\n"
+#~ "        this.name = name;\n"
+#~ "    }\n"
+#~ "    ......\n"
+#~ "    ......\n"
+#~ "}]]>"
 
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
+#~ msgid ""
+#~ "<![CDATA[public class Name {\n"
+#~ "    char initial;\n"
+#~ "    String first;\n"
+#~ "    String last;\n"
+#~ "    public String getFirst() {\n"
+#~ "        return first;\n"
+#~ "    }\n"
+#~ "    void setFirst(String first) {\n"
+#~ "        this.first = first;\n"
+#~ "    }\n"
+#~ "    public String getLast() {\n"
+#~ "        return last;\n"
+#~ "    }\n"
+#~ "    void setLast(String last) {\n"
+#~ "        this.last = last;\n"
+#~ "    }\n"
+#~ "    public char getInitial() {\n"
+#~ "        return initial;\n"
+#~ "    }\n"
+#~ "    void setInitial(char initial) {\n"
+#~ "        this.initial = initial;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[public class Name {\n"
+#~ "    char initial;\n"
+#~ "    String first;\n"
+#~ "    String last;\n"
+#~ "    public String getFirst() {\n"
+#~ "        return first;\n"
+#~ "    }\n"
+#~ "    void setFirst(String first) {\n"
+#~ "        this.first = first;\n"
+#~ "    }\n"
+#~ "    public String getLast() {\n"
+#~ "        return last;\n"
+#~ "    }\n"
+#~ "    void setLast(String last) {\n"
+#~ "        this.last = last;\n"
+#~ "    }\n"
+#~ "    public char getInitial() {\n"
+#~ "        return initial;\n"
+#~ "    }\n"
+#~ "    void setInitial(char initial) {\n"
+#~ "        this.initial = initial;\n"
+#~ "    }\n"
+#~ "}]]>"
 
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
+#~ "optional -->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
+#~ "optional -->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
+#~ "        <parent name=\"namedPerson\"/> <!-- reference back to the Person "
+#~ "-->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
+#~ "        <parent name=\"namedPerson\"/> <!-- reference back to the Person "
+#~ "-->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
+#~ "    <key column=\"id\"/>\n"
+#~ "    <composite-element class=\"eg.Name\"> <!-- class attribute required --"
+#~ ">\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </composite-element>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
+#~ "    <key column=\"id\"/>\n"
+#~ "    <composite-element class=\"eg.Name\"> <!-- class attribute required --"
+#~ ">\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </composite-element>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.Purchase\">\n"
+#~ "            <property name=\"purchaseDate\"/>\n"
+#~ "            <property name=\"price\"/>\n"
+#~ "            <property name=\"quantity\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class "
+#~ "attribute is optional -->\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.Purchase\">\n"
+#~ "            <property name=\"purchaseDate\"/>\n"
+#~ "            <property name=\"price\"/>\n"
+#~ "            <property name=\"quantity\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class "
+#~ "attribute is optional -->\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.OrderLine\">\n"
+#~ "            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.OrderLine\">\n"
+#~ "            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" class=\"OrderLineId\">\n"
+#~ "        <key-property name=\"lineId\"/>\n"
+#~ "        <key-property name=\"orderId\"/>\n"
+#~ "        <key-property name=\"customerId\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\" class=\"Order\"\n"
+#~ "            insert=\"false\" update=\"false\">\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    ....\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" class=\"OrderLineId\">\n"
+#~ "        <key-property name=\"lineId\"/>\n"
+#~ "        <key-property name=\"orderId\"/>\n"
+#~ "        <key-property name=\"customerId\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\" class=\"Order\"\n"
+#~ "            insert=\"false\" update=\"false\">\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    ....\n"
+#~ "    \n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
+#~ "<!-- the \"class\" attribute is optional, as usual -->\n"
+#~ "    <column name=\"lineId\"/>\n"
+#~ "    <column name=\"orderId\"/>\n"
+#~ "    <column name=\"customerId\"/>\n"
+#~ "</many-to-one>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
+#~ "<!-- the \"class\" attribute is optional, as usual -->\n"
+#~ "    <column name=\"lineId\"/>\n"
+#~ "    <column name=\"orderId\"/>\n"
+#~ "    <column name=\"customerId\"/>\n"
+#~ "</many-to-one>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set name=\"undeliveredOrderLines\">\n"
+#~ "    <key column name=\"warehouseId\"/>\n"
+#~ "    <many-to-many class=\"OrderLine\">\n"
+#~ "        <column name=\"lineId\"/>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-many>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"undeliveredOrderLines\">\n"
+#~ "    <key column name=\"warehouseId\"/>\n"
+#~ "    <many-to-many class=\"OrderLine\">\n"
+#~ "        <column name=\"lineId\"/>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-many>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
+#~ "    <key>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </key>\n"
+#~ "    <one-to-many class=\"OrderLine\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
+#~ "    <key>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </key>\n"
+#~ "    <one-to-many class=\"OrderLine\"/>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    ....\n"
+#~ "    ....\n"
+#~ "    <list name=\"deliveryAttempts\">\n"
+#~ "        <key>   <!-- a collection inherits the composite key type -->\n"
+#~ "            <column name=\"lineId\"/>\n"
+#~ "            <column name=\"orderId\"/>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "        </key>\n"
+#~ "        <list-index column=\"attemptId\" base=\"1\"/>\n"
+#~ "        <composite-element class=\"DeliveryAttempt\">\n"
+#~ "            ...\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    ....\n"
+#~ "    ....\n"
+#~ "    <list name=\"deliveryAttempts\">\n"
+#~ "        <key>   <!-- a collection inherits the composite key type -->\n"
+#~ "            <column name=\"lineId\"/>\n"
+#~ "            <column name=\"orderId\"/>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "        </key>\n"
+#~ "        <list-index column=\"attemptId\" base=\"1\"/>\n"
+#~ "        <composite-element class=\"DeliveryAttempt\">\n"
+#~ "            ...\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<dynamic-component name=\"userAttributes\">\n"
+#~ "    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
+#~ "    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
+#~ "    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
+#~ "</dynamic-component>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<dynamic-component name=\"userAttributes\">\n"
+#~ "    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
+#~ "    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
+#~ "    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
+#~ "</dynamic-component>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/configuration.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/configuration.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/configuration.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,21 +1,35 @@
-#, fuzzy
+# translation of configuration.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: configuration\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-16 18:47+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-07 09:53+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: configuration.xml:29
 #, no-c-format
 msgid "Configuration"
-msgstr "Configuraci&#x00f3;n"
+msgstr "Configuración"
 
 #. Tag: para
-#: configuration.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate is designed to operate in many different environments and, as "
 "such, there is a broad range of configuration parameters. Fortunately, most "
@@ -24,23 +38,21 @@
 "displays the various options. Simply put the example file in your classpath "
 "and customize it to suit your needs."
 msgstr ""
-"Debido a que Hibernate est&#x00e1; dise&#x00f1;ado para operar en muchos "
-"entornos diferentes, hay un gran n&#x00fa;mero de par&#x00e1;metros de "
-"configuraci&#x00f3;n. Afortunadamente, la mayor&#x00ed;a tiene valores por "
-"defecto sensibles e Hibernate se distribuye con un fichero "
-"<literal>hibernate.properties</literal> de ejemplo en <literal>etc/</"
-"literal> que muestra las diversas opciones. Tan s&#x00f3;lo pon el fichero "
-"de ejemplo en tu classpath y personal&#x00ed;zalo."
+"Hibernate está diseñado para operar en muchos entornos diferentes y por lo "
+"tanto hay un gran número de parámetros de configuración. Afortunadamente, la "
+"mayoría tiene valores predeterminados sensibles y Hibernate se distribuye "
+"con un archivo <literal>hibernate.properties</literal> de ejemplo en "
+"<literal>etc/</literal> que muestra las diversas opciones. Simplemente ponga "
+"el fichero de ejemplo en su ruta de clase y personalícelo de acuerdo a sus "
+"necesidades."
 
 #. Tag: title
-#: configuration.xml:40
 #, no-c-format
 msgid "Programmatic configuration"
-msgstr "Configuraci&#x00f3;n program&#x00e1;tica"
+msgstr "Configuración programática"
 
 #. Tag: para
-#: configuration.xml:42
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of <classname>org.hibernate.cfg.Configuration</classname> "
 "represents an entire set of mappings of an application's Java types to an "
@@ -48,256 +60,181 @@
 "used to build an immutable <interfacename>org.hibernate.SessionFactory</"
 "interfacename>. The mappings are compiled from various XML mapping files."
 msgstr ""
-"Una instancia de <literal>org.hibernate.cfg.Configuration</literal> "
-"representa un conjunto entero de mapeos de los tipos Java de una "
-"aplicaci&#x00f3;n a una base de datos SQL. La <literal>Configuration</"
-"literal> es usada para construir una <literal>SessionFactory</literal> "
-"(inmutable). Los mapeos se compilan de varios ficheros de mapeo XML."
+"Una instancia de <classname>org.hibernate.cfg.Configuration</classname> "
+"representa un conjunto entero de mapeos de los tipos Java de una aplicación "
+"a una base de datos SQL. La <classname>org.hibernate.cfg.Configuration</"
+"classname> se utiliza para construir una <interfacename>org.hibernate."
+"SessionFactory</interfacename> inmutable. Los mapeos se compilan desde "
+"varios archivos de mapeo XML."
 
 #. Tag: para
-#: configuration.xml:49
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can obtain a <classname>org.hibernate.cfg.Configuration</classname> "
 "instance by instantiating it directly and specifying XML mapping documents. "
 "If the mapping files are in the classpath, use <literal>addResource()</"
 "literal>. For example:"
 msgstr ""
-"Puedes obtener una instancia de <literal>Configuration</literal> "
-"instanci&#x00e1;ndola directamente y especificando documentos de mapeo XML. "
-"Si los ficheros de mapeo est&#x00e1;n en el classpath, usa "
-"<literal>addResource()</literal>:"
+"Puede obtener una instancia de <classname>org.hibernate.cfg.Configuration</"
+"classname> instanciándola directamente y especificando los documentos de "
+"mapeo XML. Si los archivos de mapeo están en la ruta de clase, utilice "
+"<literal>addResource()</literal>. Por ejemplo:"
 
-#. Tag: programlisting
-#: configuration.xml:55
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addResource(\"Item.hbm.xml\")\n"
-"    .addResource(\"Bid.hbm.xml\");]]>"
-msgstr ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addResource(\"Item.hbm.xml\")\n"
-"    .addResource(\"Bid.hbm.xml\");]]>"
-
-#. Tag: para
-#: configuration.xml:57
-#, fuzzy, no-c-format
-msgid ""
 "An alternative way is to specify the mapped class and allow Hibernate to "
 "find the mapping document for you:"
 msgstr ""
-"Una forma alternativa (a veces mejor) es especificar la clase mapeada, y "
-"dejar que Hibernate encuentre el documento de mapeo por ti:"
+"Una manera opcional es especificar la clase mapeada y dejar que Hibernate "
+"encuentre el documento de mapeo por usted:"
 
-#. Tag: programlisting
-#: configuration.xml:62
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addClass(org.hibernate.auction.Item.class)\n"
-"    .addClass(org.hibernate.auction.Bid.class);]]>"
-msgstr ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addClass(org.hibernate.auction.Item.class)\n"
-"    .addClass(org.hibernate.auction.Bid.class);]]>"
-
-#. Tag: para
-#: configuration.xml:64
-#, fuzzy, no-c-format
-msgid ""
 "Hibernate will then search for mapping files named <filename>/org/hibernate/"
 "auction/Item.hbm.xml</filename> and <filename>/org/hibernate/auction/Bid.hbm."
 "xml</filename> in the classpath. This approach eliminates any hardcoded "
 "filenames."
 msgstr ""
-"Entonces Hibernate buscar&#x00e1; ficheros de mapeo llamados <literal>/org/"
-"hibernate/auction/Item.hbm.xml</literal> y <literal>/org/hibernate/auction/"
-"Bid.hbm.xml</literal> en el classpath. Este enfoque elimina cualquier nombre "
-"de fichero en el c&#x00f3;digo."
+"Luego Hibernate buscará los archivos de mapeo llamados <filename>/org/"
+"hibernate/auction/Item.hbm.xml</filename> y <filename>/org/hibernate/auction/"
+"Bid.hbm.xml</filename> en la ruta de clase. Este enfoque elimina cualquier "
+"nombre de archivo establecido manualmente."
 
 #. Tag: para
-#: configuration.xml:70
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <classname>org.hibernate.cfg.Configuration</classname> also allows you to "
 "specify configuration properties. For example:"
 msgstr ""
-"Una <literal>Configuration</literal> tambi&#x00e9;n te permite especificar "
-"propiedades de configuraci&#x00f3;n:"
+"Una <classname>org.hibernate.cfg.Configuration</classname> también le "
+"permite especificar las propiedades de configuración. Por ejemplo:"
 
-#. Tag: programlisting
-#: configuration.xml:75
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addClass(org.hibernate.auction.Item.class)\n"
-"    .addClass(org.hibernate.auction.Bid.class)\n"
-"    .setProperty(\"hibernate.dialect\", \"org.hibernate.dialect."
-"MySQLInnoDBDialect\")\n"
-"    .setProperty(\"hibernate.connection.datasource\", \"java:comp/env/jdbc/"
-"test\")\n"
-"    .setProperty(\"hibernate.order_updates\", \"true\");]]>"
-msgstr ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addClass(org.hibernate.auction.Item.class)\n"
-"    .addClass(org.hibernate.auction.Bid.class)\n"
-"    .setProperty(\"hibernate.dialect\", \"org.hibernate.dialect."
-"MySQLInnoDBDialect\")\n"
-"    .setProperty(\"hibernate.connection.datasource\", \"java:comp/env/jdbc/"
-"test\")\n"
-"    .setProperty(\"hibernate.order_updates\", \"true\");]]>"
-
-#. Tag: para
-#: configuration.xml:77
-#, fuzzy, no-c-format
-msgid ""
 "This is not the only way to pass configuration properties to Hibernate. Some "
 "alternative options include:"
 msgstr ""
-"Esta no es la &#x00fa;nica forma de pasar propiedades de configuraci&#x00f3;"
-"n a Hibernate. La diversas opciones incluyen:"
+"Esta no es la única manera de pasar propiedades de configuración a "
+"Hibernate. Algunas opciones incluyen:"
 
 #. Tag: para
-#: configuration.xml:84
 #, no-c-format
 msgid ""
 "Pass an instance of <classname>java.util.Properties</classname> to "
 "<literal>Configuration.setProperties()</literal>."
 msgstr ""
-"Pasar una instancia de <literal>java.util.Properties</literal> a "
+"Pasar una instancia de <classname>java.util.Properties</classname> a "
 "<literal>Configuration.setProperties()</literal>."
 
 #. Tag: para
-#: configuration.xml:90
 #, no-c-format
 msgid ""
 "Place a file named <filename>hibernate.properties</filename> in a root "
 "directory of the classpath."
 msgstr ""
-"Colocar <literal>hibernate.properties</literal> en un directorio ra&#x00ed;z "
-"del classpath."
+"Colocar un archivo llamado <literal>hibernate.properties</literal> en un "
+"directorio raíz de la ruta de clase."
 
 #. Tag: para
-#: configuration.xml:95
 #, no-c-format
 msgid ""
 "Set <literal>System</literal> properties using <literal>java -"
 "Dproperty=value</literal>."
 msgstr ""
-"Establecer propiedades <literal>System</literal> usando <literal>java -"
+"Establecer propiedades <literal>System</literal> utilizando <literal>java -"
 "Dproperty=value</literal>."
 
 #. Tag: para
-#: configuration.xml:100
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Include <literal>&lt;property&gt;</literal> elements in <literal>hibernate."
 "cfg.xml</literal> (this is discussed later)."
 msgstr ""
-"Incluir elementos <literal>&lt;property&gt;</literal> en <literal>hibernate."
-"cfg.xml</literal> (discutido luego)."
+"Incluir los elementos <literal>&lt;property&gt;</literal> en "
+"<literal>hibernate.cfg.xml</literal> (esto se discute más adelante)."
 
 #. Tag: para
-#: configuration.xml:107
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want to get started quickly<filename>hibernate.properties</filename> "
 "is the easiest approach."
 msgstr ""
-"<literal>hibernate.properties</literal> es el enfoque m&#x00e1;s f&#x00e1;"
-"cil si quieres comenzar r&#x00e1;pido."
+"Si quiere empezar rápidamente <filename>hibernate.properties</filename> es "
+"el enfoque más fácil."
 
 #. Tag: para
-#: configuration.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <classname>org.hibernate.cfg.Configuration</classname> is intended as a "
 "startup-time object that will be discarded once a <literal>SessionFactory</"
 "literal> is created."
 msgstr ""
-"La <literal>Configuration</literal> est&#x00e1; concebida como un objeto de "
-"tiempo de arranque, para ser descartado una vez que una "
-"<literal>SessionFactory</literal> es creada."
+"La <classname>org.hibernate.cfg.Configuration</classname> está concebida "
+"como un objeto de tiempo de inicio que se va a descartar una vez se crea una "
+"<literal>SessionFactory</literal>."
 
 #. Tag: title
-#: configuration.xml:119
 #, no-c-format
 msgid "Obtaining a SessionFactory"
-msgstr "Obteniendo una SessionFactory"
+msgstr "Obtención de una SessionFactory"
 
 #. Tag: para
-#: configuration.xml:121
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "When all mappings have been parsed by the <classname>org.hibernate.cfg."
 "Configuration</classname>, the application must obtain a factory for "
 "<interfacename>org.hibernate.Session</interfacename> instances. This factory "
 "is intended to be shared by all application threads:"
 msgstr ""
-"Cuando todos los mapeos han sido parseados por la <literal>Configuration</"
-"literal>, la aplicaci&#x00f3;n debe obtener una f&#x00e1;brica de instancias "
-"de <literal>Session</literal>. Esta f&#x00e1;brica est&#x00e1; concebida "
-"para ser compartida por todas las hebras de aplicaci&#x00f3;n:"
+"Cuando la <classname>org.hibernate.cfg.Configuration</classname> ha "
+"analizado sintácticamente todos los mapeos, la aplicación tiene que obtener "
+"una fábrica para las instancias <interfacename>org.hibernate.Session</"
+"interfacename>. Esta fábrica está concebida para que todos los hilos de la "
+"aplicación la compartan:"
 
-#. Tag: programlisting
-#: configuration.xml:127
-#, no-c-format
-msgid "<![CDATA[SessionFactory sessions = cfg.buildSessionFactory();]]>"
-msgstr "<![CDATA[SessionFactory sessions = cfg.buildSessionFactory();]]>"
-
 #. Tag: para
-#: configuration.xml:129
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Hibernate does allow your application to instantiate more than one "
 "<interfacename>org.hibernate.SessionFactory</interfacename>. This is useful "
 "if you are using more than one database."
 msgstr ""
-"Hibernate permite que tu aplicaci&#x00f3;n instancie m&#x00e1;s de una "
-"<literal>SessionFactory</literal>. Esto es &#x00fa;til si est&#x00e1;s "
-"usando m&#x00e1;s de una base de datos."
+"Hibernate permite que su aplicación instancie más de una <interfacename>org."
+"hibernate.SessionFactory</interfacename>. Esto es útil si está utilizando "
+"más de una base de datos."
 
 #. Tag: title
-#: configuration.xml:138
 #, no-c-format
 msgid "JDBC connections"
 msgstr "Conexiones JDBC"
 
 #. Tag: para
-#: configuration.xml:140
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is advisable to have the <interfacename>org.hibernate.SessionFactory</"
 "interfacename> create and pool JDBC connections for you. If you take this "
 "approach, opening a <interfacename>org.hibernate.Session</interfacename> is "
 "as simple as:"
 msgstr ""
-"Usualmente, quieres que la <literal>SessionFactory</literal> cree y almacene "
-"en pool conexiones JDBC para ti. Si adoptas este enfoque, abrir una "
-"<literal>Session</literal> es tan simple como:"
+"Se aconseja que la <interfacename>org.hibernate.SessionFactory</"
+"interfacename> cree y almacene en pool conexiones JDBC por usted Si adopta "
+"este enfoque, el abrir una <interfacename>org.hibernate.Session</"
+"interfacename> es tan simple como:"
 
-#. Tag: programlisting
-#: configuration.xml:146
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessions.openSession(); // open a new Session]]>"
-msgstr ""
-"<![CDATA[Session session = sessions.openSession(); // open a new Session]]>"
-
-#. Tag: para
-#: configuration.xml:148
-#, fuzzy, no-c-format
-msgid ""
 "Once you start a task that requires access to the database, a JDBC "
 "connection will be obtained from the pool."
 msgstr ""
-"En cuanto hagas algo que requiera acceso a la base de datos, se "
-"obtendr&#x00e1; una conexi&#x00f3;n JDBC del pool."
+"En el momento en que inicie una tarea que requiera acceso a la base de "
+"datos, se obtendrá una conexión JDBC del pool."
 
 #. Tag: para
-#: configuration.xml:153
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Before you can do this, you first need to pass some JDBC connection "
 "properties to Hibernate. All Hibernate property names and semantics are "
@@ -305,108 +242,89 @@
 "The most important settings for JDBC connection configuration are outlined "
 "below."
 msgstr ""
-"Para que esto funcione, necesitamos pasar algunas propiedades de "
-"conexi&#x00f3;n JDBC a Hibernate. Todos los nombres de propiedades y su "
-"sem&#x00e1;ntica est&#x00e1;n definidas en la clase <literal>org.hibernate."
-"cfg.Environment</literal>. Describiremos ahora las configuraciones m&#x00e1;"
-"s importantes para la conexi&#x00f3;n JDBC."
+"Para que esto funcione, primero necesita pasar algunas las propiedades de "
+"conexión JDBC a Hibernate. Todos los nombres de las propiedades de Hibernate "
+"y su semántica están definidas en la clase <classname>org.hibernate.cfg."
+"Environment</classname>. Ahora describiremos las configuraciones más "
+"importantes para la conexión JDBC."
 
 #. Tag: para
-#: configuration.xml:159
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will obtain and pool connections using <classname>java.sql."
 "DriverManager</classname> if you set the following properties:"
 msgstr ""
-"Hibernate obtendr&#x00e1; (y tendr&#x00e1; en pool) conexiones usando "
-"<literal>java.sql.DriverManager</literal> si configuras las siguientes "
+"Hibernate obtendrá y tendrá en pool las conexiones utilizando "
+"<classname>java.sql.DriverManager</classname> si configura las siguientes "
 "propiedades:"
 
 #. Tag: title
-#: configuration.xml:165
 #, no-c-format
 msgid "Hibernate JDBC Properties"
 msgstr "Propiedades JDBC de Hibernate"
 
 #. Tag: entry
-#: configuration.xml:171 configuration.xml:257 configuration.xml:353
-#: configuration.xml:546 configuration.xml:741 configuration.xml:848
-#: configuration.xml:936
 #, no-c-format
 msgid "Property name"
-msgstr "Nombre de propiedad"
+msgstr "Nombre de la propiedad"
 
 #. Tag: entry
-#: configuration.xml:172 configuration.xml:258 configuration.xml:354
-#: configuration.xml:547 configuration.xml:742 configuration.xml:849
-#: configuration.xml:937
 #, no-c-format
 msgid "Purpose"
-msgstr "Prop&#x00f3;sito"
+msgstr "Propósito"
 
-#. Tag: property
-#: configuration.xml:178
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.driver_class"
-msgstr "hibernate.connection.driver_class"
+msgid "<property>hibernate.connection.driver_class</property>"
+msgstr "<property>hibernate.connection.driver_class</property>"
 
-#. Tag: emphasis
-#: configuration.xml:181
+#. Tag: entry
 #, no-c-format
-msgid "JDBC driver class"
-msgstr "clase del driver jdbc"
+msgid "<emphasis>JDBC driver class</emphasis>"
+msgstr "<emphasis>clase del controlador JDBC</emphasis>"
 
-#. Tag: property
-#: configuration.xml:186
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.url"
-msgstr "hibernate.connection.url"
+msgid "<property>hibernate.connection.url</property>"
+msgstr "<property>hibernate.connection.url</property>"
 
-#. Tag: emphasis
-#: configuration.xml:189
+#. Tag: entry
 #, no-c-format
-msgid "JDBC URL"
-msgstr "URL de jdbc"
+msgid "<emphasis>JDBC URL</emphasis>"
+msgstr "<emphasis>URL JDBC</emphasis>"
 
-#. Tag: property
-#: configuration.xml:194 configuration.xml:288
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.username"
-msgstr "hibernate.connection.username"
+msgid "<property>hibernate.connection.username</property>"
+msgstr "<property>hibernate.connection.username</property>"
 
-#. Tag: emphasis
-#: configuration.xml:197
+#. Tag: entry
 #, no-c-format
-msgid "database user"
-msgstr "usuario de base de datos"
+msgid "<emphasis>database user</emphasis>"
+msgstr "<emphasis>usuario de la base de datos</emphasis>"
 
-#. Tag: property
-#: configuration.xml:202 configuration.xml:296
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.password"
-msgstr "hibernate.connection.password"
+msgid "<property>hibernate.connection.password</property>"
+msgstr "<property>hibernate.connection.password</property>"
 
-#. Tag: emphasis
-#: configuration.xml:205
+#. Tag: entry
 #, no-c-format
-msgid "database user password"
-msgstr "contrase&#x00f1;a del usuario de base de datos"
+msgid "<emphasis>database user password</emphasis>"
+msgstr "<emphasis>contraseña del usuario de la base de datos</emphasis>"
 
-#. Tag: property
-#: configuration.xml:210
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.pool_size"
-msgstr "hibernate.connection.pool_size"
+msgid "<property>hibernate.connection.pool_size</property>"
+msgstr "<property>hibernate.connection.pool_size</property>"
 
-#. Tag: emphasis
-#: configuration.xml:213
+#. Tag: entry
 #, no-c-format
-msgid "maximum number of pooled connections"
-msgstr "n&#x00fa;mero m&#x00e1;ximo de conexiones manejadas por pooling"
+msgid "<emphasis>maximum number of pooled connections</emphasis>"
+msgstr "<emphasis>número máximo de conexiones en pools</emphasis>"
 
 #. Tag: para
-#: configuration.xml:220
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's own connection pooling algorithm is, however, quite rudimentary. "
 "It is intended to help you get started and is <emphasis>not intended for use "
@@ -416,19 +334,17 @@
 "with connection pool specific settings. This will turn off Hibernate's "
 "internal pool. For example, you might like to use c3p0."
 msgstr ""
-"El algoritmo de pooling de conexiones propio de Hibernate es sin embargo "
-"algo rudimentario. Est&#x00e1; concebido para ayudarte a comenzar y "
-"<emphasis>no est&#x00e1; concebido para usar en un sistema de "
-"producci&#x00f3;n</emphasis> ni siquiera para pruebas de rendimiento. Debes "
-"usar un pool de terceros para un mejor rendimiento y estabilidad. S&#x00f3;"
-"lo remplaza la propiedad <literal>hibernate.connection.pool_size</literal> "
-"con configuraciones espec&#x00ed;ficas del pool de conexiones. Esto "
-"desactivar&#x00e1; el pool interno de Hibernate. Por ejemplo, podr&#x00ed;as "
-"querer usar C3P0."
+"Sin embargo, el algoritmo de pooling de la conexión propia de Hibernate es "
+"algo rudimentario. Está concebido para ayudarle a comenzar y <emphasis>no "
+"para utilizarse en un sistema de producción</emphasis> ni siquiera para "
+"pruebas de rendimiento. Para alcanzar un mejor rendimiento y estabilidad "
+"debe utilizar un pool de terceros. Sólo remplace la propiedad "
+"<property>hibernate.connection.pool_size</property> con configuraciones "
+"específicas del pool de conexiones. Esto desactivará el pool interno de "
+"Hibernate. Por ejemplo, es posible utilizar C3P0."
 
 #. Tag: para
-#: configuration.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "C3P0 is an open source JDBC connection pool distributed along with Hibernate "
 "in the <filename>lib</filename> directory. Hibernate will use its "
@@ -438,178 +354,122 @@
 "<filename>hibernate.properties</filename> and the Hibernate web site for "
 "more information."
 msgstr ""
-"C3P0 es un pool de conexiones JDBC de c&#x00f3;digo abierto distribuido "
-"junto a Hibernate en el directorio <literal>lib</literal>. Hibernate "
-"usar&#x00e1; su <literal>C3P0ConnectionProvider</literal> para pooling de "
-"conexiones si estableces propiedades <literal>hibernate.c3p0.*</literal>. Si "
-"quieres usar Proxool refi&#x00e9;rete al <literal>hibernate.properties</"
-"literal> empaquetado y al sitio web de Hibernate para m&#x00e1;s "
-"informaci&#x00f3;n."
+"C3P0 es un pool de conexiones JDBC de código abierto distribuido junto con "
+"Hibernate en el directorio <literal>lib</literal>. Hibernate utilizará su "
+"<classname>org.hibernate.connection.C3P0ConnectionProvider</classname> para "
+"pooling de conexiones si establece propiedades <literal>hibernate.c3p0.*</"
+"literal>. Si quiere utilizar Proxool refiérase a <literal>hibernate."
+"properties</literal> incluído en el paquete y al sitio web de Hibernate para "
+"obtener más información."
 
 #. Tag: para
-#: configuration.xml:238
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is an example <filename>hibernate.properties</filename> file "
 "for c3p0:"
 msgstr ""
-"Aqu&#x00ed; hay un fichero <literal>hibernate.properties</literal> de "
-"ejemplo para C3P0:"
+"Aquí hay un archivo <literal>hibernate.properties</literal> de ejemplo para "
+"c3p0:"
 
-#. Tag: programlisting
-#: configuration.xml:242
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[hibernate.connection.driver_class = org.postgresql.Driver\n"
-"hibernate.connection.url = jdbc:postgresql://localhost/mydatabase\n"
-"hibernate.connection.username = myuser\n"
-"hibernate.connection.password = secret\n"
-"hibernate.c3p0.min_size=5\n"
-"hibernate.c3p0.max_size=20\n"
-"hibernate.c3p0.timeout=1800\n"
-"hibernate.c3p0.max_statements=50\n"
-"hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
-msgstr ""
-"<![CDATA[hibernate.connection.driver_class = org.postgresql.Driver\n"
-"hibernate.connection.url = jdbc:postgresql://localhost/mydatabase\n"
-"hibernate.connection.username = myuser\n"
-"hibernate.connection.password = secret\n"
-"hibernate.c3p0.min_size=5\n"
-"hibernate.c3p0.max_size=20\n"
-"hibernate.c3p0.timeout=1800\n"
-"hibernate.c3p0.max_statements=50\n"
-"hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
-
-#. Tag: para
-#: configuration.xml:244
-#, fuzzy, no-c-format
-msgid ""
 "For use inside an application server, you should almost always configure "
 "Hibernate to obtain connections from an application server "
 "<interfacename>javax.sql.Datasource</interfacename> registered in JNDI. You "
 "will need to set at least one of the following properties:"
 msgstr ""
-"Para su uso en un servidor de aplicaciones, casi siempre debes configurar "
-"Hibernate para que obtenga conexiones de un <literal>Datasource</literal> "
-"del servidor de aplicaciones registrado en JNDI. Necesitar&#x00e1;s "
-"establecer al menos una de las siguientes propiedades:"
+"Para su utilización dentro de un servidor de aplicaciones, casi siempre "
+"usted debe configurar Hibernate para obtener conexiones de un "
+"<interfacename>javax.sql.Datasource</interfacename> del servidor de "
+"aplicaciones registrado en JNDI. Necesitará establecer al menos una de las "
+"siguientes propiedades:"
 
 #. Tag: title
-#: configuration.xml:251
 #, no-c-format
 msgid "Hibernate Datasource Properties"
-msgstr "Propiedades de Datasource de Hibernate"
+msgstr "Propiedades de la Fuente de Datos de Hibernate"
 
-#. Tag: property
-#: configuration.xml:264
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.datasource"
-msgstr "hibernate.connection.datasource"
+msgid "<property>hibernate.connection.datasource</property>"
+msgstr "<property>hibernate.connection.datasource</property>"
 
-#. Tag: emphasis
-#: configuration.xml:267
+#. Tag: entry
 #, no-c-format
-msgid "datasource JNDI name"
-msgstr "nombre del datasource JNDI"
+msgid "<emphasis>datasource JNDI name</emphasis>"
+msgstr "<emphasis>nombre JNDI de la fuente de datos</emphasis>"
 
-#. Tag: property
-#: configuration.xml:272
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jndi.url"
-msgstr "hibernate.jndi.url"
+msgid "<property>hibernate.jndi.url</property>"
+msgstr "<property>hibernate.jndi.url</property>"
 
 #. Tag: entry
-#: configuration.xml:274
 #, no-c-format
 msgid "<emphasis>URL of the JNDI provider</emphasis> (optional)"
-msgstr "<emphasis>URL del provedor JNDI</emphasis> (optional)"
+msgstr "<emphasis>URL del proveedor JNDI</emphasis> (opcional)"
 
-#. Tag: property
-#: configuration.xml:280
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jndi.class"
-msgstr "hibernate.jndi.class"
+msgid "<property>hibernate.jndi.class</property>"
+msgstr "<property>hibernate.jndi.class</property>"
 
 #. Tag: entry
-#: configuration.xml:282
 #, no-c-format
 msgid ""
 "<emphasis>class of the JNDI <literal>InitialContextFactory</literal></"
 "emphasis> (optional)"
 msgstr ""
-"<emphasis>clase de la <literal>InitialContextFactory</literal> de JNDI</"
-"emphasis> (opcional)"
+"<emphasis>clase del JNDI <literal>InitialContextFactory</literal></emphasis> "
+"(opcional)"
 
 #. Tag: entry
-#: configuration.xml:290
 #, no-c-format
 msgid "<emphasis>database user</emphasis> (optional)"
-msgstr "<emphasis>usuario de base de datos</emphasis> (opcional)"
+msgstr "<emphasis>usuario de la base de datos</emphasis> (opcional)"
 
 #. Tag: entry
-#: configuration.xml:298
 #, no-c-format
 msgid "<emphasis>database user password</emphasis> (optional)"
 msgstr ""
-"<emphasis>contrase&#x00f1;a del usuario de base de datos</emphasis> "
-"(opcional)"
+"<emphasis>contraseña del usuario de la base de datos</emphasis> (opcional)"
 
 #. Tag: para
-#: configuration.xml:306
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Here is an example <filename>hibernate.properties</filename> file for an "
 "application server provided JNDI datasource:"
 msgstr ""
-"He aqu&#x00ed; un fichero <literal>hibernate.properties</literal> de ejemplo "
-"para un un datasource JNDI provisto por un servidor de aplicaciones."
+"He aquí un archivo <literal>hibernate.properties</literal> de ejemplo para "
+"una fuente de datos JNDI provisto por un servidor de aplicaciones:"
 
-#. Tag: programlisting
-#: configuration.xml:311
-#, no-c-format
-msgid ""
-"<![CDATA[hibernate.connection.datasource = java:/comp/env/jdbc/test\n"
-"hibernate.transaction.factory_class = \\\n"
-"    org.hibernate.transaction.JTATransactionFactory\n"
-"hibernate.transaction.manager_lookup_class = \\\n"
-"    org.hibernate.transaction.JBossTransactionManagerLookup\n"
-"hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
-msgstr ""
-"<![CDATA[hibernate.connection.datasource = java:/comp/env/jdbc/test\n"
-"hibernate.transaction.factory_class = \\\n"
-"    org.hibernate.transaction.JTATransactionFactory\n"
-"hibernate.transaction.manager_lookup_class = \\\n"
-"    org.hibernate.transaction.JBossTransactionManagerLookup\n"
-"hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
-
 #. Tag: para
-#: configuration.xml:313
 #, no-c-format
 msgid ""
 "JDBC connections obtained from a JNDI datasource will automatically "
 "participate in the container-managed transactions of the application server."
 msgstr ""
-"Las conexiones JDBC obtenidas de un datasource JNDI participar&#x00e1;n "
-"autom&#x00e1;ticamente en las transacciones del servidor de aplicaciones "
-"manejadas por contenedor."
+"Las conexiones JDBC obtenidas de una fuente de datos JNDI participarán "
+"automáticamente en las transacciones del servidor de aplicaciones "
+"administradas por el contenedor."
 
 #. Tag: para
-#: configuration.xml:318
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Arbitrary connection properties can be given by prepending "
 "\"<literal>hibernate.connection</literal>\" to the connection property name. "
 "For example, you can specify a <property>charSet</property> connection "
 "property using <property>hibernate.connection.charSet</property>."
 msgstr ""
-"Pueden darse propiedades de conexi&#x00f3;n arbitrarias anteponiendo "
-"\"<literal>hibernate.connnection</literal>\" al nombre de propiedad. Por "
-"ejemplo, puedes especificar un <literal>charSet</literal> usando "
-"<literal>hibernate.connection.charSet</literal>."
+"Pueden darse propiedades de conexión arbitrarias anteponiendo "
+"\"<literal>hibernate.connnection</literal>\" al nombre de propiedad de la "
+"conexión. Por ejemplo, puede especificar una propiedad de conexión "
+"<literal>charSet</literal> usando <property>hibernate.connection.charSet</"
+"property>."
 
 #. Tag: para
-#: configuration.xml:324
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can define your own plugin strategy for obtaining JDBC connections by "
 "implementing the interface <interfacename>org.hibernate.connection."
@@ -617,31 +477,27 @@
 "implementation via the <property>hibernate.connection.provider_class</"
 "property> property."
 msgstr ""
-"Puedes definir tu propia estrategia de plugin para obtener conexiones JDBC "
-"implementando la interface <literal>org.hibernate.connection."
-"ConnectionProvider</literal>. Puedes seleccionar una implementaci&#x00f3;n "
-"personalizada estableciendo <literal>hibernate.connection.provider_class</"
-"literal>."
+"Puede definir su propia estrategia plugin para obtener conexiones JDBC "
+"implementando la interfaz <interfacename>org.hibernate.connection."
+"ConnectionProvider</interfacename> y especificando su propia implementación "
+"personalizada por medio de la propiedad <property>hibernate.connection."
+"provider_class</property>."
 
 #. Tag: title
-#: configuration.xml:333
 #, no-c-format
 msgid "Optional configuration properties"
-msgstr "Par&#x00e1;metros de configuraci&#x00f3;n opcionales"
+msgstr "Parámetros de configuración opcionales"
 
 #. Tag: para
-#: configuration.xml:335
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are a number of other properties that control the behavior of "
 "Hibernate at runtime. All are optional and have reasonable default values."
 msgstr ""
-"Hay un n&#x00fa;mero de otras propiedades que controlan el comportamiento de "
-"Hibernate en tiempo de ejecuci&#x00f3;n. Todas son opcionales y tienen "
-"valores por defecto razonables."
+"Hay otras propiedades que controlan el comportamiento de Hibernate en tiempo "
+"de ejecución. Todas son opcionales y tienen valores razonables por defecto. "
 
-#. Tag: warning
-#: configuration.xml:341
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Some of these properties are \"system-level\" only.</emphasis> "
@@ -649,247 +505,215 @@
 "literal> or <filename>hibernate.properties</filename>. They "
 "<emphasis>cannot</emphasis> be set by the other techniques described above."
 msgstr ""
-"<emphasis>Advertencia: algunas de estas propiedades son de \"nivel-de-sistema"
-"\" solamente.</emphasis>. Las propiedades a nivel de sistema s&#x00f3;lo "
-"pueden ser establecidas por medio de <literal>java -Dproperty=value</"
-"literal> o <literal>hibernate.properties</literal>. <emphasis>No</emphasis> "
-"pueden establecerse por medio de las otras t&#x00e9;cnicas arriba descritas."
+"Algunas de estas propiedades se encuentran a nivel-del-sistema sólamente. "
+"Las propiedades a nivel del sistema sólamente se pueden establecer por medio "
+"de <code>java -Dproperty=value</code> o <filename>hibernate.properties</"
+"filename>. <emphasis>No</emphasis> pueden establecerse por medio de las "
+"técnicas descritas anteriormente."
 
 #. Tag: title
-#: configuration.xml:347
 #, no-c-format
 msgid "Hibernate Configuration Properties"
-msgstr "Propiedades de Configuraci&#x00f3;n de Hibernate"
+msgstr "Propiedades de Configuración de Hibernate"
 
-#. Tag: property
-#: configuration.xml:360
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.dialect"
-msgstr "hibernate.dialect"
+msgid "<property>hibernate.dialect</property>"
+msgstr "<property>hibernate.dialect</property>"
 
 #. Tag: entry
-#: configuration.xml:362
 #, no-c-format
 msgid ""
 "The classname of a Hibernate <classname>org.hibernate.dialect.Dialect</"
 "classname> which allows Hibernate to generate SQL optimized for a particular "
 "relational database."
 msgstr ""
-"El nombre de clase de un <literal>Dialect</literal> de Hibernate que permite "
-"a Hibernate generar SQL optimizado para una base de datos relacional en "
-"particular."
+"El nombre de clase de un <classname>org.hibernate.dialect.Dialect</"
+"classname> de Hibernate, el cual le permite que genere un SQL optimizado "
+"para una base de datos relacional en particular. "
 
 #. Tag: para
-#: configuration.xml:365
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>full.classname.of."
 "Dialect</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ej.</emphasis> <literal>full.classname.of.Dialect</"
-"literal>"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>full.classname.of."
+"Dialect</literal>"
 
 #. Tag: para
-#: configuration.xml:369
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In most cases Hibernate will actually be able to choose the correct "
 "<classname>org.hibernate.dialect.Dialect</classname> implementation based on "
 "the <literal>JDBC metadata</literal> returned by the JDBC driver."
 msgstr ""
-"UNTRANSLATED! In most cases Hibernate will actually be able to chose the "
-"correct <classname>org.hibernate.dialect.Dialect</classname> implementation "
-"to use based on the <literal>JDBC metadata</literal> returned by the JDBC "
-"driver."
+"En la mayoría de los casos Hibernate podrá de hecho seleccionar la "
+"implementación <classname>org.hibernate.dialect.Dialect</classname> correcta "
+"con base en los <literal>JDBC metadata</literal> que el controlador JDBC "
+"retorna."
 
-#. Tag: property
-#: configuration.xml:378
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.show_sql"
-msgstr "hibernate.show_sql"
+msgid "<property>hibernate.show_sql</property>"
+msgstr "<property>hibernate.show_sql</property>"
 
 #. Tag: entry
-#: configuration.xml:380
 #, no-c-format
 msgid ""
 "Write all SQL statements to console. This is an alternative to setting the "
 "log category <literal>org.hibernate.SQL</literal> to <literal>debug</"
 "literal>."
 msgstr ""
-"Escribe todas las sentencias SQL a la consola. This is an alternative to "
-"setting the log category <literal>org.hibernate.SQL</literal> to "
-"<literal>debug</literal>."
+"Escribe todas las declaraciones SQL a la consola. Esta es una alternativa "
+"para establecer la categoria de registro <literal>org.hibernate.SQL</"
+"literal> a <literal>debug</literal>."
 
 #. Tag: para
-#: configuration.xml:384 configuration.xml:396 configuration.xml:490
-#: configuration.xml:503 configuration.xml:516 configuration.xml:529
-#: configuration.xml:581 configuration.xml:608 configuration.xml:621
-#: configuration.xml:676 configuration.xml:904 configuration.xml:919
-#: configuration.xml:1009
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>true</literal> | "
 "<literal>false</literal>"
 msgstr ""
-"<emphasis role=\"strong\">eg.</emphasis> <literal>true</literal> | "
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: property
-#: configuration.xml:392
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.format_sql"
-msgstr "hibernate.format_sql"
+msgid "<property>hibernate.format_sql</property>"
+msgstr "<property>hibernate.format_sql</property>"
 
 #. Tag: entry
-#: configuration.xml:394
 #, no-c-format
 msgid "Pretty print the SQL in the log and console."
-msgstr "Pretty print the SQL in the log and console."
+msgstr "Imprime el SQL en el registro y la consola."
 
-#. Tag: property
-#: configuration.xml:404
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_schema"
-msgstr "hibernate.default_schema"
+msgid "<property>hibernate.default_schema</property>"
+msgstr "<property>hibernate.default_schema</property>"
 
 #. Tag: entry
-#: configuration.xml:406
 #, no-c-format
 msgid ""
 "Qualify unqualified table names with the given schema/tablespace in "
 "generated SQL."
 msgstr ""
-"Cualifica, en el SQL generado, los nombres de tabla sin cualificar con el "
-"esquema/tablespace dado."
+"Califica los nombres de tabla sin calificar con el esquema/espacio de tabla "
+"dado en el SQL generado. "
 
 #. Tag: para
-#: configuration.xml:409
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>SCHEMA_NAME</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ej.</emphasis> <literal>SCHEMA_NAME</literal>"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>SCHEMA_NAME</literal>"
 
-#. Tag: property
-#: configuration.xml:417
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_catalog"
-msgstr "hibernate.default_catalog"
+msgid "<property>hibernate.default_catalog</property>"
+msgstr "<property>hibernate.default_catalog</property>"
 
 #. Tag: entry
-#: configuration.xml:419
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Qualifies unqualified table names with the given catalog in generated SQL."
 msgstr ""
-"Cualifica, en el SQL generado, los nombres de tabla sin cualificar con el "
-"cat&#x00e1;logo dado."
+"Califica los nombres de tabla sin calificar con el catálogo dado en el SQL "
+"generado."
 
 #. Tag: para
-#: configuration.xml:422
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>CATALOG_NAME</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ej.</emphasis> <literal>CATALOG_NAME</literal>"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>CATALOG_NAME</literal>"
 
-#. Tag: property
-#: configuration.xml:430
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.session_factory_name"
-msgstr "hibernate.session_factory_name"
+msgid "<property>hibernate.session_factory_name</property>"
+msgstr "<property>hibernate.session_factory_name</property>"
 
 #. Tag: entry
-#: configuration.xml:432
 #, no-c-format
 msgid ""
 "The <interfacename>org.hibernate.SessionFactory</interfacename> will be "
 "automatically bound to this name in JNDI after it has been created."
 msgstr ""
-"La <literal>SessionFactory</literal> ser&#x00e1; ligada a este nombre en "
-"JNDI autom&#x00e1;ticamente despu&#x00e9;s de ser creada."
+"Automáticamente se vinculará el <interfacename>org.hibernate.SessionFactory</"
+"interfacename> a este nombre en JNDI después de que se ha creado."
 
 #. Tag: para
-#: configuration.xml:435 configuration.xml:875
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>jndi/composite/name</"
 "literal>"
 msgstr ""
-"<emphasis role=\"strong\">ej.</emphasis> <literal>jndi/composite/name</"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>jndi/composite/name</"
 "literal>"
 
-#. Tag: property
-#: configuration.xml:443
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.max_fetch_depth"
-msgstr "hibernate.max_fetch_depth"
+msgid "<property>hibernate.max_fetch_depth</property>"
+msgstr "<property>hibernate.max_fetch_depth</property>"
 
 #. Tag: entry
-#: configuration.xml:445
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sets a maximum \"depth\" for the outer join fetch tree for single-ended "
 "associations (one-to-one, many-to-one). A <literal>0</literal> disables "
 "default outer join fetching."
 msgstr ""
-"Establece una \"profundidad\" m&#x00e1;xima del &#x00e1;rbol de "
-"recuperaci&#x00f3;n por outer join para asociaciones de un extremo solo (uno-"
-"a-uno, muchos-a-uno). Un <literal>0</literal> deshabilita la "
-"recuperaci&#x00f3;n por outer join por defecto."
+"Establece una \"profundidad\" máxima del árbol de recuperación por unión "
+"externa (outer join) para asociaciones de un sólo extremo (uno-a-uno, muchos-"
+"a-uno). Un <literal>0</literal> deshabilita la recuperación por unión "
+"externa predeterminada."
 
 #. Tag: para
-#: configuration.xml:449
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values between "
 "<literal>0</literal> and <literal>3</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ej.</emphasis> valores recomendados entre "
+"<emphasis role=\"strong\">ej.</emphasis> los valores recomendados entre "
 "<literal>0</literal> y <literal>3</literal>"
 
-#. Tag: property
-#: configuration.xml:458
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_batch_fetch_size"
-msgstr "hibernate.default_batch_fetch_size"
+msgid "<property>hibernate.default_batch_fetch_size</property>"
+msgstr "<property>hibernate.default_batch_fetch_size</property>"
 
 #. Tag: entry
-#: configuration.xml:460
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Sets a default size for Hibernate batch fetching of associations."
 msgstr ""
-"Establece un tama&#x00f1;o por defecto para la recuperaci&#x00f3;n en lote "
-"de asociaciones de Hibernate."
+"Establece un tamaño por defecto para la recuperación en lote de asociaciones "
+"de Hibernate."
 
 #. Tag: para
-#: configuration.xml:462
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values <literal>4</"
 "literal>, <literal>8</literal>, <literal>16</literal>"
 msgstr ""
 "<emphasis role=\"strong\">ej.</emphasis> valores recomendados <literal>4</"
-"literal>, <literal>8</literal>, <literal>16</literal>"
+"literal>, <literal>8</literal>, <literal>16</literal> "
 
-#. Tag: property
-#: configuration.xml:471
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_entity_mode"
-msgstr "hibernate.default_entity_mode"
+msgid "<property>hibernate.default_entity_mode</property>"
+msgstr "<property>hibernate.default_entity_mode</property>"
 
 #. Tag: entry
-#: configuration.xml:473
 #, fuzzy, no-c-format
 msgid ""
 "Sets a default mode for entity representation for all sessions opened from "
 "this <literal>SessionFactory</literal>"
 msgstr ""
-"Establece un modo por defecto de representaci&#x00f3;n de entidades para "
-"todas las sesiones abiertas por esta <literal>SessionFactory</literal>"
+"Establece un modo predeterminado de representación de entidades para todas "
+"las sesiones abiertas desde esta <literal>SessionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:476
 #, no-c-format
 msgid ""
 "<literal>dynamic-map</literal>, <literal>dom4j</literal>, <literal>pojo</"
@@ -898,212 +722,186 @@
 "<literal>dynamic-map</literal>, <literal>dom4j</literal>, <literal>pojo</"
 "literal>"
 
-#. Tag: property
-#: configuration.xml:484
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.order_updates"
-msgstr "hibernate.order_updates"
+msgid "<property>hibernate.order_updates</property>"
+msgstr "<property>hibernate.order_updates</property>"
 
 #. Tag: entry
-#: configuration.xml:486
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Forces Hibernate to order SQL updates by the primary key value of the items "
 "being updated. This will result in fewer transaction deadlocks in highly "
 "concurrent systems."
 msgstr ""
-"Fuerza a Hibernate a ordenar las actualizaciones SQL por el valor de la "
-"clave primaria de los items a actualizar. Esto resultar&#x00e1; en menos "
-"bloqueos muertos de transacci&#x00f3;n en sistemas altamente concurrentes."
+"Obliga a Hibernate a ordenar las actualizaciones SQL por el valor de la "
+"clave principal de los items a actualizar. Esto resultará en menos bloqueos "
+"de transacción en sistemas altamente concurrentes."
 
-#. Tag: property
-#: configuration.xml:498
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.generate_statistics"
-msgstr "hibernate.generate_statistics"
+msgid "<property>hibernate.generate_statistics</property>"
+msgstr "<property>hibernate.generate_statistics</property>"
 
 #. Tag: entry
-#: configuration.xml:500
 #, no-c-format
 msgid ""
 "If enabled, Hibernate will collect statistics useful for performance tuning."
 msgstr ""
-"De habilitarse, Hibernate colectar&#x00e1; estad&#x00ed;sticas &#x00fa;tiles "
-"para la afinaci&#x00f3;n de rendimiento."
+"De habilitarse, Hibernate colectará estadísticas útiles para la afinación de "
+"rendimiento. "
 
-#. Tag: property
-#: configuration.xml:511
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.use_identifier_rollback"
-msgstr "hibernate.use_identifer_rollback"
+msgid "<property>hibernate.use_identifier_rollback</property>"
+msgstr "<property>hibernate.use_identifier_rollback</property>"
 
 #. Tag: entry
-#: configuration.xml:513
 #, no-c-format
 msgid ""
 "If enabled, generated identifier properties will be reset to default values "
 "when objects are deleted."
 msgstr ""
-"De habilitarse, las propiedades identificadoras generadas ser&#x00e1;n "
-"reseteadas a valores por defecto cuando los objetos sean borrados."
+"De habilitarse, cuando se borren los objetos las propiedades identificadoras "
+"generadas se resetearán a losvalores establecidos por defecto."
 
-#. Tag: property
-#: configuration.xml:524
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.use_sql_comments"
-msgstr "hibernate.use_sql_comments"
+msgid "<property>hibernate.use_sql_comments</property>"
+msgstr "<property>hibernate.use_sql_comments</property>"
 
 #. Tag: entry
-#: configuration.xml:526
 #, no-c-format
 msgid ""
 "If turned on, Hibernate will generate comments inside the SQL, for easier "
 "debugging, defaults to <literal>false</literal>."
 msgstr ""
-"De activarse, Hibernate generar&#x00e1; comentarios dentro del SQL, para una "
-"m&#x00e1;s f&#x00e1;cil depuraci&#x00f3;n, por defecto a <literal>false</"
-"literal>."
+"De activarse, Hibernate generará comentarios dentro del SQL, para una "
+"depuración más fácil, por defecto es <literal>false</literal>."
 
 #. Tag: title
-#: configuration.xml:540
 #, no-c-format
 msgid "Hibernate JDBC and Connection Properties"
 msgstr "Propiedades de JDBC y Conexiones de Hibernate"
 
-#. Tag: property
-#: configuration.xml:553
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.fetch_size"
-msgstr "hibernate.jdbc.fetch_size"
+msgid "<property>hibernate.jdbc.fetch_size</property>"
+msgstr "<property>hibernate.jdbc.fetch_size</property>"
 
 #. Tag: entry
-#: configuration.xml:555
 #, no-c-format
 msgid ""
 "A non-zero value determines the JDBC fetch size (calls <literal>Statement."
 "setFetchSize()</literal>)."
 msgstr ""
-"Un valor distinto de cero que determina el tama&#x00f1;o de "
-"recuperaci&#x00f3;n de JDBC (llama a <literal>Statement.setFetchSize()</"
-"literal>)."
+"Un valor distinto de cero que determina el tamaño de recuperación de JDBC "
+"(llama a <literal>Statement.setFetchSize()</literal>)."
 
-#. Tag: property
-#: configuration.xml:562
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.batch_size"
-msgstr "hibernate.jdbc.batch_size"
+msgid "<property>hibernate.jdbc.batch_size</property>"
+msgstr "<property>hibernate.jdbc.batch_size</property>"
 
 #. Tag: entry
-#: configuration.xml:564
 #, no-c-format
 msgid "A non-zero value enables use of JDBC2 batch updates by Hibernate."
 msgstr ""
-"Un valor distinto de cero habilita el uso de actualizaciones en lote de "
-"JDBC2 por Hibernate."
+"Un valor distinto de cero habilita que Hibernate utilice las actualizaciones "
+"en lote de JDBC2. "
 
 #. Tag: para
-#: configuration.xml:566
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values between "
 "<literal>5</literal> and <literal>30</literal>"
 msgstr ""
 "<emphasis role=\"strong\">ej.</emphasis> valores recomendados entre "
-"<literal>5</literal> y <literal>30</literal>"
+"<literal>5</literal> y <literal>30</literal> "
 
-#. Tag: property
-#: configuration.xml:574
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.batch_versioned_data"
-msgstr "hibernate.jdbc.batch_versioned_data"
+msgid "<property>hibernate.jdbc.batch_versioned_data</property>"
+msgstr "<property>hibernate.jdbc.batch_versioned_data</property>"
 
 #. Tag: entry
-#: configuration.xml:576
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Set this property to <literal>true</literal> if your JDBC driver returns "
 "correct row counts from <literal>executeBatch()</literal>. Iit is usually "
 "safe to turn this option on. Hibernate will then use batched DML for "
 "automatically versioned data. Defaults to <literal>false</literal>."
 msgstr ""
-"Establece esta propiedad a <literal>true</literal> si tu driver JDBC "
-"devuelve cuentas correctas de filas desde <literal>executeBatch()</literal> "
-"(usualmente es seguro activar esta opci&#x00f3;n). Hibernate usar&#x00e1; "
-"DML en lote para versionar autom&#x00e1;ticamente los datos. Por defecto a "
-"<literal>false</literal>."
+"Establece esta propiedad como <literal>true</literal> si su controlador JDBC "
+"retorna cuentas correctas de filas desde <literal>executeBatch()</literal>. "
+"Usualmente es seguro activar esta opción. Hibernate utilizará un DML en lote "
+"para versionar automáticamente los datos. Por defecto es <literal>false</"
+"literal>."
 
-#. Tag: property
-#: configuration.xml:589
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.factory_class"
-msgstr "hibernate.jdbc.factory_class"
+msgid "<property>hibernate.jdbc.factory_class</property>"
+msgstr "<property>hibernate.jdbc.factory_class</property>"
 
 #. Tag: entry
-#: configuration.xml:591
 #, no-c-format
 msgid ""
 "Select a custom <interfacename>org.hibernate.jdbc.Batcher</interfacename>. "
 "Most applications will not need this configuration property."
 msgstr ""
-"Selecciona un <literal>Batcher</literal> personalizado. La mayor&#x00ed;a de "
-"las aplicaciones no necesitar&#x00e1;n esta propiedad de configuraci&#x00f3;"
-"n."
+"Selecciona un <interfacename>org.hibernate.jdbc.Batcher</interfacename> "
+"personalizado. La mayoría de las aplicaciones no necesitarán esta propiedad "
+"de configuración. "
 
 #. Tag: para
-#: configuration.xml:594
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "BatcherFactory</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ej.</emphasis> <literal>classname.of."
+"<emphasis role=\"strong\">eg.</emphasis> <literal>classname.of."
 "BatcherFactory</literal>"
 
-#. Tag: property
-#: configuration.xml:602
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_scrollable_resultset"
-msgstr "hibernate.jdbc.use_scrollable_resultset"
+msgid "<property>hibernate.jdbc.use_scrollable_resultset</property>"
+msgstr "<property>hibernate.jdbc.use_scrollable_resultset</property>"
 
 #. Tag: entry
-#: configuration.xml:604
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Enables use of JDBC2 scrollable resultsets by Hibernate. This property is "
 "only necessary when using user-supplied JDBC connections. Hibernate uses "
 "connection metadata otherwise."
 msgstr ""
-"Habilita el uso de resultados scrollables de JDBC2 por Hibernate. Esta "
-"propiedad s&#x00f3;lo es necesaria cuando se usan conexiones JDBC provistas "
-"por el usuario, en caso contrario Hibernate usa los metadatos de "
-"conexi&#x00f3;n."
+"Habilita a Hibernate para utilizar los grupos de resultados deslizables de "
+"JDBC2. Esta propiedad sólamente es necesaria cuando se utilizan conexiones "
+"JDBC provistas por el usuario. En el caso contrario Hibernate utiliza los "
+"metadatos de conexión."
 
-#. Tag: property
-#: configuration.xml:616
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_streams_for_binary"
-msgstr "hibernate.jdbc.use_streams_for_binary"
+msgid "<property>hibernate.jdbc.use_streams_for_binary</property>"
+msgstr "<property>hibernate.jdbc.use_streams_for_binary</property>"
 
 #. Tag: entry
-#: configuration.xml:618
 #, no-c-format
 msgid ""
 "Use streams when writing/reading <literal>binary</literal> or "
 "<literal>serializable</literal> types to/from JDBC. <emphasis>*system-level "
 "property*</emphasis>"
 msgstr ""
-"Usa flujos (streams) al escribir/leer tipos <literal>binary</literal> o "
-"<literal>serializable</literal> a/desde JDBC (propiedad a nivel de sistema)."
+"Utiliza flujos (streams) al escribir/leer tipos <literal>binary</literal> o "
+"<literal>serializable</literal> a/desde JDBC. <emphasis>Propiedad a nivel de "
+"sistema</emphasis>"
 
-#. Tag: property
-#: configuration.xml:629
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_get_generated_keys"
-msgstr "hibernate.jdbc.use_get_generated_keys"
+msgid "<property>hibernate.jdbc.use_get_generated_keys</property>"
+msgstr "<property>hibernate.jdbc.use_get_generated_keys</property>"
 
 #. Tag: entry
-#: configuration.xml:631
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Enables use of JDBC3 <literal>PreparedStatement.getGeneratedKeys()</literal> "
 "to retrieve natively generated keys after insert. Requires JDBC3+ driver and "
@@ -1112,95 +910,87 @@
 "capabilities using connection metadata."
 msgstr ""
 "Habilita el uso de <literal>PreparedStatement.getGeneratedKeys()</literal> "
-"de JDBC3 para traer claves generadas nativamente despu&#x00e9;s de insertar. "
-"Requiere un driver JDBC3+ y un JRE1.4+. Establ&#x00e9;cela a false si tu "
-"driver tiene problemas con los generadores de identificador de Hibernate. "
-"Por defecto, se intenta determinar las capacidades del driver usando los "
-"metadatos de conexi&#x00f3;n."
+"de JDBC3 para recuperar claves generadas nativamente después de insertar. "
+"Requiere un controlador JDBC3+ y un JRE1.4+. Establézcalo como falso si su "
+"controlador tiene problemas con los generadores del identificador de "
+"Hibernate. Por defecto, se intenta determinar las capacidades del "
+"controlador utilizando los metadatos de conexión."
 
 #. Tag: para
-#: configuration.xml:637 configuration.xml:767 configuration.xml:779
-#: configuration.xml:793 configuration.xml:831
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>true|false</literal>"
-msgstr "<emphasis role=\"strong\">ej.</emphasis> <literal>true|false</literal>"
+msgstr ""
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>true|false</literal>"
 
-#. Tag: property
-#: configuration.xml:645
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.provider_class"
-msgstr "hibernate.connection.provider_class"
+msgid "<property>hibernate.connection.provider_class</property>"
+msgstr "<property>hibernate.connection.provider_class</property>"
 
 #. Tag: entry
-#: configuration.xml:647
 #, no-c-format
 msgid ""
 "The classname of a custom <interfacename>org.hibernate.connection."
 "ConnectionProvider</interfacename> which provides JDBC connections to "
 "Hibernate."
 msgstr ""
-"EL nombre de clase de un <literal>ConnectionProvider</literal> personalizado "
-"que provea conexiones JDBC a Hibernate."
+"EL nombre de clase de un <interfacename>org.hibernate.connection."
+"ConnectionProvider</interfacename> personalizado que proporcione conexiones "
+"JDBC a Hibernate. "
 
 #. Tag: para
-#: configuration.xml:650
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "ConnectionProvider</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ej.</emphasis> <literal>classname.of."
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "ConnectionProvider</literal>"
 
-#. Tag: property
-#: configuration.xml:658
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.isolation"
-msgstr "hibernate.connection.isolation"
+msgid "<property>hibernate.connection.isolation</property>"
+msgstr "<property>hibernate.connection.isolation</property>"
 
 #. Tag: entry
-#: configuration.xml:660
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sets the JDBC transaction isolation level. Check <interfacename>java.sql."
 "Connection</interfacename> for meaningful values, but note that most "
 "databases do not support all isolation levels and some define additional, "
 "non-standard isolations."
 msgstr ""
-"Establece el nivel de aislamiento de transacci&#x00f3;n JDBC. Comprueba "
-"<literal>java.sql.Connection</literal> para valores significativos pero "
-"observa que la mayor&#x00ed;a de las bases de datos no soportan todos los "
-"niveles de aislamiento."
+"Establece el nivel de aislamiento de la transacción JDBC. Comprueba "
+"<interfacename>java.sql.Connection</interfacename> para valores "
+"significativos pero observe que la mayoría de las bases de datos no soportan "
+"todos los niveles de aislamiento y algunos definen nivekes de aislamiento "
+"adicionales y no estándares."
 
 #. Tag: para
-#: configuration.xml:664
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>1, 2, 4, 8</literal>"
-msgstr "<emphasis role=\"strong\">eg.</emphasis> <literal>1, 2, 4, 8</literal>"
+msgstr ""
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>1, 2, 4, 8</literal>"
 
-#. Tag: property
-#: configuration.xml:672
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.autocommit"
-msgstr "hibernate.connection.autocommit"
+msgid "<property>hibernate.connection.autocommit</property>"
+msgstr "<property>hibernate.connection.autocommit</property>"
 
 #. Tag: entry
-#: configuration.xml:674
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Enables autocommit for JDBC pooled connections (it is not recommended)."
 msgstr ""
-"Habilita compromiso autom&#x00e1;tico (autocommit) para las conexiones JDBC "
-"en pool (no recomendado)."
+"Habilita un guardado automático (autocommit) para las conexiones JDBC en "
+"pool (no se recomienda)."
 
-#. Tag: property
-#: configuration.xml:684
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.release_mode"
-msgstr "hibernate.connection.release_mode"
+msgid "<property>hibernate.connection.release_mode</property>"
+msgstr "<property>hibernate.connection.release_mode</property>"
 
 #. Tag: entry
-#: configuration.xml:686
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Specifies when Hibernate should release JDBC connections. By default, a JDBC "
 "connection is held until the session is explicitly closed or disconnected. "
@@ -1212,493 +1002,445 @@
 "the JTA and CMT transaction strategies and <literal>after_transaction</"
 "literal> for the JDBC transaction strategy."
 msgstr ""
-"Especifica cu&#x00e1;ndo Hibernate debe liberar las conexiones JDBC. Por "
-"defecto, una conexi&#x00f3;n JDBC es retenida hasta que la sesi&#x00f3;n es "
-"cerrada expl&#x00ed;citamente o desconectada. Para un datasource JTA del "
-"servidor de aplicaciones, debes usar <literal>after_statement</literal> para "
-"liberar agresivamente las conexiones despu&#x00e9;s de cada llamada JDBC. "
-"Para una conexi&#x00f3;n no JTA, frecuentemente tiene sentido liberar la "
-"conexi&#x00f3;n al final de cada transacci&#x00f3;n, usando "
-"<literal>after_transaction</literal>. <literal>auto</literal> eligir&#x00e1; "
-"<literal>after_statement</literal> para las estrategias JTA o CMT de "
-"transacci&#x00f3;n y <literal>after_transaction</literal> para la estrategia "
-"JDBC de transacci&#x00f3;n."
+"Especifica el momento en que Hibernate debe liberar las conexiones JDBC. Por "
+"defecto, una conexión JDBC es retenida hasta que la sesión se cierra o se "
+"desconecta explícitamente. Para una fuente de datos JTA del servidor de "
+"aplicaciones, debe utilizar <literal>after_statement</literal> para liberar "
+"agresivamente las conexiones después de cada llamada JDBC. Para una conexión "
+"no JTA, frecuentemente tiene sentido el liberar la conexión al final de cada "
+"transacción, el utilizar<literal>after_transaction</literal>. <literal>auto</"
+"literal> escogerá <literal>after_statement</literal> para las estrategias de "
+"transacción JTA y CMT y <literal>after_transaction</literal> para la "
+"estrategia JDBC de transacción. "
 
 #. Tag: para
-#: configuration.xml:697
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>auto</literal> (default) "
 "| <literal>on_close</literal> | <literal>after_transaction</literal> | "
 "<literal>after_statement</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ej.</emphasis> <literal>on_close</literal> (por "
-"defecto)| <literal>after_transaction</literal> | <literal>after_statement</"
-"literal> | <literal>auto</literal>"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>auto</literal> (default) "
+"| <literal>on_close</literal> | <literal>after_transaction</literal> | "
+"<literal>after_statement</literal>"
 
 #. Tag: para
-#: configuration.xml:702
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This setting only affects <literal>Session</literal>s returned from "
 "<literal>SessionFactory.openSession</literal>. For <literal>Session</"
 "literal>s obtained through <literal>SessionFactory.getCurrentSession</"
 "literal>, the <literal>CurrentSessionContext</literal> implementation "
 "configured for use controls the connection release mode for those "
-"<literal>Session</literal>s. See"
+"<literal>Session</literal>s. See <xref linkend=\"architecture-current-session"
+"\" />"
 msgstr ""
-"Note that this setting only affects <literal>Session</literal>s returned "
-"from <literal>SessionFactory.openSession</literal>. For <literal>Session</"
-"literal>s obtained through <literal>SessionFactory.getCurrentSession</"
-"literal>, the <literal>CurrentSessionContext</literal> implementation "
-"configured for use controls the connection release mode for those "
-"<literal>Session</literal>s. See"
+"Esta configuración sólamente afecta las <literal>Session</literal>es "
+"retornadas desde <literal>SessionFactory.openSession</literal>. Para las "
+"<literal>Session</literal>es obtenidas por medio de <literal>SessionFactory."
+"getCurrentSession</literal>, la implementación "
+"<literal>CurrentSessionContext</literal> configurada para utilización "
+"controla el modo de liberación de la conexión para esas <literal>Session</"
+"literal>es. Consulte <xref linkend=\"architecture-current-session\" />."
 
 #. Tag: entry
-#: configuration.xml:713
 #, no-c-format
 msgid ""
 "<property>hibernate.connection.</property><emphasis>&lt;propertyName&gt;</"
 "emphasis>"
-msgstr "hibernate.connection.<emphasis>&lt;propertyName&gt;</emphasis>"
+msgstr ""
+"<property>hibernate.connection.</property><emphasis>&lt;propertyName&gt;</"
+"emphasis>"
 
 #. Tag: entry
-#: configuration.xml:716
 #, no-c-format
 msgid ""
 "Pass the JDBC property <emphasis>&lt;propertyName&gt;</emphasis> to "
 "<literal>DriverManager.getConnection()</literal>."
 msgstr ""
-"Pasa la propiedad JDBC <literal>propertyName</literal> a "
+"Pasar la propiedad JDBC <emphasis>&lt;propertyName&gt;</emphasis> a "
 "<literal>DriverManager.getConnection()</literal>."
 
 #. Tag: entry
-#: configuration.xml:722
 #, no-c-format
 msgid ""
 "<property>hibernate.jndi.</property><emphasis>&lt;propertyName&gt;</emphasis>"
-msgstr "hibernate.jndi.<emphasis>&lt;propertyName&gt;</emphasis>"
+msgstr ""
+"<property>hibernate.jndi.</property><emphasis>&lt;propertyName&gt;</emphasis>"
 
 #. Tag: entry
-#: configuration.xml:725
 #, no-c-format
 msgid ""
 "Pass the property <emphasis>&lt;propertyName&gt;</emphasis> to the JNDI "
 "<literal>InitialContextFactory</literal>."
 msgstr ""
-"Pasa la propiedad <literal>propertyName</literal> a "
-"<literal>InitialContextFactory</literal> de JNDI."
+"Pasar la propiedad <emphasis>&lt;propertyName&gt;</emphasis> al "
+"<literal>InitialContextFactory</literal> JNDI."
 
 #. Tag: title
-#: configuration.xml:735
 #, no-c-format
 msgid "Hibernate Cache Properties"
-msgstr "Propiedades de Cach&#x00e9; de Hibernate"
+msgstr "Propiedades de Caché de Hibernate"
 
-#. Tag: literal
-#: configuration.xml:748
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.provider_class"
-msgstr "hibernate.cache.provider_class"
+msgid "<literal>hibernate.cache.provider_class</literal>"
+msgstr "<literal>hibernate.cache.provider_class</literal>"
 
 #. Tag: entry
-#: configuration.xml:750
 #, no-c-format
 msgid "The classname of a custom <literal>CacheProvider</literal>."
 msgstr ""
 "El nombre de clase de un <literal>CacheProvider</literal> personalizado."
 
 #. Tag: para
-#: configuration.xml:752
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "CacheProvider</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ej.</emphasis> <literal>classname.of."
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "CacheProvider</literal>"
 
-#. Tag: literal
-#: configuration.xml:760
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_minimal_puts"
-msgstr "hibernate.cache.use_minimal_puts"
+msgid "<literal>hibernate.cache.use_minimal_puts</literal>"
+msgstr "<literal>hibernate.cache.use_minimal_puts</literal>"
 
 #. Tag: entry
-#: configuration.xml:762
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Optimizes second-level cache operation to minimize writes, at the cost of "
 "more frequent reads. This setting is most useful for clustered caches and, "
 "in Hibernate3, is enabled by default for clustered cache implementations."
 msgstr ""
-"Optimiza la operaci&#x00f3;n del cach&#x00e9; de segundo nivel para "
-"minimizar escrituras, al costo de lecturas m&#x00e1;s frecuentes. Esto es "
-"m&#x00e1;s &#x00fa;til para cach&#x00e9;s en cluster y, en Hibernate3, "
-"est&#x00e1; habilitado por defecto para implementaciones de cach&#x00e9; en "
-"cluster."
+"Optimiza la operación del caché de segundo nivel para minimizar escrituras, "
+"con el costo de lecturas más frecuentes. Esta configuración es más útil para "
+"cachés en clúster y en Hibernate3, está habilitado por defecto para "
+"implementaciones de caché en clúster. "
 
-#. Tag: literal
-#: configuration.xml:775
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_query_cache"
-msgstr "hibernate.cache.use_query_cache"
+msgid "<literal>hibernate.cache.use_query_cache</literal>"
+msgstr "<literal>hibernate.cache.use_query_cache</literal>"
 
 #. Tag: entry
-#: configuration.xml:777
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Enables the query cache. Individual queries still have to be set cachable."
 msgstr ""
-"Habilita el cach&#x00e9; de lectura, consultas individuales todav&#x00ed;a "
-"tienen que ponerse cachables."
+"Habilita el caché de consultas. Las consultas individuales todavía tienen "
+"que establecerse con cachés. "
 
-#. Tag: literal
-#: configuration.xml:787
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_second_level_cache"
-msgstr "hibernate.cache.use_second_level_cache"
+msgid "<literal>hibernate.cache.use_second_level_cache</literal>"
+msgstr "<literal>hibernate.cache.use_second_level_cache</literal>"
 
 #. Tag: entry
-#: configuration.xml:789
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Can be used to completely disable the second level cache, which is enabled "
 "by default for classes which specify a <literal>&lt;cache&gt;</literal> "
 "mapping."
 msgstr ""
-"Puede ser usado para deshabilitar completamente el cach&#x00e9; de segundo "
-"nivel, que est&#x00e1; habilitado por defecto para clases que especifican un "
-"mapeo <literal>&lt;cache&gt;</literal>."
+"Se puede utilizar para deshabilitar por completo el caché de segundo nivel, "
+"que está habilitado por defecto para clases que especifican un mapeo "
+"<literal>&lt;cache&gt;</literal>. "
 
-#. Tag: literal
-#: configuration.xml:801
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.query_cache_factory"
-msgstr "hibernate.cache.query_cache_factory"
+msgid "<literal>hibernate.cache.query_cache_factory</literal>"
+msgstr "<literal>hibernate.cache.query_cache_factory</literal>"
 
 #. Tag: entry
-#: configuration.xml:803
 #, no-c-format
 msgid ""
 "The classname of a custom <literal>QueryCache</literal> interface, defaults "
 "to the built-in <literal>StandardQueryCache</literal>."
 msgstr ""
-"El nombre de clase de una interface <literal>QueryCache</literal> "
+"El nombre de clase de una interfaz <literal>QueryCache</literal> "
 "personalizada, por defecto al <literal>StandardQueryCache</literal> "
-"prefabricado."
+"incorporado."
 
 #. Tag: para
-#: configuration.xml:806
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of.QueryCache</"
 "literal>"
 msgstr ""
-"<emphasis role=\"strong\">ej.</emphasis> <literal>classname.of.QueryCache</"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of.QueryCache</"
 "literal>"
 
-#. Tag: literal
-#: configuration.xml:814
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.region_prefix"
-msgstr "hibernate.cache.region_prefix"
+msgid "<literal>hibernate.cache.region_prefix</literal>"
+msgstr "<literal>hibernate.cache.region_prefix</literal>"
 
 #. Tag: entry
-#: configuration.xml:816
 #, no-c-format
 msgid "A prefix to use for second-level cache region names."
 msgstr ""
-"Un prefijo a usar para los nombres de regi&#x00f3;n del cach&#x00e9; de "
+"Un prefijo que se debe utilizar para los nombres de región del caché de "
 "segundo nivel."
 
 #. Tag: para
-#: configuration.xml:818
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>prefix</literal>"
-msgstr "<emphasis role=\"strong\">ej.</emphasis> <literal>prefix</literal>"
+msgstr "<emphasis role=\"strong\">e.g.</emphasis> <literal>prefix</literal>"
 
-#. Tag: literal
-#: configuration.xml:826
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_structured_entries"
-msgstr "hibernate.cache.use_structured_entries"
+msgid "<literal>hibernate.cache.use_structured_entries</literal>"
+msgstr "<literal>hibernate.cache.use_structured_entries</literal>"
 
 #. Tag: entry
-#: configuration.xml:828
 #, no-c-format
 msgid ""
 "Forces Hibernate to store data in the second-level cache in a more human-"
 "friendly format."
 msgstr ""
-"Fuerza a Hibernate a almacenar los datos en el cach&#x00e9; de segundo nivel "
-"en un formato m&#x00e1;s amigable al humano."
+"Obliga a Hibernate a almacenar los datos en el caché de segundo nivel en un "
+"formato más amigable para personas."
 
 #. Tag: title
-#: configuration.xml:842
 #, no-c-format
 msgid "Hibernate Transaction Properties"
-msgstr "Propiedades de Transacci&#x00f3;n de Hibernate"
+msgstr "Propiedades de Transacción de Hibernate"
 
-#. Tag: literal
-#: configuration.xml:855
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.transaction.factory_class"
-msgstr "hibernate.transaction.factory_class"
+msgid "<literal>hibernate.transaction.factory_class</literal>"
+msgstr "<literal>hibernate.transaction.factory_class</literal>"
 
 #. Tag: entry
-#: configuration.xml:857
 #, no-c-format
 msgid ""
 "The classname of a <literal>TransactionFactory</literal> to use with "
 "Hibernate <literal>Transaction</literal> API (defaults to "
 "<literal>JDBCTransactionFactory</literal>)."
 msgstr ""
-"El nombre de clase de un <literal>TransactionFactory</literal> a usar con la "
-"API de <literal>Transaction</literal> de Hibernate (por defectoa "
+"El nombre de clase de un <literal>TransactionFactory</literal> a utilizar "
+"con la API de <literal>Transaction</literal> de Hibernate (por defecto es "
 "<literal>JDBCTransactionFactory</literal>)."
 
 #. Tag: para
-#: configuration.xml:861
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "TransactionFactory</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ej.</emphasis> <literal>classname.of."
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "TransactionFactory</literal>"
 
-#. Tag: literal
-#: configuration.xml:869
+#. Tag: entry
 #, no-c-format
-msgid "jta.UserTransaction"
-msgstr "jta.UserTransaction"
+msgid "<literal>jta.UserTransaction</literal>"
+msgstr "<literal>jta.UserTransaction</literal>"
 
 #. Tag: entry
-#: configuration.xml:871
 #, no-c-format
 msgid ""
 "A JNDI name used by <literal>JTATransactionFactory</literal> to obtain the "
 "JTA <literal>UserTransaction</literal> from the application server."
 msgstr ""
-"Un nombre JNDI usado por <literal>JTATransactionFactory</literal> para "
-"obtener la <literal>UserTransaction</literal> JTA del servidor de "
-"aplicaciones."
+"Un nombre JNDI utilizado por <literal>JTATransactionFactory</literal> para "
+"obtener la <literal>UserTransaction</literal> de JTA del servidor de "
+"aplicaciones. "
 
-#. Tag: literal
-#: configuration.xml:883
-#, no-c-format
-msgid "hibernate.transaction.manager_lookup_class"
-msgstr "hibernate.transaction.manager_lookup_class"
-
 #. Tag: entry
-#: configuration.xml:885
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.manager_lookup_class</literal>"
+msgstr "<literal>hibernate.transaction. manager_lookup_class</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "The classname of a <literal>TransactionManagerLookup</literal>. It is "
 "required when JVM-level caching is enabled or when using hilo generator in a "
 "JTA environment."
 msgstr ""
-"El nombre de clase de un <literal>TransactionManagerLookup</literal> "
-"requerido cuando el chach&#x00e9; a nivel de JVM est&#x00e1; habilitado o "
-"cuando se usa un generador alto/bajo en un entorno JTA."
+"El nombre de clase de un <literal>TransactionManagerLookup</literal>. Se "
+"requiere cuando el chaché a nivel de MVJ está habilitado o cuando se utiliza "
+"un generador alto/bajo en un entorno JTA."
 
 #. Tag: para
-#: configuration.xml:889
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "TransactionManagerLookup</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ej.</emphasis> <literal>classname.of."
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "TransactionManagerLookup</literal>"
 
-#. Tag: literal
-#: configuration.xml:897
-#, no-c-format
-msgid "hibernate.transaction.flush_before_completion"
-msgstr "hibernate.transaction.flush_before_completion"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.flush_before_completion</literal>"
+msgstr "<literal>hibernate.transaction. flush_before_completion</literal>"
 
 #. Tag: entry
-#: configuration.xml:899
 #, no-c-format
 msgid ""
 "If enabled, the session will be automatically flushed during the before "
 "completion phase of the transaction. Built-in and automatic session context "
-"management is preferred, see <xref linkend=\"architecture-current-session\"/"
+"management is preferred, see <xref linkend=\"architecture-current-session\" /"
 ">."
 msgstr ""
-"De habilitarse, la sesi&#x00f3;n se limpiar&#x00e1; (flushed) autom&#x00e1;"
-"ticamente durante la fase previa a la compleci&#x00f3;n de la "
-"transacci&#x00f3;n. (Muy &#x00fa;til cuando se usa Hibernate con CMT)."
+"Si está habilitado, la sesión se vaciará automáticamente durante la fase "
+"previa a la finalización de la transacción. Se prefiere la administración "
+"del contexto de sesión automático e incorporado. Consulte <xref linkend="
+"\"architecture-current-session\" />."
 
-#. Tag: literal
-#: configuration.xml:912
-#, no-c-format
-msgid "hibernate.transaction.auto_close_session"
-msgstr "hibernate.transaction.auto_close_session"
-
 #. Tag: entry
-#: configuration.xml:914
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.auto_close_session</literal>"
+msgstr "<literal>hibernate.transaction. auto_close_session</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "If enabled, the session will be automatically closed during the after "
 "completion phase of the transaction. Built-in and automatic session context "
-"management is preferred, see <xref linkend=\"architecture-current-session\"/"
+"management is preferred, see <xref linkend=\"architecture-current-session\" /"
 ">."
 msgstr ""
-"De habilitarse, la sesi&#x00f3;n ser&#x00e1; cerrada autom&#x00e1;ticamente "
-"durante la fase posterior a la compleci&#x00f3;n de la transacci&#x00f3;n. "
-"(Muy &#x00fa;til cuando se usa Hibernate con CMT)."
+"Si se habilita, la sesión se cerrará automáticamente durante la fase "
+"posterior a la finalización de la transacción. Se prefiere la administración "
+"del contexto de sesión automático e incorporado. Consulte <xref linkend="
+"\"architecture-current-session\" />."
 
 #. Tag: title
-#: configuration.xml:930
 #, no-c-format
 msgid "Miscellaneous Properties"
-msgstr "Propiedades Miscel&#x00e1;neas"
+msgstr "Propiedades Misceláneas"
 
-#. Tag: literal
-#: configuration.xml:943
-#, no-c-format
-msgid "hibernate.current_session_context_class"
-msgstr "hibernate.current_session_context_class"
-
 #. Tag: entry
-#: configuration.xml:945
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.current_session_context_class</literal>"
+msgstr "<literal>hibernate. current_session_context_class</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "Supply a custom strategy for the scoping of the \"current\" "
 "<literal>Session</literal>. See <xref linkend=\"architecture-current-session"
-"\"/> for more information about the built-in strategies."
+"\" /> for more information about the built-in strategies."
 msgstr ""
-"Supply a (custom) strategy for the scoping of the \"current\" "
-"<literal>Session</literal>. See <xref linkend=\"architecture-current-session"
-"\"/> for more information about the built-in strategies."
+"Proporciona una estrategia personalizada para el alcance de la "
+"<literal>Session</literal> \"actual\". Consulte <xref linkend=\"architecture-"
+"current-session\" /> para obtener más información sobre las estrategias "
+"incorporadas. "
 
 #. Tag: para
-#: configuration.xml:950
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>jta</literal> | "
 "<literal>thread</literal> | <literal>managed</literal> | <literal>custom."
 "Class</literal>"
 msgstr ""
-"<emphasis role=\"strong\">eg.</emphasis> <literal>jta</literal> | "
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>jta</literal> | "
 "<literal>thread</literal> | <literal>managed</literal> | <literal>custom."
 "Class</literal>"
 
-#. Tag: literal
-#: configuration.xml:959
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.query.factory_class"
-msgstr "hibernate.query.factory_class"
+msgid "<literal>hibernate.query.factory_class</literal>"
+msgstr "<literal>hibernate.query.factory_class</literal>"
 
 #. Tag: entry
-#: configuration.xml:961
 #, no-c-format
 msgid "Chooses the HQL parser implementation."
-msgstr "Elige la implementaci&#x00f3;n de parser HQL."
+msgstr "Elige la implementación de análisis sintáctico HQL."
 
 #. Tag: para
-#: configuration.xml:963
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>org.hibernate.hql.ast."
 "ASTQueryTranslatorFactory</literal> or <literal>org.hibernate.hql.classic."
 "ClassicQueryTranslatorFactory</literal>"
 msgstr ""
 "<emphasis role=\"strong\">ej.</emphasis> <literal>org.hibernate.hql.ast."
-"ASTQueryTranslatorFactory</literal> or <literal>org.hibernate.hql.classic."
+"ASTQueryTranslatorFactory</literal> o <literal>org.hibernate.hql.classic."
 "ClassicQueryTranslatorFactory</literal>"
 
-#. Tag: literal
-#: configuration.xml:972
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.query.substitutions"
-msgstr "hibernate.query.substitutions"
+msgid "<literal>hibernate.query.substitutions</literal>"
+msgstr "<literal>hibernate.query.substitutions</literal>"
 
 #. Tag: entry
-#: configuration.xml:974
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Is used to map from tokens in Hibernate queries to SQL tokens (tokens might "
 "be function or literal names, for example)."
 msgstr ""
-"Mapeos de s&#x00ed;mbolos en consultas Hibernate a s&#x00ed;mbolos SQL. (los "
-"s&#x00ed;mbolos puedem ser nombres de funci&#x00f3;n o literales, por "
-"ejemplo)."
+"Se utiliza para mapear desde tokens en consultas Hibernate a tokens SQL. "
+"(por ejemplo, los tokens pueden ser nombres de función o literales). "
 
 #. Tag: para
-#: configuration.xml:977
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>hqlLiteral=SQL_LITERAL, "
 "hqlFunction=SQLFUNC</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ej.</emphasis> <literal>hqlLiteral=SQL_LITERAL, "
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>hqlLiteral=SQL_LITERAL, "
 "hqlFunction=SQLFUNC</literal>"
 
-#. Tag: literal
-#: configuration.xml:985
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.hbm2ddl.auto"
-msgstr "hibernate.hbm2ddl.auto"
+msgid "<literal>hibernate.hbm2ddl.auto</literal>"
+msgstr "<literal>hibernate.hbm2ddl.auto</literal>"
 
 #. Tag: entry
-#: configuration.xml:987
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Automatically validates or exports schema DDL to the database when the "
 "<literal>SessionFactory</literal> is created. With <literal>create-drop</"
 "literal>, the database schema will be dropped when the "
 "<literal>SessionFactory</literal> is closed explicitly."
 msgstr ""
-"Exporta autom&#x00e1;ticamente DDL de esquema cuando al crear la "
-"<literal>SessionFactory</literal>. Con <literal>create-drop</literal>, el "
-"esquema de base de datos ser&#x00e1; desechado cuando la "
-"<literal>SessionFactory</literal> se cierre expl&#x00ed;citamente."
+"Exporta o valida automáticamente DDL de esquema a la base de datos cuando se "
+"crea la <literal>SessionFactory</literal>. Con <literal>create-drop</"
+"literal> se desechará el esquema de la base de datos cuando la "
+"<literal>SessionFactory</literal> se cierre explícitamente."
 
 #. Tag: para
-#: configuration.xml:993
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>validate</literal> | "
 "<literal>update</literal> | <literal>create</literal> | <literal>create-"
 "drop</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ej.</emphasis> <literal>update</literal> | "
-"<literal>create</literal> | <literal>create-drop</literal>"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>validate</literal> | "
+"<literal>update</literal> | <literal>create</literal> | <literal>create-"
+"drop</literal>"
 
-#. Tag: literal
-#: configuration.xml:1002
-#, no-c-format
-msgid "hibernate.cglib.use_reflection_optimizer"
-msgstr "hibernate.cglib.use_reflection_optimizer"
-
 #. Tag: entry
-#: configuration.xml:1004
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.cglib.use_reflection_optimizer</literal>"
+msgstr "<literal>hibernate.cglib. use_reflection_optimizer</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "Enables the use of CGLIB instead of runtime reflection (System-level "
 "property). Reflection can sometimes be useful when troubleshooting. "
 "Hibernate always requires CGLIB even if you turn off the optimizer. You "
 "cannot set this property in <literal>hibernate.cfg.xml</literal>."
 msgstr ""
-"Habilita el uso de CGLIB en vez de reflecc&#x00f3;n en tiempo de "
-"ejecuci&#x00f3;n (propiedad a nivel de sistema). La reflecci&#x00f3;n a "
-"veces puede ser &#x00fa;til ante la aparici&#x00f3;n de problemas. Observa "
-"que Hibernate siempre requiere CGLIB incluso si desactivas el optimizador. "
-"No puedes establecer esta propiedad en <literal>hibernate.cfg.xml</literal>."
+"Habilita el uso de CGLIB en vez de reflección en tiempo de ejecución "
+"(propiedad a nivel del sistema). La reflección a veces puede ser útil ante "
+"ciertos problemas. Hibernate siempre requiere CGLIB incluso si desactiva el "
+"optimizador. No puede establecer esta propiedad en <literal>hibernate.cfg."
+"xml</literal>."
 
 #. Tag: title
-#: configuration.xml:1020
 #, no-c-format
 msgid "SQL Dialects"
-msgstr "SQL Dialects"
+msgstr "Dialectos de SQL"
 
 #. Tag: para
-#: configuration.xml:1022
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Always set the <literal>hibernate.dialect</literal> property to the correct "
 "<literal>org.hibernate.dialect.Dialect</literal> subclass for your database. "
@@ -1706,315 +1448,265 @@
 "the other properties listed above. This means that you will not have to "
 "specify them manually."
 msgstr ""
-"You should always set the <literal>hibernate.dialect</literal> property to "
-"the correct <literal>org.hibernate.dialect.Dialect</literal> subclass for "
-"your database. If you specify a dialect, Hibernate will use sensible "
-"defaults for some of the other properties listed above, saving you the "
-"effort of specifying them manually."
+"Siempre configure la propiedad <literal>hibernate.dialect</literal> a la "
+"subclase correcta <literal>org.hibernate.dialect.Dialect</literal> para su "
+"base de datos. Si especifica un dialecto, Hibernate utilizará valores "
+"predeterminados de manera sensible para algunas de las otras propiedades "
+"enumeradas anteriormente, ahorrándole el esfuerzo de especificarlas "
+"manualmente."
 
 #. Tag: title
-#: configuration.xml:1030
 #, no-c-format
 msgid "Hibernate SQL Dialects (<literal>hibernate.dialect</literal>)"
 msgstr "Dialectos SQL de Hibernate(<literal>hibernate.dialect</literal>)"
 
 #. Tag: entry
-#: configuration.xml:1036
 #, no-c-format
 msgid "RDBMS"
 msgstr "RDBMS"
 
 #. Tag: entry
-#: configuration.xml:1037
 #, no-c-format
 msgid "Dialect"
 msgstr "Dialecto"
 
 #. Tag: entry
-#: configuration.xml:1042
 #, no-c-format
-msgid "<entry>DB2</entry>"
-msgstr "<entry>DB2</entry>"
+msgid "DB2"
+msgstr "DB2"
 
-#. Tag: literal
-#: configuration.xml:1042
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2Dialect"
-msgstr "org.hibernate.dialect.DB2Dialect"
+msgid "<literal>org.hibernate.dialect.DB2Dialect</literal>"
+msgstr "<literal>org.hibernate.dialect.DB2Dialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1045
 #, no-c-format
 msgid "DB2 AS/400"
 msgstr "DB2 AS/400"
 
-#. Tag: literal
-#: configuration.xml:1045
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2400Dialect"
-msgstr "org.hibernate.dialect.DB2400Dialect"
+msgid "<literal>org.hibernate.dialect.DB2400Dialect</literal>"
+msgstr "<literal>org.hibernate.dialect.DB2400Dialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1048
 #, no-c-format
 msgid "DB2 OS390"
 msgstr "DB2 OS390"
 
-#. Tag: literal
-#: configuration.xml:1048
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2390Dialect"
-msgstr "org.hibernate.dialect.DB2390Dialect"
+msgid "<literal>org.hibernate.dialect.DB2390Dialect</literal>"
+msgstr "<literal>org.hibernate.dialect.DB2390Dialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1051
 #, no-c-format
 msgid "PostgreSQL"
 msgstr "PostgreSQL"
 
-#. Tag: literal
-#: configuration.xml:1051
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.PostgreSQLDialect"
-msgstr "org.hibernate.dialect.PostgreSQLDialect"
+msgid "<literal>org.hibernate.dialect.PostgreSQLDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.PostgreSQLDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1054
 #, no-c-format
 msgid "MySQL"
 msgstr "MySQL"
 
-#. Tag: literal
-#: configuration.xml:1054
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLDialect"
-msgstr "org.hibernate.dialect.MySQLDialect"
+msgid "<literal>org.hibernate.dialect.MySQLDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MySQLDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1057
 #, no-c-format
 msgid "MySQL with InnoDB"
 msgstr "MySQL con InnoDB"
 
-#. Tag: literal
-#: configuration.xml:1057
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLInnoDBDialect"
-msgstr "org.hibernate.dialect.MySQLInnoDBDialect"
+msgid "<literal>org.hibernate.dialect.MySQLInnoDBDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MySQLInnoDBDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1060
 #, no-c-format
 msgid "MySQL with MyISAM"
 msgstr "MySQL con MyISAM"
 
-#. Tag: literal
-#: configuration.xml:1060
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLMyISAMDialect"
-msgstr "org.hibernate.dialect.MySQLMyISAMDialect"
+msgid "<literal>org.hibernate.dialect.MySQLMyISAMDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MySQLMyISAMDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1063
 #, no-c-format
 msgid "Oracle (any version)"
-msgstr "Oracle (cualquier versi&#x00f3;n)"
+msgstr "Oracle (cualquier versión)"
 
-#. Tag: literal
-#: configuration.xml:1063
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.OracleDialect"
-msgstr "org.hibernate.dialect.OracleDialect"
+msgid "<literal>org.hibernate.dialect.OracleDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.OracleDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1066
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Oracle 9i"
-msgstr "Oracle 9i/10g"
+msgstr "Oracle 9i"
 
-#. Tag: literal
-#: configuration.xml:1066
-#, fuzzy, no-c-format
-msgid "org.hibernate.dialect.Oracle9iDialect"
-msgstr "org.hibernate.dialect.Oracle9Dialect"
+#. Tag: entry
+#, no-c-format
+msgid "<literal>org.hibernate.dialect.Oracle9iDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.Oracle9iDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1069
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Oracle 10g"
-msgstr "Oracle 9i/10g"
+msgstr "Oracle 10g"
 
-#. Tag: literal
-#: configuration.xml:1069
-#, fuzzy, no-c-format
-msgid "org.hibernate.dialect.Oracle10gDialect"
-msgstr "org.hibernate.dialect.OracleDialect"
+#. Tag: entry
+#, no-c-format
+msgid "<literal>org.hibernate.dialect.Oracle10gDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.Oracle10gDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1072
 #, no-c-format
 msgid "Sybase"
 msgstr "Sybase"
 
-#. Tag: literal
-#: configuration.xml:1072
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SybaseDialect"
-msgstr "org.hibernate.dialect.SybaseDialect"
+msgid "<literal>org.hibernate.dialect.SybaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SybaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1075
 #, no-c-format
 msgid "Sybase Anywhere"
 msgstr "Sybase Anywhere"
 
-#. Tag: literal
-#: configuration.xml:1075
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SybaseAnywhereDialect"
-msgstr "org.hibernate.dialect.SybaseAnywhereDialect"
+msgid "<literal>org.hibernate.dialect.SybaseAnywhereDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SybaseAnywhereDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1078
 #, no-c-format
 msgid "Microsoft SQL Server"
 msgstr "Microsoft SQL Server"
 
-#. Tag: literal
-#: configuration.xml:1078
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SQLServerDialect"
-msgstr "org.hibernate.dialect.SQLServerDialect"
+msgid "<literal>org.hibernate.dialect.SQLServerDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SQLServerDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1081
 #, no-c-format
 msgid "SAP DB"
 msgstr "SAP DB"
 
-#. Tag: literal
-#: configuration.xml:1081
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SAPDBDialect"
-msgstr "org.hibernate.dialect.SAPDBDialect"
+msgid "<literal>org.hibernate.dialect.SAPDBDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SAPDBDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1084
 #, no-c-format
 msgid "Informix"
 msgstr "Informix"
 
-#. Tag: literal
-#: configuration.xml:1084
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.InformixDialect"
-msgstr "org.hibernate.dialect.InformixDialect"
+msgid "<literal>org.hibernate.dialect.InformixDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.InformixDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1087
 #, no-c-format
 msgid "HypersonicSQL"
 msgstr "HypersonicSQL"
 
-#. Tag: literal
-#: configuration.xml:1087
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.HSQLDialect"
-msgstr "org.hibernate.dialect.HSQLDialect"
+msgid "<literal>org.hibernate.dialect.HSQLDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.HSQLDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1090
 #, no-c-format
 msgid "Ingres"
 msgstr "Ingres"
 
-#. Tag: literal
-#: configuration.xml:1090
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.IngresDialect"
-msgstr "org.hibernate.dialect.IngresDialect"
+msgid "<literal>org.hibernate.dialect.IngresDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.IngresDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1093
 #, no-c-format
 msgid "Progress"
 msgstr "Progress"
 
-#. Tag: literal
-#: configuration.xml:1093
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.ProgressDialect"
-msgstr "org.hibernate.dialect.ProgressDialect"
+msgid "<literal>org.hibernate.dialect.ProgressDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.ProgressDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1096
 #, no-c-format
 msgid "Mckoi SQL"
 msgstr "Mckoi SQL"
 
-#. Tag: literal
-#: configuration.xml:1096
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MckoiDialect"
-msgstr "org.hibernate.dialect.MckoiDialect"
+msgid "<literal>org.hibernate.dialect.MckoiDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MckoiDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1099
 #, no-c-format
 msgid "Interbase"
 msgstr "Interbase"
 
-#. Tag: literal
-#: configuration.xml:1099
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.InterbaseDialect"
-msgstr "org.hibernate.dialect.InterbaseDialect"
+msgid "<literal>org.hibernate.dialect.InterbaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.InterbaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1102
 #, no-c-format
 msgid "Pointbase"
 msgstr "Pointbase"
 
-#. Tag: literal
-#: configuration.xml:1102
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.PointbaseDialect"
-msgstr "org.hibernate.dialect.PointbaseDialect"
+msgid "<literal>org.hibernate.dialect.PointbaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.PointbaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1105
 #, no-c-format
 msgid "FrontBase"
 msgstr "FrontBase"
 
-#. Tag: literal
-#: configuration.xml:1105
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.FrontbaseDialect"
-msgstr "org.hibernate.dialect.FrontbaseDialect"
+msgid "<literal>org.hibernate.dialect.FrontbaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.FrontbaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1108
 #, no-c-format
 msgid "Firebird"
 msgstr "Firebird"
 
-#. Tag: literal
-#: configuration.xml:1108
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.FirebirdDialect"
-msgstr "org.hibernate.dialect.FirebirdDialect"
+msgid "<literal>org.hibernate.dialect.FirebirdDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.FirebirdDialect</literal>"
 
 #. Tag: title
-#: configuration.xml:1117
 #, no-c-format
 msgid "Outer Join Fetching"
-msgstr "Recuperaci&#x00f3;n por Uni&#x00f3;n Externa (Outer Join Fetching)"
+msgstr "Recuperación por Unión Externa - Outer Join Fetching"
 
 #. Tag: para
-#: configuration.xml:1119
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your database supports ANSI, Oracle or Sybase style outer joins, "
 "<emphasis>outer join fetching</emphasis> will often increase performance by "
@@ -2024,18 +1716,15 @@
 "one, one-to-many, many-to-many and one-to-one associations to be retrieved "
 "in a single SQL <literal>SELECT</literal>."
 msgstr ""
-"Si tu base de datos soporta uniones externas del estilo ANSI, Oracle o "
-"Sybase, la <emphasis>recuperaci&#x00f3;n por uni&#x00f3;n externa</emphasis> "
-"aumentar&#x00e1; frecuentemente el rendimiento limitando el n&#x00fa;mero de "
-"llamadas a la base de datos (al costo de m&#x00e1;s trabajo posiblemente "
-"realizado por la base de datos misma). La recuperaci&#x00f3;n por uni&#x00f3;"
-"n externa permite que un grafo completo de objetos conectados por "
-"asociaciones muchos-a-uno, uno-a-muchos, muchos-a-muchos y uno-a-uno sea "
-"tra&#x00ed;do en una sola <literal>SELECT</literal> SQL."
+"Si su base de datos soporta uniones externas del estilo ANSI, Oracle o "
+"Sybase, frecuentemente la <emphasis>recuperación por unión externa</"
+"emphasis> aumentará el rendimiento limitando el número de llamadas a la base "
+"de datos. La recuperación por unión externa permite que un gráfico completo "
+"de objetos conectados por asociaciones muchos-a-uno, uno-a-muchos, muchos-a-"
+"muchos y uno-a-uno sea recuperado en un sólo <literal>SELECT</literal> SQL."
 
 #. Tag: para
-#: configuration.xml:1128
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Outer join fetching can be disabled <emphasis>globally</emphasis> by setting "
 "the property <literal>hibernate.max_fetch_depth</literal> to <literal>0</"
@@ -2043,30 +1732,27 @@
 "fetching for one-to-one and many-to-one associations that have been mapped "
 "with <literal>fetch=\"join\"</literal>."
 msgstr ""
-"La recuperaci&#x00f3;n por uni&#x00f3;n externa puede ser deshabilitada "
+"La recuperación por unión externa puede ser deshabilitada "
 "<emphasis>globalmente</emphasis> estableciendo la propiedad "
-"<literal>hibernate.max_fetch_depth</literal> a <literal>0</literal>. Un "
-"valor de <literal>1</literal> o mayor habilita la recuperaci&#x00f3;n por "
-"uni&#x00f3;n externa para asociaciones uno-a-uno y muchos-a-uno que hayan "
-"sido mapeadas con <literal>fetch=\"join\"</literal>."
+"<literal>hibernate.max_fetch_depth</literal> como <literal>0</literal>. Un "
+"valor de <literal>1</literal> o mayor habilita la recuperación por unión "
+"externa para asociaciones uno-a-uno y muchos-a-uno que hayan sido mapeadas "
+"con <literal>fetch=\"join\"</literal>."
 
 #. Tag: para
-#: configuration.xml:1136
 #, no-c-format
-msgid "See <xref linkend=\"performance-fetching\"/> for more information."
+msgid "See <xref linkend=\"performance-fetching\" /> for more information."
 msgstr ""
-"Ver <xref linkend=\"performance-fetching\"/> para m&#x00e1;s "
-"informaci&#x00f3;n."
+"Consulte <xref linkend=\"performance-fetching\" /> para obtener más "
+"información."
 
 #. Tag: title
-#: configuration.xml:1143
 #, no-c-format
 msgid "Binary Streams"
 msgstr "Flujos Binarios"
 
 #. Tag: para
-#: configuration.xml:1145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Oracle limits the size of <literal>byte</literal> arrays that can be passed "
 "to and/or from its JDBC driver. If you wish to use large instances of "
@@ -2074,88 +1760,66 @@
 "should enable <literal>hibernate.jdbc.use_streams_for_binary</literal>. "
 "<emphasis>This is a system-level setting only.</emphasis>"
 msgstr ""
-"Oracle limita el tama&#x00f1;o de arrays de <literal>byte</literal> que "
-"puedan ser pasados a/desde su driver JDBC. Si deseas usar instancias grandes "
-"de tipo <literal>binary</literal> o <literal>serializable</literal>, debes "
+"Oracle limita el tamaño de arrays de <literal>byte</literal> que se puedan "
+"pasar a/desde su controlador JDBC. Si desea utilizar instancias grandes de "
+"tipo <literal>binary</literal> o <literal>serializable</literal>, usted debe "
 "habilitar <literal>hibernate.jdbc.use_streams_for_binary</literal>. "
-"<emphasis>Esta es una propiedad a nivel de sistema solamente.</emphasis>"
+"<emphasis>Esta es una configuración a nivel de sistema sólamente.</emphasis>"
 
 #. Tag: title
-#: configuration.xml:1156
 #, no-c-format
 msgid "Second-level and query cache"
-msgstr "Cach&#x00e9; de segundo nivel y de lectura"
+msgstr "Caché de segundo nivel y de lectura"
 
 #. Tag: para
-#: configuration.xml:1158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The properties prefixed by <literal>hibernate.cache</literal> allow you to "
 "use a process or cluster scoped second-level cache system with Hibernate. "
-"See the <xref linkend=\"performance-cache\"/> for more information."
+"See the <xref linkend=\"performance-cache\" /> for more information."
 msgstr ""
-"Las propiedades prefijadas por <literal>hibernate.cache</literal> te "
-"permiten usar un sistema de cach&#x00e9; de segundo nivel en el &#x00e1;"
-"mbito de un proceso o cluster con Hibernate. Ver <xref linkend=\"performance-"
-"cache\"/> para m&#x00e1;s detalles."
+"Las propiedades prefijadas por <literal>hibernate.cache</literal> le "
+"permiten utilizar un sistema de caché de segundo nivel en el ámbito de un "
+"proceso o clúster con Hibernate. Vea la <xref linkend=\"performance-cache\" /"
+"> para obtener más detalles."
 
 #. Tag: title
-#: configuration.xml:1168
 #, no-c-format
 msgid "Query Language Substitution"
-msgstr "Sustituci&#x00f3;n de Lenguaje de Consulta"
+msgstr "Sustitución de Lenguaje de Consulta"
 
 #. Tag: para
-#: configuration.xml:1170
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can define new Hibernate query tokens using <literal>hibernate.query."
 "substitutions</literal>. For example:"
 msgstr ""
-"Puedes definir nuevos s&#x00ed;mbolos de consulta de Hibernate usando "
+"Puede definir nuevos tokens de consulta de Hibernate utilizando "
 "<literal>hibernate.query.substitutions</literal>. Por ejemplo:"
 
-#. Tag: programlisting
-#: configuration.xml:1175
-#, no-c-format
-msgid "hibernate.query.substitutions true=1, false=0"
-msgstr "hibernate.query.substitutions true=1, false=0"
-
 #. Tag: para
-#: configuration.xml:1177
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This would cause the tokens <literal>true</literal> and <literal>false</"
 "literal> to be translated to integer literals in the generated SQL."
 msgstr ""
-"causar&#x00ed;a que los s&#x00ed;mbolos <literal>true</literal> y "
-"<literal>false</literal> sean traducidos a literales enteros en el SQL "
-"generado."
+"Esto causaría que los tokens <literal>true</literal> y <literal>false</"
+"literal> sean traducidos a literales enteros en el SQL generado."
 
-#. Tag: programlisting
-#: configuration.xml:1182
-#, no-c-format
-msgid "hibernate.query.substitutions toLowercase=LOWER"
-msgstr "hibernate.query.substitutions toLowercase=LOWER"
-
 #. Tag: para
-#: configuration.xml:1184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This would allow you to rename the SQL <literal>LOWER</literal> function."
 msgstr ""
-"te permitir&#x00ed;a renombrar la funci&#x00f3;n <literal>LOWER</literal> de "
-"SQL."
+"Esto le permitiría renombrar la función <literal>LOWER</literal> de SQL."
 
 #. Tag: title
-#: configuration.xml:1191
 #, no-c-format
 msgid "Hibernate statistics"
-msgstr "Hibernate statistics"
+msgstr "Estadísticas de Hibernate"
 
 #. Tag: para
-#: configuration.xml:1193
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you enable <literal>hibernate.generate_statistics</literal>, Hibernate "
 "exposes a number of metrics that are useful when tuning a running system via "
@@ -2163,22 +1827,19 @@
 "configured to expose these statistics via JMX. Read the Javadoc of the "
 "interfaces in <literal>org.hibernate.stats</literal> for more information."
 msgstr ""
-"Si habilitas <literal>hibernate.generate_statistics</literal>, Hibernate "
-"expondr&#x00e1; un n&#x00fa;mero de m&#x00e9;tricas que son &#x00fa;tiles al "
-"afinar un sistema en ejecuci&#x00f3;n v&#x00ed;a <literal>SessionFactory."
-"getStatistics()</literal>. Hibernate puede incluso ser configurado para "
-"exponer estas estad&#x00ed;sticas v&#x00ed;a JMX. Lee el Javadoc de las "
-"interfaces en <literal>org.hibernate.stats</literal> para m&#x00e1;s "
-"informaci&#x00f3;n."
+"Si habilita <literal>hibernate.generate_statistics</literal>, Hibernate "
+"expondrá un número de métricas que son útiles al afinar un sistema en "
+"ejecución por medio de <literal>SessionFactory.getStatistics()</literal>. "
+"Incluso se puede configurar Hibernate para exponer estas estadísticas por "
+"medio de JMX. Lea el Javadoc de las interfaces en <literal>org.hibernate."
+"stats</literal> para obtener más información."
 
 #. Tag: title
-#: configuration.xml:1205
 #, no-c-format
 msgid "Logging"
 msgstr "Registros de mensajes (Logging)"
 
 #. Tag: para
-#: configuration.xml:1207
 #, no-c-format
 msgid ""
 "Hibernate utilizes <ulink url=\"http://www.slf4j.org/\">Simple Logging "
@@ -2194,10 +1855,22 @@
 "properties file is distributed with Hibernate in the <literal>src/</literal> "
 "directory."
 msgstr ""
+"Hibernate utiliza <ulink url=\"http://www.slf4j.org/\">Simple Logging Facade "
+"for Java</ulink> (SLF4J) con el fin de registrar varios eventos del sistema. "
+"SLF4J puede direccionar su salida de registro a varios marcos de trabajo de "
+"registro (NOP, Simple, log4j versión 1.2, JDK 1.4 logging, JCL o logback) "
+"dependiendo de su enlace escogido. Con el fin de configurar el registro "
+"necesitará <filename>slf4j-api.jar</filename> en su ruta de clase junto con "
+"el archivo jar para su enlace preferido - <filename>slf4j-log4j12.jar</"
+"filename> en el caso de Log4J. Consulte la <ulink url=\"http://www.slf4j.org/"
+"manual.html\">documentación</ulink> SLF4J para obtener mayores detalles. "
+"Para usar Log4j también necesitará poner un archivo <filename>log4j."
+"properties</filename> en su ruta de clase. Un archivo de propiedades de "
+"ejemplo se distribuye junto con Hibernate en el directorio <literal>src/</"
+"literal>."
 
 #. Tag: para
-#: configuration.xml:1218
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you familiarize yourself with Hibernate's log "
 "messages. A lot of work has been put into making the Hibernate log as "
@@ -2205,162 +1878,136 @@
 "troubleshooting device. The most interesting log categories are the "
 "following:"
 msgstr ""
-"Recomendamos fuertemente que te familiarices con los registros de mensajes "
-"de Hibernate. Se ha puesto un gran trabajo en hacer los registros de "
-"Hibernate tan detallados como se puede, sin hacerlos ilegibles. Es un "
-"dispositivo esencial en la resoluci&#x00f3;n de problemas. Las "
-"categor&#x00ed;as de registro m&#x00e1;s interesantes son las siguientes:"
+"Le recomendamos bastante que se familiarice con los mensajes de registro de "
+"Hibernate. Se ha trabajado bastante para hacer que los registros de "
+"Hibernate sean tan detallados como sea posible, sin hacerlos ilegibles. Es "
+"un dispositivo esencial en la resolución de problemas. Las categorías de "
+"registro más interesantes son las siguientes: "
 
 #. Tag: title
-#: configuration.xml:1227
 #, no-c-format
 msgid "Hibernate Log Categories"
-msgstr "Categor&#x00ed;as de Registro de Hibernate"
+msgstr "Categorías de Registro de Hibernate"
 
 #. Tag: entry
-#: configuration.xml:1233
 #, no-c-format
 msgid "Category"
-msgstr "Categor&#x00ed;a"
+msgstr "Categoría"
 
 #. Tag: entry
-#: configuration.xml:1234
 #, no-c-format
 msgid "Function"
-msgstr "Funci&#x00f3;n"
+msgstr "Función"
 
-#. Tag: literal
-#: configuration.xml:1239
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.SQL"
-msgstr "org.hibernate.SQL"
+msgid "<literal>org.hibernate.SQL</literal>"
+msgstr "<literal>org.hibernate.SQL</literal>"
 
 #. Tag: entry
-#: configuration.xml:1240
 #, no-c-format
 msgid "Log all SQL DML statements as they are executed"
-msgstr "Registra todas las sentencias DML de SQL a medida que se ejecutan"
+msgstr "Registra todas las declaraciones DML de SQL a medida que se ejecutan"
 
-#. Tag: literal
-#: configuration.xml:1243
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.type"
-msgstr "org.hibernate.type"
+msgid "<literal>org.hibernate.type</literal>"
+msgstr "<literal>org.hibernate.type</literal>"
 
 #. Tag: entry
-#: configuration.xml:1244
 #, no-c-format
 msgid "Log all JDBC parameters"
-msgstr "Registra todos los par&#x00e1;metros JDBC"
+msgstr "Registra todos los parámetros JDBC"
 
-#. Tag: literal
-#: configuration.xml:1247
-#, no-c-format
-msgid "org.hibernate.tool.hbm2ddl"
-msgstr "org.hibernate.tool.hbm2ddl"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.tool.hbm2ddl</literal>"
+msgstr "<literal>org.hibernate.tool. hbm2ddl</literal>"
 
 #. Tag: entry
-#: configuration.xml:1248
 #, no-c-format
 msgid "Log all SQL DDL statements as they are executed"
-msgstr "Registra todas las sentencias DDL de SQL a medida que se ejecutan"
+msgstr "Registra todas las declaraciones DDL de SQL a medida que se ejecutan"
 
-#. Tag: literal
-#: configuration.xml:1251
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.pretty"
-msgstr "org.hibernate.pretty"
+msgid "<literal>org.hibernate.pretty</literal>"
+msgstr "<literal>org.hibernate.pretty</literal>"
 
 #. Tag: entry
-#: configuration.xml:1252
 #, no-c-format
 msgid ""
 "Log the state of all entities (max 20 entities) associated with the session "
 "at flush time"
 msgstr ""
-"Registra el estado de todas las entidades (m&#x00e1;ximo de 20 entidades) "
-"asociadas con la sesi&#x00f3;n en tiempo de limpieza (flush)"
+"Registra el estado de todas las entidades (máximo 20 entidades) asociadas "
+"con la sesión en tiempo de limpieza (flush)"
 
-#. Tag: literal
-#: configuration.xml:1258
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.cache"
-msgstr "org.hibernate.cache"
+msgid "<literal>org.hibernate.cache</literal>"
+msgstr "<literal>org.hibernate.cache</literal>"
 
 #. Tag: entry
-#: configuration.xml:1259
 #, no-c-format
 msgid "Log all second-level cache activity"
-msgstr "Registra toda la actividad del cach&#x00e9; de segundo nivel"
+msgstr "Registra toda la actividad del caché de segundo nivel"
 
-#. Tag: literal
-#: configuration.xml:1262
-#, no-c-format
-msgid "org.hibernate.transaction"
-msgstr "org.hibernate.transaction"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.transaction</literal>"
+msgstr "<literal>org.hibernate. transaction</literal>"
 
 #. Tag: entry
-#: configuration.xml:1263
 #, no-c-format
 msgid "Log transaction related activity"
-msgstr "Registra la actividad relacionada con la transacci&#x00f3;n"
+msgstr "Registra la actividad relacionada con la transacción"
 
-#. Tag: literal
-#: configuration.xml:1266
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.jdbc"
-msgstr "org.hibernate.jdbc"
+msgid "<literal>org.hibernate.jdbc</literal>"
+msgstr "<literal>org.hibernate.jdbc</literal>"
 
 #. Tag: entry
-#: configuration.xml:1267
 #, no-c-format
 msgid "Log all JDBC resource acquisition"
-msgstr "Registra toda adquisici&#x00f3;n de recursos JDBC"
+msgstr "Registra toda adquisición de recursos JDBC"
 
-#. Tag: literal
-#: configuration.xml:1270
-#, no-c-format
-msgid "org.hibernate.hql.ast.AST"
-msgstr "org.hibernate.hql.ast"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.hql.ast.AST</literal>"
+msgstr "<literal>org.hibernate.hql. ast.AST</literal>"
 
 #. Tag: entry
-#: configuration.xml:1271
 #, no-c-format
 msgid "Log HQL and SQL ASTs during query parsing"
-msgstr ""
-"Regista los ASTs de HQL y SQL, as&#x00ed; como otra informaci&#x00f3;n sobre "
-"an&#x00e1;lisis de consultas."
+msgstr "Regista los ASTs de HQL y SQL, durante análisis de consultas."
 
-#. Tag: literal
-#: configuration.xml:1276
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.secure"
-msgstr "org.hibernate.secure"
+msgid "<literal>org.hibernate.secure</literal>"
+msgstr "<literal>org.hibernate.secure</literal>"
 
 #. Tag: entry
-#: configuration.xml:1277
 #, no-c-format
 msgid "Log all JAAS authorization requests"
-msgstr "Registra todas las peticiones de autorizaci&#x00f3;n JAAS"
+msgstr "Registra todas las peticiones de autorización JAAS"
 
-#. Tag: literal
-#: configuration.xml:1280
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate"
-msgstr "org.hibernate"
+msgid "<literal>org.hibernate</literal>"
+msgstr "<literal>org.hibernate</literal>"
 
 #. Tag: entry
-#: configuration.xml:1281
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Log everything. This is a lot of information but it is useful for "
 "troubleshooting"
 msgstr ""
-"Registra todo (mucha informaci&#x00f3;n, pero muy &#x00fa;til para la "
-"resoluci&#x00f3;n de problemas)"
+"Registra todo. Hay mucha información, pero es útil para la resolución de "
+"problemas"
 
 #. Tag: para
-#: configuration.xml:1290
 #, no-c-format
 msgid ""
 "When developing applications with Hibernate, you should almost always work "
@@ -2368,31 +2015,28 @@
 "hibernate.SQL</literal>, or, alternatively, the property <literal>hibernate."
 "show_sql</literal> enabled."
 msgstr ""
-"Al desarrollar aplicacinoes con Hibernate, casi siempre debes trabajar con "
-"<literal>debug</literal> habilitado para la categor&#x0ed;a <literal>org."
-"hibernate.SQL</literal> o, alternativamente, la propiedad <literal>hibernate."
-"show_sql</literal> habilitada."
+"Al desarrollar aplicaciones con Hibernate, casi siempre debe trabajar con "
+"<literal>debug</literal> habilitado para la categoría <literal>org.hibernate."
+"SQL</literal> o, alternativamente, la propiedad <literal>hibernate.show_sql</"
+"literal> habilitada."
 
 #. Tag: title
-#: configuration.xml:1300
 #, no-c-format
 msgid "Implementing a <literal>NamingStrategy</literal>"
-msgstr "Implementando una <literal>NamingStrategy</literal>"
+msgstr "Implementación de una <literal>NamingStrategy</literal>"
 
 #. Tag: para
-#: configuration.xml:1302
 #, no-c-format
 msgid ""
 "The interface <literal>org.hibernate.cfg.NamingStrategy</literal> allows you "
 "to specify a \"naming standard\" for database objects and schema elements."
 msgstr ""
-"La interface <literal>org.hibernate.cfg.NamingStrategy</literal> te permite "
-"especificar un \"est&#x00e1;ndar de nombrado\" para objetos de la base de "
-"datos y elementos de esquema."
+"La interfaz <literal>org.hibernate.cfg.NamingStrategy</literal> le permite "
+"especificar un \"estándar de nombrado\" para objetos de la base de datos y "
+"los elementos del esquema."
 
 #. Tag: para
-#: configuration.xml:1307
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can provide rules for automatically generating database identifiers from "
 "Java identifiers or for processing \"logical\" column and table names given "
@@ -2401,60 +2045,39 @@
 "noise (<literal>TBL_</literal> prefixes, for example). The default strategy "
 "used by Hibernate is quite minimal."
 msgstr ""
-"Puedes proveer reglas para generar autom&#x00e1;ticamente identificadores de "
-"base de datos a partir de identificadores JDBC o para procesar nombres "
-"\"l&#x00f3;gicos\" de columnas y tablas dados en el fichero de mapeo en "
-"nombres \"f&#x00ed;sicos\" de columnas y tablas. Esta funcionalidad ayuda a "
-"reducir la verborragia del documento de mapeo, eliminando ruido repetitivo "
-"(prefijos <literal>TBL_</literal>, por ejemplo). La estrategia por defecto "
-"usada por Hibernate m&#x00ed;nima en absoluto."
+"Puede proveer reglas para generar automáticamente identificadores de la base "
+"de datos a partir de identificadores JDBC o para procesar nombres \"lógicos"
+"\" de columnas y tablas dadas en el archivo de mapeo en nombres \"físicos\" "
+"de columnas y tablas. Esta funcionalidad ayuda a reducir la verborragia del "
+"documento de mapeo, eliminando ruidos repetitivos (por ejemplo, prefijos "
+"<literal>TBL_</literal>). Hibernate utiliza una estrategia por defecto "
+"bastante mínima."
 
 #. Tag: para
-#: configuration.xml:1316
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can specify a different strategy by calling <literal>Configuration."
 "setNamingStrategy()</literal> before adding mappings:"
 msgstr ""
-"Puedes especificar una estrategia diferente llamando a "
-"<literal>Configuration.setNamingStrategy()</literal> antes de agregar los "
-"mapeos:"
+"Puede especificar una estrategia diferente llamando a <literal>Configuration."
+"setNamingStrategy()</literal> antes de agregar los mapeos:"
 
-#. Tag: programlisting
-#: configuration.xml:1321
-#, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration()\n"
-"    .setNamingStrategy(ImprovedNamingStrategy.INSTANCE)\n"
-"    .addFile(\"Item.hbm.xml\")\n"
-"    .addFile(\"Bid.hbm.xml\")\n"
-"    .buildSessionFactory();]]>"
-msgstr ""
-"<![CDATA[SessionFactory sf = new Configuration()\n"
-"    .setNamingStrategy(ImprovedNamingStrategy.INSTANCE)\n"
-"    .addFile(\"Item.hbm.xml\")\n"
-"    .addFile(\"Bid.hbm.xml\")\n"
-"    .buildSessionFactory();]]>"
-
 #. Tag: para
-#: configuration.xml:1323
 #, no-c-format
 msgid ""
 "<literal>org.hibernate.cfg.ImprovedNamingStrategy</literal> is a built-in "
 "strategy that might be a useful starting point for some applications."
 msgstr ""
 "<literal>org.hibernate.cfg.ImprovedNamingStrategy</literal> es una "
-"estrategia prefabricada que puede ser un punto de partida &#x00fa;til para "
-"algunas aplicaciones."
+"estrategia incorporada que puede ser un punto de partida útil para algunas "
+"aplicaciones."
 
 #. Tag: title
-#: configuration.xml:1331
 #, no-c-format
 msgid "XML configuration file"
-msgstr "Fichero de configuraci&#x00f3;n XML"
+msgstr "Archivo de configuración XML"
 
 #. Tag: para
-#: configuration.xml:1333
 #, no-c-format
 msgid ""
 "An alternative approach to configuration is to specify a full configuration "
@@ -2462,108 +2085,24 @@
 "as a replacement for the <literal>hibernate.properties</literal> file or, if "
 "both are present, to override properties."
 msgstr ""
-"Un enfoque alternativo de configuraci&#x00f3;n es especificar una "
-"configuraci&#x00f3;n completa en un fichero llamado <literal>hibernate.cfg."
-"xml</literal>. Este fichero puede ser usado como un remplazo del fichero "
-"<literal>hibernate.properties</literal> o, si ambos est&#x00e1;n presentes, "
-"para sobrescribir propiedades."
+"Un enfoque alternativo de configuración es especificar una configuración "
+"completa en un archivo llamado <literal>hibernate.cfg.xml</literal>. Este "
+"archivo se puede utilizar como un remplazo del archivo <literal>hibernate."
+"properties</literal> o en el caso de que ambos se encuentren presentes, para "
+"sobrescribir propiedades."
 
 #. Tag: para
-#: configuration.xml:1340
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The XML configuration file is by default expected to be in the root of your "
 "<literal>CLASSPATH</literal>. Here is an example:"
 msgstr ""
-"El fichero de configuraci&#x00f3;n XML se espera por defecto en la ra&#x00ed;"
-"z o tu <literal>CLASSPATH</literal>. He aqu&#x00ed; un ejemplo:"
+"El archivo de configuración XML por defecto se espera en la raíz de su "
+"<literal>CLASSPATH</literal>. Este es un ejemplo:"
 
-#. Tag: programlisting
-#: configuration.xml:1345
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-"<!DOCTYPE hibernate-configuration PUBLIC\n"
-"    \"-//Hibernate/Hibernate Configuration DTD//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd\">\n"
-"\n"
-"<hibernate-configuration>\n"
-"\n"
-"    <!-- a SessionFactory instance listed as /jndi/name -->\n"
-"    <session-factory\n"
-"        name=\"java:hibernate/SessionFactory\">\n"
-"\n"
-"        <!-- properties -->\n"
-"        <property name=\"connection.datasource\">java:/comp/env/jdbc/MyDB</"
-"property>\n"
-"        <property name=\"dialect\">org.hibernate.dialect.MySQLDialect</"
-"property>\n"
-"        <property name=\"show_sql\">false</property>\n"
-"        <property name=\"transaction.factory_class\">\n"
-"            org.hibernate.transaction.JTATransactionFactory\n"
-"        </property>\n"
-"        <property name=\"jta.UserTransaction\">java:comp/UserTransaction</"
-"property>\n"
-"\n"
-"        <!-- mapping files -->\n"
-"        <mapping resource=\"org/hibernate/auction/Item.hbm.xml\"/>\n"
-"        <mapping resource=\"org/hibernate/auction/Bid.hbm.xml\"/>\n"
-"\n"
-"        <!-- cache settings -->\n"
-"        <class-cache class=\"org.hibernate.auction.Item\" usage=\"read-write"
-"\"/>\n"
-"        <class-cache class=\"org.hibernate.auction.Bid\" usage=\"read-only\"/"
-">\n"
-"        <collection-cache collection=\"org.hibernate.auction.Item.bids\" "
-"usage=\"read-write\"/>\n"
-"\n"
-"    </session-factory>\n"
-"\n"
-"</hibernate-configuration>]]>"
-msgstr ""
-"<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-"<!DOCTYPE hibernate-configuration PUBLIC\n"
-"    \"-//Hibernate/Hibernate Configuration DTD//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd\">\n"
-"\n"
-"<hibernate-configuration>\n"
-"\n"
-"    <!-- a SessionFactory instance listed as /jndi/name -->\n"
-"    <session-factory\n"
-"        name=\"java:hibernate/SessionFactory\">\n"
-"\n"
-"        <!-- properties -->\n"
-"        <property name=\"connection.datasource\">java:/comp/env/jdbc/MyDB</"
-"property>\n"
-"        <property name=\"dialect\">org.hibernate.dialect.MySQLDialect</"
-"property>\n"
-"        <property name=\"show_sql\">false</property>\n"
-"        <property name=\"transaction.factory_class\">\n"
-"            org.hibernate.transaction.JTATransactionFactory\n"
-"        </property>\n"
-"        <property name=\"jta.UserTransaction\">java:comp/UserTransaction</"
-"property>\n"
-"\n"
-"        <!-- mapping files -->\n"
-"        <mapping resource=\"org/hibernate/auction/Item.hbm.xml\"/>\n"
-"        <mapping resource=\"org/hibernate/auction/Bid.hbm.xml\"/>\n"
-"\n"
-"        <!-- cache settings -->\n"
-"        <class-cache class=\"org.hibernate.auction.Item\" usage=\"read-write"
-"\"/>\n"
-"        <class-cache class=\"org.hibernate.auction.Bid\" usage=\"read-only\"/"
-">\n"
-"        <collection-cache collection=\"org.hibernate.auction.Item.bids\" "
-"usage=\"read-write\"/>\n"
-"\n"
-"    </session-factory>\n"
-"\n"
-"</hibernate-configuration>]]>"
-
-#. Tag: para
-#: configuration.xml:1347
-#, fuzzy, no-c-format
-msgid ""
 "The advantage of this approach is the externalization of the mapping file "
 "names to configuration. The <literal>hibernate.cfg.xml</literal> is also "
 "more convenient once you have to tune the Hibernate cache. It is your choice "
@@ -2571,65 +2110,38 @@
 "cfg.xml</literal>. Both are equivalent, except for the above mentioned "
 "benefits of using the XML syntax."
 msgstr ""
-"Como puedes ver, la ventaja de este enfoque es la externalizaci&#x00f3;n de "
-"los nombres de los fichero de mapeo a configuraci&#x00f3;n. El "
-"<literal>hibernate.cfg.xml</literal> es tambi&#x00e9;n m&#x00e1;s "
-"conveniente una vez que hayas afinado el cach&#x00e9; de Hibernate. Observa "
-"que elecci&#x00f3;n tuya usar ya sea <literal>hibernate.properties</literal> "
-"o <literal>hibernate.cfg.xml</literal>, ambos son equivalentes, excepto por "
-"los beneficios de usar la sintaxis XML arriba mencionados."
+"La ventaja de este enfoque es la externalización de los nombres de los "
+"archivos de mapeo a la configuración. El <literal>hibernate.cfg.xml</"
+"literal> también es más práctico una vez que haya afinado el caché de "
+"Hibernate. Puede escoger ya sea <literal>hibernate.properties</literal> o "
+"<literal>hibernate.cfg.xml</literal>. Ambos son equivalentes, excepto por "
+"los beneficios de utilizar la sintaxis XML que mencionados anteriormente."
 
 #. Tag: para
-#: configuration.xml:1356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "With the XML configuration, starting Hibernate is then as simple as:"
-msgstr "Con la configuraci&#x00f3;n XML, arrancar Hibernate es tan simple como"
+msgstr "Con la configuración XML, iniciar Hibernate es tan simple como:"
 
-#. Tag: programlisting
-#: configuration.xml:1360
-#, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration().configure()."
-"buildSessionFactory();]]>"
-msgstr ""
-"<![CDATA[SessionFactory sf = new Configuration().configure()."
-"buildSessionFactory();]]>"
-
 #. Tag: para
-#: configuration.xml:1362
-#, fuzzy, no-c-format
-msgid "You can select a different XML configuration file using:"
-msgstr "Puedes tomar un fichero XML diferente usando"
-
-#. Tag: programlisting
-#: configuration.xml:1366
 #, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration()\n"
-"    .configure(\"catdb.cfg.xml\")\n"
-"    .buildSessionFactory();]]>"
+msgid "You can select a different XML configuration file using:"
 msgstr ""
-"<![CDATA[SessionFactory sf = new Configuration()\n"
-"    .configure(\"catdb.cfg.xml\")\n"
-"    .buildSessionFactory();]]>"
+"Puede seleccionar un fichero de configuración XML diferente utilizando:"
 
 #. Tag: title
-#: configuration.xml:1371
 #, no-c-format
 msgid "J2EE Application Server integration"
-msgstr "Integraci&#x00f3; con Servidores de Aplicaciones J2EE"
+msgstr "Integración con Servidores de Aplicaciones J2EE"
 
 #. Tag: para
-#: configuration.xml:1373
 #, no-c-format
 msgid "Hibernate has the following integration points for J2EE infrastructure:"
 msgstr ""
-"Hibernate tiene los siguientes puntos de integraci&#x00f3;n con la "
-"infraestructura J2EE:"
+"Hibernate tiene los siguientes puntos de integración con la infraestructura "
+"J2EE:"
 
 #. Tag: para
-#: configuration.xml:1379
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Container-managed datasources</emphasis>: Hibernate can use JDBC "
 "connections managed by the container and provided through JNDI. Usually, a "
@@ -2640,30 +2152,27 @@
 "(BMT), or you might want to use the optional Hibernate <literal>Transaction</"
 "literal> API for this to keep your code portable."
 msgstr ""
-"<emphasis>Datasources manejados por contenedor</emphasis>: Hibernate puede "
-"usar conexiones JDBC manejadas por el contenedor y provistas a trav&#x00e9;s "
-"de JNDI. Usualmente, un <literal>TransactionManager</literal> compatible con "
-"JTA y un <literal>ResourceManager</literal> cuidan del manejo de "
-"transacciones (CMT), esp. manejo de transacciones distribu&#x00ed;das a "
-"trav&#x00e9;s de varios datasources. Puedes tambi&#x00e9;n, por supuesto, "
-"demarcar los l&#x00ed;mites de las transacciones program&#x00e1;ticamente "
-"(BMT) o podr&#x00ed;as querer usar para esto la API opcional de "
-"<literal>Transaction</literal> de Hibernate para mantener tu c&#x00f3;digo "
-"portable."
+"<emphasis>Fuentes de datos administrados por el contenedor</emphasis>: "
+"Hibernate puede utilizar conexiones JDBC administradas por el contenedor y "
+"provistas a través de JNDI. Usualmente, un <literal>TransactionManager</"
+"literal> compatible con JTA y un <literal>ResourceManager</literal> se "
+"ocupan de la administración de transacciones (CMT), especialmente del manejo "
+"de transacciones distribuídas a través de varias fuentes de datos. También "
+"puede demarcar los límites de las transacciones programáticamente (BMT) o "
+"puede que quiera utilizar para esto la API opcional de <literal>Transaction</"
+"literal> de Hibernate para mantener portátil su código."
 
 #. Tag: para
-#: configuration.xml:1394
 #, no-c-format
 msgid ""
 "<emphasis>Automatic JNDI binding</emphasis>: Hibernate can bind its "
 "<literal>SessionFactory</literal> to JNDI after startup."
 msgstr ""
-"<emphasis>Ligamento Autom&#x00e1;tico JNDI</emphasis>: Hibernate puede ligar "
-"sus <literal>SessionFactory</literal> a JNDI despu&#x00e9;s del arranque."
+"<emphasis>Vinculación Automática JNDI</emphasis>: Hibernate puede vincular "
+"sus <literal>SessionFactory</literal> a JNDI después del inicio."
 
 #. Tag: para
-#: configuration.xml:1403
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>JTA Session binding:</emphasis> the Hibernate <literal>Session</"
 "literal> can be automatically bound to the scope of JTA transactions. Simply "
@@ -2673,18 +2182,16 @@
 "demarcation is either declarative (CMT) or programmatic (BMT/"
 "UserTransaction)."
 msgstr ""
-"<emphasis>Ligamento de Sesi&#x00f3;n JTA:</emphasis> La <literal>Session</"
-"literal> de Hibernate puede ser ligada autom&#x00e1;ticamente al &#x00e1;"
-"mbito de transacciones JTA si usas EJBs. Simplemente busca la "
-"<literal>SessionFactory</literal> de JNDI y obt&#x00e9;n la "
-"<literal>Session</literal> actual. Deja que Hibernate cuide de limpiar y "
-"cerrar la <literal>Session</literal> cuando se complete tu transacci&#x00f3;"
-"n JTA. La demarcaci&#x00f3;n de transacci&#x00f3;n es declarativa, en "
-"descriptores de despliegue de EJB."
+"<emphasis>Vinculación de Sesión JTA:</emphasis> La <literal>Session</"
+"literal> de Hibernate se puede vincular automáticamente al ámbito de "
+"transacciones JTA. Simplemente busque la <literal>SessionFactory</literal> "
+"de JNDI y obténga la <literal>Session</literal> actual. Deje que Hibernate "
+"se ocupe de vaciar y cerrar la <literal>Session</literal> cuando se complete "
+"su transacción JTA. La demarcación de transacción puede ser declarativa "
+"(CMT) o programática (BMT/UserTransaction)."
 
 #. Tag: para
-#: configuration.xml:1416
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>JMX deployment:</emphasis> if you have a JMX capable application "
 "server (e.g. JBoss AS), you can choose to deploy Hibernate as a managed "
@@ -2694,37 +2201,34 @@
 "take care of service dependencies (datasource has to be available before "
 "Hibernate starts, etc)."
 msgstr ""
-"<emphasis>Despliegue JMX:</emphasis> Si tienes un servidor de aplicaciones "
-"capaz de JMX (por ejemplo, JBoss AS), puedes optar por desplegar Hibernate "
-"como un MBean manejado. Esto te ahorra el c&#x00f3;digo de una l&#x00ed;nea "
-"de arranque para construir tu <literal>SessionFactory</literal> desde una "
-"<literal>Configuration</literal>. El contenedor arrancar&#x00e1; tu "
-"<literal>HibernateService</literal>, e idealmente tambi&#x00e9;n "
-"cuidar&#x00e1; de las dependencias entre servicios (El datasource debe estar "
-"disponible antes que arranque Hibernate, etc)."
+"<emphasis>Despliegue JMX:</emphasis> Si tiene un servidor de aplicaciones "
+"con capacidad para JMX (por ejemplo, JBoss AS), puede escoger el desplegar "
+"Hibernate como un MBean administrado. Esto le ahorra el código de una línea "
+"de inicio para construir su <literal>SessionFactory</literal> desde una "
+"<literal>Configuration</literal>. El contenedor iniciará su "
+"<literal>HibernateService</literal>, e idealmente también cuidará de las "
+"dependencias entre servicios (la fuente de datos debe estar disponible antes "
+"de que Hibernate inicie, etc)."
 
 #. Tag: para
-#: configuration.xml:1427
 #, no-c-format
 msgid ""
 "Depending on your environment, you might have to set the configuration "
 "option <literal>hibernate.connection.aggressive_release</literal> to true if "
 "your application server shows \"connection containment\" exceptions."
 msgstr ""
-"Dependiendo de tu entorno, podr&#x00ed;as tener que establecer la "
-"opci&#x00f3;n de configuraci&#x00f3;n <literal>hibernate.connection."
-"aggressive_release</literal> a true si tu servidor de aplicaciones muestra "
-"excepciones \"connection containment\"."
+"Dependiendo de su entorno, podría tener que establecer la opción de "
+"configuración <literal>hibernate.connection.aggressive_release</literal> "
+"como true si su servidor de aplicaciones muestra excepciones \"contención de "
+"conexión\"."
 
 #. Tag: title
-#: configuration.xml:1434
 #, no-c-format
 msgid "Transaction strategy configuration"
-msgstr "Configuraci&#x00f3;n de la estrategia de transacci&#x00f3;n"
+msgstr "Configuración de la estrategia de transacción"
 
 #. Tag: para
-#: configuration.xml:1436
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The Hibernate <literal>Session</literal> API is independent of any "
 "transaction demarcation system in your architecture. If you let Hibernate "
@@ -2734,15 +2238,14 @@
 "and <literal>UserTransaction</literal> when needed."
 msgstr ""
 "La API de <literal>Session</literal> de Hibernate es independiente de "
-"cualquier demarcaci&#x00f3;n de transacci&#x00f3;n en tu arquitectura. Si "
-"dejas que Hibernate use JDBC directamente, a trav&#x00e9;s de un pool de "
-"conexiones. puedes comenzar y acabar tus transacciones llamando la API de "
-"JDBC. Si ejecutas en un servidor de aplicaciones J2EE, podr&#x00e9;as querer "
-"usar transacciones manejadas por bean y llamar la API de JTA y "
+"cualquier demarcación de transacción en su arquitectura. Si deja que "
+"Hibernate utilice JDBC directamente, a través de un pool de conexiones, "
+"puede comenzar y acabar sus transacciones llamando la API de JDBC. Si "
+"ejecuta en un servidor de aplicaciones J2EE, puede que quiera utilizar "
+"transacciones administradas por bean y llamar la API de JTA y "
 "<literal>UserTransaction</literal> cuando sea necesario."
 
 #. Tag: para
-#: configuration.xml:1444
 #, no-c-format
 msgid ""
 "To keep your code portable between these two (and other) environments we "
@@ -2752,75 +2255,66 @@
 "configuration property <literal>hibernate.transaction.factory_class</"
 "literal>."
 msgstr ""
-"Para mantener tu c&#x00f3;digo portable entre estos dos (y otros) entornos "
+"Para mantener su código portable entre estos dos (y otros) entornos le "
 "recomendamos la API de <literal>Transaction</literal> de Hibernate, que "
-"envuelve y oculta el sistema subyacente. Tienes que especificar una clase "
-"f&#x00e1;brica para las instancias de <literal>Transaction</literal> "
-"estableciendo la propiedad de configuraci&#x00f3;n <literal>hibernate."
-"transaction.factory_class</literal> de Hibernate."
+"envuelve y oculta el sistema subyacente. Tiene que especificar una clase "
+"fábrica para las instancias de <literal>Transaction</literal> estableciendo "
+"la propiedad de configuración <literal>hibernate.transaction.factory_class</"
+"literal> de Hibernate."
 
 #. Tag: para
-#: configuration.xml:1451
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "There are three standard, or built-in, choices:"
-msgstr "Hay tres elecciones est&#x00e1;ndar (prefabricadas):"
+msgstr "Existen tres opciones estándares o incorporadas:"
 
-#. Tag: literal
-#: configuration.xml:1457
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.JDBCTransactionFactory"
-msgstr "org.hibernate.transaction.JDBCTransactionFactory"
+msgid "<literal>org.hibernate.transaction.JDBCTransactionFactory</literal>"
+msgstr "<literal>org.hibernate.transaction.JDBCTransactionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1459
 #, no-c-format
 msgid "delegates to database (JDBC) transactions (default)"
-msgstr "delega a transacciones de base de datos (JDBC) (por defecto)"
+msgstr "delega a transacciones de bases de datos (JDBC) (por defecto)"
 
-#. Tag: literal
-#: configuration.xml:1463
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.JTATransactionFactory"
-msgstr "org.hibernate.transaction.JTATransactionFactory"
+msgid "<literal>org.hibernate.transaction.JTATransactionFactory</literal>"
+msgstr "<literal>org.hibernate.transaction.JTATransactionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1465
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "delegates to container-managed transactions if an existing transaction is "
 "underway in this context (for example, EJB session bean method). Otherwise, "
 "a new transaction is started and bean-managed transactions are used."
 msgstr ""
-"delega a transacciones manejadas por contenedor si una transacci&#x00f3;n "
-"existente est&#x00f3; por debajo en este contexto (ej. m&#x00e9;todo de un "
-"bean de sesi&#x00f3;n EJB), en otro caso una nueva transacci&#x00f3;n es "
-"comenzada y se usan transacciones manejadas por bean."
+"delega a transacciones administradas por el contenedor si una transacción "
+"existente se encuentra en proceso en este contexto (por ejemplo, un método "
+"de bean de sesión EJB). De otra manera, se inicia una nueva transacción y se "
+"utilizan las transacciones administradas por bean."
 
-#. Tag: literal
-#: configuration.xml:1473
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.CMTTransactionFactory"
-msgstr "org.hibernate.transaction.CMTTransactionFactory"
+msgid "<literal>org.hibernate.transaction.CMTTransactionFactory</literal>"
+msgstr "<literal>org.hibernate.transaction.CMTTransactionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1475
 #, no-c-format
 msgid "delegates to container-managed JTA transactions"
-msgstr "delega a transacciones JTA manejadas por contenedor"
+msgstr "delega a transacciones JTA administradas por el contenedor"
 
 #. Tag: para
-#: configuration.xml:1480
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also define your own transaction strategies (for a CORBA transaction "
 "service, for example)."
 msgstr ""
-"Puedes definir tambi&#x00e9;n tus propias estrategias de transacci&#x00f3;n "
-"(para un servicio de transacci&#x00f3;n CORBA, por ejemplo)."
+"También puede definir sus propias estrategias de transacción (por ejemplo, "
+"para un servicio de transacción CORBA)."
 
 #. Tag: para
-#: configuration.xml:1485
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Some features in Hibernate (i.e., the second level cache, Contextual "
 "Sessions with JTA, etc.) require access to the JTA "
@@ -2829,175 +2323,174 @@
 "have to specify how Hibernate should obtain a reference to the "
 "<literal>TransactionManager</literal>:"
 msgstr ""
-"Algunas funcionalidades en Hibernate (ej, el cach&#x00e9; de segundo nivel, "
-"ligamento autom&#x00e1;tico de JTA y Session, etc.) requieren acceso al "
-"<literal>TransactionManager</literal> de JTA en un entorno manejado. En un "
-"servidor de aplicaciones tienes que especificar c&#x00f3;mo Hibernate debe "
-"obtener una referencia al <literal>TransactionManager</literal>, pues J2EE "
-"no estandariza un solo mecanismo:"
+"Algunas funcionalidades en Hibernate (por ejemplo, el caché de segundo "
+"nivel, las sesiones contextuales, etc.) requieren acceso al "
+"<literal>TransactionManager</literal> de JTA en un entorno administrado. En "
+"un servidor de aplicaciones tiene que especificar cómo Hibernate debe "
+"obtener una referencia al <literal>TransactionManager</literal>, ya que J2EE "
+"no estandariza un sólo mecanismo:"
 
 #. Tag: title
-#: configuration.xml:1493
 #, no-c-format
 msgid "JTA TransactionManagers"
 msgstr "TransactionManagers de JTA"
 
 #. Tag: entry
-#: configuration.xml:1499
 #, no-c-format
 msgid "Transaction Factory"
 msgstr "Transaction Factory"
 
 #. Tag: entry
-#: configuration.xml:1500
 #, no-c-format
 msgid "Application Server"
 msgstr "Servidor de Aplicaciones"
 
-#. Tag: literal
-#: configuration.xml:1505
-#, no-c-format
-msgid "org.hibernate.transaction.JBossTransactionManagerLookup"
-msgstr "org.hibernate.transaction.JBossTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JBossTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JBossTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1506
 #, no-c-format
 msgid "JBoss"
 msgstr "JBoss"
 
-#. Tag: literal
-#: configuration.xml:1509
-#, no-c-format
-msgid "org.hibernate.transaction.WeblogicTransactionManagerLookup"
-msgstr "org.hibernate.transaction.WeblogicTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WeblogicTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. WeblogicTransactionManagerLookup</"
+"literal>"
 
 #. Tag: entry
-#: configuration.xml:1510
 #, no-c-format
 msgid "Weblogic"
 msgstr "Weblogic"
 
-#. Tag: literal
-#: configuration.xml:1513
-#, no-c-format
-msgid "org.hibernate.transaction.WebSphereTransactionManagerLookup"
-msgstr "org.hibernate.transaction.WebSphereTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WebSphereTransactionManagerLookup</"
+"literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. WebSphereTransactionManagerLookup</"
+"literal>"
 
 #. Tag: entry
-#: configuration.xml:1514
 #, no-c-format
 msgid "WebSphere"
 msgstr "WebSphere"
 
-#. Tag: literal
-#: configuration.xml:1517
-#, no-c-format
-msgid "org.hibernate.transaction.WebSphereExtendedJTATransactionLookup"
-msgstr "org.hibernate.transaction.WebSphereExtendedJTATransactionLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WebSphereExtendedJTATransactionLookup</"
+"literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. WebSphereExtendedJTATransactionLookup</"
+"literal>"
 
 #. Tag: entry
-#: configuration.xml:1518
 #, no-c-format
 msgid "WebSphere 6"
 msgstr "WebSphere 6"
 
-#. Tag: literal
-#: configuration.xml:1521
-#, no-c-format
-msgid "org.hibernate.transaction.OrionTransactionManagerLookup"
-msgstr "org.hibernate.transaction.OrionTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.OrionTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. OrionTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1522
 #, no-c-format
 msgid "Orion"
 msgstr "Orion"
 
-#. Tag: literal
-#: configuration.xml:1525
-#, no-c-format
-msgid "org.hibernate.transaction.ResinTransactionManagerLookup"
-msgstr "org.hibernate.transaction.ResinTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.ResinTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. ResinTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1526
 #, no-c-format
 msgid "Resin"
 msgstr "Resin"
 
-#. Tag: literal
-#: configuration.xml:1529
-#, no-c-format
-msgid "org.hibernate.transaction.JOTMTransactionManagerLookup"
-msgstr "org.hibernate.transaction.JOTMTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JOTMTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JOTMTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1530
 #, no-c-format
 msgid "JOTM"
 msgstr "JOTM"
 
-#. Tag: literal
-#: configuration.xml:1533
-#, no-c-format
-msgid "org.hibernate.transaction.JOnASTransactionManagerLookup"
-msgstr "org.hibernate.transaction.JOnASTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JOnASTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JOnASTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1534
 #, no-c-format
 msgid "JOnAS"
 msgstr "JOnAS"
 
-#. Tag: literal
-#: configuration.xml:1537
-#, no-c-format
-msgid "org.hibernate.transaction.JRun4TransactionManagerLookup"
-msgstr "org.hibernate.transaction.JRun4TransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JRun4TransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JRun4TransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1538
 #, no-c-format
 msgid "JRun4"
 msgstr "JRun4"
 
-#. Tag: literal
-#: configuration.xml:1541
-#, no-c-format
-msgid "org.hibernate.transaction.BESTransactionManagerLookup"
-msgstr "org.hibernate.transaction.BESTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.BESTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. BESTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1542
 #, no-c-format
 msgid "Borland ES"
 msgstr "Borland ES"
 
 #. Tag: title
-#: configuration.xml:1551
 #, no-c-format
 msgid "JNDI-bound <literal>SessionFactory</literal>"
-msgstr "<literal>SessionFactory</literal> ligada a JNDI"
+msgstr "<literal>SessionFactory</literal> enlazado a JNDI"
 
 #. Tag: para
-#: configuration.xml:1553
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A JNDI-bound Hibernate <literal>SessionFactory</literal> can simplify the "
 "lookup function of the factory and create new <literal>Session</literal>s. "
 "This is not, however, related to a JNDI bound <literal>Datasource</literal>; "
 "both simply use the same registry."
 msgstr ""
-"Una <literal>SessionFactory</literal> de Hibernate ligada a JNDI puede "
-"simplificar la obtenci&#x00f3;n de la f&#x00e1;brica y la creaci&#x00f3;n de "
-"nuevas <literal>Session</literal>s. Observa que esto no est&#x00e1; "
-"relacionado a un <literal>Datasource</literal> ligado a JNDI, simplemente "
-"ambos usan el mismo registro!"
+"Una <literal>SessionFactory</literal> de Hibernate vinculada a JNDI puede "
+"simplificar la búsqueda de la fábrica y la creación de nuevas "
+"<literal>Session</literal>es. Sin embargo, esto no se relaciona con un "
+"<literal>Datasource</literal> vinculado a JNDI; simplemente que ambos "
+"utilizan el mismo registro."
 
 #. Tag: para
-#: configuration.xml:1560
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you wish to have the <literal>SessionFactory</literal> bound to a JNDI "
 "namespace, specify a name (e.g. <literal>java:hibernate/SessionFactory</"
@@ -3006,16 +2499,15 @@
 "will not be bound to JNDI. This is especially useful in environments with a "
 "read-only JNDI default implementation (in Tomcat, for example)."
 msgstr ""
-"Si deseas tener la <literal>SessionFactory</literal> ligada a un espacio de "
-"nombres de JNDI, especifica un nombre (ej. <literal>java:hibernate/"
-"SessionFactory</literal>) usando la propiedad <literal>hibernate."
-"session_factory_name</literal>. Si esta propiedad es omitida, la "
-"<literal>SessionFactory</literal> no ser&#x00e1; ligada a JNDI (Esto es "
-"especialmente &#x00fa;til en entornos con una implementaci&#x00f3; JNDI de "
-"s&#x00f3;lo lectura por defecto, ej. Tomcat.)"
+"Si desea tener la <literal>SessionFactory</literal> vinculada a un espacio "
+"de nombres de JNDI, especifique un nombre (por ejemplo, <literal>java:"
+"hibernate/SessionFactory</literal>) utilizando la propiedad "
+"<literal>hibernate.session_factory_name</literal>. Si se omite esta "
+"propiedad, la <literal>SessionFactory</literal> no será vinculada a JNDI. "
+"Esto es particularmente útil en entornos con una implementación JNDI de sólo "
+"lectura por defecto (por ejemplo, en Tomcat)."
 
 #. Tag: para
-#: configuration.xml:1568
 #, no-c-format
 msgid ""
 "When binding the <literal>SessionFactory</literal> to JNDI, Hibernate will "
@@ -3023,15 +2515,13 @@
 "jndi.class</literal> to instantiate an initial context. If they are not "
 "specified, the default <literal>InitialContext</literal> will be used."
 msgstr ""
-"Al ligar la <literal>SessionFactory</literal> a JNDI, Hibernate usar&#x00e1; "
+"Al vincular la <literal>SessionFactory</literal> a JNDI, Hibernate utilizará "
 "los valores de <literal>hibernate.jndi.url</literal>, <literal>hibernate."
-"jndi.class</literal> para instanciar un contexto inicial. Si &#x00e9;tos no "
-"se especifican, se usar&#x00e1; el <literal>InitialContext</literal> por "
-"defecto."
+"jndi.class</literal> para instanciar un contexto inicial. Si éstos no se "
+"especifican, se utilizará el <literal>InitialContext</literal> por defecto."
 
 #. Tag: para
-#: configuration.xml:1575
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will automatically place the <literal>SessionFactory</literal> in "
 "JNDI after you call <literal>cfg.buildSessionFactory()</literal>. This means "
@@ -3040,28 +2530,26 @@
 "<literal>HibernateService</literal> (this is discussed later in greater "
 "detail)."
 msgstr ""
-"Hibernate colocar&#x00e1; autom&#x00e1;ticamente la <literal>SessionFactory</"
-"literal> en JNDI despu&#x00e9;s que llames a <literal>cfg.buildSessionFactory"
-"()</literal>. Esto significa que tendr&#x00e1;s al menos esta llamada en "
-"alg&#x00fa;n c&#x00f3;digo de arranque (o clase de utilidad) en tu "
-"aplicaci&#x00f3;n, a menos qie uses el despliegue JMX con el "
-"<literal>HibernateService</literal> (discutido luego)."
+"Hibernate colocará automáticamente la <literal>SessionFactory</literal> en "
+"JNDI después de que llame a <literal>cfg.buildSessionFactory()</literal>. "
+"Esto significa que tendrá al menos esta llamada en algún código de inicio o "
+"clase de utilidad en su aplicación, a menos de que utilice el despliegue JMX "
+"con el <literal>HibernateService</literal> (esto se discute más adelante en "
+"mayor detalle)."
 
 #. Tag: para
-#: configuration.xml:1582
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you use a JNDI <literal>SessionFactory</literal>, an EJB or any other "
 "class, you can obtain the <literal>SessionFactory</literal> using a JNDI "
 "lookup."
 msgstr ""
-"UNTRANSLATED! If you use a JNDI <literal>SessionFactory</literal>, an EJB or "
-"any other class may obtain the <literal>SessionFactory</literal> using a "
-"JNDI lookup."
+"Si utiliza una <literal>SessionFactory</literal> JNDI, un EJB or cualquier "
+"otra clase puede llegar a obtener el <literal>SessionFactory</literal> "
+"utilizando una búsqueda JNDI."
 
 #. Tag: para
-#: configuration.xml:1587
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you bind the <literal>SessionFactory</literal> to "
 "JNDI in a managed environment and use a <literal>static</literal> singleton "
@@ -3071,28 +2559,26 @@
 "()</literal>. Note that such a class is also a convenient way to startup "
 "Hibernate&mdash;see chapter 1."
 msgstr ""
-"Si usas una <literal>SessionFactory</literal> de JNDI, un EJB o cualquier "
-"otra clase puede obtener la <literal>SessionFactory</literal> usando una "
-"b&#x00fa;squeda JNDI. Observa que esta configuraci&#x00f3;n no es necesaria "
-"si usas la clase de ayuda <literal>HibernateUtil</literal> introducida en el "
-"cap&#x00ed;tulo uno, que act&#x00fa;a como un registro Singleton. Sin "
-"embargo, <literal>HibernateUtil</literal> es m&#x00e1;s com&#x00fa;n en un "
-"entorno no manejado."
+"Le recomendamos que vincule el <literal>SessionFactory</literal> a JNDI en "
+"un entorno administrado y que de otra manera, use un singleton "
+"<literal>static</literal>. Para proteger su código de aplicación de estos "
+"detalles, también le recomendamos que esconda el código de búsqueda real "
+"para una <literal>SessionFactory</literal> en una clase de ayuda como "
+"<literal>HibernateUtil.getSessionFactory()</literal>. Note que dicha clase "
+"también es una manera práctica de iniciar Hibernate&mdash; vea el capítulo 1."
 
 #. Tag: title
-#: configuration.xml:1599
 #, no-c-format
 msgid "Current Session context management with JTA"
-msgstr "Ligado autom&#x00e1;tico de JTA y Session"
+msgstr "Administración de contexto de Sesión Actual con JTA"
 
 #. Tag: para
-#: configuration.xml:1601
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The easiest way to handle <literal>Sessions</literal> and transactions is "
 "Hibernate's automatic \"current\" <literal>Session</literal> management. For "
 "a discussion of contextual sessions see <xref linkend=\"architecture-current-"
-"session\"/>. Using the <literal>\"jta\"</literal> session context, if there "
+"session\" />. Using the <literal>\"jta\"</literal> session context, if there "
 "is no Hibernate <literal>Session</literal> associated with the current JTA "
 "transaction, one will be started and associated with that JTA transaction "
 "the first time you call <literal>sessionFactory.getCurrentSession()</"
@@ -3109,35 +2595,35 @@
 "in an EJB container, declarative transaction demarcation with CMT is "
 "preferred."
 msgstr ""
-"UNTRANSLATED! The easiest way to handle <literal>Session</literal>s and "
-"transactions is Hibernates automatic \"current\" <literal>Session</literal> "
-"management. See the discussion of <link linkend=\"architecture-current-"
-"session\">current sessions</link>. Using the <literal>\"jta\"</literal> "
-"session context, if there is no Hibernate <literal>Session</literal> "
-"associated with the current JTA transaction, one will be started and "
-"associated with that JTA transaction the first time you call "
-"<literal>sessionFactory.getCurrentSession()</literal>. The <literal>Session</"
-"literal>s retrieved via <literal>getCurrentSession()</literal> in <literal>"
-"\"jta\"</literal> context will be set to automatically flush before the "
-"transaction completes, close after the transaction completes, and "
-"aggressively release JDBC connections after each statement. This allows the "
-"<literal>Session</literal>s to be managed by the life cycle of the JTA "
-"transaction to which it is associated, keeping user code clean of such "
-"management concerns. Your code can either use JTA programmatically through "
-"<literal>UserTransaction</literal>, or (recommended for portable code) use "
-"the Hibernate <literal>Transaction</literal> API to set transaction "
-"boundaries. If you run in an EJB container, declarative transaction "
-"demarcation with CMT is preferred."
+"La manera más fácil de manejar <literal>Session</literal>es y transacciones "
+"es la administración de <literal>Session</literal> \"actual\" automática de "
+"Hibernate. Vea la discusión sobre las sesiones contextuales en <xref linkend="
+"\"architecture-current-session\"/>. Al utilizar el contexto de sesión de "
+"<literal>\"jta\"</literal>, si no hay una <literal>Session</literal> de "
+"Hibernate asociada con la transacción JTA actual, se iniciará y se asociará "
+"una con esa transacción JTA la primera vez que llame a "
+"<literal>sessionFactory.getCurrentSession()</literal>. Las <literal>Session</"
+"literal>es recuperadas por medio de <literal>getCurrentSession()</literal> "
+"en el contexto <literal>\"jta\"</literal> se configurarán con un vaciado "
+"automático antes de que la transacción se complete, se cerrará después de "
+"completar la transacción y liberará conexiones JDBC agresivamente para cada "
+"declaración. Esto permite que las <literal>Session</literal>es sean "
+"administradas por el ciclo de vida de la transacción JTA a la cual se "
+"encuentra asociada, manteniendo el código del usuario limpio de esas "
+"preocupaciones de administración. Su código puede utilizar JTA "
+"programáticamente por medio de <literal>UserTransaction</literal>, o "
+"(recomendable para el código portable) utilizar el API <literal>Transaction</"
+"literal> de Hibernate para establecer límites de transacciones. Si ejecuta "
+"un contenedor EJB, se prefiere una demarcación de transacción declarativa "
+"con CTM."
 
 #. Tag: title
-#: configuration.xml:1624
 #, no-c-format
 msgid "JMX deployment"
 msgstr "Despliegue JMX"
 
 #. Tag: para
-#: configuration.xml:1626
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The line <literal>cfg.buildSessionFactory()</literal> still has to be "
 "executed somewhere to get a <literal>SessionFactory</literal> into JNDI. You "
@@ -3145,16 +2631,14 @@
 "the one in <literal>HibernateUtil</literal>, or you can deploy Hibernate as "
 "a <emphasis>managed service</emphasis>."
 msgstr ""
-"La l&#x00ed;nea <literal>cfg.buildSessionFactory()</literal> todav&#x00ed;a "
-"tiene que ser ejecutada en algun sitio para obtener una "
-"<literal>SessionFactory</literal> en JNDI. Puedes hacer esto bien en un "
-"bloque inicializador <literal>static</literal> (como aquel en "
-"<literal>HibernateUtil</literal>) o bien despliegas Hibernate como un "
-"<emphasis>servicio manejado</emphasis>."
+"La línea <literal>cfg.buildSessionFactory()</literal> todavía se tiene que "
+"ejecutar en algún sitio para obtener una <literal>SessionFactory</literal> "
+"en JNDI. Puede hacer esto ya sea en un bloque inicializador <literal>static</"
+"literal> (como aquel en <literal>HibernateUtil</literal>) o bien puede "
+"desplegar Hibernate como un <emphasis>servicio administrado</emphasis>."
 
 #. Tag: para
-#: configuration.xml:1634
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate is distributed with <literal>org.hibernate.jmx.HibernateService</"
 "literal> for deployment on an application server with JMX capabilities, such "
@@ -3162,111 +2646,14 @@
 "Here is an example <literal>jboss-service.xml</literal> for JBoss 4.0.x:"
 msgstr ""
 "Hibernate se distribuye con <literal>org.hibernate.jmx.HibernateService</"
-"literal> para despliegue en un servidor de aplicaciones con capacidades JMX, "
-"como JBoss AS. El despliegue y la configurac&#x00f3;n reales son "
-"espec&#x00ed;ficos del vendedor. He aqu&#x00ed; un <literal>jboss-service."
-"xml</literal> de ejemplo para JBoss 4.0.x:"
+"literal> para desplegar en un servidor de aplicaciones con capacidades JMX, "
+"como JBoss AS. El despliegue y la configuracón reales son específicos del "
+"vendedor. He aquí un ejemplo de <literal>jboss-service.xml</literal> para "
+"JBoss 4.0.x: "
 
-#. Tag: programlisting
-#: configuration.xml:1641
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<server>\n"
-"\n"
-"<mbean code=\"org.hibernate.jmx.HibernateService\"\n"
-"    name=\"jboss.jca:service=HibernateFactory,name=HibernateFactory\">\n"
-"\n"
-"    <!-- Required services -->\n"
-"    <depends>jboss.jca:service=RARDeployer</depends>\n"
-"    <depends>jboss.jca:service=LocalTxCM,name=HsqlDS</depends>\n"
-"\n"
-"    <!-- Bind the Hibernate service to JNDI -->\n"
-"    <attribute name=\"JndiName\">java:/hibernate/SessionFactory</attribute>\n"
-"\n"
-"    <!-- Datasource settings -->\n"
-"    <attribute name=\"Datasource\">java:HsqlDS</attribute>\n"
-"    <attribute name=\"Dialect\">org.hibernate.dialect.HSQLDialect</"
-"attribute>\n"
-"\n"
-"    <!-- Transaction integration -->\n"
-"    <attribute name=\"TransactionStrategy\">\n"
-"        org.hibernate.transaction.JTATransactionFactory</attribute>\n"
-"    <attribute name=\"TransactionManagerLookupStrategy\">\n"
-"        org.hibernate.transaction.JBossTransactionManagerLookup</attribute>\n"
-"    <attribute name=\"FlushBeforeCompletionEnabled\">true</attribute>\n"
-"    <attribute name=\"AutoCloseSessionEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Fetching options -->\n"
-"    <attribute name=\"MaximumFetchDepth\">5</attribute>\n"
-"\n"
-"    <!-- Second-level caching -->\n"
-"    <attribute name=\"SecondLevelCacheEnabled\">true</attribute>\n"
-"    <attribute name=\"CacheProviderClass\">org.hibernate.cache."
-"EhCacheProvider</attribute>\n"
-"    <attribute name=\"QueryCacheEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Logging -->\n"
-"    <attribute name=\"ShowSqlEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Mapping files -->\n"
-"    <attribute name=\"MapResources\">auction/Item.hbm.xml,auction/Category."
-"hbm.xml</attribute>\n"
-"\n"
-"</mbean>\n"
-"\n"
-"</server>]]>"
-msgstr ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<server>\n"
-"\n"
-"<mbean code=\"org.hibernate.jmx.HibernateService\"\n"
-"    name=\"jboss.jca:service=HibernateFactory,name=HibernateFactory\">\n"
-"\n"
-"    <!-- Required services -->\n"
-"    <depends>jboss.jca:service=RARDeployer</depends>\n"
-"    <depends>jboss.jca:service=LocalTxCM,name=HsqlDS</depends>\n"
-"\n"
-"    <!-- Bind the Hibernate service to JNDI -->\n"
-"    <attribute name=\"JndiName\">java:/hibernate/SessionFactory</attribute>\n"
-"\n"
-"    <!-- Datasource settings -->\n"
-"    <attribute name=\"Datasource\">java:HsqlDS</attribute>\n"
-"    <attribute name=\"Dialect\">org.hibernate.dialect.HSQLDialect</"
-"attribute>\n"
-"\n"
-"    <!-- Transaction integration -->\n"
-"    <attribute name=\"TransactionStrategy\">\n"
-"        org.hibernate.transaction.JTATransactionFactory</attribute>\n"
-"    <attribute name=\"TransactionManagerLookupStrategy\">\n"
-"        org.hibernate.transaction.JBossTransactionManagerLookup</attribute>\n"
-"    <attribute name=\"FlushBeforeCompletionEnabled\">true</attribute>\n"
-"    <attribute name=\"AutoCloseSessionEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Fetching options -->\n"
-"    <attribute name=\"MaximumFetchDepth\">5</attribute>\n"
-"\n"
-"    <!-- Second-level caching -->\n"
-"    <attribute name=\"SecondLevelCacheEnabled\">true</attribute>\n"
-"    <attribute name=\"CacheProviderClass\">org.hibernate.cache."
-"EhCacheProvider</attribute>\n"
-"    <attribute name=\"QueryCacheEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Logging -->\n"
-"    <attribute name=\"ShowSqlEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Mapping files -->\n"
-"    <attribute name=\"MapResources\">auction/Item.hbm.xml,auction/Category."
-"hbm.xml</attribute>\n"
-"\n"
-"</mbean>\n"
-"\n"
-"</server>]]>"
-
-#. Tag: para
-#: configuration.xml:1643
-#, fuzzy, no-c-format
-msgid ""
 "This file is deployed in a directory called <literal>META-INF</literal> and "
 "packaged in a JAR file with the extension <literal>.sar</literal> (service "
 "archive). You also need to package Hibernate, its required third-party "
@@ -3277,39 +2664,13 @@
 "JBoss AS documentation for more information about JMX service and EJB "
 "deployment."
 msgstr ""
-"Este fichero es desplegado en un directorio llamado <literal>META-INF</"
-"literal> y empaquetado en un fichero JAR con la extensi&#x00f3;n <literal>."
-"sar</literal> (fichero de servicio). Tambi&#x00e9;n necesitas empaquetar "
-"Hibernate, sus bibliotecas de terceros requeridas, tus clases persistentes "
-"compiladas, as&#x00ed; como tus ficheros de mapeo en el mismo fichero. Tus "
-"beans de empresa (usualmente beans de sesi&#x00f3;n) pueden ser mantenidos "
-"en su propio fichero JAR, pero debes incluir este fichero EJB JAR en el "
-"fichero de servicio principal para obtener una unidad desplegable (en "
-"caliente). Consulta la documentaci&#x00f3;n de JBoss AS para m&#x00e1;s "
-"informaci&#x00f3;n sobre el servicio JMX y despliegue de EJB."
-
-#~ msgid "Hibernate logs various events using Apache commons-logging."
-#~ msgstr "Hibernate registra varios eventos usando commons-logging de Apache."
-
-#~ msgid ""
-#~ "The commons-logging service will direct output to either Apache Log4j (if "
-#~ "you include <literal>log4j.jar</literal> in your classpath) or JDK1.4 "
-#~ "logging (if running under JDK1.4 or above). You may download Log4j from "
-#~ "<literal>http://jakarta.apache.org</literal>. To use Log4j you will need "
-#~ "to place a <literal>log4j.properties</literal> file in your classpath, an "
-#~ "example properties file is distributed with Hibernate in the <literal>src/"
-#~ "</literal> directory."
-#~ msgstr ""
-#~ "El servicio de commons-logging saldr&#x00e1; directamente ya sea a Log4J "
-#~ "(si incluyes <literal>log4j.jar</literal> in your classpath) o JDK1.4 "
-#~ "logging (al ejecutar bajo JDK1.4 o superior). Puedes descargar Log4J "
-#~ "desde <literal>http://logging.apache.org</literal>. Para usar Log4J "
-#~ "necesitar&#x00e1;s colocar un fichero <literal>log4j.properties</literal> "
-#~ "en tu classpath. Un fichero de propiedades de ejemplo se distribuye con "
-#~ "Hibernate en el directorio <literal>src/</literal>."
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+"Este archivo se implementa en un directorio llamado <literal>META-INF</"
+"literal> y se encuentra empacado en un archivo JAR con la extensión "
+"<literal>.sar</literal> (archivo de servicio). También necesita empacar "
+"Hibernate, sus bibliotecas de terceros requeridas, sus clases persistentes "
+"compiladas, así como sus archivos de mapeo en el mismo archivo. Sus beans "
+"empresariales (usualmente beans de sesión) se pueden dejar en su propio "
+"archivo JAR, pero puede incluir este archivo EJB JAR en el archivo de "
+"servicio principal para obtener una unidad desplegable en vivo (sin "
+"apagarlo). Consulte la documentación de JBoss AS para obtener más "
+"información sobre el servicio JMX y la implementación de EJB."

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/events.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/events.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/events.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,40 +1,51 @@
-#, fuzzy
+# translation of events.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: events\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2009-11-12 09:03+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: events.xml:29
 #, no-c-format
 msgid "Interceptors and events"
 msgstr "Interceptores y eventos"
 
 #. Tag: para
-#: events.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is useful for the application to react to certain events that occur "
 "inside Hibernate. This allows for the implementation of generic "
 "functionality and the extension of Hibernate functionality."
 msgstr ""
-"Frecuentemente es &#x00fa;til para la aplicaci&#x00f3;n reaccionar a ciertos "
-"eventos que ocurran dentro de Hibernate. Esto permite la implementaci&#x00f3;"
-"n de ciertos tipos de funcionalidade gen&#x00e9;rica, y extensi&#x00f3;n de "
-"la funcionalidad de Hibernate."
+"Es útil para la aplicación reaccionar a ciertos eventos que ocurren dentro "
+"de Hibernate. Esto permite la implementación de funcionalidades genéricas y "
+"la extensión de la funcionalidad de Hibernate."
 
 #. Tag: title
-#: events.xml:38
 #, no-c-format
 msgid "Interceptors"
 msgstr "Interceptores"
 
 #. Tag: para
-#: events.xml:40
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>Interceptor</literal> interface provides callbacks from the "
 "session to the application, allowing the application to inspect and/or "
@@ -46,227 +57,47 @@
 "<literal>lastUpdateTimestamp</literal> property when an <literal>Auditable</"
 "literal> is updated."
 msgstr ""
-"La interface <literal>Interceptor</literal> provee callbacks desde la "
-"sesi&#x00f3;n a la aplicaci&#x00f3;n permitiendo a &#x00e9;sta &#x00fa;ltima "
-"inspeccionar y/o manipular las propiedades de un objeto persistente antes "
-"que sea salvado, actualizado, borrado o cargado. Un uso posible de esto es "
-"seguir la pista de informaci&#x00f3;n de auditor&#x00ed;a. Por ejemplo, el "
-"siguiente <literal>Interceptor</literal> establece autom&#x00e1;ticamente el "
-"<literal>createTimestamp</literal> cuando un <literal>Auditable</literal> es "
-"creado y actualiza la propiedad <literal>lastUpdateTimestamp</literal> "
-"cuando un <literal>Auditable</literal> es acutalizado."
+"La interfaz <literal>Interceptor</literal> brinda callbacks desde la sesión "
+"a la aplicación, permitiendole a ésta última inspeccionar y/o manipular las "
+"propiedades de un objeto persistente antes de que sea guardado, actualizado, "
+"borrado o cargado. Un uso posible de esto es seguir la pista de la "
+"información de auditoría. Por ejemplo, el siguiente <literal>Interceptor</"
+"literal> establece automáticamente el <literal>createTimestamp</literal> "
+"cuando se crea un <literal>Auditable</literal> y se actualiza la propiedad "
+"<literal>lastUpdateTimestamp</literal> cuando se actualiza un "
+"<literal>Auditable</literal>."
 
 #. Tag: para
-#: events.xml:51
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can either implement <literal>Interceptor</literal> directly or extend "
 "<literal>EmptyInterceptor</literal>."
 msgstr ""
-"UNTRANSLATED! You may either implement <literal>Interceptor</literal> "
-"directly or (better) extend <literal>EmptyInterceptor</literal>."
+"Puede implementar el <literal>Interceptor</literal> directamente o extender "
+"el <literal>EmptyInterceptor</literal>."
 
-#. Tag: programlisting
-#: events.xml:56
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[package org.hibernate.test;\n"
-"\n"
-"import java.io.Serializable;\n"
-"import java.util.Date;\n"
-"import java.util.Iterator;\n"
-"\n"
-"import org.hibernate.EmptyInterceptor;\n"
-"import org.hibernate.Transaction;\n"
-"import org.hibernate.type.Type;\n"
-"\n"
-"public class AuditInterceptor extends EmptyInterceptor {\n"
-"\n"
-"    private int updates;\n"
-"    private int creates;\n"
-"    private int loads;\n"
-"\n"
-"    public void onDelete(Object entity,\n"
-"                         Serializable id,\n"
-"                         Object[] state,\n"
-"                         String[] propertyNames,\n"
-"                         Type[] types) {\n"
-"        // do nothing\n"
-"    }\n"
-"\n"
-"    public boolean onFlushDirty(Object entity,\n"
-"                                Serializable id,\n"
-"                                Object[] currentState,\n"
-"                                Object[] previousState,\n"
-"                                String[] propertyNames,\n"
-"                                Type[] types) {\n"
-"\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            updates++;\n"
-"            for ( int i=0; i < propertyNames.length; i++ ) {\n"
-"                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) {\n"
-"                    currentState[i] = new Date();\n"
-"                    return true;\n"
-"                }\n"
-"            }\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public boolean onLoad(Object entity,\n"
-"                          Serializable id,\n"
-"                          Object[] state,\n"
-"                          String[] propertyNames,\n"
-"                          Type[] types) {\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            loads++;\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public boolean onSave(Object entity,\n"
-"                          Serializable id,\n"
-"                          Object[] state,\n"
-"                          String[] propertyNames,\n"
-"                          Type[] types) {\n"
-"\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            creates++;\n"
-"            for ( int i=0; i<propertyNames.length; i++ ) {\n"
-"                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
-"                    state[i] = new Date();\n"
-"                    return true;\n"
-"                }\n"
-"            }\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public void afterTransactionCompletion(Transaction tx) {\n"
-"        if ( tx.wasCommitted() ) {\n"
-"            System.out.println(\"Creations: \" + creates + \", Updates: \" + "
-"updates, \"Loads: \" + loads);\n"
-"        }\n"
-"        updates=0;\n"
-"        creates=0;\n"
-"        loads=0;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-"<![CDATA[package org.hibernate.test;\n"
-"\n"
-"import java.io.Serializable;\n"
-"import java.util.Date;\n"
-"import java.util.Iterator;\n"
-"\n"
-"import org.hibernate.Interceptor;\n"
-"import org.hibernate.type.Type;\n"
-"\n"
-"public class AuditInterceptor implements Interceptor, Serializable {\n"
-"\n"
-"    private int updates;\n"
-"    private int creates;\n"
-"\n"
-"    public void onDelete(Object entity,\n"
-"                         Serializable id,\n"
-"                         Object[] state,\n"
-"                         String[] propertyNames,\n"
-"                         Type[] types) {\n"
-"        // do nothing\n"
-"    }\n"
-"\n"
-"    public boolean onFlushDirty(Object entity,\n"
-"                                Serializable id,\n"
-"                                Object[] currentState,\n"
-"                                Object[] previousState,\n"
-"                                String[] propertyNames,\n"
-"                                Type[] types) {\n"
-"\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            updates++;\n"
-"            for ( int i=0; i < propertyNames.length; i++ ) {\n"
-"                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) {\n"
-"                    currentState[i] = new Date();\n"
-"                    return true;\n"
-"                }\n"
-"            }\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public boolean onLoad(Object entity,\n"
-"                          Serializable id,\n"
-"                          Object[] state,\n"
-"                          String[] propertyNames,\n"
-"                          Type[] types) {\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public boolean onSave(Object entity,\n"
-"                          Serializable id,\n"
-"                          Object[] state,\n"
-"                          String[] propertyNames,\n"
-"                          Type[] types) {\n"
-"\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            creates++;\n"
-"            for ( int i=0; i<propertyNames.length; i++ ) {\n"
-"                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
-"                    state[i] = new Date();\n"
-"                    return true;\n"
-"                }\n"
-"            }\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public void postFlush(Iterator entities) {\n"
-"        System.out.println(\"Creations: \" + creates + \", Updates: \" + "
-"updates);\n"
-"    }\n"
-"\n"
-"    public void preFlush(Iterator entities) {\n"
-"        updates=0;\n"
-"        creates=0;\n"
-"    }\n"
-"\n"
-"    ...\n"
-"\n"
-"}]]>"
-
-#. Tag: para
-#: events.xml:58
-#, fuzzy, no-c-format
-msgid ""
 "There are two kinds of inteceptors: <literal>Session</literal>-scoped and "
 "<literal>SessionFactory</literal>-scoped."
 msgstr ""
-"UNTRANSLATED! Interceptors come in two flavors: <literal>Session</literal>-"
-"scoped and <literal>SessionFactory</literal>-scoped."
+"Hay dos clases de interceptores: incluído en <literal>Session</literal>- e "
+"incluído en <literal>SessionFactory</literal>."
 
 #. Tag: para
-#: events.xml:63
 #, no-c-format
 msgid ""
 "A <literal>Session</literal>-scoped interceptor is specified when a session "
 "is opened using one of the overloaded SessionFactory.openSession() methods "
 "accepting an <literal>Interceptor</literal>."
 msgstr ""
-"UNTRANSLATED! A <literal>Session</literal>-scoped interceptor is specified "
-"when a session is opened using one of the overloaded SessionFactory."
-"openSession() methods accepting an <literal>Interceptor</literal>."
+"Se especifica un interceptor incluído <literal>Session</literal> cuando se "
+"abre una sesión utilizando uno de los métodos SessionFactory.openSession() "
+"sobrecargados aceptando un <literal>Interceptor</literal>."
 
-#. Tag: programlisting
-#: events.xml:69
-#, no-c-format
-msgid "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
-msgstr ""
-"<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
-
 #. Tag: para
-#: events.xml:71
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>SessionFactory</literal>-scoped interceptor is registered with "
 "the <literal>Configuration</literal> object prior to building the "
@@ -277,46 +108,35 @@
 "Ensure that you do not store session-specific states, since multiple "
 "sessions will use this interceptor potentially concurrently."
 msgstr ""
-"UNTRANSLATED! A <literal>SessionFactory</literal>-scoped interceptor is "
-"registered with the <literal>Configuration</literal> object prior to "
-"building the <literal>SessionFactory</literal>. In this case, the supplied "
-"interceptor will be applied to all sessions opened from that "
-"<literal>SessionFactory</literal>; this is true unless a session is opened "
-"explicitly specifying the interceptor to use. <literal>SessionFactory</"
-"literal>-scoped interceptors must be thread safe, taking care to not store "
-"session-specific state since multiple sessions will use this interceptor "
-"(potentially) concurrently."
+"Un interceptor incluido en <literal>SessionFactory</literal> se encuentra "
+"registrado con el objeto <literal>Configuration</literal> antes de construir "
+"el <literal>SessionFactory</literal>. En este caso, el interceptor proveido "
+"será aplicado a todas las sesiones abiertas desde ese "
+"<literal>SessionFactory</literal>; a menos de que se abra una sesión "
+"especificando explícitamente el interceptor a utilizar. Los interceptores "
+"<literal>SessionFactory</literal> incluidos deben ser a prueba de hilos. "
+"Asegúrese de no almacenar un estado especifico a la sesión ya que múltiples "
+"sesiones utilizarán este interceptor potencialmente de manera concurrente."
 
-#. Tag: programlisting
-#: events.xml:80
-#, no-c-format
-msgid ""
-"<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
-msgstr ""
-"<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
-
 #. Tag: title
-#: events.xml:85
 #, no-c-format
 msgid "Event system"
 msgstr "Sistema de eventos"
 
 #. Tag: para
-#: events.xml:87
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you have to react to particular events in your persistence layer, you can "
 "also use the Hibernate3 <emphasis>event</emphasis> architecture. The event "
 "system can be used in addition, or as a replacement, for interceptors."
 msgstr ""
-"Si tienes que reaccionar a eventos particulares en tu capa de persistencia, "
-"puedes tambi&#x00e9;n la arquitectura de <emphasis>eventos</emphasis> de "
-"Hibernate3. El sistema de eventos puede ser usado en adici&#x00f3;n o como "
-"un remplazo a los interceptores."
+"Si tiene que reaccionar a eventos particulares en su capa de persistencia, "
+"también puede utilizar la arquitectura de <emphasis>eventos</emphasis> de "
+"Hibernate3. El sistema de eventos se puede ser utilizar además de o como un "
+"remplazo para los interceptores."
 
 #. Tag: para
-#: events.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All the methods of the <literal>Session</literal> interface correlate to an "
 "event. You have a <literal>LoadEvent</literal>, a <literal>FlushEvent</"
@@ -333,37 +153,34 @@
 "processing any <literal>load()</literal> requests made of the "
 "<literal>Session</literal>."
 msgstr ""
-"Esencialmente todos los m&#x00e9;todos de la interface <literal>Session</"
-"literal> se correlacionan con un evento. Tienes un <literal>LoadEvent</"
-"literal>, un <literal>FlushEvent</literal>, etc (consulta el DTD del fichero "
-"de configuraci&#x00f3;n XML o el paquete <literal>org.hibernate.event</"
-"literal> para la lista completa de tipos de evento definidos). Cuando se "
-"hace una petici&#x00f3;n de uno de estos m&#x00e9;todos, la "
-"<literal>Session</literal> de Hibernate genera un evento apropiado y se lo "
-"pasa al oyente (listener) de eventos configurado para ese tipo. De f&#x00e1;"
-"brica, estos oyentes implementan el mismo procesamiento en los que siempre "
-"resultan aquellos m&#x00e9;todos. Sin embargo, eres libre de implementar una "
-"personalizaci&#x00f3;n de una de las interfaces oyentes (es decir, el "
-"<literal>LoadEvent</literal> es procesado por la implementaci&#x00f3;n "
-"registrada de la interface <literal>LoadEventListener</literal>), en cuyo "
-"caso su implementaci&#x00f3;n ser&#x00ed;a responsable de procesar cualquier "
-"petici&#x00f3;n <literal>load()</literal> hecha a la <literal>Session</"
-"literal>."
+"Todos los métodos de la interfaz <literal>Session</literal> se correlacionan "
+"con un evento. Tiene un <literal>LoadEvent</literal>, un "
+"<literal>FlushEvent</literal>, etc. Consulte el DTD del archivo de "
+"configuración XML o el paquete <literal>org.hibernate.event</literal> para "
+"ver la lista completa de los tipos de eventos definidos. Cuando se realiza "
+"una petición de uno de estos métodos, la <literal>Session</literal> de "
+"Hibernate genera un evento apropiado y se lo pasa al escucha (listener) de "
+"eventos configurado para ese tipo. Tal como vienen, estos escuchas "
+"implementan el mismo procesamiento en aquellos métodos donde siempre "
+"resultan . Sin embargo, usted es libre de implementar una personalización de "
+"una de las interfaces escuchas (por ejemplo, el <literal>LoadEvent</literal> "
+"es procesado por la implementación registrada de la interfaz "
+"<literal>LoadEventListener</literal>), en cuyo caso su implementación sería "
+"responsable de procesar cualquier petición <literal>load()</literal> "
+"realizada a la <literal>Session</literal>."
 
 #. Tag: para
-#: events.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The listeners should be considered singletons. This means they are shared "
 "between requests, and should not save any state as instance variables."
 msgstr ""
-"Los oyentes deben ser considerados efectivamente singletons; quiere decir, "
-"que son compartidos entre las peticiones, y por lo tanto no guardan "
-"ning&#x00fa;n estado en variables de instancia."
+"Los escuchas se deben considerar como singletons. Esto significa que son "
+"compartidos entre las peticiones y por lo tanto, no deben guardar ningún "
+"estado como variables de instancia."
 
 #. Tag: para
-#: events.xml:113
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A custom listener implements the appropriate interface for the event it "
 "wants to process and/or extend one of the convenience base classes (or even "
@@ -374,101 +191,33 @@
 "configuration through the properties file is not supported. Here is an "
 "example of a custom load event listener:"
 msgstr ""
-"Un oyente personalizado debe implementar la interface apropiada para el "
-"evento que quiere procesar y/o extender una de las clases base de "
-"conveniencia (o incluso los oyentes de eventos por defecto usados por "
-"Hibernate de f&#x00e1;brica al ser &#x00e9;stos declarados non-final para "
-"este prop&#x00f3;sito). Los oyentes personalizados pueden ser registrados "
-"program&#x00e1;ticamente a trav&#x00e9;s del objeto <literal>Configuration</"
-"literal>, o especificados en el XML de configuraci&#x00f3;n de Hibernate (la "
-"declaraci&#x00f3;n declarativa a trav&#x00e9;s del fichero de propiedades no "
-"est&#x00e1; soportada). He aqu&#x00ed; un ejemplo de un oyente personalizado "
-"de eventos load:"
+"Un escucha personalizado implementa la interfaz apropiada para el evento que "
+"quiere procesar y/o extender una de las clases base de conveniencia (o "
+"incluso los escuchas de eventos predeterminados utilizados por Hibernate de "
+"fábrica al declararlos como no-finales para este propósito). Los escuchas "
+"personalizados pueden ser registrados programáticamente a través del objeto "
+"<literal>Configuration</literal>, o especificados en el XML de configuración "
+"de Hibernate. No se soporta la configuración declarativa a través del "
+"archivo de propiedades. Este es un ejemplo de un escucha personalizado de "
+"eventos load:"
 
-#. Tag: programlisting
-#: events.xml:123
-#, no-c-format
-msgid ""
-"<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
-"    // this is the single method defined by the LoadEventListener interface\n"
-"    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
-"loadType)\n"
-"            throws HibernateException {\n"
-"        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
-"getEntityId() ) ) {\n"
-"            throw MySecurityException(\"Unauthorized access\");\n"
-"        }\n"
-"    }\n"
-"}]]>"
-msgstr ""
-"<![CDATA[public class MyLoadListener extends DefaultLoadEventListener {\n"
-"    // this is the single method defined by the LoadEventListener interface\n"
-"    public Object onLoad(LoadEvent event, LoadEventListener.LoadType "
-"loadType)\n"
-"            throws HibernateException {\n"
-"        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
-"getEntityId() ) ) {\n"
-"            throw MySecurityException(\"Unauthorized access\");\n"
-"        }\n"
-"        return super.onLoad(event, loadType);\n"
-"    }\n"
-"}]]>"
-
 #. Tag: para
-#: events.xml:125
 #, no-c-format
 msgid ""
 "You also need a configuration entry telling Hibernate to use the listener in "
 "addition to the default listener:"
 msgstr ""
-"Necesitas adem&#x00e1;s una entrada de configuraci&#x00f3;n dici&#x00e9;"
-"ndole a Hibernate que use el oyente en vez del oyente por defecto:"
+"También necesita una entrada de configuración diciéndole a Hibernate que "
+"utilice el oyente en vez del oyente por defecto:"
 
-#. Tag: programlisting
-#: events.xml:130
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-configuration>\n"
-"    <session-factory>\n"
-"        ...\n"
-"        <event type=\"load\">\n"
-"            <listener class=\"com.eg.MyLoadListener\"/>\n"
-"            <listener class=\"org.hibernate.event.def."
-"DefaultLoadEventListener\"/>\n"
-"        </event>\n"
-"    </session-factory>\n"
-"</hibernate-configuration>]]>"
-msgstr ""
-"<![CDATA[<hibernate-configuration>\n"
-"    <session-factory>\n"
-"        ...\n"
-"        <listener type=\"load\" class=\"MyLoadListener\"/>\n"
-"    </session-factory>\n"
-"</hibernate-configuration>]]>"
-
 #. Tag: para
-#: events.xml:132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Instead, you can register it programmatically:"
-msgstr "En cambio, puedes registrarlo program&#x00e1;ticamente:"
+msgstr "En cambio, puede registrarlo programáticamente: "
 
-#. Tag: programlisting
-#: events.xml:136
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration();\n"
-"LoadEventListener[] stack = { new MyLoadListener(), new "
-"DefaultLoadEventListener() };\n"
-"cfg.EventListeners().setLoadEventListeners(stack);]]>"
-msgstr ""
-"<![CDATA[Configuration cfg = new Configuration();\n"
-"cfg.getSessionEventListenerConfig().setLoadEventListener( new MyLoadListener"
-"() );]]>"
-
-#. Tag: para
-#: events.xml:138
-#, fuzzy, no-c-format
-msgid ""
 "Listeners registered declaratively cannot share instances. If the same class "
 "name is used in multiple <literal>&lt;listener/&gt;</literal> elements, each "
 "reference will result in a separate instance of that class. If you need to "
@@ -476,15 +225,13 @@
 "programmatic registration approach."
 msgstr ""
 "Los oyentes registrados declarativamente no pueden compartir instancias. Si "
-"el mismo nombre de clase es usado en m&#x00fa;ltiples elementos <literal>&lt;"
-"listener/&gt;</literal>, cada referencia resultar&#x00e1; en una instancia "
-"separada de esa clase. Si necesitas la capacidad de compartir instancias de "
-"oyentes entre tipos de oyente debes usar el enfoque de registraci&#x00f3;n "
-"program&#x00e1;tica."
+"se utiliza el mismo nombre de clase en múltiples elementos <literal>&lt;"
+"listener/&gt;</literal>, cada referencia resultará en una instancia separada "
+"de esa clase. Si necesita compartir instancias de oyentes entre tipos de "
+"oyentes debe usar el enfoque de registración programática."
 
 #. Tag: para
-#: events.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Why implement an interface and define the specific type during "
 "configuration? A listener implementation could implement multiple event "
@@ -492,110 +239,332 @@
 "registration makes it easier to turn custom listeners on or off during "
 "configuration."
 msgstr ""
-"&#x00bf;Por qu&#x00e9; implementar una interface y definir el tipo "
-"espc&#x00ed;fico durante la configuraci&#x00f3;n? Bueno, una "
-"implementaci&#x00f3;n de oyente podr&#x00ed;a implementar m&#x00fa;ltiples "
-"interfaces de oyente de eventos. Teniendo el tipo definido adicionalmente "
-"durante la registraci&#x00f3;n lo hace m&#x00e1;s f&#x00e1;cil para activar "
-"o desactivar oyentes personalizados durante la configuraci&#x00f3;n."
+"¿Por qué implementar una interfaz y definir el tipo específico durante la "
+"configuración? Una implementación de escucha podría implementar múltiples "
+"interfaces de escucha de eventos. Teniendo el tipo definido adicionalmente "
+"durante la registración hace más fácil activar o desactivar escuchas "
+"personalizados durante la configuración."
 
 #. Tag: title
-#: events.xml:156
 #, no-c-format
 msgid "Hibernate declarative security"
 msgstr "Seguridad declarativa de Hibernate"
 
 #. Tag: para
-#: events.xml:157
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Usually, declarative security in Hibernate applications is managed in a "
 "session facade layer. Hibernate3 allows certain actions to be permissioned "
 "via JACC, and authorized via JAAS. This is an optional functionality that is "
 "built on top of the event architecture."
 msgstr ""
-"Usualmente, la seguridad declarativa en aplicaciones Hibernate es manejada "
-"en una capa de fachada de sesi&#x00f3;n. Ahora, Hibernate3 permite que "
-"ciertas acciones sean permitidas v&#x00ed;a JACC, y autorizadas v&#x00ed;a "
-"JAAS. Esta en una funcionalidad opcional constru&#x00ed;da encima de la "
-"arquitectura de eventos."
+"Usualmente, la seguridad declarativa en aplicaciones Hibernate se administra "
+"en una capa de fachada de sesión. Hibernate3 permite que ciertas acciones se "
+"permitan por medio de JACC y las autoriza por medio de JAAS. Esta es una "
+"funcionalidad opcional construída encima de la arquitectura de eventos."
 
 #. Tag: para
-#: events.xml:163
 #, no-c-format
 msgid ""
 "First, you must configure the appropriate event listeners, to enable the use "
 "of JAAS authorization."
 msgstr ""
-"Primero, debes configurar los oyentes de eventos apropiados, para habilitar "
-"el uso de autorizaci&#x00f3;n JAAS."
+"Primero, tiene que configurar los oyentes de eventos apropiados, para "
+"habilitar la utilización de autorización JAAS."
 
-#. Tag: programlisting
-#: events.xml:168
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
-"JACCPreDeleteEventListener\"/>\n"
-"<listener type=\"pre-update\" class=\"org.hibernate.secure."
-"JACCPreUpdateEventListener\"/>\n"
-"<listener type=\"pre-insert\" class=\"org.hibernate.secure."
-"JACCPreInsertEventListener\"/>\n"
-"<listener type=\"pre-load\" class=\"org.hibernate.secure."
-"JACCPreLoadEventListener\"/>]]>"
-msgstr ""
-"<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
-"JACCPreDeleteEventListener\"/>\n"
-"<listener type=\"pre-update\" class=\"org.hibernate.secure."
-"JACCPreUpdateEventListener\"/>\n"
-"<listener type=\"pre-insert\" class=\"org.hibernate.secure."
-"JACCPreInsertEventListener\"/>\n"
-"<listener type=\"pre-load\" class=\"org.hibernate.secure."
-"JACCPreLoadEventListener\"/>]]>"
-
-#. Tag: para
-#: events.xml:170
-#, fuzzy, no-c-format
-msgid ""
 "Note that <literal>&lt;listener type=\"...\" class=\"...\"/&gt;</literal> is "
 "shorthand for <literal>&lt;event type=\"...\"&gt;&lt;listener class=\"...\"/"
 "&gt;&lt;/event&gt;</literal> when there is exactly one listener for a "
 "particular event type."
 msgstr ""
-"UNTRANSLATED! Note that <literal>&lt;listener type=\"...\" class=\"...\"/&gt;"
-"</literal> is just a shorthand for <literal>&lt;event type=\"...\"&gt;&lt;"
-"listener class=\"...\"/&gt;&lt;/event&gt;</literal> when there is exactly "
-"one listener for a particular event type."
+"Note que <literal>&lt;listener type=\"...\" class=\"...\"/&gt;</literal> es "
+"la abreviatura para <literal>&lt;event type=\"...\"&gt;&lt;listener class="
+"\"...\"/&gt;&lt;/event&gt;</literal> cuando hay exactamente un escucha para "
+"un tipo de evento en particular."
 
 #. Tag: para
-#: events.xml:176
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next, while still in <literal>hibernate.cfg.xml</literal>, bind the "
 "permissions to roles:"
 msgstr ""
-"Seguido, a&#x00fa;n en <literal>hibernate.cfg.xml</literal>, liga los "
-"permisos a roles:"
+"A continuación, todavía en <literal>hibernate.cfg.xml</literal>, enlace los "
+"permisos a los roles:"
 
-#. Tag: programlisting
-#: events.xml:180
-#, no-c-format
-msgid ""
-"<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,update,"
-"read\"/>\n"
-"<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"
-msgstr ""
-"<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,update,"
-"read\"/>\n"
-"<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"
-
 #. Tag: para
-#: events.xml:182
 #, no-c-format
 msgid "The role names are the roles understood by your JACC provider."
-msgstr "Los nombres de role son los roles entendidos por tu proveedor de JACC."
+msgstr "Los nombres de los roles son comprendidos por su proveedor de JACC."
 
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
+#~ msgid ""
+#~ "<![CDATA[package org.hibernate.test;\n"
+#~ "\n"
+#~ "import java.io.Serializable;\n"
+#~ "import java.util.Date;\n"
+#~ "import java.util.Iterator;\n"
+#~ "\n"
+#~ "import org.hibernate.EmptyInterceptor;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.type.Type;\n"
+#~ "\n"
+#~ "public class AuditInterceptor extends EmptyInterceptor {\n"
+#~ "\n"
+#~ "    private int updates;\n"
+#~ "    private int creates;\n"
+#~ "    private int loads;\n"
+#~ "\n"
+#~ "    public void onDelete(Object entity,\n"
+#~ "                         Serializable id,\n"
+#~ "                         Object[] state,\n"
+#~ "                         String[] propertyNames,\n"
+#~ "                         Type[] types) {\n"
+#~ "        // do nothing\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onFlushDirty(Object entity,\n"
+#~ "                                Serializable id,\n"
+#~ "                                Object[] currentState,\n"
+#~ "                                Object[] previousState,\n"
+#~ "                                String[] propertyNames,\n"
+#~ "                                Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            updates++;\n"
+#~ "            for ( int i=0; i < propertyNames.length; i++ ) {\n"
+#~ "                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) "
+#~ "{\n"
+#~ "                    currentState[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onLoad(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            loads++;\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onSave(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            creates++;\n"
+#~ "            for ( int i=0; i<propertyNames.length; i++ ) {\n"
+#~ "                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
+#~ "                    state[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void afterTransactionCompletion(Transaction tx) {\n"
+#~ "        if ( tx.wasCommitted() ) {\n"
+#~ "            System.out.println(\"Creations: \" + creates + \", Updates: "
+#~ "\" + updates, \"Loads: \" + loads);\n"
+#~ "        }\n"
+#~ "        updates=0;\n"
+#~ "        creates=0;\n"
+#~ "        loads=0;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package org.hibernate.test;\n"
+#~ "\n"
+#~ "import java.io.Serializable;\n"
+#~ "import java.util.Date;\n"
+#~ "import java.util.Iterator;\n"
+#~ "\n"
+#~ "import org.hibernate.EmptyInterceptor;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.type.Type;\n"
+#~ "\n"
+#~ "public class AuditInterceptor extends EmptyInterceptor {\n"
+#~ "\n"
+#~ "    private int updates;\n"
+#~ "    private int creates;\n"
+#~ "    private int loads;\n"
+#~ "\n"
+#~ "    public void onDelete(Object entity,\n"
+#~ "                         Serializable id,\n"
+#~ "                         Object[] state,\n"
+#~ "                         String[] propertyNames,\n"
+#~ "                         Type[] types) {\n"
+#~ "        // do nothing\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onFlushDirty(Object entity,\n"
+#~ "                                Serializable id,\n"
+#~ "                                Object[] currentState,\n"
+#~ "                                Object[] previousState,\n"
+#~ "                                String[] propertyNames,\n"
+#~ "                                Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            updates++;\n"
+#~ "            for ( int i=0; i < propertyNames.length; i++ ) {\n"
+#~ "                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) "
+#~ "{\n"
+#~ "                    currentState[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onLoad(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            loads++;\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onSave(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            creates++;\n"
+#~ "            for ( int i=0; i<propertyNames.length; i++ ) {\n"
+#~ "                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
+#~ "                    state[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void afterTransactionCompletion(Transaction tx) {\n"
+#~ "        if ( tx.wasCommitted() ) {\n"
+#~ "            System.out.println(\"Creations: \" + creates + \", Updates: "
+#~ "\" + updates, \"Loads: \" + loads);\n"
+#~ "        }\n"
+#~ "        updates=0;\n"
+#~ "        creates=0;\n"
+#~ "        loads=0;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
 
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+#~ msgid ""
+#~ "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
+
+#~ msgid ""
+#~ "<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
+#~ msgstr ""
+#~ "<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
+
+#~ msgid ""
+#~ "<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
+#~ "    // this is the single method defined by the LoadEventListener "
+#~ "interface\n"
+#~ "    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
+#~ "loadType)\n"
+#~ "            throws HibernateException {\n"
+#~ "        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
+#~ "getEntityId() ) ) {\n"
+#~ "            throw MySecurityException(\"Unauthorized access\");\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
+#~ "    // this is the single method defined by the LoadEventListener "
+#~ "interface\n"
+#~ "    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
+#~ "loadType)\n"
+#~ "            throws HibernateException {\n"
+#~ "        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
+#~ "getEntityId() ) ) {\n"
+#~ "            throw MySecurityException(\"Unauthorized access\");\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-configuration>\n"
+#~ "    <session-factory>\n"
+#~ "        ...\n"
+#~ "        <event type=\"load\">\n"
+#~ "            <listener class=\"com.eg.MyLoadListener\"/>\n"
+#~ "            <listener class=\"org.hibernate.event.def."
+#~ "DefaultLoadEventListener\"/>\n"
+#~ "        </event>\n"
+#~ "    </session-factory>\n"
+#~ "</hibernate-configuration>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-configuration>\n"
+#~ "    <session-factory>\n"
+#~ "        ...\n"
+#~ "        <event type=\"load\">\n"
+#~ "            <listener class=\"com.eg.MyLoadListener\"/>\n"
+#~ "            <listener class=\"org.hibernate.event.def."
+#~ "DefaultLoadEventListener\"/>\n"
+#~ "        </event>\n"
+#~ "    </session-factory>\n"
+#~ "</hibernate-configuration>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Configuration cfg = new Configuration();\n"
+#~ "LoadEventListener[] stack = { new MyLoadListener(), new "
+#~ "DefaultLoadEventListener() };\n"
+#~ "cfg.EventListeners().setLoadEventListeners(stack);]]>"
+#~ msgstr ""
+#~ "<![CDATA[Configuration cfg = new Configuration();\n"
+#~ "LoadEventListener[] stack = { new MyLoadListener(), new "
+#~ "DefaultLoadEventListener() };\n"
+#~ "cfg.EventListeners().setLoadEventListeners(stack);]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
+#~ "JACCPreDeleteEventListener\"/>\n"
+#~ "<listener type=\"pre-update\" class=\"org.hibernate.secure."
+#~ "JACCPreUpdateEventListener\"/>\n"
+#~ "<listener type=\"pre-insert\" class=\"org.hibernate.secure."
+#~ "JACCPreInsertEventListener\"/>\n"
+#~ "<listener type=\"pre-load\" class=\"org.hibernate.secure."
+#~ "JACCPreLoadEventListener\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
+#~ "JACCPreDeleteEventListener\"/>\n"
+#~ "<listener type=\"pre-update\" class=\"org.hibernate.secure."
+#~ "JACCPreUpdateEventListener\"/>\n"
+#~ "<listener type=\"pre-insert\" class=\"org.hibernate.secure."
+#~ "JACCPreInsertEventListener\"/>\n"
+#~ "<listener type=\"pre-load\" class=\"org.hibernate.secure."
+#~ "JACCPreLoadEventListener\"/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,"
+#~ "update,read\"/>\n"
+#~ "<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,"
+#~ "update,read\"/>\n"
+#~ "<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/example_mappings.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/example_mappings.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/example_mappings.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,34 +1,46 @@
-#, fuzzy
+# translation of example_mappings.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: example_mappings\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-11-03 12:36+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: example_mappings.xml:29
 #, no-c-format
 msgid "Example: Various Mappings"
-msgstr "Ejemplo: Varios Mapeos"
+msgstr "Ejemplo: mapeos varios"
 
 #. Tag: para
-#: example_mappings.xml:32
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This chapters explores some more complex association mappings."
 msgstr ""
-"Este cap&#x00ed;tulo muestra mapeos de asociaciones m&#x00e1;s complejos."
+"Este capítulo explora algunos de los mapeos de asociaciones más complejos."
 
 #. Tag: title
-#: example_mappings.xml:37
 #, no-c-format
 msgid "Employer/Employee"
 msgstr "Empleador/Empleado"
 
 #. Tag: para
-#: example_mappings.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following model of the relationship between <literal>Employer</literal> "
 "and <literal>Employee</literal> uses an entity class (<literal>Employment</"
@@ -36,218 +48,31 @@
 "more than one period of employment for the same two parties. Components are "
 "used to model monetary values and employee names."
 msgstr ""
-"El siguiente modelo de la relaci&#x00f3;n entre <literal>Employer</literal> "
-"y <literal>Employee</literal> usa una clase de entidad real "
-"(<literal>Employment</literal>) para representar la asociaci&#x00f3;n. Esto "
-"se ha hecho esto porque podr&#x00ed;a haber m&#x00e1;s de un per&#x00ed;odo "
-"de empleo para los mismos dos participantes. Se usan componentes para "
-"modelar valores monetarios y nombres de empleado."
+"El siguiente modelo de la relación entre <literal>Employer</literal> y "
+"<literal>Employee</literal> utiliza una clase de entidad "
+"(<literal>Employment</literal>) para representar la asociación. Puede hacer "
+"esto cuando podría haber más de un período de empleo para los dos mismos "
+"participantes. Se utilizan componentes para modelar los valores monetarios y "
+"los nombres de los empleados."
 
 #. Tag: para
-#: example_mappings.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is a possible mapping document:"
-msgstr "He aqu&#x00ed; un documento de mapeo posible:"
+msgstr "He aquí un posible documento de mapeo: "
 
-#. Tag: programlisting
-#: example_mappings.xml:60
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"        \n"
-"    <class name=\"Employer\" table=\"employers\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employer_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Employment\" table=\"employment_periods\">\n"
-"\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employment_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"startDate\" column=\"start_date\"/>\n"
-"        <property name=\"endDate\" column=\"end_date\"/>\n"
-"\n"
-"        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
-"            <property name=\"amount\">\n"
-"                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/>\n"
-"            </property>\n"
-"            <property name=\"currency\" length=\"12\"/>\n"
-"        </component>\n"
-"\n"
-"        <many-to-one name=\"employer\" column=\"employer_id\" not-null=\"true"
-"\"/>\n"
-"        <many-to-one name=\"employee\" column=\"employee_id\" not-null=\"true"
-"\"/>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Employee\" table=\"employees\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employee_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"taxfileNumber\"/>\n"
-"        <component name=\"name\" class=\"Name\">\n"
-"            <property name=\"firstName\"/>\n"
-"            <property name=\"initial\"/>\n"
-"            <property name=\"lastName\"/>\n"
-"        </component>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<hibernate-mapping>\n"
-"        \n"
-"    <class name=\"Employer\" table=\"employers\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employer_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Employment\" table=\"employment_periods\">\n"
-"\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employment_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"startDate\" column=\"start_date\"/>\n"
-"        <property name=\"endDate\" column=\"end_date\"/>\n"
-"\n"
-"        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
-"            <property name=\"amount\">\n"
-"                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/>\n"
-"            </property>\n"
-"            <property name=\"currency\" length=\"12\"/>\n"
-"        </component>\n"
-"\n"
-"        <many-to-one name=\"employer\" column=\"employer_id\" not-null=\"true"
-"\"/>\n"
-"        <many-to-one name=\"employee\" column=\"employee_id\" not-null=\"true"
-"\"/>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Employee\" table=\"employees\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employee_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"taxfileNumber\"/>\n"
-"        <component name=\"name\" class=\"Name\">\n"
-"            <property name=\"firstName\"/>\n"
-"            <property name=\"initial\"/>\n"
-"            <property name=\"lastName\"/>\n"
-"        </component>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-
 #. Tag: para
-#: example_mappings.xml:62
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is the table schema generated by <literal>SchemaExport</literal>."
 msgstr ""
-"Y he aqu&#x00ed; el esquema de tablas generado por <literal>SchemaExport</"
-"literal>."
+"Este es el esquema de tablas generado por <literal>SchemaExport</literal>."
 
-#. Tag: programlisting
-#: example_mappings.xml:66
-#, no-c-format
-msgid ""
-"<![CDATA[create table employers (\n"
-"    id BIGINT not null, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table employment_periods (\n"
-"    id BIGINT not null,\n"
-"    hourly_rate NUMERIC(12, 2),\n"
-"    currency VARCHAR(12), \n"
-"    employee_id BIGINT not null, \n"
-"    employer_id BIGINT not null, \n"
-"    end_date TIMESTAMP, \n"
-"    start_date TIMESTAMP, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table employees (\n"
-"    id BIGINT not null, \n"
-"    firstName VARCHAR(255), \n"
-"    initial CHAR(1), \n"
-"    lastName VARCHAR(255), \n"
-"    taxfileNumber VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table employment_periods \n"
-"    add constraint employment_periodsFK0 foreign key (employer_id) "
-"references employers\n"
-"alter table employment_periods \n"
-"    add constraint employment_periodsFK1 foreign key (employee_id) "
-"references employees\n"
-"create sequence employee_id_seq\n"
-"create sequence employment_id_seq\n"
-"create sequence employer_id_seq]]>"
-msgstr ""
-"<![CDATA[create table employers (\n"
-"    id BIGINT not null, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table employment_periods (\n"
-"    id BIGINT not null,\n"
-"    hourly_rate NUMERIC(12, 2),\n"
-"    currency VARCHAR(12), \n"
-"    employee_id BIGINT not null, \n"
-"    employer_id BIGINT not null, \n"
-"    end_date TIMESTAMP, \n"
-"    start_date TIMESTAMP, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table employees (\n"
-"    id BIGINT not null, \n"
-"    firstName VARCHAR(255), \n"
-"    initial CHAR(1), \n"
-"    lastName VARCHAR(255), \n"
-"    taxfileNumber VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table employment_periods \n"
-"    add constraint employment_periodsFK0 foreign key (employer_id) "
-"references employers\n"
-"alter table employment_periods \n"
-"    add constraint employment_periodsFK1 foreign key (employee_id) "
-"references employees\n"
-"create sequence employee_id_seq\n"
-"create sequence employment_id_seq\n"
-"create sequence employer_id_seq]]>"
-
 #. Tag: title
-#: example_mappings.xml:71
 #, no-c-format
 msgid "Author/Work"
 msgstr "Autor/Obra"
 
 #. Tag: para
-#: example_mappings.xml:73
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Consider the following model of the relationships between <literal>Work</"
 "literal>, <literal>Author</literal> and <literal>Person</literal>. In the "
@@ -257,232 +82,44 @@
 "literal> is represented as one-to-one association. Another possibility would "
 "be to have <literal>Author</literal> extend <literal>Person</literal>."
 msgstr ""
-"Considera el siguiente modelo de las relaciones entre <literal>Work</"
-"literal>, <literal>Author</literal> y <literal>Person</literal>. "
-"Representamos la relaci&#x00f3;n entre <literal>Work</literal> y "
-"<literal>Author</literal> como una asociaci&#x00f3;n muchos-a-muchos. "
-"Elegimos representar la relaci&#x00f3;n entre <literal>Author</literal> y "
-"<literal>Person</literal> como una asociaci&#x00f3;n uno-a-uno. Otra "
-"posibilidad hubiese sido que <literal>Author</literal> extendiera "
-"<literal>Person</literal>."
+"Considere el siguiente modelo de las relaciones entre <literal>Work</"
+"literal>, <literal>Author</literal> y <literal>Person</literal>. En el "
+"ejemplo representamos la relación entre <literal>Work</literal> y "
+"<literal>Author</literal> como una asociación muchos-a-muchos y la relación "
+"entre <literal>Author</literal> y <literal>Person</literal> como una "
+"asociación uno-a-uno. Otra posibilidad sería que <literal>Author</literal> "
+"extendiera <literal>Person</literal>."
 
 #. Tag: para
-#: example_mappings.xml:91
 #, no-c-format
 msgid ""
 "The following mapping document correctly represents these relationships:"
 msgstr ""
-"El siguiente documento de mapeo representa estas relaciones correctamente:"
+"El siguiente documento de mapeo representa estas relaciones de manera "
+"correcta:"
 
-#. Tag: programlisting
-#: example_mappings.xml:95
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
-"\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <discriminator column=\"type\" type=\"character\"/>\n"
-"\n"
-"        <property name=\"title\"/>\n"
-"        <set name=\"authors\" table=\"author_work\">\n"
-"            <key column name=\"work_id\"/>\n"
-"            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
-"        </set>\n"
-"\n"
-"        <subclass name=\"Book\" discriminator-value=\"B\">\n"
-"            <property name=\"text\"/>\n"
-"        </subclass>\n"
-"\n"
-"        <subclass name=\"Song\" discriminator-value=\"S\">\n"
-"            <property name=\"tempo\"/>\n"
-"            <property name=\"genre\"/>\n"
-"        </subclass>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Author\" table=\"authors\">\n"
-"\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <!-- The Author must have the same identifier as the Person -->\n"
-"            <generator class=\"assigned\"/> \n"
-"        </id>\n"
-"\n"
-"        <property name=\"alias\"/>\n"
-"        <one-to-one name=\"person\" constrained=\"true\"/>\n"
-"\n"
-"        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
-"            <key column=\"author_id\"/>\n"
-"            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
-"        </set>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Person\" table=\"persons\">\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
-"\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <discriminator column=\"type\" type=\"character\"/>\n"
-"\n"
-"        <property name=\"title\"/>\n"
-"        <set name=\"authors\" table=\"author_work\">\n"
-"            <key column name=\"work_id\"/>\n"
-"            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
-"        </set>\n"
-"\n"
-"        <subclass name=\"Book\" discriminator-value=\"B\">\n"
-"            <property name=\"text\"/>\n"
-"        </subclass>\n"
-"\n"
-"        <subclass name=\"Song\" discriminator-value=\"S\">\n"
-"            <property name=\"tempo\"/>\n"
-"            <property name=\"genre\"/>\n"
-"        </subclass>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Author\" table=\"authors\">\n"
-"\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <!-- The Author must have the same identifier as the Person -->\n"
-"            <generator class=\"assigned\"/> \n"
-"        </id>\n"
-"\n"
-"        <property name=\"alias\"/>\n"
-"        <one-to-one name=\"person\" constrained=\"true\"/>\n"
-"\n"
-"        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
-"            <key column=\"author_id\"/>\n"
-"            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
-"        </set>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Person\" table=\"persons\">\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-
-#. Tag: para
-#: example_mappings.xml:97
-#, fuzzy, no-c-format
-msgid ""
 "There are four tables in this mapping: <literal>works</literal>, "
 "<literal>authors</literal> and <literal>persons</literal> hold work, author "
 "and person data respectively. <literal>author_work</literal> is an "
 "association table linking authors to works. Here is the table schema, as "
 "generated by <literal>SchemaExport</literal>:"
 msgstr ""
-"Hay cuatro tablas en este mapeo. <literal>works</literal>, <literal>authors</"
+"Hay cuatro tablas en este mapeo: <literal>works</literal>, <literal>authors</"
 "literal> y <literal>persons</literal> tienen los datos de obra, autor y "
 "persona respectivamente. <literal>author_work</literal> es una tabla de "
-"asociaci&#x00f3;n enlazando autores a obras. He aqu&#x00ed; el esquema de "
-"tablas, tal como fue generado por <literal>SchemaExport</literal>."
+"asociación enlazando los autores a las obras. Este es el esquema de tablas, "
+"tal como fue generado por <literal>SchemaExport</literal>:"
 
-#. Tag: programlisting
-#: example_mappings.xml:105
-#, no-c-format
-msgid ""
-"<![CDATA[create table works (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    tempo FLOAT, \n"
-"    genre VARCHAR(255), \n"
-"    text INTEGER, \n"
-"    title VARCHAR(255), \n"
-"    type CHAR(1) not null, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table author_work (\n"
-"    author_id BIGINT not null, \n"
-"    work_id BIGINT not null, \n"
-"    primary key (work_id, author_id)\n"
-")\n"
-"\n"
-"create table authors (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    alias VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table persons (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table authors \n"
-"    add constraint authorsFK0 foreign key (id) references persons\n"
-"alter table author_work \n"
-"    add constraint author_workFK0 foreign key (author_id) references "
-"authors\n"
-"alter table author_work\n"
-"    add constraint author_workFK1 foreign key (work_id) references works]]>"
-msgstr ""
-"<![CDATA[create table works (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    tempo FLOAT, \n"
-"    genre VARCHAR(255), \n"
-"    text INTEGER, \n"
-"    title VARCHAR(255), \n"
-"    type CHAR(1) not null, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table author_work (\n"
-"    author_id BIGINT not null, \n"
-"    work_id BIGINT not null, \n"
-"    primary key (work_id, author_id)\n"
-")\n"
-"\n"
-"create table authors (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    alias VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table persons (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table authors \n"
-"    add constraint authorsFK0 foreign key (id) references persons\n"
-"alter table author_work \n"
-"    add constraint author_workFK0 foreign key (author_id) references "
-"authors\n"
-"alter table author_work\n"
-"    add constraint author_workFK1 foreign key (work_id) references works]]>"
-
 #. Tag: title
-#: example_mappings.xml:110
 #, no-c-format
 msgid "Customer/Order/Product"
 msgstr "Cliente/Orden/Producto"
 
 #. Tag: para
-#: example_mappings.xml:112
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In this section we consider a model of the relationships between "
 "<literal>Customer</literal>, <literal>Order</literal>, <literal>Line Item</"
@@ -494,105 +131,22 @@
 "between <literal>Order</literal> and <literal>Product</literal>. In "
 "Hibernate this is called a composite element."
 msgstr ""
-"Ahora considera un modelo de las relaciones entre <literal>Customer</"
-"literal>, <literal>Order</literal> y <literal>LineItem</literal> y "
-"<literal>Product</literal>. Hay una asociaci&#x00f3;n uno-a-muchos entre "
-"<literal>Customer</literal> y <literal>Order</literal>, pero, &#x00bf;"
-"c&#x00f3;mo deber&#x00ed;amos representar <literal>Order</literal> / "
-"<literal>LineItem</literal> / <literal>Product</literal>? He elegido mapear "
-"<literal>LineItem</literal> como una clase de asociaci&#x00f3;n "
-"representando la asociaci&#x00f3;n muchos-a-muchos entre <literal>Order</"
-"literal> y <literal>Product</literal>. En Hibernate, esto se llama un "
-"elemento compuesto."
+"En esta sección consideramos un modelo de las relaciones entre "
+"<literal>Customer</literal>, <literal>Order</literal>, <literal>Line Item</"
+"literal> y <literal>Product</literal>. Hay una asociación uno-a-muchos entre "
+"<literal>Customer</literal> y <literal>Order</literal>, pero, ¿cómo "
+"deberíamos representar <literal>Order</literal> / <literal>LineItem</"
+"literal> / <literal>Product</literal>? En el ejemplo, <literal>LineItem</"
+"literal> se mapea como una clase de asociación representando la asociación "
+"muchos-a-muchos entre <literal>Order</literal> y <literal>Product</literal>. "
+"En Hibernate, esto se llama un elemento compuesto."
 
 #. Tag: para
-#: example_mappings.xml:132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The mapping document will look like this:"
-msgstr "El documento de mapeo:"
+msgstr "El documento de mapeo se verá así:"
 
-#. Tag: programlisting
-#: example_mappings.xml:136
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Customer\" table=\"customers\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"        <set name=\"orders\" inverse=\"true\">\n"
-"            <key column=\"customer_id\"/>\n"
-"            <one-to-many class=\"Order\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Order\" table=\"orders\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"date\"/>\n"
-"        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
-"        <list name=\"lineItems\" table=\"line_items\">\n"
-"            <key column=\"order_id\"/>\n"
-"            <list-index column=\"line_number\"/>\n"
-"            <composite-element class=\"LineItem\">\n"
-"                <property name=\"quantity\"/>\n"
-"                <many-to-one name=\"product\" column=\"product_id\"/>\n"
-"            </composite-element>\n"
-"        </list>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Product\" table=\"products\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"serialNumber\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Customer\" table=\"customers\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"        <set name=\"orders\" inverse=\"true\">\n"
-"            <key column=\"customer_id\"/>\n"
-"            <one-to-many class=\"Order\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Order\" table=\"orders\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"date\"/>\n"
-"        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
-"        <list name=\"lineItems\" table=\"line_items\">\n"
-"            <key column=\"order_id\"/>\n"
-"            <list-index column=\"line_number\"/>\n"
-"            <composite-element class=\"LineItem\">\n"
-"                <property name=\"quantity\"/>\n"
-"                <many-to-one name=\"product\" column=\"product_id\"/>\n"
-"            </composite-element>\n"
-"        </list>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Product\" table=\"products\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"serialNumber\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-
 #. Tag: para
-#: example_mappings.xml:138
 #, no-c-format
 msgid ""
 "<literal>customers</literal>, <literal>orders</literal>, "
@@ -602,714 +156,1120 @@
 msgstr ""
 "<literal>customers</literal>, <literal>orders</literal>, "
 "<literal>line_items</literal> y <literal>products</literal> tienen los datos "
-"de cliente, orden, &#x00ed;tem de l&#x00ed;nea de orden y producto "
-"respectivamente. Adem&#x00e1;s <literal>line_items</literal> act&#x00fa;a "
-"como una tabla de asociaci&#x00f3;n enlazando &#x00f3;rdenes con productos."
+"de cliente, orden, ítem de línea de orden y producto respectivamente. Además "
+"<literal>line_items</literal> también actúa como una tabla de asociación "
+"enlazando órdenes con productos."
 
-#. Tag: programlisting
-#: example_mappings.xml:145
-#, no-c-format
-msgid ""
-"<![CDATA[create table customers (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table orders (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    customer_id BIGINT, \n"
-"    date TIMESTAMP, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table line_items (\n"
-"    line_number INTEGER not null, \n"
-"    order_id BIGINT not null, \n"
-"    product_id BIGINT, \n"
-"    quantity INTEGER, \n"
-"    primary key (order_id, line_number)\n"
-")\n"
-"\n"
-"create table products (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    serialNumber VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table orders \n"
-"    add constraint ordersFK0 foreign key (customer_id) references customers\n"
-"alter table line_items\n"
-"    add constraint line_itemsFK0 foreign key (product_id) references "
-"products\n"
-"alter table line_items\n"
-"    add constraint line_itemsFK1 foreign key (order_id) references orders]]>"
-msgstr ""
-"<![CDATA[create table customers (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table orders (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    customer_id BIGINT, \n"
-"    date TIMESTAMP, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table line_items (\n"
-"    line_number INTEGER not null, \n"
-"    order_id BIGINT not null, \n"
-"    product_id BIGINT, \n"
-"    quantity INTEGER, \n"
-"    primary key (order_id, line_number)\n"
-")\n"
-"\n"
-"create table products (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    serialNumber VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table orders \n"
-"    add constraint ordersFK0 foreign key (customer_id) references customers\n"
-"alter table line_items\n"
-"    add constraint line_itemsFK0 foreign key (product_id) references "
-"products\n"
-"alter table line_items\n"
-"    add constraint line_itemsFK1 foreign key (order_id) references orders]]>"
-
 #. Tag: title
-#: example_mappings.xml:150
 #, no-c-format
 msgid "Miscellaneous example mappings"
-msgstr "Mapeos miscel&#x00e1;neos de ejemplo"
+msgstr "Mapeos varios de ejemplo"
 
 #. Tag: para
-#: example_mappings.xml:152
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These examples are available from the Hibernate test suite. You will find "
 "many other useful example mappings there by searching in the <literal>test</"
 "literal> folder of the Hibernate distribution."
 msgstr ""
-"Todos estos ejemplos est&#x00e1;n tomados de la bater&#x00ed;a de pruebas de "
-"Hibernate. Encontrar&#x00e1;s muchos otros mapeos de ejemplo &#x00fa;tiles "
-"all&#x00ed;. Mira en la carpeta <literal>test</literal> de la "
-"distribuci&#x00f3;n de Hibernate."
+"Estos ejemplos están disponibles en la suite de pruebas de Hibernate. Allí "
+"encontrará muchos otros mapeos de ejemplos útiles en la carpeta "
+"<literal>test</literal> de la distribución de Hibernate."
 
 #. Tag: title
-#: example_mappings.xml:161
 #, no-c-format
 msgid "\"Typed\" one-to-one association"
-msgstr "Asociaci&#x00f3;n uno-a-uno \"Tipificada\""
+msgstr "Asociación uno-a-uno \"Tipificada\""
 
-#. Tag: programlisting
-#: example_mappings.xml:162
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"name\"/>\n"
-"    <one-to-one name=\"address\" \n"
-"            cascade=\"all\">\n"
-"        <formula>name</formula>\n"
-"        <formula>'HOME'</formula>\n"
-"    </one-to-one>\n"
-"    <one-to-one name=\"mailingAddress\" \n"
-"            cascade=\"all\">\n"
-"        <formula>name</formula>\n"
-"        <formula>'MAILING'</formula>\n"
-"    </one-to-one>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\" batch-size=\"2\" \n"
-"        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
-"    <composite-id>\n"
-"        <key-many-to-one name=\"person\" \n"
-"                column=\"personName\"/>\n"
-"        <key-property name=\"type\" \n"
-"                column=\"addressType\"/>\n"
-"    </composite-id>\n"
-"    <property name=\"street\" type=\"text\"/>\n"
-"    <property name=\"state\"/>\n"
-"    <property name=\"zip\"/>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"name\"/>\n"
-"    <one-to-one name=\"address\" \n"
-"            cascade=\"all\">\n"
-"        <formula>name</formula>\n"
-"        <formula>'HOME'</formula>\n"
-"    </one-to-one>\n"
-"    <one-to-one name=\"mailingAddress\" \n"
-"            cascade=\"all\">\n"
-"        <formula>name</formula>\n"
-"        <formula>'MAILING'</formula>\n"
-"    </one-to-one>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\" batch-size=\"2\" \n"
-"        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
-"    <composite-id>\n"
-"        <key-many-to-one name=\"person\" \n"
-"                column=\"personName\"/>\n"
-"        <key-property name=\"type\" \n"
-"                column=\"addressType\"/>\n"
-"    </composite-id>\n"
-"    <property name=\"street\" type=\"text\"/>\n"
-"    <property name=\"state\"/>\n"
-"    <property name=\"zip\"/>\n"
-"</class>]]>"
-
 #. Tag: title
-#: example_mappings.xml:166
 #, no-c-format
 msgid "Composite key example"
 msgstr "Ejemplo de clave compuesta"
 
-#. Tag: programlisting
-#: example_mappings.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Customer\">\n"
-"\n"
-"    <id name=\"customerId\"\n"
-"        length=\"10\">\n"
-"        <generator class=\"assigned\"/>\n"
-"    </id>\n"
-"\n"
-"    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
-"    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
-"\n"
-"    <list name=\"orders\"\n"
-"            inverse=\"true\"\n"
-"            cascade=\"save-update\">\n"
-"        <key column=\"customerId\"/>\n"
-"        <index column=\"orderNumber\"/>\n"
-"        <one-to-many class=\"Order\"/>\n"
-"    </list>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
-"    <synchronize table=\"LineItem\"/>\n"
-"    <synchronize table=\"Product\"/>\n"
-"    \n"
-"    <composite-id name=\"id\" \n"
-"            class=\"Order$Id\">\n"
-"        <key-property name=\"customerId\" length=\"10\"/>\n"
-"        <key-property name=\"orderNumber\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"orderDate\" \n"
-"            type=\"calendar_date\"\n"
-"            not-null=\"true\"/>\n"
-"    \n"
-"    <property name=\"total\">\n"
-"        <formula>\n"
-"            ( select sum(li.quantity*p.price) \n"
-"            from LineItem li, Product p \n"
-"            where li.productId = p.productId \n"
-"                and li.customerId = customerId \n"
-"                and li.orderNumber = orderNumber )\n"
-"        </formula>\n"
-"    </property>\n"
-"    \n"
-"    <many-to-one name=\"customer\"\n"
-"            column=\"customerId\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\"/>\n"
-"        \n"
-"    <bag name=\"lineItems\"\n"
-"            fetch=\"join\" \n"
-"            inverse=\"true\"\n"
-"            cascade=\"save-update\">\n"
-"        <key>\n"
-"            <column name=\"customerId\"/>\n"
-"            <column name=\"orderNumber\"/>\n"
-"        </key>\n"
-"        <one-to-many class=\"LineItem\"/>\n"
-"    </bag>\n"
-"    \n"
-"</class>\n"
-"    \n"
-"<class name=\"LineItem\">\n"
-"    \n"
-"    <composite-id name=\"id\" \n"
-"            class=\"LineItem$Id\">\n"
-"        <key-property name=\"customerId\" length=\"10\"/>\n"
-"        <key-property name=\"orderNumber\"/>\n"
-"        <key-property name=\"productId\" length=\"10\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"quantity\"/>\n"
-"    \n"
-"    <many-to-one name=\"order\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\">\n"
-"        <column name=\"customerId\"/>\n"
-"        <column name=\"orderNumber\"/>\n"
-"    </many-to-one>\n"
-"    \n"
-"    <many-to-one name=\"product\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\"\n"
-"            column=\"productId\"/>\n"
-"        \n"
-"</class>\n"
-"\n"
-"<class name=\"Product\">\n"
-"    <synchronize table=\"LineItem\"/>\n"
-"\n"
-"    <id name=\"productId\"\n"
-"        length=\"10\">\n"
-"        <generator class=\"assigned\"/>\n"
-"    </id>\n"
-"    \n"
-"    <property name=\"description\" \n"
-"        not-null=\"true\" \n"
-"        length=\"200\"/>\n"
-"    <property name=\"price\" length=\"3\"/>\n"
-"    <property name=\"numberAvailable\"/>\n"
-"    \n"
-"    <property name=\"numberOrdered\">\n"
-"        <formula>\n"
-"            ( select sum(li.quantity) \n"
-"            from LineItem li \n"
-"            where li.productId = productId )\n"
-"        </formula>\n"
-"    </property>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Customer\">\n"
-"\n"
-"    <id name=\"customerId\"\n"
-"        length=\"10\">\n"
-"        <generator class=\"assigned\"/>\n"
-"    </id>\n"
-"\n"
-"    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
-"    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
-"\n"
-"    <list name=\"orders\"\n"
-"            inverse=\"true\"\n"
-"            cascade=\"save-update\">\n"
-"        <key column=\"customerId\"/>\n"
-"        <index column=\"orderNumber\"/>\n"
-"        <one-to-many class=\"Order\"/>\n"
-"    </list>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
-"    <synchronize table=\"LineItem\"/>\n"
-"    <synchronize table=\"Product\"/>\n"
-"    \n"
-"    <composite-id name=\"id\" \n"
-"            class=\"Order$Id\">\n"
-"        <key-property name=\"customerId\" length=\"10\"/>\n"
-"        <key-property name=\"orderNumber\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"orderDate\" \n"
-"            type=\"calendar_date\"\n"
-"            not-null=\"true\"/>\n"
-"    \n"
-"    <property name=\"total\">\n"
-"        <formula>\n"
-"            ( select sum(li.quantity*p.price) \n"
-"            from LineItem li, Product p \n"
-"            where li.productId = p.productId \n"
-"                and li.customerId = customerId \n"
-"                and li.orderNumber = orderNumber )\n"
-"        </formula>\n"
-"    </property>\n"
-"    \n"
-"    <many-to-one name=\"customer\"\n"
-"            column=\"customerId\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\"/>\n"
-"        \n"
-"    <bag name=\"lineItems\"\n"
-"            fetch=\"join\" \n"
-"            inverse=\"true\"\n"
-"            cascade=\"save-update\">\n"
-"        <key>\n"
-"            <column name=\"customerId\"/>\n"
-"            <column name=\"orderNumber\"/>\n"
-"        </key>\n"
-"        <one-to-many class=\"LineItem\"/>\n"
-"    </bag>\n"
-"    \n"
-"</class>\n"
-"    \n"
-"<class name=\"LineItem\">\n"
-"    \n"
-"    <composite-id name=\"id\" \n"
-"            class=\"LineItem$Id\">\n"
-"        <key-property name=\"customerId\" length=\"10\"/>\n"
-"        <key-property name=\"orderNumber\"/>\n"
-"        <key-property name=\"productId\" length=\"10\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"quantity\"/>\n"
-"    \n"
-"    <many-to-one name=\"order\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\">\n"
-"        <column name=\"customerId\"/>\n"
-"        <column name=\"orderNumber\"/>\n"
-"    </many-to-one>\n"
-"    \n"
-"    <many-to-one name=\"product\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\"\n"
-"            column=\"productId\"/>\n"
-"        \n"
-"</class>\n"
-"\n"
-"<class name=\"Product\">\n"
-"    <synchronize table=\"LineItem\"/>\n"
-"\n"
-"    <id name=\"productId\"\n"
-"        length=\"10\">\n"
-"        <generator class=\"assigned\"/>\n"
-"    </id>\n"
-"    \n"
-"    <property name=\"description\" \n"
-"        not-null=\"true\" \n"
-"        length=\"200\"/>\n"
-"    <property name=\"price\" length=\"3\"/>\n"
-"    <property name=\"numberAvailable\"/>\n"
-"    \n"
-"    <property name=\"numberOrdered\">\n"
-"        <formula>\n"
-"            ( select sum(li.quantity) \n"
-"            from LineItem li \n"
-"            where li.productId = productId )\n"
-"        </formula>\n"
-"    </property>\n"
-"    \n"
-"</class>]]>"
-
 #. Tag: title
-#: example_mappings.xml:171
 #, no-c-format
 msgid "Many-to-many with shared composite key attribute"
-msgstr "Muchos-a-muchos con atributo de clave compuesta compartido"
+msgstr "Muchos-a-muchos con atributo compartido de clave compuesta"
 
-#. Tag: programlisting
-#: example_mappings.xml:172
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"User\" table=\"`User`\">\n"
-"    <composite-id>\n"
-"        <key-property name=\"name\"/>\n"
-"        <key-property name=\"org\"/>\n"
-"    </composite-id>\n"
-"    <set name=\"groups\" table=\"UserGroup\">\n"
-"        <key>\n"
-"            <column name=\"userName\"/>\n"
-"            <column name=\"org\"/>\n"
-"        </key>\n"
-"        <many-to-many class=\"Group\">\n"
-"            <column name=\"groupName\"/>\n"
-"            <formula>org</formula>\n"
-"        </many-to-many>\n"
-"    </set>\n"
-"</class>\n"
-"    \n"
-"<class name=\"Group\" table=\"`Group`\">\n"
-"    <composite-id>\n"
-"        <key-property name=\"name\"/>\n"
-"        <key-property name=\"org\"/>\n"
-"    </composite-id>\n"
-"    <property name=\"description\"/>\n"
-"    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
-"        <key>\n"
-"            <column name=\"groupName\"/>\n"
-"            <column name=\"org\"/>\n"
-"        </key>\n"
-"        <many-to-many class=\"User\">\n"
-"            <column name=\"userName\"/>\n"
-"            <formula>org</formula>\n"
-"        </many-to-many>\n"
-"    </set>\n"
-"</class>\n"
-"]]>"
-msgstr ""
-"<![CDATA[<class name=\"User\" table=\"`User`\">\n"
-"    <composite-id>\n"
-"        <key-property name=\"name\"/>\n"
-"        <key-property name=\"org\"/>\n"
-"    </composite-id>\n"
-"    <set name=\"groups\" table=\"UserGroup\">\n"
-"        <key>\n"
-"            <column name=\"userName\"/>\n"
-"            <column name=\"org\"/>\n"
-"        </key>\n"
-"        <many-to-many class=\"Group\">\n"
-"            <column name=\"groupName\"/>\n"
-"            <formula>org</formula>\n"
-"        </many-to-many>\n"
-"    </set>\n"
-"</class>\n"
-"    \n"
-"<class name=\"Group\" table=\"`Group`\">\n"
-"    <composite-id>\n"
-"        <key-property name=\"name\"/>\n"
-"        <key-property name=\"org\"/>\n"
-"    </composite-id>\n"
-"    <property name=\"description\"/>\n"
-"    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
-"        <key>\n"
-"            <column name=\"groupName\"/>\n"
-"            <column name=\"org\"/>\n"
-"        </key>\n"
-"        <many-to-many class=\"User\">\n"
-"            <column name=\"userName\"/>\n"
-"            <formula>org</formula>\n"
-"        </many-to-many>\n"
-"    </set>\n"
-"</class>\n"
-"]]>"
-
 #. Tag: title
-#: example_mappings.xml:176
 #, no-c-format
 msgid "Content based discrimination"
-msgstr "Discriminaci&#x00f3;n basada en contenido"
+msgstr "Discriminación basada en contenido"
 
-#. Tag: programlisting
-#: example_mappings.xml:177
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\"\n"
-"    discriminator-value=\"P\">\n"
-"    \n"
-"    <id name=\"id\" \n"
-"        column=\"person_id\" \n"
-"        unsaved-value=\"0\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    \n"
-"            \n"
-"    <discriminator \n"
-"        type=\"character\">\n"
-"        <formula>\n"
-"            case \n"
-"                when title is not null then 'E' \n"
-"                when salesperson is not null then 'C' \n"
-"                else 'P' \n"
-"            end\n"
-"        </formula>\n"
-"    </discriminator>\n"
-"\n"
-"    <property name=\"name\" \n"
-"        not-null=\"true\"\n"
-"        length=\"80\"/>\n"
-"        \n"
-"    <property name=\"sex\" \n"
-"        not-null=\"true\"\n"
-"        update=\"false\"/>\n"
-"    \n"
-"    <component name=\"address\">\n"
-"        <property name=\"address\"/>\n"
-"        <property name=\"zip\"/>\n"
-"        <property name=\"country\"/>\n"
-"    </component>\n"
-"    \n"
-"    <subclass name=\"Employee\" \n"
-"        discriminator-value=\"E\">\n"
-"            <property name=\"title\"\n"
-"                length=\"20\"/>\n"
-"            <property name=\"salary\"/>\n"
-"            <many-to-one name=\"manager\"/>\n"
-"    </subclass>\n"
-"    \n"
-"    <subclass name=\"Customer\" \n"
-"        discriminator-value=\"C\">\n"
-"            <property name=\"comments\"/>\n"
-"            <many-to-one name=\"salesperson\"/>\n"
-"    </subclass>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\"\n"
-"    discriminator-value=\"P\">\n"
-"    \n"
-"    <id name=\"id\" \n"
-"        column=\"person_id\" \n"
-"        unsaved-value=\"0\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    \n"
-"            \n"
-"    <discriminator \n"
-"        type=\"character\">\n"
-"        <formula>\n"
-"            case \n"
-"                when title is not null then 'E' \n"
-"                when salesperson is not null then 'C' \n"
-"                else 'P' \n"
-"            end\n"
-"        </formula>\n"
-"    </discriminator>\n"
-"\n"
-"    <property name=\"name\" \n"
-"        not-null=\"true\"\n"
-"        length=\"80\"/>\n"
-"        \n"
-"    <property name=\"sex\" \n"
-"        not-null=\"true\"\n"
-"        update=\"false\"/>\n"
-"    \n"
-"    <component name=\"address\">\n"
-"        <property name=\"address\"/>\n"
-"        <property name=\"zip\"/>\n"
-"        <property name=\"country\"/>\n"
-"    </component>\n"
-"    \n"
-"    <subclass name=\"Employee\" \n"
-"        discriminator-value=\"E\">\n"
-"            <property name=\"title\"\n"
-"                length=\"20\"/>\n"
-"            <property name=\"salary\"/>\n"
-"            <many-to-one name=\"manager\"/>\n"
-"    </subclass>\n"
-"    \n"
-"    <subclass name=\"Customer\" \n"
-"        discriminator-value=\"C\">\n"
-"            <property name=\"comments\"/>\n"
-"            <many-to-one name=\"salesperson\"/>\n"
-"    </subclass>\n"
-"    \n"
-"</class>]]>"
-
 #. Tag: title
-#: example_mappings.xml:181
 #, no-c-format
 msgid "Associations on alternate keys"
 msgstr "Asociaciones sobre claves alternativas"
 
-#. Tag: programlisting
-#: example_mappings.xml:182
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    \n"
-"    <id name=\"id\">\n"
-"        <generator class=\"hilo\"/>\n"
-"    </id>\n"
-"    \n"
-"    <property name=\"name\" length=\"100\"/>\n"
-"    \n"
-"    <one-to-one name=\"address\" \n"
-"        property-ref=\"person\"\n"
-"        cascade=\"all\"\n"
-"        fetch=\"join\"/>\n"
-"    \n"
-"    <set name=\"accounts\" \n"
-"        inverse=\"true\">\n"
-"        <key column=\"userId\"\n"
-"            property-ref=\"userId\"/>\n"
-"        <one-to-many class=\"Account\"/>\n"
-"    </set>\n"
-"    \n"
-"    <property name=\"userId\" length=\"8\"/>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"hilo\"/>\n"
-"    </id>\n"
-"\n"
-"    <property name=\"address\" length=\"300\"/>\n"
-"    <property name=\"zip\" length=\"5\"/>\n"
-"    <property name=\"country\" length=\"25\"/>\n"
-"    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Account\">\n"
-"    <id name=\"accountId\" length=\"32\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    \n"
-"    <many-to-one name=\"user\"\n"
-"        column=\"userId\"\n"
-"        property-ref=\"userId\"/>\n"
-"    \n"
-"    <property name=\"type\" not-null=\"true\"/>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    \n"
-"    <id name=\"id\">\n"
-"        <generator class=\"hilo\"/>\n"
-"    </id>\n"
-"    \n"
-"    <property name=\"name\" length=\"100\"/>\n"
-"    \n"
-"    <one-to-one name=\"address\" \n"
-"        property-ref=\"person\"\n"
-"        cascade=\"all\"\n"
-"        fetch=\"join\"/>\n"
-"    \n"
-"    <set name=\"accounts\" \n"
-"        inverse=\"true\">\n"
-"        <key column=\"userId\"\n"
-"            property-ref=\"userId\"/>\n"
-"        <one-to-many class=\"Account\"/>\n"
-"    </set>\n"
-"    \n"
-"    <property name=\"userId\" length=\"8\"/>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"hilo\"/>\n"
-"    </id>\n"
-"\n"
-"    <property name=\"address\" length=\"300\"/>\n"
-"    <property name=\"zip\" length=\"5\"/>\n"
-"    <property name=\"country\" length=\"25\"/>\n"
-"    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Account\">\n"
-"    <id name=\"accountId\" length=\"32\">\n"
-"        <generator class=\"uuid.hex\"/>\n"
-"    </id>\n"
-"    \n"
-"    <many-to-one name=\"user\"\n"
-"        column=\"userId\"\n"
-"        property-ref=\"userId\"/>\n"
-"    \n"
-"    <property name=\"type\" not-null=\"true\"/>\n"
-"    \n"
-"</class>]]>"
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "        \n"
+#~ "    <class name=\"Employer\" table=\"employers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employer_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employment\" table=\"employment_periods\">\n"
+#~ "\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employment_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"startDate\" column=\"start_date\"/>\n"
+#~ "        <property name=\"endDate\" column=\"end_date\"/>\n"
+#~ "\n"
+#~ "        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
+#~ "            <property name=\"amount\">\n"
+#~ "                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/"
+#~ ">\n"
+#~ "            </property>\n"
+#~ "            <property name=\"currency\" length=\"12\"/>\n"
+#~ "        </component>\n"
+#~ "\n"
+#~ "        <many-to-one name=\"employer\" column=\"employer_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "        <many-to-one name=\"employee\" column=\"employee_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employee\" table=\"employees\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employee_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"taxfileNumber\"/>\n"
+#~ "        <component name=\"name\" class=\"Name\">\n"
+#~ "            <property name=\"firstName\"/>\n"
+#~ "            <property name=\"initial\"/>\n"
+#~ "            <property name=\"lastName\"/>\n"
+#~ "        </component>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "        \n"
+#~ "    <class name=\"Employer\" table=\"employers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employer_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employment\" table=\"employment_periods\">\n"
+#~ "\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employment_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"startDate\" column=\"start_date\"/>\n"
+#~ "        <property name=\"endDate\" column=\"end_date\"/>\n"
+#~ "\n"
+#~ "        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
+#~ "            <property name=\"amount\">\n"
+#~ "                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/"
+#~ ">\n"
+#~ "            </property>\n"
+#~ "            <property name=\"currency\" length=\"12\"/>\n"
+#~ "        </component>\n"
+#~ "\n"
+#~ "        <many-to-one name=\"employer\" column=\"employer_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "        <many-to-one name=\"employee\" column=\"employee_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employee\" table=\"employees\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employee_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"taxfileNumber\"/>\n"
+#~ "        <component name=\"name\" class=\"Name\">\n"
+#~ "            <property name=\"firstName\"/>\n"
+#~ "            <property name=\"initial\"/>\n"
+#~ "            <property name=\"lastName\"/>\n"
+#~ "        </component>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 
-#~ msgid "TODO: put words around this stuff"
-#~ msgstr "POR HACER: poner palabras alrededor de este material"
+#~ msgid ""
+#~ "<![CDATA[create table employers (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employment_periods (\n"
+#~ "    id BIGINT not null,\n"
+#~ "    hourly_rate NUMERIC(12, 2),\n"
+#~ "    currency VARCHAR(12), \n"
+#~ "    employee_id BIGINT not null, \n"
+#~ "    employer_id BIGINT not null, \n"
+#~ "    end_date TIMESTAMP, \n"
+#~ "    start_date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employees (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    firstName VARCHAR(255), \n"
+#~ "    initial CHAR(1), \n"
+#~ "    lastName VARCHAR(255), \n"
+#~ "    taxfileNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK0 foreign key (employer_id) "
+#~ "references employers\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK1 foreign key (employee_id) "
+#~ "references employees\n"
+#~ "create sequence employee_id_seq\n"
+#~ "create sequence employment_id_seq\n"
+#~ "create sequence employer_id_seq]]>"
+#~ msgstr ""
+#~ "<![CDATA[create table employers (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employment_periods (\n"
+#~ "    id BIGINT not null,\n"
+#~ "    hourly_rate NUMERIC(12, 2),\n"
+#~ "    currency VARCHAR(12), \n"
+#~ "    employee_id BIGINT not null, \n"
+#~ "    employer_id BIGINT not null, \n"
+#~ "    end_date TIMESTAMP, \n"
+#~ "    start_date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employees (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    firstName VARCHAR(255), \n"
+#~ "    initial CHAR(1), \n"
+#~ "    lastName VARCHAR(255), \n"
+#~ "    taxfileNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK0 foreign key (employer_id) "
+#~ "references employers\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK1 foreign key (employee_id) "
+#~ "references employees\n"
+#~ "create sequence employee_id_seq\n"
+#~ "create sequence employment_id_seq\n"
+#~ "create sequence employer_id_seq]]>"
 
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <discriminator column=\"type\" type=\"character\"/>\n"
+#~ "\n"
+#~ "        <property name=\"title\"/>\n"
+#~ "        <set name=\"authors\" table=\"author_work\">\n"
+#~ "            <key column name=\"work_id\"/>\n"
+#~ "            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "        <subclass name=\"Book\" discriminator-value=\"B\">\n"
+#~ "            <property name=\"text\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "        <subclass name=\"Song\" discriminator-value=\"S\">\n"
+#~ "            <property name=\"tempo\"/>\n"
+#~ "            <property name=\"genre\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Author\" table=\"authors\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <!-- The Author must have the same identifier as the Person --"
+#~ ">\n"
+#~ "            <generator class=\"assigned\"/> \n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property name=\"alias\"/>\n"
+#~ "        <one-to-one name=\"person\" constrained=\"true\"/>\n"
+#~ "\n"
+#~ "        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
+#~ "            <key column=\"author_id\"/>\n"
+#~ "            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Person\" table=\"persons\">\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <discriminator column=\"type\" type=\"character\"/>\n"
+#~ "\n"
+#~ "        <property name=\"title\"/>\n"
+#~ "        <set name=\"authors\" table=\"author_work\">\n"
+#~ "            <key column name=\"work_id\"/>\n"
+#~ "            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "        <subclass name=\"Book\" discriminator-value=\"B\">\n"
+#~ "            <property name=\"text\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "        <subclass name=\"Song\" discriminator-value=\"S\">\n"
+#~ "            <property name=\"tempo\"/>\n"
+#~ "            <property name=\"genre\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Author\" table=\"authors\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <!-- The Author must have the same identifier as the Person --"
+#~ ">\n"
+#~ "            <generator class=\"assigned\"/> \n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property name=\"alias\"/>\n"
+#~ "        <one-to-one name=\"person\" constrained=\"true\"/>\n"
+#~ "\n"
+#~ "        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
+#~ "            <key column=\"author_id\"/>\n"
+#~ "            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Person\" table=\"persons\">\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+#~ msgid ""
+#~ "<![CDATA[create table works (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    tempo FLOAT, \n"
+#~ "    genre VARCHAR(255), \n"
+#~ "    text INTEGER, \n"
+#~ "    title VARCHAR(255), \n"
+#~ "    type CHAR(1) not null, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table author_work (\n"
+#~ "    author_id BIGINT not null, \n"
+#~ "    work_id BIGINT not null, \n"
+#~ "    primary key (work_id, author_id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table authors (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    alias VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table persons (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table authors \n"
+#~ "    add constraint authorsFK0 foreign key (id) references persons\n"
+#~ "alter table author_work \n"
+#~ "    add constraint author_workFK0 foreign key (author_id) references "
+#~ "authors\n"
+#~ "alter table author_work\n"
+#~ "    add constraint author_workFK1 foreign key (work_id) references works]]"
+#~ ">"
+#~ msgstr ""
+#~ "<![CDATA[create table works (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    tempo FLOAT, \n"
+#~ "    genre VARCHAR(255), \n"
+#~ "    text INTEGER, \n"
+#~ "    title VARCHAR(255), \n"
+#~ "    type CHAR(1) not null, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table author_work (\n"
+#~ "    author_id BIGINT not null, \n"
+#~ "    work_id BIGINT not null, \n"
+#~ "    primary key (work_id, author_id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table authors (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    alias VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table persons (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table authors \n"
+#~ "    add constraint authorsFK0 foreign key (id) references persons\n"
+#~ "alter table author_work \n"
+#~ "    add constraint author_workFK0 foreign key (author_id) references "
+#~ "authors\n"
+#~ "alter table author_work\n"
+#~ "    add constraint author_workFK1 foreign key (work_id) references works]]"
+#~ ">"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Customer\" table=\"customers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "        <set name=\"orders\" inverse=\"true\">\n"
+#~ "            <key column=\"customer_id\"/>\n"
+#~ "            <one-to-many class=\"Order\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Order\" table=\"orders\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"date\"/>\n"
+#~ "        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
+#~ "        <list name=\"lineItems\" table=\"line_items\">\n"
+#~ "            <key column=\"order_id\"/>\n"
+#~ "            <list-index column=\"line_number\"/>\n"
+#~ "            <composite-element class=\"LineItem\">\n"
+#~ "                <property name=\"quantity\"/>\n"
+#~ "                <many-to-one name=\"product\" column=\"product_id\"/>\n"
+#~ "            </composite-element>\n"
+#~ "        </list>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Product\" table=\"products\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"serialNumber\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Customer\" table=\"customers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "        <set name=\"orders\" inverse=\"true\">\n"
+#~ "            <key column=\"customer_id\"/>\n"
+#~ "            <one-to-many class=\"Order\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Order\" table=\"orders\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"date\"/>\n"
+#~ "        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
+#~ "        <list name=\"lineItems\" table=\"line_items\">\n"
+#~ "            <key column=\"order_id\"/>\n"
+#~ "            <list-index column=\"line_number\"/>\n"
+#~ "            <composite-element class=\"LineItem\">\n"
+#~ "                <property name=\"quantity\"/>\n"
+#~ "                <many-to-one name=\"product\" column=\"product_id\"/>\n"
+#~ "            </composite-element>\n"
+#~ "        </list>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Product\" table=\"products\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"serialNumber\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[create table customers (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table orders (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    customer_id BIGINT, \n"
+#~ "    date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table line_items (\n"
+#~ "    line_number INTEGER not null, \n"
+#~ "    order_id BIGINT not null, \n"
+#~ "    product_id BIGINT, \n"
+#~ "    quantity INTEGER, \n"
+#~ "    primary key (order_id, line_number)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table products (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    serialNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table orders \n"
+#~ "    add constraint ordersFK0 foreign key (customer_id) references "
+#~ "customers\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK0 foreign key (product_id) references "
+#~ "products\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK1 foreign key (order_id) references "
+#~ "orders]]>"
+#~ msgstr ""
+#~ "<![CDATA[create table customers (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table orders (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    customer_id BIGINT, \n"
+#~ "    date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table line_items (\n"
+#~ "    line_number INTEGER not null, \n"
+#~ "    order_id BIGINT not null, \n"
+#~ "    product_id BIGINT, \n"
+#~ "    quantity INTEGER, \n"
+#~ "    primary key (order_id, line_number)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table products (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    serialNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table orders \n"
+#~ "    add constraint ordersFK0 foreign key (customer_id) references "
+#~ "customers\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK0 foreign key (product_id) references "
+#~ "products\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK1 foreign key (order_id) references "
+#~ "orders]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"name\"/>\n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'HOME'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "    <one-to-one name=\"mailingAddress\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'MAILING'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\" batch-size=\"2\" \n"
+#~ "        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-many-to-one name=\"person\" \n"
+#~ "                column=\"personName\"/>\n"
+#~ "        <key-property name=\"type\" \n"
+#~ "                column=\"addressType\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"street\" type=\"text\"/>\n"
+#~ "    <property name=\"state\"/>\n"
+#~ "    <property name=\"zip\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"name\"/>\n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'HOME'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "    <one-to-one name=\"mailingAddress\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'MAILING'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\" batch-size=\"2\" \n"
+#~ "        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-many-to-one name=\"person\" \n"
+#~ "                column=\"personName\"/>\n"
+#~ "        <key-property name=\"type\" \n"
+#~ "                column=\"addressType\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"street\" type=\"text\"/>\n"
+#~ "    <property name=\"state\"/>\n"
+#~ "    <property name=\"zip\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Customer\">\n"
+#~ "\n"
+#~ "    <id name=\"customerId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
+#~ "    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
+#~ "\n"
+#~ "    <list name=\"orders\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key column=\"customerId\"/>\n"
+#~ "        <index column=\"orderNumber\"/>\n"
+#~ "        <one-to-many class=\"Order\"/>\n"
+#~ "    </list>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "    <synchronize table=\"Product\"/>\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"Order$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"orderDate\" \n"
+#~ "            type=\"calendar_date\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"total\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity*p.price) \n"
+#~ "            from LineItem li, Product p \n"
+#~ "            where li.productId = p.productId \n"
+#~ "                and li.customerId = customerId \n"
+#~ "                and li.orderNumber = orderNumber )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"customer\"\n"
+#~ "            column=\"customerId\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        \n"
+#~ "    <bag name=\"lineItems\"\n"
+#~ "            fetch=\"join\" \n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "            <column name=\"orderNumber\"/>\n"
+#~ "        </key>\n"
+#~ "        <one-to-many class=\"LineItem\"/>\n"
+#~ "    </bag>\n"
+#~ "    \n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"LineItem\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"LineItem$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "        <key-property name=\"productId\" length=\"10\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"quantity\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\">\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "        <column name=\"orderNumber\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"product\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            column=\"productId\"/>\n"
+#~ "        \n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Product\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "\n"
+#~ "    <id name=\"productId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"description\" \n"
+#~ "        not-null=\"true\" \n"
+#~ "        length=\"200\"/>\n"
+#~ "    <property name=\"price\" length=\"3\"/>\n"
+#~ "    <property name=\"numberAvailable\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"numberOrdered\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity) \n"
+#~ "            from LineItem li \n"
+#~ "            where li.productId = productId )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Customer\">\n"
+#~ "\n"
+#~ "    <id name=\"customerId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
+#~ "    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
+#~ "\n"
+#~ "    <list name=\"orders\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key column=\"customerId\"/>\n"
+#~ "        <index column=\"orderNumber\"/>\n"
+#~ "        <one-to-many class=\"Order\"/>\n"
+#~ "    </list>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "    <synchronize table=\"Product\"/>\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"Order$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"orderDate\" \n"
+#~ "            type=\"calendar_date\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"total\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity*p.price) \n"
+#~ "            from LineItem li, Product p \n"
+#~ "            where li.productId = p.productId \n"
+#~ "                and li.customerId = customerId \n"
+#~ "                and li.orderNumber = orderNumber )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"customer\"\n"
+#~ "            column=\"customerId\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        \n"
+#~ "    <bag name=\"lineItems\"\n"
+#~ "            fetch=\"join\" \n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "            <column name=\"orderNumber\"/>\n"
+#~ "        </key>\n"
+#~ "        <one-to-many class=\"LineItem\"/>\n"
+#~ "    </bag>\n"
+#~ "    \n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"LineItem\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"LineItem$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "        <key-property name=\"productId\" length=\"10\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"quantity\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\">\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "        <column name=\"orderNumber\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"product\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            column=\"productId\"/>\n"
+#~ "        \n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Product\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "\n"
+#~ "    <id name=\"productId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"description\" \n"
+#~ "        not-null=\"true\" \n"
+#~ "        length=\"200\"/>\n"
+#~ "    <property name=\"price\" length=\"3\"/>\n"
+#~ "    <property name=\"numberAvailable\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"numberOrdered\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity) \n"
+#~ "            from LineItem li \n"
+#~ "            where li.productId = productId )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"User\" table=\"`User`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <set name=\"groups\" table=\"UserGroup\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"Group\">\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"Group\" table=\"`Group`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"description\"/>\n"
+#~ "    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"User\">\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"User\" table=\"`User`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <set name=\"groups\" table=\"UserGroup\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"Group\">\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"Group\" table=\"`Group`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"description\"/>\n"
+#~ "    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"User\">\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\"\n"
+#~ "    discriminator-value=\"P\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\" \n"
+#~ "        column=\"person_id\" \n"
+#~ "        unsaved-value=\"0\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "            \n"
+#~ "    <discriminator \n"
+#~ "        type=\"character\">\n"
+#~ "        <formula>\n"
+#~ "            case \n"
+#~ "                when title is not null then 'E' \n"
+#~ "                when salesperson is not null then 'C' \n"
+#~ "                else 'P' \n"
+#~ "            end\n"
+#~ "        </formula>\n"
+#~ "    </discriminator>\n"
+#~ "\n"
+#~ "    <property name=\"name\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        length=\"80\"/>\n"
+#~ "        \n"
+#~ "    <property name=\"sex\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        update=\"false\"/>\n"
+#~ "    \n"
+#~ "    <component name=\"address\">\n"
+#~ "        <property name=\"address\"/>\n"
+#~ "        <property name=\"zip\"/>\n"
+#~ "        <property name=\"country\"/>\n"
+#~ "    </component>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Employee\" \n"
+#~ "        discriminator-value=\"E\">\n"
+#~ "            <property name=\"title\"\n"
+#~ "                length=\"20\"/>\n"
+#~ "            <property name=\"salary\"/>\n"
+#~ "            <many-to-one name=\"manager\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Customer\" \n"
+#~ "        discriminator-value=\"C\">\n"
+#~ "            <property name=\"comments\"/>\n"
+#~ "            <many-to-one name=\"salesperson\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\"\n"
+#~ "    discriminator-value=\"P\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\" \n"
+#~ "        column=\"person_id\" \n"
+#~ "        unsaved-value=\"0\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "            \n"
+#~ "    <discriminator \n"
+#~ "        type=\"character\">\n"
+#~ "        <formula>\n"
+#~ "            case \n"
+#~ "                when title is not null then 'E' \n"
+#~ "                when salesperson is not null then 'C' \n"
+#~ "                else 'P' \n"
+#~ "            end\n"
+#~ "        </formula>\n"
+#~ "    </discriminator>\n"
+#~ "\n"
+#~ "    <property name=\"name\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        length=\"80\"/>\n"
+#~ "        \n"
+#~ "    <property name=\"sex\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        update=\"false\"/>\n"
+#~ "    \n"
+#~ "    <component name=\"address\">\n"
+#~ "        <property name=\"address\"/>\n"
+#~ "        <property name=\"zip\"/>\n"
+#~ "        <property name=\"country\"/>\n"
+#~ "    </component>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Employee\" \n"
+#~ "        discriminator-value=\"E\">\n"
+#~ "            <property name=\"title\"\n"
+#~ "                length=\"20\"/>\n"
+#~ "            <property name=\"salary\"/>\n"
+#~ "            <many-to-one name=\"manager\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Customer\" \n"
+#~ "        discriminator-value=\"C\">\n"
+#~ "            <property name=\"comments\"/>\n"
+#~ "            <many-to-one name=\"salesperson\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\" length=\"100\"/>\n"
+#~ "    \n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "        property-ref=\"person\"\n"
+#~ "        cascade=\"all\"\n"
+#~ "        fetch=\"join\"/>\n"
+#~ "    \n"
+#~ "    <set name=\"accounts\" \n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"userId\"\n"
+#~ "            property-ref=\"userId\"/>\n"
+#~ "        <one-to-many class=\"Account\"/>\n"
+#~ "    </set>\n"
+#~ "    \n"
+#~ "    <property name=\"userId\" length=\"8\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"address\" length=\"300\"/>\n"
+#~ "    <property name=\"zip\" length=\"5\"/>\n"
+#~ "    <property name=\"country\" length=\"25\"/>\n"
+#~ "    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Account\">\n"
+#~ "    <id name=\"accountId\" length=\"32\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"user\"\n"
+#~ "        column=\"userId\"\n"
+#~ "        property-ref=\"userId\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"type\" not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\" length=\"100\"/>\n"
+#~ "    \n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "        property-ref=\"person\"\n"
+#~ "        cascade=\"all\"\n"
+#~ "        fetch=\"join\"/>\n"
+#~ "    \n"
+#~ "    <set name=\"accounts\" \n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"userId\"\n"
+#~ "            property-ref=\"userId\"/>\n"
+#~ "        <one-to-many class=\"Account\"/>\n"
+#~ "    </set>\n"
+#~ "    \n"
+#~ "    <property name=\"userId\" length=\"8\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"address\" length=\"300\"/>\n"
+#~ "    <property name=\"zip\" length=\"5\"/>\n"
+#~ "    <property name=\"country\" length=\"25\"/>\n"
+#~ "    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Account\">\n"
+#~ "    <id name=\"accountId\" length=\"32\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"user\"\n"
+#~ "        column=\"userId\"\n"
+#~ "        property-ref=\"userId\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"type\" not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "</class>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/example_parentchild.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/example_parentchild.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/example_parentchild.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,21 +1,35 @@
-#, fuzzy
+# translation of example_parentchild.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: example_parentchild\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2010-01-05 17:42+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: example_parentchild.xml:29
 #, no-c-format
 msgid "Example: Parent/Child"
 msgstr "Ejemplo: Padre/Hijo"
 
 #. Tag: para
-#: example_parentchild.xml:31
-#, fuzzy, no-c-format
+#, 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 "
@@ -31,54 +45,47 @@
 "cascades</emphasis> to model a parent/child relationship efficiently and "
 "elegantly."
 msgstr ""
-"Una de las primer&#x00ed;simas cosas que los usuarios nuevos intentan hacer "
-"con Hibernate es modelar una relaci&#x00f3;n de tipo padre / hijo. Para esto "
-"hay dos enfoques diferentes. Por varias razones, el enfoque m&#x00e1;s "
-"conveniente, especialmente para usuarios nuevos, es modelar tanto "
-"<literal>Parent</literal> como <literal>Child</literal> como clases de "
-"entidad con una asociaci&#x00f3;n <literal>&lt;one-to-many&gt;</literal> "
-"desde <literal>Parent</literal> a <literal>Child</literal>. (El enfoque "
-"alternativo es declarar el <literal>Child</literal> como un <literal>&lt;"
-"composite-element&gt;</literal>.) Ahora, resulta que la sem&#x00e1;ntica por "
-"defecto de una asociaci&#x00f3;n uno a muchos (en Hibernate) es mucho menos "
-"cercana a la sem&#x00e1;ntica usual de una relaci&#x00f3;n padre / hijo que "
-"aquellas de un mapeo de elementos compuestos. Explicaremos c&#x00f3;mo usar "
-"una <emphasis>asociaci&#x00f3;n uno a muchos bidireccional con tratamiento "
-"en cascada</emphasis> para modelar una relaci&#x00f3;n padre / hijo "
-"eficiente y elegantemente. &#x00a1;No es para nada dif&#x00ed;cil!"
+"Una de las primeras cosas que los usuarios nuevos intentan hacer con "
+"Hibernate es modelar una relación de tipo padre / hijo. Para esto existen "
+"dos enfoques diferentes. El enfoque más conveniente, especialmente para los "
+"usuarios nuevos, es modelar tanto <literal>Parent</literal> como "
+"<literal>Child</literal> como clases de entidad con una asociación "
+"<literal>&lt;one-to-many&gt;</literal> desde <literal>Parent</literal> a "
+"<literal>Child</literal>. El enfoque opcional es declarar el <literal>Child</"
+"literal> como un <literal>&lt;composite-element&gt;</literal>. La semántica "
+"prederterminada de una asociación uno-a-muchos en Hibernate es mucho menos "
+"cercana a la semántica usual de una relación padre / hijo que la de un mapeo "
+"de elementos compuestos. Explicaremos cómo utilizar una <emphasis>asociación "
+"uno-a-muchos bidireccional con tratamiento en cascada</emphasis> para "
+"modelar una relación padre / hijo de manera eficiente y elegante."
 
 #. Tag: title
-#: example_parentchild.xml:45
 #, no-c-format
 msgid "A note about collections"
-msgstr "Una nota sobre las colecciones"
+msgstr "Nota sobre las colecciones"
 
 #. Tag: para
-#: example_parentchild.xml:47
-#, fuzzy, no-c-format
+#, 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 ""
-"Se considera que las colecciones de Hibernate son una parte l&#x00f3;gica de "
-"la entidad que las posee; nunca de las entidades contenidas. &#x00a1;Esta es "
-"una distinci&#x00f3;n crucial! Esto tiene las siguientes consecuencias:"
+"Se considera que las colecciones de Hibernate son una parte lógica de la "
+"entidad que las posee y no de las entidades contenidas. Note que esta es una "
+"diferencia crucial y que esto tiene las siguientes consecuencias:"
 
 #. Tag: para
-#: example_parentchild.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When you remove/add an object from/to a collection, the version number of "
 "the collection owner is incremented."
 msgstr ""
-"Cuando se quita / a&#x00f1;ade un objeto desde / a una colecci&#x00f3;n, se "
-"incrementa el n&#x00fa;mero de versi&#x00f3;n del due&#x00f1;o de la "
-"colecci&#x00f3;n."
+"Cuando se elimina/agrega un objeto desde/a una colección, se incrementa el "
+"número de la versión del dueño de la colección."
 
 #. Tag: para
-#: example_parentchild.xml:60
-#, fuzzy, no-c-format
+#, 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 "
@@ -86,15 +93,14 @@
 "value type instance to the collection will cause its state to be immediately "
 "persistent."
 msgstr ""
-"Si un objeto que fue quitado de una colecci&#x00f3;n es una instancia de un "
-"tipo de valor (por ejemplo, un elemento compuesto), ese objeta cesar&#x00e1; "
-"de ser persistente y su estado ser&#x00e1; completamente quitado de la base "
-"de datos. Asimismo, a&#x00f1;adir una instancia de tipo de valor a la "
-"colecci&#x00f3;n causar&#x00e1; que su estado sea inmediatamente persistente."
+"Si un objeto que fue eliminado de una colección es una instancia de un tipo "
+"de valor (por ejemplo, un elemento compuesto), ese objeto cesará de ser "
+"persistente y su estado será completamente eliminado de la base de datos. "
+"Asimismo, añadir una instancia de tipo de valor a la colección causará que "
+"su estado sea persistente inmediatamente."
 
 #. Tag: para
-#: example_parentchild.xml:68
-#, fuzzy, no-c-format
+#, 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 "
@@ -102,16 +108,15 @@
 "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 ""
-"Por otro lado, si se quita una entidad de una colecci&#x00f3;n (una "
-"asociaci&#x00f3;n uno-a-muchos o muchos-a-muchos), no ser&#x00e1; borrado, "
-"por defecto. Este comportamiento es completamente consistente. &#x00a1;Un "
-"cambio en el estado interno de otra entidad no hace desaparecer la entidad "
-"asociada! Asimismo, a&#x00f1;adir una entidad a una colecci&#x00f3;n no "
-"causa que la entidad se vuelva persistente, por defecto."
+"Por otro lado, si se elimina una entidad de una colección (una asociación "
+"uno-a-muchos o muchos-a-muchos), no se borrará por defecto. Este "
+"comportamiento es completamente consistente; un cambio en el estado interno "
+"de otra entidad no hace desaparecer la entidad asociada. Asimismo, el "
+"agregar una entidad a una colección no causa que la entidad se vuelva "
+"persistente por defecto."
 
 #. Tag: para
-#: example_parentchild.xml:78
-#, fuzzy, no-c-format
+#, 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 "
@@ -119,74 +124,37 @@
 "case of a parent/child relationship. In this case, the life of the child is "
 "bound to the life cycle of the parent."
 msgstr ""
-"En cambio, el comportamiento por defecto es que al a&#x00f1;adir una entidad "
-"a una colecci&#x00f3;n se crea meramente un enlace entre las dos entidades, "
-"mientras que al quitarla se quita el enlace. Esto es muy apropiado para "
-"todos los tipos de casos. Donde no es para nada apropiado es en el caso de "
-"una relaci&#x00f3;n padre / hijo. donde la vida del hijo est&#x00e1; ligada "
-"al ciclo de vida del padre."
+"El comportamiento por defecto es que al agregar una entidad a una colección "
+"se crea un enlace entre las dos entidades. Al eliminar la entidad se "
+"eliminará el enlace. Esto es muy apropiado para todos los tipos de casos. "
+"Sin embargo, no apropiado en el caso de una relación padre / hijo. En este "
+"caso la vida del hijo se encuentra vinculada al ciclo de vida del padre."
 
 #. Tag: title
-#: example_parentchild.xml:88
 #, no-c-format
 msgid "Bidirectional one-to-many"
-msgstr "Uno-a-muchos bidirectional"
+msgstr "Uno-a-muchos bidireccional"
 
 #. Tag: para
-#: example_parentchild.xml:90
 #, no-c-format
 msgid ""
 "Suppose we start with a simple <literal>&lt;one-to-many&gt;</literal> "
 "association from <literal>Parent</literal> to <literal>Child</literal>."
 msgstr ""
-"Sup&#x00f3;n que empezamos con una asociaci&#x00f3;n simple <literal>&lt;one-"
-"to-many&gt;</literal> desde <literal>Parent</literal> a <literal>Child</"
-"literal>."
+"Supónga que empezamos con una asociación simple <literal>&lt;one-to-many&gt;"
+"</literal> desde <literal>Parent</literal> a <literal>Child</literal>."
 
-#. Tag: programlisting
-#: example_parentchild.xml:95
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-"<![CDATA[<set name=\"children\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-
 #. Tag: para
-#: example_parentchild.xml:97
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "If we were to execute the following code:"
-msgstr "Si ejecut&#x00e1;semos el siguiente c&#x00f3;digo"
+msgstr "Si ejecutásemos el siguiente código:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:101
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = .....;\n"
-"Child c = new Child();\n"
-"p.getChildren().add(c);\n"
-"session.save(c);\n"
-"session.flush();]]>"
-msgstr ""
-"<![CDATA[Parent p = .....;\n"
-"Child c = new Child();\n"
-"p.getChildren().add(c);\n"
-"session.save(c);\n"
-"session.flush();]]>"
-
 #. Tag: para
-#: example_parentchild.xml:103
 #, no-c-format
 msgid "Hibernate would issue two SQL statements:"
-msgstr "Hibernate publicar&#x00ed;a dos sentencias SQL:"
+msgstr "Hibernate publicaría dos declaraciones SQL:"
 
 #. Tag: para
-#: example_parentchild.xml:109
 #, no-c-format
 msgid ""
 "an <literal>INSERT</literal> to create the record for <literal>c</literal>"
@@ -194,7 +162,6 @@
 "un <literal>INSERT</literal> para crear el registro de <literal>c</literal>"
 
 #. Tag: para
-#: example_parentchild.xml:112
 #, no-c-format
 msgid ""
 "an <literal>UPDATE</literal> to create the link from <literal>p</literal> to "
@@ -204,43 +171,25 @@
 "a <literal>c</literal>"
 
 #. Tag: para
-#: example_parentchild.xml:119
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is not only inefficient, but also violates any <literal>NOT NULL</"
 "literal> constraint on the <literal>parent_id</literal> column. You can fix "
 "the nullability constraint violation by specifying <literal>not-null=\"true"
 "\"</literal> in the collection mapping:"
 msgstr ""
-"Esto no es s&#x00f3;lo ineficiente, sino que adem&#x00e1;s viola cualquier "
-"restricci&#x00f3;n <literal>NOT NULL</literal> en la columna "
-"<literal>parent_id</literal>. Podemos reparar la violaci&#x00f3;n de "
-"restricci&#x00f3;n de nulabilidad especificando <literal>not-null=\"true\"</"
-"literal> en el mapeo de la colecci&#x00f3;n:"
+"Esto no es sólo ineficiente, sino que además viola cualquier restricción "
+"<literal>NOT NULL</literal> en la columna <literal>parent_id</literal>. "
+"Puede arreglar la violación de restricción de nulabilidad especificando "
+"<literal>not-null=\"true\"</literal> en el mapeo de la colección:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:125
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\">\n"
-"    <key column=\"parent_id\" not-null=\"true\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-"<![CDATA[<set name=\"children\">\n"
-"    <key column=\"parent_id\" not-null=\"true\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-
 #. Tag: para
-#: example_parentchild.xml:127
 #, no-c-format
 msgid "However, this is not the recommended solution."
-msgstr "Sin embargo, esta no es la soluci&#x00f3;n recomendada."
+msgstr "Sin embargo, esta no es la solución recomendada."
 
 #. Tag: para
-#: example_parentchild.xml:130
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The underlying cause of this behavior is that the link (the foreign key "
 "<literal>parent_id</literal>) from <literal>p</literal> to <literal>c</"
@@ -248,323 +197,141 @@
 "object and is therefore not created in the <literal>INSERT</literal>. The "
 "solution is to make the link part of the <literal>Child</literal> mapping."
 msgstr ""
-"El caso subyacente de este comportamiento es que el enlace (la clave "
-"for&#x00e1;nea <literal>parent_id</literal>) de <literal>p</literal> a "
-"<literal>c</literal> no es considerado parte del estado del objeto "
-"<literal>Child</literal> y por lo tanto no es creada en el <literal>INSERT</"
-"literal>. De modo que la soluci&#x00f3;n es hacer el enlace parte del mapeo "
-"del <literal>Child</literal>."
+"El caso subyacente de este comportamiento es que el enlace (la clave foránea "
+"<literal>parent_id</literal>) de <literal>p</literal> a <literal>c</literal> "
+"no se considera parte del estado del objeto <literal>Child</literal> y por "
+"lo tanto no se crea en el <literal>INSERT</literal>. De modo que la solución "
+"es hacer que el enlace sea parte del mapeo del <literal>Child</literal>. "
 
-#. Tag: programlisting
-#: example_parentchild.xml:137
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"parent\" column=\"parent_id\" not-null=\"true\"/"
-">]]>"
-msgstr ""
-"<![CDATA[<many-to-one name=\"parent\" column=\"parent_id\" not-null=\"true\"/"
-">]]>"
-
-#. Tag: para
-#: example_parentchild.xml:139
-#, fuzzy, no-c-format
-msgid ""
 "You also need to add the <literal>parent</literal> property to the "
 "<literal>Child</literal> class."
 msgstr ""
-"(Necesitamos adem&#x00e1;s a&#x00f1;adir la propiedad <literal>parent</"
-"literal> a la clase <literal>Child</literal>.)"
+"También necesita agregar la propiedad <literal>parent</literal> a la clase "
+"<literal>Child</literal>."
 
 #. Tag: para
-#: example_parentchild.xml:143
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now that the <literal>Child</literal> entity is managing the state of the "
 "link, we tell the collection not to update the link. We use the "
 "<literal>inverse</literal> attribute to do this:"
 msgstr ""
-"Ahora que la entidad <literal>Child</literal> est&#x00e1; gestionando el "
-"estado del enlace, le decimos a la colecci&#x00f3;n que no actualice el "
-"enlace. Usamos el atributo <literal>inverse</literal>."
+"Ahora que la entidad <literal>Child</literal> está administrando el estado "
+"del enlace, le decimos a la colección que no actualice el enlace. Usamos el "
+"atributo <literal>inverse</literal> para hacer esto:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:148
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-"<![CDATA[<set name=\"children\" inverse=\"true\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-
 #. Tag: para
-#: example_parentchild.xml:150
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The following code would be used to add a new <literal>Child</literal>:"
 msgstr ""
-"El siguiente c&#x00f3;digo podr&#x00ed;a ser usado para a&#x00f1;adir un "
-"nuevo <literal>Child</literal>"
+"El siguiente código se podría utilizar para agregar un nuevo <literal>Child</"
+"literal>:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:154
-#, no-c-format
-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 ""
-"<![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();]]>"
-
 #. Tag: para
-#: example_parentchild.xml:156
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Only one SQL <literal>INSERT</literal> would now be issued."
-msgstr ""
-"Y ahora, &#x00a1;S&#x00f3;lo se publicar&#x00ed;a un <literal>INSERT</"
-"literal> de SQL!"
+msgstr "Sólo se emitiría un <literal>INSERT</literal> de SQL."
 
 #. Tag: para
-#: example_parentchild.xml:160
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You could also create an <literal>addChild()</literal> method of "
 "<literal>Parent</literal>."
 msgstr ""
-"Para ajustar un poco m&#x00e1;s las cosas, podr&#x00ed;amos crear un "
-"m&#x00e9;todo <literal>addChild()</literal> en <literal>Parent</literal>."
+"También podría crear un método <literal>addChild()</literal> de "
+"<literal>Parent</literal>."
 
-#. Tag: programlisting
-#: example_parentchild.xml:165
-#, no-c-format
-msgid ""
-"<![CDATA[public void addChild(Child c) {\n"
-"    c.setParent(this);\n"
-"    children.add(c);\n"
-"}]]>"
-msgstr ""
-"<![CDATA[public void addChild(Child c) {\n"
-"    c.setParent(this);\n"
-"    children.add(c);\n"
-"}]]>"
-
 #. Tag: para
-#: example_parentchild.xml:167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The code to add a <literal>Child</literal> looks like this:"
-msgstr ""
-"Ahora, el c&#x00f3;digo para a&#x00f1;adir un <literal>Child</literal> se ve "
-"as&#x00ed;"
+msgstr "El código para agregar un <literal>Child</literal> se ve así:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:171
-#, no-c-format
-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 ""
-"<![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();]]>"
-
 #. Tag: title
-#: example_parentchild.xml:176
 #, no-c-format
 msgid "Cascading life cycle"
-msgstr "Ciclo de vida en cascada"
+msgstr "Ciclo de vida en cascada "
 
 #. Tag: para
-#: example_parentchild.xml:178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can address the frustrations of the explicit call to <literal>save()</"
 "literal> by using cascades."
 msgstr ""
-"La llamada expl&#x00ed;cita a <literal>save()</literal> es a&#x00fa;n "
-"molesta. Apuntaremos a esto usando tratamientos en cascada."
+"Puede abordar las frustraciones de la llamada explícita a <literal>save()</"
+"literal> utilizando cascadas."
 
-#. Tag: programlisting
-#: example_parentchild.xml:183
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-"<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-
 #. Tag: para
-#: example_parentchild.xml:185
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This simplifies the code above to:"
-msgstr "Esto simplifica el c&#x00f3;digo anterior a"
+msgstr "Esto simplifica el código anterior a:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:189
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-"Child c = new Child();\n"
-"p.addChild(c);\n"
-"session.flush();]]>"
-msgstr ""
-"<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-"Child c = new Child();\n"
-"p.addChild(c);\n"
-"session.flush();]]>"
-
-#. Tag: para
-#: example_parentchild.xml:191
-#, fuzzy, no-c-format
-msgid ""
 "Similarly, we do not need to iterate over the children when saving or "
 "deleting a <literal>Parent</literal>. The following removes <literal>p</"
 "literal> and all its children from the database."
 msgstr ""
-"Similarmente, no necesitamos iterar los hijos al salvar o borrar un "
-"<literal>Parent</literal>. Lo siguiente quita <literal>p</literal> y todos "
+"De manera similar, no necesitamos iterar los hijos al guardar o borrar un "
+"<literal>Parent</literal>. Lo siguiente elimina <literal>p</literal> y todos "
 "sus hijos de la base de datos."
 
-#. Tag: programlisting
-#: example_parentchild.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-"session.delete(p);\n"
-"session.flush();]]>"
-msgstr ""
-"<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-"session.delete(p);\n"
-"session.flush();]]>"
-
 #. Tag: para
-#: example_parentchild.xml:198
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "However, the following code:"
-msgstr "Sin embargo, este c&#x00f3;digo"
+msgstr "Sin embargo, el siguiente código:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:202
+#. Tag: para
 #, no-c-format
 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 ""
-"<![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();]]>"
-
-#. Tag: para
-#: example_parentchild.xml:204
-#, fuzzy, no-c-format
-msgid ""
 "will not remove <literal>c</literal> from the database. In this case, it "
 "will only remove the link to <literal>p</literal> and cause a <literal>NOT "
 "NULL</literal> constraint violation. You need to explicitly <literal>delete()"
 "</literal> the <literal>Child</literal>."
 msgstr ""
-"no quitar&#x00e1; <literal>c</literal> de la base de datos; s&#x00f3;lo "
-"quitar&#x00e1; el enlace a <literal>p</literal> (y causar&#x00e1; una "
-"violaci&#x00f3;n a una restricci&#x00f3;n <literal>NOT NULL</literal>). "
-"Necesitas borrar el hijo expl&#x00ed;citamente llamando a <literal>delete()</"
+"no eliminará <literal>c</literal> de la base de datos. En este caso, sólo "
+"quitará el enlace a <literal>p</literal> y causará una violación a una "
+"restricción <literal>NOT NULL</literal>. Necesita borrar el hijo "
+"explícitamente llamando a <literal>delete()</literal> en <literal>Child</"
 "literal>."
 
-#. Tag: programlisting
-#: example_parentchild.xml:210
+#. Tag: para
 #, no-c-format
 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 ""
-"<![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();]]>"
-
-#. Tag: para
-#: example_parentchild.xml:212
-#, fuzzy, no-c-format
-msgid ""
 "In our case, a <literal>Child</literal> cannot exist without its parent. So "
 "if we remove a <literal>Child</literal> from the collection, we do want it "
 "to be deleted. To do this, we must use <literal>cascade=\"all-delete-orphan"
 "\"</literal>."
 msgstr ""
-"Ahora, en nuestro caso, un <literal>Child</literal> no puede existir "
-"realmente sin su padre. De modo que si quitamos un <literal>Child</literal> "
-"de la colecci&#x00f3;n, realmente queremos que sea borrado. Para esto, "
-"debemos usar <literal>cascade=\"all-delete-orphan\"</literal>."
+"En nuestro caso, un <literal>Child</literal> no puede existir realmente sin "
+"su padre. De modo que si eliminamos un <literal>Child</literal> de la "
+"colección, realmente queremos que sea borrado. Para esto, tenemos que "
+"utilizar <literal>cascade=\"all-delete-orphan\"</literal>."
 
-#. Tag: programlisting
-#: example_parentchild.xml:218
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all-delete-orphan"
-"\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-"<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all-delete-orphan"
-"\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-
-#. Tag: para
-#: example_parentchild.xml:220
-#, fuzzy, no-c-format
-msgid ""
 "Even though the collection mapping specifies <literal>inverse=\"true\"</"
 "literal>, cascades are still processed by iterating the collection elements. "
 "If you need an object be saved, deleted or updated by cascade, you must add "
 "it to the collection. It is not enough to simply call <literal>setParent()</"
 "literal>."
 msgstr ""
-"Nota: aunque el mapeo de la colecci&#x00f3;n especifique <literal>inverse="
-"\"true\"</literal>, el tratamiento en cascada se procesa a&#x00fa;n al "
-"iterar los elementos de colecci&#x00f3;n. De modo que si requieres que un "
-"objeto sea salvado, borrado o actualizado en cascada, debes a&#x00f1;adirlo "
-"a la colecci&#x00f3;n. No es suficiente con simplemente llamar a "
-"<literal>setParent()</literal>."
+"Aunque el mapeo de la colección especifique <literal>inverse=\"true\"</"
+"literal>, el tratamiento en cascada se procesa aún al iterar los elementos "
+"de la colección. De modo que si necesita que un objeto se guarde, borre o "
+"actualice en cascada, debe añadirlo a la colección. No es suficiente con "
+"simplemente llamar a <literal>setParent()</literal>."
 
 #. Tag: title
-#: example_parentchild.xml:230
 #, no-c-format
 msgid "Cascades and <literal>unsaved-value</literal>"
-msgstr "Tratamiento en cascada y <literal>unsaved-value</literal>"
+msgstr "Cascadas y <literal>unsaved-value</literal>"
 
 #. Tag: para
-#: example_parentchild.xml:232
 #, fuzzy, no-c-format
 msgid ""
 "Suppose we loaded up a <literal>Parent</literal> in one <literal>Session</"
@@ -577,58 +344,37 @@
 "literal> have generated identifier properties of type <literal>Long</"
 "literal>. Hibernate will use the identifier and version/timestamp property "
 "value to determine which of the children are new. (See <xref linkend="
-"\"objectstate-saveorupdate\"/>.) <emphasis>In Hibernate3, it is no longer "
+"\"objectstate-saveorupdate\" />.) <emphasis>In Hibernate3, it is no longer "
 "necessary to specify an <literal>unsaved-value</literal> explicitly.</"
 "emphasis>"
 msgstr ""
-"Sup&#x00f3;n que hemos cargado un <literal>Parent</literal> en una "
-"<literal>Session</literal>, hemos hecho algunos cambios en una acci&#x00f3;n "
-"de UI y deseamos hacer persistentes estos cambios en una nueva sesi&#x00f3;n "
-"llamando a <literal>update()</literal>. El <literal>Parent</literal> "
-"contendr&#x00e1; una colecci&#x00f3;n de hijos y, ya que est&#x00e1; "
-"habilitado el tratamiento en cascada, Hibernate necesita saber qu&#x00e9; "
-"hijos est&#x00e1;n reci&#x00e9;n instanciados y cu&#x00e1;les representan "
-"filas existentes en la base de datos. Asumamos que tanto <literal>Parent</"
-"literal> como <literal>Child</literal> tienen propiedades identificadoras "
-"generadas de tipo <literal>Long</literal>. Hibernate usar&#x00e1; el "
-"identificador y el valor de la propiedad de versi&#x00f3;n/timestamp para "
-"determinar cu&#x00e1;les de los hijos son nuevos. (Ver <xref linkend="
-"\"objectstate-saveorupdate\"/>.) <emphasis>En Hibernate3, no es m&#x00e1;s "
-"necesario especificar un <literal>unsaved-value</literal> expl&#x00ed;"
-"citamente.</emphasis>"
+"Supónga que hemos cargado un <literal>Parent</literal> en una "
+"<literal>Session</literal>, hemos realizado algunos cambios en una acción UI "
+"y deseamos hacer persistentes estos cambios en una nueva sesión llamando a "
+"<literal>update()</literal>. El <literal>Parent</literal> contendrá una "
+"colección de hijos y ya que está habilitado el tratamiento en cascada, "
+"Hibernate necesita saber qué hijos están recién instanciados y cuáles "
+"representan filas existentes en la base de datos. También vamos a asumir que "
+"tanto <literal>Parent</literal> como <literal>Child</literal> tienen "
+"propiedades identificadoras generadas de tipo <literal>Long</literal>. "
+"Hibernate usará el identificador y el valor de la propiedad de versión/sello "
+"de fecha para determinar cuáles de los hijos son nuevos, (consulte la <xref "
+"linkend=\"objectstate-saveorupdate\" />). <emphasis>En Hibernate3, ya no es "
+"necesario especificar un <literal>unsaved-value</literal> explícitamente.</"
+"emphasis>"
 
 #. Tag: para
-#: example_parentchild.xml:244
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following code will update <literal>parent</literal> and <literal>child</"
 "literal> and insert <literal>newChild</literal>:"
 msgstr ""
-"The following code will update <literal>parent</literal> and <literal>child</"
-"literal> and insert <literal>newChild</literal>."
+"El siguiente código actualizará <literal>parent</literal> y <literal>child</"
+"literal> e insertará <literal>newChild</literal>:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:249
+#. Tag: para
 #, no-c-format
 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 ""
-"<![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();]]>"
-
-#. Tag: para
-#: example_parentchild.xml:251
-#, fuzzy, 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 "
@@ -637,38 +383,33 @@
 "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 ""
-"Bueno, todo eso est&#x00e1; muy bien para el caso de un identificador "
-"generado, pero &#x00bf;qu&#x00e9; de los identificadores asignados y de los "
-"identificadores compuestos? Esto es m&#x00e1;s dif&#x00ed;cil, ya que "
-"Hibernate no puede usar la propiedad identificadora para distinguir entre un "
-"objeto reci&#x00e9;n instanciado (con un identificador asignado por el "
-"usuario) y un objeto cargado en una sesi&#x00f3;n previa. En este caso, "
-"Hibernate bien usar&#x00e1; la propiedad de versi&#x00f3;n o timestamp, o "
-"bien consultar&#x00e1; realmente el cach&#x00e9; de segundo nivel, o bien, "
-"en el peor de los casos, la base de datos, para ver si existe la fila."
+"Todo eso es apropiado para el caso de un identificador generado, pero ¿qué "
+"de los identificadores asignados y de los identificadores compuestos? Esto "
+"es más difícil, ya que Hibernate no puede usar la propiedad identificadora "
+"para distinguir entre un objeto recién instanciado, con un identificador "
+"asignado por el usuario y un objeto cargado en una sesión previa. En este "
+"caso, Hibernate utilizará la propiedad de versión o sello de fecha, o bien "
+"consultará realmente el caché de segundo nivel, o bien, en el peor de los "
+"casos, consultará la base de datos, para ver si la fila existe."
 
 #. Tag: title
-#: example_parentchild.xml:284
 #, no-c-format
 msgid "Conclusion"
-msgstr "Conclusi&#x00f3;n"
+msgstr "Conclusión"
 
 #. Tag: para
-#: example_parentchild.xml:286
-#, fuzzy, no-c-format
+#, 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 ""
-"Hay que resumir un poco aqu&#x00ed; y podr&#x00ed;a parecer confuso a la "
-"primera vez. Sin embargo, en la pr&#x00e1;ctica, todo funciona muy "
-"agradablemente. La mayor&#x00ed;a de las aplicaciones de Hibernate usan el "
-"patr&#x00f3;n padre / hijo en muchos sitios."
+"Las secciones que acabamos de cubrir pueden parecer un poco confusas. Sin "
+"embargo, en la práctica, todo funciona muy bien. La mayoría de las "
+"aplicaciones de Hibernate utilizan el patrón padre / hijo en muchos sitios."
 
 #. Tag: para
-#: example_parentchild.xml:291
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We mentioned an alternative in the first paragraph. None of the above issues "
 "exist in the case of <literal>&lt;composite-element&gt;</literal> mappings, "
@@ -677,16 +418,10 @@
 "composite elements cannot own collections and they should not be the child "
 "of any entity other than the unique parent."
 msgstr ""
-"Hemos mencionado una alternativa en el primer p&#x00e1;rrafo. Ninguno de los "
-"temas anteriores existe en el caso de los mapeos <literal>&lt;composite-"
-"element&gt;</literal>, que tienen exactamente la sem&#x00e1;ntica de una "
-"relaci&#x00f3;n padre / hijo. Desafortunadamente, hay dos grandes "
-"limitaciones para las clases de elementos compuestos: los elementos "
-"compuestos no pueden poseer sus propias colecciones, y no deben ser el hijo "
-"de cualquier otra entidad que no sea su padre &#x00fa;nico."
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+"Mencionamos una opción en el primer párrafo. Ninguno de los temas anteriores "
+"existe en el caso de los mapeos <literal>&lt;composite-element&gt;</"
+"literal>, los cuales tienen exactamente la semántica de una relación padre / "
+"hijo. Desafortunadamente, existen dos grandes limitaciones para las clases "
+"de elementos compuestos: los elementos compuestos no pueden poseer sus "
+"propias colecciones y no deben ser el hijo de cualquier otra entidad que no "
+"sea su padre único."

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/example_weblog.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/example_weblog.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/example_weblog.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,878 +1,868 @@
-#, fuzzy
+# translation of example_weblog.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: example_weblog\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-11-03 12:25+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: example_weblog.xml:29
 #, no-c-format
 msgid "Example: Weblog Application"
-msgstr "Ejemplo: Aplicaci&#x00f3;n de Weblog"
+msgstr "Ejemplo: Aplicación de Weblog"
 
 #. Tag: title
-#: example_weblog.xml:32
 #, no-c-format
 msgid "Persistent Classes"
 msgstr "Clases Persistentes"
 
 #. Tag: para
-#: example_weblog.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The persistent classes here represent a weblog and an item posted in a "
 "weblog. They are to be modelled as a standard parent/child relationship, but "
 "we will use an ordered bag, instead of a set:"
 msgstr ""
-"Las clases persistentes representan un weblog, y un &#x00ed;tem enviado a un "
-"weblog. Van a ser modelados como una relaci&#x00f3;n padre/hijo est&#x00f1;"
-"ndar, pero usaremos un bag ordenado, en vez de un conjunto (set)."
+"Las clases persistentes aquí representan un weblog, y un ítem publicado en "
+"un weblog. Van a ser modelados como una relación padre/hijo estándar, pero "
+"usaremos un bag ordenado, en lugar de un conjunto:"
 
-#. Tag: programlisting
-#: example_weblog.xml:40
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.util.List;\n"
-"\n"
-"public class Blog {\n"
-"    private Long _id;\n"
-"    private String _name;\n"
-"    private List _items;\n"
-"\n"
-"    public Long getId() {\n"
-"        return _id;\n"
-"    }\n"
-"    public List getItems() {\n"
-"        return _items;\n"
-"    }\n"
-"    public String getName() {\n"
-"        return _name;\n"
-"    }\n"
-"    public void setId(Long long1) {\n"
-"        _id = long1;\n"
-"    }\n"
-"    public void setItems(List list) {\n"
-"        _items = list;\n"
-"    }\n"
-"    public void setName(String string) {\n"
-"        _name = string;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.util.List;\n"
-"\n"
-"public class Blog {\n"
-"    private Long _id;\n"
-"    private String _name;\n"
-"    private List _items;\n"
-"\n"
-"    public Long getId() {\n"
-"        return _id;\n"
-"    }\n"
-"    public List getItems() {\n"
-"        return _items;\n"
-"    }\n"
-"    public String getName() {\n"
-"        return _name;\n"
-"    }\n"
-"    public void setId(Long long1) {\n"
-"        _id = long1;\n"
-"    }\n"
-"    public void setItems(List list) {\n"
-"        _items = list;\n"
-"    }\n"
-"    public void setName(String string) {\n"
-"        _name = string;\n"
-"    }\n"
-"}]]>"
-
-#. Tag: programlisting
-#: example_weblog.xml:42
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.text.DateFormat;\n"
-"import java.util.Calendar;\n"
-"\n"
-"public class BlogItem {\n"
-"    private Long _id;\n"
-"    private Calendar _datetime;\n"
-"    private String _text;\n"
-"    private String _title;\n"
-"    private Blog _blog;\n"
-"\n"
-"    public Blog getBlog() {\n"
-"        return _blog;\n"
-"    }\n"
-"    public Calendar getDatetime() {\n"
-"        return _datetime;\n"
-"    }\n"
-"    public Long getId() {\n"
-"        return _id;\n"
-"    }\n"
-"    public String getText() {\n"
-"        return _text;\n"
-"    }\n"
-"    public String getTitle() {\n"
-"        return _title;\n"
-"    }\n"
-"    public void setBlog(Blog blog) {\n"
-"        _blog = blog;\n"
-"    }\n"
-"    public void setDatetime(Calendar calendar) {\n"
-"        _datetime = calendar;\n"
-"    }\n"
-"    public void setId(Long long1) {\n"
-"        _id = long1;\n"
-"    }\n"
-"    public void setText(String string) {\n"
-"        _text = string;\n"
-"    }\n"
-"    public void setTitle(String string) {\n"
-"        _title = string;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.text.DateFormat;\n"
-"import java.util.Calendar;\n"
-"\n"
-"public class BlogItem {\n"
-"    private Long _id;\n"
-"    private Calendar _datetime;\n"
-"    private String _text;\n"
-"    private String _title;\n"
-"    private Blog _blog;\n"
-"\n"
-"    public Blog getBlog() {\n"
-"        return _blog;\n"
-"    }\n"
-"    public Calendar getDatetime() {\n"
-"        return _datetime;\n"
-"    }\n"
-"    public Long getId() {\n"
-"        return _id;\n"
-"    }\n"
-"    public String getText() {\n"
-"        return _text;\n"
-"    }\n"
-"    public String getTitle() {\n"
-"        return _title;\n"
-"    }\n"
-"    public void setBlog(Blog blog) {\n"
-"        _blog = blog;\n"
-"    }\n"
-"    public void setDatetime(Calendar calendar) {\n"
-"        _datetime = calendar;\n"
-"    }\n"
-"    public void setId(Long long1) {\n"
-"        _id = long1;\n"
-"    }\n"
-"    public void setText(String string) {\n"
-"        _text = string;\n"
-"    }\n"
-"    public void setTitle(String string) {\n"
-"        _title = string;\n"
-"    }\n"
-"}]]>"
-
 #. Tag: title
-#: example_weblog.xml:47
 #, no-c-format
 msgid "Hibernate Mappings"
 msgstr "Mapeos de Hibernate"
 
 #. Tag: para
-#: example_weblog.xml:49
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The XML mappings are now straightforward. For example:"
-msgstr "Los mapeos XML ahora deben ser absolutamente directos."
+msgstr "Los mapeos XML ahora deben ser bastante sencillos. Por ejemplo:"
 
-#. Tag: programlisting
-#: example_weblog.xml:53
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"    <class\n"
-"        name=\"Blog\"\n"
-"        table=\"BLOGS\">\n"
-"\n"
-"        <id\n"
-"            name=\"id\"\n"
-"            column=\"BLOG_ID\">\n"
-"\n"
-"            <generator class=\"native\"/>\n"
-"\n"
-"        </id>\n"
-"\n"
-"        <property\n"
-"            name=\"name\"\n"
-"            column=\"NAME\"\n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"\n"
-"        <bag\n"
-"            name=\"items\"\n"
-"            inverse=\"true\"\n"
-"            order-by=\"DATE_TIME\"\n"
-"            cascade=\"all\">\n"
-"\n"
-"            <key column=\"BLOG_ID\"/>\n"
-"            <one-to-many class=\"BlogItem\"/>\n"
-"\n"
-"        </bag>\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"    <class\n"
-"        name=\"Blog\"\n"
-"        table=\"BLOGS\">\n"
-"\n"
-"        <id\n"
-"            name=\"id\"\n"
-"            column=\"BLOG_ID\">\n"
-"\n"
-"            <generator class=\"native\"/>\n"
-"\n"
-"        </id>\n"
-"\n"
-"        <property\n"
-"            name=\"name\"\n"
-"            column=\"NAME\"\n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"\n"
-"        <bag\n"
-"            name=\"items\"\n"
-"            inverse=\"true\"\n"
-"            order-by=\"DATE_TIME\"\n"
-"            cascade=\"all\">\n"
-"\n"
-"            <key column=\"BLOG_ID\"/>\n"
-"            <one-to-many class=\"BlogItem\"/>\n"
-"\n"
-"        </bag>\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-
-#. Tag: programlisting
-#: example_weblog.xml:55
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"    <class\n"
-"        name=\"BlogItem\"\n"
-"        table=\"BLOG_ITEMS\"\n"
-"        dynamic-update=\"true\">\n"
-"\n"
-"        <id\n"
-"            name=\"id\"\n"
-"            column=\"BLOG_ITEM_ID\">\n"
-"\n"
-"            <generator class=\"native\"/>\n"
-"\n"
-"        </id>\n"
-"\n"
-"        <property\n"
-"            name=\"title\"\n"
-"            column=\"TITLE\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <property\n"
-"            name=\"text\"\n"
-"            column=\"TEXT\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <property\n"
-"            name=\"datetime\"\n"
-"            column=\"DATE_TIME\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <many-to-one\n"
-"            name=\"blog\"\n"
-"            column=\"BLOG_ID\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"    <class\n"
-"        name=\"BlogItem\"\n"
-"        table=\"BLOG_ITEMS\"\n"
-"        dynamic-update=\"true\">\n"
-"\n"
-"        <id\n"
-"            name=\"id\"\n"
-"            column=\"BLOG_ITEM_ID\">\n"
-"\n"
-"            <generator class=\"native\"/>\n"
-"\n"
-"        </id>\n"
-"\n"
-"        <property\n"
-"            name=\"title\"\n"
-"            column=\"TITLE\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <property\n"
-"            name=\"text\"\n"
-"            column=\"TEXT\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <property\n"
-"            name=\"datetime\"\n"
-"            column=\"DATE_TIME\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <many-to-one\n"
-"            name=\"blog\"\n"
-"            column=\"BLOG_ID\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-
 #. Tag: title
-#: example_weblog.xml:60
 #, no-c-format
 msgid "Hibernate Code"
-msgstr "C&#x00f3;digo Hibernate"
+msgstr "Código Hibernate"
 
 #. Tag: para
-#: example_weblog.xml:62
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following class demonstrates some of the kinds of things we can do with "
 "these classes using Hibernate:"
 msgstr ""
-"La siguiente clase demuestra algunos de los tipos de cosas que podemos haces "
-"con estas clases, usando Hibernate."
+"La siguiente clase demuestra algunos de los tipos de cosas que podemos hacer "
+"con estas clases, utilizando Hibernate:"
 
-#. Tag: programlisting
-#: example_weblog.xml:67
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.util.ArrayList;\n"
-"import java.util.Calendar;\n"
-"import java.util.Iterator;\n"
-"import java.util.List;\n"
-"\n"
-"import org.hibernate.HibernateException;\n"
-"import org.hibernate.Query;\n"
-"import org.hibernate.Session;\n"
-"import org.hibernate.SessionFactory;\n"
-"import org.hibernate.Transaction;\n"
-"import org.hibernate.cfg.Configuration;\n"
-"import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
-"\n"
-"public class BlogMain {\n"
-"    \n"
-"    private SessionFactory _sessions;\n"
-"    \n"
-"    public void configure() throws HibernateException {\n"
-"        _sessions = new Configuration()\n"
-"            .addClass(Blog.class)\n"
-"            .addClass(BlogItem.class)\n"
-"            .buildSessionFactory();\n"
-"    }\n"
-"    \n"
-"    public void exportTables() throws HibernateException {\n"
-"        Configuration cfg = new Configuration()\n"
-"            .addClass(Blog.class)\n"
-"            .addClass(BlogItem.class);\n"
-"        new SchemaExport(cfg).create(true, true);\n"
-"    }\n"
-"    \n"
-"    public Blog createBlog(String name) throws HibernateException {\n"
-"        \n"
-"        Blog blog = new Blog();\n"
-"        blog.setName(name);\n"
-"        blog.setItems( new ArrayList() );\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.persist(blog);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return blog;\n"
-"    }\n"
-"    \n"
-"    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
-"                        throws HibernateException {\n"
-"        \n"
-"        BlogItem item = new BlogItem();\n"
-"        item.setTitle(title);\n"
-"        item.setText(text);\n"
-"        item.setBlog(blog);\n"
-"        item.setDatetime( Calendar.getInstance() );\n"
-"        blog.getItems().add(item);\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.update(blog);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return item;\n"
-"    }\n"
-"    \n"
-"    public BlogItem createBlogItem(Long blogid, String title, String text)\n"
-"                        throws HibernateException {\n"
-"        \n"
-"        BlogItem item = new BlogItem();\n"
-"        item.setTitle(title);\n"
-"        item.setText(text);\n"
-"        item.setDatetime( Calendar.getInstance() );\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
-"            item.setBlog(blog);\n"
-"            blog.getItems().add(item);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return item;\n"
-"    }\n"
-"    \n"
-"    public void updateBlogItem(BlogItem item, String text)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        item.setText(text);\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.update(item);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"    }\n"
-"    \n"
-"    public void updateBlogItem(Long itemid, String text)\n"
-"                    throws HibernateException {\n"
-"    \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            BlogItem item = (BlogItem) session.load(BlogItem.class, "
-"itemid);\n"
-"            item.setText(text);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"    }\n"
-"    \n"
-"    public List listAllBlogNamesAndItemCounts(int max)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        List result = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"select blog.id, blog.name, count(blogItem) \" +\n"
-"                \"from Blog as blog \" +\n"
-"                \"left outer join blog.items as blogItem \" +\n"
-"                \"group by blog.name, blog.id \" +\n"
-"                \"order by max(blogItem.datetime)\"\n"
-"            );\n"
-"            q.setMaxResults(max);\n"
-"            result = q.list();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return result;\n"
-"    }\n"
-"    \n"
-"    public Blog getBlogAndAllItems(Long blogid)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        Blog blog = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"from Blog as blog \" +\n"
-"                \"left outer join fetch blog.items \" +\n"
-"                \"where blog.id = :blogid\"\n"
-"            );\n"
-"            q.setParameter(\"blogid\", blogid);\n"
-"            blog  = (Blog) q.uniqueResult();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return blog;\n"
-"    }\n"
-"    \n"
-"    public List listBlogsAndRecentItems() throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        List result = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"from Blog as blog \" +\n"
-"                \"inner join blog.items as blogItem \" +\n"
-"                \"where blogItem.datetime > :minDate\"\n"
-"            );\n"
-"\n"
-"            Calendar cal = Calendar.getInstance();\n"
-"            cal.roll(Calendar.MONTH, false);\n"
-"            q.setCalendar(\"minDate\", cal);\n"
-"            \n"
-"            result = q.list();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return result;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.util.ArrayList;\n"
-"import java.util.Calendar;\n"
-"import java.util.Iterator;\n"
-"import java.util.List;\n"
-"\n"
-"import org.hibernate.HibernateException;\n"
-"import org.hibernate.Query;\n"
-"import org.hibernate.Session;\n"
-"import org.hibernate.SessionFactory;\n"
-"import org.hibernate.Transaction;\n"
-"import org.hibernate.cfg.Configuration;\n"
-"import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
-"\n"
-"public class BlogMain {\n"
-"    \n"
-"    private SessionFactory _sessions;\n"
-"    \n"
-"    public void configure() throws HibernateException {\n"
-"        _sessions = new Configuration()\n"
-"            .addClass(Blog.class)\n"
-"            .addClass(BlogItem.class)\n"
-"            .buildSessionFactory();\n"
-"    }\n"
-"    \n"
-"    public void exportTables() throws HibernateException {\n"
-"        Configuration cfg = new Configuration()\n"
-"            .addClass(Blog.class)\n"
-"            .addClass(BlogItem.class);\n"
-"        new SchemaExport(cfg).create(true, true);\n"
-"    }\n"
-"    \n"
-"    public Blog createBlog(String name) throws HibernateException {\n"
-"        \n"
-"        Blog blog = new Blog();\n"
-"        blog.setName(name);\n"
-"        blog.setItems( new ArrayList() );\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.persist(blog);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return blog;\n"
-"    }\n"
-"    \n"
-"    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
-"                        throws HibernateException {\n"
-"        \n"
-"        BlogItem item = new BlogItem();\n"
-"        item.setTitle(title);\n"
-"        item.setText(text);\n"
-"        item.setBlog(blog);\n"
-"        item.setDatetime( Calendar.getInstance() );\n"
-"        blog.getItems().add(item);\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.update(blog);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return item;\n"
-"    }\n"
-"    \n"
-"    public BlogItem createBlogItem(Long blogid, String title, String text)\n"
-"                        throws HibernateException {\n"
-"        \n"
-"        BlogItem item = new BlogItem();\n"
-"        item.setTitle(title);\n"
-"        item.setText(text);\n"
-"        item.setDatetime( Calendar.getInstance() );\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
-"            item.setBlog(blog);\n"
-"            blog.getItems().add(item);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return item;\n"
-"    }\n"
-"    \n"
-"    public void updateBlogItem(BlogItem item, String text)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        item.setText(text);\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.update(item);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"    }\n"
-"    \n"
-"    public void updateBlogItem(Long itemid, String text)\n"
-"                    throws HibernateException {\n"
-"    \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            BlogItem item = (BlogItem) session.load(BlogItem.class, "
-"itemid);\n"
-"            item.setText(text);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"    }\n"
-"    \n"
-"    public List listAllBlogNamesAndItemCounts(int max)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        List result = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"select blog.id, blog.name, count(blogItem) \" +\n"
-"                \"from Blog as blog \" +\n"
-"                \"left outer join blog.items as blogItem \" +\n"
-"                \"group by blog.name, blog.id \" +\n"
-"                \"order by max(blogItem.datetime)\"\n"
-"            );\n"
-"            q.setMaxResults(max);\n"
-"            result = q.list();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return result;\n"
-"    }\n"
-"    \n"
-"    public Blog getBlogAndAllItems(Long blogid)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        Blog blog = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"from Blog as blog \" +\n"
-"                \"left outer join fetch blog.items \" +\n"
-"                \"where blog.id = :blogid\"\n"
-"            );\n"
-"            q.setParameter(\"blogid\", blogid);\n"
-"            blog  = (Blog) q.uniqueResult();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return blog;\n"
-"    }\n"
-"    \n"
-"    public List listBlogsAndRecentItems() throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        List result = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"from Blog as blog \" +\n"
-"                \"inner join blog.items as blogItem \" +\n"
-"                \"where blogItem.datetime > :minDate\"\n"
-"            );\n"
-"\n"
-"            Calendar cal = Calendar.getInstance();\n"
-"            cal.roll(Calendar.MONTH, false);\n"
-"            q.setCalendar(\"minDate\", cal);\n"
-"            \n"
-"            result = q.list();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return result;\n"
-"    }\n"
-"}]]>"
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "public class Blog {\n"
+#~ "    private Long _id;\n"
+#~ "    private String _name;\n"
+#~ "    private List _items;\n"
+#~ "\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public List getItems() {\n"
+#~ "        return _items;\n"
+#~ "    }\n"
+#~ "    public String getName() {\n"
+#~ "        return _name;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setItems(List list) {\n"
+#~ "        _items = list;\n"
+#~ "    }\n"
+#~ "    public void setName(String string) {\n"
+#~ "        _name = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "public class Blog {\n"
+#~ "    private Long _id;\n"
+#~ "    private String _name;\n"
+#~ "    private List _items;\n"
+#~ "\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public List getItems() {\n"
+#~ "        return _items;\n"
+#~ "    }\n"
+#~ "    public String getName() {\n"
+#~ "        return _name;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setItems(List list) {\n"
+#~ "        _items = list;\n"
+#~ "    }\n"
+#~ "    public void setName(String string) {\n"
+#~ "        _name = string;\n"
+#~ "    }\n"
+#~ "}]]>"
 
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.text.DateFormat;\n"
+#~ "import java.util.Calendar;\n"
+#~ "\n"
+#~ "public class BlogItem {\n"
+#~ "    private Long _id;\n"
+#~ "    private Calendar _datetime;\n"
+#~ "    private String _text;\n"
+#~ "    private String _title;\n"
+#~ "    private Blog _blog;\n"
+#~ "\n"
+#~ "    public Blog getBlog() {\n"
+#~ "        return _blog;\n"
+#~ "    }\n"
+#~ "    public Calendar getDatetime() {\n"
+#~ "        return _datetime;\n"
+#~ "    }\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public String getText() {\n"
+#~ "        return _text;\n"
+#~ "    }\n"
+#~ "    public String getTitle() {\n"
+#~ "        return _title;\n"
+#~ "    }\n"
+#~ "    public void setBlog(Blog blog) {\n"
+#~ "        _blog = blog;\n"
+#~ "    }\n"
+#~ "    public void setDatetime(Calendar calendar) {\n"
+#~ "        _datetime = calendar;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setText(String string) {\n"
+#~ "        _text = string;\n"
+#~ "    }\n"
+#~ "    public void setTitle(String string) {\n"
+#~ "        _title = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.text.DateFormat;\n"
+#~ "import java.util.Calendar;\n"
+#~ "\n"
+#~ "public class BlogItem {\n"
+#~ "    private Long _id;\n"
+#~ "    private Calendar _datetime;\n"
+#~ "    private String _text;\n"
+#~ "    private String _title;\n"
+#~ "    private Blog _blog;\n"
+#~ "\n"
+#~ "    public Blog getBlog() {\n"
+#~ "        return _blog;\n"
+#~ "    }\n"
+#~ "    public Calendar getDatetime() {\n"
+#~ "        return _datetime;\n"
+#~ "    }\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public String getText() {\n"
+#~ "        return _text;\n"
+#~ "    }\n"
+#~ "    public String getTitle() {\n"
+#~ "        return _title;\n"
+#~ "    }\n"
+#~ "    public void setBlog(Blog blog) {\n"
+#~ "        _blog = blog;\n"
+#~ "    }\n"
+#~ "    public void setDatetime(Calendar calendar) {\n"
+#~ "        _datetime = calendar;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setText(String string) {\n"
+#~ "        _text = string;\n"
+#~ "    }\n"
+#~ "    public void setTitle(String string) {\n"
+#~ "        _title = string;\n"
+#~ "    }\n"
+#~ "}]]>"
 
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"Blog\"\n"
+#~ "        table=\"BLOGS\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"name\"\n"
+#~ "            column=\"NAME\"\n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "\n"
+#~ "        <bag\n"
+#~ "            name=\"items\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            order-by=\"DATE_TIME\"\n"
+#~ "            cascade=\"all\">\n"
+#~ "\n"
+#~ "            <key column=\"BLOG_ID\"/>\n"
+#~ "            <one-to-many class=\"BlogItem\"/>\n"
+#~ "\n"
+#~ "        </bag>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"Blog\"\n"
+#~ "        table=\"BLOGS\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"name\"\n"
+#~ "            column=\"NAME\"\n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "\n"
+#~ "        <bag\n"
+#~ "            name=\"items\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            order-by=\"DATE_TIME\"\n"
+#~ "            cascade=\"all\">\n"
+#~ "\n"
+#~ "            <key column=\"BLOG_ID\"/>\n"
+#~ "            <one-to-many class=\"BlogItem\"/>\n"
+#~ "\n"
+#~ "        </bag>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"BlogItem\"\n"
+#~ "        table=\"BLOG_ITEMS\"\n"
+#~ "        dynamic-update=\"true\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ITEM_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"title\"\n"
+#~ "            column=\"TITLE\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"text\"\n"
+#~ "            column=\"TEXT\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"datetime\"\n"
+#~ "            column=\"DATE_TIME\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <many-to-one\n"
+#~ "            name=\"blog\"\n"
+#~ "            column=\"BLOG_ID\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"BlogItem\"\n"
+#~ "        table=\"BLOG_ITEMS\"\n"
+#~ "        dynamic-update=\"true\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ITEM_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"title\"\n"
+#~ "            column=\"TITLE\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"text\"\n"
+#~ "            column=\"TEXT\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"datetime\"\n"
+#~ "            column=\"DATE_TIME\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <many-to-one\n"
+#~ "            name=\"blog\"\n"
+#~ "            column=\"BLOG_ID\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.ArrayList;\n"
+#~ "import java.util.Calendar;\n"
+#~ "import java.util.Iterator;\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "import org.hibernate.HibernateException;\n"
+#~ "import org.hibernate.Query;\n"
+#~ "import org.hibernate.Session;\n"
+#~ "import org.hibernate.SessionFactory;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.cfg.Configuration;\n"
+#~ "import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
+#~ "\n"
+#~ "public class BlogMain {\n"
+#~ "    \n"
+#~ "    private SessionFactory _sessions;\n"
+#~ "    \n"
+#~ "    public void configure() throws HibernateException {\n"
+#~ "        _sessions = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class)\n"
+#~ "            .buildSessionFactory();\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void exportTables() throws HibernateException {\n"
+#~ "        Configuration cfg = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class);\n"
+#~ "        new SchemaExport(cfg).create(true, true);\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog createBlog(String name) throws HibernateException {\n"
+#~ "        \n"
+#~ "        Blog blog = new Blog();\n"
+#~ "        blog.setName(name);\n"
+#~ "        blog.setItems( new ArrayList() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.persist(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setBlog(blog);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        blog.getItems().add(item);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Long blogid, String title, String "
+#~ "text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
+#~ "            item.setBlog(blog);\n"
+#~ "            blog.getItems().add(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(BlogItem item, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        item.setText(text);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(Long itemid, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "    \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            BlogItem item = (BlogItem) session.load(BlogItem.class, "
+#~ "itemid);\n"
+#~ "            item.setText(text);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listAllBlogNamesAndItemCounts(int max)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"select blog.id, blog.name, count(blogItem) \" +\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join blog.items as blogItem \" +\n"
+#~ "                \"group by blog.name, blog.id \" +\n"
+#~ "                \"order by max(blogItem.datetime)\"\n"
+#~ "            );\n"
+#~ "            q.setMaxResults(max);\n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog getBlogAndAllItems(Long blogid)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        Blog blog = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join fetch blog.items \" +\n"
+#~ "                \"where blog.id = :blogid\"\n"
+#~ "            );\n"
+#~ "            q.setParameter(\"blogid\", blogid);\n"
+#~ "            blog  = (Blog) q.uniqueResult();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listBlogsAndRecentItems() throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"inner join blog.items as blogItem \" +\n"
+#~ "                \"where blogItem.datetime > :minDate\"\n"
+#~ "            );\n"
+#~ "\n"
+#~ "            Calendar cal = Calendar.getInstance();\n"
+#~ "            cal.roll(Calendar.MONTH, false);\n"
+#~ "            q.setCalendar(\"minDate\", cal);\n"
+#~ "            \n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.ArrayList;\n"
+#~ "import java.util.Calendar;\n"
+#~ "import java.util.Iterator;\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "import org.hibernate.HibernateException;\n"
+#~ "import org.hibernate.Query;\n"
+#~ "import org.hibernate.Session;\n"
+#~ "import org.hibernate.SessionFactory;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.cfg.Configuration;\n"
+#~ "import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
+#~ "\n"
+#~ "public class BlogMain {\n"
+#~ "    \n"
+#~ "    private SessionFactory _sessions;\n"
+#~ "    \n"
+#~ "    public void configure() throws HibernateException {\n"
+#~ "        _sessions = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class)\n"
+#~ "            .buildSessionFactory();\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void exportTables() throws HibernateException {\n"
+#~ "        Configuration cfg = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class);\n"
+#~ "        new SchemaExport(cfg).create(true, true);\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog createBlog(String name) throws HibernateException {\n"
+#~ "        \n"
+#~ "        Blog blog = new Blog();\n"
+#~ "        blog.setName(name);\n"
+#~ "        blog.setItems( new ArrayList() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.persist(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setBlog(blog);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        blog.getItems().add(item);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Long blogid, String title, String "
+#~ "text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
+#~ "            item.setBlog(blog);\n"
+#~ "            blog.getItems().add(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(BlogItem item, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        item.setText(text);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(Long itemid, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "    \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            BlogItem item = (BlogItem) session.load(BlogItem.class, "
+#~ "itemid);\n"
+#~ "            item.setText(text);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listAllBlogNamesAndItemCounts(int max)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"select blog.id, blog.name, count(blogItem) \" +\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join blog.items as blogItem \" +\n"
+#~ "                \"group by blog.name, blog.id \" +\n"
+#~ "                \"order by max(blogItem.datetime)\"\n"
+#~ "            );\n"
+#~ "            q.setMaxResults(max);\n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog getBlogAndAllItems(Long blogid)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        Blog blog = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join fetch blog.items \" +\n"
+#~ "                \"where blog.id = :blogid\"\n"
+#~ "            );\n"
+#~ "            q.setParameter(\"blogid\", blogid);\n"
+#~ "            blog  = (Blog) q.uniqueResult();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listBlogsAndRecentItems() throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"inner join blog.items as blogItem \" +\n"
+#~ "                \"where blogItem.datetime > :minDate\"\n"
+#~ "            );\n"
+#~ "\n"
+#~ "            Calendar cal = Calendar.getInstance();\n"
+#~ "            cal.roll(Calendar.MONTH, false);\n"
+#~ "            q.setCalendar(\"minDate\", cal);\n"
+#~ "            \n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "}]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/filters.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/filters.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/filters.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,41 +1,53 @@
-#, fuzzy
+# translation of filters.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: filters\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-11-11 08:28+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: filters.xml:29
 #, no-c-format
 msgid "Filtering data"
-msgstr "Filtrando datos"
+msgstr "Filtración de datos"
 
 #. Tag: para
-#: filters.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 provides an innovative new approach to handling data with "
 "\"visibility\" rules. A <emphasis>Hibernate filter</emphasis> is a global, "
 "named, parameterized filter that can be enabled or disabled for a particular "
 "Hibernate session."
 msgstr ""
-"Hibernate3 provee un nuevo enfoque innovador para manejar datos con reglas "
-"de \"visibilidad\". Un <emphasis>filtro de Hibernate</emphasis> es un filtro "
-"global, con nombre y parametrizado que puede ser habilitado o deshabilitado "
-"para una sesión de Hibernate en particular."
+"Hibernate3 proporciona un nuevo enfoque innovador para manejar datos con "
+"reglas de \"visibilidad\". Un <emphasis>filtro Hibernate</emphasis> es un "
+"filtro global, con nombre y parametrizado que puede ser habilitado o "
+"deshabilitado para una sesión de Hibernate especifica."
 
 #. Tag: title
-#: filters.xml:38
 #, no-c-format
 msgid "Hibernate filters"
 msgstr "Filtros de Hibernate"
 
 #. Tag: para
-#: filters.xml:40
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 has the ability to pre-define filter criteria and attach those "
 "filters at both a class level and a collection level. A filter criteria "
@@ -46,18 +58,17 @@
 "parameter values should be. Filters can be used like database views, but "
 "they are parameterized inside the application."
 msgstr ""
-"Hibernate3 añade la habilidad de predefinir criterios de filtros y unir esos "
-"filtros tanto a nivel de una clase como de una colección. Un criterio de "
-"filtro es la habilidad de definir una cláusula de restricción muy similar al "
-"atributo existente \"where\" disponible en el elemento class y varios "
-"elementos de colección. Excepto en que estos filtros pueden ser "
-"parametrizados. La aplicación puede tomar la decisión en tiempo de ejecución "
-"de qué filtros deben estar habilitados y cuáles deben ser sus parámetros. "
-"Los filtros pueden ser usados como vistas de base de datos, pero "
+"Hibernate3 tiene la habilidad de predefinir criterios de filtros y unir esos "
+"filtros tanto a nivel de clase como de colección. Un criterio de filtro le "
+"permite definir una cláusula de restricción muy similar al atributo "
+"existente \"where\" disponible en el elemento class y en varios elementos de "
+"colección. Sin embargo, las condiciones de estos filtros se pueden "
+"parametrizar. La aplicación puede tomar la decisión en tiempo de ejecución "
+"de si los filtros deben estar habilitados y cuáles deben ser sus parámetros. "
+"Los filtros se pueden utilizar como vistas de la base de datos, pero "
 "parametrizados dentro de la aplicación."
 
 #. Tag: para
-#: filters.xml:50
 #, no-c-format
 msgid ""
 "In order to use filters, they must first be defined and then attached to the "
@@ -65,74 +76,28 @@
 "filter-def/&gt;</literal> element within a <literal>&lt;hibernate-mapping/"
 "&gt;</literal> element:"
 msgstr ""
-"Para usar los filtros, éstos deben primero ser definidos y luego unidos a "
-"los elementos de mapeo apropiados. Para definir un filtro, usa el elemento "
-"<literal>&lt;filter-def/&gt;</literal> dentro de un elemento <literal>&lt;"
-"hibernate-mapping/&gt;</literal>:"
+"Para utilizar los filtros, éstos se deben definir primero y luego se unen a "
+"los elementos de mapeo apropiados. Para definir un filtro, utilice el "
+"elemento <literal>&lt;filter-def/&gt;</literal> dentro de un elemento "
+"<literal>&lt;hibernate-mapping/&gt;</literal>:"
 
-#. Tag: programlisting
-#: filters.xml:56
-#, no-c-format
-msgid ""
-"<![CDATA[<filter-def name=\"myFilter\">\n"
-"    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
-"</filter-def>]]>"
-msgstr ""
-"<![CDATA[<filter-def name=\"myFilter\">\n"
-"    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
-"</filter-def>]]>"
-
 #. Tag: para
-#: filters.xml:58
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This filter can then be attached to a class:"
-msgstr "Entonces este filtro puede ser unido a una clase:"
+msgstr "Luego este filtro se puede adjuntar a una clase:"
 
-#. Tag: programlisting
-#: filters.xml:62
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"myClass\" ...>\n"
-"    ...\n"
-"    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN"
-"\"/>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"myClass\" ...>\n"
-"    ...\n"
-"    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN"
-"\"/>\n"
-"</class>]]>"
-
 #. Tag: para
-#: filters.xml:64
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Or, to a collection:"
-msgstr "o a una colección:"
+msgstr "O a una colección:"
 
-#. Tag: programlisting
-#: filters.xml:68
-#, no-c-format
-msgid ""
-"<![CDATA[<set ...>\n"
-"    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN"
-"\"/>\n"
-"</set>]]>"
-msgstr ""
-"<![CDATA[<set ...>\n"
-"    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN"
-"\"/>\n"
-"</set>]]>"
-
 #. Tag: para
-#: filters.xml:70
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Or, to both or multiples of each at the same time."
-msgstr "o incluso a ambos (o muchos de cada uno) al mismo tiempo."
+msgstr "O incluso a ambos o múltiples de cada uno al mismo tiempo."
 
 #. Tag: para
-#: filters.xml:74
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The methods on <literal>Session</literal> are: <literal>enableFilter(String "
 "filterName)</literal>, <literal>getEnabledFilter(String filterName)</"
@@ -145,177 +110,69 @@
 msgstr ""
 "Los métodos en <literal>Session</literal> son: <literal>enableFilter(String "
 "filterName)</literal>, <literal>getEnabledFilter(String filterName)</"
-"literal>, y <literal>disableFilter(String filterName)</literal>. Por "
-"defecto, los filtros <emphasis>no</emphasis> están habilitados para una "
-"sesión dada; deben ser habilitados explícitamente por medio del uso del "
-"método <literal>Session.enableFilter()</literal>, que devuelve una instancia "
-"de la interface <literal>Filter</literal>. Usando el filtro simple definido "
-"arriba, esto se vería así:"
+"literal> y <literal>disableFilter(String filterName)</literal>. Por defecto, "
+"los filtros <emphasis>no</emphasis> están habilitados para una sesión dada. "
+"Los filtros deben ser habilitados explícitamente por medio del uso del "
+"método <literal>Session.enableFilter()</literal>, el cual retorna una "
+"instancia de la interfaz <literal>Filter</literal>. Si se utiliza el filtro "
+"simple definido anteriormente, esto se vería así:"
 
-#. Tag: programlisting
-#: filters.xml:83
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam\", "
-"\"some-value\");]]>"
-msgstr ""
-"<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam\", "
-"\"some-value\");]]>"
-
-#. Tag: para
-#: filters.xml:85
-#, fuzzy, no-c-format
-msgid ""
 "Methods on the org.hibernate.Filter interface do allow the method-chaining "
 "common to much of Hibernate."
 msgstr ""
-"Nota que los métodos en la interface org.hibernate.Filter permiten el "
-"encadenamiento de métodos común en gran parte de Hibernate."
+"Los métodos en la interfaz org.hibernate.Filter permiten el encadenamiento "
+"de métodos, lo cual es bastante común en gran parte de Hibernate."
 
 #. Tag: para
-#: filters.xml:89
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is a full example, using temporal data with an effective "
 "record date pattern:"
 msgstr ""
-"Un ejemplo completo, usando datos temporales con un patrón efectivo de "
-"fechas de registro:"
+"Este es un ejemplo completo, utilizando datos temporales con un patrón "
+"efectivo de fechas de registro: "
 
-#. Tag: programlisting
-#: filters.xml:93
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<filter-def name=\"effectiveDate\">\n"
-"    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
-"</filter-def>\n"
-"\n"
-"<class name=\"Employee\" ...>\n"
-"...\n"
-"    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department\"/"
-">\n"
-"    <property name=\"effectiveStartDate\" type=\"date\" column=\"eff_start_dt"
-"\"/>\n"
-"    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt\"/"
-">\n"
-"...\n"
-"    <!--\n"
-"        Note that this assumes non-terminal records have an eff_end_dt set "
-"to\n"
-"        a max db date for simplicity-sake\n"
-"    -->\n"
-"    <filter name=\"effectiveDate\"\n"
-"            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Department\" ...>\n"
-"...\n"
-"    <set name=\"employees\" lazy=\"true\">\n"
-"        <key column=\"dept_id\"/>\n"
-"        <one-to-many class=\"Employee\"/>\n"
-"        <filter name=\"effectiveDate\"\n"
-"                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
-">\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<filter-def name=\"effectiveDate\">\n"
-"    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
-"</filter-def>\n"
-"\n"
-"<class name=\"Employee\" ...>\n"
-"...\n"
-"    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department\"/"
-">\n"
-"    <property name=\"effectiveStartDate\" type=\"date\" column=\"eff_start_dt"
-"\"/>\n"
-"    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt\"/"
-">\n"
-"...\n"
-"    <!--\n"
-"        Note that this assumes non-terminal records have an eff_end_dt set "
-"to\n"
-"        a max db date for simplicity-sake\n"
-"    -->\n"
-"    <filter name=\"effectiveDate\"\n"
-"            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Department\" ...>\n"
-"...\n"
-"    <set name=\"employees\" lazy=\"true\">\n"
-"        <key column=\"dept_id\"/>\n"
-"        <one-to-many class=\"Employee\"/>\n"
-"        <filter name=\"effectiveDate\"\n"
-"                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
-">\n"
-"    </set>\n"
-"</class>]]>"
-
-#. Tag: para
-#: filters.xml:95
-#, fuzzy, no-c-format
-msgid ""
 "In order to ensure that you are provided with currently effective records, "
 "enable the filter on the session prior to retrieving employee data:"
 msgstr ""
-"Entonces, en orden de asegurar que siempre tendrás de vuelta registros "
-"actualmente efectivos, simplemente habilita el filtro en la sesión previo a "
-"recuperar los datos de empleados:"
+"Con el fin de asegurarse de que siempre recibirá los registros efectivos "
+"actualmente, habilite el filtro en la sesión antes de recuperar los datos de "
+"los empleados:"
 
-#. Tag: programlisting
-#: filters.xml:100
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = ...;\n"
-"session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new Date"
-"());\n"
-"List results = session.createQuery(\"from Employee as e where e.salary > :"
-"targetSalary\")\n"
-"         .setLong(\"targetSalary\", new Long(1000000))\n"
-"         .list();\n"
-"]]>"
-msgstr ""
-"<![CDATA[Session session = ...;\n"
-"session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new Date"
-"());\n"
-"List results = session.createQuery(\"from Employee as e where e.salary > :"
-"targetSalary\")\n"
-"         .setLong(\"targetSalary\", new Long(1000000))\n"
-"         .list();\n"
-"]]>"
-
-#. Tag: para
-#: filters.xml:102
-#, fuzzy, no-c-format
-msgid ""
 "Even though a salary constraint was mentioned explicitly on the results in "
 "the above HQL, because of the enabled filter, the query will return only "
 "currently active employees who have a salary greater than one million "
 "dollars."
 msgstr ""
-"En el HQL de arriba, aunque sólo hemos mencionado explícitamente una "
-"restricción de salario en los resultados, debido al filtro habilitado la "
-"consulta sólo devolverá empleados actualmente activos que tengan un salario "
-"mayor que un millón de dólares."
+"En el HQL anterior, aunque sólo mencionamos explícitamente una restricción "
+"de salario en los resultados, debido al filtro habilitado la consulta sólo "
+"retornará empleados actualmente activos que tengan un salario mayor a un "
+"millón de dólares."
 
 #. Tag: para
-#: filters.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want to use filters with outer joining, either through HQL or load "
 "fetching, be careful of the direction of the condition expression. It is "
 "safest to set this up for left outer joining. Place the parameter first "
 "followed by the column name(s) after the operator."
 msgstr ""
-"Nota: si planeas usar filtros con unión externa (outer joining) (bien a "
-"través de HQL, o bien de recuperación de carga) sé cuidadoso en la dirección "
-"de expresión de la condición. Lo más seguro es establecer esto para unión "
-"externa izquierda (left outer joining). En general, coloca el primer "
-"parámetro seguido del nombre(s) de columna(s) después del operador."
+"Si quiere utilizar filtros con unión externa, ya sea a través de HQL, o bien "
+"de recuperación de carga, tenga cuidado en la dirección de expresión de la "
+"condición. Lo más seguro es configurar esto para una unión externa "
+"izquierda. Coloque el parámetro primero seguido del nombre(s) de la(s) "
+"columna(s) después del operador."
 
 #. Tag: para
-#: filters.xml:115
 #, no-c-format
 msgid ""
 "After being defined, a filter might be attached to multiple entities and/or "
@@ -324,18 +181,13 @@
 "literal> allows you to definine a default condition, either as an attribute "
 "or CDATA:"
 msgstr ""
+"Después de definir un filtro, este se puede unir a múltiples entidades y/o "
+"colecciones cada una con su propia condición. Esto puede llegar a ser "
+"problemático cuando las condiciones son las mismas. Así que el usar "
+"<literal>&lt;filter-def/&gt;</literal> le permite definir una condición por "
+"defecto, ya sea como atributo o como CDATA:"
 
-#. Tag: programlisting
-#: filters.xml:122
-#, no-c-format
-msgid ""
-"<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</filter-"
-"def>\n"
-"<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"
-msgstr ""
-
 #. Tag: para
-#: filters.xml:124
 #, no-c-format
 msgid ""
 "This default condition will be used whenever the filter is attached to "
@@ -343,9 +195,144 @@
 "condition as part of the attachment of the filter that overrides the default "
 "condition in that particular case."
 msgstr ""
+"Esta condición predeterminada se utilizará cuando se una el filtro a algo "
+"sin especificar una condición. Esto significa que usted le puede dar una "
+"condición especifica como parte del anexo del filtro, el cual substituye la "
+"condición por defecto en ese caso en particular."
 
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
+#~ msgid ""
+#~ "<![CDATA[<filter-def name=\"myFilter\">\n"
+#~ "    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
+#~ "</filter-def>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<filter-def name=\"myFilter\">\n"
+#~ "    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
+#~ "</filter-def>]]>"
 
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+#~ msgid ""
+#~ "<![CDATA[<class name=\"myClass\" ...>\n"
+#~ "    ...\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"myClass\" ...>\n"
+#~ "    ...\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set ...>\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set ...>\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam"
+#~ "\", \"some-value\");]]>"
+#~ msgstr ""
+#~ "<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam"
+#~ "\", \"some-value\");]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<filter-def name=\"effectiveDate\">\n"
+#~ "    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
+#~ "</filter-def>\n"
+#~ "\n"
+#~ "<class name=\"Employee\" ...>\n"
+#~ "...\n"
+#~ "    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department"
+#~ "\"/>\n"
+#~ "    <property name=\"effectiveStartDate\" type=\"date\" column="
+#~ "\"eff_start_dt\"/>\n"
+#~ "    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt"
+#~ "\"/>\n"
+#~ "...\n"
+#~ "    <!--\n"
+#~ "        Note that this assumes non-terminal records have an eff_end_dt "
+#~ "set to\n"
+#~ "        a max db date for simplicity-sake\n"
+#~ "    -->\n"
+#~ "    <filter name=\"effectiveDate\"\n"
+#~ "            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
+#~ ">\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Department\" ...>\n"
+#~ "...\n"
+#~ "    <set name=\"employees\" lazy=\"true\">\n"
+#~ "        <key column=\"dept_id\"/>\n"
+#~ "        <one-to-many class=\"Employee\"/>\n"
+#~ "        <filter name=\"effectiveDate\"\n"
+#~ "                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt"
+#~ "\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<filter-def name=\"effectiveDate\">\n"
+#~ "    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
+#~ "</filter-def>\n"
+#~ "\n"
+#~ "<class name=\"Employee\" ...>\n"
+#~ "...\n"
+#~ "    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department"
+#~ "\"/>\n"
+#~ "    <property name=\"effectiveStartDate\" type=\"date\" column="
+#~ "\"eff_start_dt\"/>\n"
+#~ "    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt"
+#~ "\"/>\n"
+#~ "...\n"
+#~ "    <!--\n"
+#~ "        Note that this assumes non-terminal records have an eff_end_dt "
+#~ "set to\n"
+#~ "        a max db date for simplicity-sake\n"
+#~ "    -->\n"
+#~ "    <filter name=\"effectiveDate\"\n"
+#~ "            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
+#~ ">\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Department\" ...>\n"
+#~ "...\n"
+#~ "    <set name=\"employees\" lazy=\"true\">\n"
+#~ "        <key column=\"dept_id\"/>\n"
+#~ "        <one-to-many class=\"Employee\"/>\n"
+#~ "        <filter name=\"effectiveDate\"\n"
+#~ "                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt"
+#~ "\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = ...;\n"
+#~ "session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new "
+#~ "Date());\n"
+#~ "List results = session.createQuery(\"from Employee as e where e.salary > :"
+#~ "targetSalary\")\n"
+#~ "         .setLong(\"targetSalary\", new Long(1000000))\n"
+#~ "         .list();\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = ...;\n"
+#~ "session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new "
+#~ "Date());\n"
+#~ "List results = session.createQuery(\"from Employee as e where e.salary > :"
+#~ "targetSalary\")\n"
+#~ "         .setLong(\"targetSalary\", new Long(1000000))\n"
+#~ "         .list();\n"
+#~ "]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</"
+#~ "filter-def>\n"
+#~ "<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</"
+#~ "filter-def>\n"
+#~ "<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/inheritance_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/inheritance_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/inheritance_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,68 +1,74 @@
-#, fuzzy
+# translation of inheritance_mapping.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: inheritance_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-16 18:47+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-08 11:55+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: inheritance_mapping.xml:29
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Inheritance mapping"
-msgstr "Mapeo de Herencia"
+msgstr "Mapeo de herencia"
 
 #. Tag: title
-#: inheritance_mapping.xml:32
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The three strategies"
-msgstr "Las Tres Estrategias"
+msgstr "Las tres estrategias"
 
 #. Tag: para
-#: inheritance_mapping.xml:34
 #, no-c-format
 msgid "Hibernate supports the three basic inheritance mapping strategies:"
-msgstr ""
-"Hibernate soporta las tres estrategias b&#x00e1;sicas de mapeo de herencia:"
+msgstr "Hibernate soporta las tres estrategias básicas de mapeo de herencia:"
 
 #. Tag: para
-#: inheritance_mapping.xml:40
 #, no-c-format
 msgid "table per class hierarchy"
-msgstr "<para>tabla por jerarqu&#x00ed;a de clases</para>"
+msgstr "tabla por jerarquía de clases"
 
 #. Tag: para
-#: inheritance_mapping.xml:45
-#, no-c-format
-msgid "<para>table per subclass</para>"
-msgstr "<para>tabla por subclase</para>"
+#, fuzzy, no-c-format
+msgid "table per subclass"
+msgstr "Tabla por subclase"
 
 #. Tag: para
-#: inheritance_mapping.xml:50
 #, no-c-format
 msgid "table per concrete class"
 msgstr "tabla por clase concreta"
 
 #. Tag: para
-#: inheritance_mapping.xml:56
 #, no-c-format
 msgid ""
 "In addition, Hibernate supports a fourth, slightly different kind of "
 "polymorphism:"
 msgstr ""
-"En adici&#x00f3;n, Hibernate soporta un cuarto, ligeramente diferente tipo "
-"de polimorfismo:"
+"Además, Hibernate soporta un cuarto, un tipo ligeramente diferente de "
+"polimorfismo:"
 
 #. Tag: para
-#: inheritance_mapping.xml:63
 #, no-c-format
 msgid "implicit polymorphism"
-msgstr "polimorfismo impl&#x00ed;cito"
+msgstr "polimorfismo implícito"
 
 #. Tag: para
-#: inheritance_mapping.xml:69
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to use different mapping strategies for different branches of "
 "the same inheritance hierarchy. You can then make use of implicit "
@@ -75,20 +81,20 @@
 "literal> element, by combining the <literal>&lt;subclass&gt;</literal> and "
 "<literal>&lt;join&gt;</literal> elements (see below for an example)."
 msgstr ""
-"UNTRANSLATED! It is possible to define <literal>subclass</literal>, "
-"<literal>union-subclass</literal>, and <literal>joined-subclass</literal> "
-"mappings in separate mapping documents, directly beneath <literal>hibernate-"
-"mapping</literal>. This allows you to extend a class hierachy just by adding "
-"a new mapping file. You must specify an <literal>extends</literal> attribute "
-"in the subclass mapping, naming a previously mapped superclass. Note: "
-"Previously this feature made the ordering of the mapping documents "
-"important. Since Hibernate3, the ordering of mapping files does not matter "
-"when using the extends keyword. The ordering inside a single mapping file "
-"still needs to be defined as superclasses before subclasses."
+"Es posible utilizar estrategias de mapeo diferentes para diferentes "
+"ramificaciones de la misma jerarquía de herencia. Luego puede usar un "
+"polimorfismo implícito para conseguir polimorfismo a través de toda la "
+"jerarquía. Sin embargo, Hibernate no soporta la mezcla de mapeos "
+"<literal>&lt;subclass&gt;</literal>, <literal>&lt;joined-subclass&gt;</"
+"literal> y <literal>&lt;union-subclass&gt;</literal> bajo el mismo elemento "
+"<literal>&lt;class&gt;</literal> raíz. Es posible mezclar las estrategias de "
+"tabla por jerarquía y tabla por subclase bajo el mismo elemento <literal>&lt;"
+"class&gt;</literal>, combinando los elementos <literal>&lt;subclass&gt;</"
+"literal> y <literal>&lt;join&gt;</literal> (a continuación encontrará un "
+"ejemplo)."
 
 #. Tag: para
-#: inheritance_mapping.xml:83
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to define <literal>subclass</literal>, <literal>union-"
 "subclass</literal>, and <literal>joined-subclass</literal> mappings in "
@@ -101,193 +107,75 @@
 "extends keyword. The ordering inside a single mapping file still needs to be "
 "defined as superclasses before subclasses."
 msgstr ""
-"<![CDATA[\n"
-"                                 <hibernate-mapping>\n"
-"                                         <subclass name=\"DomesticCat\" "
-"extends=\"Cat\" discriminator-value=\"D\">\n"
-"                                                 <property name=\"name\" "
-"type=\"string\"/>\n"
-"                                         </subclass>\n"
-" </hibernate-mapping>]]>"
+"Es posible definir los mapeos <literal>subclass</literal>, <literal>union-"
+"subclass</literal>, y <literal>joined-subclass</literal> en documentos de "
+"mapeo separados, directamente debajo de <literal>hibernate-mapping</"
+"literal>. Esto le permite extender une jerarquía de clase sólamente "
+"añadiendo un nuevo archivo de mapeo. Tiene que especificar un atributo "
+"<literal>extends</literal> en la subclase de mapeo, nombrando una superclase "
+"mapeada previamente. Nota: Anteriormente esta característica hacia que el "
+"orden de los documentos de mapeo fuera importante. Desde Hibernate3, el "
+"orden de los archivos de mapeo no tiene relevancia cuando se utiliza la "
+"palabra clave extends. El orden dentro de un sólo archivo de mapeo todavía "
+"necesita ser definido como superclases antes de subclases."
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:94
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-" <hibernate-mapping>\n"
-"     <subclass name=\"DomesticCat\" extends=\"Cat\" discriminator-value=\"D"
-"\">\n"
-"          <property name=\"name\" type=\"string\"/>\n"
-"     </subclass>\n"
-" </hibernate-mapping>]]>"
-msgstr ""
-"Es posible usar estrategias de mapeo diferentes para diferentes "
-"ramificaciones de la misma jerarqu&#x00ed;a de herencia, y entonces usar "
-"polimorfismo impl&#x00ed;cito para conseguir polimorfismo a trav&#x00e9;s de "
-"toda la jerarqu&#x00ed;a. Sin embargo, Hibernate no soporta la mezcla de "
-"mapeos <literal>&lt;subclass&gt;</literal>, y <literal>&lt;joined-"
-"subclass&gt;</literal> y <literal>&lt;union-subclass&gt;</literal> bajo el "
-"mismo elemento <literal>&lt;class&gt;</literal> ra&#x00ed;z. Es posible "
-"mezclar juntas las estrategias de tabla por jerarqu&#x00ed;a y tabla por "
-"subclase, bajo el mismo elemento <literal>&lt;class&gt;</literal>, "
-"combinando los elementos <literal>&lt;subclass&gt;</literal> y <literal>&lt;"
-"join&gt;</literal> (ver debajo)."
-
 #. Tag: title
-#: inheritance_mapping.xml:98
 #, no-c-format
 msgid "Table per class hierarchy"
-msgstr "Tabla por jerarqu&#x00ed;a de clases"
+msgstr "Tabla por jerarquía de clases"
 
 #. Tag: para
-#: inheritance_mapping.xml:100
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Suppose we have an interface <literal>Payment</literal> with the "
 "implementors <literal>CreditCardPayment</literal>, <literal>CashPayment</"
 "literal>, and <literal>ChequePayment</literal>. The table per hierarchy "
 "mapping would display in the following way:"
 msgstr ""
-"Sup&#x00f3;n que tenemos una interface <literal>Payment</literal>, con los "
+"Suponga que tenemos una interfaz <literal>Payment</literal>, con los "
 "implementadores <literal>CreditCardPayment</literal>, <literal>CashPayment</"
-"literal>, <literal>ChequePayment</literal>. El mapeo de tabla por "
-"jerarqu&#x00ed;a se ver&#x00ed;a as&#x00ed;:"
+"literal>, <literal>ChequePayment</literal>. El mapeo de tabla por jerarquía "
+"se vería así: "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:107
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        ...\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        ...\n"
-"    </subclass>\n"
-"</class>]]>"
-
-#. Tag: para
-#: inheritance_mapping.xml:109
-#, fuzzy, no-c-format
-msgid ""
 "Exactly one table is required. There is a limitation of this mapping "
 "strategy: columns declared by the subclasses, such as <literal>CCTYPE</"
 "literal>, cannot have <literal>NOT NULL</literal> constraints."
 msgstr ""
-"Se requiere exactamente una tabla. Hay una gran limitaci&#x00f3;n de esta "
-"estrategia de mapeo: las columnas declaradas por las subclases, como "
-"<literal>CCTYPE</literal>, no pueden tener restricciones <literal>NOT NULL</"
-"literal>."
+"Se requiere exactamente una tabla. Hay una limitación de esta estrategia de "
+"mapeo: las columnas declaradas por las subclases tal como <literal>CCTYPE</"
+"literal>, no pueden tener restricciones <literal>NOT NULL</literal>."
 
 #. Tag: title
-#: inheritance_mapping.xml:118
 #, no-c-format
 msgid "Table per subclass"
 msgstr "Tabla por subclase"
 
 #. Tag: para
-#: inheritance_mapping.xml:120
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A table per subclass mapping looks like this:"
-msgstr "Un mapeo de tabla por sublclase se ver&#x00ed;a as&#x00ed;:"
+msgstr "Un mapeo de tabla por subclase se vería así: "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:124
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <joined-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <joined-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"</class>]]>"
-
-#. Tag: para
-#: inheritance_mapping.xml:126
-#, fuzzy, no-c-format
-msgid ""
 "Four tables are required. The three subclass tables have primary key "
 "associations to the superclass table so the relational model is actually a "
 "one-to-one association."
 msgstr ""
-"Se requieren cuatro tablas. Las tres tablas de subclase tienen asociaciones "
-"de clave primaria a la tabla de superclase (de modo que en el modelo "
-"relacional es realmente una asociaci&#x00f3;n uno-a-uno)."
+"Se necesitan cuatro tablas. Las tres tablas de subclase tienen asociaciones "
+"de clave principal a la tabla de superclase de modo que en el modelo "
+"relacional es realmente una asociación uno-a-uno."
 
 #. Tag: title
-#: inheritance_mapping.xml:135
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Table per subclass: using a discriminator"
-msgstr "Tabla por subclase, usando un discriminador"
+msgstr "Tabla por subclase: utilizando un discriminador"
 
 #. Tag: para
-#: inheritance_mapping.xml:137
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's implementation of table per subclass does not require a "
 "discriminator column. Other object/relational mappers use a different "
@@ -298,242 +186,77 @@
 "strategy, you can combine the use of <literal>&lt;subclass&gt;</literal> and "
 "<literal>&lt;join&gt;</literal>, as follows:"
 msgstr ""
-"Observa que la implementaci&#x00f3;n de Hibernate de tabla por subclase no "
-"requiere ninguna columna discriminadora. Otros mapeadores objeto/relacional "
-"usan una implementaci&#x00f3;n diferente de tabla por subclase que requiere "
-"una columna discriminadora de tipo en la tabla de superclase. Este enfoque "
-"es mucho m&#x00e1;s dif&#x00ed;cil de implementar pero discutiblemente "
-"m&#x00e1;s correcto desde un punto de vista relacional. Si quisieras usar "
-"una columna discriminadora con la estrategia de tabla por subclase, puedes "
-"combinar el uso de <literal>&lt;subclass&gt;</literal> y <literal>&lt;"
-"join&gt;</literal>, como sigue:"
+"La implementación de Hibernate de tabla por subclase no requiere ninguna "
+"columna discriminadora. Otros mapeadores objeto/relacional usan una "
+"implementación diferente de tabla por subclase que necesita una columna "
+"discriminadora de tipo en la tabla de superclase. Este enfoque es mucho más "
+"difícil de implementar pero discutiblemente más correcto desde un punto de "
+"vista relacional. Si quisiere utilizar una columna discriminadora con la "
+"estrategia de tabla por subclase, puede combinar el uso de <literal>&lt;"
+"subclass&gt;</literal> y <literal>&lt;join&gt;</literal>, así:"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:149
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <join table=\"CREDIT_PAYMENT\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        <join table=\"CASH_PAYMENT\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        <join table=\"CHEQUE_PAYMENT\" fetch=\"select\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <join table=\"CREDIT_PAYMENT\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        <join table=\"CASH_PAYMENT\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        <join table=\"CHEQUE_PAYMENT\" fetch=\"select\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"</class>]]>"
-
 #. Tag: para
-#: inheritance_mapping.xml:151
 #, no-c-format
 msgid ""
 "The optional <literal>fetch=\"select\"</literal> declaration tells Hibernate "
 "not to fetch the <literal>ChequePayment</literal> subclass data using an "
 "outer join when querying the superclass."
 msgstr ""
-"la declaraci&#x00f3;n opcional <literal>fetch=\"select\"</literal> dice a "
+"La declaración opcional <literal>fetch=\"select\"</literal> le dice a "
 "Hibernate que no recupere los datos de la subclase <literal>ChequePayment</"
-"literal> usando una uni&#x00f3;n externa (outer join) al consultar la "
+"literal> utilizando una unión externa (outer join) al consultar la "
 "superclase."
 
 #. Tag: title
-#: inheritance_mapping.xml:160
 #, no-c-format
 msgid "Mixing table per class hierarchy with table per subclass"
-msgstr "Mezclando tabla por jerarqu&#x00ed;a de clases con tabla por subclase"
+msgstr "Mezcla de tabla por jerarquía de clases con tabla por subclase"
 
 #. Tag: para
-#: inheritance_mapping.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can even mix the table per hierarchy and table per subclass strategies "
 "using the following approach:"
 msgstr ""
-"Puedes incluso mezclar las estrategias de tabla po jerarqu&#x00ed;a y tabla "
-"por subclase usando este enfoque:"
+"Incluso puede mezclar las estrategias de tabla por jerarquía y tabla por "
+"subclase utilizando este enfoque: "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <join table=\"CREDIT_PAYMENT\">\n"
-"            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        ...\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <join table=\"CREDIT_PAYMENT\">\n"
-"            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        ...\n"
-"    </subclass>\n"
-"</class>]]>"
-
 #. Tag: para
-#: inheritance_mapping.xml:169
 #, no-c-format
 msgid ""
 "For any of these mapping strategies, a polymorphic association to the root "
 "<literal>Payment</literal> class is mapped using <literal>&lt;many-to-one&gt;"
 "</literal>."
 msgstr ""
-"Para cualquiera de estas estrategias de mapeo, una asociaci&#x00f3;n "
-"polim&#x00f3;rfica a la clase ra&#x00ed;z <literal>Payment</literal> es "
-"mapeada usando <literal>&lt;many-to-one&gt;</literal>."
+"Para cualquiera de estas estrategias de mapeo, una asociación polimórfica a "
+"la clase raíz <literal>Payment</literal> es mapeada usando <literal>&lt;many-"
+"to-one&gt;</literal>."
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:175
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"payment\" column=\"PAYMENT_ID\" class=\"Payment"
-"\"/>]]>"
-msgstr ""
-"<![CDATA[<many-to-one name=\"payment\" column=\"PAYMENT_ID\" class=\"Payment"
-"\"/>]]>"
-
 #. Tag: title
-#: inheritance_mapping.xml:180
 #, no-c-format
 msgid "Table per concrete class"
 msgstr "Tabla por clase concreta"
 
 #. Tag: para
-#: inheritance_mapping.xml:182
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are two ways we can map the table per concrete class strategy. First, "
 "you can use <literal>&lt;union-subclass&gt;</literal>."
 msgstr ""
-"Podr&#x00ed;amos ir de dos maneras a la estrategia de mapeo de tabla por "
-"clase concreta. La primera es usar <literal>&lt;union-subclass&gt;</literal>."
+"Hay dos maneras de mapear la tabla por estrategia de clase concreta. La "
+"primera es utilizar <literal>&lt;union-subclass&gt;</literal>."
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:187
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"sequence\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <union-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </union-subclass>\n"
-"    <union-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        ...\n"
-"    </union-subclass>\n"
-"    <union-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        ...\n"
-"    </union-subclass>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Payment\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"sequence\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <union-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </union-subclass>\n"
-"    <union-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        ...\n"
-"    </union-subclass>\n"
-"    <union-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        ...\n"
-"    </union-subclass>\n"
-"</class>]]>"
-
 #. Tag: para
-#: inheritance_mapping.xml:189
 #, no-c-format
 msgid ""
 "Three tables are involved for the subclasses. Each table defines columns for "
 "all properties of the class, including inherited properties."
 msgstr ""
-"Est&#x00e1;n implicadas tres tablas. Cada tabla define columnas para todas "
-"las propiedades de la clase, inccluyendo las propiedades heredadas."
+"Hay tres tablas involucradas. Cada tabla define columnas para todas las "
+"propiedades de la clase, incluyendo las propiedades heredadas."
 
 #. Tag: para
-#: inheritance_mapping.xml:194
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The limitation of this approach is that if a property is mapped on the "
 "superclass, the column name must be the same on all subclass tables. The "
@@ -541,94 +264,36 @@
 "The primary key seed has to be shared across all unioned subclasses of a "
 "hierarchy."
 msgstr ""
-"La limitaci&#x00f3;n de este enfoque es que si una propiedad es mapeada en "
-"la superclase, el nombre de columna debe ser el mismo en todas las tablas de "
-"subclase. (Podr&#x00ed;amos relajar esto en un lanzamiento futuro de "
-"Hibernate.) La estrategia de generador de indentidad no est&#x00e1; "
-"permitida en la herencia de uni&#x00f3;n de subclase, de hecho la semilla de "
-"clave primaria tiene que ser compartida a trav&#x00e9;s de todas las "
-"subclases unidas de una jerarqu&#x00ed;a."
+"La limitación de este enfoque es que si una propiedad se mapea en la "
+"superclase, el nombre de la columna debe ser el mismo en todas las tablas de "
+"subclase. La estrategia del generador de identidad no está permitida en la "
+"herencia de unión de subclase. La semilla de la clave principal tiene que "
+"compartirse a través de todas las subclases unidas de una jerarquía."
 
 #. Tag: para
-#: inheritance_mapping.xml:203
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your superclass is abstract, map it with <literal>abstract=\"true\"</"
 "literal>. If it is not abstract, an additional table (it defaults to "
 "<literal>PAYMENT</literal> in the example above), is needed to hold "
 "instances of the superclass."
 msgstr ""
-"UNTRANSLATED! If your superclass is abstract, map it with <literal>abstract="
-"\"true\"</literal>. Of course, if it is not abstract, an additional table "
-"(defaults to <literal>PAYMENT</literal> in the example above) is needed to "
-"hold instances of the superclass."
+"Si su superclase es abstracta, mapeéla con <literal>abstract=\"true\"</"
+"literal>. Si no es abstracta, se necesita una tabla adicional (en el ejemplo "
+"anterior, por defecto es <literal>PAYMENT</literal>) para mantener las "
+"instancias de la superclase."
 
 #. Tag: title
-#: inheritance_mapping.xml:213
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Table per concrete class using implicit polymorphism"
-msgstr "Tabla por clase concreta, usando polimorfismo impl&#x00ed;cito"
+msgstr "Tabla por clase concreta utilizando polimorfismo implícito"
 
 #. Tag: para
-#: inheritance_mapping.xml:215
 #, no-c-format
 msgid "An alternative approach is to make use of implicit polymorphism:"
-msgstr "Un enfoque alternativo es hacer uso de polimorfismo impl&#x00ed;cito:"
+msgstr "Un enfoque alternativo es para hacer uso del polimorfismo implícito:"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:219
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-"    ...\n"
-"</class>\n"
-"\n"
-"<class name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CASH_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-"    ...\n"
-"</class>\n"
-"\n"
-"<class name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CHEQUE_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-"    ...\n"
-"</class>\n"
-"\n"
-"<class name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CASH_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-"    ...\n"
-"</class>\n"
-"\n"
-"<class name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CHEQUE_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-"    ...\n"
-"</class>]]>"
-
 #. Tag: para
-#: inheritance_mapping.xml:221
 #, fuzzy, no-c-format
 msgid ""
 "Notice that the <literal>Payment</literal> interface is not mentioned "
@@ -636,66 +301,42 @@
 "mapped in each of the subclasses. If you want to avoid duplication, consider "
 "using XML entities (for example, <literal>[ &lt;!ENTITY allproperties SYSTEM "
 "\"allproperties.xml\"&gt; ]</literal> in the <literal>DOCTYPE</literal> "
-"declaration and <literal>&amp;allproperties;</literal> in the mapping)."
+"declaration and <literal>&amp;allproperties&semi;</literal> in the mapping)."
 msgstr ""
-"Nota que en ning&#x00fa;n sitio mencionamos la interface <literal>Payment</"
-"literal> expl&#x00ed;citamente. Nota adem&#x00e1;s que las propiedades de "
-"<literal>Payment</literal> son mapeadas en cada una de las subclases. Si "
-"quieres evitar duplicaci&#x00f3;n, considera usar entidades XML. (por "
-"ejemplo, <literal>[ &lt;!ENTITY allproperties SYSTEM \"allproperties.xml"
-"\"&gt; ]</literal> en la declaraci&#x00f3;n <literal>DOCTYPE</literal> y "
-"<literal>&amp;allproperties;</literal> en el mapeo)."
+"Observe que la interfaz <literal>Payment</literal> no se menciona "
+"explícitamente. También note que las propiedades de <literal>Payment</"
+"literal> se mapean en cada una de las subclases. Si quiere evitar la "
+"duplicación, considere el usar entidades XML (por ejemplo, <literal>[ &lt;!"
+"ENTITY allproperties SYSTEM \"allproperties.xml\"&gt; ]</literal> en la "
+"declaración <literal>DOCTYPE</literal> y <literal>&amp;allproperties&semi;</"
+"literal> en el mapeo). "
 
 #. Tag: para
-#: inheritance_mapping.xml:231
 #, no-c-format
 msgid ""
 "The disadvantage of this approach is that Hibernate does not generate SQL "
 "<literal>UNION</literal>s when performing polymorphic queries."
 msgstr ""
 "La desventaja de este enfoque es que Hibernate no genera <literal>UNION</"
-"literal>s de SQL al realizar consultas polim&#x00f3;rficas."
+"literal>es de SQL al realizar consultas polimórficas. "
 
 #. Tag: para
-#: inheritance_mapping.xml:236
 #, no-c-format
 msgid ""
 "For this mapping strategy, a polymorphic association to <literal>Payment</"
 "literal> is usually mapped using <literal>&lt;any&gt;</literal>."
 msgstr ""
-"Para esta estrategia de mapeo, una asociaci&#x00f3;n polim&#x00f3;rfica a "
-"<literal>Payment</literal> es mapeada generalmente usando <literal>&lt;"
+"Para esta estrategia de mapeo, una asociación polimórfica a "
+"<literal>Payment</literal> es mapeada generalmente utilizando <literal>&lt;"
 "any&gt;</literal>."
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:241
-#, no-c-format
-msgid ""
-"<![CDATA[<any name=\"payment\" meta-type=\"string\" id-type=\"long\">\n"
-"    <meta-value value=\"CREDIT\" class=\"CreditCardPayment\"/>\n"
-"    <meta-value value=\"CASH\" class=\"CashPayment\"/>\n"
-"    <meta-value value=\"CHEQUE\" class=\"ChequePayment\"/>\n"
-"    <column name=\"PAYMENT_CLASS\"/>\n"
-"    <column name=\"PAYMENT_ID\"/>\n"
-"</any>]]>"
-msgstr ""
-"<![CDATA[<any name=\"payment\" meta-type=\"string\" id-type=\"long\">\n"
-"    <meta-value value=\"CREDIT\" class=\"CreditCardPayment\"/>\n"
-"    <meta-value value=\"CASH\" class=\"CashPayment\"/>\n"
-"    <meta-value value=\"CHEQUE\" class=\"ChequePayment\"/>\n"
-"    <column name=\"PAYMENT_CLASS\"/>\n"
-"    <column name=\"PAYMENT_ID\"/>\n"
-"</any>]]>"
-
 #. Tag: title
-#: inheritance_mapping.xml:246
 #, no-c-format
 msgid "Mixing implicit polymorphism with other inheritance mappings"
-msgstr "Mezclando polimorfismo impl&#x00ed;cito con otros mapeos de herencia"
+msgstr "Mezcla de polimorfismo implícito con otros mapeos de herencia"
 
 #. Tag: para
-#: inheritance_mapping.xml:248
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Since the subclasses are each mapped in their own <literal>&lt;class&gt;</"
 "literal> element, and since <literal>Payment</literal> is just an "
@@ -703,77 +344,15 @@
 "inheritance hierarchy. You can still use polymorphic queries against the "
 "<literal>Payment</literal> interface."
 msgstr ""
-"Hay una cosa m&#x00e1;s por notar acerca de este mapeo. Ya que las subclases "
-"se mapean cada una en su propio elemento <literal>&lt;class&gt;</literal> (y "
-"ya que <literal>Payment</literal> es s&#x00f3;lo una interface), cada una de "
-"las subclases podr&#x00ed;a ser parte de otra jerarqu&#x00ed;a de herencia! "
-"(Y todav&#x00ed;a puedes seguir usando consultas polim&#x00f3;rficas contra "
-"la interface <literal>Payment</literal>.)"
+"Ya que las subclases se mapean cada una en su propio elemento <literal>&lt;"
+"class&gt;</literal> y debido a que <literal>Payment</literal> es sólo una "
+"interfaz, cada una de las subclases podría ser fácilmente parte de otra "
+"jerarquía de herencia. Todavía puede seguir usando consultas polimórficas "
+"contra la interfaz <literal>Payment</literal>."
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:256
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"CREDIT_CARD\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"MasterCardPayment\" discriminator-value=\"MDC\"/>\n"
-"    <subclass name=\"VisaPayment\" discriminator-value=\"VISA\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"NonelectronicTransaction\" table=\"NONELECTRONIC_TXN\">\n"
-"    <id name=\"id\" type=\"long\" column=\"TXN_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    ...\n"
-"    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"CREDIT_CARD\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"MasterCardPayment\" discriminator-value=\"MDC\"/>\n"
-"    <subclass name=\"VisaPayment\" discriminator-value=\"VISA\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"NonelectronicTransaction\" table=\"NONELECTRONIC_TXN\">\n"
-"    <id name=\"id\" type=\"long\" column=\"TXN_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    ...\n"
-"    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"</class>]]>"
-
-#. Tag: para
-#: inheritance_mapping.xml:258
-#, fuzzy, no-c-format
-msgid ""
 "Once again, <literal>Payment</literal> is not mentioned explicitly. If we "
 "execute a query against the <literal>Payment</literal> interface, for "
 "example <literal>from Payment</literal>, Hibernate automatically returns "
@@ -782,221 +361,215 @@
 "literal> and <literal>ChequePayment</literal>, but not instances of "
 "<literal>NonelectronicTransaction</literal>."
 msgstr ""
-"Una vez m&#x00e1;s, no mencionamos a <literal>Payment</literal> expl&#x00ed;"
-"citamente. Si ejecutamos una consulta contra la interface <literal>Payment</"
-"literal> - por ejemplo, <literal>from Payment</literal> - Hibernate devuelve "
-"autom&#x00e1;ticamente instancias de <literal>CreditCardPayment</literal> (y "
-"sus subclases, ya que ellas tambi&#x00e9;n implementan <literal>Payment</"
-"literal>), <literal>CashPayment</literal> y <literal>ChequePayment</literal> "
-"pero no instancias de <literal>NonelectronicTransaction</literal>."
+"Una vez más, no mencionamos a <literal>Payment</literal> explícitamente. Si "
+"ejecutamos una consulta frente a la interfaz <literal>Payment</literal> - "
+"por ejemplo, <literal>from Payment</literal>, Hibernate retorna "
+"automáticamente instancias de <literal>CreditCardPayment</literal> (y sus "
+"subclases, ya que ellas también implementan <literal>Payment</literal>), "
+"<literal>CashPayment</literal> y <literal>ChequePayment</literal> pero no "
+"las instancias de <literal>NonelectronicTransaction</literal>."
 
 #. Tag: title
-#: inheritance_mapping.xml:273
 #, no-c-format
 msgid "Limitations"
 msgstr "Limitaciones"
 
 #. Tag: para
-#: inheritance_mapping.xml:275
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are limitations to the \"implicit polymorphism\" approach to the table "
 "per concrete-class mapping strategy. There are somewhat less restrictive "
 "limitations to <literal>&lt;union-subclass&gt;</literal> mappings."
 msgstr ""
-"Existen ciertas limitaciones al enfoque de \"polimorfismo impl&#x00ed;cito\" "
-"en la estrategia de mapeo de tabla por clase concreta. Existen limitaciones "
-"algo menos restrictivas a los mapeos <literal>&lt;union-subclass&gt;</"
-"literal>."
+"Existen ciertas limitaciones al enfoque de \"polimorfismo implícito\" en la "
+"estrategia de mapeo de tabla por clase concreta. Existen limitaciones un "
+"poco menos restrictivas a los mapeos <literal>&lt;union-subclass&gt;</"
+"literal>. "
 
 #. Tag: para
-#: inheritance_mapping.xml:282
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The following table shows the limitations of table per concrete-class "
 "mappings, and of implicit polymorphism, in Hibernate."
 msgstr ""
-"La siguiente tabla muestra las limitaciones de mapeos de tabla por clase "
-"concreta, y de polmorfismo impl&#x00ed;cito, en Hibernate."
+"La siguiente tabla muestra las limitaciones de los mapeos de tabla por clase "
+"concreta y del polimorfismo implícito en Hibernate."
 
 #. Tag: title
-#: inheritance_mapping.xml:288
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Features of inheritance mappings"
-msgstr "Funcionalidades de mapeo de herencia"
+msgstr "Mapeo de herencia"
 
 #. Tag: entry
-#: inheritance_mapping.xml:301
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Inheritance strategy"
-msgstr "Estrategia de herencia"
+msgstr "Mapeo de herencia"
 
 #. Tag: entry
-#: inheritance_mapping.xml:302
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Polymorphic many-to-one"
-msgstr "muchos-a-uno polim&#x00f3;rfica"
+msgstr "Polimórfico muchos-a-uno: <code>&lt;any&gt;</code>"
 
 #. Tag: entry
-#: inheritance_mapping.xml:303
 #, no-c-format
 msgid "Polymorphic one-to-one"
-msgstr "uno-a-uno polim&#x00f3;rfica"
+msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:304
 #, no-c-format
 msgid "Polymorphic one-to-many"
-msgstr "uno-a-muchos polim&#x00f3;rfica"
+msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:305
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Polymorphic many-to-many"
-msgstr "mushos-a-muchos polim&#x00f3;rfica"
+msgstr "Polimórfico muchos-a-uno: <code>&lt;any&gt;</code>"
 
 #. Tag: entry
-#: inheritance_mapping.xml:306
 #, no-c-format
 msgid "Polymorphic <literal>load()/get()</literal>"
-msgstr "<literal>load()/get()</literal> polim&#x00f3;rficos"
+msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:307
 #, no-c-format
 msgid "Polymorphic queries"
-msgstr "Consultas polim&#x00f3;rficas"
+msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:308
 #, no-c-format
 msgid "Polymorphic joins"
-msgstr "Uniones polim&#x00f3;rficas"
+msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:309
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Outer join fetching"
-msgstr "Recuperaci&#x00f3;n por uni&#x00f3;n externa (outer join)"
+msgstr "Se soporta la recuperación por unión externa."
 
 #. Tag: entry
-#: inheritance_mapping.xml:314
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "table per class-hierarchy"
-msgstr "tabla por jerarqu&#x00ed;a de clases"
+msgstr "tabla por jerarquía de clases"
 
-#. Tag: literal
-#: inheritance_mapping.xml:315 inheritance_mapping.xml:326
-#: inheritance_mapping.xml:337
+#. Tag: entry
 #, no-c-format
-msgid "&lt;many-to-one&gt;"
-msgstr "&lt;many-to-one&gt;"
+msgid "<literal>&lt;many-to-one&gt;</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:316 inheritance_mapping.xml:327
-#: inheritance_mapping.xml:338
+#. Tag: entry
 #, no-c-format
-msgid "&lt;one-to-one&gt;"
-msgstr "&lt;one-to-one&gt;"
+msgid "<literal>&lt;one-to-one&gt;</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:317 inheritance_mapping.xml:328
+#. Tag: entry
 #, no-c-format
-msgid "&lt;one-to-many&gt;"
-msgstr "&lt;one-to-many&gt;"
+msgid "<literal>&lt;one-to-many&gt;</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:318 inheritance_mapping.xml:329
-#: inheritance_mapping.xml:340
+#. Tag: entry
 #, no-c-format
-msgid "&lt;many-to-many&gt;"
-msgstr "&lt;many-to-many&gt;"
+msgid "<literal>&lt;many-to-many&gt;</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:319 inheritance_mapping.xml:330
-#: inheritance_mapping.xml:341
+#. Tag: entry
 #, no-c-format
-msgid "s.get(Payment.class, id)"
-msgstr "s.get(Payment.class, id)"
+msgid "<literal>s.get(Payment.class, id)</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:320 inheritance_mapping.xml:331
-#: inheritance_mapping.xml:342 inheritance_mapping.xml:353
+#. Tag: entry
 #, no-c-format
-msgid "from Payment p"
-msgstr "from Payment p"
+msgid "<literal>from Payment p</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:321 inheritance_mapping.xml:332
-#: inheritance_mapping.xml:343
-#, no-c-format
-msgid "from Order o join o.payment p"
-msgstr "from Order o join o.payment p"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>from Order o join o.payment p</literal>"
+msgstr "Uniones polimórficas: <code>from Order o join o.payment p</code>"
 
-#. Tag: emphasis
-#: inheritance_mapping.xml:322 inheritance_mapping.xml:333
-#: inheritance_mapping.xml:344
-#, no-c-format
-msgid "supported"
-msgstr "soportada"
-
 #. Tag: entry
-#: inheritance_mapping.xml:325
 #, no-c-format
-msgid "<entry>table per subclass</entry>"
-msgstr "<entry>tabla por subclase</entry>"
+msgid "<emphasis>supported</emphasis>"
+msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:336
 #, no-c-format
 msgid "table per concrete-class (union-subclass)"
 msgstr "tabla por clase concreta (union-subclass)"
 
 #. Tag: entry
-#: inheritance_mapping.xml:339
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "<literal>&lt;one-to-many&gt;</literal> (for <literal>inverse=\"true\"</"
 "literal> only)"
 msgstr ""
-"<literal>&lt;one-to-many&gt;</literal> (para <literal>inverse=\"true\"</"
-"literal> solamente)"
+"Polimórfico uno-a-muchos: <code>&lt;one-to-many&gt;</code> (solo para "
+"<code>inverse=\"true\"</code>)"
 
 #. Tag: entry
-#: inheritance_mapping.xml:347
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "table per concrete class (implicit polymorphism)"
-msgstr "tabla por clase concreta (polimorfismo impl&#x00ed;cito)"
+msgstr "tabla por clase concreta (polimorfismo implícito) "
 
-#. Tag: literal
-#: inheritance_mapping.xml:348
+#. Tag: entry
 #, no-c-format
-msgid "&lt;any&gt;"
-msgstr "&lt;any&gt;"
+msgid "<literal>&lt;any&gt;</literal>"
+msgstr ""
 
-#. Tag: emphasis
-#: inheritance_mapping.xml:349 inheritance_mapping.xml:350
-#: inheritance_mapping.xml:354 inheritance_mapping.xml:355
+#. Tag: entry
 #, no-c-format
-msgid "not supported"
-msgstr "no soportada"
+msgid "<emphasis>not supported</emphasis>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:351
+#. Tag: entry
 #, no-c-format
-msgid "&lt;many-to-any&gt;"
-msgstr "&lt;many-to-any&gt;"
+msgid "<literal>&lt;many-to-any&gt;</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:352
-#, no-c-format
+#. Tag: entry
+#, fuzzy, no-c-format
 msgid ""
-"s.createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()"
+"<literal>s.createCriteria(Payment.class).add( Restrictions.idEq(id) )."
+"uniqueResult()</literal>"
 msgstr ""
-"s.createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()"
+"Polimórfico <literal>load()</literal> o <literal>get()</literal>: <code>s."
+"createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()</"
+"code>"
 
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
+#~ msgid "table per class-heirarchy"
+#~ msgstr "tabla por jerarquía de clases "
 
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+#~ msgid "Polymorphic many-to-one: <code>&lt;many-to-one&gt;</code>"
+#~ msgstr "Polimórfico muchos-a-uno: <code>&lt;many-to-one&gt;</code>"
+
+#~ msgid "Polymorphic one-to-one: <code>&lt;one-to-one&gt;</code>"
+#~ msgstr "Polimórfico uno-a-uno: <code>&lt;one-to-one&gt;</code>"
+
+#~ msgid "Polymorphic one-to-many: <code>&lt;one-to-many&gt;</code>"
+#~ msgstr "Polimórfico uno-a-muchos: <code>&lt;one-to-many&gt;</code>"
+
+#~ msgid "Polymorphic many-to-many: <code>&lt;many-to-many&gt;</code>"
+#~ msgstr "Polimórfico muchos-a-muchos: <code>&lt;many-to-many&gt;</code>"
+
+#~ msgid ""
+#~ "Polymorphic <literal>load()</literal> or <literal>get()</literal>: "
+#~ "<code>s.get(Payment.class, id)</code>"
+#~ msgstr ""
+#~ "Polimórfico <literal>load()</literal> o <literal>get()</literal>: <code>s."
+#~ "get(Payment.class, id)</code>"
+
+#~ msgid "Polymorphic queries: <code>from Payment p</code>"
+#~ msgstr "Consultas polimórficas: <code>from Payment p</code>"
+
+#~ msgid ""
+#~ "Polymorphic one-to-one, polymorphic one-to-many, polymorphic joins, and "
+#~ "outer join fetching are not supported."
+#~ msgstr ""
+#~ "No se soporta polimórfico uno-a-uno, polimórfico uno-a-muchos, uniones "
+#~ "polimórficas y búsquedas de unión externa."
+
+#, fuzzy
+#~ msgid "<para>table per subclass</para>"
+#~ msgstr "tabla por subclase"
+
+#, fuzzy
+#~ msgid "<term>table per subclass</term>"
+#~ msgstr "tabla por subclase"

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/performance.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/performance.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/performance.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,77 +1,84 @@
-#, fuzzy
+# translation of performance.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: performance\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-04 15:23+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: performance.xml:29
 #, no-c-format
 msgid "Improving performance"
-msgstr "Mejorando el rendimiento"
+msgstr "Mejoramiento del rendimiento"
 
 #. Tag: title
-#: performance.xml:32
 #, no-c-format
 msgid "Fetching strategies"
-msgstr "Estrategias de recuperaci&#x00f3;n"
+msgstr "Estrategias de recuperación"
 
 #. Tag: para
-#: performance.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate uses a <emphasis>fetching strategy</emphasis> to retrieve "
 "associated objects if the application needs to navigate the association. "
 "Fetch strategies can be declared in the O/R mapping metadata, or over-ridden "
 "by a particular HQL or <literal>Criteria</literal> query."
 msgstr ""
-"Una <emphasis>estrategia de recuperaci&#x00f3;n</emphasis> es la estrategia "
-"que usar&#x00e1; Hibernate para recuperar los objetos asociados cuando la "
-"aplicaci&#x00f3;n necesite navegar la asociaci&#x00f3;n. Las estrategias de "
-"recuperaci&#x00f3;n pueden ser declaradas en los metadatos de mapeo O/R, o "
-"sobrescritas por una consulta HQL o <literal>Criteria</literal> en "
-"particular."
+"Hibernate utiliza una <emphasis>estrategia de recuperación</emphasis> para "
+"recuperar los objetos asociados cuando la aplicación necesita navegar la "
+"asociación. Las estrategias de recuperación se pueden declarar en los "
+"metadatos de mapeo O/R, o se pueden sobrescribir por medio de una HQL "
+"particular o una petición <literal>Criteria</literal>."
 
 #. Tag: para
-#: performance.xml:41
 #, no-c-format
 msgid "Hibernate3 defines the following fetching strategies:"
-msgstr "Hibernate3 define las siguientes estrategias de recuperaci&#x00f3;n:"
+msgstr "Hibernate3 define las siguientes estrategias de recuperación:"
 
 #. Tag: para
-#: performance.xml:47
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Join fetching</emphasis>: Hibernate retrieves the associated "
 "instance or collection in the same <literal>SELECT</literal>, using an "
 "<literal>OUTER JOIN</literal>."
 msgstr ""
-"<emphasis>Recuperaci&#x00f3;n por uni&#x00f3;n (join fetching)</emphasis> - "
-"Hibernate recupera la instancia asociada o colecci&#x00f3;n en la misma "
-"<literal>SELECT</literal>, usando una <literal>OUTER JOIN</literal>."
+"<emphasis>Recuperación por unión (join fetching)</emphasis>: Hibernate "
+"recupera la instancia asociada o la colección en el mismo <literal>SELECT</"
+"literal>, utilizando un <literal>OUTER JOIN</literal>."
 
 #. Tag: para
-#: performance.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Select fetching</emphasis>: a second <literal>SELECT</literal> is "
 "used to retrieve the associated entity or collection. Unless you explicitly "
 "disable lazy fetching by specifying <literal>lazy=\"false\"</literal>, this "
 "second select will only be executed when you access the association."
 msgstr ""
-"<emphasis>Recuperaci&#x00f3;n por selecci&#x00f3;n (select fetching)</"
-"emphasis> - se usa una segunda <literal>SELECT</literal> para recuperar la "
-"entidad asociada o colecci&#x00f3;n. A menos que deshabilites expl&#x00ed;"
-"citamente la recuperaci&#x00f3;n perezosa especificando <literal>lazy=\"false"
-"\"</literal>, la segunda selecci&#x00f3;n s&#x00f3;lo ser&#x00e1; ejecutada "
-"cuando realmente accedas a la asociaci&#x00f3;n."
+"<emphasis>Recuperación por selección (select fetching)</emphasis>: se "
+"utiliza un segundo <literal>SELECT</literal> para recuperar la entidad o "
+"colección asocidas. A menos que deshabilite explícitamente la recuperación "
+"perezosa especificando <literal>lazy=\"false\"</literal>, la segunda "
+"selección sólo será ejecutada cuando acceda a la asociación."
 
 #. Tag: para
-#: performance.xml:63
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Subselect fetching</emphasis>: a second <literal>SELECT</literal> "
 "is used to retrieve the associated collections for all entities retrieved in "
@@ -79,88 +86,78 @@
 "specifying <literal>lazy=\"false\"</literal>, this second select will only "
 "be executed when you access the association."
 msgstr ""
-"<emphasis>Recuperaci&#x00f3;n por subselecci&#x00f3;n (subselect fetching)</"
-"emphasis> - se usa una segunda <literal>SELECT</literal> para recuperar las "
-"colecciones asociadas de todas las entidades recuperadas en una consulta o "
-"recuperaci&#x00f3;n previa. A menos que deshabilites expl&#x00ed;citamente "
-"la recuperaci&#x00f3;n perezosa especificando <literal>lazy=\"false\"</"
-"literal>, esta segunda selecci&#x00f3;n s&#x00f3;lo ser&#x00e1; ejecutada "
-"cuando realmente accedas a la asociaci&#x00f3;n."
+"<emphasis>Recuperación por subselección (subselect fetching)</emphasis>: se "
+"utiliza un segundo <literal>SELECT</literal> para recuperar las colecciones "
+"asociadas de todas las entidades recuperadas en una consulta o recuperación "
+"previa. A menos de que deshabilite explícitamente la recuperación perezosa "
+"especificando <literal>lazy=\"false\"</literal>, esta segunda selección sólo "
+"se ejecutará cuando acceda a la asociación."
 
 #. Tag: para
-#: performance.xml:72
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Batch fetching</emphasis>: an optimization strategy for select "
 "fetching. Hibernate retrieves a batch of entity instances or collections in "
 "a single <literal>SELECT</literal> by specifying a list of primary or "
 "foreign keys."
 msgstr ""
-"<emphasis>Recuperaci&#x00f3;n en lote</emphasis> - una estrategia de "
-"optimizaci&#x00f3;n para la recuperaci&#x00f3;n por selecci&#x00f3;n - "
-"Hibernate recupera un lote de instancias de entidad o colecciones en una "
-"sola <literal>SELECT</literal>, especificando una lista de claves primarias "
-"o de claves for&#x00e1;neas."
+"<emphasis>Recuperación en lote</emphasis>: una estrategia de optimización "
+"para la recuperación por selección. Hibernate recupera un lote de instancias "
+"de entidad o colecciones en un solo <literal>SELECT</literal>, especificando "
+"una lista de claves principales o de claves foráneas."
 
 #. Tag: para
-#: performance.xml:81
 #, no-c-format
 msgid "Hibernate also distinguishes between:"
-msgstr "Hibernate tambi&#x00e9;n distingue entre:"
+msgstr "Hibernate también distingue entre:"
 
 #. Tag: para
-#: performance.xml:87
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Immediate fetching</emphasis>: an association, collection or "
 "attribute is fetched immediately when the owner is loaded."
 msgstr ""
-"<emphasis>Recuperaci&#x00f3;n inmediata</emphasis> - una asociaci&#x00f3;n, "
-"colecci&#x00f3;n o atributo es recuperado inmediatamente, cuando el "
-"due&#x00f1;o es cargado."
+"<emphasis>Recuperación inmediata</emphasis>: una asociación, colección o "
+"atributo se recupera inmediatamente cuando se carga el dueño."
 
 #. Tag: para
-#: performance.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Lazy collection fetching</emphasis>: a collection is fetched when "
 "the application invokes an operation upon that collection. This is the "
 "default for collections."
 msgstr ""
-"<emphasis>Recuperaci&#x00f3;n perezosa de colecciones</emphasis> - se "
-"recupera una colecci&#x00f3;n cuando la aplicaci&#x00f3;n invoca una "
-"operaci&#x00f3;n sobre la colecci&#x00f3;n. (Esto es por defecto para las "
-"colecciones.)"
+"<emphasis>Recuperación perezosa de colecciones</emphasis>: una colección se "
+"recupera cuando la aplicación invoca una operación sobre esa colección. Este "
+"es el valor predeterminado para las colecciones."
 
 #. Tag: para
-#: performance.xml:100
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>\"Extra-lazy\" collection fetching</emphasis>: individual elements "
 "of the collection are accessed from the database as needed. Hibernate tries "
 "not to fetch the whole collection into memory unless absolutely needed. It "
 "is suitable for large collections."
 msgstr ""
-"<emphasis>\"Extra-lazy\" collection fetching</emphasis> - individual "
-"elements of the collection are accessed from the database as needed. "
-"Hibernate tries not to fetch the whole collection into memory unless "
-"absolutely needed (suitable for very large collections)"
+"<emphasis>Recuperación de colección \"extra-perezoza\" </emphasis>: se "
+"accede a elementos individuales desde la base de datos cuando se necesita. "
+"Hibernate intenta no recuperar toda la colección en la memoria a menos de "
+"que sea absolutamente necesario. Esto es apropiado para colecciones muy "
+"grandes."
 
 #. Tag: para
-#: performance.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Proxy fetching</emphasis>: a single-valued association is fetched "
 "when a method other than the identifier getter is invoked upon the "
 "associated object."
 msgstr ""
-"<emphasis>Proxy fetching</emphasis> - a single-valued association is fetched "
-"when a method other than the identifier getter is invoked upon the "
-"associated object."
+"<emphasis>Recuperación por proxy</emphasis>: una asociación monovaluada se "
+"recupera cuando se invoca un método que no sea el getter del identificador "
+"sobre el objeto asociado."
 
 #. Tag: para
-#: performance.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>\"No-proxy\" fetching</emphasis>: a single-valued association is "
 "fetched when the instance variable is accessed. Compared to proxy fetching, "
@@ -169,26 +166,28 @@
 "visible to the application. This approach requires buildtime bytecode "
 "instrumentation and is rarely necessary."
 msgstr ""
-"<emphasis>Recuperaci&#x00f3;n por proxy</emphasis> - se recupera una "
-"asociaci&#x00f3;n monovaluada cuando se invoca un m&#x00e9;todo que no sea "
-"el getter del identificador sobre el objeto asociado."
+"<emphasis> Recuperación \"no-proxy\" </emphasis>: una asociación monovaluada "
+"se recupera cuando se accede a la variable de la instancia. Comparado con la "
+"recuperación por proxy, este enfoque es menos perezozo; la asociación se "
+"recupera cuando se accede sólamente al identificador. También es más "
+"transparente ya que para la aplicación no hay proxies visibles. Este enfoque "
+"requiere instrumentación del código byte del tiempo estimado de construcción "
+"y se necesita muy raramente."
 
 #. Tag: para
-#: performance.xml:125
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Lazy attribute fetching</emphasis>: an attribute or single valued "
 "association is fetched when the instance variable is accessed. This approach "
 "requires buildtime bytecode instrumentation and is rarely necessary."
 msgstr ""
-"<emphasis>Recuperaci&#x00f3;n perezosa de atributos</emphasis> - se recupera "
-"un atributo o una asociaci&#x00f3;n monovaluada cuando se accede a la "
-"variable de instancia (requiere instrumentaci&#x00f3;n del bytecode en "
-"tiempo de ejecuci&#x00f3;n). Este enfoque es raramente necesario."
+"<emphasis>Recuperación perezosa de atributos</emphasis>: un atributo o una "
+"asociación monovaluada se recuperan cuando se accede a la variable de la "
+"instancia. Este enfoque requiere instrumentación del código byte en tiempo "
+"estimado de construcción y se necesita muy raramente."
 
 #. Tag: para
-#: performance.xml:134
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We have two orthogonal notions here: <emphasis>when</emphasis> is the "
 "association fetched and <emphasis>how</emphasis> is it fetched. It is "
@@ -197,108 +196,68 @@
 "for what data is always available in any detached instance of a particular "
 "class."
 msgstr ""
-"Aqu&#x00ed; tenemos dos nociones ortogonales: <emphasis>cu&#x00e1;ndo</"
-"emphasis> se recupera la aplicaci&#x00f3;n, y <emphasis>c&#x00f3;mo</"
-"emphasis> es recuperada (qu&#x00e9; SQL es usado). &#x00a1;No las confundas! "
-"Usamos <literal>fetch</literal> para afinar el rendimiento. Podemos usar "
-"<literal>lazy</literal> para definir un contrato sobre qu&#x00e9; datos "
-"est&#x00e1;n siempre disponibles en cualquier instancia separada de una "
-"clase en particular."
+"Aquí tenemos dos nociones ortogonales: <emphasis>cuándo</emphasis> se "
+"recupera la aplicación, y <emphasis>cómo</emphasis> se recupera. Es "
+"importante que no las confunda. Utilizamos <literal>fetch</literal> para "
+"afinar el rendimiento. Podemos usar <literal>lazy</literal> para definir un "
+"contrato sobre qué datos están siempre disponibles en cualquier instancia "
+"separada de una clase en particular."
 
 #. Tag: title
-#: performance.xml:143
 #, no-c-format
 msgid "Working with lazy associations"
-msgstr "Trabajando con asociaciones perezosas"
+msgstr "Trabajo con asociaciones perezosas"
 
 #. Tag: para
-#: performance.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "By default, Hibernate3 uses lazy select fetching for collections and lazy "
 "proxy fetching for single-valued associations. These defaults make sense for "
 "most associations in the majority of applications."
 msgstr ""
-"Por defecto, Hibernate3 usa una recuperaci&#x00f3;n perezosa por "
-"selecci&#x00f3;n para colecciones y una recuperaci&#x00f3;n por proxy "
-"perezosa para asociaciones monovaluadas. Estas pol&#x00ed;ticas por defecto "
-"tienen sentido para casi todas las asociaciones en casi todas las "
-"aplicaciones."
+"Por defecto, Hibernate3 usa una recuperación perezosa por selección para "
+"colecciones y una recuperación por proxy perezosa para asociaciones "
+"monovaluadas. Estas políticas predeterminadas tienen sentido para casi todas "
+"las asociaciones en la mayoría de las aplicaciones."
 
 #. Tag: para
-#: performance.xml:151
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you set <literal>hibernate.default_batch_fetch_size</literal>, Hibernate "
 "will use the batch fetch optimization for lazy fetching. This optimization "
 "can also be enabled at a more granular level."
 msgstr ""
-"<emphasis>Nota:</emphasis> si estableces <literal>hibernate."
-"default_batch_fetch_size</literal>, Hibernate usar&#x00e1; la "
-"optimizaci&#x00f3;n de recuperaci&#x00f3;n en lotes para recuperaci&#x00f3;n "
-"perezosa (esta optimizaci&#x00f3;n tambi&#x00e9;n puede ser habilitada a un "
-"nivel m&#x00e1;s granularizado)."
+"Si configura <literal>hibernate.default_batch_fetch_size</literal>, "
+"Hibernate utilizará la optimización de recuperación en lotes para "
+"recuperación perezosa. Esta optimización también se puede habilitar en un "
+"nivel más detallado."
 
 #. Tag: para
-#: performance.xml:158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please be aware that access to a lazy association outside of the context of "
 "an open Hibernate session will result in an exception. For example:"
 msgstr ""
-"Sin embargo, la recuperaci&#x00f3;n perezosa plantea un problema del que "
-"tienes que estar al tanto. Acceder a una asociaci&#x00f3;n perezosa fuera "
-"del contexto de una sesi&#x00f3;n de Hibernate abierta resultar&#x00e1; en "
-"una excepci&#x00f3;n. Por ejemplo:"
+"Note que el acceder a una asociación perezosa fuera del contexto de una "
+"sesión de Hibernate abierta resultará en una excepción. Por ejemplo:"
 
-#. Tag: programlisting
-#: performance.xml:164
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[s = sessions.openSession();\n"
-"Transaction tx = s.beginTransaction();\n"
-"            \n"
-"User u = (User) s.createQuery(\"from User u where u.name=:userName\")\n"
-"    .setString(\"userName\", userName).uniqueResult();\n"
-"Map permissions = u.getPermissions();\n"
-"\n"
-"tx.commit();\n"
-"s.close();\n"
-"\n"
-"Integer accessLevel = (Integer) permissions.get(\"accounts\");  // Error!]]>"
-msgstr ""
-"<![CDATA[s = sessions.openSession();\n"
-"Transaction tx = s.beginTransaction();\n"
-"            \n"
-"User u = (User) s.createQuery(\"from User u where u.name=:userName\")\n"
-"    .setString(\"userName\", userName).uniqueResult();\n"
-"Map permissions = u.getPermissions();\n"
-"\n"
-"tx.commit();\n"
-"s.close();\n"
-"\n"
-"Integer accessLevel = (Integer) permissions.get(\"accounts\");  // Error!]]>"
-
-#. Tag: para
-#: performance.xml:166
-#, fuzzy, no-c-format
-msgid ""
 "Since the permissions collection was not initialized when the "
 "<literal>Session</literal> was closed, the collection will not be able to "
 "load its state. <emphasis>Hibernate does not support lazy initialization for "
 "detached objects</emphasis>. This can be fixed by moving the code that reads "
 "from the collection to just before the transaction is committed."
 msgstr ""
-"Ya que la colecci&#x00f3;n de permisos no fue inicializada cuando se "
-"cerr&#x00f3; la <literal>Session</literal>, la colecci&#x00f3;n no "
-"ser&#x00e1; capaz de cargar su estado. <emphasis>Hibernate no soporta la "
-"inicializaci&#x00f3;n perezosa de objetos separados</emphasis>. La "
-"soluci&#x00f3;n es mover el c&#x00f3;digo que lee de la colecci&#x00f3;n a "
-"justo antes que la transacci&#x00f3;n sea comprometida."
+"Ya que la colección de permisos no fue inicializada cuando se cerró la "
+"<literal>Session</literal>, la colección no será capaz de cargar su estado. "
+"<emphasis>Hibernate no soporta la inicialización perezosa de objetos "
+"separados</emphasis>. La solución es mover el código que lee de la colección "
+"a justo antes de que se guarde la transacción."
 
 #. Tag: para
-#: performance.xml:174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, you can use a non-lazy collection or association, by "
 "specifying <literal>lazy=\"false\"</literal> for the association mapping. "
@@ -307,17 +266,15 @@
 "in your object model, Hibernate will fetch the entire database into memory "
 "in every transaction."
 msgstr ""
-"Alternativamente, podr&#x00ed;amos usar una colecci&#x00f3;n no perezosa o "
-"asociaci&#x00f3;n, especificando <literal>lazy=\"false\"</literal> para el "
-"mapeo de asociaci&#x00f3;n. Sin embargo, est&#x00e1; pensado que la "
-"inicializaci&#x00f3;n perezosa sea usada para casi todas las colecciones y "
-"asociaciones. &#x00a1;Si defines demasiadas asociaciones no perezosas en tu "
-"modelo de objetos, Hibernate terminar&#x00e1; necesitando recuperar la base "
-"de datos entera en cada transacci&#x00f3;n!"
+"Opcionalmente puede utilizar una colección no perezosa o asociación, "
+"especificando <literal>lazy=\"false\"</literal> para el mapeo de asociación. "
+"Sin embargo, el propósito de la inicialización perezosa es que se utilice "
+"para casi todas las colecciones y asociaciones. ¡Si define demasiadas "
+"asociaciones no perezosas en su modelo de objetos, Hibernate recuperará la "
+"base de datos entera en toda transacción."
 
 #. Tag: para
-#: performance.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "On the other hand, you can use join fetching, which is non-lazy by nature, "
 "instead of select fetching in a particular transaction. We will now explain "
@@ -325,108 +282,76 @@
 "choosing a fetch strategy are identical for single-valued associations and "
 "collections."
 msgstr ""
-"Por otro lado, frecuentemente necesitamos elegir la recuperaci&#x00f3;n por "
-"uni&#x00f3;n (que es no perezosa por naturaleza) en vez de la "
-"recuperaci&#x00f3;n por selecci&#x00f3;n en una transacci&#x00f3;n en "
-"particular. Veremos ahora c&#x00f3;mo personalizar la estrategia de "
-"recuperaci&#x00f3;n. En Hibernate3, los mecanismos para elegir una "
-"estrategia de recuperaci&#x00f3;n son id&#x00e9;nticas a las de las "
-"asociaciones monovaluadas y colecciones."
+"Por otro lado, puede utilizar la recuperación por unión, la cual no es "
+"perezosa por naturaleza, en lugar de la recuperación por selección en una "
+"transacción en particular. Veremos ahora cómo personalizar la estrategia de "
+"recuperación. En Hibernate3, los mecanismos para elegir una estrategia de "
+"recuperación son idénticas para las de las asociaciones monovaluadas y las "
+"colecciones."
 
 #. Tag: title
-#: performance.xml:194
 #, no-c-format
 msgid "Tuning fetch strategies"
-msgstr "Afinando las estrategias de recuperaci&#x00f3;n"
+msgstr "Afinación de las estrategias de recuperación"
 
 #. Tag: para
-#: performance.xml:196
 #, no-c-format
 msgid ""
 "Select fetching (the default) is extremely vulnerable to N+1 selects "
 "problems, so we might want to enable join fetching in the mapping document:"
 msgstr ""
-"La recuperaci&#x00f3;n por selecci&#x00f3;n (la preestablecida) es "
-"extremadamente vulnerable a problemas de selecci&#x00f3;n N+1, de modo "
-"querr&#x00ed;amos habilitar la recuperaci&#x00f3;n por uni&#x00f3;n (join "
-"fetching) en el documento de mapeo:"
+"La recuperación por selección (la preestablecida) es extremadamente "
+"vulnerable a problemas de selección N+1, de modo que puede que queramos "
+"habilitar la recuperación por unión (join fetching) en el documento de mapeo:"
 
-#. Tag: programlisting
-#: performance.xml:201
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"permissions\" \n"
-"            fetch=\"join\">\n"
-"    <key column=\"userId\"/>\n"
-"    <one-to-many class=\"Permission\"/>\n"
-"</set]]>"
-msgstr ""
-"<![CDATA[<set name=\"permissions\" \n"
-"            fetch=\"join\">\n"
-"    <key column=\"userId\"/>\n"
-"    <one-to-many class=\"Permission\"/>\n"
-"</set]]>"
-
-#. Tag: programlisting
-#: performance.xml:203
-#, no-c-format
-msgid "<![CDATA[<many-to-one name=\"mother\" class=\"Cat\" fetch=\"join\"/>]]>"
-msgstr ""
-"<![CDATA[<many-to-one name=\"mother\" class=\"Cat\" fetch=\"join\"/>]]>"
-
 #. Tag: para
-#: performance.xml:205
 #, no-c-format
 msgid ""
 "The <literal>fetch</literal> strategy defined in the mapping document "
 "affects:"
 msgstr ""
-"La estrategia de recuperaci&#x00f3;n definida en el documento de mapeo "
-"afecta a:"
+"La estrategia de <literal>recuperación</literal> definida en el documento de "
+"mapeo afecta a:"
 
 #. Tag: para
-#: performance.xml:211
 #, no-c-format
 msgid "retrieval via <literal>get()</literal> or <literal>load()</literal>"
 msgstr ""
-"las recuperaciones v&#x00ed;a <literal>get()</literal> o <literal>load()</"
+"las recuperaciones por medio de <literal>get()</literal> o <literal>load()</"
 "literal>"
 
 #. Tag: para
-#: performance.xml:216
 #, no-c-format
 msgid "retrieval that happens implicitly when an association is navigated"
 msgstr ""
-"las recuperaciones que ocurren impl&#x00ed;citamente cuando se navega una "
-"asociaci&#x00f3;n (recuperaci&#x00f3;n perezosa)"
+"las recuperaciones que ocurren implícitamente cuando se navega una "
+"asociación (recuperación perezosa)"
 
 #. Tag: para
-#: performance.xml:221
 #, no-c-format
 msgid "<literal>Criteria</literal> queries"
 msgstr "las consultas de <literal>Criteria</literal>"
 
 #. Tag: para
-#: performance.xml:226
 #, no-c-format
 msgid "HQL queries if <literal>subselect</literal> fetching is used"
-msgstr "HQL queries if <literal>subselect</literal> fetching is used"
+msgstr ""
+"las consultas HQL si se utiliza la recuperación <literal>subselect</literal>"
 
 #. Tag: para
-#: performance.xml:232
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Irrespective of the fetching strategy you use, the defined non-lazy graph is "
 "guaranteed to be loaded into memory. This might, however, result in several "
 "immediate selects being used to execute a particular HQL query."
 msgstr ""
-"No matter what fetching strategy you use, the defined non-lazy graph is "
-"guaranteed to be loaded into memory. Note that this might result in several "
-"immediate selects being used to execute a particular HQL query."
+"Sin importar que estrategia de recuperación utilice, se garantiza que la "
+"gráfica no-perezoza definida será cargada en la memoria. Sin embargo, esto "
+"puede causar la utilización de varias selecciones inmediatas para ejecutar "
+"una consulta HQL en particular."
 
 #. Tag: para
-#: performance.xml:238
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Usually, the mapping document is not used to customize fetching. Instead, we "
 "keep the default behavior, and override it for a particular transaction, "
@@ -435,70 +360,50 @@
 "the <literal>Criteria</literal> query API, you would use "
 "<literal>setFetchMode(FetchMode.JOIN)</literal>."
 msgstr ""
-"Usualmente, no usamos el documento de mapeo para personalizar la "
-"recuperaci&#x00f3;n. En cambio, mantenemos el comportamiento por defecto, y "
-"lo sobrescribimos para una transacci&#x00f3;n en particular, usando "
-"<literal>left join fetch</literal> en HQL. Esto le dice a Hibernate que "
-"recupere la asociaci&#x00f3;n tempranamente en la primera selecci&#x00f3;n, "
-"usando una uni&#x00f3;n externa. En la API de consulta de <literal>Criteria</"
-"literal>, usar&#x00ed;as <literal>setFetchMode(FetchMode.JOIN)</literal>."
+"Usualmente, no utilizamos el documento de mapeo para personalizar la "
+"recuperación. En cambio, mantenemos el comportamiento por defecto y lo "
+"sobrescribimos para una transacción en particular, utilizando <literal>left "
+"join fetch</literal> en HQL. Esto le dice a Hibernate que recupere la "
+"asociación tempranamente en la primera selección, usando una unión externa. "
+"En la API de consulta de <literal>Criteria</literal>, usted utilizaría "
+"<literal>setFetchMode(FetchMode.JOIN)</literal>."
 
 #. Tag: para
-#: performance.xml:247
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want to change the fetching strategy used by <literal>get()</literal> "
 "or <literal>load()</literal>, you can use a <literal>Criteria</literal> "
 "query. For example:"
 msgstr ""
-"Si acaso lo deseases, podr&#x00ed;as cambiar la estrategia de "
-"recuperaci&#x00f3;n usada por <literal>get()</literal> or <literal>load()</"
-"literal>; simplemente usa una consulta <literal>Criteria</literal>, por "
-"ejemplo:"
+"Si quiere cambiar la estrategia de recuperación utilizada por <literal>get()"
+"</literal> o <literal>load()</literal>; utilice una consulta "
+"<literal>Criteria</literal>. Por ejemplo:"
 
-#. Tag: programlisting
-#: performance.xml:253
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[User user = (User) session.createCriteria(User.class)\n"
-"                .setFetchMode(\"permissions\", FetchMode.JOIN)\n"
-"                .add( Restrictions.idEq(userId) )\n"
-"                .uniqueResult();]]>"
-msgstr ""
-"<![CDATA[User user = (User) session.createCriteria(User.class)\n"
-"                .setFetchMode(\"permissions\", FetchMode.JOIN)\n"
-"                .add( Restrictions.idEq(userId) )\n"
-"                .uniqueResult();]]>"
-
-#. Tag: para
-#: performance.xml:255
-#, fuzzy, no-c-format
-msgid ""
 "This is Hibernate's equivalent of what some ORM solutions call a \"fetch plan"
 "\"."
 msgstr ""
-"(Esto es el equivalente de Hibernate de lo que otras soluciones ORM llaman "
-"un \"plan de recuperaci&#x00f3;n\".)"
+"Esto es el equivalente de Hibernate de lo que otras soluciones ORM denominan "
+"un \"plan de recuperación\"."
 
 #. Tag: para
-#: performance.xml:259
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A completely different approach to problems with N+1 selects is to use the "
 "second-level cache."
 msgstr ""
-"Una forma completamente diferente de evitar problemas con selecciones N+1 es "
-"usar el cach&#x00e9; de segundo nivel."
+"Un enfoque completamente diferente de evitar problemas con selecciones N+1 "
+"es usar el caché de segundo nivel."
 
 #. Tag: title
-#: performance.xml:267
 #, no-c-format
 msgid "Single-ended association proxies"
-msgstr "Proxies de asociaciones de un solo extremo"
+msgstr "Proxies de asociaciones de un sólo extremo"
 
 #. Tag: para
-#: performance.xml:269
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Lazy fetching for collections is implemented using Hibernate's own "
 "implementation of persistent collections. However, a different mechanism is "
@@ -507,31 +412,27 @@
 "proxies for persistent objects using runtime bytecode enhancement which is "
 "accessed via the CGLIB library."
 msgstr ""
-"La recuperaci&#x00f3;n perezosa de colecciones est&#x00e1; implementada "
-"usando la implementaci&#x00f3;n de colecciones persistentes propia de "
-"Hibernate. Sin embargo, se necesita un mecanismo diferente para un "
-"comportamiento perezoso en las asociaciones de un solo extremo. La entidad "
-"objetivo de la asociaci&#x00f3;n debe ser tratada con proxies. Hibernate "
-"implementa proxies de inicializaci&#x00f3;n perezosa para objetos "
-"persistentes usando mejora del bytecode en tiempo de ejecuci&#x00f3;n (por "
-"medio de la excelente biblioteca CGLIB)."
+"La recuperación perezosa de colecciones está implementada utilizando la "
+"implementación de colecciones persistentes propia de Hibernate. Sin embargo, "
+"se necesita un mecanismo diferente para un comportamiento perezoso en las "
+"asociaciones de un sólo extremo. La entidad destino de la asociación se debe "
+"tratar con proxies. Hibernate implementa proxies de inicialización perezosa "
+"para objetos persistentes utilizando la mejora del código byte en tiempo de "
+"ejecución por medio de la biblioteca CGLIB)."
 
 #. Tag: para
-#: performance.xml:277
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "At startup, Hibernate3 generates proxies by default for all persistent "
 "classes and uses them to enable lazy fetching of <literal>many-to-one</"
 "literal> and <literal>one-to-one</literal> associations."
 msgstr ""
-"Por defecto, Hibernate3 genera proxies (en el arranque) para todas las "
-"clases persistentes y los usa para habilitar la recuperaci&#x00f3;n perezosa "
-"de asociaciones <literal>muchos-a-uno</literal> y <literal>uno-a-uno</"
-"literal>."
+"En el arranque, Hibernate3 genera proxies por defecto para todas las clases "
+"persistentes y los usa para habilitar la recuperación perezosa de "
+"asociaciones <literal>muchos-a-uno</literal> y <literal>uno-a-uno</literal>."
 
 #. Tag: para
-#: performance.xml:283
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The mapping file may declare an interface to use as the proxy interface for "
 "that class, with the <literal>proxy</literal> attribute. By default, "
@@ -539,147 +440,73 @@
 "implement a default constructor with at least package visibility. This "
 "constructor is recommended for all persistent classes</emphasis>."
 msgstr ""
-"El fichero de mapeo puede declarar una interface a usar como interface de "
+"El archivo de mapeo puede declarar una interfaz a utilizar como interfaz de "
 "proxy para esa clase, con el atributo <literal>proxy</literal>. Por defecto, "
-"Hibernate usa una subclase de la clase. <emphasis>Nota que la clase tratada "
-"con proxies debe implementar un constructor por defecto con al menos "
-"visibilidad de paquete. &#x00a1;Recomendamos este constructor para todas las "
-"clases persistentes!</emphasis>"
+"Hibernate usa una subclase de la clase. <emphasis>La clase tratada con "
+"proxies debe implementar un constructor por defecto con al menos visibilidad "
+"de paquete. Recomendamos este constructor para todas las clases "
+"persistentes</emphasis>."
 
 #. Tag: para
-#: performance.xml:290
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are potential problems to note when extending this approach to "
 "polymorphic classes.For example:"
 msgstr ""
-"Hay algunos puntos a tener en cuenta al extender este enfoque a clases "
-"polim&#x00f3;rficas, por ejemplo."
+"Hay problemas potenciales que se deben tener en cuenta al extender este "
+"enfoque a las clases polimórficas. Por ejemplo:"
 
-#. Tag: programlisting
-#: performance.xml:294
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Cat\" proxy=\"Cat\">\n"
-"    ......\n"
-"    <subclass name=\"DomesticCat\">\n"
-"        .....\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Cat\" proxy=\"Cat\">\n"
-"    ......\n"
-"    <subclass name=\"DomesticCat\">\n"
-"        .....\n"
-"    </subclass>\n"
-"</class>]]>"
-
 #. Tag: para
-#: performance.xml:296
 #, no-c-format
 msgid ""
 "Firstly, instances of <literal>Cat</literal> will never be castable to "
 "<literal>DomesticCat</literal>, even if the underlying instance is an "
 "instance of <literal>DomesticCat</literal>:"
 msgstr ""
-"Primero, las instancias de <literal>Cat</literal> nunca ser&#x00e1;n objeto "
-"de un cast a <literal>DomesticCat</literal>, incluso aunque la instancia "
-"subyacente sea instancia de <literal>DomesticCat</literal>:"
+"Primero, las instancias de <literal>Cat</literal> nunca serán objeto de un "
+"cast a <literal>DomesticCat</literal>, incluso aunque la instancia "
+"subyacente sea una instancia de <literal>DomesticCat</literal>:"
 
-#. Tag: programlisting
-#: performance.xml:302
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);  // instantiate a "
-"proxy (does not hit the db)\n"
-"if ( cat.isDomesticCat() ) {                  // hit the db to initialize "
-"the proxy\n"
-"    DomesticCat dc = (DomesticCat) cat;       // Error!\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-"<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);  // instantiate a "
-"proxy (does not hit the db)\n"
-"if ( cat.isDomesticCat() ) {                  // hit the db to initialize "
-"the proxy\n"
-"    DomesticCat dc = (DomesticCat) cat;       // Error!\n"
-"    ....\n"
-"}]]>"
-
 #. Tag: para
-#: performance.xml:304
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Secondly, it is possible to break proxy <literal>==</literal>:"
-msgstr ""
-"Segundo, es posible romper con el operador <literal>==</literal> de un proxy."
+msgstr "Segundo, es posible romper el proxy <literal>==</literal>:"
 
-#. Tag: programlisting
-#: performance.xml:308
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);            // "
-"instantiate a Cat proxy\n"
-"DomesticCat dc = \n"
-"        (DomesticCat) session.load(DomesticCat.class, id);  // acquire new "
-"DomesticCat proxy!\n"
-"System.out.println(cat==dc);                            // false]]>"
-msgstr ""
-"<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);            // "
-"instantiate a Cat proxy\n"
-"DomesticCat dc = \n"
-"        (DomesticCat) session.load(DomesticCat.class, id);  // acquire new "
-"DomesticCat proxy!\n"
-"System.out.println(cat==dc);                            // false]]>"
-
 #. Tag: para
-#: performance.xml:310
 #, no-c-format
 msgid ""
 "However, the situation is not quite as bad as it looks. Even though we now "
 "have two references to different proxy objects, the underlying instance will "
 "still be the same object:"
 msgstr ""
-"Sin embargo, la situaci&#x00f3;n no en absoluta tan mala como parece. Aunque "
+"Sin embargo, la situación no es en absoluto tan mala como parece. Aunque "
 "tenemos ahora dos referencias a objetos proxy diferentes, la instancia "
-"subyacente ser&#x00e1; a&#x00fa;n el mismo objeto:"
+"subyacente será aún el mismo objeto:"
 
-#. Tag: programlisting
-#: performance.xml:315
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[cat.setWeight(11.0);  // hit the db to initialize the proxy\n"
-"System.out.println( dc.getWeight() );  // 11.0]]>"
-msgstr ""
-"<![CDATA[cat.setWeight(11.0);  // hit the db to initialize the proxy\n"
-"System.out.println( dc.getWeight() );  // 11.0]]>"
-
-#. Tag: para
-#: performance.xml:317
-#, fuzzy, no-c-format
-msgid ""
 "Third, you cannot use a CGLIB proxy for a <literal>final</literal> class or "
 "a class with any <literal>final</literal> methods."
 msgstr ""
-"Tercero, no debes usar un proxy CGLIB para una clase <literal>final</"
-"literal> o una clase con alg&#x00fa;n m&#x00e9;todo <literal>final</literal>."
+"Tercero, no puede usar un proxy CGLIB para una clase <literal>final</"
+"literal> o una clase con algún método <literal>final</literal>."
 
 #. Tag: para
-#: performance.xml:322
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, if your persistent object acquires any resources upon instantiation "
 "(e.g. in initializers or default constructor), then those resources will "
 "also be acquired by the proxy. The proxy class is an actual subclass of the "
 "persistent class."
 msgstr ""
-"Finalmente, si tu objeto persistente adquiere cualquier recurso bajo "
-"instanciaci&#x00f3;n (por ejemplo, en inicializadores o constructores por "
-"defecto), entonces esos recursos ser&#x00e1;n adquiridos tambi&#x00e9;n por "
-"el proxy. La clase del proxy es una subclase real de la clase persistente."
+"Finalmente, si su objeto persistente adquiere cualquier recurso bajo "
+"instanciación (por ejemplo, en inicializadores o constructores por defecto), "
+"entonces esos recursos serán adquiridos también por el proxy. La clase del "
+"proxy es una subclase real de la clase persistente. "
 
 #. Tag: para
-#: performance.xml:328
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These problems are all due to fundamental limitations in Java's single "
 "inheritance model. To avoid these problems your persistent classes must each "
@@ -690,163 +517,119 @@
 "<literal>DomesticCat</literal>. For example:"
 msgstr ""
 "Estos problemas se deben a limitaciones fundamentales en el modelo de "
-"herencia &#x00fa;nica de Java. Si deseas evitar estos problemas cada una de "
-"tus clases persistentes deben implementar una interface que declare sus "
-"m&#x00e9;todos de negocio. Debes especificar estas interfaces en el fichero "
-"de mapeo. Por ejemplo:"
+"herencia única de Java. Si desea evitar estos problemas cada una de sus "
+"clases persistentes deben implementar una interfaz que declare sus métodos "
+"de negocio. Debe especificar estas interfaces en el archivo de mapeo en "
+"donde <literal>CatImpl</literal> implementa la interfaz <literal>Cat</"
+"literal> y <literal>DomesticCatImpl</literal> implementa la interfaz "
+"<literal>DomesticCat</literal>. Por ejemplo:"
 
-#. Tag: programlisting
-#: performance.xml:336
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"CatImpl\" proxy=\"Cat\">\n"
-"    ......\n"
-"    <subclass name=\"DomesticCatImpl\" proxy=\"DomesticCat\">\n"
-"        .....\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"CatImpl\" proxy=\"Cat\">\n"
-"    ......\n"
-"    <subclass name=\"DomesticCatImpl\" proxy=\"DomesticCat\">\n"
-"        .....\n"
-"    </subclass>\n"
-"</class>]]>"
-
-#. Tag: para
-#: performance.xml:338
-#, fuzzy, no-c-format
-msgid ""
 "Then proxies for instances of <literal>Cat</literal> and "
 "<literal>DomesticCat</literal> can be returned by <literal>load()</literal> "
 "or <literal>iterate()</literal>."
 msgstr ""
-"Primero, las instancias de <literal>Cat</literal> nunca ser&#x00e1;n objeto "
-"de un cast a <literal>DomesticCat</literal>, incluso aunque la instancia "
-"subyacente sea instancia de <literal>DomesticCat</literal>:"
+"Entonces los proxies para las instancias de <literal>Cat</literal> y "
+"<literal>DomesticCat</literal> pueden ser retornadas por <literal>load()</"
+"literal> o <literal>iterate()</literal>."
 
-#. Tag: programlisting
-#: performance.xml:343
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(CatImpl.class, catid);\n"
-"Iterator iter = session.createQuery(\"from CatImpl as cat where cat."
-"name='fritz'\").iterate();\n"
-"Cat fritz = (Cat) iter.next();]]>"
-msgstr ""
-"<![CDATA[Cat cat = (Cat) session.load(CatImpl.class, catid);\n"
-"Iterator iter = session.createQuery(\"from CatImpl as cat where cat."
-"name='fritz'\").iterate();\n"
-"Cat fritz = (Cat) iter.next();]]>"
-
 #. Tag: title
-#: performance.xml:346
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Nota"
 
 #. Tag: para
-#: performance.xml:347
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>list()</literal> does not usually return proxies."
-msgstr "las consultas de <literal>Criteria</literal>"
+msgstr "<literal>list()</literal> usualmente no retorna proxies."
 
 #. Tag: para
-#: performance.xml:352
 #, no-c-format
 msgid ""
 "Relationships are also lazily initialized. This means you must declare any "
 "properties to be of type <literal>Cat</literal>, not <literal>CatImpl</"
 "literal>."
 msgstr ""
-"Las relaciones tambi&#x00e9;n son inicializadas perezosamente. Esto "
-"significa que debes declarar cualquier propiedad como de tipo <literal>Cat</"
-"literal>, no <literal>CatImpl</literal>."
+"Las relaciones también son inicializadas perezosamente. Esto significa que "
+"debe declarar cualquier propiedad como de tipo <literal>Cat</literal>, no "
+"<literal>CatImpl</literal>."
 
 #. Tag: para
-#: performance.xml:357
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Certain operations do <emphasis>not</emphasis> require proxy initialization:"
 msgstr ""
-"Ciertas operaciones <emphasis>no</emphasis> requieren inicializaci&#x00f3;n "
-"de proxies."
+"Ciertas operaciones <emphasis>no</emphasis> requieren inicialización de "
+"proxies:"
 
 #. Tag: para
-#: performance.xml:363
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>equals()</literal>: if the persistent class does not override "
 "<literal>equals()</literal>"
 msgstr ""
 "<literal>equals()</literal>, si la clase persistente no sobrescribe "
-"<literal>equals()</literal>"
+"<literal>equals()</literal> "
 
 #. Tag: para
-#: performance.xml:369
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>hashCode()</literal>: if the persistent class does not override "
 "<literal>hashCode()</literal>"
 msgstr ""
 "<literal>hashCode()</literal>, si la clase persistente no sobrescribe "
-"<literal>hashCode()</literal>"
+"<literal>hashCode()</literal> "
 
 #. Tag: para
-#: performance.xml:375
 #, no-c-format
 msgid "The identifier getter method"
-msgstr "El m&#x00e9;todo getter del identificador"
+msgstr "El método getter del identificador"
 
 #. Tag: para
-#: performance.xml:381
 #, no-c-format
 msgid ""
 "Hibernate will detect persistent classes that override <literal>equals()</"
 "literal> or <literal>hashCode()</literal>."
 msgstr ""
-"Hibernate detectar&#x00e1; las clase persistentes que sobrescriban "
-"<literal>equals()</literal> o <literal>hashCode()</literal>."
+"Hibernate detectará las clases persistentes que sobrescriban <literal>equals"
+"()</literal> o <literal>hashCode()</literal>."
 
 #. Tag: para
-#: performance.xml:386
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "By choosing <literal>lazy=\"no-proxy\"</literal> instead of the default "
 "<literal>lazy=\"proxy\"</literal>, you can avoid problems associated with "
 "typecasting. However, buildtime bytecode instrumentation is required, and "
 "all operations will result in immediate proxy initialization."
 msgstr ""
-"UNTRANSLATED!!! By choosing <literal>lazy=\"no-proxy\"</literal> instead of "
-"the default <literal>lazy=\"proxy\"</literal>, we can avoid the problems "
-"associated with typecasting. However, we will require buildtime bytecode "
-"instrumentation, and all operations will result in immediate proxy "
-"initialization."
+"Al escoger <literal>lazy=\"no-proxy\"</literal> en vez del <literal>lazy="
+"\"proxy\"</literal> predeterminado, podemos evitar los problemas asociados "
+"con conversión de tipos (typecasting). Sin embargo, requiere la "
+"instrumentación de código byte en tiempo estimado de construcción y todas "
+"las operaciones resultarán en una inicialización de proxies inmediata."
 
 #. Tag: title
-#: performance.xml:396
 #, no-c-format
 msgid "Initializing collections and proxies"
-msgstr "Inicializando colecciones y proxies"
+msgstr "Inicialización de colecciones y proxies"
 
 #. Tag: para
-#: performance.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>LazyInitializationException</literal> will be thrown by Hibernate "
 "if an uninitialized collection or proxy is accessed outside of the scope of "
 "the <literal>Session</literal>, i.e., when the entity owning the collection "
 "or having the reference to the proxy is in the detached state."
 msgstr ""
-"Una <literal>LazyInitializationException</literal> ser&#x00e1; lanzada por "
-"Hibernate si una colecci&#x00f3;n o proxy sin inicializar es accedido fuera "
-"del &#x00e1;mbito de la <literal>Session</literal>, es decir, cuando la "
-"entidad que posee la colecci&#x00f3;n o que tiene la referencia al proxy "
-"est&#x00e9; en el estado separada."
+"Hibernate lanzará una <literal>LazyInitializationException</literal> si se "
+"accede a una colección o proxy sin acceder fuera del ámbito de la "
+"<literal>Session</literal>, por ejemplo, cuando la entidad que posee la "
+"colección o que tiene la referencia al proxy esté en el estado separado."
 
 #. Tag: para
-#: performance.xml:404
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes a proxy or collection needs to be initialized before closing the "
 "<literal>Session</literal>. You can force initialization by calling "
@@ -854,16 +637,14 @@
 "literal>, for example. However, this can be confusing to readers of the code "
 "and it is not convenient for generic code."
 msgstr ""
-"A veces necesitamos asegurarnos que un proxy o colecci&#x00f3;n est&#x00e9; "
-"inicializado antes de cerrar la <literal>Session</literal>. Por supuesto, "
-"siempre podemos forzar la inicializaci&#x00f3;n llamando a <literal>cat."
-"getSex()</literal> o <literal>cat.getKittens().size()</literal>, por "
-"ejemplo. Pero esto es confuso a lectores del c&#x00f3;digo y no es "
-"conveniente para c&#x00f3;digo gen&#x00e9;rico."
+"A veces es necesario inicializar un proxy o una colección antes de cerrar la "
+"<literal>Session</literal>. Puede forzar la inicialización llamando a "
+"<literal>cat.getSex()</literal> o <literal>cat.getKittens().size()</"
+"literal>, por ejemplo. Sin embargo, esto puede ser confuso para los lectores "
+"del código y no es conveniente para el código genérico."
 
 #. Tag: para
-#: performance.xml:411
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The static methods <literal>Hibernate.initialize()</literal> and "
 "<literal>Hibernate.isInitialized()</literal>, provide the application with a "
@@ -873,18 +654,17 @@
 "literal> is still open. <literal>Hibernate.initialize( cat.getKittens() )</"
 "literal> has a similar effect for the collection of kittens."
 msgstr ""
-"Los m&#x00e9;todos est&#x00e1;ticos <literal>Hibernate.initialize()</"
-"literal> y <literal>Hibernate.isInitialized()</literal> proveen a la "
-"aplicaci&#x00f3;n de una forma conveniente de trabajar con colecciones o "
-"proxies inicializados perezosamente. <literal>Hibernate.initialize(cat)</"
-"literal> forzar&#x00e1; la inicializaci&#x00f3;n de un proxy, <literal>cat</"
-"literal>, en tanto su <literal>Session</literal> est&#x00e9; todav&#x00ed;a "
-"abierta. <literal>Hibernate.initialize( cat.getKittens() )</literal> tiene "
-"un efecto similar para la colecci&#x00f3;n de gatitos."
+"Los métodos estáticos <literal>Hibernate.initialize()</literal> y "
+"<literal>Hibernate.isInitialized()</literal> proporcionan a la aplicación "
+"una forma conveniente de trabajar con colecciones o proxies inicializados "
+"perezosamente. <literal>Hibernate.initialize(cat)</literal> forzará la "
+"inicialización de un proxy, <literal>cat</literal>, en tanto su "
+"<literal>Session</literal> esté todavía abierta. <literal>Hibernate."
+"initialize( cat.getKittens() )</literal> tiene un efecto similar para la "
+"colección de gatitos. "
 
 #. Tag: para
-#: performance.xml:420
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Another option is to keep the <literal>Session</literal> open until all "
 "required collections and proxies have been loaded. In some application "
@@ -894,19 +674,16 @@
 "<literal>Session</literal> is open when a collection is initialized. There "
 "are two basic ways to deal with this issue:"
 msgstr ""
-"Otra opci&#x00f3;n es mantener la <literal>Session</literal> abierta hasta "
-"que todas las colecciones y proxies necesarios hayan sido cargados. En "
-"algunas arquitecturas de aplicaci&#x00f3;n, particularmente en aquellas "
-"donde el c&#x00f3;digo que accede a los datos usando Hibernate, y el "
-"c&#x00f3;digo que los usa est&#x00e1;n en capas de aplicaci&#x00f3;n "
-"diferentes o procesos f&#x00ed;sicos diferentes, puede ser un problema "
-"asegurar que la <literal>Session</literal> est&#x00e9; abierta cuando se "
-"inicializa una colecci&#x00f3;n. Existen dos formas b&#x00e1;sicas de tratar "
-"este tema:"
+"Otra opción es mantener la <literal>Session</literal> abierta hasta que "
+"todas las colecciones y proxies necesarios hayan sido cargados. En algunas "
+"arquitecturas de aplicación, particularmente en aquellas donde el código que "
+"accede a los datos usando Hibernate, y el código que los utiliza están en "
+"capas de aplicación diferentes o procesos físicos diferentes, puede ser un "
+"problema asegurar que la <literal>Session</literal> esté abierta cuando se "
+"inicializa una colección. Existen dos formas básicas para abordar este tema: "
 
 #. Tag: para
-#: performance.xml:431
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In a web-based application, a servlet filter can be used to close the "
 "<literal>Session</literal> only at the end of a user request, once the "
@@ -918,25 +695,19 @@
 "rendering of the view. See the Hibernate Wiki for examples of this \"Open "
 "Session in View\" pattern."
 msgstr ""
-"En una aplicaci&#x00f3;n basada web, puede usarse un filtro de servlets para "
-"cerrar la <literal>Session</literal> s&#x00f3;lo bien al final de una "
-"petici&#x00f3;n de usuario, una vez que el rendering de la vista est&#x00e9; "
-"completa (el patr&#x00f3;n <emphasis>Sesi&#x00f3;n Abierta en Vista (Open "
-"Session in View)</emphasis>). Por supuesto, estos sitios requieren una "
-"fuerte demanda de correcci&#x00f3;n del manejo de excepciones de tu "
-"infraestructura de aplicaci&#x00f3;n. Es de una importancia vital que la "
-"<literal>Session</literal> est&#x00e9; cerrada y la transacci&#x00f3;n "
-"terminada antes de volver al usuario, incluso cuando ocurra una "
-"excepci&#x00f3;n durante el rendering de la p&#x00e1;gina. Para este "
-"enfoque, el filtro de servlet tiene que ser capaz de accceder la "
-"<literal>Session</literal>. Recomendamos que se use una variable "
-"<literal>ThreadLocal</literal> para tener la <literal>Session</literal> "
-"actual (ver el cap&#x00ed;tulo 1, <xref linkend=\"quickstart-playingwithcats"
-"\"/>, para una implementaci&#x00f3;n de ejemplo)."
+"En una aplicación basada en la web se puede utilizar un filtro de servlets "
+"para cerrar la <literal>Session</literal> sólamente al final de una petición "
+"del usuario, una vez que la entrega de la vista esté completa (el patrón "
+"<emphasis>sesión abierta en vista (open session in view)</emphasis>). Por "
+"supuesto, estos sitios requieren una fuerte demanda de corrección del manejo "
+"de excepciones de la infraestructura de su aplicación. Es de una vital "
+"importancia que la <literal>Session</literal> esté cerrada y la transacción "
+"terminada antes de volver al usuario, incluso cuando ocurra una excepción "
+"durante le entrega de la vista. Refiérase a la Wiki de Hibernate para ver "
+"ejemplos de este patrón \"Open Session in View\" (sesión abierta en vista). "
 
 #. Tag: para
-#: performance.xml:444
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In an application with a separate business tier, the business logic must "
 "\"prepare\" all collections that the web tier needs before returning. This "
@@ -950,24 +721,22 @@
 "literal>. This is usually easier if you adopt the <emphasis>Command</"
 "emphasis> pattern instead of a <emphasis>Session Facade</emphasis>."
 msgstr ""
-"En una aplciaci&#x00f3;n con una grada de negocios separada, la l&#x00f3;"
-"gica de negocio debe \"preparar\" todas las colecciones que se vayan a "
-"necesitar por la grada web antes de volver. Esto significa que la grada de "
-"negocios debe cargar todos los datos y devolver a la grada de "
-"presentaci&#x00f3;n web todos los datos que se requieran para un caso de uso "
-"en particular ya inicializados. Usualmente, la aplicaci&#x00f3;n llama a "
-"<literal>Hibernate.initialize()</literal> para cada colecci&#x00f3;n que se "
-"necesitar&#x00e1; en la grada web (esta llamada debe ocurrir antes que la "
-"sesi&#x00f3;n sea cerrada) o recupera la colecci&#x00f3;n tempranamente "
-"usando una consulta de Hibernate con una cl&#x00e1;usula <literal>FETCH</"
-"literal> o una <literal>FetchMode.JOIN</literal> en <literal>Criteria</"
-"literal>. Esto es usualmente m&#x00e1;s f&#x00e1;cil si adoptas el "
-"patr&#x00f3;n <emphasis>Comando</emphasis> en vez de un <emphasis>Fachada de "
-"Sesi&#x00f3;n</emphasis>."
+"En una aplicación con una capa de negocios separada, la lógica empresarial "
+"tiene que \"preparar\" todas las colecciones que la capa web va a necesitar "
+"antes de retornar. Esto significa que la capa empresarial debe cargar todos "
+"los datos y devolver a la capa web/presentación todos los datos ya "
+"inicializados que se requieran para un caso de uso en particular. "
+"Usualmente, la aplicación llama a <literal>Hibernate.initialize()</literal> "
+"para cada colección que se necesitará en la capa web (esta llamada debe "
+"tener lugar antes de que se cierre la sesión) o recupera la colección "
+"tempranamente utilizando una consulta de Hibernate con una cláusula "
+"<literal>FETCH</literal> o una <literal>FetchMode.JOIN</literal> en "
+"<literal>Criteria</literal>. Usualmente, esto es más fácil si adopta el "
+"patrón <emphasis>Comando</emphasis> en vez de una <emphasis>Fachada de "
+"Sesión</emphasis>."
 
 #. Tag: para
-#: performance.xml:459
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also attach a previously loaded object to a new <literal>Session</"
 "literal> with <literal>merge()</literal> or <literal>lock()</literal> before "
@@ -975,92 +744,64 @@
 "and certainly <emphasis>should</emphasis> not, do this automatically since "
 "it would introduce impromptu transaction semantics."
 msgstr ""
-"Puedes tambi&#x00e9;n adjuntar un objeto cargado previamente a una nueva "
+"También puede adjuntar un objeto cargado previamente a una nueva "
 "<literal>Session</literal> con <literal>merge()</literal> o <literal>lock()</"
-"literal> antes de acceder a colecciones no inicializadas (u otros proxies). "
-"&#x00a1;No, Hibernate no, y ciertamente <emphasis>no debe</emphasis> hacer "
-"esto autom&#x00e1;ticamente, ya que introducir&#x00ed;a sem&#x00e1;nticas de "
-"transacci&#x00f3;n ad hoc!"
+"literal> antes de acceder a colecciones no inicializadas u otros proxies. "
+"Hibernate no y ciertamente <emphasis>no debe</emphasis> hacer esto "
+"automáticamente ya que introduciría semánticas de transacción improvisadas."
 
 #. Tag: para
-#: performance.xml:469
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes you do not want to initialize a large collection, but still need "
 "some information about it, like its size, for example, or a subset of the "
 "data."
 msgstr ""
-"A veces no quieres inicializar una colecci&#x00f3;n grande, pero necesitas "
-"a&#x00fa;n alguna informacion sobre ella (como su tama&#x00f1;o) o un "
-"subconjunto de los datos."
+"A veces no quiere inicializar una colección grande, pero todavía necesita "
+"alguna información sobre ella como por ejemplo, su tamaño o un subconjunto "
+"de los datos."
 
 #. Tag: para
-#: performance.xml:474
 #, no-c-format
 msgid ""
 "You can use a collection filter to get the size of a collection without "
 "initializing it:"
 msgstr ""
-"Puedes usar un filtro de colecciones para obtener el tama&#x00f1;o de una "
-"colecci&#x00f3;n sin inicializarla:"
+"Puede utilizar un filtro de colecciones para obtener el tamaño de una "
+"colección sin inicializarla:"
 
-#. Tag: programlisting
-#: performance.xml:478
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) s.createFilter( collection, \"select count(*)\" ).list"
-"().get(0) ).intValue()]]>"
-msgstr ""
-"<![CDATA[( (Integer) s.createFilter( collection, \"select count(*)\" ).list"
-"().get(0) ).intValue()]]>"
-
 #. Tag: para
-#: performance.xml:480
 #, no-c-format
 msgid ""
 "The <literal>createFilter()</literal> method is also used to efficiently "
 "retrieve subsets of a collection without needing to initialize the whole "
 "collection:"
 msgstr ""
-"El m&#x00e9;todo <literal>createFilter()</literal> se usa tambi&#x00e9;n "
-"para recuperar eficientemente subconjuntos de una colecci&#x00f3;n sin "
-"necesidad de inicializar toda la colecci&#x00f3;n:"
+"El método <literal>createFilter()</literal> también se utiliza para "
+"recuperar eficientemente subconjuntos de una colección sin necesidad de "
+"inicializar toda la colección:"
 
-#. Tag: programlisting
-#: performance.xml:485
-#, no-c-format
-msgid ""
-"<![CDATA[s.createFilter( lazyCollection, \"\").setFirstResult(0)."
-"setMaxResults(10).list();]]>"
-msgstr ""
-"<![CDATA[s.createFilter( lazyCollection, \"\").setFirstResult(0)."
-"setMaxResults(10).list();]]>"
-
 #. Tag: title
-#: performance.xml:490
 #, no-c-format
 msgid "Using batch fetching"
-msgstr "Usando recuperaci&#x00f3;n en lotes"
+msgstr "Utilización de recuperación de lotes"
 
 #. Tag: para
-#: performance.xml:492
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Using batch fetching, Hibernate can load several uninitialized proxies if "
 "one proxy is accessed. Batch fetching is an optimization of the lazy select "
 "fetching strategy. There are two ways you can configure batch fetching: on "
 "the class level and the collection level."
 msgstr ""
-"Hibernate puede hacer un uso eficiente de la recuperaci&#x00f3;n en lotes, "
-"esto es, Hibernate puede cargar muchos proxies sin inicializar si se accede "
-"a un proxy (o colecciones). La recuperaci&#x00f3;n en lotes es una "
-"optimizaci&#x00f3;n de la estrategia de recuperaci&#x00f3;n por "
-"selecci&#x00f3;n perezosa. Hay dos formas en que puedes afinar la "
-"recuperaci&#x00f3;n en lotes: a nivel de la clase o de la colecci&#x00f3;n."
+"Usando la recuperación por lotes, Hibernate puede cargar varios proxies sin "
+"inicializar si se accede a un proxy. La recuperación en lotes es una "
+"optimización de la estrategia de recuperación por selección perezosa. Hay "
+"dos formas en que puede configurar la recuperación en lotes: a nivel de la "
+"clase y a nivel de colección."
 
 #. Tag: para
-#: performance.xml:498
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Batch fetching for classes/entities is easier to understand. Consider the "
 "following example: at runtime you have 25 <literal>Cat</literal> instances "
@@ -1073,37 +814,27 @@
 "can tune this behavior by specifying a <literal>batch-size</literal> in the "
 "mapping of <literal>Person</literal>:"
 msgstr ""
-"La recuperaci&#x00f3;n en lotes para clases/entidades es m&#x00e1;s f&#x00e1;"
-"cil de entender. Imagina que tienes la siguiente situaci&#x00f3;n en tiempo "
-"de ejecuci&#x00f3;n: Tienes 25 instancias de <literal>Cat</literal> cargadas "
-"en una <literal>Session</literal>, cada <literal>Cat</literal> tiene una "
-"referencia a su <literal>owner</literal>, una <literal>Person</literal>. La "
-"clase <literal>Person</literal> est&#x00e1; mapeada con un proxy, "
-"<literal>lazy=\"true\"</literal>. Si ahora iteras a trav&#x00e9;s de todos "
-"los gatos y llamas a <literal>getOwner()</literal> para cada uno, Hibernate "
-"por defecto ejecutar&#x00e1; 25 sentencias <literal>SELECT</literal> para "
-"traer los due&#x00f1;os tratados con proxies. Puedes afinar este "
-"comportamiento especificando un <literal>batch-size</literal> en el mapeo de "
+"La recuperación en lotes para clases/entidades es más fácil de entender. "
+"Considere el siguiente ejemplo: en tiempo de ejecución tiene 25 instancias "
+"de <literal>Cat</literal> cargadas en una <literal>Session</literal> y cada "
+"<literal>Cat</literal> tiene una referencia a su <literal>owner</literal>, "
+"una <literal>Person</literal>. La clase <literal>Person</literal> está "
+"mapeada con un proxy, <literal>lazy=\"true\"</literal>. Si ahora itera a "
+"través de todos los cats y llama a <literal>getOwner()</literal> para cada "
+"uno, Hibernate por defecto, ejecutará 25 declaraciones <literal>SELECT</"
+"literal> para recuperar los dueños proxies. Puede afinar este comportamiento "
+"especificando un <literal>batch-size</literal> en el mapeo de "
 "<literal>Person</literal>:"
 
-#. Tag: programlisting
-#: performance.xml:508
-#, no-c-format
-msgid "<![CDATA[<class name=\"Person\" batch-size=\"10\">...</class>]]>"
-msgstr "<![CDATA[<class name=\"Person\" batch-size=\"10\">...</class>]]>"
-
 #. Tag: para
-#: performance.xml:510
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will now execute only three queries: the pattern is 10, 10, 5."
 msgstr ""
-"Hibernate ahora ejecutar&#x00e1; s&#x00f3;lo tres consultas, el patr&#x00f3;"
-"n es 10, 10, 5."
+"Hibernate ahora ejecutará sólamente tres consultas: el patrón es 10, 10, 5."
 
 #. Tag: para
-#: performance.xml:514
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also enable batch fetching of collections. For example, if each "
 "<literal>Person</literal> has a lazy collection of <literal>Cat</literal>s, "
@@ -1113,34 +844,16 @@
 "fetching for the <literal>cats</literal> collection in the mapping of "
 "<literal>Person</literal>, Hibernate can pre-fetch collections:"
 msgstr ""
-"Tambi&#x00e9;n puedes habilitar la recuperaci&#x00f3;n en lotes para "
-"colecciones. Por ejemplo, si cada <literal>Person</literal> tiene una "
-"colecci&#x00f3;n perezosa de <literal>Cat</literal>s, y hay 10 personas "
-"actualmente cargadas en la <literal>Session</literal>, iterar a trav&#x00e9;"
-"s de las 10 personas generar&#x00e1; 10 <literal>SELECT</literal>s, una para "
-"cada llamada a <literal>getCats()</literal>. Si habilitas la "
-"recuperaci&#x00f3;n en lotes para la colecci&#x00f3;n de <literal>cats</"
-"literal> en el mapeo de <literal>Person</literal>, Hibernate puede recuperar "
-"por adelantado las colecciones:"
+"También puede habilitar la recuperación en lotes para colecciones. Por "
+"ejemplo, si cada <literal>Person</literal> tiene una colección perezosa de "
+"<literal>Cat</literal>s y hay 10 personas actualmente cargadas en la "
+"<literal>Session</literal>, iterar a través de las 10 personas generará 10 "
+"<literal>SELECT</literal>s, uno para cada llamada a <literal>getCats()</"
+"literal>. Si habilita la recuperación en lotes para la colección de "
+"<literal>cats</literal> en el mapeo de <literal>Person</literal>, Hibernate "
+"puede recuperar por adelantado las colecciones: "
 
-#. Tag: programlisting
-#: performance.xml:523
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <set name=\"cats\" batch-size=\"3\">\n"
-"        ...\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <set name=\"cats\" batch-size=\"3\">\n"
-"        ...\n"
-"    </set>\n"
-"</class>]]>"
-
 #. Tag: para
-#: performance.xml:525
 #, no-c-format
 msgid ""
 "With a <literal>batch-size</literal> of 3, Hibernate will load 3, 3, 3, 1 "
@@ -1148,55 +861,107 @@
 "attribute depends on the expected number of uninitialized collections in a "
 "particular <literal>Session</literal>."
 msgstr ""
-"Con un <literal>batch-size</literal> de 3, Hibernate cargar&#x00e1; 3, 3, 3, "
-"1 colecciones en cuatro <literal>SELECT</literal>s. Una vez m&#x00e1;s, el "
-"valor del atributo depende del n&#x00fa;mero esperado de colecciones sin "
-"inicializar en una <literal>Session</literal> en particular."
+"Con un <literal>batch-size</literal> de 3, Hibernate cargará las colecciones "
+"3, 3, 3, 1 en cuatro <literal>SELECT</literal>s. Una vez más, el valor del "
+"atributo depende del número esperado de colecciones sin inicializar en una "
+"<literal>Session</literal> en particular."
 
 #. Tag: para
-#: performance.xml:531
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Batch fetching of collections is particularly useful if you have a nested "
 "tree of items, i.e. the typical bill-of-materials pattern. However, a "
 "<emphasis>nested set</emphasis> or a <emphasis>materialized path</emphasis> "
 "might be a better option for read-mostly trees."
 msgstr ""
-"La recuperaci&#x00f3;n de coleccione en lotes es particularmente &#x00fa;til "
-"si tienes un &#x00e1;rbol anidado de &#x00ed;tems, es decir, el t&#x00ed;"
-"pico patr&#x00f3;n de cuenta de materiales. (Aunque un <emphasis>conjunto "
-"anidado</emphasis> o una <emphasis>ruta materializada</emphasis> podr&#x00ed;"
-"a ser una mejor opci&#x00f3;n para &#x00e1;rboles que sean de lectura en la "
-"mayor&#x00ed;a de los casos.)"
+"La recuperación de colecciones en lotes es particularmente útil si tiene un "
+"árbol anidado de ítems, por ejemplo, el típico patrón de cuenta de "
+"materiales. Sin embargo, un <emphasis>conjunto anidado</emphasis> o una "
+"<emphasis>ruta materializada</emphasis> podría ser una mejor opción para "
+"árboles que sean de lectura en la mayoría de los casos."
 
 #. Tag: title
-#: performance.xml:540
 #, no-c-format
 msgid "Using subselect fetching"
-msgstr "Usando recuperaci&#x00f3;n por subselecci&#x00f3;n"
+msgstr "Utilización de la recuperación por subselección"
 
 #. Tag: para
-#: performance.xml:542
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If one lazy collection or single-valued proxy has to be fetched, Hibernate "
 "will load all of them, re-running the original query in a subselect. This "
 "works in the same way as batch-fetching but without the piecemeal loading."
 msgstr ""
-"Si una colecci&#x00f3;n perezosa o proxy monovaluado tiene que ser "
-"recuperado, Hibernate los carga a todos, volviendo a ejecutar la consulta "
-"original en una subselecci&#x00f3;n. Esto funciona de la misma forma que la "
-"recuperaci&#x00f3;n en lotes, sin carga fragmentaria."
+"Si una colección perezosa o proxy monovaluado tiene que ser recuperado, "
+"Hibernate los carga a todos, volviendo a ejecutar la consulta original en "
+"una subselección. Esto funciona de la misma forma que la recuperación en "
+"lotes, sin carga fragmentaria. "
 
 #. Tag: title
-#: performance.xml:553
+#, fuzzy, no-c-format
+msgid "Fetch profiles"
+msgstr "Estrategias de recuperación"
+
+#. Tag: para
 #, no-c-format
+msgid ""
+"Another way to affect the fetching strategy for loading associated objects "
+"is through something called a fetch profile, which is a named configuration "
+"associated with the <interfacename>org.hibernate.SessionFactory</"
+"interfacename> but enabled, by name, on the <interfacename>org.hibernate."
+"Session</interfacename>. Once enabled on a <interfacename>org.hibernate."
+"Session</interfacename>, the fetch profile wull be in affect for that "
+"<interfacename>org.hibernate.Session</interfacename> until it is explicitly "
+"disabled."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"So what does that mean? Well lets explain that by way of an example. Say we "
+"have the following mappings:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Now normally when you get a reference to a particular customer, that "
+"customer's set of orders will be lazy meaning we will not yet have loaded "
+"those orders from the database. Normally this is a good thing. Now lets say "
+"that you have a certain use case where it is more efficient to load the "
+"customer and their orders together. One way certainly is to use \"dynamic "
+"fetching\" strategies via an HQL or criteria queries. But another option is "
+"to use a fetch profile to achieve that. Just add the following to your "
+"mapping:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "or even:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Now the following code will actually load both the customer <emphasis>and "
+"their orders</emphasis>:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Currently only join style fetch profiles are supported, but they plan is to "
+"support additional styles. See <ulink url=\"http://opensource.atlassian.com/"
+"projects/hibernate/browse/HHH-3414\">HHH-3414</ulink> for details."
+msgstr ""
+
+#. Tag: title
+#, no-c-format
 msgid "Using lazy property fetching"
-msgstr "Usando recuperaci&#x00f3;n perezosa de propiedades"
+msgstr "Utilización de la recuperación perezosa de propiedades"
 
 #. Tag: para
-#: performance.xml:555
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 supports the lazy fetching of individual properties. This "
 "optimization technique is also known as <emphasis>fetch groups</emphasis>. "
@@ -1206,141 +971,72 @@
 "when legacy tables have hundreds of columns and the data model cannot be "
 "improved."
 msgstr ""
-"Hibernate3 soporta la recuperaci&#x00f3;n perezosa de propiedades "
-"individuales. Esta t&#x00e9;cnica de optimizaci&#x00f3;n es tambi&#x00e9;n "
-"conocida como <emphasis>grupos de recuperaci&#x00f3;n (fetch groups)</"
-"emphasis>. Por favor, nota que &#x00e9;ste es mayormente un aspecto de "
-"marketing, ya que en la pr&#x00e1;ctica, optimizar lecturas de filas es "
-"mucho m&#x00e1;s importante que la optimizaci&#x00f3;n de lectura de "
-"columnas. Sin embargo, cargar s&#x00f3;lo algunas propiedades de una clase "
-"podr&#x00ed;a ser &#x00fa;til en casos extremos, cuando tablas heredadas "
-"tienen cientos de columnas y el modelo de datos no puede ser mejorado."
+"Hibernate3 soporta la recuperación perezosa de propiedades individuales. "
+"Esta técnica de optimización también es conocida como <emphasis>grupos de "
+"recuperación (fetch groups)</emphasis>. Por favor, note que éste es "
+"principalmente un aspecto de marketing, ya que en la práctica, optimizar las "
+"lecturas de filas es mucho más importante que la optimización de lectura de "
+"columnas. Sin embargo, cargar sólo algunas propiedades de una clase podría "
+"ser útil en casos extremos. Por ejemplo, cuando las tablas heredadas tienen "
+"cientos de columnas y el modelo de datos no puede ser mejorado."
 
 #. Tag: para
-#: performance.xml:564
 #, no-c-format
 msgid ""
 "To enable lazy property loading, set the <literal>lazy</literal> attribute "
 "on your particular property mappings:"
 msgstr ""
-"Para habilitar la carga perezosa de propiedades, establece el atributo "
-"<literal>lazy</literal> en tus mapeos de propiedades:"
+"Para habilitar la carga perezosa de propiedades, establezca el atributo "
+"<literal>lazy</literal> en sus mapeos de propiedades:"
 
-#. Tag: programlisting
-#: performance.xml:569
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Document\">\n"
-"       <id name=\"id\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\" length=\"50\"/>\n"
-"    <property name=\"summary\" not-null=\"true\" length=\"200\" lazy=\"true"
-"\"/>\n"
-"    <property name=\"text\" not-null=\"true\" length=\"2000\" lazy=\"true\"/"
-">\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Document\">\n"
-"       <id name=\"id\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\" length=\"50\"/>\n"
-"    <property name=\"summary\" not-null=\"true\" length=\"200\" lazy=\"true"
-"\"/>\n"
-"    <property name=\"text\" not-null=\"true\" length=\"2000\" lazy=\"true\"/"
-">\n"
-"</class>]]>"
-
-#. Tag: para
-#: performance.xml:571
-#, fuzzy, no-c-format
-msgid ""
 "Lazy property loading requires buildtime bytecode instrumentation. If your "
 "persistent classes are not enhanced, Hibernate will ignore lazy property "
 "settings and return to immediate fetching."
 msgstr ""
-"&#x00a1;La carga perezosa de propiedades requiere la instrumentaci&#x00f3;n "
-"del bytecode en tiempo de construcci&#x00f3;n! Si tus clases persistentes no "
-"son mejoradas, Hibernate ignorar&#x00e1; silenciosamente la "
-"configuraci&#x00f3;n perezosa de propiedades y caer&#x00e1; en "
-"recuperaci&#x00f3;n inmediata."
+"La carga perezosa de propiedades requiere la instrumentación del código byte "
+"en tiempo de construcción. Si sus clases persistentes no se mejoran, "
+"Hibernate ignorará la configuración perezosa de propiedades y retornará a la "
+"recuperación inmediata."
 
 #. Tag: para
-#: performance.xml:577
 #, no-c-format
 msgid "For bytecode instrumentation, use the following Ant task:"
 msgstr ""
-"Para la instrumentaci&#x00f3;n del bytecode, usa la siguiente tarea Ant:"
+"Para la instrumentación del código byte, utilice la siguiente tarea Ant:"
 
-#. Tag: programlisting
-#: performance.xml:581
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<target name=\"instrument\" depends=\"compile\">\n"
-"    <taskdef name=\"instrument\" classname=\"org.hibernate.tool.instrument."
-"InstrumentTask\">\n"
-"        <classpath path=\"${jar.path}\"/>\n"
-"        <classpath path=\"${classes.dir}\"/>\n"
-"        <classpath refid=\"lib.class.path\"/>\n"
-"    </taskdef>\n"
-"\n"
-"    <instrument verbose=\"true\">\n"
-"        <fileset dir=\"${testclasses.dir}/org/hibernate/auction/model\">\n"
-"            <include name=\"*.class\"/>\n"
-"        </fileset>\n"
-"    </instrument>\n"
-"</target>]]>"
-msgstr ""
-"<![CDATA[<target name=\"instrument\" depends=\"compile\">\n"
-"    <taskdef name=\"instrument\" classname=\"org.hibernate.tool.instrument."
-"InstrumentTask\">\n"
-"        <classpath path=\"${jar.path}\"/>\n"
-"        <classpath path=\"${classes.dir}\"/>\n"
-"        <classpath refid=\"lib.class.path\"/>\n"
-"    </taskdef>\n"
-"\n"
-"    <instrument verbose=\"true\">\n"
-"        <fileset dir=\"${testclasses.dir}/org/hibernate/auction/model\">\n"
-"            <include name=\"*.class\"/>\n"
-"        </fileset>\n"
-"    </instrument>\n"
-"</target>]]>"
-
-#. Tag: para
-#: performance.xml:583
-#, fuzzy, no-c-format
-msgid ""
 "A different way of avoiding unnecessary column reads, at least for read-only "
 "transactions, is to use the projection features of HQL or Criteria queries. "
 "This avoids the need for buildtime bytecode processing and is certainly a "
 "preferred solution."
 msgstr ""
-"Una forma diferente (&#x00bf;mejor?) de evitar lecturas innecesarias de "
-"columnas, al menos para transacciones de s&#x00f3;lo lectura es usar las "
-"funcionalidades de proyecci&#x00f3;n de consultas HQL o Criteria. Esto evita "
-"la necesidad de procesar el bytecode en tiempo de construcci&#x00f3;n y "
-"ciertamente es una soluci&#x00f3;n preferida."
+"Una forma diferente de evitar lecturas innecesarias de columnas, al menos "
+"para transacciones de sólo lectura es utilizar las funcionalidades de "
+"proyección de consultas HQL o Criteria. Esto evita la necesidad de procesar "
+"el código byte en tiempo de construcción y ciertamente es la solución "
+"preferida."
 
 #. Tag: para
-#: performance.xml:590
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can force the usual eager fetching of properties using <literal>fetch "
 "all properties</literal> in HQL."
 msgstr ""
-"Puedes forzar la usual recuperaci&#x00f3;n temprana de propiedades usando "
+"Puede forzar la usual recuperación temprana de propiedades utilizando "
 "<literal>fetch all properties</literal> en HQL."
 
 #. Tag: title
-#: performance.xml:600
 #, no-c-format
 msgid "The Second Level Cache"
-msgstr "El Cach&#x00e9; de Segundo Nivel"
+msgstr "El Caché de Segundo Nivel"
 
 #. Tag: para
-#: performance.xml:602
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A Hibernate <literal>Session</literal> is a transaction-level cache of "
 "persistent data. It is possible to configure a cluster or JVM-level "
@@ -1350,18 +1046,17 @@
 "another application. They can, however, be configured to regularly expire "
 "cached data."
 msgstr ""
-"Una <literal>Session</literal> de Hibernate es una cach&#x00e9; de datos "
-"persistentes a nivel de transacci&#x00f3;n. Es posible configurar un cluster "
-"o cach&#x00e9; a nivel de JVM (a nivel de <literal>SessionFactory</literal>) "
-"sobre una base de clase-a-clase o colecci&#x00f3;n-a-colecci&#x00f3;n. "
-"Puedes incluso enchufar una cach&#x00e9; en cluster. S&#x00e9; cuidadoso. "
-"Las cach&#x00e9;s nunca est&#x00e1;n al tanto de los cambios hechos por otra "
-"aplicaci&#x00f3;n al almac&#x00e9;n persistente (aunque pueden ser "
-"configurados para expirar regularmente los datos en cach&#x00e9;)."
+"Una <literal>Session</literal> de Hibernate es un caché de datos "
+"persistentes a nivel de transacción. Es posible configurar un clúster o "
+"caché a nivel de MVJ (a nivel de <literal>SessionFactory</literal>) sobre "
+"una base de clase-por-clase o colección-por-colección. Incluso puede "
+"enchufar un caché en clúster. Tenga en cuenta de que los cachés nunca están "
+"al tanto de los cambios que otra aplicación haya realizado al almacén "
+"persistente. Sin embargo, se pueden configurar para que los datos en caché "
+"expiren regularmente."
 
 #. Tag: para
-#: performance.xml:610
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You have the option to tell Hibernate which caching implementation to use by "
 "specifying the name of a class that implements <literal>org.hibernate.cache."
@@ -1371,311 +1066,243 @@
 "can also implement your own and plug it in as outlined above. Note that "
 "versions prior to 3.2 use EhCache as the default cache provider."
 msgstr ""
-"Por defecto, Hibernate usa EHCache para caching a nivel de JVM. (El soporte "
-"a JCS ahora est&#x00e1; despreciado y ser&#x00e1; quitado en una futura "
-"versi&#x00f3;n de Hibernate.) Puedes elegir una implementaci&#x00f3;n "
-"diferente estableciendo el nombre de una clase que implemente <literal>org."
-"hibernate.cache.CacheProvider</literal> usando la propiedad "
-"<literal>hibernate.cache.provider_class</literal>."
+"Tiene la opción de decirle a Hibernate cual implementación de caché utilizar "
+"al especificar el nombre de una clase que implemente <literal>org.hibernate."
+"cache.CacheProvider</literal> utilizando la propiedad <literal>hibernate."
+"cache.provider_class</literal>. Hibernate viene vinculada con un número de "
+"integraciones incorporadas con los proveedores caché de código abierto "
+"enumerados a continuación. Además puede implementar el suyo y enchufarlo "
+"como se explicó anteriormente. Observe que las versiones anteriores a 3.2 "
+"por defecto utilizan EhCache como proveedor de caché."
 
 #. Tag: title
-#: performance.xml:621
 #, no-c-format
 msgid "Cache Providers"
-msgstr "Proveedores de Cach&#x00e9;"
+msgstr "Proveedores de Caché"
 
 #. Tag: entry
-#: performance.xml:630 performance.xml:818
 #, no-c-format
 msgid "Cache"
-msgstr "Cach&#x00e9;"
+msgstr "Caché"
 
 #. Tag: entry
-#: performance.xml:631
 #, no-c-format
 msgid "Provider class"
-msgstr "clase del Provedor"
+msgstr "Clase del Provedor"
 
 #. Tag: entry
-#: performance.xml:632
 #, no-c-format
 msgid "Type"
 msgstr "Tipo"
 
 #. Tag: entry
-#: performance.xml:633
 #, no-c-format
 msgid "Cluster Safe"
-msgstr "Cluster Seguro"
+msgstr "Clúster Seguro"
 
 #. Tag: entry
-#: performance.xml:634
 #, no-c-format
 msgid "Query Cache Supported"
-msgstr "Cach&#x00e9; de Consultas Soportado"
+msgstr "Caché de Consultas Soportado"
 
 #. Tag: entry
-#: performance.xml:639 performance.xml:827
 #, no-c-format
 msgid "Hashtable (not intended for production use)"
-msgstr "Hashtable (no pensado para uso en producci&#x00f3;n)"
+msgstr "Hashtable (no fue pensado para la utilización en producción)"
 
-#. Tag: literal
-#: performance.xml:640
-#, no-c-format
-msgid "org.hibernate.cache.HashtableCacheProvider"
-msgstr "org.hibernate.cache.HashtableCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.HashtableCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.HashtableCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:641
 #, no-c-format
 msgid "memory"
 msgstr "memoria"
 
 #. Tag: entry
-#: performance.xml:643 performance.xml:650 performance.xml:657
-#: performance.xml:828 performance.xml:829 performance.xml:830
-#: performance.xml:835 performance.xml:836 performance.xml:837
-#: performance.xml:842 performance.xml:843 performance.xml:844
-#: performance.xml:849 performance.xml:850 performance.xml:856
-#: performance.xml:859 performance.xml:863 performance.xml:866
 #, no-c-format
-msgid "<entry>yes</entry>"
-msgstr "<entry>si</entry>"
+msgid "yes"
+msgstr "si"
 
 #. Tag: entry
-#: performance.xml:646 performance.xml:834
 #, no-c-format
 msgid "EHCache"
 msgstr "EHCache"
 
-#. Tag: literal
-#: performance.xml:647
-#, no-c-format
-msgid "org.hibernate.cache.EhCacheProvider"
-msgstr "org.hibernate.cache.EhCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.EhCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.EhCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:648 performance.xml:655
 #, no-c-format
 msgid "memory, disk"
 msgstr "memoria, disco"
 
 #. Tag: entry
-#: performance.xml:653 performance.xml:841
 #, no-c-format
 msgid "OSCache"
 msgstr "OSCache"
 
-#. Tag: literal
-#: performance.xml:654
-#, no-c-format
-msgid "org.hibernate.cache.OSCacheProvider"
-msgstr "org.hibernate.cache.OSCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.OSCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.OSCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:660 performance.xml:848
 #, no-c-format
 msgid "SwarmCache"
 msgstr "SwarmCache"
 
-#. Tag: literal
-#: performance.xml:661
-#, no-c-format
-msgid "org.hibernate.cache.SwarmCacheProvider"
-msgstr "org.hibernate.cache.SwarmCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.SwarmCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.SwarmCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:662
 #, no-c-format
 msgid "clustered (ip multicast)"
-msgstr "clusterizado (ip multicast)"
+msgstr "en clúster (ip multicast)"
 
 #. Tag: entry
-#: performance.xml:663
 #, no-c-format
 msgid "yes (clustered invalidation)"
-msgstr "s&#x00ed; (invalidaci&#x00f3;n en cluster)"
+msgstr "sí (invalidación en clúster)"
 
 #. Tag: entry
-#: performance.xml:667 performance.xml:855
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "JBoss Cache 1.x"
-msgstr "TreeCache de JBoss"
+msgstr "JBoss Cache 1.x"
 
-#. Tag: literal
-#: performance.xml:668
-#, no-c-format
-msgid "org.hibernate.cache.TreeCacheProvider"
-msgstr "org.hibernate.cache.TreeCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.TreeCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.TreeCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:669 performance.xml:676
 #, no-c-format
 msgid "clustered (ip multicast), transactional"
-msgstr "clusterizado (ip multicast), transaccional"
+msgstr "en clúster (ip multicast), transaccional"
 
 #. Tag: entry
-#: performance.xml:670
 #, no-c-format
 msgid "yes (replication)"
-msgstr "s&#x00ed; (replicaci&#x00f3;n)"
+msgstr "sí (replicación)"
 
 #. Tag: entry
-#: performance.xml:671 performance.xml:678
 #, no-c-format
 msgid "yes (clock sync req.)"
-msgstr "s&#x00ed; (requiere sincronizaci&#x00f3;n de reloj)"
+msgstr "sí (requiere sincronización de reloj)"
 
 #. Tag: entry
-#: performance.xml:674 performance.xml:862
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "JBoss Cache 2"
-msgstr "TreeCache de JBoss"
+msgstr "JBoss Cache 2"
 
-#. Tag: literal
-#: performance.xml:675
+#. Tag: entry
 #, fuzzy, no-c-format
-msgid "org.hibernate.cache.jbc2.JBossCacheRegionFactory"
-msgstr "org.hibernate.cache.EhCacheProvider"
+msgid "<literal>org.hibernate.cache.jbc.JBossCacheRegionFactory</literal>"
+msgstr "<literal>org.hibernate.cache.jbc2.JBossCacheRegionFactory</literal>"
 
 #. Tag: entry
-#: performance.xml:677
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "yes (replication or invalidation)"
-msgstr "s&#x00ed; (invalidaci&#x00f3;n en cluster)"
+msgstr "sí (replicación o invalidación)"
 
 #. Tag: title
-#: performance.xml:685
 #, no-c-format
 msgid "Cache mappings"
-msgstr "Mapeos de cach&#x00e9;"
+msgstr "Mapeos de caché"
 
 #. Tag: para
-#: performance.xml:687
 #, no-c-format
 msgid ""
 "The <literal>&lt;cache&gt;</literal> element of a class or collection "
 "mapping has the following form:"
 msgstr ""
-"El elemento <literal>&lt;cache&gt;</literal> de una mapeo de clase o "
-"colecci&#x00f3;n tiene la siguiente forma:"
+"El elemento <literal>&lt;cache&gt;</literal> de un mapeo de clase o "
+"colección tiene la siguiente forma:"
 
-#. Tag: programlisting
-#: performance.xml:698
-#, no-c-format
-msgid ""
-"<![CDATA[<cache \n"
-"    usage=\"transactional|read-write|nonstrict-read-write|read-only\"\n"
-"    region=\"RegionName\"\n"
-"    include=\"all|non-lazy\"\n"
-"/>]]>"
-msgstr ""
-"<![CDATA[<cache \n"
-"    usage=\"transactional|read-write|nonstrict-read-write|read-only\"\n"
-"/>]]>"
-
 #. Tag: para
-#: performance.xml:701
 #, no-c-format
 msgid ""
 "<literal>usage</literal> (required) specifies the caching strategy: "
 "<literal>transactional</literal>, <literal>read-write</literal>, "
 "<literal>nonstrict-read-write</literal> or <literal>read-only</literal>"
 msgstr ""
-"<literal>usage</literal> especifica la estrategia de caching: "
+"<literal>usage</literal> especifica la estrategia de caché: "
 "<literal>transactional</literal>, <literal>read-write</literal>, "
 "<literal>nonstrict-read-write</literal> o <literal>read-only</literal>"
 
 #. Tag: para
-#: performance.xml:710
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>region</literal> (optional: defaults to the class or collection "
 "role name): specifies the name of the second level cache region"
 msgstr ""
-"<literal>region</literal> (optional, defaults to the class or collection "
-"role name) specifies the name of the second level cache region"
+"<literal>region</literal> (opcional: por defecto es el nombre del rol de la "
+"clase o colección): especifica el nombre de la región de caché de segundo "
+"nivel."
 
 #. Tag: para
-#: performance.xml:717
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>include</literal> (optional: defaults to <literal>all</literal>) "
 "<literal>non-lazy</literal>: specifies that properties of the entity mapped "
 "with <literal>lazy=\"true\"</literal> cannot be cached when attribute-level "
 "lazy fetching is enabled"
 msgstr ""
-"<literal>include</literal> (optional, defaults to <literal>all</literal>) "
-"<literal>non-lazy</literal> specifies that properties of the entity mapped "
-"with <literal>lazy=\"true\"</literal> may not be cached when attribute-level "
-"lazy fetching is enabled"
+"<literal>include</literal> (opcional: por defecto es <literal>all</literal>) "
+"<literal>non-lazy</literal>: especifica que las propiedades de la entidad "
+"mapeadas con <literal>lazy=\"true\"</literal> no se pueden poner en caché "
+"cuando se habilita la recuperación perezoza a nivel de atributos."
 
 #. Tag: para
-#: performance.xml:727
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, you can specify <literal>&lt;class-cache&gt;</literal> and "
 "<literal>&lt;collection-cache&gt;</literal> elements in <literal>hibernate."
 "cfg.xml</literal>."
 msgstr ""
-"Alternativamente (&#x00bf;preferiblemente?), puedes especificar los "
-"elementos <literal>&lt;class-cache&gt;</literal> y <literal>&lt;collection-"
-"cache&gt;</literal> en <literal>hibernate.cfg.xml</literal>."
+"Opcionalmente, puede especificar los elementos <literal>&lt;class-cache&gt;</"
+"literal> y <literal>&lt;collection-cache&gt;</literal> en <literal>hibernate."
+"cfg.xml</literal>."
 
 #. Tag: para
-#: performance.xml:732
 #, no-c-format
 msgid ""
 "The <literal>usage</literal> attribute specifies a <emphasis>cache "
 "concurrency strategy</emphasis>."
 msgstr ""
 "El atributo <literal>usage</literal> especifica una <emphasis>estrategia de "
-"concurrencia al cach&#x00e9;</emphasis>."
+"concurrencia al caché</emphasis>."
 
 #. Tag: title
-#: performance.xml:739
 #, no-c-format
 msgid "Strategy: read only"
-msgstr "Estrategia: s&#x00f3;lo lectura (read only)"
+msgstr "Estrategia: sólo lectura"
 
 #. Tag: para
-#: performance.xml:741
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your application needs to read, but not modify, instances of a persistent "
 "class, a <literal>read-only</literal> cache can be used. This is the "
 "simplest and optimal performing strategy. It is even safe for use in a "
 "cluster."
 msgstr ""
-"Si tu aplicaci&#x00f3;n necesita leer pero nunca modificar las instancias de "
-"una clase persistente, puede usarse un cach&#x00e9; <literal>read-only</"
-"literal>. Esta es la mejor y m&#x00e1;s simple estrategia. Es incluso "
-"perfectamente segura de usar en un cluster."
+"Si su aplicación necesita leer pero no modificar las instancias de una clase "
+"persistente, puede utilizar un caché <literal>read-only</literal> (de sólo "
+"lectura). Esta es la mejor estrategia y la más simple. Incluso es totalmente "
+"segura para utilizar en un clúster."
 
-#. Tag: programlisting
-#: performance.xml:747
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Immutable\" mutable=\"false\">\n"
-"    <cache usage=\"read-only\"/>\n"
-"    ....\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"eg.Immutable\" mutable=\"false\">\n"
-"    <cache usage=\"read-only\"/>\n"
-"    ....\n"
-"</class>]]>"
-
 #. Tag: title
-#: performance.xml:753
 #, no-c-format
 msgid "Strategy: read/write"
 msgstr "Estrategia: lectura/escritura (read/write)"
 
 #. Tag: para
-#: performance.xml:755
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the application needs to update data, a <literal>read-write</literal> "
 "cache might be appropriate. This cache strategy should never be used if "
@@ -1689,51 +1316,26 @@
 "should ensure that the underlying cache implementation supports locking. The "
 "built-in cache providers <emphasis>do not</emphasis> support locking."
 msgstr ""
-"Si la aplicaci&#x00f3;n necesita actualizar datos, un cach&#x00e9; "
-"<literal>read-write</literal> podr&#x00ed;a ser apropiado. Esta estrategia "
-"de cach&#x00e9; nunca debe ser usada si se requiere nivel de aislamiento "
-"serializable de transacciones. Si el cach&#x00e9; es usado en un entorno "
-"JTA, debes especificar la propiedad <literal>hibernate.transaction."
-"manager_lookup_class</literal>, mencionando una estrategia para obtener el "
-"<literal>TransactionManager</literal> de JTA. En otros entornos, debes "
-"asegurarte que la transacci&#x00f3;n est&#x00e9; completada cuando se llame "
-"a <literal>Session.close()</literal> o <literal>Session.disconnect()</"
-"literal>. Si deseas usar esta estrategia en un cluster, debes asegurarte que "
-"la implementaci&#x00f3;n de cach&#x00e9; subyacente soporta bloqueos. Los "
-"provedores de cach&#x00e9; internos predeterminados <emphasis>no</emphasis> "
-"no lo soportan."
+"Si la aplicación necesita actualizar datos, un caché <literal>read-write</"
+"literal> puede ser apropiado. Esta estrategia de caché nunca se debe "
+"utilizar si se requiere un nivel de aislamiento serializable de "
+"transacciones. Si el caché se usa en un entorno JTA, tiene que especificar "
+"la propiedad <literal>hibernate.transaction.manager_lookup_class</literal>, "
+"mencionando una estrategia para obtener el <literal>TransactionManager</"
+"literal> de JTA. En otros entornos, debe asegurarse de que la transacción "
+"esté completada cuando se llame a <literal>Session.close()</literal> o "
+"<literal>Session.disconnect()</literal>. Si desea utilizar esta estrategia "
+"en un clúster, debe asegurarse de que la implementación de caché subyacente "
+"soporta bloqueos. Los provedores de caché internos <emphasis>no</emphasis> "
+"soportan bloqueos."
 
-#. Tag: programlisting
-#: performance.xml:766
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Cat\" .... >\n"
-"    <cache usage=\"read-write\"/>\n"
-"    ....\n"
-"    <set name=\"kittens\" ... >\n"
-"        <cache usage=\"read-write\"/>\n"
-"        ....\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"eg.Cat\" .... >\n"
-"    <cache usage=\"read-write\"/>\n"
-"    ....\n"
-"    <set name=\"kittens\" ... >\n"
-"        <cache usage=\"read-write\"/>\n"
-"        ....\n"
-"    </set>\n"
-"</class>]]>"
-
 #. Tag: title
-#: performance.xml:771
 #, no-c-format
 msgid "Strategy: nonstrict read/write"
-msgstr "Estrategia: lectura/escritura no estricta (nonstrict read/write)"
+msgstr "Estrategia: lectura/escritura no estricta"
 
 #. Tag: para
-#: performance.xml:773
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the application only occasionally needs to update data (i.e. if it is "
 "extremely unlikely that two transactions would try to update the same item "
@@ -1744,103 +1346,88 @@
 "should ensure that the transaction is completed when <literal>Session.close()"
 "</literal> or <literal>Session.disconnect()</literal> is called."
 msgstr ""
-"Si la aplicaci&#x00f3;n necesita s&#x00f3;lo ocasionalmente actualizar datos "
-"(es decir, es extremadamente inprobable que dos transacciones intenten "
-"actualizar el mismo &#x00ed;tem simult&#x00e1;neamente) y no se requiere de "
-"un aislamiento de transacciones estricto, un cach&#x00e9; <literal>nonstrict-"
-"read-write</literal> podr&#x00ed;a ser apropiado. Si se usa el cach&#x00e9; "
-"en un entorno JTA, debes especificar <literal>hibernate.transaction."
-"manager_lookup_class</literal>. En otros entornos, debes asegurarte que la "
-"transacci&#x00f3;n se haya completado cuando se llame a <literal>Session."
-"close()</literal> o <literal>Session.disconnect()</literal>."
+"Si la aplicación necesita sólo ocasionalmente actualizar datos (es decir, es "
+"extremadamente improbable que dos transacciones intenten actualizar el mismo "
+"ítem simultáneamente) y no se requiere de un aislamiento de transacciones "
+"estricto, un caché <literal>nonstrict-read-write</literal> podría ser "
+"apropiado. Si se utiliza el caché en un entorno JTA, tiene que especificar "
+"<literal>hibernate.transaction.manager_lookup_class</literal>. En otros "
+"entornos, debe asegurarse que se haya completado la transacción cuando se "
+"llame a <literal>Session.close()</literal> o <literal>Session.disconnect()</"
+"literal>."
 
 #. Tag: title
-#: performance.xml:785
 #, no-c-format
 msgid "Strategy: transactional"
 msgstr "Estrategia: transaccional"
 
 #. Tag: para
-#: performance.xml:787
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>transactional</literal> cache strategy provides support for "
 "fully transactional cache providers such as JBoss TreeCache. Such a cache "
 "can only be used in a JTA environment and you must specify "
 "<literal>hibernate.transaction.manager_lookup_class</literal>."
 msgstr ""
-"La estrategia de cach&#x00e9; <literal>transactional</literal> brinda "
-"soporte a provedores de cach&#x00e9;s completamente transaccionales como "
-"TreeCache de JBoss. Un cach&#x00e9; as&#x00ed;, puede s&#x00f3;lo ser usado "
-"en un entorno JTA y debes especificar <literal>hibernate.transaction."
-"manager_lookup_class</literal>."
+"La estrategia de caché <literal>transactional</literal> brinda soporte a "
+"provedores de cachés completamente transaccionales como JBoss TreeCache. Un "
+"caché así, sólo se puede utilizar en un entorno JTA y tiene que especificar "
+"<literal>hibernate.transaction.manager_lookup_class</literal>."
 
 #. Tag: title
-#: performance.xml:796
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Cache-provider/concurrency-strategy compatibility"
-msgstr "Soporte a Estrategia de Concurrencia a Cach&#x00e9;"
+msgstr "Compatibilidad de proveedor de caché/estrategia de concurrencia"
 
 #. Tag: para
-#: performance.xml:799
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "None of the cache providers support all of the cache concurrency strategies."
 msgstr ""
-"Ninguno de los provedores de cach&#x00e9; soporta todas las estrategias de "
-"concurrencia al cach&#x00e9;. La siguiente tabla muestra qu&#x00e9; "
-"provedores son compatibles con qu&#x00e9; estrategias de concurrencia."
+"Ninguno de los provedores de caché soporta todas las estrategias de "
+"concurrencia al caché. "
 
 #. Tag: para
-#: performance.xml:804
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table shows which providers are compatible with which "
 "concurrency strategies."
 msgstr ""
-"Ninguno de los provedores de cach&#x00e9; soporta todas las estrategias de "
-"concurrencia al cach&#x00e9;. La siguiente tabla muestra qu&#x00e9; "
-"provedores son compatibles con qu&#x00e9; estrategias de concurrencia."
+"La siguiente tabla muestra qué provedores son compatibles con qué "
+"estrategias de concurrencia."
 
 #. Tag: title
-#: performance.xml:809
 #, no-c-format
 msgid "Cache Concurrency Strategy Support"
-msgstr "Soporte a Estrategia de Concurrencia a Cach&#x00e9;"
+msgstr "Soporte a Estrategia de Concurrencia a Caché"
 
 #. Tag: entry
-#: performance.xml:819
 #, no-c-format
 msgid "read-only"
 msgstr "read-only"
 
 #. Tag: entry
-#: performance.xml:820
 #, no-c-format
 msgid "nonstrict-read-write"
 msgstr "nonstrict-read-write"
 
 #. Tag: entry
-#: performance.xml:821
 #, no-c-format
 msgid "read-write"
 msgstr "read-write"
 
 #. Tag: entry
-#: performance.xml:822
 #, no-c-format
 msgid "transactional"
 msgstr "transactional"
 
 #. Tag: title
-#: performance.xml:877
 #, no-c-format
 msgid "Managing the caches"
-msgstr "Gestionando los cach&#x00e9;s"
+msgstr "Gestión de cachés"
 
 #. Tag: para
-#: performance.xml:879
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Whenever you pass an object to <literal>save()</literal>, <literal>update()</"
 "literal> or <literal>saveOrUpdate()</literal>, and whenever you retrieve an "
@@ -1849,16 +1436,15 @@
 "</literal>, that object is added to the internal cache of the "
 "<literal>Session</literal>."
 msgstr ""
-"Siempre que pases un objeto a <literal>save()</literal>, <literal>update()</"
-"literal> o <literal>saveOrUpdate()</literal> y siempre que recuperes un "
-"objeto usando <literal>load()</literal>, <literal>get()</literal>, "
+"Siempre que pase un objeto a <literal>save()</literal>, <literal>update()</"
+"literal> o <literal>saveOrUpdate()</literal> y siempre que recupere un "
+"objeto utilizando <literal>load()</literal>, <literal>get()</literal>, "
 "<literal>list()</literal>, <literal>iterate()</literal> o <literal>scroll()</"
-"literal>, ese objeto es agregado al cach&#x00e9; interno de la "
-"<literal>Session</literal>."
+"literal>, ese objeto se agrega al caché interno de la <literal>Session</"
+"literal>."
 
 #. Tag: para
-#: performance.xml:886
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When <literal>flush()</literal> is subsequently called, the state of that "
 "object will be synchronized with the database. If you do not want this "
@@ -1867,350 +1453,284 @@
 "can be used to remove the object and its collections from the first-level "
 "cache."
 msgstr ""
-"Cuando subsecuentemente se llame a <literal>flush()</literal>, el estado de "
-"ese objeto ser&#x00e1; sincronizado con la base de datos. Si no quieres que "
-"ocurra esta sincronizaci&#x00f3;n o si est&#x00e1;s procesando un n&#x00fa;"
-"mero enorme de objetos y necesitas gestionar la memoria eficientemente, "
-"puede usarse el m&#x00e9;todo <literal>evict()</literal> para quitar el "
-"objeto y sus colecciones del cach&#x00e9; de primer nivel."
+"Cuando luego se llame a <literal>flush()</literal>, el estado de ese objeto "
+"será sincronizado con la base de datos. Si no quiere que ocurra esta "
+"sincronización o si está procesando un número enorme de objetos y necesita "
+"gestionar la memoria eficientemente, puede utilizar el método <literal>evict"
+"()</literal> para quitar el objeto y sus colecciones del caché de primer "
+"nivel. "
 
-#. Tag: programlisting
-#: performance.xml:894
-#, no-c-format
-msgid ""
-"<![CDATA[ScrollableResult cats = sess.createQuery(\"from Cat as cat\").scroll"
-"(); //a huge result set\n"
-"while ( cats.next() ) {\n"
-"    Cat cat = (Cat) cats.get(0);\n"
-"    doSomethingWithACat(cat);\n"
-"    sess.evict(cat);\n"
-"}]]>"
-msgstr ""
-"<![CDATA[ScrollableResult cats = sess.createQuery(\"from Cat as cat\").scroll"
-"(); //a huge result set\n"
-"while ( cats.next() ) {\n"
-"    Cat cat = (Cat) cats.get(0);\n"
-"    doSomethingWithACat(cat);\n"
-"    sess.evict(cat);\n"
-"}]]>"
-
 #. Tag: para
-#: performance.xml:896
 #, no-c-format
 msgid ""
 "The <literal>Session</literal> also provides a <literal>contains()</literal> "
 "method to determine if an instance belongs to the session cache."
 msgstr ""
-"La <literal>Session</literal> tambi&#x00e9;n provee un m&#x00e9;todo "
-"<literal>contains()</literal> para determinar si una instancia pertenece al "
-"cach&#x00e9; de la sesi&#x00f3;n."
+"La <literal>Session</literal> también proporciona un método <literal>contains"
+"()</literal> para determinar si una instancia pertenece al caché de la "
+"sesión."
 
 #. Tag: para
-#: performance.xml:901
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To evict all objects from the session cache, call <literal>Session.clear()</"
 "literal>"
 msgstr ""
-"Para desahuciar (evict) todos los objetos del cach&#x00e9; de sesi&#x00f3;n, "
-"llama a <literal>Session.clear()</literal>."
+"Para expulsar todos los objetos del caché de sesión, llame a "
+"<literal>Session.clear()</literal>. "
 
 #. Tag: para
-#: performance.xml:905
 #, no-c-format
 msgid ""
 "For the second-level cache, there are methods defined on "
 "<literal>SessionFactory</literal> for evicting the cached state of an "
 "instance, entire class, collection instance or entire collection role."
 msgstr ""
-"Para el cach&#x00e9; de segundo nivel, hay m&#x00e9;todos definidos en "
-"<literal>SessionFactory</literal> para desahuciar el estado en cach&#x00e9; "
-"de una instancia, clase entera, instancia de colecci&#x00f3;n o rol enter de "
-"colecci&#x00f3;n."
+"Para el caché de segundo nivel, hay métodos definidos en "
+"<literal>SessionFactory</literal> para explusar el estado en caché de una "
+"instancia, clase entera, instancia de colección o rol entero de colección."
 
-#. Tag: programlisting
-#: performance.xml:911
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sessionFactory.evict(Cat.class, catId); //evict a particular Cat\n"
-"sessionFactory.evict(Cat.class);  //evict all Cats\n"
-"sessionFactory.evictCollection(\"Cat.kittens\", catId); //evict a particular "
-"collection of kittens\n"
-"sessionFactory.evictCollection(\"Cat.kittens\"); //evict all kitten "
-"collections]]>"
-msgstr ""
-"<![CDATA[sessionFactory.evict(Cat.class, catId); //evict a particular Cat\n"
-"sessionFactory.evict(Cat.class);  //evict all Cats\n"
-"sessionFactory.evictCollection(\"Cat.kittens\", catId); //evict a particular "
-"collection of kittens\n"
-"sessionFactory.evictCollection(\"Cat.kittens\"); //evict all kitten "
-"collections]]>"
-
-#. Tag: para
-#: performance.xml:913
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>CacheMode</literal> controls how a particular session interacts "
 "with the second-level cache:"
 msgstr ""
-"El <literal>CacheMode</literal> controla c&#x00f3;mo una sesi&#x00f3;n en "
-"particular interact&#x00fa;a con el cach&#x00e9; de segundo nivel."
+"El <literal>CacheMode</literal> controla la manera en que interactúa una "
+"sesión en particular con el caché de segundo nivel:"
 
 #. Tag: para
-#: performance.xml:920
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.NORMAL</literal>: will read items from and write items to "
 "the second-level cache"
 msgstr ""
-"<literal>CacheMode.NORMAL</literal> - lee &#x00ed;tems desde y escribe "
-"&#x00ed;tems hacia el cach&#x00e9; de segundo nivel"
+"<literal>CacheMode.NORMAL</literal>: lee ítems desde y escribe ítems hacia "
+"el caché del segundo nivel"
 
 #. Tag: para
-#: performance.xml:925
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.GET</literal>: will read items from the second-level "
 "cache. Do not write to the second-level cache except when updating data"
 msgstr ""
-"<literal>CacheMode.GET</literal> - lee &#x00ed;tems del cach&#x00e9; de "
-"segundo nivel, pero no escribe al cach&#x00e9; de segundo nivel excepto al "
-"actualizar datos"
+"<literal>CacheMode.GET</literal>: lee ítems del caché del segundo nivel. No "
+"escribe al caché de segundo nivel excepto cuando actualiza datos"
 
 #. Tag: para
-#: performance.xml:931
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.PUT</literal>: will write items to the second-level "
 "cache. Do not read from the second-level cache"
 msgstr ""
-"<literal>CacheMode.PUT</literal> - escribe &#x00ed;tems al cach&#x00e9; de "
-"segundo nivel, pero no lee del cach&#x00e9; de segundo nivel"
+"<literal>CacheMode.PUT</literal>: escribe ítems al caché de segundo nivel. "
+"No lee del caché de segundo nivel"
 
 #. Tag: para
-#: performance.xml:937
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.REFRESH</literal>: will write items to the second-level "
 "cache. Do not read from the second-level cache. Bypass the effect of "
 "<literal>hibernate.cache.use_minimal_puts</literal> forcing a refresh of the "
 "second-level cache for all items read from the database"
 msgstr ""
-"<literal>CacheMode.REFRESH</literal> - escribe &#x00ed;tems al cach&#x00e9; "
-"de segundo nivel, pero no lee del cach&#x00e9; de segundo nivel, salt&#x00e1;"
-"ndose el efecto de <literal>hibernate.cache.use_minimal_puts</literal>, "
-"forzando un refresco del cach&#x00e9; de segundo nivel para todos los "
-"&#x00ed;tems le&#x00ed;dos de la base de datos"
+"<literal>CacheMode.REFRESH</literal>: escribe ítems al caché de segundo "
+"nivel. No lee del caché de segundo nivel, saltándose el efecto de "
+"<literal>hibernate.cache.use_minimal_puts</literal>, forzando la "
+"actualización del caché de segundo nivel para todos los ítems leídos de la "
+"base de datos"
 
 #. Tag: para
-#: performance.xml:945
 #, no-c-format
 msgid ""
 "To browse the contents of a second-level or query cache region, use the "
 "<literal>Statistics</literal> API:"
 msgstr ""
-"Para navegar por los contenidos de una regi&#x00f3;n de cach&#x00e9; de "
-"segundo nivel o de consultas, usa la API de <literal>Statistics</literal>:"
+"Para navegar por los contenidos de una región de caché de segundo nivel o de "
+"consultas, use la API de <literal>Statistics</literal>:"
 
-#. Tag: programlisting
-#: performance.xml:950
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Map cacheEntries = sessionFactory.getStatistics()\n"
-"        .getSecondLevelCacheStatistics(regionName)\n"
-"        .getEntries();]]>"
+"You will need to enable statistics and, optionally, force Hibernate to keep "
+"the cache entries in a more readable format:"
 msgstr ""
-"<![CDATA[Map cacheEntries = sessionFactory.getStatistics()\n"
-"        .getSecondLevelCacheStatistics(regionName)\n"
-"        .getEntries();]]>"
+"Necesitará habilitar las estadísticas y, opcionalmente, forzar a Hibernate "
+"para que guarde las entradas del caché en un formato más fácil de entender "
+"para humanos: "
 
+#. Tag: title
+#, no-c-format
+msgid "The Query Cache"
+msgstr "El Caché de Consultas"
+
 #. Tag: para
-#: performance.xml:952
 #, fuzzy, no-c-format
 msgid ""
-"You will need to enable statistics and, optionally, force Hibernate to keep "
-"the cache entries in a more readable format:"
+"Query result sets can also be cached. This is only useful for queries that "
+"are run frequently with the same parameters."
 msgstr ""
-"Necesitar&#x00e1;s habilitar las estad&#x00ed;sticas y, opcionalmente, "
-"forzar a Hibernate para que guarde las entradas del cach&#x00e9; en un "
-"formato m&#x00e1;s entendible por humanos:"
+"Los conjuntos de resultados de peticiones también pueden ponerse en caché. "
+"Esto sólamente es útil para consultas que se ejecutan frecuentemente con los "
+"mismos parámetros. Para utilizar el caché de consultas primero tiene que "
+"habilitarlo:"
 
-#. Tag: programlisting
-#: performance.xml:957
+#. Tag: title
 #, no-c-format
+msgid "Enabling query caching"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
 msgid ""
-"<![CDATA[hibernate.generate_statistics true\n"
-"hibernate.cache.use_structured_entries true]]>"
+"Caching of query results introduces some overhead in terms of your "
+"applications normal transactional processing. For example, if you cache "
+"results of a query against Person Hibernate will need to keep track of when "
+"those results should be invalidated because changes have been committed "
+"against Person. That, coupled with the fact that most applications simply "
+"gain no benefit from caching query results, leads Hibernate to disable "
+"caching of query results by default. To use query caching, you will first "
+"need to enable the query cache:"
 msgstr ""
-"<![CDATA[hibernate.generate_statistics true\n"
-"hibernate.cache.use_structured_entries true]]>"
 
-#. Tag: title
-#: performance.xml:962
+#. Tag: para
 #, no-c-format
-msgid "The Query Cache"
-msgstr "El Cach&#x00e9; de Consultas"
+msgid "This setting creates two new cache regions:"
+msgstr ""
 
 #. Tag: para
-#: performance.xml:964
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"Query result sets can also be cached. This is only useful for queries that "
-"are run frequently with the same parameters. You will first need to enable "
-"the query cache:"
+"<classname>org.hibernate.cache.StandardQueryCache</classname>, holding the "
+"cached query results"
 msgstr ""
-"Los conjuntos resultado de consultas tambi&#x00e9;n pueden tratarse en "
-"cach&#x00e9;. Esto s&#x00f3;lo es &#x00fa;til para consultas que se ejecutan "
-"frecuentemente con los mismos par&#x00e1;metros. Para usar el cach&#x00e9; "
-"de consultas primero debes habilitarlo:"
 
-#. Tag: programlisting
-#: performance.xml:969
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[hibernate.cache.use_query_cache true]]>"
-msgstr "<![CDATA[hibernate.cache.use_query_cache true]]>"
+msgid ""
+"<classname>org.hibernate.cache.UpdateTimestampsCache</classname>, holding "
+"timestamps of the most recent updates to queryable tables. These are used to "
+"validate the results as they are served from the query cache."
+msgstr ""
 
 #. Tag: para
-#: performance.xml:971
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"This setting creates two new cache regions: one holding cached query result "
-"sets (<literal>org.hibernate.cache.StandardQueryCache</literal>), the other "
-"holding timestamps of the most recent updates to queryable tables "
-"(<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). Note that "
-"the query cache does not cache the state of the actual entities in the "
-"result set; it caches only identifier values and results of value type. The "
-"query cache should always be used in conjunction with the second-level cache."
+"If you configure your underlying cache implementation to use expiry or "
+"timeouts is is very important that the cache timeout of the underlying cache "
+"region for the UpdateTimestampsCache be set to a higher value than the "
+"timeouts of any of the query caches. In fact, we recommend that the the "
+"UpdateTimestampsCache region not be configured for expiry at all. Note, in "
+"particular, that an LRU cache expiry policy is never appropriate."
 msgstr ""
-"Esta configuraci&#x00f3;n causa la creaci&#x00f3;n de dos nuevas regiones de "
-"cach&#x00e9; - una teniendo en cach&#x00e9; conjuntos resultado de consulta "
-"(<literal>org.hibernate.cache.StandardQueryCache</literal>), el otro "
-"teniendo timestamps de las actualizaciones m&#x00e1;s recientes a tablas "
-"consultables (<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). "
-"Nota que el cach&#x00e9; de consultas no pone en cach&#x00e9; el estado de "
-"las entidades reales en el conjunto resultado; s&#x00f3;lo tiene en "
-"cach&#x00e9; valores indentificadores y resultados de tipo de valor. De modo "
-"que el cach&#x00e9; de consultas siempre debe ser usado en conjunci&#x00f3;n "
-"con el cach&#x00e9; de segundo nivel."
 
 #. Tag: para
-#: performance.xml:981
 #, fuzzy, no-c-format
 msgid ""
-"Most queries do not benefit from caching, so by default, queries are not "
-"cached. To enable caching, call <literal>Query.setCacheable(true)</literal>. "
-"This call allows the query to look for existing cache results or add its "
-"results to the cache when it is executed."
+"As mentioned above, most queries do not benefit from caching or their "
+"results. So by default, individual queries are not cached even after "
+"enabling query caching. To enable results caching for a particular query, "
+"call <literal>org.hibernate.Query.setCacheable(true)</literal>. This call "
+"allows the query to look for existing cache results or add its results to "
+"the cache when it is executed."
 msgstr ""
-"La mayor&#x00ed;a de consultas no se benefician del tratamiento en "
-"cach&#x00e9;, de modo que por defecto las consultas no son tratadas en "
-"cach&#x00e9;. Para habilitar el tratamiento en cach&#x00e9;, llama a "
-"<literal>Query.setCacheable(true)</literal>. Esta llamada permite a la "
-"consulta buscar resultados existentes en cach&#x00e9; o agregar sus "
-"resultados al cach&#x00e9; cuando se ejecuta."
+"La mayoría de consultas no se benefician del caché, de modo que por defecto "
+"las consultas no se ponen en caché. Para habilitar el caché, llame a "
+"<literal>Query.setCacheable(true)</literal>. Esta llamada permite que la "
+"consulta busque resultados existentes en caché o que agregue sus resultados "
+"al caché cuando se ejecuta."
 
 #. Tag: para
-#: performance.xml:988
+#, no-c-format
+msgid ""
+"The query cache does not cache the state of the actual entities in the "
+"cache; it caches only identifier values and results of value type. For this "
+"reaso, the query cache should always be used in conjunction with the second-"
+"level cache for those entities expected to be cached as part of a query "
+"result cache (just as with collection caching)."
+msgstr ""
+
+#. Tag: title
 #, fuzzy, no-c-format
+msgid "Query cache regions"
+msgstr "Caché de Consultas Soportado"
+
+#. Tag: para
+#, no-c-format
 msgid ""
 "If you require fine-grained control over query cache expiration policies, "
 "you can specify a named cache region for a particular query by calling "
 "<literal>Query.setCacheRegion()</literal>."
 msgstr ""
-"Si requieres un control finamente granularizado sobre las pol&#x00ed;ticas "
-"de expiraci&#x00f3;n del cach&#x00e9; de consultas, puedes especificar una "
-"regi&#x00f3;n de cach&#x00e9; con nombre para una consulta en particular "
-"llamando a <literal>Query.setCacheRegion()</literal>."
+"Si necesita un control muy detallado sobre las políticas de expiración del "
+"caché de consultas, puede especificar una región de caché con nombre para "
+"una consulta en particular llamando a <literal>Query.setCacheRegion()</"
+"literal>."
 
-#. Tag: programlisting
-#: performance.xml:994
-#, no-c-format
-msgid ""
-"<![CDATA[List blogs = sess.createQuery(\"from Blog blog where blog.blogger "
-"= :blogger\")\n"
-"    .setEntity(\"blogger\", blogger)\n"
-"    .setMaxResults(15)\n"
-"    .setCacheable(true)\n"
-"    .setCacheRegion(\"frontpages\")\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List blogs = sess.createQuery(\"from Blog blog where blog.blogger "
-"= :blogger\")\n"
-"    .setEntity(\"blogger\", blogger)\n"
-"    .setMaxResults(15)\n"
-"    .setCacheable(true)\n"
-"    .setCacheRegion(\"frontpages\")\n"
-"    .list();]]>"
-
 #. Tag: para
-#: performance.xml:996
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"If the query should force a refresh of its query cache region, you should "
-"call <literal>Query.setCacheMode(CacheMode.REFRESH)</literal>. This is "
-"particularly useful in cases where underlying data may have been updated via "
-"a separate process (i.e., not modified through Hibernate) and allows the "
-"application to selectively refresh particular query result sets. This is a "
-"more efficient alternative to eviction of a query cache region via "
-"<literal>SessionFactory.evictQueries()</literal>."
+"If you want to force the query cache to refresh one of its regions "
+"(disregard any cached results it finds there) you can use <literal>org."
+"hibernate.Query.setCacheMode(CacheMode.REFRESH)</literal>. In conjunction "
+"with the region you have defined for the given query, Hibernate will "
+"selectively force the results cached in that particular region to be "
+"refreshed. This is particularly useful in cases where underlying data may "
+"have been updated via a separate process and is a far more efficient "
+"alternative to bulk eviction of the region via <literal>org.hibernate."
+"SessionFactory.evictQueries()</literal>."
 msgstr ""
-"Si la consulta debe forzar un refresco de si regi&#x00f3;n del cach&#x00e9; "
-"de consultas, debes llamar a <literal>Query.setCacheMode(CacheMode.REFRESH)</"
-"literal>. Esto es particularmente &#x00fa;til en casos donde los datos "
-"subyacentes pueden haber sido actualizados por medio de un proceso separado "
-"(es decir, no modificados a trav&#x00e9;s de Hibernate) y permite a la "
-"aplicaci&#x00f3;n refrescar selectivamente conjuntos resultado de consultas "
-"en particular. Esto es una alternativa m&#x00e1;s eficient al "
-"desahuciamiento de una regi&#x00f3;n del cach&#x00e9; de consultas v&#x00ed;"
-"a <literal>SessionFactory.evictQueries()</literal>."
+"Si la consulta debe forzar un refresco de su región del caché de consultas, "
+"usteddebe llamar a <literal>Query.setCacheMode(CacheMode.REFRESH)</literal>. "
+"Esto es particularmente útil en casos donde los datos subyacentes pueden "
+"haber sido actualizados por medio de un proceso separado (es decir, no "
+"modificados a través de Hibernate) y permite a la aplicación refrescar "
+"selectivamente conjuntos resultado de consultas en particular. Esto es una "
+"alternativa más eficient que que expulsión de una región del caché de "
+"consultas vía <literal>SessionFactory.evictQueries()</literal>."
 
 #. Tag: title
-#: performance.xml:1008
 #, no-c-format
 msgid "Understanding Collection performance"
-msgstr "Entendiendo el rendimiento de Colecciones"
+msgstr "Comprensión del rendimiento de Colecciones"
 
 #. Tag: para
-#: performance.xml:1010
 #, no-c-format
 msgid ""
 "In the previous sections we have covered collections and their applications. "
 "In this section we explore some more issues in relation to collections at "
 "runtime."
 msgstr ""
+"En las secciones anteriores hemos abordado las colecciones y sus "
+"aplicaciones. En esta sección exploramos algunos puntos en relación con las "
+"colecciones en tiempo de ejecución. "
 
 #. Tag: title
-#: performance.xml:1017
 #, no-c-format
 msgid "Taxonomy"
-msgstr "Taxonomia"
+msgstr "Taxonomía"
 
 #. Tag: para
-#: performance.xml:1019
 #, no-c-format
 msgid "Hibernate defines three basic kinds of collections:"
-msgstr "Hibernate define tres tipos b&#x00e1;sicos de colecciones:"
+msgstr "Hibernate define tres tipos básicos de colecciones:"
 
 #. Tag: para
-#: performance.xml:1023
 #, no-c-format
 msgid "collections of values"
 msgstr "colecciones de valores"
 
 #. Tag: para
-#: performance.xml:1026
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "one-to-many associations"
-msgstr "asociaciones uno a muchos"
+msgstr "Asociaciones uno-a-muchos "
 
 #. Tag: para
-#: performance.xml:1029
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "many-to-many associations"
-msgstr "asociaciones muchos a muchos"
+msgstr "Aociaciones muchos-a-muchos"
 
 #. Tag: para
-#: performance.xml:1033
 #, no-c-format
 msgid ""
 "This classification distinguishes the various table and foreign key "
@@ -2220,35 +1740,30 @@
 "primary key that is used by Hibernate to update or delete collection rows. "
 "This suggests the following classification:"
 msgstr ""
-"Esta clasificaci&#x00f3;n distingue las varias tablas y relaciones de clave "
-"for&#x00e1;nea pero no nos dice absolutamente todo lo que necesitamos saber "
-"sobre el modelo relacional. Para entender completamente la estructura "
-"relacional y las caracter&#x00ed;sticas de rendimiento, debemos considerar "
-"la estructura de la clave primaria que es usada por Hibernate para "
-"actualizar o borrar filas de colecci&#x00f3;n. Esto sugiere la siguiente "
-"clasificaci&#x00f3;n:"
+"Esta clasificación distingue las varias tablas y relaciones de clave foránea "
+"pero no nos dice absolutamente todo lo que necesitamos saber sobre el modelo "
+"relacional. Para entender completamente la estructura relacional y las "
+"características de rendimiento, debemos considerar la estructura de la clave "
+"primaria que Hibernate utiliza para actualizar o borrar filas de colección. "
+"Esto sugiere la siguiente clasificación:"
 
 #. Tag: para
-#: performance.xml:1044
 #, no-c-format
 msgid "indexed collections"
 msgstr "colecciones indexadas"
 
 #. Tag: para
-#: performance.xml:1047
 #, no-c-format
 msgid "sets"
 msgstr "conjuntos (sets)"
 
 #. Tag: para
-#: performance.xml:1050
 #, no-c-format
 msgid "bags"
 msgstr "bolsas (bags)"
 
 #. Tag: para
-#: performance.xml:1054
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All indexed collections (maps, lists, and arrays) have a primary key "
 "consisting of the <literal>&lt;key&gt;</literal> and <literal>&lt;index&gt;</"
@@ -2256,16 +1771,15 @@
 "The primary key can be efficiently indexed and a particular row can be "
 "efficiently located when Hibernate tries to update or delete it."
 msgstr ""
-"Todas las colecciones indexadas (mapas, listas, arrays) tienen una clave "
-"primaria consistente de las columnas <literal>&lt;key&gt;</literal> y "
+"Todas las colecciones indexadas (mapas, listas y arrays) tienen una clave "
+"principal que consiste de las columnas <literal>&lt;key&gt;</literal> e "
 "<literal>&lt;index&gt;</literal>. En este caso las actualizaciones de "
-"colecciones son usualmente extremadamente eficientes. La clave primaria "
-"puede ser indexada f&#x00e1;cilmente y una fila en particular puede ser "
-"localizada cuando Hibernate intenta actualizarla o borrarla."
+"colecciones son extremadamente eficientes. La clave principal puede ser "
+"indexada eficientemente y una fila en particular puede ser localizada cuando "
+"Hibernate intenta actualizarla o borrarla."
 
 #. Tag: para
-#: performance.xml:1062
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sets have a primary key consisting of <literal>&lt;key&gt;</literal> and "
 "element columns. This can be less efficient for some types of collection "
@@ -2277,21 +1791,19 @@
 "<literal>&lt;set&gt;</literal>, you must declare all columns as <literal>not-"
 "null=\"true\"</literal>."
 msgstr ""
-"Los conjuntos (sets) tienen una clave primaria consistente en <literal>&lt;"
-"key&gt;</literal> y columnas de elemento. Esto puede ser menos eficiente "
-"para algunos tipos de elemento de colecci&#x00f3;n, particularmente "
-"elementos compuestos o texto largo, o campos binarios. La base de datos "
-"puede no ser capaz de indexar una clave primaria compleja eficientemente. "
-"Por otra parte, para asociaciones uno a muchos o muchos a muchos, "
-"particularmente en el caso de identificadores sint&#x00e9;ticos, es probable "
-"que s&#x00f3;lo sea tan eficiente. (Nota al m&#x00e1;rgen: si quieres que "
-"<literal>SchemaExport</literal> realmente cree la clave primaria de un "
-"<literal>&lt;set&gt;</literal> por ti, debes declarar todas las columnas "
-"como <literal>not-null=\"true\"</literal>.)"
+"Los conjuntos tienen una clave principal que consiste de <literal>&lt;key&gt;"
+"</literal> y columnas de elementos. Esto puede ser menos eficiente para "
+"algunos tipos de elementos de colección, particularmente elementos "
+"compuestos o texto largo o campos binarios ya que la base de datos puede no "
+"ser capaz de indexar una clave principal compleja eficientemente. Sin "
+"embargo, para asociaciones uno a muchos o muchos a muchos, particularmente "
+"en el caso de los identificadores sintéticos, es probable que sólo sea igual "
+"de eficiente. Si quiere que <literal>SchemaExport</literal> realmente cree "
+"la clave principal de un <literal>&lt;set&gt;</literal>, tiene que declarar "
+"todas las columnas como <literal>not-null=\"true\"</literal>."
 
 #. Tag: para
-#: performance.xml:1073
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>&lt;idbag&gt;</literal> mappings define a surrogate key, so they "
 "are efficient to update. In fact, they are the best case."
@@ -2301,8 +1813,7 @@
 "mejor caso."
 
 #. Tag: para
-#: performance.xml:1078
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Bags are the worst case since they permit duplicate element values and, as "
 "they have no index column, no primary key can be defined. Hibernate has no "
@@ -2310,53 +1821,47 @@
 "problem by completely removing in a single <literal>DELETE</literal> and "
 "recreating the collection whenever it changes. This can be inefficient."
 msgstr ""
-"Los bags son el peor caso. Ya que un bag permite valores de elementos "
-"duplicados y no tiene ninguna columna &#x00ed;ndice, no puede definirse "
-"ninguna clave primaria. Hibernate no tiene forma de distinguir entre filas "
-"duplicadas. Hibernate resuelve este problema quitando completamente (en un "
-"solo <literal>DELETE</literal>) y recreando la colecci&#x00f3;n siempre que "
-"cambia. Esto podr&#x00ed;a ser muy ineficiente."
+"Los bags son el peor caso ya que un bag permite valores de elementos "
+"duplicados y no tiene ninguna columna índice, no puede definirse ninguna "
+"clave principal. Hibernate no tiene forma de distinguir entre filas "
+"duplicadas. Hibernate resuelve este problema quitando por completo con un "
+"sólo <literal>DELETE</literal> y recreando la colección siempre que cambia. "
+"Esto puede ser muy ineficiente."
 
 #. Tag: para
-#: performance.xml:1086
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For a one-to-many association, the \"primary key\" may not be the physical "
 "primary key of the database table. Even in this case, the above "
 "classification is still useful. It reflects how Hibernate \"locates\" "
 "individual rows of the collection."
 msgstr ""
-"Nota que para una asociaci&#x00f3;n uno-a-muchos, la \"clave primaria\" "
-"puede no ser la clave primaria f&#x00ed;sica de la tabla de base de datos; "
-"pero incluso en este caso, la clasificaci&#x00f3;n anterior es &#x00fa;til "
-"todav&#x00ed;a. (A&#x00fa;n refleja c&#x00f3;mo Hibernate \"localiza\" filas "
-"individuales de la colecci&#x00f3;n.)"
+"Para una asociación uno-a-muchos, la \"clave principal\" puede no ser la "
+"clave principal física de la tabla de la base de datos. Incluso en este "
+"caso, la clasificación anterior es útil todavía. Refleja cómo Hibernate "
+"\"localiza\" filas individuales de la colección."
 
 #. Tag: title
-#: performance.xml:1096
 #, no-c-format
 msgid ""
 "Lists, maps, idbags and sets are the most efficient collections to update"
 msgstr ""
-"Las listas, mapas, idbags y conjuntos son las colecciones m&#x00e1;s "
-"eficientes de actualizar"
+"Las listas, mapas, idbags y conjuntos son las colecciones más eficientes de "
+"actualizar"
 
 #. Tag: para
-#: performance.xml:1098
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "From the discussion above, it should be clear that indexed collections and "
 "sets allow the most efficient operation in terms of adding, removing and "
 "updating elements."
 msgstr ""
-"Desde la discusi&#x00f3;n anterior, debe quedar claro que las colecciones "
-"indexadas y (usualmente) los conjuntos permiten la operaci&#x00f3;n m&#x00e1;"
-"s eficiente en t&#x00e9;rminos de a&#x00f1;adir, quitar y actualizar "
-"elementos."
+"De la discusión anterior, debe quedar claro que las colecciones indexadas y "
+"los conjuntos permiten una operación más eficiente en términos de agregar, "
+"quitar y actualizar elementos."
 
 #. Tag: para
-#: performance.xml:1104
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is, arguably, one more advantage that indexed collections have over "
 "sets for many-to-many associations or collections of values. Because of the "
@@ -2366,18 +1871,17 @@
 "literal> of individual rows. Once again, this consideration does not apply "
 "to one-to-many associations."
 msgstr ""
-"Hay, discutiblemente, una ventaja m&#x00e1;s que las colecciones indexadas "
-"tienen sobre otros conjuntos para las asociaciones muchos a muchos o "
-"colecciones de valores. Debido a la estructura de un <literal>Set</literal>, "
-"Hibernate ni siquiera actualiza una fila con <literal>UPDATE</literal> "
-"cuando se \"cambia\" un elemento. Los cambios a un <literal>Set</literal> "
-"siempre funcionan por medio de <literal>INSERT</literal> y <literal>DELETE</"
-"literal> (de filas individuales). Una vez m&#x00e1;s, esta "
-"consideraci&#x00f3;n no se aplica a las asociaciones uno a muchos."
+"Discutiblemente, hay una ventaja más de las colecciones indexadas sobre "
+"otros conjuntos para las asociaciones muchos a muchos o colecciones de "
+"valores. Debido a la estructura de un <literal>Set</literal>, Hibernate ni "
+"siquiera actualiza una fila con <literal>UPDATE</literal> cuando se \"cambia"
+"\" un elemento. Los cambios a un <literal>Set</literal> siempre funcionan "
+"por medio de <literal>INSERT</literal> y <literal>DELETE</literal> de filas "
+"individuales. Una vez más, esta consideración no se aplica a las "
+"asociaciones uno a muchos."
 
 #. Tag: para
-#: performance.xml:1113
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "After observing that arrays cannot be lazy, you can conclude that lists, "
 "maps and idbags are the most performant (non-inverse) collection types, with "
@@ -2385,17 +1889,15 @@
 "collection in Hibernate applications. This is because the \"set\" semantics "
 "are most natural in the relational model."
 msgstr ""
-"Despu&#x00e9;s de observar que los arrays no pueden ser perezosos, "
-"podr&#x00ed;amos concluir que las listas, mapas e idbags son los tipos "
-"m&#x00e1;s eficientes de colecciones (no inversas), con los conjuntos (sets) "
-"no muy por detr&#x00e1;s. Se espera que los sets sean el tipo m&#x00e1;s "
-"com&#x00fa;n de colecci&#x00f3;n en las aplicaciones de Hibernate. Esto es "
-"debido a que la sem&#x00e1;ntica de los sets es la m&#x00e1;s natural en el "
-"modelo relacional."
+"Después de observar que los arrays no pueden ser perezosos, podríamos "
+"concluir que las listas, mapas e idbags son los tipos más eficientes de "
+"colecciones (no inversas), con los conjuntos (sets) no muy atrás. Se espera "
+"que los sets sean el tipo más común de colección en las aplicaciones de "
+"Hibernate. Esto se debe a que la semántica de los sets es la más natural en "
+"el modelo relacional."
 
 #. Tag: para
-#: performance.xml:1121
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, in well-designed Hibernate domain models, most collections are in "
 "fact one-to-many associations with <literal>inverse=\"true\"</literal>. For "
@@ -2403,24 +1905,20 @@
 "association, and so considerations of collection update performance simply "
 "do not apply."
 msgstr ""
-"Sin embargo, en modelos de dominio de Hibernate bien die&#x00f1;ados, "
-"usualmente vemos que la mayor&#x00ed;a de las colecciones son de hecho "
-"asociaciones uno-a-muchos con <literal>inverse=\"true\"</literal>. Para "
-"estas asociaciones, la actualizaci&#x00f3;n es manejada por el extremo "
-"muchos-a-uno de la asociaci&#x00f3;n, y las consideraciones de este tipo "
-"sobre el rendimiento de actualizaci&#x00f3;n de colecciones simplemente no "
-"se aplican."
+"Sin embargo, en modelos de dominio de Hibernate bien dieñados, usualmente "
+"vemos que la mayoría de las colecciones son de hecho asociaciones uno-a-"
+"muchos con <literal>inverse=\"true\"</literal>. Para estas asociaciones, la "
+"actualización es manejada por el extremo muchos-a-uno de la asociación, y "
+"las consideraciones de este tipo sobre el rendimiento de la actualización de "
+"las colecciones simplemente no se aplican."
 
 #. Tag: title
-#: performance.xml:1131
 #, no-c-format
 msgid "Bags and lists are the most efficient inverse collections"
-msgstr ""
-"Los Bags y las listas son las colecciones inversas m&#x00e1;s eficientes"
+msgstr "Los Bags y las listas son las colecciones inversas más eficientes"
 
 #. Tag: para
-#: performance.xml:1133
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is a particular case, however, in which bags, and also lists, are much "
 "more performant than sets. For a collection with <literal>inverse=\"true\"</"
@@ -2431,143 +1929,109 @@
 "literal> must always return true for a bag or <literal>List</literal>. This "
 "can make the following common code much faster:"
 msgstr ""
-"Justo antes que tires a la zanja los bags para siempre, hay un caso en "
-"particular en el que los bags son muchos m&#x00e1;s eficientes que los "
-"conjuntos. Para una colecci&#x00f3;n con <literal>inverse=\"true\"</literal> "
-"(el idioma est&#x00e1;ndar de relaciones uno-a-muchos bidireccionales, por "
-"ejemplo) &#x00a1;podemos a&#x00f1;adir elementos a un bag o lista sin "
-"necesidad de inicializar (fetch) los elementos del bag! Esto se debe a que "
-"<literal>Collection.add()</literal> o <literal>Collection.addAll()</literal> "
-"siempre deben devolver true para un bag o <literal>List</literal> (no como "
-"un <literal>Set</literal>). Esto puede hacer el siguiente c&#x00f3;digo "
-"com&#x00fa;n mucho m&#x00e1;s r&#x00e1;pido."
+"Hay un caso en particular en el que los bags y también las listas son mucho "
+"más eficientes que los conjuntos. Para una colección con <literal>inverse="
+"\"true\"</literal>, por ejemplo, el idioma estándar de relaciones uno-a-"
+"muchos bidireccionales, podemos agregar elementos a un bag o lista sin "
+"necesidad de inicializar (recuperar) los elementos del bag. Esto se debe a "
+"que, a manera opuesta de <literal>Collection.add()</literal> o "
+"<literal>Collection.addAll()</literal> siempre deben retornar verdadero para "
+"un bag o <literal>List</literal> (no como un <literal>Set</literal>). Esto "
+"puede hacer el siguiente código común mucho más rápido:"
 
-#. Tag: programlisting
-#: performance.xml:1143
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = (Parent) sess.load(Parent.class, id);\n"
-"Child c = new Child();\n"
-"c.setParent(p);\n"
-"p.getChildren().add(c);  //no need to fetch the collection!\n"
-"sess.flush();]]>"
-msgstr ""
-"<![CDATA[Parent p = (Parent) sess.load(Parent.class, id);\n"
-"    Child c = new Child();\n"
-"    c.setParent(p);\n"
-"    p.getChildren().add(c);  //no need to fetch the collection!\n"
-"    sess.flush();]]>"
-
 #. Tag: title
-#: performance.xml:1148
 #, no-c-format
 msgid "One shot delete"
-msgstr "Borrado de un solo tiro"
+msgstr "Borrado de un sólo tiro"
 
 #. Tag: para
-#: performance.xml:1150
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Deleting collection elements one by one can sometimes be extremely "
 "inefficient. Hibernate knows not to do that in the case of an newly-empty "
 "collection (if you called <literal>list.clear()</literal>, for example). In "
 "this case, Hibernate will issue a single <literal>DELETE</literal>."
 msgstr ""
-"Ocasionalmente, borrar los elementos de una colecci&#x00f3;n uno a uno puede "
-"ser extremadamente ineficiente. Hibernate no es completamente est&#x00fa;"
-"pido, de modo que sabe no hacer eso, en el caso de una colecci&#x00f3;n "
-"nueva-vac&#x00ed;a (si has llamado a <literal>list.clear()</literal>, por "
-"ejemplo). En este caso, Hibernate publicar&#x00e1; una sola <literal>DELETE</"
-"literal>, &#x00a1;y listo!"
+"Borrar los elementos de una colección uno por uno a veces puede ser "
+"extremadamente ineficiente. Hibernate sabe que no debe hacer eso, en el caso "
+"de una colección nueva-vacía (si ha llamado a <literal>list.clear()</"
+"literal>, por ejemplo). En este caso, Hibernate publicará un sólo "
+"<literal>DELETE</literal>."
 
 #. Tag: para
-#: performance.xml:1157
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Suppose you added a single element to a collection of size twenty and then "
 "remove two elements. Hibernate will issue one <literal>INSERT</literal> "
 "statement and two <literal>DELETE</literal> statements, unless the "
 "collection is a bag. This is certainly desirable."
 msgstr ""
-"Sup&#x00f3;n que a&#x00f1;adimos un solo elemento a una colecci&#x00f3;n de "
-"tama&#x00f1;o veinte y luego quitamos dos elementos. Hibernate "
-"publicar&#x00e1; una sentencia <literal>INSERT</literal> y dos sentencias "
-"<literal>DELETE</literal> (a menos que la colecci&#x00f3;n sea un bag). Esto "
-"es ciertamente deseable."
+"Suponga que agrega un solo elemento a una colección de tamaño veinte y luego "
+"quitamos dos elementos. Hibernate publicará una declaración <literal>INSERT</"
+"literal> y dos declaraciones <literal>DELETE</literal> a menos que la "
+"colección sea un bag. Esto ciertamente es deseable."
 
 #. Tag: para
-#: performance.xml:1163
 #, no-c-format
 msgid ""
 "However, suppose that we remove eighteen elements, leaving two and then add "
 "thee new elements. There are two possible ways to proceed"
 msgstr ""
-"Sin embargo, sup&#x00f3;n que quitamos dieciocho elementos, dejando dos y "
-"luego a&#x00f1;adimos tres nuevos elementos. Hay dos formas posibles de "
-"proceder"
+"Sin embargo, supónga que quitamos dieciocho elementos, dejando dos y luego "
+"añadimos tres elementos nuevos. Hay dos formas posibles de proceder"
 
 #. Tag: para
-#: performance.xml:1170
 #, no-c-format
 msgid "delete eighteen rows one by one and then insert three rows"
 msgstr "borrar dieciocho filas una a una y luego insertar tres filas"
 
 #. Tag: para
-#: performance.xml:1173
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "remove the whole collection in one SQL <literal>DELETE</literal> and insert "
 "all five current elements one by one"
 msgstr ""
-"quitar toda la colecci&#x00f3;n (en un solo <literal>DELETE</literal> de "
-"SQL) e insertar todos los cinco elementos actuales (uno a uno)"
+"quitar toda la colección en un sólo <literal>DELETE</literal> de SQL e "
+"insertar todos los cinco elementos actuales uno por uno"
 
 #. Tag: para
-#: performance.xml:1178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate cannot know that the second option is probably quicker. It would "
 "probably be undesirable for Hibernate to be that intuitive as such behavior "
 "might confuse database triggers, etc."
 msgstr ""
-"Hibernate no es lo suficientemente inteligente para saber que la segunda "
-"opci&#x00f3;n es probablemente m&#x00e1;s r&#x00e1;pida en este caso. (Y que "
-"ser&#x00ed;a probablemente indeseable para Hibernate ser tan inteligente; "
-"este comportamiento podr&#x00ed;a confundir a disparadores de base de datos, "
-"etc.)"
+"Hibernate no sabe que la segunda opción es probablemente la más rápida. "
+"Probablemente no sería deseable que Hibernate fuese tan intuitivo ya que tal "
+"comportamiento podría confundir a disparadores de la base de datos, etc."
 
 #. Tag: para
-#: performance.xml:1184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Fortunately, you can force this behavior (i.e. the second strategy) at any "
 "time by discarding (i.e. dereferencing) the original collection and "
 "returning a newly instantiated collection with all the current elements."
 msgstr ""
-"Afortunadamente, puedes forzar este comportamiento (es decir, la segunda "
-"estrategia) en cualquier momento descartando (es decir, desreferenciando) la "
-"colecci&#x00f3;n original y devolviendo una colecci&#x00f3;n nuevamente "
-"instanciada con todos los elementos actuales. Esto puede ser muy &#x00fa;til "
-"y potente de vez en cuando."
+"Afortunadamente, puede forzar este comportamiento (por ejemplo, la segunda "
+"estrategia) en cualquier momento descartando (por ejemplo, desreferenciando) "
+"la colección original y retornando una colección nuevamente instanciada con "
+"todos los elementos actuales."
 
 #. Tag: para
-#: performance.xml:1190
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "One-shot-delete does not apply to collections mapped <literal>inverse=\"true"
 "\"</literal>."
 msgstr ""
-"Por supuesto, el borrado-de-un-solo-tiro no se aplica a colecciones mapeadas "
+"El borrado-de-un-sólo-tiro no se aplica a las colecciones mapeadas "
 "<literal>inverse=\"true\"</literal>."
 
 #. Tag: title
-#: performance.xml:1199
 #, no-c-format
 msgid "Monitoring performance"
-msgstr "Monitoreando el rendimiento"
+msgstr "Control del rendimiento"
 
 #. Tag: para
-#: performance.xml:1201
 #, no-c-format
 msgid ""
 "Optimization is not much use without monitoring and access to performance "
@@ -2575,191 +2039,128 @@
 "operations. Statistics in Hibernate are available per "
 "<literal>SessionFactory</literal>."
 msgstr ""
-"La optimizaci&#x00f3;n no es de mucho uso sin el monitoreo y el acceso a "
-"n&#x00fa;meros de rendimiento. Hibernate provee un rango completo de figuras "
-"sobre sus operaciones internas. Las estad&#x00ed;sticas en Hibernate "
-"est&#x00e1;n disponibles por <literal>SessionFactory</literal>."
+"La optimización no es de mucho uso sin el monitoreo y el acceso a números de "
+"rendimiento. Hibernate brinda un rango completo de números sobre sus "
+"operaciones internas. Las estadísticas en Hibernate están disponibles por "
+"<literal>SessionFactory</literal>."
 
 #. Tag: title
-#: performance.xml:1208
 #, no-c-format
 msgid "Monitoring a SessionFactory"
-msgstr "Monitoreando una SessionFactory"
+msgstr "Control de una SessionFactory"
 
 #. Tag: para
-#: performance.xml:1210
 #, no-c-format
 msgid ""
 "You can access <literal>SessionFactory</literal> metrics in two ways. Your "
 "first option is to call <literal>sessionFactory.getStatistics()</literal> "
 "and read or display the <literal>Statistics</literal> yourself."
 msgstr ""
-"Puedes acceder a las m&#x00e9;tricas de <literal>SessionFactory</literal> de "
-"dos formas. Tu primera opci&#x00f3;n es llamar a <literal>sessionFactory."
-"getStatistics()</literal> y leer o mostrar por pantalla la "
-"<literal>Statistics</literal> por ti mismo."
+"Puede acceder a las métricas de <literal>SessionFactory</literal> de dos "
+"formas. Su primera opción es llamar a <literal>sessionFactory.getStatistics()"
+"</literal> y leer o mostrar por pantalla la <literal>Statistics</literal> "
+"por sí mismo."
 
 #. Tag: para
-#: performance.xml:1216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate can also use JMX to publish metrics if you enable the "
 "<literal>StatisticsService</literal> MBean. You can enable a single MBean "
 "for all your <literal>SessionFactory</literal> or one per factory. See the "
 "following code for minimalistic configuration examples:"
 msgstr ""
-"Hibernate puede tambi&#x00e9;n usar JMX para publicar las m&#x00e9;tricas si "
-"habilitas el MBean <literal>StatisticsService</literal>. Puede habilitar un "
-"solo MBean para todas tus <literal>SessionFactory</literal> o una por "
-"f&#x00e1;brica. Mira el siguiente c&#x00f3;digo para ejemplos de "
-"configuraci&#x00f3;n minimalistas:"
+"Hibernate también puede utilizar JMX para publicar las métricas si habilita "
+"el MBean <literal>StatisticsService</literal>. Puede habilitar un sólo MBean "
+"para todas sus <literal>SessionFactory</literal> o una por fábrica. Véa el "
+"siguiente código para ver ejemplos de configuración minimalistas:"
 
-#. Tag: programlisting
-#: performance.xml:1223
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// MBean service registration for a specific SessionFactory\n"
-"Hashtable tb = new Hashtable();\n"
-"tb.put(\"type\", \"statistics\");\n"
-"tb.put(\"sessionFactory\", \"myFinancialApp\");\n"
-"ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-"\n"
-"StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-"stats.setSessionFactory(sessionFactory); // Bind the stats to a "
-"SessionFactory\n"
-"server.registerMBean(stats, on); // Register the Mbean on the server]]>"
-msgstr ""
-"<![CDATA[// MBean service registration for a specific SessionFactory\n"
-"Hashtable tb = new Hashtable();\n"
-"tb.put(\"type\", \"statistics\");\n"
-"tb.put(\"sessionFactory\", \"myFinancialApp\");\n"
-"ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-"\n"
-"StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-"stats.setSessionFactory(sessionFactory); // Bind the stats to a "
-"SessionFactory\n"
-"server.registerMBean(stats, on); // Register the Mbean on the server]]>"
-
-#. Tag: programlisting
-#: performance.xml:1226
-#, no-c-format
-msgid ""
-"<![CDATA[// MBean service registration for all SessionFactory's\n"
-"Hashtable tb = new Hashtable();\n"
-"tb.put(\"type\", \"statistics\");\n"
-"tb.put(\"sessionFactory\", \"all\");\n"
-"ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-"\n"
-"StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-"server.registerMBean(stats, on); // Register the MBean on the server]]>"
-msgstr ""
-"<![CDATA[// MBean service registration for all SessionFactory's\n"
-"Hashtable tb = new Hashtable();\n"
-"tb.put(\"type\", \"statistics\");\n"
-"tb.put(\"sessionFactory\", \"all\");\n"
-"ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-"\n"
-"StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-"server.registerMBean(stats, on); // Register the MBean on the server]]>"
-
-#. Tag: para
-#: performance.xml:1233
-#, fuzzy, no-c-format
-msgid ""
 "You can activate and deactivate the monitoring for a "
 "<literal>SessionFactory</literal>:"
 msgstr ""
-"Puedes (des)activar el monitoreo de una <literal>SessionFactory</literal>"
+"Puede activar y desactivar el monitoreo de una <literal>SessionFactory</"
+"literal>"
 
 #. Tag: para
-#: performance.xml:1238
 #, no-c-format
 msgid ""
 "at configuration time, set <literal>hibernate.generate_statistics</literal> "
 "to <literal>false</literal>"
 msgstr ""
-"en tiempo de configuraci&#x00f3;n, establece <literal>hibernate."
-"generate_statistics</literal> a <literal>false</literal>"
+"en tiempo de configuración, establezca <literal>hibernate."
+"generate_statistics</literal> como <literal>false</literal>"
 
 #. Tag: para
-#: performance.xml:1245
 #, no-c-format
 msgid ""
 "at runtime: <literal>sf.getStatistics().setStatisticsEnabled(true)</literal> "
 "or <literal>hibernateStatsBean.setStatisticsEnabled(true)</literal>"
 msgstr ""
-"en tiempo de ejecuci&#x00f3;n: <literal>sf.getStatistics()."
-"setStatisticsEnabled(true)</literal> o <literal>hibernateStatsBean."
-"setStatisticsEnabled(true)</literal>"
+"en tiempo de ejecución: <literal>sf.getStatistics().setStatisticsEnabled"
+"(true)</literal> o <literal>hibernateStatsBean.setStatisticsEnabled(true)</"
+"literal>"
 
 #. Tag: para
-#: performance.xml:1252
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Statistics can be reset programmatically using the <literal>clear()</"
 "literal> method. A summary can be sent to a logger (info level) using the "
 "<literal>logSummary()</literal> method."
 msgstr ""
-"Las estad&#x00ed;sticas pueden ser reajustadas program&#x00e1;ticamente "
-"usando el m&#x00e9;todo <literal>clear()</literal>. Puede enviarse un "
-"resumen a un logger (nivel info) usando el m&#x00e9;todo <literal>logSummary"
-"()</literal>."
+"Las estadísticas pueden ser reajustadas programáticamente utilizando el "
+"método <literal>clear()</literal>. Puede enviarse un resumen a un registro "
+"(a nivel de información) utilizando el método <literal>logSummary()</"
+"literal>. "
 
 #. Tag: title
-#: performance.xml:1261
 #, no-c-format
 msgid "Metrics"
-msgstr "M&#x00e9;tricas"
+msgstr "Métricas"
 
 #. Tag: para
-#: performance.xml:1263
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate provides a number of metrics, from basic information to more "
 "specialized information that is only relevant in certain scenarios. All "
 "available counters are described in the <literal>Statistics</literal> "
 "interface API, in three categories:"
 msgstr ""
-"Hibernate provee un n&#x00fa;mero de m&#x00e9;tricas, desde informaci&#x00f3;"
-"n muy b&#x00e1;sica a la especializada s&#x00f3;lo relevante en ciertos "
-"escenarios. Todos los contadores disponibles se describen en la API de la "
-"interface <literal>Statistics</literal>, en tres categor&#x00ed;as:"
+"Hibernate proporciona un número de métricas, desde información muy básica "
+"hasta la más especializada sólamente relevante en ciertos escenarios. Todos "
+"los contadores disponibles se describen en la API de la interfaz "
+"<literal>Statistics</literal>, en tres categorías:"
 
 #. Tag: para
-#: performance.xml:1270
 #, no-c-format
 msgid ""
 "Metrics related to the general <literal>Session</literal> usage, such as "
 "number of open sessions, retrieved JDBC connections, etc."
 msgstr ""
-"M&#x00e9;tricas relacionadas al uso general de <literal>Session</literal> "
-"usage, tales como n&#x00fa;mero de sesiones abiertas, conexiones JDBC "
-"recuperadas, etc,"
+"Métricas relacionadas al uso general de <literal>Session</literal> usage, "
+"tales como número de sesiones abiertas, conexiones JDBC recuperadas, etc,"
 
 #. Tag: para
-#: performance.xml:1276
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Metrics related to the entities, collections, queries, and caches as a whole "
 "(aka global metrics)."
 msgstr ""
-"M&#x00e9;tricas relacionadas a las entidades, colecciones, consultas, y "
-"cach&#x00e9;s como un todo. (tambi&#x00e9;n conocidas como m&#x00e9;tricas "
-"globales)."
+"Métricas relacionadas con las entidades, colecciones, consultas y cachés "
+"como un todo (también conocidas como métricas globales)."
 
 #. Tag: para
-#: performance.xml:1282
 #, no-c-format
 msgid ""
 "Detailed metrics related to a particular entity, collection, query or cache "
 "region."
 msgstr ""
-"M&#x00e9;tricas detalladas relacionadas a una entidad, colecci&#x00f3;n, "
-"consulta o regi&#x00f3;n de cach&#x00e9; en particular."
+"Métricas detalladas relacionadas con una entidad, colección, consulta o "
+"región de caché en particular."
 
 #. Tag: para
-#: performance.xml:1289
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For example, you can check the cache hit, miss, and put ratio of entities, "
 "collections and queries, and the average time a query needs. Be aware that "
@@ -2767,17 +2168,14 @@
 "tied to the JVM precision and on some platforms this might only be accurate "
 "to 10 seconds."
 msgstr ""
-"Por ejemplo, puedes comprobar el acceso, p&#x00e9;rdida, y radio de "
-"colocaci&#x00f3;n de entidades, colecciones y consultas en el cach&#x00e9;, "
-"y el tiempo promedio que necesita una consulta. Ten en cuenta que el "
-"n&#x00fa;mero de milisegundos est&#x00e1; sujeto a aproximaci&#x00f3;n en "
-"Java. Hibernate est&#x00e1; pegado a la precisi&#x00f3;n de la JVM, en "
-"algunas plataformas esto podr&#x00ed;a incuso ser tener s&#x00f3;lo una "
-"exactitud de 10 segundos."
+"Por ejemplo, puede comprobar el acceso, pérdida y radio de colecciones de "
+"entidades y consultas en el caché, y el tiempo promedio que necesita una "
+"consulta. Tenga en cuenta que el número de milisegundos está sujeto a una "
+"aproximación en Java. Hibernate está vinculado a la precisión de la MVJ, en "
+"algunas plataformas esto podría tener incluso una exactitud de 10 segundos."
 
 #. Tag: para
-#: performance.xml:1296
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Simple getters are used to access the global metrics (i.e. not tied to a "
 "particular entity, collection, cache region, etc.). You can access the "
@@ -2789,60 +2187,20 @@
 "literal> API Javadoc for more information. The following code is a simple "
 "example:"
 msgstr ""
-"Se usan getters simples para acceder a las m&#x00e9;tricas globales (es "
-"decir, no pegadas a una entidad, colecci&#x00f3;n, regi&#x00f3;n de "
-"cach&#x00e9;, etc, en particular). Puedes acceder a las m&#x00e9;tricas de "
-"una entidad, colecci&#x00f3;n, regi&#x00f3;n de cach&#x00e9; en particular a "
-"trav&#x00e9;s de su nombre, y a trav&#x00e9;s de su representaci&#x00f3;n "
-"HQL o SQL para las consultas. Por favor refi&#x00e9;rete al Javadoc de la "
-"API de <literal>Statistics</literal>, <literal>EntityStatistics</literal>, "
+"Se usan getters simples para acceder a la métrica global (por ejemplo, no "
+"vinculadas en particular a una entidad, colección, región de caché, etc). "
+"Puede acceder a las métricas de una entidad, colección, región de caché en "
+"particular a través de su nombre y a través de su representación HQL o SQL "
+"para las consultas. Por favor refiérase al Javadoc de la API de "
+"<literal>Statistics</literal>, <literal>EntityStatistics</literal>, "
 "<literal>CollectionStatistics</literal>, "
 "<literal>SecondLevelCacheStatistics</literal>, y <literal>QueryStatistics</"
-"literal> para m&#x00e1;s informaci&#x00f3;n. El siguiente c&#x00f3;digo "
-"muestra un ejemplo sencillo:"
+"literal> para obtener más información. El siguiente código es un ejemplo "
+"sencillo:"
 
-#. Tag: programlisting
-#: performance.xml:1306
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Statistics stats = HibernateUtil.sessionFactory.getStatistics();\n"
-"\n"
-"double queryCacheHitCount  = stats.getQueryCacheHitCount();\n"
-"double queryCacheMissCount = stats.getQueryCacheMissCount();\n"
-"double queryCacheHitRatio =\n"
-"  queryCacheHitCount / (queryCacheHitCount + queryCacheMissCount);\n"
-"\n"
-"log.info(\"Query Hit ratio:\" + queryCacheHitRatio);\n"
-"\n"
-"EntityStatistics entityStats =\n"
-"  stats.getEntityStatistics( Cat.class.getName() );\n"
-"long changes =\n"
-"        entityStats.getInsertCount()\n"
-"        + entityStats.getUpdateCount()\n"
-"        + entityStats.getDeleteCount();\n"
-"log.info(Cat.class.getName() + \" changed \" + changes + \"times\"  );]]>"
-msgstr ""
-"<![CDATA[Statistics stats = HibernateUtil.sessionFactory.getStatistics();\n"
-"\n"
-"double queryCacheHitCount  = stats.getQueryCacheHitCount();\n"
-"double queryCacheMissCount = stats.getQueryCacheMissCount();\n"
-"double queryCacheHitRatio =\n"
-"  queryCacheHitCount / (queryCacheHitCount + queryCacheMissCount);\n"
-"\n"
-"log.info(\"Query Hit ratio:\" + queryCacheHitRatio);\n"
-"\n"
-"EntityStatistics entityStats =\n"
-"  stats.getEntityStatistics( Cat.class.getName() );\n"
-"long changes =\n"
-"        entityStats.getInsertCount()\n"
-"        + entityStats.getUpdateCount()\n"
-"        + entityStats.getDeleteCount();\n"
-"log.info(Cat.class.getName() + \" changed \" + changes + \"times\"  );]]>"
-
-#. Tag: para
-#: performance.xml:1308
-#, fuzzy, no-c-format
-msgid ""
 "You can work on all entities, collections, queries and region caches, by "
 "retrieving the list of names of entities, collections, queries and region "
 "caches using the following methods: <literal>getQueries()</literal>, "
@@ -2850,51 +2208,28 @@
 "literal>, and <literal>getSecondLevelCacheRegionNames()</literal>."
 msgstr ""
 "Para trabajar sobre todas las entidades, colecciones, consultas y regiones "
-"de cach&#x00e9;s, puedes recuperar la lista de nombres de entidades, "
-"colecciones, consultas y regiones de cach&#x00e9;s con los siguientes "
-"m&#x00e9;todos: <literal>getQueries()</literal>, <literal>getEntityNames()</"
-"literal>, <literal>getCollectionRoleNames()</literal>, y "
+"de cachés, recuperando la lista de nombres de entidades, colecciones, "
+"consultas y regiones de cachés con los siguientes métodos: "
+"<literal>getQueries()</literal>, <literal>getEntityNames()</literal>, "
+"<literal>getCollectionRoleNames()</literal> y "
 "<literal>getSecondLevelCacheRegionNames()</literal>."
 
 #~ msgid ""
-#~ "where <literal>CatImpl</literal> implements the interface <literal>Cat</"
-#~ "literal> and <literal>DomesticCatImpl</literal> implements the interface "
-#~ "<literal>DomesticCat</literal>. Then proxies for instances of "
-#~ "<literal>Cat</literal> and <literal>DomesticCat</literal> may be returned "
-#~ "by <literal>load()</literal> or <literal>iterate()</literal>. (Note that "
-#~ "<literal>list()</literal> does not usually return proxies.)"
+#~ "This setting creates two new cache regions: one holding cached query "
+#~ "result sets (<literal>org.hibernate.cache.StandardQueryCache</literal>), "
+#~ "the other holding timestamps of the most recent updates to queryable "
+#~ "tables (<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). "
+#~ "Note that the query cache does not cache the state of the actual entities "
+#~ "in the result set; it caches only identifier values and results of value "
+#~ "type. The query cache should always be used in conjunction with the "
+#~ "second-level cache."
 #~ msgstr ""
-#~ "donde <literal>CatImpl</literal> implementa la interface <literal>Cat</"
-#~ "literal> y <literal>DomesticCatImpl</literal> implementa la interface "
-#~ "<literal>DomesticCat</literal>. Entonces <literal>load()</literal> o "
-#~ "<literal>iterate()</literal> pueden devolver instancias de <literal>Cat</"
-#~ "literal> y <literal>DomesticCat</literal>. (Nota que <literal>list()</"
-#~ "literal> usualmente no devuelve proxies.)"
-
-#~ msgid ""
-#~ "We've already spent quite some time talking about collections. In this "
-#~ "section we will highlight a couple more issues about how collections "
-#~ "behave at runtime."
-#~ msgstr ""
-#~ "Ya hemos llevado un buen tiempo hablando sobre colecciones. En esta "
-#~ "secci&#x00f3;n resaltaremos un par de temas m&#x00e1;s sobre c&#x00f3;mo "
-#~ "las colecciones se comportan en tiempo de ejecuci&#x00f3;n."
-
-#~ msgid ""
-#~ "TODO: This doesn't make sense: In the first case, we retrieve and use the "
-#~ "MBean directly. In the second one, we must give the JNDI name in which "
-#~ "the session factory is held before using it. Use "
-#~ "<literal>hibernateStatsBean.setSessionFactoryJNDIName(\"my/JNDI/Name\")</"
-#~ "literal>"
-#~ msgstr ""
-#~ "POR HACER: Esto no tiene sentido: En el primer caso, recuperamos y usamos "
-#~ "el MBean directamente. En el segundo, debemos proporcionar el nombre JNDI "
-#~ "en el que se guarda la f&#x00e1;brica de sesiones antes de usarlo. Usa "
-#~ "<literal>hibernateStatsBean.setSessionFactoryJNDIName(\"my/JNDI/Name\")</"
-#~ "literal>"
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+#~ "Esta configuración crea dos nuevas regiones de caché: una que tiene en "
+#~ "caché los conjuntos resultados de consultas (<literal>org.hibernate.cache."
+#~ "StandardQueryCache</literal>), el otro tiene los sellos de fecha de las "
+#~ "actualizaciones más recientes a las tablas consultables (<literal>org."
+#~ "hibernate.cache.UpdateTimestampsCache</literal>). Note que el caché de "
+#~ "consultas no pone en caché el estado de las entidades reales en el "
+#~ "conjunto que resulta; sólo tiene en caché los valores indentificadores y "
+#~ "los resultados de tipo de valor. De modo que el caché de consultas "
+#~ "siempre debe ser utilizado en conjunto con el caché de segundo nivel."

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/persistent_classes.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/persistent_classes.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/persistent_classes.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,21 +1,35 @@
-#, fuzzy
+# translation of persistent_classes.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: persistent_classes\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-07 06:20+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: persistent_classes.xml:29
 #, no-c-format
 msgid "Persistent Classes"
-msgstr "Clases Persistentes"
+msgstr "Clases persistentes"
 
 #. Tag: para
-#: persistent_classes.xml:31
-#, fuzzy, no-c-format
+#, 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 "
@@ -23,15 +37,14 @@
 "in the persistent state. For example, an instance can instead be transient "
 "or detached."
 msgstr ""
-"Clases presistentes son clases en una aplicaci&#x00f3;n que implementan las "
-"entidades del problema de negocio (por ejemplo, Customer y Order en una "
-"aplicaci&#x00f3;n de comercio electr&#x00f3;nico). No todas las instancias "
-"de una clase persistente se considera que est&#x00e9;n en el estado "
-"persistente, una instancia puede en cambio ser transitoria o estar separada."
+"Las clases presistentes son clases en una aplicación que implementan las "
+"entidades del problema empresarial (por ejemplo, Customer y Order en una "
+"aplicación de comercio electrónico). No se considera que todas las "
+"instancias de una clase persistente estén en estado persistente. Por "
+"ejemplo, una instancia puede ser transitoria o separada."
 
 #. Tag: para
-#: persistent_classes.xml:38
-#, fuzzy, no-c-format
+#, 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 "
@@ -39,209 +52,43 @@
 "about the nature of your persistent objects. You can express a domain model "
 "in other ways (using trees of <literal>Map</literal> instances, for example)."
 msgstr ""
-"Hibernate funciona mejor si las clases siguen algunas simples reglas, "
-"tambi&#x00e9;n conocidas como el modelo de programaci&#x00f3;n de Viejas "
-"Clases Java Planas (Plain Old Java Object o POJO). Sin embargo, ninguna de "
-"estas reglas son requerimientos r&#x00ed;gidos. En cambio, Hibernate3 asume "
-"muy poco acerca de la naturaleza de tus objetos persistentes. Puedes "
-"expresar un modelo de dominio en otras formas: usando &#x00e1;rboles de "
-"instancias de <literal>Map</literal>, por ejemplo."
+"Hibernate funciona mejor si estas clases siguen algunas reglas simples, "
+"también conocidas como el modelo de programación POJO (Plain Old Java "
+"Object). Sin embargo, ninguna de estas reglas son requerimientos rígidos. De "
+"hecho, Hibernate3 asume muy poco acerca de la naturaleza de sus objetos "
+"persistentes. Puede expresar un modelo de dominio en otras formas (por "
+"ejemplo, utilizando árboles de instancias de <literal>Map</literal>)."
 
 #. Tag: title
-#: persistent_classes.xml:47
 #, no-c-format
 msgid "A simple POJO example"
-msgstr "Un ejemplo simple de POJO"
+msgstr "Ejemplo simple de POJO"
 
 #. Tag: para
-#: persistent_classes.xml:49
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Most Java applications require a persistent class representing felines. For "
 "example:"
 msgstr ""
-"La mayor&#x00ed;a de aplicaciones Java requieren una clase representando "
-"felinos."
+"La mayoría de aplicaciones Java requieren una clase persistente que "
+"represente a los felinos. Por ejemplo:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:53
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"import java.util.Date;\n"
-"\n"
-"public class Cat {\n"
-"    private Long id; // identifier\n"
-"\n"
-"    private Date birthdate;\n"
-"    private Color color;\n"
-"    private char sex;\n"
-"    private float weight;\n"
-"    private int litterId;\n"
-"\n"
-"    private Cat mother;\n"
-"    private Set kittens = new HashSet();\n"
-"\n"
-"    private void setId(Long id) {\n"
-"        this.id=id;\n"
-"    }\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"\n"
-"    void setBirthdate(Date date) {\n"
-"        birthdate = date;\n"
-"    }\n"
-"    public Date getBirthdate() {\n"
-"        return birthdate;\n"
-"    }\n"
-"\n"
-"    void setWeight(float weight) {\n"
-"        this.weight = weight;\n"
-"    }\n"
-"    public float getWeight() {\n"
-"        return weight;\n"
-"    }\n"
-"\n"
-"    public Color getColor() {\n"
-"        return color;\n"
-"    }\n"
-"    void setColor(Color color) {\n"
-"        this.color = color;\n"
-"    }\n"
-"\n"
-"    void setSex(char sex) {\n"
-"        this.sex=sex;\n"
-"    }\n"
-"    public char getSex() {\n"
-"        return sex;\n"
-"    }\n"
-"\n"
-"    void setLitterId(int id) {\n"
-"        this.litterId = id;\n"
-"    }\n"
-"    public int getLitterId() {\n"
-"        return litterId;\n"
-"    }\n"
-"\n"
-"    void setMother(Cat mother) {\n"
-"        this.mother = mother;\n"
-"    }\n"
-"    public Cat getMother() {\n"
-"        return mother;\n"
-"    }\n"
-"    void setKittens(Set kittens) {\n"
-"        this.kittens = kittens;\n"
-"    }\n"
-"    public Set getKittens() {\n"
-"        return kittens;\n"
-"    }\n"
-"    \n"
-"    // addKitten not needed by Hibernate\n"
-"    public void addKitten(Cat kitten) {\n"
-"            kitten.setMother(this);\n"
-"        kitten.setLitterId( kittens.size() ); \n"
-"        kittens.add(kitten);\n"
-"    }\n"
-"}]]>"
-msgstr ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"import java.util.Date;\n"
-"\n"
-"public class Cat {\n"
-"    private Long id; // identifier\n"
-"\n"
-"    private Date birthdate;\n"
-"    private Color color;\n"
-"    private char sex;\n"
-"    private float weight;\n"
-"    private int litterId;\n"
-"\n"
-"    private Cat mother;\n"
-"    private Set kittens = new HashSet();\n"
-"\n"
-"    private void setId(Long id) {\n"
-"        this.id=id;\n"
-"    }\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"\n"
-"    void setBirthdate(Date date) {\n"
-"        birthdate = date;\n"
-"    }\n"
-"    public Date getBirthdate() {\n"
-"        return birthdate;\n"
-"    }\n"
-"\n"
-"    void setWeight(float weight) {\n"
-"        this.weight = weight;\n"
-"    }\n"
-"    public float getWeight() {\n"
-"        return weight;\n"
-"    }\n"
-"\n"
-"    public Color getColor() {\n"
-"        return color;\n"
-"    }\n"
-"    void setColor(Color color) {\n"
-"        this.color = color;\n"
-"    }\n"
-"\n"
-"    void setSex(char sex) {\n"
-"        this.sex=sex;\n"
-"    }\n"
-"    public char getSex() {\n"
-"        return sex;\n"
-"    }\n"
-"\n"
-"    void setLitterId(int id) {\n"
-"        this.litterId = id;\n"
-"    }\n"
-"    public int getLitterId() {\n"
-"        return litterId;\n"
-"    }\n"
-"\n"
-"    void setMother(Cat mother) {\n"
-"        this.mother = mother;\n"
-"    }\n"
-"    public Cat getMother() {\n"
-"        return mother;\n"
-"    }\n"
-"    void setKittens(Set kittens) {\n"
-"        this.kittens = kittens;\n"
-"    }\n"
-"    public Set getKittens() {\n"
-"        return kittens;\n"
-"    }\n"
-"    \n"
-"    // addKitten not needed by Hibernate\n"
-"    public void addKitten(Cat kitten) {\n"
-"            kitten.setMother(this);\n"
-"        kitten.setLitterId( kittens.size() ); \n"
-"        kittens.add(kitten);\n"
-"    }\n"
-"}]]>"
-
 #. Tag: para
-#: persistent_classes.xml:55
 #, no-c-format
 msgid ""
 "The four main rules of persistent classes are explored in more detail in the "
 "following sections."
 msgstr ""
+"En las siguientes secciones vamos a explorar en mayor detalle las cuatro "
+"reglas principales de las clases persistentes. "
 
 #. Tag: title
-#: persistent_classes.xml:61
 #, no-c-format
 msgid "Implement a no-argument constructor"
-msgstr "Implementa un constructor sin argumentos"
+msgstr "Implemente un constructor sin argumentos"
 
 #. Tag: para
-#: persistent_classes.xml:63
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Cat</literal> has a no-argument constructor. All persistent classes "
 "must have a default constructor (which can be non-public) so that Hibernate "
@@ -251,22 +98,19 @@
 "Hibernate."
 msgstr ""
 "<literal>Cat</literal> tiene un contructor sin argumentos. Todas las clases "
-"persistentes deben tener un constructor por defecto (que puede no ser "
-"p&#x00fa;blico) de modo que Hibernate pueda instanciarlas usando "
-"<literal>Constructor.newInstance()</literal>. Recomendamos fuertemente tener "
-"un constructor por defecto con al menos visibilidad de <emphasis>package</"
-"emphasis> para la generaci&#x00f3;n de proxies en tiempo de ejecuci&#x00f3;n "
-"en Hibernate."
+"persistentes deben tener un constructor predeterminado (el cual puede ser no-"
+"público) de modo que Hibernate pueda instanciarlas usando "
+"<literal>Constructor.newInstance()</literal>. Le recomendamos contar con un "
+"constructor por defecto con al menos una visibilidad de <emphasis>paquete</"
+"emphasis> para la generación de proxies en tiempo de ejecución en Hibernate."
 
 #. Tag: title
-#: persistent_classes.xml:73
 #, no-c-format
 msgid "Provide an identifier property (optional)"
-msgstr "Provee una propiedad identificadora (opcional)"
+msgstr "Proporcione una propiedad identificadora (opcional)"
 
 #. Tag: para
-#: persistent_classes.xml:75
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Cat</literal> has a property called <literal>id</literal>. This "
 "property maps to the primary key column of a database table. The property "
@@ -277,105 +121,94 @@
 "types (see the section on composite identifiers later in the chapter.)"
 msgstr ""
 "<literal>Cat</literal> tiene una propiedad llamada <literal>id</literal>. "
-"Esta propiedad mapea a la columna clave primaria de la tabla de base de "
-"datos. La propiedad podr&#x00ed;a llamarse cualquierCosa, y su tipo "
-"podr&#x00ed;a haber sido cualquier tipo primitivo, cualquier tipo de "
-"\"envoltura\" primitivo, <literal>java.lang.String</literal> o <literal>java."
-"util.Date</literal>. (Si tu tabla de base de datos heredada tiene claves "
-"compuestas, puedes incluso usar una clase definida por el usuario con "
-"propiedades de estos tipos, ver la secci&#x00f3;n sobre identificadores "
-"compuestos luego.)"
+"Esta propiedad mapea a la columna de la llave principal de la tabla de la "
+"base de datos. La propiedad podría llamarse de cualquier manera y su tipo "
+"podría haber sido cualquier tipo primitivo, cualquier tipo de \"wrapper\" "
+"primitivo, <literal>java.lang.String</literal> o <literal>java.util.Date</"
+"literal>. Si su tabla de base de datos heredada tiene claves compuestas, "
+"puede utilizar una clase definida por el usuario con propiedades de estos "
+"tipos (vea la sección sobre identificadores compuestos más adelante en este "
+"capítulo)."
 
 #. Tag: para
-#: persistent_classes.xml:84
 #, 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 ""
-"La propiedad identificadora es estrictamente opcional. Puedes olvidarla y "
+"La propiedad identificadora es estrictamente opcional. Puede olvidarla y "
 "dejar que Hibernate siga internamente la pista de los identificadores del "
-"objeto. Sin embargo, no recomendamos esto."
+"objeto. Sin embargo, no recomendamos que esto suceda."
 
 #. Tag: para
-#: persistent_classes.xml:89
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In fact, some functionality is available only to classes that declare an "
 "identifier property:"
 msgstr ""
-"De hecho, alguna funcionalidad est&#x00e1; disponible s&#x00f3;lo para "
-"clases que declaran una propiedad identificadora:"
+"De hecho, algunas funcionalidades se encuentran disponibles sólamente para "
+"clases que declaran una propiedad identificadora: "
 
 #. Tag: para
-#: persistent_classes.xml:96
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Transitive reattachment for detached objects (cascade update or cascade "
-"merge) - see"
+"merge) - see <xref linkend=\"objectstate-transitive\" />"
 msgstr ""
-"Reasociaci&#x00f3;n transitiva de objetos separados (actualizaciones o "
-"fusiones en cascada) - ver"
+"Reasociación transitiva de objetos separados (actualizaciones o fusiones en "
+"cascada) - consulte <xref linkend=\"objectstate-transitive\" />"
 
-#. Tag: literal
-#: persistent_classes.xml:103
-#, no-c-format
-msgid "Session.saveOrUpdate()"
-msgstr "Session.saveOrUpdate()"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>Session.saveOrUpdate()</literal>"
+msgstr "<literal>Session.saveOrUpdate()</literal>"
 
-#. Tag: literal
-#: persistent_classes.xml:108
-#, no-c-format
-msgid "Session.merge()"
-msgstr "Session.merge()"
-
 #. Tag: para
-#: persistent_classes.xml:113
 #, fuzzy, no-c-format
+msgid "<literal>Session.merge()</literal>"
+msgstr "<literal>Session.merge()</literal>"
+
+#. Tag: para
+#, 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 ""
-"Recomendamos que declares propiedades identificadoras nombradas-"
-"consistentemente en clases persistentes. Mas a&#x00fa;n, recomendamos que "
-"uses un tipo nulable (es decir, no primitivo)."
+"Le recomendamos que declare propiedades identificadoras nombradas-"
+"consistentemente en clases persistentes. y que utilice un tipo nulable (por "
+"ejemplo, no primitivo)."
 
 #. Tag: title
-#: persistent_classes.xml:120
 #, no-c-format
 msgid "Prefer non-final classes (optional)"
-msgstr "Prefiere las clases no finales (opcional)"
+msgstr "Prefiera las clases no finales (opcional)"
 
 #. Tag: para
-#: persistent_classes.xml:121
 #, no-c-format
 msgid ""
 "A central feature of Hibernate, <emphasis>proxies</emphasis>, depends upon "
 "the persistent class being either non-final, or the implementation of an "
 "interface that declares all public methods."
 msgstr ""
-"Un aspecto central de Hibernate, <emphasis>proxies</emphasis>, depende de "
-"que las clases persistentes sean ya no finales, o sean ya la "
-"implementaci&#x00f3;n de una interface que declare todos los m&#x00e9;todos "
-"p&#x00fa;blicos."
+"Un aspecto central de Hibernate, los <emphasis>proxies</emphasis>, dependen "
+"de que las clases persistentes sean no finales o de la implementación de una "
+"interfaz que declare todos los métodos públicos."
 
 #. Tag: para
-#: persistent_classes.xml:126
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can persist <literal>final</literal> 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 ""
-"Puedes persistir con Hibernate clases <literal>final</literal> que no "
-"implementen una interface, pero no ser&#x00e1;s capaz de usar proxies para "
-"recuperaci&#x00f3;n perezosa de asociaciones, lo que limitar&#x00e1; tus "
-"opciones para afinar el rendimiento."
+"Con Hibernate puede persistir las clases <literal>final</literal>es que no "
+"implementen una interfaz. Sin embargo, no podrá utilizar proxies para "
+"recuperación perezosa de asociaciones, lo cual limitará sus opciones para "
+"afinar el rendimiento."
 
 #. Tag: para
-#: persistent_classes.xml:131
 #, no-c-format
 msgid ""
 "You should also avoid declaring <literal>public final</literal> methods on "
@@ -383,22 +216,20 @@
 "final</literal> method, you must explicitly disable proxying by setting "
 "<literal>lazy=\"false\"</literal>."
 msgstr ""
-"Debes tambi&#x00e9;n evitar declarar m&#x00e9;todos <literal>public final</"
-"literal> en clases non-final. Si quieres usar una clase con un m&#x00e9;todo "
-"<literal>public final</literal>, debes deshabilitar expl&#x00ed;citamente el "
-"uso de proxies estableciendo <literal>lazy=\"false\"</literal>."
+"También debe evitar el declarar métodos <literal>public final</literal> en "
+"las clases no-finales. Si quiere utilizar una clase con un método "
+"<literal>public final</literal>, debe deshabilitar explícitamente el uso de "
+"proxies estableciendo <literal>lazy=\"false\"</literal>."
 
 #. Tag: title
-#: persistent_classes.xml:139
 #, no-c-format
 msgid "Declare accessors and mutators for persistent fields (optional)"
 msgstr ""
-"Declara m&#x00e9;todos de acceso y modificaci&#x00f3;n para los campos "
-"persistentes (opcional)"
+"Declare métodos de acceso y de modificación para los campos persistentes "
+"(opcional)"
 
 #. Tag: para
-#: persistent_classes.xml:141
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Cat</literal> declares accessor methods for all its persistent "
 "fields. Many other ORM tools directly persist instance variables. It is "
@@ -408,75 +239,42 @@
 "literal>, <literal>isFoo</literal> and <literal>setFoo</literal>. If "
 "required, you can switch to direct field access for particular properties."
 msgstr ""
-"<literal>Cat</literal> declara m&#x00e9;todos de acceso para todos sus "
-"campos persistente. Muchas otras herramientas ORM persisten directamente "
-"variables de instancia. Creemos que es mejor proveer una indirecci&#x00f3;n "
-"entre el esquema relacional y las estructuras internas de la clase. Por "
-"defecto, Hibernate persiste propiedades del estilo JavaBeans, y reconoce "
-"nombres de m&#x00e9;todo de la forma <literal>getFoo</literal>, "
-"<literal>isFoo</literal> y <literal>setFoo</literal>. Puedes cambiar a "
-"acceso directo a campos para propiedades en particular, de ser necesario."
+"<literal>Cat</literal> declara métodos de acceso para todos sus campos "
+"persistentes. Muchas otras herramientas ORM persisten directamente variables "
+"de instancia. Es mejor proporcionar una indirección entre el esquema "
+"relacional y las estructuras de datos internos de la clase. Por defecto, "
+"Hibernate persiste las propiedades del estilo JavaBeans, y reconoce los "
+"nombres de método de la forma <literal>getFoo</literal>, <literal>isFoo</"
+"literal> y <literal>setFoo</literal>. De ser necesario, puede cambiarse al "
+"acceso directo a campos para propiedades específicas."
 
 #. Tag: para
-#: persistent_classes.xml:151
 #, no-c-format
 msgid ""
 "Properties need <emphasis>not</emphasis> be declared public - Hibernate can "
 "persist a property with a default, <literal>protected</literal> or "
 "<literal>private</literal> get / set pair."
 msgstr ""
-"Las propiedades <emphasis>no</emphasis> necesitan ser declaradas p&#x00fa;"
-"blicas. Hibernate puede persistir una propiedad con un par get / set "
+"<emphasis>No</emphasis> es necesario declarar públicas las propiedades. "
+"Hibernate puede persistir una propiedad con un par get / set "
 "<literal>protected</literal> o <literal>private</literal>."
 
 #. Tag: title
-#: persistent_classes.xml:162
 #, no-c-format
 msgid "Implementing inheritance"
-msgstr "Implementando herencia"
+msgstr "Implementación de herencia"
 
 #. Tag: para
-#: persistent_classes.xml:164
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A subclass must also observe the first and second rules. It inherits its "
 "identifier property from the superclass, <literal>Cat</literal>. For example:"
 msgstr ""
-"Una subclase puede a su vez observar la primera y segunda regla. Hereda su "
-"propiedad identificadora de la superclase, <literal>Cat</literal>."
+"Una subclase también tiene que cumplir con la primera y la segunda regla. "
+"Hereda su propiedad identificadora de la superclase <literal>Cat</literal>. "
+"Por ejemplo:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:169
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"public class DomesticCat extends Cat {\n"
-"        private String name;\n"
-"\n"
-"        public String getName() {\n"
-"                return name;\n"
-"        }\n"
-"        protected void setName(String name) {\n"
-"                this.name=name;\n"
-"        }\n"
-"}]]>"
-msgstr ""
-"<![CDATA[package eg;\n"
-"\n"
-"public class DomesticCat extends Cat {\n"
-"        private String name;\n"
-"\n"
-"        public String getName() {\n"
-"                return name;\n"
-"        }\n"
-"        protected void setName(String name) {\n"
-"                this.name=name;\n"
-"        }\n"
-"}]]>"
-
 #. Tag: title
-#: persistent_classes.xml:173
 #, no-c-format
 msgid ""
 "Implementing <literal>equals()</literal> and <literal>hashCode()</literal>"
@@ -484,36 +282,32 @@
 "Implementando <literal>equals()</literal> y <literal>hashCode()</literal>"
 
 #. Tag: para
-#: persistent_classes.xml:175
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You have to override the <literal>equals()</literal> and <literal>hashCode()"
 "</literal> methods if you:"
 msgstr ""
-"Tienes que sobrescribir los m&#x00e9;todos <literal>equals()</literal> y "
-"<literal>hashCode()</literal> si :"
+"Tiene que sobrescribir los métodos <literal>equals()</literal> y "
+"<literal>hashCode()</literal> si:"
 
 #. Tag: para
-#: persistent_classes.xml:181
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "intend to put instances of persistent classes in a <literal>Set</literal> "
 "(the recommended way to represent many-valued associations); <emphasis>and</"
 "emphasis>"
 msgstr ""
-"piensas poner instancias de clases persistentes en un <literal>Set</literal> "
-"(la forma recomendada de representar asociaciones multivaluadas) "
+"piensa poner instancias de clases persistentes en un <literal>Set</literal> "
+"(la forma recomendada de representar asociaciones multivaluadas); "
 "<emphasis>y</emphasis>"
 
 #. Tag: para
-#: persistent_classes.xml:188
 #, no-c-format
 msgid "intend to use reattachment of detached instances"
-msgstr "piensas usar reasociaci&#x00f3;n de instancias separadas."
+msgstr "piensa utilizar reasociación de instancias separadas."
 
 #. Tag: para
-#: persistent_classes.xml:194
-#, fuzzy, no-c-format
+#, 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 "
@@ -522,15 +316,14 @@
 "semantics for <literal>Set</literal>s."
 msgstr ""
 "Hibernate garantiza la equivalencia de identidad persistente (fila de base "
-"de datos) y identidad Java s&#x00f3;lo dentro del &#x00e1;mbito de una "
-"sesi&#x00f3;n en particular. De modo que en el momento que mezclamos "
-"instancias recuperadas en sesiones diferentes, debemos implementar "
-"<literal>equals()</literal> y <literal>hashCode()</literal> si deseamos "
-"tener una sem&#x00e1;ntica significativa de <literal>Set</literal>s."
+"de datos) y de identidad Java sólamente dentro del ámbito de una sesión en "
+"particular. De modo que en el momento en que mezcla instancias recuperadas "
+"en sesiones diferentes, tiene que implementar <literal>equals()</literal> y "
+"<literal>hashCode()</literal> si desea tener una semántica significativa "
+"para <literal>Set</literal>s."
 
 #. Tag: para
-#: persistent_classes.xml:202
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The most obvious way is to implement <literal>equals()</literal>/"
 "<literal>hashCode()</literal> by comparing the identifier value of both "
@@ -547,27 +340,25 @@
 "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 ""
-"La forma m&#x00e1;s obvia es implementar <literal>equals()</literal>/"
+"La forma más obvia es implementar <literal>equals()</literal>/"
 "<literal>hashCode()</literal> comparando el valor identificador de ambos "
-"objetos. Si el valor es el mismo, ambos deben ser la misma fila de base de "
-"datos, por lo tanto son iguales (si ambos son agregados a un <literal>Set</"
-"literal>, s&#x00f3;lo tendremos un elemento en el <literal>Set</literal>). "
-"Desafortunadamente, no podemos usar este enfoque con identificadores "
-"generados! Hibernate s&#x00f3;lo asignar&#x00e1; valores identificadores a "
-"objetos que son persistentes, una instancia reci&#x00e9;n creada no "
-"tendr&#x00e1; ning&#x00fa;n valor identificador! Adem&#x00e1;s, si una "
-"instancia no est&#x00e1; salvada y est&#x00e1; actualmente en un "
-"<literal>Set</literal>, salvarla asignar&#x00e1; un valor identificador al "
-"objeto. Si <literal>equals()</literal> and <literal>hashCode()</literal> "
-"est&#x00e1;n basados en el valor identificador, el c&#x00f3;digo hash "
-"podr&#x00ed;a cambiar, rompiendo el contrato de <literal>Set</literal>. Ver "
-"el sitio web de Hibernate para una discusi&#x00f3;n completa de este "
-"problema. Observa que esto no es una incidencia de Hibernate, sino la "
-"sem&#x00e1;ntica normal de Java de identidad de objeto e igualdad."
+"objetos. Si el valor es el mismo, ambos deben ser la misma fila de la base "
+"de datos ya que son iguales. Si ambos son agregados a un <literal>Set</"
+"literal>, sólo tendremos un elemento en el <literal>Set</literal>). "
+"Desafortunadamente, no puede utilizar este enfoque con identificadores "
+"generados. Hibernate sólo asignará valores identificadores a objetos que son "
+"persistentes; una instancia recién creada no tendrá ningún valor "
+"identificador. Además, si una instancia no se encuentra guardada y está "
+"actualmente en un <literal>Set</literal>, al guardarla se asignará un valor "
+"identificador al objeto. Si <literal>equals()</literal> y <literal>hashCode()"
+"</literal> están basados en el valor identificador, el código hash podría "
+"cambiar, rompiendo el contrato del <literal>Set</literal>. Consulte el sitio "
+"web de Hibernate y allí encontrará una discusión completa sobre este "
+"problema. Este no es un problema de Hibernate, sino de la semántica normal "
+"de Java de identidad de objeto e igualdad."
 
 #. Tag: para
-#: persistent_classes.xml:216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you implement <literal>equals()</literal> and "
 "<literal>hashCode()</literal> using <emphasis>Business key equality</"
@@ -576,104 +367,47 @@
 "that would identify our instance in the real world (a <emphasis>natural</"
 "emphasis> candidate key):"
 msgstr ""
-"Recomendamos implementar <literal>equals()</literal> y <literal>hashCode()</"
-"literal> usando <emphasis>igualdad de clave de negocio (Business key "
-"equality)</emphasis>. Igualdad de clave de negocio significa que el m&#x00e9;"
-"todo <literal>equals()</literal> compara s&#x00f3;lo las propiedades que "
-"forman la clave de negocio, una clave que podr&#x00ed;a identificar nuestra "
+"Le recomendamos implementar <literal>equals()</literal> y <literal>hashCode()"
+"</literal> utilizando <emphasis>igualdad de clave empresarial (Business key "
+"equality)</emphasis>. Igualdad de clave empresarial significa que el método "
+"<literal>equals()</literal> sólamente compara las propiedades que forman la "
+"clave empresarial. Esta es una clave que podría identificar nuestra "
 "instancia en el mundo real (una clave candidata <emphasis>natural</"
 "emphasis>):"
 
-#. Tag: programlisting
-#: persistent_classes.xml:224
-#, no-c-format
-msgid ""
-"<![CDATA[public class Cat {\n"
-"\n"
-"    ...\n"
-"    public boolean equals(Object other) {\n"
-"        if (this == other) return true;\n"
-"        if ( !(other instanceof Cat) ) return false;\n"
-"\n"
-"        final Cat cat = (Cat) other;\n"
-"\n"
-"        if ( !cat.getLitterId().equals( getLitterId() ) ) return false;\n"
-"        if ( !cat.getMother().equals( getMother() ) ) return false;\n"
-"\n"
-"        return true;\n"
-"    }\n"
-"\n"
-"    public int hashCode() {\n"
-"        int result;\n"
-"        result = getMother().hashCode();\n"
-"        result = 29 * result + getLitterId();\n"
-"        return result;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-"<![CDATA[public class Cat {\n"
-"\n"
-"    ...\n"
-"    public boolean equals(Object other) {\n"
-"        if (this == other) return true;\n"
-"        if ( !(other instanceof Cat) ) return false;\n"
-"\n"
-"        final Cat cat = (Cat) other;\n"
-"\n"
-"        if ( !cat.getLitterId().equals( getLitterId() ) ) return false;\n"
-"        if ( !cat.getMother().equals( getMother() ) ) return false;\n"
-"\n"
-"        return true;\n"
-"    }\n"
-"\n"
-"    public int hashCode() {\n"
-"        int result;\n"
-"        result = getMother().hashCode();\n"
-"        result = 29 * result + getLitterId();\n"
-"        return result;\n"
-"    }\n"
-"\n"
-"}]]>"
-
 #. Tag: para
-#: persistent_classes.xml:226
 #, 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 "
+"candidate (see <xref linkend=\"transactions-basics-identity\" />). Immutable "
 "or unique properties are usually good candidates for a business key."
 msgstr ""
-"Nota que una clave de negocio no tiene que ser tan s&#x00f3;lida como una "
-"clave primaria candidata de base de datos (ver <xref linkend=\"transactions-"
-"basics-identity\"/>). Las propiedades inmutables o &#x00fa;nicas son "
-"usualmente buenas candidatas para una clave de negocio."
+"Una clave empresarial no tiene que ser tan sólida como una clave principal "
+"candidata de la base de datos (consulte la <xref linkend=\"transactions-"
+"basics-identity\" />). Las propiedades inmutables o únicas usualmente son "
+"buenas candidatas para una clave empresarial."
 
 #. Tag: title
-#: persistent_classes.xml:236
 #, no-c-format
 msgid "Dynamic models"
-msgstr "Modelos din&#x00e1;micos"
+msgstr "Modelos dinámicos"
 
 #. Tag: title
-#: persistent_classes.xml:239
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Nota"
 
-#. Tag: emphasis
-#: persistent_classes.xml:241
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
-"The following features are currently considered experimental and may change "
-"in the near future."
+"<emphasis>The following features are currently considered experimental and "
+"may change in the near future.</emphasis>"
 msgstr ""
-"Ten en cuenta que las siguientes funcionalidades est&#x00e1;n consideradas "
-"actualmente experimentales y pueden cambiar en el futuro cercano."
+"<emphasis>Las siguientes funcionalidades se consideran actualmente como "
+"experimentales y pueden cambiar pronto.</emphasis>"
 
 #. Tag: para
-#: persistent_classes.xml:246
-#, fuzzy, no-c-format
+#, 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 "
@@ -682,189 +416,63 @@
 "do not write persistent classes, only mapping files."
 msgstr ""
 "Las entidades persistentes no necesariamente tienen que estar representadas "
-"como clases POJO o como objetos JavaBean en tiempo de ejecuci&#x00f3;n. "
-"Hibernate soporta adem&#x00e1;s modelos din&#x00e1;micos (usando "
-"<literal>Map</literal>s de <literal>Map</literal>s en tiempo de "
-"ejecuci&#x00f3;n) y la representaci&#x00f3;n de entidades como &#x00e1;"
-"rboles de DOM4J. Con este enfoque no escribes clases persistentes, s&#x00f3;"
-"lo ficheros de mapeo."
+"como clases POJO o como objetos JavaBean en tiempo de ejecución. Hibernate "
+"también soporta modelos dinámicos (utilizando <literal>Map</literal>eos de "
+"<literal>Map</literal>eos en tiempo de ejecución) y la representación de "
+"entidades como árboles de DOM4J. No escriba clases persistentes con este "
+"enfoque, sólamente archivos de mapeo. "
 
 #. Tag: para
-#: persistent_classes.xml:254
 #, 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>SessionFactory</"
 "literal> using the <literal>default_entity_mode</literal> configuration "
-"option (see <xref linkend=\"configuration-optional-properties\"/>)."
+"option (see <xref linkend=\"configuration-optional-properties\" />)."
 msgstr ""
-"Por defecto, Hibernate funciona en modo POJO normal. Puedes establecer una "
-"representaci&#x00f3;n de entidad por defecto para una "
-"<literal>SessionFactory</literal> en particular usando la opci&#x00f3;n de "
-"configuraci&#x00f3;n <literal>default_entity_mode</literal> (ver <xref "
-"linkend=\"configuration-optional-properties\"/>)."
+"Por defecto, Hibernate funciona en modo POJO normal. Puede establecer un "
+"modo de representación de entidad predeterminado para una "
+"<literal>SessionFactory</literal> en particular utilizando la opción de "
+"configuración <literal>default_entity_mode</literal> (consulte <xref linkend="
+"\"configuration-optional-properties\" />)."
 
 #. Tag: para
-#: persistent_classes.xml:261
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following examples demonstrate the representation using <literal>Map</"
 "literal>s. First, in the mapping file an <literal>entity-name</literal> has "
 "to be declared instead of, or in addition to, a class name:"
 msgstr ""
-"Los siguientes ejemplos demuestran la representaci&#x00f3;n usando "
-"<literal>Map</literal>s. Primero, en el fichero de mapeo, tiene que "
-"declararse un <literal>entity-name</literal> en vez de (o como agregado a) "
-"un nombre de clase:"
+"Los siguientes ejemplos demuestran la representación utilizando "
+"<literal>Map</literal>eos. Primero, en el archivo de mapeo tiene que "
+"declararse un <literal>entity-name</literal> en lugar de, o además de un "
+"nombre de clase:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:267
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class entity-name=\"Customer\">\n"
-"\n"
-"        <id name=\"id\"\n"
-"            type=\"long\"\n"
-"            column=\"ID\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"\n"
-"        <property name=\"name\"\n"
-"            column=\"NAME\"\n"
-"            type=\"string\"/>\n"
-"\n"
-"        <property name=\"address\"\n"
-"            column=\"ADDRESS\"\n"
-"            type=\"string\"/>\n"
-"\n"
-"        <many-to-one name=\"organization\"\n"
-"            column=\"ORGANIZATION_ID\"\n"
-"            class=\"Organization\"/>\n"
-"\n"
-"        <bag name=\"orders\"\n"
-"            inverse=\"true\"\n"
-"            lazy=\"false\"\n"
-"            cascade=\"all\">\n"
-"            <key column=\"CUSTOMER_ID\"/>\n"
-"            <one-to-many class=\"Order\"/>\n"
-"        </bag>\n"
-"\n"
-"    </class>\n"
-"    \n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class entity-name=\"Customer\">\n"
-"\n"
-"        <id name=\"id\"\n"
-"            type=\"long\"\n"
-"            column=\"ID\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"\n"
-"        <property name=\"name\"\n"
-"            column=\"NAME\"\n"
-"            type=\"string\"/>\n"
-"\n"
-"        <property name=\"address\"\n"
-"            column=\"ADDRESS\"\n"
-"            type=\"string\"/>\n"
-"\n"
-"        <many-to-one name=\"organization\"\n"
-"            column=\"ORGANIZATION_ID\"\n"
-"            class=\"Organization\"/>\n"
-"\n"
-"        <bag name=\"orders\"\n"
-"            inverse=\"true\"\n"
-"            lazy=\"false\"\n"
-"            cascade=\"all\">\n"
-"            <key column=\"CUSTOMER_ID\"/>\n"
-"            <one-to-many class=\"Order\"/>\n"
-"        </bag>\n"
-"\n"
-"    </class>\n"
-"    \n"
-"</hibernate-mapping>]]>"
-
-#. Tag: para
-#: persistent_classes.xml:269
-#, 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 ""
-"Ten en cuenta que aunque las asociaciones se declaran usando nombres de "
-"clase objetivo, el tipo objetivo de una asociaci&#x00f3;n puede ser "
-"adem&#x00e1;s una entidad din&#x00e1;mica en vez de un POJO."
+"Aunque las asociaciones se declaran utilizando nombres de clase destino, el "
+"tipo destino de una asociación puede ser además una entidad dinámica en "
+"lugar de un POJO."
 
 #. Tag: para
-#: persistent_classes.xml:276
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "After setting the default entity mode to <literal>dynamic-map</literal> for "
 "the <literal>SessionFactory</literal>, you can, at runtime, work with "
 "<literal>Map</literal>s of <literal>Map</literal>s:"
 msgstr ""
-"Despu&#x00e9;s de establecer el modo de entidad por defecto a "
+"Después de establecer el modo de entidad predeterminado como "
 "<literal>dynamic-map</literal> para la <literal>SessionFactory</literal>, "
-"podemos trabajar en tiempo de ejecuci&#x00f3;n con <literal>Map</literal>s "
-"de <literal>Map</literal>s:"
+"puede trabajar en tiempo de ejecución con <literal>Map</literal>eos de "
+"<literal>Map</literal>eos: "
 
-#. Tag: programlisting
-#: persistent_classes.xml:282
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session s = openSession();\n"
-"Transaction tx = s.beginTransaction();\n"
-"Session s = openSession();\n"
-"\n"
-"// Create a customer\n"
-"Map david = new HashMap();\n"
-"david.put(\"name\", \"David\");\n"
-"\n"
-"// Create an organization\n"
-"Map foobar = new HashMap();\n"
-"foobar.put(\"name\", \"Foobar Inc.\");\n"
-"\n"
-"// Link both\n"
-"david.put(\"organization\", foobar);\n"
-"\n"
-"// Save both\n"
-"s.save(\"Customer\", david);\n"
-"s.save(\"Organization\", foobar);\n"
-"\n"
-"tx.commit();\n"
-"s.close();]]>"
-msgstr ""
-"<![CDATA[Session s = openSession();\n"
-"Transaction tx = s.beginTransaction();\n"
-"Session s = openSession();\n"
-"\n"
-"// Create a customer\n"
-"Map david = new HashMap();\n"
-"david.put(\"name\", \"David\");\n"
-"\n"
-"// Create an organization\n"
-"Map foobar = new HashMap();\n"
-"foobar.put(\"name\", \"Foobar Inc.\");\n"
-"\n"
-"// Link both\n"
-"david.put(\"organization\", foobar);\n"
-"\n"
-"// Save both\n"
-"s.save(\"Customer\", david);\n"
-"s.save(\"Organization\", foobar);\n"
-"\n"
-"tx.commit();\n"
-"s.close();]]>"
-
-#. Tag: para
-#: persistent_classes.xml:284
-#, 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 "
@@ -872,58 +480,26 @@
 "easily be normalized and sound, allowing to add a proper domain model "
 "implementation on top later on."
 msgstr ""
-"Las ventajas de un mapeo din&#x00e1;mico es r&#x00e1;pido tiempo de ciclo de "
-"prototipado sin la necesidad de implementaci&#x00f3;n de clases de entidad. "
-"Sin embargo, pierdes chequeo de tipos en tiempo de compilaci&#x00f3;n y muy "
-"probablemente tratar&#x00e1;s con muchas excepciones en tiempo de "
-"ejecuci&#x00f3;n. Gracias al mapeo de Hibernate, el esquema de base de datos "
-"puede estar facilmente sano y normalizado, permitiendo agregar una "
-"implementaci&#x00f3;n apropiada del modelo de dominio m&#x00e1;s tarde."
+"Una de las ventajas principales de un mapeo dinámico es el rápido tiempo de "
+"entrega del prototipado sin la necesidad de implementar clases de entidad. "
+"Sin embargo, pierde el chequeo de tipos en tiempo de compilación y muy "
+"probablemente tendrá que tratar con muchas excepciones en tiempo de "
+"ejecución. Gracias al mapeo de Hibernate, el esquema de base de datos se "
+"puede normalizar y volver sólido, permitiendo añadir una implementación "
+"apropiada del modelo de dominio más adelante."
 
 #. Tag: para
-#: persistent_classes.xml:292
 #, no-c-format
 msgid ""
 "Entity representation modes can also be set on a per <literal>Session</"
 "literal> basis:"
 msgstr ""
-"Los modos de representaci&#x00f3;n de entidad pueden ser establecidos por "
+"Los modos de representación de entidad se pueden establecer por "
 "<literal>Session</literal>:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:297
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session dynamicSession = pojoSession.getSession(EntityMode.MAP);\n"
-"\n"
-"// Create a customer\n"
-"Map david = new HashMap();\n"
-"david.put(\"name\", \"David\");\n"
-"dynamicSession.save(\"Customer\", david);\n"
-"...\n"
-"dynamicSession.flush();\n"
-"dynamicSession.close()\n"
-"...\n"
-"// Continue on pojoSession\n"
-"]]>"
-msgstr ""
-"<![CDATA[Session dynamicSession = pojoSession.getSession(EntityMode.MAP);\n"
-"\n"
-"// Create a customer\n"
-"Map david = new HashMap();\n"
-"david.put(\"name\", \"David\");\n"
-"dynamicSession.save(\"Customer\", david);\n"
-"...\n"
-"dynamicSession.flush();\n"
-"dynamicSession.close()\n"
-"...\n"
-"// Continue on pojoSession\n"
-"]]>"
-
-#. Tag: para
-#: persistent_classes.xml:300
-#, fuzzy, no-c-format
-msgid ""
 "Please note that the call to <literal>getSession()</literal> using an "
 "<literal>EntityMode</literal> is on the <literal>Session</literal> API, not "
 "the <literal>SessionFactory</literal>. That way, the new <literal>Session</"
@@ -933,35 +509,31 @@
 "literal>, and also leave the transaction and connection handling to the "
 "primary unit of work."
 msgstr ""
-"Por favor, ten en cuenta que la llamada a <literal>getSession()</literal> "
-"usando un <literal>EntityMode</literal> est&#x00e1; en la API de "
-"<literal>Session</literal>, no en la de <literal>SessionFactory</literal>. "
-"De esta forma, la nueva <literal>Session</literal> comparte la conexi&#x00f3;"
-"n JDBC, transacci&#x00f3;n y otra informaci&#x00f3;n de contexto. Esto "
-"significa que no tienes que llamar a <literal>flush()</literal> ni a "
-"<literal>close()</literal> en la <literal>Session</literal> secundaria, y "
-"tembi&#x00e9;n dejar el manejo de la transacci&#x00f3;n y de la "
-"conexi&#x00f3;n a la unidad de trabajo primaria."
+"Tenga en cuenta que la llamada a <literal>getSession()</literal> utilizando "
+"un <literal>EntityMode</literal> está en la API de <literal>Session</"
+"literal>, no en la de <literal>SessionFactory</literal>. De esta forma, la "
+"nueva <literal>Session</literal> comparte la conexión JDBC, la transacción y "
+"otra información de contexto. Esto significa que no tiene que llamar a "
+"<literal>flush()</literal> ni a <literal>close()</literal> en la "
+"<literal>Session</literal> secundaria, y también tiene que dejar el manejo "
+"de la transacción y de la conexión a la unidad de trabajo primaria. "
 
 #. Tag: para
-#: persistent_classes.xml:310
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "More information about the XML representation capabilities can be found in "
-"<xref linkend=\"xml\"/>."
+"<xref linkend=\"xml\" />."
 msgstr ""
-"Puede encontrarse m&#x00e1;s informaci&#x00f3;n sobre las capacidades de "
-"representaci&#x00f3;n XML en <xref linkend=\"xml\"/>."
+"Puede encontrar más información sobre las capacidades de representación de "
+"XML en <xref linkend=\"xml\" />."
 
 #. Tag: title
-#: persistent_classes.xml:318
 #, no-c-format
 msgid "Tuplizers"
-msgstr "UNTRANSLATED!!! Tuplizers"
+msgstr "Tuplizers"
 
 #. Tag: para
-#: persistent_classes.xml:320
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.tuple.Tuplizer</literal>, and its sub-interfaces, are "
 "responsible for managing a particular representation of a piece of data "
@@ -973,23 +545,17 @@
 "through its constructor. It also knows how to access the POJO properties "
 "using the defined property accessors."
 msgstr ""
-"<literal>org.hibernate.tuple.Tuplizer</literal>, and its sub-interfaces, are "
-"responsible for managing a particular representation of a piece of data, "
-"given that representation's <literal>org.hibernate.EntityMode</literal>. If "
-"a given piece of data is thought of as a data structure, then a tuplizer is "
-"the thing which 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 correpsonding tuplizer knows how create the POJO "
-"through its constructor and how to access the POJO properties using the "
-"defined property accessors. There are two high-level types of Tuplizers, "
-"represented by the <literal>org.hibernate.tuple.entity.EntityTuplizer</"
-"literal> and <literal>org.hibernate.tuple.component.ComponentTuplizer</"
-"literal> interfaces. <literal>EntityTuplizer</literal>s are responsible for "
-"managing the above mentioned contracts in regards to entities, while "
-"<literal>ComponentTuplizer</literal>s do the same for components."
+"<literal>org.hibernate.tuple.Tuplizer</literal> y sus subinterfaces son las "
+"responsables de administrar una representación en particular de un dato, "
+"dadas las representaciones de <literal>org.hibernate.EntityMode</literal>. "
+"Si un dato dado se considera como una estructura de datos entonces un "
+"tuplizer es la cosa que sabe como crear tal estructura de datos y sabe como "
+"extraer e insertar valores en dicha estructura de datos. Por ejemplo, para "
+"el modo de entidad POJO, el tuplizer correspondiente sabe como crear el POJO "
+"por medio de su constructor. También sabe como acceder a las propiedades "
+"POJO utilizando los accesores de propiedad definidos. "
 
 #. Tag: para
-#: persistent_classes.xml:330
 #, no-c-format
 msgid ""
 "There are two high-level types of Tuplizers, represented by the <literal>org."
@@ -999,10 +565,16 @@
 "mentioned contracts in regards to entities, while "
 "<literal>ComponentTuplizer</literal>s do the same for components."
 msgstr ""
+"Hay dos tipos altos de niveles de Tuplizers, representados por las "
+"interfaces <literal>org.hibernate.tuple.entity.EntityTuplizer</literal> y "
+"<literal>org.hibernate.tuple.component.ComponentTuplizer</literal>. Los "
+"<literal>EntityTuplizer</literal>s son los responsables de administrar los "
+"contratos mencionados anteriormente en relación con las entidades mientras "
+"que los <literal>ComponentTuplizer</literal>s hacen lo mismo para los "
+"componentes."
 
 #. Tag: para
-#: persistent_classes.xml:338
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Users can also plug in their own tuplizers. Perhaps you require that a "
 "<literal>java.util.Map</literal> implementation other than <literal>java."
@@ -1013,105 +585,22 @@
 "mapping they are meant to manage. Going back to the example of our customer "
 "entity:"
 msgstr ""
-"Users may also plug in their own tuplizers. Perhaps you require that a "
-"<literal>java.util.Map</literal> implementation other than <literal>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. Tuplizers definitions are attached to the entity or "
-"component mapping they are meant to manage. Going back to the example of our "
-"customer entity:"
+"Los usuarios también pueden enchufar sus propios tuplizers. Tal vez necesite "
+"que una implementación <literal>java.util.Map</literal> diferente de "
+"<literal>java.util.HashMap</literal> se utilice en el modo de entidad de "
+"mapeo dinámico. O quizás necesite definir una estrategia de generación proxy "
+"diferente de la que se utiliza por defecto. Se pueden obtener ambas al "
+"definir una implementación tuplizer personalizada. Las definiciones de los "
+"tuplizers se encuentran sujetas a la entidad o componente de mapeo que se "
+"supone que tienen que administrar. Regresando al ejemplo de nuestra entidad "
+"de cliente:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:347
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    <class entity-name=\"Customer\">\n"
-"        <!--\n"
-"            Override the dynamic-map entity-mode\n"
-"            tuplizer for the customer entity\n"
-"        -->\n"
-"        <tuplizer entity-mode=\"dynamic-map\"\n"
-"                class=\"CustomMapTuplizerImpl\"/>\n"
-"\n"
-"        <id name=\"id\" type=\"long\" column=\"ID\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"\n"
-"        <!-- other properties -->\n"
-"        ...\n"
-"    </class>\n"
-"</hibernate-mapping>\n"
-"\n"
-"\n"
-"public class CustomMapTuplizerImpl\n"
-"        extends org.hibernate.tuple.entity.DynamicMapEntityTuplizer {\n"
-"    // override the buildInstantiator() method to plug in our custom map...\n"
-"    protected final Instantiator buildInstantiator(\n"
-"            org.hibernate.mapping.PersistentClass mappingInfo) {\n"
-"        return new CustomMapInstantiator( mappingInfo );\n"
-"    }\n"
-"\n"
-"    private static final class CustomMapInstantiator\n"
-"            extends org.hibernate.tuple.DynamicMapInstantitor {\n"
-"        // override the generateMap() method to return our custom map...\n"
-"            protected final Map generateMap() {\n"
-"                    return new CustomMap();\n"
-"            }\n"
-"    }\n"
-"}]]>"
-msgstr ""
-"<![CDATA[<hibernate-mapping>\n"
-"                            <class entity-name=\"Customer\">\n"
-"                                    <!--\n"
-"                                        Override the dynamic-map entity-"
-"mode\n"
-"                                        tuplizer for the customer entity\n"
-"                                        -->\n"
-"                                    <tuplizer entity-mode=\"dynamic-map\"\n"
-"                                              class=\"CustomMapTuplizerImpl"
-"\"/>\n"
-"                                    \n"
-"                                    <id name=\"id\" type=\"long\" column=\"ID"
-"\">\n"
-"                                            <generator class=\"sequence\"/>\n"
-"                                    </id>\n"
-"                                    \n"
-"                                    <!-- other properties -->\n"
-"                                    ...\n"
-"                            </class>\n"
-"                    </hibernate-mapping>\n"
-"                    \n"
-"                    \n"
-"                    public class CustomMapTuplizerImpl\n"
-"                    extends org.hibernate.tuple.entity."
-"DynamicMapEntityTuplizer {\n"
-"                    // override the buildInstantiator() method to plug in "
-"our custom map...\n"
-"                    protected final Instantiator buildInstantiator(\n"
-"                    org.hibernate.mapping.PersistentClass mappingInfo) {\n"
-"                    return new CustomMapInstantiator( mappingInfo );\n"
-"                    }\n"
-"                    \n"
-"                    private static final class CustomMapInstantiator\n"
-"                    extends org.hibernate.tuple.DynamicMapInstantitor {\n"
-"                    // override the generateMap() method to return our "
-"custom map...\n"
-"                    protected final Map generateMap() {\n"
-"                    return new CustomMap();\n"
-"                    }\n"
-"                    }\n"
-"                    }]]>"
-
 #. Tag: title
-#: persistent_classes.xml:353
 #, no-c-format
 msgid "EntityNameResolvers"
-msgstr ""
+msgstr "EntityNameResolvers"
 
 #. Tag: para
-#: persistent_classes.xml:355
 #, no-c-format
 msgid ""
 "The <interfacename>org.hibernate.EntityNameResolver</interfacename> "
@@ -1128,158 +617,41 @@
 "dynamicentity.tuplizer2</package>. Here is some of the code from that "
 "package for illustration."
 msgstr ""
+"La interfaz <interfacename>org.hibernate.EntityNameResolver</interfacename> "
+"es un contrato para resolver el nombre de la entidad de una instancia de "
+"entidad dada. La interfaz define un solo método "
+"<methodname>resolveEntityName</methodname>, el cual se le pasa la instancia "
+"entidad y se espera que retorne el nombre de entidad apropriado (se permite "
+"nulo e indicaría que el resolvedor no sabe cómo resolver el nombre de la "
+"entidad de la instancia de entidad dada). Generalmente hablando, un "
+"<interfacename>org.hibernate.EntityNameResolver</interfacename> será más "
+"útil en el caso de modelos dinámicos. Un ejemplo puede ser el usar "
+"interfaces con proxis como su modelo de dominio. La suite de prueba de "
+"hibernate tiene un ejemplo de este estilo exacto de uso bajo el <package>org."
+"hibernate.test.dynamicentity.tuplizer2</package>. Aquí está algo del código "
+"de ese paquete para su ilustración."
 
-#. Tag: programlisting
-#: persistent_classes.xml:367
-#, no-c-format
-msgid ""
-"/**\n"
-" * A very trivial JDK Proxy InvocationHandler implementation where we proxy "
-"an interface as\n"
-" * the domain model and simply store persistent state in an internal Map.  "
-"This is an extremely\n"
-" * trivial example meant only for illustration.\n"
-" */\n"
-"public final class DataProxyHandler implements InvocationHandler {\n"
-"        private String entityName;\n"
-"        private HashMap data = new HashMap();\n"
-"\n"
-"        public DataProxyHandler(String entityName, Serializable id) {\n"
-"                this.entityName = entityName;\n"
-"                data.put( \"Id\", id );\n"
-"        }\n"
-"\n"
-"        public Object invoke(Object proxy, Method method, Object[] args) "
-"throws Throwable {\n"
-"                String methodName = method.getName();\n"
-"                if ( methodName.startsWith( \"set\" ) ) {\n"
-"                        String propertyName = methodName.substring( 3 );\n"
-"                        data.put( propertyName, args[0] );\n"
-"                }\n"
-"                else if ( methodName.startsWith( \"get\" ) ) {\n"
-"                        String propertyName = methodName.substring( 3 );\n"
-"                        return data.get( propertyName );\n"
-"                }\n"
-"                else if ( \"toString\".equals( methodName ) ) {\n"
-"                        return entityName + \"#\" + data.get( \"Id\" );\n"
-"                }\n"
-"                else if ( \"hashCode\".equals( methodName ) ) {\n"
-"                        return new Integer( this.hashCode() );\n"
-"                }\n"
-"                return null;\n"
-"        }\n"
-"\n"
-"        public String getEntityName() {\n"
-"                return entityName;\n"
-"        }\n"
-"\n"
-"        public HashMap getData() {\n"
-"                return data;\n"
-"        }\n"
-"}\n"
-"\n"
-"/**\n"
-" *\n"
-" */\n"
-"public class ProxyHelper {\n"
-"    public static String extractEntityName(Object object) {\n"
-"        // Our custom java.lang.reflect.Proxy instances actually bundle\n"
-"        // their appropriate entity name, so we simply extract it from "
-"there\n"
-"        // if this represents one of our proxies; otherwise, we return null\n"
-"        if ( Proxy.isProxyClass( object.getClass() ) ) {\n"
-"            InvocationHandler handler = Proxy.getInvocationHandler"
-"( object );\n"
-"            if ( DataProxyHandler.class.isAssignableFrom( handler.getClass"
-"() ) ) {\n"
-"                DataProxyHandler myHandler = ( DataProxyHandler ) handler;\n"
-"                return myHandler.getEntityName();\n"
-"            }\n"
-"        }\n"
-"        return null;\n"
-"    }\n"
-"\n"
-"    // various other utility methods ....\n"
-"\n"
-"}\n"
-"\n"
-"/**\n"
-" * The EntityNameResolver implementation.\n"
-" * IMPL NOTE : An EntityNameResolver really defines a strategy for how "
-"entity names should be\n"
-" * resolved.  Since this particular impl can handle resolution for all of "
-"our entities we want to\n"
-" * take advantage of the fact that SessionFactoryImpl keeps these in a Set "
-"so that we only ever\n"
-" * have one instance registered.  Why?  Well, when it comes time to resolve "
-"an entity name,\n"
-" * Hibernate must iterate over all the registered resolvers.  So keeping "
-"that number down\n"
-" * helps that process be as speedy as possible.  Hence the equals and "
-"hashCode impls\n"
-" */\n"
-"public class MyEntityNameResolver implements EntityNameResolver {\n"
-"    public static final MyEntityNameResolver INSTANCE = new "
-"MyEntityNameResolver();\n"
-"\n"
-"    public String resolveEntityName(Object entity) {\n"
-"        return ProxyHelper.extractEntityName( entity );\n"
-"    }\n"
-"\n"
-"    public boolean equals(Object obj) {\n"
-"        return getClass().equals( obj.getClass() );\n"
-"    }\n"
-"\n"
-"    public int hashCode() {\n"
-"        return getClass().hashCode();\n"
-"    }\n"
-"}\n"
-"\n"
-"public class MyEntityTuplizer extends PojoEntityTuplizer {\n"
-"        public MyEntityTuplizer(EntityMetamodel entityMetamodel, "
-"PersistentClass mappedEntity) {\n"
-"                super( entityMetamodel, mappedEntity );\n"
-"        }\n"
-"\n"
-"        public EntityNameResolver[] getEntityNameResolvers() {\n"
-"                return new EntityNameResolver[] { MyEntityNameResolver."
-"INSTANCE };\n"
-"        }\n"
-"\n"
-"    public String determineConcreteSubclassEntityName(Object entityInstance, "
-"SessionFactoryImplementor factory) {\n"
-"        String entityName = ProxyHelper.extractEntityName"
-"( entityInstance );\n"
-"        if ( entityName == null ) {\n"
-"            entityName = super.determineConcreteSubclassEntityName"
-"( entityInstance, factory );\n"
-"        }\n"
-"        return entityName;\n"
-"    }\n"
-"\n"
-"    ...\n"
-"}"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:369
 #, no-c-format
 msgid ""
 "In order to register an <interfacename>org.hibernate.EntityNameResolver</"
 "interfacename> users must either:"
 msgstr ""
+"Con el fin de registrar un <interfacename>org.hibernate.EntityNameResolver</"
+"interfacename> los usuarios deben:"
 
 #. Tag: para
-#: persistent_classes.xml:373
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Implement a custom <link linkend=\"persistent-classes-tuplizers\">Tuplizer</"
 "link>, implementing the <methodname>getEntityNameResolvers</methodname> "
 "method."
 msgstr ""
+"Implementar un <xref linkend=\"persistent-classes-tuplizers\" /> "
+"personalizado, implementando el método <methodname>getEntityNameResolvers</"
+"methodname>."
 
 #. Tag: para
-#: persistent_classes.xml:379
 #, no-c-format
 msgid ""
 "Register it with the <classname>org.hibernate.impl.SessionFactoryImpl</"
@@ -1287,18 +659,7 @@
 "hibernate.SessionFactory</interfacename>) using the "
 "<methodname>registerEntityNameResolver</methodname> method."
 msgstr ""
-
-#~ msgid "There are four main rules to follow here:"
-#~ msgstr "Aqu&#x00ed; hay cuatro reglas principales a seguir:"
-
-#~ msgid ""
-#~ "TODO: Document user-extension framework in the property and proxy packages"
-#~ msgstr ""
-#~ "PORHACER: Documentar el framework de extensiones del usuario en los "
-#~ "paquetes de propiedad y proxies."
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+"Registrarlo con el <classname>org.hibernate.impl.SessionFactoryImpl</"
+"classname> (el cual es la clase de implementación para <interfacename>org."
+"hibernate.SessionFactory</interfacename>) usando el método "
+"<methodname>registerEntityNameResolver</methodname>."

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/portability.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/portability.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/portability.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,32 +1,39 @@
-# Language es-ES translations for Branch package.
-# Automatically generated, 2009.
-#
+# translation of portability.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: Branch 3_3\n"
+"Project-Id-Version: portability\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-23 18:41+0000\n"
-"PO-Revision-Date: 2009-06-16 18:47+0000\n"
-"Last-Translator: Automatically generated\n"
-"Language-Team: none\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-07 10:51+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: portability.xml:26
 #, no-c-format
 msgid "Database Portability Considerations"
-msgstr ""
+msgstr "Consideraciones de la portabilidad de la base de datos"
 
 #. Tag: title
-#: portability.xml:29
 #, no-c-format
 msgid "Portability Basics"
-msgstr ""
+msgstr "Aspectos básicos de la portabilidad"
 
 #. Tag: para
-#: portability.xml:31
 #, no-c-format
 msgid ""
 "One of the selling points of Hibernate (and really Object/Relational Mapping "
@@ -38,15 +45,22 @@
 "run against any number of databases without changes to your code, and "
 "ideally without any changes to the mapping metadata."
 msgstr ""
+"Uno de los aspectos que más vende de Hibernate (y realmente del mapeo objeto/"
+"relacional en sí) es la noción de portabilidad de la base de datos. Podría "
+"ser el caso de un administrador de sistemas migrando de una base de datos de "
+"un vendedor a otro, o podría ser un marco de trabajo o una aplicación "
+"desplegable consumiendo Hibernate para que apunte simultáneamente a "
+"múltiples productos de bases de datos. Sin importar el escenario exacto, la "
+"idea básica es que quiere que Hibernate le ayude a ejecutar frente a "
+"cualquier número de bases de datos sin cambiar el código e idealmente sin "
+"cambiar los metadatos de mapeo. "
 
 #. Tag: title
-#: portability.xml:42
 #, no-c-format
 msgid "Dialect"
-msgstr ""
+msgstr "Dialecto"
 
 #. Tag: para
-#: portability.xml:44
 #, no-c-format
 msgid ""
 "The first line of portability for Hibernate is the dialect, which is a "
@@ -58,15 +72,22 @@
 "your particular database is not among them, it is not terribly difficult to "
 "write your own."
 msgstr ""
+"La primera línea de portabilidad para Hibernate es el dialecto, el cual es "
+"una especialización del contrato <classname>org.hibernate.dialect.Dialect</"
+"classname>. Un dialecto encapsula todas las diferencias en la manera en que "
+"Hibernate debe comunicarse con una base de datos en particular para lograr "
+"alguna tarea como el obtener un valor de secuencia o el estructurar una "
+"petición SELECT. Hibernate reune un gran rango de dialectos para muchas de "
+"las bases de datos más populares. Si encuentra que su base de datos en "
+"particular no se encuentra entre estos, no es demasiado dificil es escribir "
+"el propio."
 
 #. Tag: title
-#: portability.xml:55
 #, no-c-format
 msgid "Dialect resolution"
-msgstr ""
+msgstr "Resolución del dialecto"
 
 #. Tag: para
-#: portability.xml:57
 #, no-c-format
 msgid ""
 "Originally, Hibernate would always require that users specify which dialect "
@@ -75,9 +96,14 @@
 "their users to configure the Hibernate dialect or defining their own method "
 "of setting that value."
 msgstr ""
+"Originalmente, Hibernate siempre requería que los usuarios especificaran qué "
+"dialecto utilizar. En el caso de aquellos usuarios que buscaban apuntar a "
+"múltiples bases de datos de manera simultánea con su construcción eso "
+"representaba un problema. Generalmente esto requería que los usuarios "
+"configuraran el dialecto de Hibernate o que definieran su propio método para "
+"establecer ese valor. "
 
 #. Tag: para
-#: portability.xml:64
 #, no-c-format
 msgid ""
 "Starting with version 3.2, Hibernate introduced the notion of automatically "
@@ -87,17 +113,23 @@
 "that this resolution was limited to databases Hibernate know about ahead of "
 "time and was in no way configurable or overrideable."
 msgstr ""
+"Empezando con la versión 3.2, Hibernate introdujo la noción de detectar "
+"automáticamente el dialecto a utilizar con base en los <interfacename>java."
+"sql.DatabaseMetaData</interfacename> que se obtuvieron de una "
+"<interfacename>java.sql.Connection</interfacename> a esa base de datos. Esto "
+"era mucho mejor pero esta resolución estaba limitada a las bases de datos "
+"que Hibernate conoce por adelantado y de ninguna manera era configurable ni "
+"se podía sobreescribir."
 
 #. Tag: para
-#: portability.xml:72
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Starting with version 3.3, Hibernate has a fare more powerful way to "
 "automatically determine which dialect to should be used by relying on a "
 "series of delegates which implement the <interfacename>org.hibernate.dialect."
 "resolver.DialectResolver</interfacename> which defines only a single method:"
-"<programlisting><![CDATA[public Dialect resolveDialect(DatabaseMetaData "
-"metaData) throws JDBCConnectionException]]></programlisting>. The basic "
+"<programlisting role=\"JAVA\">public Dialect resolveDialect(DatabaseMetaData "
+"metaData) throws JDBCConnectionException</programlisting>. The basic "
 "contract here is that if the resolver 'understands' the given database "
 "metadata then it returns the corresponding Dialect; if not it returns null "
 "and the process continues to the next resolver. The signature also "
@@ -108,9 +140,24 @@
 "All other exceptions result in a warning and continuing on to the next "
 "resolver."
 msgstr ""
+"Empezando por la versión 3.3, Hibernate cuenta con una manera más poderosa "
+"de determinar automáticamente cuál dialecto se debe utilizar dependiendo de "
+"una serie de delegados, los cuales implementan el <interfacename>org."
+"hibernate.dialect.resolver.DialectResolver</interfacename> el cual define "
+"solo un método único:<programlisting>public Dialect resolveDialect"
+"(DatabaseMetaData metaData) throws JDBCConnectionException</programlisting>. "
+"El contrato básico aquí es que si el resolvedor 'entiende' los metadatos de "
+"la base de datos dada entonces retorna el dialecto correspondiente; si no "
+"entonces retorna nulo y el proceso continua al siguiente resolvedor. La "
+"firma también identifica <exceptionname>org.hibernate.exception."
+"JDBCConnectionException</exceptionname> ya que posiblemente se presenta. Una "
+"JDBCConnectionException aquí se interpreta como un problema de conexión \"no "
+"transitorio\" (también conocido como no-recuperable) y se utiliza para "
+"indicar que se deben detener inmediatamente los intentos de resolución. "
+"Todas las otras excepciones resultan en una advertencia y continua al "
+"siguiente resolvedor. "
 
 #. Tag: para
-#: portability.xml:85
 #, no-c-format
 msgid ""
 "The cool part about these resolvers is that users can also register their "
@@ -124,16 +171,25 @@
 "<constant>DIALECT_RESOLVERS</constant> constant on <classname>org.hibernate."
 "cfg.Environment</classname>)."
 msgstr ""
+"La parte divertida de estos resolvedores es que los usuarios también pueden "
+"registrar sus propios resolvedores personalizados, los cuales se procesarán "
+"antes de los incluídos en Hibernate. Esto puede llegar a ser útil en un "
+"número de situaciones diferentes: permite una fácil integración para la auto-"
+"detección de dialectos más allá de los que se envían junto con Hibernate; le "
+"permite especificar el uso de un dialecto personalizado cuando se reconoce "
+"una base de datos en particular; etc. Para registrar uno o más resolvedores, "
+"simplemente especifiquelos (separados por comas o espacios) usando la "
+"configuración 'hibernate.dialect_resolvers' (consulte la constante "
+"<constant>DIALECT_RESOLVERS</constant> en <classname>org.hibernate.cfg."
+"Environment</classname>)."
 
 #. Tag: title
-#: portability.xml:98
 #, no-c-format
 msgid "Identifier generation"
-msgstr ""
+msgstr "Generación del identificador"
 
 #. Tag: para
-#: portability.xml:100
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "When considering portability between databases, another important decision "
 "is selecting the identifier generation stratagy you want to use. Originally "
@@ -151,38 +207,94 @@
 "reference entities within a persistence context it must then issue the "
 "insert immediately when the users requests the entitiy be associated with "
 "the session (like via save() e.g.) regardless of current transactional "
-"semantics. <note> <para> Hibernate was changed slightly once the implication "
-"of this was better understood so that the insert is delayed in cases where "
-"that is feasible. </para> </note> The underlying issue is that the actual "
-"semanctics of the application itself changes in these cases."
+"semantics."
 msgstr ""
+"Al considerar la portabilidad entre bases de datos, otra decisión importante "
+"es el seleccionar la estrategia de generación del identificador que quiere "
+"utilizar. Originalmente Hibernate brindaba el generador <emphasis>nativo</"
+"emphasis> para este propósito, el cual tenía el objetivo de seleccionar "
+"entre las estrategias <emphasis>sequence</emphasis>, <emphasis>identity</"
+"emphasis> o <emphasis>table</emphasis> dependiendo de la capacidad de la "
+"base de datos subyacente. Sin embargo, una de las implicaciones de este "
+"enfoque se presenta al tener como destino algunas bases de datos que "
+"soportan la generación de <emphasis>identidad</emphasis> y algunas no. La "
+"generación de <emphasis>identidad</emphasis> depende de la definición SQL de "
+"una columna IDENTITY (o auto-incremento) para administrar el valor del "
+"identificador; es lo que se conoce como una estrategia de generación post-"
+"insert ya que el insert de hecho debe tener lugar antes de saber el valor "
+"del identificador. Ya que Hibernate depende de este valor de identificador "
+"para referenciar de maner única a las entidades dentro de un contexto de "
+"persistencia entonces debe emitir el insert inmediatamente cuando los "
+"usuarios solicitan que la entidad se asocie con la sesión (por ejemplo, por "
+"medio de save()) sin importar la semántica transaccional actual. El problema "
+"subyacente es que la semántica de la aplicación misma cambia en estos casos."
 
 #. Tag: para
-#: portability.xml:125
+#, fuzzy, no-c-format
+msgid ""
+"Hibernate was changed slightly once the implication of this was better "
+"understood so that the insert is delayed in cases where that is feasible."
+msgstr ""
+"Hibernate se ha mejorado de manera que el insert se retrasa en los casos en "
+"donde es posible. "
+
+#. Tag: note
 #, no-c-format
 msgid ""
+"The underlying issue is that the actual semanctics of the application itself "
+"changes in these cases."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
 "Starting with version 3.2.3, Hibernate comes with a set of <ulink url="
 "\"http://in.relation.to/2082.lace\">enhanced</ulink> identifier generators "
-"targetting portability in a much different way. <note> <para> There are "
-"specifically 2 bundled <emphasis>enhanced</emphasis>generators: "
-"<itemizedlist> <listitem> <para> <classname>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</classname> </para> </listitem> <listitem> <para> "
-"<classname>org.hibernate.id.enhanced.TableGenerator</classname> </para> </"
-"listitem> </itemizedlist> </para> </note> The idea behind these generators "
-"is to port the actual semantics of the identifer value generation to the "
-"different databases. For example, the <classname>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</classname> mimics the behavior of a sequence on "
-"databases which do not support sequences by using a table."
+"targetting portability in a much different way."
 msgstr ""
+"Desde la versión 3.2.3, Hibernate viene junto con un grupo de generadores "
+"identificadores <ulink url=\"http://in.relation.to/2082.lace\">mejorados</"
+"ulink> apuntando a la portabilidad de una manera muy diferente."
 
+#. Tag: para
+#, no-c-format
+msgid ""
+"There are specifically 2 bundled <emphasis>enhanced</emphasis>generators:"
+msgstr ""
+"Hay especificamente 2 paquetes de generadores <emphasis>mejorados</emphasis>:"
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname>"
+msgstr ""
+"<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname>"
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<classname>org.hibernate.id.enhanced.TableGenerator</classname>"
+msgstr "<classname>org.hibernate.id.enhanced.TableGenerator</classname>"
+
+#. Tag: note
+#, no-c-format
+msgid ""
+"The idea behind these generators is to port the actual semantics of the "
+"identifer value generation to the different databases. For example, the "
+"<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname> "
+"mimics the behavior of a sequence on databases which do not support "
+"sequences by using a table."
+msgstr ""
+"La idea detrás de estos generadores es el llevar la semántica de la "
+"generación del valor identificador a las diferentes bases de datos. Por "
+"ejemplo, el <classname>org.hibernate.id.enhanced.SequenceStyleGenerator</"
+"classname> asemeja el comportamiento de una secuencia en las bases de datos "
+"que no soportan secuencias usando una tabla."
+
 #. Tag: title
-#: portability.xml:154
 #, no-c-format
 msgid "Database functions"
-msgstr ""
+msgstr "Funciones de la base de datos"
 
 #. Tag: para
-#: portability.xml:157
 #, no-c-format
 msgid ""
 "This is an area in Hibernate in need of improvement. In terms of portability "
@@ -191,7 +303,6 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:164
 #, no-c-format
 msgid ""
 "SQL functions can be referenced in many ways by users. However, not all "
@@ -200,9 +311,14 @@
 "knows how to render that particular function, perhaps even using a totally "
 "different physical function call."
 msgstr ""
+"Los usuarios pueden referenciar las funciones de SQL de muchas maneras. Sin "
+"embargo, no todas las bases de datos soportan el mismo grupo de funciones. "
+"Hibernate, proporciona una manera de mapear un nombre de una función "
+"<emphasis>lógica</emphasis> a un delegado, el cual sabe cómo entregar esa "
+"función en particular, tal vez incluso usando una llamada de función física "
+"totalmente diferente."
 
 #. Tag: para
-#: portability.xml:170
 #, no-c-format
 msgid ""
 "Technically this function registration is handled through the <classname>org."
@@ -211,24 +327,37 @@
 "having to provide a custom dialect. This specific behavior is not fully "
 "completed as of yet."
 msgstr ""
+"Técnicamente este registro de función se maneja por medio de la clase "
+"<classname>org.hibernate.dialect.function.SQLFunctionRegistry</classname>, "
+"la cual tiene el propósito de permitirle a los usuarios el proporcionar "
+"definiciones de funciones personalizadas sin tener que brindar un dialecto "
+"personalizado. Este comportamiento especifico todavía no está del todo "
+"completo."
 
 #. Tag: para
-#: portability.xml:177
 #, no-c-format
 msgid ""
 "It is sort of implemented such that users can programatically register "
 "functions with the <classname>org.hibernate.cfg.Configuration</classname> "
 "and those functions will be recognized for HQL."
 msgstr ""
+"De cierta manera está implementado para que los usuarios puedan registrar "
+"programáticamente las funciones con la <classname>org.hibernate.cfg."
+"Configuration</classname> y aquellas funciones serán reconocidas por HQL."
 
 #. Tag: title
-#: portability.xml:187
 #, no-c-format
 msgid "Type mappings"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:189
 #, no-c-format
 msgid "This section scheduled for completion at a later date..."
 msgstr ""
+
+#~ msgid ""
+#~ "This is a new area in Hibernate and as such it is not as mature as the "
+#~ "overall Hibernate experience."
+#~ msgstr ""
+#~ "Esta es una nueva área en Hibernate y como tal no es tan madura como lo "
+#~ "es en general el resto de Hibernate. "

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/preface.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/preface.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/preface.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,20 +1,35 @@
-#, fuzzy
+# translation of Preface.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of preface.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: Preface\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-16 18:47+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-07 10:45+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: preface.xml:29
 #, no-c-format
 msgid "Preface"
 msgstr "Prefacio"
 
 #. Tag: para
-#: preface.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "Working with object-oriented software and a relational database can be "
@@ -24,31 +39,30 @@
 "representation from an object model to a relational data model with a SQL-"
 "based schema."
 msgstr ""
-"Trabajar con software orientado a objetos y una base de datos relacional "
-"puede ser inc&#x00f3;modo y consumir tiempo en los entornos de empresa de "
-"hoy. Hibernate es una herramienta de mapeo objeto/relacional para entornos "
-"Java. El t&#x00e9;rmino mapeo objeto/relacional (MOR) hace referencia a la "
-"t&#x00e9;cnica de mapear una representaci&#x00f3;n de datos desde un modelo "
-"de objetos a un modelo de datos relacional con un esquema basado en SQL."
+"El trabajar con software orientado a objetos y con una base de datos "
+"relacional puede llegar a ser engorroso y puede llegar a tomar bastante "
+"tiempo en los entornos empresariales de hoy en día. Hibernate es una "
+"herramienta de mapeo objeto/relacional para entornos Java. El término mapeo "
+"objeto/relacional (ORM) se refiere a la técnica de mapear una representación "
+"de datos desde un modelo de objeto a un modelo de datos relacionales con un "
+"esquema basado en SQL."
 
 #. Tag: para
-#: preface.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate not only takes care of the mapping from Java classes to database "
 "tables (and from Java data types to SQL data types), but also provides data "
 "query and retrieval facilities. It can also significantly reduce development "
 "time otherwise spent with manual data handling in SQL and JDBC."
 msgstr ""
-"Hibernate no s&#x00f3;lo se encarga de mapear de clases Java a tablas de "
-"base de datos (y de tipos de datos de Java a tipos de datos SQL), sino que "
-"tambi&#x00e9;n provee facilidades de consulta y recuperaci&#x00f3;n de datos "
-"y puede reducir significativamente el tiempo de desarrollo que de otra forma "
-"se gasta en el manejo de los datos en SQL y JDBC."
+"Hibernate no sólamente se ocupa del mapeo desde las clases Java a las tablas "
+"de las bases de datos (y desde los tipos de datos de Java a los tipos de "
+"datos de SQL), sino que también facilita la consulta y recuperación de "
+"datos. Esto puede reducir de manera importante el tiempo de desarrollo que "
+"se tomaría con el manejo de datos de forma manual en SQL y JDBC."
 
 #. Tag: para
-#: preface.xml:46
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's goal is to relieve the developer from 95 percent of common data "
 "persistence related programming tasks. Hibernate may not be the best "
@@ -59,51 +73,49 @@
 "specific SQL code and will help with the common task of result set "
 "translation from a tabular representation to a graph of objects."
 msgstr ""
-"La meta de Hibernate es relevar al desarrollador del 95 por ciento de las "
-"tareas comunes relacionadas a la programaci&#x00f3;n de la persistencia de "
-"los datos. Hibernate puede no ser la mejor soluci&#x00f3;n para aplicaciones "
-"que usan solamente procedimientos almacenados para implementar la l&#x00f3;"
-"gica de negocio en la base de datos, es mas &#x00fa;til con modelos de "
-"dominio orientados a objetos y l&#x00f3;gica de negocio en middle-tier "
-"basada en Java. Sin embargo, Hibernate ciertamente puede ayudarte a quitar o "
-"encapsular c&#x00f3;digo SQL espec&#x00ed;fico de vendedor y ayudar&#x00e1; "
-"con la tarea com&#x00fa;n de traducci&#x00f3;n de resultados desde una "
-"representaci&#x00f3;n tabular a un grafo de objetos."
+"La meta de Hibernate es aliviar el trabajo del desarrollador en 95% de la "
+"persistencia de datos comunes relacionados con tareas de programación. Es "
+"posible que Hibernate no sea la mejor solución para aquellas aplicaciones "
+"centralizadas en datos que sólamente utilizan los procedimientos almacenados "
+"para implementar la lógica empresarial en la base de datos, Hibernate es "
+"mucho más útil con modelos de dominio orientados a objetos y con lógica "
+"empresarial middle-tier con base en Java. Sin embargo, Hibernate ciertamente "
+"le puede ayudar a eliminar o a encapsular código SQL específico del vendedor "
+"y le ayudará con la tarea común de traducción del grupo de resultados desde "
+"una representación tabular a un grafo de objetos."
 
 #. Tag: para
-#: preface.xml:56
 #, no-c-format
 msgid ""
 "If you are new to Hibernate and Object/Relational Mapping or even Java, "
 "please follow these steps:"
 msgstr ""
-"Si eres nuevo en Hibernate y lo del Mapeo Objeto/Relacional o incluso en "
-"Java, sigue por favor estos pasos:"
+"Si usted es nuevo en el tema de Hibernate y del Mapeo Objeto/Relacional o "
+"inclusive en Java por favor siga los siguientes pasos:"
 
 #. Tag: para
-#: preface.xml:63
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"Read <xref linkend=\"tutorial\"/> for a tutorial with step-by-step "
+"Read <xref linkend=\"tutorial\" /> for a tutorial with step-by-step "
 "instructions. The source code for the tutorial is included in the "
 "distribution in the <literal>doc/reference/tutorial/</literal> directory."
 msgstr ""
-"Lee <xref linkend=\"tutorial\"/> para un tutorial de 30 minutos, usando "
-"Tomcat."
+"Consulte el <xref linkend=\"tutorial\"/>, el cual es un tutorial con "
+"instrucciones paso por paso. El código fuente para el tutorial se encuentra "
+"incluido en la distribución en el directorio <literal>doc/reference/tutorial/"
+"</literal>. "
 
 #. Tag: para
-#: preface.xml:71
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"Read <xref linkend=\"architecture\"/> to understand the environments where "
+"Read <xref linkend=\"architecture\" /> to understand the environments where "
 "Hibernate can be used."
 msgstr ""
-"Lee <xref linkend=\"architecture\"/> para entender los entornos en los que "
-"puede ser usado Hibernate."
+"Consulte el <xref linkend=\"architecture\" /> para comprender los entornos "
+"en donde se puede utilizar Hibernate."
 
 #. Tag: para
-#: preface.xml:77
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "View the <literal>eg/</literal> directory in the Hibernate distribution. It "
 "contains a simple standalone application. Copy your JDBC driver to the "
@@ -112,64 +124,59 @@
 "command prompt in the distribution directory, type <literal>ant eg</literal> "
 "(using Ant), or under Windows, type <literal>build eg</literal>."
 msgstr ""
-"Dale una mirada al directorio <literal>eg/</literal> en la distribuci&#x00f3;"
-"n de Hibernate, contiene una aplicaci&#x00f3;n independiente simple. Copia "
-"tu driver JDBC al directorio <literal>lib/</literal> y edita <literal>etc/"
-"hibernate.properties</literal>, especificando los valores correctos para tu "
-"base de datos. Desde l&#x00ed;nea de comandos en el directorio de la "
-"distribuci&#x00f3;n, tipea <literal>ant eg</literal> (usando Ant), o bajo "
-"Windows, tipea <literal>build eg</literal>."
+"Déle un vistazo al directorio <literal>eg/</literal> en la distribución de "
+"Hibernate. Este comprende una aplicación autónoma simple. Copie su "
+"compilador JDBC al directorio <literal>lib/</literal> y edite <literal>etc/"
+"hibernate.properties</literal>, especificando los valores correctos para su "
+"base de datos. Desde un intérprete de comandos en el directorio de la "
+"distribución, escriba <literal>ant eg</literal> (utilizando Ant), o bajo "
+"Windows, escriba <literal>build eg</literal>."
 
 #. Tag: para
-#: preface.xml:88
 #, fuzzy, no-c-format
 msgid ""
 "Use this reference documentation as your primary source of information. "
 "Consider reading <biblioref linkend=\"biblio-JPwH\"></biblioref> if you need "
 "more help with application design, or if you prefer a step-by-step tutorial. "
-"Also visit <ulink url=\"http://caveatemptor.hibernate.org\"></ulink> and "
-"download the example application from <biblioref linkend=\"biblio-JPwH\"></"
-"biblioref>."
+"Also visit <ulink url=\"http://caveatemptor.hibernate.org\" /> and download "
+"the example application from <biblioref linkend=\"biblio-JPwH\"></biblioref>."
 msgstr ""
-"Usa esta documentaci&#x00f3;n de referencia como tu fuente de "
-"informaci&#x00f3;n primaria. Ten en consideraci&#x00f3;n leer <emphasis>Java "
-"Persistence with Hibernate</emphasis> (http://www.manning.com/bauer2) si "
-"necesitas mas ayuda con el dise&#x00f1;o de aplicaciones o si prefieres un "
-"tutorial paso a paso. Visita tambi&#x00e9;n http://caveatemptor.hibernate."
-"org y descarga la aplicaci&#x00f3;n de ejemplo para Java Persistence with "
-"Hibernate."
+"Utilice esta documentación de referencia como su fuente principal de "
+"información. Considere el leer <emphasis>Java Persistence with Hibernate</"
+"emphasis> (http://www.manning.com/bauer2) si necesita más ayuda con el "
+"diseño de la aplicación o si prefiere un tutorial paso por paso. También "
+"visite http://caveatemptor.hibernate.org y descargue la aplicación  "
+"deejemplo para la persistencia de Java con Hibernate."
 
 #. Tag: para
-#: preface.xml:98
 #, no-c-format
 msgid "FAQs are answered on the Hibernate website."
-msgstr "Los FAQs son respondidos en el sitio web de Hibernate."
+msgstr ""
+"En el sitio web de Hibernate encontrará las respuestas a las preguntas más "
+"frecuentes."
 
 #. Tag: para
-#: preface.xml:103
 #, fuzzy, no-c-format
 msgid ""
 "Links to third party demos, examples, and tutorials are maintained on the "
 "Hibernate website."
 msgstr ""
-"En el sitio web de Hibernate hay enlaces a demos de terceros, ejemplos y "
-"tutoriales."
+"En el sitio web de Hibernate encontrará un enlace a la demostraciones de "
+"terceros, ejemplos y tutoriales."
 
 #. Tag: para
-#: preface.xml:109
 #, no-c-format
 msgid ""
 "The Community Area on the Hibernate website is a good resource for design "
 "patterns and various integration solutions (Tomcat, JBoss AS, Struts, EJB, "
 "etc.)."
 msgstr ""
-"El Area de Comunidad en el sitio web de Hibernate es una buena fuente de "
-"patrones de dise&#x00f1;o y varias soluciones de integraci&#x00f3;n (Tomcat, "
-"JBoss, Struts, EJB, etc.)."
+"El área de la comunidad en el sitio web de Hibernate es un buen recurso para "
+"encontrar patrones de diseño y varias soluciones de integración (Tomcat, "
+"JBoss AS, Struts, EJB, etc)."
 
 #. Tag: para
-#: preface.xml:117
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you have questions, use the user forum linked on the Hibernate website. "
 "We also provide a JIRA issue tracking system for bug reports and feature "
@@ -177,15 +184,14 @@
 "developer mailing list. If you are interested in translating this "
 "documentation into your language, contact us on the developer mailing list."
 msgstr ""
-"Si tienes preguntas, usa el foro de usuarios enlazado en el sitio web de "
-"Hibernate. Tambi&#x00e9;n proveemos un sistema de seguimiento JIRA para "
-"reportes de defectos y peticiones de nuevas caracter&#x00ed;sticas. Si estas "
-"interesado en el desarrollo de Hibernate, &#x00fa;nete a la lista de correo "
-"de desarrolladores. Si estas interesado en traducir esta documentaci&#x00f3;"
-"n a tu lenguaje, cont&#x00e1;ctanos en la lista de correo de desarrolladores."
+"Si tiene alguna pregunta, diríjase al sitio web de Hibernate en donde "
+"encontrará un enlace al foro de usuarios. También proporcionamos un sistema "
+"de localización para reportes de errores JIRA y solicitud de funciones. Si "
+"está interesado en el desarrollo de Hibernate, únase a la lista de correo de "
+"los desarrolladores. Si le interesa traducir esta documentación a su propio "
+"idioma, contáctenos en la lista de correo de los desarrolladores."
 
 #. Tag: para
-#: preface.xml:125
 #, no-c-format
 msgid ""
 "Commercial development support, production support, and training for "
@@ -194,29 +200,8 @@
 "critical component of the JBoss Enterprise Middleware System (JEMS) suite of "
 "products."
 msgstr ""
-"A trav&#x00e9;s de JBoss Inc. (see http://www.hibernate.org/"
-"SupportTraining/) hay disponibilidad de soporte comercial de desarrollo, "
-"soporte de producci&#x00f3;n y entrenamiento en Hibernate. Hibernate es un "
-"proyecto de la suite de productos de c&#x00f3;digo abierto JBoss "
-"Professional."
-
-#. Tag: title
-#: preface.xml:133
-#, no-c-format
-msgid "Feedback"
-msgstr ""
-
-#. Tag: para
-#: preface.xml:134
-#, no-c-format
-msgid ""
-"Use <ulink url=\"http://opensource.atlassian.com/projects/hibernate"
-"\">Hibernate JIRA</ulink> to report errors or request enhacements to this "
-"documentation."
-msgstr ""
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+"JBoss Inc. proporciona soporte para desarrollo comercial, soporte para "
+"producción y entrenamiento (vea http://www.hibernate.org/SupportTraining/). "
+"Hibernate es un proyecto de Código Abierto Profesional y es un componente "
+"crítico de la suite de productos de JBoss Enterprise Middleware System "
+"(JEMS)."

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/query_criteria.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/query_criteria.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/query_criteria.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,64 +1,62 @@
-#, fuzzy
+# translation of query_criteria.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: query_criteria\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-05 17:44+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: query_criteria.xml:29
 #, no-c-format
 msgid "Criteria Queries"
-msgstr "Consultas por Criterios"
+msgstr "Consultas por criterios"
 
 #. Tag: para
-#: query_criteria.xml:31
 #, no-c-format
 msgid "Hibernate features an intuitive, extensible criteria query API."
 msgstr ""
-"Acompa&#x00f1;a a Hibernate una API de consultas por criterios intuitiva y "
+"Acompaña a Hibernate una API de consultas por criterios intuitiva y "
 "extensible."
 
 #. Tag: title
-#: query_criteria.xml:36
 #, no-c-format
 msgid "Creating a <literal>Criteria</literal> instance"
-msgstr "Creando una instancia de <literal>Criteria</literal>"
+msgstr "Creación de una instancia <literal>Criteria</literal>"
 
 #. Tag: para
-#: query_criteria.xml:38
 #, no-c-format
 msgid ""
 "The interface <literal>org.hibernate.Criteria</literal> represents a query "
 "against a particular persistent class. The <literal>Session</literal> is a "
 "factory for <literal>Criteria</literal> instances."
 msgstr ""
-"La interface <literal>org.hibernate.Criteria</literal> representa una "
+"La interfaz <literal>org.hibernate.Criteria</literal> representa una "
 "consulta contra una clase persistente en particular. La <literal>Session</"
-"literal> es una f&#x00e1;brica de instancias de <literal>Criteria</literal>."
+"literal> es una fábrica de instancias de <literal>Criteria</literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:44
-#, no-c-format
-msgid ""
-"<![CDATA[Criteria crit = sess.createCriteria(Cat.class);\n"
-"crit.setMaxResults(50);\n"
-"List cats = crit.list();]]>"
-msgstr ""
-"<![CDATA[Criteria crit = sess.createCriteria(Cat.class);\n"
-"crit.setMaxResults(50);\n"
-"List cats = crit.list();]]>"
-
 #. Tag: title
-#: query_criteria.xml:49
 #, no-c-format
 msgid "Narrowing the result set"
-msgstr "Estrechando el conjunto resultado"
+msgstr "Límitando el conjunto de resultados"
 
 #. Tag: para
-#: query_criteria.xml:51
 #, no-c-format
 msgid ""
 "An individual query criterion is an instance of the interface <literal>org."
@@ -66,275 +64,93 @@
 "criterion.Restrictions</literal> defines factory methods for obtaining "
 "certain built-in <literal>Criterion</literal> types."
 msgstr ""
-"Un criterio individual de consulta es una instancia de la interface "
+"Un criterio individual de consulta es una instancia de la interfaz "
 "<literal>org.hibernate.criterion.Criterion</literal>. La clase <literal>org."
-"hibernate.criterion.Restrictions</literal> define m&#x00e9;todos de f&#x00e1;"
-"brica para obtener ciertos tipos prefabricados de <literal>Criterion</"
-"literal>."
+"hibernate.criterion.Restrictions</literal> define métodos de fábrica para "
+"obtener ciertos tipos incorporados de <literal>Criterion</literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:59
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .add( Restrictions.between(\"weight\", minWeight, maxWeight) )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .add( Restrictions.between(\"weight\", minWeight, maxWeight) )\n"
-"    .list();]]>"
-
 #. Tag: para
-#: query_criteria.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Restrictions can be grouped logically."
-msgstr "Las restricciones pueden ser agrupadas l&#x00f3;gicamente."
+msgstr "Las restricciones se pueden agrupar lógicamente. "
 
-#. Tag: programlisting
-#: query_criteria.xml:65
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .add( Restrictions.or(\n"
-"        Restrictions.eq( \"age\", new Integer(0) ),\n"
-"        Restrictions.isNull(\"age\")\n"
-"    ) )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .add( Restrictions.or(\n"
-"        Restrictions.eq( \"age\", new Integer(0) ),\n"
-"        Restrictions.isNull(\"age\")\n"
-"    ) )\n"
-"    .list();]]>"
-
-#. Tag: programlisting
-#: query_criteria.xml:67
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.in( \"name\", new String[] { \"Fritz\", \"Izi\", \"Pk"
-"\" } ) )\n"
-"    .add( Restrictions.disjunction()\n"
-"        .add( Restrictions.isNull(\"age\") )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(0) ) )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(1) ) )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(2) ) )\n"
-"    ) )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.in( \"name\", new String[] { \"Fritz\", \"Izi\", \"Pk"
-"\" } ) )\n"
-"    .add( Restrictions.disjunction()\n"
-"        .add( Restrictions.isNull(\"age\") )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(0) ) )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(1) ) )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(2) ) )\n"
-"    ) )\n"
-"    .list();]]>"
-
-#. Tag: para
-#: query_criteria.xml:69
-#, fuzzy, no-c-format
-msgid ""
 "There are a range of built-in criterion types (<literal>Restrictions</"
 "literal> subclasses). One of the most useful allows you to specify SQL "
 "directly."
 msgstr ""
-"Hay un gran rango de tipos de criterio prefabricados (subclases de "
-"<literal>Restrictions</literal>), pero uno que es especialmente útil te deja "
+"Hay un rango de tipos de criterios incorporados (subclases de "
+"<literal>Restrictions</literal>). Uno de los más útiles le permite "
 "especificar SQL directamente."
 
-#. Tag: programlisting
-#: query_criteria.xml:74
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.sqlRestriction(\"lower({alias}.name) like lower(?)\", "
-"\"Fritz%\", Hibernate.STRING) )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.sql(\"lower({alias}.name) like lower(?)\", \"Fritz%"
-"\", Hibernate.STRING) )\n"
-"    .list();]]>"
-
 #. Tag: para
-#: query_criteria.xml:76
 #, no-c-format
 msgid ""
 "The <literal>{alias}</literal> placeholder with be replaced by the row alias "
 "of the queried entity."
 msgstr ""
-"El sitio <literal>{alias}</literal> ser&#x00e1; remplazado por el alias de "
-"fila de la entidad consultada."
+"El sitio <literal>{alias}</literal> será remplazado por el alias de fila de "
+"la entidad consultada."
 
 #. Tag: para
-#: query_criteria.xml:81
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also obtain a criterion from a <literal>Property</literal> instance. "
 "You can create a <literal>Property</literal> by calling <literal>Property."
 "forName()</literal>:"
 msgstr ""
-"Un enfoque alternativo para obtener un criterio es tomarlo de una instancia "
-"de <literal>Property</literal>. Puedes crear una <literal>Property</literal> "
-"llamando a <literal>Property.forName()</literal>."
+"También puede obtener un criterio de una instancia <literal>Property</"
+"literal>. Puede crear una <literal>Property</literal> llamando a "
+"<literal>Property.forName()</literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:87
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"Property age = Property.forName(\"age\");\n"
-"List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.disjunction()\n"
-"        .add( age.isNull() )\n"
-"        .add( age.eq( new Integer(0) ) )\n"
-"        .add( age.eq( new Integer(1) ) )\n"
-"        .add( age.eq( new Integer(2) ) )\n"
-"    ) )\n"
-"    .add( Property.forName(\"name\").in( new String[] { \"Fritz\", \"Izi\", "
-"\"Pk\" } ) )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[\n"
-"Property age = Property.forName(\"age\");\n"
-"List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.disjunction()\n"
-"        .add( age.isNull() )\n"
-"        .add( age.eq( new Integer(0) ) )\n"
-"        .add( age.eq( new Integer(1) ) )\n"
-"        .add( age.eq( new Integer(2) ) )\n"
-"    ) )\n"
-"    .add( Property.forName(\"name\").in( new String[] { \"Fritz\", \"Izi\", "
-"\"Pk\" } ) )\n"
-"    .list();]]>"
-
 #. Tag: title
-#: query_criteria.xml:92
 #, no-c-format
 msgid "Ordering the results"
-msgstr "Ordenando los resultados"
+msgstr "Orden de los resultados"
 
 #. Tag: para
-#: query_criteria.xml:94
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can order the results using <literal>org.hibernate.criterion.Order</"
 "literal>."
 msgstr ""
-"Puedes ordenar los resultados usando <literal>org.hibernate.criterion.Order</"
+"Puede ordenar los resultados usando <literal>org.hibernate.criterion.Order</"
 "literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:98
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"F%\")\n"
-"    .addOrder( Order.asc(\"name\") )\n"
-"    .addOrder( Order.desc(\"age\") )\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"F%\")\n"
-"    .addOrder( Order.asc(\"name\") )\n"
-"    .addOrder( Order.desc(\"age\") )\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-
-#. Tag: programlisting
-#: query_criteria.xml:100
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Property.forName(\"name\").like(\"F%\") )\n"
-"    .addOrder( Property.forName(\"name\").asc() )\n"
-"    .addOrder( Property.forName(\"age\").desc() )\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Property.forName(\"name\").like(\"F%\") )\n"
-"    .addOrder( Property.forName(\"name\").asc() )\n"
-"    .addOrder( Property.forName(\"age\").desc() )\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-
 #. Tag: title
-#: query_criteria.xml:105
 #, no-c-format
 msgid "Associations"
 msgstr "Asociaciones"
 
 #. Tag: para
-#: query_criteria.xml:107
 #, no-c-format
 msgid ""
 "By navigating associations using <literal>createCriteria()</literal> you can "
 "specify constraints upon related entities:"
 msgstr ""
+"Al navegar asociaciones usando <literal>createCriteria()</literal> puede "
+"especificar restricciones en entidades relacionadas:"
 
-#. Tag: programlisting
-#: query_criteria.xml:112
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"F%\") )\n"
-"    .createCriteria(\"kittens\")\n"
-"        .add( Restrictions.like(\"name\", \"F%\") )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"F%\")\n"
-"    .createCriteria(\"kittens\")\n"
-"        .add( Restrictions.like(\"name\", \"F%\")\n"
-"    .list();]]>"
-
-#. Tag: para
-#: query_criteria.xml:114
-#, fuzzy, no-c-format
-msgid ""
 "The second <literal>createCriteria()</literal> returns a new instance of "
 "<literal>Criteria</literal> that refers to the elements of the "
 "<literal>kittens</literal> collection."
 msgstr ""
-"nota que el segundo <literal>createCriteria()</literal> devuelve una nueva "
-"instancia de <literal>Criteria</literal>, que hace referencia a los "
-"elementos de la colecci&#x00f3;n <literal>kittens</literal>."
+"El segundo <literal>createCriteria()</literal> retorna una nueva instancia "
+"de <literal>Criteria</literal>, que se refiere a los elementos de la "
+"colección <literal>kittens</literal>."
 
 #. Tag: para
-#: query_criteria.xml:120
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is also an alternate form that is useful in certain circumstances:"
-msgstr "La siguiente forma alternativa es útil en ciertas circunstancias."
+msgstr "Hay una alternativa que es útil en ciertas circunstancias:"
 
-#. Tag: programlisting
-#: query_criteria.xml:124
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .createAlias(\"kittens\", \"kt\")\n"
-"    .createAlias(\"mate\", \"mt\")\n"
-"    .add( Restrictions.eqProperty(\"kt.name\", \"mt.name\") )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .createAlias(\"kittens\", \"kt\")\n"
-"    .createAlias(\"mate\", \"mt\")\n"
-"    .add( Restrictions.eqProperty(\"kt.name\", \"mt.name\") )\n"
-"    .list();]]>"
-
 #. Tag: para
-#: query_criteria.xml:126
 #, no-c-format
 msgid ""
 "(<literal>createAlias()</literal> does not create a new instance of "
@@ -344,303 +160,153 @@
 "<literal>Criteria</literal>.)"
 
 #. Tag: para
-#: query_criteria.xml:131
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The kittens collections held by the <literal>Cat</literal> instances "
 "returned by the previous two queries are <emphasis>not</emphasis> pre-"
 "filtered by the criteria. If you want to retrieve just the kittens that "
 "match the criteria, you must use a <literal>ResultTransformer</literal>."
 msgstr ""
-"&#x00a1;Observa que las colecciones de gatitos tenidas por las instancias de "
-"<literal>Cat</literal> devueltas por las dos consultas previas <emphasis>no</"
-"emphasis> est&#x00e1;n prefiltradas por los criterios! Si deseas recuperar "
-"s&#x00f3;lo los gatitos que emparejen los criterios, debes usar "
-"<literal>returnMaps()</literal>."
+"Las colecciones de gatitos de las instancias <literal>Cat</literal> "
+"retornadas por las dos consultas previas <emphasis>no</emphasis> están "
+"prefiltradas por los criterios. Si desea recuperar sólo los gatitos que "
+"coincidan con los criterios debe usar un <literal>ResultTransformer</"
+"literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:138
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .createCriteria(\"kittens\", \"kt\")\n"
-"        .add( Restrictions.eq(\"name\", \"F%\") )\n"
-"    .setResultTransformer(Criteria.ALIAS_TO_ENTITY_MAP)\n"
-"    .list();\n"
-"Iterator iter = cats.iterator();\n"
-"while ( iter.hasNext() ) {\n"
-"    Map map = (Map) iter.next();\n"
-"    Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);\n"
-"    Cat kitten = (Cat) map.get(\"kt\");\n"
-"}]]>"
+msgid "Additionally you may manipulate the result set using a left outer join:"
 msgstr ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .createCriteria(\"kittens\", \"kt\")\n"
-"        .add( Restrictions.eq(\"name\", \"F%\") )\n"
-"    .returnMaps()\n"
-"    .list();\n"
-"Iterator iter = cats.iterator();\n"
-"while ( iter.hasNext() ) {\n"
-"    Map map = (Map) iter.next();\n"
-"    Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);\n"
-"    Cat kitten = (Cat) map.get(\"kt\");\n"
-"}]]>"
 
-#. Tag: title
-#: query_criteria.xml:143
+#. Tag: para
 #, no-c-format
-msgid "Dynamic association fetching"
-msgstr "Recuperaci&#x00f3;n din&#x00e1;mica de asociaciones"
+msgid ""
+"This will return all of the <literal>Cat</literal>s with a mate whose name "
+"starts with \"good\" ordered by their mate's age, and all cats who do not "
+"have a mate. This is useful when there is a need to order or limit in the "
+"database prior to returning complex/large result sets, and removes many "
+"instances where multiple queries would have to be performed and the results "
+"unioned by java in memory."
+msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"You can specify association fetching semantics at runtime using "
-"<literal>setFetchMode()</literal>."
+"Without this feature, first all of the cats without a mate would need to be "
+"loaded in one query."
 msgstr ""
-"Puedes especificar la sem&#x00e1;ntica de recuperaci&#x00f3;n de "
-"asociaciones en tiempo de ejecuci&#x00f3;n usando <literal>setFetchMode()</"
-"literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:150
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .setFetchMode(\"mate\", FetchMode.EAGER)\n"
-"    .setFetchMode(\"kittens\", FetchMode.EAGER)\n"
-"    .list();]]>"
+"A second query would need to retreive the cats with mates who's name started "
+"with \"good\" sorted by the mates age."
 msgstr ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .setFetchMode(\"mate\", FetchMode.EAGER)\n"
-"    .setFetchMode(\"kittens\", FetchMode.EAGER)\n"
-"    .list();]]>"
 
 #. Tag: para
-#: query_criteria.xml:152
 #, no-c-format
+msgid "Thirdly, in memory; the lists would need to be joined manually."
+msgstr ""
+
+#. Tag: title
+#, no-c-format
+msgid "Dynamic association fetching"
+msgstr "Recuperación dinámica de asociaciones"
+
+#. Tag: para
+#, no-c-format
 msgid ""
+"You can specify association fetching semantics at runtime using "
+"<literal>setFetchMode()</literal>."
+msgstr ""
+"Puede especificar la semántica de recuperación de asociaciones en tiempo de "
+"ejecución usando <literal>setFetchMode()</literal>. "
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
 "This query will fetch both <literal>mate</literal> and <literal>kittens</"
-"literal> by outer join. See <xref linkend=\"performance-fetching\"/> for "
+"literal> by outer join. See <xref linkend=\"performance-fetching\" /> for "
 "more information."
 msgstr ""
-"Esta consulta recuperar&#x00e1; tanto <literal>mate</literal> como "
-"<literal>kittens</literal> por uni&#x00f3;n exterior (outer join). Ver <xref "
-"linkend=\"performance-fetching\"/> para m&#x00e1;s informaci&#x00f3;n."
+"Esta consulta recuperará tanto <literal>mate</literal> como "
+"<literal>kittens</literal> por unión exterior (outer join). Consulte la "
+"<xref linkend=\"performance-fetching\" /> para obtener más información."
 
 #. Tag: title
-#: query_criteria.xml:160
 #, no-c-format
 msgid "Example queries"
-msgstr "Consultas por ejemplos"
+msgstr "Consultas ejemplo"
 
 #. Tag: para
-#: query_criteria.xml:162
 #, no-c-format
 msgid ""
 "The class <literal>org.hibernate.criterion.Example</literal> allows you to "
 "construct a query criterion from a given instance."
 msgstr ""
-"La clase <literal>org.hibernate.criterion.Example</literal> te permite "
+"La clase <literal>org.hibernate.criterion.Example</literal> le permite "
 "construir un criterio de consulta a partir de una instancia dada."
 
-#. Tag: programlisting
-#: query_criteria.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = new Cat();\n"
-"cat.setSex('F');\n"
-"cat.setColor(Color.BLACK);\n"
-"List results = session.createCriteria(Cat.class)\n"
-"    .add( Example.create(cat) )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[Cat cat = new Cat();\n"
-"cat.setSex('F');\n"
-"cat.setColor(Color.BLACK);\n"
-"List results = session.createCriteria(Cat.class)\n"
-"    .add( Example.create(cat) )\n"
-"    .list();]]>"
-
 #. Tag: para
-#: query_criteria.xml:169
 #, no-c-format
 msgid ""
 "Version properties, identifiers and associations are ignored. By default, "
 "null valued properties are excluded."
 msgstr ""
-"Las propiedades de versi&#x00f3;n, los identificadores y las asociaciones "
-"son ignorados. Por defecto, las propiedades valuadas a nulo son exclu&#x00ed;"
-"das."
+"Las propiedades de versión, los identificadores y las asociaciones se "
+"ignoran. Por defecto, las propiedades valuadas como nulas se excluyen."
 
 #. Tag: para
-#: query_criteria.xml:174
 #, no-c-format
 msgid "You can adjust how the <literal>Example</literal> is applied."
-msgstr "Puedes ajustar c&#x00f3;mo se aplica el <literal>Example</literal>."
+msgstr "Puede modificar la aplicación del <literal>Example</literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:178
-#, no-c-format
-msgid ""
-"<![CDATA[Example example = Example.create(cat)\n"
-"    .excludeZeroes()           //exclude zero valued properties\n"
-"    .excludeProperty(\"color\")  //exclude the property named \"color\"\n"
-"    .ignoreCase()              //perform case insensitive string "
-"comparisons\n"
-"    .enableLike();             //use like for string comparisons\n"
-"List results = session.createCriteria(Cat.class)\n"
-"    .add(example)\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[Example example = Example.create(cat)\n"
-"    .excludeZeroes()           //exclude zero valued properties\n"
-"    .excludeProperty(\"color\")  //exclude the property named \"color\"\n"
-"    .ignoreCase()              //perform case insensitive string "
-"comparisons\n"
-"    .enableLike();             //use like for string comparisons\n"
-"List results = session.createCriteria(Cat.class)\n"
-"    .add(example)\n"
-"    .list();]]>"
-
 #. Tag: para
-#: query_criteria.xml:180
 #, no-c-format
 msgid "You can even use examples to place criteria upon associated objects."
 msgstr ""
-"Puedes incluso usar ejemplos para colocar criterios sobre objetos asociados."
+"Puede incluso usar ejemplos para colocar criterios sobre objetos asociados."
 
-#. Tag: programlisting
-#: query_criteria.xml:184
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .add( Example.create(cat) )\n"
-"    .createCriteria(\"mate\")\n"
-"        .add( Example.create( cat.getMate() ) )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .add( Example.create(cat) )\n"
-"    .createCriteria(\"mate\")\n"
-"        .add( Example.create( cat.getMate() ) )\n"
-"    .list();]]>"
-
 #. Tag: title
-#: query_criteria.xml:189
 #, no-c-format
 msgid "Projections, aggregation and grouping"
-msgstr "Proyecciones, agregaci&#x00f3;n y agrupamiento"
+msgstr "Proyecciones, agregación y agrupamiento"
 
 #. Tag: para
-#: query_criteria.xml:190
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The class <literal>org.hibernate.criterion.Projections</literal> is a "
 "factory for <literal>Projection</literal> instances. You can apply a "
 "projection to a query by calling <literal>setProjection()</literal>."
 msgstr ""
 "La clase <literal>org.hibernate.criterion.Projections</literal> es una "
-"f&#x00e1;brica de instancias de <literal>Projection</literal>. Aplicamos una "
-"proyecci&#x00f3;n a una consulta llamando a <literal>setProjection()</"
-"literal>."
+"fábrica de instancias de <literal>Projection</literal>. Puede aplicar una "
+"proyección a una consulta llamando a <literal>setProjection()</literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.rowCount() )\n"
-"    .add( Restrictions.eq(\"color\", Color.BLACK) )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.rowCount() )\n"
-"    .add( Restrictions.eq(\"color\", Color.BLACK) )\n"
-"    .list();]]>"
-
-#. Tag: programlisting
-#: query_criteria.xml:198
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount() )\n"
-"        .add( Projections.avg(\"weight\") )\n"
-"        .add( Projections.max(\"weight\") )\n"
-"        .add( Projections.groupProperty(\"color\") )\n"
-"    )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount() )\n"
-"        .add( Projections.avg(\"weight\") )\n"
-"        .add( Projections.max(\"weight\") )\n"
-"        .add( Projections.groupProperty(\"color\") )\n"
-"    )\n"
-"    .list();]]>"
-
 #. Tag: para
-#: query_criteria.xml:200
 #, no-c-format
 msgid ""
 "There is no explicit \"group by\" necessary in a criteria query. Certain "
 "projection types are defined to be <emphasis>grouping projections</"
 "emphasis>, which also appear in the SQL <literal>group by</literal> clause."
 msgstr ""
-"No es necesario ningún \"group by\" expl&#x00ed;cito en una consulta por "
+"No es necesario ningún \"agrupamiento por\" explícito en una consulta por "
 "criterios. Ciertos tipos de proyecciones son definidos para ser "
-"<emphasis>proyecciones agrupadas</emphasis>, que adem&#x00e1;s aparecen en "
-"la cl&#x00e1;usula SQL <literal>group by</literal>."
+"<emphasis>proyecciones agrupadas</emphasis>, que además aparecen en la "
+"cláusula SQL <literal>group by</literal>."
 
 #. Tag: para
-#: query_criteria.xml:206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An alias can be assigned to a projection so that the projected value can be "
 "referred to in restrictions or orderings. Here are two different ways to do "
 "this:"
 msgstr ""
-"Puede opcionalmente asignarse un alias a una proyecci&#x00f3;n, de modo que "
-"el valor proyectado pueda ser referido en restricciones u ordenamientos. "
-"Aqu&#x00ed; hay dos formas diferentes de hacer esto:"
+"Puede asignar un alias a una proyección de modo que el valor proyectado "
+"pueda ser referido en restricciones u ordenamientos. Aquí hay dos formas "
+"diferentes de hacer esto:"
 
-#. Tag: programlisting
-#: query_criteria.xml:212
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.alias( Projections.groupProperty(\"color\"), "
-"\"colr\" ) )\n"
-"    .addOrder( Order.asc(\"colr\") )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.alias( Projections.groupProperty(\"color\"), "
-"\"colr\" ) )\n"
-"    .addOrder( Order.asc(\"colr\") )\n"
-"    .list();]]>"
-
-#. Tag: programlisting
-#: query_criteria.xml:214
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.groupProperty(\"color\").as(\"colr\") )\n"
-"    .addOrder( Order.asc(\"colr\") )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.groupProperty(\"color\").as(\"colr\") )\n"
-"    .addOrder( Order.asc(\"colr\") )\n"
-"    .list();]]>"
-
 #. Tag: para
-#: query_criteria.xml:216
 #, no-c-format
 msgid ""
 "The <literal>alias()</literal> and <literal>as()</literal> methods simply "
@@ -648,233 +314,60 @@
 "<literal>Projection</literal>. As a shortcut, you can assign an alias when "
 "you add the projection to a projection list:"
 msgstr ""
-"Los m&#x00e9;todos <literal>alias()</literal> y <literal>as()</literal> "
-"simplemente envuelven una instancia de proyecci&#x00f3;n en otra instancia "
-"de <literal>Projection</literal> con alias. Como un atajo, puedes asignar un "
-"alias cuando agregas la proyecci&#x00f3;n a una lista de proyecciones:"
+"Los métodos <literal>alias()</literal> y <literal>as()</literal> simplemente "
+"envuelven una instancia de proyección en otra instancia de "
+"<literal>Projection</literal> con alias. Como atajo, puede asignar un alias "
+"cuando agregue la proyección a una lista de proyecciones:"
 
-#. Tag: programlisting
-#: query_criteria.xml:223
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount(), \"catCountByColor\" )\n"
-"        .add( Projections.avg(\"weight\"), \"avgWeight\" )\n"
-"        .add( Projections.max(\"weight\"), \"maxWeight\" )\n"
-"        .add( Projections.groupProperty(\"color\"), \"color\" )\n"
-"    )\n"
-"    .addOrder( Order.desc(\"catCountByColor\") )\n"
-"    .addOrder( Order.desc(\"avgWeight\") )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount(), \"catCountByColor\" )\n"
-"        .add( Projections.avg(\"weight\"), \"avgWeight\" )\n"
-"        .add( Projections.max(\"weight\"), \"maxWeight\" )\n"
-"        .add( Projections.groupProperty(\"color\"), \"color\" )\n"
-"    )\n"
-"    .addOrder( Order.desc(\"catCountByColor\") )\n"
-"    .addOrder( Order.desc(\"avgWeight\") )\n"
-"    .list();]]>"
-
-#. Tag: programlisting
-#: query_criteria.xml:225
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Domestic.class, \"cat\")\n"
-"    .createAlias(\"kittens\", \"kit\")\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.property(\"cat.name\"), \"catName\" )\n"
-"        .add( Projections.property(\"kit.name\"), \"kitName\" )\n"
-"    )\n"
-"    .addOrder( Order.asc(\"catName\") )\n"
-"    .addOrder( Order.asc(\"kitName\") )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List results = session.createCriteria(Domestic.class, \"cat\")\n"
-"    .createAlias(\"kittens\", \"kit\")\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.property(\"cat.name\"), \"catName\" )\n"
-"        .add( Projections.property(\"kit.name\"), \"kitName\" )\n"
-"    )\n"
-"    .addOrder( Order.asc(\"catName\") )\n"
-"    .addOrder( Order.asc(\"kitName\") )\n"
-"    .list();]]>"
-
 #. Tag: para
-#: query_criteria.xml:227
 #, no-c-format
 msgid ""
 "You can also use <literal>Property.forName()</literal> to express "
 "projections:"
 msgstr ""
-"Puedes tambi&#x00e9;n usar <literal>Property.forName()</literal> para "
-"expresar proyecciones:"
+"También puede usar <literal>Property.forName()</literal> para expresar "
+"proyecciones:"
 
-#. Tag: programlisting
-#: query_criteria.xml:231
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Property.forName(\"name\") )\n"
-"    .add( Property.forName(\"color\").eq(Color.BLACK) )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Property.forName(\"name\") )\n"
-"    .add( Property.forName(\"color\").eq(Color.BLACK) )\n"
-"    .list();]]>"
-
-#. Tag: programlisting
-#: query_criteria.xml:233
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount().as(\"catCountByColor\") )\n"
-"        .add( Property.forName(\"weight\").avg().as(\"avgWeight\") )\n"
-"        .add( Property.forName(\"weight\").max().as(\"maxWeight\") )\n"
-"        .add( Property.forName(\"color\").group().as(\"color\" )\n"
-"    )\n"
-"    .addOrder( Order.desc(\"catCountByColor\") )\n"
-"    .addOrder( Order.desc(\"avgWeight\") )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount().as(\"catCountByColor\") )\n"
-"        .add( Property.forName(\"weight\").avg().as(\"avgWeight\") )\n"
-"        .add( Property.forName(\"weight\").max().as(\"maxWeight\") )\n"
-"        .add( Property.forName(\"color\").group().as(\"color\" )\n"
-"    )\n"
-"    .addOrder( Order.desc(\"catCountByColor\") )\n"
-"    .addOrder( Order.desc(\"avgWeight\") )\n"
-"    .list();]]>"
-
 #. Tag: title
-#: query_criteria.xml:238
 #, no-c-format
 msgid "Detached queries and subqueries"
 msgstr "Consultas y subconsultas separadas"
 
 #. Tag: para
-#: query_criteria.xml:239
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>DetachedCriteria</literal> class allows you to create a query "
 "outside the scope of a session and then execute it using an arbitrary "
 "<literal>Session</literal>."
 msgstr ""
-"La clase <literal>DetachedCriteria</literal> te deja crear una consulta "
-"fuera del &#x00e1;mbito de una sesi&#x00f3;n, y entonces ejecutarla luego "
-"usando alguna <literal>Session</literal> arbitraria."
+"La clase <literal>DetachedCriteria</literal> le permite crear una consulta "
+"fuera del ámbito de una sesión y luego ejecutarla usando una "
+"<literal>Session</literal> arbitraria."
 
-#. Tag: programlisting
-#: query_criteria.xml:244
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DetachedCriteria query = DetachedCriteria.forClass(Cat.class)\n"
-"    .add( Property.forName(\"sex\").eq('F') );\n"
-"    \n"
-"Session session = ....;\n"
-"Transaction txn = session.beginTransaction();\n"
-"List results = query.getExecutableCriteria(session).setMaxResults(100).list"
-"();\n"
-"txn.commit();\n"
-"session.close();]]>"
-msgstr ""
-"<![CDATA[DetachedCriteria query = DetachedCriteria.forClass(Cat.class)\n"
-"    .add( Property.forName(\"sex\").eq('F') );\n"
-"    \n"
-"Session session = ....;\n"
-"Transaction txn = session.beginTransaction();\n"
-"List results = query.getExecutableCriteria(session).setMaxResults(100).list"
-"();\n"
-"txn.commit();\n"
-"session.close();]]>"
-
-#. Tag: para
-#: query_criteria.xml:246
-#, fuzzy, no-c-format
-msgid ""
 "A <literal>DetachedCriteria</literal> can also be used to express a "
 "subquery. Criterion instances involving subqueries can be obtained via "
 "<literal>Subqueries</literal> or <literal>Property</literal>."
 msgstr ""
-"Tambi&#x00e9;n una <literal>DetachedCriteria</literal> puede usarse para "
-"expresar una subconsulta. Las instancias de Criterion implicando "
-"subconsultas pueden obtenerse v&#x00ed;a <literal>Subqueries</literal> o "
+"También puede utilizar una <literal>DetachedCriteria</literal> para expresar "
+"una subconsulta. Las instancias de Criterion involucrando subconsultas se "
+"pueden obtener por medio de <literal>Subqueries</literal> o "
 "<literal>Property</literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:252
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria avgWeight = DetachedCriteria.forClass(Cat.class)\n"
-"    .setProjection( Property.forName(\"weight\").avg() );\n"
-"session.createCriteria(Cat.class)\n"
-"    .add( Property.forName(\"weight\").gt(avgWeight) )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[DetachedCriteria avgWeight = DetachedCriteria.forClass(Cat.class)\n"
-"    .setProjection( Property.forName(\"weight\").avg() );\n"
-"session.createCriteria(Cat.class)\n"
-"    .add( Property.forName(\"weight\").gt(avgWeight) )\n"
-"    .list();]]>"
-
-#. Tag: programlisting
-#: query_criteria.xml:254
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria weights = DetachedCriteria.forClass(Cat.class)\n"
-"    .setProjection( Property.forName(\"weight\") );\n"
-"session.createCriteria(Cat.class)\n"
-"    .add( Subqueries.geAll(\"weight\", weights) )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[DetachedCriteria weights = DetachedCriteria.forClass(Cat.class)\n"
-"    .setProjection( Property.forName(\"weight\") );\n"
-"session.createCriteria(Cat.class)\n"
-"    .add( Subqueries.geAll(\"weight\", weights) )\n"
-"    .list();]]>"
-
 #. Tag: para
-#: query_criteria.xml:256
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Correlated subqueries are also possible:"
-msgstr "Incluso son posibles las subconsultas correlacionadas:"
+msgstr "Las subconsultas correlacionadas tambień son posibles:"
 
-#. Tag: programlisting
-#: query_criteria.xml:260
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria avgWeightForSex = DetachedCriteria.forClass(Cat."
-"class, \"cat2\")\n"
-"    .setProjection( Property.forName(\"weight\").avg() )\n"
-"    .add( Property.forName(\"cat2.sex\").eqProperty(\"cat.sex\") );\n"
-"session.createCriteria(Cat.class, \"cat\")\n"
-"    .add( Property.forName(\"weight\").gt(avgWeightForSex) )\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[DetachedCriteria avgWeightForSex = DetachedCriteria.forClass(Cat."
-"class, \"cat2\")\n"
-"    .setProjection( Property.forName(\"weight\").avg() )\n"
-"    .add( Property.forName(\"cat2.sex\").eqProperty(\"cat.sex\") );\n"
-"session.createCriteria(Cat.class, \"cat\")\n"
-"    .add( Property.forName(\"weight\").gt(avgWeightForSex) )\n"
-"    .list();]]>"
-
 #. Tag: title
-#: query_criteria.xml:269
 #, no-c-format
 msgid "Queries by natural identifier"
 msgstr "Consultas por identificador natural"
 
 #. Tag: para
-#: query_criteria.xml:271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For most queries, including criteria queries, the query cache is not "
 "efficient because query cache invalidation occurs too frequently. However, "
@@ -883,106 +376,39 @@
 "applications, this kind of query occurs frequently. The criteria API "
 "provides special provision for this use case."
 msgstr ""
-"Para la mayor&#x00ed;a de consultas, incluyendo las consultas por criterios, "
-"el cach&#x00e9; de consulta no es muy eficiente, debido a que la "
-"invalidaci&#x00f3;n del cach&#x00e9; de consulta ocurre demasiado "
-"frecuentemente. Sin embargo, hay un tipo especial de consulta donde podemos "
-"optimizar el algoritmo de invalidaci&#x00f3;n de cach&#x00e9;: búsquedas por "
-"una clave natural constante. En algunas aplicaciones, este tipo de consulta, "
-"ocurre frecuentemente. La API de criterios brinda especial provisi&#x00f3;n "
-"para este caso de uso."
+"Para la mayoría de las consultas, incluyendo las consultas por criterios, el "
+"caché de consulta no es muy eficiente debido a que la invalidación del caché "
+"de consulta ocurre con demasiada frecuencia. Sin embargo, hay un tipo "
+"especial de consulta donde podemos optimizar el algoritmo de invalidación de "
+"caché: búsquedas de una clave natural constante. En algunas aplicaciones, "
+"este tipo de consulta, ocurre frecuentemente. La API de criterios brinda una "
+"provisión especial para este caso."
 
 #. Tag: para
-#: query_criteria.xml:279
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, map the natural key of your entity using <literal>&lt;natural-id&gt;</"
 "literal> and enable use of the second-level cache."
 msgstr ""
-"Primero, debes mapear la clave natural de tu entidad usando <literal>&lt;"
-"natural-id&gt;</literal>, y habilitar el uso del cach&#x00e9; de segundo "
-"nivel."
+"Primero, mapee la clave natural de su entidad utilizando <literal>&lt;"
+"natural-id&gt;</literal> y habilite el uso del caché de segundo nivel."
 
-#. Tag: programlisting
-#: query_criteria.xml:284
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"User\">\n"
-"    <cache usage=\"read-write\"/>\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <natural-id>\n"
-"        <property name=\"name\"/>\n"
-"        <property name=\"org\"/>\n"
-"    </natural-id>\n"
-"    <property name=\"password\"/>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"User\">\n"
-"    <cache usage=\"read-write\"/>\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <natural-id>\n"
-"        <property name=\"name\"/>\n"
-"        <property name=\"org\"/>\n"
-"    </natural-id>\n"
-"    <property name=\"password\"/>\n"
-"</class>]]>"
-
-#. Tag: para
-#: query_criteria.xml:286
-#, fuzzy, no-c-format
-msgid ""
 "This functionality is not intended for use with entities with "
 "<emphasis>mutable</emphasis> natural keys."
 msgstr ""
-"Nota que esta funcionalidad no est&#x00e1; pensada para uso con entidades "
-"con claves naturales <emphasis>mutable</emphasis>."
+"Esta funcionalidad no está pensada para uso con entidades con claves "
+"naturales <emphasis>mutables</emphasis>."
 
 #. Tag: para
-#: query_criteria.xml:291
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Once you have enabled the Hibernate query cache, the <literal>Restrictions."
 "naturalId()</literal> allows you to make use of the more efficient cache "
 "algorithm."
 msgstr ""
-"Ahora, <literal>Restrictions.naturalId()</literal> nos permite hacer uso de "
-"el algoritmo de cach&#x00e9; m&#x00e1;s eficiente."
-
-#. Tag: programlisting
-#: query_criteria.xml:297
-#, no-c-format
-msgid ""
-"<![CDATA[session.createCriteria(User.class)\n"
-"    .add( Restrictions.naturalId()\n"
-"        .set(\"name\", \"gavin\")\n"
-"        .set(\"org\", \"hb\") \n"
-"    ).setCacheable(true)\n"
-"    .uniqueResult();]]>"
-msgstr ""
-"<![CDATA[session.createCriteria(User.class)\n"
-"    .add( Restrictions.naturalId()\n"
-"        .set(\"name\", \"gavin\")\n"
-"        .set(\"org\", \"hb\") \n"
-"    ).setCacheable(true)\n"
-"    .uniqueResult();]]>"
-
-#~ msgid ""
-#~ "You may easily specify constraints upon related entities by navigating "
-#~ "associations using <literal>createCriteria()</literal>."
-#~ msgstr ""
-#~ "Puedes especificar f&#x00e1;cilmente restricciones sobre las entidades "
-#~ "relacionadas al navegar asociaciones usando <literal>createCriteria()</"
-#~ "literal>."
-
-#~ msgid "Next, enable the Hibernate query cache."
-#~ msgstr "Seguido, habilita el cach&#x00e9; de consulta de Hibernate."
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+"Una vez que haya habilitado el caché de consulta de Hibernate, "
+"<literal>Restrictions.naturalId()</literal> le permite hacer uso del "
+"algoritmo de caché más eficiente."

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/query_hql.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/query_hql.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/query_hql.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,41 +1,51 @@
-#, fuzzy
+# translation of query_hql.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: query_hql\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-05 17:47+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: query_hql.xml:29
 #, no-c-format
 msgid "HQL: The Hibernate Query Language"
-msgstr "HQL: El Lenguaje de Consulta de Hibernate"
+msgstr "HQL: El lenguaje de consulta de Hibernate"
 
 #. Tag: para
-#: query_hql.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate uses a powerful query language (HQL) that is similar in appearance "
 "to SQL. Compared with SQL, however, HQL is fully object-oriented and "
 "understands notions like inheritance, polymorphism and association."
 msgstr ""
-"Hibernate est&#x00e1; equipado con un lenguaje de consulta extremadamente "
-"potente que (intencionalmente en absoluto) se parece much&#x00ed;simo a SQL. "
-"Pero no te enga&#x00f1;es por la sintaxis; HQL es completamente orientado a "
-"objetos, entendiendo nociones como herencia, polimorfismo y asociaci&#x00f3;"
-"n."
+"Hibernate utiliza un lenguaje de consulta potente (HQL) que se parece a SQL. "
+"Sin embargo, comparado con SQL, HQL es completamente orientado a objetos y "
+"comprende nociones como herencia, polimorfismo y asociación."
 
 #. Tag: title
-#: query_hql.xml:38
 #, no-c-format
 msgid "Case Sensitivity"
-msgstr "Sensibilidad a May&#x00fa;sculas"
+msgstr "Sensibilidad a mayúsculas"
 
 #. Tag: para
-#: query_hql.xml:40
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "With the exception of names of Java classes and properties, queries are case-"
 "insensitive. So <literal>SeLeCT</literal> is the same as <literal>sELEct</"
@@ -43,281 +53,165 @@
 "hibernate.eg.FOO</literal> is not <literal>org.hibernate.eg.Foo</literal>, "
 "and <literal>foo.barSet</literal> is not <literal>foo.BARSET</literal>."
 msgstr ""
-"Las consultas son insensibles a may&#x00fa;sculas, excepto para nombres de "
-"clases Java y propiedades. De modo que <literal>SeLeCT</literal> es lo mismo "
-"que <literal>sELEct</literal> e igual a <literal>SELECT</literal>, pero "
-"<literal>org.hibernate.eg.FOO</literal> no lo es a <literal>org.hibernate.eg."
-"Foo</literal> y <literal>foo.barSet</literal> no es igual a <literal>foo."
-"BARSET</literal>."
+"Las consultas no son sensibles a mayúsculas, a excepción de los nombres de "
+"las clases y propiedades Java. De modo que <literal>SeLeCT</literal> es lo "
+"mismo que <literal>sELEct</literal> e igual a <literal>SELECT</literal>, "
+"pero <literal>org.hibernate.eg.FOO</literal> no es lo mismo que <literal>org."
+"hibernate.eg.Foo</literal> y <literal>foo.barSet</literal> no es igual a "
+"<literal>foo.BARSET</literal>."
 
 #. Tag: para
-#: query_hql.xml:51
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This manual uses lowercase HQL keywords. Some users find queries with "
 "uppercase keywords more readable, but this convention is unsuitable for "
 "queries embedded in Java code."
 msgstr ""
-"Este manual usa palabras clave HQL en min&#x00fa;sculas. Algunos usuarios "
-"encuentran las consultas con palabras clave en may&#x00fa;sculas m&#x00e1;s "
-"le&#x00ed;bles, pero encontramos esta convenci&#x00f3;n fea cuando se encaja "
-"en c&#x00f3;digo Java."
+"Este manual utiliza palabras clave HQL en minúsculas. Algunos usuarios "
+"encuentran que las consultas con palabras clave en mayúsculas son más "
+"fáciles de leer, pero esta convención no es apropiada para las peticiones "
+"incluidas en código Java."
 
 #. Tag: title
-#: query_hql.xml:59
 #, no-c-format
 msgid "The from clause"
-msgstr "La cl&#x00e1;usula from"
+msgstr "La cláusula from"
 
 #. Tag: para
-#: query_hql.xml:61
 #, no-c-format
 msgid "The simplest possible Hibernate query is of the form:"
-msgstr "La consulta m&#x00e1;s simple posible de Hibernate es de la forma:"
+msgstr "La consulta posible más simple de Hibernate es de esta manera:"
 
-#. Tag: programlisting
-#: query_hql.xml:65
-#, no-c-format
-msgid "<![CDATA[from eg.Cat]]>"
-msgstr "<![CDATA[from eg.Cat]]>"
-
 #. Tag: para
-#: query_hql.xml:67
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This returns all instances of the class <literal>eg.Cat</literal>. You do "
 "not usually need to qualify the class name, since <literal>auto-import</"
 "literal> is the default. For example:"
 msgstr ""
-"que simplemente devuelve todas las instancias de la clase <literal>eg.Cat</"
-"literal>. Usualmente no necesitamos cualificar el nombre de la clase, ya que "
-"<literal>auto-import</literal> est&#x00e1; por defecto. De modo que casi "
-"siempre escribimos solamente:"
+"Esto retorna todas las instancias de la clase <literal>eg.Cat</literal>. "
+"Usualmente no es necesario calificar el nombre de la clase ya que "
+"<literal>auto-import</literal> es el valor predeterminado. Por ejemplo:"
 
-#. Tag: programlisting
-#: query_hql.xml:73
-#, no-c-format
-msgid "<![CDATA[from Cat]]>"
-msgstr "<![CDATA[from Cat]]>"
-
 #. Tag: para
-#: query_hql.xml:75
 #, no-c-format
 msgid ""
 "In order to refer to the <literal>Cat</literal> in other parts of the query, "
 "you will need to assign an <emphasis>alias</emphasis>. For example:"
 msgstr ""
+"Con el fin de referirse al <literal>Cat</literal> en otras partes de la "
+"petición, necesitará asignar un <emphasis>alias</emphasis>. Por ejemplo:"
 
-#. Tag: programlisting
-#: query_hql.xml:81 query_hql.xml:396
-#, no-c-format
-msgid "<![CDATA[from Cat as cat]]>"
-msgstr "<![CDATA[from Cat as cat]]>"
-
 #. Tag: para
-#: query_hql.xml:83
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This query assigns the alias <literal>cat</literal> to <literal>Cat</"
 "literal> instances, so you can use that alias later in the query. The "
 "<literal>as</literal> keyword is optional. You could also write:"
 msgstr ""
-"Esta consulta asigna el alias <literal>cat</literal> a las instancias de "
-"<literal>Cat</literal>, de modo que podr&#x00ed;amos usar ese alias luego en "
-"la consulta. La palabra clave <literal>as</literal> es opcional; "
-"tambi&#x00e9;n podr&#x00ed;amos escribir:"
+"Esta consulta asigna el alias <literal>cat</literal> a las instancias "
+"<literal>Cat</literal>, de modo que puede utilizar ese alias luego en la "
+"consulta. La palabra clave <literal>as</literal> es opcional. También podría "
+"escribir:"
 
-#. Tag: programlisting
-#: query_hql.xml:89
-#, no-c-format
-msgid "<![CDATA[from Cat cat]]>"
-msgstr "<![CDATA[from Cat cat]]>"
-
 #. Tag: para
-#: query_hql.xml:91
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Multiple classes can appear, resulting in a cartesian product or \"cross\" "
 "join."
 msgstr ""
-"Pueden aparecer m&#x00fa;ltiples clases, resultando en un producto "
-"cartesiano o uni&#x00f3;n \"cruzada\" (cross join)."
+"Pueden aparecer múltiples clases, lo que causa un producto cartesiano o una "
+"unión \"cruzada\" (cross join)."
 
-#. Tag: programlisting
-#: query_hql.xml:95
-#, no-c-format
-msgid "<![CDATA[from Formula, Parameter]]>"
-msgstr "<![CDATA[from Formula, Parameter]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:96
-#, no-c-format
-msgid "<![CDATA[from Formula as form, Parameter as param]]>"
-msgstr "<![CDATA[from Formula as form, Parameter as param]]>"
-
 #. Tag: para
-#: query_hql.xml:98
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is good practice to name query aliases using an initial lowercase as this "
 "is consistent with Java naming standards for local variables (e.g. "
 "<literal>domesticCat</literal>)."
 msgstr ""
-"Se considera buena pr&#x00e1;ctica el nombrar los alias de consulta usando "
-"una inicial en min&#x00fa;sculas, consistente con los est&#x00e1;ndares de "
-"nombrado de Java para variables locales (por ejemplo, <literal>domesticCat</"
-"literal>)."
+"Se considera como una buena práctica el nombrar los alias de consulta "
+"utilizando una inicial en minúsculas, consistente con los estándares de "
+"nombrado de Java para las variables locales (por ejemplo, "
+"<literal>domesticCat</literal>). "
 
 #. Tag: title
-#: query_hql.xml:107
 #, no-c-format
 msgid "Associations and joins"
 msgstr "Asociaciones y uniones (joins)"
 
 #. Tag: para
-#: query_hql.xml:109
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also assign aliases to associated entities or to elements of a "
 "collection of values using a <literal>join</literal>. For example:"
 msgstr ""
-"Podemos tambi&#x00e9;n asignar aliases a entidades asociadas, e incluso a "
-"elementos de una colecci&#x00f3;n de valores, usando una <literal>join</"
-"literal>."
+"También puede asignar alias a entidades asociadas o a elementos de una "
+"colección de valores utilizando una <literal>join</literal>. Por ejemplo:"
 
-#. Tag: programlisting
-#: query_hql.xml:114
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join cat.mate as mate\n"
-"    left outer join cat.kittens as kitten]]>"
-msgstr ""
-"<![CDATA[from Cat as cat \n"
-"    inner join cat.mate as mate\n"
-"    left outer join cat.kittens as kitten]]>"
+msgid "The supported join types are borrowed from ANSI SQL:"
+msgstr "Los tipos de uniones soportadas se tomaron prestados de ANSI SQL"
 
-#. Tag: programlisting
-#: query_hql.xml:116
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from Cat as cat left join cat.mate.kittens as kittens]]>"
-msgstr "<![CDATA[from Cat as cat left join cat.mate.kittens as kittens]]>"
+msgid "<literal>inner join</literal>"
+msgstr "<literal>inner join</literal>"
 
-#. Tag: programlisting
-#: query_hql.xml:118
-#, no-c-format
-msgid "<![CDATA[from Formula form full join form.parameter param]]>"
-msgstr "<![CDATA[from Formula form full join form.parameter param]]>"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>left outer join</literal>"
+msgstr "<literal>inner join</literal>"
 
 #. Tag: para
-#: query_hql.xml:120
 #, fuzzy, no-c-format
-msgid "The supported join types are borrowed from ANSI SQL:"
-msgstr "Los tipos de join soportados son prestados de ANSI SQL"
+msgid "<literal>right outer join</literal>"
+msgstr "<literal>inner join</literal>"
 
-#. Tag: literal
-#: query_hql.xml:127
-#, no-c-format
-msgid "inner join"
-msgstr "inner join"
-
-#. Tag: literal
-#: query_hql.xml:132
-#, no-c-format
-msgid "left outer join"
-msgstr "left outer join"
-
-#. Tag: literal
-#: query_hql.xml:137
-#, no-c-format
-msgid "right outer join"
-msgstr "right outer join"
-
 #. Tag: para
-#: query_hql.xml:141
 #, no-c-format
 msgid "<literal>full join</literal> (not usually useful)"
-msgstr "<literal>full join</literal> (no &#x00fa;til usualmente)"
+msgstr "<literal>full join</literal> (no es útil usualmente)"
 
 #. Tag: para
-#: query_hql.xml:147
 #, no-c-format
 msgid ""
 "The <literal>inner join</literal>, <literal>left outer join</literal> and "
 "<literal>right outer join</literal> constructs may be abbreviated."
 msgstr ""
 "Las construcciones <literal>inner join</literal>, <literal>left outer join</"
-"literal> y <literal>right outer join</literal> pueden ser abreviadas."
+"literal> y <literal>right outer join</literal> se pueden abreviar."
 
-#. Tag: programlisting
-#: query_hql.xml:152
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    join cat.mate as mate\n"
-"    left join cat.kittens as kitten]]>"
-msgstr ""
-"<![CDATA[from Cat as cat \n"
-"    join cat.mate as mate\n"
-"    left join cat.kittens as kitten]]>"
-
 #. Tag: para
-#: query_hql.xml:154
 #, no-c-format
 msgid ""
 "You may supply extra join conditions using the HQL <literal>with</literal> "
 "keyword."
 msgstr ""
-"Puedes proveer condiciones de uni&#x00f3;n extra usando la palabra clave "
+"Puede proveer condiciones extras de unión utilizando la palabra clave "
 "<literal>with</literal> de HQL."
 
-#. Tag: programlisting
-#: query_hql.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    left join cat.kittens as kitten\n"
-"        with kitten.bodyWeight > 10.0]]>"
-msgstr ""
-"<![CDATA[from Cat as cat \n"
-"    left join cat.kittens as kitten \n"
-"        with kitten.bodyWeight > 10.0]]>"
-
 #. Tag: para
-#: query_hql.xml:161
 #, fuzzy, no-c-format
 msgid ""
 "A \"fetch\" join allows associations or collections of values to be "
 "initialized along with their parent objects using a single select. This is "
 "particularly useful in the case of a collection. It effectively overrides "
 "the outer join and lazy declarations of the mapping file for associations "
-"and collections. See <xref linkend=\"performance-fetching\"/> for more "
+"and collections. See <xref linkend=\"performance-fetching\" /> for more "
 "information."
 msgstr ""
-"En adici&#x00f3;n, un \"fetch\" join permite a las asociaciones o "
-"colecciones de valores ser inicializadas junto a sus objetos padres, usando "
-"una sola selecci&#x00f3;n. Esto es particularmente &#x00fa;til en el case de "
-"una colecci&#x00f3;n. Efectivamente sobrescribe el outer join y las "
-"declaraciones perezosas (lazy) del fichero de mapeo para asociaciones y "
-"colecciones. Ver <xref linkend=\"performance-fetching\"/> para m&#x00e1;s "
-"informaci&#x00f3;n."
+"Una unión de \"recuperación\" le permite a las asociaciones o colecciones de "
+"valores que se inicialicen junto a sus objetos padres, usando un sólo "
+"select. Esto es útil particularmente en el caso de una colección. "
+"Efectivamente sobrescribe la unión externa y las declaraciones perezosas del "
+"archivo de mapeo para asociaciones y colecciones. Consulte <xref linkend="
+"\"performance-fetching\" /> para obtener más información."
 
-#. Tag: programlisting
-#: query_hql.xml:169
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join fetch cat.mate\n"
-"    left join fetch cat.kittens]]>"
-msgstr ""
-"<![CDATA[from Cat as cat \n"
-"    inner join fetch cat.mate\n"
-"    left join fetch cat.kittens]]>"
-
-#. Tag: para
-#: query_hql.xml:171
-#, fuzzy, no-c-format
-msgid ""
 "A fetch join does not usually need to assign an alias, because the "
 "associated objects should not be used in the <literal>where</literal> clause "
 "(or any other clause). The associated objects are also not returned directly "
@@ -325,32 +219,17 @@
 "The only reason you might need an alias is if you are recursively join "
 "fetching a further collection:"
 msgstr ""
-"Usualmente a un fetch join no se necesita asign&#x00e1;rsele un alias, "
-"porque los objetos asociados no deben ser usados en la cl&#x00e1;usula "
-"<literal>where</literal> (ni en cualquier otra cl&#x00e1;usula). Adem&#x00e1;"
-"s, los objetos asociados no son devueltos directamente en los resultados de "
-"consulta. En cambio, pueden ser accedidos v&#x00ed;a el objeto padre. La "
-"&#x00fa;nica raz&#x00f3;n por la que necesitar&#x00ed;amos un alias es "
-"estamos uniendo recursivamente otra colecci&#x00f3;n:"
+"Usualmente no se necesita asignársele un alias a una unión de recuperación "
+"ya que los objetos asociados no se deben utilizar en la cláusula "
+"<literal>where</literal> (ni en cualquier otra cláusula). Los objetos "
+"asociados no se retornan directamente en los resultados de la consulta. En "
+"cambio, se pueden acceder por medio del objeto padre. La única razón por la "
+"que necesitaríamos un alias es si estamos uniendo recursivamente otra "
+"colección:"
 
-#. Tag: programlisting
-#: query_hql.xml:179
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join fetch cat.mate\n"
-"    left join fetch cat.kittens child\n"
-"    left join fetch child.kittens]]>"
-msgstr ""
-"<![CDATA[from Cat as cat \n"
-"    inner join fetch cat.mate\n"
-"    left join fetch cat.kittens child\n"
-"    left join fetch child.kittens]]>"
-
-#. Tag: para
-#: query_hql.xml:181
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>fetch</literal> construct cannot be used in queries called "
 "using <literal>iterate()</literal> (though <literal>scroll()</literal> can "
 "be used). <literal>Fetch</literal> should be used together with "
@@ -366,79 +245,61 @@
 "<literal>full join fetch</literal> and <literal>right join fetch</literal> "
 "are not meaningful."
 msgstr ""
-"Nota que la construcci&#x00f3;n <literal>fetch</literal> no puede usarse en "
-"consultas llamadas usando <literal>scroll()</literal> o <literal>iterate()</"
-"literal>. Ni debe usarse <literal>fetch</literal> junto con "
-"<literal>setMaxResults()</literal> o <literal>setFirstResult()</literal>. "
-"Tampoco puede usarse <literal>fetch</literal> junto a una condici&#x00f3;n "
-"<literal>with</literal> ad hoc. Es posible crear un producto cartesiano "
-"trayendo por join m&#x00e1;s de una colecci&#x00f3;n en una colecci&#x00f3;"
-"n, as&#x00ed; que ten cuidado en este caso. Traer por join m&#x00fa;ltiples "
-"roles de colecci&#x00f3;n tambi&#x00e9;n da a veces resultados inesperados "
-"para mapeos de bag, as&#x00ed; que s&#x00e9; cuidadoso sobre c&#x00f3;mo "
-"formular tus consultas en este caso. Finalmente, nota que <literal>full join "
-"fetch</literal> y <literal>right join fetch</literal> no son significativos."
+"La construcción <literal>fetch</literal> no puede utilizarse en consultas "
+"llamadas que usen <literal>iterate()</literal> (aunque se puede utilizar "
+"<literal>scroll()</literal>). <literal>Fetch</literal> se debe usar junto "
+"con <literal>setMaxResults()</literal> o <literal>setFirstResult()</literal> "
+"ya que estas operaciones se basan en las filas de resultados, las cuales "
+"usualmente contienen duplicados para la recuperación de colección temprana, "
+"por lo tanto, el número de filas no es lo que se esperaría. <literal>Fetch</"
+"literal> no se debe usar junto con una condición <literal>with</literal> "
+"improvisadas. Es posible crear un producto cartesiano por medio de una "
+"recuperación por union más de una colección en una consulta, así que tenga "
+"cuidado en este caso. La recuperación por unión de múltiples roles de "
+"colección también da resultados a veces inesperados para mapeos de bag, así "
+"que tenga cuidado de cómo formular sus consultas en este caso. Finalmente, "
+"observe que <literal>full join fetch</literal> y <literal>right join fetch</"
+"literal> no son significativos."
 
 #. Tag: para
-#: query_hql.xml:196
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are using property-level lazy fetching (with bytecode "
 "instrumentation), it is possible to force Hibernate to fetch the lazy "
 "properties in the first query immediately using <literal>fetch all "
 "properties</literal>."
 msgstr ""
-"Si est&#x00e1;s usando recuperaci&#x00f3;n perezosa a nivel de propiedad "
-"(con instrumentaci&#x00f3;n de bytecode), es posible forzar a Hibernate a "
-"traer las propiedades perezosas inmediatamente (en la primera consulta) "
-"usando <literal>fetch all properties</literal>."
+"Si está utilizando una recuperación perezosa a nivel de propiedad (con "
+"instrumentación de código byte), es posible forzar a Hibernate a traer las "
+"propiedades perezosas inmediatamente utilizando <literal>fetch all "
+"properties</literal>."
 
-#. Tag: programlisting
-#: query_hql.xml:202
-#, no-c-format
-msgid "<![CDATA[from Document fetch all properties order by name]]>"
-msgstr "<![CDATA[from Document fetch all properties order by name]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:203
-#, no-c-format
-msgid ""
-"<![CDATA[from Document doc fetch all properties where lower(doc.name) like '%"
-"cats%']]>"
-msgstr ""
-"<![CDATA[from Document doc fetch all properties where lower(doc.name) like '%"
-"cats%']]>"
-
 #. Tag: title
-#: query_hql.xml:208
 #, no-c-format
 msgid "Forms of join syntax"
-msgstr "UNTRANSLATED!!! Forms of join syntax"
+msgstr "Formas de sintaxis unida"
 
 #. Tag: para
-#: query_hql.xml:210
 #, no-c-format
 msgid ""
 "HQL supports two forms of association joining: <literal>implicit</literal> "
 "and <literal>explicit</literal>."
 msgstr ""
-"HQL supports two forms of association joining: <literal>implicit</literal> "
-"and <literal>explicit</literal>."
+"HQL soporta dos formas de unión de asociación: <literal>implicit</literal> y "
+"<literal>explicit</literal>."
 
 #. Tag: para
-#: query_hql.xml:214
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The queries shown in the previous section all use the <literal>explicit</"
 "literal> form, that is, where the join keyword is explicitly used in the "
 "from clause. This is the recommended form."
 msgstr ""
-"The queries shown in the previous section all use the <literal>explicit</"
-"literal> form where the join keyword is explicitly used in the from clause. "
-"This is the recommended form."
+"Las consultas que se mostraron en la sección anterior todas utilizan la "
+"forma <literal>explicit</literal>, en donde la palabra clave join se utiliza "
+"explícitamente en la claúsula from. Esta es la forma recomendada."
 
 #. Tag: para
-#: query_hql.xml:219
 #, no-c-format
 msgid ""
 "The <literal>implicit</literal> form does not use the join keyword. Instead, "
@@ -446,56 +307,46 @@
 "literal> joins can appear in any of the HQL clauses. <literal>implicit</"
 "literal> join result in inner joins in the resulting SQL statement."
 msgstr ""
-"The <literal>implicit</literal> form does not use the join keyword. Instead, "
-"the associations are \"dereferenced\" using dot-notation. <literal>implicit</"
-"literal> joins can appear in any of the HQL clauses. <literal>implicit</"
-"literal> join result in inner joins in the resulting SQL statement."
+"La forma <literal>implicit</literal> no utiliza la palabra clave join. Las "
+"asociaciones se \"desreferencian\" utilizando la notación punto. Uniones "
+"<literal>implicit</literal> pueden aparecer en cualquiera de las cláusulas "
+"HQL. La unión <literal>implicit</literal> causa uniones internas (inner "
+"joins) en la declaración SQL que resulta."
 
-#. Tag: programlisting
-#: query_hql.xml:226
-#, no-c-format
-msgid "<![CDATA[from Cat as cat where cat.mate.name like '%s%']]>"
-msgstr "<![CDATA[from Cat as cat where cat.mate.name like '%s%']]>"
-
 #. Tag: title
-#: query_hql.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Referring to identifier property"
-msgstr "Refering to identifier property"
+msgstr "Referencia a la propiedad identificadora "
 
 #. Tag: para
-#: query_hql.xml:232
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "There are 2 ways to refer to an entity's identifier property:"
 msgstr ""
-"There are, generally speaking, 2 ways to refer to an entity's identifier "
-"property:"
+"Hay dos maneras de referirse a la propiedad identificadora de una entidad:"
 
 #. Tag: para
-#: query_hql.xml:237
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The special property (lowercase) <literal>id</literal> may be used to "
 "reference the identifier property of an entity <emphasis>provided that the "
 "entity does not define a non-identifier property named id</emphasis>."
 msgstr ""
-"The special property (lowercase) <literal>id</literal> may be used to "
-"reference the identifier property of an entity <emphasis>provided that "
-"entity does not define a non-identifier property named id</emphasis>."
+"La propiedad especial (en minúsculas) <literal>id</literal> se puede "
+"utilizar para referenciar la propiedad identificadora de una entidad "
+"<emphasis> dado que la entidad no defina un id del nombre de la propiedad no-"
+"identificadora</emphasis>."
 
 #. Tag: para
-#: query_hql.xml:244
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the entity defines a named identifier property, you can use that property "
 "name."
 msgstr ""
-"If the entity defines a named identifier property, you may use that property "
-"name."
+"Si la entidad define una propiedad identificadora nombrada, puede utilizar "
+"ese nombre de propiedad."
 
 #. Tag: para
-#: query_hql.xml:250
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "References to composite identifier properties follow the same naming rules. "
 "If the entity has a non-identifier property named id, the composite "
@@ -503,15 +354,15 @@
 "the special <literal>id</literal> property can be used to reference the "
 "identifier property."
 msgstr ""
-"References to composite identifier properties follow the same naming rules. "
-"If the entity has a non-identifier property named id, the composite "
-"identifier property can only be referenced by its defined named; otherwise, "
-"the special <literal>id</literal> property can be used to rerference the "
-"identifier property."
+"Las referencias a propiedades identificadoras compuestas siguen las mismas "
+"reglas de nombramiento. Si la entidad no tiene un id del nombre de la "
+"propiedad no-identificadora, la propiedad identificadora compuesta sólamente "
+"puede ser referenciada por su nombre definido. De otra manera se puede "
+"utilizar la propiedad <literal>id</literal> especial para referenciar la "
+"propiedad identificadora."
 
 #. Tag: para
-#: query_hql.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please note that, starting in version 3.2.2, this has changed significantly. "
 "In previous versions, <literal>id</literal> <emphasis>always</emphasis> "
@@ -519,323 +370,156 @@
 "ramification of that decision was that non-identifier properties named "
 "<literal>id</literal> could never be referenced in Hibernate queries."
 msgstr ""
-"Note: this has changed significantly starting in version 3.2.2. In previous "
-"versions, <literal>id</literal> <emphasis>always</emphasis> referred to the "
-"identifier property no matter what its actual name. A ramification of that "
-"decision was that non-identifier properties named <literal>id</literal> "
-"could never be referenced in Hibernate queries."
+"Observe que esto ha cambiado bastante desde la version 3.2.2. En versiones "
+"previas, <literal>id</literal><emphasis>siempre</emphasis> se refería a la "
+"propiedad identificadora sin importar su nombre real. Una ramificación de "
+"esa decisión fue que las propiedades no-identificadoras nombradas "
+"<literal>id</literal> nunca podrían ser referenciadas en consultas de "
+"Hibernate. "
 
 #. Tag: title
-#: query_hql.xml:269
 #, no-c-format
 msgid "The select clause"
-msgstr "La cl&#x00e1;usula select"
+msgstr "La cláusula select"
 
 #. Tag: para
-#: query_hql.xml:271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>select</literal> clause picks which objects and properties to "
 "return in the query result set. Consider the following:"
 msgstr ""
-"La cl&#x00e1;usula <literal>select</literal> escoge qu&#x00e9; objetos y "
-"propiedades devolver in el conjunto resultado de la consulta. Considera:"
+"La cláusula <literal>select</literal> escoge qué objetos y propiedades "
+"devolver en el conjunto de resultados de la consulta. Considere lo siguiente:"
 
-#. Tag: programlisting
-#: query_hql.xml:276
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select mate\n"
-"from Cat as cat\n"
-"    inner join cat.mate as mate]]>"
-msgstr ""
-"<![CDATA[select mate \n"
-"from Cat as cat \n"
-"    inner join cat.mate as mate]]>"
-
-#. Tag: para
-#: query_hql.xml:278
-#, fuzzy, no-c-format
-msgid ""
 "The query will select <literal>mate</literal>s of other <literal>Cat</"
 "literal>s. You can express this query more compactly as:"
 msgstr ""
-"La consulta seleccionar&#x00e1; <literal>mate</literal>s de otros "
-"<literal>Cat</literal>s. Realmente, puedes expresar esta consulta en un "
-"forma m&#x00e1;s compacta como:"
+"La consulta seleccionará <literal>mate</literal>s de otros <literal>Cat</"
+"literal>s. Puede expresar esta consulta de una manera más compacta así:"
 
-#. Tag: programlisting
-#: query_hql.xml:283
-#, no-c-format
-msgid "<![CDATA[select cat.mate from Cat cat]]>"
-msgstr "<![CDATA[select cat.mate from Cat cat]]>"
-
 #. Tag: para
-#: query_hql.xml:285
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Queries can return properties of any value type including properties of "
 "component type:"
 msgstr ""
-"Las consultas pueden devolver propiedades de cualquier tipo de valor "
-"incluyendo propiedades de tipo componente:"
+"Las consultas pueden retornar propiedades de cualquier tipo de valor "
+"incluyendo propiedades del tipo componente:"
 
-#. Tag: programlisting
-#: query_hql.xml:289
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat.name from DomesticCat cat\n"
-"where cat.name like 'fri%']]>"
-msgstr ""
-"<![CDATA[select cat.name from DomesticCat cat\n"
-"where cat.name like 'fri%']]>"
-
-#. Tag: programlisting
-#: query_hql.xml:291
-#, no-c-format
-msgid "<![CDATA[select cust.name.firstName from Customer as cust]]>"
-msgstr "<![CDATA[select cust.name.firstName from Customer as cust]]>"
-
-#. Tag: para
-#: query_hql.xml:293
-#, fuzzy, no-c-format
-msgid ""
 "Queries can return multiple objects and/or properties as an array of type "
 "<literal>Object[]</literal>:"
 msgstr ""
-"Las consultas pueden devolver m&#x00fa;ltiples objetos y/o propiedades como "
-"un array de tipo <literal>Object[]</literal>,"
+"Las consultas pueden retornar múltiples objetos y/o propiedades como un "
+"array de tipo <literal>Object[]</literal>,"
 
-#. Tag: programlisting
-#: query_hql.xml:298
-#, no-c-format
-msgid ""
-"<![CDATA[select mother, offspr, mate.name\n"
-"from DomesticCat as mother\n"
-"    inner join mother.mate as mate\n"
-"    left outer join mother.kittens as offspr]]>"
-msgstr ""
-"<![CDATA[select mother, offspr, mate.name \n"
-"from DomesticCat as mother\n"
-"    inner join mother.mate as mate\n"
-"    left outer join mother.kittens as offspr]]>"
-
 #. Tag: para
-#: query_hql.xml:300
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Or as a <literal>List</literal>:"
-msgstr "o como una <literal>List</literal>,"
+msgstr "O como una <literal>List</literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:304
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select new list(mother, offspr, mate.name)\n"
-"from DomesticCat as mother\n"
-"    inner join mother.mate as mate\n"
-"    left outer join mother.kittens as offspr]]>"
-msgstr ""
-"<![CDATA[select new list(mother, offspr, mate.name)\n"
-"from DomesticCat as mother\n"
-"    inner join mother.mate as mate\n"
-"    left outer join mother.kittens as offspr]]>"
-
-#. Tag: para
-#: query_hql.xml:306
-#, fuzzy, no-c-format
-msgid ""
 "Or - assuming that the class <literal>Family</literal> has an appropriate "
 "constructor - as an actual typesafe Java object:"
 msgstr ""
-"asumiendo que la clase <literal>Family</literal> tiene un constructor "
-"apropiado."
+"O asumiendo que la clase <literal>Family</literal> tiene un constructor "
+"apropiado - como un objeto Java de tipo seguro:"
 
-#. Tag: programlisting
-#: query_hql.xml:310
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select new Family(mother, mate, offspr)\n"
-"from DomesticCat as mother\n"
-"    join mother.mate as mate\n"
-"    left join mother.kittens as offspr]]>"
-msgstr ""
-"<![CDATA[select new Family(mother, mate, offspr)\n"
-"from DomesticCat as mother\n"
-"    join mother.mate as mate\n"
-"    left join mother.kittens as offspr]]>"
-
-#. Tag: para
-#: query_hql.xml:313
-#, fuzzy, no-c-format
-msgid ""
 "You can assign aliases to selected expressions using <literal>as</literal>:"
 msgstr ""
-"Puedes asignar aliases para seleccionar expresiones usando <literal>as</"
+"Puede asignar alias para expresiones seleccionadas utilizando <literal>as</"
 "literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:317
-#, no-c-format
-msgid ""
-"<![CDATA[select max(bodyWeight) as max, min(bodyWeight) as min, count(*) as "
-"n\n"
-"from Cat cat]]>"
-msgstr ""
-"<![CDATA[select max(bodyWeight) as max, min(bodyWeight) as min, count(*) as "
-"n\n"
-"from Cat cat]]>"
-
 #. Tag: para
-#: query_hql.xml:319
 #, no-c-format
 msgid ""
 "This is most useful when used together with <literal>select new map</"
 "literal>:"
 msgstr ""
-"Esto es lo m&#x00e1;s &#x00fa;til cuando se usa junto con <literal>select "
-"new map</literal>:"
+"Esto es lo más útil cuando se usa junto con <literal>select new map</"
+"literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:323
-#, no-c-format
-msgid ""
-"<![CDATA[select new map( max(bodyWeight) as max, min(bodyWeight) as min, "
-"count(*) as n )\n"
-"from Cat cat]]>"
-msgstr ""
-"<![CDATA[select new map( max(bodyWeight) as max, min(bodyWeight) as min, "
-"count(*) as n )\n"
-"from Cat cat]]>"
-
 #. Tag: para
-#: query_hql.xml:325
 #, no-c-format
 msgid ""
 "This query returns a <literal>Map</literal> from aliases to selected values."
 msgstr ""
-"Esta consulta devuelve un <literal>Map</literal> de aliases a valores "
+"Esta consulta devuelve un <literal>Map</literal> de alias a valores "
 "seleccionados."
 
 #. Tag: title
-#: query_hql.xml:332
 #, no-c-format
 msgid "Aggregate functions"
-msgstr "Funciones de agregaci&#x00f3;n"
+msgstr "Funciones de agregación"
 
 #. Tag: para
-#: query_hql.xml:334
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL queries can even return the results of aggregate functions on properties:"
 msgstr ""
-"Las consultas HQL pueden incluso devolver resultados de funciones de "
-"agregaci&#x00f3;n sobre propiedades:"
+"Las consultas HQL pueden incluso retornar resultados de funciones de "
+"agregación sobre propiedades:"
 
-#. Tag: programlisting
-#: query_hql.xml:338
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[select avg(cat.weight), sum(cat.weight), max(cat.weight), count"
-"(cat)\n"
-"from Cat cat]]>"
-msgstr ""
-"<![CDATA[select avg(cat.weight), sum(cat.weight), max(cat.weight), count"
-"(cat)\n"
-"from Cat cat]]>"
+msgid "The supported aggregate functions are:"
+msgstr "Las funciones de agregación soportadas son:"
 
 #. Tag: para
-#: query_hql.xml:349
 #, fuzzy, no-c-format
-msgid "The supported aggregate functions are:"
-msgstr "Las funciones de agregaci&#x00f3;n soportadas son"
+msgid "<literal>avg(...), sum(...), min(...), max(...)</literal>"
+msgstr "<literal>avg(...), sum(...), min(...), max(...)</literal>"
 
-#. Tag: literal
-#: query_hql.xml:356
+#. Tag: para
 #, no-c-format
-msgid "avg(...), sum(...), min(...), max(...)"
-msgstr "avg(...), sum(...), min(...), max(...)"
+msgid "<literal>count(*)</literal>"
+msgstr "<literal>count(*)</literal>"
 
-#. Tag: literal
-#: query_hql.xml:361
-#, no-c-format
-msgid "count(*)"
-msgstr "count(*)"
-
-#. Tag: literal
-#: query_hql.xml:366
-#, no-c-format
-msgid "count(...), count(distinct ...), count(all...)"
-msgstr "count(...), count(distinct ...), count(all...)"
-
 #. Tag: para
-#: query_hql.xml:371
 #, fuzzy, no-c-format
+msgid "<literal>count(...), count(distinct ...), count(all...)</literal>"
+msgstr "<literal>count(...), count(distinct ...), count(all...)</literal>"
+
+#. Tag: para
+#, no-c-format
 msgid ""
 "You can use arithmetic operators, concatenation, and recognized SQL "
 "functions in the select clause:"
 msgstr ""
-"Puedes usar operadores aritm&#x00e9;ticos, concatenaci&#x00f3;n, y funciones "
-"SQL reconocidas en la cl&#x00e1;usula select:"
+"Puede utilizar operadores aritméticos, concatenación y funciones SQL "
+"reconocidas en la cláusula select:"
 
-#. Tag: programlisting
-#: query_hql.xml:376
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat.weight + sum(kitten.weight)\n"
-"from Cat cat\n"
-"    join cat.kittens kitten\n"
-"group by cat.id, cat.weight]]>"
-msgstr ""
-"<![CDATA[select cat.weight + sum(kitten.weight) \n"
-"from Cat cat \n"
-"    join cat.kittens kitten\n"
-"group by cat.id, cat.weight]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:378
-#, no-c-format
-msgid ""
-"<![CDATA[select firstName||' '||initial||' '||upper(lastName) from Person]]>"
-msgstr ""
-"<![CDATA[select firstName||' '||initial||' '||upper(lastName) from Person]]>"
-
-#. Tag: para
-#: query_hql.xml:380
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>distinct</literal> and <literal>all</literal> keywords can be "
 "used and have the same semantics as in SQL."
 msgstr ""
-"Las palabras clave <literal>distinct</literal> y <literal>all</literal> "
-"pueden ser usadas y tienen las misma sem&#x00e1;ntica que en SQL."
+"Las palabras clave <literal>distinct</literal> y <literal>all</literal> se "
+"pueden utilizar y tienen las misma semántica que en SQL."
 
-#. Tag: programlisting
-#: query_hql.xml:385
-#, no-c-format
-msgid ""
-"<![CDATA[select distinct cat.name from Cat cat\n"
-"\n"
-"select count(distinct cat.name), count(cat) from Cat cat]]>"
-msgstr ""
-"<![CDATA[select distinct cat.name from Cat cat\n"
-"\n"
-"select count(distinct cat.name), count(cat) from Cat cat]]>"
-
 #. Tag: title
-#: query_hql.xml:390
 #, no-c-format
 msgid "Polymorphic queries"
-msgstr "Consultas polim&#x00f3;rficas"
+msgstr "Consultas polimórficas"
 
 #. Tag: para
-#: query_hql.xml:392
 #, no-c-format
 msgid "A query like:"
 msgstr "Una consulta como:"
 
 #. Tag: para
-#: query_hql.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "returns instances not only of <literal>Cat</literal>, but also of subclasses "
 "like <literal>DomesticCat</literal>. Hibernate queries can name "
@@ -844,291 +528,173 @@
 "that extend that class or implement the interface. The following query would "
 "return all persistent objects:"
 msgstr ""
-"devuelve instancias no s&#x00f3;lo de <literal>Cat</literal>, sino "
-"tambi&#x00e9;n de subclases como <literal>DomesticCat</literal>. Las "
-"consultas de Hibernate pueden mencionar <emphasis>cualquier</emphasis> clase "
-"o interface Java en la cl&#x00e1;usula <literal>from</literal>. La consulta "
-"devolver&#x00e1; instancias de todas las clases persistentes que extiendan "
-"esa clase o implementen la interface. La siguiente consulta devolver&#x00ed;"
-"a todos los objetos persistentes."
+"devuelve instancias no sólamente de <literal>Cat</literal>, sino también de "
+"subclases como <literal>DomesticCat</literal>. Las consultas de Hibernate "
+"pueden nombrar <emphasis>cualquier</emphasis> clase o interfaz Java en la "
+"cláusula <literal>from</literal>. La consulta retornará instancias de todas "
+"las clases persistentes que extiendan esa clase o implementen la interfaz. "
+"La siguiente consulta retornaría todos los objetos persistentes."
 
-#. Tag: programlisting
-#: query_hql.xml:406
-#, no-c-format
-msgid "<![CDATA[from java.lang.Object o]]>"
-msgstr "<![CDATA[from java.lang.Object o]]>"
-
 #. Tag: para
-#: query_hql.xml:408
 #, no-c-format
 msgid ""
 "The interface <literal>Named</literal> might be implemented by various "
 "persistent classes:"
 msgstr ""
-"La interface <literal>Named</literal> podr&#x00ed;a ser implementada por "
-"varias clases persistentes:"
+"La interfaz <literal>Named</literal> se podría implementar por varias clases "
+"persistentes:"
 
-#. Tag: programlisting
-#: query_hql.xml:413
-#, no-c-format
-msgid "<![CDATA[from Named n, Named m where n.name = m.name]]>"
-msgstr "<![CDATA[from Named n, Named m where n.name = m.name]]>"
-
 #. Tag: para
-#: query_hql.xml:415
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These last two queries will require more than one SQL <literal>SELECT</"
 "literal>. This means that the <literal>order by</literal> clause does not "
 "correctly order the whole result set. It also means you cannot call these "
 "queries using <literal>Query.scroll()</literal>."
 msgstr ""
-"Nota que estas dos &#x00fa;ltimas consultas requerir&#x00e1;n m&#x00e1;s de "
-"un <literal>SELECT</literal> SQL. Esto significa que la cl&#x00e1;usula "
-"<literal>order by</literal> no ordenar&#x00e1; correctamente todo el "
-"conjunto resultado. (Significa adem&#x00e1;s que no puedes llamar estas "
-"consulta usando <literal>Query.scroll()</literal>.)"
+"Las dos últimas consultas requerirán más de un <literal>SELECT</literal> "
+"SQL. Esto significa que la cláusula <literal>order by</literal> no ordenará "
+"correctamente todo el conjunto que resulte. También significa que no puede "
+"llamar estas consulta usando <literal>Query.scroll()</literal>."
 
 #. Tag: title
-#: query_hql.xml:424
 #, no-c-format
 msgid "The where clause"
-msgstr "La cl&#x00e1;usula where"
+msgstr "La cláusula where"
 
 #. Tag: para
-#: query_hql.xml:426
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>where</literal> clause allows you to refine the list of "
 "instances returned. If no alias exists, you can refer to properties by name:"
 msgstr ""
-"La cl&#x00e1;usula where te permite estrechar la lista de instancias "
-"devueltas. Si no existe ning&#x00fa;n alias. puedes referirte a las "
+"La cláusula <literal>where</literal> le permite refinar la lista de "
+"instancias retornadas. Si no existe ningún alias, puede referirse a las "
 "propiedades por nombre:"
 
-#. Tag: programlisting
-#: query_hql.xml:431
-#, no-c-format
-msgid "<![CDATA[from Cat where name='Fritz']]>"
-msgstr "<![CDATA[from Cat where name='Fritz']]>"
-
 #. Tag: para
-#: query_hql.xml:433
 #, no-c-format
 msgid "If there is an alias, use a qualified property name:"
-msgstr "Si existe un alias, usan un nombre cualificado de propiedad:"
+msgstr "Si existe un alias, use un nombre de propiedad calificado:"
 
-#. Tag: programlisting
-#: query_hql.xml:437
-#, no-c-format
-msgid "<![CDATA[from Cat as cat where cat.name='Fritz']]>"
-msgstr "<![CDATA[from Cat as cat where cat.name='Fritz']]>"
-
 #. Tag: para
-#: query_hql.xml:439
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This returns instances of <literal>Cat</literal> named 'Fritz'."
-msgstr "devuelve las instancias de <literal>Cat</literal> llamadas 'Fritz'."
+msgstr "Esto retorna instancias de <literal>Cat</literal> llamadas 'Fritz'."
 
 #. Tag: para
-#: query_hql.xml:443
-#, fuzzy, no-c-format
-msgid ""
-"The following query: <programlisting><![CDATA[select foo\n"
-"from Foo foo, Bar bar\n"
-"where foo.startDate = bar.date]]></programlisting> returns all instances of "
-"<literal>Foo</literal> with an instance of <literal>bar</literal> with a "
-"<literal>date</literal> property equal to the <literal>startDate</literal> "
-"property of the <literal>Foo</literal>. Compound path expressions make the "
-"<literal>where</literal> clause extremely powerful. Consider the following:"
-msgstr ""
-"devolver&#x00e1; todas las instancias de <literal>Foo</literal> para las "
-"cuales exista una instancia de <literal>bar</literal> con una propiedad "
-"<literal>date</literal> igual a la propiedad <literal>startDate</literal> "
-"del <literal>Foo</literal>. Las expresiones de ruta compuestas hacen la "
-"cl&#x00e1;usula <literal>where</literal> extremadamente potente. Considera:"
-
-#. Tag: programlisting
-#: query_hql.xml:454
 #, no-c-format
-msgid "<![CDATA[from Cat cat where cat.mate.name is not null]]>"
-msgstr "<![CDATA[from Cat cat where cat.mate.name is not null]]>"
+msgid "The following query:"
+msgstr "La siguiente petición:"
 
 #. Tag: para
-#: query_hql.xml:456
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"This query translates to an SQL query with a table (inner) join. For example:"
+"returns all instances of <literal>Foo</literal> with an instance of "
+"<literal>bar</literal> with a <literal>date</literal> property equal to the "
+"<literal>startDate</literal> property of the <literal>Foo</literal>. "
+"Compound path expressions make the <literal>where</literal> clause extremely "
+"powerful. Consider the following:"
 msgstr ""
-"Esta consulta se traduce en una consulta SQL con una uni&#x00f3;n de tabla "
-"(interna). Si fueses a escribir algo como"
+"retornará todas las instancias de <literal>Foo</literal> con una instancia "
+"de <literal>bar</literal> con una propiedad <literal>date</literal> igual a "
+"la propiedad <literal>startDate</literal> del <literal>Foo</literal>. Las "
+"expresiones de ruta compuestas hacen la cláusula <literal>where</literal> "
+"extremadamente potente. Tome en consideración lo siguiente:"
 
-#. Tag: programlisting
-#: query_hql.xml:461
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Foo foo\n"
-"where foo.bar.baz.customer.address.city is not null]]>"
+"This query translates to an SQL query with a table (inner) join. For example:"
 msgstr ""
-"<![CDATA[from Foo foo  \n"
-"where foo.bar.baz.customer.address.city is not null]]>"
+"Esta consulta se traduce a una consulta SQL con una unión de tabla "
+"(interna). Por ejemplo:"
 
 #. Tag: para
-#: query_hql.xml:463
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "would result in a query that would require four table joins in SQL."
 msgstr ""
-"terminar&#x00ed;as con una consulta que requerir&#x00ed;a cuatro uniones de "
-"tablas en SQL."
+"terminaría con una consulta que requeriría cuatro uniones de tablas en SQL. "
 
 #. Tag: para
-#: query_hql.xml:467
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>=</literal> operator can be used to compare not only "
 "properties, but also instances:"
 msgstr ""
-"El operador <literal>=</literal> puede ser usado para comparar no s&#x00f3;"
-"lo propiedades, sino tambi&#x00e9;n instancias:"
+"El operador <literal>=</literal> se puede utilizar para comparar no "
+"sólamente propiedades sino también instancias:"
 
-#. Tag: programlisting
-#: query_hql.xml:472
-#, no-c-format
-msgid "<![CDATA[from Cat cat, Cat rival where cat.mate = rival.mate]]>"
-msgstr "<![CDATA[from Cat cat, Cat rival where cat.mate = rival.mate]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:474
-#, no-c-format
-msgid ""
-"<![CDATA[select cat, mate\n"
-"from Cat cat, Cat mate\n"
-"where cat.mate = mate]]>"
-msgstr ""
-"<![CDATA[select cat, mate \n"
-"from Cat cat, Cat mate\n"
-"where cat.mate = mate]]>"
-
 #. Tag: para
-#: query_hql.xml:476
 #, fuzzy, no-c-format
 msgid ""
 "The special property (lowercase) <literal>id</literal> can be used to "
 "reference the unique identifier of an object. See <xref linkend=\"queryhql-"
-"identifier-property\"/> for more information."
+"identifier-property\" /> for more information."
 msgstr ""
-"La propiedad especial (en min&#x00fa;sculas) <literal>id</literal> puede ser "
-"usada para referenciar el identificador &#x00fa;nico de un objeto. "
-"(Tambi&#x00e9;n puedes usar su nombre de propiedad.)"
+"La propiedad especial <literal>id</literal> (en minúsculas) se puede "
+"utilizar para referenciar el identificador único de un objeto. Consulte "
+"<xref linkend=\"queryhql-identifier-property\" /> para obtener más "
+"información."
 
-#. Tag: programlisting
-#: query_hql.xml:482
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat where cat.id = 123\n"
-"\n"
-"from Cat as cat where cat.mate.id = 69]]>"
-msgstr ""
-"<![CDATA[from Cat as cat where cat.id = 123\n"
-"\n"
-"from Cat as cat where cat.mate.id = 69]]>"
-
 #. Tag: para
-#: query_hql.xml:484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The second query is efficient and does not require a table join."
-msgstr ""
-"La segunda consulta es eficiente. &#x00a1;No se requiere ninguna uni&#x00f3;"
-"n de tablas!"
+msgstr "La segunda consulta es eficiente y no se necesita una unión de tablas."
 
 #. Tag: para
-#: query_hql.xml:488
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Properties of composite identifiers can also be used. Consider the following "
 "example where <literal>Person</literal> has composite identifiers consisting "
 "of <literal>country</literal> and <literal>medicareNumber</literal>:"
 msgstr ""
-"Tambi&#x00e9;n pueden ser usadas las propiedades de identificadores "
-"compuestos. Sup&#x00f3;n que <literal>Person</literal> tiene un "
-"identificador compuesto consistente en <literal>country</literal> y "
-"<literal>medicareNumber</literal>."
+"También se pueden utilizar las propiedades de identificadores compuestos. "
+"Considere el siguiente ejemplo en donde <literal>Person</literal> tiene "
+"identificadores compuestos que consisten de <literal>country</literal> y "
+"<literal>medicareNumber</literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:494
-#, no-c-format
-msgid ""
-"<![CDATA[from bank.Person person\n"
-"where person.id.country = 'AU'\n"
-"    and person.id.medicareNumber = 123456]]>"
-msgstr ""
-"<![CDATA[from bank.Person person\n"
-"where person.id.country = 'AU' \n"
-"    and person.id.medicareNumber = 123456]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:496
-#, no-c-format
-msgid ""
-"<![CDATA[from bank.Account account\n"
-"where account.owner.id.country = 'AU'\n"
-"    and account.owner.id.medicareNumber = 123456]]>"
-msgstr ""
-"<![CDATA[from bank.Account account\n"
-"where account.owner.id.country = 'AU' \n"
-"    and account.owner.id.medicareNumber = 123456]]>"
-
 #. Tag: para
-#: query_hql.xml:498
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Once again, the second query does not require a table join."
-msgstr ""
-"Una vez m&#x00e1;s, la segunda consulta no requiere ninguna uni&#x00f3;n de "
-"tablas."
+msgstr "Una vez más, la segunda consulta no requiere una unión de tablas."
 
 #. Tag: para
-#: query_hql.xml:502
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"See <xref linkend=\"queryhql-identifier-property\"/> for more information "
+"See <xref linkend=\"queryhql-identifier-property\" /> for more information "
 "regarding referencing identifier properties)"
 msgstr ""
+"Consulte <xref linkend=\"queryhql-identifier-property\" /> para obtener "
+"mayor información con relación a la referencia de propiedades del "
+"identificador)"
 
 #. Tag: para
-#: query_hql.xml:507
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The special property <literal>class</literal> accesses the discriminator "
 "value of an instance in the case of polymorphic persistence. A Java class "
 "name embedded in the where clause will be translated to its discriminator "
 "value."
 msgstr ""
-"Asimismo, la propiedad especial <literal>class</literal> acccede al valor "
-"discriminador de una instancia en el caso de persistencia polim&#x00f3;"
-"rfica. Un nombre de clase Java embebido en la cl&#x00e1;usula where "
-"ser&#x00e1; traducido a su valor discriminador."
+"La propiedad especial <literal>class</literal> acccede al valor "
+"discriminador de una instancia en el caso de persistencia polimórfica. Un "
+"nombre de clase Java incluído en la cláusula where será traducido a su valor "
+"discriminador."
 
-#. Tag: programlisting
-#: query_hql.xml:513
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.class = DomesticCat]]>"
-msgstr "<![CDATA[from Cat cat where cat.class = DomesticCat]]>"
-
 #. Tag: para
-#: query_hql.xml:515
 #, fuzzy, no-c-format
 msgid ""
 "You can also use components or composite user types, or properties of said "
-"component types. See <xref linkend=\"queryhql-components\"/> for more "
+"component types. See <xref linkend=\"queryhql-components\" /> for more "
 "information."
 msgstr ""
-"You may also use components or composite user types, or properties of said "
-"component types. See <xref linkend=\"queryhql-components\"/> for more "
-"details."
+"También puede utilizar componentes o tipos de usuario compuesto o "
+"propiedades de dichos tipos de componentes. Consulte <xref linkend="
+"\"queryhql-components\" /> para obtener más detalles."
 
 #. Tag: para
-#: query_hql.xml:520
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An \"any\" type has the special properties <literal>id</literal> and "
 "<literal>class</literal> that allows you to express a join in the following "
@@ -1136,79 +702,60 @@
 "<literal>&lt;any&gt;</literal>):"
 msgstr ""
 "Un tipo \"any\" tiene las propiedades especiales <literal>id</literal> y "
-"<literal>class</literal>, permit&#x00e9;ndonos expresar un join en la "
-"siguiente forma (donde <literal>AuditLog.item</literal> es una propiedad "
-"mapeada con <literal>&lt;any&gt;</literal>)."
+"<literal>class</literal>, permiténdole expresar una unión de la siguiente "
+"forma (en donde <literal>AuditLog.item</literal> es una propiedad mapeada "
+"con <literal>&lt;any&gt;</literal>)."
 
-#. Tag: programlisting
-#: query_hql.xml:526
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from AuditLog log, Payment payment\n"
-"where log.item.class = 'Payment' and log.item.id = payment.id]]>"
-msgstr ""
-"<![CDATA[from AuditLog log, Payment payment \n"
-"where log.item.class = 'Payment' and log.item.id = payment.id]]>"
-
-#. Tag: para
-#: query_hql.xml:528
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>log.item.class</literal> and <literal>payment.class</literal> "
 "would refer to the values of completely different database columns in the "
 "above query."
 msgstr ""
-"Nota que <literal>log.item.class</literal> y <literal>payment.class</"
-"literal> har&#x00ed;an referencia a los valores de columnas de base de datos "
+"La <literal>log.item.class</literal> y <literal>payment.class</literal> "
+"harían referencia a los valores de columnas de la base de datos "
 "completamente diferentes en la consulta anterior."
 
 #. Tag: title
-#: query_hql.xml:536
 #, no-c-format
 msgid "Expressions"
 msgstr "Expresiones"
 
 #. Tag: para
-#: query_hql.xml:538
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Expressions used in the <literal>where</literal> clause include the "
 "following:"
 msgstr ""
-"Las expresiones permitidas en la cl&#x00e1;usula <literal>where</literal> "
-"incluyen la mayor&#x00ed;a del tipo de cosas que podr&#x00ed;as escribir en "
-"SQL:"
+"Las expresiones utilizadas en la cláusula <literal>where</literal> incluyen "
+"lo siguiente:"
 
 #. Tag: para
-#: query_hql.xml:545
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "mathematical operators: <literal>+, -, *, /</literal>"
-msgstr "operadores matem&#x00e1;ticos <literal>+, -, *, /</literal>"
+msgstr "operadores matemáticos: <literal>+, -, *, /</literal>"
 
 #. Tag: para
-#: query_hql.xml:550
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "binary comparison operators: <literal>=, &gt;=, &lt;=, &lt;&gt;, !=, like</"
 "literal>"
 msgstr ""
-"operadores de comparaci&#x00f3;n binarios <literal>=, &gt;=, &lt;=, &lt;"
-"&gt;, !=, like</literal>"
+"operadores de comparación binarios: <literal>=, &gt;=, &lt;=, &lt;&gt;, !=, "
+"like</literal>"
 
 #. Tag: para
-#: query_hql.xml:555
 #, no-c-format
 msgid "logical operations <literal>and, or, not</literal>"
-msgstr "operadores l&#x00f3;gicos <literal>and, or, not</literal>"
+msgstr "operadores lógicos <literal>and, or, not</literal>"
 
 #. Tag: para
-#: query_hql.xml:560
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Parentheses <literal>( )</literal> that indicates grouping"
-msgstr "Par&#x00e9;ntesis <literal>( )</literal>, indicando agrupaci&#x00f3;n"
+msgstr "Paréntesis <literal>( )</literal> que indican agrupación"
 
 #. Tag: para
-#: query_hql.xml:565
 #, no-c-format
 msgid ""
 "<literal>in</literal>, <literal>not in</literal>, <literal>between</"
@@ -1222,7 +769,6 @@
 "<literal>member of</literal> y <literal>not member of</literal>"
 
 #. Tag: para
-#: query_hql.xml:578
 #, no-c-format
 msgid ""
 "\"Simple\" case, <literal>case ... when ... then ... else ... end</literal>, "
@@ -1232,28 +778,25 @@
 "y caso \"buscado\", <literal>case when ... then ... else ... end</literal>"
 
 #. Tag: para
-#: query_hql.xml:584
 #, no-c-format
 msgid ""
 "string concatenation <literal>...||...</literal> or <literal>concat(...,...)"
 "</literal>"
 msgstr ""
-"concatenaci&#x00f3;n de cadenas <literal>...||...</literal> o <literal>concat"
+"concatenación de cadenas <literal>...||...</literal> o <literal>concat"
 "(...,...)</literal>"
 
 #. Tag: para
-#: query_hql.xml:589
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>current_date()</literal>, <literal>current_time()</literal>, and "
 "<literal>current_timestamp()</literal>"
 msgstr ""
-"<literal>current_date()</literal>, <literal>current_time()</literal>, "
+"<literal>current_date()</literal>, <literal>current_time()</literal> y "
 "<literal>current_timestamp()</literal>"
 
 #. Tag: para
-#: query_hql.xml:595
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>second(...)</literal>, <literal>minute(...)</literal>, <literal>hour"
 "(...)</literal>, <literal>day(...)</literal>, <literal>month(...)</literal>, "
@@ -1261,38 +804,34 @@
 msgstr ""
 "<literal>second(...)</literal>, <literal>minute(...)</literal>, <literal>hour"
 "(...)</literal>, <literal>day(...)</literal>, <literal>month(...)</literal>, "
-"<literal>year(...)</literal>,"
+"and <literal>year(...)</literal>"
 
 #. Tag: para
-#: query_hql.xml:602
 #, no-c-format
 msgid ""
 "Any function or operator defined by EJB-QL 3.0: <literal>substring(), trim"
 "(), lower(), upper(), length(), locate(), abs(), sqrt(), bit_length(), mod()"
 "</literal>"
 msgstr ""
-"Cualquier funci&#x00f3;n u operador definido por EJB-QL 3.0: "
-"<literal>substring(), trim(), lower(), upper(), length(), locate(), abs(), "
-"sqrt(), bit_length(), mod()</literal>"
+"Cualquier función u operador definido por EJB-QL 3.0: <literal>substring(), "
+"trim(), lower(), upper(), length(), locate(), abs(), sqrt(), bit_length(), "
+"mod()</literal>"
 
 #. Tag: para
-#: query_hql.xml:608
 #, no-c-format
 msgid "<literal>coalesce()</literal> and <literal>nullif()</literal>"
 msgstr "<literal>coalesce()</literal> y <literal>nullif()</literal>"
 
 #. Tag: para
-#: query_hql.xml:613
 #, no-c-format
 msgid ""
 "<literal>str()</literal> for converting numeric or temporal values to a "
 "readable string"
 msgstr ""
-"<literal>str()</literal> para convertir valores num&#x00e9;ricos o "
-"temporales a una cadena legible."
+"<literal>str()</literal> para convertir valores numéricos o temporales a una "
+"cadena legible."
 
 #. Tag: para
-#: query_hql.xml:619
 #, no-c-format
 msgid ""
 "<literal>cast(... as ...)</literal>, where the second argument is the name "
@@ -1301,23 +840,21 @@
 "the underlying database"
 msgstr ""
 "<literal>cast(... as ...)</literal>, donde el segundo argumento es el nombre "
-"de un tipo Hibernate , y <literal>extract(... from ...)</literal> si "
-"<literal>cast()</literal> y <literal>extract()</literal> fuesen soportados "
-"por la base de datos subyacente."
+"de un tipo de Hibernate , y <literal>extract(... from ...)</literal> si "
+"<literal>cast()</literal> y <literal>extract()</literal> es soportado por la "
+"base de datos subyacente."
 
 #. Tag: para
-#: query_hql.xml:627
 #, no-c-format
 msgid ""
 "the HQL <literal>index()</literal> function, that applies to aliases of a "
 "joined indexed collection"
 msgstr ""
-"la funci&#x00f3;n <literal>index()</literal> de HQL, que se aplica a alias "
-"de una colecci&#x00f3;n indexada unida."
+"la función <literal>index()</literal> de HQL, que se aplica a alias de una "
+"colección indexada unida."
 
 #. Tag: para
-#: query_hql.xml:633
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL functions that take collection-valued path expressions: <literal>size(), "
 "minelement(), maxelement(), minindex(), maxindex()</literal>, along with the "
@@ -1325,42 +862,38 @@
 "functions that can be quantified using <literal>some, all, exists, any, in</"
 "literal>."
 msgstr ""
-"funciones de HQL que tomen expresiones de ruta valuadas en colecciones: "
+"Las funciones de HQL que tomen expresiones de ruta valuadas en colecciones: "
 "<literal>size(), minelement(), maxelement(), minindex(), maxindex()</"
-"literal>, junto a las funciones especiales <literal>elements()</literal> and "
-"<literal>indices</literal> que pueden ser cuantificadas usando "
+"literal>, junto con las funciones especiales <literal>elements()</literal> e "
+"<literal>indices</literal>, las cuales se pueden cuantificar utilizando "
 "<literal>some, all, exists, any, in</literal>."
 
 #. Tag: para
-#: query_hql.xml:641
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Any database-supported SQL scalar function like <literal>sign()</literal>, "
 "<literal>trunc()</literal>, <literal>rtrim()</literal>, and <literal>sin()</"
 "literal>"
 msgstr ""
-"Cualquier funci&#x00f3;n escalar SQL soportada por la base de datos como "
+"Cualquier función escalar SQL soportada por la base de datos como "
 "<literal>sign()</literal>, <literal>trunc()</literal>, <literal>rtrim()</"
-"literal>, <literal>sin()</literal>"
+"literal> y <literal>sin()</literal>"
 
 #. Tag: para
-#: query_hql.xml:647
 #, no-c-format
 msgid "JDBC-style positional parameters <literal>?</literal>"
-msgstr "par&#x00e1;metros posicionales JDBC <literal>?</literal>"
+msgstr "parámetros posicionales JDBC <literal>?</literal>"
 
 #. Tag: para
-#: query_hql.xml:652
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "named parameters <literal>:name</literal>, <literal>:start_date</literal>, "
 "and <literal>:x1</literal>"
 msgstr ""
-"par&#x00e1;metros con nombre <literal>:name</literal>, <literal>:start_date</"
-"literal>, <literal>:x1</literal>"
+"parámetros con nombre <literal>:name</literal>, <literal>:start_date</"
+"literal> y <literal>:x1</literal>"
 
 #. Tag: para
-#: query_hql.xml:657
 #, no-c-format
 msgid ""
 "SQL literals <literal>'foo'</literal>, <literal>69</literal>, <literal>6.66E"
@@ -1370,134 +903,66 @@
 "+2</literal>, <literal>'1970-01-01 10:00:01.0'</literal>"
 
 #. Tag: para
-#: query_hql.xml:663
 #, no-c-format
 msgid ""
 "Java <literal>public static final</literal> constants <literal>eg.Color."
 "TABBY</literal>"
 msgstr ""
-"constantes Java <literal>public static final</literal> <literal>eg.Color."
+"constantes Java <literal>public static final</literal><literal>eg.Color."
 "TABBY</literal>"
 
 #. Tag: para
-#: query_hql.xml:669
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>in</literal> and <literal>between</literal> can be used as follows:"
 msgstr ""
-"<literal>in</literal> y <literal>between</literal> pueden usarse como sigue:"
+"<literal>in</literal> y <literal>between</literal> pueden utilizarse así:"
 
-#. Tag: programlisting
-#: query_hql.xml:673
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name between 'A' and 'B']]>"
-msgstr "<![CDATA[from DomesticCat cat where cat.name between 'A' and 'B']]>"
-
-#. Tag: programlisting
-#: query_hql.xml:675
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat cat where cat.name in ( 'Foo', 'Bar', 'Baz' )]]>"
-msgstr ""
-"<![CDATA[from DomesticCat cat where cat.name in ( 'Foo', 'Bar', 'Baz' )]]>"
-
 #. Tag: para
-#: query_hql.xml:677
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The negated forms can be written as follows:"
-msgstr "y pueden escribirse las formas negadas"
+msgstr "Las formas negadas se pueden escribir así:"
 
-#. Tag: programlisting
-#: query_hql.xml:681
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name not between 'A' and 'B']]>"
-msgstr ""
-"<![CDATA[from DomesticCat cat where cat.name not between 'A' and 'B']]>"
-
-#. Tag: programlisting
-#: query_hql.xml:683
-#, no-c-format
 msgid ""
-"<![CDATA[from DomesticCat cat where cat.name not in ( 'Foo', 'Bar', 'Baz' )]]"
-">"
-msgstr ""
-"<![CDATA[from DomesticCat cat where cat.name not in ( 'Foo', 'Bar', 'Baz' )]]"
-">"
-
-#. Tag: para
-#: query_hql.xml:685
-#, fuzzy, no-c-format
-msgid ""
 "Similarly, <literal>is null</literal> and <literal>is not null</literal> can "
 "be used to test for null values."
 msgstr ""
-"Asimismo, <literal>is null</literal> y <literal>is not null</literal> pueden "
-"ser usadas para comprobar valores nulos."
+"De manera similar, <literal>is null</literal> y <literal>is not null</"
+"literal> se pueden utilizar para probar valores nulos."
 
 #. Tag: para
-#: query_hql.xml:690
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Booleans can be easily used in expressions by declaring HQL query "
 "substitutions in Hibernate configuration:"
 msgstr ""
-"Los booleanos pueden ser f&#x00e1;cilmente usados en expresiones declarando "
-"substituciones de consulta HQL en la configuraci&#x00f3;n de Hibernate:"
+"Los valores booleanos se pueden utilizar fácilmente en expresiones "
+"declarando substituciones de consulta HQL en la configuración de Hibernate:"
 
-#. Tag: programlisting
-#: query_hql.xml:695
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"hibernate.query.substitutions\">true 1, false 0</"
-"property>]]>"
-msgstr ""
-"<![CDATA[<property name=\"hibernate.query.substitutions\">true 1, false 0</"
-"property>]]>"
-
 #. Tag: para
-#: query_hql.xml:697
 #, no-c-format
 msgid ""
 "This will replace the keywords <literal>true</literal> and <literal>false</"
 "literal> with the literals <literal>1</literal> and <literal>0</literal> in "
 "the translated SQL from this HQL:"
 msgstr ""
-"Esto remplazar&#x00e1; las palabras clave <literal>true</literal> y "
-"<literal>false</literal> con los literales <literal>1</literal> y "
-"<literal>0</literal> en el SQL traducido de este HQL:"
+"Esto remplazará las palabras clave <literal>true</literal> y <literal>false</"
+"literal> con los literales <literal>1</literal> y <literal>0</literal> en el "
+"SQL traducido de este HQL:"
 
-#. Tag: programlisting
-#: query_hql.xml:702
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.alive = true]]>"
-msgstr "<![CDATA[from Cat cat where cat.alive = true]]>"
-
 #. Tag: para
-#: query_hql.xml:704
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can test the size of a collection with the special property "
 "<literal>size</literal> or the special <literal>size()</literal> function."
 msgstr ""
-"Puedes comprobar el tama&#x00f1;o de una colecci&#x00f3;n con la propiedad "
-"especial <literal>size</literal>, o la funci&#x00f3;n especial <literal>size"
-"()</literal>."
+"Puede comprobar el tamaño de una colección con la propiedad especial "
+"<literal>size</literal> o la función especial <literal>size()</literal>."
 
-#. Tag: programlisting
-#: query_hql.xml:709
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.kittens.size > 0]]>"
-msgstr "<![CDATA[from Cat cat where cat.kittens.size > 0]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:711
-#, no-c-format
-msgid "<![CDATA[from Cat cat where size(cat.kittens) > 0]]>"
-msgstr "<![CDATA[from Cat cat where size(cat.kittens) > 0]]>"
-
 #. Tag: para
-#: query_hql.xml:713
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For indexed collections, you can refer to the minimum and maximum indices "
 "using <literal>minindex</literal> and <literal>maxindex</literal> functions. "
@@ -1505,315 +970,103 @@
 "of basic type using the <literal>minelement</literal> and "
 "<literal>maxelement</literal> functions. For example:"
 msgstr ""
-"Para colecciones indexadas, puedes referirte a los &#x00ed;ndices m&#x00e1;"
-"ximo y m&#x00ed;nimo usando las funciones <literal>minindex</literal> y "
-"<literal>maxindex</literal>. Similarmente, puedes referirte a los elementos "
-"m&#x00e1;ximo y m&#x00ed;nimo de una colecci&#x00f3;n de tipo b&#x00e1;sico "
-"usando las funciones <literal>minelement</literal> y <literal>maxelement</"
-"literal>."
+"Para las colecciones indexadas, puede referirse a los índices máximo y "
+"mínimo utilizando las funciones <literal>minindex</literal> y "
+"<literal>maxindex</literal>. De manera similar, se puede referir a los "
+"elementos máximo y mínimo de una colección de tipo básico utilizando las "
+"funciones <literal>minelement</literal> y <literal>maxelement</literal>. Por "
+"ejemplo: "
 
-#. Tag: programlisting
-#: query_hql.xml:721
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Calendar cal where maxelement(cal.holidays) > current_date]]>"
-msgstr ""
-"<![CDATA[from Calendar cal where maxelement(cal.holidays) > current_date]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:723
-#, no-c-format
-msgid "<![CDATA[from Order order where maxindex(order.items) > 100]]>"
-msgstr "<![CDATA[from Order order where maxindex(order.items) > 100]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:725
-#, no-c-format
-msgid "<![CDATA[from Order order where minelement(order.items) > 10000]]>"
-msgstr "<![CDATA[from Order order where minelement(order.items) > 10000]]>"
-
-#. Tag: para
-#: query_hql.xml:727
-#, fuzzy, no-c-format
-msgid ""
 "The SQL functions <literal>any, some, all, exists, in</literal> are "
 "supported when passed the element or index set of a collection "
 "(<literal>elements</literal> and <literal>indices</literal> functions) or "
 "the result of a subquery (see below):"
 msgstr ""
-"Las funciones SQL <literal>any, some, all, exists, in</literal> est&#x00e1;n "
-"soportadas cuando se les pasa el conjunto de elementos o &#x00ed;ndices de "
-"una colecci&#x00f3;n (funciones <literal>elements</literal> y "
-"<literal>indices</literal>) o el resultado de una subconsulta (ver debajo)."
+"Las funciones SQL <literal>any, some, all, exists, in</literal> están "
+"soportadas cuando se les pasa el conjunto de elementos o índices de una "
+"colección (las funciones <literal>elements</literal> e <literal>indices</"
+"literal>) o el resultado de una subconsulta (vea a continuación):"
 
-#. Tag: programlisting
-#: query_hql.xml:733
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select mother from Cat as mother, Cat as kit\n"
-"where kit in elements(foo.kittens)]]>"
-msgstr ""
-"<![CDATA[select mother from Cat as mother, Cat as kit\n"
-"where kit in elements(foo.kittens)]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:735
-#, no-c-format
-msgid ""
-"<![CDATA[select p from NameList list, Person p\n"
-"where p.name = some elements(list.names)]]>"
-msgstr ""
-"<![CDATA[select p from NameList list, Person p\n"
-"where p.name = some elements(list.names)]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:737
-#, no-c-format
-msgid "<![CDATA[from Cat cat where exists elements(cat.kittens)]]>"
-msgstr "<![CDATA[from Cat cat where exists elements(cat.kittens)]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:739
-#, no-c-format
-msgid "<![CDATA[from Player p where 3 > all elements(p.scores)]]>"
-msgstr "<![CDATA[from Player p where 3 > all elements(p.scores)]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:741
-#, no-c-format
-msgid "<![CDATA[from Show show where 'fizard' in indices(show.acts)]]>"
-msgstr "<![CDATA[from Show show where 'fizard' in indices(show.acts)]]>"
-
-#. Tag: para
-#: query_hql.xml:743
-#, fuzzy, no-c-format
-msgid ""
 "Note that these constructs - <literal>size</literal>, <literal>elements</"
 "literal>, <literal>indices</literal>, <literal>minindex</literal>, "
 "<literal>maxindex</literal>, <literal>minelement</literal>, "
 "<literal>maxelement</literal> - can only be used in the where clause in "
 "Hibernate3."
 msgstr ""
-"Nota que estas construcciones - <literal>size</literal>, <literal>elements</"
+"Note que estas construcciones - <literal>size</literal>, <literal>elements</"
 "literal>, <literal>indices</literal>, <literal>minindex</literal>, "
 "<literal>maxindex</literal>, <literal>minelement</literal>, "
-"<literal>maxelement</literal> - pueden ser usadas solamente en la cl&#x00e1;"
-"usula where en Hibernate3."
+"<literal>maxelement</literal> - solo se pueden utilizar en la cláusula where "
+"en Hibernate3."
 
 #. Tag: para
-#: query_hql.xml:750
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Elements of indexed collections (arrays, lists, and maps) can be referred to "
 "by index in a where clause only:"
 msgstr ""
-"Los elementos de colecciones indexadas (arrays, listas, mapas) pueden ser "
-"referidos por &#x00ed;ndice (en una cl&#x00e1;usula where solamente):"
+"Los elementos de colecciones indexadas (arrays, listas, mapas) se pueden "
+"referir por índice sólamente en una cláusula where:"
 
-#. Tag: programlisting
-#: query_hql.xml:755
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from Order order where order.items[0].id = 1234]]>"
-msgstr "<![CDATA[from Order order where order.items[0].id = 1234]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:757
-#, no-c-format
 msgid ""
-"<![CDATA[select person from Person person, Calendar calendar\n"
-"where calendar.holidays['national day'] = person.birthDay\n"
-"    and person.nationality.calendar = calendar]]>"
-msgstr ""
-"<![CDATA[select person from Person person, Calendar calendar\n"
-"where calendar.holidays['national day'] = person.birthDay\n"
-"    and person.nationality.calendar = calendar]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:759
-#, no-c-format
-msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ order.deliveredItemIndices[0] ] = item and order.id = 11]]"
-">"
-msgstr ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ order.deliveredItemIndices[0] ] = item and order.id = 11]]"
-">"
-
-#. Tag: programlisting
-#: query_hql.xml:761
-#, no-c-format
-msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ maxindex(order.items) ] = item and order.id = 11]]>"
-msgstr ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ maxindex(order.items) ] = item and order.id = 11]]>"
-
-#. Tag: para
-#: query_hql.xml:763
-#, fuzzy, no-c-format
-msgid ""
 "The expression inside <literal>[]</literal> can even be an arithmetic "
 "expression:"
 msgstr ""
-"La expresi&#x00f3;n dentro de <literal>[]</literal> puede incluso ser una "
-"expresi&#x00f3;n aritm&#x00e9;tica."
+"La expresión dentro de <literal>[]</literal> puede incluso ser una expresión "
+"aritmética:"
 
-#. Tag: programlisting
-#: query_hql.xml:767
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ size(order.items) - 1 ] = item]]>"
-msgstr ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ size(order.items) - 1 ] = item]]>"
-
-#. Tag: para
-#: query_hql.xml:769
-#, fuzzy, no-c-format
-msgid ""
 "HQL also provides the built-in <literal>index()</literal> function for "
 "elements of a one-to-many association or collection of values."
 msgstr ""
-"HQL provee adem&#x00e1;s el funci&#x00f3;n prefabricada <literal>index()</"
-"literal>, para elementos de una asociaci&#x00f3;n uno-a-muchos o "
-"colecci&#x00f3;n de valores."
+"HQL también proporciona la función incorporada <literal>index()</literal>, "
+"para los elementos de una asociación uno-a-muchos o una colección de valores."
 
-#. Tag: programlisting
-#: query_hql.xml:774
-#, no-c-format
-msgid ""
-"<![CDATA[select item, index(item) from Order order\n"
-"    join order.items item\n"
-"where index(item) < 5]]>"
-msgstr ""
-"<![CDATA[select item, index(item) from Order order \n"
-"    join order.items item\n"
-"where index(item) < 5]]>"
-
 #. Tag: para
-#: query_hql.xml:776
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Scalar SQL functions supported by the underlying database can be used:"
 msgstr ""
-"Pueden usarse las funciones SQL escalares soportadas por la base de datos "
-"subyacente"
+"Se pueden utilizar las funciones SQL escalares soportadas por la base de "
+"datos subyacente:"
 
-#. Tag: programlisting
-#: query_hql.xml:780
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where upper(cat.name) like 'FRI%']]>"
-msgstr "<![CDATA[from DomesticCat cat where upper(cat.name) like 'FRI%']]>"
-
 #. Tag: para
-#: query_hql.xml:782
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Consider how much longer and less readable the following query would be in "
 "SQL:"
 msgstr ""
-"Si a&#x00fa;n no est&#x00e1;s convencido de todo esto, piensa cu&#x00e1;nto "
-"m&#x00e1;s largo y menos le&#x00ed;ble ser&#x00ed;a la siguiente consulta en "
-"SQL:"
+"Considere qué tan larga y menos leíble sería la siguiente consulta en SQL:"
 
-#. Tag: programlisting
-#: query_hql.xml:787
-#, no-c-format
-msgid ""
-"<![CDATA[select cust\n"
-"from Product prod,\n"
-"    Store store\n"
-"    inner join store.customers cust\n"
-"where prod.name = 'widget'\n"
-"    and store.location.name in ( 'Melbourne', 'Sydney' )\n"
-"    and prod = all elements(cust.currentOrder.lineItems)]]>"
-msgstr ""
-"<![CDATA[select cust\n"
-"from Product prod,\n"
-"    Store store\n"
-"    inner join store.customers cust\n"
-"where prod.name = 'widget'\n"
-"    and store.location.name in ( 'Melbourne', 'Sydney' )\n"
-"    and prod = all elements(cust.currentOrder.lineItems)]]>"
-
 #. Tag: para
-#: query_hql.xml:789
 #, no-c-format
 msgid "<emphasis>Hint:</emphasis> something like"
 msgstr "<emphasis>Ayuda:</emphasis> algo como"
 
-#. Tag: programlisting
-#: query_hql.xml:793
-#, no-c-format
-msgid ""
-"<![CDATA[SELECT cust.name, cust.address, cust.phone, cust.id, cust."
-"current_order\n"
-"FROM customers cust,\n"
-"    stores store,\n"
-"    locations loc,\n"
-"    store_customers sc,\n"
-"    product prod\n"
-"WHERE prod.name = 'widget'\n"
-"    AND store.loc_id = loc.id\n"
-"    AND loc.name IN ( 'Melbourne', 'Sydney' )\n"
-"    AND sc.store_id = store.id\n"
-"    AND sc.cust_id = cust.id\n"
-"    AND prod.id = ALL(\n"
-"        SELECT item.prod_id\n"
-"        FROM line_items item, orders o\n"
-"        WHERE item.order_id = o.id\n"
-"            AND cust.current_order = o.id\n"
-"    )]]>"
-msgstr ""
-"<![CDATA[SELECT cust.name, cust.address, cust.phone, cust.id, cust."
-"current_order\n"
-"FROM customers cust,\n"
-"    stores store,\n"
-"    locations loc,\n"
-"    store_customers sc,\n"
-"    product prod\n"
-"WHERE prod.name = 'widget'\n"
-"    AND store.loc_id = loc.id\n"
-"    AND loc.name IN ( 'Melbourne', 'Sydney' )\n"
-"    AND sc.store_id = store.id\n"
-"    AND sc.cust_id = cust.id\n"
-"    AND prod.id = ALL(\n"
-"        SELECT item.prod_id\n"
-"        FROM line_items item, orders o\n"
-"        WHERE item.order_id = o.id\n"
-"            AND cust.current_order = o.id\n"
-"    )]]>"
-
 #. Tag: title
-#: query_hql.xml:798
 #, no-c-format
 msgid "The order by clause"
-msgstr "La cl&#x00e1;usula order by"
+msgstr "La cláusula order by"
 
 #. Tag: para
-#: query_hql.xml:800
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The list returned by a query can be ordered by any property of a returned "
 "class or components:"
 msgstr ""
-"La lista devuelta por una consulta puede ser ordenada por cualquier "
-"propiedad de una clase devuelta o componentes:"
+"La lista retornada por una consulta se puede ordenar por cualquier propiedad "
+"de una clase retornada o componentes:"
 
-#. Tag: programlisting
-#: query_hql.xml:804
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat cat\n"
-"order by cat.name asc, cat.weight desc, cat.birthdate]]>"
-msgstr ""
-"<![CDATA[from DomesticCat cat\n"
-"order by cat.name asc, cat.weight desc, cat.birthdate]]>"
-
 #. Tag: para
-#: query_hql.xml:806
 #, no-c-format
 msgid ""
 "The optional <literal>asc</literal> or <literal>desc</literal> indicate "
@@ -1823,119 +1076,58 @@
 "ordenamiento ascendente o descendente respectivamente."
 
 #. Tag: title
-#: query_hql.xml:813
 #, no-c-format
 msgid "The group by clause"
-msgstr "La cl&#x00e1;usula group by"
+msgstr "La cláusula group by"
 
 #. Tag: para
-#: query_hql.xml:815
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A query that returns aggregate values can be grouped by any property of a "
 "returned class or components:"
 msgstr ""
-"Una consulta que devuelve valores agregados puede ser agrupada por cualquier "
-"propiedad de una clase devuelta o componentes:"
+"Una consulta que retorna valores agregados  se puede agrupar por cualquier "
+"propiedad de una clase retornada o componentes:"
 
-#. Tag: programlisting
-#: query_hql.xml:819
-#, no-c-format
-msgid ""
-"<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
-"from Cat cat\n"
-"group by cat.color]]>"
-msgstr ""
-"<![CDATA[select cat.color, sum(cat.weight), count(cat) \n"
-"from Cat cat\n"
-"group by cat.color]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:821
-#, no-c-format
-msgid ""
-"<![CDATA[select foo.id, avg(name), max(name)\n"
-"from Foo foo join foo.names name\n"
-"group by foo.id]]>"
-msgstr ""
-"<![CDATA[select foo.id, avg(name), max(name) \n"
-"from Foo foo join foo.names name\n"
-"group by foo.id]]>"
-
 #. Tag: para
-#: query_hql.xml:823
 #, no-c-format
 msgid "A <literal>having</literal> clause is also allowed."
-msgstr ""
-"Se permite tambi&#x00e9;n una cl&#x00e1;usula <literal>having</literal>."
+msgstr "Se permite también una cláusula <literal>having</literal>."
 
-#. Tag: programlisting
-#: query_hql.xml:827
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
-"from Cat cat\n"
-"group by cat.color\n"
-"having cat.color in (eg.Color.TABBY, eg.Color.BLACK)]]>"
-msgstr ""
-"<![CDATA[select cat.color, sum(cat.weight), count(cat) \n"
-"from Cat cat\n"
-"group by cat.color \n"
-"having cat.color in (eg.Color.TABBY, eg.Color.BLACK)]]>"
-
-#. Tag: para
-#: query_hql.xml:829
-#, fuzzy, no-c-format
-msgid ""
 "SQL functions and aggregate functions are allowed in the <literal>having</"
 "literal> and <literal>order by</literal> clauses if they are supported by "
 "the underlying database (i.e., not in MySQL)."
 msgstr ""
-"Las funciones y funciones de agregaci&#x00f3;n SQL est&#x00e1;n permitidas "
-"en las cl&#x00e1;usulas <literal>having</literal> y <literal>order by</"
-"literal>, si est&#x00e1;n soportadas por la base de datos subyacente (por "
-"ejemplo, no en MySQL)."
+"Las funciones SQL y las funciones de agregación SQL están permitidas en las "
+"cláusulas <literal>having</literal> y <literal>order by</literal>, si están "
+"soportadas por la base de datos subyacente (por ejemplo, no lo están en "
+"MySQL). "
 
-#. Tag: programlisting
-#: query_hql.xml:835
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat\n"
-"from Cat cat\n"
-"    join cat.kittens kitten\n"
-"group by cat.id, cat.name, cat.other, cat.properties\n"
-"having avg(kitten.weight) > 100\n"
-"order by count(kitten) asc, sum(kitten.weight) desc]]>"
-msgstr ""
-"<![CDATA[select cat\n"
-"from Cat cat\n"
-"    join cat.kittens kitten\n"
-"group by cat\n"
-"having avg(kitten.weight) > 100\n"
-"order by count(kitten) asc, sum(kitten.weight) desc]]>"
-
-#. Tag: para
-#: query_hql.xml:837
-#, fuzzy, no-c-format
-msgid ""
 "Neither the <literal>group by</literal> clause nor the <literal>order by</"
 "literal> clause can contain arithmetic expressions. Hibernate also does not "
 "currently expand a grouped entity, so you cannot write <literal>group by "
 "cat</literal> if all properties of <literal>cat</literal> are non-"
 "aggregated. You have to list all non-aggregated properties explicitly."
 msgstr ""
-"Nota que ni la cl&#x00e1;usula <literal>group by</literal> ni la cl&#x00e1;"
-"usula <literal>order by</literal> pueden contener expresiones aritm&#x00e9;"
-"ticas."
+"La cláusula <literal>group by</literal> ni la cláusula <literal>order by</"
+"literal> pueden contener expresiones aritméticas. Hibernate tampocoo expande "
+"una entidad agrupada así que no puede escribir <literal>group by cat</"
+"literal> si todas las propiedades de <literal>cat</literal> son no-"
+"agregadas. Tiene que enumerar todas la propiedades no-agregadas "
+"explícitamente."
 
 #. Tag: title
-#: query_hql.xml:849
 #, no-c-format
 msgid "Subqueries"
 msgstr "Subconsultas"
 
 #. Tag: para
-#: query_hql.xml:851
 #, no-c-format
 msgid ""
 "For databases that support subselects, Hibernate supports subqueries within "
@@ -1944,106 +1136,36 @@
 "to an alias in the outer query) are allowed."
 msgstr ""
 "Para bases de datos que soportan subconsultas, Hibernate soporta "
-"subconsultas dentro de consultas. Una subconsulta debe ser encerrada entre "
-"par&#x00e9;ntesis (frecuentemente por una llamada a una funci&#x00f3;n de "
-"agregaci&#x00f3;n SQL). Incluso se permiten subconsultas correlacionadas "
-"(subconsultas que hacen referencia a un alias en la consulta exterior)."
+"subconsultas dentro de consultas. Una subconsulta se debe encerrar entre "
+"paréntesis (frecuentemente por una llamada a una función de agregación SQL). "
+"Incluso se permiten subconsultas correlacionadas (subconsultas que se "
+"refieren a un alias en la consulta exterior)."
 
-#. Tag: programlisting
-#: query_hql.xml:857
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as fatcat\n"
-"where fatcat.weight > (\n"
-"    select avg(cat.weight) from DomesticCat cat\n"
-")]]>"
-msgstr ""
-"<![CDATA[from Cat as fatcat\n"
-"                                      where fatcat.weight > (\n"
-"                select avg(cat.weight) from DomesticCat cat\n"
-"                )]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:859
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat as cat\n"
-"where cat.name = some (\n"
-"    select name.nickName from Name as name\n"
-")]]>"
-msgstr ""
-"<![CDATA[from DomesticCat as cat\n"
-"                                      where cat.name = some (\n"
-"                                      select name.nickName from Name as "
-"name\n"
-"                                      )]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:861
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"where not exists (\n"
-"    from Cat as mate where mate.mate = cat\n"
-")]]>"
-msgstr ""
-"<![CDATA[from Cat as cat\n"
-"                                      where not exists (\n"
-"                                      from Cat as mate where mate.mate = "
-"cat\n"
-"                                      )]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:863
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat as cat\n"
-"where cat.name not in (\n"
-"    select name.nickName from Name as name\n"
-")]]>"
-msgstr ""
-"<![CDATA[from DomesticCat as cat\n"
-"                                      where cat.name not in (\n"
-"                                      select name.nickName from Name as "
-"name\n"
-"                                      )]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:865
-#, no-c-format
-msgid ""
-"<![CDATA[select cat.id, (select max(kit.weight) from cat.kitten kit)\n"
-"from Cat as cat]]>"
-msgstr ""
-"<![CDATA[select cat.id, (select max(kit.weight) from cat.kitten kit)\n"
-"                                        from Cat as cat]]>"
-
 #. Tag: para
-#: query_hql.xml:867
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Note that HQL subqueries can occur only in the select or where clauses."
 msgstr ""
-"Note that HQL subqueries may occur only in the select or where clauses."
+"Note que las subconsultas HQL pueden ocurrir sólamente en las cláusulas "
+"select o where."
 
 #. Tag: para
-#: query_hql.xml:871
 #, fuzzy, no-c-format
 msgid ""
 "Note that subqueries can also utilize <literal>row value constructor</"
-"literal> syntax. See <xref linkend=\"queryhql-tuple\"/> for more information."
+"literal> syntax. See <xref linkend=\"queryhql-tuple\" /> for more "
+"information."
 msgstr ""
-"Note that subqueries can also utilize <literal>row value constructor</"
-"literal> syntax. See <xref linkend=\"queryhql-tuple\"/> for more details."
+"Note que las subconsultas también pueden utilizar la sintaxis <literal>row "
+"value constructor</literal>. Consulte la <xref linkend=\"queryhql-tuple\" /> "
+"para obtener más información."
 
 #. Tag: title
-#: query_hql.xml:879
 #, no-c-format
 msgid "HQL examples"
 msgstr "Ejemplos de HQL"
 
 #. Tag: para
-#: query_hql.xml:881
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate queries can be quite powerful and complex. In fact, the power of "
 "the query language is one of Hibernate's main strengths. The following "
@@ -2051,16 +1173,14 @@
 "projects. Please note that most queries you will write will be much simpler "
 "than the following examples."
 msgstr ""
-"Las consultas de Hibernate pueden ser abolutamente potentes y complejas, De "
-"hecho, el poder del lenguaje de consulta es uno de los puntos principales de "
-"venta de Hibernate. He aqu&#x00ed; algunos consultas de ejemplo muy "
-"similares a consultas que he usado en un proyecto reciente. &#x00a1;Nota que "
-"la mayor&#x00ed;a de las consultas que escribir&#x00e1;s som mucho m&#x00e1;"
-"s simples que estas!"
+"Las consultas de Hibernate pueden ser bastante potentes y complejas. De "
+"hecho, el poder del lenguaje de consulta es uno de las fortalezas "
+"principales de Hibernate. He aquí algunos ejemplos de consultas muy "
+"similares a las consultas de proyectos recientes. Note que la mayoría de las "
+"consultas que escribirá son mucho más simples que los siguientes ejemplos."
 
 #. Tag: para
-#: query_hql.xml:887
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following query returns the order id, number of items, the given minimum "
 "total value and the total value of the order for all unpaid orders for a "
@@ -2070,102 +1190,25 @@
 "<literal>PRODUCT</literal>, <literal>CATALOG</literal> and <literal>PRICE</"
 "literal> tables has four inner joins and an (uncorrelated) subselect."
 msgstr ""
-"La siguiente consulta devuelve el order id, n&#x00fa;mero de items y valor "
-"total de la orden para todas las ordenes inpagas de un cliente en particular "
-"y valor total m&#x00ed;nimo dados, ordenando los resultados por valor total. "
-"Al determinar los precios, usa el cat&#x00e1;logo actual. La consulta SQL "
+"La siguiente consulta retorna el order id, número de items y valor total "
+"mínimo dado y el valor de la orden para todas las órdenes no pagadas de un "
+"cliente en particular. Los resultados se ordenan de acuerdo al valor total. "
+"Al determinar los precios, usa el catálogo actual. La consulta SQL "
 "resultante, contra las tablas <literal>ORDER</literal>, <literal>ORDER_LINE</"
-"literal>, <literal>PRODUCT</literal>, <literal>CATALOG</literal> and "
-"<literal>PRICE</literal> tiene cuatro joins interiores y una subselect (no "
-"correlacionada)."
+"literal>, <literal>PRODUCT</literal>, <literal>CATALOG</literal> y "
+"<literal>PRICE</literal> tiene cuatro uniones interiores y una subselección "
+"(no correlacionada)."
 
-#. Tag: programlisting
-#: query_hql.xml:896
-#, no-c-format
-msgid ""
-"<![CDATA[select order.id, sum(price.amount), count(item)\n"
-"from Order as order\n"
-"    join order.lineItems as item\n"
-"    join item.product as product,\n"
-"    Catalog as catalog\n"
-"    join catalog.prices as price\n"
-"where order.paid = false\n"
-"    and order.customer = :customer\n"
-"    and price.product = product\n"
-"    and catalog.effectiveDate < sysdate\n"
-"    and catalog.effectiveDate >= all (\n"
-"        select cat.effectiveDate\n"
-"        from Catalog as cat\n"
-"        where cat.effectiveDate < sysdate\n"
-"    )\n"
-"group by order\n"
-"having sum(price.amount) > :minAmount\n"
-"order by sum(price.amount) desc]]>"
-msgstr ""
-"<![CDATA[select order.id, sum(price.amount), count(item)\n"
-"from Order as order\n"
-"    join order.lineItems as item\n"
-"    join item.product as product,\n"
-"    Catalog as catalog\n"
-"    join catalog.prices as price\n"
-"where order.paid = false\n"
-"    and order.customer = :customer\n"
-"    and price.product = product\n"
-"    and catalog.effectiveDate < sysdate\n"
-"    and catalog.effectiveDate >= all (\n"
-"        select cat.effectiveDate \n"
-"        from Catalog as cat\n"
-"        where cat.effectiveDate < sysdate\n"
-"    )\n"
-"group by order\n"
-"having sum(price.amount) > :minAmount\n"
-"order by sum(price.amount) desc]]>"
-
 #. Tag: para
-#: query_hql.xml:898
 #, no-c-format
 msgid ""
 "What a monster! Actually, in real life, I'm not very keen on subqueries, so "
 "my query was really more like this:"
 msgstr ""
-"&#x00a1;Qu&#x00e9; monstruo! Realmente, en la vida real, no estoy muy "
-"afilado en subconsultas, de modo que mi consulta fue realmente algo como "
-"esto:"
+"¡Qué monstruo! Realmente, en la vida real, no me gustan mucho las "
+"subconsultas, de modo que mi consulta fue realmente algo como esto:"
 
-#. Tag: programlisting
-#: query_hql.xml:903
-#, no-c-format
-msgid ""
-"<![CDATA[select order.id, sum(price.amount), count(item)\n"
-"from Order as order\n"
-"    join order.lineItems as item\n"
-"    join item.product as product,\n"
-"    Catalog as catalog\n"
-"    join catalog.prices as price\n"
-"where order.paid = false\n"
-"    and order.customer = :customer\n"
-"    and price.product = product\n"
-"    and catalog = :currentCatalog\n"
-"group by order\n"
-"having sum(price.amount) > :minAmount\n"
-"order by sum(price.amount) desc]]>"
-msgstr ""
-"<![CDATA[select order.id, sum(price.amount), count(item)\n"
-"from Order as order\n"
-"    join order.lineItems as item\n"
-"    join item.product as product,\n"
-"    Catalog as catalog\n"
-"    join catalog.prices as price\n"
-"where order.paid = false\n"
-"    and order.customer = :customer\n"
-"    and price.product = product\n"
-"    and catalog = :currentCatalog\n"
-"group by order\n"
-"having sum(price.amount) > :minAmount\n"
-"order by sum(price.amount) desc]]>"
-
 #. Tag: para
-#: query_hql.xml:905
 #, no-c-format
 msgid ""
 "The next query counts the number of payments in each status, excluding all "
@@ -2175,84 +1218,23 @@
 "<literal>PAYMENT</literal>, <literal>PAYMENT_STATUS</literal> and "
 "<literal>PAYMENT_STATUS_CHANGE</literal> tables."
 msgstr ""
-"La pr&#x00f3;xima consulta cuenta el n&#x00fa;mero de pagos en cada estado, "
-"excluyendo todos los pagos en el estado <literal>AWAITING_APPROVAL</literal> "
-"donde el estado m&#x00e1;s reciente fue hecho por el usuario actual. Se "
-"traduce en una consulta SQL con dos joins interiores y una subselect "
-"correlacionada contra las tablas <literal>PAYMENT</literal>, "
-"<literal>PAYMENT_STATUS</literal> y <literal>PAYMENT_STATUS_CHANGE</literal>."
+"La próxima consulta cuenta el número de pagos en cada estado, excluyendo "
+"todos los pagos en el estado <literal>AWAITING_APPROVAL</literal> donde el "
+"cambio más reciente al estado lo hizo el usuario actual. Se traduce en una "
+"consulta SQL con dos uniones interiores y una subselección correlacionada "
+"contra las tablas <literal>PAYMENT</literal>, <literal>PAYMENT_STATUS</"
+"literal> y <literal>PAYMENT_STATUS_CHANGE</literal>."
 
-#. Tag: programlisting
-#: query_hql.xml:913
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select count(payment), status.name\n"
-"from Payment as payment\n"
-"    join payment.currentStatus as status\n"
-"    join payment.statusChanges as statusChange\n"
-"where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-"    or (\n"
-"        statusChange.timeStamp = (\n"
-"            select max(change.timeStamp)\n"
-"            from PaymentStatusChange change\n"
-"            where change.payment = payment\n"
-"        )\n"
-"        and statusChange.user <> :currentUser\n"
-"    )\n"
-"group by status.name, status.sortOrder\n"
-"order by status.sortOrder]]>"
-msgstr ""
-"<![CDATA[select count(payment), status.name \n"
-"from Payment as payment \n"
-"    join payment.currentStatus as status\n"
-"    join payment.statusChanges as statusChange\n"
-"where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-"    or (\n"
-"        statusChange.timeStamp = ( \n"
-"            select max(change.timeStamp) \n"
-"            from PaymentStatusChange change \n"
-"            where change.payment = payment\n"
-"        )\n"
-"        and statusChange.user <> :currentUser\n"
-"    )\n"
-"group by status.name, status.sortOrder\n"
-"order by status.sortOrder]]>"
-
-#. Tag: para
-#: query_hql.xml:915
-#, fuzzy, no-c-format
-msgid ""
 "If the <literal>statusChanges</literal> collection was mapped as a list, "
 "instead of a set, the query would have been much simpler to write."
 msgstr ""
-"Si hubiese mapeado la colecci&#x00f3;n <literal>statusChanges</literal> como "
-"una lista, en vez de un conjunto, la consulta habr&#x00ed;a sido mucho "
-"m&#x00e1;s simple de escribir."
+"Si la colección <literal>statusChanges</literal> se mapeara como una lista, "
+"en vez de un conjunto, la consulta habría sido mucho más simple de escribir."
 
-#. Tag: programlisting
-#: query_hql.xml:920
-#, no-c-format
-msgid ""
-"<![CDATA[select count(payment), status.name\n"
-"from Payment as payment\n"
-"    join payment.currentStatus as status\n"
-"where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-"    or payment.statusChanges[ maxIndex(payment.statusChanges) ].user <> :"
-"currentUser\n"
-"group by status.name, status.sortOrder\n"
-"order by status.sortOrder]]>"
-msgstr ""
-"<![CDATA[select count(payment), status.name \n"
-"from Payment as payment\n"
-"    join payment.currentStatus as status\n"
-"where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-"    or payment.statusChanges[ maxIndex(payment.statusChanges) ].user <> :"
-"currentUser\n"
-"group by status.name, status.sortOrder\n"
-"order by status.sortOrder]]>"
-
 #. Tag: para
-#: query_hql.xml:922
 #, no-c-format
 msgid ""
 "The next query uses the MS SQL Server <literal>isNull()</literal> function "
@@ -2263,372 +1245,156 @@
 "<literal>ACCOUNT_TYPE</literal>, <literal>ORGANIZATION</literal> and "
 "<literal>ORG_USER</literal> tables."
 msgstr ""
-"La pr&#x00f3;xima consulta usa la funci&#x00f3;n <literal>isNull()</literal> "
-"de MS SQL Server para devolver todas las cuentas y pagos inpagos de la "
-"organizaci&#x00f3;n a la que pertenece el usuario actual. Se traduce en una "
-"consulta SQL con tres joins interiores, un join exterior y una subconsulta "
-"contra las tablas <literal>ACCOUNT</literal>, <literal>PAYMENT</literal>, "
-"<literal>PAYMENT_STATUS</literal>, <literal>ACCOUNT_TYPE</literal>, "
-"<literal>ORGANIZATION</literal> y <literal>ORG_USER</literal>."
+"La próxima consulta utiliza la función <literal>isNull()</literal> de MS SQL "
+"Server para devolver todas las cuentas y pagos aún no cancelados de la "
+"organización a la que pertenece el usuario actual. Se traduce como una "
+"consulta SQL con tres uniones interiores, una unión exterior y una "
+"subselección contra las tablas <literal>ACCOUNT</literal>, <literal>PAYMENT</"
+"literal>, <literal>PAYMENT_STATUS</literal>, <literal>ACCOUNT_TYPE</"
+"literal>, <literal>ORGANIZATION</literal> y <literal>ORG_USER</literal>."
 
-#. Tag: programlisting
-#: query_hql.xml:931
-#, no-c-format
-msgid ""
-"<![CDATA[select account, payment\n"
-"from Account as account\n"
-"    left outer join account.payments as payment\n"
-"where :currentUser in elements(account.holder.users)\n"
-"    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
-"PaymentStatus.UNPAID)\n"
-"order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-msgstr ""
-"<![CDATA[select account, payment\n"
-"from Account as account\n"
-"    left outer join account.payments as payment\n"
-"where :currentUser in elements(account.holder.users)\n"
-"    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
-"PaymentStatus.UNPAID)\n"
-"order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-
 #. Tag: para
-#: query_hql.xml:933
 #, no-c-format
 msgid ""
 "For some databases, we would need to do away with the (correlated) subselect."
 msgstr ""
-"Para algunas bases de datos, necesitar&#x00ed;amos eliminar la subselect "
+"Para algunas bases de datos, necesitaríamos eliminar la subselección "
 "(correlacionada)."
 
-#. Tag: programlisting
-#: query_hql.xml:937
-#, no-c-format
-msgid ""
-"<![CDATA[select account, payment\n"
-"from Account as account\n"
-"    join account.holder.users as user\n"
-"    left outer join account.payments as payment\n"
-"where :currentUser = user\n"
-"    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
-"PaymentStatus.UNPAID)\n"
-"order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-msgstr ""
-"<![CDATA[select account, payment\n"
-"from Account as account\n"
-"    join account.holder.users as user\n"
-"    left outer join account.payments as payment\n"
-"where :currentUser = user\n"
-"    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
-"PaymentStatus.UNPAID)\n"
-"order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-
 #. Tag: title
-#: query_hql.xml:942
 #, no-c-format
 msgid "Bulk update and delete"
-msgstr "Sentencias UPDATE y DELETE masivas"
+msgstr "Declaraciones UPDATE y DELETE masivas"
 
 #. Tag: para
-#: query_hql.xml:944
 #, fuzzy, no-c-format
 msgid ""
 "HQL now supports <literal>update</literal>, <literal>delete</literal> and "
 "<literal>insert ... select ...</literal> statements. See <xref linkend="
-"\"batch-direct\"/> for more information."
+"\"batch-direct\" /> for more information."
 msgstr ""
-"HQL soporta ahora sentencias UPDATE y DELETE en HQL. Ver <xref linkend="
-"\"batch-direct\"/> para detalles."
+"HQL ahora soporta declaraciones <literal>update</literal>, <literal>delete</"
+"literal> e <literal>insert ... select ...</literal>. Consulte la <xref "
+"linkend=\"batch-direct\" /> para obtener mayor información. "
 
 #. Tag: title
-#: query_hql.xml:952
 #, no-c-format
 msgid "Tips &amp; Tricks"
 msgstr "Consejos y Trucos"
 
 #. Tag: para
-#: query_hql.xml:954
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can count the number of query results without returning them:"
-msgstr ""
-"Puedes contar el n&#x00fa;mero de resultados de una consulta sin devolverlos "
-"realmente:"
+msgstr "Puede contar el número de resultados de una consulta sin retornarlos:"
 
-#. Tag: programlisting
-#: query_hql.xml:958
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
-"iterate().next() ).intValue()]]>"
-msgstr ""
-"<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
-"iterate().next() ).intValue()]]>"
-
 #. Tag: para
-#: query_hql.xml:960
 #, no-c-format
 msgid "To order a result by the size of a collection, use the following query:"
 msgstr ""
-"Para ordenar un resultado por el tama&#x00f1;o de una colecci&#x00f3;n, usa "
-"la siguiente consulta:"
+"Para ordenar un resultado por el tamaño de una colección, utilice la "
+"siguiente consulta:"
 
-#. Tag: programlisting
-#: query_hql.xml:964
-#, no-c-format
-msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User as usr\n"
-"    left join usr.messages as msg\n"
-"group by usr.id, usr.name\n"
-"order by count(msg)]]>"
-msgstr ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User as usr \n"
-"    left join usr.messages as msg\n"
-"group by usr.id, usr.name\n"
-"order by count(msg)]]>"
-
 #. Tag: para
-#: query_hql.xml:966
 #, no-c-format
 msgid ""
 "If your database supports subselects, you can place a condition upon "
 "selection size in the where clause of your query:"
 msgstr ""
-"Si tu base de datos soporta subselects, puedes colocar una condici&#x00f3;n "
-"sobre el tama&#x00f1;o de selecci&#x00f3;n en la cl&#x00e1;usula where de tu "
-"consulta:"
+"Si su base de datos soporta subselecciones, puede colocar una condición "
+"sobre el tamaño de selección en la cláusula where de su consulta:"
 
-#. Tag: programlisting
-#: query_hql.xml:971
-#, no-c-format
-msgid "<![CDATA[from User usr where size(usr.messages) >= 1]]>"
-msgstr "<![CDATA[from User usr where size(usr.messages) >= 1]]>"
-
 #. Tag: para
-#: query_hql.xml:973
-#, fuzzy, no-c-format
-msgid "If your database does not support subselects, use the following query:"
-msgstr "Si tu base de datos no soporta subselects, usa la siguiente consulta:"
-
-#. Tag: programlisting
-#: query_hql.xml:977
 #, no-c-format
-msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User usr.name\n"
-"    join usr.messages msg\n"
-"group by usr.id, usr.name\n"
-"having count(msg) >= 1]]>"
+msgid "If your database does not support subselects, use the following query:"
 msgstr ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User usr.name\n"
-"    join usr.messages msg\n"
-"group by usr.id, usr.name\n"
-"having count(msg) >= 1]]>"
+"Si su base de datos no soporta subselecciones, utilice la siguiente "
+"consulta: "
 
 #. Tag: para
-#: query_hql.xml:980
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As this solution cannot return a <literal>User</literal> with zero messages "
 "because of the inner join, the following form is also useful:"
 msgstr ""
-"Como esta soluci&#x00f3;n no puede devolver un <literal>User</literal> con "
-"cero mensajes debido a la uni&#x00f3;n interior, la siguiente forma es "
-"tambi&#x00e9;n &#x00fa;til:"
+"Como esta solución no puede retornar un <literal>User</literal> con cero "
+"mensajes debido a la unión interior, la siguiente forma también es útil:"
 
-#. Tag: programlisting
-#: query_hql.xml:985
-#, no-c-format
-msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User as usr\n"
-"    left join usr.messages as msg\n"
-"group by usr.id, usr.name\n"
-"having count(msg) = 0]]>"
-msgstr ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User as usr\n"
-"    left join usr.messages as msg\n"
-"group by usr.id, usr.name\n"
-"having count(msg) = 0]]>"
-
 #. Tag: para
-#: query_hql.xml:987
 #, no-c-format
 msgid "Properties of a JavaBean can be bound to named query parameters:"
 msgstr ""
-"Las propiedades de un JavaBean pueden ser ligadas al par&#x00e1;metros de "
+"Las propiedades de un JavaBean pueden ser ligadas a los parámetros de "
 "consulta con nombre:"
 
-#. Tag: programlisting
-#: query_hql.xml:991
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = s.createQuery(\"from foo Foo as foo where foo.name=:name "
-"and foo.size=:size\");\n"
-"q.setProperties(fooBean); // fooBean has getName() and getSize()\n"
-"List foos = q.list();]]>"
-msgstr ""
-"<![CDATA[Query q = s.createQuery(\"from foo Foo as foo where foo.name=:name "
-"and foo.size=:size\");\n"
-"q.setProperties(fooBean); // fooBean has getName() and getSize()\n"
-"List foos = q.list();]]>"
-
 #. Tag: para
-#: query_hql.xml:993
 #, no-c-format
 msgid ""
 "Collections are pageable by using the <literal>Query</literal> interface "
 "with a filter:"
 msgstr ""
-"Las colecciones son paginables usando la interface <literal>Query</literal> "
+"Las colecciones son paginables usando la interfaz <literal>Query</literal> "
 "con un filtro:"
 
-#. Tag: programlisting
-#: query_hql.xml:997
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = s.createFilter( collection, \"\" ); // the trivial "
-"filter\n"
-"q.setMaxResults(PAGE_SIZE);\n"
-"q.setFirstResult(PAGE_SIZE * pageNumber);\n"
-"List page = q.list();]]>"
-msgstr ""
-"<![CDATA[Query q = s.createFilter( collection, \"\" ); // the trivial "
-"filter\n"
-"q.setMaxResults(PAGE_SIZE);\n"
-"q.setFirstResult(PAGE_SIZE * pageNumber);\n"
-"List page = q.list();]]>"
-
 #. Tag: para
-#: query_hql.xml:999
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Collection elements can be ordered or grouped using a query filter:"
 msgstr ""
-"Los elementos de colecci&#x00f3;n pueden ser ordenados o agrupados usando un "
-"filtro de consulta:"
+"Los elementos de colección se pueden ordenar o agrupar usando un filtro de "
+"consulta:"
 
-#. Tag: programlisting
-#: query_hql.xml:1003
-#, no-c-format
-msgid ""
-"<![CDATA[Collection orderedCollection = s.filter( collection, \"order by "
-"this.amount\" );\n"
-"Collection counts = s.filter( collection, \"select this.type, count(this) "
-"group by this.type\" );]]>"
-msgstr ""
-"<![CDATA[Collection orderedCollection = s.filter( collection, \"order by "
-"this.amount\" );\n"
-"Collection counts = s.filter( collection, \"select this.type, count(this) "
-"group by this.type\" );]]>"
-
 #. Tag: para
-#: query_hql.xml:1005
 #, no-c-format
 msgid "You can find the size of a collection without initializing it:"
-msgstr ""
-"Puedes hallar el tama&#x00f1;o de una colecci&#x00f3;n sin inicializarla:"
+msgstr "Puede hallar el tamaño de una colección sin inicializarla:"
 
-#. Tag: programlisting
-#: query_hql.xml:1009
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
-"iterate().next() ).intValue();]]>"
-msgstr ""
-"<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
-"iterate().next() ).intValue();]]>"
-
 #. Tag: title
-#: query_hql.xml:1014
 #, no-c-format
 msgid "Components"
-msgstr "UNTRANSLATED! Components"
+msgstr "Componentes"
 
 #. Tag: para
-#: query_hql.xml:1016
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Components can be used similarly to the simple value types that are used in "
 "HQL queries. They can appear in the <literal>select</literal> clause as "
 "follows:"
 msgstr ""
-"Components might be used in just about every way that simple value types can "
-"be used in HQL queries. They can appear in the <literal>select</literal> "
-"clause:"
+"Los componentes se pueden utilizar de la misma manera en que se pueden "
+"utilizar los tipos de valores simples en consultas HQL. Pueden aparecer en "
+"la cláusula <literal>select</literal> así:"
 
-#. Tag: programlisting
-#: query_hql.xml:1021 query_hql.xml:1067
-#, no-c-format
-msgid "<![CDATA[select p.name from Person p]]>"
-msgstr "<![CDATA[select p.name from Person p]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:1022
-#, no-c-format
-msgid "<![CDATA[select p.name.first from Person p]]>"
-msgstr "<![CDATA[select p.name.first from Person p]]>"
-
 #. Tag: para
-#: query_hql.xml:1024
 #, no-c-format
 msgid ""
 "where the Person's name property is a component. Components can also be used "
 "in the <literal>where</literal> clause:"
 msgstr ""
-"where the Person's name property is a component. Components can also be used "
-"in the <literal>where</literal> clause:"
+"en donde el nombre de la Persona es un componente. Los componentes también "
+"se pueden utilizar en la cláusula <literal>where</literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:1029
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name = :name]]>"
-msgstr "<![CDATA[from Person p where p.name = :name]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:1030
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name.first = :firstName]]>"
-msgstr "<![CDATA[from Person p where p.name.first = :firstName]]>"
-
 #. Tag: para
-#: query_hql.xml:1032
 #, no-c-format
 msgid "Components can also be used in the <literal>order by</literal> clause:"
-msgstr "Components can also be used in the <literal>order by</literal> clause:"
+msgstr ""
+"Los componentes también se pueden utilizar en la cláusula <literal>where</"
+"literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:1036
-#, no-c-format
-msgid "<![CDATA[from Person p order by p.name]]>"
-msgstr "<![CDATA[from Person p order by p.name]]>"
-
-#. Tag: programlisting
-#: query_hql.xml:1037
-#, no-c-format
-msgid "<![CDATA[from Person p order by p.name.first]]>"
-msgstr "<![CDATA[from Person p order by p.name.first]]>"
-
 #. Tag: para
-#: query_hql.xml:1039
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Another common use of components is in <link linkend=\"queryhql-tuple\">row "
 "value constructors</link>."
 msgstr ""
-"Another common use of components is in <link linkend=\"queryhql-tuple\">row "
-"value constructors</link>."
+"Otro uso común de los componentes se encuentra en <xref linkend=\"queryhql-"
+"tuple\" />."
 
 #. Tag: title
-#: query_hql.xml:1045
 #, no-c-format
 msgid "Row value constructor syntax"
-msgstr "Row value constructor syntax"
+msgstr "Sintaxis del constructor de valores por fila"
 
 #. Tag: para
-#: query_hql.xml:1047
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL supports the use of ANSI SQL <literal>row value constructor</literal> "
 "syntax, sometimes referred to AS <literal>tuple</literal> syntax, even "
@@ -2636,111 +1402,56 @@
 "generally referring to multi-valued comparisons, typically associated with "
 "components. Consider an entity Person which defines a name component:"
 msgstr ""
-"HQL supports the use of ANSI SQL <literal>row value constructor</literal> "
-"syntax (sometimes called <literal>tuple</literal> syntax), even though the "
-"underlying database may not support that notion. Here we are generally "
-"referring to multi-valued comparisons, typically associated with components. "
-"Consider an entity Person which defines a name component:"
+"HQL soporta la utilización de la sintaxis <literal>row value constructor</"
+"literal> de SQL ANSI que a veces se denomina sintaxis <literal>tuple</"
+"literal>, aunque puede que la base de datos subyacentes no soporte esa "
+"noción. Aquí estamos refiriéndonos generalmente a las comparaciones "
+"multivaluadas que se asocian típicamente con los componentes. Considere una "
+"entidad Persona, la cual define un componente de nombre:"
 
-#. Tag: programlisting
-#: query_hql.xml:1054
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Person p where p.name.first='John' and p.name."
-"last='Jingleheimer-Schmidt']]>"
-msgstr ""
-"<![CDATA[from Person p where p.name.first='John' and p.name."
-"last='Jingleheimer-Schmidt']]>"
-
-#. Tag: para
-#: query_hql.xml:1056
-#, fuzzy, no-c-format
-msgid ""
 "That is valid syntax although it is a little verbose. You can make this more "
 "concise by using <literal>row value constructor</literal> syntax:"
 msgstr ""
-"That's valid syntax, although a little verbose. It be nice to make this a "
-"bit more concise and use <literal>row value constructor</literal> syntax:"
+"Esa es una sintaxis válida aunque un poco verbosa. Puede hacerlo un poco más "
+"conciso utilizando la sintaxis <literal>row value constructor</literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:1061
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name=('John', 'Jingleheimer-Schmidt')]]>"
-msgstr ""
-"<![CDATA[from Person p where p.name=('John', 'Jingleheimer-Schmidt')]]>"
-
 #. Tag: para
-#: query_hql.xml:1063
 #, no-c-format
 msgid ""
 "It can also be useful to specify this in the <literal>select</literal> "
 "clause:"
 msgstr ""
-"It can also be useful to specify this in the <literal>select</literal> "
-"clause:"
+"También puede ser útil especificar esto en la cláusula <literal>select</"
+"literal>:"
 
 #. Tag: para
-#: query_hql.xml:1069
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Using <literal>row value constructor</literal> syntax can also be beneficial "
 "when using subqueries that need to compare against multiple values:"
 msgstr ""
-"Another time using <literal>row value constructor</literal> syntax can be "
-"beneficial is when using subqueries needing to compare against multiple "
-"values:"
+"También puede ser beneficioso el utilizar la sintaxis <literal>row value "
+"constructor</literal> cuando se utilizan subconsultas que necesitan "
+"compararse con valores múltiples:"
 
-#. Tag: programlisting
-#: query_hql.xml:1074
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Cat as cat\n"
-"where not ( cat.name, cat.color ) in (\n"
-"    select cat.name, cat.color from DomesticCat cat\n"
-")]]>"
-msgstr ""
-"<![CDATA[from Cat as cat\n"
-"                                          where not ( cat.name, cat.color ) "
-"in (\n"
-"                                          select cat.name, cat.color from "
-"DomesticCat cat\n"
-"                                          )]]>"
-
-#. Tag: para
-#: query_hql.xml:1076
-#, fuzzy, no-c-format
-msgid ""
 "One thing to consider when deciding if you want to use this syntax, is that "
 "the query will be dependent upon the ordering of the component sub-"
 "properties in the metadata."
 msgstr ""
-"One thing to consider when deciding if you want to use this syntax is that "
-"the query will be dependent upon the ordering of the component sub-"
-"properties in the metadata."
+"Algo que se debe tomar en consideración al decidir si quiere usar esta "
+"sintaxis es que la consulta dependerá del orden de las sub-propiedades "
+"componentes en los metadatos."
 
-#~ msgid ""
-#~ "Most of the time, you will need to assign an <emphasis>alias</emphasis>, "
-#~ "since you will want to refer to the <literal>Cat</literal> in other parts "
-#~ "of the query."
-#~ msgstr ""
-#~ "La mayor&#x00ed;a del tiempo, necesitar&#x00e1;s asignar un "
-#~ "<emphasis>alias</emphasis>, ya que querr&#x00e1;s referirte al "
-#~ "<literal>Cat</literal> en otras partes de la consulta."
+#, fuzzy
+#~ msgid "left outer join"
+#~ msgstr "<literal>left outer join</literal>"
 
-#~ msgid "or as an actual typesafe Java object,"
-#~ msgstr "o como un objeto real Java de tipo seguro,"
-
-#~ msgid ""
-#~ "<![CDATA[select foo\n"
-#~ "from Foo foo, Bar bar\n"
-#~ "where foo.startDate = bar.date]]>"
-#~ msgstr ""
-#~ "<![CDATA[select foo \n"
-#~ "from Foo foo, Bar bar\n"
-#~ "where foo.startDate = bar.date]]>"
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+#, fuzzy
+#~ msgid "right outer join"
+#~ msgstr "<literal>right outer join</literal>"

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/query_sql.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/query_sql.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/query_sql.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,21 +1,35 @@
-#, fuzzy
+# translation of query_sql.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: query_sql\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-05 07:45+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: query_sql.xml:29
 #, no-c-format
 msgid "Native SQL"
 msgstr "SQL Nativo"
 
 #. Tag: para
-#: query_sql.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also express queries in the native SQL dialect of your database. "
 "This is useful if you want to utilize database-specific features such as "
@@ -23,133 +37,92 @@
 "provides a clean migration path from a direct SQL/JDBC based application to "
 "Hibernate."
 msgstr ""
-"Puedes tambi&#x00e9;n expresar consultas en el dialecto SQL nativo de tu "
-"base de datos. Esto es &#x00fa;til si quieres utilizar aspectos espec&#x00ed;"
-"ficos de base de datos tal como consejos (hints) de consulta o la palabra "
-"clave <literal>CONNECT</literal> en Oracle. Provee adem&#x00e1;s una clara "
-"ruta de migraci&#x00f3;n desde una aplicaci&#x00f3;n basada en SQL/JDBC "
-"directo a Hibernate."
+"También puede expresar sus consultas en el dialecto SQL nativo de su base de "
+"datos. Esto es útil si quiere utilizar las características especificas de la "
+"base de datos tales como hints de consulta o la palabra clave "
+"<literal>CONNECT</literal> en Oracle. También proporciona una ruta de "
+"migración limpia desde una aplicación basada en SQL/JDBC a Hibernate."
 
 #. Tag: para
-#: query_sql.xml:37
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 allows you to specify handwritten SQL, including stored "
 "procedures, for all create, update, delete, and load operations."
 msgstr ""
-"Hibernate3 te permite especificar SQL escrito a mano (incluyendo "
-"procedimientos almacenados) para todas las operaciones de creaci&#x00f3;n, "
-"actualizaci&#x00f3;n, borrado y carga."
+"Hibernate3 le permite especificar SQL escrito a mano, incluyendo "
+"procedimientos almacenados para todas las operaciones create, update, delete "
+"y load."
 
 #. Tag: title
-#: query_sql.xml:41
 #, no-c-format
 msgid "Using a <literal>SQLQuery</literal>"
-msgstr "Using a <literal>SQLQuery</literal>"
+msgstr "Uso de una <literal>SQLQuery</literal>"
 
 #. Tag: para
-#: query_sql.xml:43
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Execution of native SQL queries is controlled via the <literal>SQLQuery</"
 "literal> interface, which is obtained by calling <literal>Session."
 "createSQLQuery()</literal>. The following sections describe how to use this "
 "API for querying."
 msgstr ""
-"Execution of native SQL queries is controlled via the <literal>SQLQuery</"
-"literal> interface, which is obtained by calling <literal>Session."
-"createSQLQuery()</literal>. The following describes how to use this API for "
-"querying."
+"La ejecución de consultas SQL nativas se controla por medio de la interfaz "
+"<literal>SQLQuery</literal>, la cual se obtiene llamando a <literal>Session."
+"createSQLQuery()</literal>. Las siguientes secciones describen cómo utilizar "
+"esta API para consultas."
 
 #. Tag: title
-#: query_sql.xml:49
 #, no-c-format
 msgid "Scalar queries"
-msgstr "Scalar queries"
+msgstr "Consultas escalares"
 
 #. Tag: para
-#: query_sql.xml:51
 #, no-c-format
 msgid "The most basic SQL query is to get a list of scalars (values)."
-msgstr "The most basic SQL query is to get a list of scalars (values)."
-
-#. Tag: programlisting
-#: query_sql.xml:54
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").list();\n"
-"sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").list();\n"
-"]]>"
 msgstr ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").list();\n"
-"                                                                         sess."
-"createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").list();\n"
-"                                                                         ]]>"
+"La consulta SQL más básica es para obtener a una lista de escalares "
+"(valores)."
 
 #. Tag: para
-#: query_sql.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These will return a List of Object arrays (Object[]) with scalar values for "
 "each column in the CATS table. Hibernate will use ResultSetMetadata to "
 "deduce the actual order and types of the returned scalar values."
 msgstr ""
-"These will both return a List of Object arrays (Object[]) with scalar values "
-"for each column in the CATS table. Hibernate will use ResultSetMetadata to "
-"deduce the actual order and types of the returned scalar values."
+"Estas retornarán una lista de objetos arrays (Object[]) con valores "
+"escalares para cada columna en la tabla CATS. Hibernate utilizará "
+"ResultSetMetadata para deducir el orden real y los tipos de los valores "
+"escalares retornados."
 
 #. Tag: para
-#: query_sql.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To avoid the overhead of using <literal>ResultSetMetadata</literal>, or "
 "simply to be more explicit in what is returned, one can use "
 "<literal>addScalar()</literal>:"
 msgstr ""
-"To avoid the overhead of using <literal>ResultSetMetadata</literal> or "
-"simply to be more explicit in what is returned one can use <literal>addScalar"
-"()</literal>."
+"Para evitar los gastos generales de la utilización de "
+"<literal>ResultSetMetadata</literal> o simplemente para ser más explícito en "
+"lo que se devuelve se puede utilizar <literal>addScalar()</literal>:"
 
-#. Tag: programlisting
-#: query_sql.xml:65
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-" .addScalar(\"ID\", Hibernate.LONG)\n"
-" .addScalar(\"NAME\", Hibernate.STRING)\n"
-" .addScalar(\"BIRTHDATE\", Hibernate.DATE)\n"
-"]]>"
-msgstr ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-"                                                                         ."
-"addScalar(\"ID\", Hibernate.LONG)\n"
-"                                                                         ."
-"addScalar(\"NAME\", Hibernate.STRING)\n"
-"                                                                         ."
-"addScalar(\"BIRTHDATE\", Hibernate.DATE)\n"
-"                                                                         ]]>"
-
 #. Tag: para
-#: query_sql.xml:67 query_sql.xml:113 query_sql.xml:198 query_sql.xml:349
 #, no-c-format
 msgid "This query specified:"
-msgstr "This query specified:"
+msgstr "Se especifica esta consulta:"
 
 #. Tag: para
-#: query_sql.xml:71 query_sql.xml:117 query_sql.xml:353
 #, no-c-format
 msgid "the SQL query string"
-msgstr "the SQL query string"
+msgstr "la cadena de consulta SQL"
 
 #. Tag: para
-#: query_sql.xml:75
 #, no-c-format
 msgid "the columns and types to return"
-msgstr "the columns and types to return"
+msgstr "las columnas y tipos que se devuelven"
 
 #. Tag: para
-#: query_sql.xml:79
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This will return Object arrays, but now it will not use "
 "<literal>ResultSetMetadata</literal> but will instead explicitly get the ID, "
@@ -158,76 +131,54 @@
 "be returned, even though the query is using <literal>*</literal> and could "
 "return more than the three listed columns."
 msgstr ""
-"This will still return Object arrays, but now it will not use "
-"<literal>ResultSetMetdata</literal> but will instead explicitly get the ID, "
-"NAME and BIRTHDATE column as respectively a Long, String and a Short from "
-"the underlying resultset. This also means that only these three columns will "
-"be returned, even though the query is using <literal>*</literal> and could "
-"return more than the three listed columns."
+"Esto retornará objetos arrays, pero no utilizará <literal>ResultSetMetdata</"
+"literal> sino que obtendrá explícitamente las columnas de IDENTIFICACION, "
+"NOMBRE y FECHA DE NACIMIENTO respectivamente como Larga, Cadena y Corta del "
+"grupo de resultados subyacente. Esto también significa que sólamente estas "
+"tres columnas serán retornadass aunque la consulta este utilizando "
+"<literal>*</literal> y pueda devolver más de las tres columnas enumeradas."
 
 #. Tag: para
-#: query_sql.xml:87
 #, no-c-format
 msgid ""
 "It is possible to leave out the type information for all or some of the "
 "scalars."
 msgstr ""
-"It is possible to leave out the type information for all or some of the "
-"scalars."
+"Es posible dejar afuera la información de tipo para todos o algunos de los "
+"escalares."
 
-#. Tag: programlisting
-#: query_sql.xml:90
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-" .addScalar(\"ID\", Hibernate.LONG)\n"
-" .addScalar(\"NAME\")\n"
-" .addScalar(\"BIRTHDATE\")\n"
-"]]>"
-msgstr ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-"                                                                         ."
-"addScalar(\"ID\", Hibernate.LONG)\n"
-"                                                                         ."
-"addScalar(\"NAME\")\n"
-"                                                                         ."
-"addScalar(\"BIRTHDATE\")\n"
-"                                                                         ]]>"
-
-#. Tag: para
-#: query_sql.xml:92
-#, fuzzy, no-c-format
-msgid ""
 "This is essentially the same query as before, but now "
 "<literal>ResultSetMetaData</literal> is used to determine the type of NAME "
 "and BIRTHDATE, where as the type of ID is explicitly specified."
 msgstr ""
-"This is essentially the same query as before, but now "
-"<literal>ResultSetMetaData</literal> is used to decide the type of NAME and "
-"BIRTHDATE where as the type of ID is explicitly specified."
+"Esto es esencialmente la misma consulta que antes, pero ahora se utiliza "
+"<literal>ResultSetMetaData</literal> para determinar el tipo de NOMBRE y "
+"FECHA DE NACIMIENTO, mientras que el tipo de IDENTIFICACION se especifica "
+"explícitamente."
 
 #. Tag: para
-#: query_sql.xml:96
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "How the java.sql.Types returned from ResultSetMetaData is mapped to "
 "Hibernate types is controlled by the Dialect. If a specific type is not "
 "mapped, or does not result in the expected type, it is possible to customize "
 "it via calls to <literal>registerHibernateType</literal> in the Dialect."
 msgstr ""
-"How the java.sql.Types returned from ResultSetMetaData is mapped to "
-"Hibernate types is controlled by the Dialect. If a specific type is not "
-"mapped or does not result in the expected type it is possible to customize "
-"it via calls to <literal>registerHibernateType</literal> in the Dialect."
+"El dialecto controla la manera en que los java.sql.Types retornados de "
+"ResultSetMetaData se mapean a los tipos de Hibernate. Si un tipo en especial "
+"no se encuentra mapeado o no resulta en el tipo esperado es posible "
+"personalizarlo por medio de llamadas a <literal>registerHibernateType</"
+"literal> en el dialecto."
 
 #. Tag: title
-#: query_sql.xml:104
 #, no-c-format
 msgid "Entity queries"
-msgstr "Entity queries"
+msgstr "Consultas de entidades"
 
 #. Tag: para
-#: query_sql.xml:106
 #, no-c-format
 msgid ""
 "The above queries were all about returning scalar values, basically "
@@ -235,46 +186,28 @@
 "get entity objects from a native sql query via <literal>addEntity()</"
 "literal>."
 msgstr ""
-"The above queries were all about returning scalar values, basically "
-"returning the \"raw\" values from the resultset. The following shows how to "
-"get entity objects from a native sql query via <literal>addEntity()</"
-"literal>."
+"Todas las consultas anteriores eran sobre los valores escalraes devueltos, "
+"basicamente devolviendo los valores \"crudos\" desde el grupo resultado. Lo "
+"siguiente muestra como obtener los objetos entidades desde una consulta sql "
+"nativa por medio de <literal>addEntity()</literal>."
 
-#. Tag: programlisting
-#: query_sql.xml:111
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").addEntity(Cat.class);\n"
-"sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").addEntity(Cat."
-"class);\n"
-"]]>"
-msgstr ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").addEntity(Cat.class);\n"
-"                                                                         sess."
-"createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").addEntity(Cat."
-"class);\n"
-"                                                                         ]]>"
-
 #. Tag: para
-#: query_sql.xml:121
 #, no-c-format
 msgid "the entity returned by the query"
-msgstr "the entity returned by the query"
+msgstr "la entidad devuelta por la consulta"
 
 #. Tag: para
-#: query_sql.xml:125
 #, no-c-format
 msgid ""
 "Assuming that Cat is mapped as a class with the columns ID, NAME and "
 "BIRTHDATE the above queries will both return a List where each element is a "
 "Cat entity."
 msgstr ""
-"Assuming that Cat is mapped as a class with the columns ID, NAME and "
-"BIRTHDATE the above queries will both return a List where each element is a "
-"Cat entity."
+"Asumiendo que Cat es mapeado como una clase con las columnas IDENTIFICACION, "
+"NOMBRE y FECHA DE NACIMIENTO las consultas anteriores devolverán una Lista "
+"en donde cada elemento es una entidad Cat."
 
 #. Tag: para
-#: query_sql.xml:129
 #, no-c-format
 msgid ""
 "If the entity is mapped with a <literal>many-to-one</literal> to another "
@@ -284,39 +217,25 @@
 "but we prefer to be explicit as in the following example for a <literal>many-"
 "to-one</literal> to a <literal>Dog</literal>:"
 msgstr ""
-"If the entity is mapped with a <literal>many-to-one</literal> to another "
-"entity it is required to also return this when performing the native query, "
-"otherwise a database specific \"column not found\" error will occur. The "
-"additional columns will automatically be returned when using the * notation, "
-"but we prefer to be explicit as in the following example for a <literal>many-"
-"to-one</literal> to a <literal>Dog</literal>:"
+"Si la entidad es mapeada con una <literal>many-to-one</literal> a otra "
+"entidad tambien se necesita que devuelva esto cuando realice una consulta "
+"nativa, de otra manera, aparecerá un error \"no se encontró la columna\" "
+"específico a la base de datos. Se devolverán automáticamente las columnas "
+"adicionales cuando se utiliza la anotación *, pero preferimos ser tan "
+"explícitos así como lo muestra el siguiente ejemplo para una <literal>many-"
+"to-one</literal> a un <literal>Dog</literal>:"
 
-#. Tag: programlisting
-#: query_sql.xml:137
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, DOG_ID FROM CATS"
-"\").addEntity(Cat.class);\n"
-"]]>"
-msgstr ""
-"<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, DOG_ID FROM CATS"
-"\").addEntity(Cat.class);\n"
-"                                                                         ]]>"
-
 #. Tag: para
-#: query_sql.xml:139
 #, no-c-format
 msgid "This will allow cat.getDog() to function properly."
-msgstr "This will allow cat.getDog() to function properly."
+msgstr "Esto permitirá que cat.getDog() funcione apropiadamente."
 
 #. Tag: title
-#: query_sql.xml:143
 #, no-c-format
 msgid "Handling associations and collections"
-msgstr "Handling associations and collections"
+msgstr "Manejo de asociaciones y colecciones"
 
 #. Tag: para
-#: query_sql.xml:145
 #, no-c-format
 msgid ""
 "It is possible to eagerly join in the <literal>Dog</literal> to avoid the "
@@ -324,33 +243,14 @@
 "<literal>addJoin()</literal> method, which allows you to join in an "
 "association or collection."
 msgstr ""
-"It is possible to eagerly join in the <literal>Dog</literal> to avoid the "
-"possible extra roundtrip for initializing the proxy. This is done via the "
-"<literal>addJoin()</literal> method, which allows you to join in an "
-"association or collection."
+"Es posible unir de manera temprana en el <literal>Dog</literal> para evitar "
+"el posible viaje de ida y vuelta para iniciar el proxy. Esto se hace por "
+"medio del método <literal>addJoin()</literal>, el cual le permite unirse en "
+"una asociación o colección."
 
-#. Tag: programlisting
-#: query_sql.xml:150
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT c.ID, NAME, BIRTHDATE, DOG_ID, D_ID, "
-"D_NAME FROM CATS c, DOGS d WHERE c.DOG_ID = d.D_ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addJoin(\"cat.dog\");\n"
-"]]>"
-msgstr ""
-"<![CDATA[sess.createSQLQuery(\"SELECT c.ID, NAME, BIRTHDATE, DOG_ID, D_ID, "
-"D_NAME FROM CATS c, DOGS d WHERE c.DOG_ID = d.D_ID\")\n"
-"                                                                         ."
-"addEntity(\"cat\", Cat.class)\n"
-"                                                                         ."
-"addJoin(\"cat.dog\");\n"
-"                                                                         ]]>"
-
-#. Tag: para
-#: query_sql.xml:152
-#, fuzzy, no-c-format
-msgid ""
 "In this example, the returned <literal>Cat</literal>'s will have their "
 "<literal>dog</literal> property fully initialized without any extra "
 "roundtrip to the database. Notice that you added an alias name (\"cat\") to "
@@ -358,97 +258,59 @@
 "do the same eager joining for collections, e.g. if the <literal>Cat</"
 "literal> had a one-to-many to <literal>Dog</literal> instead."
 msgstr ""
-"In this example the returned <literal>Cat</literal>'s will have their "
-"<literal>dog</literal> property fully initialized without any extra "
-"roundtrip to the database. Notice that we added a alias name (\"cat\") to be "
-"able to specify the target property path of the join. It is possible to do "
-"the same eager joining for collections, e.g. if the <literal>Cat</literal> "
-"had a one-to-many to <literal>Dog</literal> instead."
+"En este ejemplo los <literal>Cat</literal>s retornados tendrán su propiedad "
+"<literal>dog</literal> completamente iniciada sin ningún viaje extra de ida "
+"y vuelta a la base de datos. Observe que agregó un nombre alias (\"cat\") "
+"para poder especificar la ruta de la propiedad de destino de la unión. Es "
+"posible hacer la misma unión temprana para colecciones, por ejemplo, si el "
+"<literal>Cat</literal> tuviese en lugar un <literal>Dog</literal> uno-a-"
+"muchos."
 
-#. Tag: programlisting
-#: query_sql.xml:160
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, D_ID, D_NAME, "
-"CAT_ID FROM CATS c, DOGS d WHERE c.ID = d.CAT_ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addJoin(\"cat.dogs\");\n"
-"]]>"
-msgstr ""
-"<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, D_ID, D_NAME, "
-"CAT_ID FROM CATS c, DOGS d WHERE c.ID = d.CAT_ID\")\n"
-"                                                                         ."
-"addEntity(\"cat\", Cat.class)\n"
-"                                                                         ."
-"addJoin(\"cat.dogs\");\n"
-"                                                                         ]]>"
-
-#. Tag: para
-#: query_sql.xml:162
-#, fuzzy, no-c-format
-msgid ""
 "At this stage you are reaching the limits of what is possible with native "
 "queries, without starting to enhance the sql queries to make them usable in "
 "Hibernate. Problems can arise when returning multiple entities of the same "
 "type or when the default alias/column names are not enough."
 msgstr ""
-"At this stage we are reaching the limits of what is possible with native "
-"queries without starting to enhance the sql queries to make them usable in "
-"Hibernate; the problems starts to arise when returning multiple entities of "
-"the same type or when the default alias/column names are not enough."
+"En este punto estamos alcanzando los límites de lo que es posible con las "
+"consultas nativas sin empezar a mejorar las consultas sql para hacerlas "
+"utilizables en Hibernate. Los problemas empiezan a surgir cuando las "
+"entidades múltiples retornadas son del mismo tipo o cuando no son "
+"suficientes los nombres de las columnas/alias predeterminados."
 
 #. Tag: title
-#: query_sql.xml:170
 #, no-c-format
 msgid "Returning multiple entities"
-msgstr "Returning multiple entities"
+msgstr "Devolución de entidades múltiples"
 
 #. Tag: para
-#: query_sql.xml:172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Until now, the result set column names are assumed to be the same as the "
 "column names specified in the mapping document. This can be problematic for "
 "SQL queries that join multiple tables, since the same column names can "
 "appear in more than one table."
 msgstr ""
-"Until now the result set column names are assumed to be the same as the "
-"column names specified in the mapping document. This can be problematic for "
-"SQL queries which join multiple tables, since the same column names may "
-"appear in more than one table."
+"Hasta ahora se ha asumido que los nombres de las columnas del grupo de "
+"resultados son las mismas que los nombres de columnas especificados en el "
+"documento de mapeo. Esto puede llegar a ser problemático para las consultas "
+"SQL que unen múltiples tablas ya que los mismos nombres de columnas pueden "
+"aparecer en más de una tabla."
 
 #. Tag: para
-#: query_sql.xml:177
 #, no-c-format
 msgid ""
 "Column alias injection is needed in the following query (which most likely "
 "will fail):"
 msgstr ""
-"Column alias injection is needed in the following query (which most likely "
-"will fail):"
+"Se necesita una inyección de alias en las columnas en la siguiente consulta "
+"(que con mucha probabilidad fallará):"
 
-#. Tag: programlisting
-#: query_sql.xml:180
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT c.*, m.*  FROM CATS c, CATS m WHERE c."
-"MOTHER_ID = c.ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addEntity(\"mother\", Cat.class)\n"
-"]]>"
-msgstr ""
-"<![CDATA[sess.createSQLQuery(\"SELECT c.*, m.*  FROM CATS c, CATS m WHERE c."
-"MOTHER_ID = c.ID\")\n"
-"                                                                         ."
-"addEntity(\"cat\", Cat.class)\n"
-"                                                                         ."
-"addEntity(\"mother\", Cat.class)\n"
-"                                                                         ]]>"
-
-#. Tag: para
-#: query_sql.xml:184
-#, fuzzy, no-c-format
-msgid ""
 "The query was intended to return two Cat instances per row: a cat and its "
 "mother. The query will, however, fail because there is a conflict of names; "
 "the instances are mapped to the same column names. Also, on some databases "
@@ -456,56 +318,36 @@
 "NAME\", etc. which are not equal to the columns specified in the mappings "
 "(\"ID\" and \"NAME\")."
 msgstr ""
-"The intention for this query is to return two Cat instances per row, a cat "
-"and its mother. This will fail since there is a conflict of names since they "
-"are mapped to the same column names and on some databases the returned "
-"column aliases will most likely be on the form \"c.ID\", \"c.NAME\", etc. "
-"which are not equal to the columns specificed in the mappings (\"ID\" and "
-"\"NAME\")."
+"La intención de esta consulta es retornar dos instancias Cat por fila: un "
+"gato y su mamá. Sin embargo, esto fallará debido a que hay un conflicto de "
+"nombres;las instancias se encuentran mapeadas a los mismos nombres de "
+"columna. También en algunas bases de datos los alias de las columnas "
+"retornadas serán con mucha probabilidad de la forma \"c.IDENTIFICACION\", "
+"\"c.NOMBRE\", etc, los cuales no son iguales a las columnas especificadas en "
+"los mapeos (\"IDENTIFICACION\" y \"NOMBRE\")."
 
 #. Tag: para
-#: query_sql.xml:193
 #, no-c-format
 msgid "The following form is not vulnerable to column name duplication:"
-msgstr "The following form is not vulnerable to column name duplication:"
-
-#. Tag: programlisting
-#: query_sql.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT {cat.*}, {mother.*}  FROM CATS c, CATS "
-"m WHERE c.MOTHER_ID = c.ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addEntity(\"mother\", Cat.class)\n"
-"]]>"
 msgstr ""
-"<![CDATA[sess.createSQLQuery(\"SELECT {cat.*}, {mother.*}  FROM CATS c, CATS "
-"m WHERE c.MOTHER_ID = c.ID\")\n"
-"                                                                         ."
-"addEntity(\"cat\", Cat.class)\n"
-"                                                                         ."
-"addEntity(\"mother\", Cat.class)\n"
-"                                                                         ]]>"
+"La siguiente forma no es vulnerable a la duplicación de nombres de columnas:"
 
 #. Tag: para
-#: query_sql.xml:202
 #, no-c-format
 msgid ""
 "the SQL query string, with placeholders for Hibernate to inject column "
 "aliases"
 msgstr ""
-"the SQL query string, with placeholders for Hibernate to inject column "
-"aliases"
+"la cadena de consultas SQL, con un espacio reservado para que Hibernate "
+"inserte alias de columnas"
 
 #. Tag: para
-#: query_sql.xml:207
 #, no-c-format
 msgid "the entities returned by the query"
-msgstr "the entities returned by the query"
+msgstr "las entidades devueltas por la consulta"
 
 #. Tag: para
-#: query_sql.xml:211
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The {cat.*} and {mother.*} notation used above is a shorthand for \"all "
 "properties\". Alternatively, you can list the columns explicitly, but even "
@@ -515,723 +357,395 @@
 "from a different table (cat_log) to the one declared in the mapping "
 "metadata. You can even use the property aliases in the where clause."
 msgstr ""
-"The {cat.*} and {mother.*} notation used above is a shorthand for \"all "
-"properties\". Alternatively, you may list the columns explicity, but even in "
-"this case we let Hibernate inject the SQL column aliases for each property. "
-"The placeholder for a column alias is just the property name qualified by "
-"the table alias. In the following example, we retrieve Cats and their "
-"mothers from a different table (cat_log) to the one declared in the mapping "
-"metadata. Notice that we may even use the property aliases in the where "
-"clause if we like."
+"La anotación {cat.*} y {mother.*} que se utilizó anteriormente es la "
+"abreviatura para \"todas las propiedades\". Opcionalmente puede enumerar las "
+"columnas explícitamente, pero inclusive en este caso Hibernate inyecta los "
+"alias de columnas SQL para cada propiedad. El espacio para un alias de "
+"columna es sólamente el nombre calificado de la propiedad del alias de la "
+"tabla. En el siguiente ejemplo, recuperamos Cats y sus madres desde una "
+"tabla diferente (cat_log) a la declarada en los meta datos de mapeo. "
+"Inclusive puede utilizar los alias de propiedad en la cláusula where."
 
-#. Tag: programlisting
-#: query_sql.xml:220
-#, no-c-format
-msgid ""
-"<![CDATA[String sql = \"SELECT ID as {c.id}, NAME as {c.name}, \" + \n"
-"         \"BIRTHDATE as {c.birthDate}, MOTHER_ID as {c.mother}, {mother.*} "
-"\" +\n"
-"         \"FROM CAT_LOG c, CAT_LOG m WHERE {c.mother} = c.ID\";\n"
-"\n"
-"List loggedCats = sess.createSQLQuery(sql)\n"
-"        .addEntity(\"cat\", Cat.class)\n"
-"        .addEntity(\"mother\", Cat.class).list()\n"
-"]]>"
-msgstr ""
-"<![CDATA[String sql = \"SELECT ID as {c.id}, NAME as {c.name}, \" + \n"
-"                                                    \"BIRTHDATE as {c."
-"birthDate}, MOTHER_ID as {c.mother}, {mother.*} \" +\n"
-"                                                    \"FROM CAT_LOG c, "
-"CAT_LOG m WHERE {c.mother} = c.ID\";\n"
-"                                                    \n"
-"                                                    List loggedCats = sess."
-"createSQLQuery(sql)\n"
-"                                                    .addEntity(\"cat\", Cat."
-"class)\n"
-"                                                    .addEntity(\"mother\", "
-"Cat.class).list()\n"
-"                                                    ]]>"
-
 #. Tag: title
-#: query_sql.xml:223
 #, no-c-format
 msgid "Alias and property references"
-msgstr "Alias and property references"
+msgstr "Referencias de propiedad y alias"
 
 #. Tag: para
-#: query_sql.xml:225
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In most cases the above alias injection is needed. For queries relating to "
 "more complex mappings, like composite properties, inheritance "
 "discriminators, collections etc., you can use specific aliases that allow "
 "Hibernate to inject the proper aliases."
 msgstr ""
-"For most cases the above alias injection is needed, but for queries relating "
-"to more complex mappings like composite properties, inheritance "
-"discriminators, collections etc. there are some specific aliases to use to "
-"allow Hibernate to inject the proper aliases."
+"Para la mayoría de los casos, se necesita la inyección del alias anterior. "
+"Para las consultas relacionadas con mapeos más complejos como propiedades "
+"compuestas, discriminadores de herencia, colecciones, etc, existen alias "
+"especificos a utilizar para permitir que Hibernate inyecte los alias "
+"apropiados."
 
 #. Tag: para
-#: query_sql.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table shows the different ways you can use the alias "
 "injection. Please note that the alias names in the result are simply "
 "examples; each alias will have a unique and probably different name when "
 "used."
 msgstr ""
-"The following table shows the different possibilities of using the alias "
-"injection. Note: the alias names in the result are examples, each alias will "
-"have a unique and probably different name when used."
+"La siguiente tabla muestra las diferentes maneras de utilizar la inyección "
+"de alias. Note que los nombres alias en el resultado son simplemente "
+"ejemplos; cada alias tendrá un nombre único y probablemente diferente cuando "
+"se utilice."
 
 #. Tag: title
-#: query_sql.xml:236
 #, no-c-format
 msgid "Alias injection names"
-msgstr "Alias injection names"
+msgstr "Nombres con inyección alias"
 
 #. Tag: entry
-#: query_sql.xml:247
 #, no-c-format
 msgid "Description"
-msgstr "Description"
+msgstr "Descripción"
 
 #. Tag: entry
-#: query_sql.xml:249
 #, no-c-format
 msgid "Syntax"
-msgstr "Syntax"
+msgstr "Sintaxis"
 
 #. Tag: entry
-#: query_sql.xml:251
 #, no-c-format
 msgid "Example"
-msgstr "Example"
+msgstr "Ejemplo"
 
 #. Tag: entry
-#: query_sql.xml:257
 #, no-c-format
 msgid "A simple property"
-msgstr "A simple property"
+msgstr "Una propiedad simple"
 
-#. Tag: literal
-#: query_sql.xml:259
-#, no-c-format
-msgid "{[aliasname].[propertyname]"
-msgstr "{[aliasname].[propertyname]"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].[propertyname]</literal>"
+msgstr "<literal>{[aliasname].[propertyname]</literal>"
 
-#. Tag: literal
-#: query_sql.xml:261
-#, no-c-format
-msgid "A_NAME as {item.name}"
-msgstr "A_NAME as {item.name}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>A_NAME as {item.name}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:265
 #, no-c-format
 msgid "A composite property"
-msgstr "A composite property"
+msgstr "Una propiedad compuesta"
 
-#. Tag: literal
-#: query_sql.xml:267
-#, no-c-format
-msgid "{[aliasname].[componentname].[propertyname]}"
-msgstr "{[aliasname].[componentname].[propertyname]}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].[componentname].[propertyname]}</literal>"
+msgstr "<literal>{[aliasname].[componentname].[propertyname]}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:269
-#, no-c-format
-msgid "CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}"
-msgstr "CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}</"
+"literal>"
+msgstr ""
+"<literal>CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}</"
+"literal>"
 
 #. Tag: entry
-#: query_sql.xml:274
 #, no-c-format
 msgid "Discriminator of an entity"
-msgstr "Discriminator of an entity"
+msgstr "Discriminador de una entidad"
 
-#. Tag: literal
-#: query_sql.xml:276
-#, no-c-format
-msgid "{[aliasname].class}"
-msgstr "{[aliasname].class}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].class}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:278
-#, no-c-format
-msgid "DISC as {item.class}"
-msgstr "DISC as {item.class}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>DISC as {item.class}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:282
 #, no-c-format
 msgid "All properties of an entity"
-msgstr "All properties of an entity"
+msgstr "Todas las propiedades de una entidad"
 
-#. Tag: literal
-#: query_sql.xml:284 query_sql.xml:332
-#, no-c-format
-msgid "{[aliasname].*}"
-msgstr "{[aliasname].*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].*}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:286
+#. Tag: entry
 #, no-c-format
-msgid "{item.*}"
-msgstr "{item.*}"
+msgid "<literal>{item.*}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:290
 #, no-c-format
 msgid "A collection key"
-msgstr "A collection key"
+msgstr "Una clave de colección"
 
-#. Tag: literal
-#: query_sql.xml:292
-#, no-c-format
-msgid "{[aliasname].key}"
-msgstr "{[aliasname].key}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].key}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:294
-#, no-c-format
-msgid "ORGID as {coll.key}"
-msgstr "ORGID as {coll.key}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>ORGID as {coll.key}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:298
 #, no-c-format
 msgid "The id of an collection"
-msgstr "The id of an collection"
+msgstr "La identificación -id- de una colección"
 
-#. Tag: literal
-#: query_sql.xml:300
-#, no-c-format
-msgid "{[aliasname].id}"
-msgstr "{[aliasname].id}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].id}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:302
-#, no-c-format
-msgid "EMPID as {coll.id}"
-msgstr "EMPID as {coll.id}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>EMPID as {coll.id}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:306
 #, no-c-format
 msgid "The element of an collection"
-msgstr "The element of an collection"
+msgstr "El elemento de una colección"
 
-#. Tag: literal
-#: query_sql.xml:308
-#, no-c-format
-msgid "{[aliasname].element}"
-msgstr "{[aliasname].element}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:310
-#, no-c-format
-msgid "XID as {coll.element}"
-msgstr "XID as {coll.element}"
-
 #. Tag: entry
-#: query_sql.xml:314
 #, fuzzy, no-c-format
-msgid "property of the element in the collection"
-msgstr "roperty of the element in the collection"
+msgid "<literal>XID as {coll.element}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:316
+#. Tag: entry
 #, no-c-format
-msgid "{[aliasname].element.[propertyname]}"
-msgstr "{[aliasname].element.[propertyname]}"
+msgid "property of the element in the collection"
+msgstr "propiedad del elemento en la colección "
 
-#. Tag: literal
-#: query_sql.xml:318
-#, no-c-format
-msgid "NAME as {coll.element.name}"
-msgstr "NAME as {coll.element.name}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element.[propertyname]}</literal>"
+msgstr "<literal>{[aliasname].element.[propertyname]}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:322
+#, fuzzy, no-c-format
+msgid "<literal>NAME as {coll.element.name}</literal>"
+msgstr "<literal>NAME as {coll.element.name}</literal>"
+
+#. Tag: entry
 #, no-c-format
 msgid "All properties of the element in the collection"
-msgstr "All properties of the element in the collection"
+msgstr "Todas las propiedades del elemeto en la colección"
 
-#. Tag: literal
-#: query_sql.xml:324
-#, no-c-format
-msgid "{[aliasname].element.*}"
-msgstr "{[aliasname].element.*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element.*}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:326
-#, no-c-format
-msgid "{coll.element.*}"
-msgstr "{coll.element.*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{coll.element.*}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:330
 #, no-c-format
 msgid "All properties of the the collection"
-msgstr "All properties of the the collection"
+msgstr "Todas las propiedades de la colección"
 
-#. Tag: literal
-#: query_sql.xml:334
+#. Tag: entry
 #, no-c-format
-msgid "{coll.*}"
-msgstr "{coll.*}"
+msgid "<literal>{coll.*}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: title
-#: query_sql.xml:343
 #, no-c-format
 msgid "Returning non-managed entities"
-msgstr "Returning non-managed entities"
+msgstr "Devolución de entidades no-administradas"
 
 #. Tag: para
-#: query_sql.xml:345
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to apply a ResultTransformer to native SQL queries, allowing "
 "it to return non-managed entities."
 msgstr ""
-"It is possible to apply a ResultTransformer to native sql queries. Allowing "
-"it to e.g. return non-managed entities."
+"Es posible aplicar un ResultTransformer para consultas SQL nativas, "
+"permitiéndole retornar entidades no-administradas."
 
-#. Tag: programlisting
-#: query_sql.xml:347
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT NAME, BIRTHDATE FROM CATS\")\n"
-"        .setResultTransformer(Transformers.aliasToBean(CatDTO.class))]]>"
-msgstr ""
-"<![CDATA[sess.createSQLQuery(\"SELECT NAME, BIRTHDATE FROM CATS\")\n"
-"                                                                         ."
-"setResultTransformer(Transformers.aliasToBean(CatDTO.class))]]>"
-
 #. Tag: para
-#: query_sql.xml:357
 #, no-c-format
 msgid "a result transformer"
-msgstr "a result transformer"
+msgstr "un transformador de resultado"
 
 #. Tag: para
-#: query_sql.xml:361
 #, no-c-format
 msgid ""
 "The above query will return a list of <literal>CatDTO</literal> which has "
 "been instantiated and injected the values of NAME and BIRTHNAME into its "
 "corresponding properties or fields."
 msgstr ""
-"The above query will return a list of <literal>CatDTO</literal> which has "
-"been instantiated and injected the values of NAME and BIRTHNAME into its "
-"corresponding properties or fields."
+"La consulta anterior devolverá una lista de <literal>CatDTO</literal> a la "
+"cual se ha instanciado e inyectado los valores de NOMBRE y FECHA DE "
+"NACIMIENTO en su propiedades o campos correspondientes."
 
 #. Tag: title
-#: query_sql.xml:368
 #, no-c-format
 msgid "Handling inheritance"
-msgstr "Handling inheritance"
+msgstr "Manejo de herencias"
 
 #. Tag: para
-#: query_sql.xml:370
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Native SQL queries which query for entities that are mapped as part of an "
 "inheritance must include all properties for the baseclass and all its "
 "subclasses."
 msgstr ""
-"Native sql queries which query for entities that is mapped as part of an "
-"inheritance must include all properties for the baseclass and all it "
-"subclasses."
+"Las consultas SQL nativas, las cuales consultan por entidades que son "
+"mapeadas como parte de una herencia tienen que incluir todas las propiedades "
+"para la clase base y todas sus subclases."
 
 #. Tag: title
-#: query_sql.xml:376
 #, no-c-format
 msgid "Parameters"
-msgstr "Parameters"
+msgstr "Parámetros"
 
 #. Tag: para
-#: query_sql.xml:378
-#, fuzzy, no-c-format
-msgid "Native SQL queries support positional as well as named parameters:"
-msgstr "Native sql queries support positional as well as named parameters:"
-
-#. Tag: programlisting
-#: query_sql.xml:381
 #, no-c-format
-msgid ""
-"<![CDATA[Query query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME "
-"like ?\").addEntity(Cat.class);\n"
-"List pusList = query.setString(0, \"Pus%\").list();\n"
-"     \n"
-"query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME like :name\")."
-"addEntity(Cat.class);\n"
-"List pusList = query.setString(\"name\", \"Pus%\").list();          ]]>"
+msgid "Native SQL queries support positional as well as named parameters:"
 msgstr ""
-"<![CDATA[Query query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME "
-"like ?\").addEntity(Cat.class);\n"
-"                                                   List pusList = query."
-"setString(0, \"Pus%\").list();\n"
-"                                                   \n"
-"                                                   query = sess."
-"createSQLQuery(\"SELECT * FROM CATS WHERE NAME like :name\").addEntity(Cat."
-"class);\n"
-"                                                   List pusList = query."
-"setString(\"name\", \"Pus%\").list();          ]]>"
+"Las consultas SQL nativas soportan parámetros nombrados así como "
+"posicionales:"
 
 #. Tag: title
-#: query_sql.xml:389
 #, no-c-format
 msgid "Named SQL queries"
-msgstr "Consultas SQL con nombre"
+msgstr "Consultas SQL nombradas"
 
 #. Tag: para
-#: query_sql.xml:391
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Named SQL queries can be defined in the mapping document and called in "
 "exactly the same way as a named HQL query. In this case, you do "
 "<emphasis>not</emphasis> need to call <literal>addEntity()</literal>."
 msgstr ""
-"Las consultas SQL con nombre pueden definirse en el documento de mapeo y "
-"llamadas exactamente en la misma forma en que a una consulta HQL con nombre. "
-"En este caso, <emphasis>no</emphasis> necesitamos llamar a <literal>addEntity"
-"()</literal>."
+"Las consultas SQL nombradas se pueden definir en el documento de mapeo y se "
+"pueden llamar de la misma manera que una consulta HQL nombrada. En este "
+"caso, <emphasis>no</emphasis> necesitamos llamar a <literal>addEntity()</"
+"literal>."
 
-#. Tag: programlisting
-#: query_sql.xml:396
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"persons\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex}\n"
-"    FROM PERSON person\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-"<![CDATA[<sql-query name=\"persons\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex}\n"
-"    FROM PERSON person \n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-
-#. Tag: programlisting
-#: query_sql.xml:398
-#, no-c-format
-msgid ""
-"<![CDATA[List people = sess.getNamedQuery(\"persons\")\n"
-"    .setString(\"namePattern\", namePattern)\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List people = sess.getNamedQuery(\"persons\")\n"
-"    .setString(\"namePattern\", namePattern)\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-
-#. Tag: para
-#: query_sql.xml:400
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>&lt;return-join&gt;</literal> element is use to join "
 "associations and the <literal>&lt;load-collection&gt;</literal> element is "
 "used to define queries which initialize collections,"
 msgstr ""
-"Los elementos <literal>&lt;return-join&gt;</literal> y <literal>&lt;load-"
-"collection&gt;</literal> se usan para unir asociaciones y definir consultas "
-"que inicialicen colecciones, respectivamente."
+"El elemento <literal>&lt;return-join&gt;</literal> se utiliza para unir "
+"asociaciones y el elemento <literal>&lt;load-collection&gt;</literal> se usa "
+"para definir consultas, las cuales dan inicio a colecciones."
 
-#. Tag: programlisting
-#: query_sql.xml:404
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"personsWith\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex},\n"
-"           address.STREET AS {address.street},\n"
-"           address.CITY AS {address.city},\n"
-"           address.STATE AS {address.state},\n"
-"           address.ZIP AS {address.zip}\n"
-"    FROM PERSON person\n"
-"    JOIN ADDRESS address\n"
-"        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-"<![CDATA[<sql-query name=\"personsWith\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex},\n"
-"           address.STREET AS {address.street},\n"
-"           address.CITY AS {address.city},\n"
-"           address.STATE AS {address.state},\n"
-"           address.ZIP AS {address.zip}\n"
-"    FROM PERSON person \n"
-"    JOIN ADDRESS address\n"
-"            ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-
 #. Tag: para
-#: query_sql.xml:406
 #, no-c-format
 msgid ""
 "A named SQL query may return a scalar value. You must declare the column "
 "alias and Hibernate type using the <literal>&lt;return-scalar&gt;</literal> "
 "element:"
 msgstr ""
-"Una consulta SQL con nombre puede devolver un valor escalar. Debes "
-"especificar el alias de columna y tipo Hibernate usando el elementp "
-"<literal>&lt;return-scalar&gt;</literal>:"
+"Una consulta SQL nombrada puede devolver un valor escalar. Tiene que "
+"declarar el alias de la columna y el tipo de Hibernate utilizando el "
+"elemento <literal>&lt;return-scalar&gt;</literal>:"
 
-#. Tag: programlisting
-#: query_sql.xml:410
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-"    <return-scalar column=\"name\" type=\"string\"/>\n"
-"    <return-scalar column=\"age\" type=\"long\"/>\n"
-"    SELECT p.NAME AS name,\n"
-"           p.AGE AS age,\n"
-"    FROM PERSON p WHERE p.NAME LIKE 'Hiber%'\n"
-"</sql-query>]]>"
-msgstr ""
-"<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-"    <return-scalar column=\"name\" type=\"string\"/>\n"
-"    <return-scalar column=\"age\" type=\"long\"/>\n"
-"    SELECT p.NAME AS name,\n"
-"           p.AGE AS age,\n"
-"    FROM PERSON p WHERE p.NAME LIKE 'Hiber%'\n"
-"</sql-query>]]>"
-
-#. Tag: para
-#: query_sql.xml:412
-#, fuzzy, no-c-format
-msgid ""
 "You can externalize the resultset mapping information in a <literal>&lt;"
 "resultset&gt;</literal> element which will allow you to either reuse them "
 "across several named queries or through the <literal>setResultSetMapping()</"
 "literal> API."
 msgstr ""
-"You can externalize the resultset mapping informations in a <literal>&lt;"
-"resultset&gt;</literal> element to either reuse them accross several named "
-"queries or through the <literal>setResultSetMapping()</literal> API."
+"Puede externalizar el grupo de resultados mapeando información en un "
+"elemento <literal>&lt;resultset&gt;</literal>, el cual le permitirá "
+"reutilizarlos a través de consultas nombradas o por medio de la API "
+"<literal>setResultSetMapping()</literal>."
 
-#. Tag: programlisting
-#: query_sql.xml:417
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<resultset name=\"personAddress\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
-"</resultset>\n"
-"\n"
-"<sql-query name=\"personsWith\" resultset-ref=\"personAddress\">\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex},\n"
-"           address.STREET AS {address.street},\n"
-"           address.CITY AS {address.city},\n"
-"           address.STATE AS {address.state},\n"
-"           address.ZIP AS {address.zip}\n"
-"    FROM PERSON person\n"
-"    JOIN ADDRESS address\n"
-"        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-"<![CDATA[<resultset name=\"personAddress\">\n"
-"                <return alias=\"person\" class=\"eg.Person\"/>\n"
-"                <return-join alias=\"address\" property=\"person."
-"mailingAddress\"/>\n"
-"        </resultset>\n"
-"        \n"
-"        <sql-query name=\"personsWith\" resultset-ref=\"personAddress\">\n"
-"                SELECT person.NAME AS {person.name},\n"
-"                person.AGE AS {person.age},\n"
-"                person.SEX AS {person.sex},\n"
-"                address.STREET AS {address.street},\n"
-"                address.CITY AS {address.city},\n"
-"                address.STATE AS {address.state},\n"
-"                address.ZIP AS {address.zip}\n"
-"                FROM PERSON person\n"
-"                JOIN ADDRESS address\n"
-"                ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-"                WHERE person.NAME LIKE :namePattern\n"
-"        </sql-query>]]>"
-
-#. Tag: para
-#: query_sql.xml:419
-#, fuzzy, no-c-format
-msgid ""
 "You can, alternatively, use the resultset mapping information in your hbm "
 "files directly in java code."
 msgstr ""
-"You can alternatively use the resultset mapping information in your hbm "
-"files directly in java code."
+"Opcionalmente, puede utilizar el grupo de resultados mapeando la información "
+"en sus archivos hbm directamente en código java."
 
-#. Tag: programlisting
-#: query_sql.xml:422
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createSQLQuery(\n"
-"        \"select {cat.*}, {kitten.*} from cats cat, cats kitten where kitten."
-"mother = cat.id\"\n"
-"    )\n"
-"    .setResultSetMapping(\"catAndKitten\")\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[List cats = sess.createSQLQuery(\n"
-"                              \"select {cat.*}, {kitten.*} from cats cat, "
-"cats kitten where kitten.mother = cat.id\"\n"
-"                              )\n"
-"                              .setResultSetMapping(\"catAndKitten\")\n"
-"    .list();]]>"
-
 #. Tag: title
-#: query_sql.xml:425
 #, no-c-format
 msgid "Using return-property to explicitly specify column/alias names"
 msgstr ""
-"Usando return-property para especificar expl&#x00ed;citamente nombres de "
-"columna/alias"
+"Utilización de la propiedad return para especificar explícitamente los "
+"nombres de columnas/alias"
 
 #. Tag: para
-#: query_sql.xml:428
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can explicitly tell Hibernate what column aliases to use with "
 "<literal>&lt;return-property&gt;</literal>, instead of using the <literal>{}"
 "</literal>-syntax to let Hibernate inject its own aliases.For example:"
 msgstr ""
-"Con <literal>&lt;return-property&gt;</literal> puedes decirle expl&#x00ed;"
-"citamente a Hibernate qu&#x00e9; alias de columna usar, en vez de usar la "
-"sint&#x00e1;xis <literal>{}</literal> para dejar que Hibernate inyecte sus "
-"propios alias."
+"Con <literal>&lt;return-property&gt;</literal> usted puede decirle a "
+"Hibernate explícitamente qué alias de columnas se deben utilizar, en vez de "
+"utilizar la sintaxis <literal>{}</literal> para dejar que Hibernate inyecte "
+"sus propios alias. Por ejemplo:"
 
-#. Tag: programlisting
-#: query_sql.xml:433
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-"    <return alias=\"person\" class=\"eg.Person\">\n"
-"        <return-property name=\"name\" column=\"myName\"/>\n"
-"        <return-property name=\"age\" column=\"myAge\"/>\n"
-"        <return-property name=\"sex\" column=\"mySex\"/>\n"
-"    </return>\n"
-"    SELECT person.NAME AS myName,\n"
-"           person.AGE AS myAge,\n"
-"           person.SEX AS mySex,\n"
-"    FROM PERSON person WHERE person.NAME LIKE :name\n"
-"</sql-query>\n"
-"]]>"
-msgstr ""
-"<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-"    <return alias=\"person\" class=\"eg.Person\">\n"
-"        <return-property name=\"name\" column=\"myName\"/>\n"
-"        <return-property name=\"age\" column=\"myAge\"/>\n"
-"        <return-property name=\"sex\" column=\"mySex\"/>\n"
-"    </return>\n"
-"    SELECT person.NAME AS myName,\n"
-"           person.AGE AS myAge,\n"
-"           person.SEX AS mySex,\n"
-"    FROM PERSON person WHERE person.NAME LIKE :name\n"
-"</sql-query>\n"
-"]]>"
-
-#. Tag: para
-#: query_sql.xml:435
-#, fuzzy, no-c-format
-msgid ""
 "<literal>&lt;return-property&gt;</literal> also works with multiple columns. "
 "This solves a limitation with the <literal>{}</literal>-syntax which cannot "
 "allow fine grained control of multi-column properties."
 msgstr ""
-"<literal>&lt;return-property&gt;</literal> tambi&#x00e9;n trabaja con "
-"m&#x00fa;ltiples columnas. Esto resuelve una limitaci&#x00f3;n de la "
-"sint&#x00e1;xis <literal>{}</literal>, la cual no puede permitir un control "
-"fino de propiedades multi-columna."
+"<literal>&lt;return-property&gt;</literal> también funciona con columnas "
+"múltiples. Esto resuelve una limitación con la sintaxis <literal>{}</"
+"literal>, la cual no puede permitir control muy detallado de propiedades "
+"multi-columnas."
 
-#. Tag: programlisting
-#: query_sql.xml:440
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"organizationCurrentEmployments\">\n"
-"    <return alias=\"emp\" class=\"Employment\">\n"
-"        <return-property name=\"salary\">\n"
-"            <return-column name=\"VALUE\"/>\n"
-"            <return-column name=\"CURRENCY\"/>\n"
-"        </return-property>\n"
-"        <return-property name=\"endDate\" column=\"myEndDate\"/>\n"
-"    </return>\n"
-"        SELECT EMPLOYEE AS {emp.employee}, EMPLOYER AS {emp.employer},\n"
-"        STARTDATE AS {emp.startDate}, ENDDATE AS {emp.endDate},\n"
-"        REGIONCODE as {emp.regionCode}, EID AS {emp.id}, VALUE, CURRENCY\n"
-"        FROM EMPLOYMENT\n"
-"        WHERE EMPLOYER = :id AND ENDDATE IS NULL\n"
-"        ORDER BY STARTDATE ASC\n"
-"</sql-query>]]>"
-msgstr ""
-"<![CDATA[<sql-query name=\"organizationCurrentEmployments\">\n"
-"    <return alias=\"emp\" class=\"Employment\">            \n"
-"        <return-property name=\"salary\"> \n"
-"            <return-column name=\"VALUE\"/>\n"
-"            <return-column name=\"CURRENCY\"/>            \n"
-"        </return-property>\n"
-"        <return-property name=\"endDate\" column=\"myEndDate\"/>\n"
-"    </return>\n"
-"        SELECT EMPLOYEE AS {emp.employee}, EMPLOYER AS {emp.employer}, \n"
-"        STARTDATE AS {emp.startDate}, ENDDATE AS {emp.endDate},\n"
-"        REGIONCODE as {emp.regionCode}, EID AS {emp.id}, VALUE, CURRENCY\n"
-"        FROM EMPLOYMENT\n"
-"        WHERE EMPLOYER = :id AND ENDDATE IS NULL\n"
-"        ORDER BY STARTDATE ASC\n"
-"</sql-query>]]>"
-
-#. Tag: para
-#: query_sql.xml:442
-#, fuzzy, no-c-format
-msgid ""
 "In this example <literal>&lt;return-property&gt;</literal> was used in "
 "combination with the <literal>{}</literal>-syntax for injection. This allows "
 "users to choose how they want to refer column and properties."
 msgstr ""
-"Nota que en este ejemplo hemos usado <literal>&lt;return-property&gt;</"
-"literal> en combinaci&#x00f3;n con la sint&#x00e1;xis <literal>{}</literal> "
-"para inyecci&#x00f3;n, permitiendo a los usuarios elejir c&#x00f3;mo quieren "
-"referirse a las columnas y propiedades."
+"En este ejemplo utilizamos <literal>&lt;return-property&gt;</literal> en "
+"combinación junto con la sintaxis <literal>{}</literal> para inyección. Esto "
+"le permite a los usuarios escoger cómo quieren referirse a la columna y a "
+"las propiedades."
 
 #. Tag: para
-#: query_sql.xml:447
 #, no-c-format
 msgid ""
 "If your mapping has a discriminator you must use <literal>&lt;return-"
 "discriminator&gt;</literal> to specify the discriminator column."
 msgstr ""
-"Si tu mapeo tiene un discriminador debes usar <literal>&lt;return-"
-"discriminator&gt;</literal> para especificar la columna discriminadora."
+"Si su mapeo tiene un discriminador usted tiene que utilizar <literal>&lt;"
+"return-discriminator&gt;</literal> para especificar la columna "
+"discriminadora."
 
 #. Tag: title
-#: query_sql.xml:453
 #, no-c-format
 msgid "Using stored procedures for querying"
-msgstr "Usando procedimientos almacenados para consultar"
+msgstr "Utilización de procedimientos para consultas"
 
 #. Tag: para
-#: query_sql.xml:455
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 provides support for queries via stored procedures and functions. "
 "Most of the following documentation is equivalent for both. The stored "
@@ -1239,110 +753,38 @@
 "able to work with Hibernate. An example of such a stored function in Oracle "
 "9 and higher is as follows:"
 msgstr ""
-"Hibernate3 introduce soporte para consultas v&#x00ed;a procedimientos "
-"almacenados. Los procedimientos almacenados deben devolver un conjunto "
-"resultado como el primer par&#x00e1;metro de salida para ser capaces de "
-"funcionar con Hibernate. Un ejemplo de uno procedimiento almacenado en "
-"Oracle 9 o superior es as&#x00ed;:"
+"Hibernate 3 brinda soporte para consultas por medio de procedimientos "
+"almacenados y funciones. La mayoría de la siguiente documentación es igual "
+"para ambos. La función/procedimiento almacenado tiene que retornar un grupo "
+"de resultados como el primer parámetro de salida para poder trabajar con "
+"Hibernate. A continuación hay un ejemplo de tal función almacenada en Oracle "
+"9 y posteriores:"
 
-#. Tag: programlisting
-#: query_sql.xml:461
-#, no-c-format
-msgid ""
-"<![CDATA[CREATE OR REPLACE FUNCTION selectAllEmployments\n"
-"    RETURN SYS_REFCURSOR\n"
-"AS\n"
-"    st_cursor SYS_REFCURSOR;\n"
-"BEGIN\n"
-"    OPEN st_cursor FOR\n"
-" SELECT EMPLOYEE, EMPLOYER,\n"
-" STARTDATE, ENDDATE,\n"
-" REGIONCODE, EID, VALUE, CURRENCY\n"
-" FROM EMPLOYMENT;\n"
-"      RETURN  st_cursor;\n"
-" END;]]>"
-msgstr ""
-"<![CDATA[CREATE OR REPLACE FUNCTION selectAllEmployments \n"
-"    RETURN SYS_REFCURSOR \n"
-"AS \n"
-"    st_cursor SYS_REFCURSOR; \n"
-"BEGIN \n"
-"    OPEN st_cursor FOR \n"
-" SELECT EMPLOYEE, EMPLOYER, \n"
-" STARTDATE, ENDDATE, \n"
-" REGIONCODE, EID, VALUE, CURRENCY \n"
-" FROM EMPLOYMENT; \n"
-"      RETURN  st_cursor; \n"
-" END;]]>"
-
 #. Tag: para
-#: query_sql.xml:463
 #, no-c-format
 msgid "To use this query in Hibernate you need to map it via a named query."
 msgstr ""
-"Para usar esta consulta en Hibernate necesitas mapearla por medio de una "
-"consulta con nombre."
+"Para utilizar esta consulta en Hibernate u.d necesita mapearla por medio de "
+"una consulta nombrada."
 
-#. Tag: programlisting
-#: query_sql.xml:466
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"selectAllEmployees_SP\" callable=\"true\">\n"
-"    <return alias=\"emp\" class=\"Employment\">\n"
-"        <return-property name=\"employee\" column=\"EMPLOYEE\"/>\n"
-"        <return-property name=\"employer\" column=\"EMPLOYER\"/>\n"
-"        <return-property name=\"startDate\" column=\"STARTDATE\"/>\n"
-"        <return-property name=\"endDate\" column=\"ENDDATE\"/>\n"
-"        <return-property name=\"regionCode\" column=\"REGIONCODE\"/>\n"
-"        <return-property name=\"id\" column=\"EID\"/>\n"
-"        <return-property name=\"salary\">\n"
-"            <return-column name=\"VALUE\"/>\n"
-"            <return-column name=\"CURRENCY\"/>\n"
-"        </return-property>\n"
-"    </return>\n"
-"    { ? = call selectAllEmployments() }\n"
-"</sql-query>]]>"
-msgstr ""
-"<![CDATA[<sql-query name=\"selectAllEmployees_SP\" callable=\"true\">\n"
-"    <return alias=\"emp\" class=\"Employment\">\n"
-"        <return-property name=\"employee\" column=\"EMPLOYEE\"/>\n"
-"        <return-property name=\"employer\" column=\"EMPLOYER\"/"
-">            \n"
-"        <return-property name=\"startDate\" column=\"STARTDATE\"/>\n"
-"        <return-property name=\"endDate\" column=\"ENDDATE\"/>            \n"
-"        <return-property name=\"regionCode\" column=\"REGIONCODE\"/"
-">            \n"
-"        <return-property name=\"id\" column=\"EID\"/"
-">                        \n"
-"        <return-property name=\"salary\"> \n"
-"            <return-column name=\"VALUE\"/>\n"
-"            <return-column name=\"CURRENCY\"/>            \n"
-"        </return-property>\n"
-"    </return>\n"
-"    { ? = call selectAllEmployments() }\n"
-"</sql-query>]]>"
-
-#. Tag: para
-#: query_sql.xml:468
-#, fuzzy, no-c-format
-msgid ""
 "Stored procedures currently only return scalars and entities. <literal>&lt;"
 "return-join&gt;</literal> and <literal>&lt;load-collection&gt;</literal> are "
 "not supported."
 msgstr ""
-"Nota que los procedimientos almacenados s&#x00f3;lo devuelven escalares y "
-"entidades. No est&#x00e1;n soportados <literal>&lt;return-join&gt;</literal> "
-"y <literal>&lt;load-collection&gt;</literal>."
+"Los procedimientos almacenados actualmente sólo retornan escalares y "
+"entidades. No se soporta <literal>&lt;return-join&gt;</literal> ni "
+"<literal>&lt;load-collection&gt;</literal> ."
 
 #. Tag: title
-#: query_sql.xml:473
 #, no-c-format
 msgid "Rules/limitations for using stored procedures"
-msgstr "Reglas/limitaciones para usar procedimientos almacenados"
+msgstr "Reglas/limitaciones para utilizar procedimientos almacenados"
 
 #. Tag: para
-#: query_sql.xml:475
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You cannot use stored procedures with Hibernate unless you follow some "
 "procedure/function rules. If they do not follow those rules they are not "
@@ -1351,45 +793,42 @@
 "different for each database, since database vendors have different stored "
 "procedure semantics/syntax."
 msgstr ""
-"Para usar procedimientos almacenados con Hibernate los procedimientos tienen "
-"que seguir algunas reglas. Si no siguen esas reglas no son usables por "
-"Hibernate. Si a&#x00fa;n quisieras usar estos procedimientos tendr&#x00ed;as "
-"que ejecutarlos por medio de <literal>session.connection()</literal>. Las "
-"reglas son diferentes para cada base de datos, ya que los vendedores de base "
-"de datos tienen diferentes sem&#x00e1;nticas/sint&#x00e1;xis de "
+"Para utilizar procedimientos almacenados con Hibernate, debe seguir ciertas "
+"reglas de funciones/procedimientos. Si no siguen esas reglas entonces no se "
+"pueden utilizar con Hibernate. Si todavía quiere utilizar estos "
+"procedimientos tiene que ejecutarlos por medio de <literal>session.connection"
+"()</literal>. Las reglas son diferentes para cada base de datos debido a que "
+"los vendedores de la base de datos tienen diferentes sintaxis/semántica de "
 "procedimientos almacenados."
 
 #. Tag: para
-#: query_sql.xml:482
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Stored procedure queries cannot be paged with <literal>setFirstResult()/"
 "setMaxResults()</literal>."
 msgstr ""
-"Las consultas de procedimientos almacenados no pueden ser paginadas con "
+"Las consultas de procedimientos almacenados no se pueden llamar con "
 "<literal>setFirstResult()/setMaxResults()</literal>."
 
 #. Tag: para
-#: query_sql.xml:485
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The recommended call form is standard SQL92: <literal>{ ? = call functionName"
 "(&lt;parameters&gt;) }</literal> or <literal>{ ? = call procedureName(&lt;"
 "parameters&gt;}</literal>. Native call syntax is not supported."
-msgstr "Para Oracle se aplican las siguientes reglas:"
+msgstr ""
+"La forma de la llamada recomendada es SQL92 estándar: <literal>{ ? = call "
+"functionName(&lt;parameters&gt;) }</literal> o <literal>{ ? = call "
+"procedureName(&lt;parameters&gt;}</literal>. No se soporta la sintaxis de "
+"llamadas nativas."
 
 #. Tag: para
-#: query_sql.xml:490
 #, no-c-format
 msgid "For Oracle the following rules apply:"
-msgstr ""
-"El procedimiento debe devolver un conjunto resultado. Esto se hace "
-"devolviendo un <literal>SYS_REFCURSOR</literal> en Oracle 9 o 10. En Oracle "
-"necesitas definir un tipo <literal>REF CURSOR</literal>."
+msgstr "Para Oracle aplican las siguientes reglas:"
 
 #. Tag: para
-#: query_sql.xml:494
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A function must return a result set. The first parameter of a procedure must "
 "be an <literal>OUT</literal> that returns a result set. This is done by "
@@ -1397,154 +836,102 @@
 "you need to define a <literal>REF CURSOR</literal> type. See Oracle "
 "literature for further information."
 msgstr ""
-"La forma recomendada es <literal>{ ? = call procName(&lt;parameters&gt;) }</"
-"literal> o <literal>{ ? = call procName }</literal> (esto es m&#x00e1;s una "
-"regla de Oracle que una regla de Hibernate)."
+"Una función tiene que retornar un grupo de resultados. El primer parámetro "
+"de un procedimiento tiene que ser un <literal>OUT</literal> que retorna un "
+"grupo de resultados. Esto se hace utilizando un tipo <literal>SYS_REFCURSOR</"
+"literal>  en Oracle 9 o 10. En Oracle necesita definir un tipo <literal>REF "
+"CURSOR</literal>. Consulte la documentación de Oracle para obtener mayor "
+"información."
 
 #. Tag: para
-#: query_sql.xml:503
 #, no-c-format
 msgid "For Sybase or MS SQL server the following rules apply:"
-msgstr "Para Sybase o MS SQL server se aplican las siguientes reglas:"
+msgstr "Para Sybase o el servidor MS SQL aplican las siguientes reglas:"
 
 #. Tag: para
-#: query_sql.xml:507
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The procedure must return a result set. Note that since these servers can "
 "return multiple result sets and update counts, Hibernate will iterate the "
 "results and take the first result that is a result set as its return value. "
 "Everything else will be discarded."
 msgstr ""
-"El procedimiento debe devolver un conjunto resultado. Nota que ya que estos "
-"servidores pueden y devolver&#x00e1;n m&#x00fa;ltiples conjuntos resultados "
-"y cuentas de actualizaci&#x00f3;n, Hibernate iterar&#x00e1; los resultados y "
-"tomar&#x00e1; el primer resultado que sea un conjunto resultado como su "
-"valor a devolver. Todo lo dem&#x00e1;s ser&#x00e1; descartado."
+"El procedimiento tiene que retornar un grupo de resultados. Observe que "
+"debido a que estos servidores pueden retornar grupos de resultados múltiples "
+"y cuentas actualizadas, Hibernate iterará los resultados y tomará el primer "
+"resultado que sea un grupo resultados como su valor retornado. Todo lo demás "
+"será descartado."
 
 #. Tag: para
-#: query_sql.xml:515
 #, no-c-format
 msgid ""
 "If you can enable <literal>SET NOCOUNT ON</literal> in your procedure it "
 "will probably be more efficient, but this is not a requirement."
 msgstr ""
-"Si habilitas <literal>SET NOCOUNT ON</literal> en tu procedimiento "
-"ser&#x00e1; probablemente m&#x00e1;s eficiente, pero esto no es un "
-"requerimiento."
+"Si puede habilitar <literal>SET NOCOUNT ON</literal> en su procedimiento "
+"probablemente será más eficiente, pero no es un requerimiento."
 
 #. Tag: title
-#: query_sql.xml:525
 #, no-c-format
 msgid "Custom SQL for create, update and delete"
-msgstr "SQL personalizado para crear, actualizar y borrar"
+msgstr "Personalice SQL para crear, actualizar y borrar"
 
 #. Tag: para
-#: query_sql.xml:527
 #, no-c-format
 msgid ""
-"Hibernate3 can use custom SQL statements for create, update, and delete "
-"operations. The class and collection persisters in Hibernate already contain "
-"a set of configuration time generated strings (insertsql, deletesql, "
-"updatesql etc.). The mapping tags <literal>&lt;sql-insert&gt;</literal>, "
-"<literal>&lt;sql-delete&gt;</literal>, and <literal>&lt;sql-update&gt;</"
-"literal> override these strings:"
+"Hibernate3 can use custom SQL for create, update, and delete operations. The "
+"SQL can be overridden at the statement level or inidividual column level. "
+"This section describes statement overrides. For columns, see <xref linkend="
+"\"mapping-column-read-and-write\" />."
 msgstr ""
-"Hibernate3 puede usar sentencias SQL personalizadas para las operaciones de "
-"crear, actualizar y borrar. Los persistidores de clases y colecciones en "
-"Hibernate ya contienen un conjunto de cadenas generadas en tiempo de "
-"configuraci&#x00f3;n (insertsql, deletesql, updatesql, etc.). Las etiquetas "
-"de mapeo <literal>&lt;sql-insert&gt;</literal>, <literal>&lt;sql-delete&gt;</"
-"literal>, y <literal>&lt;sql-update&gt;</literal> sobrescriben estas cadenas:"
 
-#. Tag: programlisting
-#: query_sql.xml:535
-#, no-c-format
+#. Tag: para
+#, fuzzy, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <sql-insert>INSERT INTO PERSON (NAME, ID) VALUES ( UPPER(?), ? )</sql-"
-"insert>\n"
-"    <sql-update>UPDATE PERSON SET NAME=UPPER(?) WHERE ID=?</sql-update>\n"
-"    <sql-delete>DELETE FROM PERSON WHERE ID=?</sql-delete>\n"
-"</class>]]>"
+"The class and collection persisters in Hibernate already contain a set of "
+"configuration time generated strings (insertsql, deletesql, updatesql etc.). "
+"The mapping tags <literal>&lt;sql-insert&gt;</literal>, <literal>&lt;sql-"
+"delete&gt;</literal>, and <literal>&lt;sql-update&gt;</literal> override "
+"these strings:"
 msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <sql-insert>INSERT INTO PERSON (NAME, ID) VALUES ( UPPER(?), ? )</sql-"
-"insert>\n"
-"    <sql-update>UPDATE PERSON SET NAME=UPPER(?) WHERE ID=?</sql-update>\n"
-"    <sql-delete>DELETE FROM PERSON WHERE ID=?</sql-delete>\n"
-"</class>]]>"
+"Hibernate3 puede utilizar declaraciones SQL personalizadas para crear, "
+"actualizar y borrar operaciones. Los persistentes de clase y de colección en "
+"Hibernate ya contienen un grupo de cadenas generadas en tiempo de "
+"configuración (insertsql, deletesql, updatesql etc.). Las etiquetas de mapeo "
+"<literal>&lt;sql-insert&gt;</literal>, <literal>&lt;sql-delete&gt;</"
+"literal>, y <literal>&lt;sql-update&gt;</literal> sobrescriben estas cadenas:"
 
 #. Tag: para
-#: query_sql.xml:537
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The SQL is directly executed in your database, so you can use any dialect "
 "you like. This will reduce the portability of your mapping if you use "
 "database specific SQL."
 msgstr ""
-"El SQL se ejecuta directamente en tu base de datos, de modo que eres libre "
-"de usar cualquier dialecto que quieras. Esto reducir&#x00e1;, por supuesto, "
-"la portabilidad de tu mapeo si usas SQL espec&#x00ed;fico de la base de "
-"datos."
+"El SQL se ejecuta directamente en su base de datos asi que usted es libre de "
+"utilizar cualquier dialecto que desee. Esto reducirá la portabilidad de su "
+"mapeo si utiliza una base de datos especifica de SQL."
 
 #. Tag: para
-#: query_sql.xml:541
 #, no-c-format
 msgid ""
 "Stored procedures are supported if the <literal>callable</literal> attribute "
 "is set:"
 msgstr ""
-"Los procedimientos almacenados son soportados si est&#x00e1; establecido el "
-"atributo <literal>callable</literal>:"
+"Los procedimientos almacenados se encuentran soportados si el atributo "
+"<literal>callable</literal> está configurado:"
 
-#. Tag: programlisting
-#: query_sql.xml:544
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <sql-insert callable=\"true\">{call createPerson (?, ?)}</sql-insert>\n"
-"    <sql-delete callable=\"true\">{? = call deletePerson (?)}</sql-delete>\n"
-"    <sql-update callable=\"true\">{? = call updatePerson (?, ?)}</sql-"
-"update>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <sql-insert callable=\"true\">{call createPerson (?, ?)}</sql-insert>\n"
-"    <sql-delete callable=\"true\">{? = call deletePerson (?)}</sql-delete>\n"
-"    <sql-update callable=\"true\">{? = call updatePerson (?, ?)}</sql-"
-"update>\n"
-"</class>]]>"
-
-#. Tag: para
-#: query_sql.xml:546
-#, fuzzy, no-c-format
-msgid ""
 "The order of the positional parameters is vital, as they must be in the same "
 "sequence as Hibernate expects them."
 msgstr ""
-"El orden de los par&#x00e1;metros posicionales son actualmente vitales, ya "
-"que deben estar en la misma secuencia en que las espera Hibernate."
+"El orden de los parámetros posicionales es vital ya que se deben encontrar "
+"en la misma secuencia en que Hibernate los espera."
 
 #. Tag: para
-#: query_sql.xml:549
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can view the expected order by enabling debug logging for the "
 "<literal>org.hibernate.persister.entity</literal> level. With this level "
@@ -1553,214 +940,120 @@
 "your custom SQL in the mapping files, as this will override the Hibernate "
 "generated static SQL."
 msgstr ""
-"Puedes ver el orden esperado habilitando el registro de depuraci&#x00f3;n "
-"para el nivel <literal>org.hibernate.persister.entity</literal>. Con este "
-"nivel habilitado, Hibernate imprimir&#x00e1; el SQL est&#x00e1;tico que se "
-"usa para crear, actualizar, borrar, etc. las entidades. (Para ver la "
-"secuencia esperada, recuerda no incluir tu SQL personalizado en los ficheros "
-"de mapeo ya que sobrescribir&#x00e1;n el sql est&#x00e1;tico generado por "
-"Hibernate.)"
+"Puede ver el orden esperado habilitando el registro de depuración para el "
+"nivel <literal>org.hibernate.persister.entity</literal>. Con este nivel "
+"habilitado Hibernate imprimirá el SQL estático que se utiliza para crear, "
+"actualizar, borrar, etc, entidades, ( para ver la secuencia esperada, "
+"recuerde no incluir su SQL personalizado en los archivos de mapeo ya que eso "
+"sobrescribirá el sql estático generado por Hibernate)."
 
 #. Tag: para
-#: query_sql.xml:556
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The stored procedures are in most cases required to return the number of "
 "rows inserted, updated and deleted, as Hibernate has some runtime checks for "
 "the success of the statement. Hibernate always registers the first statement "
 "parameter as a numeric output parameter for the CUD operations:"
 msgstr ""
-"Los procedimientos almacenados son, en la mayor&#x00ed;a de los casos "
-"(l&#x00e9;ase, mejor hacerlo que no hacerlo), obligados a devolver el "
-"n&#x00fa;mero de filas insertadas/actualizadas/borradas, ya que Hibernate "
-"tiene algunas comprobaciones en tiempo de ejecuci&#x00f3;n del &#x00e9;xito "
-"de la sentencia. Hibernate siempre registra el primer par&#x00e1;metro de la "
-"sentencia como un par&#x00e1;metro de salida num&#x00e9;rico para las "
-"operaciones CUD:"
+"En la mayoría de los casos se requiere que los procedimientos almacenados "
+"retornen el número de filas insertadas, actualizadas y borradas ya que "
+"Hibernate tiene algunas verificaciones en tiempo de ejecución para el éxito "
+"de la declaración. Hibernate siempre registra el primer parámetro de la "
+"declaración como un parámetro de la salida numérica para las operaciones CUD:"
 
-#. Tag: programlisting
-#: query_sql.xml:562
-#, no-c-format
-msgid ""
-"<![CDATA[CREATE OR REPLACE FUNCTION updatePerson (uid IN NUMBER, uname IN "
-"VARCHAR2)\n"
-"    RETURN NUMBER IS\n"
-"BEGIN\n"
-"\n"
-"    update PERSON\n"
-"    set\n"
-"        NAME = uname,\n"
-"    where\n"
-"        ID = uid;\n"
-"\n"
-"    return SQL%ROWCOUNT;\n"
-"\n"
-"END updatePerson;]]>"
-msgstr ""
-"<![CDATA[CREATE OR REPLACE FUNCTION updatePerson (uid IN NUMBER, uname IN "
-"VARCHAR2)\n"
-"    RETURN NUMBER IS\n"
-"BEGIN\n"
-"\n"
-"    update PERSON\n"
-"    set\n"
-"        NAME = uname,\n"
-"    where\n"
-"        ID = uid;\n"
-"\n"
-"    return SQL%ROWCOUNT;\n"
-"\n"
-"END updatePerson;]]>"
-
 #. Tag: title
-#: query_sql.xml:566
 #, no-c-format
 msgid "Custom SQL for loading"
-msgstr "SQL personalizado para carga"
+msgstr "Personalice SQL para cargar"
 
 #. Tag: para
-#: query_sql.xml:568
-#, fuzzy, no-c-format
-msgid "You can also declare your own SQL (or HQL) queries for entity loading:"
-msgstr ""
-"Puedes tambi&#x00e9;n declarar tu propias consultas SQL (o HQL) para cargar "
-"entidades:"
-
-#. Tag: programlisting
-#: query_sql.xml:571
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"person\">\n"
-"    <return alias=\"pers\" class=\"Person\" lock-mode=\"upgrade\"/>\n"
-"    SELECT NAME AS {pers.name}, ID AS {pers.id}\n"
-"    FROM PERSON\n"
-"    WHERE ID=?\n"
-"    FOR UPDATE\n"
-"</sql-query>]]>"
+"You can also declare your own SQL (or HQL) queries for entity loading. As "
+"with inserts, updates, and deletes, this can be done at the individual "
+"column level as described in <xref linkend=\"mapping-column-read-and-write"
+"\" /> or at the statement level. Here is an example of a statement level "
+"override:"
 msgstr ""
-"<![CDATA[<sql-query name=\"person\">\n"
-"    <return alias=\"pers\" class=\"Person\" lock-mode=\"upgrade\"/>\n"
-"    SELECT NAME AS {pers.name}, ID AS {pers.id} \n"
-"    FROM PERSON \n"
-"    WHERE ID=? \n"
-"    FOR UPDATE\n"
-"</sql-query>]]>"
 
 #. Tag: para
-#: query_sql.xml:573
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is just a named query declaration, as discussed earlier. You can "
 "reference this named query in a class mapping:"
 msgstr ""
-"Esto es s&#x00f3;lo una declaraci&#x00f3;n de consulta con nombrem como se "
-"ha discutido anteriormente. Puedes hacer referencia a esta consulta con "
-"nombre en un mapeo de clase:"
+"Esta es tan sólo una declaración de consulta nombrada, como se discutió "
+"anteriormente. Puede referenciar esta consulta nombrada en un mapeo de clase:"
 
-#. Tag: programlisting
-#: query_sql.xml:576
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <loader query-ref=\"person\"/>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <loader query-ref=\"person\"/>\n"
-"</class>]]>"
-
 #. Tag: para
-#: query_sql.xml:578
 #, no-c-format
 msgid "This even works with stored procedures."
-msgstr "Esto incluso funciona con procedimientos almacenados."
+msgstr "Esto funciona inclusive con procedimientos almacenados."
 
 #. Tag: para
-#: query_sql.xml:580
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can even define a query for collection loading:"
-msgstr "Puedes incluso definit una consulta para la carga de colecciones:"
+msgstr "Puede incluso definir una consulta para la carga de colección:"
 
-#. Tag: programlisting
-#: query_sql.xml:582
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"employments\" inverse=\"true\">\n"
-"    <key/>\n"
-"    <one-to-many class=\"Employment\"/>\n"
-"    <loader query-ref=\"employments\"/>\n"
-"</set>]]>"
-msgstr ""
-"<![CDATA[<set name=\"employments\" inverse=\"true\">\n"
-"    <key/>\n"
-"    <one-to-many class=\"Employment\"/>\n"
-"    <loader query-ref=\"employments\"/>\n"
-"</set>]]>"
-
-#. Tag: programlisting
-#: query_sql.xml:584
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"employments\">\n"
-"    <load-collection alias=\"emp\" role=\"Person.employments\"/>\n"
-"    SELECT {emp.*}\n"
-"    FROM EMPLOYMENT emp\n"
-"    WHERE EMPLOYER = :id\n"
-"    ORDER BY STARTDATE ASC, EMPLOYEE ASC\n"
-"</sql-query>]]>"
-msgstr ""
-"<![CDATA[<sql-query name=\"employments\">\n"
-"    <load-collection alias=\"emp\" role=\"Person.employments\"/>\n"
-"    SELECT {emp.*}\n"
-"    FROM EMPLOYMENT emp\n"
-"    WHERE EMPLOYER = :id\n"
-"    ORDER BY STARTDATE ASC, EMPLOYEE ASC\n"
-"</sql-query>]]>"
-
-#. Tag: para
-#: query_sql.xml:586
-#, fuzzy, no-c-format
-msgid ""
 "You can also define an entity loader that loads a collection by join "
 "fetching:"
 msgstr ""
-"Podr&#x00ed;as incluso definir un cargador de entidades que cargue una "
-"colecci&#x00f3;n por recuperaci&#x00f3;n por uni&#x00f3;n (join fetching):"
+"También puede definir un cargador de entidad que cargue una colección con "
+"una unión temprana:"
 
-#. Tag: programlisting
-#: query_sql.xml:589
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"person\">\n"
-"    <return alias=\"pers\" class=\"Person\"/>\n"
-"    <return-join alias=\"emp\" property=\"pers.employments\"/>\n"
-"    SELECT NAME AS {pers.*}, {emp.*}\n"
-"    FROM PERSON pers\n"
-"    LEFT OUTER JOIN EMPLOYMENT emp\n"
-"        ON pers.ID = emp.PERSON_ID\n"
-"    WHERE ID=?\n"
-"</sql-query>]]>"
-msgstr ""
-"<![CDATA[<sql-query name=\"person\">\n"
-"    <return alias=\"pers\" class=\"Person\"/>\n"
-"    <return-join alias=\"emp\" property=\"pers.employments\"/> \n"
-"    SELECT NAME AS {pers.*}, {emp.*}\n"
-"    FROM PERSON pers\n"
-"    LEFT OUTER JOIN EMPLOYMENT emp \n"
-"        ON pers.ID = emp.PERSON_ID\n"
-"    WHERE ID=?\n"
-"</sql-query>]]>"
+#~ msgid ""
+#~ "You can also declare your own SQL (or HQL) queries for entity loading:"
+#~ msgstr ""
+#~ "También puede declarar sus propias consultas SQL (o HQL) para cargar "
+#~ "entidad:"
 
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
+#, fuzzy
+#~ msgid "A_NAME as {item.name}"
+#~ msgstr "<literal>A_NAME as {item.name}</literal>"
 
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+#, fuzzy
+#~ msgid "{[aliasname].class}"
+#~ msgstr "<literal>{[aliasname].class}</literal>"
+
+#, fuzzy
+#~ msgid "DISC as {item.class}"
+#~ msgstr "<literal>DISC as {item.class}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].*}"
+#~ msgstr "<literal>{[aliasname].*}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].key}"
+#~ msgstr "<literal>{[aliasname].key}</literal>"
+
+#, fuzzy
+#~ msgid "ORGID as {coll.key}"
+#~ msgstr "<literal>ORGID as {coll.key}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].id}"
+#~ msgstr "<literal>{[aliasname].id}</literal>"
+
+#, fuzzy
+#~ msgid "EMPID as {coll.id}"
+#~ msgstr "<literal>EMPID as {coll.id}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].element}"
+#~ msgstr "<literal>{[aliasname].element}</literal>"
+
+#, fuzzy
+#~ msgid "XID as {coll.element}"
+#~ msgstr "<literal>XID as {coll.element}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].element.*}"
+#~ msgstr "<literal>{[aliasname].element.*}</literal>"
+
+#, fuzzy
+#~ msgid "{coll.element.*}"
+#~ msgstr "<literal>{coll.element.*}</literal>"

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/session_api.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/session_api.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/session_api.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,21 +1,35 @@
-#, fuzzy
+# translation of session_api.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: session_api\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2010-01-07 10:43+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: session_api.xml:29
 #, no-c-format
 msgid "Working with objects"
-msgstr "Trabajando con objetos"
+msgstr "Trabajo con objetos"
 
 #. Tag: para
-#: session_api.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate is a full object/relational mapping solution that not only shields "
 "the developer from the details of the underlying database management system, "
@@ -24,16 +38,15 @@
 "JDBC/SQL persistence layers, a natural object-oriented view of persistence "
 "in Java applications."
 msgstr ""
-"Hibernate es una soluci&#x00f3;n completa de mapeo objeto/relacional que no "
-"s&#x00f3;lo abstrae al desarrollador de los detalles del sistema de manejo "
-"de base datos subyacente, sino que adem&#x00e1;s ofrece <emphasis>manejo de "
-"estado</emphasis> de objetos. Esto es, al contrario del manejo de "
-"<literal>sentencias</literal> SQL en capas comunes de persistencia JDBC/SQL, "
-"una vista de la persistencia en aplicaciones Java muy natural y orientada a "
-"objetos."
+"Hibernate es una solución completa de mapeo objeto/relacional que no sólo "
+"proteje al desarrollador de los detalles del sistema de administración de la "
+"base datos subyacente, sino que además ofrece <emphasis>administración de "
+"estado</emphasis> de objetos. Contrario a la administración de "
+"<literal>declaraciones</literal> SQL en capas comunes de persistencia JDBC/"
+"SQL, esta es una vista natural orientada a objetos de la persistencia en "
+"aplicaciones Java."
 
 #. Tag: para
-#: session_api.xml:40
 #, no-c-format
 msgid ""
 "In other words, Hibernate application developers should always think about "
@@ -42,27 +55,24 @@
 "is only relevant for the application developer when tuning the performance "
 "of the system."
 msgstr ""
-"En otras palabras, los desarroladores de aplicaciones Hibernate deben "
-"siempre pensar en el <emphasis>estado</emphasis> de sus objetos, y no "
-"necesariamente en la ejecuci&#x00f3;n de sentencias SQL. Esta parte es "
-"cuidada por Hibernate y es s&#x00f3;lo relevante para el desarrollador de la "
-"aplicaci&#x00f3;n al afinar el rendimiento del sistema."
+"En otras palabras, los desarrolladores de aplicaciones de Hibernate siempre "
+"deben pensar en el <emphasis>estado</emphasis> de sus objetos, y no "
+"necesariamente en la ejecución de declaraciones SQL. Hibernate se ocupa de "
+"esto y es sólamente relevante para el desarrollador de la aplicación al "
+"afinar el rendimiento del sistema."
 
 #. Tag: title
-#: session_api.xml:48
 #, no-c-format
 msgid "Hibernate object states"
 msgstr "Estados de objeto de Hibernate"
 
 #. Tag: para
-#: session_api.xml:50
 #, no-c-format
 msgid "Hibernate defines and supports the following object states:"
 msgstr "Hibernate define y soporta los siguientes estados de objeto:"
 
 #. Tag: para
-#: session_api.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Transient</emphasis> - an object is transient if it has just been "
 "instantiated using the <literal>new</literal> operator, and it is not "
@@ -75,18 +85,17 @@
 "transition)."
 msgstr ""
 "<emphasis>Transitorio</emphasis> - un objeto es transitorio si ha sido "
-"reci&#x00e9;n instanciado usando el operador <literal>new</literal>, y no "
-"est&#x00e1; asociado a una <literal>Session</literal> de Hibernate. No tiene "
-"una representaci&#x00f3;n persistente en la base de datos y no se le ha "
-"asignado un valor identificador. Las instancias transitorias ser&#x00e1;n "
-"destru&#x00ed;das por el recolector de basura si la aplicaci&#x00f3;n no "
-"mantiene m&#x00e1;s una referencia. Usa la <literal>Session</literal> de "
-"Hibernate para hacer un objeto persistente (y deja que Hibernate cuide de "
-"las sentencias SQL que necesitan ejecutarse para esta transici&#x00f3;n)."
+"recién instanciado utilizando el operador <literal>new</literal>, y no está "
+"asociado a una <literal>Session</literal> de Hibernate. No tiene una "
+"representación persistente en la base de datos y no se le ha asignado un "
+"valor identificador. Las instancias transitorias serán destruídas por el "
+"recolector de basura si la aplicación no mantiene más una referencia. "
+"Utiliza la <literal>Session</literal> de Hibernate para hacer un objeto "
+"persistente (y deja que Hibernate se ocupe de las declaraciones SQL que "
+"necesitan ejecutarse para esta transición)."
 
 #. Tag: para
-#: session_api.xml:68
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Persistent</emphasis> - a persistent instance has a representation "
 "in the database and an identifier value. It might just have been saved or "
@@ -98,18 +107,17 @@
 "made transient."
 msgstr ""
 "<emphasis>Persistente</emphasis> - una instancia persistente tiene una "
-"representaci&#x00f3;n en la base de datos y un valor identificador. Puede "
-"haber sido salvado o cargado, sin embargo, est&#x00e1; por definici&#x00f3;n "
-"en el &#x00e1;mbito de una <literal>Session</literal>. Hibernate "
-"detectar&#x00e1; cualquier cambio hecho a un objeto en estado persistentey "
-"sincronizar&#x00e1; el estado con la base de datos cuando se complete la "
-"unidad de trabajo. Los desarrolladores no ejecutan sentencias "
-"<literal>UPDATE</literal> manuales, o sentencias <literal>DELETE</literal> "
-"cuando un objeto debe ser hecho transitorio."
+"representación en la base de datos y un valor identificador. Puede haber "
+"sido guardado o cargado, sin embargo, por definición, se encuentra en el "
+"ámbito de una <literal>Session</literal>. Hibernate detectará cualquier "
+"cambio realizado a un objeto en estado persistente y sincronizará el estado "
+"con la base de datos cuando se complete la unidad de trabajo. Los "
+"desarrolladores no ejecutan declaraciones <literal>UPDATE</literal> "
+"manuales, o declaraciones <literal>DELETE</literal> cuando un objeto se debe "
+"poner como transitorio."
 
 #. Tag: para
-#: session_api.xml:79
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Detached</emphasis> - a detached instance is an object that has "
 "been persistent, but its <literal>Session</literal> has been closed. The "
@@ -121,67 +129,45 @@
 "them <emphasis>application transactions</emphasis>, i.e., a unit of work "
 "from the point of view of the user."
 msgstr ""
-"<emphasis>Separado (detached)</emphasis> - una instancia separada es un "
-"objeto que ha sido hecho persistente, pero su <literal>Session</literal> ha "
-"sido cerrada. La referencia al objeto todav&#x00ed;a es v&#x00e1;lida, por "
-"supuesto, y la instancia separada podr&#x00ed;a incluso ser modificada en "
-"este estado. Una instancia separada puede ser re-unida a una nueva "
-"<literal>Session</literal> en un punto posterior en el tiempo, haci&#x00e9;"
-"ndola persistente de nuevo (con todas las modificaciones). Este aspecto "
-"habilita un modelo de programaci&#x00f3;n para unidades de trabajo de "
-"ejecuci&#x00f3;n larga que requieren tiempo-para-pensar del usuario. Las "
-"llamamos <emphasis>transaccciones de aplicaci&#x00f3;n</emphasis>, es decir, "
-"una unidad de trabajo desde el punto de vista del usuario."
+"<emphasis>Separado</emphasis> - una instancia separada es un objeto que se "
+"ha hecho persistente, pero su <literal>Session</literal> ha sido cerrada. La "
+"referencia al objeto todavía es válida, por supuesto, y la instancia "
+"separada podría incluso ser modificada en este estado. Una instancia "
+"separada puede ser re-unida a una nueva <literal>Session</literal> más "
+"tarde, haciéndola persistente de nuevo (con todas las modificaciones). Este "
+"aspecto habilita un modelo de programación para unidades de trabajo de "
+"ejecución larga que requieren tiempo-para-pensar por parte del usuario. Las "
+"llamamos <emphasis>transaccciones de aplicación</emphasis>, por ejemplo, una "
+"unidad de trabajo desde el punto de vista del usuario."
 
 #. Tag: para
-#: session_api.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will now discuss the states and state transitions (and the Hibernate "
 "methods that trigger a transition) in more detail."
 msgstr ""
-"Discutiremos ahora los estados y transiciones de estados (y los m&#x00e9;"
-"todos de Hibernate que disparan una transici&#x00f3;n) en m&#x00e1;s detalle:"
+"Discutiremos ahora los estados y transiciones de estados (y los métodos de "
+"Hibernate que disparan una transición) en más detalle. "
 
 #. Tag: title
-#: session_api.xml:101
 #, no-c-format
 msgid "Making objects persistent"
 msgstr "Haciendo los objetos persistentes"
 
 #. Tag: para
-#: session_api.xml:103
 #, no-c-format
 msgid ""
 "Newly instantiated instances of a a persistent class are considered "
 "<emphasis>transient</emphasis> by Hibernate. We can make a transient "
 "instance <emphasis>persistent</emphasis> by associating it with a session:"
 msgstr ""
-"Las instancias reci&#x00e9;n instanciadas de una clase persistente son "
-"consideradas <emphasis>transitorias</emphasis> por Hibernate. Podemos hacer "
-"una instancia transitoria <emphasis>persistente</emphasis> asoci&#x00e1;"
-"ndola con una sesi&#x00f3;n:"
+"Las instancias recién instanciadas de una clase persistente son consideradas "
+"<emphasis>transitorias</emphasis> por Hibernate. Podemos hacer una instancia "
+"transitoria <emphasis>persistente</emphasis> asociándola con una sesión:"
 
-#. Tag: programlisting
-#: session_api.xml:110
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DomesticCat fritz = new DomesticCat();\n"
-"fritz.setColor(Color.GINGER);\n"
-"fritz.setSex('M');\n"
-"fritz.setName(\"Fritz\");\n"
-"Long generatedId = (Long) sess.save(fritz);]]>"
-msgstr ""
-"<![CDATA[DomesticCat fritz = new DomesticCat();\n"
-"fritz.setColor(Color.GINGER);\n"
-"fritz.setSex('M');\n"
-"fritz.setName(\"Fritz\");\n"
-"Long generatedId = (Long) sess.save(fritz);]]>"
-
-#. Tag: para
-#: session_api.xml:112
-#, fuzzy, no-c-format
-msgid ""
 "If <literal>Cat</literal> has a generated identifier, the identifier is "
 "generated and assigned to the <literal>cat</literal> when <literal>save()</"
 "literal> is called. If <literal>Cat</literal> has an <literal>assigned</"
@@ -196,13 +182,12 @@
 "<literal>save()</literal>. Si <literal>Cat</literal> tiene un identificador "
 "<literal>assigned</literal>, o una clave compuesta, el identificador debe "
 "ser asignado a la instancia de <literal>cat</literal> antes de llamar a "
-"<literal>save()</literal>. Puedes tambi&#x00e9;n usar <literal>persist()</"
-"literal> en vez de <literal>save()</literal>, con la sem&#x00e1;ntica "
-"definida en el temprano borrador de EJB3."
+"<literal>save()</literal>. También puede utilizar <literal>persist()</"
+"literal> en vez de <literal>save()</literal>, con la semántica definida en "
+"el borrador de EJB3. "
 
 #. Tag: para
-#: session_api.xml:124
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>persist()</literal> makes a transient instance persistent. However, "
 "it does not guarantee that the identifier value will be assigned to the "
@@ -212,16 +197,15 @@
 "boundaries. This is useful in long-running conversations with an extended "
 "Session/persistence context."
 msgstr ""
-"UNTRANSLATED!!! <literal>persist()</literal> makes a transient instance "
-"persistent. However, it doesn't guarantee that the identifier value will be "
-"assigned to the persistent instance immediately, the assignment might happen "
-"at flush time. <literal>persist()</literal> also guarantees that it will not "
-"execute an <literal>INSERT</literal> statement if it is called outside of "
-"transaction boundaries. This is useful in long-running conversations with an "
-"extended Session/persistence context."
+"<literal>persist()</literal> hace que una instancia transitoria sea "
+"persistente. Sin embargo, no garantiza que el valor identificador sea "
+"asignado a la instancia persistente inmediatamente, la tarea puede tener "
+"lugar durante el vaciado. <literal>persist()</literal> también garantiza que "
+"no ejecutará una declaración <literal>INSERT</literal> si se llama por fuera "
+"de los límites de una transacción. Esto es útil en conversaciones largas con "
+"un contexto extendido sesión/persistencia."
 
 #. Tag: para
-#: session_api.xml:135
 #, no-c-format
 msgid ""
 "<literal>save()</literal> does guarantee to return an identifier. If an "
@@ -230,46 +214,25 @@
 "you are inside or outside of a transaction. This is problematic in a long-"
 "running conversation with an extended Session/persistence context."
 msgstr ""
-"<literal>save()</literal> does guarantee to return an identifier. If an "
-"INSERT has to be executed to get the identifier ( e.g. \"identity\" "
-"generator, not \"sequence\"), this INSERT happens immediately, no matter if "
-"you are inside or outside of a transaction. This is problematic in a long-"
-"running conversation with an extended Session/persistence context."
+"<literal>save()</literal> sí garantiza el retorno de un identificador. Si se "
+"tiene que ejecutar un INSERT para obtener el identificador ( por ejemplo, "
+"generador \"identidad\", no \"secuencia\"), este INSERT tiene lugar "
+"inmediatamente sin importar si se encuentra dentro o fuera de una "
+"transacción. Esto es problemático en una conversación larga con un contexto "
+"extendido sesión/persistencia."
 
 #. Tag: para
-#: session_api.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, you can assign the identifier using an overloaded version of "
 "<literal>save()</literal>."
 msgstr ""
-"Alternativamente, puedes asignar el identificador usando una versi&#x00f3;n "
+"Opcionalmente, puede asignar el identificador utilizando una versión "
 "sobrecargada de <literal>save()</literal>."
 
-#. Tag: programlisting
-#: session_api.xml:150
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DomesticCat pk = new DomesticCat();\n"
-"pk.setColor(Color.TABBY);\n"
-"pk.setSex('F');\n"
-"pk.setName(\"PK\");\n"
-"pk.setKittens( new HashSet() );\n"
-"pk.addKitten(fritz);\n"
-"sess.save( pk, new Long(1234) );]]>"
-msgstr ""
-"<![CDATA[DomesticCat pk = new DomesticCat();\n"
-"pk.setColor(Color.TABBY);\n"
-"pk.setSex('F');\n"
-"pk.setName(\"PK\");\n"
-"pk.setKittens( new HashSet() );\n"
-"pk.addKitten(fritz);\n"
-"sess.save( pk, new Long(1234) );]]>"
-
-#. Tag: para
-#: session_api.xml:152
-#, fuzzy, no-c-format
-msgid ""
 "If the object you make persistent has associated objects (e.g. the "
 "<literal>kittens</literal> collection in the previous example), these "
 "objects can be made persistent in any order you like unless you have a "
@@ -278,18 +241,17 @@
 "violate a <literal>NOT NULL</literal> constraint if you <literal>save()</"
 "literal> the objects in the wrong order."
 msgstr ""
-"Si el objeto que haces persistente tiene objetos asociados (por ejemplo, la "
-"colecci&#x00f3;n <literal>kittens</literal> en el ejemplo anterior), estos "
-"objetos pueden ser hechos persistentes en cualquier orden que quieras a "
-"menos que tengas una restricci&#x00f3;n <literal>NOT NULL</literal> sobre "
-"una columna clave for&#x00e1;nea. Nunca hay riesgo de violar restricciones "
-"de clave for&#x00e1;nea. Sin embargo, podr&#x00ed;as violar una "
-"restricci&#x00f3;n <literal>NOT NULL</literal> si llamas a <literal>save()</"
-"literal> sobre objetos en orden err&#x00f3;neo."
+"Si el objeto que hace persistente tiene objetos asociados (por ejemplo, la "
+"colección <literal>kittens</literal> en el ejemplo anterior), estos objetos "
+"pueden ser hechos persistentes en cualquier orden que quiera a menos de que "
+"tenga una restricción <literal>NOT NULL</literal> sobre una columna clave "
+"foránea. Nunca hay riesgo de violar restricciones de clave foránea. Sin "
+"embargo, puede que usted viole una restricción <literal>NOT NULL</literal> "
+"si llama a <literal>save()</literal> sobre los objetos en el orden "
+"equivocado. "
 
 #. Tag: para
-#: session_api.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Usually you do not bother with this detail, as you will normally use "
 "Hibernate's <emphasis>transitive persistence</emphasis> feature to save the "
@@ -297,79 +259,40 @@
 "constraint violations do not occur - Hibernate will take care of everything. "
 "Transitive persistence is discussed later in this chapter."
 msgstr ""
-"Usualmente no te preocupas con este detalle, pues muy probablemente "
-"usar&#x00e1;s la funcionalidad de <emphasis>persistencia transitiva</"
-"emphasis> de Hibernate para salvar los objetos asociados autom&#x00e1;"
-"ticamente. Entonces, ni siquiera ocurren violaciones de restricciones "
-"<literal>NOT NULL</literal> - Hibernate cuidar&#x00e1; de todo. La "
-"persistencia transitiva se discute m&#x00e1;s adelante en este cap&#x00ed;"
-"tulo."
+"Usualmente no se preocupe de este detalle, pues muy probablemente utilizará "
+"la funcionalidad de <emphasis>persistencia transitiva</emphasis> de "
+"Hibernate para guardar los objetos asociados automáticamente. Entonces, ni "
+"siquiera tienen lugar violaciones de restricciones <literal>NOT NULL</"
+"literal> - Hibernate se ocupará de todo. Más adelante en este capítulo se "
+"discute la persistencia transitiva."
 
 #. Tag: title
-#: session_api.xml:173
 #, no-c-format
 msgid "Loading an object"
 msgstr "Cargando un objeto"
 
 #. Tag: para
-#: session_api.xml:175
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>load()</literal> methods of <literal>Session</literal> provide "
 "a way of retrieving a persistent instance if you know its identifier. "
 "<literal>load()</literal> takes a class object and loads the state into a "
 "newly instantiated instance of that class in a persistent state."
 msgstr ""
-"Los m&#x00e9;todos <literal>load()</literal> de <literal>Session</literal> "
-"te brindan una forma de traer una instancia persistente si ya saves su "
-"identificador. <literal>load()</literal> toma un objeto clase y "
-"cargar&#x00e1; el estado dentro de una instancia reci&#x00e9;n instanciada "
-"de esta clase, en estado persistente."
+"Los métodos <literal>load()</literal> de <literal>Session</literal> le "
+"proporcionan una forma de recuperar una instancia persistente si ya conoce "
+"su identificador. <literal>load()</literal> toma un objeto clase y carga el "
+"estado dentro de una instancia recién instanciada de esa clase, en un estado "
+"persistente."
 
-#. Tag: programlisting
-#: session_api.xml:182
-#, no-c-format
-msgid "<![CDATA[Cat fritz = (Cat) sess.load(Cat.class, generatedId);]]>"
-msgstr "<![CDATA[Cat fritz = (Cat) sess.load(Cat.class, generatedId);]]>"
-
-#. Tag: programlisting
-#: session_api.xml:184
-#, no-c-format
-msgid ""
-"<![CDATA[// you need to wrap primitive identifiers\n"
-"long id = 1234;\n"
-"DomesticCat pk = (DomesticCat) sess.load( DomesticCat.class, new Long"
-"(id) );]]>"
-msgstr ""
-"<![CDATA[// you need to wrap primitive identifiers\n"
-"long id = 1234;\n"
-"DomesticCat pk = (DomesticCat) sess.load( DomesticCat.class, new Long"
-"(id) );]]>"
-
 #. Tag: para
-#: session_api.xml:186
 #, no-c-format
 msgid "Alternatively, you can load state into a given instance:"
-msgstr "Alternativamente, puedes cargar estado dentro de una instancia dada:"
+msgstr "Alternativamente, puede cargar estado dentro de una instancia dada:"
 
-#. Tag: programlisting
-#: session_api.xml:190
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Cat cat = new DomesticCat();\n"
-"// load pk's state into cat\n"
-"sess.load( cat, new Long(pkId) );\n"
-"Set kittens = cat.getKittens();]]>"
-msgstr ""
-"<![CDATA[Cat cat = new DomesticCat();\n"
-"// load pk's state into cat\n"
-"sess.load( cat, new Long(pkId) );\n"
-"Set kittens = cat.getKittens();]]>"
-
-#. Tag: para
-#: session_api.xml:192
-#, fuzzy, no-c-format
-msgid ""
 "Be aware that <literal>load()</literal> will throw an unrecoverable "
 "exception if there is no matching database row. If the class is mapped with "
 "a proxy, <literal>load()</literal> just returns an uninitialized proxy and "
@@ -379,80 +302,51 @@
 "be loaded as a batch if <literal>batch-size</literal> is defined for the "
 "class mapping."
 msgstr ""
-"Nota que <literal>load()</literal> lanzar&#x00e1; una excepci&#x00f3;n "
-"irrecuperable si no hay una fila correspondiente en base de datos. Si la "
-"clase es mapeada con un proxy, <literal>load()</literal> s&#x00f3;lo "
-"devuelve un proxy no inicializado y no llamar&#x00e1; realmente a la base de "
-"datos hasta que invoques un m&#x00e9;todo del proxy. Este comportamiento es "
-"muy &#x00fa;til si deseas crear una asociaci&#x00f3;n a un objeto sin "
-"cargarlo realmente de la base de datos. Permite adem&#x00e1;s que m&#x00fa;"
-"ltiples instancias sean cargadas como un lote si se define <literal>batch-"
+"Note que <literal>load()</literal> lanzará una excepción irrecuperable si no "
+"hay una fila correspondiente en la base de datos. Si la clase se mapea con "
+"un proxy, <literal>load()</literal> sólo retorna un proxy no inicializado y "
+"no llamará realmente a la base de datos hasta que invoque un método del "
+"proxy. Este comportamiento es muy útil si desea crear una asociación a un "
+"objeto sin cargarlo realmente de la base de datos. Además permite que "
+"múltiples instancias sean cargadas como un lote si se define <literal>batch-"
 "size</literal> para el mapeo de la clase."
 
 #. Tag: para
-#: session_api.xml:203
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are not certain that a matching row exists, you should use the "
 "<literal>get()</literal> method which hits the database immediately and "
 "returns null if there is no matching row."
 msgstr ""
-"Si no tienes certeza que exista una fila correspondiente, debes usar el "
-"m&#x00e9;todo <literal>get()</literal>, que llama a la base de datos "
-"inmediatamente y devuelve nulo si no existe una fila correspondiente."
+"Si no tiene la certeza de que existe una fila correspondiente, debe utilizar "
+"el método <literal>get()</literal>, que llama a la base de datos "
+"inmediatamente y devuelve nulo si no existe una fila correspondiente. "
 
-#. Tag: programlisting
-#: session_api.xml:209
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id);\n"
-"if (cat==null) {\n"
-"    cat = new Cat();\n"
-"    sess.save(cat, id);\n"
-"}\n"
-"return cat;]]>"
-msgstr ""
-"<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id);\n"
-"if (cat==null) {\n"
-"    cat = new Cat();\n"
-"    sess.save(cat, id);\n"
-"}\n"
-"return cat;]]>"
-
-#. Tag: para
-#: session_api.xml:211
-#, fuzzy, no-c-format
-msgid ""
 "You can even load an object using an SQL <literal>SELECT ... FOR UPDATE</"
 "literal>, using a <literal>LockMode</literal>. See the API documentation for "
 "more information."
 msgstr ""
-"Puedes incluso cargar un objeto usando un <literal>SELECT ... FOR UPDATE</"
-"literal> de SQL, usando un <literal>LockMode</literal>. Ver la "
-"documentaci&#x00f3;n de la API para m&#x00e1;s informaci&#x00f3;n."
+"Incluso puede cargar un objeto utilizando un <literal>SELECT ... FOR UPDATE</"
+"literal> de SQL, usando un <literal>LockMode</literal>. Consulte la "
+"documentación de la API para obtener más información."
 
-#. Tag: programlisting
-#: session_api.xml:216
-#, no-c-format
-msgid "<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id, LockMode.UPGRADE);]]>"
-msgstr "<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id, LockMode.UPGRADE);]]>"
-
 #. Tag: para
-#: session_api.xml:218
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Any associated instances or contained collections will <emphasis>not</"
 "emphasis> be selected <literal>FOR UPDATE</literal>, unless you decide to "
 "specify <literal>lock</literal> or <literal>all</literal> as a cascade style "
 "for the association."
 msgstr ""
-"Ten en cuenta que <emphasis>ninguna</emphasis> instancia asociada o "
-"colecci&#x00f3;n contenida es selecciona <literal>FOR UPDATE</literal>, a "
-"menos que decidas especificar <literal>lock</literal> o <literal>all</"
-"literal> como un estilo de cascada para la asociaci&#x00f3;n."
+"<emphasis>Ninguna</emphasis> instancia asociada o colección contenida es "
+"seleccionada para actualizacion - <literal>FOR UPDATE</literal>, a menos de "
+"que decida especificar <literal>lock</literal> o <literal>all</literal> como "
+"un estilo de cascada para la asociación."
 
 #. Tag: para
-#: session_api.xml:225
 #, no-c-format
 msgid ""
 "It is possible to re-load an object and all its collections at any time, "
@@ -460,46 +354,30 @@
 "triggers are used to initialize some of the properties of the object."
 msgstr ""
 "Es posible volver a cargar un objeto y todas sus colecciones en cualquier "
-"momento, usando el m&#x00e9;todo <literal>refresh()</literal>. Esto es "
-"&#x00fa;til cuando se usan disparadores de base de datos para inicializar "
-"algunas de las propiedades del objeto."
+"momento, utilizando el método <literal>refresh()</literal>. Esto es útil "
+"cuando se usan disparadores de base de datos para inicializar algunas de las "
+"propiedades del objeto."
 
-#. Tag: programlisting
-#: session_api.xml:231
-#, no-c-format
-msgid ""
-"<![CDATA[sess.save(cat);\n"
-"sess.flush(); //force the SQL INSERT\n"
-"sess.refresh(cat); //re-read the state (after the trigger executes)]]>"
-msgstr ""
-"<![CDATA[sess.save(cat);\n"
-"sess.flush(); //force the SQL INSERT\n"
-"sess.refresh(cat); //re-read the state (after the trigger executes)]]>"
-
 #. Tag: para
-#: session_api.xml:233
 #, fuzzy, no-c-format
 msgid ""
 "How much does Hibernate load from the database and how many SQL "
 "<literal>SELECT</literal>s will it use? This depends on the "
 "<emphasis>fetching strategy</emphasis>. This is explained in <xref linkend="
-"\"performance-fetching\"/>."
+"\"performance-fetching\" />."
 msgstr ""
-"Una cuesti&#x00f3;n importante aparece usualmente en este punto: ¿Cu&#x00e1;"
-"nto carga Hibernate de la base de datos y cu&#x00e1;ntos <literal>SELECT</"
-"literal>s de SQL usar&#x00e1;? Esto depende de la <emphasis>estrategia de "
-"recuperaci&#x00f3;n</emphasis> y se explica en <xref linkend=\"performance-"
-"fetching\"/>."
+"¿Cuánto carga Hibernate de la base de datos y cuántos <literal>SELECT</"
+"literal>s de SQL utilizará? Esto depende de la <emphasis>estrategia de "
+"recuperación</emphasis>. Esto se explica en la <xref linkend=\"performance-"
+"fetching\" />."
 
 #. Tag: title
-#: session_api.xml:243
 #, no-c-format
 msgid "Querying"
-msgstr "Consultando"
+msgstr "Consultas"
 
 #. Tag: para
-#: session_api.xml:245
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you do not know the identifiers of the objects you are looking for, you "
 "need a query. Hibernate supports an easy-to-use but powerful object oriented "
@@ -508,23 +386,20 @@
 "express your query in the native SQL of your database, with optional support "
 "from Hibernate for result set conversion into objects."
 msgstr ""
-"Si no sabes los identificadores de los objetos que est&#x00e1;s buscando, "
-"necesitas una consulta. Hibernate soporta un lenguaje de consulta orientado "
-"a objetos (HQL) f&#x00e1;cil de usar pero potente. Para la creaci&#x00f3;n "
-"de consultas program&#x00e1;ticas, Hibernate soporta una funcionalidad "
-"sofisticada de consulta de Criteria y Example (QBC and QBE). Tambi&#x00e9;n "
-"puedes expresar tu consulta en el SQL nativo de tu base de datos, con "
-"soporte opcional de Hibernate para la conversi&#x00f3;n del conjunto "
-"resultado en objetos."
+"Si no conoce los identificadores de los objetos que está buscando, necesita "
+"una consulta. Hibernate soporta un lenguaje de consulta orientado a objetos "
+"(HQL) fácil de usar pero potente a la vez. Para la creación de consultas "
+"programáticas, Hibernate soporta una funcionalidad sofisticada de consulta "
+"de Criteria y Example (QBC y QBE). También puede expresar su consulta en el "
+"SQL nativo de su base de datos, con soporte opcional de Hibernate para la "
+"conversión del conjunto de resultados a objetos."
 
 #. Tag: title
-#: session_api.xml:255
 #, no-c-format
 msgid "Executing queries"
-msgstr "Ejecutando consultas"
+msgstr "Ejecución de consultas"
 
 #. Tag: para
-#: session_api.xml:257
 #, no-c-format
 msgid ""
 "HQL and native SQL queries are represented with an instance of <literal>org."
@@ -534,65 +409,14 @@
 "literal>:"
 msgstr ""
 "Las consultas HQL y SQL nativas son representadas con una instancia de "
-"<literal>org.hibernate.Query</literal>. Esta interface ofrece m&#x00e9;todos "
-"para la ligaci&#x00f3;n de par&#x00e1;metros, manejo del conjunto resultado, "
-"y para la ejecuci&#x00f3;n de la consulta real. Siempre obtienes una "
-"<literal>Query</literal> usando la <literal>Session</literal> actual:"
+"<literal>org.hibernate.Query</literal>. Esta interfaz ofrece métodos para "
+"ligar parámetros, manejo del conjunto resultado, y para la ejecución de la "
+"consulta real. Siempre obtiene una <literal>Query</literal> utilizando la "
+"<literal>Session</literal> actual:"
 
-#. Tag: programlisting
-#: session_api.xml:264
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = session.createQuery(\n"
-"    \"from Cat as cat where cat.birthdate < ?\")\n"
-"    .setDate(0, date)\n"
-"    .list();\n"
-"\n"
-"List mothers = session.createQuery(\n"
-"    \"select mother from Cat as cat join cat.mother as mother where cat.name "
-"= ?\")\n"
-"    .setString(0, name)\n"
-"    .list();\n"
-"\n"
-"List kittens = session.createQuery(\n"
-"    \"from Cat as cat where cat.mother = ?\")\n"
-"    .setEntity(0, pk)\n"
-"    .list();\n"
-"\n"
-"Cat mother = (Cat) session.createQuery(\n"
-"    \"select cat.mother from Cat as cat where cat = ?\")\n"
-"    .setEntity(0, izi)\n"
-"    .uniqueResult();]]\n"
-"\n"
-"Query mothersWithKittens = (Cat) session.createQuery(\n"
-"    \"select mother from Cat as mother left join fetch mother.kittens\");\n"
-"Set uniqueMothers = new HashSet(mothersWithKittens.list());]]>"
-msgstr ""
-"<![CDATA[List cats = session.createQuery(\n"
-"    \"from Cat as cat where cat.birthdate < ?\")\n"
-"    .setDate(0, date)\n"
-"    .list();\n"
-"\n"
-"List mothers = session.createQuery(\n"
-"    \"select mother from Cat as cat join cat.mother as mother where cat.name "
-"= ?\")\n"
-"    .setString(0, name)\n"
-"    .list();\n"
-"\n"
-"List kittens = session.createQuery(\n"
-"    \"from Cat as cat where cat.mother = ?\")\n"
-"    .setEntity(0, pk)\n"
-"    .list();\n"
-"\n"
-"Cat mother = (Cat) session.createQuery(\n"
-"    \"select cat.mother from Cat as cat where cat = ?\")\n"
-"    .setEntity(0, izi)\n"
-"    .uniqueResult();]]>"
-
-#. Tag: para
-#: session_api.xml:266
-#, fuzzy, no-c-format
-msgid ""
 "A query is usually executed by invoking <literal>list()</literal>. The "
 "result of the query will be loaded completely into a collection in memory. "
 "Entity instances retrieved by a query are in a persistent state. The "
@@ -602,22 +426,23 @@
 "with their collections initialized. You can filter these duplicates through "
 "a <literal>Set</literal>."
 msgstr ""
-"Una consulta se ejecuta usualmente invocando a <literal>list()</literal>, el "
-"resultado de la consulta ser&#x00e1; cargado completamente dentro de una "
-"colecci&#x00f3;n en memoria. Las instancias de entidad tra&#x00ed;das por "
-"una consulta est&#x00e1;n en estado persistente. El m&#x00e9;todo "
-"<literal>uniqueResult()</literal> ofrece un atajo si sabes que tu consulta "
-"devolver&#x00e1; s&#x00f3;lo un objeto."
+"Una consulta se ejecuta usualmente invocando a <literal>list()</literal>. El "
+"resultado de la consulta será cargado completamente dentro de una colección "
+"en memoria. Las instancias de entidad recuperadas por una consulta se "
+"encuentran en estado persistente. El método <literal>uniqueResult()</"
+"literal> ofrece un atajo si sabe que su consulta retornará sólamente un "
+"objeto. Las consultas que hacen uso de una recuperación temprana de "
+"colecciones usualmente retornan duplicados de los objetos raíz, pero con sus "
+"colecciones inicializadas. Puede filtrar estos duplicados a través de un "
+"<literal>Set</literal>."
 
 #. Tag: title
-#: session_api.xml:278
 #, no-c-format
 msgid "Iterating results"
-msgstr "Iterando los resultados"
+msgstr "Iteración de resultados"
 
 #. Tag: para
-#: session_api.xml:280
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Occasionally, you might be able to achieve better performance by executing "
 "the query using the <literal>iterate()</literal> method. This will usually "
@@ -629,158 +454,54 @@
 "returns identifiers, and <emphasis>n</emphasis> additional selects to "
 "initialize the actual instances."
 msgstr ""
-"Ocasionalmente, podr&#x00ed;as ser capaz de lograr mejor rendimiento al "
-"ejecutar la consulta usando el m&#x00e9;todo <literal>iterate()</literal>. "
-"Esto s&#x00f3;lo ser&#x00e1; en el caso que esperes que las instancias "
-"reales de entidad devueltas por la consulta est&#x00e9;n ya en la "
-"sesi&#x00f3;n o cach&#x00e9; de segundo nivel. Si todav&#x00ed;a no "
-"est&#x00e1;n en cach&#x00e9;, <literal>iterate()</literal> ser&#x00e1; "
-"m&#x00e1;s lento que <literal>list()</literal> y podr&#x00ed;a requerir "
-"muchas llamadas a la base de datos para una consulta simple, usualmente "
-"<emphasis>1</emphasis> para la selecci&#x00f3;n inicial que solamente "
-"devuelve identificadores, y <emphasis>n</emphasis> selecciones adicionales "
-"para inicializar las instancias reales."
+"Ocasionalmente, puede lograr un mejor rendimiento al ejecutar la consulta "
+"utilizando el método <literal>iterate()</literal>. Esto ocurrirá usualmente "
+"si espera que las instancias reales de entidad retornadas por la consulta "
+"estén ya en la sesión o en el caché de segundo nivel. Si todavía no están en "
+"caché, <literal>iterate()</literal> será más lento que <literal>list()</"
+"literal> y podría requerir muchas llamadas a la base de datos para una "
+"consulta simple, usualmente <emphasis>1</emphasis> para la selección inicial "
+"que sólamente retorna identificadores y <emphasis>n</emphasis> selecciones "
+"adicionales para inicializar las instancias reales."
 
-#. Tag: programlisting
-#: session_api.xml:292
-#, no-c-format
-msgid ""
-"<![CDATA[// fetch ids\n"
-"Iterator iter = sess.createQuery(\"from eg.Qux q order by q.likeliness\")."
-"iterate();\n"
-"while ( iter.hasNext() ) {\n"
-"    Qux qux = (Qux) iter.next();  // fetch the object\n"
-"    // something we couldnt express in the query\n"
-"    if ( qux.calculateComplicatedAlgorithm() ) {\n"
-"        // delete the current instance\n"
-"        iter.remove();\n"
-"        // dont need to process the rest\n"
-"        break;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-"<![CDATA[// fetch ids\n"
-"Iterator iter = sess.createQuery(\"from eg.Qux q order by q.likeliness\")."
-"iterate();\n"
-"while ( iter.hasNext() ) {\n"
-"    Qux qux = (Qux) iter.next();  // fetch the object\n"
-"    // something we couldnt express in the query\n"
-"    if ( qux.calculateComplicatedAlgorithm() ) {\n"
-"        // delete the current instance\n"
-"        iter.remove();\n"
-"        // dont need to process the rest\n"
-"        break;\n"
-"    }\n"
-"}]]>"
-
 #. Tag: title
-#: session_api.xml:296
 #, no-c-format
 msgid "Queries that return tuples"
 msgstr "Consultas que devuelven tuplas"
 
 #. Tag: para
-#: session_api.xml:298
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate queries sometimes return tuples of objects. Each tuple is returned "
 "as an array:"
 msgstr ""
-"Las consultas de Hibernate a veces devuelven tuplas de objetos, en cuyo caso "
-"cada tupla se devuelve como un array:"
+"Las consultas de Hibernate a veces retornan tuplas de objetos. Cada tupla se "
+"retorna como un array:"
 
-#. Tag: programlisting
-#: session_api.xml:303
-#, no-c-format
-msgid ""
-"<![CDATA[Iterator kittensAndMothers = sess.createQuery(\n"
-"            \"select kitten, mother from Cat kitten join kitten.mother mother"
-"\")\n"
-"            .list()\n"
-"            .iterator();\n"
-"\n"
-"while ( kittensAndMothers.hasNext() ) {\n"
-"    Object[] tuple = (Object[]) kittensAndMothers.next();\n"
-"    Cat kitten = (Cat) tuple[0];\n"
-"    Cat mother = (Cat) tuple[1];\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-"<![CDATA[Iterator kittensAndMothers = sess.createQuery(\n"
-"            \"select kitten, mother from Cat kitten join kitten.mother mother"
-"\")\n"
-"            .list()\n"
-"            .iterator();\n"
-"\n"
-"while ( kittensAndMothers.hasNext() ) {\n"
-"    Object[] tuple = (Object[]) kittensAndMothers.next();\n"
-"    Cat kitten = (Cat) tuple[0];\n"
-"    Cat mother = (Cat) tuple[1];\n"
-"    ....\n"
-"}]]>"
-
 #. Tag: title
-#: session_api.xml:308
 #, no-c-format
 msgid "Scalar results"
 msgstr "Resultados escalares"
 
 #. Tag: para
-#: session_api.xml:310
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Queries can specify a property of a class in the <literal>select</literal> "
 "clause. They can even call SQL aggregate functions. Properties or aggregates "
 "are considered \"scalar\" results and not entities in persistent state."
 msgstr ""
-"Las consultas pueden especificar una propiedad de una clase en la cl&#x00e1;"
-"usula <literal>select</literal>. Pueden incluso llamar a funciones de "
-"agregaci&#x00f3;n SQL. Las propiedades o agregaciones son considerados "
-"resultados \"escalares\" (y no entidades en estado persistente)."
+"Las consultas pueden especificar una propiedad de una clase en la cláusula "
+"<literal>select</literal>. Pueden incluso llamar a funciones de agregación "
+"SQL. Las propiedades o agregaciones son considerados resultados \"escalares"
+"\" y no entidades en estado persistente."
 
-#. Tag: programlisting
-#: session_api.xml:316
-#, no-c-format
-msgid ""
-"<![CDATA[Iterator results = sess.createQuery(\n"
-"        \"select cat.color, min(cat.birthdate), count(cat) from Cat cat \" "
-"+\n"
-"        \"group by cat.color\")\n"
-"        .list()\n"
-"        .iterator();\n"
-"\n"
-"while ( results.hasNext() ) {\n"
-"    Object[] row = (Object[]) results.next();\n"
-"    Color type = (Color) row[0];\n"
-"    Date oldest = (Date) row[1];\n"
-"    Integer count = (Integer) row[2];\n"
-"    .....\n"
-"}]]>"
-msgstr ""
-"<![CDATA[Iterator results = sess.createQuery(\n"
-"        \"select cat.color, min(cat.birthdate), count(cat) from Cat cat \" "
-"+\n"
-"        \"group by cat.color\")\n"
-"        .list()\n"
-"        .iterator();\n"
-"\n"
-"while ( results.hasNext() ) {\n"
-"    Object[] row = results.next();\n"
-"    Color type = (Color) row[0];\n"
-"    Date oldest = (Date) row[1];\n"
-"    Integer count = (Integer) row[2];\n"
-"    .....\n"
-"}]]>"
-
 #. Tag: title
-#: session_api.xml:321
 #, no-c-format
 msgid "Bind parameters"
-msgstr "Ligaci&#x00f3;n de par&#x00e1;metros"
+msgstr "Ligado de parámetros"
 
 #. Tag: para
-#: session_api.xml:323
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Methods on <literal>Query</literal> are provided for binding values to named "
 "parameters or JDBC-style <literal>?</literal> parameters. <emphasis>Contrary "
@@ -788,290 +509,121 @@
 "are identifiers of the form <literal>:name</literal> in the query string. "
 "The advantages of named parameters are as follows:"
 msgstr ""
-"Se proveen m&#x00e9;todos en <literal>Query</literal> para ligar valores a "
-"par&#x00e1;metros con nombre o par&#x00e1;metros <literal>?</literal> de "
-"estilo JDBC. <emphasis>Al contrario de JDBC, Hibernate numera los par&#x00e1;"
-"metros desde cero.</emphasis> Los par&#x00e1;metros con nombre son "
-"identificadores de la forma <literal>:name</literal> en la cadena de la "
-"consulta. Las ventajas de los par&#x00e1;metros con nombre son:"
+"Los métodos en <literal>Query</literal> se proporcionan para enlazar valores "
+"a los parámetros con nombre o parámetros <literal>?</literal> de estilo "
+"JDBC. <emphasis>Al contrario de JDBC, Hibernate numera los parámetros desde "
+"cero.</emphasis> Los parámetros con nombre son identificadores de la forma "
+"<literal>:name</literal> en la cadena de la consulta. Las ventajas de los "
+"parámetros con nombre son las siguientes:"
 
 #. Tag: para
-#: session_api.xml:333
 #, no-c-format
 msgid ""
 "named parameters are insensitive to the order they occur in the query string"
 msgstr ""
-"los par&#x00e1;metros con nombre son insensibles al orden en que aparecen en "
-"la cadena de consulta"
+"los parámetros con nombre son insensibles al orden en que aparecen en la "
+"cadena de consulta"
 
 #. Tag: para
-#: session_api.xml:339
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "they can occur multiple times in the same query"
-msgstr "pueden aparecer m&#x00fa;ltiples veces en la misma consulta"
+msgstr "pueden aparecer múltiples veces en la misma petición"
 
 #. Tag: para
-#: session_api.xml:344
 #, no-c-format
 msgid "they are self-documenting"
 msgstr "son auto-documentados"
 
-#. Tag: programlisting
-#: session_api.xml:350
-#, no-c-format
-msgid ""
-"<![CDATA[//named parameter (preferred)\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name = :name"
-"\");\n"
-"q.setString(\"name\", \"Fritz\");\n"
-"Iterator cats = q.iterate();]]>"
-msgstr ""
-"<![CDATA[//named parameter (preferred)\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name = :name"
-"\");\n"
-"q.setString(\"name\", \"Fritz\");\n"
-"Iterator cats = q.iterate();]]>"
-
-#. Tag: programlisting
-#: session_api.xml:352
-#, no-c-format
-msgid ""
-"<![CDATA[//positional parameter\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name = ?\");\n"
-"q.setString(0, \"Izi\");\n"
-"Iterator cats = q.iterate();]]>"
-msgstr ""
-"<![CDATA[//positional parameter\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name = ?\");\n"
-"q.setString(0, \"Izi\");\n"
-"Iterator cats = q.iterate();]]>"
-
-#. Tag: programlisting
-#: session_api.xml:354
-#, no-c-format
-msgid ""
-"<![CDATA[//named parameter list\n"
-"List names = new ArrayList();\n"
-"names.add(\"Izi\");\n"
-"names.add(\"Fritz\");\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name in (:"
-"namesList)\");\n"
-"q.setParameterList(\"namesList\", names);\n"
-"List cats = q.list();]]>"
-msgstr ""
-"<![CDATA[//named parameter list\n"
-"List names = new ArrayList();\n"
-"names.add(\"Izi\");\n"
-"names.add(\"Fritz\");\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name in (:"
-"namesList)\");\n"
-"q.setParameterList(\"namesList\", names);\n"
-"List cats = q.list();]]>"
-
 #. Tag: title
-#: session_api.xml:359
 #, no-c-format
 msgid "Pagination"
-msgstr "Paginaci&#x00f3;n"
+msgstr "Paginación"
 
 #. Tag: para
-#: session_api.xml:361
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you need to specify bounds upon your result set, that is, the maximum "
 "number of rows you want to retrieve and/or the first row you want to "
 "retrieve, you can use methods of the <literal>Query</literal> interface:"
 msgstr ""
-"Si necesitas especificar l&#x00ed;mites sobre tu conjunto resultado (el "
-"n&#x00fa;mero m&#x00e1;ximo de filas que quieras traer y/o la primera fila "
-"que quieras traer) debes usar los m&#x00e9;todos de la interface "
-"<literal>Query</literal>:"
+"Si necesita especificar enlaces sobre su conjunto de resultados, el número "
+"máximo de filas que quiere recuperar y/o la primera fila que quiere "
+"recuperar, puede utilizar los métodos de la interfaz <literal>Query</"
+"literal>:"
 
-#. Tag: programlisting
-#: session_api.xml:367
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = sess.createQuery(\"from DomesticCat cat\");\n"
-"q.setFirstResult(20);\n"
-"q.setMaxResults(10);\n"
-"List cats = q.list();]]>"
-msgstr ""
-"<![CDATA[Query q = sess.createQuery(\"from DomesticCat cat\");\n"
-"q.setFirstResult(20);\n"
-"q.setMaxResults(10);\n"
-"List cats = q.list();]]>"
-
 #. Tag: para
-#: session_api.xml:369
 #, no-c-format
 msgid ""
 "Hibernate knows how to translate this limit query into the native SQL of "
 "your DBMS."
 msgstr ""
-"Hibernate sabe c&#x00f3;mo traducir este l&#x00ed;mite de consulta al SQL "
-"nativo de tu DBMS."
+"Hibernate sabe cómo traducir este límite de consulta al SQL nativo de su "
+"DBMS."
 
 #. Tag: title
-#: session_api.xml:377
 #, no-c-format
 msgid "Scrollable iteration"
-msgstr "Iteraci&#x00f3;n scrollable"
+msgstr "Iteración deslizable"
 
 #. Tag: para
-#: session_api.xml:379
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your JDBC driver supports scrollable <literal>ResultSet</literal>s, the "
 "<literal>Query</literal> interface can be used to obtain a "
 "<literal>ScrollableResults</literal> object that allows flexible navigation "
 "of the query results."
 msgstr ""
-"Si tu driver JDBC soporta <literal>ResultSet</literal>s scrollables, la "
-"interface <literal>Query</literal> puede ser usada para obtener un objeto "
-"<literal>ScrollableResults</literal>, que permite una navegaci&#x00f3;n "
-"flexible de los resultados de consulta."
+"Si su controlador JDBC soporta <literal>ResultSet</literal>s deslizables, la "
+"interfaz <literal>Query</literal> se puede utilizar para obtener un objeto "
+"<literal>ScrollableResults</literal> que permite una navegación flexible de "
+"los resultados de consulta. "
 
-#. Tag: programlisting
-#: session_api.xml:386
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Query q = sess.createQuery(\"select cat.name, cat from DomesticCat "
-"cat \" +\n"
-"                            \"order by cat.name\");\n"
-"ScrollableResults cats = q.scroll();\n"
-"if ( cats.first() ) {\n"
-"\n"
-"    // find the first name on each page of an alphabetical list of cats by "
-"name\n"
-"    firstNamesOfPages = new ArrayList();\n"
-"    do {\n"
-"        String name = cats.getString(0);\n"
-"        firstNamesOfPages.add(name);\n"
-"    }\n"
-"    while ( cats.scroll(PAGE_SIZE) );\n"
-"\n"
-"    // Now get the first page of cats\n"
-"    pageOfCats = new ArrayList();\n"
-"    cats.beforeFirst();\n"
-"    int i=0;\n"
-"    while( ( PAGE_SIZE > i++ ) && cats.next() ) pageOfCats.add( cats.get"
-"(1) );\n"
-"\n"
-"}\n"
-"cats.close()]]>"
-msgstr ""
-"<![CDATA[Query q = sess.createQuery(\"select cat.name, cat from DomesticCat "
-"cat \" +\n"
-"                            \"order by cat.name\");\n"
-"ScrollableResults cats = q.scroll();\n"
-"if ( cats.first() ) {\n"
-"\n"
-"    // find the first name on each page of an alphabetical list of cats by "
-"name\n"
-"    firstNamesOfPages = new ArrayList();\n"
-"    do {\n"
-"        String name = cats.getString(0);\n"
-"        firstNamesOfPages.add(name);\n"
-"    }\n"
-"    while ( cats.scroll(PAGE_SIZE) );\n"
-"\n"
-"    // Now get the first page of cats\n"
-"    pageOfCats = new ArrayList();\n"
-"    cats.beforeFirst();\n"
-"    int i=0;\n"
-"    while( ( PAGE_SIZE > i++ ) && cats.next() ) pageOfCats.add( cats.get"
-"(1) );\n"
-"\n"
-"}\n"
-"cats.close()]]>"
-
-#. Tag: para
-#: session_api.xml:388
-#, fuzzy, no-c-format
-msgid ""
 "Note that an open database connection and cursor is required for this "
 "functionality. Use <literal>setMaxResult()</literal>/<literal>setFirstResult"
 "()</literal> if you need offline pagination functionality."
 msgstr ""
-"Nota que se requiere una conexi&#x00f3;n de base de datos abierta (y cursor) "
-"para esta funcionalidad, usa <literal>setMaxResult()</literal>/"
-"<literal>setFirstResult()</literal> si necesitas la funcionalidad de "
-"paginaci&#x00f3;n fuera de l&#x00ed;nea."
+"Note que se requiere una conexión de base de datos abierta y un cursor para "
+"esta funcionalidad. Utilice <literal>setMaxResult()</literal>/"
+"<literal>setFirstResult()</literal> si necesita la funcionalidad de "
+"paginación fuera de línea."
 
 #. Tag: title
-#: session_api.xml:397
 #, no-c-format
 msgid "Externalizing named queries"
-msgstr "Externalizando consultas con nombre"
+msgstr "Externalización de consultas con nombre"
 
 #. Tag: para
-#: session_api.xml:399
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also define named queries in the mapping document. Remember to use a "
 "<literal>CDATA</literal> section if your query contains characters that "
 "could be interpreted as markup."
 msgstr ""
-"Puedes adem&#x00e1;s definir consultas con nombre en el documento de mapeo. "
-"(Recuerda usar una secci&#x00f3;n <literal>CDATA</literal> si tu consulta "
-"contiene caracteres que puedan ser interpretados como etiquetado.)"
+"También puede definir consultas con nombre en el documento de mapeo. "
+"Recuerde utilizar una sección <literal>CDATA</literal> si su consulta "
+"contiene caracteres que puedan ser interpretados como etiquetado."
 
-#. Tag: programlisting
-#: session_api.xml:405
-#, no-c-format
-msgid ""
-"<![CDATA[<query name=\"ByNameAndMaximumWeight\"><![CDATA[\n"
-"    from eg.DomesticCat as cat\n"
-"        where cat.name = ?\n"
-"        and cat.weight > ?\n"
-"] ]></query>]]>"
-msgstr ""
-"<![CDATA[<query name=\"eg.DomesticCat.by.name.and.minimum.weight\"><![CDATA"
-"[\n"
-"    from eg.DomesticCat as cat\n"
-"        where cat.name = ?\n"
-"        and cat.weight > ?\n"
-"] ]></query>]]>"
-
 #. Tag: para
-#: session_api.xml:407
 #, no-c-format
 msgid "Parameter binding and executing is done programatically:"
-msgstr ""
-"La ligaci&#x00f3;n de par&#x00e1;metros y ejecuci&#x00f3;n se hace "
-"program&#x00e1;ticamente:"
+msgstr "El ligado de parámetros y de ejecución se realiza programáticamente:"
 
-#. Tag: programlisting
-#: session_api.xml:411
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Query q = sess.getNamedQuery(\"ByNameAndMaximumWeight\");\n"
-"q.setString(0, name);\n"
-"q.setInt(1, minWeight);\n"
-"List cats = q.list();]]>"
-msgstr ""
-"<![CDATA[Query q = sess.getNamedQuery(\"eg.DomesticCat.by.name.and.minimum."
-"weight\");\n"
-"q.setString(0, name);\n"
-"q.setInt(1, minWeight);\n"
-"List cats = q.list();]]>"
-
-#. Tag: para
-#: session_api.xml:413
-#, fuzzy, no-c-format
-msgid ""
 "The actual program code is independent of the query language that is used. "
 "You can also define native SQL queries in metadata, or migrate existing "
 "queries to Hibernate by placing them in mapping files."
 msgstr ""
-"Nota que el c&#x00f3;digo real del programa es independiente del lenguaje de "
-"consulta usado; puedes adem&#x00e1;s definir consultas SQL nativas en "
-"metadatos, o migrar consultas existentes a Hibernate coloc&#x00e1;ndolas en "
-"ficheros de mapeo."
+"El código real del programa es independiente del lenguaje de consulta "
+"utilizado. También puede definir consultas SQL nativas en metadatos, o "
+"migrar consultas existentes a Hibernate colocándolas en archivos de mapeo."
 
 #. Tag: para
-#: session_api.xml:419
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Also note that a query declaration inside a <literal>&lt;hibernate-"
 "mapping&gt;</literal> element requires a global unique name for the query, "
@@ -1079,123 +631,69 @@
 "is made unique automatically by prepending the fully qualified name of the "
 "class. For example <literal>eg.Cat.ByNameAndMaximumWeight</literal>."
 msgstr ""
-"UNTRANSLATED! Also note that a query declaration inside a <literal>&lt;"
-"hibernate-mapping&gt;</literal> element requires a global unique name for "
-"the query, while a query declaration inside a <literal>&lt;class&gt;</"
-"literal> element is made unique automatically by prepending the fully "
-"qualified name of the class, for example <literal>eg.Cat."
-"ByNameAndMaximumWeight</literal>."
+"Observe además que una declaración de consulta dentro de un elemento "
+"<literal>&lt;hibernate-mapping&gt;</literal> necesita de un nombre único "
+"global para la consulta, mientras que una declaración de consulta dentro de "
+"un elemento <literal>&lt;class&gt;</literal> se hace única automáticamente "
+"al agregar el nombre completamente calificado de la clase. Por ejemplo, "
+"<literal>eg.Cat.ByNameAndMaximumWeight</literal>."
 
 #. Tag: title
-#: session_api.xml:432
 #, no-c-format
 msgid "Filtering collections"
-msgstr "Filtrando colecciones"
+msgstr "Filtración de colecciones"
 
 #. Tag: para
-#: session_api.xml:433
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A collection <emphasis>filter</emphasis> is a special type of query that can "
 "be applied to a persistent collection or array. The query string can refer "
 "to <literal>this</literal>, meaning the current collection element."
 msgstr ""
-"Un <emphasis>filtro</emphasis> de colecci&#x00f3;n es un tipo especial de "
-"consulta que puede ser aplicado a una colecci&#x00f3;n persistente o array. "
-"La cadena de consulta puede referirse a <literal>this</literal>, "
-"significando el elemento de colecci&#x00f3;n actual."
+"Un <emphasis>filtro</emphasis> de colección es un tipo especial de consulta "
+"que puede ser aplicado a una colección persistente o array. La cadena de "
+"consulta puede referirse a <literal>this</literal>, lo que quiere decir el "
+"elemento de la colección actual."
 
-#. Tag: programlisting
-#: session_api.xml:439
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Collection blackKittens = session.createFilter(\n"
-"    pk.getKittens(), \n"
-"    \"where this.color = ?\")\n"
-"    .setParameter( Color.BLACK, Hibernate.custom(ColorUserType.class) )\n"
-"    .list()\n"
-");]]>"
-msgstr ""
-"<![CDATA[Collection blackKittens = session.createFilter(\n"
-"    pk.getKittens(), \n"
-"    \"where this.color = ?\")\n"
-"    .setParameter( Color.BLACK, Hibernate.custom(ColorUserType.class) )\n"
-"    .list()\n"
-");]]>"
-
-#. Tag: para
-#: session_api.xml:441
-#, fuzzy, no-c-format
-msgid ""
 "The returned collection is considered a bag that is a copy of the given "
 "collection. The original collection is not modified. This is contrary to the "
 "implication of the name \"filter\", but consistent with expected behavior."
 msgstr ""
-"La colecci&#x00f3;n devuelta es considerada un bag, y es una copia de la "
-"colecci&#x00f3;n dada. La colecci&#x00f3;n original no es modificada (esto "
-"es contrario a la implicaci&#x00f3;n del nombre \"filtro\", pero consistente "
-"con el comportamiento esperado)."
+"La colección devuelta es considerada un bag, y es una copia de la colección "
+"dada. La colección original no es modificada. Esto es lo opuesto a lo que "
+"implica el nombre \"filtro\", pero es consistente con el comportamiento "
+"esperado."
 
 #. Tag: para
-#: session_api.xml:447
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Observe that filters do not require a <literal>from</literal> clause, "
 "although they can have one if required. Filters are not limited to returning "
 "the collection elements themselves."
 msgstr ""
-"Observa que los filtros no requieren una cl&#x00e1;usula <literal>from</"
-"literal> (aunque pueden tener uno si se requiere). Los filtros no est&#x00e1;"
-"n limitados a devolver los elementos de colecci&#x00f3;n por s&#x00ed; "
-"mismos."
+"Observe que los filtros no requieren una cláusula <literal>from</literal> "
+"aunque pueden tener una si se necesita. Los filtros no están limitados a "
+"devolver los elementos de colección por sí mismos."
 
-#. Tag: programlisting
-#: session_api.xml:452
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Collection blackKittenMates = session.createFilter(\n"
-"    pk.getKittens(), \n"
-"    \"select this.mate where this.color = eg.Color.BLACK.intValue\")\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[Collection blackKittenMates = session.createFilter(\n"
-"    pk.getKittens(), \n"
-"    \"select this.mate where this.color = eg.Color.BLACK.intValue\")\n"
-"    .list();]]>"
-
-#. Tag: para
-#: session_api.xml:454
-#, fuzzy, no-c-format
-msgid ""
 "Even an empty filter query is useful, e.g. to load a subset of elements in a "
 "large collection:"
 msgstr ""
-"Incluso una consulta de filtro vac&#x00ed;o es &#x00fa;til, por ejemplo, "
-"para cargar un subconjunto de elementos en una colecci&#x00f3;n enorme:"
+"Incluso una consulta de filtro vacío es útil, por ejemplo, para cargar un "
+"subconjunto de elementos en una colección enorme: "
 
-#. Tag: programlisting
-#: session_api.xml:459
-#, no-c-format
-msgid ""
-"<![CDATA[Collection tenKittens = session.createFilter(\n"
-"    mother.getKittens(), \"\")\n"
-"    .setFirstResult(0).setMaxResults(10)\n"
-"    .list();]]>"
-msgstr ""
-"<![CDATA[Collection tenKittens = session.createFilter(\n"
-"    mother.getKittens(), \"\")\n"
-"    .setFirstResult(0).setMaxResults(10)\n"
-"    .list();]]>"
-
 #. Tag: title
-#: session_api.xml:464
 #, no-c-format
 msgid "Criteria queries"
 msgstr "Consultas de criterios"
 
 #. Tag: para
-#: session_api.xml:466
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL is extremely powerful, but some developers prefer to build queries "
 "dynamically using an object-oriented API, rather than building query "
@@ -1203,45 +701,27 @@
 "API for these cases:"
 msgstr ""
 "HQL es extremadamente potente pero algunos desarrolladores prefieren "
-"construir consultas din&#x00e1;micamente usando una API orientada a objetos, "
-"en vez construir cadenas de consulta. Hibernate provee una API intuitiva de "
-"consulta <literal>Criteria</literal> para estos casos:"
+"construir consultas dinámicamente utilizando una API orientada a objetos, en "
+"vez de construir cadenas de consulta. Hibernate brinda una API intuitiva de "
+"consulta <literal>Criteria</literal> para estos casos: "
 
-#. Tag: programlisting
-#: session_api.xml:472
-#, no-c-format
-msgid ""
-"<![CDATA[Criteria crit = session.createCriteria(Cat.class);\n"
-"crit.add( Restrictions.eq( \"color\", eg.Color.BLACK ) );\n"
-"crit.setMaxResults(10);\n"
-"List cats = crit.list();]]>"
-msgstr ""
-"<![CDATA[Criteria crit = session.createCriteria(Cat.class);\n"
-"crit.add( Restrictions.eq( \"color\", eg.Color.BLACK ) );\n"
-"crit.setMaxResults(10);\n"
-"List cats = crit.list();]]>"
-
 #. Tag: para
-#: session_api.xml:474
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The <literal>Criteria</literal> and the associated <literal>Example</"
-"literal> API are discussed in more detail in <xref linkend=\"querycriteria\"/"
-">."
+"literal> API are discussed in more detail in <xref linkend=\"querycriteria"
+"\" />."
 msgstr ""
-"Las APIs de <literal>Criteria</literal> y la asociada <literal>Example</"
-"literal> son discutidas en m&#x00e1;s detalle en <xref linkend="
-"\"querycriteria\"/>."
+"Las APIs de <literal>Criteria</literal> y el <literal>Example</literal> "
+"asociado se discuten en más detalle en el xref linkend=\"querycriteria\" />."
 
 #. Tag: title
-#: session_api.xml:482
 #, no-c-format
 msgid "Queries in native SQL"
 msgstr "Consultas en SQL nativo"
 
 #. Tag: para
-#: session_api.xml:484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can express a query in SQL, using <literal>createSQLQuery()</literal> "
 "and let Hibernate manage the mapping from result sets to objects. You can at "
@@ -1249,69 +729,31 @@
 "<literal>Connection</literal> directly. If you choose to use the Hibernate "
 "API, you must enclose SQL aliases in braces:"
 msgstr ""
-"Puedes expresar una consulta en SQL, usando <literal>createSQLQuery()</"
-"literal> y dejando que Hibernate cuide del mapeo de los conjuntos resultado "
-"a objetos. Nota que puedes llamar en cualquier momento a <literal>session."
-"connection()</literal> y usar la <literal>Connection</literal> JDBC "
-"directamente. Si eliges usar la API de Hibernate, debes encerrar los alias "
-"de SQL entre llaves:"
+"Puede expresar una consulta en SQL, utilizando <literal>createSQLQuery()</"
+"literal> y dejar que Hibernate administre el mapeo de los conjuntos de "
+"resultados a objetos. Puede llamar en cualquier momento a <literal>session."
+"connection()</literal> y utilizar la <literal>Connection</literal> JDBC "
+"directamente. Si elige usar la API de Hibernate, tiene que encerrar los "
+"alias de SQL entre llaves:"
 
-#. Tag: programlisting
-#: session_api.xml:492
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = session.createSQLQuery(\"SELECT {cat.*} FROM CAT {cat} "
-"WHERE ROWNUM<10\")\n"
-"    .addEntity(\"cat\", Cat.class)\n"
-".list();]]>"
-msgstr ""
-"<![CDATA[List cats = session.createSQLQuery(\"SELECT {cat.*} FROM CAT {cat} "
-"WHERE ROWNUM<10\")\n"
-"    .addEntity(\"cat\", Cat.class)\n"
-".list();]]>"
-
-#. Tag: programlisting
-#: session_api.xml:494
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = session.createSQLQuery(\n"
-"    \"SELECT {cat}.ID AS {cat.id}, {cat}.SEX AS {cat.sex}, \" +\n"
-"           \"{cat}.MATE AS {cat.mate}, {cat}.SUBCLASS AS {cat.class}, ... \" "
-"+\n"
-"    \"FROM CAT {cat} WHERE ROWNUM<10\")\n"
-"    .addEntity(\"cat\", Cat.class)\n"
-".list()]]>"
-msgstr ""
-"<![CDATA[List cats = session.createSQLQuery(\n"
-"    \"SELECT {cat}.ID AS {cat.id}, {cat}.SEX AS {cat.sex}, \" +\n"
-"           \"{cat}.MATE AS {cat.mate}, {cat}.SUBCLASS AS {cat.class}, ... \" "
-"+\n"
-"    \"FROM CAT {cat} WHERE ROWNUM<10\")\n"
-"    .addEntity(\"cat\", Cat.class)\n"
-".list()]]>"
-
 #. Tag: para
-#: session_api.xml:496
 #, fuzzy, no-c-format
 msgid ""
 "SQL queries can contain named and positional parameters, just like Hibernate "
 "queries. More information about native SQL queries in Hibernate can be found "
-"in <xref linkend=\"querysql\"/>."
+"in <xref linkend=\"querysql\" />."
 msgstr ""
-"Las consultas SQL pueden contener par&#x00e1;metros con nombre y "
-"posicionales, al igual que las consultas de Hibernate. Puede encontrarse "
-"m&#x00e1;s informaci&#x00f3;n sobre consultas en SQL nativo en <xref linkend="
-"\"querysql\"/>."
+"Las consultas SQL pueden contener parámetros con nombre y posicionados, al "
+"igual que las consultas de Hibernate. Puede encontrar más información sobre "
+"las consultas en SQL nativo en Hibernate en el <xref linkend=\"querysql\" />."
 
 #. Tag: title
-#: session_api.xml:507
 #, no-c-format
 msgid "Modifying persistent objects"
-msgstr "Modificando objetos persistentes"
+msgstr "Modificación de objetos persistentes"
 
 #. Tag: para
-#: session_api.xml:509
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Transactional persistent instances</emphasis> (i.e. objects "
 "loaded, saved, created or queried by the <literal>Session</literal>) can be "
@@ -1323,49 +765,33 @@
 "to update the state of an object is to <literal>load()</literal> it and then "
 "manipulate it directly while the <literal>Session</literal> is open:"
 msgstr ""
-"Las <emphasis>instancias persistentes transaccionales</emphasis> (es decir, "
-"objetos cargados, creados o consultados por la <literal>Session</literal>) "
-"pueden ser manipulados por la aplicaci&#x00f3;n y cualquier cambio al estado "
-"persistente ser&#x00e1; persistido cuando la <literal>Session</literal> sea "
-"<emphasis>limpiada (flushed)</emphasis> (discutido m&#x00e1;s adelante en "
-"este cap&#x00ed;tulo). No hay necesidad de llamar un m&#x00e9;todo en "
-"particular (como <literal>update()</literal>, que tiene un prop&#x00f3;sito "
-"diferente) para hacer persistentes tus modificaciones. De modo que la forma "
-"m&#x00e1;s directa de actualizar el estado de un objeto es cargarlo con "
-"<literal>load()</literal>, y entonces manipularlo directamente, mientras la "
-"<literal>Session</literal> est&#x00e1; abierta:"
+"Las <emphasis>instancias persistentes transaccionales</emphasis> (por "
+"ejemplo, los objetos cargados, creados o consultados por la "
+"<literal>Session</literal>) pueden ser manipulados por la aplicación y "
+"cualquier cambio al estado persistente será persistido cuando se "
+"<emphasis>vacie</emphasis> la <literal>Session</literal>. Esto se discute "
+"más adelante en este capítulo. No hay necesidad de llamar a un método en "
+"particular (como <literal>update()</literal>, que tiene un propósito "
+"diferente) para hacer persistentes sus modificaciones. De modo que la forma "
+"más directa de actualizar el estado de un objeto es cargarlo con "
+"<literal>load()</literal> y luego manipularlo directamente, mientras la "
+"<literal>Session</literal> está abierta:"
 
-#. Tag: programlisting
-#: session_api.xml:520
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DomesticCat cat = (DomesticCat) sess.load( Cat.class, new Long"
-"(69) );\n"
-"cat.setName(\"PK\");\n"
-"sess.flush();  // changes to cat are automatically detected and persisted]]>"
-msgstr ""
-"<![CDATA[DomesticCat cat = (DomesticCat) sess.load( Cat.class, new Long"
-"(69) );\n"
-"cat.setName(\"PK\");\n"
-"sess.flush();  // changes to cat are automatically detected and persisted]]>"
-
-#. Tag: para
-#: session_api.xml:522
-#, fuzzy, no-c-format
-msgid ""
 "Sometimes this programming model is inefficient, as it requires in the same "
 "session both an SQL <literal>SELECT</literal> to load an object and an SQL "
 "<literal>UPDATE</literal> to persist its updated state. Hibernate offers an "
 "alternate approach by using detached instances."
 msgstr ""
-"A veces este modelo de programaci&#x00f3;n es ineficiente pues podr&#x00ed;a "
-"requerir una <literal>SELECT</literal> de SQL (para cargar un objeto) y un "
-"<literal>UPDATE</literal> de SQL (para hacer persistentes sus datos "
-"actualizados) en la misma sesi&#x00f3;n. Por lo tanto, Hibernate ofrece un "
-"enfoque alternativo, usando instancias separadas (detached)."
+"A veces este modelo de programación es ineficiente pues requiere un "
+"<literal>SELECT</literal> de SQL para cargar un objeto y un <literal>UPDATE</"
+"literal> de SQL para hacer persistente su estado actualizado en la misma "
+"sesión. Por lo tanto, Hibernate ofrece un enfoque opcional, utilizando "
+"instancias separadas."
 
 #. Tag: para
-#: session_api.xml:529
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate does not offer its own API for direct execution of "
@@ -1377,29 +803,27 @@
 "the notion of mass operations conflicts with object/relational mapping for "
 "online transaction processing-oriented applications. Future versions of "
 "Hibernate can, however, provide special mass operation functions. See <xref "
-"linkend=\"batch\"/> for some possible batch operation tricks."
+"linkend=\"batch\" /> for some possible batch operation tricks."
 msgstr ""
-"Nota que Hibernate no ofreve su propia API para ejecuci&#x00f3;n directa de "
-"sentencias <literal>UPDATE</literal> o <literal>DELETE</literal>. Hibernate "
-"es un servicio de <emphasis>gesti&#x00f3;n de estado</emphasis>, no tienes "
-"que pensar en <literal>sentencias</literal> para usarlo. JDBC es una API "
-"perfecta para ejecutar sentencias SQL; puedes obtener una "
+"Hibernate no ofrece su propia API para ejecución directa de declaraciones "
+"<literal>UPDATE</literal> o <literal>DELETE</literal>. Hibernate es un "
+"servicio de <emphasis>administración de estado</emphasis>, no tiene que "
+"pensar en <emphasis>declaraciones</emphasis> para poder utilizarlo. JDBC es "
+"una API perfecta para ejecutar declaraciones SQL; puede obtener una "
 "<literal>Connection</literal> JDBC en cualquier momento llamando a "
-"<literal>session.connection()</literal>. Adem&#x00e1;s, la noci&#x00f3;n de "
-"operaciones masivas entra en conflicto con el mapeo objeto/relacional en "
-"aplicaciones en l&#x00ed;nea orientadas al procesamiento de transacciones. "
-"Versiones futuras de Hibernate pueden, sin embargo, proveer funciones de "
-"operaci&#x00f3;n masiva especiales. Ver <xref linkend=\"batch\"/> por "
-"algunos trucos de operaci&#x00f3;n en lote (batch) posibles."
+"<literal>session.connection()</literal>. Además, la noción de operaciones "
+"masivas entra en conflicto con el mapeo objeto/relacional en aplicaciones en "
+"línea orientadas al procesamiento de transacciones. Sin embargo, las "
+"versiones futuras de Hibernate podrán proporcionar funciones de operación "
+"masiva especiales. Consulte <xref linkend=\"batch\"/> para obtener algunos "
+"trucos posibles para la operación en lote."
 
 #. Tag: title
-#: session_api.xml:546
 #, no-c-format
 msgid "Modifying detached objects"
-msgstr "Modificando objetos separados"
+msgstr "Modificación de objetos separados"
 
 #. Tag: para
-#: session_api.xml:548
 #, no-c-format
 msgid ""
 "Many applications need to retrieve an object in one transaction, send it to "
@@ -1408,54 +832,24 @@
 "environment usually use versioned data to ensure isolation for the \"long\" "
 "unit of work."
 msgstr ""
-"Muchas aplicaciones necesitan recuperar un objeto en una transacci&#x00f3;n, "
-"enviarla a la capa de UI para su manipulaci&#x00f3;n, y entonces salvar los "
-"cambios en una nueva transacci&#x00f3;n. Las aplicaciones que usan este tipo "
-"de enfoque en un entorno de alta concurrencia usualmente usan datos "
+"Muchas aplicaciones necesitan recuperar un objeto en una transacción, "
+"enviarla a la capa de UI para su manipulación, y entonces guardar los "
+"cambios en una nueva transacción. Las aplicaciones que usan este tipo de "
+"enfoque en un entorno de alta concurrencia usualmente utilizan datos "
 "versionados para asegurar el aislamiento de la unidad de trabajo \"larga\"."
 
 #. Tag: para
-#: session_api.xml:555
 #, no-c-format
 msgid ""
 "Hibernate supports this model by providing for reattachment of detached "
 "instances using the <literal>Session.update()</literal> or <literal>Session."
 "merge()</literal> methods:"
 msgstr ""
-"Hibernate soporta este modelo al proveer re-uni&#x00f3;n de instancias "
-"separadas usando los m&#x00e9;todos <literal>Session.update()</literal> o "
+"Hibernate soporta este modelo al proveer re-unión de instancias separadas "
+"utilizando los métodos <literal>Session.update()</literal> o "
 "<literal>Session.merge()</literal>:"
 
-#. Tag: programlisting
-#: session_api.xml:561
-#, no-c-format
-msgid ""
-"<![CDATA[// in the first session\n"
-"Cat cat = (Cat) firstSession.load(Cat.class, catId);\n"
-"Cat potentialMate = new Cat();\n"
-"firstSession.save(potentialMate);\n"
-"\n"
-"// in a higher layer of the application\n"
-"cat.setMate(potentialMate);\n"
-"\n"
-"// later, in a new session\n"
-"secondSession.update(cat);  // update cat\n"
-"secondSession.update(mate); // update mate]]>"
-msgstr ""
-"<![CDATA[// in the first session\n"
-"Cat cat = (Cat) firstSession.load(Cat.class, catId);\n"
-"Cat potentialMate = new Cat();\n"
-"firstSession.save(potentialMate);\n"
-"\n"
-"// in a higher layer of the application\n"
-"cat.setMate(potentialMate);\n"
-"\n"
-"// later, in a new session\n"
-"secondSession.update(cat);  // update cat\n"
-"secondSession.update(mate); // update mate]]>"
-
 #. Tag: para
-#: session_api.xml:563
 #, no-c-format
 msgid ""
 "If the <literal>Cat</literal> with identifier <literal>catId</literal> had "
@@ -1464,12 +858,10 @@
 msgstr ""
 "Si el <literal>Cat</literal> con identificador <literal>catId</literal> ya "
 "hubiera sido cargado por <literal>secondSession</literal> cuando la "
-"aplicaci&#x00f3;n intent&#x00f3; volver a unirlo, se habr&#x00ed;a lanzado "
-"una excepci&#x00f3;n."
+"aplicación intentó volver a unirlo, se habría lanzado una excepción."
 
 #. Tag: para
-#: session_api.xml:569
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use <literal>update()</literal> if you are certain that the session does not "
 "contain an already persistent instance with the same identifier. Use "
@@ -1479,95 +871,69 @@
 "fresh session, ensuring that the reattachment of your detached instances is "
 "the first operation that is executed."
 msgstr ""
-"Usa <literal>update()</literal> si no est&#x00e1;s seguro que la sesi&#x00f3;"
-"n tenga una instancia ya persistente con el mismo identificador, y "
-"<literal>merge()</literal> si quieres fusionar tus modificaciones en "
-"cualquier momento sin consideraci&#x00f3;n del estado de la sesi&#x00f3;n. "
-"En otras palabras, <literal>update()</literal> es usualmente el primer "
-"m&#x00e9;todo que llamar&#x00ed;as en una sesi&#x00f3;n fresca, asegurando "
-"que la re-uni&#x00f3;n de tus instancias separadas es la primera "
-"operaci&#x00f3;n que se ejecuta."
+"Utilice <literal>update()</literal> si está seguro de que la sesión no tiene "
+"una instancia ya persistente con el mismo identificador. Utilice "
+"<literal>merge()</literal> si quiere fusionar sus modificaciones en "
+"cualquier momento sin consideración del estado de la sesión. En otras "
+"palabras, <literal>update()</literal> usualmente es el primer método que "
+"usted llamaría en una sesión actualizada, asegurando que la re-unión de sus "
+"instancias separadas es la primera operación que se ejecuta."
 
 #. Tag: para
-#: session_api.xml:578
 #, fuzzy, no-c-format
 msgid ""
 "The application should individually <literal>update()</literal> detached "
 "instances that are reachable from the given detached instance "
 "<emphasis>only</emphasis> if it wants their state to be updated. This can be "
 "automated using <emphasis>transitive persistence</emphasis>. See <xref "
-"linkend=\"objectstate-transitive\"/> for more information."
+"linkend=\"objectstate-transitive\" /> for more information."
 msgstr ""
-"La aplicaci&#x00f3;n debe actualizar individualmente las instancias "
-"separadas alcanzables por la instancia separada dada llamando a "
-"<literal>update()</literal>, si y <emphasis>s&#x00f3;lo</emphasis> si quiere "
-"que sus estados sean tambi&#x00e9;n actualizados. Esto puede, por supuesto, "
-"ser automatizado usando <emphasis>persistencia transitiva</emphasis>, ver "
-"<xref linkend=\"objectstate-transitive\"/>."
+"La aplicación debe actualizar <literal>update()</literal> individualmente "
+"las instancias separadas alcanzables por la instancia separada dada "
+"<emphasis>sólo</emphasis> si quiere que su estado se actualice. Esto puede "
+"ser automatizado la utilizando la <emphasis>persistencia transitiva</"
+"emphasis>. Consulte la <xref linkend=\"objectstate-transitive\" /> para "
+"obtener mayor información. "
 
 #. Tag: para
-#: session_api.xml:585
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>lock()</literal> method also allows an application to "
 "reassociate an object with a new session. However, the detached instance has "
 "to be unmodified."
 msgstr ""
-"El m&#x00e9;todo <literal>lock()</literal> tambi&#x00e9;n permite a una "
-"aplicaci&#x00f3;n reasociar un objeto con una sesi&#x00f3;n nueva. Sin "
-"embargo, la instancia separada no puede haber sido modificada!"
+"El método <literal>lock()</literal> también le permite a una aplicación "
+"reasociar un objeto con una sesión nueva. Sin embargo, la instancia separada "
+"no puede haber sido modificada."
 
-#. Tag: programlisting
-#: session_api.xml:590
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[//just reassociate:\n"
-"sess.lock(fritz, LockMode.NONE);\n"
-"//do a version check, then reassociate:\n"
-"sess.lock(izi, LockMode.READ);\n"
-"//do a version check, using SELECT ... FOR UPDATE, then reassociate:\n"
-"sess.lock(pk, LockMode.UPGRADE);]]>"
-msgstr ""
-"<![CDATA[//just reassociate:\n"
-"sess.lock(fritz, LockMode.NONE);\n"
-"//do a version check, then reassociate:\n"
-"sess.lock(izi, LockMode.READ);\n"
-"//do a version check, using SELECT ... FOR UPDATE, then reassociate:\n"
-"sess.lock(pk, LockMode.UPGRADE);]]>"
-
-#. Tag: para
-#: session_api.xml:592
-#, fuzzy, no-c-format
-msgid ""
 "Note that <literal>lock()</literal> can be used with various "
 "<literal>LockMode</literal>s. See the API documentation and the chapter on "
 "transaction handling for more information. Reattachment is not the only "
 "usecase for <literal>lock()</literal>."
 msgstr ""
-"Nota que <literal>lock()</literal> puede ser usado con varios "
-"<literal>LockMode</literal>s, ver la documentaci&#x00f3;n de la API y el "
-"cap&#x00ed;tulo sobre manejo de transacciones para m&#x00e1;s "
-"informaci&#x00f3;n. La re-uni&#x00f3;n no es el &#x00fa;nico caso de uso "
-"para <literal>lock()</literal>."
+"Note que <literal>lock()</literal> se puede utilizar con varios "
+"<literal>LockMode</literal>s. Consulte la documentación de la API y el "
+"capítulo sobre el manejo de transacciones para obtener mayor información. La "
+"re-unión no es el único caso de uso para <literal>lock()</literal>."
 
 #. Tag: para
-#: session_api.xml:599
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Other models for long units of work are discussed in <xref linkend="
-"\"transactions-optimistic\"/>."
+"\"transactions-optimistic\" />."
 msgstr ""
 "Se discuten otros modelos para unidades de trabajo largas en <xref linkend="
-"\"transactions-optimistic\"/>."
+"\"transactions-optimistic\" />."
 
 #. Tag: title
-#: session_api.xml:606
 #, no-c-format
 msgid "Automatic state detection"
-msgstr "Detecci&#x00f3;n autom&#x00e1;tica de estado"
+msgstr "Detección automática de estado"
 
 #. Tag: para
-#: session_api.xml:608
 #, no-c-format
 msgid ""
 "Hibernate users have requested a general purpose method that either saves a "
@@ -1575,44 +941,13 @@
 "detached instances associated with its current identifier. The "
 "<literal>saveOrUpdate()</literal> method implements this functionality."
 msgstr ""
-"Los usuarios de Hibernate han pedido un m&#x00e9;todo de prop&#x00f3;sito "
-"general que bien salve una instancia transitoria generando un identificador "
-"nuevo, o bien actualice/re&#x00fa;na las instancias separadas asociadas con "
-"su identificador actual. El m&#x00e9;todo <literal>saveOrUpdate()</literal> "
-"implementa esta funcionalidad."
+"Los usuarios de Hibernate han pedido un método de propósito general que bien "
+"guarde una instancia transitoria generando un identificador nuevo, o bien "
+"actualice/reúna las instancias separadas asociadas con su identificador "
+"actual. El método <literal>saveOrUpdate()</literal> implementa esta "
+"funcionalidad."
 
-#. Tag: programlisting
-#: session_api.xml:615
-#, no-c-format
-msgid ""
-"<![CDATA[// in the first session\n"
-"Cat cat = (Cat) firstSession.load(Cat.class, catID);\n"
-"\n"
-"// in a higher tier of the application\n"
-"Cat mate = new Cat();\n"
-"cat.setMate(mate);\n"
-"\n"
-"// later, in a new session\n"
-"secondSession.saveOrUpdate(cat);   // update existing state (cat has a non-"
-"null id)\n"
-"secondSession.saveOrUpdate(mate);  // save the new instance (mate has a null "
-"id)]]>"
-msgstr ""
-"<![CDATA[// in the first session\n"
-"Cat cat = (Cat) firstSession.load(Cat.class, catID);\n"
-"\n"
-"// in a higher tier of the application\n"
-"Cat mate = new Cat();\n"
-"cat.setMate(mate);\n"
-"\n"
-"// later, in a new session\n"
-"secondSession.saveOrUpdate(cat);   // update existing state (cat has a non-"
-"null id)\n"
-"secondSession.saveOrUpdate(mate);  // save the new instance (mate has a null "
-"id)]]>"
-
 #. Tag: para
-#: session_api.xml:617
 #, no-c-format
 msgid ""
 "The usage and semantics of <literal>saveOrUpdate()</literal> seems to be "
@@ -1622,127 +957,111 @@
 "<literal>merge()</literal>. Some whole applications will never use either of "
 "these methods."
 msgstr ""
-"El uso y sem&#x00e1;ntica de <literal>saveOrUpdate()</literal> parece ser "
-"confuso para usuarios nuevos. Primeramente, en tanto no est&#x00e9;s "
-"intentando usar instancias de una sesi&#x00f3;n en otra sesi&#x00f3;n nueva, "
-"no debes necesitar usar <literal>update()</literal>, <literal>saveOrUpdate()"
-"</literal>, o <literal>merge()</literal>. Algunas aplicaciones enteras nunca "
-"usar&#x00e1;n ninguno de estos m&#x00e9;todos."
+"La utilización y semántica de <literal>saveOrUpdate()</literal> parece ser "
+"confuso para los usuarios nuevos. Primero, en tanto no esté tratando de "
+"utilizar instancias de una sesión en otra sesión nueva, no debe necesitar "
+"usar <literal>update()</literal>, <literal>saveOrUpdate()</literal>, o "
+"<literal>merge()</literal>. Algunas aplicaciones enteras nunca usarán "
+"ninguno de estos métodos."
 
 #. Tag: para
-#: session_api.xml:625
 #, no-c-format
 msgid ""
 "Usually <literal>update()</literal> or <literal>saveOrUpdate()</literal> are "
 "used in the following scenario:"
 msgstr ""
 "Usualmente <literal>update()</literal> o <literal>saveOrUpdate()</literal> "
-"se usan en el siguiente escenario:"
+"se utilizan en el siguiente escenario:"
 
 #. Tag: para
-#: session_api.xml:632
 #, no-c-format
 msgid "the application loads an object in the first session"
-msgstr "la aplicaci&#x00f3;n carga un objeto en la primera sesi&#x00f3;n"
+msgstr "la aplicación carga un objeto en la primera sesión"
 
 #. Tag: para
-#: session_api.xml:637
 #, no-c-format
 msgid "the object is passed up to the UI tier"
-msgstr "el objeto es pasado a la capa de UI"
+msgstr "el objeto se pasa a la capa de UI"
 
 #. Tag: para
-#: session_api.xml:642
 #, no-c-format
 msgid "some modifications are made to the object"
-msgstr "se hacen algunas modificaciones al objeto"
+msgstr "se realizan algunas modificaciones al objeto"
 
 #. Tag: para
-#: session_api.xml:647
 #, no-c-format
 msgid "the object is passed back down to the business logic tier"
-msgstr "el objeto se pasa abajo de regreso a la capa de negocio"
+msgstr "el objeto se pasa abajo de regreso a la capa lógica de negocios"
 
 #. Tag: para
-#: session_api.xml:652
 #, no-c-format
 msgid ""
 "the application persists these modifications by calling <literal>update()</"
 "literal> in a second session"
 msgstr ""
-"la aplicaci&#x00f3;n hace estas modificaciones persistentes llamando a "
-"<literal>update()</literal> en una segunda sesi&#x00f3;n"
+"la aplicación hace estas modificaciones persistentes llamando a "
+"<literal>update()</literal> en una segunda sesión"
 
 #. Tag: para
-#: session_api.xml:659
 #, no-c-format
 msgid "<literal>saveOrUpdate()</literal> does the following:"
 msgstr "<literal>saveOrUpdate()</literal> hace lo siguiente:"
 
 #. Tag: para
-#: session_api.xml:665
 #, no-c-format
 msgid "if the object is already persistent in this session, do nothing"
-msgstr "si el objeto ya es persistente en esta sesi&#x00f3;n, no hace nada"
+msgstr "si el objeto ya es persistente en esta sesión, no haga nada"
 
 #. Tag: para
-#: session_api.xml:670
 #, no-c-format
 msgid ""
 "if another object associated with the session has the same identifier, throw "
 "an exception"
 msgstr ""
-"si otro objeto asociado con la sesi&#x00f3;n tiene el mismo identificador, "
-"lanza una excepci&#x00f3;n"
+"si otro objeto asociado con la sesión tiene el mismo identificador, lance "
+"una excepción"
 
 #. Tag: para
-#: session_api.xml:676
 #, no-c-format
 msgid "if the object has no identifier property, <literal>save()</literal> it"
 msgstr ""
-"si el objeto no tiene ninguna propiedad identificadora, lo salva llamando a "
+"si el objeto no tiene ninguna propiedad identificadora, guárdelo llamando a "
 "<literal>save()</literal>"
 
 #. Tag: para
-#: session_api.xml:681
 #, no-c-format
 msgid ""
 "if the object's identifier has the value assigned to a newly instantiated "
 "object, <literal>save()</literal> it"
 msgstr ""
-"si el identificador del objeto tiene el valor asignado a un objeto "
-"reci&#x00e9;n instanciado, lo salva llamando a <literal>save()</literal>"
+"si el identificador del objeto tiene el valor asignado a un objeto recién "
+"instanciado, guárdelo llamando a <literal>save()</literal>"
 
 #. Tag: para
-#: session_api.xml:687
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "if the object is versioned by a <literal>&lt;version&gt;</literal> or "
 "<literal>&lt;timestamp&gt;</literal>, and the version property value is the "
 "same value assigned to a newly instantiated object, <literal>save()</"
 "literal> it"
 msgstr ""
-"si el objeto est&#x00e1; versionado (por un <literal>&lt;version&gt;</"
-"literal> o <literal>&lt;timestamp&gt;</literal>), y el valor de la propiedad "
-"de versi&#x00f3;n es el mismo valor asignado a una objeto reci&#x00e9;n "
-"instanciado, lo salva llamando a <literal>save()</literal>"
+"si el objeto está versionado por un <literal>&lt;version&gt;</literal> o "
+"<literal>&lt;timestamp&gt;</literal>, y el valor de la propiedad de versión "
+"es el mismo valor asignado a un objeto recién instanciado, guárdelo llamando "
+"a <literal>save()</literal>"
 
 #. Tag: para
-#: session_api.xml:695
 #, no-c-format
 msgid "otherwise <literal>update()</literal> the object"
 msgstr ""
-"en cualquier otro caso se actualiza el objeto llamando a <literal>update()</"
-"literal>"
+"de otra manera actualice el objeto llamando a <literal>update()</literal>"
 
 #. Tag: para
-#: session_api.xml:701
 #, no-c-format
 msgid "and <literal>merge()</literal> is very different:"
 msgstr "y <literal>merge()</literal> es muy diferente:"
 
 #. Tag: para
-#: session_api.xml:707
 #, no-c-format
 msgid ""
 "if there is a persistent instance with the same identifier currently "
@@ -1750,182 +1069,127 @@
 "persistent instance"
 msgstr ""
 "si existe una instancia persistente con el mismo identificador asignado "
-"actualmente con la sesi&#x00f3;n, copia el estado del objeto dado en la "
-"instancia persistente"
+"actualmente con la sesión, copie el estado del objeto dado en la instancia "
+"persistente"
 
 #. Tag: para
-#: session_api.xml:714
 #, no-c-format
 msgid ""
 "if there is no persistent instance currently associated with the session, "
 "try to load it from the database, or create a new persistent instance"
 msgstr ""
-"si no existe ninguna instancia persistente actualmente asociada a la "
-"sesi&#x00f3;n, intente cargarla de la base de datos, o crear una nueva "
-"instancia persistente"
+"si no existe ninguna instancia persistente asociada a la sesión actualmente, "
+"intente cargarla desde la base de datos, o cree una nueva instancia "
+"persistente"
 
 #. Tag: para
-#: session_api.xml:720
 #, no-c-format
 msgid "the persistent instance is returned"
 msgstr "la instancia persistente es devuelta"
 
 #. Tag: para
-#: session_api.xml:725
 #, no-c-format
 msgid ""
 "the given instance does not become associated with the session, it remains "
 "detached"
-msgstr ""
-"la instancia dada no resulta ser asociada a la sesi&#x00f3;n, permanece "
-"separada"
+msgstr "la instancia dada no se asocia a la sesión, permanece separada"
 
 #. Tag: title
-#: session_api.xml:735
 #, no-c-format
 msgid "Deleting persistent objects"
-msgstr "Borrando objetos persistentes"
+msgstr "Borrado de objetos persistentes"
 
 #. Tag: para
-#: session_api.xml:737
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Session.delete()</literal> will remove an object's state from the "
 "database. Your application, however, can still hold a reference to a deleted "
 "object. It is best to think of <literal>delete()</literal> as making a "
 "persistent instance, transient."
 msgstr ""
-"<literal>Session.delete()</literal> quitar&#x00e1; el estado de un objeto de "
-"la base de datos. Por supuesto, tu aplicaci&#x00f3;n podr&#x00ed;a tener "
-"a&#x00fa;n una referencia a un objeto borrado. Lo mejor es pensar en "
-"<literal>delete()</literal> como hacer transitoria una instancia persistente."
+"<literal>Session.delete()</literal> borrará el estado de un objeto de la "
+"base de datos. Sin embargo, su aplicación puede tener todavía una referencia "
+"a un objeto borrado. Lo mejor es pensar en <literal>delete()</literal> al "
+"hacer transitoria una instancia persistente."
 
-#. Tag: programlisting
-#: session_api.xml:744
-#, no-c-format
-msgid "<![CDATA[sess.delete(cat);]]>"
-msgstr "<![CDATA[sess.delete(cat);]]>"
-
 #. Tag: para
-#: session_api.xml:746
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can delete objects in any order, without risk of foreign key constraint "
 "violations. It is still possible to violate a <literal>NOT NULL</literal> "
 "constraint on a foreign key column by deleting objects in the wrong order, e."
 "g. if you delete the parent, but forget to delete the children."
 msgstr ""
-"Puedes borrar los objetos en el orden que gustes, sin riesgo de violaciones "
-"de restricci&#x00f3;n de clave for&#x00e1;nea. A&#x00fa;n es posible violar "
-"una restricci&#x00f3;n <literal>NOT NULL</literal> sobre una columna clave "
-"for&#x00e1;nea borrando objetos en un orden err&#x00f3;neo, por ejemplo, si "
-"borras el padre, pero olvidas borrar los hijos."
+"Puede borrar objetos en el orden que quiera, sin riesgo de violaciones de "
+"restricción de clave foránea. Aún es posible violar una restricción "
+"<literal>NOT NULL</literal> sobre una columna de clave foránea borrando "
+"objetos en un orden erróneo, por ejemplo, si borra el padre, pero olvida "
+"borrar los hijos."
 
 #. Tag: title
-#: session_api.xml:757
 #, no-c-format
 msgid "Replicating object between two different datastores"
-msgstr "Replicando objetos entre dos almac&#x00e9;nes de datos diferentes"
+msgstr "Replicación de objetos entre dos almacenamientos de datos diferentes"
 
 #. Tag: para
-#: session_api.xml:759
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is sometimes useful to be able to take a graph of persistent instances "
 "and make them persistent in a different datastore, without regenerating "
 "identifier values."
 msgstr ""
-"Es ocasionalmente &#x00fa;til ser capaz de tomar un grafo de instancias "
-"persistentes y hacerlas persistentes en un almac&#x00e9;n de datos "
-"diferente, sin regenerar los valores identificadores."
+"A veces es útil poder tomar un grafo de la instancias persistentes y "
+"hacerlas persistentes en un almacenamiento de datos diferente, sin regenerar "
+"los valores identificadores."
 
-#. Tag: programlisting
-#: session_api.xml:765
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[//retrieve a cat from one database\n"
-"Session session1 = factory1.openSession();\n"
-"Transaction tx1 = session1.beginTransaction();\n"
-"Cat cat = session1.get(Cat.class, catId);\n"
-"tx1.commit();\n"
-"session1.close();\n"
-"\n"
-"//reconcile with a second database\n"
-"Session session2 = factory2.openSession();\n"
-"Transaction tx2 = session2.beginTransaction();\n"
-"session2.replicate(cat, ReplicationMode.LATEST_VERSION);\n"
-"tx2.commit();\n"
-"session2.close();]]>"
-msgstr ""
-"<![CDATA[//retrieve a cat from one database\n"
-"Session session1 = factory1.openSession();\n"
-"Transaction tx1 = session1.beginTransaction();\n"
-"Cat cat = session1.get(Cat.class, catId);\n"
-"tx1.commit();\n"
-"session1.close();\n"
-"\n"
-"//reconcile with a second database\n"
-"Session session2 = factory2.openSession();\n"
-"Transaction tx2 = session2.beginTransaction();\n"
-"session2.replicate(cat, ReplicationMode.LATEST_VERSION);\n"
-"tx2.commit();\n"
-"session2.close();]]>"
-
-#. Tag: para
-#: session_api.xml:767
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>ReplicationMode</literal> determines how <literal>replicate()</"
 "literal> will deal with conflicts with existing rows in the database:"
 msgstr ""
-"El <literal>ReplicationMode</literal> determina c&#x00f3;mo "
-"<literal>replicate()</literal> tratar&#x00e1; los conflictos con filas "
-"existentes en la base de datos."
+"El <literal>ReplicationMode</literal> determina cómo <literal>replicate()</"
+"literal> tratará los conflictos con filas existentes en la base de datos:"
 
 #. Tag: para
-#: session_api.xml:774
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.IGNORE</literal>: ignores the object when there is "
 "an existing database row with the same identifier"
 msgstr ""
-"<literal>ReplicationMode.IGNORE</literal> - ignora el objeto cuando existe "
-"una fila de base de datos con el mismo identificador"
+"<literal>ReplicationMode.IGNORE</literal>: ignora el objeto cuando existe "
+"una fila de la base de datos con el mismo identificador"
 
 #. Tag: para
-#: session_api.xml:780
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.OVERWRITE</literal>: overwrites any existing "
 "database row with the same identifier"
 msgstr ""
-"<literal>ReplicationMode.OVERWRITE</literal> - sobrescribe cualquier fila de "
-"base de datos existente con el mismo identificador"
+"<literal>ReplicationMode.OVERWRITE</literal>: sobrescribe cualquier fila de "
+"la base de datos existente con el mismo identificador"
 
 #. Tag: para
-#: session_api.xml:786
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.EXCEPTION</literal>: throws an exception if there "
 "is an existing database row with the same identifier"
 msgstr ""
-"<literal>ReplicationMode.EXCEPTION</literal> - lanza una excepci&#x00f3;n si "
-"existe una fila de base de datos con el mismo identificador"
+"<literal>ReplicationMode.EXCEPTION</literal>: lanza una excepción si existe "
+"una fila de la base de datos con el mismo identificador"
 
 #. Tag: para
-#: session_api.xml:792
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.LATEST_VERSION</literal>: overwrites the row if its "
 "version number is earlier than the version number of the object, or ignore "
 "the object otherwise"
 msgstr ""
-"<literal>ReplicationMode.LATEST_VERSION</literal> - sobrescribe la fila si "
-"su n&#x00fa;mero de versi&#x00f3;n es anterior al n&#x00fa;mero de "
-"versi&#x00f3;n del objeto, o en caso contrario ignora el objeto"
+"<literal>ReplicationMode.LATEST_VERSION</literal>: sobrescribe la fila si su "
+"número de versión es anterior al número de versión del objeto, o de lo "
+"contrario ignora el objeto"
 
 #. Tag: para
-#: session_api.xml:800
 #, no-c-format
 msgid ""
 "Usecases for this feature include reconciling data entered into different "
@@ -1935,114 +1199,98 @@
 msgstr ""
 "Los casos de uso para esta funcionalidad incluyen reconciliar datos "
 "ingresados en instancias diferentes de bases de datos, actualizar "
-"informaci&#x00f3;n de configuraci&#x00f3;n de sistema durante "
-"actualizaciones de producto, deshacer cambios producidos durante "
-"transacciones no-ACID y m&#x00e1;s."
+"información de configuración del sistema durante actualizaciones de "
+"producto, deshacer cambios realizados durante transacciones no-ACID y más."
 
 #. Tag: title
-#: session_api.xml:809
 #, no-c-format
 msgid "Flushing the Session"
-msgstr "Limpiando (flushing) la sesi&#x00f3;n"
+msgstr "Limpieza (flushing) de la sesión"
 
 #. Tag: para
-#: session_api.xml:811
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes the <literal>Session</literal> will execute the SQL statements "
 "needed to synchronize the JDBC connection's state with the state of objects "
 "held in memory. This process, called <emphasis>flush</emphasis>, occurs by "
 "default at the following points:"
 msgstr ""
-"Cada tanto, la <literal>Session</literal> ejecutar&#x00e1; las sentencias "
-"SQL necesarias para sincronizar el estado de la conexi&#x00f3;n JDBC con el "
-"estado de los objetos mantenidos en menoria. Este proceso, "
-"<emphasis>limpieza (flush)</emphasis>, ocurre por defecto en los siguientes "
-"puntos"
+"A veces la <literal>Session</literal> ejecutará las declaraciones SQL "
+"necesarias para sincronizar el estado de la conexión JDBC con el estado de "
+"los objetos en la menoria. Este proceso, denominado <emphasis>vaciado (flush)"
+"</emphasis>, ocurre por defecto en los siguientes puntos:"
 
 #. Tag: para
-#: session_api.xml:820
 #, no-c-format
 msgid "before some query executions"
 msgstr "antes de algunas ejecuciones de consulta"
 
 #. Tag: para
-#: session_api.xml:825
 #, no-c-format
 msgid "from <literal>org.hibernate.Transaction.commit()</literal>"
 msgstr "desde <literal>org.hibernate.Transaction.commit()</literal>"
 
 #. Tag: para
-#: session_api.xml:830
 #, no-c-format
 msgid "from <literal>Session.flush()</literal>"
 msgstr "desde <literal>Session.flush()</literal>"
 
 #. Tag: para
-#: session_api.xml:836
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The SQL statements are issued in the following order:"
-msgstr "Las sentencias SQL son liberadas en el siguiente orden"
+msgstr "Las declaraciones SQL se emiten en el siguiente orden:"
 
 #. Tag: para
-#: session_api.xml:842
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "all entity insertions in the same order the corresponding objects were saved "
 "using <literal>Session.save()</literal>"
 msgstr ""
 "todas las inserciones de entidades, en el mismo orden que los objetos "
-"correspondientes fueron salvados usando <literal>Session.save()</literal>"
+"correspondientes fueron guardados utilizando <literal>Session.save()</"
+"literal>"
 
 #. Tag: para
-#: session_api.xml:848
 #, no-c-format
 msgid "all entity updates"
 msgstr "todas las actualizaciones de entidades"
 
 #. Tag: para
-#: session_api.xml:853
 #, no-c-format
 msgid "all collection deletions"
 msgstr "todas los borrados de colecciones"
 
 #. Tag: para
-#: session_api.xml:858
 #, no-c-format
 msgid "all collection element deletions, updates and insertions"
 msgstr ""
-"todos los borrados, actualizaciones e inserciones de elementos de "
-"colecci&#x00f3;n"
+"todos los borrados, actualizaciones e inserciones de elementos de colección"
 
 #. Tag: para
-#: session_api.xml:863
 #, no-c-format
 msgid "all collection insertions"
 msgstr "todas las inserciones de colecciones"
 
 #. Tag: para
-#: session_api.xml:868
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "all entity deletions in the same order the corresponding objects were "
 "deleted using <literal>Session.delete()</literal>"
 msgstr ""
 "todos los borrados de entidades, en el mismo orden que los objetos "
-"correspondientes fueron borrados usando <literal>Session.delete()</literal>"
+"correspondientes fueron borrados usando <literal>Session.delete()</literal> "
 
 #. Tag: para
-#: session_api.xml:875
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An exception is that objects using <literal>native</literal> ID generation "
 "are inserted when they are saved."
 msgstr ""
-"(Una excepci&#x00f3;n es que los objetos que usan generaci&#x00f3;n de ID "
-"<literal>native</literal> se insertan cuando son salvados.)"
+"Una excepción es que los objetos que utilizan generación de ID "
+"<literal>native</literal> se insertan cuando se guardan."
 
 #. Tag: para
-#: session_api.xml:880
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Except when you explicitly <literal>flush()</literal>, there are absolutely "
 "no guarantees about <emphasis>when</emphasis> the <literal>Session</literal> "
@@ -2050,15 +1298,14 @@
 "are executed. However, Hibernate does guarantee that the <literal>Query.list"
 "(..)</literal> will never return stale or incorrect data."
 msgstr ""
-"Excepto cuando llamas expl&#x00ed;citamente a <literal>flush()</literal>, no "
-"hay en absoluto garant&#x00ed;as sobre <emphasis>cu&#x00e1;ndo</emphasis> la "
-"<literal>Session</literal> ejecuta las llamadas JDBC. s&#x00f3;lo sobre el "
-"<emphasis>orden</emphasis> en que son ejecutadas. Sin embargo, Hibernate "
-"garantiza que los m&#x00e9;todos <literal>Query.list(..)</literal> nunca "
-"devolver&#x00e1;n datos a&#x00f1;ejos o err&#x00f3;neos."
+"Excepto cuando llama explícitamente a <literal>flush()</literal>, no hay en "
+"absoluto garantías sobre <emphasis>cuándo</emphasis> la <literal>Session</"
+"literal> ejecuta las llamadas JDBC, sólamente sobre el <emphasis>orden</"
+"emphasis> en que se ejecutan. Sin embargo, Hibernate garantiza que los "
+"métodos <literal>Query.list(..)</literal> nunca devolverán datos "
+"desactualizados o incorrectos."
 
 #. Tag: para
-#: session_api.xml:888
 #, fuzzy, no-c-format
 msgid ""
 "It is possible to change the default behavior so that flush occurs less "
@@ -2068,88 +1315,49 @@
 "never flush unless <literal>flush()</literal> is called explicitly. The last "
 "mode is useful for long running units of work, where a <literal>Session</"
 "literal> is kept open and disconnected for a long time (see <xref linkend="
-"\"transactions-optimistic-longsession\"/>)."
+"\"transactions-optimistic-longsession\" />)."
 msgstr ""
-"Es posible cambiar el comportamiento por defecto de modo que la limpieza "
-"(flush) ocurra menos frecuentemente. La clase <literal>FlushMode</literal> "
-"tres modos diferentes: s&#x00f3;lo en tiempo de compromiso (y s&#x00f3;lo "
-"cuando se use la API de <literal>Transaction</literal> de Hibernate), "
-"limpieza autom&#x00e1;tica usando la rutina explicada, o nunca limpiar a "
-"menos que se llame a <literal>flush()</literal> expl&#x00ed;citamente. El "
-"&#x00fa;ltimo modo es &#x00fa;til para unidades de trabajo largas, donde una "
-"<literal>Session</literal> se mantiene abierta y desconectada por largo "
-"tiempo (ver <xref linkend=\"transactions-optimistic-longsession\"/>)."
+"Es posible cambiar el comportamiento predeterminado de modo que el vaciado "
+"ocurra con menos frecuencia. La clase <literal>FlushMode</literal> define "
+"tres modos diferentes: sólo en tiempo de guardar los cambios cuando la API "
+"de <literal>Transaction</literal> de Hibernate se utiliza, vaciado "
+"automático utilizando la rutina explicada, o nunca vaciar a menos de que se "
+"llame a <literal>flush()</literal> explícitamente. El último modo es útil "
+"para unidades de trabajo largas, donde se mantiene abierta una "
+"<literal>Session</literal> y es desconectada por largo tiempo (vea la <xref "
+"linkend=\"transactions-optimistic-longsession\"/>)."
 
-#. Tag: programlisting
-#: session_api.xml:898
-#, no-c-format
-msgid ""
-"<![CDATA[sess = sf.openSession();\n"
-"Transaction tx = sess.beginTransaction();\n"
-"sess.setFlushMode(FlushMode.COMMIT); // allow queries to return stale state\n"
-"\n"
-"Cat izi = (Cat) sess.load(Cat.class, id);\n"
-"izi.setName(iznizi);\n"
-"\n"
-"// might return stale data\n"
-"sess.find(\"from Cat as cat left outer join cat.kittens kitten\");\n"
-"\n"
-"// change to izi is not flushed!\n"
-"...\n"
-"tx.commit(); // flush occurs\n"
-"sess.close();]]>"
-msgstr ""
-"<![CDATA[sess = sf.openSession();\n"
-"Transaction tx = sess.beginTransaction();\n"
-"sess.setFlushMode(FlushMode.COMMIT); // allow queries to return stale state\n"
-"\n"
-"Cat izi = (Cat) sess.load(Cat.class, id);\n"
-"izi.setName(iznizi);\n"
-"\n"
-"// might return stale data\n"
-"sess.find(\"from Cat as cat left outer join cat.kittens kitten\");\n"
-"\n"
-"// change to izi is not flushed!\n"
-"...\n"
-"tx.commit(); // flush occurs]]>"
-
 #. Tag: para
-#: session_api.xml:900
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "During flush, an exception might occur (e.g. if a DML operation violates a "
 "constraint). Since handling exceptions involves some understanding of "
 "Hibernate's transactional behavior, we discuss it in <xref linkend="
-"\"transactions\"/>."
+"\"transactions\" />."
 msgstr ""
-"Durante la limpieza, puede ocurrir una excepci&#x00f3;n (por ejemplo, si una "
-"operaci&#x00f3;n DML violase una restricci&#x00f3;n). Ya que el manejo de "
-"excepciones implica alguna comprensi&#x00f3;n del comportamiento "
-"transaccional de Hibernate, lo discutimos en <xref linkend=\"transactions\"/"
-">."
+"Durante el vaciado se puede presentar una excepción (por ejemplo, si una "
+"operación DML viola una restricción). Ya que el manejo de excepciones "
+"implica algo de comprensión del comportamiento transaccional de Hibernate, "
+"lo discutimos en <xref linkend=\"transactions\" />."
 
 #. Tag: title
-#: session_api.xml:909
 #, no-c-format
 msgid "Transitive persistence"
 msgstr "Persistencia transitiva"
 
 #. Tag: para
-#: session_api.xml:911
 #, no-c-format
 msgid ""
 "It is quite cumbersome to save, delete, or reattach individual objects, "
 "especially if you deal with a graph of associated objects. A common case is "
 "a parent/child relationship. Consider the following example:"
 msgstr ""
-"Es absolutamente inc&#x00f3;modo dalvar, borrar, o reunir objetos "
-"individuales, especialmente si tratas con un grafo de objetos asociados. Un "
-"caso com&#x00fa;n es una relaci&#x00f3;n padre/hijo. Considera el siguiente "
-"ejemplo:"
+"Es absolutamente incómodo guardar, borrar, o reunir objetos individuales, "
+"especialmente si trata con un grafo de objetos asociados. Un caso común es "
+"una relación padre/hijo. Considere el siguiente ejemplo:"
 
 #. Tag: para
-#: session_api.xml:917
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the children in a parent/child relationship would be value typed (e.g. a "
 "collection of addresses or strings), their life cycle would depend on the "
@@ -2160,20 +1368,18 @@
 "collection. Since value-typed objects cannot have shared references, "
 "Hibernate will detect this and delete the child from the database."
 msgstr ""
-"Si los hijos en una relaci&#x00f3;n padre/hijo pudieran ser tipificados en "
-"valor (por ejemplo, una colecci&#x00f3;n de direcciones o cadenas), sus "
-"ciclos de vida depender&#x00ed;an del padre y se requerir&#x00ed;a ninguna "
-"otra acci&#x00f3;n para el tratamiento en \"cascada\" de cambios de estado. "
-"Cuando el padre es salvado, los objetos hijo tipificados en valor son "
-"salvados tambi&#x00e9;n, cuando se borra el padre, se borran los hijos, etc. "
-"Esto funciona incluso para operaciones como el retiro de un hijo de la "
-"colecci&#x00f3;n. Hibernate detectar&#x00e1; esto y, ya que los objetos "
-"tipificados en valor no pueden tener referencias compartidas, borrar&#x00e1; "
-"el hijo de la base de datos."
+"Si los hijos en una relación padre/hijo pudieran ser tipificados en valor "
+"(por ejemplo, una colección de direcciones o cadenas), sus ciclos de vida "
+"dependerían del padre y no se requeriría ninguna otra acción para el "
+"tratamiento apropiado en \"cascada\" de los cambios de estado. Cuando se "
+"guarda el padre, los objetos hijo tipificados en valor también se guardan, "
+"cuando se borra el padre, se borran los hijos, etc. Esto funciona incluso "
+"para operaciones tales como el retiro de un hijo de la colección. Hibernate "
+"detectará esto y ya que los objetos tipificados en valor no pueden tener "
+"referencias compartidas entonces borrará el hijo de la base de datos."
 
 #. Tag: para
-#: session_api.xml:928
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now consider the same scenario with parent and child objects being entities, "
 "not value-types (e.g. categories and items, or parent and child cats). "
@@ -2183,17 +1389,15 @@
 "entities. Hibernate does not implement <emphasis>persistence by "
 "reachability</emphasis> by default."
 msgstr ""
-"Ahora considera el mismo escenario con los objetos padre e hijos siendo "
-"entidades, no tipos de valor (por ejemplo, categor&#x00ed;as e &#x00ed;tems, "
-"o gatos padre e hijos). Las entidades tienen su propio ciclo de vida, "
-"soportan referencias compartidas (de modo que quitar una entidad de una "
-"colecci&#x00f3;n no significa que sea borrada), y no hay por defecto "
-"ning&#x00fa;n tratamiento en \"cascada\" de estado de una entidad a otras "
-"entidades asociadas. Hibernate no implementa <emphasis>persistencia por "
-"alcance</emphasis>."
+"Ahora considere el mismo escenario con los objetos padre e hijos siendo "
+"entidades, no tipos de valor (por ejemplo, categorías e ítems, o gatos "
+"padres e hijos). Las entidades tienen su propio ciclo de vida y soportan "
+"referencias compartidas. El eliminar una entidad de una colección no "
+"significa que se pueda borrar, y no hay por defecto ningún tratamiento en "
+"\"cascada\" del estado de una entidad a otras entidades asociadas. Hibernate "
+"no implementa por defecto la <emphasis>persistencia por alcance</emphasis>."
 
 #. Tag: para
-#: session_api.xml:937
 #, no-c-format
 msgid ""
 "For each basic operation of the Hibernate session - including "
@@ -2204,52 +1408,34 @@
 "operation to be cascaded along an association, you must indicate that in the "
 "mapping document. For example:"
 msgstr ""
-"Para cada operaci&#x00f3;n b&#x00e1;sica de la sesi&#x00f3;n de Hibernate - "
-"incluyendo <literal>persist(), merge(), saveOrUpdate(), delete(), lock(), "
-"refresh(), evict(), replicate()</literal> - hay un estilo de cascada "
+"Para cada operación básica de la sesión de Hibernate - incluyendo "
+"<literal>persist(), merge(), saveOrUpdate(), delete(), lock(), refresh(), "
+"evict(), replicate()</literal> - existe un estilo de cascada "
 "correspondiente. Respectivamente, los estilos de cascada se llaman "
 "<literal>create, merge, save-update, delete, lock, refresh, evict, "
-"replicate</literal>. Si quieres que una operaci&#x00f3;n sea tratada en "
-"cascada a lo largo de una asociaci&#x00f3;n, debes indicar eso en el "
-"documento de mapeo. Por ejemplo:"
+"replicate</literal>. Si quiere que una operación sea tratada en cascada a lo "
+"largo de una asociación, debe indicar eso en el documento de mapeo. Por "
+"ejemplo:"
 
-#. Tag: programlisting
-#: session_api.xml:946
-#, no-c-format
-msgid "<![CDATA[<one-to-one name=\"person\" cascade=\"persist\"/>]]>"
-msgstr "<![CDATA[<one-to-one name=\"person\" cascade=\"persist\"/>]]>"
-
 #. Tag: para
-#: session_api.xml:948
 #, no-c-format
 msgid "Cascade styles my be combined:"
 msgstr "Los estilos de cascada pueden combinarse:"
 
-#. Tag: programlisting
-#: session_api.xml:952
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<one-to-one name=\"person\" cascade=\"persist,delete,lock\"/>]]>"
-msgstr ""
-"<![CDATA[<one-to-one name=\"person\" cascade=\"persist,delete,lock\"/>]]>"
-
-#. Tag: para
-#: session_api.xml:954
-#, fuzzy, no-c-format
-msgid ""
 "You can even use <literal>cascade=\"all\"</literal> to specify that "
 "<emphasis>all</emphasis> operations should be cascaded along the "
 "association. The default <literal>cascade=\"none\"</literal> specifies that "
 "no operations are to be cascaded."
 msgstr ""
-"Puedes incluso usar <literal>cascade=\"all\"</literal> para especificar que "
-"<emphasis>todas</emphasis> las operaciones deben ser tratadas en cascada a "
-"lo largo de la asociaci&#x00f3;n. El por defecto <literal>cascade=\"none\"</"
-"literal> especifica que ninguna operaci&#x00f3;n ser&#x00e1; tratada en "
-"cascada."
+"Incluso puede utilizar <literal>cascade=\"all\"</literal> para especificar "
+"que <emphasis>todas</emphasis> las operaciones deben ser tratadas en cascada "
+"a lo largo de la asociación. La <literal>cascade=\"none\"</literal> "
+"predeterminada especifica que ninguna operación se tratará en cascada. "
 
 #. Tag: para
-#: session_api.xml:960
 #, no-c-format
 msgid ""
 "A special cascade style, <literal>delete-orphan</literal>, applies only to "
@@ -2258,46 +1444,41 @@
 "association."
 msgstr ""
 "Un estilo de cascada especial, <literal>delete-orphan</literal>, se aplica "
-"s&#x00f3;lo a asociaciones uno-a-muchos, e indica que la operaci&#x00f3;n "
-"<literal>delete()</literal> debe aplicarse a cualquier objeto hijo que sea "
-"quitado de la asociaci&#x00f3;n."
+"sólamente a asociaciones uno-a-muchos, e indica que la operación "
+"<literal>delete()</literal> debe aplicarse a cualquier objeto hijo que se "
+"elimine de la asociación."
 
 #. Tag: para
-#: session_api.xml:967
 #, no-c-format
 msgid "Recommendations:"
 msgstr "Recomendaciones:"
 
 #. Tag: para
-#: session_api.xml:973
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It does not usually make sense to enable cascade on a <literal>&lt;many-to-"
 "one&gt;</literal> or <literal>&lt;many-to-many&gt;</literal> association. "
 "Cascade is often useful for <literal>&lt;one-to-one&gt;</literal> and "
 "<literal>&lt;one-to-many&gt;</literal> associations."
 msgstr ""
-"Usualmente no tiene sentido habilitar el tratamiento en cascada a una "
-"asociaci&#x00f3;n <literal>&lt;many-to-one&gt;</literal> o <literal>&lt;many-"
-"to-many&gt;</literal>. El tratamiento en cascada es frecuentemente &#x00fa;"
-"til para las asociaciones <literal>&lt;one-to-one&gt;</literal> y "
-"<literal>&lt;one-to-many&gt;</literal>. associations."
+"Usualmente no tiene sentido habilitar el tratamiento en cascada en una "
+"asociación <literal>&lt;many-to-one&gt;</literal> o <literal>&lt;many-to-"
+"many&gt;</literal>. El tratamiento en cascada es frecuentemente útil para "
+"las asociaciones <literal>&lt;one-to-one&gt;</literal> y <literal>&lt;one-to-"
+"many&gt;</literal>."
 
 #. Tag: para
-#: session_api.xml:981
 #, no-c-format
 msgid ""
 "If the child object's lifespan is bounded by the lifespan of the parent "
 "object, make it a <emphasis>life cycle object</emphasis> by specifying "
 "<literal>cascade=\"all,delete-orphan\"</literal>."
 msgstr ""
-"Si la esperanza de vida de los objetos hijos est&#x00e1; ligada a la "
-"eesperanza de vida del objeto padre, h&#x00e1;zlo un <emphasis>objeto de "
-"ciclo de vida</emphasis> especificando <literal>cascade=\"all,delete-orphan"
-"\"</literal>."
+"Si el periodo de vida de los objetos hijos está ligado al periodo de vida "
+"del objeto padre, hágalo un <emphasis>objeto de ciclo de vida</emphasis> "
+"especificando <literal>cascade=\"all,delete-orphan\"</literal>. "
 
 #. Tag: para
-#: session_api.xml:988
 #, no-c-format
 msgid ""
 "Otherwise, you might not need cascade at all. But if you think that you will "
@@ -2305,14 +1486,13 @@
 "transaction, and you want to save yourself some typing, consider using "
 "<literal>cascade=\"persist,merge,save-update\"</literal>."
 msgstr ""
-"En otro caso, puede que no necesites tratamiento en cascada en absoluto. "
-"Pero si piensas que estar&#x00e1;s trabajando frecuentemente con padre e "
-"hijos juntos en la misma transacci&#x00f3;n, y quieres ahorrarte algo de "
-"tipeo, considera usar <literal>cascade=\"persist,merge,save-update\"</"
-"literal>."
+"En otro caso, puede que usted no necesite tratamiento en cascada en "
+"absoluto. Pero si piensa que va a estar trabajando frecuentemente con padre "
+"e hijos juntos en la misma transacción, y quiere ahorrarse algo de escritura "
+"en computador, considere el utilizar <literal>cascade=\"persist,merge,save-"
+"update\"</literal>."
 
 #. Tag: para
-#: session_api.xml:996
 #, no-c-format
 msgid ""
 "Mapping an association (either a single valued association, or a collection) "
@@ -2320,15 +1500,14 @@
 "<emphasis>parent/child</emphasis> style relationship where save/update/"
 "delete of the parent results in save/update/delete of the child or children."
 msgstr ""
-"Mapear una asociaci&#x00f3;n (ya sea una asociaci&#x00f3;n monovaluada, o "
-"una colecci&#x00f3;n) con <literal>cascade=\"all\"</literal> marca la "
-"asociaci&#x00f3;n como una relaci&#x00f3;n del estilo <emphasis>padre/hijo</"
-"emphasis> donde save/update/delete en el padre resulta en save/update/delete "
-"del hijo o hijos."
+"Mapear una asociación (ya sea una asociación monovaluada, o una colección) "
+"con <literal>cascade=\"all\"</literal> marca la asociación como una relación "
+"del estilo <emphasis>padre/hijo</emphasis> en donde guardar/actualizar/"
+"borrar (save/update/delete) el padre causa el guardar/actualizar/borrar del "
+"hijo o hijos."
 
 #. Tag: para
-#: session_api.xml:1002
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Furthermore, a mere reference to a child from a persistent parent will "
 "result in save/update of the child. This metaphor is incomplete, however. A "
@@ -2338,49 +1517,44 @@
 "literal>. The precise semantics of cascading operations for a parent/child "
 "relationship are as follows:"
 msgstr ""
-"Adem&#x00e1;s, una mera referencia a un hijo desde un padre persistente "
-"resultar&#x00e1; en un save/update del hijo. Esta met&#x00e1;fora "
-"est&#x00e1; incompleta, sin embargo. Un hijo que deje de ser referenciado "
-"por su padre <emphasis>no</emphasis> es borrado autom&#x00e1;ticamente, "
-"excepto en el caso de una asociaci&#x00f3;n <literal>&lt;one-to-many&gt;</"
-"literal> mapeada con <literal>cascade=\"delete-orphan\"</literal>. La "
-"sem&#x00e1;ntica precisa de las operaciones en cascada para una "
-"relaci&#x00f3;n padre/hijo es:"
+"Además, una mera referencia a un hijo desde un padre persistente hará que se "
+"guarde/actualice el hijo. Sin embargo, esta metáfora se encuentra "
+"incompleta. Un hijo que deje de ser referenciado por su padre <emphasis>no</"
+"emphasis> es borrado automáticamente, excepto en el caso de una asociación "
+"<literal>&lt;one-to-many&gt;</literal> mapeada con <literal>cascade=\"delete-"
+"orphan\"</literal>. La semántica precisa de las operaciones en cascada para "
+"una relación padre/hijo es la siguiente:"
 
 #. Tag: para
-#: session_api.xml:1013
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>persist()</literal>, all children are "
 "passed to <literal>persist()</literal>"
 msgstr ""
-"Si un padre le es pasado a <literal>persist()</literal>, todos los hijos le "
-"son pasados a <literal>persist()</literal>"
+"Si un padre pasa a <literal>persist()</literal>, se pasan todos los hijos a "
+"<literal>persist()</literal>"
 
 #. Tag: para
-#: session_api.xml:1019
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>merge()</literal>, all children are passed "
 "to <literal>merge()</literal>"
 msgstr ""
-"Si un padre le es pasado a <literal>merge()</literal>, todos los hijos le "
-"son pasados a <literal>merge()</literal>"
+"Si un padre pasa a <literal>merge()</literal>, se pasan todos los hijos a "
+"<literal>merge()</literal>"
 
 #. Tag: para
-#: session_api.xml:1025
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>save()</literal>, <literal>update()</"
 "literal> or <literal>saveOrUpdate()</literal>, all children are passed to "
 "<literal>saveOrUpdate()</literal>"
 msgstr ""
-"Si un padre le es pasado a <literal>save()</literal>, <literal>update()</"
-"literal> o <literal>saveOrUpdate()</literal>, todos los hijos le son pasados "
-"a <literal>saveOrUpdate()</literal>"
+"Si se pasa un padre a <literal>save()</literal>, <literal>update()</literal> "
+"o <literal>saveOrUpdate()</literal>, todos los hijos pasan a "
+"<literal>saveOrUpdate()</literal>"
 
 #. Tag: para
-#: session_api.xml:1031
 #, no-c-format
 msgid ""
 "If a transient or detached child becomes referenced by a persistent parent, "
@@ -2390,17 +1564,14 @@
 "persistente, le es pasado a <literal>saveOrUpdate()</literal>"
 
 #. Tag: para
-#: session_api.xml:1037
 #, no-c-format
 msgid ""
 "If a parent is deleted, all children are passed to <literal>delete()</"
 "literal>"
 msgstr ""
-"Si un padre es borrado, todos los hijos le son pasados a <literal>delete()</"
-"literal>"
+"Si se borra un padre, se pasan todos los hijos a <literal>delete()</literal>"
 
 #. Tag: para
-#: session_api.xml:1042
 #, no-c-format
 msgid ""
 "If a child is dereferenced by a persistent parent, <emphasis>nothing special "
@@ -2409,14 +1580,12 @@
 "case the \"orphaned\" child is deleted."
 msgstr ""
 "Si un hijo deja de ser referenciado por un padre persistente, <emphasis>no "
-"ocurre nada especial</emphasis> - la aplicaci&#x00f3;n debe borrar "
-"expl&#x00ed;citamente el hijo de ser necesario - a menos que "
-"<literal>cascade=\"delete-orphan\"</literal>, en cuyo caso el hijo "
-"\"hu&#x00e9;rfano\" es borrado."
+"ocurre nada especial</emphasis> - la aplicación debe borrar explícitamente "
+"el hijo de ser necesario - a menos que <literal>cascade=\"delete-orphan\"</"
+"literal>, en cuyo caso se borra el hijo \"huérfano\"."
 
 #. Tag: para
-#: session_api.xml:1051
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, note that cascading of operations can be applied to an object graph "
 "at <emphasis>call time</emphasis> or at <emphasis>flush time</emphasis>. All "
@@ -2425,22 +1594,22 @@
 "<literal>delete-orphan</literal> are transitive for all associated entities "
 "reachable during flush of the <literal>Session</literal>."
 msgstr ""
-"UNTRANSLATED!!! Finally, note that cascading of operations can be applied to "
-"an object graph at <emphasis>call time</emphasis> or at <emphasis>flush "
-"time</emphasis>. All operations, if enabled, are cascaded to associated "
-"entities reachable when the operation is executed. However, <literal>save-"
-"upate</literal> and <literal>delete-orphan</literal> are transitive for all "
-"associated entities reachable during flush of the <literal>Session</literal>."
+"Finalmente, note que las operaciones en cascadas se pueden aplicar a un "
+"grafo de objeto en <emphasis>tiempo de llamada</emphasis> o en "
+"<emphasis>tiempo de vaciado</emphasis>. Todas las operaciones, si se "
+"encuentran activadas se tratan en cascadas en entidades asociadas "
+"alcanzables cuando se ejecuta la operación. Sin embargo, <literal>save-"
+"upate</literal> y <literal>delete-orphan</literal> son transitivos para "
+"todas las entidades asociadas alcanzables durante el vaciado de la "
+"<literal>Session</literal>."
 
 #. Tag: title
-#: session_api.xml:1063
 #, no-c-format
 msgid "Using metadata"
-msgstr "Usando metadatos"
+msgstr "Utilización de metadatos"
 
 #. Tag: para
-#: session_api.xml:1065
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate requires a rich meta-level model of all entity and value types. "
 "This model can be useful to the application itself. For example, the "
@@ -2450,67 +1619,22 @@
 "and, possibly, associated entities)."
 msgstr ""
 "Hibernate requiere de un modelo de meta-nivel muy rico de todas las "
-"entidades y tipos de valor. De vez en cuando, este modelo es muy &#x00fa;til "
-"para la aplicaci&#x00f3;n misma. Por ejemplo, la aplicaci&#x00f3;n "
-"podr&#x00ed;a usar los metadatos de Hibernate para implementar un algoritmo "
-"\"inteligente\" de copia en profundidad que entienda qu&#x00e9; objetos "
-"deben ser copiados (por ejemplo, tipo de valor mutables) y cu&#x00e1;les no "
-"(por ejemplo, tipos de valor inmutables y, posiblemente, entidades "
-"asociadas)."
+"entidades y tipos de valor. Este modelo puede ser útil para la aplicación "
+"misma. Por ejemplo, la aplicación podría utilizar los metadatos de Hibernate "
+"para implementar un algoritmo \"inteligente\" de copia en profundidad que "
+"entienda qué objetos deben ser copiados (por ejemplo, tipos de valor "
+"mutables) y cuáles no (por ejemplo, tipos de valor inmutables y posiblemente "
+"las entidades asociadas)."
 
 #. Tag: para
-#: session_api.xml:1072
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate exposes metadata via the <literal>ClassMetadata</literal> and "
 "<literal>CollectionMetadata</literal> interfaces and the <literal>Type</"
 "literal> hierarchy. Instances of the metadata interfaces can be obtained "
 "from the <literal>SessionFactory</literal>."
 msgstr ""
-"Hibernate expone los metadatos v&#x00ed;a las interfaces "
+"Hibernate expone los metadatos por medio de las interfaces "
 "<literal>ClassMetadata</literal> y <literal>CollectionMetadata</literal> y "
-"la jerarqu&#x00ed;a <literal>Type</literal>. Las instancias de las "
-"interfaces de metadatos pueden obtenerse de <literal>SessionFactory</"
-"literal>."
-
-#. Tag: programlisting
-#: session_api.xml:1079
-#, no-c-format
-msgid ""
-"<![CDATA[Cat fritz = ......;\n"
-"ClassMetadata catMeta = sessionfactory.getClassMetadata(Cat.class);\n"
-"\n"
-"Object[] propertyValues = catMeta.getPropertyValues(fritz);\n"
-"String[] propertyNames = catMeta.getPropertyNames();\n"
-"Type[] propertyTypes = catMeta.getPropertyTypes();\n"
-"\n"
-"// get a Map of all properties which are not collections or associations\n"
-"Map namedValues = new HashMap();\n"
-"for ( int i=0; i<propertyNames.length; i++ ) {\n"
-"    if ( !propertyTypes[i].isEntityType() && !propertyTypes[i]."
-"isCollectionType() ) {\n"
-"        namedValues.put( propertyNames[i], propertyValues[i] );\n"
-"    }\n"
-"}]]>"
-msgstr ""
-"<![CDATA[Cat fritz = ......;\n"
-"ClassMetadata catMeta = sessionfactory.getClassMetadata(Cat.class);\n"
-"\n"
-"Object[] propertyValues = catMeta.getPropertyValues(fritz);\n"
-"String[] propertyNames = catMeta.getPropertyNames();\n"
-"Type[] propertyTypes = catMeta.getPropertyTypes();\n"
-"\n"
-"// get a Map of all properties which are not collections or associations\n"
-"Map namedValues = new HashMap();\n"
-"for ( int i=0; i<propertyNames.length; i++ ) {\n"
-"    if ( !propertyTypes[i].isEntityType() && !propertyTypes[i]."
-"isCollectionType() ) {\n"
-"        namedValues.put( propertyNames[i], propertyValues[i] );\n"
-"    }\n"
-"}]]>"
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+"la jerarquía <literal>Type</literal>. Las instancias de las interfaces de "
+"metadatos se pueden obtener de la <literal>SessionFactory</literal>."

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/toolset_guide.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/toolset_guide.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/toolset_guide.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,59 +1,68 @@
-#, fuzzy
+# translation of toolset_guide.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: toolset_guide\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-01-05 07:51+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: toolset_guide.xml:29
 #, no-c-format
 msgid "Toolset Guide"
-msgstr "Gu&#x00ed;a del Conjunto de Herramientas"
+msgstr "Manual del conjunto de herramientas"
 
 #. Tag: para
-#: toolset_guide.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Roundtrip engineering with Hibernate is possible using a set of Eclipse "
 "plugins, commandline tools, and Ant tasks."
 msgstr ""
-"La ingenier&#x00ed;a de ida y vuelta con Hibernate es posible usando un "
-"conjunto de plugins de Eclipse, herramientas de l&#x00ed;nea de comandos, "
-"as&#x00ed; como tareas de Ant."
+"La ingeniería compatible con Hibernate es posible utilizando un conjunto de "
+"plugins de Eclipse, herramientas de la línea de comandos así como tareas Ant."
 
 #. Tag: para
-#: toolset_guide.xml:36
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Hibernate Tools</emphasis> currently include plugins for the "
 "Eclipse IDE as well as Ant tasks for reverse engineering of existing "
 "databases:"
 msgstr ""
-"Las <emphasis>Herramientas de Hibernate</emphasis> actualmente incluyen "
-"plugins para la IDE de Eclipse as&#x00ed; como tareas de Ant para la "
-"ingenier&#x00ed;a inversa de bases de datos existentes:"
+"Las <emphasis>herramientas de Hibernate</emphasis> actualmente incluyen "
+"plugins la IDE de Eclipse así como tareas Ant para la ingeniería inversa de "
+"bases de datos existentes:"
 
 #. Tag: para
-#: toolset_guide.xml:42
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Mapping Editor:</emphasis> an editor for Hibernate XML mapping "
 "files that supports auto-completion and syntax highlighting. It also "
 "supports semantic auto-completion for class names and property/field names, "
 "making it more versatile than a normal XML editor."
 msgstr ""
-"<emphasis>Editor de Mapeo:</emphasis> Un editor de ficheros de mapeo XML, "
-"que soporta autocompleci&#x00f3;n y resaltado de sint&#x00e1;xis. Soporta "
-"tambi&#x00e9;n autocompleci&#x00f3;n sem&#x00e1;ntica de nombres de clases y "
-"nombres de campos/propiedades, haci&#x00e9;ndolo mucho m&#x00e1;s "
-"vers&#x00e1;til que un editor de XML normal."
+"<emphasis>Editor de Mapeo:</emphasis> Un editor de archivos de mapeo XML que "
+"soporta autocompleción y resaltado de sintáxis. También soporta la "
+"autocompleción semántica de nombres de clases y nombres de campos/"
+"propiedades, haciéndolo mucho más versátil que un editor normal de XML."
 
 #. Tag: para
-#: toolset_guide.xml:47
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Console:</emphasis> the console is a new view in Eclipse. In "
 "addition to a tree overview of your console configurations, you are also "
@@ -62,14 +71,13 @@
 "database and browse the result directly in Eclipse."
 msgstr ""
 "<emphasis>Consola:</emphasis> La consola es una nueva vista en Eclipse. "
-"Adem&#x00e1;s de la vista de &#x00e1;rbol de tus configuraciones de consola, "
-"tienes tambi&#x00e9;n una vista interactiva de tus clases persistentes y sus "
-"relaciones. La console te permite ejecutar consultas HQL contra tu base de "
-"datos y navegar el resultado directamente en Eclipse."
+"Además de la vista de árbol de sus configuraciones de la consola, también "
+"tiene una vista interactiva de sus clases persistentes y sus relaciones. La "
+"consola le permite ejecutar consultas HQL en su base de datos y navegar el "
+"resultado directamente en Eclipse."
 
 #. Tag: para
-#: toolset_guide.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Development Wizards:</emphasis> several wizards are provided with "
 "the Hibernate Eclipse tools. You can use a wizard to quickly generate "
@@ -77,280 +85,164 @@
 "database schema into POJO source files and Hibernate mapping files. The "
 "reverse engineering wizard supports customizable templates."
 msgstr ""
-"<emphasis>Asistentes de Desarrollo:</emphasis> Se proveen muchos asistentes "
-"con las herramientas de Eclipse. Puedes usar un asistente para generar "
-"r&#x00e1;pidamente ficheros de configuraci&#x00f3;n de Hibernate (cfg.xml), "
-"o incluso puedes haceruna ingenier&#x00ed;a inversa completa de un esquema "
-"de base de datos existente en ficheros de c&#x00f3;digo de POJO y ficheros "
-"de mapeo de Hibernate. El asistente de ingenier&#x00ed;a inversa soporta "
-"plantillas personalizables."
+"<emphasis>Asistentes de desarrollo:</emphasis> Se proporcionan muchos "
+"asistentes junto con las herramientas Eclipse de Hibernate. Puede utilizar "
+"un asistente para generar rápidamente los archivos de configuración de "
+"Hibernate (cfg.xml), o incluso puede realizar una ingeniería inversa "
+"completa de un esquema de la base de datos existente en los archivos de "
+"código fuente de POJO y los archivos de mapeo de Hibernate. El asistente de "
+"ingeniería inversa soporta plantillas personalizables."
 
 #. Tag: para
-#: toolset_guide.xml:67
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please refer to the <emphasis>Hibernate Tools</emphasis> package "
 "documentation for more information."
 msgstr ""
-"Por favor refi&#x00e9;rete al paquete <emphasis>Herramientas de Hibernate</"
-"emphasis> y su documentaci&#x00f3;n para m&#x00e1;s informaci&#x00f3;n."
+"Por favor refiérase al paquete de documentación de las "
+"<emphasis>Herramientas de Hibernate</emphasis> para obtener más información."
 
 #. Tag: para
-#: toolset_guide.xml:72
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, the Hibernate main package comes bundled with an integrated tool : "
 "<emphasis>SchemaExport</emphasis> aka <literal>hbm2ddl</literal>.It can even "
 "be used from \"inside\" Hibernate."
 msgstr ""
-"Sin embargo, el paquete principal de Hibernate viene incluyendo una "
-"herramienta integrada (puede ser usada incluso \"dentro\" de Hibernate on-"
-"the-fly): <emphasis>SchemaExport</emphasis> tambi&#x00e9;n conocido como "
-"<literal>hbm2ddl</literal>."
+"Sin embargo, el paquete principal de Hibernate viene con una herramienta "
+"integrada: <emphasis>SchemaExport</emphasis> también conocida como "
+"<literal>hbm2ddl</literal>. Incluso se puede utilizar \"dentro\" de "
+"Hibernate."
 
 #. Tag: title
-#: toolset_guide.xml:79
 #, no-c-format
 msgid "Automatic schema generation"
-msgstr "Generaci&#x00f3;n autom&#x00e1;tica de esquemas"
+msgstr "Generación automática de esquemas"
 
 #. Tag: para
-#: toolset_guide.xml:81
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "DDL can be generated from your mapping files by a Hibernate utility. The "
 "generated schema includes referential integrity constraints, primary and "
 "foreign keys, for entity and collection tables. Tables and sequences are "
 "also created for mapped identifier generators."
 msgstr ""
-"Una utilidad de Hibernate puede generar DDL desde tus ficheros de mapeo. El "
-"esquema generado incluye restricciones de integridad referencial (claves "
-"primarias y for&#x00e1;neas) para las tablas de entidades y colecciones. Las "
-"tablas y secuencias tambi&#x00e9;n son creadas para los generadores de "
-"identificadores mapeados."
+"Una de las funciones de Hibernate puede generar DDL desde sus archivos de "
+"mapeo. El esquema generado incluye restricciones de integridad referencial, "
+"claves principales y foráneas, para las tablas de entidades y colecciones. "
+"También se creen tablas y secuencias para los generadores de identificadores "
+"mapeados."
 
 #. Tag: para
-#: toolset_guide.xml:88
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You <emphasis>must</emphasis> specify a SQL <literal>Dialect</literal> via "
 "the <literal>hibernate.dialect</literal> property when using this tool, as "
 "DDL is highly vendor-specific."
 msgstr ""
-"<emphasis>Debes</emphasis> especificar un <literal>Dialecto</literal> SQL "
-"v&#x00ed;a la propiedad <literal>hibernate.dialect</literal> al usar esta "
-"herramienta, ya que el DDL es altamente espec&#x00ed;fico del vendedor."
+"<emphasis>Tiene</emphasis> que especificar un <literal>Dialecto</literal> "
+"SQL por medio de la propiedad <literal>hibernate.dialect</literal> al usar "
+"esta herramienta, ya que el DDL es altamente específico de acuerdo con el "
+"vendedor."
 
 #. Tag: para
-#: toolset_guide.xml:94
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, you must customize your mapping files to improve the generated "
 "schema. The next section covers schema customization."
-msgstr "First, customize your mapping files to improve the generated schema."
+msgstr ""
+"Primero, debe personazar sus archivos de mapeo para mejorar el esquema "
+"generado. La siguiente sección aborda la personalización del esquema. "
 
 #. Tag: title
-#: toolset_guide.xml:99
 #, no-c-format
 msgid "Customizing the schema"
-msgstr "Personalizando el esquema"
+msgstr "Personalización del esquema"
 
 #. Tag: para
-#: toolset_guide.xml:101
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Many Hibernate mapping elements define optional attributes named "
 "<literal>length</literal>, <literal>precision</literal> and <literal>scale</"
 "literal>. You can set the length, precision and scale of a column with this "
 "attribute."
 msgstr ""
-"Muchos elementos de mapeo de Hibernate definen un atributo opcional llamado "
-"<literal>length</literal>. Con este atributo puedes establecer el "
-"tama&#x00f1;o de una columna. (O, para tipos de datos num&#x00e9;ricos/"
-"decimales, la precisi&#x00f3;n.)"
+"Muchos elementos de mapeo de Hibernate definen atributos opcionales "
+"denominados <literal>length</literal>, <literal>precision</literal> y "
+"<literal>scale</literal>. Con estos atributos puede establecer el tamaño, la "
+"precisión y la escala de una columna."
 
-#. Tag: programlisting
-#: toolset_guide.xml:108
-#, no-c-format
-msgid "<![CDATA[<property name=\"zip\" length=\"5\"/>]]>"
-msgstr "<![CDATA[<property name=\"zip\" length=\"5\"/>]]>"
-
-#. Tag: programlisting
-#: toolset_guide.xml:109
-#, no-c-format
-msgid "<![CDATA[<property name=\"balance\" precision=\"12\" scale=\"2\"/>]]>"
-msgstr "<![CDATA[<property name=\"balance\" precision=\"12\" scale=\"2\"/>]]>"
-
 #. Tag: para
-#: toolset_guide.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Some tags also accept a <literal>not-null</literal> attribute for generating "
 "a <literal>NOT NULL</literal> constraint on table columns, and a "
 "<literal>unique</literal> attribute for generating <literal>UNIQUE</literal> "
 "constraint on table columns."
 msgstr ""
-"Algunas etiquetas tambi&#x00e9;n aceptan un atributo <literal>not-null</"
-"literal> (para generar una restricci&#x00f3;n <literal>NOT NULL</literal> en "
-"columnas de tablas) y y un atributo <literal>unique</literal> (para generar "
-"restricciones <literal>UNIQUE</literal> en columnas de tablas)."
+"Algunas etiquetas también aceptan un atributo <literal>not-null</literal> "
+"para generar una restricción <literal>NOT NULL</literal> en columnas de "
+"tablas y un atributo <literal>unique</literal> para generar restricciones "
+"<literal>UNIQUE</literal> en columnas de tablas."
 
-#. Tag: programlisting
-#: toolset_guide.xml:117
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"bar\" column=\"barId\" not-null=\"true\"/>]]>"
-msgstr ""
-"<![CDATA[<many-to-one name=\"bar\" column=\"barId\" not-null=\"true\"/>]]>"
-
-#. Tag: programlisting
-#: toolset_guide.xml:119
-#, no-c-format
-msgid ""
-"<![CDATA[<element column=\"serialNumber\" type=\"long\" not-null=\"true\" "
-"unique=\"true\"/>]]>"
-msgstr ""
-"<![CDATA[<element column=\"serialNumber\" type=\"long\" not-null=\"true\" "
-"unique=\"true\"/>]]>"
-
-#. Tag: para
-#: toolset_guide.xml:121
-#, fuzzy, no-c-format
-msgid ""
 "A <literal>unique-key</literal> attribute can be used to group columns in a "
 "single, unique key constraint. Currently, the specified value of the "
 "<literal>unique-key</literal> attribute is <emphasis>not</emphasis> used to "
 "name the constraint in the generated DDL. It is only used to group the "
 "columns in the mapping file."
 msgstr ""
-"A <literal>unique-key</literal> attribute may be used to group columns in a "
-"single unique key constraint. Currently, the specified value of the "
-"<literal>unique-key</literal> attribute is <emphasis>not</emphasis> used to "
-"name the constraint in the generated DDL, only to group the columns in the "
-"mapping file."
+"Se puede usar un atributo <literal>unique-key</literal> para agrupar "
+"columnas en una restricción de clave única. Actualmente, el valor "
+"especificado del atributo <literal>unique-key</literal><emphasis>no</"
+"emphasis> se utiliza para nombrar la restricción en el DDL generado. "
+"Sólamente se utiliza para agrupar las columnas en el archivo de mapeo."
 
-#. Tag: programlisting
-#: toolset_guide.xml:129
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"org\" column=\"orgId\" unique-key="
-"\"OrgEmployeeId\"/>\n"
-"<property name=\"employeeId\" unique-key=\"OrgEmployee\"/>]]>"
-msgstr ""
-"<![CDATA[<many-to-one name=\"org\" column=\"orgId\" unique-key="
-"\"OrgEmployeeId\"/>\n"
-"<property name=\"employeeId\" unique-key=\"OrgEmployee\"/>]]>"
-
-#. Tag: para
-#: toolset_guide.xml:131
-#, fuzzy, no-c-format
-msgid ""
 "An <literal>index</literal> attribute specifies the name of an index that "
 "will be created using the mapped column or columns. Multiple columns can be "
 "grouped into the same index by simply specifying the same index name."
 msgstr ""
-"An <literal>index</literal> attribute specifies the name of an index that "
-"will be created using the mapped column or columns. Multiple columns may be "
-"grouped into the same index, simply by specifying the same index name."
+"Un atributo <literal>index</literal> especifica el nombre de un índice que "
+"se creará utilizando la columa o las columnas mapeadas. Se pueden ser "
+"agrupar múltiples columnas bajo el mismo índice, simplemente especificando "
+"el mismo nombre de índice. "
 
-#. Tag: programlisting
-#: toolset_guide.xml:137
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<property name=\"lastName\" index=\"CustName\"/>\n"
-"<property name=\"firstName\" index=\"CustName\"/>]]>"
-msgstr ""
-"<![CDATA[<property name=\"lastName\" index=\"CustName\"/>\n"
-"        <property name=\"firstName\" index=\"CustName\"/>]]>"
-
-#. Tag: para
-#: toolset_guide.xml:139
-#, fuzzy, no-c-format
-msgid ""
 "A <literal>foreign-key</literal> attribute can be used to override the name "
 "of any generated foreign key constraint."
 msgstr ""
-"A <literal>foreign-key</literal> attribute may be used to override the name "
-"of any generated foreign key constraint."
+"Un atributo <literal>foreign-key</literal> se puede utilizar para "
+"sobreescribir el nombre de cualquier restricción de clave foránea generada."
 
-#. Tag: programlisting
-#: toolset_guide.xml:144
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"bar\" column=\"barId\" foreign-key=\"FKFooBar\"/"
-">]]>"
-msgstr ""
-"<![CDATA[<many-to-one name=\"bar\" column=\"barId\" foreign-key=\"FKFooBar\"/"
-">]]>"
-
 #. Tag: para
-#: toolset_guide.xml:146
 #, no-c-format
 msgid ""
 "Many mapping elements also accept a child <literal>&lt;column&gt;</literal> "
 "element. This is particularly useful for mapping multi-column types:"
 msgstr ""
-"Many mapping elements also accept a child <literal>&lt;column&gt;</literal> "
-"element. This is particularly useful for mapping multi-column types:"
+"Muchos elementos de mapeo también aceptan un elemento <literal>&lt;column&gt;"
+"</literal> hijo. Esto es particularmente útil para mapear tipos de multi-"
+"columna:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:151
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<property name=\"name\" type=\"my.customtypes.Name\"/>\n"
-"    <column name=\"last\" not-null=\"true\" index=\"bar_idx\" length=\"30\"/"
-">\n"
-"    <column name=\"first\" not-null=\"true\" index=\"bar_idx\" length=\"20\"/"
-">\n"
-"    <column name=\"initial\"/>\n"
-"</property>]]>"
-msgstr ""
-"<![CDATA[<property name=\"name\" type=\"my.customtypes.Name\"/>\n"
-"        <column name=\"last\" not-null=\"true\" index=\"bar_idx\" length=\"30"
-"\"/>\n"
-"        <column name=\"first\" not-null=\"true\" index=\"bar_idx\" length="
-"\"20\"/>\n"
-"        <column name=\"initial\"/>\n"
-"</property>]]>"
-
-#. Tag: para
-#: toolset_guide.xml:153
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>default</literal> attribute allows you to specify a default "
 "value for a column.You should assign the same value to the mapped property "
 "before saving a new instance of the mapped class."
 msgstr ""
-"The <literal>default</literal> attribute lets you specify a default value "
-"for a column (you should assign the same value to the mapped property before "
-"saving a new instance of the mapped class)."
+"El atributo <literal>default</literal> le permite especificar un valor por "
+"defecto para una columna. Usted le debe asignar el mismo valor a la "
+"propiedad mapeada antes de guardar una nueva instancia de la clase mapeada."
 
-#. Tag: programlisting
-#: toolset_guide.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"credits\" type=\"integer\" insert=\"false\">\n"
-"    <column name=\"credits\" default=\"10\"/>\n"
-"</property>]]>"
-msgstr ""
-"<![CDATA[<property name=\"credits\" type=\"integer\" insert=\"false\">\n"
-"                <column name=\"credits\" default=\"10\"/>\n"
-"        </property>]]>"
-
-#. Tag: programlisting
-#: toolset_guide.xml:161
-#, no-c-format
-msgid ""
-"<![CDATA[<version name=\"version\" type=\"integer\" insert=\"false\">\n"
-"    <column name=\"version\" default=\"0\"/>\n"
-"</property>]]>"
-msgstr ""
-"<![CDATA[<version name=\"version\" type=\"integer\" insert=\"false\">\n"
-"                <column name=\"version\" default=\"0\"/>\n"
-"        </property>]]>"
-
 #. Tag: para
-#: toolset_guide.xml:163
 #, no-c-format
 msgid ""
 "The <literal>sql-type</literal> attribute allows the user to override the "
@@ -359,209 +251,141 @@
 "El atributo <literal>sql-type</literal> permite al usuario sobrescribir el "
 "mapeo por defecto de tipo Hibernate a tipo de datos SQL."
 
-#. Tag: programlisting
-#: toolset_guide.xml:168
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"balance\" type=\"float\">\n"
-"    <column name=\"balance\" sql-type=\"decimal(13,3)\"/>\n"
-"</property>]]>"
-msgstr ""
-"<![CDATA[<property name=\"balance\" type=\"float\">\n"
-"                            <column name=\"balance\" sql-type=\"decimal(13,3)"
-"\"/>\n"
-"</property>]]>"
-
 #. Tag: para
-#: toolset_guide.xml:170
 #, no-c-format
 msgid ""
 "The <literal>check</literal> attribute allows you to specify a check "
 "constraint."
 msgstr ""
-"El atributo <literal>check</literal> te permite especificar una "
-"comprobaci&#x00f3;n de restricci&#x00f3;n."
+"El atributo <literal>check</literal> le permite especificar una comprobación "
+"de restricción."
 
-#. Tag: programlisting
-#: toolset_guide.xml:174
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"foo\" type=\"integer\">\n"
-"    <column name=\"foo\" check=\"foo > 10\"/>\n"
-"</property>]]>"
-msgstr ""
-"<![CDATA[<property name=\"foo\" type=\"integer\">\n"
-"    <column name=\"foo\" check=\"foo > 10\"/>\n"
-"</property>]]>"
-
-#. Tag: programlisting
-#: toolset_guide.xml:176
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Foo\" table=\"foos\" check=\"bar < 100.0\">\n"
-"    ...\n"
-"    <property name=\"bar\" type=\"float\"/>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Foo\" table=\"foos\" check=\"bar < 100.0\">\n"
-"    ...\n"
-"    <property name=\"bar\" type=\"float\"/>\n"
-"</class>]]>"
-
 #. Tag: para
-#: toolset_guide.xml:179
 #, no-c-format
 msgid "The following table summarizes these optional attributes."
-msgstr ""
+msgstr "La siguiente tabla resume estos atributos opcionales. "
 
 #. Tag: title
-#: toolset_guide.xml:182
 #, no-c-format
 msgid "Summary"
 msgstr "Resumen"
 
 #. Tag: entry
-#: toolset_guide.xml:189
 #, no-c-format
 msgid "Attribute"
 msgstr "Atributo"
 
 #. Tag: entry
-#: toolset_guide.xml:190
 #, no-c-format
 msgid "Values"
 msgstr "Valores"
 
 #. Tag: entry
-#: toolset_guide.xml:191
 #, no-c-format
 msgid "Interpretation"
-msgstr "Interpretaci&#x00f3;n"
+msgstr "Interpretación"
 
-#. Tag: literal
-#: toolset_guide.xml:196
+#. Tag: entry
 #, no-c-format
-msgid "length"
-msgstr "length"
+msgid "<literal>length</literal>"
+msgstr "<literal>length</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:197 toolset_guide.xml:202 toolset_guide.xml:207
 #, no-c-format
 msgid "number"
-msgstr "number"
+msgstr "número"
 
 #. Tag: entry
-#: toolset_guide.xml:198
 #, no-c-format
 msgid "column length"
-msgstr "largo de columna/precisi&#x00f3;n decimal"
+msgstr "longitud de columna/precisión decimal"
 
-#. Tag: literal
-#: toolset_guide.xml:201
+#. Tag: entry
 #, no-c-format
-msgid "precision"
-msgstr "precision"
+msgid "<literal>precision</literal>"
+msgstr "<literal>precision</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:203
 #, no-c-format
 msgid "column decimal precision"
-msgstr "column decimal precision"
+msgstr "precisión decimal de columna"
 
-#. Tag: literal
-#: toolset_guide.xml:206
+#. Tag: entry
 #, no-c-format
-msgid "scale"
-msgstr "scale"
+msgid "<literal>scale</literal>"
+msgstr "<literal>scale</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:208
 #, no-c-format
 msgid "column decimal scale"
-msgstr "column decimal scale"
+msgstr "escala decimal de columna"
 
-#. Tag: literal
-#: toolset_guide.xml:211
+#. Tag: entry
 #, no-c-format
-msgid "not-null"
-msgstr "not-null"
+msgid "<literal>not-null</literal>"
+msgstr "<literal>not-null</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:212 toolset_guide.xml:217
+#. Tag: entry
 #, no-c-format
-msgid "true|false"
-msgstr "true|false"
+msgid "<literal>true|false</literal>"
+msgstr "<literal>true|false</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:213
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "specifies that the column should be non-nullable"
-msgstr "especifica que la columna debe ser no nulable"
+msgstr "especifica que la columna debe ser sin nulos"
 
-#. Tag: literal
-#: toolset_guide.xml:216
+#. Tag: entry
 #, no-c-format
-msgid "unique"
-msgstr "unique"
+msgid "<literal>unique</literal>"
+msgstr "<literal>unique</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:218
 #, no-c-format
 msgid "specifies that the column should have a unique constraint"
-msgstr ""
-"especifica que la columna debe tener una restricci&#x00f3;n de unicidad"
+msgstr "especifica que la columna debe tener una restricción de unicidad"
 
-#. Tag: literal
-#: toolset_guide.xml:221
+#. Tag: entry
 #, no-c-format
-msgid "index"
-msgstr "index"
+msgid "<literal>index</literal>"
+msgstr "<literal>index</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:222
+#. Tag: entry
 #, no-c-format
-msgid "index_name"
-msgstr "index_name"
+msgid "<literal>index_name</literal>"
+msgstr "<literal>index_name</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:223
 #, no-c-format
 msgid "specifies the name of a (multi-column) index"
-msgstr "especifica el nombre de un &#x00ed;ndice (multicolumna)"
+msgstr "especifica el nombre de un índice (multicolumna)"
 
-#. Tag: literal
-#: toolset_guide.xml:226
+#. Tag: entry
 #, no-c-format
-msgid "unique-key"
-msgstr "unique-key"
+msgid "<literal>unique-key</literal>"
+msgstr "<literal>unique-key</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:227
-#, no-c-format
-msgid "unique_key_name"
-msgstr "unique_key_name"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>unique_key_name</literal>"
+msgstr "<literal>unique-key</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:228
 #, no-c-format
 msgid "specifies the name of a multi-column unique constraint"
-msgstr ""
-"especifica el nombre de una restricci&#x00f3;n de unicidad multicolumna"
+msgstr "especifica el nombre de una restricción de unicidad multicolumna"
 
-#. Tag: literal
-#: toolset_guide.xml:231
+#. Tag: entry
 #, no-c-format
-msgid "foreign-key"
-msgstr "foreign-key"
+msgid "<literal>foreign-key</literal>"
+msgstr "<literal>foreign-key</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:232
-#, no-c-format
-msgid "foreign_key_name"
-msgstr "foreign_key_name"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>foreign_key_name</literal>"
+msgstr "<literal>foreign-key</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:233
 #, no-c-format
 msgid ""
 "specifies the name of the foreign key constraint generated for an "
@@ -570,601 +394,403 @@
 "to-many&gt;</literal> mapping element. Note that <literal>inverse=\"true\"</"
 "literal> sides will not be considered by <literal>SchemaExport</literal>."
 msgstr ""
-"especifica el nombre de la restricci&#x00f3;n de clave for&#x00e1;nea "
-"generada por una asociaci&#x00f3;n, &#x00fa;salo e <literal>&lt;one-to-"
-"one&gt;</literal>, <literal>&lt;many-to-one&gt;</literal>, <literal>&lt;"
-"key&gt;</literal>, or <literal>&lt;many-to-many&gt;</literal> . Nota que los "
-"lados <literal>inverse=\"true\"</literal> no ser&#x00e1;n considerados por "
-"<literal>SchemaExport</literal>."
+"especifica el nombre de la restricción de clave foránea generada por una "
+"asociación, para un elemento de mapeo <literal>&lt;one-to-one&gt;</literal>, "
+"<literal>&lt;many-to-one&gt;</literal>, <literal>&lt;key&gt;</literal>, o "
+"<literal>&lt;many-to-many&gt;</literal>. Observe que <literal>SchemaExport</"
+"literal> no considerará los lados <literal>inverse=\"true\"</literal>."
 
-#. Tag: literal
-#: toolset_guide.xml:243
+#. Tag: entry
 #, no-c-format
-msgid "sql-type"
-msgstr "sql-type"
+msgid "<literal>sql-type</literal>"
+msgstr "<literal>sql-type</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:244
-#, no-c-format
-msgid "SQL column type"
-msgstr "column_type"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>SQL column type</literal>"
+msgstr "<literal>sql-type</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:245
 #, no-c-format
 msgid ""
 "overrides the default column type (attribute of <literal>&lt;column&gt;</"
 "literal> element only)"
 msgstr ""
-"sobrescribe el tipo de columna por defecto (s&#x00f3;lo atributo del "
+"sobrescribe el tipo de columna por defecto (sólamente el atributo del "
 "elemento <literal>&lt;column&gt;</literal>)"
 
-#. Tag: literal
-#: toolset_guide.xml:251
+#. Tag: entry
 #, no-c-format
-msgid "default"
-msgstr "default"
+msgid "<literal>default</literal>"
+msgstr "<literal>default</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:252 toolset_guide.xml:259
 #, no-c-format
 msgid "SQL expression"
-msgstr "SQL expression"
+msgstr "expresión SQL"
 
 #. Tag: entry
-#: toolset_guide.xml:253
 #, no-c-format
 msgid "specify a default value for the column"
-msgstr "specify a default value for the column"
+msgstr "especifica un valor predeterminado para la columna"
 
-#. Tag: literal
-#: toolset_guide.xml:258
+#. Tag: entry
 #, no-c-format
-msgid "check"
-msgstr "check"
+msgid "<literal>check</literal>"
+msgstr "<literal>check</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:260
 #, no-c-format
 msgid "create an SQL check constraint on either column or table"
-msgstr ""
-"crea una restricci&#x00f3;n de comprobaci&#x00f3;n SQL en columna o tabla"
+msgstr "crea una restricción de comprobación SQL en columna o tabla"
 
 #. Tag: para
-#: toolset_guide.xml:268
 #, no-c-format
 msgid ""
 "The <literal>&lt;comment&gt;</literal> element allows you to specify "
 "comments for the generated schema."
 msgstr ""
-"El elemento <literal>&lt;comment&gt;</literal> te permite especificar un "
+"El elemento <literal>&lt;comment&gt;</literal> le permite especificar un "
 "comentario para el esquema generado."
 
-#. Tag: programlisting
-#: toolset_guide.xml:273
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Customer\" table=\"CurCust\">\n"
-"    <comment>Current customers only</comment>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Customer\" table=\"CurCust\">\n"
-"    <comment>Current customers only</comment>\n"
-"    ...\n"
-"</class>]]>"
-
-#. Tag: programlisting
-#: toolset_guide.xml:275
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"balance\">\n"
-"    <column name=\"bal\">\n"
-"        <comment>Balance in USD</comment>\n"
-"    </column>\n"
-"</property>]]>"
-msgstr ""
-"<![CDATA[<property name=\"balance\">\n"
-"    <column name=\"bal\">\n"
-"        <comment>Balance in USD</comment>\n"
-"    </column>\n"
-"</property>]]>"
-
-#. Tag: para
-#: toolset_guide.xml:277
-#, fuzzy, no-c-format
-msgid ""
 "This results in a <literal>comment on table</literal> or <literal>comment on "
 "column</literal> statement in the generated DDL where supported."
 msgstr ""
-"Esto resulta en una sentencia <literal>comment on table</literal> o "
-"<literal>comment on column</literal> en el DDL generado (donde est&#x00e9; "
-"soportado)."
+"Esto da como resultado una declaración <literal>comment on table</literal> o "
+"<literal>comment on column</literal> en el DDL generado, donde se encuentre "
+"soportado."
 
 #. Tag: title
-#: toolset_guide.xml:286
 #, no-c-format
 msgid "Running the tool"
-msgstr "Ejecutando la herramienta"
+msgstr "Ejecución de la herramienta"
 
 #. Tag: para
-#: toolset_guide.xml:288
 #, no-c-format
 msgid ""
 "The <literal>SchemaExport</literal> tool writes a DDL script to standard out "
 "and/or executes the DDL statements."
 msgstr ""
-"La herramienta <literal>SchemaExport</literal> escribe un gui&#x00f3;n DDL a "
-"la salida est&#x00e1;ndar y/o ejecuta las sentencias DDL."
+"La herramienta <literal>SchemaExport</literal> escribe un script DDL a la "
+"salida estándar y/o ejecuta las declaraciones DDL."
 
 #. Tag: para
-#: toolset_guide.xml:293
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table displays the <literal>SchemaExport</literal> command "
 "line options"
 msgstr ""
-"Opciones de L&#x00ed;nea de Comandos de <literal>SchemaExport</literal>"
+"La siguiente tabla presenta las opciones de la línea de comandos de "
+"<literal>SchemaExport</literal>"
 
 #. Tag: para
-#: toolset_guide.xml:295
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
 "<literal>org.hibernate.tool.hbm2ddl.SchemaExport</literal> <emphasis>options "
 "mapping_files</emphasis>"
 msgstr ""
-"<literal>java -cp </literal><emphasis>classpaths_de_hibernate</emphasis> "
-"<literal>org.hibernate.tool.hbm2ddl.SchemaExport</literal> "
-"<emphasis>opciones ficheros_de_mapeo</emphasis>"
+"<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
+"<literal>org.hibernate.tool.hbm2ddl.SchemaExport</literal> <emphasis>options "
+"mapping_files</emphasis>"
 
 #. Tag: title
-#: toolset_guide.xml:301
 #, no-c-format
 msgid "<literal>SchemaExport</literal> Command Line Options"
-msgstr ""
-"Opciones de L&#x00ed;nea de Comandos de <literal>SchemaExport</literal>"
+msgstr "Opciones de Línea de Comandos de <literal>SchemaExport</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:307 toolset_guide.xml:457 toolset_guide.xml:526
 #, no-c-format
 msgid "Option"
-msgstr "Opci&#x00f3;n"
+msgstr "Opción"
 
 #. Tag: entry
-#: toolset_guide.xml:308 toolset_guide.xml:395 toolset_guide.xml:458
-#: toolset_guide.xml:527
 #, no-c-format
 msgid "Description"
-msgstr "Descripci&#x00f3;n"
+msgstr "Descripción"
 
-#. Tag: literal
-#: toolset_guide.xml:313 toolset_guide.xml:463
+#. Tag: entry
 #, no-c-format
-msgid "--quiet"
-msgstr "--quiet"
+msgid "<literal>--quiet</literal>"
+msgstr "<literal>--quiet</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:314 toolset_guide.xml:464
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "do not output the script to stdout"
-msgstr "no enviar a salida est&#x00e1;ndar el gui&#x00f3;n"
+msgstr "no envie el script a la salida estándar"
 
-#. Tag: literal
-#: toolset_guide.xml:317
+#. Tag: entry
 #, no-c-format
-msgid "--drop"
-msgstr "--drop"
+msgid "<literal>--drop</literal>"
+msgstr "<literal>--drop</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:318
 #, no-c-format
 msgid "only drop the tables"
-msgstr "s&#x00f3;lo desechar las tablas"
+msgstr "sólamente desechar las tablas"
 
-#. Tag: literal
-#: toolset_guide.xml:321
+#. Tag: entry
 #, no-c-format
-msgid "--create"
-msgstr "--create"
+msgid "<literal>--create</literal>"
+msgstr "<literal>--create</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:322
 #, no-c-format
 msgid "only create the tables"
-msgstr "only create the tables"
+msgstr "sólamente crear las tablas"
 
-#. Tag: literal
-#: toolset_guide.xml:325 toolset_guide.xml:467
+#. Tag: entry
 #, no-c-format
-msgid "--text"
-msgstr "--text"
+msgid "<literal>--text</literal>"
+msgstr "<literal>--text</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:326
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "do not export to the database"
-msgstr "no exportar a la base de datos"
+msgstr "no exportar a la base de datos "
 
-#. Tag: literal
-#: toolset_guide.xml:329
-#, no-c-format
-msgid "--output=my_schema.ddl"
-msgstr "--output=my_schema.ddl"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--output=my_schema.ddl</literal>"
+msgstr "<literal>scale</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:330
 #, no-c-format
 msgid "output the ddl script to a file"
-msgstr "enviar la salida del gui&#x00f3;n ddl a un fichero"
+msgstr "enviar la salida del script ddl a un archivo"
 
-#. Tag: literal
-#: toolset_guide.xml:333 toolset_guide.xml:471 toolset_guide.xml:532
-#, no-c-format
-msgid "--naming=eg.MyNamingStrategy"
-msgstr "--naming=eg.MyNamingStrategy"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--naming=eg.MyNamingStrategy</literal>"
+msgstr "<literal>--naming=eg.MyNamingStrategy</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:334 toolset_guide.xml:472 toolset_guide.xml:533
 #, no-c-format
 msgid "select a <literal>NamingStrategy</literal>"
-msgstr "select a <literal>NamingStrategy</literal>"
+msgstr "seleccione un <literal>NamingStrategy</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:337 toolset_guide.xml:479 toolset_guide.xml:540
-#, no-c-format
-msgid "--config=hibernate.cfg.xml"
-msgstr "--config=hibernate.cfg.xml"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--config=hibernate.cfg.xml</literal>"
+msgstr "<literal>--config=hibernate.cfg.xml</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:338
 #, no-c-format
 msgid "read Hibernate configuration from an XML file"
-msgstr "lee la configuraci&#x00f3;n de Hibernate de un fichero XML"
+msgstr "lee la configuración de Hibernate de un archivo XML"
 
-#. Tag: literal
-#: toolset_guide.xml:341 toolset_guide.xml:475 toolset_guide.xml:536
-#, no-c-format
-msgid "--properties=hibernate.properties"
-msgstr "--properties=hibernate.properties"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--properties=hibernate.properties</literal>"
+msgstr "en <literal>hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:342 toolset_guide.xml:476 toolset_guide.xml:537
 #, no-c-format
 msgid "read database properties from a file"
-msgstr "lee las propiedades de base de datos de un fichero"
+msgstr "lee las propiedades de base de datos de un archivo"
 
-#. Tag: literal
-#: toolset_guide.xml:345
+#. Tag: entry
 #, no-c-format
-msgid "--format"
-msgstr "--format"
+msgid "<literal>--format</literal>"
+msgstr "<literal>--format</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:346
 #, no-c-format
 msgid "format the generated SQL nicely in the script"
-msgstr "formatea agradablemente el SQL generado en el gui&#x00f3;n"
+msgstr "formatea muy bien el SQL generado en el script"
 
-#. Tag: literal
-#: toolset_guide.xml:349
+#. Tag: entry
 #, no-c-format
-msgid "--delimiter=;"
-msgstr "--delimiter=x"
+msgid "<literal>--delimiter=;</literal>"
+msgstr "<literal>--delimiter=;</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:350
 #, no-c-format
 msgid "set an end of line delimiter for the script"
-msgstr "establece un delimitador de fin de l&#x00ed;nea para el gui&#x00f3;n"
+msgstr "establece un delimitador de fin de línea para el script"
 
 #. Tag: para
-#: toolset_guide.xml:356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can even embed <literal>SchemaExport</literal> in your application:"
 msgstr ""
-"Puedes incluso encajar <literal>SchemaExport</literal> en tu aplicaci&#x00f3;"
-"n:"
+"Inclusive puede incluir <literal>SchemaExport</literal> en su aplicación: "
 
-#. Tag: programlisting
-#: toolset_guide.xml:360
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaExport(cfg).create(false, true);]]>"
-msgstr ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaExport(cfg).create(false, true);]]>"
-
 #. Tag: title
-#: toolset_guide.xml:365
 #, no-c-format
 msgid "Properties"
 msgstr "Propiedades"
 
 #. Tag: para
-#: toolset_guide.xml:367
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Database properties can be specified:"
-msgstr "Las propiedades de base de datos pueden especificarse"
+msgstr "Las propiedades de la base de datos se pueden especificar:"
 
 #. Tag: para
-#: toolset_guide.xml:373
 #, no-c-format
 msgid ""
 "as system properties with <literal>-D</literal><emphasis>&lt;property&gt;</"
 "emphasis>"
 msgstr ""
-"como propiedades de sistema con <literal>-D</literal><emphasis>&lt;"
+"como propiedades del sistema con <literal>-D</literal><emphasis>&lt;"
 "property&gt;</emphasis>"
 
 #. Tag: para
-#: toolset_guide.xml:376
 #, no-c-format
 msgid "in <literal>hibernate.properties</literal>"
 msgstr "en <literal>hibernate.properties</literal>"
 
 #. Tag: para
-#: toolset_guide.xml:379
 #, no-c-format
 msgid "in a named properties file with <literal>--properties</literal>"
 msgstr ""
-"en un fichero de propiedades mencionado con <literal>--properties</literal>"
+"en un archivo de propiedades nombrado con <literal>--properties</literal>"
 
 #. Tag: para
-#: toolset_guide.xml:383
 #, no-c-format
 msgid "The needed properties are:"
-msgstr "Las propiedades necesarias son:"
+msgstr "Las propiedades necesarias son las siguientes:"
 
 #. Tag: title
-#: toolset_guide.xml:388
 #, no-c-format
 msgid "SchemaExport Connection Properties"
-msgstr "Propiedades de Conexi&#x00f3;n de SchemaExport"
+msgstr "Propiedades de Conexión del SchemaExport"
 
 #. Tag: entry
-#: toolset_guide.xml:394
 #, no-c-format
 msgid "Property Name"
-msgstr "Nombre de Propiedad"
+msgstr "Nombre de la Propiedad"
 
-#. Tag: literal
-#: toolset_guide.xml:400
-#, no-c-format
-msgid "hibernate.connection.driver_class"
-msgstr "hibernate.connection.driver_class"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.driver_class</literal>"
+msgstr "<literal>hibernate.connection.driver_class</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:401
 #, no-c-format
 msgid "jdbc driver class"
-msgstr "clase del driver jdbc"
+msgstr "clase del controlador jdbc"
 
-#. Tag: literal
-#: toolset_guide.xml:404
-#, no-c-format
-msgid "hibernate.connection.url"
-msgstr "hibernate.connection.url"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.url</literal>"
+msgstr "en <literal>hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:405
 #, no-c-format
 msgid "jdbc url"
 msgstr "url de jdbc"
 
-#. Tag: literal
-#: toolset_guide.xml:408
-#, no-c-format
-msgid "hibernate.connection.username"
-msgstr "hibernate.connection.username"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.username</literal>"
+msgstr "en <literal>hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:409
 #, no-c-format
 msgid "database user"
-msgstr "usuario de base de datos"
+msgstr "usuario de la base de datos"
 
-#. Tag: literal
-#: toolset_guide.xml:412
-#, no-c-format
-msgid "hibernate.connection.password"
-msgstr "hibernate.connection.password"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.password</literal>"
+msgstr "en <literal>hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:413
 #, no-c-format
 msgid "user password"
-msgstr "contrase&#x00f1;a de usuario"
+msgstr "contraseña del usuario"
 
-#. Tag: literal
-#: toolset_guide.xml:416
-#, no-c-format
-msgid "hibernate.dialect"
-msgstr "hibernate.dialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.dialect</literal>"
+msgstr "en <literal>hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:417
 #, no-c-format
 msgid "dialect"
 msgstr "dialecto"
 
 #. Tag: title
-#: toolset_guide.xml:426
 #, no-c-format
 msgid "Using Ant"
-msgstr "Usando Ant"
+msgstr "Utilización de Ant"
 
 #. Tag: para
-#: toolset_guide.xml:428
 #, no-c-format
 msgid ""
 "You can call <literal>SchemaExport</literal> from your Ant build script:"
 msgstr ""
-"Puedes llamar a <literal>SchemaExport</literal> desde tu gui&#x00f3;n de "
-"construcci&#x00f3;n de Ant:"
+"Puede llamar a <literal>SchemaExport</literal> desde su script de "
+"construcción de Ant:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:432
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemaexport\">\n"
-"    <taskdef name=\"schemaexport\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaExportTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemaexport\n"
-"        properties=\"hibernate.properties\"\n"
-"        quiet=\"no\"\n"
-"        text=\"no\"\n"
-"        drop=\"no\"\n"
-"        delimiter=\";\"\n"
-"        output=\"schema-export.sql\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemaexport>\n"
-"</target>]]>"
-msgstr ""
-"<![CDATA[<target name=\"schemaexport\">\n"
-"    <taskdef name=\"schemaexport\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaExportTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemaexport\n"
-"        properties=\"hibernate.properties\"\n"
-"        quiet=\"no\"\n"
-"        text=\"no\"\n"
-"        drop=\"no\"\n"
-"        delimiter=\";\"\n"
-"        output=\"schema-export.sql\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemaexport>\n"
-"</target>]]>"
-
 #. Tag: title
-#: toolset_guide.xml:437
 #, no-c-format
 msgid "Incremental schema updates"
 msgstr "Actualizaciones incrementales de esquema"
 
 #. Tag: para
-#: toolset_guide.xml:439
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>SchemaUpdate</literal> tool will update an existing schema with "
 "\"incremental\" changes. The <literal>SchemaUpdate</literal> depends upon "
 "the JDBC metadata API and, as such, will not work with all JDBC drivers."
 msgstr ""
-"La herramienta <literal>SchemaUpdate</literal> actualizar&#x00e1; un esquema "
-"existente con cambios \"incrementales\". Nota que <literal>SchemaUpdate</"
-"literal> depende fuertemente de la API de metadatos de JDBC, de modo que no "
-"funcionar&#x00e1; con todos los drivers JDBC."
+"La herramienta <literal>SchemaUpdate</literal> actualizará un esquema "
+"existente con cambios \"incrementales\". El <literal>SchemaUpdate</literal> "
+"depende de la API de metadatos de JDBC, de modo que no funcionará con todos "
+"los controladores JDBC."
 
 #. Tag: para
-#: toolset_guide.xml:445
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
 "<literal>org.hibernate.tool.hbm2ddl.SchemaUpdate</literal> <emphasis>options "
 "mapping_files</emphasis>"
 msgstr ""
-"<literal>java -cp </literal><emphasis>classpaths_de_hibernate</emphasis> "
-"<literal>org.hibernate.tool.hbm2ddl.SchemaUpdate</literal> "
-"<emphasis>opciones ficheros_de_mapeo</emphasis>"
+"<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
+"<literal>org.hibernate.tool.hbm2ddl.SchemaUpdate</literal> <emphasis>options "
+"mapping_files</emphasis>"
 
 #. Tag: title
-#: toolset_guide.xml:451
 #, no-c-format
 msgid "<literal>SchemaUpdate</literal> Command Line Options"
-msgstr ""
-"Opciones de L&#x00ed;nea de Comandos de <literal>SchemaUpdate</literal>"
+msgstr "Opciones de Línea de Comandos de <literal>SchemaUpdate</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:468
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "do not export the script to the database"
-msgstr "don't export the script to the database"
+msgstr "no exporte el script a la base de datos "
 
 #. Tag: entry
-#: toolset_guide.xml:480 toolset_guide.xml:541
 #, no-c-format
 msgid "specify a <literal>.cfg.xml</literal> file"
-msgstr "specify a <literal>.cfg.xml</literal> file"
+msgstr "specifique un archivo <literal>.cfg.xml</literal>"
 
 #. Tag: para
-#: toolset_guide.xml:486
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can embed <literal>SchemaUpdate</literal> in your application:"
-msgstr ""
-"Puedes encajar <literal>SchemaUpdate</literal> en tu aplicaci&#x00f3;n:"
+msgstr "Puede incluir <literal>SchemaUpdate</literal> en su aplicación: "
 
-#. Tag: programlisting
-#: toolset_guide.xml:490
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaUpdate(cfg).execute(false);]]>"
-msgstr ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaUpdate(cfg).execute(false);]]>"
-
 #. Tag: title
-#: toolset_guide.xml:495
 #, no-c-format
 msgid "Using Ant for incremental schema updates"
-msgstr "Usando Ant para actualizaciones incrementales de esquema"
+msgstr "Utilización de Ant para actualizaciones incrementales de esquema"
 
 #. Tag: para
-#: toolset_guide.xml:497
 #, no-c-format
 msgid "You can call <literal>SchemaUpdate</literal> from the Ant script:"
-msgstr ""
-"Puedes llamar a <literal>SchemaUpdate</literal> desde el gui&#x00f3;n de Ant:"
+msgstr "Puede llamar a <literal>SchemaUpdate</literal> desde el script de Ant:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:501
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemaupdate\">\n"
-"    <taskdef name=\"schemaupdate\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaUpdateTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemaupdate\n"
-"        properties=\"hibernate.properties\"\n"
-"        quiet=\"no\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemaupdate>\n"
-"</target>]]>"
-msgstr ""
-"<![CDATA[<target name=\"schemaupdate\">\n"
-"    <taskdef name=\"schemaupdate\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaUpdateTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemaupdate\n"
-"        properties=\"hibernate.properties\"\n"
-"        quiet=\"no\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemaupdate>\n"
-"</target>]]>"
-
 #. Tag: title
-#: toolset_guide.xml:506
 #, no-c-format
 msgid "Schema validation"
-msgstr "Schema validation"
+msgstr "Validación de Esquema"
 
 #. Tag: para
-#: toolset_guide.xml:508
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>SchemaValidator</literal> tool will validate that the existing "
 "database schema \"matches\" your mapping documents. The "
@@ -1172,14 +798,13 @@
 "API and, as such, will not work with all JDBC drivers. This tool is "
 "extremely useful for testing."
 msgstr ""
-"The <literal>SchemaValidator</literal> tool will validate that the existing "
-"database schema \"matches\" your mapping documents. Note that "
-"<literal>SchemaValidator</literal> depends heavily upon the JDBC metadata "
-"API, so it will not work with all JDBC drivers. This tool is extremely "
-"useful for testing."
+"La herramienta <literal>SchemaValidator</literal> validará que el esquema de "
+"la base de datos existente \"coincide\" con sus documentos de mapeo. El "
+"<literal>SchemaValidator</literal> depene bastante de la API de metadatos "
+"JDBC así que no funcionará con todos los controladores JDBC. Esta "
+"herramienta es extremadamente útil para comprobar."
 
 #. Tag: para
-#: toolset_guide.xml:514
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
@@ -1190,79 +815,78 @@
 "<literal>org.hibernate.tool.hbm2ddl.SchemaValidator</literal> "
 "<emphasis>options mapping_files</emphasis>"
 
+#. Tag: para
+#, no-c-format
+msgid ""
+"The following table displays the <literal>SchemaValidator</literal> command "
+"line options:"
+msgstr ""
+"La siguiente tabla presenta las opciones de la línea de comandos para "
+"<literal>SchemaValidator</literal> "
+
 #. Tag: title
-#: toolset_guide.xml:520
 #, no-c-format
 msgid "<literal>SchemaValidator</literal> Command Line Options"
-msgstr "<literal>SchemaValidator</literal> Command Line Options"
+msgstr "Opciones de la Línea de Comandos <literal>SchemaValidator</literal> "
 
 #. Tag: para
-#: toolset_guide.xml:547
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can embed <literal>SchemaValidator</literal> in your application:"
-msgstr "You may embed <literal>SchemaValidator</literal> in your application:"
+msgstr "Puede incluir <literal>SchemaValidator</literal> en su aplicación:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:551
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaValidator(cfg).validate();]]>"
-msgstr ""
-"<![CDATA[Configuration cfg = ....;\n"
-"                                                       new SchemaValidator"
-"(cfg).validate();]]>"
-
 #. Tag: title
-#: toolset_guide.xml:556
 #, no-c-format
 msgid "Using Ant for schema validation"
-msgstr "Using Ant for schema validation"
+msgstr "Utilización de Ant para la validación de esquema"
 
 #. Tag: para
-#: toolset_guide.xml:558
 #, no-c-format
 msgid "You can call <literal>SchemaValidator</literal> from the Ant script:"
-msgstr "You can call <literal>SchemaValidator</literal> from the Ant script:"
+msgstr "Puede llamar <literal>SchemaValidator</literal> desde el scrip de Ant:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:562
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemavalidate\">\n"
-"    <taskdef name=\"schemavalidator\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaValidatorTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemavalidator\n"
-"        properties=\"hibernate.properties\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemavalidator>\n"
-"</target>]]>"
-msgstr ""
-"<![CDATA[<target name=\"schemavalidate\">\n"
-"                                <taskdef name=\"schemavalidator\"\n"
-"                                         classname=\"org.hibernate.tool."
-"hbm2ddl.SchemaValidatorTask\"\n"
-"                                         classpathref=\"class.path\"/>\n"
-"                                \n"
-"                                <schemavalidator\n"
-"                                                properties=\"hibernate."
-"properties\">\n"
-"                                        <fileset dir=\"src\">\n"
-"                                                <include name=\"**/*.hbm.xml"
-"\"/>\n"
-"                                        </fileset>\n"
-"                                </schemavalidator>\n"
-"                        </target>]]>"
+#, fuzzy
+#~ msgid "length"
+#~ msgstr "longitud de columna/precisión decimal"
 
-#~ msgid "Ant Tasks:"
-#~ msgstr "Tareas de Ant:"
+#, fuzzy
+#~ msgid "precision"
+#~ msgstr "expresión SQL"
 
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
+#, fuzzy
+#~ msgid "unique_key_name"
+#~ msgstr "<literal>unique_key_name</literal>"
 
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+#, fuzzy
+#~ msgid "foreign_key_name"
+#~ msgstr "<literal>foreign_key_name</literal>"
+
+#, fuzzy
+#~ msgid "SQL column type"
+#~ msgstr "<literal>SQL column type</literal>"
+
+#, fuzzy
+#~ msgid "--output=my_schema.ddl"
+#~ msgstr "<literal>--output=my_schema.ddl</literal>"
+
+#, fuzzy
+#~ msgid "--properties=hibernate.properties"
+#~ msgstr "<literal>--properties=hibernate.properties</literal>"
+
+#, fuzzy
+#~ msgid "hibernate.connection.url"
+#~ msgstr "<literal>hibernate.connection.url</literal>"
+
+#, fuzzy
+#~ msgid "hibernate.connection.username"
+#~ msgstr "<literal>hibernate.connection.username</literal>"
+
+#, fuzzy
+#~ msgid "hibernate.connection.password"
+#~ msgstr "<literal>hibernate.connection.password</literal>"
+
+#, fuzzy
+#~ msgid "hibernate.dialect"
+#~ msgstr "<literal>hibernate.dialect</literal>"
+
+#~ msgid "<!-- <emphasis>Ant Tasks:</emphasis> -->"
+#~ msgstr "<!-- <emphasis>Tareas Ant:</emphasis> -->"

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/transactions.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/transactions.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/transactions.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,35 @@
+# translation of transactions.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: transactions\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-01-07 10:38+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: transactions.xml:29
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Transactions and Concurrency"
-msgstr "Transacciones y Concurrencia"
+msgstr "Transacciones y concurrencia"
 
 #. Tag: para
-#: transactions.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The most important point about Hibernate and concurrency control is that it "
 "is easy to understand. Hibernate directly uses JDBC connections and JTA "
@@ -27,18 +38,14 @@
 "specification of your database management system."
 msgstr ""
 "El punto más importante sobre Hibernate y el control de concurrencia es que "
-"muy fácil de comprender. Hibernate usa directamente conexiones JDBC y "
-"recursos JTA sin agregar ningún comportamiento de bloqueo adicional. "
-"Recomendamos altamente que gastes algo de tiempo con la especificación de "
-"JDBC, ANSI, y el aislamiento de transacciones de tu sistema de gestión de "
-"base de datos. Hibernate sólo añade versionado automático pero no bloquea "
-"objetos en memoria ni cambia el nivel de aislamiento de tus transacciones de "
-"base de datos. Básicamente, usa Hibernate como usarías JDBC directo (o JTA/"
-"CMT) con tus recursos de base de datos."
+"es fácil de comprender. Hibernate usa directamente conexiones JDBC y "
+"recursos JTA sin agregar ningún comportamiento de bloqueo adicional. Le "
+"recomendamos bastante que tome algo de tiempo con la especificación de JDBC, "
+"ANSI y el aislamiento de transacciones de su sistema de gestión de base de "
+"datos. "
 
 #. Tag: para
-#: transactions.xml:38
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate does not lock objects in memory. Your application can expect the "
 "behavior as defined by the isolation level of your database transactions. "
@@ -46,29 +53,28 @@
 "cache, Hibernate provides repeatable reads for lookup by identifier and "
 "entity queries and not reporting queries that return scalar values."
 msgstr ""
-"Hibernate does not lock objects in memory. Your application can expect the "
-"behavior as defined by the isolation level of your database transactions. "
-"Note that thanks to the <literal>Session</literal>, which is also a "
-"transaction-scoped cache, Hibernate provides repeatable reads for lookup by "
-"identifier and entity queries (not reporting queries that return scalar "
-"values)."
+"Hibernate no bloquea objetos en la memoria. Su aplicación puede esperar el "
+"comportamiento definido por el nivel de aislamiento de sus transacciones de "
+"las bases de datos. Gracias a la <literal>Session</literal>, la cual también "
+"es un caché con alcance de transacción, Hibernate proporciona lecturas "
+"repetidas para búsquedas del identificador y consultas de entidad y no "
+"consultas de reporte que retornan valores escalares."
 
 #. Tag: para
-#: transactions.xml:46
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In addition to versioning for automatic optimistic concurrency control, "
 "Hibernate also offers, using the <literal>SELECT FOR UPDATE</literal> "
 "syntax, a (minor) API for pessimistic locking of rows. Optimistic "
 "concurrency control and this API are discussed later in this chapter."
 msgstr ""
-"Sin embargo, además del versionado automático, Hibernate ofrece una API "
-"(menor) para bloqueo pesimista de filas, usando la sintáxis <literal>SELECT "
-"FOR UPDATE</literal>. Esta API se discute más adelante en este capítulo:"
+"Además del versionado del control de concurrencia optimista automático, "
+"Hibernate también ofrece una API (menor) para bloqueo pesimista de filas, "
+"usando la sintáxis <literal>SELECT FOR UPDATE</literal>. Esta API y el "
+"control de concurrencia optimista se discuten más adelante en este capítulo."
 
 #. Tag: para
-#: transactions.xml:53
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The discussion of concurrency control in Hibernate begins with the "
 "granularity of <literal>Configuration</literal>, <literal>SessionFactory</"
@@ -77,32 +83,29 @@
 msgstr ""
 "Comenzamos la discusión del control de concurrencia en Hibernate con la "
 "granularidad de <literal>Configuration</literal>, <literal>SessionFactory</"
-"literal>, y <literal>Session</literal>, así como la base de datos y las "
-"transacciones de aplicación largas."
+"literal> y <literal>Session</literal>, así como las transacciones de la base "
+"de datos y las conversaciones largas."
 
 #. Tag: title
-#: transactions.xml:60
 #, no-c-format
 msgid "Session and transaction scopes"
 msgstr "Ámbitos de sesión y de transacción"
 
 #. Tag: para
-#: transactions.xml:62
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>SessionFactory</literal> is an expensive-to-create, threadsafe "
 "object, intended to be shared by all application threads. It is created "
 "once, usually on application startup, from a <literal>Configuration</"
 "literal> instance."
 msgstr ""
-"Una <literal>SessionFactory</literal> es un objeto seguro entre hebras caro-"
-"de-crear pensado para ser compartido por todas las hebras de la aplicación. "
-"Es creado una sola vez, usualmente en el arranque de la aplicación, a partir "
-"de una instancia de <literal>Configuration</literal>."
+"Una <literal>SessionFactory</literal> es un objeto seguro entre hilos y "
+"costoso de crear pensado para que todas las hebras de la aplicación lo "
+"compartan. Se crea una sola vez, usualmente en el inicio de la aplicación, a "
+"partir de una instancia <literal>Configuration</literal>."
 
 #. Tag: para
-#: transactions.xml:68
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>Session</literal> is an inexpensive, non-threadsafe object that "
 "should be used once and then discarded for: a single request, a conversation "
@@ -110,19 +113,15 @@
 "JDBC <literal>Connection</literal>, or a <literal>Datasource</literal>, "
 "unless it is needed. It will not consume any resources until used."
 msgstr ""
-"Una <literal>Session</literal> es un objeto barato, inseguro entre hebras "
-"que debe ser usado una sola vez, para un solo proceso de negocio, una sola "
-"unidad de trabajo, y luego descartado. Una <literal>Session</literal> no "
-"obtendrá una <literal>Connection</literal> JDBC (o un <literal>Datasource</"
-"literal>) a menos que sea necesario, de modo que puedas abrir y cerrar "
-"seguramente una <literal>Session</literal> incluso si no estás seguro que se "
-"necesitará acceso a los datos para servir una petición en particular. (Esto "
-"se vuelve importante en cuanto estés implementando alguno de los siguientes "
-"patrones usando intercepción de peticiones)."
+"Una <literal>Session</literal> es un objeto de bajo costo, inseguro entre "
+"hilos que se debe utilizar una sola vez y luego se debe descartar: para un "
+"sólo pedido, una sola conversación o una sóla unidad de trabajo. Una "
+"<literal>Session</literal> no obtendrá una <literal>Connection</literal> "
+"JDBC o un <literal>Datasource</literal> a menos de que sea necesario. No "
+"consumirá recursos hasta que se utilice."
 
 #. Tag: para
-#: transactions.xml:76
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In order to reduce lock contention in the database, a database transaction "
 "has to be as short as possible. Long database transactions will prevent your "
@@ -130,15 +129,16 @@
 "that you hold a database transaction open during user think time until the "
 "unit of work is complete."
 msgstr ""
-"Para completar este cuadro tienes que pensar también en las transacciones de "
-"base de datos. Una transacción de base de datos tiene que ser tan corta como "
-"sea posible, para reducir la contención de bloqueos en la base de datos. Las "
-"transacciones largas de base de datos prevendrán a tu aplicación de escalar "
-"a una carga altamente concurrente."
+"Una transacción de la base de datos tiene que ser tan corta como sea posible "
+"para reducir la contención de bloqueos en la base de datos. Las "
+"transacciones largas de la base de datos prevendrán a su aplicación de "
+"escalar a una carga altamente concurrente. Por lo tanto, no se recomienda "
+"que mantenga una transacción de la base de datos abierta durante el tiempo "
+"para pensar del usuario, hasta que la unidad de trabajo se encuentre "
+"completa."
 
 #. Tag: para
-#: transactions.xml:84
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What is the scope of a unit of work? Can a single Hibernate "
 "<literal>Session</literal> span several database transactions, or is this a "
@@ -146,21 +146,20 @@
 "<literal>Session</literal> and how do you demarcate the database transaction "
 "boundaries? These questions are addressed in the following sections."
 msgstr ""
-"¿Qué es el ámbito de una unidad de trabajo? ¿Puede una sola "
+"¿Cuál es el ámbito de una unidad de trabajo? ¿Puede una sola "
 "<literal>Session</literal> de Hibernate extenderse a través de varias "
-"transacciones de base de datos o es ésta una relación uno-a-uno de ámbitos? "
-"¿Cuándo debes abrir y cerrar una <literal>Session</literal> y cómo demarcas "
-"los límites de la transacción de base de datos?"
+"transacciones de la base de datos o ésta es una relación uno-a-uno de "
+"ámbitos? ¿Cuándo debe abrir y cerrar una <literal>Session</literal>? y ¿cómo "
+"demarca los límites de la transacción de la base de datos? En las siguientes "
+"secciones abordaremos estas preguntas. "
 
 #. Tag: title
-#: transactions.xml:92
 #, no-c-format
 msgid "Unit of work"
 msgstr "Unidad de trabajo"
 
 #. Tag: para
-#: transactions.xml:94
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "First, let's define a unit of work. A unit of work is a design pattern "
 "described by Martin Fowler as <quote> [maintaining] a list of objects "
@@ -169,14 +168,25 @@
 "citation> In other words, its a series of operations we wish to carry out "
 "against the database together. Basically, it is a transaction, though "
 "fulfilling a unit of work will often span multiple physical database "
-"transactions (see <xref linkend=\"transactions-basics-apptx\"/>). So really "
+"transactions (see <xref linkend=\"transactions-basics-apptx\" />). So really "
 "we are talking about a more abstract notion of a transaction. The term "
 "\"business transaction\" is also sometimes used in lieu of unit of work."
 msgstr ""
+"Primero, vamos a definir una unidad de trabajo. Una unidad de trabajo es un "
+"patrón de diseño que Martin Fowler describe como <quote> [mantener] una "
+"lista de objetos afectados por una transacción empresarial y coordina la "
+"escritura de los cambios y la resolución de problemas de concurrencia. </"
+"quote><citation>PoEAA</citation> En otras palabras, es una serie de "
+"operaciones que deseamos llevar a cabo frente a la base de datos. "
+"Básicamente es una transacción, aunque el llevar a cabo una unidad de "
+"trabajo con frecuencia abarca múltiples transacciones de la base de datos "
+"física (consulte <xref linkend=\"transactions-basics-apptx\"/>). Así que "
+"realmente estamos hablando sobre una noción más abstracta de una "
+"transacción. El término \"transacción empresarial\" también se utiliza a "
+"veces en lugar de unidad de trabajo."
 
 #. Tag: para
-#: transactions.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not use the <emphasis>session-per-operation</emphasis> antipattern: do "
 "not open and close a <literal>Session</literal> for every simple database "
@@ -192,20 +202,24 @@
 "clearly defined unit of work. The latter is also more maintainable and "
 "extensible."
 msgstr ""
-"Primero, no uses el antipatrón <emphasis>sesión-por-operación</emphasis>, "
-"esto es, ¡no abras y cierres una <literal>Session</literal> para cada simple "
-"llamada a la base de datos en una sola hebra! Por supuesto, lo mismo es "
-"verdad para transacciones de base de datos. Las llamadas a base de datos en "
-"una aplicación se hacen usando una secuencia prevista, que están agrupadas "
-"dentro de unidades de trabajo atómicas. (Nota que esto también significa que "
-"el auto-commit después de cada una de las sentencias SQL es inútil en una "
-"aplicación, este modo está pensado para trabajo ad-hoc de consola SQL. "
-"Hibernate deshabilita, o espera que el servidor de aplicaciones lo haga, el "
-"modo auto-commit inmediatamente.)"
+"Primero, no use el antipatrón <emphasis>sesión-por-operación</emphasis>: no "
+"abra y cierre una <literal>Session</literal> para cada llamada simple a la "
+"base de datos en un solo hilo. Lo mismo aplica para las transacciones de "
+"base de datos. Las llamadas a la base de datos en una aplicación se hacen "
+"usando una secuencia planeada; estas se agrupan dentro de unidades de "
+"trabajo atómicas. Esto también significa que el auto-commit después de cada "
+"una de las declaraciones SQL es inútil en una aplicación ya que este modo "
+"está pensado para trabajo ad-hoc de consola SQL. Hibernate deshabilita, o "
+"espera que el servidor de aplicaciones lo haga, el modo auto-commit "
+"inmediatamente. Las transacciones de las bases de datos nunca son "
+"opcionales. Toda comunicación con una base de datos tiene que ocurrir dentro "
+"de una transacción. El comportamiento auto-commit para leer datos se debe "
+"evitar, ya que hay muy poca probabilidad de que las transacciones pequeñas "
+"funcionen mejor que una unidad de trabajo definida claramente. La última es "
+"mucho más sostenible y extensible."
 
 #. Tag: para
-#: transactions.xml:126
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The most common pattern in a multi-user client/server application is "
 "<emphasis>session-per-request</emphasis>. In this model, a request from the "
@@ -218,21 +232,20 @@
 "literal>. The relationship between the two is one-to-one and this model is a "
 "perfect fit for many applications."
 msgstr ""
-"El patrón más común en una aplicación mutiusuario cliente/servidor es "
+"El patrón más común en una aplicación multiusuario cliente/servidor es "
 "<emphasis>sesión-por-petición</emphasis>. En este modelo, una petición del "
-"cliente es enviada al servidor (en donde se ejecuta la capa de persistencia "
-"de Hibernate), se abre una nueva <literal>Session</literal> de Hibernate, y "
-"todas las operaciones de base de datos se ejecutan en esta unidad de "
-"trabajo. Una vez completado el trabajo (y se ha preparado la respuesta para "
-"el cliente) la sesión es limpiada y cerrada. Podrías usar una sola "
-"transacción de base de datos para servir a petición del cliente, "
-"comenzándola y comprometiéndola cuando abres y cierras la <literal>Session</"
-"literal>. La relación entre las dos es uno-a-uno y este modelo es a la "
-"medida perfecta de muchas aplicaciones."
+"cliente se envia al servidor, en donde se ejecuta la capa de persistencia de "
+"Hibernate. Se abre una nueva <literal>Session</literal> de Hibernate y todas "
+"las operaciones de la base de datos se ejecutan en esta unidad de trabajo. "
+"Una vez completado el trabajo, y una vez se ha preparado la respuesta para "
+"el cliente, se limpia la sesión y se cierra. Use una sóla transacción de la "
+"base de datos para servir la petición del cliente, dándole inicio y "
+"guardándola cuando abre y cierra la <literal>Session</literal>. La relación "
+"entre las dos es uno-a-uno y este modelo es a la medida perfecta de muchas "
+"aplicaciones."
 
 #. Tag: para
-#: transactions.xml:138
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The challenge lies in the implementation. Hibernate provides built-in "
 "management of the \"current session\" to simplify this pattern. Start a "
@@ -246,38 +259,36 @@
 "use the Hibernate <literal>Transaction</literal> API shown later in this "
 "chapter."
 msgstr ""
-"The challenge lies in the implementation. Hibernate provides built-in "
-"management of the \"current session\" to simplify this pattern. All you have "
-"to do is start a transaction when a server request has to be processed, and "
-"end the transaction before the response is send to the client. You can do "
-"this in any way you like, common solutions are <literal>ServletFilter</"
-"literal>, AOP interceptor with a pointcut on the service methods, or a proxy/"
-"interception container. An EJB container is a standardized way to implement "
-"cross-cutting aspects such as transaction demarcation on EJB session beans, "
-"declaratively with CMT. If you decide to use programmatic transaction "
-"demarcation, prefer the Hibernate <literal>Transaction</literal> API shown "
-"later in this chapter, for ease of use and code portability."
+"El reto se encuentra en la implementación. Hibernate brinda administración "
+"incorporada de la \"sesión actual\" para simplificar este patrón. Inicie una "
+"transacción cuando se tiene que procesar un pedido del servidor y termine la "
+"transacción antes de que se envie la respuesta al cliente. Las soluciones "
+"más comunes son <literal>ServletFilter</literal>, un interceptor AOP con un "
+"punto de corte en los métodos del servicio o un contenedor proxy/"
+"intercepción. Un contenedor EJB es una manera estandarizada de implementar "
+"aspectos de doble filo como demarcación de transacción en beans de sesión "
+"EJB, declarativamente con CMT. Si decide utilizar la demarcación de "
+"transacción programática, use el API <literal>Transaction</literal> de "
+"Hibernate de fácil uso y portable que se muestra más adelante en este "
+"capítulo."
 
 #. Tag: para
-#: transactions.xml:150
 #, fuzzy, no-c-format
 msgid ""
 "Your application code can access a \"current session\" to process the "
 "request by calling <literal>sessionFactory.getCurrentSession()</literal>. "
 "You will always get a <literal>Session</literal> scoped to the current "
 "database transaction. This has to be configured for either resource-local or "
-"JTA environments, see <xref linkend=\"architecture-current-session\"/>."
+"JTA environments, see <xref linkend=\"architecture-current-session\" />."
 msgstr ""
-"Your application code can access a \"current session\" to process the "
-"request by simply calling <literal>sessionFactory.getCurrentSession()</"
-"literal> anywhere and as often as needed. You will always get a "
-"<literal>Session</literal> scoped to the current database transaction. This "
-"has to be configured for either resource-local or JTA environments, see "
-"<xref linkend=\"architecture-current-session\"/>."
+"Su código de aplicación puede acceder a una \"sesión actual\" para procesar "
+"el pedido llamando a <literal>sessionFactory.getCurrentSession()</literal>. "
+"Siempre obtendrá una <literal>Session</literal> con ámbito a la transacción "
+"de la base de datos actual. Esto tiene que ser configurado para entornos JTA "
+"o recurso-local, consulte <xref linkend=\"architecture-current-session\" />."
 
 #. Tag: para
-#: transactions.xml:158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can extend the scope of a <literal>Session</literal> and database "
 "transaction until the \"view has been rendered\". This is especially useful "
@@ -289,26 +300,25 @@
 "of any view can start. See the Hibernate website and forum for tips and "
 "examples relating to this <emphasis>Open Session in View</emphasis> pattern."
 msgstr ""
-"Sometimes it is convenient to extend the scope of a <literal>Session</"
-"literal> and database transaction until the \"view has been rendered\". This "
-"is especially useful in servlet applications that utilize a separate "
-"rendering phase after the request has been processed. Extending the database "
-"transaction until view rendering is complete is easy to do if you implement "
-"your own interceptor. However, it is not easily doable if you rely on EJBs "
-"with container-managed transactions, as a transaction will be completed when "
-"an EJB method returns, before rendering of any view can start. See the "
-"Hibernate website and forum for tips and examples around this <emphasis>Open "
-"Session in View</emphasis> pattern."
+"Puede extender el ámbito de una <literal>Session</literal> y transacción de "
+"la base de datos hasta que \"se ha presentado la vista\". Esto es bastante "
+"útil en aplicaciones de servlet que utilizan una fase de entrega separada "
+"después de que se ha procesado el pedido. El extender la transacción de la "
+"base de datos hasta que la entrega de la vista se encuentre completa es "
+"fácil de lograr si implementa su propio interceptor. Sin embargo, no se "
+"logra fácilmente si depende de EJBs con transacciones administradas por el "
+"contenedor. Una transacción se completará cuando un método EJB retorna, "
+"antes de que pueda empezar la entrega de cualquier vista. Vea el sitio web "
+"de Hibernate y el foro para encontrar consejos y ejemplos sobre este patrón "
+"de <emphasis>sesión abierta en vista</emphasis>."
 
 #. Tag: title
-#: transactions.xml:173
 #, no-c-format
 msgid "Long conversations"
-msgstr "Transacciones de aplicación"
+msgstr "Conversaciones largas"
 
 #. Tag: para
-#: transactions.xml:175
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The session-per-request pattern is not the only way of designing units of "
 "work. Many business processes require a whole series of interactions with "
@@ -316,53 +326,51 @@
 "applications, it is not acceptable for a database transaction to span a user "
 "interaction. Consider the following example:"
 msgstr ""
-"El patrón sesión-por-petición no es el único concepto útil que puedes usar "
-"para diseñar unidades de trabajo. Muchos procesos de negocio requiere una "
-"serie completa de interacciones con el usuario intercaladas con accesos a "
-"base de datos. En aplicaciones web y de empresa no es aceptable que una "
-"transacción de base de datos se extienda a través de la interacción de un "
-"usuario. Considera el siguiente ejemplo:"
+"El patrón sesión-por-petición no es la única forma de diseñar unidades de "
+"trabajo. Muchos procesos empresariales requieren una serie completa de "
+"interacciones con el usuario intercaladas con accesos a la base de datos. En "
+"aplicaciones empresariales y web no es aceptable que una transacción de la "
+"base de datos abarque la interacción de un usuario. Considere el siguiente "
+"ejemplo:"
 
 #. Tag: para
-#: transactions.xml:185
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The first screen of a dialog opens. The data seen by the user has been "
 "loaded in a particular <literal>Session</literal> and database transaction. "
 "The user is free to modify the objects."
 msgstr ""
-"Se abre la primera pantalla de un diálogo, los datos vistos por el usuario "
-"han sido cargados en una <literal>Session</literal> y transacción de base de "
-"datos particular. El usuario es libre de modificar los objetos."
+"Se abre la primera pantalla de un diálogo. Los datos que ve el usuario han "
+"sido cargados en una <literal>Session</literal> en particular y en una "
+"transacción de la base de datos. El usuario es libre de modificar los "
+"objetos."
 
 #. Tag: para
-#: transactions.xml:192
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The user clicks \"Save\" after 5 minutes and expects their modifications to "
 "be made persistent. The user also expects that they were the only person "
 "editing this information and that no conflicting modification has occurred."
 msgstr ""
-"El usuario hace click en \"Salvar\" después de 5 minutos y espera que sus "
-"modificaciones sean hechas persistentes. También espera que él sea la única "
-"persona editando esta información y que no puede ocurrir ninguna "
-"modificación en conflicto."
+"El usuario hace click en \"Guardar\" después de 5 minutos y espera que sus "
+"modificaciones se hagan persistentes. También espera que él sea la única "
+"persona editando esta información y que no ocurra ningún conflicto en la "
+"modificación."
 
 #. Tag: para
-#: transactions.xml:200
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "From the point of view of the user, we call this unit of work a long-running "
 "<emphasis>conversation</emphasis> or <emphasis>application transaction</"
 "emphasis>. There are many ways to implement this in your application."
 msgstr ""
-"Llamamos a esto unidad de trabajo, desde el punto de vista del usuario, una "
-"larga <emphasis>transacción de aplicación</emphasis> ejecutándose. Hay "
-"muchas formas en que puedes implementar esto en tu aplicación."
+"Desde el punto de vista del usuario, llamamos a esta unidad de trabajo, una "
+"larga <emphasis>conversación</emphasis> o <emphasis>transacción de "
+"aplicación</emphasis>. Hay muchas formas de implementar esto en su "
+"aplicación."
 
 #. Tag: para
-#: transactions.xml:206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A first naive implementation might keep the <literal>Session</literal> and "
 "database transaction open during user think time, with locks held in the "
@@ -371,16 +379,14 @@
 "the application to scale with the number of concurrent users."
 msgstr ""
 "Una primera implementación ingenua podría mantener abierta la "
-"<literal>Session</literal> y la transacción de base de datos durante el "
-"tiempo de pensar del usuario, con bloqueos tomados en la base de datos para "
-"prevenir la modificación concurrente, y para garantizar aislamiento y "
-"atomicidad. Esto es, por supuesto, un antipatrón, ya que la contención de "
-"bloqueo no permitiría a la aplicación escalar con el número de usuarios "
-"concurrentes."
+"<literal>Session</literal> y la transacción de la base de datos durante el "
+"tiempo para pensar del usuario, con bloqueos en la base de datos para "
+"prevenir la modificación simultánea y para garantizar el aislamiento y la "
+"atomicidad. Esto es un antipatrón, ya que la contención de bloqueo no "
+"permitiría a la aplicación escalar con el número de usuarios simultáneos."
 
 #. Tag: para
-#: transactions.xml:214
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You have to use several database transactions to implement the conversation. "
 "In this case, maintaining isolation of business processes becomes the "
@@ -391,34 +397,32 @@
 "several request/response cycles). This is easier to implement than it might "
 "sound, especially if you utilize some of Hibernate's features:"
 msgstr ""
-"Claramente, tenemos que usar muchas transacciones de base de datos para "
-"implementar la transacción de aplicación. En este caso, mantener el "
-"aislamiento de los procesos de negocio se vuelve una responsabilidad parcial "
-"de la capa de aplicación. Una sola transacción de aplicación usualmente "
-"abarca varias transacciones de base de datos. Será atómica si sólo una de "
-"estas transacciones de base de datos (la última) almacena los datos "
-"actualizados, todas las otras simplemente leen datos (por ejemplo, en un "
-"diálogo estilo-asistente abarcando muchos ciclos petición/respuesta). Esto "
-"es más fácil de implementar de lo que suena, especialmente si usas las "
-"funcionalidades de Hibernate:"
+"Tiene que usar varias transacciones de la base de datos para implementar la "
+"conversación. En este caso, mantener el aislamiento de los procesos "
+"empresariales se vuelve una responsabilidad parcial de la capa de la "
+"aplicación. Una sóla conversación usualmente abarca varias transacciones de "
+"la base de datos. Será atómica si sólo una de estas transacciones de la base "
+"de datos (la última) almacena los datos actualizados. Todas las otras "
+"simplemente leen datos (por ejemplo, en un diálogo de estilo-asistente "
+"abarcando muchos ciclos petición/respuesta). Esto es más fácil de "
+"implementar de lo que suena, especialmente si usa las funcionalidades de "
+"Hibernate:"
 
 #. Tag: para
-#: transactions.xml:227
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Automatic Versioning</emphasis>: Hibernate can perform automatic "
 "optimistic concurrency control for you. It can automatically detect if a "
 "concurrent modification occurred during user think time. Check for this at "
 "the end of the conversation."
 msgstr ""
-"<emphasis>Versionado Automático</emphasis> - Hibernate puede llevar un "
-"control automático de concurrencia optimista por ti, puede detectar "
-"automáticamente si una modificación concurrente ha ocurrido durante el "
-"tiempo de pensar del usuario."
+"<emphasis>Versionado automático</emphasis> - Hibernate puede realizar un "
+"control automático de concurrencia optimista por usted .Puede detectar "
+"automáticamente si ha ocurrido una modificación simultánea durante el tiempo "
+"para pensar del usuario. Chequee esto al final de la conversación. "
 
 #. Tag: para
-#: transactions.xml:235
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Detached Objects</emphasis>: if you decide to use the "
 "<emphasis>session-per-request</emphasis> pattern, all loaded instances will "
@@ -427,17 +431,16 @@
 "<emphasis>session-per-request-with-detached-objects</emphasis>. Automatic "
 "versioning is used to isolate concurrent modifications."
 msgstr ""
-"<emphasis>Objetos Separados</emphasis> - Si decides usar el ya discutido "
-"patrón de <emphasis>sesión-por-petición</emphasis>, todas las instancias "
-"cargadas estarán en estado separado durante el tiempo de pensar del usuario. "
-"Hibernate te permite volver a unir los objetos y hacer persistentes las "
+"<emphasis>Objetos separados</emphasis>: Si decide usar el patrón "
+"<emphasis>sesión-por-petición</emphasis>, todas las instancias cargadas "
+"estarán en estado separado durante el tiempo para pensar del usuario. "
+"Hibernate le permite volver a unir los objetos y hacer persistentes las "
 "modificaciones. El patrón se llama <emphasis>sesión-por-petición-con-objetos-"
-"separados</emphasis>. Se usa versionado automático para aislar las "
-"modificaciones concurrentes."
+"separados</emphasis>. Se usa el versionado automático para aislar las "
+"modificaciones simultáneas."
 
 #. Tag: para
-#: transactions.xml:245
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Extended (or Long) Session</emphasis>: the Hibernate "
 "<literal>Session</literal> can be disconnected from the underlying JDBC "
@@ -448,76 +451,69 @@
 "<literal>Session</literal> will not be allowed to be flushed automatically, "
 "but explicitly."
 msgstr ""
-"<emphasis>Sesión Larga</emphasis> - La <literal>Session</literal> de "
-"Hibernate puede ser desconectada de la conexión JDBC subyacente después que "
-"se haya sido comprometida la transacción de base de datos, y reconectada "
-"cuando ocurra una nueva petición del cliente. Este patrón es conocido como "
-"<emphasis>sesión-por-transacción-de-aplicación</emphasis> y hace la re-unión "
-"innecesaria. Para aislar las modificaciones concurrentes se usa el "
-"versionado automático."
+"<emphasis>Sesión extendida (o larga) </emphasis> - La <literal>Session</"
+"literal> de Hibernate puede ser desconectada de la conexión JDBC subyacente "
+"después de que haya guardado la transacción de la base de datos y haya "
+"reconectado cuando ocurra una nueva petición del cliente. Este patrón se "
+"conoce como <emphasis>sesión-por-conversación</emphasis> y hace la re-unión "
+"innecesaria. Para aislar las modificaciones simultáneas se usa el versionado "
+"automático y usualmente no se permite que se limpie la <literal>Session</"
+"literal> automáticamente sino explícitamente."
 
 #. Tag: para
-#: transactions.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Both <emphasis>session-per-request-with-detached-objects</emphasis> and "
 "<emphasis>session-per-conversation</emphasis> have advantages and "
 "disadvantages. These disadvantages are discussed later in this chapter in "
 "the context of optimistic concurrency control."
 msgstr ""
-"Tanto <emphasis>sesión-por-petición-con-objetos-separados</emphasis> como "
-"<emphasis>sesión-por-transacción-de-aplicación</emphasis>, ambas tienen "
-"ventajas y desventajas, las discutimos más adelante en este capítulo en el "
-"contexto del control optimista de concurrencia."
+"Tanto la <emphasis>sesión-por-petición-con-objetos-separados</emphasis> como "
+"la <emphasis>sesión-por-conversación</emphasis> tienen ventajas y "
+"desventajas. Estas desventajas las discutimos más adelante en este capítulo "
+"en el contexto del control optimista de concurrencia."
 
 #. Tag: title
-#: transactions.xml:267
 #, no-c-format
 msgid "Considering object identity"
-msgstr "Considerando la identidad del objeto"
+msgstr "Consideración de la identidad del objeto"
 
 #. Tag: para
-#: transactions.xml:269
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An application can concurrently access the same persistent state in two "
 "different <literal>Session</literal>s. However, an instance of a persistent "
 "class is never shared between two <literal>Session</literal> instances. It "
 "is for this reason that there are two different notions of identity:"
 msgstr ""
-"Una aplicación puede acceder concurrentemente a el mismo estado persistente "
-"en dos <literal>Session</literal>s diferentes. Sin embargo, una instancia de "
+"Una aplicación puede acceder simultáneamente al mismo estado persistente en "
+"dos <literal>Session</literal>es diferentes. Sin embargo, una instancia de "
 "una clase persistente nunca se comparte entre dos instancias de "
-"<literal>Session</literal>. Por lo tanto existen dos nociones diferentes de "
-"identidad:"
+"<literal>Session</literal>. Por lo tanto, existen dos nociones diferentes de "
+"identidad: "
 
 #. Tag: term
-#: transactions.xml:278
 #, no-c-format
 msgid "Database Identity"
 msgstr "Identidad de Base de Datos"
 
-#. Tag: literal
-#: transactions.xml:281
-#, no-c-format
-msgid "foo.getId().equals( bar.getId() )"
-msgstr "foo.getId().equals( bar.getId() )"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>foo.getId().equals( bar.getId() )</literal>"
+msgstr "<literal>foo.getId().equals( bar.getId() )</literal>"
 
 #. Tag: term
-#: transactions.xml:286
 #, no-c-format
 msgid "JVM Identity"
 msgstr "Identidad JVM"
 
-#. Tag: literal
-#: transactions.xml:289
+#. Tag: para
 #, no-c-format
-msgid "foo==bar"
-msgstr "foo==bar"
+msgid "<literal>foo==bar</literal>"
+msgstr "<literal>foo==bar</literal>"
 
 #. Tag: para
-#: transactions.xml:295
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For objects attached to a <emphasis>particular</emphasis> <literal>Session</"
 "literal> (i.e., in the scope of a <literal>Session</literal>), the two "
@@ -528,19 +524,18 @@
 "resolved using an optimistic approach and automatic versioning at flush/"
 "commit time."
 msgstr ""
-"Entonces para objetos unidos a una <literal>Session</literal><emphasis>en "
-"particular</emphasis> (es decir en el ámbito de una <literal>Session</"
-"literal>) las dos nociones son equivalentes, y la identidad JVM para la "
-"identidad de base de datos está garantizada por Hibernate. Sin embargo, "
-"mientras la aplicación acceda concurrentemente al \"mismo\" (identidad "
-"persistente) objeto de negocio en dos sesiones diferentes, las dos "
-"instancias serán realmente \"diferentes\" (identidad JVM). Los conflictos se "
-"resuelven (con versionado automático) en tiempo de limpieza (flush) usando "
-"un enfoque optimista."
+"Para los bjetos unidos a una <literal>Session</literal><emphasis> en "
+"particular</emphasis> (por ejemplo, en el ámbito de una <literal>Session</"
+"literal>) las dos nociones son equivalentes y la identidad de la MVJ para la "
+"identidad de la base de datos se encuentra garantizada por Hibernate. "
+"Mientras la aplicación acceda simultáneamente al \"mismo\" objeto "
+"empresarial (identidad persistente) en dos sesiones diferentes, las dos "
+"instancias serán realmente \"diferentes\" (identidad MVJ). Los conflictos se "
+"resuelven usando un enfoque optimista y el versionado automático en tiempo "
+"de vaciado/ al guardar."
 
 #. Tag: para
-#: transactions.xml:304
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This approach leaves Hibernate and the database to worry about concurrency. "
 "It also provides the best scalability, since guaranteeing identity in single-"
@@ -550,18 +545,17 @@
 "<literal>Session</literal>. Within a <literal>Session</literal> the "
 "application can safely use <literal>==</literal> to compare objects."
 msgstr ""
-"Este enfoque deja que Hibernate y la base de datos se preocupen sobre la "
+"Este enfoque deja que Hibernate y la base de datos se preocupen de la "
 "concurrencia. Además provee la mejor escalabilidad, ya que garantizando la "
-"identidad un unidades de trabajo monohebra no se necesitan bloqueos caros u "
-"otros medios de sincronización. La aplicación nunca necesita sincronizar "
-"sobre ningún objeto de negocio, siempre que se apegue a una sola hebra por "
+"identidad en unidades de trabajo monohilo no se necesitan bloqueos caros u "
+"otros medios de sincronización. La aplicación no necesita sincronizar sobre "
+"ningún objeto empresarial, siempre que se mantenga un solo hilo por "
 "<literal>Session</literal>. Dentro de una <literal>Session</literal> la "
 "aplicación puede usar con seguridad <literal>==</literal> para comparar "
 "objetos."
 
 #. Tag: para
-#: transactions.xml:313
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, an application that uses <literal>==</literal> outside of a "
 "<literal>Session</literal> might produce unexpected results. This might "
@@ -586,36 +580,34 @@
 msgstr ""
 "Sin embargo, una aplicación que usa <literal>==</literal> fuera de una "
 "<literal>Session</literal>, podría ver resultados inesperados. Esto podría "
-"ocurrir incluso en sitios algo inesperados, por ejemplo, si pones dos "
-"instancias separadas dentro del mismo <literal>Set</literal>. Ambas podrían "
-"tener la misma identidad de base de datos (es decir, representar la misma "
-"fila), pero la identidad JVM, por definición, no está garantizada para las "
-"instancias en estado separado. El desarrollador tiene que sobrescribir los "
-"métodos <literal>equals()</literal> y <literal>hashCode()</literal> en las "
-"clases persistentes e implementar su propia noción de igualdad de objetos. "
-"Hay una advertencia: Nunca uses el identificador de base de datos para "
-"implementar la igualdad, usa una clave de negocio, una combinación de "
-"atributos únicos, usualmente inmutables. El identificador de base de datos "
-"cambiará si un objeto transitorio es hecho persistente. Si la instancia "
-"transitoria (usualmente junta a instancias separadas) es mantenida en un "
-"<literal>Set</literal>, cambiar el código hash rompe el contrato del "
-"<literal>Set</literal>. Los atributos para las claves de negocio no tienen "
-"que ser tan estables como las claves primarias de base de datos, sólo tienes "
-"que garantizar estabilidad en tanto los objetos estén en el mismo "
-"<literal>Set</literal>. Mira el sitio web de Hibernate para una discusión "
-"más cuidadosa de este tema. Nota también que éste no es un tema de "
-"Hibernate, sino simplemente cómo la identidad y la igualdad de los objetos "
-"Java tiene que ser implementada."
+"ocurrir incluso en sitios algo inesperados. Por ejemplo, si pone dos "
+"instancias separadas dentro del mismo <literal>Set</literal> ambas podrían "
+"tener la misma identidad de la base de datos (por ejemplo, representar la "
+"misma fila). Sin embargo, la identidad MVJ, por definición, no está "
+"garantizada para las instancias en estado separado. El desarrollador tiene "
+"que sobrescribir los métodos <literal>equals()</literal> y <literal>hashCode"
+"()</literal> en las clases persistentes e implementar su propia noción de "
+"igualdad de objetos. Hay una advertencia: nunca use el identificador de la "
+"base de datos para implementar la igualdad. Use una clave de negocio, una "
+"combinación de atributos únicos, usualmente inmutables. El identificador de "
+"la base de datos cambiará si un objeto transitorio es hecho persistente. Si "
+"la instancia transitoria (usualmente junto a las instancias separadas) es "
+"mantenida en un <literal>Set</literal>, cambiar el código hash rompe el "
+"contrato del <literal>Set</literal>. Los atributos para las claves "
+"empresariales no tienen que ser tan estables como las claves principales de "
+"la base de datos, sólo tiene que garantizar estabilidad en tanto los objetos "
+"estén en el mismo <literal>Set</literal>. Mire el sitio web de Hibernate "
+"para obetener una discusión más profunda de este tema. Note también que éste "
+"no es problema de Hibernate, sino que simplemente se tiene que implementar "
+"la identidad y la igualdad de los objetos Java."
 
 #. Tag: title
-#: transactions.xml:334
 #, no-c-format
 msgid "Common issues"
-msgstr "Temas comunes"
+msgstr "Temas comúnes"
 
 #. Tag: para
-#: transactions.xml:336
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not use the anti-patterns <emphasis>session-per-user-session</emphasis> "
 "or <emphasis>session-per-application</emphasis> (there are, however, rare "
@@ -623,15 +615,14 @@
 "within the recommended patterns, so ensure that you understand the "
 "implications before making a design decision:"
 msgstr ""
-"Nunca uses los antipatrones <emphasis>sesión-por-sesión-de-usuario</"
-"emphasis> o <emphasis>sesión-por-aplicación</emphasis> (por supuesto, hay "
-"raras excepciones a esta regla). Nota que algunis de los siguientes temas "
-"podrían también aparecer con los patrones recomendados. Asegúrate que "
-"entiendes las implicaciones antes de tomar una decisión de diseño:"
+"No use los antipatrones <emphasis>sesión-por-sesión-de-usuario</emphasis> o "
+"<emphasis>sesión-por-aplicación</emphasis> (hay excepciones raras a esta "
+"regla). Algunos de los siguientes temas también podrían aparecer con los "
+"patrones recomendados así que asegúrese de que entiende las implicaciones "
+"antes de tomar una decisión de diseño:"
 
 #. Tag: para
-#: transactions.xml:345
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>Session</literal> is not thread-safe. Things that work "
 "concurrently, like HTTP requests, session beans, or Swing workers, will "
@@ -642,19 +633,18 @@
 "that clicks reload fast enough can use the same <literal>Session</literal> "
 "in two concurrently running threads."
 msgstr ""
-"Una <literal>Session</literal> no es segura entre hebras. Las cosas que se "
-"suponen que funcionan concurrentemente, como peticiones HTTP, beans de "
-"sesión, o workers de Swing, provocarán condiciones de competencia si una "
-"instancia de <literal>Session</literal> fuese compartida. Si guardas tu "
-"<literal>Session</literal> de Hibernate en tu <literal>HttpSession</literal> "
-"(discutido más adelante), debes considerar sincronizar el acceso a tu sesión "
-"HTTP. De otro modo, un usuario que hace click lo suficientemente rápido "
-"puede llegar a usar la misma <literal>Session</literal> en dos hebras "
-"ejecutándose concurrentemente."
+"Una <literal>Session</literal> no es segura entre hilos. Las cosas que "
+"funcionan de manera simultánea, como las peticiones HTTP, beans de sesión, o "
+"workers de Swing, provocarán condiciones de competencia si una instancia de "
+"<literal>Session</literal> se comparte. Si guarda su <literal>Session</"
+"literal> de Hibernate en su <literal>HttpSession</literal> (se discute más "
+"adelante), debe considerar el sincronizar el acceso a su sesión HTTP. De "
+"otro modo, un usuario que hace click lo suficientemente rápido puede llegar "
+"a usar la misma <literal>Session</literal> en dos hilos ejecutándose "
+"simultáneamente."
 
 #. Tag: para
-#: transactions.xml:356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An exception thrown by Hibernate means you have to rollback your database "
 "transaction and close the <literal>Session</literal> immediately (this is "
@@ -666,19 +656,18 @@
 "Usually this is not a problem, because exceptions are not recoverable and "
 "you will have to start over after rollback anyway."
 msgstr ""
-"Una excepción lanzada por Hibernate significa que tienes que deshacer "
-"(rollback) tu transacción de base de datos y cerrar la <literal>Session</"
-"literal> inmediatamente (discutido en más detalle luego). Si tu "
-"<literal>Session</literal> está ligada a la aplicación, tienes que parar la "
-"aplicación. Deshacer (rollback) la transacción de base de datos no pone a "
-"tus objetos de vuelta al estado en que estaban al comienzo de la "
+"Una excepción lanzada por Hibernate significa que tiene que deshacer su "
+"transacción de la base de datos y cerrar la <literal>Session</literal> "
+"inmediatamente (se discute en más detalle más adelante en este capítulo). Si "
+"su <literal>Session</literal> está vinculada a la aplicación, tiene que "
+"parar la aplicación. Deshacer la transacción de la base de datos no pone a "
+"sus objetos de vuelta al estado en que estaban al comienzo de la "
 "transacción. Esto significa que el estado de la base de datos y los objetos "
-"de negocio quedan fuera de sincronía. Usualmente esto no es un problema, "
-"pues las excepciones no son recuperables y tienes que volver a comenzar "
-"después del rollback de todos modos."
+"empreariales quedan fuera de sincronía. Usualmente esto no es un problema, "
+"pues las excepciones no son recuperables y tendrá que volver a comenzar "
+"después de deshacer de todos modos."
 
 #. Tag: para
-#: transactions.xml:368
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>Session</literal> caches every object that is in a persistent "
@@ -687,31 +676,29 @@
 "until you get an OutOfMemoryException. One solution is to call <literal>clear"
 "()</literal> and <literal>evict()</literal> to manage the <literal>Session</"
 "literal> cache, but you should consider a Stored Procedure if you need mass "
-"data operations. Some solutions are shown in <xref linkend=\"batch\"/>. "
+"data operations. Some solutions are shown in <xref linkend=\"batch\" />. "
 "Keeping a <literal>Session</literal> open for the duration of a user session "
 "also means a higher probability of stale data."
 msgstr ""
 "La <literal>Session</literal> pone en caché todo objeto que esté en estado "
-"persistente (vigilado y chequeado por estado sucio por Hibernate). Esto "
-"significa que crece sin fin hasta que obtienes una OutOfMemoryException, si "
-"la mantienes abierta por un largo tiempo o simplemente cargas demasiados "
-"datos. Una solución para esto es llamar a <literal>clear()</literal> y "
-"<literal>evict()</literal> para gestionar el caché de la <literal>Session</"
-"literal>, pero probalemente debas considerar un procedimiento almacenado si "
-"necesitas operaciones de datos masivas. Se muestran algunas soluciones en "
-"<xref linkend=\"batch\"/>. Mantener una <literal>Session</literal> abierta "
-"por la duración de una sesión de usuario significa también una alta "
-"probabilidad de datos añejos."
+"persistente (Hibernate vigila y chequea para identificar estados "
+"desactualizados). Si la mantiene abierta por un largo tiempo o simplemente "
+"carga demasiados datos crece sin fin hasta que obtiene una "
+"OutOfMemoryException. Una solución para esto es llamar a <literal>clear()</"
+"literal> y <literal>evict()</literal> para gestionar el caché de la "
+"<literal>Session</literal>, pero probalemente deba considerar un "
+"procedimiento almacenado si necesita operaciones de datos masivas. Se pueden "
+"ver algunas soluciones en <xref linkend=\"batch\"/>. Mantener una "
+"<literal>Session</literal> abierta durante una sesión de usuario también "
+"significa una alta probabilidad de datos desactualizados."
 
 #. Tag: title
-#: transactions.xml:386
 #, no-c-format
 msgid "Database transaction demarcation"
-msgstr "Demarcación de la transacción de base de datos"
+msgstr "Demarcación de la transacción de la base de datos"
 
 #. Tag: para
-#: transactions.xml:388
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Database, or system, transaction boundaries are always necessary. No "
 "communication with the database can occur outside of a database transaction "
@@ -722,18 +709,19 @@
 "transactions explicitly. Certainly, a single database transaction is going "
 "to perform better than many small transactions, even for reading data."
 msgstr ""
-"Los límites de las transacciones de base de datos (o sistema) son siempre "
-"necesarios. Ninguna comunicación con la base de datos puede darse fuera de "
-"una transacción de base de datos (esto parece confundir muchos "
-"desarrolladores acostumbrados al modo auto-commit). Siempre usa límites de "
+"Los límites de las transacciones de la base de datos o el sistema son "
+"siempre necesarios. Ninguna comunicación con la base de datos puede darse "
+"fuera de una transacción de la base de datos (esto parece confundir a muchos "
+"desarrolladores acostumbrados al modo auto-commit). Siempre use límites de "
 "transacción claros, incluso para las operaciones de sólo lectura. "
-"Dependiendo del nivel de aislamiento y las capacidades de base de datos, "
-"esto podría o no ser requerido, pero no hay un merma si siempre demarcas "
-"explícitamente las transacciones."
+"Dependiendo del nivel de aislamiento y las capacidades de la base de datos, "
+"esto podría requerirse o no, pero no hay inconvenientes si siempre demarca "
+"explícitamente las transacciones. Con seguridad, una transacción única de "
+"base de datos va a funcionar mejor que muchas transacciones pequeñas, "
+"inclusive para leer datos."
 
 #. Tag: para
-#: transactions.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A Hibernate application can run in non-managed (i.e., standalone, simple "
 "Web- or Swing applications) and managed J2EE environments. In a non-managed "
@@ -745,22 +733,20 @@
 "descriptors of EJB session beans, for example). Programmatic transaction "
 "demarcation is then no longer necessary."
 msgstr ""
-"Una aplicación Hibernate puede ejecutarse en entornos no manejados (es "
-"decir, como independiente, Web simple, o aplicaciones Swing) y entornos "
-"manejados J2EE. En un entorno no manejado, Hibernate es usualmente "
-"responsable de su propio pool de conexiones de base de datos. El "
-"desarrollador de aplicaciones tiene que establecer manualmente los límites "
-"de transacción, en otras palabras, hacer begin, commit, o rollback las "
-"transacciones de base de datos por sí mismo. Un entorno manejado usualmente "
-"provee transacciones gestionadas por contenedor, con el ensamble de "
-"transacción definido declarativamente en descriptores de despliegue de beans "
-"de sesión EJB, por ejemplo. La demarcación programática de transacciones no "
-"es más necesario, incluso limpiar (flush) la <literal>Session</literal> es "
-"hecho automáticamente."
+"Una aplicación Hibernate puede ejecutarse en entornos no administrados (por "
+"ejemplo, aplicaciones simples Web o Swing autónomas) y entornos "
+"administrados por J2EE. En un entorno no administrado, Hibernate es "
+"usualmente responsable de su propio pool de conexiones de la base de datos. "
+"El desarrollador de aplicaciones tiene que establecer manualmente los "
+"límites de transacción (inicar, guardar o deshacer las transacciones de la "
+"base de datos) por sí mismo. Un entorno administrado usualmente proporciona "
+"transacciones gestionadas por contenedor, con el ensamble de transacción "
+"definido declarativamente (por ejemplo, en descriptores de despliegue de "
+"beans de sesión EJB). La demarcación programática de transacciones ya no es "
+"necesaria."
 
 #. Tag: para
-#: transactions.xml:408
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, it is often desirable to keep your persistence layer portable "
 "between non-managed resource-local environments, and systems that can rely "
@@ -770,102 +756,74 @@
 "system of your deployment environment. This API is actually optional, but we "
 "strongly encourage its use unless you are in a CMT session bean."
 msgstr ""
-"Sin embargo, frecuentemente es deseable mantener portable tu capa de "
-"persistencia. Hibernate ofrece una API de envoltura llamada "
-"<literal>Transaction</literal> que se traduce al sistema de transacciones "
-"nativo de tu entorno de despliegue. Esta API es realmente opcional, pero "
-"recomendamos fuertemente su uso salvo que estés en un bean de sesión CMT."
+"Sin embargo, comúnmente se quiere mantener su capa de persistencia portátil "
+"entre entornos locales- de recursos no-administrados y sistemas que pueden "
+"confiar en JTA, pero utilizar BMT en vez de CMT. En ambos casos utilizaría "
+"la demarcación de transacción programática. Hibernate ofrece una API de "
+"envoltura llamada <literal>Transaction</literal> que se traduce al sistema "
+"de transacciones nativo de su entorno de despliegue. Esta API es de hecho "
+"opcional, pero le recomendamos bastante su uso salvo que esté en un bean de "
+"sesión CMT. "
 
 #. Tag: para
-#: transactions.xml:417
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Ending a <literal>Session</literal> usually involves four distinct phases:"
 msgstr ""
-"Usualmente, finalizar una <literal>Session</literal> implica cuatro fases "
+"Usualmente, el finalizar una <literal>Session</literal> implica cuatro fases "
 "distintas:"
 
 #. Tag: para
-#: transactions.xml:423
 #, no-c-format
 msgid "flush the session"
-msgstr "limpiar (flush) la sesión"
+msgstr "limpiar la sesión"
 
 #. Tag: para
-#: transactions.xml:428
 #, no-c-format
 msgid "commit the transaction"
-msgstr "comprometer la transacción"
+msgstr "someter la transacción"
 
 #. Tag: para
-#: transactions.xml:433
 #, no-c-format
 msgid "close the session"
 msgstr "cerrar la sesión"
 
 #. Tag: para
-#: transactions.xml:438
 #, no-c-format
 msgid "handle exceptions"
 msgstr "manejar excepciones"
 
 #. Tag: para
-#: transactions.xml:444
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We discussed Flushing the session earlier, so we will now have a closer look "
 "at transaction demarcation and exception handling in both managed and non-"
 "managed environments."
 msgstr ""
-"Limpiar la sesión ha sido discutido anteriormente, tendremos ahora una "
-"mirada más de cerca a la demarcación de transacciones y manejo de "
-"excepciones en sendos entornos manejado y no manejados."
+"Anteriormente se discutió el vacido de la sesión así que ahora vamos a mirar "
+"más de cerca la demarcación de transacciones y el manejo de excepciones en "
+"los dos entornos administrado y no administrado."
 
 #. Tag: title
-#: transactions.xml:451
 #, no-c-format
 msgid "Non-managed environment"
-msgstr "Entorno no manejado"
+msgstr "Entorno no administrado"
 
 #. Tag: para
-#: transactions.xml:453
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If a Hibernate persistence layer runs in a non-managed environment, database "
 "connections are usually handled by simple (i.e., non-DataSource) connection "
 "pools from which Hibernate obtains connections as needed. The session/"
 "transaction handling idiom looks like this:"
 msgstr ""
-"Si una capa de persistencia Hibernate se ejecuta en un entorno no manejado, "
-"las conexiones de base de datos son manejadas usualmente por el mecanismo de "
-"pooling de Hibernate. El idioma manejo de sesión/transacción se ve así:"
+"Si una capa de persistencia Hibernate se ejecuta en un entorno no "
+"administrado, las conexiones de la base de datos se manejan usualmente por "
+"simples pools de conexión (por ejemplo, no-DataSource) del cual Hibernate "
+"obtiene conexiones al ser necesario. El idioma de manejo de sesión/"
+"transacción se ve así:"
 
-#. Tag: programlisting
-#: transactions.xml:460
-#, no-c-format
-msgid ""
-"<![CDATA[// Non-managed environment idiom\n"
-"Session sess = factory.openSession();\n"
-"Transaction tx = null;\n"
-"try {\n"
-"    tx = sess.beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    if (tx != null) tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:462
 #, fuzzy, no-c-format
 msgid ""
 "You do not have to <literal>flush()</literal> the <literal>Session</literal> "
@@ -876,46 +834,27 @@
 "literal> is that the JDBC connection will be relinquished by the session. "
 "This Java code is portable and runs in both non-managed and JTA environments."
 msgstr ""
-"No tienes que limpiar con <literal>flush()</literal> la <literal>Session</"
-"literal> explícitamente - la llamada a <literal>commit()</literal> "
-"automáticamente dispara la sincronización. Una llamada a <literal>close()</"
-"literal> marca el fin de una sesión. La principal implicación de "
+"No tiene que vaciar con <literal>flush()</literal> la <literal>Session</"
+"literal> explícitamente: la llamada a <literal>commit()</literal> "
+"automáticamente dispara la sincronización dependiendo del <xref linkend="
+"\"objectstate-flushing\"/> para la sesión. Una llamada a <literal>close()</"
+"literal> marca el final de una sesión. La implicación principal de "
 "<literal>close()</literal> es que la conexión JDBC será abandonada por la "
-"sesión."
+"sesión. Este código Java es portátil y ejecuta en entornos tanto no-"
+"administrados como JTA."
 
 #. Tag: para
-#: transactions.xml:471
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As outlined earlier, a much more flexible solution is Hibernate's built-in "
 "\"current session\" context management:"
 msgstr ""
-"Este código Java es portable y se ejecuta tanto en entornos no manejados "
-"como en entornos JTA."
+"Como se mencionó anteriormente, una solución mucho más flexible es la "
+"administración de contexto \"sesión actual\" incorporada en Hibernate:"
 
-#. Tag: programlisting
-#: transactions.xml:476
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// Non-managed environment idiom with getCurrentSession()\n"
-"try {\n"
-"    factory.getCurrentSession().beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    factory.getCurrentSession().getTransaction().commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    factory.getCurrentSession().getTransaction().rollback();\n"
-"    throw e; // or display error message\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:478
-#, fuzzy, no-c-format
-msgid ""
 "You will not see these code snippets in a regular application; fatal "
 "(system) exceptions should always be caught at the \"top\". In other words, "
 "the code that executes Hibernate calls in the persistence layer, and the "
@@ -925,37 +864,36 @@
 "<literal>SessionFactory</literal>. Exception handling is discussed later in "
 "this chapter."
 msgstr ""
-"Muy probablemente nunca veas este idioma en código de negocio en una "
-"aplicación normal; las excepciones fatales (sistema) deben siempre ser "
-"capturadas en la \"cima\". En otras palabras, el código que ejecuta las "
-"llamadas de Hibernate (en la capa de persistencia) y el código que maneja "
-"<literal>RuntimeException</literal> (y usualmente sólo puede limpiar y "
-"salir) están en capas diferentes. Esto puede ser un desafío de diseñarlo tú "
-"mismo y debes usar los servicios de contenedor J2EE/EJB en cuanto estuviesen "
-"disponibles. El manejo de excepciones se dicute más adelante en este "
-"capítulo."
+"No verá estos pedazos de código en una aplicación normal; las excepciones "
+"fatales (del sistema) siempre deben ser capturadas en la \"cima\". En otras "
+"palabras, el código que ejecuta las llamadas de Hibernate en la capa de "
+"persistencia y el código que maneja <literal>RuntimeException</literal> (y "
+"usualmente sólo puede limpiar y salir) se encuentran en capas diferentes. La "
+"administración de contexto actual de Hibernate puede simplificar de manera "
+"importante este diseño, ya que todo lo que necesita hacer es acceder a "
+"<literal>SessionFactory</literal>. El manejo de excepciones se discute más "
+"adelante en este capítulo."
 
 #. Tag: para
-#: transactions.xml:488
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You should select <literal>org.hibernate.transaction.JDBCTransactionFactory</"
 "literal>, which is the default, and for the second example select <literal>"
 "\"thread\"</literal> as your <literal>hibernate."
 "current_session_context_class</literal>."
 msgstr ""
-"Nota que debes seleccionar <literal>org.hibernate.transaction."
-"JDBCTransactionFactory</literal> (que es el por defecto)."
+"Debe seleccionar <literal>org.hibernate.transaction.JDBCTransactionFactory</"
+"literal>, el cual es el predeterminado, y para el segundo ejemplo "
+"seleccionar <literal>\"thread\"</literal> como su <literal>hibernate."
+"current_session_context_class</literal>."
 
 #. Tag: title
-#: transactions.xml:497
 #, no-c-format
 msgid "Using JTA"
-msgstr "Usando JTA"
+msgstr "Utilización de JTA"
 
 #. Tag: para
-#: transactions.xml:499
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your persistence layer runs in an application server (for example, behind "
 "EJB session beans), every datasource connection obtained by Hibernate will "
@@ -963,126 +901,51 @@
 "standalone JTA implementation and use it without EJB. Hibernate offers two "
 "strategies for JTA integration."
 msgstr ""
-"Si tu capa de persistencia se ejecuta en un servidor de aplicaciones (por "
-"ejemplo, detrás de beans de sesión EJB), cada conexión de datasource "
-"obtenida por Hibernate será parte automáticamente de la transacción JTA "
-"global. Hibernate ofrece dos estrategias para esta integración."
+"Si su capa de persistencia se ejecuta en un servidor de aplicaciones (por "
+"ejemplo, detrás de los beans de sesión EJB), cada conexión de fuente de "
+"datos obtenida por Hibernate será parte de la transacción JTA global de "
+"manera automática. También puede instalar una implementación JTA autónoma y "
+"utilizarla sin EJB. Hibernate ofrece dos estrategias para esta integración "
+"JTA."
 
 #. Tag: para
-#: transactions.xml:506
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you use bean-managed transactions (BMT), Hibernate will tell the "
 "application server to start and end a BMT transaction if you use the "
 "<literal>Transaction</literal> API. The transaction management code is "
 "identical to the non-managed environment."
 msgstr ""
-"Si usas transacciones gestionadas-por-bean (BMT) Hibernate le dirá al "
-"servidor de aplicaciones que comience y finalice una transacción BMT si usas "
+"Si usa transacciones gestionadas-por-bean (BMT) Hibernate le dirá al "
+"servidor de aplicaciones que comience y finalice una transacción BMT si usa "
 "la API de <literal>Transaction</literal>. De modo que, el código de gestión "
-"de la transacción es idéntico al de un entorno no manejado."
+"de la transacción es idéntico al de un entorno no administrado. "
 
-#. Tag: programlisting
-#: transactions.xml:512
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// BMT idiom\n"
-"Session sess = factory.openSession();\n"
-"Transaction tx = null;\n"
-"try {\n"
-"    tx = sess.beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    if (tx != null) tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:514
-#, fuzzy, no-c-format
-msgid ""
 "If you want to use a transaction-bound <literal>Session</literal>, that is, "
 "the <literal>getCurrentSession()</literal> functionality for easy context "
 "propagation, use the JTA <literal>UserTransaction</literal> API directly:"
 msgstr ""
-"Con CMT, la demarcación de la transacción se hace en descriptores de "
-"despliegue de beans de sesión, no programáticamente. Si no quieres limpiar "
-"(flush) y cerrar manualmente la <literal>Session</literal> por ti mismo, "
-"solamente establece <literal>hibernate.transaction.flush_before_completion</"
-"literal> a <literal>true</literal>, <literal>hibernate.connection."
-"release_mode</literal> a <literal>after_statement</literal> o <literal>auto</"
-"literal> y <literal>hibernate.transaction.auto_close_session</literal> a "
-"<literal>true</literal>. Hibernate limpiará y cerrará entonces "
-"automáticamente la <literal>Session</literal> para ti. Lo único que resta es "
-"deshacer (rollback) la transacción cuando ocurra una excepción. "
-"Afortunadamente, en un bean CMT, incluso esto ocurre automáticamente, ya que "
-"una <literal>RuntimeException</literal> no manejada disparada por un método "
-"de un bean de sesión le dice al contenedor que ponga a deshacer la "
-"transacción global. <emphasis>Esto significa que, en CMT, no necesitas usar "
-"en absoluto la API de <literal>Transaction</literal> de Hibernate.</emphasis>"
+"Si quiere utilizar un vínculo de transacción <literal>Session</literal>, es "
+"decir, la funcionalidad <literal>getCurrentSession()</literal> para "
+"propagación de contexto de manera fácil, tendrá que utilizar el API "
+"<literal>UserTransaction</literal> del JTA directamente: "
 
-#. Tag: programlisting
-#: transactions.xml:520
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// BMT idiom with getCurrentSession()\n"
-"try {\n"
-"    UserTransaction tx = (UserTransaction)new InitialContext()\n"
-"                            .lookup(\"java:comp/UserTransaction\");\n"
-"\n"
-"    tx.begin();\n"
-"\n"
-"    // Do some work on Session bound to transaction\n"
-"    factory.getCurrentSession().load(...);\n"
-"    factory.getCurrentSession().persist(...);\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:522
-#, fuzzy, no-c-format
-msgid ""
 "With CMT, transaction demarcation is completed in session bean deployment "
 "descriptors, not programmatically. The code is reduced to:"
 msgstr ""
-"Nota que debes elegir <literal>org.hibernate.transaction."
-"JTATransactionFactory</literal> en un bean de sesión BMT, y <literal>org."
-"hibernate.transaction.CMTTransactionFactory</literal> en un bean de sesión "
-"CMT, cuando configures la fábrica de transacciones de Hibernate. Recuerda "
-"además establecer <literal>org.hibernate.transaction.manager_lookup_class</"
-"literal>."
+"Con CMT, la demarcación de transacción se realiza en los descriptores de "
+"implementacion bean de sesión, no programáticamente. Por lo tanto el código "
+"se reduce a:"
 
-#. Tag: programlisting
-#: transactions.xml:527
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// CMT idiom\n"
-" Session sess = factory.getCurrentSession();\n"
-"\n"
-" // do some work\n"
-" ...\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:529
-#, fuzzy, no-c-format
-msgid ""
 "In a CMT/EJB, even rollback happens automatically. An unhandled "
 "<literal>RuntimeException</literal> thrown by a session bean method tells "
 "the container to set the global transaction to rollback. <emphasis>You do "
@@ -1090,24 +953,15 @@
 "BMT or CMT, and you get automatic propagation of the \"current\" Session "
 "bound to the transaction.</emphasis>"
 msgstr ""
-"Si trabajas en un entorno CMT, y usas limpieza (flushing) y cierre "
-"automáticos de la sesión, podrías querer también usar la misma sesión en "
-"diferentes partes de tu código. Típicamente, en un entorno no manejado, "
-"usarías una variable <literal>ThreadLocal</literal> para tener la sesión, "
-"pero una sola petición de EJB puede ejecutarse en diferentes hebras (por "
-"ejemplo, un bean de sesión llamando a otro bean de sesión). Si no quieres "
-"molestarte en pasar tu <literal>Session</literal> por alrededor, la "
-"<literal>SessionFactory</literal> provee el método <literal>getCurrentSession"
-"()</literal>, que devuelve una sesión que está pegada al contexto de "
-"transacción JTA. ¡Esta es la forma más fácil de integrar Hibernate en una "
-"aplicación! La sesión \"actual\" siempre tiene habilitados limpieza, cierre "
-"y liberación de conexión automáticos (sin importar la configuración de las "
-"propiedades anteriores). Nuestra idioma de gestión de sesión/transacción se "
-"reduce a:"
+"En un CMT/EJB incluso el deshacer sucede de forma automática. Un "
+"<literal>RuntimeException</literal> lanzado por un método bean de sesión le "
+"dice al contenedor que establezca una transacción global para deshacer. "
+"<emphasis>No necesita utilizar el API <literal>Transaction</literal> de "
+"Hibernate con BMT o CMT y obtiene la propagación automática de sesión\"actual"
+"\" vinculada a la transacción.</emphasis>"
 
 #. Tag: para
-#: transactions.xml:537
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When configuring Hibernate's transaction factory, choose <literal>org."
 "hibernate.transaction.JTATransactionFactory</literal> if you use JTA "
@@ -1117,16 +971,17 @@
 "your <literal>hibernate.current_session_context_class</literal> is either "
 "unset (backwards compatibility), or is set to <literal>\"jta\"</literal>."
 msgstr ""
-"En otras palabras, todo lo que tienes que hacer en un entorno manejado, es "
-"llamar a <literal>SessionFactory.getCurrentSession()</literal>, hacer tu "
-"trabajo de acceso a datos, y dejar el resto al contenedor. Los límites de "
-"transacción se establecen declarativamente en los descriptores de despliegue "
-"de tu bean de sesión. El ciclo de vida de la sesión es manejado "
-"completamente por Hibernate."
+"Al configurar la fábrica de transacciones de Hibernate, escoja <literal>org."
+"hibernate.transaction.JTATransactionFactory</literal> si utiliza JTA "
+"directamente (BMT) y <literal>org.hibernate.transaction."
+"CMTTransactionFactory</literal> en una bean de sesión CMT. Recuerde "
+"establecer también <literal>hibernate.transaction.manager_lookup_class</"
+"literal>. Asegúrese de que su <literal>hibernate."
+"current_session_context_class</literal> no se encuentra configurado "
+"(compatibilidad retrasada) o configurada como <literal>\"jta\"</literal>."
 
 #. Tag: para
-#: transactions.xml:546
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>getCurrentSession()</literal> operation has one downside in a "
 "JTA environment. There is one caveat to the use of <literal>after_statement</"
@@ -1141,28 +996,27 @@
 "using <literal>scroll()</literal> or <literal>iterate()</literal> from the "
 "JTA or CMT code.)"
 msgstr ""
-"Existe una advertencia al uso del modo de liberación de conexión "
-"<literal>after_statement</literal>. Debido a una limitación tonta de la "
-"especificación de JTA, no es posible para Hibernate limpiar automáticamente "
-"ningún <literal>ScrollableResults</literal> no cerrado ni instancias de "
-"<literal>Iterator</literal> devueltas por <literal>scroll()</literal> o "
-"<literal>iterate()</literal>. <emphasis>Debes</emphasis> liberar el cursor "
-"de base de datos subyacente llamando a <literal>ScrollableResults.close()</"
-"literal> o <literal>Hibernate.close(Iterator)</literal> explícitamente desde "
-"un bloque <literal>finally</literal>. (Por supuesto, la mayoría de las "
-"aplicaciones pueden evitarlo fácilmente no usando en absoluto ningún "
-"<literal>scroll()</literal> o <literal>iterate()</literal> desde el código "
-"CMT.)"
+"La operación <literal>getCurrentSession()</literal> tiene un inconveniente "
+"en un entorno JTA. Hay una desventaja en el uso del modo de liberación de la "
+"conección <literal>after_statement</literal>, la cual luego se utiliza por "
+"defecto. Debido a una limitación de la especificación JTA, no le es posible "
+"a Hibernate limpiar automáticamente cualquier instancia "
+"<literal>ScrollableResults</literal> o <literal>Iterator</literal> no "
+"cerradas y retornadas por <literal>scroll()</literal> o <literal>iterate()</"
+"literal>. <emphasis>Tiene</emphasis> que liberar el cursor de la base de "
+"datos subyacente llamando a <literal>ScrollableResults.close()</literal> o "
+"<literal>Hibernate.close(Iterator)</literal> explícitamente desde un bloque "
+"<literal>finally</literal>. La mayoría de las aplicaciones pueden evitar "
+"fácilmente el utilizar <literal>scroll()</literal> o <literal>iterate()</"
+"literal> del código JTA o CMT."
 
 #. Tag: title
-#: transactions.xml:562
 #, no-c-format
 msgid "Exception handling"
 msgstr "Manejo de excepciones"
 
 #. Tag: para
-#: transactions.xml:564
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the <literal>Session</literal> throws an exception, including any "
 "<literal>SQLException</literal>, immediately rollback the database "
@@ -1173,19 +1027,18 @@
 "Ensure that the <literal>Session</literal> will be closed by calling "
 "<literal>close()</literal> in a <literal>finally</literal> block."
 msgstr ""
-"Si la <literal>Session</literal> lanza una excepción (incluyendo cualquier "
-"<literal>SQLException</literal>), debes inmediatamente deshacer (rollback) "
-"la transacción de base de datos, llamar a <literal>Session.close()</literal> "
-"y descartar la instancia de <literal>Session</literal>. Ciertos métodos de "
-"<literal>Session</literal><emphasis>no</emphasis> dejarán la sesión en un "
+"Si la <literal>Session</literal> lanza una excepción, incluyendo cualquier "
+"<literal>SQLException</literal>, debe deshacer inmediatamente la transacción "
+"de la base de datos, llamar a <literal>Session.close()</literal> y descartar "
+"la instancia de <literal>Session</literal>. Ciertos métodos de "
+"<literal>Session</literal> <emphasis>no</emphasis> dejarán la sesión en un "
 "estado consistente. Ninguna excepción lanzada por Hibernate puede ser "
-"tratada como recuperable. Asegúrate que la <literal>Session</literal> sea "
-"cerrada llamando a <literal>close()</literal> en un bloque <literal>finally</"
+"tratada como recuperable. Asegúrese de que la <literal>Session</literal> se "
+"cierre llamando a <literal>close()</literal> en un bloque <literal>finally</"
 "literal>."
 
 #. Tag: para
-#: transactions.xml:575
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>HibernateException</literal>, which wraps most of the errors "
 "that can occur in a Hibernate persistence layer, is an unchecked exception. "
@@ -1198,22 +1051,21 @@
 "unchecked exceptions that are not a <literal>HibernateException</literal>. "
 "These are not recoverable and appropriate action should be taken."
 msgstr ""
-"La <literal>HibernateException</literal>, que envuelve la mayoría de los "
-"errores que pueden ocurrir en la capa de persistencia de Hibernate, en una "
-"excepción no chequeada (no lo era en versiones anteriores de Hibernate). En "
+"La <literal>HibernateException</literal>, que envuelve a la mayoría de los "
+"errores que pueden ocurrir en la capa de persistencia de Hibernate, es una "
+"excepción no chequeada. No lo era en versiones anteriores de Hibernate. En "
 "nuestra opinión, no debemos forzar al desarrollador de aplicaciones a "
 "capturar una excepción irrecuperable en una capa baja. En la mayoría de los "
 "sistemas, las excepciones no chequeadas y fatales son manejadas en uno de "
-"los primeros cuadros de la pila de llamadas a métodos (es decir, en las "
-"capas más altas) y se presenta un mensaje de error al usuario de la "
-"aplicación (o se toma alguna otra acción apropiada). Nota que Hibernate "
-"podría también lanzar otras excepciones no chequeadas que no sean una "
-"<literal>HibernateException</literal>. Una vez más, no son recuperables y "
-"debe tomarse una acción apropiada."
+"los primeros cuadros de la pila de llamadas a métodos (por ejemplo, en las "
+"capas más altas) y presenta un mensaje de error al usuario de la aplicación "
+"o se toma alguna otra acción apropiada. Note que Hibernate podría también "
+"lanzar otras excepciones no chequeadas que no sean una "
+"<literal>HibernateException</literal>. Estas no son recuperables y debe "
+"tomarse una acción apropiada."
 
 #. Tag: para
-#: transactions.xml:587
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate wraps <literal>SQLException</literal>s thrown while interacting "
 "with the database in a <literal>JDBCException</literal>. In fact, Hibernate "
@@ -1234,76 +1086,69 @@
 "interactúa con la base de datos en una <literal>JDBCException</literal>. De "
 "hecho, Hibernate intentará convertir la excepción en una subclase de "
 "<literal>JDBCException</literal> más significativa. La "
-"<literal>SQLException</literal> está siempre disponible vía "
-"<literal>JDBCException.getCause()</literal>. Hibernate convierte la "
+"<literal>SQLException</literal> subyacente siempre está disponible por medio "
+"de <literal>JDBCException.getCause()</literal>. Hibernate convierte la "
 "<literal>SQLException</literal> en una subclase de <literal>JDBCException</"
 "literal> apropiada usando el <literal>SQLExceptionConverter</literal> "
 "adjunto a la <literal>SessionFactory</literal>. Por defecto, el "
-"<literal>SQLExceptionConverter</literal> está definido para el dialecto "
-"configurado; sin embargo, es también posible enchufar una implementación "
-"personalizada (ver los javadocs de la clase "
-"<literal>SQLExceptionConverterFactory</literal> para los detalles). Los "
-"subtipos estándar de <literal>JDBCException</literal> son:"
+"<literal>SQLExceptionConverter</literal> está definido por el dialecto "
+"configurado. Sin embargo, también es posible enchufar una implementación "
+"personalizada . Consulte los javadocs de la clase "
+"<literal>SQLExceptionConverterFactory</literal> para obtener más detalles. "
+"Los subtipos estándar de <literal>JDBCException</literal> son: "
 
 #. Tag: para
-#: transactions.xml:603
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>JDBCConnectionException</literal>: indicates an error with the "
 "underlying JDBC communication."
 msgstr ""
-"<literal>JDBCConnectionException</literal> - indica un error con la "
+"<literal>JDBCConnectionException</literal>: indica un error con la "
 "comunicación JDBC subyacente."
 
 #. Tag: para
-#: transactions.xml:609
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>SQLGrammarException</literal>: indicates a grammar or syntax "
 "problem with the issued SQL."
 msgstr ""
-"<literal>SQLGrammarException</literal> - indica un problema de gramática o "
+"<literal>SQLGrammarException</literal>: indica un problema de gramática o "
 "sintáxis con el SQL publicado."
 
 #. Tag: para
-#: transactions.xml:615
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ConstraintViolationException</literal>: indicates some form of "
 "integrity constraint violation."
 msgstr ""
-"<literal>ConstraintViolationException</literal> - indica alguna forma de "
+"<literal>ConstraintViolationException</literal>: indica alguna forma de "
 "violación de restricción de integridad."
 
 #. Tag: para
-#: transactions.xml:621
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockAcquisitionException</literal>: indicates an error acquiring a "
 "lock level necessary to perform the requested operation."
 msgstr ""
-"<literal>LockAcquisitionException</literal> - indica un error adquiriendo un "
+"<literal>LockAcquisitionException</literal>: indica un error adquiriendo un "
 "nivel de bloqueo necesario para realizar una operación solicitada."
 
 #. Tag: para
-#: transactions.xml:627
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>GenericJDBCException</literal>: a generic exception which did not "
 "fall into any of the other categories."
 msgstr ""
-"<literal>GenericJDBCException</literal> - una excepción genérica que no cayó "
-"en ninguna de las otras categorías."
+"<literal>GenericJDBCException</literal>: una excepción genérica que no "
+"encajó en ninguna de las otras categorías."
 
 #. Tag: title
-#: transactions.xml:637
 #, no-c-format
 msgid "Transaction timeout"
-msgstr "Transaction timeout"
+msgstr "Tiempo de espera de la transacción"
 
 #. Tag: para
-#: transactions.xml:639
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An important feature provided by a managed environment like EJB, that is "
 "never provided for non-managed code, is transaction timeout. Transaction "
@@ -1316,61 +1161,36 @@
 "transaction timeout to JTA. This functionality is abstracted by the "
 "Hibernate <literal>Transaction</literal> object."
 msgstr ""
-"One extremely important feature provided by a managed environment like EJB "
-"that is never provided for non-managed code is transaction timeout. "
-"Transaction timeouts ensure that no misbehaving transaction can indefinitely "
-"tie up resources while returning no response to the user. Outside a managed "
-"(JTA) environment, Hibernate cannot fully provide this functionality. "
-"However, Hibernate can at least control data access operations, ensuring "
-"that database level deadlocks and queries with huge result sets are limited "
-"by a defined timeout. In a managed environment, Hibernate can delegate "
-"transaction timeout to JTA. This functioanlity is abstracted by the "
-"Hibernate <literal>Transaction</literal> object."
+"Una característica importante proporcionada por un entorno administrado como "
+"EJB que nunca es proporcionado para un código no-administrado, es el tiempo "
+"de espera de la transacción. Estos tiempos de espera se aseguran de que "
+"ninguna transacción que se comporte inapropiadamente pueda vincular recursos "
+"mientras no devuelva una respuesta al usuario. Fuera de un entorno "
+"administrado (JTA), Hibernate no puede proporcionar completamente esta "
+"funcionalidad. Sin embargo, Hibernate puede por lo menos controlar las "
+"operaciones de acceso de datos, asegurándose de que los bloqueos a nivel de "
+"base de datos y las consultas con grandes grupos de resultados se encuentran "
+"limitados por un tiempo de espera definido. En un entorno administrado, "
+"Hibernate puede delegar el tiempo de espera de la transacción a JTA. Esta "
+"funcionalidad es abstraída por el objeto <literal>Transaction</literal> de "
+"Hibernate."
 
-#. Tag: programlisting
-#: transactions.xml:652
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"Session sess = factory.openSession();\n"
-"try {\n"
-"    //set transaction timeout to 3 seconds\n"
-"    sess.getTransaction().setTimeout(3);\n"
-"    sess.getTransaction().begin();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    sess.getTransaction().commit()\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    sess.getTransaction().rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:654
-#, fuzzy, no-c-format
-msgid ""
 "<literal>setTimeout()</literal> cannot be called in a CMT bean, where "
 "transaction timeouts must be defined declaratively."
 msgstr ""
-"Note that <literal>setTimeout()</literal> may not be called in a CMT bean, "
-"where transaction timeouts must be defined declaratively."
+"<literal>setTimeout()</literal> no se puede llamar en un bean CMT, en donde "
+"se deben definir declarativamente los tiempos de espera de las transacciones."
 
 #. Tag: title
-#: transactions.xml:664
 #, no-c-format
 msgid "Optimistic concurrency control"
-msgstr "Control optimista de concurrencia"
+msgstr "Control de concurrencia optimista"
 
 #. Tag: para
-#: transactions.xml:666
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The only approach that is consistent with high concurrency and high "
 "scalability, is optimistic concurrency control with versioning. Version "
@@ -1380,25 +1200,23 @@
 "discuss are in the context of long conversations, but version checking also "
 "has the benefit of preventing lost updates in single database transactions."
 msgstr ""
-"El único enfoque que es consistente con alta concurrencia y alta "
-"escalabilidad es el control optimista de concurrencia con versionamiento. El "
-"chuequeo de versión usa números de versión, o timestamps, para detectar "
-"actualizaciones en conflicto (y para prevenir actualizaciones perdidas). "
-"Hibernate provee para tres enfoques posibles de escribir código de "
-"aplicación que use concurrencia optimista. Los casos de uso que hemos "
-"mostrado están en el contexto de transacciones de aplicación largas pero el "
-"chequeo de versiones tiene además el beneficio de prevenir actualizaciones "
-"perdidas en transacciones de base de datos solas."
+"El único enfoque consistente con una alta concurrencia y una alta "
+"escalabilidad es el control de concurrencia optimista con versionamiento. El "
+"chequeo de versión utiliza números de versión, o sellos de fecha "
+"(timestamps), para detectar actualizaciones en conflicto y para prevenir la "
+"pérdida de actualizaciones. Hibernate proporciona tres enfoques posibles de "
+"escribir código de aplicación que utilice concurrencia optimista. Los casos "
+"de uso que mostramos se encuentran en el contexto de conversaciones largas, "
+"pero el chequeo de versiones tiene además el beneficio de prevenir la "
+"pérdida de actualizaciones en transacciones individuales de la base de datos."
 
 #. Tag: title
-#: transactions.xml:677
 #, no-c-format
 msgid "Application version checking"
-msgstr "Chequeo de versiones de aplicación"
+msgstr "Chequeo de versiones de la aplicación"
 
 #. Tag: para
-#: transactions.xml:679
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In an implementation without much help from Hibernate, each interaction with "
 "the database occurs in a new <literal>Session</literal> and the developer is "
@@ -1408,47 +1226,28 @@
 "least efficient in terms of database access. It is the approach most similar "
 "to entity EJBs."
 msgstr ""
-"En una implementación sin mucha ayuda de Hibernate, cada interacción con la "
-"base de datos ocurre en una nueva <literal>Session</literal> y el "
-"desarrollador es responsable de recargar todas las intancias persistentes "
-"desde la base de datos antes de manipularlas. Este enfoque fuerza a la "
-"aplicación a realizar su propio chequeo de versiones para asegurar el "
-"aislamiento de transacciones de base de datos. Es el enfoque más similar a "
-"los EJBs de entidad."
+"En una implementación que no tiene mucha ayuda de Hibernate, cada "
+"interacción con la base de datos ocurre en una nueva <literal>Session</"
+"literal> y el desarrollador es el responsable de recargar todas las "
+"intancias persistentes desde la base de datos antes de manipularlas. Este "
+"enfoque fuerza a la aplicación a realizar su propio chequeo de versiones "
+"para asegurar el aislamiento de transacciones de conversaciones. Este "
+"enfoque es el menos eficiente en términos de acceso a la base de datos. Es "
+"el enfoque más similar a los EJBs de entidad."
 
-#. Tag: programlisting
-#: transactions.xml:688
-#, no-c-format
-msgid ""
-"<![CDATA[// foo is an instance loaded by a previous Session\n"
-"session = factory.openSession();\n"
-"Transaction t = session.beginTransaction();\n"
-"\n"
-"int oldVersion = foo.getVersion();\n"
-"session.load( foo, foo.getKey() ); // load the current state\n"
-"if ( oldVersion != foo.getVersion() ) throw new StaleObjectStateException"
-"();\n"
-"foo.setProperty(\"bar\");\n"
-"\n"
-"t.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:690
 #, no-c-format
 msgid ""
 "The <literal>version</literal> property is mapped using <literal>&lt;"
 "version&gt;</literal>, and Hibernate will automatically increment it during "
 "flush if the entity is dirty."
 msgstr ""
-"La propiedad <literal>version</literal> se mapea usando <literal>&lt;"
+"La propiedad <literal>version</literal> se mapea utilizando <literal>&lt;"
 "version&gt;</literal>, e Hibernate la incrementará automáticamente durante "
-"la limpieza si la entidad está sucia."
+"la limpieza si la entidad está desactualizada."
 
 #. Tag: para
-#: transactions.xml:696
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are operating in a low-data-concurrency environment, and do not "
 "require version checking, you can use this approach and skip the version "
@@ -1457,18 +1256,16 @@
 "of the application, as they might experience lost updates without error "
 "messages or a chance to merge conflicting changes."
 msgstr ""
-"Por supuesto, si estás operando un entorno de baja-concurrencia-de-datos y "
-"no requieres chequeo de versiones, puedes usar este enfoque y simplemente "
-"saltar el chequeo de versiones. En ese caso, <emphasis>el último compromiso "
-"(commit) gana</emphasis> será la estrategia por defecto para tus "
-"transacciones de aplicación largas. Ten en mente que esto podría confundir a "
-"los usuarios de la aplicación, pues podrían experimentar actualizaciones "
-"perdidas sin mensajes de error ni chance de fusionar los cambios "
-"conflictivos."
+"Si está operando un entorno de baja-concurrencia-de-datos y no requiere "
+"chequeo de versiones, puede usar este enfoque y simplemente saltarse el "
+"chequeo de versiones. En ese caso, <emphasis>el último que guarda gana</"
+"emphasis> y será la estrategia por defecto para conversaciones largas. Tenga "
+"en mente que esto podría confundir a los usuarios de la aplicación, pues "
+"podrían experimentar pérdidas de actualizaciones sin mensajes de error ni "
+"oportunidad de fusionar los cambios conflictivos."
 
 #. Tag: para
-#: transactions.xml:705
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Manual version checking is only feasible in trivial circumstances and not "
 "practical for most applications. Often not only single instances, but "
@@ -1476,22 +1273,20 @@
 "automatic version checking with either an extended <literal>Session</"
 "literal> or detached instances as the design paradigm."
 msgstr ""
-"Claramente, el chequeo manual de versiones es factible solamente en "
-"circunstancias muy triviales, y no es práctico para la mayoría de "
-"aplicaciones. Frecuentemente, no sólo intancias solas, sino grafos completos "
-"de objetos modificados tienen que ser chequeados. Hibernate ofrece chequeo "
+"El chequeo manual de versiones es factible sólamente en circunstancias muy "
+"triviales y no es práctico para la mayoría de las aplicaciones. Con "
+"frecuencia se tienen que chequear no sólamente las intancias sólas, sino "
+"también grafos completos de objetos modificados. Hibernate ofrece el chequeo "
 "de versiones automático con el paradigma de diseño de <literal>Session</"
 "literal> larga o de instancias separadas."
 
 #. Tag: title
-#: transactions.xml:716
 #, no-c-format
 msgid "Extended session and automatic versioning"
-msgstr "Sesión larga y versionado automático"
+msgstr "Sesión extendida y versionado automático"
 
 #. Tag: para
-#: transactions.xml:718
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A single <literal>Session</literal> instance and its persistent instances "
 "that are used for the whole conversation are known as <emphasis>session-per-"
@@ -1501,17 +1296,17 @@
 "opportunity for the user to merge changes or to restart the business "
 "conversation with non-stale data."
 msgstr ""
-"Una sola instancia de <literal>Session</literal> y sus instancias "
-"persistentes son usadas para toda la transacción de aplicación. Hibernate "
-"chequea las versiones de instancia en el momento de limpieza (flush), "
-"lanzando una excepción si se detecta una modificación concurrente. Concierne "
-"al desarrollador capturar y manejar esta excepción (las opciones comunes son "
-"la oportunidad del usuario de fusionar los cambios, o recomenzar el proceso "
-"de negocio sin datos añejos)."
+"Una sóla instancia de <literal>Session</literal> y sus instancias "
+"persistentes se utilizan para toda la convervsación conocida como "
+"<emphasis>sesión-por-conversación</emphasis>. Hibernate chequea las "
+"versiones de instancia en el momento de vaciado, lanzando una excepción si "
+"se detecta una modificación concurrente. Le concierne al desarrollador "
+"capturar y manejar esta excepción. Las opciones comunes son la oportunidad "
+"del usuario de fusionar los cambios, o de recomenzar el proceso empresarial "
+"sin datos desactualizados."
 
 #. Tag: para
-#: transactions.xml:727
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>Session</literal> is disconnected from any underlying JDBC "
 "connection when waiting for user interaction. This approach is the most "
@@ -1520,31 +1315,15 @@
 "in every database transaction."
 msgstr ""
 "La <literal>Session</literal> se desconecta de cualquier conexión JDBC "
-"subyacente al esperar por una interacción del usuario. Este enfoque es el "
-"más eficiente en términos de acceso a base de datos. La aplicación no "
-"necesita tratar por sí misma con el chequeo de versiones, ni re-uniendo "
-"instancias separadas, ni tiene que recargar instancias en cadatransactions-"
-"demarcation-timeout transacción de base de datos."
+"subyacente a la espera de una interacción del usuario. Este enfoque es el "
+"más eficiente en términos de acceso a la base de datos. La aplicación no "
+"necesita por sí misma tratar con el chequeo de versiones, ni re-unir "
+"instancias separadas, ni tiene que recargar instancias en cada transacción "
+"de la base de datos."
 
-#. Tag: programlisting
-#: transactions.xml:735
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// foo is an instance loaded earlier by the old session\n"
-"Transaction t = session.beginTransaction(); // Obtain a new JDBC connection, "
-"start transaction\n"
-"\n"
-"foo.setProperty(\"bar\");\n"
-"\n"
-"session.flush();    // Only for last transaction in conversation\n"
-"t.commit();         // Also return JDBC connection\n"
-"session.close();    // Only for last transaction in conversation]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:736
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>foo</literal> object knows which <literal>Session</literal> it "
 "was loaded in. Beginning a new database transaction on an old session "
 "obtains a new connection and resumes the session. Committing a database "
@@ -1560,20 +1339,25 @@
 "will include the <literal>flush()</literal> operation, and then "
 "<literal>close()</literal> the session to end the conversation."
 msgstr ""
-"El objeto <literal>foo</literal> todavía conoce en qué <literal>Session</"
-"literal> fue cargado. <literal>Session.reconnect()</literal> obtiene una "
-"nueva conexión (o puedes proveer una) y reasume la sesión. El método "
-"<literal>Session.disconnect()</literal> desconectará la sesión de la "
-"conexión JDBC y la devolverá la conexión al pool (a menos que hayas provisto "
-"la conexión). Después de la reconexión, para forzar un chequeo de versión en "
-"datos que no estés actualizando, puedes llamar a <literal>Session.lock()</"
-"literal> con <literal>LockMode.READ</literal> sobre cualquier objeto que "
-"pudiese haber sido actualizado por otra transacción. No necesitas bloquear "
-"ningún dato que <emphasis>sí estés</emphasis> actualizando."
+"El objeto <literal>foo</literal> sabe en qué <literal>Session</literal> fue "
+"cargado. El dar inicio a una nueva base de datos en una sesión vieja obtiene "
+"una nueva conexión y reanuda la sesión. El guardar una transacción de la "
+"base de datos desconecta una sesión de la conexion JDBC y devuelve la "
+"conexión al pool. Después de la reconexión, para poder forzar una "
+"verificación de versión sobre datos que usted no está actalizando, puede "
+"llamar a <literal>Session.lock()</literal> con <literal>LockMode.READ</"
+"literal> en cualquier objeto que pueda haber sido actualizado por otra "
+"transacción. No necesita bloquear ningún dato que <emphasis>sí esté</"
+"emphasis> actualizando. Usualmente configuraría <literal>FlushMode.MANUAL</"
+"literal> en una <literal>Session</literal> extendida, de manera que de hecho "
+"sólamente se permite persistir el último ciclo de transacción de la base de "
+"datos de todas las modificaciones realizadas en esta conversación. Sólamente "
+"esta última transacción de la base de datos incluiría la operación "
+"<literal>flush()</literal> y luego cierra -<literal>close()</literal>- la "
+"sesión para dar fin a la conversación."
 
 #. Tag: para
-#: transactions.xml:751
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This pattern is problematic if the <literal>Session</literal> is too big to "
 "be stored during user think time (for example, an <literal>HttpSession</"
@@ -1583,36 +1367,35 @@
 "<literal>Session</literal> only for a single conversation as it will soon "
 "have stale data."
 msgstr ""
-"Si las llamadas explícitas a <literal>disconnect()</literal> y "
-"<literal>reconnect()</literal> son muy onerosas, puedes usar en cambio "
-"<literal>hibernate.connection.release_mode</literal>."
+"Este patrón es problemático si la <literal>Session</literal> es demasiado "
+"grande para almacenarla durante el tiempo para pensar del usuario, por "
+"ejemplo, una <literal>HttpSession</literal> se debe mantener tan pequeña "
+"como sea posible. Como la <literal>Session</literal> también lo es el caché "
+"de primer nivel (obligatorio) y comprende todos los objetos cargados, "
+"probablemente podemos utilizar esta estrategia sólamente para unos pocos "
+"ciclos de pedido/respuesta. Debe utilizar una <literal>Session</literal> "
+"sólamente para una conversación única ya que pronto también tendrá  datos "
+"añejos."
 
 #. Tag: title
-#: transactions.xml:762
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Nota"
 
 #. Tag: para
-#: transactions.xml:763
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Earlier versions of Hibernate required explicit disconnection and "
 "reconnection of a <literal>Session</literal>. These methods are deprecated, "
 "as beginning and ending a transaction has the same effect."
 msgstr ""
-"Este patrón es problemático si la <literal>Session</literal> es demasiado "
-"grande para ser almacenada durante el tiempo de pensar del usuario, por "
-"ejemplo, una <literal>HttpSession</literal> debe mantenerse tan pequeña como "
-"sea posible. Ya que la <literal>Session</literal> es también el caché "
-"(obligatorio) de primer nivel y contiene todos los objetos cargados, podemos "
-"probablemente cargar esta estrategia sólo para unos pocos ciclos petición/"
-"respuesta. Esto está de hecho recomendado, ya que la <literal>Session</"
-"literal> tendrá pronto también datos añejos."
+"Las versiones anteriores de Hibernate necesitaban desconexión explícita y "
+"reconexión de una <literal>Session</literal>. Estos métodos ya no se "
+"aprueban ya que tienen el mismo efecto que dar inicio o finalizar a una "
+"transacción."
 
 #. Tag: para
-#: transactions.xml:769
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Keep the disconnected <literal>Session</literal> close to the persistence "
 "layer. Use an EJB stateful session bean to hold the <literal>Session</"
@@ -1620,15 +1403,14 @@
 "or even serialize it to a separate tier, to store it in the "
 "<literal>HttpSession</literal>."
 msgstr ""
-"Nota también que debes mantener la <literal>Session</literal> desconectada "
-"próxima a la capa de persistencia. En otras palabras, usa una sesión de EJB "
-"con estado para tener la <literal>Session</literal> y no transferirla a la "
-"capa web para almacenarla en la <literal>HttpSession</literal> (ni incluso "
-"serializarla a una capa separada)."
+"Mantenga la <literal>Session</literal> desconectada cerca a la capa de "
+"persistencia. Use un bean de sesión EJB con estado para mantener la "
+"<literal>Session</literal> en un entorno de tres capas . No la transfiera a "
+"la capa web ni la serialice en una capa separada para almacenarla en la "
+"<literal>HttpSession</literal>."
 
 #. Tag: para
-#: transactions.xml:777
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The extended session pattern, or <emphasis>session-per-conversation</"
 "emphasis>, is more difficult to implement with automatic current session "
@@ -1636,20 +1418,18 @@
 "<literal>CurrentSessionContext</literal> for this. See the Hibernate Wiki "
 "for examples."
 msgstr ""
-"UNTRANSLATED!!! The extended session pattern, or <emphasis>session-per-"
-"conversation</emphasis>, is more difficult to implement with automatic "
-"current session context management. You need to supply your own "
-"implementation of the <literal>CurrentSessionContext</literal> for this, see "
-"the Hibernate Wiki for examples."
+"El patrón de sesión extendido, o <emphasis>sesión-por-conversación</"
+"emphasis>, es más dificil de implementar con la administración de contexto "
+"de sesión actual. Necesita proporcionar su propia implementación de la "
+"<literal>CurrentSessionContext</literal> para esto, vea el Wiki de Hibernate "
+"para obtener más ejemplos."
 
 #. Tag: title
-#: transactions.xml:787
 #, no-c-format
 msgid "Detached objects and automatic versioning"
 msgstr "Objetos separados y versionado automático"
 
 #. Tag: para
-#: transactions.xml:789
 #, no-c-format
 msgid ""
 "Each interaction with the persistent store occurs in a new <literal>Session</"
@@ -1660,75 +1440,58 @@
 "<literal>Session.saveOrUpdate()</literal>, or <literal>Session.merge()</"
 "literal>."
 msgstr ""
-"Cada interacción con el almacén persistente ocurre en una nueva "
+"Cada interacción con el almacenamiento persistente ocurre en una nueva "
 "<literal>Session</literal>. Sin embargo, las mismas instancias persistentes "
-"son reusadas para cada interacción con la base de datos. La aplicación "
-"manipula el estado de las instancias separadas originalmente cargadas en "
+"son reutilizadas para cada interacción con la base de datos. La aplicación "
+"manipula el estado de las instancias separadas cargadas originalmente en "
 "otra <literal>Session</literal> y luego las readjunta usando "
 "<literal>Session.update()</literal>, <literal>Session.saveOrUpdate()</"
 "literal>, o <literal>Session.merge()</literal>."
 
-#. Tag: programlisting
-#: transactions.xml:797
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// foo is an instance loaded by a previous Session\n"
-"foo.setProperty(\"bar\");\n"
-"session = factory.openSession();\n"
-"Transaction t = session.beginTransaction();\n"
-"session.saveOrUpdate(foo); // Use merge() if \"foo\" might have been loaded "
-"already\n"
-"t.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:799
-#, fuzzy, no-c-format
-msgid ""
 "Again, Hibernate will check instance versions during flush, throwing an "
 "exception if conflicting updates occurred."
 msgstr ""
-"De nuevo, Hibernate chequeará las versiones de instancia durante la limpieza "
-"(flush), lanzando una excepción si ocurrieron actualizaciones en conflicto."
+"De nuevo, Hibernate chequeará las versiones de la instancia durante el "
+"vaciado, lanzando una excepción si tuvieron lugar conflictos en las "
+"actualizaciones."
 
 #. Tag: para
-#: transactions.xml:804
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also call <literal>lock()</literal> instead of <literal>update()</"
 "literal>, and use <literal>LockMode.READ</literal> (performing a version "
 "check and bypassing all caches) if you are sure that the object has not been "
 "modified."
 msgstr ""
-"Puedes también llamar a <literal>lock()</literal> en vez de <literal>update()"
-"</literal> y usar <literal>LockMode.READ</literal> (realizando un chequeo de "
-"versión, puenteando todos los cachés) si estás seguro que el objeto no ha "
-"sido modificado."
+"También puede llamar a <literal>lock()</literal> en lugar de <literal>update"
+"()</literal> y utilizar <literal>LockMode.READ</literal> (realizando un "
+"chequeo de versión, evitando todos los cachés) si está seguro de que el "
+"objeto no ha sido modificado."
 
 #. Tag: title
-#: transactions.xml:813
 #, no-c-format
 msgid "Customizing automatic versioning"
-msgstr "Personalizando el versionado automático"
+msgstr "Personalización del versionado automático"
 
 #. Tag: para
-#: transactions.xml:815
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can disable Hibernate's automatic version increment for particular "
 "properties and collections by setting the <literal>optimistic-lock</literal> "
 "mapping attribute to <literal>false</literal>. Hibernate will then no longer "
 "increment versions if the property is dirty."
 msgstr ""
-"Puedes deshabilitar el incremento de versión automático de Hibernate para "
-"propiedades en particular y colecciones estableciendo el atributo de mapeo "
-"<literal>optimistic-lock</literal> a <literal>false</literal>. Hibernate "
-"entonces no incrementará ya más las versiones si la propiedad está sucia."
+"Puede deshabilitar el incremento de la versión automática de Hibernate para "
+"ciertas propiedades y colecciones en particular estableciendo el atributo de "
+"mapeo <literal>optimistic-lock</literal> como <literal>false</literal>. "
+"Hibernate entonces ya no incrementará más las versiones si la propiedad se "
+"encuentra desactualizada."
 
 #. Tag: para
-#: transactions.xml:822
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Legacy database schemas are often static and cannot be modified. Or, other "
 "applications might access the same database and will not know how to handle "
@@ -1741,36 +1504,34 @@
 "long <literal>Session</literal> and not session-per-request-with-detached-"
 "objects)."
 msgstr ""
-"Los esquemas de base de datos heredados son frecuentemente estáticos y no "
-"pueden ser modificados. U otras aplicaciones podrían también acceder la "
-"misma base de datos y no saber cómo manejar los números de versión ni "
-"incluso timestamps. En ambos casos, el versionado no puede confiarse a una "
+"Los esquemas heredados de la base de datos con frecuencia son estáticos y no "
+"pueden ser modificados. Inclusive otras aplicaciones podrían también acceder "
+"la misma base de datos y no saber cómo manejar los números de versión ni los "
+"sellos de fecha. En ambos casos, el versionado no puede confiarse a una "
 "columna en particular en una tabla. Para forzar un chequeo de versiones sin "
-"un mapeo de propiedad de versión o timestamp, con una comparación del estado "
-"de todos los campos en una fila, activa <literal>optimistic-lock=\"all\"</"
-"literal> en el mapeo de <literal>&lt;class&gt;</literal>. Nota que esto "
-"conceptualmente funciona solamente si Hibernate puede comparar el estado "
-"viejo y nuevo, es decir, si usas una sola <literal>Session</literal> larga y "
-"no sesión-por-petición-con-instancias-separadas."
+"un mapeo de propiedad de versión o sello de fecha, con una comparación del "
+"estado de todos los campos en una fila, active <literal>optimistic-lock=\"all"
+"\"</literal> en el mapeo de <literal>&lt;class&gt;</literal>. Esto funciona "
+"conceptualmente sólamente si Hibernate puede comparar el estado viejo y el "
+"nuevo, es decir, si usa una sóla <literal>Session</literal> larga y no "
+"sesión-por-petición-con-instancias-separadas."
 
 #. Tag: para
-#: transactions.xml:834
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Concurrent modification can be permitted in instances where the changes that "
 "have been made do not overlap. If you set <literal>optimistic-lock=\"dirty"
 "\"</literal> when mapping the <literal>&lt;class&gt;</literal>, Hibernate "
 "will only compare dirty fields during flush."
 msgstr ""
-"A veces las modificaciones concurrentes pueden permitirse, en cuanto los "
-"cambios que hayan sido hechos no se traslapen. Si estableces "
+"Las modificaciones simultáneas pueden permitirse en instancias en tanto los "
+"cambios que se hayan realizado no se superpongan. Si establece "
 "<literal>optimistic-lock=\"dirty\"</literal> al mapear la <literal>&lt;"
-"class&gt;</literal>, Hibernate sólo comparará los campos sucios durante la "
-"limpieza."
+"class&gt;</literal>, Hibernate sólo comparará los campos desactualizados "
+"durante el vaciado."
 
 #. Tag: para
-#: transactions.xml:840
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In both cases, with dedicated version/timestamp columns or with a full/dirty "
 "field comparison, Hibernate uses a single <literal>UPDATE</literal> "
@@ -1785,29 +1546,28 @@
 "to <literal>SELECT</literal> the instance to ensure that changes did occur "
 "before updating the row."
 msgstr ""
-"En ambos casos, con columnas de versión/timestamp dedicadas o con "
-"comparación de campos completa/sucios, Hibernate usa una sola sentencia "
-"<literal>UPDATE</literal> (con una cláusula <literal>WHERE</literal> "
-"apropiada) por entidad para ejecutar el chequeo de versiones y actualizar la "
-"información. Si usas persistencia transitiva para la re-unión en cascada de "
-"entidades asociadas, Hibernate podría ejecutar actualizaciones innecesarias. "
-"Esto usualmente no es un problema, pero podrían ejecutarse disparadores "
-"(triggers) <emphasis>on update</emphasis> en la base de datos incluso cuando "
-"no se haya hecho ningún cambio a las instancias separadas. Puedes "
-"personalizar este comportamiento estableciendo <literal>select-before-update="
-"\"true\"</literal> en el mapeo de <literal>&lt;class&gt;</literal>, forzando "
-"a Hibernate a <literal>SELECT</literal> la instancia para asegurar que las "
-"actualizaciones realmente ocurran, antes de actualizar la fila."
+"En ambos casos, con columnas de versión/sello de fecha dedicadas o con "
+"comparación de campos completos/desactualizados, Hibernate utiliza una sóla "
+"declaración <literal>UPDATE</literal> (con una cláusula <literal>WHERE</"
+"literal> apropiada) por entidad para ejecutar el chequeo de versiones y "
+"actualizar la información. Si utiliza una persistencia transitiva para la re-"
+"unión en cascada de entidades asociadas, Hibernate podría ejecutar "
+"actualizaciones innecesarias. Esto usualmente no es problema, pero podrían "
+"ejecutarse disparadores (triggers) <emphasis>enactualizazción</emphasis> en "
+"la base de datos incluso cuando no se haya hecho ningún cambio a las "
+"instancias separadas. Puede personalizar este comportamiento estableciendo "
+"<literal>select-before-update=\"true\"</literal> en el mapeo de <literal>&lt;"
+"class&gt;</literal>, forzando a Hibernate a <literal>SELECT</literal> la "
+"instancia para asegurar que las actualizaciones realmente ocurran, antes de "
+"actualizar la fila."
 
 #. Tag: title
-#: transactions.xml:858
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Pessimistic locking"
-msgstr "Bloqueo pesimista"
+msgstr "Bloqueo pesimista "
 
 #. Tag: para
-#: transactions.xml:860
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is not intended that users spend much time worrying about locking "
 "strategies. It is usually enough to specify an isolation level for the JDBC "
@@ -1815,36 +1575,33 @@
 "advanced users may wish to obtain exclusive pessimistic locks or re-obtain "
 "locks at the start of a new transaction."
 msgstr ""
-"No se pretende que los usuarios gasten mucho tiempo preocupándose de las "
+"No se pretende que los usuarios tomen mucho tiempo preocupándose de las "
 "estrategias de bloqueo. Usualmente es suficiente con especificar un nivel de "
 "aislamiento para las conexiones JDBC y entonces simplemente dejar que la "
-"base de datos haga todo el trabajo. Sin embargo, los usuarios avanzados "
-"pueden a veces obtener bloqueos exclusivos pesimistas, o reobtener bloqueos "
-"al comienzo de una nueva transacción."
+"base de datos haga todo el trabajo. Sin embargo, los usuarios avanzados a "
+"veces pueden obtener bloqueos exclusivos pesimistas, o reobtener bloqueos al "
+"comienzo de una nueva transacción."
 
 #. Tag: para
-#: transactions.xml:867
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will always use the locking mechanism of the database; it never "
 "lock objects in memory."
 msgstr ""
-"¡Hibernate siempre usará el mecanismo de bloqueo de la base de datos, nunca "
-"bloqueo de objetos en memoria!"
+"Hibernate siempre usará el mecanismo de bloqueo de la base de datos, nunca "
+"el bloqueo de objetos en memoria."
 
 #. Tag: para
-#: transactions.xml:872
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>LockMode</literal> class defines the different lock levels that "
 "can be acquired by Hibernate. A lock is obtained by the following mechanisms:"
 msgstr ""
 "La clase <literal>LockMode</literal> define los diferentes niveles de "
-"bloqueo que pueden ser adquiridos por Hibernate. Un bloqueo se obtiene por "
-"los siguientes mecanismos:"
+"bloqueo que Hibernate puede adquirir. Un bloqueo se obtiene por medio de los "
+"siguientes mecanismos: "
 
 #. Tag: para
-#: transactions.xml:879
 #, no-c-format
 msgid ""
 "<literal>LockMode.WRITE</literal> is acquired automatically when Hibernate "
@@ -1854,43 +1611,39 @@
 "Hibernate actualiza o inserta una fila."
 
 #. Tag: para
-#: transactions.xml:885
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockMode.UPGRADE</literal> can be acquired upon explicit user "
 "request using <literal>SELECT ... FOR UPDATE</literal> on databases which "
 "support that syntax."
 msgstr ""
-"<literal>LockMode.UPGRADE</literal> puede ser adquirido bajo petición "
+"<literal>LockMode.UPGRADE</literal> se puede ser adquirir bajo petición "
 "explícita del usuario usando <literal>SELECT ... FOR UPDATE</literal> en "
-"base de datos que soporten esa sintáxis."
+"bases de datos que soporten esa sintáxis."
 
 #. Tag: para
-#: transactions.xml:891
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockMode.UPGRADE_NOWAIT</literal> can be acquired upon explicit "
 "user request using a <literal>SELECT ... FOR UPDATE NOWAIT</literal> under "
 "Oracle."
 msgstr ""
-"<literal>LockMode.UPGRADE_NOWAIT</literal> puede ser adquirido bajo petición "
+"<literal>LockMode.UPGRADE_NOWAIT</literal> se puede adquirir bajo petición "
 "explícita del usuario usando un <literal>SELECT ... FOR UPDATE NOWAIT</"
 "literal> bajo Oracle."
 
 #. Tag: para
-#: transactions.xml:897
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockMode.READ</literal> is acquired automatically when Hibernate "
 "reads data under Repeatable Read or Serializable isolation level. It can be "
 "re-acquired by explicit user request."
 msgstr ""
-"<literal>LockMode.READ</literal> es adquirido automáticamente cuando "
-"Hibernate lee datos bajo los niveles de aislamiento Repeatable Read o "
-"Serializable. Puede ser readquirido por pedido explícito del usuario."
+"<literal>LockMode.READ</literal> se adquiere automáticamente cuando "
+"Hibernate lee los datos bajo los niveles de aislamiento de lectura repetible "
+"o serializable. Se puede readquirir por pedido explícito del usuario."
 
 #. Tag: para
-#: transactions.xml:904
 #, no-c-format
 msgid ""
 "<literal>LockMode.NONE</literal> represents the absence of a lock. All "
@@ -1901,12 +1654,11 @@
 msgstr ""
 "<literal>LockMode.NONE</literal> representa la ausencia de un bloqueo. Todos "
 "los objetos se pasan a este modo de bloqueo al final de una "
-"<literal>Transaction</literal>. Los objetos asociados con una sesión vía una "
-"llamada a <literal>update()</literal> o <literal>saveOrUpdate()</literal> "
-"también comienzan en este modo de bloqueo."
+"<literal>Transaction</literal>. Los objetos asociados con una sesión por "
+"medio de una llamada a <literal>update()</literal> o <literal>saveOrUpdate()"
+"</literal> también comienzan en este modo de bloqueo."
 
 #. Tag: para
-#: transactions.xml:913
 #, no-c-format
 msgid ""
 "The \"explicit user request\" is expressed in one of the following ways:"
@@ -1915,7 +1667,6 @@
 "formas:"
 
 #. Tag: para
-#: transactions.xml:919
 #, no-c-format
 msgid ""
 "A call to <literal>Session.load()</literal>, specifying a <literal>LockMode</"
@@ -1925,19 +1676,16 @@
 "<literal>LockMode</literal>."
 
 #. Tag: para
-#: transactions.xml:924
 #, no-c-format
 msgid "A call to <literal>Session.lock()</literal>."
 msgstr "Una llamada a <literal>Session.lock()</literal>."
 
 #. Tag: para
-#: transactions.xml:929
 #, no-c-format
 msgid "A call to <literal>Query.setLockMode()</literal>."
 msgstr "Una llamada a <literal>Query.setLockMode()</literal>."
 
 #. Tag: para
-#: transactions.xml:935
 #, no-c-format
 msgid ""
 "If <literal>Session.load()</literal> is called with <literal>UPGRADE</"
@@ -1950,14 +1698,13 @@
 msgstr ""
 "Si se llama a <literal>Session.load()</literal> con <literal>UPGRADE</"
 "literal> o <literal>UPGRADE_NOWAIT</literal>, y el objeto pedido no ha sido "
-"aún cargado por la sesión, el objeto es cargado usando <literal>SELECT ... "
-"FOR UPDATE</literal>. Si se llama a <literal>load()</literal> para un objeto "
-"que ya esté cargado con un bloqueo menos restrictivo que el pedido, "
-"Hibernate llama a <literal>lock()</literal> para ese objeto."
+"cargado todavía por la sesión, el objeto es cargado usando "
+"<literal>SELECT ... FOR UPDATE</literal>. Si se llama a <literal>load()</"
+"literal> para un objeto que ya esté cargado con un bloqueo menos restrictivo "
+"que el pedido, Hibernate llama a <literal>lock()</literal> para ese objeto."
 
 #. Tag: para
-#: transactions.xml:944
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Session.lock()</literal> performs a version number check if the "
 "specified lock mode is <literal>READ</literal>, <literal>UPGRADE</literal> "
@@ -1967,30 +1714,27 @@
 msgstr ""
 "<literal>Session.lock()</literal> realiza un chequeo de número de versión si "
 "el modo de bloqueo especificado es <literal>READ</literal>, "
-"<literal>UPGRADE</literal> o <literal>UPGRADE_NOWAIT</literal>. (En el caso "
+"<literal>UPGRADE</literal> o <literal>UPGRADE_NOWAIT</literal>. En el caso "
 "de <literal>UPGRADE</literal> o <literal>UPGRADE_NOWAIT</literal>, se usa "
-"<literal>SELECT ... FOR UPDATE</literal>.)"
+"<literal>SELECT ... FOR UPDATE</literal>."
 
 #. Tag: para
-#: transactions.xml:951
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the requested lock mode is not supported by the database, Hibernate uses "
 "an appropriate alternate mode instead of throwing an exception. This ensures "
 "that applications are portable."
 msgstr ""
-"Si la base de datos no soporta el modo de bloqueo solicitado, Hibernate "
-"usará un modo alternativo apropiado (en vez de lanzar una excepción). Esto "
-"asegura que las aplicaciones serán portables."
+"Si la base de datos no soporta el modo de bloqueo solicitado, Hibernate usa "
+"un modo opcional apropiado en lugar de lanzar una excepción. Esto asegura "
+"que las aplicaciones serán portátiles."
 
 #. Tag: title
-#: transactions.xml:960
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Connection release modes"
-msgstr "translator-credits"
+msgstr "Modos de liberación de la conexión"
 
 #. Tag: para
-#: transactions.xml:962
 #, no-c-format
 msgid ""
 "One of the legacies of Hibernate 2.x JDBC connection management meant that a "
@@ -2004,26 +1748,39 @@
 "by the enumerated values of <literal>org.hibernate.ConnectionReleaseMode</"
 "literal>:"
 msgstr ""
+"La herencia (2x) de Hibernate en relación con la administración de la "
+"conexion JDBC fue que una <literal>Session</literal> obtendría una conexión "
+"cuando se necesitara por primera vez y luego la mantendría hasta que se "
+"cerrara la sesión. Hibernate 3.x introdujo la noción de modos de liberación "
+"de conexión para decirle a la sesión como manejar sus conexiones JDBC. La "
+"siguiente discusión sólamente es pertinente para las conexiones provistas "
+"por medio de un <literal>ConnectionProvider</literal> configurado. Las "
+"conexiones provistas por el usuario no se discuten aquí. Los diferentes "
+"modos de liberación se identifican por los valores numerados de <literal>org."
+"hibernate.ConnectionReleaseMode</literal>:"
 
 #. Tag: para
-#: transactions.xml:976
 #, no-c-format
 msgid ""
 "<literal>ON_CLOSE</literal>: is the legacy behavior described above. The "
 "Hibernate session obtains a connection when it first needs to perform some "
 "JDBC access and maintains that connection until the session is closed."
 msgstr ""
+"<literal>ON_CLOSE</literal>: es el comportamiento heredado descrito "
+"anteriormente. La sesión de Hibernate obtiene una conexión cuando necesita "
+"acceder a JDBC la primera vez y mantiene esa conexión hasta que se cierra la "
+"sesión."
 
 #. Tag: para
-#: transactions.xml:983
 #, no-c-format
 msgid ""
 "<literal>AFTER_TRANSACTION</literal>: releases connections after a "
 "<literal>org.hibernate.Transaction</literal> has been completed."
 msgstr ""
+"<literal>AFTER_TRANSACTION</literal>: libera las conecciones después de que "
+"se ha completado una <literal>org.hibernate.Transaction</literal>."
 
 #. Tag: para
-#: transactions.xml:989
 #, no-c-format
 msgid ""
 "<literal>AFTER_STATEMENT</literal> (also referred to as aggressive release): "
@@ -2032,18 +1789,25 @@
 "the given session. Currently the only situation where this occurs is through "
 "the use of <literal>org.hibernate.ScrollableResults</literal>."
 msgstr ""
+"<literal>AFTER_STATEMENT</literal> (también se conoce como una liberación "
+"agresiva): libera conexiones después de cada ejecución de una declaración. "
+"Se salta esta liberación agresiva si la declaración deja abiertos recursos "
+"asociados con la sesión dada. Actualmente la única situación donde ocurre "
+"esto es por medio del uso de <literal>org.hibernate.ScrollableResults</"
+"literal>."
 
 #. Tag: para
-#: transactions.xml:999
 #, no-c-format
 msgid ""
 "The configuration parameter <literal>hibernate.connection.release_mode</"
 "literal> is used to specify which release mode to use. The possible values "
 "are as follows:"
 msgstr ""
+"El parámetro de configuración <literal>hibernate.connection.release_mode</"
+"literal> se utiliza para especificar el modo de liberación a utilizar. Los "
+"valores posibles son los siguientes:"
 
 #. Tag: para
-#: transactions.xml:1006
 #, no-c-format
 msgid ""
 "<literal>auto</literal> (the default): this choice delegates to the release "
@@ -2054,17 +1818,26 @@
 "default behavior as failures due to the value of this setting tend to "
 "indicate bugs and/or invalid assumptions in user code."
 msgstr ""
+"<literal>auto</literal> (predeterminado): esta opción delega al modo de "
+"liberación devuelto por el método <literal>org.hibernate.transaction."
+"TransactionFactory.getDefaultReleaseMode()</literal>. Para "
+"JTATransactionFactory, esto devuelve ConnectionReleaseMode.AFTER_STATEMENT; "
+"para JDBCTransactionFactory, esto devuelve ConnectionReleaseMode."
+"AFTER_TRANSACTION. No cambie este comportamiento predeterminado ya que las "
+"fallas debido a este valor de esta configuración tienden a indicar errores y/"
+"o suposiciones en el código del usuario."
 
 #. Tag: para
-#: transactions.xml:1016
 #, no-c-format
 msgid ""
 "<literal>on_close</literal>: uses ConnectionReleaseMode.ON_CLOSE. This "
 "setting is left for backwards compatibility, but its use is discouraged."
 msgstr ""
+"<literal>on_close</literal>: usa ConnectionReleaseMode.ON_CLOSE. Esta "
+"configuración se deja para la compatibilidad con versiones anteriores, pero "
+"no se recomienda para nada su utilización."
 
 #. Tag: para
-#: transactions.xml:1022
 #, no-c-format
 msgid ""
 "<literal>after_transaction</literal>: uses ConnectionReleaseMode."
@@ -2073,9 +1846,13 @@
 "considered to be in auto-commit mode, connections will be released as if the "
 "release mode were AFTER_STATEMENT."
 msgstr ""
+"<literal>after_transaction</literal>: utiliza ConnectionReleaseMode."
+"AFTER_TRANSACTION. Esta configuración no se debe utilizar en entornos JTA. "
+"También note que con ConnectionReleaseMode.AFTER_TRANSACTION, si se "
+"considera que una sesión se encuentra en modo auto-commit, las conexiones "
+"serán liberada como si el modo de liberación fuese AFTER_STATEMENT."
 
 #. Tag: para
-#: transactions.xml:1030
 #, no-c-format
 msgid ""
 "<literal>after_statement</literal>: uses ConnectionReleaseMode."
@@ -2088,3 +1865,12 @@
 "getConnection()</literal> or in auto-commit environments where it does not "
 "matter if we re-establish the same connection."
 msgstr ""
+"<literal>after_statement</literal>: usa ConnectionReleaseMode."
+"AFTER_STATEMENT. Además se consulta la <literal>ConnectionProvider</literal> "
+"configurada para ver si soporta esta característica "
+"<literal>supportsAggressiveRelease()</literal>. Si no, el modo de liberación "
+"se vuelve a establecer como ConnectionReleaseMode.AFTER_TRANSACTION. Esta "
+"configuración sólamente es segura en entornos en donde podemos re-adquirir "
+"la misma conexión JDBC subyacente cada vez que llamamos a "
+"<literal>ConnectionProvider.getConnection()</literal> o en entornos auto-"
+"commit, en donde no importa si recibimos la misma conexión."

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/tutorial.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/tutorial.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/tutorial.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,20 +1,34 @@
-#, fuzzy
+# translation of tutorial.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: tutorial\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-23 18:41+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-01-07 10:05+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: tutorial.xml:31
 #, no-c-format
 msgid "Tutorial"
-msgstr ""
+msgstr "Tutorial"
 
 #. Tag: para
-#: tutorial.xml:33
 #, no-c-format
 msgid ""
 "Intended for new users, this chapter provides an step-by-step introduction "
@@ -23,43 +37,49 @@
 "Gloegl. All code is contained in the <filename>tutorials/web</filename> "
 "directory of the project source."
 msgstr ""
+"Dirigido a los nuevos usuarios, este capítulo brinda una introducción a "
+"Hibernate paso por paso, empezando con una aplicación simple usando una base "
+"de datos en memoria. Este tutorial se basa en un tutorial anterior que "
+"Michael Gloegl desarrolló. Todo el código se encuentra en el directorio "
+"<filename>tutorials/web</filename> de la fuente del proyecto. "
 
 #. Tag: para
-#: tutorial.xml:42
 #, no-c-format
 msgid ""
 "This tutorial expects the user have knowledge of both Java and SQL. If you "
 "have a limited knowledge of JAVA or SQL, it is advised that you start with a "
 "good introduction to that technology prior to attempting to learn Hibernate."
 msgstr ""
+"Este tutorial se basa en que el usuario tenga conocimiento de Java y SQL. Si "
+"tiene un conocimiento muy limitado de JAVA o SQL, le aconsejamos que empiece "
+"con una buena introducción a esta tecnología antes de tratar de aprender "
+"sobre Hibernate."
 
 #. Tag: para
-#: tutorial.xml:51
 #, no-c-format
 msgid ""
 "The distribution contains another example application under the "
 "<filename>tutorial/eg</filename> project source directory."
 msgstr ""
+"La distribución contiene otra aplicación de ejemplo bajo el directorio "
+"fuente del proyecto <filename>tutorial/eg</filename>."
 
 #. Tag: title
-#: tutorial.xml:59
 #, no-c-format
 msgid "Part 1 - The first Hibernate Application"
-msgstr "Parte 1 - La primera Aplicaci&#x00f3;n Hibernate"
+msgstr "Parte 1 - La primera aplicación Hibernate"
 
 #. Tag: para
-#: tutorial.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For this example, we will set up a small database application that can store "
 "events we want to attend and information about the host(s) of these events."
 msgstr ""
-"Asumamos que necesitamos una aplicaci&#x00f3;n peque&#x00f1;a de base de "
-"datos que pueda almacenar eventos que queremos atender, e informaci&#x00f3;n "
-"acerca de los hostales de estos eventos."
+"Para este ejemplo, vamos a configurar una aplicación base de datos pequeña "
+"que pueda almacenar eventos a los que queremos asistir e información sobre "
+"los anfitriones de estos eventos."
 
 #. Tag: para
-#: tutorial.xml:67
 #, no-c-format
 msgid ""
 "Although you can use whatever database you feel comfortable using, we will "
@@ -67,15 +87,17 @@
 "database) to avoid describing installation/setup of any particular database "
 "servers."
 msgstr ""
+"Aunque puede utilizar cualquier base de datos con la que se sienta bien, "
+"vamos a usar <ulink url=\"http://hsqldb.org/\">HSQLDB</ulink> (una base de "
+"datos Java en-memoria) para evitar describir la instalación/configuración de "
+"cualquier servidor de base de datos en particular."
 
 #. Tag: title
-#: tutorial.xml:76
 #, no-c-format
 msgid "Setup"
-msgstr ""
+msgstr "Configuración"
 
 #. Tag: para
-#: tutorial.xml:78
 #, no-c-format
 msgid ""
 "The first thing we need to do is to set up the development environment. We "
@@ -87,72 +109,30 @@
 "making use of <filename>src/main/java</filename>, <filename>src/main/"
 "resources</filename> and <filename>src/main/webapp</filename> directories."
 msgstr ""
+"Lo primero que tenemos que hacer es configurar el entorno de desarrollo. "
+"Vamos a utilizar el \"diseño estándar\" apoyado por muchas herramientas de "
+"construcción tal como <ulink url=\"http://maven.org\">Maven</ulink>. Maven, "
+"en particular, tiene un buen recurso que describe este <ulink url=\"http://"
+"maven.apache.org/guides/introduction/introduction-to-the-standard-directory-"
+"layout.html\">diseño</ulink>. Como este tutorial va a ser una aplicación "
+"web, vamos a crear y a utilizar los directorios <filename>src/main/java</"
+"filename>, <filename>src/main/resources</filename> y <filename>src/main/"
+"webapp</filename>."
 
 #. Tag: para
-#: tutorial.xml:88
 #, no-c-format
 msgid ""
 "We will be using Maven in this tutorial, taking advantage of its transitive "
 "dependency management capabilities as well as the ability of many IDEs to "
 "automatically set up a project for us based on the maven descriptor."
 msgstr ""
+"Vamos a usar Maven en este tutorial, sacando ventaja de sus funcionalidades "
+"de administración de dependencias transitivas así como la habilidad de "
+"muchos IDEs para configurar automáticamente un proyecto para nosotros con "
+"base en el descriptor maven."
 
-#. Tag: programlisting
-#: tutorial.xml:94
-#, no-c-format
-msgid ""
-"<![CDATA[<project xmlns=\"http://maven.apache.org/POM/4.0.0\"\n"
-"         xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
-"         xsi:schemaLocation=\"http://maven.apache.org/POM/4.0.0 http://maven."
-"apache.org/xsd/maven-4.0.0.xsd\">\n"
-"\n"
-"    <modelVersion>4.0.0</modelVersion>\n"
-"\n"
-"    <groupId>org.hibernate.tutorials</groupId>\n"
-"    <artifactId>hibernate-tutorial</artifactId>\n"
-"    <version>1.0.0-SNAPSHOT</version>\n"
-"    <name>First Hibernate Tutorial</name>\n"
-"\n"
-"    <build>\n"
-"         <!-- we dont want the version to be part of the generated war file "
-"name -->\n"
-"         <finalName>${artifactId}</finalName>\n"
-"    </build>\n"
-"\n"
-"    <dependencies>\n"
-"        <dependency>\n"
-"            <groupId>org.hibernate</groupId>\n"
-"            <artifactId>hibernate-core</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Because this is a web app, we also have a dependency on the "
-"servlet api. -->\n"
-"        <dependency>\n"
-"            <groupId>javax.servlet</groupId>\n"
-"            <artifactId>servlet-api</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Hibernate uses slf4j for logging, for our purposes here use the "
-"simple backend -->\n"
-"        <dependency>\n"
-"            <groupId>org.slf4j</groupId>\n"
-"            <artifactId>slf4j-simple</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Hibernate gives you a choice of bytecode providers between "
-"cglib and javassist -->\n"
-"        <dependency>\n"
-"            <groupId>javassist</groupId>\n"
-"            <artifactId>javassist</artifactId>\n"
-"        </dependency>\n"
-"    </dependencies>\n"
-"\n"
-"</project>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:97
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "It is not a requirement to use Maven. If you wish to use something else to "
 "build this tutoial (such as Ant), the layout will remain the same. The only "
@@ -168,109 +148,45 @@
 "javassist</filename> directory; additionally you will need both the servlet-"
 "api jar and one of the slf4j logging backends."
 msgstr ""
+"El usar Maven no es un requerimiento. Si desea utilizar otra tecnologia para "
+"construir este tutorial (tal como Ant), el diseño sigue siendo el mismo. El "
+"único cambio es que necesitará dar cuenta manualmente por todas las "
+"dependencias que se necesitan. Si usa <ulink url=\"http://ant.apache.org/ivy/"
+"\">Ivy</ulink> para brindar administración de dependencias transitivas "
+"todavía utilizaría las dependencias que mencionamos anteriormente. De otra "
+"manera, necesitará encontrar todas las dependencias, explícitas y "
+"transitivas y agregarlas a la ruta de clase del proyecto. Si trabaja desde "
+"el paquete de distribución Hibernate, esto significaría que "
+"<filename>hibernate3.jar</filename>, todos los artefactos en el directorio "
+"<filename>lib/required</filename> y todos los archivos del directorio "
+"<filename>lib/bytecode/cglib</filename> o <filename>lib/bytecode/javassist</"
+"filename>; además necesitará el servlet-api jar y uno de los backends de "
+"registro slf4j."
 
 #. Tag: para
-#: tutorial.xml:114
 #, no-c-format
 msgid ""
 "Save this file as <filename>pom.xml</filename> in the project root directory."
 msgstr ""
+"Guarde este archivo como <filename>pom.xml</filename> en el directorio raíz "
+"del proyecto."
 
 #. Tag: title
-#: tutorial.xml:121
 #, no-c-format
 msgid "The first class"
 msgstr "La primera clase"
 
 #. Tag: para
-#: tutorial.xml:123
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next, we create a class that represents the event we want to store in the "
 "database; it is a simple JavaBean class with some properties:"
 msgstr ""
-"Por siguiente, creamos una clase que represente el evento que queremos "
-"almacenar en base de datos."
+"Luego creamos una clase que representa el evento que queremos almacenar en "
+"la base de datos, es una clase JavaBean simple con algunas propiedades:"
 
-#. Tag: programlisting
-#: tutorial.xml:128
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.domain;\n"
-"\n"
-"import java.util.Date;\n"
-"\n"
-"public class Event {\n"
-"    private Long id;\n"
-"\n"
-"    private String title;\n"
-"    private Date date;\n"
-"\n"
-"    public Event() {}\n"
-"\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"\n"
-"    private void setId(Long id) {\n"
-"        this.id = id;\n"
-"    }\n"
-"\n"
-"    public Date getDate() {\n"
-"        return date;\n"
-"    }\n"
-"\n"
-"    public void setDate(Date date) {\n"
-"        this.date = date;\n"
-"    }\n"
-"\n"
-"    public String getTitle() {\n"
-"        return title;\n"
-"    }\n"
-"\n"
-"    public void setTitle(String title) {\n"
-"        this.title = title;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-"<![CDATA[import java.util.Date;\n"
-"\n"
-"public class Event {\n"
-"    private Long id;\n"
-"\n"
-"    private String title;\n"
-"    private Date date;\n"
-"\n"
-"    Event() {}\n"
-"\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"\n"
-"    private void setId(Long id) {\n"
-"        this.id = id;\n"
-"    }\n"
-"\n"
-"    public Date getDate() {\n"
-"        return date;\n"
-"    }\n"
-"\n"
-"    public void setDate(Date date) {\n"
-"        this.date = date;\n"
-"    }\n"
-"\n"
-"    public String getTitle() {\n"
-"        return title;\n"
-"    }\n"
-"\n"
-"    public void setTitle(String title) {\n"
-"        this.title = title;\n"
-"    }\n"
-"}]]>"
-
 #. Tag: para
-#: tutorial.xml:130
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This class uses standard JavaBean naming conventions for property getter and "
 "setter methods, as well as private visibility for the fields. Although this "
@@ -278,16 +194,14 @@
 "fields directly, the benefit of accessor methods is robustness for "
 "refactoring."
 msgstr ""
-"Puedes ver que esta clase usa las convenciones de nombrado est&#x00e1;ndar "
-"de JavaBean para m&#x00e9;todos getter y setter de propiedad, as&#x00ed; "
-"como visibilidad privada para los campos. Esto es un dise&#x00f1;o "
-"recomendado, aunque no requerido. Hibernate tambi&#x00e9;n puede acceder a "
-"los campos directamente; el beneficio de los m&#x00e9;todos de acceso es la "
-"robustez para la refactorizaci&#x00f3;n."
+"Esta clase utiliza convenciones de nombrado estándares de JavaBean para los "
+"métodos de propiedades getter y setter así como también visibilidad privada "
+"para los campos. Se recomienda este diseño, pero no se exige. Hibernate "
+"también puede acceder a los campos directamente, los métodos de acceso "
+"benefician la robustez de la refactorización. "
 
 #. Tag: para
-#: tutorial.xml:138
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>id</literal> property holds a unique identifier value for a "
 "particular event. All persistent entity classes (there are less important "
@@ -301,25 +215,22 @@
 "as well as public, private and protected fields directly. The choice is up "
 "to you and you can match it to fit your application design."
 msgstr ""
-"La propiedad <literal>id</literal> tiene un valor &#x00fa;nico de "
-"identificador para un evento en particular. Todas las clase de entidad "
-"persistentes ( tambi&#x00e9;n hay clases dependientes menos importantes) "
-"necesitar&#x00e1;n una propiedad identificadora similar si queremos usar el "
-"conjunto completo de funcionalidades de Hibernate. De hecho, la mayor&#x00ed;"
-"a de las aplicaciones (esp. aplicaciones web) necesitan distinguir objetos "
-"por identificador, de modo que debes considerar esto como un aspecto en vez "
-"de una limitaci&#x00f3;n. Sin embargo, usualmente no manipulamos la "
-"identidad de un objeto, por lo tanto el m&#x00e9;todo setter debe ser "
-"privado. S&#x00f3;lo Hibernate asignar&#x00e1; identificadores cuando un "
-"objeto sea salvado. Puedes ver que Hibernate puede acceder a m&#x00e9;todos "
-"de acceso p&#x00fa;blicos, privados y protegidos, tanto como directamente a "
-"campos (p&#x00fa;blicos, privados y protegidos). La elecci&#x00f3;n "
-"est&#x00e1; en ti, y puedes ajustarla a tu dise&#x00f1;o de aplicaci&#x00f3;"
-"n."
+"La propiedad <literal>id</literal> tiene un valor identificador único para "
+"un evento en particular. Todas las clases de entidad persistentes "
+"necesitarán tal propiedad identificadora si queremos utilizar el grupo "
+"completo de funcionalidades de Hibernate (también algunas clases "
+"dependientes menos importantes). De hecho, la mayoría de las aplicaciones "
+"(en especial las aplicaciones web) necesitan distinguir los objetos por "
+"identificador, así que usted debe tomar esto como una funcionalidad más que "
+"una limitación. Sin embargo, usualmente no manipulamos la identidad de un "
+"objeto, por lo tanto, el método setter debe ser privado. Sólamente Hibernate "
+"asignará identificadores cuando se guarde un objeto. Como se puede ver, "
+"Hibernate puede acceder a métodos de acceso públicos, privados y protegidos, "
+"así como también a campos directamente públicos, privados y protegidos. "
+"Puede escoger y hacer que se ajuste a su diseño de su aplicación."
 
 #. Tag: para
-#: tutorial.xml:153
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The no-argument constructor is a requirement for all persistent classes; "
 "Hibernate has to create objects for you, using Java Reflection. The "
@@ -328,28 +239,27 @@
 "instrumentation."
 msgstr ""
 "El constructor sin argumentos es un requerimiento para todas las clases "
-"persistentes. Hibernate tiene que crear objetos para ti, usando "
-"reflecci&#x00f3;n Java. El constructor puede ser privado, sin embargo, la "
-"visibilidad de paquete es requerida para la generaci&#x00f3;n de proxies en "
-"tiempo de ejecuci&#x00f3;n y la recuperaci&#x00f3;n de datos sin "
-"instrumentaci&#x00f3;n del bytecode."
+"persistentes, Hibernate tiene que crear objetos por usted utilizando Java "
+"Reflection. El constructor puede ser privado; sin embargo, se necesita la "
+"visibilidad del paquete para generar proxies en tiempo de ejecución y para "
+"la recuperación de datos de manera efectiva sin la instrumentación del "
+"código byte."
 
 #. Tag: para
-#: tutorial.xml:161
 #, no-c-format
 msgid ""
 "Save this file to the <filename>src/main/java/org/hibernate/tutorial/domain</"
 "filename> directory."
 msgstr ""
+"Duarde este archivo en el directorio <filename>src/main/java/org/hibernate/"
+"tutorial/domain</filename>."
 
 #. Tag: title
-#: tutorial.xml:168
 #, no-c-format
 msgid "The mapping file"
-msgstr "El fichero de mapeo"
+msgstr "El archivo de mapeo"
 
 #. Tag: para
-#: tutorial.xml:170
 #, no-c-format
 msgid ""
 "Hibernate needs to know how to load and store objects of the persistent "
@@ -357,42 +267,18 @@
 "file tells Hibernate what table in the database it has to access, and what "
 "columns in that table it should use."
 msgstr ""
-"Hibernate necesita saber c&#x00f3;mo cargar y almacenar objetos de la clase "
-"persistente. Aqu&#x00ed; es donde el fichero de mapeo de Hibernate entra en "
-"juego. El fichero de mapeo le dice a Hibernate a qu&#x00e9; tabla en la base "
-"de datos tiene que acceder, y qu&#x00e9; columnas en esta tabla debe usar."
+"Hibernate necesita saber cómo cargar y almacenar objetos de la clase "
+"persistente. En este punto es donde entra en juego el archivo de mapeo de "
+"Hibernate. Este archivo le dice a Hibernate a que tabla tiene que acceder en "
+"la base de datos, y que columnas debe utilizar en esta tabla."
 
 #. Tag: para
-#: tutorial.xml:178
 #, no-c-format
 msgid "The basic structure of a mapping file looks like this:"
-msgstr "La estructura b&#x00e1;sica de un fichero de mapeo se parece a esto:"
+msgstr "La estructura básica de un archivo de mapeo se ve así:"
 
-#. Tag: programlisting
-#: tutorial.xml:182
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"[...]\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping>\n"
-"[...]\n"
-"</hibernate-mapping>]]>"
-
 #. Tag: para
-#: tutorial.xml:184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate DTD is sophisticated. You can use it for auto-completion of XML "
 "mapping elements and attributes in your editor or IDE. Opening up the DTD "
@@ -403,65 +289,41 @@
 "<filename>hibernate-core.jar</filename> (it is also included in the "
 "<filename>hibernate3.jar</filename>, if using the distribution bundle)."
 msgstr ""
-"Observa que el DTD de Hibernate es muy sofisticado. Puedes usarlo para "
-"autocompleci&#x00f3;n de los elementos y atributos XML de mapeo en tu editor "
-"o IDE. Debes tambi&#x00e9;n abrir el fichero DTD en tu editor de texto. Es "
-"la forma m&#x00e1;s f&#x00e1;cil para tener un panorama de todos los "
-"elementos y atributos y ver los valores por defectos, as&#x00ed; como "
-"algunos comentarios. Nota que Hibernate no cargar&#x00e1; el fichero DTD de "
-"la web, sino que primero buscar&#x00e1; en el classpath de la "
-"aplicaci&#x00f3;n. El fichero DTD est&#x00e1; inclu&#x00ed;do en "
-"<literal>hibernate3.jar</literal> as&#x00ed; como tambi&#x00e9;n en el "
-"directorio <literal>src/</literal> de la distribuci&#x00f3;n de Hibernate."
+"El DTD de Hibernate es sofisticado. Puede utilizarlo para autocompletar los "
+"elementos y atributos XML de mapeo en su editor o IDE. Abrir el archivo DTD "
+"en su editor de texto es la manera más fácil para obtener una sinopsis de "
+"todos los elementos y atributos y para ver los valores por defecto, así como "
+"algunos de los comentarios. Note que Hibernate no cargará el fichero DTD de "
+"la web, sino que primero lo buscará en la ruta de clase de la aplicación. El "
+"archivo DTD se encuentra incluido en <filename>hibernate-core.jar</filename> "
+"(también en <filename>hibernate3.jar</filename> si está usando el paquete de "
+"la distribución)."
 
 #. Tag: para
-#: tutorial.xml:197
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will omit the DTD declaration in future examples to shorten the code. It "
 "is, of course, not optional."
 msgstr ""
-"Omitiremos la declaraci&#x00f3;n de DTD en futuros ejemplos para acortar el "
-"c&#x00f3;digo. Por supuesto, no es opcional."
+"Omitiremos la declaración de DTD en los ejemplos posteriores para hacer más "
+"corto el código. Esto no es opcional."
 
 #. Tag: para
-#: tutorial.xml:203
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Between the two <literal>hibernate-mapping</literal> tags, include a "
 "<literal>class</literal> element. All persistent entity classes (again, "
 "there might be dependent classes later on, which are not first-class "
 "entities) need a mapping to a table in the SQL database:"
 msgstr ""
-"Entre las dos etiquetas <literal>hibernate-mapping</literal>, incluye un "
+"Entre las dos etiquetas <literal>hibernate-mapping</literal>, incluya un "
 "elemento <literal>class</literal>. Todas las clases de entidad persistentes "
-"(de nuevo, podr&#x00ed;a haber m&#x00e1;s adelante clases dependientes, que "
-"no sean entidades de-primera-clase) necesitan dicho mapeo a una tabla en la "
-"base de datos SQL:"
+"(de nuevo, podrían haber clases dependientes más adelante, las cuales no son "
+"entidades de primera clase) necesitan de dicho mapeo en una tabla en la base "
+"de datos SQL:"
 
-#. Tag: programlisting
-#: tutorial.xml:210
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-
 #. Tag: para
-#: tutorial.xml:212
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "So far we have told Hibernate how to persist and load object of class "
 "<literal>Event</literal> to the table <literal>EVENTS</literal>. Each "
@@ -470,40 +332,15 @@
 "not want to care about handling this identifier, we configure Hibernate's "
 "identifier generation strategy for a surrogate primary key column:"
 msgstr ""
-"Hasta ahora dijimos a Hibernate c&#x00f3;mo persistir y cargar el objeto de "
-"clase <literal>Event</literal> a la tabla <literal>EVENTS</literal>, cada "
-"instancia representada por una fila en esta tabla. Ahora continuamos con un "
-"mapeo de la propiedad de identificado &#x00fa;nico a la clave primaria de la "
-"tabla. Adem&#x00e1;s, como no queremos cuidar del manejo de este "
-"identificador, configuramos la estrategia de generaci&#x00f3;n de "
-"identificadores para una columna clave primaria delegada:"
+"Hasta ahora le hemos dicho a Hibernate cómo persistir y cargar el objeto de "
+"clase <literal>Event</literal> a la tabla <literal>EVENTS</literal>. Cada "
+"instancia se encuentra representada por una fila en esa tabla. Ahora podemos "
+"continuar mapeando la propiedad identificadora única a la clave primaria de "
+"la tabla. Ya que no queremos preocuparnos por el manejo de este "
+"identificador, configuramos la estrategia de generación del identificador de "
+"Hibernate para una columna clave primaria sustituta:"
 
-#. Tag: programlisting
-#: tutorial.xml:222
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"        <id name=\"id\" column=\"EVENT_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"        <id name=\"id\" column=\"EVENT_ID\">\n"
-"            <generator class=\"increment\"/>\n"
-"        </id>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-
 #. Tag: para
-#: tutorial.xml:224
 #, no-c-format
 msgid ""
 "The <literal>id</literal> element is the declaration of the identifier "
@@ -513,9 +350,14 @@
 "The column attribute tells Hibernate which column of the <literal>EVENTS</"
 "literal> table holds the primary key value."
 msgstr ""
+"El elemento <literal>id</literal> es la declaración de la propiedad "
+"identificadora. El atributo de mapeo <literal>name=\"id\"</literal> declara "
+"el nombre de la propiedad JavaBean y le dice a Hibernate que utilice los "
+"métodos <literal>getId()</literal> y <literal>setId()</literal> para acceder "
+"a la propiedad. El atributo columna le dice a Hibernate qué columna de la "
+"tabla <literal>EVENTS</literal> tiene el valor de la llave principal."
 
 #. Tag: para
-#: tutorial.xml:234
 #, no-c-format
 msgid ""
 "The nested <literal>generator</literal> element specifies the identifier "
@@ -526,59 +368,39 @@
 "Identifier value generation is also one of Hibernate's many extension points "
 "and you can plugin in your own strategy."
 msgstr ""
+"El elemento anidado <literal>generator</literal> especifica la estrategia de "
+"generación del identificador (también conocidos como ¿cómo se generan los "
+"valores del identificador?). En este caso escogimos <literal>native</"
+"literal>, el cual ofrece un nivel de qué tan portátil es dependiendo del "
+"dialecto configurado de la base de datos. Hibernate soporta identificadores "
+"generados por la base de datos, globalmente únicos así como asignados por la "
+"aplicación. La generación del valor del identificador también es uno de los "
+"muchos puntos de extensión de Hibernate y puede conectar su propia "
+"estrategia."
 
 #. Tag: para
-#: tutorial.xml:246
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "<literal>native</literal> is no longer consider the best strategy in terms "
-"of portability. for further discussion, see"
+"of portability. for further discussion, see <xref linkend=\"portability-idgen"
+"\" />"
 msgstr ""
+"<literal>native</literal> ya no se considera como la mejor estrategia en "
+"términos de portabilidad. Para obtener mayor información consulte <xref "
+"linkend=\"portability-idgen\" />"
 
 #. Tag: para
-#: tutorial.xml:252
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Lastly, we need to tell Hibernate about the remaining entity class "
 "properties. By default, no properties of the class are considered persistent:"
 msgstr ""
-"Finalmente inclu&#x00ed;mos declaraciones para las propiedades persistentes "
-"de la clases en el fichero de mapeo. Por defecto, ninguna propiedad de la "
-"clase se considera persistente:"
+"Por último es necesario decirle a Hibernate sobre las porpiedades de clase "
+"de entidad que quedan. Por defecto, ninguna propiedad de la clase se "
+"considera persistente:"
 
-#. Tag: programlisting
-#: tutorial.xml:258
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[\n"
-"<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"        <id name=\"id\" column=\"EVENT_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"date\" type=\"timestamp\" column=\"EVENT_DATE\"/>\n"
-"        <property name=\"title\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-"<![CDATA[\n"
-"<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"        <id name=\"id\" column=\"EVENT_ID\">\n"
-"            <generator class=\"increment\"/>\n"
-"        </id>\n"
-"        <property name=\"date\" type=\"timestamp\" column=\"EVENT_DATE\"/>\n"
-"        <property name=\"title\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-
 #. Tag: para
-#: tutorial.xml:260
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Similar to the <literal>id</literal> element, the <literal>name</literal> "
 "attribute of the <literal>property</literal> element tells Hibernate which "
@@ -587,12 +409,13 @@
 "()</literal> and <literal>setTitle()</literal> methods."
 msgstr ""
 "Al igual que con el elemento <literal>id</literal>, el atributo "
-"<literal>name</literal> del elemento <literal>property</literal> dice a "
-"Hibernate c&#x00e1;les m&#x00e9;todos getter y setter usar."
+"<literal>name</literal> del elemento <literal>property</literal> le dice a "
+"Hibernate que métodos getter y setter utilizar. Así que en este caso, "
+"Hibernate buscará los métodos <literal>getDate()</literal>, <literal>setDate"
+"()</literal>, <literal>getTitle()</literal> y <literal>setTitle()</literal>."
 
 #. Tag: para
-#: tutorial.xml:271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Why does the <literal>date</literal> property mapping include the "
 "<literal>column</literal> attribute, but the <literal>title</literal> does "
@@ -601,17 +424,16 @@
 "literal>, however, <literal>date</literal> is a reserved keyword in most "
 "databases so you will need to map it to a different name."
 msgstr ""
-"¿Por qu&#x00e9; el mapeo de la propiedad <literal>date</literal> incluye el "
-"atributo <literal>column</literal>, pero el de la de <literal>title</"
-"literal> no? Sin el atributo <literal>column</literal> Hibernate usa por "
-"defecto el nombre de propiedad como nombre de columna. Esto funciona bien "
-"para <literal>title</literal>. Sin embargo, However, <literal>date</literal> "
-"es una palabra reservada en la mayor&#x00ed;a de las bases de datos, "
-"as&#x00ed; que mejor la mapeamos a un nombre diferente."
+"¿Por qué el mapeo de la propiedad <literal>date</literal> incluye el "
+"atributo <literal>column</literal>, pero el de <literal>title</literal> no? "
+"Sin el atributo <literal>column</literal> Hibernate utiliza, por defecto, el "
+"nombre de propiedad como nombre de la columna. Esto funciona bien para "
+"<literal>title</literal>. Sin embargo, <literal>date</literal> es una "
+"palabra clave reservada en la mayoría de las bases de datos, así que es "
+"mejor que la mapeamos a un nombre diferente."
 
 #. Tag: para
-#: tutorial.xml:281
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>title</literal> mapping also lacks a <literal>type</literal> "
 "attribute. The types declared and used in the mapping files are not Java "
@@ -628,25 +450,23 @@
 "literal> column. Full date and time information is preserved by mapping the "
 "property with a <literal>timestamp</literal> converter."
 msgstr ""
-"La pr&#x00f3;xima cosa interesante es que el mapeo de <literal>title</"
-"literal> carece de un atributo <literal>type</literal>. Los tipos que "
-"declaramos y usamos en el fichero de mapeo no son, como podr&#x00ed;as "
-"esperar, tipos de datos Java. Tampoco son tipos de base de datos SQL. Estos "
-"tipos son los llamados as&#x00ed; <emphasis>Tipos de mapeo de Hibernate</"
-"emphasis>, convertidores que pueden traducir de tipos Java a SQL y vice "
-"versa. De nuevo, Hibernate intentar&#x00e1; determinar la conversi&#x00f3;n "
-"y el mapeo mismo de tipo correctos si el atributo <literal>type</literal> no "
-"estuviese presente en el mapeo. En algunos casos esta detecci&#x00f3;n "
-"autom&#x00e1;tica (usando reflecci&#x00f3;n en la clase Java) puede no tener "
-"lo que esperas o necesitas. Este es el caso de la propiedad <literal>date</"
-"literal>. Hibernate no puede saber is la propiedad mapear&#x00e1; a una "
-"columna <literal>date</literal>, <literal>timestamp</literal> o "
-"<literal>time</literal>. Declaramos que queremos preservar la "
-"informaci&#x00f3;n completa de fecha y hora mapeando la propiedad con un "
-"<literal>timestamp</literal>."
+"El mapeo de <literal>title</literal> carece de un atributo <literal>type</"
+"literal>. Los tipos que declaramos y utilizamos en los archivos de mapeo no "
+"son tipos de datos Java. Tampoco son tipos de base de datos SQL. Estos tipos "
+"se llaman <emphasis>tipos de mapeo Hibernate </emphasis>, convertidores que "
+"pueden traducir de tipos de datos de Java a SQL y viceversa. De nuevo, "
+"Hibernate tratará de determinar el tipo correcto de conversión y de mapeo "
+"por sí mismo si el atributo <literal>type</literal> no se encuentra presente "
+"en el mapeo. En algunos casos esta detección automática (utilizando "
+"Reflection en la clase Java) puede que no tenga lo que usted espera o "
+"necesita. Este es el caso de la propiedad <literal>date</literal>. Hibernate "
+"no puede saber is la propiedad, la cual es de <literal>java.util.Date</"
+"literal>, debe mapear a una columna <literal>date</literal>, "
+"<literal>timestamp</literal> o <literal>time</literal> de SQL. Por medio de "
+"un convertidor <literal>timestamp</literal>, mapeamos la propiedad y "
+"mantenemos la información completa sobre la hora y fecha."
 
 #. Tag: para
-#: tutorial.xml:297
 #, no-c-format
 msgid ""
 "Hibernate makes this mapping type determination using reflection when the "
@@ -654,39 +474,43 @@
 "performance is important you should consider explicitly defining the type to "
 "use."
 msgstr ""
+"Hibernate realiza esta determinación de tipo de mapeo usando reflection "
+"cuando se procesan los archivos de mapeo. Esto puede tomar tiempo y recursos "
+"así que el rendimiento al arrancar es importante entonces debe considerar el "
+"definir explícitamente el tipo a usar."
 
 #. Tag: para
-#: tutorial.xml:304
 #, no-c-format
 msgid ""
 "Save this mapping file as <filename>src/main/resources/org/hibernate/"
 "tutorial/domain/Event.hbm.xml</filename>."
 msgstr ""
+"Guarde este archivo de mapeo como <filename>src/main/resources/org/hibernate/"
+"tutorial/domain/Event.hbm.xml</filename>."
 
 #. Tag: title
-#: tutorial.xml:312
 #, no-c-format
 msgid "Hibernate configuration"
-msgstr "Configuraci&#x00f3;n de Hibernate"
+msgstr "Configuración de Hibernate"
 
 #. Tag: para
-#: tutorial.xml:314
 #, no-c-format
 msgid ""
 "At this point, you should have the persistent class and its mapping file in "
 "place. It is now time to configure Hibernate. First let's set up HSQLDB to "
 "run in \"server mode\""
 msgstr ""
+"En este momento debe tener la clase persistente y su archivo de mapeo. Ahora "
+"debe configurar Hibernate. Primero vamos a configurar HSQLDB para que "
+"ejecute en \"modo de servidor\""
 
 #. Tag: para
-#: tutorial.xml:321
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "We do this do that the data remains between runs."
-msgstr ""
+msgstr "Hacemos esto o lo otro y los datos permanecen entre ejecuciones. "
 
 #. Tag: para
-#: tutorial.xml:326
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will utilize the Maven exec plugin to launch the HSQLDB server by "
 "running: <command> mvn exec:java -Dexec.mainClass=\"org.hsqldb.Server\" -"
@@ -696,12 +520,15 @@
 "tutorial, shutdown HSQLDB, delete all files in the <filename>target/data</"
 "filename> directory, and start HSQLDB again."
 msgstr ""
-"Crea un directorio llamado <literal>data</literal> en la ra&#x00ed;z del "
-"directorio de desarrollo. All&#x00ed; es donde HSQL DB almacenar&#x00e1; sus "
-"ficheros de datos."
+"Vamos a utilizar el plugin de ejecución Maven para lanzar el servidor HSQLDB "
+"ejecutando: <command> mvn exec:java -Dexec.mainClass=\"org.hsqldb.Server\" -"
+"Dexec.args=\"-database.0 file:target/data/tutorial\"</command>.Lo verá "
+"iniciando y vinculandose a un enchufe TCP/IP, allí es donde nuestra "
+"aplicación se conectará más adelante. Si quiere dar inicio con una base de "
+"datos fresca durante este tutorial, apague HSQLDB, borre todos los archivos "
+"en el directorio <filename>target/data</filename> e inicie HSQLDB de nuevo."
 
 #. Tag: para
-#: tutorial.xml:337
 #, no-c-format
 msgid ""
 "Hibernate will be connecting to the database on behalf of your application, "
@@ -713,158 +540,81 @@
 "net/\">proxool</ulink>. However, we will be using the Hibernate built-in "
 "connection pool for this tutorial."
 msgstr ""
+"Hibernate se conectará a la base de datos de parte de su aplicación así que "
+"necesita saber cómo obtener conexiones. Para este tutorial vamos a utilizar "
+"un pool de conexiones autónomo (opuesto a <interfacename>javax.sql."
+"DataSource</interfacename>). Hibernate viene con soporte para dos pools de "
+"conexiones JDBC de código abierto de terceros: <ulink url=\"https://"
+"sourceforge.net/projects/c3p0\">c3p0</ulink> y <ulink url=\"http://proxool."
+"sourceforge.net/\">proxool</ulink>. Sin embargo, vamos a utilizar el pool de "
+"conexiones incluido de Hibernate para este tutorial."
 
 #. Tag: para
-#: tutorial.xml:348
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The built-in Hibernate connection pool is in no way intended for production "
 "use. It lacks several features found on any decent connection pool."
 msgstr ""
+"El pool de conexiones de Hibernate no está diseñado para utilizarse en "
+"producción. "
 
 #. Tag: para
-#: tutorial.xml:354
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For Hibernate's configuration, we can use a simple <literal>hibernate."
 "properties</literal> file, a more sophisticated <literal>hibernate.cfg.xml</"
 "literal> file, or even complete programmatic setup. Most users prefer the "
 "XML configuration file:"
 msgstr ""
-"Para la configuraci&#x00f3;n de Hibernate, podemos usar un fichero "
-"<literal>hibernate.properties</literal> simple, un fichero "
-"<literal>hibernate.cfg.xml</literal> ligeramente m&#x00e1;s sofisticado, o "
-"incluso una configuraci&#x00f3;n completamente program&#x00e1;tica. La "
-"mayor&#x00ed;a de los usuarios prefieren el fichero de configuraci&#x00f3;n "
-"XML:"
+"Para la configuración de Hibernate, podemos utilizar un archivo "
+"<literal>hibernate.properties</literal> simple, un archivo "
+"<literal>hibernate.cfg.xml</literal> un poco más sofisticado, o incluso una "
+"configuración completamente programática. La mayoría de los usuarios "
+"prefieren el archivo de configuración XML:"
 
-#. Tag: programlisting
-#: tutorial.xml:360
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-"<!DOCTYPE hibernate-configuration PUBLIC\n"
-"        \"-//Hibernate/Hibernate Configuration DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
-"\">\n"
-"\n"
-"<hibernate-configuration>\n"
-"\n"
-"    <session-factory>\n"
-"\n"
-"        <!-- Database connection settings -->\n"
-"        <property name=\"connection.driver_class\">org.hsqldb.jdbcDriver</"
-"property>\n"
-"        <property name=\"connection.url\">jdbc:hsqldb:hsql://localhost</"
-"property>\n"
-"        <property name=\"connection.username\">sa</property>\n"
-"        <property name=\"connection.password\"></property>\n"
-"\n"
-"        <!-- JDBC connection pool (use the built-in) -->\n"
-"        <property name=\"connection.pool_size\">1</property>\n"
-"\n"
-"        <!-- SQL dialect -->\n"
-"        <property name=\"dialect\">org.hibernate.dialect.HSQLDialect</"
-"property>\n"
-"\n"
-"        <!-- Enable Hibernate's automatic session context management -->\n"
-"        <property name=\"current_session_context_class\">thread</property>\n"
-"\n"
-"        <!-- Disable the second-level cache  -->\n"
-"        <property name=\"cache.provider_class\">org.hibernate.cache."
-"NoCacheProvider</property>\n"
-"\n"
-"        <!-- Echo all executed SQL to stdout -->\n"
-"        <property name=\"show_sql\">true</property>\n"
-"\n"
-"        <!-- Drop and re-create the database schema on startup -->\n"
-"        <property name=\"hbm2ddl.auto\">update</property>\n"
-"\n"
-"        <mapping resource=\"org/hibernate/tutorial/domain/Event.hbm.xml\"/>\n"
-"\n"
-"    </session-factory>\n"
-"\n"
-"</hibernate-configuration>]]>"
-msgstr ""
-"<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-"<!DOCTYPE hibernate-configuration PUBLIC\n"
-"        \"-//Hibernate/Hibernate Configuration DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
-"\">\n"
-"\n"
-"<hibernate-configuration>\n"
-"\n"
-"    <session-factory>\n"
-"\n"
-"        <!-- Database connection settings -->\n"
-"        <property name=\"connection.driver_class\">org.hsqldb.jdbcDriver</"
-"property>\n"
-"        <property name=\"connection.url\">jdbc:hsqldb:data/tutorial</"
-"property>\n"
-"        <property name=\"connection.username\">sa</property>\n"
-"        <property name=\"connection.password\"></property>\n"
-"\n"
-"        <!-- JDBC connection pool (use the built-in) -->\n"
-"        <property name=\"connection.pool_size\">1</property>\n"
-"\n"
-"        <!-- SQL dialect -->\n"
-"        <property name=\"dialect\">org.hibernate.dialect.HSQLDialect</"
-"property>\n"
-"\n"
-"        <!-- Echo all executed SQL to stdout -->\n"
-"        <property name=\"show_sql\">true</property>\n"
-"\n"
-"        <!-- Drop and re-create the database schema on startup -->\n"
-"        <property name=\"hbm2ddl.auto\">create</property>\n"
-"\n"
-"        <mapping resource=\"Event.hbm.xml\"/>\n"
-"\n"
-"    </session-factory>\n"
-"\n"
-"</hibernate-configuration>]]>"
-
 #. Tag: para
-#: tutorial.xml:363
 #, no-c-format
 msgid "Notice that this configuration file specifies a different DTD"
-msgstr ""
+msgstr "Observe que este archivo de configuración especifica un DTD diferente"
 
 #. Tag: para
-#: tutorial.xml:366
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You configure Hibernate's <literal>SessionFactory</literal>. SessionFactory "
 "is a global factory responsible for a particular database. If you have "
 "several databases, for easier startup you should use several <literal>&lt;"
 "session-factory&gt;</literal> configurations in several configuration files."
 msgstr ""
-"Observa que esta configuraci&#x00f3;n XML usa un DTD diferente. Configuramos "
-"la <literal>SessionFactory</literal> de Hibernate, una f&#x00e1;brica global "
-"responsable de una base de datos en particular. Si tienes varias bases de "
-"datos, usa varias configuraciones <literal>&lt;session-factory&gt;</"
-"literal> , usualmente en varios ficheros de configuraci&#x00f3;n (para un "
-"arranque m&#x00e1;s f&#x00e1;cil)."
+"Configure la <literal>SessionFactory</literal> de Hibernate. SessionFactory "
+"es una fábrica global responsable de una base de datos en particular. Si "
+"usted tiene varias bases de datos, para un inicio más fácil utilice varias "
+"configuraciones <literal>&lt;session-factory&gt;</literal> en varios "
+"archivos de configuración."
 
 #. Tag: para
-#: tutorial.xml:373
 #, no-c-format
 msgid ""
 "The first four <literal>property</literal> elements contain the necessary "
 "configuration for the JDBC connection. The dialect <literal>property</"
 "literal> element specifies the particular SQL variant Hibernate generates."
 msgstr ""
+"Los primeros cuatro elementos <literal>property</literal> contienen la "
+"configuración necesaria para la conexión JDBC. El elemento "
+"<literal>property</literal> dialecto especifica la variante SQL en "
+"particular que Hibernate genera."
 
 #. Tag: para
-#: tutorial.xml:380
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "In most cases, Hibernate is able to properly determine which dialect to use. "
-"See <xref linkend=\"portability-dialectresolver\"/> for more information."
+"See <xref linkend=\"portability-dialectresolver\" /> for more information."
 msgstr ""
+"Hibernate tiene la habilidad de determinar correctamente qué dialecto "
+"utilizar en la mayoría de los casos. Consulte <xref linkend=\"portability-"
+"dialectresolver\" /> para obtener mayor información."
 
 #. Tag: para
-#: tutorial.xml:386
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's automatic session management for persistence contexts is "
 "particularly useful in this context. The <literal>hbm2ddl.auto</literal> "
@@ -874,32 +624,30 @@
 "Ant task. Finally, add the mapping file(s) for persistent classes to the "
 "configuration."
 msgstr ""
-"Los primeros cuatro elementos <literal>property</literal> contienen la "
-"configuraci&#x00f3;n necesaria para la conexi&#x00f3;n JDBC. El elemento de "
-"dialecto <literal>property</literal> especifica la variante de SQL en "
-"particular que genera Hibernate. La opci&#x00f3;n <literal>hbm2ddl.auto</"
-"literal> activa la generaci&#x00f3;n autom&#x00e1;tica de esquemas de base "
-"de datos, directamente en la base de datos. Esto, por supuesto, puede "
-"desactivarse (quitando la opci&#x00f3;n config) o redirigido a un fichero "
-"con la ayuda de la tarea de Ant <literal>SchemaExport</literal>. Finalmente, "
-"agregamos el(los) fichero(s) de mapeo para clases persistentes."
+"La administración de la sesión automática de Hibernate para contextos de "
+"persistencia es particularmente útil en este contexto. La opción "
+"<literal>hbm2ddl.auto</literal> activa la generación automática de los "
+"esquemas de la base de datos directamente en la base de datos. Esto se puede "
+"desactivar, eliminando la opción de configuración o redirigiéndolo a un "
+"archivo con la ayuda de la tarea de Ant <literal>SchemaExport</literal>. "
+"Finalmente, agregue a la configuración el/los fichero(s) de mapeo para "
+"clases persistentes."
 
 #. Tag: para
-#: tutorial.xml:395
 #, no-c-format
 msgid ""
 "Save this file as <filename>hibernate.cfg.xml</filename> into the "
 "<filename>src/main/resources</filename> directory."
 msgstr ""
+"Guarde este archivo como <filename>hibernate.cfg.xml</filename> en el "
+"directorio <filename>src/main/resources</filename>."
 
 #. Tag: title
-#: tutorial.xml:403
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Building with Maven"
-msgstr "Construyendo con Ant"
+msgstr "Construcción con Maven"
 
 #. Tag: para
-#: tutorial.xml:405
 #, no-c-format
 msgid ""
 "We will now build the tutorial with Maven. You will need to have Maven "
@@ -909,51 +657,21 @@
 "basic project tasks. First, lets run the <literal>compile</literal> goal to "
 "make sure we can compile everything so far:"
 msgstr ""
+"Ahora vamos a construir el tutorial con Maven. Es necesario que tenga "
+"instalado Maven; se encuentra disponible en la <ulink url=\"http://maven."
+"apache.org/download.html\">página de descargas Maven</ulink>. Maven leerá el "
+"archivo <filename>/pom.xml</filename> que creamos anteriormente y sabrá cómo "
+"realizar algunas tareas de proyectos básicos. Primero, vamos a ejecutar la "
+"meta <literal>compile</literal> para asegurarnos de que podemos compilar "
+"todo hasta el momento:"
 
-#. Tag: programlisting
-#: tutorial.xml:415
-#, no-c-format
-msgid ""
-"<![CDATA[[hibernateTutorial]$ mvn compile\n"
-"[INFO] Scanning for projects...\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] Building First Hibernate Tutorial\n"
-"[INFO]    task-segment: [compile]\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] [resources:resources]\n"
-"[INFO] Using default encoding to copy filtered resources.\n"
-"[INFO] [compiler:compile]\n"
-"[INFO] Compiling 1 source file to /home/steve/projects/sandbox/"
-"hibernateTutorial/target/classes\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] BUILD SUCCESSFUL\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] Total time: 2 seconds\n"
-"[INFO] Finished at: Tue Jun 09 12:25:25 CDT 2009\n"
-"[INFO] Final Memory: 5M/547M\n"
-"[INFO] "
-"------------------------------------------------------------------------]]>"
-msgstr ""
-
 #. Tag: title
-#: tutorial.xml:420
 #, no-c-format
 msgid "Startup and helpers"
-msgstr ""
-"Esto dir&#x00e1; a Ant que agregue todos los ficheros en el directorio lib "
-"que terminen con <literal>.jar</literal> al classpath usado para la "
-"compilaci&#x00f3;n. Tambi&#x00e9;n copiar&#x00e1; todos los ficheros que no "
-"sean c&#x00f3;digo Java al directorio objetivo, por ejemplo, ficheros de "
-"configuraci&#x00f3;n y mapeos de Hibernate. Si ahora corres Ant, debes "
-"obtener esta salida:"
+msgstr "Inicio y ayudantes"
 
 #. Tag: para
-#: tutorial.xml:422
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is time to load and store some <literal>Event</literal> objects, but "
 "first you have to complete the setup with some infrastructure code. You have "
@@ -966,82 +684,40 @@
 "<interfacename>org.hibernate.SessionFactory</interfacename> is a thread-safe "
 "global object that is instantiated once."
 msgstr ""
-"<![CDATA[C:\\hibernateTutorial\\>ant\n"
-"Buildfile: build.xml\n"
-"\n"
-"copy-resources:\n"
-"     [copy] Copying 2 files to C:\\hibernateTutorial\\bin\n"
-"\n"
-"compile:\n"
-"    [javac] Compiling 1 source file to C:\\hibernateTutorial\\bin\n"
-"\n"
-"BUILD SUCCESSFUL\n"
-"Total time: 1 second ]]>"
+"Es el momento de cargar y almacenar algunos objetos <literal>Event</"
+"literal>, pero primero tiene que completar la configuración con algo de "
+"código de infraestructura. Tiene que iniciar Hibernate construyendo un "
+"objeto <interfacename>org.hibernate.SessionFactory</interfacename> global y "
+"almacenarlo en algún lugar de fácil acceso en el código de la aplicación. "
+"Una <interfacename>org.hibernate.SessionFactory</interfacename> se utiliza "
+"para obtener instancias <interfacename>org.hibernate.Session</"
+"interfacename>. Una <interfacename>org.hibernate.Session</interfacename> "
+"representa una unidad de trabajo mono-hilo. La <interfacename>org.hibernate."
+"SessionFactory</interfacename> es un objeto global seguro entre hilos que se "
+"instancia una sóla vez."
 
 #. Tag: para
-#: tutorial.xml:436
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will create a <literal>HibernateUtil</literal> helper class that takes "
 "care of startup and makes accessing the <interfacename>org.hibernate."
 "SessionFactory</interfacename> more convenient."
-msgstr "Arranque y ayudantes"
-
-#. Tag: programlisting
-#: tutorial.xml:442
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.util;\n"
-"\n"
-"import org.hibernate.SessionFactory;\n"
-"import org.hibernate.cfg.Configuration;\n"
-"\n"
-"public class HibernateUtil {\n"
-"\n"
-"    private static final SessionFactory sessionFactory = buildSessionFactory"
-"();\n"
-"\n"
-"    private static SessionFactory buildSessionFactory() {\n"
-"        try {\n"
-"            // Create the SessionFactory from hibernate.cfg.xml\n"
-"            return new Configuration().configure().buildSessionFactory();\n"
-"        }\n"
-"        catch (Throwable ex) {\n"
-"            // Make sure you log the exception, as it might be swallowed\n"
-"            System.err.println(\"Initial SessionFactory creation failed.\" + "
-"ex);\n"
-"            throw new ExceptionInInitializerError(ex);\n"
-"        }\n"
-"    }\n"
-"\n"
-"    public static SessionFactory getSessionFactory() {\n"
-"        return sessionFactory;\n"
-"    }\n"
-"\n"
-"}]]>"
 msgstr ""
-"Es momento de cargar y almacenar algunos objetos <literal>Event</literal>, "
-"pero primero tenemos que completar la configuraci&#x00f3;n de alg&#x00fa;n "
-"c&#x00f3;digo de infraestructura. Tenemos que arrancar Hibernate. Este "
-"arranque incluye construir un objeto <literal>SessionFactory</literal> "
-"global y almacenarlo en alg&#x00fa;n sitio de f&#x00e1;cil acceso en el "
-"c&#x00f3;digo de aplicaci&#x00f3;n. Una <literal>SessionFactory</literal> "
-"puede abrir nuevas <literal>Session</literal>'s. Una <literal>Session</"
-"literal> representa un unidad de trabajo mono-hebra. La "
-"<literal>SessionFactory</literal> es un objeto global seguro entre hebras, "
-"instanciado una sola vez."
+"Vamos a crear una clase de ayuda <literal>HibernateUtil</literal> que se "
+"encargue del inicio y haga más práctico el acceso a <interfacename>org."
+"hibernate.SessionFactory</interfacename>. "
 
 #. Tag: para
-#: tutorial.xml:444
 #, no-c-format
 msgid ""
 "Save this code as <filename>src/main/java/org/hibernate/tutorial/util/"
 "HibernateUtil.java</filename>"
 msgstr ""
+"Guarde este código como <filename>src/main/java/org/hibernate/tutorial/util/"
+"HibernateUtil.java</filename>"
 
 #. Tag: para
-#: tutorial.xml:449
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This class not only produces the global <interfacename>org.hibernate."
 "SessionFactory</interfacename> reference in its static initializer; it also "
@@ -1050,16 +726,15 @@
 "reference from JNDI in an application server or any other location for that "
 "matter."
 msgstr ""
-"Crearemos una clase de ayuda <literal>HibernateUtil</literal> que cuide del "
-"arranque y haga conveniente el manejo de <literal>Session</literal>. El "
-"as&#x00ed; llamado patr&#x00f3;n <emphasis>Sesi&#x00f3;n de Hebra Local "
-"(ThreadLocal Session)</emphasis> es &#x00fa;til aqu&#x00ed;; mantenemos la "
-"unidad de trabajo actual asociada a la hebra actual. Echemos una mirada a la "
-"implementaci&#x00f3;n:"
+"Esta clase no sólamente produce la referencia <interfacename>org.hibernate."
+"SessionFactory</interfacename> global en su inicializador estático, sino que "
+"también esconde el hecho de que utiliza un singleton estático. También puede "
+"que busque la  referencia <interfacename>org.hibernate.SessionFactory</"
+"interfacename> desde JNDI en un servidor de aplicaciones en cualquier otro "
+"lugar."
 
 #. Tag: para
-#: tutorial.xml:458
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you give the <interfacename>org.hibernate.SessionFactory</interfacename> "
 "a name in your configuration, Hibernate will try to bind it to JNDI under "
@@ -1068,50 +743,15 @@
 "<literal>HibernateService</literal> to JNDI. Such advanced options are "
 "discussed later."
 msgstr ""
-"<![CDATA[import org.hibernate.*;\n"
-"import org.hibernate.cfg.*;\n"
-"\n"
-"public class HibernateUtil {\n"
-"\n"
-"    public static final SessionFactory sessionFactory;\n"
-"\n"
-"    static {\n"
-"        try {\n"
-"            // Create the SessionFactory from hibernate.cfg.xml\n"
-"            sessionFactory = new Configuration().configure()."
-"buildSessionFactory();\n"
-"        } catch (Throwable ex) {\n"
-"            // Make sure you log the exception, as it might be swallowed\n"
-"            System.err.println(\"Initial SessionFactory creation failed.\" + "
-"ex);\n"
-"            throw new ExceptionInInitializerError(ex);\n"
-"        }\n"
-"    }\n"
-"\n"
-"    public static final ThreadLocal session = new ThreadLocal();\n"
-"\n"
-"    public static Session currentSession() throws HibernateException {\n"
-"        Session s = (Session) session.get();\n"
-"        // Open a new Session, if this thread has none yet\n"
-"        if (s == null) {\n"
-"            s = sessionFactory.openSession();\n"
-"            // Store it in the ThreadLocal variable\n"
-"            session.set(s);\n"
-"        }\n"
-"        return s;\n"
-"    }\n"
-"\n"
-"    public static void closeSession() throws HibernateException {\n"
-"        Session s = (Session) session.get();\n"
-"        if (s != null)\n"
-"            s.close();\n"
-"        session.set(null);\n"
-"    }\n"
-"}]]>"
+"Si usted le da un nombre a <interfacename>org.hibernate.SessionFactory</"
+"interfacename> en su archivo de configuración, de hecho, Hibernate tratará "
+"de vincularlo a JNDI bajo ese nombre después de que ha sido construido. Otra "
+"mejor opción es utilizar el despliegue JMX y dejar que el contenedor con "
+"capacidad JMX instancie y vincule un <literal>HibernateService</literal> a "
+"JNDI. Más adelante discutiremos estas opciones avanzadas."
 
 #. Tag: para
-#: tutorial.xml:467
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You now need to configure a logging system. Hibernate uses commons logging "
 "and provides two choices: Log4j and JDK 1.4 logging. Most developers prefer "
@@ -1122,111 +762,56 @@
 "configuration, you can change the settings. By default, only the Hibernate "
 "startup message is shown on stdout."
 msgstr ""
-"Coloca <literal>HibernateUtil.java</literal> en el directorio de fuentes de "
-"desarrollo, junto a <literal>Event.java</literal>:"
+"Ahora necesita configurar un sistema de registro. Hibernate utiliza "
+"registros comunes le da dos opciones: Log4J y registros de JDK 1.4. La "
+"mayoría de los desarrolladores prefieren Log4J: copie <literal>log4j."
+"properties</literal> de la distribución de Hibernate, se encuentra en el "
+"directorio <literal>etc/</literal>) a su directorio <literal>src</literal>, "
+"junto a <literal>hibernate.cfg.xml</literal>. Si desea tener una salida más "
+"verbosa que la que se proporcionó en la configuración del ejemplo entonces "
+"puede cambiar su configuración. Por defecto, sólo se muestra el mensaje de "
+"inicio de Hibernate en la salida estándar."
 
 #. Tag: para
-#: tutorial.xml:477
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The tutorial infrastructure is complete and you are now ready to do some "
 "real work with Hibernate."
 msgstr ""
-"<![CDATA[.\n"
-"+lib\n"
-"  <Hibernate and third-party libraries>\n"
-"+src\n"
-"  Event.java\n"
-"  Event.hbm.xml\n"
-"  HibernateUtil.java\n"
-"  hibernate.cfg.xml\n"
-"+data\n"
-"build.xml]]>"
+"La infraestructura del tutorial está completa y estamos listos para hacer un "
+"poco de trabajo real con Hibernate."
 
 #. Tag: title
-#: tutorial.xml:485
 #, no-c-format
 msgid "Loading and storing objects"
-msgstr ""
-"Esto tambi&#x00e9;n debe compilar sin problemas. Finalmente necesitamos "
-"configurar un sistema de logging (registro). Hibernate usa commons logging y "
-"te deja la elecci&#x00f3;n entre Log4J y logging de JDK 1.4. La mayor&#x00ed;"
-"a de los desarrolladores prefieren Log4J: copia <literal>log4j.properties</"
-"literal> de la distribuci&#x00f3;n de Hibernate (est&#x00e1; en el "
-"directorio <literal>etc/</literal>) a tu directorio <literal>src</literal>, "
-"junto a <literal>hibernate.cfg.xml</literal>. Echa una mirada a la "
-"configuraci&#x00f3;n de ejemplo y cambia los ajustes si te gusta tener una "
-"salida m&#x00e1;s verborr&#x00e1;gica. Por defecto, s&#x00f3;lo se muestra "
-"el mensaje de arranque de Hibernate en la salida."
+msgstr "Carga y almacenamiento de objetos"
 
 #. Tag: para
-#: tutorial.xml:487
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We are now ready to start doing some real worjk with Hibernate. Let's start "
 "by writing an <literal>EventManager</literal> class with a <literal>main()</"
 "literal> method:"
 msgstr ""
-"La infraestructura del tutorial est&#x00e1; completa, y estamos listos para "
-"hacer alg&#x00fa;n trabajo real con Hibernate."
+"Ahora estamos listos para hacer un poco de trabajo real con Hibernate. "
+"Empecemos por escribir una clase <literal>EventManager</literal> con un "
+"método <literal>main()</literal>:"
 
-#. Tag: programlisting
-#: tutorial.xml:493
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial;\n"
-"\n"
-"import org.hibernate.Session;\n"
-"\n"
-"import java.util.*;\n"
-"\n"
-"import org.hibernate.tutorial.domain.Event;\n"
-"import org.hibernate.tutorial.util.HibernateUtil;\n"
-"\n"
-"public class EventManager {\n"
-"\n"
-"    public static void main(String[] args) {\n"
-"        EventManager mgr = new EventManager();\n"
-"\n"
-"        if (args[0].equals(\"store\")) {\n"
-"            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-"        }\n"
-"\n"
-"        HibernateUtil.getSessionFactory().close();\n"
-"    }\n"
-"\n"
-"    private void createAndStoreEvent(String title, Date theDate) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Event theEvent = new Event();\n"
-"        theEvent.setTitle(title);\n"
-"        theEvent.setDate(theDate);\n"
-"        session.save(theEvent);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr "Cargando y almacenando objetos"
-
 #. Tag: para
-#: tutorial.xml:495
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In <literal>createAndStoreEvent()</literal> we created a new <literal>Event</"
 "literal> object and handed it over to Hibernate. At that point, Hibernate "
 "takes care of the SQL and executes an <literal>INSERT</literal> on the "
 "database."
 msgstr ""
-"Finalmente, podemos usar Hibernate para cargar y almacenar objetos. "
-"Escribimos una clase <literal>EventManager</literal> con un m&#x00e9;todo "
-"<literal>main()</literal>:"
+"En <literal>createAndStoreEvent()</literal> creamos un nuevo objeto "
+"<literal>Event</literal> y se lo entregamos a Hibernate. En ese momento, "
+"Hibernate se encarga de SQL y ejecuta un <literal>INSERT</literal> en la "
+"base de datos."
 
 #. Tag: para
-#: tutorial.xml:502
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <interface>org.hibernate.Session</interface> is designed to represent a "
 "single unit of work (a single atmoic piece of work to be performed). For now "
@@ -1237,28 +822,18 @@
 "interfacename> API. In this particular case we are using JDBC-based "
 "transactional semantics, but it could also run with JTA."
 msgstr ""
-"<![CDATA[import org.hibernate.Transaction;\n"
-"import org.hibernate.Session;\n"
-"\n"
-"import java.util.Date;\n"
-"\n"
-"public class EventManager {\n"
-"\n"
-"    public static void main(String[] args) {\n"
-"        EventManager mgr = new EventManager();\n"
-"\n"
-"        if (args[0].equals(\"store\")) {\n"
-"            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-"        }\n"
-"\n"
-"        HibernateUtil.sessionFactory.close();\n"
-"    }\n"
-"\n"
-"}]]>"
+"Una <interface>org.hibernate.Session</interface> está diseñada para "
+"representar una sóla unidad de trabajo (una sola parte atómica de trabajo "
+"que se va a realizar). Por ahora vamos a mantener las cosas sencillas y "
+"vamos a asumir una granularidad de uno a uno entre la <interface>org."
+"hibernate.Session</interface> de Hibernate y una transacción de la base "
+"datos. Para proteger nuestro código del sistema de transacciones subyacentes "
+"utilizamos el API <interfacename>org.hibernate.Transaction</interfacename> "
+"de Hibernate. En este caso en particular estamos utilizado una semántica "
+"transaccional basada en JDBC pero también puede ejecutarse con JTA. "
 
 #. Tag: para
-#: tutorial.xml:515
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What does <literal>sessionFactory.getCurrentSession()</literal> do? First, "
 "you can call it as many times and anywhere you like once you get hold of "
@@ -1269,11 +844,16 @@
 "xml</filename>? Due to that setting, the context of a current unit of work "
 "is bound to the current Java thread that executes the application."
 msgstr ""
-"Leemos algunos argumentos de la l&#x00ed;nea de comandos, y si el primer "
-"argumento es \"store\", creamos y almacenamos un nuevo Event:"
+"¿Qué hace <literal>sessionFactory.getCurrentSession()</literal>? Primero, la "
+"puede llamar tantas veces como desee y en donde quiera, una vez consiga su "
+"<interfacename>org.hibernate.SessionFactory</interfacename>. El método "
+"<literal>getCurrentSession()</literal> siempre retorna la unidad de trabajo "
+"\"actual\". ¿Recuerda que cambiamos la opción de la configuración de este "
+"mecanismo a \"thread\" en <filename>src/main/resources/hibernate.cfg.xml</"
+"filename>? Por lo tanto, el contexto de una unidad de trabajo actual se "
+"encuentra vinculada al hilo de Java actual que ejecuta nuestra aplicación."
 
 #. Tag: para
-#: tutorial.xml:529
 #, no-c-format
 msgid ""
 "Hibernate offers three methods of current session tracking. The \"thread\" "
@@ -1281,10 +861,13 @@
 "prototyping and tutorials such as this one. Current session tracking is "
 "discussed in more detail later on."
 msgstr ""
+"Hibernate ofrece tres métodos de rastreo de sesión actual. El método basado "
+"en \"hilos\" no está dirigido al uso de producción; sólo es útil para "
+"prototipos y para tutoriales como este. Más adelante discutiremos con más "
+"detalles el rastreo de sesión actual."
 
 #. Tag: para
-#: tutorial.xml:538
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <interface>org.hibernate.Session</interface> begins when the first call to "
 "<literal>getCurrentSession()</literal> is made for the current thread. It is "
@@ -1295,23 +878,18 @@
 "new <interface>org.hibernate.Session</interface> and can start a new unit of "
 "work."
 msgstr ""
-"<![CDATA[private void createAndStoreEvent(String title, Date theDate) {\n"
-"    Session session = HibernateUtil.currentSession();\n"
-"    Transaction tx = session.beginTransaction();\n"
-"\n"
-"    Event theEvent = new Event();\n"
-"    theEvent.setTitle(title);\n"
-"    theEvent.setDate(theDate);\n"
-"\n"
-"    session.save(theEvent);\n"
-"\n"
-"    tx.commit();\n"
-"    HibernateUtil.closeSession();\n"
-"}]]>"
+"Una <interface>org.hibernate.Session</interface> se inicia cuando se realiza "
+"la primera llamada a <literal>getCurrentSession()</literal> para el hilo "
+"actual. Luego Hibernate la vincula al hilo actual. Cuando termina la "
+"transacción, ya sea por medio de guardar o deshacer los cambios, Hibernate "
+"desvincula automáticamente la <interface>org.hibernate.Session</interface> "
+"del hilo y la cierra por usted. Si llama a <literal>getCurrentSession()</"
+"literal> de nuevo, obtiene una <interface>org.hibernate.Session</interface> "
+"nueva y obtiene una nueva <interface>org.hibernate.Session</interface> "
+"unidad de trabajo. "
 
 #. Tag: para
-#: tutorial.xml:551
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Related to the unit of work scope, should the Hibernate <interface>org."
 "hibernate.Session</interface> be used to execute one or several database "
@@ -1325,314 +903,171 @@
 "<emphasis>session-per-operation</emphasis> an anti-pattern. A real web "
 "application is shown later in the tutorial which will help illustrate this."
 msgstr ""
-"Creamos un nuevo objeto <literal>Event</literal>, y se lo damos a Hibernate. "
-"Hibernate cuida ahora del SQL y ejecuta <literal>INSERT</literal>s en la "
-"base de datos. Echemos una mirada al c&#x00f3;digo de manejo de "
-"<literal>Session</literal> y <literal>Transaction</literal> antes de "
-"ejecutar esto."
+"En relación con la unidad del campo de trabajo, ¿Se debería utilizar "
+"<interface>org.hibernate.Session</interface> de Hibernate para ejecutar una "
+"o varias operaciones de la base de datos? El ejemplo anterior utiliza una "
+"<interface>org.hibernate.Session</interface> para una operación. Sin "
+"embargo, esto es pura coincidencia; el ejemplo simplemente no es lo "
+"suficientemente complicado para mostrar cualquier otro enfoque. El ámbito de "
+"una <interface>org.hibernate.Session</interface> de Hibernate es flexible "
+"pero nunca debe diseñar su aplicación para que utilice una nueva "
+"<interface>org.hibernate.Session</interface> de Hibernate para "
+"<emphasis>cada</emphasis> operación de la base de datos. Aunque lo "
+"utilizamos en los siguientes ejemplos, considere la <emphasis>sesión-por-"
+"operación</emphasis> como un anti-patrón. Más adelante en este tutorial, se "
+"muestra una aplicación web real, lo cual le ayudará a ilustrar esto."
 
 #. Tag: para
-#: tutorial.xml:568
 #, fuzzy, no-c-format
 msgid ""
-"See <xref linkend=\"transactions\"/> for more information about transaction "
+"See <xref linkend=\"transactions\" /> for more information about transaction "
 "handling and demarcation. The previous example also skipped any error "
 "handling and rollback."
 msgstr ""
-"Una <literal>Session</literal> es una sola unidad de trabajo. Podr&#x00ed;a "
-"sorprenderte que tengamos una API adicional, <literal>Transaction</literal>. "
-"Esto implica que una unidad de trabajo puede ser \"m&#x00e1;s larga\" que "
-"una sola transacci&#x00f3;n de base de datos; imagina una unidad de trabajo "
-"que se abarca varios ciclos petici&#x00f3;n/respuesta HTTP (por ejemplo, un "
-"di&#x00e1;logo asistente) en una aplicaci&#x00f3;n web. Separar las "
-"transacciones de base de datos de \"las unidades de trabajo de la "
-"aplicaci&#x00f3;n desde el punto de vista del usuario\" es uno de los "
-"conceptos b&#x00e1;sicos de dise&#x00f1;o de Hibernate. Llamamos una unidad "
-"de trabajo larga <emphasis>Transacci&#x00f3;n de Aplicaci&#x00f3;n</"
-"emphasis>, usualmente encapsulando varias transacciones de base de datos "
-"m&#x00e1;s cortas. Por ahora mantendremos las cosas simples y asumiremos una "
-"granularidad uno-a-uno entre una <literal>Session</literal> y una "
-"<literal>Transaction</literal>."
+"Consulte <xref linkend=\"transactions\" /> para obtener mayor información "
+"sobre el manejo de transacciones y la demarcación. En el ejemplo anterior "
+"también nos saltamos el manejo de errores y cómo deshacerlos."
 
 #. Tag: para
-#: tutorial.xml:574
 #, no-c-format
 msgid ""
 "To run this, we will make use of the Maven exec plugin to call our class "
 "with the necessary classpath setup: <command>mvn exec:java -Dexec.mainClass="
 "\"org.hibernate.tutorial.EventManager\" -Dexec.args=\"store\"</command>"
 msgstr ""
+"Para ejecutar esto, utilizaremos el plugin de ejecución Maven para llamar "
+"nuestra clase con la configuración de ruta de clase necesaria: <command>mvn "
+"exec:java -Dexec.mainClass=\"org.hibernate.tutorial.EventManager\" -Dexec."
+"args=\"store\"</command>"
 
 #. Tag: para
-#: tutorial.xml:581
 #, no-c-format
 msgid "You may need to perform <command>mvn compile</command> first."
 msgstr ""
+"Es posible que primero necesite realizar <command>mvn compile</command>."
 
 #. Tag: para
-#: tutorial.xml:586
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You should see Hibernate starting up and, depending on your configuration, "
 "lots of log output. Towards the end, the following line will be displayed:"
-msgstr "<![CDATA[C:\\hibernateTutorial\\>ant run -Daction=store]]>"
-
-#. Tag: programlisting
-#: tutorial.xml:591
-#, no-c-format
-msgid ""
-"<![CDATA[[java] Hibernate: insert into EVENTS (EVENT_DATE, title, EVENT_ID) "
-"values (?, ?, ?)]]>"
 msgstr ""
-"Debes ver, despu&#x00e9;s de la compilaci&#x00f3;n, a Hibernate arrancando "
-"y, dependiendo de tu configuraci&#x00f3;n mucha salida de registro (log). Al "
-"final encontrar&#x00e1;s la siguiente l&#x00ed;nea:"
+"Debe ver que Hibernate inicia y dependiendo de su configuración, también "
+"verá bastantes salidas de registro. Al final, verá la siguiente línea:"
 
 #. Tag: para
-#: tutorial.xml:593
 #, no-c-format
 msgid "This is the <literal>INSERT</literal> executed by Hibernate."
-msgstr ""
+msgstr "Este es el <literal>INSERT</literal> que Hibernate ejecuta."
 
 #. Tag: para
-#: tutorial.xml:597
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "To list stored events an option is added to the main method:"
 msgstr ""
-"Esta es la <literal>INSERT</literal> ejecutada por Hibernate, los signos de "
-"preguntas representan par&#x00e1;metros de ligado JDBC. Para ver los valores "
-"ligados como argumentos, o para reducir la verborragia del registro, chequea "
-"tu <literal>log4j.properties</literal>."
+"Para listar los eventos almacenados se agrega una opción al método principal:"
 
-#. Tag: programlisting
-#: tutorial.xml:601
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[        if (args[0].equals(\"store\")) {\n"
-"            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-"        }\n"
-"        else if (args[0].equals(\"list\")) {\n"
-"            List events = mgr.listEvents();\n"
-"            for (int i = 0; i < events.size(); i++) {\n"
-"                Event theEvent = (Event) events.get(i);\n"
-"                System.out.println(\n"
-"                        \"Event: \" + theEvent.getTitle() + \" Time: \" + "
-"theEvent.getDate()\n"
-"                );\n"
-"            }\n"
-"        }]]>"
-msgstr ""
-"Ahora quisi&#x00e9;ramos listar acontecimientos almacenados tambi&#x00e9;n, "
-"as&#x00ed; que agregamos una opci&#x00f3;n al m&#x00e9;todo principal:"
-
 #. Tag: para
-#: tutorial.xml:603
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A new <literal>listEvents() method is also added</literal>:"
-msgstr ""
-"<![CDATA[if (args[0].equals(\"store\")) {\n"
-"    mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-"}\n"
-"else if (args[0].equals(\"list\")) {\n"
-"    List events = mgr.listEvents();\n"
-"    for (int i = 0; i < events.size(); i++) {\n"
-"        Event theEvent = (Event) events.get(i);\n"
-"        System.out.println(\"Event: \" + theEvent.getTitle() +\n"
-"                           \" Time: \" + theEvent.getDate());\n"
-"    }\n"
-"}]]>"
+msgstr "También agregamos un método <literal>listEvents()</literal>:"
 
-#. Tag: programlisting
-#: tutorial.xml:607
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[    private List listEvents() {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"        List result = session.createQuery(\"from Event\").list();\n"
-"        session.getTransaction().commit();\n"
-"        return result;\n"
-"    }]]>"
-msgstr ""
-"Agregamos tambi&#x00e9;n un nuevo m&#x00e9;todo <literal>listEvents()</"
-"literal>:"
-
 #. Tag: para
-#: tutorial.xml:609
 #, fuzzy, no-c-format
 msgid ""
 "Here, we are using a Hibernate Query Language (HQL) query to load all "
 "existing <literal>Event</literal> objects from the database. Hibernate will "
 "generate the appropriate SQL, send it to the database and populate "
 "<literal>Event</literal> objects with the data. You can create more complex "
-"queries with HQL. See <xref linkend=\"queryhql\"/> for more information."
+"queries with HQL. See <xref linkend=\"queryhql\" /> for more information."
 msgstr ""
-"<![CDATA[private List listEvents() {\n"
-"    Session session = HibernateUtil.currentSession();\n"
-"    Transaction tx = session.beginTransaction();\n"
-"\n"
-"    List result = session.createQuery(\"from Event\").list();\n"
-"\n"
-"    tx.commit();\n"
-"    session.close();\n"
-"\n"
-"    return result;\n"
-"}]]>"
+"Aquí utilizamos una consulta HQL (Hibernate Query Language) para cargar "
+"todos los objetos <literal>Event</literal> desde la base de datos. Hibernate "
+"generará el SQL apropiado, lo enviará a la base de datos y poblará los "
+"objetos <literal>Event</literal> con los datos. Puede crear peticiones más "
+"complejas con HQL. Consulte <xref linkend=\"queryhql\"/> para obtener mayor "
+"información. "
 
 #. Tag: para
-#: tutorial.xml:617
 #, no-c-format
 msgid ""
 "Now we can call our new functionality, again using the Maven exec plugin: "
 "<command>mvn exec:java -Dexec.mainClass=\"org.hibernate.tutorial.EventManager"
 "\" -Dexec.args=\"list\"</command>"
 msgstr ""
+"Ahora podemos llamar nuestra nueva funcionalidad, de nuevo usando el plugin "
+"de ejecución Maven: <command>mvn exec:java -Dexec.mainClass=\"org.hibernate."
+"tutorial.EventManager\" -Dexec.args=\"list\"</command>"
 
 #. Tag: title
-#: tutorial.xml:627
 #, no-c-format
 msgid "Part 2 - Mapping associations"
-msgstr ""
-"Note: Most new Hibernate users fail at this point and we see questions about "
-"<emphasis>Table not found</emphasis> error messages regularly. However, if "
-"you follow the steps outlined above you will not have this problem, as "
-"hbm2ddl creates the database schema on the first run, and subsequent "
-"application restarts will use this schema. If you change the mapping and/or "
-"database schema, you have to re-enable hbm2ddl once again."
+msgstr "Part 2 - Mapeo de asociaciones"
 
 #. Tag: para
-#: tutorial.xml:629
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "So far we have mapped a single persistent entity class to a table in "
 "isolation. Let's expand on that a bit and add some class associations. We "
 "will add people to the application and store a list of events in which they "
 "participate."
-msgstr "Part 2 - Mapeando asociaciones"
+msgstr ""
+"Hasta ahora hemos mapeado una clase de entidad persistente a una tabla "
+"aislada. Vamos a construir sobre esto y agregaremos algunas asociaciones de "
+"clase. Vamos a agregar personas a la aplicación y vamos a almacenar una "
+"lista de eventos en las que participan."
 
 #. Tag: title
-#: tutorial.xml:637
 #, no-c-format
 msgid "Mapping the Person class"
-msgstr ""
-"Hemos mapeado un clase de entidad persistente a una tabla. Construyamos "
-"sobre esto y agreguemos algunas asociaciones de clase. Primero agregaremos "
-"personas a nuestra aplicaci&#x00f3;n, y almacenaremos una lista de eventos "
-"en las que participan."
+msgstr "Mapeo de la clase Person"
 
 #. Tag: para
-#: tutorial.xml:639
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The first cut of the <literal>Person</literal> class looks like this:"
-msgstr "Mapeando la clase Person"
+msgstr "El primer corte de la clase <literal>Person</literal> se ve así:"
 
-#. Tag: programlisting
-#: tutorial.xml:643
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.domain;\n"
-"\n"
-"public class Person {\n"
-"\n"
-"    private Long id;\n"
-"    private int age;\n"
-"    private String firstname;\n"
-"    private String lastname;\n"
-"\n"
-"    public Person() {}\n"
-"\n"
-"    // Accessor methods for all properties, private setter for 'id'\n"
-"\n"
-"}]]>"
-msgstr "El primer corte de la clase <literal>Person</literal> es simple:"
-
 #. Tag: para
-#: tutorial.xml:645
 #, no-c-format
 msgid ""
 "Save this to a file named <filename>src/main/java/org/hibernate/tutorial/"
 "domain/Person.java</filename>"
 msgstr ""
+"Guarde esto en un archivo llamado <filename>src/main/java/org/hibernate/"
+"tutorial/domain/Person.java</filename>"
 
 #. Tag: para
-#: tutorial.xml:650
 #, no-c-format
 msgid ""
 "Next, create the new mapping file as <filename>src/main/resources/org/"
 "hibernate/tutorial/domain/Person.hbm.xml</filename>"
 msgstr ""
+"Luego, cree el nuevo archivo de mapeo como <filename>src/main/resources/org/"
+"hibernate/tutorial/domain/Person.hbm.xml</filename>"
 
-#. Tag: programlisting
-#: tutorial.xml:655
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Person\" table=\"PERSON\">\n"
-"        <id name=\"id\" column=\"PERSON_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"age\"/>\n"
-"        <property name=\"firstname\"/>\n"
-"        <property name=\"lastname\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr "Crea un fichero de mapeo llamado <literal>Person.hbm.xml</literal>:"
-
 #. Tag: para
-#: tutorial.xml:657
 #, no-c-format
 msgid "Finally, add the new mapping to Hibernate's configuration:"
-msgstr ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Person\" table=\"PERSON\">\n"
-"        <id name=\"id\" column=\"PERSON_ID\">\n"
-"            <generator class=\"increment\"/>\n"
-"        </id>\n"
-"        <property name=\"age\"/>\n"
-"        <property name=\"firstname\"/>\n"
-"        <property name=\"lastname\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
+msgstr "Finalmente, añada el nuevo mapeo a la configuración de Hibernate:"
 
-#. Tag: programlisting
-#: tutorial.xml:661
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<mapping resource=\"events/Event.hbm.xml\"/>\n"
-"<mapping resource=\"events/Person.hbm.xml\"/>]]>"
-msgstr ""
-"Finalmente, agrega el nuevo mapeo a la configuraci&#x00f3;n de Hibernate:"
-
-#. Tag: para
-#: tutorial.xml:663
-#, fuzzy, no-c-format
-msgid ""
 "Create an association between these two entities. Persons can participate in "
 "events, and events have participants. The design questions you have to deal "
 "with are: directionality, multiplicity, and collection behavior."
 msgstr ""
-"<![CDATA[        <mapping resource=\"Event.hbm.xml\"/>\n"
-"        <mapping resource=\"Person.hbm.xml\"/>\n"
-"]]>"
+"Vamos a crear una asociación entre estas dos entidades. Las personas pueden "
+"participar en los eventos y los eventos cuentan con participantes. Las "
+"cuestiones de diseño con las que tenemos que tratar son: direccionalidad, "
+"multiplicidad y comportamiento de la colección."
 
 #. Tag: title
-#: tutorial.xml:673
 #, no-c-format
 msgid "A unidirectional Set-based association"
-msgstr ""
-"Crearemos ahora una asociaci&#x00f3;n entre estas dos entidades. Obviamente, "
-"las personas pueden participar en eventos, y los eventos tienen "
-"participantes. Las cuestiones de dise&#x00f1;o con que tenemos que tratar "
-"son: direccionalidad, multiplicidad y comportamiento de colecci&#x00f3;n."
+msgstr "Una asociación unidireccional basada en Set"
 
 #. Tag: para
-#: tutorial.xml:675
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "By adding a collection of events to the <literal>Person</literal> class, you "
 "can easily navigate to the events for a particular person, without executing "
@@ -1641,32 +1076,18 @@
 "Collection Framework contracts; here we choose a <interfacename>java.util."
 "Set</interfacename> because the collection will not contain duplicate "
 "elements and the ordering is not relevant to our examples:"
-msgstr "Una asociaci&#x00f3;n unidireccional basada en Set"
-
-#. Tag: programlisting
-#: tutorial.xml:686
-#, no-c-format
-msgid ""
-"<![CDATA[public class Person {\n"
-"\n"
-"    private Set events = new HashSet();\n"
-"\n"
-"    public Set getEvents() {\n"
-"        return events;\n"
-"    }\n"
-"\n"
-"    public void setEvents(Set events) {\n"
-"        this.events = events;\n"
-"    }\n"
-"}]]>"
 msgstr ""
-"Hasta ahora hemos dise&#x00f1;ado asociaciones unidireccionales "
-"multivaluadas, implementadas con un <literal>Set</literal>. Escribamos el "
-"c&#x00f3;digo para esto en las clases Java y luego lo mapeemos:"
+"Al agregar una colección de eventos a la clase <literal>Person</literal>, "
+"puede navegar fácilmente a los eventos de una persona en particular, sin "
+"ejecutar una petición explícita - llamando a <literal>Person#getEvents</"
+"literal>. En Hibernate, las asociaciones multi-valores se representan por "
+"medio de uno de los contratos del marco de colecciones Java; aquí escogimos "
+"un <interfacename>java.util.Set</interfacename> ya que la colección no "
+"contendrá elementos duplicados y el orden no es relevante para nuestros "
+"ejemplos."
 
 #. Tag: para
-#: tutorial.xml:688
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Before mapping this association, let's consider the other side. We could "
 "just keep this unidirectional or create another collection on the "
@@ -1678,51 +1099,19 @@
 "on both sides is called a <emphasis>many-to-many</emphasis> association. "
 "Hence, we use Hibernate's many-to-many mapping:"
 msgstr ""
-"<![CDATA[public class Person {\n"
-"\n"
-"    private Set events = new HashSet();\n"
-"\n"
-"    public Set getEvents() {\n"
-"        return events;\n"
-"    }\n"
-"\n"
-"    public void setEvents(Set events) {\n"
-"        this.events = events;\n"
-"    }\n"
-"}]]>"
+"Antes de mapear esta asociación, considere el otro lado. Podriamos mantener "
+"esto unidireccional o podríamos crear otra colección en el <literal>Event</"
+"literal>, si queremos tener la habilidad de navegarlo desde ambas "
+"direcciones. Esto no es necesario desde un punto de vista funcional. Siempre "
+"puede ejeutar un pedido explícito para recuperar los participantes de un "
+"evento en particular. Esta es una elección de diseño que depende de usted, "
+"pero lo que queda claro de esta discusión es la multiplicidad de la "
+"asociación: \"muchos\" valuada en ambos lados, denominamos esto como una "
+"asociación <emphasis>muchos-a-muchos</emphasis>. Por lo tanto, utilizamos un "
+"mapeo muchos-a-muchos de Hibernate:"
 
-#. Tag: programlisting
-#: tutorial.xml:701
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\" table=\"PERSON\">\n"
-"    <id name=\"id\" column=\"PERSON_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"age\"/>\n"
-"    <property name=\"firstname\"/>\n"
-"    <property name=\"lastname\"/>\n"
-"\n"
-"    <set name=\"events\" table=\"PERSON_EVENT\">\n"
-"        <key column=\"PERSON_ID\"/>\n"
-"        <many-to-many column=\"EVENT_ID\" class=\"Event\"/>\n"
-"    </set>\n"
-"\n"
-"</class>]]>"
-msgstr ""
-"Antes que mapeemos esta asociaci&#x00f3;n, piensa sobre el otro lado. "
-"Claramente, podemos mantener esto solamente unidireccional. O podemos crear "
-"otra colecci&#x00f3;n en el <literal>Event</literal>, si queremos ser "
-"capaces de navegarlos bidireccionalmente; por ejemplo, <literal>anEvent."
-"getParticipants()</literal>. Esta es una elecci&#x00f3;n de dise&#x00f1;o "
-"que recae en ti, pero lo que est&#x00e1; claro de esta discusi&#x00f3;n es "
-"la multiplicidad de la asociaci&#x00f3;n: \"multi\" valuada a ambos lados, "
-"llamamos a esto una asociaci&#x00f3;n <emphasis>muchos-a-muchos</emphasis>. "
-"Por lo tanto, usamos un mapeo many-to-many de Hibernate:"
-
 #. Tag: para
-#: tutorial.xml:703
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate supports a broad range of collection mappings, a <literal>set</"
 "literal> being most common. For a many-to-many association, or <emphasis>n:"
@@ -1736,108 +1125,39 @@
 "tell Hibernate the class of the objects in your collection (the class on the "
 "other side of the collection of references)."
 msgstr ""
-"<![CDATA[<class name=\"Person\" table=\"PERSON\">\n"
-"    <id name=\"id\" column=\"PERSON_ID\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"age\"/>\n"
-"    <property name=\"firstname\"/>\n"
-"    <property name=\"lastname\"/>\n"
-"\n"
-"    <set name=\"events\" table=\"PERSON_EVENT\">\n"
-"        <key column=\"PERSON_ID\"/>\n"
-"        <many-to-many column=\"EVENT_ID\" class=\"Event\"/>\n"
-"    </set>\n"
-"\n"
-"</class>]]>"
+"Hibernate soporta un amplio rango de mapeos de colección, el más común "
+"<literal>set</literal>. Para una asociación muchos-a-muchos o la relación de "
+"entidad <emphasis>n:m</emphasis>, se necesita una tabla de asociación. Cada "
+"fila en esta tabla representa un enlace entre una persona y un evento. El "
+"nombre de esta tabla se declara con el atributo <literal>table</literal> del "
+"elemento <literal>set</literal>. El nombre de la columna identificadora en "
+"la asociación, del lado de la persona, se define con el elemento "
+"<literal>key</literal>, el nombre de columna para el lado del evento se "
+"define con el atributo <literal>column</literal> del <literal>many-to-many</"
+"literal>. También tiene que informarle a Hibernate la clase de los objetos "
+"en su colección (la clase del otro lado de la colección de referencias)."
 
 #. Tag: para
-#: tutorial.xml:719
 #, no-c-format
 msgid "The database schema for this mapping is therefore:"
-msgstr ""
-"Hibernate soporta todo tipo de mapeos de colecci&#x00f3;n, siendo el "
-"m&#x00e1;s com&#x00fa;n un <literal>&lt;set&gt;</literal>. Para una "
-"asociaci&#x00f3;n muchos-a-muchos (o relaci&#x00f3;n de entidad <emphasis>n:"
-"m</emphasis>), se necesita una tabla de asociaci&#x00f3;n. Cada fila en esta "
-"tabla representa un enlace entre una persona y un evento. Esta tabla se "
-"configura con el atributo <literal>table</literal> del elemento "
-"<literal>set</literal>. El nombre de la columna identificadora en la "
-"asociaci&#x00f3;n, para el lado de la persona, se define con el elemento "
-"<literal>&lt;key&gt;</literal>. El nombre de columna para el lado del evento "
-"se define con el atributo <literal>column</literal> del <literal>&lt;many-to-"
-"many&gt;</literal>. Tambi&#x00e9;n tienes que decirle a Hibernate la clase "
-"de los objetos en tu colecci&#x00f3;n (correcto: la clase del otro lado de "
-"la colecci&#x00f3;n de referencias)."
+msgstr "Por consiguiente, el esquema de base de datos para este mapeo es:"
 
-#. Tag: programlisting
-#: tutorial.xml:723
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"    _____________        __________________\n"
-"   |             |      |                  |       _____________\n"
-"   |   EVENTS    |      |   PERSON_EVENT   |      |             |\n"
-"   |_____________|      |__________________|      |    PERSON   |\n"
-"   |             |      |                  |      |_____________|\n"
-"   | *EVENT_ID   | <--> | *EVENT_ID        |      |             |\n"
-"   |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  |\n"
-"   |  TITLE      |      |__________________|      |  AGE        |\n"
-"   |_____________|                                |  FIRSTNAME  |\n"
-"                                                  |  LASTNAME   |\n"
-"                                                  |_____________|\n"
-" ]]>"
-msgstr "El esquema de base de datos para este mapeo es, por lo tanto:"
-
 #. Tag: title
-#: tutorial.xml:728
 #, no-c-format
 msgid "Working the association"
-msgstr ""
-"<![CDATA[\n"
-"    _____________        __________________\n"
-"   |             |      |                  |       _____________\n"
-"   |   EVENTS    |      |   PERSON_EVENT   |      |             |\n"
-"   |_____________|      |__________________|      |    PERSON   |\n"
-"   |             |      |                  |      |_____________|\n"
-"   | *EVENT_ID   | <--> | *EVENT_ID        |      |             |\n"
-"   |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  |\n"
-"   |  TITLE      |      |__________________|      |  AGE        |\n"
-"   |_____________|                                |  FIRSTNAME  |\n"
-"                                                  |  LASTNAME   |\n"
-"                                                  |_____________|\n"
-" ]]>"
+msgstr "Trabajo de la asociación"
 
 #. Tag: para
-#: tutorial.xml:730
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now we will bring some people and events together in a new method in "
 "<literal>EventManager</literal>:"
-msgstr "Trabajando la asociaci&#x00f3;n"
-
-#. Tag: programlisting
-#: tutorial.xml:734
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session.load(Person.class, personId);\n"
-"        Event anEvent = (Event) session.load(Event.class, eventId);\n"
-"        aPerson.getEvents().add(anEvent);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }]]>"
 msgstr ""
-"Traigamos alguna gente y eventos juntos en un nuevo m&#x00e9;todo en "
+"Vamos a reunir a algunas personas y eventos en un nuevo método en "
 "<literal>EventManager</literal>:"
 
 #. Tag: para
-#: tutorial.xml:736
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "After loading a <literal>Person</literal> and an <literal>Event</literal>, "
 "simply modify the collection using the normal collection methods. There is "
@@ -1853,22 +1173,24 @@
 "of a unit of work, is called <emphasis>flushing</emphasis>. In our code, the "
 "unit of work ends with a commit, or rollback, of the database transaction."
 msgstr ""
-"<![CDATA[private void addPersonToEvent(Long personId, Long eventId) {\n"
-"    Session session = HibernateUtil.currentSession();\n"
-"    Transaction tx = session.beginTransaction();\n"
-"\n"
-"    Person aPerson = (Person) session.load(Person.class, personId);\n"
-"    Event anEvent = (Event) session.load(Event.class, eventId);\n"
-"\n"
-"    aPerson.getEvents().add(anEvent);\n"
-"\n"
-"    tx.commit();\n"
-"    HibernateUtil.closeSession();\n"
-"}]]>"
+"Después de cargar una <literal>Person</literal> y un <literal>Event</"
+"literal>, simplemente modifique la colección utilizando los métodos normales "
+"de colección. No hay una llamada explícita a <literal>update()</literal> o "
+"<literal>save()</literal>; Hibernate detecta automáticamente que se ha "
+"modificado la colección y que se necesita actualizarla. Esto se denomina "
+"<emphasis>chequeo automático de desactualizaciones</emphasis> y también "
+"puede probarlo modificando el nombre o la propiedad de fecha de cualquiera "
+"de sus objetos. Mientras se encuentran en estado <emphasis>persistente</"
+"emphasis>, es decir, enlazado a una <interfacename>org.hibernate.Session</"
+"interfacename> de Hibernate en particular, Hibernate monitorea cualquier "
+"cambio y ejecuta SQL de un modo escribe-detrás. El proceso de sincronización "
+"del estado de la memoria con la base de datos, usualmente sólo al final de "
+"una unidad de trabajo, se denomina <emphasis>vaciado</emphasis>. En nuestro "
+"código la unidad de trabajo termina con guardar o deshacer los cambios de la "
+"transacción de la base de datos."
 
 #. Tag: para
-#: tutorial.xml:755
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can load person and event in different units of work. Or you can modify "
 "an object outside of a <interfacename>org.hibernate.Session</interfacename>, "
@@ -1876,65 +1198,15 @@
 "is called <emphasis>detached</emphasis>). You can even modify a collection "
 "when it is detached:"
 msgstr ""
-"Despu&#x00e9;s de cargar una <literal>Person</literal> y un <literal>Event</"
-"literal>, simplemente modifica la colecci&#x00f3;n usando sus m&#x00e9;todos "
-"normales. Como puedes ver, no hay una llamada expl&#x00ed;cita a "
-"<literal>update()</literal> o <literal>save()</literal>. Hibernate detecta "
-"autom&#x00e1;ticamente que la colecci&#x00f3;n ha sido modificada y necesita "
-"ser salvada. Esto es llamado <emphasis>chequeo sucio autom&#x00f3;tico "
-"(automatic dirty checking)</emphasis>, y tambi&#x00e9;n puedes intentarlo "
-"modificando el nombre de la propiedad de fecha de cualquiera de tus objetos. "
-"Mientras est&#x00e9;n en estado <emphasis>persistente</emphasis>, esto es, "
-"ligados a una <literal>Session</literal> de Hibernate particular (es decir, "
-"justo han sido cargados o almacenados en una unidad de trabajo), Hibernate "
-"monitoriza cualquier cambio y ejecuta SQL en estilo escribe-por-detr&#x00e1;"
-"s. El proceso de sincronizaci&#x00f3;n del estado de memoria con la base de "
-"datos, usualmente s&#x00f3;lo al final de una unidad de trabajo, es llamado "
-"<emphasis>limpieza (flushing)</emphasis>."
+"Puede cargar una persona y un evento en diferentes unidades de trabajo. "
+"También puede modificar un objeto fuera de una <interfacename>org.hibernate."
+"Session</interfacename>, cuando no se encuentra en estado persistente (si "
+"antes era persistente denominamos a este estado <emphasis>separado</"
+"emphasis> ). Inclusive, puede modificar una colección cuando se encuentre "
+"separada:"
 
-#. Tag: programlisting
-#: tutorial.xml:764
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session\n"
-"                .createQuery(\"select p from Person p left join fetch p."
-"events where p.id = :pid\")\n"
-"                .setParameter(\"pid\", personId)\n"
-"                .uniqueResult(); // Eager fetch the collection so we can use "
-"it detached\n"
-"        Event anEvent = (Event) session.load(Event.class, eventId);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"\n"
-"        // End of first unit of work\n"
-"\n"
-"        aPerson.getEvents().add(anEvent); // aPerson (and its collection) is "
-"detached\n"
-"\n"
-"        // Begin second unit of work\n"
-"\n"
-"        Session session2 = HibernateUtil.getSessionFactory()."
-"getCurrentSession();\n"
-"        session2.beginTransaction();\n"
-"        session2.update(aPerson); // Reattachment of aPerson\n"
-"\n"
-"        session2.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-"Podr&#x00ed;as, por supuesto, cargar persona y evento en unidades de trabajo "
-"diferentes. O modificas un objeto fuera de una <literal>Session</literal>, "
-"cuando no est&#x00e1; en estado persistente (si antes era persistente "
-"llamamos a este estado <emphasis>separado (detached) </emphasis>). En "
-"c&#x00f3;digo (no muy realista), esto se ver&#x00ed;a como sigue:"
-
 #. Tag: para
-#: tutorial.xml:766
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The call to <literal>update</literal> makes a detached object persistent "
 "again by binding it to a new unit of work, so any modifications you made to "
@@ -1942,32 +1214,14 @@
 "modifications (additions/deletions) you made to a collection of that entity "
 "object."
 msgstr ""
-"<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) {\n"
-"\n"
-"        Session session = HibernateUtil.currentSession();\n"
-"        Transaction tx = session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session.load(Person.class, personId);\n"
-"        Event anEvent = (Event) session.load(Event.class, eventId);\n"
-"\n"
-"        tx.commit();\n"
-"        HibernateUtil.closeSession();\n"
-"\n"
-"        aPerson.getEvents().add(anEvent); // aPerson is detached\n"
-"\n"
-"        Session session2 = HibernateUtil.currentSession();\n"
-"        Transaction tx2 = session.beginTransaction();\n"
-"\n"
-"        session2.update(aPerson); // Reattachment of aPerson\n"
-"\n"
-"        tx2.commit();\n"
-"        HibernateUtil.closeSession();\n"
-"    }\n"
-"]]>"
+"La llamada a <literal>update</literal> hace que un objeto separado sea "
+"persistente de nuevo enlazándolo a una nueva unidad de trabajo, así que "
+"cualquier modificación que le realizó mientras estaba separado se puede "
+"guardar en la base de datos. Esto incluye cualquier modificación (adiciones "
+"o eliminaciones) que le hizo a una colección de ese objeto entidad."
 
 #. Tag: para
-#: tutorial.xml:775
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is not much use in our example, but it is an important concept you can "
 "incorporate into your own application. Complete this exercise by adding a "
@@ -1976,34 +1230,16 @@
 "an event - the <literal>save()</literal> method returns it (you might have "
 "to modify some of the previous methods to return that identifier):"
 msgstr ""
-"La llamada a <literal>update</literal> hace a un objeto persistente de "
-"nuevo, podr&#x00ed;as decir que la liga a una nueva unidad de trabajo, de "
-"modo que cualquier modificaci&#x00f3;n que le hagas mientras est&#x00e9; "
-"separado puede ser salvada a base de datos."
+"Esto no se utiliza mucho en nuestro ejemplo, pero es un concepto importante "
+"que puede incorporar en su propia aplicación. Complete este ejercicio "
+"agregando una nueva acción al método main de <literal>EventManager</literal> "
+"y llámela desde la línea de comandos. Si necesita los identificadores de una "
+"persona y de un evento - el método <literal>save()</literal> los retorna "
+"(pueda que necesite modificar algunos de los métodos anteriores para "
+"retornar ese identificador):"
 
-#. Tag: programlisting
-#: tutorial.xml:783
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[        else if (args[0].equals(\"addpersontoevent\")) {\n"
-"            Long eventId = mgr.createAndStoreEvent(\"My Event\", new Date"
-"());\n"
-"            Long personId = mgr.createAndStorePerson(\"Foo\", \"Bar\");\n"
-"            mgr.addPersonToEvent(personId, eventId);\n"
-"            System.out.println(\"Added person \" + personId + \" to event \" "
-"+ eventId);\n"
-"        }]]>"
-msgstr ""
-"Bueno, esto no es muy usado en nuestra situaci&#x00f3;n actual, pero es un "
-"concepto importante que puedes dise&#x00f1;ar en tu propia aplicaci&#x00f3;"
-"n. Por ahora, completa este ejercicio agregando una nueva acci&#x00f3;n al "
-"m&#x00e9;todo main de <literal>EventManager</literal> y ll&#x00e1;mala desde "
-"la l&#x00ed;nea de comandos. Si necesitas los identificadores de una persona "
-"o evento, el m&#x00e9;todo <literal>save()</literal> los devuelve."
-
 #. Tag: para
-#: tutorial.xml:785
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is an example of an association between two equally important classes : "
 "two entities. As mentioned earlier, there are other classes and types in a "
@@ -2018,95 +1254,56 @@
 "<literal>Address</literal> or <literal>MonetaryAmount</literal> class. In "
 "fact, in a Hibernate application all JDK classes are considered value types."
 msgstr ""
-"Esto fue un ejemplo de una asociaci&#x00f3;n entre dos clases igualmente "
-"importantes, dos entidades. Como se ha mencionado anteriormente, hay otras "
-"clases y tipos en un modelo t&#x00ed;pico, usualmente \"menos importantes\". "
-"Algunos ya los habr&#x00e1;s visto, como un <literal>int</literal> o un "
-"<literal>String</literal>. Llamamos a estas clases <emphasis>tipos de valor "
-"(value types)</emphasis>, y sus instancias <emphasis>dependen</emphasis> de "
-"una entidad en particular. Las instancias de estos tipos no tienen su propia "
-"identidad, ni son compartidas entre entidades (dos personas no referencian "
-"el mismo objeto <literal>firstname</literal>, incluso si tuvieran el mismo "
-"primer nombre). Por supuesto, los tipos de valor no s&#x00f3;lo pueden "
-"encontrarse en el JDK (de hecho, en una aplicaci&#x00f3;n Hibernate todas "
-"las clases del JDK son consideradas tipos de valor), sino que adem&#x00e1;s "
-"puedes escribir por ti mismo clases dependientes, por ejemplo, "
-"<literal>Address</literal> o <literal>MonetaryAmount</literal>."
+"Esto fue un ejemplo de una asociación entre dos clases igualmente "
+"importantes: dos entidades. Como se mencionó anteriormente, hay otras clases "
+"y tipos en un modelo típico, usualmente \"menos importantes\". Algunos de "
+"ustedes las habrán visto, como un <literal>int</literal> o un "
+"<classname>java.lang.String</classname>. Denominamos a estas clases "
+"<emphasis>tipos de valor</emphasis> y sus instancias <emphasis>dependen</"
+"emphasis> de una entidad en particular. Las instancias de estos tipos no "
+"tienen su propia identidad, ni son compartidas entre entidades. Dos personas "
+"no referencian el mismo objeto <literal>firstname</literal>, incluso si "
+"tienen el mismo nombre. Los tipos de valor no sólo pueden encontrarse en el "
+"JDK, sino que también puede escribir por sí mismo clases dependientes como "
+"por ejemplo, <literal>Address</literal> o <literal>MonetaryAmount</literal>. "
+"De hecho, en una aplicación Hibernate todas las clases JDK se consideran "
+"como tipos de valor. "
 
 #. Tag: para
-#: tutorial.xml:803
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also design a collection of value types. This is conceptually "
 "different from a collection of references to other entities, but looks "
 "almost the same in Java."
 msgstr ""
-"Tambi&#x00e9;n puedes dise&#x00f1;ar una colecci&#x00f3;n de tipos de valor. "
-"Esto es conceptualmente muy diferente de una colecci&#x00f3;n de referencias "
-"a otras entidades, pero se ve casi lo mismo en Java."
+"También puede diseñar una colección de tipos de valor. Esto es "
+"conceptualmente diferente de una colección de referencias a otras entidades, "
+"pero se ve casi igual en Java."
 
 #. Tag: title
-#: tutorial.xml:812
 #, no-c-format
 msgid "Collection of values"
-msgstr "Colecci&#x00f3;n de valores"
+msgstr "Colección de valores"
 
 #. Tag: para
-#: tutorial.xml:814
 #, no-c-format
 msgid ""
 "Let's add a collection of email addresses to the <literal>Person</literal> "
 "entity. This will be represented as a <interfacename>java.util.Set</"
 "interfacename> of <classname>java.lang.String</classname> instances:"
 msgstr ""
+"Vamos a agregar una colección de direcciones de correo electrónico a la "
+"entidad <literal>Person</literal>. Esto se representará como un "
+"<interfacename>java.util.Set</interfacename> de las instnaicas "
+"<classname>java.lang.String</classname>:"
 
-#. Tag: programlisting
-#: tutorial.xml:820
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[    private Set emailAddresses = new HashSet();\n"
-"\n"
-"    public Set getEmailAddresses() {\n"
-"        return emailAddresses;\n"
-"    }\n"
-"\n"
-"    public void setEmailAddresses(Set emailAddresses) {\n"
-"        this.emailAddresses = emailAddresses;\n"
-"    }]]>"
-msgstr ""
-"<![CDATA[private Set emailAddresses = new HashSet();\n"
-"\n"
-"public Set getEmailAddresses() {\n"
-"    return emailAddresses;\n"
-"}\n"
-"\n"
-"public void setEmailAddresses(Set emailAddresses) {\n"
-"    this.emailAddresses = emailAddresses;\n"
-"}]]>"
-
 #. Tag: para
-#: tutorial.xml:822
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The mapping of this <literal>Set</literal> is as follows:"
-msgstr "El mapeo de este <literal>Set</literal>:"
+msgstr "El mapeo de este <literal>Set</literal> es así:"
 
-#. Tag: programlisting
-#: tutorial.xml:826
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[        <set name=\"emailAddresses\" table=\"PERSON_EMAIL_ADDR\">\n"
-"            <key column=\"PERSON_ID\"/>\n"
-"            <element type=\"string\" column=\"EMAIL_ADDR\"/>\n"
-"        </set>]]>"
-msgstr ""
-"<![CDATA[<set name=\"emailAddresses\" table=\"PERSON_EMAIL_ADDR\">\n"
-"    <key column=\"PERSON_ID\"/>\n"
-"    <element type=\"string\" column=\"EMAIL_ADDR\"/>\n"
-"</set>]]>"
-
 #. Tag: para
-#: tutorial.xml:828
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The difference compared with the earlier mapping is the use of the "
 "<literal>element</literal> part which tells Hibernate that the collection "
@@ -2120,240 +1317,103 @@
 "<literal>element</literal> element defines the column name where the email "
 "address values will actually be stored."
 msgstr ""
-"La diferencia comparada con el mapeo anterior es la parte <literal>element</"
-"literal>, que le dice a Hibernate que la colecci&#x00f3;n no contiene "
-"referencias a otra entidad, sino una colecci&#x00f3;n de elementos de tipo "
-"<literal>String</literal> (el nombre en min&#x00fa;sculas te dice que es un "
-"tipo/conversor de mapeo de Hibernate). Una vez m&#x00e1;s, el atributo "
-"<literal>table</literal> del elemento <literal>set</literal> determina el "
-"nombre de la tabla para la colecci&#x00f3;n. El elemento <literal>key</"
-"literal> define el nombre de la columna clave for&#x00e1;nea en la tabla de "
-"colecci&#x00f3;n. El atributo <literal>column</literal> en el elemento "
-"<literal>element</literal> define el nombre de columna donde realmente "
-"ser&#x00e1;n almacenados los valores <literal>String</literal>."
+"La diferencia comparado con el mapeo anterior es el uso de la parte "
+"<literal>element</literal>, que le dice a Hibernate que la colección no "
+"contiene referencias a otra entidad, sino que es una colección de elementos "
+"que son tipos de valores, aquí especificamente de tipo <literal>String</"
+"literal>. El nombre en minúsculas le dice que es un tipo/conversor de mapeo "
+"de Hibernate. Una vez más, el atributo <literal>table</literal> del elemento "
+"<literal>set</literal> determina el nombre de la tabla para la colección. El "
+"elemento <literal>key</literal> define el nombre de la columna clave foránea "
+"en la tabla de colección. El atributo <literal>column</literal> en el "
+"elemento <literal>element</literal> define el nombre de la columna donde "
+"realmente se almacenarán los valores de la dirección de correo electrónico."
 
 #. Tag: para
-#: tutorial.xml:844
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is the updated schema:"
-msgstr "Echa una mirada al esquema actualizado:"
+msgstr "Este es el esquema actualizado:"
 
-#. Tag: programlisting
-#: tutorial.xml:848
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"  _____________        __________________\n"
-" |             |      |                  |       _____________\n"
-" |   EVENTS    |      |   PERSON_EVENT   |      |             |       "
-"___________________\n"
-" |_____________|      |__________________|      |    PERSON   |      "
-"|                   |\n"
-" |             |      |                  |      |_____________|      | "
-"PERSON_EMAIL_ADDR |\n"
-" | *EVENT_ID   | <--> | *EVENT_ID        |      |             |      |"
-"___________________|\n"
-" |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  | <--> |  "
-"*PERSON_ID       |\n"
-" |  TITLE      |      |__________________|      |  AGE        |      |  "
-"*EMAIL_ADDR      |\n"
-" |_____________|                                |  FIRSTNAME  |      |"
-"___________________|\n"
-"                                                |  LASTNAME   |\n"
-"                                                |_____________|\n"
-" ]]>"
-msgstr ""
-"<![CDATA[\n"
-"  _____________        __________________\n"
-" |             |      |                  |       _____________\n"
-" |   EVENTS    |      |   PERSON_EVENT   |      |             |       "
-"___________________\n"
-" |_____________|      |__________________|      |    PERSON   |      "
-"|                   |\n"
-" |             |      |                  |      |_____________|      | "
-"PERSON_EMAIL_ADDR |\n"
-" | *EVENT_ID   | <--> | *EVENT_ID        |      |             |      |"
-"___________________|\n"
-" |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  | <--> |  "
-"*PERSON_ID       |\n"
-" |  TITLE      |      |__________________|      |  AGE        |      |  "
-"*EMAIL_ADDR      |\n"
-" |_____________|                                |  FIRSTNAME  |      |"
-"___________________|\n"
-"                                                |  LASTNAME   |\n"
-"                                                |_____________|\n"
-" ]]>"
-
-#. Tag: para
-#: tutorial.xml:850
-#, fuzzy, no-c-format
-msgid ""
 "You can see that the primary key of the collection table is in fact a "
 "composite key that uses both columns. This also implies that there cannot be "
 "duplicate email addresses per person, which is exactly the semantics we need "
 "for a set in Java."
 msgstr ""
-"Puedes ver que la clave primaria de la tabla de colecci&#x00f3;n es de hecho "
-"una clave compuesta, usando ambas columnas. Esto implica tambi&#x00e9;n que "
-"no pueden haber direcciones de email duplicadas por persona, que es "
-"exactamente la sem&#x00e1;ntica que necesitamos para un conjunto en Java."
+"Puede ver que la clave principal de la tabla de colección es, de hecho, una "
+"clave compuesta que utiliza ambas columnas. Esto también implica que no "
+"pueden haber direcciones de correo electrónico duplicadas por persona, la "
+"cual es exactamente la semántica que necesitamos para un conjunto en Java."
 
 #. Tag: para
-#: tutorial.xml:856
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can now try to add elements to this collection, just like we did before "
 "by linking persons and events. It is the same code in Java:"
 msgstr ""
-"<![CDATA[private void addEmailToPerson(Long personId, String emailAddress) "
-"{\n"
-"                                             \n"
-"                                             Session session = HibernateUtil."
-"getSessionFactory().getCurrentSession();\n"
-"                                             session.beginTransaction();\n"
-"                                             \n"
-"                                             Person aPerson = (Person) "
-"session.load(Person.class, personId);\n"
-"                                             \n"
-"                                             // The getEmailAddresses() "
-"might trigger a lazy load of the collection\n"
-"                                             aPerson.getEmailAddresses().add"
-"(emailAddress);\n"
-"                                             \n"
-"                                             session.getTransaction().commit"
-"();\n"
-"}]]>"
+"Ahora, puede tratar de agregar elementos a esta colección, al igual que lo "
+"hicimos antes vinculando personas y eventos. Es el mismo código en Java."
 
-#. Tag: programlisting
-#: tutorial.xml:861
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[    private void addEmailToPerson(Long personId, String "
-"emailAddress) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session.load(Person.class, personId);\n"
-"        // adding to the emailAddress collection might trigger a lazy load "
-"of the collection\n"
-"        aPerson.getEmailAddresses().add(emailAddress);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-"Puedes ahora intentar y agregar elementos a esta colecci&#x00f3;n, al igual "
-"que hicimos antes enlazando personas y eventos. Es el mismo c&#x00f3;digo en "
-"Java."
-
 #. Tag: para
-#: tutorial.xml:863
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This time we did not use a <emphasis>fetch</emphasis> query to initialize "
 "the collection. Monitor the SQL log and try to optimize this with an eager "
 "fetch."
 msgstr ""
-"This time we didnt' use a <emphasis>fetch</emphasis> query to initialize the "
-"collection. Hence, the call to its getter method will trigger an additional "
-"select to initialize it, so we can add an element to it. Monitor the SQL log "
-"and try to optimize this with an eager fetch."
+"Esta vez no utilizamos una petición de <emphasis>búqueda - fetch -</"
+"emphasis> para dar inicio a la colección. Monitoree su registro SQL e "
+"intente de optimizar esto con una recuperación temprana."
 
 #. Tag: title
-#: tutorial.xml:872
 #, no-c-format
 msgid "Bi-directional associations"
 msgstr "Asociaciones bidireccionales"
 
 #. Tag: para
-#: tutorial.xml:874
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next you will map a bi-directional association. You will make the "
 "association between person and event work from both sides in Java. The "
 "database schema does not change, so you will still have many-to-many "
 "multiplicity."
 msgstr ""
-"A continuacion vamos a mapear una asociaci&#x00f3;n bidireccional, haciendo "
-"que la asociaci&#x00f3;n entre persona y evento funcione desde ambos lados "
-"en Java. Por supuesto, el esquema de base de datos no cambia; todav&#x00ed;a "
-"necesitamos multiplicidad muchos-a-muchos. Una base de datos relacional es "
-"m&#x00e1;s flexible que un lenguaje de programaci&#x00f3;n de red, "
-"as&#x00ed; que no necesita nada parecido a una direcci&#x00f3;n de "
-"navegaci&#x00f3;n; los datos pueden ser vistos y recuperados en cualquier "
-"forma posible."
+"A continuacion vamos a mapear una asociación bidireccional. Vamos a hacer "
+"que la asociación entre persona y evento funcione desde ambos lados en Java. "
+"El esquema de la base de datos no cambia así que todavía tendremos una "
+"multiplicidad muchos-a-muchos."
 
 #. Tag: para
-#: tutorial.xml:882
 #, no-c-format
 msgid ""
 "A relational database is more flexible than a network programming language, "
 "in that it does not need a navigation direction; data can be viewed and "
 "retrieved in any possible way."
 msgstr ""
+"Una base de datos relacional es más flexible que un lenguaje de programación "
+"de red ya que no necesita una dirección de navegación; los datos se pueden "
+"ver y recuperar de cualquier forma posible."
 
 #. Tag: para
-#: tutorial.xml:890
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, add a collection of participants to the <literal>Event</literal> "
 "class:"
 msgstr ""
-"Primero agrega una colecci&#x00f3;n de participantes a la clase de eventos "
-"<literal>Event</literal>:"
+"Primero, agregue una colección de participantes a la clase <literal>Event</"
+"literal>:"
 
-#. Tag: programlisting
-#: tutorial.xml:895
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[    private Set participants = new HashSet();\n"
-"\n"
-"    public Set getParticipants() {\n"
-"        return participants;\n"
-"    }\n"
-"\n"
-"    public void setParticipants(Set participants) {\n"
-"        this.participants = participants;\n"
-"    }]]>"
-msgstr ""
-"<![CDATA[private Set participants = new HashSet();\n"
-"\n"
-"public Set getParticipants() {\n"
-"    return participants;\n"
-"}\n"
-"\n"
-"public void setParticipants(Set participants) {\n"
-"    this.participants = participants;\n"
-"}]]>"
-
 #. Tag: para
-#: tutorial.xml:897
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now map this side of the association in <literal>Event.hbm.xml</literal>."
 msgstr ""
-"Ahora mapea este lado de la asociaci&#x00f3;n tambi&#x00e9;n, en "
-"<literal>Event.hbm.xml</literal>."
+"Ahora mapee este lado de la asociación en <literal>Event.hbm.xml</literal>."
 
-#. Tag: programlisting
-#: tutorial.xml:901
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[        <set name=\"participants\" table=\"PERSON_EVENT\" inverse="
-"\"true\">\n"
-"            <key column=\"EVENT_ID\"/>\n"
-"            <many-to-many column=\"PERSON_ID\" class=\"events.Person\"/>\n"
-"        </set>]]>"
-msgstr ""
-"<![CDATA[<set name=\"participants\" table=\"PERSON_EVENT\" inverse=\"true"
-"\">\n"
-"    <key column=\"EVENT_ID\"/>\n"
-"    <many-to-many column=\"PERSON_ID\" class=\"Person\"/>\n"
-"</set>]]>"
-
 #. Tag: para
-#: tutorial.xml:903
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These are normal <literal>set</literal> mappings in both mapping documents. "
 "Notice that the column names in <literal>key</literal> and <literal>many-to-"
@@ -2362,37 +1422,33 @@
 "<literal>set</literal> element of the <literal>Event</literal>'s collection "
 "mapping."
 msgstr ""
-"Como ves, estos son mapeos normales de <literal>set</literal> en ambos "
-"documentos de mapeo. Nota que los nombres de columnas en <literal>key</"
-"literal> y <literal>many-to-many</literal> fueron permutados en ambos "
-"documentos de mapeo. Aqu&#x00ed; la adici&#x00f3;n m&#x00e1;s importante es "
-"el atributo <literal>inverse=\"true\"</literal> en el elemento <literal>set</"
-"literal> del mapeo de colecci&#x00f3;n de <literal>Event</literal>."
+"Estos son mapeos normales de <literal>set</literal> en ambos documentos de "
+"mapeo. Note que los nombres de las columnas en <literal>key</literal> y "
+"<literal>many-to-many</literal> se intercambiaron en ambos documentos de "
+"mapeo. La adición más importante aquí es el atributo <literal>inverse=\"true"
+"\"</literal> en el elemento <literal>set</literal> del mapeo de colección de "
+"<literal>Event</literal>."
 
 #. Tag: para
-#: tutorial.xml:911
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What this means is that Hibernate should take the other side, the "
 "<literal>Person</literal> class, when it needs to find out information about "
 "the link between the two. This will be a lot easier to understand once you "
 "see how the bi-directional link between our two entities is created."
 msgstr ""
-"Lo que esto significa es que Hibernate debe tomar el otro lado - la clase "
-"<literal>Person</literal> - cuando necesite descubrir informaci&#x00f3;n "
-"sobre el enlace entre las dos. Esto ser&#x00e1; mucho m&#x00e1;s f&#x00e1;"
-"cil de entender una vez que veas c&#x00f3;mo se crea el enlace bidireccional "
-"entre nuestras dos entidades."
+"Esto significa que Hibernate debe tomar el otro lado, la clase "
+"<literal>Person</literal>, cuando necesite encontrar información sobre el "
+"enlace entre las dos. Esto será mucho más fácil de entender una vez que vea "
+"como se crea el enlace bidireccional entre nuestras dos entidades."
 
 #. Tag: title
-#: tutorial.xml:920
 #, no-c-format
 msgid "Working bi-directional links"
-msgstr "Trabajando enlaces bidireccionales"
+msgstr "Trabajo con enlaces bidireccionales"
 
 #. Tag: para
-#: tutorial.xml:922
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, keep in mind that Hibernate does not affect normal Java semantics. "
 "How did we create a link between a <literal>Person</literal> and an "
@@ -2404,86 +1460,41 @@
 "literal>. This process of \"setting the link on both sides\" is absolutely "
 "necessary with bi-directional links."
 msgstr ""
-"Primero, ten en mente que Hhibernate no afecta la sem&#x00e1;ntica normal de "
-"Java. ¿C&#x00f3;mo hemos creado un enlace entre una <literal>Person</"
-"literal> y un <literal>Event</literal> en el ejemplo unidireccional? Hemos "
-"agregado una instancia de <literal>Event</literal> a la colecci&#x00f3;n de "
-"referencias de eventos de una instancia de <literal>Person</literal>. De "
-"modo que, obviamente, si queremos que este enlace funcione "
-"bidireccionalmente, tenemos que hacer lo mismo del otro lado, agregando una "
-"referencia a <literal>Person</literal> a la colecci&#x00f3;n en un "
-"<literal>Event</literal>. Este \"establecer el enlace a ambos lados\" es "
-"absolutamente necesario y nunca debes olvidar hacerlo."
+"Primero, recuerde que Hibernate no afecta la semántica normal de Java. ¿Cómo "
+"creamos un enlace entre <literal>Person</literal> y un <literal>Event</"
+"literal> en el ejemplo unidireccional? Agregue una instancia de "
+"<literal>Event</literal> a la colección de referencias de eventos de una "
+"instancia de <literal>Person</literal>. Si quiere que este enlace funcione "
+"bidireccionalmente, tiene que hacer lo mismo del otro lado, añadiendo una "
+"referencia <literal>Person</literal> a la colección en un <literal>Event</"
+"literal>. Este proceso de \"establecer el enlace en ambos lados\" es "
+"absolutamente necesario con enlaces bidireccionales."
 
 #. Tag: para
-#: tutorial.xml:932
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Many developers program defensively and create link management methods to "
 "correctly set both sides (for example, in <literal>Person</literal>):"
 msgstr ""
-"Muchos desarrolladores programan a la defensiva y crean m&#x00e9;todos de "
-"manejo de un enlace para establecer correctamente ambos lados, por ejemplo "
-"en <literal>Person</literal>:"
+"Muchos desarrolladores programan a la defensiva y crean métodos de "
+"administración de enlaces para establecer correctamente ambos lados, (por "
+"ejemplo, en <literal>Person</literal>):"
 
-#. Tag: programlisting
-#: tutorial.xml:937
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[    protected Set getEvents() {\n"
-"        return events;\n"
-"    }\n"
-"\n"
-"    protected void setEvents(Set events) {\n"
-"        this.events = events;\n"
-"    }\n"
-"\n"
-"    public void addToEvent(Event event) {\n"
-"        this.getEvents().add(event);\n"
-"        event.getParticipants().add(this);\n"
-"    }\n"
-"\n"
-"    public void removeFromEvent(Event event) {\n"
-"        this.getEvents().remove(event);\n"
-"        event.getParticipants().remove(this);\n"
-"    }]]>"
-msgstr ""
-"<![CDATA[protected Set getEvents() {\n"
-"    return events;\n"
-"}\n"
-"\n"
-"protected void setEvents(Set events) {\n"
-"    this.events = events;\n"
-"}\n"
-"\n"
-"public void addToEvent(Event event) {\n"
-"    this.getEvents().add(event);\n"
-"    event.getParticipants().add(this);\n"
-"}\n"
-"\n"
-"public void removeFromEvent(Event event) {\n"
-"    this.getEvents().remove(event);\n"
-"    event.getParticipants().remove(this);\n"
-"}]]>"
-
 #. Tag: para
-#: tutorial.xml:939
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The get and set methods for the collection are now protected. This allows "
 "classes in the same package and subclasses to still access the methods, but "
 "prevents everybody else from altering the collections directly. Repeat the "
 "steps for the collection on the other side."
 msgstr ""
-"Nota que los m&#x00e9;todos get y set para esta colecci&#x00f3;n son ahora "
-"protegidos. Esto le permite a clases en el mismo paquete y a subclases "
-"acceder a&#x00fa;n a los m&#x00e9;todos, pero previene a cualquier otro de "
-"ensuciarse con la colecci&#x00f3;n directamente (bueno, casi). Probablemente "
-"debas hacer lo mismo con la colecci&#x00f3;n al otro lado."
+"Los métodos get y set para la colección ahora se encuentran protegidos. Esto "
+"le permite a las clases en el mismo paquete y a las subclases acceder aún a "
+"los métodos, pero impide a cualquier otro que desordene las colecciones "
+"directamente. Repita los pasos para la colección del otro lado."
 
 #. Tag: para
-#: tutorial.xml:946
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What about the <literal>inverse</literal> mapping attribute? For you, and "
 "for Java, a bi-directional link is simply a matter of setting the references "
@@ -2498,32 +1509,27 @@
 "as <literal>inverse</literal>. In a one-to-many association it has to be the "
 "many-side, and in many-to-many association you can select either side."
 msgstr ""
-"Y ¿qu&#x00e9; del atributo de mapeo <literal>inverse</literal>? Para ti, y "
-"para Java, un enlace bidireccional es simplemente cuesti&#x00f3;n de "
-"establecer correctamente las referencias a ambos lados. Hibernate, sin "
-"embargo, no tiene suficiente informaci&#x00f3;n para arreglar correctamente "
-"sentencias <literal>INSERT</literal> y <literal>UPDATE</literal> de SQL "
-"(para evitar violaci&#x00f3;n de restricciones), y necesita alguna ayuda "
-"para manejar asociaciones bidireccionales apropiadamente. El hacer un lado "
-"de la asociaci&#x00f3;n <literal>inverse</literal> le dice a Hibernate que "
-"basicamente lo ignore, que lo considere un <emphasis>espejo</emphasis> del "
-"otro lado. Esto es todo lo necesario para que Hibernate resuelva todas las "
-"incidencias al transformar un modelo de navegaci&#x00f3;n direccional a un "
-"esquema SQL de base de datos. Las reglas que tienes que recordar son "
-"directas: Todas las asociaciones bidireccionales necesitan uno de los lados "
-"como <literal>inverse</literal>. En una asociaci&#x00f3;n uno-a-muchos debe "
-"ser el lado-de-muchos. En una asociaci&#x00f3;n muchos-a-muchos, puedes "
-"tomar cualquier lado, no hay diferencia."
+"¿Y el atributo de mapeo <literal>inverse</literal>? Para usted y para Java, "
+"un enlace bidireccional es simplemente cuestión de establecer correctamente "
+"las referencias en ambos lados. Sin embargo, Hibernate no tiene suficiente "
+"información para organizar correctamente declaraciones <literal>INSERT</"
+"literal> y <literal>UPDATE</literal> de SQL (para evitar violaciones de "
+"restricciones). El hacer un lado de la asociación <literal>inverse</literal> "
+"le dice a Hibernate que lo considere un <emphasis>espejo</emphasis> del otro "
+"lado. Eso es todo lo necesario para que Hibernate resuelva todos los asuntos "
+"que surgen al transformar un modelo de navegación direccional a un esquema "
+"de base de datos SQL. Las reglas son muy simples: todas las asociaciones "
+"bidireccionales necesitan que uno de los lados sea <literal>inverse</"
+"literal>. En una asociación uno-a-muchos debe ser el lado-de-muchos; y en "
+"una asociación muchos-a-muchos, puede escoger cualquier lado."
 
 #. Tag: title
-#: tutorial.xml:962
 #, no-c-format
 msgid "Part 3 - The EventManager web application"
-msgstr "Part 3 - The EventManager web application"
+msgstr "Part 3 - La aplicación web EventManager"
 
 #. Tag: para
-#: tutorial.xml:964
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A Hibernate web application uses <literal>Session</literal> and "
 "<literal>Transaction</literal> almost like a standalone application. "
@@ -2531,119 +1537,40 @@
 "<literal>EventManagerServlet</literal>. This servlet can list all events "
 "stored in the database, and it provides an HTML form to enter new events."
 msgstr ""
-"A Hibernate web application uses <literal>Session</literal> and "
-"<literal>Transaction</literal> almost like a standalone application. "
-"However, some common patterns are useful. We now write an "
-"<literal>EventManagerServlet</literal>. This servlet can list all events "
-"stored in the database, and it provides an HTML form to enter new events."
+"Una aplicación web de Hibernate utiliza <literal>Session</literal> y "
+"<literal>Transaction</literal> casi como una aplicación autónoma. Sin "
+"embargo, algunos patrones comunes son útiles. Ahora puede escribir un "
+"<literal>EventManagerServlet</literal>. Este servlet puede enumerar todos "
+"los eventos almacenados en la base de datos y proporciona una forma HTML "
+"para ingresar eventos nuevos."
 
 #. Tag: title
-#: tutorial.xml:972
 #, no-c-format
 msgid "Writing the basic servlet"
-msgstr "Writing the basic servlet"
+msgstr "Escritura de un servlet básico"
 
 #. Tag: para
-#: tutorial.xml:974
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First we need create our basic processing servlet. Since our servlet only "
 "handles HTTP <literal>GET</literal> requests, we will only implement the "
 "<literal>doGet()</literal> method:"
 msgstr ""
-"The servlet handles HTTP <literal>GET</literal> requests only, hence, the "
-"method we implement is <literal>doGet()</literal>:"
+"Primero necesitamos crear nuestro servlet de procesamiento básico. Ya que "
+"nuestro servlet solo maneja pedidos <literal>GET</literal> HTTP sólamente, "
+"solo implementaremos el método <literal>doGet()</literal>:"
 
-#. Tag: programlisting
-#: tutorial.xml:980
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.web;\n"
-"\n"
-"// Imports\n"
-"\n"
-"public class EventManagerServlet extends HttpServlet {\n"
-"\n"
-"    protected void doGet(\n"
-"            HttpServletRequest request,\n"
-"            HttpServletResponse response) throws ServletException, "
-"IOException {\n"
-"\n"
-"        SimpleDateFormat dateFormatter = new SimpleDateFormat( \"dd.MM.yyyy"
-"\" );\n"
-"\n"
-"        try {\n"
-"            // Begin unit of work\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"beginTransaction();\n"
-"\n"
-"            // Process request and render page...\n"
-"\n"
-"            // End unit of work\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"getTransaction().commit();\n"
-"        }\n"
-"        catch (Exception ex) {\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"getTransaction().rollback();\n"
-"            if ( ServletException.class.isInstance( ex ) ) {\n"
-"                throw ( ServletException ) ex;\n"
-"            }\n"
-"            else {\n"
-"                throw new ServletException( ex );\n"
-"            }\n"
-"        }\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-"<![CDATA[protected void doGet(HttpServletRequest request,\n"
-"                                                   HttpServletResponse "
-"response)\n"
-"                                                   throws ServletException, "
-"IOException {\n"
-"                                                   \n"
-"                                                   SimpleDateFormat "
-"dateFormatter = new SimpleDateFormat(\"dd.MM.yyyy\");\n"
-"                                                   \n"
-"                                                   try {\n"
-"                                                   // Begin unit of work\n"
-"                                                   HibernateUtil."
-"getSessionFactory()\n"
-"                                                   .getCurrentSession()."
-"beginTransaction();\n"
-"                                                   \n"
-"                                                   // Process request and "
-"render page...\n"
-"                                                   \n"
-"                                                   // End unit of work\n"
-"                                                   HibernateUtil."
-"getSessionFactory()\n"
-"                                                   .getCurrentSession()."
-"getTransaction().commit();\n"
-"                                                   \n"
-"                                                   } catch (Exception ex) {\n"
-"                                                   HibernateUtil."
-"getSessionFactory()\n"
-"                                                   .getCurrentSession()."
-"getTransaction().rollback();\n"
-"                                                   throw new ServletException"
-"(ex);\n"
-"                                                   }\n"
-"                                                   \n"
-"                                                   }]]>"
-
 #. Tag: para
-#: tutorial.xml:982
 #, no-c-format
 msgid ""
 "Save this servlet as <filename>src/main/java/org/hibernate/tutorial/web/"
 "EventManagerServlet.java</filename>"
 msgstr ""
+"Guarde este servlet como <filename>src/main/java/org/hibernate/tutorial/web/"
+"EventManagerServlet.java</filename>"
 
 #. Tag: para
-#: tutorial.xml:987
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The pattern applied here is called <emphasis>session-per-request</emphasis>. "
 "When a request hits the servlet, a new Hibernate <literal>Session</literal> "
@@ -2652,16 +1579,16 @@
 "started. All data access occurs inside a transaction irrespective of whether "
 "the data is read or written. Do not use the auto-commit mode in applications."
 msgstr ""
-"The pattern we are applying here is called <emphasis>session-per-request</"
-"emphasis>. When a request hits the servlet, a new Hibernate "
-"<literal>Session</literal> is opened through the first call to "
-"<literal>getCurrentSession()</literal> on the <literal>SessionFactory</"
-"literal>. Then a database transaction is started&mdash;all data access as to "
-"occur inside a transaction, no matter if data is read or written (we don't "
-"use the auto-commit mode in applications)."
+"El patrón aplicado aquí se llama <emphasis>sesión-por-petición</emphasis>. "
+"Cuando una petición llega al servlet, se abre una nueva <literal>Session</"
+"literal> de Hibernate por medio de la primera llamada a "
+"<literal>getCurrentSession()</literal> en el <literal>SessionFactory</"
+"literal>. Entonces se inicia una transacción de la base de datos. Todo "
+"acceso a los datos tiene que suceder dentro de una transacción, sin importar "
+"que los datos sean leídos o escritos . No utilice el modo auto-commit en las "
+"aplicaciones."
 
 #. Tag: para
-#: tutorial.xml:996
 #, no-c-format
 msgid ""
 "Do <emphasis>not</emphasis> use a new Hibernate <literal>Session</literal> "
@@ -2669,24 +1596,23 @@
 "that is scoped to the whole request. Use <literal>getCurrentSession()</"
 "literal>, so that it is automatically bound to the current Java thread."
 msgstr ""
-"Do <emphasis>not</emphasis> use a new Hibernate <literal>Session</literal> "
-"for every database operation. Use one Hibernate <literal>Session</literal> "
-"that is scoped to the whole request. Use <literal>getCurrentSession()</"
-"literal>, so that it is automatically bound to the current Java thread."
+"<emphasis>No</emphasis> utilice una nueva <literal>Session</literal> de "
+"Hibernate para cada operación de base de datos. Utilice una "
+"<literal>Session</literal> Hibernate que cubra el campo de todo el pedido. "
+"Utilice <literal>getCurrentSession()</literal> para vincularlo "
+"automáticamente al hilo de Java actual."
 
 #. Tag: para
-#: tutorial.xml:1003
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next, the possible actions of the request are processed and the response "
 "HTML is rendered. We will get to that part soon."
 msgstr ""
-"Next, the possible actions of the request are processed and the response "
-"HTML is rendered. We'll get to that part soon."
+"Después, se procesan las acciones posibles del pedido y se entrega la "
+"respuesta HTML. Llegaremos a esa parte muy pronto. "
 
 #. Tag: para
-#: tutorial.xml:1008
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, the unit of work ends when processing and rendering are complete. "
 "If any problems occurred during processing or rendering, an exception will "
@@ -2697,109 +1623,32 @@
 "called <emphasis>Open Session in View</emphasis>. You will need it as soon "
 "as you consider rendering your view in JSP, not in a servlet."
 msgstr ""
-"Finally, the unit of work ends when processing and rendering is complete. If "
-"any problem occured during processing or rendering, an exception will be "
-"thrown and the database transaction rolled back. This completes the "
-"<literal>session-per-request</literal> pattern. Instead of the transaction "
-"demarcation code in every servlet you could also write a servlet filter. See "
-"the Hibernate website and Wiki for more information about this pattern, "
-"called <emphasis>Open Session in View</emphasis>&mdash;you'll need it as "
-"soon as you consider rendering your view in JSP, not in a servlet."
+"Finalmente, la unidad de trabajo termina cuando se completa el procesamiento "
+"y la entrega. Si surgió algún problema durante el procesamiento o la "
+"entrega , se presentará una excepción y la transacción de la base de datos "
+"se deshará. Esto completa el patrón <literal>session-per-request</literal>. "
+"En vez del código de demarcación de la transacción en todo servlet, también "
+"podría escribir un filtro de servlet. Véa el sitio web de Hibernate y el "
+"Wiki para obtener más información sobre este patrón llamado <emphasis>sesión "
+"abierta en vista</emphasis>. Lo necesitará tan pronto como considere "
+"representar su vista en JSP, no en un servlet."
 
 #. Tag: title
-#: tutorial.xml:1022
 #, no-c-format
 msgid "Processing and rendering"
-msgstr "Processing and rendering"
+msgstr "Procesamiento y entrega"
 
 #. Tag: para
-#: tutorial.xml:1024
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now you can implement the processing of the request and the rendering of the "
 "page."
 msgstr ""
-"Let's implement the processing of the request and rendering of the page."
+"Ahora puede implementar el procesamiento del pedido y la representación de "
+"la página."
 
-#. Tag: programlisting
-#: tutorial.xml:1028
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[        // Write HTML header\n"
-"        PrintWriter out = response.getWriter();\n"
-"        out.println(\"<html><head><title>Event Manager</title></head><body>"
-"\");\n"
-"\n"
-"        // Handle actions\n"
-"        if ( \"store\".equals(request.getParameter(\"action\")) ) {\n"
-"\n"
-"            String eventTitle = request.getParameter(\"eventTitle\");\n"
-"            String eventDate = request.getParameter(\"eventDate\");\n"
-"\n"
-"            if ( \"\".equals(eventTitle) || \"\".equals(eventDate) ) {\n"
-"                out.println(\"<b><i>Please enter event title and date.</i></"
-"b>\");\n"
-"            }\n"
-"            else {\n"
-"                createAndStoreEvent(eventTitle, dateFormatter.parse"
-"(eventDate));\n"
-"                out.println(\"<b><i>Added event.</i></b>\");\n"
-"            }\n"
-"        }\n"
-"\n"
-"        // Print page\n"
-"       printEventForm(out);\n"
-"       listEvents(out, dateFormatter);\n"
-"\n"
-"       // Write HTML footer\n"
-"       out.println(\"</body></html>\");\n"
-"       out.flush();\n"
-"       out.close();]]>"
-msgstr ""
-"<![CDATA[// Write HTML header\n"
-"                                            PrintWriter out = response."
-"getWriter();\n"
-"                                            out.println"
-"(\"<html><head><title>Event Manager</title></head><body>\");\n"
-"                                                            \n"
-"                                                            // Handle "
-"actions\n"
-"                                                            if ( \"store\"."
-"equals(request.getParameter(\"action\")) ) {\n"
-"                                                            \n"
-"                                                            String "
-"eventTitle = request.getParameter(\"eventTitle\");\n"
-"                                                            String eventDate "
-"= request.getParameter(\"eventDate\");\n"
-"                                                            \n"
-"                                                            if ( \"\".equals"
-"(eventTitle) || \"\".equals(eventDate) ) {\n"
-"                                                            out.println"
-"(\"<b><i>Please enter event title and date.</i></b>\");\n"
-"                                                            } else {\n"
-"                                                            createAndStoreEvent"
-"(eventTitle, dateFormatter.parse(eventDate));\n"
-"                                                            out.println"
-"(\"<b><i>Added event.</i></b>\");\n"
-"                                                            }\n"
-"                                                            }\n"
-"                                                            \n"
-"                                                            // Print page\n"
-"                                                            printEventForm"
-"(out);\n"
-"                                                            listEvents(out, "
-"dateFormatter);\n"
-"                                                            \n"
-"                                                            // Write HTML "
-"footer\n"
-"                                                            out.println(\"</"
-"body></html>\");\n"
-"                                            out.flush();\n"
-"                                            out.close();]]>"
-
 #. Tag: para
-#: tutorial.xml:1030
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This coding style, with a mix of Java and HTML, would not scale in a more "
 "complex application&mdash;keep in mind that we are only illustrating basic "
@@ -2808,167 +1657,37 @@
 "events in the database are printed. The first method is trivial and only "
 "outputs HTML:"
 msgstr ""
-"Granted, this coding style with a mix of Java and HTML would not scale in a "
-"more complex application&mdash;keep in mind that we are only illustrating "
-"basic Hibernate concepts in this tutorial. The code prints an HTML header "
-"and a footer. Inside this page, an HTML form for event entry and a list of "
-"all events in the database are printed. The first method is trivial and only "
-"outputs HTML:"
+"Dado que este estilo de codificación con una mezcla de Java y HTML no "
+"escalaría en una aplicación más compleja - tenga en cuenta que sólo estamos "
+"ilustrando los conceptos básicos de Hibernate en este tutorial. El código "
+"imprime una cabecera y un pie de página HTML. Dentro de esta página se "
+"imprime una forma HTML para entrada de eventos y se imprime una lista de "
+"todos los eventos en la base de datos. El primer método es trivial y su "
+"salida se realiza únicamente en HTML:"
 
-#. Tag: programlisting
-#: tutorial.xml:1039
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[    private void printEventForm(PrintWriter out) {\n"
-"        out.println(\"<h2>Add new event:</h2>\");\n"
-"        out.println(\"<form>\");\n"
-"        out.println(\"Title: <input name='eventTitle' length='50'/><br/>"
-"\");\n"
-"        out.println(\"Date (e.g. 24.12.2009): <input name='eventDate' "
-"length='10'/><br/>\");\n"
-"        out.println(\"<input type='submit' name='action' value='store'/>"
-"\");\n"
-"        out.println(\"</form>\");\n"
-"    }]]>"
-msgstr ""
-"<![CDATA[private void printEventForm(PrintWriter out) {\n"
-"                                                                     out."
-"println(\"<h2>Add new event:</h2>\");\n"
-"                                                                     out."
-"println(\"<form>\");\n"
-"                                                                             out."
-"println(\"Title: <input name='eventTitle' length='50'/><br/>\");\n"
-"                                                                             out."
-"println(\"Date (e.g. 24.12.2009): <input name='eventDate' length='10'/><br/>"
-"\");\n"
-"                                                                             out."
-"println(\"<input type='submit' name='action' value='store'/>\");\n"
-"                                                                             out."
-"println(\"</form>\");\n"
-"                                                                     }]]>"
-
 #. Tag: para
-#: tutorial.xml:1041
 #, no-c-format
 msgid ""
 "The <literal>listEvents()</literal> method uses the Hibernate "
 "<literal>Session</literal> bound to the current thread to execute a query:"
 msgstr ""
-"The <literal>listEvents()</literal> method uses the Hibernate "
-"<literal>Session</literal> bound to the current thread to execute a query:"
+"El método <literal>listEvents()</literal> utiliza Hibernate "
+"<literal>Session</literal> vinculado al hilo actual para ejecutar una "
+"petición:"
 
-#. Tag: programlisting
-#: tutorial.xml:1047
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[    private void listEvents(PrintWriter out, SimpleDateFormat "
-"dateFormatter) {\n"
-"\n"
-"        List result = HibernateUtil.getSessionFactory()\n"
-"                .getCurrentSession().createCriteria(Event.class).list();\n"
-"        if (result.size() > 0) {\n"
-"            out.println(\"<h2>Events in database:</h2>\");\n"
-"            out.println(\"<table border='1'>\");\n"
-"            out.println(\"<tr>\");\n"
-"            out.println(\"<th>Event title</th>\");\n"
-"            out.println(\"<th>Event date</th>\");\n"
-"            out.println(\"</tr>\");\n"
-"            Iterator it = result.iterator();\n"
-"            while (it.hasNext()) {\n"
-"                Event event = (Event) it.next();\n"
-"                out.println(\"<tr>\");\n"
-"                out.println(\"<td>\" + event.getTitle() + \"</td>\");\n"
-"                out.println(\"<td>\" + dateFormatter.format(event.getDate()) "
-"+ \"</td>\");\n"
-"                out.println(\"</tr>\");\n"
-"            }\n"
-"            out.println(\"</table>\");\n"
-"        }\n"
-"    }]]>"
-msgstr ""
-"<![CDATA[private void listEvents(PrintWriter out, SimpleDateFormat "
-"dateFormatter) {\n"
-"                                                                                \n"
-"                                                                                List "
-"result = HibernateUtil.getSessionFactory()\n"
-"                                                                                ."
-"getCurrentSession().createCriteria(Event.class).list();\n"
-"                                                                                if "
-"(result.size() > 0) {\n"
-"                                                                     out."
-"println(\"<h2>Events in database:</h2>\");\n"
-"                                                                     out."
-"println(\"<table border='1'>\");\n"
-"                                                                             out."
-"println(\"<tr>\");\n"
-"                                                                                out."
-"println(\"<th>Event title</th>\");\n"
-"                                                                                out."
-"println(\"<th>Event date</th>\");\n"
-"                                                                                out."
-"println(\"</tr>\");\n"
-"                                                                        for "
-"(Iterator it = result.iterator(); it.hasNext();) {\n"
-"                                                                        Event "
-"event = (Event) it.next();\n"
-"                                                                        out."
-"println(\"<tr>\");\n"
-"                                                                                out."
-"println(\"<td>\" + event.getTitle() + \"</td>\");\n"
-"                                                                                out."
-"println(\"<td>\" + dateFormatter.format(event.getDate()) + \"</td>\");\n"
-"                                                                                out."
-"println(\"</tr>\");\n"
-"                                                                        }\n"
-"                                                                        out."
-"println(\"</table>\");\n"
-"                                                                }\n"
-"                                                                }]]>"
-
 #. Tag: para
-#: tutorial.xml:1049
 #, no-c-format
 msgid ""
 "Finally, the <literal>store</literal> action is dispatched to the "
 "<literal>createAndStoreEvent()</literal> method, which also uses the "
 "<literal>Session</literal> of the current thread:"
 msgstr ""
-"Finally, the <literal>store</literal> action is dispatched to the "
-"<literal>createAndStoreEvent()</literal> method, which also uses the "
-"<literal>Session</literal> of the current thread:"
+"Finalmente, la acción <literal>store</literal> se despacha al método "
+"<literal>createAndStoreEvent()</literal>, el cual también utiliza la "
+"<literal>Session</literal> del hilo actual:"
 
-#. Tag: programlisting
-#: tutorial.xml:1055
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[    protected void createAndStoreEvent(String title, Date theDate) "
-"{\n"
-"        Event theEvent = new Event();\n"
-"        theEvent.setTitle(title);\n"
-"        theEvent.setDate(theDate);\n"
-"\n"
-"        HibernateUtil.getSessionFactory()\n"
-"                .getCurrentSession().save(theEvent);\n"
-"    }]]>"
-msgstr ""
-"<![CDATA[protected void createAndStoreEvent(String title, Date theDate) {\n"
-"                                                                                Event "
-"theEvent = new Event();\n"
-"                                                                                theEvent."
-"setTitle(title);\n"
-"                                                                                theEvent."
-"setDate(theDate);\n"
-"                                                                                \n"
-"                                                                                HibernateUtil."
-"getSessionFactory()\n"
-"                                                                                ."
-"getCurrentSession().save(theEvent);\n"
-"                                                                                }]]"
-">"
-
 #. Tag: para
-#: tutorial.xml:1057
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The servlet is now complete. A request to the servlet will be processed in a "
 "single <literal>Session</literal> and <literal>Transaction</literal>. As "
@@ -2979,106 +1698,55 @@
 "data access code into data access objects (the DAO pattern). See the "
 "Hibernate Wiki for more examples."
 msgstr ""
-"That's it, the servlet is complete. A request to the servlet will be "
-"processed in a single <literal>Session</literal> and <literal>Transaction</"
-"literal>. As earlier in the standalone application, Hibernate can "
-"automatically bind these ojects to the current thread of execution. This "
-"gives you the freedom to layer your code and access the "
-"<literal>SessionFactory</literal> in any way you like. Usually you'd use a "
-"more sophisticated design and move the data access code into data access "
-"objects (the DAO pattern). See the Hibernate Wiki for more examples."
+"El servlet se encuentra completo. Un pedido al servlet será procesado en una "
+"sola <literal>Session</literal> y <literal>Transaction</literal>. Como lo "
+"vimos antes en la aplicación autónoma, Hibernate puede enlazar "
+"automáticamente estos objetos al hilo actual de ejecución. Esto le da la "
+"libertad de utilizar capas en su código y acceder a la "
+"<literal>SessionFactory</literal> de cualquier manera que lo desee. "
+"Usualmente, usted utilizaría un diseño más sofisticado y movería el código "
+"de acceso de datos a los objetos de acceso de datos (el patrón DAO). "
+"Refiérase al Wiki de Hibernate para ver más ejemplos."
 
 #. Tag: title
-#: tutorial.xml:1071
 #, no-c-format
 msgid "Deploying and testing"
-msgstr "Deploying and testing"
+msgstr "Despliegue y prueba"
 
 #. Tag: para
-#: tutorial.xml:1073
 #, no-c-format
 msgid ""
 "To deploy this application for testing we must create a Web ARchive (WAR). "
 "First we must define the WAR descriptor as <filename>src/main/webapp/WEB-INF/"
 "web.xml</filename>"
 msgstr ""
+"Para implementar esta aplicación para prueba debemos crear una Web ARchive "
+"(WAR). Primero debemos definir el descriptor WAR como <filename>src/main/"
+"webapp/WEB-INF/web.xml</filename>"
 
-#. Tag: programlisting
-#: tutorial.xml:1079
-#, fuzzy, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
-"<web-app version=\"2.4\"\n"
-"    xmlns=\"http://java.sun.com/xml/ns/j2ee\"\n"
-"    xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
-"    xsi:schemaLocation=\"http://java.sun.com/xml/ns/j2ee http://java.sun.com/"
-"xml/ns/j2ee/web-app_2_4.xsd\">\n"
-"\n"
-"    <servlet>\n"
-"        <servlet-name>Event Manager</servlet-name>\n"
-"        <servlet-class>org.hibernate.tutorial.web.EventManagerServlet</"
-"servlet-class>\n"
-"    </servlet>\n"
-"\n"
-"    <servlet-mapping>\n"
-"        <servlet-name>Event Manager</servlet-name>\n"
-"        <url-pattern>/eventmanager</url-pattern>\n"
-"    </servlet-mapping>\n"
-"</web-app>]]>"
-msgstr ""
-"<![CDATA[<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
-"                                                        <web-app version="
-"\"2.4\"\n"
-"                                                                 xmlns="
-"\"http://java.sun.com/xml/ns/j2ee\"\n"
-"                                                                 xmlns:xsi="
-"\"http://www.w3.org/2001/XMLSchema-instance\"\n"
-"                                                                 xsi:"
-"schemaLocation=\"http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/"
-"j2ee/web-app_2_4.xsd\">\n"
-"                                                                \n"
-"                                                                <servlet>\n"
-"                                                                        <servlet-"
-"name>Event Manager</servlet-name>\n"
-"                                                                        <servlet-"
-"class>events.EventManagerServlet</servlet-class>\n"
-"                                                                </servlet>\n"
-"                                                                \n"
-"                                                                <servlet-"
-"mapping>\n"
-"                                                                        <servlet-"
-"name>Event Manager</servlet-name>\n"
-"                                                                        <url-"
-"pattern>/eventmanager</url-pattern>\n"
-"                                                                </servlet-"
-"mapping>\n"
-"                                                        </web-app>]]>"
-
 #. Tag: para
-#: tutorial.xml:1081
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To build and deploy call <literal>mvn package</literal> in your project "
 "directory and copy the <filename>hibernate-tutorial.war</filename> file into "
 "your Tomcat <filename>webapps</filename> directory."
 msgstr ""
-"To build and deploy call <literal>ant war</literal> in your project "
-"directory and copy the <literal>hibernate-tutorial.war</literal> file into "
-"your Tomcat <literal>webapp</literal> directory. If you don't have Tomcat "
-"installed, download it and follow the installation instructions. You don't "
-"have to change any Tomcat configuration to deploy this application though."
+"Para construir y desplegar llame a <literal>mvn package</literal> en su "
+"directorio de proyecto y copie el archivo <literal>hibernate-tutorial.war</"
+"literal> en su directorio <literal>webapp</literal> Tomcat. "
 
 #. Tag: para
-#: tutorial.xml:1088
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "If you do not have Tomcat installed, download it from <ulink url=\"http://"
-"tomcat.apache.org/\"></ulink> and follow the installation instructions. Our "
+"tomcat.apache.org/\" /> and follow the installation instructions. Our "
 "application requires no changes to the standard Tomcat configuration."
 msgstr ""
+"Si no tiene Tomcat instalado, descárguelo de <ulink url=\"http://tomcat."
+"apache.org/\" /> y siga las instrucciones de instalación. Nuestra aplicación "
+"no requiere cambios a la configuración estándar de Tomcat."
 
 #. Tag: para
-#: tutorial.xml:1096
 #, no-c-format
 msgid ""
 "Once deployed and Tomcat is running, access the application at "
@@ -3088,698 +1756,26 @@
 "<literal>HibernateUtil</literal> is called) and to get the detailed output "
 "if any exceptions occurs."
 msgstr ""
-"Once deployed and Tomcat is running, access the application at "
-"<literal>http://localhost:8080/hibernate-tutorial/eventmanager</literal>. "
-"Make sure you watch the Tomcat log to see Hibernate initialize when the "
-"first request hits your servlet (the static initializer in "
-"<literal>HibernateUtil</literal> is called) and to get the detailed output "
-"if any exceptions occurs."
+"Una vez que se encuentre desplegado y que Tomcat esté ejecutando, acceda la "
+"aplicación en <literal>http://localhost:8080/hibernate-tutorial/"
+"eventmanager</literal>. Asegúrese de ver el registro de Tomcat para ver a "
+"Hibernate iniciar cuando llegue el primer pedido a su servlet (se llama al "
+"inicializador estático en <literal>HibernateUtil</literal>) y para obetener "
+"la salida detallada si ocurre alguna excepción."
 
 #. Tag: title
-#: tutorial.xml:1109
 #, no-c-format
 msgid "Summary"
-msgstr "Summary"
+msgstr "Resumen"
 
 #. Tag: para
-#: tutorial.xml:1111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This tutorial covered the basics of writing a simple standalone Hibernate "
 "application and a small web application. More tutorials are available from "
 "the Hibernate <ulink url=\"http://hibernate.org\">website</ulink>."
 msgstr ""
-"Este tutorial cubri&#x00f3; los fundamentos de escribir una simple "
-"aplicaci&#x00f3;n independiente de Hibernate."
-
-#~ msgid "Introduction to Hibernate"
-#~ msgstr "Introducci&#x00f3;n a Hibernate"
-
-#~ msgid "Preface"
-#~ msgstr "Prefacio"
-
-#~ msgid ""
-#~ "This chapter is an introductory tutorial for new users of Hibernate. We "
-#~ "start with a simple command line application using an in-memory database "
-#~ "and develop it in easy to understand steps."
-#~ msgstr ""
-#~ "Este cap&#x00ed;tulo es un tutorial introductorio de Hibernate. "
-#~ "Comenzamos con una aplicaci&#x00f3;n simple de l&#x00ed;nea de comandos "
-#~ "usando un base de datos en-memoria y desarroll&#x00e1;ndola en f&#x00e1;"
-#~ "cil para entender los pasos."
-
-#~ msgid ""
-#~ "This tutorial is intended for new users of Hibernate but requires Java "
-#~ "and SQL knowledge. It is based on a tutorial by Michael Gloegl, the third-"
-#~ "party libraries we name are for JDK 1.4 and 5.0. You might need others "
-#~ "for JDK 1.3."
-#~ msgstr ""
-#~ "Este tutorial est&#x00e1; concebido para usuarios nuevos de Hibernate "
-#~ "pero requiere conocimiento en Java y SQL. Est&#x00e1; basado en un "
-#~ "tutorial de Michael Gloegl. Las bibliotecas de terceros que mencionamos "
-#~ "son para JDK 1.4 y 5.0. Podr&#x00ed;as necesitar otras para JDK 1.3."
-
-#~ msgid ""
-#~ "The source code for the tutorial is included in the distribution in the "
-#~ "<literal>doc/reference/tutorial/</literal> directory."
-#~ msgstr ""
-#~ "UNTRANSLATED!!! The source code for the tutorial is included in the "
-#~ "distribution in the <literal>doc/reference/tutorial/</literal> directory."
-
-#~ msgid ""
-#~ "First, we'll create a simple console-based Hibernate application. We use "
-#~ "an Java database (HSQL DB), so we do not have to install any database "
-#~ "server."
-#~ msgstr ""
-#~ "Primero, crearemos una aplicaci&#x00f3;n simple de Hibenate basada en "
-#~ "consola. Usamos usamos una base de datos en-memoria (HSQL DB), de modo "
-#~ "que no necesitamos instalar ning&#x00fa;n servidor de base de datos."
-
-#~ msgid ""
-#~ "The first thing we do, is set up our development directory and put all "
-#~ "the Java libraries we need into it. Download the Hibernate distribution "
-#~ "from the Hibernate website. Extract the package and place all required "
-#~ "libraries found in <literal>/lib</literal> into into the <literal>/lib</"
-#~ "literal> directory of your new development working directory. It should "
-#~ "look like this:"
-#~ msgstr ""
-#~ "La primera cosa que hacemos, es armar nuestro directorio de desarrollo y "
-#~ "poner en &#x00e9;l todas las bibliotecas Java que necesitamos. Descarga "
-#~ "la distribuci&#x00f3;n de Hibernate del sitio web de Hibernate. Extrae el "
-#~ "paquete y coloca todas las bibliotecas requeridas encontradas en "
-#~ "<literal>/lib</literal> dentro del directorio <literal>/lib</literal> de "
-#~ "nuestro nuevo directorio de desarrollo de trabajo. Debe asemejarse a esto:"
-
-#~ msgid ""
-#~ "<![CDATA[.\n"
-#~ "+lib\n"
-#~ "  antlr.jar\n"
-#~ "  cglib.jar\n"
-#~ "  asm.jar\n"
-#~ "  asm-attrs.jars\n"
-#~ "  commons-collections.jar\n"
-#~ "  commons-logging.jar\n"
-#~ "  hibernate3.jar\n"
-#~ "  jta.jar\n"
-#~ "  dom4j.jar\n"
-#~ "  log4j.jar ]]>"
-#~ msgstr ""
-#~ "<![CDATA[.\n"
-#~ "+lib\n"
-#~ "  antlr.jar\n"
-#~ "  cglib-full.jar\n"
-#~ "  asm.jar\n"
-#~ "  asm-attrs.jars\n"
-#~ "  commons-collections.jar\n"
-#~ "  commons-logging.jar\n"
-#~ "  ehcache.jar\n"
-#~ "  hibernate3.jar\n"
-#~ "  jta.jar\n"
-#~ "  dom4j.jar\n"
-#~ "  log4j.jar ]]>"
-
-#~ msgid ""
-#~ "This is the minimum set of required libraries (note that we also copied "
-#~ "hibernate3.jar, the main archive) for Hibernate <emphasis>at the time of "
-#~ "writing</emphasis>. The Hibernate release you are using might require "
-#~ "more or less libraries. See the <literal>README.txt</literal> file in the "
-#~ "<literal>lib/</literal> directory of the Hibernate distribution for more "
-#~ "information about required and optional third-party libraries. (Actually, "
-#~ "Log4j is not required but preferred by many developers.)"
-#~ msgstr ""
-#~ "Este es el conjunto m&#x00ed;nimo de bibliotecas requeridas para "
-#~ "Hibernate (observa que tambi&#x00e9;n hemos copiado hibernate3.jar, el "
-#~ "fichero principal). Ver el fichero <literal>README.txt</literal> en el "
-#~ "directorio <literal>lib/</literal> de la distribuci&#x00f3;n de Hibernate "
-#~ "para m&#x00e1;s informaci&#x00f3;n sobre bibliotecas de terceros "
-#~ "requeridas y opcionales. (Realmente, Log4J no es requerida aunque "
-#~ "preferida por muchos desarrolladores)."
-
-#~ msgid ""
-#~ "Our first persistent class is a simple JavaBean class with some "
-#~ "properties:"
-#~ msgstr ""
-#~ "Nuestra primera clase persistente es un JavaBean simple con algunas "
-#~ "propiedades:"
-
-#~ msgid ""
-#~ "Place this Java source file in a directory called <literal>src</literal> "
-#~ "in the development folder, and in its correct package. The directory "
-#~ "should now look like this:"
-#~ msgstr ""
-#~ "Coloca este fichero de c&#x00f3;digo Java en un directorio llamado "
-#~ "<literal>src</literal> en la carpeta de desarrollo. El directorio ahora "
-#~ "debe verse como esto:"
-
-#~ msgid ""
-#~ "<![CDATA[.\n"
-#~ "+lib\n"
-#~ "  <Hibernate and third-party libraries>\n"
-#~ "+src\n"
-#~ "  +events\n"
-#~ "    Event.java]]>"
-#~ msgstr ""
-#~ "<![CDATA[.\n"
-#~ "+lib\n"
-#~ "  <Hibernate and third-party libraries>\n"
-#~ "+src\n"
-#~ "  Event.java]]>"
-
-#~ msgid "In the next step, we tell Hibernate about this persistent class."
-#~ msgstr ""
-#~ "En el pr&#x00f3;ximo paso, le decimos a Hibernate sobre esta clase "
-#~ "persistente."
-
-#~ msgid ""
-#~ "The <literal>id</literal> element is the declaration of the identifer "
-#~ "property, <literal>name=\"id\"</literal> declares the name of the Java "
-#~ "property - Hibernate will use the getter and setter methods to access the "
-#~ "property. The column attribute tells Hibernate which column of the "
-#~ "<literal>EVENTS</literal> table we use for this primary key. The nested "
-#~ "<literal>generator</literal> element specifies the identifier generation "
-#~ "strategy, in this case we used <literal>native</literal>, which picks the "
-#~ "best strategy depending on the configured database (dialect). Hibernate "
-#~ "supports database generated, globally unique, as well as application "
-#~ "assigned identifiers (or any strategy you have written an extension for)."
-#~ msgstr ""
-#~ "El elemento <literal>id</literal> el la declaraci&#x00f3;n de la "
-#~ "propiedad identificadora, <literal>name=\"id\"</literal> declara el "
-#~ "nombre de la propiedad Java. Hibernate usar&#x00e1; los m&#x00e9;todos "
-#~ "getter y setter para acceder a la propiedad. El attributo de columna dice "
-#~ "a Hibernate cu&#x00e1;l columna de la tabla <literal>EVENTS</literal> "
-#~ "usamos para esta clave primaria. El elemento anidado <literal>generator</"
-#~ "literal> especifica la estrategia de generaci&#x00f3;n de "
-#~ "identificadores, en este caso usamos <literal>increment</literal>, que es "
-#~ "un m&#x00e9;todo muy simple de incremento de n&#x00fa;mero en-memoria "
-#~ "&#x00fa;til mayormente para testeo (y tutoriales). Hibernate tambi&#x0e9;"
-#~ "n soporta identificadores generados por base de datos, globalmente "
-#~ "&#x00fa;nicos, as&#x00ed; como tambi&#x00e9;n asignados por "
-#~ "aplicaci&#x00f3;n (o cualquier estrategia para la que hayas escrito una "
-#~ "extensi&#x00f3;n)."
-
-#~ msgid ""
-#~ "This mapping file should be saved as <literal>Event.hbm.xml</literal>, "
-#~ "right in the directory next to the <literal>Event</literal> Java class "
-#~ "source file. The naming of mapping files can be arbitrary, however the "
-#~ "<literal>hbm.xml</literal> suffix is a convention in the Hibernate "
-#~ "developer community. The directory structure should now look like this:"
-#~ msgstr ""
-#~ "Este fichero de mapeo debe ser salvado como <literal>Event.hbm.xml</"
-#~ "literal>, justo en el directorio pr&#x00f3;ximo al fichero de c&#x00f3;"
-#~ "digo fuente de la clase Java <literal>Event</literal>. El nombrado de los "
-#~ "ficheros de mapeo puede ser arbitrario, sin embargo, el sufijo "
-#~ "<literal>hbm.xml</literal> se ha vuelto una convenci&#x00f3;n el la "
-#~ "comunidad de desarrolladores de Hibernate. La estructura de directorio "
-#~ "debe ahora verse como esto:"
-
-#~ msgid ""
-#~ "<![CDATA[.\n"
-#~ "+lib\n"
-#~ "  <Hibernate and third-party libraries>\n"
-#~ "+src\n"
-#~ "  +events\n"
-#~ "    Event.java\n"
-#~ "    Event.hbm.xml]]>"
-#~ msgstr ""
-#~ "<![CDATA[.\n"
-#~ "+lib\n"
-#~ "  <Hibernate and third-party libraries>\n"
-#~ "+src\n"
-#~ "  Event.java\n"
-#~ "  Event.hbm.xml]]>"
-
-#~ msgid "We continue with the main configuration of Hibernate."
-#~ msgstr "Continuamos con la configuraci&#x00f3;n principal de Hibernate."
-
-#~ msgid ""
-#~ "We now have a persistent class and its mapping file in place. It is time "
-#~ "to configure Hibernate. Before we do this, we will need a database. HSQL "
-#~ "DB, a java-based SQL DBMS, can be downloaded from the HSQL DB website"
-#~ "(http://hsqldb.org/). Actually, you only need the <literal>hsqldb.jar</"
-#~ "literal> from this download. Place this file in the <literal>lib/</"
-#~ "literal> directory of the development folder."
-#~ msgstr ""
-#~ "Tenemos ahora una clase persistente y su fichero de mapeo en su sitio. Es "
-#~ "momento de configurar Hibernate. Antes que hagamos esto, necesitaremos "
-#~ "una base de datos. HSQL DB, un DBMS SQL en-memoria basado en Java, puede "
-#~ "ser descargado del sitio web de HSQL DB. Realmente, de esta descarga "
-#~ "s&#x00f3;lo necesitas el <literal>hsqldb.jar</literal>. Coloca este "
-#~ "fichero en el directorio <literal>lib/</literal> de la carpeta de "
-#~ "desarrollo."
-
-#~ msgid ""
-#~ "Hibernate is the layer in your application which connects to this "
-#~ "database, so it needs connection information. The connections are made "
-#~ "through a JDBC connection pool, which we also have to configure. The "
-#~ "Hibernate distribution contains several open source JDBC connection "
-#~ "pooling tools, but will use the Hibernate built-in connection pool for "
-#~ "this tutorial. Note that you have to copy the required library into your "
-#~ "classpath and use different connection pooling settings if you want to "
-#~ "use a production-quality third party JDBC pooling software."
-#~ msgstr ""
-#~ "Hibernate es la capa en tu aplicaci&#x00f3;n que se conecta a esta base "
-#~ "de datos, de modo que necesita informaci&#x00f3;n de conexi&#x00f3;n. Las "
-#~ "conexiones se hacen a trav&#x00e9;s de un pool de conexiones JDBC, que "
-#~ "tamb&#x00e9;n tenemos que configurar. La distribuci&#x00f3;n de Hibernate "
-#~ "contiene muchas herramientas de pooling de conexiones JDBC de c&#x00f3;"
-#~ "digo abierto, pero para este tutorial usaremos el pool de conexiones "
-#~ "prefabricado dentro de Hibernate. Observa que tienes que copiar la "
-#~ "biblioteca requerida en tu classpath y usar diferentes configuraciones de "
-#~ "pooling de conexiones si quieres usar un software de pooling JDBC de "
-#~ "terceros de calidad de producci&#x00f3;n."
-
-#~ msgid ""
-#~ "Copy this file into the source directory, so it will end up in the root "
-#~ "of the classpath. Hibernate automatically looks for a file called "
-#~ "<literal>hibernate.cfg.xml</literal> in the root of the classpath, on "
-#~ "startup."
-#~ msgstr ""
-#~ "Copia este fichero dentro del directorio de c&#x00f3;digo fuente, de modo "
-#~ "que termine ubicado en la rai&#x00ed;z del classpath. Hibernate busca "
-#~ "autom&#x00e1;ticamente un fichero llamado <literal>hibernate.cfg.xml</"
-#~ "literal> en la ra&#x00ed;z del classpath al arrancar."
-
-#~ msgid ""
-#~ "We'll now build the tutorial with Ant. You will need to have Ant "
-#~ "installed - get it from the <ulink url=\"http://ant.apache.org/"
-#~ "bindownload.cgi\">Ant download page</ulink>. How to install Ant will not "
-#~ "be covered here. Please refer to the <ulink url=\"http://ant.apache.org/"
-#~ "manual/index.html\">Ant manual</ulink>. After you have installed Ant, we "
-#~ "can start to create the buildfile. It will be called <literal>build.xml</"
-#~ "literal> and placed directly in the development directory."
-#~ msgstr ""
-#~ "Construiremos ahora el tutorial con Ant. Necesitar&#x00e1;s tener Ant "
-#~ "instalado. Obt&#x00e9;nlo de <ulink url=\"http://ant.apache.org/"
-#~ "bindownload.cgi\">P&#x00e1;gina de descarga de Ant</ulink>. No se "
-#~ "cubrir&#x00e1; aqu&#x00ed; c&#x00f3;mo instalar Ant. Por favor "
-#~ "refi&#x00e9;rete al <ulink url=\"http://ant.apache.org/manual/index.html"
-#~ "\"> Manual de Ant</ulink>. Despu&#x00e9;s que hayas instalado Ant, "
-#~ "podemos comenzar a crear el buildfile. Ser&#x00e1; llamado <literal>build."
-#~ "xml</literal> y colocado directamente en el directorio de desarrollo."
-
-#~ msgid "A basic build file looks like this:"
-#~ msgstr "Reparar Ant"
-
-#~ msgid ""
-#~ "<![CDATA[<project name=\"hibernate-tutorial\" default=\"compile\">\n"
-#~ "\n"
-#~ "    <property name=\"sourcedir\" value=\"${basedir}/src\"/>\n"
-#~ "    <property name=\"targetdir\" value=\"${basedir}/bin\"/>\n"
-#~ "    <property name=\"librarydir\" value=\"${basedir}/lib\"/>\n"
-#~ "\n"
-#~ "    <path id=\"libraries\">\n"
-#~ "        <fileset dir=\"${librarydir}\">\n"
-#~ "            <include name=\"*.jar\"/>\n"
-#~ "        </fileset>\n"
-#~ "    </path>\n"
-#~ "\n"
-#~ "    <target name=\"clean\">\n"
-#~ "        <delete dir=\"${targetdir}\"/>\n"
-#~ "        <mkdir dir=\"${targetdir}\"/>\n"
-#~ "    </target>\n"
-#~ "\n"
-#~ "    <target name=\"compile\" depends=\"clean, copy-resources\">\n"
-#~ "      <javac srcdir=\"${sourcedir}\"\n"
-#~ "             destdir=\"${targetdir}\"\n"
-#~ "             classpathref=\"libraries\"/>\n"
-#~ "    </target>\n"
-#~ "\n"
-#~ "    <target name=\"copy-resources\">\n"
-#~ "        <copy todir=\"${targetdir}\">\n"
-#~ "            <fileset dir=\"${sourcedir}\">\n"
-#~ "                <exclude name=\"**/*.java\"/>\n"
-#~ "            </fileset>\n"
-#~ "        </copy>\n"
-#~ "    </target>\n"
-#~ "\n"
-#~ "</project>]]>"
-#~ msgstr ""
-#~ "Observa que la distribuci&#x00f3;n de Ant est&#x00e1; por defecto rota "
-#~ "(como se describe en el FAQ de Ant) y tiene que ser reparado por ti, por "
-#~ "ejemplo, si quisieras usar JUnit desde dentro de tu fichero de "
-#~ "construcci&#x00f3;n. Para hacer que funcione la tarea de JUnit (no lo "
-#~ "necesitaremos en este tutorial), copia junit.jar a <literal>ANT_HOME/lib</"
-#~ "literal> o quita el trozo de plugin <literal>ANT_HOME/lib/ant-junit.jar</"
-#~ "literal>."
-
-#~ msgid ""
-#~ "This will tell Ant to add all files in the lib directory ending with "
-#~ "<literal>.jar</literal> to the classpath used for compilation. It will "
-#~ "also copy all non-Java source files to the target directory, e.g. "
-#~ "configuration and Hibernate mapping files. If you now run Ant, you should "
-#~ "get this output:"
-#~ msgstr "Un fichero de construcci&#x00f3;n b&#x00e1;sico se ve como esto:"
-
-#~ msgid ""
-#~ "<![CDATA[C:\\hibernateTutorial\\>ant\n"
-#~ "Buildfile: build.xml\n"
-#~ "\n"
-#~ "copy-resources:\n"
-#~ "     [copy] Copying 2 files to C:\\hibernateTutorial\\bin\n"
-#~ "\n"
-#~ "compile:\n"
-#~ "    [javac] Compiling 1 source file to C:\\hibernateTutorial\\bin\n"
-#~ "\n"
-#~ "BUILD SUCCESSFUL\n"
-#~ "Total time: 1 second ]]>"
-#~ msgstr ""
-#~ "<![CDATA[<project name=\"hibernate-tutorial\" default=\"compile\">\n"
-#~ "\n"
-#~ "    <property name=\"sourcedir\" value=\"${basedir}/src\"/>\n"
-#~ "    <property name=\"targetdir\" value=\"${basedir}/bin\"/>\n"
-#~ "    <property name=\"librarydir\" value=\"${basedir}/lib\"/>\n"
-#~ "\n"
-#~ "    <path id=\"libraries\">\n"
-#~ "        <fileset dir=\"${librarydir}\">\n"
-#~ "            <include name=\"*.jar\"/>\n"
-#~ "        </fileset>\n"
-#~ "    </path>\n"
-#~ "\n"
-#~ "    <target name=\"clean\">\n"
-#~ "        <delete dir=\"${targetdir}\"/>\n"
-#~ "        <mkdir dir=\"${targetdir}\"/>\n"
-#~ "    </target>\n"
-#~ "\n"
-#~ "    <target name=\"compile\" depends=\"clean, copy-resources\">\n"
-#~ "      <javac srcdir=\"${sourcedir}\"\n"
-#~ "             destdir=\"${targetdir}\"\n"
-#~ "             classpathref=\"libraries\"/>\n"
-#~ "    </target>\n"
-#~ "\n"
-#~ "    <target name=\"copy-resources\">\n"
-#~ "        <copy todir=\"${targetdir}\">\n"
-#~ "            <fileset dir=\"${sourcedir}\">\n"
-#~ "                <exclude name=\"**/*.java\"/>\n"
-#~ "            </fileset>\n"
-#~ "        </copy>\n"
-#~ "    </target>\n"
-#~ "\n"
-#~ "</project>]]>"
-
-#~ msgid ""
-#~ "Place <literal>HibernateUtil.java</literal> in the development source "
-#~ "directory, in a package next to <literal>events</literal>:"
-#~ msgstr ""
-#~ "Esta clase no &#x00f3;lo produce la <literal>SessionFactory</literal> "
-#~ "global en su inicializador static (llamado s&#x00f3;lo una vez por la JVM "
-#~ "al cargar la clase), sino que tambi&#x00e9;n tiene una variable "
-#~ "<literal>ThreadLocal</literal> para tener la <literal>Session</literal> "
-#~ "para la hebra actual. No importa cu&#x00e1;ndo llames a "
-#~ "<literal>HibernateUtil.currentSession()</literal>, siempre "
-#~ "devolver&#x00e1; la misma unidad de trabajo de Hibernate en la misma "
-#~ "hebra. Una llamada a <literal>HibernateUtil.closeSession()</literal> "
-#~ "termina la unidad de trabajo actualmente asociada a la hebra."
-
-#~ msgid ""
-#~ "<![CDATA[.\n"
-#~ "+lib\n"
-#~ "  <Hibernate and third-party libraries>\n"
-#~ "+src\n"
-#~ "  +events\n"
-#~ "    Event.java\n"
-#~ "    Event.hbm.xml\n"
-#~ "  +util\n"
-#~ "    HibernateUtil.java\n"
-#~ "  hibernate.cfg.xml\n"
-#~ "+data\n"
-#~ "build.xml]]>"
-#~ msgstr ""
-#~ "Aseg&#x00fa;rate de entender el concepto Java de una variable local a una "
-#~ "hebra antes de usar esta ayuda. Una clase <literal>HibernateUtil</"
-#~ "literal> m&#x00e1;s potente puede encontrarse en <literal>CaveatEmptor</"
-#~ "literal>, http://caveatemptor.hibernate.org/, as&#x00ed; como en el libro "
-#~ "\"Java Persistence with Hibernate\". Observa que esta clase no es "
-#~ "necesaria si despliegas Hibernate en un servidor de aplicaciones J2EE: "
-#~ "una <literal>Session</literal> ser&#x00e1; autom&#x00e1;ticamente ligada "
-#~ "a la transacci&#x00f3;n JTA actual, y puedes buscar la "
-#~ "<literal>SessionFactory</literal> a trav&#x00e9;s de JNDI. Si usas JBoss "
-#~ "AS, Hibernate puede ser desplegado como un servicio de sistema manejado y "
-#~ "autom&#x00e1;ticamente ligar&#x00e1; la <literal>SessionFactory</literal> "
-#~ "a un nombre JNDI."
-
-#~ msgid ""
-#~ "To run this first routine we have to add a callable target to the Ant "
-#~ "build file:"
-#~ msgstr ""
-#~ "¿Qu&#x00e9; es lo que hacen <literal>Transaction.begin()</literal> y "
-#~ "<literal>commit()</literal>? ¿D&#x00f3;nde est&#x00e1; el rollback en "
-#~ "caso que algo vaya mal? La API de <literal>Transaction</literal> de "
-#~ "Hibernate es opcional realmente, pero la usamos por conveniencia y "
-#~ "portabilidad. Si manejases la transacci&#x00f3;n de base de datos por ti "
-#~ "mismo (por ejemplo, llamando a <literal>session.connection.commit()</"
-#~ "literal>), ligar&#x00ed;as el c&#x00f3;digo a un entorno de despliegue "
-#~ "particular, en este JDBC directo no manejado. Estableciendo la f&#x00e1;"
-#~ "brica de <literal>Transaction</literal> en tu configuraci&#x00f3;n de "
-#~ "Hibernate puedes desplegar tu capa de persistencia en cualquier sitio. "
-#~ "Echa una mirada al <xref linkend=\"transactions\"/> para m&#x00e1;s "
-#~ "informaci&#x00f3;n sobre manejo y demarcaci&#x00f3;n de transacciones. "
-#~ "Hemos saltado tambi&#x00e9;n cualquier manejo de excepciones y rollback "
-#~ "en este ejemplo."
-
-#~ msgid ""
-#~ "<![CDATA[<target name=\"run\" depends=\"compile\">\n"
-#~ "    <java fork=\"true\" classname=\"events.EventManager\" classpathref="
-#~ "\"libraries\">\n"
-#~ "        <classpath path=\"${targetdir}\"/>\n"
-#~ "        <arg value=\"${action}\"/>\n"
-#~ "    </java>\n"
-#~ "</target>]]>"
-#~ msgstr ""
-#~ "Para ejecutar la primera rutina tenemos que agregar un objetivo llamable "
-#~ "al fichero de construcci&#x00f3;n de Ant:"
-
-#~ msgid ""
-#~ "The value of the <literal>action</literal> argument is set on the command "
-#~ "line when calling the target:"
-#~ msgstr ""
-#~ "<![CDATA[<target name=\"run\" depends=\"compile\">\n"
-#~ "    <java fork=\"true\" classname=\"EventManager\" classpathref="
-#~ "\"libraries\">\n"
-#~ "        <classpath path=\"${targetdir}\"/>\n"
-#~ "        <arg value=\"${action}\"/>\n"
-#~ "    </java>\n"
-#~ "</target>]]>"
-
-#~ msgid "<![CDATA[C:\\hibernateTutorial\\>ant run -Daction=store]]>"
-#~ msgstr ""
-#~ "El valor del argumento <literal>action</literal> es establecido por "
-#~ "l&#x00ed;nea de comandos al llamar al objetivo:"
-
-#~ msgid ""
-#~ "This is the <literal>INSERT</literal> executed by Hibernate, the question "
-#~ "marks represent JDBC bind parameters. To see the values bound as "
-#~ "arguments, or to reduce the verbosity of the log, check your "
-#~ "<literal>log4j.properties</literal>."
-#~ msgstr ""
-#~ "<![CDATA[[java] Hibernate: insert into EVENTS (EVENT_DATE, title, "
-#~ "EVENT_ID) values (?, ?, ?)]]>"
-
-#~ msgid "Now, to execute and test all of this, follow these steps:"
-#~ msgstr ""
-#~ "Lo que hacemos aqu&#x00ed; es usar una consulta HQL (Lenguaje de Consulta "
-#~ "de Hibernate o Hibernate Query Language) para cargar todos los objetos "
-#~ "<literal>Event</literal> existentes de la base de datos. Hibernate "
-#~ "generar&#x00e1; el SQL apropiado, lo enviar&#x00e1; a la base de datosy "
-#~ "poblar&#x00e1; los objetos <literal>Event</literal> con datos. Puedes, "
-#~ "por supuesto, crear consultas m&#x00e1;s complejas con HQL."
-
-#~ msgid ""
-#~ "Run <literal>ant run -Daction=store</literal> to store something into the "
-#~ "database and, of course, to generate the database schema before through "
-#~ "hbm2ddl."
-#~ msgstr "Now, to execute and test all of this, follow these steps:"
-
-#~ msgid ""
-#~ "Now disable hbm2ddl by commenting out the property in your "
-#~ "<literal>hibernate.cfg.xml</literal> file. Usually you only leave it "
-#~ "turned on in continous unit testing, but another run of hbm2ddl would "
-#~ "<emphasis>drop</emphasis> everything you have stored - the "
-#~ "<literal>create</literal> configuration setting actually translates into "
-#~ "\"drop all tables from the schema, then re-create all tables, when the "
-#~ "SessionFactory is build\"."
-#~ msgstr ""
-#~ "Run <literal>ant run -Daction=store</literal> to store something into the "
-#~ "database and, of course, to generate the database schema before through "
-#~ "hbm2ddl."
-
-#~ msgid ""
-#~ "If you now call Ant with <literal>-Daction=list</literal>, you should see "
-#~ "the events you have stored so far. You can of course also call the "
-#~ "<literal>store</literal> action a few times more."
-#~ msgstr ""
-#~ "Now disable hbm2ddl by commenting out the property in your "
-#~ "<literal>hibernate.cfg.xml</literal> file. Usually you only leave it "
-#~ "turned on in continous unit testing, but another run of hbm2ddl would "
-#~ "<emphasis>drop</emphasis> everything you have stored - the "
-#~ "<literal>create</literal> configuration setting actually translates into "
-#~ "\"drop all tables from the schema, then re-create all tables, when the "
-#~ "SessionFactory is build\"."
-
-#~ msgid ""
-#~ "Note: Most new Hibernate users fail at this point and we see questions "
-#~ "about <emphasis>Table not found</emphasis> error messages regularly. "
-#~ "However, if you follow the steps outlined above you will not have this "
-#~ "problem, as hbm2ddl creates the database schema on the first run, and "
-#~ "subsequent application restarts will use this schema. If you change the "
-#~ "mapping and/or database schema, you have to re-enable hbm2ddl once again."
-#~ msgstr ""
-#~ "If you now call Ant with <literal>-Daction=list</literal>, you should see "
-#~ "the events you have stored so far. You can of course also call the "
-#~ "<literal>store</literal> action a few times more."
-
-#~ msgid ""
-#~ "Create a new mapping file called <literal>Person.hbm.xml</literal> (don't "
-#~ "forget the DTD reference at the top):"
-#~ msgstr ""
-#~ "<![CDATA[public class Person {\n"
-#~ "\n"
-#~ "    private Long id;\n"
-#~ "    private int age;\n"
-#~ "    private String firstname;\n"
-#~ "    private String lastname;\n"
-#~ "\n"
-#~ "    Person() {}\n"
-#~ "\n"
-#~ "    // Accessor methods for all properties, private setter for 'id'\n"
-#~ "\n"
-#~ "}]]>"
-
-#~ msgid ""
-#~ "We need a unidirectional, many-valued associations, implemented with a "
-#~ "<literal>Set</literal>. Let's write the code for this in the Java classes "
-#~ "and then map it:"
-#~ msgstr ""
-#~ "Agregaremos una colecci&#x00f3;n de eventos a la clase <literal>Person</"
-#~ "literal>. De esta forma podemos navegar facilmente a los eventos de una "
-#~ "persona en particular, sin ejecutar una consulta expl&#x00ed;cita, "
-#~ "llamando a <literal>aPerson.getEvents()</literal>. Usamos una "
-#~ "colecci&#x00f3;n Java, un <literal>Set</literal>, porque la "
-#~ "colecci&#x00f3;n no contendr&#x00e1; elementos duplicados y el "
-#~ "ordenamiento no nos es relevante."
-
-#~ msgid ""
-#~ "We add a collection of value typed objects to the <literal>Person</"
-#~ "literal> entity. We want to store email addresses, so the type we use is "
-#~ "<literal>String</literal>, and the collection is again a <literal>Set</"
-#~ "literal>:"
-#~ msgstr ""
-#~ "Agregamos una colecci&#x00f3;n de objetos tipificados en valor a la "
-#~ "entidad <literal>Person</literal>. Queremos almacenar direcciones de "
-#~ "email, de modo que el tipo que usamos es <literal>String</literal>, y la "
-#~ "colecci&#x00f3;n es nuevamente un <literal>Set</literal>:"
-
-#~ msgid "Let's turn this into a small web application."
-#~ msgstr "Let's turn this into a small web application."
-
-#~ msgid ""
-#~ "Create a new class in your source directory, in the <literal>events</"
-#~ "literal> package:"
-#~ msgstr ""
-#~ "Create a new class in your source directory, in the <literal>events</"
-#~ "literal> package:"
-
-#~ msgid ""
-#~ "<![CDATA[package events;\n"
-#~ "\n"
-#~ "// Imports\n"
-#~ "\n"
-#~ "public class EventManagerServlet extends HttpServlet {\n"
-#~ "\n"
-#~ "    // Servlet code\n"
-#~ "}]]>"
-#~ msgstr ""
-#~ "<![CDATA[package events;\n"
-#~ "                                                 \n"
-#~ "                                                 // Imports\n"
-#~ "                                                 \n"
-#~ "                                                 public class "
-#~ "EventManagerServlet extends HttpServlet {\n"
-#~ "                                                 \n"
-#~ "                                                 // Servlet code\n"
-#~ "                                                 }]]>"
-
-#~ msgid ""
-#~ "To deploy this application you have to create a web archive, a WAR. Add "
-#~ "the following Ant target to your <literal>build.xml</literal>:"
-#~ msgstr ""
-#~ "To deploy this application you have to create a web archive, a WAR. Add "
-#~ "the following Ant target to your <literal>build.xml</literal>:"
-
-#~ msgid ""
-#~ "<![CDATA[<target name=\"war\" depends=\"compile\">\n"
-#~ "    <war destfile=\"hibernate-tutorial.war\" webxml=\"web.xml\">\n"
-#~ "        <lib dir=\"${librarydir}\">\n"
-#~ "          <exclude name=\"jsdk*.jar\"/>\n"
-#~ "        </lib>\n"
-#~ "\n"
-#~ "        <classes dir=\"${targetdir}\"/>\n"
-#~ "    </war>\n"
-#~ "</target>]]>"
-#~ msgstr ""
-#~ "<![CDATA[<target name=\"war\" depends=\"compile\">\n"
-#~ "                                                                        <war "
-#~ "destfile=\"hibernate-tutorial.war\" webxml=\"web.xml\">\n"
-#~ "                                                                                <lib "
-#~ "dir=\"${librarydir}\">\n"
-#~ "                                                                                <exclude "
-#~ "name=\"jsdk*.jar\"/>\n"
-#~ "                                                                        </"
-#~ "lib>\n"
-#~ "                                                                        \n"
-#~ "                                                                        <classes "
-#~ "dir=\"${targetdir}\"/>\n"
-#~ "                                                                </war>\n"
-#~ "                                                        </target>]]>"
-
-#~ msgid ""
-#~ "This target creates a file called <literal>hibernate-tutorial.war</"
-#~ "literal> in your project directory. It packages all libraries and the "
-#~ "<literal>web.xml</literal> descriptor, which is expected in the base "
-#~ "directory of your project:"
-#~ msgstr ""
-#~ "This target creates a file called <literal>hibernate-tutorial.war</"
-#~ "literal> in your project directory. It packages all libraries and the "
-#~ "<literal>web.xml</literal> descriptor, which is expected in the base "
-#~ "directory of your project:"
-
-#~ msgid ""
-#~ "Before you compile and deploy the web application, note that an "
-#~ "additional library is required: <literal>jsdk.jar</literal>. This is the "
-#~ "Java servlet development kit, if you don't have this library already, get "
-#~ "it from the Sun website and copy it to your library directory. However, "
-#~ "it will be only used for compliation and excluded from the WAR package."
-#~ msgstr ""
-#~ "Before you compile and deploy the web application, note that an "
-#~ "additional library is required: <literal>jsdk.jar</literal>. This is the "
-#~ "Java servlet development kit, if you don't have this library already, get "
-#~ "it from the Sun website and copy it to your library directory. However, "
-#~ "it will be only used for compliation and excluded from the WAR package."
-
-#~ msgid ""
-#~ "If you already feel confident with Hibernate, continue browsing through "
-#~ "the reference documentation table of contents for topics you find "
-#~ "interesting - most asked are transactional processing (<xref linkend="
-#~ "\"transactions\"/>), fetch performance (<xref linkend=\"performance\"/>), "
-#~ "or the usage of the API (<xref linkend=\"objectstate\"/>) and the query "
-#~ "features (<xref linkend=\"objectstate-querying\"/>)."
-#~ msgstr ""
-#~ "Si ya te sientes confidente con Hibernate, contin&#x00fa;a navegando a "
-#~ "trav&#x00e9;s de la tabla de contenidos de la documentaci&#x00f3;n de "
-#~ "referencia para los temas que encuentres interesantes. Los m&#x00e1;s "
-#~ "consultados son procesamiento transaccional (<xref linkend=\"transactions"
-#~ "\"/>), rendimiento de recuperaci&#x00f3;n (<xref linkend=\"performance\"/"
-#~ ">), o el uso de la API (<xref linkend=\"objectstate\"/>) y las "
-#~ "funcionalidades de consulta (<xref linkend=\"objectstate-querying\"/>)."
-
-#~ msgid ""
-#~ "Don't forget to check the Hibernate website for more (specialized) "
-#~ "tutorials."
-#~ msgstr ""
-#~ "No olvides chequear el sitio web de Hibernate por m&#x00e1;s "
-#~ "(especializados) tutoriales."
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+"Este tutorial abordó los puntos básicos de la escritura de una simple "
+"aplicación de Hibernate autónoma y una pequeña aplicación web. Encontrará "
+"más tutoriales en el website de Hibernate <ulink url=\"http://hibernate.org"
+"\"></ulink>."

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/content/xml.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/content/xml.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/content/xml.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,50 +1,61 @@
-#, fuzzy
+# translation of xml.po to
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Angela Garcia <agarcia at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
+"Project-Id-Version: xml\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-10 21:02+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2010-01-05 07:52+1000\n"
+"Last-Translator: Angela Garcia <agarcia at redhat.com>\n"
+"Language-Team:  <en at 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
-#: xml.xml:29
 #, no-c-format
 msgid "XML Mapping"
 msgstr "Mapeo XML"
 
-#. Tag: emphasis
-#: xml.xml:31
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
-"XML Mapping is an experimental feature in Hibernate 3.0 and is currently "
-"under active development."
+"<emphasis> XML Mapping is an experimental feature in Hibernate 3.0 and is "
+"currently under active development. </emphasis>"
 msgstr ""
-"Nota que esta es una funcionalidad experimental en Hibernate 3.0 y está bajo "
-"un desarrollo extremadamente activo."
+"<emphasis> El mapeo XML es una funcionalidad experimental en Hibernate 3.0 y "
+"se encuentra bajos desarrollo activo. </emphasis>"
 
 #. Tag: title
-#: xml.xml:37
 #, no-c-format
 msgid "Working with XML data"
-msgstr "Trabajando con datos XML"
+msgstr "Trabajo con datos XML"
 
 #. Tag: para
-#: xml.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate allows you to work with persistent XML data in much the same way "
 "you work with persistent POJOs. A parsed XML tree can be thought of as "
 "another way of representing the relational data at the object level, instead "
 "of POJOs."
 msgstr ""
-"Hibernate te permite trabajar con datos XML persistentes en casi la misma "
-"forma que trabajas con POJOs persistentes. Un árbol XML analizado (parsed) "
-"puede ser pensado como sólo otra forma de representar los datos relacionales "
-"a nivel de objetos, en vez de POJOs."
+"Hibernate le permite trabajar con datos XML persistentes en casi de la misma "
+"forma que trabaja con POJOs persistentes. Un árbol XML analizado "
+"semáticamente se puede considerar como otra manera de representar los datos "
+"relacionales a nivel de objetos, en lugar de POJOs."
 
 #. Tag: para
-#: xml.xml:46
 #, no-c-format
 msgid ""
 "Hibernate supports dom4j as API for manipulating XML trees. You can write "
@@ -55,181 +66,75 @@
 "(), saveOrUpdate(), merge(), delete(), replicate()</literal> (merging is not "
 "yet supported)."
 msgstr ""
-"Hibernate soporta dom4j como API para manipular árboles XML. Puedes escribir "
-"consultas que traigan árboles dom4j de la base de datos y tener cualquier "
-"modificación que hagas al árbol sincronizada automáticamente a la base de "
-"datos. Puedes incluso tomar un documento XML, analizarlo usando dom4j, y "
-"escribirlo a la base de datos con cualquiera de las operaciones básicas de "
-"Hibernate: <literal>persist(), saveOrUpdate(), merge(), delete(), replicate()"
-"</literal> (la fusión no está aún soportada)."
+"Hibernate soporta dom4j como API para manipular árboles XML. Puede escribir "
+"consultas que recuperen árboles dom4j de la base de datos y puede tener "
+"cualquier modificación que realice al árbol sincronizada automáticamente con "
+"la base de datos. Incluso puede tomar un documento XML, analizarlo "
+"sintácticamente utilizando dom4j, y escribirlo a la base de datos con "
+"cualquiera de las operaciones básicas de Hibernate: <literal>persist(), "
+"saveOrUpdate(), merge(), delete(), replicate()</literal> (merge aún no está "
+"soportado)."
 
 #. Tag: para
-#: xml.xml:56
 #, no-c-format
 msgid ""
 "This feature has many applications including data import/export, "
 "externalization of entity data via JMS or SOAP and XSLT-based reporting."
 msgstr ""
 "Esta funcionalidad tiene muchas aplicaciones incluyendo la importación/"
-"exportación de datos, externalización de datos de entidad vía JMS o SOAP y "
-"reportes basados en XSLT."
+"exportación de datos, externalización de datos de entidad por medio de JMS o "
+"SOAP y reportes basados en XSLT."
 
 #. Tag: para
-#: xml.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A single mapping can be used to simultaneously map properties of a class and "
 "nodes of an XML document to the database, or, if there is no class to map, "
 "it can be used to map just the XML."
 msgstr ""
-"Un solo mapeo puede ser usado para mapear simultáneamente las propiedades de "
-"una clase y los nodos de un documento XML a la base de datos, o, si no hay "
-"ninguna clase a mapear, puede ser usado para mapear sólo el XML."
+"Un sólo mapeo se puede utilizar para mapear simultáneamente las propiedades "
+"de una clase y los nodos de un documento XML a la base de datos, o si no hay "
+"ninguna clase a mapear, se puede utilizar para mapear sólo el XML."
 
 #. Tag: title
-#: xml.xml:68
 #, no-c-format
 msgid "Specifying XML and class mapping together"
-msgstr "Especificando los mapeos de XML y de clase juntos"
+msgstr "Especificación de los mapeos de XML y de clase en conjunto"
 
 #. Tag: para
-#: xml.xml:70
 #, no-c-format
 msgid "Here is an example of mapping a POJO and XML simultaneously:"
-msgstr "He aquí un ejemplo de mapear un POJO y XML simultáneamente:"
+msgstr "Este es un ejemplo del mapeo de un POJO y XML de manera simultánea:"
 
-#. Tag: programlisting
-#: xml.xml:74
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Account\" \n"
-"        table=\"ACCOUNTS\" \n"
-"        node=\"account\">\n"
-"        \n"
-"    <id name=\"accountId\" \n"
-"            column=\"ACCOUNT_ID\" \n"
-"            node=\"@id\"/>\n"
-"            \n"
-"    <many-to-one name=\"customer\" \n"
-"            column=\"CUSTOMER_ID\" \n"
-"            node=\"customer/@id\" \n"
-"            embed-xml=\"false\"/>\n"
-"            \n"
-"    <property name=\"balance\" \n"
-"            column=\"BALANCE\" \n"
-"            node=\"balance\"/>\n"
-"            \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Account\" \n"
-"        table=\"ACCOUNTS\" \n"
-"        node=\"account\">\n"
-"        \n"
-"    <id name=\"accountId\" \n"
-"            column=\"ACCOUNT_ID\" \n"
-"            node=\"@id\"/>\n"
-"            \n"
-"    <many-to-one name=\"customer\" \n"
-"            column=\"CUSTOMER_ID\" \n"
-"            node=\"customer/@id\" \n"
-"            embed-xml=\"false\"/>\n"
-"            \n"
-"    <property name=\"balance\" \n"
-"            column=\"BALANCE\" \n"
-"            node=\"balance\"/>\n"
-"            \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-
 #. Tag: title
-#: xml.xml:78
 #, no-c-format
 msgid "Specifying only an XML mapping"
-msgstr "Especificando sólo un mapeo XML"
+msgstr "Especificación de sólo un mapeo XML"
 
 #. Tag: para
-#: xml.xml:80
 #, no-c-format
 msgid "Here is an example where there is no POJO class:"
-msgstr "He aquí un ejemplo donde no hay ninguna clase POJO:"
+msgstr "Este es un ejemplo donde no hay ninguna clase POJO:"
 
-#. Tag: programlisting
-#: xml.xml:84
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class entity-name=\"Account\" \n"
-"        table=\"ACCOUNTS\" \n"
-"        node=\"account\">\n"
-"        \n"
-"    <id name=\"id\" \n"
-"            column=\"ACCOUNT_ID\" \n"
-"            node=\"@id\" \n"
-"            type=\"string\"/>\n"
-"            \n"
-"    <many-to-one name=\"customerId\" \n"
-"            column=\"CUSTOMER_ID\" \n"
-"            node=\"customer/@id\" \n"
-"            embed-xml=\"false\" \n"
-"            entity-name=\"Customer\"/>\n"
-"            \n"
-"    <property name=\"balance\" \n"
-"            column=\"BALANCE\" \n"
-"            node=\"balance\" \n"
-"            type=\"big_decimal\"/>\n"
-"            \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class entity-name=\"Account\" \n"
-"        table=\"ACCOUNTS\" \n"
-"        node=\"account\">\n"
-"        \n"
-"    <id name=\"id\" \n"
-"            column=\"ACCOUNT_ID\" \n"
-"            node=\"@id\" \n"
-"            type=\"string\"/>\n"
-"            \n"
-"    <many-to-one name=\"customerId\" \n"
-"            column=\"CUSTOMER_ID\" \n"
-"            node=\"customer/@id\" \n"
-"            embed-xml=\"false\" \n"
-"            entity-name=\"Customer\"/>\n"
-"            \n"
-"    <property name=\"balance\" \n"
-"            column=\"BALANCE\" \n"
-"            node=\"balance\" \n"
-"            type=\"big_decimal\"/>\n"
-"            \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-
-#. Tag: para
-#: xml.xml:86
-#, fuzzy, no-c-format
-msgid ""
 "This mapping allows you to access the data as a dom4j tree, or as a graph of "
 "property name/value pairs or java <literal>Map</literal>s. The property "
 "names are purely logical constructs that can be referred to in HQL queries."
 msgstr ""
-"Este mapeo te permite acceder a los datos como un árbol dom4j, o como un "
-"grafo de pares nombre/valor de propiedad (<literal>Map</literal>s de Java). "
-"Los nombres de propiedades son construcciones puramente lógicas a las que se "
-"puede hacer referencia en consultas HQL."
+"Este mapeo le permite acceder a los datos como un árbol dom4j o como un "
+"grafo de parejas nombre/valor de propiedad o<literal>Map</literal>as de "
+"Java. Los nombres de propiedades son construcciones puramente lógicas a las "
+"que se puede hacer referencia en consultas HQL."
 
 #. Tag: title
-#: xml.xml:97
 #, no-c-format
 msgid "XML mapping metadata"
 msgstr "Mapeo de metadatos XML"
 
 #. Tag: para
-#: xml.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A range of Hibernate mapping elements accept the <literal>node</literal> "
 "attribute. This lets you specify the name of an XML attribute or element "
@@ -237,42 +142,38 @@
 "literal> attribute must be one of the following:"
 msgstr ""
 "Muchos elementos de mapeo de Hibernate aceptan el atributo <literal>node</"
-"literal>. Esto te permite espcificar el nombre de un atributo o elemento XML "
-"que contenga los datos de la propiedad o entidad. El formato del atributo "
-"<literal>node</literal> debe ser uno de los siguientes:"
+"literal>. Esto le permite especificar el nombre de un atributo o elemento "
+"XML que contenga los datos de la propiedad o entidad. El formato del "
+"atributo <literal>node</literal> tiene que ser uno de los siguientes: "
 
 #. Tag: para
-#: xml.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>\"element-name\"</literal>: map to the named XML element"
-msgstr "<literal>\"element-name\"</literal> - mapea al elemento XML mencionado"
+msgstr ""
+"<literal>\"element-name\"</literal> - mapea al elemento XML mencionado "
 
 #. Tag: para
-#: xml.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>\"@attribute-name\"</literal>: map to the named XML attribute"
 msgstr ""
-"<literal>\"@attribute-name\"</literal> - mapea al atributo XML mencionado"
+"<literal>\"@attribute-name\"</literal>: mapea al atributo XML mencionado"
 
 #. Tag: para
-#: xml.xml:114
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>\".\"</literal>: map to the parent element"
-msgstr "<literal>\".\"</literal> - mapea al elemento padre"
+msgstr "<literal>\".\"</literal> - mapea al elemento padre "
 
 #. Tag: para
-#: xml.xml:117
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>\"element-name/@attribute-name\"</literal>: map to the named "
 "attribute of the named element"
 msgstr ""
-"<literal>\"element-name/@attribute-name\"</literal> - mapea al atributo "
-"mencionado del elemento mencionado"
+"<literal>\"element-name/@attribute-name\"</literal>: mapea al atributo "
+"mencionado del elemento nombrado"
 
 #. Tag: para
-#: xml.xml:124
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For collections and single valued associations, there is an additional "
 "<literal>embed-xml</literal> attribute. If <literal>embed-xml=\"true\"</"
@@ -284,306 +185,65 @@
 msgstr ""
 "Para las colecciones y asociaciones monovaluadas, existe un atributo "
 "adicional <literal>embed-xml</literal>. Si <literal>embed-xml=\"true\"</"
-"literal>, que es el valor por defecto, el árbol XML para la entidad asociada "
-"(o colección de tipo de valor) será embebida directamente en el árbol XML "
-"para la entidad que posee la asociación. En otro caso, si <literal>embed-xml="
-"\"false\"</literal>, sólo el valor identificador referenciado aparecerá en "
-"el XML para asociaciones de punto único y para las colecciones simplemente "
-"no aparecerá en absoluto."
+"literal>, el cual es el valor por defecto, el árbol XML para la entidad "
+"asociada (o colección de tipo de valor) será incluida directamente en el "
+"árbol XML para la entidad que posee la asociación. De otra manera, si "
+"<literal>embed-xml=\"false\"</literal>, entonces sólo el valor identificador "
+"referenciado aparecerá en el XML para asociaciones de punto único y para las "
+"colecciones simplemente no aparecerá."
 
 #. Tag: para
-#: xml.xml:134
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not leave <literal>embed-xml=\"true\"</literal> for too many "
 "associations, since XML does not deal well with circularity."
 msgstr ""
-"¡Debes ser cuidadoso de no dejar <literal>embed-xml=\"true\"</literal> para "
-"demasiadas asociaciones, ya que XML no trata bien la circularidad!"
+"No deje <literal>embed-xml=\"true\"</literal> para demasiadas asociaciones "
+"ya que XML no se ocupa bien de la circularidad."
 
-#. Tag: programlisting
-#: xml.xml:139
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Customer\" \n"
-"        table=\"CUSTOMER\" \n"
-"        node=\"customer\">\n"
-"        \n"
-"    <id name=\"id\" \n"
-"            column=\"CUST_ID\" \n"
-"            node=\"@id\"/>\n"
-"            \n"
-"    <map name=\"accounts\" \n"
-"            node=\".\" \n"
-"            embed-xml=\"true\">\n"
-"        <key column=\"CUSTOMER_ID\" \n"
-"                not-null=\"true\"/>\n"
-"        <map-key column=\"SHORT_DESC\" \n"
-"                node=\"@short-desc\" \n"
-"                type=\"string\"/>\n"
-"        <one-to-many entity-name=\"Account\"\n"
-"                embed-xml=\"false\" \n"
-"                node=\"account\"/>\n"
-"    </map>\n"
-"    \n"
-"    <component name=\"name\" \n"
-"            node=\"name\">\n"
-"        <property name=\"firstName\" \n"
-"                node=\"first-name\"/>\n"
-"        <property name=\"initial\" \n"
-"                node=\"initial\"/>\n"
-"        <property name=\"lastName\" \n"
-"                node=\"last-name\"/>\n"
-"    </component>\n"
-"    \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Customer\" \n"
-"        table=\"CUSTOMER\" \n"
-"        node=\"customer\">\n"
-"        \n"
-"    <id name=\"id\" \n"
-"            column=\"CUST_ID\" \n"
-"            node=\"@id\"/>\n"
-"            \n"
-"    <map name=\"accounts\" \n"
-"            node=\".\" \n"
-"            embed-xml=\"true\">\n"
-"        <key column=\"CUSTOMER_ID\" \n"
-"                not-null=\"true\"/>\n"
-"        <map-key column=\"SHORT_DESC\" \n"
-"                node=\"@short-desc\" \n"
-"                type=\"string\"/>\n"
-"        <one-to-many entity-name=\"Account\"\n"
-"                embed-xml=\"false\" \n"
-"                node=\"account\"/>\n"
-"    </map>\n"
-"    \n"
-"    <component name=\"name\" \n"
-"            node=\"name\">\n"
-"        <property name=\"firstName\" \n"
-"                node=\"first-name\"/>\n"
-"        <property name=\"initial\" \n"
-"                node=\"initial\"/>\n"
-"        <property name=\"lastName\" \n"
-"                node=\"last-name\"/>\n"
-"    </component>\n"
-"    \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-
-#. Tag: para
-#: xml.xml:141
-#, fuzzy, no-c-format
-msgid ""
 "In this case, the collection of account ids is embedded, but not the actual "
 "account data. The following HQL query:"
 msgstr ""
-"en este caso, hemos decidido embeber la colección de ids de cuenta, pero no "
-"los datos reales de cuenta. La siguiente consulta HQL:"
+"En este caso, la colección de ids de cuenta están incluídos, pero no los "
+"datos reales de cuenta. La siguiente consulta HQL:"
 
-#. Tag: programlisting
-#: xml.xml:146
-#, no-c-format
-msgid ""
-"<![CDATA[from Customer c left join fetch c.accounts where c.lastName like :"
-"lastName]]>"
-msgstr ""
-"<![CDATA[from Customer c left join fetch c.accounts where c.lastName like :"
-"lastName]]>"
-
 #. Tag: para
-#: xml.xml:148
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "would return datasets such as this:"
-msgstr "devolvería conjuntos de datos como estos:"
+msgstr "retornaría conjuntos de datos como este:"
 
-#. Tag: programlisting
-#: xml.xml:152
-#, no-c-format
-msgid ""
-"<![CDATA[<customer id=\"123456789\">\n"
-"    <account short-desc=\"Savings\">987632567</account>\n"
-"    <account short-desc=\"Credit Card\">985612323</account>\n"
-"    <name>\n"
-"        <first-name>Gavin</first-name>\n"
-"        <initial>A</initial>\n"
-"        <last-name>King</last-name>\n"
-"    </name>\n"
-"    ...\n"
-"</customer>]]>"
-msgstr ""
-"<![CDATA[<customer id=\"123456789\">\n"
-"    <account short-desc=\"Savings\">987632567</account>\n"
-"    <account short-desc=\"Credit Card\">985612323</account>\n"
-"    <name>\n"
-"        <first-name>Gavin</first-name>\n"
-"        <initial>A</initial>\n"
-"        <last-name>King</last-name>\n"
-"    </name>\n"
-"    ...\n"
-"</customer>]]>"
-
 #. Tag: para
-#: xml.xml:154
 #, no-c-format
 msgid ""
 "If you set <literal>embed-xml=\"true\"</literal> on the <literal>&lt;one-to-"
 "many&gt;</literal> mapping, the data might look more like this:"
 msgstr ""
-"Si estableces <literal>embed-xml=\"true\"</literal> en el mapeo <literal>&lt;"
-"one-to-many&gt;</literal>, los datos podrían verse así:"
+"Si establece <literal>embed-xml=\"true\"</literal> en el mapeo <literal>&lt;"
+"one-to-many&gt;</literal>, puede que los datos se vean así:"
 
-#. Tag: programlisting
-#: xml.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[<customer id=\"123456789\">\n"
-"    <account id=\"987632567\" short-desc=\"Savings\">\n"
-"        <customer id=\"123456789\"/>\n"
-"        <balance>100.29</balance>\n"
-"    </account>\n"
-"    <account id=\"985612323\" short-desc=\"Credit Card\">\n"
-"        <customer id=\"123456789\"/>\n"
-"        <balance>-2370.34</balance>\n"
-"    </account>\n"
-"    <name>\n"
-"        <first-name>Gavin</first-name>\n"
-"        <initial>A</initial>\n"
-"        <last-name>King</last-name>\n"
-"    </name>\n"
-"    ...\n"
-"</customer>]]>"
-msgstr ""
-"<![CDATA[<customer id=\"123456789\">\n"
-"    <account id=\"987632567\" short-desc=\"Savings\">\n"
-"        <customer id=\"123456789\"/>\n"
-"        <balance>100.29</balance>\n"
-"    </account>\n"
-"    <account id=\"985612323\" short-desc=\"Credit Card\">\n"
-"        <customer id=\"123456789\"/>\n"
-"        <balance>-2370.34</balance>\n"
-"    </account>\n"
-"    <name>\n"
-"        <first-name>Gavin</first-name>\n"
-"        <initial>A</initial>\n"
-"        <last-name>King</last-name>\n"
-"    </name>\n"
-"    ...\n"
-"</customer>]]>"
-
 #. Tag: title
-#: xml.xml:165
 #, no-c-format
 msgid "Manipulating XML data"
-msgstr "Manipulando datos XML"
+msgstr "Manipulación de datos XML"
 
 #. Tag: para
-#: xml.xml:167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also re-read and update XML documents in the application. You can do "
 "this by obtaining a dom4j session:"
 msgstr ""
-"Vamos a releer y actualizar documentos XML en la aplicación. Hacemos esto "
+"Puede releer y actualizar documentos XML en la aplicación. Puede hacer esto "
 "obteniendo una sesión dom4j:"
 
-#. Tag: programlisting
-#: xml.xml:172
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Document doc = ....;\n"
-"       \n"
-"Session session = factory.openSession();\n"
-"Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"List results = dom4jSession\n"
-"    .createQuery(\"from Customer c left join fetch c.accounts where c."
-"lastName like :lastName\")\n"
-"    .list();\n"
-"for ( int i=0; i<results.size(); i++ ) {\n"
-"    //add the customer data to the XML document\n"
-"    Element customer = (Element) results.get(i);\n"
-"    doc.add(customer);\n"
-"}\n"
-"\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-"<![CDATA[Document doc = ....;\n"
-"       \n"
-"Session session = factory.openSession();\n"
-"Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"List results = dom4jSession\n"
-"    .createQuery(\"from Customer c left join fetch c.accounts where c."
-"lastName like :lastName\")\n"
-"    .list();\n"
-"for ( int i=0; i<results.size(); i++ ) {\n"
-"    //add the customer data to the XML document\n"
-"    Element customer = (Element) results.get(i);\n"
-"    doc.add(customer);\n"
-"}\n"
-"\n"
-"tx.commit();\n"
-"session.close();]]>"
-
-#. Tag: programlisting
-#: xml.xml:174
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = factory.openSession();\n"
-"Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"Element cust = (Element) dom4jSession.get(\"Customer\", customerId);\n"
-"for ( int i=0; i<results.size(); i++ ) {\n"
-"    Element customer = (Element) results.get(i);\n"
-"    //change the customer name in the XML and database\n"
-"    Element name = customer.element(\"name\");\n"
-"    name.element(\"first-name\").setText(firstName);\n"
-"    name.element(\"initial\").setText(initial);\n"
-"    name.element(\"last-name\").setText(lastName);\n"
-"}\n"
-"\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-"<![CDATA[Session session = factory.openSession();\n"
-"Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"Element cust = (Element) dom4jSession.get(\"Customer\", customerId);\n"
-"for ( int i=0; i<results.size(); i++ ) {\n"
-"    Element customer = (Element) results.get(i);\n"
-"    //change the customer name in the XML and database\n"
-"    Element name = customer.element(\"name\");\n"
-"    name.element(\"first-name\").setText(firstName);\n"
-"    name.element(\"initial\").setText(initial);\n"
-"    name.element(\"last-name\").setText(lastName);\n"
-"}\n"
-"\n"
-"tx.commit();\n"
-"session.close();]]>"
-
-#. Tag: para
-#: xml.xml:176
-#, fuzzy, no-c-format
-msgid ""
 "When implementing XML-based data import/export, it is useful to combine this "
 "feature with Hibernate's <literal>replicate()</literal> operation."
 msgstr ""
-"Es extremadamente útil combinar esta funcionalidad con la operación "
-"<literal>replicate()</literal> de Hibernate para implementar la importación/"
-"exportación de datos basada en XML."
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+"Es útil combinar esta funcionalidad con la operación <literal>replicate()</"
+"literal> de Hibernate para implementar la importación/exportación de datos "
+"basada en XML."

Modified: core/trunk/documentation/manual/src/main/docbook/es-ES/legal_notice.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/es-ES/legal_notice.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/es-ES/legal_notice.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,35 +2,33 @@
 msgid ""
 msgstr ""
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-06-16 18:47+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:23\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
 "Content-Type: text/plain; charset=UTF-8\n"
 
 #. Tag: title
-#: legal_notice.xml:28
 #, no-c-format
 msgid "Legal Notice"
 msgstr "Legal Notice"
 
-#. Tag: address
-#: legal_notice.xml:30
-#, no-c-format
+#. Tag: para
+#, fuzzy, no-c-format
 msgid ""
-"<street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
-"state><postcode>27606-2072</postcode><country>USA</country> <phone>Phone: +1 "
-"919 754 3700</phone> <phone>Phone: 888 733 4281</phone> <fax>Fax: +1 919 754 "
-"3701</fax> <pob>PO Box 13588</pob><city>Research Triangle Park</city>, "
-"<state>NC</state><postcode>27709</postcode><country>USA</country>"
+"<address> <street>1801 Varsity Drive</street> <city>Raleigh</city>, "
+"<state>NC</state><postcode>27606-2072</postcode><country>USA</country> "
+"<phone>Phone: +1 919 754 3700</phone> <phone>Phone: 888 733 4281</phone> "
+"<fax>Fax: +1 919 754 3701</fax> <pob>PO Box 13588</pob><city>Research "
+"Triangle Park</city>, <state>NC</state><postcode>27709</"
+"postcode><country>USA</country> </address>"
 msgstr ""
-"<street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
+"<address> <street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
 "state><postcode>27606-2072</postcode><country>USA</country> <phone>Phone: +1 "
 "919 754 3700</phone> <phone>Phone: 888 733 4281</phone> <fax>Fax: +1 919 754 "
 "3701</fax> <pob>PO Box 13588</pob><city>Research Triangle Park</city>, "
-"<state>NC</state><postcode>27709</postcode><country>USA</country>"
+"<state>NC</state><postcode>27709</postcode><country>USA</country> </address>"
 
 #. Tag: para
-#: legal_notice.xml:39
 #, fuzzy, no-c-format
 msgid ""
 "Copyright <trademark class=\"copyright\"></trademark> 2007 by Red Hat, Inc. "
@@ -46,7 +44,6 @@
 "Public License</ulink>, as published by the Free Software Foundation."
 
 #. Tag: para
-#: legal_notice.xml:45
 #, no-c-format
 msgid ""
 "Red Hat and the Red Hat \"Shadow Man\" logo are registered trademarks of Red "
@@ -56,7 +53,6 @@
 "Hat, Inc. in the United States and other countries."
 
 #. Tag: para
-#: legal_notice.xml:48
 #, no-c-format
 msgid ""
 "All other trademarks referenced herein are the property of their respective "
@@ -66,13 +62,11 @@
 "owners."
 
 #. Tag: para
-#: legal_notice.xml:51
 #, no-c-format
 msgid "The GPG fingerprint of the security at redhat.com key is:"
 msgstr "The GPG fingerprint of the security at redhat.com key is:"
 
 #. Tag: para
-#: legal_notice.xml:54
 #, no-c-format
 msgid "CA 20 86 86 2B D6 9D FC 65 F6 EC C4 21 91 80 CD DB 42 A6 0E"
 msgstr "CA 20 86 86 2B D6 9D FC 65 F6 EC C4 21 91 80 CD DB 42 A6 0E"

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/Hibernate_Reference.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/Hibernate_Reference.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/Hibernate_Reference.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,32 +1,30 @@
+# SOME DESCRIPTIVE TITLE.
+# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+#
 #, fuzzy
 msgid ""
 msgstr ""
+"Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-11T05:38:14\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Content-Type: text/plain; charset=UTF-8\n"
+"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: Hibernate_Reference.xml:35
 #, no-c-format
 msgid "HIBERNATE - Relational Persistence for Idiomatic Java"
-msgstr "HIBERNATE - Persistance relationnelle en Java standard"
+msgstr ""
 
 #. Tag: subtitle
-#: Hibernate_Reference.xml:36
 #, no-c-format
 msgid "Hibernate Reference Documentation"
-msgstr "Documentation de référence d'Hibernate"
+msgstr ""
 
-#. Tag: holder
-#: Hibernate_Reference.xml:51
+#. Tag: releaseinfo
 #, no-c-format
-msgid "&copyrightHolder;"
-msgstr "&copyrightHolder;"
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+msgid "&versionNumber;"
+msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/author_group.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/author_group.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/author_group.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -5,7 +5,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: 2009-07-14 19:55+0000\n"
 "Last-Translator: Automatically generated\n"
 "Language-Team: none\n"
@@ -13,209 +13,137 @@
 "Content-Type: text/plain; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
-#. Tag: author
-#: author_group.xml:27
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Gavin</firstname> <surname>King</surname>"
+msgid "Gavin"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:31
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Christian</firstname> <surname>Bauer</surname>"
+msgid "Christian"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:35
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Max</firstname> <othername>Rydahl</othername> <surname>Andersen</"
-"surname>"
+msgid "Max"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:40
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<author><firstname>Emmanuel</firstname> <surname>Bernard</surname></author>"
+msgid "Emmanuel"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:44
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Steve</firstname> <surname>Ebersole</surname>"
+msgid "Steve"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:49
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>James</firstname> <surname>Cobb</surname>"
+msgid "James"
 msgstr ""
 
-#. Tag: shortaffil
-#: author_group.xml:53 author_group.xml:60
+#. Tag: firstname
 #, no-c-format
-msgid "Graphic Design"
+msgid "Cheyenne"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:56
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Cheyenne</firstname> <surname>Weaver</surname>"
+msgid "Vincent"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:69
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<othername><![CDATA[Bernardo Antonio Buffa Colom&#x00e9]]></othername> "
-"<email>kreimer at bbs.frc.utn.edu.ar</email>"
+msgid "Sebastien"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:79
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Vincent</firstname> <surname>Ricard</surname>"
+msgid "Michael"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:83
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Sebastien</firstname> <surname>Cesbron</surname>"
+msgid "Baptiste"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:87
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Michael</firstname> <surname>Courcy</surname>"
+msgid "Anthony"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:91
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Vincent</firstname> <surname>Giguère</surname>"
+msgid "Alvaro"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:95
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Baptiste</firstname> <surname>Mathus</surname>"
+msgid "Anderson"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:99
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<othercredit><firstname>Emmanuel</firstname> <surname>Bernard</surname></"
-"othercredit>"
+msgid "Daniel Vieira"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:103
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Anthony</firstname> <surname>Patricio</surname>"
+msgid "Francisco"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:113
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Alvaro</firstname> <surname>Netto</surname> "
-"<email>alvaronetto at cetip.com.br</email>"
+msgid "Gamarra"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:118
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Anderson</firstname> <surname>Braulio</surname> "
-"<email>andersonbraulio at gmail.com</email>"
+msgid "Luiz Carlos"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:123
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Daniel Vieira</firstname> <surname>Costa</surname> "
-"<email>danielvc at gmail.com</email>"
+msgid "Marcel"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:128
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Francisco</firstname> <surname>gamarra</surname> <email>francisco."
-"gamarra at gmail.com</email>"
+msgid "Paulo"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:133
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Gamarra</firstname> <email>mauricio.gamarra at gmail.com</email>"
+msgid "Pablo L."
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:137
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Luiz Carlos</firstname> <surname>Rodrigues</surname> "
-"<email>luizcarlos_rodrigues at yahoo.com.br</email>"
+msgid "Renato"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:142
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Marcel</firstname> <surname>Castelo</surname> <email>marcel."
-"castelo at gmail.com</email>"
+msgid "Rogério"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:147
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Paulo</firstname> <surname>César</surname> <email>paulocol at gmail."
-"com</email>"
+msgid "Wanderson"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:152
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Pablo L.</firstname> <surname>de Miranda</surname> "
-"<email>pablolmiranda at gmail.com</email>"
+msgid "Cao"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:157
+#. Tag: orgname
 #, no-c-format
-msgid ""
-"<firstname>Renato</firstname> <surname>Deggau</surname> <email>rdeggau at gmail."
-"com</email>"
+msgid "RedSaga"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:162
+#. Tag: contrib
 #, no-c-format
-msgid ""
-"<firstname>Rogério</firstname> <surname>Araújo</surname> "
-"<email>rgildoaraujo at yahoo.com.br</email>"
+msgid "Translation Lead"
 msgstr ""
-
-#. Tag: othercredit
-#: author_group.xml:167
-#, no-c-format
-msgid ""
-"<firstname>Wanderson</firstname> <surname>Siqueira</surname> "
-"<email>wandersonxs at gmail.com</email>"
-msgstr ""
-
-#. Tag: othercredit
-#: author_group.xml:178
-#, no-c-format
-msgid ""
-"<firstname>Cao</firstname> <surname>Xiaogang</surname> <affiliation> "
-"<orgname>RedSaga</orgname> </affiliation> <contrib>Translation Lead</"
-"contrib> <email>caoxg at yahoo.com</email>"
-msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/architecture.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/architecture.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/architecture.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,101 +1,95 @@
+# translation of architecture.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: architecture\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2010-01-04 16:40+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: architecture.xml:30
 #, no-c-format
 msgid "Architecture"
 msgstr "Architecture"
 
 #. Tag: title
-#: architecture.xml:33
 #, no-c-format
 msgid "Overview"
 msgstr "Généralités"
 
 #. Tag: para
-#: architecture.xml:35
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The diagram below provides a high-level view of the Hibernate architecture:"
-msgstr "Voici une vue (très) haut niveau de l'architecture d'Hibernate :"
+msgstr ""
+"Le diagramme ci-dessus procure une vue - (très) haut niveau - de "
+"l'architecture Hibernate :"
 
 #. Tag: para
-#: architecture.xml:48
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We do not have the scope in this document to provide a more detailed view of "
 "all the runtime architectures available; Hibernate is flexible and supports "
 "several different approaches. We will, however, show the two extremes: "
 "\"minimal\" architecture and \"comprehensive\" architecture."
 msgstr ""
-"Nous aimerions décrire une vue plus détaillée de l'architecture. "
-"Malheureusement, Hibernate est flexible et supporte différentes approches. "
-"Nous allons en montrer les deux extrêmes. L'architecture légère laisse "
-"l'application fournir ses propres connexions JDBC et gérer ses propres "
-"transactions. Cette approche utilise le minimum des APIs Hibernate :"
+"Nous aimerions décrire une vue plus détaillée de l'architecture. Hibernate "
+"est flexible et prend en charge différentes approches. Nous allons en "
+"montrer les deux extrêmes : l'architecture \"légère\"  et l'architecture "
+"\"complète\"."
 
 #. Tag: para
-#: architecture.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This next diagram illustrates how Hibernate utilizes database and "
 "configuration data to provide persistence services, and persistent objects, "
 "to the application."
 msgstr ""
-"Ce diagramme montre Hibernate utilisant une base de données et des données "
-"de configuration pour fournir un service de persistance (et des objets "
-"persistants) à l'application."
+"Ce diagramme montre Hibernate utilisant la base de données et des données de "
+"configuration pour fournir un service de persistance, et des objets "
+"persistants, à l'application."
 
 #. Tag: para
-#: architecture.xml:59
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The \"minimal\" architecture has the application provide its own JDBC "
 "connections and manage its own transactions. This approach uses a minimal "
 "subset of Hibernate's APIs:"
 msgstr ""
-"Nous aimerions décrire une vue plus détaillée de l'architecture. "
-"Malheureusement, Hibernate est flexible et supporte différentes approches. "
-"Nous allons en montrer les deux extrêmes. L'architecture légère laisse "
-"l'application fournir ses propres connexions JDBC et gérer ses propres "
-"transactions. Cette approche utilise le minimum des APIs Hibernate :"
+"L'architecture \"légère\" permet à l'application de fournir ses propres "
+"connexions JDBC et de gérer ses propres transactions. Cette approche utilise "
+"un sous-ensemble minimum des API Hibernate :"
 
 #. Tag: para
-#: architecture.xml:74
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The \"comprehensive\" architecture abstracts the application away from the "
 "underlying JDBC/JTA APIs and allows Hibernate to manage the details."
 msgstr ""
-"L'architecture la plus complète abstrait l'application des APIs JDBC/JTA "
-"sous-jacentes et laisse Hibernate s'occuper des détails."
+"L'architecture \"complète\" abstrait l'application des API JDBC/JTA sous-"
+"jacentes et permet à Hibernate de s'occuper des détails."
 
 #. Tag: para
-#: architecture.xml:88
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here are some definitions of the objects depicted in the diagrams:"
-msgstr ""
-"Voici quelques définitions des objets des diagrammes : <placeholder-1/>"
+msgstr "Voici quelques définitions des objets dans les diagrammes :"
 
 #. Tag: term
-#: architecture.xml:93
 #, no-c-format
 msgid "SessionFactory (<literal>org.hibernate.SessionFactory</literal>)"
 msgstr "SessionFactory (<literal>org.hibernate.SessionFactory</literal>)"
 
 #. Tag: para
-#: architecture.xml:95
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A threadsafe, immutable cache of compiled mappings for a single database. A "
 "factory for <literal>Session</literal> and a client of "
@@ -103,22 +97,20 @@
 "hold an optional (second-level) cache of data that is reusable between "
 "transactions at a process, or cluster, level."
 msgstr ""
-"Un cache threadsafe (immuable) des mappings vers une (et une seule) base de "
-"données. Une factory (fabrique) de <literal>Session</literal> et un client "
-"de <literal>ConnectionProvider</literal>. Peut contenir un cache optionnel "
-"de données (de second niveau) qui est réutilisable entre les différentes "
-"transactions que cela soit au sein du même processus (JVLM) ou par plusieurs "
-"nœuds d'un cluster."
+"Un cache threadsafe (immuable) de mappages compilés pour une base de "
+"données. En tant que fabrique de <literal>Session</literal> et que client du "
+"<literal>ConnectionProvider</literal>, <literal>SessionFactory</literal>peut "
+"contenir un cache optionnel de données (de second niveau), réutilisable "
+"entre les différentes transactions, que cela soit au sein du même processus "
+"ou au niveau d'un cluster."
 
 #. Tag: term
-#: architecture.xml:105
 #, no-c-format
 msgid "Session (<literal>org.hibernate.Session</literal>)"
 msgstr "Session (<literal>org.hibernate.Session</literal>)"
 
 #. Tag: para
-#: architecture.xml:107
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A single-threaded, short-lived object representing a conversation between "
 "the application and the persistent store. It wraps a JDBC connection and is "
@@ -128,20 +120,18 @@
 msgstr ""
 "Un objet mono-threadé, à durée de vie courte, qui représente une "
 "conversation entre l'application et l'entrepôt de persistance. Encapsule une "
-"connexion JDBC. Factory (fabrique) des objets <literal>Transaction</"
-"literal>. Contient un cache (de premier niveau) des objets persistants, ce "
-"cache est obligatoire. Il est utilisé lors de la navigation dans le graphe "
-"d'objets ou lors de la récupération d'objets par leur identifiant."
+"connexion JDBC. Fabrique des objets <literal>Transaction</literal>. La "
+"<literal>Session</literal> contient un cache (de premier niveau) des objets "
+"persistants, qui sont utilisés lors de la navigation dans le graphe d'objets "
+"ou lors de la récupération d'objets par leur identifiant."
 
 #. Tag: term
-#: architecture.xml:117
 #, no-c-format
 msgid "Persistent objects and collections"
-msgstr "Objets et Collections persistants"
+msgstr "Objets et collections persistants"
 
 #. Tag: para
-#: architecture.xml:119
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Short-lived, single threaded objects containing persistent state and "
 "business function. These can be ordinary JavaBeans/POJOs. They are "
@@ -150,23 +140,20 @@
 "in any application layer (for example, directly as data transfer objects to "
 "and from presentation)."
 msgstr ""
-"Objets mono-threadés à vie courte contenant l'état de persistance et la "
-"fonction métier. Ceux-ci sont en général les objets de type JavaBean (ou "
-"POJOs) ; la seule particularité est qu'ils sont associés avec une (et une "
+"Objets mono-threadés à vie courte, contenant état persistant et fonction "
+"commerciale. Ceux-ci sont en général des objets ordinaires de type JavaBean "
+"(ou POJO); la seule particularité est qu'ils sont associés avec une (et une "
 "seule) <literal>Session</literal>. Dès que la <literal>Session</literal> est "
-"fermée, ils seront détachés et libres d'être utilisés par n'importe laquelle "
-"des couches de l'application (ie. de et vers la présentation en tant que "
-"Data Transfer Objects - DTO : objet de transfert de données)."
+"fermée, ils sont détachés et libres d'être utilisés par n'importe quelle "
+"couche de l'application (par ex. de et vers la présentation)."
 
 #. Tag: term
-#: architecture.xml:129
 #, no-c-format
 msgid "Transient and detached objects and collections"
-msgstr "Objets et collections transients"
+msgstr "Objets et collections éphémères (transient) et détachés"
 
 #. Tag: para
-#: architecture.xml:131
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Instances of persistent classes that are not currently associated with a "
 "<literal>Session</literal>. They may have been instantiated by the "
@@ -175,18 +162,16 @@
 msgstr ""
 "Instances de classes persistantes qui ne sont actuellement pas associées à "
 "une <literal>Session</literal>. Elles ont pu être instanciées par "
-"l'application et ne pas avoir (encore) été persistées ou elle ont pu être "
+"l'application et ne pas avoir (encore) été persistées, ou elle ont pu être "
 "instanciées par une <literal>Session</literal> fermée."
 
 #. Tag: term
-#: architecture.xml:140
 #, no-c-format
 msgid "Transaction (<literal>org.hibernate.Transaction</literal>)"
 msgstr "Transaction (<literal>org.hibernate.Transaction</literal>)"
 
 #. Tag: para
-#: architecture.xml:142
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "(Optional) A single-threaded, short-lived object used by the application to "
 "specify atomic units of work. It abstracts the application from the "
@@ -197,14 +182,13 @@
 msgstr ""
 "(Optionnel) Un objet mono-threadé à vie courte utilisé par l'application "
 "pour définir une unité de travail atomique. Abstrait l'application des "
-"transactions sous-jacentes qu'elles soient JDBC, JTA ou CORBA. Une "
+"transactions sous-jacentes, qu'elles soient JDBC, JTA ou CORBA. Une "
 "<literal>Session</literal> peut fournir plusieurs <literal>Transaction</"
 "literal>s dans certains cas. Toutefois, la délimitation des transactions, "
 "via l'API d'Hibernate ou par la <literal>Transaction</literal> sous-jacente, "
-"n'est jamais optionnelle!"
+"n'est jamais optionnelle. "
 
 #. Tag: term
-#: architecture.xml:153
 #, no-c-format
 msgid ""
 "ConnectionProvider (<literal>org.hibernate.connection.ConnectionProvider</"
@@ -214,8 +198,7 @@
 "literal>)"
 
 #. Tag: para
-#: architecture.xml:155
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "(Optional) A factory for, and pool of, JDBC connections. It abstracts the "
 "application from underlying <literal>Datasource</literal> or "
@@ -225,10 +208,9 @@
 "(Optionnel) Une fabrique de (pool de) connexions JDBC. Abstrait "
 "l'application de la <literal>Datasource</literal> ou du "
 "<literal>DriverManager</literal> sous-jacent. Non exposé à l'application, "
-"mais peut être étendu/implémenté par le développeur."
+"mais peut être étendu/implémenté par le développeur. "
 
 #. Tag: term
-#: architecture.xml:163
 #, no-c-format
 msgid ""
 "TransactionFactory (<literal>org.hibernate.TransactionFactory</literal>)"
@@ -236,25 +218,23 @@
 "TransactionFactory (<literal>org.hibernate.TransactionFactory</literal>)"
 
 #. Tag: para
-#: architecture.xml:165
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "(Optional) A factory for <literal>Transaction</literal> instances. It is not "
 "exposed to the application, but it can be extended and/or implemented by the "
 "developer."
 msgstr ""
 "(Optionnel) Une fabrique d'instances de <literal>Transaction</literal>. Non "
-"exposé à l'application, mais peut être étendu/implémenté par le développeur."
+"exposée à l'application, mais peut être étendue/implémentée par le "
+"développeur. "
 
-#. Tag: emphasis
-#: architecture.xml:172
-#, no-c-format
-msgid "Extension Interfaces"
-msgstr "Interfaces d'extension"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<emphasis>Extension Interfaces</emphasis>"
+msgstr "<emphasis>Interfaces d'extension</emphasis> "
 
 #. Tag: para
-#: architecture.xml:174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate offers a range of optional extension interfaces you can implement "
 "to customize the behavior of your persistence layer. See the API "
@@ -263,31 +243,28 @@
 "Hibernate fournit de nombreuses interfaces d'extensions optionnelles que "
 "vous pouvez implémenter pour personnaliser le comportement de votre couche "
 "de persistance. Reportez vous à la documentation de l'API pour plus de "
-"détails."
+"détails. "
 
 #. Tag: para
-#: architecture.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Given a \"minimal\" architecture, the application bypasses the "
 "<literal>Transaction</literal>/<literal>TransactionFactory</literal> and/or "
 "<literal>ConnectionProvider</literal> APIs to communicate with JTA or JDBC "
 "directly."
 msgstr ""
-"Dans une architecture légère, l'application n'aura pas à utiliser les APIs "
+"Dans une architecture légère, l'application n'aura pas à utiliser les API "
 "<literal>Transaction</literal>/<literal>TransactionFactory</literal> et/ou "
-"n'utilisera pas les APIs <literal>ConnectionProvider</literal> pour utiliser "
-"JTA ou JDBC."
+"n'utilisera pas les API <literal>ConnectionProvider</literal> pour utiliser "
+"directement JTA ou JDBC. "
 
 #. Tag: title
-#: architecture.xml:191
 #, no-c-format
 msgid "Instance states"
 msgstr "Etats des instances"
 
 #. Tag: para
-#: architecture.xml:192
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of a persistent class can be in one of three different states. "
 "These states are defined in relation to a <emphasis>persistence context</"
@@ -296,35 +273,31 @@
 msgstr ""
 "Une instance d'une classe persistante peut être dans l'un des trois états "
 "suivants, définis par rapport à un <emphasis>contexte de persistance</"
-"emphasis>. L'objet <literal>Session</literal> d'hibernate correspond à ce "
-"concept de contexte de persistance :"
+"emphasis>. L'objet <literal>Session</literal> Hibernate correspond à ce "
+"contexte de persistance. Les trois états distincts sont:"
 
 #. Tag: term
-#: architecture.xml:200
 #, no-c-format
 msgid "transient"
-msgstr "passager (transient)"
+msgstr "éphémère (transient)"
 
 #. Tag: para
-#: architecture.xml:202
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The instance is not associated with any persistence context. It has no "
 "persistent identity or primary key value."
 msgstr ""
 "L'instance n'est pas et n'a jamais été associée à un contexte de "
 "persistance. Elle ne possède pas d'identité persistante (valeur de clé "
-"primaire)"
+"primaire)."
 
 #. Tag: term
-#: architecture.xml:210
 #, no-c-format
 msgid "persistent"
 msgstr "persistant"
 
 #. Tag: para
-#: architecture.xml:212
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The instance is currently associated with a persistence context. It has a "
 "persistent identity (primary key value) and can have a corresponding row in "
@@ -332,22 +305,20 @@
 "<emphasis>guarantees</emphasis> that persistent identity is equivalent to "
 "Java identity in relation to the in-memory location of the object."
 msgstr ""
-"L'instance est associée au contexte de persistance. Elle possède une "
-"identité persistante (valeur de clé primaire) et, peut-être, un "
-"enregistrement correspondant dans la base. Pour un contexte de persistance "
-"particulier, Hibernate <emphasis>garantit</emphasis> que l'identité "
-"persistante est équivalente à l'identité Java (emplacement mémoire de "
-"l'objet)"
+"L'instance est associée à un contexte de persistance. Elle possède une "
+"identité persistante (valeur de clé primaire) et, peut-être un "
+"enregistrement correspondant dans la base de données. Pour un contexte de "
+"persistance particulier, Hibernate <emphasis>garantit</emphasis> que "
+"l'identité persistante soit équivalente à l'identité Java (emplacement "
+"mémoire de l'objet). "
 
 #. Tag: term
-#: architecture.xml:224
 #, no-c-format
 msgid "detached"
 msgstr "détaché"
 
 #. Tag: para
-#: architecture.xml:226
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The instance was once associated with a persistence context, but that "
 "context was closed, or the instance was serialized to another process. It "
@@ -358,18 +329,16 @@
 "L'instance a été associée au contexte de persistance mais ce contexte a été "
 "fermé, ou l'instance a été sérialisée vers un autre processus. Elle possède "
 "une identité persistante et peut-être un enregistrement correspondant dans "
-"la base. Pour des instances détachées, Hibernate ne donne aucune garantie "
-"sur la relation entre l'identité persistante et l'identité Java."
+"la base de données. Pour des instances détachées, Hibernate ne donne aucune "
+"garantie sur la relation entre l'identité persistante et l'identité Java. "
 
 #. Tag: title
-#: architecture.xml:241
 #, no-c-format
 msgid "JMX Integration"
 msgstr "Intégration JMX"
 
 #. Tag: para
-#: architecture.xml:243
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "JMX is the J2EE standard for the management of Java components. Hibernate "
 "can be managed via a JMX standard service. AN MBean implementation is "
@@ -379,24 +348,22 @@
 "JMX est le standard J2EE de gestion des composants Java. Hibernate peut être "
 "géré via un service JMX standard. Nous fournissons une implémentation d'un "
 "MBean dans la distribution : <literal>org.hibernate.jmx.HibernateService</"
-"literal>."
+"literal>. "
 
 #. Tag: para
-#: architecture.xml:249
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For an example of how to deploy Hibernate as a JMX service on the JBoss "
 "Application Server, please see the JBoss User Guide. JBoss AS also provides "
 "these benefits if you deploy using JMX:"
 msgstr ""
-"Pour avoir un exemple sur la manière de déployer Hibernate en tant que "
-"service JMX dans le serveur d'application JBoss Application Server, référez "
-"vous au guide utilisateur JBoss (JBoss User Guide). Si vous déployez "
-"Hibernate via JMX sur JBoss AS, vous aurez également les bénéfices suivants :"
+"Pour un exemple sur la manière de déployer Hibernate en tant que service JMX "
+"dans le serveur d'application JBoss Application Server, référez vous au "
+"guide de l'utilisateur JBoss (JBoss User Guide). Si vous déployez Hibernate "
+"via JMX sur JBoss AS, vous aurez également les avantages suivants : "
 
 #. Tag: para
-#: architecture.xml:257
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Session Management</emphasis>: the Hibernate <literal>Session</"
 "literal>'s life cycle can be automatically bound to the scope of a JTA "
@@ -408,20 +375,19 @@
 "the <literal>HibernateContext</literal> to access a <literal>Session</"
 "literal>."
 msgstr ""
-"<emphasis>Gestion de la session :</emphasis> Le cycle de vie de la "
-"<literal>Session</literal> Hibernate peut être automatiquement limitée à la "
+"<emphasis>Gestion de la session</emphasis> : le cycle de vie de la "
+"<literal>Session</literal> Hibernate peut être automatiquement liée à la "
 "portée d'une transaction JTA. Cela signifie que vous n'avez plus besoin "
 "d'ouvrir et de fermer la <literal>Session</literal> manuellement, cela "
 "devient le travail de l'intercepteur EJB de JBoss. Vous n'avez pas non plus "
 "à vous occuper des démarcations des transactions dans votre code (sauf si "
 "vous voulez écrire une couche de persistance qui soit portable, dans ce cas "
-"vous pouvez utiliser l'API optionnelle <literal>Transaction</literal> "
-"d'Hibernate). Vous appelez l'<literal>HibernateContext</literal> pour "
-"accéder à la <literal>Session</literal>."
+"vous pouvez utiliser l'API optionnelle <literal>Transaction</literal> de "
+"Hibernate). Vous appelez le <literal>HibernateContext</literal> pour accéder "
+"à la <literal>Session</literal>. "
 
 #. Tag: para
-#: architecture.xml:269
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>HAR deployment</emphasis>: the Hibernate JMX service is deployed "
 "using a JBoss service deployment descriptor in an EAR and/or SAR file, as it "
@@ -431,17 +397,16 @@
 "deployment, JBoss will automatically detect all mapping files in your HAR "
 "file."
 msgstr ""
-"<emphasis>Déploiement HAR :</emphasis> Habituellement vous déployez le "
+"<emphasis>Déploiement HAR :</emphasis>: habituellement vous déployez le "
 "service JMX Hibernate en utilisant le descripteur de déploiement de JBoss "
-"(dans un fichier EAR et/ou un SAR), il supporte toutes les options de "
+"dans un fichier EAR et/ou un SAR, car il supporte toutes les options de "
 "configuration usuelles d'une <literal>SessionFactory</literal> Hibernate. "
-"Cependant, vous devez toujours nommer tous vos fichiers de mapping dans le "
+"Cependant, vous devez toujours nommer tous vos fichiers de mappage dans le "
 "descripteur de déploiement. Si vous décidez d'utiliser le déploiement "
 "optionnel sous forme de HAR, JBoss détectera automatiquement tous vos "
 "fichiers de mapping dans votre fichier HAR."
 
 #. Tag: para
-#: architecture.xml:280
 #, no-c-format
 msgid ""
 "Consult the JBoss AS user guide for more information about these options."
@@ -450,26 +415,23 @@
 "ces options."
 
 #. Tag: para
-#: architecture.xml:284
 #, fuzzy, no-c-format
 msgid ""
 "Another feature available as a JMX service is runtime Hibernate statistics. "
-"See <xref linkend=\"configuration-optional-statistics\"/> for more "
+"See <xref linkend=\"configuration-optional-statistics\" /> for more "
 "information."
 msgstr ""
-"Les statistiques pendant l'exécution d'Hibernate (au runtime) sont une autre "
-"fonctionnalité disponible en tant que service JMX. Voyez pour cela <xref "
-"linkend=\"configuration-optional-statistics\"/>."
+"Les statistiques Hibernate (runtime) représentent une autre fonctionnalité "
+"qui est disponible en tant que service JMX. Voyez pour cela les <xref "
+"linkend=\"configuration-optional-statistics\" />."
 
 #. Tag: title
-#: architecture.xml:291
 #, no-c-format
 msgid "JCA Support"
 msgstr "Support JCA"
 
 #. Tag: para
-#: architecture.xml:292
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate can also be configured as a JCA connector. Please see the website "
 "for more information. Please note, however, that at this stage Hibernate JCA "
@@ -477,17 +439,15 @@
 msgstr ""
 "Hibernate peut aussi être configuré en tant que connecteur JCA. Référez-vous "
 "au site web pour de plus amples détails. Il est important de noter que le "
-"support JCA d'Hibernate est encore considéré comme expérimental."
+"support JCA de Hibernate est encore considéré comme expérimental. "
 
 #. Tag: title
-#: architecture.xml:299
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Contextual sessions"
-msgstr "Sessions Contextuelles"
+msgstr "Sessions contextuelles "
 
 #. Tag: para
-#: architecture.xml:300
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Most applications using Hibernate need some form of \"contextual\" session, "
 "where a given session is in effect throughout the scope of a given context. "
@@ -500,20 +460,19 @@
 "proxy/interception-based contextual sessions."
 msgstr ""
 "Certaines applications utilisant Hibernate ont besoin d'une sorte de session "
-"\"contextuelle\", où une session est liée à la portée d'un contexte "
-"particulier. Cependant, les applications ne définissent pas toutes la notion "
-"de contexte de la même manière, et différents contextes définissent "
-"différentes portées à la notion de \"courant\". Les applications à base "
-"d'Hibernate, versions précédentes à la 3.0 utilisaient généralement un "
-"principe maison de sessions contextuelles basées sur le "
+"\"contextuelle\", où une session donnée est en effet liée à la portée d'un "
+"contexte particulier. Cependant, les applications ne définissent pas toutes "
+"la notion de contexte de la même manière, et différents contextes "
+"définissent différentes portées à la notion de \"courant\". Les applications "
+"qui utilisaient Hibernate, versions précédentes à la 3.0, avaient tendance à "
+"employer un principe maison de sessions contextuelles basées sur le "
 "<literal>ThreadLocal</literal>, ainsi que sur des classes utilitaires comme "
 "<literal>HibernateUtil</literal>, ou utilisaient des framework tiers (comme "
 "Spring ou Pico) qui fournissaient des sessions contextuelles basées sur "
-"l'utilisation de proxy/interception."
+"l'utilisation de proxy/interception. "
 
 #. Tag: para
-#: architecture.xml:309
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Starting with version 3.0.1, Hibernate added the <literal>SessionFactory."
 "getCurrentSession()</literal> method. Initially, this assumed usage of "
@@ -530,16 +489,15 @@
 "demandait l'usage de transactions <literal>JTA</literal>, où la transaction "
 "<literal>JTA</literal> définissait la portée et le contexte de la session "
 "courante. L'équipe Hibernate pense que, étant donnée la maturité des "
-"implémentations de <literal>JTA TransactionManager</literal> , la plupart "
-"(sinon toutes) des applications devraient utiliser la gestion des "
-"transactions par <literal>JTA</literal> qu'elles soient ou non déployées "
-"dans un conteneur <literal>J2EE</literal>. Par conséquent, vous devriez "
-"toujours contextualiser vos sessions, si vous en avez besoin, via la méthode "
-"basée sur JTA."
+"nombreuses implémentations autonomes du <literal>JTA TransactionManager</"
+"literal>, la plupart (sinon toutes) des applications devraient utiliser la "
+"gestion des transactions par <literal>JTA</literal> qu'elles soient ou non "
+"déployées dans un conteneur <literal>J2EE</literal>. Par conséquent, il vous "
+"suffira de contextualiser vos sessions via la méthode basée sur "
+"<literal>JTA</literal>. "
 
 #. Tag: para
-#: architecture.xml:319
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, as of version 3.1, the processing behind <literal>SessionFactory."
 "getCurrentSession()</literal> is now pluggable. To that end, a new extension "
@@ -550,15 +508,14 @@
 msgstr ""
 "Cependant, depuis la version 3.1, la logique derrière "
 "<literal>SessionFactory.getCurrentSession()</literal> est désormais "
-"branchable. A cette fin, une nouvelle interface d'extension (<literal>org."
-"hibernate.context.CurrentSessionContext</literal>) et un nouveau paramètre "
-"de configuration (<literal>hibernate.current_session_context_class</"
-"literal>) ont été ajoutés pour permettre de configurer d'autres moyens de "
-"définir la portée et le contexte des sessions courantes."
+"enfichable. A cette fin, une nouvelle interface d'extension(<literal>org."
+"hibernate.context.CurrentSessionContext</literal> et un nouveau paramètre de "
+"configuration <literal>hibernate.current_session_context_class</literal> ont "
+"été ajoutés pour enficher la portée et le contexte de sessions courantes "
+"caractéristiques."
 
 #. Tag: para
-#: architecture.xml:326
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "See the Javadocs for the <literal>org.hibernate.context."
 "CurrentSessionContext</literal> interface for a detailed discussion of its "
@@ -567,16 +524,14 @@
 "contextual session. Out-of-the-box, Hibernate comes with three "
 "implementations of this interface:"
 msgstr ""
-"Allez voir les Javadocs de l'interface <literal>org.hibernate.context."
-"CurrentSessionContext</literal> pour une description détaillée de son "
-"contrat. Elle définit une seule méthode, <literal>currentSession()</"
-"literal>, depuis laquelle l'implémentation est responsable de traquer la "
-"session courante du contexte. Hibernate fournit deux implémentation de cette "
-"interface."
+"Pour une description détaillée de son contrat, consultez les Javadocs de "
+"l'interface <literal>org.hibernate.context.CurrentSessionContext</literal>. "
+"Elle définit une seule méthode, <literal>currentSession()</literal>, par "
+"laquelle l'implémentation est responsable de traquer la session contextuelle "
+"courante. Hibernate fournit trois implémentations de cette interface :"
 
 #. Tag: para
-#: architecture.xml:336
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.context.JTASessionContext</literal>: current sessions "
 "are tracked and scoped by a <literal>JTA</literal> transaction. The "
@@ -585,36 +540,34 @@
 msgstr ""
 "<literal>org.hibernate.context.JTASessionContext</literal> - les sessions "
 "courantes sont associées à une transaction <literal>JTA</literal>. La "
-"logique est la même que l'ancienne approche basée sur JTA. Voir les javadocs "
-"pour les détails."
+"logique est la même que l'ancienne approche basée sur JTA. Consultez les "
+"javadocs pour pour plus d'informations. "
 
 #. Tag: para
-#: architecture.xml:344
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.context.ThreadLocalSessionContext</literal>:current "
 "sessions are tracked by thread of execution. See the Javadocs for details."
 msgstr ""
 "<literal>org.hibernate.context.ThreadLocalSessionContext</literal> - les "
-"sessions courantes sont associées au thread d'exécution. Voir les javadocs "
-"pour les détails."
+"sessions courantes sont traquées par l'exécution du thread. Consultez les "
+"javadocs pour plus d'informations. "
 
 #. Tag: para
-#: architecture.xml:350
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.context.ManagedSessionContext</literal>: current "
 "sessions are tracked by thread of execution. However, you are responsible to "
 "bind and unbind a <literal>Session</literal> instance with static methods on "
 "this class: it does not open, flush, or close a <literal>Session</literal>."
 msgstr ""
-"<literal>org.hibernate.context.ManagedSessionContext</literal> - current "
-"sessions are tracked by thread of execution. However, you are responsible to "
-"bind and unbind a <literal>Session</literal> instance with static methods on "
-"this class, it does never open, flush, or close a <literal>Session</literal>."
+"<literal>org.hibernate.context.ManagedSessionContext</literal> - les "
+"sessions courantes sont traquées par l'exécution du thread. Toutefois, vous "
+"êtes responsable de lier et de délier une instance de <literal>Session</"
+"literal> avec des méthodes statiques de cette classe.  Elle n'ouvre jamais, "
+"ni ne nettoie ou ne ferme une <literal>Session</literal>."
 
 #. Tag: para
-#: architecture.xml:359
 #, fuzzy, no-c-format
 msgid ""
 "The first two implementations provide a \"one session - one database "
@@ -627,25 +580,24 @@
 "utilize the JTA interfaces to demarcate transactions. If you execute in an "
 "EJB container that supports CMT, transaction boundaries are defined "
 "declaratively and you do not need any transaction or session demarcation "
-"operations in your code. Refer to <xref linkend=\"transactions\"/> for more "
+"operations in your code. Refer to <xref linkend=\"transactions\" /> for more "
 "information and code examples."
 msgstr ""
-"Les deux implémentations fournissent un modèle de programmation de type "
-"\"une session - une transaction à la base de données\", aussi connu sous le "
-"nom de <emphasis>session-per-request</emphasis>. Le début et la fin d'une "
+"Les deux premières implémentations fournissent un modèle de programmation de "
+"type \"une session - une transaction de base de données\", aussi connu sous "
+"le nom de <emphasis>session-per-request</emphasis>. Le début et la fin d'une "
 "session Hibernate sont définis par la durée d'une transaction de base de "
 "données. Si vous utilisez une démarcation programmatique de la transaction "
-"(par exemple sous J2SE ou JTA/UserTransaction/BMT), nous vous conseillons "
-"d'utiliser l'API Hibernate <literal>Transaction</literal> pour masquer le "
-"système de transaction utilisé. Si vous exécutez sous un conteneur EJB qui "
-"supporte CMT, vous n'avez besoin d'aucune opérations de démarcations de "
-"session ou transaction dans votre code puisque tout est géré de manière "
-"déclarative. Référez vous à <xref linkend=\"transactions\"/> pour plus "
-"d'informations et des exemples de code."
+"avec JSE sans JTA, nous vous conseillons d'utiliser l'API Hibernate "
+"<literal>Transaction</literal> pour masquer le système de transaction sous-"
+"jacent à votre code. Si vous exécutez sous un conteneur EJB qui prend en "
+"charge CMT, vous n'avez besoin d'aucune opération de démarcation de session "
+"ou transaction dans votre code puisque tout est géré de manière déclarative. "
+"Référez vous au <xref linkend=\"transactions\" /> pour plus d'informations "
+"et des exemples de code."
 
 #. Tag: para
-#: architecture.xml:371
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>hibernate.current_session_context_class</literal> configuration "
 "parameter defines which <literal>org.hibernate.context."
@@ -666,5 +618,6 @@
 "hibernate.transaction.TransactionManagerLookup</literal> est configuré, "
 "Hibernate utilisera le <literal>org.hibernate.context.JTASessionContext</"
 "literal>. La valeur de ce paramètre devrait juste nommer la classe "
-"d'implémentation à utiliser, pour les deux implémentations fournies, il y a "
-"cependant deux alias correspondant: \"jta\" et \"thread\"."
+"d'implémentation à utiliser. Pour les trois implémentations prêtes à "
+"utiliser, toutefois, il y a trois noms brefs correspondants : \"jta\", "
+"\"thread\" et \"managed\"."

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/association_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/association_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/association_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,30 +1,33 @@
+# translation of association_mapping.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: association_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2009-11-10 14:49+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: association_mapping.xml:30
 #, no-c-format
 msgid "Association Mappings"
 msgstr "Mapper les associations"
 
 #. Tag: title
-#: association_mapping.xml:33
 #, no-c-format
 msgid "Introduction"
 msgstr "Introduction"
 
 #. Tag: para
-#: association_mapping.xml:35
-#, fuzzy, no-c-format
+#, 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, "
@@ -32,28 +35,23 @@
 "use <literal>Person</literal> and <literal>Address</literal> in all the "
 "examples."
 msgstr ""
-"Correctement mapper les associations est souvent la tâche la plus difficile. "
-"Dans cette section nous traiterons les cas classiques les uns après les "
-"autres. Nous commencerons d'abbord par les mappings unidirectionnels, puis "
-"nous aborderons la question des mappings bidirectionnels. Nous illustrerons "
-"tous nos exemples avec les classes <literal>Person</literal> et "
-"<literal>Address</literal>."
+"Mapper les associations correctement, est souvent la tâche la plus "
+"difficile. Dans cette section, nous traiterons les cas classiques, un par "
+"un, en commençant par les mappages unidirectionnels, puis nous aborderons la "
+"question des mappages bidirectionnels. Nous illustrons tous nos exemples "
+"avec les classes <literal>Person</literal> et <literal>Address</literal>."
 
 #. Tag: para
-#: association_mapping.xml:43
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Associations will be classified by multiplicity and whether or not they map "
 "to an intervening join table."
 msgstr ""
-"Nous utiliserons deux critères pour classer les associations : le premier "
-"sera de savoir si l'association est bâti sur une table supplémentaire "
-"d'association et le deuxieme sera basé sur la multiplicité de cette "
-"association."
+"Nous classifions les associations selon qu'elles sont ou non bâties sur une "
+"table de jointure supplémentaire et sur la multiplicité. "
 
 #. Tag: para
-#: association_mapping.xml:48
-#, fuzzy, no-c-format
+#, 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 "
@@ -64,476 +62,153 @@
 "la construction d'un modèle de données. Nous supposerons donc que dans tous "
 "les exemples qui vont suivre on aura interdit la valeur nulle pour les clés "
 "étrangères. Attention, ceci ne veut pas dire que Hibernate ne supporte pas "
-"les clés étrangères pouvant prendre des valeurs nulles, les exemples qui "
+"les clés étrangères pouvant prendre des valeurs nulles, et les exemples qui "
 "suivent continueront de fonctionner si vous décidiez ne plus imposer la "
 "contrainte de non-nullité sur les clés étrangères."
 
 #. Tag: title
-#: association_mapping.xml:58
 #, no-c-format
 msgid "Unidirectional associations"
-msgstr "Association unidirectionnelle"
+msgstr "Associations unidirectionnelles"
 
 #. Tag: title
-#: association_mapping.xml:61 association_mapping.xml:132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Many-to-one"
-msgstr "plusieurs à un"
+msgstr "plusieurs-à-un "
 
 #. Tag: para
-#: association_mapping.xml:63
 #, no-c-format
 msgid ""
 "A <emphasis>unidirectional many-to-one association</emphasis> is the most "
 "common kind of unidirectional association."
 msgstr ""
-"Une <emphasis>association plusieurs-à-un (many-to-one) unidirectionnelle </"
-"emphasis> est le type que l'on rencontre le plus souvent dans les "
-"associations unidirectionnelles."
+"Une <emphasis>association plusieurs-à-un unidirectionnelle </emphasis> est "
+"le type que l'on rencontre le plus souvent dans les associations "
+"unidirectionnelles."
 
-#. Tag: programlisting
-#: association_mapping.xml:68
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:69 association_mapping.xml:185
-#, no-c-format
-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 ""
-
-#. Tag: title
-#: association_mapping.xml:74 association_mapping.xml:145
-#: association_mapping.xml:210
-#, fuzzy, no-c-format
 msgid "One-to-one"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"un à un\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"un à un\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Un à un\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Un à un"
+msgstr "Un-à-un"
 
 #. Tag: para
-#: association_mapping.xml:76
 #, no-c-format
 msgid ""
 "A <emphasis>unidirectional one-to-one association on a foreign key</"
 "emphasis> is almost identical. The only difference is the column unique "
 "constraint."
 msgstr ""
-"une <emphasis>association un-à-un (one-to-one) sur une clé étrangère</"
-"emphasis> est presque identique. La seule différence est sur la contrainte "
-"d'unicité que l'on impose à cette colonne."
+"Une <emphasis>association un-à-un sur une clé étrangère</emphasis> est "
+"presque identique. La seule différence est sur la contrainte d'unicité que "
+"l'on impose à cette colonne."
 
-#. Tag: programlisting
-#: association_mapping.xml:81
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:82 association_mapping.xml:218
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:84
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>unidirectional one-to-one association on a primary key</"
 "emphasis> usually uses a special id generator In this example, however, we "
 "have reversed the direction of the association:"
 msgstr ""
-"Une <emphasis>association un-à-un (one-to-one) unidirectionnelle sur une clé "
-"primaire</emphasis> utilise un générateur d'identifiant particulier. "
-"(Remarquez que nous avons inversé le sens de cette association dans cet "
-"exemple.)"
+"Une <emphasis>association un-à-un unidirectionnelle sur une clé primaire</"
+"emphasis> utilise un générateur d'identifiant particulier. Remarquez que "
+"nous avons inversé le sens de cette association dans cet exemple :"
 
-#. Tag: programlisting
-#: association_mapping.xml:90
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" constrained=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:91 association_mapping.xml:226
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"create table Person ( personId bigint not null primary key )\n"
-"create table Address ( personId bigint not null primary key )\n"
-"        ]]>"
-msgstr ""
-
-#. Tag: title
-#: association_mapping.xml:96 association_mapping.xml:118
-#, fuzzy, no-c-format
 msgid "One-to-many"
-msgstr "un à plusieurs"
+msgstr "un-à-plusieurs"
 
 #. Tag: para
-#: association_mapping.xml:98
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>unidirectional one-to-many association on a foreign key</"
 "emphasis> is an unusual case, and is not recommended."
 msgstr ""
-"Une <emphasis>association un-à-plusieurs (one-to-many) unidirectionnelle sur "
-"une clé étrangère</emphasis> est vraiment inhabituelle, et n'est pas "
-"vraiment recommandée."
+"Une <emphasis>association un-à-plusieurs unidirectionnelle sur une clé "
+"étrangère</emphasis> est un cas inhabituel, et n'est pas vraiment "
+"recommandée."
 
-#. Tag: programlisting
-#: association_mapping.xml:103
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\">\n"
-"        <key column=\"personId\" \n"
-"            not-null=\"true\"/>\n"
-"        <one-to-many class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:104
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:106
-#, fuzzy, no-c-format
 msgid "You should instead use a join table for this kind of association."
 msgstr ""
 "Nous pensons qu'il est préférable d'utiliser une table de jointure pour ce "
-"type d'association."
+"type d'association. "
 
 #. Tag: title
-#: association_mapping.xml:115
 #, no-c-format
 msgid "Unidirectional associations with join tables"
 msgstr "Associations unidirectionnelles avec tables de jointure"
 
 #. Tag: para
-#: association_mapping.xml:120
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>unidirectional one-to-many association on a join table</"
 "emphasis> is the preferred option. Specifying <literal>unique=\"true\"</"
 "literal>, changes the multiplicity from many-to-many to one-to-many."
 msgstr ""
-"Une <emphasis>association unidirectionnelle un-à-plusieurs (one-to-many) "
-"avec une table de jointure</emphasis> est un bien meilleur choix. Remarquez "
-"qu'en spécifiant <literal>unique=\"true\"</literal>, on a changé la "
-"multiplicité plusieurs-à-plusieurs (many-to-many) pour un-à-plusieurs (one-"
-"to-many)."
+"Une <emphasis>association unidirectionnelle un-à-plusieurs avec une table de "
+"jointure</emphasis> est un bien meilleur choix. Remarquez qu'en spécifiant "
+"<literal>unique=\"true\"</literal>, on a changé la multiplicité plusieurs-à-"
+"plusieurs pour un-à-plusieurs. "
 
-#. Tag: programlisting
-#: association_mapping.xml:126
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:127
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:134
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>unidirectional many-to-one association on a join table</"
 "emphasis> is common when the association is optional. For example:"
 msgstr ""
-"Une <emphasis>assiociation plusieurs-à-un (many-to-one) unidirectionnelle "
-"sur une table de jointure</emphasis> est très fréquente quand l'association "
-"est optionnelle."
+"Une <emphasis>assiociation plusieurs-à-un unidirectionnelle sur une table de "
+"jointure</emphasis> est assez fréquente quand l'association est optionnelle. "
+"Par exemple :"
 
-#. Tag: programlisting
-#: association_mapping.xml:139
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:140
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:147
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>unidirectional one-to-one association on a join table</emphasis> "
 "is possible, but extremely unusual."
 msgstr ""
-"Une <emphasis>association unidirectionnelle un-à-un (one-to-one) sur une "
-"table de jointure</emphasis> est extrèmement rare mais envisageable."
+"Une <emphasis>association unidirectionnelle un-à-un sur une table de "
+"jointure</emphasis> est extrêmement rare mais envisageable. "
 
-#. Tag: programlisting
-#: association_mapping.xml:152
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:153 association_mapping.xml:258
-#, no-c-format
-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 ""
-
-#. Tag: title
-#: association_mapping.xml:158 association_mapping.xml:263
-#, fuzzy, no-c-format
 msgid "Many-to-many"
-msgstr "plusieurs à plusieurs"
+msgstr "Plusieurs-à-plusieurs "
 
 #. Tag: para
-#: association_mapping.xml:160
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, here is an example of a <emphasis>unidirectional many-to-many "
 "association</emphasis>."
 msgstr ""
-"Finallement, nous avons <emphasis>l'association unidirectionnelle plusieurs-"
-"à-plusieurs (many-to-many)</emphasis>."
+"Finalement, nous avons un exemple d' <emphasis>association unidirectionnelle "
+"plusieurs-à-plusieurs</emphasis>."
 
-#. Tag: programlisting
-#: association_mapping.xml:164
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:165 association_mapping.xml:271
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: association_mapping.xml:172
 #, no-c-format
 msgid "Bidirectional associations"
-msgstr "Associations bidirectionnelles"
+msgstr "Associations bidirectionnelles "
 
 #. Tag: title
-#: association_mapping.xml:175 association_mapping.xml:236
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "one-to-many / many-to-one"
-msgstr "un à plusieurs / plusieurs à un"
+msgstr "un-à-plusieurs / plusieurs-à-un "
 
 #. Tag: para
-#: association_mapping.xml:177
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional many-to-one association</emphasis> is the most "
 "common kind of association. The following example illustrates the standard "
 "parent/child relationship."
 msgstr ""
-"Une <emphasis>association bidirectionnelle plusieurs à un (many-to-one)</"
-"emphasis> est le type d'association que l'on rencontre le plus souvent. "
-"(c'est la façon standard de créer des relations parents/enfants.)"
+"Une <emphasis>association bidirectionnelle plusieurs-à-un</emphasis> est le "
+"type d'association que l'on rencontre le plus fréquemment. L'exemple suivant "
+"illustre la façon standard de créer des relations parents/enfants."
 
-#. Tag: programlisting
-#: association_mapping.xml:183
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <one-to-many class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:187
-#, fuzzy, no-c-format
-msgid ""
 "If you use a <literal>List</literal>, or other indexed collection, set the "
 "<literal>key</literal> column of the foreign key to <literal>not null</"
 "literal>. Hibernate will manage the association from the collections side to "
@@ -541,42 +216,16 @@
 "by setting <literal>update=\"false\"</literal> and <literal>insert=\"false"
 "\"</literal>:"
 msgstr ""
-"Si vous utilisez une <literal>List</literal> (ou toute autre collection "
-"indexée) vous devez paramétrer la colonne <literal>key</literal> de la clé "
+"Si vous utilisez une <literal>List</literal>, ou toute autre collection "
+"indexée, vous devez paramétrer la colonne <literal>key</literal> de la clé "
 "étrangère à <literal>not null</literal>, et laisser Hibernate gérer "
 "l'association depuis l'extrémité collection pour maintenir l'index de chaque "
 "élément (rendant l'autre extrémité virtuellement inverse en paramétrant "
-"<literal>update=\"false\"</literal> et <literal>insert=\"false\"</literal>):"
+"<literal>update=\"false\"</literal> et <literal>insert=\"false\"</literal>) :"
 
-#. Tag: programlisting
-#: association_mapping.xml:195
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"   <id name=\"id\"/>\n"
-"   ...\n"
-"   <many-to-one name=\"address\"\n"
-"      column=\"addressId\"\n"
-"      not-null=\"true\"\n"
-"      insert=\"false\"\n"
-"      update=\"false\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"   <id name=\"id\"/>\n"
-"   ...\n"
-"   <list name=\"people\">\n"
-"      <key column=\"addressId\" not-null=\"true\"/>\n"
-"      <list-index column=\"peopleIdx\"/>\n"
-"      <one-to-many class=\"Person\"/>\n"
-"   </list>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:197
-#, fuzzy, no-c-format
-msgid ""
 "If the underlying foreign key column is <literal>NOT NULL</literal>, it is "
 "important that you define <literal>not-null=\"true\"</literal> on the "
 "<literal>&lt;key&gt;</literal> element of the collection mapping. Do not "
@@ -584,248 +233,79 @@
 "<literal>&lt;column&gt;</literal> element, but on the <literal>&lt;key&gt;</"
 "literal> element."
 msgstr ""
-"It is important that you define <literal>not-null=\"true\"</literal> on the "
-"<literal>&lt;key&gt;</literal> element of the collection mapping if the "
-"underlying foreign key column is <literal>NOT NULL</literal>. Don't only "
-"declare <literal>not-null=\"true\"</literal> on a possible nested "
-"<literal>&lt;column&gt;</literal> element, but on the <literal>&lt;key&gt;</"
-"literal> element."
+"Il est important de définir <literal>not-null=\"true</literal> sur l'élément "
+"<literal>&lt;key&gt;</literal> du mapping de la collection si la colonne de "
+"clé étrangère sous-jacente est <literal>NOT NULL</literal>. Ne déclarez pas "
+"seulement <literal>not-null=\"true\"</literal> sur un élément imbriqué "
+"possible<literal>&lt;column&gt;</literal>, mais sur l'élément <literal>&lt;"
+"key&gt;</literal>."
 
 #. Tag: para
-#: association_mapping.xml:212
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional one-to-one association on a foreign key</emphasis> "
 "is common:"
 msgstr ""
-"Une <emphasis>association bidirectionnelle un à un (one-to-one) sur une clé "
-"étrangère</emphasis> est aussi très fréquente."
+"Une <emphasis>association bidirectionnelle un-à-un sur une clé étrangère</"
+"emphasis> est assez fréquente :"
 
-#. Tag: programlisting
-#: association_mapping.xml:217
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"   <one-to-one name=\"person\" \n"
-"        property-ref=\"address\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:220
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>bidirectional one-to-one association on a primary key</emphasis> "
 "uses the special id generator:"
 msgstr ""
-"Une <emphasis>association bidirectionnelle un-à-un (one-to-one) sur une clé "
-"primaire</emphasis> utilise un générateur particulier d'id."
+"Une <emphasis>association bidirectionnelle un-à-un sur une clé primaire</"
+"emphasis> utilise un générateur particulier d'id :"
 
-#. Tag: programlisting
-#: association_mapping.xml:225
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <one-to-one name=\"address\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" \n"
-"        constrained=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: association_mapping.xml:233
 #, no-c-format
 msgid "Bidirectional associations with join tables"
-msgstr "Associations bidirectionnelles avec table de jointure"
+msgstr "Associations bidirectionnelles avec tables de jointure"
 
 #. Tag: para
-#: association_mapping.xml:238
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is an example of a <emphasis>bidirectional one-to-many "
 "association on a join table</emphasis>. The <literal>inverse=\"true\"</"
 "literal> can go on either end of the association, on the collection, or on "
 "the join."
 msgstr ""
-"Une <emphasis>association bidirectionnelle un-à-plusieurs (one-to-many) sur "
-"une table de jointure </emphasis>. Remarquez que <literal>inverse=\"true\"</"
-"literal> peut s'appliquer sur les deux extrémités de l' association, sur la "
-"collection, ou sur la jointure."
+"Une <emphasis>association bidirectionnelle un-à-plusieurs sur une table de "
+"jointure</emphasis>. Remarquez que <literal>inverse=\"true\"</literal> peut "
+"s'appliquer sur les deux extrémités de l'association, sur la collection, ou "
+"sur la jointure."
 
-#. Tag: programlisting
-#: association_mapping.xml:244
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" \n"
-"        table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        inverse=\"true\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-one name=\"person\"\n"
-"            column=\"personId\"\n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:245
-#, no-c-format
-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 ""
-
-#. Tag: title
-#: association_mapping.xml:250
-#, fuzzy, no-c-format
 msgid "one to one"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"un à un\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"un à un\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Un à un\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Un à un"
+msgstr "un-à-un"
 
 #. Tag: para
-#: association_mapping.xml:252
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional one-to-one association on a join table</emphasis> "
 "is possible, but extremely unusual."
 msgstr ""
-"Une <emphasis>association bidirectionnelle un-à-un (one-to-one) sur une "
-"table de jointure</emphasis> est extrèmement rare mais envisageable."
+"Une <emphasis>association bidirectionnelle un-à-un sur une table de "
+"jointure</emphasis> est extrêmement rare mais envisageable. "
 
-#. Tag: programlisting
-#: association_mapping.xml:257
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\"\n"
-"        inverse=\"true\">\n"
-"        <key column=\"addressId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"person\"\n"
-"            column=\"personId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:265
-#, fuzzy, no-c-format
-msgid ""
 "Here is an example of a <emphasis>bidirectional many-to-many association</"
 "emphasis>."
 msgstr ""
-"Finallement nous avons <emphasis>l'association bidirectionnelle plusieurs à "
-"plusieurs</emphasis>."
+"Finalement nous avons <emphasis>l'association bidirectionnelle plusieurs-à-"
+"plusieurs</emphasis>. "
 
-#. Tag: programlisting
-#: association_mapping.xml:269
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-many column=\"personId\"\n"
-"            class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: association_mapping.xml:278
 #, no-c-format
 msgid "More complex association mappings"
-msgstr "Des mappings plus complexes"
+msgstr "Des mappages d'associations plus complexes"
 
 #. Tag: para
-#: association_mapping.xml:280
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "More complex association joins are <emphasis>extremely</emphasis> rare. "
 "Hibernate handles more complex situations by using SQL fragments embedded in "
@@ -836,53 +316,25 @@
 msgstr ""
 "Des associations encore plus complexes sont <emphasis>extrêmement</emphasis> "
 "rares. Hibernate permet de gérer des situations plus complexes en utilisant "
-"des parties SQL dans les fichiers de mapping. Par exemple, si une table avec "
-"l'historiques des informations d'un compte définit les colonnes "
+"des extraits SQL embarqués dans le fichier de mapping. Par exemple, si une "
+"table avec des informations historiques sur un compte définit les colonnes "
 "<literal>accountNumber</literal>, <literal>effectiveEndDate</literal> et "
-"<literal>effectiveStartDate</literal>, mappées de telle sorte:"
+"<literal>effectiveStartDate</literal>, elle sera mappée de la façon "
+"suivante : "
 
-#. Tag: programlisting
-#: association_mapping.xml:289
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<properties name=\"currentAccountKey\">\n"
-"    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
-"    <property name=\"currentAccount\" type=\"boolean\">\n"
-"        <formula>case when effectiveEndDate is null then 1 else 0 end</"
-"formula>\n"
-"    </property>\n"
-"</properties>\n"
-"<property name=\"effectiveEndDate\" type=\"date\"/>\n"
-"<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:291
-#, fuzzy, no-c-format
-msgid ""
 "You can then map an association to the <emphasis>current</emphasis> "
 "instance, the one with null <literal>effectiveEndDate</literal>, by using:"
 msgstr ""
-"alors nous pouvons mapper une association à l'instance <emphasis>courante</"
-"emphasis> (celle avec une <literal>effectiveEndDate</literal>) nulle en "
-"utilisant:"
+"Nous pouvons mapper une association à l'instance <emphasis>courante</"
+"emphasis>, celle avec une <literal>effectiveEndDate</literal> nulle, en "
+"utilisant :"
 
-#. Tag: programlisting
-#: association_mapping.xml:296
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
-"        property-ref=\"currentAccountKey\"\n"
-"        class=\"AccountInfo\">\n"
-"    <column name=\"accountNumber\"/>\n"
-"    <formula>'1'</formula>\n"
-"</many-to-one>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:298
-#, fuzzy, no-c-format
-msgid ""
 "In a more complex example, imagine that the association between "
 "<literal>Employee</literal> and <literal>Organization</literal> is "
 "maintained in an <literal>Employment</literal> table full of historical "
@@ -891,37 +343,805 @@
 "literal>, could be mapped in the following way:"
 msgstr ""
 "Dans un exemple plus complexe, imaginez qu'une association entre "
-"<literal>Employee</literal> et <literal>Organization</literal> est gérée "
-"dans une table <literal>Employment</literal> pleines de données historiques. "
+"<literal>Employee</literal> et <literal>Organization</literal> soit gérée "
+"dans une table <literal>Employment</literal> pleine de données historiques. "
 "Dans ce cas, une association vers l'employeur <emphasis>le plus récent</"
-"emphasis> (celui avec la <literal>startDate</literal> la plus récente) "
-"pourrait être mappée comme cela:"
+"emphasis> (celui avec la <literal>startDate</literal> (date de commencement "
+"de travail la plus récente) pourrait être mappée comme suit :"
 
-#. Tag: programlisting
-#: association_mapping.xml:306
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<join>\n"
-"    <key column=\"employeeId\"/>\n"
-"    <subselect>\n"
-"        select employeeId, orgId \n"
-"        from Employments \n"
-"        group by orgId \n"
-"        having startDate = max(startDate)\n"
-"    </subselect>\n"
-"    <many-to-one name=\"mostRecentEmployer\" \n"
-"            class=\"Organization\" \n"
-"            column=\"orgId\"/>\n"
-"</join>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:308
-#, fuzzy, 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 ""
-"Vous pouvez être créatif grace à ces possibilités, mais il est généralement "
-"plus pratique d'utiliser des requêtes HQL ou criteria dans ce genre de "
-"situation."
+"Vous pouvez être créatif grâce à ces possibilités, mais il est généralement "
+"plus pratique de gérer ce genre de cas en utilisant des requêtes HQL ou par "
+"critère."
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" constrained=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        <one-to-many class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        <one-to-many class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <one-to-many class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <one-to-many class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <many-to-one name=\"address\"\n"
+#~ "      column=\"addressId\"\n"
+#~ "      not-null=\"true\"\n"
+#~ "      insert=\"false\"\n"
+#~ "      update=\"false\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <list name=\"people\">\n"
+#~ "      <key column=\"addressId\" not-null=\"true\"/>\n"
+#~ "      <list-index column=\"peopleIdx\"/>\n"
+#~ "      <one-to-many class=\"Person\"/>\n"
+#~ "   </list>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <many-to-one name=\"address\"\n"
+#~ "      column=\"addressId\"\n"
+#~ "      not-null=\"true\"\n"
+#~ "      insert=\"false\"\n"
+#~ "      update=\"false\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <list name=\"people\">\n"
+#~ "      <key column=\"addressId\" not-null=\"true\"/>\n"
+#~ "      <list-index column=\"peopleIdx\"/>\n"
+#~ "      <one-to-many class=\"Person\"/>\n"
+#~ "   </list>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "   <one-to-one name=\"person\" \n"
+#~ "        property-ref=\"address\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "   <one-to-one name=\"person\" \n"
+#~ "        property-ref=\"address\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"address\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" \n"
+#~ "        constrained=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"address\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" \n"
+#~ "        constrained=\"true\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        inverse=\"true\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        inverse=\"true\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\"\n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"addressId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\"\n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"addressId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-many column=\"personId\"\n"
+#~ "            class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-many column=\"personId\"\n"
+#~ "            class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<properties name=\"currentAccountKey\">\n"
+#~ "    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
+#~ "    <property name=\"currentAccount\" type=\"boolean\">\n"
+#~ "        <formula>case when effectiveEndDate is null then 1 else 0 end</"
+#~ "formula>\n"
+#~ "    </property>\n"
+#~ "</properties>\n"
+#~ "<property name=\"effectiveEndDate\" type=\"date\"/>\n"
+#~ "<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<properties name=\"currentAccountKey\">\n"
+#~ "    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
+#~ "    <property name=\"currentAccount\" type=\"boolean\">\n"
+#~ "        <formula>case when effectiveEndDate is null then 1 else 0 end</"
+#~ "formula>\n"
+#~ "    </property>\n"
+#~ "</properties>\n"
+#~ "<property name=\"effectiveEndDate\" type=\"date\"/>\n"
+#~ "<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
+#~ "        property-ref=\"currentAccountKey\"\n"
+#~ "        class=\"AccountInfo\">\n"
+#~ "    <column name=\"accountNumber\"/>\n"
+#~ "    <formula>'1'</formula>\n"
+#~ "</many-to-one>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
+#~ "        property-ref=\"currentAccountKey\"\n"
+#~ "        class=\"AccountInfo\">\n"
+#~ "    <column name=\"accountNumber\"/>\n"
+#~ "    <formula>'1'</formula>\n"
+#~ "</many-to-one>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<join>\n"
+#~ "    <key column=\"employeeId\"/>\n"
+#~ "    <subselect>\n"
+#~ "        select employeeId, orgId \n"
+#~ "        from Employments \n"
+#~ "        group by orgId \n"
+#~ "        having startDate = max(startDate)\n"
+#~ "    </subselect>\n"
+#~ "    <many-to-one name=\"mostRecentEmployer\" \n"
+#~ "            class=\"Organization\" \n"
+#~ "            column=\"orgId\"/>\n"
+#~ "</join>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<join>\n"
+#~ "    <key column=\"employeeId\"/>\n"
+#~ "    <subselect>\n"
+#~ "        select employeeId, orgId \n"
+#~ "        from Employments \n"
+#~ "        group by orgId \n"
+#~ "        having startDate = max(startDate)\n"
+#~ "    </subselect>\n"
+#~ "    <many-to-one name=\"mostRecentEmployer\" \n"
+#~ "            class=\"Organization\" \n"
+#~ "            column=\"orgId\"/>\n"
+#~ "</join>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/basic_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/basic_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/basic_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,155 +1,83 @@
+# translation of basic_mapping.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: basic_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-04 17:01+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: basic_mapping.xml:29
 #, no-c-format
 msgid "Basic O/R Mapping"
-msgstr "Mapping O/R basique"
+msgstr "Mappage O/R de base"
 
 #. Tag: title
-#: basic_mapping.xml:32
 #, no-c-format
 msgid "Mapping declaration"
-msgstr "Déclaration de Mapping"
+msgstr "Déclaration de mappage"
 
 #. Tag: para
-#: basic_mapping.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Object/relational mappings are usually defined in an XML document. The "
 "mapping document is designed to be readable and hand-editable. The mapping "
 "language is Java-centric, meaning that mappings are constructed around "
 "persistent class declarations and not table declarations."
 msgstr ""
-"Les mappings Objet/relationnel sont généralement définis dans un document "
-"XML. Le document de mapping est conçu pour être lisible et éditable à la "
-"main. Le langage de mapping est Java-centrique, c'est à dire que les "
-"mappings sont construits à partir des déclarations des classes persistantes "
-"et non des déclarations des tables."
+"Les mappages objet/relationnel sont généralement définis dans un document "
+"XML. Le document de mappage est conçu pour être lisible et éditable à la "
+"main. Le langage de mappage est Java-centrique, c'est-à-dire que les "
+"mappages sont construits à partir de déclarations de classes persistantes et "
+"non à partir de déclarations de tables. "
 
 #. Tag: para
-#: basic_mapping.xml:41
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please note that even though many Hibernate users choose to write the XML by "
 "hand, a number of tools exist to generate the mapping document. These "
 "include XDoclet, Middlegen and AndroMDA."
 msgstr ""
 "Remarquez que même si beaucoup d'utilisateurs de Hibernate préfèrent écrire "
-"les fichiers de mappings à la main, plusieurs outils existent pour générer "
-"ce document, notamment XDoclet, Middlegen et AndroMDA."
+"les fichiers de mappages XML à la main, plusieurs outils existent pour "
+"générer ce document, notamment XDoclet, Middlegen et AndroMDA. "
 
 #. Tag: para
-#: basic_mapping.xml:47
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is an example mapping:"
-msgstr "Démarrons avec un exemple de mapping :"
+msgstr "Commençons avec un exemple de mappage : "
 
-#. Tag: programlisting
-#: basic_mapping.xml:51
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"      \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"          \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"        <class name=\"Cat\"\n"
-"            table=\"cats\"\n"
-"            discriminator-value=\"C\">\n"
-"\n"
-"                <id name=\"id\">\n"
-"                        <generator class=\"native\"/>\n"
-"                </id>\n"
-"\n"
-"                <discriminator column=\"subclass\"\n"
-"                     type=\"character\"/>\n"
-"\n"
-"                <property name=\"weight\"/>\n"
-"\n"
-"                <property name=\"birthdate\"\n"
-"                    type=\"date\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"color\"\n"
-"                    type=\"eg.types.ColorUserType\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"sex\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"litterId\"\n"
-"                    column=\"litterId\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <many-to-one name=\"mother\"\n"
-"                    column=\"mother_id\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <set name=\"kittens\"\n"
-"                    inverse=\"true\"\n"
-"                    order-by=\"litter_id\">\n"
-"                        <key column=\"mother_id\"/>\n"
-"                        <one-to-many class=\"Cat\"/>\n"
-"                </set>\n"
-"\n"
-"                <subclass name=\"DomesticCat\"\n"
-"                    discriminator-value=\"D\">\n"
-"\n"
-"                        <property name=\"name\"\n"
-"                            type=\"string\"/>\n"
-"\n"
-"                </subclass>\n"
-"\n"
-"        </class>\n"
-"\n"
-"        <class name=\"Dog\">\n"
-"                <!-- mapping for Dog could go here -->\n"
-"        </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:53
-#, fuzzy, no-c-format
-msgid ""
 "We will now discuss the content of the mapping document. We will only "
 "describe, however, the document elements and attributes that are used by "
 "Hibernate at runtime. The mapping document also contains some extra optional "
 "attributes and elements that affect the database schemas exported by the "
 "schema export tool (for example, the <literal> not-null</literal> attribute)."
 msgstr ""
-"Etudions le contenu du document de mapping. Nous décrirons uniquement les "
+"Étudions le contenu du document de mappage. Nous ne décrirons que les "
 "éléments et attributs du document utilisés par Hibernate à l'exécution. Le "
-"document de mapping contient aussi des attributs et éléments optionnels qui "
+"document de mappage contient aussi des attributs et éléments optionnels qui "
 "agissent sur le schéma de base de données exporté par l'outil de génération "
-"de schéma. (Par exemple l'attribut <literal>not-null</literal>.)"
+"de schéma. (Par exemple l'attribut <literal>not-null</literal>)."
 
 #. Tag: title
-#: basic_mapping.xml:64
 #, no-c-format
 msgid "Doctype"
 msgstr "Doctype"
 
 #. Tag: para
-#: basic_mapping.xml:66
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All XML mappings should declare the doctype shown. The actual DTD can be "
 "found at the URL above, in the directory <literal>hibernate-x.x.x/src/org/"
@@ -158,22 +86,21 @@
 "lookups of the DTD using an Internet connection, check the DTD declaration "
 "against the contents of your classpath."
 msgstr ""
-"Tous les mappings XML devraient utiliser le doctype indiqué. Ce fichier est "
-"présent à l'URL ci-dessus, dans le répertoire <literal>hibernate-x.x.x/src/"
-"org/hibernate</literal> ou dans <literal>hibernate3.jar</literal>. Hibernate "
-"va toujours chercher la DTD dans son classpath en premier lieu. Si vous "
-"constatez des recherches de la DTD sur Internet, vérifiez votre déclaration "
-"de DTD par rapport au contenu de votre classpath."
+"Tous les mappages XML devraient utiliser le doctype indiqué. En effet vous "
+"trouverez le fichier DTD à l'URL ci-dessus, dans le répertoire "
+"<literal>hibernate-x.x.x/src/org/hibernate</literal> ou dans "
+"<literal>hibernate3.jar</literal>. Hibernate va toujours chercher la DTD "
+"dans son classpath en premier lieu. Si vous constatez des recherches de la "
+"DTD sur Internet, vérifiez votre déclaration de DTD par rapport au contenu "
+"de votre classpath. "
 
 #. Tag: title
-#: basic_mapping.xml:76
 #, no-c-format
 msgid "EntityResolver"
 msgstr "EntityResolver"
 
 #. Tag: para
-#: basic_mapping.xml:77
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will first attempt to resolve DTDs in its classpath. It does this "
 "is by registering a custom <literal>org.xml.sax.EntityResolver</literal> "
@@ -181,30 +108,28 @@
 "custom <literal>EntityResolver</literal> recognizes two different systemId "
 "namespaces:"
 msgstr ""
-"As mentioned previously, Hibernate will first attempt to resolve DTDs in its "
-"classpath. The manner in which it does this is by registering a custom "
-"<literal>org.xml.sax.EntityResolver</literal> implementation with the "
-"SAXReader it uses to read in the xml files. This custom "
-"<literal>EntityResolver</literal> recognizes two different systemId "
-"namespaces."
+"Comme mentionné précédemment, Hibernate tentera en premier lieu de résoudre "
+"les DTD dans leur classpath. Il réussit à le faire en enregistrant une "
+"implémentation personnalisée de <literal>org.xml.sax.EntityResolver</"
+"literal> avec le SAXReader qu'il utilise pour lire les fichiers xml. Cet "
+"<literal>EntityResolver</literal> personnalisé reconnaît deux espaces de "
+"nommage systemId différents :"
 
 #. Tag: para
-#: basic_mapping.xml:85
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "a <literal>hibernate namespace</literal> is recognized whenever the resolver "
 "encounters a systemId starting with <literal>http://hibernate.sourceforge."
 "net/</literal>. The resolver attempts to resolve these entities via the "
 "classloader which loaded the Hibernate classes."
 msgstr ""
-"a <literal>hibernate namespace</literal> is recognized whenever the resolver "
-"encounteres a systemId starting with <literal>http://hibernate.sourceforge."
-"net/</literal>; the resolver attempts to resolve these entities via the "
-"classlaoder which loaded the Hibernate classes."
+"un <literal>espace de nommage hibernate</literal> est reconnu dès que le "
+"résolveur rencontre un systemId commençant par <literal>http://hibernate."
+"sourceforge.net/</literal>. Le résolveur tente alors de résoudre ces entités "
+"via le chargeur de classe qui a chargé les classes Hibernate."
 
 #. Tag: para
-#: basic_mapping.xml:94
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "a <literal>user namespace</literal> is recognized whenever the resolver "
 "encounters a systemId using a <literal>classpath://</literal> URL protocol. "
@@ -212,60 +137,35 @@
 "thread context classloader and (2) the classloader which loaded the "
 "Hibernate classes."
 msgstr ""
-"a <literal>user namespace</literal> is recognized whenever the resolver "
-"encounteres a systemId using a <literal>classpath://</literal> URL protocol; "
-"the resolver will attempt to resolve these entities via (1) the current "
-"thread context classloader and (2) the classloader which loaded the "
-"Hibernate classes."
+"un <literal>espace de nommage utilisateur</literal> est reconnu dès que le "
+"résolveur rencontre un systemId qui utilise un protocole URL "
+"<literal>classpath://</literal>. Le résolveur tentera alors de résoudre ces "
+"entités via (1) le chargeur de classe du contexte du thread courant et (2) "
+"le chargeur de classe qui a chargé les classes Hibernate."
 
 #. Tag: para
-#: basic_mapping.xml:103
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The following is an example of utilizing user namespacing:"
-msgstr "An example of utilizing user namespacing:"
+msgstr "Un exemple d'utilisation de l'espace de nommage utilisateur: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:106
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\" [\n"
-"    <!ENTITY types SYSTEM \"classpath://your/domain/types.xml\">\n"
-"]>\n"
-"\n"
-"<hibernate-mapping package=\"your.domain\">\n"
-"    <class name=\"MyEntity\">\n"
-"        <id name=\"id\" type=\"my-custom-id-type\">\n"
-"            ...\n"
-"        </id>\n"
-"    <class>\n"
-"    &types;\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:107
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Where <literal>types.xml</literal> is a resource in the <literal>your."
 "domain</literal> package and contains a custom <link linkend=\"mapping-types-"
 "custom\">typedef</link>."
 msgstr ""
-"Where <literal>types.xml</literal> is a resource in the <literal>your."
-"domain</literal> package and contains a custom <link linkend=\"mapping-types-"
-"custom\">typedef</link>."
+"Là où <literal>types.xml</literal> est une ressource dans votre paquetage "
+"<literal>your.domain</literal> et contient un <xref linkend=\"mapping-types-"
+"custom\"/> personnalisé. "
 
 #. Tag: title
-#: basic_mapping.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Hibernate-mapping"
-msgstr "hibernate-mapping"
+msgstr "Hibernate-mappage"
 
 #. Tag: para
-#: basic_mapping.xml:117
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This element has several optional attributes. The <literal>schema</literal> "
 "and <literal>catalog</literal> attributes specify that tables referred to in "
@@ -279,59 +179,40 @@
 "language."
 msgstr ""
 "Cet élément a plusieurs attributs optionnels. Les attributs <literal>schema</"
-"literal> et <literal>catalog</literal> indiquent que les tables référencées "
-"par ce mapping appartiennent au schéma nommé et/ou au catalogue. S'ils sont "
-"spécifiés, les noms de tables seront qualifiés par les noms de schéma et "
+"literal> et <literal>catalog</literal> indiquent que les tables mentionnées "
+"dans ce mappage appartiennent au schéma nommé et/ou au catalogue. S'ils sont "
+"spécifiés, les noms de tables seront qualifiés par les noms de schéma et de "
 "catalogue. L'attribut <literal>default-cascade</literal> indique quel type "
-"de cascade sera utlisé par défaut pour les propriétés et collections qui ne "
+"de cascade sera utilisé par défaut pour les propriétés et collections qui ne "
 "précisent pas l'attribut <literal>cascade</literal>. L'attribut "
 "<literal>auto-import</literal> nous permet d'utiliser par défaut des noms de "
-"classes non qualifiés dans le langage de requête."
+"classes non qualifiés dans le langage de requête, par défaut. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:138
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping\n"
-"         schema=\"schemaName\"\n"
-"         catalog=\"catalogName\"\n"
-"         default-cascade=\"cascade_style\"\n"
-"         default-access=\"field|property|ClassName\"\n"
-"         default-lazy=\"true|false\"\n"
-"         auto-import=\"true|false\"\n"
-"         package=\"package.name\"\n"
-" />]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:141
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>schema</literal> (optional): the name of a database schema."
 msgstr ""
-"<literal>schema</literal> (optionnel) : Le nom d'un schéma de base de "
-"données."
+"<literal>schema</literal> (optionnel) : le nom d'un schéma de base de "
+"données. "
 
 #. Tag: para
-#: basic_mapping.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>catalog</literal> (optional): the name of a database catalog."
 msgstr ""
-"<literal>catalog</literal> (optionnel) : Le nom d'un catalogue de base de "
-"données."
+"<literal>catalog</literal> (optionnel) : le nom d'un catalogue de base de "
+"données. "
 
 #. Tag: para
-#: basic_mapping.xml:151
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>default-cascade</literal> (optional - defaults to <literal>none</"
 "literal>): a default cascade style."
 msgstr ""
 "<literal>default-cascade</literal> (optionnel - par défaut vaut : "
-"<literal>none</literal>) : Un type de cascade par défaut."
+"<literal>none</literal>) : un type de cascade par défaut. "
 
 #. Tag: para
-#: basic_mapping.xml:157
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>default-access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate should use for accessing all properties. "
@@ -340,57 +221,54 @@
 "<literal>default-access</literal> (optionnel - par défaut vaut : "
 "<literal>property</literal>) : Comment hibernate accèdera aux propriétés. On "
 "peut aussi redéfinir sa propre implémentation de <literal>PropertyAccessor</"
-"literal>."
+"literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:164
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>default-lazy</literal> (optional - defaults to <literal>true</"
 "literal>): the default value for unspecified <literal>lazy</literal> "
 "attributes of class and collection mappings."
 msgstr ""
 "<literal>default-lazy</literal> (optionnel - par défaut vaut : "
-"<literal>true</literal>) : Valeur par défaut pour un attribut <literal>lazy</"
-"literal> non spécifié : celui des mappings de classes et de collection."
+"<literal>true</literal>) : Valeur par défaut pour des attributs "
+"<literal>lazy</literal> non spécifiés des mappages de classe et de "
+"collection. "
 
 #. Tag: para
-#: basic_mapping.xml:171
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>auto-import</literal> (optional - defaults to <literal>true</"
 "literal>): specifies whether we can use unqualified class names of classes "
 "in this mapping in the query language."
 msgstr ""
 "<literal>auto-import</literal> (optionnel - par défaut vaut : <literal>true</"
-"literal>) : Spécifie si l'on peut utiliser des noms de classes non qualifiés "
-"(des classes de ce mapping) dans le langage de requête."
+"literal>) : spécifie si l'on peut utiliser des noms de classes non qualifiés "
+"(de classes de ce mappage) dans le langage de requête. "
 
 #. Tag: para
-#: basic_mapping.xml:178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>package</literal> (optional): specifies a package prefix to use for "
 "unqualified class names in the mapping document."
 msgstr ""
-"<literal>package</literal> (optionnel) : Préfixe de package par défaut pour "
-"les noms de classe non qualifiés du document de mapping."
+"<literal>package</literal> (optionnel) : préfixe de paquetage par défaut "
+"pour les noms de classe non qualifiés du document de mappage. "
 
 #. Tag: para
-#: basic_mapping.xml:186
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you have two persistent classes with the same unqualified name, you "
 "should set <literal>auto-import=\"false\"</literal>. An exception will "
 "result if you attempt to assign two classes to the same \"imported\" name."
 msgstr ""
-"Si deux classes possèdent le même nom de classe (non qualifié), vous devez "
-"indiquer <literal>auto-import=\"false\"</literal>. Hibernate lancera une "
-"exception si vous essayez d'assigner à deux classes le même nom importé."
+"Si deux classes persistantes possèdent le même nom de classe (non qualifié), "
+"vous devez configurer <literal>auto-import=\"false\"</literal>. Hibernate "
+"lancera une exception si vous essayez d'assigner le même nom \"importé\" à "
+"deux classes."
 
 #. Tag: para
-#: basic_mapping.xml:192
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>hibernate-mapping</literal> element allows you to nest several "
 "persistent <literal>&lt;class&gt;</literal> mappings, as shown above. It is, "
@@ -400,85 +278,51 @@
 "literal>, <literal>Dog.hbm.xml</literal>, or if using inheritance, "
 "<literal>Animal.hbm.xml</literal>."
 msgstr ""
-"Notez que l'élément <literal>hibernate-mapping</literal> vous permet "
-"d'imbriquer plusieurs mappings de <literal>&lt;class&gt;</literal> "
-"persistantes, comme dans l'exemple ci-dessus. Cependant la bonne pratique "
-"(ce qui est attendu par certains outils) est de mapper une seule classe (ou "
-"une seule hiérarchie de classes) par fichier de mapping et de nommer ce "
-"fichier d'après le nom de la superclasse, par exemple <literal>Cat.hbm.xml</"
-"literal>, <literal>Dog.hbm.xml</literal>, ou en cas d'héritage, "
-"<literal>Animal.hbm.xml</literal>."
+"Notez que l'élément <literal>hibernate-mappage</literal> vous permet "
+"d'imbriquer plusieurs mappages de <literal>&lt;class&gt;</literal> "
+"persistantes, comme dans l'exemple ci-dessus. Cependant il est recommandé "
+"(et c'est parfois une exigence de certains outils) de mapper une seule "
+"classe persistante (ou une seule hiérarchie de classes) par fichier de "
+"mappage et de nommer ce fichier d'après le nom de la superclasse "
+"persistante, par exemple <literal>Cat.hbm.xml</literal>, <literal>Dog.hbm."
+"xml</literal>, ou en cas d'héritage, <literal>Animal.hbm.xml</literal>. "
 
 #. Tag: title
-#: basic_mapping.xml:205
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Class"
-msgstr "class"
+msgstr "Classe"
 
 #. Tag: para
-#: basic_mapping.xml:207
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can declare a persistent class using the <literal>class</literal> "
 "element. For example:"
 msgstr ""
-"Déclarez une classe persistante avec l'élément <literal>class</literal> :"
+"Déclarez une classe persistante avec l'élément <literal>class</literal>. "
+"Part exemple :"
 
-#. Tag: programlisting
-#: basic_mapping.xml:235
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class\n"
-"        name=\"ClassName\"\n"
-"        table=\"tableName\"\n"
-"        discriminator-value=\"discriminator_value\"\n"
-"        mutable=\"true|false\"\n"
-"        schema=\"owner\"\n"
-"        catalog=\"catalog\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        select-before-update=\"true|false\"\n"
-"        polymorphism=\"implicit|explicit\"\n"
-"        where=\"arbitrary sql where condition\"\n"
-"        persister=\"PersisterClass\"\n"
-"        batch-size=\"N\"\n"
-"        optimistic-lock=\"none|version|dirty|all\"\n"
-"        lazy=\"true|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        check=\"arbitrary sql check condition\"\n"
-"        rowid=\"rowid\"\n"
-"        subselect=\"SQL expression\"\n"
-"        abstract=\"true|false\"\n"
-"        node=\"element-name\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:238
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal> (optional): the fully qualified Java class name of "
 "the persistent class or interface. If this attribute is missing, it is "
 "assumed that the mapping is for a non-POJO entity."
 msgstr ""
-"<literal>name</literal> (optionnel) : Le nom Java complet de la classe (ou "
-"interface) persistante. Si cet attribut est absent, il est supposé que ce "
-"mapping ne se rapporte pas à une entité POJO."
+"<literal>name</literal> (optionnel) : le nom Java complet de la classe (ou "
+"interface) persistante. Si cet attribut est absent, nous supposons que ce "
+"mappage ne se rapporte pas à une entité POJO. "
 
 #. Tag: para
-#: basic_mapping.xml:245
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>table</literal> (optional - defaults to the unqualified class "
 "name): the name of its database table."
 msgstr ""
-"<literal>table</literal> (optionnel - par défaut le nom (non-qualifié) de la "
-"classe) : Le nom de sa table en base de données."
+"<literal>table</literal> (optionnel - par défaut le nom non-qualifié de la "
+"classe) : le nom de sa table en base de données."
 
 #. Tag: para
-#: basic_mapping.xml:251
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>discriminator-value</literal> (optional - defaults to the class "
 "name): a value that distinguishes individual subclasses that is used for "
@@ -486,88 +330,73 @@
 "<literal>not null</literal>."
 msgstr ""
 "<literal>discriminator-value</literal> (optionnel - par défaut le nom de la "
-"classe) : Une valeur permettant de distinguer les sous-classes dans le cas "
-"de l'utilisation du polymorphisme. Les valeurs <literal>null</literal> et "
-"<literal>not null</literal> sont autorisées."
+"classe) : une valeur permettant de distinguer les différentes sous-classes "
+"utilisées dans le comportement polymorphique. Les valeurs <literal>null</"
+"literal> et <literal>not null</literal> sont autorisées. "
 
 #. Tag: para
-#: basic_mapping.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>true</literal>): "
 "specifies that instances of the class are (not) mutable."
 msgstr ""
 "<literal>mutable</literal> (optionnel, vaut <literal>true</literal> par "
-"défaut) : Spécifie que des instances de la classe sont (ou non) immuables."
+"défaut) : spécifie que des instances de la classe sont (ou non) immuables. "
 
 #. Tag: para
-#: basic_mapping.xml:264 basic_mapping.xml:2231
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>schema</literal> (optional): overrides the schema name specified by "
 "the root <literal>&lt;hibernate-mapping&gt;</literal> element."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>schema</literal> (optionnel) : Surcharge le nom de schéma spécifié "
-"par l'élément racine <literal>&lt;hibernate-mapping&gt;</literal>.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>schema</literal> (optionnel) : court-circuite le nom de schéma "
-"spécifié par l'élément de base <literal>&lt;hibernate-mapping&gt;</literal>."
+"<literal>schema</literal> (optionnel) : surcharge le nom de schéma spécifié "
+"par l'élément racine <literal>&lt;hibernate-mappage&gt;</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:270 basic_mapping.xml:2237
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>catalog</literal> (optional): overrides the catalog name specified "
 "by the root <literal>&lt;hibernate-mapping&gt;</literal> element."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>catalog</literal> (optionnel) : Surcharge le nom du catalogue "
-"spécifié par l'élément racine <literal>&lt;hibernate-mapping&gt;</literal>.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>catalog</literal> (optionnel) : court-circuite le nom de catalogue "
-"spécifié par l'élément de base <literal>&lt;hibernate-mapping&gt;</literal>."
+"<literal>catalog</literal> (optionnel) : surcharge le nom du catalogue "
+"spécifié par l'élément racine <literal>&lt;hibernate-mappage&gt;</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:276
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies an interface to use for lazy "
 "initializing proxies. You can specify the name of the class itself."
 msgstr ""
-"<literal>proxy</literal> (optionnel) : Spécifie une interface à utiliser "
+"<literal>proxy</literal> (optionnel) : spécifie une interface à utiliser "
 "pour l'initialisation différée (lazy loading) des proxies. Vous pouvez "
-"indiquer le nom de la classe elle-même."
+"indiquer le nom de la classe elle-même. "
 
 #. Tag: para
-#: basic_mapping.xml:282
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>dynamic-update</literal> (optional - defaults to <literal>false</"
 "literal>): specifies that <literal>UPDATE</literal> SQL should be generated "
 "at runtime and can contain only those columns whose values have changed."
 msgstr ""
 "<literal>dynamic-update</literal> (optionnel, par défaut à <literal>false</"
-"literal>) : Spécifie que les <literal>UPDATE</literal> SQL doivent être "
+"literal>) : spécifie que les SQL <literal>UPDATE</literal> doivent être "
 "générés à l'exécution et contenir uniquement les colonnes dont les valeurs "
-"ont été modifiées."
+"ont été modifiées. "
 
 #. Tag: para
-#: basic_mapping.xml:289
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>dynamic-insert</literal> (optional - defaults to <literal>false</"
 "literal>): specifies that <literal>INSERT</literal> SQL should be generated "
 "at runtime and contain only the columns whose values are not null."
 msgstr ""
 "<literal>dynamic-insert</literal> (optionnel, par défaut à <literal>false</"
-"literal>): Spécifie que les <literal>INSERT</literal> SQL doivent être "
+"literal>) : spécifie que les SQL <literal>INSERT</literal> doivent être "
 "générés à l'exécution et ne contenir que les colonnes dont les valeurs sont "
-"non nulles."
+"non nulles. "
 
 #. Tag: para
-#: basic_mapping.xml:296
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>select-before-update</literal> (optional - defaults to "
 "<literal>false</literal>): specifies that Hibernate should <emphasis>never</"
@@ -578,113 +407,106 @@
 "<literal>UPDATE</literal> is actually required."
 msgstr ""
 "<literal>select-before-update</literal> (optionnel, par défaut à "
-"<literal>false</literal>): Spécifie que Hibernate ne doit <emphasis>jamais</"
-"emphasis> exécuter un <literal>UPDATE</literal> SQL sans être certain qu'un "
+"<literal>false</literal>): spécifie que Hibernate ne doit <emphasis>jamais</"
+"emphasis> exécuter un SQL <literal>UPDATE</literal> sans être certain qu'un "
 "objet a été réellement modifié. Dans certains cas, (en réalité, seulement "
 "quand un objet transient a été associé à une nouvelle session par "
-"<literal>update()</literal>), cela signifie que Hibernate exécutera un "
-"<literal>SELECT</literal> SQL pour s'assurer qu'un <literal>UPDATE</literal> "
-"SQL est véritablement nécessaire."
+"<literal>update()</literal>), cela signifie que Hibernate exécutera un SQL "
+"<literal>SELECT</literal> pour déterminer si un SQL <literal>UPDATE</"
+"literal> est véritablement nécessaire. "
 
 #. Tag: para
-#: basic_mapping.xml:306
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>polymorphism</literal> (optional - defaults to <literal>implicit</"
 "literal>): determines whether implicit or explicit query polymorphism is "
 "used."
 msgstr ""
 "<literal>polymorphism</literal> (optionnel, vaut <literal>implicit</literal> "
-"par défaut) : Détermine si, pour cette classe, une requête polymorphique "
-"implicite ou explicite est utilisée."
+"par défaut) : détermine si, pour cette classe, une requête polymorphique "
+"implicite ou explicite est utilisée. "
 
 #. Tag: para
-#: basic_mapping.xml:312
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>where</literal> (optional): specifies an arbitrary SQL "
 "<literal>WHERE</literal> condition to be used when retrieving objects of "
 "this class."
 msgstr ""
 "<literal>where</literal> (optionnel) spécifie une clause SQL <literal>WHERE</"
-"literal> à utiliser lorsque l'on récupère des objets de cette classe."
+"literal> à utiliser lorsque l'on récupère des objets de cette classe. "
 
 #. Tag: para
-#: basic_mapping.xml:318
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>persister</literal> (optional): specifies a custom "
 "<literal>ClassPersister</literal>."
 msgstr ""
-"<literal>persister</literal> (optionnel) : Spécifie un "
-"<literal>ClassPersister</literal> particulier."
+"<literal>persister</literal> (optionnel) : spécifie un "
+"<literal>ClassPersister</literal> particulier. "
 
 #. Tag: para
-#: basic_mapping.xml:323
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>batch-size</literal> (optional - defaults to <literal>1</literal>): "
 "specifies a \"batch size\" for fetching instances of this class by "
 "identifier."
 msgstr ""
 "<literal>batch-size</literal> (optionnel, par défaut = <literal>1</"
-"literal>) : spécifie une taille de batch pour remplir les instances de cette "
-"classe par identifiant en une seule requête."
+"literal>) : spécifie une \"taille de lot\" pour remplir les instances de "
+"cette classe par identifiant en une seule requête."
 
 #. Tag: para
-#: basic_mapping.xml:329
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>version</"
 "literal>): determines the optimistic locking strategy."
 msgstr ""
 "<literal>optimistic-lock</literal> (optionnel, par défaut = "
-"<literal>version</literal>) : Détermine la stratégie de verrou optimiste."
+"<literal>version</literal>) : détermine la stratégie de verrouillage "
+"optimiste. "
 
 #. Tag: para
-#: basic_mapping.xml:335
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional): lazy fetching can be disabled by setting "
 "<literal>lazy=\"false\"</literal>."
 msgstr ""
-"<literal>lazy</literal> (optionnel) : Déclarer <literal>lazy=\"true\"</"
-"literal> est un raccourci pour spécifier le nom de la classe comme étant "
-"l'interface <literal>proxy</literal>."
+"<literal>lazy</literal> (optionnel) : l'extraction différée (lazy fetching) "
+"peut être totalement désactivée en configurant <literal>lazy=\"false\"</"
+"literal>."
 
 #. Tag: para
-#: basic_mapping.xml:341
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>entity-name</literal> (optional - defaults to the class name): "
 "Hibernate3 allows a class to be mapped multiple times, potentially to "
 "different tables. It also allows entity mappings that are represented by "
 "Maps or XML at the Java level. In these cases, you should provide an "
 "explicit arbitrary name for the entity. See <xref linkend=\"persistent-"
-"classes-dynamicmodels\"/> and <xref linkend=\"xml\"/> for more information."
+"classes-dynamicmodels\" /> and <xref linkend=\"xml\" /> for more information."
 msgstr ""
-"<literal>entity-name</literal> (optionnel) : Hibernate3 permet à une classe "
-"d'être mappée plusieurs fois (potentiellement à plusieurs tables), et permet "
-"aux mappings d'entité d'être représentés par des Maps ou du XML au niveau "
-"Java. Dans ces cas, vous devez indiquer un nom explicite arbitraire pour les "
-"entités. Voir <xref linkend=\"persistent-classes-dynamicmodels\"/> et <xref "
-"linkend=\"xml\"/> pour plus d'informations."
+"<literal>entity-name</literal> (optionnel - le nom de classe par défaut) : "
+"Hibernate3 permet à une classe d'être mappée plusieurs fois (potentiellement "
+"à plusieurs tables), et permet aux mappages d'entité d'être représentés par "
+"des Maps ou du XML au niveau Java. Dans ces cas, vous devez indiquer un nom "
+"explicite arbitraire pour les entités. Consultez <xref linkend=\"persistent-"
+"classes-dynamicmodels\"/> et <xref linkend=\"xml\"/> pour plus "
+"d'informations. "
 
 #. Tag: para
-#: basic_mapping.xml:351
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>check</literal> (optional): an SQL expression used to generate a "
 "multi-row <emphasis>check</emphasis> constraint for automatic schema "
 "generation."
 msgstr ""
 "<literal>check</literal> (optionnel) : expression SQL utilisée pour générer "
-"une contrainte de vérification multi-lignes pour la génération automatique "
-"de schéma."
+"une contrainte de vérification <emphasis>check</emphasis> multi-lignes pour "
+"la génération automatique de schéma. "
 
 #. Tag: para
-#: basic_mapping.xml:357
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>rowid</literal> (optional): Hibernate can use ROWIDs on databases. "
 "On Oracle, for example, Hibernate can use the <literal>rowid</literal> extra "
@@ -695,36 +517,34 @@
 "<literal>rowid</literal> (optionnel) : Hibernate peut utiliser des ROWID sur "
 "les bases de données qui utilisent ce mécanisme. Par exemple avec Oracle, "
 "Hibernate peut utiliser la colonne additionnelle <literal>rowid</literal> "
-"pour des mises à jour rapides si cette option vaut <literal>rowid</literal>. "
-"Un ROWID représente la localisation physique d'un tuple enregistré."
+"pour des mise à jour rapides si cette option vaut <literal>rowid</literal>. "
+"Un ROWID est un détail d'implémentation et représente la localisation "
+"physique d'un uplet enregistré. "
 
 #. Tag: para
-#: basic_mapping.xml:364
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>subselect</literal> (optional): maps an immutable and read-only "
 "entity to a database subselect. This is useful if you want to have a view "
 "instead of a base table. See below for more information."
 msgstr ""
-"<literal>subselect</literal> (optionnel) : Permet de mapper une entité "
+"<literal>subselect</literal> (optionnel) : permet de mapper une entité "
 "immuable en lecture-seule sur un sous-select de base de données. Utile pour "
-"avoir une vue au lieu d'une table en base, mais à éviter. Voir plus bas pour "
-"plus d'information."
+"avoir une vue au lieu d'une table de base, mais à éviter. Voir plus bas pour "
+"plus d'informations. "
 
 #. Tag: para
-#: basic_mapping.xml:371
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>abstract</literal> (optional): is used to mark abstract "
 "superclasses in <literal>&lt;union-subclass&gt;</literal> hierarchies."
 msgstr ""
-"<literal>abstract</literal> (optionnel) : Utilisé pour marquer des "
+"<literal>abstract</literal> (optionnel) : utilisé pour marquer des "
 "superclasses abstraites dans des hiérarchies de <literal>&lt;union-"
-"subclass&gt;</literal>."
+"subclass&gt;</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:379
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is acceptable for the named persistent class to be an interface. You can "
 "declare implementing classes of that interface using the <literal>&lt;"
@@ -737,11 +557,10 @@
 "interface en utilisant l'élément <literal>&lt;subclass&gt;</literal>. Vous "
 "pouvez faire persister toute classe interne <emphasis>static</emphasis>. "
 "Vous devez alors spécifier le nom de la classe par la notation habituelle "
-"des classes internes c'est à dire <literal>eg.Foo$Bar</literal>."
+"des classes internes, c'est à dire <literal>eg.Foo$Bar</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:386
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Immutable classes, <literal>mutable=\"false\"</literal>, cannot be updated "
 "or deleted by the application. This allows Hibernate to make some minor "
@@ -749,11 +568,10 @@
 msgstr ""
 "Les classes immuables, <literal>mutable=\"false\"</literal>, ne peuvent pas "
 "être modifiées ou supprimées par l'application. Cela permet à Hibernate de "
-"faire quelques optimisations mineures sur les performances."
+"faire quelques optimisations mineures sur les performances. "
 
 #. Tag: para
-#: basic_mapping.xml:391
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The optional <literal>proxy</literal> attribute enables lazy initialization "
 "of persistent instances of the class. Hibernate will initially return CGLIB "
@@ -761,16 +579,15 @@
 "when a method of the proxy is invoked. See \"Initializing collections and "
 "proxies\" below."
 msgstr ""
-"L'attribut optionnnel <literal>proxy</literal> permet les intialisations "
+"L'attribut optionnel <literal>proxy</literal> permet les initialisations "
 "différées des instances persistantes de la classe. Hibernate retournera "
 "initialement des proxies CGLIB qui implémentent l'interface nommée. Le "
-"véritable objet persistant ne sera chargé que lorsque une méthode du proxy "
-"sera appelée. Voir plus bas le paragraphe abordant les proxies et le "
-"chargement différé (lazy initialization)."
+"véritable objet persistant ne sera chargé que lorsqu'une méthode du proxy "
+"sera appelée. Voir plus bas le paragraphe abordant les Proxies et leur "
+"initialisation différée (lazy initialization). "
 
 #. Tag: para
-#: basic_mapping.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Implicit</emphasis> polymorphism means that instances of the class "
 "will be returned by a query that names any superclass or implemented "
@@ -786,7 +603,7 @@
 "table This allows a \"lightweight\" class that contains a subset of the "
 "table columns."
 msgstr ""
-"Le polymorphisme <emphasis>implicite</emphasis> signifie que les instances "
+"Le polymorphisme <emphasis>implicite</emphasis> signifie que des instances "
 "de la classe seront retournées par une requête qui utilise les noms de la "
 "classe ou de chacune de ses superclasses ou encore des interfaces "
 "implémentées par cette classe ou ses superclasses. Les instances des classes "
@@ -800,11 +617,10 @@
 "literal>, est appropriée. Le polymorphisme explicite est utile lorsque deux "
 "classes différentes sont mappées à la même table (ceci permet d'écrire une "
 "classe \"légère\" qui ne contient qu'une partie des colonnes de la table - "
-"voir la partie design pattern du site communautaire)."
+"voir la partie design pattern du site communautaire). "
 
 #. Tag: para
-#: basic_mapping.xml:410
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>persister</literal> attribute lets you customize the "
 "persistence strategy used for the class. You can, for example, specify your "
@@ -815,19 +631,19 @@
 "files or LDAP. See <literal>org.hibernate.test.CustomPersister</literal> for "
 "a simple example of \"persistence\" to a <literal>Hashtable</literal>."
 msgstr ""
-"L'attribut <literal>persister</literal> vous permet de customiser la "
-"stratégie utilisée pour la classe. Vous pouvez, par exemple, spécifier votre "
-"propre sous-classe de <literal>org.hibernate.persister.EntityPersister</"
-"literal> ou vous pourriez aussi créer une nouvelle implémentation de "
-"l'interface <literal>org.hibernate.persister.ClassPersister</literal> qui "
-"proposerait une persistance via, par exemple, des appels de procédures "
-"stockées, de la sérialisation vers des fichiers plats ou un annuaire LDAP. "
-"Voir <literal>org.hibernate.test.CustomPersister</literal> pour un exemple "
-"simple (d'une \"persistance\" vers une <literal>Hashtable</literal>)."
+"L'attribut <literal>persister</literal> vous permet de personnaliser la "
+"stratégie de persistance utilisée pour la classe. Vous pouvez, par exemple, "
+"spécifier votre propre sous-classe de <literal>org.hibernate.persister."
+"EntityPersister</literal> ou vous pourriez aussi fournir une nouvelle "
+"implémentation de l'interface <literal>org.hibernate.persister."
+"ClassPersister</literal> qui proposerait une persistance via, par exemple, "
+"des appels de procédures stockées, de la sérialisation vers des fichiers "
+"plats ou un annuaire LDAP. Voir <literal>org.hibernate.test.CustomPersister</"
+"literal> pour un exemple simple (d'une \"persistance\" vers une "
+"<literal>Hashtable</literal>). "
 
 #. Tag: para
-#: basic_mapping.xml:421
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>dynamic-update</literal> and <literal>dynamic-insert</literal> "
 "settings are not inherited by subclasses, so they can also be specified on "
@@ -838,13 +654,12 @@
 "Notez que les paramètres <literal>dynamic-update</literal> et "
 "<literal>dynamic-insert</literal> ne sont pas hérités par les sous-classes "
 "et peuvent donc être spécifiés pour les éléments <literal>&lt;subclass&gt;</"
-"literal> ou <literal>&lt;joined-subclass&gt;</literal> Ces paramètres "
+"literal> ou <literal>&lt;joined-subclass&gt;</literal>. Ces paramètres "
 "peuvent améliorer les performances dans certains cas, mais peuvent aussi les "
-"amoindrir. A utiliser en connaissance de causes."
+"amoindrir. À utiliser en connaissance de causes. "
 
 #. Tag: para
-#: basic_mapping.xml:429
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use of <literal>select-before-update</literal> will usually decrease "
 "performance. It is useful to prevent a database update trigger being called "
@@ -852,51 +667,45 @@
 "<literal>Session</literal>."
 msgstr ""
 "L'utilisation de <literal>select-before-update</literal> va généralement "
-"faire baisser les performances. Ce paramètre est pratique pour prévenir "
-"l'appel inutile d'un trigger sur modification quand on réattache un graphe "
-"d'instances à une <literal>Session</literal>."
+"faire baisser les performances. Ce paramètre est pratique pour éviter "
+"l'appel inutile par un déclenchement de mise à jour de base de donnée, quand "
+"on ré-attache un graphe d'instances à une <literal>Session</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:435
 #, no-c-format
 msgid ""
 "If you enable <literal>dynamic-update</literal>, you will have a choice of "
 "optimistic locking strategies:"
 msgstr ""
 "Si vous utilisez le <literal>dynamic-update</literal>, les différentes "
-"stratégies de verrouillage optimiste (optimistic locking) sont les suivantes:"
+"stratégies de verrouillage optimiste sont les suivantes :"
 
 #. Tag: para
-#: basic_mapping.xml:441
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>version</literal>: check the version/timestamp columns"
-msgstr "<literal>version</literal> vérifie les colonnes version/timestamp"
+msgstr "<literal>version</literal> vérifie les colonnes version/timestamp "
 
 #. Tag: para
-#: basic_mapping.xml:446
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>all</literal>: check all columns"
-msgstr "<literal>all</literal> vérifie toutes les colonnes"
+msgstr "<literal>all</literal> vérifie toutes les colonnes "
 
 #. Tag: para
-#: basic_mapping.xml:451
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>dirty</literal>: check the changed columns, allowing some "
 "concurrent updates"
 msgstr ""
-"<literal>dirty</literal> vérifie les colonnes modifiées, permettant des "
-"updates concurrents"
+"<literal>dirty</literal> vérifie les colonnes modifiées, permettant quelques "
+"mise à jour concurrentes "
 
 #. Tag: para
-#: basic_mapping.xml:456
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>none</literal>: do not use optimistic locking"
-msgstr "<literal>none</literal> pas de verrouillage optimiste"
+msgstr "<literal>none</literal> n'utilisez pas le verrouillage optimiste "
 
 #. Tag: para
-#: basic_mapping.xml:461
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is <emphasis>strongly</emphasis> recommended that you use version/"
 "timestamp columns for optimistic locking with Hibernate. This strategy "
@@ -905,13 +714,12 @@
 msgstr ""
 "Nous encourageons <emphasis>très</emphasis> fortement l'utilisation de "
 "colonnes de version/timestamp pour le verrouillage optimiste avec Hibernate. "
-"C'est la meilleure stratégie en regard des performances et la seule qui gère "
-"correctement les modifications sur les objets détachés (c'est à dire "
-"lorsqu'on utilise <literal>Session.merge()</literal>)."
+"C'est la meilleure stratégie en ce qui concerne les performances et la seule "
+"qui gère correctement les modifications sur les instances détachées (c'est à "
+"dire lorsqu'on utilise <literal>Session.merge()</literal>). "
 
 #. Tag: para
-#: basic_mapping.xml:468
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is no difference between a view and a base table for a Hibernate "
 "mapping. This is transparent at the database level, although some DBMS do "
@@ -920,36 +728,17 @@
 "schema). In this case, you can map an immutable and read-only entity to a "
 "given SQL subselect expression:"
 msgstr ""
-"Il n'y a pas de différence entre table et vue pour le mapping Hibernate, "
-"tant que c'est transparent au niveau base de données (remarquez que "
-"certaines BDD ne supportent pas les vues correctement, notamment pour les "
-"updates). Vous rencontrerez peut-être des cas où vous souhaitez utiliser une "
-"vue mais ne pouvez pas en créer sur votre BDD (par exemple à cause de "
-"schémas anciens et figés). Dans ces cas, vous pouvez mapper une entité "
-"immuable en lecture seule sur un sous-select SQL donné:"
+"Il n'y a pas de différence entre table et vue pour le mappage Hibernate, "
+"comme on peut s'y attendre, cela est transparent au niveau base de données "
+"(remarquez que certaines BDD ne supportent pas les vues correctement, "
+"notamment pour les mise à jour). Il est possible que vous souhaitiez "
+"utiliser une vue mais vous ne puissiez pas en créer une sur votre BDD (c'est-"
+"à-dire avec un schéma ancien). Dans ces cas, vous pouvez mapper une entité "
+"immuable en lecture seule sur une expression sous-select SQL donnée :"
 
-#. Tag: programlisting
-#: basic_mapping.xml:476
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Summary\">\n"
-"    <subselect>\n"
-"        select item.name, max(bid.amount), count(*)\n"
-"        from item\n"
-"        join bid on bid.item_id = item.id\n"
-"        group by item.name\n"
-"    </subselect>\n"
-"    <synchronize table=\"item\"/>\n"
-"    <synchronize table=\"bid\"/>\n"
-"    <id name=\"name\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:478
-#, fuzzy, no-c-format
-msgid ""
 "Declare the tables to synchronize this entity with, ensuring that auto-flush "
 "happens correctly and that queries against the derived entity do not return "
 "stale data. The <literal>&lt;subselect&gt;</literal> is available both as an "
@@ -957,18 +746,16 @@
 msgstr ""
 "Déclarez les tables à synchroniser avec cette entité pour assurer que le "
 "flush automatique se produise correctement, et pour que les requêtes sur "
-"l'entité dérivée ne renvoient pas des données périmées. Le litéral "
-"<literal>&lt;subselect&gt;</literal> est disponible comme attribut ou comme "
-"élément de mapping."
+"l'entité dérivée ne renvoient pas des données périmées. Le <literal>&lt;"
+"subselect&gt;</literal> est disponible comme attribut ou comme élément de "
+"mappage imbriqué. "
 
 #. Tag: title
-#: basic_mapping.xml:488
 #, no-c-format
-msgid "<title>id</title>"
-msgstr ""
+msgid "id"
+msgstr "id"
 
 #. Tag: para
-#: basic_mapping.xml:490
 #, no-c-format
 msgid ""
 "Mapped classes <emphasis>must</emphasis> declare the primary key column of "
@@ -977,159 +764,95 @@
 "literal> element defines the mapping from that property to the primary key "
 "column."
 msgstr ""
-"Les classes mappées <emphasis>doivent</emphasis> déclarer la clef primaire "
-"de la table en base de données. La plupart des classes auront aussi une "
-"propriété de type javabean présentant l'identifiant unique d'une instance. "
-"L'élément <literal>&lt;id&gt;</literal> sert à définir le mapping entre "
-"cette propriété et la clef primaire en base."
+"Les classes mappées <emphasis>doivent</emphasis> déclarer la clé primaire de "
+"la table en base de données. La plupart des classes auront aussi une "
+"propriété de type JavaBeans présentant l'identifiant unique d'une instance. "
+"L'élément <literal>&lt;id&gt;</literal> sert à définir le mappage entre "
+"cette propriété et la colonne de la clé primaire."
 
-#. Tag: programlisting
-#: basic_mapping.xml:505
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id\n"
-"        name=\"propertyName\"\n"
-"        type=\"typename\"\n"
-"        column=\"column_name\"\n"
-"        unsaved-value=\"null|any|none|undefined|id_value\"\n"
-"        access=\"field|property|ClassName\">\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"\n"
-"        <generator class=\"generatorClass\"/>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:508
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal> (optional): the name of the identifier property."
 msgstr ""
-"<literal>name</literal> (optionnel) : Nom de la propriété qui sert "
-"d'identifiant."
+"<literal>name</literal> (optionnel) : nom de la propriété de l'identifiant."
 
 #. Tag: para
-#: basic_mapping.xml:513 basic_mapping.xml:1351
 #, no-c-format
 msgid ""
 "<literal>type</literal> (optional): a name that indicates the Hibernate type."
-msgstr "<literal>type</literal> (optionnel) : nom indiquant le type Hibernate."
+msgstr ""
+"<literal>type</literal> (optionnel) : nom indiquant le type Hibernate. "
 
 #. Tag: para
-#: basic_mapping.xml:518
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of the primary key column."
 msgstr ""
 "<literal>column</literal> (optionnel - le nom de la propriété est pris par "
-"défaut) : Nom de la clef primaire."
+"défaut) : nom de la colonne de la clé primaire."
 
 #. Tag: para
-#: basic_mapping.xml:524
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to a \"sensible\" "
 "value): an identifier property value that indicates an instance is newly "
 "instantiated (unsaved), distinguishing it from detached instances that were "
 "saved or loaded in a previous session."
 msgstr ""
-"<literal>unsaved-value</literal> (optionnel - par défaut une valeur \"bien "
-"choisie\") : Une valeur de la propriété d'identifiant qui indique que "
+"<literal>unsaved-value</literal> (optionnel - devient par défaut une valeur "
+"\"sensible\") : une valeur de propriété d'identifiant qui indique que "
 "l'instance est nouvellement instanciée (non sauvegardée), et qui la "
-"distingue des instances <literal>transient</literal>s qui ont été "
-"sauvegardées ou chargées dans une session précédente."
+"distingue des instances détachées qui ont été sauvegardées ou chargées dans "
+"une session précédente. "
 
 #. Tag: para
-#: basic_mapping.xml:532
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate should use for accessing the property "
 "value."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>access</literal> (optionnel - par défaut <literal>property</"
-"literal>) : La stratégie que doit utiliser Hibernate pour accéder aux "
-"valeurs des propriétés.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - défaut à <literal>property</"
-"literal>) : La stratégie qu'Hibernate utilisera pour accéder à la valeur de "
-"la propriété.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>) : La stratégie à utiliser par Hibernate pour accéder à la valeur "
-"de la propriété.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>) : La stratégie à utiliser par Hibernate pour accéder à la valeur "
-"de la propriété.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>): Stratégie que Hibernate doit utiliser pour accéder à cette "
-"valeur.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>) : La stratégie à utiliser par Hibernate pour accéder à la valeur "
-"de cette propriété.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>formula</literal> (optionnel) : Presque toutes les associations one-"
-"to-one pointent sur la clef primaire de l'entité propriétaire. Dans les "
-"rares cas différents, vous devez donner une ou plusieurs autres colonnes ou "
-"expression à joindre par une formule SQL (voir <literal>org.hibernate.test."
-"onetooneformula</literal> pour un exemple).\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (optionnel - par défaut à <literal>false</"
-"literal>) : Indique que ce composant doit être chargé au premier accès à la "
-"variable d'instance (nécessite une instrumentation du bytecode au moment du "
-"build).\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>) : La stratégie à utiliser par Hibernate pour accéder à cette "
-"propriété."
+"literal>) : la stratégie que doit utiliser Hibernate pour accéder aux "
+"valeurs des propriétés. "
 
 #. Tag: para
-#: basic_mapping.xml:540
 #, no-c-format
 msgid ""
 "If the <literal>name</literal> attribute is missing, it is assumed that the "
 "class has no identifier property."
 msgstr ""
 "Si l'attribut <literal>name</literal> est absent, Hibernate considère que la "
-"classe ne possède pas de propriété identifiant."
+"classe ne possède pas de propriété d'identifiant."
 
 #. Tag: para
-#: basic_mapping.xml:545
 #, no-c-format
 msgid ""
 "The <literal>unsaved-value</literal> attribute is almost never needed in "
 "Hibernate3."
 msgstr ""
-"L'attribut <literal>unsaved-value</literal> est important ! Si l'identifiant "
-"de votre classe n'a pas une valeur par défaut compatible avec le "
-"comportement standard de Java (zéro ou null), vous devez alors préciser la "
-"valeur par défaut."
+"L'attribut <literal>unsaved-value</literal> n'est presque jamais nécessaire "
+"dans Hibernate3."
 
 #. Tag: para
-#: basic_mapping.xml:549
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is an alternative <literal>&lt;composite-id&gt;</literal> declaration "
 "that allows access to legacy data with composite keys. Its use is strongly "
 "discouraged for anything else."
 msgstr ""
 "La déclaration alternative <literal>&lt;composite-id&gt;</literal> permet "
-"l'acccès aux données d'anciens systèmes qui utilisent des clefs composées. "
-"Son utilisation est fortement déconseillée pour d'autres cas."
+"l'accès aux données d'anciens systèmes qui utilisent des clés composées. Son "
+"utilisation est fortement déconseillée pour d'autres cas."
 
 #. Tag: title
-#: basic_mapping.xml:555
 #, no-c-format
 msgid "Generator"
 msgstr "Generator"
 
 #. Tag: para
-#: basic_mapping.xml:557
 #, no-c-format
 msgid ""
 "The optional <literal>&lt;generator&gt;</literal> child element names a Java "
@@ -1138,49 +861,33 @@
 "generator instance, they are passed using the <literal>&lt;param&gt;</"
 "literal> element."
 msgstr ""
-"L'élément fils <literal>&lt;generator&gt;</literal> nomme une classe Java "
+"L'élément enfant <literal>&lt;generator&gt;</literal> nomme une classe Java "
 "utilisée pour générer les identifiants uniques pour les instances des "
 "classes persistantes. Si des paramètres sont requis pour configurer ou "
 "initialiser l'instance du générateur, ils sont passés en utilisant l'élément "
 "<literal>&lt;param&gt;</literal>."
 
-#. Tag: programlisting
-#: basic_mapping.xml:564
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"org.hibernate.id.TableHiLoGenerator\">\n"
-"                <param name=\"table\">uid_table</param>\n"
-"                <param name=\"column\">next_hi_value_column</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:566
-#, fuzzy, no-c-format
-msgid ""
 "All generators implement the interface <literal>org.hibernate.id."
 "IdentifierGenerator</literal>. This is a very simple interface. Some "
 "applications can choose to provide their own specialized implementations, "
 "however, Hibernate provides a range of built-in implementations. The "
 "shortcut names for the built-in generators are as follows:"
 msgstr ""
-"Tous les générateurs doivent implémenter l'interface <literal>org.hibernate."
-"id.IdentifierGenerator</literal>. C'est une interface très simple ; "
-"certaines applications peuvent proposer leur propre implémentations "
-"spécialisées. Cependant, Hibernate propose une série d'implémentations "
-"intégrées. Il existe des noms raccourcis pour les générateurs intégrés : "
-"<placeholder-1/>"
+"Tous les générateurs implémentent l'interface <literal>org.hibernate.id."
+"IdentifierGenerator</literal>. C'est une interface très simple ; certaines "
+"applications peuvent proposer leurs propres implémentations spécialisées. "
+"Cependant, Hibernate propose une série d'implémentations intégrées. Il "
+"existe des noms raccourcis pour les générateurs intégrés :"
 
-#. Tag: literal
-#: basic_mapping.xml:574
+#. Tag: term
 #, no-c-format
-msgid "increment"
-msgstr "increment"
+msgid "<literal>increment</literal>"
+msgstr "<literal>increment</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:576
 #, no-c-format
 msgid ""
 "generates identifiers of type <literal>long</literal>, <literal>short</"
@@ -1188,55 +895,49 @@
 "process is inserting data into the same table. <emphasis>Do not use in a "
 "cluster.</emphasis>"
 msgstr ""
-"Génère des identifiants de type <literal>long</literal>, <literal>short</"
+"génère des identifiants de type <literal>long</literal>, <literal>short</"
 "literal> ou <literal>int</literal> qui ne sont uniques que si aucun autre "
 "processus n'insère de données dans la même table. <emphasis>Ne pas utiliser "
 "en environnement clusterisé.</emphasis>"
 
-#. Tag: literal
-#: basic_mapping.xml:585
+#. Tag: term
 #, no-c-format
-msgid "identity"
-msgstr "identity"
+msgid "<literal>identity</literal>"
+msgstr "<literal>identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:587
 #, no-c-format
 msgid ""
 "supports identity columns in DB2, MySQL, MS SQL Server, Sybase and "
 "HypersonicSQL. The returned identifier is of type <literal>long</literal>, "
 "<literal>short</literal> or <literal>int</literal>."
 msgstr ""
-"Utilisation de la colonne identity de DB2, MySQL, MS SQL Server, Sybase et "
-"HypersonicSQL. L'identifiant renvoyé est de type <literal>long</literal>, "
-"<literal>short</literal> ou <literal>int</literal>."
+"prend en charge les colonnes d'identité dans DB2, MySQL, MS SQL Server, "
+"Sybase et HypersonicSQL. L'identifiant renvoyé est de type <literal>long</"
+"literal>, <literal>short</literal> ou <literal>int</literal>."
 
-#. Tag: literal
-#: basic_mapping.xml:595
+#. Tag: term
 #, no-c-format
-msgid "sequence"
-msgstr "sequence"
+msgid "<literal>sequence</literal>"
+msgstr "<literal>sequence</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:597
 #, no-c-format
 msgid ""
 "uses a sequence in DB2, PostgreSQL, Oracle, SAP DB, McKoi or a generator in "
 "Interbase. The returned identifier is of type <literal>long</literal>, "
 "<literal>short</literal> or <literal>int</literal>"
 msgstr ""
-"Utilisation des séquences dans DB2, PostgreSQL, Oracle, SAP DB, McKoi ou "
-"d'un générateur dans Interbase. L'identifiant renvoyé est de type "
-"<literal>long</literal>, <literal>short</literal> ou <literal>int</literal>"
+"utilise une séquence dans DB2, PostgreSQL, Oracle, SAP DB, McKoi ou un "
+"générateur dans Interbase. L'identifiant renvoyé est de type <literal>long</"
+"literal>, <literal>short</literal> ou <literal>int</literal>"
 
-#. Tag: literal
-#: basic_mapping.xml:605
+#. Tag: term
 #, no-c-format
-msgid "hilo"
-msgstr "hilo"
+msgid "<literal>hilo</literal>"
+msgstr "<literal>hilo</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:607
 #, no-c-format
 msgid ""
 "uses a hi/lo algorithm to efficiently generate identifiers of type "
@@ -1246,141 +947,126 @@
 "hi/lo algorithm generates identifiers that are unique only for a particular "
 "database."
 msgstr ""
-"Utilise un algorithme hi/lo pour générer de façon efficace des identifiants "
+"utilise un algorithme hi/lo pour générer de façon efficace des identifiants "
 "de type <literal>long</literal>, <literal>short</literal> ou <literal>int</"
-"literal>, en prenant comme source de valeur \"hi\" une table et une colonne "
+"literal>, en prenant comme source de valeurs \"hi\" une table et une colonne "
 "(par défaut <literal>hibernate_unique_key</literal> et <literal>next_hi</"
 "literal> respectivement). L'algorithme hi/lo génère des identifiants uniques "
 "pour une base de données particulière seulement."
 
-#. Tag: literal
-#: basic_mapping.xml:617
+#. Tag: term
 #, no-c-format
-msgid "seqhilo"
-msgstr "seqhilo"
+msgid "<literal>seqhilo</literal>"
+msgstr "<literal>seqhilo</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:619
 #, no-c-format
 msgid ""
 "uses a hi/lo algorithm to efficiently generate identifiers of type "
 "<literal>long</literal>, <literal>short</literal> or <literal>int</literal>, "
 "given a named database sequence."
 msgstr ""
-"Utilise un algorithme hi/lo pour générer efficacement des identifiants de "
+"utilise un algorithme hi/lo pour générer efficacement des identifiants de "
 "type <literal>long</literal>, <literal>short</literal> ou <literal>int</"
-"literal>, étant donné un nom de séquence en base."
+"literal>, en prenant une séquence en base nommée."
 
-#. Tag: literal
-#: basic_mapping.xml:627
+#. Tag: term
 #, no-c-format
-msgid "uuid"
-msgstr "uuid"
+msgid "<literal>uuid</literal>"
+msgstr "<literal>uuid</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:629
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "uses a 128-bit UUID algorithm to generate identifiers of type string that "
 "are unique within a network (the IP address is used). The UUID is encoded as "
 "a string of 32 hexadecimal digits in length."
 msgstr ""
-"Utilise un algorithme de type UUID 128 bits pour générer des identifiants de "
+"utilise un algorithme de type UUID 128 bits pour générer des identifiants de "
 "type string, unique au sein d'un réseau (l'adresse IP est utilisée). Le UUID "
-"en codé en une chaîne de nombre héxadécimaux de longueur 32."
+"est encodé en une chaîne de nombre héxadécimaux de longueur 32. "
 
-#. Tag: literal
-#: basic_mapping.xml:637
+#. Tag: term
 #, no-c-format
-msgid "guid"
-msgstr "guid"
+msgid "<literal>guid</literal>"
+msgstr "<literal>guid</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:639
 #, no-c-format
 msgid "uses a database-generated GUID string on MS SQL Server and MySQL."
 msgstr ""
-"Utilise une chaîne GUID générée par la base pour MS SQL Server et MySQL."
+"utilise une chaîne GUID générée par la base pour MS SQL Server et MySQL."
 
-#. Tag: literal
-#: basic_mapping.xml:645
+#. Tag: term
 #, no-c-format
-msgid "native"
-msgstr "native"
+msgid "<literal>native</literal>"
+msgstr "<literal>native</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:647
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "selects <literal>identity</literal>, <literal>sequence</literal> or "
 "<literal>hilo</literal> depending upon the capabilities of the underlying "
 "database."
 msgstr ""
-"Choisit <literal>identity</literal>, <literal>sequence</literal> ou "
+"choisit <literal>identity</literal>, <literal>sequence</literal> ou "
 "<literal>hilo</literal> selon les possibilités offertes par la base de "
-"données sous-jacente."
+"données sous-jacente. "
 
-#. Tag: literal
-#: basic_mapping.xml:655
+#. Tag: term
 #, no-c-format
-msgid "assigned"
-msgstr "assigned"
+msgid "<literal>assigned</literal>"
+msgstr "<literal>assigned</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:657
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "lets the application assign an identifier to the object before <literal>save"
 "()</literal> is called. This is the default strategy if no <literal>&lt;"
 "generator&gt;</literal> element is specified."
 msgstr ""
-"Laisse l'application affecter un identifiant à l'objet avant que la métode "
-"<literal>save()</literal> soit appelée. Il s'agit de la stratégie par défaut "
-"si aucun <literal>&lt;generator&gt;</literal> n'est spécifié."
+"permet à l'application d'affecter un identifiant à l'objet avant que la "
+"méthode <literal>save()</literal> soit appelée. Il s'agit de la stratégie "
+"par défaut si aucun <literal>&lt;generator&gt;</literal> n'est spécifié. "
 
-#. Tag: literal
-#: basic_mapping.xml:665
+#. Tag: term
 #, no-c-format
-msgid "select"
-msgstr "select"
+msgid "<literal>select</literal>"
+msgstr "<literal>select</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:667
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "retrieves a primary key, assigned by a database trigger, by selecting the "
 "row by some unique key and retrieving the primary key value."
 msgstr ""
-"Récupère une clef primaire assignée par un trigger en sélectionnant la ligne "
-"par une clef unique quelconque."
+"récupère une clé primaire assignée par un déclencheur (trigger) de base de "
+"données en sélectionnant la ligne par une clé unique quelconque et en "
+"extrayant la valeur de la clé primaire."
 
-#. Tag: literal
-#: basic_mapping.xml:674
+#. Tag: term
 #, no-c-format
-msgid "foreign"
-msgstr "foreign"
+msgid "<literal>foreign</literal>"
+msgstr "<literal>foreign</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:676
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "uses the identifier of another associated object. It is usually used in "
 "conjunction with a <literal>&lt;one-to-one&gt;</literal> primary key "
 "association."
 msgstr ""
-"Utilise l'identifiant d'un objet associé. Habituellement utilisé en "
+"utilise l'identifiant d'un autre objet associé. Habituellement utilisé en "
 "conjonction avec une association <literal>&lt;one-to-one&gt;</literal> sur "
-"la clef primaire."
+"la clé primaire. "
 
-#. Tag: literal
-#: basic_mapping.xml:683
+#. Tag: term
 #, no-c-format
-msgid "sequence-identity"
-msgstr "sequence-identity"
+msgid "<literal>sequence-identity</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:685
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "a specialized sequence generation strategy that utilizes a database sequence "
 "for the actual value generation, but combines this with JDBC3 "
@@ -1389,22 +1075,21 @@
 "drivers targeted for JDK 1.4. Comments on these insert statements are "
 "disabled due to a bug in the Oracle drivers."
 msgstr ""
-"a specialized sequence generation strategy which utilizes a database "
-"sequence for the actual value generation, but combines this with JDBC3 "
-"getGeneratedKeys to actually return the generated identifier value as part "
-"of the insert statement execution. This strategy is only known to be "
-"supported on Oracle 10g drivers targetted for JDK 1.4. Note comments on "
-"these insert statements are disabled due to a bug in the Oracle drivers."
+"Une stratégie de génération de séquence spécialisée qui utilise une séquence "
+"de base de données pour la génération réelle de valeurs, tout en utilisant "
+"JDBC3 getGeneratedKeys pour retourner effectivement la valeur d'identifiant "
+"générée, comme faisant partie de l'exécution de la déclaration insert. Cette "
+"stratégie est uniquement prise en charge par les pilotes Oracle 10g pour JDK "
+"1.4. Notez que les commentaires sur ces déclarations insert sont désactivés "
+"à cause d'un bogue dans les pilotes d'Oracle. "
 
 #. Tag: title
-#: basic_mapping.xml:702
 #, no-c-format
 msgid "Hi/lo algorithm"
-msgstr "algorithme Hi/lo"
+msgstr "Algorithme Hi/lo"
 
 #. Tag: para
-#: basic_mapping.xml:703
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>hilo</literal> and <literal>seqhilo</literal> generators "
 "provide two alternate implementations of the hi/lo algorithm. The first "
@@ -1413,82 +1098,52 @@
 "sequence."
 msgstr ""
 "Les générateurs <literal>hilo</literal> et <literal>seqhilo</literal> "
-"proposent deux implémentations alternatives de l'algorithme hi/lo, une "
-"approche largement utilisée pour générer des identifiants. La première "
-"implémentation nécessite une table \"spéciale\" en base pour héberger la "
-"prochaine valeur \"hi\" disponible. La seconde utilise une séquence de type "
-"Oracle (quand la base sous-jacente le propose)."
+"proposent deux implémentations alternatives de l'algorithme hi/lo. La "
+"première implémentation nécessite une table \"spéciale\" en base pour "
+"héberger la prochaine valeur \"hi\" disponible. La seconde utilise une "
+"séquence de type Oracle (quand la base sous-jacente le propose). "
 
-#. Tag: programlisting
-#: basic_mapping.xml:710
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"hilo\">\n"
-"                <param name=\"table\">hi_value</param>\n"
-"                <param name=\"column\">next_value</param>\n"
-"                <param name=\"max_lo\">100</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:712
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"seqhilo\">\n"
-"                <param name=\"sequence\">hi_value</param>\n"
-"                <param name=\"max_lo\">100</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:714
-#, fuzzy, no-c-format
-msgid ""
 "Unfortunately, you cannot use <literal>hilo</literal> when supplying your "
 "own <literal>Connection</literal> to Hibernate. When Hibernate uses an "
 "application server datasource to obtain connections enlisted with JTA, you "
 "must configure the <literal>hibernate.transaction.manager_lookup_class</"
 "literal>."
 msgstr ""
-"Malheureusement, vous ne pouvez pas utilisez <literal>hilo</literal> quand "
+"Malheureusement, vous ne pouvez pas utiliser <literal>hilo</literal> quand "
 "vous apportez votre propre <literal>Connection</literal> à Hibernate. Quand "
 "Hibernate utilise une datasource du serveur d'application pour obtenir des "
 "connexions inscrites avec JTA, vous devez correctement configurer "
-"<literal>hibernate.transaction.manager_lookup_class</literal>."
+"<literal>hibernate.transaction.manager_lookup_class</literal>. "
 
 #. Tag: title
-#: basic_mapping.xml:723
 #, no-c-format
 msgid "UUID algorithm"
-msgstr "UUID algorithm"
+msgstr "Algorithme UUID "
 
 #. Tag: para
-#: basic_mapping.xml:724
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The UUID contains: IP address, startup time of the JVM that is accurate to a "
 "quarter second, system time and a counter value that is unique within the "
 "JVM. It is not possible to obtain a MAC address or memory address from Java "
 "code, so this is the best option without using JNI."
 msgstr ""
-"Le contenu du UUID est : adresse IP, date de démarrage de la JVM (précis au "
-"quart de seconde), l'heure système et un compteur (unique au sein de la "
-"JVM). Il n'est pas possible d'obtenir l'adresse MAC ou une adresse mémoire à "
-"partir de Java, c'est donc le mieux que l'on puisse faire sans utiliser JNI."
+"Le contenu du UUID est : l'adresse IP, la date de démarrage de la JVM "
+"(précis au quart de seconde), l'heure système et une contre-valeur (unique "
+"au sein de la JVM). Il n'est pas possible d'obtenir une adresse MAC ou une "
+"adresse mémoire à partir de Java, c'est donc le mieux que l'on puisse faire "
+"sans utiliser JNI. "
 
 #. Tag: title
-#: basic_mapping.xml:733
 #, no-c-format
 msgid "Identity columns and sequences"
 msgstr "Colonnes identifiantes et séquences"
 
 #. Tag: para
-#: basic_mapping.xml:734
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For databases that support identity columns (DB2, MySQL, Sybase, MS SQL), "
 "you can use <literal>identity</literal> key generation. For databases that "
@@ -1497,37 +1152,15 @@
 "strategies require two SQL queries to insert a new object. For example:"
 msgstr ""
 "Pour les bases qui implémentent les colonnes \"identité\" (DB2, MySQL, "
-"Sybase, MS SQL), vous pouvez utiliser la génération de clef par "
+"Sybase, MS SQL), vous pouvez utiliser la génération de clé par "
 "<literal>identity</literal>. Pour les bases qui implémentent les séquences "
 "(DB2, Oracle, PostgreSQL, Interbase, McKoi, SAP DB) vous pouvez utiliser la "
-"génération de clef par <literal>sequence</literal>. Ces deux méthodes "
-"nécessitent deux requêtes SQL pour insérer un objet."
+"génération de clé par <literal>sequence</literal>. Ces deux méthodes "
+"nécessitent deux requêtes SQL pour insérer un nouvel objet. Par exemple :"
 
-#. Tag: programlisting
-#: basic_mapping.xml:742
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-"        <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">person_id_sequence</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:744
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\" unsaved-value=\"0"
-"\">\n"
-"        <generator class=\"identity\"/>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:746
-#, fuzzy, no-c-format
-msgid ""
 "For cross-platform development, the <literal>native</literal> strategy will, "
 "depending on the capabilities of the underlying database, choose from the "
 "<literal>identity</literal>, <literal>sequence</literal> and <literal>hilo</"
@@ -1536,17 +1169,15 @@
 "Pour le développement multi-plateformes, la stratégie <literal>native</"
 "literal> choisira entre les méthodes <literal>identity</literal>, "
 "<literal>sequence</literal> et <literal>hilo</literal>, selon les "
-"possibilités offertes par la base sous-jacente."
+"possibilités offertes par la base sous-jacente. "
 
 #. Tag: title
-#: basic_mapping.xml:754
 #, no-c-format
 msgid "Assigned identifiers"
 msgstr "Identifiants assignés"
 
 #. Tag: para
-#: basic_mapping.xml:755
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want the application to assign identifiers, as opposed to having "
 "Hibernate generate them, you can use the <literal>assigned</literal> "
@@ -1559,14 +1190,13 @@
 "Si vous souhaitez que l'application assigne des identifiants (par opposition "
 "à la génération par Hibernate), vous pouvez utiliser le générateur "
 "<literal>assigned</literal>. Ce générateur spécial utilisera une valeur "
-"d'identifiant déjà utilisé par la propriété identifiant l'objet. Ce "
-"générateur est utilisé quand la clef primaire est une clef naturelle plutôt "
-"qu'une clef secondaire. C'est le comportement par défaut si vous ne précisez "
+"d'identifiant déjà utilisée par la propriété identifiant l'objet. Ce "
+"générateur est utilisé quand la clé primaire est une clé naturelle plutôt "
+"qu'une clé secondaire. C'est le comportement par défaut si vous ne précisez "
 "pas d'élément <literal>&lt;generator&gt;</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:764
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>assigned</literal> generator makes Hibernate use "
 "<literal>unsaved-value=\"undefined\"</literal>. This forces Hibernate to go "
@@ -1574,61 +1204,45 @@
 "there is a version or timestamp property, or you define <literal>Interceptor."
 "isUnsaved()</literal>."
 msgstr ""
-"Choisir le générateur <literal>assigned</literal> fait utiliser "
-"<literal>unsaved-value=\"undefined\"</literal> par Hibernate, le forçant à "
-"interroger la base pour déterminer si l'instance est transiente ou détachée, "
-"à moins d'utiliser une propriété version ou timestamp, ou alors de définir "
-"<literal>Interceptor.isUnsaved()</literal>."
+"Choisir le générateur <literal>assigned</literal> fait que Hibernate "
+"utilise<literal>unsaved-value=\"undefined\"</literal>, le forçant ainsi à "
+"interroger la base de données pour déterminer si une instance est transiente "
+"ou détachée, à moins d'utiliser une propriété version ou timestamp, ou alors "
+"de définir <literal>Interceptor.isUnsaved()</literal>. "
 
 #. Tag: title
-#: basic_mapping.xml:774
 #, no-c-format
 msgid "Primary keys assigned by triggers"
-msgstr "Clefs primaires assignées par trigger"
+msgstr "Clés primaires assignées par les triggers"
 
 #. Tag: para
-#: basic_mapping.xml:775
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate does not generate DDL with triggers. It is for legacy schemas only."
 msgstr ""
 "Pour les schémas de base hérités d'anciens systèmes uniquement (Hibernate ne "
-"génère pas de DDL avec des triggers)"
+"génère pas de DDL avec des triggers) "
 
-#. Tag: programlisting
-#: basic_mapping.xml:779
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-"        <generator class=\"select\">\n"
-"                <param name=\"key\">socialSecurityNumber</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:781
-#, fuzzy, no-c-format
-msgid ""
 "In the above example, there is a unique valued property named "
 "<literal>socialSecurityNumber</literal>. It is defined by the class, as a "
 "natural key and a surrogate key named <literal>person_id</literal>, whose "
 "value is generated by a trigger."
 msgstr ""
-"Dans l'exemple ci-dessus, <literal>socialSecurityNumber</literal> a une "
-"valeur unique définie par la classe en tant que clef naturelle et "
-"<literal>person_id</literal> est une clef secondaire dont la valeur est "
-"générée par trigger."
+"Dans l'exemple ci-dessus, il y a une valeur de propriété unique appelée "
+"<literal>socialSecurityNumber</literal>. Elle est définie par la classe en "
+"tant que clé naturelle et il y a également une clé secondaire appelée "
+"<literal>person_id</literal> dont la valeur est générée par un trigger."
 
 #. Tag: title
-#: basic_mapping.xml:793
 #, no-c-format
 msgid "Enhanced identifier generators"
-msgstr "Enhanced identifier generators"
+msgstr "La méthode getter de l'identifiant "
 
 #. Tag: para
-#: basic_mapping.xml:795
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Starting with release 3.2.3, there are 2 new generators which represent a re-"
 "thinking of 2 different aspects of identifier generation. The first aspect "
@@ -1638,17 +1252,17 @@
 "the named generators described above, starting in 3.3.x. However, they are "
 "included in the current releases and can be referenced by FQN."
 msgstr ""
-"Starting with release 3.2.3, there are 2 new generators which represent a re-"
-"thinking of 2 different aspects of identifier generation. The first aspect "
-"is database portability; the second is optimization (not having to query the "
-"database for every request for a new identifier value). These two new "
-"generators are intended to take the place of some of the named generators "
-"described above (starting in 3.3.x); however, they are included in the "
-"current releases and can be referenced by FQN."
+"A partir de la version 3.2.3, 2 générateurs représentent une nouvelle "
+"conception de 2 aspects séparés de la génération d'identifiants. Le premier "
+"aspect est la portabilité de la base de données; le second est "
+"l'optimization, c'est à dire que vous n'avez pas à interroger la base de "
+"données pour chaque requête de valeur d'identifiant. Ces deux nouveaux "
+"générateurs sont sensés prendre la place de générateurs décrits ci-dessus, "
+"ayant pour préfixe 3.3.x. Cependant, ils sont inclus dans les versions "
+"actuelles, et peuvent être référencés par FQN."
 
 #. Tag: para
-#: basic_mapping.xml:803
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The first of these new generators is <literal>org.hibernate.id.enhanced."
 "SequenceStyleGenerator</literal> which is intended, firstly, as a "
@@ -1667,100 +1281,95 @@
 "with its table-based generators. This generator has a number of "
 "configuration parameters:"
 msgstr ""
-"The first of these new generators is <literal>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</literal> which is intended firstly as a replacement "
-"for the <literal>sequence</literal> generator and secondly as a better "
-"portability generator than <literal>native</literal> (because "
-"<literal>native</literal> (generally) chooses between <literal>identity</"
-"literal> and <literal>sequence</literal> which have largely different "
-"semantics which can cause subtle isssues in applications eyeing "
-"portability). <literal>org.hibernate.id.enhanced.SequenceStyleGenerator</"
-"literal> however achieves portability in a different manner. It chooses "
-"between using a table or a sequence in the database to store its "
-"incrementing values depending on the capabilities of the dialect being used. "
-"The difference between this and <literal>native</literal> is that table-"
-"based and sequence-based storage have the same exact semantic (in fact "
-"sequences are exactly what Hibernate tries to emmulate with its table-based "
-"generators). This generator has a number of configuration parameters: "
-"<placeholder-1/>"
+"Le premier de ces nouveaux générateurs est <literal>org.Hibernate.ID."
+"Enhanced.SequenceStyleGenerator</literal> qui est destiné, tout d'abord, "
+"comme un remplacement pour le générateur <literal>séquence</literal> et, "
+"deuxièmement, comme un générateur de portabilité supérieur à <literal>natif</"
+"literal>. C'est parce que <literal>natif</literal> a généralement le choix "
+"entre <literal>identité</literal> et <literal>séquence</literal> qui ont des "
+"sémantiques largement différentes, ce qui peut entraîner des problèmes "
+"subtils en observant la portabilité des applications. <literal>org.Hibernate."
+"ID.Enhanced SequenceStyleGenerator.</literal>, cependant, réalise la "
+"portabilité d'une manière différente. Il choisit entre une table ou une "
+"séquence dans la base de données pour stocker ses valeurs s'incrémentant, "
+"selon les capacités du dialecte utilisé. La différence avec <literal>natif</"
+"literal> c'est que de stockage basé sur les tables ou basé sur la séquence "
+"ont la même sémantique. En fait, les séquences sont exactement ce "
+"qu'Hibernate essaie d'émuler avec ses générateurs basée sur les tables. Ce "
+"générateur a un certain nombre de paramètres de configuration :"
 
 #. Tag: para
-#: basic_mapping.xml:817
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>sequence_name</literal> (optional, defaults to "
 "<literal>hibernate_sequence</literal>): the name of the sequence or table to "
 "be used."
 msgstr ""
-"<literal>sequence_name</literal> (optional, defaults to "
-"<literal>hibernate_sequence</literal>): The name of the sequence (or table) "
-"to be used."
+"<literal>sequence_name</literal> (en option, par défaut = "
+"<literal>hibernate_sequence</literal>): le nom de la séquence ou table à "
+"utiliser."
 
 #. Tag: para
-#: basic_mapping.xml:823
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>initial_value</literal> (optional, defaults to <literal>1</"
 "literal>): the initial value to be retrieved from the sequence/table. In "
 "sequence creation terms, this is analogous to the clause typically named "
 "\"STARTS WITH\"."
 msgstr ""
-"<literal>initial_value</literal> (optional, defaults to <literal>1</"
-"literal>): The initial value to be retrieved from the sequence/table. In "
-"sequence creation terms, this is analogous to the clause typical named "
-"\"STARTS WITH\"."
+"<literal>initial_value</literal> (en option - par défaut = <literal>1</"
+"literal>) : la première valeur à extraire de la séquence/table. En termes de "
+"création de séquences, c'est semblable à la clause qui s'appelle \"STARTS "
+"WITH\" normalement."
 
 #. Tag: para
-#: basic_mapping.xml:830
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>increment_size</literal> (optional - defaults to <literal>1</"
 "literal>): the value by which subsequent calls to the sequence/table should "
 "differ. In sequence creation terms, this is analogous to the clause "
 "typically named \"INCREMENT BY\"."
 msgstr ""
-"<literal>increment_size</literal> (optional, defaults to <literal>1</"
-"literal>): The value by which subsequent calls to the sequence/table should "
-"differ. In sequence creation terms, this is analogous to the clause typical "
-"named \"INCREMENT BY\"."
+"<literal>increment_size</literal> (en option - par défaut = <literal>1</"
+"literal>): la valeur par laquelle les appels suivants à la séquence / table "
+"doivent différer. En termes de création de séquence, c'est analogue à la "
+"clause généralement nommé \"INCREMENT BY\"."
 
 #. Tag: para
-#: basic_mapping.xml:837
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>force_table_use</literal> (optional - defaults to <literal>false</"
 "literal>): should we force the use of a table as the backing structure even "
 "though the dialect might support sequence?"
 msgstr ""
-"<literal>force_table_use</literal> (optional, defaults to <literal>false</"
-"literal>): Should we force the use of a table as the backing structure even "
-"though the dialect might support sequence?"
+"<literal>force_table_use</literal> (optionnel - par défaut = <literal>false</"
+"literal>) : doit-on forcer l'utilisation de la table en tant que structure "
+"de soutien même si le dialecte peut supporter la séquence ?"
 
 #. Tag: para
-#: basic_mapping.xml:844
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>value_column</literal> (optional - defaults to <literal>next_val</"
 "literal>): only relevant for table structures, it is the name of the column "
 "on the table which is used to hold the value."
 msgstr ""
-"<literal>value_column</literal> (optional, defaults to <literal>next_val</"
-"literal>): Only relevant for table structures! The name of the column on the "
-"table which is used to hold the value."
+"<literal>value_column</literal> (en option - par défaut = <literal>next_val</"
+"literal>): uniquement utile pour les structures de tables. Correspond au nom "
+"de la colonne de la table qui est utilisée pour contenir la valeur."
 
 #. Tag: para
-#: basic_mapping.xml:851
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimizer</literal> (optional - defaults to <literal>none</"
-"literal>): See"
+"literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\" /"
+">"
 msgstr ""
-"<literal>cascade</literal> (optionnel - par défaut à <literal>none</"
-"literal>) : le style de cascade."
+"<literal>optimizer</literal> (en option - valeur par défaut = <literal>none</"
+"literal>): Voir <xref linkend=\"mapping-declaration-id-enhanced-optimizers"
+"\" />"
 
 #. Tag: para
-#: basic_mapping.xml:858
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The second of these new generators is <literal>org.hibernate.id.enhanced."
 "TableGenerator</literal>, which is intended, firstly, as a replacement for "
@@ -1773,148 +1382,141 @@
 "multiple distinctly keyed rows. This generator has a number of configuration "
 "parameters:"
 msgstr ""
-"The second of these new generators is <literal>org.hibernate.id.enhanced."
-"TableGenerator</literal> which is intended firstly as a replacement for the "
-"<literal>table</literal> generator (although it actually functions much more "
-"like <literal>org.hibernate.id.MultipleHiLoPerTableGenerator</literal>) and "
-"secondly as a re-implementation of <literal>org.hibernate.id."
-"MultipleHiLoPerTableGenerator</literal> utilizing the notion of pluggable "
-"optimiziers. Essentially this generator defines a table capable of holding a "
-"number of different increment values simultaneously by using multiple "
-"distinctly keyed rows. This generator has a number of configuration "
-"parameters: <placeholder-1/>"
+"Le deuxième de ces nouveaux générateurs est <literal>org.Hibernate.ID."
+"Enhanced.TableGenerator</literal>, qui est destiné, tout d'abord, comme un "
+"remplacement pour le générateur de la <literal>table</literal>, même si elle "
+"fonctionne effectivement beaucoup plus comme <literal>org.Hibernate.ID."
+"MultipleHiLoPerTableGenerator</literal>et deuxièmement, comme une remise en "
+"œuvre de <literal>org.Hibernate.ID.MultipleHiLoPerTableGenerator</literal>, "
+"qui utilise la notion d'optimizers enfichables. Essentiellement ce "
+"générateur définit une table susceptible de contenir un certain nombre de "
+"valeurs d'incrément différents simultanément à l'aide de plusieurs lignes "
+"distinctement masquées. Ce générateur a un certain nombre de paramètres de "
+"configuration :"
 
 #. Tag: para
-#: basic_mapping.xml:868
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>table_name</literal> (optional - defaults to "
 "<literal>hibernate_sequences</literal>): the name of the table to be used."
 msgstr ""
-"<literal>table_name</literal> (optional, defaults to "
-"<literal>hibernate_sequences</literal>): The name of the table to be used."
+"<literal>table_name</literal> (en optin - valeur par défaut = "
+"<literal>hibernate_sequences</literal>): le nom de la table à utiliser."
 
 #. Tag: para
-#: basic_mapping.xml:874
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>value_column_name</literal> (optional - defaults to "
 "<literal>next_val</literal>): the name of the column on the table that is "
 "used to hold the value."
 msgstr ""
-"<literal>value_column_name</literal> (optional, defaults to "
-"<literal>next_val</literal>): The name of the column on the table which is "
-"used to hold the value."
+"<literal>value_column_name</literal> (en option - valeur par défaut "
+"=<literal>next_val</literal>): le nom de la colonne contenue dans la table "
+"utilisée pour la valeur."
 
 #. Tag: para
-#: basic_mapping.xml:880
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>segment_column_name</literal> (optional - defaults to "
 "<literal>sequence_name</literal>): the name of the column on the table that "
 "is used to hold the \"segment key\". This is the value which identifies "
 "which increment value to use."
 msgstr ""
-"<literal>segment_column_name</literal> (optional, defaults to "
-"<literal>sequence_name</literal>): The name of the column on the table which "
-"is used to hold the \"segement key\". This is the value which distinctly "
-"identifies which increment value to use."
+"<literal>segment_column_name</literal> (en option - par défaut = "
+"<literal>sequence_name</literal>): le nom de la colonne de la table qui est "
+"utilisée pour contenir la \"segment key\". Il s'agit de la valeur qui "
+"identifie la valeur d'incrément à utiliser."
 
 #. Tag: para
-#: basic_mapping.xml:887
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>segment_value</literal> (optional - defaults to <literal>default</"
 "literal>): The \"segment key\" value for the segment from which we want to "
 "pull increment values for this generator."
 msgstr ""
-"<literal>segment_value</literal> (optional, defaults to <literal>default</"
-"literal>): The \"segment key\" value for the segment from which we want to "
-"pull increment values for this generator."
+"<literal>segment_value</literal> (en option - par défaut = <literal>par "
+"défaut</literal>): La \"segment key\"valeur pour le segment à partir de "
+"laquelle nous voulons extraire des valeurs d'incrémentation pour ce "
+"générateur."
 
 #. Tag: para
-#: basic_mapping.xml:894
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>segment_value_length</literal> (optional - defaults to "
 "<literal>255</literal>): Used for schema generation; the column size to "
 "create this segment key column."
 msgstr ""
-"<literal>segment_value_length</literal> (optional, defaults to <literal>255</"
-"literal>): Used for schema generation; the column size to create this "
-"segment key column."
+"<literal>segment_value_length</literal> (en option - par défaut = "
+"<literal>255</literal>): Utilisée pour la génération de schéma ; la taille "
+"de la colonne pour créer cette colonne de clé de segment."
 
 #. Tag: para
-#: basic_mapping.xml:900
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>initial_value</literal> (optional - defaults to <literal>1</"
 "literal>): The initial value to be retrieved from the table."
 msgstr ""
-"<literal>initial_value</literal> (optional, defaults to <literal>1</"
-"literal>): The initial value to be retrieved from the table."
+"<literal>initial_value</literal> (en option - par défaut est <literal>1</"
+"literal> : La valeur initiale à récupérer à partir de la table."
 
 #. Tag: para
-#: basic_mapping.xml:906
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>increment_size</literal> (optional - defaults to <literal>1</"
 "literal>): The value by which subsequent calls to the table should differ."
 msgstr ""
-"<literal>increment_size</literal> (optional, defaults to <literal>1</"
-"literal>): The value by which subsequent calls to the table should differ."
+"<literal>increment_size</literal> (en option - par défaut = <literal>1</"
+"literal>): La valeur par laquelle les appels à la table, qui suivent, "
+"devront différer."
 
 #. Tag: para
-#: basic_mapping.xml:912
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimizer</literal> (optional - defaults to <literal></literal>): "
-"See"
+"See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\" />"
 msgstr ""
-"<literal>cascade</literal> (optionnel - par défaut à <literal>none</"
-"literal>) : le style de cascade."
+"<literal>optimizer</literal> (en option - valeur par défaut = <literal></"
+"literal>): Voir <xref linkend=\"mapping-declaration-id-enhanced-optimizers"
+"\" />"
 
 #. Tag: title
-#: basic_mapping.xml:922
 #, no-c-format
 msgid "Identifier generator optimization"
-msgstr "Identifier generator optimization"
+msgstr "Optimisation du générateur d'identifiants"
 
 #. Tag: para
-#: basic_mapping.xml:923
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For identifier generators that store values in the database, it is "
 "inefficient for them to hit the database on each and every call to generate "
 "a new identifier value. Instead, you can group a bunch of them in memory and "
 "only hit the database when you have exhausted your in-memory value group. "
 "This is the role of the pluggable optimizers. Currently only the two "
-"enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced\"/> "
+"enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced\" /> "
 "support this operation."
 msgstr ""
-"For identifier generators which store values in the database, it is "
-"inefficient for them to hit the database on each and every call to generate "
-"a new identifier value. Instead, you'd ideally want to group a bunch of them "
-"in memory and only hit the database when you have exhausted your in-memory "
-"value group. This is the role of the pluggable optimizers. Currently only "
-"the two enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced"
-"\"/> support this notion. <placeholder-1/>"
+"Pour les générateurs d'identifiants qui stockent des valeurs dans la base de "
+"données, il est inefficace d'interroger la base de données sur chaque appel "
+"en vue de générer une nouvelle valeur d'identifiant. Au lieu de cela, vous "
+"pouvez les regrouper dans un ensemble dans la mémoire et interroger la base "
+"de données que lorsque vous aurez épuisé votre groupe de valeur en mémoire. "
+"C'est le rôle des optimizers enfichables. Actuellement seulement les deux "
+"générateurs améliorés (<xref linkend=\"mapping-declaration-id-enhanced\" /> "
+"prennent en charge cette opération."
 
 #. Tag: para
-#: basic_mapping.xml:931
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>none</literal> (generally this is the default if no optimizer was "
 "specified): this will not perform any optimizations and hit the database for "
 "each and every request."
 msgstr ""
-"<literal>none</literal> (generally this is the default if no optimizer was "
-"specified): This says to not perform any optimizations, and hit the database "
-"each and every request."
+"<literal>aucun</literal> (en général il s'agit de la valeur par défaut si "
+"aucun optimizer n'a été spécifié): n'effectuera pas d'optimisations et "
+"n'interrogera pas la base de données à chaque demande."
 
 #. Tag: para
-#: basic_mapping.xml:937
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>hilo</literal>: applies a hi/lo algorithm around the database "
 "retrieved values. The values from the database for this optimizer are "
@@ -1923,16 +1525,15 @@
 "<literal>increment_size</literal> is multiplied by that value in memory to "
 "define a group \"hi value\"."
 msgstr ""
-"<literal>hilo</literal>: applies a hi/lo algorithm around the database "
-"retrieved values. The values from the database for this optimizer are "
-"expected to be sequential. The values retrieved from the database structure "
-"for this optimizer indicates the \"group number\"; the "
-"<literal>increment_size</literal> is multiplied by that value in memory to "
-"define a group \"hi value\"."
+"<literal>hilo</literal>: applique un algorithme hi/lo autour des valeurs "
+"extraites des base de données. Les valeurs de la base de données de cet "
+"optimizer sont censées être séquentielles. Les valeurs extraites de la "
+"structure des base de données pour cet optimizer indique le \"numéro de "
+"groupe\". Le <literal>increment_size</literal> est multiplié par cette "
+"valeur en mémoire pour définir un groupe de \"hi value\"."
 
 #. Tag: para
-#: basic_mapping.xml:946
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>pooled</literal>: as with the case of <literal>hilo</literal>, this "
 "optimizer attempts to minimize the number of hits to the database. Here, "
@@ -1941,79 +1542,47 @@
 "memory grouping algorithm. Here, <literal>increment_size</literal> refers to "
 "the values coming from the database."
 msgstr ""
-"<literal>pooled</literal>: like was discussed for <literal>hilo</literal>, "
-"this optimizers attempts to minimize the number of hits to the database. "
-"Here, however, we simply store the starting value for the \"next group\" "
-"into the database structure rather than a sequential value in combination "
-"with an in-memory grouping algorithm. <literal>increment_size</literal> here "
-"refers to the values coming from the database."
+"<literal>mise en commun</literal>: tout comme dans le cas de <literal>hilo</"
+"literal>, cet optimizer tente de réduire le nombre d'interrogations vers la "
+"base de données. Ici, cependant, nous avons simplement stocké la valeur de "
+"départ pour le \"prochain groupe\"dans la structure de la base de données "
+"plutôt qu'une valeur séquentielle en combinaison avec un algorithme de "
+"regroupement en mémoire. Ici, <literal>increment_size</literal> fait "
+"référence aux valeurs provenant de la base de données."
 
 #. Tag: title
-#: basic_mapping.xml:959
 #, no-c-format
 msgid "composite-id"
 msgstr "composite-id"
 
-#. Tag: programlisting
-#: basic_mapping.xml:961
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<composite-id\n"
-"        name=\"propertyName\"\n"
-"        class=\"ClassName\"\n"
-"        mapped=\"true|false\"\n"
-"        access=\"field|property|ClassName\">\n"
-"        node=\"element-name|.\"\n"
-"\n"
-"        <key-property name=\"propertyName\" type=\"typename\" column="
-"\"column_name\"/>\n"
-"        <key-many-to-one name=\"propertyName class=\"ClassName\" column="
-"\"column_name\"/>\n"
-"        ......\n"
-"</composite-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:963
-#, fuzzy, no-c-format
-msgid ""
 "A table with a composite key can be mapped with multiple properties of the "
 "class as identifier properties. The <literal>&lt;composite-id&gt;</literal> "
 "element accepts <literal>&lt;key-property&gt;</literal> property mappings "
 "and <literal>&lt;key-many-to-one&gt;</literal> mappings as child elements."
 msgstr ""
-"Pour une table avec clef composée, vous pouvez mapper plusieurs attributs de "
-"la classe comme propriétés identifiantes. L'élement <literal>&lt;composite-"
-"id&gt;</literal> accepte les mappings de propriétés <literal>&lt;key-"
-"property&gt;</literal> et les mappings <literal>&lt;key-many-to-one&gt;</"
-"literal> comme fils."
+"Pour une table avec clé composée, vous pouvez mapper plusieurs attributs de "
+"la classe comme propriétés identifiantes. L'élément <literal>&lt;composite-"
+"id&gt;</literal> accepte les mappages de propriétés <literal>&lt;key-"
+"property&gt;</literal> et les mappages <literal>&lt;key-many-to-one&gt;</"
+"literal> comme éléments enfants. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:970
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<composite-id>\n"
-"        <key-property name=\"medicareNumber\"/>\n"
-"        <key-property name=\"dependent\"/>\n"
-"</composite-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:972
-#, fuzzy, no-c-format
-msgid ""
 "The persistent class <emphasis>must</emphasis> override <literal>equals()</"
 "literal> and <literal>hashCode()</literal> to implement composite identifier "
 "equality. It must also implement <literal>Serializable</literal>."
 msgstr ""
 "Vos classes persistantes <emphasis>doivent</emphasis> surcharger les "
 "méthodes <literal>equals()</literal> et <literal>hashCode()</literal> pour "
-"implémenter l'égalité d'identifiant composé. Elles doivent aussi implenter "
-"l'interface <literal>Serializable</literal>."
+"implémenter l'égalité d'identifiant composite. Elles doivent aussi "
+"implémenter l'interface <literal>Serializable</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:978
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Unfortunately, this approach means that a persistent object is its own "
 "identifier. There is no convenient \"handle\" other than the object itself. "
@@ -2023,17 +1592,16 @@
 "<emphasis>embedded</emphasis> composite identifier, and discourage it for "
 "serious applications."
 msgstr ""
-"Malheureusement cette approche sur les identifiants composés signifie qu'un "
-"objet persistant est son propre identifiant. Il n'y a pas d'autre moyen "
-"pratique de manipuler l'objet que par l'objet lui-même. Vous devez "
-"instancier une instance de la classe persistante elle-même et peupler ses "
-"attributs identifiants avant de pouvoir appeler la méthode <literal>load()</"
-"literal> pour charger son état persistant associé à une clef composée. Nous "
-"appelons cette approche \"identifiant composé <emphasis>embarqué</emphasis>"
-"\" et ne la recommandons pas pour des applications complexes."
+"Malheureusement, cette approche signifie qu'un objet persistant est son "
+"propre identifiant. Il n'y a pas d'autre moyen pratique de \"manipuler\" "
+"l'objet que par l'objet lui-même. Vous devez instancier une instance de la "
+"classe persistante elle-même et peupler ses attributs identifiants avant de "
+"pouvoir appeler la méthode <literal>load()</literal> pour charger son état "
+"persistant associé à une clé composée. Nous appelons cette approche "
+"\"identifiant composé <emphasis>embarqué</emphasis>\" et ne la recommandons "
+"pas pour des applications complexes."
 
 #. Tag: para
-#: basic_mapping.xml:987
 #, no-c-format
 msgid ""
 "A second approach is what we call a <emphasis>mapped</emphasis> composite "
@@ -2042,24 +1610,13 @@
 "class and a separate identifier class."
 msgstr ""
 "Une seconde approche, appelée identifiant composé <emphasis>mappé</"
-"emphasis>, consiste à encapsuler les propriétés identifiantes (celles "
-"contenues dans <literal>&lt;composite-id&gt;</literal>) dans une classe "
-"particulière."
+"emphasis>, consiste à dupliquer les propriétés identifiantes nommées dans "
+"l'élément <literal>&lt;composite-id&gt;</literal>) à la fois dans la classe "
+"persistante et dans une classe identifiante particulière."
 
-#. Tag: programlisting
-#: basic_mapping.xml:993
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<composite-id class=\"MedicareId\" mapped=\"true\">\n"
-"        <key-property name=\"medicareNumber\"/>\n"
-"        <key-property name=\"dependent\"/>\n"
-"</composite-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:995
-#, fuzzy, no-c-format
-msgid ""
 "In this example, both the composite identifier class, <literal>MedicareId</"
 "literal>, and the entity class itself have properties named "
 "<literal>medicareNumber</literal> and <literal>dependent</literal>. The "
@@ -2072,10 +1629,9 @@
 "<literal>medicareNumber</literal> et <literal>dependent</literal>. La classe "
 "identifiante doit redéfinir <literal>equals()</literal> et <literal>hashCode"
 "()</literal> et implémenter <literal>Serializable</literal>. Le désavantage "
-"de cette approche est la duplication du code."
+"de cette approche est la duplication du code. "
 
 #. Tag: para
-#: basic_mapping.xml:1004
 #, no-c-format
 msgid ""
 "The following attributes are used to specify a mapped composite identifier:"
@@ -2083,8 +1639,7 @@
 "Les attributs suivants servent à configurer un identifiant composé mappé :"
 
 #. Tag: para
-#: basic_mapping.xml:1010
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mapped</literal> (optional - defaults to <literal>false</literal>): "
 "indicates that a mapped composite identifier is used, and that the contained "
@@ -2092,37 +1647,34 @@
 "identifier class."
 msgstr ""
 "<literal>mapped</literal> (optionnel, défaut à <literal>false</literal>) : "
-"indique qu'un identifiant composé mappé est utilisé, et que les propriétés "
-"contenues font référence aux deux classes (celle mappée et la classe "
-"identifiante)."
+"indique qu'un identifiant composé mappé est utilisé, et que les mappages de "
+"propriétés contenues font référence aux deux classes, la classe mappée et la "
+"classe identifiante composée. "
 
 #. Tag: para
-#: basic_mapping.xml:1018
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - but required for a mapped composite "
 "identifier): the class used as a composite identifier."
 msgstr ""
 "<literal>class</literal> (optionnel, mais requis pour un identifiant composé "
-"mappé) : La classe composant utilisée comme identifiant composé."
+"mappé) : la classe utilisée comme identifiant composé. "
 
 #. Tag: para
-#: basic_mapping.xml:1025
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will describe a third, even more convenient approach, where the composite "
 "identifier is implemented as a component class in <xref linkend=\"components-"
-"compositeid\"/>. The attributes described below apply only to this "
+"compositeid\" />. The attributes described below apply only to this "
 "alternative approach:"
 msgstr ""
-"Nous décrirons une troisième approche beaucoup plus efficace ou "
+"Nous décrirons une troisième approche beaucoup plus efficace pour laquelle "
 "l'identifiant composé est implémenté comme une classe composant dans <xref "
-"linkend=\"components-compositeid\"/>. Les attributs décrits ci dessous, ne "
+"linkend=\"components-compositeid\" />. Les attributs décrits ci dessous, ne "
 "s'appliquent que pour cette dernière approche :"
 
 #. Tag: para
-#: basic_mapping.xml:1033
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal> (optional - required for this approach): a property "
 "of component type that holds the composite identifier. Please see chapter 9 "
@@ -2130,88 +1682,45 @@
 msgstr ""
 "<literal>name</literal> (optionnel, requis pour cette approche) : une "
 "propriété de type composant qui contient l'identifiant composé (voir "
-"chapitre 9)."
+"chapitre 9). "
 
 #. Tag: para
-#: basic_mapping.xml:1039 basic_mapping.xml:1260 basic_mapping.xml:1372
-#: basic_mapping.xml:1561 basic_mapping.xml:1735 basic_mapping.xml:1905
-#: basic_mapping.xml:2484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate uses for accessing the property value."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>access</literal> (optionnel - par défaut <literal>property</"
-"literal>) : La stratégie que doit utiliser Hibernate pour accéder aux "
-"valeurs des propriétés.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - défaut à <literal>property</"
-"literal>) : La stratégie qu'Hibernate utilisera pour accéder à la valeur de "
-"la propriété.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>) : La stratégie à utiliser par Hibernate pour accéder à la valeur "
-"de la propriété.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>) : La stratégie à utiliser par Hibernate pour accéder à la valeur "
-"de la propriété.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>): Stratégie que Hibernate doit utiliser pour accéder à cette "
-"valeur.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>) : La stratégie à utiliser par Hibernate pour accéder à la valeur "
-"de cette propriété.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>formula</literal> (optionnel) : Presque toutes les associations one-"
-"to-one pointent sur la clef primaire de l'entité propriétaire. Dans les "
-"rares cas différents, vous devez donner une ou plusieurs autres colonnes ou "
-"expression à joindre par une formule SQL (voir <literal>org.hibernate.test."
-"onetooneformula</literal> pour un exemple).\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (optionnel - par défaut à <literal>false</"
-"literal>) : Indique que ce composant doit être chargé au premier accès à la "
-"variable d'instance (nécessite une instrumentation du bytecode au moment du "
-"build).\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>) : La stratégie à utiliser par Hibernate pour accéder à cette "
-"propriété."
+"literal>) : la stratégie que doit utiliser Hibernate pour accéder aux "
+"valeurs des propriétés. "
 
 #. Tag: para
-#: basic_mapping.xml:1045
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
 "determined by reflection): the component class used as a composite "
 "identifier. Please see the next section for more information."
 msgstr ""
-"<literal>class</literal> (optionnel - défaut au type de la propriété "
-"déterminé par réflexion) : La classe composant utilisée comme identifiant "
-"(voir prochaine section)."
+"<literal>class</literal> (optionnel - par défaut le type de la propriété "
+"déterminé par réflexion) : la classe composant utilisée comme identifiant "
+"(voir prochaine section). "
 
 #. Tag: para
-#: basic_mapping.xml:1052
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The third approach, an <emphasis>identifier component</emphasis>, is "
 "recommended for almost all applications."
 msgstr ""
-"Cette dernière approche est celle que nous recommandons pour toutes vos "
-"applications."
+"La troisième approche, un <emphasis>composant d'identifiant</emphasis>, est "
+"celle que nous recommandons pour toutes vos applications."
 
 #. Tag: title
-#: basic_mapping.xml:1060
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Discriminator"
-msgstr "discriminator"
+msgstr "Discriminator"
 
 #. Tag: para
-#: basic_mapping.xml:1062
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;discriminator&gt;</literal> element is required for "
 "polymorphic persistence using the table-per-class-hierarchy mapping "
@@ -2224,51 +1733,36 @@
 "literal>."
 msgstr ""
 "L'élément <literal>&lt;discriminator&gt;</literal> est nécessaire pour la "
-"persistance polymorphique qui utilise la stratégie de mapping de table par "
-"hiérarchie de classe. La colonne discriminante contient une valeur marqueur "
-"qui permet à la couche de persistance de savoir quelle sous-classe "
-"instancier pour une ligne particulière de table en base. Un nombre restreint "
-"de types peuvent être utilisés : <literal>string</literal>, "
-"<literal>character</literal>, <literal>integer</literal>, <literal>byte</"
-"literal>, <literal>short</literal>, <literal>boolean</literal>, "
-"<literal>yes_no</literal>, <literal>true_false</literal>."
+"persistance polymorphique qui utilise la stratégie de mappage de table par "
+"hiérarchie de classe et déclare une colonne discriminante de la table. La "
+"colonne discriminante contient des valeurs marqueur qui permettent à la "
+"couche de persistance de savoir quelle sous-classe instancier pour une ligne "
+"particulière de table en base. Un nombre restreint de types peuvent être "
+"utilisés : <literal>string</literal>, <literal>character</literal>, "
+"<literal>integer</literal>, <literal>byte</literal>, <literal>short</"
+"literal>, <literal>boolean</literal>, <literal>yes_no</literal>, "
+"<literal>true_false</literal>."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1080
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<discriminator\n"
-"        column=\"discriminator_column\"\n"
-"        type=\"discriminator_type\"\n"
-"        force=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        formula=\"arbitrary sql expression\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1083
-#, fuzzy, no-c-format
-msgid ""
 "<literal>column</literal> (optional - defaults to <literal>class</literal>): "
 "the name of the discriminator column."
 msgstr ""
 "<literal>column</literal> (optionnel - par défaut à <literal>class</"
-"literal>) le nom de la colonne discriminante."
+"literal>), le nom de la colonne discriminante. "
 
 #. Tag: para
-#: basic_mapping.xml:1089
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>type</literal> (optional - defaults to <literal>string</literal>): "
 "a name that indicates the Hibernate type"
 msgstr ""
 "<literal>type</literal> (optionnel - par défaut à <literal>string</literal>) "
-"un nom indiquant le type Hibernate."
+"un nom indiquant le type Hibernate. "
 
 #. Tag: para
-#: basic_mapping.xml:1095
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>force</literal> (optional - defaults to <literal>false</literal>): "
 "\"forces\" Hibernate to specify the allowed discriminator values, even when "
@@ -2276,11 +1770,10 @@
 msgstr ""
 "<literal>force</literal> (optionnel - par défaut à <literal>false</literal>) "
 "\"oblige\" Hibernate à spécifier une valeur discriminante autorisée même "
-"quand on récupère toutes les instances de la classe de base."
+"quand on récupère toutes les instances de la classe de base. "
 
 #. Tag: para
-#: basic_mapping.xml:1102
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>insert</literal> (optional - defaults to <literal>true</literal>): "
 "set this to <literal>false</literal> if your discriminator column is also "
@@ -2290,11 +1783,10 @@
 "<literal>insert</literal> (optionnel - par défaut à <literal>true</literal>) "
 "à passer à <literal>false</literal> si la colonne discriminante fait aussi "
 "partie d'un identifiant composé mappé (Indique à Hibernate de ne pas inclure "
-"la colonne dans les <literal>INSERT</literal> SQL)."
+"la colonne dans les SQL <literal>INSERT</literal> s). "
 
 #. Tag: para
-#: basic_mapping.xml:1110
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an arbitrary SQL expression that is "
 "executed when a type has to be evaluated. It allows content-based "
@@ -2302,10 +1794,9 @@
 msgstr ""
 "<literal>formula</literal> (optionnel) une expression SQL arbitraire qui est "
 "exécutée quand un type doit être évalué. Permet la discrimination basée sur "
-"le contenu."
+"le contenu. "
 
 #. Tag: para
-#: basic_mapping.xml:1118
 #, no-c-format
 msgid ""
 "Actual values of the discriminator column are specified by the "
@@ -2314,11 +1805,10 @@
 msgstr ""
 "Les véritables valeurs de la colonne discriminante sont spécifiées par "
 "l'attribut <literal>discriminator-value</literal> des éléments <literal>&lt;"
-"class&gt;</literal> et <literal>&lt;subclass&gt;</literal>."
+"class&gt;</literal> et <literal>&lt;subclass&gt;</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:1124
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>force</literal> attribute is only useful if the table contains "
 "rows with \"extra\" discriminator values that are not mapped to a persistent "
@@ -2326,37 +1816,25 @@
 msgstr ""
 "L'attribut <literal>force</literal> n'est utile que si la table contient des "
 "lignes avec des valeurs \"extra\" discriminantes qui ne sont pas mappées à "
-"une classe persistante. Ce ne sera généralement pas le cas."
+"une classe persistante. Ce ne sera généralement pas le cas. "
 
 #. Tag: para
-#: basic_mapping.xml:1130
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>formula</literal> attribute allows you to declare an arbitrary "
 "SQL expression that will be used to evaluate the type of a row. For example:"
 msgstr ""
 "En utilisant l'attribut <literal>formula</literal> vous pouvez déclarer une "
 "expression SQL arbitraire qui sera utilisée pour évaluer le type d'une "
-"ligne :"
+"ligne : "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1135
-#, no-c-format
-msgid ""
-"<![CDATA[<discriminator\n"
-"    formula=\"case when CLASS_TYPE in ('a', 'b', 'c') then 0 else 1 end\"\n"
-"    type=\"integer\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:1140
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Version (optional)"
-msgstr "version (optionnel)"
+msgstr "Version (optionnel)"
 
 #. Tag: para
-#: basic_mapping.xml:1142
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;version&gt;</literal> element is optional and indicates "
 "that the table contains versioned data. This is particularly useful if you "
@@ -2368,100 +1846,43 @@
 "avez l'intention d'utiliser des <emphasis>transactions longues</emphasis> "
 "(voir plus-bas)."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1158
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<version\n"
-"        column=\"version_column\"\n"
-"        name=\"propertyName\"\n"
-"        type=\"typename\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unsaved-value=\"null|negative|undefined\"\n"
-"        generated=\"never|always\"\n"
-"        insert=\"true|false\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1161
-#, fuzzy, no-c-format
-msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of the column holding the version number."
 msgstr ""
 "<literal>column</literal> (optionnel - par défaut égal au nom de la "
-"propriété) : Le nom de la colonne contenant le numéro de version."
+"propriété) : le nom de la colonne contenant le numéro de version. "
 
 #. Tag: para
-#: basic_mapping.xml:1167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal>: the name of a property of the persistent class."
 msgstr ""
-"<literal>name</literal> : Le nom d'un attribut de la classe persistante."
+"<literal>name</literal> : le nom d'un attribut de la classe persistante. "
 
 #. Tag: para
-#: basic_mapping.xml:1172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>type</literal> (optional - defaults to <literal>integer</literal>): "
 "the type of the version number."
 msgstr ""
 "<literal>type</literal> (optionnel - par défaut à <literal>integer</"
-"literal>) : Le type du numéro de version."
+"literal>) : le type du numéro de version. "
 
 #. Tag: para
-#: basic_mapping.xml:1178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate uses to access the property value."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>access</literal> (optionnel - par défaut <literal>property</"
-"literal>) : La stratégie que doit utiliser Hibernate pour accéder aux "
-"valeurs des propriétés.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - défaut à <literal>property</"
-"literal>) : La stratégie qu'Hibernate utilisera pour accéder à la valeur de "
-"la propriété.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>) : La stratégie à utiliser par Hibernate pour accéder à la valeur "
-"de la propriété.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>) : La stratégie à utiliser par Hibernate pour accéder à la valeur "
-"de la propriété.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>): Stratégie que Hibernate doit utiliser pour accéder à cette "
-"valeur.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>) : La stratégie à utiliser par Hibernate pour accéder à la valeur "
-"de cette propriété.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>formula</literal> (optionnel) : Presque toutes les associations one-"
-"to-one pointent sur la clef primaire de l'entité propriétaire. Dans les "
-"rares cas différents, vous devez donner une ou plusieurs autres colonnes ou "
-"expression à joindre par une formule SQL (voir <literal>org.hibernate.test."
-"onetooneformula</literal> pour un exemple).\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (optionnel - par défaut à <literal>false</"
-"literal>) : Indique que ce composant doit être chargé au premier accès à la "
-"variable d'instance (nécessite une instrumentation du bytecode au moment du "
-"build).\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>) : La stratégie à utiliser par Hibernate pour accéder à cette "
-"propriété."
+"literal>) : la stratégie que doit utiliser Hibernate pour accéder aux "
+"valeurs des propriétés. "
 
 #. Tag: para
-#: basic_mapping.xml:1184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to <literal>undefined</"
 "literal>): a version property value that indicates that an instance is newly "
@@ -2470,14 +1891,13 @@
 "specifies that the identifier property value should be used."
 msgstr ""
 "<literal>unsaved-value</literal> (optionnel - par défaut à "
-"<literal>undefined</literal>) : Une valeur de la propriété d'identifiant qui "
+"<literal>undefined</literal>) : une valeur de la propriété d'identifiant qui "
 "indique que l'instance est nouvellement instanciée (non sauvegardée), et qui "
 "la distingue des instances détachées qui ont été sauvegardées ou chargées "
-"dans une session précédente (<literal>undefined</literal> indique que la "
-"valeur de l'atribut identifiant devrait être utilisé)."
+"dans une session précédente. <literal>Undefined</literal> indique que la "
+"valeur de la propritété identifiant devrait être utilisée."
 
 #. Tag: para
-#: basic_mapping.xml:1193
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2485,29 +1905,27 @@
 "database. See the discussion of <link linkend=\"mapping-generated"
 "\">generated properties</link> for more information."
 msgstr ""
-"<literal>generated</literal> (optional - défaut à <literal>never</"
-"literal>) : Indique que la valeur de la propriété version est générée par la "
-"base de données cf. <xref linkend=\"mapping-generated\">generated "
-"properties</xref>."
+"<literal>generated</literal> (optionnel - défaut à <literal>never</"
+"literal>) : spécifie que cette valeur de la propriété version est en réalité "
+"générée par la base de données. Consultez la discussion <xref linkend="
+"\"mapping-generated\"/> pour obtenir des informations supplémentaires."
 
 #. Tag: para
-#: basic_mapping.xml:1200
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>insert</literal> (optional - defaults to <literal>true</literal>): "
 "specifies whether the version column should be included in SQL insert "
 "statements. It can be set to <literal>false</literal> if the database column "
 "is defined with a default value of <literal>0</literal>."
 msgstr ""
-"<literal>insert</literal> (optionnel - défaut à <literal>true</literal>) : "
-"Indique si la colonne de version doit être incluse dans les ordres insert. "
-"Peut être à <literal>false</literal> si et seulement si la colonne de la "
-"base de données est définie avec une valeur par défaut à <literal>0</"
-"literal>."
+"<literal>insert</literal> (optionnel - par défaut à <literal>true</"
+"literal>) : indique si la colonne de version doit être incluse dans les "
+"ordres SQL insert. Peut être configuré à <literal>false</literal> si et "
+"seulement si la colonne de la base de données est définie avec une valeur "
+"par défaut égale à <literal>0</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:1210
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Version numbers can be of Hibernate type <literal>long</literal>, "
 "<literal>integer</literal>, <literal>short</literal>, <literal>timestamp</"
@@ -2515,11 +1933,10 @@
 msgstr ""
 "Les numéros de version doivent avoir les types Hibernate <literal>long</"
 "literal>, <literal>integer</literal>, <literal>short</literal>, "
-"<literal>timestamp</literal> ou <literal>calendar</literal>."
+"<literal>timestamp</literal> ou <literal>calendar</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:1215
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A version or timestamp property should never be null for a detached "
 "instance. Hibernate will detect any instance with a null version or "
@@ -2534,19 +1951,17 @@
 "version ou un timestamp null comme transient, quelles que soient les "
 "stratégies <literal>unsaved-value</literal> spécifiées. <emphasis>Déclarer "
 "un numéro de version ou un timestamp \"nullable\" est un moyen pratique "
-"d'éviter tout problème avec les réattachements transitifs dans Hibernate, "
+"d'éviter tout problème avec les ré-attachements transitifs dans Hibernate, "
 "particulièrement utile pour ceux qui utilisent des identifiants assignés ou "
-"des clefs composées !</emphasis>"
+"des clés composées </emphasis>."
 
 #. Tag: title
-#: basic_mapping.xml:1226
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Timestamp (optional)"
-msgstr "timestamp (optionnel)"
+msgstr "Timestamp (optionnel) "
 
 #. Tag: para
-#: basic_mapping.xml:1228
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The optional <literal>&lt;timestamp&gt;</literal> element indicates that the "
 "table contains timestamped data. This provides an alternative to versioning. "
@@ -2554,51 +1969,33 @@
 "sometimes the application might use the timestamps in other ways."
 msgstr ""
 "L'élément optionnel <literal>&lt;timestamp&gt;</literal> indique que la "
-"table contient des données horodatées (timestamp). Cela sert d'alternative à "
-"l'utilisation de numéros de version. Les timestamps (ou horodatage) sont par "
-"nature une implémentation moins fiable pour l'optimistic locking. Cependant, "
-"l'application peut parfois utiliser l'horodatage à d'autres fins."
+"table contient des données horodatées (timestamped). Cela sert d'alternative "
+"à l'utilisation de numéros de version. Les timestamps (ou horodatage) sont "
+"par nature une implémentation moins fiable pour le verrouillage optimiste. "
+"Cependant, l'application peut parfois utiliser l'horodatage à d'autres fins. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1244
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<timestamp\n"
-"        column=\"timestamp_column\"\n"
-"        name=\"propertyName\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unsaved-value=\"null|undefined\"\n"
-"        source=\"vm|db\"\n"
-"        generated=\"never|always\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1247
-#, fuzzy, no-c-format
-msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of a column holding the timestamp."
 msgstr ""
-"<literal>column</literal> (optionnel - par défaut à le nom de la "
-"propriété) : Le nom d'une colonne contenant le timestamp."
+"<literal>column</literal> (optionnel - par défaut devient le nom de la "
+"propriété) : le nom d'une colonne contenant le timestamp. "
 
 #. Tag: para
-#: basic_mapping.xml:1253
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal>: the name of a JavaBeans style property of Java type "
 "<literal>Date</literal> or <literal>Timestamp</literal> of the persistent "
 "class."
 msgstr ""
-"<literal>name</literal> : Le nom d'une propriété au sens JavaBean de type "
-"<literal>Date</literal> ou <literal>Timestamp</literal> de la classe "
-"persistante."
+"<literal>name</literal> : le nom d'une propriété au sens JavaBean de type "
+"Java <literal>Date</literal> ou <literal>Timestamp</literal> de la classe "
+"persistante. "
 
 #. Tag: para
-#: basic_mapping.xml:1266
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to <literal>null</"
 "literal>): a version property value that indicates that an instance is newly "
@@ -2607,15 +2004,14 @@
 "specifies that the identifier property value should be used."
 msgstr ""
 "<literal>unsaved-value</literal> (optionnel - par défaut à <literal>null</"
-"literal>) : Propriété dont la valeur est un numéro de version qui indique "
+"literal>) : propriété dont la valeur est un numéro de version qui indique "
 "que l'instance est nouvellement instanciée (non sauvegardée), et qui la "
 "distingue des instances détachées qui ont été sauvegardées ou chargées dans "
-"une session précédente (<literal>undefined</literal> indique que la valeur "
-"de l'attribut identifiant devrait être utilisée)."
+"une session précédente. (<literal>undefined</literal> indique que la valeur "
+"de propriété identifiant devrait être utilisée). "
 
 #. Tag: para
-#: basic_mapping.xml:1275
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>source</literal> (optional - defaults to <literal>vm</literal>): "
 "Where should Hibernate retrieve the timestamp value from? From the database, "
@@ -2627,16 +2023,16 @@
 "precision (Oracle 8, for example)."
 msgstr ""
 "<literal>source</literal> (optionnel - par défaut à <literal>vm</literal>) : "
-"D'où Hibernate doit-il récupérer la valeur du timestamp? Depuis la base de "
+"d'où Hibernate doit-il récupérer la valeur du timestamp? Depuis la base de "
 "données ou depuis la JVM d'exécution? Les valeurs de timestamp de la base de "
 "données provoquent une surcharge puisque Hibernate doit interroger la base "
 "pour déterminer la prochaine valeur mais cela est plus sûr lorsque vous "
-"fonctionnez dans un cluster. Remarquez aussi que certains des dialectes ne "
-"supportent pas cette fonction, et que d'autres l'implémentent mal, "
-"provoquant des erreurs de précision (Oracle 8 par exemple)."
+"fonctionnez dans un cluster. Remarquez aussi que certains des "
+"<literal>Dialect</literal> s ne supportent pas cette fonction, et que "
+"d'autres l'implémentent mal, à cause d'un manque de précision (Oracle 8 par "
+"exemple)."
 
 #. Tag: para
-#: basic_mapping.xml:1287
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2644,19 +2040,18 @@
 "generated by the database. See the discussion of <link linkend=\"mapping-"
 "generated\">generated properties</link> for more information."
 msgstr ""
-"<literal>generated</literal> (optional - défaut à <literal>never</"
-"literal>) : Indique que la valeur de ce timestamp est générée par la base de "
-"données cf. <xref linkend=\"mapping-generated\">generated properties</xref>."
+"<literal>generated</literal> (optionnel - par défaut à <literal>never</"
+"literal>) : indique que la valeur de ce timestamp est générée par la base de "
+"données des propriétés générées. Voir la discussion sur <xref linkend="
+"\"mapping-generated\"/> pour obtenir des informations supplémentaires. "
 
 #. Tag: title
-#: basic_mapping.xml:1298 basic_mapping.xml:2890
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Note"
 
 #. Tag: para
-#: basic_mapping.xml:1299
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>&lt;Timestamp&gt;</literal> is equivalent to <literal>&lt;version "
 "type=\"timestamp\"&gt;</literal>. And <literal>&lt;timestamp source=\"db"
@@ -2664,63 +2059,35 @@
 "\"&gt;</literal>"
 msgstr ""
 "Notez que <literal>&lt;timestamp&gt;</literal> est équivalent à <literal>&lt;"
-"version type=\"timestamp\"&gt;</literal>."
+"version type=\"timestamp\"&gt;</literal> et <literal>&lt;timestamp source="
+"\"db\"&gt;</literal> équivaut à <literal>&lt;version type=\"dbtimestamp\"&gt;"
+"</literal>"
 
 #. Tag: title
-#: basic_mapping.xml:1311
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Property"
-msgstr "property"
+msgstr "Property"
 
 #. Tag: para
-#: basic_mapping.xml:1313
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;property&gt;</literal> element declares a persistent "
 "JavaBean style property of the class."
 msgstr ""
-"L'élément <literal>&lt;property&gt;</literal> déclare une propriété de la "
-"classe au sens JavaBean."
+"L'élément <literal>&lt;property&gt;</literal> déclare une propriété "
+"persistante de la classe au sens JavaBean."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1335
-#, no-c-format
-msgid ""
-"<![CDATA[<property\n"
-"        name=\"propertyName\"\n"
-"        column=\"column_name\"\n"
-"        type=\"typename\"\n"
-"        update=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        formula=\"arbitrary SQL expression\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        lazy=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        not-null=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        generated=\"never|insert|always\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        index=\"index_name\"\n"
-"        unique_key=\"unique_key_id\"\n"
-"        length=\"L\"\n"
-"        precision=\"P\"\n"
-"        scale=\"S\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1338
 #, no-c-format
 msgid ""
 "<literal>name</literal>: the name of the property, with an initial lowercase "
 "letter."
 msgstr ""
 "<literal>name</literal> : nom de la propriété, avec une lettre initiale en "
-"minuscule."
+"minuscule. "
 
 #. Tag: para
-#: basic_mapping.xml:1344
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of the mapped database table column. This can also be specified by "
@@ -2728,11 +2095,10 @@
 msgstr ""
 "<literal>column</literal> (optionnel - par défaut au nom de la propriété) : "
 "le nom de la colonne mappée. Cela peut aussi être indiqué dans le(s) sous-"
-"élément(s) <literal>&lt;column&gt;</literal>."
+"élément(s) <literal>&lt;column&gt;</literal> imbriqués. "
 
 #. Tag: para
-#: basic_mapping.xml:1356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update, insert</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that the mapped columns should be included in SQL "
@@ -2743,12 +2109,13 @@
 msgstr ""
 "<literal>update, insert</literal> (optionnel - par défaut à <literal>true</"
 "literal>) : indique que les colonnes mappées devraient être incluses dans "
-"des <literal>UPDATE</literal> SQL et/ou des <literal>INSERT</literal>. "
-"Mettre les deux à <literal>false</literal> empêche la propagation en base de "
-"données (utile si vous savez qu'un trigger affectera la valeur à la colonne)."
+"des déclarations SQL <literal>UPDATE</literal> et/ou des <literal>INSERT</"
+"literal>. Mettre les deux à <literal>false</literal> autorise une propriété "
+"pure dérivée dont la valeur est initialisée de quelque autre propriété qui "
+"mappe à la même colonne(s) ou par un trigger ou une autre application. "
+"(utile si vous savez qu'un trigger affectera la valeur à la colonne). "
 
 #. Tag: para
-#: basic_mapping.xml:1365
 #, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an SQL expression that defines the "
@@ -2757,45 +2124,43 @@
 msgstr ""
 "<literal>formula</literal> (optionnel) : une expression SQL qui définit la "
 "valeur pour une propriété <emphasis>calculée</emphasis>. Les propriétés "
-"calculées ne possède pas leur propre mapping."
+"calculées ne possèdent pas leur propre mappage."
 
 #. Tag: para
-#: basic_mapping.xml:1378
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>false</literal>): "
 "specifies that this property should be fetched lazily when the instance "
 "variable is first accessed. It requires build-time bytecode instrumentation."
 msgstr ""
-"<literal>lazy</literal> (optionnel - par défaut à <literal>false</literal>): "
-"Indique que cette propriété devrait être chargée en différé (lazy loading) "
-"quand on accède à la variable d'instance pour la première fois."
+"<literal>lazy</literal> (optionnel - par défaut à <literal>false</"
+"literal>) : indique que cette propriété devrait être chargée en différé "
+"(lazy loading) quand on accède à la variable d'instance pour la première "
+"fois (nécessite une instrumentation du bytecode lors de la phase de "
+"construction). "
 
 #. Tag: para
-#: basic_mapping.xml:1385
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): enables the DDL generation of a unique "
 "constraint for the columns. Also, allow this to be the target of a "
 "<literal>property-ref</literal>."
 msgstr ""
-"<literal>unique</literal> (optionnel): Génère le DDL d'une contrainte "
-"d'unicité pour les colonnes. Permet aussi d'en faire la cible d'un "
+"<literal>unique</literal> (optionnel) : génère le DDL d'une contrainte "
+"d'unicité pour les colonnes. Permet aussi d'en faire la cible d'une "
 "<literal>property-ref</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:1392
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): enables the DDL generation of a "
 "nullability constraint for the columns."
 msgstr ""
-"<literal>not-null</literal> (optionnel): Génère le DDL d'une contrainte de "
-"non nullité pour les colonnes."
+"<literal>not-null</literal> (optionnel) : génère le DDL d'une contrainte de "
+"nullité pour les colonnes."
 
 #. Tag: para
-#: basic_mapping.xml:1398 basic_mapping.xml:1581
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to this property do or do not require "
@@ -2803,13 +2168,12 @@
 "version increment should occur when this property is dirty."
 msgstr ""
 "<literal>optimistic-lock</literal> (optionnel - par défaut à <literal>true</"
-"literal>): Indique que les mises à jour de cette propriété peuvent ou non "
-"nécessiter l'acquisition d'un verrou optimiste. En d'autres termes, cela "
-"détermine s'il est nécessaire d'incrémenter un numéro de version quand cette "
-"propriété est marquée obsolète (dirty)."
+"literal>) : indique si les mise à jour de cette propriété nécessitent ou non "
+"l'acquisition d'un verrou optimiste. En d'autres termes, cela détermine s'il "
+"est nécessaire d'incrémenter un numéro de version quand cette propriété est "
+"marquée obsolète (dirty)."
 
 #. Tag: para
-#: basic_mapping.xml:1406
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2817,57 +2181,53 @@
 "database. See the discussion of <link linkend=\"mapping-generated"
 "\">generated properties</link> for more information."
 msgstr ""
-"<literal>generated</literal> (optional - défaut à<literal>never</literal>): "
-"Indique que la valeur de ce timestamp est générée par la base de données cf. "
-"<xref linkend=\"mapping-generated\">generated properties</xref>."
+"<literal>generated</literal> (optionnel - par défaut à <literal>never</"
+"literal>) : indique que la valeur de ce timestamp est générée par la base de "
+"données des propriétés générées. Voir la discussion sur <xref linkend="
+"\"mapping-generated\"/> pour plus d'informations. "
 
 #. Tag: para
-#: basic_mapping.xml:1415
 #, no-c-format
 msgid "<emphasis>typename</emphasis> could be:"
-msgstr "<emphasis>typename</emphasis> peut être:"
+msgstr "<emphasis>typename</emphasis> peut être :"
 
 #. Tag: para
-#: basic_mapping.xml:1421
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The name of a Hibernate basic type: <literal>integer, string, character, "
 "date, timestamp, float, binary, serializable, object, blob</literal> etc."
 msgstr ""
-"Nom d'un type basique Hibernate (ex: <literal>integer, string, character, "
-"date, timestamp, float, binary, serializable, object, blob</literal>)."
+"Le nom d'un type basique Hibernate (par ex : <literal>integer, string, "
+"character, date, timestamp, float, binary, serializable, object, blob</"
+"literal> etc.). "
 
 #. Tag: para
-#: basic_mapping.xml:1427
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The name of a Java class with a default basic type: <literal>int, float, "
 "char, java.lang.String, java.util.Date, java.lang.Integer, java.sql.Clob</"
 "literal> etc."
 msgstr ""
-"Nom d'une classe Java avec un type basique par défaut (ex: <literal>int, "
-"float, char, java.lang.String, java.util.Date, java.lang.Integer, java.sql."
-"Clob</literal>)."
+"le nom d'une classe Java avec un type basique par défaut (par ex : "
+"<literal>int, float, char, java.lang.String, java.util.Date, java.lang."
+"Integer, java.sql.Clob</literal> etc.). "
 
 #. Tag: para
-#: basic_mapping.xml:1433
 #, no-c-format
 msgid "The name of a serializable Java class."
-msgstr "Nom d'une classe Java sérialisable."
+msgstr "Le nom d'une classe Java sérialisable."
 
 #. Tag: para
-#: basic_mapping.xml:1438
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The class name of a custom type: <literal>com.illflow.type.MyCustomType</"
 "literal> etc."
 msgstr ""
-"Nom d'une classe ayant un type spécifique (ex: <literal>com.illflow.type."
-"MyCustomType</literal>)."
+"Le nom d'une classe avec un type personnalisé (par ex : <literal>com.illflow."
+"type.MyCustomType</literal>)."
 
 #. Tag: para
-#: basic_mapping.xml:1444
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you do not specify a type, Hibernate will use reflection upon the named "
 "property and guess the correct Hibernate type. Hibernate will attempt to "
@@ -2877,18 +2237,17 @@
 "DATE</literal> and <literal>Hibernate.TIMESTAMP</literal>, or to specify a "
 "custom type."
 msgstr ""
-"Si vous n'indiquez pas un type, Hibernate utlisera la réflexion sur le nom "
+"Si vous n'indiquez pas un type, Hibernate utilisera la réflexion sur le nom "
 "de la propriété pour tenter de trouver le type Hibernate correct. Hibernate "
 "essayera d'interprêter le nom de la classe retournée par le getter de la "
-"propriété en utilisant les régles 2, 3, 4 dans cet ordre. Cependant, ce "
-"n'est pas toujours suffisant. Dans certains cas vous aurez encore besoin de "
-"l'attribut <literal>type</literal> (Par exemple, pour distinguer "
-"<literal>Hibernate.DATE</literal> et <literal>Hibernate.TIMESTAMP</literal>, "
-"ou pour préciser un type spécifique)."
+"propriété en utilisant les règles 2, 3, 4 dans cet ordre. Dans certains cas "
+"vous aurez encore besoin de l'attribut <literal>type</literal>. (Par "
+"exemple, pour distinguer <literal>Hibernate.DATE</literal> et "
+"<literal>Hibernate.TIMESTAMP</literal>, ou pour préciser un type "
+"personnalisé)."
 
 #. Tag: para
-#: basic_mapping.xml:1454
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>access</literal> attribute allows you to control how Hibernate "
 "accesses the property at runtime. By default, Hibernate will call the "
@@ -2899,45 +2258,31 @@
 "PropertyAccessor</literal>."
 msgstr ""
 "L'attribut <literal>access</literal> permet de contrôler comment Hibernate "
-"accèdera à la propriété à l'exécution. Par défaut, Hibernate utilisera les "
+"accédera à la propriété à l'exécution. Par défaut, Hibernate utilisera les "
 "méthodes set/get. Si vous indiquez <literal>access=\"field\"</literal>, "
-"Hibernate ignorera les getter/setter et accèdera à la propriété directement "
+"Hibernate ignorera les getter/setter et accédera à la propriété directement "
 "en utilisant la réflexion. Vous pouvez spécifier votre propre stratégie "
-"d'accès aux propriété en donnant une classe qui implémente l'interface "
-"<literal>org.hibernate.property.PropertyAccessor</literal>."
+"d'accès aux propriétés en nommant une classe qui implémente l'interface "
+"<literal>org.hibernate.propertexige une instrumentation de code d'octets "
+"build-timey.PropertyAccessor</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:1463
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A powerful feature is derived properties. These properties are by definition "
 "read-only. The property value is computed at load time. You declare the "
 "computation as an SQL expression. This then translates to a <literal>SELECT</"
 "literal> clause subquery in the SQL query that loads an instance:"
 msgstr ""
-"Une fonctionnalité particulièrement intéressante est les propriétés "
-"dérivées. Ces propriétés sont par définition en lecture seule, la valeur de "
-"la propriété est calculée au chargement. Le calcul est déclaré comme une "
+"Les propriétés dérivées représentent une fonctionnalité particulièrement "
+"intéressante. Ces propriétés sont par définition en lecture seule, la valeur "
+"de la propriété est calculée au chargement. Le calcul est déclaré comme une "
 "expression SQL, qui se traduit par une sous-requête <literal>SELECT</"
-"literal> dans la requête SQL qui charge une instance :"
+"literal> dans la requête SQL qui charge une instance : "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1470
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"<property name=\"totalPrice\"\n"
-"    formula=\"( SELECT SUM (li.quantity*p.price) FROM LineItem li, Product "
-"p\n"
-"                WHERE li.productId = p.productId\n"
-"                AND li.customerId = customerId\n"
-"                AND li.orderNumber = orderNumber )\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1472
-#, fuzzy, no-c-format
-msgid ""
 "You can reference the entity table by not declaring an alias on a particular "
 "column. This would be <literal>customerId</literal> in the given example. "
 "You can also use the nested <literal>&lt;formula&gt;</literal> mapping "
@@ -2946,18 +2291,16 @@
 "Remarquez que vous pouvez référencer la propre table des entités en ne "
 "déclarant pas un alias sur une colonne particulière (<literal>customerId</"
 "literal> dans l'exemple donné). Notez aussi que vous pouvez utiliser le sous-"
-"élément de mapping <literal>&lt;formula&gt;</literal> plutôt que d'utiliser "
-"l'attribut si vous le souhaitez."
+"élément de mappage <literal>&lt;formula&gt;</literal> plutôt que d'utiliser "
+"l'attribut si vous le souhaitez. "
 
 #. Tag: title
-#: basic_mapping.xml:1482
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Many-to-one"
-msgstr "many-to-one"
+msgstr "Plusieurs-à-un"
 
 #. Tag: para
-#: basic_mapping.xml:1484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An ordinary association to another persistent class is declared using a "
 "<literal>many-to-one</literal> element. The relational model is a many-to-"
@@ -2966,116 +2309,55 @@
 msgstr ""
 "Une association ordinaire vers une autre classe persistante est déclarée en "
 "utilisant un élément <literal>many-to-one</literal>. Le modèle relationnel "
-"est une association de type many-to-one : une clef étrangère dans une table "
-"référence la ou les clef(s) primaire(s) dans la table cible."
+"est une association de type plusieurs-à-un : une clé étrangère dans une "
+"table référence la ou les clé(s) primaire(s) dans la table cible. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1512
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one\n"
-"        name=\"propertyName\"\n"
-"        column=\"column_name\"\n"
-"        class=\"ClassName\"\n"
-"        cascade=\"cascade_style\"\n"
-"        fetch=\"join|select\"\n"
-"        update=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unique=\"true|false\"\n"
-"        not-null=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        lazy=\"proxy|no-proxy|false\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        formula=\"arbitrary SQL expression\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        embed-xml=\"true|false\"\n"
-"        index=\"index_name\"\n"
-"        unique_key=\"unique_key_id\"\n"
-"        foreign-key=\"foreign_key_name\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1515 basic_mapping.xml:1696 basic_mapping.xml:1882
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>name</literal>: the name of the property."
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>name</literal> : Nom de la propriété.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>class</literal> (optionnel - par défaut du type de la propriété "
-"déterminé par réflexion) : Le nom de la classe associée.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>class</literal> (optionnel - par défaut au type de la propriété "
-"déterminé par réflexion) : le nom de la classe (fille) du composant."
+msgstr "<literal>name</literal> : le nom de la propriété. "
 
 #. Tag: para
-#: basic_mapping.xml:1520 basic_mapping.xml:2311
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>column</literal> (optional): the name of the foreign key column. "
 "This can also be specified by nested <literal>&lt;column&gt;</literal> "
 "element(s)."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>column</literal> (optionnel) : Le nom de la clef étrangère. Cela "
-"peut être aussi indiqué avec le sous-élément <literal>&lt;column&gt;</"
-"literal>.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>column</literal> (optionnel) : Le nom de la colonne de la clef "
-"étrangère Cela peut aussi être spécifié par l'élément(s) intégré(s) "
-"<literal>&lt;column&gt;</literal>."
+"<literal>column</literal> (optionnel) : le nom de la colonne de la clé "
+"étrangère. Cela peut être aussi spécifié par un ou des sous-élément(s) "
+"<literal>&lt;column&gt;</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:1527 basic_mapping.xml:1701
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
 "determined by reflection): the name of the associated class."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>class</literal> (optionnel - par défaut le type de la propriété "
-"déterminé par réflexion) : Le nom de la classe associée.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>cascade</literal> (optionnel) : Indique quelles opérations doivent "
-"être cascadées de l'objet père vers l'objet associé."
+"<literal>class</literal> (optionnel - par défaut, le type de la propriété "
+"déterminé par réflexion) : le nom de la classe associée. "
 
 #. Tag: para
-#: basic_mapping.xml:1533 basic_mapping.xml:1707
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional): specifies which operations should be "
 "cascaded from the parent object to the associated object."
 msgstr ""
-"<literal>constrained</literal> (optionnel) : Indique qu'une contrainte de "
-"clef étrangère sur la clef primaire de la table mappée référence la table de "
-"la classe associée. Cette option affecte l'ordre dans lequel chaque "
-"<literal>save()</literal> et chaque <literal>delete()</literal> sont "
-"cascadés et détermine si l'association peut utiliser un proxy (aussi utilisé "
-"par l'outil d'export de schéma)."
+"<literal>cascade</literal> (optionnel) : indique quelles opérations doivent "
+"être cascadées de l'objet parent vers l'objet associé. "
 
 #. Tag: para
-#: basic_mapping.xml:1539 basic_mapping.xml:1722
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional - defaults to <literal>select</literal>): "
 "chooses between outer-join fetching or sequential select fetching."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>fetch</literal> (optionnel - par défaut à <literal>select</"
-"literal>) : Choisit entre le chargement de type outer-join ou le chargement "
-"par select successifs.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>property-ref</literal> (optionnel) : Le nom de la propriété de la "
-"classe associée qui est jointe à la clef primaire de cette classe. Si ce "
-"n'est pas spécifié, la clef primaire de la classe associée est utilisée."
+"literal>) : choisit entre le chargement de type jointure externe (outer-"
+"join) ou le chargement par select successifs."
 
 #. Tag: para
-#: basic_mapping.xml:1545
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update, insert</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that the mapped columns should be included in SQL "
@@ -3086,49 +2368,47 @@
 msgstr ""
 "<literal>update, insert</literal> (optionnel - par défaut à <literal>true</"
 "literal>) : indique que les colonnes mappées devraient être incluses dans "
-"des <literal>UPDATE</literal> SQL et/ou des <literal>INSERT</literal>. "
-"Mettre les deux à <literal>false</literal> empêche la propagation en base de "
-"données (utile si vous savez qu'un trigger affectera la valeur à la colonne)."
+"des SQL <literal>UPDATE</literal> et/ou des déclarations <literal>INSERT</"
+"literal>. Mettre les deux à <literal>false</literal>, permet une association "
+"pure dérivée dont la valeur est initialisée à partir d'une autre propriété "
+"qui mappe à une ou plusieurs mêmes colonnes, ou par un trigger  ou une autre "
+"application. "
 
 #. Tag: para
-#: basic_mapping.xml:1554
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): the name of a property of the "
 "associated class that is joined to this foreign key. If not specified, the "
 "primary key of the associated class is used."
 msgstr ""
-"<literal>property-ref</literal> : (optionnel) Le nom d'une propriété de la "
-"classe associée qui est liée à cette clef étrangère. Si ce n'est pas "
-"spécifié, la clef primaire de la classe associée est utilisée."
+"<literal>property-ref</literal> (optionnel) : le nom d'une propriété de la "
+"classe associée qui est jointe à cette clé étrangère. Si non-spécifiée, la "
+"clé primaire de la classe associée est utilisée. "
 
 #. Tag: para
-#: basic_mapping.xml:1567
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): enables the DDL generation of a unique "
 "constraint for the foreign-key column. By allowing this to be the target of "
 "a <literal>property-ref</literal>, you can make the association multiplicity "
 "one-to-one."
 msgstr ""
-"<literal>unique</literal> (optionnel) : Génère le DDL d'une contrainte "
-"d'unicité pour la clef étrangère. Permet aussi d'en faire la cible d'un "
+"<literal>unique</literal> (optionnel) : génère le DDL d'une contrainte "
+"unique pour la clé étrangère. Permet aussi d'en faire la cible d'une "
 "<literal>property-ref</literal>. Cela permet de créer une véritable "
-"association one-to-one."
+"association un-à-un. "
 
 #. Tag: para
-#: basic_mapping.xml:1575
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): enables the DDL generation of a "
 "nullability constraint for the foreign key columns."
 msgstr ""
-"<literal>not-null</literal> (optionnel) : Génère le DDL pour une contrainte "
-"de non nullité pour la clef étrangère."
+"<literal>not-null</literal> (optionnel) : active le DDL d'une contrainte de "
+"nullité pour les colonnes de clés étrangères."
 
 #. Tag: para
-#: basic_mapping.xml:1589
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>proxy</literal>): "
 "by default, single point associations are proxied. <literal>lazy=\"no-proxy"
@@ -3137,55 +2417,47 @@
 "instrumentation. <literal>lazy=\"false\"</literal> specifies that the "
 "association will always be eagerly fetched."
 msgstr ""
-"<literal>lazy</literal> (optionnel - par défaut à <literal>false</"
-"literal>) : Indique que cette propriété doit être chargée en différé (lazy "
-"loading) au premier accès à la variable d'instance (nécessite une "
-"instrumentation du bytecode lors de la phase de construction). Remarquez que "
-"cela n'influence pas le comportement du proxy Hibernate - comme l'attribut "
-"<literal>lazy</literal> sur des classes ou des mappings de collections, mais "
-"utilise l'interception pour le chargement différé. <literal>lazy=\"false\"</"
-"literal> indique que l'association sera toujours chargée."
+"<literal>lazy</literal> (optionnel - par défaut à <literal>proxy</"
+"literal>) : par défaut, les associations de point uniques utilisent des "
+"proxies. <literal>lazy=\"no-proxy\"</literal> indique que cette propriété "
+"doit être chargée en différé au premier accès à la variable d'instance "
+"(nécessite une instrumentation du bytecode lors de la phase de "
+"construction). <literal>lazy=\"false\"</literal> indique que l'association "
+"sera toujours chargée."
 
 #. Tag: para
-#: basic_mapping.xml:1599
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-found</literal> (optional - defaults to <literal>exception</"
 "literal>): specifies how foreign keys that reference missing rows will be "
 "handled. <literal>ignore</literal> will treat a missing row as a null "
 "association."
 msgstr ""
-"<literal>not-found</literal> (optionnel - par défaut à <literal>exception</"
-"literal>) : Indique comment les clefs étrangères qui référencent des lignes "
-"manquantes doivent être manipulées : <literal>ignore</literal> traitera une "
-"ligne manquante comme une association nulle."
+"<literal>not-found</literal> (optionnel - par défaut = <literal>exception</"
+"literal>) : spécifie comment les clés étrangères qui référencent des lignes "
+"manquantes seront gérées : <literal>ignore</literal> traitera une ligne "
+"manquante comme une association nulle. "
 
 #. Tag: para
-#: basic_mapping.xml:1606 basic_mapping.xml:1760
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>entity-name</literal> (optional): the entity name of the associated "
 "class."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>entity-name</literal> (optionnel) : Le nom de l'entité de la classe "
-"associée.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Il existe deux types d'associations one-to-one :"
+"<literal>entity-name</literal> (optionnel) : le nom de l'entité de la classe "
+"associée. "
 
 #. Tag: para
-#: basic_mapping.xml:1611
 #, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an SQL expression that defines the "
 "value for a <emphasis>computed</emphasis> foreign key."
 msgstr ""
 "<literal>formula</literal> (optionnel) : une expression SQL qui définit la "
-"valeur pour une clé étrangère calculée."
+"valeur pour une clé étrangère calculée. "
 
 #. Tag: para
-#: basic_mapping.xml:1619
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Setting a value of the <literal>cascade</literal> attribute to any "
 "meaningful value other than <literal>none</literal> will propagate certain "
@@ -3195,42 +2467,34 @@
 "second, special values: <literal>delete-orphan</literal>; and third,"
 "<literal>all</literal> comma-separated combinations of operation names: "
 "<literal>cascade=\"persist,merge,evict\"</literal> or <literal>cascade=\"all,"
-"delete-orphan\"</literal>. See <xref linkend=\"objectstate-transitive\"/> "
+"delete-orphan\"</literal>. See <xref linkend=\"objectstate-transitive\" /> "
 "for a full explanation. Note that single valued, many-to-one and one-to-one, "
 "associations do not support orphan delete."
 msgstr ""
 "Donner une valeur significative à l'attribut <literal>cascade</literal> "
 "autre que <literal>none</literal> propagera certaines opérations à l'objet "
-"associé. Les valeurs significatives sont les noms des opérations Hibernate "
-"basiques, <literal>persist, merge, delete, save-update, evict, replicate, "
-"lock, refresh</literal>, ainsi que les valeurs spéciales <literal>delete-"
-"orphan</literal> et <literal>all</literal> et des combinaisons de noms "
+"associé. Les valeurs significatives sont les noms des opérations et sont "
+"divisées en trois catégories. Tout d'abord, les valeurs Hibernate basiques, "
+"<literal>persist, merge, delete, save-update, evict, replicate, lock, "
+"refresh</literal>, puis les valeurs spéciales <literal>delete-orphan</"
+"literal> et <literal>all</literal> et enfin, des combinaisons de noms "
 "d'opérations séparées par des virgules, comme par exemple <literal>cascade="
 "\"persist,merge,evict\"</literal> ou <literal>cascade=\"all,delete-orphan\"</"
-"literal>. Voir <xref linkend=\"objectstate-transitive\"/> pour une "
-"explication complète. Notez que les assocations many-to-one et one-to-one ne "
-"supportent pas orphan delete."
+"literal>. Consultez la <xref linkend=\"objectstate-transitive\" /> pour une "
+"explication complète. Notez que des associations valuées uniques "
+"(associations plusieurs-à-un et un-à-un) ne supportent pas orphan delete. "
 
 #. Tag: para
-#: basic_mapping.xml:1632
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Here is an example of a typical <literal>many-to-one</literal> declaration:"
 msgstr ""
-"Une déclaration <literal>many-to-one</literal> typique est aussi simple que :"
+"Une déclaration <literal>many-to-one</literal> typique est aussi simple "
+"que : "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1636
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"product\" class=\"Product\" column=\"PRODUCT_ID"
-"\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1638
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>property-ref</literal> attribute should only be used for "
 "mapping legacy data where a foreign key refers to a unique key of the "
 "associated table other than the primary key. This is a complicated and "
@@ -3240,109 +2504,59 @@
 "the SchemaExport tool."
 msgstr ""
 "L'attribut <literal>property-ref</literal> devrait être utilisé pour mapper "
-"seulement des données provenant d'un ancien système où les clefs étrangères "
-"font référence à une clef unique de la table associée et qui n'est pas la "
-"clef primaire. C'est un cas de mauvaise conception relationnelle. Par "
-"exemple, supposez que la classe <literal>Product</literal> a un numéro de "
-"série unique qui n'est pas la clef primaire. (L'attribut <literal>unique</"
-"literal> contrôle la génération DDL par Hibernate avec l'outil SchemaExport.)"
+"seulement des données provenant d'un ancien système où les clés étrangères "
+"font référence à une clé unique de la table associée et qui n'est pas la clé "
+"primaire. C'est un cas de mauvaise conception relationnelle. Par exemple, "
+"supposez que la classe <literal>Product</literal> ait un numéro de série "
+"unique qui n'est pas la clé primaire. L'attribut <literal>unique</literal> "
+"contrôle la génération DDL par Hibernate avec l'outil SchemaExport."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1647
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"serialNumber\" unique=\"true\" type=\"string\" "
-"column=\"SERIAL_NUMBER\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1649
 #, no-c-format
 msgid "Then the mapping for <literal>OrderItem</literal> might use:"
-msgstr "Ainsi le mapping pour <literal>OrderItem</literal> peut utiliser :"
+msgstr "Ainsi le mappage pour <literal>OrderItem</literal> peut utiliser :"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1653
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"product\" property-ref=\"serialNumber\" column="
-"\"PRODUCT_SERIAL_NUMBER\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1655
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This is not encouraged, however."
-msgstr "bien que ce ne soit certainement pas encouragé."
+msgstr "Bien que ce ne soit certainement pas encouragé."
 
 #. Tag: para
-#: basic_mapping.xml:1659
 #, no-c-format
 msgid ""
 "If the referenced unique key comprises multiple properties of the associated "
 "entity, you should map the referenced properties inside a named <literal>&lt;"
 "properties&gt;</literal> element."
 msgstr ""
-"Si la clef unique référencée comprend des propriétés multiples de l'entité "
-"associée, vous devez mapper ces propriétés à l'intérieur d'un élément "
-"<literal>&lt;properties&gt;</literal>."
+"Si la clé unique référencée comprend des propriétés multiples de l'entité "
+"associée, vous devez mapper ces propriétés à l'intérieur d'un élément nommé "
+"<literal>&lt;properties&gt;</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:1664
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the referenced unique key is the property of a component, you can specify "
 "a property path:"
-msgstr "one-to-one"
-
-#. Tag: programlisting
-#: basic_mapping.xml:1668
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"owner\" property-ref=\"identity.ssn\" column="
-"\"OWNER_SSN\"/>]]>"
 msgstr ""
+"Si la clé unique référencée est la propriété d'un composant, vous pouvez "
+"spécifier le chemin de propriété :"
 
 #. Tag: title
-#: basic_mapping.xml:1673
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "One-to-one"
-msgstr ""
-"Une association one-to-one vers une autre classe persistante est déclarée "
-"avec l'élément <literal>one-to-one</literal>."
+msgstr "Un-à-un"
 
 #. Tag: para
-#: basic_mapping.xml:1675
 #, no-c-format
 msgid ""
 "A one-to-one association to another persistent class is declared using a "
 "<literal>one-to-one</literal> element."
-msgstr "<literal>name</literal> : Le nom de la propriété."
-
-#. Tag: programlisting
-#: basic_mapping.xml:1693
-#, no-c-format
-msgid ""
-"<![CDATA[<one-to-one\n"
-"        name=\"propertyName\"\n"
-"        class=\"ClassName\"\n"
-"        cascade=\"cascade_style\"\n"
-"        constrained=\"true|false\"\n"
-"        fetch=\"join|select\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        formula=\"any SQL expression\"\n"
-"        lazy=\"proxy|no-proxy|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        embed-xml=\"true|false\"\n"
-"        foreign-key=\"foreign_key_name\"\n"
-"/>]]>"
 msgstr ""
+"Une association un-à-un vers une autre classe persistante est déclarée avec "
+"l'élément <literal>one-to-one</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:1713
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>constrained</literal> (optional): specifies that a foreign key "
 "constraint on the primary key of the mapped table and references the table "
@@ -3351,25 +2565,26 @@
 "whether the association can be proxied. It is also used by the schema export "
 "tool."
 msgstr ""
-"<literal>fetch</literal> (optionnel - par défaut à <literal>select</"
-"literal>) : Choisit entre récupération par jointure externe ou select "
-"séquentiel."
+"<literal>constrained</literal> (optionnel) : indique qu'une contrainte de "
+"clé étrangère sur la clé primaire de la table mappée référence la table de "
+"la classe associée. Cette option affecte l'ordre dans lequel chaque "
+"<literal>save()</literal> et chaque <literal>delete()</literal> est cascadé "
+"et détermine si l'association peut utiliser un proxy (aussi utilisé par "
+"l'outil SchemaExport). "
 
 #. Tag: para
-#: basic_mapping.xml:1728
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): the name of a property of the "
 "associated class that is joined to the primary key of this class. If not "
 "specified, the primary key of the associated class is used."
 msgstr ""
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>) : La stratégie à utiliser par Hibernate pour accéder à la valeur "
-"de la propriété."
+"<literal>property-ref</literal> (optionnel) : le nom de la propriété de la "
+"classe associée qui est jointe à la clé primaire de cette classe. Si ce "
+"n'est pas spécifié, la clé primaire de la classe associée est utilisée. "
 
 #. Tag: para
-#: basic_mapping.xml:1741
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): almost all one-to-one associations "
 "map to the primary key of the owning entity. If this is not the case, you "
@@ -3377,18 +2592,14 @@
 "formula. See <literal>org.hibernate.test.onetooneformula</literal> for an "
 "example."
 msgstr ""
-"<literal>lazy</literal> (optionnel - par défaut <literal>proxy</literal>) : "
-"Par défaut, les associations simples sont soumise à proxy. <literal>lazy="
-"\"no-proxy\"</literal> spécifie que la propriété doit être chargée à la "
-"demande au premier accès à l'instance. (nécessite l'intrumentation du "
-"bytecode à la construction). <literal>lazy=\"false\"</literal> indique que "
-"l'association sera toujours chargée agressivement. <emphasis>Notez que si "
-"<literal>constrained=\"false\"</literal>, l'utilisation de proxy est "
-"impossible et Hibernate chargera automatiquement l'association !</emphasis>"
+"<literal>formula</literal> (optionnel) : presque toutes les associations un-"
+"à-un pointent sur la clé primaire de l'entité propriétaire. Dans les rares "
+"cas différents, vous devez donner une ou plusieurs autres colonnes ou "
+"expression à joindre par une formule SQL . Voir <literal>org.hibernate.test."
+"onetooneformula</literal> pour un exemple."
 
 #. Tag: para
-#: basic_mapping.xml:1749
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>proxy</literal>): "
 "by default, single point associations are proxied. <literal>lazy=\"no-proxy"
@@ -3399,177 +2610,106 @@
 "<literal>constrained=\"false\"</literal>, proxying is impossible and "
 "Hibernate will eagerly fetch the association</emphasis>."
 msgstr ""
-"<literal>entity-name</literal> (optional) : The entity name of the "
-"associated class."
+"<literal>lazy</literal> (optionnel - par défaut <literal>proxy</literal>) : "
+"par défaut, les associations simples sont soumises à proxy. <literal>lazy="
+"\"no-proxy\"</literal> spécifie que la propriété doit être chargée en "
+"différé au premier accès à l'instance. (nécessite l'instrumentation du "
+"bytecode à la construction). <literal>lazy=\"false\"</literal> indique que "
+"l'association sera toujours chargée agressivement. <emphasis>. Notez que si "
+"<literal>constrained=\"false\"</literal>, l'utilisation de proxy est "
+"impossible et Hibernate chargera automatiquement l'association </emphasis>."
 
 #. Tag: para
-#: basic_mapping.xml:1767
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "There are two varieties of one-to-one associations:"
-msgstr "associations par clef primaire"
+msgstr "Il existe deux types d'associations un-à-un : "
 
 #. Tag: para
-#: basic_mapping.xml:1771
 #, no-c-format
 msgid "primary key associations"
-msgstr "association par clef étrangère unique"
+msgstr "association par clé primaire "
 
 #. Tag: para
-#: basic_mapping.xml:1774
 #, no-c-format
 msgid "unique foreign key associations"
-msgstr ""
-"Les associations par clef primaire ne nécessitent pas une colonne "
-"supplémentaire en table ; si deux lignes sont liés par l'association alors "
-"les deux lignes de la table partagent la même valeur de clef primaire. Donc "
-"si vous voulez que deux objets soient liés par une association par clef "
-"primaire, vous devez faire en sorte qu'on leur assigne la même valeur "
-"d'identifiant !"
+msgstr "association par clé étrangère unique"
 
 #. Tag: para
-#: basic_mapping.xml:1779
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Primary key associations do not need an extra table column. If two rows are "
 "related by the association, then the two table rows share the same primary "
 "key value. To relate two objects by a primary key association, ensure that "
 "they are assigned the same identifier value."
 msgstr ""
-"Pour une association par clef primaire, ajoutez les mappings suivants à "
-"<literal>Employee</literal> et <literal>Person</literal>, respectivement."
+"Les associations par clé primaire ne nécessitent pas une colonne "
+"supplémentaire en table ; si deux lignes sont liées par l'association alors "
+"les deux lignes de la table partagent la même valeur de clé primaire. Donc "
+"si vous voulez que deux objets soient liés par une association par clé "
+"primaire, vous devez faire en sorte qu'on leur assigne la même valeur "
+"d'identifiant. "
 
 #. Tag: para
-#: basic_mapping.xml:1786
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For a primary key association, add the following mappings to "
 "<literal>Employee</literal> and <literal>Person</literal> respectively:"
 msgstr ""
-"Maintenant, vous devez faire en sorte que les clefs primaires des lignes "
-"liées dans les tables PERSON et EMPLOYEE sont égales. On utilise une "
-"stratégie Hibernate spéciale de génération d'identifiants appelée "
-"<literal>foreign</literal> :"
+"Pour une association par clé primaire, ajoutez les mappages suivants à "
+"<literal>Employee</literal> et <literal>Person</literal>, respectivement :"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1791
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[<one-to-one name=\"person\" class=\"Person\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:1792
-#, no-c-format
 msgid ""
-"<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" constrained=\"true"
-"\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1794
-#, fuzzy, no-c-format
-msgid ""
 "Ensure that the primary keys of the related rows in the PERSON and EMPLOYEE "
 "tables are equal. You use a special Hibernate identifier generation strategy "
 "called <literal>foreign</literal>:"
 msgstr ""
-"Une instance fraîchement enregistrée de <literal>Person</literal> se voit "
-"alors assignée la même valeur de clef primaire que l'instance de "
-"<literal>Employee</literal> référencée par la propriété <literal>employee</"
-"literal> de cette <literal>Person</literal>."
+"Maintenant, vous devez faire en sorte que les clés primaires des lignes "
+"liées dans les tables PERSON et EMPLOYEE sont égales. On utilise une "
+"stratégie Hibernate spéciale de génération d'identifiants appelée "
+"<literal>foreign</literal> : "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1800
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"person\" table=\"PERSON\">\n"
-"    <id name=\"id\" column=\"PERSON_ID\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">employee</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    ...\n"
-"    <one-to-one name=\"employee\"\n"
-"        class=\"Employee\"\n"
-"        constrained=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1802
-#, fuzzy, no-c-format
-msgid ""
 "A newly saved instance of <literal>Person</literal> is assigned the same "
 "primary key value as the <literal>Employee</literal> instance referred with "
 "the <literal>employee</literal> property of that <literal>Person</literal>."
 msgstr ""
-"Alternativement, une clef étrangère avec contrainte d'unicité de "
-"<literal>Employee</literal> vers <literal>Person</literal> peut être "
-"indiquée ainsi :"
+"Une instance fraîchement enregistrée de <literal>Person</literal> se voit "
+"alors assignée la même valeur de clé primaire que l'instance de "
+"<literal>Employee</literal> référencée par la propriété <literal>employee</"
+"literal> de cette <literal>Person</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:1808
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, a foreign key with a unique constraint, from "
 "<literal>Employee</literal> to <literal>Person</literal>, can be expressed "
 "as:"
 msgstr ""
-"Et cette association peut être rendue bidirectionnelle en ajoutant ceci au "
-"mapping de <literal>Person</literal> :"
+"Alternativement, une clé étrangère avec contrainte d'unicité de "
+"<literal>Employee</literal> vers <literal>Person</literal> peut être "
+"indiquée ainsi : "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1813
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"person\" class=\"Person\" column=\"PERSON_ID\" "
-"unique=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1815
-#, fuzzy, no-c-format
-msgid ""
 "This association can be made bidirectional by adding the following to the "
 "<literal>Person</literal> mapping:"
-msgstr "natural-id"
-
-#. Tag: programlisting
-#: basic_mapping.xml:1820
-#, no-c-format
-msgid ""
-"<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" property-ref="
-"\"person\"/>]]>"
 msgstr ""
+"Et cette association peut être rendue bidirectionnelle en ajoutant ceci au "
+"mappage de <literal>Person</literal> : "
 
 #. Tag: title
-#: basic_mapping.xml:1825
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Natural-id"
-msgstr ""
-"Bien que nous recommandions l'utilisation de clé primaire générée, vous "
-"devriez toujours essayer d'identifier des clé métier (naturelles) pour "
-"toutes vos entités. Une clé naturelle est une propriété ou une combinaison "
-"de propriétés uniques et non nulles. Si elle est aussi immuable, c'est "
-"encore mieux. Mappez les propriétés de la clé naturelle dans l'élément "
-"<literal>&lt;natural-id&gt;</literal>. Hibernate générera la clé unique "
-"nécessaire et les contraintes de non-nullité, et votre mapping s'auto-"
-"documentera."
+msgstr "Natural-id"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1827
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<natural-id mutable=\"true|false\"/>\n"
-"        <property ... />\n"
-"        <many-to-one ... />\n"
-"        ......\n"
-"</natural-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1829
-#, fuzzy, no-c-format
-msgid ""
 "Although we recommend the use of surrogate keys as primary keys, you should "
 "try to identify natural keys for all entities. A natural key is a property "
 "or combination of properties that is unique and non-null. It is also "
@@ -3578,215 +2718,167 @@
 "unique key and nullability constraints and, as a result, your mapping will "
 "be more self-documenting."
 msgstr ""
-"Nous vous recommandons fortement d'implémenter <literal>equals()</literal> "
-"et <literal>hashCode()</literal> pour comparer les clés naturelles de "
-"l'entité."
+"Bien que nous recommandions l'utilisation de clés primaires générées, vous "
+"devriez toujours essayer d'identifier des clés métier (naturelles) pour "
+"toutes vos entités. Une clé naturelle est une propriété ou une combinaison "
+"de propriétés unique et non nulle. Si elle est aussi immuable, c'est encore "
+"mieux. Mappez les propriétés de la clé naturelle dans l'élément <literal>&lt;"
+"natural-id&gt;</literal>. Hibernate générera la clé unique nécessaire et les "
+"contraintes de non-nullité, et votre mappage s'auto-documentera. "
 
 #. Tag: para
-#: basic_mapping.xml:1838
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you implement <literal>equals()</literal> and "
 "<literal>hashCode()</literal> to compare the natural key properties of the "
 "entity."
 msgstr ""
-"Ce mapping n'est pas destiné à être utilisé avec des entités qui ont des "
-"clés naturelles."
+"Nous vous recommandons fortement d'implémenter <literal>equals()</literal> "
+"et <literal>hashCode()</literal> pour comparer les propriétés clés "
+"naturelles de l'entité."
 
 #. Tag: para
-#: basic_mapping.xml:1843
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This mapping is not intended for use with entities that have natural primary "
 "keys."
 msgstr ""
-"<literal>mutable</literal> (optionel, par défaut à <literal>false</"
-"literal>) : Par défaut, les identifiants naturels sont supposés être "
-"immuable (constants)."
+"Ce mappage n'est pas destiné à être utilisé avec des entités qui ont des "
+"clés naturelles. "
 
 #. Tag: para
-#: basic_mapping.xml:1849
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>false</"
 "literal>): by default, natural identifier properties are assumed to be "
 "immutable (constant)."
-msgstr "component, dynamic-component"
+msgstr ""
+"<literal>mutable</literal> (optionnel, par défaut à <literal>false</"
+"literal>) : par défaut, les identifiants naturels sont supposés être "
+"immuables (constants). "
 
 #. Tag: title
-#: basic_mapping.xml:1859
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Component and dynamic-component"
-msgstr ""
-"L'élément <literal>&lt;component&gt;</literal> mappe les propriétés d'un "
-"objet fils aux colonnes d'une classe parente. Les composants peuvent en "
-"retour déclarer leurs propres propriétés, composants ou collections. Voir "
-"\"Components\" plus bas."
+msgstr "Component, dynamic-component"
 
 #. Tag: para
-#: basic_mapping.xml:1861
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element maps properties of a child "
 "object to columns of the table of a parent class. Components can, in turn, "
 "declare their own properties, components or collections. See the \"Component"
 "\" examples below:"
-msgstr "<literal>name</literal> : Nom de la propriété"
-
-#. Tag: programlisting
-#: basic_mapping.xml:1879
-#, no-c-format
-msgid ""
-"<![CDATA[<component\n"
-"        name=\"propertyName\"\n"
-"        class=\"className\"\n"
-"        insert=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        lazy=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        node=\"element-name|.\"\n"
-">\n"
-"\n"
-"        <property ...../>\n"
-"        <many-to-one .... />\n"
-"        ........\n"
-"</component>]]>"
 msgstr ""
+"L'élément <literal>&lt;component&gt;</literal> mappe les propriétés d'un "
+"objet enfant aux colonnes d'une classe parente. Les composants peuvent en "
+"retour déclarer leurs propres propriétés, composants ou collections. Voir "
+"\"Components\" plus bas :"
 
 #. Tag: para
-#: basic_mapping.xml:1887
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
 "determined by reflection): the name of the component (child) class."
 msgstr ""
-"<literal>insert</literal> : Est ce que les colonnes mappées apparaissent "
-"dans les <literal>INSERT</literal>s ?"
+"<literal>class</literal> (optionnel - par défaut au type de la propriété "
+"déterminé par réflexion) : le nom de la classe (enfant) du composant. "
 
 #. Tag: para
-#: basic_mapping.xml:1893 basic_mapping.xml:1982
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>insert</literal>: do the mapped columns appear in SQL "
 "<literal>INSERTs</literal>?"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>update</literal>: Est ce que les colonnes mappées apparaissent dans "
-"les <literal>UPDATE</literal>s ?\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>update</literal> : Est-ce que les colonnes mappées apparaissent "
-"dans les <literal>UPDATE</literal>s ?"
+"<literal>insert</literal> : les colonnes mappées apparaissent-elles dans les "
+"SQL <literal>INSERT</literal> s ? "
 
 #. Tag: para
-#: basic_mapping.xml:1899 basic_mapping.xml:1988
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update</literal>: do the mapped columns appear in SQL "
 "<literal>UPDATEs</literal>?"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (optionnel - par défaut à <literal>property</"
-"literal>) : La stratégie que Hibernate doit utiliser pour accéder à la "
-"valeur de cette propriété.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>optimistic-lock</literal> (optionnel - par défaut à <literal>true</"
-"literal>) : Indique que les mises à jour sur ce composant nécessitent ou non "
-"l'acquisition d'un verrou optimiste. En d'autres termes, cela détermine si "
-"une incrémentation de version doit avoir lieu quand la propriété est marquée "
-"obsolète (dirty)."
+"<literal>update</literal>: les colonnes mappées apparaissent-elles dans les "
+"SQL <literal>UPDATE</literal> s ? "
 
 #. Tag: para
-#: basic_mapping.xml:1911
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>false</literal>): "
 "specifies that this component should be fetched lazily when the instance "
 "variable is first accessed. It requires build-time bytecode instrumentation."
 msgstr ""
-"<literal>optimistic-lock</literal> (optionnel - par défaut à <literal>true</"
-"literal>) : Indique que les mises à jour sur ce composant nécessitent ou non "
-"l'acquisition d'un verrou optimiste. En d'autres termes, cela détermine si "
-"une incrémentation de version doit avoir lieu quand la propriété est marquée "
-"obsolète (dirty)."
+"<literal>lazy</literal> (optionnel - par défaut à <literal>false</"
+"literal>) : indique que ce composant doit être chargé en différé au premier "
+"accès à la variable d'instance (nécessite une instrumentation du bytecode "
+"lors de la phase de construction). "
 
 #. Tag: para
-#: basic_mapping.xml:1918
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to this component either do or do not "
 "require acquisition of the optimistic lock. It determines if a version "
 "increment should occur when this property is dirty."
 msgstr ""
-"<literal>unique</literal> (optionnel - par défaut à <literal>false</"
-"literal>) : Indique qu'une contrainte d'unicité existe sur toutes les "
-"colonnes mappées de ce composant."
+"<literal>optimistic-lock</literal> (optionnel - par défaut à <literal>true</"
+"literal>) : spécifie si les mise à jour sur ce composant nécessitent ou non "
+"l'acquisition d'un verrou optimiste. En d'autres termes, cela détermine si "
+"une incrémentation de version doit avoir lieu quand la propriété est marquée "
+"obsolète (dirty). "
 
 #. Tag: para
-#: basic_mapping.xml:1926 basic_mapping.xml:2002
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional - defaults to <literal>false</literal>): "
 "specifies that a unique constraint exists upon all mapped columns of the "
 "component."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Les tags fils <literal>&lt;property&gt;</literal> mappent les propriétés de "
-"la classe fille sur les colonnes de la table.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Par exemple, si nous avons le mapping de <literal>&lt;properties&gt;</"
-"literal> suivant :"
+"<literal>unique</literal> (optionnel - par défaut à <literal>false</"
+"literal>) : Indique qu'une contrainte d'unicité existe sur toutes les "
+"colonnes mappées de ce composant. "
 
 #. Tag: para
-#: basic_mapping.xml:1935
 #, no-c-format
 msgid ""
 "The child <literal>&lt;property&gt;</literal> tags map properties of the "
 "child class to table columns."
 msgstr ""
-"L'élément <literal>&lt;component&gt;</literal> permet de déclarer sous-"
-"élément <literal>&lt;parent&gt;</literal> qui associe une propriété de la "
-"classe composant comme une référence arrière vers l'entité contenante."
+"Les balises enfant <literal>&lt;property&gt;</literal> mappent les "
+"propriétés de la classe enfant sur les colonnes de la table. "
 
 #. Tag: para
-#: basic_mapping.xml:1940
 #, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element allows a <literal>&lt;"
 "parent&gt;</literal> subelement that maps a property of the component class "
 "as a reference back to the containing entity."
 msgstr ""
-"L'élément <literal>&lt;dynamic-component&gt;</literal> permet à une "
-"<literal>Map</literal> d'être mappée comme un composant, quand les noms de "
-"la propriété font référence aux clefs de cette Map, voir <xref linkend="
-"\"components-dynamic\"/>."
+"L'élément <literal>&lt;component&gt;</literal> permet de déclarer un sous-"
+"élément <literal>&lt;parent&gt;</literal> qui associe une propriété de la "
+"classe composant comme une référence arrière vers l'entité contenante. "
 
 #. Tag: para
-#: basic_mapping.xml:1946
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;dynamic-component&gt;</literal> element allows a "
 "<literal>Map</literal> to be mapped as a component, where the property names "
-"refer to keys of the map. See <xref linkend=\"components-dynamic\"/> for "
+"refer to keys of the map. See <xref linkend=\"components-dynamic\" /> for "
 "more information."
-msgstr "properties"
+msgstr ""
+"L'élément <literal>&lt;dynamic-component&gt;</literal> permet à une "
+"<literal>Map</literal> d'être mappée en tant que composant, quand les noms "
+"de la propriété font référence aux clés de cette Map. Voir <xref linkend="
+"\"components-dynamic\" />. "
 
 #. Tag: title
-#: basic_mapping.xml:1955
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Properties"
-msgstr ""
-"L'élément <literal>&lt;properties&gt;</literal> permet la définition d'un "
-"groupement logique nommé des propriétés d'une classe. L'utilisation la plus "
-"importante de cette construction est la possibilité pour une combinaison de "
-"propriétés d'être la cible d'un <literal>property-ref</literal>. C'est aussi "
-"un moyen pratique de définir une contrainte d'unicité multi-colonnes."
+msgstr "Propriétés"
 
 #. Tag: para
-#: basic_mapping.xml:1957
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;properties&gt;</literal> element allows the definition of a "
 "named, logical grouping of the properties of a class. The most important use "
@@ -3794,215 +2886,117 @@
 "target of a <literal>property-ref</literal>. It is also a convenient way to "
 "define a multi-column unique constraint. For example:"
 msgstr ""
-"<literal>name</literal> : Le nom logique d'un regroupement et <emphasis>non</"
-"emphasis> le véritable nom d'une propriété."
+"L'élément <literal>&lt;properties&gt;</literal> permet la définition d'un "
+"groupement logique nommé des propriétés d'une classe. L'utilisation la plus "
+"importante de cette construction est la possibilité pour une combinaison de "
+"propriétés d'être la cible d'un <literal>property-ref</literal>. C'est aussi "
+"un moyen pratique de définir une contrainte d'unicité multi-colonnes. Par "
+"exemple :"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1973
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<properties\n"
-"        name=\"logicalName\"\n"
-"        insert=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-">\n"
-"\n"
-"        <property ...../>\n"
-"        <many-to-one .... />\n"
-"        ........\n"
-"</properties>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1976
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal>: the logical name of the grouping. It is "
 "<emphasis>not</emphasis> an actual property name."
 msgstr ""
-"<literal>insert</literal> : Est-ce que les colonnes mappées apparaissent "
-"dans les <literal>INSERT</literal>s ?"
+"<literal>name</literal> : le nom logique d'un regroupement et <emphasis>non</"
+"emphasis> le véritable nom d'une propriété. "
 
 #. Tag: para
-#: basic_mapping.xml:1994
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to these properties either do or do not "
 "require acquisition of the optimistic lock. It determines if a version "
 "increment should occur when these properties are dirty."
 msgstr ""
-"<literal>unique</literal> (optionnel - par défaut à <literal>false</"
-"literal>) : Indique qu'une contrainte d'unicité existe sur toutes les "
-"colonnes mappées de ce composant."
+"<literal>optimistic-lock</literal> (optionnel - par défaut à <literal>true</"
+"literal>) : indique si les mise à jour sur ce composant nécessitent ou non "
+"l'acquisition d'un verrou optimiste. En d'autres termes, cela détermine si "
+"une incrémentation de version doit avoir lieu quand la propriété est marquée "
+"obsolète (dirty). "
 
 #. Tag: para
-#: basic_mapping.xml:2011
 #, no-c-format
 msgid ""
 "For example, if we have the following <literal>&lt;properties&gt;</literal> "
 "mapping:"
 msgstr ""
-"Alors nous pourrions avoir une association sur des données d'un ancien "
-"système (legacy) qui font référence à cette clef unique de la table "
-"<literal>Person</literal> au lieu de la clef primaire :"
+"Par exemple, si nous avons le mappage de <literal>&lt;properties&gt;</"
+"literal> suivant : "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2015
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"personNumber\"/>\n"
-"\n"
-"    ...\n"
-"    <properties name=\"name\"\n"
-"            unique=\"true\" update=\"false\">\n"
-"        <property name=\"firstName\"/>\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"lastName\"/>\n"
-"    </properties>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2017
-#, fuzzy, no-c-format
-msgid ""
 "You might have some legacy data association that refers to this unique key "
 "of the <literal>Person</literal> table, instead of to the primary key:"
 msgstr ""
-"Nous ne recommandons pas l'utilisation de ce genre de chose en dehors du "
-"contexte de mapping de données héritées d'anciens systèmes."
+"Alors nous pourrions avoir une association sur des données d'un ancien "
+"système qui font référence à cette clé unique de la table <literal>Person</"
+"literal> au lieu de la clé primaire : "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2022
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"person\"\n"
-"         class=\"Person\" property-ref=\"name\">\n"
-"    <column name=\"firstName\"/>\n"
-"    <column name=\"initial\"/>\n"
-"    <column name=\"lastName\"/>\n"
-"</many-to-one>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2024
-#, fuzzy, no-c-format
-msgid ""
 "The use of this outside the context of mapping legacy data is not "
 "recommended."
-msgstr "subclass"
+msgstr ""
+"Nous ne recommandons pas une telle utilisation, en dehors du contexte de "
+"mappage de données héritées d'anciens systèmes. "
 
 #. Tag: title
-#: basic_mapping.xml:2032
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Subclass"
-msgstr ""
-"Pour finir, la persistance polymorphique nécessite la déclaration de chaque "
-"sous-classe de la classe persistante de base. pour la stratégie de mapping "
-"de type table-per-class-hierarchy, on utilise la déclaration <literal>&lt;"
-"subclass&gt;</literal>."
+msgstr "Subclass"
 
 #. Tag: para
-#: basic_mapping.xml:2034
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Polymorphic persistence requires the declaration of each subclass of the "
 "root persistent class. For the table-per-class-hierarchy mapping strategy, "
 "the <literal>&lt;subclass&gt;</literal> declaration is used. For example:"
-msgstr "<literal>name</literal> : Le nom complet de la sous-classe."
-
-#. Tag: programlisting
-#: basic_mapping.xml:2047
-#, no-c-format
-msgid ""
-"<![CDATA[<subclass\n"
-"        name=\"ClassName\"\n"
-"        discriminator-value=\"discriminator_value\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\"\n"
-"        extends=\"SuperclassName\">\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</subclass>]]>"
 msgstr ""
+"Pour finir, la persistance polymorphique nécessite la déclaration de chaque "
+"sous-classe de la classe racine persistante. Pour la stratégie de mappage de "
+"type table-per-class-hierarchy, on utilise la déclaration <literal>&lt;"
+"subclass&gt;</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:2050 basic_mapping.xml:2108 basic_mapping.xml:2171
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal>: the fully qualified class name of the subclass."
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>discriminator-value</literal> (optionnel - par défaut le nom de la "
-"classe) : une valeur qui distingue les différentes sous-classes.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>name</literal> : Le nom Java complet de la sous-classe.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>name</literal> : Le nom Java complet de la sous-classe."
+msgstr "<literal>name</literal> : le nom de classe complet de la sous-classe. "
 
 #. Tag: para
-#: basic_mapping.xml:2055
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>discriminator-value</literal> (optional - defaults to the class "
 "name): a value that distinguishes individual subclasses."
 msgstr ""
-"<literal>proxy</literal> (optionnel) : Indique une classe ou interface à "
-"utiliser pour les chargements à la demande des proxies (lazy)."
+"<literal>discriminator-value</literal> (optionnel - par défaut le nom de la "
+"classe) : une valeur qui distingue les différentes sous-classes. "
 
 #. Tag: para
-#: basic_mapping.xml:2061
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies a class or interface used for "
 "lazy initializing proxies."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (optionnel, par défaut à <literal>true</literal>) : "
-"Spécifier <literal>lazy=\"false\"</literal> désactive l'utilisation du "
-"chargement à la demande (lazy).\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal> (optionnel) : Indique une classe ou interface pour "
-"le chargement différé des proxies.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal> (optionnel) : Indique une classe ou interface pour "
-"le chargement différé des proxies."
+"<literal>proxy</literal> (optionnel) : indique une classe ou interface à "
+"utiliser pour l'initialisation différée des proxies. "
 
 #. Tag: para
-#: basic_mapping.xml:2067
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>true</literal>): "
 "setting <literal>lazy=\"false\"</literal> disables the use of lazy fetching."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Chaque sous-classe devrait déclarer ses propres propriétés persistantes et "
-"sous-classes. Les propriétés <literal>&lt;version&gt;</literal> et "
-"<literal>&lt;id&gt;</literal> sont implicitement hérités de la classe de "
-"base. Chaque sous-classe dans une hiérarchie doit définir une unique "
-"<literal>discriminator-value</literal>. Si aucune n'est spécifiée, le nom "
-"complet de la classe Java est utilisé.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>lazy</literal> (optionnel, par défaut à <literal>true</literal>) : "
-"Indiquer <literal>lazy=\"false\"</literal> désactive l'utilisation du "
-"chargement à la demande.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (optionnel, par défaut à <literal>true</literal>) : "
-"Indiquer <literal>lazy=\"false\"</literal> désactive l'utilisation du "
-"chargement à la demande."
+"spécifier <literal>lazy=\"false\"</literal> désactive l'utilisation de "
+"l'extraction différée."
 
 #. Tag: para
-#: basic_mapping.xml:2075
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Each subclass declares its own persistent properties and subclasses. "
 "<literal>&lt;version&gt;</literal> and <literal>&lt;id&gt;</literal> "
@@ -4010,119 +3004,66 @@
 "a hierarchy must define a unique <literal>discriminator-value</literal>. If "
 "this is not specified, the fully qualified Java class name is used."
 msgstr ""
-"Pour plus d'infos sur le mapping d'héritage, voir <xref linkend=\"inheritance"
-"\"/>."
+"Chaque sous-classe devrait déclarer ses propres propriétés persistantes et "
+"sous-classes. Les propriétés <literal>&lt;version&gt;</literal> et "
+"<literal>&lt;id&gt;</literal> sont implicitement hérités de la classe "
+"racine. Chaque sous-classe dans une hiérarchie doit définir une unique "
+"<literal>discriminator-value</literal>. Si non spécifiée, le nom complet de "
+"la classe Java est utilisé. "
 
 #. Tag: para
-#: basic_mapping.xml:2083 basic_mapping.xml:2141 basic_mapping.xml:2199
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"For information about inheritance mappings see <xref linkend=\"inheritance\"/"
-">."
+"For information about inheritance mappings see <xref linkend=\"inheritance"
+"\" />."
 msgstr ""
-"Pour des informations sur les mappings d'héritage, voir <xref linkend="
-"\"inheritance\"/>."
+"Pour plus d'informations sur les mappages d'héritage, consultez le <xref "
+"linkend=\"inheritance\" />. "
 
 #. Tag: title
-#: basic_mapping.xml:2090
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Joined-subclass"
-msgstr "joined-subclass"
+msgstr "Joined-subclass"
 
 #. Tag: para
-#: basic_mapping.xml:2092
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Each subclass can also be mapped to its own table. This is called the table-"
 "per-subclass mapping strategy. An inherited state is retrieved by joining "
 "with the table of the superclass. To do this you use the <literal>&lt;joined-"
 "subclass&gt;</literal> element. For example:"
 msgstr ""
-"Une autre façon possible de faire est la suivante, chaque sous-classe peut "
-"être mappée vers sa propre table (stratégie de mapping de type table-per-"
-"subclass). L'état hérité est récupéré en joignant la table de la super-"
-"classe. L'élément <literal>&lt;joined-subclass&gt;</literal> est utilisé."
+"Il est également possible de mapper chaque sous-classe vers sa propre table "
+"(stratégie de mappage de type table-per-subclass). L'état hérité est "
+"récupéré en joignant la table de la super-classe. L'élément <literal>&lt;"
+"joined-subclass&gt;</literal> est utilisé. Par exemple :"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2105
-#, no-c-format
-msgid ""
-"<![CDATA[<joined-subclass\n"
-"        name=\"ClassName\"\n"
-"        table=\"tablename\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        schema=\"schema\"\n"
-"        catalog=\"catalog\"\n"
-"        extends=\"SuperclassName\"\n"
-"        persister=\"ClassName\"\n"
-"        subselect=\"SQL expression\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\">\n"
-"\n"
-"        <key .... >\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</joined-subclass>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2113 basic_mapping.xml:2176
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>table</literal>: the name of the subclass table."
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>table</literal> : Le nom de la table de la sous-classe.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>table</literal> : nom de la table de la sous-classe."
+msgstr "<literal>table</literal>: le nom de la table de la sous-classe. "
 
 #. Tag: para
-#: basic_mapping.xml:2118 basic_mapping.xml:2181
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies a class or interface to use "
 "for lazy initializing proxies."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (optionnel, par défaut à <literal>true</literal>) : "
-"Spécifier <literal>lazy=\"false\"</literal> désactive l'utilisation du "
-"chargement à la demande (lazy).\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal> (optionnel) : Indique une classe ou interface pour "
-"le chargement différé des proxies.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal> (optionnel) : Indique une classe ou interface pour "
-"le chargement différé des proxies."
+"<literal>proxy</literal> (optionnel) : indique une classe ou interface à "
+"utiliser pour l'initialisation différée des proxies. "
 
 #. Tag: para
-#: basic_mapping.xml:2124 basic_mapping.xml:2187
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional, defaults to <literal>true</literal>): "
 "setting <literal>lazy=\"false\"</literal> disables the use of lazy fetching."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Chaque sous-classe devrait déclarer ses propres propriétés persistantes et "
-"sous-classes. Les propriétés <literal>&lt;version&gt;</literal> et "
-"<literal>&lt;id&gt;</literal> sont implicitement hérités de la classe de "
-"base. Chaque sous-classe dans une hiérarchie doit définir une unique "
-"<literal>discriminator-value</literal>. Si aucune n'est spécifiée, le nom "
-"complet de la classe Java est utilisé.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>lazy</literal> (optionnel, par défaut à <literal>true</literal>) : "
-"Indiquer <literal>lazy=\"false\"</literal> désactive l'utilisation du "
-"chargement à la demande.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (optionnel, par défaut à <literal>true</literal>) : "
-"Indiquer <literal>lazy=\"false\"</literal> désactive l'utilisation du "
-"chargement à la demande."
+"spécifier <literal>lazy=\"false\"</literal> désactive l'utilisation de "
+"l'extraction différée. "
 
 #. Tag: para
-#: basic_mapping.xml:2132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A discriminator column is not required for this mapping strategy. Each "
 "subclass must, however, declare a table column holding the object identifier "
@@ -4130,57 +3071,17 @@
 "of the chapter would then be re-written as:"
 msgstr ""
 "Aucune colonne discriminante n'est nécessaire pour cette stratégie de "
-"mapping. Cependant, chaque sous-classe doit déclarer une colonne de table "
+"mappage. Cependant, chaque sous-classe doit déclarer une colonne de table "
 "contenant l'objet identifiant qui utilise l'élément <literal>&lt;key&gt;</"
-"literal>. Le mapping au début de ce chapitre serait ré-écrit ainsi :"
+"literal>. Le mappage au début de ce chapitre serait ré-écrit ainsi : "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2139
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"        <class name=\"Cat\" table=\"CATS\">\n"
-"                <id name=\"id\" column=\"uid\" type=\"long\">\n"
-"                        <generator class=\"hilo\"/>\n"
-"                </id>\n"
-"                <property name=\"birthdate\" type=\"date\"/>\n"
-"                <property name=\"color\" not-null=\"true\"/>\n"
-"                <property name=\"sex\" not-null=\"true\"/>\n"
-"                <property name=\"weight\"/>\n"
-"                <many-to-one name=\"mate\"/>\n"
-"                <set name=\"kittens\">\n"
-"                        <key column=\"MOTHER\"/>\n"
-"                        <one-to-many class=\"Cat\"/>\n"
-"                </set>\n"
-"                <joined-subclass name=\"DomesticCat\" table=\"DOMESTIC_CATS"
-"\">\n"
-"                    <key column=\"CAT\"/>\n"
-"                    <property name=\"name\" type=\"string\"/>\n"
-"                </joined-subclass>\n"
-"        </class>\n"
-"\n"
-"        <class name=\"eg.Dog\">\n"
-"                <!-- mapping for Dog could go here -->\n"
-"        </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:2148
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Union-subclass"
-msgstr "union-subclass"
+msgstr "Union-subclass"
 
 #. Tag: para
-#: basic_mapping.xml:2150
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A third option is to map only the concrete classes of an inheritance "
 "hierarchy to tables. This is called the table-per-concrete-class strategy. "
@@ -4192,95 +3093,48 @@
 "need to use the <literal>&lt;union-subclass&gt;</literal> mapping. For "
 "example:"
 msgstr ""
-"Une troisième option est de seulement mapper vers des tables les classes "
-"concrètes d'une hiérarchie d'héritage, (stratégie de type table-per-concrete-"
+"Une troisième option est de mapper uniquement les classes concrètes d'une "
+"hiérarchie d'héritage vers des tables, (stratégie de type table-per-concrete-"
 "class) où chaque table définit tous les états persistants de la classe, y "
 "compris les états hérités. Dans Hibernate il n'est absolument pas nécessaire "
 "de mapper explicitement de telles hiérarchies d'héritage. Vous pouvez "
 "simplement mapper chaque classe avec une déclaration <literal>&lt;class&gt;</"
 "literal> différente. Cependant, si vous souhaitez utiliser des associations "
-"polymorphiques (càd une association vers la superclasse de la hiérarchie), "
-"vous devez utiliser le mapping <literal>&lt;union-subclass&gt;</literal>."
+"polymorphiques (c'est-à-dire une association vers la superclasse de votre "
+"hiérarchie), vous devez utiliser le mappage <literal>&lt;union-subclass&gt;</"
+"literal>. Par exemple :"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2168
-#, no-c-format
-msgid ""
-"<![CDATA[<union-subclass\n"
-"        name=\"ClassName\"\n"
-"        table=\"tablename\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        schema=\"schema\"\n"
-"        catalog=\"catalog\"\n"
-"        extends=\"SuperclassName\"\n"
-"        abstract=\"true|false\"\n"
-"        persister=\"ClassName\"\n"
-"        subselect=\"SQL expression\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\">\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</union-subclass>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2195
 #, no-c-format
 msgid ""
 "No discriminator column or key column is required for this mapping strategy."
 msgstr ""
-"Aucune colonne discriminante ou colonne clef n'est requise pour cette "
-"stratégie de mapping."
+"Aucune colonne discriminante ou colonne clé n'est requise pour cette "
+"stratégie de mappage."
 
 #. Tag: title
-#: basic_mapping.xml:2206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Join"
-msgstr "join"
+msgstr "Join"
 
 #. Tag: para
-#: basic_mapping.xml:2208
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Using the <literal>&lt;join&gt;</literal> element, it is possible to map "
 "properties of one class to several tables that have a one-to-one "
 "relationship. For example:"
 msgstr ""
 "En utilisant l'élément <literal>&lt;join&gt;</literal>, il est possible de "
-"mapper des propriétés d'une classe sur plusieurs tables."
+"mapper des propriétés d'une classe sur plusieurs tables quand il existe une "
+"relation un-à-un entre les tables. Par exemple :"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2222
-#, no-c-format
-msgid ""
-"<![CDATA[<join\n"
-"        table=\"tablename\"\n"
-"        schema=\"owner\"\n"
-"        catalog=\"catalog\"\n"
-"        fetch=\"join|select\"\n"
-"        inverse=\"true|false\"\n"
-"        optional=\"true|false\">\n"
-"\n"
-"        <key ... />\n"
-"\n"
-"        <property ... />\n"
-"        ...\n"
-"</join>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2226
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>table</literal>: the name of the joined table."
-msgstr "<literal>table</literal> : Le nom de la table jointe."
+msgstr "<literal>table</literal> : le nom de la table jointe. "
 
 #. Tag: para
-#: basic_mapping.xml:2243
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional - defaults to <literal>join</literal>): "
 "if set to <literal>join</literal>, the default, Hibernate will use an inner "
@@ -4293,32 +3147,30 @@
 "<literal>&lt;join&gt;</literal> defined by the class and its superclasses."
 msgstr ""
 "<literal>fetch</literal> (optionnel - par défaut à <literal>join</"
-"literal>) : Si positionné à <literal>join</literal>, Hibernate utilisera une "
+"literal>) : si positionné à <literal>join</literal>, Hibernate utilisera une "
 "jointure interne pour charger une <literal>jointure</literal> définie par "
 "une classe ou ses super-classes et une jointure externe pour une "
 "<literal>&lt;jointure&gt;</literal> définie par une sous-classe. Si "
-"positionné à <literal>select</literal> alors Hibernate utilisera un select "
+"positionné à <literal>select</literal>, Hibernate utilisera un select "
 "séquentiel pour une <literal>&lt;jointure&gt;</literal> définie sur une sous-"
-"classe, qui ne sera délivrée que si une ligne se représente une instance de "
-"la sous-classe. Les jointures internes seront quand même utilisées pour "
-"charger une <literal>&lt;jointure&gt;</literal> définie par une classe et "
-"ses super-classes."
+"classe, qui ne sera délivrée que si une ligne représente une instance de la "
+"sous-classe. Les jointures internes seront quand même utilisées pour charger "
+"une <literal>&lt;jointure&gt;</literal> définie par une classe et ses super-"
+"classes. "
 
 #. Tag: para
-#: basic_mapping.xml:2256
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>inverse</literal> (optional - defaults to <literal>false</"
 "literal>): if enabled, Hibernate will not insert or update the properties "
 "defined by this join."
 msgstr ""
 "<literal>inverse</literal> (optionnel - par défaut à <literal>false</"
-"literal>) : Si positionné à true, Hibernate n'essaiera pas d'insérer ou de "
-"mettre à jour les propriétés définies par cette jointure."
+"literal>) : si positionné à true, Hibernate n'essaiera pas d'insérer ou de "
+"mettre à jour les propriétés définies par cette jointure. "
 
 #. Tag: para
-#: basic_mapping.xml:2263
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optional</literal> (optional - defaults to <literal>false</"
 "literal>): if enabled, Hibernate will insert a row only if the properties "
@@ -4326,63 +3178,41 @@
 "retrieve the properties."
 msgstr ""
 "<literal>optionnel</literal> (optionnel - par défaut à <literal>false</"
-"literal>) : Si positionné à true, Hibernate insèrera une ligne seulement si "
+"literal>) : si positionné à true, Hibernate insèrera une ligne seulement si "
 "les propriétés définies par cette jointure sont non-nulles et utilisera "
-"toujours une jointure externe pour charger les propriétés."
+"toujours une jointure externe pour extraire les propriétés. "
 
 #. Tag: para
-#: basic_mapping.xml:2272
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For example, address information for a person can be mapped to a separate "
 "table while preserving value type semantics for all properties:"
 msgstr ""
 "Par exemple, les informations d'adresse pour une personne peuvent être "
 "mappées vers une table séparée (tout en préservant des sémantiques de type "
-"valeur pour toutes ses propriétés) :"
+"valeur pour toutes ses propriétés) : "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2277
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\"\n"
-"    table=\"PERSON\">\n"
-"\n"
-"    <id name=\"id\" column=\"PERSON_ID\">...</id>\n"
-"\n"
-"    <join table=\"ADDRESS\">\n"
-"        <key column=\"ADDRESS_ID\"/>\n"
-"        <property name=\"address\"/>\n"
-"        <property name=\"zip\"/>\n"
-"        <property name=\"country\"/>\n"
-"    </join>\n"
-"    ...]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2279
-#, fuzzy, no-c-format
-msgid ""
 "This feature is often only useful for legacy data models. We recommend fewer "
 "tables than classes and a fine-grained domain model. However, it is useful "
 "for switching between inheritance mapping strategies in a single hierarchy, "
 "as explained later."
 msgstr ""
 "Cette fonctionnalité est souvent seulement utile pour les modèles de données "
-"hérités d'anciens systèmes (legacy), nous recommandons d'utiliser moins de "
-"tables que de classes et un modèle de domaine à granularité fine. Cependant, "
-"c'est utile pour passer d'une stratégie de mapping d'héritage à une autre "
-"dans une hiérarchie simple ainsi qu'il est expliqué plus tard."
+"hérités d'anciens systèmes, nous recommandons d'utiliser moins de tables que "
+"de classes et un modèle de domaine à granularité fine. Cependant, c'est "
+"utile pour passer d'une stratégie de mappage d'héritage à une autre dans une "
+"hiérarchie simple, comme nous le verrons plus tard. "
 
 #. Tag: title
-#: basic_mapping.xml:2289
 #, no-c-format
-msgid "<title>Key</title>"
-msgstr ""
+msgid "Key"
+msgstr "Key"
 
 #. Tag: para
-#: basic_mapping.xml:2291
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;key&gt;</literal> element has featured a few times within "
 "this guide. It appears anywhere the parent mapping element defines a join to "
@@ -4390,88 +3220,67 @@
 "defines the foreign key in the joined table:"
 msgstr ""
 "Nous avons rencontré l'élément <literal>&lt;key&gt;</literal> à plusieurs "
-"reprises maintenant. Il apparaît partout que l'élément de mapping parent "
-"définit une jointure sur une nouvele table, et définit la clef étrangère "
-"dans la table jointe, ce qui référence la clef primaire de la table "
-"d'origine."
+"reprises maintenant. Il apparaît partout que l'élément de mappage parent "
+"définit une jointure sur une nouvelle table, et définit la clé étrangère "
+"dans la table jointe, qui référence la clé primaire de la table d'origine :"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2307
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<key\n"
-"        column=\"columnname\"\n"
-"        on-delete=\"noaction|cascade\"\n"
-"        property-ref=\"propertyName\"\n"
-"        not-null=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2318
-#, fuzzy, no-c-format
-msgid ""
 "<literal>on-delete</literal> (optional - defaults to <literal>noaction</"
 "literal>): specifies whether the foreign key constraint has database-level "
 "cascade delete enabled."
 msgstr ""
 "<literal>on-delete</literal> (optionnel, par défaut à <literal>noaction</"
-"literal>) : Indique si la contrainte de clef étrangère possède la "
-"possibilité au niveau base de données de suppression en cascade."
+"literal>) : indique si la contrainte de clé étrangère possède la possibilité "
+"au niveau base de données de suppression en cascade. "
 
 #. Tag: para
-#: basic_mapping.xml:2325
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): specifies that the foreign key "
 "refers to columns that are not the primary key of the original table. It is "
 "provided for legacy data."
 msgstr ""
-"<literal>property-ref</literal> (optionnel) : Indique que la clef étrangère "
-"fait référence à des colonnes qui ne sont pas la clef primaire de la table "
-"d'origine (Pour les données de systèmes legacy)."
+"<literal>property-ref</literal> (optionnel) : indique que la clé étrangère "
+"fait référence à des colonnes qui ne sont pas la clé primaire de la table "
+"d'origine (Pour les données d'anciens systèmes). "
 
 #. Tag: para
-#: basic_mapping.xml:2332
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): specifies that the foreign key "
 "columns are not nullable. This is implied whenever the foreign key is also "
 "part of the primary key."
 msgstr ""
-"<literal>not-null</literal> (optionnel) : Indique que les colonnes des clefs "
-"étrangères ne peuvent pas être nulles (c'est implicite si la clef étrangère "
-"fait partie de la clef primaire)."
+"<literal>not-null</literal> (optionnel) : indique que les colonnes des clés "
+"étrangères ne peuvent pas être nulles (c'est implicite si la clé étrangère "
+"fait partie de la clé primaire). "
 
 #. Tag: para
-#: basic_mapping.xml:2339
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update</literal> (optional): specifies that the foreign key should "
 "never be updated. This is implied whenever the foreign key is also part of "
 "the primary key."
 msgstr ""
-"<literal>update</literal> (optionnel) : Indique que la clef étrangère ne "
-"devrait jamais être mise à jour (implicite si celle-ci fait partie de la "
-"clef primaire)."
+"<literal>update</literal> (optionnel) : indique que la clé étrangère ne "
+"devrait jamais être mise à jour (implicite si celle-ci fait partie de la clé "
+"primaire). "
 
 #. Tag: para
-#: basic_mapping.xml:2346
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): specifies that the foreign key should "
 "have a unique constraint. This is implied whenever the foreign key is also "
 "the primary key."
 msgstr ""
-"<literal>unique</literal> (optionnel) : Indique que la clef étrangère doit "
-"posséder une contrainte d'unicité (implicite si la clef étrangère est aussi "
-"la clef primaire)."
+"<literal>unique</literal> (optionnel) : indique que la clé étrangère doit "
+"posséder une contrainte d'unicité (implicite si la clé étrangère est aussi "
+"la clé primaire). "
 
 #. Tag: para
-#: basic_mapping.xml:2354
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For systems where delete performance is important, we recommend that all "
 "keys should be defined <literal>on-delete=\"cascade\"</literal>. Hibernate "
@@ -4480,17 +3289,16 @@
 "that this feature bypasses Hibernate's usual optimistic locking strategy for "
 "versioned data."
 msgstr ""
-"Nous recommandons pour les systèmes où les suppressions doivent être "
-"performantes de définir toutes les clefs <literal>on-delete=\"cascade\"</"
+"Là où les suppressions doivent être performantes, nous recommandons pour les "
+"systèmes de définir toutes les clés <literal>on-delete=\"cascade\"</"
 "literal>, ainsi Hibernate utilisera une contrainte <literal>ON CASCADE "
 "DELETE</literal> au niveau base de données, plutôt que de nombreux "
 "<literal>DELETE</literal> individuels. Attention, cette fonctionnalité court-"
 "circuite la stratégie habituelle de verrou optimiste pour les données "
-"versionnées."
+"versionnées. "
 
 #. Tag: para
-#: basic_mapping.xml:2362
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>not-null</literal> and <literal>update</literal> attributes are "
 "useful when mapping a unidirectional one-to-many association. If you map a "
@@ -4499,88 +3307,59 @@
 "null=\"true\"&gt;</literal>."
 msgstr ""
 "Les attributs <literal>not-null</literal> et <literal>update</literal> sont "
-"utiles pour mapper une association one-to-many unidirectionnelle. Si vous "
-"mappez un one-to-many unidirectionnel vers une clef étrangère non nulle, "
-"vous <emphasis>devez</emphasis> déclarer la colonne de la clef en utilisant "
-"<literal>&lt;key not-null=\"true\"&gt;</literal>."
+"utiles pour mapper une association un-à-plusieurs unidirectionnelle. Si vous "
+"mappez un un-à-plusieurs unidirectionnel vers une clé étrangère non nulle, "
+"vous <emphasis>devez</emphasis> déclarer la colonne de la clé en utilisant "
+"<literal>&lt;key not-null=\"true\"&gt;</literal>. "
 
 #. Tag: title
-#: basic_mapping.xml:2372
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Column and formula elements"
-msgstr "éléments column et formula"
+msgstr "Éléments column et formula "
 
 #. Tag: para
-#: basic_mapping.xml:2373
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Mapping elements which accept a <literal>column</literal> attribute will "
 "alternatively accept a <literal>&lt;column&gt;</literal> subelement. "
 "Likewise, <literal>&lt;formula&gt;</literal> is an alternative to the "
 "<literal>formula</literal> attribute. For example:"
 msgstr ""
-"Tout élément de mapping qui accepte un attribut <literal>column</literal> "
+"Tout élément de mappage qui accepte un attribut <literal>column</literal> "
 "acceptera alternativement un sous-élément <literal>&lt;column&gt;</literal>. "
-"De façon identique, <literal>&lt;formula&gt;</literal> est une alternative à "
-"l'attribut <literal>formula</literal>."
+"Pareillement <literal>&lt;formula&gt;</literal> est une alternative à "
+"l'attribut <literal>formula</literal>. Par exemple :"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2379
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<column\n"
-"        name=\"column_name\"\n"
-"        length=\"N\"\n"
-"        precision=\"N\"\n"
-"        scale=\"N\"\n"
-"        not-null=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        unique-key=\"multicolumn_unique_key_name\"\n"
-"        index=\"index_name\"\n"
-"        sql-type=\"sql_type_name\"\n"
-"        check=\"SQL expression\"\n"
-"        default=\"SQL expression\"/>]]>"
+"Most of the attributes on <literal>column</literal> provide a means of "
+"tailoring the DDL during automatic schema generation. The <literal>read</"
+"literal> and <literal>write</literal> attributes allow you to specify custom "
+"SQL that Hibernate will use to access the column's value. For more on this, "
+"see the discussion of <link linkend=\"mapping-column-read-and-write\">column "
+"read and write expressions</link>."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2381
-#, no-c-format
-msgid "<![CDATA[<formula>SQL expression</formula>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2383
 #, fuzzy, no-c-format
 msgid ""
-"<literal>column</literal> and <literal>formula</literal> attributes can even "
-"be combined within the same property or association mapping to express, for "
-"example, exotic join conditions."
+"The <literal>column</literal> and <literal>formula</literal> elements can "
+"even be combined within the same property or association mapping to express, "
+"for example, exotic join conditions."
 msgstr ""
 "Les attributs <literal>column</literal> et <literal>formula</literal> "
-"peuvent même être combinés au sein d'une même propriété ou mapping "
+"peuvent même être combinés au sein d'une même propriété ou mappage "
 "d'association pour exprimer, par exemple, des conditions de jointure "
-"exotiques."
+"exotiques. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2389
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"homeAddress\" class=\"Address\"\n"
-"        insert=\"false\" update=\"false\">\n"
-"    <column name=\"person_id\" not-null=\"true\" length=\"10\"/>\n"
-"    <formula>'MAILING'</formula>\n"
-"</many-to-one>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:2394
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Import"
-msgstr "import"
+msgstr "Import"
 
 #. Tag: para
-#: basic_mapping.xml:2396
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your application has two persistent classes with the same name, and you "
 "do not want to specify the fully qualified package name in Hibernate "
@@ -4589,54 +3368,34 @@
 "interfaces that are not explicitly mapped:"
 msgstr ""
 "Supposez que votre application possède deux classes persistantes du même "
-"nom, et vous ne voulez pas préciser le nom Java complet (packages inclus) "
-"dans les queries Hibernate. Les classes peuvent alors être \"importées\" "
+"nom, et vous ne voulez pas préciser le nom Java complet (paquetage) dans les "
+"requêtes Hibernate. Les classes peuvent alors être \"importées\" "
 "explicitement plutôt que de compter sur <literal>auto-import=\"true\"</"
 "literal>.Vous pouvez même importer des classes et interfaces qui ne sont pas "
-"mappées explicitement."
+"mappées explicitement :"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2403
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[<import class=\"java.lang.Object\" rename=\"Universe\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2410
-#, no-c-format
 msgid ""
-"<![CDATA[<import\n"
-"        class=\"ClassName\"\n"
-"        rename=\"ShortName\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2413
-#, fuzzy, no-c-format
-msgid ""
 "<literal>class</literal>: the fully qualified class name of any Java class."
-msgstr "<literal>class</literal> : Nom Java complet de la classe."
+msgstr "<literal>class</literal> : nom complet de toute classe Java. "
 
 #. Tag: para
-#: basic_mapping.xml:2418
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>rename</literal> (optional - defaults to the unqualified class "
 "name): a name that can be used in the query language."
 msgstr ""
 "<literal>rename</literal> (optionnel - par défaut vaut le nom de la classe "
-"Java (sans package)) : Nom pouvant être utilisé dans le langage de requête."
+"non qualifié): nom pouvant être utilisé dans le langage de requête. "
 
 #. Tag: title
-#: basic_mapping.xml:2429
 #, no-c-format
-msgid "<title>Any</title>"
-msgstr ""
+msgid "Any"
+msgstr "Any"
 
 #. Tag: para
-#: basic_mapping.xml:2431
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is one more type of property mapping. The <literal>&lt;any&gt;</"
 "literal> mapping element defines a polymorphic association to classes from "
@@ -4647,20 +3406,19 @@
 "mapping polymorphic associations and you should use this only in special "
 "cases. For example, for audit logs, user session data, etc."
 msgstr ""
-"Il existe encore un type de mapping de propriété. L'élément de mapping "
+"Il existe encore un type de mappage de propriété. L'élément de mappage "
 "<literal>&lt;any&gt;</literal> définit une association polymorphique vers "
-"des classes de tables multiples. Ce type de mapping requiert toujours plus "
+"des classes de tables multiples. Ce type de mappage requiert toujours plus "
 "d'une colonne. La première colonne contient le type de l'entité associée. "
-"Les colonnes restantes contiennent l'identifiant. il est impossible de "
-"spécifier une contrainte de clef étrangère pour ce type d'association, donc "
+"Les colonnes restantes contiennent l'identifiant. Il est impossible de "
+"spécifier une contrainte de clé étrangère pour ce type d'association, donc "
 "ce n'est certainement pas considéré comme le moyen habituel de mapper des "
-"associations (polymorphiques). Vous devriez utiliser cela uniquement dans "
-"des cas particuliers (par exemple des logs d'audit, des données de session "
-"utilisateur, etc...)."
+"associations (polymorphiques). Ne doit être utilisé que dans des cas "
+"particuliers (par exemple des logs d'audit, des données de session "
+"utilisateur, etc...). "
 
 #. Tag: para
-#: basic_mapping.xml:2441
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>meta-type</literal> attribute allows the application to specify "
 "a custom type that maps database column values to persistent classes that "
@@ -4669,80 +3427,41 @@
 "names."
 msgstr ""
 "L'attribut <literal>meta-type</literal> permet à l'application de spécifier "
-"un type personnalisé qui mappe des valeurs de colonnes de le base de données "
+"un type personnalisé qui mappe des valeurs de colonnes de base de données "
 "sur des classes persistantes qui ont un attribut identifiant du type "
-"spécifié par <literal>id-type</literal>. Vous devez spécifier le mapping à "
-"partir de valeurs du méta-type sur les noms des classes."
+"spécifié par <literal>id-type</literal>. Vous devez spécifier le mappage à "
+"partir de valeurs du méta-type sur les noms des classes. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2448
-#, no-c-format
-msgid ""
-"<![CDATA[<any name=\"being\" id-type=\"long\" meta-type=\"string\">\n"
-"    <meta-value value=\"TBL_ANIMAL\" class=\"Animal\"/>\n"
-"    <meta-value value=\"TBL_HUMAN\" class=\"Human\"/>\n"
-"    <meta-value value=\"TBL_ALIEN\" class=\"Alien\"/>\n"
-"    <column name=\"table_name\"/>\n"
-"    <column name=\"id\"/>\n"
-"</any>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2459
-#, no-c-format
-msgid ""
-"<![CDATA[<any\n"
-"        name=\"propertyName\"\n"
-"        id-type=\"idtypename\"\n"
-"        meta-type=\"metatypename\"\n"
-"        cascade=\"cascade_style\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        optimistic-lock=\"true|false\"\n"
-">\n"
-"        <meta-value ... />\n"
-"        <meta-value ... />\n"
-"        .....\n"
-"        <column .... />\n"
-"        <column .... />\n"
-"        .....\n"
-"</any>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2462
 #, no-c-format
 msgid "<literal>name</literal>: the property name."
-msgstr "<literal>name</literal> : le nom de la propriété."
+msgstr "<literal>name</literal> : le nom de la propriété. "
 
 #. Tag: para
-#: basic_mapping.xml:2467
 #, no-c-format
 msgid "<literal>id-type</literal>: the identifier type."
 msgstr "<literal>id-type</literal> : le type identifiant."
 
 #. Tag: para
-#: basic_mapping.xml:2472
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>meta-type</literal> (optional - defaults to <literal>string</"
 "literal>): any type that is allowed for a discriminator mapping."
 msgstr ""
 "<literal>meta-type</literal> (optionnel - par défaut à <literal>string</"
-"literal>) : Tout type permis pour un mapping par discriminateur."
+"literal>) : tout type permis pour un mappage par discriminateur."
 
 #. Tag: para
-#: basic_mapping.xml:2478
 #, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional- defaults to <literal>none</literal>): "
 "the cascade style."
 msgstr ""
 "<literal>cascade</literal> (optionnel - par défaut à <literal>none</"
-"literal>) : le style de cascade."
+"literal>) : le style de cascade. "
 
 #. Tag: para
-#: basic_mapping.xml:2490
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to this property either do or do not "
@@ -4750,33 +3469,32 @@
 "increment should occur if this property is dirty."
 msgstr ""
 "<literal>optimistic-lock</literal> (optionnel - par défaut à <literal>true</"
-"literal>) : Indique que les mises à jour sur cette propriété nécessitent ou "
+"literal>) : indique si les mise à jour sur cette propriété nécessitent ou "
 "non l'acquisition d'un verrou optimiste. En d'autres termes, définit si un "
-"incrément de version doit avoir lieu quand cette propriété est marquée dirty."
+"incrément de version doit avoir lieu quand cette propriété est marquée "
+"dirty. "
 
 #. Tag: title
-#: basic_mapping.xml:2505
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Hibernate types"
-msgstr "Hibernate Types"
+msgstr "Types Hibernate "
 
 #. Tag: title
-#: basic_mapping.xml:2508
 #, no-c-format
 msgid "Entities and values"
 msgstr "Entités et valeurs"
 
 #. Tag: para
-#: basic_mapping.xml:2510
 #, no-c-format
 msgid ""
 "In relation to the persistence service, Java language-level objects are "
 "classified into two groups:"
 msgstr ""
+"Pour le service de persistance, les objets sont classés en deux groupes au "
+"niveau langage Java :"
 
 #. Tag: para
-#: basic_mapping.xml:2515
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An <emphasis>entity</emphasis> exists independently of any other objects "
 "holding references to the entity. Contrast this with the usual Java model, "
@@ -4789,19 +3507,18 @@
 "also be versioned."
 msgstr ""
 "Une <emphasis>entité</emphasis> existe indépendamment de tout autre objet "
-"possédant une référence vers l'entité. Comparez cela avec le modèle Java "
+"possédant des références vers l'entité. Comparez cela avec le modèle Java "
 "habituel où un objet est supprimé par le garbage collector dès qu'il n'est "
 "plus référencé. Les entités doivent être explicitement enregistrées et "
 "supprimées (sauf dans les cas où sauvegardes et suppressions sont "
-"<emphasis>cascadées</emphasis> d'une entité mère vers ses enfants). C'est "
+"<emphasis>cascadées</emphasis> d'une entité parent vers ses enfants). C'est "
 "différent du modèle ODMG de persistance par atteignabilité - et correspond "
 "mieux à la façon dont les objets sont habituellement utilisés dans des "
 "grands systèmes. Les entités permettent les références circulaires et "
 "partagées. Elles peuvent aussi être versionnées."
 
 #. Tag: para
-#: basic_mapping.xml:2526
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An entity's persistent state consists of references to other entities and "
 "instances of <emphasis>value</emphasis> types. Values are primitives: "
@@ -4818,15 +3535,14 @@
 "des types primitifs, des collections (et non le contenu d'une collection), "
 "des composants de certains objets immuables. Contrairement aux entités, les "
 "valeurs (et en particulier les collections et composants) <emphasis>sont</"
-"emphasis> persistés par atteignabiliité. Comme les valeurs (et types "
-"primitifs) sont persistés et supprimés avec l'entité qui les contient, ils "
-"ne peuvent pas posséder leurs propres versions. Les valeurs n'ont pas "
-"d'identité indépendantes, ainsi elles ne peuvent pas être partagées par deux "
-"entités ou collections."
+"emphasis> persistées et supprimées par atteignabiliité. Comme les valeurs "
+"(et types primitifs) sont persistées et supprimées avec l'entité qui les "
+"contient, ils ne peuvent pas posséder leurs propres versions. Les valeurs "
+"n'ont pas d'identité indépendantes, ainsi elles ne peuvent pas être "
+"partagées par deux entités ou collections. "
 
 #. Tag: para
-#: basic_mapping.xml:2537
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Until now, we have been using the term \"persistent class\" to refer to "
 "entities. We will continue to do that. Not all user-defined classes with a "
@@ -4844,26 +3560,25 @@
 "parler d'entités. Nous allons continuer à faire ainsi. Cependant, au sens "
 "strict, toutes les classes définies par un utilisateur possédant un état "
 "persistant ne sont pas des entités. Un <emphasis>composant</emphasis> est "
-"une classe définie par un utilisateur avec les caractéristiques d'une "
-"valeur. Une propriété Java de type <literal>java.lang.String</literal> a "
-"aussi les caractéristiques d'une valeur. Given this definition, we can say "
-"that all types (classes) provided by the JDK have value type semantics in "
-"Java, while user-defined types may be mapped with entity or value type "
-"semantics. This decision is up to the application developer. A good hint for "
-"an entity class in a domain model are shared references to a single instance "
-"of that class, while composition or aggregation usually translates to a "
-"value type."
+"une classe définie par un utilisateur avec la sémantique d'une valeur. Une "
+"propriété Java de type <literal>java.lang.String</literal> a aussi les "
+"caractéristiques d'une valeur. Selon cette définition, nous sommes en mesure "
+"de déclarer que tous les types (classes) fournis par JDK possèdent la "
+"sémantique d'une valeur dans Java, alors que les types définis par un "
+"utilisateur pourront être mappés avec des sémantiques entités ou valeur "
+"type. Cette décision est prise par le développeur d'application. Un bon "
+"conseil pour une classe entité dans un modèle de domaine sont des références "
+"partagées à une instance unique de cette classe, alors que la composition ou "
+"l'agrégation se traduit en général par une valeur type. "
 
 #. Tag: para
-#: basic_mapping.xml:2551
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "We will revisit both concepts throughout this reference guide."
 msgstr ""
-"Nous nous pencherons sur ces deux concepts tout au long de la documentation."
+"Nous nous pencherons sur ces deux concepts tout au long de la documentation. "
 
 #. Tag: para
-#: basic_mapping.xml:2555
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The challenge is to map the Java type system, and the developers' definition "
 "of entities and value types, to the SQL/database type system. The bridge "
@@ -4876,57 +3591,52 @@
 "for standard JDK value types out of the box. You can write your own mapping "
 "types and implement your own custom conversion strategies."
 msgstr ""
-"Le défi est de mapper les type Javas (et la définition des développeurs des "
+"Le défi est de mapper les types Javas (et la définition des développeurs des "
 "entités et valeurs types) sur les types du SQL ou des bases de données. Le "
 "pont entre les deux systèmes est proposé par Hibernate : pour les entités "
 "nous utilisons <literal>&lt;class&gt;</literal>, <literal>&lt;subclass&gt;</"
 "literal> et ainsi de suite. Pour les types valeurs nous utilisons "
 "<literal>&lt;property&gt;</literal>, <literal>&lt;component&gt;</literal>, "
 "etc., habituellement avec un attribut <literal>type</literal>. La valeur de "
-"cet attribut est le nom d'un <emphasis>type de mapping</emphasis> Hibernate. "
-"Hibernate propose de base de nombreux mappings (pour les types de valeurs "
-"standards du JDK). Vous pouvez écrire vos propres types de mappings et "
-"implémenter aussi vos propres stratégies de conversion, nous le verrons plus "
-"tard."
+"cet attribut est le nom d'un <emphasis>type de mappage</emphasis> Hibernate. "
+"Hibernate propose de nombreux mappages prêts à l'utilisation (pour les types "
+"de valeurs standards du JDK). Vous pouvez écrire vos propres types de "
+"mappages et implémenter aussi vos propres stratégies de conversion comme "
+"nous le verrons plus tard. "
 
 #. Tag: para
-#: basic_mapping.xml:2568
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "With the exception of collections, all built-in Hibernate types support null "
 "semantics."
 msgstr ""
-"Tous les types proposés de base par Hibernate à part les collections "
-"autorisent la valeur null."
+"Tous les types proposés Hibernate à part les collections autorisent les "
+"sémantiques null. "
 
 #. Tag: title
-#: basic_mapping.xml:2575
 #, no-c-format
 msgid "Basic value types"
-msgstr "Basic value types"
+msgstr "Types valeurs de base "
 
 #. Tag: para
-#: basic_mapping.xml:2577
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The built-in <emphasis>basic mapping types</emphasis> can be roughly "
 "categorized into the following:"
 msgstr ""
-"Les <emphasis>types basiques de mapping</emphasis> proposés de base peuvent "
-"grossièrement être rangés dans les catégories suivantes : <placeholder-1/>"
+"Les <emphasis>types de mappage de base</emphasis> peuvent être classés de la "
+"façon suivante :"
 
-#. Tag: literal
-#: basic_mapping.xml:2582
+#. Tag: term
 #, no-c-format
 msgid ""
-"integer, long, short, float, double, character, byte, boolean, yes_no, "
-"true_false"
+"<literal>integer, long, short, float, double, character, byte, boolean, "
+"yes_no, true_false</literal>"
 msgstr ""
-"integer, long, short, float, double, character, byte, boolean, yes_no, "
-"true_false"
+"<literal>integer, long, short, float, double, character, byte, boolean, "
+"yes_no, true_false</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2585
 #, no-c-format
 msgid ""
 "Type mappings from Java primitives or wrapper classes to appropriate (vendor-"
@@ -4934,88 +3644,78 @@
 "<literal>true_false</literal> are all alternative encodings for a Java "
 "<literal>boolean</literal> or <literal>java.lang.Boolean</literal>."
 msgstr ""
-"Les mappings de type des primitives Java ou leurs classes wrappers (ex: "
-"Integer pour int) vers les types SQL (propriétaires) appropriés. "
+"Les mappages de type des primitives Java ou leurs classes wrappers (ex : "
+"Integer pour int) vers les types de colonne SQL (propriétaires) appropriés. "
 "<literal>boolean, yes_no</literal>et <literal>true_false</literal> sont tous "
 "des alternatives pour les types Java <literal>boolean</literal> ou "
 "<literal>java.lang.Boolean</literal>."
 
-#. Tag: literal
-#: basic_mapping.xml:2594
+#. Tag: term
 #, no-c-format
-msgid "string"
-msgstr "string"
+msgid "<literal>string</literal>"
+msgstr "<literal>string</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2596
 #, no-c-format
 msgid ""
 "A type mapping from <literal>java.lang.String</literal> to <literal>VARCHAR</"
 "literal> (or Oracle <literal>VARCHAR2</literal>)."
 msgstr ""
-"Mapping de type de <literal>java.lang.String</literal> vers "
+"Mappage de type de <literal>java.lang.String</literal> vers "
 "<literal>VARCHAR</literal> (ou le <literal>VARCHAR2</literal> Oracle)."
 
-#. Tag: literal
-#: basic_mapping.xml:2603
+#. Tag: term
 #, no-c-format
-msgid "date, time, timestamp"
-msgstr "date, time, timestamp"
+msgid "<literal>date, time, timestamp</literal>"
+msgstr "<literal>date, time, timestamp</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2605
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Date</literal> and its subclasses to "
 "SQL types <literal>DATE</literal>, <literal>TIME</literal> and "
 "<literal>TIMESTAMP</literal> (or equivalent)."
 msgstr ""
-"Mappings de type pour <literal>java.util.Date</literal> et ses sous-classes "
+"mappages de type pour <literal>java.util.Date</literal> et ses sous-classes "
 "vers les types SQL <literal>DATE</literal>, <literal>TIME</literal> et "
 "<literal>TIMESTAMP</literal> (ou équivalent)."
 
-#. Tag: literal
-#: basic_mapping.xml:2613
+#. Tag: term
 #, no-c-format
-msgid "calendar, calendar_date"
-msgstr "calendar, calendar_date"
+msgid "<literal>calendar, calendar_date</literal>"
+msgstr "<literal>calendar, calendar_date</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2615
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Calendar</literal> to SQL types "
 "<literal>TIMESTAMP</literal> and <literal>DATE</literal> (or equivalent)."
 msgstr ""
-"Mappings de type pour <literal>java.util.Calendar</literal> vers les types "
+"mappages de type pour <literal>java.util.Calendar</literal> vers les types "
 "SQL <literal>TIMESTAMP</literal> et <literal>DATE</literal> (ou équivalent)."
 
-#. Tag: literal
-#: basic_mapping.xml:2623
+#. Tag: term
 #, no-c-format
-msgid "big_decimal, big_integer"
-msgstr "big_decimal, big_integer"
+msgid "<literal>big_decimal, big_integer</literal>"
+msgstr "<literal>big_decimal, big_integer</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2625
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.math.BigDecimal</literal> and <literal>java."
 "math.BigInteger</literal> to <literal>NUMERIC</literal> (or Oracle "
 "<literal>NUMBER</literal>)."
 msgstr ""
-"Mappings de type pour <literal>java.math.BigDecimal</literal> et "
-"<literal>java.math.BigInteger</literal> vers <literal>NUMERIC</literal> (ou "
-"le <literal>NUMBER</literal> Oracle)."
+"mappages de type de <literal>java.math.BigDecimal</literal> et <literal>java."
+"math.BigInteger</literal> vers <literal>NUMERIC</literal> (ou le "
+"<literal>NUMBER</literal> Oracle)."
 
-#. Tag: literal
-#: basic_mapping.xml:2633
+#. Tag: term
 #, no-c-format
-msgid "locale, timezone, currency"
-msgstr "locale, timezone, currency"
+msgid "<literal>locale, timezone, currency</literal>"
+msgstr "<literal>locale, timezone, currency</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2635
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Locale</literal>, <literal>java.util."
@@ -5025,51 +3725,45 @@
 "mapped to their ISO codes. Instances of <literal>TimeZone</literal> are "
 "mapped to their <literal>ID</literal>."
 msgstr ""
-"Mappings de type pour <literal>java.util.Locale</literal>, <literal>java."
+"mappages de type pour <literal>java.util.Locale</literal>, <literal>java."
 "util.TimeZone</literal> et <literal>java.util.Currency</literal> vers "
 "<literal>VARCHAR</literal> (ou le <literal>VARCHAR2</literal> Oracle). Les "
 "instances de <literal>Locale</literal> et <literal>Currency</literal> sont "
 "mappées sur leurs codes ISO. Les instances de <literal>TimeZone</literal> "
 "sont mappées sur leur <literal>ID</literal>."
 
-#. Tag: literal
-#: basic_mapping.xml:2647
+#. Tag: term
 #, no-c-format
-msgid "class"
-msgstr "class"
+msgid "<literal>class</literal>"
+msgstr "<literal>class</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2649
 #, no-c-format
 msgid ""
 "A type mapping from <literal>java.lang.Class</literal> to <literal>VARCHAR</"
 "literal> (or Oracle <literal>VARCHAR2</literal>). A <literal>Class</literal> "
 "is mapped to its fully qualified name."
 msgstr ""
-"Un type de mapping pour <literal>java.lang.Class</literal> vers "
+"Un type de mappage de <literal>java.lang.Class</literal> vers "
 "<literal>VARCHAR</literal> (ou le <literal>VARCHAR2</literal> Oracle). Un "
 "objet <literal>Class</literal> est mappé sur son nom Java complet."
 
-#. Tag: literal
-#: basic_mapping.xml:2657
+#. Tag: term
 #, no-c-format
-msgid "binary"
-msgstr "binary"
+msgid "<literal>binary</literal>"
+msgstr "<literal>binary</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2659
 #, no-c-format
 msgid "Maps byte arrays to an appropriate SQL binary type."
 msgstr "Mappe les tableaux de bytes vers le type binaire SQL approprié."
 
-#. Tag: literal
-#: basic_mapping.xml:2665
+#. Tag: term
 #, no-c-format
-msgid "text"
-msgstr "text"
+msgid "<literal>text</literal>"
+msgstr "<literal>text</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2667
 #, no-c-format
 msgid ""
 "Maps long Java strings to a SQL <literal>CLOB</literal> or <literal>TEXT</"
@@ -5078,15 +3772,13 @@
 "Mappe les longues chaînes de caractères Java vers les types SQL "
 "<literal>CLOB</literal> ou <literal>TEXT</literal>."
 
-#. Tag: literal
-#: basic_mapping.xml:2674
+#. Tag: term
 #, no-c-format
-msgid "serializable"
-msgstr "serializable"
+msgid "<literal>serializable</literal>"
+msgstr "<literal>serializable</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2676
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Maps serializable Java types to an appropriate SQL binary type. You can also "
 "indicate the Hibernate type <literal>serializable</literal> with the name of "
@@ -5095,42 +3787,38 @@
 "Mappe les types Java sérialisables vers le type SQL binaire approprié. Vous "
 "pouvez aussi indiquer le type Hibernate <literal>serializable</literal> avec "
 "le nom d'une classe Java sérialisable ou une interface qui ne soit pas par "
-"défaut un type de base."
+"défaut un type de base. "
 
-#. Tag: literal
-#: basic_mapping.xml:2685
+#. Tag: term
 #, no-c-format
-msgid "clob, blob"
-msgstr "clob, blob"
+msgid "<literal>clob, blob</literal>"
+msgstr "<literal>clob, blob</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2687
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Type mappings for the JDBC classes <literal>java.sql.Clob</literal> and "
 "<literal>java.sql.Blob</literal>. These types can be inconvenient for some "
 "applications, since the blob or clob object cannot be reused outside of a "
 "transaction. Driver support is patchy and inconsistent."
 msgstr ""
-"Mappings de type pour les classes JDBC <literal>java.sql.Clob</literal> and "
+"Mappages de type pour les classes JDBC <literal>java.sql.Clob</literal> et "
 "<literal>java.sql.Blob</literal>. Ces types peuvent ne pas convenir pour "
 "certaines applications car un objet blob ou clob peut ne pas être "
 "réutilisable en dehors d'une transaction (de plus l'implémentation par les "
-"pilotes est moyennement bonne)."
+"pilotes comporte des lacunes)."
 
-#. Tag: literal
-#: basic_mapping.xml:2697
+#. Tag: term
 #, no-c-format
 msgid ""
-"imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
-"imm_serializable, imm_binary"
+"<literal>imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
+"imm_serializable, imm_binary</literal>"
 msgstr ""
-"imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
-"imm_serializable, imm_binary"
+"<literal>imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
+"imm_serializable, imm_binary</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2701
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Type mappings for what are considered mutable Java types. This is where "
 "Hibernate makes certain optimizations appropriate only for immutable Java "
@@ -5140,17 +3828,17 @@
 "have that change made persistent, the application must assign a new, "
 "nonidentical, object to the property."
 msgstr ""
-"Mappings de type pour ceux qui sont habituellement modifiable, pour lesquels "
-"Hibernate effectue certains optimisations convenant seulement aux types Java "
-"immuables, et l'application les traite comme immuable. Par exemple, vous ne "
-"devriez pas appeler <literal>Date.setTime()</literal> sur une instance "
-"mappée sur un <literal>imm_timestamp</literal>. Pour changer la valeur de la "
-"propriété, et faire que cette modification soit persistée, l'application "
-"doit assigner un nouvel (non identique) objet à la propriété."
+"Mappages de type pour ceux qui sont habituellement considérés comme des "
+"types Java modifiables, et pour lesquels Hibernate effectue certaines "
+"optimisations convenant seulement aux types Java immuables. L'application "
+"les traite comme immuables. Par exemple, vous ne devriez pas appeler "
+"<literal>Date.setTime()</literal> sur une instance mappée sur un "
+"<literal>imm_timestamp</literal>. Pour changer la valeur de la propriété, et "
+"faire en sorte que cette modification soit persistée, l'application doit "
+"assigner un nouvel (non identique) objet à la propriété. "
 
 #. Tag: para
-#: basic_mapping.xml:2716
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Unique identifiers of entities and collections can be of any basic type "
 "except <literal>binary</literal>, <literal>blob</literal> and <literal>clob</"
@@ -5160,10 +3848,9 @@
 "Les identifiants uniques des entités et collections peuvent être de "
 "n'importe quel type de base excepté <literal>binary</literal>, "
 "<literal>blob</literal> et <literal>clob</literal> (les identifiants "
-"composites sont aussi permis, voir plus bas)."
+"composites sont aussi permis, voir plus bas). "
 
 #. Tag: para
-#: basic_mapping.xml:2722
 #, no-c-format
 msgid ""
 "The basic value types have corresponding <literal>Type</literal> constants "
@@ -5172,19 +3859,17 @@
 "type."
 msgstr ""
 "Les types de base des valeurs ont des <literal>Type</literal> constants "
-"correspondants définis dans <literal>org.hibernate.Hibernate</literal>. Par "
-"exemple, <literal>Hibernate.STRING</literal> représenté le type "
-"<literal>string</literal>."
+"correspondants et définis dans <literal>org.hibernate.Hibernate</literal>. "
+"Par exemple, <literal>Hibernate.STRING</literal> représente le type "
+"<literal>string</literal>. "
 
 #. Tag: title
-#: basic_mapping.xml:2731
 #, no-c-format
 msgid "Custom value types"
-msgstr "Types de valeur définis par l'utilisateur"
+msgstr "Types de valeur personnalisés"
 
 #. Tag: para
-#: basic_mapping.xml:2733
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is relatively easy for developers to create their own value types. For "
 "example, you might want to persist properties of type <literal>java.lang."
@@ -5197,19 +3882,18 @@
 "<literal>INITIAL</literal>, <literal>SURNAME</literal>."
 msgstr ""
 "Il est assez facile pour les développeurs de créer leurs propres types de "
-"valeurs. Par exemple, vous pourriez vouloir persister des propriétés du type "
-"<literal>java.lang.BigInteger</literal> dans des colonnnes <literal>VARCHAR</"
-"literal>. Hibernate ne procure pas par défaut un type pour cela. Mais les "
-"types que vous pouvez créer ne se limitent pas à mapper des propriétés (ou "
-"élément collection) à une simple colonne d'une table. Donc, par exemple, "
-"vous pourriez avoir une propriété Java <literal>getName()</literal>/"
+"valeurs. Par exemple, vous aimeriez persister des propriétés du type "
+"<literal>java.lang.BigInteger</literal> dans des colonnes <literal>VARCHAR</"
+"literal>. Hibernate ne procure pas de type par défaut à cet effet. "
+"Toutefois, les types personnalisés ne se limitent pas à mapper des "
+"propriétés (ou élément collection) à une simple colonne de table. Donc, par "
+"exemple, vous pourriez avoir une propriété Java <literal>getName()</literal>/"
 "<literal>setName()</literal> de type <literal>java.lang.String</literal> "
 "persistée dans les colonnes <literal>FIRST_NAME</literal>, <literal>INITIAL</"
-"literal>, <literal>SURNAME</literal>."
+"literal>, <literal>SURNAME</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:2744
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To implement a custom type, implement either <literal>org.hibernate."
 "UserType</literal> or <literal>org.hibernate.CompositeUserType</literal> and "
@@ -5220,32 +3904,19 @@
 "Pour implémenter votre propre type, vous pouvez soit implémenter "
 "<literal>org.hibernate.UserType</literal> soit <literal>org.hibernate."
 "CompositeUserType</literal> et déclarer des propriétés utilisant des noms de "
-"classes complets du type. Regardez <literal>org.hibernate.test."
-"DoubleStringType</literal> pour voir ce qu'il est possible de faire."
+"classes complets du type. Consultez <literal>org.hibernate.test."
+"DoubleStringType</literal> pour étudier les possibilités. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2752
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"twoStrings\" type=\"org.hibernate.test."
-"DoubleStringType\">\n"
-"    <column name=\"first_string\"/>\n"
-"    <column name=\"second_string\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2754
 #, no-c-format
 msgid ""
 "Notice the use of <literal>&lt;column&gt;</literal> tags to map a property "
 "to multiple columns."
 msgstr ""
-"Remarquez l'utilisation des tags <literal>&lt;column&gt;</literal> pour "
+"Remarquez l'utilisation des balises <literal>&lt;column&gt;</literal> pour "
 "mapper une propriété sur des colonnes multiples."
 
 #. Tag: para
-#: basic_mapping.xml:2759
 #, no-c-format
 msgid ""
 "The <literal>CompositeUserType</literal>, <literal>EnhancedUserType</"
@@ -5255,12 +3926,11 @@
 msgstr ""
 "Les interfaces <literal>CompositeUserType</literal>, "
 "<literal>EnhancedUserType</literal>, <literal>UserCollectionType</literal>, "
-"et <literal>UserVersionType</literal> permettent des utilisations plus "
-"spécialisées."
+"et <literal>UserVersionType</literal> prennent en charge des utilisations "
+"plus spécialisées. "
 
 #. Tag: para
-#: basic_mapping.xml:2765
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can even supply parameters to a <literal>UserType</literal> in the "
 "mapping file. To do this, your <literal>UserType</literal> must implement "
@@ -5268,26 +3938,14 @@
 "To supply parameters to your custom type, you can use the <literal>&lt;"
 "type&gt;</literal> element in your mapping files."
 msgstr ""
-"Vous pouvez même donner des paramètres en indiquant <literal>UserType</"
-"literal> dans le fichier de mapping ; Pour cela, votre <literal>UserType</"
+"Vous pouvez même fournir des paramètres en indiquant <literal>UserType</"
+"literal> dans le fichier de mappage. À cet effet, votre <literal>UserType</"
 "literal> doit implémenter l'interface <literal>org.hibernate.usertype."
 "ParameterizedType</literal>. Pour spécifier des paramètres dans votre type "
 "propre, vous pouvez utiliser l'élément <literal>&lt;type&gt;</literal> dans "
-"vos fichiers de mapping."
+"vos fichiers de mappage. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2773
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"priority\">\n"
-"    <type name=\"com.mycompany.usertypes.DefaultValueIntegerType\">\n"
-"        <param name=\"default\">0</param>\n"
-"    </type>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2775
 #, no-c-format
 msgid ""
 "The <literal>UserType</literal> can now retrieve the value for the parameter "
@@ -5296,11 +3954,10 @@
 msgstr ""
 "Le <literal>UserType</literal> permet maintenant de récupérer la valeur pour "
 "le paramètre nommé <literal>default</literal> à partir de l'objet "
-"<literal>Properties</literal> qui lui est passé."
+"<literal>Properties</literal> qui lui est passé. "
 
 #. Tag: para
-#: basic_mapping.xml:2780
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you regularly use a certain <literal>UserType</literal>, it is useful to "
 "define a shorter name for it. You can do this using the <literal>&lt;"
@@ -5308,41 +3965,24 @@
 "can also contain a list of default parameter values if the type is "
 "parameterized."
 msgstr ""
-"Si vous utilisez fréquemment un <literal>UserType</literal>, cela peut être "
-"utile de lui définir un nom plus court. Vous pouvez faire cela en utilisant "
+"Si vous utilisez fréquemment un <literal>UserType</literal>, il est utile de "
+"lui définir un nom plus court. Vous pouvez l'effectuer, en utilisant "
 "l'élément <literal>&lt;typedef&gt;</literal>. Les typedefs permettent "
 "d'assigner un nom à votre type propre et peuvent aussi contenir une liste de "
-"valeurs de paramètres par défaut si ce type est paramétré."
+"valeurs de paramètres par défaut si ce type est paramétré. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2787
-#, no-c-format
-msgid ""
-"<![CDATA[<typedef class=\"com.mycompany.usertypes.DefaultValueIntegerType\" "
-"name=\"default_zero\">\n"
-"    <param name=\"default\">0</param>\n"
-"</typedef>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2789
-#, no-c-format
-msgid "<![CDATA[<property name=\"priority\" type=\"default_zero\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2791
 #, no-c-format
 msgid ""
 "It is also possible to override the parameters supplied in a typedef on a "
 "case-by-case basis by using type parameters on the property mapping."
 msgstr ""
-"Il est aussi possible de redéfinir les paramètres par défaut du typedef au "
-"cas par cas en utilisant des paramètres type sur le mapping de la propriété."
+"Il est également possible de redéfinir les paramètres par défaut du typedef "
+"au cas par cas en utilisant des paramètres type sur le mappage de la "
+"propriété. "
 
 #. Tag: para
-#: basic_mapping.xml:2796
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Even though Hibernate's rich range of built-in types and support for "
 "components means you will rarely need to use a custom type, it is considered "
@@ -5353,26 +3993,24 @@
 "is abstraction. With a custom type, your mapping documents would be "
 "protected against changes to the way monetary values are represented."
 msgstr ""
-"Bien que le fait que Hibernate propose de base une riche variété de types, "
-"et qu'il supporte les composants signifie que vous aurez très rarement "
-"<emphasis>besoin</emphasis> d'utiliser un nouveau type propre, il est "
-"néanmoins de bonne pratique d'utiliser des types propres pour les classes "
-"(non entités) qui apparaissent fréquemment dans votre application. Par "
-"exemple une classe <literal>MonetaryAmount</literal> est un bon candidat "
-"pour un <literal>CompositeUserType</literal> même s'il pourrait facilement "
-"être mappé comme un composant. Une motivation pour cela est l'abstraction. "
-"Avec un type propre vos documents de mapping sont à l'abri des changements "
-"futurs dans votre façon de représenter des valeurs monétaires."
+"Alors que Hibernate offre une riche variété de types, et la prise en charge "
+"des composants, vous aurez très rarement <emphasis>besoin</emphasis> "
+"d'utiliser un type personnalisé, il est néanmoins recommandé d'utiliser des "
+"types personnalisés pour les classes (non entités) qui apparaissent "
+"fréquemment dans votre application. Par exemple, une classe "
+"<literal>MonetaryAmount</literal> est un bon candidat pour un "
+"<literal>CompositeUserType</literal> même si elle pourrait facilement être "
+"mappée en tant que composant. Une motivation pour cela est l'abstraction. "
+"Avec un type personnalisé, vos documents de mappage sont à l'abri des "
+"changements futurs dans votre façon de représenter des valeurs monétaires. "
 
 #. Tag: title
-#: basic_mapping.xml:2812
 #, no-c-format
 msgid "Mapping a class more than once"
 msgstr "Mapper une classe plus d'une fois"
 
 #. Tag: para
-#: basic_mapping.xml:2813
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to provide more than one mapping for a particular persistent "
 "class. In this case, you must specify an <emphasis>entity name</emphasis> to "
@@ -5381,56 +4019,30 @@
 "entity name when working with persistent objects, when writing queries, or "
 "when mapping associations to the named entity."
 msgstr ""
-"Il est possible de proposer plus d'un mapping par classe persistante. Dans "
-"ce cas, vous devez spécifier un <emphasis>nom d'entité</emphasis> pour lever "
+"Il est possible de fournir plus d'un mappage par classe persistante. Dans ce "
+"cas, vous devez spécifier un <emphasis>nom d'entité</emphasis> pour lever "
 "l'ambiguité entre les instances des entités mappées (par défaut, le nom de "
 "l'entité est celui de la classe). Hibernate vous permet de spécifier le nom "
 "de l'entité lorsque vous utilisez des objets persistants, lorsque vous "
 "écrivez des requêtes ou quand vous mappez des associations vers les entités "
-"nommées."
+"nommées. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2821
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Contract\" table=\"Contracts\"\n"
-"        entity-name=\"CurrentContract\">\n"
-"    ...\n"
-"    <set name=\"history\" inverse=\"true\"\n"
-"            order-by=\"effectiveEndDate desc\">\n"
-"        <key column=\"currentContractId\"/>\n"
-"        <one-to-many entity-name=\"HistoricalContract\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Contract\" table=\"ContractHistory\"\n"
-"        entity-name=\"HistoricalContract\">\n"
-"    ...\n"
-"    <many-to-one name=\"currentContract\"\n"
-"            column=\"currentContractId\"\n"
-"            entity-name=\"CurrentContract\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2823
-#, fuzzy, no-c-format
-msgid ""
 "Associations are now specified using <literal>entity-name</literal> instead "
 "of <literal>class</literal>."
 msgstr ""
 "Remarquez comment les associations sont désormais spécifiées en utilisant "
-"<literal>entity-name</literal> au lieu de <literal>class</literal>."
+"<literal>entity-name</literal> au lieu de <literal>class</literal>. "
 
 #. Tag: title
-#: basic_mapping.xml:2831
 #, no-c-format
 msgid "SQL quoted identifiers"
 msgstr "SQL quoted identifiers"
 
 #. Tag: para
-#: basic_mapping.xml:2832
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can force Hibernate to quote an identifier in the generated SQL by "
 "enclosing the table or column name in backticks in the mapping document. "
@@ -5440,47 +4052,31 @@
 msgstr ""
 "Vous pouvez forcer Hibernate à mettre un identifiant entre quotes dans le "
 "SQL généré en mettant le nom de la table ou de la colonne entre backticks "
-"dans le document de mapping. Hibernate utilisera les bons styles de quotes "
-"pour le <literal>Dialect</literal> SQL (habituellement des doubles quotes, "
-"mais des parenthèses pour SQL server et des backticks pour MySQL)."
+"dans le document de mappage. Hibernate utilisera les bons styles de quotes "
+"pour le SQL <literal>Dialect</literal> (habituellement des doubles quotes, "
+"mais des parenthèses pour SQL Server et des backticks pour MySQL). "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2839
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"LineItem\" table=\"`Line Item`\">\n"
-"    <id name=\"id\" column=\"`Item Id`\"/><generator class=\"assigned\"/></"
-"id>\n"
-"    <property name=\"itemNumber\" column=\"`Item #`\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:2845
 #, no-c-format
 msgid "Metadata alternatives"
-msgstr "alternatives Metadata"
+msgstr "Métadonnées alternatives"
 
 #. Tag: para
-#: basic_mapping.xml:2847
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "XML does not suit all users so there are some alternative ways to define O/R "
 "mapping metadata in Hibernate."
 msgstr ""
 "XML ne convient pas à tout le monde, il y a donc des moyens alternatifs pour "
-"définir des metatda de mappings O/R dans Hibernate."
+"définir des métadonnées de mappage O/R dans Hibernate. "
 
 #. Tag: title
-#: basic_mapping.xml:2852
 #, no-c-format
 msgid "Using XDoclet markup"
-msgstr "utilisation de XDoclet"
+msgstr "Utilisation de XDoclet "
 
 #. Tag: para
-#: basic_mapping.xml:2854
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Many Hibernate users prefer to embed mapping information directly in "
 "sourcecode using XDoclet <literal>@hibernate.tags</literal>. We do not cover "
@@ -5489,138 +4085,26 @@
 "literal> class with XDoclet mappings:"
 msgstr ""
 "De nombreux utilisateurs de Hibernate préfèrent embarquer les informations "
-"de mappings directement au sein du code source en utilisant les tags XDoclet "
-"<literal>@hibernate.tags</literal>. Nous ne couvrons pas cette approche dans "
-"ce document cependant, puisque c'est considéré comme faisant partie de "
+"de mappages directement au sein du code source en utilisant lesbalises "
+"XDoclet <literal>@hibernate.tags</literal>. Nous ne couvrons pas cette "
+"approche dans ce document puisque cela est considéré comme faisant partie de "
 "XDoclet. Cependant, nous présentons l'exemple suivant de la classe "
-"<literal>Cat</literal> avec des mappings XDoclet."
+"<literal>Cat</literal> avec des mappages XDoclet :"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2861
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"import java.util.Date;\n"
-"\n"
-"/**\n"
-" * @hibernate.class\n"
-" *  table=\"CATS\"\n"
-" */\n"
-"public class Cat {\n"
-"    private Long id; // identifier\n"
-"    private Date birthdate;\n"
-"    private Cat mother;\n"
-"    private Set kittens\n"
-"    private Color color;\n"
-"    private char sex;\n"
-"    private float weight;\n"
-"\n"
-"    /*\n"
-"     * @hibernate.id\n"
-"     *  generator-class=\"native\"\n"
-"     *  column=\"CAT_ID\"\n"
-"     */\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"    private void setId(Long id) {\n"
-"        this.id=id;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.many-to-one\n"
-"     *  column=\"PARENT_ID\"\n"
-"     */\n"
-"    public Cat getMother() {\n"
-"        return mother;\n"
-"    }\n"
-"    void setMother(Cat mother) {\n"
-"        this.mother = mother;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"BIRTH_DATE\"\n"
-"     */\n"
-"    public Date getBirthdate() {\n"
-"        return birthdate;\n"
-"    }\n"
-"    void setBirthdate(Date date) {\n"
-"        birthdate = date;\n"
-"    }\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"WEIGHT\"\n"
-"     */\n"
-"    public float getWeight() {\n"
-"        return weight;\n"
-"    }\n"
-"    void setWeight(float weight) {\n"
-"        this.weight = weight;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"COLOR\"\n"
-"     *  not-null=\"true\"\n"
-"     */\n"
-"    public Color getColor() {\n"
-"        return color;\n"
-"    }\n"
-"    void setColor(Color color) {\n"
-"        this.color = color;\n"
-"    }\n"
-"    /**\n"
-"     * @hibernate.set\n"
-"     *  inverse=\"true\"\n"
-"     *  order-by=\"BIRTH_DATE\"\n"
-"     * @hibernate.collection-key\n"
-"     *  column=\"PARENT_ID\"\n"
-"     * @hibernate.collection-one-to-many\n"
-"     */\n"
-"    public Set getKittens() {\n"
-"        return kittens;\n"
-"    }\n"
-"    void setKittens(Set kittens) {\n"
-"        this.kittens = kittens;\n"
-"    }\n"
-"    // addKitten not needed by Hibernate\n"
-"    public void addKitten(Cat kitten) {\n"
-"        kittens.add(kitten);\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"SEX\"\n"
-"     *  not-null=\"true\"\n"
-"     *  update=\"false\"\n"
-"     */\n"
-"    public char getSex() {\n"
-"        return sex;\n"
-"    }\n"
-"    void setSex(char sex) {\n"
-"        this.sex=sex;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2863
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "See the Hibernate website for more examples of XDoclet and Hibernate."
 msgstr ""
-"Voyez le site web de Hibernate pour plus d'exemples sur XDoclet et Hibernate."
+"Voyez le site web de Hibernate pour plus d'exemples sur XDoclet et "
+"Hibernate. "
 
 #. Tag: title
-#: basic_mapping.xml:2870
 #, no-c-format
 msgid "Using JDK 5.0 Annotations"
 msgstr "Utilisation des annotations JDK 5.0"
 
 #. Tag: para
-#: basic_mapping.xml:2872
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "JDK 5.0 introduced XDoclet-style annotations at the language level that are "
 "type-safe and checked at compile time. This mechanism is more powerful than "
@@ -5635,71 +4119,39 @@
 msgstr ""
 "Le JDK 5.0 introduit des annotations proches de celles de XDoclet au niveau "
 "java, qui sont type-safe et vérifiées à la compilation. Ce mécanisme est "
-"plus puissant que XDoclet et mieux supporté par les outils et IDE. IntelliJ "
-"IDEA, par exemple, supporte l'auto-complétion et le surlignement syntaxique "
-"des annotations JDK 5.0. La nouvelle révision des spécifications des EJB "
-"(JSR-220) utilise les annotations JDK 5.0 comme mécanisme primaire pour les "
-"meta-données des beans entités. Hibernate3 implémente "
+"plus puissant que XDoclet et mieux supporté par les outils et les IDE. "
+"IntelliJ IDEA, par exemple, supporte l'auto-complétion et le surlignement "
+"syntaxique des annotations JDK 5.0. La nouvelle révision des spécifications "
+"des EJB (JSR-220) utilise les annotations JDK 5.0 comme mécanisme primaire "
+"pour les metadonnées des beans entités. Hibernate3 implémente "
 "l'<literal>EntityManager</literal> de la JSR-220 (API de persistance), le "
-"support du mapping de meta-données est disponible via le package "
+"support du mappage de métadonnées est disponible via le paquetage "
 "<emphasis>Hibernate Annotations</emphasis>, en tant que module séparé à "
-"télécharger. EJB3 (JSR-220) et les métadata Hibernate3 sont supportés."
+"télécharger. EJB3 (JSR-220) et les métadonnées Hibernate3 sont supportés. "
 
 #. Tag: para
-#: basic_mapping.xml:2883
 #, no-c-format
 msgid "This is an example of a POJO class annotated as an EJB entity bean:"
 msgstr "Ceci est un exemple d'une classe POJO annotée comme un EJB entité :"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2887
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[@Entity(access = AccessType.FIELD)\n"
-"public class Customer implements Serializable {\n"
-"\n"
-"    @Id;\n"
-"    Long id;\n"
-"\n"
-"    String firstName;\n"
-"    String lastName;\n"
-"    Date birthday;\n"
-"\n"
-"    @Transient\n"
-"    Integer age;\n"
-"\n"
-"    @Embedded\n"
-"    private Address homeAddress;\n"
-"\n"
-"    @OneToMany(cascade=CascadeType.ALL)\n"
-"    @JoinColumn(name=\"CUSTOMER_ID\")\n"
-"    Set<Order> orders;\n"
-"\n"
-"    // Getter/setter and business methods\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2891
-#, fuzzy, no-c-format
-msgid ""
 "Support for JDK 5.0 Annotations (and JSR-220) is currently under "
 "development. Please refer to the Hibernate Annotations module for more "
 "details."
 msgstr ""
 "Notez que le support des annotations JDK 5.0 (et de la JSR-220) est encore "
 "en cours et n'est pas terminé. Référez vous au module Hibernate Annotation "
-"pour plus de détails."
+"pour plus d'informations. "
 
 #. Tag: title
-#: basic_mapping.xml:2901
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Generated properties"
-msgstr "Propriétés générées"
+msgstr "Propriétés générées "
 
 #. Tag: para
-#: basic_mapping.xml:2902
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Generated properties are properties that have their values generated by the "
 "database. Typically, Hibernate applications needed to <literal>refresh</"
@@ -5713,14 +4165,13 @@
 "par la base de données. Typiquement, les applications Hibernate avaient "
 "besoin d'invoquer <literal>refresh</literal> sur les instances qui "
 "contenaient des propriétés pour lesquelles la base de données générait des "
-"valeurs. Marquer les propriétés comme générées permet à l'application de "
-"déléguer cette responsabilité à Hibernate. Principalement, à chaque fois "
-"qu'Hibernate réalise une insertion ou une mise à jour en base de données "
-"pour une entité marquée comme telle, cela provoque immédiatement un select "
-"pour récupérer les valeurs générées."
+"valeurs. Marquer les propriétés comme générées, permet à l'application de "
+"déléguer cette responsabilité à Hibernate. Principalement, à chaque fois que "
+"Hibernate réalise un SQL INSERT ou UPDATE en base de données pour une entité "
+"marquée comme telle, cela provoque immédiatement un select pour récupérer "
+"les valeurs générées. "
 
 #. Tag: para
-#: basic_mapping.xml:2911
 #, fuzzy, no-c-format
 msgid ""
 "Properties marked as generated must additionally be non-insertable and non-"
@@ -5730,23 +4181,21 @@
 "can be marked as generated."
 msgstr ""
 "Les propriétés marquées comme générées doivent de plus ne pas être "
-"insérables et modifiables Seuls <xref linkend=\"mapping-declaration-version"
-"\">versions</xref>, <xref linkend=\"mapping-declaration-timestamp"
-"\">timestamps</xref>, et <xref linkend=\"mapping-declaration-property"
-"\">simple properties</xref> peuvent être marqués comme générées."
+"insérables et modifiables. Seules les versions <xref linkend=\"mapping-"
+"declaration-version\"/>, les timestamps <xref linkend=\"mapping-declaration-"
+"timestamp\"/>, et les propriétés simples <xref linkend=\"mapping-declaration-"
+"property\" /> peuvent être marqués comme générés. "
 
 #. Tag: para
-#: basic_mapping.xml:2918
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>never</literal> (the default): the given property value is not "
 "generated within the database."
 msgstr ""
-"<literal>never</literal> (par défaut) - indique la valeur de la propriété "
-"n'est pas générée dans la base de données."
+"<literal>never</literal> (par défaut) - indique que la valeur donnée de la "
+"propriété n'est pas générée dans la base de données. "
 
 #. Tag: para
-#: basic_mapping.xml:2922
 #, fuzzy, no-c-format
 msgid ""
 "<literal>insert</literal>: the given property value is generated on insert, "
@@ -5757,32 +4206,73 @@
 "not available."
 msgstr ""
 "<literal>insert</literal> - indique que la valeur de la propriété donnée est "
-"générée à l'insertion mais pas lors des futures mises à jour de "
+"générée à l'insertion mais pas lors des futures mise à jour de "
 "l'enregistrement. Les colonnes de type \"date de création\" sont le cas "
-"d'utilisation typique de cette option. Notez que même les propriétés <xref "
-"linkend=\"mapping-declaration-version\">version</xref> et <xref linkend="
-"\"mapping-declaration-timestamp\">timestamp</xref> peuvent être déclarées "
-"comme générées, cette option n'est pas disponible à cet endroit..."
+"d'utilisation typique de cette option. Notez que bien que la version <xref "
+"linkend=\"mapping-declaration-version\"/> et les propriétés timestamp <xref "
+"linkend=\"mapping-declaration-timestamp\" /> puissent être déclarées comme "
+"générées, cette option n'est pas disponible."
 
 #. Tag: para
-#: basic_mapping.xml:2930
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>always</literal>: the property value is generated both on insert "
 "and on update."
 msgstr ""
 "<literal>always</literal> - indique que la valeur de la propriété est "
-"générée à l'insert comme aux updates."
+"générée à l'insertion comme aux mise à jour. "
 
 #. Tag: title
-#: basic_mapping.xml:2937
-#, fuzzy, no-c-format
+#, no-c-format
+msgid "Column read and write expressions"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Hibernate allows you to customize the SQL it uses to read and write the "
+"values of columns mapped to <link linkend=\"mapping-declaration-property"
+"\">simple properties</link>. For example, if your database provides a set of "
+"data encryption functions, you can invoke them for individual columns like "
+"this: <programlisting role=\"XML\">&lt;property name=\"creditCardNumber"
+"\"&gt; &lt;column name=\"credit_card_num\" read=\"decrypt(credit_card_num)\" "
+"write=\"encrypt(?)\"/&gt; &lt;/property&gt;</programlisting>"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Hibernate applies the custom expressions automatically whenever the property "
+"is referenced in a query. This functionality is similar to a derived-"
+"property <literal>formula</literal> with two differences:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"The property is backed by one or more columns that are exported as part of "
+"automatic schema generation."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "The property is read-write, not read-only."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"The <literal>write</literal> expression, if specified, must contain exactly "
+"one '?' placeholder for the value."
+msgstr ""
+
+#. Tag: title
+#, no-c-format
 msgid "Auxiliary database objects"
-msgstr "Objets auxiliaires de la base de données"
+msgstr "Objets auxiliaires de la base de données "
 
 #. Tag: para
-#: basic_mapping.xml:2938
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Auxiliary database objects allow for the CREATE and DROP of arbitrary "
 "database objects. In conjunction with Hibernate's schema evolution tools, "
@@ -5794,144 +4284,41 @@
 "defining auxiliary database objects:"
 msgstr ""
 "Permettent les ordres CREATE et DROP d'objets arbitraire de la base de "
-"donnéées, en conjonction avec les outils Hibernate d'évolutions de schéma, "
+"données, en conjonction avec les outils Hibernate d'évolutions de schéma, "
 "pour permettre de définir complètement un schéma utilisateur au sein des "
-"fichiers de mapping Hibernate. Bien que conçu spécifiquement pour créer et "
-"supprimer des objets tels que des triggers et des procédures stockées, ou "
-"toute commande pouvant être exécutée via une méthode de <literal>java.sql."
-"Statement.execute()</literal> (ALTERs, INSERTS, etc). Il y a principalement "
-"deux modes pour définir les objets auxiliaires de base de données..."
+"fichiers de mappage Hibernate. Bien que conçu spécifiquement pour créer et "
+"supprimer des objets tels que les triggers et les procédures stockées, en "
+"réalité toute commande pouvant être exécutée via une méthode de "
+"<literal>java.sql.Statement.execute()</literal> (ALTERs, INSERTS, etc) est "
+"valable à cet endroit. Il y a principalement deux modes pour définir les "
+"objets auxiliaires de base de données :"
 
 #. Tag: para
-#: basic_mapping.xml:2947
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The first mode is to explicitly list the CREATE and DROP commands in the "
 "mapping file:"
 msgstr ""
 "Le premier mode est de lister explicitement les commandes CREATE et DROP "
-"dans le fichier de mapping:"
+"dans le fichier de mappage : "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2951
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <create>CREATE TRIGGER my_trigger ...</create>\n"
-"        <drop>DROP TRIGGER my_trigger</drop>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2952
-#, fuzzy, no-c-format
-msgid ""
 "The second mode is to supply a custom class that constructs the CREATE and "
 "DROP commands. This custom class must implement the <literal>org.hibernate."
 "mapping.AuxiliaryDatabaseObject</literal> interface."
 msgstr ""
-"Le second mode est de fournir une classe particulière qui connait comment "
-"construire les commandes CREATE et DROP. Cette classe particulière doit "
-"implémenter l'interface <literal>org.hibernate.mapping."
-"AuxiliaryDatabaseObject</literal>."
+"Le second mode est de fournir une classe personnalisée qui sait comment "
+"construire les commandes CREATE et DROP. Cette classe personnalisée doit "
+"implémenter l'interface <literal>org.hibernate.mappage."
+"AuxiliaryDatabaseObject</literal>. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2957
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <definition class=\"MyTriggerDefinition\"/>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2958
-#, fuzzy, no-c-format
-msgid ""
 "Additionally, these database objects can be optionally scoped so that they "
 "only apply when certain dialects are used."
 msgstr ""
-"Additionnellement, ces objets de base de données peuvent être "
-"optionnellement traités selon l'utilisation de dialectes particuliers.."
-
-#. Tag: programlisting
-#: basic_mapping.xml:2962
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <definition class=\"MyTriggerDefinition\"/>\n"
-"        <dialect-scope name=\"org.hibernate.dialect.Oracle9iDialect\"/>\n"
-"        <dialect-scope name=\"org.hibernate.dialect.Oracle10gDialect\"/>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#~ msgid ""
-#~ "<literal>type</literal> (optional): A name that indicates the Hibernate "
-#~ "type."
-#~ msgstr ""
-#~ "<literal>type</literal> (optionnel) : Nom indiquant le type Hibernate."
-
-#~ msgid ""
-#~ "<literal>cascade</literal> (optional): Specifies which operations should "
-#~ "be cascaded from the parent object to the associated object."
-#~ msgstr ""
-#~ "<literal>cascade</literal> (optionnel) : Indique quelles opérations "
-#~ "doivent être propagées de l'objet père vers les objets associés."
-
-#~ msgid ""
-#~ "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
-#~ "literal>): Specifies that updates to this property do or do not require "
-#~ "acquisition of the optimistic lock. In other words, dertermines if a "
-#~ "version increment should occur when this property is dirty."
-#~ msgstr ""
-#~ "<literal>optimistic-lock</literal> (optionnel - par défaut à "
-#~ "<literal>true</literal>) : Indique que les mises à jour de cette "
-#~ "propriété requièrent ou non l'acquisition d'un verrou optimiste. En "
-#~ "d'autres termes, détermine si un incrément de version doit avoir lieu "
-#~ "quand la propriété est marquée obsolète (dirty)."
-
-#~ msgid ""
-#~ "To understand the behaviour of various Java language-level objects with "
-#~ "respect to the persistence service, we need to classify them into two "
-#~ "groups:"
-#~ msgstr ""
-#~ "Pour comprendre le comportement des différents objets Java par rapport au "
-#~ "service de persistance, nous avons besoin de les classer en deux groupes :"
-
-#, fuzzy
-#~ msgid "<literal>class</literal>"
-#~ msgstr "<literal>all</literal> vérifie toutes les colonnes"
-
-#~ msgid "id"
-#~ msgstr "id"
-
-#~ msgid ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal>none</"
-#~ "literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers"
-#~ "\"/>"
-#~ msgstr ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal>none</"
-#~ "literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers"
-#~ "\"/>"
-
-#~ msgid ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal/>): See "
-#~ "<xref linkend=\"mapping-declaration-id-enhanced-optimizers\"/>"
-#~ msgstr ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal/>): See "
-#~ "<xref linkend=\"mapping-declaration-id-enhanced-optimizers\"/>"
-
-#~ msgid "key"
-#~ msgstr "key"
-
-#~ msgid "any"
-#~ msgstr "any"
+"De plus, ces objets de base de données peuvent être optionnellement traités "
+"selon l'utilisation de dialectes particuliers. "

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/batch.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/batch.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/batch.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,225 +1,134 @@
+# translation of batch.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: batch\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-04 17:03+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: batch.xml:29
 #, no-c-format
 msgid "Batch processing"
-msgstr "Traitement par paquet"
+msgstr "Traitement par lot"
 
 #. Tag: para
-#: batch.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A naive approach to inserting 100,000 rows in the database using Hibernate "
 "might look like this:"
 msgstr ""
 "Une approche naïve pour insérer 100 000 lignes dans la base de données en "
-"utilisant Hibernate pourrait ressembler à ça :"
+"utilisant Hibernate ressemblerait à : "
 
-#. Tag: programlisting
-#: batch.xml:36
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"}\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:38
-#, fuzzy, no-c-format
-msgid ""
 "This would fall over with an <literal>OutOfMemoryException</literal> "
 "somewhere around the 50,000th row. That is because Hibernate caches all the "
 "newly inserted <literal>Customer</literal> instances in the session-level "
 "cache. In this chapter we will show you how to avoid this problem."
 msgstr ""
 "Ceci devrait s'écrouler avec une <literal>OutOfMemoryException</literal> "
-"quelque part aux alentours de la 50 000ème ligne. C'est parce qu'Hibernate "
+"quelque part aux alentours de la 50 000ème ligne. C'est parce que Hibernate "
 "cache toutes les instances de <literal>Customer</literal> nouvellement "
-"insérées dans le cache de second niveau."
+"insérées dans le cache de second niveau. Dans ce chapitre, nous allons vous "
+"montrer comment éviter ce problème."
 
 #. Tag: para
-#: batch.xml:45
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are undertaking batch processing you will need to enable the use of "
 "JDBC batching. This is absolutely essential if you want to achieve optimal "
 "performance. Set the JDBC batch size to a reasonable number (10-50, for "
 "example):"
 msgstr ""
-"Dans ce chapitre nous montrerons comment éviter ce problème. D'abord, "
-"cependant, si vous faites des traitements par batch, il est absolument "
-"critique que vous activiez l'utilisation ds paquet JDBC (NdT : JDBC "
-"batching), si vous avez l'intention d'obtenir des performances raisonnables. "
-"Configurez la taille du paquet JDBC avec un nombre raisonnable (disons, 10-"
-"50) :"
+"Dans ce chapitre nous montrerons comment éviter ce problème. Mais tout "
+"d'abord, si vous faites des traitements par lot, il est absolument "
+"indispensable d'activer l'utilisation des lots JDBC, pour obtenir des "
+"performances raisonnables. Configurez la taille du lot JDBC à un nombre "
+"raisonnable (disons, 10-50) : "
 
-#. Tag: programlisting
-#: batch.xml:52
-#, no-c-format
-msgid "<![CDATA[hibernate.jdbc.batch_size 20]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate disables insert batching at the JDBC level transparently if you "
 "use an <literal>identity</literal> identifier generator."
 msgstr ""
-"Vous pourriez aussi vouloir faire cette sorte de travail dans un traitement "
-"où l'interaction avec le cache de second niveau est complètement désactivé :"
+"Notez que Hibernate désactive, de manière transparente, l'insertion par lot "
+"au niveau JDBC si vous utilisez un générateur d'identifiant de type "
+"<literal>identity</literal>. "
 
 #. Tag: para
-#: batch.xml:59
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also do this kind of work in a process where interaction with the "
 "second-level cache is completely disabled:"
-msgstr "Insertions en paquet"
-
-#. Tag: programlisting
-#: batch.xml:64
-#, no-c-format
-msgid "<![CDATA[hibernate.cache.use_second_level_cache false]]>"
 msgstr ""
+"Vous désirez peut-être effectuer ce genre de tâche dans un traitement où "
+"l'interaction avec le cache de second niveau est complètement désactivée :"
 
 #. Tag: para
-#: batch.xml:66
 #, no-c-format
 msgid ""
 "However, this is not absolutely necessary, since we can explicitly set the "
 "<literal>CacheMode</literal> to disable interaction with the second-level "
 "cache."
 msgstr ""
-"Lorsque vous rendez des nouveaux objets persistants, vous devez "
-"régulièrement appeler <literal>flush()</literal> et puis <literal>clear()</"
-"literal> sur la session, pour contrôler la taille du cache de premier niveau."
+"Toutefois ce n'est pas absolument nécessaire puisque nous pouvons configurer "
+"le <literal>CacheMode</literal> de façon à désactiver l'interaction avec le "
+"cache de second niveau."
 
 #. Tag: title
-#: batch.xml:72
 #, no-c-format
 msgid "Batch inserts"
-msgstr "Paquet de mises à jour"
+msgstr "Insertions en lot"
 
 #. Tag: para
-#: batch.xml:74
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When making new objects persistent <literal>flush()</literal> and then "
 "<literal>clear()</literal> the session regularly in order to control the "
 "size of the first-level cache."
 msgstr ""
-"Pour récupérer et mettre à jour des données les mêmes idées s'appliquent. En "
-"plus, vous avez besoin d'utiliser <literal>scroll()</literal> pour tirer "
-"partie des curseurs côté serveur pour les requêtes qui retournent beaucoup "
-"de lignes de données."
+"Lorsque vous rendez des nouveaux objets persistants, vous devez "
+"régulièrement appeler <literal>flush()</literal> et puis <literal>clear()</"
+"literal> sur la session, pour contrôler la taille du cache de premier "
+"niveau. "
 
-#. Tag: programlisting
-#: batch.xml:80
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"    if ( i % 20 == 0 ) { //20, same as the JDBC batch size\n"
-"        //flush a batch of inserts and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: title
-#: batch.xml:85
 #, no-c-format
 msgid "Batch updates"
-msgstr "L'interface StatelessSession"
+msgstr "Mise à jour des lots"
 
 #. Tag: para
-#: batch.xml:87
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For retrieving and updating data, the same ideas apply. In addition, you "
 "need to use <literal>scroll()</literal> to take advantage of server-side "
 "cursors for queries that return many rows of data."
 msgstr ""
-"Alternativement, Hibernate fournit une API orientée commande qui peut être "
-"utilisée avec des flux de données pour et en provenance de la base de "
-"données sous la forme d'objets détachés. Une <literal>StatelessSession</"
-"literal> n'a pas de contexte de persistance associé et ne fournit pas "
-"beaucoup de sémantique de durée de vie de haut niveau. En particulier, une "
-"session sans état n'implémente pas de cache de premier niveau et n'interagit "
-"pas non plus avec un cache de seconde niveau ou un cache de requêtes. Elle "
-"n'implémente pas les transactions ou la vérification sale automatique (NdT : "
-"automatic dirty checking). Les opérations réalisées avec une session sans "
-"état ne sont jamais répercutées en cascade sur les instances associées. Les "
-"collections sont ignorées par une session sans état. Les opérations "
-"exécutées via une session sans état outrepasse le modèle d'événements "
-"d'Hibernate et les intercepteurs. Les sessions sans état sont vulnérables "
-"aux effets de modification des données, ceci est dû au manque de cache de "
-"premier niveau. Une session sans état est une abstraction bas niveau, plus "
-"proche de la couche JDBC sous-jacente."
+"Pour récupérer et mettre à jour des données les mêmes idées s'appliquent. De "
+"plus, vous devez utiliser <literal>scroll()</literal> pour tirer partie des "
+"curseurs côté serveur pour les requêtes qui retournent beaucoup de lignes de "
+"données. "
 
-#. Tag: programlisting
-#: batch.xml:93
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-"    .setCacheMode(CacheMode.IGNORE)\n"
-"    .scroll(ScrollMode.FORWARD_ONLY);\n"
-"int count=0;\n"
-"while ( customers.next() ) {\n"
-"    Customer customer = (Customer) customers.get(0);\n"
-"    customer.updateStuff(...);\n"
-"    if ( ++count % 20 == 0 ) {\n"
-"        //flush a batch of updates and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: title
-#: batch.xml:98
 #, no-c-format
 msgid "The StatelessSession interface"
-msgstr ""
-"Notez que dans le code de l'exemple, les intances de <literal>Customer</"
-"literal> retournées par la requête sont immédiatement détachées. Elles ne "
-"sont jamais associées à un contexte de persistance."
+msgstr "L'interface StatelessSession"
 
 #. Tag: para
-#: batch.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, Hibernate provides a command-oriented API that can be used "
 "for streaming data to and from the database in the form of detached objects. "
@@ -235,47 +144,36 @@
 "effects. A stateless session is a lower-level abstraction that is much "
 "closer to the underlying JDBC."
 msgstr ""
-"Les opérations <literal>insert()</literal>, <literal>update()</literal> et "
-"<literal>delete()</literal> définies par l'interface "
-"<literal>StatelessSession</literal> sont considérées comme des opérations "
-"d'accès direct aux lignes de la base de données, ce qui résulte en une "
-"exécution immédiate du SQL <literal>INSERT</literal>, <literal>UPDATE</"
-"literal> ou <literal>DELETE</literal> respectif. De là, elles ont des "
-"sémantiques tres différentes des opérations <literal>save()</literal>, "
-"<literal>saveOrUpdate()</literal> et <literal>delete()</literal> définies "
-"par l'interface <literal>Session</literal>."
+"Alternativement, Hibernate fournit une API orientée commande qui peut être "
+"utilisée avec des flux de données vers et en provenance de la base de "
+"données sous la forme d'objets détachés. Une <literal>StatelessSession</"
+"literal> n'a pas de contexte de persistance associé et ne fournit pas "
+"beaucoup de sémantique de cycle de vie de haut niveau. En particulier, une "
+"session sans état n'implémente pas de cache de premier niveau et n'interagit "
+"pas non plus avec un cache de seconde niveau ou un cache de requêtes. Elle "
+"n'implémente pas les transactions ou la vérification sale automatique "
+"(automatic dirty checking). Les opérations réalisées avec une session sans "
+"état ne sont jamais répercutées en cascade sur les instances associées. Les "
+"collections sont ignorées par une session sans état. Les opérations "
+"exécutées via une session sans état outrepassent le modèle d'événements de "
+"Hibernate et les intercepteurs. Les sessions sans état sont vulnérables aux "
+"effets de réplication des données, ceci est dû au manque de cache de premier "
+"niveau. Une session sans état est une abstraction bas niveau, plus proche de "
+"la couche JDBC sous-jacente. "
 
-#. Tag: programlisting
-#: batch.xml:114
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[StatelessSession session = sessionFactory.openStatelessSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-"    .scroll(ScrollMode.FORWARD_ONLY);\n"
-"while ( customers.next() ) {\n"
-"    Customer customer = (Customer) customers.get(0);\n"
-"    customer.updateStuff(...);\n"
-"    session.update(customer);\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:116
-#, fuzzy, no-c-format
-msgid ""
 "In this code example, the <literal>Customer</literal> instances returned by "
 "the query are immediately detached. They are never associated with any "
 "persistence context."
-msgstr "Opérations de style DML"
+msgstr ""
+"Notez que dans le code de l'exemple, les instances de <literal>Customer</"
+"literal> retournées par la requête sont immédiatement détachées. Elles ne "
+"sont jamais associées à un contexte de persistance. "
 
 #. Tag: para
-#: batch.xml:122
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>insert(), update()</literal> and <literal>delete()</literal> "
 "operations defined by the <literal>StatelessSession</literal> interface are "
@@ -285,28 +183,22 @@
 "<literal>save(), saveOrUpdate()</literal> and <literal>delete()</literal> "
 "operations defined by the <literal>Session</literal> interface."
 msgstr ""
-"Comme déjà discuté avant, le mapping objet/relationnel automatique et "
-"transparent est intéressé par la gestion de l'état de l'objet. Ceci implique "
-"que l'état de l'objet est disponible en mémoire, d'où manipuler (en "
-"utilisant des expressions du langage de manipulation de données - "
-"<literal>Data Manipulation Language</literal> (DML) - SQL) les données "
-"directement dans la base n'affectera pas l'état en mémoire. Pourtant, "
-"Hibernate fournit des méthodes pour l'exécution d'expression DML de style "
-"SQL lesquelles sont réalisées à travers le langage de requête d'Hibernate "
-"(<xref linkend=\"queryhql\">HQL</xref>)."
+"Les opérations <literal>insert()</literal>, <literal>update()</literal> et "
+"<literal>delete()</literal> définies par l'interface "
+"<literal>StatelessSession</literal> sont considérées comme des opérations "
+"d'accès direct aux lignes de la base de données, ce qui résulte en une "
+"exécution immédiate du SQL <literal>INSERT</literal>, <literal>UPDATE</"
+"literal> ou <literal>DELETE</literal> respectivement. Ainsi, elles ont des "
+"sémantiques très différentes des opérations <literal>save()</literal>, "
+"<literal>saveOrUpdate()</literal> et <literal>delete()</literal> définies "
+"par l'interface <literal>Session</literal>."
 
 #. Tag: title
-#: batch.xml:135
 #, no-c-format
 msgid "DML-style operations"
-msgstr ""
-"La pseudo-syntaxe pour les expressions <literal>UPDATE</literal> et "
-"<literal>DELETE</literal> est : <literal>( UPDATE | DELETE ) FROM? "
-"EntityName (WHERE where_conditions)?</literal>. Certains points sont à "
-"noter :"
+msgstr "Opérations de style DML"
 
 #. Tag: para
-#: batch.xml:137
 #, fuzzy, no-c-format
 msgid ""
 "As already discussed, automatic and transparent object/relational mapping is "
@@ -318,111 +210,84 @@
 "Hibernate provides methods for bulk SQL-style DML statement execution that "
 "is performed through the Hibernate Query Language (<link linkend=\"queryhql"
 "\">HQL</link>)."
-msgstr "Dans la clause from, le mot-clef FROM est optionnel"
+msgstr ""
+"Comme mentionné auparavant, le mapping objet/relationnel automatique et "
+"transparent s'intéresse à la gestion de l'état de l'objet. Ceci implique que "
+"l'état de l'objet soit disponible en mémoire, c'est pourquoi manipuler (en "
+"utilisant des expressions SQL du langage de manipulation de données - "
+"<literal>Data Manipulation Language</literal> (DML) : les données "
+"<literal>INSERT</literal>, <literal>UPDATE</literal>, <literal>DELETE</"
+"literal>) directement dans la base n'affecteront pas l'état en mémoire. "
+"Cependant, Hibernate fournit des méthodes pour l'exécution d'expression DML "
+"de style SQL en gros, qui sont réalisées à travers le langage de requête de "
+"Hibernate, Hibernate Query Language (<xref linkend=\"queryhql\"/> HQL)."
 
 #. Tag: para
-#: batch.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The pseudo-syntax for <literal>UPDATE</literal> and <literal>DELETE</"
 "literal> statements is: <literal>( UPDATE | DELETE ) FROM? EntityName (WHERE "
 "where_conditions)?</literal>."
 msgstr ""
-"Il ne peut y avoir qu'une seule entité nommée dans la clause from ; elle "
-"peut optionnellement avoir un alias. Si le nom de l'entité a un alias, alors "
-"n'importe quelle référence de propriété doit être qualifiée en ayant un "
-"alias ; si le nom de l'entité n'a pas d'alias, alors il est illégal pour "
-"n'importe quelle référence de propriété d'être qualifiée."
+"La pseudo-syntaxe pour les expressions <literal>UPDATE</literal> et "
+"<literal>DELETE</literal> est : <literal>( UPDATE | DELETE ) FROM? "
+"EntityName (WHERE where_conditions)?</literal>. "
 
 #. Tag: para
-#: batch.xml:151
 #, no-c-format
 msgid "Some points to note:"
-msgstr ""
+msgstr "Certains points à noter :"
 
 #. Tag: para
-#: batch.xml:157
 #, no-c-format
 msgid "In the from-clause, the FROM keyword is optional"
-msgstr ""
-"Aucune jointure (implicite ou explicite) ne peut être spécifiée dans une "
-"requête HQL. Les sous-requêtes peuvent être utilisées dans la clause where ; "
-"les sous-requêtes, elles-mêmes, peuvent contenir des jointures."
+msgstr "Dans la clause from, le mot-clef FROM est optionnel"
 
 #. Tag: para
-#: batch.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There can only be a single entity named in the from-clause. It can, however, "
 "be aliased. If the entity name is aliased, then any property references must "
 "be qualified using that alias. If the entity name is not aliased, then it is "
 "illegal for any property references to be qualified."
-msgstr "La clause where est aussi optionnelle."
+msgstr ""
+"Il ne peut y avoir qu'une seule entité nommée dans la clause from ; elle "
+"peut optionnellement avoir un alias. Si le nom de l'entité a un alias, alors "
+"n'importe quelle référence de propriété doit être qualifiée en utilisant un "
+"alias ; si le nom de l'entité n'a pas d'alias, il sera illégal pour "
+"n'importe quelle référence de propriété d'être qualifiée."
 
 #. Tag: para
-#: batch.xml:170
 #, fuzzy, no-c-format
 msgid ""
 "No <link linkend=\"queryhql-joins-forms\">joins</link>, either implicit or "
 "explicit, can be specified in a bulk HQL query. Sub-queries can be used in "
 "the where-clause, where the subqueries themselves may contain joins."
 msgstr ""
-"Par exemple, pour exécuter un <literal>UPDATE</literal> HQL, utilisez la "
-"méthode <literal>Query.executeUpdate()</literal> (la méthode est données "
-"pour ceux qui sont familiers avec <literal>PreparedStatement.executeUpdate()"
-"</literal> de JDBC) :"
+"Aucune jointure <xref linkend=\"queryhql-joins-forms\" /> (implicite ou "
+"explicite) ne peut être spécifiée dans une requête HQL en gros. Les sous-"
+"requêtes peuvent être utilisées dans la clause where- ; les sous-requêtes, "
+"elles-mêmes, peuvent contenir des jointures."
 
 #. Tag: para
-#: batch.xml:177
 #, no-c-format
 msgid "The where-clause is also optional."
-msgstr ""
-"Pour exécuter un <literal>DELETE</literal> HQL, utilisez la même méthode "
-"<literal>Query.executeUpdate()</literal> :"
+msgstr "La clause where- est aussi optionnelle."
 
 #. Tag: para
-#: batch.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As an example, to execute an HQL <literal>UPDATE</literal>, use the "
 "<literal>Query.executeUpdate()</literal> method. The method is named for "
 "those familiar with JDBC's <literal>PreparedStatement.executeUpdate()</"
 "literal>:"
 msgstr ""
-"La valeur du <literal>int</literal> retourné par la méthode <literal>Query."
-"executeUpdate()</literal> indique le nombre d'entités affectées par "
-"l'opération. Considérez que cela peut ou pas corréler le nombre de lignes "
-"affectés dans la base de données. Une opération HQL pourrait entraîner "
-"l'exécution de multiples expressions SQL réelles, pour des classes filles "
-"mappées par jointure (NdT: join-subclass), par exemple. Le nombre retourné "
-"indique le nombre d'entités réelles affectées par l'expression. Retour à "
-"l'exemple de la classe fille mappée par jointure, un effacement d'une des "
-"classes filles peut réellement entraîner des suppressions pas seulement dans "
-"la table qui mappe la classe fille, mais aussi dans la table \"racine\" et "
-"potentillement dans les tables des classes filles plus bas dans la "
-"hiérarchie d'héritage."
+"Par exemple, pour exécuter un HQL <literal>UPDATE</literal>, utilisez la "
+"méthode <literal>Query.executeUpdate()</literal> (la méthode est données "
+"pour ceux qui connaissent <literal>PreparedStatement.executeUpdate()</"
+"literal> de JDBC) : "
 
-#. Tag: programlisting
-#: batch.xml:189
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlUpdate = \"update Customer c set c.name = :newName where c.name = :"
-"oldName\";\n"
-"// or String hqlUpdate = \"update Customer set name = :newName where name = :"
-"oldName\";\n"
-"int updatedEntities = s.createQuery( hqlUpdate )\n"
-"        .setString( \"newName\", newName )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:191
 #, fuzzy, no-c-format
 msgid ""
 "In keeping with the EJB3 specification, HQL <literal>UPDATE</literal> "
@@ -435,73 +300,39 @@
 "<literal>VERSIONED</literal> keyword after the <literal>UPDATE</literal> "
 "keyword."
 msgstr ""
-"La pseudo-syntaxe pour l'expression <literal>INSERT</literal> est : "
-"<literal>INSERT INTO EntityName properties_list select_statement</literal>. "
-"Quelques points sont à noter :"
+"Par défaut, les déclarations HQL <literal>UPDATE</literal>, n'affectent pas "
+"la version <xref linkend=\"mapping-declaration-version\"/> ou les valeurs "
+"<xref linkend=\"mapping-declaration-timestamp\" /> de propriétés timestamp "
+"pour les entités concernées; ceci est compatible avec la spécification EJB3. "
+"Toutefois, vous pouvez forcer Hibernate à mettre à jour les valeurs des "
+"propriétés <literal>version</literal> ou <literal>timestamp</literal> en "
+"utilisant le <literal>versioned update</literal>. Pour ce faire, ajoutez le "
+"mot clé <literal>VERSIONED</literal> après le mot clé <literal>UPDATE</"
+"literal>. "
 
-#. Tag: programlisting
-#: batch.xml:201
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"String hqlVersionedUpdate = \"update versioned Customer set name = :newName "
-"where name = :oldName\";\n"
-"int updatedEntities = s.createQuery( hqlUpdate )\n"
-"        .setString( \"newName\", newName )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:203
-#, fuzzy, no-c-format
-msgid ""
 "Custom version types, <literal>org.hibernate.usertype.UserVersionType</"
 "literal>, are not allowed in conjunction with a <literal>update versioned</"
 "literal> statement."
 msgstr ""
-"Seule la forme INSERT INTO ... SELECT ... est supportée ; pas la forme "
-"INSERT INTO ... VALUES ... ."
+"Notez que les types personnalisés (<literal>org.hibernate.usertype."
+"UserVersionType</literal>) ne sont pas permis en conjonction avec la "
+"déclaration <literal>update versioned</literal>. "
 
 #. Tag: para
-#: batch.xml:208
 #, no-c-format
 msgid ""
 "To execute an HQL <literal>DELETE</literal>, use the same <literal>Query."
 "executeUpdate()</literal> method:"
 msgstr ""
-"La properties_list est analogue à la <literal>spécification de la colonne</"
-"literal> The properties_list is analogous to the <literal>column "
-"speficiation</literal> dans l'expression SQL <literal>INSERT</literal>. Pour "
-"les entités impliquées dans un héritage mappé, seules les propriétés "
-"directement définies à ce niveau de classe donné peuvent être utilisées dans "
-"properties_list. Les propriétés de la classe mère ne sont pas permises ; et "
-"les propriétés des classes filles n'ont pas de sens. En d'autres mots, les "
-"expressions <literal>INSERT</literal> par nature non polymorphiques."
+"Pour exécuter un HQL <literal>DELETE</literal>, utilisez la même méthode "
+"<literal>Query.executeUpdate()</literal> :"
 
-#. Tag: programlisting
-#: batch.xml:213
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlDelete = \"delete Customer c where c.name = :oldName\";\n"
-"// or String hqlDelete = \"delete Customer where name = :oldName\";\n"
-"int deletedEntities = s.createQuery( hqlDelete )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:215
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>int</literal> value returned by the <literal>Query.executeUpdate"
 "()</literal> method indicates the number of entities effected by the "
 "operation. This may or may not correlate to the number of rows effected in "
@@ -513,61 +344,41 @@
 "which that subclass is mapped, but also the \"root\" table and potentially "
 "joined-subclass tables further down the inheritance hierarchy."
 msgstr ""
-"select_statement peut être n'importe quelle requête de sélection HQl valide, "
-"avec l'avertissement que les types de retour doivent correspondre aux types "
-"attendus par l'insertion. Actuellement, c'est vérifié durant la compilation "
-"de la requête plutôt que la vérification soit reléguée à la base de données. "
-"Notez cependant que cela pourrait poser des problèmes entre les "
-"<literal>Type</literal>s d'Hibernate qui sont <emphasis>équivalents</"
-"emphasis> opposé à <emphasis>égaux</emphasis>. Cela pourrait poser des "
-"problèmes avec des disparités entre une propriété définie comme un "
-"<literal>org.hibernate.type.DateType</literal> et une propriété définie "
-"comme un <literal>org.hibernate.type.TimestampType</literal>, même si la "
-"base de données ne ferait pas de distinction ou ne serait pas capable de "
-"gérer la conversion."
+"La valeur du <literal>int</literal> retourné par la méthode <literal>Query."
+"executeUpdate()</literal> indique le nombre d'entités affectées par "
+"l'opération. Considérez que cela peut ou non, corréler le nombre de lignes "
+"affectées dans la base de données. Une opération HQL pourrait entraîner "
+"l'exécution de multiples expressions SQL réelles, pour des classes filles "
+"mappées par jointure (join-subclass), par exemple. Le nombre retourné "
+"indique le nombre d'entités réelles affectées par l'expression. Si on "
+"revient à l'exemple de la classe fille mappée par jointure, un effacement "
+"d'une des classes filles peut réellement entraîner des suppressions pas "
+"seulement dans la table à laquelle la classe fille est mappée, mais "
+"également dans la table \"racine\" et potentillement dans les tables des "
+"classes filles plus bas dans la hiérarchie d'héritage. "
 
 #. Tag: para
-#: batch.xml:226
 #, no-c-format
 msgid ""
 "The pseudo-syntax for <literal>INSERT</literal> statements is: "
 "<literal>INSERT INTO EntityName properties_list select_statement</literal>. "
 "Some points to note:"
 msgstr ""
-"Pour la propriéte id, l'expression d'insertion vous donne deux options. Vous "
-"pouvez soit spécifier explicitement la propriété id dans properties_list "
-"(auquel cas sa valeur est extraite de l'expression de sélection "
-"correspondante), soit l'omettre de properties_list (auquel cas une valeur "
-"générée est utilisée). Cette dernière option est seulement disponible en "
-"utilisant le générateur d'identifiant qui opère dans la base de données ; "
-"tenter d'utiliser cette option avec n'importe quel type de générateur \"en "
-"mémoire\" causera une exception durant l'analyse. Notez que pour les buts de "
-"cette discussion, les générateurs \"en base\" sont considérés être "
-"<literal>org.hibernate.id.SequenceGenerator</literal> (et ses classes "
-"filles) et n'importe quelles implémentations de <literal>org.hibernate.id."
-"PostInsertIdentifierGenerator</literal>. L'exception la plus notable ici est "
-"<literal>org.hibernate.id.TableHiLoGenerator</literal>, qu ne peut pas être "
-"utilisée parce qu'il ne propose pas un moyen de d'exposer ses valeurs par un "
-"select."
+"La pseudo-syntaxe pour l'expression <literal>INSERT</literal> est : "
+"<literal>INSERT INTO EntityName properties_list select_statement</literal>. "
+"Quelques points sont à noter :"
 
 #. Tag: para
-#: batch.xml:234
 #, no-c-format
 msgid ""
 "Only the INSERT INTO ... SELECT ... form is supported; not the INSERT "
 "INTO ... VALUES ... form."
 msgstr ""
-"Pour des propriétés mappées comme <literal>version</literal> ou "
-"<literal>timestamp</literal>, l'expression d'insertion vous donne deux "
-"options. Vous pouvez soit spécifier la propriété dans properties_list "
-"(auquel cas sa valeur est extraite des expressions select correspondantes), "
-"soit l'omettre de properties_list (auquel cas la <literal>valeur de graine</"
-"literal> (NdT : seed value) définie par le <literal>org.hibernate.type."
-"VersionType</literal> est utilisée)."
+"Seule la forme INSERT INTO ... SELECT ... est supportée ; pas la forme "
+"INSERT INTO ... VALUES ... ."
 
 #. Tag: para
-#: batch.xml:237
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The properties_list is analogous to the <literal>column specification</"
 "literal> in the SQL <literal>INSERT</literal> statement. For entities "
@@ -576,11 +387,16 @@
 "are not allowed and subclass properties do not make sense. In other words, "
 "<literal>INSERT</literal> statements are inherently non-polymorphic."
 msgstr ""
-"Un exemple d'exécution d'une expression <literal>INSERT</literal> HQL :"
+"La properties_list est analogue à la <literal>column speficiation</literal> "
+"dans la déclaration SQL <literal>INSERT</literal>. Pour les entités "
+"impliquées dans un héritage mappé, seules les propriétés directement "
+"définies à ce niveau de classe donné peuvent être utilisées dans "
+"properties_list. Les propriétés de la classe mère ne sont pas permises ; et "
+"les propriétés des classes filles n'ont pas de sens. En d'autres termes, les "
+"expressions <literal>INSERT</literal> sont par nature non polymorphiques. "
 
 #. Tag: para
-#: batch.xml:247
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "select_statement can be any valid HQL select query, with the caveat that the "
 "return types must match the types expected by the insert. Currently, this is "
@@ -592,10 +408,21 @@
 "DateType</literal> and a property defined as a <literal>org.hibernate.type."
 "TimestampType</literal>, even though the database might not make a "
 "distinction or might be able to handle the conversion."
-msgstr "translator-credits"
+msgstr ""
+"select_statement peut être n'importe quelle requête de sélection HQL valide, "
+"avec l'avertissement que les types de retour doivent correspondre aux types "
+"attendus par l'insertion. Actuellement, cela est vérifié durant la "
+"compilation de la requête plutôt que de reléguer la vérification à la base "
+"de données. Notez cependant que cela pourrait poser des problèmes entre les "
+"<literal>Type</literal>s de Hibernate qui sont <emphasis>équivalents</"
+"emphasis> contrairement à <emphasis>égaux</emphasis>. Cela pourrait poser "
+"des problèmes avec des disparités entre une propriété définie comme un "
+"<literal>org.hibernate.type.DateType</literal> et une propriété définie "
+"comme un <literal>org.hibernate.type.TimestampType</literal>, bien que la "
+"base de données ne fasse pas de distinction ou ne soit pas capable de gérer "
+"la conversion."
 
 #. Tag: para
-#: batch.xml:259
 #, no-c-format
 msgid ""
 "For the id property, the insert statement gives you two options. You can "
@@ -612,9 +439,23 @@
 "TableHiLoGenerator</literal>, which cannot be used because it does not "
 "expose a selectable way to get its values."
 msgstr ""
+"Pour la propriété id, l'expression d'insertion vous donne deux options. Vous "
+"pouvez soit spécifier explicitement la propriété id dans properties_list "
+"(auquel cas sa valeur est extraite de l'expression de sélection "
+"correspondante), soit l'omettre de properties_list (auquel cas une valeur "
+"générée est utilisée). Cette dernière option est seulement disponible si "
+"vous utilisez le générateur d'identifiant qui opère dans la base de "
+"données ; tenter d'utiliser cette option avec n'importe quel type de "
+"générateur \"en mémoire\" causera une exception durant l'analyse. Notez que "
+"pour les buts de cette discussion, les générateurs \"en base\" sont "
+"considérés comme <literal>org.hibernate.id.SequenceGenerator</literal> (et "
+"ses classes filles) et n'importe quelles implémentations de <literal>org."
+"hibernate.id.PostInsertIdentifierGenerator</literal>. L'exception la plus "
+"notable ici est <literal>org.hibernate.id.TableHiLoGenerator</literal>, qui "
+"ne peut pas être utilisée parce qu'elle ne propose pas de moyen d'obtenir "
+"ses valeurs par un select. "
 
 #. Tag: para
-#: batch.xml:274
 #, no-c-format
 msgid ""
 "For properties mapped as either <literal>version</literal> or "
@@ -624,26 +465,18 @@
 "from the properties_list, in which case the <literal>seed value</literal> "
 "defined by the <literal>org.hibernate.type.VersionType</literal> is used."
 msgstr ""
+"Pour des propriétés mappées comme <literal>version</literal> ou "
+"<literal>timestamp</literal>, l'expression d'insertion vous donne deux "
+"options. Vous pouvez soit spécifier la propriété dans properties_list "
+"(auquel cas sa valeur est extraite des expressions select correspondantes), "
+"soit l'omettre de properties_list (auquel cas la <literal>seed value</"
+"literal> définie par le <literal>org.hibernate.type.VersionType</literal> "
+"est utilisée). "
 
 #. Tag: para
-#: batch.xml:284
 #, no-c-format
 msgid ""
 "The following is an example of an HQL <literal>INSERT</literal> statement "
 "execution:"
 msgstr ""
-
-#. Tag: programlisting
-#: batch.xml:288
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlInsert = \"insert into DelinquentAccount (id, name) select c.id, c."
-"name from Customer c where ...\";\n"
-"int createdEntities = s.createQuery( hqlInsert )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
+"Un exemple d'exécution d'une expression HQL <literal>INSERT</literal> : "

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/best_practices.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/best_practices.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/best_practices.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,33 +1,36 @@
+# translation of best_practices.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: best_practices\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-11-10 16:06+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: best_practices.xml:29
 #, no-c-format
 msgid "Best Practices"
 msgstr "Meilleures pratiques"
 
 #. Tag: term
-#: best_practices.xml:33
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Write fine-grained classes and map them using <literal>&lt;component&gt;</"
 "literal>:"
 msgstr ""
-"Découpez finement vos classes et mappez les en utilisant <literal>&lt;"
-"component&gt;</literal>."
+"Découpez finement vos classes et mappez-les en utilisant <literal>&lt;"
+"component&gt;</literal> :"
 
 #. Tag: para
-#: best_practices.xml:35
 #, no-c-format
 msgid ""
 "Use an <literal>Address</literal> class to encapsulate <literal>street</"
@@ -35,37 +38,33 @@
 "<literal>postcode</literal>. This encourages code reuse and simplifies "
 "refactoring."
 msgstr ""
-"Utilisez une classe <literal>Adresse</literal> pour encapsuler <literal>Rue</"
-"literal>, <literal>Region</literal>, <literal>CodePostal</literal>. Ceci "
-"permet la réutilisation du code et simplifie la maintenance."
+"Utilisez une classe <literal>Address</literal> pour résumer <literal>street</"
+"literal>, <literal>suburb</literal>, <literal>state</literal>, "
+"<literal>postcode</literal>. Ceci permet la réutilisation du code et "
+"simplifie la maintenance. "
 
 #. Tag: term
-#: best_practices.xml:43
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Declare identifier properties on persistent classes:"
-msgstr "Déclarez des propriétés d'identifiants dans les classes persistantes."
+msgstr "Déclarez des propriétés d'identifiants dans les classes persistantes :"
 
 #. Tag: para
-#: best_practices.xml:45
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate makes identifier properties optional. There are a range of reasons "
 "why you should use them. We recommend that identifiers be 'synthetic', that "
 "is, generated with no business meaning."
 msgstr ""
-"Hibernate rend les propriétés d'identifiants optionnelles. Il existe "
-"beaucoup de raisons pour lesquelles vous devriez les utiliser. Nous "
-"recommandons que vous utilisiez des identifiants techniques (générés, et "
-"sans connotation métier)."
+"Hibernate rend les propriétés d'identifiants optionnelles. Il est recommandé "
+"de les utiliser pour de nombreuses raisons. Utilisez les identifiants comme "
+"'synthetic' (générés, et sans connotation métier)."
 
 #. Tag: term
-#: best_practices.xml:53
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Identify natural keys:"
-msgstr "Identifiez les clefs naturelles."
+msgstr "Identifiez les clefs naturelles :"
 
 #. Tag: para
-#: best_practices.xml:55
 #, no-c-format
 msgid ""
 "Identify natural keys for all entities, and map them using <literal>&lt;"
@@ -73,20 +72,18 @@
 "<literal>hashCode()</literal> to compare the properties that make up the "
 "natural key."
 msgstr ""
-"Identifiez les clefs naturelles pour toutes les entités, et mappez les avec "
+"Identifiez les clefs naturelles pour toutes les entités, et mappez-les avec "
 "<literal>&lt;natural-id&gt;</literal>. Implémentez <literal>equals()</"
 "literal> et <literal>hashCode()</literal> pour comparer les propriétés qui "
-"composent la clef naturelle."
+"composent la clef naturelle. "
 
 #. Tag: term
-#: best_practices.xml:63
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Place each class mapping in its own file:"
-msgstr "Placez chaque mapping de classe dans son propre fichier."
+msgstr "Placez chaque mapping de classe dans son propre fichier :"
 
 #. Tag: para
-#: best_practices.xml:65
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not use a single monolithic mapping document. Map <literal>com.eg.Foo</"
 "literal> in the file <literal>com/eg/Foo.hbm.xml</literal>. This makes "
@@ -94,87 +91,77 @@
 msgstr ""
 "N'utilisez pas un unique document de mapping. Mappez <literal>com.eg.Foo</"
 "literal> dans le fichier <literal>com/eg/Foo.hbm.xml</literal>. Cela prend "
-"tout son sens lors d'un travail en équipe."
+"tout son sens lors d'un travail en équipe. "
 
 #. Tag: term
-#: best_practices.xml:73
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Load mappings as resources:"
-msgstr "Chargez les mappings comme des ressources."
+msgstr "Chargez les mappings comme des ressources :"
 
 #. Tag: para
-#: best_practices.xml:75
 #, no-c-format
 msgid "Deploy the mappings along with the classes they map."
 msgstr "Déployez les mappings en même temps que les classes qu'ils mappent."
 
 #. Tag: term
-#: best_practices.xml:81
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Consider externalizing query strings:"
-msgstr "Pensez à externaliser les chaînes de caractères."
+msgstr "Pensez à externaliser les chaînes de requêtes :"
 
 #. Tag: para
-#: best_practices.xml:83
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is recommended if your queries call non-ANSI-standard SQL functions. "
 "Externalizing the query strings to mapping files will make the application "
 "more portable."
 msgstr ""
 "Ceci est une bonne habitude si vos requêtes appellent des fonctions SQL qui "
-"ne sont pas au standard ANSI. Cette externalisation dans les fichiers de "
-"mapping rendra votre application plus portable."
+"ne sont pas au standard ANSI. Cette externalisation des chaînes de requête "
+"dans les fichiers de mapping rendra votre application plus portable. "
 
 #. Tag: term
-#: best_practices.xml:91
 #, no-c-format
 msgid "Use bind variables."
-msgstr "Utilisez les variables \"bindées\"."
+msgstr "Utilisez les variables bindées."
 
 #. Tag: para
-#: best_practices.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As in JDBC, always replace non-constant values by \"?\". Do not use string "
 "manipulation to bind a non-constant value in a query. You should also "
 "consider using named parameters in queries."
 msgstr ""
-"Comme en JDBC, remplacez toujours les valeurs non constantes par \"?\". "
-"N'utilisez jamais la manipulation des chaînes de caractères pour remplacer "
-"des valeurs non constantes dans une requête ! Encore mieux, utilisez les "
+"Comme dans JDBC, remplacez toujours les valeurs non constantes par \"?\". "
+"N'utilisez jamais la manipulation des chaînes de caractères pour lier des "
+"valeurs non constantes dans une requête ! Encore mieux, utilisez les "
 "paramètres nommés dans les requêtes."
 
 #. Tag: term
-#: best_practices.xml:101
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Do not manage your own JDBC connections:"
-msgstr "Ne gérez pas vous même les connexions JDBC."
+msgstr "Ne gérez pas vous-même les connexions JDBC :"
 
 #. Tag: para
-#: best_practices.xml:103
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate allows the application to manage JDBC connections, but his "
 "approach should be considered a last-resort. If you cannot use the built-in "
 "connection providers, consider providing your own implementation of "
 "<literal>org.hibernate.connection.ConnectionProvider</literal>."
 msgstr ""
-"Hibernate laisse l'application gérer les connexions JDBC. Vous ne devriez "
-"gérer vos connexions qu'en dernier recours. Si vous ne pouvez pas utiliser "
-"les systèmes de connexions livrés, réfléchissez à l'idée de fournir votre "
-"propre implémentation de <literal>org.hibernate.connection."
-"ConnectionProvider</literal>."
+"Hibernate permet à l'application de gérer les connexions JDBC. Vous ne "
+"devriez gérer vos connexions qu'en dernier recours. Si vous ne pouvez pas "
+"utiliser les systèmes de connexions livrés, considérez la fourniture de "
+"votre propre implémentation de <literal>org.hibernate.connection."
+"ConnectionProvider</literal>. "
 
 #. Tag: term
-#: best_practices.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Consider using a custom type:"
-msgstr "Pensez à utiliser les types utilisateurs."
+msgstr "Considérez l'utilisation de types personnalisés :"
 
 #. Tag: para
-#: best_practices.xml:113
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Suppose you have a Java type from a library that needs to be persisted but "
 "does not provide the accessors needed to map it as a component. You should "
@@ -182,48 +169,45 @@
 "approach frees the application code from implementing transformations to/"
 "from a Hibernate type."
 msgstr ""
-"Supposez que vous ayez une type Java, de telle bibliothèque, qui a besoin "
+"Supposez que vous ayez un type Java, de telle bibliothèque, qui a besoin "
 "d'être persisté mais qui ne fournit pas les accesseurs nécessaires pour le "
 "mapper comme composant. Vous devriez implémenter <literal>org.hibernate."
-"UserType</literal>.Cette approche libère le code de l'application de "
-"l'implémentation des transformations vers / depuis les types Hibernate."
+"UserType</literal>. Cette approche évite au code de l'application, "
+"l'implémentation de transformations vers / depuis les types Hibernate. "
 
 #. Tag: term
-#: best_practices.xml:122
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Use hand-coded JDBC in bottlenecks:"
-msgstr "Utilisez du JDBC pur dans les goulets d'étranglement."
+msgstr "Utilisez du JDBC pur dans les goulots d'étranglement :"
 
 #. Tag: para
-#: best_practices.xml:124
 #, fuzzy, no-c-format
 msgid ""
 "In performance-critical areas of the system, some kinds of operations might "
 "benefit from direct JDBC. Do not assume, however, that JDBC is necessarily "
 "faster. Please wait until you <emphasis>know</emphasis> something is a "
 "bottleneck. If you need to use direct JDBC, you can open a Hibernate "
-"<literal>Session</literal> and usingfile:///usr/share/doc/HTML/en-US/index."
-"html that JDBC connection. This way you can still use the same transaction "
-"strategy and underlying connection provider."
+"<literal>Session</literal>, wrap your JDBC operation as a <literal>org."
+"hibernate.jdbc.Work</literal> object and using that JDBC connection. This "
+"way you can still use the same transaction strategy and underlying "
+"connection provider."
 msgstr ""
-"Dans certaines parties critiques de votre système d'un point de vue "
-"performance, quelques opérations peuvent tirer partie d'un appel JDBC natif. "
-"Mais attendez de <emphasis>savoir</emphasis> que c'est un goulet "
+"En ce qui concerne les performances dans certaines parties critiques de "
+"votre système, quelques opérations peuvent tirer partie d'un appel JDBC "
+"natif. Mais attendez de <emphasis>savoir</emphasis> que c'est un goulet "
 "d'étranglement. Ne supposez jamais qu'un appel JDBC sera forcément plus "
-"rapide. Si vous avez besoin d'utiliser JDBC directement, ouvrez une "
+"rapide. Si vous devez utiliser JDBC directement, ouvrez une "
 "<literal>Session</literal> Hibernate et utilisez la connexion SQL sous-"
 "jacente. Ainsi vous pourrez utiliser la même stratégie de transation et la "
-"même gestion des connexions."
+"même gestion des connexions. "
 
 #. Tag: term
-#: best_practices.xml:134
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Understand <literal>Session</literal> flushing:"
-msgstr "Comprendre le flush de <literal>Session</literal>."
+msgstr "Comprenez le flush de <literal>Session</literal> :"
 
 #. Tag: para
-#: best_practices.xml:136
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes the Session synchronizes its persistent state with the database. "
 "Performance will be affected if this process occurs too often. You can "
@@ -234,20 +218,18 @@
 "De temps en temps la Session synchronise ses états persistants avec la base "
 "de données. Les performances seront affectées si ce processus arrive trop "
 "souvent. Vous pouvez parfois minimiser les flush non nécessaires en "
-"désactivant le flush automatique ou même en changeant l'ordre des opérations "
-"menées dans une transaction particulière."
+"désactivant le flush automatique ou même en changeant l'ordre des requêtes "
+"et autres opérations effectuées dans une transaction particulière. "
 
 #. Tag: term
-#: best_practices.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "In a three tiered architecture, consider using detached objects:"
 msgstr ""
-"Dans une architecture à trois couches, pensez à utiliser "
-"<literal>saveOrUpdate()</literal>."
+"Dans une architecture à trois couches, vous pouvez utilisez des objets "
+"détachés :"
 
 #. Tag: para
-#: best_practices.xml:147
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When using a servlet/session bean architecture, you can pass persistent "
 "objects loaded in the session bean to and from the servlet/JSP layer. Use a "
@@ -256,23 +238,21 @@
 "database."
 msgstr ""
 "Quand vous utilisez une architecture à base de servlet / session bean, vous "
-"pourriez passer des objets chargés dans le bean session vers et depuis la "
+"pouvez passer des objets chargés dans le bean session vers et depuis la "
 "couche servlet / JSP. Utilisez une nouvelle session pour traiter chaque "
 "requête. Utilisez <literal>Session.merge()</literal> ou <literal>Session."
 "saveOrUpdate()</literal> pour synchroniser les objets avec la base de "
-"données."
+"données. "
 
 #. Tag: term
-#: best_practices.xml:156
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "In a two tiered architecture, consider using long persistence contexts:"
 msgstr ""
-"Dans une architecture à deux couches, pensez à utiliser la déconnexion de "
-"session."
+"Dans une architecture à deux couches, pensez à utiliser les contextes de "
+"persistance longue :"
 
 #. Tag: para
-#: best_practices.xml:158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Database Transactions have to be as short as possible for best scalability. "
 "However, it is often necessary to implement long running "
@@ -288,28 +268,26 @@
 "stale data."
 msgstr ""
 "Les transactions de bases de données doivent être aussi courtes que possible "
-"pour une meilleure montée en charge.Cependant, il est souvent nécessaire "
+"pour une meilleure extensibilité. Cependant, il est souvent nécessaire "
 "d'implémenter de longues <emphasis>transactions applicatives</emphasis>, une "
 "simple unité de travail du point de vue de l'utilisateur. Une transaction "
 "applicative peut s'étaler sur plusieurs cycles de requêtes/réponses du "
 "client. Il est commun d'utiliser des objets détachés pour implémenter des "
 "transactions applicatives. Une alternative, extrêmement appropriée dans une "
-"architecture à 2 couches, est de maintenir un seul contact de persistance "
+"architecture à deux couches, est de maintenir un seul contact de persistance "
 "ouvert (session) pour toute la durée de vie de la transaction applicative et "
 "simplement se déconnecter de la connexion JDBC à la fin de chaque requête, "
 "et se reconnecter au début de la requête suivante. Ne partagez jamais une "
-"seule session avec plus d'une transaction applicative, ou vous travaillerez "
-"avec des données périmées."
+"seule session avec plus d'une transaction applicative, ou bien vous "
+"travaillerez avec des données périmées. "
 
 #. Tag: term
-#: best_practices.xml:172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Do not treat exceptions as recoverable:"
-msgstr "Considérez que les exceptions ne sont pas rattrapables."
+msgstr "Considérez que les exceptions ne sont pas rattrapables :"
 
 #. Tag: para
-#: best_practices.xml:174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is more of a necessary practice than a \"best\" practice. When an "
 "exception occurs, roll back the <literal>Transaction</literal> and close the "
@@ -324,18 +302,17 @@
 "<literal>Transaction</literal> et fermer la <literal>Session</literal>. "
 "Sinon, Hibernate ne peut garantir l'intégrité des états persistants en "
 "mémoire. En particulier, n'utilisez pas <literal>Session.load()</literal> "
-"pour déterminer si une instance avec un identifiant donné existe en base de "
-"données, utilisez <literal>Session.get()</literal> ou un requête."
+"pour déterminer si une instance avec l'identifiant donné existe en base de "
+"données, à la place utilisez <literal>Session.get()</literal> ou une "
+"requête. "
 
 #. Tag: term
-#: best_practices.xml:184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Prefer lazy fetching for associations:"
-msgstr "Préférez le chargement tardif des associations."
+msgstr "Préférez le chargement différé des associations :"
 
 #. Tag: para
-#: best_practices.xml:186
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use eager fetching sparingly. Use proxies and lazy collections for most "
 "associations to classes that are not likely to be completely held in the "
@@ -348,27 +325,25 @@
 "Utilisez le chargement complet avec modération. Utilisez les proxies et les "
 "collections chargées tardivement pour la plupart des associations vers des "
 "classes qui ne sont pas susceptibles d'être complètement retenues dans le "
-"cache de second niveau. Pour les assocations de classes en cache, où il y a "
-"une extrêmement forte probabilité que l'élément soit en cache, désactivez "
-"explicitement le chargement par jointures ouvertes en utilisant "
-"<literal>outer-join=\"false\"</literal>. Lorsqu'un chargement par jointure "
-"ouverte est approprié pour un cas d'utilisation particulier, utilisez une "
-"requête avec un <literal>left join fetch</literal>."
+"cache de second niveau. Pour les associations de classes en cache, où il y a "
+"une forte probabilité que l'élément soit en cache, désactivez explicitement "
+"le chargement par jointures ouvertes en utilisant <literal>outer-join=\"false"
+"\"</literal>. Lorsqu'un chargement par jointure ouverte est approprié pour "
+"un cas d'utilisation particulier, utilisez une requête avec un <literal>left "
+"join fetch</literal>. "
 
 #. Tag: term
-#: best_practices.xml:196
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use the <emphasis>open session in view</emphasis> pattern, or a disciplined "
 "<emphasis>assembly phase</emphasis> to avoid problems with unfetched data:"
 msgstr ""
 "Utilisez le pattern <emphasis>d'une ouverture de session dans une vue</"
 "emphasis>, ou une <emphasis>phase d'assemblage</emphasis> disciplinée pour "
-"éviter des problèmes avec des données non rapatriées."
+"éviter des problèmes avec des données non rapatriées :"
 
 #. Tag: para
-#: best_practices.xml:201
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate frees the developer from writing tedious <emphasis>Data Transfer "
 "Objects</emphasis> (DTO). In a traditional EJB architecture, DTOs serve dual "
@@ -384,28 +359,28 @@
 "requirement of safe transactional data access."
 msgstr ""
 "Hibernate libère les développeurs de l'écriture fastidieuse des "
-"<emphasis>objets de transfert de données (NdT : Data Transfer Objects)</"
-"emphasis> (DTO). Dans une architecture EJB traditionnelle, les DTOs ont deux "
-"buts : premièrement, ils contournent le problème des \"entity bean\" qui ne "
-"sont pas sérialisables ; deuxièmement, ils définissent implicitement une "
-"phase d'assemblage où toutes les données utilisées par la vue sont "
-"rapatriées et organisées dans les DTOs avant de retourner sous le contrôle "
-"de la couche de présentation. Hibernate élimine le premier but. Pourtant, "
-"vous aurez encore besoin d'une phase d'assemblage (pensez vos méthodes "
-"métier comme ayant un contrat strict avec la couche de présentation à propos "
-"de quelles données sont disponibles dans les objets détachés) à moins que "
-"vous soyez préparés à garder le contexte de persistance (la session) ouvert "
-"à travers tout le processus de rendu de la vue."
+"<emphasis>objets de transfert de données </emphasis> (DTO). Dans une "
+"architecture EJB traditionnelle, les DTO ont deux buts : premièrement, ils "
+"contournent le problème des beans entités qui ne sont pas sérialisables ; "
+"deuxièmement, ils définissent implicitement une phase d'assemblage où toutes "
+"les données utilisées par la vue sont rapatriées et organisées dans les DTO "
+"avant de retourner sous le contrôle de la couche de présentation. Hibernate "
+"élimine le premier but. Cependant, vous aurez encore besoin d'une phase "
+"d'assemblage (pensez à vos méthodes métier comme ayant un contrat strict "
+"avec la couche de présentation, en ce qui concerne les données disponibles "
+"dans les objets détachés) à moins que vous soyez préparés à garder le "
+"contexte de persistance (la session) ouvert à travers tout le processus de "
+"rendu de la vue. Ceci ne représente pas une limitation de Hibernate! Au "
+"contraire c'est une exigence fondamentale d'un accès sécurisé aux données "
+"transactionnelles. "
 
 #. Tag: term
-#: best_practices.xml:215
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Consider abstracting your business logic from Hibernate:"
-msgstr "Pensez à abstraite votre logique métier d'Hibernate."
+msgstr "Pensez à abstraire votre logique métier d'Hibernate :"
 
 #. Tag: para
-#: best_practices.xml:217
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hide Hibernate data-access code behind an interface. Combine the "
 "<emphasis>DAO</emphasis> and <emphasis>Thread Local Session</emphasis> "
@@ -415,21 +390,19 @@
 "appropriate for an application with five tables."
 msgstr ""
 "Cachez le mécanisme d'accès aux données (Hibernate) derrière une interface. "
-"Combinez les patterns <emphasis>DAO</emphasis> et <emphasis>Thread Local "
+"Combinez les modèles <emphasis>DAO</emphasis> et <emphasis>Thread Local "
 "Session</emphasis>. Vous pouvez même avoir quelques classes persistées par "
 "du JDBC pur, associées à Hibernate via un <literal>UserType</literal> (ce "
 "conseil est valable pour des applications de taille respectables ; il n'est "
-"pas valable pour une application avec cinq tables)."
+"pas valable pour une application avec cinq tables). "
 
 #. Tag: term
-#: best_practices.xml:227
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Do not use exotic association mappings:"
-msgstr "N'utilisez pas d'associations de mapping exotiques."
+msgstr "N'utilisez pas d'associations de mapping exotiques :"
 
 #. Tag: para
-#: best_practices.xml:229
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Practical test cases for real many-to-many associations are rare. Most of "
 "the time you need additional information stored in the \"link table\". In "
@@ -438,23 +411,21 @@
 "to-one. For this reason, you should proceed cautiously when using any other "
 "association style."
 msgstr ""
-"De bons cas d'utilisation pour de vraies associations plusieurs-vers-"
-"plusieurs sont rares. La plupart du temps vous avez besoin d'informations "
+"Les utilisations appropriées de vraies associations plusieurs-à-plusieurs "
+"sont rares. La plupart du temps vous avez besoin d'informations "
 "additionnelles stockées dans la table d'association. Dans ce cas, il est "
-"préférable d'utiliser deux associations un-vers-plusieurs vers une classe de "
+"préférable d'utiliser deux associations un-à-plusieurs vers une classe de "
 "liaisons intermédiaire. En fait, nous pensons que la plupart des "
-"associations sont de type un-vers-plusieurs ou plusieurs-vers-un, vous devez "
-"être très attentifs lorsque vous utilisez autre chose et vous demander si "
-"c'est vraiment nécessaire."
+"associations sont de type un-à-plusieurs ou plusieurs-à-un, vous devez être "
+"très prudent lorsque vous utilisez toute autre association et vous demander "
+"si c'est vraiment nécessaire. "
 
 #. Tag: term
-#: best_practices.xml:239
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Prefer bidirectional associations:"
-msgstr "Préférez les associations bidirectionnelles."
+msgstr "Préférez les associations bidirectionnelles :"
 
 #. Tag: para
-#: best_practices.xml:241
 #, no-c-format
 msgid ""
 "Unidirectional associations are more difficult to query. In a large "
@@ -463,4 +434,4 @@
 msgstr ""
 "Les associations unidirectionnelles sont plus difficiles à questionner. Dans "
 "une grande application, la plupart des associations devraient être "
-"navigables dans les deux directions dans les requêtes."
+"navigables dans les deux directions dans les requêtes. "

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/bibliography.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/bibliography.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/bibliography.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -5,7 +5,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: 2009-07-14 19:55+0000\n"
 "Last-Translator: Automatically generated\n"
 "Language-Team: none\n"
@@ -14,55 +14,36 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: bibliography.xml:27
 #, no-c-format
 msgid "References"
 msgstr ""
 
 #. Tag: title
-#: bibliography.xml:31
 #, no-c-format
 msgid "Patterns of Enterprise Application Architecture"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:34
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Martin</firstname> <surname>Fowler</surname>"
+msgid "Martin"
 msgstr ""
 
-#. Tag: holder
-#: bibliography.xml:41
-#, no-c-format
-msgid "Pearson Education, Inc."
-msgstr ""
-
 #. Tag: title
-#: bibliography.xml:50
 #, no-c-format
 msgid "Java Persistence with Hibernate"
 msgstr ""
 
 #. Tag: subtitle
-#: bibliography.xml:51
 #, no-c-format
 msgid "Second Edition of Hibernate in Action"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:57
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Christian</firstname> <surname>Bauer</surname>"
+msgid "Christian"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:61
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Gavin</firstname> <surname>King</surname>"
+msgid "Gavin"
 msgstr ""
-
-#. Tag: holder
-#: bibliography.xml:68
-#, no-c-format
-msgid "Manning Publications Co."
-msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/collection_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/collection_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/collection_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,56 +1,43 @@
+# translation of collection_mapping.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: collection_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2010-01-05 08:54+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: collection_mapping.xml:29
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Collection mapping"
-msgstr "Mapper une collection"
+msgstr "Mapper une collection "
 
 #. Tag: title
-#: collection_mapping.xml:32
 #, no-c-format
 msgid "Persistent collections"
 msgstr "Collections persistantes"
 
 #. Tag: para
-#: collection_mapping.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate requires that persistent collection-valued fields be declared as "
 "an interface type. For example:"
 msgstr ""
 "Hibernate requiert que les champs contenant des collections persistantes "
-"soient déclarés comme des types d'interface, par exemple :"
+"soient déclarés comme des types d'interface, par exemple : "
 
-#. Tag: programlisting
-#: collection_mapping.xml:39
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[public class Product {\n"
-"    private String serialNumber;\n"
-"    private Set parts = new HashSet();\n"
-"    \n"
-"    public Set getParts() { return parts; }\n"
-"    void setParts(Set parts) { this.parts = parts; }\n"
-"    public String getSerialNumber() { return serialNumber; }\n"
-"    void setSerialNumber(String sn) { serialNumber = sn; }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:41
-#, fuzzy, no-c-format
-msgid ""
 "The actual interface might be <literal>java.util.Set</literal>, "
 "<literal>java.util.Collection</literal>, <literal>java.util.List</literal>, "
 "<literal>java.util.Map</literal>, <literal>java.util.SortedSet</literal>, "
@@ -58,17 +45,15 @@
 "like\" means you will have to write an implementation of <literal>org."
 "hibernate.usertype.UserCollectionType</literal>.)"
 msgstr ""
-"L'interface réelle devrait être <literal>java.util.Set</literal>, "
-"<literal>java.util.Collection</literal>, <literal>java.util.List</literal>, "
-"<literal>java.util.Map</literal>, <literal>java.util.SortedSet</literal>, "
-"<literal>java.util.SortedMap</literal> ou ... n'importe quoi d'autre ! (Où "
-"\"n'importe quoi d'autre\" signifie que vous devrez écrire une "
-"implémentation de <literal>org.hibernate.usertype.UserCollectionType</"
-"literal>.)"
+"L'interface réelle peut être <literal>java.util.Set</literal>, <literal>java."
+"util.Collection</literal>, <literal>java.util.List</literal>, <literal>java."
+"util.Map</literal>, <literal>java.util.SortedSet</literal>, <literal>java."
+"util.SortedMap</literal> ou n'importe quoi d'autre ! (Où \"n'importe quoi "
+"d'autre\" signifie que vous devrez écrire une implémentation de <literal>org."
+"hibernate.usertype.UserCollectionType</literal>.)"
 
 #. Tag: para
-#: collection_mapping.xml:50
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Notice how the instance variable was initialized with an instance of "
 "<literal>HashSet</literal>. This is the best way to initialize collection "
@@ -78,33 +63,17 @@
 "an instance of Hibernate's own implementation of <literal>Set</literal>. Be "
 "aware of the following errors:"
 msgstr ""
-"Notez comment nous avons initialisé les variables d'instance avec une "
-"instance de <literal>HashSet</literal>. C'est le meilleur moyen pour "
-"initialiser les collections d'instances nouvellement créées (non "
-"persistantes). Quand nous fabriquons l'instance persistante - en appelant "
-"<literal>persist()</literal>, par exemple - Hibernate remplacera réellement "
-"le <literal>HashSet</literal> avec une instance d'une implémentation propre "
-"à Hibernate de <literal>Set</literal>. Prenez garde aux erreurs :"
+"Notez comment nous avons initialisé la variable d'instance avec une instance "
+"de <literal>HashSet</literal>. C'est le meilleur moyen pour initialiser les "
+"collections d'instances nouvellement créées (non persistantes). Quand nous "
+"fabriquons l'instance persistante - en appelant <literal>persist()</"
+"literal>, par exemple - Hibernate remplacera réellement le <literal>HashSet</"
+"literal> par une instance d'une implémentation propre à Hibernate de "
+"<literal>Set</literal>. Prenez garde aux erreurs suivantes : "
 
-#. Tag: programlisting
-#: collection_mapping.xml:60
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Cat cat = new DomesticCat();\n"
-"Cat kitten = new DomesticCat();\n"
-"....\n"
-"Set kittens = new HashSet();\n"
-"kittens.add(kitten);\n"
-"cat.setKittens(kittens);\n"
-"session.persist(cat);\n"
-"kittens = cat.getKittens(); // Okay, kittens collection is a Set\n"
-"(HashSet) cat.getKittens(); // Error!]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:62
-#, fuzzy, no-c-format
-msgid ""
 "The persistent collections injected by Hibernate behave like "
 "<literal>HashMap</literal>, <literal>HashSet</literal>, <literal>TreeMap</"
 "literal>, <literal>TreeSet</literal> or <literal>ArrayList</literal>, "
@@ -113,11 +82,10 @@
 "Les collections persistantes injectées par Hibernate se comportent de la "
 "même manière que <literal>HashMap</literal>, <literal>HashSet</literal>, "
 "<literal>TreeMap</literal>, <literal>TreeSet</literal> ou "
-"<literal>ArrayList</literal>, selon le type de l'interface."
+"<literal>ArrayList</literal>, selon le type de l'interface. "
 
 #. Tag: para
-#: collection_mapping.xml:69
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collections instances have the usual behavior of value types. They are "
 "automatically persisted when referenced by a persistent object and are "
@@ -128,79 +96,61 @@
 "properties do not support null value semantics. Hibernate does not "
 "distinguish between a null collection reference and an empty collection."
 msgstr ""
-"Les instances des collections ont le comportement habituel des types des "
+"Les instances des collections ont le comportement habituel des types de "
 "valeurs. Elles sont automatiquement persistées quand elles sont référencées "
 "par un objet persistant et automatiquement effacées quand elles sont "
 "déréférencées. Si une collection est passée d'un objet persistant à un "
-"autre, ses éléments pourraient être déplacés d'une table à une autre. Deux "
-"entités ne peuvent pas partager une référence vers une même instance d'une "
+"autre, ses éléments peuvent être déplacés d'une table à une autre. Deux "
+"entités ne peuvent pas partager une référence vers une même instance de "
 "collection. Dû au modèle relationnel sous-jacent, les propriétés contenant "
 "des collections ne supportent pas la sémantique de la valeur null ; "
-"Hibernate ne distingue pas une référence vers une collection nulle d'une "
-"collection vide."
+"Hibernate ne fait pas de distinction entre une référence de collection nulle "
+"et une collection vide. "
 
 #. Tag: para
-#: collection_mapping.xml:80
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use persistent collections the same way you use ordinary Java collections. "
 "However, please ensure you understand the semantics of bidirectional "
 "associations (these are discussed later)."
 msgstr ""
-"Vous ne devriez pas vous préoccuper trop de ça. Utilisez les collections "
-"persistantes de la même manière que vous utilisez des collections Java "
-"ordinaires. Assurez-vous de comprendre la sémantique des associations "
-"bidirectionnelles (traitée plus loin)."
+"Ne vous en souciez pas trop. Utilisez les collections persistantes de la "
+"même manière que vous utilisez des collections Java ordinaires. Assurez-vous "
+"de comprendre la sémantique des associations bidirectionnelles (traitée plus "
+"loin). "
 
 #. Tag: title
-#: collection_mapping.xml:89
 #, no-c-format
 msgid "Collection mappings"
 msgstr "Mapper une collection"
 
 #. Tag: para
-#: collection_mapping.xml:92
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are quite a range of mappings that can be generated for collections "
 "that cover many common relational models. We suggest you experiment with the "
 "schema generation tool so that you understand how various mapping "
 "declarations translate to database tables."
 msgstr ""
-"Il y a pas mal de variétés de mappings qui peuvent être générés pour les "
-"collections, couvrant beaucoup des modèles relationnels communs. Nous vous "
-"suggérons d'expérimenter avec l'outil de génération de schéma pour avoir une "
-"idée de comment traduire les différentes déclarations de mapping vers des "
-"table de la base de données."
+"Il y a une grande variété de mappages qui peuvent être générés pour les "
+"collections, couvrant beaucoup de nombreux modèles relationnels communs. "
+"Nous vous suggérons d'expérimenter avec l'outil de génération de schéma pour "
+"cerner comment les différentes déclarations de mappage se traduisent vers "
+"des tables de bases de données. "
 
 #. Tag: para
-#: collection_mapping.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The Hibernate mapping element used for mapping a collection depends upon the "
 "type of interface. For example, a <literal>&lt;set&gt;</literal> element is "
 "used for mapping properties of type <literal>Set</literal>."
 msgstr ""
-"L'élément de mapping d'Hibernate utilisé pour mapper une collection dépend "
+"L'élément de mappage d'Hibernate utilisé pour mapper une collection dépend "
 "du type de l'interface. Par exemple, un élément <literal>&lt;set&gt;</"
 "literal> est utilisé pour mapper des propriétés de type <literal>Set</"
-"literal>."
+"literal>. "
 
-#. Tag: programlisting
-#: collection_mapping.xml:105
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Product\">\n"
-"    <id name=\"serialNumber\" column=\"productSerialNumber\"/>\n"
-"    <set name=\"parts\">\n"
-"        <key column=\"productSerialNumber\" not-null=\"true\"/>\n"
-"        <one-to-many class=\"Part\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:107
 #, no-c-format
 msgid ""
 "Apart from <literal>&lt;set&gt;</literal>, there is also <literal>&lt;"
@@ -209,72 +159,39 @@
 "array&gt;</literal> mapping elements. The <literal>&lt;map&gt;</literal> "
 "element is representative:"
 msgstr ""
-"À part <literal>&lt;set&gt;</literal>, il y aussi les éléments de mapping "
+"À part <literal>&lt;set&gt;</literal>, il y aussi les éléments de mappage "
 "<literal>&lt;list&gt;</literal>, <literal>&lt;map&gt;</literal>, "
 "<literal>&lt;bag&gt;</literal>, <literal>&lt;array&gt;</literal> et "
 "<literal>&lt;primitive-array&gt;</literal>. L'élément <literal>&lt;map&gt;</"
-"literal> est représentatif :"
+"literal> est représentatif : "
 
-#. Tag: programlisting
-#: collection_mapping.xml:132
-#, no-c-format
-msgid ""
-"<![CDATA[<map\n"
-"    name=\"propertyName\"\n"
-"    table=\"table_name\"\n"
-"    schema=\"schema_name\"\n"
-"    lazy=\"true|extra|false\"\n"
-"    inverse=\"true|false\"\n"
-"    cascade=\"all|none|save-update|delete|all-delete-orphan|delete-orphan\"\n"
-"    sort=\"unsorted|natural|comparatorClass\"\n"
-"    order-by=\"column_name asc|desc\"\n"
-"    where=\"arbitrary sql where condition\"\n"
-"    fetch=\"join|select|subselect\"\n"
-"    batch-size=\"N\"\n"
-"    access=\"field|property|ClassName\"\n"
-"    optimistic-lock=\"true|false\"\n"
-"    mutable=\"true|false\"\n"
-"    node=\"element-name|.\"\n"
-"    embed-xml=\"true|false\"\n"
-">\n"
-"\n"
-"    <key .... />\n"
-"    <map-key .... />\n"
-"    <element .... />\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:135
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>name</literal>: the collection property name"
 msgstr ""
-"<literal>name</literal> : le nom de la propriété contenant la collection"
+"<literal>name</literal> : le nom de la propriété contenant la collection "
 
 #. Tag: para
-#: collection_mapping.xml:140
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>table</literal> (optional - defaults to property name): the name of "
 "the collection table. It is not used for one-to-many associations."
 msgstr ""
 "<literal>table</literal> (optionnel - par défaut = nom de la propriété) : le "
-"nom de la table de la collection (non utilisé pour les associations one-to-"
-"many)"
+"nom de la table de la collection (non utilisé pour les associations un-à-"
+"plusieurs) "
 
 #. Tag: para
-#: collection_mapping.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>schema</literal> (optional): the name of a table schema to override "
 "the schema declared on the root element"
 msgstr ""
 "<literal>schema</literal> (optionnel) : le nom du schéma pour surcharger le "
-"schéma déclaré dans l'élément racine"
+"schéma déclaré dans l'élément racine "
 
 #. Tag: para
-#: collection_mapping.xml:152
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>true</literal>): "
 "disables lazy fetching and specifies that the association is always eagerly "
@@ -285,45 +202,41 @@
 "<literal>lazy</literal> (optionnel - par défaut = <literal>true</literal>) : "
 "peut être utilisé pour désactiver l'initialisation tardive et spécifier que "
 "l'association est toujours rapportée, ou pour activer la récupération extra-"
-"paresseuse (NdT : extra-lazy) où la plupart des opérations n'initialisent "
-"pas la collection (approprié pour de très grosses collections)"
+"paresseuse (extra-lazy) où la plupart des opérations n'initialisent pas la "
+"collection (approprié pour de très grosses collections)."
 
 #. Tag: para
-#: collection_mapping.xml:161
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>inverse</literal> (optional - defaults to <literal>false</"
 "literal>): marks this collection as the \"inverse\" end of a bidirectional "
 "association."
 msgstr ""
 "<literal>inverse</literal> (optionnel - par défaut = <literal>false</"
-"literal>) : définit cette collection comme l'extrêmité \"inverse\" de "
-"l'association bidirectionnelle"
+"literal>) : définit cette collection comme l'extrémité \"inverse\" de "
+"l'association bidirectionnelle."
 
 #. Tag: para
-#: collection_mapping.xml:167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional - defaults to <literal>none</literal>): "
 "enables operations to cascade to child entities."
 msgstr ""
 "<literal>cascade</literal> (optionnel - par défaut = <literal>none</"
-"literal>) : active les opérations de cascade vers les entités filles"
+"literal>) : active les opérations de cascade vers les entités filles."
 
 #. Tag: para
-#: collection_mapping.xml:173
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>sort</literal> (optional): specifies a sorted collection with "
 "<literal>natural</literal> sort order or a given comparator class."
 msgstr ""
 "<literal>sort</literal> (optionnel) : spécifie une collection triée via un "
 "ordre de tri <literal>naturel</literal>, ou via une classe comparateur "
-"donnée (implémentant Comparator)"
+"donnée."
 
 #. Tag: para
-#: collection_mapping.xml:179
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>order-by</literal> (optional, JDK1.4 only): specifies a table "
 "column or columns that define the iteration order of the <literal>Map</"
@@ -333,11 +246,10 @@
 "<literal>order-by</literal> (optionnel, seulement à partir du JDK1.4) : "
 "spécifie une colonne de table (ou des colonnes) qui définit l'ordre "
 "d'itération de <literal>Map</literal>, <literal>Set</literal> ou Bag, avec "
-"en option <literal>asc</literal> ou <literal>desc</literal>"
+"en option <literal>asc</literal> ou <literal>desc</literal>."
 
 #. Tag: para
-#: collection_mapping.xml:186
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>where</literal> (optional): specifies an arbitrary SQL "
 "<literal>WHERE</literal> condition that is used when retrieving or removing "
@@ -347,11 +259,10 @@
 "<literal>where</literal> (optionnel) : spécifie une condition SQL arbitraire "
 "<literal>WHERE</literal> à utiliser au chargement ou à la suppression d'une "
 "collection (utile si la collection ne doit contenir qu'un sous ensemble des "
-"données disponibles)"
+"données disponibles)."
 
 #. Tag: para
-#: collection_mapping.xml:193
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional, defaults to <literal>select</literal>): "
 "chooses between outer-join fetching, fetching by sequential select, and "
@@ -360,34 +271,31 @@
 "<literal>fetch</literal> (optionnel, par défaut = <literal>select</"
 "literal>) : à choisir entre récupération par jointures externes, "
 "récupération par selects séquentiels, et récupération par sous-selects "
-"séquentiels"
+"séquentiels."
 
 #. Tag: para
-#: collection_mapping.xml:200
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>batch-size</literal> (optional, defaults to <literal>1</literal>): "
 "specifies a \"batch size\" for lazily fetching instances of this collection."
 msgstr ""
 "<literal>batch-size</literal> (optionnel, par défaut = <literal>1</"
-"literal>) : une taille de batch (batch size) utilisée pour charger plusieurs "
-"instances de cette collection en initialisation tardive"
+"literal>) : une \"taille de batch\" utilisée pour charger plusieurs "
+"instances de cette collection."
 
 #. Tag: para
-#: collection_mapping.xml:206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate uses for accessing the collection property "
 "value."
 msgstr ""
 "<literal>access</literal> (optionnel - par défaut = <literal>property</"
-"literal>) : La stratégie qu'Hibernate doit utiliser pour accéder à la valeur "
-"de la propriété"
+"literal>) : la stratégie que Hibernate doit utiliser pour accéder à la "
+"valeur de la propriété."
 
 #. Tag: para
-#: collection_mapping.xml:212
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that changes to the state of the collection results in "
@@ -395,13 +303,13 @@
 "may want to disable this setting."
 msgstr ""
 "<literal>optimistic-lock</literal> (optionnel - par défaut = <literal>true</"
-"literal>) : spécifie que changer l'état de la collection entraîne "
-"l'incrémentation de la version appartenant à l'entité (Pour une association "
-"un vers plusieurs, il est souvent raisonnable de désactiver ce paramètre)"
+"literal>) : spécifie que changer l'état des résultats de la collection "
+"entraîne l'incrémentation de la version appartenant à l'entité (Pour une "
+"association un-à-plusieurs, il est souvent raisonnable de désactiver ce "
+"paramètre)."
 
 #. Tag: para
-#: collection_mapping.xml:220
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>true</literal>): "
 "a value of <literal>false</literal> specifies that the elements of the "
@@ -411,17 +319,15 @@
 "<literal>mutable</literal> (optionnel - par défaut = <literal>true</"
 "literal>) : une valeur à <literal>false</literal> spécifie que les éléments "
 "de la collection ne changent jamais (une optimisation mineure dans certains "
-"cas)"
+"cas)."
 
 #. Tag: title
-#: collection_mapping.xml:230
 #, no-c-format
 msgid "Collection foreign keys"
-msgstr "Les clefs étrangères d'une collection"
+msgstr "Les clés étrangères d'une collection"
 
 #. Tag: para
-#: collection_mapping.xml:232
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collection instances are distinguished in the database by the foreign key of "
 "the entity that owns the collection. This foreign key is referred to as the "
@@ -429,49 +335,34 @@
 "table. The collection key column is mapped by the <literal>&lt;key&gt;</"
 "literal> element."
 msgstr ""
-"Les instances d'une collection sont distinguées dans la base par la clef "
-"étrangère de l'entité qui possède la collection. Cette clef étrangère est "
-"référencée comme la(es) <emphasis>colonne(s) de la clef de la collection</"
-"emphasis> de la table de la collection. La colonne de la clef de la "
+"Les instances d'une collection sont distinguées dans la base de données par "
+"la clé étrangère de l'entité qui possède la collection. Cette clé étrangère "
+"est référencée comme la(es) <emphasis>colonne(s) de la clé de la collection</"
+"emphasis> de la table de la collection. La colonne de la clé de la "
 "collection est mappée par l'élément <literal>&lt;key&gt;</literal>."
 
 #. Tag: para
-#: collection_mapping.xml:240
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There can be a nullability constraint on the foreign key column. For most "
 "collections, this is implied. For unidirectional one-to-many associations, "
 "the foreign key column is nullable by default, so you may need to specify "
 "<literal>not-null=\"true\"</literal>."
 msgstr ""
-"Il peut y avoir une contrainte de nullité sur la colonne de la clef "
-"étrangère. Pour les associations unidirectionnelles un vers plusieurs, la "
-"colonne de la clef étrangère peut être nulle par défaut, donc vous pourriez "
-"avoir besoin de spécifier <literal>not-null=\"true\"</literal>."
+"Il peut y avoir une contrainte de nullité sur la colonne de la clé "
+"étrangère. Pour les associations unidirectionnelles un-à-plusieurs, la "
+"colonne de la clé étrangère peut être nulle par défaut, donc vous pourriez "
+"avoir besoin de spécifier <literal>not-null=\"true\"</literal>. "
 
-#. Tag: programlisting
-#: collection_mapping.xml:247
-#, no-c-format
-msgid "<![CDATA[<key column=\"productSerialNumber\" not-null=\"true\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:249
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The foreign key constraint can use <literal>ON DELETE CASCADE</literal>."
 msgstr ""
-"La contraite de la clef étrangère peut utiliser <literal>ON DELETE CASCADE</"
-"literal>."
+"La contraite de la clé étrangère peut utiliser <literal>ON DELETE CASCADE</"
+"literal>. "
 
-#. Tag: programlisting
-#: collection_mapping.xml:253
-#, no-c-format
-msgid "<![CDATA[<key column=\"productSerialNumber\" on-delete=\"cascade\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:255
 #, no-c-format
 msgid ""
 "See the previous chapter for a full definition of the <literal>&lt;key&gt;</"
@@ -481,14 +372,12 @@
 "<literal>&lt;key&gt;</literal>."
 
 #. Tag: title
-#: collection_mapping.xml:263
 #, no-c-format
 msgid "Collection elements"
 msgstr "Les éléments d'une collection"
 
 #. Tag: para
-#: collection_mapping.xml:265
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collections can contain almost any other Hibernate type, including: basic "
 "types, custom types, components and references to other entities. This is an "
@@ -498,17 +387,17 @@
 "latter case, only the \"link\" between the two objects is considered to be a "
 "state held by the collection."
 msgstr ""
-"Les collections peuvent contenir la plupart des autres types Hibernate, dont "
-"tous les types basiques, les types utilisateur, les composants, et bien sûr, "
-"les références vers d'autres entités. C'est une distinction importante : un "
-"objet dans une collection pourrait être géré avec une sémantique de \"valeur"
-"\" (sa durée de vie dépend complètement du propriétaire de la collection) ou "
-"il pourrait avoir une référence vers une autre entité, avec sa propre durée "
-"de vie. Dans le dernier cas, seul le \"lien\" entre les 2 objets est "
-"considéré être l'état retenu par la collection."
+"Les collections peuvent contenir la plupart des autres types Hibernate, y "
+"compris tous les types basiques, les types utilisateur, les composants, et "
+"bien sûr, les références vers d'autres entités. C'est une distinction "
+"importante. Un objet dans une collection pourrait être géré avec une "
+"sémantique de \"valeur\" (sa durée de vie dépend complètement du "
+"propriétaire de la collection) ou il pourrait avoir une référence vers une "
+"autre entité, avec sa propre durée de vie. Dans le dernier cas, seul le "
+"\"lien\" entre les deux objets est considéré être l'état retenu par la "
+"collection. "
 
 #. Tag: para
-#: collection_mapping.xml:274
 #, no-c-format
 msgid ""
 "The contained type is referred to as the <emphasis>collection element type</"
@@ -523,18 +412,16 @@
 "<literal>&lt;element&gt;</literal> ou <literal>&lt;composite-element&gt;</"
 "literal>, ou dans le cas des références d'entité, avec <literal>&lt;one-to-"
 "many&gt;</literal> ou <literal>&lt;many-to-many&gt;</literal>. Les deux "
-"premiers mappent des éléments avec un sémantique de valeur, les deux "
+"premiers mappent des éléments avec une sémantique de valeur, les deux "
 "suivants sont utilisés pour mapper des associations d'entité."
 
 #. Tag: title
-#: collection_mapping.xml:286
 #, no-c-format
 msgid "Indexed collections"
 msgstr "Collections indexées"
 
 #. Tag: para
-#: collection_mapping.xml:288
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All collection mappings, except those with set and bag semantics, need an "
 "<emphasis>index column</emphasis> in the collection table. An index column "
@@ -548,70 +435,91 @@
 "index&gt;</literal> element. The mapped column contains sequential integers "
 "that are numbered from zero by default."
 msgstr ""
-"Tous les mappings de collection, exceptés ceux avec les sémantiques "
-"d'ensemble (NdT : set) et de sac (NdT : bag), ont besoin d'une "
-"<emphasis>colonne d'index</emphasis> dans la table de la collection - une "
-"colonne qui mappe un index de tableau, ou un index de <literal>List</"
-"literal>, ou une clef de <literal>Map</literal>. L'index d'une <literal>Map</"
-"literal> peut être n'importe quel type basique, mappé avec <literal>&lt;map-"
-"key&gt;</literal>, ça peut être une référence d'entité mappée avec "
-"<literal>&lt;map-key-many-to-many&gt;</literal>, ou ça peut être un type "
-"composé, mappé avec <literal>&lt;composite-map-key&gt;</literal>. L'index "
-"d'un tableau ou d'une liste est toujours de type <literal>integer</literal> "
-"et est mappé en utilisant l'élément <literal>&lt;list-index&gt;</literal>. "
-"Les colonnes mappées contiennent des entiers séquentiels (numérotés à partir "
-"de zéro par défaut)."
+"Tous les mappages de collection, exceptés ceux avec les sémantiques "
+"d'ensemble (set) et de sac (bag), ont besoin d'une <emphasis>colonne "
+"d'index</emphasis> dans la table de la collection - une colonne qui mappe un "
+"index de tableau, ou un index de <literal>List</literal>, ou une clé de "
+"<literal>Map</literal>. L'index d'une <literal>Map</literal> peut être "
+"n'importe quel type basique, mappé avec <literal>&lt;map-key&gt;</literal>, "
+"ou peut être une référence d'entité mappée avec <literal>&lt;map-key-many-to-"
+"many&gt;</literal>, ou peut être un type composé, mappé avec <literal>&lt;"
+"composite-map-key&gt;</literal>. L'index d'un tableau ou d'une liste est "
+"toujours de type <literal>integer</literal> et est mappé en utilisant "
+"l'élément <literal>&lt;list-index&gt;</literal>. Les colonnes mappées "
+"contiennent des entiers séquentiels (numérotés à partir de zéro par défaut). "
 
-#. Tag: sect2
-#: collection_mapping.xml:299
+#. Tag: para
 #, no-c-format
 msgid ""
-"<programlistingco> <areaspec> <area id=\"index1\" coords=\"2 45\"/> <area id="
-"\"index2\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA[<list-"
-"index \n"
-"        column=\"column_name\"\n"
-"        base=\"0|1|...\"/>]]></programlisting> <calloutlist> <callout "
-"arearefs=\"index1\"> <para> <literal>column_name</literal> (required): the "
-"name of the column holding the collection index values. </para> </callout> "
-"<callout arearefs=\"index1\"> <para> <literal>base</literal> (optional - "
-"defaults to <literal>0</literal>): the value of the index column that "
-"corresponds to the first element of the list or array. </para> </callout> </"
-"calloutlist> </programlistingco> <programlistingco> <areaspec> <area id="
-"\"mapkey1\" coords=\"2 45\"/> <area id=\"mapkey2\" coords=\"3 45\"/> <area "
-"id=\"mapkey3\" coords=\"4 45\"/> </areaspec> <programlisting><![CDATA[<map-"
-"key \n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        type=\"type_name\"\n"
-"        node=\"@attribute-name\"\n"
-"        length=\"N\"/>]]></programlisting> <calloutlist> <callout arearefs="
-"\"mapkey1\"> <para> <literal>column</literal> (optional): the name of the "
-"column holding the collection index values. </para> </callout> <callout "
-"arearefs=\"mapkey2\"> <para> <literal>formula</literal> (optional): a SQL "
-"formula used to evaluate the key of the map. </para> </callout> <callout "
-"arearefs=\"mapkey3\"> <para> <literal>type</literal> (required): the type of "
-"the map keys. </para> </callout> </calloutlist> </programlistingco> "
-"<programlistingco> <areaspec> <area id=\"indexmanytomany1\" coords=\"2 45\"/"
-"> <area id=\"indexmanytomany2\" coords=\"3 45\"/> <area id=\"indexmanytomany3"
-"\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA[<map-key-many-to-"
-"many\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        class=\"ClassName\"\n"
-"/>]]></programlisting> <calloutlist> <callout arearefs=\"indexmanytomany1\"> "
-"<para> <literal>column</literal> (optional): the name of the foreign key "
-"column for the collection index values. </para> </callout> <callout arearefs="
-"\"indexmanytomany2\"> <para> <literal>formula</literal> (optional): a SQ "
-"formula used to evaluate the foreign key of the map key. </para> </callout> "
-"<callout arearefs=\"indexmanytomany3\"> <para> <literal>class</literal> "
-"(required): the entity class used as the map key. </para> </callout> </"
-"calloutlist> </programlistingco>"
+"<literal>column_name</literal> (required): the name of the column holding "
+"the collection index values."
 msgstr ""
+"<literal>column_name</literal> (champ requis): lenom de la lolonne qui "
+"contient les valeurs 'index' de la collection."
 
 #. Tag: para
-#: collection_mapping.xml:380
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
+"<literal>base</literal> (optional - defaults to <literal>0</literal>): the "
+"value of the index column that corresponds to the first element of the list "
+"or array."
+msgstr ""
+"<literal>base</literal> (optionnel - par défaut = <literal>0</literal>) : la "
+"valeur de la colonne 'index' qui correspond au premier élément de la liste "
+"ou de la table."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>column</literal> (optional): the name of the column holding the "
+"collection index values."
+msgstr ""
+"<literal>colonne</literal> (optionnel) : le nom de la colonne qui contient "
+"les valeurs 'index' de la collection."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>formula</literal> (optional): a SQL formula used to evaluate the "
+"key of the map."
+msgstr ""
+"<literal>formula</literal> (optionnel): formule SQL utilisée pour évaluer la "
+"clé de la mappe."
+
+#. Tag: para
+#, no-c-format
+msgid "<literal>type</literal> (required): the type of the map keys."
+msgstr "<literal>type</literal> (requis) : le type de clés de mappe."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>column</literal> (optional): the name of the foreign key column for "
+"the collection index values."
+msgstr ""
+"<literal>colonne</literal> (optionnel) : le nom de la colonne de clés "
+"étrangères pour la collection de valeurs 'index'."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>formula</literal> (optional): a SQ formula used to evaluate the "
+"foreign key of the map key."
+msgstr ""
+"<literal>formula</literal> (optionnel): formule SQ utilisée pour évaluer la "
+"clé étrangère d'une clé de mappe."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>class</literal> (required): the entity class used as the map key."
+msgstr ""
+"<literal>class</literal> (requis) : le nom de la classe utilisée en tant que "
+"clé de mappe."
+
+#. Tag: para
+#, no-c-format
+msgid ""
 "If your table does not have an index column, and you still wish to use "
 "<literal>List</literal> as the property type, you can map the property as a "
 "Hibernate <emphasis>&lt;bag&gt;</emphasis>. A bag does not retain its order "
@@ -621,260 +529,227 @@
 "Si votre table n'a pas de colonne d'index, et que vous souhaitez tout de "
 "même utiliser <literal>List</literal> comme type de propriété, vous devriez "
 "mapper la propriété comme un <emphasis>&lt;bag&gt;</emphasis> Hibernate. Un "
-"sac (NdT : bag) ne garde pas son ordre quand il est récupéré de la base de "
-"données, mais il peut être optionnellement trié ou ordonné."
+"sac (bag) ne garde pas son ordre quand il est récupéré de la base de "
+"données, mais il peut être optionnellement trié ou ordonné. "
 
 #. Tag: title
-#: collection_mapping.xml:390
 #, no-c-format
 msgid "Collections of values and many-to-many associations"
-msgstr "Collections de valeurs et associations plusieurs-vers-plusieurs"
+msgstr "Collections de valeurs et associations plusieurs-à-plusieurs"
 
 #. Tag: para
-#: collection_mapping.xml:392
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Any collection of values or many-to-many associations requires a dedicated "
 "<emphasis>collection table</emphasis> with a foreign key column or columns, "
 "<emphasis>collection element column</emphasis> or columns, and possibly an "
 "index column or columns."
 msgstr ""
-"N'importe quelle collection de valeurs ou association plusieurs-vers-"
-"plusieurs requiert une <emphasis>table de collection</emphasis> avec une"
-"(des) colonne(s) de clef étrangère, une(des) <emphasis>colonne(s) d'élément "
-"de la collection</emphasis> ou des colonnes et possiblement une(des) colonne"
-"(s) d'index."
+"Toute collection de valeurs ou association plusieurs-à-plusieurs requiert "
+"une <emphasis>table de collection</emphasis> avec une(des) colonne(s) de clé "
+"étrangère, une(des) <emphasis>colonne(s) d'élément de la collection</"
+"emphasis> ou des colonnes et éventuellement une(des) colonne(s) d'index. "
 
 #. Tag: para
-#: collection_mapping.xml:399
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For a collection of values use the <literal>&lt;element&gt;</literal> tag. "
 "For example:"
 msgstr ""
 "Pour une collection de valeurs, nous utilisons la balise <literal>&lt;"
-"element&gt;</literal>."
+"element&gt;</literal>. Par exemple :"
 
-#. Tag: sect2
-#: collection_mapping.xml:401
+#. Tag: para
 #, no-c-format
 msgid ""
-"<programlistingco> <areaspec> <area id=\"element1b\" coords=\"2 50\"/> <area "
-"id=\"element2b\" coords=\"3 50\"/> <area id=\"element3b\" coords=\"4 50\"/> "
-"</areaspec> <programlisting><![CDATA[<element\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        type=\"typename\"\n"
-"        length=\"L\"\n"
-"        precision=\"P\"\n"
-"        scale=\"S\"\n"
-"        not-null=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        node=\"element-name\"\n"
-"/>]]></programlisting> <calloutlist> <callout arearefs=\"element1b\"> <para> "
 "<literal>column</literal> (optional): the name of the column holding the "
-"collection element values. </para> </callout> <callout arearefs=\"element2b"
-"\"> <para> <literal>formula</literal> (optional): an SQL formula used to "
-"evaluate the element. </para> </callout> <callout arearefs=\"element3b\"> "
-"<para> <literal>type</literal> (required): the type of the collection "
-"element. </para> </callout> </calloutlist> </programlistingco> <para> A "
-"<emphasis>many-to-many association</emphasis> is specified using the "
-"<literal>&lt;many-to-many&gt;</literal> element. </para> <programlistingco> "
-"<areaspec> <area id=\"manytomany1\" coords=\"2 60\"/> <area id=\"manytomany2"
-"\" coords=\"3 60\"/> <area id=\"manytomany3\" coords=\"4 60\"/> <area id="
-"\"manytomany4\" coords=\"5 60\"/> <area id=\"manytomany5\" coords=\"6 60\"/> "
-"<area id=\"manytomany6\" coords=\"7 60\"/> <area id=\"manytomany7\" coords="
-"\"8 60\"/> <area id=\"manytomany8\" coords=\"9 60\"/> </areaspec> "
-"<programlisting><![CDATA[<many-to-many\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        class=\"ClassName\"\n"
-"        fetch=\"select|join\"\n"
-"        unique=\"true|false\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        node=\"element-name\"\n"
-"        embed-xml=\"true|false\"\n"
-"    />]]></programlisting> <calloutlist> <callout arearefs=\"manytomany1\"> "
-"<para> <literal>column</literal> (optional): the name of the element foreign "
-"key column. </para> </callout> <callout arearefs=\"manytomany2\"> <para> "
-"<literal>formula</literal> (optional): an SQL formula used to evaluate the "
-"element foreign key value. </para> </callout> <callout arearefs=\"manytomany3"
-"\"> <para> <literal>class</literal> (required): the name of the associated "
-"class. </para> </callout> <callout arearefs=\"manytomany4\"> <para> "
-"<literal>fetch</literal> (optional - defaults to <literal>join</literal>): "
-"enables outer-join or sequential select fetching for this association. This "
-"is a special case; for full eager fetching in a single <literal>SELECT</"
-"literal> of an entity and its many-to-many relationships to other entities, "
-"you would enable <literal>join</literal> fetching,not only of the collection "
-"itself, but also with this attribute on the <literal>&lt;many-to-many&gt;</"
-"literal> nested element. </para> </callout> <callout arearefs=\"manytomany5"
-"\"> <para> <literal>unique</literal> (optional): enables the DDL generation "
-"of a unique constraint for the foreign-key column. This makes the "
-"association multiplicity effectively one-to-many. </para> </callout> "
-"<callout arearefs=\"manytomany6\"> <para> <literal>not-found</literal> "
-"(optional - defaults to <literal>exception</literal>): specifies how foreign "
-"keys that reference missing rows will be handled: <literal>ignore</literal> "
-"will treat a missing row as a null association. </para> </callout> <callout "
-"arearefs=\"manytomany7\"> <para> <literal>entity-name</literal> (optional): "
-"the entity name of the associated class, as an alternative to "
-"<literal>class</literal>. </para> </callout> <callout arearefs=\"manytomany8"
-"\"> <para> <literal>property-ref</literal> (optional): the name of a "
-"property of the associated class that is joined to this foreign key. If not "
-"specified, the primary key of the associated class is used. </para> </"
-"callout> </calloutlist> </programlistingco>"
+"collection element values."
 msgstr ""
+"<literal>colonne</literal> (optionnel) : le nom de la colonne qui contient "
+"les valeurs des éléments de collection."
 
 #. Tag: para
-#: collection_mapping.xml:506
 #, no-c-format
-msgid "Here are some examples."
+msgid ""
+"<literal>formula</literal> (optional): an SQL formula used to evaluate the "
+"element."
 msgstr ""
+"<literal>formula</literal> (optionnel) : formule SQL utilisée pour évaluer "
+"l'élément."
 
 #. Tag: para
-#: collection_mapping.xml:509
 #, no-c-format
-msgid "A set of strings:"
+msgid "<literal>type</literal> (required): the type of the collection element."
+msgstr "<literal>type</literal> (requis) : le type d'élément de collection."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"A <emphasis>many-to-many association</emphasis> is specified using the "
+"<literal>&lt;many-to-many&gt;</literal> element."
 msgstr ""
+"Une association <emphasis>many-to-many</emphasis> est spécifiée en utilisant "
+"l'élément <literal>&lt;many-to-many&gt;</literal>."
 
-#. Tag: programlisting
-#: collection_mapping.xml:513
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"names\" table=\"person_names\">\n"
-"    <key column=\"person_id\"/>\n"
-"    <element column=\"person_name\" type=\"string\"/>\n"
-"</set>]]>"
+"<literal>column</literal> (optional): the name of the element foreign key "
+"column."
 msgstr ""
+"<literal>colonne</literal> (optionnel) : le nom de la colonne de clés "
+"étrangères des éléments."
 
 #. Tag: para
-#: collection_mapping.xml:515
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"A bag containing integers with an iteration order determined by the "
-"<literal>order-by</literal> attribute:"
+"<literal>formula</literal> (optional): an SQL formula used to evaluate the "
+"element foreign key value."
 msgstr ""
-"Un bag contenant des entiers (avec un ordre d'itération déterminé par "
-"l'attribut <literal>order-by</literal>) :"
+"<literal>formula</literal> (optionnel): formule SQL utilisée pour évaluer la "
+"valeur des clés étrangères des éléments."
 
-#. Tag: programlisting
-#: collection_mapping.xml:520
+#. Tag: para
 #, no-c-format
+msgid "<literal>class</literal> (required): the name of the associated class."
+msgstr "<literal>class</literal> (requis) : le nom de la classe associée."
+
+#. Tag: para
+#, no-c-format
 msgid ""
-"<![CDATA[<bag name=\"sizes\" \n"
-"        table=\"item_sizes\" \n"
-"        order-by=\"size asc\">\n"
-"    <key column=\"item_id\"/>\n"
-"    <element column=\"size\" type=\"integer\"/>\n"
-"</bag>]]>"
+"<literal>fetch</literal> (optional - defaults to <literal>join</literal>): "
+"enables outer-join or sequential select fetching for this association. This "
+"is a special case; for full eager fetching in a single <literal>SELECT</"
+"literal> of an entity and its many-to-many relationships to other entities, "
+"you would enable <literal>join</literal> fetching,not only of the collection "
+"itself, but also with this attribute on the <literal>&lt;many-to-many&gt;</"
+"literal> nested element."
 msgstr ""
+"<literal>fetch</literal> (optionnel - par défaut <literal>join</literal>): "
+"permet la récupération par jointures externes ou bien par selects "
+"séquentiels pour cette association. Il s'agit d'un cas particulier de "
+"récupération. Pour que la récupération soit toujours rapportée en un seul "
+"<literal>SELECT</literal> d'entité ou à partir de ses relations many-to-many "
+"à d'autres entités, vous devrez activer la récupération <literal>join</"
+"literal>, non seulement pour la collection elle-même, mais aussi avec cet "
+"attribut qui se trouve sur l'élément <literal>&lt;many-to-many&gt;</literal>."
 
 #. Tag: para
-#: collection_mapping.xml:522
-#, fuzzy, no-c-format
-msgid "An array of entities, in this case, a many-to-many association:"
+#, no-c-format
+msgid ""
+"<literal>unique</literal> (optional): enables the DDL generation of a unique "
+"constraint for the foreign-key column. This makes the association "
+"multiplicity effectively one-to-many."
 msgstr ""
-"Un tableau d'entités - dans ce cas, une association plusieurs-vers-"
-"plusieurs :"
+"<literal>unique</literal> (optionnel): permet la génération DDL d'une seule "
+"contrainte pour la colonne de la clé étrangère. Cela transforme la "
+"muticiplicité de l'association en one-to-many."
 
-#. Tag: programlisting
-#: collection_mapping.xml:526
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<array name=\"addresses\" \n"
-"        table=\"PersonAddress\" \n"
-"        cascade=\"persist\">\n"
-"    <key column=\"personId\"/>\n"
-"    <list-index column=\"sortOrder\"/>\n"
-"    <many-to-many column=\"addressId\" class=\"Address\"/>\n"
-"</array>]]>"
+"<literal>not-found</literal> (optional - defaults to <literal>exception</"
+"literal>): specifies how foreign keys that reference missing rows will be "
+"handled: <literal>ignore</literal> will treat a missing row as a null "
+"association."
 msgstr ""
+"<literal>not-found</literal> (optionnel - par défaut <literal>exception</"
+"literal>) : spécifie comment les clés étrangères cachées qui référencent des "
+"lignes manquantes seront gérées : <literal>ignore</literal> traitera une "
+"ligne manquante comme une association nulle."
 
 #. Tag: para
-#: collection_mapping.xml:528
 #, no-c-format
-msgid "A map from string indices to dates:"
-msgstr "Une map de chaînes de caractères vers des dates :"
+msgid ""
+"<literal>entity-name</literal> (optional): the entity name of the associated "
+"class, as an alternative to <literal>class</literal>."
+msgstr ""
+"<literal>entity-name</literal> (optionnel) : le nom de l'entité de la classe "
+"associée, comme une alternative à <literal>class</literal>. "
 
-#. Tag: programlisting
-#: collection_mapping.xml:532
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<map name=\"holidays\" \n"
-"        table=\"holidays\" \n"
-"        schema=\"dbo\" \n"
-"        order-by=\"hol_name asc\">\n"
-"    <key column=\"id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date\" type=\"date\"/>\n"
-"</map>]]>"
+"<literal>property-ref</literal> (optional): the name of a property of the "
+"associated class that is joined to this foreign key. If not specified, the "
+"primary key of the associated class is used."
 msgstr ""
+"<literal>property-ref</literal> (optionnel): nom d'une propriété de la "
+"classe associée associée à une clé étrangère. Si elle n'est pas précisée, la "
+"clé primaire de la classe associée sera alors utilisée."
 
 #. Tag: para
-#: collection_mapping.xml:534
-#, fuzzy, no-c-format
-msgid "A list of components (this is discussed in the next chapter):"
-msgstr "Une liste de composants (discute dans le prochain chapitre) :"
+#, no-c-format
+msgid "Here are some examples."
+msgstr "Voici quelques exemples :"
 
-#. Tag: programlisting
-#: collection_mapping.xml:538
+#. Tag: para
 #, no-c-format
+msgid "A set of strings:"
+msgstr "Un ensemble de chaînes de caractères :"
+
+#. Tag: para
+#, no-c-format
 msgid ""
-"<![CDATA[<list name=\"carComponents\" \n"
-"        table=\"CarComponents\">\n"
-"    <key column=\"carId\"/>\n"
-"    <list-index column=\"sortOrder\"/>\n"
-"    <composite-element class=\"CarComponent\">\n"
-"        <property name=\"price\"/>\n"
-"        <property name=\"type\"/>\n"
-"        <property name=\"serialNumber\" column=\"serialNum\"/>\n"
-"    </composite-element>\n"
-"</list>]]>"
+"A bag containing integers with an iteration order determined by the "
+"<literal>order-by</literal> attribute:"
 msgstr ""
+"Un sac contenant des entiers (avec un ordre d'itération déterminé par "
+"l'attribut <literal>order-by</literal>) : "
 
+#. Tag: para
+#, no-c-format
+msgid "An array of entities, in this case, a many-to-many association:"
+msgstr ""
+"Un tableau d'entités - dans ce cas, une association plusieurs-à-plusieurs : "
+
+#. Tag: para
+#, no-c-format
+msgid "A map from string indices to dates:"
+msgstr "Une map de chaînes de caractères vers des dates :"
+
+#. Tag: para
+#, no-c-format
+msgid "A list of components (this is discussed in the next chapter):"
+msgstr "Une liste de composants (traité dans le prochain chapitre) : "
+
 #. Tag: title
-#: collection_mapping.xml:543
 #, no-c-format
 msgid "One-to-many associations"
-msgstr "Association un-vers-plusieurs"
+msgstr "Associations un-à-plusieurs"
 
 #. Tag: para
-#: collection_mapping.xml:545
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>one-to-many association</emphasis> links the tables of two "
 "classes via a foreign key with no intervening collection table. This mapping "
 "loses certain semantics of normal Java collections:"
 msgstr ""
-"Une <emphasis>association un vers plusieurs</emphasis> lie les tables de "
-"deux classes par une clef étrangère, sans l'intervention d'une table de "
-"collection. Ce mapping perd certaines sémantiques des collections Java "
-"normales :"
+"Une <emphasis>association un-à-plusieurs</emphasis> lie les tables de deux "
+"classes par une clé étrangère, sans l'intervention d'une table de "
+"collection. Ce mappage perd certaines sémantiques des collections Java "
+"normales : "
 
 #. Tag: para
-#: collection_mapping.xml:553
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of the contained entity class cannot belong to more than one "
 "instance of the collection."
 msgstr ""
 "Une instance de la classe de l'entité contenue ne peut pas appartenir à plus "
-"d'une instance de la collection"
+"d'une instance de la collection."
 
 #. Tag: para
-#: collection_mapping.xml:559
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of the contained entity class cannot appear at more than one "
 "value of the collection index."
 msgstr ""
-"Une instance de la classe de l'entité contenue ne peut pas apparaître plus "
-"plus d'une valeur d'index de la collection"
+"Une instance de la classe de l'entité contenue peut ne pas apparaître à plus "
+"plus d'une valeur d'index de la collection."
 
 #. Tag: para
-#: collection_mapping.xml:566
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An association from <literal>Product</literal> to <literal>Part</literal> "
 "requires the existence of a foreign key column and possibly an index column "
@@ -882,33 +757,13 @@
 "literal> tag indicates that this is a one-to-many association."
 msgstr ""
 "Une association de <literal>Product</literal> vers <literal>Part</literal> "
-"requiert l'existence d'une clef étrangère et possiblement une colonne "
+"requiert l'existence d'une clé étrangère et éventuellement une colonne "
 "d'index pour la table <literal>Part</literal>. Une balise <literal>&lt;one-"
-"to-many&gt;</literal> indique que c'est une association un vers plusieurs."
+"to-many&gt;</literal> indique que c'est une association un-à-plusieurs. "
 
-#. Tag: programlisting
-#: collection_mapping.xml:579
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<one-to-many \n"
-"        class=\"ClassName\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\"\n"
-"        embed-xml=\"true|false\"\n"
-"    />]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:582
-#, fuzzy, no-c-format
-msgid "<literal>class</literal> (required): the name of the associated class."
-msgstr "<literal>class</literal> (requis) : le nom de la classe associée"
-
-#. Tag: para
-#: collection_mapping.xml:587
-#, fuzzy, no-c-format
-msgid ""
 "<literal>not-found</literal> (optional - defaults to <literal>exception</"
 "literal>): specifies how cached identifiers that reference missing rows will "
 "be handled. <literal>ignore</literal> will treat a missing row as a null "
@@ -917,37 +772,21 @@
 "<literal>not-found</literal> (optionnel - par défaut <literal>exception</"
 "literal>) : spécifie comment les identifiants cachés qui référencent des "
 "lignes manquantes seront gérés : <literal>ignore</literal> traitera une "
-"ligne manquante comme une association nulle"
+"ligne manquante comme une association nulle."
 
 #. Tag: para
-#: collection_mapping.xml:594
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"<literal>entity-name</literal> (optional): the entity name of the associated "
-"class, as an alternative to <literal>class</literal>."
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>entity-name</literal> (optionnel) : le nom de l'entité de la classe "
-"associée, comme une alternative à <literal>class</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>entity-name</literal> (optionnel) : le nom de l'entité de la classe "
-"associée, comme une alternative à <literal>class</literal>."
-
-#. Tag: para
-#: collection_mapping.xml:602
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>&lt;one-to-many&gt;</literal> element does not need to declare "
 "any columns. Nor is it necessary to specify the <literal>table</literal> "
 "name anywhere."
 msgstr ""
 "Notez que l'élément <literal>&lt;one-to-many&gt;</literal> n'a pas besoin de "
 "déclarer de colonnes. Il n'est pas non plus nécessaire de spécifier le nom "
-"de la table nulle part."
+"de la <literal>table</literal> à aucun endroit."
 
 #. Tag: para
-#: collection_mapping.xml:609
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the foreign key column of a <literal>&lt;one-to-many&gt;</literal> "
 "association is declared <literal>NOT NULL</literal>, you must declare the "
@@ -956,17 +795,16 @@
 "mapping marked <literal>inverse=\"true\"</literal>. See the discussion of "
 "bidirectional associations later in this chapter for more information."
 msgstr ""
-"<emphasis>Note très importante :</emphasis> si la colonne de la clef d'une "
+"<emphasis>Note très importante :</emphasis> si la colonne de la clé d'une "
 "association <literal>&lt;one-to-many&gt;</literal> est déclarée <literal>NOT "
-"NULL</literal>, vous devez déclarer le mapping de <literal>&lt;key&gt;</"
-"literal> avec <literal>not-null=\"true\"</literal> ou <emphasis>utiliser une "
-"association bidirectionnelle</emphasis> avec le mapping de la collection "
-"marqué <literal>inverse=\"true\"</literal>. Voir la discussion sur les "
-"associations bidirectionnelles plus tard dans ce chapitre."
+"NULL</literal>, vous devez déclarer le mappage de <literal>&lt;key&gt;</"
+"literal> avec <literal>not-null=\"true\"</literal> ou <emphasis> utiliser "
+"une association bidirectionnelle </emphasis> avec le mappage de la "
+"collection marqué <literal>inverse=\"true\"</literal>. Voir la discussion "
+"sur les associations bidirectionnelles plus tard dans ce chapitre. "
 
 #. Tag: para
-#: collection_mapping.xml:619
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following example shows a map of <literal>Part</literal> entities by "
 "name, where <literal>partName</literal> is a persistent property of "
@@ -974,34 +812,19 @@
 msgstr ""
 "Cet exemple montre une map d'entités <literal>Part</literal> par nom (où "
 "<literal>partName</literal> est une propriété persistante de <literal>Part</"
-"literal>). Notez l'utilisation d'un index basé sur une formule."
+"literal>). Notez l'utilisation d'un index basé sur une formule :"
 
-#. Tag: programlisting
-#: collection_mapping.xml:625
-#, no-c-format
-msgid ""
-"<![CDATA[<map name=\"parts\"\n"
-"        cascade=\"all\">\n"
-"    <key column=\"productId\" not-null=\"true\"/>\n"
-"    <map-key formula=\"partName\"/>\n"
-"    <one-to-many class=\"Part\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:631
 #, no-c-format
 msgid "Advanced collection mappings"
-msgstr "Mappings de collection avancés"
+msgstr "Mappages de collection avancés"
 
 #. Tag: title
-#: collection_mapping.xml:634
 #, no-c-format
 msgid "Sorted collections"
 msgstr "Collections triées"
 
 #. Tag: para
-#: collection_mapping.xml:636
 #, no-c-format
 msgid ""
 "Hibernate supports collections implementing <literal>java.util.SortedMap</"
@@ -1010,28 +833,9 @@
 msgstr ""
 "Hibernate supporte des collections implémentant <literal>java.util."
 "SortedMap</literal> et <literal>java.util.SortedSet</literal>. Vous devez "
-"spécifier un comparateur dans le fichier de mapping :"
+"spécifier un comparateur dans le fichier de mappage :"
 
-#. Tag: programlisting
-#: collection_mapping.xml:641
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"aliases\" \n"
-"            table=\"person_aliases\" \n"
-"            sort=\"natural\">\n"
-"    <key column=\"person\"/>\n"
-"    <element column=\"name\" type=\"string\"/>\n"
-"</set>\n"
-"\n"
-"<map name=\"holidays\" sort=\"my.custom.HolidayComparator\">\n"
-"    <key column=\"year_id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date\" type=\"date\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:643
 #, no-c-format
 msgid ""
 "Allowed values of the <literal>sort</literal> attribute are "
@@ -1043,7 +847,6 @@
 "classe implémentant <literal>java.util.Comparator</literal>."
 
 #. Tag: para
-#: collection_mapping.xml:649
 #, no-c-format
 msgid ""
 "Sorted collections actually behave like <literal>java.util.TreeSet</literal> "
@@ -1053,8 +856,7 @@
 "TreeSet</literal> ou <literal>java.util.TreeMap</literal>."
 
 #. Tag: para
-#: collection_mapping.xml:654
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want the database itself to order the collection elements, use the "
 "<literal>order-by</literal> attribute of <literal>set</literal>, "
@@ -1064,191 +866,113 @@
 "performs the ordering in the SQL query and not in the memory."
 msgstr ""
 "Si vous voulez que la base de données elle-même ordonne les éléments de la "
-"collection, utilisez l'attribut <literal>order-by</literal> des mappings "
+"collection, utilisez l'attribut <literal>order-by</literal> des mappages "
 "<literal>set</literal>, <literal>bag</literal> ou <literal>map</literal>. "
 "Cette solution est seulement disponible à partir du JDK 1.4 (c'est "
 "implémenté en utilisant <literal>LinkedHashSet</literal> ou "
 "<literal>LinkedHashMap</literal>). Ceci exécute le tri dans la requête SQL, "
-"pas en mémoire."
+"pas en mémoire. "
 
-#. Tag: programlisting
-#: collection_mapping.xml:663
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"aliases\" table=\"person_aliases\" order-by=\"lower"
-"(name) asc\">\n"
-"    <key column=\"person\"/>\n"
-"    <element column=\"name\" type=\"string\"/>\n"
-"</set>\n"
-"\n"
-"<map name=\"holidays\" order-by=\"hol_date, hol_name\">\n"
-"    <key column=\"year_id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date type=\"date\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:666
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Note"
 
 #. Tag: para
-#: collection_mapping.xml:667
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The value of the <literal>order-by</literal> attribute is an SQL ordering, "
 "not an HQL ordering."
 msgstr ""
 "Notez que la valeur de l'attribut <literal>order-by</literal> est un ordre "
-"SQL, pas un ordre HQL !"
+"SQL, et non pas un ordre HQL."
 
 #. Tag: para
-#: collection_mapping.xml:673
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Associations can even be sorted by arbitrary criteria at runtime using a "
 "collection <literal>filter()</literal>:"
 msgstr ""
 "Les associations peuvent même être triées sur des critères arbitraires à "
-"l'exécution en utilisant un <literal>filter()</literal> de collection."
+"l'exécution en utilisant un <literal>filter()</literal> de collection :"
 
-#. Tag: programlisting
-#: collection_mapping.xml:678
-#, no-c-format
-msgid ""
-"<![CDATA[sortedUsers = s.createFilter( group.getUsers(), \"order by this.name"
-"\" ).list();]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:683
 #, no-c-format
 msgid "Bidirectional associations"
 msgstr "Associations bidirectionnelles"
 
 #. Tag: para
-#: collection_mapping.xml:685
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional association</emphasis> allows navigation from both "
 "\"ends\" of the association. Two kinds of bidirectional association are "
 "supported:"
 msgstr ""
-"Une <emphasis>association bidirectionnelle</emphasis> permet une navigation "
-"à partir de la \"fin\" de l'association. Deux sortes d'associations "
-"bidirectionnelles sont supportées : <placeholder-1/>"
+"Une <emphasis>association bidirectionnelle</emphasis> permet la navigation à "
+"partir des deux extrémités de l'association. Deux types d'associations "
+"bidirectionnelles sont supportées : "
 
 #. Tag: term
-#: collection_mapping.xml:692
 #, no-c-format
 msgid "one-to-many"
-msgstr "un-vers-plusieurs (NdT : one-to-many)"
+msgstr "un-à-plusieurs (one-to-many)"
 
 #. Tag: para
-#: collection_mapping.xml:694
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "set or bag valued at one end and single-valued at the other"
-msgstr "ensemble ou sac à une extrémité, une seule valeur à l'autre"
+msgstr "ensemble ou sac à une extrémité, une seule valeur à l'autre "
 
 #. Tag: term
-#: collection_mapping.xml:700
 #, no-c-format
 msgid "many-to-many"
-msgstr "plusieurs-vers-plusieurs (NdT : many-to-many)"
+msgstr "plusieurs-à-plusieurs "
 
 #. Tag: para
-#: collection_mapping.xml:702
 #, no-c-format
 msgid "set or bag valued at both ends"
 msgstr "ensemble ou sac aux deux extrémités"
 
 #. Tag: para
-#: collection_mapping.xml:711
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can specify a bidirectional many-to-many association by mapping two many-"
 "to-many associations to the same database table and declaring one end as "
 "<emphasis>inverse</emphasis>. You cannot select an indexed collection."
 msgstr ""
-"Vous pouvez spécifier une association plusieurs-vers-plusieurs "
-"bidirectionnelle simplement en mappant deux associations plusieurs-vers-"
-"plusieurs vers la même table de base de données et en déclarant une "
-"extrémité comme <emphasis>inverse</emphasis> (celle de votre choix, mais ça "
-"ne peut pas être une collection indexée)."
+"Vous pouvez spécifier une association bidirectionnelle plusieurs-à-plusieurs "
+"simplement en mappant deux associations plusieurs-à-plusieurs vers la même "
+"table de base de données et en déclarant une extrémité comme "
+"<emphasis>inverse</emphasis> (celle de votre choix, mais pas une collection "
+"indexée). "
 
 #. Tag: para
-#: collection_mapping.xml:718
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Here is an example of a bidirectional many-to-many association that "
 "illustrates how each category can have many items and each item can be in "
 "many categories:"
 msgstr ""
-"Voici un exemple d'association bidirectionnelle plusieurs-vers-plusieurs ; "
+"Voici un exemple d'association bidirectionnelle plusieurs-à-plusieurs ; "
 "chaque catégorie peut avoir plusieurs objets et chaque objet peut être dans "
-"plusieurs catégories :"
+"plusieurs catégories : "
 
-#. Tag: programlisting
-#: collection_mapping.xml:723
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Category\">\n"
-"    <id name=\"id\" column=\"CATEGORY_ID\"/>\n"
-"    ...\n"
-"    <bag name=\"items\" table=\"CATEGORY_ITEM\">\n"
-"        <key column=\"CATEGORY_ID\"/>\n"
-"        <many-to-many class=\"Item\" column=\"ITEM_ID\"/>\n"
-"    </bag>\n"
-"</class>\n"
-"\n"
-"<class name=\"Item\">\n"
-"    <id name=\"id\" column=\"ITEM_ID\"/>\n"
-"    ...\n"
-"\n"
-"    <!-- inverse end -->\n"
-"    <bag name=\"categories\" table=\"CATEGORY_ITEM\" inverse=\"true\">\n"
-"        <key column=\"ITEM_ID\"/>\n"
-"        <many-to-many class=\"Category\" column=\"CATEGORY_ID\"/>\n"
-"    </bag>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:725
-#, fuzzy, no-c-format
-msgid ""
 "Changes made only to the inverse end of the association are <emphasis>not</"
 "emphasis> persisted. This means that Hibernate has two representations in "
 "memory for every bidirectional association: one link from A to B and another "
 "link from B to A. This is easier to understand if you think about the Java "
 "object model and how a many-to-many relationship in Javais created:"
 msgstr ""
-"Les changements faits uniquement sur l'extréminté inverse de l'association "
+"Les changements faits uniquement sur l'extrémité inverse de l'association "
 "<emphasis>ne sont pas</emphasis> persistés. Ceci signifie qu'Hibernate a "
-"deux représentations en mémoire pour chaque association bidirectionnelles, "
-"un lien de A vers B et un autre de B vers A. C'est plus facile à comprendre "
-"si vous pensez au modèle objet de Java et comment nous créons une relation "
-"plusieurs-vers-plusieurs en Java :"
+"deux représentations en mémoire pour chaque association bidirectionnelle, un "
+"lien de A vers B et un autre de B vers A. Ceci est plus facile à comprendre "
+"si vous pensez au modèle objet de Java et à la façon dont nous créons une "
+"relation plusieurs-à-plusieurs dans Java : "
 
-#. Tag: programlisting
-#: collection_mapping.xml:733
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"category.getItems().add(item);          // The category now \"knows\" about "
-"the relationship\n"
-"item.getCategories().add(category);     // The item now \"knows\" about the "
-"relationship\n"
-"\n"
-"session.persist(item);                   // The relationship won't be "
-"saved!\n"
-"session.persist(category);               // The relationship will be saved]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:735
 #, no-c-format
 msgid ""
 "The non-inverse side is used to save the in-memory representation to the "
@@ -1258,61 +982,34 @@
 "mémoire dans la base de données."
 
 #. Tag: para
-#: collection_mapping.xml:739
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can define a bidirectional one-to-many association by mapping a one-to-"
 "many association to the same table column(s) as a many-to-one association "
 "and declaring the many-valued end <literal>inverse=\"true\"</literal>."
 msgstr ""
-"Vous pouvez définir une association un-vers-plusieurs bidirectionnelle en "
-"mappant une association un-vers-plusieurs vers la(es) même(s) colonne(s) de "
-"table qu'une association plusieurs-vers-un et en déclarant l'extrémité pluri-"
-"valuée <literal>inverse=\"true\"</literal>."
+"Vous pouvez définir une association bidirectionnelle un-à-plusieurs en "
+"mappant une association un-à-plusieurs vers la(es) même(s) colonne(s) de "
+"table qu'une association plusieurs-à-un et en déclarant l'extrémité pluri-"
+"valuée <literal>inverse=\"true\"</literal>. "
 
-#. Tag: programlisting
-#: collection_mapping.xml:745
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <set name=\"children\" inverse=\"true\">\n"
-"        <key column=\"parent_id\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:747
-#, fuzzy, no-c-format
-msgid ""
 "Mapping one end of an association with <literal>inverse=\"true\"</literal> "
 "does not affect the operation of cascades as these are orthogonal concepts."
 msgstr ""
 "Mapper une extrémité d'une association avec <literal>inverse=\"true\"</"
 "literal> n'affecte pas l'opération de cascades, ce sont des concepts "
-"orthogonaux !"
+"orthogonaux."
 
 #. Tag: title
-#: collection_mapping.xml:755
 #, no-c-format
 msgid "Bidirectional associations with indexed collections"
 msgstr "Associations bidirectionnelles avec des collections indexées"
 
 #. Tag: para
-#: collection_mapping.xml:756
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A bidirectional association where one end is represented as a <literal>&lt;"
 "list&gt;</literal> or <literal>&lt;map&gt;</literal>, requires special "
@@ -1322,162 +1019,77 @@
 msgstr ""
 "Une association bidirectionnelle où une extrémité est représentée comme une "
 "<literal>&lt;list&gt;</literal> ou une <literal>&lt;map&gt;</literal> "
-"requiert une considération spéciale. Si il y a une propriété de la classe "
+"requiert une considération spéciale. S'il y a une propriété de la classe "
 "enfant qui mappe la colonne de l'index, pas de problème, nous pouvons "
-"continuer à utiliser <literal>inverse=\"true\"</literal> sur le mapping de "
-"la collection :"
+"continuer à utiliser <literal>inverse=\"true\"</literal> sur le mappage de "
+"la collection : "
 
-#. Tag: programlisting
-#: collection_mapping.xml:763
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <map name=\"children\" inverse=\"true\">\n"
-"        <key column=\"parent_id\"/>\n"
-"        <map-key column=\"name\" \n"
-"            type=\"string\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </map>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <property name=\"name\" \n"
-"        not-null=\"true\"/>\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:765
-#, fuzzy, no-c-format
-msgid ""
 "If there is no such property on the child class, the association cannot be "
 "considered truly bidirectional. That is, there is information available at "
 "one end of the association that is not available at the other end. In this "
 "case, you cannot map the collection <literal>inverse=\"true\"</literal>. "
 "Instead, you could use the following mapping:"
 msgstr ""
-"Mais, si il n'y a pas de telle prorpriété sur la classe enfant, nous ne "
-"pouvons pas penser à l'association comme vraiment bidirectionnelle (il y a "
+"Mais, si il n'y a pas de telle propriété sur la classe enfant, nous ne "
+"pouvons pas considérer l'association comme vraiment bidirectionnelle (il y a "
 "des informations disponibles à une extrémité de l'association qui ne sont "
 "pas disponibles à l'autre extrémité). Dans ce cas, nous ne pouvons pas "
-"mapper la collection <literal>inverse=\"true\"</literal>. À la place, nous "
-"pourrions utiliser le mapping suivant :"
+"mapper la collection <literal>inverse=\"true\"</literal>. Par contre, nous "
+"utiliserons le mappage suivant : "
 
-#. Tag: programlisting
-#: collection_mapping.xml:772
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <map name=\"children\">\n"
-"        <key column=\"parent_id\"\n"
-"            not-null=\"true\"/>\n"
-"        <map-key column=\"name\" \n"
-"            type=\"string\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </map>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        insert=\"false\"\n"
-"        update=\"false\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:774
 #, fuzzy, no-c-format
 msgid ""
 "Note that in this mapping, the collection-valued end of the association is "
 "responsible for updates to the foreign key."
 msgstr ""
-"Notez que dans ce mapping, l'extrémité de l'association contenant la "
-"collection est responsable des mises à jour de la clef étrangère. À faire : "
-"cela entraîne-t-il réellement des expressions updates inutiles ?"
+"Notez que dans ce mappage, l'extrémité de l'association contenant la "
+"collection est responsable des mise à jour de la clé étrangère. <!-- TODO: "
+"Does this really result in some unnecessary update statements? -->"
 
 #. Tag: title
-#: collection_mapping.xml:782
 #, no-c-format
 msgid "Ternary associations"
 msgstr "Associations ternaires"
 
 #. Tag: para
-#: collection_mapping.xml:784
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are three possible approaches to mapping a ternary association. One "
 "approach is to use a <literal>Map</literal> with an association as its index:"
 msgstr ""
 "Il y a trois approches possibles pour mapper une association ternaire. L'une "
-"est d'utiliser une <literal>Map</literal> avec une association en tant "
-"qu'index :"
+"est d'utiliser une <literal>Map</literal> avec une association comme son "
+"index : "
 
-#. Tag: programlisting
-#: collection_mapping.xml:789
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<map name=\"contracts\">\n"
-"    <key column=\"employer_id\" not-null=\"true\"/>\n"
-"    <map-key-many-to-many column=\"employee_id\" class=\"Employee\"/>\n"
-"    <one-to-many class=\"Contract\"/>\n"
-"</map>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: collection_mapping.xml:791
-#, no-c-format
-msgid ""
-"<![CDATA[<map name=\"connections\">\n"
-"    <key column=\"incoming_node_id\"/>\n"
-"    <map-key-many-to-many column=\"outgoing_node_id\" class=\"Node\"/>\n"
-"    <many-to-many column=\"connection_id\" class=\"Connection\"/>\n"
-"</map>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:793
-#, fuzzy, no-c-format
-msgid ""
 "A second approach is to remodel the association as an entity class. This is "
 "the most common approach."
 msgstr ""
 "Une seconde approche est simplement de remodeler l'association comme une "
-"classe d'entité. C'est l'approche la plus commune."
+"classe d'entité. C'est l'approche la plus commune. "
 
 #. Tag: para
-#: collection_mapping.xml:798
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A final alternative is to use composite elements, which will be discussed "
 "later."
 msgstr ""
 "Une alternative finale est d'utiliser des éléments composites, dont nous "
-"discuterons plus tard."
+"discuterons plus tard. "
 
-#. Tag: literal
-#: collection_mapping.xml:805
-#, no-c-format
-msgid "Using an &lt;idbag&gt;"
-msgstr "Utiliser un <literal>&lt;idbag&gt;</literal>"
+#. Tag: title
+#, fuzzy, no-c-format
+msgid "<literal>Using an &lt;idbag&gt;</literal>"
+msgstr "<literal>Using an &lt;idbag&gt;</literal>"
 
 #. Tag: para
-#: collection_mapping.xml:807
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The majority of the many-to-many associations and collections of values "
 "shown previously all map to tables with composite keys, even though it has "
@@ -1488,60 +1100,44 @@
 "feature that allows you to map many-to-many associations and collections of "
 "values to a table with a surrogate key."
 msgstr ""
-"Si vous embrassez pleinement notre vue que les clefs composées sont une "
-"mauvaise chose et que des entités devraient avoir des identifiants "
-"artificiels (des clefs subrogées), alors vous pourriez trouver un peu "
-"curieux que les associations plusieurs-vers-plusieurs et les collections de "
-"valeurs que nous avons montré jusqu'ici mappent toutes des tables avec des "
-"clefs composées ! Maintenant, ce point est assez discutable ; une table "
-"d'association pure ne semble pas beaucoup bénéficier d'une clef subrogée "
-"(bien qu'une collection de valeur composées le <emphasis>pourrait</"
-"emphasis>). Néanmoins, Hibernate fournit une foncionnalité qui vous permet "
-"de mapper des associations plusieurs-vers-plusieurs et des collections de "
-"valeurs vers une table avec une clef subrogée."
+"Si vous êtes bien d'accord avec nous sur le fait que les clés composées sont "
+"une mauvaise chose et que les entités devraient avoir des identifiants "
+"artificiels (des clés subrogées), vous pourrez trouver un peu curieux que "
+"les associations plusieurs-à-plusieurs et les collections de valeurs que "
+"nous avons montrées jusqu'ici, mappent toutes des tables avec des clés "
+"composées ! Il est vrai que ce point est ambigu ; une table d'association "
+"pure ne semble pas tirer avantage d'une clé subrogée (bien qu'une collection "
+"de valeur composées le <emphasis>pourrait</emphasis>). Néanmoins, Hibernate "
+"fournit une fonctionnalité qui vous permet de mapper des associations "
+"plusieurs-à-plusieurs et des collections de valeurs vers une table avec une "
+"clé subrogée. "
 
 #. Tag: para
-#: collection_mapping.xml:817
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;idbag&gt;</literal> element lets you map a <literal>List</"
 "literal> (or <literal>Collection</literal>) with bag semantics. For example:"
 msgstr ""
 "L'élément <literal>&lt;idbag&gt;</literal> vous laisse mapper une "
 "<literal>List</literal> (ou une <literal>Collection</literal>) avec une "
-"sémantique de sac."
+"sémantique de sac. Par exemple :"
 
-#. Tag: programlisting
-#: collection_mapping.xml:822
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<idbag name=\"lovers\" table=\"LOVERS\">\n"
-"    <collection-id column=\"ID\" type=\"long\">\n"
-"        <generator class=\"sequence\"/>\n"
-"    </collection-id>\n"
-"    <key column=\"PERSON1\"/>\n"
-"    <many-to-many column=\"PERSON2\" class=\"Person\" fetch=\"join\"/>\n"
-"</idbag>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:824
-#, fuzzy, no-c-format
-msgid ""
 "An <literal>&lt;idbag&gt;</literal> has a synthetic id generator, just like "
 "an entity class. A different surrogate key is assigned to each collection "
 "row. Hibernate does not, however, provide any mechanism for discovering the "
 "surrogate key value of a particular row."
 msgstr ""
-"Comme vous pouvez voir, un <literal>&lt;idbag&gt;</literal> a un généréteur "
-"d'id artificiel, comme une classe d'entité ! Une clef subrogée différente "
-"est assignée à chaque ligne de la collection. Cependant, Hibernate ne "
-"fournit pas de mécanisme pour découvrir la valeur d'une clef subrogée d'une "
-"ligne particulière."
+"Comme vous pouvez le constater, un <literal>&lt;idbag&gt;</literal> a un "
+"générateur d'id artificiel, exactement comme une classe d'entité ! Une clé "
+"subrogée différente est assignée à chaque ligne de la collection. Cependant, "
+"Hibernate ne fournit pas de mécanisme pour découvrir la valeur d'une clé "
+"subrogée d'une ligne particulière. "
 
 #. Tag: para
-#: collection_mapping.xml:831
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The update performance of an <literal>&lt;idbag&gt;</literal> supersedes a "
 "regular <literal>&lt;bag&gt;</literal>. Hibernate can locate individual rows "
@@ -1552,10 +1148,9 @@
 "literal> sont <emphasis>bien</emphasis> meilleures qu'un <literal>&lt;bag&gt;"
 "</literal> ordinaire ! Hibernate peut localiser des lignes individuelles "
 "efficacement et les mettre à jour ou les effacer individuellement, comme une "
-"liste, une map ou un ensemble."
+"liste, une map ou un ensemble. "
 
 #. Tag: para
-#: collection_mapping.xml:837
 #, no-c-format
 msgid ""
 "In the current implementation, the <literal>native</literal> identifier "
@@ -1564,420 +1159,91 @@
 msgstr ""
 "Dans l'implémentation actuelle, la stratégie de la génération de "
 "l'identifiant <literal>native</literal> n'est pas supportée pour les "
-"identifiants de collection <literal>&lt;idbag&gt;</literal>."
+"identifiants de collection <literal>&lt;idbag&gt;</literal>. "
 
 #. Tag: title
-#: collection_mapping.xml:861
 #, no-c-format
 msgid "Collection examples"
 msgstr "Exemples de collections"
 
 #. Tag: para
-#: collection_mapping.xml:863
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This section covers collection examples."
-msgstr "Exemples de collections"
+msgstr "Exemples de collections "
 
 #. Tag: para
-#: collection_mapping.xml:867
 #, no-c-format
 msgid ""
 "The following class has a collection of <literal>Child</literal> instances:"
 msgstr ""
+"La classe suivante possède une collection d'instances <literal>Child</"
+"literal>(filles) :"
 
-#. Tag: programlisting
-#: collection_mapping.xml:871
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"\n"
-"public class Parent {\n"
-"    private long id;\n"
-"    private Set children;\n"
-"\n"
-"    public long getId() { return id; }\n"
-"    private void setId(long id) { this.id=id; }\n"
-"\n"
-"    private Set getChildren() { return children; }\n"
-"    private void setChildren(Set children) { this.children=children; }\n"
-"\n"
-"    ....\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:873
-#, fuzzy, no-c-format
-msgid ""
 "If each child has, at most, one parent, the most natural mapping is a one-to-"
 "many association:"
 msgstr ""
-"a une collection d'instances de <literal>Child</literal>. Si chaque enfant a "
-"au plus un parent, le mapping le plus naturel est une association un-vers-"
-"plusieurs :"
+"Si chaque instance fille a au plus un parent, le mappage le plus naturel est "
+"une association un-à-plusieurs :"
 
-#. Tag: programlisting
-#: collection_mapping.xml:879
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:881
 #, no-c-format
 msgid "This maps to the following table definitions:"
 msgstr "Ceci mappe les définitions de tables suivantes :"
 
-#. Tag: programlisting
-#: collection_mapping.xml:885
-#, no-c-format
-msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null primary key, name varchar(255), "
-"parent_id bigint )\n"
-"alter table child add constraint childfk0 (parent_id) references parent]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:887
 #, no-c-format
 msgid ""
 "If the parent is <emphasis>required</emphasis>, use a bidirectional one-to-"
 "many association:"
 msgstr ""
-"Si le parent est <emphasis>requis</emphasis>, utilisez une association un-"
-"vers-plusieurs unidirectionnelle :"
+"Si le parent est <emphasis>requis</emphasis>, utilisez une association "
+"bidirectionnelle un-à-plusieurs : "
 
-#. Tag: programlisting
-#: collection_mapping.xml:892
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\" inverse=\"true\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"        <many-to-one name=\"parent\" class=\"Parent\" column=\"parent_id\" "
-"not-null=\"true\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:894
 #, no-c-format
 msgid "Notice the <literal>NOT NULL</literal> constraint:"
-msgstr "Notez la contrainte <literal>NOT NULL</literal> :"
+msgstr "Notez la contrainte <literal>NOT NULL</literal> : "
 
-#. Tag: programlisting
-#: collection_mapping.xml:898
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null\n"
-"                     primary key,\n"
-"                     name varchar(255),\n"
-"                     parent_id bigint not null )\n"
-"alter table child add constraint childfk0 (parent_id) references parent]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:900
-#, fuzzy, no-c-format
-msgid ""
 "Alternatively, if this association must be unidirectional you can declare "
 "the <literal>NOT NULL</literal> constraint on the <literal>&lt;key&gt;</"
 "literal> mapping:"
 msgstr ""
 "Alternativement, si vous insistez absolument pour que cette association soit "
 "unidirectionnelle, vous pouvez déclarer la contrainte <literal>NOT NULL</"
-"literal> sur le mapping <literal>&lt;key&gt;</literal> :"
+"literal> sur le mappage <literal>&lt;key&gt;</literal> : "
 
-#. Tag: programlisting
-#: collection_mapping.xml:906
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\">\n"
-"            <key column=\"parent_id\" not-null=\"true\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:908
-#, fuzzy, no-c-format
-msgid ""
 "On the other hand, if a child has multiple parents, a many-to-many "
 "association is appropriate:"
 msgstr ""
-"D'un autre côté, si un enfant pouvait avoir plusieurs parent, une "
-"association plusieurs-vers-plusieurs est plus appropriée :"
+"D'autre part, si un enfant peut avoir plusieurs parents, une association "
+"plusieurs-à-plusieurs est plus appropriée : "
 
-#. Tag: programlisting
-#: collection_mapping.xml:913
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\" table=\"childset\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <many-to-many class=\"Child\" column=\"child_id\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:915
 #, no-c-format
 msgid "Table definitions:"
 msgstr "Définitions des tables :"
 
-#. Tag: programlisting
-#: collection_mapping.xml:919
-#, no-c-format
-msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null primary key, name varchar(255) )\n"
-"create table childset ( parent_id bigint not null,\n"
-"                        child_id bigint not null,\n"
-"                        primary key ( parent_id, child_id ) )\n"
-"alter table childset add constraint childsetfk0 (parent_id) references "
-"parent\n"
-"alter table childset add constraint childsetfk1 (child_id) references child]]"
-">"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:921
 #, fuzzy, no-c-format
 msgid ""
 "For more examples and a complete explanation of a parent/child relationship "
-"mapping, see <xref linkend=\"example-parentchild\"/> for more information."
+"mapping, see <xref linkend=\"example-parentchild\" /> for more information."
 msgstr ""
-"Pour plus d'exemples et une revue complète du mapping de la relation parent/"
-"enfant, voir see <xref linkend=\"example-parentchild\"/>."
+"Pour plus d'exemples et une revue complète du mappage de la relation parent/"
+"enfant, consultez le <xref linkend=\"example-parentchild\" />. "
 
 #. Tag: para
-#: collection_mapping.xml:926
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Even more complex association mappings are covered in the next chapter."
 msgstr ""
-"Des mappings d'association plus exotiques sont possibles, nous cataloguerons "
-"toutes les possibilités dans le prochain chapitre."
-
-#~ msgid "Collection Mapping"
-#~ msgstr "Mapping des collections"
-
-#~ msgid "Some examples, first, a set of strings:"
-#~ msgstr "Quelques exemples, d'abord, un ensemble de chaînes de caractères :"
-
-#~ msgid ""
-#~ "The previous sections are pretty confusing. So lets look at an example. "
-#~ "This class:"
-#~ msgstr ""
-#~ "Les sections précédentes sont assez confuses. Donc prenons un exemple. "
-#~ "Cette classe :"
-
-#~ msgid ""
-#~ "<literal>column_name</literal> (required): The name of the column holding "
-#~ "the collection index values."
-#~ msgstr ""
-#~ "<literal>nom_de_colonne</literal> (requis) : le nom de la colonne "
-#~ "contenant les valeurs de l'index de la collection"
-
-#~ msgid ""
-#~ "<literal>base</literal> (optional, defaults to <literal>0</literal>): The "
-#~ "value of the index column that corresponds to the first element of the "
-#~ "list or array."
-#~ msgstr ""
-#~ "<literal>base</literal> (optionnel, par défaut = <literal>0</literal>) : "
-#~ "la valeur de la colonne de l'index qui correspond au premier élément de "
-#~ "la liste ou du tableau"
-
-#~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the column holding the "
-#~ "collection index values."
-#~ msgstr ""
-#~ "<literal>column</literal> (optionnel) : le nom de la colonne contenant "
-#~ "les valeurs de l'index de la collection"
-
-#~ msgid ""
-#~ "<literal>formula</literal> (optional): A SQL formula used to evaluate the "
-#~ "key of the map."
-#~ msgstr ""
-#~ "<literal>formula</literal> (optionnel) : une formule SQL utilisée pour "
-#~ "évaluer la clef de la map"
-
-#~ msgid "<literal>type</literal> (reguired): The type of the map keys."
-#~ msgstr "<literal>type</literal> (reguis): le type des clefs de la map"
-
-#~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the foreign key column "
-#~ "for the collection index values."
-#~ msgstr ""
-#~ "<literal>column</literal> (optionnel) : le nom de la colonne de la clef "
-#~ "étrangère pour les valeurs de l'index de la collection"
-
-#~ msgid ""
-#~ "<literal>formula</literal> (optional): A SQL formula used to evaluate the "
-#~ "foreign key of the map key."
-#~ msgstr ""
-#~ "<literal>formula</literal> (optionnel) : une formulre SQL utilisée pour "
-#~ "évaluer la clef étrangère de la clef de la map"
-
-#~ msgid ""
-#~ "<literal>class</literal> (required): The entity class used as the map key."
-#~ msgstr ""
-#~ "<literal>class</literal> (requis): la classe de l'entité utilisée comme "
-#~ "clef de la map"
-
-#~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the column holding the "
-#~ "collection element values."
-#~ msgstr ""
-#~ "<literal>column</literal> (optionnel) : le nom de la colonne contenant "
-#~ "les valeurs de l'élément de la collection"
-
-#~ msgid ""
-#~ "<literal>formula</literal> (optional): An SQL formula used to evaluate "
-#~ "the element."
-#~ msgstr ""
-#~ "<literal>formula</literal> (optionnel) : une formule SQL utilisée pour "
-#~ "évaluer l'élément"
-
-#~ msgid ""
-#~ "<literal>type</literal> (required): The type of the collection element."
-#~ msgstr ""
-#~ "<literal>type</literal> (requis) : le type de l'élément de la collection"
-
-#~ msgid ""
-#~ "A <emphasis>many-to-many association</emphasis> is specified using the "
-#~ "<literal>&lt;many-to-many&gt;</literal> element."
-#~ msgstr ""
-#~ "Une <emphasis>association plusieurs-vers-plusieurs</emphasis> est "
-#~ "spécifiée en utilisant l'élément <literal>&lt;many-to-many&gt;</literal>."
-
-#~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the element foreign key "
-#~ "column."
-#~ msgstr ""
-#~ "<literal>column</literal> (optionnel) : le nom de la colonne de la clef "
-#~ "étrangère de l'élément"
-
-#~ msgid ""
-#~ "<literal>formula</literal> (optional): An SQL formula used to evaluate "
-#~ "the element foreign key value."
-#~ msgstr ""
-#~ "<literal>formula</literal> (optionnel) : une formule SQL utilisée pour "
-#~ "évaluer la valeur de la clef étrangère de l'élément"
-
-#~ msgid ""
-#~ "<literal>fetch</literal> (optional - defaults to <literal>join</"
-#~ "literal>): enables outer-join or sequential select fetching for this "
-#~ "association. This is a special case; for full eager fetching (in a single "
-#~ "<literal>SELECT</literal>) of an entity and its many-to-many "
-#~ "relationships to other entities, you would enable <literal>join</literal> "
-#~ "fetching not only of the collection itself, but also with this attribute "
-#~ "on the <literal>&lt;many-to-many&gt;</literal> nested element."
-#~ msgstr ""
-#~ "<literal>fetch</literal> (optionnel - par défaut <literal>join</"
-#~ "literal>) : active les récupérations par jointures externes ou par "
-#~ "selects séquentiels pour cette association. C'est un cas spécial ; pour "
-#~ "une récupération complète sans attente (dans un seul <literal>SELECT</"
-#~ "literal>) d'une entité et de ses relations plusieurs-vers-plusieurs vers "
-#~ "d'autres entités, vous devriez activer la récupération <literal>join</"
-#~ "literal> non seulement sur la collection elle-même, mais aussi avec cet "
-#~ "attribut sur l'élément imbriqué <literal>&lt;many-to-many&gt;</literal>."
-
-#~ msgid ""
-#~ "<literal>unique</literal> (optional): Enable the DDL generation of a "
-#~ "unique constraint for the foreign-key column. This makes the association "
-#~ "multiplicity effectively one to many."
-#~ msgstr ""
-#~ "<literal>unique</literal> (optionnel) : activer la génération DDL d'une "
-#~ "contrainte d'unicité pour la colonne de la clef étrangère. Ça rend la "
-#~ "pluralité de l'association effectivement un-vers-plusieurs."
-
-#~ msgid ""
-#~ "<literal>not-found</literal> (optional - defaults to <literal>exception</"
-#~ "literal>): Specifies how foreign keys that reference missing rows will be "
-#~ "handled: <literal>ignore</literal> will treat a missing row as a null "
-#~ "association."
-#~ msgstr ""
-#~ "<literal>not-found</literal> (optionnel - par défaut <literal>exception</"
-#~ "literal>) : spécifie comment les clefs étrangères qui référencent la "
-#~ "lignes manquantes seront gérées : <literal>ignore</literal> traitera une "
-#~ "ligne manquante comme une association nulle."
-
-#~ msgid ""
-#~ "<literal>property-ref</literal>: (optional) The name of a property of the "
-#~ "associated class that is joined to this foreign key. If not specified, "
-#~ "the primary key of the associated class is used."
-#~ msgstr ""
-#~ "<literal>property-ref</literal> (optionnel) : le nom d'une propriété de "
-#~ "la classe associée qui est jointe à cette clef étrangère. Si non "
-#~ "spécifiée, la clef primaire de la classe associée est utilisée."
+"Des mappages d'association plus exotiques sont possibles, nous cataloguerons "
+"toutes les possibilités dans le prochain chapitre. "

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/component_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/component_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/component_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,166 +1,86 @@
+# translation of component_mapping.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: component_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-11-11 08:51+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: component_mapping.xml:29
 #, no-c-format
 msgid "Component Mapping"
-msgstr "Mapping de composants"
+msgstr "Mappage de composants"
 
 #. Tag: para
-#: component_mapping.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The notion of a <emphasis>component</emphasis> is re-used in several "
 "different contexts and purposes throughout Hibernate."
 msgstr ""
-"La notion de <emphasis>composants</emphasis> est réutilisé dans différents "
-"contextes, avec différents objectifs, à travers Hibernate."
+"La notion de <emphasis>composants</emphasis> est réutilisée dans différents "
+"contextes, avec différents objectifs, à travers Hibernate. "
 
 #. Tag: title
-#: component_mapping.xml:37
 #, no-c-format
 msgid "Dependent objects"
-msgstr "Objects dépendants"
+msgstr "Objets dépendants"
 
 #. Tag: para
-#: component_mapping.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A component is a contained object that is persisted as a value type and not "
 "an entity reference. The term \"component\" refers to the object-oriented "
 "notion of composition and not to architecture-level components. For example, "
 "you can model a person like this:"
 msgstr ""
-"Le composant est un objet inclu dans un autre qui est sauvegardé comme une "
-"valeur, et non pas comme une entité. Le composant fait référence à la notion "
-"(au sens objet) de composition (et non pas de composant au sens "
-"d'architecture de composants). Par exemple on pourrait modélisé l'objet "
-"personne de cette façon:"
+"Le composant est un objet inclus dans un autre objet, sauvegardé en tant que "
+"type valeur, et non en tant que référence entité. Le terme \"composant\" "
+"fait référence à la notion (au sens objet) de composition et non pas de "
+"composant au sens d'architecture de composants. Par exemple, on pourrait "
+"modéliser l'objet personne de la façon suivante :"
 
-#. Tag: programlisting
-#: component_mapping.xml:45
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[public class Person {\n"
-"    private java.util.Date birthday;\n"
-"    private Name name;\n"
-"    private String key;\n"
-"    public String getKey() {\n"
-"        return key;\n"
-"    }\n"
-"    private void setKey(String key) {\n"
-"        this.key=key;\n"
-"    }\n"
-"    public java.util.Date getBirthday() {\n"
-"        return birthday;\n"
-"    }\n"
-"    public void setBirthday(java.util.Date birthday) {\n"
-"        this.birthday = birthday;\n"
-"    }\n"
-"    public Name getName() {\n"
-"        return name;\n"
-"    }\n"
-"    public void setName(Name name) {\n"
-"        this.name = name;\n"
-"    }\n"
-"    ......\n"
-"    ......\n"
-"}]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: component_mapping.xml:47
-#, no-c-format
-msgid ""
-"<![CDATA[public class Name {\n"
-"    char initial;\n"
-"    String first;\n"
-"    String last;\n"
-"    public String getFirst() {\n"
-"        return first;\n"
-"    }\n"
-"    void setFirst(String first) {\n"
-"        this.first = first;\n"
-"    }\n"
-"    public String getLast() {\n"
-"        return last;\n"
-"    }\n"
-"    void setLast(String last) {\n"
-"        this.last = last;\n"
-"    }\n"
-"    public char getInitial() {\n"
-"        return initial;\n"
-"    }\n"
-"    void setInitial(char initial) {\n"
-"        this.initial = initial;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:49
-#, fuzzy, no-c-format
-msgid ""
 "Now <literal>Name</literal> can be persisted as a component of "
 "<literal>Person</literal>. <literal>Name</literal> defines getter and setter "
 "methods for its persistent properties, but it does not need to declare any "
 "interfaces or identifier properties."
 msgstr ""
-"Maintenant <literal>Name</literal> peut-être sauvegardé comme un composant "
-"de <literal>Person</literal>. Remarquer que <literal>Name</literal> définit "
-"des methodes d'accès et de modification pour ses propriétés persistantes, "
-"mais il n'a pas besoin des interfaces ou des propriétés d'identification "
-"( par exemple getId() ) qui sont propres aux entités."
+"Maintenant <literal>Name</literal> pourra être sauvegardé en tant que "
+"composant de <literal>Person</literal>. Remarquez que <literal>Name</"
+"literal> définit des méthodes getter et setter pour ses propriétés "
+"persistantes, mais ne doit déclarer aucune interface ou propriété "
+"d'identification."
 
 #. Tag: para
-#: component_mapping.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Our Hibernate mapping would look like this:"
-msgstr "Nous serions alors amené à mapper ce composant de cette façon:"
+msgstr "Dans Hibernate le mappage du composant serait :"
 
-#. Tag: programlisting
-#: component_mapping.xml:60
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-"    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    <property name=\"birthday\" type=\"date\"/>\n"
-"    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
-"optional -->\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </component>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:62
 #, no-c-format
 msgid ""
 "The person table would have the columns <literal>pid</literal>, "
 "<literal>birthday</literal>, <literal>initial</literal>, <literal>first</"
 "literal> and <literal>last</literal>."
 msgstr ""
-"La table person aurai les colonnes <literal>pid</literal>, "
+"La table \"person\" aurait les colonnes <literal>pid</literal>, "
 "<literal>birthday</literal>, <literal>initial</literal>, <literal>first</"
-"literal> and <literal>last</literal>."
+"literal> et <literal>last</literal>."
 
 #. Tag: para
-#: component_mapping.xml:70
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Like value types, components do not support shared references. In other "
 "words, two persons could have the same name, but the two person objects "
@@ -171,109 +91,71 @@
 "is suitable for most purposes."
 msgstr ""
 "Comme tous les types valeurs, les composants ne supportent pas les "
-"références partagés. En d'autres mots, deux instances de person peuvent "
+"références partagées. En d'autres termes, deux instances de person peuvent "
 "avoir un même nom, mais ces noms sont indépendants, ils peuvent être "
 "identiques si on les compare par valeur mais ils représentent deux objets "
-"distincts en mémoire. La notion de nullité pour un composant est "
+"distincts en mémoire. La sémantique de la valeur null d'un composant est "
 "<emphasis>ad hoc</emphasis>. Quand il recharge l'objet qui contient le "
-"composant, Hibernate supposera que si tous les champs du composants sont "
-"nuls alors le composant sera positionné à la valeur null. Ce choix "
-"programmatif devrait être satisfaisant dans la plupart des cas."
+"composant, Hibernate suppose que si toutes les colonnes de composants sont "
+"nulles, le composant est positionné à la valeur null. Ce choix programmatif "
+"devrait être satisfaisant dans la plupart des cas. "
 
 #. Tag: para
-#: component_mapping.xml:78
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The properties of a component can be of any Hibernate type (collections, "
 "many-to-one associations, other components, etc). Nested components should "
 "<emphasis>not</emphasis> be considered an exotic usage. Hibernate is "
 "intended to support a fine-grained object model."
 msgstr ""
-"Les propriétés d'un composant peuvent être de tous les types qu'Hibernate "
-"supporte habituellement (collections, many-to-one associations, autres "
-"composants, etc). Les composants inclus ne doivent <emphasis>pas</emphasis> "
-"être vus comme quelque chose d'exotique. Hibernate a été conçu pour "
-"supporter un modèle objet très granulaire."
+"Les propriétés d'un composant peuvent être de tous les types habituellement "
+"supportés par Hibernate (collections, associations plusieurs-à-un, autres "
+"composants, etc). Les composants imbriqués ne doivent <emphasis>pas</"
+"emphasis> être vus comme quelque chose d'exotique. Hibernate a été conçu "
+"pour supporter un modèle d'objet finement granulé. "
 
 #. Tag: para
-#: component_mapping.xml:85
 #, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element allows a <literal>&lt;"
 "parent&gt;</literal> subelement that maps a property of the component class "
 "as a reference back to the containing entity."
 msgstr ""
-"Le <literal>&lt;component&gt;</literal> peut inclure dans la liste de ses "
-"propriétés une référence au <literal>&lt;parent&gt;</literal> conteneur."
+"L'élément <literal>&lt;component&gt;</literal> permet de déclarer un sous-"
+"élément <literal>&lt;parent&gt;</literal> qui associe une propriété de la "
+"classe composant comme une référence arrière vers l'entité contenante."
 
-#. Tag: programlisting
-#: component_mapping.xml:91
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-"    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    <property name=\"birthday\" type=\"date\"/>\n"
-"    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
-"        <parent name=\"namedPerson\"/> <!-- reference back to the Person --"
-">\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </component>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: component_mapping.xml:96
 #, no-c-format
 msgid "Collections of dependent objects"
 msgstr "Collection d'objets dépendants"
 
 #. Tag: para
-#: component_mapping.xml:98
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collections of components are supported (e.g. an array of type "
 "<literal>Name</literal>). Declare your component collection by replacing the "
 "<literal>&lt;element&gt;</literal> tag with a <literal>&lt;composite-"
 "element&gt;</literal> tag:"
 msgstr ""
-"Les collections d'objets dépendants sont supportés (exemple: un tableau de "
-"type <literal>Name</literal>). Déclarer la collection de composants en "
-"remplaçant le tag <literal>&lt;element&gt;</literal> par le tag <literal>&lt;"
-"composite-element&gt;</literal>."
+"Les collections d'objets dépendants sont supportées (exemple: un tableau de "
+"type <literal>Name</literal>). Déclarez votre collection de composants en "
+"remplaçant la balise <literal>&lt;element&gt;</literal> par la balise "
+"<literal>&lt;composite-element&gt;</literal> :"
 
-#. Tag: programlisting
-#: component_mapping.xml:105
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
-"    <key column=\"id\"/>\n"
-"    <composite-element class=\"eg.Name\"> <!-- class attribute required -->\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </composite-element>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:108
-#, fuzzy, no-c-format
-msgid ""
 "If you define a <literal>Set</literal> of composite elements, it is "
 "important to implement <literal>equals()</literal> and <literal>hashCode()</"
 "literal> correctly."
 msgstr ""
-"Remarque: Si vous définissez un <literal>Set</literal> d'élément composite, "
-"il est très important d'implémenter la méthode <literal>equals()</literal> "
-"et <literal>hashCode()</literal> correctement."
+"Remarque : si vous définissez un <literal>Set</literal> d'éléments "
+"composites, il est très important d'implémenter les méthodes <literal>equals"
+"()</literal> et <literal>hashCode()</literal> correctement. "
 
 #. Tag: para
-#: component_mapping.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Composite elements can contain components but not collections. If your "
 "composite element contains components, use the <literal>&lt;nested-composite-"
@@ -283,19 +165,17 @@
 "but be aware that even though the Java model is the same, the relational "
 "model and persistence semantics are still slightly different."
 msgstr ""
-"Les élements composite peuvent aussi contenir des composants mais pas des "
+"Les éléments composites peuvent aussi contenir des composants mais pas des "
 "collections. Si votre élément composite contient aussi des composants, "
-"utilisez l'élément <literal>&lt;nested-composite-element&gt;</literal> . Une "
-"collections de composants qui ccontiennent eux-mêmes des composants est un "
-"cas très exotique. A ce stade demandez-vous si une association un-à-"
-"plusieurs ne serait pas plus approprié. Essayez de re remodeler votre "
-"élément composite comme une entité ( Dans ce cas même si le modèle Java est "
-"le même la logique de persitence et de relation sont tout de même "
-"différentes)"
+"utilisez la balise  <literal>&lt;nested-composite-element&gt;</literal>. Une "
+"collection de composants qui contiennent eux-mêmes des composants est un cas "
+"très exotique. A ce stade, demandez-vous si une association un-à-plusieurs "
+"ne serait pas plus appropriée. Essayez de remodeler votre élément composite "
+"comme une entité - remarquez que si le modèle Java est le même, toutefois le "
+"modèle relationnel et la sémantique de persistance diffèrent quelque peu. "
 
 #. Tag: para
-#: component_mapping.xml:127
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A composite element mapping does not support null-able properties if you are "
 "using a <literal>&lt;set&gt;</literal>. There is no separate primary key "
@@ -305,19 +185,18 @@
 "element or choose a <literal>&lt;list&gt;</literal>, <literal>&lt;map&gt;</"
 "literal>, <literal>&lt;bag&gt;</literal> or <literal>&lt;idbag&gt;</literal>."
 msgstr ""
-"Remarque, le mapping d'éléments composites ne supporte pas la nullité des "
-"propriétés lorsqu'on utilise un <literal>&lt;set&gt;</literal>. Hibernate "
-"lorsqu'il supprime un objet utilise chaque colonne pour identifier un objet "
-"(on ne peut pas utiliser des clés primaires distinctes dans une table "
-"d'éléments composites), ce qui n'est pas possible avec des valeurs nulles. "
-"Vous devez donc choisir d'interdire la nullité des propriétés d'un élément "
-"composite ou choisir un autre type de collection comme : <literal>&lt;"
-"list&gt;</literal>, <literal>&lt;map&gt;</literal>, <literal>&lt;bag&gt;</"
-"literal> ou <literal>&lt;idbag&gt;</literal>."
+"Remarquez que le mappage d'éléments composites ne supporte pas la nullité "
+"des propriétés lorsqu'on utilise un <literal>&lt;set&gt;</literal>. "
+"Hibernate lorsqu'il supprime un objet, utilise chaque colonne pour "
+"identifier un objet (il n'y a pas de colonne distincte de clés primaires "
+"dans la table d'éléments composites), ce qui n'est pas possible avec des "
+"valeurs nulles. Vous devez donc choisir d'interdire la nullité des "
+"propriétés d'un élément composite ou choisir un autre type de collection "
+"comme : <literal>&lt;list&gt;</literal>, <literal>&lt;map&gt;</literal>, "
+"<literal>&lt;bag&gt;</literal> ou <literal>&lt;idbag&gt;</literal>. "
 
 #. Tag: para
-#: component_mapping.xml:138
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A special case of a composite element is a composite element with a nested "
 "<literal>&lt;many-to-one&gt;</literal> element. This mapping allows you to "
@@ -328,163 +207,118 @@
 "<literal>quantity</literal> are properties of the association:"
 msgstr ""
 "Un cas particulier d'élément composite est un élément composite qui inclut "
-"un élément <literal>&lt;many-to-one&gt;</literal>. Un mapping comme celui-ci "
-"vous permet d'associer les colonnes d'une table d'association plusieurs à "
-"plusieurs (many-to-many) à la classse de l'élément composite. L'exemple "
-"suivant est une association plusieurs à plusieurs de <literal>Order</"
-"literal> à <literal>Item</literal> à <literal>purchaseDate</literal>, "
-"<literal>price</literal> et <literal>quantity</literal> sont des propriétés "
-"de l'association."
+"un élément imbriqué <literal>&lt;many-to-one&gt;</literal>. Un mappage comme "
+"celui-ci vous permet d'associer des colonnes supplémentaires d'une table "
+"d'association plusieurs à plusieurs à la classe de l'élément composite. "
+"L'exemple suivant est une association plusieurs à plusieurs de "
+"<literal>Order</literal> à <literal>Item</literal> où <literal>purchaseDate</"
+"literal>, <literal>price</literal> et <literal>quantity</literal> sont des "
+"propriétés de l'association :"
 
-#. Tag: programlisting
-#: component_mapping.xml:148
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"eg.Order\" .... >\n"
-"    ....\n"
-"    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-"        <key column=\"order_id\">\n"
-"        <composite-element class=\"eg.Purchase\">\n"
-"            <property name=\"purchaseDate\"/>\n"
-"            <property name=\"price\"/>\n"
-"            <property name=\"quantity\"/>\n"
-"            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class "
-"attribute is optional -->\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:150
-#, fuzzy, no-c-format
-msgid ""
 "There cannot be a reference to the purchase on the other side for "
 "bidirectional association navigation. Components are value types and do not "
 "allow shared references. A single <literal>Purchase</literal> can be in the "
 "set of an <literal>Order</literal>, but it cannot be referenced by the "
 "<literal>Item</literal> at the same time."
 msgstr ""
-"Bien sûr, il ne peut pas y avoir de référence à l'achat (purchase) depuis "
-"l'article (item), pour pouvoir naviguer de façon bidirectionnelle dans "
+"Par ailleurs, on ne peut évidemment pas faire référence à l'achat "
+"(purchase), pour pouvoir naviguer de façon bidirectionnelle dans "
 "l'association. N'oubliez pas que les composants sont de type valeurs et "
-"n'autorise pas les références partagées."
+"n'autorisent pas les références partagées. Un <literal>Purchase</literal> "
+"unique peut être dans le set d'un <literal>Order</literal>, mais ne peut pas "
+"être référencé par <literal>Item</literal> simultanément."
 
 #. Tag: para
-#: component_mapping.xml:158
 #, no-c-format
 msgid "Even ternary (or quaternary, etc) associations are possible:"
-msgstr "Même les associations ternaires ou quaternaires sont possibles:"
-
-#. Tag: programlisting
-#: component_mapping.xml:160
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Order\" .... >\n"
-"    ....\n"
-"    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-"        <key column=\"order_id\">\n"
-"        <composite-element class=\"eg.OrderLine\">\n"
-"            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
-"            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
 msgstr ""
+"Même les associations ternaires, quaternaires ou autres sont possibles :"
 
 #. Tag: para
-#: component_mapping.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Composite elements can appear in queries using the same syntax as "
 "associations to other entities."
 msgstr ""
-"Les éléments composites peuvent apparaître dans les requêtes en utilisant la "
-"même syntaxe que associations"
+"Des éléments composites peuvent apparaître dans les requêtes en utilisant la "
+"même syntaxe que les associations vers d'autres entités. "
 
 #. Tag: title
-#: component_mapping.xml:170
 #, no-c-format
 msgid "Components as Map indices"
-msgstr "Utiliser les composants comme index de map"
+msgstr "Les composants en tant qu'indices de Map"
 
 #. Tag: para
-#: component_mapping.xml:172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;composite-map-key&gt;</literal> element allows you to map a "
 "component class as the key of a <literal>Map</literal>. Ensure that you "
 "override <literal>hashCode()</literal> and <literal>equals()</literal> "
 "correctly on the component class."
 msgstr ""
-"l'élément <literal>&lt;composite-map-key&gt;</literal> vous permet "
-"d'utiliser une classe de composant comme indice de <literal>Map</literal>. "
-"Assurez-vous d'avoir surdéfini <literal>hashCode()</literal> et "
-"<literal>equals()</literal> dans la classe du composant."
+"L'élément <literal>&lt;composite-map-key&gt;</literal> vous permet de mapper "
+"une classe de composant comme indice d'une <literal>Map</literal>. Assurez-"
+"vous de surcharger correctement <literal>hashCode()</literal> et "
+"<literal>equals()</literal> dans la classe du composant. "
 
 #. Tag: title
-#: component_mapping.xml:181
 #, no-c-format
 msgid "Components as composite identifiers"
-msgstr "Utiliser un composant comme identifiant"
+msgstr "Les composants en tant qu'identifiants composites"
 
 #. Tag: para
-#: component_mapping.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can use a component as an identifier of an entity class. Your component "
 "class must satisfy certain requirements:"
 msgstr ""
-"Vous pouvez utiliser un composant comme identifiant d'une entité. Mais pour "
-"cela la classe du composant doit respecter certaines règles."
+"Vous pouvez utiliser un composant comme identifiant d'une classe entité. À "
+"cet effet, votre classe de composant doit respecter certaines exigences : "
 
 #. Tag: para
-#: component_mapping.xml:190
 #, no-c-format
 msgid "It must implement <literal>java.io.Serializable</literal>."
 msgstr "Elle doit implémenter <literal>java.io.Serializable</literal>."
 
 #. Tag: para
-#: component_mapping.xml:195
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It must re-implement <literal>equals()</literal> and <literal>hashCode()</"
 "literal> consistently with the database's notion of composite key equality."
 msgstr ""
 "Elle doit redéfinir <literal>equals()</literal> et <literal>hashCode()</"
-"literal>, de façon cohérente avec le fait qu'elle définit une clé composite "
-"dans la base de données."
+"literal>, de façon cohérente avec la notion d'égalité de clé composite de la "
+"base de données. "
 
 #. Tag: title
-#: component_mapping.xml:204
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Remarque"
 
 #. Tag: para
-#: component_mapping.xml:205
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In Hibernate3, although the second requirement is not an absolutely hard "
 "requirement of Hibernate, it is recommended."
 msgstr ""
-"Remarque: avec hibernate3, la seconde règle n'est plus absolument necessaire "
-"mais faîtes le quand même."
+"Avec Hibernate3, la seconde exigence n'est plus absolument nécessaire, "
+"néanmoins continuez de l'effectuer."
 
 #. Tag: para
-#: component_mapping.xml:211
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You cannot use an <literal>IdentifierGenerator</literal> to generate "
 "composite keys. Instead the application must assign its own identifiers."
 msgstr ""
 "Vous ne pouvez pas utiliser de <literal>IdentifierGenerator</literal> pour "
-"générer une clé composite, l'application devra définir elle même ses propres "
-"identifiants."
+"générer des clés composites, par contre l'application doit assigner ses "
+"propres identifiants. "
 
 #. Tag: para
-#: component_mapping.xml:216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use the <literal>&lt;composite-id&gt;</literal> tag, with nested "
 "<literal>&lt;key-property&gt;</literal> elements, in place of the usual "
@@ -492,183 +326,82 @@
 "<literal>OrderLine</literal> class has a primary key that depends upon the "
 "(composite) primary key of <literal>Order</literal>."
 msgstr ""
-"Utiliser l'élément <literal>&lt;composite-id&gt;</literal> (en incluant "
-"l'élément <literal>&lt;key-property&gt;</literal>) à la place de l'habituel "
-"déclaration <literal>&lt;id&gt;</literal>. Par exemple la classe "
-"<literal>OrderLine</literal> qui dépend de la clé primaire (composite) de "
-"<literal>Order</literal>."
+"Utiliser la balise <literal>&lt;composite-id&gt;</literal> (avec les "
+"éléments imbriqués <literal>&lt;key-property&gt;</literal>) à la place de "
+"l'habituel déclaration <literal>&lt;id&gt;</literal>. Par exemple, la classe "
+"<literal>OrderLine</literal> possède une clé primaire qui dépend de la clé "
+"primaire (composite) de <literal>Order</literal>. "
 
-#. Tag: programlisting
-#: component_mapping.xml:224
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"OrderLine\">\n"
-"\n"
-"    <composite-id name=\"id\" class=\"OrderLineId\">\n"
-"        <key-property name=\"lineId\"/>\n"
-"        <key-property name=\"orderId\"/>\n"
-"        <key-property name=\"customerId\"/>\n"
-"    </composite-id>\n"
-"\n"
-"    <property name=\"name\"/>\n"
-"\n"
-"    <many-to-one name=\"order\" class=\"Order\"\n"
-"            insert=\"false\" update=\"false\">\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </many-to-one>\n"
-"    ....\n"
-"\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:226
-#, fuzzy, no-c-format
-msgid ""
 "Any foreign keys referencing the <literal>OrderLine</literal> table are now "
 "composite. Declare this in your mappings for other classes. An association "
 "to <literal>OrderLine</literal> is mapped like this:"
 msgstr ""
-"Maintenant toutes clés étrangères référençant la table <literal>OrderLine</"
-"literal> devra aussi être composite. Vous devez en tenir compte lorsque vous "
-"écrivez vos mapping d'association pour les autres classes. Une association à "
-"<literal>OrderLine</literal> devrait être mappé de la façon suivante :"
+"Toutes les clés étrangères référençant la table <literal>OrderLine</literal> "
+"sont également composites. Vous devez en tenir compte lorsque vous écrivez "
+"vos mappage d'association pour les autres classes. Une association à "
+"<literal>OrderLine</literal> sera mappée de la façon suivante : "
 
-#. Tag: programlisting
-#: component_mapping.xml:232
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
-"<!-- the \"class\" attribute is optional, as usual -->\n"
-"    <column name=\"lineId\"/>\n"
-"    <column name=\"orderId\"/>\n"
-"    <column name=\"customerId\"/>\n"
-"</many-to-one>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:235
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The <literal>column</literal> element is an alternative to the "
 "<literal>column</literal> attribute everywhere. Using the <literal>column</"
 "literal> element just gives more declaration options, which are mostly "
 "useful when utilizing <literal>hbm2ddl</literal>"
 msgstr ""
+"Remarquez que la balise <literal>&lt;column&gt;</literal> est une "
+"alternative à l'attribut <literal>column</literal> que l'on utilise partout."
 
 #. Tag: para
-#: component_mapping.xml:244
 #, no-c-format
 msgid ""
 "A <literal>many-to-many</literal> association to <literal>OrderLine</"
 "literal> also uses the composite foreign key:"
 msgstr ""
-"Une association <literal>plusieurs-à-plusieurs</literal> (many-to-many) à "
-"<literal>OrderLine</literal> utilisera aussi une clé étrangère composite:"
+"Une association <literal>plusieurs-à-plusieurs</literal> à "
+"<literal>OrderLine</literal> utilisera aussi une clé étrangère composite :"
 
-#. Tag: programlisting
-#: component_mapping.xml:249
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"undeliveredOrderLines\">\n"
-"    <key column name=\"warehouseId\"/>\n"
-"    <many-to-many class=\"OrderLine\">\n"
-"        <column name=\"lineId\"/>\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </many-to-many>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:251
 #, no-c-format
 msgid ""
 "The collection of <literal>OrderLine</literal>s in <literal>Order</literal> "
 "would use:"
 msgstr ""
-"La collection des <literal>OrderLine</literal>s dans <literal>Order</"
-"literal> utilisera:"
+"La collection des <literal>OrderLine</literal> s dans <literal>Order</"
+"literal> utilisera : "
 
-#. Tag: programlisting
-#: component_mapping.xml:256
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
-"    <key>\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </key>\n"
-"    <one-to-many class=\"OrderLine\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:258
-#, fuzzy, no-c-format
 msgid "The <literal>&lt;one-to-many&gt;</literal> element declares no columns."
 msgstr ""
-"(L'élément <literal>&lt;one-to-many&gt;</literal>, comme d'habitude, ne "
-"déclare pas de colonne.)"
+"Comme d'habitude, l'élément <literal>&lt;one-to-many&gt;</literal> ne "
+"déclare pas de colonne."
 
 #. Tag: para
-#: component_mapping.xml:262
 #, no-c-format
 msgid ""
 "If <literal>OrderLine</literal> itself owns a collection, it also has a "
 "composite foreign key."
 msgstr ""
-"Si <literal>OrderLine</literal> lui-même possède une collection, celle-ci "
-"aura aussi une clé composite étrangère."
+"Si <literal>OrderLine</literal> lui-même possède une collection, il "
+"possédera de même une clé composite étrangère."
 
-#. Tag: programlisting
-#: component_mapping.xml:267
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"OrderLine\">\n"
-"    ....\n"
-"    ....\n"
-"    <list name=\"deliveryAttempts\">\n"
-"        <key>   <!-- a collection inherits the composite key type -->\n"
-"            <column name=\"lineId\"/>\n"
-"            <column name=\"orderId\"/>\n"
-"            <column name=\"customerId\"/>\n"
-"        </key>\n"
-"        <list-index column=\"attemptId\" base=\"1\"/>\n"
-"        <composite-element class=\"DeliveryAttempt\">\n"
-"            ...\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: component_mapping.xml:272
 #, no-c-format
 msgid "Dynamic components"
-msgstr "Composant Dynamique"
+msgstr "Les composants dynamiques"
 
 #. Tag: para
-#: component_mapping.xml:274
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can also map a property of type <literal>Map</literal>:"
-msgstr "Vous pouvez même mapper une propriété de type <literal>Map</literal>:"
-
-#. Tag: programlisting
-#: component_mapping.xml:278
-#, no-c-format
-msgid ""
-"<![CDATA[<dynamic-component name=\"userAttributes\">\n"
-"    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
-"    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
-"    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
-"</dynamic-component>]]>"
 msgstr ""
+"Vous pouvez également mapper une propriété de type <literal>Map</literal> :"
 
 #. Tag: para
-#: component_mapping.xml:280
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The semantics of a <literal>&lt;dynamic-component&gt;</literal> mapping are "
 "identical to <literal>&lt;component&gt;</literal>. The advantage of this "
@@ -679,19 +412,378 @@
 "via the <literal>Configuration</literal> object."
 msgstr ""
 "La sémantique de l'association à un <literal>&lt;dynamic-component&gt;</"
-"literal> est identique à celle que l'on utilise pour les composants. "
-"L'avantage de ce type de mapping est qu'il pemet de déterminer les "
-"véritables propriétés du bean au moment su déploiement en éditant simplement "
-"le document de mapping. La manipulation du document de mapping pendant "
-"l'execution de l'application est aussi possible en utilisant un parser DOM. "
-"Il ya même mieux, vous pouvez accéder (et changer) le metamodel de "
-"configuration d'hibernate en utilisant l'objet <literal>Configuration</"
-"literal>"
+"literal> est identique à celle que l'on utilise pour le <literal>&lt;"
+"component&gt;</literal>. L'avantage de ce type de mappage est qu'il permet "
+"de déterminer les véritables propriétés du bean au moment du déploiement, en "
+"éditant simplement le document de mappage. La manipulation du document de "
+"mappage pendant l'exécution de l'application est aussi possible en utilisant "
+"un parser DOM. Il y a même mieux, vous pouvez accéder (et changer) le "
+"métamodèle de configuration-temps de Hibernate en utilisant l'objet "
+"<literal>Configuration</literal>."
 
 #~ msgid ""
-#~ "(Note that the <literal>&lt;column&gt;</literal> tag is an alternative to "
-#~ "the <literal>column</literal> attribute everywhere.)"
+#~ "<![CDATA[public class Person {\n"
+#~ "    private java.util.Date birthday;\n"
+#~ "    private Name name;\n"
+#~ "    private String key;\n"
+#~ "    public String getKey() {\n"
+#~ "        return key;\n"
+#~ "    }\n"
+#~ "    private void setKey(String key) {\n"
+#~ "        this.key=key;\n"
+#~ "    }\n"
+#~ "    public java.util.Date getBirthday() {\n"
+#~ "        return birthday;\n"
+#~ "    }\n"
+#~ "    public void setBirthday(java.util.Date birthday) {\n"
+#~ "        this.birthday = birthday;\n"
+#~ "    }\n"
+#~ "    public Name getName() {\n"
+#~ "        return name;\n"
+#~ "    }\n"
+#~ "    public void setName(Name name) {\n"
+#~ "        this.name = name;\n"
+#~ "    }\n"
+#~ "    ......\n"
+#~ "    ......\n"
+#~ "}]]>"
 #~ msgstr ""
-#~ "(Remarque: l'élément <literal>&lt;column&gt;</literal> est une "
-#~ "alternative à l'attribut <literal>column</literal> que l'on utilise "
-#~ "partout.)"
+#~ "<![CDATA[public class Person {\n"
+#~ "    private java.util.Date birthday;\n"
+#~ "    private Name name;\n"
+#~ "    private String key;\n"
+#~ "    public String getKey() {\n"
+#~ "        return key;\n"
+#~ "    }\n"
+#~ "    private void setKey(String key) {\n"
+#~ "        this.key=key;\n"
+#~ "    }\n"
+#~ "    public java.util.Date getBirthday() {\n"
+#~ "        return birthday;\n"
+#~ "    }\n"
+#~ "    public void setBirthday(java.util.Date birthday) {\n"
+#~ "        this.birthday = birthday;\n"
+#~ "    }\n"
+#~ "    public Name getName() {\n"
+#~ "        return name;\n"
+#~ "    }\n"
+#~ "    public void setName(Name name) {\n"
+#~ "        this.name = name;\n"
+#~ "    }\n"
+#~ "    ......\n"
+#~ "    ......\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[public class Name {\n"
+#~ "    char initial;\n"
+#~ "    String first;\n"
+#~ "    String last;\n"
+#~ "    public String getFirst() {\n"
+#~ "        return first;\n"
+#~ "    }\n"
+#~ "    void setFirst(String first) {\n"
+#~ "        this.first = first;\n"
+#~ "    }\n"
+#~ "    public String getLast() {\n"
+#~ "        return last;\n"
+#~ "    }\n"
+#~ "    void setLast(String last) {\n"
+#~ "        this.last = last;\n"
+#~ "    }\n"
+#~ "    public char getInitial() {\n"
+#~ "        return initial;\n"
+#~ "    }\n"
+#~ "    void setInitial(char initial) {\n"
+#~ "        this.initial = initial;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[public class Name {\n"
+#~ "    char initial;\n"
+#~ "    String first;\n"
+#~ "    String last;\n"
+#~ "    public String getFirst() {\n"
+#~ "        return first;\n"
+#~ "    }\n"
+#~ "    void setFirst(String first) {\n"
+#~ "        this.first = first;\n"
+#~ "    }\n"
+#~ "    public String getLast() {\n"
+#~ "        return last;\n"
+#~ "    }\n"
+#~ "    void setLast(String last) {\n"
+#~ "        this.last = last;\n"
+#~ "    }\n"
+#~ "    public char getInitial() {\n"
+#~ "        return initial;\n"
+#~ "    }\n"
+#~ "    void setInitial(char initial) {\n"
+#~ "        this.initial = initial;\n"
+#~ "    }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
+#~ "optional -->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
+#~ "optional -->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
+#~ "        <parent name=\"namedPerson\"/> <!-- reference back to the Person "
+#~ "-->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
+#~ "        <parent name=\"namedPerson\"/> <!-- reference back to the Person "
+#~ "-->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
+#~ "    <key column=\"id\"/>\n"
+#~ "    <composite-element class=\"eg.Name\"> <!-- class attribute required --"
+#~ ">\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </composite-element>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
+#~ "    <key column=\"id\"/>\n"
+#~ "    <composite-element class=\"eg.Name\"> <!-- class attribute required --"
+#~ ">\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </composite-element>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.Purchase\">\n"
+#~ "            <property name=\"purchaseDate\"/>\n"
+#~ "            <property name=\"price\"/>\n"
+#~ "            <property name=\"quantity\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class "
+#~ "attribute is optional -->\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.Purchase\">\n"
+#~ "            <property name=\"purchaseDate\"/>\n"
+#~ "            <property name=\"price\"/>\n"
+#~ "            <property name=\"quantity\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class "
+#~ "attribute is optional -->\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.OrderLine\">\n"
+#~ "            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.OrderLine\">\n"
+#~ "            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" class=\"OrderLineId\">\n"
+#~ "        <key-property name=\"lineId\"/>\n"
+#~ "        <key-property name=\"orderId\"/>\n"
+#~ "        <key-property name=\"customerId\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\" class=\"Order\"\n"
+#~ "            insert=\"false\" update=\"false\">\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    ....\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" class=\"OrderLineId\">\n"
+#~ "        <key-property name=\"lineId\"/>\n"
+#~ "        <key-property name=\"orderId\"/>\n"
+#~ "        <key-property name=\"customerId\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\" class=\"Order\"\n"
+#~ "            insert=\"false\" update=\"false\">\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    ....\n"
+#~ "    \n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
+#~ "<!-- the \"class\" attribute is optional, as usual -->\n"
+#~ "    <column name=\"lineId\"/>\n"
+#~ "    <column name=\"orderId\"/>\n"
+#~ "    <column name=\"customerId\"/>\n"
+#~ "</many-to-one>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
+#~ "<!-- the \"class\" attribute is optional, as usual -->\n"
+#~ "    <column name=\"lineId\"/>\n"
+#~ "    <column name=\"orderId\"/>\n"
+#~ "    <column name=\"customerId\"/>\n"
+#~ "</many-to-one>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set name=\"undeliveredOrderLines\">\n"
+#~ "    <key column name=\"warehouseId\"/>\n"
+#~ "    <many-to-many class=\"OrderLine\">\n"
+#~ "        <column name=\"lineId\"/>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-many>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"undeliveredOrderLines\">\n"
+#~ "    <key column name=\"warehouseId\"/>\n"
+#~ "    <many-to-many class=\"OrderLine\">\n"
+#~ "        <column name=\"lineId\"/>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-many>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
+#~ "    <key>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </key>\n"
+#~ "    <one-to-many class=\"OrderLine\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
+#~ "    <key>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </key>\n"
+#~ "    <one-to-many class=\"OrderLine\"/>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    ....\n"
+#~ "    ....\n"
+#~ "    <list name=\"deliveryAttempts\">\n"
+#~ "        <key>   <!-- a collection inherits the composite key type -->\n"
+#~ "            <column name=\"lineId\"/>\n"
+#~ "            <column name=\"orderId\"/>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "        </key>\n"
+#~ "        <list-index column=\"attemptId\" base=\"1\"/>\n"
+#~ "        <composite-element class=\"DeliveryAttempt\">\n"
+#~ "            ...\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    ....\n"
+#~ "    ....\n"
+#~ "    <list name=\"deliveryAttempts\">\n"
+#~ "        <key>   <!-- a collection inherits the composite key type -->\n"
+#~ "            <column name=\"lineId\"/>\n"
+#~ "            <column name=\"orderId\"/>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "        </key>\n"
+#~ "        <list-index column=\"attemptId\" base=\"1\"/>\n"
+#~ "        <composite-element class=\"DeliveryAttempt\">\n"
+#~ "            ...\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<dynamic-component name=\"userAttributes\">\n"
+#~ "    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
+#~ "    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
+#~ "    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
+#~ "</dynamic-component>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<dynamic-component name=\"userAttributes\">\n"
+#~ "    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
+#~ "    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
+#~ "    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
+#~ "</dynamic-component>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/configuration.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/configuration.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/configuration.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,28 @@
+# translation of configuration.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: configuration\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-05 09:05+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: configuration.xml:29
 #, no-c-format
 msgid "Configuration"
 msgstr "Configuration"
 
 #. Tag: para
-#: configuration.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate is designed to operate in many different environments and, as "
 "such, there is a broad range of configuration parameters. Fortunately, most "
@@ -27,23 +31,21 @@
 "displays the various options. Simply put the example file in your classpath "
 "and customize it to suit your needs."
 msgstr ""
-"Parce qu'Hibernate est conçu pour fonctionner dans différents "
-"environnements, il existe beaucoup de paramètres de configuration. "
-"Heureusement, la plupart ont des valeurs par défaut appropriées et la "
-"distribution d'Hibernate contient un exemple de fichier <literal>hibernate."
-"properties</literal> dans le répertoire <literal>etc/</literal> qui montre "
-"les différentes options. Vous n'avez qu'à placer ce fichier dans votre "
-"classpath et à l'adapter."
+"Hibernate est conçu pour fonctionner dans de nombreux environnements , c'est "
+"pourquoi il existe beaucoup de paramètres de configuration. Heureusement, la "
+"plupart ont des valeurs par défaut appropriées et la Hibernate inclut un "
+"fichier d'exemples <literal>hibernate.properties</literal> dans le "
+"répertoire <literal>etc/</literal> qui fournit  les différentes options. "
+"Vous n'avez qu'à placer ce fichier dans votre classpath et à l'adapter à vos "
+"besoins."
 
 #. Tag: title
-#: configuration.xml:40
 #, no-c-format
 msgid "Programmatic configuration"
 msgstr "Configuration par programmation"
 
 #. Tag: para
-#: configuration.xml:42
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of <classname>org.hibernate.cfg.Configuration</classname> "
 "represents an entire set of mappings of an application's Java types to an "
@@ -52,14 +54,13 @@
 "interfacename>. The mappings are compiled from various XML mapping files."
 msgstr ""
 "Une instance de <literal>org.hibernate.cfg.Configuration</literal> "
-"représente un ensemble de mappings des classes Java d'une application vers "
+"représente un ensemble de mappages des classes Java d'une application vers "
 "la base de données SQL. La <literal>Configuration</literal> est utilisée "
 "pour construire un objet (immuable) <literal>SessionFactory</literal>. Les "
-"mappings sont constitués d'un ensemble de fichiers de mapping XML."
+"mappages sont constitués d'un ensemble de fichiers de mappage XML. "
 
 #. Tag: para
-#: configuration.xml:49
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can obtain a <classname>org.hibernate.cfg.Configuration</classname> "
 "instance by instantiating it directly and specifying XML mapping documents. "
@@ -68,107 +69,68 @@
 msgstr ""
 "Vous pouvez obtenir une instance de <literal>Configuration</literal> en "
 "l'instanciant directement et en spécifiant la liste des documents XML de "
-"mapping. Si les fichiers de mapping sont dans le classpath, vous pouvez le "
-"faire à l'aide de la méthode <literal>addResource()</literal> :"
+"mappage. Si les fichiers de mappage sont dans le classpath, vous pouvez "
+"utiliser la méthode <literal>addResource()</literal> : "
 
-#. Tag: programlisting
-#: configuration.xml:55
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addResource(\"Item.hbm.xml\")\n"
-"    .addResource(\"Bid.hbm.xml\");]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:57
-#, fuzzy, no-c-format
-msgid ""
 "An alternative way is to specify the mapped class and allow Hibernate to "
 "find the mapping document for you:"
 msgstr ""
-"Une alternative (parfois meilleure) est de spécifier les classes mappées et "
-"de laisser Hibernate trouver les documents de mapping pour vous :"
+"Une solution alternative consiste à spécifier la classe mappée et à donner à "
+"Hibernate la possibilité de trouver les documents de mappage pour vous :"
 
-#. Tag: programlisting
-#: configuration.xml:62
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addClass(org.hibernate.auction.Item.class)\n"
-"    .addClass(org.hibernate.auction.Bid.class);]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:64
-#, fuzzy, no-c-format
-msgid ""
 "Hibernate will then search for mapping files named <filename>/org/hibernate/"
 "auction/Item.hbm.xml</filename> and <filename>/org/hibernate/auction/Bid.hbm."
 "xml</filename> in the classpath. This approach eliminates any hardcoded "
 "filenames."
 msgstr ""
-"Hibernate va rechercher les fichiers de mappings <literal>/org/hibernate/"
+"Hibernate va rechercher les fichiers de mappages <literal>/org/hibernate/"
 "auction/Item.hbm.xml</literal> et <literal>/org/hibernate/auction/Bid.hbm."
 "xml</literal> dans le classpath. Cette approche élimine les noms de fichiers "
-"en dur."
+"en dur. "
 
 #. Tag: para
-#: configuration.xml:70
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <classname>org.hibernate.cfg.Configuration</classname> also allows you to "
 "specify configuration properties. For example:"
 msgstr ""
 "Une <literal>Configuration</literal> vous permet également de préciser des "
-"propriétés de configuration :"
+"propriétés de configuration. Par exemple :"
 
-#. Tag: programlisting
-#: configuration.xml:75
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addClass(org.hibernate.auction.Item.class)\n"
-"    .addClass(org.hibernate.auction.Bid.class)\n"
-"    .setProperty(\"hibernate.dialect\", \"org.hibernate.dialect."
-"MySQLInnoDBDialect\")\n"
-"    .setProperty(\"hibernate.connection.datasource\", \"java:comp/env/jdbc/"
-"test\")\n"
-"    .setProperty(\"hibernate.order_updates\", \"true\");]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:77
-#, fuzzy, no-c-format
-msgid ""
 "This is not the only way to pass configuration properties to Hibernate. Some "
 "alternative options include:"
 msgstr ""
 "Ce n'est pas le seul moyen de passer des propriétés de configuration à "
-"Hibernate. Les différentes options sont :"
+"Hibernate. Les différentes options sont : "
 
 #. Tag: para
-#: configuration.xml:84
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Pass an instance of <classname>java.util.Properties</classname> to "
 "<literal>Configuration.setProperties()</literal>."
 msgstr ""
 "Passer une instance de <literal>java.util.Properties</literal> à "
-"<literal>Configuration.setProperties()</literal>."
+"<literal>Configuration.setProperties()</literal>. "
 
 #. Tag: para
-#: configuration.xml:90
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Place a file named <filename>hibernate.properties</filename> in a root "
 "directory of the classpath."
 msgstr ""
 "Placer <literal>hibernate.properties</literal> dans un répertoire racine du "
-"classpath"
+"chemin de classe."
 
 #. Tag: para
-#: configuration.xml:95
 #, no-c-format
 msgid ""
 "Set <literal>System</literal> properties using <literal>java -"
@@ -178,44 +140,40 @@
 "<literal>java -Dproperty=value</literal>."
 
 #. Tag: para
-#: configuration.xml:100
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Include <literal>&lt;property&gt;</literal> elements in <literal>hibernate."
 "cfg.xml</literal> (this is discussed later)."
 msgstr ""
 "Inclure des éléments <literal>&lt;property&gt;</literal> dans le fichier "
-"<literal>hibernate.cfg.xml</literal> (voir plus loin)."
+"<literal>hibernate.cfg.xml</literal> (voir plus loin). "
 
 #. Tag: para
-#: configuration.xml:107
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want to get started quickly<filename>hibernate.properties</filename> "
 "is the easiest approach."
 msgstr ""
-"L'utilisation d'<literal>hibernate.properties</literal> est l'approche la "
-"plus simple si vous voulez démarrer rapidement"
+"Si vous souhaitez démarrer rapidement, <filename>hibernate.properties</"
+"filename> est l'approche la plus facile."
 
 #. Tag: para
-#: configuration.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <classname>org.hibernate.cfg.Configuration</classname> is intended as a "
 "startup-time object that will be discarded once a <literal>SessionFactory</"
 "literal> is created."
 msgstr ""
-"La <literal>Configuration</literal> est un objet de démarrage qui sera "
-"supprimé une fois qu'une <literal>SessionFactory</literal> aura été créée."
+"<classname>org.hibernate.cfg.Configuration</classname> est un objet de "
+"démarrage qui sera supprimé une fois qu'une <literal>SessionFactory</"
+"literal> aura été créée."
 
 #. Tag: title
-#: configuration.xml:119
 #, no-c-format
 msgid "Obtaining a SessionFactory"
 msgstr "Obtenir une SessionFactory"
 
 #. Tag: para
-#: configuration.xml:121
 #, fuzzy, no-c-format
 msgid ""
 "When all mappings have been parsed by the <classname>org.hibernate.cfg."
@@ -223,19 +181,12 @@
 "<interfacename>org.hibernate.Session</interfacename> instances. This factory "
 "is intended to be shared by all application threads:"
 msgstr ""
-"Une fois que tous les mappings ont été parsés par la <literal>Configuration</"
+"Une fois que tous les mappages ont été parsés par la <literal>Configuration</"
 "literal>, l'application doit obtenir une fabrique d'instances de "
 "<literal>Session</literal>. Cette fabrique sera partagée entre tous les "
-"threads de l'application :"
+"threads de l'application : "
 
-#. Tag: programlisting
-#: configuration.xml:127
-#, no-c-format
-msgid "<![CDATA[SessionFactory sessions = cfg.buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:129
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate does allow your application to instantiate more than one "
@@ -244,47 +195,37 @@
 msgstr ""
 "Hibernate permet à votre application d'instancier plus d'une "
 "<literal>SessionFactory</literal>. Cela est pratique lorsque vous utilisez "
-"plus d'une base de données."
+"plus d'une base de données. "
 
 #. Tag: title
-#: configuration.xml:138
 #, no-c-format
 msgid "JDBC connections"
-msgstr "Connexions JDBC"
+msgstr "Connexions JDBC "
 
 #. Tag: para
-#: configuration.xml:140
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is advisable to have the <interfacename>org.hibernate.SessionFactory</"
 "interfacename> create and pool JDBC connections for you. If you take this "
 "approach, opening a <interfacename>org.hibernate.Session</interfacename> is "
 "as simple as:"
 msgstr ""
-"Habituellement, vous voulez que la <literal>SessionFactory</literal> crée "
-"les connexions JDBC et les mette dans un pool pour vous. Si vous suivez "
-"cette approche, ouvrir une <literal>Session</literal> est aussi simple que :"
+"Il est conseillé que <interfacename>org.hibernate.SessionFactory</"
+"interfacename> crée les connexions JDBC et les mette dans un pool pour vous. "
+"Si vous suivez cette approche, ouvrir une <interfacename>org.hibernate."
+"Session</interfacename> est aussi simple que :"
 
-#. Tag: programlisting
-#: configuration.xml:146
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessions.openSession(); // open a new Session]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:148
-#, fuzzy, no-c-format
-msgid ""
 "Once you start a task that requires access to the database, a JDBC "
 "connection will be obtained from the pool."
 msgstr ""
-"Dès que vous ferez quelquechose qui requiert un accès à la base de données, "
-"une connexion JDBC sera récupérée dans le pool."
+"Dès que vous initierez une action qui requiert un accès à la base de "
+"données, une connexion JDBC sera récupérée dans le pool."
 
 #. Tag: para
-#: configuration.xml:153
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Before you can do this, you first need to pass some JDBC connection "
 "properties to Hibernate. All Hibernate property names and semantics are "
@@ -292,136 +233,89 @@
 "The most important settings for JDBC connection configuration are outlined "
 "below."
 msgstr ""
-"Pour faire cela, il faut passer les propriétés de la connexion JDBC à "
-"Hibernate. Tous les noms des propriétés Hibernate et leur signification sont "
-"définies dans la classe <literal>org.hibernate.cfg.Environment</literal>. "
-"Nous allons maintenant décrire les paramètres de configuration des "
-"connexions JDBC les plus importants."
+"À cet effet, il faut passer les propriétés de la connexion JDBC à Hibernate. "
+"Tous les noms des propriétés Hibernate et leur signification sont définies "
+"dans la classe <literal>org.hibernate.cfg.Environment</literal>. Nous allons "
+"maintenant décrire les paramètres de configuration des connexions JDBC les "
+"plus importants. "
 
 #. Tag: para
-#: configuration.xml:159
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will obtain and pool connections using <classname>java.sql."
 "DriverManager</classname> if you set the following properties:"
 msgstr ""
 "Hibernate obtiendra des connexions (et les mettra dans un pool) en utilisant "
 "<literal>java.sql.DriverManager</literal> si vous positionnez les paramètres "
-"de la manière suivante :"
+"de la manière suivante : "
 
 #. Tag: title
-#: configuration.xml:165
 #, no-c-format
 msgid "Hibernate JDBC Properties"
-msgstr "Propriétés JDBC d'Hibernate"
+msgstr "Propriétés JDBC de Hibernate"
 
 #. Tag: entry
-#: configuration.xml:171 configuration.xml:257 configuration.xml:353
-#: configuration.xml:548 configuration.xml:743 configuration.xml:850
-#: configuration.xml:938
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Property name"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Nom de la propriété\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Nom d'une propriété\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Nom de la propriété\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Nom de la propriété\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Nom de la propriété\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Nom de la propriété\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Nom de la propriété"
+msgstr "Nom de la propriété"
 
 #. Tag: entry
-#: configuration.xml:172 configuration.xml:258 configuration.xml:354
-#: configuration.xml:549 configuration.xml:744 configuration.xml:851
-#: configuration.xml:939
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Purpose"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Fonction\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"fonction\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Fonction\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Fonction\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Fonction\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Fonction\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Fonction"
+msgstr "Fonction"
 
-#. Tag: property
-#: configuration.xml:178
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.driver_class"
-msgstr "hibernate.connection.driver_class"
+msgid "<property>hibernate.connection.driver_class</property>"
+msgstr "<property>hibernate.connection.driver_class</property>"
 
-#. Tag: emphasis
-#: configuration.xml:181
+#. Tag: entry
 #, no-c-format
-msgid "JDBC driver class"
-msgstr "Classe du driver jdbc"
+msgid "<emphasis>JDBC driver class</emphasis>"
+msgstr "<emphasis>Classe de pilote JDBC</emphasis>"
 
-#. Tag: property
-#: configuration.xml:186
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.url"
-msgstr "hibernate.connection.url"
+msgid "<property>hibernate.connection.url</property>"
+msgstr "<property>hibernate.connection.url</property>"
 
-#. Tag: emphasis
-#: configuration.xml:189
+#. Tag: entry
 #, no-c-format
-msgid "JDBC URL"
-msgstr "URL jdbc"
+msgid "<emphasis>JDBC URL</emphasis>"
+msgstr "<emphasis>JDBC URL</emphasis>"
 
-#. Tag: property
-#: configuration.xml:194 configuration.xml:288
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.username"
-msgstr "hibernate.connection.username"
+msgid "<property>hibernate.connection.username</property>"
+msgstr "<property>hibernate.connection.username</property>"
 
-#. Tag: emphasis
-#: configuration.xml:197
+#. Tag: entry
 #, no-c-format
-msgid "database user"
-msgstr "utilisateur de la base de données"
+msgid "<emphasis>database user</emphasis>"
+msgstr "<emphasis>utilisateur de la base de données</emphasis>"
 
-#. Tag: property
-#: configuration.xml:202 configuration.xml:296
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.password"
-msgstr "hibernate.connection.password"
+msgid "<property>hibernate.connection.password</property>"
+msgstr "<property>hibernate.connection.password</property>"
 
-#. Tag: emphasis
-#: configuration.xml:205
+#. Tag: entry
 #, no-c-format
-msgid "database user password"
-msgstr "mot de passe de la base de données"
+msgid "<emphasis>database user password</emphasis>"
+msgstr "<emphasis>mot de passe de l'utilisateur de base de données</emphasis>"
 
-#. Tag: property
-#: configuration.xml:210
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.pool_size"
-msgstr "hibernate.connection.pool_size"
+msgid "<property>hibernate.connection.pool_size</property>"
+msgstr "<property>hibernate.connection.pool_size</property>"
 
-#. Tag: emphasis
-#: configuration.xml:213
+#. Tag: entry
 #, no-c-format
-msgid "maximum number of pooled connections"
-msgstr "nombre maximum de connexions dans le pool"
+msgid "<emphasis>maximum number of pooled connections</emphasis>"
+msgstr "<emphasis>nombre maximum de connexions dans le pool</emphasis>"
 
 #. Tag: para
-#: configuration.xml:220
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's own connection pooling algorithm is, however, quite rudimentary. "
 "It is intended to help you get started and is <emphasis>not intended for use "
@@ -431,19 +325,18 @@
 "with connection pool specific settings. This will turn off Hibernate's "
 "internal pool. For example, you might like to use c3p0."
 msgstr ""
-"L'algorithme natif de pool de connexions d'Hibernate est plutôt "
-"rudimentaire. Il a été fait dans le but de vous aider à démarrer et "
+"L'algorithme natif de pool de connexions de Hibernate est plutôt "
+"rudimentaire. Il a été conçu dans le but de vous aider à démarrer et "
 "<emphasis>n'est pas prévu pour un système en production</emphasis> ou même "
-"pour un test de peformance. Utilisez plutôt un pool tiers pour de meilleures "
-"performances et une meilleure stabilité : pour cela, remplacez la propriété "
+"pour un test de performance. Utilisez plutôt un pool tiers pour de "
+"meilleures performances et une meilleure stabilité : remplacez la propriété "
 "<literal>hibernate.connection.pool_size</literal> avec les propriétés "
-"spécifique au pool de connexions que vous avez choisi. Cela désactivera le "
-"pool de connexions interne d'Hibernate. Vous pouvez par exemple utiliser "
-"C3P0."
+"spécifiques au pool de connexions que vous avez choisi. Cela désactivera le "
+"pool de connexions interne de Hibernate. Vous pouvez par exemple utiliser "
+"C3P0. "
 
 #. Tag: para
-#: configuration.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "C3P0 is an open source JDBC connection pool distributed along with Hibernate "
 "in the <filename>lib</filename> directory. Hibernate will use its "
@@ -456,131 +349,95 @@
 "C3P0 est un pool de connexions JDBC open source distribué avec Hibernate "
 "dans le répertoire <literal>lib</literal>. Hibernate utilisera son provider "
 "<literal>C3P0ConnectionProvider</literal> pour le pool de connexions si vous "
-"positionnez les propriétés <literal>hibernate.c3p0.*</literal>. Si vous "
+"configurez les propriétés <literal>hibernate.c3p0.*</literal>. Si vous "
 "voulez utiliser Proxool, référez vous au groupe de propriétés "
-"d'<literal>hibernate.properties</literal> correspondant et regardez sur le "
-"site web d'Hibernate pour plus d'informations."
+"<literal>hibernate.properties</literal> correspondant et consultez le site "
+"web Hibernate pour plus d'informations. "
 
 #. Tag: para
-#: configuration.xml:238
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is an example <filename>hibernate.properties</filename> file "
 "for c3p0:"
 msgstr ""
 "Voici un exemple de fichier <literal>hibernate.properties</literal> pour "
-"C3P0:"
+"C3P0: "
 
-#. Tag: programlisting
-#: configuration.xml:242
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[hibernate.connection.driver_class = org.postgresql.Driver\n"
-"hibernate.connection.url = jdbc:postgresql://localhost/mydatabase\n"
-"hibernate.connection.username = myuser\n"
-"hibernate.connection.password = secret\n"
-"hibernate.c3p0.min_size=5\n"
-"hibernate.c3p0.max_size=20\n"
-"hibernate.c3p0.timeout=1800\n"
-"hibernate.c3p0.max_statements=50\n"
-"hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:244
-#, fuzzy, no-c-format
-msgid ""
 "For use inside an application server, you should almost always configure "
 "Hibernate to obtain connections from an application server "
 "<interfacename>javax.sql.Datasource</interfacename> registered in JNDI. You "
 "will need to set at least one of the following properties:"
 msgstr ""
-"Dans le cadre de l'utilisation au sein d'un serveur d'applications, vous "
-"devriez quasiment toujours configurer Hibernate pour qu'il obtienne ses "
-"connexions de la <literal>DataSource</literal> du serveur d'application "
-"enregistrée dans le JNDI. Pour cela vous devrez définir au moins une des "
-"propriétés suivantes :"
+"Pour l'utilisation de Hibernate au sein d'un serveur d'applications, il est "
+"recommandé de configurer Hibernate presque toujours de façon à ce qu'il "
+"obtienne ses connexions de la <literal>DataSource</literal> enregistrée du "
+"serveur d'applications dans le JNDI. À cet effet, vous devrez définir au "
+"moins une des propriétés suivantes : "
 
 #. Tag: title
-#: configuration.xml:251
 #, no-c-format
 msgid "Hibernate Datasource Properties"
-msgstr "Propriété d'une Datasource Hibernate"
+msgstr "Propriétés d'une Datasource Hibernate"
 
-#. Tag: property
-#: configuration.xml:264
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.datasource"
-msgstr "hibernate.connection.datasource"
+msgid "<property>hibernate.connection.datasource</property>"
+msgstr "<property>hibernate.connection.datasource</property>"
 
-#. Tag: emphasis
-#: configuration.xml:267
+#. Tag: entry
 #, no-c-format
-msgid "datasource JNDI name"
-msgstr "Nom JNDI de la datasource"
+msgid "<emphasis>datasource JNDI name</emphasis>"
+msgstr "<emphasis>nom JNDI de la source de données</emphasis>"
 
-#. Tag: property
-#: configuration.xml:272
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jndi.url"
-msgstr "hibernate.jndi.url"
+msgid "<property>hibernate.jndi.url</property>"
+msgstr "<property>hibernate.jndi.url</property>"
 
 #. Tag: entry
-#: configuration.xml:274
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis>URL of the JNDI provider</emphasis> (optional)"
-msgstr "URL du fournisseur JNDI"
+msgstr "<emphasis>URL du fournisseur JNDI</emphasis> (optionnel)"
 
-#. Tag: property
-#: configuration.xml:280
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jndi.class"
-msgstr "hibernate.jndi.class"
+msgid "<property>hibernate.jndi.class</property>"
+msgstr "<property>hibernate.jndi.class</property>"
 
 #. Tag: entry
-#: configuration.xml:282
 #, no-c-format
 msgid ""
 "<emphasis>class of the JNDI <literal>InitialContextFactory</literal></"
 "emphasis> (optional)"
 msgstr ""
+"<emphasis>classe de JNDI <literal>InitialContextFactory</literal></emphasis> "
+"(optionnel)"
 
 #. Tag: entry
-#: configuration.xml:290
 #, no-c-format
 msgid "<emphasis>database user</emphasis> (optional)"
-msgstr ""
+msgstr "<emphasis>utilisateur de base de données</emphasis> (optionnel)"
 
 #. Tag: entry
-#: configuration.xml:298
 #, no-c-format
 msgid "<emphasis>database user password</emphasis> (optional)"
 msgstr ""
+"<emphasis>mot de passe de l'utilisateur de base de données</emphasis> "
+"(optionnel)"
 
 #. Tag: para
-#: configuration.xml:306
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Here is an example <filename>hibernate.properties</filename> file for an "
 "application server provided JNDI datasource:"
 msgstr ""
 "Voici un exemple de fichier <literal>hibernate.properties</literal> pour "
-"l'utilisation d'une datasource JNDI fournie par un serveur d'applications :"
+"l'utilisation d'une datasource JNDI fournie par un serveur d'applications : "
 
-#. Tag: programlisting
-#: configuration.xml:311
-#, no-c-format
-msgid ""
-"<![CDATA[hibernate.connection.datasource = java:/comp/env/jdbc/test\n"
-"hibernate.transaction.factory_class = \\\n"
-"    org.hibernate.transaction.JTATransactionFactory\n"
-"hibernate.transaction.manager_lookup_class = \\\n"
-"    org.hibernate.transaction.JBossTransactionManagerLookup\n"
-"hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:313
 #, no-c-format
 msgid ""
 "JDBC connections obtained from a JNDI datasource will automatically "
@@ -591,22 +448,20 @@
 "d'applications."
 
 #. Tag: para
-#: configuration.xml:318
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Arbitrary connection properties can be given by prepending "
 "\"<literal>hibernate.connection</literal>\" to the connection property name. "
 "For example, you can specify a <property>charSet</property> connection "
 "property using <property>hibernate.connection.charSet</property>."
 msgstr ""
-"Des propriétés supplémentaires de connexion peuvent être passées en "
-"préfixant le nom de la propriété par \"<literal>hibernate.connnection</"
-"literal>\". Par exemple, vous pouvez spécifier un jeu de caractères en "
-"utilisant <literal>hibernate.connection.charSet</literal>."
+"Des propriétés arbitraires de connexion peuvent être passées en préfixant le "
+"nom de la propriété par \"<literal>hibernate.connnection</literal>\". Par "
+"exemple, vous pouvez spécifier un <literal>charSet</literal> en utilisant "
+"<literal>hibernate.connection.charSet</literal>. "
 
 #. Tag: para
-#: configuration.xml:324
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can define your own plugin strategy for obtaining JDBC connections by "
 "implementing the interface <interfacename>org.hibernate.connection."
@@ -617,29 +472,25 @@
 "Vous pouvez fournir votre propre stratégie d'obtention des connexions JDBC "
 "en implémentant l'interface <literal>org.hibernate.connection."
 "ConnectionProvider</literal>. Vous pouvez sélectionner une implémentation "
-"spécifique en positionnant <literal>hibernate.connection.provider_class</"
+"spécifique par la propriété <literal>hibernate.connection.provider_class</"
 "literal>."
 
 #. Tag: title
-#: configuration.xml:333
 #, no-c-format
 msgid "Optional configuration properties"
 msgstr "Propriétés de configuration optionnelles"
 
 #. Tag: para
-#: configuration.xml:335
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are a number of other properties that control the behavior of "
 "Hibernate at runtime. All are optional and have reasonable default values."
 msgstr ""
 "Il y a un certain nombre d'autres propriétés qui contrôlent le "
 "fonctionnement d'Hibernate à l'exécution. Toutes sont optionnelles et ont "
-"comme valeurs par défaut des valeurs \"raisonnables\" pour un fonctionnement "
-"nominal."
+"comme valeurs par défaut des valeurs raisonnables."
 
-#. Tag: warning
-#: configuration.xml:341
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Some of these properties are \"system-level\" only.</emphasis> "
@@ -647,432 +498,216 @@
 "literal> or <filename>hibernate.properties</filename>. They "
 "<emphasis>cannot</emphasis> be set by the other techniques described above."
 msgstr ""
-"<emphasis>Attention : Certaines de ces propriétés sont uniquement de niveau "
-"System.</emphasis> Les propriétés de niveau System ne peuvent être "
-"positionnées que via la ligne de commande (<literal>java -Dproperty=value</"
-"literal>) ou être définies dans <literal>hibernate.properties</literal>. "
-"Elle <emphasis>ne peuvent pas</emphasis> l'être via une des autres "
-"techniques décrites ci-dessus."
+"Attention : certaines de ces propriétés sont uniquement de niveau System. "
+"Les propriétés de niveau System ne peuvent être positionnées que via la "
+"ligne de commande <literal>java -Dproperty=value</literal> ou être définies "
+"dans <literal>hibernate.properties</literal>. Elles peuvent <emphasis>ne "
+"pas</emphasis> être configurées par les autres techniques décrites ci-"
+"dessus. "
 
 #. Tag: title
-#: configuration.xml:347
 #, no-c-format
 msgid "Hibernate Configuration Properties"
-msgstr "Propriétés de configuration d'Hibernate"
+msgstr "Propriétés de configuration Hibernate"
 
-#. Tag: property
-#: configuration.xml:360
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.dialect"
-msgstr "hibernate.dialect"
+msgid "<property>hibernate.dialect</property>"
+msgstr "<property>hibernate.dialect</property>"
 
 #. Tag: entry
-#: configuration.xml:362
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a Hibernate <classname>org.hibernate.dialect.Dialect</"
 "classname> which allows Hibernate to generate SQL optimized for a particular "
 "relational database."
 msgstr ""
-"Le nom de la classe du <placeholder-1/> Hibernate. qui permet à Hibernate de "
-"générer du SQL optimisé pour une base de données relationnelle particulière. "
-"<placeholder-2/>"
+"Le nom de la classe d'un <classname>org.hibernate.dialect.Dialect</"
+"classname> Hibernate qui permet à Hibernate de générer du SQL optimisé pour "
+"une base de données relationnelle particulière. "
 
 #. Tag: para
-#: configuration.xml:365
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>full.classname.of."
 "Dialect</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+" <emphasis role=\"strong\">par ex.</emphasis><literal>full.classname.of."
+"Dialect</literal> "
 
 #. Tag: para
-#: configuration.xml:369
 #, no-c-format
 msgid ""
 "In most cases Hibernate will actually be able to choose the correct "
 "<classname>org.hibernate.dialect.Dialect</classname> implementation based on "
 "the <literal>JDBC metadata</literal> returned by the JDBC driver."
 msgstr ""
+"Dans la plupart des cas, Hibernate sera en mesure de choisir "
+"l'implémentation <classname>org.hibernate.dialect.Dialect</classname> qui "
+"convient sur la base des <literal>métadonnées JDBC</literal> retournées par "
+"le driver JDBC."
 
-#. Tag: property
-#: configuration.xml:378
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.show_sql"
-msgstr "hibernate.show_sql"
+msgid "<property>hibernate.show_sql</property>"
+msgstr "<property>hibernate.show_sql</property>"
 
 #. Tag: entry
-#: configuration.xml:380
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Write all SQL statements to console. This is an alternative to setting the "
 "log category <literal>org.hibernate.SQL</literal> to <literal>debug</"
 "literal>."
 msgstr ""
-"Ecrit toutes les requêtes SQL sur la console. Il s'agit d'une alternative au "
-"positionnement de la catégorie de log <placeholder-1/> au niveau "
-"<placeholder-2/>. <placeholder-3/>"
+"Écrit toutes les requêtes SQL sur la console. Il s'agit d'une alternative au "
+"paramétrage de la catégorie de log <literal>org.hibernate.SQL</literal> à "
+"<literal>debug</literal>. "
 
 #. Tag: para
-#: configuration.xml:384 configuration.xml:396 configuration.xml:490
-#: configuration.xml:503 configuration.xml:516 configuration.xml:529
-#: configuration.xml:583 configuration.xml:610 configuration.xml:623
-#: configuration.xml:678 configuration.xml:906 configuration.xml:921
-#: configuration.xml:1011
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>true</literal> | "
 "<literal>false</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+" <emphasis role=\"strong\">par ex.</emphasis><literal>true</literal> | "
+"<literal>false</literal>  "
 
-#. Tag: property
-#: configuration.xml:392
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.format_sql"
-msgstr "hibernate.format_sql"
+msgid "<property>hibernate.format_sql</property>"
+msgstr "<property>hibernate.format_sql</property>"
 
 #. Tag: entry
-#: configuration.xml:394
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Pretty print the SQL in the log and console."
-msgstr ""
-"Formate et indente le sql dans la console et dans le log <placeholder-1/>"
+msgstr "Effectue un pretty print du SQL dans la console et dans le log. "
 
-#. Tag: property
-#: configuration.xml:404
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_schema"
-msgstr "hibernate.default_schema"
+msgid "<property>hibernate.default_schema</property>"
+msgstr "<property>hibernate.default_schema</property>"
 
 #. Tag: entry
-#: configuration.xml:406
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Qualify unqualified table names with the given schema/tablespace in "
 "generated SQL."
 msgstr ""
-"Positionne dans le SQL généré un schéma/tablespace par défaut pour les noms "
-"de table ne l'ayant pas surchargé. <placeholder-1/>"
+"Qualifie des noms de table non qualifiés avec le schéma/tablespace dans le "
+"SQL généré."
 
 #. Tag: para
-#: configuration.xml:409
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>SCHEMA_NAME</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>SCHEMA_NAME</literal>"
 
-#. Tag: property
-#: configuration.xml:417
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_catalog"
-msgstr "hibernate.default_catalog"
+msgid "<property>hibernate.default_catalog</property>"
+msgstr "<property>hibernate.default_catalog</property>"
 
 #. Tag: entry
-#: configuration.xml:419
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Qualifies unqualified table names with the given catalog in generated SQL."
 msgstr ""
 "Qualifie les noms de tables non qualifiées avec ce catalogue dans le SQL "
-"généré. <placeholder-1/>"
+"généré.  "
 
 #. Tag: para
-#: configuration.xml:422
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>CATALOG_NAME</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>CATALOG_NAME</literal>"
 
-#. Tag: property
-#: configuration.xml:430
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.session_factory_name"
-msgstr "hibernate.session_factory_name"
+msgid "<property>hibernate.session_factory_name</property>"
+msgstr "<property>hibernate.session_factory_name</property>"
 
 #. Tag: entry
-#: configuration.xml:432
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <interfacename>org.hibernate.SessionFactory</interfacename> will be "
 "automatically bound to this name in JNDI after it has been created."
 msgstr ""
-"La <placeholder-1/> sera automatiquement liée à ce nom dans le JNDI après sa "
-"création. <placeholder-2/>"
+"<interfacename>org.hibernate.SessionFactory</interfacename> sera "
+"automatiquement liée à ce nom dans JNDI après sa création. "
 
 #. Tag: para
-#: configuration.xml:435 configuration.xml:877
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>jndi/composite/name</"
 "literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+" <emphasis role=\"strong\">par ex.</emphasis><literal>jndi/composite/name</"
+"literal>"
 
-#. Tag: property
-#: configuration.xml:443
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.max_fetch_depth"
-msgstr "hibernate.max_fetch_depth"
+msgid "<property>hibernate.max_fetch_depth</property>"
+msgstr "<property>hibernate.max_fetch_depth</property>"
 
 #. Tag: entry
-#: configuration.xml:445
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sets a maximum \"depth\" for the outer join fetch tree for single-ended "
 "associations (one-to-one, many-to-one). A <literal>0</literal> disables "
 "default outer join fetching."
 msgstr ""
-"Définit la profondeur maximale d'un arbre de chargement par jointures "
-"ouvertes pour les associations à cardinalité unitaire (un-à-un, plusieurs-à-"
-"un). Un <placeholder-1/> désactive le chargement par jointure ouverte. "
-"<placeholder-2/>"
+"Configure la profondeur maximale d'un arbre de chargement par jointures "
+"externes pour les associations à cardinalité unitaire (un-à-un, plusieurs-à-"
+"un). Un <literal>0</literal> désactive le chargement par défaut par jointure "
+"externe."
 
 #. Tag: para
-#: configuration.xml:449
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values between "
 "<literal>0</literal> and <literal>3</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ex.</emphasis> valeurs recommandées entre "
-"<literal>0</literal> et <literal>3</literal>"
+"<emphasis role=\"strong\">par ex.</emphasis> valeurs recommandées entre "
+"<literal>0</literal> et <literal>3</literal> "
 
-#. Tag: property
-#: configuration.xml:458
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_batch_fetch_size"
-msgstr "hibernate.default_batch_fetch_size"
+msgid "<property>hibernate.default_batch_fetch_size</property>"
+msgstr "<property>hibernate.default_batch_fetch_size</property>"
 
 #. Tag: entry
-#: configuration.xml:460
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Sets a default size for Hibernate batch fetching of associations."
 msgstr ""
-"Définit une taille par défaut pour le chargement par lot des associations "
-"<placeholder-1/>"
+"Configure une taille par défaut pour le chargement par lot des associations "
+"Hibernate "
 
 #. Tag: para
-#: configuration.xml:462
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values <literal>4</"
 "literal>, <literal>8</literal>, <literal>16</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ex.</emphasis> Valeurs recommandées : <literal>4</"
-"literal>, <literal>8</literal>, <literal>16</literal>"
+"<emphasis role=\"strong\">ex.</emphasis> valeurs recommandées : <literal>4</"
+"literal>, <literal>8</literal>, <literal>16</literal> "
 
-#. Tag: property
-#: configuration.xml:471
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_entity_mode"
-msgstr "hibernate.default_entity_mode"
+msgid "<property>hibernate.default_entity_mode</property>"
+msgstr "<property>hibernate.default_entity_mode</property>"
 
 #. Tag: entry
-#: configuration.xml:473
 #, fuzzy, no-c-format
 msgid ""
 "Sets a default mode for entity representation for all sessions opened from "
 "this <literal>SessionFactory</literal>"
 msgstr ""
-"Définit un mode de représentation par défaut des entités pour toutes les "
-"sessions ouvertes depuis cette <placeholder-1/><placeholder-2/>"
+"Configure un mode de représentation par défaut des entités pour toutes les "
+"sessions ouvertes depuis cette <literal>SessionFactory</literal> "
 
 #. Tag: para
-#: configuration.xml:476
 #, no-c-format
 msgid ""
 "<literal>dynamic-map</literal>, <literal>dom4j</literal>, <literal>pojo</"
@@ -1081,112 +716,96 @@
 "<literal>dynamic-map</literal>, <literal>dom4j</literal>, <literal>pojo</"
 "literal>"
 
-#. Tag: property
-#: configuration.xml:484
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.order_updates"
-msgstr "hibernate.order_updates"
+msgid "<property>hibernate.order_updates</property>"
+msgstr "<property>hibernate.order_updates</property>"
 
 #. Tag: entry
-#: configuration.xml:486
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Forces Hibernate to order SQL updates by the primary key value of the items "
 "being updated. This will result in fewer transaction deadlocks in highly "
 "concurrent systems."
 msgstr ""
-"Force Hibernate à trier les updates SQL par la valeur de la clé primaire des "
-"éléments qui sont mis à jour. Cela permet de limiter les deadlocks de "
-"transaction dans les systèmes hautement concurents. <placeholder-1/>"
+"Force Hibernate à trier les mises à jour SQL par la valeur de la clé "
+"primaire des éléments mis à jour. Cela permet de limiter les deadlocks de "
+"transaction dans les systèmes hautement concurrents."
 
-#. Tag: property
-#: configuration.xml:498
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.generate_statistics"
-msgstr "hibernate.generate_statistics"
+msgid "<property>hibernate.generate_statistics</property>"
+msgstr "<property>hibernate.generate_statistics</property>"
 
 #. Tag: entry
-#: configuration.xml:500
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If enabled, Hibernate will collect statistics useful for performance tuning."
 msgstr ""
 "Si activé, Hibernate va collecter des statistiques utiles pour le réglage "
-"des performances. <placeholder-1/>"
+"des performances. "
 
-#. Tag: property
-#: configuration.xml:511
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.use_identifier_rollback"
-msgstr "hibernate.use_identifer_rollback"
+msgid "<property>hibernate.use_identifier_rollback</property>"
+msgstr "<property>hibernate.use_identifer_rollback</property>"
 
 #. Tag: entry
-#: configuration.xml:513
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If enabled, generated identifier properties will be reset to default values "
 "when objects are deleted."
 msgstr ""
-"Si activé, les propriétés correspondant à l'identifiant des objets vont être "
-"remises aux valeurs par défaut lorsque les objets seront supprimés. "
-"<placeholder-1/>"
+"Si activé, les propriétés correspondant à l'identifiant des objets sont "
+"remises aux valeurs par défaut lorsque les objets sont supprimés. "
 
-#. Tag: property
-#: configuration.xml:524
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.use_sql_comments"
-msgstr "hibernate.use_sql_comments"
+msgid "<property>hibernate.use_sql_comments</property>"
+msgstr "<property>hibernate.use_sql_comments</property>"
 
 #. Tag: entry
-#: configuration.xml:526
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If turned on, Hibernate will generate comments inside the SQL, for easier "
 "debugging, defaults to <literal>false</literal>."
 msgstr ""
-"Si activé, Hibernate va générer des commentaires à l'intérieur des requêtes "
-"SQL pour faciliter le debogage., par défaut à <placeholder-1/>. <placeholder-"
-"2/>"
+"Si activé, Hibernate génère des commentaires à l'intérieur des requêtes SQL "
+"pour faciliter le débogage, par défaut à <literal>false</literal>."
 
 #. Tag: title
-#: configuration.xml:540
 #, no-c-format
 msgid "Hibernate JDBC and Connection Properties"
 msgstr "Propriétés Hibernate liées à JDBC et aux connexions"
 
-#. Tag: property
-#: configuration.xml:555
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.fetch_size"
-msgstr "hibernate.jdbc.fetch_size"
+msgid "<property>hibernate.jdbc.fetch_size</property>"
+msgstr "<property>hibernate.jdbc.fetch_size</property>"
 
 #. Tag: entry
-#: configuration.xml:557
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A non-zero value determines the JDBC fetch size (calls <literal>Statement."
 "setFetchSize()</literal>)."
 msgstr ""
-"Une valeur non nulle détermine la taille de chargement des statements JDBC "
-"(appelle <placeholder-1/>)."
+"Une valeur non nulle détermine la taille des chargements JDBC (appelle "
+"<literal>Statement.setFetchSize()</literal>)."
 
-#. Tag: property
-#: configuration.xml:564
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.batch_size"
-msgstr "hibernate.jdbc.batch_size"
+msgid "<property>hibernate.jdbc.batch_size</property>"
+msgstr "<property>hibernate.jdbc.batch_size</property>"
 
 #. Tag: entry
-#: configuration.xml:566
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A non-zero value enables use of JDBC2 batch updates by Hibernate."
 msgstr ""
-"Une valeur non nulle active l'utilisation par Hibernate des mises à jour par "
-"batch de JDBC2. <placeholder-1/>"
+"Une valeur non nulle active l'utilisation par Hibernate des mise à jour par "
+"lot de JDBC2. "
 
 #. Tag: para
-#: configuration.xml:568
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values between "
 "<literal>5</literal> and <literal>30</literal>"
@@ -1194,136 +813,89 @@
 "<emphasis role=\"strong\">ex.</emphasis> les valeurs recommandées entre "
 "<literal>5</literal> et <literal>30</literal>"
 
-#. Tag: property
-#: configuration.xml:576
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.batch_versioned_data"
-msgstr "hibernate.jdbc.batch_versioned_data"
+msgid "<property>hibernate.jdbc.batch_versioned_data</property>"
+msgstr "<property>hibernate.jdbc.batch_versioned_data</property>"
 
 #. Tag: entry
-#: configuration.xml:578
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Set this property to <literal>true</literal> if your JDBC driver returns "
 "correct row counts from <literal>executeBatch()</literal>. Iit is usually "
 "safe to turn this option on. Hibernate will then use batched DML for "
 "automatically versioned data. Defaults to <literal>false</literal>."
 msgstr ""
-"Paramétrez cette propriété à <placeholder-1/> si votre pilote JDBC retourne "
-"des row counts corrects depuis <placeholder-2/> (il est souvent approprié "
-"d'activer cette option). Hibernate utilisera alors le \"batched DML\" pour "
-"versionner automatiquement les données. Par défaut = <placeholder-3/>. "
-"<placeholder-4/>"
+"Paramétrez cette propriété à <literal>true</literal> si votre pilote JDBC "
+"retourne des comptes de lignes corrects depuis <literal>executeBatch()</"
+"literal> (il est souvent approprié d'activer cette option). Hibernate "
+"utilisera alors le \"batched DML\" pour les données automatiquement "
+"versionnées. Par défaut à <literal>false</literal>. "
 
-#. Tag: property
-#: configuration.xml:591
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.factory_class"
-msgstr "hibernate.jdbc.factory_class"
+msgid "<property>hibernate.jdbc.factory_class</property>"
+msgstr "<property>hibernate.jdbc.factory_class</property>"
 
 #. Tag: entry
-#: configuration.xml:593
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Select a custom <interfacename>org.hibernate.jdbc.Batcher</interfacename>. "
 "Most applications will not need this configuration property."
 msgstr ""
-"Sélectionne un <placeholder-1/> personnalisé. La plupart des applications "
-"n'auront pas besoin de cette propriété de configuration <placeholder-2/>"
+"Sélectionne un <interfacename>org.hibernate.jdbc.Batcher</interfacename> "
+"personnalisé. La plupart des applications n'auront pas besoin de cette "
+"propriété de configuration."
 
 #. Tag: para
-#: configuration.xml:596
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "BatcherFactory</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">par.ex.</emphasis> <literal>classname.of."
+"BatcherFactory</literal>"
 
-#. Tag: property
-#: configuration.xml:604
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_scrollable_resultset"
-msgstr "hibernate.jdbc.use_scrollable_resultset"
+msgid "<property>hibernate.jdbc.use_scrollable_resultset</property>"
+msgstr "<property>hibernate.jdbc.use_scrollable_resultset</property>"
 
 #. Tag: entry
-#: configuration.xml:606
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Enables use of JDBC2 scrollable resultsets by Hibernate. This property is "
 "only necessary when using user-supplied JDBC connections. Hibernate uses "
 "connection metadata otherwise."
 msgstr ""
-"Active l'utilisation par Hibernate des resultsets scrollables de JDBC2. "
-"Cette propriété est seulement nécessaire lorsque l'on utilise une connexion "
-"JDBC fournie par l'utilisateur. Autrement, Hibernate utilise les métadonnées "
-"de la connexion. <placeholder-1/>"
+"Active l'utilisation par Hibernate des ensembles de résultats déroulants de "
+"JDBC2. Cette propriété est seulement nécessaire lorsque l'on utilise des "
+"connexions JDBC fournies par l'utilisateur. Autrement, Hibernate utilise les "
+"métadonnées de la connexion."
 
-#. Tag: property
-#: configuration.xml:618
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_streams_for_binary"
-msgstr "hibernate.jdbc.use_streams_for_binary"
+msgid "<property>hibernate.jdbc.use_streams_for_binary</property>"
+msgstr "<property>hibernate.jdbc.use_streams_for_binary</property>"
 
 #. Tag: entry
-#: configuration.xml:620
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use streams when writing/reading <literal>binary</literal> or "
 "<literal>serializable</literal> types to/from JDBC. <emphasis>*system-level "
 "property*</emphasis>"
 msgstr ""
-"Utilise des flux lorsque l'on écrit/lit des types <placeholder-1/> ou "
-"<placeholder-2/> vers et à partir de JDBC (propriété de niveau système). "
-"<placeholder-3/>"
+"Utilise des flux lorsque l'on écrit/lit des types <literal>binary</literal> "
+"ou des types  <literal>serializable</literal>vers/à partir de JDBC. "
+"<emphasis>*system-level property*</emphasis>"
 
-#. Tag: property
-#: configuration.xml:631
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_get_generated_keys"
-msgstr "hibernate.jdbc.use_get_generated_keys"
+msgid "<property>hibernate.jdbc.use_get_generated_keys</property>"
+msgstr "<property>hibernate.jdbc.use_get_generated_keys</property>"
 
 #. Tag: entry
-#: configuration.xml:633
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Enables use of JDBC3 <literal>PreparedStatement.getGeneratedKeys()</literal> "
 "to retrieve natively generated keys after insert. Requires JDBC3+ driver and "
@@ -1331,210 +903,88 @@
 "identifier generators. By default, it tries to determine the driver "
 "capabilities using connection metadata."
 msgstr ""
-"Active l'utilisation de <placeholder-1/> de JDBC3 pour récupérer nativement "
-"les clés générées après insertion. Nécessite un pilote JDBC3+, le mettre à "
-"false si votre pilote a des problèmes avec les générateurs d'identifiant "
-"Hibernate. Par défaut, essaie de déterminer les possibilités du pilote en "
-"utilisant les meta données de connexion. <placeholder-2/>"
+"Active l'utilisation de <literal>PreparedStatement.getGeneratedKeys()</"
+"literal> de JDBC3 pour récupérer nativement les clés générées après "
+"insertion. Nécessite un pilote JDBC3+ et JRE1.4+, configurés à false si "
+"votre pilote a des problèmes avec les générateurs d'identifiant Hibernate. "
+"Par défaut, essaie de déterminer les possibilités du pilote en utilisant les "
+"metadonnées de connexion."
 
 #. Tag: para
-#: configuration.xml:639 configuration.xml:769 configuration.xml:781
-#: configuration.xml:795 configuration.xml:833
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>true|false</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">par ex.</emphasis> <literal>true|false</literal>"
 
-#. Tag: property
-#: configuration.xml:647
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.provider_class"
-msgstr "hibernate.connection.provider_class"
+msgid "<property>hibernate.connection.provider_class</property>"
+msgstr "<property>hibernate.connection.provider_class</property>"
 
 #. Tag: entry
-#: configuration.xml:649
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a custom <interfacename>org.hibernate.connection."
 "ConnectionProvider</interfacename> which provides JDBC connections to "
 "Hibernate."
 msgstr ""
-"Le nom de la classe d'un <placeholder-1/> personnalisé qui fournit des "
-"connexions JDBC à Hibernate <placeholder-2/>"
+"Le nom de la classe d'un <interfacename>org.hibernate.connection."
+"ConnectionProvider</interfacename> personnalisé qui fournit des connexions "
+"JDBC à Hibernate."
 
 #. Tag: para
-#: configuration.xml:652
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "ConnectionProvider</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">par ex.</emphasis><literal>classname.of."
+"ConnectionProvider</literal> "
 
-#. Tag: property
-#: configuration.xml:660
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.isolation"
-msgstr "hibernate.connection.isolation"
+msgid "<property>hibernate.connection.isolation</property>"
+msgstr "<property>hibernate.connection.isolation</property>"
 
 #. Tag: entry
-#: configuration.xml:662
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sets the JDBC transaction isolation level. Check <interfacename>java.sql."
 "Connection</interfacename> for meaningful values, but note that most "
 "databases do not support all isolation levels and some define additional, "
 "non-standard isolations."
 msgstr ""
-"Définit le niveau d'isolation des transactions JDBC. Regardez <placeholder-1/"
-"> pour connaître le sens des différentes valeurs mais notez également que la "
-"plupart des bases de données ne supportent pas tous les niveaux d'isolation. "
-"<placeholder-2/>"
+"Définit le niveau d'isolation des transactions JDBC. Regardez <literal>java."
+"sql.Connection</literal> pour des valeurs significatives mais notez "
+"également que la plupart des bases de données ne supportent pas tous les "
+"niveaux d'isolation et que certaines définissent des isolations non standard "
+"supplémentaires."
 
 #. Tag: para
-#: configuration.xml:666
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>1, 2, 4, 8</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">par ex.</emphasis><literal>1, 2, 4, 8</literal> "
 
-#. Tag: property
-#: configuration.xml:674
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.autocommit"
-msgstr "hibernate.connection.autocommit"
+msgid "<property>hibernate.connection.autocommit</property>"
+msgstr " hibernate.connection.autocommit"
 
 #. Tag: entry
-#: configuration.xml:676
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Enables autocommit for JDBC pooled connections (it is not recommended)."
 msgstr ""
 "Active le mode de commit automatique (autocommit) pour les connexions JDBC "
-"du pool (non recommandé). <placeholder-1/>"
+"du pool (non recommandé). "
 
-#. Tag: property
-#: configuration.xml:686
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.release_mode"
-msgstr "hibernate.connection.release_mode"
+msgid "<property>hibernate.connection.release_mode</property>"
+msgstr "<property>hibernate.connection.release_mode</property>"
 
 #. Tag: entry
-#: configuration.xml:688
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Specifies when Hibernate should release JDBC connections. By default, a JDBC "
 "connection is held until the session is explicitly closed or disconnected. "
@@ -1546,186 +996,143 @@
 "the JTA and CMT transaction strategies and <literal>after_transaction</"
 "literal> for the JDBC transaction strategy."
 msgstr ""
-"Spécifie à quel moment Hibernate doit relacher les connexion JDBC. Par "
-"défaut une connexion JDBC est conservée jusqu'à ce que la session soit "
+"Spécifie à quel moment Hibernate doit relâcher les connexions JDBC. Par "
+"défaut, une connexion JDBC est conservée jusqu'à ce que la session soit "
 "explicitement fermée ou déconnectée. Pour une source de données JTA d'un "
-"serveur d'application, vous devriez utiliser <placeholder-1/> pour libérer "
-"les connexions de manière plus agressive après chaque appel JDBC. Pour une "
-"connexion non JTA, il est souvent préférable de libérer la connexion à la "
-"fin de chaque transaction en utilisant <placeholder-2/>. <placeholder-3/> "
-"choisira <placeholder-4/> pour des transactions JTA et CMT et <placeholder-5/"
-"> pour des transactions JDBC. <placeholder-6/><placeholder-7/>"
+"serveur d'applications, vous devriez utiliser <literal>after_statement</"
+"literal> pour libérer les connexions de manière plus agressive après chaque "
+"appel JDBC. Pour une connexion non JTA, il est souvent préférable de libérer "
+"la connexion à la fin de chaque transaction en utilisant "
+"<literal>after_transaction</literal>. <literal>auto</literal> choisira "
+"<literal>after_statement</literal> pour les stratégies de transactions JTA "
+"et CMT et <literal>after_transaction</literal> pour des stratégies de "
+"transactions JDBC. "
 
 #. Tag: para
-#: configuration.xml:699
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>auto</literal> (default) "
 "| <literal>on_close</literal> | <literal>after_transaction</literal> | "
 "<literal>after_statement</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ex.</emphasis><literal>on_close</literal> "
-"(default) | <literal>after_transaction</literal> | <literal>after_statement</"
-"literal> | <literal>auto</literal>"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>auto</literal> (default) "
+"| <literal>on_close</literal> | <literal>after_transaction</literal> | "
+"<literal>after_statement</literal>"
 
 #. Tag: para
-#: configuration.xml:704
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This setting only affects <literal>Session</literal>s returned from "
 "<literal>SessionFactory.openSession</literal>. For <literal>Session</"
 "literal>s obtained through <literal>SessionFactory.getCurrentSession</"
 "literal>, the <literal>CurrentSessionContext</literal> implementation "
 "configured for use controls the connection release mode for those "
-"<literal>Session</literal>s. See"
-msgstr ""
-"Note that this setting only affects <literal>Session</literal>s returned "
-"from <literal>SessionFactory.openSession</literal>. For <literal>Session</"
-"literal>s obtained through <literal>SessionFactory.getCurrentSession</"
-"literal>, the <literal>CurrentSessionContext</literal> implementation "
-"configured for use controls the connection release mode for those "
 "<literal>Session</literal>s. See <xref linkend=\"architecture-current-session"
-"\"/>"
+"\" />"
+msgstr ""
+"Remarquez que ce paramètre influence uniquement les <literal>Session</"
+"literal> s retournées depuis <literal>SessionFactory.openSession</literal>. "
+"Pour les <literal>Session</literal> s obtenues depuis "
+"<literal>SessionFactory.getCurrentSession</literal>, l'implémentation "
+"<literal>CurrentSessionContext</literal> configurée pour l'utilisation, "
+"contrôle le mode de libération des connexions pour ces <literal>Session</"
+"literal> s. Consultez <xref linkend=\"architecture-current-session\" />"
 
 #. Tag: entry
-#: configuration.xml:715
 #, no-c-format
 msgid ""
 "<property>hibernate.connection.</property><emphasis>&lt;propertyName&gt;</"
 "emphasis>"
 msgstr ""
+"<property>hibernate.connection.</property><emphasis>&lt;propertyName&gt;</"
+"emphasis>"
 
 #. Tag: entry
-#: configuration.xml:718
 #, no-c-format
 msgid ""
 "Pass the JDBC property <emphasis>&lt;propertyName&gt;</emphasis> to "
 "<literal>DriverManager.getConnection()</literal>."
 msgstr ""
+"Passez une propriété JDBC <literal>propertyName</literal> à "
+"<literal>DriverManager.getConnection()</literal>. "
 
 #. Tag: entry
-#: configuration.xml:724
 #, no-c-format
 msgid ""
 "<property>hibernate.jndi.</property><emphasis>&lt;propertyName&gt;</emphasis>"
 msgstr ""
+"<property>hibernate.jndi.</property><emphasis>&lt;propertyName&gt;</emphasis>"
 
 #. Tag: entry
-#: configuration.xml:727
 #, no-c-format
 msgid ""
 "Pass the property <emphasis>&lt;propertyName&gt;</emphasis> to the JNDI "
 "<literal>InitialContextFactory</literal>."
 msgstr ""
+"Passez la propriété <emphasis>&lt;propertyName&gt;</emphasis> au JNDI "
+"<literal>InitialContextFactory</literal>."
 
 #. Tag: title
-#: configuration.xml:737
 #, no-c-format
 msgid "Hibernate Cache Properties"
-msgstr "Propriétés du Cache d'Hibernate"
+msgstr "Propriétés du Cache Hibernate"
 
-#. Tag: literal
-#: configuration.xml:750
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.provider_class"
-msgstr "hibernate.cache.provider_class"
+msgid "<literal>hibernate.cache.provider_class</literal>"
+msgstr "<literal>hibernate.cache.provider_class</literal>"
 
 #. Tag: entry
-#: configuration.xml:752
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The classname of a custom <literal>CacheProvider</literal>."
-msgstr "Le nom de classe d'un <placeholder-1/> spécifique. <placeholder-2/>"
+msgstr "Le nom de classe d'un <literal>CacheProvider</literal> personnalisé."
 
 #. Tag: para
-#: configuration.xml:754
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "CacheProvider</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">par ex.</emphasis><literal>classname.of."
+"CacheProvider</literal> "
 
-#. Tag: literal
-#: configuration.xml:762
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_minimal_puts"
-msgstr "hibernate.cache.use_minimal_puts"
+msgid "<literal>hibernate.cache.use_minimal_puts</literal>"
+msgstr "<literal>hibernate.cache.use_minimal_puts</literal>"
 
 #. Tag: entry
-#: configuration.xml:764
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Optimizes second-level cache operation to minimize writes, at the cost of "
 "more frequent reads. This setting is most useful for clustered caches and, "
 "in Hibernate3, is enabled by default for clustered cache implementations."
 msgstr ""
 "Optimise le cache de second niveau en minimisant les écritures, au prix de "
-"plus de lectures. Ce paramètre est surtout utile pour les caches en cluster "
+"plus de lectures. Ce paramètre est surtout utile pour les caches en cluster,"
 "et est activé par défaut dans hibernate3 pour les implémentations de cache "
-"en cluster. <placeholder-1/>"
+"en cluster.  "
 
-#. Tag: literal
-#: configuration.xml:777
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_query_cache"
-msgstr "hibernate.cache.use_query_cache"
+msgid "<literal>hibernate.cache.use_query_cache</literal>"
+msgstr "<literal>hibernate.cache.use_query_cache</literal>"
 
 #. Tag: entry
-#: configuration.xml:779
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Enables the query cache. Individual queries still have to be set cachable."
 msgstr ""
 "Activer le cache de requête, les requêtes individuelles doivent tout de même "
-"être déclarées comme pouvant être mise en cache. <placeholder-1/>"
+"être déclarées comme pouvant être mises en cache."
 
-#. Tag: literal
-#: configuration.xml:789
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_second_level_cache"
-msgstr "hibernate.cache.use_second_level_cache"
+msgid "<literal>hibernate.cache.use_second_level_cache</literal>"
+msgstr "<literal>hibernate.cache.use_second_level_cache</literal>"
 
 #. Tag: entry
-#: configuration.xml:791
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Can be used to completely disable the second level cache, which is enabled "
 "by default for classes which specify a <literal>&lt;cache&gt;</literal> "
@@ -1733,469 +1140,250 @@
 msgstr ""
 "Peut être utilisé pour désactiver complètement le cache de second niveau qui "
 "est activé par défaut pour les classes qui spécifient un élément "
-"<placeholder-1/> dans leur mapping. <placeholder-2/>"
+"<literal>&lt;cache&gt;</literal> dans leur mappage.  "
 
-#. Tag: literal
-#: configuration.xml:803
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.query_cache_factory"
-msgstr "hibernate.cache.query_cache_factory"
+msgid "<literal>hibernate.cache.query_cache_factory</literal>"
+msgstr "<literal>hibernate.cache.query_cache_factory</literal>"
 
 #. Tag: entry
-#: configuration.xml:805
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a custom <literal>QueryCache</literal> interface, defaults "
 "to the built-in <literal>StandardQueryCache</literal>."
 msgstr ""
-"Le nom de classe d'une interface <placeholder-1/> , par défaut = built-in "
-"<placeholder-2/>. <placeholder-3/>"
+"Le nom de classe d'une interface <literal>QueryCache</literal> "
+"personnalisée, par défaut prend la valeur du <literal>StandardQueryCache</"
+"literal> imbriqué."
 
 #. Tag: para
-#: configuration.xml:808
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of.QueryCache</"
 "literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">par ex.</emphasis><literal>classname.of."
+"QueryCache</literal> "
 
-#. Tag: literal
-#: configuration.xml:816
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.region_prefix"
-msgstr "hibernate.cache.region_prefix"
+msgid "<literal>hibernate.cache.region_prefix</literal>"
+msgstr "<literal>hibernate.cache.region_prefix</literal>"
 
 #. Tag: entry
-#: configuration.xml:818
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A prefix to use for second-level cache region names."
 msgstr ""
-"Un préfixe à utiliser pour le nom des régions du cache de second niveau. "
-"<placeholder-1/>"
+"Un préfixe à utiliser pour les noms de régions du cache de second niveau. "
 
 #. Tag: para
-#: configuration.xml:820
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>prefix</literal>"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+msgstr "<emphasis role=\"strong\">par ex.</emphasis> <literal>prefix</literal>"
 
-#. Tag: literal
-#: configuration.xml:828
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_structured_entries"
-msgstr "hibernate.cache.use_structured_entries"
+msgid "<literal>hibernate.cache.use_structured_entries</literal>"
+msgstr "<literal>hibernate.cache.use_structured_entries</literal>"
 
 #. Tag: entry
-#: configuration.xml:830
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Forces Hibernate to store data in the second-level cache in a more human-"
 "friendly format."
 msgstr ""
-"Force Hibernate à stocker les données dans le cache de second niveau dans un "
-"format plus adapté à la visualisation par un humain. <placeholder-1/>"
+"Force Hibernate à stocker les données dans le cache de second niveau en un "
+"format plus adapté à la visualisation. "
 
 #. Tag: title
-#: configuration.xml:844
 #, no-c-format
 msgid "Hibernate Transaction Properties"
 msgstr "Propriétés des transactions Hibernate"
 
-#. Tag: literal
-#: configuration.xml:857
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.transaction.factory_class"
-msgstr "hibernate.transaction.factory_class"
+msgid "<literal>hibernate.transaction.factory_class</literal>"
+msgstr "<literal>hibernate.transaction.factory_class</literal>"
 
 #. Tag: entry
-#: configuration.xml:859
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a <literal>TransactionFactory</literal> to use with "
 "Hibernate <literal>Transaction</literal> API (defaults to "
 "<literal>JDBCTransactionFactory</literal>)."
 msgstr ""
-"Le nom de classe d'une <placeholder-1/> qui sera utilisée par l'API "
-"<placeholder-2/> d'Hibernate (la valeur par défaut est <placeholder-3/>). "
-"<placeholder-4/>"
+"Le nom de classe d'une <literal>TransactionFactory</literal> qui sera "
+"utilisée par l'API <literal>Transaction</literal> de Hibernate (la valeur "
+"par défaut est <literal>JDBCTransactionFactory</literal>). "
 
 #. Tag: para
-#: configuration.xml:863
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "TransactionFactory</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">par ex.</emphasis><literal>classname.of."
+"TransactionFactory</literal> "
 
-#. Tag: literal
-#: configuration.xml:871
+#. Tag: entry
 #, no-c-format
-msgid "jta.UserTransaction"
-msgstr "jta.UserTransaction"
+msgid "<literal>jta.UserTransaction</literal>"
+msgstr "<literal>jta.UserTransaction</literal>"
 
 #. Tag: entry
-#: configuration.xml:873
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A JNDI name used by <literal>JTATransactionFactory</literal> to obtain the "
 "JTA <literal>UserTransaction</literal> from the application server."
 msgstr ""
-"Le nom JNDI utilisé par la <placeholder-1/> pour obtenir la <placeholder-2/> "
-"JTA du serveur d'applications. <placeholder-3/>"
+"Le nom JNDI utilisé par la <literal>JTATransactionFactory</literal> pour "
+"obtenir la <literal>UserTransaction</literal> JTA du serveur d'applications."
 
-#. Tag: literal
-#: configuration.xml:885
-#, no-c-format
-msgid "hibernate.transaction.manager_lookup_class"
-msgstr "hibernate.transaction.manager_lookup_class"
-
 #. Tag: entry
-#: configuration.xml:887
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.manager_lookup_class</literal>"
+msgstr "<literal>hibernate.transaction. manager_lookup_class</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "The classname of a <literal>TransactionManagerLookup</literal>. It is "
 "required when JVM-level caching is enabled or when using hilo generator in a "
 "JTA environment."
 msgstr ""
-"Le nom de la classe du <placeholder-1/> - requis lorsque le cache de niveau "
-"JVM est activé ou lorsque l'on utilise un générateur hilo dans un "
-"environnement JTA. <placeholder-2/>"
+"Le nom de la classe d'une <literal>TransactionManagerLookup</literal> - "
+"requise lorsque le cache de niveau JVM est activé ou lorsque l'on utilise un "
+"générateur hilo dans un environnement JTA."
 
 #. Tag: para
-#: configuration.xml:891
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "TransactionManagerLookup</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">par ex.</emphasis><literal>classname.of."
+"TransactionManagerLookup</literal> "
 
-#. Tag: literal
-#: configuration.xml:899
-#, no-c-format
-msgid "hibernate.transaction.flush_before_completion"
-msgstr "hibernate.transaction.flush_before_completion"
-
 #. Tag: entry
-#: configuration.xml:901
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.flush_before_completion</literal>"
+msgstr "<literal>hibernate.transaction. flush_before_completion</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "If enabled, the session will be automatically flushed during the before "
 "completion phase of the transaction. Built-in and automatic session context "
-"management is preferred, see <xref linkend=\"architecture-current-session\"/"
+"management is preferred, see <xref linkend=\"architecture-current-session\" /"
 ">."
 msgstr ""
 "Si activé, la session sera automatiquement vidée durant la phase qui précède "
-"la fin de la transaction (before completion). La gestion automatique de "
-"contexte fourni par Hibernate est recommandée, voir <xref linkend="
-"\"architecture-current-session\"/>. <placeholder-1/>"
+"la fin de la transaction. La gestion automatique et imbriquée du contexte de "
+"session fourni par Hibernate est préférable, consultez <xref linkend="
+"\"architecture-current-session\" />."
 
-#. Tag: literal
-#: configuration.xml:914
-#, no-c-format
-msgid "hibernate.transaction.auto_close_session"
-msgstr "hibernate.transaction.auto_close_session"
-
 #. Tag: entry
-#: configuration.xml:916
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.auto_close_session</literal>"
+msgstr "<literal>hibernate.transaction. auto_close_session</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "If enabled, the session will be automatically closed during the after "
 "completion phase of the transaction. Built-in and automatic session context "
-"management is preferred, see <xref linkend=\"architecture-current-session\"/"
+"management is preferred, see <xref linkend=\"architecture-current-session\" /"
 ">."
 msgstr ""
-"Si activé, la session sera automatiquement fermé pendant la phase qui suit "
-"la fin de la transaction (after completion). La gestion automatique de "
-"contexte fourni par Hibernate est recommandée, voir <placeholder-1/>"
+"Si activé, la session sera automatiquement fermée pendant la phase qui suit "
+"la fin de la transaction. La gestion automatique et imbriquée du contexte de "
+"session fourni par Hibernate est préférable, consultez <xref linkend="
+"\"architecture-current-session\" />."
 
 #. Tag: title
-#: configuration.xml:932
 #, no-c-format
 msgid "Miscellaneous Properties"
 msgstr "Propriétés diverses"
 
-#. Tag: literal
-#: configuration.xml:945
-#, no-c-format
-msgid "hibernate.current_session_context_class"
-msgstr "hibernate.current_session_context_class"
-
 #. Tag: entry
-#: configuration.xml:947
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.current_session_context_class</literal>"
+msgstr "<literal>hibernate. current_session_context_class</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "Supply a custom strategy for the scoping of the \"current\" "
 "<literal>Session</literal>. See <xref linkend=\"architecture-current-session"
-"\"/> for more information about the built-in strategies."
+"\" /> for more information about the built-in strategies."
 msgstr ""
-"Fournit une stratégie particulière pour contextualiser la <placeholder-1/> "
-"courante. Voir <xref linkend=\"architecture-current-session\"/> pour plus "
-"d'informations sur les stratégies fournies. <placeholder-2/>"
+"Fournit une stratégie particulière pour la portée de la <literal>Session</"
+"literal> courante. Consultez <xref linkend=\"architecture-current-session\" /"
+"> pour plus d'informations sur les stratégies incorporées. "
 
 #. Tag: para
-#: configuration.xml:952
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>jta</literal> | "
 "<literal>thread</literal> | <literal>managed</literal> | <literal>custom."
 "Class</literal>"
 msgstr ""
-"<emphasis role=\"strong\">eg.</emphasis><literal>jta</literal> | "
-"<literal>thread</literal> | <literal>custom.Class</literal>"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>jta</literal> | "
+"<literal>thread</literal> | <literal>managed</literal> | <literal>custom."
+"Class</literal>"
 
-#. Tag: literal
-#: configuration.xml:961
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.query.factory_class"
-msgstr "hibernate.query.factory_class"
+msgid "<literal>hibernate.query.factory_class</literal>"
+msgstr "<literal>hibernate.query.factory_class</literal>"
 
 #. Tag: entry
-#: configuration.xml:963
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Chooses the HQL parser implementation."
-msgstr "Choisi l'implémentation du parseur de requête <placeholder-1/>"
+msgstr "Choisit l'implémentation du parseur de requête HQL. "
 
 #. Tag: para
-#: configuration.xml:965
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>org.hibernate.hql.ast."
 "ASTQueryTranslatorFactory</literal> or <literal>org.hibernate.hql.classic."
 "ClassicQueryTranslatorFactory</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ex.</emphasis><literal>org.hibernate.hql.ast."
+"<emphasis role=\"strong\">par ex.</emphasis><literal>org.hibernate.hql.ast."
 "ASTQueryTranslatorFactory</literal> ou <literal>org.hibernate.hql.classic."
-"ClassicQueryTranslatorFactory</literal>"
+"ClassicQueryTranslatorFactory</literal> "
 
-#. Tag: literal
-#: configuration.xml:974
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.query.substitutions"
-msgstr "hibernate.query.substitutions"
+msgid "<literal>hibernate.query.substitutions</literal>"
+msgstr "<literal>hibernate.query.substitutions</literal>"
 
 #. Tag: entry
-#: configuration.xml:976
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Is used to map from tokens in Hibernate queries to SQL tokens (tokens might "
 "be function or literal names, for example)."
 msgstr ""
-"Lien entre les tokens de requêtes Hibernate et les tokens SQL (les tokens "
-"peuvent être des fonctions ou des noms littéraux par exemple). <placeholder-"
-"1/>"
+"Lien entre les jetons de requêtes Hibernate et les jetons SQL (les jetons "
+"peuvent être des fonctions ou des noms textuels par exemple)."
 
 #. Tag: para
-#: configuration.xml:979
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>hqlLiteral=SQL_LITERAL, "
 "hqlFunction=SQLFUNC</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">par ex.</emphasis><literal>hqlLiteral=SQL_LITERAL, "
+"hqlFunction=SQLFUNC</literal> "
 
-#. Tag: literal
-#: configuration.xml:987
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.hbm2ddl.auto"
-msgstr "hibernate.hbm2ddl.auto"
+msgid "<literal>hibernate.hbm2ddl.auto</literal>"
+msgstr "<literal>hibernate.hbm2ddl.auto</literal>"
 
 #. Tag: entry
-#: configuration.xml:989
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Automatically validates or exports schema DDL to the database when the "
 "<literal>SessionFactory</literal> is created. With <literal>create-drop</"
@@ -2203,31 +1391,29 @@
 "<literal>SessionFactory</literal> is closed explicitly."
 msgstr ""
 "Valide ou exporte automatiquement le schéma DDL vers la base de données "
-"lorsque la <placeholder-1/> est créée. La valeur <placeholder-2/> permet de "
-"supprimer le schéma de base de données lorsque la <placeholder-3/> est "
-"fermée explicitement. <placeholder-4/>"
+"lorsque la <literal>SessionFactory</literal> est créée. La valeur "
+"<literal>create-drop</literal> permet de supprimer le schéma de base de "
+"données lorsque la <literal>SessionFactory</literal> est fermée "
+"explicitement."
 
 #. Tag: para
-#: configuration.xml:995
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>validate</literal> | "
 "<literal>update</literal> | <literal>create</literal> | <literal>create-"
 "drop</literal>"
 msgstr ""
-"<emphasis role=\"strong\">ex.</emphasis><literal>validate</literal> | "
+"<emphasis role=\"strong\">par ex.</emphasis><literal>validate</literal> | "
 "<literal>update</literal> | <literal>create</literal> | <literal>create-"
-"drop</literal>"
+"drop</literal> "
 
-#. Tag: literal
-#: configuration.xml:1004
-#, no-c-format
-msgid "hibernate.cglib.use_reflection_optimizer"
-msgstr "hibernate.cglib.use_reflection_optimizer"
-
 #. Tag: entry
-#: configuration.xml:1006
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.cglib.use_reflection_optimizer</literal>"
+msgstr "<literal>hibernate.cglib. use_reflection_optimizer</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "Enables the use of CGLIB instead of runtime reflection (System-level "
 "property). Reflection can sometimes be useful when troubleshooting. "
@@ -2236,19 +1422,17 @@
 msgstr ""
 "Active l'utilisation de CGLIB à la place de la réflexion à l'exécution "
 "(Propriété de niveau système). La réflexion peut parfois être utile pour "
-"résoudre des problèmes. Notez qu'Hibernate a tout de même toujours besoin de "
-"CGLIB même si l'optimiseur est désactivé. Cette optimisation ne peut être "
-"définie que dans le fichier <placeholder-1/>. <placeholder-2/>"
+"résoudre des problèmes. Notez que Hibernate a encore besoin et toujours de "
+"CGLIB, même si l'optimiseur est désactivé. Vous ne pouvez pas configurer "
+"cette propriété dans la <literal>hibernate.cfg.xml</literal>. "
 
 #. Tag: title
-#: configuration.xml:1022
 #, no-c-format
 msgid "SQL Dialects"
 msgstr "Dialectes SQL"
 
 #. Tag: para
-#: configuration.xml:1024
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Always set the <literal>hibernate.dialect</literal> property to the correct "
 "<literal>org.hibernate.dialect.Dialect</literal> subclass for your database. "
@@ -2256,319 +1440,264 @@
 "the other properties listed above. This means that you will not have to "
 "specify them manually."
 msgstr ""
-"Vous devriez toujours positionner la propriété <literal>hibernate.dialect</"
-"literal> à la sous-classe de <literal>org.hibernate.dialect.Dialect</"
-"literal> appropriée à votre base de données. Si vous spécifiez un dialecte, "
-"Hibernate utilisera des valeurs adaptées pour certaines autres propriétés "
-"listées ci-dessus, vous évitant l'effort de le faire à la main."
+"Il est recommandé de toujours positionner la propriété <literal>hibernate."
+"dialect</literal> à la sous-classe de <literal>org.hibernate.dialect."
+"Dialect</literal> appropriée à votre base de données. Si vous spécifiez un "
+"dialecte, Hibernate utilisera des valeurs adaptées pour certaines autres "
+"propriétés listées ci-dessus, vous évitant ainsi de l'effectuer à la main. "
 
 #. Tag: title
-#: configuration.xml:1032
 #, no-c-format
 msgid "Hibernate SQL Dialects (<literal>hibernate.dialect</literal>)"
-msgstr "Dialectes SQL d'Hibernate (<literal>hibernate.dialect</literal>)"
+msgstr "Dialectes SQL de Hibernate (<literal>hibernate.dialect</literal>)"
 
 #. Tag: entry
-#: configuration.xml:1040
 #, no-c-format
 msgid "RDBMS"
-msgstr "SGBD"
+msgstr "RDBMS"
 
 #. Tag: entry
-#: configuration.xml:1041
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Dialect"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Dialect\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Dialecte"
+msgstr "Dialecte"
 
 #. Tag: entry
-#: configuration.xml:1046
 #, no-c-format
-msgid "<entry>DB2</entry>"
-msgstr ""
+msgid "DB2"
+msgstr "DB2"
 
-#. Tag: literal
-#: configuration.xml:1046
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2Dialect"
-msgstr "org.hibernate.dialect.DB2Dialect"
+msgid "<literal>org.hibernate.dialect.DB2Dialect</literal>"
+msgstr "<literal>org.hibernate.dialect.DB2Dialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1049
 #, no-c-format
 msgid "DB2 AS/400"
 msgstr "DB2 AS/400"
 
-#. Tag: literal
-#: configuration.xml:1049
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2400Dialect"
-msgstr "org.hibernate.dialect.DB2400Dialect"
+msgid "<literal>org.hibernate.dialect.DB2400Dialect</literal>"
+msgstr "<literal>org.hibernate.dialect.DB2400Dialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1052
 #, no-c-format
 msgid "DB2 OS390"
 msgstr "DB2 OS390"
 
-#. Tag: literal
-#: configuration.xml:1052
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2390Dialect"
-msgstr "org.hibernate.dialect.DB2390Dialect"
+msgid "<literal>org.hibernate.dialect.DB2390Dialect</literal>"
+msgstr "<literal>org.hibernate.dialect.DB2390Dialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1055
 #, no-c-format
 msgid "PostgreSQL"
 msgstr "PostgreSQL"
 
-#. Tag: literal
-#: configuration.xml:1055
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.PostgreSQLDialect"
-msgstr "org.hibernate.dialect.PostgreSQLDialect"
+msgid "<literal>org.hibernate.dialect.PostgreSQLDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.PostgreSQLDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1058
 #, no-c-format
 msgid "MySQL"
 msgstr "MySQL"
 
-#. Tag: literal
-#: configuration.xml:1058
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLDialect"
-msgstr "org.hibernate.dialect.MySQLDialect"
+msgid "<literal>org.hibernate.dialect.MySQLDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MySQLDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1061
 #, no-c-format
 msgid "MySQL with InnoDB"
 msgstr "MySQL with InnoDB"
 
-#. Tag: literal
-#: configuration.xml:1061
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLInnoDBDialect"
-msgstr "org.hibernate.dialect.MySQLInnoDBDialect"
+msgid "<literal>org.hibernate.dialect.MySQLInnoDBDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MySQLInnoDBDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1064
 #, no-c-format
 msgid "MySQL with MyISAM"
 msgstr "MySQL with MyISAM"
 
-#. Tag: literal
-#: configuration.xml:1064
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLMyISAMDialect"
-msgstr "org.hibernate.dialect.MySQLMyISAMDialect"
+msgid "<literal>org.hibernate.dialect.MySQLMyISAMDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MySQLMyISAMDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1067
 #, no-c-format
 msgid "Oracle (any version)"
-msgstr "Oracle (any version)"
+msgstr "Oracle (toutes versions)"
 
-#. Tag: literal
-#: configuration.xml:1067
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.OracleDialect"
-msgstr "org.hibernate.dialect.OracleDialect"
+msgid "<literal>org.hibernate.dialect.OracleDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.OracleDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1070
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Oracle 9i"
-msgstr "Oracle 9i/10g"
+msgstr "Oracle 9i"
 
-#. Tag: literal
-#: configuration.xml:1070
-#, fuzzy, no-c-format
-msgid "org.hibernate.dialect.Oracle9iDialect"
-msgstr "org.hibernate.dialect.Oracle9Dialect"
+#. Tag: entry
+#, no-c-format
+msgid "<literal>org.hibernate.dialect.Oracle9iDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.Oracle9iDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1073
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Oracle 10g"
-msgstr "Oracle 9i/10g"
+msgstr "Oracle 10g"
 
-#. Tag: literal
-#: configuration.xml:1073
-#, fuzzy, no-c-format
-msgid "org.hibernate.dialect.Oracle10gDialect"
-msgstr "org.hibernate.dialect.OracleDialect"
+#. Tag: entry
+#, no-c-format
+msgid "<literal>org.hibernate.dialect.Oracle10gDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.Oracle10gDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1076
 #, no-c-format
 msgid "Sybase"
 msgstr "Sybase"
 
-#. Tag: literal
-#: configuration.xml:1076
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SybaseDialect"
-msgstr "org.hibernate.dialect.SybaseDialect"
+msgid "<literal>org.hibernate.dialect.SybaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SybaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1079
 #, no-c-format
 msgid "Sybase Anywhere"
 msgstr "Sybase Anywhere"
 
-#. Tag: literal
-#: configuration.xml:1079
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SybaseAnywhereDialect"
-msgstr "org.hibernate.dialect.SybaseAnywhereDialect"
+msgid "<literal>org.hibernate.dialect.SybaseAnywhereDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SybaseAnywhereDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1082
 #, no-c-format
 msgid "Microsoft SQL Server"
 msgstr "Microsoft SQL Server"
 
-#. Tag: literal
-#: configuration.xml:1082
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SQLServerDialect"
-msgstr "org.hibernate.dialect.SQLServerDialect"
+msgid "<literal>org.hibernate.dialect.SQLServerDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SQLServerDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1085
 #, no-c-format
 msgid "SAP DB"
 msgstr "SAP DB"
 
-#. Tag: literal
-#: configuration.xml:1085
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SAPDBDialect"
-msgstr "org.hibernate.dialect.SAPDBDialect"
+msgid "<literal>org.hibernate.dialect.SAPDBDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SAPDBDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1088
 #, no-c-format
 msgid "Informix"
 msgstr "Informix"
 
-#. Tag: literal
-#: configuration.xml:1088
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.InformixDialect"
-msgstr "org.hibernate.dialect.InformixDialect"
+msgid "<literal>org.hibernate.dialect.InformixDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.InformixDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1091
 #, no-c-format
 msgid "HypersonicSQL"
 msgstr "HypersonicSQL"
 
-#. Tag: literal
-#: configuration.xml:1091
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.HSQLDialect"
-msgstr "org.hibernate.dialect.HSQLDialect"
+msgid "<literal>org.hibernate.dialect.HSQLDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.HSQLDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1094
 #, no-c-format
 msgid "Ingres"
 msgstr "Ingres"
 
-#. Tag: literal
-#: configuration.xml:1094
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.IngresDialect"
-msgstr "org.hibernate.dialect.IngresDialect"
+msgid "<literal>org.hibernate.dialect.IngresDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.IngresDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1097
 #, no-c-format
 msgid "Progress"
 msgstr "Progress"
 
-#. Tag: literal
-#: configuration.xml:1097
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.ProgressDialect"
-msgstr "org.hibernate.dialect.ProgressDialect"
+msgid "<literal>org.hibernate.dialect.ProgressDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.ProgressDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1100
 #, no-c-format
 msgid "Mckoi SQL"
 msgstr "Mckoi SQL"
 
-#. Tag: literal
-#: configuration.xml:1100
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MckoiDialect"
-msgstr "org.hibernate.dialect.MckoiDialect"
+msgid "<literal>org.hibernate.dialect.MckoiDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MckoiDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1103
 #, no-c-format
 msgid "Interbase"
 msgstr "Interbase"
 
-#. Tag: literal
-#: configuration.xml:1103
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.InterbaseDialect"
-msgstr "org.hibernate.dialect.InterbaseDialect"
+msgid "<literal>org.hibernate.dialect.InterbaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.InterbaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1106
 #, no-c-format
 msgid "Pointbase"
 msgstr "Pointbase"
 
-#. Tag: literal
-#: configuration.xml:1106
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.PointbaseDialect"
-msgstr "org.hibernate.dialect.PointbaseDialect"
+msgid "<literal>org.hibernate.dialect.PointbaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.PointbaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1109
 #, no-c-format
 msgid "FrontBase"
 msgstr "FrontBase"
 
-#. Tag: literal
-#: configuration.xml:1109
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.FrontbaseDialect"
-msgstr "org.hibernate.dialect.FrontbaseDialect"
+msgid "<literal>org.hibernate.dialect.FrontbaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.FrontbaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1112
 #, no-c-format
 msgid "Firebird"
 msgstr "Firebird"
 
-#. Tag: literal
-#: configuration.xml:1112
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.FirebirdDialect"
-msgstr "org.hibernate.dialect.FirebirdDialect"
+msgid "<literal>org.hibernate.dialect.FirebirdDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.FirebirdDialect</literal>"
 
 #. Tag: title
-#: configuration.xml:1121
 #, no-c-format
 msgid "Outer Join Fetching"
-msgstr "Chargement par Jointure Ouverte"
+msgstr "Chargement par jointure externe"
 
 #. Tag: para
-#: configuration.xml:1123
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your database supports ANSI, Oracle or Sybase style outer joins, "
 "<emphasis>outer join fetching</emphasis> will often increase performance by "
@@ -2578,17 +1707,16 @@
 "one, one-to-many, many-to-many and one-to-one associations to be retrieved "
 "in a single SQL <literal>SELECT</literal>."
 msgstr ""
-"Si votre base de données supporte les outer joins de type ANSI, Oracle ou "
-"Sybase, <emphasis>le chargement par jointure ouverte</emphasis> devrait "
-"améliorer les performances en limitant le nombre d'aller-retour avec la base "
-"de données (la base de données effectuant donc potentiellement plus de "
-"travail). Le chargement par jointure ouverte permet à un graphe entier "
+"Si votre base de données supporte les jointures externes de type ANSI, "
+"Oracle ou Sybase, <emphasis>le chargement par jointure externe</emphasis> "
+"devrait améliorer les performances en limitant le nombre d'aller-retour avec "
+"la base de données (la base de données effectuant donc potentiellement plus "
+"de travail). Le chargement par jointure ouverte permet à un graphe entier "
 "d'objets connectés par une relation plusieurs-à-un, un-à-plusieurs ou un-à-"
-"un d'être chargé en un seul <literal>SELECT</literal> SQL."
+"un d'être chargé en un seul SQL<literal>SELECT</literal>."
 
 #. Tag: para
-#: configuration.xml:1132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Outer join fetching can be disabled <emphasis>globally</emphasis> by setting "
 "the property <literal>hibernate.max_fetch_depth</literal> to <literal>0</"
@@ -2596,30 +1724,27 @@
 "fetching for one-to-one and many-to-one associations that have been mapped "
 "with <literal>fetch=\"join\"</literal>."
 msgstr ""
-"Le chargement par jointure ouverte peut être désactiver "
+"Le chargement par jointure ouverte peut être désactivé "
 "<emphasis>globalement</emphasis> en mettant la propriété <literal>hibernate."
 "max_fetch_depth</literal> à <literal>0</literal>. Une valeur de <literal>1</"
-"literal> ou plus active le chargement par jointure ouverte pour les "
-"associatiosn un-à-un et plusieurs-à-un qui ont été mappée avec "
-"<literal>fetch=\"join\"</literal>."
+"literal> ou plus active le chargement par jointure externe pour les "
+"associations un-à-un et plusieurs-à-un qui ont été mappées avec "
+"<literal>fetch=\"join\"</literal>. "
 
 #. Tag: para
-#: configuration.xml:1140
 #, no-c-format
-msgid "See <xref linkend=\"performance-fetching\"/> for more information."
+msgid "See <xref linkend=\"performance-fetching\" /> for more information."
 msgstr ""
-"Reportez vous à <xref linkend=\"performance-fetching\"/> pour plus "
-"d'information."
+"Reportez vous à <xref linkend=\"performance-fetching\" /> pour plus "
+"d'informations."
 
 #. Tag: title
-#: configuration.xml:1147
 #, no-c-format
 msgid "Binary Streams"
 msgstr "Flux binaires"
 
 #. Tag: para
-#: configuration.xml:1149
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Oracle limits the size of <literal>byte</literal> arrays that can be passed "
 "to and/or from its JDBC driver. If you wish to use large instances of "
@@ -2627,90 +1752,65 @@
 "should enable <literal>hibernate.jdbc.use_streams_for_binary</literal>. "
 "<emphasis>This is a system-level setting only.</emphasis>"
 msgstr ""
-"Oracle limite la taille d'un tableau de <literal>byte</literal> qui peuvent "
-"être passées à et vers son pilote JDBC. Si vous souhaitez utiliser des "
-"instances larges de type <literal>binary</literal> ou <literal>serializable</"
-"literal>, vous devez activer la propriété <literal>hibernate.jdbc."
-"use_streams_for_binary</literal>. <emphasis>C'est une fonctionalité de "
-"niveau système uniquement.</emphasis>"
+"Oracle limite la taille d'un tableau d'<literal>octets</literal> qui peuvent "
+"être passés vers et à partir de son pilote JDBC. Si vous souhaitez utiliser "
+"des instances larges de type <literal>binary</literal> ou "
+"<literal>serializable</literal>, vous devez activer la propriété "
+"<literal>hibernate.jdbc.use_streams_for_binary</literal>. <emphasis>C'est "
+"une fonctionalité de niveau système uniquement.</emphasis>"
 
 #. Tag: title
-#: configuration.xml:1160
 #, no-c-format
 msgid "Second-level and query cache"
 msgstr "Cache de second niveau et cache de requêtes"
 
 #. Tag: para
-#: configuration.xml:1162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The properties prefixed by <literal>hibernate.cache</literal> allow you to "
 "use a process or cluster scoped second-level cache system with Hibernate. "
-"See the <xref linkend=\"performance-cache\"/> for more information."
+"See the <xref linkend=\"performance-cache\" /> for more information."
 msgstr ""
 "Les propriétés préfixées par <literal>hibernate.cache</literal> vous "
-"permettent d'utiliser un système de cache de second niveau. Ce cache peut "
-"avoir une portée dans le processus ou même être utilisable dans un système "
-"distribué. Référez vous au chapitre <xref linkend=\"performance-cache\"/> "
-"pour plus de détails."
+"permettent d'utiliser un système de cache de second niveau avec Hibernate. "
+"Référez vous à <xref linkend=\"performance-cache\" /> pour plus de détails."
 
 #. Tag: title
-#: configuration.xml:1172
 #, no-c-format
 msgid "Query Language Substitution"
-msgstr "Substitution dans le langage de requêtage"
+msgstr "Substitution dans le langage de requêtes"
 
 #. Tag: para
-#: configuration.xml:1174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can define new Hibernate query tokens using <literal>hibernate.query."
 "substitutions</literal>. For example:"
 msgstr ""
-"Vous pouvez définir de nouveaux tokens dans les requêtes Hibernate en "
-"utilisant la propriété <literal>hibernate.query.substitutions</literal>. Par "
-"exemple :"
+"Vous pouvez définir de nouveaux jetons dans les requêtes Hibernate en "
+"utilisant <literal>hibernate.query.substitutions</literal>. Par exemple :"
 
-#. Tag: programlisting
-#: configuration.xml:1179
-#, no-c-format
-msgid "hibernate.query.substitutions true=1, false=0"
-msgstr "hibernate.query.substitutions vrai=1, faux=0"
-
 #. Tag: para
-#: configuration.xml:1181
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This would cause the tokens <literal>true</literal> and <literal>false</"
 "literal> to be translated to integer literals in the generated SQL."
 msgstr ""
-"remplacerait les tokens <literal>vrai</literal> et <literal>faux</literal> "
-"par des entiers dans le SQL généré."
+"Cela signifierait que les jetons <literal>true</literal> et <literal>false</"
+"literal>  seraient transformés par des entiers dans le SQL généré."
 
-#. Tag: programlisting
-#: configuration.xml:1186
-#, no-c-format
-msgid "hibernate.query.substitutions toLowercase=LOWER"
-msgstr "hibernate.query.substitutions toLowercase=LOWER"
-
 #. Tag: para
-#: configuration.xml:1188
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This would allow you to rename the SQL <literal>LOWER</literal> function."
-msgstr ""
-"permettrait de renommer la fonction SQL <literal>LOWER</literal> en "
-"<literal>toLowercase</literal>"
+msgstr "Cela permettrait de renommer la fonction SQL <literal>LOWER</literal>."
 
 #. Tag: title
-#: configuration.xml:1195
 #, no-c-format
 msgid "Hibernate statistics"
 msgstr "Statistiques Hibernate"
 
 #. Tag: para
-#: configuration.xml:1197
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you enable <literal>hibernate.generate_statistics</literal>, Hibernate "
 "exposes a number of metrics that are useful when tuning a running system via "
@@ -2719,20 +1819,18 @@
 "interfaces in <literal>org.hibernate.stats</literal> for more information."
 msgstr ""
 "Si vous activez <literal>hibernate.generate_statistics</literal>, Hibernate "
-"va fournir un certains nombre de métriques utiles pour régler les "
-"performances d'une application qui tourne via <literal>SessionFactory."
-"getStatistics()</literal>. Hibernate peut aussi être configuré pour exposer "
-"ces statistiques via JMX. Lisez les Javadoc des interfaces dans le package "
-"<literal>org.hibernate.stats</literal> pour plus d'informations."
+"fournira un certain nombre de métriques utiles pour régler les performances "
+"d'une application qui tourne via <literal>SessionFactory.getStatistics()</"
+"literal>. Hibernate peut aussi être configuré pour exposer ces statistiques "
+"via JMX. Lisez les Javadoc des interfaces dans le paquetage <literal>org."
+"hibernate.stats</literal> pour plus d'informations. "
 
 #. Tag: title
-#: configuration.xml:1209
 #, no-c-format
 msgid "Logging"
-msgstr "Tracer"
+msgstr "Journalisation"
 
 #. Tag: para
-#: configuration.xml:1211
 #, no-c-format
 msgid ""
 "Hibernate utilizes <ulink url=\"http://www.slf4j.org/\">Simple Logging "
@@ -2748,10 +1846,22 @@
 "properties file is distributed with Hibernate in the <literal>src/</literal> "
 "directory."
 msgstr ""
+"Hibernate utilise <ulink url=\"http://www.slf4j.org/\">Simple Logging Facade "
+"for Java</ulink> (SLF4J) pour enregistrer divers événements du système. "
+"SLF4J peut diriger votre sortie de logging vers plusieurs structures de "
+"loggings (NOP, Simple, log4j version 1.2, JDK 1.4 logging, JCL or logback) "
+"suivant la liaison que vous choisirez. Pour pouvoir configurer votre "
+"logging, vous aurez besoin de <filename>slf4j-api.jar</filename> dans votre "
+"chemin de classe, ainsi que du fichier jar pour votre liaison préférée - "
+"<filename>slf4j-log4j12.jar</filename> pour Log4J. Voir la documentation "
+"SLF4J <ulink url=\"http://www.slf4j.org/manual.html\">documentation</ulink> "
+"pour davantage d'informations. Pour utiliser Log4j, vous aurez aussi besoin "
+"de mettre un fichier <filename>log4j.properties</filename> dans votre chemin "
+"de classe. Un exemple de fichier de propriétés est distribué avec Hibernate "
+"dans le répertoire <literal>src/</literal>."
 
 #. Tag: para
-#: configuration.xml:1222
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you familiarize yourself with Hibernate's log "
 "messages. A lot of work has been put into making the Hibernate log as "
@@ -2759,166 +1869,142 @@
 "troubleshooting device. The most interesting log categories are the "
 "following:"
 msgstr ""
-"Nous vous recommandons fortement de vous familiariser avec les messages des "
-"traces d'Hibernate. Beaucoup de soins a été apporté pour donner le plus de "
-"détails possible sans les rendre illisibles. C'est un outil essentiel en cas "
-"de soucis. Les catégories de trace les plus intéressantes sont les "
-"suivantes :"
+"Il est vivement recommandé de vous familiariser avec les messages des logs "
+"de Hibernate. Beaucoup de soin a été apporté pour donner le plus de détails "
+"possible sans les rendre illisibles. C'est un outil essentiel en cas de "
+"problèmes. Les catégories de logs les plus intéressantes sont les "
+"suivantes : "
 
 #. Tag: title
-#: configuration.xml:1231
 #, no-c-format
 msgid "Hibernate Log Categories"
-msgstr "Catégories de trace d'Hibernate"
+msgstr "Catégories de logs de Hibernate"
 
 #. Tag: entry
-#: configuration.xml:1237
 #, no-c-format
 msgid "Category"
 msgstr "Catégorie"
 
 #. Tag: entry
-#: configuration.xml:1238
 #, no-c-format
 msgid "Function"
 msgstr "Fonction"
 
-#. Tag: literal
-#: configuration.xml:1243
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.SQL"
-msgstr "org.hibernate.SQL"
+msgid "<literal>org.hibernate.SQL</literal>"
+msgstr "<literal>org.hibernate.SQL</literal>"
 
 #. Tag: entry
-#: configuration.xml:1244
 #, no-c-format
 msgid "Log all SQL DML statements as they are executed"
 msgstr ""
-"Trace toutes les requêts SQL de type DML (gestion des données) qui sont "
-"exécutées"
+"Journalise toutes les requêtes SQL de type DML (gestion des données) qui "
+"sont exécutées"
 
-#. Tag: literal
-#: configuration.xml:1247
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.type"
-msgstr "org.hibernate.type"
+msgid "<literal>org.hibernate.type</literal>"
+msgstr "<literal>org.hibernate.type</literal>"
 
 #. Tag: entry
-#: configuration.xml:1248
 #, no-c-format
 msgid "Log all JDBC parameters"
-msgstr "Trace tous les paramètres JDBC"
+msgstr "Journalise tous les paramètres JDBC"
 
-#. Tag: literal
-#: configuration.xml:1251
-#, no-c-format
-msgid "org.hibernate.tool.hbm2ddl"
-msgstr "org.hibernate.tool.hbm2ddl"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.tool.hbm2ddl</literal>"
+msgstr "<literal>org.hibernate.tool. hbm2ddl</literal>"
 
 #. Tag: entry
-#: configuration.xml:1252
 #, no-c-format
 msgid "Log all SQL DDL statements as they are executed"
 msgstr ""
-"Trace toutes les requêts SQL de type DDL (gestion de la structure de la "
-"base) qui sont exécutées"
+"Journalise toutes les requêtes SQL de type DDL (gestion de la structure de "
+"la base) qui sont exécutées"
 
-#. Tag: literal
-#: configuration.xml:1255
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.pretty"
-msgstr "org.hibernate.pretty"
+msgid "<literal>org.hibernate.pretty</literal>"
+msgstr "<literal>org.hibernate.pretty</literal>"
 
 #. Tag: entry
-#: configuration.xml:1256
 #, no-c-format
 msgid ""
 "Log the state of all entities (max 20 entities) associated with the session "
 "at flush time"
 msgstr ""
-"Trace l'état de toutes les entités (20 entités maximum) qui sont associées "
-"avec la session hibernate au moment du flush"
+"Journalise l'état de toutes les entités (20 entités maximum) associées avec "
+"la session Hibernate au moment du flush"
 
-#. Tag: literal
-#: configuration.xml:1262
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.cache"
-msgstr "org.hibernate.cache"
+msgid "<literal>org.hibernate.cache</literal>"
+msgstr "<literal>org.hibernate.cache</literal>"
 
 #. Tag: entry
-#: configuration.xml:1263
 #, no-c-format
 msgid "Log all second-level cache activity"
-msgstr "Trace toute l'activité du cache de second niveau"
+msgstr "Journalise toute activité du cache de second niveau"
 
-#. Tag: literal
-#: configuration.xml:1266
-#, no-c-format
-msgid "org.hibernate.transaction"
-msgstr "org.hibernate.transaction"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.transaction</literal>"
+msgstr "<literal>org.hibernate. transaction</literal>"
 
 #. Tag: entry
-#: configuration.xml:1267
 #, no-c-format
 msgid "Log transaction related activity"
-msgstr "Trace toute l'activité relative aux transactions"
+msgstr "Journalise toute activité relative aux transactions"
 
-#. Tag: literal
-#: configuration.xml:1270
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.jdbc"
-msgstr "org.hibernate.jdbc"
+msgid "<literal>org.hibernate.jdbc</literal>"
+msgstr "<literal>org.hibernate.jdbc</literal>"
 
 #. Tag: entry
-#: configuration.xml:1271
 #, no-c-format
 msgid "Log all JDBC resource acquisition"
-msgstr "Trace toute acquisition de ressource JDBC"
+msgstr "Journalise toute acquisition de ressource JDBC "
 
-#. Tag: literal
-#: configuration.xml:1274
-#, no-c-format
-msgid "org.hibernate.hql.ast.AST"
-msgstr "org.hibernate.hql.ast.AST"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.hql.ast.AST</literal>"
+msgstr "<literal>org.hibernate.hql. ast.AST</literal>"
 
 #. Tag: entry
-#: configuration.xml:1275
 #, no-c-format
 msgid "Log HQL and SQL ASTs during query parsing"
 msgstr ""
-"Trace l'arbre syntaxique des requêtes HQL et SQL durant l'analyse syntaxique "
-"des requêtes"
+"Journalise l'arbre syntaxique des requêtes HQL et SQL durant l'analyse "
+"syntaxique des requêtes"
 
-#. Tag: literal
-#: configuration.xml:1280
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.secure"
-msgstr "org.hibernate.secure"
+msgid "<literal>org.hibernate.secure</literal>"
+msgstr "<literal>org.hibernate.secure</literal>"
 
 #. Tag: entry
-#: configuration.xml:1281
 #, no-c-format
 msgid "Log all JAAS authorization requests"
-msgstr "Trace toutes les demandes d'autorisation JAAS"
+msgstr "Journalise toutes les demandes d'autorisation JAAS"
 
-#. Tag: literal
-#: configuration.xml:1284
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate"
-msgstr "org.hibernate"
+msgid "<literal>org.hibernate</literal>"
+msgstr "<literal>org.hibernate</literal>"
 
 #. Tag: entry
-#: configuration.xml:1285
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Log everything. This is a lot of information but it is useful for "
 "troubleshooting"
 msgstr ""
-"Trace tout (beaucoupe d'informations, mais très utile pour résoudre les "
+"Journalise tout (beaucoup d'informations, mais très utile pour résoudre les "
 "problèmes)."
 
 #. Tag: para
-#: configuration.xml:1294
 #, no-c-format
 msgid ""
 "When developing applications with Hibernate, you should almost always work "
@@ -2932,13 +2018,12 @@
 "propriété <literal>hibernate.show_sql</literal> activée."
 
 #. Tag: title
-#: configuration.xml:1304
 #, no-c-format
 msgid "Implementing a <literal>NamingStrategy</literal>"
-msgstr "Implémenter une <literal>NamingStrategy</literal>"
+msgstr ""
+"Sélectionne une <literal>NamingStrategy</literal> (stratégie de nommage)"
 
 #. Tag: para
-#: configuration.xml:1306
 #, no-c-format
 msgid ""
 "The interface <literal>org.hibernate.cfg.NamingStrategy</literal> allows you "
@@ -2949,8 +2034,7 @@
 "de données."
 
 #. Tag: para
-#: configuration.xml:1311
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can provide rules for automatically generating database identifiers from "
 "Java identifiers or for processing \"logical\" column and table names given "
@@ -2961,36 +2045,23 @@
 msgstr ""
 "Vous pouvez fournir des règles pour automatiquement générer les identifiants "
 "de base de données à partir des identifiants Java, ou transformer une "
-"colonne ou table \"logique\" donnée dans le fichier de mapping en une "
+"colonne ou table \"logique\" donnée dans le fichier de mappage en une "
 "colonne ou table \"physique\". Cette fonctionnalité aide à réduire la "
-"verbosité de documents de mapping, en éliminant le bruit répétitif (les "
+"verbosité de documents de mappage, en éliminant le bruit répétitif (les "
 "préfixes <literal>TBL_</literal> par exemple). La stratégie par défaut "
-"utilisée par Hibernate est minimale."
+"utilisée par Hibernate est assez minimale."
 
 #. Tag: para
-#: configuration.xml:1320
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can specify a different strategy by calling <literal>Configuration."
 "setNamingStrategy()</literal> before adding mappings:"
 msgstr ""
 "Vous pouvez définir une stratégie différente en appelant "
 "<literal>Configuration.setNamingStrategy()</literal> avant d'ajouter des "
-"mappings :"
+"mappages : "
 
-#. Tag: programlisting
-#: configuration.xml:1325
-#, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration()\n"
-"    .setNamingStrategy(ImprovedNamingStrategy.INSTANCE)\n"
-"    .addFile(\"Item.hbm.xml\")\n"
-"    .addFile(\"Bid.hbm.xml\")\n"
-"    .buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1327
 #, no-c-format
 msgid ""
 "<literal>org.hibernate.cfg.ImprovedNamingStrategy</literal> is a built-in "
@@ -3001,13 +2072,11 @@
 "applications."
 
 #. Tag: title
-#: configuration.xml:1335
 #, no-c-format
 msgid "XML configuration file"
 msgstr "Fichier de configuration XML"
 
 #. Tag: para
-#: configuration.xml:1337
 #, no-c-format
 msgid ""
 "An alternative approach to configuration is to specify a full configuration "
@@ -3022,63 +2091,17 @@
 "présents."
 
 #. Tag: para
-#: configuration.xml:1344
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The XML configuration file is by default expected to be in the root of your "
 "<literal>CLASSPATH</literal>. Here is an example:"
 msgstr ""
 "Le fichier de configuration XML doit par défaut se placer à la racine du "
-"<literal>CLASSPATH</literal>. En voici un exemple :"
+"<literal>CLASSPATH</literal>. En voici un exemple : "
 
-#. Tag: programlisting
-#: configuration.xml:1349
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-"<!DOCTYPE hibernate-configuration PUBLIC\n"
-"    \"-//Hibernate/Hibernate Configuration DTD//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd\">\n"
-"\n"
-"<hibernate-configuration>\n"
-"\n"
-"    <!-- a SessionFactory instance listed as /jndi/name -->\n"
-"    <session-factory\n"
-"        name=\"java:hibernate/SessionFactory\">\n"
-"\n"
-"        <!-- properties -->\n"
-"        <property name=\"connection.datasource\">java:/comp/env/jdbc/MyDB</"
-"property>\n"
-"        <property name=\"dialect\">org.hibernate.dialect.MySQLDialect</"
-"property>\n"
-"        <property name=\"show_sql\">false</property>\n"
-"        <property name=\"transaction.factory_class\">\n"
-"            org.hibernate.transaction.JTATransactionFactory\n"
-"        </property>\n"
-"        <property name=\"jta.UserTransaction\">java:comp/UserTransaction</"
-"property>\n"
-"\n"
-"        <!-- mapping files -->\n"
-"        <mapping resource=\"org/hibernate/auction/Item.hbm.xml\"/>\n"
-"        <mapping resource=\"org/hibernate/auction/Bid.hbm.xml\"/>\n"
-"\n"
-"        <!-- cache settings -->\n"
-"        <class-cache class=\"org.hibernate.auction.Item\" usage=\"read-write"
-"\"/>\n"
-"        <class-cache class=\"org.hibernate.auction.Bid\" usage=\"read-only\"/"
-">\n"
-"        <collection-cache collection=\"org.hibernate.auction.Item.bids\" "
-"usage=\"read-write\"/>\n"
-"\n"
-"    </session-factory>\n"
-"\n"
-"</hibernate-configuration>]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:1351
-#, fuzzy, no-c-format
-msgid ""
 "The advantage of this approach is the externalization of the mapping file "
 "names to configuration. The <literal>hibernate.cfg.xml</literal> is also "
 "more convenient once you have to tune the Hibernate cache. It is your choice "
@@ -3086,62 +2109,42 @@
 "cfg.xml</literal>. Both are equivalent, except for the above mentioned "
 "benefits of using the XML syntax."
 msgstr ""
-"Commme vous pouvez le voir, l'avantage de cette approche est "
-"l'externalisation des noms des fichiers de mapping de la configuration. Le "
+"Comme vous pouvez le constater, l'avantage de cette approche est "
+"l'externalisation des noms des fichiers de mappage de la configuration. Le "
 "fichier <literal>hibernate.cfg.xml</literal> est également plus pratique "
 "quand on commence à régler le cache d'Hibernate. Notez que vous pouvez "
 "choisir entre utiliser <literal>hibernate.properties</literal> ou "
 "<literal>hibernate.cfg.xml</literal>, les deux sont équivalents, sauf en ce "
 "qui concerne les bénéfices de l'utilisation de la syntaxe XML mentionnés ci-"
-"dessus."
+"dessus. "
 
 #. Tag: para
-#: configuration.xml:1360
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "With the XML configuration, starting Hibernate is then as simple as:"
 msgstr ""
 "Avec la configuration XML, démarrer Hibernate devient donc aussi simple que "
-"ceci :"
+"ceci : "
 
-#. Tag: programlisting
-#: configuration.xml:1364
-#, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration().configure()."
-"buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1366
-#, fuzzy, no-c-format
-msgid "You can select a different XML configuration file using:"
-msgstr "You can pick a different XML configuration file using"
-
-#. Tag: programlisting
-#: configuration.xml:1370
 #, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration()\n"
-"    .configure(\"catdb.cfg.xml\")\n"
-"    .buildSessionFactory();]]>"
+msgid "You can select a different XML configuration file using:"
 msgstr ""
+"Vous pouvez choisir un fichier de configuration XML différent en utilisant : "
 
 #. Tag: title
-#: configuration.xml:1375
 #, no-c-format
 msgid "J2EE Application Server integration"
-msgstr "Intégration à un serveur d'application J2EE"
+msgstr "Intégration à un serveur d'applications J2EE"
 
 #. Tag: para
-#: configuration.xml:1377
 #, no-c-format
 msgid "Hibernate has the following integration points for J2EE infrastructure:"
 msgstr ""
-"Hibernate possède les points suivants d'intégration à l'infrastructure J2EE :"
+"Hibernate possède les points d'intégration suivants pour l'infrastructure "
+"J2EE :"
 
 #. Tag: para
-#: configuration.xml:1383
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Container-managed datasources</emphasis>: Hibernate can use JDBC "
 "connections managed by the container and provided through JNDI. Usually, a "
@@ -3153,18 +2156,17 @@
 "literal> API for this to keep your code portable."
 msgstr ""
 "<emphasis>Source de données gérée par le conteneur</emphasis> : Hibernate "
-"peut utiliser des connexions JDBC gérées par le conteneur et fournie par "
+"peut utiliser des connexions JDBC gérées par le conteneur et fournies par "
 "l'intermédiaire de JNDI. Souvent, un <literal>TransactionManager</literal> "
 "compatible JTA et un <literal>ResourceManager</literal> s'occupent de la "
-"gestion des transactions (CMT). Ils sont particulièrement prévus pour "
-"pouvoir gérer des transactions distribuées sur plusieurs sources de données. "
-"Vous pouvez bien sûr également définir vos limites de transaction dans votre "
-"programme (BMT) ou vous pouvez sinon aussi utiliser l'API optionnelle "
-"<literal>Transaction</literal> d'Hibernate qui vous garantira la portabilité "
-"de votre code entre plusieurs serveurs d'application."
+"gestion des transactions (CMT). Ils sont conçus en particulier pour gérer "
+"des transactions distribuées sur plusieurs sources de données. Vous pouvez "
+"biensûr également définir les limites des transactions dans votre programme "
+"(BMT) ou vous pouvez par ailleurs utiliser l'API optionnelle "
+"<literal>Transaction</literal> de Hibernate qui vous garantira la "
+"portabilité de votre code entre plusieurs serveurs d'application. "
 
 #. Tag: para
-#: configuration.xml:1398
 #, no-c-format
 msgid ""
 "<emphasis>Automatic JNDI binding</emphasis>: Hibernate can bind its "
@@ -3174,8 +2176,7 @@
 "sa <literal>SessionFactory</literal> à JNDI après le démarrage."
 
 #. Tag: para
-#: configuration.xml:1407
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>JTA Session binding:</emphasis> the Hibernate <literal>Session</"
 "literal> can be automatically bound to the scope of JTA transactions. Simply "
@@ -3185,18 +2186,17 @@
 "demarcation is either declarative (CMT) or programmatic (BMT/"
 "UserTransaction)."
 msgstr ""
-"<emphasis>Association de la Session à JTA:</emphasis> La <literal>Session</"
-"literal> Hibernate peut être associée automatiquement à une transaction JTA "
-"si vous utilisez les EJBs. Vous avez juste à récupérer la "
+"<emphasis>Association de la Session à JTA:</emphasis> la <literal>Session</"
+"literal> Hibernate peut être automatiquement associée à la portée des "
+"transactions JTA si vous utilisez les EJB. Vous avez juste à récupérer la "
 "<literal>SessionFactory</literal> depuis JNDI et à récupérer la "
 "<literal>Session</literal> courante. Hibernate s'occupe de vider et fermer "
-"la <literal>Session</literal> lorsque le transaction JTA se termine. La "
-"démarcation des transactions se fait de manière déclarative dans les "
-"descripteurs de déploiement."
+"la <literal>Session</literal> lorsque votre transaction JTA se termine. La "
+"démarcation des transactions se fait de manière déclarative (CMT) ou de "
+"façon programmatique (BMT/UserTransaction)."
 
 #. Tag: para
-#: configuration.xml:1420
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>JMX deployment:</emphasis> if you have a JMX capable application "
 "server (e.g. JBoss AS), you can choose to deploy Hibernate as a managed "
@@ -3206,37 +2206,34 @@
 "take care of service dependencies (datasource has to be available before "
 "Hibernate starts, etc)."
 msgstr ""
-"<emphasis>Déploiement JMX :</emphasis>Si vous avez un serveur d'application "
+"<emphasis>Déploiement JMX :</emphasis>Si vous avez un serveur d'applications "
 "compatible JMX (JBoss AS par exemple), vous pouvez choisir de déployer "
-"Hibernate en temps que MBean géré par le serveur. Cela vous évite de coder "
-"la ligne de démarrage qui permet de construire la <literal>SessionFactory</"
+"Hibernate en tant que MBean géré par le serveur. Cela vous évite de coder la "
+"ligne de démarrage qui permet de construire la <literal>SessionFactory</"
 "literal> depuis la <literal>Configuration</literal>. Le conteneur va "
 "démarrer votre <literal>HibernateService</literal>, et va idéalement "
 "s'occuper des dépendances entre les services (la source de données doit être "
-"disponible avant qu'Hibernate ne démarre, etc)."
+"disponible avant le démarrage de Hibernate, etc). "
 
 #. Tag: para
-#: configuration.xml:1431
 #, no-c-format
 msgid ""
 "Depending on your environment, you might have to set the configuration "
 "option <literal>hibernate.connection.aggressive_release</literal> to true if "
 "your application server shows \"connection containment\" exceptions."
 msgstr ""
-"En fonction de votre environnement, vous devrez peut être mettre l'option de "
-"configuration <literal>hibernate.connection.aggressive_release</literal> à "
-"vrai si le serveur d'application affiche des exceptions de type \"connection "
+"En fonction de votre environnement, vous mettrez l'option de configuration "
+"<literal>hibernate.connection.aggressive_release</literal> à true si le "
+"serveur d'applications affiche des exceptions de type \"connection "
 "containment\"."
 
 #. Tag: title
-#: configuration.xml:1438
 #, no-c-format
 msgid "Transaction strategy configuration"
 msgstr "Configuration de la stratégie transactionnelle"
 
 #. Tag: para
-#: configuration.xml:1440
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The Hibernate <literal>Session</literal> API is independent of any "
 "transaction demarcation system in your architecture. If you let Hibernate "
@@ -3246,16 +2243,15 @@
 "and <literal>UserTransaction</literal> when needed."
 msgstr ""
 "L'API de la <literal>Session</literal> Hibernate est indépendante de tout "
-"système de démarcation des transactions qui peut être présent dans votre "
-"architecture. Si vous laissez Hibernate utiliser l'API JDBC directement via "
-"un pool de connexion, vous devrez commencer et terminer vos transactions en "
-"utilisant l'API JDBC. Si votre application tourne à l'intérieur d'un serveur "
-"d'application J2EE, vous voudrez peut être utiliser les transactions gérées "
-"par les beans (BMT) et appeller l'API JTA et <literal>UserTransaction</"
-"literal> lorsque cela est nécessaire."
+"système de démarcation des transactions, présent dans votre architecture. Si "
+"vous laissez Hibernate utiliser l'API JDBC directement via un pool de "
+"connexion, vous commencerez et terminerez vos transactions en appelant l'API "
+"JDBC. Si votre application tourne à l'intérieur d'un serveur d'applications "
+"J2EE, vous utiliserez peut être les transactions gérées par les beans (BMT) "
+"et vous appellerez l'API JTA et <literal>UserTransaction</literal> lorsque "
+"cela est nécessaire. "
 
 #. Tag: para
-#: configuration.xml:1448
 #, no-c-format
 msgid ""
 "To keep your code portable between these two (and other) environments we "
@@ -3266,75 +2262,66 @@
 "literal>."
 msgstr ""
 "Pour conserver votre code portable entre ces deux environnements (et "
-"d'autres éventuels) nous vous recommandons d'utiliser l'API optionnelle "
-"<literal>Transaction</literal> d'Hibernate, qui va encapsuler et masquer le "
+"d'autres), nous vous recommandons d'utiliser l'API optionnelle "
+"<literal>Transaction</literal> d'Hibernate, qui encapsule et masque le "
 "système de transaction sous-jacent. Pour cela, vous devez préciser une "
 "classe de fabrique d'instances de <literal>Transaction</literal> en "
-"positionnant la propriété <literal>hibernate.transaction.factory_class</"
-"literal>."
+"positionnant la propriété de configuration <literal>hibernate.transaction."
+"factory_class</literal>."
 
 #. Tag: para
-#: configuration.xml:1455
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "There are three standard, or built-in, choices:"
-msgstr "Il existe trois choix standards (fournis) :"
+msgstr "Il existe trois choix standards (intégrés) : "
 
-#. Tag: literal
-#: configuration.xml:1461
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.JDBCTransactionFactory"
-msgstr "net.sf.hibernate.transaction.JDBCTransactionFactory"
+msgid "<literal>org.hibernate.transaction.JDBCTransactionFactory</literal>"
+msgstr "<literal>org.hibernate.transaction.JDBCTransactionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1463
 #, no-c-format
 msgid "delegates to database (JDBC) transactions (default)"
 msgstr ""
-"délègue aux transactions de la base de données (JDBC). Valeur par défaut."
+"délègue aux transactions de la base de données (JDBC) (valeur par défaut)."
 
-#. Tag: literal
-#: configuration.xml:1467
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.JTATransactionFactory"
-msgstr "org.hibernate.transaction.JTATransactionFactory"
+msgid "<literal>org.hibernate.transaction.JTATransactionFactory</literal>"
+msgstr "<literal>org.hibernate.transaction.JTATransactionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1469
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "delegates to container-managed transactions if an existing transaction is "
 "underway in this context (for example, EJB session bean method). Otherwise, "
 "a new transaction is started and bean-managed transactions are used."
 msgstr ""
-"délègue à CMT si une transaction existante est sous ce contexte (ex: méthode "
-"d'un EJB session), sinon une nouvelle transaction est entamée et une "
-"transaction gérée par le bean est utilisée."
+"délègue à CMT si une transaction existante est sous ce contexte (par ex : "
+"méthode d'un EJB session), sinon une nouvelle transaction est entamée et une "
+"transaction gérée par le bean est utilisée. "
 
-#. Tag: literal
-#: configuration.xml:1477
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.CMTTransactionFactory"
-msgstr "org.hibernate.transaction.CMTTransactionFactory"
+msgid "<literal>org.hibernate.transaction.CMTTransactionFactory</literal>"
+msgstr "<literal>org.hibernate.transaction.CMTTransactionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1479
 #, no-c-format
 msgid "delegates to container-managed JTA transactions"
-msgstr "délègue à aux transactions JTA gérées par le conteneur"
+msgstr "délègue aux transactions JTA gérées par le conteneur"
 
 #. Tag: para
-#: configuration.xml:1484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also define your own transaction strategies (for a CORBA transaction "
 "service, for example)."
 msgstr ""
-"Vous pouvez également définir votre propre stratégie transactionnelle (pour "
-"un service de transaction CORBA par exemple)."
+"Vous pouvez également définir vos propres stratégies transactionnelles (pour "
+"un service de transaction CORBA par exemple). "
 
 #. Tag: para
-#: configuration.xml:1489
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Some features in Hibernate (i.e., the second level cache, Contextual "
 "Sessions with JTA, etc.) require access to the JTA "
@@ -3343,160 +2330,160 @@
 "have to specify how Hibernate should obtain a reference to the "
 "<literal>TransactionManager</literal>:"
 msgstr ""
-"Certaines fonctionnalités d'Hibernate (i.e. le cache de second niveau, "
-"l'association automatique des Session à JTA, etc.) nécessitent l'accès au "
-"<literal>TransactionManager</literal> JTA dans un environnement \"managé\". "
-"Dans un serveur d'application, vous devez indiquer comment Hibernate peut "
-"obtenir une référence vers le <literal>TransactionManager</literal>, car "
-"J2EE ne fournit pas un seul mécanisme standard."
+"Certaines fonctionnalités de Hibernate (c'est-à-dire le cache de second "
+"niveau, l'association automatique des Sessions à JTA, etc.) nécessitent "
+"l'accès au <literal>TransactionManager</literal> JTA dans un environnement "
+"géré. Dans un serveur d'applications, vous devez indiquer comment Hibernate "
+"peut obtenir une référence vers le <literal>TransactionManager</literal>, "
+"car J2EE ne fournit pas un seul mécanisme standard. "
 
 #. Tag: title
-#: configuration.xml:1497
 #, no-c-format
 msgid "JTA TransactionManagers"
 msgstr "TransactionManagers JTA"
 
 #. Tag: entry
-#: configuration.xml:1503
 #, no-c-format
 msgid "Transaction Factory"
-msgstr "Fabrique de Transaction"
+msgstr "Fabrique de transaction"
 
 #. Tag: entry
-#: configuration.xml:1504
 #, no-c-format
 msgid "Application Server"
-msgstr "Serveur d'application"
+msgstr "Serveur d'applications"
 
-#. Tag: literal
-#: configuration.xml:1509
-#, no-c-format
-msgid "org.hibernate.transaction.JBossTransactionManagerLookup"
-msgstr "org.hibernate.transaction.JBossTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JBossTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JBossTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1510
 #, no-c-format
 msgid "JBoss"
 msgstr "JBoss"
 
-#. Tag: literal
-#: configuration.xml:1513
-#, no-c-format
-msgid "org.hibernate.transaction.WeblogicTransactionManagerLookup"
-msgstr "org.hibernate.transaction.WeblogicTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WeblogicTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. WeblogicTransactionManagerLookup</"
+"literal>"
 
 #. Tag: entry
-#: configuration.xml:1514
 #, no-c-format
 msgid "Weblogic"
 msgstr "Weblogic"
 
-#. Tag: literal
-#: configuration.xml:1517
-#, no-c-format
-msgid "org.hibernate.transaction.WebSphereTransactionManagerLookup"
-msgstr "org.hibernate.transaction.WebSphereTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WebSphereTransactionManagerLookup</"
+"literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. WebSphereTransactionManagerLookup</"
+"literal>"
 
 #. Tag: entry
-#: configuration.xml:1518
 #, no-c-format
 msgid "WebSphere"
 msgstr "WebSphere"
 
-#. Tag: literal
-#: configuration.xml:1521
-#, no-c-format
-msgid "org.hibernate.transaction.WebSphereExtendedJTATransactionLookup"
-msgstr "org.hibernate.transaction.WebSphereExtendedJTATransactionLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WebSphereExtendedJTATransactionLookup</"
+"literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. WebSphereExtendedJTATransactionLookup</"
+"literal>"
 
 #. Tag: entry
-#: configuration.xml:1522
 #, no-c-format
 msgid "WebSphere 6"
 msgstr "WebSphere 6"
 
-#. Tag: literal
-#: configuration.xml:1525
-#, no-c-format
-msgid "org.hibernate.transaction.OrionTransactionManagerLookup"
-msgstr "org.hibernate.transaction.OrionTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.OrionTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. OrionTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1526
 #, no-c-format
 msgid "Orion"
 msgstr "Orion"
 
-#. Tag: literal
-#: configuration.xml:1529
-#, no-c-format
-msgid "org.hibernate.transaction.ResinTransactionManagerLookup"
-msgstr "org.hibernate.transaction.ResinTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.ResinTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. ResinTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1530
 #, no-c-format
 msgid "Resin"
 msgstr "Resin"
 
-#. Tag: literal
-#: configuration.xml:1533
-#, no-c-format
-msgid "org.hibernate.transaction.JOTMTransactionManagerLookup"
-msgstr "org.hibernate.transaction.JOTMTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JOTMTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JOTMTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1534
 #, no-c-format
 msgid "JOTM"
 msgstr "JOTM"
 
-#. Tag: literal
-#: configuration.xml:1537
-#, no-c-format
-msgid "org.hibernate.transaction.JOnASTransactionManagerLookup"
-msgstr "org.hibernate.transaction.JOnASTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JOnASTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JOnASTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1538
 #, no-c-format
 msgid "JOnAS"
 msgstr "JOnAS"
 
-#. Tag: literal
-#: configuration.xml:1541
-#, no-c-format
-msgid "org.hibernate.transaction.JRun4TransactionManagerLookup"
-msgstr "org.hibernate.transaction.JRun4TransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JRun4TransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JRun4TransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1542
 #, no-c-format
 msgid "JRun4"
 msgstr "JRun4"
 
-#. Tag: literal
-#: configuration.xml:1545
-#, no-c-format
-msgid "org.hibernate.transaction.BESTransactionManagerLookup"
-msgstr "org.hibernate.transaction.BESTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.BESTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. BESTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1546
 #, no-c-format
 msgid "Borland ES"
 msgstr "Borland ES"
 
 #. Tag: title
-#: configuration.xml:1555
 #, no-c-format
 msgid "JNDI-bound <literal>SessionFactory</literal>"
 msgstr "<literal>SessionFactory</literal> associée au JNDI"
 
 #. Tag: para
-#: configuration.xml:1557
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A JNDI-bound Hibernate <literal>SessionFactory</literal> can simplify the "
 "lookup function of the factory and create new <literal>Session</literal>s. "
@@ -3505,13 +2492,12 @@
 msgstr ""
 "Une <literal>SessionFactory</literal> Hibernate associée au JNDI peut "
 "simplifier l'accès à la fabrique et donc la création de nouvelles "
-"<literal>Session</literal>s. Notez que cela n'est pas lié avec les "
+"<literal>Session</literal> s. Notez que cela n'est pas lié avec les "
 "<literal>Datasource</literal> associées au JNDI, elles utilisent juste le "
-"même registre."
+"même registre ! "
 
 #. Tag: para
-#: configuration.xml:1564
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you wish to have the <literal>SessionFactory</literal> bound to a JNDI "
 "namespace, specify a name (e.g. <literal>java:hibernate/SessionFactory</"
@@ -3521,15 +2507,14 @@
 "read-only JNDI default implementation (in Tomcat, for example)."
 msgstr ""
 "Si vous désirez associer la <literal>SessionFactory</literal> à un nom JNDI, "
-"spécifiez un nom (ex. <literal>java:hibernate/SessionFactory</literal>) en "
-"utilisant la propriété <literal>hibernate.session_factory_name</literal>. Si "
-"cette propriété est omise, la <literal>SessionFactory</literal> ne sera pas "
-"associée au JNDI (c'est particulièrement pratique dans les environnements "
-"ayant une implémentation de JNDI en lecture seule, comme c'est le cas pour "
-"Tomcat)."
+"spécifiez un nom (par ex. <literal>java:hibernate/SessionFactory</literal>) "
+"en utilisant la propriété <literal>hibernate.session_factory_name</literal>. "
+"Si cette propriété est omise, la <literal>SessionFactory</literal> ne sera "
+"pas associée au JNDI (c'est particulièrement pratique dans les "
+"environnements ayant une implémentation JNDI par défaut en lecture seule, "
+"comme c'est le cas pour Tomcat). "
 
 #. Tag: para
-#: configuration.xml:1572
 #, no-c-format
 msgid ""
 "When binding the <literal>SessionFactory</literal> to JNDI, Hibernate will "
@@ -3541,11 +2526,10 @@
 "utilisera les valeurs de <literal>hibernate.jndi.url</literal>, "
 "<literal>hibernate.jndi.class</literal> pour instancier un contexte "
 "d'initialisation. S'ils ne sont pas spécifiés, l'<literal>InitialContext</"
-"literal> par défaut sera utilisé."
+"literal> par défaut sera utilisé. "
 
 #. Tag: para
-#: configuration.xml:1579
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will automatically place the <literal>SessionFactory</literal> in "
 "JNDI after you call <literal>cfg.buildSessionFactory()</literal>. This means "
@@ -3559,11 +2543,10 @@
 "Cela signifie que vous devez avoir cet appel dans un code de démarrage (ou "
 "dans une classe utilitaire) dans votre application sauf si vous utilisez le "
 "déploiement JMX avec le service <literal>HibernateService</literal> présenté "
-"plus tard dans ce document."
+"plus tard dans ce document. "
 
 #. Tag: para
-#: configuration.xml:1586
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you use a JNDI <literal>SessionFactory</literal>, an EJB or any other "
 "class, you can obtain the <literal>SessionFactory</literal> using a JNDI "
@@ -3571,11 +2554,10 @@
 msgstr ""
 "Si vous utilisez <literal>SessionFactory</literal> JNDI, un EJB ou n'importe "
 "quelle autre classe peut obtenir la <literal>SessionFactory</literal> en "
-"utilisant un lookup JNDI."
+"utilisant une recherche JNDI. "
 
 #. Tag: para
-#: configuration.xml:1591
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you bind the <literal>SessionFactory</literal> to "
 "JNDI in a managed environment and use a <literal>static</literal> singleton "
@@ -3585,33 +2567,30 @@
 "()</literal>. Note that such a class is also a convenient way to startup "
 "Hibernate&mdash;see chapter 1."
 msgstr ""
-"Nous recommandons que vous liiez la <literal>SessionFactory</literal> à JNDI "
-"dans les environnements managés et que vous utilisiez un singleton "
-"<literal>static</literal> si ce n'est pas le cas. Pour isoler votre "
-"application de ces détails, nous vous recommandons aussi de masquer le code "
-"de lookup actuel pour une <literal>SessionFactory</literal> dans une classe "
-"helper, comme <literal>HibernateUtil.getSessionFactory()</literal>. Notez "
-"qu'une telle classe est aussi un moyen efficace de démarrer Hibernate&mdash;"
-"voir chapitre 1."
+"Nous recommandons de lier la <literal>SessionFactory</literal> à JNDI dans "
+"les environnements gérés et d'utilisier un singleton <literal>static</"
+"literal> si ce n'est pas le cas. Pour isoler votre application de ces "
+"détails, nous vous recommandons aussi de masquer le code de recherche actuel "
+"pour une <literal>SessionFactory</literal> dans une classe helper, comme "
+"<literal>HibernateUtil.getSessionFactory()</literal>. Notez qu'une telle "
+"classe est aussi un moyen efficace de démarrer Hibernate - voir chapitre 1. "
 
 #. Tag: title
-#: configuration.xml:1603
 #, no-c-format
 msgid "Current Session context management with JTA"
-msgstr "Association automatique de la Session à JTA"
+msgstr "Gestion du contexte de la session courante à JTA"
 
 #. Tag: para
-#: configuration.xml:1605
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The easiest way to handle <literal>Sessions</literal> and transactions is "
 "Hibernate's automatic \"current\" <literal>Session</literal> management. For "
-"a discussion of contextual sessions see <link linkend=\"architecture-current-"
-"session\"></link>. Using the <literal>\"jta\"</literal> session context, if "
-"there is no Hibernate <literal>Session</literal> associated with the current "
-"JTA transaction, one will be started and associated with that JTA "
-"transaction the first time you call <literal>sessionFactory.getCurrentSession"
-"()</literal>. The <literal>Session</literal>s retrieved via "
+"a discussion of contextual sessions see <xref linkend=\"architecture-current-"
+"session\" />. Using the <literal>\"jta\"</literal> session context, if there "
+"is no Hibernate <literal>Session</literal> associated with the current JTA "
+"transaction, one will be started and associated with that JTA transaction "
+"the first time you call <literal>sessionFactory.getCurrentSession()</"
+"literal>. The <literal>Session</literal>s retrieved via "
 "<literal>getCurrentSession()</literal> in the<literal>\"jta\"</literal> "
 "context are set to automatically flush before the transaction completes, "
 "close after the transaction completes, and aggressively release JDBC "
@@ -3626,34 +2605,32 @@
 msgstr ""
 "Le moyen le plus simple de gérer les <literal>Session</literal>s et "
 "transactions est la gestion automatique de session \"courante\" offerte par "
-"Hibernate. Voir détail à <xref linkend=\"architecture-current-session"
-"\">current sessions</xref>. En utilisant le contexte de session <literal>"
-"\"jta\"</literal> session context, s'il n'y a pas de <literal>Session</"
-"literal> associée à la transaction JTA courante, une session sera démarrée "
-"et associée à la transaction JTA courante la première fois que vous appelez "
-"<literal>sessionFactory.getCurrentSession()</literal>. Les <literal>Session</"
-"literal>s obtenue via <literal>getCurrentSession()</literal> dans une "
-"contexte <literal>\"jta\"</literal> seront automatiquement flushées avant la "
-"validation de la transaction, fermées une fois la transaction complétée, et "
-"libéreront les connexions JDBC de manière aggressive après chaque statement. "
-"Ceci permet aux <literal>Session</literal>s d'être gérées par le cycle de "
-"vie de la transaction JTA à la quelle est sont associées, laissant le code "
-"de l'utilisateur propre de ce type de gestion. Votre code peut soit utiliser "
-"JTA de manière programmatique via <literal>UserTransaction</literal>, ou (ce "
-"qui est recommandé pour la portabilité du code) utiliser l'API "
-"<literal>Transaction</literal> API pour marquer les limites. Si vous "
-"exécutez sous un conteneur EJB, la démarcation déclarative des transactions "
-"avec CMT est recommandée."
+"Hibernate. Pour plus d'informations, consultez les sessions courantes <xref "
+"linkend=\"architecture-current-session\" />. En utilisant le contexte de "
+"session <literal>\"jta\"</literal> session context, s'il n'y a pas de "
+"<literal>Session</literal> associée à la transaction JTA courante, une "
+"session sera démarrée et associée à la transaction JTA courante la première "
+"fois que vous appelez <literal>sessionFactory.getCurrentSession()</literal>. "
+"Les <literal>Session</literal> s obtenues via <literal>getCurrentSession()</"
+"literal> dans un contexte <literal>\"jta\"</literal> seront automatiquement "
+"flushées avant la validation de la transaction, fermées une fois la "
+"transaction complétée, et libèreront les connexions JDBC de manière "
+"agressive après chaque statement. Ceci permet aux <literal>Session</literal> "
+"s d'être gérées par le cycle de vie de la transaction JTA à laquelle il est "
+"associé, ainsi le code de l'utilisateur n'a pas à se préoccupper de ce type "
+"de gestion. Votre code peut soit utiliser JTA de manière programmatique via "
+"<literal>UserTransaction</literal>, ou (ce qui est recommandé pour la "
+"portabilité du code) utiliser l'API <literal>Transaction</literal> pour "
+"marquer les limites. Si vous exécutez sous un conteneur EJB, la démarcation "
+"déclarative des transactions avec CMT est recommandée. "
 
 #. Tag: title
-#: configuration.xml:1628
 #, no-c-format
 msgid "JMX deployment"
 msgstr "Déploiement JMX"
 
 #. Tag: para
-#: configuration.xml:1630
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The line <literal>cfg.buildSessionFactory()</literal> still has to be "
 "executed somewhere to get a <literal>SessionFactory</literal> into JNDI. You "
@@ -3662,15 +2639,14 @@
 "a <emphasis>managed service</emphasis>."
 msgstr ""
 "La ligne <literal>cfg.buildSessionFactory()</literal> doit toujours être "
-"exécutée quelque part pour avoir une <literal>SessionFactory</literal> dans "
-"JNDI. Vous pouvez faire cela dans un bloc d'initialisation <literal>static</"
-"literal> (comme celui qui se trouve dans la classe <literal>HibernateUtil</"
-"literal>) ou vous pouvez déployer Hibernate en temps que <emphasis>service "
-"managé</emphasis>."
+"exécutée quelque part pour obtenir une <literal>SessionFactory</literal> "
+"dans JNDI. Vous pouvez faire cela dans un bloc d'initialisation "
+"<literal>static</literal> (comme celui qui se trouve dans la classe "
+"<literal>HibernateUtil</literal>) ou vous pouvez déployer Hibernate en temps "
+"que <emphasis>service géré</emphasis>. "
 
 #. Tag: para
-#: configuration.xml:1638
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate is distributed with <literal>org.hibernate.jmx.HibernateService</"
 "literal> for deployment on an application server with JMX capabilities, such "
@@ -3678,66 +2654,14 @@
 "Here is an example <literal>jboss-service.xml</literal> for JBoss 4.0.x:"
 msgstr ""
 "Hibernate est distribué avec <literal>org.hibernate.jmx.HibernateService</"
-"literal> pour le déploiement sur un serveur d'application avec le support de "
-"JMX comme JBoss AS. Le déploiement et la configuration sont spécifiques à "
+"literal> pour le déploiement sur un serveur d'applications avec le support "
+"de JMX comme JBoss AS. Le déploiement et la configuration sont spécifiques à "
 "chaque vendeur. Voici un fichier <literal>jboss-service.xml</literal> "
-"d'exemple pour JBoss 4.0.x:"
+"d'exemple pour JBoss 4.0.x :"
 
-#. Tag: programlisting
-#: configuration.xml:1645
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<server>\n"
-"\n"
-"<mbean code=\"org.hibernate.jmx.HibernateService\"\n"
-"    name=\"jboss.jca:service=HibernateFactory,name=HibernateFactory\">\n"
-"\n"
-"    <!-- Required services -->\n"
-"    <depends>jboss.jca:service=RARDeployer</depends>\n"
-"    <depends>jboss.jca:service=LocalTxCM,name=HsqlDS</depends>\n"
-"\n"
-"    <!-- Bind the Hibernate service to JNDI -->\n"
-"    <attribute name=\"JndiName\">java:/hibernate/SessionFactory</attribute>\n"
-"\n"
-"    <!-- Datasource settings -->\n"
-"    <attribute name=\"Datasource\">java:HsqlDS</attribute>\n"
-"    <attribute name=\"Dialect\">org.hibernate.dialect.HSQLDialect</"
-"attribute>\n"
-"\n"
-"    <!-- Transaction integration -->\n"
-"    <attribute name=\"TransactionStrategy\">\n"
-"        org.hibernate.transaction.JTATransactionFactory</attribute>\n"
-"    <attribute name=\"TransactionManagerLookupStrategy\">\n"
-"        org.hibernate.transaction.JBossTransactionManagerLookup</attribute>\n"
-"    <attribute name=\"FlushBeforeCompletionEnabled\">true</attribute>\n"
-"    <attribute name=\"AutoCloseSessionEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Fetching options -->\n"
-"    <attribute name=\"MaximumFetchDepth\">5</attribute>\n"
-"\n"
-"    <!-- Second-level caching -->\n"
-"    <attribute name=\"SecondLevelCacheEnabled\">true</attribute>\n"
-"    <attribute name=\"CacheProviderClass\">org.hibernate.cache."
-"EhCacheProvider</attribute>\n"
-"    <attribute name=\"QueryCacheEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Logging -->\n"
-"    <attribute name=\"ShowSqlEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Mapping files -->\n"
-"    <attribute name=\"MapResources\">auction/Item.hbm.xml,auction/Category."
-"hbm.xml</attribute>\n"
-"\n"
-"</mbean>\n"
-"\n"
-"</server>]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:1647
-#, fuzzy, no-c-format
-msgid ""
 "This file is deployed in a directory called <literal>META-INF</literal> and "
 "packaged in a JAR file with the extension <literal>.sar</literal> (service "
 "archive). You also need to package Hibernate, its required third-party "
@@ -3749,247 +2673,11 @@
 "deployment."
 msgstr ""
 "Ce fichier est déployé dans un répertoire <literal>META-INF</literal> et est "
-"packagé dans un fichier JAR avec l'extension <literal>.sar</literal> "
-"(service archive). Vous devez également packager Hibernate, les librairies "
+"empaqueté dans un fichier JAR avec l'extension <literal>.sar</literal> "
+"(service archive). Vous devez également empaqueter Hibernate, les librairies "
 "tierces requises, vos classes persistantes compilées et vos fichiers de "
-"mapping dans la même archive. Vos beans entreprise (souvent des EJBs "
-"session) peuvent rester dans leur propre fichier JAR mais vous pouvez "
-"inclure ce fichier JAR dans le jar principal du service pour avoir une seule "
-"unité déployable à chaud. Vous pouvez consulter la documentation de JBoss AS "
-"pour plus d'information sur les services JMX et le déploiement des EJBs."
-
-#~ msgid "Hibernate logs various events using Apache commons-logging."
-#~ msgstr ""
-#~ "Hibernate trace divers évènements en utilisant Apache commons-logging."
-
-#~ msgid ""
-#~ "The commons-logging service will direct output to either Apache Log4j (if "
-#~ "you include <literal>log4j.jar</literal> in your classpath) or JDK1.4 "
-#~ "logging (if running under JDK1.4 or above). You may download Log4j from "
-#~ "<literal>http://jakarta.apache.org</literal>. To use Log4j you will need "
-#~ "to place a <literal>log4j.properties</literal> file in your classpath, an "
-#~ "example properties file is distributed with Hibernate in the <literal>src/"
-#~ "</literal> directory."
-#~ msgstr ""
-#~ "Le service commons-logging délèguera directement à Apache Log4j (si vous "
-#~ "incluez <literal>log4j.jar</literal> dans votre classpath) ou le système "
-#~ "de trace du JDK 1.4 (si vous tournez sous le JDK 1.4 et supérieur). Vous "
-#~ "pouvez télécharger Log4j à partir de <literal>http://jakarta.apache.org</"
-#~ "literal>. Pour utiliser Log4j, vous devrez placer dans votre classpath un "
-#~ "fichier <literal>log4j.properties</literal>. Un exemple de fichier est "
-#~ "distribué avec Hibernate dans le répertoire <literal>src/</literal>."
-
-#~ msgid "<placeholder-1/> (optional)"
-#~ msgstr "<placeholder-1/> (optionnelle)"
-
-#~ msgid "InitialContextFactory"
-#~ msgstr "InitialContextFactory"
-
-#~ msgid "class of the JNDI <placeholder-1/>"
-#~ msgstr "Classe de l'<placeholder-1/> du JNDI"
-
-#, fuzzy
-#~ msgid "eg."
-#~ msgstr ""
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "eg.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "eg.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "ex."
-
-#~ msgid "full.classname.of.Dialect"
-#~ msgstr "nom.complet.de.ma.classe.de.Dialect"
-
-#~ msgid "debug"
-#~ msgstr "debug"
-
-#~ msgid "SCHEMA_NAME"
-#~ msgstr "MON_SCHEMA"
-
-#~ msgid "CATALOG_NAME"
-#~ msgstr "CATALOG_NAME"
-
-#~ msgid "SessionFactory"
-#~ msgstr "SessionFactory"
-
-#, fuzzy
-#~ msgid "jndi/composite/name"
-#~ msgstr ""
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "jndi/nom/hierarchique\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "jndi/nom/compose"
-
-#~ msgid "0"
-#~ msgstr "0"
-
-#~ msgid "false"
-#~ msgstr "false"
-
-#~ msgid "Statement.setFetchSize()"
-#~ msgstr "Statement.setFetchSize()"
-
-#~ msgid "true"
-#~ msgstr "true"
-
-#~ msgid "executeBatch()"
-#~ msgstr "executeBatch()"
-
-#~ msgid "Batcher"
-#~ msgstr "Batcher"
-
-#~ msgid "classname.of.BatcherFactory"
-#~ msgstr "classname.of.BatcherFactory"
-
-#~ msgid "binary"
-#~ msgstr "binary"
-
-#~ msgid "serializable"
-#~ msgstr "serializable"
-
-#~ msgid "PreparedStatement.getGeneratedKeys()"
-#~ msgstr "PreparedStatement.getGeneratedKeys()"
-
-#~ msgid "true|false"
-#~ msgstr "true|false"
-
-#~ msgid "ConnectionProvider"
-#~ msgstr "ConnectionProvider"
-
-#~ msgid "classname.of.ConnectionProvider"
-#~ msgstr "classname.of.ConnectionProvider"
-
-#~ msgid "java.sql.Connection"
-#~ msgstr "java.sql.Connection"
-
-#~ msgid "1, 2, 4, 8"
-#~ msgstr "1, 2, 4, 8"
-
-#~ msgid "after_statement"
-#~ msgstr "after_statement"
-
-#~ msgid "after_transaction"
-#~ msgstr "after_transaction"
-
-#~ msgid "auto"
-#~ msgstr "auto"
-
-#~ msgid "hibernate.connection."
-#~ msgstr "hibernate.connection."
-
-#, fuzzy
-#~ msgid "&lt;propertyName&gt;"
-#~ msgstr ""
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "&lt;propertyName&gt;\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "&lt;propertyName&gt;\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "&lt;propertyName&gt;\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "propertyName"
-
-#~ msgid "DriverManager.getConnection()"
-#~ msgstr "DriverManager.getConnection()"
-
-#~ msgid "Pass the JDBC property <placeholder-1/> to <placeholder-2/>."
-#~ msgstr "Passe la propriété JDBC <placeholder-1/> à <placeholder-2/>."
-
-#~ msgid "hibernate.jndi."
-#~ msgstr "hibernate.jndi."
-
-#~ msgid "Pass the property <placeholder-1/> to the JNDI <placeholder-2/>."
-#~ msgstr "Passe la propriété <placeholder-1/> à l'<placeholder-2/> de JNDI."
-
-#~ msgid "CacheProvider"
-#~ msgstr "CacheProvider"
-
-#~ msgid "classname.of.CacheProvider"
-#~ msgstr "nom.de.classe.du.CacheProvider"
-
-#~ msgid "&lt;cache&gt;"
-#~ msgstr "&lt;cache&gt;"
-
-#~ msgid "QueryCache"
-#~ msgstr "QueryCacheFactory"
-
-#~ msgid "StandardQueryCache"
-#~ msgstr "StandardQueryCacheFactory"
-
-#~ msgid "classname.of.QueryCache"
-#~ msgstr "nom.de.la.classe.de.QueryCacheFactory"
-
-#~ msgid "prefix"
-#~ msgstr "prefix"
-
-#~ msgid "TransactionFactory"
-#~ msgstr "TransactionFactory"
-
-#~ msgid "Transaction"
-#~ msgstr "Transaction"
-
-#~ msgid "JDBCTransactionFactory"
-#~ msgstr "JDBCTransactionFactory"
-
-#~ msgid "classname.of.TransactionFactory"
-#~ msgstr "nom.de.classe.d.une.TransactionFactory"
-
-#~ msgid "JTATransactionFactory"
-#~ msgstr "JTATransactionFactory"
-
-#~ msgid "UserTransaction"
-#~ msgstr "UserTransaction"
-
-#~ msgid "TransactionManagerLookup"
-#~ msgstr "TransactionManagerLookup"
-
-#~ msgid "classname.of.TransactionManagerLookup"
-#~ msgstr "nom.de.classe.du.TransactionManagerLookup"
-
-#~ msgid "Session"
-#~ msgstr "Session"
-
-#~ msgid "hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC"
-#~ msgstr "hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC"
-
-#~ msgid "create-drop"
-#~ msgstr "create-drop"
-
-#~ msgid "hibernate.cfg.xml"
-#~ msgstr "hibernate.cfg.xml"
-
-#~ msgid "DB2"
-#~ msgstr "DB2"
+"mappage dans la même archive. Vos beans entreprise (souvent des EJB session) "
+"peuvent rester dans leur propre fichier JAR mais vous pouvez inclure ce "
+"fichier JAR dans le jar principal du service pour avoir une seule unité "
+"déployable à chaud. Vous pouvez consulter la documentation de JBoss AS pour "
+"plus d'informations sur les services JMX et le déploiement des EJB. "

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/events.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/events.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/events.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,28 @@
+# translation of events.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: events\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2009-11-11 09:16+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: events.xml:29
 #, no-c-format
 msgid "Interceptors and events"
-msgstr "Les intercepteurs et les événements"
+msgstr "Intercepteurs et événements"
 
 #. Tag: para
-#: events.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is useful for the application to react to certain events that occur "
 "inside Hibernate. This allows for the implementation of generic "
@@ -26,18 +30,15 @@
 msgstr ""
 "Il est souvent utile pour l'application de réagir à certains événements qui "
 "surviennent dans Hibernate. Cela autorise l'implémentation de certaines "
-"sortes de fonctionnalités génériques, et d'extensions de fonctionnalités "
-"d'Hibernate."
+"fonctionnalités génériques, et l'extension de fonctionnalités d'Hibernate."
 
 #. Tag: title
-#: events.xml:38
 #, no-c-format
 msgid "Interceptors"
 msgstr "Intercepteurs"
 
 #. Tag: para
-#: events.xml:40
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>Interceptor</literal> interface provides callbacks from the "
 "session to the application, allowing the application to inspect and/or "
@@ -50,145 +51,46 @@
 "literal> is updated."
 msgstr ""
 "L'interface <literal>Interceptor</literal> fournit des \"callbacks\" de la "
-"session vers l'application et permettent à l'application de consulter et/ou "
-"de manipuler des propriétés d'un objet persistant avant qu'il soit "
-"sauvegardé, mis à jour, supprimé ou chargé. Une utilisation possible de "
-"cette fonctionnalité est de tracer l'accès à l'information. Par exemple, "
+"session vers l'application permettant à l'application de consulter et/ou de "
+"manipuler des propriétés d'un objet persistant avant qu'il soit sauvegardé, "
+"mis à jour, supprimé ou chargé. Une utilisation possible de cette "
+"fonctionnalité est de tracer l'accès à l'information. Par exemple, "
 "l'<literal>Interceptor</literal> suivant positionne "
 "<literal>createTimestamp</literal> quand un <literal>Auditable</literal> est "
 "créé et met à jour la propriété <literal>lastUpdateTimestamp</literal> quand "
-"un <literal>Auditable</literal> est mis à jour."
+"un <literal>Auditable</literal> est mis à jour. "
 
 #. Tag: para
-#: events.xml:51
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can either implement <literal>Interceptor</literal> directly or extend "
 "<literal>EmptyInterceptor</literal>."
 msgstr ""
 "Vous pouvez soit implémenter <literal>Interceptor</literal> directement ou "
-"(mieux) étendre <literal>EmptyInterceptor</literal>."
+"(mieux) étendre <literal>EmptyInterceptor</literal>. "
 
-#. Tag: programlisting
-#: events.xml:56
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[package org.hibernate.test;\n"
-"\n"
-"import java.io.Serializable;\n"
-"import java.util.Date;\n"
-"import java.util.Iterator;\n"
-"\n"
-"import org.hibernate.EmptyInterceptor;\n"
-"import org.hibernate.Transaction;\n"
-"import org.hibernate.type.Type;\n"
-"\n"
-"public class AuditInterceptor extends EmptyInterceptor {\n"
-"\n"
-"    private int updates;\n"
-"    private int creates;\n"
-"    private int loads;\n"
-"\n"
-"    public void onDelete(Object entity,\n"
-"                         Serializable id,\n"
-"                         Object[] state,\n"
-"                         String[] propertyNames,\n"
-"                         Type[] types) {\n"
-"        // do nothing\n"
-"    }\n"
-"\n"
-"    public boolean onFlushDirty(Object entity,\n"
-"                                Serializable id,\n"
-"                                Object[] currentState,\n"
-"                                Object[] previousState,\n"
-"                                String[] propertyNames,\n"
-"                                Type[] types) {\n"
-"\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            updates++;\n"
-"            for ( int i=0; i < propertyNames.length; i++ ) {\n"
-"                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) {\n"
-"                    currentState[i] = new Date();\n"
-"                    return true;\n"
-"                }\n"
-"            }\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public boolean onLoad(Object entity,\n"
-"                          Serializable id,\n"
-"                          Object[] state,\n"
-"                          String[] propertyNames,\n"
-"                          Type[] types) {\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            loads++;\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public boolean onSave(Object entity,\n"
-"                          Serializable id,\n"
-"                          Object[] state,\n"
-"                          String[] propertyNames,\n"
-"                          Type[] types) {\n"
-"\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            creates++;\n"
-"            for ( int i=0; i<propertyNames.length; i++ ) {\n"
-"                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
-"                    state[i] = new Date();\n"
-"                    return true;\n"
-"                }\n"
-"            }\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public void afterTransactionCompletion(Transaction tx) {\n"
-"        if ( tx.wasCommitted() ) {\n"
-"            System.out.println(\"Creations: \" + creates + \", Updates: \" + "
-"updates, \"Loads: \" + loads);\n"
-"        }\n"
-"        updates=0;\n"
-"        creates=0;\n"
-"        loads=0;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:58
-#, fuzzy, no-c-format
-msgid ""
 "There are two kinds of inteceptors: <literal>Session</literal>-scoped and "
 "<literal>SessionFactory</literal>-scoped."
 msgstr ""
-"Interceptors come in two flavors: <literal>Session</literal>-scoped and "
-"<literal>SessionFactory</literal>-scoped."
+"Il y a deux types d'intercepteurs : lié à la <literal>Session</literal> et "
+"lié à la <literal>SessionFactory</literal>. "
 
 #. Tag: para
-#: events.xml:63
 #, no-c-format
 msgid ""
 "A <literal>Session</literal>-scoped interceptor is specified when a session "
 "is opened using one of the overloaded SessionFactory.openSession() methods "
 "accepting an <literal>Interceptor</literal>."
 msgstr ""
-"A <literal>Session</literal>-scoped interceptor is specified when a session "
-"is opened using one of the overloaded SessionFactory.openSession() methods "
-"accepting an <literal>Interceptor</literal>."
+"Un intercepteur lié à la <literal>Session</literal> est défini lorsqu'une "
+"session est ouverte via l'invocation des méthodes surchargées SessionFactory."
+"openSession() acceptant un <literal>Interceptor</literal> (comme argument)."
 
-#. Tag: programlisting
-#: events.xml:69
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:71
-#, fuzzy, no-c-format
 msgid ""
 "A <literal>SessionFactory</literal>-scoped interceptor is registered with "
 "the <literal>Configuration</literal> object prior to building the "
@@ -199,31 +101,24 @@
 "Ensure that you do not store session-specific states, since multiple "
 "sessions will use this interceptor potentially concurrently."
 msgstr ""
-"A <literal>SessionFactory</literal>-scoped interceptor is registered with "
-"the <literal>Configuration</literal> object prior to building the "
-"<literal>SessionFactory</literal>. In this case, the supplied interceptor "
-"will be applied to all sessions opened from that <literal>SessionFactory</"
-"literal>; this is true unless a session is opened explicitly specifying the "
-"interceptor to use. <literal>SessionFactory</literal>-scoped interceptors "
-"must be thread safe, taking care to not store session-specific state since "
-"multiple sessions will use this interceptor (potentially) concurrently."
+"Un intercepteur lié à <literal>SessionFactory</literal> est enregistré avec "
+"l'objet <literal>Configuration</literal> avant la construction de la "
+"<literal>SessionFactory</literal>. Dans ce cas, les intercepteurs fournis "
+"seront appliqués à toutes les sessions ouvertes pour cette "
+"<literal>SessionFactory</literal>; ceci est vrai à moins que la session ne "
+"soit ouverte en spécifiant l'intercepteur à utiliser. Les intercepteurs liés "
+"à la <literal>SessionFactory</literal> doivent être thread safe, en faisant "
+"attention à ne pas stocker des états spécifiques de la session puisque "
+"plusieurs sessions peuvent utiliser cet intercepteur (potentiellement) de "
+"manière concurrente. "
 
-#. Tag: programlisting
-#: events.xml:80
-#, no-c-format
-msgid ""
-"<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
-msgstr ""
-
 #. Tag: title
-#: events.xml:85
 #, no-c-format
 msgid "Event system"
 msgstr "Système d'événements"
 
 #. Tag: para
-#: events.xml:87
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you have to react to particular events in your persistence layer, you can "
 "also use the Hibernate3 <emphasis>event</emphasis> architecture. The event "
@@ -231,12 +126,11 @@
 msgstr ""
 "Si vous devez réagir à des événements particuliers dans votre couche de "
 "persistance, vous pouvez aussi utiliser l'architecture "
-"d'<emphasis>événements</emphasis> d'Hibernate3. Le système d'événements peut "
-"être utilisé en supplément ou en remplacement des interceptors."
+"d'<emphasis>événements</emphasis> de Hibernate3. Le système d'événements "
+"peut être utilisé en supplément ou en remplacement des interceptors. "
 
 #. Tag: para
-#: events.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All the methods of the <literal>Session</literal> interface correlate to an "
 "event. You have a <literal>LoadEvent</literal>, a <literal>FlushEvent</"
@@ -256,7 +150,7 @@
 "Essentiellement toutes les méthodes de l'interface <literal>Session</"
 "literal> sont corrélées à un événement. Vous avez un <literal>LoadEvent</"
 "literal>, un <literal>FlushEvent</literal>, etc (consultez la DTD du fichier "
-"de configuration XML ou le paquet <literal>org.hibernate.event</literal> "
+"de configuration XML ou le paquetage <literal>org.hibernate.event</literal> "
 "pour avoir la liste complète des types d'événement définis). Quand une "
 "requête est faite à partir d'une de ces méthodes, la <literal>Session</"
 "literal> Hibernate génère un événement approprié et le passe au listener "
@@ -267,22 +161,20 @@
 "l'implémentation de l'interface <literal>LoadEventListener</literal> "
 "déclarée), dans quel cas leur implémentation devrait être responsable du "
 "traitement des requêtes <literal>load()</literal> faites par la "
-"<literal>Session</literal>."
+"<literal>Session</literal>. "
 
 #. Tag: para
-#: events.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The listeners should be considered singletons. This means they are shared "
 "between requests, and should not save any state as instance variables."
 msgstr ""
 "Les listeners devraient effectivement être considérés comme des singletons ; "
 "dans le sens où ils sont partagés entre des requêtes, et donc ne devraient "
-"pas sauvegarder des états de variables d'instance."
+"pas sauvegarder des états en tant que variables d'instance. "
 
 #. Tag: para
-#: events.xml:113
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A custom listener implements the appropriate interface for the event it "
 "wants to process and/or extend one of the convenience base classes (or even "
@@ -298,73 +190,28 @@
 "même l'événement prêt à l'emploi utilisé par Hibernate comme ceux déclarés "
 "non-finaux à cette intention). Les listeners personnalisés peuvent être soit "
 "inscrits par programmation à travers l'objet <literal>Configuration</"
-"literal>, ou spécifiés la configuration XML d'Hibernate (la configuration "
-"déclarative à travers le fichier de propriétés n'est pas supportée). Voici "
-"un exemple de listener personnalisé pour l'événement de chargement :"
+"literal>, ou spécifiés dans la configuration XML de Hibernate (la "
+"configuration déclarative à travers le fichier de propriétés n'est pas "
+"supportée). Voici un exemple de listener personnalisé pour l'événement de "
+"chargement :"
 
-#. Tag: programlisting
-#: events.xml:123
-#, no-c-format
-msgid ""
-"<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
-"    // this is the single method defined by the LoadEventListener interface\n"
-"    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
-"loadType)\n"
-"            throws HibernateException {\n"
-"        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
-"getEntityId() ) ) {\n"
-"            throw MySecurityException(\"Unauthorized access\");\n"
-"        }\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:125
 #, no-c-format
 msgid ""
 "You also need a configuration entry telling Hibernate to use the listener in "
 "addition to the default listener:"
 msgstr ""
-"Vous avez aussi besoin d'une entrée de configuration disant à Hibernate "
+"Vous avez aussi besoin d'une entrée de configuration indiquant à Hibernate "
 "d'utiliser ce listener en plus du listener par défaut :"
 
-#. Tag: programlisting
-#: events.xml:130
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<hibernate-configuration>\n"
-"    <session-factory>\n"
-"        ...\n"
-"        <event type=\"load\">\n"
-"            <listener class=\"com.eg.MyLoadListener\"/>\n"
-"            <listener class=\"org.hibernate.event.def."
-"DefaultLoadEventListener\"/>\n"
-"        </event>\n"
-"    </session-factory>\n"
-"</hibernate-configuration>]]>"
-msgstr ""
+msgid "Instead, you can register it programmatically:"
+msgstr "Vous pouvez aussi l'inscrire par programmation : "
 
 #. Tag: para
-#: events.xml:132
-#, fuzzy, no-c-format
-msgid "Instead, you can register it programmatically:"
-msgstr "Vous pouvez aussi l'inscrire par programmation :"
-
-#. Tag: programlisting
-#: events.xml:136
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration();\n"
-"LoadEventListener[] stack = { new MyLoadListener(), new "
-"DefaultLoadEventListener() };\n"
-"cfg.EventListeners().setLoadEventListeners(stack);]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:138
-#, fuzzy, no-c-format
-msgid ""
 "Listeners registered declaratively cannot share instances. If the same class "
 "name is used in multiple <literal>&lt;listener/&gt;</literal> elements, each "
 "reference will result in a separate instance of that class. If you need to "
@@ -373,14 +220,13 @@
 msgstr ""
 "Les listeners inscrits déclarativement ne peuvent pas partager d'instances. "
 "Si le même nom de classe est utilisée dans plusieurs éléments <literal>&lt;"
-"listener/&gt;</literal>, chaque référence sera une instance distincte de "
-"cette classe. Si vous avez besoin de la faculté de partager des instances de "
-"listener entre plusieurs types de listener, vous devez utiliser l'approche "
-"d'inscription par programmation."
+"listener/&gt;</literal>, chaque référence résultera en une instance "
+"distincte de cette classe. Si vous avez besoin de la faculté de partager des "
+"instances de listener entre plusieurs types de listener, vous devez utiliser "
+"l'approche d'inscription par programmation. "
 
 #. Tag: para
-#: events.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Why implement an interface and define the specific type during "
 "configuration? A listener implementation could implement multiple event "
@@ -390,19 +236,17 @@
 msgstr ""
 "Pourquoi implémenter une interface et définir le type spécifique durant la "
 "configuration ? Une implémentation de listener pourrait implémenter "
-"plusieurs interfaces de listener d'événements. Avoir en plus le type défini "
-"durant l'inscription rend plus facile l'activation ou la désactivation "
-"pendant la configuration."
+"plusieurs interfaces de listener d'événements. Par ailleurs, le fait de "
+"définir le type durant l'inscription, rend l'activation ou la désactivation "
+"plus facile au moment de la configuration. "
 
 #. Tag: title
-#: events.xml:156
 #, no-c-format
 msgid "Hibernate declarative security"
-msgstr "Sécurité déclarative d'Hibernate"
+msgstr "Sécurité déclarative de Hibernate "
 
 #. Tag: para
-#: events.xml:157
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Usually, declarative security in Hibernate applications is managed in a "
 "session facade layer. Hibernate3 allows certain actions to be permissioned "
@@ -413,36 +257,20 @@
 "gérée dans la couche de session. Maintenant, Hibernate3 permet à certaines "
 "actions d'être approuvées via JACC, et autorisées via JAAS. Cette "
 "fonctionnalité optionnelle est construite au dessus de l'architecture "
-"d'événements."
+"d'événements. "
 
 #. Tag: para
-#: events.xml:163
 #, no-c-format
 msgid ""
 "First, you must configure the appropriate event listeners, to enable the use "
 "of JAAS authorization."
 msgstr ""
 "D'abord, vous devez configurer les listeners d'événements appropriés pour "
-"permettre l'utilisation d'autorisations JAAS."
+"permettre l'utilisation d'autorisations JAAS. "
 
-#. Tag: programlisting
-#: events.xml:168
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
-"JACCPreDeleteEventListener\"/>\n"
-"<listener type=\"pre-update\" class=\"org.hibernate.secure."
-"JACCPreUpdateEventListener\"/>\n"
-"<listener type=\"pre-insert\" class=\"org.hibernate.secure."
-"JACCPreInsertEventListener\"/>\n"
-"<listener type=\"pre-load\" class=\"org.hibernate.secure."
-"JACCPreLoadEventListener\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:170
-#, fuzzy, no-c-format
-msgid ""
 "Note that <literal>&lt;listener type=\"...\" class=\"...\"/&gt;</literal> is "
 "shorthand for <literal>&lt;event type=\"...\"&gt;&lt;listener class=\"...\"/"
 "&gt;&lt;/event&gt;</literal> when there is exactly one listener for a "
@@ -451,29 +279,288 @@
 "Notez que <literal>&lt;listener type=\"...\" class=\"...\"/&gt;</literal> "
 "est juste un raccourci pour <literal>&lt;event type=\"...\"&gt;&lt;listener "
 "class=\"...\"/&gt;&lt;/event&gt;</literal> quand il y a exactement un "
-"listener pour un type d'événement particulier."
+"listener pour un type d'événement particulier. "
 
 #. Tag: para
-#: events.xml:176
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next, while still in <literal>hibernate.cfg.xml</literal>, bind the "
 "permissions to roles:"
 msgstr ""
-"Ensuite, toujours dans <literal>hibernate.cfg.xml</literal>, lier les "
-"permissions aux rôles :"
+"Ensuite, toujours dans <literal>hibernate.cfg.xml</literal>, liez les "
+"permissions aux rôles : "
 
-#. Tag: programlisting
-#: events.xml:180
-#, no-c-format
-msgid ""
-"<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,update,"
-"read\"/>\n"
-"<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:182
 #, no-c-format
 msgid "The role names are the roles understood by your JACC provider."
 msgstr "Les noms de rôle sont les rôles compris par votre fournisseur JAAC."
+
+#~ msgid ""
+#~ "<![CDATA[package org.hibernate.test;\n"
+#~ "\n"
+#~ "import java.io.Serializable;\n"
+#~ "import java.util.Date;\n"
+#~ "import java.util.Iterator;\n"
+#~ "\n"
+#~ "import org.hibernate.EmptyInterceptor;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.type.Type;\n"
+#~ "\n"
+#~ "public class AuditInterceptor extends EmptyInterceptor {\n"
+#~ "\n"
+#~ "    private int updates;\n"
+#~ "    private int creates;\n"
+#~ "    private int loads;\n"
+#~ "\n"
+#~ "    public void onDelete(Object entity,\n"
+#~ "                         Serializable id,\n"
+#~ "                         Object[] state,\n"
+#~ "                         String[] propertyNames,\n"
+#~ "                         Type[] types) {\n"
+#~ "        // do nothing\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onFlushDirty(Object entity,\n"
+#~ "                                Serializable id,\n"
+#~ "                                Object[] currentState,\n"
+#~ "                                Object[] previousState,\n"
+#~ "                                String[] propertyNames,\n"
+#~ "                                Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            updates++;\n"
+#~ "            for ( int i=0; i < propertyNames.length; i++ ) {\n"
+#~ "                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) "
+#~ "{\n"
+#~ "                    currentState[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onLoad(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            loads++;\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onSave(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            creates++;\n"
+#~ "            for ( int i=0; i<propertyNames.length; i++ ) {\n"
+#~ "                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
+#~ "                    state[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void afterTransactionCompletion(Transaction tx) {\n"
+#~ "        if ( tx.wasCommitted() ) {\n"
+#~ "            System.out.println(\"Creations: \" + creates + \", Updates: "
+#~ "\" + updates, \"Loads: \" + loads);\n"
+#~ "        }\n"
+#~ "        updates=0;\n"
+#~ "        creates=0;\n"
+#~ "        loads=0;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package org.hibernate.test;\n"
+#~ "\n"
+#~ "import java.io.Serializable;\n"
+#~ "import java.util.Date;\n"
+#~ "import java.util.Iterator;\n"
+#~ "\n"
+#~ "import org.hibernate.EmptyInterceptor;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.type.Type;\n"
+#~ "\n"
+#~ "public class AuditInterceptor extends EmptyInterceptor {\n"
+#~ "\n"
+#~ "    private int updates;\n"
+#~ "    private int creates;\n"
+#~ "    private int loads;\n"
+#~ "\n"
+#~ "    public void onDelete(Object entity,\n"
+#~ "                         Serializable id,\n"
+#~ "                         Object[] state,\n"
+#~ "                         String[] propertyNames,\n"
+#~ "                         Type[] types) {\n"
+#~ "        // do nothing\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onFlushDirty(Object entity,\n"
+#~ "                                Serializable id,\n"
+#~ "                                Object[] currentState,\n"
+#~ "                                Object[] previousState,\n"
+#~ "                                String[] propertyNames,\n"
+#~ "                                Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            updates++;\n"
+#~ "            for ( int i=0; i < propertyNames.length; i++ ) {\n"
+#~ "                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) "
+#~ "{\n"
+#~ "                    currentState[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onLoad(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            loads++;\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onSave(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            creates++;\n"
+#~ "            for ( int i=0; i<propertyNames.length; i++ ) {\n"
+#~ "                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
+#~ "                    state[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void afterTransactionCompletion(Transaction tx) {\n"
+#~ "        if ( tx.wasCommitted() ) {\n"
+#~ "            System.out.println(\"Creations: \" + creates + \", Updates: "
+#~ "\" + updates, \"Loads: \" + loads);\n"
+#~ "        }\n"
+#~ "        updates=0;\n"
+#~ "        creates=0;\n"
+#~ "        loads=0;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
+
+#~ msgid ""
+#~ "<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
+#~ msgstr ""
+#~ "<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
+
+#~ msgid ""
+#~ "<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
+#~ "    // this is the single method defined by the LoadEventListener "
+#~ "interface\n"
+#~ "    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
+#~ "loadType)\n"
+#~ "            throws HibernateException {\n"
+#~ "        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
+#~ "getEntityId() ) ) {\n"
+#~ "            throw MySecurityException(\"Unauthorized access\");\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
+#~ "    // this is the single method defined by the LoadEventListener "
+#~ "interface\n"
+#~ "    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
+#~ "loadType)\n"
+#~ "            throws HibernateException {\n"
+#~ "        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
+#~ "getEntityId() ) ) {\n"
+#~ "            throw MySecurityException(\"Unauthorized access\");\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-configuration>\n"
+#~ "    <session-factory>\n"
+#~ "        ...\n"
+#~ "        <event type=\"load\">\n"
+#~ "            <listener class=\"com.eg.MyLoadListener\"/>\n"
+#~ "            <listener class=\"org.hibernate.event.def."
+#~ "DefaultLoadEventListener\"/>\n"
+#~ "        </event>\n"
+#~ "    </session-factory>\n"
+#~ "</hibernate-configuration>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-configuration>\n"
+#~ "    <session-factory>\n"
+#~ "        ...\n"
+#~ "        <event type=\"load\">\n"
+#~ "            <listener class=\"com.eg.MyLoadListener\"/>\n"
+#~ "            <listener class=\"org.hibernate.event.def."
+#~ "DefaultLoadEventListener\"/>\n"
+#~ "        </event>\n"
+#~ "    </session-factory>\n"
+#~ "</hibernate-configuration>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Configuration cfg = new Configuration();\n"
+#~ "LoadEventListener[] stack = { new MyLoadListener(), new "
+#~ "DefaultLoadEventListener() };\n"
+#~ "cfg.EventListeners().setLoadEventListeners(stack);]]>"
+#~ msgstr ""
+#~ "<![CDATA[Configuration cfg = new Configuration();\n"
+#~ "LoadEventListener[] stack = { new MyLoadListener(), new "
+#~ "DefaultLoadEventListener() };\n"
+#~ "cfg.EventListeners().setLoadEventListeners(stack);]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
+#~ "JACCPreDeleteEventListener\"/>\n"
+#~ "<listener type=\"pre-update\" class=\"org.hibernate.secure."
+#~ "JACCPreUpdateEventListener\"/>\n"
+#~ "<listener type=\"pre-insert\" class=\"org.hibernate.secure."
+#~ "JACCPreInsertEventListener\"/>\n"
+#~ "<listener type=\"pre-load\" class=\"org.hibernate.secure."
+#~ "JACCPreLoadEventListener\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
+#~ "JACCPreDeleteEventListener\"/>\n"
+#~ "<listener type=\"pre-update\" class=\"org.hibernate.secure."
+#~ "JACCPreUpdateEventListener\"/>\n"
+#~ "<listener type=\"pre-insert\" class=\"org.hibernate.secure."
+#~ "JACCPreInsertEventListener\"/>\n"
+#~ "<listener type=\"pre-load\" class=\"org.hibernate.secure."
+#~ "JACCPreLoadEventListener\"/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,"
+#~ "update,read\"/>\n"
+#~ "<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,"
+#~ "update,read\"/>\n"
+#~ "<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/example_mappings.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/example_mappings.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/example_mappings.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,36 +1,38 @@
+# translation of example_mappings.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: example_mappings\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-11-11 09:19+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: example_mappings.xml:29
 #, no-c-format
 msgid "Example: Various Mappings"
-msgstr "Exemple : quelques mappings"
+msgstr "Exemple : quelques mappages"
 
 #. Tag: para
-#: example_mappings.xml:32
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This chapters explores some more complex association mappings."
-msgstr "Ce chapitre montre quelques mappings plus complexes."
+msgstr "Ce chapitre montre quelques mappages plus complexes. "
 
 #. Tag: title
-#: example_mappings.xml:37
 #, no-c-format
 msgid "Employer/Employee"
 msgstr "Employeur/Employé (Employer/Employee)"
 
 #. Tag: para
-#: example_mappings.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following model of the relationship between <literal>Employer</literal> "
 "and <literal>Employee</literal> uses an entity class (<literal>Employment</"
@@ -40,130 +42,29 @@
 msgstr ""
 "Le modèle suivant de relation entre <literal>Employer</literal> et "
 "<literal>Employee</literal> utilise une vraie classe entité "
-"(<literal>Employment</literal>) pour représenter l'association. On a fait "
-"cela parce qu'il peut y avoir plus d'une période d'emploi pour les deux "
-"mêmes parties. Des composants sont utilisés pour modéliser les valeurs "
-"monétaires et les noms des employés."
+"(<literal>Employment</literal>) pour représenter l'association. La raison "
+"étant qu'il peut y avoir plus d'une période d'emploi pour les deux mêmes "
+"parties. Des composants sont utilisés pour modéliser les valeurs monétaires "
+"et les noms des employés. "
 
 #. Tag: para
-#: example_mappings.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is a possible mapping document:"
-msgstr "Voici un document de mapping possible :"
+msgstr "Voici un document de mappage possible : "
 
-#. Tag: programlisting
-#: example_mappings.xml:60
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"        \n"
-"    <class name=\"Employer\" table=\"employers\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employer_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Employment\" table=\"employment_periods\">\n"
-"\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employment_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"startDate\" column=\"start_date\"/>\n"
-"        <property name=\"endDate\" column=\"end_date\"/>\n"
-"\n"
-"        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
-"            <property name=\"amount\">\n"
-"                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/>\n"
-"            </property>\n"
-"            <property name=\"currency\" length=\"12\"/>\n"
-"        </component>\n"
-"\n"
-"        <many-to-one name=\"employer\" column=\"employer_id\" not-null=\"true"
-"\"/>\n"
-"        <many-to-one name=\"employee\" column=\"employee_id\" not-null=\"true"
-"\"/>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Employee\" table=\"employees\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employee_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"taxfileNumber\"/>\n"
-"        <component name=\"name\" class=\"Name\">\n"
-"            <property name=\"firstName\"/>\n"
-"            <property name=\"initial\"/>\n"
-"            <property name=\"lastName\"/>\n"
-"        </component>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: example_mappings.xml:62
-#, fuzzy, no-c-format
 msgid "Here is the table schema generated by <literal>SchemaExport</literal>."
 msgstr ""
-"Et voici le schéma des tables générées par <literal>SchemaExport</literal>."
+"Et voici le schéma des tables générées par <literal>SchemaExport</literal>. "
 
-#. Tag: programlisting
-#: example_mappings.xml:66
-#, no-c-format
-msgid ""
-"<![CDATA[create table employers (\n"
-"    id BIGINT not null, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table employment_periods (\n"
-"    id BIGINT not null,\n"
-"    hourly_rate NUMERIC(12, 2),\n"
-"    currency VARCHAR(12), \n"
-"    employee_id BIGINT not null, \n"
-"    employer_id BIGINT not null, \n"
-"    end_date TIMESTAMP, \n"
-"    start_date TIMESTAMP, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table employees (\n"
-"    id BIGINT not null, \n"
-"    firstName VARCHAR(255), \n"
-"    initial CHAR(1), \n"
-"    lastName VARCHAR(255), \n"
-"    taxfileNumber VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table employment_periods \n"
-"    add constraint employment_periodsFK0 foreign key (employer_id) "
-"references employers\n"
-"alter table employment_periods \n"
-"    add constraint employment_periodsFK1 foreign key (employee_id) "
-"references employees\n"
-"create sequence employee_id_seq\n"
-"create sequence employment_id_seq\n"
-"create sequence employer_id_seq]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:71
 #, no-c-format
 msgid "Author/Work"
-msgstr "Auteur/Travail (Author/Work)"
+msgstr "Auteur/Travail "
 
 #. Tag: para
-#: example_mappings.xml:73
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Consider the following model of the relationships between <literal>Work</"
 "literal>, <literal>Author</literal> and <literal>Person</literal>. In the "
@@ -173,144 +74,42 @@
 "literal> is represented as one-to-one association. Another possibility would "
 "be to have <literal>Author</literal> extend <literal>Person</literal>."
 msgstr ""
-"Soit le modèle de la relation entre <literal>Work</literal>, "
+"Examinons le modèle suivant de la relation entre <literal>Work</literal>, "
 "<literal>Author</literal> et <literal>Person</literal>. Nous représentons la "
 "relation entre <literal>Work</literal> et <literal>Author</literal> comme "
-"une association plusieurs-vers-plusieurs. Nous avons choisi de représenter "
-"la relation entre <literal>Author</literal> et <literal>Person</literal> "
-"comme une association un-vers-un. Une autre possibilité aurait été que "
-"<literal>Author</literal> hérite de <literal>Person</literal>."
+"une association plusieurs-à-plusieurs. Nous avons choisi de représenter la "
+"relation entre <literal>Author</literal> et <literal>Person</literal> comme "
+"une association un-à-un. Une autre possibilité aurait été que "
+"<literal>Author</literal> étende <literal>Person</literal>. "
 
 #. Tag: para
-#: example_mappings.xml:91
 #, no-c-format
 msgid ""
 "The following mapping document correctly represents these relationships:"
-msgstr "Le mapping suivant représente exactement ces relations :"
+msgstr "Le mappage suivant représente exactement ces relations :"
 
-#. Tag: programlisting
-#: example_mappings.xml:95
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
-"\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <discriminator column=\"type\" type=\"character\"/>\n"
-"\n"
-"        <property name=\"title\"/>\n"
-"        <set name=\"authors\" table=\"author_work\">\n"
-"            <key column name=\"work_id\"/>\n"
-"            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
-"        </set>\n"
-"\n"
-"        <subclass name=\"Book\" discriminator-value=\"B\">\n"
-"            <property name=\"text\"/>\n"
-"        </subclass>\n"
-"\n"
-"        <subclass name=\"Song\" discriminator-value=\"S\">\n"
-"            <property name=\"tempo\"/>\n"
-"            <property name=\"genre\"/>\n"
-"        </subclass>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Author\" table=\"authors\">\n"
-"\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <!-- The Author must have the same identifier as the Person -->\n"
-"            <generator class=\"assigned\"/> \n"
-"        </id>\n"
-"\n"
-"        <property name=\"alias\"/>\n"
-"        <one-to-one name=\"person\" constrained=\"true\"/>\n"
-"\n"
-"        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
-"            <key column=\"author_id\"/>\n"
-"            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
-"        </set>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Person\" table=\"persons\">\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: example_mappings.xml:97
-#, fuzzy, no-c-format
-msgid ""
 "There are four tables in this mapping: <literal>works</literal>, "
 "<literal>authors</literal> and <literal>persons</literal> hold work, author "
 "and person data respectively. <literal>author_work</literal> is an "
 "association table linking authors to works. Here is the table schema, as "
 "generated by <literal>SchemaExport</literal>:"
 msgstr ""
-"Il y a quatre tables dans ce mapping. <literal>works</literal>, "
+"Il y a quatre tables dans ce mappage. <literal>works</literal>, "
 "<literal>authors</literal> et <literal>persons</literal> qui contiennent "
 "respectivement les données de work, author et person. <literal>author_work</"
 "literal> est une table d'association qui lie authors à works. Voici le "
-"schéma de tables, généré par <literal>SchemaExport</literal>."
+"schéma de tables, généré par <literal>SchemaExport</literal> :"
 
-#. Tag: programlisting
-#: example_mappings.xml:105
-#, no-c-format
-msgid ""
-"<![CDATA[create table works (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    tempo FLOAT, \n"
-"    genre VARCHAR(255), \n"
-"    text INTEGER, \n"
-"    title VARCHAR(255), \n"
-"    type CHAR(1) not null, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table author_work (\n"
-"    author_id BIGINT not null, \n"
-"    work_id BIGINT not null, \n"
-"    primary key (work_id, author_id)\n"
-")\n"
-"\n"
-"create table authors (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    alias VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table persons (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table authors \n"
-"    add constraint authorsFK0 foreign key (id) references persons\n"
-"alter table author_work \n"
-"    add constraint author_workFK0 foreign key (author_id) references "
-"authors\n"
-"alter table author_work\n"
-"    add constraint author_workFK1 foreign key (work_id) references works]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:110
 #, no-c-format
 msgid "Customer/Order/Product"
-msgstr "Client/Commande/Produit (Customer/Order/Product)"
+msgstr "Client/Commande/Produit "
 
 #. Tag: para
-#: example_mappings.xml:112
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In this section we consider a model of the relationships between "
 "<literal>Customer</literal>, <literal>Order</literal>, <literal>Line Item</"
@@ -322,68 +121,22 @@
 "between <literal>Order</literal> and <literal>Product</literal>. In "
 "Hibernate this is called a composite element."
 msgstr ""
-"Imaginons maintenant le modèle de relation entre <literal>Customer</"
+"Imaginons maintenant le modèle de relations entre <literal>Customer</"
 "literal>, <literal>Order</literal>, <literal>LineItem</literal> et "
-"<literal>Product</literal>. Il y a une association un-vers-plusieurs entre "
-"<literal>Customer</literal> et <literal>Order</literal>, mais comment "
-"devrions nous représenter <literal>Order</literal> / <literal>LineItem</"
-"literal> / <literal>Product</literal>? J'ai choisi de mapper "
-"<literal>LineItem</literal> comme une classe d'association représentant "
-"l'association plusieurs-vers-plusieurs entre <literal>Order</literal> et "
-"<literal>Product</literal>. Dans Hibernate, on appelle cela un élément "
-"composite."
+"<literal>Product</literal>. Il y a une association un-à-plusieurs entre "
+"<literal>Customer</literal> et <literal>Order</literal>, mais comment devons "
+"nous représenter <literal>Order</literal> / <literal>LineItem</literal> / "
+"<literal>Product</literal> ? J'ai choisi de mapper <literal>LineItem</"
+"literal> comme une classe d'association représentant l'association plusieurs-"
+"à-plusieurs entre <literal>Order</literal> et <literal>Product</literal>. "
+"Dans Hibernate, on appelle cela un élément composite. "
 
 #. Tag: para
-#: example_mappings.xml:132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The mapping document will look like this:"
-msgstr "Le document de mapping :"
+msgstr "Le document de mappage : "
 
-#. Tag: programlisting
-#: example_mappings.xml:136
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Customer\" table=\"customers\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"        <set name=\"orders\" inverse=\"true\">\n"
-"            <key column=\"customer_id\"/>\n"
-"            <one-to-many class=\"Order\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Order\" table=\"orders\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"date\"/>\n"
-"        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
-"        <list name=\"lineItems\" table=\"line_items\">\n"
-"            <key column=\"order_id\"/>\n"
-"            <list-index column=\"line_number\"/>\n"
-"            <composite-element class=\"LineItem\">\n"
-"                <property name=\"quantity\"/>\n"
-"                <many-to-one name=\"product\" column=\"product_id\"/>\n"
-"            </composite-element>\n"
-"        </list>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Product\" table=\"products\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"serialNumber\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_mappings.xml:138
 #, no-c-format
 msgid ""
 "<literal>customers</literal>, <literal>orders</literal>, "
@@ -394,398 +147,1118 @@
 "<literal>customers</literal>, <literal>orders</literal>, "
 "<literal>line_items</literal> et <literal>products</literal> contiennent les "
 "données de customer, order, order line item et product. <literal>line_items</"
-"literal> est aussi la table d'association liant orders à products."
+"literal> est aussi la table d'association liant orders à products. "
 
-#. Tag: programlisting
-#: example_mappings.xml:145
-#, no-c-format
-msgid ""
-"<![CDATA[create table customers (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table orders (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    customer_id BIGINT, \n"
-"    date TIMESTAMP, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table line_items (\n"
-"    line_number INTEGER not null, \n"
-"    order_id BIGINT not null, \n"
-"    product_id BIGINT, \n"
-"    quantity INTEGER, \n"
-"    primary key (order_id, line_number)\n"
-")\n"
-"\n"
-"create table products (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    serialNumber VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table orders \n"
-"    add constraint ordersFK0 foreign key (customer_id) references customers\n"
-"alter table line_items\n"
-"    add constraint line_itemsFK0 foreign key (product_id) references "
-"products\n"
-"alter table line_items\n"
-"    add constraint line_itemsFK1 foreign key (order_id) references orders]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:150
 #, no-c-format
 msgid "Miscellaneous example mappings"
-msgstr "Divers mappings d'exemple"
+msgstr "Divers exemples de mappages"
 
 #. Tag: para
-#: example_mappings.xml:152
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These examples are available from the Hibernate test suite. You will find "
 "many other useful example mappings there by searching in the <literal>test</"
 "literal> folder of the Hibernate distribution."
 msgstr ""
-"Ces exemples sont tous pris de la suite de tests d'Hibernate. Vous en "
+"Ces exemples sont tous pris de la suite de tests de Hibernate. Vous en "
 "trouverez beaucoup d'autres. Regardez dans le dossier <literal>test</"
-"literal> de la distribution d'Hibernate."
+"literal> de la distribution Hibernate. "
 
 #. Tag: title
-#: example_mappings.xml:161
 #, no-c-format
 msgid "\"Typed\" one-to-one association"
-msgstr "\"Typed\" one-to-one association"
+msgstr "\"Typed\" association un-à-un"
 
-#. Tag: programlisting
-#: example_mappings.xml:162
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"name\"/>\n"
-"    <one-to-one name=\"address\" \n"
-"            cascade=\"all\">\n"
-"        <formula>name</formula>\n"
-"        <formula>'HOME'</formula>\n"
-"    </one-to-one>\n"
-"    <one-to-one name=\"mailingAddress\" \n"
-"            cascade=\"all\">\n"
-"        <formula>name</formula>\n"
-"        <formula>'MAILING'</formula>\n"
-"    </one-to-one>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\" batch-size=\"2\" \n"
-"        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
-"    <composite-id>\n"
-"        <key-many-to-one name=\"person\" \n"
-"                column=\"personName\"/>\n"
-"        <key-property name=\"type\" \n"
-"                column=\"addressType\"/>\n"
-"    </composite-id>\n"
-"    <property name=\"street\" type=\"text\"/>\n"
-"    <property name=\"state\"/>\n"
-"    <property name=\"zip\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:166
 #, no-c-format
 msgid "Composite key example"
 msgstr "Exemple de clef composée"
 
-#. Tag: programlisting
-#: example_mappings.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Customer\">\n"
-"\n"
-"    <id name=\"customerId\"\n"
-"        length=\"10\">\n"
-"        <generator class=\"assigned\"/>\n"
-"    </id>\n"
-"\n"
-"    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
-"    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
-"\n"
-"    <list name=\"orders\"\n"
-"            inverse=\"true\"\n"
-"            cascade=\"save-update\">\n"
-"        <key column=\"customerId\"/>\n"
-"        <index column=\"orderNumber\"/>\n"
-"        <one-to-many class=\"Order\"/>\n"
-"    </list>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
-"    <synchronize table=\"LineItem\"/>\n"
-"    <synchronize table=\"Product\"/>\n"
-"    \n"
-"    <composite-id name=\"id\" \n"
-"            class=\"Order$Id\">\n"
-"        <key-property name=\"customerId\" length=\"10\"/>\n"
-"        <key-property name=\"orderNumber\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"orderDate\" \n"
-"            type=\"calendar_date\"\n"
-"            not-null=\"true\"/>\n"
-"    \n"
-"    <property name=\"total\">\n"
-"        <formula>\n"
-"            ( select sum(li.quantity*p.price) \n"
-"            from LineItem li, Product p \n"
-"            where li.productId = p.productId \n"
-"                and li.customerId = customerId \n"
-"                and li.orderNumber = orderNumber )\n"
-"        </formula>\n"
-"    </property>\n"
-"    \n"
-"    <many-to-one name=\"customer\"\n"
-"            column=\"customerId\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\"/>\n"
-"        \n"
-"    <bag name=\"lineItems\"\n"
-"            fetch=\"join\" \n"
-"            inverse=\"true\"\n"
-"            cascade=\"save-update\">\n"
-"        <key>\n"
-"            <column name=\"customerId\"/>\n"
-"            <column name=\"orderNumber\"/>\n"
-"        </key>\n"
-"        <one-to-many class=\"LineItem\"/>\n"
-"    </bag>\n"
-"    \n"
-"</class>\n"
-"    \n"
-"<class name=\"LineItem\">\n"
-"    \n"
-"    <composite-id name=\"id\" \n"
-"            class=\"LineItem$Id\">\n"
-"        <key-property name=\"customerId\" length=\"10\"/>\n"
-"        <key-property name=\"orderNumber\"/>\n"
-"        <key-property name=\"productId\" length=\"10\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"quantity\"/>\n"
-"    \n"
-"    <many-to-one name=\"order\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\">\n"
-"        <column name=\"customerId\"/>\n"
-"        <column name=\"orderNumber\"/>\n"
-"    </many-to-one>\n"
-"    \n"
-"    <many-to-one name=\"product\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\"\n"
-"            column=\"productId\"/>\n"
-"        \n"
-"</class>\n"
-"\n"
-"<class name=\"Product\">\n"
-"    <synchronize table=\"LineItem\"/>\n"
-"\n"
-"    <id name=\"productId\"\n"
-"        length=\"10\">\n"
-"        <generator class=\"assigned\"/>\n"
-"    </id>\n"
-"    \n"
-"    <property name=\"description\" \n"
-"        not-null=\"true\" \n"
-"        length=\"200\"/>\n"
-"    <property name=\"price\" length=\"3\"/>\n"
-"    <property name=\"numberAvailable\"/>\n"
-"    \n"
-"    <property name=\"numberOrdered\">\n"
-"        <formula>\n"
-"            ( select sum(li.quantity) \n"
-"            from LineItem li \n"
-"            where li.productId = productId )\n"
-"        </formula>\n"
-"    </property>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:171
 #, no-c-format
 msgid "Many-to-many with shared composite key attribute"
-msgstr "Many-to-many avec une clef composée partagée"
+msgstr "Plusieurs-à-plusieurs avec un attribut de clef composée partagée"
 
-#. Tag: programlisting
-#: example_mappings.xml:172
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"User\" table=\"`User`\">\n"
-"    <composite-id>\n"
-"        <key-property name=\"name\"/>\n"
-"        <key-property name=\"org\"/>\n"
-"    </composite-id>\n"
-"    <set name=\"groups\" table=\"UserGroup\">\n"
-"        <key>\n"
-"            <column name=\"userName\"/>\n"
-"            <column name=\"org\"/>\n"
-"        </key>\n"
-"        <many-to-many class=\"Group\">\n"
-"            <column name=\"groupName\"/>\n"
-"            <formula>org</formula>\n"
-"        </many-to-many>\n"
-"    </set>\n"
-"</class>\n"
-"    \n"
-"<class name=\"Group\" table=\"`Group`\">\n"
-"    <composite-id>\n"
-"        <key-property name=\"name\"/>\n"
-"        <key-property name=\"org\"/>\n"
-"    </composite-id>\n"
-"    <property name=\"description\"/>\n"
-"    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
-"        <key>\n"
-"            <column name=\"groupName\"/>\n"
-"            <column name=\"org\"/>\n"
-"        </key>\n"
-"        <many-to-many class=\"User\">\n"
-"            <column name=\"userName\"/>\n"
-"            <formula>org</formula>\n"
-"        </many-to-many>\n"
-"    </set>\n"
-"</class>\n"
-"]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:176
 #, no-c-format
 msgid "Content based discrimination"
 msgstr "Contenu basé sur une discrimination"
 
-#. Tag: programlisting
-#: example_mappings.xml:177
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\"\n"
-"    discriminator-value=\"P\">\n"
-"    \n"
-"    <id name=\"id\" \n"
-"        column=\"person_id\" \n"
-"        unsaved-value=\"0\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    \n"
-"            \n"
-"    <discriminator \n"
-"        type=\"character\">\n"
-"        <formula>\n"
-"            case \n"
-"                when title is not null then 'E' \n"
-"                when salesperson is not null then 'C' \n"
-"                else 'P' \n"
-"            end\n"
-"        </formula>\n"
-"    </discriminator>\n"
-"\n"
-"    <property name=\"name\" \n"
-"        not-null=\"true\"\n"
-"        length=\"80\"/>\n"
-"        \n"
-"    <property name=\"sex\" \n"
-"        not-null=\"true\"\n"
-"        update=\"false\"/>\n"
-"    \n"
-"    <component name=\"address\">\n"
-"        <property name=\"address\"/>\n"
-"        <property name=\"zip\"/>\n"
-"        <property name=\"country\"/>\n"
-"    </component>\n"
-"    \n"
-"    <subclass name=\"Employee\" \n"
-"        discriminator-value=\"E\">\n"
-"            <property name=\"title\"\n"
-"                length=\"20\"/>\n"
-"            <property name=\"salary\"/>\n"
-"            <many-to-one name=\"manager\"/>\n"
-"    </subclass>\n"
-"    \n"
-"    <subclass name=\"Customer\" \n"
-"        discriminator-value=\"C\">\n"
-"            <property name=\"comments\"/>\n"
-"            <many-to-one name=\"salesperson\"/>\n"
-"    </subclass>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:181
 #, no-c-format
 msgid "Associations on alternate keys"
-msgstr "Associations sur des clefs alternées"
+msgstr "Associations sur des clés alternées"
 
-#. Tag: programlisting
-#: example_mappings.xml:182
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    \n"
-"    <id name=\"id\">\n"
-"        <generator class=\"hilo\"/>\n"
-"    </id>\n"
-"    \n"
-"    <property name=\"name\" length=\"100\"/>\n"
-"    \n"
-"    <one-to-one name=\"address\" \n"
-"        property-ref=\"person\"\n"
-"        cascade=\"all\"\n"
-"        fetch=\"join\"/>\n"
-"    \n"
-"    <set name=\"accounts\" \n"
-"        inverse=\"true\">\n"
-"        <key column=\"userId\"\n"
-"            property-ref=\"userId\"/>\n"
-"        <one-to-many class=\"Account\"/>\n"
-"    </set>\n"
-"    \n"
-"    <property name=\"userId\" length=\"8\"/>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"hilo\"/>\n"
-"    </id>\n"
-"\n"
-"    <property name=\"address\" length=\"300\"/>\n"
-"    <property name=\"zip\" length=\"5\"/>\n"
-"    <property name=\"country\" length=\"25\"/>\n"
-"    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Account\">\n"
-"    <id name=\"accountId\" length=\"32\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    \n"
-"    <many-to-one name=\"user\"\n"
-"        column=\"userId\"\n"
-"        property-ref=\"userId\"/>\n"
-"    \n"
-"    <property name=\"type\" not-null=\"true\"/>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "        \n"
+#~ "    <class name=\"Employer\" table=\"employers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employer_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employment\" table=\"employment_periods\">\n"
+#~ "\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employment_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"startDate\" column=\"start_date\"/>\n"
+#~ "        <property name=\"endDate\" column=\"end_date\"/>\n"
+#~ "\n"
+#~ "        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
+#~ "            <property name=\"amount\">\n"
+#~ "                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/"
+#~ ">\n"
+#~ "            </property>\n"
+#~ "            <property name=\"currency\" length=\"12\"/>\n"
+#~ "        </component>\n"
+#~ "\n"
+#~ "        <many-to-one name=\"employer\" column=\"employer_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "        <many-to-one name=\"employee\" column=\"employee_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employee\" table=\"employees\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employee_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"taxfileNumber\"/>\n"
+#~ "        <component name=\"name\" class=\"Name\">\n"
+#~ "            <property name=\"firstName\"/>\n"
+#~ "            <property name=\"initial\"/>\n"
+#~ "            <property name=\"lastName\"/>\n"
+#~ "        </component>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "        \n"
+#~ "    <class name=\"Employer\" table=\"employers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employer_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employment\" table=\"employment_periods\">\n"
+#~ "\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employment_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"startDate\" column=\"start_date\"/>\n"
+#~ "        <property name=\"endDate\" column=\"end_date\"/>\n"
+#~ "\n"
+#~ "        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
+#~ "            <property name=\"amount\">\n"
+#~ "                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/"
+#~ ">\n"
+#~ "            </property>\n"
+#~ "            <property name=\"currency\" length=\"12\"/>\n"
+#~ "        </component>\n"
+#~ "\n"
+#~ "        <many-to-one name=\"employer\" column=\"employer_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "        <many-to-one name=\"employee\" column=\"employee_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employee\" table=\"employees\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employee_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"taxfileNumber\"/>\n"
+#~ "        <component name=\"name\" class=\"Name\">\n"
+#~ "            <property name=\"firstName\"/>\n"
+#~ "            <property name=\"initial\"/>\n"
+#~ "            <property name=\"lastName\"/>\n"
+#~ "        </component>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 
-#~ msgid "TODO: put words around this stuff"
-#~ msgstr "TODO: put words around this stuff"
+#~ msgid ""
+#~ "<![CDATA[create table employers (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employment_periods (\n"
+#~ "    id BIGINT not null,\n"
+#~ "    hourly_rate NUMERIC(12, 2),\n"
+#~ "    currency VARCHAR(12), \n"
+#~ "    employee_id BIGINT not null, \n"
+#~ "    employer_id BIGINT not null, \n"
+#~ "    end_date TIMESTAMP, \n"
+#~ "    start_date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employees (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    firstName VARCHAR(255), \n"
+#~ "    initial CHAR(1), \n"
+#~ "    lastName VARCHAR(255), \n"
+#~ "    taxfileNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK0 foreign key (employer_id) "
+#~ "references employers\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK1 foreign key (employee_id) "
+#~ "references employees\n"
+#~ "create sequence employee_id_seq\n"
+#~ "create sequence employment_id_seq\n"
+#~ "create sequence employer_id_seq]]>"
+#~ msgstr ""
+#~ "<![CDATA[create table employers (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employment_periods (\n"
+#~ "    id BIGINT not null,\n"
+#~ "    hourly_rate NUMERIC(12, 2),\n"
+#~ "    currency VARCHAR(12), \n"
+#~ "    employee_id BIGINT not null, \n"
+#~ "    employer_id BIGINT not null, \n"
+#~ "    end_date TIMESTAMP, \n"
+#~ "    start_date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employees (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    firstName VARCHAR(255), \n"
+#~ "    initial CHAR(1), \n"
+#~ "    lastName VARCHAR(255), \n"
+#~ "    taxfileNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK0 foreign key (employer_id) "
+#~ "references employers\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK1 foreign key (employee_id) "
+#~ "references employees\n"
+#~ "create sequence employee_id_seq\n"
+#~ "create sequence employment_id_seq\n"
+#~ "create sequence employer_id_seq]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <discriminator column=\"type\" type=\"character\"/>\n"
+#~ "\n"
+#~ "        <property name=\"title\"/>\n"
+#~ "        <set name=\"authors\" table=\"author_work\">\n"
+#~ "            <key column name=\"work_id\"/>\n"
+#~ "            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "        <subclass name=\"Book\" discriminator-value=\"B\">\n"
+#~ "            <property name=\"text\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "        <subclass name=\"Song\" discriminator-value=\"S\">\n"
+#~ "            <property name=\"tempo\"/>\n"
+#~ "            <property name=\"genre\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Author\" table=\"authors\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <!-- The Author must have the same identifier as the Person --"
+#~ ">\n"
+#~ "            <generator class=\"assigned\"/> \n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property name=\"alias\"/>\n"
+#~ "        <one-to-one name=\"person\" constrained=\"true\"/>\n"
+#~ "\n"
+#~ "        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
+#~ "            <key column=\"author_id\"/>\n"
+#~ "            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Person\" table=\"persons\">\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <discriminator column=\"type\" type=\"character\"/>\n"
+#~ "\n"
+#~ "        <property name=\"title\"/>\n"
+#~ "        <set name=\"authors\" table=\"author_work\">\n"
+#~ "            <key column name=\"work_id\"/>\n"
+#~ "            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "        <subclass name=\"Book\" discriminator-value=\"B\">\n"
+#~ "            <property name=\"text\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "        <subclass name=\"Song\" discriminator-value=\"S\">\n"
+#~ "            <property name=\"tempo\"/>\n"
+#~ "            <property name=\"genre\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Author\" table=\"authors\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <!-- The Author must have the same identifier as the Person --"
+#~ ">\n"
+#~ "            <generator class=\"assigned\"/> \n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property name=\"alias\"/>\n"
+#~ "        <one-to-one name=\"person\" constrained=\"true\"/>\n"
+#~ "\n"
+#~ "        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
+#~ "            <key column=\"author_id\"/>\n"
+#~ "            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Person\" table=\"persons\">\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[create table works (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    tempo FLOAT, \n"
+#~ "    genre VARCHAR(255), \n"
+#~ "    text INTEGER, \n"
+#~ "    title VARCHAR(255), \n"
+#~ "    type CHAR(1) not null, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table author_work (\n"
+#~ "    author_id BIGINT not null, \n"
+#~ "    work_id BIGINT not null, \n"
+#~ "    primary key (work_id, author_id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table authors (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    alias VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table persons (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table authors \n"
+#~ "    add constraint authorsFK0 foreign key (id) references persons\n"
+#~ "alter table author_work \n"
+#~ "    add constraint author_workFK0 foreign key (author_id) references "
+#~ "authors\n"
+#~ "alter table author_work\n"
+#~ "    add constraint author_workFK1 foreign key (work_id) references works]]"
+#~ ">"
+#~ msgstr ""
+#~ "<![CDATA[create table works (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    tempo FLOAT, \n"
+#~ "    genre VARCHAR(255), \n"
+#~ "    text INTEGER, \n"
+#~ "    title VARCHAR(255), \n"
+#~ "    type CHAR(1) not null, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table author_work (\n"
+#~ "    author_id BIGINT not null, \n"
+#~ "    work_id BIGINT not null, \n"
+#~ "    primary key (work_id, author_id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table authors (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    alias VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table persons (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table authors \n"
+#~ "    add constraint authorsFK0 foreign key (id) references persons\n"
+#~ "alter table author_work \n"
+#~ "    add constraint author_workFK0 foreign key (author_id) references "
+#~ "authors\n"
+#~ "alter table author_work\n"
+#~ "    add constraint author_workFK1 foreign key (work_id) references works]]"
+#~ ">"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Customer\" table=\"customers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "        <set name=\"orders\" inverse=\"true\">\n"
+#~ "            <key column=\"customer_id\"/>\n"
+#~ "            <one-to-many class=\"Order\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Order\" table=\"orders\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"date\"/>\n"
+#~ "        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
+#~ "        <list name=\"lineItems\" table=\"line_items\">\n"
+#~ "            <key column=\"order_id\"/>\n"
+#~ "            <list-index column=\"line_number\"/>\n"
+#~ "            <composite-element class=\"LineItem\">\n"
+#~ "                <property name=\"quantity\"/>\n"
+#~ "                <many-to-one name=\"product\" column=\"product_id\"/>\n"
+#~ "            </composite-element>\n"
+#~ "        </list>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Product\" table=\"products\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"serialNumber\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Customer\" table=\"customers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "        <set name=\"orders\" inverse=\"true\">\n"
+#~ "            <key column=\"customer_id\"/>\n"
+#~ "            <one-to-many class=\"Order\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Order\" table=\"orders\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"date\"/>\n"
+#~ "        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
+#~ "        <list name=\"lineItems\" table=\"line_items\">\n"
+#~ "            <key column=\"order_id\"/>\n"
+#~ "            <list-index column=\"line_number\"/>\n"
+#~ "            <composite-element class=\"LineItem\">\n"
+#~ "                <property name=\"quantity\"/>\n"
+#~ "                <many-to-one name=\"product\" column=\"product_id\"/>\n"
+#~ "            </composite-element>\n"
+#~ "        </list>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Product\" table=\"products\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"serialNumber\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[create table customers (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table orders (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    customer_id BIGINT, \n"
+#~ "    date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table line_items (\n"
+#~ "    line_number INTEGER not null, \n"
+#~ "    order_id BIGINT not null, \n"
+#~ "    product_id BIGINT, \n"
+#~ "    quantity INTEGER, \n"
+#~ "    primary key (order_id, line_number)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table products (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    serialNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table orders \n"
+#~ "    add constraint ordersFK0 foreign key (customer_id) references "
+#~ "customers\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK0 foreign key (product_id) references "
+#~ "products\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK1 foreign key (order_id) references "
+#~ "orders]]>"
+#~ msgstr ""
+#~ "<![CDATA[create table customers (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table orders (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    customer_id BIGINT, \n"
+#~ "    date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table line_items (\n"
+#~ "    line_number INTEGER not null, \n"
+#~ "    order_id BIGINT not null, \n"
+#~ "    product_id BIGINT, \n"
+#~ "    quantity INTEGER, \n"
+#~ "    primary key (order_id, line_number)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table products (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    serialNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table orders \n"
+#~ "    add constraint ordersFK0 foreign key (customer_id) references "
+#~ "customers\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK0 foreign key (product_id) references "
+#~ "products\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK1 foreign key (order_id) references "
+#~ "orders]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"name\"/>\n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'HOME'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "    <one-to-one name=\"mailingAddress\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'MAILING'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\" batch-size=\"2\" \n"
+#~ "        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-many-to-one name=\"person\" \n"
+#~ "                column=\"personName\"/>\n"
+#~ "        <key-property name=\"type\" \n"
+#~ "                column=\"addressType\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"street\" type=\"text\"/>\n"
+#~ "    <property name=\"state\"/>\n"
+#~ "    <property name=\"zip\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"name\"/>\n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'HOME'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "    <one-to-one name=\"mailingAddress\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'MAILING'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\" batch-size=\"2\" \n"
+#~ "        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-many-to-one name=\"person\" \n"
+#~ "                column=\"personName\"/>\n"
+#~ "        <key-property name=\"type\" \n"
+#~ "                column=\"addressType\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"street\" type=\"text\"/>\n"
+#~ "    <property name=\"state\"/>\n"
+#~ "    <property name=\"zip\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Customer\">\n"
+#~ "\n"
+#~ "    <id name=\"customerId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
+#~ "    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
+#~ "\n"
+#~ "    <list name=\"orders\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key column=\"customerId\"/>\n"
+#~ "        <index column=\"orderNumber\"/>\n"
+#~ "        <one-to-many class=\"Order\"/>\n"
+#~ "    </list>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "    <synchronize table=\"Product\"/>\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"Order$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"orderDate\" \n"
+#~ "            type=\"calendar_date\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"total\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity*p.price) \n"
+#~ "            from LineItem li, Product p \n"
+#~ "            where li.productId = p.productId \n"
+#~ "                and li.customerId = customerId \n"
+#~ "                and li.orderNumber = orderNumber )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"customer\"\n"
+#~ "            column=\"customerId\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        \n"
+#~ "    <bag name=\"lineItems\"\n"
+#~ "            fetch=\"join\" \n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "            <column name=\"orderNumber\"/>\n"
+#~ "        </key>\n"
+#~ "        <one-to-many class=\"LineItem\"/>\n"
+#~ "    </bag>\n"
+#~ "    \n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"LineItem\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"LineItem$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "        <key-property name=\"productId\" length=\"10\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"quantity\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\">\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "        <column name=\"orderNumber\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"product\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            column=\"productId\"/>\n"
+#~ "        \n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Product\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "\n"
+#~ "    <id name=\"productId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"description\" \n"
+#~ "        not-null=\"true\" \n"
+#~ "        length=\"200\"/>\n"
+#~ "    <property name=\"price\" length=\"3\"/>\n"
+#~ "    <property name=\"numberAvailable\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"numberOrdered\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity) \n"
+#~ "            from LineItem li \n"
+#~ "            where li.productId = productId )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Customer\">\n"
+#~ "\n"
+#~ "    <id name=\"customerId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
+#~ "    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
+#~ "\n"
+#~ "    <list name=\"orders\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key column=\"customerId\"/>\n"
+#~ "        <index column=\"orderNumber\"/>\n"
+#~ "        <one-to-many class=\"Order\"/>\n"
+#~ "    </list>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "    <synchronize table=\"Product\"/>\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"Order$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"orderDate\" \n"
+#~ "            type=\"calendar_date\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"total\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity*p.price) \n"
+#~ "            from LineItem li, Product p \n"
+#~ "            where li.productId = p.productId \n"
+#~ "                and li.customerId = customerId \n"
+#~ "                and li.orderNumber = orderNumber )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"customer\"\n"
+#~ "            column=\"customerId\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        \n"
+#~ "    <bag name=\"lineItems\"\n"
+#~ "            fetch=\"join\" \n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "            <column name=\"orderNumber\"/>\n"
+#~ "        </key>\n"
+#~ "        <one-to-many class=\"LineItem\"/>\n"
+#~ "    </bag>\n"
+#~ "    \n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"LineItem\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"LineItem$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "        <key-property name=\"productId\" length=\"10\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"quantity\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\">\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "        <column name=\"orderNumber\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"product\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            column=\"productId\"/>\n"
+#~ "        \n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Product\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "\n"
+#~ "    <id name=\"productId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"description\" \n"
+#~ "        not-null=\"true\" \n"
+#~ "        length=\"200\"/>\n"
+#~ "    <property name=\"price\" length=\"3\"/>\n"
+#~ "    <property name=\"numberAvailable\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"numberOrdered\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity) \n"
+#~ "            from LineItem li \n"
+#~ "            where li.productId = productId )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"User\" table=\"`User`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <set name=\"groups\" table=\"UserGroup\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"Group\">\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"Group\" table=\"`Group`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"description\"/>\n"
+#~ "    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"User\">\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"User\" table=\"`User`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <set name=\"groups\" table=\"UserGroup\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"Group\">\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"Group\" table=\"`Group`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"description\"/>\n"
+#~ "    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"User\">\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\"\n"
+#~ "    discriminator-value=\"P\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\" \n"
+#~ "        column=\"person_id\" \n"
+#~ "        unsaved-value=\"0\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "            \n"
+#~ "    <discriminator \n"
+#~ "        type=\"character\">\n"
+#~ "        <formula>\n"
+#~ "            case \n"
+#~ "                when title is not null then 'E' \n"
+#~ "                when salesperson is not null then 'C' \n"
+#~ "                else 'P' \n"
+#~ "            end\n"
+#~ "        </formula>\n"
+#~ "    </discriminator>\n"
+#~ "\n"
+#~ "    <property name=\"name\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        length=\"80\"/>\n"
+#~ "        \n"
+#~ "    <property name=\"sex\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        update=\"false\"/>\n"
+#~ "    \n"
+#~ "    <component name=\"address\">\n"
+#~ "        <property name=\"address\"/>\n"
+#~ "        <property name=\"zip\"/>\n"
+#~ "        <property name=\"country\"/>\n"
+#~ "    </component>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Employee\" \n"
+#~ "        discriminator-value=\"E\">\n"
+#~ "            <property name=\"title\"\n"
+#~ "                length=\"20\"/>\n"
+#~ "            <property name=\"salary\"/>\n"
+#~ "            <many-to-one name=\"manager\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Customer\" \n"
+#~ "        discriminator-value=\"C\">\n"
+#~ "            <property name=\"comments\"/>\n"
+#~ "            <many-to-one name=\"salesperson\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\"\n"
+#~ "    discriminator-value=\"P\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\" \n"
+#~ "        column=\"person_id\" \n"
+#~ "        unsaved-value=\"0\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "            \n"
+#~ "    <discriminator \n"
+#~ "        type=\"character\">\n"
+#~ "        <formula>\n"
+#~ "            case \n"
+#~ "                when title is not null then 'E' \n"
+#~ "                when salesperson is not null then 'C' \n"
+#~ "                else 'P' \n"
+#~ "            end\n"
+#~ "        </formula>\n"
+#~ "    </discriminator>\n"
+#~ "\n"
+#~ "    <property name=\"name\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        length=\"80\"/>\n"
+#~ "        \n"
+#~ "    <property name=\"sex\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        update=\"false\"/>\n"
+#~ "    \n"
+#~ "    <component name=\"address\">\n"
+#~ "        <property name=\"address\"/>\n"
+#~ "        <property name=\"zip\"/>\n"
+#~ "        <property name=\"country\"/>\n"
+#~ "    </component>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Employee\" \n"
+#~ "        discriminator-value=\"E\">\n"
+#~ "            <property name=\"title\"\n"
+#~ "                length=\"20\"/>\n"
+#~ "            <property name=\"salary\"/>\n"
+#~ "            <many-to-one name=\"manager\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Customer\" \n"
+#~ "        discriminator-value=\"C\">\n"
+#~ "            <property name=\"comments\"/>\n"
+#~ "            <many-to-one name=\"salesperson\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\" length=\"100\"/>\n"
+#~ "    \n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "        property-ref=\"person\"\n"
+#~ "        cascade=\"all\"\n"
+#~ "        fetch=\"join\"/>\n"
+#~ "    \n"
+#~ "    <set name=\"accounts\" \n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"userId\"\n"
+#~ "            property-ref=\"userId\"/>\n"
+#~ "        <one-to-many class=\"Account\"/>\n"
+#~ "    </set>\n"
+#~ "    \n"
+#~ "    <property name=\"userId\" length=\"8\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"address\" length=\"300\"/>\n"
+#~ "    <property name=\"zip\" length=\"5\"/>\n"
+#~ "    <property name=\"country\" length=\"25\"/>\n"
+#~ "    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Account\">\n"
+#~ "    <id name=\"accountId\" length=\"32\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"user\"\n"
+#~ "        column=\"userId\"\n"
+#~ "        property-ref=\"userId\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"type\" not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\" length=\"100\"/>\n"
+#~ "    \n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "        property-ref=\"person\"\n"
+#~ "        cascade=\"all\"\n"
+#~ "        fetch=\"join\"/>\n"
+#~ "    \n"
+#~ "    <set name=\"accounts\" \n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"userId\"\n"
+#~ "            property-ref=\"userId\"/>\n"
+#~ "        <one-to-many class=\"Account\"/>\n"
+#~ "    </set>\n"
+#~ "    \n"
+#~ "    <property name=\"userId\" length=\"8\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"address\" length=\"300\"/>\n"
+#~ "    <property name=\"zip\" length=\"5\"/>\n"
+#~ "    <property name=\"country\" length=\"25\"/>\n"
+#~ "    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Account\">\n"
+#~ "    <id name=\"accountId\" length=\"32\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"user\"\n"
+#~ "        column=\"userId\"\n"
+#~ "        property-ref=\"userId\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"type\" not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "</class>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/example_parentchild.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/example_parentchild.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/example_parentchild.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,28 @@
+# translation of example_parentchild.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: example_parentchild\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-08-17 20:22+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2010-01-05 09:05+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: example_parentchild.xml:29
 #, no-c-format
 msgid "Example: Parent/Child"
-msgstr "Exemple : Père/Fils"
+msgstr "Exemple : père/fils"
 
 #. Tag: para
-#: example_parentchild.xml:31
-#, fuzzy, no-c-format
+#, 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 "
@@ -42,46 +46,41 @@
 "literal> comme des classes entités liées par une association <literal>&lt;"
 "one-to-many&gt;</literal> du <literal>Père</literal> vers le <literal>Fils</"
 "literal> (l'autre approche est de déclarer le <literal>Fils</literal> comme "
-"un <literal>&lt;composite-element&gt;</literal>). Il est évident que le sens "
-"de l'association un vers plusieurs (dans Hibernate) est bien moins proche du "
-"sens habituel d'une relation père/fils que ne l'est celui d'un élément "
-"cmposite. Nous allons vous expliquer comment utiliser une association "
-"<emphasis>un vers plusieurs bidirectionnelle avec cascade</emphasis> afin de "
-"modéliser efficacement et élégamment une relation père/fils, ce n'est "
-"vraiment pas difficile !"
+"un <literal>&lt;composite-element&gt;</literal>). On constate que la "
+"sémantique par défaut de l'association un-à-plusieurs (dans Hibernate) est "
+"bien moins proche du sens habituel d'une relation père/fils que celle d'un "
+"mappage d'élément composite. Nous allons vous expliquer comment utiliser une "
+"association <emphasis>un-à-plusieurs bidirectionnelle avec cascade</"
+"emphasis> afin de modéliser efficacement et élégamment une relation père/"
+"fils."
 
 #. Tag: title
-#: example_parentchild.xml:45
 #, no-c-format
 msgid "A note about collections"
 msgstr "Une note à propos des collections"
 
 #. Tag: para
-#: example_parentchild.xml:47
-#, fuzzy, no-c-format
+#, 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 ""
 "Les collections Hibernate sont considérées comme étant une partie logique de "
-"l'entité dans laquelle elles sont contenues ; jamais des entités qu'elle "
-"contient. C'est une distinction crutiale ! Les conséquences sont les "
-"suivantes :"
+"leur entité propriétaire, jamais des entités qu'elle contient. C'est une "
+"distinction cruciale ! Les conséquences sont les suivantes : "
 
 #. Tag: para
-#: example_parentchild.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When you remove/add an object from/to a collection, the version number of "
 "the collection owner is incremented."
 msgstr ""
 "Quand nous ajoutons / retirons un objet d'une collection, le numéro de "
-"version du propriétaire de la collection est incrémenté."
+"version du propriétaire de la collection est incrémenté. "
 
 #. Tag: para
-#: example_parentchild.xml:60
-#, fuzzy, no-c-format
+#, 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 "
@@ -90,14 +89,13 @@
 "persistent."
 msgstr ""
 "Si un objet qui a été enlevé d'une collection est une instance de type "
-"valeur (ex : élément composite), cet objet cessera d'être persistant et son "
-"état sera complètement effacé de la base de données. Par ailleurs, ajouter "
-"une instance de type valeur dans une collection aura pour conséquence que "
-"son état sera immédiatement persistant."
+"valeur (par ex : élément composite), cet objet cessera d'être persistant et "
+"son état sera complètement effacé de la base de données. Par ailleurs, "
+"ajouter une instance de type valeur dans une collection entraînera que son "
+"état sera immédiatement persistant. "
 
 #. Tag: para
-#: example_parentchild.xml:68
-#, fuzzy, no-c-format
+#, 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 "
@@ -105,16 +103,15 @@
 "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 ""
-"Si une entité est enlevée d'une collection (association un-vers-plusieurs ou "
-"plusieurs-vers-plusieurs), par défaut, elle ne sera pas effacée. Ce "
-"comportement est complètement logique - une modification de l'un des états "
-"internes d'une entité ne doit pas causer la disparition de l'entité "
-"associée ! De même, l'ajout d'une entité dans une collection n'engendre pas, "
-"par défaut, la persistance de cette entité."
+"Si une entité est enlevée d'une collection (association un-à-plusieurs ou "
+"plusieurs-à-plusieurs), elle ne sera pas effacée par défaut. Ce comportement "
+"est complètement logique - une modification de l'un des états internes d'une "
+"autre entité ne doit pas causer la disparition de l'entité associée. De "
+"même, l'ajout d'une entité dans une collection n'engendre pas, par défaut, "
+"la persistance de cette entité."
 
 #. Tag: para
-#: example_parentchild.xml:78
-#, fuzzy, no-c-format
+#, 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 "
@@ -123,62 +120,36 @@
 "bound to the life cycle of the parent."
 msgstr ""
 "Le comportement par défaut est donc que l'ajout d'une entité dans une "
-"collection créé simplement le lien entre les deux entités, et qu'effacer une "
-"entité supprime ce lien. C'est le comportement le plus approprié dans la "
+"collection crée simplement le lien entre les deux entités, alors qu'effacer "
+"une entité supprime ce lien. C'est le comportement le plus approprié dans la "
 "plupart des cas. Ce comportement n'est cependant pas approprié lorsque la "
-"vie du fils est liée au cycle de vie du père."
+"vie du fils est liée au cycle de vie du père. "
 
 #. Tag: title
-#: example_parentchild.xml:88
 #, no-c-format
 msgid "Bidirectional one-to-many"
-msgstr "un-vers-plusieurs bidirectionnel"
+msgstr "Un-à-plusieurs bidirectionnel"
 
 #. Tag: para
-#: example_parentchild.xml:90
 #, no-c-format
 msgid ""
 "Suppose we start with a simple <literal>&lt;one-to-many&gt;</literal> "
 "association from <literal>Parent</literal> to <literal>Child</literal>."
 msgstr ""
 "Supposons que nous ayons une simple association <literal>&lt;one-to-many&gt;"
-"</literal> de <literal>Parent</literal> vers <literal>Child</literal>."
+"</literal> de <literal>Parent</literal> à <literal>Child</literal>."
 
-#. Tag: programlisting
-#: example_parentchild.xml:95
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:97
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "If we were to execute the following code:"
-msgstr "Si nous executions le code suivant"
+msgstr "Si nous exécutions le code suivant :"
 
-#. Tag: programlisting
-#: example_parentchild.xml:101
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = .....;\n"
-"Child c = new Child();\n"
-"p.getChildren().add(c);\n"
-"session.save(c);\n"
-"session.flush();]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:103
 #, no-c-format
 msgid "Hibernate would issue two SQL statements:"
-msgstr "Hibernate exécuterait deux ordres SQL:"
+msgstr "Hibernate exécuterait deux ordres SQL :"
 
 #. Tag: para
-#: example_parentchild.xml:109
 #, no-c-format
 msgid ""
 "an <literal>INSERT</literal> to create the record for <literal>c</literal>"
@@ -187,7 +158,6 @@
 "literal>"
 
 #. Tag: para
-#: example_parentchild.xml:112
 #, no-c-format
 msgid ""
 "an <literal>UPDATE</literal> to create the link from <literal>p</literal> to "
@@ -197,38 +167,25 @@
 "<literal>c</literal>"
 
 #. Tag: para
-#: example_parentchild.xml:119
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is not only inefficient, but also violates any <literal>NOT NULL</"
 "literal> constraint on the <literal>parent_id</literal> column. You can fix "
 "the nullability constraint violation by specifying <literal>not-null=\"true"
 "\"</literal> in the collection mapping:"
 msgstr ""
-"Ceci est non seuleument inefficace, mais viole aussi toute contrainte "
+"Ceci est non seulement inefficace, mais viole aussi toute contrainte "
 "<literal>NOT NULL</literal> sur la colonne <literal>parent_id</literal>. "
 "Nous pouvons réparer la contrainte de nullité en spécifiant <literal>not-"
-"null=\"true\"</literal> dans le mapping de la collection :"
+"null=\"true\"</literal> dans le mappage de la collection : "
 
-#. Tag: programlisting
-#: example_parentchild.xml:125
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\">\n"
-"    <key column=\"parent_id\" not-null=\"true\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:127
 #, no-c-format
 msgid "However, this is not the recommended solution."
 msgstr "Cependant ce n'est pas la solution recommandée."
 
 #. Tag: para
-#: example_parentchild.xml:130
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The underlying cause of this behavior is that the link (the foreign key "
 "<literal>parent_id</literal>) from <literal>p</literal> to <literal>c</"
@@ -240,30 +197,20 @@
 "<literal>parent_id</literal>) de <literal>p</literal> vers <literal>c</"
 "literal> n'est pas considérée comme faisant partie de l'état de l'objet "
 "<literal>Child</literal> et n'est donc pas créé par l'<literal>INSERT</"
-"literal>. La solution est donc que ce lien fasse partie du mapping de "
-"<literal>Child</literal>."
+"literal>. La solution est donc que ce lien fasse partie du mappage de "
+"<literal>Child</literal>. "
 
-#. Tag: programlisting
-#: example_parentchild.xml:137
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"parent\" column=\"parent_id\" not-null=\"true\"/"
-">]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:139
-#, fuzzy, no-c-format
-msgid ""
 "You also need to add the <literal>parent</literal> property to the "
 "<literal>Child</literal> class."
 msgstr ""
-"(Nous avons aussi besoin d'ajouter la propriété <literal>parent</literal> "
-"dans la classe <literal>Child</literal>)."
+"Nous avons aussi besoin d'ajouter la propriété <literal>parent</literal> "
+"dans la classe <literal>Child</literal>."
 
 #. Tag: para
-#: example_parentchild.xml:143
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now that the <literal>Child</literal> entity is managing the state of the "
 "link, we tell the collection not to update the link. We use the "
@@ -271,165 +218,72 @@
 msgstr ""
 "Maintenant que l'état du lien est géré par l'entité <literal>Child</"
 "literal>, nous spécifions à la collection de ne pas mettre à jour le lien. "
-"Nous utilisons l'attribut <literal>inverse</literal>."
+"Nous utilisons l'attribut <literal>inverse</literal> pour faire cela :"
 
-#. Tag: programlisting
-#: example_parentchild.xml:148
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:150
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The following code would be used to add a new <literal>Child</literal>:"
 msgstr ""
 "Le code suivant serait utilisé pour ajouter un nouveau <literal>Child</"
-"literal>"
+"literal> :"
 
-#. Tag: programlisting
-#: example_parentchild.xml:154
-#, no-c-format
-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 ""
-
 #. Tag: para
-#: example_parentchild.xml:156
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Only one SQL <literal>INSERT</literal> would now be issued."
-msgstr "Maintenant, seul un <literal>INSERT</literal> SQL est nécessaire !"
+msgstr "Maintenant, seul un SQL <literal>INSERT</literal> est nécessaire."
 
 #. Tag: para
-#: example_parentchild.xml:160
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You could also create an <literal>addChild()</literal> method of "
 "<literal>Parent</literal>."
 msgstr ""
-"Pour alléger encore un peu les choses, nous devrions créer une méthode "
-"<literal>addChild()</literal> dans <literal>Parent</literal>."
+"Pour alléger encore un peu les choses, nous créerons une méthode "
+"<literal>addChild()</literal> de <literal>Parent</literal>. "
 
-#. Tag: programlisting
-#: example_parentchild.xml:165
-#, no-c-format
-msgid ""
-"<![CDATA[public void addChild(Child c) {\n"
-"    c.setParent(this);\n"
-"    children.add(c);\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The code to add a <literal>Child</literal> looks like this:"
-msgstr "Le code d'ajout d'un <literal>Child</literal> serait alors"
+msgstr "Le code d'ajout d'un <literal>Child</literal> serait alors :"
 
-#. Tag: programlisting
-#: example_parentchild.xml:171
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: example_parentchild.xml:176
 #, no-c-format
 msgid "Cascading life cycle"
-msgstr "Cycle de vie en cascade"
+msgstr "Cycle de vie en cascade "
 
 #. Tag: para
-#: example_parentchild.xml:178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can address the frustrations of the explicit call to <literal>save()</"
 "literal> by using cascades."
 msgstr ""
 "L'appel explicite de <literal>save()</literal> est un peu fastidieux. Nous "
-"pouvons simplifier cela en utilisant les cascades."
+"pouvons simplifier cela en utilisant les cascades. "
 
-#. Tag: programlisting
-#: example_parentchild.xml:183
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:185
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This simplifies the code above to:"
-msgstr "Simplifie le code précédent en"
+msgstr "Cela simplifie le code précédent en :"
 
-#. Tag: programlisting
-#: example_parentchild.xml:189
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-"Child c = new Child();\n"
-"p.addChild(c);\n"
-"session.flush();]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:191
-#, fuzzy, no-c-format
-msgid ""
 "Similarly, we do not need to iterate over the children when saving or "
 "deleting a <literal>Parent</literal>. The following removes <literal>p</"
 "literal> and all its children from the database."
 msgstr ""
 "De la même manière, nous n'avons pas à itérer sur les fils lorsque nous "
-"sauvons ou effacons un <literal>Parent</literal>. Le code suivant efface "
-"<literal>p</literal> et tous ses fils de la base de données."
+"sauvons ou effaçons un <literal>Parent</literal>. Le code suivant efface "
+"<literal>p</literal> et tous ses fils de la base de données. "
 
-#. Tag: programlisting
-#: example_parentchild.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-"session.delete(p);\n"
-"session.flush();]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:198
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "However, the following code:"
-msgstr "Par contre, ce code"
+msgstr "Par contre, ce code :"
 
-#. Tag: programlisting
-#: example_parentchild.xml:202
+#. Tag: para
 #, no-c-format
 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 ""
-
-#. Tag: para
-#: example_parentchild.xml:204
-#, fuzzy, no-c-format
-msgid ""
 "will not remove <literal>c</literal> from the database. In this case, it "
 "will only remove the link to <literal>p</literal> and cause a <literal>NOT "
 "NULL</literal> constraint violation. You need to explicitly <literal>delete()"
@@ -439,69 +293,44 @@
 "seulement le lien vers <literal>p</literal> (et causera une violation de "
 "contrainte <literal>NOT NULL</literal>, dans ce cas). Vous devez "
 "explicitement utiliser <literal>delete()</literal> sur <literal>Child</"
-"literal>."
+"literal>. "
 
-#. Tag: programlisting
-#: example_parentchild.xml:210
+#. Tag: para
 #, no-c-format
 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 ""
-
-#. Tag: para
-#: example_parentchild.xml:212
-#, fuzzy, no-c-format
-msgid ""
 "In our case, a <literal>Child</literal> cannot exist without its parent. So "
 "if we remove a <literal>Child</literal> from the collection, we do want it "
 "to be deleted. To do this, we must use <literal>cascade=\"all-delete-orphan"
 "\"</literal>."
 msgstr ""
 "Dans notre cas, un <literal>Child</literal> ne peut pas vraiment exister "
-"sans son père. Si nous effacons un <literal>Child</literal> de la "
+"sans son père. Si nous effaçons un <literal>Child</literal> de la "
 "collection, nous voulons vraiment qu'il soit effacé. Pour cela, nous devons "
-"utiliser <literal>cascade=\"all-delete-orphan\"</literal>."
+"utiliser <literal>cascade=\"all-delete-orphan\"</literal>. "
 
-#. Tag: programlisting
-#: example_parentchild.xml:218
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all-delete-orphan"
-"\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:220
-#, fuzzy, no-c-format
-msgid ""
 "Even though the collection mapping specifies <literal>inverse=\"true\"</"
 "literal>, cascades are still processed by iterating the collection elements. "
 "If you need an object be saved, deleted or updated by cascade, you must add "
 "it to the collection. It is not enough to simply call <literal>setParent()</"
 "literal>."
 msgstr ""
-"A noter : même si le mapping de la collection spécifie <literal>inverse="
+"À noter : même si le mappage de la collection spécifie <literal>inverse="
 "\"true\"</literal>, les cascades sont toujours assurées par l'itération sur "
 "les éléments de la collection. Donc, si vous avez besoin qu'un objet soit "
 "enregistré, effacé ou mis à jour par cascade, vous devez l'ajouter dans la "
-"colleciton. Il ne suffit pas d'appeler explicitement <literal>setParent()</"
+"collection. Il ne suffit pas d'appeler explicitement <literal>setParent()</"
 "literal>."
 
 #. Tag: title
-#: example_parentchild.xml:230
 #, no-c-format
 msgid "Cascades and <literal>unsaved-value</literal>"
-msgstr "Cascades et <literal>unsaved-value</literal>"
+msgstr ""
+"Cascades et <literal>unsaved-value</literal> (valeurs non sauvegardées)"
 
 #. Tag: para
-#: example_parentchild.xml:232
 #, fuzzy, no-c-format
 msgid ""
 "Suppose we loaded up a <literal>Parent</literal> in one <literal>Session</"
@@ -514,51 +343,37 @@
 "literal> have generated identifier properties of type <literal>Long</"
 "literal>. Hibernate will use the identifier and version/timestamp property "
 "value to determine which of the children are new. (See <xref linkend="
-"\"objectstate-saveorupdate\"/>.) <emphasis>In Hibernate3, it is no longer "
+"\"objectstate-saveorupdate\" />.) <emphasis>In Hibernate3, it is no longer "
 "necessary to specify an <literal>unsaved-value</literal> explicitly.</"
 "emphasis>"
 msgstr ""
 "Supposons que nous ayons chargé un <literal>Parent</literal> dans une "
 "<literal>Session</literal>, que nous l'ayons ensuite modifié et que voulions "
-"persiter ces modifications dans une nouvelle session en appelant "
+"persister ces modifications dans une nouvelle session en appelant "
 "<literal>update()</literal>. Le <literal>Parent</literal> contiendra une "
 "collection de fils et, puisque la cascade est activée, Hibernate a besoin de "
-"savoir quels fils viennent d'être instanciés et quels fils proviennent de la "
-"base de données. Supposons aussi que <literal>Parent</literal> et "
-"<literal>Child</literal> ont tous deux des identifiants du type "
-"<literal>Long</literal>. Hibernate utilisera la propriété de l'identifiant "
-"et la propriété de la version/horodatage pour déterminer quels fils sont "
-"nouveaux (vous pouvez aussi utiliser la propriété version ou timestamp, voir "
-"<xref linkend=\"manipulatingdata-updating-detached\"/>). <emphasis>Dans "
-"Hibernate3, il n'est plus nécessaire de spécifier une <literal>unsaved-"
-"value</literal> explicitement.</emphasis>"
+"savoir quels fils viennent d'être instanciés et quels fils représentent des "
+"lignes existantes dans la base de données. Supposons aussi que "
+"<literal>Parent</literal> et <literal>Child</literal> ont tous deux des "
+"identifiants du type <literal>Long</literal>. Hibernate utilisera la "
+"propriété de l'identifiant et la propriété de la version/horodatage pour "
+"déterminer quels fils sont nouveaux (vous pouvez aussi utiliser la propriété "
+"version ou timestamp, consultez <xref linkend=\"objectstate-saveorupdate\" /"
+">.) <emphasis>Dans Hibernate3, il n'est plus nécessaire de spécifier une "
+"<literal>unsaved-value</literal> explicitement.</emphasis> "
 
 #. Tag: para
-#: example_parentchild.xml:244
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following code will update <literal>parent</literal> and <literal>child</"
 "literal> and insert <literal>newChild</literal>:"
 msgstr ""
 "Le code suivant mettra à jour <literal>parent</literal> et <literal>child</"
-"literal> et insérera <literal>newChild</literal>."
+"literal> et insérera <literal>newChild</literal>. "
 
-#. Tag: programlisting
-#: example_parentchild.xml:249
+#. Tag: para
 #, no-c-format
 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 ""
-
-#. Tag: para
-#: example_parentchild.xml:251
-#, fuzzy, 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 "
@@ -569,22 +384,21 @@
 msgstr ""
 "Ceci est très bien pour des identifiants générés, mais qu'en est-il des "
 "identifiants assignés et des identifiants composés ? C'est plus difficile, "
-"puisqu'Hibernate ne peut pas utiliser la propriété de l'identifiant pour "
-"distinguer un objet nouvellement instancié (avec un identifiant assigné par "
-"l'utilisateur) d'un objet chargé dans une session précédente. Dans ce cas, "
-"Hibernate utilisera soit la propriété de version ou d'horodatage, soit "
-"effectuera vraiment une requête au cache de second niveau, soit, dans le "
-"pire des cas, à la base de données, pour voir si la ligne existe."
+"puisque Hibernate ne peut pas utiliser la propriété de l'identifiant pour "
+"distinguer entre un objet nouvellement instancié (avec un identifiant "
+"assigné par l'utilisateur) et un objet chargé dans une session précédente. "
+"Dans ce cas, Hibernate utilisera soit la propriété de version ou "
+"d'horodatage, soit effectuera vraiment une requête au cache de second "
+"niveau, soit, dans le pire des cas, à la base de données, pour voir si la "
+"ligne existe. "
 
 #. Tag: title
-#: example_parentchild.xml:263
 #, no-c-format
 msgid "Conclusion"
 msgstr "Conclusion"
 
 #. Tag: para
-#: example_parentchild.xml:265
-#, fuzzy, no-c-format
+#, 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 "
@@ -593,11 +407,10 @@
 "Il y a quelques principes à maîtriser dans ce chapitre et tout cela peut "
 "paraître déroutant la première fois. Cependant, dans la pratique, tout "
 "fonctionne parfaitement. La plupart des applications Hibernate utilisent le "
-"pattern père / fils."
+"modèle père / fils. "
 
 #. Tag: para
-#: example_parentchild.xml:270
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We mentioned an alternative in the first paragraph. None of the above issues "
 "exist in the case of <literal>&lt;composite-element&gt;</literal> mappings, "
@@ -607,9 +420,9 @@
 "of any entity other than the unique parent."
 msgstr ""
 "Nous avons évoqué une alternative dans le premier paragraphe. Aucun des "
-"points traités précédemment n'existe dans le cas d'un mapping <literal>&lt;"
+"points traités précédemment n'existe dans le cas de mappings <literal>&lt;"
 "composite-element&gt;</literal> qui possède exactement la sémantique d'une "
 "relation père / fils. Malheureusement, il y a deux grandes limitations pour "
-"les classes éléments composites : les éléments composites ne peuvent "
+"les classes d'éléments composites : les éléments composites ne peuvent "
 "contenir de collections, et ils ne peuvent être les fils d'entités autres "
-"que l'unique parent."
+"que l'unique parent. "

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/example_weblog.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/example_weblog.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/example_weblog.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,484 +1,863 @@
+# translation of example_weblog.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: example_weblog\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-10-30 13:49+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: example_weblog.xml:29
 #, no-c-format
 msgid "Example: Weblog Application"
 msgstr "Exemple : application Weblog"
 
 #. Tag: title
-#: example_weblog.xml:32
 #, no-c-format
 msgid "Persistent Classes"
 msgstr "Classes persistantes"
 
 #. Tag: para
-#: example_weblog.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The persistent classes here represent a weblog and an item posted in a "
 "weblog. They are to be modelled as a standard parent/child relationship, but "
 "we will use an ordered bag, instead of a set:"
 msgstr ""
-"Les classes persistantes representent un weblog, et un article posté dans un "
+"Les classes persistantes représentent un weblog, et un article posté dans un "
 "weblog. Il seront modélisés comme une relation père/fils standard, mais nous "
-"allons utiliser un \"bag\" trié au lieu d'un set."
+"allons utiliser un sac trié au lieu d'un set :"
 
-#. Tag: programlisting
-#: example_weblog.xml:40
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.util.List;\n"
-"\n"
-"public class Blog {\n"
-"    private Long _id;\n"
-"    private String _name;\n"
-"    private List _items;\n"
-"\n"
-"    public Long getId() {\n"
-"        return _id;\n"
-"    }\n"
-"    public List getItems() {\n"
-"        return _items;\n"
-"    }\n"
-"    public String getName() {\n"
-"        return _name;\n"
-"    }\n"
-"    public void setId(Long long1) {\n"
-"        _id = long1;\n"
-"    }\n"
-"    public void setItems(List list) {\n"
-"        _items = list;\n"
-"    }\n"
-"    public void setName(String string) {\n"
-"        _name = string;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: example_weblog.xml:42
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.text.DateFormat;\n"
-"import java.util.Calendar;\n"
-"\n"
-"public class BlogItem {\n"
-"    private Long _id;\n"
-"    private Calendar _datetime;\n"
-"    private String _text;\n"
-"    private String _title;\n"
-"    private Blog _blog;\n"
-"\n"
-"    public Blog getBlog() {\n"
-"        return _blog;\n"
-"    }\n"
-"    public Calendar getDatetime() {\n"
-"        return _datetime;\n"
-"    }\n"
-"    public Long getId() {\n"
-"        return _id;\n"
-"    }\n"
-"    public String getText() {\n"
-"        return _text;\n"
-"    }\n"
-"    public String getTitle() {\n"
-"        return _title;\n"
-"    }\n"
-"    public void setBlog(Blog blog) {\n"
-"        _blog = blog;\n"
-"    }\n"
-"    public void setDatetime(Calendar calendar) {\n"
-"        _datetime = calendar;\n"
-"    }\n"
-"    public void setId(Long long1) {\n"
-"        _id = long1;\n"
-"    }\n"
-"    public void setText(String string) {\n"
-"        _text = string;\n"
-"    }\n"
-"    public void setTitle(String string) {\n"
-"        _title = string;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: example_weblog.xml:47
 #, no-c-format
 msgid "Hibernate Mappings"
-msgstr "Mappings Hibernate"
+msgstr "Mappages Hibernate"
 
 #. Tag: para
-#: example_weblog.xml:49
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The XML mappings are now straightforward. For example:"
-msgstr "Le mapping XML doit maintenant être relativement simple à vos yeux."
-
-#. Tag: programlisting
-#: example_weblog.xml:53
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"    <class\n"
-"        name=\"Blog\"\n"
-"        table=\"BLOGS\">\n"
-"\n"
-"        <id\n"
-"            name=\"id\"\n"
-"            column=\"BLOG_ID\">\n"
-"\n"
-"            <generator class=\"native\"/>\n"
-"\n"
-"        </id>\n"
-"\n"
-"        <property\n"
-"            name=\"name\"\n"
-"            column=\"NAME\"\n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"\n"
-"        <bag\n"
-"            name=\"items\"\n"
-"            inverse=\"true\"\n"
-"            order-by=\"DATE_TIME\"\n"
-"            cascade=\"all\">\n"
-"\n"
-"            <key column=\"BLOG_ID\"/>\n"
-"            <one-to-many class=\"BlogItem\"/>\n"
-"\n"
-"        </bag>\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
 msgstr ""
+"Le mappage XML doit maintenant être relativement simple à vos yeux. Par "
+"exemple :"
 
-#. Tag: programlisting
-#: example_weblog.xml:55
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"    <class\n"
-"        name=\"BlogItem\"\n"
-"        table=\"BLOG_ITEMS\"\n"
-"        dynamic-update=\"true\">\n"
-"\n"
-"        <id\n"
-"            name=\"id\"\n"
-"            column=\"BLOG_ITEM_ID\">\n"
-"\n"
-"            <generator class=\"native\"/>\n"
-"\n"
-"        </id>\n"
-"\n"
-"        <property\n"
-"            name=\"title\"\n"
-"            column=\"TITLE\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <property\n"
-"            name=\"text\"\n"
-"            column=\"TEXT\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <property\n"
-"            name=\"datetime\"\n"
-"            column=\"DATE_TIME\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <many-to-one\n"
-"            name=\"blog\"\n"
-"            column=\"BLOG_ID\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_weblog.xml:60
 #, no-c-format
 msgid "Hibernate Code"
 msgstr "Code Hibernate"
 
 #. Tag: para
-#: example_weblog.xml:62
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following class demonstrates some of the kinds of things we can do with "
 "these classes using Hibernate:"
 msgstr ""
-"La classe suivante montre quelques utilisations que nous pouvons faire de "
-"ces classes."
+"La classe suivante montre quelques utilisations de ces classes avec "
+"Hibernate :"
 
-#. Tag: programlisting
-#: example_weblog.xml:67
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.util.ArrayList;\n"
-"import java.util.Calendar;\n"
-"import java.util.Iterator;\n"
-"import java.util.List;\n"
-"\n"
-"import org.hibernate.HibernateException;\n"
-"import org.hibernate.Query;\n"
-"import org.hibernate.Session;\n"
-"import org.hibernate.SessionFactory;\n"
-"import org.hibernate.Transaction;\n"
-"import org.hibernate.cfg.Configuration;\n"
-"import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
-"\n"
-"public class BlogMain {\n"
-"    \n"
-"    private SessionFactory _sessions;\n"
-"    \n"
-"    public void configure() throws HibernateException {\n"
-"        _sessions = new Configuration()\n"
-"            .addClass(Blog.class)\n"
-"            .addClass(BlogItem.class)\n"
-"            .buildSessionFactory();\n"
-"    }\n"
-"    \n"
-"    public void exportTables() throws HibernateException {\n"
-"        Configuration cfg = new Configuration()\n"
-"            .addClass(Blog.class)\n"
-"            .addClass(BlogItem.class);\n"
-"        new SchemaExport(cfg).create(true, true);\n"
-"    }\n"
-"    \n"
-"    public Blog createBlog(String name) throws HibernateException {\n"
-"        \n"
-"        Blog blog = new Blog();\n"
-"        blog.setName(name);\n"
-"        blog.setItems( new ArrayList() );\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.persist(blog);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return blog;\n"
-"    }\n"
-"    \n"
-"    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
-"                        throws HibernateException {\n"
-"        \n"
-"        BlogItem item = new BlogItem();\n"
-"        item.setTitle(title);\n"
-"        item.setText(text);\n"
-"        item.setBlog(blog);\n"
-"        item.setDatetime( Calendar.getInstance() );\n"
-"        blog.getItems().add(item);\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.update(blog);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return item;\n"
-"    }\n"
-"    \n"
-"    public BlogItem createBlogItem(Long blogid, String title, String text)\n"
-"                        throws HibernateException {\n"
-"        \n"
-"        BlogItem item = new BlogItem();\n"
-"        item.setTitle(title);\n"
-"        item.setText(text);\n"
-"        item.setDatetime( Calendar.getInstance() );\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
-"            item.setBlog(blog);\n"
-"            blog.getItems().add(item);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return item;\n"
-"    }\n"
-"    \n"
-"    public void updateBlogItem(BlogItem item, String text)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        item.setText(text);\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.update(item);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"    }\n"
-"    \n"
-"    public void updateBlogItem(Long itemid, String text)\n"
-"                    throws HibernateException {\n"
-"    \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            BlogItem item = (BlogItem) session.load(BlogItem.class, "
-"itemid);\n"
-"            item.setText(text);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"    }\n"
-"    \n"
-"    public List listAllBlogNamesAndItemCounts(int max)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        List result = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"select blog.id, blog.name, count(blogItem) \" +\n"
-"                \"from Blog as blog \" +\n"
-"                \"left outer join blog.items as blogItem \" +\n"
-"                \"group by blog.name, blog.id \" +\n"
-"                \"order by max(blogItem.datetime)\"\n"
-"            );\n"
-"            q.setMaxResults(max);\n"
-"            result = q.list();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return result;\n"
-"    }\n"
-"    \n"
-"    public Blog getBlogAndAllItems(Long blogid)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        Blog blog = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"from Blog as blog \" +\n"
-"                \"left outer join fetch blog.items \" +\n"
-"                \"where blog.id = :blogid\"\n"
-"            );\n"
-"            q.setParameter(\"blogid\", blogid);\n"
-"            blog  = (Blog) q.uniqueResult();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return blog;\n"
-"    }\n"
-"    \n"
-"    public List listBlogsAndRecentItems() throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        List result = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"from Blog as blog \" +\n"
-"                \"inner join blog.items as blogItem \" +\n"
-"                \"where blogItem.datetime > :minDate\"\n"
-"            );\n"
-"\n"
-"            Calendar cal = Calendar.getInstance();\n"
-"            cal.roll(Calendar.MONTH, false);\n"
-"            q.setCalendar(\"minDate\", cal);\n"
-"            \n"
-"            result = q.list();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return result;\n"
-"    }\n"
-"}]]>"
-msgstr ""
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "public class Blog {\n"
+#~ "    private Long _id;\n"
+#~ "    private String _name;\n"
+#~ "    private List _items;\n"
+#~ "\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public List getItems() {\n"
+#~ "        return _items;\n"
+#~ "    }\n"
+#~ "    public String getName() {\n"
+#~ "        return _name;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setItems(List list) {\n"
+#~ "        _items = list;\n"
+#~ "    }\n"
+#~ "    public void setName(String string) {\n"
+#~ "        _name = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "public class Blog {\n"
+#~ "    private Long _id;\n"
+#~ "    private String _name;\n"
+#~ "    private List _items;\n"
+#~ "\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public List getItems() {\n"
+#~ "        return _items;\n"
+#~ "    }\n"
+#~ "    public String getName() {\n"
+#~ "        return _name;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setItems(List list) {\n"
+#~ "        _items = list;\n"
+#~ "    }\n"
+#~ "    public void setName(String string) {\n"
+#~ "        _name = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.text.DateFormat;\n"
+#~ "import java.util.Calendar;\n"
+#~ "\n"
+#~ "public class BlogItem {\n"
+#~ "    private Long _id;\n"
+#~ "    private Calendar _datetime;\n"
+#~ "    private String _text;\n"
+#~ "    private String _title;\n"
+#~ "    private Blog _blog;\n"
+#~ "\n"
+#~ "    public Blog getBlog() {\n"
+#~ "        return _blog;\n"
+#~ "    }\n"
+#~ "    public Calendar getDatetime() {\n"
+#~ "        return _datetime;\n"
+#~ "    }\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public String getText() {\n"
+#~ "        return _text;\n"
+#~ "    }\n"
+#~ "    public String getTitle() {\n"
+#~ "        return _title;\n"
+#~ "    }\n"
+#~ "    public void setBlog(Blog blog) {\n"
+#~ "        _blog = blog;\n"
+#~ "    }\n"
+#~ "    public void setDatetime(Calendar calendar) {\n"
+#~ "        _datetime = calendar;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setText(String string) {\n"
+#~ "        _text = string;\n"
+#~ "    }\n"
+#~ "    public void setTitle(String string) {\n"
+#~ "        _title = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.text.DateFormat;\n"
+#~ "import java.util.Calendar;\n"
+#~ "\n"
+#~ "public class BlogItem {\n"
+#~ "    private Long _id;\n"
+#~ "    private Calendar _datetime;\n"
+#~ "    private String _text;\n"
+#~ "    private String _title;\n"
+#~ "    private Blog _blog;\n"
+#~ "\n"
+#~ "    public Blog getBlog() {\n"
+#~ "        return _blog;\n"
+#~ "    }\n"
+#~ "    public Calendar getDatetime() {\n"
+#~ "        return _datetime;\n"
+#~ "    }\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public String getText() {\n"
+#~ "        return _text;\n"
+#~ "    }\n"
+#~ "    public String getTitle() {\n"
+#~ "        return _title;\n"
+#~ "    }\n"
+#~ "    public void setBlog(Blog blog) {\n"
+#~ "        _blog = blog;\n"
+#~ "    }\n"
+#~ "    public void setDatetime(Calendar calendar) {\n"
+#~ "        _datetime = calendar;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setText(String string) {\n"
+#~ "        _text = string;\n"
+#~ "    }\n"
+#~ "    public void setTitle(String string) {\n"
+#~ "        _title = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"Blog\"\n"
+#~ "        table=\"BLOGS\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"name\"\n"
+#~ "            column=\"NAME\"\n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "\n"
+#~ "        <bag\n"
+#~ "            name=\"items\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            order-by=\"DATE_TIME\"\n"
+#~ "            cascade=\"all\">\n"
+#~ "\n"
+#~ "            <key column=\"BLOG_ID\"/>\n"
+#~ "            <one-to-many class=\"BlogItem\"/>\n"
+#~ "\n"
+#~ "        </bag>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"Blog\"\n"
+#~ "        table=\"BLOGS\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"name\"\n"
+#~ "            column=\"NAME\"\n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "\n"
+#~ "        <bag\n"
+#~ "            name=\"items\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            order-by=\"DATE_TIME\"\n"
+#~ "            cascade=\"all\">\n"
+#~ "\n"
+#~ "            <key column=\"BLOG_ID\"/>\n"
+#~ "            <one-to-many class=\"BlogItem\"/>\n"
+#~ "\n"
+#~ "        </bag>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"BlogItem\"\n"
+#~ "        table=\"BLOG_ITEMS\"\n"
+#~ "        dynamic-update=\"true\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ITEM_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"title\"\n"
+#~ "            column=\"TITLE\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"text\"\n"
+#~ "            column=\"TEXT\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"datetime\"\n"
+#~ "            column=\"DATE_TIME\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <many-to-one\n"
+#~ "            name=\"blog\"\n"
+#~ "            column=\"BLOG_ID\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"BlogItem\"\n"
+#~ "        table=\"BLOG_ITEMS\"\n"
+#~ "        dynamic-update=\"true\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ITEM_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"title\"\n"
+#~ "            column=\"TITLE\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"text\"\n"
+#~ "            column=\"TEXT\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"datetime\"\n"
+#~ "            column=\"DATE_TIME\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <many-to-one\n"
+#~ "            name=\"blog\"\n"
+#~ "            column=\"BLOG_ID\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.ArrayList;\n"
+#~ "import java.util.Calendar;\n"
+#~ "import java.util.Iterator;\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "import org.hibernate.HibernateException;\n"
+#~ "import org.hibernate.Query;\n"
+#~ "import org.hibernate.Session;\n"
+#~ "import org.hibernate.SessionFactory;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.cfg.Configuration;\n"
+#~ "import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
+#~ "\n"
+#~ "public class BlogMain {\n"
+#~ "    \n"
+#~ "    private SessionFactory _sessions;\n"
+#~ "    \n"
+#~ "    public void configure() throws HibernateException {\n"
+#~ "        _sessions = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class)\n"
+#~ "            .buildSessionFactory();\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void exportTables() throws HibernateException {\n"
+#~ "        Configuration cfg = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class);\n"
+#~ "        new SchemaExport(cfg).create(true, true);\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog createBlog(String name) throws HibernateException {\n"
+#~ "        \n"
+#~ "        Blog blog = new Blog();\n"
+#~ "        blog.setName(name);\n"
+#~ "        blog.setItems( new ArrayList() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.persist(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setBlog(blog);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        blog.getItems().add(item);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Long blogid, String title, String "
+#~ "text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
+#~ "            item.setBlog(blog);\n"
+#~ "            blog.getItems().add(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(BlogItem item, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        item.setText(text);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(Long itemid, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "    \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            BlogItem item = (BlogItem) session.load(BlogItem.class, "
+#~ "itemid);\n"
+#~ "            item.setText(text);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listAllBlogNamesAndItemCounts(int max)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"select blog.id, blog.name, count(blogItem) \" +\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join blog.items as blogItem \" +\n"
+#~ "                \"group by blog.name, blog.id \" +\n"
+#~ "                \"order by max(blogItem.datetime)\"\n"
+#~ "            );\n"
+#~ "            q.setMaxResults(max);\n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog getBlogAndAllItems(Long blogid)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        Blog blog = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join fetch blog.items \" +\n"
+#~ "                \"where blog.id = :blogid\"\n"
+#~ "            );\n"
+#~ "            q.setParameter(\"blogid\", blogid);\n"
+#~ "            blog  = (Blog) q.uniqueResult();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listBlogsAndRecentItems() throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"inner join blog.items as blogItem \" +\n"
+#~ "                \"where blogItem.datetime > :minDate\"\n"
+#~ "            );\n"
+#~ "\n"
+#~ "            Calendar cal = Calendar.getInstance();\n"
+#~ "            cal.roll(Calendar.MONTH, false);\n"
+#~ "            q.setCalendar(\"minDate\", cal);\n"
+#~ "            \n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.ArrayList;\n"
+#~ "import java.util.Calendar;\n"
+#~ "import java.util.Iterator;\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "import org.hibernate.HibernateException;\n"
+#~ "import org.hibernate.Query;\n"
+#~ "import org.hibernate.Session;\n"
+#~ "import org.hibernate.SessionFactory;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.cfg.Configuration;\n"
+#~ "import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
+#~ "\n"
+#~ "public class BlogMain {\n"
+#~ "    \n"
+#~ "    private SessionFactory _sessions;\n"
+#~ "    \n"
+#~ "    public void configure() throws HibernateException {\n"
+#~ "        _sessions = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class)\n"
+#~ "            .buildSessionFactory();\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void exportTables() throws HibernateException {\n"
+#~ "        Configuration cfg = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class);\n"
+#~ "        new SchemaExport(cfg).create(true, true);\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog createBlog(String name) throws HibernateException {\n"
+#~ "        \n"
+#~ "        Blog blog = new Blog();\n"
+#~ "        blog.setName(name);\n"
+#~ "        blog.setItems( new ArrayList() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.persist(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setBlog(blog);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        blog.getItems().add(item);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Long blogid, String title, String "
+#~ "text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
+#~ "            item.setBlog(blog);\n"
+#~ "            blog.getItems().add(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(BlogItem item, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        item.setText(text);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(Long itemid, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "    \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            BlogItem item = (BlogItem) session.load(BlogItem.class, "
+#~ "itemid);\n"
+#~ "            item.setText(text);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listAllBlogNamesAndItemCounts(int max)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"select blog.id, blog.name, count(blogItem) \" +\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join blog.items as blogItem \" +\n"
+#~ "                \"group by blog.name, blog.id \" +\n"
+#~ "                \"order by max(blogItem.datetime)\"\n"
+#~ "            );\n"
+#~ "            q.setMaxResults(max);\n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog getBlogAndAllItems(Long blogid)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        Blog blog = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join fetch blog.items \" +\n"
+#~ "                \"where blog.id = :blogid\"\n"
+#~ "            );\n"
+#~ "            q.setParameter(\"blogid\", blogid);\n"
+#~ "            blog  = (Blog) q.uniqueResult();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listBlogsAndRecentItems() throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"inner join blog.items as blogItem \" +\n"
+#~ "                \"where blogItem.datetime > :minDate\"\n"
+#~ "            );\n"
+#~ "\n"
+#~ "            Calendar cal = Calendar.getInstance();\n"
+#~ "            cal.roll(Calendar.MONTH, false);\n"
+#~ "            q.setCalendar(\"minDate\", cal);\n"
+#~ "            \n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "}]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/filters.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/filters.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/filters.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,44 +1,46 @@
+# translation of filters.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: filters\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-11-11 09:26+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: filters.xml:29
 #, no-c-format
 msgid "Filtering data"
 msgstr "Filtrer les données"
 
 #. Tag: para
-#: filters.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 provides an innovative new approach to handling data with "
 "\"visibility\" rules. A <emphasis>Hibernate filter</emphasis> is a global, "
 "named, parameterized filter that can be enabled or disabled for a particular "
 "Hibernate session."
 msgstr ""
-"Hibernate3 fournit une nouvelle approche innovatrice pour gérer des données "
-"avec des règles de \"visibilité\". Un <emphasis>filtre Hibernate</emphasis> "
-"est un filtre global, nommé, paramétré qui peut être activé ou désactivé "
-"pour une session Hibernate particulière."
+"Hibernate3 fournit une nouvelle approche innovatrice pour manipuler des "
+"données avec des règles de \"visibilité\". Un <emphasis>filtre Hibernate</"
+"emphasis> est un filtre global, nommé, paramétré qui peut être activé ou "
+"désactivé pour une session Hibernate particulière. "
 
 #. Tag: title
-#: filters.xml:38
 #, no-c-format
 msgid "Hibernate filters"
 msgstr "Filtres Hibernate"
 
 #. Tag: para
-#: filters.xml:40
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 has the ability to pre-define filter criteria and attach those "
 "filters at both a class level and a collection level. A filter criteria "
@@ -53,14 +55,13 @@
 "d'attacher ces filtres à une classe ou à une collection. Un critère de "
 "filtre est la faculté de définir une clause de restriction très similaire à "
 "l'attribut \"where\" existant disponible sur une classe et divers éléments "
-"d'une collection. Mis à part que ces conditions de filtre peuvent être "
+"d'une collection. Par ailleurs ces conditions de filtre peuvent être "
 "paramétrées. L'application peut alors prendre la décision à l'exécution si "
-"des filtres donnés devraient être activés et quels devraient être leurs "
+"des filtres donnés doivent être activés et quels doivent être leurs "
 "paramètres. Des filtres peuvent être utilisés comme des vues de base de "
-"données, mais paramétrées dans l'application."
+"données, mais paramétrées dans l'application. "
 
 #. Tag: para
-#: filters.xml:50
 #, no-c-format
 msgid ""
 "In order to use filters, they must first be defined and then attached to the "
@@ -73,57 +74,23 @@
 "l'élément <literal>&lt;filter-def/&gt;</literal> dans un élément "
 "<literal>&lt;hibernate-mapping/&gt;</literal> :"
 
-#. Tag: programlisting
-#: filters.xml:56
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<filter-def name=\"myFilter\">\n"
-"    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
-"</filter-def>]]>"
-msgstr ""
+msgid "This filter can then be attached to a class:"
+msgstr "Puis, ce filtre peut être attaché à une classe : "
 
 #. Tag: para
-#: filters.xml:58
-#, fuzzy, no-c-format
-msgid "This filter can then be attached to a class:"
-msgstr "Puis, ce filtre peut être attaché à une classe :"
-
-#. Tag: programlisting
-#: filters.xml:62
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"myClass\" ...>\n"
-"    ...\n"
-"    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN"
-"\"/>\n"
-"</class>]]>"
-msgstr ""
+msgid "Or, to a collection:"
+msgstr "Ou bien, à une collection :"
 
 #. Tag: para
-#: filters.xml:64
-#, fuzzy, no-c-format
-msgid "Or, to a collection:"
-msgstr "ou à une collection :"
-
-#. Tag: programlisting
-#: filters.xml:68
 #, no-c-format
-msgid ""
-"<![CDATA[<set ...>\n"
-"    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN"
-"\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:70
-#, fuzzy, no-c-format
 msgid "Or, to both or multiples of each at the same time."
-msgstr "ou même aux deux (ou à plusieurs de chaque) en même temps."
+msgstr "Ou même encore, aux deux (ou à plusieurs de chaque) en même temps."
 
 #. Tag: para
-#: filters.xml:74
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The methods on <literal>Session</literal> are: <literal>enableFilter(String "
 "filterName)</literal>, <literal>getEnabledFilter(String filterName)</"
@@ -139,118 +106,53 @@
 "literal>, et <literal>disableFilter(String filterName)</literal>. Par "
 "défaut, les filtres <emphasis>ne sont pas</emphasis> activés pour une "
 "session donnée ; ils doivent être explicitement activés en appelant la "
-"méthode <literal>Session.enableFilter()</literal>, laquelle retourne une "
+"méthode <literal>Session.enabledFilter()</literal>, laquelle retourne une "
 "instance de l'interface <literal>Filter</literal>. Utiliser le simple filtre "
-"défini au-dessus ressemblerait à :"
+"défini ci-dessus ressemblerait à : "
 
-#. Tag: programlisting
-#: filters.xml:83
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam\", "
-"\"some-value\");]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:85
-#, fuzzy, no-c-format
-msgid ""
 "Methods on the org.hibernate.Filter interface do allow the method-chaining "
 "common to much of Hibernate."
 msgstr ""
 "Notez que des méthodes sur l'interface org.hibernate.Filter autorisent le "
-"chaînage de beaucoup de méthodes communes d'Hibernate."
+"chaînage de beaucoup de méthodes communes à Hibernate. "
 
 #. Tag: para
-#: filters.xml:89
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is a full example, using temporal data with an effective "
 "record date pattern:"
 msgstr ""
 "Un exemple complet, utilisant des données temporelles avec une structure de "
-"date d'enregistrement effectif :"
+"date d'enregistrement effectif : "
 
-#. Tag: programlisting
-#: filters.xml:93
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<filter-def name=\"effectiveDate\">\n"
-"    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
-"</filter-def>\n"
-"\n"
-"<class name=\"Employee\" ...>\n"
-"...\n"
-"    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department\"/"
-">\n"
-"    <property name=\"effectiveStartDate\" type=\"date\" column=\"eff_start_dt"
-"\"/>\n"
-"    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt\"/"
-">\n"
-"...\n"
-"    <!--\n"
-"        Note that this assumes non-terminal records have an eff_end_dt set "
-"to\n"
-"        a max db date for simplicity-sake\n"
-"    -->\n"
-"    <filter name=\"effectiveDate\"\n"
-"            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Department\" ...>\n"
-"...\n"
-"    <set name=\"employees\" lazy=\"true\">\n"
-"        <key column=\"dept_id\"/>\n"
-"        <one-to-many class=\"Employee\"/>\n"
-"        <filter name=\"effectiveDate\"\n"
-"                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
-">\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:95
-#, fuzzy, no-c-format
-msgid ""
 "In order to ensure that you are provided with currently effective records, "
 "enable the filter on the session prior to retrieving employee data:"
 msgstr ""
 "Puis, afin de s'assurer que vous pouvez toujours récupérer les "
 "enregistrements actuellement effectifs, activez simplement le filtre sur la "
-"session avant de récupérer des données des employés :"
+"session avant de récupérer des données des employés : "
 
-#. Tag: programlisting
-#: filters.xml:100
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = ...;\n"
-"session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new Date"
-"());\n"
-"List results = session.createQuery(\"from Employee as e where e.salary > :"
-"targetSalary\")\n"
-"         .setLong(\"targetSalary\", new Long(1000000))\n"
-"         .list();\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:102
-#, fuzzy, no-c-format
-msgid ""
 "Even though a salary constraint was mentioned explicitly on the results in "
 "the above HQL, because of the enabled filter, the query will return only "
 "currently active employees who have a salary greater than one million "
 "dollars."
 msgstr ""
 "Dans le HQL ci-dessus, bien que nous ayons seulement mentionné une "
-"contrainte de salaire sur les resultats, à cause du filtre activé, la "
+"contrainte de salaire sur les résultats, à cause du filtre activé, la "
 "requête retournera seulement les employés actuellement actifs qui ont un "
-"salaire supérieur à un million de dollars."
+"salaire supérieur à un million de dollars. "
 
 #. Tag: para
-#: filters.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want to use filters with outer joining, either through HQL or load "
 "fetching, be careful of the direction of the condition expression. It is "
@@ -258,33 +160,27 @@
 "followed by the column name(s) after the operator."
 msgstr ""
 "A noter : si vous prévoyez d'utiliser des filtres avec des jointures "
-"externes (soit à travers HQL, soit par le chargement) faites attention à la "
+"externes (soit à travers HQL, soit par le chargement), faites attention à la "
 "direction de l'expression de condition. Il est plus sûr de la positionner "
 "pour les jointures externes à gauche ; en général, placez le paramètre "
-"d'abord, suivi du(des) nom(s) de colonne après l'opérateur."
+"d'abord, suivi du(des) nom(s) de colonne après l'opérateur. "
 
 #. Tag: para
-#: filters.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "After being defined, a filter might be attached to multiple entities and/or "
 "collections each with its own condition. This can be problematic when the "
 "conditions are the same each time. Using <literal>&lt;filter-def/&gt;</"
 "literal> allows you to definine a default condition, either as an attribute "
 "or CDATA:"
-msgstr "translator-credits"
-
-#. Tag: programlisting
-#: filters.xml:122
-#, no-c-format
-msgid ""
-"<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</filter-"
-"def>\n"
-"<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"
 msgstr ""
+"Après avoir été défini, un filtre peut être attaché à de nombreuses entités "
+"et/ou des collections, chacune avec sa propre condition. Cela peut être "
+"fastidieux quand les conditions sont les mêmes à chaque fois. Ainsi "
+"<literal>&lt;filter-def/&gt;</literal> permet de définir une condition par "
+"défaut, soit en tant qu'attribut, soit comme CDATA. "
 
 #. Tag: para
-#: filters.xml:124
 #, no-c-format
 msgid ""
 "This default condition will be used whenever the filter is attached to "
@@ -292,3 +188,145 @@
 "condition as part of the attachment of the filter that overrides the default "
 "condition in that particular case."
 msgstr ""
+"Cette condition par défaut sera alors utilisée à chaque fois que le filtre "
+"est attaché à quelque chose sans spécifier la condition. Notez que cela "
+"signifie que vous pouvez fournir une condition spécifique en tant que "
+"faisant partie de la pièce attachée du filtre qui surcharge la condition par "
+"défaut dans ce cas particulier.  "
+
+#~ msgid ""
+#~ "<![CDATA[<filter-def name=\"myFilter\">\n"
+#~ "    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
+#~ "</filter-def>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<filter-def name=\"myFilter\">\n"
+#~ "    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
+#~ "</filter-def>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"myClass\" ...>\n"
+#~ "    ...\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"myClass\" ...>\n"
+#~ "    ...\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set ...>\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set ...>\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam"
+#~ "\", \"some-value\");]]>"
+#~ msgstr ""
+#~ "<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam"
+#~ "\", \"some-value\");]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<filter-def name=\"effectiveDate\">\n"
+#~ "    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
+#~ "</filter-def>\n"
+#~ "\n"
+#~ "<class name=\"Employee\" ...>\n"
+#~ "...\n"
+#~ "    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department"
+#~ "\"/>\n"
+#~ "    <property name=\"effectiveStartDate\" type=\"date\" column="
+#~ "\"eff_start_dt\"/>\n"
+#~ "    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt"
+#~ "\"/>\n"
+#~ "...\n"
+#~ "    <!--\n"
+#~ "        Note that this assumes non-terminal records have an eff_end_dt "
+#~ "set to\n"
+#~ "        a max db date for simplicity-sake\n"
+#~ "    -->\n"
+#~ "    <filter name=\"effectiveDate\"\n"
+#~ "            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
+#~ ">\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Department\" ...>\n"
+#~ "...\n"
+#~ "    <set name=\"employees\" lazy=\"true\">\n"
+#~ "        <key column=\"dept_id\"/>\n"
+#~ "        <one-to-many class=\"Employee\"/>\n"
+#~ "        <filter name=\"effectiveDate\"\n"
+#~ "                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt"
+#~ "\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<filter-def name=\"effectiveDate\">\n"
+#~ "    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
+#~ "</filter-def>\n"
+#~ "\n"
+#~ "<class name=\"Employee\" ...>\n"
+#~ "...\n"
+#~ "    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department"
+#~ "\"/>\n"
+#~ "    <property name=\"effectiveStartDate\" type=\"date\" column="
+#~ "\"eff_start_dt\"/>\n"
+#~ "    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt"
+#~ "\"/>\n"
+#~ "...\n"
+#~ "    <!--\n"
+#~ "        Note that this assumes non-terminal records have an eff_end_dt "
+#~ "set to\n"
+#~ "        a max db date for simplicity-sake\n"
+#~ "    -->\n"
+#~ "    <filter name=\"effectiveDate\"\n"
+#~ "            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
+#~ ">\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Department\" ...>\n"
+#~ "...\n"
+#~ "    <set name=\"employees\" lazy=\"true\">\n"
+#~ "        <key column=\"dept_id\"/>\n"
+#~ "        <one-to-many class=\"Employee\"/>\n"
+#~ "        <filter name=\"effectiveDate\"\n"
+#~ "                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt"
+#~ "\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = ...;\n"
+#~ "session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new "
+#~ "Date());\n"
+#~ "List results = session.createQuery(\"from Employee as e where e.salary > :"
+#~ "targetSalary\")\n"
+#~ "         .setLong(\"targetSalary\", new Long(1000000))\n"
+#~ "         .list();\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = ...;\n"
+#~ "session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new "
+#~ "Date());\n"
+#~ "List results = session.createQuery(\"from Employee as e where e.salary > :"
+#~ "targetSalary\")\n"
+#~ "         .setLong(\"targetSalary\", new Long(1000000))\n"
+#~ "         .list();\n"
+#~ "]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</"
+#~ "filter-def>\n"
+#~ "<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</"
+#~ "filter-def>\n"
+#~ "<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/inheritance_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/inheritance_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/inheritance_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,74 +1,67 @@
+# translation of inheritance_mapping.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: inheritance_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-05 09:37+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: inheritance_mapping.xml:29
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Inheritance mapping"
-msgstr "Mapping d'héritage de classe"
+msgstr "Mapping d'héritage de classe "
 
 #. Tag: title
-#: inheritance_mapping.xml:32
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The three strategies"
-msgstr "Les trois stratégies"
+msgstr "Les trois stratégies "
 
 #. Tag: para
-#: inheritance_mapping.xml:34
 #, no-c-format
 msgid "Hibernate supports the three basic inheritance mapping strategies:"
 msgstr "Hibernate supporte les trois stratégies d'héritage de base :"
 
 #. Tag: para
-#: inheritance_mapping.xml:40
 #, no-c-format
 msgid "table per class hierarchy"
-msgstr "une table par hiérarchie de classe (table per class hierarchy)"
+msgstr "une table par hiérarchie de classe"
 
 #. Tag: para
-#: inheritance_mapping.xml:45
 #, fuzzy, no-c-format
-msgid "<para>table per subclass</para>"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"une table par classe fille (table per subclass)\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"une table par classe fille"
+msgid "table per subclass"
+msgstr "Une table par classe fille"
 
 #. Tag: para
-#: inheritance_mapping.xml:50
 #, no-c-format
 msgid "table per concrete class"
-msgstr "une table par classe concrète (table per concrete class)"
+msgstr "une table par classe concrète "
 
 #. Tag: para
-#: inheritance_mapping.xml:56
 #, no-c-format
 msgid ""
 "In addition, Hibernate supports a fourth, slightly different kind of "
 "polymorphism:"
 msgstr ""
-"Hibernate supporte en plus une quatrièmestratégie, légèrement différente, "
-"qui supporte le polymorphisme :"
+"Par ailleurs, Hibernate supporte une quatrième stratégie, avec un "
+"polymorphisme légèrement différent : "
 
 #. Tag: para
-#: inheritance_mapping.xml:63
 #, no-c-format
 msgid "implicit polymorphism"
 msgstr "le polymorphisme implicite"
 
 #. Tag: para
-#: inheritance_mapping.xml:69
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to use different mapping strategies for different branches of "
 "the same inheritance hierarchy. You can then make use of implicit "
@@ -82,20 +75,19 @@
 "<literal>&lt;join&gt;</literal> elements (see below for an example)."
 msgstr ""
 "Il est possible d'utiliser différentes stratégies de mapping pour "
-"différentes branches d'une même hiérarchie d'héritage, et alors d'employer "
+"différentes branches d'une même hiérarchie d'héritage, et ensuite d'employer "
 "le polymorphisme implicite pour réaliser le polymorphisme à travers toute la "
-"hiérarchie. Pourtant, Hibernate ne supporte pas de mélanger des mappings "
-"<literal>&lt;subclass&gt;</literal> et <literal>&lt;joined-subclass&gt;</"
+"hiérarchie. Toutefois, Hibernate ne supporte pas les mélanges de mappages "
+"<literal>&lt;subclass&gt;</literal>, <literal>&lt;joined-subclass&gt;</"
 "literal> et <literal>&lt;union-subclass&gt;</literal> pour le même élément "
-"<literal>&lt;class&gt;</literal> racine. Il est possible de mélanger "
-"ensemble les stratégies d'une table par hiérarchie et d'une table par sous-"
-"classe, pour le même élément <literal>&lt;class&gt;</literal>, en combinant "
-"les éléments <literal>&lt;subclass&gt;</literal> et <literal>&lt;join&gt;</"
-"literal> (voir dessous)."
+"<literal>&lt;class&gt;</literal> racine. Il est possible de mélanger les "
+"stratégies d'une table par hiérarchie et d'une table par sous-classe, pour "
+"le même élément <literal>&lt;class&gt;</literal>, en combinant les éléments "
+"<literal>&lt;subclass&gt;</literal> et <literal>&lt;join&gt;</literal> (voir "
+"ci-dessous). "
 
 #. Tag: para
-#: inheritance_mapping.xml:83
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to define <literal>subclass</literal>, <literal>union-"
 "subclass</literal>, and <literal>joined-subclass</literal> mappings in "
@@ -108,40 +100,25 @@
 "extends keyword. The ordering inside a single mapping file still needs to be "
 "defined as superclasses before subclasses."
 msgstr ""
-"Il est possible de définir des mappings de <literal>subclass</literal>, "
+"Il est possible de définir des mappages de <literal>subclass</literal>, "
 "<literal>union-subclass</literal>, et <literal>joined-subclass</literal> "
-"dans des documents de mapping séparés, directement sous <literal>hibernate-"
-"mapping</literal>. Ceci vous permet d'étendre une hiérarchie de classe juste "
-"en ajoutant un nouveau fichier de mapping. Vous devez spécifier un attribut "
-"<literal>extends</literal> dans le mapping de la sous-classe, en nommant une "
-"super-classe précédemment mappée. Note : précédemment cette foncionnalité "
-"rendait l'ordre des documents de mapping important. Depuis Hibernate3, "
-"l'ordre des fichier de mapping n'importe plus lors de l'utilisation du mot-"
-"clef \"extends\". L'ordre à l'intérieur d'un simple fichier de mapping "
-"impose encore de définir les classes mères avant les classes filles."
+"dans des documents de mappage séparés, directement sous <literal>hibernate-"
+"mappage</literal>. Ceci vous permet d'étendre une hiérarchie de classe juste "
+"en ajoutant un nouveau fichier de mappage. Vous devez spécifier un attribut "
+"<literal>extends</literal> dans le mappage de la sous-classe, en nommant une "
+"super-classe précédemment mappée. Note : précédemment cette fonctionnalité "
+"rendait important l'ordre des documents de mappage. Depuis Hibernate3, "
+"l'ordre des fichier de mappage n'importe plus lors de l'utilisation du mot-"
+"clef \"extends\". L'ordre à l'intérieur d'un simple fichier de mappage "
+"impose encore de définir les classes mères avant les classes filles. "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:94
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-" <hibernate-mapping>\n"
-"     <subclass name=\"DomesticCat\" extends=\"Cat\" discriminator-value=\"D"
-"\">\n"
-"          <property name=\"name\" type=\"string\"/>\n"
-"     </subclass>\n"
-" </hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:98
 #, no-c-format
 msgid "Table per class hierarchy"
 msgstr "Une table par hiérarchie de classe"
 
 #. Tag: para
-#: inheritance_mapping.xml:100
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Suppose we have an interface <literal>Payment</literal> with the "
 "implementors <literal>CreditCardPayment</literal>, <literal>CashPayment</"
@@ -151,104 +128,48 @@
 "Supposons que nous ayons une interface <literal>Payment</literal>, "
 "implémentée par <literal>CreditCardPayment</literal>, <literal>CashPayment</"
 "literal>, <literal>ChequePayment</literal>. La stratégie une table par "
-"hiérarchie serait :"
+"hiérarchie serait : "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:107
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        ...\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: inheritance_mapping.xml:109
-#, fuzzy, no-c-format
-msgid ""
 "Exactly one table is required. There is a limitation of this mapping "
 "strategy: columns declared by the subclasses, such as <literal>CCTYPE</"
 "literal>, cannot have <literal>NOT NULL</literal> constraints."
 msgstr ""
 "Une seule table est requise. Une grande limitation de cette stratégie est "
 "que les colonnes déclarées par les classes filles, telles que "
-"<literal>CCTYPE</literal>, ne peuvent avoir de contrainte <literal>NOT NULL</"
-"literal>."
+"<literal>CCTYPE</literal>, peuvent ne pas avoir de contrainte <literal>NOT "
+"NULL</literal>. "
 
 #. Tag: title
-#: inheritance_mapping.xml:118
 #, no-c-format
 msgid "Table per subclass"
 msgstr "Une table par classe fille"
 
 #. Tag: para
-#: inheritance_mapping.xml:120
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A table per subclass mapping looks like this:"
-msgstr "La stratégie une table par classe fille serait :"
+msgstr "Une table par classe-fille de mappage serait : "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:124
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <joined-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: inheritance_mapping.xml:126
-#, fuzzy, no-c-format
-msgid ""
 "Four tables are required. The three subclass tables have primary key "
 "associations to the superclass table so the relational model is actually a "
 "one-to-one association."
 msgstr ""
 "Quatre tables sont requises. Les trois tables des classes filles ont une clé "
 "primaire associée à la table classe mère (le modèle relationnel est une "
-"association un-vers-un)."
+"association un-à-un)."
 
 #. Tag: title
-#: inheritance_mapping.xml:135
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Table per subclass: using a discriminator"
-msgstr "Une table par classe fille, en utilisant un discriminant"
+msgstr "Une table par classe fille, en utilisant un discriminant "
 
 #. Tag: para
-#: inheritance_mapping.xml:137
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's implementation of table per subclass does not require a "
 "discriminator column. Other object/relational mappers use a different "
@@ -259,52 +180,18 @@
 "strategy, you can combine the use of <literal>&lt;subclass&gt;</literal> and "
 "<literal>&lt;join&gt;</literal>, as follows:"
 msgstr ""
-"Notez que l'implémentation Hibernate de la stratégie un table par classe "
-"fille ne nécessite pas de colonne discriminante dans la table classe mère. "
+"Notez que l'implémentation Hibernate de la stratégie une table par classe "
+"fille, ne nécessite pas de colonne discriminante dans la table classe mère. "
 "D'autres implémentations de mappers Objet/Relationnel utilisent une autre "
 "implémentation de la stratégie une table par classe fille qui nécessite une "
 "colonne de type discriminant dans la table de la classe mère. L'approche "
 "prise par Hibernate est plus difficile à implémenter mais plus correcte "
 "d'une point de vue relationnel. Si vous aimeriez utiliser une colonne "
-"discriminante avec la stratégie d'une table par classe fille, vous pourriez "
+"discriminante avec la stratégie d'une table par classe fille, vous pouvez "
 "combiner l'utilisation de <literal>&lt;subclass&gt;</literal> et "
-"<literal>&lt;join&gt;</literal>, comme suit :"
+"<literal>&lt;join&gt;</literal>, comme suit : "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:149
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <join table=\"CREDIT_PAYMENT\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        <join table=\"CASH_PAYMENT\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        <join table=\"CHEQUE_PAYMENT\" fetch=\"select\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:151
 #, no-c-format
 msgid ""
 "The optional <literal>fetch=\"select\"</literal> declaration tells Hibernate "
@@ -314,53 +201,24 @@
 "La déclaration optionnelle <literal>fetch=\"select\"</literal> indique à "
 "Hibernate de ne pas récupérer les données de la classe fille "
 "<literal>ChequePayment</literal> par une jointure externe lors des requêtes "
-"sur la classe mère."
+"sur la classe mère. "
 
 #. Tag: title
-#: inheritance_mapping.xml:160
 #, no-c-format
 msgid "Mixing table per class hierarchy with table per subclass"
 msgstr ""
 "Mélange d'une table par hiérarchie de classe avec une table par classe fille"
 
 #. Tag: para
-#: inheritance_mapping.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can even mix the table per hierarchy and table per subclass strategies "
 "using the following approach:"
 msgstr ""
 "Vous pouvez même mélanger les stratégies d'une table par hiérarchie de "
-"classe et d'une table par classe fille en utilisant cette approche :"
+"classe et d'une table par classe fille en utilisant cette approche : "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <join table=\"CREDIT_PAYMENT\">\n"
-"            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        ...\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:169
 #, no-c-format
 msgid ""
 "For any of these mapping strategies, a polymorphic association to the root "
@@ -371,68 +229,33 @@
 "la classe racine <literal>Payment</literal> est mappée en utilisant "
 "<literal>&lt;many-to-one&gt;</literal>."
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:175
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"payment\" column=\"PAYMENT_ID\" class=\"Payment"
-"\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:180
 #, no-c-format
 msgid "Table per concrete class"
 msgstr "Une table par classe concrète"
 
 #. Tag: para
-#: inheritance_mapping.xml:182
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are two ways we can map the table per concrete class strategy. First, "
 "you can use <literal>&lt;union-subclass&gt;</literal>."
 msgstr ""
 "Il y a deux manières d'utiliser la stratégie d'une table par classe "
 "concrète. La première est d'employer <literal>&lt;union-subclass&gt;</"
-"literal>."
+"literal>. "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:187
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"sequence\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <union-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </union-subclass>\n"
-"    <union-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        ...\n"
-"    </union-subclass>\n"
-"    <union-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        ...\n"
-"    </union-subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:189
 #, no-c-format
 msgid ""
 "Three tables are involved for the subclasses. Each table defines columns for "
 "all properties of the class, including inherited properties."
 msgstr ""
 "Trois tables sont nécessaires pour les classes filles. Chaque table définit "
-"des colonnes pour toutes les propriétés de la classe, incluant les "
-"propriétés héritéés."
+"des colonnes pour toutes les propriétés de la classe, y compris les "
+"propriétés héritées. "
 
 #. Tag: para
-#: inheritance_mapping.xml:194
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The limitation of this approach is that if a property is mapped on the "
 "superclass, the column name must be the same on all subclass tables. The "
@@ -442,15 +265,14 @@
 msgstr ""
 "La limitation de cette approche est que si une propriété est mappée sur la "
 "classe mère, le nom de la colonne doit être le même pour toutes les classes "
-"filles. (Nous pourrions être plus souple dans une future version "
-"d'Hibernate). La stratégie du générateur d'identifiant n'est pas permise "
-"dans l'héritage de classes filles par union, en effet la valeur (NdT : seed) "
-"de la clef primaire doit être partagée par toutes les classes filles \"union"
-"\" d'une hiérarchie."
+"filles (Une future version de Hibernate pourra assouplir ce comportement). "
+"La stratégie du générateur d'identifiant n'est pas permise dans l'héritage "
+"de classes filles par union, en effet la valeur de graine de la clef "
+"primaire doit être partagée par toutes les classes filles fusionnées d'une "
+"hiérarchie. "
 
 #. Tag: para
-#: inheritance_mapping.xml:203
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your superclass is abstract, map it with <literal>abstract=\"true\"</"
 "literal>. If it is not abstract, an additional table (it defaults to "
@@ -460,51 +282,20 @@
 "Si votre classe mère est abstraite, mappez la avec <literal>abstract=\"true"
 "\"</literal>. Bien sûr, si elle n'est pas abstraite, une table "
 "supplémentaire (par défaut, <literal>PAYMENT</literal> dans l'exemple ci-"
-"dessus) est requise pour contenir des instances de la classe mère."
+"dessus) est requise pour contenir des instances de la classe mère. "
 
 #. Tag: title
-#: inheritance_mapping.xml:213
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Table per concrete class using implicit polymorphism"
-msgstr "Une table par classe concrète, en utilisant le polymorphisme implicite"
+msgstr ""
+"Une table par classe concrète, en utilisant le polymorphisme implicite "
 
 #. Tag: para
-#: inheritance_mapping.xml:215
 #, no-c-format
 msgid "An alternative approach is to make use of implicit polymorphism:"
 msgstr "Une approche alternative est l'emploi du polymorphisme implicite :"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:219
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-"    ...\n"
-"</class>\n"
-"\n"
-"<class name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CASH_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-"    ...\n"
-"</class>\n"
-"\n"
-"<class name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CHEQUE_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:221
 #, fuzzy, no-c-format
 msgid ""
 "Notice that the <literal>Payment</literal> interface is not mentioned "
@@ -512,60 +303,42 @@
 "mapped in each of the subclasses. If you want to avoid duplication, consider "
 "using XML entities (for example, <literal>[ &lt;!ENTITY allproperties SYSTEM "
 "\"allproperties.xml\"&gt; ]</literal> in the <literal>DOCTYPE</literal> "
-"declaration and <literal>&amp;allproperties;</literal> in the mapping)."
+"declaration and <literal>&amp;allproperties&semi;</literal> in the mapping)."
 msgstr ""
 "Notez que nulle part nous ne mentionnons l'interface <literal>Payment</"
 "literal> explicitement. Notez aussi que des propriétés de <literal>Payment</"
 "literal> sont mappées dans chaque classe fille. Si vous voulez éviter des "
-"duplications, considérez l'utilisation des entités XML (cf. <literal>[ &lt;!"
-"ENTITY allproperties SYSTEM \"allproperties.xml\"&gt; ]</literal> dans la "
-"déclaration du <literal>DOCTYPE</literal> et <literal>&amp;allproperties;</"
-"literal> dans le mapping)."
+"duplications, considérez l'utilisation des entités XML (par ex. <literal>"
+"[ &lt;!ENTITY allproperties SYSTEM \"allproperties.xml\"&gt; ]</literal> "
+"dans la déclaration <literal>DOCTYPE</literal> et dans le mappage "
+"<literal>&amp;allproperties&semi;</literal>). "
 
 #. Tag: para
-#: inheritance_mapping.xml:231
 #, no-c-format
 msgid ""
 "The disadvantage of this approach is that Hibernate does not generate SQL "
 "<literal>UNION</literal>s when performing polymorphic queries."
 msgstr ""
-"L'inconvénient de cette approche est qu'Hibernate ne génère pas "
-"d'<literal>UNION</literal>s SQL lors de l'exécution des requêtes "
-"polymorphiques."
+"L'inconvénient de cette approche est que Hibernate ne génère pas de SQL "
+"<literal>UNION</literal> s lors de l'exécution des requêtes polymorphiques. "
 
 #. Tag: para
-#: inheritance_mapping.xml:236
 #, no-c-format
 msgid ""
 "For this mapping strategy, a polymorphic association to <literal>Payment</"
 "literal> is usually mapped using <literal>&lt;any&gt;</literal>."
 msgstr ""
-"Pour cette stratégie de mapping, une association polymorphique pour "
+"Pour cette stratégie de mappage, une association polymorphique pour "
 "<literal>Payment</literal> est habituellement mappée en utilisant "
-"<literal>&lt;any&gt;</literal>."
+"<literal>&lt;any&gt;</literal>. "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:241
-#, no-c-format
-msgid ""
-"<![CDATA[<any name=\"payment\" meta-type=\"string\" id-type=\"long\">\n"
-"    <meta-value value=\"CREDIT\" class=\"CreditCardPayment\"/>\n"
-"    <meta-value value=\"CASH\" class=\"CashPayment\"/>\n"
-"    <meta-value value=\"CHEQUE\" class=\"ChequePayment\"/>\n"
-"    <column name=\"PAYMENT_CLASS\"/>\n"
-"    <column name=\"PAYMENT_ID\"/>\n"
-"</any>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:246
 #, no-c-format
 msgid "Mixing implicit polymorphism with other inheritance mappings"
-msgstr "Mélange du polymorphisme implicite avec d'autres mappings d'héritage"
+msgstr "Mélange du polymorphisme implicite avec d'autres mappages d'héritage "
 
 #. Tag: para
-#: inheritance_mapping.xml:248
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Since the subclasses are each mapped in their own <literal>&lt;class&gt;</"
 "literal> element, and since <literal>Payment</literal> is just an "
@@ -573,50 +346,16 @@
 "inheritance hierarchy. You can still use polymorphic queries against the "
 "<literal>Payment</literal> interface."
 msgstr ""
-"Il y a une chose supplémentaire à noter à propos de ce mapping. Puisque les "
+"Il y a une chose supplémentaire à noter à propos de ce mappage. Puisque les "
 "classes filles sont chacune mappées avec leur propre élément <literal>&lt;"
 "class&gt;</literal> (et puisque <literal>Payment</literal> est juste une "
 "interface), chaque classe fille pourrait facilement faire partie d'une autre "
 "hiérarchie d'héritage ! (Et vous pouvez encore faire des requêtes "
-"polymorphiques pour l'interface <literal>Payment</literal>)."
+"polymorphiques pour l'interface <literal>Payment</literal>). "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:256
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"CREDIT_CARD\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"MasterCardPayment\" discriminator-value=\"MDC\"/>\n"
-"    <subclass name=\"VisaPayment\" discriminator-value=\"VISA\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"NonelectronicTransaction\" table=\"NONELECTRONIC_TXN\">\n"
-"    <id name=\"id\" type=\"long\" column=\"TXN_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    ...\n"
-"    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: inheritance_mapping.xml:258
-#, fuzzy, no-c-format
-msgid ""
 "Once again, <literal>Payment</literal> is not mentioned explicitly. If we "
 "execute a query against the <literal>Payment</literal> interface, for "
 "example <literal>from Payment</literal>, Hibernate automatically returns "
@@ -632,231 +371,210 @@
 "literal> (et ses classes filles puisqu'elles implémentent aussi "
 "<literal>Payment</literal>), <literal>CashPayment</literal> et "
 "<literal>ChequePayment</literal> mais pas les instances de "
-"<literal>NonelectronicTransaction</literal>."
+"<literal>NonelectronicTransaction</literal>. "
 
 #. Tag: title
-#: inheritance_mapping.xml:273
 #, no-c-format
 msgid "Limitations"
 msgstr "Limitations"
 
 #. Tag: para
-#: inheritance_mapping.xml:275
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are limitations to the \"implicit polymorphism\" approach to the table "
 "per concrete-class mapping strategy. There are somewhat less restrictive "
 "limitations to <literal>&lt;union-subclass&gt;</literal> mappings."
 msgstr ""
 "Il y a certaines limitations à l'approche du \"polymorphisme implicite\" "
-"pour la stratégie de mapping d'une table par classe concrète. Il y a plutôt "
-"moins de limitations restrictives aux mappings <literal>&lt;union-"
-"subclass&gt;</literal>."
+"pour la stratégie de mappage d'une table par classe concrète. Il y a plutôt "
+"moins de limitations restrictives aux mappages <literal>&lt;union-"
+"subclass&gt;</literal>. "
 
 #. Tag: para
-#: inheritance_mapping.xml:282
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The following table shows the limitations of table per concrete-class "
 "mappings, and of implicit polymorphism, in Hibernate."
 msgstr ""
-"La table suivante montre les limitations des mappings d'une table par classe "
-"concrète, et du polymorphisme implicite, dans Hibernate."
+"La table suivante montre les limitations des mappages d'une table par classe "
+"concrète, et du polymorphisme implicite, dans Hibernate. "
 
 #. Tag: title
-#: inheritance_mapping.xml:288
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Features of inheritance mappings"
-msgstr "Caractéristiques du mapping d'héritage"
+msgstr "Mapping d'héritage de classe "
 
 #. Tag: entry
-#: inheritance_mapping.xml:301
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Inheritance strategy"
-msgstr "Stratégie d'héritage"
+msgstr "Mapping d'héritage de classe "
 
 #. Tag: entry
-#: inheritance_mapping.xml:302
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Polymorphic many-to-one"
-msgstr "many-to-one polymorphique"
+msgstr "Polymorphisme many-to-one : <code>&lt;any&gt;</code>"
 
 #. Tag: entry
-#: inheritance_mapping.xml:303
 #, no-c-format
 msgid "Polymorphic one-to-one"
-msgstr "one-to-one polymorphique"
+msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:304
 #, no-c-format
 msgid "Polymorphic one-to-many"
-msgstr "one-to-many polymorphique"
+msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:305
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Polymorphic many-to-many"
-msgstr "many-to-many polymorphique"
+msgstr "Polymorphisme many-to-one : <code>&lt;any&gt;</code>"
 
 #. Tag: entry
-#: inheritance_mapping.xml:306
 #, no-c-format
 msgid "Polymorphic <literal>load()/get()</literal>"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:307
 #, no-c-format
 msgid "Polymorphic queries"
-msgstr "Requêtes polymorphiques"
+msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:308
 #, no-c-format
 msgid "Polymorphic joins"
-msgstr "Jointures polymorphiques"
+msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:309
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Outer join fetching"
-msgstr "Récupération par jointure externe"
+msgstr "Récupération par jointure externe supportée."
 
 #. Tag: entry
-#: inheritance_mapping.xml:314
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "table per class-hierarchy"
 msgstr "une table par hiérarchie de classe"
 
-#. Tag: literal
-#: inheritance_mapping.xml:315 inheritance_mapping.xml:326
-#: inheritance_mapping.xml:337
+#. Tag: entry
 #, no-c-format
-msgid "&lt;many-to-one&gt;"
-msgstr "&lt;many-to-one&gt;"
+msgid "<literal>&lt;many-to-one&gt;</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:316 inheritance_mapping.xml:327
-#: inheritance_mapping.xml:338
+#. Tag: entry
 #, no-c-format
-msgid "&lt;one-to-one&gt;"
-msgstr "&lt;one-to-one&gt;"
+msgid "<literal>&lt;one-to-one&gt;</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:317 inheritance_mapping.xml:328
+#. Tag: entry
 #, no-c-format
-msgid "&lt;one-to-many&gt;"
-msgstr "&lt;one-to-many&gt;"
+msgid "<literal>&lt;one-to-many&gt;</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:318 inheritance_mapping.xml:329
-#: inheritance_mapping.xml:340
+#. Tag: entry
 #, no-c-format
-msgid "&lt;many-to-many&gt;"
-msgstr "&lt;many-to-many&gt;"
+msgid "<literal>&lt;many-to-many&gt;</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:319 inheritance_mapping.xml:330
-#: inheritance_mapping.xml:341
+#. Tag: entry
 #, no-c-format
-msgid "s.get(Payment.class, id)"
-msgstr "s.get(Payment.class, id)"
+msgid "<literal>s.get(Payment.class, id)</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:320 inheritance_mapping.xml:331
-#: inheritance_mapping.xml:342 inheritance_mapping.xml:353
+#. Tag: entry
 #, no-c-format
-msgid "from Payment p"
-msgstr "from Payment p"
+msgid "<literal>from Payment p</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:321 inheritance_mapping.xml:332
-#: inheritance_mapping.xml:343
-#, no-c-format
-msgid "from Order o join o.payment p"
-msgstr "from Order o join o.payment p"
-
-#. Tag: emphasis
-#: inheritance_mapping.xml:322 inheritance_mapping.xml:333
-#: inheritance_mapping.xml:344
-#, no-c-format
-msgid "supported"
-msgstr "supportée"
-
 #. Tag: entry
-#: inheritance_mapping.xml:325
 #, fuzzy, no-c-format
-msgid "<entry>table per subclass</entry>"
+msgid "<literal>from Order o join o.payment p</literal>"
+msgstr "Jointures polymorphiques <code>from o join o.payment p</code>"
+
+#. Tag: entry
+#, no-c-format
+msgid "<emphasis>supported</emphasis>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"une table par classe fille (table per subclass)\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"une table par classe fille"
 
 #. Tag: entry
-#: inheritance_mapping.xml:336
 #, no-c-format
 msgid "table per concrete-class (union-subclass)"
-msgstr "une table par classe concrète (union-subclass)"
+msgstr "une table par classe concrète (union-classe fille)"
 
 #. Tag: entry
-#: inheritance_mapping.xml:339
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "<literal>&lt;one-to-many&gt;</literal> (for <literal>inverse=\"true\"</"
 "literal> only)"
 msgstr ""
+"Polymorphisme one-to-many : <literal>&lt;one-to-many&gt;</literal> "
+"(uniquement pour <literal>inverse=\"true\"</literal>)"
 
 #. Tag: entry
-#: inheritance_mapping.xml:347
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "table per concrete class (implicit polymorphism)"
-msgstr "une table par classe concrète (polymorphisme implicite)"
+msgstr "une table par classe concrète (polymorphisme implicite) "
 
-#. Tag: literal
-#: inheritance_mapping.xml:348
+#. Tag: entry
 #, no-c-format
-msgid "&lt;any&gt;"
-msgstr "&lt;any&gt;"
-
-#. Tag: emphasis
-#: inheritance_mapping.xml:349 inheritance_mapping.xml:350
-#: inheritance_mapping.xml:354 inheritance_mapping.xml:355
-#, fuzzy, no-c-format
-msgid "not supported"
+msgid "<literal>&lt;any&gt;</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"non supporté\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"non supporté\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"non supportées\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"non supportée"
 
-#. Tag: literal
-#: inheritance_mapping.xml:351
+#. Tag: entry
 #, no-c-format
-msgid "&lt;many-to-any&gt;"
-msgstr "&lt;many-to-any&gt;"
+msgid "<emphasis>not supported</emphasis>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:352
+#. Tag: entry
 #, no-c-format
+msgid "<literal>&lt;many-to-any&gt;</literal>"
+msgstr ""
+
+#. Tag: entry
+#, fuzzy, no-c-format
 msgid ""
-"s.createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()"
+"<literal>s.createCriteria(Payment.class).add( Restrictions.idEq(id) )."
+"uniqueResult()</literal>"
 msgstr ""
-"s.createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()"
+"Polymorphisme <literal>load()</literal> ou <literal>get()</literal>: <code>s."
+"createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()</"
+"code>"
 
-#~ msgid "load()/get()"
-#~ msgstr "load()/get()"
+#~ msgid "table per class-heirarchy"
+#~ msgstr "une table par hiérarchie de classe "
 
-#~ msgid "Polymorphic <placeholder-1/>"
-#~ msgstr "<placeholder-1/> polymorphique"
+#~ msgid "Polymorphic many-to-one: <code>&lt;many-to-one&gt;</code>"
+#~ msgstr "Polymorphisme many-to-one : <code>&lt;many-to-one&gt;</code>"
 
-#~ msgid "inverse=\"true\""
-#~ msgstr "inverse=\"true\""
+#~ msgid "Polymorphic one-to-one: <code>&lt;one-to-one&gt;</code>"
+#~ msgstr "Polymorphisme one-to-one : <code>&lt;one-to-one&gt;</code>"
 
-#~ msgid "<placeholder-1/> (for <placeholder-2/> only)"
-#~ msgstr "<placeholder-1/> (pour <placeholder-2/> seulement)"
+#~ msgid "Polymorphic one-to-many: <code>&lt;one-to-many&gt;</code>"
+#~ msgstr "Polymorphisme one-to-many : <code>&lt;one-to-many&gt;</code>"
+
+#~ msgid "Polymorphic many-to-many: <code>&lt;many-to-many&gt;</code>"
+#~ msgstr "Polymorphisme many-to-many : <code>&lt;many-to-many&gt;</code>"
+
+#~ msgid ""
+#~ "Polymorphic <literal>load()</literal> or <literal>get()</literal>: "
+#~ "<code>s.get(Payment.class, id)</code>"
+#~ msgstr ""
+#~ "Polymorphisme <literal>load()</literal> ou <literal>get()</literal>: "
+#~ "<code>s.get(Payment.class, id)</code>"
+
+#~ msgid "Polymorphic queries: <code>from Payment p</code>"
+#~ msgstr "Requêtes polymorphiques : <code>from Payment p</code>"
+
+#~ msgid ""
+#~ "Polymorphic one-to-one, polymorphic one-to-many, polymorphic joins, and "
+#~ "outer join fetching are not supported."
+#~ msgstr ""
+#~ "Polymorphisme one-to-one, polymorphisme one-to-many, les jointures "
+#~ "polymorphiques, et les récupération de jointures externes ne sont pas "
+#~ "supportées."
+
+#, fuzzy
+#~ msgid "<para>table per subclass</para>"
+#~ msgstr "Une table par classe fille "
+
+#, fuzzy
+#~ msgid "<term>table per subclass</term>"
+#~ msgstr "Une table par classe fille "

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/performance.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/performance.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/performance.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,52 +1,53 @@
+# translation of performance.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: performance\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-08-17 20:22+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-05 09:38+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: performance.xml:29
 #, no-c-format
 msgid "Improving performance"
 msgstr "Améliorer les performances"
 
 #. Tag: title
-#: performance.xml:32
 #, no-c-format
 msgid "Fetching strategies"
 msgstr "Stratégies de chargement"
 
 #. Tag: para
-#: performance.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate uses a <emphasis>fetching strategy</emphasis> to retrieve "
 "associated objects if the application needs to navigate the association. "
 "Fetch strategies can be declared in the O/R mapping metadata, or over-ridden "
 "by a particular HQL or <literal>Criteria</literal> query."
 msgstr ""
-"Une <emphasis>stratégie de chargement</emphasis> est une stratégie "
-"qu'Hibernate va utiliser pour récupérer des objets associés si l'application "
-"à besoin de naviguer à travers une association. Les stratégies de chargement "
-"peuvent être déclarées dans les méta-données de l'outil de mapping objet "
-"relationnel ou surchargées par une requête de type HQL ou <literal>Criteria</"
-"literal> particulière."
+"Une <emphasis>stratégie de chargement</emphasis> est une stratégie que "
+"Hibernate va utiliser pour récupérer des objets associés si l'application a "
+"besoin de naviguer à travers une association. Les stratégies de chargement "
+"peuvent être déclarées dans les méta-données de l'outil de mappage objet "
+"relationnel, ou surchargées par une requête de type HQL ou "
+"<literal>Criteria</literal> particulière."
 
 #. Tag: para
-#: performance.xml:41
 #, no-c-format
 msgid "Hibernate3 defines the following fetching strategies:"
 msgstr "Hibernate3 définit les stratégies de chargement suivantes :"
 
 #. Tag: para
-#: performance.xml:47
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Join fetching</emphasis>: Hibernate retrieves the associated "
 "instance or collection in the same <literal>SELECT</literal>, using an "
@@ -54,11 +55,10 @@
 msgstr ""
 "<emphasis>Chargement par jointure</emphasis> - Hibernate récupère l'instance "
 "associée ou la collection dans un même <literal>SELECT</literal>, en "
-"utilisant un <literal>OUTER JOIN</literal>."
+"utilisant un <literal>OUTER JOIN</literal>. "
 
 #. Tag: para
-#: performance.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Select fetching</emphasis>: a second <literal>SELECT</literal> is "
 "used to retrieve the associated entity or collection. Unless you explicitly "
@@ -66,14 +66,13 @@
 "second select will only be executed when you access the association."
 msgstr ""
 "<emphasis>Chargement par select</emphasis> - Un second <literal>SELECT</"
-"literal> est utilisé pour récupérer l'instance associée ou la collection. A "
-"moins que vous ne désactiviez explicitement le chargement tardif en "
-"spécifiant <literal>lazy=\"false\"</literal>, ce second select ne sera "
-"exécuté que lorsque vous accéderez réellement à l'association."
+"literal> est utilisé pour récupérer l'instance associée à l'entité ou à la "
+"collection. À moins que vous ne désactiviez explicitement le chargement "
+"différé en spécifiant <literal>lazy=\"false\"</literal>, ce second select ne "
+"sera exécuté que lorsque vous accéderez réellement à l'association."
 
 #. Tag: para
-#: performance.xml:63
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Subselect fetching</emphasis>: a second <literal>SELECT</literal> "
 "is used to retrieve the associated collections for all entities retrieved in "
@@ -84,13 +83,12 @@
 "<emphasis>Chargement par sous-select</emphasis> - Un second <literal>SELECT</"
 "literal> est utilisé pour récupérer les associations pour toutes les entités "
 "récupérées dans une requête ou un chargement préalable. A moins que vous ne "
-"désactiviez explicitement le chargement tardif en spécifiant <literal>lazy="
+"désactiviez explicitement le chargement différé en spécifiant <literal>lazy="
 "\"false\"</literal>, ce second select ne sera exécuté que lorsque vous "
-"accéderez réellement à l'association."
+"accéderez réellement à l'association. "
 
 #. Tag: para
-#: performance.xml:72
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Batch fetching</emphasis>: an optimization strategy for select "
 "fetching. Hibernate retrieves a batch of entity instances or collections in "
@@ -100,67 +98,61 @@
 "<emphasis>Chargement par lot</emphasis> - Il s'agit d'une stratégie "
 "d'optimisation pour le chargement par select - Hibernate récupère un lot "
 "d'instances ou de collections en un seul <literal>SELECT</literal> en "
-"spécifiant une liste de clé primaire ou de clé étrangère."
+"spécifiant une liste de clés primaires ou de clés étrangères. "
 
 #. Tag: para
-#: performance.xml:81
 #, no-c-format
 msgid "Hibernate also distinguishes between:"
 msgstr "Hibernate fait également la distinction entre :"
 
 #. Tag: para
-#: performance.xml:87
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Immediate fetching</emphasis>: an association, collection or "
 "attribute is fetched immediately when the owner is loaded."
 msgstr ""
 "<emphasis>Chargement immédiat</emphasis> - Une association, une collection "
 "ou un attribut est chargé immédiatement lorsque l'objet auquel appartient "
-"cet élément est chargé."
+"cet élément est chargé. "
 
 #. Tag: para
-#: performance.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Lazy collection fetching</emphasis>: a collection is fetched when "
 "the application invokes an operation upon that collection. This is the "
 "default for collections."
 msgstr ""
-"<emphasis>Chargement tardif d'une collection</emphasis> - Une collection est "
-"chargée lorque l'application invoque une méthode sur cette collection (il "
-"s'agit du mode de chargement par défaut pour les collections)."
+"<emphasis>Chargement différé d'une collection</emphasis> - Une collection "
+"est chargée lorsque l'application invoque une méthode sur cette collection "
+"(il s'agit du mode de chargement par défaut pour les collections). "
 
 #. Tag: para
-#: performance.xml:100
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>\"Extra-lazy\" collection fetching</emphasis>: individual elements "
 "of the collection are accessed from the database as needed. Hibernate tries "
 "not to fetch the whole collection into memory unless absolutely needed. It "
 "is suitable for large collections."
 msgstr ""
-"<emphasis>Chargement \"super tardif\" d'une collection</emphasis> - les "
-"éléments de la collection sont récupérés individuellement depuis la base de "
-"données lorsque nécessaire. Hibernate essaie de ne pas charger toute la "
-"collection en mémoire sauf si cela est absolument nécessaire (bien adapté "
-"aux très grandes collections)."
+"<emphasis>Chargement \"super différé\" d'une collection</emphasis> - On "
+"accède aux éléments de la collection depuis la base de données lorsque c'est "
+"nécessaire. Hibernate essaie de ne pas charger toute la collection en "
+"mémoire sauf si cela est absolument nécessaire (bien adapté aux très grandes "
+"collections). "
 
 #. Tag: para
-#: performance.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Proxy fetching</emphasis>: a single-valued association is fetched "
 "when a method other than the identifier getter is invoked upon the "
 "associated object."
 msgstr ""
-"<emphasis>Chargement par proxy</emphasis> - une association vers un seul "
+"<emphasis>Chargement par proxy</emphasis> - Une association vers un seul "
 "objet est chargée lorsqu'une méthode autre que le getter sur l'identifiant "
 "est appelée sur l'objet associé."
 
 #. Tag: para
-#: performance.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>\"No-proxy\" fetching</emphasis>: a single-valued association is "
 "fetched when the instance variable is accessed. Compared to proxy fetching, "
@@ -170,28 +162,27 @@
 "instrumentation and is rarely necessary."
 msgstr ""
 "<emphasis>Chargement \"sans proxy\"</emphasis> - une association vers un "
-"seul objet est chargée lorsque l'on accède à cet objet. Par rapport au "
-"chargement par proxy, cette approche est moins tardif (l'association est "
-"quand même chargée même si on n'accède qu'à l'identifiant) mais plus "
-"transparente car il n'y a pas de proxy visible dans l'application. Cette "
-"approche requiert une instrumentation du bytecode à la compilation et est "
-"rarement nécessaire."
+"seul objet est chargée lorsque l'on accède à la variable d'instance. Par "
+"rapport au chargement par proxy, cette approche est moins différée "
+"(l'association est quand même chargée même si on n'accède qu'à "
+"l'identifiant) mais plus transparente car il n'y a pas de proxy visible dans "
+"l'application. Cette approche requiert une instrumentation du bytecode à la "
+"compilation et est rarement nécessaire. "
 
 #. Tag: para
-#: performance.xml:125
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Lazy attribute fetching</emphasis>: an attribute or single valued "
 "association is fetched when the instance variable is accessed. This approach "
 "requires buildtime bytecode instrumentation and is rarely necessary."
 msgstr ""
-"<emphasis>Chargement tardif des attributs</emphasis> - Un attribut ou un "
-"objet associé seul est chargé lorsque l'on y accède. Cette approche requiert "
-"une instrumentation du bytecode à la compilation et est rarement nécessaire."
+"<emphasis>Chargement différé des attributs</emphasis> - Un attribut ou un "
+"objet associé seul est chargé lorsque l'on accède à la variable d'instance. "
+"Cette approche requiert une instrumentation du bytecode à la compilation et "
+"est rarement nécessaire. "
 
 #. Tag: para
-#: performance.xml:134
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We have two orthogonal notions here: <emphasis>when</emphasis> is the "
 "association fetched and <emphasis>how</emphasis> is it fetched. It is "
@@ -202,90 +193,68 @@
 msgstr ""
 "Nous avons ici deux notions orthogonales : <emphasis>quand</emphasis> "
 "l'association est chargée et <emphasis>comment</emphasis> (quelle requête "
-"SQL est utilisée). Il ne faut pas confondre les deux. Le mode de chargement "
-"est utilisé pour améliorer les performances. On peut utiliser le mode tardif "
-"pour définir un contrat sur quelles données sont toujours accessibles sur "
-"une instance détachée d'une classe particulière."
+"SQL est utilisée). Il ne faut pas les confondre. Le mode de chargement "
+"<literal>fetch</literal> est utilisé pour améliorer les performances. On "
+"peut utiliser le mode <literal>lazy</literal> pour définir un contrat sur "
+"quelles données sont toujours accessibles sur toute instance détachée d'une "
+"classe particulière. "
 
 #. Tag: title
-#: performance.xml:143
 #, no-c-format
 msgid "Working with lazy associations"
-msgstr "Travailler avec des associations chargées tardivement"
+msgstr "Travailler avec des associations chargées en différé"
 
 #. Tag: para
-#: performance.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "By default, Hibernate3 uses lazy select fetching for collections and lazy "
 "proxy fetching for single-valued associations. These defaults make sense for "
 "most associations in the majority of applications."
 msgstr ""
-"Par défaut, Hibernate3 utilise le chargement tardif par select pour les "
-"collections et le chargement tardif par proxy pour les associations vers un "
+"Par défaut, Hibernate3 utilise le chargement différé par select pour les "
+"collections et le chargement différé par proxy pour les associations vers un "
 "seul objet. Ces valeurs par défaut sont valables pour la plupart des "
-"associations dans la plupart des applications."
+"associations dans la plupart des applications. "
 
 #. Tag: para
-#: performance.xml:151
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you set <literal>hibernate.default_batch_fetch_size</literal>, Hibernate "
 "will use the batch fetch optimization for lazy fetching. This optimization "
 "can also be enabled at a more granular level."
 msgstr ""
-"<emphasis>Note :</emphasis> si vous définissez <literal>hibernate."
-"default_batch_fetch_size</literal>, Hibernate va utiliser l'optimisation du "
-"chargement par lot pour le chargement tardif (cette optimisation peut aussi "
-"être activée à un niveau de granularité plus fin)."
+"Si vous définissez <literal>hibernate.default_batch_fetch_size</literal>, "
+"Hibernate va utiliser l'optimisation du chargement par lot pour le "
+"chargement différé (cette optimisation peut aussi être activée à un niveau "
+"de granularité plus fin). "
 
 #. Tag: para
-#: performance.xml:158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please be aware that access to a lazy association outside of the context of "
 "an open Hibernate session will result in an exception. For example:"
 msgstr ""
-"Cependant, le chargement tardif pose un problème qu'il faut connaitre. "
-"L'accès à une association définie comme \"tardive\", hors du contexte d'une "
-"session hibernate ouverte, va conduire à une exception. Par exemple :"
+"L'accès à une association définie comme \"différé\", hors du contexte d'une "
+"session Hibernate ouverte, entraîne une exception. Par exemple : "
 
-#. Tag: programlisting
-#: performance.xml:164
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[s = sessions.openSession();\n"
-"Transaction tx = s.beginTransaction();\n"
-"            \n"
-"User u = (User) s.createQuery(\"from User u where u.name=:userName\")\n"
-"    .setString(\"userName\", userName).uniqueResult();\n"
-"Map permissions = u.getPermissions();\n"
-"\n"
-"tx.commit();\n"
-"s.close();\n"
-"\n"
-"Integer accessLevel = (Integer) permissions.get(\"accounts\");  // Error!]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:166
-#, fuzzy, no-c-format
-msgid ""
 "Since the permissions collection was not initialized when the "
 "<literal>Session</literal> was closed, the collection will not be able to "
 "load its state. <emphasis>Hibernate does not support lazy initialization for "
 "detached objects</emphasis>. This can be fixed by moving the code that reads "
 "from the collection to just before the transaction is committed."
 msgstr ""
-"Etant donné que la collection des permissions n'a pas été initialisée avant "
-"que la <literal>Session</literal> soit fermée, la collection n'est pas "
-"capable de se charger. <emphasis>Hibernate ne supporte pas le chargement "
-"tardif pour des objets détachés</emphasis>. La solution à ce problème est de "
-"déplacer le code qui lit la collection avant le \"commit\" de la transaction."
+"Étant donné que la collection des permissions n'a pas été initialisée avant "
+"de fermer la <literal>Session</literal>, la collection n'est pas capable de "
+"charger son état. <emphasis>Hibernate ne supporte pas le chargement différé "
+"pour des objets détachés</emphasis>. La solution à ce problème est de "
+"déplacer le code qui lit à partir de la collection avant le \"commit\" de la "
+"transaction. "
 
 #. Tag: para
-#: performance.xml:174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, you can use a non-lazy collection or association, by "
 "specifying <literal>lazy=\"false\"</literal> for the association mapping. "
@@ -295,16 +264,15 @@
 "in every transaction."
 msgstr ""
 "Une autre alternative est d'utiliser une collection ou une association non "
-"\"tardive\" en spécifiant <literal>lazy=\"false\"</literal> dans le mapping "
-"de l'association. Cependant il est prévu que le chargement tardif soit "
+"\"différée\" en spécifiant <literal>lazy=\"false\"</literal> dans le mappage "
+"de l'association. Cependant il est prévu que le chargement différé soit "
 "utilisé pour quasiment toutes les collections ou associations. Si vous "
-"définissez trop d'associtions non \"tardives\" dans votre modèle objet, "
+"définissez trop d'associations non \"différées\" dans votre modèle objet, "
 "Hibernate va finir par devoir charger toute la base de données en mémoire à "
-"chaque transaction !"
+"chaque transaction."
 
 #. Tag: para
-#: performance.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "On the other hand, you can use join fetching, which is non-lazy by nature, "
 "instead of select fetching in a particular transaction. We will now explain "
@@ -312,79 +280,55 @@
 "choosing a fetch strategy are identical for single-valued associations and "
 "collections."
 msgstr ""
-"D'un autre côté, on veut souvent choisir un chargement par jointure (qui est "
-"par défaut non tardif) à la place du chargement par select dans une "
+"Par ailleurs, on veut souvent choisir un chargement par jointure (qui est "
+"par défaut non différé) à la place du chargement par select dans une "
 "transaction particulière. Nous allons maintenant voir comment adapter les "
 "stratégies de chargement. Dans Hibernate3 les mécanismes pour choisir une "
 "stratégie de chargement sont identiques que l'on ait une association vers un "
-"objet simple ou vers une collection."
+"objet simple ou vers une collection. "
 
 #. Tag: title
-#: performance.xml:194
 #, no-c-format
 msgid "Tuning fetch strategies"
 msgstr "Personnalisation des stratégies de chargement"
 
 #. Tag: para
-#: performance.xml:196
 #, no-c-format
 msgid ""
 "Select fetching (the default) is extremely vulnerable to N+1 selects "
 "problems, so we might want to enable join fetching in the mapping document:"
 msgstr ""
 "Le chargement par select (mode par défaut) est très vulnérable au problème "
-"du N+1 selects, du coup vous pouvez avoir envie d'activer le chargement par "
-"jointure dans les fichiers de mapping :"
+"du N+1 selects, ainsi vous souhaiterez peut-être activer le chargement par "
+"jointure dans les fichiers de mappage :"
 
-#. Tag: programlisting
-#: performance.xml:201
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"permissions\" \n"
-"            fetch=\"join\">\n"
-"    <key column=\"userId\"/>\n"
-"    <one-to-many class=\"Permission\"/>\n"
-"</set]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: performance.xml:203
-#, no-c-format
-msgid "<![CDATA[<many-to-one name=\"mother\" class=\"Cat\" fetch=\"join\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:205
 #, no-c-format
 msgid ""
 "The <literal>fetch</literal> strategy defined in the mapping document "
 "affects:"
 msgstr ""
 "La stratégie de chargement définie à l'aide du mot <literal>fetch</literal> "
-"dans les fichiers de mapping affecte :"
+"dans les fichiers de mappage affecte :"
 
 #. Tag: para
-#: performance.xml:211
 #, no-c-format
 msgid "retrieval via <literal>get()</literal> or <literal>load()</literal>"
 msgstr ""
 "La récupération via <literal>get()</literal> ou <literal>load()</literal>"
 
 #. Tag: para
-#: performance.xml:216
 #, no-c-format
 msgid "retrieval that happens implicitly when an association is navigated"
 msgstr ""
 "La récupération implicite lorsque l'on navigue à travers une association"
 
 #. Tag: para
-#: performance.xml:221
 #, no-c-format
 msgid "<literal>Criteria</literal> queries"
-msgstr "Les requêtes de type <literal>Criteria</literal>"
+msgstr "Les requêtes par <literal>Criteria</literal>"
 
 #. Tag: para
-#: performance.xml:226
 #, no-c-format
 msgid "HQL queries if <literal>subselect</literal> fetching is used"
 msgstr ""
@@ -392,21 +336,18 @@
 "literal>"
 
 #. Tag: para
-#: performance.xml:232
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Irrespective of the fetching strategy you use, the defined non-lazy graph is "
 "guaranteed to be loaded into memory. This might, however, result in several "
 "immediate selects being used to execute a particular HQL query."
 msgstr ""
 "Quelle que soit la stratégie de chargement que vous utilisez, la partie du "
-"graphe d'objets qui est définie comme non \"tardive\" sera chargée en "
-"mémoire. Cela peut mener à l'exécution de plusieurs selects successifs pour "
-"une seule requête HQL."
+"graphe d'objets, non-différée, sera chargée en mémoire. Cela peut mener à "
+"l'exécution de plusieurs selects successifs pour une seule requête HQL. "
 
 #. Tag: para
-#: performance.xml:238
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Usually, the mapping document is not used to customize fetching. Instead, we "
 "keep the default behavior, and override it for a particular transaction, "
@@ -415,66 +356,51 @@
 "the <literal>Criteria</literal> query API, you would use "
 "<literal>setFetchMode(FetchMode.JOIN)</literal>."
 msgstr ""
-"On n'utilise pas souvent les documents de mapping pour adapter le "
-"chargement. Au lieu de cela, on conserve le comportement par défaut et on le "
+"On n'utilise pas souvent les documents de mappage pour adapter le "
+"chargement. En revanche, on conserve le comportement par défaut et on le "
 "surcharge pour une transaction particulière en utilisant <literal>left join "
-"fetch</literal> dans les requêtes HQL. Cela indique à hibernate à Hibernate "
-"de charger l'association de manière agressive lors du premier select en "
-"utilisant une jointure externe. Dans l'API Criteria vous pouvez utiliser la "
-"méthode <literal>setFetchMode(FetchMode.JOIN)</literal>"
+"fetch</literal> dans les requêtes HQL. Cela indique à Hibernate de charger "
+"l'association de manière agressive lors du premier select en utilisant une "
+"jointure externe. Dans la requête API <literal>Criteria</literal> vous "
+"utiliserez la méthode <literal>setFetchMode(FetchMode.JOIN)</literal>."
 
 #. Tag: para
-#: performance.xml:247
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want to change the fetching strategy used by <literal>get()</literal> "
 "or <literal>load()</literal>, you can use a <literal>Criteria</literal> "
 "query. For example:"
 msgstr ""
-"Si vous ne vous sentez pas prêt à modifier la stratégie de chargement "
-"utilisé par <literal>get()</literal> ou <literal>load()</literal>, vous "
+"S'il vous arrive de vouloir changer la stratégie de chargement utilisée par "
+"utilisée par <literal>get()</literal> ou <literal>load()</literal>, vous "
 "pouvez juste utiliser une requête de type <literal>Criteria</literal> comme "
-"par exemple :"
+"par exemple : "
 
-#. Tag: programlisting
-#: performance.xml:253
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[User user = (User) session.createCriteria(User.class)\n"
-"                .setFetchMode(\"permissions\", FetchMode.JOIN)\n"
-"                .add( Restrictions.idEq(userId) )\n"
-"                .uniqueResult();]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:255
-#, fuzzy, no-c-format
-msgid ""
 "This is Hibernate's equivalent of what some ORM solutions call a \"fetch plan"
 "\"."
 msgstr ""
-"(Il s'agit de l'équivalent pour Hibernate de ce que d'autres outils de "
-"mapping appellent un \"fetch plan\" ou \"plan de chargement\")"
+"Il s'agit de l'équivalent pour Hibernate de ce que d'autres outils de "
+"mappage appellent un \"fetch plan\" ou \"plan de chargement\"."
 
 #. Tag: para
-#: performance.xml:259
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A completely different approach to problems with N+1 selects is to use the "
 "second-level cache."
 msgstr ""
 "Une autre manière complètement différente d'éviter le problème des N+1 "
-"selects est d'utiliser le cache de second niveau."
+"selects est d'utiliser le cache de second niveau. "
 
 #. Tag: title
-#: performance.xml:267
 #, no-c-format
 msgid "Single-ended association proxies"
-msgstr "Proxys pour des associations vers un seul objet"
+msgstr "Proxies pour des associations vers un seul objet "
 
 #. Tag: para
-#: performance.xml:269
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Lazy fetching for collections is implemented using Hibernate's own "
 "implementation of persistent collections. However, a different mechanism is "
@@ -483,29 +409,27 @@
 "proxies for persistent objects using runtime bytecode enhancement which is "
 "accessed via the CGLIB library."
 msgstr ""
-"Le chargement tardif des collections est implémenté par Hibernate en "
-"utilisant ses propres implémentations pour des collections persistantes. Si "
-"l'on veut un chargement tardif pour des associations vers un seul objet "
-"métier il faut utiliser un autre mécanisme. L'entité qui est pointée par "
-"l'association doit être masquée derrière un proxy. Hibernate implémente "
-"l'initialisation tardive des proxys sur des objets persistents via une mise "
-"à jour à chaud du bytecode (à l'aide de l'excellente librairie CGLIB)."
+"Le chargement différé des collections est implémenté par Hibernate qui "
+"utilise ses propres implémentations pour des collections persistantes. Si "
+"l'on veut un chargement différé pour des associations vers un seul objet, il "
+"faut utiliser un autre mécanisme. L'entité qui est pointée par l'association "
+"doit être masquée derrière un proxy. Hibernate implémente l'initialisation "
+"différée des proxies sur des objets persistants via une mise à jour à chaud "
+"du bytecode (à l'aide de l'excellente librairie CGLIB)."
 
 #. Tag: para
-#: performance.xml:277
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "At startup, Hibernate3 generates proxies by default for all persistent "
 "classes and uses them to enable lazy fetching of <literal>many-to-one</"
 "literal> and <literal>one-to-one</literal> associations."
 msgstr ""
-"Par défaut, Hibernate génère des proxys (au démarrage) pour toutes les "
-"classes persistantes et les utilise pour activer le chargement tardif des "
+"Par défaut, Hibernate génère des proxies (au démarrage) pour toutes les "
+"classes persistantes et les utilise pour activer le chargement différé des "
 "associations <literal>many-to-one</literal> et <literal>one-to-one</literal>."
 
 #. Tag: para
-#: performance.xml:283
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The mapping file may declare an interface to use as the proxy interface for "
 "that class, with the <literal>proxy</literal> attribute. By default, "
@@ -513,38 +437,24 @@
 "implement a default constructor with at least package visibility. This "
 "constructor is recommended for all persistent classes</emphasis>."
 msgstr ""
-"Le fichier de mapping peut déclarer une interface qui sera utilisée par le "
-"proxy d'interfaçage pour cette classe à l'aide de l'attribut <literal>proxy</"
-"literal>. Par défaut Hibernate utilises une sous classe de la classe "
-"persistante. <emphasis>Il faut que les classes pour lesquelles on ajoute un "
-"proxy implémentent un constructeur par défaut de visibilité au moins "
-"package. Ce constructeur est recommandé pour toutes les classes "
-"persistantes !</emphasis>"
+"Le fichier de mappage peut déclarer une interface à utiliser comme interface "
+"de proxy pour cette classe à l'aide de l'attribut <literal>proxy</literal>. "
+"Par défaut Hibernate utilise une sous-classe de la classe persistante. "
+"<emphasis>Il faut que les classes pour lesquelles on ajoute un proxy "
+"implémentent un constructeur par défaut avec au minimum une visibilité de "
+"paquetage. Ce constructeur est recommandé pour toutes les classes "
+"persistantes !</emphasis>."
 
 #. Tag: para
-#: performance.xml:290
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are potential problems to note when extending this approach to "
 "polymorphic classes.For example:"
 msgstr ""
 "Il y a quelques précautions à prendre lorsque l'on étend cette approche à "
-"des classes polymorphiques, exemple :"
+"des classes polymorphiques, par exemple : "
 
-#. Tag: programlisting
-#: performance.xml:294
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Cat\" proxy=\"Cat\">\n"
-"    ......\n"
-"    <subclass name=\"DomesticCat\">\n"
-"        .....\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:296
 #, no-c-format
 msgid ""
 "Firstly, instances of <literal>Cat</literal> will never be castable to "
@@ -552,44 +462,17 @@
 "instance of <literal>DomesticCat</literal>:"
 msgstr ""
 "Tout d'abord, les instances de <literal>Cat</literal> ne pourront jamais "
-"être \"castées\" en <literal>DomesticCat</literal>, même si l'instance sous "
+"être \"castées\" en <literal>DomesticCat</literal>, même si l'instance sous-"
 "jacente est une instance de <literal>DomesticCat</literal> :"
 
-#. Tag: programlisting
-#: performance.xml:302
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);  // instantiate a "
-"proxy (does not hit the db)\n"
-"if ( cat.isDomesticCat() ) {                  // hit the db to initialize "
-"the proxy\n"
-"    DomesticCat dc = (DomesticCat) cat;       // Error!\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:304
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Secondly, it is possible to break proxy <literal>==</literal>:"
 msgstr ""
-"Deuxièmement, il est possible de casser la notion d'<literal>==</literal> "
-"des proxy."
+"Deuxièmement, il est possible de casser la notion de <literal>==</literal> "
+"des proxies. "
 
-#. Tag: programlisting
-#: performance.xml:308
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);            // "
-"instantiate a Cat proxy\n"
-"DomesticCat dc = \n"
-"        (DomesticCat) session.load(DomesticCat.class, id);  // acquire new "
-"DomesticCat proxy!\n"
-"System.out.println(cat==dc);                            // false]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:310
 #, no-c-format
 msgid ""
 "However, the situation is not quite as bad as it looks. Even though we now "
@@ -597,45 +480,34 @@
 "still be the same object:"
 msgstr ""
 "Cette situation n'est pas si mauvaise qu'il n'y parait. Même si nous avons "
-"deux références à deux objets proxys différents, l'instance de base sera "
-"quand même le même objet :"
+"deux références à deux objets proxies différents, l'instance sous-jacente "
+"sera quand même le même objet :"
 
-#. Tag: programlisting
-#: performance.xml:315
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[cat.setWeight(11.0);  // hit the db to initialize the proxy\n"
-"System.out.println( dc.getWeight() );  // 11.0]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:317
-#, fuzzy, no-c-format
-msgid ""
 "Third, you cannot use a CGLIB proxy for a <literal>final</literal> class or "
 "a class with any <literal>final</literal> methods."
 msgstr ""
 "Troisièmement, vous ne pourrez pas utiliser un proxy CGLIB pour une classe "
 "<literal>final</literal> ou pour une classe contenant la moindre méthode "
-"<literal>final</literal>."
+"<literal>final</literal>. "
 
 #. Tag: para
-#: performance.xml:322
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, if your persistent object acquires any resources upon instantiation "
 "(e.g. in initializers or default constructor), then those resources will "
 "also be acquired by the proxy. The proxy class is an actual subclass of the "
 "persistent class."
 msgstr ""
-"Enfin, si votre objet persistant obtient une ressource à l'instanciation "
-"(par example dans les initialiseurs ou dans le contructeur par défaut), "
-"alors ces ressources seront aussi obtenues par le proxy. La classe proxy est "
-"vraiment une sous classe de la classe persistante."
+"Enfin, si votre objet persistant obtient une quelconque ressource à "
+"l'instanciation (par exemple dans les initialiseurs ou dans le constructeur "
+"par défaut), alors ces ressources seront aussi obtenues par le proxy. La "
+"classe proxy est en réalité une sous-classe de la classe persistante. "
 
 #. Tag: para
-#: performance.xml:328
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These problems are all due to fundamental limitations in Java's single "
 "inheritance model. To avoid these problems your persistent classes must each "
@@ -649,101 +521,74 @@
 "d'héritage unique de Java. Si vous souhaitez éviter ces problèmes, vos "
 "classes persistantes doivent chacune implémenter une interface qui déclare "
 "ses méthodes métier. Vous devriez alors spécifier ces interfaces dans le "
-"fichier de mapping :"
+"fichier de mappage : <literal>CatImpl</literal> implémente l'interface "
+"<literal>Cat</literal> et <literal>DomesticCatImpl</literal> implémente "
+"l'interface <literal>DomesticCat</literal>. Par exemple :"
 
-#. Tag: programlisting
-#: performance.xml:336
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"CatImpl\" proxy=\"Cat\">\n"
-"    ......\n"
-"    <subclass name=\"DomesticCatImpl\" proxy=\"DomesticCat\">\n"
-"        .....\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:338
-#, fuzzy, no-c-format
-msgid ""
 "Then proxies for instances of <literal>Cat</literal> and "
 "<literal>DomesticCat</literal> can be returned by <literal>load()</literal> "
 "or <literal>iterate()</literal>."
 msgstr ""
-"Tout d'abord, les instances de <literal>Cat</literal> ne pourront jamais "
-"être \"castées\" en <literal>DomesticCat</literal>, même si l'instance sous "
-"jacente est une instance de <literal>DomesticCat</literal> :"
+"Tout d'abord, les instances de <literal>Cat</literal> et de "
+"<literal>DomesticCat</literal> peuvent être retournées par <literal>load()</"
+"literal> ou par <literal>iterate()</literal>."
 
-#. Tag: programlisting
-#: performance.xml:343
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(CatImpl.class, catid);\n"
-"Iterator iter = session.createQuery(\"from CatImpl as cat where cat."
-"name='fritz'\").iterate();\n"
-"Cat fritz = (Cat) iter.next();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:346
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Remarque"
 
 #. Tag: para
-#: performance.xml:347
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>list()</literal> does not usually return proxies."
-msgstr "Les requêtes de type <literal>Criteria</literal>"
+msgstr "<literal>list()</literal> ne retourne pas les proxies normalement."
 
 #. Tag: para
-#: performance.xml:352
 #, no-c-format
 msgid ""
 "Relationships are also lazily initialized. This means you must declare any "
 "properties to be of type <literal>Cat</literal>, not <literal>CatImpl</"
 "literal>."
 msgstr ""
-"Les relations sont aussi initialisées tardivement. Ceci signifie que vous "
+"Les relations sont aussi initialisées en différé. Ceci signifie que vous "
 "devez déclarer chaque propriété comme étant de type <literal>Cat</literal>, "
 "et non <literal>CatImpl</literal>."
 
 #. Tag: para
-#: performance.xml:357
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Certain operations do <emphasis>not</emphasis> require proxy initialization:"
-msgstr "Certaines opérations ne nécessitent pas l'initialisation du proxy"
+msgstr ""
+"Certaines opérations ne nécessitent <emphasis>pas</emphasis> "
+"l'initialisation du proxy :"
 
 #. Tag: para
-#: performance.xml:363
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>equals()</literal>: if the persistent class does not override "
 "<literal>equals()</literal>"
 msgstr ""
 "<literal>equals()</literal>, si la classe persistante ne surcharge pas "
-"<literal>equals()</literal>"
+"<literal>equals()</literal> "
 
 #. Tag: para
-#: performance.xml:369
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>hashCode()</literal>: if the persistent class does not override "
 "<literal>hashCode()</literal>"
 msgstr ""
 "<literal>hashCode()</literal>, si la classe persistante ne surcharge pas "
-"<literal>hashCode()</literal>"
+"<literal>hashCode()</literal> "
 
 #. Tag: para
-#: performance.xml:375
 #, no-c-format
 msgid "The identifier getter method"
-msgstr "Le getter de l'identifiant"
+msgstr "La méthode getter de l'identifiant "
 
 #. Tag: para
-#: performance.xml:381
 #, no-c-format
 msgid ""
 "Hibernate will detect persistent classes that override <literal>equals()</"
@@ -753,8 +598,7 @@
 "ou <literal>hashCode()</literal>."
 
 #. Tag: para
-#: performance.xml:386
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "By choosing <literal>lazy=\"no-proxy\"</literal> instead of the default "
 "<literal>lazy=\"proxy\"</literal>, you can avoid problems associated with "
@@ -764,18 +608,16 @@
 "Eh choisissant <literal>lazy=\"no-proxy\"</literal> au lieu de <literal>lazy="
 "\"proxy\"</literal> qui est la valeur par défaut, il est possible d'éviter "
 "les problèmes liés au transtypage. Il faudra alors une instrumentation du "
-"bytecode à la compilation et toutes les opérations résulterons immédiatement "
-"en une initialisation du proxy."
+"bytecode à la compilation et toutes les opérations résulteront immédiatement "
+"en une initialisation du proxy. "
 
 #. Tag: title
-#: performance.xml:396
 #, no-c-format
 msgid "Initializing collections and proxies"
-msgstr "Initialisation des collections et des proxys"
+msgstr "Initialisation des collections et des proxies"
 
 #. Tag: para
-#: performance.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>LazyInitializationException</literal> will be thrown by Hibernate "
 "if an uninitialized collection or proxy is accessed outside of the scope of "
@@ -783,14 +625,13 @@
 "or having the reference to the proxy is in the detached state."
 msgstr ""
 "Une exception de type <literal>LazyInitializationException</literal> sera "
-"renvoyée par hibernate si une collection ou un proxy non initialisé est "
-"accédé en dehors de la portée de la <literal>Session</literal>, e.g. lorsque "
-"l'entité à laquelle appartient la collection ou qui a une référence vers le "
-"proxy est dans l'état \"détachée\"."
+"renvoyée par Hibernate si une collection ou un proxy non initialisé est "
+"accédé en dehors de la portée de la <literal>Session</literal>, par ex. "
+"lorsque l'entité à laquelle appartient la collection ou qui a une référence "
+"vers le proxy, est dans l'état \"détaché\". "
 
 #. Tag: para
-#: performance.xml:404
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes a proxy or collection needs to be initialized before closing the "
 "<literal>Session</literal>. You can force initialization by calling "
@@ -799,15 +640,14 @@
 "and it is not convenient for generic code."
 msgstr ""
 "Parfois, nous devons nous assurer qu'un proxy ou une collection est "
-"initialisée avant de fermer la <literal>Session</literal>. Bien sûr, nous "
+"initialisé avant de fermer la <literal>Session</literal>. Bien sûr, nous "
 "pouvons toujours forcer l'initialisation en appelant par exemple "
 "<literal>cat.getSex()</literal> ou <literal>cat.getKittens().size()</"
 "literal>. Mais ceci n'est pas très lisible pour les personnes parcourant le "
-"code et n'est pas très générique."
+"code et n'est pas approprié pour le code générique. "
 
 #. Tag: para
-#: performance.xml:411
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The static methods <literal>Hibernate.initialize()</literal> and "
 "<literal>Hibernate.isInitialized()</literal>, provide the application with a "
@@ -819,15 +659,14 @@
 msgstr ""
 "Les méthodes statiques <literal>Hibernate.initialize()</literal> et "
 "<literal>Hibernate.isInitialized()</literal> fournissent à l'application un "
-"moyen de travailler avec des proxys ou des collections initialisés. "
+"moyen de travailler avec des proxies ou des collections initialisés. "
 "<literal>Hibernate.initialize(cat)</literal> forcera l'initialisation d'un "
 "proxy de <literal>cat</literal>, si tant est que sa <literal>Session</"
 "literal> est ouverte. <literal>Hibernate.initialize( cat.getKittens() )</"
-"literal> a le même effet sur la collection kittens."
+"literal> a le même effet sur la collection kittens. "
 
 #. Tag: para
-#: performance.xml:420
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Another option is to keep the <literal>Session</literal> open until all "
 "required collections and proxies have been loaded. In some application "
@@ -838,17 +677,16 @@
 "are two basic ways to deal with this issue:"
 msgstr ""
 "Une autre option est de conserver la <literal>Session</literal> ouverte "
-"jusqu'à ce que toutes les collections et tous les proxys aient été chargés. "
-"Dans certaines architectures applicatives, particulièrement celles ou le "
-"code d'accès aux données via hiberante et le code qui utilise ces données "
-"sont dans des couches applicatives différentes ou des processus physiques "
-"différents, il peut devenir problématique de garantir que la "
+"jusqu'à ce que toutes les collections et tous les proxies nécessaires aient "
+"été chargés. Dans certaines architectures applicatives, particulièrement "
+"celles ou le code d'accès aux données via Hiberante et le code qui utilise "
+"ces données sont dans des couches applicatives différentes ou des processus "
+"physiques différents, il sera alors difficile de garantir que la "
 "<literal>Session</literal> est ouverte lorsqu'une collection est "
-"initialisée. Il y a deux moyens de traiter ce problème :"
+"initialisée. Il y a deux moyens de maîtriser ce problème : "
 
 #. Tag: para
-#: performance.xml:431
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In a web-based application, a servlet filter can be used to close the "
 "<literal>Session</literal> only at the end of a user request, once the "
@@ -863,16 +701,15 @@
 "Dans une application web, un filtre de servlet peut être utilisé pour fermer "
 "la <literal>Session</literal> uniquement lorsque la requête a été "
 "entièrement traitée, lorsque le rendu de la vue est fini (il s'agit du "
-"pattern <emphasis>Open Session in View</emphasis>). Bien sûr, cela demande "
-"plus d'attention à la bonne gestion des exceptions de l'application. Il est "
-"d'une importance vitale que la <literal>Session</literal> soit fermée et la "
-"transaction terminée avant que l'on rende la main à l'utilisateur même si "
-"une exception survient durant le traitement de la vue. Voir le wiki "
-"Hibernate pour des exemples sur le pattern \"Open Session in View\"."
+"modèle <emphasis>Vue de la session ouverte</emphasis>). Bien sûr, cela "
+"demande plus d'attention à la bonne gestion des exceptions de l'application. "
+"Il est d'une importance vitale que la <literal>Session</literal> soit fermée "
+"et la transaction terminée avant que l'on rende la main à l'utilisateur même "
+"si une exception survient durant le traitement de la vue. Voir le wiki "
+"Hibernate pour des exemples sur le modèle \"Open Session in View\". "
 
 #. Tag: para
-#: performance.xml:444
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In an application with a separate business tier, the business logic must "
 "\"prepare\" all collections that the web tier needs before returning. This "
@@ -886,24 +723,23 @@
 "literal>. This is usually easier if you adopt the <emphasis>Command</"
 "emphasis> pattern instead of a <emphasis>Session Facade</emphasis>."
 msgstr ""
-"Dans une application avec une couche métier séparée, la couche contenant la "
-"logique métier doit \"préparer\" toutes les collections qui seront "
-"nécessaires à la couche web avant de retourner les données. Cela signifie "
-"que la couche métier doit charger toutes les données et retourner toutes les "
-"données déjà initialisées à la couche de présentation/web pour un cas "
-"d'utilisation donné. En général l'application appelle la méthode "
-"<literal>Hibernate.initialize()</literal> pour chaque collection nécessaire "
-"dans la couche web (cet appel doit être fait avant la fermeture de la "
-"session) ou bien récupère les collections de manière agressive à l'aide "
-"d'une requête HQL avec une clause <literal>FETCH</literal> ou à l'aide du "
-"mode <literal>FetchMode.JOIN</literal> pour une requête de type "
-"<literal>Criteria</literal>. Cela est en général plus facile si vous "
-"utilisez le pattern <emphasis>Command</emphasis> plutôt que "
-"<emphasis>Session Facade</emphasis>."
+"Dans une application avec une couche métier multiniveaux séparée, la couche "
+"contenant la logique métier doit \"préparer\" toutes les collections qui "
+"seront nécessaires à la couche web multiniveaux avant de retourner les "
+"données. Cela signifie que la couche métier doit charger toutes les données "
+"et retourner toutes les données déjà initialisées à la couche de "
+"présentation/web pour un cas d'utilisation donné. En général l'application "
+"appelle la méthode <literal>Hibernate.initialize()</literal> pour chaque "
+"collection nécessaire dans la couche web (cet appel doit être fait avant la "
+"fermeture de la session) ou bien récupère les collections de manière "
+"agressive à l'aide d'une requête HQL avec une clause <literal>FETCH</"
+"literal> ou à l'aide du mode <literal>FetchMode.JOIN</literal> pour une "
+"requête de type <literal>Criteria</literal>. Cela est en général plus facile "
+"si vous utilisez le modèle <emphasis>Command</emphasis> plutôt que "
+"<emphasis>Session Facade</emphasis>. "
 
 #. Tag: para
-#: performance.xml:459
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also attach a previously loaded object to a new <literal>Session</"
 "literal> with <literal>merge()</literal> or <literal>lock()</literal> before "
@@ -913,25 +749,23 @@
 msgstr ""
 "Vous pouvez également attacher à une <literal>Session</literal> un objet "
 "chargé au préalable à l'aide des méthodes <literal>merge()</literal> ou "
-"<literal>lock()</literal> avant d'accéder aux collections (ou aux proxys) "
-"non initialisés. Non, Hibernate ne fait pas, et ne doit pas faire, cela "
+"<literal>lock()</literal> avant d'accéder aux collections (ou aux proxies) "
+"non initialisés. Non, Hibernate ne fait pas, et ne doit pas faire cela "
 "automatiquement car cela pourrait introduire une sémantique transactionnelle "
-"ad hoc."
+"ad hoc. "
 
 #. Tag: para
-#: performance.xml:469
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes you do not want to initialize a large collection, but still need "
 "some information about it, like its size, for example, or a subset of the "
 "data."
 msgstr ""
 "Parfois, vous ne voulez pas initialiser une grande collection mais vous avez "
-"quand même besoin d'informations sur elle (comme sa taille) ou un sous "
-"ensemble de ses données"
+"quand même besoin d'informations sur elle (comme sa taille) ou un sous-"
+"ensemble de ses données."
 
 #. Tag: para
-#: performance.xml:474
 #, no-c-format
 msgid ""
 "You can use a collection filter to get the size of a collection without "
@@ -940,16 +774,7 @@
 "Vous pouvez utiliser un filtre de collection pour récupérer sa taille sans "
 "l'initialiser :"
 
-#. Tag: programlisting
-#: performance.xml:478
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) s.createFilter( collection, \"select count(*)\" ).list"
-"().get(0) ).intValue()]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:480
 #, no-c-format
 msgid ""
 "The <literal>createFilter()</literal> method is also used to efficiently "
@@ -957,26 +782,16 @@
 "collection:"
 msgstr ""
 "La méthode <literal>createFilter()</literal> est également utilisée pour "
-"récupérer de manière efficace des sous ensembles d'une collection sans avoir "
-"besoin de l'initialiser dans son ensemble."
+"récupérer efficacement des sous-ensembles d'une collection sans avoir besoin "
+"de l'initialiser dans son ensemble :"
 
-#. Tag: programlisting
-#: performance.xml:485
-#, no-c-format
-msgid ""
-"<![CDATA[s.createFilter( lazyCollection, \"\").setFirstResult(0)."
-"setMaxResults(10).list();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:490
 #, no-c-format
 msgid "Using batch fetching"
 msgstr "Utiliser le chargement par lot"
 
 #. Tag: para
-#: performance.xml:492
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Using batch fetching, Hibernate can load several uninitialized proxies if "
 "one proxy is accessed. Batch fetching is an optimization of the lazy select "
@@ -984,15 +799,15 @@
 "the class level and the collection level."
 msgstr ""
 "Pour améliorer les performances, Hibernate peut utiliser le chargement par "
-"lot ce qui veut dire qu'Hibernate peut charger plusieurs proxys (ou "
+"lot ce qui veut dire que Hibernate peut charger plusieurs proxies (ou "
 "collections) non initialisés en une seule requête lorsque l'on accède à l'un "
-"de ces proxys. Le chargement par lot est une optimisation intimement liée à "
-"la stratégie de chargement tardif par select. Il y a deux moyens d'activer "
-"le chargement par lot : au niveau de la classe et au niveau de la collection."
+"de ces proxies. Le chargement par lot est une optimisation intimement liée à "
+"la stratégie de chargement en différé par select. Il y a deux moyens "
+"d'activer le chargement par lot : au niveau de la classe et au niveau de la "
+"collection."
 
 #. Tag: para
-#: performance.xml:498
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Batch fetching for classes/entities is easier to understand. Consider the "
 "following example: at runtime you have 25 <literal>Cat</literal> instances "
@@ -1015,26 +830,19 @@
 "literal> sur chacun d'eux, Hibernate exécutera par défaut 25 "
 "<literal>SELECT</literal>, pour charger les owners (initialiser le proxy). "
 "Vous pouvez paramétrer ce comportement en spécifiant une <literal>batch-"
-"size</literal> (taille du lot) dans le mapping de <literal>Person</literal> :"
+"size</literal> (taille du lot) dans le mappage de <literal>Person</"
+"literal> : "
 
-#. Tag: programlisting
-#: performance.xml:508
-#, no-c-format
-msgid "<![CDATA[<class name=\"Person\" batch-size=\"10\">...</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:510
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will now execute only three queries: the pattern is 10, 10, 5."
 msgstr ""
 "Hibernate exécutera désormais trois requêtes, en chargeant respectivement "
-"10, 10, et 5 entités."
+"10, 10, et 5 entités. "
 
 #. Tag: para
-#: performance.xml:514
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also enable batch fetching of collections. For example, if each "
 "<literal>Person</literal> has a lazy collection of <literal>Cat</literal>s, "
@@ -1045,27 +853,15 @@
 "<literal>Person</literal>, Hibernate can pre-fetch collections:"
 msgstr ""
 "Vous pouvez aussi activer le chargement par lot pour les collections. Par "
-"exemple, si chaque <literal>Person</literal> a une collection chargée "
-"tardivement de <literal>Cat</literal>s, et que 10 personnes sont "
-"actuellement chargées dans la <literal>Session</literal>, itérer sur toutes "
-"les persons générera 10 <literal>SELECT</literal>s, un pour chaque appel de "
+"exemple, si chaque <literal>Person</literal> a une collection chargée en "
+"différé des <literal>Cat</literal>s, et que 10 personnes sont actuellement "
+"chargées dans la <literal>Session</literal>, itérer sur toutes les persons "
+"générera 10 <literal>SELECT</literal> s, un pour chaque appel de "
 "<literal>getCats()</literal>. Si vous activez le chargement par lot pour la "
-"collection <literal>cats</literal> dans le mapping de <literal>Person</"
+"collection <literal>cats</literal> dans le mappage de <literal>Person</"
 "literal>, Hibernate pourra précharger les collections :"
 
-#. Tag: programlisting
-#: performance.xml:523
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <set name=\"cats\" batch-size=\"3\">\n"
-"        ...\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:525
 #, no-c-format
 msgid ""
 "With a <literal>batch-size</literal> of 3, Hibernate will load 3, 3, 3, 1 "
@@ -1073,15 +869,14 @@
 "attribute depends on the expected number of uninitialized collections in a "
 "particular <literal>Session</literal>."
 msgstr ""
-"Avec une taille de lot (<literal>batch-size</literal>) de 3, Hibernate "
-"chargera respectivement 3, 3, 3, et 1 collections en quatre <literal>SELECT</"
-"literal>s. Encore une fois, la valeur de l'attribut dépend du nombre de "
-"collections non initialisées dans une <literal>Session</literal> "
-"particulière."
+"Avec une taille de lot <literal>batch-size</literal> de 8, Hibernate "
+"chargera respectivement des collections 3, 3, 3, et 1 en quatre "
+"<literal>SELECT</literal> s. Encore une fois, la valeur de l'attribut dépend "
+"du nombre de collections non initialisées dans une <literal>Session</"
+"literal> particulière. "
 
 #. Tag: para
-#: performance.xml:531
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Batch fetching of collections is particularly useful if you have a nested "
 "tree of items, i.e. the typical bill-of-materials pattern. However, a "
@@ -1089,39 +884,93 @@
 "might be a better option for read-mostly trees."
 msgstr ""
 "Le chargement par lot de collections est particulièrement utile si vous avez "
-"des arborescenses récursives d'éléments (typiquement, le schéma facture de "
-"matériels). (Bien qu'un <emphasis>sous ensemble</emphasis> ou un "
-"<emphasis>chemin matérialisé</emphasis> est sans doute une meilleure option "
-"pour des arbres principalement en lecture.)"
+"une arborescence imbriquée d'éléments, c'est-à-dire le le schéma facture de "
+"matériels typique. (Bien qu'un <emphasis>sous ensemble</emphasis> ou un "
+"<emphasis>chemin matérialisé</emphasis> soit probablement une meilleure "
+"option pour des arbres principalement en lecture.) "
 
 #. Tag: title
-#: performance.xml:540
 #, no-c-format
 msgid "Using subselect fetching"
 msgstr "Utilisation du chargement par sous select"
 
 #. Tag: para
-#: performance.xml:542
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If one lazy collection or single-valued proxy has to be fetched, Hibernate "
 "will load all of them, re-running the original query in a subselect. This "
 "works in the same way as batch-fetching but without the piecemeal loading."
 msgstr ""
-"Si une collection ou un proxy vers un objet doit être chargé, Hibernate va "
-"tous les charger en ré-exécutant la requête orignial dans un sous select. "
-"Cela fonctionne de la même manière que le chargement par lot sans la "
-"possibilité de fragmenter le chargement."
+"Si une collection en différé ou un proxy vers un objet doit être chargée, "
+"Hibernate va tous les charger en ré-exécutant la requête originale dans un "
+"sous select. Cela fonctionne de la même manière que le chargement par lot "
+"sans la possibilité de fragmenter le chargement."
 
 #. Tag: title
-#: performance.xml:553
+#, fuzzy, no-c-format
+msgid "Fetch profiles"
+msgstr "Stratégies de chargement"
+
+#. Tag: para
 #, no-c-format
+msgid ""
+"Another way to affect the fetching strategy for loading associated objects "
+"is through something called a fetch profile, which is a named configuration "
+"associated with the <interfacename>org.hibernate.SessionFactory</"
+"interfacename> but enabled, by name, on the <interfacename>org.hibernate."
+"Session</interfacename>. Once enabled on a <interfacename>org.hibernate."
+"Session</interfacename>, the fetch profile wull be in affect for that "
+"<interfacename>org.hibernate.Session</interfacename> until it is explicitly "
+"disabled."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"So what does that mean? Well lets explain that by way of an example. Say we "
+"have the following mappings:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Now normally when you get a reference to a particular customer, that "
+"customer's set of orders will be lazy meaning we will not yet have loaded "
+"those orders from the database. Normally this is a good thing. Now lets say "
+"that you have a certain use case where it is more efficient to load the "
+"customer and their orders together. One way certainly is to use \"dynamic "
+"fetching\" strategies via an HQL or criteria queries. But another option is "
+"to use a fetch profile to achieve that. Just add the following to your "
+"mapping:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "or even:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Now the following code will actually load both the customer <emphasis>and "
+"their orders</emphasis>:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Currently only join style fetch profiles are supported, but they plan is to "
+"support additional styles. See <ulink url=\"http://opensource.atlassian.com/"
+"projects/hibernate/browse/HHH-3414\">HHH-3414</ulink> for details."
+msgstr ""
+
+#. Tag: title
+#, no-c-format
 msgid "Using lazy property fetching"
-msgstr "Utiliser le chargement tardif des propriétés"
+msgstr "Utiliser le chargement en différé des propriétés"
 
 #. Tag: para
-#: performance.xml:555
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 supports the lazy fetching of individual properties. This "
 "optimization technique is also known as <emphasis>fetch groups</emphasis>. "
@@ -1131,87 +980,48 @@
 "when legacy tables have hundreds of columns and the data model cannot be "
 "improved."
 msgstr ""
-"Hibernate3 supporte le chargement tardif de propriétés individuelles. La "
+"Hibernate3 supporte le chargement en différé de propriétés individuelles. La "
 "technique d'optimisation est également connue sous le nom de <emphasis>fetch "
 "groups</emphasis> (groupes de chargement). Il faut noter qu'il s'agit "
 "principalement d'une fonctionnalité marketing car en pratique l'optimisation "
 "de la lecture d'un enregistrement est beaucoup plus importante que "
 "l'optimisation de la lecture d'une colonne. Cependant, la restriction du "
-"chargement à certaines colonnes peut être pratique dans des cas extrèmes, "
+"chargement à certaines colonnes peut être pratique dans des cas extrêmes, "
 "lorsque des tables \"legacy\" possèdent des centaines de colonnes et que le "
 "modèle de données ne peut pas être amélioré."
 
 #. Tag: para
-#: performance.xml:564
 #, no-c-format
 msgid ""
 "To enable lazy property loading, set the <literal>lazy</literal> attribute "
 "on your particular property mappings:"
 msgstr ""
-"Pour activer le chargement tardif d'une propriété, il faut mettre l'attribut "
-"<literal>lazy</literal> sur une propriété particulière du mapping :"
+"Pour activer le chargement en différé d'une propriété, il faut mettre "
+"l'attribut <literal>lazy</literal> sur une propriété particulière du "
+"mappage :"
 
-#. Tag: programlisting
-#: performance.xml:569
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Document\">\n"
-"       <id name=\"id\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\" length=\"50\"/>\n"
-"    <property name=\"summary\" not-null=\"true\" length=\"200\" lazy=\"true"
-"\"/>\n"
-"    <property name=\"text\" not-null=\"true\" length=\"2000\" lazy=\"true\"/"
-">\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:571
-#, fuzzy, no-c-format
-msgid ""
 "Lazy property loading requires buildtime bytecode instrumentation. If your "
 "persistent classes are not enhanced, Hibernate will ignore lazy property "
 "settings and return to immediate fetching."
 msgstr ""
-"Le chargement tardif des propriétés requiert une instrumentation du bytecode "
-"lors de la compilation ! Si les classes persistantes ne sont pas "
-"instrumentées, Hibernate ignorera de manière silencieuse le mode tardif et "
-"retombera dans le mode de chargement immédiat."
+"Le chargement en différé des propriétés requiert une instrumentation du "
+"bytecode lors de la compilation ! Si les classes persistantes ne sont pas "
+"instrumentées, Hibernate ignorera de manière silencieuse le mode en différé "
+"et retombera dans le mode de chargement immédiat. "
 
 #. Tag: para
-#: performance.xml:577
 #, no-c-format
 msgid "For bytecode instrumentation, use the following Ant task:"
 msgstr ""
 "Pour l'instrumentation du bytecode vous pouvez utiliser la tâche Ant "
 "suivante :"
 
-#. Tag: programlisting
-#: performance.xml:581
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<target name=\"instrument\" depends=\"compile\">\n"
-"    <taskdef name=\"instrument\" classname=\"org.hibernate.tool.instrument."
-"InstrumentTask\">\n"
-"        <classpath path=\"${jar.path}\"/>\n"
-"        <classpath path=\"${classes.dir}\"/>\n"
-"        <classpath refid=\"lib.class.path\"/>\n"
-"    </taskdef>\n"
-"\n"
-"    <instrument verbose=\"true\">\n"
-"        <fileset dir=\"${testclasses.dir}/org/hibernate/auction/model\">\n"
-"            <include name=\"*.class\"/>\n"
-"        </fileset>\n"
-"    </instrument>\n"
-"</target>]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:583
-#, fuzzy, no-c-format
-msgid ""
 "A different way of avoiding unnecessary column reads, at least for read-only "
 "transactions, is to use the projection features of HQL or Criteria queries. "
 "This avoids the need for buildtime bytecode processing and is certainly a "
@@ -1221,27 +1031,24 @@
 "nécessaire au moins pour des transactions en lecture seule est d'utiliser "
 "les fonctionnalités de projection des requêtes HQL ou Criteria. Cela évite "
 "de devoir instrumenter le bytecode à la compilation et est certainement une "
-"solution préférable."
+"solution préférable. "
 
 #. Tag: para
-#: performance.xml:590
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can force the usual eager fetching of properties using <literal>fetch "
 "all properties</literal> in HQL."
 msgstr ""
 "Vous pouvez forcer le mode de chargement agressif des propriétés en "
-"utilisant <literal>fetch all properties</literal> dans les requêts HQL."
+"utilisant <literal>fetch all properties</literal> dans les requêtes HQL. "
 
 #. Tag: title
-#: performance.xml:600
 #, no-c-format
 msgid "The Second Level Cache"
 msgstr "Le cache de second niveau"
 
 #. Tag: para
-#: performance.xml:602
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A Hibernate <literal>Session</literal> is a transaction-level cache of "
 "persistent data. It is possible to configure a cluster or JVM-level "
@@ -1252,18 +1059,16 @@
 "cached data."
 msgstr ""
 "Une <literal>Session</literal> Hibernate est un cache de niveau "
-"transactionnel des données persistantes. Il est possible de configurer un "
-"cache de cluster ou de JVM (de niveau <literal>SessionFactory</literal> pour "
-"être exact) défini classe par classe et collection par collection. Vous "
-"pouvez même utiliser votr choix de cache en implémentant le pourvoyeur "
-"(provider) associé. Faites attention, les caches ne sont jamais avertis des "
-"modifications faites dans la base de données par d'autres applications (ils "
-"peuvent cependant être configurés pour régulièrement expirer les données en "
-"cache)."
+"transactionnel de données persistantes. Il est possible de configurer un "
+"cache de cluster ou de JVM (de niveau <literal>SessionFactory</literal>) "
+"défini classe par classe et collection par collection. Vous pouvez même "
+"utiliser votre choix de cache en implémentant le fournisseur associé. Faites "
+"attention, les caches ne sont jamais avertis des modifications faites dans "
+"la base de données par d'autres applications (ils peuvent cependant être "
+"configurés pour régulièrement expirer les données en cache). "
 
 #. Tag: para
-#: performance.xml:610
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You have the option to tell Hibernate which caching implementation to use by "
 "specifying the name of a class that implements <literal>org.hibernate.cache."
@@ -1273,213 +1078,165 @@
 "can also implement your own and plug it in as outlined above. Note that "
 "versions prior to 3.2 use EhCache as the default cache provider."
 msgstr ""
-"Par défaut, Hibernate utilise EHCache comme cache de niveau JVM (le support "
-"de JCS est désormais déprécié et sera enlevé des futures versions "
-"d'Hibernate). Vous pouvez choisir une autre implémentation en spécifiant le "
-"nom de la classe qui implémente <literal>org.hibernate.cache.CacheProvider</"
-"literal> en utilisant la propriété <literal>hibernate.cache.provider_class</"
-"literal>."
+"Vous pouvez choisir une autre implémentation en spécifiant le nom de la "
+"classe qui implémente <literal>org.hibernate.cache.CacheProvider</literal> "
+"en utilisant la propriété <literal>hibernate.cache.provider_class</literal>. "
+"Hibernate est accompagné de plusieurs intégrations imbriquées avec des "
+"fournisseurs de cache open-source (listés ci-dessous) ; par ailleurs vous "
+"pouvez implémenter votre propre fournisseur et le brancher comme indiqué ci-"
+"dessus. Notez que les versions antérieures à 3.2, utilisaient par défaut le "
+"EhCache comme le fournisseur de cache par défaut, ce qui n'est plus le cas. "
 
 #. Tag: title
-#: performance.xml:621
 #, no-c-format
 msgid "Cache Providers"
-msgstr "Fournisseur de cache"
+msgstr "Fournisseurs de cache"
 
 #. Tag: entry
-#: performance.xml:630 performance.xml:818
 #, no-c-format
 msgid "Cache"
 msgstr "Cache"
 
 #. Tag: entry
-#: performance.xml:631
 #, no-c-format
 msgid "Provider class"
 msgstr "Classe pourvoyeuse"
 
 #. Tag: entry
-#: performance.xml:632
 #, no-c-format
 msgid "Type"
 msgstr "Type"
 
 #. Tag: entry
-#: performance.xml:633
 #, no-c-format
 msgid "Cluster Safe"
-msgstr "Support en Cluster"
+msgstr "Cluster sécurisé"
 
 #. Tag: entry
-#: performance.xml:634
 #, no-c-format
 msgid "Query Cache Supported"
 msgstr "Cache de requêtes supporté"
 
 #. Tag: entry
-#: performance.xml:639 performance.xml:827
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Hashtable (not intended for production use)"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Hashtable (ne pas utiliser en production)\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Hashtable (ne pas utilser en production)"
+msgstr "Table de hachage (ne pas utiliser en production)"
 
-#. Tag: literal
-#: performance.xml:640
-#, no-c-format
-msgid "org.hibernate.cache.HashtableCacheProvider"
-msgstr "org.hibernate.cache.HashtableCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.HashtableCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.HashtableCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:641
 #, no-c-format
 msgid "memory"
 msgstr "mémoire"
 
 #. Tag: entry
-#: performance.xml:643 performance.xml:650 performance.xml:657
-#: performance.xml:828 performance.xml:829 performance.xml:830
-#: performance.xml:835 performance.xml:836 performance.xml:837
-#: performance.xml:842 performance.xml:843 performance.xml:844
-#: performance.xml:849 performance.xml:850 performance.xml:856
-#: performance.xml:859 performance.xml:863 performance.xml:866
 #, no-c-format
-msgid "<entry>yes</entry>"
-msgstr ""
+msgid "yes"
+msgstr "oui"
 
 #. Tag: entry
-#: performance.xml:646 performance.xml:834
 #, no-c-format
 msgid "EHCache"
 msgstr "EHCache"
 
-#. Tag: literal
-#: performance.xml:647
-#, no-c-format
-msgid "org.hibernate.cache.EhCacheProvider"
-msgstr "org.hibernate.cache.EhCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.EhCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.EhCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:648 performance.xml:655
 #, no-c-format
 msgid "memory, disk"
 msgstr "mémoire, disque"
 
 #. Tag: entry
-#: performance.xml:653 performance.xml:841
 #, no-c-format
 msgid "OSCache"
 msgstr "OSCache"
 
-#. Tag: literal
-#: performance.xml:654
-#, no-c-format
-msgid "org.hibernate.cache.OSCacheProvider"
-msgstr "org.hibernate.cache.OSCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.OSCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.OSCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:660 performance.xml:848
 #, no-c-format
 msgid "SwarmCache"
 msgstr "SwarmCache"
 
-#. Tag: literal
-#: performance.xml:661
-#, no-c-format
-msgid "org.hibernate.cache.SwarmCacheProvider"
-msgstr "org.hibernate.cache.SwarmCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.SwarmCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.SwarmCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:662
 #, no-c-format
 msgid "clustered (ip multicast)"
 msgstr "en cluster (multicast ip)"
 
 #. Tag: entry
-#: performance.xml:663
 #, no-c-format
 msgid "yes (clustered invalidation)"
 msgstr "oui (invalidation de cluster)"
 
 #. Tag: entry
-#: performance.xml:667 performance.xml:855
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "JBoss Cache 1.x"
-msgstr "JBoss TreeCache"
+msgstr "JBoss Cache 1.x"
 
-#. Tag: literal
-#: performance.xml:668
-#, no-c-format
-msgid "org.hibernate.cache.TreeCacheProvider"
-msgstr "org.hibernate.cache.TreeCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.TreeCacheProvider</literal>"
+msgstr "    org.hibernate.cache.TreeCacheProvider"
 
 #. Tag: entry
-#: performance.xml:669 performance.xml:676
 #, no-c-format
 msgid "clustered (ip multicast), transactional"
 msgstr "en cluster (multicast ip), transactionnel"
 
 #. Tag: entry
-#: performance.xml:670
 #, no-c-format
 msgid "yes (replication)"
-msgstr "oui (replication)"
+msgstr "oui (réplication)"
 
 #. Tag: entry
-#: performance.xml:671 performance.xml:678
 #, no-c-format
 msgid "yes (clock sync req.)"
 msgstr "oui (horloge sync. nécessaire)"
 
 #. Tag: entry
-#: performance.xml:674 performance.xml:862
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "JBoss Cache 2"
-msgstr "JBoss TreeCache"
+msgstr "JBoss Cache 2"
 
-#. Tag: literal
-#: performance.xml:675
+#. Tag: entry
 #, fuzzy, no-c-format
-msgid "org.hibernate.cache.jbc.JBossCacheRegionFactory"
-msgstr "org.hibernate.cache.EhCacheProvider"
+msgid "<literal>org.hibernate.cache.jbc.JBossCacheRegionFactory</literal>"
+msgstr "<literal>org.hibernate.cache.jbc2.JBossCacheRegionFactory</literal>"
 
 #. Tag: entry
-#: performance.xml:677
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "yes (replication or invalidation)"
-msgstr "oui (invalidation de cluster)"
+msgstr "oui (replication ou invalidation)"
 
 #. Tag: title
-#: performance.xml:685
 #, no-c-format
 msgid "Cache mappings"
-msgstr "Mapping de Cache"
+msgstr "Mappages de Cache"
 
 #. Tag: para
-#: performance.xml:687
 #, no-c-format
 msgid ""
 "The <literal>&lt;cache&gt;</literal> element of a class or collection "
 "mapping has the following form:"
 msgstr ""
 "L'élément <literal>&lt;cache&gt;</literal> d'une classe ou d'une collection "
-"à la forme suivante :"
+"a la forme suivante :"
 
-#. Tag: programlisting
-#: performance.xml:698
-#, no-c-format
-msgid ""
-"<![CDATA[<cache \n"
-"    usage=\"transactional|read-write|nonstrict-read-write|read-only\"\n"
-"    region=\"RegionName\"\n"
-"    include=\"all|non-lazy\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:701
 #, no-c-format
 msgid ""
 "<literal>usage</literal> (required) specifies the caching strategy: "
@@ -1492,19 +1249,17 @@
 "literal>"
 
 #. Tag: para
-#: performance.xml:710
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>region</literal> (optional: defaults to the class or collection "
 "role name): specifies the name of the second level cache region"
 msgstr ""
 "<literal>region</literal> (optionnel, par défaut il s'agit du nom de la "
-"classe ou du nom de role de la collection) spécifie le nom de la région du "
+"classe ou du nom de rôle de la collection) : spécifie le nom de la région du "
 "cache de second niveau"
 
 #. Tag: para
-#: performance.xml:717
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>include</literal> (optional: defaults to <literal>all</literal>) "
 "<literal>non-lazy</literal>: specifies that properties of the entity mapped "
@@ -1512,13 +1267,12 @@
 "lazy fetching is enabled"
 msgstr ""
 "<literal>include</literal> (optionnel, par défaut <literal>all</literal>) "
-"<literal>non-lazy</literal> spécifie que les propriétés des entités mappées "
-"avec <literal>lazy=\"true\"</literal> ne doivent pas être mises en cache "
-"lorsque le chargement tardif des attributs est activé."
+"<literal>non-lazy</literal> : spécifie que les propriétés des entités "
+"mappées avec <literal>lazy=\"true\"</literal> ne doivent pas être mises en "
+"cache lorsque le chargement en différé des attributs est activé."
 
 #. Tag: para
-#: performance.xml:727
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, you can specify <literal>&lt;class-cache&gt;</literal> and "
 "<literal>&lt;collection-cache&gt;</literal> elements in <literal>hibernate."
@@ -1526,10 +1280,9 @@
 msgstr ""
 "Alternativement (voir préférentiellement), vous pouvez spécifier les "
 "éléments <literal>&lt;class-cache&gt;</literal> et <literal>&lt;collection-"
-"cache&gt;</literal> dans <literal>hibernate.cfg.xml</literal>."
+"cache&gt;</literal> dans <literal>hibernate.cfg.xml</literal>. "
 
 #. Tag: para
-#: performance.xml:732
 #, no-c-format
 msgid ""
 "The <literal>usage</literal> attribute specifies a <emphasis>cache "
@@ -1539,14 +1292,12 @@
 "concurrence d'accès au cache</emphasis>."
 
 #. Tag: title
-#: performance.xml:739
 #, no-c-format
 msgid "Strategy: read only"
-msgstr "Strategie : lecture seule"
+msgstr "Stratégie : lecture seule"
 
 #. Tag: para
-#: performance.xml:741
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your application needs to read, but not modify, instances of a persistent "
 "class, a <literal>read-only</literal> cache can be used. This is the "
@@ -1556,27 +1307,15 @@
 "Si votre application a besoin de lire mais ne modifie jamais les instances "
 "d'une classe, un cache <literal>read-only</literal> peut être utilisé. C'est "
 "la stratégie la plus simple et la plus performante. Elle est même "
-"parfaitement sûre dans un cluster."
+"parfaitement sûre dans un cluster. "
 
-#. Tag: programlisting
-#: performance.xml:747
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Immutable\" mutable=\"false\">\n"
-"    <cache usage=\"read-only\"/>\n"
-"    ....\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:753
 #, no-c-format
 msgid "Strategy: read/write"
 msgstr "Stratégie : lecture/écriture"
 
 #. Tag: para
-#: performance.xml:755
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the application needs to update data, a <literal>read-write</literal> "
 "cache might be appropriate. This cache strategy should never be used if "
@@ -1594,39 +1333,23 @@
 "<literal>read-write</literal> peut être approprié. Cette stratégie ne "
 "devrait jamais être utilisée si votre application nécessite un niveau "
 "d'isolation transactionnelle sérialisable. Si le cache est utilisé dans un "
-"environnement JTA, vous devez spécifier <literal>hibernate.transaction."
-"manager_lookup_class</literal>, fournissant une stratégie pour obtenir le "
-"<literal>TransactionManager</literal> JTA. Dans d'autres environnements, "
-"vous devriez vous assurer que la transation est terminée à l'appel de "
-"<literal>Session.close()</literal> ou <literal>Session.disconnect()</"
-"literal>. Si vous souhaitez utiliser cette stratégie dans un cluster, vous "
-"devriez vous assurer que l'implémentation de cache utilisée supporte le "
-"vérrouillage. Ce que ne font <emphasis>pas</emphasis> les pourvoyeurs caches "
-"fournis."
+"environnement JTA, vous devez spécifier la propriété <literal>hibernate."
+"transaction.manager_lookup_class</literal>, fournissant une stratégie pour "
+"obtenir le JTA <literal>TransactionManager</literal>. Dans d'autres "
+"environnements, vous devriez vous assurer que la transation est terminée à "
+"l'appel de <literal>Session.close()</literal> ou <literal>Session.disconnect"
+"()</literal>. Si vous souhaitez utiliser cette stratégie dans un cluster, "
+"vous devriez vous assurer que l'implémentation de cache utilisée supporte le "
+"verrouillage, ce que ne font <emphasis>pas</emphasis> les pourvoyeurs caches "
+"fournis. "
 
-#. Tag: programlisting
-#: performance.xml:766
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Cat\" .... >\n"
-"    <cache usage=\"read-write\"/>\n"
-"    ....\n"
-"    <set name=\"kittens\" ... >\n"
-"        <cache usage=\"read-write\"/>\n"
-"        ....\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:771
 #, no-c-format
 msgid "Strategy: nonstrict read/write"
 msgstr "Stratégie : lecture/écriture non stricte"
 
 #. Tag: para
-#: performance.xml:773
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the application only occasionally needs to update data (i.e. if it is "
 "extremely unlikely that two transactions would try to update the same item "
@@ -1637,25 +1360,23 @@
 "should ensure that the transaction is completed when <literal>Session.close()"
 "</literal> or <literal>Session.disconnect()</literal> is called."
 msgstr ""
-"Si l'application besoin de mettre à jour les données de manière "
-"occasionnelle (qu'il est très peu probable que deux transactions essaient de "
-"mettre à jour le même élément simultanément) et qu'une isolation "
+"Si l'application a besoin de mettre à jour les données de manière "
+"occasionnelle (il est très peu probable que deux transactions essaient de "
+"mettre à jour le même élément simultanément) et si une isolation "
 "transactionnelle stricte n'est pas nécessaire, un cache <literal>nonstrict-"
 "read-write</literal> peut être approprié. Si le cache est utilisé dans un "
 "environnement JTA, vous devez spécifier <literal>hibernate.transaction."
 "manager_lookup_class</literal>. Dans d'autres environnements, vous devriez "
 "vous assurer que la transation est terminée à l'appel de <literal>Session."
-"close()</literal> ou <literal>Session.disconnect()</literal>"
+"close()</literal> ou <literal>Session.disconnect()</literal>."
 
 #. Tag: title
-#: performance.xml:785
 #, no-c-format
 msgid "Strategy: transactional"
 msgstr "Stratégie : transactionelle"
 
 #. Tag: para
-#: performance.xml:787
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>transactional</literal> cache strategy provides support for "
 "fully transactional cache providers such as JBoss TreeCache. Such a cache "
@@ -1665,74 +1386,64 @@
 "La stratégie de cache <literal>transactional</literal> supporte un cache "
 "complètement transactionnel comme, par exemple, JBoss TreeCache. Un tel "
 "cache ne peut être utilisé que dans un environnement JTA et vous devez "
-"spécifier <literal>hibernate.transaction.manager_lookup_class</literal>."
+"spécifier <literal>hibernate.transaction.manager_lookup_class</literal>. "
 
 #. Tag: title
-#: performance.xml:796
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Cache-provider/concurrency-strategy compatibility"
-msgstr "Stratégie de concurrence du cache"
+msgstr "Support de stratégie de concurrence du fournisseur-cache"
 
 #. Tag: para
-#: performance.xml:799
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "None of the cache providers support all of the cache concurrency strategies."
 msgstr ""
 "Aucun des caches livrés ne supporte toutes les stratégies de concurrence. Le "
 "tableau suivant montre quels caches sont compatibles avec quelles stratégies "
-"de concurrence."
+"de concurrence. "
 
 #. Tag: para
-#: performance.xml:804
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table shows which providers are compatible with which "
 "concurrency strategies."
 msgstr ""
 "Aucun des caches livrés ne supporte toutes les stratégies de concurrence. Le "
 "tableau suivant montre quels caches sont compatibles avec quelles stratégies "
-"de concurrence."
+"de concurrence. "
 
 #. Tag: title
-#: performance.xml:809
 #, no-c-format
 msgid "Cache Concurrency Strategy Support"
-msgstr "Stratégie de concurrence du cache"
+msgstr "Support de stratégie de concurrence du cache"
 
 #. Tag: entry
-#: performance.xml:819
 #, no-c-format
 msgid "read-only"
 msgstr "read-only (lecture seule)"
 
 #. Tag: entry
-#: performance.xml:820
 #, no-c-format
 msgid "nonstrict-read-write"
 msgstr "nonstrict-read-write (lecture-écriture non stricte)"
 
 #. Tag: entry
-#: performance.xml:821
 #, no-c-format
 msgid "read-write"
-msgstr "read-write (lecture-ériture)"
+msgstr "read-write (lecture-écriture)"
 
 #. Tag: entry
-#: performance.xml:822
 #, no-c-format
 msgid "transactional"
 msgstr "transactional (transactionnel)"
 
 #. Tag: title
-#: performance.xml:877
 #, no-c-format
 msgid "Managing the caches"
 msgstr "Gérer les caches"
 
 #. Tag: para
-#: performance.xml:879
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Whenever you pass an object to <literal>save()</literal>, <literal>update()</"
 "literal> or <literal>saveOrUpdate()</literal>, and whenever you retrieve an "
@@ -1745,12 +1456,11 @@
 "literal>, <literal>update()</literal> ou <literal>saveOrUpdate()</literal> "
 "et à chaque fois que vous récupérez un objet avec <literal>load()</literal>, "
 "<literal>get()</literal>, <literal>list()</literal>, <literal>iterate()</"
-"literal> or <literal>scroll()</literal>, cet objet est ajouté au cache "
-"interne de la <literal>Session</literal>."
+"literal> ou <literal>scroll()</literal>, cet objet est ajouté au cache "
+"interne de la <literal>Session</literal>. "
 
 #. Tag: para
-#: performance.xml:886
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When <literal>flush()</literal> is subsequently called, the state of that "
 "object will be synchronized with the database. If you do not want this "
@@ -1764,43 +1474,29 @@
 "que cette synchronisation ait lieu ou si vous traitez un grand nombre "
 "d'objets et que vous avez besoin de gérer la mémoire de manière efficace, "
 "vous pouvez utiliser la méthode <literal>evict()</literal> pour supprimer "
-"l'objet et ses collections dépendantes du cache de la session"
+"l'objet et ses collections dépendantes du cache de premier niveau de la "
+"session. "
 
-#. Tag: programlisting
-#: performance.xml:894
-#, no-c-format
-msgid ""
-"<![CDATA[ScrollableResult cats = sess.createQuery(\"from Cat as cat\").scroll"
-"(); //a huge result set\n"
-"while ( cats.next() ) {\n"
-"    Cat cat = (Cat) cats.get(0);\n"
-"    doSomethingWithACat(cat);\n"
-"    sess.evict(cat);\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:896
 #, no-c-format
 msgid ""
 "The <literal>Session</literal> also provides a <literal>contains()</literal> "
 "method to determine if an instance belongs to the session cache."
 msgstr ""
-"La <literal>Session</literal> dispose aussi de la méthode <literal>contains()"
-"</literal> pour déterminer si une instance appartient au cache de la session."
+"La <literal>Session</literal> fournit également une méthode <literal>contains"
+"()</literal> pour déterminer si une instance appartient au cache de la "
+"session. "
 
 #. Tag: para
-#: performance.xml:901
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To evict all objects from the session cache, call <literal>Session.clear()</"
 "literal>"
 msgstr ""
 "Pour retirer tous les objets du cache session, appelez <literal>Session.clear"
-"()</literal>"
+"()</literal> "
 
 #. Tag: para
-#: performance.xml:905
 #, no-c-format
 msgid ""
 "For the second-level cache, there are methods defined on "
@@ -1808,180 +1504,177 @@
 "instance, entire class, collection instance or entire collection role."
 msgstr ""
 "Pour le cache de second niveau, il existe des méthodes définies dans "
-"<literal>SessionFactory</literal> pour retirer des instances du cache, la "
-"classe entière, une instance de collection ou le rôle entier d'une "
+"<literal>SessionFactory</literal> pour retirer du cache d'une instance, de "
+"la classe entière, d'une instance de collection ou du rôle entier d'une "
 "collection."
 
-#. Tag: programlisting
-#: performance.xml:911
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sessionFactory.evict(Cat.class, catId); //evict a particular Cat\n"
-"sessionFactory.evict(Cat.class);  //evict all Cats\n"
-"sessionFactory.evictCollection(\"Cat.kittens\", catId); //evict a particular "
-"collection of kittens\n"
-"sessionFactory.evictCollection(\"Cat.kittens\"); //evict all kitten "
-"collections]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:913
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>CacheMode</literal> controls how a particular session interacts "
 "with the second-level cache:"
 msgstr ""
-"Le <literal>CacheMode</literal> contrôle comme une session particulière "
-"interragit avec le cache de second niveau"
+"Le <literal>CacheMode</literal> contrôle la manière dont une session "
+"particulière interagit avec le cache de second niveau :"
 
 #. Tag: para
-#: performance.xml:920
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.NORMAL</literal>: will read items from and write items to "
 "the second-level cache"
 msgstr ""
-"<literal>CacheMode.NORMAL</literal> - lit et écrit les items dans le cache "
-"de second niveau"
+"<literal>CacheMode.NORMAL</literal> - lit et écrit les articles dans le "
+"cache de second niveau "
 
 #. Tag: para
-#: performance.xml:925
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.GET</literal>: will read items from the second-level "
 "cache. Do not write to the second-level cache except when updating data"
 msgstr ""
-"<literal>CacheMode.GET</literal> - lit les items dans le cache de second "
-"niveau mais ne les écrit pas sauf dans le cache d'une mise à jour d'une "
-"donnée"
+"<literal>CacheMode.GET</literal> - lit les articles du cache de second "
+"niveau mais ne les écrit pas sauf dans le cas d'une mise à jour des données "
 
 #. Tag: para
-#: performance.xml:931
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.PUT</literal>: will write items to the second-level "
 "cache. Do not read from the second-level cache"
 msgstr ""
-"<literal>CacheMode.PUT</literal> - écrit les items dans le cache de second "
-"niveau mais ne les lit pas dans le cache de second niveau"
+"<literal>CacheMode.PUT</literal> - écrit les articles dans le cache de "
+"second niveau mais ne les lit pas dans le cache de second niveau "
 
 #. Tag: para
-#: performance.xml:937
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.REFRESH</literal>: will write items to the second-level "
 "cache. Do not read from the second-level cache. Bypass the effect of "
 "<literal>hibernate.cache.use_minimal_puts</literal> forcing a refresh of the "
 "second-level cache for all items read from the database"
 msgstr ""
-"<literal>CacheMode.REFRESH</literal> - écrit les items dans le cache de "
+"<literal>CacheMode.REFRESH</literal> - écrit les articles dans le cache de "
 "second niveau mais ne les lit pas dans le cache de second niveau, outrepasse "
-"l'effet de<literal>hibernate.cache.use_minimal_puts</literal>, en forçant un "
-"rafraîchissement du cache de second niveau pour chaque item lu dans la base"
+"l'effet de <literal>hibernate.cache.use_minimal_puts</literal>, en forçant "
+"un rafraîchissement du cache de second niveau pour chaque article lu dans la "
+"base de données. "
 
 #. Tag: para
-#: performance.xml:945
 #, no-c-format
 msgid ""
 "To browse the contents of a second-level or query cache region, use the "
 "<literal>Statistics</literal> API:"
 msgstr ""
 "Pour parcourir le contenu du cache de second niveau ou la région du cache "
-"dédiée au requêtes, vous pouvez utiliser l'API <literal>Statistics</literal> "
-"API:"
+"dédiée aux requêtes, vous pouvez utiliser l'API <literal>Statistics</"
+"literal> :"
 
-#. Tag: programlisting
-#: performance.xml:950
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Map cacheEntries = sessionFactory.getStatistics()\n"
-"        .getSecondLevelCacheStatistics(regionName)\n"
-"        .getEntries();]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:952
-#, fuzzy, no-c-format
-msgid ""
 "You will need to enable statistics and, optionally, force Hibernate to keep "
 "the cache entries in a more readable format:"
 msgstr ""
 "Vous devez pour cela activer les statistiques et optionnellement forcer "
 "Hibernate à conserver les entrées dans le cache sous un format plus "
-"compréhensible pour l'utilisateur :"
+"compréhensible pour l'utilisateur : "
 
-#. Tag: programlisting
-#: performance.xml:957
-#, no-c-format
-msgid ""
-"<![CDATA[hibernate.generate_statistics true\n"
-"hibernate.cache.use_structured_entries true]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:962
 #, no-c-format
 msgid "The Query Cache"
 msgstr "Le cache de requêtes"
 
 #. Tag: para
-#: performance.xml:964
 #, fuzzy, no-c-format
 msgid ""
 "Query result sets can also be cached. This is only useful for queries that "
-"are run frequently with the same parameters. You will first need to enable "
-"the query cache:"
+"are run frequently with the same parameters."
 msgstr ""
 "Les résultats d'une requête peuvent aussi être placés en cache. Ceci n'est "
 "utile que pour les requêtes qui sont exécutées avec les mêmes paramètres. "
-"Pour utiliser le cache de requêtes, vous devez d'abord l'activer :"
+"Pour utiliser le cache de requêtes, vous devez d'abord l'activer : "
 
-#. Tag: programlisting
-#: performance.xml:969
+#. Tag: title
 #, no-c-format
-msgid "<![CDATA[hibernate.cache.use_query_cache true]]>"
+msgid "Enabling query caching"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:971
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"This setting creates two new cache regions: one holding cached query result "
-"sets (<literal>org.hibernate.cache.StandardQueryCache</literal>), the other "
-"holding timestamps of the most recent updates to queryable tables "
-"(<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). Note that "
-"the query cache does not cache the state of the actual entities in the "
-"result set; it caches only identifier values and results of value type. The "
-"query cache should always be used in conjunction with the second-level cache."
+"Caching of query results introduces some overhead in terms of your "
+"applications normal transactional processing. For example, if you cache "
+"results of a query against Person Hibernate will need to keep track of when "
+"those results should be invalidated because changes have been committed "
+"against Person. That, coupled with the fact that most applications simply "
+"gain no benefit from caching query results, leads Hibernate to disable "
+"caching of query results by default. To use query caching, you will first "
+"need to enable the query cache:"
 msgstr ""
-"Ce paramètre amène la création de deux nouvelles régions dans le cache, une "
-"qui va conserver le résultat des requêtes mises en cache (<literal>org."
-"hibernate.cache.StandardQueryCache</literal>) et l'autre qui va conserver "
-"l'horodatage des mises à jour les plus récentes effectuées sur les tables "
-"requêtables (<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). "
-"Il faut noter que le cache de requête ne conserve pas l'état des entités, il "
-"met en cache uniquement les valeurs de l'identifiant et les valeurs de types "
-"de base (?). Le cache de requête doit toujours être utilisé avec le cache de "
-"second niveau pour être efficace."
 
 #. Tag: para
-#: performance.xml:981
+#, no-c-format
+msgid "This setting creates two new cache regions:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<classname>org.hibernate.cache.StandardQueryCache</classname>, holding the "
+"cached query results"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<classname>org.hibernate.cache.UpdateTimestampsCache</classname>, holding "
+"timestamps of the most recent updates to queryable tables. These are used to "
+"validate the results as they are served from the query cache."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"If you configure your underlying cache implementation to use expiry or "
+"timeouts is is very important that the cache timeout of the underlying cache "
+"region for the UpdateTimestampsCache be set to a higher value than the "
+"timeouts of any of the query caches. In fact, we recommend that the the "
+"UpdateTimestampsCache region not be configured for expiry at all. Note, in "
+"particular, that an LRU cache expiry policy is never appropriate."
+msgstr ""
+
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
-"Most queries do not benefit from caching, so by default, queries are not "
-"cached. To enable caching, call <literal>Query.setCacheable(true)</literal>. "
-"This call allows the query to look for existing cache results or add its "
-"results to the cache when it is executed."
+"As mentioned above, most queries do not benefit from caching or their "
+"results. So by default, individual queries are not cached even after "
+"enabling query caching. To enable results caching for a particular query, "
+"call <literal>org.hibernate.Query.setCacheable(true)</literal>. This call "
+"allows the query to look for existing cache results or add its results to "
+"the cache when it is executed."
 msgstr ""
-"La plupart des requêtes ne retirent pas de bénéfice pas du cache, donc par "
-"défaut les requêtes ne sont pas mises en cache. Pour activer le cache, "
-"appelez <literal>Query.setCacheable(true)</literal>. Cet appel permet de "
-"vérifier si les résultats sont en cache ou non, voire d'ajouter ces "
-"résultats si la requête est exécutée."
+"La plupart des requêtes ne tirent pas avantage du cache, donc par défaut les "
+"requêtes ne sont pas mises en cache. Pour activer le cache, appelez "
+"<literal>Query.setCacheable(true)</literal>. Cet appel permet de vérifier si "
+"les résultats sont en cache ou non, voire d'ajouter ces résultats quand la "
+"requête est exécutée. "
 
 #. Tag: para
-#: performance.xml:988
+#, no-c-format
+msgid ""
+"The query cache does not cache the state of the actual entities in the "
+"cache; it caches only identifier values and results of value type. For this "
+"reaso, the query cache should always be used in conjunction with the second-"
+"level cache for those entities expected to be cached as part of a query "
+"result cache (just as with collection caching)."
+msgstr ""
+
+#. Tag: title
 #, fuzzy, no-c-format
+msgid "Query cache regions"
+msgstr "Cache de requêtes supporté"
+
+#. Tag: para
+#, no-c-format
 msgid ""
 "If you require fine-grained control over query cache expiration policies, "
 "you can specify a named cache region for a particular query by calling "
@@ -1989,89 +1682,72 @@
 msgstr ""
 "Si vous avez besoin de contrôler finement les délais d'expiration du cache, "
 "vous pouvez spécifier une région de cache nommée pour une requête "
-"particulière en appelant <literal>Query.setCacheRegion()</literal>."
+"particulière en appelant <literal>Query.setCacheRegion()</literal>. "
 
-#. Tag: programlisting
-#: performance.xml:994
-#, no-c-format
-msgid ""
-"<![CDATA[List blogs = sess.createQuery(\"from Blog blog where blog.blogger "
-"= :blogger\")\n"
-"    .setEntity(\"blogger\", blogger)\n"
-"    .setMaxResults(15)\n"
-"    .setCacheable(true)\n"
-"    .setCacheRegion(\"frontpages\")\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:996
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"If the query should force a refresh of its query cache region, you should "
-"call <literal>Query.setCacheMode(CacheMode.REFRESH)</literal>. This is "
-"particularly useful in cases where underlying data may have been updated via "
-"a separate process (i.e., not modified through Hibernate) and allows the "
-"application to selectively refresh particular query result sets. This is a "
-"more efficient alternative to eviction of a query cache region via "
-"<literal>SessionFactory.evictQueries()</literal>."
+"If you want to force the query cache to refresh one of its regions "
+"(disregard any cached results it finds there) you can use <literal>org."
+"hibernate.Query.setCacheMode(CacheMode.REFRESH)</literal>. In conjunction "
+"with the region you have defined for the given query, Hibernate will "
+"selectively force the results cached in that particular region to be "
+"refreshed. This is particularly useful in cases where underlying data may "
+"have been updated via a separate process and is a far more efficient "
+"alternative to bulk eviction of the region via <literal>org.hibernate."
+"SessionFactory.evictQueries()</literal>."
 msgstr ""
 "Si une requête doit forcer le rafraîchissement de sa région de cache, vous "
 "devez appeler <literal>Query.setCacheMode(CacheMode.REFRESH)</literal>. "
 "C'est particulièrement utile lorsque les données peuvent avoir été mises à "
-"jour par un processus séparé (e.g. elles n'ont pas été modifiées par "
-"Hibernate). Cela permet à l'application de rafraîchir de manière sélective "
-"les résultats d'une requête particulière. Il s'agit d'une alternative plus "
-"efficace à l'éviction d'une région du cache à l'aide de la méthode "
-"<literal>SessionFactory.evictQueries()</literal>."
+"jour par un processus séparé (c'est-à-dire qu'elles n'ont pas été modifiées "
+"par Hibernate). Cela permet à l'application de rafraîchir de manière "
+"sélective les résultats d'une requête particulière. Il s'agit d'une "
+"alternative plus efficace à l'éviction d'une région du cache à l'aide de la "
+"méthode <literal>SessionFactory.evictQueries()</literal>."
 
 #. Tag: title
-#: performance.xml:1008
 #, no-c-format
 msgid "Understanding Collection performance"
-msgstr "Comprendre les performances des Collections"
+msgstr "Comprendre les performances des collections"
 
 #. Tag: para
-#: performance.xml:1010
 #, no-c-format
 msgid ""
 "In the previous sections we have covered collections and their applications. "
 "In this section we explore some more issues in relation to collections at "
 "runtime."
 msgstr ""
+"Dans les sections précédentes, nous avons couvert les collections et leurs "
+"applications. Dans cette section, nous allons explorer de nouveaux problèmes "
+"en rapport aux collections en cours d'exécution."
 
 #. Tag: title
-#: performance.xml:1017
 #, no-c-format
 msgid "Taxonomy"
-msgstr "Classification"
+msgstr "Taxinomie"
 
 #. Tag: para
-#: performance.xml:1019
 #, no-c-format
 msgid "Hibernate defines three basic kinds of collections:"
-msgstr "Hibernate définit trois types de collections :"
+msgstr "Hibernate définit trois types de collections de base :"
 
 #. Tag: para
-#: performance.xml:1023
 #, no-c-format
 msgid "collections of values"
 msgstr "les collections de valeurs"
 
 #. Tag: para
-#: performance.xml:1026
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "one-to-many associations"
-msgstr "les associations un-vers-plusieurs"
+msgstr "Association un-à-plusieurs "
 
 #. Tag: para
-#: performance.xml:1029
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "many-to-many associations"
-msgstr "les associations plusieurs-vers-plusieurs"
+msgstr "les associations plusieurs-à-plusieurs "
 
 #. Tag: para
-#: performance.xml:1033
 #, no-c-format
 msgid ""
 "This classification distinguishes the various table and foreign key "
@@ -2082,34 +1758,29 @@
 "This suggests the following classification:"
 msgstr ""
 "Cette classification distingue les différentes relations entre les tables et "
-"les clés étrangères mais ne nous apprend rien de ce que nous devons savoir "
-"sur le modèle relationnel. Pour comprendre parfaitement la structure "
-"relationnelle et les caractéristiques des performances, nous devons "
-"considérer la structure de la clé primaire qui est utilisée par Hibernate "
-"pour mettre à jour ou supprimer les éléments des collections. Celà nous "
-"amène aux classifications suivantes :"
+"les clés étrangères mais ne n'en dit pas suffisamment sur le modèle "
+"relationnel. Pour comprendre parfaitement la structure relationnelle et les "
+"caractéristiques des performances, nous devons considérer la structure de la "
+"clé primaire qui est utilisée par Hibernate pour mettre à jour ou supprimer "
+"les lignes des collections. Cela nous amène aux classifications suivantes :"
 
 #. Tag: para
-#: performance.xml:1044
 #, no-c-format
 msgid "indexed collections"
 msgstr "collections indexées"
 
 #. Tag: para
-#: performance.xml:1047
 #, no-c-format
 msgid "sets"
-msgstr "sets"
+msgstr "ensembles (sets)"
 
 #. Tag: para
-#: performance.xml:1050
 #, no-c-format
 msgid "bags"
-msgstr "bags"
+msgstr "sacs (bags)"
 
 #. Tag: para
-#: performance.xml:1054
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All indexed collections (maps, lists, and arrays) have a primary key "
 "consisting of the <literal>&lt;key&gt;</literal> and <literal>&lt;index&gt;</"
@@ -2118,15 +1789,15 @@
 "efficiently located when Hibernate tries to update or delete it."
 msgstr ""
 "Toutes les collections indexées (maps, lists, arrays) ont une clé primaire "
-"constituée des colonnes clé (<literal>&lt;key&gt;</literal>) et <literal>&lt;"
-"index&gt;</literal>. Avec ce type de clé primaire, la mise à jour de "
-"collection est en général très performante - la clé primaire peut être "
-"indexées efficacement et un élément particulier peut être localisé "
-"efficacement lorsqu'Hibernate essaie de le mettre à jour ou de le supprimer."
+"constituée des colonnes clés (<literal>&lt;key&gt;</literal>) et "
+"<literal>&lt;index&gt;</literal>. Avec ce type de clé primaire, la mise à "
+"jour de collection est en général très performante - la clé primaire peut "
+"être indexées efficacement et une ligne particulière peut être localisée "
+"efficacement lorsque Hibernate essaie de la mettre à jour ou de la "
+"supprimer. "
 
 #. Tag: para
-#: performance.xml:1062
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sets have a primary key consisting of <literal>&lt;key&gt;</literal> and "
 "element columns. This can be less efficient for some types of collection "
@@ -2138,33 +1809,31 @@
 "<literal>&lt;set&gt;</literal>, you must declare all columns as <literal>not-"
 "null=\"true\"</literal>."
 msgstr ""
-"Les Sets ont une clé primaire composée de <literal>&lt;key&gt;</literal> et "
-"des colonnes représentant l'élément. Elle est donc moins efficace pour "
-"certains types de collections d'éléments, en particulier les éléments "
-"composites, les textes volumineux ou les champs binaires ; la base de "
-"données peut ne pas être capable d'indexer aussi efficacement une clé "
-"primaire aussi complexe. Cependant, pour les associations un-vers-plusieurs "
-"ou plusieurs-vers-plusieurs, spécialement lorsque l'on utilise des entités "
-"ayant des identifiants techniques, il est probable que cela soit aussi "
-"efficace (note : si vous voulez que <literal>SchemaExport</literal> créé "
+"Les ensembles ont une clé primaire composée de <literal>&lt;key&gt;</"
+"literal> et des colonnes représentant l'élément. Elle est donc moins "
+"efficace pour certains types d'éléments de collection, en particulier les "
+"éléments composites, les textes volumineux ou les champs binaires ; la base "
+"de données peut ne pas être capable d'indexer aussi efficacement une clé "
+"primaire aussi complexe. Cependant, pour les associations un-à-plusieurs ou "
+"plusieurs-à-plusieurs, en particulier lorsqu'on utilise des entités ayant "
+"des identifiants techniques, il est probable que cela soit aussi efficace "
+"(note : si vous voulez que <literal>SchemaExport</literal> crée "
 "effectivement la clé primaire d'un <literal>&lt;set&gt;</literal> pour vous, "
 "vous devez déclarer toutes les colonnes avec <literal>not-null=\"true\"</"
-"literal>)."
+"literal>). "
 
 #. Tag: para
-#: performance.xml:1073
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>&lt;idbag&gt;</literal> mappings define a surrogate key, so they "
 "are efficient to update. In fact, they are the best case."
 msgstr ""
-"Le mapping à l'aide d'<literal>&lt;idbag&gt;</literal> définit une clé de "
+"Le mappage à l'aide de <literal>&lt;idbag&gt;</literal> définit une clé de "
 "substitution ce qui leur permet d'être très efficaces lors de la mise à "
-"jour. En fait il s'agit du meilleur cas de mise à jour d'une collection"
+"jour. En fait il s'agit du meilleur cas de mise à jour d'une collection."
 
 #. Tag: para
-#: performance.xml:1078
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Bags are the worst case since they permit duplicate element values and, as "
 "they have no index column, no primary key can be defined. Hibernate has no "
@@ -2172,52 +1841,48 @@
 "problem by completely removing in a single <literal>DELETE</literal> and "
 "recreating the collection whenever it changes. This can be inefficient."
 msgstr ""
-"Le pire cas intervient pour les Bags. Dans la mesure où un bag permet la "
-"duplications des éléments et n'a pas de colonne d'index, aucune clé primaire "
-"ne peut être définie. Hibernate n'a aucun moyen de distinguer des "
-"enregistrements dupliqués. Hibernate résout ce problème en supprimant "
-"complètement les enregistrements (via un simple <literal>DELETE</literal>), "
-"puis en recréant la collection chaque fois qu'elle change. Ce qui peut être "
-"très inefficace."
+"Le pire cas intervient pour les sacs. Dans la mesure où un sac permet la "
+"duplication des valeurs d'éléments et n'a pas de colonne d'index, aucune clé "
+"primaire ne peut être définie. Hibernate n'a aucun moyen de distinguer entre "
+"les  lignes dupliquées. Hibernate résout ce problème en supprimant "
+"complètement (via un simple <literal>DELETE</literal>), puis en recréant la "
+"collection chaque fois qu'elle change. Ce qui peut être très inefficace. "
 
 #. Tag: para
-#: performance.xml:1086
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For a one-to-many association, the \"primary key\" may not be the physical "
 "primary key of the database table. Even in this case, the above "
 "classification is still useful. It reflects how Hibernate \"locates\" "
 "individual rows of the collection."
 msgstr ""
-"Notez que pour une relation un-vers-plusieurs, la \"clé primaire\" peut ne "
-"pas être la clé primaire de la table en base de données - mais même dans ce "
-"cas, la classification ci-dessus reste utile (Elle explique comment "
-"Hibernate \"localise\" chaque enregistrement de la collection)."
+"Notez que pour une relation un-à-plusieurs, la \"clé primaire\" peut ne pas "
+"être la clé primaire de la table en base de données - mais même dans ce cas, "
+"la classification ci-dessus reste utile (Elle explique comment Hibernate "
+"localise les lignes individuelles de la collection). "
 
 #. Tag: title
-#: performance.xml:1096
 #, no-c-format
 msgid ""
 "Lists, maps, idbags and sets are the most efficient collections to update"
 msgstr ""
-"Les lists, les maps, les idbags et les sets sont les collections les plus "
-"efficaces pour la mise à jour"
+"Les lists, les maps, les idbags et les ensembles sont les collections les "
+"plus efficaces pour la mise à jour "
 
 #. Tag: para
-#: performance.xml:1098
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "From the discussion above, it should be clear that indexed collections and "
 "sets allow the most efficient operation in terms of adding, removing and "
 "updating elements."
 msgstr ""
 "La discussion précédente montre clairement que les collections indexées et "
-"(la plupart du temps) les sets, permettent de réaliser le plus efficacement "
-"les opérations d'ajout, de suppression ou de modification d'éléments."
+"(la plupart du temps) les ensembles, permettent de réaliser le plus "
+"efficacement les opérations d'ajout, de suppression ou mise à jour "
+"d'éléments. "
 
 #. Tag: para
-#: performance.xml:1104
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is, arguably, one more advantage that indexed collections have over "
 "sets for many-to-many associations or collections of values. Because of the "
@@ -2227,18 +1892,16 @@
 "literal> of individual rows. Once again, this consideration does not apply "
 "to one-to-many associations."
 msgstr ""
-"Il existe un autre avantage qu'ont les collections indexées sur les Sets "
-"dans le cadre d'une association plusieurs vers plusieurs ou d'une collection "
-"de valeurs. A cause de la structure inhérente d'un <literal>Set</literal>, "
-"Hibernate n'effectue jamais d'<literal>UPDATE</literal> quand un "
-"enregistrement est modifié. Les modifications apportées à un <literal>Set</"
-"literal> se font via un <literal>INSERT</literal> et <literal>DELETE</"
-"literal> (de chaque enregistrement). Une fois de plus, ce cas ne s'applique "
-"pas aux associations un vers plusieurs."
+"Les collections indexées ont un avantage sur les ensembles, dans le cadre "
+"des associations plusieurs-à-plusieurs ou de collections de valeurs. À cause "
+"de la structure inhérente d'un <literal>Set</literal>, Hibernate n'effectue "
+"jamais de ligne <literal>UPDATE</literal> quand un élément est modifié. Les "
+"modifications apportées à un <literal>Set</literal> se font via un "
+"<literal>INSERT</literal> et <literal>DELETE</literal> (de chaque ligne). "
+"Une fois de plus, ce cas ne s'applique pas aux associations un-à-plusieurs. "
 
 #. Tag: para
-#: performance.xml:1113
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "After observing that arrays cannot be lazy, you can conclude that lists, "
 "maps and idbags are the most performant (non-inverse) collection types, with "
@@ -2246,16 +1909,15 @@
 "collection in Hibernate applications. This is because the \"set\" semantics "
 "are most natural in the relational model."
 msgstr ""
-"Après s'être rappelé que les tableaux ne peuvent pas être chargés "
-"tardivement, nous pouvons conclure que les lists, les maps et les idbags "
-"sont les types de collections (non inversées) les plus performants, avec les "
-"sets pas loin derrières. Les sets son le type de collection le plus courant "
-"dans les applications Hibernate. Cela est du au fait que la sémantique des "
-"\"set\" est la plus naturelle dans le modèle relationnel."
+"Après s'être rappelé que les tableaux ne peuvent pas être chargés en "
+"différé, nous pouvons conclure que les lists, les maps et les idbags sont "
+"les types de collections (non inversées) les plus performants, avec les "
+"ensembles pas loin derrière. Les ensembles sont le type de collection le "
+"plus courant dans les applications Hibernate. Cela vient du fait que la "
+"sémantique des ensembles est la plus naturelle dans le modèle relationnel. "
 
 #. Tag: para
-#: performance.xml:1121
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, in well-designed Hibernate domain models, most collections are in "
 "fact one-to-many associations with <literal>inverse=\"true\"</literal>. For "
@@ -2263,23 +1925,21 @@
 "association, and so considerations of collection update performance simply "
 "do not apply."
 msgstr ""
-"Cependant, dans des modèles objet bien conçus avec Hibernate, on voit "
-"souvent que la plupart des collections sont en fait des associations \"un-"
-"vers-plusieurs\" avec <literal>inverse=\"true\"</literal>. Pour ces "
-"associations, les mises à jour sont gérées au niveau de l'association "
-"\"plusieurs-vers-un\" et les considérations de performance de mise à jour "
-"des collections ne s'appliquent tout simplement pas dans ces cas là."
+"Cependant, dans des modèles objet bien conçus avec Hibernate, on constate "
+"que la plupart des collections sont en fait des associations un-à-plusieurs "
+"avec <literal>inverse=\"true\"</literal>. Pour ces associations, les mises à "
+"jour sont gérées au niveau de l'association \"plusieurs-à-un\" et les "
+"considérations de performance de mise à jour des collections ne s'appliquent "
+"tout simplement pas dans ces cas-là. "
 
 #. Tag: title
-#: performance.xml:1131
 #, no-c-format
 msgid "Bags and lists are the most efficient inverse collections"
 msgstr ""
-"Les Bags et les lists sont les plus efficaces pour les collections inverse"
+"Les sacs et les listes sont les plus efficaces pour les collections inverses"
 
 #. Tag: para
-#: performance.xml:1133
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is a particular case, however, in which bags, and also lists, are much "
 "more performant than sets. For a collection with <literal>inverse=\"true\"</"
@@ -2290,37 +1950,24 @@
 "literal> must always return true for a bag or <literal>List</literal>. This "
 "can make the following common code much faster:"
 msgstr ""
-"Avant que vous n'oubliez les bags pour toujours, il y a un cas précis où les "
-"bags (et les lists) sont bien plus performants que les sets. Pour une "
+"Avant que vous n'oubliez les sacs pour toujours, il y a un cas précis où les "
+"sacs (et les listes) sont bien plus performants que les ensembles. Pour une "
 "collection marquée comme <literal>inverse=\"true\"</literal> (le choix le "
-"plus courant pour un relation un vers plusieurs bidirectionnelle), nous "
-"pouvons ajouter des éléments à un bag ou une list sans avoir besoin de "
-"l'initialiser (fetch) les éléments du sac! Ceci parce que "
+"plus courant pour un relation un-à-plusieurs bidirectionnelle), nous pouvons "
+"ajouter des éléments à un sac ou une liste sans avoir besoin de "
+"l'initialiser (charger) les éléments du sac! Ceci parce que "
 "<literal>Collection.add()</literal> ou <literal>Collection.addAll()</"
-"literal> doit toujours retourner vrai pour un bag ou une <literal>List</"
+"literal> doit toujours retourner vrai pour un sac ou une <literal>List</"
 "literal> (contrairement au <literal>Set</literal>). Cela peut rendre le code "
-"suivant beaucoup plus rapide."
+"suivant beaucoup plus rapide :"
 
-#. Tag: programlisting
-#: performance.xml:1143
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = (Parent) sess.load(Parent.class, id);\n"
-"Child c = new Child();\n"
-"c.setParent(p);\n"
-"p.getChildren().add(c);  //no need to fetch the collection!\n"
-"sess.flush();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:1148
 #, no-c-format
 msgid "One shot delete"
 msgstr "Suppression en un coup"
 
 #. Tag: para
-#: performance.xml:1150
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Deleting collection elements one by one can sometimes be extremely "
 "inefficient. Hibernate knows not to do that in the case of an newly-empty "
@@ -2330,95 +1977,86 @@
 "Parfois, effacer les éléments d'une collection un par un peut être "
 "extrêmement inefficace. Hibernate n'est pas totalement stupide, il sait "
 "qu'il ne faut pas le faire dans le cas d'une collection complètement vidée "
-"(lorsque vous appellez <literal>list.clear()</literal>, par exemple). Dans "
-"ce cas, Hibernate fera un simple <literal>DELETE</literal> et le travail est "
-"fait !"
+"(lorsque vous appelez <literal>list.clear()</literal>, par exemple). Dans ce "
+"cas, Hibernate fera un simple <literal>DELETE</literal> et le travail est "
+"fait ! "
 
 #. Tag: para
-#: performance.xml:1157
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Suppose you added a single element to a collection of size twenty and then "
 "remove two elements. Hibernate will issue one <literal>INSERT</literal> "
 "statement and two <literal>DELETE</literal> statements, unless the "
 "collection is a bag. This is certainly desirable."
 msgstr ""
-"Supposons que nous ajoutions un élément dans une collection de taille vingt "
-"et que nous enlevions ensuite deux éléments. Hibernate effectuera un "
+"Supposons que nous ajoutions un élément unique dans une collection de taille "
+"vingt et que nous enlevions ensuite deux éléments. Hibernate effectuera un "
 "<literal>INSERT</literal> puis deux <literal>DELETE</literal> (à moins que "
-"la collection ne soit un bag). Ce qui est souhaitable."
+"la collection ne soit un sac). Cela est préférable. "
 
 #. Tag: para
-#: performance.xml:1163
 #, no-c-format
 msgid ""
 "However, suppose that we remove eighteen elements, leaving two and then add "
 "thee new elements. There are two possible ways to proceed"
 msgstr ""
-"Cependant, supposons que nous enlevions dix huit éléments, laissant ainsi "
+"Cependant, supposons que nous enlevions dix-huit éléments, laissant ainsi "
 "deux éléments, puis que nous ajoutions trois nouveaux éléments. Il y a deux "
 "moyens de procéder."
 
 #. Tag: para
-#: performance.xml:1170
 #, no-c-format
 msgid "delete eighteen rows one by one and then insert three rows"
-msgstr "effacer dix huit enregistrements un à un puis en insérer trois"
+msgstr "effacer dix-huit lignes une à une puis en insérer trois"
 
 #. Tag: para
-#: performance.xml:1173
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "remove the whole collection in one SQL <literal>DELETE</literal> and insert "
 "all five current elements one by one"
 msgstr ""
-"effacer la totalité de la collection (en un <literal>DELETE</literal> SQL) "
-"puis insérer les cinq éléments restant un à un"
+"effacer la totalité de la collection (en un SQL <literal>DELETE</literal>) "
+"puis insérer les cinq éléments restant (un à un) "
 
 #. Tag: para
-#: performance.xml:1178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate cannot know that the second option is probably quicker. It would "
 "probably be undesirable for Hibernate to be that intuitive as such behavior "
 "might confuse database triggers, etc."
 msgstr ""
 "Hibernate n'est pas assez intelligent pour savoir que, dans ce cas, la "
-"seconde méthode est plus rapide (Il plutôt heureux qu'Hibernate ne soit pas "
-"trop intelligent ; un tel comportement pourrait rendre l'utilisation de "
-"triggers de bases de données plutôt aléatoire, etc...)."
+"seconde option est plus rapide (Il vaut mieux que Hibernate ne soit pas trop "
+"intelligent ; un tel comportement pourrait rendre l'utilisation de triggers "
+"de bases de données plutôt aléatoire, etc...). "
 
 #. Tag: para
-#: performance.xml:1184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Fortunately, you can force this behavior (i.e. the second strategy) at any "
 "time by discarding (i.e. dereferencing) the original collection and "
 "returning a newly instantiated collection with all the current elements."
 msgstr ""
-"Heureusement, vous pouvez forcer ce comportement lorsque vous le souhaitez, "
-"en liberant (c'est-à-dire en déréférençant) la collection initiale et en "
-"retournant une collection nouvellement instanciée avec les éléments "
-"restants. Ceci peut être très pratique et très puissant de temps en temps."
+"Heureusement, vous pouvez forcer ce comportement (c'est-à-dire la deuxième "
+"stratégie) à tout moment en libérant (c'est-à-dire en déréférençant) la "
+"collection initiale et en retournant une collection nouvellement instanciée "
+"avec tous les éléments restants. "
 
 #. Tag: para
-#: performance.xml:1190
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "One-shot-delete does not apply to collections mapped <literal>inverse=\"true"
 "\"</literal>."
 msgstr ""
 "Bien sûr, la suppression en un coup ne s'applique pas pour les collections "
-"qui sont mappées avec <literal>inverse=\"true\"</literal>."
+"qui sont mappées avec <literal>inverse=\"true\"</literal>. "
 
 #. Tag: title
-#: performance.xml:1199
 #, no-c-format
 msgid "Monitoring performance"
 msgstr "Moniteur de performance"
 
 #. Tag: para
-#: performance.xml:1201
 #, no-c-format
 msgid ""
 "Optimization is not much use without monitoring and access to performance "
@@ -2432,27 +2070,24 @@
 "<literal>SessionFactory</literal>."
 
 #. Tag: title
-#: performance.xml:1208
 #, no-c-format
 msgid "Monitoring a SessionFactory"
 msgstr "Suivi d'une SessionFactory"
 
 #. Tag: para
-#: performance.xml:1210
 #, no-c-format
 msgid ""
 "You can access <literal>SessionFactory</literal> metrics in two ways. Your "
 "first option is to call <literal>sessionFactory.getStatistics()</literal> "
 "and read or display the <literal>Statistics</literal> yourself."
 msgstr ""
-"Vous pouvez accéder au métriques d'une <literal>SessionFactory</literal> de "
+"Vous pouvez accéder aux métriques d'une <literal>SessionFactory</literal> de "
 "deux manières. La première option est d'appeler <literal>sessionFactory."
 "getStatistics()</literal> et de lire ou d'afficher les <literal>Statistics</"
-"literal> vous même."
+"literal> vous-même."
 
 #. Tag: para
-#: performance.xml:1216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate can also use JMX to publish metrics if you enable the "
 "<literal>StatisticsService</literal> MBean. You can enable a single MBean "
@@ -2462,49 +2097,18 @@
 "Hibernate peut également utiliser JMX pour publier les métriques si vous "
 "activez le MBean <literal>StatisticsService</literal>. Vous pouvez activer "
 "un seul MBean pour toutes vos <literal>SessionFactory</literal> ou un par "
-"factory. Voici un code qui montre un exemple de configuration minimaliste :"
+"fabrique. Voici un code qui montre un exemple de configuration minimaliste : "
 
-#. Tag: programlisting
-#: performance.xml:1223
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// MBean service registration for a specific SessionFactory\n"
-"Hashtable tb = new Hashtable();\n"
-"tb.put(\"type\", \"statistics\");\n"
-"tb.put(\"sessionFactory\", \"myFinancialApp\");\n"
-"ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-"\n"
-"StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-"stats.setSessionFactory(sessionFactory); // Bind the stats to a "
-"SessionFactory\n"
-"server.registerMBean(stats, on); // Register the Mbean on the server]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: performance.xml:1226
-#, no-c-format
-msgid ""
-"<![CDATA[// MBean service registration for all SessionFactory's\n"
-"Hashtable tb = new Hashtable();\n"
-"tb.put(\"type\", \"statistics\");\n"
-"tb.put(\"sessionFactory\", \"all\");\n"
-"ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-"\n"
-"StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-"server.registerMBean(stats, on); // Register the MBean on the server]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:1228
-#, fuzzy, no-c-format
-msgid ""
 "You can activate and deactivate the monitoring for a "
 "<literal>SessionFactory</literal>:"
 msgstr ""
-"Vous pouvez (dés)activer le suivi pour une <literal>SessionFactory</literal>"
+"Vous pouvez (dés)activer le suivi pour une <literal>SessionFactory</"
+"literal> :"
 
 #. Tag: para
-#: performance.xml:1233
 #, no-c-format
 msgid ""
 "at configuration time, set <literal>hibernate.generate_statistics</literal> "
@@ -2514,7 +2118,6 @@
 "generate_statistics</literal> à <literal>false</literal>"
 
 #. Tag: para
-#: performance.xml:1240
 #, no-c-format
 msgid ""
 "at runtime: <literal>sf.getStatistics().setStatisticsEnabled(true)</literal> "
@@ -2524,8 +2127,7 @@
 "literal> ou <literal>hibernateStatsBean.setStatisticsEnabled(true)</literal>"
 
 #. Tag: para
-#: performance.xml:1247
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Statistics can be reset programmatically using the <literal>clear()</"
 "literal> method. A summary can be sent to a logger (info level) using the "
@@ -2534,30 +2136,27 @@
 "Les statistiques peuvent être remises à zéro de manière programmatique à "
 "l'aide de la méthode <literal>clear()</literal> Un résumé peut être envoyé à "
 "un logger (niveau info) à l'aide de la méthode <literal>logSummary()</"
-"literal>"
+"literal>."
 
 #. Tag: title
-#: performance.xml:1256
 #, no-c-format
 msgid "Metrics"
 msgstr "Métriques"
 
 #. Tag: para
-#: performance.xml:1258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate provides a number of metrics, from basic information to more "
 "specialized information that is only relevant in certain scenarios. All "
 "available counters are described in the <literal>Statistics</literal> "
 "interface API, in three categories:"
 msgstr ""
-"Hibernate fournit un certain nombre de métriques, qui vont des informations "
-"très basiques aux informations très spécialisées qui ne sont appropriées que "
-"dans certains scenarii. Tous les compteurs accessibles sont décrits dans "
-"l'API de l'interface <literal>Statistics</literal> dans trois catégories :"
+"Hibernate fournit plusieurs métriques, qui vont des informations très "
+"basiques aux informations très spécialisées qui ne sont appropriées que dans "
+"certains scénarios. Tous les compteurs accessibles sont décrits dans l'API "
+"de l'interface <literal>Statistics</literal> dans trois catégories : "
 
 #. Tag: para
-#: performance.xml:1265
 #, no-c-format
 msgid ""
 "Metrics related to the general <literal>Session</literal> usage, such as "
@@ -2568,17 +2167,15 @@
 "récupérées, etc..."
 
 #. Tag: para
-#: performance.xml:1271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Metrics related to the entities, collections, queries, and caches as a whole "
 "(aka global metrics)."
 msgstr ""
 "Les métriques relatives aux entités, collections, requêtes et caches dans "
-"leur ensemble (métriques globales),"
+"leur ensemble (métriques globales aka)."
 
 #. Tag: para
-#: performance.xml:1277
 #, no-c-format
 msgid ""
 "Detailed metrics related to a particular entity, collection, query or cache "
@@ -2588,8 +2185,7 @@
 "ou une région de cache particulière."
 
 #. Tag: para
-#: performance.xml:1284
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For example, you can check the cache hit, miss, and put ratio of entities, "
 "collections and queries, and the average time a query needs. Be aware that "
@@ -2597,16 +2193,15 @@
 "tied to the JVM precision and on some platforms this might only be accurate "
 "to 10 seconds."
 msgstr ""
-"Par exemple, vous pouvez vérifier l'accès au cache ainsi que le taux "
+"Par exemple, vous pouvez vérifier les hit, miss du cache ainsi que le taux "
 "d'éléments manquants et de mise à jour des entités, collections et requêtes "
 "et le temps moyen que met une requête. Il faut faire attention au fait que "
 "le nombre de millisecondes est sujet à approximation en Java. Hibernate est "
 "lié à la précision de la machine virtuelle, sur certaines plateformes, cela "
-"n'offre qu'une précision de l'ordre de 10 secondes."
+"n'offre qu'une précision de l'ordre de 10 secondes. "
 
 #. Tag: para
-#: performance.xml:1291
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Simple getters are used to access the global metrics (i.e. not tied to a "
 "particular entity, collection, cache region, etc.). You can access the "
@@ -2618,43 +2213,20 @@
 "literal> API Javadoc for more information. The following code is a simple "
 "example:"
 msgstr ""
-"Des accesseurs simples sont utilisés pour accéder aux métriques globales (e."
-"g. celles qui ne sont pas liées à une entité, collection ou région de cache "
-"particulière). Vous pouvez accéder aux métriques d'une entité, collection, "
-"région de cache particulière à l'aide de son nom et à l'aide de sa "
-"représentation HQL ou SQL pour une requête. Référez vous à la javadoc des "
-"APIS <literal>Statistics</literal>, <literal>EntityStatistics</literal>, "
-"<literal>CollectionStatistics</literal>, "
-"<literal>SecondLevelCacheStatistics</literal>, and <literal>QueryStatistics</"
+"Des accesseurs simples sont utilisés pour accéder aux métriques globales "
+"(c'est-à-dire, celles qui ne sont pas liées à une entité, collection ou "
+"région de cache particulière). Vous pouvez accéder aux métriques d'une "
+"entité, collection, région de cache particulière à l'aide de son nom et à "
+"l'aide de sa représentation HQL ou SQL pour une requête. Référez vous à la "
+"javadoc des APIS <literal>Statistics</literal>, <literal>EntityStatistics</"
+"literal>, <literal>CollectionStatistics</literal>, "
+"<literal>SecondLevelCacheStatistics</literal>, et <literal>QueryStatistics</"
 "literal> pour plus d'informations. Le code ci-dessous montre un exemple "
-"simple :"
+"simple : "
 
-#. Tag: programlisting
-#: performance.xml:1301
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Statistics stats = HibernateUtil.sessionFactory.getStatistics();\n"
-"\n"
-"double queryCacheHitCount  = stats.getQueryCacheHitCount();\n"
-"double queryCacheMissCount = stats.getQueryCacheMissCount();\n"
-"double queryCacheHitRatio =\n"
-"  queryCacheHitCount / (queryCacheHitCount + queryCacheMissCount);\n"
-"\n"
-"log.info(\"Query Hit ratio:\" + queryCacheHitRatio);\n"
-"\n"
-"EntityStatistics entityStats =\n"
-"  stats.getEntityStatistics( Cat.class.getName() );\n"
-"long changes =\n"
-"        entityStats.getInsertCount()\n"
-"        + entityStats.getUpdateCount()\n"
-"        + entityStats.getDeleteCount();\n"
-"log.info(Cat.class.getName() + \" changed \" + changes + \"times\"  );]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:1303
-#, fuzzy, no-c-format
-msgid ""
 "You can work on all entities, collections, queries and region caches, by "
 "retrieving the list of names of entities, collections, queries and region "
 "caches using the following methods: <literal>getQueries()</literal>, "
@@ -2663,48 +2235,28 @@
 msgstr ""
 "Pour travailler sur toutes les entités, collections, requêtes et régions de "
 "cache, vous pouvez récupérer la liste des noms des entités, collections, "
-"requêtes et régions de cache avec les méthodes : <literal>getQueries()</"
-"literal>, <literal>getEntityNames()</literal>, "
+"requêtes et régions de cache avec les méthodes suivantes : "
+"<literal>getQueries()</literal>, <literal>getEntityNames()</literal>, "
 "<literal>getCollectionRoleNames()</literal>, et "
-"<literal>getSecondLevelCacheRegionNames()</literal>."
+"<literal>getSecondLevelCacheRegionNames()</literal>. "
 
 #~ msgid ""
-#~ "where <literal>CatImpl</literal> implements the interface <literal>Cat</"
-#~ "literal> and <literal>DomesticCatImpl</literal> implements the interface "
-#~ "<literal>DomesticCat</literal>. Then proxies for instances of "
-#~ "<literal>Cat</literal> and <literal>DomesticCat</literal> may be returned "
-#~ "by <literal>load()</literal> or <literal>iterate()</literal>. (Note that "
-#~ "<literal>list()</literal> does not usually return proxies.)"
+#~ "This setting creates two new cache regions: one holding cached query "
+#~ "result sets (<literal>org.hibernate.cache.StandardQueryCache</literal>), "
+#~ "the other holding timestamps of the most recent updates to queryable "
+#~ "tables (<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). "
+#~ "Note that the query cache does not cache the state of the actual entities "
+#~ "in the result set; it caches only identifier values and results of value "
+#~ "type. The query cache should always be used in conjunction with the "
+#~ "second-level cache."
 #~ msgstr ""
-#~ "où <literal>CatImpl</literal> implémente l'interface <literal>Cat</"
-#~ "literal> et <literal>DomesticCatImpl</literal> implémente l'interface "
-#~ "<literal>DomesticCat</literal>. Ainsi, des proxys pour les instances de "
-#~ "<literal>Cat</literal> et <literal>DomesticCat</literal> pourraient être "
-#~ "retournées par <literal>load()</literal> ou <literal>iterate()</literal> "
-#~ "(Notez que <literal>list()</literal> ne retourne généralement pas de "
-#~ "proxy)."
-
-#~ msgid ""
-#~ "We've already spent quite some time talking about collections. In this "
-#~ "section we will highlight a couple more issues about how collections "
-#~ "behave at runtime."
-#~ msgstr ""
-#~ "Nous avons déjà passé du temps à discuter des collections. Dans cette "
-#~ "section, nous allons traiter du comportement des collections à "
-#~ "l'exécution."
-
-#~ msgid ""
-#~ "TODO: This doesn't make sense: In the first case, we retrieve and use the "
-#~ "MBean directly. In the second one, we must give the JNDI name in which "
-#~ "the session factory is held before using it. Use "
-#~ "<literal>hibernateStatsBean.setSessionFactoryJNDIName(\"my/JNDI/Name\")</"
-#~ "literal>"
-#~ msgstr ""
-#~ "TODO: Cela n'a pas de sens : dans le premier cs on récupère et on utilise "
-#~ "le MBean directement. Dans le second, on doit fournir le nom JNDI sous "
-#~ "lequel est retenu la fabrique de session avant de l'utiliser. Pour cela "
-#~ "il faut utiliser <literal>hibernateStatsBean.setSessionFactoryJNDIName"
-#~ "(\"my/JNDI/Name\")</literal>"
-
-#~ msgid "yes"
-#~ msgstr "oui"
+#~ "Ce paramètre amène la création de deux nouvelles régions dans le cache, "
+#~ "une qui va conserver le résultat des requêtes mises en cache "
+#~ "(<literal>org.hibernate.cache.StandardQueryCache</literal>) et l'autre "
+#~ "qui va conserver l'horodatage des mises à jour les plus récentes "
+#~ "effectuées sur les tables requêtables (<literal>org.hibernate.cache."
+#~ "UpdateTimestampsCache</literal>). Il faut noter que le cache de requête "
+#~ "ne conserve pas l'état des entités dans les résultats, il met en cache "
+#~ "uniquement les valeurs de l'identifiant et les résultats de types de "
+#~ "valeurs. Par conséquent, le cache de requête doit toujours être utilisé "
+#~ "avec le cache de second niveau. "

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/persistent_classes.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/persistent_classes.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/persistent_classes.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,28 @@
+# translation of persistent_classes.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: persistent_classes\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-05 09:39+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: persistent_classes.xml:29
 #, no-c-format
 msgid "Persistent Classes"
 msgstr "Classes persistantes"
 
 #. Tag: para
-#: persistent_classes.xml:31
-#, fuzzy, no-c-format
+#, 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 "
@@ -27,14 +31,13 @@
 "or detached."
 msgstr ""
 "Les classes persistantes sont les classes d'une application qui implémentent "
-"les entités d'un problème métier (ex. Client et Commande dans une "
+"les entités d'un problème métier (par ex. Client et Commande dans une "
 "application de commerce électronique). Toutes les instances d'une classe "
-"persistante ne sont pas forcément dans l'état persistant - au lieu de cela, "
-"une instance peut être éphémère (NdT : transient) ou détachée."
+"persistante ne sont pas forcément dans l'état persistant - en revanche, une "
+"instance peut être éphémère (transient) ou détachée."
 
 #. Tag: para
-#: persistent_classes.xml:38
-#, fuzzy, no-c-format
+#, 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 "
@@ -45,128 +48,41 @@
 "Hibernate fonctionne de manière optimale lorsque ces classes suivent "
 "quelques règles simples, aussi connues comme le modèle de programmation "
 "Plain Old Java Object (POJO). Cependant, aucune de ces règles ne sont des "
-"besoins absolus. En effet, Hibernate3 suppose très peu de choses à propos de "
-"la nature de vos objets persistants. Vous pouvez exprimer un modèle de "
+"besoins absolus. En effet, Hibernate3 présuppose très peu de choses à propos "
+"de la nature de vos objets persistants. Vous pouvez exprimer un modèle de "
 "domaine par d'autres moyens : utiliser des arbres d'instances de "
 "<literal>Map</literal>, par exemple."
 
 #. Tag: title
-#: persistent_classes.xml:47
 #, no-c-format
 msgid "A simple POJO example"
 msgstr "Un exemple simple de POJO"
 
 #. Tag: para
-#: persistent_classes.xml:49
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Most Java applications require a persistent class representing felines. For "
 "example:"
 msgstr ""
 "Toute bonne application Java nécessite une classe persistante représentant "
-"les félins."
+"les félins. Par exemple :"
 
-#. Tag: programlisting
-#: persistent_classes.xml:53
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"import java.util.Date;\n"
-"\n"
-"public class Cat {\n"
-"    private Long id; // identifier\n"
-"\n"
-"    private Date birthdate;\n"
-"    private Color color;\n"
-"    private char sex;\n"
-"    private float weight;\n"
-"    private int litterId;\n"
-"\n"
-"    private Cat mother;\n"
-"    private Set kittens = new HashSet();\n"
-"\n"
-"    private void setId(Long id) {\n"
-"        this.id=id;\n"
-"    }\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"\n"
-"    void setBirthdate(Date date) {\n"
-"        birthdate = date;\n"
-"    }\n"
-"    public Date getBirthdate() {\n"
-"        return birthdate;\n"
-"    }\n"
-"\n"
-"    void setWeight(float weight) {\n"
-"        this.weight = weight;\n"
-"    }\n"
-"    public float getWeight() {\n"
-"        return weight;\n"
-"    }\n"
-"\n"
-"    public Color getColor() {\n"
-"        return color;\n"
-"    }\n"
-"    void setColor(Color color) {\n"
-"        this.color = color;\n"
-"    }\n"
-"\n"
-"    void setSex(char sex) {\n"
-"        this.sex=sex;\n"
-"    }\n"
-"    public char getSex() {\n"
-"        return sex;\n"
-"    }\n"
-"\n"
-"    void setLitterId(int id) {\n"
-"        this.litterId = id;\n"
-"    }\n"
-"    public int getLitterId() {\n"
-"        return litterId;\n"
-"    }\n"
-"\n"
-"    void setMother(Cat mother) {\n"
-"        this.mother = mother;\n"
-"    }\n"
-"    public Cat getMother() {\n"
-"        return mother;\n"
-"    }\n"
-"    void setKittens(Set kittens) {\n"
-"        this.kittens = kittens;\n"
-"    }\n"
-"    public Set getKittens() {\n"
-"        return kittens;\n"
-"    }\n"
-"    \n"
-"    // addKitten not needed by Hibernate\n"
-"    public void addKitten(Cat kitten) {\n"
-"            kitten.setMother(this);\n"
-"        kitten.setLitterId( kittens.size() ); \n"
-"        kittens.add(kitten);\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:55
 #, no-c-format
 msgid ""
 "The four main rules of persistent classes are explored in more detail in the "
 "following sections."
 msgstr ""
+"On explore quatre règles principales de classes persistantes en détail dans "
+"les sections qui suivent :"
 
 #. Tag: title
-#: persistent_classes.xml:61
 #, no-c-format
 msgid "Implement a no-argument constructor"
 msgstr "Implémenter un constructeur sans argument"
 
 #. Tag: para
-#: persistent_classes.xml:63
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Cat</literal> has a no-argument constructor. All persistent classes "
 "must have a default constructor (which can be non-public) so that Hibernate "
@@ -177,21 +93,19 @@
 msgstr ""
 "<literal>Cat</literal> a un constructeur sans argument. Toutes les classes "
 "persistantes doivent avoir un constructeur par défaut (lequel peut ne pas "
-"être public) pour qu'Hibernate puissent les instancier en utilisant "
+"être public) pour que Hibernate puisse les instancier en utilisant "
 "<literal>Constructor.newInstance()</literal>. Nous recommandons fortement "
 "d'avoir un constructeur par défaut avec au moins une visibilité "
-"<emphasis>paquet</emphasis> pour la génération du proxy à l'exécution dans "
-"Hibernate."
+"<emphasis>paquetage</emphasis> pour la génération du proxy à l'exécution "
+"dans Hibernate. "
 
 #. Tag: title
-#: persistent_classes.xml:73
 #, no-c-format
 msgid "Provide an identifier property (optional)"
-msgstr "Fournir une propriété d'indentifiant (optionnel)"
+msgstr "Fournir une propriété d'identifiant (optionnel)"
 
 #. Tag: para
-#: persistent_classes.xml:75
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Cat</literal> has a property called <literal>id</literal>. This "
 "property maps to the primary key column of a database table. The property "
@@ -203,92 +117,83 @@
 msgstr ""
 "<literal>Cat</literal> possède une propriété appelée <literal>id</literal>. "
 "Cette propriété mappe la valeur de la colonne de clé primaire de la table "
-"d'une base de données.La propriété aurait pu s'appeler complètement "
-"autrement, et son type aurait pu être n'importe quel type primitif, "
-"n'importe quel \"encapsuleur\" de type primitif, <literal>java.lang.String</"
-"literal> ou <literal>java.util.Date</literal>. (Si votre base de données "
-"héritée possède des clés composites, elles peuvent être mappées en utilisant "
-"une classe définie par l'utilisateur et possédant les propriétés associées "
-"aux types de la clé composite - voir la section concernant les identifiants "
-"composites plus tard)."
+"d'une base de données. La propriété aurait pu s'appeler autrement, et son "
+"type aurait pu être n'importe quel type primitif, n'importe quel "
+"\"encapsuleur\" de type primitif, <literal>java.lang.String</literal> ou "
+"<literal>java.util.Date</literal>. (Si votre base de données héritée possède "
+"des clés composites, elles peuvent être mappées en utilisant une classe "
+"définie par l'utilisateur et possédant les propriétés associées aux types de "
+"la clé composite - voir la section concernant les identifiants composites "
+"ultérieurement). "
 
 #. Tag: para
-#: persistent_classes.xml:84
 #, 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 ""
-"La propriété d'identifiant est strictement optionnelle. Vous pouver "
+"La propriété d'identifiant est strictement optionnelle. Vous pouvez "
 "l'oublier et laisser Hibernate s'occuper des identifiants de l'objet en "
-"interne. Toutefois, nous ne le recommandons pas."
+"interne. Toutefois, ce n'est pas recommandé. "
 
 #. Tag: para
-#: persistent_classes.xml:89
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In fact, some functionality is available only to classes that declare an "
 "identifier property:"
 msgstr ""
 "En fait, quelques fonctionnalités ne sont disponibles que pour les classes "
-"déclarant un identifiant de propriété :"
+"déclarant un identifiant de propriété : "
 
 #. Tag: para
-#: persistent_classes.xml:96
 #, fuzzy, no-c-format
 msgid ""
 "Transitive reattachment for detached objects (cascade update or cascade "
-"merge) - see"
+"merge) - see <xref linkend=\"objectstate-transitive\" />"
 msgstr ""
-"Les réattachements transitifs pour les objets détachés (mise à jour en "
-"cascade ou fusion en cascade) - voir <xref linkend=\"objectstate-transitive"
-"\"/>"
+"Pour les rattachements transitifs pour les objets détachés (mise à jour en "
+"cascade ou fusion en cascade) - consultez <xref linkend=\"objectstate-"
+"transitive\" />"
 
-#. Tag: literal
-#: persistent_classes.xml:103
-#, no-c-format
-msgid "Session.saveOrUpdate()"
-msgstr "Session.saveOrUpdate()"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>Session.saveOrUpdate()</literal>"
+msgstr "<literal>Session.saveOrUpdate()</literal>"
 
-#. Tag: literal
-#: persistent_classes.xml:108
-#, no-c-format
-msgid "Session.merge()"
-msgstr "Session.merge()"
-
 #. Tag: para
-#: persistent_classes.xml:113
 #, fuzzy, no-c-format
+msgid "<literal>Session.merge()</literal>"
+msgstr "<literal>Session.merge()</literal>"
+
+#. Tag: para
+#, 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 ""
 "Nous recommandons que vous déclariez les propriétés d'identifiant de manière "
 "uniforme. Nous recommandons également que vous utilisiez un type nullable "
-"(ie. non primitif)."
+"(c'est-à-dire non primitif). "
 
 #. Tag: title
-#: persistent_classes.xml:120
 #, no-c-format
 msgid "Prefer non-final classes (optional)"
 msgstr "Favoriser les classes non finales (optionnel)"
 
 #. Tag: para
-#: persistent_classes.xml:121
 #, no-c-format
 msgid ""
 "A central feature of Hibernate, <emphasis>proxies</emphasis>, depends upon "
 "the persistent class being either non-final, or the implementation of an "
 "interface that declares all public methods."
 msgstr ""
-"Une fonctionnalité clef d'Hibernate, les <emphasis>proxies</emphasis>, "
-"nécessitent que la classe persistente soit non finale ou qu'elle soit "
+"Une fonctionnalité clé de Hibernate, les <emphasis>proxies</emphasis>, "
+"nécessitent que la classe persistante soit non finale ou qu'elle soit "
 "l'implémentation d'une interface qui déclare toutes les méthodes publiques."
 
 #. Tag: para
-#: persistent_classes.xml:126
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can persist <literal>final</literal> classes that do not implement an "
 "interface with Hibernate. You will not, however, be able to use proxies for "
@@ -297,11 +202,10 @@
 msgstr ""
 "Vous pouvez persister, grâce à Hibernate, les classes <literal>final</"
 "literal> qui n'implémentent pas d'interface, mais vous ne pourrez pas "
-"utiliser les proxies pour les chargements d'associations paresseuses - ce "
-"qui limitera vos possibilités d'ajustement des performances."
+"utiliser les proxies pour les chargements d'associations paresseux - ce qui "
+"limitera vos possibilités d'ajustement des performances. "
 
 #. Tag: para
-#: persistent_classes.xml:131
 #, no-c-format
 msgid ""
 "You should also avoid declaring <literal>public final</literal> methods on "
@@ -312,18 +216,16 @@
 "Vous devriez aussi éviter de déclarer des méthodes <literal>public final</"
 "literal> sur des classes non-finales. Si vous voulez utiliser une classe "
 "avec une méthode <literal>public final</literal>, vous devez explicitement "
-"désactiver les proxies en paramétrant <literal>lazy=\"false\"</literal>."
+"désactiver les proxies en paramétrant <literal>lazy=\"false\"</literal>. "
 
 #. Tag: title
-#: persistent_classes.xml:139
 #, no-c-format
 msgid "Declare accessors and mutators for persistent fields (optional)"
 msgstr ""
 "Déclarer les accesseurs et mutateurs des attributs persistants (optionnel)"
 
 #. Tag: para
-#: persistent_classes.xml:141
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Cat</literal> declares accessor methods for all its persistent "
 "fields. Many other ORM tools directly persist instance variables. It is "
@@ -333,18 +235,17 @@
 "literal>, <literal>isFoo</literal> and <literal>setFoo</literal>. If "
 "required, you can switch to direct field access for particular properties."
 msgstr ""
-"<literal>Cat</literal> déclare des mutateurs pour toutes ses champs "
-"persistants. Beaucoup d'autres solutions de mapping Objet/relationnel "
-"persistent directement les variables d'instance. Nous pensons qu'il est bien "
-"mieux de fournir une indirection entre le schéma relationnel et les "
+"<literal>Cat</literal> déclare des mutateurs pour tous ses champs "
+"persistants. Beaucoup d'autres solutions de mappage Objet/relationnel "
+"persistent directement les variables d'instance. Nous pensons qu'il est "
+"préférable de fournir une indirection entre le schéma relationnel et les "
 "structures de données internes de la classe. Par défaut, Hibernate persiste "
 "les propriétés suivant le style JavaBean, et reconnaît les noms de méthodes "
 "de la forme <literal> getFoo</literal>, <literal>isFoo</literal> et "
-"<literal>setFoo</literal>. Nous pouvons changer pour un accès direct aux "
-"champs pour des propriétés particulières, si besoin est."
+"<literal>setFoo</literal>. Vous pouvez changer pour un accès direct aux "
+"champs pour des propriétés particulières, si besoin est. "
 
 #. Tag: para
-#: persistent_classes.xml:151
 #, no-c-format
 msgid ""
 "Properties need <emphasis>not</emphasis> be declared public - Hibernate can "
@@ -352,65 +253,42 @@
 "<literal>private</literal> get / set pair."
 msgstr ""
 "Les propriétés <emphasis>n'ont pas</emphasis> à être déclarées publiques - "
-"Hibernate peut persister une propriété avec un paire de getter/setter de "
-"visibilité par défault, <literal>protected</literal> ou <literal> private</"
-"literal>."
+"Hibernate peut persister une propriété avec une paire de getter/setter par "
+"défault, <literal>protected</literal> ou <literal> private</literal>. "
 
 #. Tag: title
-#: persistent_classes.xml:162
 #, no-c-format
 msgid "Implementing inheritance"
 msgstr "Implémenter l'héritage"
 
 #. Tag: para
-#: persistent_classes.xml:164
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A subclass must also observe the first and second rules. It inherits its "
 "identifier property from the superclass, <literal>Cat</literal>. For example:"
 msgstr ""
 "Une sous-classe doit également suivre la première et la seconde règle. Elle "
-"hérite sa propriété d'identifiant de <literal>Cat</literal>."
+"hérite sa propriété d'identifiant de la classe mère <literal>Cat</literal>. "
+"Par exemple :"
 
-#. Tag: programlisting
-#: persistent_classes.xml:169
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"public class DomesticCat extends Cat {\n"
-"        private String name;\n"
-"\n"
-"        public String getName() {\n"
-"                return name;\n"
-"        }\n"
-"        protected void setName(String name) {\n"
-"                this.name=name;\n"
-"        }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: persistent_classes.xml:173
 #, no-c-format
 msgid ""
 "Implementing <literal>equals()</literal> and <literal>hashCode()</literal>"
 msgstr ""
-"Implémenter <literal>equals()</literal> et <literal>hashCode()</literal>"
+"Implémenter <literal>equals()</literal> et <literal>hashCode()</literal> "
 
 #. Tag: para
-#: persistent_classes.xml:175
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You have to override the <literal>equals()</literal> and <literal>hashCode()"
 "</literal> methods if you:"
 msgstr ""
 "Vous devez surcharger les méthodes <literal>equals()</literal> et "
-"<literal>hashCode()</literal> si vous"
+"<literal>hashCode()</literal> si vous :"
 
 #. Tag: para
-#: persistent_classes.xml:181
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "intend to put instances of persistent classes in a <literal>Set</literal> "
 "(the recommended way to represent many-valued associations); <emphasis>and</"
@@ -418,17 +296,15 @@
 msgstr ""
 "avez l'intention de mettre des instances de classes persistantes dans un "
 "<literal>Set</literal> (la manière recommandée pour représenter des "
-"associations pluri-valuées) <emphasis>et</emphasis>"
+"associations pluri-valuées); <emphasis>et</emphasis>"
 
 #. Tag: para
-#: persistent_classes.xml:188
 #, no-c-format
 msgid "intend to use reattachment of detached instances"
-msgstr "avez l'intention d'utiliser le réattachement d'instances détachées"
+msgstr "avez l'intention d'utiliser le rattachement d'instances détachées"
 
 #. Tag: para
-#: persistent_classes.xml:194
-#, fuzzy, no-c-format
+#, 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 "
@@ -441,11 +317,10 @@
 "session particulière. Donc dès que nous mélangeons des instances venant de "
 "différentes sessions, nous devons implémenter <literal>equals()</literal> et "
 "<literal>hashCode()</literal> si nous souhaitons avoir une sémantique "
-"correcte pour les <literal>Set</literal>s."
+"correcte pour les <literal>Set</literal> s. "
 
 #. Tag: para
-#: persistent_classes.xml:202
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The most obvious way is to implement <literal>equals()</literal>/"
 "<literal>hashCode()</literal> by comparing the identifier value of both "
@@ -475,14 +350,13 @@
 "sauvegarder assignera une valeur d'identifiant à l'objet. Si <literal>equals"
 "()</literal> et <literal>hashCode()</literal> sont basées sur la valeur de "
 "l'identifiant, le code de hachage devrait changer, rompant le contrat du "
-"<literal>Set</literal>. Regardez sur le site web d'Hibernate pour une "
-"discussion complète de ce problème. Notez que ceci n'est pas un problème "
-"d'Hibernate, mais la sémantique normale de Java pour l'identité d'un objet "
-"et l'égalité."
+"<literal>Set</literal>. Consultez le site web de Hibernate pour des "
+"informations plus approfondies. Notez que ceci n'est pas un problème "
+"Hibernate, mais concerne la sémantique normale de Java pour l'identité et "
+"l'égalité d'un objet. "
 
 #. Tag: para
-#: persistent_classes.xml:216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you implement <literal>equals()</literal> and "
 "<literal>hashCode()</literal> using <emphasis>Business key equality</"
@@ -493,78 +367,45 @@
 msgstr ""
 "Nous recommandons donc d'implémenter <literal>equals()</literal> et "
 "<literal>hashCode()</literal> en utilisant <emphasis> l'égalité par clé "
-"métier</emphasis>.L'égalité par clé métier signifie que la méthode "
+"métier</emphasis>. L'égalité par clé métier signifie que la méthode "
 "<literal>equals()</literal> compare uniquement les propriétés qui forment "
 "une clé métier, une clé qui identifierait notre instance dans le monde réel "
-"(une clé candidate <emphasis>naturelle</emphasis>) :"
+"(une clé candidate <emphasis>naturelle</emphasis>) : "
 
-#. Tag: programlisting
-#: persistent_classes.xml:224
-#, no-c-format
-msgid ""
-"<![CDATA[public class Cat {\n"
-"\n"
-"    ...\n"
-"    public boolean equals(Object other) {\n"
-"        if (this == other) return true;\n"
-"        if ( !(other instanceof Cat) ) return false;\n"
-"\n"
-"        final Cat cat = (Cat) other;\n"
-"\n"
-"        if ( !cat.getLitterId().equals( getLitterId() ) ) return false;\n"
-"        if ( !cat.getMother().equals( getMother() ) ) return false;\n"
-"\n"
-"        return true;\n"
-"    }\n"
-"\n"
-"    public int hashCode() {\n"
-"        int result;\n"
-"        result = getMother().hashCode();\n"
-"        result = 29 * result + getLitterId();\n"
-"        return result;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:226
 #, 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 "
+"candidate (see <xref linkend=\"transactions-basics-identity\" />). Immutable "
 "or unique properties are usually good candidates for a business key."
 msgstr ""
-"Notez qu'une clef métier ne doit pas être solide comme une clef primaire de "
-"base de données (voir <xref linkend=\"transactions-basics-identity\"/>). Les "
-"propriétés immuables ou uniques sont généralement de bonnes candidates pour "
-"une clef métier."
+"Notez qu'une clé métier ne doit pas être solide comme une clé primaire de "
+"base de données (voir <xref linkend=\"transactions-basics-identity\" />). "
+"Les propriétés immuables ou uniques sont généralement de bonnes candidates "
+"pour une clé métier. "
 
 #. Tag: title
-#: persistent_classes.xml:236
 #, no-c-format
 msgid "Dynamic models"
 msgstr "Modèles dynamiques"
 
 #. Tag: title
-#: persistent_classes.xml:239
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Remarque"
 
-#. Tag: emphasis
-#: persistent_classes.xml:241
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
-"The following features are currently considered experimental and may change "
-"in the near future."
+"<emphasis>The following features are currently considered experimental and "
+"may change in the near future.</emphasis>"
 msgstr ""
-"Notez que la fonctionnalités suivantes sont actuellement considérées comme "
-"expérimentales et peuvent changer dans un futur proche."
+"<emphasis>Notez que les fonctionnalités suivantes sont actuellement "
+"considérées comme expérimentales et pourront changer dans un futur proche.</"
+"emphasis>"
 
 #. Tag: para
-#: persistent_classes.xml:246
-#, fuzzy, no-c-format
+#, 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 "
@@ -575,91 +416,48 @@
 "Les entités persistantes ne doivent pas nécessairement être représentées "
 "comme des classes POJO ou des objets JavaBean à l'exécution. Hibernate "
 "supporte aussi les modèles dynamiques (en utilisant des <literal>Map</"
-"literal>s de <literal>Map</literal>s à l'exécution) et la représentation des "
-"entités comme des arbres DOM4J. Avec cette approche, vous n'écrivez pas de "
-"classes persistantes, seulement des fichiers de mapping."
+"literal> s de <literal>Map</literal> s à l'exécution) et la représentation "
+"des entités comme des arbres DOM4J. Avec cette approche, vous n'écrivez pas "
+"de classes persistantes, seulement des fichiers de mappage. "
 
 #. Tag: para
-#: persistent_classes.xml:254
 #, 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>SessionFactory</"
 "literal> using the <literal>default_entity_mode</literal> configuration "
-"option (see <xref linkend=\"configuration-optional-properties\"/>)."
+"option (see <xref linkend=\"configuration-optional-properties\" />)."
 msgstr ""
 "Par défaut, Hibernate fonctionne en mode POJO normal. Vous pouvez paramétrer "
 "un mode de représentation d'entité par défaut pour une "
 "<literal>SessionFactory</literal> particulière en utilisant l'option de "
 "configuration <literal>default_entity_mode</literal> (voir <xref linkend="
-"\"configuration-optional-properties\"/>)."
+"\"configuration-optional-properties\" />)."
 
 #. Tag: para
-#: persistent_classes.xml:261
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following examples demonstrate the representation using <literal>Map</"
 "literal>s. First, in the mapping file an <literal>entity-name</literal> has "
 "to be declared instead of, or in addition to, a class name:"
 msgstr ""
 "Les exemples suivants démontrent la représentation utilisant des "
-"<literal>Map</literal>s. D'abord, dans le fichier de mapping, un "
+"<literal>Map</literal> s. D'abord, dans le fichier de mappage, un "
 "<literal>entity-name</literal> doit être déclaré au lieu (ou en plus) d'un "
 "nom de classe :"
 
-#. Tag: programlisting
-#: persistent_classes.xml:267
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class entity-name=\"Customer\">\n"
-"\n"
-"        <id name=\"id\"\n"
-"            type=\"long\"\n"
-"            column=\"ID\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"\n"
-"        <property name=\"name\"\n"
-"            column=\"NAME\"\n"
-"            type=\"string\"/>\n"
-"\n"
-"        <property name=\"address\"\n"
-"            column=\"ADDRESS\"\n"
-"            type=\"string\"/>\n"
-"\n"
-"        <many-to-one name=\"organization\"\n"
-"            column=\"ORGANIZATION_ID\"\n"
-"            class=\"Organization\"/>\n"
-"\n"
-"        <bag name=\"orders\"\n"
-"            inverse=\"true\"\n"
-"            lazy=\"false\"\n"
-"            cascade=\"all\">\n"
-"            <key column=\"CUSTOMER_ID\"/>\n"
-"            <one-to-many class=\"Order\"/>\n"
-"        </bag>\n"
-"\n"
-"    </class>\n"
-"    \n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: persistent_classes.xml:269
-#, 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 ""
 "Notez que même si des associations sont déclarées en utilisant des noms de "
 "classe cible, le type de cible d'une association peut aussi être une entité "
-"dynamique au lieu d'un POJO."
+"dynamique au lieu d'un POJO. "
 
 #. Tag: para
-#: persistent_classes.xml:276
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "After setting the default entity mode to <literal>dynamic-map</literal> for "
 "the <literal>SessionFactory</literal>, you can, at runtime, work with "
@@ -667,40 +465,12 @@
 msgstr ""
 "Après avoir configuré le mode d'entité par défaut à <literal>dynamic-map</"
 "literal> pour la <literal>SessionFactory</literal>, nous pouvons lors de "
-"l'exécution fonctionner avec des <literal>Map</literal>s de <literal>Map</"
-"literal>s :"
+"l'exécution fonctionner avec des <literal>Map</literal> s de <literal>Map</"
+"literal> s : "
 
-#. Tag: programlisting
-#: persistent_classes.xml:282
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session s = openSession();\n"
-"Transaction tx = s.beginTransaction();\n"
-"Session s = openSession();\n"
-"\n"
-"// Create a customer\n"
-"Map david = new HashMap();\n"
-"david.put(\"name\", \"David\");\n"
-"\n"
-"// Create an organization\n"
-"Map foobar = new HashMap();\n"
-"foobar.put(\"name\", \"Foobar Inc.\");\n"
-"\n"
-"// Link both\n"
-"david.put(\"organization\", foobar);\n"
-"\n"
-"// Save both\n"
-"s.save(\"Customer\", david);\n"
-"s.save(\"Organization\", foobar);\n"
-"\n"
-"tx.commit();\n"
-"s.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: persistent_classes.xml:284
-#, 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 "
@@ -708,46 +478,26 @@
 "easily be normalized and sound, allowing to add a proper domain model "
 "implementation on top later on."
 msgstr ""
-"Les avantages d'un mapping dynamique sont un gain de temps pour le "
+"Les avantages d'un mappage dynamique sont un gain de temps pour le "
 "prototypage sans la nécessité d'implémenter les classes d'entité. Pourtant, "
 "vous perdez la vérification du typage au moment de la compilation et aurez "
-"plus d'exceptions à gérer lors de l'exécution. Grâce au mapping d'Hibernate, "
-"le schéma de la base de données peut facilement être normalisé et solidifié, "
-"permettant de rajouter une implémentation propre du modèle de domaine plus "
-"tard."
+"plus d'exceptions à gérer lors de l'exécution. Grâce au mappage de "
+"Hibernate, le schéma de la base de données peut facilement être normalisé et "
+"solidifié, permettant de rajouter une implémentation propre du modèle de "
+"domaine plus tard. "
 
 #. Tag: para
-#: persistent_classes.xml:292
 #, no-c-format
 msgid ""
 "Entity representation modes can also be set on a per <literal>Session</"
 "literal> basis:"
 msgstr ""
-"Les modes de représentation d'une entité peut aussi être configuré par "
-"<literal>Session</literal> :"
+"Les modes de représentation d'une entité peuvent aussi être configurés en se "
+"basant sur <literal>Session</literal> :"
 
-#. Tag: programlisting
-#: persistent_classes.xml:297
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session dynamicSession = pojoSession.getSession(EntityMode.MAP);\n"
-"\n"
-"// Create a customer\n"
-"Map david = new HashMap();\n"
-"david.put(\"name\", \"David\");\n"
-"dynamicSession.save(\"Customer\", david);\n"
-"...\n"
-"dynamicSession.flush();\n"
-"dynamicSession.close()\n"
-"...\n"
-"// Continue on pojoSession\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: persistent_classes.xml:300
-#, fuzzy, no-c-format
-msgid ""
 "Please note that the call to <literal>getSession()</literal> using an "
 "<literal>EntityMode</literal> is on the <literal>Session</literal> API, not "
 "the <literal>SessionFactory</literal>. That way, the new <literal>Session</"
@@ -759,32 +509,29 @@
 msgstr ""
 "Veuillez noter que l'appel à <literal>getSession()</literal> en utilisant un "
 "<literal>EntityMode</literal> se fait sur l'API <literal>Session</literal>, "
-"pas <literal>SessionFactory</literal>. De cette manière, la nouvelle "
+"et non sur <literal>SessionFactory</literal>. De cette manière, la nouvelle "
 "<literal>Session</literal> partage les connexions JDBC, transactions et "
 "autres informations de contexte sous-jacentes. Cela signifie que vous n'avez "
 "pas à appeler <literal>flush()</literal> et <literal>close()</literal> sur "
 "la <literal>Session</literal> secondaire, et laissez aussi la gestion de la "
-"transaction et de la connexion à l'unité de travail primaire."
+"transaction et de la connexion à l'unité de travail primaire. "
 
 #. Tag: para
-#: persistent_classes.xml:310
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "More information about the XML representation capabilities can be found in "
-"<xref linkend=\"xml\"/>."
+"<xref linkend=\"xml\" />."
 msgstr ""
-"Plus d'informations à propos de la représentation XML peuvent être trouvées "
-"dans <xref linkend=\"xml\"/>."
+"Pour plus d'informations à propos de la représentation XML, veuillez "
+"consulter <xref linkend=\"xml\" />."
 
 #. Tag: title
-#: persistent_classes.xml:318
 #, no-c-format
 msgid "Tuplizers"
 msgstr "Tuplizers"
 
 #. Tag: para
-#: persistent_classes.xml:320
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.tuple.Tuplizer</literal>, and its sub-interfaces, are "
 "responsible for managing a particular representation of a piece of data "
@@ -798,23 +545,16 @@
 msgstr ""
 "<literal>org.hibernate.tuple.Tuplizer</literal>, et ses sous-interfaces, "
 "sont responsables de la gestion d'une représentation particulière d'un "
-"morceau de données, en fonction du <literal>org.hibernate.EntityMode</"
-"literal> de réprésentation. Si un morceau donné de données est pensé comme "
-"une structure de données, alors un tuplizer est la chose qui sait comment "
-"créer une telle structure de données, comment extraire des valeurs et "
-"injecter des valeurs dans une telle structure de données. Par exemple, pour "
-"le mode d'entité POJO, le tuplizer correspondant sait comment créer le POJO "
-"à travers son constructeur et comment accéder aux propriétés du POJO "
-"utilisant les accesseurs de la propriété définie. Il y a deux types de "
-"Tuplizers haut niveau, représenté par les interfaces <literal>org.hibernate."
-"tuple.EntityTuplizer</literal> et <literal>org.hibernate.tuple."
-"ComponentTuplizer</literal>. Les <literal>EntityTuplizer</literal>s sont "
-"responsables de la gestion des contrats mentionnés ci-dessus pour les "
-"entités, alors que les <literal>ComponentTuplizer</literal>s s'occupent des "
-"composants."
+"fragment de données, en fonction du <literal>org.hibernate.EntityMode</"
+"literal> de représentation. Si un fragment donné de données est considéré "
+"comme une structure de données, alors un tuplizer sait comment créer une "
+"telle structure de données, comment extraire des valeurs et injecter des "
+"valeurs dans une telle structure de données. Par exemple, pour le mode "
+"d'entité POJO, le tuplizer correspondant sait comment créer le POJO à "
+"travers son constructeur et comment accéder aux propriétés du POJO utilisant "
+"les accesseurs de la propriété définie. "
 
 #. Tag: para
-#: persistent_classes.xml:330
 #, no-c-format
 msgid ""
 "There are two high-level types of Tuplizers, represented by the <literal>org."
@@ -824,10 +564,15 @@
 "mentioned contracts in regards to entities, while "
 "<literal>ComponentTuplizer</literal>s do the same for components."
 msgstr ""
+"Il y a deux types de Tuplizers de haut niveau, représentés par les "
+"interfaces <literal>org.hibernate.tuple.EntityTuplizer</literal> et "
+"<literal>org.hibernate.tuple.ComponentTuplizer</literal>. Les "
+"<literal>EntityTuplizer</literal> s sont responsables de la gestion des "
+"contrats mentionnés ci-dessus pour les entités, alors que les "
+"<literal>ComponentTuplizer</literal> s s'occupent des composants."
 
 #. Tag: para
-#: persistent_classes.xml:338
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Users can also plug in their own tuplizers. Perhaps you require that a "
 "<literal>java.util.Map</literal> implementation other than <literal>java."
@@ -838,65 +583,22 @@
 "mapping they are meant to manage. Going back to the example of our customer "
 "entity:"
 msgstr ""
-"Les utilisateurs peuvent aussi brancher leurs propres tuplizers. Peut-être "
-"vous est-il nécessaire qu'une implémentation de <literal>java.util.Map</"
-"literal> autre que <literal>java.util.HashMap</literal> soit utilisée dans "
-"le mode d'entité dynamic-map ; ou peut-être avez-vous besoin de définir une "
-"statégie de génération de proxy différente de celle utilisée par défaut. Les "
-"deux devraient être effectuées en définissant une implémentation de tuplizer "
-"utilisateur. Les définitions de tuplizers sont attachées au mapping de "
-"l'entité ou du composant qu'ils sont censés gérer. Retour à l'exemple de "
-"notre entité utilisateur :"
+"Les utilisateurs peuvent aussi brancher leurs propres tuplizers. Il vous "
+"faudra peut-être utiliser une implémentation de <literal>java.util.Map</"
+"literal> autre que <literal>java.util.HashMap</literal> dans le mode "
+"d'entité dynamic-map ; ou peut-être aurez vous besoin de définir une "
+"stratégie de génération de proxy différente de celle utilisée par défaut. "
+"Les deux devraient être effectuées en définissant une implémentation de "
+"tuplizer utilisateur. Les définitions de tuplizers sont attachées au mappage "
+"de l'entité ou du composant qu'ils devraient gérer. Revenons à l'exemple de "
+"notre entité utilisateur : "
 
-#. Tag: programlisting
-#: persistent_classes.xml:347
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    <class entity-name=\"Customer\">\n"
-"        <!--\n"
-"            Override the dynamic-map entity-mode\n"
-"            tuplizer for the customer entity\n"
-"        -->\n"
-"        <tuplizer entity-mode=\"dynamic-map\"\n"
-"                class=\"CustomMapTuplizerImpl\"/>\n"
-"\n"
-"        <id name=\"id\" type=\"long\" column=\"ID\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"\n"
-"        <!-- other properties -->\n"
-"        ...\n"
-"    </class>\n"
-"</hibernate-mapping>\n"
-"\n"
-"\n"
-"public class CustomMapTuplizerImpl\n"
-"        extends org.hibernate.tuple.entity.DynamicMapEntityTuplizer {\n"
-"    // override the buildInstantiator() method to plug in our custom map...\n"
-"    protected final Instantiator buildInstantiator(\n"
-"            org.hibernate.mapping.PersistentClass mappingInfo) {\n"
-"        return new CustomMapInstantiator( mappingInfo );\n"
-"    }\n"
-"\n"
-"    private static final class CustomMapInstantiator\n"
-"            extends org.hibernate.tuple.DynamicMapInstantitor {\n"
-"        // override the generateMap() method to return our custom map...\n"
-"            protected final Map generateMap() {\n"
-"                    return new CustomMap();\n"
-"            }\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: persistent_classes.xml:354
 #, no-c-format
 msgid "EntityNameResolvers"
-msgstr ""
+msgstr "EntityNameResolvers"
 
 #. Tag: para
-#: persistent_classes.xml:356
 #, no-c-format
 msgid ""
 "The <interfacename>org.hibernate.EntityNameResolver</interfacename> "
@@ -913,158 +615,41 @@
 "dynamicentity.tuplizer2</package>. Here is some of the code from that "
 "package for illustration."
 msgstr ""
+"L'interface <interfacename>org.hibernate.EntityNameResolver</interfacename> "
+"représente un contrat pour résoudre le nom de l'entité d'une instance "
+"d'entité donnée. L'interface définit une méthode simple "
+"<methodname>resolveEntityName</methodname>, à qui l'on passe l'instance "
+"d'entité et qui doit retourner le nom d'entité qui convient (null est "
+"accepté et indiquerait que le resolver ne sait pas comment résoudre le nom "
+"de l'entité de l'instance d'entité donnée). Normalement, un "
+"<interfacename>org.hibernate.EntityNameResolver</interfacename> est surtout "
+"utile pour les modèles dynamiques. Vous pourriez, par exemple, utiliser des "
+"interfaces proxy comme modèle de domaine. La suite de test Hibernate "
+"comprend un exemple de ce style précis d'utilisation dans <package>org."
+"hibernate.test.dynamicentity.tuplizer2</package>. Vous trouverez ci dessous "
+"une illustration du code de ce package."
 
-#. Tag: programlisting
-#: persistent_classes.xml:368
-#, no-c-format
-msgid ""
-"/**\n"
-" * A very trivial JDK Proxy InvocationHandler implementation where we proxy "
-"an interface as\n"
-" * the domain model and simply store persistent state in an internal Map.  "
-"This is an extremely\n"
-" * trivial example meant only for illustration.\n"
-" */\n"
-"public final class DataProxyHandler implements InvocationHandler {\n"
-"        private String entityName;\n"
-"        private HashMap data = new HashMap();\n"
-"\n"
-"        public DataProxyHandler(String entityName, Serializable id) {\n"
-"                this.entityName = entityName;\n"
-"                data.put( \"Id\", id );\n"
-"        }\n"
-"\n"
-"        public Object invoke(Object proxy, Method method, Object[] args) "
-"throws Throwable {\n"
-"                String methodName = method.getName();\n"
-"                if ( methodName.startsWith( \"set\" ) ) {\n"
-"                        String propertyName = methodName.substring( 3 );\n"
-"                        data.put( propertyName, args[0] );\n"
-"                }\n"
-"                else if ( methodName.startsWith( \"get\" ) ) {\n"
-"                        String propertyName = methodName.substring( 3 );\n"
-"                        return data.get( propertyName );\n"
-"                }\n"
-"                else if ( \"toString\".equals( methodName ) ) {\n"
-"                        return entityName + \"#\" + data.get( \"Id\" );\n"
-"                }\n"
-"                else if ( \"hashCode\".equals( methodName ) ) {\n"
-"                        return new Integer( this.hashCode() );\n"
-"                }\n"
-"                return null;\n"
-"        }\n"
-"\n"
-"        public String getEntityName() {\n"
-"                return entityName;\n"
-"        }\n"
-"\n"
-"        public HashMap getData() {\n"
-"                return data;\n"
-"        }\n"
-"}\n"
-"\n"
-"/**\n"
-" *\n"
-" */\n"
-"public class ProxyHelper {\n"
-"    public static String extractEntityName(Object object) {\n"
-"        // Our custom java.lang.reflect.Proxy instances actually bundle\n"
-"        // their appropriate entity name, so we simply extract it from "
-"there\n"
-"        // if this represents one of our proxies; otherwise, we return null\n"
-"        if ( Proxy.isProxyClass( object.getClass() ) ) {\n"
-"            InvocationHandler handler = Proxy.getInvocationHandler"
-"( object );\n"
-"            if ( DataProxyHandler.class.isAssignableFrom( handler.getClass"
-"() ) ) {\n"
-"                DataProxyHandler myHandler = ( DataProxyHandler ) handler;\n"
-"                return myHandler.getEntityName();\n"
-"            }\n"
-"        }\n"
-"        return null;\n"
-"    }\n"
-"\n"
-"    // various other utility methods ....\n"
-"\n"
-"}\n"
-"\n"
-"/**\n"
-" * The EntityNameResolver implementation.\n"
-" * IMPL NOTE : An EntityNameResolver really defines a strategy for how "
-"entity names should be\n"
-" * resolved.  Since this particular impl can handle resolution for all of "
-"our entities we want to\n"
-" * take advantage of the fact that SessionFactoryImpl keeps these in a Set "
-"so that we only ever\n"
-" * have one instance registered.  Why?  Well, when it comes time to resolve "
-"an entity name,\n"
-" * Hibernate must iterate over all the registered resolvers.  So keeping "
-"that number down\n"
-" * helps that process be as speedy as possible.  Hence the equals and "
-"hashCode impls\n"
-" */\n"
-"public class MyEntityNameResolver implements EntityNameResolver {\n"
-"    public static final MyEntityNameResolver INSTANCE = new "
-"MyEntityNameResolver();\n"
-"\n"
-"    public String resolveEntityName(Object entity) {\n"
-"        return ProxyHelper.extractEntityName( entity );\n"
-"    }\n"
-"\n"
-"    public boolean equals(Object obj) {\n"
-"        return getClass().equals( obj.getClass() );\n"
-"    }\n"
-"\n"
-"    public int hashCode() {\n"
-"        return getClass().hashCode();\n"
-"    }\n"
-"}\n"
-"\n"
-"public class MyEntityTuplizer extends PojoEntityTuplizer {\n"
-"        public MyEntityTuplizer(EntityMetamodel entityMetamodel, "
-"PersistentClass mappedEntity) {\n"
-"                super( entityMetamodel, mappedEntity );\n"
-"        }\n"
-"\n"
-"        public EntityNameResolver[] getEntityNameResolvers() {\n"
-"                return new EntityNameResolver[] { MyEntityNameResolver."
-"INSTANCE };\n"
-"        }\n"
-"\n"
-"    public String determineConcreteSubclassEntityName(Object entityInstance, "
-"SessionFactoryImplementor factory) {\n"
-"        String entityName = ProxyHelper.extractEntityName"
-"( entityInstance );\n"
-"        if ( entityName == null ) {\n"
-"            entityName = super.determineConcreteSubclassEntityName"
-"( entityInstance, factory );\n"
-"        }\n"
-"        return entityName;\n"
-"    }\n"
-"\n"
-"    ...\n"
-"}"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:370
 #, no-c-format
 msgid ""
 "In order to register an <interfacename>org.hibernate.EntityNameResolver</"
 "interfacename> users must either:"
 msgstr ""
+"Pour enregistrer un <interfacename>org.hibernate.EntityNameResolver</"
+"interfacename>, les utilisateurs doivent soit :"
 
 #. Tag: para
-#: persistent_classes.xml:374
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Implement a custom <link linkend=\"persistent-classes-tuplizers\">Tuplizer</"
 "link>, implementing the <methodname>getEntityNameResolvers</methodname> "
 "method."
 msgstr ""
+"Implémenter un <xref linkend=\"persistent-classes-tuplizers\" /> "
+"personnalisé, en implémentant la méthode <methodname>getEntityNameResolvers</"
+"methodname>."
 
 #. Tag: para
-#: persistent_classes.xml:380
 #, no-c-format
 msgid ""
 "Register it with the <classname>org.hibernate.impl.SessionFactoryImpl</"
@@ -1072,11 +657,7 @@
 "hibernate.SessionFactory</interfacename>) using the "
 "<methodname>registerEntityNameResolver</methodname> method."
 msgstr ""
-
-#~ msgid "There are four main rules to follow here:"
-#~ msgstr "Il y a quatre règles à suivre ici :"
-
-#~ msgid ""
-#~ "TODO: Document user-extension framework in the property and proxy packages"
-#~ msgstr ""
-#~ "TODO: Document user-extension framework in the property and proxy packages"
+"L'enregistrer dans <classname>org.hibernate.impl.SessionFactoryImpl</"
+"classname> (qui est la classe d'implémentation de <interfacename>org."
+"hibernate.SessionFactory</interfacename>) à l'aide de la méthode "
+"<methodname>registerEntityNameResolver</methodname>."

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/portability.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/portability.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/portability.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,32 +1,32 @@
-# Language fr-FR translations for PACKAGE package.
-# Automatically generated, 2009.
-#
+# translation of portability.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: portability\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: 2009-07-14 19:56+0000\n"
-"Last-Translator: Automatically generated\n"
-"Language-Team: none\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-05 09:42+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: portability.xml:26
 #, no-c-format
 msgid "Database Portability Considerations"
-msgstr ""
+msgstr "Considérations de portabilité des bases de données"
 
 #. Tag: title
-#: portability.xml:29
 #, no-c-format
 msgid "Portability Basics"
-msgstr ""
+msgstr "Aspects fondamentaux de la portabilité"
 
 #. Tag: para
-#: portability.xml:31
 #, no-c-format
 msgid ""
 "One of the selling points of Hibernate (and really Object/Relational Mapping "
@@ -38,15 +38,23 @@
 "run against any number of databases without changes to your code, and "
 "ideally without any changes to the mapping metadata."
 msgstr ""
+"La portabilité des bases de données est un des atouts qui sont mis en avant "
+"pour vendre Hibernate (et plus largement le mappage objet/relationnel dans "
+"son ensemble). Il pourrait s'agir d'un utilisateur IT interne qui migre "
+"d'une base de données de fournisseur vers une autre, ou il pourrait s'agir "
+"d'un framework ou d'une application déployable consommant Hibernate pour "
+"cibler simultanément plusieurs produits de base de données par leurs "
+"utilisateurs. Quel que soit le scénario exact, l'idée de base est que vous "
+"souhaitez que HIBERNATE vous permettre d'exécuter avec un certain nombre de "
+"bases de données sans modifications à votre code et idéalement sans "
+"modifications des métadonnées de mappage."
 
 #. Tag: title
-#: portability.xml:42
 #, no-c-format
 msgid "Dialect"
-msgstr ""
+msgstr "Dialecte"
 
 #. Tag: para
-#: portability.xml:44
 #, no-c-format
 msgid ""
 "The first line of portability for Hibernate is the dialect, which is a "
@@ -58,15 +66,22 @@
 "your particular database is not among them, it is not terribly difficult to "
 "write your own."
 msgstr ""
+"La première ligne de la portabilité d'Hibernate est le dialecte, qui est une "
+"spécialisation du contrat <classname>org.Hibernate.dialect.dialect</"
+"classname>. Un dialecte encapsule toutes les différences selon lesquelles "
+"Hibernate doit communiquer avec une base de données particulière pour "
+"accomplir certaines tâches comme l'obtention d'une valeur de la séquence ou "
+"de structuration d'une requête SELECT. Hibernate regroupe un large éventail "
+"de dialectes pour la plupart des bases de données les plus communes. Si vous "
+"trouvez que votre base de données particulière n'en fait pas partie, il "
+"n'est pas difficile d'écrire votre propre dialecte."
 
 #. Tag: title
-#: portability.xml:55
 #, no-c-format
 msgid "Dialect resolution"
-msgstr ""
+msgstr "Résolution de dialecte"
 
 #. Tag: para
-#: portability.xml:57
 #, no-c-format
 msgid ""
 "Originally, Hibernate would always require that users specify which dialect "
@@ -75,9 +90,14 @@
 "their users to configure the Hibernate dialect or defining their own method "
 "of setting that value."
 msgstr ""
+"À l'origine, Hibernate exigeait toujours que les utilisateurs spécifient "
+"quel dialecte utiliser. Dans le cas des utilisateurs qui cherchent à cibler "
+"simultanément plusieurs bases de données avec leur version, c'était "
+"problématique. Généralement cela amenait leurs utilisateurs à configurer le "
+"dialecte Hibernate ou à définir leur propre méthode de définition de cette "
+"valeur."
 
 #. Tag: para
-#: portability.xml:64
 #, no-c-format
 msgid ""
 "Starting with version 3.2, Hibernate introduced the notion of automatically "
@@ -87,17 +107,22 @@
 "that this resolution was limited to databases Hibernate know about ahead of "
 "time and was in no way configurable or overrideable."
 msgstr ""
+"A partir de la version 3.2, Hibernate a introduit la détection "
+"automatiquement du dialecte à utiliser basé sur les <interfacename>Java.SQL."
+"DatabaseMetaData</interfacename> obtenues à partir d'un <interfacename>Java."
+"SQL.Connexion</interfacename> vers cette base de données. C'était beaucoup "
+"mieux, sauf que cette résolution a été limitée aux bases de données déjà "
+"connues d'Hibernate et elle n'était ni configurable, ni remplaçable."
 
 #. Tag: para
-#: portability.xml:72
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Starting with version 3.3, Hibernate has a fare more powerful way to "
 "automatically determine which dialect to should be used by relying on a "
 "series of delegates which implement the <interfacename>org.hibernate.dialect."
 "resolver.DialectResolver</interfacename> which defines only a single method:"
-"<programlisting><![CDATA[public Dialect resolveDialect(DatabaseMetaData "
-"metaData) throws JDBCConnectionException]]></programlisting>. The basic "
+"<programlisting role=\"JAVA\">public Dialect resolveDialect(DatabaseMetaData "
+"metaData) throws JDBCConnectionException</programlisting>. The basic "
 "contract here is that if the resolver 'understands' the given database "
 "metadata then it returns the corresponding Dialect; if not it returns null "
 "and the process continues to the next resolver. The signature also "
@@ -108,9 +133,23 @@
 "All other exceptions result in a warning and continuing on to the next "
 "resolver."
 msgstr ""
+"A partir de la version 3.3, Hibernate a un moyen bien plus puissant de "
+"déterminer automatiquement quel dialecte devrait être utilisé en s'appuyant "
+"sur une série de délégués qui implémentent le <interfacename>org.hibernate."
+"dialect.resolver.DialectResolver</interfacename>. Le résolveur ne définit "
+"qu'une seule méthode :<programlisting>public Dialect resolveDialect"
+"(DatabaseMetaData metaData) throws JDBCConnectionException</programlisting>. "
+"Le contrat de base ici est que si le résolveur 'comprend' les métadonnées de "
+"base de données, alors il renvoie le dialecte correspondant ; si non, il "
+"renvoie la valeur null et le processus se poursuit avec le prochain "
+"résolveur. La signature identifie également l'envoi éventuel de l'exception "
+"<exceptionname>org.hibernate.exception.JDBCConnectionException</"
+"exceptionname>. Une JDBCConnectionException ici implique un problème de "
+"connexion \"non transient\" (aka non récupérable) et est utilisé pour "
+"indiquer un arrêt immédiat à des tentatives de résolution. Toutes les autres "
+"exceptions entraînent un avertissement et de passer à la résolution suivante."
 
 #. Tag: para
-#: portability.xml:85
 #, no-c-format
 msgid ""
 "The cool part about these resolvers is that users can also register their "
@@ -124,16 +163,26 @@
 "<constant>DIALECT_RESOLVERS</constant> constant on <classname>org.hibernate."
 "cfg.Environment</classname>)."
 msgstr ""
+"Le bon côté de ces outils de résolution, c'est que les utilisateurs peuvent "
+"également enregistrer leurs propres outils de résolution personnalisés, qui "
+"seront traités avant les résolveurs Hibernate intégrés. Cette option peut "
+"être utile dans un certain nombre de situations différentes : elle permet "
+"une intégration aisée pour la détection automatique des dialectes au-delà de "
+"ceux qui sont livrés avec Hibernate lui-même ; elle vous permet de spécifier "
+"d'utiliser un dialecte personnalisé lorsqu'une base de données particulière "
+"est reconnue ; etc.. Pour enregistrer un ou plusieurs outils de résolution, "
+"il vous suffit de les spécifier (séparés par des virgules, des onglets ou "
+"des espaces) à l'aide du paramètre de configuration 'hibernate."
+"dialect_resolvers' (voir la constante <constant>DIALECT_RESOLVERS</constant> "
+"sur <classname>cfg.Environment org.Hibernate.</classname>)."
 
 #. Tag: title
-#: portability.xml:98
 #, no-c-format
 msgid "Identifier generation"
-msgstr ""
+msgstr "Générer les identifiants"
 
 #. Tag: para
-#: portability.xml:100
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "When considering portability between databases, another important decision "
 "is selecting the identifier generation stratagy you want to use. Originally "
@@ -151,38 +200,96 @@
 "reference entities within a persistence context it must then issue the "
 "insert immediately when the users requests the entitiy be associated with "
 "the session (like via save() e.g.) regardless of current transactional "
-"semantics. <note> <para> Hibernate was changed slightly once the implication "
-"of this was better understood so that the insert is delayed in cases where "
-"that is feasible. </para> </note> The underlying issue is that the actual "
-"semanctics of the application itself changes in these cases."
+"semantics."
 msgstr ""
+"Quand on considère la portabilité entre les bases de données, la sélection "
+"de stratégie de génération d'identifiant à utiliser est une autre décision "
+"importante. Initialement, Hibernate fournissait le générateur "
+"<emphasis>natif</emphasis> à cette fin, dans le but de choisir entre une "
+"stratégie <emphasis>séquence</emphasis>, <emphasis>identité</emphasis>, ou "
+"<emphasis>table</emphasis> suivant la capacité de la base de données sous-"
+"jacente. Toutefois, une implication insidieuse de cette approche surgit au "
+"moment de cibler certaines bases de données entre celles qui prennent en "
+"charge la génération d' <emphasis>identité</emphasis> et celles qui ne la "
+"prenne pas. La génération d'<emphasis>identité</emphasis> s'appuie sur la "
+"définition SQL d'une colonne IDENTITY (ou auto-incrémentation) pour gérer la "
+"valeur d'identificateur ; c'est ce qui est connu sous le nom de stratégie de "
+"génération car l'insersion doit effectivement avoir lieu avant que nous "
+"puissions connaître la valeur de l'identifiant. Étant donné qu'Hibernate "
+"repose sur la valeur de cet identifiant pour indentifier les entités de "
+"façon unique dans un contexte de persistance, il doit alors émettre "
+"l'insertion immédiatement, quand les utilisateurs demandent que l'entité "
+"soit associée à la session (comme par exemple, via save()) indépendamment de "
+"la sémantique transactionnelle actuelle. La question sous-jacente est que la "
+"sémantique de l'application elle-même change dans ces cas."
 
 #. Tag: para
-#: portability.xml:125
+#, fuzzy, no-c-format
+msgid ""
+"Hibernate was changed slightly once the implication of this was better "
+"understood so that the insert is delayed in cases where that is feasible."
+msgstr ""
+"Hibernate a été amélioré de façon à ce que l'insertion puisse être retardée "
+"quand c'est possible."
+
+#. Tag: note
 #, no-c-format
 msgid ""
+"The underlying issue is that the actual semanctics of the application itself "
+"changes in these cases."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
 "Starting with version 3.2.3, Hibernate comes with a set of <ulink url="
 "\"http://in.relation.to/2082.lace\">enhanced</ulink> identifier generators "
-"targetting portability in a much different way. <note> <para> There are "
-"specifically 2 bundled <emphasis>enhanced</emphasis>generators: "
-"<itemizedlist> <listitem> <para> <classname>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</classname> </para> </listitem> <listitem> <para> "
-"<classname>org.hibernate.id.enhanced.TableGenerator</classname> </para> </"
-"listitem> </itemizedlist> </para> </note> The idea behind these generators "
-"is to port the actual semantics of the identifer value generation to the "
-"different databases. For example, the <classname>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</classname> mimics the behavior of a sequence on "
-"databases which do not support sequences by using a table."
+"targetting portability in a much different way."
 msgstr ""
+"A partir de la version 3.2.3, Hibernate est fourni avec un ensemble de "
+"générateurs d'identifiants <ulink url=\"http://in.relation.to/2082.lace"
+"\">améliorés</ulink>qui ciblent la portabilité d'une façon très différente."
 
+#. Tag: para
+#, no-c-format
+msgid ""
+"There are specifically 2 bundled <emphasis>enhanced</emphasis>generators:"
+msgstr ""
+"Il existe 2 générateurs <emphasis>améliorés</emphasis> spécifiques qui sont "
+"livrés."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname>"
+msgstr ""
+"<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname>"
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<classname>org.hibernate.id.enhanced.TableGenerator</classname>"
+msgstr "<classname>org.hibernate.id.enhanced.TableGenerator</classname>"
+
+#. Tag: note
+#, no-c-format
+msgid ""
+"The idea behind these generators is to port the actual semantics of the "
+"identifer value generation to the different databases. For example, the "
+"<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname> "
+"mimics the behavior of a sequence on databases which do not support "
+"sequences by using a table."
+msgstr ""
+"L'idée qui se cache là derrière, c'est de porter la sémantique de la "
+"génération de la valeur d'identifiant vers les bases de données diverses. "
+"Ainsi, <classname>org.hibernate.id.enhanced.SequenceStyleGenerator</"
+"classname> imite le comportement d'une séquence de databases, ne supportant "
+"pas les séquences par une table."
+
 #. Tag: title
-#: portability.xml:154
 #, no-c-format
 msgid "Database functions"
-msgstr ""
+msgstr "Fonctions de base de données"
 
 #. Tag: para
-#: portability.xml:157
 #, no-c-format
 msgid ""
 "This is an area in Hibernate in need of improvement. In terms of portability "
@@ -191,7 +298,6 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:164
 #, no-c-format
 msgid ""
 "SQL functions can be referenced in many ways by users. However, not all "
@@ -200,9 +306,14 @@
 "knows how to render that particular function, perhaps even using a totally "
 "different physical function call."
 msgstr ""
+"Les fonctions SQL peuvent être référencées de bien des façons par les "
+"utilisateurs. Cependant, toutes les bases de données ne supportent pas le "
+"même groupe de fonctions. Hibernate procure une façon de faire correspondre "
+"un nom de fonction <emphasis>logique</emphasis> à un délégué qui sait "
+"comment traduire cette fonction particulière, peut-être en utilisant un "
+"appel de fonction physique totalement différente."
 
 #. Tag: para
-#: portability.xml:170
 #, no-c-format
 msgid ""
 "Technically this function registration is handled through the <classname>org."
@@ -211,24 +322,37 @@
 "having to provide a custom dialect. This specific behavior is not fully "
 "completed as of yet."
 msgstr ""
+"Techniquement, cet enregistrement de la fonction est géré par le biais de la "
+"classe <classname>hibernate.dialect.function.SQLFunctionRegistry org.</"
+"classname> qui est destinée à permettre aux utilisateurs de fournir des "
+"définitions de fonction personnalisée sans avoir à fournir un dialecte "
+"personnalisé. Ce comportement spécifique n'est pas encore entièrement "
+"terminé."
 
 #. Tag: para
-#: portability.xml:177
 #, no-c-format
 msgid ""
 "It is sort of implemented such that users can programatically register "
 "functions with the <classname>org.hibernate.cfg.Configuration</classname> "
 "and those functions will be recognized for HQL."
 msgstr ""
+"Il est mis en oeuvre de telle sorte que les utilisateurs peuvent enregistrer "
+"des fonctions par programmation avec <classname>org.Hibernate.cfg."
+"Configuration</classname> et ces fonctions seront reconnues pour HQL."
 
 #. Tag: title
-#: portability.xml:187
 #, no-c-format
 msgid "Type mappings"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:189
 #, no-c-format
 msgid "This section scheduled for completion at a later date..."
 msgstr ""
+
+#~ msgid ""
+#~ "This is a new area in Hibernate and as such it is not as mature as the "
+#~ "overall Hibernate experience."
+#~ msgstr ""
+#~ "Il s'agit d'une nouveau domaine pour Hibernate, et de ce fait, n'a pas "
+#~ "encore atteint une maturité."

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/preface.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/preface.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/preface.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,23 +1,27 @@
+# translation of Preface.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Preface\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-05 09:43+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: preface.xml:29
 #, no-c-format
 msgid "Preface"
 msgstr "Préface"
 
 #. Tag: para
-#: preface.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "Working with object-oriented software and a relational database can be "
@@ -27,32 +31,30 @@
 "representation from an object model to a relational data model with a SQL-"
 "based schema."
 msgstr ""
-"Travailler dans les deux univers que sont l'orienté objet et la base de "
-"données relationnelle peut être lourd et consommateur en temps dans le monde "
-"de l'entreprise d'aujourd'hui. Hibernate est un outil de mapping objet/"
-"relationnel pour le monde Java. Le terme mapping objet/relationnel (ORM) "
-"décrit la technique consistant à faire le lien entre la représentation objet "
-"des données et sa représentation relationnelle basée sur un schéma SQL."
+"Travailler avec des logiciels orientés-objet et une base de données "
+"relationnelle peut sembler parfois lourd et coûteux en temps dans les "
+"environnements entreprise de nos jours. Hibernate est un outil de mappage "
+"objet/relationnel pour les environnements Java. Le terme de mappage objet/"
+"relationnel (ORM de l'anglais Objet Relational Mapping) fait référence à la "
+"technique de mappage d'une représentation de données à partir d'un modèle "
+"d'objet vers un modèle de données relationnelles dans un schéma basé-SQL."
 
 #. Tag: para
-#: preface.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate not only takes care of the mapping from Java classes to database "
 "tables (and from Java data types to SQL data types), but also provides data "
 "query and retrieval facilities. It can also significantly reduce development "
 "time otherwise spent with manual data handling in SQL and JDBC."
 msgstr ""
-"Non seulement, Hibernate s'occupe du transfert des classes Java dans les "
-"tables de la base de données (et des types de données Java dans les types de "
-"données SQL), mais il permet de requêter les données et propose des moyens "
-"de les récupérer. Il peut donc réduire de manière significative le temps de "
-"développement qui aurait été autrement perdu dans une manipulation manuelle "
-"des données via SQL et JDBC."
+"Hibernate s'occupe du mappage des classes Java vers les tables de bases de "
+"données (et des types de données Java vers les types de données SQL), mais "
+"fournit également des facilités de recherche et de retrait de données. "
+"Hibernate peut réduire énormément le temps de développement, normalement "
+"passé à traiter des données manuellement dans SQL ou JDBC."
 
 #. Tag: para
-#: preface.xml:46
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's goal is to relieve the developer from 95 percent of common data "
 "persistence related programming tasks. Hibernate may not be the best "
@@ -63,51 +65,48 @@
 "specific SQL code and will help with the common task of result set "
 "translation from a tabular representation to a graph of objects."
 msgstr ""
-"Le but d'Hibernate est de libérer le développeur de 95 pourcent des tâches "
-"de programmation liées à la persistance des données communes. Hibernate "
-"n'est probablement pas la meilleure solution pour les applications centrées "
-"sur les données qui n'utilisent que les procédures stockées pour implémenter "
-"la logique métier dans la base de données, il est le plus utile dans les "
-"modèles métier orientés objets dont la logique métier est implémentée dans "
-"la couche Java dite intermédiaire. Cependant, Hibernate vous aidera à "
-"supprimer ou à encapsuler le code SQL spécifique à votre base de données et "
-"vous aidera sur la tâche commune qu'est la transformation des données d'une "
-"représentation tabulaire à une représentation sous forme de graphe d'objets."
+"Le but d'Hibernate est de libérer le développeur de 95 pour cent des tâches "
+"de programmation liées à la persistance de données communes. Hibernate n'est "
+"peut-être pas la meilleure solution pour les applications centrées-données "
+"qui utilisent uniquement les procédures-stored pour implémenter la logique "
+"métier dans la base de données. Cela est surtout utile avec les modèles de "
+"domaines orientés-objet et la logique métier dans l'étape intermédiaire "
+"basée Java. Malgré tout, Hibernate peut vous aider à supprimer ou à "
+"encapsuler le code SQL propre à un distributeur et vous aidera à régler la "
+"tâche commune qui consiste à transposer un ensemble de résultats à partir "
+"d'un tableau de représentation vers un graphe d'objets. "
 
 #. Tag: para
-#: preface.xml:56
 #, no-c-format
 msgid ""
 "If you are new to Hibernate and Object/Relational Mapping or even Java, "
 "please follow these steps:"
 msgstr ""
-"Si vous êtes nouveau dans Hibernate et le mapping Objet/Relationnel voire "
-"même en Java, suivez ces quelques étapes :"
+"Si vous n'êtes pas familiarisé avec Hibernate et le mappage Objet/"
+"Relationnel ou même Java, veuillez suivre les étapes suivantes :"
 
 #. Tag: para
-#: preface.xml:63
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"Read <xref linkend=\"tutorial\"/> for a tutorial with step-by-step "
+"Read <xref linkend=\"tutorial\" /> for a tutorial with step-by-step "
 "instructions. The source code for the tutorial is included in the "
 "distribution in the <literal>doc/reference/tutorial/</literal> directory."
 msgstr ""
-"Lisez <xref linkend=\"tutorial\"/> pour un didacticiel plus long avec plus "
-"d'instructions étape par étape."
+"Lisez <xref linkend=\"tutorial\" /> pour bénéficier d'un tutoriel avec des "
+"instructions étape par étape. Le code source du tutoriel est inclus dans la "
+"distribution du répertoire <literal>doc/reference/tutorial/</literal>. "
 
 #. Tag: para
-#: preface.xml:71
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"Read <xref linkend=\"architecture\"/> to understand the environments where "
+"Read <xref linkend=\"architecture\" /> to understand the environments where "
 "Hibernate can be used."
 msgstr ""
-"Lisez <xref linkend=\"architecture\"/> pour comprendre les environnements "
-"dans lesquels Hibernate peut être utilisé."
+"Veuillez lire <xref linkend=\"architecture\" /> pour comprendre dans quels "
+"environnements Hibernate peuvent-être utilisés."
 
 #. Tag: para
-#: preface.xml:77
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "View the <literal>eg/</literal> directory in the Hibernate distribution. It "
 "contains a simple standalone application. Copy your JDBC driver to the "
@@ -116,66 +115,57 @@
 "command prompt in the distribution directory, type <literal>ant eg</literal> "
 "(using Ant), or under Windows, type <literal>build eg</literal>."
 msgstr ""
-"Regardez le répertoire <literal>eg</literal> de la distribution Hibernate, "
-"il contient une application simple et autonome. Copiez votre pilote JDBC "
-"dans le répertoire <literal>lib/</literal> et éditez <literal>src/hibernate."
-"properties</literal>, en positionnant correctement les valeurs pour votre "
-"base de données. A partir d'une invite de commande dans le répertoire de la "
-"distribution, tapez <literal>ant eg</literal> (cela utilise Ant), ou sous "
-"Windows tapez <literal>build eg</literal>."
+"Veuillez consulter le répertoire <literal>eg/</literal> dans la distribution "
+"Hibernate, qui contient une application autonome simple. Copier votre pilote "
+"JDBC dans le répertoire <literal>lib/</literal> et éditez <literal>etc/"
+"hibernate.properties</literal>, en spécifiant les valeurs qu'il faut dans "
+"votre base de données. A partir d'une invite de commande du répertoire de "
+"distribution, veuillez saisir <literal>ant eg</literal> (en utilisant Ant), "
+"et sous Windows, tapez <literal>build eg</literal>."
 
 #. Tag: para
-#: preface.xml:88
 #, fuzzy, no-c-format
 msgid ""
 "Use this reference documentation as your primary source of information. "
 "Consider reading <biblioref linkend=\"biblio-JPwH\"></biblioref> if you need "
 "more help with application design, or if you prefer a step-by-step tutorial. "
-"Also visit <ulink url=\"http://caveatemptor.hibernate.org\"></ulink> and "
-"download the example application from <biblioref linkend=\"biblio-JPwH\"></"
-"biblioref>."
+"Also visit <ulink url=\"http://caveatemptor.hibernate.org\" /> and download "
+"the example application from <biblioref linkend=\"biblio-JPwH\"></biblioref>."
 msgstr ""
-"Faîtes de cette documentation de référence votre principale source "
-"d'information. Pensez à lire <emphasis>Java Persistence with Hibernate</"
-"emphasis> (http://www.manning.com/bauer2) si vous avez besoin de plus d'aide "
-"avec le design d'applications ou si vous préférez un tutoriel pas à pas. "
-"Visitez aussi http://caveatemptor.hibernate.org et téléchargez l'application "
-"exemple pour Java Persistence with Hibernate."
+"Utiliser cette documentation de référence en tant que source primaire "
+"d'information. Vous pourrez lire <emphasis>Hibernate in Action</emphasis> "
+"(http://www.manning.com/bauer) si vous avez besoin d'aide supplémentaire au "
+"niveau de la conception des applications ou si vous préférez un tutoriel "
+"étape par étape. Aussi, veuillez consulter http://caveatemptor.hibernate.org "
+"et décharger l'exemple d'application pour Hibernate en action."
 
 #. Tag: para
-#: preface.xml:98
 #, no-c-format
 msgid "FAQs are answered on the Hibernate website."
-msgstr ""
-"Les questions les plus fréquemment posées (FAQs) trouvent leur réponse sur "
-"le site web Hibernate."
+msgstr "Les questions FAQ sont traitées sur le site Hibernate."
 
 #. Tag: para
-#: preface.xml:103
 #, fuzzy, no-c-format
 msgid ""
 "Links to third party demos, examples, and tutorials are maintained on the "
 "Hibernate website."
 msgstr ""
-"Des démos, exemples et tutoriaux de tierces personnes sont référencés sur le "
-"site web Hibernate."
+"Des démos de tierces parties, des exemples et des tutoriels sont accessibles "
+"à partir du site Hibernate."
 
 #. Tag: para
-#: preface.xml:109
 #, no-c-format
 msgid ""
 "The Community Area on the Hibernate website is a good resource for design "
 "patterns and various integration solutions (Tomcat, JBoss AS, Struts, EJB, "
 "etc.)."
 msgstr ""
-"La zone communautaire (Community Area) du site web Hibernate est une bonne "
-"source d'information sur les design patterns et sur différentes solutions "
-"d'intégration d'Hibernate (Tomcat, JBoss, Spring Framework, Struts, EJB, "
-"etc)."
+"La section Community Area (Zône communautaire) du site Hibernate constitue "
+"une ressource intéressante pour les modèles conceptuels et autres solutions "
+"diverses d'intégration (Tomcat, JBoss AS, Struts, EJB, etc.)."
 
 #. Tag: para
-#: preface.xml:117
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you have questions, use the user forum linked on the Hibernate website. "
 "We also provide a JIRA issue tracking system for bug reports and feature "
@@ -183,14 +173,13 @@
 "developer mailing list. If you are interested in translating this "
 "documentation into your language, contact us on the developer mailing list."
 msgstr ""
-"Si vous avez des questions, utilisez le forum utilisateurs du site web "
-"Hibernate. Nous utilisons également l'outil de gestion des incidents JIRA "
-"pour tout ce qui est rapports de bogue et demandes d'évolution. Si vous êtes "
-"intéressé par le développement d'Hibernate, joignez-vous à la liste de "
-"diffusion de développement."
+"Si vous avez des questions, participez au forum utilisateur sur le site "
+"Hibernate. Nous proposons également des systèmes de traçage JIRA pour les "
+"rapports de bogues et les demandes sur les fonctionalités. Si vous êtes "
+"intéressé à participer au développement d'Hibernate, veuillez rejoindre la "
+"liste de distribution électronique des développeurs. "
 
 #. Tag: para
-#: preface.xml:125
 #, no-c-format
 msgid ""
 "Commercial development support, production support, and training for "
@@ -199,8 +188,8 @@
 "critical component of the JBoss Enterprise Middleware System (JEMS) suite of "
 "products."
 msgstr ""
-"Le développement commercial, le support de production et les formations à "
-"Hibernate sont proposés par JBoss Inc (voir http://www.hibernate.org/"
-"SupportTraining/). Hibernate est un projet Open Source professionnel et un "
-"composant critique de la suite de produits JBoss Enterprise Middleware "
-"System (JEMS)."
+"Le support pour le développement commercial, le support production, et la "
+"formation Hibernate sont disponibles à travers JBoss Inc. (voir http://www."
+"hibernate.org/SupportTraining/). Hibernate est un projet professionnel en "
+"source ouverte et un composant critique de la suite de produits JBoss "
+"Enterprise Middleware System (JEMS). "

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/query_criteria.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/query_criteria.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/query_criteria.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,36 +1,38 @@
+# translation of query_criteria.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: query_criteria\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-05 09:43+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: query_criteria.xml:29
 #, no-c-format
 msgid "Criteria Queries"
 msgstr "Requêtes par critères"
 
 #. Tag: para
-#: query_criteria.xml:31
 #, no-c-format
 msgid "Hibernate features an intuitive, extensible criteria query API."
 msgstr ""
 "Hibernate offre une API d'interrogation par critères intuitive et extensible."
 
 #. Tag: title
-#: query_criteria.xml:36
 #, no-c-format
 msgid "Creating a <literal>Criteria</literal> instance"
 msgstr "Créer une instance de <literal>Criteria</literal>"
 
 #. Tag: para
-#: query_criteria.xml:38
 #, no-c-format
 msgid ""
 "The interface <literal>org.hibernate.Criteria</literal> represents a query "
@@ -38,26 +40,15 @@
 "factory for <literal>Criteria</literal> instances."
 msgstr ""
 "L'interface <literal>net.sf.hibernate.Criteria</literal> représente une "
-"requête sur une classe persistente donnée. La <literal>Session</literal> "
+"requête sur une classe persistante donnée. La <literal>Session</literal> "
 "fournit les instances de <literal>Criteria</literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:44
-#, no-c-format
-msgid ""
-"<![CDATA[Criteria crit = sess.createCriteria(Cat.class);\n"
-"crit.setMaxResults(50);\n"
-"List cats = crit.list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:49
 #, no-c-format
 msgid "Narrowing the result set"
 msgstr "Restriction du résultat"
 
 #. Tag: para
-#: query_criteria.xml:51
 #, no-c-format
 msgid ""
 "An individual query criterion is an instance of the interface <literal>org."
@@ -65,216 +56,94 @@
 "criterion.Restrictions</literal> defines factory methods for obtaining "
 "certain built-in <literal>Criterion</literal> types."
 msgstr ""
-"Un criterion (critère de recherche) est une instance de l'interface "
-"<literal>org.hibernate.criterion.Criterion</literal>. La classe <literal>org."
-"hibernate.criterion.Restrictions</literal> définit des méthodes pour obtenir "
-"des types de <literal>Criterion</literal> pré-définis."
+"Un critère de recherche (criterion) individuel est une instance de "
+"l'interface <literal>org.hibernate.criterion.Criterion</literal>. La classe "
+"<literal>org.hibernate.criterion.Restrictions</literal> définit des méthodes "
+"de fabrique pour obtenir des types de <literal>Criterion</literal> intégrés."
 
-#. Tag: programlisting
-#: query_criteria.xml:59
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .add( Restrictions.between(\"weight\", minWeight, maxWeight) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Restrictions can be grouped logically."
-msgstr "Les restrictions peuvent être goupées de manière logique."
+msgstr "Les restrictions peuvent être groupées de manière logique. "
 
-#. Tag: programlisting
-#: query_criteria.xml:65
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .add( Restrictions.or(\n"
-"        Restrictions.eq( \"age\", new Integer(0) ),\n"
-"        Restrictions.isNull(\"age\")\n"
-"    ) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:67
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.in( \"name\", new String[] { \"Fritz\", \"Izi\", \"Pk"
-"\" } ) )\n"
-"    .add( Restrictions.disjunction()\n"
-"        .add( Restrictions.isNull(\"age\") )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(0) ) )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(1) ) )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(2) ) )\n"
-"    ) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:69
-#, fuzzy, no-c-format
-msgid ""
 "There are a range of built-in criterion types (<literal>Restrictions</"
 "literal> subclasses). One of the most useful allows you to specify SQL "
 "directly."
 msgstr ""
-"Il y a plusieurs types de criterion pré-définis (sous classes de "
-"<literal>Restriction</literal>), mais l'une d'entre elle particulièrement "
-"utile vous permet de spécifier directement du SQL."
+"Il y a un grand choix de types de critères intégrés (sous classes de "
+"<literal>Restriction</literal>), dont un est particulièrement utile "
+"puisqu'il vous permet de spécifier directement SQL."
 
-#. Tag: programlisting
-#: query_criteria.xml:74
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.sqlRestriction(\"lower({alias}.name) like lower(?)\", "
-"\"Fritz%\", Hibernate.STRING) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:76
 #, no-c-format
 msgid ""
 "The <literal>{alias}</literal> placeholder with be replaced by the row alias "
 "of the queried entity."
 msgstr ""
 "La zone <literal>{alias}</literal> sera remplacée par l'alias de colonne de "
-"l'entité que l'on souhaite intérroger."
+"l'entité que l'on souhaite interroger."
 
 #. Tag: para
-#: query_criteria.xml:81
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also obtain a criterion from a <literal>Property</literal> instance. "
 "You can create a <literal>Property</literal> by calling <literal>Property."
 "forName()</literal>:"
 msgstr ""
-"Une autre approche pour obtenir un criterion est de le récupérer d'une "
+"Une autre approche pour obtenir un critère est de le récupérer d'une "
 "instance de <literal>Property</literal>. Vous pouvez créer une "
 "<literal>Property</literal> en appelant <literal>Property.forName()</"
-"literal>."
+"literal>. "
 
-#. Tag: programlisting
-#: query_criteria.xml:87
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"Property age = Property.forName(\"age\");\n"
-"List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.disjunction()\n"
-"        .add( age.isNull() )\n"
-"        .add( age.eq( new Integer(0) ) )\n"
-"        .add( age.eq( new Integer(1) ) )\n"
-"        .add( age.eq( new Integer(2) ) )\n"
-"    ) )\n"
-"    .add( Property.forName(\"name\").in( new String[] { \"Fritz\", \"Izi\", "
-"\"Pk\" } ) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:92
 #, no-c-format
 msgid "Ordering the results"
 msgstr "Trier les résultats"
 
 #. Tag: para
-#: query_criteria.xml:94
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can order the results using <literal>org.hibernate.criterion.Order</"
 "literal>."
 msgstr ""
 "Vous pouvez trier les résultats en utilisant <literal>org.hibernate."
-"criterion.Order</literal>."
+"criterion.Order</literal>. "
 
-#. Tag: programlisting
-#: query_criteria.xml:98
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"F%\")\n"
-"    .addOrder( Order.asc(\"name\") )\n"
-"    .addOrder( Order.desc(\"age\") )\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:100
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Property.forName(\"name\").like(\"F%\") )\n"
-"    .addOrder( Property.forName(\"name\").asc() )\n"
-"    .addOrder( Property.forName(\"age\").desc() )\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:105
 #, no-c-format
 msgid "Associations"
 msgstr "Associations"
 
 #. Tag: para
-#: query_criteria.xml:107
 #, no-c-format
 msgid ""
 "By navigating associations using <literal>createCriteria()</literal> you can "
 "specify constraints upon related entities:"
 msgstr ""
+"En naviguant les associations qui utilisent <literal>createCriteria()</"
+"literal>, vous pouvez spécifier des contraintes associées à des entités :"
 
-#. Tag: programlisting
-#: query_criteria.xml:112
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"F%\") )\n"
-"    .createCriteria(\"kittens\")\n"
-"        .add( Restrictions.like(\"name\", \"F%\") )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:114
-#, fuzzy, no-c-format
-msgid ""
 "The second <literal>createCriteria()</literal> returns a new instance of "
 "<literal>Criteria</literal> that refers to the elements of the "
 "<literal>kittens</literal> collection."
 msgstr ""
 "Notez que la seconde <literal>createCriteria()</literal> retourne une "
 "nouvelle instance de <literal>Criteria</literal>, qui se rapporte aux "
-"éléments de la collection <literal>kittens</literal>."
+"éléments de la collection <literal>kittens</literal>. "
 
 #. Tag: para
-#: query_criteria.xml:120
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is also an alternate form that is useful in certain circumstances:"
-msgstr "La forme alternative suivante est utile dans certains cas."
+msgstr "La forme alternative suivante est utile dans certains cas :"
 
-#. Tag: programlisting
-#: query_criteria.xml:124
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .createAlias(\"kittens\", \"kt\")\n"
-"    .createAlias(\"mate\", \"mt\")\n"
-"    .add( Restrictions.eqProperty(\"kt.name\", \"mt.name\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:126
 #, no-c-format
 msgid ""
 "(<literal>createAlias()</literal> does not create a new instance of "
@@ -284,8 +153,7 @@
 "<literal>Criteria</literal>.)"
 
 #. Tag: para
-#: query_criteria.xml:131
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The kittens collections held by the <literal>Cat</literal> instances "
 "returned by the previous two queries are <emphasis>not</emphasis> pre-"
@@ -295,97 +163,84 @@
 "Notez que les collections kittens contenues dans les instances de "
 "<literal>Cat</literal> retournées par les deux précédentes requêtes ne sont "
 "<emphasis>pas</emphasis> pré-filtrées par les critères ! Si vous souhaitez "
-"récupérer uniquement les kittens qui correspondent à la criteria, vous devez "
-"utiliser <literal>ResultTransformer</literal>."
+"récupérer uniquement les kittens correspondant aux critères, vous devez "
+"utiliser <literal>ResultTransformer</literal>. "
 
-#. Tag: programlisting
-#: query_criteria.xml:138
+#. Tag: para
 #, no-c-format
+msgid "Additionally you may manipulate the result set using a left outer join:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .createCriteria(\"kittens\", \"kt\")\n"
-"        .add( Restrictions.eq(\"name\", \"F%\") )\n"
-"    .setResultTransformer(Criteria.ALIAS_TO_ENTITY_MAP)\n"
-"    .list();\n"
-"Iterator iter = cats.iterator();\n"
-"while ( iter.hasNext() ) {\n"
-"    Map map = (Map) iter.next();\n"
-"    Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);\n"
-"    Cat kitten = (Cat) map.get(\"kt\");\n"
-"}]]>"
+"This will return all of the <literal>Cat</literal>s with a mate whose name "
+"starts with \"good\" ordered by their mate's age, and all cats who do not "
+"have a mate. This is useful when there is a need to order or limit in the "
+"database prior to returning complex/large result sets, and removes many "
+"instances where multiple queries would have to be performed and the results "
+"unioned by java in memory."
 msgstr ""
 
+#. Tag: para
+#, no-c-format
+msgid ""
+"Without this feature, first all of the cats without a mate would need to be "
+"loaded in one query."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"A second query would need to retreive the cats with mates who's name started "
+"with \"good\" sorted by the mates age."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "Thirdly, in memory; the lists would need to be joined manually."
+msgstr ""
+
 #. Tag: title
-#: query_criteria.xml:143
 #, no-c-format
 msgid "Dynamic association fetching"
 msgstr "Peuplement d'associations de manière dynamique"
 
 #. Tag: para
-#: query_criteria.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can specify association fetching semantics at runtime using "
 "<literal>setFetchMode()</literal>."
 msgstr ""
-"Vous pouvez spéficier au moment de l'exécution le peuplement d'une "
-"association en utilisant <literal>setFetchMode()</literal> (c'est-à-dire le "
-"chargement de celle-ci). Cela permet de surcharger les valeurs \"lazy\" et "
-"\"outer-join\" du mapping."
+"Vous pouvez spécifier, au moment de l'exécution, le peuplement d'une "
+"association en utilisant <literal>setFetchMode()</literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:150
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .setFetchMode(\"mate\", FetchMode.EAGER)\n"
-"    .setFetchMode(\"kittens\", FetchMode.EAGER)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:152
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "This query will fetch both <literal>mate</literal> and <literal>kittens</"
-"literal> by outer join. See <xref linkend=\"performance-fetching\"/> for "
+"literal> by outer join. See <xref linkend=\"performance-fetching\" /> for "
 "more information."
 msgstr ""
 "Cette requête recherchera <literal>mate</literal> et <literal>kittens</"
-"literal> via les jointures externes. Voir <xref linkend=\"performance-"
-"fetching\"/> pour plus d'informations."
+"literal> via les jointures externes. Consultez <xref linkend=\"performance-"
+"fetching\" /> pour plus d'informations."
 
 #. Tag: title
-#: query_criteria.xml:160
 #, no-c-format
 msgid "Example queries"
 msgstr "Requêtes par l'exemple"
 
 #. Tag: para
-#: query_criteria.xml:162
 #, no-c-format
 msgid ""
 "The class <literal>org.hibernate.criterion.Example</literal> allows you to "
 "construct a query criterion from a given instance."
 msgstr ""
 "La classe <literal>org.hibernate.criterion.Example</literal> vous permet de "
-"construire un critère suivant une instance d'objet donnée."
+"construire un critère de requête à partir d'une instance d'objet donnée."
 
-#. Tag: programlisting
-#: query_criteria.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = new Cat();\n"
-"cat.setSex('F');\n"
-"cat.setColor(Color.BLACK);\n"
-"List results = session.createCriteria(Cat.class)\n"
-"    .add( Example.create(cat) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:169
 #, no-c-format
 msgid ""
 "Version properties, identifiers and associations are ignored. By default, "
@@ -395,56 +250,26 @@
 "Par défaut, les valeurs null sont exclues."
 
 #. Tag: para
-#: query_criteria.xml:174
 #, no-c-format
 msgid "You can adjust how the <literal>Example</literal> is applied."
 msgstr ""
 "Vous pouvez ajuster la stratégie d'utilisation de valeurs de "
 "l'<literal>Exemple</literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:178
-#, no-c-format
-msgid ""
-"<![CDATA[Example example = Example.create(cat)\n"
-"    .excludeZeroes()           //exclude zero valued properties\n"
-"    .excludeProperty(\"color\")  //exclude the property named \"color\"\n"
-"    .ignoreCase()              //perform case insensitive string "
-"comparisons\n"
-"    .enableLike();             //use like for string comparisons\n"
-"List results = session.createCriteria(Cat.class)\n"
-"    .add(example)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:180
 #, no-c-format
 msgid "You can even use examples to place criteria upon associated objects."
 msgstr ""
-"Vous pouvez utiliser les \"exemples\" pour des critères sur les objets "
+"Vous pouvez utiliser les \"exemples\" pour des critères sur des objets "
 "associés."
 
-#. Tag: programlisting
-#: query_criteria.xml:184
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .add( Example.create(cat) )\n"
-"    .createCriteria(\"mate\")\n"
-"        .add( Example.create( cat.getMate() ) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:189
 #, no-c-format
 msgid "Projections, aggregation and grouping"
 msgstr "Projections, agrégation et regroupement"
 
 #. Tag: para
-#: query_criteria.xml:190
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The class <literal>org.hibernate.criterion.Projections</literal> is a "
 "factory for <literal>Projection</literal> instances. You can apply a "
@@ -452,34 +277,9 @@
 msgstr ""
 "La classe <literal>org.hibernate.criterion.Projections</literal> est une "
 "fabrique d'instances de <literal>Projection</literal>. Nous appliquons une "
-"projection sur une requête en appelant <literal>setProjection()</literal>."
+"projection sur une requête en appelant <literal>setProjection()</literal>. "
 
-#. Tag: programlisting
-#: query_criteria.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.rowCount() )\n"
-"    .add( Restrictions.eq(\"color\", Color.BLACK) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:198
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount() )\n"
-"        .add( Projections.avg(\"weight\") )\n"
-"        .add( Projections.max(\"weight\") )\n"
-"        .add( Projections.groupProperty(\"color\") )\n"
-"    )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:200
 #, no-c-format
 msgid ""
 "There is no explicit \"group by\" necessary in a criteria query. Certain "
@@ -488,44 +288,21 @@
 msgstr ""
 "Il n'y a pas besoin de \"group by\" explicite dans une requête par critère. "
 "Certains types de projection sont définis pour être des "
-"<emphasis>projections de regroupement</emphasis>, lesquels apparaissent "
-"aussi dans la clause <literal>group by</literal> SQL."
+"<emphasis>projections de regroupement</emphasis>, qui apparaissent aussi "
+"dans la clause SQL <literal>group by</literal>."
 
 #. Tag: para
-#: query_criteria.xml:206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An alias can be assigned to a projection so that the projected value can be "
 "referred to in restrictions or orderings. Here are two different ways to do "
 "this:"
 msgstr ""
 "Un alias peut optionnellement être assigné à une projection, ainsi la valeur "
-"projetée peut être référencée dans des restrictions ou des tris. Voici deux "
-"façons différentes de faire ça :"
+"projetée peut être référencée dans des restrictions ou des tris. À cet "
+"effet, voici deux procédés différents : "
 
-#. Tag: programlisting
-#: query_criteria.xml:212
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.alias( Projections.groupProperty(\"color\"), "
-"\"colr\" ) )\n"
-"    .addOrder( Order.asc(\"colr\") )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:214
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.groupProperty(\"color\").as(\"colr\") )\n"
-"    .addOrder( Order.asc(\"colr\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:216
 #, no-c-format
 msgid ""
 "The <literal>alias()</literal> and <literal>as()</literal> methods simply "
@@ -533,44 +310,13 @@
 "<literal>Projection</literal>. As a shortcut, you can assign an alias when "
 "you add the projection to a projection list:"
 msgstr ""
-"Les méthodes <literal>alias()</literal> et <literal>as()</literal> enveloppe "
-"simplement une instance de projection dans une autre instance (aliasée) de "
-"<literal>Projection</literal>. Comme un raccourci, vous pouvez assignez un "
-"alias lorsque vous ajoutez la projection à la liste de projections :"
+"Les méthodes <literal>alias()</literal> et <literal>as()</literal> "
+"enveloppent simplement une instance de projection dans une autre instance "
+"(aliasée) de <literal>Projection</literal>. Pour un raccourci, vous pouvez "
+"assigner un alias lorsque vous ajoutez la projection à une liste de "
+"projections :"
 
-#. Tag: programlisting
-#: query_criteria.xml:223
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount(), \"catCountByColor\" )\n"
-"        .add( Projections.avg(\"weight\"), \"avgWeight\" )\n"
-"        .add( Projections.max(\"weight\"), \"maxWeight\" )\n"
-"        .add( Projections.groupProperty(\"color\"), \"color\" )\n"
-"    )\n"
-"    .addOrder( Order.desc(\"catCountByColor\") )\n"
-"    .addOrder( Order.desc(\"avgWeight\") )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:225
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Domestic.class, \"cat\")\n"
-"    .createAlias(\"kittens\", \"kit\")\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.property(\"cat.name\"), \"catName\" )\n"
-"        .add( Projections.property(\"kit.name\"), \"kitName\" )\n"
-"    )\n"
-"    .addOrder( Order.asc(\"catName\") )\n"
-"    .addOrder( Order.asc(\"kitName\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:227
 #, no-c-format
 msgid ""
 "You can also use <literal>Property.forName()</literal> to express "
@@ -579,41 +325,13 @@
 "Vous pouvez aussi utiliser <literal>Property.forName()</literal> pour "
 "formuler des projections :"
 
-#. Tag: programlisting
-#: query_criteria.xml:231
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Property.forName(\"name\") )\n"
-"    .add( Property.forName(\"color\").eq(Color.BLACK) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:233
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount().as(\"catCountByColor\") )\n"
-"        .add( Property.forName(\"weight\").avg().as(\"avgWeight\") )\n"
-"        .add( Property.forName(\"weight\").max().as(\"maxWeight\") )\n"
-"        .add( Property.forName(\"color\").group().as(\"color\" )\n"
-"    )\n"
-"    .addOrder( Order.desc(\"catCountByColor\") )\n"
-"    .addOrder( Order.desc(\"avgWeight\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:238
 #, no-c-format
 msgid "Detached queries and subqueries"
 msgstr "Requêtes et sous-requêtes détachées"
 
 #. Tag: para
-#: query_criteria.xml:239
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>DetachedCriteria</literal> class allows you to create a query "
 "outside the scope of a session and then execute it using an arbitrary "
@@ -621,86 +339,32 @@
 msgstr ""
 "La classe <literal>DetachedCriteria</literal> vous laisse créer une requête "
 "en dehors de la portée de la session, et puis l'exécuter plus tard en "
-"utilisant n'importe quelle <literal>Session</literal> arbitraire."
+"utilisant une <literal>Session</literal> arbitraire. "
 
-#. Tag: programlisting
-#: query_criteria.xml:244
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DetachedCriteria query = DetachedCriteria.forClass(Cat.class)\n"
-"    .add( Property.forName(\"sex\").eq('F') );\n"
-"    \n"
-"Session session = ....;\n"
-"Transaction txn = session.beginTransaction();\n"
-"List results = query.getExecutableCriteria(session).setMaxResults(100).list"
-"();\n"
-"txn.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:246
-#, fuzzy, no-c-format
-msgid ""
 "A <literal>DetachedCriteria</literal> can also be used to express a "
 "subquery. Criterion instances involving subqueries can be obtained via "
 "<literal>Subqueries</literal> or <literal>Property</literal>."
 msgstr ""
-"Une <literal>DetachedCriteria</literal> peut aussi être utilisée pour "
-"exprimer une sous-requête. Des instances de criterion impliquant des sous-"
+"Les <literal>DetachedCriteria</literal> peuvent aussi être utilisés pour "
+"exprimer une sous-requête. Des instances de critère impliquant des sous-"
 "requêtes peuvent être obtenues via <literal>Subqueries</literal> ou "
-"<literal>Property</literal>."
+"<literal>Property</literal>. "
 
-#. Tag: programlisting
-#: query_criteria.xml:252
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria avgWeight = DetachedCriteria.forClass(Cat.class)\n"
-"    .setProjection( Property.forName(\"weight\").avg() );\n"
-"session.createCriteria(Cat.class)\n"
-"    .add( Property.forName(\"weight\").gt(avgWeight) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:254
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria weights = DetachedCriteria.forClass(Cat.class)\n"
-"    .setProjection( Property.forName(\"weight\") );\n"
-"session.createCriteria(Cat.class)\n"
-"    .add( Subqueries.geAll(\"weight\", weights) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:256
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Correlated subqueries are also possible:"
-msgstr "Même des requêtes corrélées sont possibles :"
+msgstr "Des sous-requêtes corrélées sont également possibles :"
 
-#. Tag: programlisting
-#: query_criteria.xml:260
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria avgWeightForSex = DetachedCriteria.forClass(Cat."
-"class, \"cat2\")\n"
-"    .setProjection( Property.forName(\"weight\").avg() )\n"
-"    .add( Property.forName(\"cat2.sex\").eqProperty(\"cat.sex\") );\n"
-"session.createCriteria(Cat.class, \"cat\")\n"
-"    .add( Property.forName(\"weight\").gt(avgWeightForSex) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:269
 #, no-c-format
 msgid "Queries by natural identifier"
 msgstr "Requêtes par identifiant naturel"
 
 #. Tag: para
-#: query_criteria.xml:271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For most queries, including criteria queries, the query cache is not "
 "efficient because query cache invalidation occurs too frequently. However, "
@@ -711,79 +375,38 @@
 msgstr ""
 "Pour la plupart des requêtes, incluant les requêtes par critère, le cache de "
 "requêtes n'est pas très efficace, parce que l'invalidation du cache de "
-"requêtes arrive trop souvent. Cependant, il y a une sorte spéciale de "
-"requête où nous pouvons optimiser l'algorithme d'invalidation du cache : les "
-"recherches sur une clef naturelle constante. Dans certaines applications, "
-"cette sorte de requête se produit fréquemment. L'API de critère fournit une "
-"provision spéciale pour ce cas d'utilisation."
+"requêtes arrive trop souvent. Cependant, il y existe une requête spéciale où "
+"l'on peut optimiser l'algorithme d'invalidation du cache : les recherches "
+"par une clef naturelle constante. Dans certaines applications, ce genre de "
+"requête se produit fréquemment. L'API des critères fournit une disposition "
+"spéciale pour ce cas d'utilisation. "
 
 #. Tag: para
-#: query_criteria.xml:279
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, map the natural key of your entity using <literal>&lt;natural-id&gt;</"
 "literal> and enable use of the second-level cache."
 msgstr ""
-"D'abord vous devriez mapper la clef naturelle de votre entité en utilisant "
+"D'abord, vous devrez mapper la clé naturelle de votre entité en utilisant "
 "<literal>&lt;natural-id&gt;</literal>, et activer l'utilisation du cache de "
 "second niveau."
 
-#. Tag: programlisting
-#: query_criteria.xml:284
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"User\">\n"
-"    <cache usage=\"read-write\"/>\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <natural-id>\n"
-"        <property name=\"name\"/>\n"
-"        <property name=\"org\"/>\n"
-"    </natural-id>\n"
-"    <property name=\"password\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:286
-#, fuzzy, no-c-format
-msgid ""
 "This functionality is not intended for use with entities with "
 "<emphasis>mutable</emphasis> natural keys."
 msgstr ""
-"Notez que cette fonctionnalité n'est pas prévue pour l'utilisation avec des "
-"entités avec des clefs naturelles <emphasis>mutables</emphasis>."
+"Cette fonctionnalité n'est pas prévue pour l'utilisation avec des entités "
+"avec des clés naturelles <emphasis>mutables</emphasis>."
 
 #. Tag: para
-#: query_criteria.xml:291
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Once you have enabled the Hibernate query cache, the <literal>Restrictions."
 "naturalId()</literal> allows you to make use of the more efficient cache "
 "algorithm."
 msgstr ""
-"Maintenant <literal>Restrictions.naturalId()</literal> nous permet de rendre "
+"Une fois que vous aurez activé le cache de requête d'Hibernate, "
+"<literal>Restrictions.naturalId()</literal> vous permettra de rendre "
 "l'utilisation de l'algorithme de cache plus efficace."
-
-#. Tag: programlisting
-#: query_criteria.xml:297
-#, no-c-format
-msgid ""
-"<![CDATA[session.createCriteria(User.class)\n"
-"    .add( Restrictions.naturalId()\n"
-"        .set(\"name\", \"gavin\")\n"
-"        .set(\"org\", \"hb\") \n"
-"    ).setCacheable(true)\n"
-"    .uniqueResult();]]>"
-msgstr ""
-
-#~ msgid ""
-#~ "You may easily specify constraints upon related entities by navigating "
-#~ "associations using <literal>createCriteria()</literal>."
-#~ msgstr ""
-#~ "Vous pouvez facilement spécifier des contraintes sur des entités liées, "
-#~ "par des associations en utilisant <literal>createCriteria()</literal>."
-
-#~ msgid "Next, enable the Hibernate query cache."
-#~ msgstr "Ensuite, activez le cache de requête d'Hibernate."

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/query_hql.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/query_hql.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/query_hql.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,43 +1,45 @@
+# translation of query_hql.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: query_hql\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-05 09:46+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: query_hql.xml:29
 #, no-c-format
 msgid "HQL: The Hibernate Query Language"
-msgstr "HQL: Langage de requêtage d'Hibernate"
+msgstr "HQL : langage d'interrogation d'Hibernate"
 
 #. Tag: para
-#: query_hql.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate uses a powerful query language (HQL) that is similar in appearance "
 "to SQL. Compared with SQL, however, HQL is fully object-oriented and "
 "understands notions like inheritance, polymorphism and association."
 msgstr ""
-"Hibernate fourni un langage d'interrogation extrêmement puissant qui "
-"ressemble (et c'est voulu) au SQL. Mais ne soyez pas distraits par la "
-"syntaxe ; HQL est totalement orienté objet, comprenant des notions "
-"d'héritage, de polymorphisme et d'association."
+"Hibernate fournit un langage d'interrogation extrêmement puissant qui "
+"ressemble (et c'est voulu) au SQL. Mais ne soyez pas dupe de la syntaxe ; "
+"HQL est totalement orienté objet, cernant des notions comme l'héritage, le "
+"polymorphisme et les associations. "
 
 #. Tag: title
-#: query_hql.xml:38
 #, no-c-format
 msgid "Case Sensitivity"
 msgstr "Sensibilité à la casse"
 
 #. Tag: para
-#: query_hql.xml:40
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "With the exception of names of Java classes and properties, queries are case-"
 "insensitive. So <literal>SeLeCT</literal> is the same as <literal>sELEct</"
@@ -45,80 +47,59 @@
 "hibernate.eg.FOO</literal> is not <literal>org.hibernate.eg.Foo</literal>, "
 "and <literal>foo.barSet</literal> is not <literal>foo.BARSET</literal>."
 msgstr ""
-"Les requêtes sont insensibles à la casse, à l'exception des noms des classes "
+"Les requêtes sont insensibles à la casse, à l'exception des noms de classes "
 "Java et des propriétés. Ainsi, <literal>SeLeCT</literal> est identique à "
 "<literal>sELEct</literal> et à <literal>SELECT</literal> mais <literal>net."
 "sf.hibernate.eg.FOO</literal> n'est pas identique <literal>net.sf.hibernate."
 "eg.Foo</literal> et <literal>foo.barSet</literal> n'est pas identique à "
-"<literal>foo.BARSET</literal>."
+"<literal>foo.BARSET</literal>. "
 
 #. Tag: para
-#: query_hql.xml:51
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This manual uses lowercase HQL keywords. Some users find queries with "
 "uppercase keywords more readable, but this convention is unsuitable for "
 "queries embedded in Java code."
 msgstr ""
-"Ce guide utilise les mots clés HQL en minuscule. Certains utilisateurs "
-"trouvent les requêtes écrites avec les mots clés en majuscule plus lisibles, "
-"mais nous trouvons cette convention pénible lorsqu'elle est lue dans du code "
-"Java."
+"Ce guide utilise les mots clés HQL en minuscules. Certains utilisateurs "
+"trouvent les requêtes écrites avec les mots clés en majuscules plus "
+"lisibles, mais nous trouvons cette convention pénible lorsqu'elle est lue "
+"dans du code Java. "
 
 #. Tag: title
-#: query_hql.xml:59
 #, no-c-format
 msgid "The from clause"
 msgstr "La clause from"
 
 #. Tag: para
-#: query_hql.xml:61
 #, no-c-format
 msgid "The simplest possible Hibernate query is of the form:"
 msgstr "La requête Hibernate la plus simple est de la forme :"
 
-#. Tag: programlisting
-#: query_hql.xml:65
-#, no-c-format
-msgid "<![CDATA[from eg.Cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:67
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This returns all instances of the class <literal>eg.Cat</literal>. You do "
 "not usually need to qualify the class name, since <literal>auto-import</"
 "literal> is the default. For example:"
 msgstr ""
-"qui retourne simplement toutes les instances de la classe <literal>eg.Cat</"
-"literal>. Nous n'avons pas besoin d'habitude de qualifier le nom de la "
-"classe, puisque <literal>auto-import</literal> est la valeur par défaut. "
-"Donc nous écrivons presque toujours :"
+"Retourne toutes les instances de la classe <literal>eg.Cat</literal>. Nous "
+"n'avons pas besoin de qualifier le nom de la classe, puisque <literal>auto-"
+"import</literal> est la valeur par défaut. Donc nous écrivons presque "
+"toujours :"
 
-#. Tag: programlisting
-#: query_hql.xml:73
-#, no-c-format
-msgid "<![CDATA[from Cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:75
 #, no-c-format
 msgid ""
 "In order to refer to the <literal>Cat</literal> in other parts of the query, "
 "you will need to assign an <emphasis>alias</emphasis>. For example:"
 msgstr ""
+"Pour pouvoir nous référer à <literal>Cat</literal> dans des autres parties "
+"de la requête, vous aurez besoin d'y assigner un <emphasis>alias</emphasis>. "
+"Ainsi :"
 
-#. Tag: programlisting
-#: query_hql.xml:81 query_hql.xml:396
-#, no-c-format
-msgid "<![CDATA[from Cat as cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:83
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This query assigns the alias <literal>cat</literal> to <literal>Cat</"
 "literal> instances, so you can use that alias later in the query. The "
@@ -126,114 +107,66 @@
 msgstr ""
 "Cette requête assigne l'alias <literal>cat</literal> à l'instance "
 "<literal>Cat</literal>, nous pouvons donc utiliser cet alias ailleurs dans "
-"la requête. Le mot clé <literal>as</literal> est optionnel ; nous aurions pu "
+"la requête. Le mot clé <literal>as</literal> est optionnel. Nous aurions pu "
 "écrire :"
 
-#. Tag: programlisting
-#: query_hql.xml:89
-#, no-c-format
-msgid "<![CDATA[from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:91
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Multiple classes can appear, resulting in a cartesian product or \"cross\" "
 "join."
 msgstr ""
 "Plusieurs classes peuvent apparaître, ce qui conduira à un produit cartésien "
-"(encore appelé jointures croisées)."
+"(encore appelé jointures croisées). "
 
-#. Tag: programlisting
-#: query_hql.xml:95
-#, no-c-format
-msgid "<![CDATA[from Formula, Parameter]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:96
-#, no-c-format
-msgid "<![CDATA[from Formula as form, Parameter as param]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:98
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is good practice to name query aliases using an initial lowercase as this "
 "is consistent with Java naming standards for local variables (e.g. "
 "<literal>domesticCat</literal>)."
 msgstr ""
 "C'est une bonne pratique que de nommer les alias dans les requêtes en "
-"utilisant l'initiale en miniscule, ce qui a le mérite d'être en phase avec "
-"les standards de nommage Java pour les variables locales "
-"(<literal>domesticCat</literal>)."
+"utilisant l'initiale en miniscule, ce qui correspond aux standards de "
+"nommage Java pour les variables locales (par ex. <literal>domesticCat</"
+"literal>)."
 
 #. Tag: title
-#: query_hql.xml:107
 #, no-c-format
 msgid "Associations and joins"
 msgstr "Associations et jointures"
 
 #. Tag: para
-#: query_hql.xml:109
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also assign aliases to associated entities or to elements of a "
 "collection of values using a <literal>join</literal>. For example:"
 msgstr ""
 "On peut aussi assigner des alias à des entités associées, ou même aux "
 "éléments d'une collection de valeurs, en utilisant un <literal>join</"
-"literal> (jointure)."
+"literal> (jointure). Par exemple :"
 
-#. Tag: programlisting
-#: query_hql.xml:114
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join cat.mate as mate\n"
-"    left outer join cat.kittens as kitten]]>"
-msgstr ""
+msgid "The supported join types are borrowed from ANSI SQL:"
+msgstr "Les types de jointures supportées sont empruntées de ANSI SQL :"
 
-#. Tag: programlisting
-#: query_hql.xml:116
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from Cat as cat left join cat.mate.kittens as kittens]]>"
-msgstr ""
+msgid "<literal>inner join</literal>"
+msgstr "<literal>inner join</literal> (jointure interne)"
 
-#. Tag: programlisting
-#: query_hql.xml:118
-#, no-c-format
-msgid "<![CDATA[from Formula form full join form.parameter param]]>"
-msgstr ""
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>left outer join</literal>"
+msgstr "<literal>inner join</literal> (jointure interne)"
 
 #. Tag: para
-#: query_hql.xml:120
 #, fuzzy, no-c-format
-msgid "The supported join types are borrowed from ANSI SQL:"
-msgstr "Les types de jointures supportées sont celles de ANSI SQL"
+msgid "<literal>right outer join</literal>"
+msgstr "<literal>inner join</literal> (jointure interne)"
 
-#. Tag: literal
-#: query_hql.xml:127
-#, no-c-format
-msgid "inner join"
-msgstr "<literal>inner join</literal> (jointure fermée)"
-
-#. Tag: literal
-#: query_hql.xml:132
-#, no-c-format
-msgid "left outer join"
-msgstr "<literal>left outer join</literal> (jointure ouverte par la gauche)"
-
-#. Tag: literal
-#: query_hql.xml:137
-#, no-c-format
-msgid "right outer join"
-msgstr "<literal>right outer join</literal> (jointure ouverte par la droite)"
-
 #. Tag: para
-#: query_hql.xml:141
 #, no-c-format
 msgid "<literal>full join</literal> (not usually useful)"
 msgstr ""
@@ -241,7 +174,6 @@
 "inutile)"
 
 #. Tag: para
-#: query_hql.xml:147
 #, no-c-format
 msgid ""
 "The <literal>inner join</literal>, <literal>left outer join</literal> and "
@@ -249,19 +181,9 @@
 msgstr ""
 "Les constructions des jointures <literal>inner join</literal>, <literal>left "
 "outer join</literal> et <literal>right outer join</literal> peuvent être "
-"abbrégées."
+"abrégées."
 
-#. Tag: programlisting
-#: query_hql.xml:152
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    join cat.mate as mate\n"
-"    left join cat.kittens as kitten]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:154
 #, no-c-format
 msgid ""
 "You may supply extra join conditions using the HQL <literal>with</literal> "
@@ -270,47 +192,27 @@
 "Nous pouvons soumettre des conditions de jointure supplémentaires en "
 "utilisant le mot-clef HQL <literal>with</literal>."
 
-#. Tag: programlisting
-#: query_hql.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    left join cat.kittens as kitten\n"
-"        with kitten.bodyWeight > 10.0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:161
 #, fuzzy, no-c-format
 msgid ""
 "A \"fetch\" join allows associations or collections of values to be "
 "initialized along with their parent objects using a single select. This is "
 "particularly useful in the case of a collection. It effectively overrides "
 "the outer join and lazy declarations of the mapping file for associations "
-"and collections. See <xref linkend=\"performance-fetching\"/> for more "
+"and collections. See <xref linkend=\"performance-fetching\" /> for more "
 "information."
 msgstr ""
-"Par ailleurs, une jointure \"fetchée\" (rapportée) permet d'initialiser les "
-"associations ou collections de valeurs en même temps que leur objet parent, "
-"le tout n'utilisant qu'un seul Select. Ceci est particulièrement utile dans "
-"le cas des collections. Ce système permet de surcharger les déclarations "
-"\"lazy\" et \"outer-join\" des fichiers de mapping pour les associations et "
-"collections. Voir <xref linkend=\"performance-fetching\"/> pour plus "
-"d'informations."
+"Par ailleurs, une jointure \"fetch\" (rapportée) permet d'initialiser les "
+"associations ou collections de valeurs en même temps que leurs objets "
+"parents, en utilisant qu'un seul Select. Ceci est particulièrement utile "
+"dans le cas des collections. Ce système permet de surcharger les "
+"déclarations \"lazy\" et \"outer-join\" des fichiers de mapping pour les "
+"associations et collections. Consultez <xref linkend=\"performance-fetching"
+"\" /> pour plus d'informations."
 
-#. Tag: programlisting
-#: query_hql.xml:169
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join fetch cat.mate\n"
-"    left join fetch cat.kittens]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:171
-#, fuzzy, no-c-format
-msgid ""
 "A fetch join does not usually need to assign an alias, because the "
 "associated objects should not be used in the <literal>where</literal> clause "
 "(or any other clause). The associated objects are also not returned directly "
@@ -318,28 +220,17 @@
 "The only reason you might need an alias is if you are recursively join "
 "fetching a further collection:"
 msgstr ""
-"Une jointure \"fetchée\" (rapportée) n'a généralement pas besoin de se voir "
-"assigner un alias puisque les objets associés n'ont pas à être utilisés dans "
-"les autres clauses. Notez aussi que les objets associés ne sont pas "
-"retournés directement dans le résultat de la requête mais l'on peut y "
-"accéder via l'objet parent. La seule raison pour laquelle nous pourrions "
-"avoir besoin d'un alias est si nous récupérions récursivement une collection "
-"supplémentaire :"
+"Une jointure \"fetch\" (rapportée) n'a généralement pas besoin de se voir "
+"assigner un alias puisque les objets associés ne doivent pas être utilisés "
+"dans la clause <literal>where</literal> ou toute autre clause. Notez aussi "
+"que les objets associés ne sont pas retournés directement dans le résultat "
+"de la requête mais l'on peut y accéder via l'objet parent. La seule raison "
+"pour laquelle nous pourrions avoir besoin d'un alias est si nous récupérons "
+"récursivement une collection supplémentaire :"
 
-#. Tag: programlisting
-#: query_hql.xml:179
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join fetch cat.mate\n"
-"    left join fetch cat.kittens child\n"
-"    left join fetch child.kittens]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:181
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>fetch</literal> construct cannot be used in queries called "
 "using <literal>iterate()</literal> (though <literal>scroll()</literal> can "
 "be used). <literal>Fetch</literal> should be used together with "
@@ -357,21 +248,22 @@
 msgstr ""
 "Notez que la construction de <literal>fetch</literal> ne peut pas être "
 "utilisée dans les requêtes appelées par <literal>scroll()</literal> ou "
-"<literal>iterate()</literal>. <literal>fetch</literal> ne devrait pas non "
-"plus être utilisé avec <literal>setMaxResults()</literal> ou "
-"<literal>setFirstResult()</literal>. <literal>fetch</literal> ne peut pas "
-"non plus être utilisé avec une condition <literal>with</literal> ad hoc. Il "
-"est possible de créer un produit cartésien par jointure en récupérant plus "
-"d'une collection dans une requête, donc faites attention dans ce cas. "
-"Récupérer par jointure de multiples collections donne aussi parfois des "
-"résultats inattendus pour des mappings de bag, donc soyez prudent lorsque "
-"vous formulez vos requêtes dans de tels cas. Finalement, notez que "
-"<literal>full join fetch</literal> et <literal>right join fetch</literal> ne "
-"sont pas utiles en général."
+"<literal>iterate()</literal>. De même <literal>Fetch</literal> ne devrait "
+"pas être utilisé avec <literal>setMaxResults()</literal> ou "
+"<literal>setFirstResult()</literal>, ces opérations étant basées sur le "
+"nombre de résultats contenant généralement des doublons dès que des "
+"collections sont chargées agressivement, par conséquent le nombre de lignes "
+"est imprévisible. <literal>Fetch</literal> ne peut pas non plus être utilisé "
+"avec une condition <literal>with</literal> ad hoc. Il est possible de créer "
+"un produit cartésien par jointure en récupérant plus d'une collection dans "
+"une requête, donc faites attention dans ce cas. Récupérer par jointure de "
+"multiples collections donne aussi parfois des résultats inattendus pour des "
+"mappages de sac, donc soyez prudent lorsque vous formulez vos requêtes dans "
+"de tels cas. Finalement, notez que <literal>full join fetch</literal> et "
+"<literal>right join fetch</literal> ne sont pas utiles en général."
 
 #. Tag: para
-#: query_hql.xml:196
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are using property-level lazy fetching (with bytecode "
 "instrumentation), it is possible to force Hibernate to fetch the lazy "
@@ -381,52 +273,34 @@
 "Si vous utilisez un chargement retardé pour les propriétés (avec une "
 "instrumentation par bytecode), il est possible de forcer Hibernate à "
 "récupérer les propriétés non encore chargées immédiatement (dans la première "
-"requête) en utilisant <literal>fetch all properties</literal>."
+"requête) en utilisant <literal>fetch all properties</literal>. "
 
-#. Tag: programlisting
-#: query_hql.xml:202
-#, no-c-format
-msgid "<![CDATA[from Document fetch all properties order by name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:203
-#, no-c-format
-msgid ""
-"<![CDATA[from Document doc fetch all properties where lower(doc.name) like '%"
-"cats%']]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:208
 #, no-c-format
 msgid "Forms of join syntax"
 msgstr "Formes de syntaxes pour les jointures"
 
 #. Tag: para
-#: query_hql.xml:210
 #, no-c-format
 msgid ""
 "HQL supports two forms of association joining: <literal>implicit</literal> "
 "and <literal>explicit</literal>."
 msgstr ""
-"HQL supporte deux formes pour joindre les associations: <literal>implicite</"
-"literal> et <literal>explicite</literal>."
+"HQL supporte deux formes pour joindre les associations : <literal>implicit</"
+"literal> et <literal>explicit</literal>."
 
 #. Tag: para
-#: query_hql.xml:214
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The queries shown in the previous section all use the <literal>explicit</"
 "literal> form, that is, where the join keyword is explicitly used in the "
 "from clause. This is the recommended form."
 msgstr ""
 "Les requêtes présentes dans la section précédente utilisent la forme "
-"<literal>explicite</literal> où le mode clé join est explicitement utilisé "
-"dans la clause from. C'est la forme recommandée."
+"<literal>explicit</literal> où le mot clé join est explicitement utilisé "
+"dans la clause from. C'est la forme recommandée. "
 
 #. Tag: para
-#: query_hql.xml:219
 #, no-c-format
 msgid ""
 "The <literal>implicit</literal> form does not use the join keyword. Instead, "
@@ -434,56 +308,47 @@
 "literal> joins can appear in any of the HQL clauses. <literal>implicit</"
 "literal> join result in inner joins in the resulting SQL statement."
 msgstr ""
-"La forme <literal>implicite</literal> n'utilise pas le mot clé join. A la "
-"place, les associations sont \"déréférencées\" en utilisant le notation '.'. "
-"Ces jointures peuvent apparaitre dans toutes les clauses. Les jointures "
-"<literal>implicites</literal> résultent en des inner join dans le SQL généré."
+"La forme <literal>implicit</literal> n'utilise pas le mot clé join. En "
+"revanche, les associations sont \"déréférencées\" en utilisant la notation. "
+"Ces jointures <literal>implicit</literal> peuvent apparaître dans toutes les "
+"clauses HQL. Les jointures <literal>implicit</literal> résultent en des "
+"jointures internes dans le SQL généré."
 
-#. Tag: programlisting
-#: query_hql.xml:226
-#, no-c-format
-msgid "<![CDATA[from Cat as cat where cat.mate.name like '%s%']]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Referring to identifier property"
-msgstr "Refering to identifier property"
+msgstr "Faire référence à la propriété identifiant "
 
 #. Tag: para
-#: query_hql.xml:232
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "There are 2 ways to refer to an entity's identifier property:"
 msgstr ""
-"There are, generally speaking, 2 ways to refer to an entity's identifier "
-"property:"
+"Il y a en général deux façons de faire référence à une propriété "
+"d'identifiant d'une entité :"
 
 #. Tag: para
-#: query_hql.xml:237
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The special property (lowercase) <literal>id</literal> may be used to "
 "reference the identifier property of an entity <emphasis>provided that the "
 "entity does not define a non-identifier property named id</emphasis>."
 msgstr ""
-"The special property (lowercase) <literal>id</literal> may be used to "
-"reference the identifier property of an entity <emphasis>provided that "
-"entity does not define a non-identifier property named id</emphasis>."
+"La propriété particulière (minuscule) <literal>id</literal> peut être "
+"utilisée pour référencer la propriété d'identifiant d'une entité "
+"<emphasis>du moment que l'entité ne définisse pas une propriété de non-"
+"identifiant appelée id</emphasis>."
 
 #. Tag: para
-#: query_hql.xml:244
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the entity defines a named identifier property, you can use that property "
 "name."
 msgstr ""
-"If the entity defines a named identifier property, you may use that property "
-"name."
+"Si l'identité définit une propriété d'identifiant nommée, vous pouvez "
+"utiliser ce nom de propriété."
 
 #. Tag: para
-#: query_hql.xml:250
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "References to composite identifier properties follow the same naming rules. "
 "If the entity has a non-identifier property named id, the composite "
@@ -491,15 +356,14 @@
 "the special <literal>id</literal> property can be used to reference the "
 "identifier property."
 msgstr ""
-"References to composite identifier properties follow the same naming rules. "
-"If the entity has a non-identifier property named id, the composite "
-"identifier property can only be referenced by its defined named; otherwise, "
-"the special <literal>id</literal> property can be used to rerference the "
-"identifier property."
+"Les références aux propriétés d'identifiant composites suivent les mêmes "
+"règles de nommage. Si l'entité a une propriété de non-identifiant appelée "
+"id, la propriété d'identifiant composite ne peut être référencée que par son "
+"nom défini ; sinon la propriété spéciale <literal>id</literal> peut être "
+"utilisée pour référencer la propriété d'identifiant. "
 
 #. Tag: para
-#: query_hql.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please note that, starting in version 3.2.2, this has changed significantly. "
 "In previous versions, <literal>id</literal> <emphasis>always</emphasis> "
@@ -507,153 +371,77 @@
 "ramification of that decision was that non-identifier properties named "
 "<literal>id</literal> could never be referenced in Hibernate queries."
 msgstr ""
-"Note: this has changed significantly starting in version 3.2.2. In previous "
-"versions, <literal>id</literal><emphasis>always</emphasis> referred to the "
-"identifier property no matter what its actual name. A ramification of that "
-"decision was that non-identifier properties named <literal>id</literal> "
-"could never be referenced in Hibernate queries."
+"Note : cela a changé de façon significative depuis la version 3.2.2. Dans "
+"les versions précédentes, <literal>id</literal> référait <emphasis>toujours</"
+"emphasis> à la propriété identifiant quel que soit son nom réel. Une des "
+"conséquences de cette décision fut que les propriétés de non-identifiant "
+"appelées <literal>id</literal> ne pouvaient jamais être référencées dans les "
+"requêtes Hibernate."
 
 #. Tag: title
-#: query_hql.xml:269
 #, no-c-format
 msgid "The select clause"
 msgstr "La clause select"
 
 #. Tag: para
-#: query_hql.xml:271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>select</literal> clause picks which objects and properties to "
 "return in the query result set. Consider the following:"
 msgstr ""
 "La clause <literal>select</literal> sélectionne les objets et propriétés qui "
-"doivent être retournés dans le résultat de la requête. Soit :"
+"doivent être retournés dans le résultat de la requête. Soit : "
 
-#. Tag: programlisting
-#: query_hql.xml:276
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select mate\n"
-"from Cat as cat\n"
-"    inner join cat.mate as mate]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:278
-#, fuzzy, no-c-format
-msgid ""
 "The query will select <literal>mate</literal>s of other <literal>Cat</"
 "literal>s. You can express this query more compactly as:"
 msgstr ""
-"La requête recherchera les <literal>mate</literal>s liés aux <literal>Cat</"
-"literal>s. Vous pouvez explimer la requête d'une manière plus compacte :"
+"La requête recherchera les <literal>mate</literal> s liés aux <literal>Cat</"
+"literal> s. Vous pouvez exprimer cette requête de manière plus compacte : "
 
-#. Tag: programlisting
-#: query_hql.xml:283
-#, no-c-format
-msgid "<![CDATA[select cat.mate from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:285
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Queries can return properties of any value type including properties of "
 "component type:"
 msgstr ""
-"Les requêtes peuvent retourner des propriétés de n'importe quel type, même "
-"celles de type composant (component) :"
+"Les requêtes peuvent retourner des propriétés de n'importe quel type de "
+"valeur, même celles de type composant : "
 
-#. Tag: programlisting
-#: query_hql.xml:289
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat.name from DomesticCat cat\n"
-"where cat.name like 'fri%']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:291
-#, no-c-format
-msgid "<![CDATA[select cust.name.firstName from Customer as cust]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:293
-#, fuzzy, no-c-format
-msgid ""
 "Queries can return multiple objects and/or properties as an array of type "
 "<literal>Object[]</literal>:"
 msgstr ""
-"Les requêtes peuvent retourner plusieurs objets et/ou propriétés sous la "
-"forme d'un tableau du type <literal>Object[]</literal>,"
+"Les requêtes peuvent retourner de multiples objets et/ou propriétés sous la "
+"forme d'un tableau du type <literal>Object[]</literal> :"
 
-#. Tag: programlisting
-#: query_hql.xml:298
-#, no-c-format
-msgid ""
-"<![CDATA[select mother, offspr, mate.name\n"
-"from DomesticCat as mother\n"
-"    inner join mother.mate as mate\n"
-"    left outer join mother.kittens as offspr]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:300
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Or as a <literal>List</literal>:"
-msgstr "ou sous la forme d'une <literal>List</literal>,"
+msgstr "Ou sous la forme d'une <literal>List</literal> :"
 
-#. Tag: programlisting
-#: query_hql.xml:304
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select new list(mother, offspr, mate.name)\n"
-"from DomesticCat as mother\n"
-"    inner join mother.mate as mate\n"
-"    left outer join mother.kittens as offspr]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:306
-#, fuzzy, no-c-format
-msgid ""
 "Or - assuming that the class <literal>Family</literal> has an appropriate "
 "constructor - as an actual typesafe Java object:"
 msgstr ""
-"à condition que la classe <literal>Family</literal> possède le constructeur "
-"approprié."
+"Ou bien - à condition que la classe <literal>Family</literal> possède le "
+"constructeur approprié - en tant qu'objet typesafe Java :"
 
-#. Tag: programlisting
-#: query_hql.xml:310
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select new Family(mother, mate, offspr)\n"
-"from DomesticCat as mother\n"
-"    join mother.mate as mate\n"
-"    left join mother.kittens as offspr]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:313
-#, fuzzy, no-c-format
-msgid ""
 "You can assign aliases to selected expressions using <literal>as</literal>:"
 msgstr ""
 "Vous pouvez assigner des alias aux expressions sélectionnées en utilisant "
-"<literal>as</literal> :"
+"<literal>as</literal> : "
 
-#. Tag: programlisting
-#: query_hql.xml:317
-#, no-c-format
-msgid ""
-"<![CDATA[select max(bodyWeight) as max, min(bodyWeight) as min, count(*) as "
-"n\n"
-"from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:319
 #, no-c-format
 msgid ""
 "This is most useful when used together with <literal>select new map</"
@@ -662,17 +450,7 @@
 "C'est surtout utile lorsque c'est utilisé avec <literal>select new map</"
 "literal> :"
 
-#. Tag: programlisting
-#: query_hql.xml:323
-#, no-c-format
-msgid ""
-"<![CDATA[select new map( max(bodyWeight) as max, min(bodyWeight) as min, "
-"count(*) as n )\n"
-"from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:325
 #, no-c-format
 msgid ""
 "This query returns a <literal>Map</literal> from aliases to selected values."
@@ -681,114 +459,68 @@
 "les valeurs sélectionnées."
 
 #. Tag: title
-#: query_hql.xml:332
 #, no-c-format
 msgid "Aggregate functions"
-msgstr "Fonctions d'aggrégation"
+msgstr "Fonctions d'agrégation"
 
 #. Tag: para
-#: query_hql.xml:334
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL queries can even return the results of aggregate functions on properties:"
 msgstr ""
-"Les requêtes HQL peuvent aussi retourner le résultat de fonctions "
-"d'aggrégation sur les propriétés :"
+"Les requêtes HQL peuvent aussi retourner les résultats de fonctions "
+"d'agrégation sur les propriétés : "
 
-#. Tag: programlisting
-#: query_hql.xml:338
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[select avg(cat.weight), sum(cat.weight), max(cat.weight), count"
-"(cat)\n"
-"from Cat cat]]>"
-msgstr ""
+msgid "The supported aggregate functions are:"
+msgstr "Les fonctions d'agrégation supportées sont :"
 
 #. Tag: para
-#: query_hql.xml:349
 #, fuzzy, no-c-format
-msgid "The supported aggregate functions are:"
-msgstr "Les fonctions supportées sont"
+msgid "<literal>avg(...), sum(...), min(...), max(...)</literal>"
+msgstr "<literal>avg(...), sum(...), min(...), max(...)</literal>"
 
-#. Tag: literal
-#: query_hql.xml:356
+#. Tag: para
 #, no-c-format
-msgid "avg(...), sum(...), min(...), max(...)"
-msgstr "avg(...), sum(...), min(...), max(...)"
+msgid "<literal>count(*)</literal>"
+msgstr "<literal>count(*)</literal>"
 
-#. Tag: literal
-#: query_hql.xml:361
-#, no-c-format
-msgid "count(*)"
-msgstr "count(*)"
-
-#. Tag: literal
-#: query_hql.xml:366
-#, no-c-format
-msgid "count(...), count(distinct ...), count(all...)"
-msgstr "count(...), count(distinct ...), count(all...)"
-
 #. Tag: para
-#: query_hql.xml:371
 #, fuzzy, no-c-format
+msgid "<literal>count(...), count(distinct ...), count(all...)</literal>"
+msgstr "<literal>count(...), count(distinct ...), count(all...)</literal>"
+
+#. Tag: para
+#, no-c-format
 msgid ""
 "You can use arithmetic operators, concatenation, and recognized SQL "
 "functions in the select clause:"
 msgstr ""
 "Vous pouvez utiliser des opérateurs arithmétiques, la concaténation, et des "
-"fonctions SQL reconnues dans la clause select :"
+"fonctions SQL reconnues dans la clause select : "
 
-#. Tag: programlisting
-#: query_hql.xml:376
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat.weight + sum(kitten.weight)\n"
-"from Cat cat\n"
-"    join cat.kittens kitten\n"
-"group by cat.id, cat.weight]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:378
-#, no-c-format
-msgid ""
-"<![CDATA[select firstName||' '||initial||' '||upper(lastName) from Person]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:380
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>distinct</literal> and <literal>all</literal> keywords can be "
 "used and have the same semantics as in SQL."
 msgstr ""
 "Les mots clé <literal>distinct</literal> et <literal>all</literal> peuvent "
-"être utilisés et ont la même signification qu'en SQL."
+"être utilisés et ont la même sémantique qu'en SQL. "
 
-#. Tag: programlisting
-#: query_hql.xml:385
-#, no-c-format
-msgid ""
-"<![CDATA[select distinct cat.name from Cat cat\n"
-"\n"
-"select count(distinct cat.name), count(cat) from Cat cat]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:390
 #, no-c-format
 msgid "Polymorphic queries"
 msgstr "Requêtes polymorphiques"
 
 #. Tag: para
-#: query_hql.xml:392
 #, no-c-format
 msgid "A query like:"
-msgstr "Une requête comme:"
+msgstr "Une requête comme :"
 
 #. Tag: para
-#: query_hql.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "returns instances not only of <literal>Cat</literal>, but also of subclasses "
 "like <literal>DomesticCat</literal>. Hibernate queries can name "
@@ -797,21 +529,15 @@
 "that extend that class or implement the interface. The following query would "
 "return all persistent objects:"
 msgstr ""
-"retourne non seuleument les instances de <literal>Cat</literal>, mais aussi "
+"retourne non seulement les instances de <literal>Cat</literal>, mais aussi "
 "celles des sous classes comme <literal>DomesticCat</literal>. Les requêtes "
 "Hibernate peuvent nommer n'importe quelle classe ou interface Java dans la "
 "clause <literal>from</literal>. La requête retournera les instances de "
 "toutes les classes persistantes qui étendent cette classe ou implémente "
-"cette interface. La requête suivante retournera tous les objets persistants :"
+"cette interface. La requête suivante retournera tous les objets "
+"persistants : "
 
-#. Tag: programlisting
-#: query_hql.xml:406
-#, no-c-format
-msgid "<![CDATA[from java.lang.Object o]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:408
 #, no-c-format
 msgid ""
 "The interface <literal>Named</literal> might be implemented by various "
@@ -820,89 +546,53 @@
 "L'interface <literal>Named</literal> peut être implémentée par plusieurs "
 "classes persistantes :"
 
-#. Tag: programlisting
-#: query_hql.xml:413
-#, no-c-format
-msgid "<![CDATA[from Named n, Named m where n.name = m.name]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:415
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These last two queries will require more than one SQL <literal>SELECT</"
 "literal>. This means that the <literal>order by</literal> clause does not "
 "correctly order the whole result set. It also means you cannot call these "
 "queries using <literal>Query.scroll()</literal>."
 msgstr ""
-"Notez que ces deux dernières requêtes nécessitent plus d'un <literal>SELECT</"
-"literal> SQL. Ce qui signifie que la clause <literal>order by</literal> ne "
-"trie pas correctement la totalité des résultats (cela signifie aussi que "
-"vous ne pouvez exécuter ces requêtes en appelant <literal>Query.scroll()</"
-"literal>)."
+"Notez que ces deux dernières requêtes nécessitent plus d'un SQL "
+"<literal>SELECT</literal>. Ce qui signifie que la clause <literal>order by</"
+"literal> ne trie pas correctement la totalité des résultats (cela signifie "
+"aussi que vous ne pouvez exécuter ces requêtes en appelant <literal>Query."
+"scroll()</literal>). "
 
 #. Tag: title
-#: query_hql.xml:424
 #, no-c-format
 msgid "The where clause"
 msgstr "La clause where"
 
 #. Tag: para
-#: query_hql.xml:426
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>where</literal> clause allows you to refine the list of "
 "instances returned. If no alias exists, you can refer to properties by name:"
 msgstr ""
 "La clause <literal>where</literal> vous permet de réduire la liste des "
 "instances retournées. Si aucun alias n'existe, vous pouvez vous référer aux "
-"propriétés par leur nom :"
+"propriétés par leur nom : "
 
-#. Tag: programlisting
-#: query_hql.xml:431
-#, no-c-format
-msgid "<![CDATA[from Cat where name='Fritz']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:433
 #, no-c-format
 msgid "If there is an alias, use a qualified property name:"
 msgstr "S'il y a un alias, utilisez un nom de propriété qualifié :"
 
-#. Tag: programlisting
-#: query_hql.xml:437
-#, no-c-format
-msgid "<![CDATA[from Cat as cat where cat.name='Fritz']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:439
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This returns instances of <literal>Cat</literal> named 'Fritz'."
-msgstr ""
-"retourne les instances de <literal>Cat</literal> dont name est égale à "
-"'Fritz'."
+msgstr "Retourne les instances de <literal>Cat</literal> appelé  'Fritz'."
 
 #. Tag: para
-#: query_hql.xml:443
 #, no-c-format
 msgid "The following query:"
-msgstr ""
+msgstr "La requête suivante :"
 
-#. Tag: programlisting
-#: query_hql.xml:446
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select foo\n"
-"from Foo foo, Bar bar\n"
-"where foo.startDate = bar.date]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:448
-#, fuzzy, no-c-format
-msgid ""
 "returns all instances of <literal>Foo</literal> with an instance of "
 "<literal>bar</literal> with a <literal>date</literal> property equal to the "
 "<literal>startDate</literal> property of the <literal>Foo</literal>. "
@@ -911,253 +601,165 @@
 msgstr ""
 "retournera les instances de <literal>Foo</literal> pour lesquelles il existe "
 "une instance de <literal>bar</literal> avec la propriété <literal>date</"
-"literal> est égale à la propriété <literal>startDate</literal> de "
-"<literal>Foo</literal>. Les expressions utilisant la navigation rendent la "
-"clause <literal>where</literal> extrêmement puissante. Soit :"
+"literal> égale à la propriété <literal>startDate</literal> de <literal>Foo</"
+"literal>. Les expressions de chemin composées rendent la clause "
+"<literal>where</literal> extrêmement puissante. Soit : "
 
-#. Tag: programlisting
-#: query_hql.xml:457
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.mate.name is not null]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:459
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This query translates to an SQL query with a table (inner) join. For example:"
 msgstr ""
-"Cette requête se traduit en SQL par une jointure interne à une table. Si "
-"vous souhaitez écrire quelque chose comme :"
+"Cette requête se traduit en une requête SQL par une jointure interne de "
+"table. Si vous souhaitez écrire quelque chose comme :"
 
-#. Tag: programlisting
-#: query_hql.xml:464
-#, no-c-format
-msgid ""
-"<![CDATA[from Foo foo\n"
-"where foo.bar.baz.customer.address.city is not null]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:466
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "would result in a query that would require four table joins in SQL."
 msgstr ""
-"vous finiriez avec une requête qui nécessiterait quatre jointures en SQL."
+"vous finiriez avec une requête qui nécessiterait quatre jointures de table "
+"en SQL. "
 
 #. Tag: para
-#: query_hql.xml:470
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>=</literal> operator can be used to compare not only "
 "properties, but also instances:"
 msgstr ""
 "L'opérateur <literal>=</literal> peut être utilisé pour comparer aussi bien "
-"des propriétés que des instances :"
+"des propriétés que des instances : "
 
-#. Tag: programlisting
-#: query_hql.xml:475
-#, no-c-format
-msgid "<![CDATA[from Cat cat, Cat rival where cat.mate = rival.mate]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:477
-#, no-c-format
-msgid ""
-"<![CDATA[select cat, mate\n"
-"from Cat cat, Cat mate\n"
-"where cat.mate = mate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:479
 #, fuzzy, no-c-format
 msgid ""
 "The special property (lowercase) <literal>id</literal> can be used to "
 "reference the unique identifier of an object. See <xref linkend=\"queryhql-"
-"identifier-property\"/> for more information."
+"identifier-property\" /> for more information."
 msgstr ""
 "La propriété spéciale (en minuscule) <literal>id</literal> peut être "
-"utilisée pour faire référence à l'identifiant d'un objet (vous pouvez aussi "
-"utiliser le nom de cette propriété)."
+"utilisée pour référencer l'identifiant unique d'un objet. Pour plus "
+"d'informations, consultez <xref linkend=\"queryhql-identifier-property\" />."
 
-#. Tag: programlisting
-#: query_hql.xml:485
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat where cat.id = 123\n"
-"\n"
-"from Cat as cat where cat.mate.id = 69]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:487
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The second query is efficient and does not require a table join."
 msgstr ""
 "La seconde requête est particulièrement efficace. Aucune jointure n'est "
-"nécessaire !"
+"nécessaire ! "
 
 #. Tag: para
-#: query_hql.xml:491
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Properties of composite identifiers can also be used. Consider the following "
 "example where <literal>Person</literal> has composite identifiers consisting "
 "of <literal>country</literal> and <literal>medicareNumber</literal>:"
 msgstr ""
-"Les propriétés d'un identifiant composé peuvent aussi être utilisées. "
-"Supposez que <literal>Person</literal> ait un identifiant composé de "
-"<literal>country</literal> et <literal>medicareNumber</literal>."
+"Les propriétés d'identifiants composites peuvent aussi être utilisées. "
+"Supposez que <literal>Person</literal> ait un identifiant composite composé "
+"de  <literal>country</literal> et <literal>medicareNumber</literal>. "
 
-#. Tag: programlisting
-#: query_hql.xml:497
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[from bank.Person person\n"
-"where person.id.country = 'AU'\n"
-"    and person.id.medicareNumber = 123456]]>"
+msgid "Once again, the second query does not require a table join."
 msgstr ""
+"Une fois de plus, la seconde requête ne nécessite pas de jointure de table. "
 
-#. Tag: programlisting
-#: query_hql.xml:499
-#, no-c-format
-msgid ""
-"<![CDATA[from bank.Account account\n"
-"where account.owner.id.country = 'AU'\n"
-"    and account.owner.id.medicareNumber = 123456]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:501
 #, fuzzy, no-c-format
-msgid "Once again, the second query does not require a table join."
-msgstr "Une fois de plus, la seconde requête ne nécessite pas de jointure."
-
-#. Tag: para
-#: query_hql.xml:505
-#, no-c-format
 msgid ""
-"See <xref linkend=\"queryhql-identifier-property\"/> for more information "
+"See <xref linkend=\"queryhql-identifier-property\" /> for more information "
 "regarding referencing identifier properties)"
 msgstr ""
+"Voir <xref linkend=\"queryhql-identifier-property\" /> pour obtenir des "
+"informations supplémentaires sur le référencement de propriétés "
+"d'identifiant."
 
 #. Tag: para
-#: query_hql.xml:510
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The special property <literal>class</literal> accesses the discriminator "
 "value of an instance in the case of polymorphic persistence. A Java class "
 "name embedded in the where clause will be translated to its discriminator "
 "value."
 msgstr ""
-"De même, la propriété spéciale <literal>class</literal> interroge la valeur "
+"De même, la propriété spéciale <literal>class</literal> accède à la valeur "
 "discriminante d'une instance dans le cas d'une persistance polymorphique. Le "
 "nom d'une classe Java incorporée dans la clause where sera traduite par sa "
-"valeur discriminante."
+"valeur discriminante. "
 
-#. Tag: programlisting
-#: query_hql.xml:516
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.class = DomesticCat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:518
 #, fuzzy, no-c-format
 msgid ""
 "You can also use components or composite user types, or properties of said "
-"component types. See <xref linkend=\"queryhql-components\"/> for more "
+"component types. See <xref linkend=\"queryhql-components\" /> for more "
 "information."
 msgstr ""
-"Vous pouvez aussi spécifier les propriétés des composants ou types "
-"utilisateurs composés (components, composite user types etc). N'essayez "
-"jamais d'utiliser un expression de navigation qui se terminerait par une "
-"propriété de type composant (qui est différent d'une propriété d'un "
-"composant). Par exemple, si <literal>store.owner</literal> est une entité "
-"avec un composant <literal>address</literal>"
+"Vous pouvez également utiliser des composants ou des types d'utilisateur "
+"composites, ou des propriétés de types composant. Consultez <xref linkend="
+"\"queryhql-components\" /> pour plus d'informations. "
 
 #. Tag: para
-#: query_hql.xml:523
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An \"any\" type has the special properties <literal>id</literal> and "
 "<literal>class</literal> that allows you to express a join in the following "
 "way (where <literal>AuditLog.item</literal> is a property mapped with "
 "<literal>&lt;any&gt;</literal>):"
 msgstr ""
-"Un type \"any\" possède les propriétés spéciales <literal>id</literal> et "
-"<literal>class</literal>, qui nous permettent d'exprimer une jointure de la "
-"manière suivante (où <literal>AuditLog.item</literal> est une propriété "
-"mappée avec <literal>&lt;any&gt;</literal>)."
+"Un type \"any\" possède les propriétés particulières <literal>id</literal> "
+"et <literal>class</literal>, qui nous permettent d'exprimer une jointure de "
+"la manière suivante (là où <literal>AuditLog.item</literal> est une "
+"propriété mappée avec <literal>&lt;any&gt;</literal>) :"
 
-#. Tag: programlisting
-#: query_hql.xml:529
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from AuditLog log, Payment payment\n"
-"where log.item.class = 'Payment' and log.item.id = payment.id]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:531
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>log.item.class</literal> and <literal>payment.class</literal> "
 "would refer to the values of completely different database columns in the "
 "above query."
 msgstr ""
 "Dans la requête précédente, notez que <literal>log.item.class</literal> et "
 "<literal>payment.class</literal> feraient référence à des valeurs de "
-"colonnes de la base de données complètement différentes."
+"colonnes de la base de données complètement différentes. "
 
 #. Tag: title
-#: query_hql.xml:539
 #, no-c-format
 msgid "Expressions"
 msgstr "Expressions"
 
 #. Tag: para
-#: query_hql.xml:541
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Expressions used in the <literal>where</literal> clause include the "
 "following:"
 msgstr ""
-"Les expressions permises dans la clause <literal>where</literal> incluent la "
-"plupart des choses que vous pouvez utiliser en SQL :"
+"Les expressions permises dans la clause <literal>where</literal> incluent :"
 
 #. Tag: para
-#: query_hql.xml:548
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "mathematical operators: <literal>+, -, *, /</literal>"
-msgstr "opérateurs mathématiques <literal>+, -, *, /</literal>"
+msgstr "opérateurs mathématiques : <literal>+, -, *, /</literal> "
 
 #. Tag: para
-#: query_hql.xml:553
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "binary comparison operators: <literal>=, &gt;=, &lt;=, &lt;&gt;, !=, like</"
 "literal>"
 msgstr ""
-"opérateur de comparaison binaire <literal>=, &gt;=, &lt;=, &lt;&gt;, !=, "
+"opérateurs de comparaison binaire : <literal>=, &gt;=, &lt;=, &lt;&gt;, !=, "
 "like</literal>"
 
 #. Tag: para
-#: query_hql.xml:558
 #, no-c-format
 msgid "logical operations <literal>and, or, not</literal>"
-msgstr "opérateurs logiques <literal>and, or, not</literal>"
+msgstr "opérations logiques : <literal>and, or, not</literal>"
 
 #. Tag: para
-#: query_hql.xml:563
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Parentheses <literal>( )</literal> that indicates grouping"
-msgstr "Parenthèses <literal>( )</literal>, indiquant un regroupement"
+msgstr "Parenthèses <literal>( )</literal>, indiquant un regroupement "
 
 #. Tag: para
-#: query_hql.xml:568
 #, no-c-format
 msgid ""
 "<literal>in</literal>, <literal>not in</literal>, <literal>between</"
@@ -1168,41 +770,37 @@
 "<literal>in</literal>, <literal>not in</literal>, <literal>between</"
 "literal>, <literal>is null</literal>, <literal>is not null</literal>, "
 "<literal>is empty</literal>, <literal>is not empty</literal>, "
-"<literal>member of</literal> and <literal>not member of</literal>"
+"<literal>member of</literal> et <literal>not member of</literal>"
 
 #. Tag: para
-#: query_hql.xml:581
 #, no-c-format
 msgid ""
 "\"Simple\" case, <literal>case ... when ... then ... else ... end</literal>, "
 "and \"searched\" case, <literal>case when ... then ... else ... end</literal>"
 msgstr ""
-"\"Simple\" case, <literal>case ... when ... then ... else ... end</literal>, "
-"and \"searched\" case, <literal>case when ... then ... else ... end</literal>"
+"Cas simple <literal>case ... when ... then ... else ... end</literal>, et "
+"cas \"searched\", <literal>case when ... then ... else ... end</literal>"
 
 #. Tag: para
-#: query_hql.xml:587
 #, no-c-format
 msgid ""
 "string concatenation <literal>...||...</literal> or <literal>concat(...,...)"
 "</literal>"
 msgstr ""
-"concatenation de chaîne de caractères <literal>...||...</literal> ou "
+"concaténation de chaîne de caractères <literal>...||...</literal> ou "
 "<literal>concat(...,...)</literal>"
 
 #. Tag: para
-#: query_hql.xml:592
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>current_date()</literal>, <literal>current_time()</literal>, and "
 "<literal>current_timestamp()</literal>"
 msgstr ""
-"<literal>current_date()</literal>, <literal>current_time()</literal>, "
+"<literal>current_date()</literal>, <literal>current_time()</literal>, and "
 "<literal>current_timestamp()</literal>"
 
 #. Tag: para
-#: query_hql.xml:598
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>second(...)</literal>, <literal>minute(...)</literal>, <literal>hour"
 "(...)</literal>, <literal>day(...)</literal>, <literal>month(...)</literal>, "
@@ -1213,25 +811,22 @@
 "<literal>year(...)</literal>,"
 
 #. Tag: para
-#: query_hql.xml:605
 #, no-c-format
 msgid ""
 "Any function or operator defined by EJB-QL 3.0: <literal>substring(), trim"
 "(), lower(), upper(), length(), locate(), abs(), sqrt(), bit_length(), mod()"
 "</literal>"
 msgstr ""
-"N'importe quel fonction ou opérateur défini par EJB-QL 3.0 : "
+"N'importe quelle fonction ou opérateur défini par EJB-QL 3.0 : "
 "<literal>substring(), trim(), lower(), upper(), length(), locate(), abs(), "
 "sqrt(), bit_length(), mod()</literal>"
 
 #. Tag: para
-#: query_hql.xml:611
 #, no-c-format
 msgid "<literal>coalesce()</literal> and <literal>nullif()</literal>"
 msgstr "<literal>coalesce()</literal> et <literal>nullif()</literal>"
 
 #. Tag: para
-#: query_hql.xml:616
 #, no-c-format
 msgid ""
 "<literal>str()</literal> for converting numeric or temporal values to a "
@@ -1241,7 +836,6 @@
 "temporelles vers une chaîne de caractères lisible"
 
 #. Tag: para
-#: query_hql.xml:622
 #, no-c-format
 msgid ""
 "<literal>cast(... as ...)</literal>, where the second argument is the name "
@@ -1255,7 +849,6 @@
 "supportés par la base de données sous-jacente"
 
 #. Tag: para
-#: query_hql.xml:630
 #, no-c-format
 msgid ""
 "the HQL <literal>index()</literal> function, that applies to aliases of a "
@@ -1265,8 +858,7 @@
 "collection indexée jointe"
 
 #. Tag: para
-#: query_hql.xml:636
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL functions that take collection-valued path expressions: <literal>size(), "
 "minelement(), maxelement(), minindex(), maxindex()</literal>, along with the "
@@ -1274,52 +866,47 @@
 "functions that can be quantified using <literal>some, all, exists, any, in</"
 "literal>."
 msgstr ""
-"Les fonctions HQL qui s'appliquent expressions représentant des "
+"Les fonctions HQL qui prennent des expressions de chemin représentant des "
 "collections : <literal>size(), minelement(), maxelement(), minindex(), "
-"maxindex()</literal>, ainsi que les fonctions spéciales <literal>elements()</"
-"literal> et <literal>indices</literal> qui peuvent être quantifiées en "
-"utilisant <literal>some, all, exists, any, in</literal>."
+"maxindex()</literal>, ainsi que les fonctions particulières <literal>elements"
+"()</literal> et <literal>indices</literal> qui peuvent être quantifiées en "
+"utilisant <literal>some, all, exists, any, in</literal>. "
 
 #. Tag: para
-#: query_hql.xml:644
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Any database-supported SQL scalar function like <literal>sign()</literal>, "
 "<literal>trunc()</literal>, <literal>rtrim()</literal>, and <literal>sin()</"
 "literal>"
 msgstr ""
-"N'importe quelle fonction scalaire supportée par la base de données comme "
-"<literal>sign()</literal>, <literal>trunc()</literal>, <literal>rtrim()</"
-"literal>, <literal>sin()</literal>"
+"N'importe quelle fonction scalaire SQL supportée par la base de données "
+"comme <literal>sign()</literal>, <literal>trunc()</literal>, <literal>rtrim()"
+"</literal>, et <literal>sin()</literal>"
 
 #. Tag: para
-#: query_hql.xml:650
 #, no-c-format
 msgid "JDBC-style positional parameters <literal>?</literal>"
-msgstr "Les paramètres positionnels de JDBC <literal>?</literal>"
+msgstr "Les paramètres de position de JDBC <literal>?</literal>"
 
 #. Tag: para
-#: query_hql.xml:655
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "named parameters <literal>:name</literal>, <literal>:start_date</literal>, "
 "and <literal>:x1</literal>"
 msgstr ""
 "paramètres nommés <literal>:name</literal>, <literal>:start_date</literal>, "
-"<literal>:x1</literal>"
+"et <literal>:x1</literal>"
 
 #. Tag: para
-#: query_hql.xml:660
 #, no-c-format
 msgid ""
 "SQL literals <literal>'foo'</literal>, <literal>69</literal>, <literal>6.66E"
 "+2</literal>, <literal>'1970-01-01 10:00:01.0'</literal>"
 msgstr ""
-"littéral SQL <literal>'foo'</literal>, <literal>69</literal>, <literal>'1970-"
-"01-01 10:00:01.0'</literal>"
+"SQL textuel <literal>'foo'</literal>, <literal>69</literal>, <literal>6.66E"
+"+2</literal>, <literal>'1970-01-01 10:00:01.0'</literal>"
 
 #. Tag: para
-#: query_hql.xml:666
 #, no-c-format
 msgid ""
 "Java <literal>public static final</literal> constants <literal>eg.Color."
@@ -1329,77 +916,37 @@
 "TABBY</literal>"
 
 #. Tag: para
-#: query_hql.xml:672
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>in</literal> and <literal>between</literal> can be used as follows:"
 msgstr ""
 "<literal>in</literal> et <literal>between</literal> peuvent être utilisés "
-"comme suit :"
+"comme suit : "
 
-#. Tag: programlisting
-#: query_hql.xml:676
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name between 'A' and 'B']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:678
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat cat where cat.name in ( 'Foo', 'Bar', 'Baz' )]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:680
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The negated forms can be written as follows:"
-msgstr "et la forme négative peut être écrite"
+msgstr "Les formes négatives peuvent être écrites ainsi :"
 
-#. Tag: programlisting
-#: query_hql.xml:684
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name not between 'A' and 'B']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:686
-#, no-c-format
 msgid ""
-"<![CDATA[from DomesticCat cat where cat.name not in ( 'Foo', 'Bar', 'Baz' )]]"
-">"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:688
-#, fuzzy, no-c-format
-msgid ""
 "Similarly, <literal>is null</literal> and <literal>is not null</literal> can "
 "be used to test for null values."
 msgstr ""
 "De même, <literal>is null</literal> et <literal>is not null</literal> "
-"peuvent être utilisés pour tester les valeurs nulle."
+"peuvent être utilisés pour tester les valeurs nulles."
 
 #. Tag: para
-#: query_hql.xml:693
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Booleans can be easily used in expressions by declaring HQL query "
 "substitutions in Hibernate configuration:"
 msgstr ""
 "Les booléens peuvent être facilement utilisés en déclarant les substitutions "
-"de requêtes dans la configuration Hibernate :"
+"de requêtes HQL dans la configuration Hibernate : "
 
-#. Tag: programlisting
-#: query_hql.xml:698
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"hibernate.query.substitutions\">true 1, false 0</"
-"property>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:700
 #, no-c-format
 msgid ""
 "This will replace the keywords <literal>true</literal> and <literal>false</"
@@ -1410,37 +957,17 @@
 "literal> par <literal>1</literal> et <literal>0</literal> dans la traduction "
 "SQL du HQL suivant :"
 
-#. Tag: programlisting
-#: query_hql.xml:705
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.alive = true]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:707
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can test the size of a collection with the special property "
 "<literal>size</literal> or the special <literal>size()</literal> function."
 msgstr ""
-"Vous pouvez tester la taille d'une collection par la propriété spéciale "
-"<literal>size</literal>, ou la fonction spéciale <literal>size()</literal>."
+"Vous pouvez tester la taille d'une collection par la propriété particulière  "
+"<literal>size</literal>, ou la fonction spéciale <literal>size()</literal>. "
 
-#. Tag: programlisting
-#: query_hql.xml:712
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.kittens.size > 0]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:714
-#, no-c-format
-msgid "<![CDATA[from Cat cat where size(cat.kittens) > 0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:716
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For indexed collections, you can refer to the minimum and maximum indices "
 "using <literal>minindex</literal> and <literal>maxindex</literal> functions. "
@@ -1449,83 +976,28 @@
 "<literal>maxelement</literal> functions. For example:"
 msgstr ""
 "Pour les collections indexées, vous pouvez faire référence aux indices "
-"minimum et maximum en utilisant les fonctions <literal>minindex</literal> "
-"and <literal>maxindex</literal>. De manière similaire, vous pouvez faire "
-"référence aux éléments minimum et maximum d'une collection de type basiques "
+"minimum et maximum en utilisant les fonctions <literal>minindex</literal> et "
+"<literal>maxindex</literal>. De manière similaire, vous pouvez faire "
+"référence aux éléments minimum et maximum d'une collection de type basique "
 "en utilisant les fonctions <literal>minelement</literal> et "
-"<literal>maxelement</literal>."
+"<literal>maxelement</literal>. Par exemple : "
 
-#. Tag: programlisting
-#: query_hql.xml:724
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Calendar cal where maxelement(cal.holidays) > current_date]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:726
-#, no-c-format
-msgid "<![CDATA[from Order order where maxindex(order.items) > 100]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:728
-#, no-c-format
-msgid "<![CDATA[from Order order where minelement(order.items) > 10000]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:730
-#, fuzzy, no-c-format
-msgid ""
 "The SQL functions <literal>any, some, all, exists, in</literal> are "
 "supported when passed the element or index set of a collection "
 "(<literal>elements</literal> and <literal>indices</literal> functions) or "
 "the result of a subquery (see below):"
 msgstr ""
-"Les fonctions SQL <literal>any, some, all, exists, in</literal> supportent "
-"que leur soient passées l'élément, l'index d'une collection (fonctions "
-"<literal>elements</literal> et <literal>indices</literal>) ou le résultat "
-"d'une sous requête (voir ci dessous)."
+"Les fonctions SQL <literal>any, some, all, exists, in</literal> sont "
+"supportées quand l'élément ou l'ensemble des indexes d'une collection (les "
+"fonctions <literal>elements</literal> et <literal>indices</literal>) ou le "
+"résultat d'une sous requête sont passés (voir ci dessous) :"
 
-#. Tag: programlisting
-#: query_hql.xml:736
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select mother from Cat as mother, Cat as kit\n"
-"where kit in elements(foo.kittens)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:738
-#, no-c-format
-msgid ""
-"<![CDATA[select p from NameList list, Person p\n"
-"where p.name = some elements(list.names)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:740
-#, no-c-format
-msgid "<![CDATA[from Cat cat where exists elements(cat.kittens)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:742
-#, no-c-format
-msgid "<![CDATA[from Player p where 3 > all elements(p.scores)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:744
-#, no-c-format
-msgid "<![CDATA[from Show show where 'fizard' in indices(show.acts)]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:746
-#, fuzzy, no-c-format
-msgid ""
 "Note that these constructs - <literal>size</literal>, <literal>elements</"
 "literal>, <literal>indices</literal>, <literal>minindex</literal>, "
 "<literal>maxindex</literal>, <literal>minelement</literal>, "
@@ -1535,182 +1007,72 @@
 "Notez que l'écriture de - <literal>size</literal>, <literal>elements</"
 "literal>, <literal>indices</literal>, <literal>minindex</literal>, "
 "<literal>maxindex</literal>, <literal>minelement</literal>, "
-"<literal>maxelement</literal> - peuvent seulement être utilisée dans la "
-"clause where dans Hibernate3."
+"<literal>maxelement</literal> - peut seulement être utilisée dans la clause "
+"where dans Hibernate3. "
 
 #. Tag: para
-#: query_hql.xml:753
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Elements of indexed collections (arrays, lists, and maps) can be referred to "
 "by index in a where clause only:"
 msgstr ""
 "Les éléments de collections indexées (arrays, lists, maps) peuvent être "
-"référencés via index (dans une clause where seulement) :"
+"référencés via index dans une clause where seulement :"
 
-#. Tag: programlisting
-#: query_hql.xml:758
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from Order order where order.items[0].id = 1234]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:760
-#, no-c-format
 msgid ""
-"<![CDATA[select person from Person person, Calendar calendar\n"
-"where calendar.holidays['national day'] = person.birthDay\n"
-"    and person.nationality.calendar = calendar]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:762
-#, no-c-format
-msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ order.deliveredItemIndices[0] ] = item and order.id = 11]]"
-">"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:764
-#, no-c-format
-msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ maxindex(order.items) ] = item and order.id = 11]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:766
-#, fuzzy, no-c-format
-msgid ""
 "The expression inside <literal>[]</literal> can even be an arithmetic "
 "expression:"
 msgstr ""
 "L'expression entre <literal>[]</literal> peut même être une expression "
-"arithmétique."
+"arithmétique :"
 
-#. Tag: programlisting
-#: query_hql.xml:770
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ size(order.items) - 1 ] = item]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:772
-#, fuzzy, no-c-format
-msgid ""
 "HQL also provides the built-in <literal>index()</literal> function for "
 "elements of a one-to-many association or collection of values."
 msgstr ""
 "HQL propose aussi une fonction <literal>index()</literal> interne, pour les "
-"éléments d'une association one-to-many ou d'une collections de valeurs."
+"éléments d'une association un-à-plusieurs ou d'une collection de valeurs."
 
-#. Tag: programlisting
-#: query_hql.xml:777
-#, no-c-format
-msgid ""
-"<![CDATA[select item, index(item) from Order order\n"
-"    join order.items item\n"
-"where index(item) < 5]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:779
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Scalar SQL functions supported by the underlying database can be used:"
 msgstr ""
 "Les fonctions SQL scalaires supportées par la base de données utilisée "
-"peuvent être utilisées"
+"peuvent être utilisées :"
 
-#. Tag: programlisting
-#: query_hql.xml:783
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where upper(cat.name) like 'FRI%']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:785
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Consider how much longer and less readable the following query would be in "
 "SQL:"
 msgstr ""
 "Si vous n'êtes pas encore convaincu par tout cela, imaginez la taille et "
-"l'illisibilité qui caractériseraient la transformation SQL de la requête HQL "
-"suivante :"
+"l'illisibilité qui caractériseraient la requête suivante en SQL :"
 
-#. Tag: programlisting
-#: query_hql.xml:790
-#, no-c-format
-msgid ""
-"<![CDATA[select cust\n"
-"from Product prod,\n"
-"    Store store\n"
-"    inner join store.customers cust\n"
-"where prod.name = 'widget'\n"
-"    and store.location.name in ( 'Melbourne', 'Sydney' )\n"
-"    and prod = all elements(cust.currentOrder.lineItems)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:792
 #, no-c-format
 msgid "<emphasis>Hint:</emphasis> something like"
-msgstr "<emphasis>Un indice :</emphasis> cela donnerait quelque chose comme"
+msgstr "<emphasis>Un indice :</emphasis> cela donne quelque chose comme"
 
-#. Tag: programlisting
-#: query_hql.xml:796
-#, no-c-format
-msgid ""
-"<![CDATA[SELECT cust.name, cust.address, cust.phone, cust.id, cust."
-"current_order\n"
-"FROM customers cust,\n"
-"    stores store,\n"
-"    locations loc,\n"
-"    store_customers sc,\n"
-"    product prod\n"
-"WHERE prod.name = 'widget'\n"
-"    AND store.loc_id = loc.id\n"
-"    AND loc.name IN ( 'Melbourne', 'Sydney' )\n"
-"    AND sc.store_id = store.id\n"
-"    AND sc.cust_id = cust.id\n"
-"    AND prod.id = ALL(\n"
-"        SELECT item.prod_id\n"
-"        FROM line_items item, orders o\n"
-"        WHERE item.order_id = o.id\n"
-"            AND cust.current_order = o.id\n"
-"    )]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:801
 #, no-c-format
 msgid "The order by clause"
 msgstr "La clause order by"
 
 #. Tag: para
-#: query_hql.xml:803
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The list returned by a query can be ordered by any property of a returned "
 "class or components:"
 msgstr ""
-"La liste retounée par la requête peut être triée par n'importe quelle "
-"propriété de la classe ou du composant retourné :"
+"La liste retournée par la requête peut être triée par n'importe quelle "
+"propriété de la classe ou des composants retournés : "
 
-#. Tag: programlisting
-#: query_hql.xml:807
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat cat\n"
-"order by cat.name asc, cat.weight desc, cat.birthdate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:809
 #, no-c-format
 msgid ""
 "The optional <literal>asc</literal> or <literal>desc</literal> indicate "
@@ -1720,84 +1082,39 @@
 "respectivement si le tri doit être croissant ou décroissant."
 
 #. Tag: title
-#: query_hql.xml:816
 #, no-c-format
 msgid "The group by clause"
 msgstr "La clause group by"
 
 #. Tag: para
-#: query_hql.xml:818
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A query that returns aggregate values can be grouped by any property of a "
 "returned class or components:"
 msgstr ""
-"Si la requête retourne des valeurs aggrégées, celles ci peuvent être "
-"groupées par propriété ou composant :"
+"Si la requête retourne des valeurs agrégées, celles-ci peuvent être groupées "
+"par propriété d'une classe retournée ou par des composants : "
 
-#. Tag: programlisting
-#: query_hql.xml:822
-#, no-c-format
-msgid ""
-"<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
-"from Cat cat\n"
-"group by cat.color]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:824
-#, no-c-format
-msgid ""
-"<![CDATA[select foo.id, avg(name), max(name)\n"
-"from Foo foo join foo.names name\n"
-"group by foo.id]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:826
 #, no-c-format
 msgid "A <literal>having</literal> clause is also allowed."
 msgstr "Une clause <literal>having</literal> est aussi permise."
 
-#. Tag: programlisting
-#: query_hql.xml:830
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
-"from Cat cat\n"
-"group by cat.color\n"
-"having cat.color in (eg.Color.TABBY, eg.Color.BLACK)]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:832
-#, fuzzy, no-c-format
-msgid ""
 "SQL functions and aggregate functions are allowed in the <literal>having</"
 "literal> and <literal>order by</literal> clauses if they are supported by "
 "the underlying database (i.e., not in MySQL)."
 msgstr ""
-"Les fonctions SQL et les fonctions d'aggrégations sont permises dans les "
-"clauses <literal>having</literal> et <literal>order by</literal>, si elles "
-"sont supportées par la base de données (ce que ne fait pas MySQL par "
-"exemple)."
+"Les fonctions SQL et les fonctions d'agrégat sont permises dans les clauses "
+"<literal>having</literal> et <literal>order by</literal>, si elles sont "
+"prises en charge par la base de données sous-jacente (ce que ne fait pas "
+"MySQL par exemple). "
 
-#. Tag: programlisting
-#: query_hql.xml:838
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat\n"
-"from Cat cat\n"
-"    join cat.kittens kitten\n"
-"group by cat.id, cat.name, cat.other, cat.properties\n"
-"having avg(kitten.weight) > 100\n"
-"order by count(kitten) asc, sum(kitten.weight) desc]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:840
-#, fuzzy, no-c-format
-msgid ""
 "Neither the <literal>group by</literal> clause nor the <literal>order by</"
 "literal> clause can contain arithmetic expressions. Hibernate also does not "
 "currently expand a grouped entity, so you cannot write <literal>group by "
@@ -1805,16 +1122,18 @@
 "aggregated. You have to list all non-aggregated properties explicitly."
 msgstr ""
 "Notez que ni la clause <literal>group by</literal> ni la clause "
-"<literal>order by</literal> ne peuvent contenir d'expressions arithmétiques."
+"<literal>order by</literal> ne peuvent contenir d'expressions arithmétiques. "
+"Notez aussi qu'Hibernate ne développe pas actuellement une entité faisant "
+"partie du regroupement, donc vous ne pouvez pas écrire <literal>group by "
+"cat</literal> si toutes les propriétés de <literal>cat</literal> sont non-"
+"agrégées. Vous devez lister toutes les propriétés non-agrégées explicitement."
 
 #. Tag: title
-#: query_hql.xml:852
 #, no-c-format
 msgid "Subqueries"
 msgstr "Sous-requêtes"
 
 #. Tag: para
-#: query_hql.xml:854
 #, no-c-format
 msgid ""
 "For databases that support subselects, Hibernate supports subqueries within "
@@ -1822,87 +1141,37 @@
 "aggregate function call). Even correlated subqueries (subqueries that refer "
 "to an alias in the outer query) are allowed."
 msgstr ""
-"Pour les bases de données le supportant, Hibernate supporte les sous "
-"requêtes dans les requêtes. Une sous requête doit être entre parenthèses "
-"(souvent pour un appel à une fonction d'agrégation SQL) Même les sous "
-"requêtes corrélées (celles qui font référence à un alias de la requête "
-"principale) sont supportées."
+"Pour les bases de données supportant les sous-selects, Hibernate supporte "
+"les sous requêtes dans les requêtes. Une sous-requête doit être entre "
+"parenthèses (souvent pour un appel à une fonction d'agrégation SQL). Même "
+"les sous-requêtes corrélées (celles qui font référence à un alias de la "
+"requête principale) sont supportées."
 
-#. Tag: programlisting
-#: query_hql.xml:860
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as fatcat\n"
-"where fatcat.weight > (\n"
-"    select avg(cat.weight) from DomesticCat cat\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:862
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat as cat\n"
-"where cat.name = some (\n"
-"    select name.nickName from Name as name\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:864
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"where not exists (\n"
-"    from Cat as mate where mate.mate = cat\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:866
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat as cat\n"
-"where cat.name not in (\n"
-"    select name.nickName from Name as name\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:868
-#, no-c-format
-msgid ""
-"<![CDATA[select cat.id, (select max(kit.weight) from cat.kitten kit)\n"
-"from Cat as cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:870
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Note that HQL subqueries can occur only in the select or where clauses."
 msgstr ""
-"Notez que les sous-requêtes HQL peuvent arriver seulememnt dans les clauses "
-"select ou where."
+"Notez que les sous-requêtes HQL peuvent survenir uniquement dans les clauses "
+"select ou where. "
 
 #. Tag: para
-#: query_hql.xml:874
 #, fuzzy, no-c-format
 msgid ""
 "Note that subqueries can also utilize <literal>row value constructor</"
-"literal> syntax. See <xref linkend=\"queryhql-tuple\"/> for more information."
+"literal> syntax. See <xref linkend=\"queryhql-tuple\" /> for more "
+"information."
 msgstr ""
-"Note that subqueries can also utilize <literal>row value constructor</"
-"literal> syntax. See <xref linkend=\"queryhql-tuple\"/> for more details."
+"Notez que les sous-requêtes peuvent également utiliser la syntaxe "
+"<literal>row value constructor</literal>. Pour plus d'informations, "
+"consultez <xref linkend=\"queryhql-tuple\" />."
 
 #. Tag: title
-#: query_hql.xml:882
 #, no-c-format
 msgid "HQL examples"
 msgstr "Exemples HQL"
 
 #. Tag: para
-#: query_hql.xml:884
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate queries can be quite powerful and complex. In fact, the power of "
 "the query language is one of Hibernate's main strengths. The following "
@@ -1911,14 +1180,14 @@
 "than the following examples."
 msgstr ""
 "Les requêtes Hibernate peuvent être relativement puissantes et complexes. En "
-"fait, la puissance du langage de requêtage est l'un des avantages principaux "
-"d'Hibernate. Voici quelques exemples très similaires aux requêtes que nous "
-"avons utilisées lors d'un récent projet. Notez que la plupart des requêtes "
-"que vous écrirez seront plus simples que les exemples suivantes !"
+"fait, la puissance du langage d'interrogation est l'un des arguments "
+"principaux de vente de Hibernate. Voici quelques exemples très similaires "
+"aux requêtes que nous avons utilisées lors d'un récent projet. Notez que la "
+"plupart des requêtes que vous écrirez seront plus simples que les exemples "
+"qui suivent."
 
 #. Tag: para
-#: query_hql.xml:890
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following query returns the order id, number of items, the given minimum "
 "total value and the total value of the order for all unpaid orders for a "
@@ -1928,70 +1197,25 @@
 "<literal>PRODUCT</literal>, <literal>CATALOG</literal> and <literal>PRICE</"
 "literal> tables has four inner joins and an (uncorrelated) subselect."
 msgstr ""
-"La requête suivante retourne l'id de commande (order), le nombre d'articles "
-"(items) et la valeur totale de la commande (order) pour toutes les commandes "
-"non payées d'un client (customer) particulier pour un total minimum donné, "
-"le tout trié par la valeur totale. La requête SQL générée sur les tables "
+"La requête suivante retourne l'id de commande, le nombre d'articles et la "
+"valeur totale de la commande pour toutes les commandes non payées d'un "
+"client particulier pour une valeur totale minimum donnée, ces résultats "
+"étant triés par la valeur totale. La requête SQL générée sur les tables "
 "<literal>ORDER</literal>, <literal>ORDER_LINE</literal>, <literal>PRODUCT</"
 "literal>, <literal>CATALOG</literal> et <literal>PRICE</literal> est "
-"composée de quatre jointures interne ainsi que d'une sous-requête (non "
-"corrélée)."
+"composée de quatre jointures internes ainsi que d'un sous-select (non "
+"corrélé)."
 
-#. Tag: programlisting
-#: query_hql.xml:899
-#, no-c-format
-msgid ""
-"<![CDATA[select order.id, sum(price.amount), count(item)\n"
-"from Order as order\n"
-"    join order.lineItems as item\n"
-"    join item.product as product,\n"
-"    Catalog as catalog\n"
-"    join catalog.prices as price\n"
-"where order.paid = false\n"
-"    and order.customer = :customer\n"
-"    and price.product = product\n"
-"    and catalog.effectiveDate < sysdate\n"
-"    and catalog.effectiveDate >= all (\n"
-"        select cat.effectiveDate\n"
-"        from Catalog as cat\n"
-"        where cat.effectiveDate < sysdate\n"
-"    )\n"
-"group by order\n"
-"having sum(price.amount) > :minAmount\n"
-"order by sum(price.amount) desc]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:901
 #, no-c-format
 msgid ""
 "What a monster! Actually, in real life, I'm not very keen on subqueries, so "
 "my query was really more like this:"
 msgstr ""
-"Quel monstre ! En principe, nous ne sommes pas très fan des sous-requêtes, "
-"la requête ressemblait donc plutôt à cela :"
+"Quel monstre ! En principe, dans des situations réelles, nous n'approuvons "
+"pas les sous-requêtes, notre requête ressemblait donc plutôt à ce qui suit :"
 
-#. Tag: programlisting
-#: query_hql.xml:906
-#, no-c-format
-msgid ""
-"<![CDATA[select order.id, sum(price.amount), count(item)\n"
-"from Order as order\n"
-"    join order.lineItems as item\n"
-"    join item.product as product,\n"
-"    Catalog as catalog\n"
-"    join catalog.prices as price\n"
-"where order.paid = false\n"
-"    and order.customer = :customer\n"
-"    and price.product = product\n"
-"    and catalog = :currentCatalog\n"
-"group by order\n"
-"having sum(price.amount) > :minAmount\n"
-"order by sum(price.amount) desc]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:908
 #, no-c-format
 msgid ""
 "The next query counts the number of payments in each status, excluding all "
@@ -2001,61 +1225,25 @@
 "<literal>PAYMENT</literal>, <literal>PAYMENT_STATUS</literal> and "
 "<literal>PAYMENT_STATUS_CHANGE</literal> tables."
 msgstr ""
-"La requête suivante compte le nombre de paiements (payments) pour chaque "
-"status, en excluant les paiements dans le status <literal>AWAITING_APPROVAL</"
-"literal> où le changement de status le plus récent à été fait par "
-"l'utilisateur courant. En SQL, cette requête effectue deux jointures "
-"internes et des sous requêtes corrélées sur les tables <literal>PAYMENT</"
-"literal>, <literal>PAYMENT_STATUS</literal> et "
-"<literal>PAYMENT_STATUS_CHANGE</literal>."
+"La requête suivante compte le nombre de paiements pour chaque statut, en "
+"excluant tout paiement dans le statut <literal>AWAITING_APPROVAL</literal> "
+"où le changement de statut le plus récent à été fait par l'utilisateur "
+"courant. En SQL, cette requête effectue deux jointures internes et un sous-"
+"select corrélé sur les tables <literal>PAYMENT</literal>, "
+"<literal>PAYMENT_STATUS</literal> et <literal>PAYMENT_STATUS_CHANGE</"
+"literal>."
 
-#. Tag: programlisting
-#: query_hql.xml:916
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select count(payment), status.name\n"
-"from Payment as payment\n"
-"    join payment.currentStatus as status\n"
-"    join payment.statusChanges as statusChange\n"
-"where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-"    or (\n"
-"        statusChange.timeStamp = (\n"
-"            select max(change.timeStamp)\n"
-"            from PaymentStatusChange change\n"
-"            where change.payment = payment\n"
-"        )\n"
-"        and statusChange.user <> :currentUser\n"
-"    )\n"
-"group by status.name, status.sortOrder\n"
-"order by status.sortOrder]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:918
-#, fuzzy, no-c-format
-msgid ""
 "If the <literal>statusChanges</literal> collection was mapped as a list, "
 "instead of a set, the query would have been much simpler to write."
 msgstr ""
 "Si nous avions mappé la collection <literal>statusChanges</literal> comme "
-"une liste, au lieu d'un ensemble, la requête aurait été plus facile à écrire."
+"une liste, au lieu d'un ensemble, la requête aurait été plus facile à "
+"écrire. "
 
-#. Tag: programlisting
-#: query_hql.xml:923
-#, no-c-format
-msgid ""
-"<![CDATA[select count(payment), status.name\n"
-"from Payment as payment\n"
-"    join payment.currentStatus as status\n"
-"where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-"    or payment.statusChanges[ maxIndex(payment.statusChanges) ].user <> :"
-"currentUser\n"
-"group by status.name, status.sortOrder\n"
-"order by status.sortOrder]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:925
 #, no-c-format
 msgid ""
 "The next query uses the MS SQL Server <literal>isNull()</literal> function "
@@ -2066,187 +1254,93 @@
 "<literal>ACCOUNT_TYPE</literal>, <literal>ORGANIZATION</literal> and "
 "<literal>ORG_USER</literal> tables."
 msgstr ""
-"La requête qui suit utilise la fonction de MS SQL <literal>isNull()</"
-"literal> pour retourner tous les comptes (accounts) et paiements (payments) "
-"impayés pour l'organisation à laquelle l'uilisateur (user) courant "
-"appartient. Elle est traduite en SQL par trois jointures internes, une "
-"jointure externe ainsi qu'une sous requête sur les tables <literal>ACCOUNT</"
-"literal>, <literal>PAYMENT</literal>, <literal>PAYMENT_STATUS</literal>, "
+"La prochaine requête utilise la fonction de serveur MS SQL <literal>isNull()"
+"</literal> pour retourner tous les comptes et paiements impayés pour "
+"l'organisation à laquelle l'utilisateur courant appartient. Elle est "
+"traduite en SQL par trois jointures internes, une jointure externe ainsi "
+"qu'un sous-select sur les tables <literal>ACCOUNT</literal>, "
+"<literal>PAYMENT</literal>, <literal>PAYMENT_STATUS</literal>, "
 "<literal>ACCOUNT_TYPE</literal>, <literal>ORGANIZATION</literal> et "
 "<literal>ORG_USER</literal>."
 
-#. Tag: programlisting
-#: query_hql.xml:934
-#, no-c-format
-msgid ""
-"<![CDATA[select account, payment\n"
-"from Account as account\n"
-"    left outer join account.payments as payment\n"
-"where :currentUser in elements(account.holder.users)\n"
-"    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
-"PaymentStatus.UNPAID)\n"
-"order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:936
 #, no-c-format
 msgid ""
 "For some databases, we would need to do away with the (correlated) subselect."
 msgstr ""
-"Pour d'autres base de données, nous aurions dû faire sans la sous-requête "
-"(corrélée)."
+"Pour certaines bases de données, nous devons éliminer le sous-select "
+"(corrélé)."
 
-#. Tag: programlisting
-#: query_hql.xml:940
-#, no-c-format
-msgid ""
-"<![CDATA[select account, payment\n"
-"from Account as account\n"
-"    join account.holder.users as user\n"
-"    left outer join account.payments as payment\n"
-"where :currentUser = user\n"
-"    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
-"PaymentStatus.UNPAID)\n"
-"order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:945
 #, no-c-format
 msgid "Bulk update and delete"
-msgstr "Mise à jour et suppression"
+msgstr "Nombreuses mises à jour et suppressions "
 
 #. Tag: para
-#: query_hql.xml:947
 #, fuzzy, no-c-format
 msgid ""
 "HQL now supports <literal>update</literal>, <literal>delete</literal> and "
 "<literal>insert ... select ...</literal> statements. See <xref linkend="
-"\"batch-direct\"/> for more information."
+"\"batch-direct\" /> for more information."
 msgstr ""
 "HQL supporte maintenant les expressions <literal>update</literal>, "
 "<literal>delete</literal> et <literal>insert ... select ...</literal>. Voir "
-"<xref linkend=\"batch-direct\"/> pour les détails."
+"<xref linkend=\"batch-direct\" /> pour des informations plus détaillées."
 
 #. Tag: title
-#: query_hql.xml:955
 #, no-c-format
 msgid "Tips &amp; Tricks"
 msgstr "Trucs &amp; Astuces"
 
 #. Tag: para
-#: query_hql.xml:957
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can count the number of query results without returning them:"
 msgstr ""
-"Vous pouvez compter le nombre de résultats d'une requête sans les retourner :"
+"Vous pouvez compter le nombre de résultats d'une requête sans les "
+"retourner : "
 
-#. Tag: programlisting
-#: query_hql.xml:961
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
-"iterate().next() ).intValue()]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:963
 #, no-c-format
 msgid "To order a result by the size of a collection, use the following query:"
 msgstr ""
 "Pour trier les résultats par la taille d'une collection, utilisez la requête "
 "suivante :"
 
-#. Tag: programlisting
-#: query_hql.xml:967
-#, no-c-format
-msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User as usr\n"
-"    left join usr.messages as msg\n"
-"group by usr.id, usr.name\n"
-"order by count(msg)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:969
 #, no-c-format
 msgid ""
 "If your database supports subselects, you can place a condition upon "
 "selection size in the where clause of your query:"
 msgstr ""
-"Si votre base de données supporte les sous-requêtes, vous pouvez placer des "
+"Si votre base de données supporte les sous-selects, vous pouvez placer des "
 "conditions sur la taille de la sélection dans la clause where de votre "
-"requête:"
+"requête :"
 
-#. Tag: programlisting
-#: query_hql.xml:974
-#, no-c-format
-msgid "<![CDATA[from User usr where size(usr.messages) >= 1]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:976
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "If your database does not support subselects, use the following query:"
 msgstr ""
-"Si votre base de données ne supporte pas les sous-requêtes, utilisez la "
-"requête suivante :"
+"Si votre base de données ne supporte pas les sous-selects, utilisez la "
+"requête suivante : "
 
-#. Tag: programlisting
-#: query_hql.xml:980
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User usr.name\n"
-"    join usr.messages msg\n"
-"group by usr.id, usr.name\n"
-"having count(msg) >= 1]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:983
-#, fuzzy, no-c-format
-msgid ""
 "As this solution cannot return a <literal>User</literal> with zero messages "
 "because of the inner join, the following form is also useful:"
 msgstr ""
 "Cette solution ne peut pas retourner un <literal>User</literal> avec zéro "
 "message à cause de la jointure interne, la forme suivante peut donc être "
-"utile :"
+"utile : "
 
-#. Tag: programlisting
-#: query_hql.xml:988
-#, no-c-format
-msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User as usr\n"
-"    left join usr.messages as msg\n"
-"group by usr.id, usr.name\n"
-"having count(msg) = 0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:990
 #, no-c-format
 msgid "Properties of a JavaBean can be bound to named query parameters:"
 msgstr ""
 "Les propriétés d'un JavaBean peuvent être injectées dans les paramètres "
-"nommés d'un requête :"
+"nommés d'une requête :"
 
-#. Tag: programlisting
-#: query_hql.xml:994
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = s.createQuery(\"from foo Foo as foo where foo.name=:name "
-"and foo.size=:size\");\n"
-"q.setProperties(fooBean); // fooBean has getName() and getSize()\n"
-"List foos = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:996
 #, no-c-format
 msgid ""
 "Collections are pageable by using the <literal>Query</literal> interface "
@@ -2255,130 +1349,65 @@
 "Les collections sont paginables via l'utilisation de l'interface "
 "<literal>Query</literal> avec un filtre :"
 
-#. Tag: programlisting
-#: query_hql.xml:1000
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = s.createFilter( collection, \"\" ); // the trivial "
-"filter\n"
-"q.setMaxResults(PAGE_SIZE);\n"
-"q.setFirstResult(PAGE_SIZE * pageNumber);\n"
-"List page = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1002
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Collection elements can be ordered or grouped using a query filter:"
 msgstr ""
 "Les éléments d'une collection peuvent être triés ou groupés en utilisant un "
-"filtre de requête :"
+"filtre de requête : "
 
-#. Tag: programlisting
-#: query_hql.xml:1006
-#, no-c-format
-msgid ""
-"<![CDATA[Collection orderedCollection = s.filter( collection, \"order by "
-"this.amount\" );\n"
-"Collection counts = s.filter( collection, \"select this.type, count(this) "
-"group by this.type\" );]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1008
 #, no-c-format
 msgid "You can find the size of a collection without initializing it:"
 msgstr "Vous pouvez récupérer la taille d'une collection sans l'initialiser :"
 
-#. Tag: programlisting
-#: query_hql.xml:1012
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
-"iterate().next() ).intValue();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:1017
 #, no-c-format
 msgid "Components"
-msgstr "translator-credits"
+msgstr "Composants"
 
 #. Tag: para
-#: query_hql.xml:1019
 #, no-c-format
 msgid ""
 "Components can be used similarly to the simple value types that are used in "
 "HQL queries. They can appear in the <literal>select</literal> clause as "
 "follows:"
 msgstr ""
+"Les composants peuvent être utilisés dans presque tous les cas comme les "
+"types de valeur dans les requêtes HQL. Ils peuvent apparaître dans la clause "
+"<literal>select</literal> comme ce qui suit :"
 
-#. Tag: programlisting
-#: query_hql.xml:1024 query_hql.xml:1070
-#, no-c-format
-msgid "<![CDATA[select p.name from Person p]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1025
-#, no-c-format
-msgid "<![CDATA[select p.name.first from Person p]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1027
 #, no-c-format
 msgid ""
 "where the Person's name property is a component. Components can also be used "
 "in the <literal>where</literal> clause:"
 msgstr ""
+"où la propriété de nom de Person est un composant. Des composants peuvent "
+"aussi être utilisés dans la clause <literal>where</literal> :"
 
-#. Tag: programlisting
-#: query_hql.xml:1032
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name = :name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1033
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name.first = :firstName]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1035
 #, no-c-format
 msgid "Components can also be used in the <literal>order by</literal> clause:"
 msgstr ""
+"Des composants peuvent être utilisés dans la clause <literal>order by</"
+"literal> :"
 
-#. Tag: programlisting
-#: query_hql.xml:1039
-#, no-c-format
-msgid "<![CDATA[from Person p order by p.name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1040
-#, no-c-format
-msgid "<![CDATA[from Person p order by p.name.first]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1042
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Another common use of components is in <link linkend=\"queryhql-tuple\">row "
 "value constructors</link>."
 msgstr ""
+"Voici encore un usage commun des composants <xref linkend=\"queryhql-tuple"
+"\" />."
 
 #. Tag: title
-#: query_hql.xml:1048
 #, no-c-format
 msgid "Row value constructor syntax"
-msgstr ""
+msgstr "Syntaxe des constructeurs de valeur de ligne"
 
 #. Tag: para
-#: query_hql.xml:1050
 #, no-c-format
 msgid ""
 "HQL supports the use of ANSI SQL <literal>row value constructor</literal> "
@@ -2387,72 +1416,56 @@
 "generally referring to multi-valued comparisons, typically associated with "
 "components. Consider an entity Person which defines a name component:"
 msgstr ""
+"HQL supporte l'utilisation de la syntaxe <literal>row value constructor</"
+"literal> SQL ANSI (aussi appelée syntaxe <literal>tuple</literal>), bien que "
+"la base de données sous-jacente ne supporte pas nécessairement cette notion. "
+"Là, nous faisons généralement référence à des comparaisons multi-valuées, "
+"typiquement associées à des composants. Considérez une entité Person qui "
+"définit un composant de nom :"
 
-#. Tag: programlisting
-#: query_hql.xml:1057
-#, no-c-format
-msgid ""
-"<![CDATA[from Person p where p.name.first='John' and p.name."
-"last='Jingleheimer-Schmidt']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1059
 #, no-c-format
 msgid ""
 "That is valid syntax although it is a little verbose. You can make this more "
 "concise by using <literal>row value constructor</literal> syntax:"
 msgstr ""
+"Voici une syntaxe valide, bien que quelque peu fastidieuse. Pour la rendre "
+"plus concise, utilisez la syntaxe <literal>row value constructor</literal> :"
 
-#. Tag: programlisting
-#: query_hql.xml:1064
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name=('John', 'Jingleheimer-Schmidt')]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1066
 #, no-c-format
 msgid ""
 "It can also be useful to specify this in the <literal>select</literal> "
 "clause:"
 msgstr ""
+"Il est utile de spécifier cela dans la clause <literal>select</literal> :"
 
 #. Tag: para
-#: query_hql.xml:1072
 #, no-c-format
 msgid ""
 "Using <literal>row value constructor</literal> syntax can also be beneficial "
 "when using subqueries that need to compare against multiple values:"
 msgstr ""
+"Alternativement, utiliser la syntaxe <literal>row value constructor</"
+"literal> peut être avantageux quand vous utilisez des sous-requêtes "
+"nécessitant une comparaison avec des valeurs multiples : "
 
-#. Tag: programlisting
-#: query_hql.xml:1077
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"where not ( cat.name, cat.color ) in (\n"
-"    select cat.name, cat.color from DomesticCat cat\n"
-")]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1079
 #, no-c-format
 msgid ""
 "One thing to consider when deciding if you want to use this syntax, is that "
 "the query will be dependent upon the ordering of the component sub-"
 "properties in the metadata."
 msgstr ""
+"Si vous décidez d'utiliser cette syntaxe, il vous faudra prendre en "
+"considération le fait que la requête sera dépendante de la commande des sous-"
+"propriétés du composant dans les métadonnées. "
 
-#~ msgid ""
-#~ "Most of the time, you will need to assign an <emphasis>alias</emphasis>, "
-#~ "since you will want to refer to the <literal>Cat</literal> in other parts "
-#~ "of the query."
-#~ msgstr ""
-#~ "La plupart du temps, vous devrez assigner un <emphasis>alias</emphasis> "
-#~ "puisque vous voudrez faire référence à <literal>Cat</literal> dans "
-#~ "d'autres parties de la requête."
+#, fuzzy
+#~ msgid "left outer join"
+#~ msgstr "<literal>left outer join</literal> (jointure ouverte par la gauche)"
 
-#~ msgid "or as an actual typesafe Java object,"
-#~ msgstr "ou sous la forme d'un objet Java typé,"
+#, fuzzy
+#~ msgid "right outer join"
+#~ msgstr ""
+#~ "<literal>right outer join</literal> (jointure ouverte par la droite)"

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/query_sql.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/query_sql.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/query_sql.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,28 @@
+# translation of query_sql.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: query_sql\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-05 09:47+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: query_sql.xml:29
 #, no-c-format
 msgid "Native SQL"
 msgstr "SQL natif"
 
 #. Tag: para
-#: query_sql.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also express queries in the native SQL dialect of your database. "
 "This is useful if you want to utilize database-specific features such as "
@@ -30,29 +34,26 @@
 "base de données. Ceci est utile si vous souhaitez utiliser les "
 "fonctionnalités spécifiques de votre base de données comme le mot clé "
 "<literal>CONNECT</literal> d'Oracle. Cette fonctionnalité offre par ailleurs "
-"un moyen de migration plus propre et doux d'une application basée sur SQL/"
-"JDBC vers une application Hibernate."
+"un moyen de migration plus propre et doux d'une application basée "
+"directement sur SQL/JDBC vers Hibernate. "
 
 #. Tag: para
-#: query_sql.xml:37
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 allows you to specify handwritten SQL, including stored "
 "procedures, for all create, update, delete, and load operations."
 msgstr ""
-"Hibernate3 vous permet de spécifier du SQL écrit à la main (incluant les "
+"Hibernate3 vous permet de spécifier du SQL écrit à la main (y compris les "
 "procédures stockées) pour toutes les opérations de création, mise à jour, "
-"suppression et chargement."
+"suppression et chargement. "
 
 #. Tag: title
-#: query_sql.xml:41
 #, no-c-format
 msgid "Using a <literal>SQLQuery</literal>"
-msgstr "Utiliser une <literal>SQLQuery</literal>"
+msgstr "Utiliser une requête <literal>SQLQuery</literal>"
 
 #. Tag: para
-#: query_sql.xml:43
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Execution of native SQL queries is controlled via the <literal>SQLQuery</"
 "literal> interface, which is obtained by calling <literal>Session."
@@ -60,87 +61,62 @@
 "API for querying."
 msgstr ""
 "L'exécution des requêtes en SQL natif est contrôlée par l'interface "
-"<literal>SQLQuery</literal>, laquelle est obtenue en appelant "
-"<literal>Session.createSQLQuery()</literal>. Dans des cas extrêmement "
-"simples, nous pouvons utiliser la forme suivante :"
+"<literal>SQLQuery</literal>, qui est obtenue en appelant <literal>Session."
+"createSQLQuery()</literal>. Ce qui suit décrit comment utiliser cette API "
+"pour les requêtes."
 
 #. Tag: title
-#: query_sql.xml:49
 #, no-c-format
 msgid "Scalar queries"
-msgstr "Scalar queries"
+msgstr "Requêtes scalaires"
 
 #. Tag: para
-#: query_sql.xml:51
 #, no-c-format
 msgid "The most basic SQL query is to get a list of scalars (values)."
-msgstr "The most basic SQL query is to get a list of scalars (values)."
-
-#. Tag: programlisting
-#: query_sql.xml:54
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").list();\n"
-"sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").list();\n"
-"]]>"
 msgstr ""
+"La requête SQL la plus basique permet de récupérer une liste de (valeurs) "
+"scalaires."
 
 #. Tag: para
-#: query_sql.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These will return a List of Object arrays (Object[]) with scalar values for "
 "each column in the CATS table. Hibernate will use ResultSetMetadata to "
 "deduce the actual order and types of the returned scalar values."
 msgstr ""
-"These will both return a List of Object arrays (Object[]) with scalar values "
-"for each column in the CATS table. Hibernate will use ResultSetMetadata to "
-"deduce the actual order and types of the returned scalar values."
+"Ces deux requêtes retourneront un tableau d'objets (Object[]) avec les "
+"valeurs scalaires de chacune des colonnes de la table CATS. Hibernate "
+"utilisera le ResultSetMetadata pour déduire l'ordre final et le type des "
+"valeurs scalaires retournées. "
 
 #. Tag: para
-#: query_sql.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To avoid the overhead of using <literal>ResultSetMetadata</literal>, or "
 "simply to be more explicit in what is returned, one can use "
 "<literal>addScalar()</literal>:"
 msgstr ""
-"To avoid the overhead of using <literal>ResultSetMetadata</literal> or "
-"simply to be more explicit in what is returned one can use <literal>addScalar"
-"()</literal>."
+"Pour éviter l'overhead lié à <literal>ResultSetMetadata</literal> ou "
+"simplement pour être plus explicite dans ce qui est retourné, vous pouvez "
+"utiliser <literal>addScalar()</literal>. "
 
-#. Tag: programlisting
-#: query_sql.xml:65
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-" .addScalar(\"ID\", Hibernate.LONG)\n"
-" .addScalar(\"NAME\", Hibernate.STRING)\n"
-" .addScalar(\"BIRTHDATE\", Hibernate.DATE)\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:67 query_sql.xml:113 query_sql.xml:198 query_sql.xml:349
 #, no-c-format
 msgid "This query specified:"
-msgstr "This query specified:"
+msgstr "Cette requête spécifie :"
 
 #. Tag: para
-#: query_sql.xml:71 query_sql.xml:117 query_sql.xml:353
 #, no-c-format
 msgid "the SQL query string"
-msgstr "the SQL query string"
+msgstr "la chaîne de requêtes SQL"
 
 #. Tag: para
-#: query_sql.xml:75
 #, no-c-format
 msgid "the columns and types to return"
-msgstr "the columns and types to return"
+msgstr "les colonnes et les types retournés"
 
 #. Tag: para
-#: query_sql.xml:79
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This will return Object arrays, but now it will not use "
 "<literal>ResultSetMetadata</literal> but will instead explicitly get the ID, "
@@ -149,68 +125,53 @@
 "be returned, even though the query is using <literal>*</literal> and could "
 "return more than the three listed columns."
 msgstr ""
-"This will still return Object arrays, but now it will not use "
-"<literal>ResultSetMetdata</literal> but will instead explicitly get the ID, "
-"NAME and BIRTHDATE column as respectively a Long, String and a Short from "
-"the underlying resultset. This also means that only these three columns will "
-"be returned, even though the query is using <literal>*</literal> and could "
-"return more than the three listed columns."
+"Cela retournera toujours un tableau d'objets, mais sans utiliser le "
+"<literal>ResultSetMetdata</literal>. Il récupérera à la place explicitement "
+"les colonnes ID, NAME et BIRTHDATE comme étant respectivement de type Long, "
+"String et Short, depuis l'ensemble de résultats sous-jacent. Cela signifie "
+"aussi que seules ces trois colonnes seront retournées même si la requête "
+"utilise <literal>*</literal> et pourait retourner plus que les trois "
+"colonnes listées."
 
 #. Tag: para
-#: query_sql.xml:87
 #, no-c-format
 msgid ""
 "It is possible to leave out the type information for all or some of the "
 "scalars."
 msgstr ""
-"It is possible to leave out the type information for all or some of the "
-"scalars."
+"Il est possible de ne pas définir l'information sur le type pour toutes ou "
+"une partie des scalaires."
 
-#. Tag: programlisting
-#: query_sql.xml:90
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-" .addScalar(\"ID\", Hibernate.LONG)\n"
-" .addScalar(\"NAME\")\n"
-" .addScalar(\"BIRTHDATE\")\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:92
-#, fuzzy, no-c-format
-msgid ""
 "This is essentially the same query as before, but now "
 "<literal>ResultSetMetaData</literal> is used to determine the type of NAME "
 "and BIRTHDATE, where as the type of ID is explicitly specified."
 msgstr ""
-"This is essentially the same query as before, but now "
-"<literal>ResultSetMetaData</literal> is used to decide the type of NAME and "
-"BIRTHDATE where as the type of ID is explicitly specified."
+"Il s'agit essentiellement de la même requête que précédemment, mais le "
+"<literal>ResultSetMetaData</literal> est utilisé pour décider des types de "
+"NAME et BIRTHDATE alors que le type de ID est explicitement spécifié. "
 
 #. Tag: para
-#: query_sql.xml:96
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "How the java.sql.Types returned from ResultSetMetaData is mapped to "
 "Hibernate types is controlled by the Dialect. If a specific type is not "
 "mapped, or does not result in the expected type, it is possible to customize "
 "it via calls to <literal>registerHibernateType</literal> in the Dialect."
 msgstr ""
-"How the java.sql.Types returned from ResultSetMetaData is mapped to "
-"Hibernate types is controlled by the Dialect. If a specific type is not "
-"mapped or does not result in the expected type it is possible to customize "
-"it via calls to <literal>registerHibernateType</literal> in the Dialect."
+"Les java.sql.Types retournés par le ResultSetMetaData sont mappés aux types "
+"Hibernate via le Dialect. Si un type spécifique n'est pas mappé ou est mappé "
+"à un type non souhaité, il est possible de le personnaliser en invoquant "
+"<literal>registerHibernateType</literal> dans le Dialect. "
 
 #. Tag: title
-#: query_sql.xml:104
 #, no-c-format
 msgid "Entity queries"
-msgstr "Entity queries"
+msgstr "Requêtes d'entités"
 
 #. Tag: para
-#: query_sql.xml:106
 #, no-c-format
 msgid ""
 "The above queries were all about returning scalar values, basically "
@@ -218,41 +179,28 @@
 "get entity objects from a native sql query via <literal>addEntity()</"
 "literal>."
 msgstr ""
-"The above queries were all about returning scalar values, basically "
-"returning the \"raw\" values from the resultset. The following shows how to "
-"get entity objects from a native sql query via <literal>addEntity()</"
-"literal>."
+"Les requêtes précédentes ne retournaient que des valeurs scalaires, en ne "
+"retournant que les valeurs brutes de l'ensemble de résultats. Ce qui suit "
+"montre comment récupérer des entités depuis une requête native SQL, grâce à "
+"<literal>addEntity()</literal>."
 
-#. Tag: programlisting
-#: query_sql.xml:111
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").addEntity(Cat.class);\n"
-"sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").addEntity(Cat."
-"class);\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:121
 #, no-c-format
 msgid "the entity returned by the query"
-msgstr "the entity returned by the query"
+msgstr "L'entité retournée par la requête"
 
 #. Tag: para
-#: query_sql.xml:125
 #, no-c-format
 msgid ""
 "Assuming that Cat is mapped as a class with the columns ID, NAME and "
 "BIRTHDATE the above queries will both return a List where each element is a "
 "Cat entity."
 msgstr ""
-"Assuming that Cat is mapped as a class with the columns ID, NAME and "
-"BIRTHDATE the above queries will both return a List where each element is a "
-"Cat entity."
+"Avec Cat mappé comme classe avec les colonnes ID, NAME et BIRTHDATE, les "
+"requêtes précédentes retournent toutes deux, une liste où chaque élément est "
+"une entité Cat."
 
 #. Tag: para
-#: query_sql.xml:129
 #, no-c-format
 msgid ""
 "If the entity is mapped with a <literal>many-to-one</literal> to another "
@@ -262,36 +210,25 @@
 "but we prefer to be explicit as in the following example for a <literal>many-"
 "to-one</literal> to a <literal>Dog</literal>:"
 msgstr ""
-"If the entity is mapped with a <literal>many-to-one</literal> to another "
-"entity it is required to also return this when performing the native query, "
-"otherwise a database specific \"column not found\" error will occur. The "
-"additional columns will automatically be returned when using the * notation, "
-"but we prefer to be explicit as in the following example for a <literal>many-"
-"to-one</literal> to a <literal>Dog</literal>:"
+"Si l'entité est mappée avec un <literal>many-to-one</literal> vers une autre "
+"entité, il est requis de retourner aussi cette entité en exécutant la "
+"requête native, sinon une erreur \"column not found\" spécifique à la base "
+"de données sera soulevée. Les colonnes additionnelles seront automatiquement "
+"retournées en utilisant la notation *, mais nous préférons être explicites "
+"comme dans l'exemple suivant avec le <literal>many-to-one</literal> vers "
+"<literal>Dog</literal>:"
 
-#. Tag: programlisting
-#: query_sql.xml:137
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, DOG_ID FROM CATS"
-"\").addEntity(Cat.class);\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:139
 #, no-c-format
 msgid "This will allow cat.getDog() to function properly."
-msgstr "This will allow cat.getDog() to function properly."
+msgstr "Ceci permet à cat.getDog() de fonctionner normalement."
 
 #. Tag: title
-#: query_sql.xml:143
 #, no-c-format
 msgid "Handling associations and collections"
-msgstr "Handling associations and collections"
+msgstr "Gérer les associations et collections"
 
 #. Tag: para
-#: query_sql.xml:145
 #, no-c-format
 msgid ""
 "It is possible to eagerly join in the <literal>Dog</literal> to avoid the "
@@ -299,26 +236,14 @@
 "<literal>addJoin()</literal> method, which allows you to join in an "
 "association or collection."
 msgstr ""
-"It is possible to eagerly join in the <literal>Dog</literal> to avoid the "
-"possible extra roundtrip for initializing the proxy. This is done via the "
-"<literal>addJoin()</literal> method, which allows you to join in an "
-"association or collection."
+"Il est possible de charger agressivement <literal>Dog</literal> pour éviter "
+"le chargement de proxies c'est-à-dire un aller-retour supplémentaire vers la "
+"base de données. Ceci est effectué via la méthode <literal>addJoin()</"
+"literal>, qui vous permet de joindre une association ou collection."
 
-#. Tag: programlisting
-#: query_sql.xml:150
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT c.ID, NAME, BIRTHDATE, DOG_ID, D_ID, "
-"D_NAME FROM CATS c, DOGS d WHERE c.DOG_ID = d.D_ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addJoin(\"cat.dog\");\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:152
-#, fuzzy, no-c-format
-msgid ""
 "In this example, the returned <literal>Cat</literal>'s will have their "
 "<literal>dog</literal> property fully initialized without any extra "
 "roundtrip to the database. Notice that you added an alias name (\"cat\") to "
@@ -326,83 +251,59 @@
 "do the same eager joining for collections, e.g. if the <literal>Cat</"
 "literal> had a one-to-many to <literal>Dog</literal> instead."
 msgstr ""
-"In this example the returned <literal>Cat</literal>'s will have their "
-"<literal>dog</literal> property fully initialized without any extra "
-"roundtrip to the database. Notice that we added a alias name (\"cat\") to be "
-"able to specify the target property path of the join. It is possible to do "
-"the same eager joining for collections, e.g. if the <literal>Cat</literal> "
-"had a one-to-many to <literal>Dog</literal> instead."
+"Dans cet exemple, les <literal>Cat</literal> retournés auront leur propriété "
+"<literal>dog</literal> entièrement initialisée sans aucun aller-retour "
+"supplémentaire vers la base de données. Notez que nous avons ajouté un alias "
+"(\"cat\") pour être capable de spécifier le chemin de la propriété cible de "
+"la jointure. Il est possible de faire la même jointure agressive pour les "
+"collections, par ex. si le <literal>Cat</literal> a un un-à-plusieurs vers "
+"<literal>Dog</literal>. "
 
-#. Tag: programlisting
-#: query_sql.xml:160
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, D_ID, D_NAME, "
-"CAT_ID FROM CATS c, DOGS d WHERE c.ID = d.CAT_ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addJoin(\"cat.dogs\");\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:162
-#, fuzzy, no-c-format
-msgid ""
 "At this stage you are reaching the limits of what is possible with native "
 "queries, without starting to enhance the sql queries to make them usable in "
 "Hibernate. Problems can arise when returning multiple entities of the same "
 "type or when the default alias/column names are not enough."
 msgstr ""
-"At this stage we are reaching the limits of what is possible with native "
-"queries without starting to enhance the sql queries to make them usable in "
-"Hibernate; the problems starts to arise when returning multiple entities of "
-"the same type or when the default alias/column names are not enough."
+"À ce stade, nous arrivons aux limites de ce qui est possible avec les "
+"requêtes natives sans modifier les requêtes SQL pour les rendre utilisables "
+"par Hibernate; les problèmes surviennent lorsque nous essayons de retourner "
+"des entités du même type ou lorsque les alias/colonnes par défaut ne sont "
+"plus suffisants."
 
 #. Tag: title
-#: query_sql.xml:170
 #, no-c-format
 msgid "Returning multiple entities"
-msgstr "Returning multiple entities"
+msgstr "Retour d'entités multiples"
 
 #. Tag: para
-#: query_sql.xml:172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Until now, the result set column names are assumed to be the same as the "
 "column names specified in the mapping document. This can be problematic for "
 "SQL queries that join multiple tables, since the same column names can "
 "appear in more than one table."
 msgstr ""
-"Until now the result set column names are assumed to be the same as the "
-"column names specified in the mapping document. This can be problematic for "
-"SQL queries which join multiple tables, since the same column names may "
-"appear in more than one table."
+"Jusqu'à présent, les colonnes de l'ensemble de résultats sont supposées être "
+"les mêmes que les noms de colonnes spécifiés dans les documents de mapping. "
+"Ceci peut être problématique pour les requêtes SQL qui effectuent de "
+"multiples jointures vers différentes tables, puisque les mêmes colonnes "
+"peuvent apparaître dans plus d'une table. "
 
 #. Tag: para
-#: query_sql.xml:177
 #, no-c-format
 msgid ""
 "Column alias injection is needed in the following query (which most likely "
 "will fail):"
 msgstr ""
-"Column alias injection is needed in the following query (which most likely "
-"will fail):"
+"L'injection d'alias de colonne est requise pour la requête suivante (qui "
+"risque de ne pas fonctionner) :"
 
-#. Tag: programlisting
-#: query_sql.xml:180
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT c.*, m.*  FROM CATS c, CATS m WHERE c."
-"MOTHER_ID = c.ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addEntity(\"mother\", Cat.class)\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:184
-#, fuzzy, no-c-format
-msgid ""
 "The query was intended to return two Cat instances per row: a cat and its "
 "mother. The query will, however, fail because there is a conflict of names; "
 "the instances are mapped to the same column names. Also, on some databases "
@@ -410,49 +311,36 @@
 "NAME\", etc. which are not equal to the columns specified in the mappings "
 "(\"ID\" and \"NAME\")."
 msgstr ""
-"The intention for this query is to return two Cat instances per row, a cat "
-"and its mother. This will fail since there is a conflict of names since they "
-"are mapped to the same column names and on some databases the returned "
-"column aliases will most likely be on the form \"c.ID\", \"c.NAME\", etc. "
-"which are not equal to the columns specificed in the mappings (\"ID\" and "
-"\"NAME\")."
+"Le but de cette requête est de retourner deux instances de Cat par ligne, un "
+"chat et sa mère. Cela échouera puisqu'il y a conflit de noms puisqu'ils sont "
+"mappés au même nom de colonne et que sur certaines base de données, les "
+"alias de colonnes retournés seront plutôt de la forme \"c.ID\", \"c.NAME\", "
+"etc. qui ne sont pas égaux aux colonnes spécifiées dans les mappings (\"ID\" "
+"et \"NAME\"). "
 
 #. Tag: para
-#: query_sql.xml:193
 #, no-c-format
 msgid "The following form is not vulnerable to column name duplication:"
-msgstr "The following form is not vulnerable to column name duplication:"
-
-#. Tag: programlisting
-#: query_sql.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT {cat.*}, {mother.*}  FROM CATS c, CATS "
-"m WHERE c.MOTHER_ID = c.ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addEntity(\"mother\", Cat.class)\n"
-"]]>"
 msgstr ""
+"La forme suivante n'est pas vulnérable à la duplication des noms de "
+"colonnes :"
 
 #. Tag: para
-#: query_sql.xml:202
 #, no-c-format
 msgid ""
 "the SQL query string, with placeholders for Hibernate to inject column "
 "aliases"
 msgstr ""
-"the SQL query string, with placeholders for Hibernate to inject column "
-"aliases"
+"la requête SQL, avec des réceptacles pour que Hibernate injecte les alias de "
+"colonnes"
 
 #. Tag: para
-#: query_sql.xml:207
 #, no-c-format
 msgid "the entities returned by the query"
-msgstr "the entities returned by the query"
+msgstr "les entités retournées par la requête"
 
 #. Tag: para
-#: query_sql.xml:211
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The {cat.*} and {mother.*} notation used above is a shorthand for \"all "
 "properties\". Alternatively, you can list the columns explicitly, but even "
@@ -462,424 +350,304 @@
 "from a different table (cat_log) to the one declared in the mapping "
 "metadata. You can even use the property aliases in the where clause."
 msgstr ""
-"The {cat.*} and {mother.*} notation used above is a shorthand for \"all "
-"properties\". Alternatively, you may list the columns explicity, but even in "
-"this case we let Hibernate inject the SQL column aliases for each property. "
-"The placeholder for a column alias is just the property name qualified by "
-"the table alias. In the following example, we retrieve Cats and their "
-"mothers from a different table (cat_log) to the one declared in the mapping "
-"metadata. Notice that we may even use the property aliases in the where "
-"clause if we like."
+"Les notations {cat.*} et {mother.*} utilisées ci-dessus sont un équivalent à "
+"'toutes les propriétés'. Alternativement, vous pouvez lister les colonnes "
+"explicitement, mais même dans ce cas, nous laissons Hibernate injecter les "
+"alias de colonne pour chaque propriété. Le paramètre fictif pour un alias de "
+"colonne est simplement le nom de la propriété qualifié par l'alias de la "
+"table. Dans l'exemple suivant, nous récupérons les Cats et leur mère depuis "
+"une table différente (cat_log) de celle déclarée dans les mappages. Notez "
+"que nous pouvons aussi utiliser les alias de propriété dans la clause where "
+"si désiré. "
 
-#. Tag: programlisting
-#: query_sql.xml:220
-#, no-c-format
-msgid ""
-"<![CDATA[String sql = \"SELECT ID as {c.id}, NAME as {c.name}, \" + \n"
-"         \"BIRTHDATE as {c.birthDate}, MOTHER_ID as {c.mother}, {mother.*} "
-"\" +\n"
-"         \"FROM CAT_LOG c, CAT_LOG m WHERE {c.mother} = c.ID\";\n"
-"\n"
-"List loggedCats = sess.createSQLQuery(sql)\n"
-"        .addEntity(\"cat\", Cat.class)\n"
-"        .addEntity(\"mother\", Cat.class).list()\n"
-"]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:223
 #, no-c-format
 msgid "Alias and property references"
-msgstr "Alias and property references"
+msgstr "Références d'alias et de propriété"
 
 #. Tag: para
-#: query_sql.xml:225
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In most cases the above alias injection is needed. For queries relating to "
 "more complex mappings, like composite properties, inheritance "
 "discriminators, collections etc., you can use specific aliases that allow "
 "Hibernate to inject the proper aliases."
 msgstr ""
-"For most cases the above alias injection is needed, but for queries relating "
-"to more complex mappings like composite properties, inheritance "
-"discriminators, collections etc. there are some specific aliases to use to "
-"allow Hibernate to inject the proper aliases."
+"Pour la plupart des cas précédents, l'injection d'alias est requise, mais "
+"pour les requêtes relatives à des mappings plus complexes, comme les "
+"propriétés composites, les discriminants d'héritage, les collections etc., "
+"il y a des alias spécifiques à utiliser pour permettre à Hibernate "
+"l'injection des alias appropriés. "
 
 #. Tag: para
-#: query_sql.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table shows the different ways you can use the alias "
 "injection. Please note that the alias names in the result are simply "
 "examples; each alias will have a unique and probably different name when "
 "used."
 msgstr ""
-"The following table shows the different possibilities of using the alias "
-"injection. Note: the alias names in the result are examples, each alias will "
-"have a unique and probably different name when used."
+"Le tableau suivant montre les diverses possibilités d'utilisation "
+"d'injection d'alias. Note : les noms d'alias dans le résultat sont des "
+"exemples, chaque alias aura un nom unique et probablement différent "
+"lorsqu'ils seront utilisés. "
 
 #. Tag: title
-#: query_sql.xml:236
 #, no-c-format
 msgid "Alias injection names"
-msgstr "Alias injection names"
+msgstr "Nom d'injection d'alias"
 
 #. Tag: entry
-#: query_sql.xml:247
 #, no-c-format
 msgid "Description"
 msgstr "Description"
 
 #. Tag: entry
-#: query_sql.xml:249
 #, no-c-format
 msgid "Syntax"
-msgstr "Syntax"
+msgstr "Syntaxe"
 
 #. Tag: entry
-#: query_sql.xml:251
 #, no-c-format
 msgid "Example"
-msgstr "Example"
+msgstr "Exemple"
 
 #. Tag: entry
-#: query_sql.xml:257
 #, no-c-format
 msgid "A simple property"
-msgstr "A simple property"
+msgstr "Une propriété simple"
 
-#. Tag: literal
-#: query_sql.xml:259
-#, no-c-format
-msgid "{[aliasname].[propertyname]"
-msgstr "{[aliasname].[propertyname]"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].[propertyname]</literal>"
+msgstr "<literal>{[aliasname].[propertyname]</literal>"
 
-#. Tag: literal
-#: query_sql.xml:261
-#, no-c-format
-msgid "A_NAME as {item.name}"
-msgstr "A_NAME as {item.name}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>A_NAME as {item.name}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:265
 #, no-c-format
 msgid "A composite property"
-msgstr "A composite property"
+msgstr "Une propriété composite"
 
-#. Tag: literal
-#: query_sql.xml:267
-#, no-c-format
-msgid "{[aliasname].[componentname].[propertyname]}"
-msgstr "{[aliasname].[componentname].[propertyname]}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].[componentname].[propertyname]}</literal>"
+msgstr "<literal>{[aliasname].[componentname].[propertyname]}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:269
-#, no-c-format
-msgid "CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}"
-msgstr "CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}</"
+"literal>"
+msgstr ""
+"<literal>CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}</"
+"literal>"
 
 #. Tag: entry
-#: query_sql.xml:274
 #, no-c-format
 msgid "Discriminator of an entity"
-msgstr "Discriminator of an entity"
+msgstr "Discriminateur d'une entité"
 
-#. Tag: literal
-#: query_sql.xml:276
-#, no-c-format
-msgid "{[aliasname].class}"
-msgstr "{[aliasname].class}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].class}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:278
-#, no-c-format
-msgid "DISC as {item.class}"
-msgstr "DISC as {item.class}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>DISC as {item.class}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:282
 #, no-c-format
 msgid "All properties of an entity"
-msgstr "All properties of an entity"
+msgstr "Toutes les propriétés d'une entité"
 
-#. Tag: literal
-#: query_sql.xml:284 query_sql.xml:332
-#, no-c-format
-msgid "{[aliasname].*}"
-msgstr "{[aliasname].*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].*}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:286
+#. Tag: entry
 #, no-c-format
-msgid "{item.*}"
-msgstr "{item.*}"
+msgid "<literal>{item.*}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:290
 #, no-c-format
 msgid "A collection key"
-msgstr "A collection key"
+msgstr "La clé d'une collection"
 
-#. Tag: literal
-#: query_sql.xml:292
-#, no-c-format
-msgid "{[aliasname].key}"
-msgstr "{[aliasname].key}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].key}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:294
-#, no-c-format
-msgid "ORGID as {coll.key}"
-msgstr "ORGID as {coll.key}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>ORGID as {coll.key}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:298
 #, no-c-format
 msgid "The id of an collection"
-msgstr "The id of an collection"
+msgstr "L'id d'une collection"
 
-#. Tag: literal
-#: query_sql.xml:300
-#, no-c-format
-msgid "{[aliasname].id}"
-msgstr "{[aliasname].id}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].id}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:302
-#, no-c-format
-msgid "EMPID as {coll.id}"
-msgstr "EMPID as {coll.id}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>EMPID as {coll.id}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:306
 #, no-c-format
 msgid "The element of an collection"
-msgstr "The element of an collection"
+msgstr "L'élément d'une collection"
 
-#. Tag: literal
-#: query_sql.xml:308
-#, no-c-format
-msgid "{[aliasname].element}"
-msgstr "{[aliasname].element}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:310
-#, no-c-format
-msgid "XID as {coll.element}"
-msgstr "XID as {coll.element}"
-
 #. Tag: entry
-#: query_sql.xml:314
 #, fuzzy, no-c-format
-msgid "property of the element in the collection"
-msgstr "roperty of the element in the collection"
+msgid "<literal>XID as {coll.element}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:316
+#. Tag: entry
 #, no-c-format
-msgid "{[aliasname].element.[propertyname]}"
-msgstr "{[aliasname].element.[propertyname]}"
+msgid "property of the element in the collection"
+msgstr "Propriété de l'élément dans une collection "
 
-#. Tag: literal
-#: query_sql.xml:318
-#, no-c-format
-msgid "NAME as {coll.element.name}"
-msgstr "NAME as {coll.element.name}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element.[propertyname]}</literal>"
+msgstr "<literal>{[aliasname].element.[propertyname]}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:322
+#, fuzzy, no-c-format
+msgid "<literal>NAME as {coll.element.name}</literal>"
+msgstr "<literal>NAME as {coll.element.name}</literal>"
+
+#. Tag: entry
 #, no-c-format
 msgid "All properties of the element in the collection"
-msgstr "All properties of the element in the collection"
+msgstr "Toutes les propriétés d'un élément dans la collection"
 
-#. Tag: literal
-#: query_sql.xml:324
-#, no-c-format
-msgid "{[aliasname].element.*}"
-msgstr "{[aliasname].element.*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element.*}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:326
-#, no-c-format
-msgid "{coll.element.*}"
-msgstr "{coll.element.*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{coll.element.*}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:330
 #, no-c-format
 msgid "All properties of the the collection"
-msgstr "All properties of the the collection"
+msgstr "Toutes les propriétés d'une collection"
 
-#. Tag: literal
-#: query_sql.xml:334
+#. Tag: entry
 #, no-c-format
-msgid "{coll.*}"
-msgstr "{coll.*}"
+msgid "<literal>{coll.*}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: title
-#: query_sql.xml:343
 #, no-c-format
 msgid "Returning non-managed entities"
-msgstr "Returning non-managed entities"
+msgstr "Retour d'entités non gérées"
 
 #. Tag: para
-#: query_sql.xml:345
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to apply a ResultTransformer to native SQL queries, allowing "
 "it to return non-managed entities."
 msgstr ""
-"It is possible to apply a ResultTransformer to native sql queries. Allowing "
-"it to e.g. return non-managed entities."
+"Il est possible d'appliquer un ResultTransformer à une requête native SQL. "
+"Ce qui permet, par exemple, de retourner des entités non gérées. "
 
-#. Tag: programlisting
-#: query_sql.xml:347
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT NAME, BIRTHDATE FROM CATS\")\n"
-"        .setResultTransformer(Transformers.aliasToBean(CatDTO.class))]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:357
 #, no-c-format
 msgid "a result transformer"
-msgstr "a result transformer"
+msgstr "un transformateur de résultat"
 
 #. Tag: para
-#: query_sql.xml:361
 #, no-c-format
 msgid ""
 "The above query will return a list of <literal>CatDTO</literal> which has "
 "been instantiated and injected the values of NAME and BIRTHNAME into its "
 "corresponding properties or fields."
 msgstr ""
-"The above query will return a list of <literal>CatDTO</literal> which has "
-"been instantiated and injected the values of NAME and BIRTHNAME into its "
-"corresponding properties or fields."
+"La requête précédente retournera la liste de <literal>CatDTO</literal> qui "
+"ont été instanciés et dans lesquels les valeurs de NAME et BIRTHNAME auront "
+"été injectées dans leurs propriétés ou champs correspondants."
 
 #. Tag: title
-#: query_sql.xml:368
 #, no-c-format
 msgid "Handling inheritance"
-msgstr "Handling inheritance"
+msgstr "Gérer l'héritage"
 
 #. Tag: para
-#: query_sql.xml:370
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Native SQL queries which query for entities that are mapped as part of an "
 "inheritance must include all properties for the baseclass and all its "
 "subclasses."
 msgstr ""
-"Native sql queries which query for entities that is mapped as part of an "
-"inheritance must include all properties for the baseclass and all it "
-"subclasses."
+"Les requêtes natives SQL qui interrogent des entités mappées en tant que "
+"part d'un héritage doivent inclure toutes les propriétés de la classe de "
+"base et de toutes ses sous classes. "
 
 #. Tag: title
-#: query_sql.xml:376
 #, no-c-format
 msgid "Parameters"
-msgstr "Parameters"
+msgstr "Paramètres"
 
 #. Tag: para
-#: query_sql.xml:378
-#, fuzzy, no-c-format
-msgid "Native SQL queries support positional as well as named parameters:"
-msgstr "Native sql queries support positional as well as named parameters:"
-
-#. Tag: programlisting
-#: query_sql.xml:381
 #, no-c-format
-msgid ""
-"<![CDATA[Query query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME "
-"like ?\").addEntity(Cat.class);\n"
-"List pusList = query.setString(0, \"Pus%\").list();\n"
-"     \n"
-"query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME like :name\")."
-"addEntity(Cat.class);\n"
-"List pusList = query.setString(\"name\", \"Pus%\").list();          ]]>"
+msgid "Native SQL queries support positional as well as named parameters:"
 msgstr ""
+"Les requêtes natives SQL supportent aussi bien les paramètres de position "
+"que les paramètres nommés : "
 
 #. Tag: title
-#: query_sql.xml:389
 #, no-c-format
 msgid "Named SQL queries"
 msgstr "Requêtes SQL nommées"
 
 #. Tag: para
-#: query_sql.xml:391
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Named SQL queries can be defined in the mapping document and called in "
 "exactly the same way as a named HQL query. In this case, you do "
 "<emphasis>not</emphasis> need to call <literal>addEntity()</literal>."
 msgstr ""
 "Les requêtes SQL nommées peuvent être définies dans le document de mapping "
-"et appelées exactement de la même manière qu'un requête HQL nommée. Dans ce "
+"et appelées exactement de la même manière qu'une requête HQL nommée. Dans ce "
 "cas, nous <emphasis>n'avons pas besoin</emphasis> d'appeler "
-"<literal>addEntity()</literal>."
+"<literal>addEntity()</literal>. "
 
-#. Tag: programlisting
-#: query_sql.xml:396
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"persons\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex}\n"
-"    FROM PERSON person\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_sql.xml:398
-#, no-c-format
-msgid ""
-"<![CDATA[List people = sess.getNamedQuery(\"persons\")\n"
-"    .setString(\"namePattern\", namePattern)\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:400
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>&lt;return-join&gt;</literal> element is use to join "
 "associations and the <literal>&lt;load-collection&gt;</literal> element is "
 "used to define queries which initialize collections,"
 msgstr ""
 "Les éléments <literal>&lt;return-join&gt;</literal> et <literal>&lt;load-"
 "collection&gt;</literal> sont respectivement utilisés pour lier des "
-"associations et définir des requêtes qui initialisent des collections."
+"associations et définir des requêtes qui initialisent des collections,"
 
-#. Tag: programlisting
-#: query_sql.xml:404
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"personsWith\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex},\n"
-"           address.STREET AS {address.street},\n"
-"           address.CITY AS {address.city},\n"
-"           address.STATE AS {address.state},\n"
-"           address.ZIP AS {address.zip}\n"
-"    FROM PERSON person\n"
-"    JOIN ADDRESS address\n"
-"        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:406
 #, no-c-format
 msgid ""
 "A named SQL query may return a scalar value. You must declare the column "
@@ -890,23 +658,9 @@
 "spécifier l'alias de colonne et le type Hibernate utilisant l'élément "
 "<literal>&lt;return-scalar&gt;</literal> :"
 
-#. Tag: programlisting
-#: query_sql.xml:410
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-"    <return-scalar column=\"name\" type=\"string\"/>\n"
-"    <return-scalar column=\"age\" type=\"long\"/>\n"
-"    SELECT p.NAME AS name,\n"
-"           p.AGE AS age,\n"
-"    FROM PERSON p WHERE p.NAME LIKE 'Hiber%'\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:412
-#, fuzzy, no-c-format
-msgid ""
 "You can externalize the resultset mapping information in a <literal>&lt;"
 "resultset&gt;</literal> element which will allow you to either reuse them "
 "across several named queries or through the <literal>setResultSetMapping()</"
@@ -915,56 +669,18 @@
 "Vous pouvez externaliser les informations de mapping des résultats dans un "
 "élément <literal>&lt;resultset&gt;</literal> pour soit les réutiliser dans "
 "différentes requêtes nommées, soit à travers l'API "
-"<literal>setResultSetMapping()</literal>."
+"<literal>setResultSetMapping()</literal>. "
 
-#. Tag: programlisting
-#: query_sql.xml:417
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<resultset name=\"personAddress\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
-"</resultset>\n"
-"\n"
-"<sql-query name=\"personsWith\" resultset-ref=\"personAddress\">\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex},\n"
-"           address.STREET AS {address.street},\n"
-"           address.CITY AS {address.city},\n"
-"           address.STATE AS {address.state},\n"
-"           address.ZIP AS {address.zip}\n"
-"    FROM PERSON person\n"
-"    JOIN ADDRESS address\n"
-"        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:419
-#, fuzzy, no-c-format
-msgid ""
 "You can, alternatively, use the resultset mapping information in your hbm "
 "files directly in java code."
 msgstr ""
-"You can alternatively use the resultset mapping information in your hbm "
-"files directly in java code."
+"Vous pouvez également utiliser les informations de mapping de l'ensemble de "
+"résultats dans vos fichiers hbm directement dans le code java. "
 
-#. Tag: programlisting
-#: query_sql.xml:422
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createSQLQuery(\n"
-"        \"select {cat.*}, {kitten.*} from cats cat, cats kitten where kitten."
-"mother = cat.id\"\n"
-"    )\n"
-"    .setResultSetMapping(\"catAndKitten\")\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:425
 #, no-c-format
 msgid "Using return-property to explicitly specify column/alias names"
 msgstr ""
@@ -972,73 +688,32 @@
 "colonnes/alias"
 
 #. Tag: para
-#: query_sql.xml:428
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can explicitly tell Hibernate what column aliases to use with "
 "<literal>&lt;return-property&gt;</literal>, instead of using the <literal>{}"
 "</literal>-syntax to let Hibernate inject its own aliases.For example:"
 msgstr ""
 "Avec <literal>&lt;return-property&gt;</literal> vous pouvez explicitement "
-"dire à Hibernate quels alias de colonne utiliser, plutot que d'employer la "
+"dire à Hibernate quels alias de colonne utiliser, plutôt que d'employer la "
 "syntaxe <literal>{}</literal> pour laisser Hibernate injecter ses propres "
-"alias."
+"alias. Par exemple :"
 
-#. Tag: programlisting
-#: query_sql.xml:433
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-"    <return alias=\"person\" class=\"eg.Person\">\n"
-"        <return-property name=\"name\" column=\"myName\"/>\n"
-"        <return-property name=\"age\" column=\"myAge\"/>\n"
-"        <return-property name=\"sex\" column=\"mySex\"/>\n"
-"    </return>\n"
-"    SELECT person.NAME AS myName,\n"
-"           person.AGE AS myAge,\n"
-"           person.SEX AS mySex,\n"
-"    FROM PERSON person WHERE person.NAME LIKE :name\n"
-"</sql-query>\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:435
-#, fuzzy, no-c-format
-msgid ""
 "<literal>&lt;return-property&gt;</literal> also works with multiple columns. "
 "This solves a limitation with the <literal>{}</literal>-syntax which cannot "
 "allow fine grained control of multi-column properties."
 msgstr ""
-"<literal>&lt;return-property&gt;</literal> fonctionne aussi avec de multiple "
-"colonnes. Cela résout une limitation de la syntaxe <literal>{}</literal> qui "
-"ne peut pas permettre une bonne granularité des propriétés multi-colonnes."
+"<literal>&lt;return-property&gt;</literal> fonctionne aussi avec de "
+"multiples colonnes. Cela résout une limitation de la syntaxe <literal>{}</"
+"literal> qui ne permet pas une fine granularité des propriétés multi-"
+"colonnes. "
 
-#. Tag: programlisting
-#: query_sql.xml:440
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"organizationCurrentEmployments\">\n"
-"    <return alias=\"emp\" class=\"Employment\">\n"
-"        <return-property name=\"salary\">\n"
-"            <return-column name=\"VALUE\"/>\n"
-"            <return-column name=\"CURRENCY\"/>\n"
-"        </return-property>\n"
-"        <return-property name=\"endDate\" column=\"myEndDate\"/>\n"
-"    </return>\n"
-"        SELECT EMPLOYEE AS {emp.employee}, EMPLOYER AS {emp.employer},\n"
-"        STARTDATE AS {emp.startDate}, ENDDATE AS {emp.endDate},\n"
-"        REGIONCODE as {emp.regionCode}, EID AS {emp.id}, VALUE, CURRENCY\n"
-"        FROM EMPLOYMENT\n"
-"        WHERE EMPLOYER = :id AND ENDDATE IS NULL\n"
-"        ORDER BY STARTDATE ASC\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:442
-#, fuzzy, no-c-format
-msgid ""
 "In this example <literal>&lt;return-property&gt;</literal> was used in "
 "combination with the <literal>{}</literal>-syntax for injection. This allows "
 "users to choose how they want to refer column and properties."
@@ -1046,10 +721,9 @@
 "Notez que dans cet exemple nous avons utilisé <literal>&lt;return-"
 "property&gt;</literal> en combinaison avec la syntaxe <literal>{}</literal> "
 "pour l'injection. Cela autorise les utilisateurs à choisir comment ils "
-"veulent référencer les colonnes et les propriétés."
+"veulent référencer les colonnes et les propriétés. "
 
 #. Tag: para
-#: query_sql.xml:447
 #, no-c-format
 msgid ""
 "If your mapping has a discriminator you must use <literal>&lt;return-"
@@ -1059,14 +733,12 @@
 "discriminator&gt;</literal> pour spécifier la colonne discriminante."
 
 #. Tag: title
-#: query_sql.xml:453
 #, no-c-format
 msgid "Using stored procedures for querying"
 msgstr "Utilisation de procédures stockées pour les requêtes"
 
 #. Tag: para
-#: query_sql.xml:455
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 provides support for queries via stored procedures and functions. "
 "Most of the following documentation is equivalent for both. The stored "
@@ -1074,81 +746,38 @@
 "able to work with Hibernate. An example of such a stored function in Oracle "
 "9 and higher is as follows:"
 msgstr ""
-"Hibernate 3 introduit le support des requêtes via procédures stockées et les "
-"fonctions. La documentation suivante est valable pour les deux. Les "
-"procédures stockées/fonctions doivent retourner l'ensemble de résultats en "
-"tant que premier paramètre sortant (NdT: \"out-parameter\") pour être "
-"capable de fonctionner avec Hibernate. Un exemple d'une telle procédure "
-"stockée en Oracle 9 et version supérieure :"
+"Hibernate 3 introduit le support des requêtes via les procédures stockées et "
+"les fonctions. La documentation suivante est valable pour les deux. Les "
+"procédures stockées/fonctions doivent retourner un ensemble de résultats en "
+"tant que premier paramètre sortant (out-parameter\") pour être capable de "
+"fonctionner avec Hibernate. Voici un exemple d'une telle procédure stockée "
+"en Oracle 9 et version supérieure : "
 
-#. Tag: programlisting
-#: query_sql.xml:461
-#, no-c-format
-msgid ""
-"<![CDATA[CREATE OR REPLACE FUNCTION selectAllEmployments\n"
-"    RETURN SYS_REFCURSOR\n"
-"AS\n"
-"    st_cursor SYS_REFCURSOR;\n"
-"BEGIN\n"
-"    OPEN st_cursor FOR\n"
-" SELECT EMPLOYEE, EMPLOYER,\n"
-" STARTDATE, ENDDATE,\n"
-" REGIONCODE, EID, VALUE, CURRENCY\n"
-" FROM EMPLOYMENT;\n"
-"      RETURN  st_cursor;\n"
-" END;]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:463
 #, no-c-format
 msgid "To use this query in Hibernate you need to map it via a named query."
 msgstr ""
 "Pour utiliser cette requête dans Hibernate vous avez besoin de la mapper via "
 "une requête nommée."
 
-#. Tag: programlisting
-#: query_sql.xml:466
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"selectAllEmployees_SP\" callable=\"true\">\n"
-"    <return alias=\"emp\" class=\"Employment\">\n"
-"        <return-property name=\"employee\" column=\"EMPLOYEE\"/>\n"
-"        <return-property name=\"employer\" column=\"EMPLOYER\"/>\n"
-"        <return-property name=\"startDate\" column=\"STARTDATE\"/>\n"
-"        <return-property name=\"endDate\" column=\"ENDDATE\"/>\n"
-"        <return-property name=\"regionCode\" column=\"REGIONCODE\"/>\n"
-"        <return-property name=\"id\" column=\"EID\"/>\n"
-"        <return-property name=\"salary\">\n"
-"            <return-column name=\"VALUE\"/>\n"
-"            <return-column name=\"CURRENCY\"/>\n"
-"        </return-property>\n"
-"    </return>\n"
-"    { ? = call selectAllEmployments() }\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:468
-#, fuzzy, no-c-format
-msgid ""
 "Stored procedures currently only return scalars and entities. <literal>&lt;"
 "return-join&gt;</literal> and <literal>&lt;load-collection&gt;</literal> are "
 "not supported."
 msgstr ""
-"Notez que les procédures stockées retournent, pour le moment, seulement des "
+"Notez que les procédures stockées ne retournent, pour le moment, que des "
 "scalaires et des entités. <literal>&lt;return-join&gt;</literal> et "
-"<literal>&lt;load-collection&gt;</literal> ne sont pas supportés."
+"<literal>&lt;load-collection&gt;</literal> ne sont pas supportés. "
 
 #. Tag: title
-#: query_sql.xml:473
 #, no-c-format
 msgid "Rules/limitations for using stored procedures"
 msgstr "Règles/limitations lors de l'utilisation des procédures stockées"
 
 #. Tag: para
-#: query_sql.xml:475
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You cannot use stored procedures with Hibernate unless you follow some "
 "procedure/function rules. If they do not follow those rules they are not "
@@ -1157,45 +786,42 @@
 "different for each database, since database vendors have different stored "
 "procedure semantics/syntax."
 msgstr ""
-"Pur utiliser des procédures stockées avec Hibernate, les procédures doivent "
+"Pour utiliser des procédures stockées avec Hibernate, les procédures doivent "
 "suivre certaines règles. Si elles ne suivent pas ces règles, elles ne sont "
-"pas utilisables avec Hibernate. Si vous voulez encore utiliser ces "
+"pas utilisables avec Hibernate. Si néanmoins, vous désirez utiliser ces "
 "procédures vous devez les exécuter via <literal>session.connection()</"
 "literal>. Les règles sont différentes pour chaque base de données, puisque "
 "les vendeurs de base de données ont des sémantiques/syntaxes différentes "
-"pour les procédures stockées."
+"pour les procédures stockées. "
 
 #. Tag: para
-#: query_sql.xml:482
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Stored procedure queries cannot be paged with <literal>setFirstResult()/"
 "setMaxResults()</literal>."
 msgstr ""
 "Les requêtes de procédures stockées ne peuvent pas être paginées avec "
-"<literal>setFirstResult()/setMaxResults()</literal>."
+"<literal>setFirstResult()/setMaxResults()</literal>. "
 
 #. Tag: para
-#: query_sql.xml:485
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The recommended call form is standard SQL92: <literal>{ ? = call functionName"
 "(&lt;parameters&gt;) }</literal> or <literal>{ ? = call procedureName(&lt;"
 "parameters&gt;}</literal>. Native call syntax is not supported."
 msgstr ""
-"Recommended call form is standard SQL92: <literal>{ ? = call functionName"
-"(&lt;parameters&gt;) }</literal> or <literal>{ ? = call procedureName(&lt;"
-"parameters&gt;}</literal>. Native call syntax is not supported."
+"La forme d'appel recommandée est le SQL92 standard : <literal>{ ? = call "
+"functionName(&lt;parameters&gt;) }</literal> or <literal>{ ? = call "
+"procedureName(&lt;parameters&gt;}</literal>. La syntaxe d'appel native n'est "
+"pas supportée."
 
 #. Tag: para
-#: query_sql.xml:490
 #, no-c-format
 msgid "For Oracle the following rules apply:"
-msgstr "Pour Oracle les règles suivantes s'appliquent :"
+msgstr "Pour Oracle les règles suivantes sont applicables :"
 
 #. Tag: para
-#: query_sql.xml:494
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A function must return a result set. The first parameter of a procedure must "
 "be an <literal>OUT</literal> that returns a result set. This is done by "
@@ -1203,21 +829,19 @@
 "you need to define a <literal>REF CURSOR</literal> type. See Oracle "
 "literature for further information."
 msgstr ""
-"La procédure doit retourner un ensemble de résultats. Le prmeier paramètre "
+"La procédure doit retourner un ensemble de résultats. Le premier paramètre "
 "d'une procédure doit être un <literal>OUT</literal> qui retourne un ensemble "
-"de résultats. Ceci est fait en retournant un <literal>SYS_REFCURSOR</"
+"de résultats. Ceci est effectué en retournant un <literal>SYS_REFCURSOR</"
 "literal> dans Oracle 9 ou 10. Dans Oracle vous avez besoin de définir un "
-"type <literal>REF CURSOR</literal>."
+"type <literal>REF CURSOR</literal>, consultez la documentation Oracle. "
 
 #. Tag: para
-#: query_sql.xml:503
 #, no-c-format
 msgid "For Sybase or MS SQL server the following rules apply:"
-msgstr "Pour Sybase ou MS SQL server les règles suivantes s'appliquent :"
+msgstr "Pour Sybase ou MS SQL server les règles suivantes sont applicables :"
 
 #. Tag: para
-#: query_sql.xml:507
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The procedure must return a result set. Note that since these servers can "
 "return multiple result sets and update counts, Hibernate will iterate the "
@@ -1226,12 +850,11 @@
 msgstr ""
 "La procédure doit retourner un ensemble de résultats. Notez que comme ces "
 "serveurs peuvent retourner de multiples ensembles de résultats et mettre à "
-"jour des compteurs, Hibernate itérera les résultats et prendra le premier "
-"résultat qui est un ensemble de résultat comme valeur de retour. Tout le "
-"reste sera ignoré."
+"jour des compteurs, Hibernate itèrera les résultats et prendra le premier "
+"résultat qui est un ensemble de résultats comme valeur de retour. Tout le "
+"reste sera ignoré. "
 
 #. Tag: para
-#: query_sql.xml:515
 #, no-c-format
 msgid ""
 "If you can enable <literal>SET NOCOUNT ON</literal> in your procedure it "
@@ -1242,61 +865,49 @@
 "obligation."
 
 #. Tag: title
-#: query_sql.xml:525
 #, no-c-format
 msgid "Custom SQL for create, update and delete"
 msgstr "SQL personnalisé pour créer, mettre à jour et effacer"
 
 #. Tag: para
-#: query_sql.xml:527
 #, no-c-format
 msgid ""
-"Hibernate3 can use custom SQL statements for create, update, and delete "
-"operations. The class and collection persisters in Hibernate already contain "
-"a set of configuration time generated strings (insertsql, deletesql, "
-"updatesql etc.). The mapping tags <literal>&lt;sql-insert&gt;</literal>, "
-"<literal>&lt;sql-delete&gt;</literal>, and <literal>&lt;sql-update&gt;</"
-"literal> override these strings:"
+"Hibernate3 can use custom SQL for create, update, and delete operations. The "
+"SQL can be overridden at the statement level or inidividual column level. "
+"This section describes statement overrides. For columns, see <xref linkend="
+"\"mapping-column-read-and-write\" />."
 msgstr ""
-"Hibernate3 peut utiliser des expression SQL personnalisées pour des "
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"The class and collection persisters in Hibernate already contain a set of "
+"configuration time generated strings (insertsql, deletesql, updatesql etc.). "
+"The mapping tags <literal>&lt;sql-insert&gt;</literal>, <literal>&lt;sql-"
+"delete&gt;</literal>, and <literal>&lt;sql-update&gt;</literal> override "
+"these strings:"
+msgstr ""
+"Hibernate3 peut utiliser des expressions SQL personnalisées pour des "
 "opérations de création, de mise à jour, et de suppression. Les objets "
 "persistants les classes et les collections dans Hibernate contiennent déjà "
 "un ensemble de chaînes de caractères générées lors de la configuration "
-"(insertsql, deletesql, updatesql, etc). Les tages de mapping <literal>&lt;"
+"(insertsql, deletesql, updatesql, etc). Les balises de mappage <literal>&lt;"
 "sql-insert&gt;</literal>, <literal>&lt;sql-delete&gt;</literal>, et "
 "<literal>&lt;sql-update&gt;</literal> surchargent ces chaînes de caractères :"
 
-#. Tag: programlisting
-#: query_sql.xml:535
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <sql-insert>INSERT INTO PERSON (NAME, ID) VALUES ( UPPER(?), ? )</sql-"
-"insert>\n"
-"    <sql-update>UPDATE PERSON SET NAME=UPPER(?) WHERE ID=?</sql-update>\n"
-"    <sql-delete>DELETE FROM PERSON WHERE ID=?</sql-delete>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:537
-#, fuzzy, no-c-format
-msgid ""
 "The SQL is directly executed in your database, so you can use any dialect "
 "you like. This will reduce the portability of your mapping if you use "
 "database specific SQL."
 msgstr ""
 "Le SQL est directement exécuté dans votre base de données, donc vous êtes "
 "libre d'utiliser le dialecte que vous souhaitez. Cela réduira bien sûr la "
-"portabilité de votre mapping si vous utilisez du SQL spécifique à votre base "
-"de données."
+"portabilité de votre mappage si vous utilisez du SQL spécifique à votre base "
+"de données. "
 
 #. Tag: para
-#: query_sql.xml:541
 #, no-c-format
 msgid ""
 "Stored procedures are supported if the <literal>callable</literal> attribute "
@@ -1305,35 +916,17 @@
 "Les procédures stockées sont supportées si l'attribut <literal>callable</"
 "literal> est paramétré :"
 
-#. Tag: programlisting
-#: query_sql.xml:544
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <sql-insert callable=\"true\">{call createPerson (?, ?)}</sql-insert>\n"
-"    <sql-delete callable=\"true\">{? = call deletePerson (?)}</sql-delete>\n"
-"    <sql-update callable=\"true\">{? = call updatePerson (?, ?)}</sql-"
-"update>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:546
-#, fuzzy, no-c-format
-msgid ""
 "The order of the positional parameters is vital, as they must be in the same "
 "sequence as Hibernate expects them."
 msgstr ""
-"L'ordre des paramètres positionnels est actuellement vital, car ils doivent "
-"être dans la même séquence qu'Hibernate les attend."
+"L'ordre des paramètres de position est essentiel, car ils doivent être dans "
+"la séquence attendue par Hibernate. "
 
 #. Tag: para
-#: query_sql.xml:549
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can view the expected order by enabling debug logging for the "
 "<literal>org.hibernate.persister.entity</literal> level. With this level "
@@ -1342,17 +935,16 @@
 "your custom SQL in the mapping files, as this will override the Hibernate "
 "generated static SQL."
 msgstr ""
-"Vous pouvez voir l'ordre attendu en activant les journaux de debug pour le "
-"niveau <literal>org.hibernate.persister.entity</literal> level. Avec ce "
+"Vous pouvez voir l'ordre attendu en activant la journalisation de débogage "
+"pour le niveau <literal>org.hibernate.persister.entity</literal>. Avec ce "
 "niveau activé, Hibernate imprimera le SQL statique qui est utilisé pour "
-"créer, mettre à jour, supprimer, etc. des entités. (Pour voir la séquence "
+"créer, mettre à jour, supprimer, etc. des entités. Pour voir la séquence "
 "attendue, rappelez-vous de ne pas inclure votre SQL personnalisé dans les "
-"fichiers de mapping de manière à surcharger le SQL statique généré par "
-"Hibernate.)"
+"fichiers de mappage car cela surchargera le SQL statique généré par "
+"Hibernate."
 
 #. Tag: para
-#: query_sql.xml:556
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The stored procedures are in most cases required to return the number of "
 "rows inserted, updated and deleted, as Hibernate has some runtime checks for "
@@ -1361,138 +953,105 @@
 msgstr ""
 "Les procédures stockées sont dans la plupart des cas (lire : il vaut mieux "
 "le faire) requises pour retourner le nombre de lignes insérées/mises à jour/"
-"supprimées, puisque Hibernate fait quelques vérifications de succès lors de "
-"l'exécution de l'expression. Hibernate inscrit toujours la première "
-"expression comme un paramètre de sortie numérique pour les opérations CUD :"
+"supprimées, puisque Hibernate vérifie plusieurs fois le succès de "
+"l'expression. Hibernate inscrit toujours le premier paramètre de "
+"l'expression comme un paramètre de sortie numérique pour les opérations "
+"CUD : "
 
-#. Tag: programlisting
-#: query_sql.xml:562
-#, no-c-format
-msgid ""
-"<![CDATA[CREATE OR REPLACE FUNCTION updatePerson (uid IN NUMBER, uname IN "
-"VARCHAR2)\n"
-"    RETURN NUMBER IS\n"
-"BEGIN\n"
-"\n"
-"    update PERSON\n"
-"    set\n"
-"        NAME = uname,\n"
-"    where\n"
-"        ID = uid;\n"
-"\n"
-"    return SQL%ROWCOUNT;\n"
-"\n"
-"END updatePerson;]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:566
 #, no-c-format
 msgid "Custom SQL for loading"
 msgstr "SQL personnalisé pour le chargement"
 
 #. Tag: para
-#: query_sql.xml:568
-#, fuzzy, no-c-format
-msgid "You can also declare your own SQL (or HQL) queries for entity loading:"
-msgstr ""
-"Vous pouvez aussi déclarer vos propres requêtes SQL (ou HQL) pour le "
-"chargement d'entité :"
-
-#. Tag: programlisting
-#: query_sql.xml:571
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"person\">\n"
-"    <return alias=\"pers\" class=\"Person\" lock-mode=\"upgrade\"/>\n"
-"    SELECT NAME AS {pers.name}, ID AS {pers.id}\n"
-"    FROM PERSON\n"
-"    WHERE ID=?\n"
-"    FOR UPDATE\n"
-"</sql-query>]]>"
+"You can also declare your own SQL (or HQL) queries for entity loading. As "
+"with inserts, updates, and deletes, this can be done at the individual "
+"column level as described in <xref linkend=\"mapping-column-read-and-write"
+"\" /> or at the statement level. Here is an example of a statement level "
+"override:"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:573
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is just a named query declaration, as discussed earlier. You can "
 "reference this named query in a class mapping:"
 msgstr ""
-"Ceci est juste une déclaration de requête nommée, comme vu plus tôt. Vous "
-"pouvez référencer cette requête nommée dans un mapping de classe :"
+"Ceci est juste une déclaration de requête nommée, comme vu précédemment. "
+"Vous pouvez référencer cette requête nommée dans un mappage de classe : "
 
-#. Tag: programlisting
-#: query_sql.xml:576
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <loader query-ref=\"person\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:578
 #, no-c-format
 msgid "This even works with stored procedures."
 msgstr "Ceci fonctionne même avec des procédures stockées."
 
 #. Tag: para
-#: query_sql.xml:580
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can even define a query for collection loading:"
 msgstr ""
-"Vous pouvez même définir une requête pour le chargement d'une collection :"
+"Vous pouvez même définir une requête pour le chargement d'une collection : "
 
-#. Tag: programlisting
-#: query_sql.xml:582
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"employments\" inverse=\"true\">\n"
-"    <key/>\n"
-"    <one-to-many class=\"Employment\"/>\n"
-"    <loader query-ref=\"employments\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_sql.xml:584
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"employments\">\n"
-"    <load-collection alias=\"emp\" role=\"Person.employments\"/>\n"
-"    SELECT {emp.*}\n"
-"    FROM EMPLOYMENT emp\n"
-"    WHERE EMPLOYER = :id\n"
-"    ORDER BY STARTDATE ASC, EMPLOYEE ASC\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:586
-#, fuzzy, no-c-format
-msgid ""
 "You can also define an entity loader that loads a collection by join "
 "fetching:"
 msgstr ""
 "Vous pourriez même définir un chargeur d'entité qui charge une collection "
-"par jointure :"
+"par jointure : "
 
-#. Tag: programlisting
-#: query_sql.xml:589
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"person\">\n"
-"    <return alias=\"pers\" class=\"Person\"/>\n"
-"    <return-join alias=\"emp\" property=\"pers.employments\"/>\n"
-"    SELECT NAME AS {pers.*}, {emp.*}\n"
-"    FROM PERSON pers\n"
-"    LEFT OUTER JOIN EMPLOYMENT emp\n"
-"        ON pers.ID = emp.PERSON_ID\n"
-"    WHERE ID=?\n"
-"</sql-query>]]>"
-msgstr ""
+#~ msgid ""
+#~ "You can also declare your own SQL (or HQL) queries for entity loading:"
+#~ msgstr ""
+#~ "Vous pouvez aussi déclarer vos propres requêtes SQL (ou HQL) pour le "
+#~ "chargement d'entité : "
+
+#, fuzzy
+#~ msgid "A_NAME as {item.name}"
+#~ msgstr "<literal>A_NAME as {item.name}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].class}"
+#~ msgstr "<literal>{[aliasname].class}</literal>"
+
+#, fuzzy
+#~ msgid "DISC as {item.class}"
+#~ msgstr "<literal>DISC as {item.class}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].*}"
+#~ msgstr "<literal>{[aliasname].*}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].key}"
+#~ msgstr "<literal>{[aliasname].key}</literal>"
+
+#, fuzzy
+#~ msgid "ORGID as {coll.key}"
+#~ msgstr "<literal>ORGID as {coll.key}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].id}"
+#~ msgstr "<literal>{[aliasname].id}</literal>"
+
+#, fuzzy
+#~ msgid "EMPID as {coll.id}"
+#~ msgstr "<literal>EMPID as {coll.id}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].element}"
+#~ msgstr "<literal>{[aliasname].element}</literal>"
+
+#, fuzzy
+#~ msgid "XID as {coll.element}"
+#~ msgstr "<literal>XID as {coll.element}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].element.*}"
+#~ msgstr "<literal>{[aliasname].element.*}</literal>"
+
+#, fuzzy
+#~ msgid "{coll.element.*}"
+#~ msgstr "<literal>{coll.element.*}</literal>"

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/session_api.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/session_api.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/session_api.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,28 @@
+# translation of session_api.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: session_api\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2010-01-05 09:57+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: session_api.xml:29
 #, no-c-format
 msgid "Working with objects"
 msgstr "Travailler avec des objets"
 
 #. Tag: para
-#: session_api.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate is a full object/relational mapping solution that not only shields "
 "the developer from the details of the underlying database management system, "
@@ -27,8 +31,8 @@
 "JDBC/SQL persistence layers, a natural object-oriented view of persistence "
 "in Java applications."
 msgstr ""
-"Hibernate est une solution de mapping objet/relationnel complète qui ne "
-"masque pas seulement au développpeur les détails du système de gestion de "
+"Hibernate est une solution de mappage objet/relationnel complète qui ne "
+"masque pas seulement au développeur les détails du système de gestion de "
 "base de données sous-jacent, mais offre aussi <emphasis>la gestion d'état</"
 "emphasis> des objets. C'est, contrairement à la gestion de "
 "<literal>statements</literal> SQL dans les couches de persistance "
@@ -36,7 +40,6 @@
 "persistance dans les applications Java."
 
 #. Tag: para
-#: session_api.xml:40
 #, no-c-format
 msgid ""
 "In other words, Hibernate application developers should always think about "
@@ -45,27 +48,24 @@
 "is only relevant for the application developer when tuning the performance "
 "of the system."
 msgstr ""
-"En d'autres mots, les développeurs d'applications Hibernate devrait toujours "
-"réfléchir à <emphasis>l'état</emphasis> de leurs objets, et pas "
+"En d'autres termes, les développeurs d'applications Hibernate devraient "
+"toujours réfléchir à <emphasis>l'état</emphasis> de leurs objets, et pas "
 "nécessairement à l'exécution des expressions SQL. Cette part est prise en "
-"charge pas Hibernate et seulement importante pour les développeurs "
-"d'applications lors du réglage de la performance de leur système."
+"charge par Hibernate et importante seulement aux développeurs d'applications "
+"lors du réglage de la performance de leur système."
 
 #. Tag: title
-#: session_api.xml:48
 #, no-c-format
 msgid "Hibernate object states"
 msgstr "États des objets Hibernate"
 
 #. Tag: para
-#: session_api.xml:50
 #, no-c-format
 msgid "Hibernate defines and supports the following object states:"
-msgstr "Hibernate définit et comprend les états suivants :"
+msgstr "Hibernate définit et prend en charge les états d'objets suivants :"
 
 #. Tag: para
-#: session_api.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Transient</emphasis> - an object is transient if it has just been "
 "instantiated using the <literal>new</literal> operator, and it is not "
@@ -77,18 +77,17 @@
 "take care of the SQL statements that need to be executed for this "
 "transition)."
 msgstr ""
-"<emphasis>Éphémère</emphasis> (NdT : transient) - un objet est éphémère s'il "
-"a juste été instancié en utilisant l'opérateur <literal>new</literal>. Il "
-"n'a aucune représentation persistante dans la base de données et aucune "
-"valeur d'identifiant n'a été assignée. Les instances éphémères seront "
-"détruites par le ramasse-miettes si l'application n'en conserve aucune "
-"référence. Utilisez la <literal>Session</literal> d'Hibernate pour rendre un "
-"objet persistant (et laisser Hibernate s'occuper des expressions SQL qui ont "
-"besoin d'être exécutées pour cette transistion)."
+"<emphasis>Éphémère</emphasis> (transient) - un objet est éphémère s'il a "
+"juste été instancié en utilisant l'opérateur <literal>new</literal>. Il n'a "
+"aucune représentation persistante dans la base de données et aucune valeur "
+"d'identifiant n'a été assignée. Les instances éphémères seront détruites par "
+"le ramasse-miettes si l'application n'en conserve aucune référence. Utilisez "
+"la <literal>Session</literal> d'Hibernate pour rendre un objet persistant "
+"(et laisser Hibernate s'occuper des expressions SQL qui ont besoin d'être "
+"exécutées pour cette transistion)."
 
 #. Tag: para
-#: session_api.xml:68
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Persistent</emphasis> - a persistent instance has a representation "
 "in the database and an identifier value. It might just have been saved or "
@@ -103,15 +102,14 @@
 "représentation dans la base de données et une valeur d'identifiant. Elle "
 "pourrait avoir juste été sauvegardée ou chargée, pourtant, elle est par "
 "définition dans la portée d'une <literal>Session</literal>. Hibernate "
-"détectera n'importe quels changements effectués sur un objet dans l'état "
-"persistant et synchronisera l'état avec la base de données lors de la fin "
-"l'unité de travail. Les développeurs n'exécutent pas d'expressions "
-"<literal>UPDATE</literal> ou <literal>DELETE</literal> manuelles lorsqu'un "
-"objet devrait être rendu éphémère."
+"détectera tout changement effectué sur un objet dans l'état persistant et "
+"synchronisera l'état avec la base de données lors de la fin de l'unité de "
+"travail. Les développeurs n'exécutent pas d'expressions <literal>UPDATE</"
+"literal> ou <literal>DELETE</literal> manuelles lorsqu'un objet devrait être "
+"rendu éphémère. "
 
 #. Tag: para
-#: session_api.xml:79
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Detached</emphasis> - a detached instance is an object that has "
 "been persistent, but its <literal>Session</literal> has been closed. The "
@@ -124,34 +122,31 @@
 "from the point of view of the user."
 msgstr ""
 "<emphasis>Détaché</emphasis> - une instance détachée est un objet qui a été "
-"persistant, mais dont sa <literal>Session</literal> a été fermée. La "
+"persistant, mais dont la <literal>Session</literal> a été fermée. La "
 "référence à l'objet est encore valide, bien sûr, et l'instance détachée "
 "pourrait même être modifiée dans cet état. Une instance détachée peut être "
-"réattachée à une nouvelle <literal>Session</literal> plus tard dans le "
-"temps, la rendant (et toutes les modifications avec) de nouveau persistante. "
-"Cette fonctionnalité rend possible un modèle de programmation pour de "
-"longues unités de travail qui requièrent un temps de réflexion de "
-"l'utilisateur. Nous les appelons des <emphasis>conversations</emphasis>, "
-"c'est-à-dire une unité de travail du point de vue de l'utilisateur."
+"rattachée à une nouvelle <literal>Session</literal> ultérieurement, la "
+"rendant (et toutes les modifications avec) de nouveau persistante. Cette "
+"fonctionnalité rend possible un modèle de programmation pour de longues "
+"unités de travail qui requièrent un temps de réflexion de l'utilisateur. "
+"Nous les appelons des <emphasis>conversations</emphasis>, c'est-à-dire une "
+"unité de travail du point de vue de l'utilisateur. "
 
 #. Tag: para
-#: session_api.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will now discuss the states and state transitions (and the Hibernate "
 "methods that trigger a transition) in more detail."
 msgstr ""
-"Nous alons maintenant dicuster des états et des transitions d'état (et des "
-"méthodes d'Hibernate qui déclenchent une transition) plus en détails."
+"Nous allons maintenant approfondir le sujet des états et des transitions "
+"d'état (et des méthodes Hibernate qui déclenchent une transition)."
 
 #. Tag: title
-#: session_api.xml:101
 #, no-c-format
 msgid "Making objects persistent"
 msgstr "Rendre des objets persistants"
 
 #. Tag: para
-#: session_api.xml:103
 #, no-c-format
 msgid ""
 "Newly instantiated instances of a a persistent class are considered "
@@ -159,25 +154,13 @@
 "instance <emphasis>persistent</emphasis> by associating it with a session:"
 msgstr ""
 "Les instances nouvellement instanciées d'une classe persistante sont "
-"considérées <emphasis>éphémères</emphasis> par Hibernate. Nous pouvons "
+"considérées comme <emphasis>éphémères</emphasis> par Hibernate. Nous pouvons "
 "rendre une instance éphémère <emphasis>persistante</emphasis> en l'associant "
-"avec une session :"
+"à une session :"
 
-#. Tag: programlisting
-#: session_api.xml:110
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DomesticCat fritz = new DomesticCat();\n"
-"fritz.setColor(Color.GINGER);\n"
-"fritz.setSex('M');\n"
-"fritz.setName(\"Fritz\");\n"
-"Long generatedId = (Long) sess.save(fritz);]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:112
-#, fuzzy, no-c-format
-msgid ""
 "If <literal>Cat</literal> has a generated identifier, the identifier is "
 "generated and assigned to the <literal>cat</literal> when <literal>save()</"
 "literal> is called. If <literal>Cat</literal> has an <literal>assigned</"
@@ -189,16 +172,15 @@
 msgstr ""
 "Si <literal>Cat</literal> a un identifiant généré, l'identifiant est généré "
 "et assigné au <literal>cat</literal> lorsque <literal>save()</literal> est "
-"appelée. Si <literal>Cat</literal> a un identifiant <literal>assigned</"
+"appelé. Si <literal>Cat</literal> a un identifiant <literal>assigned</"
 "literal>, ou une clef composée, l'identifiant devrait être assigné à "
 "l'instance de <literal>cat</literal> avant d'appeler <literal>save()</"
 "literal>. Vous pouvez aussi utiliser <literal>persist()</literal> à la place "
-"de<literal>save()</literal>, avec la sémantique définie plus tôt dans le "
-"brouillon d'EJB3."
+"de <literal>save()</literal>, avec la sémantique définie plus tôt dans la "
+"première ébauche d'EJB3. "
 
 #. Tag: para
-#: session_api.xml:124
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>persist()</literal> makes a transient instance persistent. However, "
 "it does not guarantee that the identifier value will be assigned to the "
@@ -208,16 +190,15 @@
 "boundaries. This is useful in long-running conversations with an extended "
 "Session/persistence context."
 msgstr ""
-"<literal>persist()</literal> makes a transient instance persistent. However, "
-"it doesn't guarantee that the identifier value will be assigned to the "
-"persistent instance immediately, the assignment might happen at flush time. "
-"<literal>persist()</literal> also guarantees that it will not execute an "
-"<literal>INSERT</literal> statement if it is called outside of transaction "
-"boundaries. This is useful in long-running conversations with an extended "
-"Session/persistence context."
+"<literal>persist()</literal> rend une instance éphémère persistante. "
+"Toutefois, il ne garantit pas que la valeur d'identificateur soit affectée à "
+"l'instance permanente immédiatement, l'affectation peut se produire au "
+"moment de flush. <literal>Persist()</literal> garantit également qu'il ne "
+"s'exécutera pas un énoncé <literal>INSERT</literal> s'il est appelée en "
+"dehors des limites de transaction. C'est utile pour les longues "
+"conversations dans un contexte de session/persistance étendu."
 
 #. Tag: para
-#: session_api.xml:135
 #, no-c-format
 msgid ""
 "<literal>save()</literal> does guarantee to return an identifier. If an "
@@ -226,39 +207,25 @@
 "you are inside or outside of a transaction. This is problematic in a long-"
 "running conversation with an extended Session/persistence context."
 msgstr ""
-"<literal>save()</literal> does guarantee to return an identifier. If an "
-"INSERT has to be executed to get the identifier ( e.g. \"identity\" "
-"generator, not \"sequence\"), this INSERT happens immediately, no matter if "
-"you are inside or outside of a transaction. This is problematic in a long-"
-"running conversation with an extended Session/persistence context."
+"<literal>save()</literal> garantit le retour d'un identifiant. Si une "
+"instruction INSERT doit être exécutée pour obtenir l'identifiant (par "
+"exemple,  le générateur \"identity\", et non pas \"sequence\"), cet INSERT "
+"se produit immédiatement, que vous soyez à l'intérieur ou à l'extérieur "
+"d'une transaction. C'est problématique dans une conversation longue dans un "
+"contexte de session/persistance étendu."
 
 #. Tag: para
-#: session_api.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, you can assign the identifier using an overloaded version of "
 "<literal>save()</literal>."
 msgstr ""
 "Alternativement, vous pouvez assigner l'identifiant en utilisant une version "
-"surchargée de <literal>save()</literal>."
+"surchargée de <literal>save()</literal>. "
 
-#. Tag: programlisting
-#: session_api.xml:150
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DomesticCat pk = new DomesticCat();\n"
-"pk.setColor(Color.TABBY);\n"
-"pk.setSex('F');\n"
-"pk.setName(\"PK\");\n"
-"pk.setKittens( new HashSet() );\n"
-"pk.addKitten(fritz);\n"
-"sess.save( pk, new Long(1234) );]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:152
-#, fuzzy, no-c-format
-msgid ""
 "If the object you make persistent has associated objects (e.g. the "
 "<literal>kittens</literal> collection in the previous example), these "
 "objects can be made persistent in any order you like unless you have a "
@@ -269,16 +236,15 @@
 msgstr ""
 "Si l'objet que vous rendez persistant a des objets associés (par exemple, la "
 "collection <literal>kittens</literal> dans l'exemple précédent), ces objets "
-"peuvent être rendus persistants dans n'importe quel ordre que vous souhaitez "
-"à moins que vous ayez une contrainte <literal>NOT NULL</literal> sur la "
-"colonne de la clef étrangère. Il n'y a jamais de risque de violer une "
-"contrainte de clef étrangère. Cependant, vous pourriez violer une contrainte "
-"<literal>NOT NULL</literal> si vous appeliez <literal>save()</literal> sur "
-"les objets dans le mauvais ordre."
+"peuvent être rendus persistants dans n'importe quel ordre désiré, à moins "
+"que vous ayez une contrainte <literal>NOT NULL</literal> sur la colonne de "
+"la clé étrangère. Il n'y a jamais de risque de violer une contrainte de cl. "
+"étrangère. Cependant, vous pourriez violer une contrainte <literal>NOT NULL</"
+"literal> si vous appeliez <literal>save()</literal> sur les objets dans le "
+"mauvais ordre. "
 
 #. Tag: para
-#: session_api.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Usually you do not bother with this detail, as you will normally use "
 "Hibernate's <emphasis>transitive persistence</emphasis> feature to save the "
@@ -288,20 +254,18 @@
 msgstr ""
 "Habituellement, vous ne vous préoccupez pas de ce détail, puisque vous "
 "utiliserez très probablement la fonctionnalité de <emphasis>persistance "
-"transitive</emphasis> d'Hibernate pour sauvegarder les objets associés "
+"transitive</emphasis> de Hibernate pour sauvegarder les objets associés "
 "automatiquement. Alors, même les violations de contrainte <literal>NOT NULL</"
 "literal> n'ont plus lieu - Hibernate prendra soin de tout. La persistance "
-"transitive est traitée plus loin dans ce chapitre."
+"transitive est traitée plus loin dans ce chapitre. "
 
 #. Tag: title
-#: session_api.xml:173
 #, no-c-format
 msgid "Loading an object"
 msgstr "Chargement d'un objet"
 
 #. Tag: para
-#: session_api.xml:175
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>load()</literal> methods of <literal>Session</literal> provide "
 "a way of retrieving a persistent instance if you know its identifier. "
@@ -312,45 +276,17 @@
 "donnent un moyen de récupérer une instance persistante si vous connaissez "
 "déjà son identifiant. <literal>load()</literal> prend un objet de classe et "
 "chargera l'état dans une instance nouvellement instanciée de cette classe, "
-"dans un état persistant."
+"dans un état persistant. "
 
-#. Tag: programlisting
-#: session_api.xml:182
-#, no-c-format
-msgid "<![CDATA[Cat fritz = (Cat) sess.load(Cat.class, generatedId);]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:184
-#, no-c-format
-msgid ""
-"<![CDATA[// you need to wrap primitive identifiers\n"
-"long id = 1234;\n"
-"DomesticCat pk = (DomesticCat) sess.load( DomesticCat.class, new Long"
-"(id) );]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:186
 #, no-c-format
 msgid "Alternatively, you can load state into a given instance:"
 msgstr ""
 "Alternativement, vous pouvez charger un état dans une instance donnée :"
 
-#. Tag: programlisting
-#: session_api.xml:190
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Cat cat = new DomesticCat();\n"
-"// load pk's state into cat\n"
-"sess.load( cat, new Long(pkId) );\n"
-"Set kittens = cat.getKittens();]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:192
-#, fuzzy, no-c-format
-msgid ""
 "Be aware that <literal>load()</literal> will throw an unrecoverable "
 "exception if there is no matching database row. If the class is mapped with "
 "a proxy, <literal>load()</literal> just returns an uninitialized proxy and "
@@ -368,111 +304,76 @@
 "souhaitez créer une association vers un objet sans réellement le charger à "
 "partir de la base de données. Cela permet aussi à de multiples instances "
 "d'être chargées comme un lot si <literal>batch-size</literal> est défini "
-"pour le mapping de la classe."
+"pour le mapping de la classe. "
 
 #. Tag: para
-#: session_api.xml:203
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are not certain that a matching row exists, you should use the "
 "<literal>get()</literal> method which hits the database immediately and "
 "returns null if there is no matching row."
 msgstr ""
-"Si vous n'êtes pas certain qu'une ligne correspondante existe, vous devriez "
-"utiliser la méthode <literal>get()</literal>, laquelle accède à la base de "
+"Si vous n'êtes pas certain qu'une ligne correspondante existe, vous "
+"utiliserez la méthode <literal>get()</literal>, laquelle accède à la base de "
 "données immédiatement et retourne null s'il n'y a pas de ligne "
-"correspondante."
+"correspondante. "
 
-#. Tag: programlisting
-#: session_api.xml:209
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id);\n"
-"if (cat==null) {\n"
-"    cat = new Cat();\n"
-"    sess.save(cat, id);\n"
-"}\n"
-"return cat;]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:211
-#, fuzzy, no-c-format
-msgid ""
 "You can even load an object using an SQL <literal>SELECT ... FOR UPDATE</"
 "literal>, using a <literal>LockMode</literal>. See the API documentation for "
 "more information."
 msgstr ""
-"Vous pouvez même charger un objet en employant un <literal>SELECT ... FOR "
-"UPDATE</literal> SQL, en utilisant un <literal>LockMode</literal>. Voir la "
-"documentation de l'API pour plus d'informations."
+"Vous pouvez même charger un objet en employant un SQL <literal>SELECT ... "
+"FOR UPDATE</literal>, en utilisant un <literal>LockMode</literal>. Voir la "
+"documentation de l'API pour plus d'informations. "
 
-#. Tag: programlisting
-#: session_api.xml:216
-#, no-c-format
-msgid "<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id, LockMode.UPGRADE);]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:218
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Any associated instances or contained collections will <emphasis>not</"
 "emphasis> be selected <literal>FOR UPDATE</literal>, unless you decide to "
 "specify <literal>lock</literal> or <literal>all</literal> as a cascade style "
 "for the association."
 msgstr ""
-"Notez que n'importe quelles instances associées ou collections contenues "
+"Notez que n'importe quelle instance associée ou collection contenue "
 "<emphasis>ne sont pas</emphasis> sélectionnées par <literal>FOR UPDATE</"
 "literal>, à moins que vous ne décidiez de spécifier <literal>lock</literal> "
 "ou <literal>all</literal> en tant que style de cascade pour l'association."
 
 #. Tag: para
-#: session_api.xml:225
 #, no-c-format
 msgid ""
 "It is possible to re-load an object and all its collections at any time, "
 "using the <literal>refresh()</literal> method. This is useful when database "
 "triggers are used to initialize some of the properties of the object."
 msgstr ""
-"Il est possible de re-charger un objet et toutes ses collections à n'importe "
-"quel moment, en utilisant la méthode <literal>refresh()</literal>. C'est "
-"utile lorsque des \"triggers\" de base de données sont utilisés pour "
-"initiliser certains propriétés de l'objet."
+"Il est possible de re-charger un objet et toutes ses collections à tout "
+"moment, en utilisant la méthode <literal>refresh()</literal>. C'est utile "
+"lorsque des \"triggers\" de base de données sont utilisés pour initialiser "
+"certaines propriétés de l'objet."
 
-#. Tag: programlisting
-#: session_api.xml:231
-#, no-c-format
-msgid ""
-"<![CDATA[sess.save(cat);\n"
-"sess.flush(); //force the SQL INSERT\n"
-"sess.refresh(cat); //re-read the state (after the trigger executes)]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:233
 #, fuzzy, no-c-format
 msgid ""
 "How much does Hibernate load from the database and how many SQL "
 "<literal>SELECT</literal>s will it use? This depends on the "
 "<emphasis>fetching strategy</emphasis>. This is explained in <xref linkend="
-"\"performance-fetching\"/>."
+"\"performance-fetching\" />."
 msgstr ""
-"Une question importante apparaît généralement à ce point : combien (NdT : de "
-"données) Hibernate charge-t-il de la base de données et combient de "
-"<literal>SELECT</literal>s utilisera-t-il ? Cela dépent de la "
+"Combien de données Hibernate charge-t-il de la base de données et combien de "
+"<literal>SELECT</literal>s utilisera-t-il ? Cela dépend de la "
 "<emphasis>stratégie de récupération</emphasis> et cela est expliqué dans "
-"<xref linkend=\"performance-fetching\"/>."
+"<xref linkend=\"performance-fetching\" />."
 
 #. Tag: title
-#: session_api.xml:243
 #, no-c-format
 msgid "Querying"
 msgstr "Requêtage"
 
 #. Tag: para
-#: session_api.xml:245
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you do not know the identifiers of the objects you are looking for, you "
 "need a query. Hibernate supports an easy-to-use but powerful object oriented "
@@ -483,21 +384,19 @@
 msgstr ""
 "Si vous ne connaissez par les identifiants des objets que vous recherchez, "
 "vous avez besoin d'une requête. Hibernate supporte un langage de requêtes "
-"orientées objet facile à utiliser mais puissant. Pour la création de "
+"orientées objet, facile à utiliser mais puissant. Pour la création de "
 "requêtes par programmation, Hibernate supporte une fonction de requêtage "
-"sophistiqué Criteria et Example (QBC et QBE). Vous pouvez aussi exprimez "
+"sophistiquée Criteria et Example (QBC et QBE). Vous pouvez aussi exprimer "
 "votre requête dans le SQL natif de votre base de données, avec un support "
-"optionnel d'Hibernate pour la conversion des ensembles de résultats en "
-"objets."
+"optionnel de Hibernate pour la conversion des ensembles de résultats en "
+"objets. "
 
 #. Tag: title
-#: session_api.xml:255
 #, no-c-format
 msgid "Executing queries"
 msgstr "Exécution de requêtes"
 
 #. Tag: para
-#: session_api.xml:257
 #, no-c-format
 msgid ""
 "HQL and native SQL queries are represented with an instance of <literal>org."
@@ -508,44 +407,13 @@
 msgstr ""
 "Les requêtes HQL et SQL natives sont représentées avec une instance de "
 "<literal>org.hibernate.Query</literal>. L'interface offre des méthodes pour "
-"la liaison des paramètres, la gestion des ensembles de resultats, et pour "
+"la liaison des paramètres, la gestion des ensembles de résultats, et pour "
 "l'exécution de la requête réelle. Vous obtenez toujours une <literal>Query</"
-"literal> en utilisant la <literal>Session</literal> courante :"
+"literal> en utilisant la <literal>Session</literal> courante : "
 
-#. Tag: programlisting
-#: session_api.xml:264
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = session.createQuery(\n"
-"    \"from Cat as cat where cat.birthdate < ?\")\n"
-"    .setDate(0, date)\n"
-"    .list();\n"
-"\n"
-"List mothers = session.createQuery(\n"
-"    \"select mother from Cat as cat join cat.mother as mother where cat.name "
-"= ?\")\n"
-"    .setString(0, name)\n"
-"    .list();\n"
-"\n"
-"List kittens = session.createQuery(\n"
-"    \"from Cat as cat where cat.mother = ?\")\n"
-"    .setEntity(0, pk)\n"
-"    .list();\n"
-"\n"
-"Cat mother = (Cat) session.createQuery(\n"
-"    \"select cat.mother from Cat as cat where cat = ?\")\n"
-"    .setEntity(0, izi)\n"
-"    .uniqueResult();]]\n"
-"\n"
-"Query mothersWithKittens = (Cat) session.createQuery(\n"
-"    \"select mother from Cat as mother left join fetch mother.kittens\");\n"
-"Set uniqueMothers = new HashSet(mothersWithKittens.list());]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:266
-#, fuzzy, no-c-format
-msgid ""
 "A query is usually executed by invoking <literal>list()</literal>. The "
 "result of the query will be loaded completely into a collection in memory. "
 "Entity instances retrieved by a query are in a persistent state. The "
@@ -557,20 +425,21 @@
 msgstr ""
 "Une requête est généralement exécutée en invoquant <literal>list()</"
 "literal>, le résultat de la requête sera chargée complètement dans une "
-"collection en mémoire. Les intances d'entités recupérées par une requête "
+"collection en mémoire. Les instances d'entités récupérées par une requête "
 "sont dans un état persistant. La méthode <literal>uniqueResult()</literal> "
-"offre un raccourci si vous savez que votre requête retournera seulement un "
-"seul objet."
+"offre un raccourci si vous savez que votre requête retournera un seul objet. "
+"Notez que les requêtes qui utilisent le chargement agressif de collections "
+"retournent habituellement des copies des objets racine (mais avec leurs "
+"collections initialisées). Vous pouvez simplement filtrer ces copies via un "
+"<literal>Set</literal>. "
 
 #. Tag: title
-#: session_api.xml:278
 #, no-c-format
 msgid "Iterating results"
 msgstr "Itération de résultats"
 
 #. Tag: para
-#: session_api.xml:280
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Occasionally, you might be able to achieve better performance by executing "
 "the query using the <literal>iterate()</literal> method. This will usually "
@@ -582,118 +451,55 @@
 "returns identifiers, and <emphasis>n</emphasis> additional selects to "
 "initialize the actual instances."
 msgstr ""
-"Occasionnellement, vous pourriez être capable d'obtenir de meilleures "
-"performances en exécutant la requête avec la méthode <literal>iterate()</"
-"literal>. Ce sera généralement seulement le cas si vous espérez que les "
-"intances réelles d'entité retournées par la requête soient déjà chargées "
-"dans la session ou le cache de second niveau. Si elles ne sont pas cachées, "
+"Parfois, vous serez en mesure d'obtenir de meilleures performances en "
+"exécutant la requête avec la méthode <literal>iterate()</literal>. En "
+"général, ce sera uniquement le cas si vous attendez que les instances "
+"réelles d'entité retournées par la requête, soient déjà chargées dans la "
+"session ou le cache de second niveau. Si elles ne sont pas déjà cachées, "
 "<literal>iterate()</literal> sera plus lent que <literal>list()</literal> et "
 "pourrait nécessiter plusieurs accès à la base de données pour une simple "
 "requête, généralement <emphasis>1</emphasis> pour le select initial qui "
 "retourne seulement les identifiants, et <emphasis>n</emphasis> selects "
-"supplémentaires pour initialiser les instances réelles."
+"supplémentaires pour initialiser les instances réelles. "
 
-#. Tag: programlisting
-#: session_api.xml:292
-#, no-c-format
-msgid ""
-"<![CDATA[// fetch ids\n"
-"Iterator iter = sess.createQuery(\"from eg.Qux q order by q.likeliness\")."
-"iterate();\n"
-"while ( iter.hasNext() ) {\n"
-"    Qux qux = (Qux) iter.next();  // fetch the object\n"
-"    // something we couldnt express in the query\n"
-"    if ( qux.calculateComplicatedAlgorithm() ) {\n"
-"        // delete the current instance\n"
-"        iter.remove();\n"
-"        // dont need to process the rest\n"
-"        break;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:296
 #, no-c-format
 msgid "Queries that return tuples"
 msgstr "Requêtes qui retournent des tuples"
 
 #. Tag: para
-#: session_api.xml:298
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate queries sometimes return tuples of objects. Each tuple is returned "
 "as an array:"
 msgstr ""
 "Les requêtes d'Hibernate retournent parfois des tuples d'objets, auquel cas "
-"chaque tuple est retourné comme un tableau :"
+"chaque tuple est retourné comme un tableau : "
 
-#. Tag: programlisting
-#: session_api.xml:303
-#, no-c-format
-msgid ""
-"<![CDATA[Iterator kittensAndMothers = sess.createQuery(\n"
-"            \"select kitten, mother from Cat kitten join kitten.mother mother"
-"\")\n"
-"            .list()\n"
-"            .iterator();\n"
-"\n"
-"while ( kittensAndMothers.hasNext() ) {\n"
-"    Object[] tuple = (Object[]) kittensAndMothers.next();\n"
-"    Cat kitten = (Cat) tuple[0];\n"
-"    Cat mother = (Cat) tuple[1];\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:308
 #, no-c-format
 msgid "Scalar results"
 msgstr "Résultats scalaires"
 
 #. Tag: para
-#: session_api.xml:310
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Queries can specify a property of a class in the <literal>select</literal> "
 "clause. They can even call SQL aggregate functions. Properties or aggregates "
 "are considered \"scalar\" results and not entities in persistent state."
 msgstr ""
-"Des requêtes peuvent spécifier une propriété d'une classe dans la clause "
+"Certaines requêtes peuvent spécifier une propriété de classe dans la clause "
 "<literal>select</literal>. Elles peuvent même appeler des fonctions "
 "d'aggrégat SQL. Les propriétés ou les aggrégats sont considérés comme des "
-"résultats \"scalaires\" (et pas des entités dans un état persistant)."
+"résultats \"scalaires\" (et non des entités dans un état persistant). "
 
-#. Tag: programlisting
-#: session_api.xml:316
-#, no-c-format
-msgid ""
-"<![CDATA[Iterator results = sess.createQuery(\n"
-"        \"select cat.color, min(cat.birthdate), count(cat) from Cat cat \" "
-"+\n"
-"        \"group by cat.color\")\n"
-"        .list()\n"
-"        .iterator();\n"
-"\n"
-"while ( results.hasNext() ) {\n"
-"    Object[] row = (Object[]) results.next();\n"
-"    Color type = (Color) row[0];\n"
-"    Date oldest = (Date) row[1];\n"
-"    Integer count = (Integer) row[2];\n"
-"    .....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:321
 #, no-c-format
 msgid "Bind parameters"
 msgstr "Lier des paramètres"
 
 #. Tag: para
-#: session_api.xml:323
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Methods on <literal>Query</literal> are provided for binding values to named "
 "parameters or JDBC-style <literal>?</literal> parameters. <emphasis>Contrary "
@@ -703,160 +509,76 @@
 msgstr ""
 "Des méthodes de <literal>Query</literal> sont fournies pour lier des valeurs "
 "à des paramètres nommés ou à des paramètres de style JDBC <literal>?</"
-"literal>. <emphasis>Contrairement à JDBC, les numéros des paramètres "
-"d'Hibernate commencent à zéro.</emphasis> Les paramètres nommés sont des "
+"literal>. <emphasis>Contrairement à JDBC, les numéros des paramètres de "
+"Hibernate commencent à zéro.</emphasis> Les paramètres nommés sont des "
 "identifiants de la forme <literal>:nom</literal> dans la chaîne de "
-"caractères de la requête. Les avantages des paramètres nommés sont :"
+"caractères de la requête. Les avantages des paramètres nommés sont : "
 
 #. Tag: para
-#: session_api.xml:333
 #, no-c-format
 msgid ""
 "named parameters are insensitive to the order they occur in the query string"
 msgstr ""
-"les paramètres nommés sont insensibles à l'ordre de leur place dans la "
-"chaîne de la requête"
+"les paramètres nommés sont insensibles à l'ordre dans lequel ils "
+"apparaissent dans la chaîne de la requête"
 
 #. Tag: para
-#: session_api.xml:339
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "they can occur multiple times in the same query"
-msgstr "ils peuvent apparaître plusieurs fois dans la même requête"
+msgstr "ils peuvent apparaître plusieurs fois dans la même requête "
 
 #. Tag: para
-#: session_api.xml:344
 #, no-c-format
 msgid "they are self-documenting"
 msgstr "ils sont auto-documentés"
 
-#. Tag: programlisting
-#: session_api.xml:350
-#, no-c-format
-msgid ""
-"<![CDATA[//named parameter (preferred)\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name = :name"
-"\");\n"
-"q.setString(\"name\", \"Fritz\");\n"
-"Iterator cats = q.iterate();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:352
-#, no-c-format
-msgid ""
-"<![CDATA[//positional parameter\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name = ?\");\n"
-"q.setString(0, \"Izi\");\n"
-"Iterator cats = q.iterate();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:354
-#, no-c-format
-msgid ""
-"<![CDATA[//named parameter list\n"
-"List names = new ArrayList();\n"
-"names.add(\"Izi\");\n"
-"names.add(\"Fritz\");\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name in (:"
-"namesList)\");\n"
-"q.setParameterList(\"namesList\", names);\n"
-"List cats = q.list();]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:359
 #, no-c-format
 msgid "Pagination"
 msgstr "Pagination"
 
 #. Tag: para
-#: session_api.xml:361
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you need to specify bounds upon your result set, that is, the maximum "
 "number of rows you want to retrieve and/or the first row you want to "
 "retrieve, you can use methods of the <literal>Query</literal> interface:"
 msgstr ""
 "Si vous avez besoin de spécifier des liens sur votre ensemble de résultats "
-"(le nombre maximum de lignes que vous voulez récupérez et/ou la première "
-"ligne que vous voulez récupérer) vous devriez utiliser des méthodes de "
-"l'interface <literal>Query</literal> :"
+"(le nombre maximum de lignes et/ou la première ligne que vous voulez "
+"récupérer) vous utiliserez des méthodes de l'interface <literal>Query</"
+"literal> : "
 
-#. Tag: programlisting
-#: session_api.xml:367
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = sess.createQuery(\"from DomesticCat cat\");\n"
-"q.setFirstResult(20);\n"
-"q.setMaxResults(10);\n"
-"List cats = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:369
 #, no-c-format
 msgid ""
 "Hibernate knows how to translate this limit query into the native SQL of "
 "your DBMS."
 msgstr ""
-"Hibernate sait comment traduite cette requête de limite en SQL natif pour "
+"Hibernate sait comment traduire cette requête de limite en SQL natif pour "
 "votre SGBD."
 
 #. Tag: title
-#: session_api.xml:377
 #, no-c-format
 msgid "Scrollable iteration"
 msgstr "Itération \"scrollable\""
 
 #. Tag: para
-#: session_api.xml:379
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your JDBC driver supports scrollable <literal>ResultSet</literal>s, the "
 "<literal>Query</literal> interface can be used to obtain a "
 "<literal>ScrollableResults</literal> object that allows flexible navigation "
 "of the query results."
 msgstr ""
-"Si votre connecteur JDBC supporte les <literal>ResultSet</literal>s "
+"Si votre connecteur JDBC supporte les <literal>ResultSet</literal> s "
 "\"scrollables\", l'interface <literal>Query</literal> peut être utilisée "
-"pour obtenir un objet <literal>ScrollableResults</literal>, lequel permet "
-"une navigation flexible dans les résultats de la requête."
+"pour obtenir un objet <literal>ScrollableResults</literal>, qui permettra "
+"une navigation flexible dans les résultats de la requête. "
 
-#. Tag: programlisting
-#: session_api.xml:386
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Query q = sess.createQuery(\"select cat.name, cat from DomesticCat "
-"cat \" +\n"
-"                            \"order by cat.name\");\n"
-"ScrollableResults cats = q.scroll();\n"
-"if ( cats.first() ) {\n"
-"\n"
-"    // find the first name on each page of an alphabetical list of cats by "
-"name\n"
-"    firstNamesOfPages = new ArrayList();\n"
-"    do {\n"
-"        String name = cats.getString(0);\n"
-"        firstNamesOfPages.add(name);\n"
-"    }\n"
-"    while ( cats.scroll(PAGE_SIZE) );\n"
-"\n"
-"    // Now get the first page of cats\n"
-"    pageOfCats = new ArrayList();\n"
-"    cats.beforeFirst();\n"
-"    int i=0;\n"
-"    while( ( PAGE_SIZE > i++ ) && cats.next() ) pageOfCats.add( cats.get"
-"(1) );\n"
-"\n"
-"}\n"
-"cats.close()]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:388
-#, fuzzy, no-c-format
-msgid ""
 "Note that an open database connection and cursor is required for this "
 "functionality. Use <literal>setMaxResult()</literal>/<literal>setFirstResult"
 "()</literal> if you need offline pagination functionality."
@@ -864,70 +586,45 @@
 "Notez qu'une connexion ouverte (et un curseur) est requise pour cette "
 "fonctionnalité, utilisez <literal>setMaxResult()</literal>/"
 "<literal>setFirstResult()</literal> si vous avez besoin d'une fonctionnalité "
-"de pagination hors ligne."
+"de pagination hors ligne. "
 
 #. Tag: title
-#: session_api.xml:397
 #, no-c-format
 msgid "Externalizing named queries"
 msgstr "Externaliser des requêtes nommées"
 
 #. Tag: para
-#: session_api.xml:399
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also define named queries in the mapping document. Remember to use a "
 "<literal>CDATA</literal> section if your query contains characters that "
 "could be interpreted as markup."
 msgstr ""
 "Vous pouvez aussi définir des requêtes nommées dans le document de mapping. "
-"(Souvenez-vous d'utiliser une section <literal>CDATA</literal> si votre "
+"Souvenez-vous d'utiliser une section <literal>CDATA</literal> si votre "
 "requête contient des caractères qui pourraient être interprétés comme des "
-"éléments XML.)"
+"éléments XML."
 
-#. Tag: programlisting
-#: session_api.xml:405
-#, no-c-format
-msgid ""
-"<![CDATA[<query name=\"ByNameAndMaximumWeight\"><![CDATA[\n"
-"    from eg.DomesticCat as cat\n"
-"        where cat.name = ?\n"
-"        and cat.weight > ?\n"
-"] ]></query>]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:407
 #, no-c-format
 msgid "Parameter binding and executing is done programatically:"
-msgstr "La liaison de paramètres et l'exécution sont fait par programmation :"
-
-#. Tag: programlisting
-#: session_api.xml:411
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = sess.getNamedQuery(\"ByNameAndMaximumWeight\");\n"
-"q.setString(0, name);\n"
-"q.setInt(1, minWeight);\n"
-"List cats = q.list();]]>"
 msgstr ""
+"La liaison de paramètres et l'exécution sont effectués par programmation :"
 
 #. Tag: para
-#: session_api.xml:413
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The actual program code is independent of the query language that is used. "
 "You can also define native SQL queries in metadata, or migrate existing "
 "queries to Hibernate by placing them in mapping files."
 msgstr ""
 "Notez que le code réel du programme est indépendant du langage de requête "
-"qui est utilisé, vous pouvez aussi définir des requêtes SQL nativez dans les "
-"méta-données, ou migrer des requêtes existantes vers Hibernate en les "
-"plaçant dans les fichiers de mapping."
+"utilisé, vous pouvez aussi définir des requêtes SQL natives dans les méta-"
+"données, ou migrer des requêtes existantes vers Hibernate en les plaçant "
+"dans les fichiers de mapping. "
 
 #. Tag: para
-#: session_api.xml:419
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Also note that a query declaration inside a <literal>&lt;hibernate-"
 "mapping&gt;</literal> element requires a global unique name for the query, "
@@ -935,22 +632,20 @@
 "is made unique automatically by prepending the fully qualified name of the "
 "class. For example <literal>eg.Cat.ByNameAndMaximumWeight</literal>."
 msgstr ""
-"UNTRANSLATED! Also note that a query declaration inside a <literal>&lt;"
-"hibernate-mapping&gt;</literal> element requires a global unique name for "
-"the query, while a query declaration inside a <literal>&lt;class&gt;</"
-"literal> element is made unique automatically by prepending the fully "
-"qualified name of the class, for example <literal>eg.Cat."
-"ByNameAndMaximumWeight</literal>."
+"Notez aussi que la déclaration d'une requête dans un élément <literal>&lt;"
+"hibernate-mapping&gt;</literal> nécessite un nom globalement unique pour la "
+"requête, alors que la déclaration d'une requête dans un élément <literal>&lt;"
+"class&gt;</literal> est rendue unique de manière automatique par la mise en "
+"préfixe du nom entièrement qualifié de la classe, par exemple <literal>eg."
+"Cat.ByNameAndMaximumWeight</literal>. "
 
 #. Tag: title
-#: session_api.xml:432
 #, no-c-format
 msgid "Filtering collections"
 msgstr "Filtrer des collections"
 
 #. Tag: para
-#: session_api.xml:433
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A collection <emphasis>filter</emphasis> is a special type of query that can "
 "be applied to a persistent collection or array. The query string can refer "
@@ -958,37 +653,23 @@
 msgstr ""
 "Un <emphasis>filtre</emphasis> de collection est un type spécial de requête "
 "qui peut être appliqué à une collection persistante ou à un tableau. La "
-"chaîne de requête peut se référer à <literal>this</literal>, correspondant à "
-"l'élément de la collection courant."
+"chaîne de requêtes peut se référer à <literal>this</literal>, correspondant "
+"à l'élément de la collection courant. "
 
-#. Tag: programlisting
-#: session_api.xml:439
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Collection blackKittens = session.createFilter(\n"
-"    pk.getKittens(), \n"
-"    \"where this.color = ?\")\n"
-"    .setParameter( Color.BLACK, Hibernate.custom(ColorUserType.class) )\n"
-"    .list()\n"
-");]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:441
-#, fuzzy, no-c-format
-msgid ""
 "The returned collection is considered a bag that is a copy of the given "
 "collection. The original collection is not modified. This is contrary to the "
 "implication of the name \"filter\", but consistent with expected behavior."
 msgstr ""
 "La collection retournée est considérée comme un bag, et c'est une copie de "
-"la collection donnée. La collection originale n'est pas modifiée (c'est "
+"la collection donnée. La collection originale n'est pas modifiée. C'est "
 "contraire à l'implication du nom \"filtre\"; mais cohérent avec le "
-"comportement attendu)."
+"comportement attendu."
 
 #. Tag: para
-#: session_api.xml:447
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Observe that filters do not require a <literal>from</literal> clause, "
 "although they can have one if required. Filters are not limited to returning "
@@ -996,88 +677,52 @@
 msgstr ""
 "Observez que les filtres ne nécessitent pas une clause <literal>from</"
 "literal> (bien qu'ils puissent en avoir une si besoin est). Les filtres ne "
-"sont pas limités à retourner des éléments de la collection eux-mêmes."
+"sont pas limités à retourner des éléments de la collection eux-mêmes. "
 
-#. Tag: programlisting
-#: session_api.xml:452
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Collection blackKittenMates = session.createFilter(\n"
-"    pk.getKittens(), \n"
-"    \"select this.mate where this.color = eg.Color.BLACK.intValue\")\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:454
-#, fuzzy, no-c-format
-msgid ""
 "Even an empty filter query is useful, e.g. to load a subset of elements in a "
 "large collection:"
 msgstr ""
 "Même une requête de filtre vide est utile, par exemple pour charger un sous-"
-"ensemble d'éléments dans une énorme collection :"
+"ensemble d'éléments dans une énorme collection : "
 
-#. Tag: programlisting
-#: session_api.xml:459
-#, no-c-format
-msgid ""
-"<![CDATA[Collection tenKittens = session.createFilter(\n"
-"    mother.getKittens(), \"\")\n"
-"    .setFirstResult(0).setMaxResults(10)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:464
 #, no-c-format
 msgid "Criteria queries"
-msgstr "Requêtes Criteria"
+msgstr "Requêtes par critères"
 
 #. Tag: para
-#: session_api.xml:466
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL is extremely powerful, but some developers prefer to build queries "
 "dynamically using an object-oriented API, rather than building query "
 "strings. Hibernate provides an intuitive <literal>Criteria</literal> query "
 "API for these cases:"
 msgstr ""
-"HQL est extrêmement puissant mais certains développeurs préfèrent construire "
-"des requêtes dynamiquement, en utilisant l'API orientée objet, plutôt que "
-"construire des chaînes de requêtes. Hibernate fournit une API intuitive de "
-"requête <literal>Criteria</literal> pour ces cas :"
+"HQL est extrêmement puissant, mais certains développeurs préfèrent "
+"construire des requêtes dynamiquement, en utilisant l'API orientée objet, "
+"plutôt que de construire des chaînes de requêtes. Hibernate fournit une API "
+"intuitive de requête <literal>Criteria</literal> pour ces cas :"
 
-#. Tag: programlisting
-#: session_api.xml:472
-#, no-c-format
-msgid ""
-"<![CDATA[Criteria crit = session.createCriteria(Cat.class);\n"
-"crit.add( Restrictions.eq( \"color\", eg.Color.BLACK ) );\n"
-"crit.setMaxResults(10);\n"
-"List cats = crit.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:474
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The <literal>Criteria</literal> and the associated <literal>Example</"
-"literal> API are discussed in more detail in <xref linkend=\"querycriteria\"/"
-">."
+"literal> API are discussed in more detail in <xref linkend=\"querycriteria"
+"\" />."
 msgstr ""
-"Les APIs <literal>Criteria</literal> et <literal>Example</literal> associé "
-"sont traitées plus en détail dans <xref linkend=\"querycriteria\"/>."
+"L'API <literal>Criteria</literal> et l'API<literal>Example</literal> associé "
+"sont traités plus en détail dans <xref linkend=\"querycriteria\" />."
 
 #. Tag: title
-#: session_api.xml:482
 #, no-c-format
 msgid "Queries in native SQL"
 msgstr "Requêtes en SQL natif"
 
 #. Tag: para
-#: session_api.xml:484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can express a query in SQL, using <literal>createSQLQuery()</literal> "
 "and let Hibernate manage the mapping from result sets to objects. You can at "
@@ -1086,57 +731,30 @@
 "API, you must enclose SQL aliases in braces:"
 msgstr ""
 "Vous pouvez exprimer une requête en SQL, en utilisant <literal>createSQLQuery"
-"()</literal> et laisser Hibernate s'occuper du mapping des résultats vers "
-"des objets. Notez que vous pouvez n'importe quand appeler <literal>session."
+"()</literal> et laisser Hibernate s'occuper du mappage des résultats vers "
+"des objets. Notez que vous pouvez à tout moment, appeler <literal>session."
 "connection()</literal> et utiliser directement la <literal>Connection</"
 "literal> JDBC. Si vous choisissez d'utiliser l'API Hibernate, vous devez "
-"mettre les alias SQL entre accolades :"
+"mettre les alias SQL entre accolades : "
 
-#. Tag: programlisting
-#: session_api.xml:492
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = session.createSQLQuery(\"SELECT {cat.*} FROM CAT {cat} "
-"WHERE ROWNUM<10\")\n"
-"    .addEntity(\"cat\", Cat.class)\n"
-".list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:494
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = session.createSQLQuery(\n"
-"    \"SELECT {cat}.ID AS {cat.id}, {cat}.SEX AS {cat.sex}, \" +\n"
-"           \"{cat}.MATE AS {cat.mate}, {cat}.SUBCLASS AS {cat.class}, ... \" "
-"+\n"
-"    \"FROM CAT {cat} WHERE ROWNUM<10\")\n"
-"    .addEntity(\"cat\", Cat.class)\n"
-".list()]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:496
 #, fuzzy, no-c-format
 msgid ""
 "SQL queries can contain named and positional parameters, just like Hibernate "
 "queries. More information about native SQL queries in Hibernate can be found "
-"in <xref linkend=\"querysql\"/>."
+"in <xref linkend=\"querysql\" />."
 msgstr ""
 "Les requêtes SQL peuvent contenir des paramètres nommés et positionnels, "
-"comme des requêtes Hibernate. Plus d'informations à propos des requêtes SQL "
-"natives dans Hibernate peuvent être trouvées dans <xref linkend=\"querysql\"/"
-">."
+"comme les requêtes Hibernate. Vous trouverez plus d'informations à propos "
+"des requêtes SQL natives dans Hibernate dans <xref linkend=\"querysql\" />."
 
 #. Tag: title
-#: session_api.xml:507
 #, no-c-format
 msgid "Modifying persistent objects"
 msgstr "Modifier des objets persistants"
 
 #. Tag: para
-#: session_api.xml:509
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Transactional persistent instances</emphasis> (i.e. objects "
 "loaded, saved, created or queried by the <literal>Session</literal>) can be "
@@ -1150,43 +768,31 @@
 msgstr ""
 "Les <emphasis>instances persistantes transactionnelles</emphasis> (c'est-à-"
 "dire des objets chargés, sauvegardés, créés ou requêtés par la "
-"<literal>Session</literal>) peuvent être manipulées par l'application et "
-"n'importe quel changement vers l'état persistant sera persisté lorsque la "
-"<literal>Session</literal> est <emphasis>\"flushée\"</emphasis> (traité plus "
-"tard dans ce chapitre). Il n'y a pas besoin d'appeler une méthode "
-"particulière (comme <literal>update()</literal>, qui a un but différent) "
-"pour rendre vos modifications persistantes. Donc la manière la plus directe "
-"de mettre à jour l'état d'un objet est de le charger avec <literal>load()</"
-"literal>, et puis le manipuler directement, tant que la <literal>Session</"
-"literal> est ouverte :"
+"<literal>Session</literal>) peuvent être manipulés par l'application et tout "
+"changement vers l'état persistant sera persisté lorsque la <literal>Session</"
+"literal> est <emphasis>\"flushée\"</emphasis> (traité plus tard dans ce "
+"chapitre). Il n'est pas nécessaire d'appeler une méthode particulière (comme "
+"<literal>update()</literal>, qui a un but différent) pour rendre vos "
+"modifications persistantes. Donc la manière la plus directe de mettre à jour "
+"l'état d'un objet est de le charger avec <literal>load()</literal>, et puis "
+"de le manipuler directement, tant que la <literal>Session</literal> est "
+"ouverte : "
 
-#. Tag: programlisting
-#: session_api.xml:520
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DomesticCat cat = (DomesticCat) sess.load( Cat.class, new Long"
-"(69) );\n"
-"cat.setName(\"PK\");\n"
-"sess.flush();  // changes to cat are automatically detected and persisted]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:522
-#, fuzzy, no-c-format
-msgid ""
 "Sometimes this programming model is inefficient, as it requires in the same "
 "session both an SQL <literal>SELECT</literal> to load an object and an SQL "
 "<literal>UPDATE</literal> to persist its updated state. Hibernate offers an "
 "alternate approach by using detached instances."
 msgstr ""
 "Parfois ce modèle de programmation est inefficace puisqu'il nécessiterait un "
-"<literal>SELECT</literal> SQL (pour charger l'objet) et un <literal>UPDATE</"
-"literal> SQL (pour persister son état mis à jour) dans la même session. "
-"Aussi Hibernate offre une autre approche, en utilisant des instances "
-"détachées."
+"SQL <literal>SELECT</literal> (pour charger l'objet) et un SQL "
+"<literal>UPDATE</literal> (pour persister son état mis à jour) dans la même "
+"session. Ainsi Hibernate offre une autre approche, en utilisant des "
+"instances détachées. "
 
 #. Tag: para
-#: session_api.xml:529
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate does not offer its own API for direct execution of "
@@ -1198,27 +804,27 @@
 "the notion of mass operations conflicts with object/relational mapping for "
 "online transaction processing-oriented applications. Future versions of "
 "Hibernate can, however, provide special mass operation functions. See <xref "
-"linkend=\"batch\"/> for some possible batch operation tricks."
+"linkend=\"batch\" /> for some possible batch operation tricks."
 msgstr ""
 "Notez que Hibernate n'offre par sa propre API pour l'exécution directe "
-"d'expressions <placeholder-1/> ou <placeholder-2/>. Hibernate est un service "
-"de <placeholder-3/>, vous n'avez pas à penser aux <placeholder-4/> pour "
-"l'utiliser. JDBC est une API parfaite pour exécuter des expressions SQL, "
-"vous pouvez obtenir une <placeholder-5/> JDBC n'importe quand en appelant "
-"<placeholder-6/>. En outre, la notion d'opérations de masse entre en conflit "
-"avec le mapping objet/relationnel pour les applications orientées processus "
-"de transactions en ligne. Les futures versions d'Hibernate peuvent cependant "
-"fournir des fonctions d'opération de masse. Voir <xref linkend=\"batch\"/> "
-"pour les astuces possibles d'opérations groupées."
+"d'expressions <literal>UPDATE</literal> ou <literal>DELETE</literal>. "
+"Hibernate est un service de <emphasis>gestion d'état</emphasis>, vous n'avez "
+"pas à penser aux <emphasis>expressions</emphasis> pour l'utiliser. JDBC est "
+"une API parfaite pour exécuter des expressions SQL, vous pouvez obtenir une "
+"<literal>Connection</literal> JDBC à tout moment en appelant "
+"<literal>session.connection()</literal>. En outre, la notion d'opérations de "
+"masse entre en conflit avec le mapping objet/relationnel pour les "
+"applications orientées processus de transactions en ligne. Les futures "
+"versions de Hibernate pourront cependant fournir des fonctions particulières "
+"d'opération de masse. Voir <xref linkend=\"batch\" /> pour des astuces "
+"possibles d'opérations groupées. "
 
 #. Tag: title
-#: session_api.xml:546
 #, no-c-format
 msgid "Modifying detached objects"
 msgstr "Modifier des objets détachés"
 
 #. Tag: para
-#: session_api.xml:548
 #, no-c-format
 msgid ""
 "Many applications need to retrieve an object in one transaction, send it to "
@@ -1228,43 +834,24 @@
 "unit of work."
 msgstr ""
 "Beaucoup d'applications ont besoin de récupérer un objet dans une "
-"transaction, l'envoyer à la couche interfacée avec l'utilisateur pour les "
-"manipulations, puis sauvegarder les changements dans une nouvelle "
+"transaction, de l'envoyer à la couche interfacée avec l'utilisateur pour les "
+"manipulations, et de sauvegarder les changements dans une nouvelle "
 "transaction. Les applications qui utilisent cette approche dans un "
 "environnement à haute concurrence utilisent généralement des données "
-"versionnées pour assurer l'isolation pour les \"longues\" unités de travail."
+"versionnées pour assurer l'isolation des \"longues\" unités de travail."
 
 #. Tag: para
-#: session_api.xml:555
 #, no-c-format
 msgid ""
 "Hibernate supports this model by providing for reattachment of detached "
 "instances using the <literal>Session.update()</literal> or <literal>Session."
 "merge()</literal> methods:"
 msgstr ""
-"Hibernate supporte ce modèle en permettant pour le réattachement d'instances "
-"détachées l'utilisation des méthodes <literal>Session.update()</literal> ou "
+"Hibernate supporte ce modèle en permettant pour le rattachement d'instances "
+"détachées en utilisant des méthodes <literal>Session.update()</literal> ou "
 "<literal>Session.merge()</literal> :"
 
-#. Tag: programlisting
-#: session_api.xml:561
-#, no-c-format
-msgid ""
-"<![CDATA[// in the first session\n"
-"Cat cat = (Cat) firstSession.load(Cat.class, catId);\n"
-"Cat potentialMate = new Cat();\n"
-"firstSession.save(potentialMate);\n"
-"\n"
-"// in a higher layer of the application\n"
-"cat.setMate(potentialMate);\n"
-"\n"
-"// later, in a new session\n"
-"secondSession.update(cat);  // update cat\n"
-"secondSession.update(mate); // update mate]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:563
 #, no-c-format
 msgid ""
 "If the <literal>Cat</literal> with identifier <literal>catId</literal> had "
@@ -1273,11 +860,10 @@
 msgstr ""
 "Si le <literal>Cat</literal> avec l'identifiant <literal>catId</literal> "
 "avait déjà été chargé par <literal>secondSession</literal> lorsque "
-"l'application a essayé de le réattacher, une exception aurait été levée."
+"l'application a essayé de le rattacher, une exception aurait été levée."
 
 #. Tag: para
-#: session_api.xml:569
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use <literal>update()</literal> if you are certain that the session does not "
 "contain an already persistent instance with the same identifier. Use "
@@ -1287,89 +873,70 @@
 "fresh session, ensuring that the reattachment of your detached instances is "
 "the first operation that is executed."
 msgstr ""
-"Utilisez <literal>update()</literal> si vous êtes sure que la session ne "
+"Utilisez <literal>update()</literal> si vous êtes sûr que la session ne "
 "contient pas déjà une instance persistante avec le même identifiant, et "
 "<literal>merge()</literal> si vous voulez fusionner vos modifications "
-"n'importe quand sans considérer l'état de la session. En d'autres mots, "
+"n'importe quand sans considérer l'état de la session. En d'autres termes, "
 "<literal>update()</literal> est généralement la première méthode que vous "
-"devriez appeler dans une session fraîche, pour s'assurer que le "
-"réattachement de vos instances détachées est la première opération qui est "
-"exécutée."
+"devez appeler dans une session fraîche, pour vous assurer que le "
+"rattachement de vos instances détachées est la première opération qui est "
+"exécutée. "
 
 #. Tag: para
-#: session_api.xml:578
 #, fuzzy, no-c-format
 msgid ""
 "The application should individually <literal>update()</literal> detached "
 "instances that are reachable from the given detached instance "
 "<emphasis>only</emphasis> if it wants their state to be updated. This can be "
 "automated using <emphasis>transitive persistence</emphasis>. See <xref "
-"linkend=\"objectstate-transitive\"/> for more information."
+"linkend=\"objectstate-transitive\" /> for more information."
 msgstr ""
 "L'application devrait individuellement <literal>update()</literal> (NdT : "
 "mettre à jour) les instances détachées accessibles depuis l'instance "
 "détachée donnée si et <emphasis>seulement</emphasis> si elle veut que leur "
 "état soit aussi mis à jour. Ceci peut être automatisé bien sûr, en utilisant "
-"la <emphasis>persistance transitive</emphasis>, voir <xref linkend="
-"\"objectstate-transitive\"/>."
+"la <emphasis>persistance transitive</emphasis>. Voir <xref linkend="
+"\"objectstate-transitive\" /> pour plus d'informations."
 
 #. Tag: para
-#: session_api.xml:585
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>lock()</literal> method also allows an application to "
 "reassociate an object with a new session. However, the detached instance has "
 "to be unmodified."
 msgstr ""
-"La méthode <literal>lock()</literal> permet aussi à une application de "
-"réassocier un objet avec une nouvelle session. Pourtant, l'instance détachée "
-"doit être non modifiée !"
+"La méthode <literal>lock()</literal> permet aussi à une application de ré-"
+"associer un objet avec une nouvelle session. Cependant, l'instance détachée "
+"doit être non modifiée."
 
-#. Tag: programlisting
-#: session_api.xml:590
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[//just reassociate:\n"
-"sess.lock(fritz, LockMode.NONE);\n"
-"//do a version check, then reassociate:\n"
-"sess.lock(izi, LockMode.READ);\n"
-"//do a version check, using SELECT ... FOR UPDATE, then reassociate:\n"
-"sess.lock(pk, LockMode.UPGRADE);]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:592
-#, fuzzy, no-c-format
-msgid ""
 "Note that <literal>lock()</literal> can be used with various "
 "<literal>LockMode</literal>s. See the API documentation and the chapter on "
 "transaction handling for more information. Reattachment is not the only "
 "usecase for <literal>lock()</literal>."
 msgstr ""
 "Notez que <literal>lock()</literal> peut être utilisé avec différents "
-"<literal>LockMode</literal>s, voir la documentation de l'API documentation "
-"et le chapitre sur la gestion des transactions pour plus d'informations. Le "
-"réattachement n'est pas le seul cas d'utilisation pour <literal>lock()</"
-"literal>."
+"<literal>LockMode</literal> s, voir la documentation de l'API et le chapitre "
+"sur la gestion des transactions pour plus d'informations. Le rattachement "
+"n'est pas le seul cas d'utilisation pour <literal>lock()</literal>. "
 
 #. Tag: para
-#: session_api.xml:599
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Other models for long units of work are discussed in <xref linkend="
-"\"transactions-optimistic\"/>."
+"\"transactions-optimistic\" />."
 msgstr ""
 "D'autres modèles pour de longues unités de travail sont traités dans <xref "
-"linkend=\"transactions-optimistic\"/>."
+"linkend=\"transactions-optimistic\" />."
 
 #. Tag: title
-#: session_api.xml:606
 #, no-c-format
 msgid "Automatic state detection"
 msgstr "Détection automatique d'un état"
 
 #. Tag: para
-#: session_api.xml:608
 #, no-c-format
 msgid ""
 "Hibernate users have requested a general purpose method that either saves a "
@@ -1379,30 +946,11 @@
 msgstr ""
 "Les utilisateurs d'Hibernate ont demandé une méthode dont l'intention "
 "générale serait soit de sauvegarder une instance éphémère en générant un "
-"nouvel identifiant, soit mettre à jour/réattacher les instances détachées "
+"nouvel identifiant, soit mettre à jour/rattacher les instances détachées "
 "associées à l'identifiant courant. La méthode <literal>saveOrUpdate()</"
 "literal> implémente cette fonctionnalité."
 
-#. Tag: programlisting
-#: session_api.xml:615
-#, no-c-format
-msgid ""
-"<![CDATA[// in the first session\n"
-"Cat cat = (Cat) firstSession.load(Cat.class, catID);\n"
-"\n"
-"// in a higher tier of the application\n"
-"Cat mate = new Cat();\n"
-"cat.setMate(mate);\n"
-"\n"
-"// later, in a new session\n"
-"secondSession.saveOrUpdate(cat);   // update existing state (cat has a non-"
-"null id)\n"
-"secondSession.saveOrUpdate(mate);  // save the new instance (mate has a null "
-"id)]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:617
 #, no-c-format
 msgid ""
 "The usage and semantics of <literal>saveOrUpdate()</literal> seems to be "
@@ -1420,7 +968,6 @@
 "applications n'utiliseront jamais ces méthodes."
 
 #. Tag: para
-#: session_api.xml:625
 #, no-c-format
 msgid ""
 "Usually <literal>update()</literal> or <literal>saveOrUpdate()</literal> are "
@@ -1430,53 +977,45 @@
 "literal> sont utilisées dans le scénario suivant :"
 
 #. Tag: para
-#: session_api.xml:632
 #, no-c-format
 msgid "the application loads an object in the first session"
 msgstr "l'application charge un objet dans la première session"
 
 #. Tag: para
-#: session_api.xml:637
 #, no-c-format
 msgid "the object is passed up to the UI tier"
 msgstr "l'objet est passé à la couche utilisateur"
 
 #. Tag: para
-#: session_api.xml:642
 #, no-c-format
 msgid "some modifications are made to the object"
 msgstr "certaines modifications sont effectuées sur l'objet"
 
 #. Tag: para
-#: session_api.xml:647
 #, no-c-format
 msgid "the object is passed back down to the business logic tier"
 msgstr "l'objet est retourné à la couche logique métier"
 
 #. Tag: para
-#: session_api.xml:652
 #, no-c-format
 msgid ""
 "the application persists these modifications by calling <literal>update()</"
 "literal> in a second session"
 msgstr ""
 "l'application persiste ces modifications en appelant <literal>update()</"
-"literal> dans une seconde sessin"
+"literal> dans une seconde session"
 
 #. Tag: para
-#: session_api.xml:659
 #, no-c-format
 msgid "<literal>saveOrUpdate()</literal> does the following:"
 msgstr "<literal>saveOrUpdate()</literal> s'utilise dans le cas suivant :"
 
 #. Tag: para
-#: session_api.xml:665
 #, no-c-format
 msgid "if the object is already persistent in this session, do nothing"
 msgstr "si l'objet est déjà persistant dans cette session, ne rien faire"
 
 #. Tag: para
-#: session_api.xml:670
 #, no-c-format
 msgid ""
 "if another object associated with the session has the same identifier, throw "
@@ -1486,7 +1025,6 @@
 "exception"
 
 #. Tag: para
-#: session_api.xml:676
 #, no-c-format
 msgid "if the object has no identifier property, <literal>save()</literal> it"
 msgstr ""
@@ -1494,7 +1032,6 @@
 "literal>"
 
 #. Tag: para
-#: session_api.xml:681
 #, no-c-format
 msgid ""
 "if the object's identifier has the value assigned to a newly instantiated "
@@ -1504,8 +1041,7 @@
 "instancié, appeler <literal>save()</literal>"
 
 #. Tag: para
-#: session_api.xml:687
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "if the object is versioned by a <literal>&lt;version&gt;</literal> or "
 "<literal>&lt;timestamp&gt;</literal>, and the version property value is the "
@@ -1515,22 +1051,19 @@
 "si l'objet est versionné (par <literal>&lt;version&gt;</literal> ou "
 "<literal>&lt;timestamp&gt;</literal>), et la valeur de la propriété de "
 "version est la même valeur que celle assignée à un objet nouvellement "
-"instancié, appeler <literal>save()</literal>"
+"instancié, appeler <literal>save()</literal> "
 
 #. Tag: para
-#: session_api.xml:695
 #, no-c-format
 msgid "otherwise <literal>update()</literal> the object"
 msgstr "sinon mettre à jour l'objet avec <literal>update()</literal>"
 
 #. Tag: para
-#: session_api.xml:701
 #, no-c-format
 msgid "and <literal>merge()</literal> is very different:"
 msgstr "et <literal>merge()</literal> est très différent :"
 
 #. Tag: para
-#: session_api.xml:707
 #, no-c-format
 msgid ""
 "if there is a persistent instance with the same identifier currently "
@@ -1538,11 +1071,10 @@
 "persistent instance"
 msgstr ""
 "s'il y a une instance persistante avec le même identifiant couramment "
-"associée à la session, copier l'état de l'objet donné dans l'instance "
+"associé à la session, copier l'état de l'objet donné dans l'instance "
 "persistante"
 
 #. Tag: para
-#: session_api.xml:714
 #, no-c-format
 msgid ""
 "if there is no persistent instance currently associated with the session, "
@@ -1553,13 +1085,11 @@
 "persistante"
 
 #. Tag: para
-#: session_api.xml:720
 #, no-c-format
 msgid "the persistent instance is returned"
 msgstr "l'instance persistante est retournée"
 
 #. Tag: para
-#: session_api.xml:725
 #, no-c-format
 msgid ""
 "the given instance does not become associated with the session, it remains "
@@ -1568,14 +1098,12 @@
 "l'instance donnée ne devient pas associée à la session, elle reste détachée"
 
 #. Tag: title
-#: session_api.xml:735
 #, no-c-format
 msgid "Deleting persistent objects"
 msgstr "Suppression d'objets persistants"
 
 #. Tag: para
-#: session_api.xml:737
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Session.delete()</literal> will remove an object's state from the "
 "database. Your application, however, can still hold a reference to a deleted "
@@ -1584,18 +1112,11 @@
 msgstr ""
 "<literal>Session.delete()</literal> supprimera l'état d'un objet de la base "
 "de données. Bien sûr, votre application pourrait encore conserver une "
-"référence vers un objet effacé. Il est mieux de penser à <literal>delete()</"
-"literal> comme rendant une instance persistante éphémère."
+"référence vers un objet effacé. Il est préférable de penser à <literal>delete"
+"()</literal> comme rendant une instance persistante éphémère. "
 
-#. Tag: programlisting
-#: session_api.xml:744
-#, no-c-format
-msgid "<![CDATA[sess.delete(cat);]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:746
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can delete objects in any order, without risk of foreign key constraint "
 "violations. It is still possible to violate a <literal>NOT NULL</literal> "
@@ -1605,18 +1126,16 @@
 "Vous pouvez effacer des objets dans l'ordre que vous voulez, sans risque de "
 "violations de contrainte de clef étrangère. Il est encore possible de violer "
 "une contrainte <literal>NOT NULL</literal> sur une colonne de clef étrangère "
-"en effaçant des objets dans le mauvais ordre, par exemple si vous effacer le "
-"parent, mais oubliez d'effacer les enfants."
+"en effaçant des objets dans le mauvais ordre, par exemple si vous effacez le "
+"parent, mais oubliez d'effacer les enfants. "
 
 #. Tag: title
-#: session_api.xml:757
 #, no-c-format
 msgid "Replicating object between two different datastores"
 msgstr "Réplication d'objets entre deux entrepôts de données"
 
 #. Tag: para
-#: session_api.xml:759
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is sometimes useful to be able to take a graph of persistent instances "
 "and make them persistent in a different datastore, without regenerating "
@@ -1624,82 +1143,57 @@
 msgstr ""
 "Il est occasionnellement utile de pouvoir prendre un graphe d'instances "
 "persistantes et de les rendre persistantes dans un entrepôt différent, sans "
-"regénérer les valeurs des identifiants."
+"regénérer les valeurs des identifiants. "
 
-#. Tag: programlisting
-#: session_api.xml:765
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[//retrieve a cat from one database\n"
-"Session session1 = factory1.openSession();\n"
-"Transaction tx1 = session1.beginTransaction();\n"
-"Cat cat = session1.get(Cat.class, catId);\n"
-"tx1.commit();\n"
-"session1.close();\n"
-"\n"
-"//reconcile with a second database\n"
-"Session session2 = factory2.openSession();\n"
-"Transaction tx2 = session2.beginTransaction();\n"
-"session2.replicate(cat, ReplicationMode.LATEST_VERSION);\n"
-"tx2.commit();\n"
-"session2.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:767
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>ReplicationMode</literal> determines how <literal>replicate()</"
 "literal> will deal with conflicts with existing rows in the database:"
 msgstr ""
 "Le <literal>ReplicationMode</literal> détermine comment <literal>replicate()"
-"</literal> traitera les conflits avec les lignes existantes dans la base de "
-"données."
+"</literal> traitera les conflits avec des lignes existantes dans la base de "
+"données. "
 
 #. Tag: para
-#: session_api.xml:774
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.IGNORE</literal>: ignores the object when there is "
 "an existing database row with the same identifier"
 msgstr ""
 "<literal>ReplicationMode.IGNORE</literal> - ignore l'objet s'il y a une "
-"ligne existante dans la base de données avec le même identifiant"
+"ligne existante dans la base de données avec le même identifiant "
 
 #. Tag: para
-#: session_api.xml:780
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.OVERWRITE</literal>: overwrites any existing "
 "database row with the same identifier"
 msgstr ""
 "<literal>ReplicationMode.OVERWRITE</literal> - écrase n'importe quelle ligne "
-"existante dans la base de données avec le même identifiant"
+"existante dans la base de données avec le même identifiant "
 
 #. Tag: para
-#: session_api.xml:786
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.EXCEPTION</literal>: throws an exception if there "
 "is an existing database row with the same identifier"
 msgstr ""
-"<literal>ReplicationMode.EXCEPTION</literal> - lève une exception s'il y une "
-"ligne dans la base de données avec le même identifiant"
+"<literal>ReplicationMode.EXCEPTION</literal> - lève une exception s'il y a "
+"une ligne dans la base de données avec le même identifiant "
 
 #. Tag: para
-#: session_api.xml:792
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.LATEST_VERSION</literal>: overwrites the row if its "
 "version number is earlier than the version number of the object, or ignore "
 "the object otherwise"
 msgstr ""
 "<literal>ReplicationMode.LATEST_VERSION</literal> - écrase la ligne si son "
-"numéro de version est plus petit que le numéro de version de l'objet, ou "
-"ignore l'objet sinon"
+"numéro de version est plus petit que le numéro de version de l'objet, sinon "
+"ignore l'objet  "
 
 #. Tag: para
-#: session_api.xml:800
 #, no-c-format
 msgid ""
 "Usecases for this feature include reconciling data entered into different "
@@ -1714,14 +1208,12 @@
 "ACID, et plus."
 
 #. Tag: title
-#: session_api.xml:809
 #, no-c-format
 msgid "Flushing the Session"
 msgstr "Flush de la session"
 
 #. Tag: para
-#: session_api.xml:811
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes the <literal>Session</literal> will execute the SQL statements "
 "needed to synchronize the JDBC connection's state with the state of objects "
@@ -1729,93 +1221,81 @@
 "default at the following points:"
 msgstr ""
 "De temps en temps la <literal>Session</literal> exécutera les expressions "
-"SQL requises pour syncrhoniser l'état de la connexion JDBC avec l'état des "
-"objets retenus en mémoire. Ce processus, <emphasis>flush</emphasis>, arrive "
-"par défaut aux points suivants :"
+"SQL requises pour synchroniser l'état de la connexion JDBC avec l'état des "
+"objets retenus en mémoire. Ce processus, <emphasis>flush</emphasis>, "
+"survient par défaut aux points suivants : "
 
 #. Tag: para
-#: session_api.xml:820
 #, no-c-format
 msgid "before some query executions"
-msgstr "lors de certaines exécutions de requête"
+msgstr "avant certaines exécutions de requête"
 
 #. Tag: para
-#: session_api.xml:825
 #, no-c-format
 msgid "from <literal>org.hibernate.Transaction.commit()</literal>"
 msgstr ""
 "lors d'un appel à <literal>org.hibernate.Transaction.commit()</literal>"
 
 #. Tag: para
-#: session_api.xml:830
 #, no-c-format
 msgid "from <literal>Session.flush()</literal>"
 msgstr "lors d'un appel à <literal>Session.flush()</literal>"
 
 #. Tag: para
-#: session_api.xml:836
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The SQL statements are issued in the following order:"
-msgstr "Les expressions SQL sont effectuées dans l'ordre suivant :"
+msgstr "Les expressions SQL sont effectuées dans l'ordre suivant : "
 
 #. Tag: para
-#: session_api.xml:842
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "all entity insertions in the same order the corresponding objects were saved "
 "using <literal>Session.save()</literal>"
 msgstr ""
 "insertion des entités, dans le même ordre que celui des objets "
-"correspondants sauvegardés par l'appel à <literal>Session.save()</literal>"
+"correspondants sauvegardés par l'appel à <literal>Session.save()</literal> "
 
 #. Tag: para
-#: session_api.xml:848
 #, no-c-format
 msgid "all entity updates"
-msgstr "mise à jours des entités"
+msgstr "mise à jour des entités"
 
 #. Tag: para
-#: session_api.xml:853
 #, no-c-format
 msgid "all collection deletions"
 msgstr "suppression des collections"
 
 #. Tag: para
-#: session_api.xml:858
 #, no-c-format
 msgid "all collection element deletions, updates and insertions"
 msgstr "suppression, mise à jour et insertion des éléments des collections"
 
 #. Tag: para
-#: session_api.xml:863
 #, no-c-format
 msgid "all collection insertions"
 msgstr "insertion des collections"
 
 #. Tag: para
-#: session_api.xml:868
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "all entity deletions in the same order the corresponding objects were "
 "deleted using <literal>Session.delete()</literal>"
 msgstr ""
 "suppression des entités, dans le même ordre que celui des objets "
-"correspondants qui ont été supprimés par l'appel à <literal>Session.delete()"
-"</literal>"
+"correspondants qui ont été supprimés par l'appel de <literal>Session.delete()"
+"</literal> "
 
 #. Tag: para
-#: session_api.xml:875
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An exception is that objects using <literal>native</literal> ID generation "
 "are inserted when they are saved."
 msgstr ""
-"(Une exception est que des objets utilisant la génération <literal>native</"
-"literal> d'identifiants sont insérés lorsqu'ils sont sauvegardés.)"
+"Une exception est que des objets utilisant la génération <literal>native</"
+"literal> d'identifiants sont insérés lorsqu'ils sont sauvegardés."
 
 #. Tag: para
-#: session_api.xml:880
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Except when you explicitly <literal>flush()</literal>, there are absolutely "
 "no guarantees about <emphasis>when</emphasis> the <literal>Session</literal> "
@@ -1824,14 +1304,13 @@
 "(..)</literal> will never return stale or incorrect data."
 msgstr ""
 "Excepté lorsque vous appelez <literal>flush()</literal> explicitement, il "
-"n'y absolument aucune garantie à propos de <emphasis>quand</emphasis> la "
+"n'y a absolument aucune garantie à propos de <emphasis>quand</emphasis> la "
 "<literal>Session</literal> exécute les appels JDBC, seulement sur "
 "l'<emphasis>ordre</emphasis> dans lequel ils sont exécutés. Cependant, "
 "Hibernate garantit que <literal>Query.list(..)</literal> ne retournera "
-"jamais de données périmées, ni des données fausses."
+"jamais de données périmées, ni des données fausses. "
 
 #. Tag: para
-#: session_api.xml:888
 #, fuzzy, no-c-format
 msgid ""
 "It is possible to change the default behavior so that flush occurs less "
@@ -1841,73 +1320,49 @@
 "never flush unless <literal>flush()</literal> is called explicitly. The last "
 "mode is useful for long running units of work, where a <literal>Session</"
 "literal> is kept open and disconnected for a long time (see <xref linkend="
-"\"transactions-optimistic-longsession\"/>)."
+"\"transactions-optimistic-longsession\" />)."
 msgstr ""
 "Il est possible de changer le comportement par défaut, donc que le flush se "
 "produise moins fréquemment. La classe <literal>FlushMode</literal> définit "
 "trois modes différents : flush seulement lors du commit (et seulement quand "
-"l'API <literal>Transaction</literal> d'Hibernate est utilisée), flush "
-"automatiquement en utilisant la procédure expliquée, ou jamais de flush à "
-"moins que <literal>flush()</literal> soit appelée explicitement. Le dernier "
-"mode est utile pour l'exécution de longues unités de travail, où une "
+"l'API <literal>Transaction</literal> de Hibernate est utilisé), flush "
+"automatiquement en utilisant la procédure courante expliquée, ou jamais de "
+"flush à moins que <literal>flush()</literal> soit appelé explicitement. Le "
+"dernier mode est utile pour l'exécution de longues unités de travail, où une "
 "<literal>Session</literal> est gardée ouverte et déconnectée pour un long "
-"moment (voir <xref linkend=\"transactions-optimistic-longsession\"/>)."
+"moment (voir <xref linkend=\"transactions-optimistic-longsession\" />)."
 
-#. Tag: programlisting
-#: session_api.xml:898
-#, no-c-format
-msgid ""
-"<![CDATA[sess = sf.openSession();\n"
-"Transaction tx = sess.beginTransaction();\n"
-"sess.setFlushMode(FlushMode.COMMIT); // allow queries to return stale state\n"
-"\n"
-"Cat izi = (Cat) sess.load(Cat.class, id);\n"
-"izi.setName(iznizi);\n"
-"\n"
-"// might return stale data\n"
-"sess.find(\"from Cat as cat left outer join cat.kittens kitten\");\n"
-"\n"
-"// change to izi is not flushed!\n"
-"...\n"
-"tx.commit(); // flush occurs\n"
-"sess.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:900
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "During flush, an exception might occur (e.g. if a DML operation violates a "
 "constraint). Since handling exceptions involves some understanding of "
 "Hibernate's transactional behavior, we discuss it in <xref linkend="
-"\"transactions\"/>."
+"\"transactions\" />."
 msgstr ""
 "Durant le flush, une exception peut se produire (par exemple, si une "
-"opération de la DML viole une contrainte). Puisque les exceptions de gestion "
-"impliquent une certaine compréhension du comportement transactionnel "
-"d'Hibernate, nous le traitons dans <xref linkend=\"transactions\"/>."
+"opération de la DML viole une contrainte). Les exceptions de gestion "
+"impliquent une certaine compréhension du comportement transactionnel de "
+"Hibernate, le sujet sera donc abordé dans <xref linkend=\"transactions\" />."
 
 #. Tag: title
-#: session_api.xml:909
 #, no-c-format
 msgid "Transitive persistence"
 msgstr "Persistance transitive"
 
 #. Tag: para
-#: session_api.xml:911
 #, no-c-format
 msgid ""
 "It is quite cumbersome to save, delete, or reattach individual objects, "
 "especially if you deal with a graph of associated objects. A common case is "
 "a parent/child relationship. Consider the following example:"
 msgstr ""
-"Il est assez pénible de sauvegarder, supprimer, ou réattacher des objets un "
-"par un, surtout si vous traitez un graphe d'objets associés. Un cas habituel "
+"Il est assez pénible de sauvegarder, supprimer, ou rattacher des objets un "
+"par un, surtout si vous traitez un graphe d'objets associés. Un cas courant "
 "est une relation parent/enfant. Considérez l'exemple suivant :"
 
 #. Tag: para
-#: session_api.xml:917
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the children in a parent/child relationship would be value typed (e.g. a "
 "collection of addresses or strings), their life cycle would depend on the "
@@ -1920,18 +1375,17 @@
 msgstr ""
 "Si les enfants de la relation parent/enfant étaient des types de valeur (par "
 "exemple, une collection d'adresses ou de chaînes de caractères), leur cycle "
-"de vie dépendraient du parent et aucune action ne serait requise pour "
+"de vie dépendrait du parent et aucune action ne serait requise pour "
 "\"cascader\" facilement les changements d'état. Si le parent est sauvegardé, "
 "les objets enfants de type de valeur sont sauvegardés également, si le "
 "parent est supprimé, les enfants sont supprimés, etc. Ceci fonctionne même "
 "pour des opérations telles que la suppression d'un enfant de la collection ; "
-"Hibernate détectera cela et, puisque les objets de type de valeur ne peuvent "
-"pas avoir des références partagées, supprimera l'enfant de la base de "
-"données."
+"Hibernate le détectera et étant donné que les objets de type de valeur ne "
+"peuvent pas avoir de références partagées, il supprimera l'enfant de la base "
+"de données. "
 
 #. Tag: para
-#: session_api.xml:928
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now consider the same scenario with parent and child objects being entities, "
 "not value-types (e.g. categories and items, or parent and child cats). "
@@ -1941,17 +1395,16 @@
 "entities. Hibernate does not implement <emphasis>persistence by "
 "reachability</emphasis> by default."
 msgstr ""
-"Maintenant considérez le même scénario avec un parent et dont les objets "
+"Maintenant considérez le même scénario avec un parent dont les objets "
 "enfants sont des entités, et non des types de valeur (par exemple, des "
 "catégories et des objets, ou un parent et des chatons). Les entités ont leur "
 "propre cycle de vie, supportent les références partagées (donc supprimer une "
 "entité de la collection ne signifie pas qu'elle peut être supprimée), et il "
 "n'y a par défaut pas de cascade d'état d'une entité vers n'importe quelle "
 "entité associée. Hibernate n'implémente pas la <emphasis>persistance par "
-"accessibilité</emphasis> par défaut."
+"accessibilité</emphasis> par défaut. "
 
 #. Tag: para
-#: session_api.xml:937
 #, no-c-format
 msgid ""
 "For each basic operation of the Hibernate session - including "
@@ -1962,37 +1415,22 @@
 "operation to be cascaded along an association, you must indicate that in the "
 "mapping document. For example:"
 msgstr ""
-"Pour chaque opération basique de la session d'Hibernate - incluant "
+"Pour chaque opération basique de la session Hibernate - incluant "
 "<literal>persist(), merge(), saveOrUpdate(), delete(), lock(), refresh(), "
 "evict(), replicate()</literal> - il y a un style de cascade correspondant. "
 "Respectivement, les styles de cascade s'appellent <literal>persist, merge, "
 "save-update, delete, lock, refresh, evict, replicate</literal>. Si vous "
 "voulez qu'une opération soit cascadée le long d'une association, vous devez "
-"l'indiquer dans le document de mapping. Par exemple :"
+"l'indiquer dans le document de mappage. Par exemple :"
 
-#. Tag: programlisting
-#: session_api.xml:946
-#, no-c-format
-msgid "<![CDATA[<one-to-one name=\"person\" cascade=\"persist\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:948
 #, no-c-format
 msgid "Cascade styles my be combined:"
 msgstr "Les styles de cascade peuvent être combinés :"
 
-#. Tag: programlisting
-#: session_api.xml:952
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<one-to-one name=\"person\" cascade=\"persist,delete,lock\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:954
-#, fuzzy, no-c-format
-msgid ""
 "You can even use <literal>cascade=\"all\"</literal> to specify that "
 "<emphasis>all</emphasis> operations should be cascaded along the "
 "association. The default <literal>cascade=\"none\"</literal> specifies that "
@@ -2001,10 +1439,9 @@
 "Vous pouvez même utiliser <literal>cascade=\"all\"</literal> pour spécifier "
 "que <emphasis>toutes</emphasis> les opérations devraient être cascadées le "
 "long de l'association. La valeur par défaut <literal>cascade=\"none\"</"
-"literal> spécifie qu'aucune opération ne sera cascadée."
+"literal> spécifie qu'aucune opération ne sera cascadée. "
 
 #. Tag: para
-#: session_api.xml:960
 #, no-c-format
 msgid ""
 "A special cascade style, <literal>delete-orphan</literal>, applies only to "
@@ -2012,20 +1449,18 @@
 "operation should be applied to any child object that is removed from the "
 "association."
 msgstr ""
-"Une style de cascade spécial, <literal>delete-orphan</literal>, s'applique "
-"seulement aux associations un-vers-plusieurs, et indique que l'opération "
-"<literal>delete()</literal> devrait être appliquée à n'importe quel enfant "
-"qui est supprimé de l'association."
+"Un style de cascade spécial, <literal>delete-orphan</literal>, s'applique "
+"seulement aux associations un-à-plusieurs, et indique que l'opération "
+"<literal>delete()</literal> devrait être appliquée à tout enfant supprimé de "
+"l'association."
 
 #. Tag: para
-#: session_api.xml:967
 #, no-c-format
 msgid "Recommendations:"
 msgstr "Recommandations :"
 
 #. Tag: para
-#: session_api.xml:973
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It does not usually make sense to enable cascade on a <literal>&lt;many-to-"
 "one&gt;</literal> or <literal>&lt;many-to-many&gt;</literal> association. "
@@ -2036,10 +1471,9 @@
 "<literal>&lt;many-to-one&gt;</literal> ou <literal>&lt;many-to-many&gt;</"
 "literal>. Les cascades sont souvent utiles pour des associations "
 "<literal>&lt;one-to-one&gt;</literal> et <literal>&lt;one-to-many&gt;</"
-"literal>."
+"literal>. "
 
 #. Tag: para
-#: session_api.xml:981
 #, no-c-format
 msgid ""
 "If the child object's lifespan is bounded by the lifespan of the parent "
@@ -2047,11 +1481,10 @@
 "<literal>cascade=\"all,delete-orphan\"</literal>."
 msgstr ""
 "Si la durée de vie de l'objet enfant est liée à la durée de vie de l'objet "
-"parent, faites en un <emphasis>objet du cycle de vie</emphasis> en "
-"spécifiant <literal>cascade=\"all,delete-orphan\"</literal>."
+"parent, faites-en un <emphasis>objet du cycle de vie</emphasis> en "
+"spécifiant <literal>cascade=\"all,delete-orphan\"</literal>. "
 
 #. Tag: para
-#: session_api.xml:988
 #, no-c-format
 msgid ""
 "Otherwise, you might not need cascade at all. But if you think that you will "
@@ -2063,10 +1496,9 @@
 "pensez que vous travaillerez souvent avec le parent et les enfants ensemble "
 "dans la même transaction, et que vous voulez vous éviter quelques frappes, "
 "considérez l'utilisation de <literal>cascade=\"persist,merge,save-update\"</"
-"literal>."
+"literal>. "
 
 #. Tag: para
-#: session_api.xml:996
 #, no-c-format
 msgid ""
 "Mapping an association (either a single valued association, or a collection) "
@@ -2081,8 +1513,7 @@
 "jour/suppression de l'enfant ou des enfants."
 
 #. Tag: para
-#: session_api.xml:1002
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Furthermore, a mere reference to a child from a persistent parent will "
 "result in save/update of the child. This metaphor is incomplete, however. A "
@@ -2092,16 +1523,15 @@
 "literal>. The precise semantics of cascading operations for a parent/child "
 "relationship are as follows:"
 msgstr ""
-"En outre, une simple référence à un enfant d'un parent persistant aura pour "
-"conséquence la sauvegarde/mise à jour de l'enfant. Cette métaphore est "
+"Par ailleurs, une simple référence à un enfant d'un parent persistant aura "
+"pour conséquence la sauvegarde/mise à jour de l'enfant. Cette métaphore est "
 "cependant incomplète. Un enfant qui devient non référencé par son parent "
-"<emphasis>n'est pas</emphasis> automatiquement supprimée, excepté dans le "
-"cas d'une association <literal>&lt;one-to-many&gt;</literal> mappée avec "
+"<emphasis>n'est pas</emphasis> automatiquement supprimé, sauf dans le cas "
+"d'une association <literal>&lt;one-to-many&gt;</literal> mappée avec "
 "<literal>cascade=\"delete-orphan\"</literal>. La sémantique précise des "
-"opérations de cascade pour une relation parent/enfant est la suivante :"
+"opérations de cascade pour une relation parent/enfant est la suivante : "
 
 #. Tag: para
-#: session_api.xml:1013
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>persist()</literal>, all children are "
@@ -2111,7 +1541,6 @@
 "passés à <literal>persist()</literal>"
 
 #. Tag: para
-#: session_api.xml:1019
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>merge()</literal>, all children are passed "
@@ -2121,7 +1550,6 @@
 "passés à <literal>merge()</literal>"
 
 #. Tag: para
-#: session_api.xml:1025
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>save()</literal>, <literal>update()</"
@@ -2133,7 +1561,6 @@
 "à <literal>saveOrUpdate()</literal>"
 
 #. Tag: para
-#: session_api.xml:1031
 #, no-c-format
 msgid ""
 "If a transient or detached child becomes referenced by a persistent parent, "
@@ -2143,7 +1570,6 @@
 "il est passé à <literal>saveOrUpdate()</literal>"
 
 #. Tag: para
-#: session_api.xml:1037
 #, no-c-format
 msgid ""
 "If a parent is deleted, all children are passed to <literal>delete()</"
@@ -2153,7 +1579,6 @@
 "literal>"
 
 #. Tag: para
-#: session_api.xml:1042
 #, no-c-format
 msgid ""
 "If a child is dereferenced by a persistent parent, <emphasis>nothing special "
@@ -2164,11 +1589,10 @@
 "Si un enfant est déréférencé par un parent persistant, <emphasis>rien de "
 "spécial n'arrive</emphasis> - l'application devrait explicitement supprimer "
 "l'enfant si nécessaire - à moins que <literal>cascade=\"delete-orphan\"</"
-"literal> soit paramétré, au quel cas l'enfant \"orphelin\" est supprimé."
+"literal> soit paramétré, auquel cas l'enfant \"orphelin\" est supprimé."
 
 #. Tag: para
-#: session_api.xml:1051
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, note that cascading of operations can be applied to an object graph "
 "at <emphasis>call time</emphasis> or at <emphasis>flush time</emphasis>. All "
@@ -2179,21 +1603,19 @@
 msgstr ""
 "Enfin, la cascade des opérations peut être effectuée sur un graphe donné "
 "lors de l'<emphasis>appel de l'opération</emphasis> or lors du "
-"<emphasis>flush</emphasis> suivant. Toutes les opérations, lorsque "
-"cascadées, le sont sur toutes les entités associées atteignables lorsque "
-"l'opétation est exécutée. Cependant <literal>save-upate</literal> et "
-"<literal>delete-orphan</literal> sont cascadées à toutes les entités "
-"associées atteignables lors du flush de la <literal>Session</literal>."
+"<emphasis>flush</emphasis> suivant. Toutes les opérations, lorsqu'elles sont "
+"cascadées, le sont sur toutes les entités associées accessibles lorsque "
+"l'opération est exécutée. Cependant <literal>save-upate</literal> et "
+"<literal>delete-orphan</literal> sont cascadés à toutes les entités "
+"associées accessibles lors du flush de la <literal>Session</literal>. "
 
 #. Tag: title
-#: session_api.xml:1063
 #, no-c-format
 msgid "Using metadata"
 msgstr "Utilisation des méta-données"
 
 #. Tag: para
-#: session_api.xml:1065
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate requires a rich meta-level model of all entity and value types. "
 "This model can be useful to the application itself. For example, the "
@@ -2204,16 +1626,14 @@
 msgstr ""
 "Hibernate requiert un modèle de méta-niveau très riche de toutes les entités "
 "et types valués. De temps en temps, ce modèle est très utile à l'application "
-"elle même. Par exemple, l'application pourrait utiliser les méta-données "
-"d'Hibernate pour implémenter un algorithme de copie en profondeur "
-"\"intelligent\" qui comprendrait quels objets devraient copiés (par exemple "
-"les types de valeur mutables) et lesquels ne devraient pas l'être (par "
-"exemple les types de valeurs immutables et, possiblement, les entités "
-"associées)."
+"elle même. Par exemple, l'application pourrait utiliser les méta-données de "
+"Hibernate pour implémenter un algorithme de copie en profondeur \"intelligent"
+"\" qui comprendrait quels objets devraient être copiés (par exemple les "
+"types de valeur mutables) et lesquels ne devraient pas l'être (par exemple "
+"les types de valeurs immutables et, éventuellement, les entités associées). "
 
 #. Tag: para
-#: session_api.xml:1072
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate exposes metadata via the <literal>ClassMetadata</literal> and "
 "<literal>CollectionMetadata</literal> interfaces and the <literal>Type</"
@@ -2223,43 +1643,4 @@
 "Hibernate expose les méta-données via les interfaces <literal>ClassMetadata</"
 "literal> et <literal>CollectionMetadata</literal> et la hiérarchie "
 "<literal>Type</literal>. Les instances des interfaces de méta-données "
-"peuvent être obtenues à partir de la <literal>SessionFactory</literal>."
-
-#. Tag: programlisting
-#: session_api.xml:1079
-#, no-c-format
-msgid ""
-"<![CDATA[Cat fritz = ......;\n"
-"ClassMetadata catMeta = sessionfactory.getClassMetadata(Cat.class);\n"
-"\n"
-"Object[] propertyValues = catMeta.getPropertyValues(fritz);\n"
-"String[] propertyNames = catMeta.getPropertyNames();\n"
-"Type[] propertyTypes = catMeta.getPropertyTypes();\n"
-"\n"
-"// get a Map of all properties which are not collections or associations\n"
-"Map namedValues = new HashMap();\n"
-"for ( int i=0; i<propertyNames.length; i++ ) {\n"
-"    if ( !propertyTypes[i].isEntityType() && !propertyTypes[i]."
-"isCollectionType() ) {\n"
-"        namedValues.put( propertyNames[i], propertyValues[i] );\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#~ msgid "UPDATE"
-#~ msgstr "UPDATE"
-
-#~ msgid "DELETE"
-#~ msgstr "DELETE"
-
-#~ msgid "state management"
-#~ msgstr "gestion d'état"
-
-#~ msgid "statements"
-#~ msgstr "expressions"
-
-#~ msgid "Connection"
-#~ msgstr "Connection"
-
-#~ msgid "session.connection()"
-#~ msgstr "session.connection()"
+"peuvent être obtenues à partir de la <literal>SessionFactory</literal>. "

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/toolset_guide.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/toolset_guide.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/toolset_guide.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,35 +1,38 @@
+# translation of toolset_guide.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: toolset_guide\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-01-05 10:05+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: toolset_guide.xml:29
 #, no-c-format
 msgid "Toolset Guide"
-msgstr "Guide des outils"
+msgstr "Guide de la boîte à outils"
 
 #. Tag: para
-#: toolset_guide.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Roundtrip engineering with Hibernate is possible using a set of Eclipse "
 "plugins, commandline tools, and Ant tasks."
 msgstr ""
-"Des outils en ligne de commande, des plugins Eclipse ainsu que des tâches "
-"Ant permettent de gérer de cycles de développement complet de projets "
-"utilisant Hibernate."
+"Des outils en ligne de commande, des plugins Eclipse ainsi que des tâches "
+"Ant permettent de gérer le développement complet de projets à travers "
+"Hibernate. "
 
 #. Tag: para
-#: toolset_guide.xml:36
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Hibernate Tools</emphasis> currently include plugins for the "
 "Eclipse IDE as well as Ant tasks for reverse engineering of existing "
@@ -37,11 +40,10 @@
 msgstr ""
 "Les <emphasis>outils Hibernate</emphasis> actuels incluent des plugins pour "
 "l'IDE Eclipse ainsi que des tâches Ant pour l'ingénierie inverse de bases de "
-"données existantes :"
+"données existantes : "
 
 #. Tag: para
-#: toolset_guide.xml:42
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Mapping Editor:</emphasis> an editor for Hibernate XML mapping "
 "files that supports auto-completion and syntax highlighting. It also "
@@ -49,14 +51,13 @@
 "making it more versatile than a normal XML editor."
 msgstr ""
 "<emphasis>Mapping Editor :</emphasis> un éditeur pour les fichiers de "
-"mapping XML Hibernate, supportant l'auto-complétion et la mise en valeur de "
-"la syntaxe. Il supporte aussi l'auto-complétion automatique pour les noms de "
-"classes et les noms de propriété/champ, le rendant beaucoup plus polyvalent "
-"qu'un éditeurXML normal."
+"mappage XML Hibernate, supportant l'auto-finalisation et la mise en valeur "
+"de la syntaxe. Il supporte aussi la sémantique d'auto-finalisation pour les "
+"noms de classes et les noms de propriété/champs, le rendant beaucoup plus "
+"polyvalent qu'un éditeur XML ordinaire."
 
 #. Tag: para
-#: toolset_guide.xml:47
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Console:</emphasis> the console is a new view in Eclipse. In "
 "addition to a tree overview of your console configurations, you are also "
@@ -71,8 +72,7 @@
 "votre base de données et de parcourir les résultats directement dans Eclipse."
 
 #. Tag: para
-#: toolset_guide.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Development Wizards:</emphasis> several wizards are provided with "
 "the Hibernate Eclipse tools. You can use a wizard to quickly generate "
@@ -81,59 +81,54 @@
 "reverse engineering wizard supports customizable templates."
 msgstr ""
 "<emphasis>Development Wizards :</emphasis> plusieurs assistants sont fournis "
-"avec les outils d'Hibernate pour Eclipse ; vous pouvez utiliser un assistant "
-"pour générer rapidement les fichiers de configuration d'Hibernate (cfg.xml), "
-"ou vous pouvez même complètement générer les fichiers de mapping Hibernate "
-"et les sources des POJOs à partir d'un schéma de base de données existant. "
-"L'assistant d'ingénierie inverse supporte les modèles utilisateur."
+"avec les outils de Hibernate pour Eclipse ; vous pouvez utiliser un "
+"assistant pour générer rapidement les fichiers de configuration Hibernate "
+"(cfg.xml), ou vous pouvez même complètement générer les fichiers de mappage "
+"Hibernate et les sources des POJOs à partir d'un schéma de base de données "
+"existant. L'assistant d'ingénierie inverse supporte les modèles utilisateur. "
 
 #. Tag: para
-#: toolset_guide.xml:67
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please refer to the <emphasis>Hibernate Tools</emphasis> package "
 "documentation for more information."
 msgstr ""
-"Veuillez-vous référer au paquet <emphasis>outils Hibernate</emphasis> et sa "
-"documentation pour plus d'informations."
+"Veuillez-vous référer au paquetage <emphasis>Outils Hibernate</emphasis> et "
+"à sa documentation pour plus d'informations. "
 
 #. Tag: para
-#: toolset_guide.xml:72
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, the Hibernate main package comes bundled with an integrated tool : "
 "<emphasis>SchemaExport</emphasis> aka <literal>hbm2ddl</literal>.It can even "
 "be used from \"inside\" Hibernate."
 msgstr ""
-"Pourtant, le paquet principal d'Hibernate arrive avec un lot d'outils "
-"intégrés (il peut même être utilisé de \"l'intérieur\" d'Hibernate à la "
-"volée) : <emphasis>SchemaExport</emphasis> aussi connu comme "
-"<literal>hbm2ddl</literal>."
+"Cependant, le paquetage principal de Hibernate arrive avec un ensemble "
+"d'outils intégrés (il peut même être utilisé de \"l'intérieur\" de Hibernate "
+"à la volée) : <emphasis>SchemaExport</emphasis> aussi connu comme "
+"<literal>hbm2ddl</literal>. "
 
 #. Tag: title
-#: toolset_guide.xml:79
 #, no-c-format
 msgid "Automatic schema generation"
 msgstr "Génération automatique du schéma"
 
 #. Tag: para
-#: toolset_guide.xml:81
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "DDL can be generated from your mapping files by a Hibernate utility. The "
 "generated schema includes referential integrity constraints, primary and "
 "foreign keys, for entity and collection tables. Tables and sequences are "
 "also created for mapped identifier generators."
 msgstr ""
-"La DDL peut être générée à partir de vos fichiers de mapping par un "
-"utilitaire d'Hibernate. Le schéma généré inclut les contraintes d'intégrité "
+"La DDL peut être générée à partir de vos fichiers de mappage par un "
+"utilitaire Hibernate. Le schéma généré inclut les contraintes d'intégrité "
 "référentielle (clefs primaires et étrangères) pour les tables d'entités et "
 "de collections. Les tables et les séquences sont aussi créées pour les "
-"générateurs d'identifiant mappés."
+"générateurs d'identifiants mappés. "
 
 #. Tag: para
-#: toolset_guide.xml:88
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You <emphasis>must</emphasis> specify a SQL <literal>Dialect</literal> via "
 "the <literal>hibernate.dialect</literal> property when using this tool, as "
@@ -141,83 +136,51 @@
 msgstr ""
 "Vous <emphasis>devez</emphasis> spécifier un <literal>Dialect</literal> SQL "
 "via la propriété <literal>hibernate.dialect</literal> lors de l'utilisation "
-"de cet outils, puisque la DDL est fortement dépendante de la base de données."
+"de cet outil, puisque la DDL est fortement dépendante du vendeur spécifique. "
 
 #. Tag: para
-#: toolset_guide.xml:94
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, you must customize your mapping files to improve the generated "
 "schema. The next section covers schema customization."
 msgstr ""
-"D'abord, personnalisez vos fichiers de mapping pour améliorer le schéma "
-"généré."
+"D'abord, personnalisez vos fichiers de mappage pour améliorer le schéma "
+"généré. "
 
 #. Tag: title
-#: toolset_guide.xml:99
 #, no-c-format
 msgid "Customizing the schema"
 msgstr "Personnaliser le schéma"
 
 #. Tag: para
-#: toolset_guide.xml:101
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Many Hibernate mapping elements define optional attributes named "
 "<literal>length</literal>, <literal>precision</literal> and <literal>scale</"
 "literal>. You can set the length, precision and scale of a column with this "
 "attribute."
 msgstr ""
-"Plusieurs éléments du mapping hibernate définissent des attributs optionnels "
+"Plusieurs éléments du mappage Hibernate définissent des attributs optionnels "
 "nommés <literal>length</literal>, <literal>precision</literal> et "
-"<literal>scale</literal>. Vous pouvez paramétrer la longueur, la "
-"précision,... d'une colonne avec ces attributs."
+"<literal>scale</literal>. Vous pouvez paramétrer la taille, la précision, et "
+"l'échelle d'une colonne avec cet attribut. "
 
-#. Tag: programlisting
-#: toolset_guide.xml:108
-#, no-c-format
-msgid "<![CDATA[<property name=\"zip\" length=\"5\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:109
-#, no-c-format
-msgid "<![CDATA[<property name=\"balance\" precision=\"12\" scale=\"2\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Some tags also accept a <literal>not-null</literal> attribute for generating "
 "a <literal>NOT NULL</literal> constraint on table columns, and a "
 "<literal>unique</literal> attribute for generating <literal>UNIQUE</literal> "
 "constraint on table columns."
 msgstr ""
-"Certains éléments acceptent aussi un attribut <literal>not-null</literal> "
-"(utilisé pour générer les contraintes de colonnes <literal>NOT NULL</"
-"literal>) et un attribut <literal>unique</literal> (pour générer une "
-"contrainte de colonne <literal>UNIQUE</literal>)."
+"Certaines balises acceptent aussi un attribut <literal>not-null</literal> "
+"utilisé pour générer les contraintes de colonnes <literal>NOT NULL</literal> "
+"et un attribut <literal>unique</literal> pour générer une contrainte "
+"<literal>UNIQUE</literal> de colonnes de table."
 
-#. Tag: programlisting
-#: toolset_guide.xml:117
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"bar\" column=\"barId\" not-null=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:119
-#, no-c-format
-msgid ""
-"<![CDATA[<element column=\"serialNumber\" type=\"long\" not-null=\"true\" "
-"unique=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:121
-#, fuzzy, no-c-format
-msgid ""
 "A <literal>unique-key</literal> attribute can be used to group columns in a "
 "single, unique key constraint. Currently, the specified value of the "
 "<literal>unique-key</literal> attribute is <emphasis>not</emphasis> used to "
@@ -227,131 +190,60 @@
 "Un attribut <literal>unique-key</literal> peut être utilisé pour grouper les "
 "colonnes en une seule contrainte d'unicité. Actuellement, la valeur "
 "spécifiée par l'attribut <literal>unique-key</literal> n'est <emphasis>pas</"
-"emphasis> utilisée pour nommer la contrainte dans le DDL généré, elle sert "
-"juste à grouper les colonnes dans le fichier de mapping."
+"emphasis> utilisée pour nommer la contrainte dans la DDL générée, elle sert "
+"juste à grouper les colonnes dans le fichier de mappage. "
 
-#. Tag: programlisting
-#: toolset_guide.xml:129
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"org\" column=\"orgId\" unique-key="
-"\"OrgEmployeeId\"/>\n"
-"<property name=\"employeeId\" unique-key=\"OrgEmployee\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:131
-#, fuzzy, no-c-format
-msgid ""
 "An <literal>index</literal> attribute specifies the name of an index that "
 "will be created using the mapped column or columns. Multiple columns can be "
 "grouped into the same index by simply specifying the same index name."
 msgstr ""
 "Un attribut <literal>index</literal> indique le nom d'un index qui sera créé "
 "en utilisant la ou les colonnes mappées. Plusieurs colonnes peuvent être "
-"groupées dans un même index, en spécifiant le même nom d'index."
+"groupées dans un même index, en spécifiant le même nom d'index. "
 
-#. Tag: programlisting
-#: toolset_guide.xml:137
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<property name=\"lastName\" index=\"CustName\"/>\n"
-"<property name=\"firstName\" index=\"CustName\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:139
-#, fuzzy, no-c-format
-msgid ""
 "A <literal>foreign-key</literal> attribute can be used to override the name "
 "of any generated foreign key constraint."
 msgstr ""
 "Un attribut <literal>foreign-key</literal> peut être utilisé pour surcharger "
-"le nom des clés étrangères générées."
+"le nom des clés étrangères générées. "
 
-#. Tag: programlisting
-#: toolset_guide.xml:144
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"bar\" column=\"barId\" foreign-key=\"FKFooBar\"/"
-">]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:146
 #, no-c-format
 msgid ""
 "Many mapping elements also accept a child <literal>&lt;column&gt;</literal> "
 "element. This is particularly useful for mapping multi-column types:"
 msgstr ""
-"Plusieurs éléments de mapping acceptent aussi un élément fils <literal>&lt;"
-"column&gt;</literal>. Ceci est utile pour les type multi-colonnes:"
+"Plusieurs éléments de mappage acceptent aussi un élément fils <literal>&lt;"
+"column&gt;</literal>. Ceci est particulièrement utile pour les type multi-"
+"colonnes :"
 
-#. Tag: programlisting
-#: toolset_guide.xml:151
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<property name=\"name\" type=\"my.customtypes.Name\"/>\n"
-"    <column name=\"last\" not-null=\"true\" index=\"bar_idx\" length=\"30\"/"
-">\n"
-"    <column name=\"first\" not-null=\"true\" index=\"bar_idx\" length=\"20\"/"
-">\n"
-"    <column name=\"initial\"/>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:153
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>default</literal> attribute allows you to specify a default "
 "value for a column.You should assign the same value to the mapped property "
 "before saving a new instance of the mapped class."
 msgstr ""
 "L'attribut <literal>default</literal> vous laisse spécifier une valeur par "
-"défaut pour une colonnes (vous devriez assigner la même valeur à la "
-"propriété mappée avant de sauvegarder une nouvelle instance de la classe "
-"mappée)."
+"défaut pour une colonne. Vous devez assigner la même valeur à la propriété "
+"mappée avant de sauvegarder une nouvelle instance de la classe mappée."
 
-#. Tag: programlisting
-#: toolset_guide.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"credits\" type=\"integer\" insert=\"false\">\n"
-"    <column name=\"credits\" default=\"10\"/>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:161
-#, no-c-format
-msgid ""
-"<![CDATA[<version name=\"version\" type=\"integer\" insert=\"false\">\n"
-"    <column name=\"version\" default=\"0\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:163
 #, no-c-format
 msgid ""
 "The <literal>sql-type</literal> attribute allows the user to override the "
 "default mapping of a Hibernate type to SQL datatype."
 msgstr ""
-"L'attribut <literal>sql-type</literal> laisse l'utilisateur surcharger le "
-"mapping par défaut du type Hibernate vers un type SQL."
+"L'attribut <literal>sql-type</literal> permet à l'utilisateur de surcharger "
+"le mappage par défaut d'un type Hibernate vers un type de données SQL. "
 
-#. Tag: programlisting
-#: toolset_guide.xml:168
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"balance\" type=\"float\">\n"
-"    <column name=\"balance\" sql-type=\"decimal(13,3)\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:170
 #, no-c-format
 msgid ""
 "The <literal>check</literal> attribute allows you to specify a check "
@@ -360,178 +252,133 @@
 "L'attribut <literal>check</literal> permet de spécifier une contrainte de "
 "vérification."
 
-#. Tag: programlisting
-#: toolset_guide.xml:174
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"foo\" type=\"integer\">\n"
-"    <column name=\"foo\" check=\"foo > 10\"/>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:176
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Foo\" table=\"foos\" check=\"bar < 100.0\">\n"
-"    ...\n"
-"    <property name=\"bar\" type=\"float\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:179
 #, no-c-format
 msgid "The following table summarizes these optional attributes."
-msgstr ""
+msgstr "Le tableau suivant dresse la liste des attributs en option."
 
 #. Tag: title
-#: toolset_guide.xml:182
 #, no-c-format
 msgid "Summary"
-msgstr "Summary"
+msgstr "Résumé"
 
 #. Tag: entry
-#: toolset_guide.xml:189
 #, no-c-format
 msgid "Attribute"
 msgstr "Attribut"
 
 #. Tag: entry
-#: toolset_guide.xml:190
 #, no-c-format
 msgid "Values"
-msgstr "Valeur"
+msgstr "Valeurs"
 
 #. Tag: entry
-#: toolset_guide.xml:191
 #, no-c-format
 msgid "Interpretation"
 msgstr "Interprétation"
 
-#. Tag: literal
-#: toolset_guide.xml:196
+#. Tag: entry
 #, no-c-format
-msgid "length"
-msgstr "length"
+msgid "<literal>length</literal>"
+msgstr "<literal>length</literal> (longueur)"
 
 #. Tag: entry
-#: toolset_guide.xml:197 toolset_guide.xml:202 toolset_guide.xml:207
 #, no-c-format
 msgid "number"
 msgstr "numérique"
 
 #. Tag: entry
-#: toolset_guide.xml:198
 #, no-c-format
 msgid "column length"
 msgstr "taille d'une colonne"
 
-#. Tag: literal
-#: toolset_guide.xml:201
+#. Tag: entry
 #, no-c-format
-msgid "precision"
-msgstr "precision"
+msgid "<literal>precision</literal>"
+msgstr "<literal>precision</literal>(précision)"
 
 #. Tag: entry
-#: toolset_guide.xml:203
 #, no-c-format
 msgid "column decimal precision"
 msgstr "précision décimale de la colonne"
 
-#. Tag: literal
-#: toolset_guide.xml:206
+#. Tag: entry
 #, no-c-format
-msgid "scale"
-msgstr "scale"
+msgid "<literal>scale</literal>"
+msgstr "<literal>scale</literal> (échelle)"
 
 #. Tag: entry
-#: toolset_guide.xml:208
 #, no-c-format
 msgid "column decimal scale"
-msgstr "scale décimale de la colonne"
+msgstr "échelle décimale de la colonne"
 
-#. Tag: literal
-#: toolset_guide.xml:211
+#. Tag: entry
 #, no-c-format
-msgid "not-null"
-msgstr "not-null"
+msgid "<literal>not-null</literal>"
+msgstr "<literal>not-null</literal> (non-nulle)"
 
-#. Tag: literal
-#: toolset_guide.xml:212 toolset_guide.xml:217
+#. Tag: entry
 #, no-c-format
-msgid "true|false"
-msgstr "true|false"
+msgid "<literal>true|false</literal>"
+msgstr "<literal>true|false</literal> (vrai|faux)"
 
 #. Tag: entry
-#: toolset_guide.xml:213
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "specifies that the column should be non-nullable"
-msgstr "spécifie que la colonne doit être non-nulle"
+msgstr "spécifie que la colonne doit être non-nulle "
 
-#. Tag: literal
-#: toolset_guide.xml:216
+#. Tag: entry
 #, no-c-format
-msgid "unique"
-msgstr "unique"
+msgid "<literal>unique</literal>"
+msgstr "<literal>unique</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:218
 #, no-c-format
 msgid "specifies that the column should have a unique constraint"
 msgstr "spécifie que la colonne doit avoir une contrainte d'unicité"
 
-#. Tag: literal
-#: toolset_guide.xml:221
+#. Tag: entry
 #, no-c-format
-msgid "index"
-msgstr "index"
+msgid "<literal>index</literal>"
+msgstr "<literal>index</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:222
+#. Tag: entry
 #, no-c-format
-msgid "index_name"
-msgstr "index_name"
+msgid "<literal>index_name</literal>"
+msgstr "<literal>index_name</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:223
 #, no-c-format
 msgid "specifies the name of a (multi-column) index"
 msgstr "spécifie le nom d'un index (multi-colonnes)"
 
-#. Tag: literal
-#: toolset_guide.xml:226
+#. Tag: entry
 #, no-c-format
-msgid "unique-key"
-msgstr "unique-key"
+msgid "<literal>unique-key</literal>"
+msgstr "<literal>unique-key</literal> (clé-unique)"
 
-#. Tag: literal
-#: toolset_guide.xml:227
-#, no-c-format
-msgid "unique_key_name"
-msgstr "unique_key_name"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>unique_key_name</literal>"
+msgstr "<literal>unique-key</literal> (clé-unique)"
 
 #. Tag: entry
-#: toolset_guide.xml:228
 #, no-c-format
 msgid "specifies the name of a multi-column unique constraint"
 msgstr "spécifie le nom d'une contrainte d'unicité multi-colonnes"
 
-#. Tag: literal
-#: toolset_guide.xml:231
+#. Tag: entry
 #, no-c-format
-msgid "foreign-key"
-msgstr "foreign-key"
+msgid "<literal>foreign-key</literal>"
+msgstr "<literal>foreign-key</literal> (clé étrangère)"
 
-#. Tag: literal
-#: toolset_guide.xml:232
-#, no-c-format
-msgid "foreign_key_name"
-msgstr "foreign_key_name"
-
 #. Tag: entry
-#: toolset_guide.xml:233
 #, fuzzy, no-c-format
+msgid "<literal>foreign_key_name</literal>"
+msgstr "<literal>foreign-key</literal> (clé étrangère)"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "specifies the name of the foreign key constraint generated for an "
 "association, for a <literal>&lt;one-to-one&gt;</literal>, <literal>&lt;many-"
@@ -539,117 +386,82 @@
 "to-many&gt;</literal> mapping element. Note that <literal>inverse=\"true\"</"
 "literal> sides will not be considered by <literal>SchemaExport</literal>."
 msgstr ""
-"spécifie le nom d'une contrainte de clé étrangère générée pour une "
-"association, utilisez-la avec les éléments de mapping <placeholder-1/>, "
-"<placeholder-2/>, <placeholder-3/>, or <placeholder-4/> Notez que les "
-"extrêmités <placeholder-5/> se seront pas prises en compte par <placeholder-"
-"6/>."
+"spécifie le nom de la contrainte de clé étrangère générée par une "
+"association, pour un élément de mappage <literal>&lt;one-to-one&gt;</"
+"literal>, <literal>&lt;many-to-one&gt;</literal>, <literal>&lt;key&gt;</"
+"literal>, ou <literal>&lt;many-to-many&gt;</literal>. Notez que les côtés "
+"<literal>inverse=\"true\"</literal> ne seront pas pris en considération par "
+"le <literal>SchemaExport</literal>."
 
-#. Tag: literal
-#: toolset_guide.xml:243
+#. Tag: entry
 #, no-c-format
-msgid "sql-type"
-msgstr "sql-type"
+msgid "<literal>sql-type</literal>"
+msgstr "<literal>sql-type</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:244
-#, no-c-format
-msgid "SQL column type"
-msgstr "SQL column_type"
-
 #. Tag: entry
-#: toolset_guide.xml:245
 #, fuzzy, no-c-format
+msgid "<literal>SQL column type</literal>"
+msgstr "<literal>sql-type</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "overrides the default column type (attribute of <literal>&lt;column&gt;</"
 "literal> element only)"
 msgstr ""
-"surcharge le type par défaut (attribut de l'élément <placeholder-1/> "
-"uniquement)"
+"surcharge le type par défaut (attribut de l'élément <literal>&lt;column&gt;</"
+"literal> uniquement)"
 
-#. Tag: literal
-#: toolset_guide.xml:251
+#. Tag: entry
 #, no-c-format
-msgid "default"
-msgstr "default"
+msgid "<literal>default</literal>"
+msgstr "<literal>défaut</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:252 toolset_guide.xml:259
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "SQL expression"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"expression SQL\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"SQL expression"
+msgstr "Expression SQL"
 
 #. Tag: entry
-#: toolset_guide.xml:253
 #, no-c-format
 msgid "specify a default value for the column"
 msgstr "spécifie une valeur par défaut pour la colonne"
 
-#. Tag: literal
-#: toolset_guide.xml:258
+#. Tag: entry
 #, no-c-format
-msgid "check"
-msgstr "check"
+msgid "<literal>check</literal>"
+msgstr "<literal>vérification</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:260
 #, no-c-format
 msgid "create an SQL check constraint on either column or table"
 msgstr "crée une contrainte de vérification sur la table ou la colonne"
 
 #. Tag: para
-#: toolset_guide.xml:268
 #, no-c-format
 msgid ""
 "The <literal>&lt;comment&gt;</literal> element allows you to specify "
 "comments for the generated schema."
 msgstr ""
-"L'élément <literal>&lt;comment&gt;</literal> vous permet de spécifier un "
-"commentaire pour le schéma généré."
+"L'élément <literal>&lt;comment&gt;</literal> vous permet de spécifier des "
+"commentaires pour le schéma généré."
 
-#. Tag: programlisting
-#: toolset_guide.xml:273
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Customer\" table=\"CurCust\">\n"
-"    <comment>Current customers only</comment>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:275
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"balance\">\n"
-"    <column name=\"bal\">\n"
-"        <comment>Balance in USD</comment>\n"
-"    </column>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:277
-#, fuzzy, no-c-format
-msgid ""
 "This results in a <literal>comment on table</literal> or <literal>comment on "
 "column</literal> statement in the generated DDL where supported."
 msgstr ""
 "Ceci a pour résultat une expression <literal>comment on table</literal> ou "
-"<literal>comment on column</literal> dans la DDL générée (où supportée)."
+"<literal>comment on column</literal> dans la DDL générée (là où elle est "
+"supportée). "
 
 #. Tag: title
-#: toolset_guide.xml:286
 #, no-c-format
 msgid "Running the tool"
 msgstr "Exécuter l'outil"
 
 #. Tag: para
-#: toolset_guide.xml:288
 #, no-c-format
 msgid ""
 "The <literal>SchemaExport</literal> tool writes a DDL script to standard out "
@@ -659,201 +471,158 @@
 "standard et/ou exécute les ordres DDL."
 
 #. Tag: para
-#: toolset_guide.xml:293
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table displays the <literal>SchemaExport</literal> command "
 "line options"
-msgstr "<literal>SchemaExport</literal> Options de la ligne de commande"
+msgstr ""
+"Le tableau suivant affiche les options de ligne de commande du "
+"<literal>SchemaExport</literal>"
 
 #. Tag: para
-#: toolset_guide.xml:295
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
 "<literal>org.hibernate.tool.hbm2ddl.SchemaExport</literal> <emphasis>options "
 "mapping_files</emphasis>"
 msgstr ""
+"<literal>java -cp </literal><emphasis>hibernate_classpaths</"
+"emphasis><literal>org.hibernate.tool.hbm2ddl.SchemaExport</"
+"literal><emphasis>options mapping_files</emphasis>  "
 
 #. Tag: title
-#: toolset_guide.xml:301
 #, no-c-format
 msgid "<literal>SchemaExport</literal> Command Line Options"
 msgstr "<literal>SchemaExport</literal> Options de la ligne de commande"
 
 #. Tag: entry
-#: toolset_guide.xml:307 toolset_guide.xml:457 toolset_guide.xml:527
 #, no-c-format
 msgid "Option"
 msgstr "Option"
 
 #. Tag: entry
-#: toolset_guide.xml:308 toolset_guide.xml:395 toolset_guide.xml:458
-#: toolset_guide.xml:528
 #, no-c-format
 msgid "Description"
 msgstr "Description"
 
-#. Tag: literal
-#: toolset_guide.xml:313 toolset_guide.xml:463
+#. Tag: entry
 #, no-c-format
-msgid "--quiet"
-msgstr "--quiet"
+msgid "<literal>--quiet</literal>"
+msgstr "<literal>--quiet</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:314 toolset_guide.xml:464
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "do not output the script to stdout"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"ne pas écrire le script vers la sortie standard\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"ne pas écrire vers la sortie standard"
+msgstr "ne pas écrire le script vers la sortie standard stdout"
 
-#. Tag: literal
-#: toolset_guide.xml:317
+#. Tag: entry
 #, no-c-format
-msgid "--drop"
-msgstr "--drop"
+msgid "<literal>--drop</literal>"
+msgstr "<literal>--drop</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:318
 #, no-c-format
 msgid "only drop the tables"
-msgstr "supprime seuleument les tables"
+msgstr "supprime uniquement les tables"
 
-#. Tag: literal
-#: toolset_guide.xml:321
+#. Tag: entry
 #, no-c-format
-msgid "--create"
-msgstr "--create"
+msgid "<literal>--create</literal>"
+msgstr "<literal>--create</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:322
 #, no-c-format
 msgid "only create the tables"
-msgstr "ne créé que les tables"
+msgstr "ne crée que les tables"
 
-#. Tag: literal
-#: toolset_guide.xml:325 toolset_guide.xml:467
+#. Tag: entry
 #, no-c-format
-msgid "--text"
-msgstr "--text"
+msgid "<literal>--text</literal>"
+msgstr "<literal>--text</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:326
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "do not export to the database"
-msgstr "ne pas exécuter sur la base de données"
+msgstr "n'exporte pas vers la base de données "
 
-#. Tag: literal
-#: toolset_guide.xml:329
-#, no-c-format
-msgid "--output=my_schema.ddl"
-msgstr "--output=my_schema.ddl"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--output=my_schema.ddl</literal>"
+msgstr "<literal>scale</literal> (échelle)"
 
 #. Tag: entry
-#: toolset_guide.xml:330
 #, no-c-format
 msgid "output the ddl script to a file"
 msgstr "écrit le script ddl vers un fichier"
 
-#. Tag: literal
-#: toolset_guide.xml:333 toolset_guide.xml:471 toolset_guide.xml:533
-#, no-c-format
-msgid "--naming=eg.MyNamingStrategy"
-msgstr "--naming=eg.MyNamingStrategy"
-
 #. Tag: entry
-#: toolset_guide.xml:334 toolset_guide.xml:472 toolset_guide.xml:534
 #, fuzzy, no-c-format
-msgid "select a <literal>NamingStrategy</literal>"
-msgstr "dans <literal>hibernate.properties</literal>"
+msgid "<literal>--naming=eg.MyNamingStrategy</literal>"
+msgstr "<literal>--naming=eg.MyNamingStrategy</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:337 toolset_guide.xml:479 toolset_guide.xml:541
+#. Tag: entry
 #, no-c-format
-msgid "--config=hibernate.cfg.xml"
-msgstr "--config=hibernate.cfg.xml"
+msgid "select a <literal>NamingStrategy</literal>"
+msgstr "sélectionne une <literal>NamingStrategy</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:338
+#, fuzzy, no-c-format
+msgid "<literal>--config=hibernate.cfg.xml</literal>"
+msgstr "<literal>--config=hibernate.cfg.xml</literal>"
+
+#. Tag: entry
 #, no-c-format
 msgid "read Hibernate configuration from an XML file"
 msgstr "lit la configuration Hibernate à partir d'un fichier XML"
 
-#. Tag: literal
-#: toolset_guide.xml:341 toolset_guide.xml:475 toolset_guide.xml:537
-#, no-c-format
-msgid "--properties=hibernate.properties"
-msgstr "--properties=hibernate.properties"
-
 #. Tag: entry
-#: toolset_guide.xml:342 toolset_guide.xml:476 toolset_guide.xml:538
 #, fuzzy, no-c-format
+msgid "<literal>--properties=hibernate.properties</literal>"
+msgstr "dans <literal>hibernate.properties</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid "read database properties from a file"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"lit les propriétés de la base de données à partir d'un fichier\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"lire les propriétés de la base de données à partir d'un fichier\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"lit les propriétés dela base de données depuis un fichier de propriétés"
+msgstr "lit les propriétés de la base de données à partir d'un fichier"
 
-#. Tag: literal
-#: toolset_guide.xml:345
+#. Tag: entry
 #, no-c-format
-msgid "--format"
-msgstr "--format"
+msgid "<literal>--format</literal>"
+msgstr "<literal>--format</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:346
 #, no-c-format
 msgid "format the generated SQL nicely in the script"
 msgstr "formatte proprement le SQL généré dans le script"
 
-#. Tag: literal
-#: toolset_guide.xml:349
+#. Tag: entry
 #, no-c-format
-msgid "--delimiter=;"
-msgstr "--delimiter=x"
+msgid "<literal>--delimiter=;</literal>"
+msgstr "<literal>--delimiter=;</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:350
 #, no-c-format
 msgid "set an end of line delimiter for the script"
 msgstr "paramètre un délimiteur de fin de ligne pour le script"
 
 #. Tag: para
-#: toolset_guide.xml:356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can even embed <literal>SchemaExport</literal> in your application:"
 msgstr ""
 "Vous pouvez même intégrer <literal>SchemaExport</literal> dans votre "
-"application :"
+"application : "
 
-#. Tag: programlisting
-#: toolset_guide.xml:360
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaExport(cfg).create(false, true);]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:365
 #, no-c-format
 msgid "Properties"
 msgstr "Propriétés"
 
 #. Tag: para
-#: toolset_guide.xml:367
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Database properties can be specified:"
-msgstr "Les propriétés de la base de données peuvent être spécifiées"
+msgstr "Les propriétés de la base de données peuvent être spécifiées :"
 
 #. Tag: para
-#: toolset_guide.xml:373
 #, no-c-format
 msgid ""
 "as system properties with <literal>-D</literal><emphasis>&lt;property&gt;</"
@@ -863,104 +632,87 @@
 "</emphasis>"
 
 #. Tag: para
-#: toolset_guide.xml:376
 #, no-c-format
 msgid "in <literal>hibernate.properties</literal>"
 msgstr "dans <literal>hibernate.properties</literal>"
 
 #. Tag: para
-#: toolset_guide.xml:379
 #, no-c-format
 msgid "in a named properties file with <literal>--properties</literal>"
 msgstr ""
 "dans un fichier de propriétés déclaré avec <literal>--properties</literal>"
 
 #. Tag: para
-#: toolset_guide.xml:383
 #, no-c-format
 msgid "The needed properties are:"
 msgstr "Les propriétés nécessaires sont :"
 
 #. Tag: title
-#: toolset_guide.xml:388
 #, no-c-format
 msgid "SchemaExport Connection Properties"
-msgstr "SchemaExport Connection Properties"
+msgstr "Les propriétés de connexion SchemaExport "
 
 #. Tag: entry
-#: toolset_guide.xml:394
 #, no-c-format
 msgid "Property Name"
 msgstr "Nom de la propriété"
 
-#. Tag: literal
-#: toolset_guide.xml:400
-#, no-c-format
-msgid "hibernate.connection.driver_class"
-msgstr "hibernate.connection.driver_class"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.driver_class</literal>"
+msgstr "<literal>hibernate.connection.driver_class</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:401
 #, no-c-format
 msgid "jdbc driver class"
 msgstr "classe du driver JDBC"
 
-#. Tag: literal
-#: toolset_guide.xml:404
-#, no-c-format
-msgid "hibernate.connection.url"
-msgstr "hibernate.connection.url"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.url</literal>"
+msgstr "dans <literal>hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:405
 #, no-c-format
 msgid "jdbc url"
 msgstr "URL JDBC"
 
-#. Tag: literal
-#: toolset_guide.xml:408
-#, no-c-format
-msgid "hibernate.connection.username"
-msgstr "hibernate.connection.username"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.username</literal>"
+msgstr "dans <literal>hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:409
 #, no-c-format
 msgid "database user"
 msgstr "utilisateur de la base de données"
 
-#. Tag: literal
-#: toolset_guide.xml:412
-#, no-c-format
-msgid "hibernate.connection.password"
-msgstr "hibernate.connection.password"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.password</literal>"
+msgstr "dans <literal>hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:413
 #, no-c-format
 msgid "user password"
 msgstr "mot de passe de l'utilisateur"
 
-#. Tag: literal
-#: toolset_guide.xml:416
-#, no-c-format
-msgid "hibernate.dialect"
-msgstr "hibernate.dialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.dialect</literal>"
+msgstr "dans <literal>hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:417
 #, no-c-format
 msgid "dialect"
 msgstr "dialecte"
 
 #. Tag: title
-#: toolset_guide.xml:426
 #, no-c-format
 msgid "Using Ant"
 msgstr "Utiliser Ant"
 
 #. Tag: para
-#: toolset_guide.xml:428
 #, no-c-format
 msgid ""
 "You can call <literal>SchemaExport</literal> from your Ant build script:"
@@ -968,135 +720,74 @@
 "Vous pouvez appeler <literal>SchemaExport</literal> depuis votre script de "
 "construction Ant :"
 
-#. Tag: programlisting
-#: toolset_guide.xml:432
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemaexport\">\n"
-"    <taskdef name=\"schemaexport\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaExportTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemaexport\n"
-"        properties=\"hibernate.properties\"\n"
-"        quiet=\"no\"\n"
-"        text=\"no\"\n"
-"        drop=\"no\"\n"
-"        delimiter=\";\"\n"
-"        output=\"schema-export.sql\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemaexport>\n"
-"</target>]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:437
 #, no-c-format
 msgid "Incremental schema updates"
 msgstr "Mises à jour incrémentales du schéma"
 
 #. Tag: para
-#: toolset_guide.xml:439
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>SchemaUpdate</literal> tool will update an existing schema with "
 "\"incremental\" changes. The <literal>SchemaUpdate</literal> depends upon "
 "the JDBC metadata API and, as such, will not work with all JDBC drivers."
 msgstr ""
 "L'outil <literal>SchemaUpdate</literal> mettra à jour un schéma existant en "
-"effectuant les changement par \"incrément\". Notez que "
-"<literal>SchemaUpdate</literal> dépends beaucoup de l'API JDBC metadata, il "
-"ne fonctionnera donc pas avec tous les drivers JDBC."
+"effectuant les changements par \"incrément\". Notez que "
+"<literal>SchemaUpdate</literal> dépend fortement de l'API des métadonnées "
+"JDBC, par conséquent il ne fonctionne pas avec tous les drivers JDBC. "
 
 #. Tag: para
-#: toolset_guide.xml:445
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
 "<literal>org.hibernate.tool.hbm2ddl.SchemaUpdate</literal> <emphasis>options "
 "mapping_files</emphasis>"
 msgstr ""
+"<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
+"<literal>org.hibernate.tool.hbm2ddl.SchemaUpdate</literal> <emphasis>options "
+"mapping_files</emphasis>"
 
 #. Tag: title
-#: toolset_guide.xml:451
 #, no-c-format
 msgid "<literal>SchemaUpdate</literal> Command Line Options"
 msgstr "<literal>SchemaUpdate</literal> Options de ligne de commande"
 
 #. Tag: entry
-#: toolset_guide.xml:468
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "do not export the script to the database"
-msgstr "ne pas exporter vers la base de données"
+msgstr "ne pas exporter vers la base de données "
 
 #. Tag: entry
-#: toolset_guide.xml:480 toolset_guide.xml:542
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "specify a <literal>.cfg.xml</literal> file"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"specify a <placeholder-1/> file\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"indique un fichier <placeholder-1/>"
+msgstr "spécifier un fichier <literal>.cfg.xml</literal>"
 
 #. Tag: para
-#: toolset_guide.xml:486
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can embed <literal>SchemaUpdate</literal> in your application:"
 msgstr ""
-"Vous pouvez intégrer <literal>SchemaUpdate</literal> dans votre application :"
+"Vous pouvez intégrer <literal>SchemaUpdate</literal> dans votre "
+"application : "
 
-#. Tag: programlisting
-#: toolset_guide.xml:490
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaUpdate(cfg).execute(false);]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:495
 #, no-c-format
 msgid "Using Ant for incremental schema updates"
 msgstr "Utiliser Ant pour des mises à jour de schéma par incrément"
 
 #. Tag: para
-#: toolset_guide.xml:497
 #, no-c-format
 msgid "You can call <literal>SchemaUpdate</literal> from the Ant script:"
 msgstr ""
 "Vous pouvez appeler <literal>SchemaUpdate</literal> depuis le script Ant :"
 
-#. Tag: programlisting
-#: toolset_guide.xml:501
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemaupdate\">\n"
-"    <taskdef name=\"schemaupdate\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaUpdateTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemaupdate\n"
-"        properties=\"hibernate.properties\"\n"
-"        quiet=\"no\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemaupdate>\n"
-"</target>]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:506
 #, no-c-format
 msgid "Schema validation"
 msgstr "Validation du schéma"
 
 #. Tag: para
-#: toolset_guide.xml:508
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>SchemaValidator</literal> tool will validate that the existing "
 "database schema \"matches\" your mapping documents. The "
@@ -1104,150 +795,98 @@
 "API and, as such, will not work with all JDBC drivers. This tool is "
 "extremely useful for testing."
 msgstr ""
-"L'outil <literal>SchemaValidator</literal> validera que le schéma existant "
-"correspond à vos documents de mapping. Notez que le "
-"<literal>SchemaValidator</literal> dépends de l'API metadata de JDBC, il ne "
-"fonctionnera donc pas avec tous les drivers JDBC. Cet outil est extrêmement "
-"utile pour tester."
+"L'outil <literal>SchemaValidator</literal> confirmera que le schéma existant "
+"correspond à vos documents de mappage. Notez que le "
+"<literal>SchemaValidator</literal> dépend de l'API des métadonnées de JDBC, "
+"il ne fonctionne donc pas avec tous les drivers JDBC. Cet outil est "
+"extrêmement utile pour les tests. "
 
 #. Tag: para
-#: toolset_guide.xml:514
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
 "<literal>org.hibernate.tool.hbm2ddl.SchemaValidator</literal> "
 "<emphasis>options mapping_files</emphasis>"
 msgstr ""
+"<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
+"<literal>org.hibernate.tool.hbm2ddl.SchemaValidator</literal> "
+"<emphasis>options mapping_files</emphasis>"
 
 #. Tag: para
-#: toolset_guide.xml:518
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table displays the <literal>SchemaValidator</literal> command "
 "line options:"
-msgstr "<literal>SchemaValidator</literal> Options de ligne de commande"
+msgstr ""
+"Le tableau suivant affiche les options de ligne de commande du "
+"<literal>SchemaValidator</literal>"
 
 #. Tag: title
-#: toolset_guide.xml:521
 #, no-c-format
 msgid "<literal>SchemaValidator</literal> Command Line Options"
 msgstr "<literal>SchemaValidator</literal> Options de ligne de commande"
 
 #. Tag: para
-#: toolset_guide.xml:548
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can embed <literal>SchemaValidator</literal> in your application:"
 msgstr ""
 "Vous pouvez inclure <literal>SchemaValidator</literal> dans votre "
-"application:"
+"application : "
 
-#. Tag: programlisting
-#: toolset_guide.xml:552
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaValidator(cfg).validate();]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:557
 #, no-c-format
 msgid "Using Ant for schema validation"
 msgstr "Utiliser Ant pour la validation du Schéma"
 
 #. Tag: para
-#: toolset_guide.xml:559
 #, no-c-format
 msgid "You can call <literal>SchemaValidator</literal> from the Ant script:"
 msgstr ""
 "Vous pouvez appeler <literal>SchemaValidator</literal> depuis le script Ant:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:563
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemavalidate\">\n"
-"    <taskdef name=\"schemavalidator\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaValidatorTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemavalidator\n"
-"        properties=\"hibernate.properties\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemavalidator>\n"
-"</target>]]>"
-msgstr ""
+#, fuzzy
+#~ msgid "length"
+#~ msgstr "taille d'une colonne"
 
-#~ msgid "Ant Tasks:"
-#~ msgstr "Tâches Ant :"
+#, fuzzy
+#~ msgid "precision"
+#~ msgstr "Expression SQL"
 
-#~ msgid "&lt;one-to-one&gt;"
-#~ msgstr "&lt;one-to-one&gt;"
+#, fuzzy
+#~ msgid "unique_key_name"
+#~ msgstr "<literal>unique_key_name</literal>"
 
-#~ msgid "&lt;many-to-one&gt;"
-#~ msgstr "&lt;many-to-one&gt;"
+#, fuzzy
+#~ msgid "foreign_key_name"
+#~ msgstr "<literal>foreign_key_name</literal>"
 
-#~ msgid "&lt;key&gt;"
-#~ msgstr "&lt;key&gt;"
+#, fuzzy
+#~ msgid "SQL column type"
+#~ msgstr "<literal>SQL column type</literal> (type de colonne SQL)"
 
-#~ msgid "&lt;many-to-many&gt;"
-#~ msgstr "&lt;many-to-many&gt;"
+#, fuzzy
+#~ msgid "--output=my_schema.ddl"
+#~ msgstr "<literal>--output=my_schema.ddl</literal>"
 
-#~ msgid "inverse=\"true\""
-#~ msgstr "inverse=\"true\""
+#, fuzzy
+#~ msgid "--properties=hibernate.properties"
+#~ msgstr "<literal>--properties=hibernate.properties</literal>"
 
-#~ msgid "SchemaExport"
-#~ msgstr "SchemaExport"
+#, fuzzy
+#~ msgid "hibernate.connection.url"
+#~ msgstr "<literal>hibernate.connection.url</literal>"
 
-#~ msgid "&lt;column&gt;"
-#~ msgstr "&lt;column&gt;"
-
-#~ msgid "java -cp"
-#~ msgstr "java -cp"
-
 #, fuzzy
-#~ msgid "hibernate_classpaths"
-#~ msgstr ""
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "classpath_hibernate\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "hibernate_classpaths\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "hibernate_classpaths"
+#~ msgid "hibernate.connection.username"
+#~ msgstr "<literal>hibernate.connection.username</literal>"
 
-#~ msgid "org.hibernate.tool.hbm2ddl.SchemaExport"
-#~ msgstr "net.sf.hibernate.tool.hbm2ddl.SchemaExport"
-
 #, fuzzy
-#~ msgid "options mapping_files"
-#~ msgstr ""
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "options fichiers_de_mapping\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "options mapping_files\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "options mapping_files"
+#~ msgid "hibernate.connection.password"
+#~ msgstr "<literal>hibernate.connection.password</literal>"
 
-#~ msgid "NamingStrategy"
-#~ msgstr "NamingStrategy"
-
 #, fuzzy
-#~ msgid "select a <placeholder-1/>"
-#~ msgstr ""
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "sélectionne une <placeholder-1/>\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "choisit une <placeholder-1/>\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Indique une <placeholder-1/>"
+#~ msgid "hibernate.dialect"
+#~ msgstr "<literal>hibernate.dialect</literal>"
 
-#~ msgid "org.hibernate.tool.hbm2ddl.SchemaUpdate"
-#~ msgstr "org.hibernate.tool.hbm2ddl.SchemaUpdate"
-
-#~ msgid ".cfg.xml"
-#~ msgstr ".cfg.xml"
-
-#~ msgid "org.hibernate.tool.hbm2ddl.SchemaValidator"
-#~ msgstr "org.hibernate.tool.hbm2ddl.SchemaValidator"
+#~ msgid "<!-- <emphasis>Ant Tasks:</emphasis> -->"
+#~ msgstr "<!-- <emphasis>Ant Tasks:</emphasis> -->"

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/transactions.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/transactions.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/transactions.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,28 @@
+# translation of transactions.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: transactions\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-01-05 10:06+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: transactions.xml:29
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Transactions and Concurrency"
-msgstr "Transactions et accès concurrents"
+msgstr "Transactions et Accès concurrents"
 
 #. Tag: para
-#: transactions.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The most important point about Hibernate and concurrency control is that it "
 "is easy to understand. Hibernate directly uses JDBC connections and JTA "
@@ -27,15 +31,14 @@
 "specification of your database management system."
 msgstr ""
 "L'un des principaux avantages du mécanisme de contrôle des accès concurrents "
-"d'Hibernate est qu'il est très facile à comprendre. Hibernate utilise "
+"de Hibernate est qu'il est très facile à comprendre. Hibernate utilise "
 "directement les connexions JDBC ainsi que les ressources JTA sans y ajouter "
 "davantage de mécanisme de blocage. Nous vous recommandons de vous "
 "familiariser avec les spécifications JDBC, ANSI et d'isolement de "
-"transaction de la base de données que vous utilisez."
+"transaction du système de gestion de la base de données que vous utilisez. "
 
 #. Tag: para
-#: transactions.xml:38
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate does not lock objects in memory. Your application can expect the "
 "behavior as defined by the isolation level of your database transactions. "
@@ -43,52 +46,48 @@
 "cache, Hibernate provides repeatable reads for lookup by identifier and "
 "entity queries and not reporting queries that return scalar values."
 msgstr ""
-"Hibernate ne vérouille pas vos objets en mémoire. Votre application peut "
+"Hibernate ne verrouille pas vos objets en mémoire. Votre application peut "
 "suivre le comportement défini par le niveau d'isolation de vos transactions "
 "de base de données. Notez que grâce à la <literal>Session</literal>, qui est "
-"aussi un cache de scope transaction, Hibernate fournit des lectures répétées "
-"pour les récupération par identifiants et les requêtes d'entités (pas celle "
-"de valeurs scalaires)."
+"aussi un cache de portée de transaction, Hibernate fournit des lectures "
+"répétées pour les recherches par identifiants et les requêtes d'entités (ne "
+"rapporte pas les requêtes qui retournent des valeurs scalaires). "
 
 #. Tag: para
-#: transactions.xml:46
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In addition to versioning for automatic optimistic concurrency control, "
 "Hibernate also offers, using the <literal>SELECT FOR UPDATE</literal> "
 "syntax, a (minor) API for pessimistic locking of rows. Optimistic "
 "concurrency control and this API are discussed later in this chapter."
 msgstr ""
-"En addition au versionning pour le controle automatique de concurrence, "
-"Hibernate fournit une API (mineure) pour le verrouillage perssimiste des "
-"enregistrements, en générant une syntaxe <literal>SELECT FOR UPDATE</"
-"literal>. Le controle de concurrence optimiste et cette API seront détaillés "
-"plus tard dans ce chapitre."
+"En plus du versioning, pour le contrôle automatique optimiste de "
+"concurrence, Hibernate fournit également une API (mineure) pour le "
+"verrouillage pessimiste des lignes, en générant une syntaxe <literal>SELECT "
+"FOR UPDATE</literal>. Le contrôle de concurrence optimiste et cette API "
+"seront approfondis ultérieurement dans ce chapitre. "
 
 #. Tag: para
-#: transactions.xml:53
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The discussion of concurrency control in Hibernate begins with the "
 "granularity of <literal>Configuration</literal>, <literal>SessionFactory</"
 "literal>, and <literal>Session</literal>, as well as database transactions "
 "and long conversations."
 msgstr ""
-"Nous aborderons la gestion des accès concurrents en discutant de la "
+"Nous abordons la gestion des accès concurrents en discutant de la "
 "granularité des objets <literal>Configuration</literal>, "
 "<literal>SessionFactory</literal>, et <literal>Session</literal>, ainsi que "
-"de certains concepts relatifs à la base de données et aux longues "
-"transactions applicatives."
+"des transactions de la base de données et des longues transactions "
+"applicatives. "
 
 #. Tag: title
-#: transactions.xml:60
 #, no-c-format
 msgid "Session and transaction scopes"
-msgstr "Gestion de session et délimitation de transactions"
+msgstr "Portées des sessions et des transactions"
 
 #. Tag: para
-#: transactions.xml:62
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>SessionFactory</literal> is an expensive-to-create, threadsafe "
 "object, intended to be shared by all application threads. It is created "
@@ -97,13 +96,12 @@
 msgstr ""
 "Il est important de savoir qu'un objet <literal>SessionFactory</literal> est "
 "un objet complexe et optimisé pour fonctionner avec les threads(thread- "
-"safe). Il est coûteux à créer et est ainsi prévu pour n'être instancié qu?"
-"une seule fois via un objet <literal>Configuration</literal> au démarrage de "
-"l'application, et être partagé par tous les threads d'une application."
+"safe). Il est coûteux à créer et est ainsi prévu pour n'être instancié "
+"qu'une seule fois via une instance <literal>Configuration</literal> en "
+"général au démarrage de l'application. "
 
 #. Tag: para
-#: transactions.xml:68
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>Session</literal> is an inexpensive, non-threadsafe object that "
 "should be used once and then discarded for: a single request, a conversation "
@@ -111,17 +109,16 @@
 "JDBC <literal>Connection</literal>, or a <literal>Datasource</literal>, "
 "unless it is needed. It will not consume any resources until used."
 msgstr ""
-"Un objet <literal>Session</literal> est relativement simple et n'est "
-"threadsafe. Il est également peu coûteux à créer. Il devrait n'être utilisé "
-"qu'une seule fois, pour un processus d'affaire ou une unité de travail ou "
-"une conversation et ensuite être relâché. Un objet <literal>Session</"
-"literal> ne tentera pas d'obtenir de connexion ( <literal>Connection</"
-"literal> ) JDBC (ou de <literal>Datasource</literal> ) si ce n'est pas "
-"nécessaire."
+"Une <literal>Session</literal> n'est pas coûteuse, et c'est un objet non-"
+"threadsafe qui ne devrait être utilisé qu'une seule fois pour une requête "
+"unique, une conversation, une unité de travail unique et devrait être "
+"relâché ensuite. Un objet <literal>Session</literal> ne tentera pas "
+"d'obtenir une <literal>Connection</literal>JBDC (ou une <literal>Datasource</"
+"literal>) si ce n'est pas nécessaire, par conséquent il ne consommera pas de "
+"ressource jusqu'à son utilisation."
 
 #. Tag: para
-#: transactions.xml:76
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In order to reduce lock contention in the database, a database transaction "
 "has to be as short as possible. Long database transactions will prevent your "
@@ -130,17 +127,16 @@
 "unit of work is complete."
 msgstr ""
 "Afin de compléter ce tableau, vous devez également penser aux transactions "
-"de base de données. Une transaction de base de données se doit d'être la "
-"plus courte possible afin de réduire les risques de collision sur des "
-"enregistrements verrouillés. De longues transactions à la base de données "
-"nuiront à l'extensibilité de vos applications lorsque confrontées à de hauts "
-"niveaux de charge. Par conséquent, il n'est jamais bon de maintenir une "
-"transaction ouverte pendant la durée de reflexion de l'utilisateur, jusqu'a "
-"ce que l'unité de travail soit achevée."
+"de base de données. Une transaction de base de données doit être aussi "
+"courte que possible afin de réduire les risques de contention de verrou dans "
+"la base de données. De longues transactions à la base de données nuiront à "
+"l'extensibilité de vos applications lorsque confrontées à de hauts niveaux "
+"de charge. Par conséquent, ce n'est un bon design que de maintenir une "
+"transaction ouverte pendant la durée de reflexion de l'utilisateur, jusqu'à "
+"ce que l'unité de travail soit achevée. "
 
 #. Tag: para
-#: transactions.xml:84
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What is the scope of a unit of work? Can a single Hibernate "
 "<literal>Session</literal> span several database transactions, or is this a "
@@ -148,22 +144,19 @@
 "<literal>Session</literal> and how do you demarcate the database transaction "
 "boundaries? These questions are addressed in the following sections."
 msgstr ""
-"Maintenant, comment délimiter une unité de travail? Est-ce qu'une instance "
-"de <literal>Session</literal> peut avoir une durée de vie dépassant "
-"plusieurs transactions à la base de données, ou bien est-ce que celles-ci "
-"doivent être liées une à une? Quand faut-il ouvrir et fermer une "
-"<literal>Session</literal> ? Comment définir la démarcation de vos "
-"transactions à la base de données?"
+"Quelle est la portée d'une unité de travail? Est-ce qu'une <literal>Session</"
+"literal> unique de Hibernate peut avoir une durée de vie dépassant plusieurs "
+"transactions à la base de données, ou bien est-ce une relation un-à-un des "
+"portées? Quand faut-il ouvrir et fermer une <literal>Session</literal> et "
+"comment définir les démarcations de vos transactions à la base de données ? "
 
 #. Tag: title
-#: transactions.xml:92
 #, no-c-format
 msgid "Unit of work"
 msgstr "Unité de travail"
 
 #. Tag: para
-#: transactions.xml:94
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "First, let's define a unit of work. A unit of work is a design pattern "
 "described by Martin Fowler as <quote> [maintaining] a list of objects "
@@ -172,14 +165,25 @@
 "citation> In other words, its a series of operations we wish to carry out "
 "against the database together. Basically, it is a transaction, though "
 "fulfilling a unit of work will often span multiple physical database "
-"transactions (see <xref linkend=\"transactions-basics-apptx\"/>). So really "
+"transactions (see <xref linkend=\"transactions-basics-apptx\" />). So really "
 "we are talking about a more abstract notion of a transaction. The term "
 "\"business transaction\" is also sometimes used in lieu of unit of work."
 msgstr ""
+"Tout d'abord, nous allons définir une unité de travail. Une unité de travail "
+"est un modèle de conception décrit par Martin Fowler qui <quote> [gère] une "
+"liste d'objets concernés par une transaction d'entreprise et coordonne la "
+"rédaction de modifications et la résolution des problèmes d'accès "
+"concurrentiel. </quote><citation>PoEAA</citation>. En d'autres termes, il "
+"s'agit d'une série d'opérations que nous voulons réaliser ensemble sur la "
+"base de données. Il s'agit essentiellement d'une transaction, bien qu'en "
+"remplissant une unité de travail, on couvrira souvent plusieurs transactions "
+"physiques de base de données (voir <xref linkend=\"transactions-basics-apptx"
+"\" />). Nous parlons donc vraiment une notion plus abstraite de transaction. "
+"Le terme \"business transaction\"est aussi parfois utilisé à la place "
+"d'unité de travail."
 
 #. Tag: para
-#: transactions.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not use the <emphasis>session-per-operation</emphasis> antipattern: do "
 "not open and close a <literal>Session</literal> for every simple database "
@@ -195,29 +199,28 @@
 "clearly defined unit of work. The latter is also more maintainable and "
 "extensible."
 msgstr ""
-"Il est important de mentionner que d'utiliser un paradigme <emphasis>session-"
-"par-operation</emphasis> est un anti-pattern. Autrement dit: n'ouvrez et ne "
-"fermez pas la <literal>Session</literal> à chacun de vos accès simples à la "
-"base de données dans un même thread! Bien sûr, le même raisonnement "
-"s'applique sur la gestion des transactions à la base de données. Les appels "
-"à la base de données devraient être faits en ordre et selon une séquence "
-"définie. Ils devraient également être regroupés en des unités de travail "
-"atomiques. (Notez que l?utilisation d?une connexion auto-commit constitue le "
-"même anti-pattern. Ce mode de fonctionnement existe pour les applications "
-"émettant des commandes SQL à partir d?une console. Hibernate désengage le "
-"mode auto-commit et s'attend à ce qu'un serveur d'applications le fasse "
+"Tout d'abord n'utilisez pas l'anti-pattern <emphasis>session-par-operation</"
+"emphasis> et n'ouvrez et ne fermez pas la <literal>Session</literal> à "
+"chacun de vos accès simples à la base de données dans un même thread ! Par "
+"conséquent, le même raisonnement est applicable à la gestion des "
+"transactions dans la base de données. Dans une application, les appels à la "
+"base de données doivent être effectués selon une séquence ordonnée et sont "
+"regroupés en unités de travail atomiques. (Notez que l'utilisation d'une "
+"connexion auto-commit après chaque déclaration SQL est inutile dans une "
+"application. Ce mode de fonctionnement existe pour les applications émettant "
+"des commandes SQL ad-hoc à partir d'une console. Hibernate désengage le mode "
+"auto-commit et s'attend à ce qu'un serveur d'applications le fasse "
 "également.) Les transactions avec la base de données ne sont jamais "
-"optionnelles, toute communication avec une base de données doit se dérouler "
+"optionnelles. Toute communication avec une base de données doit se dérouler "
 "dans une transaction, peu importe si vous lisez ou écrivez des données. "
-"Comme évoqué, le comportement auto-commit pour lire les données devrait être "
-"évité, puisque plusieurs petites transactions ne seront jamais aussi "
-"efficaces qu'une seule plus grosse clairement définie comme unité de "
-"travail. Ce dernier choix et en plus beaucoup plus facile a maintenir et à "
-"faire évoluer."
+"Comme déjà mentionné, le comportement auto-commit pour lire les données "
+"devrait être évité, puisque plusieurs petites transactions ne seront jamais "
+"aussi efficaces qu'une seule plus grosse clairement définie comme unité de "
+"travail. Ce dernier choix est de plus beaucoup plus facile à maintenir et "
+"plus extensible."
 
 #. Tag: para
-#: transactions.xml:126
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The most common pattern in a multi-user client/server application is "
 "<emphasis>session-per-request</emphasis>. In this model, a request from the "
@@ -230,24 +233,23 @@
 "literal>. The relationship between the two is one-to-one and this model is a "
 "perfect fit for many applications."
 msgstr ""
-"Le pattern d'utilisation le plus fréquemment rencontré dans des applications "
-"clients serveur multi-usagers est le <emphasis>session-per-request</"
-"emphasis> (littéralement : Session par requête). Dans ce modèle, la requête "
-"d'un client est envoyée à un serveur (Où la couche de persistance est "
-"implémentée via Hibernate), une nouvelle <literal>Session</literal> est "
-"ouverte et toutes les opérations d'accès à la base de données sont exécutées "
-"à l'intérieur de celle-ci. Lorsque le travail est terminé (et que les "
-"réponses à envoyer au client ont été préparées), la session est flushée et "
-"fermée. Une seule transaction à la base de données peut être utilisée pour "
-"répondre à la requête du client. La transaction est démarrée et validée au "
-"même moment où la Session est ouverte et fermée. La relation entre la "
-"<literal>Session</literal> et la <literal>Transaction</literal> est donc one-"
-"to-one. Ce modèle permet de répondre parfaitement aux attentes de la grande "
-"majorité des applications."
+"Le modèle d'utilisation le plus fréquemment rencontré dans des applications "
+"clients serveur multi-usagers est la <emphasis>session-par-requête</"
+"emphasis>. Dans ce modèle, la requête d'un client est envoyée au serveur (où "
+"la couche de persistance est implémentée via Hibernate), une nouvelle "
+"<literal>Session</literal> Hibernate est ouverte et toutes les opérations "
+"d'accès à la base de données sont exécutées à l'intérieur de celle-ci. "
+"Lorsque le travail est terminé (et que les réponses à envoyer au client ont "
+"été préparées), la session est flushée et fermée. Une seule transaction à la "
+"base de données peut être utilisée pour répondre à la requête du client. La "
+"transaction est démarrée et validée au même moment où la Session est ouverte "
+"et fermée. La relation entre la <literal>Session</literal> et la "
+"<literal>Transaction</literal> est donc un-à-un. Cette relation entre les "
+"deux est un-à-un et ce modèle permet de répondre parfaitement aux attentes "
+"de la grande majorité des applications. "
 
 #. Tag: para
-#: transactions.xml:138
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The challenge lies in the implementation. Hibernate provides built-in "
 "management of the \"current session\" to simplify this pattern. Start a "
@@ -262,40 +264,38 @@
 "chapter."
 msgstr ""
 "Le défi réside dans l'implémentation. Hibernate fournit une fonction de "
-"gestion de la \"session courante\" pour simplifier ce pattern. Tout ce que "
-"vous devez faire est démarrer une transaction lorsqu'une requête est traitée "
-"par le serveur, et la terminer avant que la réponse ne soit envoyée au "
-"client. Vous pouvez le faire de la manière que vous voulez, les solutions "
-"communes sont un <literal>ServletFilter</literal>, l'interception via AOP "
-"avec une pointcut sur les méthodes de type \"service\", ou un conteneur avec "
-"interception/proxy. Un conteneur EJB est un moyen standard d'implémenter ce "
-"genre d'acpect tranverse comme la démarcation des transactions sur les EJBs "
-"session, de manière déclarative avec CMT. Si vous décidez d'utiliser la "
-"démarcation programmatique des transactions, préferrez l'API Hibernate "
-"<literal>Transaction</literal> détaillée plus tard dans ce chapitre, afin de "
-"facilité l'utilisation et la portabilité du code."
+"gestion intégrée de la \"session courante\" pour simplifier ce pattern. Il "
+"vous suffit de démarrer une transaction lorsqu'une requête est traitée par "
+"le serveur, et la terminer avant que la réponse ne soit envoyée au client. "
+"Vous pouvez choisir la manière de l'effectuer, les solutions communes sont "
+"un <literal>ServletFilter</literal>, l'interception via AOP avec une coupe "
+"transverse (pointcut) sur les méthodes de type \"service\", ou un conteneur "
+"avec interception/proxy. Un conteneur EJB est un moyen standard "
+"d'implémenter ce genre d'acpect transverse comme la démarcation des "
+"transactions sur les EJB  session, de manière déclarative avec CMT. Si vous "
+"décidez d'utiliser la démarcation programmatique des transactions, préferrez "
+"l'API Hibernate <literal>Transaction</literal> traitée plus tard dans ce "
+"chapitre, afin de faciliter l'utilisation et la portabilité du code. "
 
 #. Tag: para
-#: transactions.xml:150
 #, fuzzy, no-c-format
 msgid ""
 "Your application code can access a \"current session\" to process the "
 "request by calling <literal>sessionFactory.getCurrentSession()</literal>. "
 "You will always get a <literal>Session</literal> scoped to the current "
 "database transaction. This has to be configured for either resource-local or "
-"JTA environments, see <xref linkend=\"architecture-current-session\"/>."
+"JTA environments, see <xref linkend=\"architecture-current-session\" />."
 msgstr ""
-"Votre application peut accéder la \"session courante\" pour exécuter une "
+"Votre application peut accéder à une \"session courante\" pour traiter une "
 "requête en invoquant simplement <literal>sessionFactory.getCurrentSession()</"
-"literal> n'importe où et autant de fois que souhaité. Vous obtiendrez "
-"toujours une <literal>Session</literal> dont le scope est la transaction "
+"literal> n'importe où et autant de fois que nécessaire. Vous obtiendrez "
+"toujours une <literal>Session</literal> dont la portée est la transaction "
 "courante avec la base de données. Ceci doit être configuré soit dans les "
-"ressources local ou dans l'environnement JTA, voir <xref linkend="
-"\"architecture-current-session\"/>."
+"ressources locales ou dans l'environnement JTA, voir <xref linkend="
+"\"architecture-current-session\" />."
 
 #. Tag: para
-#: transactions.xml:158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can extend the scope of a <literal>Session</literal> and database "
 "transaction until the \"view has been rendered\". This is especially useful "
@@ -307,27 +307,25 @@
 "of any view can start. See the Hibernate website and forum for tips and "
 "examples relating to this <emphasis>Open Session in View</emphasis> pattern."
 msgstr ""
-"Il est parfois utile d'étendre le scope d'une <literal>Session</literal> et "
+"Il est parfois utile d'étendre la portée d'une <literal>Session</literal> et "
 "d'une transaction à la base de données jusqu'à ce que \"la vue soit rendue"
 "\". Ceci est particulièrement utile dans des applications à base de servlet "
 "qui utilisent une phase de rendue séparée une fois que la réponse a été "
-"préparée. Etendre la transaction avec la base de données jusqu'à la fin du "
+"préparée. Étendre la transaction avec la base de données jusqu'à la fin du "
 "rendering de la vue est aisé si vous implémentez votre propre intercepteur. "
-"Cependant, ce n'est pas facile si vous vous appuyez sur les EJBs avec CMT, "
+"Cependant, ce n'est pas facile si vous vous appuyez sur les EJB avec CMT, "
 "puisqu'une transaction sera achevée au retour de la méthode EJB, avant le "
 "rendu de la vue. Rendez vous sur le site Hibernate et sur le forum pour des "
 "astuces et des exemples sur le pattern <emphasis>Open Session in View</"
-"emphasis> pattern.."
+"emphasis> . "
 
 #. Tag: title
-#: transactions.xml:173
 #, no-c-format
 msgid "Long conversations"
 msgstr "Longue conversation"
 
 #. Tag: para
-#: transactions.xml:175
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The session-per-request pattern is not the only way of designing units of "
 "work. Many business processes require a whole series of interactions with "
@@ -335,17 +333,16 @@
 "applications, it is not acceptable for a database transaction to span a user "
 "interaction. Consider the following example:"
 msgstr ""
-"Le paradigme <emphasis>session-per-request</emphasis> n'est pas le seul "
-"élément à utiliser dans le design de vos unités de travail. Plusieurs "
-"processus d'affaire requièrent toute une série d'interactions avec "
-"l'utilisateur, entrelacées d'accès à la base de donnée. Dans une application "
-"Web ou une application d'entreprise, il serait inacceptable que la durée de "
-"vie d'une transaction s'étale sur plusieurs interactions avec l'usager. "
-"Considérez l'exemple suivant:"
+"Le paradigme \"session-per-request\" n'est pas le seul élément à utiliser "
+"dans le design de vos unités de travail. Plusieurs processus d'affaire "
+"requièrent toute une série d'interactions avec l'utilisateur, entrelacées "
+"d'accès à la base de donnée. Dans une application Web ou une application "
+"d'entreprise, il serait inacceptable que la durée de vie d'une transaction "
+"s'étale sur plusieurs interactions avec l'usager. Considérez l'exemple "
+"suivant :"
 
 #. Tag: para
-#: transactions.xml:185
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The first screen of a dialog opens. The data seen by the user has been "
 "loaded in a particular <literal>Session</literal> and database transaction. "
@@ -353,11 +350,10 @@
 msgstr ""
 "Un écran s'affiche. Les données vues par l'usager ont été chargées dans "
 "l'instance d'un objet <literal>Session</literal> , dans le cadre d'une "
-"transaction de base de données. L'usager est libre de modifier ces objets."
+"transaction de base de données. L'usager est libre de modifier ces objets. "
 
 #. Tag: para
-#: transactions.xml:192
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The user clicks \"Save\" after 5 minutes and expects their modifications to "
 "be made persistent. The user also expects that they were the only person "
@@ -366,11 +362,10 @@
 "L'usager clique \"Sauvegarder\" après 5 minutes et souhaite persister les "
 "modifications qu'il a apportées. Il s'attend à être la seule personne a "
 "avoir modifié ces données et qu'aucune modification conflictuelle ne se soit "
-"produite durant ce laps de temps."
+"produite durant ce laps de temps. "
 
 #. Tag: para
-#: transactions.xml:200
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "From the point of view of the user, we call this unit of work a long-running "
 "<emphasis>conversation</emphasis> or <emphasis>application transaction</"
@@ -379,11 +374,10 @@
 "Ceci s'appelle une unité de travail. Du point de vue de l'utilisateur: une "
 "<emphasis>conversation</emphasis> (ou <emphasis>transaction d'application</"
 "emphasis>). Il y a plusieurs façon de mettre ceci en place dans votre "
-"application."
+"application. "
 
 #. Tag: para
-#: transactions.xml:206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A first naive implementation might keep the <literal>Session</literal> and "
 "database transaction open during user think time, with locks held in the "
@@ -398,11 +392,10 @@
 "concurrentes et de maintenir l'isolation et l'atomicité de la transaction de "
 "l'usager. Ceci est un anti-pattern à éviter, puisque le verrouillage des "
 "enregistrements dans la base de données ne permettrait pas à l'application "
-"de gérer un grand nombre d'usagers concurrents."
+"de gérer un grand nombre d'usagers concurrents. "
 
 #. Tag: para
-#: transactions.xml:214
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You have to use several database transactions to implement the conversation. "
 "In this case, maintaining isolation of business processes becomes the "
@@ -422,11 +415,10 @@
 "exclusivement par la dernière transaction BDD la composant. Toutes les "
 "autres sous transactions BD ne doivent faire que la lecture de données. Ceci "
 "est relativement facile à mettre en place, surtout avec l'utilisation de "
-"certaines fonctionnalités d'Hibernate:"
+"certaines fonctionnalités d'Hibernate :"
 
 #. Tag: para
-#: transactions.xml:227
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Automatic Versioning</emphasis>: Hibernate can perform automatic "
 "optimistic concurrency control for you. It can automatically detect if a "
@@ -436,11 +428,10 @@
 "<emphasis>Versionnage Automatique</emphasis> - Hibernate peut gérer "
 "automatiquement les accès concurrents de manière optimiste et détecter si "
 "une modification concurrente s'est produite durant le temps de réflexion "
-"d'un usager."
+"d'un usager. A vérifier en fin de conversation."
 
 #. Tag: para
-#: transactions.xml:235
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Detached Objects</emphasis>: if you decide to use the "
 "<emphasis>session-per-request</emphasis> pattern, all loaded instances will "
@@ -456,11 +447,10 @@
 "objets et de persister les modifications y ayant été apportées. Ce pattern "
 "est appelé: <emphasis>session-per- request-with-detached-objects</emphasis> "
 "(littéralement: session- par-requête-avec-objets-détachés). Le versionnage "
-"automatique est utilisé afin d'isoler les modifications concurrentes."
+"automatique est utilisé afin d'isoler les modifications concurrentes. "
 
 #. Tag: para
-#: transactions.xml:245
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Extended (or Long) Session</emphasis>: the Hibernate "
 "<literal>Session</literal> can be disconnected from the underlying JDBC "
@@ -477,11 +467,10 @@
 "et reconnectée lors d'une nouvelle requête-client. Ce pattern s'appelle: "
 "<emphasis>session-per-conversation</emphasis> (Littéralement: session-par- "
 "conversation) et rend superflu le rattachement des objets. Le versionnage "
-"automatique est utilisé afin d'isoler les modifications concurrentes."
+"automatique est utilisé afin d'isoler les modifications concurrentes. "
 
 #. Tag: para
-#: transactions.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Both <emphasis>session-per-request-with-detached-objects</emphasis> and "
 "<emphasis>session-per-conversation</emphasis> have advantages and "
@@ -492,17 +481,15 @@
 "emphasis> (session-par-requête-avec-objets- détachés) et <emphasis>session-"
 "per-conversation</emphasis> (session-par-conversation) ont chacun leurs "
 "avantages et désavantages qui seront exposés dans ce même chapitre, dans la "
-"section au sujet du contrôle optimiste de concurrence."
+"section au sujet du contrôle optimiste de concurrence. "
 
 #. Tag: title
-#: transactions.xml:267
 #, no-c-format
 msgid "Considering object identity"
 msgstr "L'identité des objets"
 
 #. Tag: para
-#: transactions.xml:269
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An application can concurrently access the same persistent state in two "
 "different <literal>Session</literal>s. However, an instance of a persistent "
@@ -512,36 +499,31 @@
 "Une application peut accéder à la même entité persistante de manière "
 "concurrente dans deux <literal>Session</literal> s différentes. Toutefois, "
 "une instance d'une classe persistante n'est jamais partagée par deux "
-"instances distinctes de la classe <literal>Session</literal> . Il existe "
-"donc deux notions de l'identité d'un objet:"
+"instances distinctes de la classe <literal>Session</literal>. Il existe donc "
+"deux notions de l'identité d'un objet :"
 
 #. Tag: term
-#: transactions.xml:278
 #, no-c-format
 msgid "Database Identity"
-msgstr "Identité BD"
+msgstr "Identité de database"
 
-#. Tag: literal
-#: transactions.xml:281
-#, no-c-format
-msgid "foo.getId().equals( bar.getId() )"
-msgstr "foo.getId().equals( bar.getId() )"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>foo.getId().equals( bar.getId() )</literal>"
+msgstr "<literal>foo.getId().equals( bar.getId() )</literal>"
 
 #. Tag: term
-#: transactions.xml:286
 #, no-c-format
 msgid "JVM Identity"
 msgstr "Identité JVM"
 
-#. Tag: literal
-#: transactions.xml:289
+#. Tag: para
 #, no-c-format
-msgid "foo==bar"
-msgstr "foo==bar"
+msgid "<literal>foo==bar</literal>"
+msgstr "<literal>foo==bar</literal>"
 
 #. Tag: para
-#: transactions.xml:295
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For objects attached to a <emphasis>particular</emphasis> <literal>Session</"
 "literal> (i.e., in the scope of a <literal>Session</literal>), the two "
@@ -553,19 +535,18 @@
 "commit time."
 msgstr ""
 "Ainsi, pour des objets attachés à une <literal>Session</"
-"literal><emphasis>précise</emphasis> (dans la cadre d'exécution (scope) "
-"d'une instance de <literal>Session</literal> ), ces deux notions d'identité "
-"sont équivalentes et garanties par Hibernate. Par contre, si une application "
-"peut accéder de manière concurrente à la même entité persistante dans deux "
-"sessions différentes, les deux instances seront en fait différentes (en ce "
-"qui a trait à l'identité JVM). Les conflits sont résolus automatiquement par "
-"approche optimiste grâce au système de versionnage automatique lorsque "
-"<literal>Session.flush()</literal> ou <literal>Transaction.commit()</"
-"literal> est appelé."
+"literal><emphasis>particulière</emphasis> (c'est-à-dire dans la portée d'une "
+"instance de <literal>Session</literal>), ces deux notions d'identité sont "
+"équivalentes et l'identité JVM pour l'identité de la base de données sont  "
+"garanties par Hibernate. Cependant, alors qu'une application peut accéder de "
+"manière concurrente au \"même\" objet métier (identité persistante) dans "
+"deux sessions différentes, les deux instances seront en fait \"différentes"
+"\" (en ce qui a trait à l'identité JVM). Les conflits sont résolus "
+"automatiquement par approche optimiste grâce au système de versionnage "
+"automatique au moment du flush/sauvegarde. "
 
 #. Tag: para
-#: transactions.xml:304
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This approach leaves Hibernate and the database to worry about concurrency. "
 "It also provides the best scalability, since guaranteeing identity in single-"
@@ -580,15 +561,14 @@
 "faire assure également une meilleure extensibilité de l'application puisque "
 "assurer l'identité JVM dans un thread ne nécessite pas de mécanismes de "
 "verrouillage coûteux ou d'autres dispositifs de synchronisation. Une "
-"application n'aura jamais le besoin de synchroniser des objets d'affaire "
-"tant qu'elle peut garantir qu'un seul thread aura accès à une instance de "
+"application n'aura jamais besoin de synchroniser des objets d'affaire tant "
+"qu'elle peut garantir qu'un seul thread aura accès à une instance de "
 "<literal>Session</literal> . Dans le cadre d'exécution d'un objet "
-"<literal>Session</literal> , l'application peut utiliser en toute sécurité "
-"<literal>== </literal> pour comparer des objets."
+"<literal>Session</literal>, l'application peut utiliser en toute sécurité "
+"<literal>== </literal> pour comparer des objets. "
 
 #. Tag: para
-#: transactions.xml:313
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, an application that uses <literal>==</literal> outside of a "
 "<literal>Session</literal> might produce unexpected results. This might "
@@ -613,37 +593,36 @@
 msgstr ""
 "Une application qui utiliserait <literal>==</literal> à l'extérieur du cadre "
 "d'exécution d'une <literal>Session</literal> pourrait obtenir des résultats "
-"inattendus et causer certains effets de bords. Par exemple, si vous mettez 2 "
-"objets dans le même <literal>Set</literal> , ceux-ci pourraient avoir la "
-"même identité BD (i.e. ils représentent le même enregistrement), mais leur "
+"inattendus. Par exemple, si vous mettez deux objets dans le même "
+"<literal>Set</literal> , ceux-ci pourraient avoir la même identité de base "
+"de données (c'est-à-dire ils représentent le même enregistrement), mais leur "
 "identité JVM pourrait être différente (elle ne peut, par définition, pas "
 "être garantie sur deux objets détachés). Le développeur doit donc redéfinir "
 "l'implémentation des méthodes <literal>equals()</literal> et "
 "<literal>hashcode()</literal> dans les classes persistantes et y adjoindre "
-"sa propre notion d'identité. Il existe toutefois une restriction: Il ne faut "
-"jamais utiliser uniquement l'identifiant de la base de données dans "
-"l'implémentation de l'égalité; Il faut utiliser une clé d'affaire, "
+"sa propre notion d'identité. Il existe toutefois une restriction : il ne "
+"faut jamais utiliser uniquement l'identifiant de la base de données dans "
+"l'implémentation de l'égalité; il faut utiliser une clé d'affaire, "
 "généralement une combinaison de plusieurs attributs uniques, si possible "
 "immuables. Les identifiants de base de données vont changer si un objet "
-"transitoire (transient) devient persistant. Si une instance transitoire est "
-"contenue dans un <literal>Set</literal> , changer le hashcode brisera le "
-"contrat du <literal>Set</literal> . Les attributs pour les clés d'affaire "
-"n'ont pas à être aussi stables que des clés primaires de bases de données. "
-"Il suffit simplement qu'elles soient stables tant et aussi longtemps que les "
-"objets sont dans le même <literal>Set</literal> . Veuillez consulter le site "
-"web Hibernate pour des discussions plus pointues à ce sujet. Notez que ce "
-"concept n'est pas propre à Hibernate mais bien général à l'implémentation de "
-"l'identité et de l'égalité en Java."
+"transitoire (transient) devient persistant. Si une instance transitoire (en "
+"général avec des instances dégachées) est contenue dans un <literal>Set</"
+"literal>, changer le hashcode brisera le contrat du <literal>Set</literal> . "
+"Les attributs pour les clés d'affaire n'ont pas à être aussi stables que des "
+"clés primaires de bases de données. Il suffit simplement qu'elles soient "
+"stables tant et aussi longtemps que les objets sont dans le même "
+"<literal>Set</literal> . Veuillez consulter le site web Hibernate pour des "
+"discussions plus pointues à ce sujet. Notez que ce concept n'est pas propre "
+"à Hibernate mais bien général à l'implémentation de l'identité et de "
+"l'égalité en Java. "
 
 #. Tag: title
-#: transactions.xml:334
 #, no-c-format
 msgid "Common issues"
 msgstr "Problèmes communs"
 
 #. Tag: para
-#: transactions.xml:336
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not use the anti-patterns <emphasis>session-per-user-session</emphasis> "
 "or <emphasis>session-per-application</emphasis> (there are, however, rare "
@@ -652,16 +631,15 @@
 "implications before making a design decision:"
 msgstr ""
 "Bien qu'il puisse y avoir quelques rares exceptions à cette règle, il est "
-"recommandé de ne jamais utiliser les anti-patterns <emphasis>session-per- "
-"user-session</emphasis> et <emphasis>session-per-application</emphasis> . "
-"Vous trouverez ici- bas quelques problèmes que vous risquez de rencontrer si "
-"vous en faite l?utilisation. (Ces problèmes pourraient quand même survenir "
-"avec des patterns recommandés) Assurez-vous de bien comprendre les "
-"implications de chacun des patterns avant de prendre votre décision."
+"recommandé de ne jamais utiliser les anti-modèles <emphasis>session-par- "
+"utilisateur-session</emphasis> ou <emphasis>session-par-application</"
+"emphasis> . Notez que certains des problèmes suivants pourraient néanmoins "
+"survenir avec des modèles recommandés, assurez-vous de bien comprendre les "
+"implications de chacun des modèles avant de prendre une décision concernant "
+"votre design :"
 
 #. Tag: para
-#: transactions.xml:345
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>Session</literal> is not thread-safe. Things that work "
 "concurrently, like HTTP requests, session beans, or Swing workers, will "
@@ -672,19 +650,19 @@
 "that clicks reload fast enough can use the same <literal>Session</literal> "
 "in two concurrently running threads."
 msgstr ""
-"L'objet <literal>Session</literal> n?est pas conçu pour être utilisé par de "
+"L'objet <literal>Session</literal> n'est pas conçu pour être utilisé par de "
 "multiples threads. En conséquence, les objets potentiellement multi-thread "
 "comme les requêtes HTTP, les EJB Session et Swing Worker, risquent de "
 "provoquer des conditions de course dans la <literal>Session</literal> si "
-"celle-ci est partagée. Dans un environnement web classique, il serait "
-"préférable de synchroniser les accès à la session http afin d?éviter qu?un "
-"usager ne recharge une page assez rapidement pour que deux requêtes s?"
-"exécutant dans des threads concurrents n?utilisent la même <literal>Session</"
-"literal> ."
+"celle-ci est partagée. Si vous gardez votre <literal>Session</literal> "
+"Hibernate dans la <literal>HttpSession</literal> (le sujet sera traité "
+"ultérieurement), il serait préférable de synchroniser les accès à la session "
+"Http afin d'éviter qu'un usager ne recharge une page assez rapidement pour "
+"que deux requêtes exécutant dans des threads concurrents n'utilisent la même "
+"<literal>Session</literal>."
 
 #. Tag: para
-#: transactions.xml:356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An exception thrown by Hibernate means you have to rollback your database "
 "transaction and close the <literal>Session</literal> immediately (this is "
@@ -696,18 +674,19 @@
 "Usually this is not a problem, because exceptions are not recoverable and "
 "you will have to start over after rollback anyway."
 msgstr ""
-"Lorsque Hibernate lance une exception, le roll back de la transaction en "
-"cours doit être effectué et la <literal>Session</literal> doit être "
-"immédiatement fermée. (Ceci sera exploré plus tard dans le chapitre.) Si la "
-"<literal>Session</literal> est directement associée à une application, il "
-"faut arrêter l?application. Le roll back de la transaction ne remettra pas "
-"les objets dans leur état du début de la transaction. Ainsi, ceux-ci "
-"pourraient être désynchronisés d?avec les enregistrements. (Généralement, "
-"cela ne cause pas de réels problèmes puisque la plupart des exceptions sont "
-"non traitables et requièrent la reprise du processus d?affaire ayant échoué.)"
+"Lorsque Hibernate lance une exception, le rollback de la transaction en "
+"cours dans la base de données, doit être effectué et la <literal>Session</"
+"literal> immédiatement fermée. (Nous approfondirons le sujet plus loin) Si "
+"votre <literal>Session</literal> est liée à l'application, il faut arrêter "
+"l'application. Le rollback de la transaction de base de données ne remettra "
+"pas les objets dans leur état du début de la transaction. Ainsi, cela "
+"signifie que l'état de la base de données et les objets d'affaires "
+"pourraient être désynchronisés d'avec les enregistrements. Généralement, "
+"cela ne cause pas de réel problème puisque la plupart des exceptions sont "
+"non traitables et de toutes façons, vous devez recommencer le processus "
+"après le rollback). "
 
 #. Tag: para
-#: transactions.xml:368
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>Session</literal> caches every object that is in a persistent "
@@ -716,34 +695,32 @@
 "until you get an OutOfMemoryException. One solution is to call <literal>clear"
 "()</literal> and <literal>evict()</literal> to manage the <literal>Session</"
 "literal> cache, but you should consider a Stored Procedure if you need mass "
-"data operations. Some solutions are shown in <xref linkend=\"batch\"/>. "
+"data operations. Some solutions are shown in <xref linkend=\"batch\" />. "
 "Keeping a <literal>Session</literal> open for the duration of a user session "
 "also means a higher probability of stale data."
 msgstr ""
 "La <literal>Session</literal> met en mémoire cache tous les objets "
-"persistants (les objets surveillés et dont l'état est géré par Hibernate.) "
-"Si la <literal>Session</literal> est ouverte indéfiniment ou si une trop "
-"grande quantité d'objets y est chargée, l?utilisation de la mémoire peut "
-"potentiellement croître jusqu?à atteindre le maximum allouable à l?"
-"application (java.lang.OutOfMemoryError.) Une solution à ce problème est d?"
-"appeler les méthodes <literal>Session.clear()</literal> et <literal>Session."
-"evict()</literal> pour gérer la mémoire cache de la <literal>Session</"
-"literal> . Vous pouvez également utiliser des stored procedures si vous "
-"devez lancer des traitements sur de grandes quantités d?informations. "
-"Certaines solutions sont décrites ici : <xref linkend=\"batch\"/> . Garder "
-"une <literal>Session</literal> ouverte pour toute la durée d?une session "
-"usager augmente également considérablement le risque de travailler avec de l?"
-"information périmée."
+"persistants (les objets surveillés et dont l'état (dirty) est vérifié par "
+"Hibernate.) Si la <literal>Session</literal> est ouverte indéfiniment ou si "
+"une trop grande quantité d'objets y est chargée, l'utilisation de la mémoire "
+"peut potentiellement croître jusqu'à atteindre java.lang.OutOfMemoryError, "
+"le maximum alouable à l'application. Une solution à ce problème est "
+"d'appeler les méthodes <literal>Session.clear()</literal> et "
+"<literal>Session.evict()</literal> pour gérer la mémoire cache de la "
+"<literal>Session</literal>. Vous pouvez également utiliser des procédures "
+"stockées si vous devez lancer des traitements sur de grandes quantités "
+"d'informations. Certaines solutions sont décrites ici : <xref linkend=\"batch"
+"\" />. Garder une <literal>Session</literal> ouverte pour toute la durée "
+"d'une session usager, augmente également considérablement le risque de "
+"travailler avec des informations périmées. "
 
 #. Tag: title
-#: transactions.xml:386
 #, no-c-format
 msgid "Database transaction demarcation"
-msgstr "Démarcation des transactions"
+msgstr "Démarcation des transactions de base de données"
 
 #. Tag: para
-#: transactions.xml:388
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Database, or system, transaction boundaries are always necessary. No "
 "communication with the database can occur outside of a database transaction "
@@ -754,19 +731,20 @@
 "transactions explicitly. Certainly, a single database transaction is going "
 "to perform better than many small transactions, even for reading data."
 msgstr ""
-"La démarcation des transactions est importante dans le design d?une "
-"application. Aucune communication avec la base de données ne peut être "
-"effectuée à l?extérieur du cadre d?une transaction. (Il semble que ce "
+"La démarcation des transactions de base de données (ou système) est toujours "
+"nécessaire. Aucune communication avec la base de données ne peut être "
+"effectuée à l'extérieur du cadre d'une transaction. (Il semble que ce "
 "concept soit mal compris par plusieurs développeurs trop habitués à utiliser "
-"le mode auto-commit.) Même si certains niveaux d'isolation et certaines "
-"possibilités offertes par les bases de données permettent de l?éviter, il "
-"n'est jamais désavantageux de toujours explicitement indiquer les bornes de "
-"transaction pour les opérations complexes comme pour les opérations simples "
-"de lecture."
+"le mode auto-commit.) Utilisez toujours la démarcation des des transactions, "
+"même pour des opérations en lecture seule. Certains niveaux d'isolation et "
+"certaines possibilités offertes par les bases de données permettent de "
+"l'éviter, il n'est jamais désavantageux de toujours explicitement indiquer "
+"les bornes de transaction. Il est certain qu'une transaction unique de base "
+"de données sera plus performante que de nombreuses petites transactions, "
+"même pour les opérations simples de lecture. "
 
 #. Tag: para
-#: transactions.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A Hibernate application can run in non-managed (i.e., standalone, simple "
 "Web- or Swing applications) and managed J2EE environments. In a non-managed "
@@ -779,25 +757,23 @@
 "demarcation is then no longer necessary."
 msgstr ""
 "Une application utilisant Hibernate peut s'exécuter dans un environnement "
-"léger n?offrant pas la gestion automatique des transactions (application "
+"léger n'offrant pas la gestion automatique des transactions (application "
 "autonome, application web simple ou applications Swing) ou dans un "
-"environnement J2EE offrant des services de gestion automatique des "
+"environnement J2EE offrant des services de gestion automatiques des "
 "transactions JTA. Dans un environnement simple, Hibernate a généralement la "
 "responsabilité de la gestion de son propre pool de connexions à la base de "
 "données. Le développeur de l'application doit manuellement délimiter les "
 "transactions. En d'autres mots, il appartient au développeur de gérer les "
 "appels à <literal>Transaction.begin()</literal> , <literal>Transaction.commit"
-"()</literal> et <literal>Transaction.rollback()</literal> . Un environnement "
+"()</literal> et <literal>Transaction.rollback()</literal>. Un environnement "
 "transactionnel J2EE (serveur d'application J2EE) doit offrir la gestion des "
-"transactions au niveau du container J2EE. Les bornes de transaction peuvent "
+"transactions au niveau du conteneur J2EE. Les bornes de transaction peuvent "
 "normalement être définies de manière déclarative dans les descripteurs de "
 "déploiement d'EJB Session, par exemple. La gestion programmatique des "
-"transactions n'y est donc pas nécessaire. Même les appels à <literal>Session."
-"flush()</literal> sont faits automatiquement."
+"transactions n'y est donc plus nécessaire."
 
 #. Tag: para
-#: transactions.xml:408
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, it is often desirable to keep your persistence layer portable "
 "between non-managed resource-local environments, and systems that can rely "
@@ -807,68 +783,62 @@
 "system of your deployment environment. This API is actually optional, but we "
 "strongly encourage its use unless you are in a CMT session bean."
 msgstr ""
-"Il peut être requis d'avoir une couche de persistance portable. Hibernate "
-"offre donc une API appelée <literal>Transaction</literal> qui sert "
+"Cependant, il est souvent préférable d'avoir une couche de persistance "
+"portable entre les environnements non gérés de ressources locales et les "
+"systèmes qui s'appuient sur JTA mais utilisent BMT à la place de CMT. Dans "
+"les deux cas, vous utiliserez la démarcation de transaction programmatique. "
+"Hibernate offre donc une API appelée <literal>Transaction</literal> qui sert "
 "d'enveloppe pour le système de transaction natif de l'environnement de "
-"déploiement. Il n'est pas obligatoire d'utiliser cette API mais il est "
+"déploiement. Il n'est pas obligatoire d'utiliser cette API, mais il est "
 "fortement conseillé de le faire, sauf lors de l'utilisation de CMT Session "
-"Bean (EJB avec transactions gérées automatiquement par le container EJB)."
+"Bean."
 
 #. Tag: para
-#: transactions.xml:417
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Ending a <literal>Session</literal> usually involves four distinct phases:"
 msgstr ""
-"Il existe quatre étapes disctinctes lors de la fermeture d'une "
-"<literal>Session</literal>"
+"Il existe quatre étapes distinctes lors de la fermeture d'une "
+"<literal>Session</literal> :"
 
 #. Tag: para
-#: transactions.xml:423
 #, no-c-format
 msgid "flush the session"
 msgstr "flush de la session"
 
 #. Tag: para
-#: transactions.xml:428
 #, no-c-format
 msgid "commit the transaction"
 msgstr "commit de la transaction"
 
 #. Tag: para
-#: transactions.xml:433
 #, no-c-format
 msgid "close the session"
-msgstr "Fermeture de la session (Close)"
+msgstr "fermeture de la session "
 
 #. Tag: para
-#: transactions.xml:438
 #, no-c-format
 msgid "handle exceptions"
-msgstr "Gestion des exceptions"
+msgstr "gestion des exceptions"
 
 #. Tag: para
-#: transactions.xml:444
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We discussed Flushing the session earlier, so we will now have a closer look "
 "at transaction demarcation and exception handling in both managed and non-"
 "managed environments."
 msgstr ""
-"La synchronisation de bdd depuis la session (flush) a déjà été expliqué, "
-"nous nous attarderons maintenant à la démarcation des transactions et à la "
-"gestion des exceptions dans les environnements légers et les environnements "
-"J2EE."
+"La notion de \"Flushing\" a déjà été expliquée, nous abordons maintenant la "
+"démarcation des transactions et la gestion des exceptions dans les "
+"environnements gérés et non-gérés."
 
 #. Tag: title
-#: transactions.xml:451
 #, no-c-format
 msgid "Non-managed environment"
-msgstr "Environnement non managé"
+msgstr "Environnement non gérés"
 
 #. Tag: para
-#: transactions.xml:453
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If a Hibernate persistence layer runs in a non-managed environment, database "
 "connections are usually handled by simple (i.e., non-DataSource) connection "
@@ -876,36 +846,12 @@
 "transaction handling idiom looks like this:"
 msgstr ""
 "Si la couche de persistance Hibernate s'exécute dans un environnement non "
-"managé, les connexions à la base de données seront généralement prises en "
-"charge par le mécanisme de pool d'Hibernate. La gestion de la session et de "
-"la transaction se fera donc de la manière suivante:"
+"géré, les connexions à la base de données seront généralement prises en "
+"charge par le mécanisme de pool d'Hibernate qui obtient les connexions. La "
+"gestion de la session et de la transaction se fera donc de la manière "
+"suivante : "
 
-#. Tag: programlisting
-#: transactions.xml:460
-#, no-c-format
-msgid ""
-"<![CDATA[// Non-managed environment idiom\n"
-"Session sess = factory.openSession();\n"
-"Transaction tx = null;\n"
-"try {\n"
-"    tx = sess.beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    if (tx != null) tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:462
 #, fuzzy, no-c-format
 msgid ""
 "You do not have to <literal>flush()</literal> the <literal>Session</literal> "
@@ -918,46 +864,25 @@
 msgstr ""
 "Vous n'avez pas à invoquer <literal>flush()</literal> explicitement sur la "
 "<literal>Session</literal> - l'appel de <literal>commit()</literal> "
-"déclenchera automatiquement la synchronisation (selon le <xref linkend="
-"\"objectstate-flushing\">FlushMode</xref> de la session. Un appel à "
-"<literal>close()</literal> marque la fin de la session. La conséquence "
-"directe est que la connexion à la base de données sera relachée par la "
-"session. Ce code est portable est fonctionne dans les environnements non "
-"managé ET les environnements JTA."
+"déclenchera automatiquement la synchronisation (selon le FlushMode <xref "
+"linkend=\"objectstate-flushing\" /> de la session. Un appel à <literal>close"
+"()</literal> marque la fin de la session. La conséquence directe de "
+"<literal>close()</literal> est que la connexion à la base de données sera "
+"relâchée par la session. Ce code est portable et fonctionne dans les "
+"environnements non gérés et les environnements JTA. "
 
 #. Tag: para
-#: transactions.xml:471
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As outlined earlier, a much more flexible solution is Hibernate's built-in "
 "\"current session\" context management:"
 msgstr ""
-"Une solution plus flexible est la gestion par contexte fourni par Hibernate "
-"que nous avons déjà rencontré:"
+"Une solution plus flexible est la gestion par contexte de la session "
+"courante intégrée, fournie par Hibernate que nous avons déjà rencontrée :"
 
-#. Tag: programlisting
-#: transactions.xml:476
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// Non-managed environment idiom with getCurrentSession()\n"
-"try {\n"
-"    factory.getCurrentSession().beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    factory.getCurrentSession().getTransaction().commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    factory.getCurrentSession().getTransaction().rollback();\n"
-"    throw e; // or display error message\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:478
-#, fuzzy, no-c-format
-msgid ""
 "You will not see these code snippets in a regular application; fatal "
 "(system) exceptions should always be caught at the \"top\". In other words, "
 "the code that executes Hibernate calls in the persistence layer, and the "
@@ -968,19 +893,18 @@
 "this chapter."
 msgstr ""
 "Vous ne verrez probablement jamais ces exemples de code dans les "
-"applications; les exceptions fatales (exceptions du système) ne devraient "
+"applications ; les exceptions fatales (exceptions du système) ne devraient "
 "être traitées que dans la couche la plus \"haute\". En d'autres termes, le "
 "code qui exécute les appels à Hibernate (à la couche de persistance) et le "
 "code qui gère les <literal>RuntimeException</literal> (qui ne peut "
 "généralement effectuer qu'un nettoyage et une sortie) sont dans des couches "
 "différentes. La gestion du contexte courant par Hibernate peut simplifier "
-"notablement ce design, puisque vous devez accéder à la gestion des "
-"exceptions de la <literal>SessionFactory</literal>, ce qui est décrit plus "
-"tard dans ce chapitre."
+"notablement ce design, puisqu'il vous suffit d'accéder à la "
+"<literal>SessionFactory</literal>. La gestion des exceptions est traitée "
+"plus loin dans ce chapitre. "
 
 #. Tag: para
-#: transactions.xml:488
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You should select <literal>org.hibernate.transaction.JDBCTransactionFactory</"
 "literal>, which is the default, and for the second example select <literal>"
@@ -989,18 +913,16 @@
 msgstr ""
 "Notez que vous devriez sélectionner <literal>org.hibernate.transaction."
 "JDBCTransactionFactory</literal> (le défaut), pour le second exemple "
-"<literal>\"thread\"</literal> comme <literal>hibernate."
-"current_session_context_class</literal>."
+"<literal>\"thread\"</literal> comme votre <literal>hibernate."
+"current_session_context_class</literal>. "
 
 #. Tag: title
-#: transactions.xml:497
 #, no-c-format
 msgid "Using JTA"
 msgstr "Utilisation de JTA"
 
 #. Tag: para
-#: transactions.xml:499
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your persistence layer runs in an application server (for example, behind "
 "EJB session beans), every datasource connection obtained by Hibernate will "
@@ -1008,14 +930,14 @@
 "standalone JTA implementation and use it without EJB. Hibernate offers two "
 "strategies for JTA integration."
 msgstr ""
-"Si votre couche de persistance s'exécute dans un serveur d'application (par "
-"exemple, derrière un EJB Session Bean), toutes les datasource utilisées par "
-"Hibernate feront automatiquement partie de transactions JTA globales. "
-"Hibernate propose deux stratégies pour réussir cette intégration."
+"Si votre couche de persistance s'exécute dans un serveur d'applications (par "
+"exemple, derrière un EJB Session Bean), toutes les datasources utilisées par "
+"Hibernate feront automatiquement partie de transactions JTA globales. Vous "
+"pouvez également installer une implémentation autonome JTA et l'utiliser "
+"sans l'EJB.Hibernate propose deux stratégies pour réussir l'intégration JTA. "
 
 #. Tag: para
-#: transactions.xml:506
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you use bean-managed transactions (BMT), Hibernate will tell the "
 "application server to start and end a BMT transaction if you use the "
@@ -1023,94 +945,37 @@
 "identical to the non-managed environment."
 msgstr ""
 "Si vous utilisez des transactions gérées par un EJB (bean managed "
-"transactions - BMT), Hibernate informera le serveur d'application du début "
+"transactions - BMT), Hibernate informera le serveur d'applications du début "
 "et de la fin des transactions si vous utilisez l'API <literal>Transaction</"
-"literal> . Ainsi, le code de gestion des transactions sera identique dans "
-"les deux types d'environnements."
+"literal>. Ainsi, le code de gestion des transactions sera identique dans les "
+"environnements non gérés. "
 
-#. Tag: programlisting
-#: transactions.xml:512
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// BMT idiom\n"
-"Session sess = factory.openSession();\n"
-"Transaction tx = null;\n"
-"try {\n"
-"    tx = sess.beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    if (tx != null) tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:514
-#, fuzzy, no-c-format
-msgid ""
 "If you want to use a transaction-bound <literal>Session</literal>, that is, "
 "the <literal>getCurrentSession()</literal> functionality for easy context "
 "propagation, use the JTA <literal>UserTransaction</literal> API directly:"
-msgstr "Ou encore, avec la gestion automatique de contexte:"
-
-#. Tag: programlisting
-#: transactions.xml:520
-#, no-c-format
-msgid ""
-"<![CDATA[// BMT idiom with getCurrentSession()\n"
-"try {\n"
-"    UserTransaction tx = (UserTransaction)new InitialContext()\n"
-"                            .lookup(\"java:comp/UserTransaction\");\n"
-"\n"
-"    tx.begin();\n"
-"\n"
-"    // Do some work on Session bound to transaction\n"
-"    factory.getCurrentSession().load(...);\n"
-"    factory.getCurrentSession().persist(...);\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}]]>"
 msgstr ""
+"Si vous souhaitez utiliser une <literal>Session</literal> couplée à la "
+"transaction, c'est à dire, utiliser la fonctionnalité "
+"<literal>getCurrentSession()</literal> pour la propagation facile du "
+"contexte, vous devez utiliser l'API JTA <literal>UserTransaction</literal> "
+"directement :"
 
 #. Tag: para
-#: transactions.xml:522
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "With CMT, transaction demarcation is completed in session bean deployment "
 "descriptors, not programmatically. The code is reduced to:"
 msgstr ""
 "Avec CMT, la démarcation des transactions est faite dans les descripteurs de "
-"déploiement des Beans Sessions et non de manière programmmatique, ceci "
-"réduit le code:"
+"déploiement des Beans Sessions et non de manière programmatique, par "
+"conséquent le code est réduit à : "
 
-#. Tag: programlisting
-#: transactions.xml:527
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// CMT idiom\n"
-" Session sess = factory.getCurrentSession();\n"
-"\n"
-" // do some work\n"
-" ...\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:529
-#, fuzzy, no-c-format
-msgid ""
 "In a CMT/EJB, even rollback happens automatically. An unhandled "
 "<literal>RuntimeException</literal> thrown by a session bean method tells "
 "the container to set the global transaction to rollback. <emphasis>You do "
@@ -1118,15 +983,16 @@
 "BMT or CMT, and you get automatic propagation of the \"current\" Session "
 "bound to the transaction.</emphasis>"
 msgstr ""
-"Dans un EJB CMT même le rollback intervient automatiquement, puisqu'une "
+"Dans un EJB CMT, le rollback aussi intervient automatiquement, puisqu'une "
 "<literal>RuntimeException</literal> non traitée et soulevée par une méthode "
 "d'un bean session indique au conteneur d'annuler la transaction globale. "
 "<emphasis>Ceci veut donc dire que vous n'avez pas à utiliser l'API "
-"<literal>Transaction</literal> d'Hibernate dans CMT.</emphasis>"
+"<literal>Transaction</literal> de Hibernate dans CMT ou BMT et vous obtenez "
+"la propagation automatique de la session courante liée à la transaction.</"
+"emphasis>"
 
 #. Tag: para
-#: transactions.xml:537
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When configuring Hibernate's transaction factory, choose <literal>org."
 "hibernate.transaction.JTATransactionFactory</literal> if you use JTA "
@@ -1140,16 +1006,15 @@
 "<literal>org.hibernate.transaction.JTATransactionFactory</literal> dans un "
 "environnement BMT ou <literal>org.hibernate.transaction."
 "CMTTransactionFactory</literal> dans un environnement CMT là où vous "
-"configurez votre transaction factory Hibernate. N'oubliez pas non plus de "
-"spécifier le paramètre <literal>org.hibernate.transaction."
-"manager_lookup_class</literal> . De plus, assurez vous de fixez votre "
+"configurez votre fabrique de transaction Hibernate. N'oubliez pas non plus "
+"de spécifier le paramètre <literal>org.hibernate.transaction."
+"manager_lookup_class</literal> . De plus, assurez vous de fixer votre "
 "<literal>hibernate.current_session_context_class</literal> soit à <literal>"
 "\"jta\"</literal> ou de ne pas le configurer (compatibilité avec les "
-"versions précédentes)."
+"versions précédentes). "
 
 #. Tag: para
-#: transactions.xml:546
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>getCurrentSession()</literal> operation has one downside in a "
 "JTA environment. There is one caveat to the use of <literal>after_statement</"
@@ -1165,28 +1030,26 @@
 "JTA or CMT code.)"
 msgstr ""
 "La méthode <literal>getCurrentSession()</literal> a un inconvénient dans les "
-"environnement JTA. Il y a une astuce qui est d'utiliser un mode de "
+"environnements JTA. Il y a une astuce qui est d'utiliser un mode de "
 "libération de connexion <literal>after_statement</literal> , qui est alors "
 "utilisé par défaut. Du à une étrange limitation de la spec JTA, il n'est pas "
-"possible pour Hibernate de nettoyer et ferme automatiquement un "
+"possible à Hibernate de nettoyer automatiquement un "
 "<literal>ScrollableResults</literal> ouvert ou une instance "
 "d'<literal>Iterator</literal> retournés <literal>scroll()</literal> ou "
 "<literal>iterate()</literal>. Vous <emphasis>devez</emphasis> libérer le "
 "curseur base de données sous jacent ou invoquer <literal>Hibernate.close"
 "(Iterator)</literal> explicitement depuis un bloc <literal>finally</"
-"literal>. (Bien sur, la plupart des applications peuvent éviter d'uiliser "
-"<literal>scroll()</literal> ou <literal>iterate()</literal> dans un code "
-"CMT.)"
+"literal>. (Bien sur, la plupart des applications peuvent éviter d'utiliser "
+"<literal>scroll()</literal> ou <literal>iterate()</literal> dans un code JTA "
+"ou CMT.) "
 
 #. Tag: title
-#: transactions.xml:562
 #, no-c-format
 msgid "Exception handling"
 msgstr "Gestion des exceptions"
 
 #. Tag: para
-#: transactions.xml:564
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the <literal>Session</literal> throws an exception, including any "
 "<literal>SQLException</literal>, immediately rollback the database "
@@ -1199,17 +1062,16 @@
 msgstr ""
 "Si une <literal>Session</literal> lance une exception (incluant les "
 "exceptions du type <literal>SQLException</literal> ou d'un sous-type), vous "
-"devez immédiatement faire le rollback de la transaction, appeler "
+"devez immédiatement effectuer le rollback de la transaction, appeler "
 "<literal>Session.close()</literal> et relâcher les références sur l'objet "
 "<literal>Session</literal> . La <literal>Session</literal> contient des "
 "méthodes pouvant la mettre dans un état inutilisable. Vous devez considérer "
 "qu'<emphasis>aucune</emphasis> exception lancée par Hibernate n'est "
-"traitable. Assurez-vous de fermer la session en faisant l'appel à "
-"<literal>close()</literal> dans un bloc <literal>finally</literal> ."
+"traitable comme recouvrable. Assurez-vous de fermer la session en appelant "
+"<literal>close()</literal> dans un bloc <literal>finally</literal> . "
 
 #. Tag: para
-#: transactions.xml:575
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>HibernateException</literal>, which wraps most of the errors "
 "that can occur in a Hibernate persistence layer, is an unchecked exception. "
@@ -1222,22 +1084,21 @@
 "unchecked exceptions that are not a <literal>HibernateException</literal>. "
 "These are not recoverable and appropriate action should be taken."
 msgstr ""
-"L'exception <literal>HibernateException</literal> , qui englobe la plupart "
+"L'exception <literal>HibernateException</literal>, qui englobe la plupart "
 "des exceptions pouvant survenir dans la couche de persistance Hibernate, est "
-"une exception non vérifiée (Ceci n'était pas le cas dans certaines versions "
-"antérieures de Hibernate.) Il est de notre avis que nous ne devrions pas "
-"forcer un développeur à gérer une exception qu'il ne peut de toute façon pas "
-"traiter dans une couche technique. Dans la plupart des applications, les "
-"exceptions non vérifiées et les exceptions fatales sont gérées en amont du "
-"processus (dans les couches hautes) et un message d'erreur est alors affiché "
-"à l'usager (ou un traitement alternatif est invoqué.) Veuillez noter "
-"qu'Hibernate peut également lancer des exceptions non vérifiées d'un autre "
-"type que <literal>HibernateException</literal> . Celles-ci sont également "
-"non traitables et vous devez les traiter comme telles."
+"une exception non vérifiée (Ceci n'était pas le cas dans des versions "
+"antérieures de Hibernate.) Nous pensons que nous ne devrions pas forcer un "
+"développeur à gérer une exception qu'il ne peut de toute façon pas traiter "
+"dans une couche technique. Dans la plupart des systèmes, les exceptions non "
+"vérifiées et les exceptions fatales sont gérées en amont du processus (dans "
+"les couches hautes) et un message d'erreur est alors affiché à l'usager (ou "
+"un traitement alternatif est invoqué.) Veuillez noter que Hibernate peut "
+"également lancer des exceptions non vérifiées d'un autre type que "
+"<literal>HibernateException</literal>. Celles-ci sont également non "
+"traitables et vous devez les traiter comme telles. "
 
 #. Tag: para
-#: transactions.xml:587
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate wraps <literal>SQLException</literal>s thrown while interacting "
 "with the database in a <literal>JDBCException</literal>. In fact, Hibernate "
@@ -1256,78 +1117,72 @@
 msgstr ""
 "Hibernate englobe les <literal>SQLException</literal> s lancées lors des "
 "interactions directes avec la base de données dans des exceptions de type: "
-"<literal>JDBCException</literal> . En fait, Hibernate essaiera de convertir "
+"<literal>JDBCException</literal>. En fait, Hibernate essaiera de convertir "
 "l'exception dans un sous-type plus significatif de <literal>JDBCException</"
-"literal> . L'exception <literal>SQLException</literal> sous-jacente est "
+"literal>. L'exception <literal>SQLException</literal> sous-jacente est "
 "toujours disponible via la méthode <literal>JDBCException.getCause()</"
-"literal> . Cette conversion est faite par un objet de type "
-"<literal>SQLExceptionConverter</literal> , qui est rattaché à l'objet "
-"<literal>SessionFactory</literal> . Par défaut, le "
-"<literal>SQLExceptionConverter</literal> est associé au dialecte de BD "
+"literal>. Hibernate convertit le <literal>SQLExceptionConverter</literal> en "
+"une sous-classe <literal>JDBCException</literal>, en utilisant le "
+"<literal>SQLExceptionConverter</literal> qui est rattaché à l'objet "
+"<literal>SessionFactory</literal>. Par défaut, le "
+"<literal>SQLExceptionConverter</literal> est défini par le dialecte "
 "configuré dans Hibernate. Toutefois, il est possible de fournir sa propre "
 "implémentation de l'interface. (Veuillez vous référer à la javadoc sur la "
 "classe <literal>SQLExceptionConverterFactory</literal> pour plus de détails. "
-"Les sous-types standard de <literal>JDBCException</literal> sont:"
+"Les sous-types standard de <literal>JDBCException</literal> sont :"
 
 #. Tag: para
-#: transactions.xml:603
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>JDBCConnectionException</literal>: indicates an error with the "
 "underlying JDBC communication."
 msgstr ""
-"<literal>JDBCConnectionException</literal> - Indique une erreur de "
-"communication avec la couche JDBC sous-jacente."
+"<literal>JDBCConnectionException</literal> - indique une erreur de "
+"communication avec la couche JDBC sous-jacente. "
 
 #. Tag: para
-#: transactions.xml:609
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>SQLGrammarException</literal>: indicates a grammar or syntax "
 "problem with the issued SQL."
 msgstr ""
-"<literal>SQLGrammarException</literal> - Indique un problème de grammaire ou "
-"de syntaxe avec la requête SQL envoyée."
+"<literal>SQLGrammarException</literal> - indique un problème de grammaire ou "
+"de syntaxe avec la requête SQL envoyée. "
 
 #. Tag: para
-#: transactions.xml:615
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ConstraintViolationException</literal>: indicates some form of "
 "integrity constraint violation."
 msgstr ""
-"<literal>ConstraintViolationException</literal> - Indique une violation de "
-"contrainte d'intégrité."
+"<literal>ConstraintViolationException</literal> - indique une violation de "
+"contrainte d'intégrité. "
 
 #. Tag: para
-#: transactions.xml:621
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockAcquisitionException</literal>: indicates an error acquiring a "
 "lock level necessary to perform the requested operation."
 msgstr ""
-"<literal>LockAcquisitionException</literal> - Indique une erreur de "
-"verrouillage lors de l'éxécution de la requête."
+"<literal>LockAcquisitionException</literal> - indique une erreur de "
+"verrouillage lors de l'exécution de la requête. "
 
 #. Tag: para
-#: transactions.xml:627
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>GenericJDBCException</literal>: a generic exception which did not "
 "fall into any of the other categories."
 msgstr ""
-"<literal>GenericJDBCException</literal> - Indique une erreur générique JDBC "
-"d'une autre catégorie."
+"<literal>GenericJDBCException</literal> - indique une erreur générique ne "
+"correspondant à aucune autre catégorie. "
 
 #. Tag: title
-#: transactions.xml:637
 #, no-c-format
 msgid "Transaction timeout"
 msgstr "Timeout de transaction"
 
 #. Tag: para
-#: transactions.xml:639
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An important feature provided by a managed environment like EJB, that is "
 "never provided for non-managed code, is transaction timeout. Transaction "
@@ -1340,64 +1195,38 @@
 "transaction timeout to JTA. This functionality is abstracted by the "
 "Hibernate <literal>Transaction</literal> object."
 msgstr ""
-"L'un des avantages fournis par les environnements transactionnels JTA (tels "
-"les containers EJB) est la gestion du timeout de transaction. La gestion des "
-"dépassements de temps de transaction vise à s'assurer qu'une transaction "
-"agissant incorrectement ne viendra pas bloquer indéfiniment les ressources "
-"de l'application. Hibernate ne peut fournir cette fonctionnalité dans un "
-"environnement transactionnel non-JTA. Par contre, Hibernate gère les "
-"opérations d'accès aux données en allouant un temps maximal aux requêtes "
-"pour s'exécuter. Ainsi, une requête créant de l'inter blocage ou retournant "
-"de très grandes quantités d'information pourrait être interrompue. Dans un "
-"environnement transactionnel JTA, Hibernate peut déléguer au gestionnaire de "
-"transaction le soin de gérer les dépassements de temps. Cette fonctionnalité "
-"est abstraite par l'objet <literal>Transaction</literal> ."
+"Une des caractéristiques extrêmement importante fournie dans les "
+"environnements gérés tels les EJB, est la gestion du timeout de transaction "
+"qui n'est jamais fournie pour le code non géré. La gestion des dépassements "
+"de temps de transaction vise à s'assurer qu'une transaction agissant "
+"incorrectement ne viendra pas bloquer indéfiniment les ressources de "
+"l'application et ne retourner aucune réponse à l'utilisateur. Hibernate ne "
+"peut fournir cette fonctionnalité dans un environnement transactionnel non-"
+"JTA. Par contre, Hibernate gère les opérations d'accès aux données en "
+"allouant un temps maximal aux requêtes pour s'exécuter. Ainsi, une requête "
+"créant de l'inter blocage ou retournant de très grandes quantités "
+"d'informations pourrait être interrompue. Dans un environnement géré, "
+"Hibernate peut déléguer au gestionnaire de transaction JTA, le soin de gérer "
+"les dépassements de temps. Cette fonctionnalité est abstraite par l'objet "
+"<literal>Transaction</literal>."
 
-#. Tag: programlisting
-#: transactions.xml:652
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"Session sess = factory.openSession();\n"
-"try {\n"
-"    //set transaction timeout to 3 seconds\n"
-"    sess.getTransaction().setTimeout(3);\n"
-"    sess.getTransaction().begin();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    sess.getTransaction().commit()\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    sess.getTransaction().rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:654
-#, fuzzy, no-c-format
-msgid ""
 "<literal>setTimeout()</literal> cannot be called in a CMT bean, where "
 "transaction timeouts must be defined declaratively."
 msgstr ""
 "Notez que <literal>setTimeout()</literal> ne peut pas être appelé d'un EJB "
 "CMT, puisque le timeout des transaction doit être spécifié de manière "
-"déclarative."
+"déclarative. "
 
 #. Tag: title
-#: transactions.xml:664
 #, no-c-format
 msgid "Optimistic concurrency control"
-msgstr "Contrôle de consurrence optimiste"
+msgstr "Contrôle de concurrence optimiste"
 
 #. Tag: para
-#: transactions.xml:666
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The only approach that is consistent with high concurrency and high "
 "scalability, is optimistic concurrency control with versioning. Version "
@@ -1410,22 +1239,22 @@
 "La gestion optimiste des accès concurrents avec versionnage est la seule "
 "approche pouvant garantir l'extensibilité des applications à haut niveau de "
 "charge. Le système de versionnage utilise des numéros de version ou "
-"l'horodatage pour détecter les mises à jour causant des conflits avec "
-"d'autres actualisations antérieures. Hibernate propose trois approches pour "
-"l'écriture de code applicatif utilisant la gestion optimiste d'accès "
-"concurrents. Le cas d'utilisation décrit plus bas fait mention de "
-"conversation, mais le versionnage peut également améliorer la qualité d'une "
-"application en prévenant la perte de mises à jour."
+"l'horodatage pour détecter les mise à jour causant des conflits avec "
+"d'autres actualisations antérieures (et pour éviter la perte de mise à "
+"jour). Hibernate propose trois approches possibles pour l'écriture de code "
+"applicatif utilisant la gestion optimiste d'accès concurrents. Le cas "
+"d'utilisation décrit plus bas fait mention de longues conversations, mais le "
+"versionnage peut également améliorer la qualité d'une application en "
+"prévenant la perte de mise à jour dans les transactions uniques de base de "
+"données. "
 
 #. Tag: title
-#: transactions.xml:677
 #, no-c-format
 msgid "Application version checking"
-msgstr "Gestion du versionnage au niveau applicatif"
+msgstr "Vérification du versionnage au niveau applicatif"
 
 #. Tag: para
-#: transactions.xml:679
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In an implementation without much help from Hibernate, each interaction with "
 "the database occurs in a new <literal>Session</literal> and the developer is "
@@ -1435,48 +1264,28 @@
 "least efficient in terms of database access. It is the approach most similar "
 "to entity EJBs."
 msgstr ""
-"Dans cet exemple d'implémentation utilisant peu les fonctionnalités "
-"d'Hibernate, chaque interaction avec la base de données se fait en utilisant "
+"Dans cet exemple d'implémentation utilisant peu les fonctionnalités de "
+"Hibernate, chaque interaction avec la base de données se fait en utilisant "
 "une nouvelle <literal>Session</literal> et le développeur doit recharger les "
-"données persistantes à partir de la BD avant de les manipuler. Cette "
-"implémentation force l'application à vérifier la version des objets afin de "
-"maintenir l'isolation transactionnelle. Cette approche, semblable à celle "
-"retrouvée pour les EJB, est la moins efficace de celles présentées dans ce "
-"chapitre."
+"données persistantes à partir de la base de données avant de les manipuler. "
+"Cette implémentation force l'application à vérifier la version des objets "
+"afin de maintenir l'isolation transactionnelle. Cette approche, semblable à "
+"celle retrouvée pour les EJB, est la moins efficace parmi celles qui sont "
+"présentées dans ce chapitre. "
 
-#. Tag: programlisting
-#: transactions.xml:688
-#, no-c-format
-msgid ""
-"<![CDATA[// foo is an instance loaded by a previous Session\n"
-"session = factory.openSession();\n"
-"Transaction t = session.beginTransaction();\n"
-"\n"
-"int oldVersion = foo.getVersion();\n"
-"session.load( foo, foo.getKey() ); // load the current state\n"
-"if ( oldVersion != foo.getVersion() ) throw new StaleObjectStateException"
-"();\n"
-"foo.setProperty(\"bar\");\n"
-"\n"
-"t.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:690
 #, no-c-format
 msgid ""
 "The <literal>version</literal> property is mapped using <literal>&lt;"
 "version&gt;</literal>, and Hibernate will automatically increment it during "
 "flush if the entity is dirty."
 msgstr ""
-"Le mapping de la propriété <literal>version</literal> est fait via "
+"Le mappage de la propriété <literal>version</literal> est fait via "
 "<literal>&lt;version&gt;</literal> et Hibernate l'incrémentera "
 "automatiquement à chaque flush() si l'entité doit être mise à jour."
 
 #. Tag: para
-#: transactions.xml:696
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are operating in a low-data-concurrency environment, and do not "
 "require version checking, you can use this approach and skip the version "
@@ -1494,11 +1303,10 @@
 "cette approche pourrait rendre perplexe les utilisateurs de l'application "
 "car ils pourraient perdre des données mises à jour sans qu'aucun message "
 "d'erreur ne leur soit présenté et sans avoir la possibilité de fusionner les "
-"données."
+"données. "
 
 #. Tag: para
-#: transactions.xml:705
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Manual version checking is only feasible in trivial circumstances and not "
 "practical for most applications. Often not only single instances, but "
@@ -1511,19 +1319,17 @@
 "approche n'est pas valable pour la plupart des applications. De manière "
 "générale, les applications ne cherchent pas à actualiser de simples objets "
 "sans relations, elles le font généralement pour de larges graphes d'objets. "
-"Pour toute application utilisant le paradigme des conversations ou des "
-"objets détachés, Hibernate peut gérer automatiquement la vérification des "
-"versions d'objets."
+"Hibernate peut gérer automatiquement la vérification des versions d'objets "
+"en utilisant soit une <literal>Session</literal> longue, soit des instances "
+"détachées comme paradigme des conversations. "
 
 #. Tag: title
-#: transactions.xml:716
 #, no-c-format
 msgid "Extended session and automatic versioning"
 msgstr "Les sessions longues et le versionnage automatique."
 
 #. Tag: para
-#: transactions.xml:718
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A single <literal>Session</literal> instance and its persistent instances "
 "that are used for the whole conversation are known as <emphasis>session-per-"
@@ -1534,17 +1340,17 @@
 "conversation with non-stale data."
 msgstr ""
 "Dans ce scénario, une seule instance de <literal>Session</literal> et des "
-"objets persistants est utilisée pour toute l'application. Hibernate vérifie "
-"la version des objets persistants avant d'effectuer le flush() et lance une "
-"exception si une modification concurrente est détectée. Il appartient alors "
-"au développeur de gérer l'exception. Les traitements alternatifs "
-"généralement proposés sont alors de permettre à l'usager de faire la fusion "
-"des données ou de lui offrir de recommencer son travail à partie des données "
-"les plus récentes dans la BD."
+"objets persistants est utilisée pour toute la conversation, connue sous "
+"<emphasis>session-par-conversation</emphasis>. Hibernate vérifie la version "
+"des objets persistants avant d'effectuer le flush() et lance une exception "
+"si une modification concurrente est détectée. Il appartient alors au "
+"développeur de gérer l'exception. Les traitements alternatifs généralement "
+"proposés sont alors de permettre à l'usager de faire la fusion des données "
+"ou de lui offrir de recommencer son travail à partie des données les plus "
+"récentes dans la base de données. "
 
 #. Tag: para
-#: transactions.xml:727
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>Session</literal> is disconnected from any underlying JDBC "
 "connection when waiting for user interaction. This approach is the most "
@@ -1552,32 +1358,16 @@
 "check or reattach detached instances, nor does it have to reload instances "
 "in every database transaction."
 msgstr ""
-"Il est à noter que lorsqu'une application est en attente d'une action de la "
-"part de l?usager, La <literal>Session</literal> n'est pas connectée à la "
-"couche JDBC sous-jacente. C'est la manière la plus efficace de gérer les "
-"accès à la base de données. L'application ne devrait pas se préoccuper du "
-"versionnage des objets, de la réassociation des objets détachés, ni du "
-"rechargement de tous les objets à chaque transaction."
+"Notez que lorsqu'une application est en attente d'une action de la part de "
+"l'usager, la <literal>Session</literal> n'est pas connectée à la couche JDBC "
+"sous-jacente. C'est la manière la plus efficace de gérer les accès à la base "
+"de données. L'application ne devrait pas se préoccuper du versionnage des "
+"objets, ou du rattachement des objets détachés, ni du rechargement de tous "
+"les objets à chaque transaction. "
 
-#. Tag: programlisting
-#: transactions.xml:735
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// foo is an instance loaded earlier by the old session\n"
-"Transaction t = session.beginTransaction(); // Obtain a new JDBC connection, "
-"start transaction\n"
-"\n"
-"foo.setProperty(\"bar\");\n"
-"\n"
-"session.flush();    // Only for last transaction in conversation\n"
-"t.commit();         // Also return JDBC connection\n"
-"session.close();    // Only for last transaction in conversation]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:736
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>foo</literal> object knows which <literal>Session</literal> it "
 "was loaded in. Beginning a new database transaction on an old session "
 "obtains a new connection and resumes the session. Committing a database "
@@ -1604,11 +1394,15 @@
 "un appel à <literal>Session.lock()</literal> en mode <literal>LockMode.READ</"
 "literal> pour tout objet ayant pu être modifié par une autre transaction. Il "
 "n'est pas nécessaire de verrouiller les données que vous désirez mettre à "
-"jour."
+"jour. En général, vous configurerez<literal>FlushMode.NEVER</literal> sur "
+"une <literal>Session</literal> étendue, de façon que seul le dernier cycle "
+"de transaction de la base de données puissent persister toutes les "
+"modifications effectuées dans cette conversation. Par conséquent, cette "
+"dernière transaction inclura l'opération <literal>flush()</literal>, de même "
+"que <literal>close()</literal> la session pour finir la conversation."
 
 #. Tag: para
-#: transactions.xml:751
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This pattern is problematic if the <literal>Session</literal> is too big to "
 "be stored during user think time (for example, an <literal>HttpSession</"
@@ -1618,36 +1412,33 @@
 "<literal>Session</literal> only for a single conversation as it will soon "
 "have stale data."
 msgstr ""
-"Si des appels implicites aux méthodes <literal>disconnect()</literal> et "
-"<literal>reconnect()</literal> sont trop coûteux, vous pouvez les éviter en "
-"utilisant <literal>hibernate.connection.release_mode</literal> ."
+"Ce modèle peut présenter des problèmes si la <literal>Session</literal> est "
+"trop volumineuse pour être stockée entre les actions de l'usager. Plus "
+"spécifiquement, une session <literal>HttpSession</literal> se doit d'être la "
+"plus petite possible. Puisque la <literal>Session</literal> joue "
+"obligatoirement le rôle de mémoire cache de premier niveau et contient à ce "
+"titre tous les objets chargés, il est préférable de n'utiliser une "
+"<literal>Session</literal> que pour une seule conversation, car les objets "
+"risquent d'y être rapidement périmés."
 
 #. Tag: title
-#: transactions.xml:762
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Remarque"
 
 #. Tag: para
-#: transactions.xml:763
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Earlier versions of Hibernate required explicit disconnection and "
 "reconnection of a <literal>Session</literal>. These methods are deprecated, "
 "as beginning and ending a transaction has the same effect."
 msgstr ""
-"Ce pattern peut présenter des problèmes si la <literal>Session</literal> est "
-"trop volumineuse pour être stockée entre les actions de l'usager. Plus "
-"spécifiquement, une session <literal>HttpSession</literal> se doit d'être la "
-"plus petite possible. Puisque la <literal>Session</literal> joue "
-"obligatoirement le rôle de mémoire cache de premier niveau et contient à ce "
-"titre tous les objets chargés, il est préférable de n'utiliser cette "
-"stratégie que pour quelques cycles de requêtes car les objets risquent d'y "
-"être rapidement périmés."
+"Notez que des versions précédentes de Hibernate exigeaient une déconnexion "
+"explicite et une reconnexion d'une <literal>Session</literal>. Ces méthodes "
+"sont périmées, puisque commencer et terminer une transaction a le même effet."
 
 #. Tag: para
-#: transactions.xml:769
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Keep the disconnected <literal>Session</literal> close to the persistence "
 "layer. Use an EJB stateful session bean to hold the <literal>Session</"
@@ -1657,13 +1448,13 @@
 msgstr ""
 "Notez que la <literal>Session</literal> déconnectée devrait être conservée "
 "près de la couche de persistance. Autrement dit, utilisez un EJB stateful "
-"pour conserver la <literal>Session</literal> et évitez de la sérialiser et "
-"de la transférer à la couche de présentation (i.e. Il est préférable de ne "
-"pas la conserver dans la session <literal>HttpSession</literal> .)"
+"pour conserver la <literal>Session</literal> dans un environnement 3 niveaux "
+"et évitez de la sérialiser et de la transférer à la couche de présentation "
+"(c'est-à-dire qu'il est préférable de ne pas la conserver dans la session "
+"<literal>HttpSession</literal> .) "
 
 #. Tag: para
-#: transactions.xml:777
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The extended session pattern, or <emphasis>session-per-conversation</"
 "emphasis>, is more difficult to implement with automatic current session "
@@ -1671,20 +1462,18 @@
 "<literal>CurrentSessionContext</literal> for this. See the Hibernate Wiki "
 "for examples."
 msgstr ""
-"The extended session pattern, or <emphasis>session-per-conversation</"
-"emphasis>, is more difficult to implement with automatic current session "
-"context management. You need to supply your own implementation of the "
-"<literal>CurrentSessionContext</literal> for this, see the Hibernate Wiki "
-"for examples."
+"Le modèle de session étendue, ou <emphasis>session-par-conversation</"
+"emphasis>, est plus difficile à implémenter avec la gestion automatique de "
+"contexte de session courante. À cet effet, vous devez fournir votre propre "
+"implémentation de<literal>CurrentSessionContext</literal>, pour des exemples "
+"consultez Hibernate Wiki. "
 
 #. Tag: title
-#: transactions.xml:787
 #, no-c-format
 msgid "Detached objects and automatic versioning"
 msgstr "Les objets détachés et le versionnage automatique"
 
 #. Tag: para
-#: transactions.xml:789
 #, no-c-format
 msgid ""
 "Each interaction with the persistent store occurs in a new <literal>Session</"
@@ -1701,37 +1490,21 @@
 "doit pouvoir manipuler l'état des instances détachées ayant été chargées "
 "antérieurement via une autre session. Pour ce faire, ces objets persistants "
 "doivent être rattachés à la <literal>Session</literal> courante en utilisant "
-"<literal>Session.update()</literal> , <literal>Session.saveOrUpdate()</"
-"literal> , ou <literal>Session.merge()</literal> ."
+"<literal>Session.update()</literal>, <literal>Session.saveOrUpdate()</"
+"literal>, ou <literal>Session.merge()</literal> ."
 
-#. Tag: programlisting
-#: transactions.xml:797
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// foo is an instance loaded by a previous Session\n"
-"foo.setProperty(\"bar\");\n"
-"session = factory.openSession();\n"
-"Transaction t = session.beginTransaction();\n"
-"session.saveOrUpdate(foo); // Use merge() if \"foo\" might have been loaded "
-"already\n"
-"t.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:799
-#, fuzzy, no-c-format
-msgid ""
 "Again, Hibernate will check instance versions during flush, throwing an "
 "exception if conflicting updates occurred."
 msgstr ""
 "Encore une fois, Hibernate vérifiera la version des instances devant être "
 "actualisées durant le flush(). Une exception sera lancée si des conflits "
-"sont détectés."
+"sont détectés. "
 
 #. Tag: para
-#: transactions.xml:804
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also call <literal>lock()</literal> instead of <literal>update()</"
 "literal>, and use <literal>LockMode.READ</literal> (performing a version "
@@ -1742,17 +1515,15 @@
 "<literal>update()</literal> et utiliser le mode <literal>LockMode.READ</"
 "literal> (qui lancera une vérification de version, en ignorant tous les "
 "niveaux de mémoire cache) si vous êtes certain que l'objet n'a pas été "
-"modifié."
+"modifié. "
 
 #. Tag: title
-#: transactions.xml:813
 #, no-c-format
 msgid "Customizing automatic versioning"
 msgstr "Personnaliser le versionnage automatique"
 
 #. Tag: para
-#: transactions.xml:815
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can disable Hibernate's automatic version increment for particular "
 "properties and collections by setting the <literal>optimistic-lock</literal> "
@@ -1761,12 +1532,12 @@
 msgstr ""
 "Vous pouvez désactiver l'incrémentation automatique du numéro de version de "
 "certains attributs et collections en mettant la valeur du paramètre de "
-"mapping <literal>optimistic-lock</literal> à false. Hibernate cessera ainsi "
-"d'incrémenter leur numéro de version s'ils sont mis à jour."
+"mapping <literal>optimistic-lock</literal> à <literal>false</literal>. "
+"Hibernate cessera ainsi d'incrémenter leur numéro de version si la propriété "
+"est dirty. "
 
 #. Tag: para
-#: transactions.xml:822
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Legacy database schemas are often static and cannot be modified. Or, other "
 "applications might access the same database and will not know how to handle "
@@ -1783,35 +1554,33 @@
 "de données sont statiques et ne peuvent être modifiés. Il existe aussi des "
 "cas où plusieurs applications doivent accéder à la même base de données, "
 "mais certaines d'entre elles ne peuvent gérer les numéros de version ou les "
-"champs horodatés. Dans les deux cas, le versionnage ne peut être implanté "
-"par le rajout d'une colonne dans la base de données. Afin de forcer la "
-"vérification de version dans un système sans en faire le mapping, mais en "
-"forçant une comparaison des états de tous les attributs d'une entité, vous "
-"pouvez utiliser l'attribut <literal>optimistic- lock=\"all\"</literal> sous "
-"l'élément <literal>&lt;class&gt;</literal> . Veuillez noter que cette "
-"manière de gérer le versionnage ne peut être utilisée que si l'application "
-"utilises de longues sessions, lui permettant de comparer l'ancien état et le "
-"nouvel état d'une entité. L'utilisation d'un pattern <literal>session-per-"
-"request-with-detached- objects</literal> devient alors impossible."
+"champs horodatés. Dans les deux cas, le versionnage ne peut se fier à une "
+"colonne particulière dans une table. Afin de forcer la vérification de "
+"version dans un système sans en faire le mappage, mais en forçant une "
+"comparaison des états de tous les attributs d'une entité, vous pouvez "
+"utiliser l'attribut <literal>optimistic- lock=\"all\"</literal> dans le "
+"mappage <literal>&lt;class&gt;</literal>. Veuillez noter que cette manière "
+"de gérer le versionnage ne peut être utilisée que si l'application utilise "
+"de longues sessions, lui permettant de comparer l'ancien état et le nouvel "
+"état d'une entité. L'utilisation d'un modèle <literal>session-per-request-"
+"with-detached- objects</literal> devient alors impossible. "
 
 #. Tag: para
-#: transactions.xml:834
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Concurrent modification can be permitted in instances where the changes that "
 "have been made do not overlap. If you set <literal>optimistic-lock=\"dirty"
 "\"</literal> when mapping the <literal>&lt;class&gt;</literal>, Hibernate "
 "will only compare dirty fields during flush."
 msgstr ""
-"Il peut être souhaitable de permettre les modifications concurrentes lorsque "
-"des champs distincts sont modifiés. En mettant la propriété "
-"<literal>optimistic-lock=\"dirty\"</literal> dans l'élément <literal>&lt;"
-"class&gt;</literal> , Hibernate ne fera la comparaison que des champs devant "
-"être actualisés lors du flush()."
+"Il peut être souhaitable de permettre les modifications concurrentes du "
+"moment que les modifications ne se chevauchent pas. En configurant la "
+"propriété à <literal>optimistic-lock=\"dirty\"</literal> quand vous mappez "
+"le <literal>&lt;class&gt;</literal>, Hibernate ne fera la comparaison que "
+"des champs devant être actualisés lors du flush."
 
 #. Tag: para
-#: transactions.xml:840
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In both cases, with dedicated version/timestamp columns or with a full/dirty "
 "field comparison, Hibernate uses a single <literal>UPDATE</literal> "
@@ -1828,29 +1597,28 @@
 msgstr ""
 "Dans les deux cas: en utilisant une colonne de version/horodatée ou via la "
 "comparaison de l'état complet de l'objet ou de ses champs modifiés, "
-"Hibernate ne créera qu'une seule commande d'UPDATE par entité avec la clause "
-"WHERE appropriée pour mettre à jour l'entité <emphasis>ET</emphasis> en "
-"vérifier la version. Si vous utilisez la persistance transitive pour "
-"propager l'évènement de rattachement à des entités associées, il est "
-"possible qu'Hibernate génère des commandes d'UPDATE inutiles. Ceci n'est "
-"généralement pas un problème, mais certains déclencheurs <emphasis>on "
-"update</emphasis> dans la base de données pourraient être activés même si "
-"aucun changement n'était réellement persisté sur des objets associés. Vous "
-"pouvez personnaliser ce comportement en indiquant <literal>select-before- "
-"update=\"true\"</literal> dans l'élément de mapping <literal>&lt;class&gt;</"
-"literal> . Ceci forcera Hibernate à faire le SELECT de l'instance afin de "
-"s'assurer que l'entité doit réellement être actualisée avant de lancer la "
-"commande d'UPDATE."
+"Hibernate ne créera qu'une seule commande <literal>UPDATE</literal> par "
+"entité avec la clause <literal>WHERE</literal> appropriée pour vérifier la "
+"version et mettre à jour les informations. Si vous utilisez la persistance "
+"transitive pour propager l'évènement de rattachement à des entités "
+"associées, il est possible que Hibernate génère des commandes de mise à jour "
+"inutiles. Ceci n'est généralement pas un problème, mais certains "
+"déclencheurs <emphasis>on update</emphasis> dans la base de données "
+"pourraient être activés même si aucun changement n'était réellement persisté "
+"sur des objets détachés. Vous pouvez personnaliser ce comportement en "
+"indiquant <literal>select-before- update=\"true\"</literal> dans l'élément "
+"de mappage <literal>&lt;class&gt;</literal>. Ceci forcera Hibernate à faire "
+"le <literal>SELECT</literal> de l'instance afin de s'assurer que l'entité "
+"doit réellement être actualisée avant de lancer la commande de mise à jour "
+"de l'enregistrement. "
 
 #. Tag: title
-#: transactions.xml:858
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Pessimistic locking"
-msgstr "Verouillage pessimiste"
+msgstr "Verrouillage pessimiste "
 
 #. Tag: para
-#: transactions.xml:860
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is not intended that users spend much time worrying about locking "
 "strategies. It is usually enough to specify an isolation level for the JDBC "
@@ -1863,42 +1631,38 @@
 "définir le niveau d'isolation pour les connexions JDBC et de laisser ensuite "
 "la base de donnée effectuer son travail. Toutefois, certains utilisateurs "
 "avancés peuvent vouloir obtenir un verrouillage pessimiste exclusif sur un "
-"enregistrement et le réobtenir au lancement d'une nouvelle transaction."
+"enregistrement, ou le ré-obtenir au lancement d'une nouvelle transaction. "
 
 #. Tag: para
-#: transactions.xml:867
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will always use the locking mechanism of the database; it never "
 "lock objects in memory."
 msgstr ""
 "Hibernate utilisera toujours le mécanisme de verrouillage de la base de "
-"données et ne verrouillera jamais les objets en mémoire!"
+"données et ne verrouillera jamais les objets en mémoire."
 
 #. Tag: para
-#: transactions.xml:872
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>LockMode</literal> class defines the different lock levels that "
 "can be acquired by Hibernate. A lock is obtained by the following mechanisms:"
 msgstr ""
 "La classe <literal>LockMode</literal> définit les différents niveaux de "
 "verrouillage pouvant être obtenus par Hibernate. Le verrouillage est obtenu "
-"par les mécanismes suivants:"
+"par les mécanismes suivants : "
 
 #. Tag: para
-#: transactions.xml:879
 #, no-c-format
 msgid ""
 "<literal>LockMode.WRITE</literal> is acquired automatically when Hibernate "
 "updates or inserts a row."
 msgstr ""
 "<literal>LockMode.WRITE</literal> est obtenu automatiquement quand Hibernate "
-"actualise ou insert un enregistrement."
+"actualise ou insère un enregistrement."
 
 #. Tag: para
-#: transactions.xml:885
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockMode.UPGRADE</literal> can be acquired upon explicit user "
 "request using <literal>SELECT ... FOR UPDATE</literal> on databases which "
@@ -1906,11 +1670,10 @@
 msgstr ""
 "<literal>LockMode.UPGRADE</literal> peut être obtenu de manière explicite "
 "via la requête en utilisant <literal>SELECT ... FOR UPDATE</literal> sur une "
-"base de données supportant cette syntaxe."
+"base de données supportant cette syntaxe. "
 
 #. Tag: para
-#: transactions.xml:891
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockMode.UPGRADE_NOWAIT</literal> can be acquired upon explicit "
 "user request using a <literal>SELECT ... FOR UPDATE NOWAIT</literal> under "
@@ -1918,11 +1681,10 @@
 msgstr ""
 "<literal>LockMode.UPGRADE_NOWAIT</literal> peut être obtenu de manière "
 "explicite en utilisant <literal>SELECT ... FOR UPDATE NOWAIT</literal> sur "
-"Oracle."
+"Oracle. "
 
 #. Tag: para
-#: transactions.xml:897
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockMode.READ</literal> is acquired automatically when Hibernate "
 "reads data under Repeatable Read or Serializable isolation level. It can be "
@@ -1930,11 +1692,10 @@
 msgstr ""
 "<literal>LockMode.READ</literal> est obtenu automatiquement quand Hibernate "
 "lit des données dans un contexte d'isolation <literal>Repeatable Read</"
-"literal> ou <literal>Serializable</literal> . Peut être réobtenu "
-"explicitement via une requête."
+"literal> ou <literal>Serializable</literal>. Peut être ré-obtenu "
+"explicitement via une requête d'utilisateur. "
 
 #. Tag: para
-#: transactions.xml:904
 #, no-c-format
 msgid ""
 "<literal>LockMode.NONE</literal> represents the absence of a lock. All "
@@ -1943,45 +1704,40 @@
 "</literal> or <literal>saveOrUpdate()</literal> also start out in this lock "
 "mode."
 msgstr ""
-"<literal>LockMode.NONE</literal> représente l'absence de verouillage. Tous "
-"les objets migrent vers ce mode a la fin d'une <literal>Transaction</"
+"<literal>LockMode.NONE</literal> représente l'absence de verrouillage. Tous "
+"les objets migrent vers ce mode à la fin d'une <literal>Transaction</"
 "literal> . Les objets associés à une session via un appel à "
 "<literal>saveOrUpdate()</literal> commencent également leur cycle de vie "
-"dans cet état."
+"dans ce mode verrouillé. "
 
 #. Tag: para
-#: transactions.xml:913
 #, no-c-format
 msgid ""
 "The \"explicit user request\" is expressed in one of the following ways:"
 msgstr ""
-"Les niveaux de verrouillage peuvent être explicitement obtenus de l'une des "
-"manières suivantes:"
+"Les requêtes explicites d'utilisateur sont exprimées d'une des manières "
+"suivantes :"
 
 #. Tag: para
-#: transactions.xml:919
 #, no-c-format
 msgid ""
 "A call to <literal>Session.load()</literal>, specifying a <literal>LockMode</"
 "literal>."
 msgstr ""
-"Un appel à <literal>Session.load()</literal> , en spécifiant un niveau "
+"Un appel à <literal>Session.load()</literal>, en spécifiant un niveau "
 "verrouillage <literal>LockMode</literal> ."
 
 #. Tag: para
-#: transactions.xml:924
 #, no-c-format
 msgid "A call to <literal>Session.lock()</literal>."
-msgstr "Un appel à <literal>Session.lock()</literal> ."
+msgstr "Un appel à <literal>Session.lock()</literal>."
 
 #. Tag: para
-#: transactions.xml:929
 #, no-c-format
 msgid "A call to <literal>Query.setLockMode()</literal>."
-msgstr "Une appel à <literal>Query.setLockMode()</literal> ."
+msgstr "Une appel à <literal>Query.setLockMode()</literal>."
 
 #. Tag: para
-#: transactions.xml:935
 #, no-c-format
 msgid ""
 "If <literal>Session.load()</literal> is called with <literal>UPGRADE</"
@@ -1993,7 +1749,7 @@
 "object."
 msgstr ""
 "Si <literal>Session.load()</literal> est appelé avec le paramètre de niveau "
-"de verouillage <literal>UPGRADE</literal> ou <literal>UPGRADE_NOWAIT</"
+"de verrouillage <literal>UPGRADE</literal> ou <literal>UPGRADE_NOWAIT</"
 "literal> et que l'objet demandé n'est pas présent dans la session, celui-ci "
 "sera chargé à l'aide d'une requête <literal>SELECT ... FOR UPDATE</"
 "literal> . Si la méthode <literal>load()</literal> est appelée pour un objet "
@@ -2001,8 +1757,7 @@
 "appellera la méthode <literal>lock()</literal> pour cet objet."
 
 #. Tag: para
-#: transactions.xml:944
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Session.lock()</literal> performs a version number check if the "
 "specified lock mode is <literal>READ</literal>, <literal>UPGRADE</literal> "
@@ -2012,31 +1767,28 @@
 msgstr ""
 "<literal>Session.lock()</literal> effectue une vérification de version si le "
 "niveau de verrouillage est <literal>READ</literal> , <literal>UPGRADE</"
-"literal> ou <literal>UPGRADE_NOWAIT</literal> . (Dans le cas des niveaux "
+"literal> ou <literal>UPGRADE_NOWAIT</literal> . Dans le cas des niveaux "
 "<literal>UPGRADE</literal> ou <literal>UPGRADE_NOWAIT</literal> , une "
-"requête <literal>SELECT ... FOR UPDATE</literal> sera utilisée.)"
+"requête <literal>SELECT ... FOR UPDATE</literal> sera utilisée."
 
 #. Tag: para
-#: transactions.xml:951
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the requested lock mode is not supported by the database, Hibernate uses "
 "an appropriate alternate mode instead of throwing an exception. This ensures "
 "that applications are portable."
 msgstr ""
 "Si une base de données ne supporte pas le niveau de verrouillage demandé, "
-"Hibernate utilisera un niveau alternatif convenable au lieux de lancer une "
-"exception. Ceci assurera la portabilité de votre application."
+"Hibernate utilisera un niveau alternatif convenable au lieu de lancer une "
+"exception. Ceci assurera la portabilité de vos applications."
 
 #. Tag: title
-#: transactions.xml:960
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Connection release modes"
-msgstr "Mode de libération de Connection"
+msgstr "Modes de libération de connexion"
 
 #. Tag: para
-#: transactions.xml:962
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "One of the legacies of Hibernate 2.x JDBC connection management meant that a "
 "<literal>Session</literal> would obtain a connection when it was first "
@@ -2049,41 +1801,39 @@
 "by the enumerated values of <literal>org.hibernate.ConnectionReleaseMode</"
 "literal>:"
 msgstr ""
-"Le comportement original (2.x) d'Hibernate pour la gestion des connexions "
+"Le comportement original (2.x) de Hibernate pour la gestion des connexions "
 "JDBC était que la <literal>Session</literal> obtenait une connexion dès "
 "qu'elle en avait besoin et la libérait une fois la session fermée. Hibernate "
-"3 a introduit les modes de libération de connexion pour indiquer à la "
+"3.x a introduit les modes de libération de connexion pour indiquer à la "
 "session comment gérer les transactions JDBC. Notez que la discussion "
 "suivante n'est pertinente que pour des connexions fournies par un "
-"<literal>ConnectionProvider</literal>, celles gérées par l'utilisateur sont "
-"en dehors du scope de cette discussion. Les différents modes sont définies "
-"par <literal>org.hibernate.ConnectionReleaseMode</literal>:"
+"<literal>ConnectionProvider</literal>, celles gérées par l'utilisateur "
+"dépassent l'objectif de cette discussion. Les différents modes de libération "
+"sont identifiés par les valeurs énumérées de <literal>org.hibernate."
+"ConnectionReleaseMode</literal> :"
 
 #. Tag: para
-#: transactions.xml:976
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ON_CLOSE</literal>: is the legacy behavior described above. The "
 "Hibernate session obtains a connection when it first needs to perform some "
 "JDBC access and maintains that connection until the session is closed."
 msgstr ""
-"<literal>ON_CLOSE</literal> - est essentiellement le comportement passé. La "
-"session Hibernate obtient une connexion lorsqu'elle en a besoin et la garde "
-"jusqu'à ce que la session se ferme."
+"<literal>ON_CLOSE</literal> - est essentiellement le comportement passé "
+"décrit ci-dessus. La session Hibernate obtient une connexion lorsqu'elle en "
+"a besoin et la garde jusqu'à ce que la session se ferme. "
 
 #. Tag: para
-#: transactions.xml:983
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>AFTER_TRANSACTION</literal>: releases connections after a "
 "<literal>org.hibernate.Transaction</literal> has been completed."
 msgstr ""
-"<literal>AFTER_TRANSACTION</literal> - indique de relacher la connexion "
-"après qu'une <literal>org.hibernate.Transaction</literal> se soit achevée."
+"<literal>AFTER_TRANSACTION</literal> - indique de relâcher la connexion "
+"après qu'une <literal>org.hibernate.Transaction</literal> soit achevée. "
 
 #. Tag: para
-#: transactions.xml:989
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>AFTER_STATEMENT</literal> (also referred to as aggressive release): "
 "releases connections after every statement execution. This aggressive "
@@ -2092,14 +1842,13 @@
 "the use of <literal>org.hibernate.ScrollableResults</literal>."
 msgstr ""
 "<literal>AFTER_STATEMENT</literal> (aussi appelé libération brutale) - "
-"indique de relacher les connexions après chaque exécution d'un statement. Ce "
-"relachement aggressif est annulé si ce statement laisse des ressources "
+"indique de relâcher les connexions après chaque exécution d'un statement. Ce "
+"relâchement agressif est annulé si ce statement laisse des ressources "
 "associées à une session donnée ouvertes, actuellement ceci n'arrive que lors "
-"de l'utilisation de <literal>org.hibernate.ScrollableResults</literal>."
+"de l'utilisation de <literal>org.hibernate.ScrollableResults</literal>. "
 
 #. Tag: para
-#: transactions.xml:999
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The configuration parameter <literal>hibernate.connection.release_mode</"
 "literal> is used to specify which release mode to use. The possible values "
@@ -2107,11 +1856,10 @@
 msgstr ""
 "Le paramètre de configuration <literal>hibernate.connection.release_mode</"
 "literal> est utilisé pour spécifier quel mode de libération doit être "
-"utiliser. Les valeurs possibles sont:"
+"utilisé. Les valeurs possibles sont : "
 
 #. Tag: para
-#: transactions.xml:1006
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>auto</literal> (the default): this choice delegates to the release "
 "mode returned by the <literal>org.hibernate.transaction.TransactionFactory."
@@ -2127,23 +1875,21 @@
 "JTATransactionFactory, elle retourne ConnectionReleaseMode.AFTER_STATEMENT; "
 "pour JDBCTransactionFactory, elle retourne ConnectionReleaseMode."
 "AFTER_TRANSACTION. C'est rarement une bonne idée de changer ce comportement "
-"par défaut puisque les erreurs soulevées par ce paramétrage tend à prouver "
-"une erreur dans le code de l'utilisateur."
+"par défaut puisque les erreurs soulevées par ce paramétrage tend à indiquer "
+"la présence de bogues et/ou d'erreurs dans le code de l'utilisateur. "
 
 #. Tag: para
-#: transactions.xml:1016
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>on_close</literal>: uses ConnectionReleaseMode.ON_CLOSE. This "
 "setting is left for backwards compatibility, but its use is discouraged."
 msgstr ""
 "<literal>on_close</literal> - indique d'utiliser ConnectionReleaseMode."
 "ON_CLOSE. Ce paramétrage existe pour garantir la compatibilité avec les "
-"versions précédentes, mais ne devrait plus être utilisé."
+"versions précédentes, mais ne devrait plus être utilisé. "
 
 #. Tag: para
-#: transactions.xml:1022
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>after_transaction</literal>: uses ConnectionReleaseMode."
 "AFTER_TRANSACTION. This setting should not be used in JTA environments. Also "
@@ -2155,12 +1901,11 @@
 "ConnectionReleaseMode.AFTER_TRANSACTION. Ne devrait pas être utilisé dans "
 "les environnements JTA. Notez aussi qu'avec ConnectionReleaseMode."
 "AFTER_TRANSACTION, si une session est considérée comme étant en mode auto-"
-"commit les connexions seront relachées comme si le mode était "
-"AFTER_STATEMENT."
+"commit les connexions seront relâchées comme si le mode était "
+"AFTER_STATEMENT. "
 
 #. Tag: para
-#: transactions.xml:1030
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>after_statement</literal>: uses ConnectionReleaseMode."
 "AFTER_STATEMENT. Additionally, the configured <literal>ConnectionProvider</"
@@ -2173,12 +1918,12 @@
 "matter if we re-establish the same connection."
 msgstr ""
 "<literal>after_statement</literal> - indique d'utiliser "
-"ConnectionReleaseMode.AFTER_STATEMENT. Additonnellement, le "
+"ConnectionReleaseMode.AFTER_STATEMENT. De plus, le "
 "<literal>ConnectionProvider</literal> utilisé est consulté pour savoir s'il "
 "supporte ce paramétrage (<literal>supportsAggressiveRelease()</literal>). Si "
-"ce n'est pas le cas, le mode de libération est ré initialisé à "
+"ce n'est pas le cas, le mode de libération est ré-initialisé à "
 "ConnectionReleaseMode.AFTER_TRANSACTION. Ce paramétrage n'est sûr que dans "
 "les environnements où il est possible d'obtenir à nouveau la même connexion "
 "JDBC à chaque fois que l'on fait un appel de <literal>ConnectionProvider."
-"getConnection()</literal> ou dans les envrionnements auto-commit où il n'est "
-"pas important d'obtenir plusieurs fois la même connexion."
+"getConnection()</literal> ou dans les environnements auto-commit où il n'est "
+"pas important d'obtenir plusieurs fois la même connexion. "

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/tutorial.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/tutorial.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/tutorial.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,23 +1,27 @@
+# translation of tutorial.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: tutorial\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-01-05 10:08+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: tutorial.xml:31
 #, no-c-format
 msgid "Tutorial"
-msgstr ""
+msgstr "Tutoriel"
 
 #. Tag: para
-#: tutorial.xml:33
 #, no-c-format
 msgid ""
 "Intended for new users, this chapter provides an step-by-step introduction "
@@ -26,33 +30,41 @@
 "Gloegl. All code is contained in the <filename>tutorials/web</filename> "
 "directory of the project source."
 msgstr ""
+"A l'intention des nouveaux utilisateurs, ce chapitre fournit une "
+"introduction étape par étape à Hibernate, en commençant par une application "
+"simple, avec une base de données en-mémoire. Le tutoriel est basé sur une "
+"tutoriel antérieur qui avait été développé par Michael Gloegl. Tout le code "
+"est contenu dans <filename>tutorials/web</filename> qui se trouve dans le "
+"répertoire source du projet. "
 
 #. Tag: para
-#: tutorial.xml:42
 #, no-c-format
 msgid ""
 "This tutorial expects the user have knowledge of both Java and SQL. If you "
 "have a limited knowledge of JAVA or SQL, it is advised that you start with a "
 "good introduction to that technology prior to attempting to learn Hibernate."
 msgstr ""
+"Ce tutoriel assume que l'utilisateur est déjà familier avec Java et SQL à la "
+"fois. Si vous ne possédez qu'une connaissance de Java et d'SQL limitée, il "
+"est conseillé de commencer par vous familiariser avec ces technologies avant "
+"d'aborder Hibernate."
 
 #. Tag: para
-#: tutorial.xml:51
 #, no-c-format
 msgid ""
 "The distribution contains another example application under the "
 "<filename>tutorial/eg</filename> project source directory."
 msgstr ""
+"La distribution contient un autre exemple d'application qui se trouve dans "
+"le répertoire source du projet <filename>tutorial/eg</filename>."
 
 #. Tag: title
-#: tutorial.xml:59
 #, no-c-format
 msgid "Part 1 - The first Hibernate Application"
-msgstr "Partie 1 - Première application Hibernate"
+msgstr "Section 1 - Première application Hibernate"
 
 #. Tag: para
-#: tutorial.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For this example, we will set up a small database application that can store "
 "events we want to attend and information about the host(s) of these events."
@@ -62,7 +74,6 @@
 "informations à propos des hôtes de ces événements."
 
 #. Tag: para
-#: tutorial.xml:67
 #, no-c-format
 msgid ""
 "Although you can use whatever database you feel comfortable using, we will "
@@ -70,15 +81,17 @@
 "database) to avoid describing installation/setup of any particular database "
 "servers."
 msgstr ""
+"Malgré que vous puissiez utiliser tout base de données qui vous convienne, "
+"on choisira <ulink url=\"http://hsqldb.org/\">HSQLDB</ulink> (une base de "
+"données Java, en-mémoire) pour éviter de décrire l'installation et la "
+"configuration de n'importe quel serveur de base de données particulière."
 
 #. Tag: title
-#: tutorial.xml:76
 #, no-c-format
 msgid "Setup"
-msgstr ""
+msgstr "Configuration"
 
 #. Tag: para
-#: tutorial.xml:78
 #, no-c-format
 msgid ""
 "The first thing we need to do is to set up the development environment. We "
@@ -90,72 +103,29 @@
 "making use of <filename>src/main/java</filename>, <filename>src/main/"
 "resources</filename> and <filename>src/main/webapp</filename> directories."
 msgstr ""
+"La première chose que nous devons faire est de configurer l'environnement de "
+"développement. Nous utiliserons la \"standard layout\" préconisée par de "
+"nombreux outils de génération tels que <ulink url=\"http://maven.org"
+"\">Maven</ulink>. Maven, en particulier, a une bonne ressource décrivant "
+"cette <ulink url=\"http://maven.apache.org/guides/introduction/introduction-"
+"to-the-standard-directory-layout.html\">layout</ulink>. Comme ce tutoriel va "
+"devenir une application web, nous allons créer et utiliser les répertoires "
+"<filename>src/main/java.</filename>, <filename>src/main/ressources</"
+"filename> et <filename>src/main/webapp</filename>."
 
 #. Tag: para
-#: tutorial.xml:88
 #, no-c-format
 msgid ""
 "We will be using Maven in this tutorial, taking advantage of its transitive "
 "dependency management capabilities as well as the ability of many IDEs to "
 "automatically set up a project for us based on the maven descriptor."
 msgstr ""
+"Nous utiliserons Maven dans ce tutoriel. Nous profiterons de ses capacités "
+"de gestion de dépendances transitives, ainsi que de la capacité des nombreux "
+"IDE à installer automatiquement un projet sur la base du descripteur Maven."
 
-#. Tag: programlisting
-#: tutorial.xml:94
-#, no-c-format
-msgid ""
-"<![CDATA[<project xmlns=\"http://maven.apache.org/POM/4.0.0\"\n"
-"         xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
-"         xsi:schemaLocation=\"http://maven.apache.org/POM/4.0.0 http://maven."
-"apache.org/xsd/maven-4.0.0.xsd\">\n"
-"\n"
-"    <modelVersion>4.0.0</modelVersion>\n"
-"\n"
-"    <groupId>org.hibernate.tutorials</groupId>\n"
-"    <artifactId>hibernate-tutorial</artifactId>\n"
-"    <version>1.0.0-SNAPSHOT</version>\n"
-"    <name>First Hibernate Tutorial</name>\n"
-"\n"
-"    <build>\n"
-"         <!-- we dont want the version to be part of the generated war file "
-"name -->\n"
-"         <finalName>${artifactId}</finalName>\n"
-"    </build>\n"
-"\n"
-"    <dependencies>\n"
-"        <dependency>\n"
-"            <groupId>org.hibernate</groupId>\n"
-"            <artifactId>hibernate-core</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Because this is a web app, we also have a dependency on the "
-"servlet api. -->\n"
-"        <dependency>\n"
-"            <groupId>javax.servlet</groupId>\n"
-"            <artifactId>servlet-api</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Hibernate uses slf4j for logging, for our purposes here use the "
-"simple backend -->\n"
-"        <dependency>\n"
-"            <groupId>org.slf4j</groupId>\n"
-"            <artifactId>slf4j-simple</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Hibernate gives you a choice of bytecode providers between "
-"cglib and javassist -->\n"
-"        <dependency>\n"
-"            <groupId>javassist</groupId>\n"
-"            <artifactId>javassist</artifactId>\n"
-"        </dependency>\n"
-"    </dependencies>\n"
-"\n"
-"</project>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:97
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "It is not a requirement to use Maven. If you wish to use something else to "
 "build this tutoial (such as Ant), the layout will remain the same. The only "
@@ -171,93 +141,62 @@
 "javassist</filename> directory; additionally you will need both the servlet-"
 "api jar and one of the slf4j logging backends."
 msgstr ""
+"Vous n'êtes pas obligés d'utiliser Maven. Si vous souhaitez utiliser une "
+"autre technologie pour créer ce tutoriel (comme Ant), la mise en page "
+"restera le même. Le seul changement est que vous devrez manuellement tenir "
+"compte de toutes les dépendances nécessaires. Si vous utilisez <ulink url="
+"\"http://ant.apache.org/ivy/\">Ivy</ulink> pour assurer la gestion des "
+"dépendances transitives, vous utiliserez toujours les dépendances "
+"mentionnées ci-dessous. Dans le cas contraire, vous devrez trouver toutes "
+"les dépendances, explicites et transitives, et les ajouter au chemin de "
+"classe des projets. Si vous travaillez à partir de l'offre de distribution "
+"Hibernate, il s'agit de <filename>hibernate3.jar</filename>, de tous les "
+"artefacts du répertoire <filename>lib / requis</filename> et de tous les "
+"fichiers des répertoires <filename>lib / pseudo-code binaire/cglib</"
+"filename> ou <filename>lib/pseudo-code binaire/javassist</filename>; en "
+"outre, vous aurez besoin à la fois du bocal servlet-api et de l'un des "
+"gestionnaires de journalisation slf4j."
 
 #. Tag: para
-#: tutorial.xml:114
 #, no-c-format
 msgid ""
 "Save this file as <filename>pom.xml</filename> in the project root directory."
 msgstr ""
+"Sauvegardez ce fichier sous la forme <filename>pom.xml</filename> dans le "
+"répertoire root du projet."
 
 #. Tag: title
-#: tutorial.xml:121
 #, no-c-format
 msgid "The first class"
 msgstr "La première classe"
 
 #. Tag: para
-#: tutorial.xml:123
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next, we create a class that represents the event we want to store in the "
 "database; it is a simple JavaBean class with some properties:"
 msgstr ""
-"Ensuite, nous créons une classe qui réprésente l'événement que nous voulons "
-"stocker dans notre base de données."
+"Ensuite, nous créons une classe qui représente l'évènement que nous voulons "
+"stocker dans notre base de données. Il s'agit d'une simple classe JavaBean "
+"avec quelques propriétés :"
 
-#. Tag: programlisting
-#: tutorial.xml:128
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[package org.hibernate.tutorial.domain;\n"
-"\n"
-"import java.util.Date;\n"
-"\n"
-"public class Event {\n"
-"    private Long id;\n"
-"\n"
-"    private String title;\n"
-"    private Date date;\n"
-"\n"
-"    public Event() {}\n"
-"\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"\n"
-"    private void setId(Long id) {\n"
-"        this.id = id;\n"
-"    }\n"
-"\n"
-"    public Date getDate() {\n"
-"        return date;\n"
-"    }\n"
-"\n"
-"    public void setDate(Date date) {\n"
-"        this.date = date;\n"
-"    }\n"
-"\n"
-"    public String getTitle() {\n"
-"        return title;\n"
-"    }\n"
-"\n"
-"    public void setTitle(String title) {\n"
-"        this.title = title;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:130
-#, fuzzy, no-c-format
-msgid ""
 "This class uses standard JavaBean naming conventions for property getter and "
 "setter methods, as well as private visibility for the fields. Although this "
 "is the recommended design, it is not required. Hibernate can also access "
 "fields directly, the benefit of accessor methods is robustness for "
 "refactoring."
 msgstr ""
-"Vous pouvez voir que cette classe utilise les conventions de nommage "
+"Vous constaterez que cette classe utilise les conventions de nommage "
 "standard JavaBean pour les méthodes getter/setter des propriétés, ainsi "
 "qu'une visibilité privée pour les champs. Ceci est la conception recommandée "
 "- mais pas obligatoire. Hibernate peut aussi accéder aux champs directement, "
 "le bénéfice des méthodes d'accès est la robustesse pour la refonte de code. "
-"Le constructeur sans argument est requis pour instancier un objet de cette "
-"classe via reflexion."
 
 #. Tag: para
-#: tutorial.xml:138
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>id</literal> property holds a unique identifier value for a "
 "particular event. All persistent entity classes (there are less important "
@@ -273,22 +212,21 @@
 msgstr ""
 "La propriété <literal>id</literal> contient la valeur d'un identifiant "
 "unique pour un événement particulier. Toutes les classes d'entités "
-"persistantes (ainsi que les classes dépendantes de moindre importance) "
-"auront besoin d'une telle propriété identifiante si nous voulons utiliser "
-"l'ensemble complet des fonctionnalités d'Hibernate. En fait, la plupart des "
-"applications (surtout les applications web) ont besoin de distinguer des "
-"objets par des identifiants, donc vous devriez considérer ça comme une "
-"fonctionnalité plutôt que comme une limitation. Cependant, nous ne "
+"persistantes (il y a également des classes dépendantes de moindre "
+"importance) auront besoin d'une telle propriété identifiante si nous voulons "
+"utiliser l'ensemble complet des fonctionnalités de Hibernate. En fait, la "
+"plupart des applications (surtout les applications web) ont besoin de "
+"distinguer des objets par des identifiants, par conséquent considérez cela "
+"comme une fonctionnalité et non comme une limitation. Cependant, nous ne "
 "manipulons généralement pas l'identité d'un objet, dorénavant la méthode "
 "setter devrait être privée. Seul Hibernate assignera les identifiants "
-"lorsqu'un objet est sauvegardé. Vous pouvez voir qu'Hibernate peut accéder "
-"aux méthodes publiques, privées et protégées, ainsi qu'aux champs (publics, "
-"privés, protégés) directement. Le choix vous est laissé, et vous pouvez "
-"l'ajuster à la conception de votre application."
+"lorsqu'un objet est sauvegardé. Remarquez que Hibernate peut accéder aux "
+"méthodes publiques, privées et protégées, ainsi qu'aux champs (publics, "
+"privés, protégés) directement. À vous de choisir, et vous pouvez également "
+"l'ajuster à la conception de votre application. "
 
 #. Tag: para
-#: tutorial.xml:153
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The no-argument constructor is a requirement for all persistent classes; "
 "Hibernate has to create objects for you, using Java Reflection. The "
@@ -297,27 +235,26 @@
 "instrumentation."
 msgstr ""
 "Le constructeur sans argument est requis pour toutes les classes "
-"persistantes ; Hibernate doit créer des objets pour vous en utilisant la "
+"persistantes; Hibernate doit créer des objets pour vous en utilisant la "
 "réflexion Java. Le constructeur peut être privé, cependant, la visibilité du "
-"paquet est requise pour la génération de proxy à l'exécution et une "
-"récupération des données efficaces sans instrumentation du bytecode."
+"paquet est requise pour la génération de proxies à l'exécution et une "
+"récupération efficace des données sans instrumentation du bytecode. "
 
 #. Tag: para
-#: tutorial.xml:161
 #, no-c-format
 msgid ""
 "Save this file to the <filename>src/main/java/org/hibernate/tutorial/domain</"
 "filename> directory."
 msgstr ""
+"Sauvegardez ce fichier dans le répertoire <filename>src/main/java/org/"
+"hibernate/tutorial/domain</filename>."
 
 #. Tag: title
-#: tutorial.xml:168
 #, no-c-format
 msgid "The mapping file"
-msgstr "Le fichier de mapping"
+msgstr "Le fichier de mappage"
 
 #. Tag: para
-#: tutorial.xml:170
 #, no-c-format
 msgid ""
 "Hibernate needs to know how to load and store objects of the persistent "
@@ -326,34 +263,18 @@
 "columns in that table it should use."
 msgstr ""
 "Hibernate a besoin de savoir comment charger et stocker des objets d'une "
-"classe persistante. C'est là qu'intervient le fichier de mapping Hibernate. "
-"Le fichier de mapping indique à Hibernate à quelle table dans la base de "
-"données il doit accéder, et quelles colonnes de cette table il devra "
-"utiliser."
+"classe persistante. C'est là qu'intervient le fichier de mappage Hibernate. "
+"Le fichier de mappage indique à Hibernate à quelle table accéder dans la "
+"base de données, et les colonnes de cette table à utiliser."
 
 #. Tag: para
-#: tutorial.xml:178
 #, no-c-format
 msgid "The basic structure of a mapping file looks like this:"
-msgstr "La structure basique de ce fichier de mapping ressemble à ça :"
-
-#. Tag: programlisting
-#: tutorial.xml:182
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"[...]\n"
-"</hibernate-mapping>]]>"
 msgstr ""
+"La structure basique de ce fichier de mappage ressemble à ce qui suit :"
 
 #. Tag: para
-#: tutorial.xml:184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate DTD is sophisticated. You can use it for auto-completion of XML "
 "mapping elements and attributes in your editor or IDE. Opening up the DTD "
@@ -365,29 +286,27 @@
 "<filename>hibernate3.jar</filename>, if using the distribution bundle)."
 msgstr ""
 "Notez que la DTD Hibernate est très sophistiquée. Vous pouvez l'utiliser "
-"pour l'auto-complétement des éléments et des attributs de mapping XML dans "
-"votre éditeur ou votre IDE. Vous devriez aussi ouvrir le fichier DTD dans "
-"votre éditeur de texte - c'est le moyen le plus facile d'obtenir une vue "
+"pour l'auto-finalisation des éléments et des attributs de mappage XML dans "
+"votre éditeur ou votre IDE. Ouvrez également le fichier DTD dans votre "
+"éditeur de texte - c'est le moyen le plus facile d'obtenir une vue "
 "d'ensemble de tous les éléments et attributs, et de voir les valeurs par "
 "défaut, ainsi que quelques commentaires. Notez qu'Hibernate ne chargera pas "
-"le fichier DTD à partir du web, mais regardera d'abord dans le classpath de "
-"l'application. Le fichier DTD est inclus dans <literal>hibernate3.jar</"
-"literal> ainsi que dans le répertoire <literal>src</literal> de la "
-"distribution Hibernate."
+"le fichier DTD à partir du web, mais regardera d'abord dans le chemin de "
+"classe de l'application. Le fichier DTD est inclus dans <filename>hibernate-"
+"core.jar ainsi que </filename>dans le répertoire <filename>src</filename> de "
+"la distribution Hibernate)."
 
 #. Tag: para
-#: tutorial.xml:197
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will omit the DTD declaration in future examples to shorten the code. It "
 "is, of course, not optional."
 msgstr ""
 "Nous omettrons la déclaration de la DTD dans les exemples futurs pour "
-"raccourcir le code. Bien sûr il n'est pas optionnel."
+"raccourcir le code. Évidemment il n'est pas optionnel. "
 
 #. Tag: para
-#: tutorial.xml:203
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Between the two <literal>hibernate-mapping</literal> tags, include a "
 "<literal>class</literal> element. All persistent entity classes (again, "
@@ -397,26 +316,12 @@
 "Entre les deux balises <literal>hibernate-mapping</literal>, incluez un "
 "élément <literal>class</literal>. Toutes les classes d'entités persistantes "
 "(encore une fois, il pourrait y avoir des classes dépendantes plus tard, qui "
-"ne sont pas des entités mère) ont besoin d'un mapping vers une table de la "
+"ne sont pas des entités mère) ont besoin d'un mappage vers une table de la "
 "base de données SQL :"
 
-#. Tag: programlisting
-#: tutorial.xml:210
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:212
-#, fuzzy, no-c-format
-msgid ""
 "So far we have told Hibernate how to persist and load object of class "
 "<literal>Event</literal> to the table <literal>EVENTS</literal>. Each "
 "instance is now represented by a row in that table. Now we can continue by "
@@ -424,32 +329,16 @@
 "not want to care about handling this identifier, we configure Hibernate's "
 "identifier generation strategy for a surrogate primary key column:"
 msgstr ""
-"Plus loin, nous disons à Hibernate comment persister et charger un objet de "
-"la classe <literal>Event</literal> dans la table <literal>EVENTS</literal>, "
-"chaque instance est représentée par une ligne dans cette table. Maintenant "
-"nous continuons avec le mapping de la propriété de l'identifiant unique vers "
-"la clef primaire de la table. De plus, comme nous ne voulons pas nous "
-"occuper de la gestion de cet identifiant, nous utilisons une stratégie de "
-"génération d'identifiant d'Hibernate pour la colonne de la clef primaire "
-"subrogée :"
+"Plus loin, nous indiquons à Hibernate comment persister et charger un objet "
+"de la classe <literal>Event</literal> dans la table <literal>EVENTS</"
+"literal>, chaque instance étant représentée par une ligne dans cette table. "
+"Maintenant nous continuons avec le mappage de la propriété de l'identifiant "
+"unique vers la clef primaire des tables. De plus, comme nous ne voulons pas "
+"nous occuper de la gestion de cet identifiant, nous utilisons une stratégie "
+"de génération d'identifiant Hibernate pour la colonne de la clé primaire "
+"subrogée : "
 
-#. Tag: programlisting
-#: tutorial.xml:222
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"        <id name=\"id\" column=\"EVENT_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:224
 #, no-c-format
 msgid ""
 "The <literal>id</literal> element is the declaration of the identifier "
@@ -459,9 +348,14 @@
 "The column attribute tells Hibernate which column of the <literal>EVENTS</"
 "literal> table holds the primary key value."
 msgstr ""
+"L'élément <literal>ID</literal> est la déclaration de l'identifiant de "
+"propriété. L'attribut de mappage <literal>name=\"id\"</literal> déclare le "
+"nom de la propriété JavaBean et indique à Hibernate d'utiliser les méthodes "
+"<literal>getId()</literal> et <literal>setId()</literal> pour accéder à la "
+"propriété. L'attribut de colonne indique à Hibernate quelle colonne de la "
+"table <literal>EVENTS</literal> contient la valeur de clé primaire."
 
 #. Tag: para
-#: tutorial.xml:234
 #, no-c-format
 msgid ""
 "The nested <literal>generator</literal> element specifies the identifier "
@@ -472,48 +366,39 @@
 "Identifier value generation is also one of Hibernate's many extension points "
 "and you can plugin in your own strategy."
 msgstr ""
+"L'élément imbriqué <literal>Générateur</literal> spécifie la stratégie de "
+"génération d'identifiant (c'est à dire comment les valeurs d'identifiant "
+"sont-elles générées?). Dans ce cas nous avons choisi <literal>native</"
+"literal>, qui offre un niveau de la portabilité selon le dialecte de base de "
+"données configurée. Mise en veille prolongée prend en charge la base de "
+"données générée, unique au monde, ainsi que l'application affectée, les "
+"identifiants. Génération de valeur d'identifiant est aussi l'un des nombreux "
+"points d'extension d'Hibernate et vous pouvez plug-in votre propre stratégie."
 
 #. Tag: para
-#: tutorial.xml:246
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "<literal>native</literal> is no longer consider the best strategy in terms "
-"of portability. for further discussion, see"
+"of portability. for further discussion, see <xref linkend=\"portability-idgen"
+"\" />"
 msgstr ""
+"<literal>native</literal> n'est plus considéré comme la meilleure stratégie "
+"en terme de  portabilité. Pour obtenir davantage d'explications, voir <xref "
+"linkend=\"portability-idgen\" />"
 
 #. Tag: para
-#: tutorial.xml:252
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Lastly, we need to tell Hibernate about the remaining entity class "
 "properties. By default, no properties of the class are considered persistent:"
 msgstr ""
-"Finalement nous incluons des déclarations pour les propriétés persistantes "
-"de la classe dans le fichier de mapping. Par défaut, aucune propriété de la "
-"classe n'est considérée comme persistante :"
+"Enfin, nous incluons des déclarations pour les propriétés persistantes de la "
+"classe dans le fichier de mappage. Par défaut, aucune propriété de la classe "
+"n'est considérée comme persistante : "
 
-#. Tag: programlisting
-#: tutorial.xml:258
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"        <id name=\"id\" column=\"EVENT_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"date\" type=\"timestamp\" column=\"EVENT_DATE\"/>\n"
-"        <property name=\"title\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:260
-#, fuzzy, no-c-format
-msgid ""
 "Similar to the <literal>id</literal> element, the <literal>name</literal> "
 "attribute of the <literal>property</literal> element tells Hibernate which "
 "getter and setter methods to use. In this case, Hibernate will search for "
@@ -521,12 +406,13 @@
 "()</literal> and <literal>setTitle()</literal> methods."
 msgstr ""
 "Comme avec l'élément <literal>id</literal>, l'attribut <literal>name</"
-"literal> de l'élément <literal>property</literal> indique à Hibernate quels "
-"getters/setters utiliser."
+"literal> de l'élément <literal>property</literal> indique à Hibernate "
+"quelles méthodes getters/setters utiliser. Par conséquent dans ce cas, "
+"Hibernate cherchera <literal>getDate()/setDate()</literal>, de même que "
+"<literal>getTitle()/setTitle()</literal>. "
 
 #. Tag: para
-#: tutorial.xml:271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Why does the <literal>date</literal> property mapping include the "
 "<literal>column</literal> attribute, but the <literal>title</literal> does "
@@ -535,17 +421,16 @@
 "literal>, however, <literal>date</literal> is a reserved keyword in most "
 "databases so you will need to map it to a different name."
 msgstr ""
-"Pourquoi le mapping de la propriété <literal>date</literal> inclut "
-"l'attribut <literal>column</literal>, mais pas <literal>title</literal> ? "
-"Sans l'attribut <literal>column</literal> Hibernate utilise par défaut le "
-"nom de la propriété comme nom de colonne. Ca fonctionne bien pour "
-"<literal>title</literal>. Cependant, <literal>date</literal> est un mot clef "
+"Pourquoi le mappage de la propriété <literal>date</literal> inclut-il "
+"l'attribut <literal>column</literal>, mais non le <literal>title</literal> ? "
+"Sans l'attribut <literal>column</literal>, Hibernate utilise par défaut le "
+"nom de la propriété comme nom de colonne. Cela fonctionne bien pour "
+"<literal>title</literal>. Cependant, <literal>date</literal> est un mot clé "
 "réservé dans la plupart des bases de données, donc nous utilisons un nom "
-"différent pour le mapping."
+"différent pour le mappage. "
 
 #. Tag: para
-#: tutorial.xml:281
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>title</literal> mapping also lacks a <literal>type</literal> "
 "attribute. The types declared and used in the mapping files are not Java "
@@ -562,26 +447,25 @@
 "literal> column. Full date and time information is preserved by mapping the "
 "property with a <literal>timestamp</literal> converter."
 msgstr ""
-"La prochaine chose intéressante est que le mapping de <literal>title</"
-"literal> manque aussi d'un attribut <literal>type</literal>. Les types que "
-"nous déclarons et utilisons dans les fichiers de mapping ne sont pas, comme "
-"vous pourriez vous y attendre, des types de données Java. Ce ne sont pas, "
-"non plus, des types de base de données SQL. Ces types sont donc appelés des "
-"<emphasis>types de mapping Hibernate</emphasis>, des convertisseurs qui "
+"Il est intéressant de noter que le mappage de <literal>title</literal> "
+"manque également d'un attribut <literal>type</literal>. Les types que nous "
+"déclarons et utilisons dans les fichiers de mappage ne sont pas, comme vous "
+"pourriez vous y attendre, des types de données Java. Ce ne sont pas, non "
+"plus, des types de base de données SQL. Ces types sont donc appelés "
+"<emphasis>types de mappage Hibernate</emphasis>, des convertisseurs qui "
 "peuvent traduire des types Java en types SQL et vice versa. De plus, "
-"Hibernate tentera de déterminer la bonne conversion et le type de mapping "
+"Hibernate tentera de déterminer la bonne conversion et le type de mappage "
 "lui-même si l'attribut <literal>type</literal> n'est pas présent dans le "
-"mapping. Dans certains cas, cette détection automatique (utilisant la "
+"mappage. Dans certains cas, cette détection automatique (utilisant la "
 "réflexion sur la classe Java) pourrait ne pas donner la valeur attendue ou "
 "dont vous avez besoin. C'est le cas avec la propriété <literal>date</"
 "literal>. Hibernate ne peut pas savoir si la propriété \"mappera\" une "
 "colonne SQL de type <literal>date</literal>, <literal>timestamp</literal> ou "
 "<literal>time</literal>. Nous déclarons que nous voulons conserver des "
 "informations avec une date complète et l'heure en mappant la propriété avec "
-"un <literal>timestamp</literal>."
+"un convertisseur <literal>timestamp</literal>. "
 
 #. Tag: para
-#: tutorial.xml:297
 #, no-c-format
 msgid ""
 "Hibernate makes this mapping type determination using reflection when the "
@@ -589,39 +473,44 @@
 "performance is important you should consider explicitly defining the type to "
 "use."
 msgstr ""
+"Hibernate rend cette détermination de type de mappage en utilisant la "
+"réflection au moment du traitement des fichiers de mappage. Cela prend du "
+"temps et consomme des ressources, donc, si la performance de démarrage est "
+"importante, vous devriez considérer définir explicitement quel type utiliser."
 
 #. Tag: para
-#: tutorial.xml:304
 #, no-c-format
 msgid ""
 "Save this mapping file as <filename>src/main/resources/org/hibernate/"
 "tutorial/domain/Event.hbm.xml</filename>."
 msgstr ""
+"Sauvegardez ce fichier de mappage ainsi <filename>src/main/resources/org/"
+"hibernate/tutorial/domain/Event.hbm.xml</filename>."
 
 #. Tag: title
-#: tutorial.xml:312
 #, no-c-format
 msgid "Hibernate configuration"
 msgstr "Configuration d'Hibernate"
 
 #. Tag: para
-#: tutorial.xml:314
 #, no-c-format
 msgid ""
 "At this point, you should have the persistent class and its mapping file in "
 "place. It is now time to configure Hibernate. First let's set up HSQLDB to "
 "run in \"server mode\""
 msgstr ""
+"A ce niveau là, vous devriez avoir la classe persistante et son fichier de "
+"mappage en place. Il est temps maintenant de configurer Hibernate. Tout "
+"d'abord, il nous faut configurer HSQLDB pour qu'il puisse exécuter en "
+"\"server mode\""
 
 #. Tag: para
-#: tutorial.xml:321
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "We do this do that the data remains between runs."
-msgstr ""
+msgstr "xxx"
 
 #. Tag: para
-#: tutorial.xml:326
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will utilize the Maven exec plugin to launch the HSQLDB server by "
 "running: <command> mvn exec:java -Dexec.mainClass=\"org.hsqldb.Server\" -"
@@ -631,18 +520,16 @@
 "tutorial, shutdown HSQLDB, delete all files in the <filename>target/data</"
 "filename> directory, and start HSQLDB again."
 msgstr ""
-"Créez un répertoire appelé <literal>data</literal> à la racine du répertoire "
-"de développement - c'est là que HSQL DB stockera ses fichiers de données. "
-"Démarrez maintenant votre base de données en exécutant <literal>java -"
-"classpath lib/hsqldb.jar org.hsqldb.Server</literal> dans votre répertoire "
-"de travail. Vous observez qu'elle démarre et ouvre une socket TCP/IP, c'est "
-"là que notre application se connectera plus tard. Si vous souhaitez démarrez "
-"à partir d'une nouvelle base de données pour ce tutoriel (faites "
-"<literal>CTRL + C</literal> dans la fenêtre the window), effacez le "
-"répertoire <literal>data/</literal> et redémarrez HSQL DB à nouveau."
+"Vous utiliserez le lugin exec Maven pour lancer le serveur HSQLDB en "
+"exécutant : <command> mvn exec:java -Dexec.mainClass=\"org.hsqldb.Server\" -"
+"Dexec.args=\"-database.0 file:target/data/tutorial\"</command>. Vous "
+"observez qu'elle démarre et ouvre un socket TCP/IP, c'est là que notre "
+"application se connectera plus tard. Si vous souhaitez démarrez à partir "
+"d'une nouvelle base de données pour ce tutoriel (choisissez <literal>CTRL + "
+"C</literal> dans la fenêtre), effacez tous les fichiers dans le répertoire "
+"<filename>target/data</filename> et redémarrez HSQL DB."
 
 #. Tag: para
-#: tutorial.xml:337
 #, no-c-format
 msgid ""
 "Hibernate will be connecting to the database on behalf of your application, "
@@ -654,121 +541,83 @@
 "net/\">proxool</ulink>. However, we will be using the Hibernate built-in "
 "connection pool for this tutorial."
 msgstr ""
+"Hibernate se connectera à la base de données pour le compte de votre "
+"application, donc il devra savoir comment obtenir des connexions. Pour ce "
+"tutoriel, nous devrons utliser un pool de connexions autonomes (et non pas "
+"<interfacename>javax.sql.DataSource</interfacename>). Hibernate bénéficie du "
+"support de deux pools de connexions JDBC open source de tierce partie : "
+"<ulink url=\"https://sourceforge.net/projects/c3p0\">c3p0</ulink> and <ulink "
+"url=\"http://proxool.sourceforge.net/\">proxool</ulink>. Cependant, nous "
+"utiliserons le pool de connexions intégré Hibernate pour ce tutoriel."
 
 #. Tag: para
-#: tutorial.xml:348
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The built-in Hibernate connection pool is in no way intended for production "
 "use. It lacks several features found on any decent connection pool."
 msgstr ""
+"Le pool de connexions intégré Hibernate n'est pas conçu pour les "
+"environnements de production."
 
 #. Tag: para
-#: tutorial.xml:354
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For Hibernate's configuration, we can use a simple <literal>hibernate."
 "properties</literal> file, a more sophisticated <literal>hibernate.cfg.xml</"
 "literal> file, or even complete programmatic setup. Most users prefer the "
 "XML configuration file:"
 msgstr ""
-"Pour la configuration d'Hibernate, nous pouvons utiliser un simple fichier "
+"Pour la configuration de Hibernate, nous pouvons utiliser un simple fichier "
 "<literal>hibernate.properties</literal>, un fichier <literal>hibernate.cfg."
 "xml</literal> légèrement plus sophistiqué, ou même une configuration "
 "complète par programmation. La plupart des utilisateurs préfèrent le fichier "
-"de configuration XML :"
+"de configuration XML : "
 
-#. Tag: programlisting
-#: tutorial.xml:360
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-"<!DOCTYPE hibernate-configuration PUBLIC\n"
-"        \"-//Hibernate/Hibernate Configuration DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
-"\">\n"
-"\n"
-"<hibernate-configuration>\n"
-"\n"
-"    <session-factory>\n"
-"\n"
-"        <!-- Database connection settings -->\n"
-"        <property name=\"connection.driver_class\">org.hsqldb.jdbcDriver</"
-"property>\n"
-"        <property name=\"connection.url\">jdbc:hsqldb:hsql://localhost</"
-"property>\n"
-"        <property name=\"connection.username\">sa</property>\n"
-"        <property name=\"connection.password\"></property>\n"
-"\n"
-"        <!-- JDBC connection pool (use the built-in) -->\n"
-"        <property name=\"connection.pool_size\">1</property>\n"
-"\n"
-"        <!-- SQL dialect -->\n"
-"        <property name=\"dialect\">org.hibernate.dialect.HSQLDialect</"
-"property>\n"
-"\n"
-"        <!-- Enable Hibernate's automatic session context management -->\n"
-"        <property name=\"current_session_context_class\">thread</property>\n"
-"\n"
-"        <!-- Disable the second-level cache  -->\n"
-"        <property name=\"cache.provider_class\">org.hibernate.cache."
-"NoCacheProvider</property>\n"
-"\n"
-"        <!-- Echo all executed SQL to stdout -->\n"
-"        <property name=\"show_sql\">true</property>\n"
-"\n"
-"        <!-- Drop and re-create the database schema on startup -->\n"
-"        <property name=\"hbm2ddl.auto\">update</property>\n"
-"\n"
-"        <mapping resource=\"org/hibernate/tutorial/domain/Event.hbm.xml\"/>\n"
-"\n"
-"    </session-factory>\n"
-"\n"
-"</hibernate-configuration>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:363
 #, no-c-format
 msgid "Notice that this configuration file specifies a different DTD"
 msgstr ""
+"Vous pourrez remarquer que cette configuration XML utilise une DTD "
+"différente."
 
 #. Tag: para
-#: tutorial.xml:366
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You configure Hibernate's <literal>SessionFactory</literal>. SessionFactory "
 "is a global factory responsible for a particular database. If you have "
 "several databases, for easier startup you should use several <literal>&lt;"
 "session-factory&gt;</literal> configurations in several configuration files."
 msgstr ""
-"Notez que cette configuration XML utilise une DTD différente. Nous "
-"configurons une <literal>SessionFactory</literal> d'Hibernate - une fabrique "
-"globale responsable d'une base de données particulière. Si vous avez "
-"plusieurs base de données, utilisez plusieurs configurations <literal>&lt;"
-"session-factory&gt;</literal>, généralement dans des fichiers de "
-"configuration différents (pour un démarrage plus facile)."
+"Nous configurons une <literal>SessionFactory</literal> de Hibernate - une "
+"fabrique globale responsable d'une base de données particulière. Si vous "
+"avez plusieurs base de données, utilisez plusieurs configurations "
+"<literal>&lt;session-factory&gt;</literal>, généralement dans des fichiers "
+"de configuration différents (pour un démarrage plus facile)."
 
 #. Tag: para
-#: tutorial.xml:373
 #, no-c-format
 msgid ""
 "The first four <literal>property</literal> elements contain the necessary "
 "configuration for the JDBC connection. The dialect <literal>property</"
 "literal> element specifies the particular SQL variant Hibernate generates."
 msgstr ""
+"Les quatre premiers éléments <literal>property</literal> contiennent la "
+"configuration nécessaire pour la connexion JDBC. L'élément "
+"<literal>property</literal> du dialecte spécifie quelle variante du SQL "
+"Hibernate va générer. "
 
 #. Tag: para
-#: tutorial.xml:380
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "In most cases, Hibernate is able to properly determine which dialect to use. "
-"See <xref linkend=\"portability-dialectresolver\"/> for more information."
+"See <xref linkend=\"portability-dialectresolver\" /> for more information."
 msgstr ""
+"Hibernate est capable de déterminer correctement quel dialecte utiliser dans "
+"la plupart des cas. Voir <xref linkend=\"portability-dialectresolver\" /> "
+"pour obtenir davantage d'informations. "
 
 #. Tag: para
-#: tutorial.xml:386
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's automatic session management for persistence contexts is "
 "particularly useful in this context. The <literal>hbm2ddl.auto</literal> "
@@ -778,34 +627,30 @@
 "Ant task. Finally, add the mapping file(s) for persistent classes to the "
 "configuration."
 msgstr ""
-"Les quatre premiers éléments <literal>property</literal> contiennent la "
-"configuration nécessaire pour la connexion JDBC. L'élément "
-"<literal>property</literal> du dialecte spécifie quelle variante du SQL "
-"Hibernate va générer. La gestion automatique des sessions d'Hibernate pour "
-"les contextes de persistance sera détaillée très vite. L'option "
+"La gestion automatique des sessions d'Hibernate pour les contextes de "
+"persistance est bien pratique, comme vous pourrez le constater. L'option "
 "<literal>hbm2ddl.auto</literal> active la génération automatique des schémas "
-"de base de données - directement dans la base de données. Cela peut bien sûr "
-"aussi être désactivé (en supprimant l'option de configuration) ou redirigé "
-"vers un fichier avec l'aide de la tâche Ant <literal>SchemaExport</literal>. "
-"Finalement, nous ajoutons le(s) fichier(s) de mapping pour les classes "
-"persistantes."
+"de base de données - directement dans la base de données. Cela peut "
+"également être désactivé (en supprimant l'option de configuration) ou "
+"redirigé vers un fichier avec l'aide de la tâche Ant <literal>SchemaExport</"
+"literal>. Finalement, nous ajoutons le(s) fichier(s) de mappage pour les "
+"classes persistantes."
 
 #. Tag: para
-#: tutorial.xml:395
 #, no-c-format
 msgid ""
 "Save this file as <filename>hibernate.cfg.xml</filename> into the "
 "<filename>src/main/resources</filename> directory."
 msgstr ""
+"Sauvegarder ce fichier en tant que <filename>hibernate.cfg.xml</filename> "
+"dans le répertoire <filename>src/main/resources</filename>."
 
 #. Tag: title
-#: tutorial.xml:403
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Building with Maven"
-msgstr "Construction avec Ant"
+msgstr "Construction avec Maven"
 
 #. Tag: para
-#: tutorial.xml:405
 #, no-c-format
 msgid ""
 "We will now build the tutorial with Maven. You will need to have Maven "
@@ -815,45 +660,21 @@
 "basic project tasks. First, lets run the <literal>compile</literal> goal to "
 "make sure we can compile everything so far:"
 msgstr ""
+"Nous allons maintenant construire le tutoriel avec Maven. Vous aurez besoin "
+"d'installer Maven pour cela. Il est disponible dans la page <ulink url="
+"\"http://maven.apache.org/download.html\">Maven download page</ulink>. Maven "
+"pourra lire le fichier <filename>/pom.xml</filename> que nous avons créé "
+"plus tôt et saura comment effectuer quelques tâches du projet de base. Tout "
+"d'abord, exécutons <literal>compile</literal> pour s'assurer que nous "
+"pouvons tout compiler jusqu'à maintenant :"
 
-#. Tag: programlisting
-#: tutorial.xml:415
-#, no-c-format
-msgid ""
-"<![CDATA[[hibernateTutorial]$ mvn compile\n"
-"[INFO] Scanning for projects...\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] Building First Hibernate Tutorial\n"
-"[INFO]    task-segment: [compile]\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] [resources:resources]\n"
-"[INFO] Using default encoding to copy filtered resources.\n"
-"[INFO] [compiler:compile]\n"
-"[INFO] Compiling 1 source file to /home/steve/projects/sandbox/"
-"hibernateTutorial/target/classes\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] BUILD SUCCESSFUL\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] Total time: 2 seconds\n"
-"[INFO] Finished at: Tue Jun 09 12:25:25 CDT 2009\n"
-"[INFO] Final Memory: 5M/547M\n"
-"[INFO] "
-"------------------------------------------------------------------------]]>"
-msgstr ""
-
 #. Tag: title
-#: tutorial.xml:420
 #, no-c-format
 msgid "Startup and helpers"
 msgstr "Démarrage et aides"
 
 #. Tag: para
-#: tutorial.xml:422
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is time to load and store some <literal>Event</literal> objects, but "
 "first you have to complete the setup with some infrastructure code. You have "
@@ -870,69 +691,34 @@
 "literal>, mais d'abord nous devons compléter la configuration avec du code "
 "d'infrastructure. Nous devons démarrer Hibernate. Ce démarrage inclut la "
 "construction d'un objet <literal>SessionFactory</literal> global et le "
-"stocker quelque part facile d'accès dans le code de l'application. Une "
-"<literal>SessionFactory</literal> peut ouvrir des nouvelles "
-"<literal>Session</literal>s. Une <literal>Session</literal> représente une "
-"unité de travail simplement \"threadée\", la <literal>SessionFactory</"
-"literal> est un objet global \"thread-safe\", instancié une seule fois."
+"stocker dans un lieu facile d'accès dans le code de l'application. Une "
+"<literal>SessionFactory</literal> peut ouvrir de nouvelles <literal>Session</"
+"literal>s. Une <literal>Session</literal> représente une unité de travail "
+"simplement \"threadée\". La <interfacename>org.hibernate.SessionFactory</"
+"interfacename> est un objet global \"thread-safe\", instancié une seule fois."
 
 #. Tag: para
-#: tutorial.xml:436
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will create a <literal>HibernateUtil</literal> helper class that takes "
 "care of startup and makes accessing the <interfacename>org.hibernate."
 "SessionFactory</interfacename> more convenient."
 msgstr ""
 "Nous créerons une classe d'aide <literal>HibernateUtil</literal> qui "
-"s'occupe du démarrage et rend la gestion des <literal>Session</literal>s "
-"plus facile. Regardons l'implémentation :"
+"s'occupe du démarrage et rend la gestion des <interfacename>org.hibernate."
+"SessionFactory</interfacename> plus facile. "
 
-#. Tag: programlisting
-#: tutorial.xml:442
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.util;\n"
-"\n"
-"import org.hibernate.SessionFactory;\n"
-"import org.hibernate.cfg.Configuration;\n"
-"\n"
-"public class HibernateUtil {\n"
-"\n"
-"    private static final SessionFactory sessionFactory = buildSessionFactory"
-"();\n"
-"\n"
-"    private static SessionFactory buildSessionFactory() {\n"
-"        try {\n"
-"            // Create the SessionFactory from hibernate.cfg.xml\n"
-"            return new Configuration().configure().buildSessionFactory();\n"
-"        }\n"
-"        catch (Throwable ex) {\n"
-"            // Make sure you log the exception, as it might be swallowed\n"
-"            System.err.println(\"Initial SessionFactory creation failed.\" + "
-"ex);\n"
-"            throw new ExceptionInInitializerError(ex);\n"
-"        }\n"
-"    }\n"
-"\n"
-"    public static SessionFactory getSessionFactory() {\n"
-"        return sessionFactory;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:444
 #, no-c-format
 msgid ""
 "Save this code as <filename>src/main/java/org/hibernate/tutorial/util/"
 "HibernateUtil.java</filename>"
 msgstr ""
+"Sauvegardez ce code en tant que <filename>src/main/java/org/hibernate/"
+"tutorial/util/HibernateUtil.java</filename>"
 
 #. Tag: para
-#: tutorial.xml:449
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This class not only produces the global <interfacename>org.hibernate."
 "SessionFactory</interfacename> reference in its static initializer; it also "
@@ -941,15 +727,16 @@
 "reference from JNDI in an application server or any other location for that "
 "matter."
 msgstr ""
-"Cette classe ne produit pas seulement la <literal>SessionFactory</literal> "
-"globale dans un initialiseur statique (appelé une seule fois par la JVM "
-"lorsque la classe est chargée), elle masque le fait qu'elle exploite un "
-"singleton. Elle pourrait aussi obtenir la <literal>SessionFactory</literal> "
-"depuis JNDI dans un serveur d'applications."
+"Cette classe ne produit pas seulement la <interfacename>org.hibernate."
+"SessionFactory</interfacename> globale dans un initialiseur statique. Elle "
+"masque le fait qu'elle exploite un singleton statique. Nous aurions pu aussi "
+"bien vérouiller la référence <interfacename>org.hibernate.SessionFactory</"
+"interfacename> à partir de JNDI dans un serveur d'application ou dans "
+"n'importe quelle location en fait. Elle pourrait aussi obtenir la "
+"<literal>SessionFactory</literal> depuis JNDI dans un serveur d'applications."
 
 #. Tag: para
-#: tutorial.xml:458
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you give the <interfacename>org.hibernate.SessionFactory</interfacename> "
 "a name in your configuration, Hibernate will try to bind it to JNDI under "
@@ -958,16 +745,15 @@
 "<literal>HibernateService</literal> to JNDI. Such advanced options are "
 "discussed later."
 msgstr ""
-"Si vous nommez la <literal>SessionFactory</literal> dans votre fichier de "
-"configuration, Hibernate tentera la récupération depuis JNDI. Pour éviter ce "
-"code, vous pouvez aussi utiliser un déploiement JMX et laisser le conteneur "
-"(compatible JMX) instancier et lier un <literal>HibernateService</literal> à "
-"JNDI. Ces options avancées sont détaillées dans la documentation de "
-"référence Hibernate."
+"Si vous nommez <interfacename>org.hibernate.SessionFactory</interfacename> "
+"dans votre fichier de configuration, Hibernate tentera la récupération "
+"depuis JNDI. Pour éviter ce code, vous pouvez aussi utiliser un déploiement "
+"JMX et laisser le conteneur (compatible JMX) instancier et lier un "
+"<literal>HibernateService</literal> à JNDI. Ces options avancées sont "
+"expliquées plus loin."
 
 #. Tag: para
-#: tutorial.xml:467
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You now need to configure a logging system. Hibernate uses commons logging "
 "and provides two choices: Log4j and JDK 1.4 logging. Most developers prefer "
@@ -978,104 +764,56 @@
 "configuration, you can change the settings. By default, only the Hibernate "
 "startup message is shown on stdout."
 msgstr ""
-"Cela devrait encore compiler sans problème. Nous avons finalement besoin de "
-"configurer le système de \"logs\" - Hibernate utilise commons-logging et "
-"vous laisse le choix entre log4j et le système de logs du JDK 1.4. La "
-"plupart des développeurs préfèrent log4j : copiez <literal>log4j.properties</"
-"literal> de la distribution d'Hibernate (il est dans le répertoire "
-"<literal>etc/</literal>) dans votre répertoire <literal>src</literal>, puis "
-"faites de même avec <literal>hibernate.cfg.xml</literal>. Regardez la "
-"configuration d'exemple et changez les paramètres si vous voulez une sortie "
-"plus verbeuse. Par défaut, seul le message de démarrage d'Hibernate est "
-"affiché sur la sortie standard."
+"Nous avons finalement besoin de configurer le système de journalisation - "
+"Hibernate utilise commons-logging et vous laisse le choix entre log4j et le "
+"système de logs du JDK 1.4. La plupart des développeurs préfèrent log4j : "
+"copiez <literal>log4j.properties</literal> de la distribution de Hibernate "
+"(il est dans le répertoire <literal>etc/</literal>) dans votre répertoire "
+"<literal>src</literal>, puis faîtes de même avec <literal>hibernate.cfg.xml</"
+"literal>. Regardez la configuration d'exemple et changez les paramètres si "
+"vous voulez une sortie plus verbeuse. Par défaut, seul le message de "
+"démarrage de Hibernate est affiché sur la sortie standard."
 
 #. Tag: para
-#: tutorial.xml:477
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The tutorial infrastructure is complete and you are now ready to do some "
 "real work with Hibernate."
 msgstr ""
-"L'infrastructure de ce didacticiel est complète - et nous sommes prêts à "
-"effectuer un travail réel avec Hibernate."
+"L'infrastructure de ce toturiel est complète - et nous sommes prêts à "
+"effectuer un travail réel avec Hibernate. "
 
 #. Tag: title
-#: tutorial.xml:485
 #, no-c-format
 msgid "Loading and storing objects"
 msgstr "Charger et stocker des objets"
 
 #. Tag: para
-#: tutorial.xml:487
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We are now ready to start doing some real worjk with Hibernate. Let's start "
 "by writing an <literal>EventManager</literal> class with a <literal>main()</"
 "literal> method:"
 msgstr ""
-"Finalement nous pouvons utiliser Hibernate pour charger et stocker des "
-"objets. Nous écrivons une classe <literal>EventManager</literal> avec une "
-"méthode <literal>main()</literal> :"
+"Enfin nous pouvons utiliser Hibernate pour charger et stocker des objets. "
+"Nous écrivons une classe <literal>EventManager</literal> avec une méthode "
+"<literal>main()</literal> : "
 
-#. Tag: programlisting
-#: tutorial.xml:493
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[package org.hibernate.tutorial;\n"
-"\n"
-"import org.hibernate.Session;\n"
-"\n"
-"import java.util.*;\n"
-"\n"
-"import org.hibernate.tutorial.domain.Event;\n"
-"import org.hibernate.tutorial.util.HibernateUtil;\n"
-"\n"
-"public class EventManager {\n"
-"\n"
-"    public static void main(String[] args) {\n"
-"        EventManager mgr = new EventManager();\n"
-"\n"
-"        if (args[0].equals(\"store\")) {\n"
-"            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-"        }\n"
-"\n"
-"        HibernateUtil.getSessionFactory().close();\n"
-"    }\n"
-"\n"
-"    private void createAndStoreEvent(String title, Date theDate) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Event theEvent = new Event();\n"
-"        theEvent.setTitle(title);\n"
-"        theEvent.setDate(theDate);\n"
-"        session.save(theEvent);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:495
-#, fuzzy, no-c-format
-msgid ""
 "In <literal>createAndStoreEvent()</literal> we created a new <literal>Event</"
 "literal> object and handed it over to Hibernate. At that point, Hibernate "
 "takes care of the SQL and executes an <literal>INSERT</literal> on the "
 "database."
 msgstr ""
-"Nous créons un nouvel objet <literal>Event</literal>, et le remettons à "
-"Hibernate. Hibernate s'occupe maintenant du SQL et exécute les "
-"<literal>INSERT</literal>s dans la base de données. Regardons le code de "
-"gestion de la <literal>Session</literal> et de la <literal>Transaction</"
-"literal> avant de lancer ça."
+"Nous créons un nouvel objet <literal>Event</literal> dans "
+"<literal>createAndStoreEvent()</literal>, et nous le remettons à Hibernate, "
+"qui s'occupe maintenant du SQL et exécute les <literal>INSERT</literal> s "
+"dans la base de données."
 
 #. Tag: para
-#: tutorial.xml:502
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <interface>org.hibernate.Session</interface> is designed to represent a "
 "single unit of work (a single atmoic piece of work to be performed). For now "
@@ -1086,17 +824,17 @@
 "interfacename> API. In this particular case we are using JDBC-based "
 "transactional semantics, but it could also run with JTA."
 msgstr ""
-"Une <literal>Session</literal> est une unité de travail. Pour le moment, "
-"nous allons faire les choses simplement et assumer une granularité un-un "
-"entre une <literal>Session</literal> hibernate et une transaction à la base "
-"de données. Pour isoler notre code du système de transaction sous-jacent "
-"(dans notre cas, du pure JDBC, mais cela pourrait être JTA), nous utilisons "
-"l'API <literal>Transaction</literal> qui est disponible depuis la "
-"<literal>Session</literal> Hibernate."
+"Une <interface>org.hibernate.Session</interface> est une unité de travail "
+"unique (une unité atmoic simple). Pour le moment, nous allons faire les "
+"choses simplement et présumer une granularité un-à-un entre une "
+"<literal>Session</literal> Hibernate et une transaction de la base de "
+"données. Pour isoler notre code du système de transaction sous-jacent, nous "
+"utilisons l'API <interfacename>org.hibernate.Transaction</interfacename> "
+"Hibernate. Dans notre cas, nous utilisons du pur JDBC, mais on aurait pu "
+"utiliser JTA."
 
 #. Tag: para
-#: tutorial.xml:515
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What does <literal>sessionFactory.getCurrentSession()</literal> do? First, "
 "you can call it as many times and anywhere you like once you get hold of "
@@ -1107,18 +845,17 @@
 "xml</filename>? Due to that setting, the context of a current unit of work "
 "is bound to the current Java thread that executes the application."
 msgstr ""
-"Que fait <literal>sessionFactory.getCurrentSession()</literal> ? "
-"Premièrement, vous pouvez l'invoquer autant de fois que vous le voulez et "
-"n'importe où du moment que vous avez votre <literal>SessionFactory</literal> "
-"(facile grâce à <literal>HibernateUtil</literal>). La méthode "
-"<literal>getCurrentSession()</literal> renvoie toujours l'unité de travail "
-"courante. Souvenez vous que nous avons basculé notre option de configuration "
-"au mécanisme basé sur le \"thread\" dans <literal>hibernate.cfg.xml</"
-"literal>. Par conséquent, le scope de l'unité de travail courante est le "
-"thread java courant d'exécution. Ceci n'est pas totalement vrai."
+"Quelle est la fonction de <literal>sessionFactory.getCurrentSession()</"
+"literal> ? Premièrement, vous pouvez l'invoquer autant de fois que vous le "
+"voulez et n'importe où, du moment que vous avez votre "
+"<literal>SessionFactory</literal> (facile grâce à <literal>HibernateUtil</"
+"literal>). La méthode <literal>getCurrentSession()</literal> renvoie "
+"toujours l'unité de travail courante. Souvenez vous que nous avons basculé "
+"notre option de configuration au mécanisme basé sur le \"thread\" dans "
+"<literal>hibernate.cfg.xml</literal>. Par conséquent, l'unité de travail "
+"courante est liée au thread Java courant qui exécute notre application."
 
 #. Tag: para
-#: tutorial.xml:529
 #, no-c-format
 msgid ""
 "Hibernate offers three methods of current session tracking. The \"thread\" "
@@ -1126,10 +863,13 @@
 "prototyping and tutorials such as this one. Current session tracking is "
 "discussed in more detail later on."
 msgstr ""
+"Hibernate offre trois méthodes le suivi de session courant. La méthode basée "
+"\"thread\" qui n'est pas conçue pour une utilisation de la production ; "
+"seulement utile pour les prototypes et des tutoriels comme celui-ci. Le "
+"suivi de session courant est abordé plus en détail par la suite."
 
 #. Tag: para
-#: tutorial.xml:538
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <interface>org.hibernate.Session</interface> begins when the first call to "
 "<literal>getCurrentSession()</literal> is made for the current thread. It is "
@@ -1140,20 +880,17 @@
 "new <interface>org.hibernate.Session</interface> and can start a new unit of "
 "work."
 msgstr ""
-"Une <literal>Session</literal> commence lorsqu'elle est vraiment utilisée la "
-"première fois, Lorsque nous appelons pour la première fois "
-"<literal>getCurrentSession()</literal>. Ensuite, elle est liée, par "
-"Hibernate, au thread courant. Lorsque la transaction s'achève (commit ou "
-"rollback), Hibernate délie la <literal>Session</literal> du thread et la "
-"ferme pour vous. Si vous invoquez <literal>getCurrentSession()</literal> une "
-"autre fois, vous obtenez une nouvelle <literal>Session</literal> et pouvez "
-"entamer une nouvelle unité de travail. Ce modèle de programmation "
-"\"<emphasis>thread-bound</emphasis>\" est le moyen le plus populaire "
-"d'utiliser Hibernate."
+"Une <interface>org.hibernate.Session</interface> commence lorsque le thread "
+"courant commence à appeler <literal>getCurrentSession()</literal>. Ensuite, "
+"elle est attachée par Hibernate au thread courant. Lorsque la transaction "
+"s'achève, par commit ou par rollback, Hibernate détache automatiquement la "
+"<literal>Session</literal> du thread et la ferme pour vous. Si vous invoquez "
+"<literal>getCurrentSession()</literal> une nouvelle fois, vous obtenez une "
+"nouvelle <literal>Session</literal> et pouvez entamer une nouvelle unité de "
+"travail. "
 
 #. Tag: para
-#: tutorial.xml:551
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Related to the unit of work scope, should the Hibernate <interface>org."
 "hibernate.Session</interface> be used to execute one or several database "
@@ -1167,248 +904,160 @@
 "<emphasis>session-per-operation</emphasis> an anti-pattern. A real web "
 "application is shown later in the tutorial which will help illustrate this."
 msgstr ""
-"UNTRANSLATED ! Related to the unit of work scope, should the Hibernate "
-"<literal>Session</literal> be used to execute one or several database "
-"operations? The above example uses one <literal>Session</literal> for one "
-"operation. This is pure coincidence, the example is just not complex enough "
-"to show any other approach. The scope of a Hibernate <literal>Session</"
-"literal> is flexible but you should never design your application to use a "
-"new Hibernate <literal>Session</literal> for <emphasis>every</emphasis> "
-"database operation. So even if you see it a few more times in the following "
-"(very trivial) examples, consider <emphasis>session-per-operation</emphasis> "
-"an anti-pattern. A real (web) application is shown later in this tutorial."
+"A propos de la portée de l'unité de travail, la session <interface>org."
+"hibernate.Session</interface> Hibernate devrait-elle être utilisée pour "
+"exécuter une ou plusieurs opérations en base de données ? L'exemple ci-"
+"dessus utilise une <literal>Session</literal> pour une opération. C'est une "
+"pure coïncidence, l'exemple n'est pas assez complexe pour montrer d'autres "
+"approches. La portée d'une <literal>Session</literal> Hibernate est flexible "
+"mais vous ne devriez jamais concevoir votre application de manière à "
+"utiliser une nouvelle <literal>Session</literal> Hibernate pour "
+"<emphasis>chaque</emphasis> opération en base de données. Donc même si vous "
+"le voyez quelquefois dans les exemples suivants, considérez <emphasis>une "
+"session par opération</emphasis> comme un anti-modèle. Une véritable "
+"application (web) est affichée plus loin dans ce tutoriel. "
 
 #. Tag: para
-#: tutorial.xml:568
 #, fuzzy, no-c-format
 msgid ""
-"See <xref linkend=\"transactions\"/> for more information about transaction "
+"See <xref linkend=\"transactions\" /> for more information about transaction "
 "handling and demarcation. The previous example also skipped any error "
 "handling and rollback."
 msgstr ""
-"Lisez <xref linkend=\"transactions\"/> pour plus d'informations sur la "
-"gestion des transactions et leur démarcations. Nous n'avons pas géré les "
-"erreurs et rollback sur l'exemple précédent."
+"Consultez <xref linkend=\"transactions\" /> pour plus d'informations sur la "
+"gestion des transactions et leur démarcation. Nous n'avons pas géré les "
+"erreurs et rollback dans l'exemple précédent."
 
 #. Tag: para
-#: tutorial.xml:574
 #, no-c-format
 msgid ""
 "To run this, we will make use of the Maven exec plugin to call our class "
 "with the necessary classpath setup: <command>mvn exec:java -Dexec.mainClass="
 "\"org.hibernate.tutorial.EventManager\" -Dexec.args=\"store\"</command>"
 msgstr ""
+"Pour pouvoir exécuter ceci, nous utiliserons le plugin exec Maven pour "
+"appeler notre classe avec la configuration de classpath qui convient : "
+"<command>mvn exec:java -Dexec.mainClass=\"org.hibernate.tutorial.EventManager"
+"\" -Dexec.args=\"store\"</command>"
 
 #. Tag: para
-#: tutorial.xml:581
 #, no-c-format
 msgid "You may need to perform <command>mvn compile</command> first."
 msgstr ""
+"Vous aurez sans doute besoin d'effectuer <command>mvn compile</command> pour "
+"commencer."
 
 #. Tag: para
-#: tutorial.xml:586
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You should see Hibernate starting up and, depending on your configuration, "
 "lots of log output. Towards the end, the following line will be displayed:"
 msgstr ""
-"Vous devriez voir, après la compilation, Hibernate démarrer et, en fonction "
-"de votre configuration, beaucoup de traces sur la sortie. À la fin vous "
-"trouverez la ligne suivante :"
+"Vous devriez constater qu'Hibernate démarre et selon votre configuration, "
+"beaucoup de traces sur la sortie. À la fin, vous trouverez la ligne "
+"suivante :"
 
-#. Tag: programlisting
-#: tutorial.xml:591
-#, no-c-format
-msgid ""
-"<![CDATA[[java] Hibernate: insert into EVENTS (EVENT_DATE, title, EVENT_ID) "
-"values (?, ?, ?)]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:593
 #, no-c-format
 msgid "This is the <literal>INSERT</literal> executed by Hibernate."
-msgstr ""
+msgstr "C'est l' <literal>INSERT</literal> exécutée par Hibernate."
 
 #. Tag: para
-#: tutorial.xml:597
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "To list stored events an option is added to the main method:"
 msgstr ""
 "Maintenant nous aimerions aussi lister les événements stockés, donc nous "
-"ajoutons une option à la méthode principale :"
+"ajoutons une option à la méthode principale : "
 
-#. Tag: programlisting
-#: tutorial.xml:601
-#, no-c-format
-msgid ""
-"<![CDATA[        if (args[0].equals(\"store\")) {\n"
-"            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-"        }\n"
-"        else if (args[0].equals(\"list\")) {\n"
-"            List events = mgr.listEvents();\n"
-"            for (int i = 0; i < events.size(); i++) {\n"
-"                Event theEvent = (Event) events.get(i);\n"
-"                System.out.println(\n"
-"                        \"Event: \" + theEvent.getTitle() + \" Time: \" + "
-"theEvent.getDate()\n"
-"                );\n"
-"            }\n"
-"        }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:603
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A new <literal>listEvents() method is also added</literal>:"
 msgstr ""
-"Nous ajoutons aussi une nouvelle méthode <literal>listEvents()</literal> :"
+"Nous ajoutons aussi une nouvelle méthode <literal>listEvents()</literal> : "
 
-#. Tag: programlisting
-#: tutorial.xml:607
-#, no-c-format
-msgid ""
-"<![CDATA[    private List listEvents() {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"        List result = session.createQuery(\"from Event\").list();\n"
-"        session.getTransaction().commit();\n"
-"        return result;\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:609
 #, fuzzy, no-c-format
 msgid ""
 "Here, we are using a Hibernate Query Language (HQL) query to load all "
 "existing <literal>Event</literal> objects from the database. Hibernate will "
 "generate the appropriate SQL, send it to the database and populate "
 "<literal>Event</literal> objects with the data. You can create more complex "
-"queries with HQL. See <xref linkend=\"queryhql\"/> for more information."
+"queries with HQL. See <xref linkend=\"queryhql\" /> for more information."
 msgstr ""
-"Ce que nous faisons ici c'est utiliser une requête HQL (Hibernate Query "
-"Language) pour charger tous les objets <literal>Event</literal> existants de "
-"la base de données. Hibernate générera le SQL approprié, l'enverra à la base "
-"de données et peuplera des objets <literal>Event</literal> avec les données. "
-"Vous pouvez créer des requêtes plus complexes avec HQL, bien sûr."
+"Ici nous utilisons une requête HQL (Hibernate Query Language) pour charger "
+"tous les objets <literal>Event</literal> existants de la base de données. "
+"Hibernate générera le SQL approprié, l'enverra à la base de données et "
+"peuplera des objets <literal>Event</literal> avec les données. Vous pouvez "
+"évidemment créer des requêtes plus complexes avec HQL. Voir <xref linkend="
+"\"queryhql\" /> pour obtenir davantage d'informations."
 
 #. Tag: para
-#: tutorial.xml:617
 #, no-c-format
 msgid ""
 "Now we can call our new functionality, again using the Maven exec plugin: "
 "<command>mvn exec:java -Dexec.mainClass=\"org.hibernate.tutorial.EventManager"
 "\" -Dexec.args=\"list\"</command>"
 msgstr ""
+"Nous pouvons maintenant appeler notre nouvelle fonctionnalité, en utilisant "
+"à nouveau le plugin exec Maven : <command>mvn exec:java -Dexec.mainClass="
+"\"org.hibernate.tutorial.EventManager\" -Dexec.args=\"list\"</command>"
 
 #. Tag: title
-#: tutorial.xml:627
 #, no-c-format
 msgid "Part 2 - Mapping associations"
-msgstr "Partie 2 - Mapper des associations"
+msgstr "Section 2 - Mapper des associations"
 
 #. Tag: para
-#: tutorial.xml:629
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "So far we have mapped a single persistent entity class to a table in "
 "isolation. Let's expand on that a bit and add some class associations. We "
 "will add people to the application and store a list of events in which they "
 "participate."
 msgstr ""
-"Nous avons mappé une classe d'une entité persistante vers une table. Partons "
-"de là et ajoutons quelques associations de classe. D'abord nous ajouterons "
-"des gens à notre application, et stockerons une liste d'événements auxquels "
-"ils participent."
+"Pour l'instant, nous nous sommes contentés de mapper une classe d'une entité "
+"persistante vers une table. Profitons-en pour ajouter quelques associations "
+"de classe. D'abord nous ajouterons des gens à notre application, et "
+"stockerons une liste d'événements auxquels ils participent."
 
 #. Tag: title
-#: tutorial.xml:637
 #, no-c-format
 msgid "Mapping the Person class"
 msgstr "Mapper la classe Person"
 
 #. Tag: para
-#: tutorial.xml:639
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The first cut of the <literal>Person</literal> class looks like this:"
 msgstr ""
-"La première version de la classe <literal>Person</literal> est simple :"
+"La première version de la classe <literal>Person</literal> est simple : "
 
-#. Tag: programlisting
-#: tutorial.xml:643
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.domain;\n"
-"\n"
-"public class Person {\n"
-"\n"
-"    private Long id;\n"
-"    private int age;\n"
-"    private String firstname;\n"
-"    private String lastname;\n"
-"\n"
-"    public Person() {}\n"
-"\n"
-"    // Accessor methods for all properties, private setter for 'id'\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:645
 #, no-c-format
 msgid ""
 "Save this to a file named <filename>src/main/java/org/hibernate/tutorial/"
 "domain/Person.java</filename>"
 msgstr ""
+"A sauvegarder dans le fichier nommé <filename>src/main/java/org/hibernate/"
+"tutorial/domain/Person.java</filename>"
 
 #. Tag: para
-#: tutorial.xml:650
 #, no-c-format
 msgid ""
 "Next, create the new mapping file as <filename>src/main/resources/org/"
 "hibernate/tutorial/domain/Person.hbm.xml</filename>"
 msgstr ""
+"Puis, créez le nouveau fichier de mappage <filename>src/main/resources/org/"
+"hibernate/tutorial/domain/Person.hbm.xml</filename>"
 
-#. Tag: programlisting
-#: tutorial.xml:655
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Person\" table=\"PERSON\">\n"
-"        <id name=\"id\" column=\"PERSON_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"age\"/>\n"
-"        <property name=\"firstname\"/>\n"
-"        <property name=\"lastname\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:657
 #, no-c-format
 msgid "Finally, add the new mapping to Hibernate's configuration:"
 msgstr ""
-"Finalement, ajoutez la nouveau mapping à la configuration d'Hibernate :"
+"Finalement, ajoutez le nouveau mappage à la configuration d'Hibernate :"
 
-#. Tag: programlisting
-#: tutorial.xml:661
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<mapping resource=\"events/Event.hbm.xml\"/>\n"
-"<mapping resource=\"events/Person.hbm.xml\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:663
-#, fuzzy, no-c-format
-msgid ""
 "Create an association between these two entities. Persons can participate in "
 "events, and events have participants. The design questions you have to deal "
 "with are: directionality, multiplicity, and collection behavior."
@@ -1416,17 +1065,15 @@
 "Nous allons maintenant créer une association entre ces deux entités. "
 "Évidemment, des personnes peuvent participer aux événements, et des "
 "événements ont des participants. Les questions de conception que nous devons "
-"traiter sont : direction, cardinalité et comportement de la collection."
+"traiter sont : direction, cardinalité et comportement de la collection. "
 
 #. Tag: title
-#: tutorial.xml:673
 #, no-c-format
 msgid "A unidirectional Set-based association"
 msgstr "Une association unidirectionnelle basée sur Set"
 
 #. Tag: para
-#: tutorial.xml:675
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "By adding a collection of events to the <literal>Person</literal> class, you "
 "can easily navigate to the events for a particular person, without executing "
@@ -1441,30 +1088,12 @@
 "événements d'une personne particulière, sans exécuter une requête explicite "
 "- en appelant <literal>aPerson.getEvents()</literal>. Nous utilisons une "
 "collection Java, un <literal>Set</literal>, parce que la collection ne "
-"contiendra pas d'éléments dupliqués et l'ordre ne nous importe pas."
+"contiendra pas d'éléments dupliqués et l'ordre ne nous importe pas pour ces "
+"exemples :"
 
-#. Tag: programlisting
-#: tutorial.xml:686
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[public class Person {\n"
-"\n"
-"    private Set events = new HashSet();\n"
-"\n"
-"    public Set getEvents() {\n"
-"        return events;\n"
-"    }\n"
-"\n"
-"    public void setEvents(Set events) {\n"
-"        this.events = events;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:688
-#, fuzzy, no-c-format
-msgid ""
 "Before mapping this association, let's consider the other side. We could "
 "just keep this unidirectional or create another collection on the "
 "<literal>Event</literal>, if we wanted to be able to navigate it from both "
@@ -1476,41 +1105,19 @@
 "Hence, we use Hibernate's many-to-many mapping:"
 msgstr ""
 "D'abord nous mappons cette association, mais pensez à l'autre côté. "
-"Clairement, nous pouvons la laisser unidirectionnelle. Ou alors, nous "
+"Clairement, nous pouvons la laisser unidirectionnelle. Ou bien, nous "
 "pourrions créer une autre collection sur <literal>Event</literal>, si nous "
-"voulons être capable de la parcourir de manière bidirectionnelle, c'est-à-"
-"dire avoir <literal>anEvent.getParticipants()</literal>. Ce n'est pas "
-"nécessaire d'un point de vue fonctionnel. Vous pourrez toujours exécuter une "
-"requête explicite pour récupérer les participants d'un \"event\" "
-"particulier. Ce choix de conception vous est laissé, mais ce qui reste "
-"certains est la cardinalité de l'association: \"plusieurs\" des deux côtés, "
-"nous appelons cela une association <emphasis>many-to-many</emphasis>. Par "
-"conséquent nous utilisons un mapping Hibernate many-to-many:"
+"voulons être capable de la parcourir de manière bidirectionnelle. Ce n'est "
+"pas nécessaire d'un point de vue fonctionnel. Vous pourrez toujours exécuter "
+"une requête explicite pour récupérer les participants d'un évènement "
+"particulier. Vous êtes libre de choisir la conception, ce qui est certain, "
+"c'est que la cardinalité de l'association : \"plusieurs\" valués des deux "
+"côtés, est appelée <emphasis>plusieurs-à-plusieurs</emphasis>. Par "
+"conséquent nous utilisons un mappage Hibernate plusieurs-à-plusieurs :"
 
-#. Tag: programlisting
-#: tutorial.xml:701
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\" table=\"PERSON\">\n"
-"    <id name=\"id\" column=\"PERSON_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"age\"/>\n"
-"    <property name=\"firstname\"/>\n"
-"    <property name=\"lastname\"/>\n"
-"\n"
-"    <set name=\"events\" table=\"PERSON_EVENT\">\n"
-"        <key column=\"PERSON_ID\"/>\n"
-"        <many-to-many column=\"EVENT_ID\" class=\"Event\"/>\n"
-"    </set>\n"
-"\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:703
-#, fuzzy, no-c-format
-msgid ""
 "Hibernate supports a broad range of collection mappings, a <literal>set</"
 "literal> being most common. For a many-to-many association, or <emphasis>n:"
 "m</emphasis> entity relationship, an association table is required. Each row "
@@ -1523,81 +1130,40 @@
 "tell Hibernate the class of the objects in your collection (the class on the "
 "other side of the collection of references)."
 msgstr ""
-"Hibernate supporte toutes sortes de mapping de collection, un <literal>&lt;"
-"set&gt;</literal> étant le plus commun. Pour une association many-to-many "
+"Hibernate supporte toutes sortes de mappage de collection, un <literal>set</"
+"literal> étant le plus commun. Pour une association plusieurs-à-plusieurs "
 "(ou une relation d'entité <emphasis>n:m</emphasis>), une table d'association "
 "est requise. Chaque ligne dans cette table représente un lien entre une "
 "personne et un événement. Le nom de la table est configuré avec l'attribut "
 "<literal>table</literal> de l'élément <literal>set</literal>. Le nom de la "
 "colonne identifiant dans l'association, du côté de la personne, est défini "
-"avec l'élément <literal>&lt;key&gt;</literal>, et le nom de la colonne pour "
-"l'événement dans l'attribut <literal>column</literal> de <literal>&lt;many-"
-"to-many&gt;</literal>. Vous devez aussi donner à Hibernate la classe des "
-"objets de votre collection (c'est-à-dire : la classe de l'autre côté de la "
-"collection)."
+"avec l'élément <literal>key</literal>, et le nom de la colonne pour "
+"l'événement avec l'attribut <literal>column</literal> de <literal>many-to-"
+"many</literal>. Vous devez aussi donner à Hibernate la classe des objets de "
+"votre collection (c'est-à-dire : la classe de l'autre côté de la collection)."
 
 #. Tag: para
-#: tutorial.xml:719
 #, no-c-format
 msgid "The database schema for this mapping is therefore:"
-msgstr "Le schéma de base de données pour ce mapping est donc :"
+msgstr "Le schéma de base de données pour ce mappage est donc :"
 
-#. Tag: programlisting
-#: tutorial.xml:723
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"    _____________        __________________\n"
-"   |             |      |                  |       _____________\n"
-"   |   EVENTS    |      |   PERSON_EVENT   |      |             |\n"
-"   |_____________|      |__________________|      |    PERSON   |\n"
-"   |             |      |                  |      |_____________|\n"
-"   | *EVENT_ID   | <--> | *EVENT_ID        |      |             |\n"
-"   |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  |\n"
-"   |  TITLE      |      |__________________|      |  AGE        |\n"
-"   |_____________|                                |  FIRSTNAME  |\n"
-"                                                  |  LASTNAME   |\n"
-"                                                  |_____________|\n"
-" ]]>"
-msgstr ""
-
 #. Tag: title
-#: tutorial.xml:728
 #, no-c-format
 msgid "Working the association"
 msgstr "Travailler avec l'association"
 
 #. Tag: para
-#: tutorial.xml:730
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now we will bring some people and events together in a new method in "
 "<literal>EventManager</literal>:"
 msgstr ""
 "Réunissons quelques personnes et quelques événements dans une nouvelle "
-"méthode dans <literal>EventManager</literal> :"
+"méthode dans <literal>EventManager</literal> : "
 
-#. Tag: programlisting
-#: tutorial.xml:734
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session.load(Person.class, personId);\n"
-"        Event anEvent = (Event) session.load(Event.class, eventId);\n"
-"        aPerson.getEvents().add(anEvent);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:736
-#, fuzzy, no-c-format
-msgid ""
 "After loading a <literal>Person</literal> and an <literal>Event</literal>, "
 "simply modify the collection using the normal collection methods. There is "
 "no explicit call to <literal>update()</literal> or <literal>save()</"
@@ -1614,26 +1180,24 @@
 msgstr ""
 "Après le chargement d'une <literal>Person</literal> et d'un <literal>Event</"
 "literal>, modifiez simplement la collection en utilisant les méthodes "
-"normales de la collection. Comme vous pouvez le voir, il n'y a pas d'appel "
-"explicite à <literal>update()</literal> ou <literal>save()</literal>, "
-"Hibernate détecte automatiquement que la collection a été modifiée et a "
-"besoin d'être mise à jour. Ceci est appelé <emphasis>la vérification sale "
-"automatique</emphasis> (NdT : \"automatic dirty checking\"), et vous pouvez "
-"aussi l'essayer en modifiant le nom ou la propriété date de n'importe lequel "
-"de vos objets. Tant qu'ils sont dans un état <emphasis>persistant</"
-"emphasis>, c'est-à-dire, liés à une <literal>Session</literal> Hibernate "
-"particulière (c-à-d qu'ils ont juste été chargés ou sauvegardés dans une "
-"unité de travail), Hibernate surveille les changements et exécute le SQL "
-"correspondant. Le processus de synchronisation de l'état de la mémoire avec "
+"normales de la collection. Comme vous pouvez le constater, il n'y a pas "
+"d'appel explicite à <literal>update()</literal> ou <literal>save()</"
+"literal>, Hibernate détecte automatiquement que la collection a été modifiée "
+"et a besoin d'être mise à jour. Ceci est appelé <emphasis>la vérification "
+"sale automatique</emphasis> (automatic dirty checking), et vous pouvez aussi "
+"l'essayer en modifiant le nom ou la propriété date de n'importe lequel de "
+"vos objets. Tant qu'ils sont dans un état <emphasis>persistant</emphasis>, "
+"c'est-à-dire, liés à une <literal>Session</literal> Hibernate particulière "
+"(c-à-d qu'ils ont juste été chargés ou sauvegardés dans une unité de "
+"travail), Hibernate surveille les changements et exécute le SQL "
+"correspondants. Le processus de synchronisation de l'état de la mémoire avec "
 "la base de données, généralement seulement à la fin d'une unité de travail, "
 "est appelé <emphasis>flushing</emphasis>. Dans notre code, l'unité de "
 "travail s'achève par un commit (ou rollback) de la transaction avec la base "
-"de données - comme défini par notre option <literal>thread</literal> de "
-"configuration pour la classe <literal>CurrentSessionContext</literal>."
+"de données."
 
 #. Tag: para
-#: tutorial.xml:755
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can load person and event in different units of work. Or you can modify "
 "an object outside of a <interfacename>org.hibernate.Session</interfacename>, "
@@ -1646,47 +1210,11 @@
 "<literal>Session</literal>, s'il n'est pas dans un état persistant (s'il "
 "était persistant avant, nous appelons cet état <emphasis>détaché</"
 "emphasis>). Vous pouvez même modifier une collection lorsqu'elle est "
-"détachée:"
+"détachée :"
 
-#. Tag: programlisting
-#: tutorial.xml:764
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session\n"
-"                .createQuery(\"select p from Person p left join fetch p."
-"events where p.id = :pid\")\n"
-"                .setParameter(\"pid\", personId)\n"
-"                .uniqueResult(); // Eager fetch the collection so we can use "
-"it detached\n"
-"        Event anEvent = (Event) session.load(Event.class, eventId);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"\n"
-"        // End of first unit of work\n"
-"\n"
-"        aPerson.getEvents().add(anEvent); // aPerson (and its collection) is "
-"detached\n"
-"\n"
-"        // Begin second unit of work\n"
-"\n"
-"        Session session2 = HibernateUtil.getSessionFactory()."
-"getCurrentSession();\n"
-"        session2.beginTransaction();\n"
-"        session2.update(aPerson); // Reattachment of aPerson\n"
-"\n"
-"        session2.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:766
-#, fuzzy, no-c-format
-msgid ""
 "The call to <literal>update</literal> makes a detached object persistent "
 "again by binding it to a new unit of work, so any modifications you made to "
 "it while detached can be saved to the database. This includes any "
@@ -1694,15 +1222,13 @@
 "object."
 msgstr ""
 "L'appel à <literal>update</literal> rend un objet détaché à nouveau "
-"persistant, vous pourriez dire qu'il le lie à une unité de travail, ainsi "
-"toutes les modifications (ajout, suppression) que vous avez faites pendant "
-"qu'il était détaché peuvent être sauvegardées dans la base de données (il se "
-"peut que vous ayez besoin de modifier quelques unes des méthodes précédentes "
-"pour retourner cet identifiant)."
+"persistant, vous pourriez dire qu'il le lie à une nouvelle unité de travail, "
+"ainsi toutes les modifications que vous avez faites pendant qu'il était "
+"détaché peuvent être sauvegardées dans la base de données, cela inclut toute "
+"modification effectuées sur une collection de cet objet entité."
 
 #. Tag: para
-#: tutorial.xml:775
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is not much use in our example, but it is an important concept you can "
 "incorporate into your own application. Complete this exercise by adding a "
@@ -1711,31 +1237,18 @@
 "an event - the <literal>save()</literal> method returns it (you might have "
 "to modify some of the previous methods to return that identifier):"
 msgstr ""
-"Ce n'est pas très utile dans notre situation actuelle, mais c'est un concept "
-"important que vous pouvez mettre dans votre propre application. Pour le "
-"moment, complétez cet exercice en ajoutant une nouvelle action à la méthode "
-"principale des <literal>EventManager</literal>s et appelez la à partir de la "
-"ligne de commande. Si vous avez besoin des identifiants d'une personne et "
-"d'un événement - la méthode <literal>save()</literal> les retourne."
+"Cela n'a pas grand intérêt dans notre situation, mais c'est un concept "
+"important qu'il vous faut concevoir dans votre application. Pour le moment, "
+"complétez cet exercice en ajoutant une nouvelle action à la méthode "
+"principale de l'<literal>EventManager</literal> et invoquez-la depuis la "
+"ligne de commande. Si vous avez besoin des identifiants d'un client et d'un "
+"évènement - la méthode <literal>save()</literal> vous les retourne (vous "
+"devrez peut-être modifier certaines méthodes précédentes pour retourner ces "
+"identifiants) :"
 
-#. Tag: programlisting
-#: tutorial.xml:783
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[        else if (args[0].equals(\"addpersontoevent\")) {\n"
-"            Long eventId = mgr.createAndStoreEvent(\"My Event\", new Date"
-"());\n"
-"            Long personId = mgr.createAndStorePerson(\"Foo\", \"Bar\");\n"
-"            mgr.addPersonToEvent(personId, eventId);\n"
-"            System.out.println(\"Added person \" + personId + \" to event \" "
-"+ eventId);\n"
-"        }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:785
-#, fuzzy, no-c-format
-msgid ""
 "This is an example of an association between two equally important classes : "
 "two entities. As mentioned earlier, there are other classes and types in a "
 "typical model, usually \"less important\". Some you have already seen, like "
@@ -1758,15 +1271,14 @@
 "entité particulière. Des instances de ces types n'ont pas leur propre "
 "identité, elles ne sont pas non plus partagées entre des entités (deux "
 "personnes ne référencent pas le même objet <literal>firstname</literal>, "
-"même si elles ont le même prénom). Bien sûr, des types de valeur ne peuvent "
-"pas seulement être trouvés dans le JDK (en fait, dans une application "
-"Hibernate toutes les classes du JDK sont considérées comme des types de "
-"valeur), vous pouvez aussi écrire vous-même des classes dépendantes, "
-"<literal>Address</literal> ou <literal>MonetaryAmount</literal>, par exemple."
+"même si elles ont le même prénom). Bien sûr, des types de valeur n'existent "
+"pas seulement dans le JDK (en fait, dans une application Hibernate toutes "
+"les classes du JDK sont considérées comme des types de valeur), vous pouvez "
+"aussi écrire vous-même des classes dépendantes, <literal>Address</literal> "
+"ou <literal>MonetaryAmount</literal>, par exemple. "
 
 #. Tag: para
-#: tutorial.xml:803
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also design a collection of value types. This is conceptually "
 "different from a collection of references to other entities, but looks "
@@ -1774,58 +1286,32 @@
 msgstr ""
 "Vous pouvez aussi concevoir une collection de types de valeur. C'est "
 "conceptuellement très différent d'une collection de références vers d'autres "
-"entités, mais très ressemblant en Java."
+"entités, mais très ressemblant dans Java. "
 
 #. Tag: title
-#: tutorial.xml:812
 #, no-c-format
 msgid "Collection of values"
 msgstr "Collection de valeurs"
 
 #. Tag: para
-#: tutorial.xml:814
 #, no-c-format
 msgid ""
 "Let's add a collection of email addresses to the <literal>Person</literal> "
 "entity. This will be represented as a <interfacename>java.util.Set</"
 "interfacename> of <classname>java.lang.String</classname> instances:"
 msgstr ""
+"Ajoutons un ensemble d'adresses email à l'entité <literal>Person</literal> "
+"qui sera représenté en tant que <interfacename>java.util.Set</interfacename> "
+"d'instance <classname>java.lang.String</classname> :"
 
-#. Tag: programlisting
-#: tutorial.xml:820
-#, no-c-format
-msgid ""
-"<![CDATA[    private Set emailAddresses = new HashSet();\n"
-"\n"
-"    public Set getEmailAddresses() {\n"
-"        return emailAddresses;\n"
-"    }\n"
-"\n"
-"    public void setEmailAddresses(Set emailAddresses) {\n"
-"        this.emailAddresses = emailAddresses;\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:822
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The mapping of this <literal>Set</literal> is as follows:"
-msgstr "Le mapping de ce <literal>Set</literal> :"
+msgstr "Le mappage de ce <literal>Set</literal> : "
 
-#. Tag: programlisting
-#: tutorial.xml:826
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[        <set name=\"emailAddresses\" table=\"PERSON_EMAIL_ADDR\">\n"
-"            <key column=\"PERSON_ID\"/>\n"
-"            <element type=\"string\" column=\"EMAIL_ADDR\"/>\n"
-"        </set>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:828
-#, fuzzy, no-c-format
-msgid ""
 "The difference compared with the earlier mapping is the use of the "
 "<literal>element</literal> part which tells Hibernate that the collection "
 "does not contain references to another entity, but is rather a collection "
@@ -1838,117 +1324,65 @@
 "<literal>element</literal> element defines the column name where the email "
 "address values will actually be stored."
 msgstr ""
-"La différence comparée au mapping vu plus tôt est la partie "
-"<literal>element</literal>, laquelle dit à Hibernate que la collection ne "
-"contient pas de références vers une autre entité, mais une collection "
+"La différence comparée au mappage vu plus tôt est la partie "
+"<literal>element</literal>, qui indique à Hibernate que la collection ne "
+"contient pas de référence vers une autre entité, mais une collection "
 "d'éléments de type <literal>String</literal> (le nom en minuscule vous "
-"indique que c'est un type/convertisseur du mapping Hibernate). Une fois "
+"indique que c'est un type/convertisseur du mappage Hibernate). Une fois "
 "encore, l'attribut <literal>table</literal> de l'élément <literal>set</"
 "literal> détermine le nom de la table pour la collection. L'élément "
-"<literal>key</literal> définit le nom de la colonne de la clef étrangère "
-"dans la table de la collection. L'attribut <literal>column</literal> dans "
+"<literal>key</literal> définit le nom de la colonne de la clé étrangère dans "
+"la table de la collection. L'attribut <literal>column</literal> dans "
 "l'élément <literal>element</literal> définit le nom de la colonne où les "
-"valeurs de <literal>String</literal> seront réellement stockées."
+"valeurs de <literal>String</literal> seront réellement stockées. "
 
 #. Tag: para
-#: tutorial.xml:844
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is the updated schema:"
-msgstr "Regardons le schéma mis à jour :"
+msgstr "Considérons le schéma mis à jour : "
 
-#. Tag: programlisting
-#: tutorial.xml:848
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"  _____________        __________________\n"
-" |             |      |                  |       _____________\n"
-" |   EVENTS    |      |   PERSON_EVENT   |      |             |       "
-"___________________\n"
-" |_____________|      |__________________|      |    PERSON   |      "
-"|                   |\n"
-" |             |      |                  |      |_____________|      | "
-"PERSON_EMAIL_ADDR |\n"
-" | *EVENT_ID   | <--> | *EVENT_ID        |      |             |      |"
-"___________________|\n"
-" |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  | <--> |  "
-"*PERSON_ID       |\n"
-" |  TITLE      |      |__________________|      |  AGE        |      |  "
-"*EMAIL_ADDR      |\n"
-" |_____________|                                |  FIRSTNAME  |      |"
-"___________________|\n"
-"                                                |  LASTNAME   |\n"
-"                                                |_____________|\n"
-" ]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:850
-#, fuzzy, no-c-format
-msgid ""
 "You can see that the primary key of the collection table is in fact a "
 "composite key that uses both columns. This also implies that there cannot be "
 "duplicate email addresses per person, which is exactly the semantics we need "
 "for a set in Java."
 msgstr ""
-"Vous pouvez voir que la clef primaire de la table de la collection est en "
-"fait une clef composée, utilisant deux colonnes. Ceci implique aussi qu'il "
-"ne peut pas y avoir d'adresses email dupliquées par personne, ce qui est "
-"exactement la sémantique dont nous avons besoin pour un ensemble en Java."
+"Vous pouvez voir que la clé primaire de la table de la collection est en "
+"fait une clé composée, utilisant les deux colonnes. Ceci implique aussi "
+"qu'il ne peut pas y avoir d'adresses email dupliquées par personne, ce qui "
+"est exactement la sémantique dont nous avons besoin pour un ensemble dans "
+"Java. "
 
 #. Tag: para
-#: tutorial.xml:856
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can now try to add elements to this collection, just like we did before "
 "by linking persons and events. It is the same code in Java:"
 msgstr ""
 "Vous pouvez maintenant tester et ajouter des éléments à cette collection, "
-"juste comme nous l'avons fait avant en liant des personnes et des "
-"événements. C'est le même code en Java."
+"juste comme nous l'avons fait auparavant en liant des personnes et des "
+"événements. C'est le même code dans Java. "
 
-#. Tag: programlisting
-#: tutorial.xml:861
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    private void addEmailToPerson(Long personId, String "
-"emailAddress) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session.load(Person.class, personId);\n"
-"        // adding to the emailAddress collection might trigger a lazy load "
-"of the collection\n"
-"        aPerson.getEmailAddresses().add(emailAddress);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:863
-#, fuzzy, no-c-format
-msgid ""
 "This time we did not use a <emphasis>fetch</emphasis> query to initialize "
 "the collection. Monitor the SQL log and try to optimize this with an eager "
 "fetch."
 msgstr ""
-"Cette fois ci, nous n'avons pas utilisé une requête de chargement agressif "
-"(<emphasis>fetch</emphasis>) pour initialiser la collection. Par conséquent, "
-"l'invocation du getter déclenchera un select supplémentaire pour "
-"l'initialiser. Traquez les logs SQL et tentez d'optimiser ce cas avec un "
-"chargement aggressif."
+"Cette fois-ci, nous n'avons pas utilisé de requête de chargement "
+"<emphasis>fetch</emphasis> pour initialiser la collection. Traquez les logs "
+"SQL et tentez d'optimiser ce cas avec un chargement agressif."
 
 #. Tag: title
-#: tutorial.xml:872
 #, no-c-format
 msgid "Bi-directional associations"
 msgstr "Associations bidirectionnelles"
 
 #. Tag: para
-#: tutorial.xml:874
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next you will map a bi-directional association. You will make the "
 "association between person and event work from both sides in Java. The "
@@ -1957,70 +1391,40 @@
 msgstr ""
 "Ensuite nous allons mapper une association bidirectionnelle - faire "
 "fonctionner l'association entre une personne et un événement à partir des "
-"deux côtés en Java. Bien sûr, le schéma de la base de données ne change pas, "
-"nous avons toujours une pluralité many-to-many. Une base de données "
-"relationnelle est plus flexible qu'un langage de programmation réseau, donc "
-"elle n'a pas besoin de direction de navigation - les données peuvent être "
-"vues et récupérées de toutes les manières possibles."
+"deux côtés dans Java. Bien sûr, le schéma de la base de données ne change "
+"pas, nous avons toujours une pluralité plusieurs-à-plusieurs. "
 
 #. Tag: para
-#: tutorial.xml:882
 #, no-c-format
 msgid ""
 "A relational database is more flexible than a network programming language, "
 "in that it does not need a navigation direction; data can be viewed and "
 "retrieved in any possible way."
 msgstr ""
+"Une base de données relationnelle est plus flexible qu'un langage de "
+"programmation réseau, donc elle n'a pas besoin de direction de navigation - "
+"les données peuvent être vues et récupérées de toutes les manières possibles."
 
 #. Tag: para
-#: tutorial.xml:890
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, add a collection of participants to the <literal>Event</literal> "
 "class:"
 msgstr ""
-"D'abord, ajouter une collection de participants à la classe <literal>Event</"
-"literal> :"
+"D'abord, ajoutez une collection de participants à la classe <literal>Event</"
+"literal> : "
 
-#. Tag: programlisting
-#: tutorial.xml:895
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    private Set participants = new HashSet();\n"
-"\n"
-"    public Set getParticipants() {\n"
-"        return participants;\n"
-"    }\n"
-"\n"
-"    public void setParticipants(Set participants) {\n"
-"        this.participants = participants;\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:897
-#, fuzzy, no-c-format
-msgid ""
 "Now map this side of the association in <literal>Event.hbm.xml</literal>."
 msgstr ""
-"Maintenant mapper ce côté de l'association aussi, dans <literal>Event.hbm."
-"xml</literal>."
+"Maintenant mappez ce côté de l'association aussi, dans <literal>Event.hbm."
+"xml</literal>. "
 
-#. Tag: programlisting
-#: tutorial.xml:901
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[        <set name=\"participants\" table=\"PERSON_EVENT\" inverse="
-"\"true\">\n"
-"            <key column=\"EVENT_ID\"/>\n"
-"            <many-to-many column=\"PERSON_ID\" class=\"events.Person\"/>\n"
-"        </set>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:903
-#, fuzzy, no-c-format
-msgid ""
 "These are normal <literal>set</literal> mappings in both mapping documents. "
 "Notice that the column names in <literal>key</literal> and <literal>many-to-"
 "many</literal> swap in both mapping documents. The most important addition "
@@ -2028,37 +1432,34 @@
 "<literal>set</literal> element of the <literal>Event</literal>'s collection "
 "mapping."
 msgstr ""
-"Comme vous le voyez, ce sont des mappings de <literal>set</literal>s normaux "
-"dans les deux documents de mapping. Notez que les noms de colonne dans "
+"Comme vous le voyez, ce sont des mappages de <literal>set</literal>s normaux "
+"dans les deux documents de mappage. Notez que les noms de colonne dans "
 "<literal>key</literal> et <literal>many-to-many</literal> sont inversés dans "
-"les 2 documents de mapping. L'ajout le plus important ici est l'attribut "
+"les 2 documents de mappage. L'ajout le plus important ici est l'attribut "
 "<literal>inverse=\"true\"</literal> dans l'élément <literal>set</literal> du "
-"mapping de la collection des <literal>Event</literal>s."
+"mappage de la collection des <literal>Event</literal>s. "
 
 #. Tag: para
-#: tutorial.xml:911
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What this means is that Hibernate should take the other side, the "
 "<literal>Person</literal> class, when it needs to find out information about "
 "the link between the two. This will be a lot easier to understand once you "
 "see how the bi-directional link between our two entities is created."
 msgstr ""
-"Ce que signifie qu'Hibernate devrait prendre l'autre côté - la classe "
-"<literal>Person</literal> - s'il a besoin de renseigner des informations à "
+"Cela signifie que Hibernate devrait prendre l'autre côté - la classe "
+"<literal>Person</literal> - quand il a besoin de trouver des informations à "
 "propos du lien entre les deux. Ce sera beaucoup plus facile à comprendre une "
 "fois que vous verrez comment le lien bidirectionnel entre les deux entités "
-"est créé."
+"est créé. "
 
 #. Tag: title
-#: tutorial.xml:920
 #, no-c-format
 msgid "Working bi-directional links"
 msgstr "Travailler avec des liens bidirectionnels"
 
 #. Tag: para
-#: tutorial.xml:922
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, keep in mind that Hibernate does not affect normal Java semantics. "
 "How did we create a link between a <literal>Person</literal> and an "
@@ -2072,67 +1473,41 @@
 msgstr ""
 "Premièrement, gardez à l'esprit qu'Hibernate n'affecte pas la sémantique "
 "normale de Java. Comment avons-nous créé un lien entre une <literal>Person</"
-"literal> et un <literal>Event</literal> dans l'exemple unidirectionnel ? "
-"Nous avons ajouté une instance de <literal>Event</literal> à la collection "
-"des références d'événement d'une instance de <literal>Person</literal>. "
-"Donc, évidemment, si vous voulons rendre ce lien bidirectionnel, nous devons "
-"faire la même chose de l'autre côté - ajouter une référence de "
-"<literal>Person</literal> à la collection d'un <literal>Event</literal>. "
-"Cette \"configuration du lien des deux côtés\" est absolument nécessaire et "
-"vous ne devriez jamais oublier de le faire."
+"literal> et un <literal>Event</literal> dans l'exemple unidirectionnel? Nous "
+"avons ajouté une instance de <literal>Event</literal> à la collection des "
+"références d'événement d'une instance de <literal>Person</literal>. Donc, "
+"évidemment, si vous voulons rendre ce lien bidirectionnel, nous devons faire "
+"la même chose de l'autre côté, en ajoutant une référence de <literal>Person</"
+"literal> à la collection dans un <literal>Event</literal>. Cette "
+"\"configuration du lien des deux côtés\" est absolument nécessaire et vous "
+"ne devriez jamais oublier de le faire. "
 
 #. Tag: para
-#: tutorial.xml:932
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Many developers program defensively and create link management methods to "
 "correctly set both sides (for example, in <literal>Person</literal>):"
 msgstr ""
 "Beaucoup de développeurs programment de manière défensive et créent des "
 "méthodes de gestion de lien pour affecter correctement les deux côtés, par "
-"exemple dans <literal>Person</literal> :"
+"exemple dans <literal>Person</literal>  :"
 
-#. Tag: programlisting
-#: tutorial.xml:937
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    protected Set getEvents() {\n"
-"        return events;\n"
-"    }\n"
-"\n"
-"    protected void setEvents(Set events) {\n"
-"        this.events = events;\n"
-"    }\n"
-"\n"
-"    public void addToEvent(Event event) {\n"
-"        this.getEvents().add(event);\n"
-"        event.getParticipants().add(this);\n"
-"    }\n"
-"\n"
-"    public void removeFromEvent(Event event) {\n"
-"        this.getEvents().remove(event);\n"
-"        event.getParticipants().remove(this);\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:939
-#, fuzzy, no-c-format
-msgid ""
 "The get and set methods for the collection are now protected. This allows "
 "classes in the same package and subclasses to still access the methods, but "
 "prevents everybody else from altering the collections directly. Repeat the "
 "steps for the collection on the other side."
 msgstr ""
 "Notez que les méthodes get et set pour la collection sont maintenant "
-"protégées - ceci permet à des classes du même paquet et aux sous-classes "
-"d'accéder encore aux méthodes, mais empêche n'importe qui d'autre de mettre "
-"le désordre directement dans les collections (enfin, presque). Vous devriez "
-"probablement faire de même avec la collection de l'autre côté."
+"protégées - ceci permet aux classes et aux sous-classes du même paquetage "
+"d'accéder aux méthodes, mais empêche quiconque de mettre le désordre "
+"directement dans les collections (enfin, presque). Vous devriez probablement "
+"faire de même avec la collection de l'autre côté. "
 
 #. Tag: para
-#: tutorial.xml:946
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What about the <literal>inverse</literal> mapping attribute? For you, and "
 "for Java, a bi-directional link is simply a matter of setting the references "
@@ -2147,32 +1522,29 @@
 "as <literal>inverse</literal>. In a one-to-many association it has to be the "
 "many-side, and in many-to-many association you can select either side."
 msgstr ""
-"Et à propos de l'attribut de mapping <literal>inverse</literal> ? Pour vous, "
-"et pour Java, un lien bidirectionnel est simplement une manière de "
-"configurer correctement les références des deux côtés. Hibernate n'a "
-"cependant pas assez d'informations pour ordonner correctement les "
-"expressions SQL <literal>INSERT</literal> et <literal>UPDATE</literal> (pour "
-"éviter les violations de contrainte), et a besoin d'aide pour gérer "
-"proprement les associations bidirectionnelles. Rendre <literal>inverse</"
-"literal> un côté d'une assocation dit à Hibernate de l'ignorer "
-"essentiellement, pour le considérer comme un <emphasis>miroir</emphasis> de "
-"l'autre côté. C'est tout ce qui est nécessaire à Hibernate pour découvrir "
-"tout des problèmes de transformation d'un modèle de navigation "
+"Et à propos de l'attribut de mappage <literal>inverse</literal> ? Pour vous, "
+"et pour Java, un lien bidirectionnel consiste simplement à configurer "
+"correctement les références des deux côtés. Hibernate n'a cependant pas "
+"assez d'informations pour ordonner correctement les expressions SQL "
+"<literal>INSERT</literal> et <literal>UPDATE</literal> (pour éviter les "
+"violations de contrainte), et a besoin d'aide pour gérer proprement les "
+"associations bidirectionnelles. Rendre <literal>inverse</literal> un côté de "
+"l'association, indique à Hibernate de l'ignorer, pour le considérer comme un "
+"<emphasis>miroir</emphasis> de l'autre côté. Cela suffit à Hibernate pour "
+"gérer tous les problèmes de transformation d'un modèle de navigation "
 "directionnelle vers un schéma SQL de base de données. Les règles dont vous "
 "devez vous souvenir sont : toutes les associations bidirectionnelles ont "
 "besoin d'un côté marqué <literal>inverse</literal>. Dans une association un-"
-"vers-plusieurs vous pouvez choisir n'importe quel côté, il n'y a pas de "
-"différence."
+"à-plusieurs ce doit être le côté plusieurs, dans une association plusieurs-à-"
+"plusieurs, vous pouvez choisir n'importe quel côté, il n'y pas de différence."
 
 #. Tag: title
-#: tutorial.xml:962
 #, no-c-format
 msgid "Part 3 - The EventManager web application"
-msgstr "Part 3 - L'application web EventManager"
+msgstr "Section 3 - L'application web EventManager"
 
 #. Tag: para
-#: tutorial.xml:964
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A Hibernate web application uses <literal>Session</literal> and "
 "<literal>Transaction</literal> almost like a standalone application. "
@@ -2181,84 +1553,39 @@
 "stored in the database, and it provides an HTML form to enter new events."
 msgstr ""
 "Une application web Hibernate utilise la <literal>Session</literal> et "
-"<literal>Transaction</literal> comme une application standalone. Cependant, "
-"quelques patterns sont utiles. Nous allons coder une "
-"<literal>EventManagerServlet</literal>. Cette servlet peut lister tous les "
+"<literal>Transaction</literal> comme une application autonome. Cependant, "
+"quelques modèles communs sont utiles. Nous allons coder une "
+"<literal>EventManagerServlet</literal>. Ce servlet peut lister tous les "
 "évènements stockés dans la base de données, et fournir une formulaire HTML "
-"pour saisir d'autres évènements."
+"pour saisir de nouveaux évènements. "
 
 #. Tag: title
-#: tutorial.xml:972
 #, no-c-format
 msgid "Writing the basic servlet"
-msgstr "Ecrire la servlet de base"
+msgstr "Écrire la servlet de base"
 
 #. Tag: para
-#: tutorial.xml:974
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First we need create our basic processing servlet. Since our servlet only "
 "handles HTTP <literal>GET</literal> requests, we will only implement the "
 "<literal>doGet()</literal> method:"
 msgstr ""
-"The servlet handles HTTP <literal>GET</literal> requests only, hence, the "
-"method we implement is <literal>doGet()</literal>:"
+"Tout d'abord, nous devons créer notre servlet de base. La servlet n'accepte "
+"que les requêtes HTTP <literal>GET</literal>, la méthode à implémenter est "
+"donc <literal>doGet()</literal> :"
 
-#. Tag: programlisting
-#: tutorial.xml:980
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.web;\n"
-"\n"
-"// Imports\n"
-"\n"
-"public class EventManagerServlet extends HttpServlet {\n"
-"\n"
-"    protected void doGet(\n"
-"            HttpServletRequest request,\n"
-"            HttpServletResponse response) throws ServletException, "
-"IOException {\n"
-"\n"
-"        SimpleDateFormat dateFormatter = new SimpleDateFormat( \"dd.MM.yyyy"
-"\" );\n"
-"\n"
-"        try {\n"
-"            // Begin unit of work\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"beginTransaction();\n"
-"\n"
-"            // Process request and render page...\n"
-"\n"
-"            // End unit of work\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"getTransaction().commit();\n"
-"        }\n"
-"        catch (Exception ex) {\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"getTransaction().rollback();\n"
-"            if ( ServletException.class.isInstance( ex ) ) {\n"
-"                throw ( ServletException ) ex;\n"
-"            }\n"
-"            else {\n"
-"                throw new ServletException( ex );\n"
-"            }\n"
-"        }\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:982
 #, no-c-format
 msgid ""
 "Save this servlet as <filename>src/main/java/org/hibernate/tutorial/web/"
 "EventManagerServlet.java</filename>"
 msgstr ""
+"Servir la servlet en tant que <filename>src/main/java/org/hibernate/tutorial/"
+"web/EventManagerServlet.java</filename>"
 
 #. Tag: para
-#: tutorial.xml:987
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The pattern applied here is called <emphasis>session-per-request</emphasis>. "
 "When a request hits the servlet, a new Hibernate <literal>Session</literal> "
@@ -2267,17 +1594,16 @@
 "started. All data access occurs inside a transaction irrespective of whether "
 "the data is read or written. Do not use the auto-commit mode in applications."
 msgstr ""
-"La pattern que nous utilisons ici est appelé <emphasis>session-per-request</"
-"emphasis>. Lorsqu'une requête touche la servlet, une nouvelle "
-"<literal>Session</literal> hibernate est ouverte à l'invocationde "
+"Le modèle appliqué ici est appelé <emphasis>session-per-request</emphasis>. "
+"Lorsqu'une requête appelle la servlet, une nouvelle <literal>Session</"
+"literal> Hibernate est ouverte à la première invocation de "
 "<literal>getCurrentSession()</literal> sur la <literal>SessionFactory</"
-"literal>. Ensuite, une transaction avec la base de données est "
-"démarrée&mdash; tous les accès à la base de données interviennent au sein de "
-"la transactiton, peu importe que les données soient lues ou écrites (nous "
-"n'utilisons pas le mode auto-commit dans les applications)."
+"literal>. Ensuite, une transaction avec la base de données est démarrée - "
+"tous les accès à la base de données interviennent au sein de la transaction, "
+"peu importe que les données soient lues ou écrites (nous n'utilisons pas le "
+"mode auto-commit dans les applications). "
 
 #. Tag: para
-#: tutorial.xml:996
 #, no-c-format
 msgid ""
 "Do <emphasis>not</emphasis> use a new Hibernate <literal>Session</literal> "
@@ -2285,25 +1611,23 @@
 "that is scoped to the whole request. Use <literal>getCurrentSession()</"
 "literal>, so that it is automatically bound to the current Java thread."
 msgstr ""
-"UNTRANSLATED Do <emphasis>not</emphasis> use a new Hibernate "
-"<literal>Session</literal> for every database operation. Use one Hibernate "
-"<literal>Session</literal> that is scoped to the whole request. Use "
-"<literal>getCurrentSession()</literal>, so that it is automatically bound to "
-"the current Java thread."
+"<emphasis>N'utilisez pas</emphasis> une nouvelle <literal>Session</literal> "
+"Hibernate pour chaque opération en base de données. Utilisez une "
+"<literal>Session</literal> Hibernate qui porte sur l'ensemble de la requête. "
+"Utlisez <literal>getCurrentSession()</literal>, ainsi elle est "
+"automatiquement attachée au thread Java courant."
 
 #. Tag: para
-#: tutorial.xml:1003
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next, the possible actions of the request are processed and the response "
 "HTML is rendered. We will get to that part soon."
 msgstr ""
 "Ensuite, les actions possibles de la requêtes sont exécutées et la réponse "
-"HTML est rendue. Nous en parlerons plus tard."
+"HTML est rendue. Nous y reviendrons ultérieurement. "
 
 #. Tag: para
-#: tutorial.xml:1008
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, the unit of work ends when processing and rendering are complete. "
 "If any problems occurred during processing or rendering, an exception will "
@@ -2316,68 +1640,29 @@
 msgstr ""
 "Enfin, l'unité de travail s'achève lorsque l'exécution et le rendu sont "
 "achevés. Si un problème survient lors de ces deux phases, une exception est "
-"soulevée et la transaction avec la base de données subit un rollback. Voila "
-"pour le pattern <literal>session-per-request</literal>. Au lieu d'un code de "
-"démarcation de transaction au sein de chaque servlet, vous pouvez écrire un "
-"filtre de servlet. Voir le site Hibernate et le Wiki pour plus d'information "
-"sur ce pattern, appelé <emphasis>Open Session in View</emphasis>&mdash; vous "
-"en aurez besoin dès que vous utiliserez des JSPs et non plus des servlets "
-"pour le rendu de vos vues."
+"lancée et la transaction avec la base de données subit un rollback. Cela "
+"complète le modèle <literal>session-per-request</literal>. Au lieu d'avoir "
+"un code de délimitant les transactions au sein de chaque servlet, vous "
+"pouvez écrire un filtre de servlet. Voir le site Hibernate et le Wiki pour "
+"plus d'informations sur ce modèle, appelé <emphasis>Open Session in View</"
+"emphasis> - vous en aurez besoin dès que vous utiliserez des JSP et non des "
+"servlets pour le rendu de vos vues. "
 
 #. Tag: title
-#: tutorial.xml:1022
 #, no-c-format
 msgid "Processing and rendering"
-msgstr "Procéder et rendre"
+msgstr "Traiter et interpréter"
 
 #. Tag: para
-#: tutorial.xml:1024
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now you can implement the processing of the request and the rendering of the "
 "page."
-msgstr "Implémentons l'exécution de la requête et le rendu de la page."
+msgstr "Implémentons l'exécution de la requête et le rendu de la page. "
 
-#. Tag: programlisting
-#: tutorial.xml:1028
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[        // Write HTML header\n"
-"        PrintWriter out = response.getWriter();\n"
-"        out.println(\"<html><head><title>Event Manager</title></head><body>"
-"\");\n"
-"\n"
-"        // Handle actions\n"
-"        if ( \"store\".equals(request.getParameter(\"action\")) ) {\n"
-"\n"
-"            String eventTitle = request.getParameter(\"eventTitle\");\n"
-"            String eventDate = request.getParameter(\"eventDate\");\n"
-"\n"
-"            if ( \"\".equals(eventTitle) || \"\".equals(eventDate) ) {\n"
-"                out.println(\"<b><i>Please enter event title and date.</i></"
-"b>\");\n"
-"            }\n"
-"            else {\n"
-"                createAndStoreEvent(eventTitle, dateFormatter.parse"
-"(eventDate));\n"
-"                out.println(\"<b><i>Added event.</i></b>\");\n"
-"            }\n"
-"        }\n"
-"\n"
-"        // Print page\n"
-"       printEventForm(out);\n"
-"       listEvents(out, dateFormatter);\n"
-"\n"
-"       // Write HTML footer\n"
-"       out.println(\"</body></html>\");\n"
-"       out.flush();\n"
-"       out.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:1030
-#, fuzzy, no-c-format
-msgid ""
 "This coding style, with a mix of Java and HTML, would not scale in a more "
 "complex application&mdash;keep in mind that we are only illustrating basic "
 "Hibernate concepts in this tutorial. The code prints an HTML header and a "
@@ -2385,102 +1670,37 @@
 "events in the database are printed. The first method is trivial and only "
 "outputs HTML:"
 msgstr ""
-"Ce style de code avec un mix de Java et d'HTML ne serait pas scalable dans "
-"une application plus complexe&mdash;gardez à l'esprit que nous ne faisons "
-"qu'illustrer les concepts basiques d'Hibernate dans ce tutoriel. Ce code "
-"affiche une en tête et un pied de page HTML. Dans cette page, sont affichés "
+"Ce style de code avec une mixture de Java et d'HTML ne serait pas extensible "
+"dans une application plus complexe - gardez à l'esprit que nous ne faisons "
+"qu'illustrer les concepts basiques de Hibernate dans ce didacticiel. Ce code "
+"affiche une entête et un pied de page HTML. Dans cette page, sont affichés "
 "un formulaire pour la saisie d'évènements ainsi qu'une liste de tous les "
-"évènements de la base de données. La première méthode est triviale est ne "
-"fait que sortir de l'HTML:"
+"évènements de la base de données. La première méthode est triviale et ne "
+"fait que sortir de l'HTML :"
 
-#. Tag: programlisting
-#: tutorial.xml:1039
-#, no-c-format
-msgid ""
-"<![CDATA[    private void printEventForm(PrintWriter out) {\n"
-"        out.println(\"<h2>Add new event:</h2>\");\n"
-"        out.println(\"<form>\");\n"
-"        out.println(\"Title: <input name='eventTitle' length='50'/><br/>"
-"\");\n"
-"        out.println(\"Date (e.g. 24.12.2009): <input name='eventDate' "
-"length='10'/><br/>\");\n"
-"        out.println(\"<input type='submit' name='action' value='store'/>"
-"\");\n"
-"        out.println(\"</form>\");\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1041
 #, no-c-format
 msgid ""
 "The <literal>listEvents()</literal> method uses the Hibernate "
 "<literal>Session</literal> bound to the current thread to execute a query:"
 msgstr ""
 "La méthode <literal>listEvents()</literal> utilise la <literal>Session</"
-"literal> Hibernate liée au thread courant pour exécuter la requête:"
+"literal> Hibernate liée au thread courant pour exécuter la requête :"
 
-#. Tag: programlisting
-#: tutorial.xml:1047
-#, no-c-format
-msgid ""
-"<![CDATA[    private void listEvents(PrintWriter out, SimpleDateFormat "
-"dateFormatter) {\n"
-"\n"
-"        List result = HibernateUtil.getSessionFactory()\n"
-"                .getCurrentSession().createCriteria(Event.class).list();\n"
-"        if (result.size() > 0) {\n"
-"            out.println(\"<h2>Events in database:</h2>\");\n"
-"            out.println(\"<table border='1'>\");\n"
-"            out.println(\"<tr>\");\n"
-"            out.println(\"<th>Event title</th>\");\n"
-"            out.println(\"<th>Event date</th>\");\n"
-"            out.println(\"</tr>\");\n"
-"            Iterator it = result.iterator();\n"
-"            while (it.hasNext()) {\n"
-"                Event event = (Event) it.next();\n"
-"                out.println(\"<tr>\");\n"
-"                out.println(\"<td>\" + event.getTitle() + \"</td>\");\n"
-"                out.println(\"<td>\" + dateFormatter.format(event.getDate()) "
-"+ \"</td>\");\n"
-"                out.println(\"</tr>\");\n"
-"            }\n"
-"            out.println(\"</table>\");\n"
-"        }\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1049
 #, no-c-format
 msgid ""
 "Finally, the <literal>store</literal> action is dispatched to the "
 "<literal>createAndStoreEvent()</literal> method, which also uses the "
 "<literal>Session</literal> of the current thread:"
 msgstr ""
-"FEnfin, l'action <literal>store</literal> renvoie à la méthode "
+"Enfin, l'action <literal>store</literal> renvoie à la méthode "
 "<literal>createAndStoreEvent()</literal>, qui utilise aussi la "
 "<literal>Session</literal> du thread courant:"
 
-#. Tag: programlisting
-#: tutorial.xml:1055
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    protected void createAndStoreEvent(String title, Date theDate) "
-"{\n"
-"        Event theEvent = new Event();\n"
-"        theEvent.setTitle(title);\n"
-"        theEvent.setDate(theDate);\n"
-"\n"
-"        HibernateUtil.getSessionFactory()\n"
-"                .getCurrentSession().save(theEvent);\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:1057
-#, fuzzy, no-c-format
-msgid ""
 "The servlet is now complete. A request to the servlet will be processed in a "
 "single <literal>Session</literal> and <literal>Transaction</literal>. As "
 "earlier in the standalone application, Hibernate can automatically bind "
@@ -2490,80 +1710,54 @@
 "data access code into data access objects (the DAO pattern). See the "
 "Hibernate Wiki for more examples."
 msgstr ""
-"La servlet est faite. Une requête à la servlet sera exécutée par une seule "
-"<literal>Session</literal> et <literal>Transaction</literal>. Comme pour une "
-"application standalone, Hibernate peut automatiquement lier ces objets au "
-"thread courant d'exécution. Cela vous laisse la liberté de séparer votre "
-"code en couches et d'accéder à la <literal>SessionFactory</literal> par le "
-"moyen que vous voulez. Généralement, vous utiliserez des conceptions plus "
-"sophistiquées et déplacerez le code d'accès aux données dans une couche DAO. "
-"Voir le wiki Hibernate pour plus d'exemples."
+"La servlet est complétée. Une requête à la servlet sera exécutée par une "
+"seule <literal>Session</literal> et <literal>Transaction</literal>. Comme "
+"dans l'application autonome vue auparavant, Hibernate peut automatiquement "
+"lier ces objets au thread courant d'exécution. Cela vous laisse la liberté "
+"de séparer votre code en couches et d'accéder à la <literal>SessionFactory</"
+"literal> selon le moyen que vous aurez choisi. Généralement, vous utiliserez "
+"des conceptions plus sophistiquées et déplacerez le code d'accès aux données "
+"dans une couche DAO. Consultez le wiki Hibernate pour plus d'exemples. "
 
 #. Tag: title
-#: tutorial.xml:1071
 #, no-c-format
 msgid "Deploying and testing"
 msgstr "Déployer et tester"
 
 #. Tag: para
-#: tutorial.xml:1073
 #, no-c-format
 msgid ""
 "To deploy this application for testing we must create a Web ARchive (WAR). "
 "First we must define the WAR descriptor as <filename>src/main/webapp/WEB-INF/"
 "web.xml</filename>"
 msgstr ""
+"Pour déployer cette application en vue de procéder à des tests, nous devons "
+"créer un WAR (Web ARchive). Tout d'abord, nous devons définir le descripteur "
+"WAR en tant que <filename>src/main/webapp/WEB-INF/web.xml</filename>"
 
-#. Tag: programlisting
-#: tutorial.xml:1079
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
-"<web-app version=\"2.4\"\n"
-"    xmlns=\"http://java.sun.com/xml/ns/j2ee\"\n"
-"    xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
-"    xsi:schemaLocation=\"http://java.sun.com/xml/ns/j2ee http://java.sun.com/"
-"xml/ns/j2ee/web-app_2_4.xsd\">\n"
-"\n"
-"    <servlet>\n"
-"        <servlet-name>Event Manager</servlet-name>\n"
-"        <servlet-class>org.hibernate.tutorial.web.EventManagerServlet</"
-"servlet-class>\n"
-"    </servlet>\n"
-"\n"
-"    <servlet-mapping>\n"
-"        <servlet-name>Event Manager</servlet-name>\n"
-"        <url-pattern>/eventmanager</url-pattern>\n"
-"    </servlet-mapping>\n"
-"</web-app>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:1081
-#, fuzzy, no-c-format
-msgid ""
 "To build and deploy call <literal>mvn package</literal> in your project "
 "directory and copy the <filename>hibernate-tutorial.war</filename> file into "
 "your Tomcat <filename>webapps</filename> directory."
 msgstr ""
 "Pour construire et déployer, appelez <literal>ant war</literal> dans votre "
-"projet et copier le fichier <literal>hibernate-tutorial.war</literal> dans "
-"le répertoire <literal>webapp</literal> de tomcat Si vous n'avez pas "
-"installé Tomcat, téléchargez le et suivez la notice d'installation. Vous "
-"n'avez pas à modifier la configuration Tomcat pour déployer cette "
-"application."
+"projet et copiez le fichier <literal>hibernate-tutorial.war</literal> dans "
+"le répertoire <literal>webapp</literal> de Tomcat. "
 
 #. Tag: para
-#: tutorial.xml:1088
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "If you do not have Tomcat installed, download it from <ulink url=\"http://"
-"tomcat.apache.org/\"></ulink> and follow the installation instructions. Our "
+"tomcat.apache.org/\" /> and follow the installation instructions. Our "
 "application requires no changes to the standard Tomcat configuration."
 msgstr ""
+"Si vous n'avez pas installé Tomcat, téléchargez-le de <ulink url=\"http://"
+"tomcat.apache.org/\" /> et suivez la notice d'installation. Vous n'avez pas "
+"à modifier la configuration Tomcat pour déployer cette application."
 
 #. Tag: para
-#: tutorial.xml:1096
 #, no-c-format
 msgid ""
 "Once deployed and Tomcat is running, access the application at "
@@ -2575,433 +1769,24 @@
 msgstr ""
 "Une fois l'application déployée et Tomcat lancé, accédez à l'application via "
 "<literal>http://localhost:8080/hibernate-tutorial/eventmanager</literal>. "
-"Assurez vous de consulter les traces tomcat pour observer l'initialisation "
+"Assurez vous de consulter les traces Tomcat pour observer l'initialisation "
 "d'Hibernate à la première requête touchant votre servlet (l'initialisation "
 "statique dans <literal>HibernateUtil</literal> est invoquée) et pour "
 "vérifier qu'aucune exception ne survienne."
 
 #. Tag: title
-#: tutorial.xml:1109
 #, no-c-format
 msgid "Summary"
 msgstr "Résumé"
 
 #. Tag: para
-#: tutorial.xml:1111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This tutorial covered the basics of writing a simple standalone Hibernate "
 "application and a small web application. More tutorials are available from "
 "the Hibernate <ulink url=\"http://hibernate.org\">website</ulink>."
 msgstr ""
 "Ce didacticiel a couvert les bases de l'écriture d'une simple application "
-"Hibernate ainsi qu'une petite application web."
-
-#~ msgid "Introduction to Hibernate"
-#~ msgstr "Introduction à Hibernate"
-
-#~ msgid "Preface"
-#~ msgstr "Préface"
-
-#~ msgid ""
-#~ "Our first persistent class is a simple JavaBean class with some "
-#~ "properties:"
-#~ msgstr ""
-#~ "Notre première classe persistante est une simple classe JavaBean avec "
-#~ "quelques propriétés :"
-
-#~ msgid ""
-#~ "Place this Java source file in a directory called <literal>src</literal> "
-#~ "in the development folder, and in its correct package. The directory "
-#~ "should now look like this:"
-#~ msgstr ""
-#~ "Placez ce fichier source Java dans un répertoire appelé <literal>src</"
-#~ "literal> dans le dossier de développement. Ce répertoire devrait "
-#~ "maintenant ressembler à ça :"
-
-#~ msgid "In the next step, we tell Hibernate about this persistent class."
-#~ msgstr ""
-#~ "Dans la prochaine étape, nous informons Hibernate de cette classe "
-#~ "persistante."
-
-#, fuzzy
-#~ msgid ""
-#~ "The <literal>id</literal> element is the declaration of the identifier "
-#~ "property, <literal>name=\"id\"</literal> declares the name of the Java "
-#~ "property - Hibernate will use the getter and setter methods to access the "
-#~ "property. The column attribute tells Hibernate which column of the "
-#~ "<literal>EVENTS</literal> table we use for this primary key. The nested "
-#~ "<literal>generator</literal> element specifies the identifier generation "
-#~ "strategy, in this case we used <literal>native</literal>, which picks the "
-#~ "best strategy depending on the configured database (dialect). Hibernate "
-#~ "supports database generated, globally unique, as well as application "
-#~ "assigned identifiers (or any strategy you have written an extension for)."
-#~ msgstr ""
-#~ "L'élément <literal>id</literal> est la déclaration de la propriété de "
-#~ "l'identifiant, <literal>name=\"id\"</literal> déclare le nom de la "
-#~ "propriété Java - Hibernate utilisera les méthodes getter et setter pour "
-#~ "accéder à la propriété. L'attribut <literal>column</literal> indique à "
-#~ "Hibernate quelle colonne de la table <literal>EVENTS</literal> nous "
-#~ "utilisons pour cette clef primaire. L'élément <literal>generator</"
-#~ "literal> imbriqué spécifie la stratégie de génération de l'identifiant, "
-#~ "dans ce cas nous avons utilisé <literal>increment</literal>, laquelle est "
-#~ "une méthode très simple utile surtout pour les tests (et didacticiels). "
-#~ "Hibernate supporte aussi les identifiants générés par les bases de "
-#~ "données, globalement uniques, ainsi que les identifiants assignés par "
-#~ "l'application (ou n'importe quelle stratégie que vous avez écrit en "
-#~ "extension)."
-
-#~ msgid ""
-#~ "This mapping file should be saved as <literal>Event.hbm.xml</literal>, "
-#~ "right in the directory next to the <literal>Event</literal> Java class "
-#~ "source file. The naming of mapping files can be arbitrary, however the "
-#~ "<literal>hbm.xml</literal> suffix is a convention in the Hibernate "
-#~ "developer community. The directory structure should now look like this:"
-#~ msgstr ""
-#~ "Ce fichier de mapping devrait être sauvegardé en tant que <literal>Event."
-#~ "hbm.xml</literal>, juste dans le répertoire à côté du fichier source de "
-#~ "la classe Java <literal>Event</literal>. Le nommage des fichiers de "
-#~ "mapping peut être arbitraire, cependant le suffixe <literal>hbm.xml</"
-#~ "literal> est devenu une convention dans la communauté des développeurs "
-#~ "Hibernate. La structure du répertoire devrait ressembler à ça :"
-
-#~ msgid "We continue with the main configuration of Hibernate."
-#~ msgstr "Nous poursuivons avec la configuration principale d'Hibernate."
-
-#~ msgid ""
-#~ "We now have a persistent class and its mapping file in place. It is time "
-#~ "to configure Hibernate. Before we do this, we will need a database. HSQL "
-#~ "DB, a java-based SQL DBMS, can be downloaded from the HSQL DB website"
-#~ "(http://hsqldb.org/). Actually, you only need the <literal>hsqldb.jar</"
-#~ "literal> from this download. Place this file in the <literal>lib/</"
-#~ "literal> directory of the development folder."
-#~ msgstr ""
-#~ "Nous avons maintenant une classe persistante et son fichier de mapping. "
-#~ "Il est temps de configurer Hibernate. Avant ça, nous avons besoin d'une "
-#~ "base de données. HSQL DB, un SGBD SQL basé sur Java et travaillant en "
-#~ "mémoire, peut être téléchargé à partir du site web de HSQL. En fait, vous "
-#~ "avez seulement besoin de <literal>hsqldb.jar</literal>. Placez ce fichier "
-#~ "dans le répertoire <literal>lib/</literal> du dossier de développement."
-
-#~ msgid ""
-#~ "Hibernate is the layer in your application which connects to this "
-#~ "database, so it needs connection information. The connections are made "
-#~ "through a JDBC connection pool, which we also have to configure. The "
-#~ "Hibernate distribution contains several open source JDBC connection "
-#~ "pooling tools, but will use the Hibernate built-in connection pool for "
-#~ "this tutorial. Note that you have to copy the required library into your "
-#~ "classpath and use different connection pooling settings if you want to "
-#~ "use a production-quality third party JDBC pooling software."
-#~ msgstr ""
-#~ "Hibernate est la couche de votre application qui se connecte à cette base "
-#~ "de données, donc il a besoin des informations de connexion. Les "
-#~ "connexions sont établies à travers un pool de connexions JDBC, que nous "
-#~ "devons aussi configurer. La distribution Hibernate contient différents "
-#~ "outils de gestion de pools de connexions JDBC open source, mais pour ce "
-#~ "didacticiel nous utiliserons le pool de connexions intégré à Hibernate. "
-#~ "Notez que vous devez copier les bibliothèques requises dans votre "
-#~ "classpath et utiliser une configuration de pool de connexions différente "
-#~ "si vous voulez utiliser un logiciel de gestion de pools JDBC tiers avec "
-#~ "une qualité de production."
-
-#~ msgid ""
-#~ "Copy this file into the source directory, so it will end up in the root "
-#~ "of the classpath. Hibernate automatically looks for a file called "
-#~ "<literal>hibernate.cfg.xml</literal> in the root of the classpath, on "
-#~ "startup."
-#~ msgstr ""
-#~ "Copiez ce fichier dans le répertoire source, il terminera dans la racine "
-#~ "du classpath. Hibernate cherchera automatiquement, au démarrage, un "
-#~ "fichier appelé <literal>hibernate.cfg.xml</literal> dans la racine du "
-#~ "classpath."
-
-#~ msgid ""
-#~ "We'll now build the tutorial with Ant. You will need to have Ant "
-#~ "installed - get it from the <ulink url=\"http://ant.apache.org/"
-#~ "bindownload.cgi\">Ant download page</ulink>. How to install Ant will not "
-#~ "be covered here. Please refer to the <ulink url=\"http://ant.apache.org/"
-#~ "manual/index.html\">Ant manual</ulink>. After you have installed Ant, we "
-#~ "can start to create the buildfile. It will be called <literal>build.xml</"
-#~ "literal> and placed directly in the development directory."
-#~ msgstr ""
-#~ "Nous allons maintenant construire le didacticiel avec Ant. Vous aurez "
-#~ "besoin d'avoir Ant d'installé - récupérez-le à partir de <ulink url="
-#~ "\"http://ant.apache.org/bindownload.cgi\"> la page de téléchargement de "
-#~ "Ant</ulink>. Comment installer Ant ne sera pas couvert ici. Référez-vous "
-#~ "au <ulink url=\"http://ant.apache.org/manual/index.html\">manuel d'Ant</"
-#~ "ulink>. Après que vous aurez installé Ant, nous pourrons commencer à "
-#~ "créer le fichier de construction. Il s'appellera <literal>build.xml</"
-#~ "literal> et sera placé directement dans le répertoire de développement."
-
-#~ msgid "A basic build file looks like this:"
-#~ msgstr "Un fichier de construction basique ressemble à ça :"
-
-#~ msgid ""
-#~ "This will tell Ant to add all files in the lib directory ending with "
-#~ "<literal>.jar</literal> to the classpath used for compilation. It will "
-#~ "also copy all non-Java source files to the target directory, e.g. "
-#~ "configuration and Hibernate mapping files. If you now run Ant, you should "
-#~ "get this output:"
-#~ msgstr ""
-#~ "Cela dira à Ant d'ajouter tous les fichiers du répertoire lib finissant "
-#~ "par <literal>.jar</literal> dans le classpath utilisé pour la "
-#~ "compilation. Cela copiera aussi tous les fichiers source non Java dans le "
-#~ "répertoire cible, par exemple les fichiers de configuration et de mapping "
-#~ "d'Hibernate. Si vous lancez Ant maintenant, vous devriez obtenir cette "
-#~ "sortie :"
-
-#~ msgid ""
-#~ "Place <literal>HibernateUtil.java</literal> in the development source "
-#~ "directory, in a package next to <literal>events</literal>:"
-#~ msgstr ""
-#~ "Placez <literal>HibernateUtil.java</literal> dans le répertoire source de "
-#~ "développement, et ensuite <literal>Event.java</literal> :"
-
-#~ msgid ""
-#~ "To run this first routine we have to add a callable target to the Ant "
-#~ "build file:"
-#~ msgstr ""
-#~ "Pour lancer cette première routine, nous devons ajouter une cible "
-#~ "appelable dans le fichier de construction de Ant :"
-
-#~ msgid ""
-#~ "The value of the <literal>action</literal> argument is set on the command "
-#~ "line when calling the target:"
-#~ msgstr ""
-#~ "La valeur de l'argument <literal>action</literal> correspond à la ligne "
-#~ "de commande qui appelle la cible :"
-
-#~ msgid ""
-#~ "This is the <literal>INSERT</literal> executed by Hibernate, the question "
-#~ "marks represent JDBC bind parameters. To see the values bound as "
-#~ "arguments, or to reduce the verbosity of the log, check your "
-#~ "<literal>log4j.properties</literal>."
-#~ msgstr ""
-#~ "C'est l'<literal>INSERT</literal> exécuté par Hibernate, les points "
-#~ "d'interrogation représentent les paramètres JDBC liés. Pour voir les "
-#~ "valeurs liées aux arguments, ou pour réduire la verbosité des traces, "
-#~ "vérifier votre <literal>log4j.properties</literal>."
-
-#~ msgid "Now, to execute and test all of this, follow these steps:"
-#~ msgstr "Maintenant, pour exécuter et tester tout ça, suivez ces étapes :"
-
-#~ msgid ""
-#~ "Run <literal>ant run -Daction=store</literal> to store something into the "
-#~ "database and, of course, to generate the database schema before through "
-#~ "hbm2ddl."
-#~ msgstr ""
-#~ "Exécutez <literal>ant run -Daction=store</literal> pour stocker quelque "
-#~ "chose dans la base de données et, bien sûr, pour générer, avant, le "
-#~ "schéma de la base de données grâce à hbm2ddl."
-
-#, fuzzy
-#~ msgid ""
-#~ "Now disable hbm2ddl by commenting out the property in your "
-#~ "<literal>hibernate.cfg.xml</literal> file. Usually you only leave it "
-#~ "turned on in continuous unit testing, but another run of hbm2ddl would "
-#~ "<emphasis>drop</emphasis> everything you have stored - the "
-#~ "<literal>create</literal> configuration setting actually translates into "
-#~ "\"drop all tables from the schema, then re-create all tables, when the "
-#~ "SessionFactory is build\"."
-#~ msgstr ""
-#~ "Maintenant désactivez hbm2ddl en commentant la propriété dans votre "
-#~ "fichier <literal>hibernate.cfg.xml</literal>. Généralement vous la "
-#~ "laissez seulement activée dans des tests unitaires en continu, mais une "
-#~ "autre exécution de hbm2ddl <emphasis>effacerait</emphasis> tout ce que "
-#~ "vous avez stocké - le paramètre de configuration <literal>create</"
-#~ "literal> se traduit en fait par \"supprimer toutes les tables du schéma, "
-#~ "puis re-créer toutes les tables, lorsque la SessionFactory est construite"
-#~ "\"."
-
-#~ msgid ""
-#~ "If you now call Ant with <literal>-Daction=list</literal>, you should see "
-#~ "the events you have stored so far. You can of course also call the "
-#~ "<literal>store</literal> action a few times more."
-#~ msgstr ""
-#~ "Si maintenant vous appelez Ant avec <literal>-Daction=list</literal>, "
-#~ "vous devriez voir les événements que vous avez stockés jusque là. Vous "
-#~ "pouvez bien sûr aussi appeler l'action <literal>store</literal> plusieurs "
-#~ "fois."
-
-#~ msgid ""
-#~ "Note: Most new Hibernate users fail at this point and we see questions "
-#~ "about <emphasis>Table not found</emphasis> error messages regularly. "
-#~ "However, if you follow the steps outlined above you will not have this "
-#~ "problem, as hbm2ddl creates the database schema on the first run, and "
-#~ "subsequent application restarts will use this schema. If you change the "
-#~ "mapping and/or database schema, you have to re-enable hbm2ddl once again."
-#~ msgstr ""
-#~ "UNTRANSLATED! Note: Most new Hibernate users fail at this point and we "
-#~ "see questions about <emphasis>Table not found</emphasis> error messages "
-#~ "regularly. However, if you follow the steps outlined above you will not "
-#~ "have this problem, as hbm2ddl creates the database schema on the first "
-#~ "run, and subsequent application restarts will use this schema. If you "
-#~ "change the mapping and/or database schema, you have to re-enable hbm2ddl "
-#~ "once again."
-
-#~ msgid ""
-#~ "Create a new mapping file called <literal>Person.hbm.xml</literal> (don't "
-#~ "forget the DTD reference at the top):"
-#~ msgstr ""
-#~ "Créez un nouveau fichier de mapping appelé <literal>Person.hbm.xml</"
-#~ "literal> (n'oubliez pas la référence à la DTD)"
-
-#~ msgid ""
-#~ "We need a unidirectional, many-valued associations, implemented with a "
-#~ "<literal>Set</literal>. Let's write the code for this in the Java classes "
-#~ "and then map it:"
-#~ msgstr ""
-#~ "Nous avons besoin d'une association unidirectionnelle, pluri-valuée, "
-#~ "implémentée avec un <literal>Set</literal>. Écrivons le code pour ça dans "
-#~ "les classes Java et mappons les :"
-
-#~ msgid ""
-#~ "We add a collection of value typed objects to the <literal>Person</"
-#~ "literal> entity. We want to store email addresses, so the type we use is "
-#~ "<literal>String</literal>, and the collection is again a <literal>Set</"
-#~ "literal>:"
-#~ msgstr ""
-#~ "Nous ajoutons une collection d'objets de type de valeur à l'entité "
-#~ "<literal>Person</literal>. Nous voulons stocker des adresses email, donc "
-#~ "le type que nous utilisons est <literal>String</literal>, et la "
-#~ "collection est encore un <literal>Set</literal> :"
-
-#, fuzzy
-#~ msgid "Let's turn the following discussion into a small web application..."
-#~ msgstr "Let's turn this into a small web application."
-
-#~ msgid ""
-#~ "Create a new class in your source directory, in the <literal>events</"
-#~ "literal> package:"
-#~ msgstr ""
-#~ "Créons une nouvelle classe dans notre répertoire source, dans le package "
-#~ "<literal>events</literal>:"
-
-#~ msgid ""
-#~ "To deploy this application you have to create a web archive, a WAR. Add "
-#~ "the following Ant target to your <literal>build.xml</literal>:"
-#~ msgstr ""
-#~ "Pour déployer cette application, vous devez créer une archive Web, un "
-#~ "War. Ajoutez la cible Ant suivante dans votre <literal>build.xml</"
-#~ "literal>:"
-
-#~ msgid ""
-#~ "This target creates a file called <literal>hibernate-tutorial.war</"
-#~ "literal> in your project directory. It packages all libraries and the "
-#~ "<literal>web.xml</literal> descriptor, which is expected in the base "
-#~ "directory of your project:"
-#~ msgstr ""
-#~ "Cette cible créé un fichier nommé <literal>hibernate-tutorial.war</"
-#~ "literal> dans le répertoire de votre projet. Elle package les "
-#~ "bibliothèques et le descripteur <literal>web.xml</literal> qui est "
-#~ "attendu dans le répertoire racine de votre projet:"
-
-#, fuzzy
-#~ msgid ""
-#~ "Before you compile and deploy the web application, note that an "
-#~ "additional library is required: <literal>jsdk.jar</literal>. This is the "
-#~ "Java servlet development kit, if you don't have this library already, get "
-#~ "it from the Sun website and copy it to your library directory. However, "
-#~ "it will be only used for compilation and excluded from the WAR package."
-#~ msgstr ""
-#~ "Avant de compiler et déployer l'application web, notez qu'une "
-#~ "bibliothèque supplémentaire est requise: <literal>servlet.jar</literal>. "
-#~ "C'est le kit de développement de Servlet Java, si vous ne disposez pas de "
-#~ "cette bibliothèque, prenez la sur le <ulink url=\"http://java.sun.com/"
-#~ "products/servlet/archive.html\">site de Sun</ulink> et copiez la dans "
-#~ "votre répertoire des bibliothèques. Cependant, elle ne sera utilisée "
-#~ "uniquement pour la compilation et sera exclue du paackage WAR."
-
-#~ msgid ""
-#~ "If you already feel confident with Hibernate, continue browsing through "
-#~ "the reference documentation table of contents for topics you find "
-#~ "interesting - most asked are transactional processing (<xref linkend="
-#~ "\"transactions\"/>), fetch performance (<xref linkend=\"performance\"/>), "
-#~ "or the usage of the API (<xref linkend=\"objectstate\"/>) and the query "
-#~ "features (<xref linkend=\"objectstate-querying\"/>)."
-#~ msgstr ""
-#~ "Si vous êtes déjà confiants avec Hibernate, continuez à parcourir les "
-#~ "sujets que vous trouvez intéressants à travers la table des matières de "
-#~ "la documentation de référence - les plus demandés sont le traitement "
-#~ "transactionnel (<xref linkend=\"transactions\"/>), la performance des "
-#~ "récupérations d'information (<xref linkend=\"performance\"/>), ou "
-#~ "l'utilisation de l'API (<xref linkend=\"objectstate\"/>) et les "
-#~ "fonctionnalités des requêtes (<xref linkend=\"objectstate-querying\"/>)."
-
-#~ msgid ""
-#~ "Don't forget to check the Hibernate website for more (specialized) "
-#~ "tutorials."
-#~ msgstr ""
-#~ "N'oubliez pas de vérifier le site web d'Hibernate pour d'autres "
-#~ "didacticiels (plus spécialisés)."
-
-#~ msgid ""
-#~ "This chapter is an introductory tutorial for new users of Hibernate. We "
-#~ "start with a simple command line application using an in-memory database "
-#~ "and develop it in easy to understand steps."
-#~ msgstr ""
-#~ "Ce chapitre est un didacticiel introductif destiné aux nouveaux "
-#~ "utilisateurs d'Hibernate. Nous commençons avec une simple application en "
-#~ "ligne de commande utilisant une base de données en mémoire, et la "
-#~ "développons en étapes faciles à comprendre."
-
-#~ msgid ""
-#~ "This tutorial is intended for new users of Hibernate but requires Java "
-#~ "and SQL knowledge. It is based on a tutorial by Michael Gloegl, the third-"
-#~ "party libraries we name are for JDK 1.4 and 5.0. You might need others "
-#~ "for JDK 1.3."
-#~ msgstr ""
-#~ "Ce didacticiel est destiné aux nouveaux utilisateurs d'Hibernate mais "
-#~ "requiert des connaissances Java et SQL. Il est basé sur un didacticiel de "
-#~ "Michael Gloegl, les bibliothèques tierces que nous nommons sont pour les "
-#~ "JDK 1.4 et 5.0. Vous pourriez avoir besoin d'autres bibliothèques pour le "
-#~ "JDK 1.3."
-
-#~ msgid ""
-#~ "The source code for the tutorial is included in the distribution in the "
-#~ "<literal>doc/reference/tutorial/</literal> directory."
-#~ msgstr ""
-#~ "Le code source de ce tutoriel est inclus dans la distribution dans le "
-#~ "répertoire <literal>doc/reference/tutorial/</literal>."
-
-#~ msgid ""
-#~ "First, we'll create a simple console-based Hibernate application. We use "
-#~ "an Java database (HSQL DB), so we do not have to install any database "
-#~ "server."
-#~ msgstr ""
-#~ "D'abord, nous créerons une simple application Hibernate en console. Nous "
-#~ "utilisons une base de données en mémoire (HSQL DB), donc nous n'avons pas "
-#~ "à installer de serveur de base de données."
-
-#~ msgid ""
-#~ "The first thing we do, is set up our development directory and put all "
-#~ "the Java libraries we need into it. Download the Hibernate distribution "
-#~ "from the Hibernate website. Extract the package and place all required "
-#~ "libraries found in <literal>/lib</literal> into into the <literal>/lib</"
-#~ "literal> directory of your new development working directory. It should "
-#~ "look like this:"
-#~ msgstr ""
-#~ "La première chose que nous faisons est de configurer notre répertoire de "
-#~ "développement et de mettre toutes les bibliothèques dont nous avons "
-#~ "besoin dedans. Téléchargez la distribution Hibernate à partir du site web "
-#~ "d'Hibernate. Extrayez le paquet et placez toutes les bibliothèques "
-#~ "requises trouvées dans <literal>/lib</literal> dans le répertoire "
-#~ "<literal>/lib</literal> de votre nouveau répertoire de travail. Il "
-#~ "devrait ressembler à ça :"
-
-#~ msgid ""
-#~ "This is the minimum set of required libraries (note that we also copied "
-#~ "hibernate3.jar, the main archive) for Hibernate <emphasis>at the time of "
-#~ "writing</emphasis>. The Hibernate release you are using might require "
-#~ "more or less libraries. See the <literal>README.txt</literal> file in the "
-#~ "<literal>lib/</literal> directory of the Hibernate distribution for more "
-#~ "information about required and optional third-party libraries. (Actually, "
-#~ "Log4j is not required but preferred by many developers.)"
-#~ msgstr ""
-#~ "Ceci est l'ensemble minimum de bibliothèques requises (notez que nous "
-#~ "avons aussi copié hibernate3.jar, l'archive principale) pour Hibernate. "
-#~ "Lisez le fichier <literal>README.txt</literal> dans le répertoire "
-#~ "<literal>lib/</literal> de la distribution Hibernate pour plus "
-#~ "d'informations à propos des biliothèques tierces requises et "
-#~ "optionnelles. (En fait, log4j n'est pas requis mais préféré par beaucoup "
-#~ "de développeurs.)"
+"Hibernate ainsi qu'une petite application web. Vous trouverez des tutoriels "
+"supplémentaires dans le site Hibernate <ulink url=\"http://hibernate.org"
+"\">website</ulink>."

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/content/xml.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/content/xml.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/content/xml.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,40 +1,42 @@
+# translation of xml.po to French
+# Myriam Malga <mmalga at redhat.com>, 2007.
+# Xi HUANG <xhuang at redhat.com>, 2007.
+# Corina Roe <croe at redhat.com>, 2009, 2010.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: xml\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2010-01-05 10:08+1000\n"
+"Last-Translator: Corina Roe <croe at redhat.com>\n"
+"Language-Team: French <i18 at redhat.com>\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
-#: xml.xml:29
 #, no-c-format
 msgid "XML Mapping"
-msgstr "Mapping XML"
+msgstr "Mappage XML"
 
-#. Tag: emphasis
-#: xml.xml:31
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
-"XML Mapping is an experimental feature in Hibernate 3.0 and is currently "
-"under active development."
+"<emphasis> XML Mapping is an experimental feature in Hibernate 3.0 and is "
+"currently under active development. </emphasis>"
 msgstr ""
-"Notez que cette fonctionnalité est expérimentale dans Hibernate 3.0 et est "
-"en développement extrêmement actif."
+"<emphasis>Notez que cette fonctionnalité est expérimentale dans Hibernate "
+"3.0 et est en développement extrêmement actif. </emphasis>"
 
 #. Tag: title
-#: xml.xml:37
 #, no-c-format
 msgid "Working with XML data"
 msgstr "Travailler avec des données XML"
 
 #. Tag: para
-#: xml.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate allows you to work with persistent XML data in much the same way "
 "you work with persistent POJOs. A parsed XML tree can be thought of as "
@@ -42,12 +44,11 @@
 "of POJOs."
 msgstr ""
 "Hibernate vous laisse travailler avec des données XML persistantes de la "
-"même manière que vous travaillez avec des POJOs persistants. Un arbre XML "
+"même manière que vous travaillez avec des POJO persistants. Un arbre XML "
 "peut être vu comme une autre manière de représenter les données "
-"relationnelles au niveau objet, à la place des POJOs."
+"relationnelles au niveau objet, à la place des POJO. "
 
 #. Tag: para
-#: xml.xml:46
 #, no-c-format
 msgid ""
 "Hibernate supports dom4j as API for manipulating XML trees. You can write "
@@ -59,181 +60,113 @@
 "yet supported)."
 msgstr ""
 "Hibernate supporte dom4j en tant qu'API pour la manipulation des arbres XML. "
-"Vous pouvez écrire des requêtes qui récupèrent des arbres dom4j à partie de "
+"Vous pouvez écrire des requêtes qui récupèrent des arbres dom4j à partir de "
 "la base de données, et avoir toutes les modifications que vous faites sur "
 "l'arbre automatiquement synchronisées dans la base de données. Vous pouvez "
 "même prendre un document XML, l'analyser en utilisant dom4j, et l'écrire "
-"dans la base de données via les opérations basiques d'Hibernate : "
+"dans la base de données via les opérations basiques de Hibernate : "
 "<literal>persist(), saveOrUpdate(), merge(), delete(), replicate()</literal> "
-"(merge() n'est pas encore supporté)."
+"(merge n'est pas encore supporté)."
 
 #. Tag: para
-#: xml.xml:56
 #, no-c-format
 msgid ""
 "This feature has many applications including data import/export, "
 "externalization of entity data via JMS or SOAP and XSLT-based reporting."
 msgstr ""
 "Cette fonctionnalité a plusieurs applications dont l'import/export de "
-"données, l'externalisation d'entités via JMS ou SOAP et les rapports XSLT."
+"données, l'externalisation de données d'entités via JMS ou SOAP et les "
+"rapports XSLT."
 
 #. Tag: para
-#: xml.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A single mapping can be used to simultaneously map properties of a class and "
 "nodes of an XML document to the database, or, if there is no class to map, "
 "it can be used to map just the XML."
 msgstr ""
-"Un simple mapping peut être utilisé pour simultanément mapper les propriétés "
-"d'une classe et les noeuds d'un document XML vers la base de données, ou, si "
-"il n'y a pas de classe à mapper, il peut être utilisé juste pour mapper le "
-"XML."
+"Un simple mappage peut être utilisé pour simultanément mapper les propriétés "
+"d'une classe et les noeuds d'un document XML vers la base de données, ou, "
+"s'il n'y a pas de classe à mapper, il peut être utilisé juste pour mapper le "
+"XML. "
 
 #. Tag: title
-#: xml.xml:68
 #, no-c-format
 msgid "Specifying XML and class mapping together"
-msgstr "Spécifier le mapping XML et le mapping d'une classe ensemble"
+msgstr "Spécifier le mappage XML et le mappage d'une classe ensemble"
 
 #. Tag: para
-#: xml.xml:70
 #, no-c-format
 msgid "Here is an example of mapping a POJO and XML simultaneously:"
-msgstr "Voici un exemple de mapping d'un POJO et du XML simultanément :"
+msgstr "Voici un exemple de mappage d'un POJO et du XML simultanément :"
 
-#. Tag: programlisting
-#: xml.xml:74
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Account\" \n"
-"        table=\"ACCOUNTS\" \n"
-"        node=\"account\">\n"
-"        \n"
-"    <id name=\"accountId\" \n"
-"            column=\"ACCOUNT_ID\" \n"
-"            node=\"@id\"/>\n"
-"            \n"
-"    <many-to-one name=\"customer\" \n"
-"            column=\"CUSTOMER_ID\" \n"
-"            node=\"customer/@id\" \n"
-"            embed-xml=\"false\"/>\n"
-"            \n"
-"    <property name=\"balance\" \n"
-"            column=\"BALANCE\" \n"
-"            node=\"balance\"/>\n"
-"            \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: xml.xml:78
 #, no-c-format
 msgid "Specifying only an XML mapping"
-msgstr "Spécifier seulement un mapping XML"
+msgstr "Spécifier seulement un mappage XML"
 
 #. Tag: para
-#: xml.xml:80
 #, no-c-format
 msgid "Here is an example where there is no POJO class:"
-msgstr "Voici un exemple dans lequel il n'y a pas de class POJO :"
+msgstr "Voici un exemple dans lequel il n'y a pas de classe POJO :"
 
-#. Tag: programlisting
-#: xml.xml:84
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class entity-name=\"Account\" \n"
-"        table=\"ACCOUNTS\" \n"
-"        node=\"account\">\n"
-"        \n"
-"    <id name=\"id\" \n"
-"            column=\"ACCOUNT_ID\" \n"
-"            node=\"@id\" \n"
-"            type=\"string\"/>\n"
-"            \n"
-"    <many-to-one name=\"customerId\" \n"
-"            column=\"CUSTOMER_ID\" \n"
-"            node=\"customer/@id\" \n"
-"            embed-xml=\"false\" \n"
-"            entity-name=\"Customer\"/>\n"
-"            \n"
-"    <property name=\"balance\" \n"
-"            column=\"BALANCE\" \n"
-"            node=\"balance\" \n"
-"            type=\"big_decimal\"/>\n"
-"            \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: xml.xml:86
-#, fuzzy, no-c-format
-msgid ""
 "This mapping allows you to access the data as a dom4j tree, or as a graph of "
 "property name/value pairs or java <literal>Map</literal>s. The property "
 "names are purely logical constructs that can be referred to in HQL queries."
 msgstr ""
-"Ce mapping vous permet d'accéder aux données comme un arbre dom4j, ou comme "
-"un graphe de paire nom de propriété/valeur (<literal>Map</literal>s java). "
+"Ce mappage vous permet d'accéder aux données comme un arbre dom4j, ou comme "
+"un graphe de paire nom/valeur de propriété (<literal>Map</literal> s java). "
 "Les noms des propriétés sont des constructions purement logiques qui peuvent "
-"être référées des dans requêtes HQL."
+"être référées dans des requêtes HQL. "
 
 #. Tag: title
-#: xml.xml:97
 #, no-c-format
 msgid "XML mapping metadata"
-msgstr "Métadonnées du mapping XML"
+msgstr "Métadonnées du mappage XML"
 
 #. Tag: para
-#: xml.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A range of Hibernate mapping elements accept the <literal>node</literal> "
 "attribute. This lets you specify the name of an XML attribute or element "
 "that holds the property or entity data. The format of the <literal>node</"
 "literal> attribute must be one of the following:"
 msgstr ""
-"Plusieurs éléments du mapping Hibernate acceptent l'attribut <literal>node</"
+"Plusieurs éléments du mappage Hibernate acceptent l'attribut <literal>node</"
 "literal>. Ceci vous permet de spécifier le nom d'un attribut XML ou d'un "
 "élément qui contient la propriété ou les données de l'entité. Le format de "
-"l'attribut <literal>node</literal> doit être un des suivants :"
+"l'attribut <literal>node</literal> doit être un des suivants : "
 
 #. Tag: para
-#: xml.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>\"element-name\"</literal>: map to the named XML element"
-msgstr "<literal>\"element-name\"</literal> - mappe vers l'élément XML nommé"
+msgstr "<literal>\"element-name\"</literal> - mappe vers l'élément XML nommé "
 
 #. Tag: para
-#: xml.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>\"@attribute-name\"</literal>: map to the named XML attribute"
 msgstr ""
-"<literal>\"@attribute-name\"</literal> - mappe vers l'attribut XML nommé"
+"<literal>\"@attribute-name\"</literal> - mappe vers l'attribut XML nommé "
 
 #. Tag: para
-#: xml.xml:114
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>\".\"</literal>: map to the parent element"
-msgstr "<literal>\".\"</literal> - mappe vers le parent de l'élément"
+msgstr "<literal>\".\"</literal> - mappe vers le parent de l'élément "
 
 #. Tag: para
-#: xml.xml:117
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>\"element-name/@attribute-name\"</literal>: map to the named "
 "attribute of the named element"
 msgstr ""
 "<literal>\"element-name/@attribute-name\"</literal> - mappe vers l'élément "
-"nommé de l'attribut nommé"
+"nommé de l'attribut nommé "
 
 #. Tag: para
-#: xml.xml:124
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For collections and single valued associations, there is an additional "
 "<literal>embed-xml</literal> attribute. If <literal>embed-xml=\"true\"</"
@@ -250,201 +183,61 @@
 "l'arbre XML pour l'entité qui possède l'association. Sinon, si "
 "<literal>embed-xml=\"false\"</literal>, alors seule la valeur de "
 "l'identifiant référencé apparaîtra dans le XML pour de simples associations "
-"de points, et les collections n'appraîtront simplement pas."
+"de points, et les collections n'apparaîtront pas. "
 
 #. Tag: para
-#: xml.xml:134
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not leave <literal>embed-xml=\"true\"</literal> for too many "
 "associations, since XML does not deal well with circularity."
 msgstr ""
-"Vous devriez faire attention à ne pas laisser <literal>embed-xml=\"true\"</"
-"literal> pour trop d'associations, puisque XML ne traite pas bien les liens "
-"circurlaires."
+"Faire attention à ne pas laisser <literal>embed-xml=\"true\"</literal> pour "
+"trop d'associations, puisque XML ne traite pas bien les liens circulaires. "
 
-#. Tag: programlisting
-#: xml.xml:139
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Customer\" \n"
-"        table=\"CUSTOMER\" \n"
-"        node=\"customer\">\n"
-"        \n"
-"    <id name=\"id\" \n"
-"            column=\"CUST_ID\" \n"
-"            node=\"@id\"/>\n"
-"            \n"
-"    <map name=\"accounts\" \n"
-"            node=\".\" \n"
-"            embed-xml=\"true\">\n"
-"        <key column=\"CUSTOMER_ID\" \n"
-"                not-null=\"true\"/>\n"
-"        <map-key column=\"SHORT_DESC\" \n"
-"                node=\"@short-desc\" \n"
-"                type=\"string\"/>\n"
-"        <one-to-many entity-name=\"Account\"\n"
-"                embed-xml=\"false\" \n"
-"                node=\"account\"/>\n"
-"    </map>\n"
-"    \n"
-"    <component name=\"name\" \n"
-"            node=\"name\">\n"
-"        <property name=\"firstName\" \n"
-"                node=\"first-name\"/>\n"
-"        <property name=\"initial\" \n"
-"                node=\"initial\"/>\n"
-"        <property name=\"lastName\" \n"
-"                node=\"last-name\"/>\n"
-"    </component>\n"
-"    \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: xml.xml:141
-#, fuzzy, no-c-format
-msgid ""
 "In this case, the collection of account ids is embedded, but not the actual "
 "account data. The following HQL query:"
 msgstr ""
-"dans ce cas, nous avons décidé d'embarquer la collection d'identifiants de "
+"Dans ce cas, nous avons décidé d'embarquer la collection d'identifiants de "
 "compte, mais pas les données actuelles du compte. La requête HQL suivante :"
 
-#. Tag: programlisting
-#: xml.xml:146
-#, no-c-format
-msgid ""
-"<![CDATA[from Customer c left join fetch c.accounts where c.lastName like :"
-"lastName]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:148
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "would return datasets such as this:"
-msgstr "devrait retourner l'ensemble de données suivant :"
+msgstr "devrait retourner l'ensemble de données suivant : "
 
-#. Tag: programlisting
-#: xml.xml:152
-#, no-c-format
-msgid ""
-"<![CDATA[<customer id=\"123456789\">\n"
-"    <account short-desc=\"Savings\">987632567</account>\n"
-"    <account short-desc=\"Credit Card\">985612323</account>\n"
-"    <name>\n"
-"        <first-name>Gavin</first-name>\n"
-"        <initial>A</initial>\n"
-"        <last-name>King</last-name>\n"
-"    </name>\n"
-"    ...\n"
-"</customer>]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:154
 #, no-c-format
 msgid ""
 "If you set <literal>embed-xml=\"true\"</literal> on the <literal>&lt;one-to-"
 "many&gt;</literal> mapping, the data might look more like this:"
 msgstr ""
-"Si vous positionnez <literal>embed-xml=\"true\"</literal> sur le mapping "
-"<literal>&lt;one-to-many&gt;</literal>, les données pourraient ressembler "
-"plus à ça :"
+"Si vous positionnez <literal>embed-xml=\"true\"</literal> sur le mappage "
+"<literal>&lt;one-to-many&gt;</literal>, les données ressembleraient à ce qui "
+"suit :"
 
-#. Tag: programlisting
-#: xml.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[<customer id=\"123456789\">\n"
-"    <account id=\"987632567\" short-desc=\"Savings\">\n"
-"        <customer id=\"123456789\"/>\n"
-"        <balance>100.29</balance>\n"
-"    </account>\n"
-"    <account id=\"985612323\" short-desc=\"Credit Card\">\n"
-"        <customer id=\"123456789\"/>\n"
-"        <balance>-2370.34</balance>\n"
-"    </account>\n"
-"    <name>\n"
-"        <first-name>Gavin</first-name>\n"
-"        <initial>A</initial>\n"
-"        <last-name>King</last-name>\n"
-"    </name>\n"
-"    ...\n"
-"</customer>]]>"
-msgstr ""
-
 #. Tag: title
-#: xml.xml:165
 #, no-c-format
 msgid "Manipulating XML data"
 msgstr "Manipuler des données XML"
 
 #. Tag: para
-#: xml.xml:167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also re-read and update XML documents in the application. You can do "
 "this by obtaining a dom4j session:"
 msgstr ""
 "Relisons et mettons à jour des documents XML dans l'application. Nous "
-"faisons ça en obtenant une session dom4j :"
+"effectuons cela en obtenant une session dom4j : "
 
-#. Tag: programlisting
-#: xml.xml:172
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Document doc = ....;\n"
-"       \n"
-"Session session = factory.openSession();\n"
-"Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"List results = dom4jSession\n"
-"    .createQuery(\"from Customer c left join fetch c.accounts where c."
-"lastName like :lastName\")\n"
-"    .list();\n"
-"for ( int i=0; i<results.size(); i++ ) {\n"
-"    //add the customer data to the XML document\n"
-"    Element customer = (Element) results.get(i);\n"
-"    doc.add(customer);\n"
-"}\n"
-"\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: xml.xml:174
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = factory.openSession();\n"
-"Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"Element cust = (Element) dom4jSession.get(\"Customer\", customerId);\n"
-"for ( int i=0; i<results.size(); i++ ) {\n"
-"    Element customer = (Element) results.get(i);\n"
-"    //change the customer name in the XML and database\n"
-"    Element name = customer.element(\"name\");\n"
-"    name.element(\"first-name\").setText(firstName);\n"
-"    name.element(\"initial\").setText(initial);\n"
-"    name.element(\"last-name\").setText(lastName);\n"
-"}\n"
-"\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: xml.xml:176
-#, fuzzy, no-c-format
-msgid ""
 "When implementing XML-based data import/export, it is useful to combine this "
 "feature with Hibernate's <literal>replicate()</literal> operation."
 msgstr ""
 "Il est extrêmement utile de combiner cette fonctionnalité avec l'opération "
-"<literal>replicate()</literal> d'Hibernate pour implémenter des imports/"
-"exports de données XML."
+"<literal>replicate()</literal> de Hibernate pour implémenter des imports/"
+"exports de données XML. "

Modified: core/trunk/documentation/manual/src/main/docbook/fr-FR/legal_notice.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/fr-FR/legal_notice.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/fr-FR/legal_notice.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,35 +2,33 @@
 msgid ""
 msgstr ""
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:23\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
 "Content-Type: text/plain; charset=UTF-8\n"
 
 #. Tag: title
-#: legal_notice.xml:28
 #, no-c-format
 msgid "Legal Notice"
 msgstr "Legal Notice"
 
-#. Tag: address
-#: legal_notice.xml:30
-#, no-c-format
+#. Tag: para
+#, fuzzy, no-c-format
 msgid ""
-"<street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
-"state><postcode>27606-2072</postcode><country>USA</country> <phone>Phone: +1 "
-"919 754 3700</phone> <phone>Phone: 888 733 4281</phone> <fax>Fax: +1 919 754 "
-"3701</fax> <pob>PO Box 13588</pob><city>Research Triangle Park</city>, "
-"<state>NC</state><postcode>27709</postcode><country>USA</country>"
+"<address> <street>1801 Varsity Drive</street> <city>Raleigh</city>, "
+"<state>NC</state><postcode>27606-2072</postcode><country>USA</country> "
+"<phone>Phone: +1 919 754 3700</phone> <phone>Phone: 888 733 4281</phone> "
+"<fax>Fax: +1 919 754 3701</fax> <pob>PO Box 13588</pob><city>Research "
+"Triangle Park</city>, <state>NC</state><postcode>27709</"
+"postcode><country>USA</country> </address>"
 msgstr ""
-"<street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
+"<address> <street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
 "state><postcode>27606-2072</postcode><country>USA</country> <phone>Phone: +1 "
 "919 754 3700</phone> <phone>Phone: 888 733 4281</phone> <fax>Fax: +1 919 754 "
 "3701</fax> <pob>PO Box 13588</pob><city>Research Triangle Park</city>, "
-"<state>NC</state><postcode>27709</postcode><country>USA</country>"
+"<state>NC</state><postcode>27709</postcode><country>USA</country> </address>"
 
 #. Tag: para
-#: legal_notice.xml:39
 #, fuzzy, no-c-format
 msgid ""
 "Copyright <trademark class=\"copyright\"></trademark> 2007 by Red Hat, Inc. "
@@ -46,7 +44,6 @@
 "Public License</ulink>, as published by the Free Software Foundation."
 
 #. Tag: para
-#: legal_notice.xml:45
 #, no-c-format
 msgid ""
 "Red Hat and the Red Hat \"Shadow Man\" logo are registered trademarks of Red "
@@ -56,7 +53,6 @@
 "Hat, Inc. in the United States and other countries."
 
 #. Tag: para
-#: legal_notice.xml:48
 #, no-c-format
 msgid ""
 "All other trademarks referenced herein are the property of their respective "
@@ -66,13 +62,11 @@
 "owners."
 
 #. Tag: para
-#: legal_notice.xml:51
 #, no-c-format
 msgid "The GPG fingerprint of the security at redhat.com key is:"
 msgstr "The GPG fingerprint of the security at redhat.com key is:"
 
 #. Tag: para
-#: legal_notice.xml:54
 #, no-c-format
 msgid "CA 20 86 86 2B D6 9D FC 65 F6 EC C4 21 91 80 CD DB 42 A6 0E"
 msgstr "CA 20 86 86 2B D6 9D FC 65 F6 EC C4 21 91 80 CD DB 42 A6 0E"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/Hibernate_Reference.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/Hibernate_Reference.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/Hibernate_Reference.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,32 +1,30 @@
+# SOME DESCRIPTIVE TITLE.
+# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+#
 #, fuzzy
 msgid ""
 msgstr ""
+"Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-11T05:38:14\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Content-Type: text/plain; charset=UTF-8\n"
+"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: Hibernate_Reference.xml:35
 #, no-c-format
 msgid "HIBERNATE - Relational Persistence for Idiomatic Java"
-msgstr "HIBERNATE - Relational Persistence for Idiomatic Java"
+msgstr ""
 
 #. Tag: subtitle
-#: Hibernate_Reference.xml:36
 #, no-c-format
 msgid "Hibernate Reference Documentation"
-msgstr "Hibernate Reference Documentation"
+msgstr ""
 
-#. Tag: holder
-#: Hibernate_Reference.xml:51
+#. Tag: releaseinfo
 #, no-c-format
-msgid "&copyrightHolder;"
-msgstr "&copyrightHolder;"
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+msgid "&versionNumber;"
+msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/author_group.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/author_group.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/author_group.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -5,7 +5,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: 2009-07-14 19:55+0000\n"
 "Last-Translator: Automatically generated\n"
 "Language-Team: none\n"
@@ -13,209 +13,137 @@
 "Content-Type: text/plain; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
-#. Tag: author
-#: author_group.xml:27
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Gavin</firstname> <surname>King</surname>"
+msgid "Gavin"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:31
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Christian</firstname> <surname>Bauer</surname>"
+msgid "Christian"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:35
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Max</firstname> <othername>Rydahl</othername> <surname>Andersen</"
-"surname>"
+msgid "Max"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:40
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<author><firstname>Emmanuel</firstname> <surname>Bernard</surname></author>"
+msgid "Emmanuel"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:44
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Steve</firstname> <surname>Ebersole</surname>"
+msgid "Steve"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:49
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>James</firstname> <surname>Cobb</surname>"
+msgid "James"
 msgstr ""
 
-#. Tag: shortaffil
-#: author_group.xml:53 author_group.xml:60
+#. Tag: firstname
 #, no-c-format
-msgid "Graphic Design"
+msgid "Cheyenne"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:56
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Cheyenne</firstname> <surname>Weaver</surname>"
+msgid "Vincent"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:69
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<othername><![CDATA[Bernardo Antonio Buffa Colom&#x00e9]]></othername> "
-"<email>kreimer at bbs.frc.utn.edu.ar</email>"
+msgid "Sebastien"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:79
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Vincent</firstname> <surname>Ricard</surname>"
+msgid "Michael"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:83
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Sebastien</firstname> <surname>Cesbron</surname>"
+msgid "Baptiste"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:87
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Michael</firstname> <surname>Courcy</surname>"
+msgid "Anthony"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:91
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Vincent</firstname> <surname>Giguère</surname>"
+msgid "Alvaro"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:95
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Baptiste</firstname> <surname>Mathus</surname>"
+msgid "Anderson"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:99
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<othercredit><firstname>Emmanuel</firstname> <surname>Bernard</surname></"
-"othercredit>"
+msgid "Daniel Vieira"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:103
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Anthony</firstname> <surname>Patricio</surname>"
+msgid "Francisco"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:113
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Alvaro</firstname> <surname>Netto</surname> "
-"<email>alvaronetto at cetip.com.br</email>"
+msgid "Gamarra"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:118
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Anderson</firstname> <surname>Braulio</surname> "
-"<email>andersonbraulio at gmail.com</email>"
+msgid "Luiz Carlos"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:123
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Daniel Vieira</firstname> <surname>Costa</surname> "
-"<email>danielvc at gmail.com</email>"
+msgid "Marcel"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:128
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Francisco</firstname> <surname>gamarra</surname> <email>francisco."
-"gamarra at gmail.com</email>"
+msgid "Paulo"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:133
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Gamarra</firstname> <email>mauricio.gamarra at gmail.com</email>"
+msgid "Pablo L."
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:137
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Luiz Carlos</firstname> <surname>Rodrigues</surname> "
-"<email>luizcarlos_rodrigues at yahoo.com.br</email>"
+msgid "Renato"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:142
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Marcel</firstname> <surname>Castelo</surname> <email>marcel."
-"castelo at gmail.com</email>"
+msgid "Rogério"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:147
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Paulo</firstname> <surname>César</surname> <email>paulocol at gmail."
-"com</email>"
+msgid "Wanderson"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:152
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Pablo L.</firstname> <surname>de Miranda</surname> "
-"<email>pablolmiranda at gmail.com</email>"
+msgid "Cao"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:157
+#. Tag: orgname
 #, no-c-format
-msgid ""
-"<firstname>Renato</firstname> <surname>Deggau</surname> <email>rdeggau at gmail."
-"com</email>"
+msgid "RedSaga"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:162
+#. Tag: contrib
 #, no-c-format
-msgid ""
-"<firstname>Rogério</firstname> <surname>Araújo</surname> "
-"<email>rgildoaraujo at yahoo.com.br</email>"
+msgid "Translation Lead"
 msgstr ""
-
-#. Tag: othercredit
-#: author_group.xml:167
-#, no-c-format
-msgid ""
-"<firstname>Wanderson</firstname> <surname>Siqueira</surname> "
-"<email>wandersonxs at gmail.com</email>"
-msgstr ""
-
-#. Tag: othercredit
-#: author_group.xml:178
-#, no-c-format
-msgid ""
-"<firstname>Cao</firstname> <surname>Xiaogang</surname> <affiliation> "
-"<orgname>RedSaga</orgname> </affiliation> <contrib>Translation Lead</"
-"contrib> <email>caoxg at yahoo.com</email>"
-msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/architecture.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/architecture.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/architecture.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,36 +1,35 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2010-01-13 10:25+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: architecture.xml:30
 #, no-c-format
 msgid "Architecture"
 msgstr "アーキテクチャ"
 
 #. Tag: title
-#: architecture.xml:33
 #, no-c-format
 msgid "Overview"
 msgstr "概観"
 
 #. Tag: para
-#: architecture.xml:35
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The diagram below provides a high-level view of the Hibernate architecture:"
-msgstr "Hibernateアーキテクチャの(非常に)高いレベルからのビュー:"
+msgstr "Hibernate アーキテクチャの(非常に)高いレベルからのビュー:"
 
 #. Tag: para
-#: architecture.xml:48
 #, fuzzy, no-c-format
 msgid ""
 "We do not have the scope in this document to provide a more detailed view of "
@@ -38,61 +37,56 @@
 "several different approaches. We will, however, show the two extremes: "
 "\"minimal\" architecture and \"comprehensive\" architecture."
 msgstr ""
-"ここで実行時アーキテクチャのより詳細なビューをお見せしましょう。 あいにく、"
-"Hibernateは柔軟であり、いろいろなアプローチをサポートしています。 ここでは、2"
-"つの極端な例をお見せします。 「軽い」アーキテクチャでは、アプリケーションが自"
-"前のJDBCコネクションを用意し、 アプリケーション自身がトランザクションを管理し"
-"ます。 この方法は、Hibernate APIの最小限のサブセットを使います:"
+"ここで実行時アーキテクチャのより詳細なビューをお見せしましょう。あいにく、 "
+"Hibernate は柔軟であり、いろいろなアプローチをサポートしています。ここでは、2"
+"つの極端な例をお見せします。「軽い」アーキテクチャでは、アプリケーションが自"
+"前の JDBC コネクションを用意し、アプリケーション自身がトランザクションを管理"
+"します。この方法は、 Hibernate API の最小限のサブセットを使います:"
 
 #. Tag: para
-#: architecture.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This next diagram illustrates how Hibernate utilizes database and "
 "configuration data to provide persistence services, and persistent objects, "
 "to the application."
 msgstr ""
-"この図はHibernateが、アプリケーションに対して永続化サービス (と永続オブジェ"
-"クト)を提供するために、データベースと設定データを使うことを 示しています。"
+"この図は Hibernate が、アプリケーションに対して永続化サービス (と永続オブ"
+"ジェクト)を提供するために、データベースと設定データを使うことを示していま"
+"す。"
 
 #. Tag: para
-#: architecture.xml:59
 #, fuzzy, no-c-format
 msgid ""
 "The \"minimal\" architecture has the application provide its own JDBC "
 "connections and manage its own transactions. This approach uses a minimal "
 "subset of Hibernate's APIs:"
 msgstr ""
-"ここで実行時アーキテクチャのより詳細なビューをお見せしましょう。 あいにく、"
-"Hibernateは柔軟であり、いろいろなアプローチをサポートしています。 ここでは、2"
-"つの極端な例をお見せします。 「軽い」アーキテクチャでは、アプリケーションが自"
-"前のJDBCコネクションを用意し、 アプリケーション自身がトランザクションを管理し"
-"ます。 この方法は、Hibernate APIの最小限のサブセットを使います:"
+"ここで実行時アーキテクチャのより詳細なビューをお見せしましょう。あいにく、 "
+"Hibernate は柔軟であり、いろいろなアプローチをサポートしています。ここでは、2"
+"つの極端な例をお見せします。「軽い」アーキテクチャでは、アプリケーションが自"
+"前の JDBC コネクションを用意し、アプリケーション自身がトランザクションを管理"
+"します。この方法は、 Hibernate API の最小限のサブセットを使います:"
 
 #. Tag: para
-#: architecture.xml:74
 #, fuzzy, no-c-format
 msgid ""
 "The \"comprehensive\" architecture abstracts the application away from the "
 "underlying JDBC/JTA APIs and allows Hibernate to manage the details."
 msgstr ""
-"「重い」アーキテクチャは、アプリケーションから、その下に位置するJDBCやJTAの"
-"APIを 取り払って抽象化し、その詳細の面倒をHibernateに見させます。"
+"「軽い」アーキテクチャは、アプリケーションから、その下に位置する JDBC や JTA "
+"の API を取り払って抽象化し、その詳細の面倒を Hibernate に見させます。"
 
 #. Tag: para
-#: architecture.xml:88
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here are some definitions of the objects depicted in the diagrams:"
-msgstr "以下は、上の図に含まれるオブジェクトの定義です: <placeholder-1/>"
+msgstr "以下は、図に含まれるオブジェクトの定義です:"
 
 #. Tag: term
-#: architecture.xml:93
 #, no-c-format
 msgid "SessionFactory (<literal>org.hibernate.SessionFactory</literal>)"
 msgstr "SessionFactory (<literal>org.hibernate.SessionFactory</literal>)"
 
 #. Tag: para
-#: architecture.xml:95
 #, fuzzy, no-c-format
 msgid ""
 "A threadsafe, immutable cache of compiled mappings for a single database. A "
@@ -101,20 +95,18 @@
 "hold an optional (second-level) cache of data that is reusable between "
 "transactions at a process, or cluster, level."
 msgstr ""
-"1つのデータベースに対するコンパイルされたマッピングの スレッドセーフな(更新"
-"不能の)キャッシュ。 <literal>Session</literal> のファクトリであり、 "
-"<literal>ConnectionProvider</literal> のクライアント。 オプションとして、プロ"
-"セスまたはクラスタレベルにおいて、 トランザクション間で再利用可能なデータの"
+"1つのデータベースに対するコンパイルされたマッピングのスレッドセーフな(更新不"
+"能の)キャッシュ。 <literal>Session</literal> のファクトリであり、 "
+"<literal>ConnectionProvider</literal> のクライアント。オプションとして、プロ"
+"セスまたはクラスタレベルにおいて、トランザクション間で再利用可能なデータの"
 "(二次)キャッシュを持ちます。"
 
 #. Tag: term
-#: architecture.xml:105
 #, no-c-format
 msgid "Session (<literal>org.hibernate.Session</literal>)"
 msgstr "Session (<literal>org.hibernate.Session</literal>)"
 
 #. Tag: para
-#: architecture.xml:107
 #, fuzzy, no-c-format
 msgid ""
 "A single-threaded, short-lived object representing a conversation between "
@@ -123,21 +115,19 @@
 "holds a mandatory first-level cache of persistent objects that are used when "
 "navigating the object graph or looking up objects by identifier."
 msgstr ""
-"アプリケーションと永続ストアとの対話を表す、 シングルスレッドで短命のオブジェ"
-"クト。 JDBCコネクションをラップします。 <literal>Transaction</literal> のファ"
-"クトリです。 永続オブジェクトの必須の(一次)キャッシュを保持します。 この"
-"キャッシュはオブジェクトグラフをナビゲーションする時や、 識別子でオブジェクト"
+"アプリケーションと永続ストアとの対話を表す、シングルスレッドで短命のオブジェ"
+"クト。 JDBC コネクションをラップします。 <literal>Transaction</literal> の"
+"ファクトリです。永続オブジェクトの必須の(一次)キャッシュを保持します。この"
+"キャッシュはオブジェクトグラフをナビゲーションする時や、識別子でオブジェクト"
 "を検索する時に使われます。"
 
 #. Tag: term
-#: architecture.xml:117
 #, no-c-format
 msgid "Persistent objects and collections"
 msgstr "Persistent objects と Collections"
 
 #. Tag: para
-#: architecture.xml:119
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Short-lived, single threaded objects containing persistent state and "
 "business function. These can be ordinary JavaBeans/POJOs. They are "
@@ -146,43 +136,38 @@
 "in any application layer (for example, directly as data transfer objects to "
 "and from presentation)."
 msgstr ""
-"永続化状態とビジネスメソッドを持つ、短命でシングルスレッドのオブジェクト。 こ"
-"れは通常のJavaBeans/POJOのこともありますが、特徴的なことは、 その時点での(た"
-"だ1つの) <literal>Session</literal> と関連していることです。 "
-"<literal>Session</literal> がクローズされるとすぐに、 それらは切り離されて他"
-"のアプリケーション層から自由に使うことができます。 (例えばデータ・トランス"
-"ファ・オブジェクトとして、 プレゼンテーション層から、またはプレゼンテーション"
-"層へ直接使用できます。)"
+"永続化状態とビジネス機能を持つ、短命でシングルスレッドのオブジェクト。これは"
+"通常の JavaBeans/POJO のこともありますが、特徴的なことは、その時点での(ただ1"
+"つの) <literal>Session</literal> と関連していることです。 <literal>Session</"
+"literal> がクローズされるとすぐに、それらは切り離されて他のアプリケーション層"
+"から自由に使うことができます(例えばデータトランスファオブジェクトとして、プ"
+"レゼンテーション層から、またはプレゼンテーション層へ直接使用できます)。"
 
 #. Tag: term
-#: architecture.xml:129
 #, no-c-format
 msgid "Transient and detached objects and collections"
 msgstr "Transient と detached な objects と Collections"
 
 #. Tag: para
-#: architecture.xml:131
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Instances of persistent classes that are not currently associated with a "
 "<literal>Session</literal>. They may have been instantiated by the "
 "application and not yet persisted, or they may have been instantiated by a "
 "closed <literal>Session</literal>."
 msgstr ""
-"現時点では <literal>Session</literal> と関連していない、 永続クラスのインスタ"
-"ンス。 すでにアプリケーション側でインスタンス化されていて、まだ永続化されてい"
-"ないか、 クローズされた <literal>Session</literal> でインスタンス化されたかの"
+"現時点では <literal>Session</literal> と関連していない、永続クラスのインスタ"
+"ンス。すでにアプリケーション側でインスタンス化されていて、まだ永続化されてい"
+"ないか、クローズされた <literal>Session</literal> でインスタンス化されたかの"
 "どちらかです。"
 
 #. Tag: term
-#: architecture.xml:140
 #, no-c-format
 msgid "Transaction (<literal>org.hibernate.Transaction</literal>)"
 msgstr "Transaction (<literal>org.hibernate.Transaction</literal>)"
 
 #. Tag: para
-#: architecture.xml:142
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "(Optional) A single-threaded, short-lived object used by the application to "
 "specify atomic units of work. It abstracts the application from the "
@@ -191,16 +176,15 @@
 "transaction demarcation, either using the underlying API or "
 "<literal>Transaction</literal>, is never optional."
 msgstr ""
-"(オプション)原子性を持つ作業単位(Unit of Work)を指定するために、アプリケー"
-"ションが使用する、 シングルスレッドで短命なオブジェクト。 下に位置するJDBC、"
-"JTA、CORBAトランザクションからアプリケーションを抽象化します。 "
-"<literal>Session</literal> は、時には いくつかの <literal>Transaction</"
-"literal> をまたがるかもしれません。 しかし、下の層のAPIを使うにせよ、 "
-"<literal>Transaction</literal> を使うにせよ、 トランザクション境界を設定する"
-"ことは、決してオプションではありません!。"
+"(オプション) 原子性を持つ作業単位 (Unit of Work) を指定するために、アプリケー"
+"ションが使用する、シングルスレッドで短命なオブジェクト。下に位置する JDBC 、 "
+"JTA 、 CORBA トランザクションからアプリケーションを抽象化します。 "
+"<literal>Session</literal> は、時にはいくつかの <literal>Transaction</"
+"literal> をまたがるかもしれません。しかし、下の層の API を使うにせよ、 "
+"<literal>Transaction</literal> を使うにせよ、トランザクション境界を設定するこ"
+"とは、決してオプションではありません。"
 
 #. Tag: term
-#: architecture.xml:153
 #, no-c-format
 msgid ""
 "ConnectionProvider (<literal>org.hibernate.connection.ConnectionProvider</"
@@ -210,21 +194,19 @@
 "literal>)"
 
 #. Tag: para
-#: architecture.xml:155
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "(Optional) A factory for, and pool of, JDBC connections. It abstracts the "
 "application from underlying <literal>Datasource</literal> or "
 "<literal>DriverManager</literal>. It is not exposed to application, but it "
 "can be extended and/or implemented by the developer."
 msgstr ""
-"(オプション)JDBCコネクション(とそのプール)のファクトリ。 下の層に位置する "
+"(オプション) JDBC コネクション(とそのプール)のファクトリ。下の層に位置する "
 "<literal>Datasource</literal> や <literal>DriverManager</literal> からアプリ"
-"ケーションを抽象化します。 アプリケーションには公開されませんが、開発者が継承"
+"ケーションを抽象化します。アプリケーションには公開されませんが、開発者が継承"
 "または実装することは可能です。"
 
 #. Tag: term
-#: architecture.xml:163
 #, no-c-format
 msgid ""
 "TransactionFactory (<literal>org.hibernate.TransactionFactory</literal>)"
@@ -232,90 +214,80 @@
 "TransactionFactory (<literal>org.hibernate.TransactionFactory</literal>)"
 
 #. Tag: para
-#: architecture.xml:165
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "(Optional) A factory for <literal>Transaction</literal> instances. It is not "
 "exposed to the application, but it can be extended and/or implemented by the "
 "developer."
 msgstr ""
-"(オプション) <literal>Transaction</literal> インスタンスのファクトリ。 アプリ"
+"(オプション) <literal>Transaction</literal> インスタンスのファクトリ。アプリ"
 "ケーションには公開されませんが、開発者が継承または実装することは可能です。"
 
-#. Tag: emphasis
-#: architecture.xml:172
-#, no-c-format
-msgid "Extension Interfaces"
-msgstr "Extension Interfaces"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<emphasis>Extension Interfaces</emphasis>"
+msgstr "<emphasis>Extension Interfaces</emphasis>"
 
 #. Tag: para
-#: architecture.xml:174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate offers a range of optional extension interfaces you can implement "
 "to customize the behavior of your persistence layer. See the API "
 "documentation for details."
 msgstr ""
-"Hibernateは、永続層の振る舞いをカスタマイズするために、 多くのオプション拡張"
-"インタフェースを用意しています。 詳細はAPIドキュメントを参照してください。"
+"Hibernate は、永続層の振る舞いをカスタマイズするために、多くのオプション拡張"
+"インタフェースを用意しています。詳細は API ドキュメントを参照してください。"
 
 #. Tag: para
-#: architecture.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Given a \"minimal\" architecture, the application bypasses the "
 "<literal>Transaction</literal>/<literal>TransactionFactory</literal> and/or "
 "<literal>ConnectionProvider</literal> APIs to communicate with JTA or JDBC "
 "directly."
 msgstr ""
-"「軽い」アーキテクチャでは、アプリケーションは直接JTAやJDBCと対話するため"
+"「軽い」アーキテクチャでは、アプリケーションは直接 JTA や JDBC と対話するため"
 "に、 <literal>Transaction</literal> や <literal>TransactionFactory</literal> "
-"や <literal>ConnectionProvider</literal> をバイパスします。"
+"や <literal>ConnectionProvider</literal> の API をバイパスします。"
 
 #. Tag: title
-#: architecture.xml:191
 #, no-c-format
 msgid "Instance states"
 msgstr "インスタンスの状態"
 
 #. Tag: para
-#: architecture.xml:192
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of a persistent class can be in one of three different states. "
 "These states are defined in relation to a <emphasis>persistence context</"
 "emphasis>. The Hibernate <literal>Session</literal> object is the "
 "persistence context. The three different states are as follows:"
 msgstr ""
-"永続クラスのインスタンスは、次の3つの異なる状態のどれかになります。 それ"
-"は、 <emphasis>永続コンテキスト</emphasis> によって決まります。 Hibernateの "
-"<literal>Session</literal> オブジェクトが、永続コンテキストになります。"
+"永続クラスのインスタンスは、次の3つの異なる状態のどれかになります。それは、 "
+"<emphasis>永続コンテキスト</emphasis> によって決まります。 Hibernate の "
+"<literal>Session</literal> オブジェクトが、永続コンテキストになります:"
 
 #. Tag: term
-#: architecture.xml:200
 #, no-c-format
 msgid "transient"
 msgstr "transient"
 
 #. Tag: para
-#: architecture.xml:202
 #, fuzzy, no-c-format
 msgid ""
 "The instance is not associated with any persistence context. It has no "
 "persistent identity or primary key value."
 msgstr ""
-"この状態のインスタンスは、現在もそして過去においても、 永続コンテキストに関連"
-"づいていません。また、永続ID(主キーの値)を 持っていません。"
+"この状態のインスタンスは、現在もそして過去においても、永続コンテキストに関連"
+"づいていません。また、永続 ID (主キーの値)を 持っていません。"
 
 #. Tag: term
-#: architecture.xml:210
 #, no-c-format
 msgid "persistent"
 msgstr "persistent"
 
 #. Tag: para
-#: architecture.xml:212
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The instance is currently associated with a persistence context. It has a "
 "persistent identity (primary key value) and can have a corresponding row in "
@@ -323,21 +295,19 @@
 "<emphasis>guarantees</emphasis> that persistent identity is equivalent to "
 "Java identity in relation to the in-memory location of the object."
 msgstr ""
-"この状態のインスタンスは、その時点で永続コンテキストに関連づいています。 ま"
-"た、永続ID(主キーの値)を持ち、 たいていはデータベースに対応する行を持ってい"
-"るでしょう。 個々の永続コンテキストのなかでは、永続IDが JavaのID(オブジェク"
-"トのメモリ上の位置)と同じであることを Hibernateが <emphasis>保証</emphasis> "
-"します。"
+"この状態のインスタンスは、その時点で永続コンテキストに関連づいています。ま"
+"た、永続 ID (主キーの値)を持ち、たいていはデータベースに対応する行を持って"
+"いるでしょう。特定の永続コンテキストのなかでは、永続 ID が Java の ID (オブ"
+"ジェクトのメモリ上の位置)と同じであることを Hibernate が <emphasis>保証</"
+"emphasis> します。"
 
 #. Tag: term
-#: architecture.xml:224
 #, no-c-format
 msgid "detached"
 msgstr "detached"
 
 #. Tag: para
-#: architecture.xml:226
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The instance was once associated with a persistence context, but that "
 "context was closed, or the instance was serialized to another process. It "
@@ -345,46 +315,43 @@
 "For detached instances, Hibernate does not guarantee the relationship "
 "between persistent identity and Java identity."
 msgstr ""
-"この状態のインスタンスは、かつて永続コンテキストに関連づけられたが、 そのコン"
-"テキストがクローズされたか、あるいは、 他のプロセスにそのインスタンスがシリア"
-"ライズされたかです。 このインスタンスは、永続IDを持ち、たいていはデータベース"
-"に 対応する行を持っているでしょう。分離インスタンスに対しては、 永続IDとJava"
-"のIDとの関連は、Hibernateが保証しません。"
+"この状態のインスタンスは、かつて永続コンテキストに関連づけられたが、そのコン"
+"テキストがクローズされたか、あるいは、他のプロセスにそのインスタンスがシリア"
+"ライズされたかです。このインスタンスは、永続 ID を持ち、たいていはデータベー"
+"スに対応する行を持っているでしょう。分離インスタンスに対しては、永続 ID と "
+"Java の ID との関連は、 Hibernate が保証しません。"
 
 #. Tag: title
-#: architecture.xml:241
 #, no-c-format
 msgid "JMX Integration"
-msgstr "JMXとの統合"
+msgstr "JMX との統合"
 
 #. Tag: para
-#: architecture.xml:243
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "JMX is the J2EE standard for the management of Java components. Hibernate "
 "can be managed via a JMX standard service. AN MBean implementation is "
 "provided in the distribution: <literal>org.hibernate.jmx.HibernateService</"
 "literal>."
 msgstr ""
-"JMXはJavaコンポーネント管理のJ2EE標準です。 JMX標準サービスを通して、"
-"Hibernateは管理されます。 ディストリビューションの中に <literal>org."
-"hibernate.jmx.HibernateService</literal> という MBean実装を用意しています。"
+"JMX は Java コンポーネント管理の J2EE 標準です。 JMX 標準サービスを通して、 "
+"Hibernate は管理されます。ディストリビューションの中に <literal>org."
+"hibernate.jmx.HibernateService</literal> という MBean 実装を用意しています。"
 
 #. Tag: para
-#: architecture.xml:249
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For an example of how to deploy Hibernate as a JMX service on the JBoss "
 "Application Server, please see the JBoss User Guide. JBoss AS also provides "
 "these benefits if you deploy using JMX:"
 msgstr ""
-"JBoss アプリケーションサーバー上にHibernateをJMXサービスとしてデプロイする方"
-"法の例としては、 JBoss ユーザガイドを参照してください。 JBoss アプリケーショ"
-"ンサーバーにおいて、 JMXを使ってデプロイすると、次のメリットが得られます。"
+"JBoss アプリケーションサーバー上に Hibernate を JMX サービスとしてデプロイす"
+"る方法の例としては、 JBoss ユーザーガイドを参照してください。 JBoss アプリ"
+"ケーションサーバーにおいて、 JMX を使ってデプロイすると、次のメリットが得られ"
+"ます:"
 
 #. Tag: para
-#: architecture.xml:257
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Session Management</emphasis>: the Hibernate <literal>Session</"
 "literal>'s life cycle can be automatically bound to the scope of a JTA "
@@ -396,19 +363,18 @@
 "the <literal>HibernateContext</literal> to access a <literal>Session</"
 "literal>."
 msgstr ""
-"<emphasis>セッション管理:</emphasis> Hibernateの <literal>Session</literal> "
-"のライフサイクルは、 自動的にJTAトランザクションのスコープに結びつけられま"
+"<emphasis>セッション管理:</emphasis> Hibernate の <literal>Session</literal> "
+"のライフサイクルは、自動的に JTA トランザクションのスコープに結びつけられま"
 "す。これは、もはや手動で <literal>Session</literal> をオープンしたり、クロー"
-"ズしたりする必要がないことを意味します。 これは、JBoss EJB インターセプタの仕"
-"事になります。 また、コードのどこでトランザクション境界を設定するかについ"
-"て、 もはや悩む必要がありません(もちろん移植可能な永続層を書かかなくていいの"
-"ならば、 オプションのHibernateの <literal>Transaction</literal> を使用してく"
-"ださい。) <literal>Session</literal> にアクセスするためには、 "
-"<literal>HibernateContext</literal> を コールしてください。"
+"ズしたりする必要がないことを意味します。これは、 JBoss EJB インターセプタの仕"
+"事になります。また、コードのどこでトランザクション境界を設定するかについて、"
+"もはや悩む必要がありません(もちろん移植可能な永続層を書かかなくていいのなら"
+"ば、オプションの Hibernate の <literal>Transaction</literal> を使用してくださ"
+"い。) <literal>Session</literal> にアクセスするためには、 "
+"<literal>HibernateContext</literal> をコールしてください。"
 
 #. Tag: para
-#: architecture.xml:269
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>HAR deployment</emphasis>: the Hibernate JMX service is deployed "
 "using a JBoss service deployment descriptor in an EAR and/or SAR file, as it "
@@ -418,61 +384,55 @@
 "deployment, JBoss will automatically detect all mapping files in your HAR "
 "file."
 msgstr ""
-"<emphasis>HAR デプロイ:</emphasis> 通常、(EAR または SAR ファイルにある)"
-"JBoss サービス デプロイメントディスクリプタを使って、Hibernate JMX サービスを"
-"デプロイします。 それは、Hibernateの <literal>SessionFactory</literal> の全て"
-"の一般的な設定オプションを サポートします。しかし依然としてデプロイメントディ"
-"スクリプタのなかにすべてのマッピングファイルの 名前を挙げる必要があります。 "
-"もし、オプションのHARデプロイメントを使うことを決めたなら、 JBossは自動的に"
-"HARファイルのなかの全てのマッピングファイルを検出します。"
+"<emphasis>HAR デプロイ:</emphasis> 通常、( EAR または SAR ファイルにある) "
+"JBoss サービスデプロイメントディスクリプタを使って、 Hibernate JMX サービスを"
+"デプロイします。それは、 Hibernate の <literal>SessionFactory</literal> の全"
+"ての一般的な設定オプションをサポートします。しかし依然としてデプロイメント"
+"ディスクリプタのなかにすべてのマッピングファイルの名前を挙げる必要がありま"
+"す。もし、オプションの HAR デプロイメントを使うことを決めたなら、 JBoss は自"
+"動的に HAR ファイルのなかの全てのマッピングファイルを検出します。"
 
 #. Tag: para
-#: architecture.xml:280
 #, no-c-format
 msgid ""
 "Consult the JBoss AS user guide for more information about these options."
 msgstr ""
-"これらのオプションについての詳細な情報は、JBossアプリケーションサーバユーザガ"
-"イドを 参考にしてください。"
+"これらのオプションについての詳細な情報は、 JBoss アプリケーションサーバーユー"
+"ザーガイドを参考にしてください。"
 
 #. Tag: para
-#: architecture.xml:284
 #, fuzzy, no-c-format
 msgid ""
 "Another feature available as a JMX service is runtime Hibernate statistics. "
-"See <xref linkend=\"configuration-optional-statistics\"/> for more "
+"See <xref linkend=\"configuration-optional-statistics\" /> for more "
 "information."
 msgstr ""
-"JMXサービスとして利用可能な他の機能に、Hibernate実行時統計情報があります。 "
+"JMX サービスとして利用可能な他の機能に、 Hibernate 実行時統計情報があります。"
 "<xref linkend=\"configuration-optional-statistics\"/> を見てください。"
 
 #. Tag: title
-#: architecture.xml:291
 #, no-c-format
 msgid "JCA Support"
 msgstr "JCA サポート"
 
 #. Tag: para
-#: architecture.xml:292
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate can also be configured as a JCA connector. Please see the website "
 "for more information. Please note, however, that at this stage Hibernate JCA "
 "support is under development."
 msgstr ""
-"Hibernate は JCA コネクタとしても設定できます。詳細については、Webサイトを見"
-"てください。 Hibernate JCA サポートは、今のところ実験段階として考えられている"
-"ことに注意してください。"
+"Hibernate は JCA コネクタとしても設定できます。詳細については、 Web サイトを"
+"見てください。 Hibernate JCA サポートは、今のところ実験段階として考えられてい"
+"ることに注意してください。"
 
 #. Tag: title
-#: architecture.xml:299
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Contextual sessions"
 msgstr "コンテキスト上のセッション"
 
 #. Tag: para
-#: architecture.xml:300
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Most applications using Hibernate need some form of \"contextual\" session, "
 "where a given session is in effect throughout the scope of a given context. "
@@ -484,19 +444,18 @@
 "utilized third-party frameworks, such as Spring or Pico, which provided "
 "proxy/interception-based contextual sessions."
 msgstr ""
-"Hibernate を使ったアプリケーションは、ほとんど、なんらかの形で\"コンテキスト"
-"上の\"セッションが必要になります。 「コンテキスト上のセッション」は、特定のコ"
-"ンテキストのスコープのなかで有効なセッションのことです。 しかし、通常アプリ"
-"ケーションごとにコンテキストを構成するものの定義は異なります。 しかも、異なる"
-"複数のコンテキストは、現時点に対して異なるスコープを定義します。 バージョン"
-"3.0より前の Hibernate では、自作の <literal>ThreadLocal</literal> ベースの"
-"「コンテキスト上のセッション」を 利用するか、 <literal>HibernateUtil</"
-"literal> のようなヘルパークラスを利用するか、 proxy/interception ベースの「コ"
-"ンテキスト上のセッション」を提供する (Spring や Pico のような)サードパー"
-"ティのフレームワークを利用するかのいずれかでした。"
+"Hibernate を使ったアプリケーションは、ほとんど、なんらかの形で「コンテキスト"
+"上の」セッションが必要になります。「コンテキスト上のセッション」は、特定のコ"
+"ンテキストのスコープのなかで有効なセッションのことです。しかし、通常アプリ"
+"ケーションごとにコンテキストを構成するものの定義は異なります。しかも、異なる"
+"複数のコンテキストは、現時点に対して異なるスコープを定義します。バージョン3.0"
+"より前の Hibernate では、自作の <literal>ThreadLocal</literal> ベースの「コン"
+"テキスト上のセッション」を利用するか、 <literal>HibernateUtil</literal> のよ"
+"うなヘルパークラスを利用するか、 proxy/interception ベースの「コンテキスト上"
+"のセッション」を提供する (Spring や Pico のような)サードパーティのフレーム"
+"ワークを利用するかのいずれかでした。"
 
 #. Tag: para
-#: architecture.xml:309
 #, fuzzy, no-c-format
 msgid ""
 "Starting with version 3.0.1, Hibernate added the <literal>SessionFactory."
@@ -509,20 +468,19 @@
 "deployed into a <literal>J2EE</literal> container. Based on that, the "
 "<literal>JTA</literal>-based contextual sessions are all you need to use."
 msgstr ""
-"バージョン 3.0.1 から、Hibernate には <literal>SessionFactory."
-"getCurrentSession()</literal> が 加わりました。 これは、 <literal>JTA</"
+"バージョン 3.0.1 から、 Hibernate には <literal>SessionFactory."
+"getCurrentSession()</literal> メソッドが加わりました。これは、 <literal>JTA</"
 "literal> トランザクションの使用を前提にしています。 <literal>JTA</literal> ト"
 "ランザクションは、現在のセッションのスコープとコンテキストの両方を定義しま"
-"す。 Hibernate チームは、次のことを主張します。 巨大なスタンドアロンの "
+"す。 Hibernate チームは、次のことを主張します。巨大なスタンドアロンの "
 "<literal>JTA TransactionManager</literal> 実装が成熟したら、 <literal>J2EE</"
-"literal> コンテナ上にデプロイされるかどうかにかかわらず、 ほとんどの(すべて"
-"とは言わないが)アプリケーションが、 <literal>JTA</literal> トランザクション"
-"管理を使用すべきであると。 この考えに基づくと、 <literal>JTA</literal> ベース"
-"の「コンテキスト上のセッション」を 使うしかないでしょう。"
+"literal> コンテナ上にデプロイされるかどうかにかかわらず、ほとんどの(すべてと"
+"は言わないが)アプリケーションが、 <literal>JTA</literal> トランザクション管"
+"理を使用すべきであると。この考えに基づくと、 <literal>JTA</literal> ベースの"
+"「コンテキスト上のセッション」を使うしかないでしょう。"
 
 #. Tag: para
-#: architecture.xml:319
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, as of version 3.1, the processing behind <literal>SessionFactory."
 "getCurrentSession()</literal> is now pluggable. To that end, a new extension "
@@ -532,14 +490,13 @@
 "pluggability of the scope and context of defining current sessions."
 msgstr ""
 "しかし、バージョン 3.1 からは、 <literal>SessionFactory.getCurrentSession()</"
-"literal> の後の処理が、 プラガブルになりました。 これを受けて、現在のセッショ"
-"ンを定義するスコープとコンテキストのプラガビリティを可能にするために、 新しい"
-"拡張インタフェース ( <literal>org.hibernate.context.CurrentSessionContext</"
-"literal> ) と 新しい構成パラメータ ( <literal>hibernate."
+"literal> の後の処理が、プラガブルになりました。これを受けて、現在のセッション"
+"を定義するスコープとコンテキストのプラガビリティを可能にするために、新しい拡"
+"張インタフェース ( <literal>org.hibernate.context.CurrentSessionContext</"
+"literal> ) と新しい構成パラメータ ( <literal>hibernate."
 "current_session_context_class</literal> ) が追加されました。"
 
 #. Tag: para
-#: architecture.xml:326
 #, fuzzy, no-c-format
 msgid ""
 "See the Javadocs for the <literal>org.hibernate.context."
@@ -550,15 +507,14 @@
 "implementations of this interface:"
 msgstr ""
 "<literal>org.hibernate.context.CurrentSessionContext</literal> インタフェース"
-"の規約についての 詳細な内容は Javadoc を参照してください。 それには、 "
-"<literal>currentSession()</literal> という1つのメソッドが定義されており、 そ"
-"の実装は、現在の「コンテキスト上のセッション」を追跡することに責任を持ちま"
-"す。 そのまま使えるように、Hibernateはこのインタフェースの実装を2つ提供してい"
-"ます。"
+"の規約についての詳細な内容は Javadoc を参照してください。それには、 "
+"<literal>currentSession()</literal> という1つのメソッドが定義されており、その"
+"実装は、現在の「コンテキスト上のセッション」を追跡することに責任を持ちます。"
+"そのまま使えるように、 Hibernate はこのインタフェースの実装を2つ提供していま"
+"す。"
 
 #. Tag: para
-#: architecture.xml:336
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.context.JTASessionContext</literal>: current sessions "
 "are tracked and scoped by a <literal>JTA</literal> transaction. The "
@@ -566,24 +522,22 @@
 "the Javadocs for details."
 msgstr ""
 "<literal>org.hibernate.context.JTASessionContext</literal> - <literal>JTA</"
-"literal> トランザクションによって、現在のセッションが追跡され、 スコープを決"
-"められます。この処理は、古いJTAだけのアプローチとまったく同じです。 詳細は"
-"Javadocを参照してください。"
+"literal> トランザクションによって、現在のセッションが追跡され、スコープを決め"
+"られます。この処理は、古い JTA だけのアプローチとまったく同じです。詳細は "
+"Javadoc を参照してください。"
 
 #. Tag: para
-#: architecture.xml:344
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.context.ThreadLocalSessionContext</literal>:current "
 "sessions are tracked by thread of execution. See the Javadocs for details."
 msgstr ""
 "<literal>org.hibernate.context.ThreadLocalSessionContext</literal> - スレッド"
-"の実行によって、現在のセッションが追跡されます。 詳細はJavadocを参照してくだ"
+"の実行によって、現在のセッションが追跡されます。詳細は Javadoc を参照してくだ"
 "さい。"
 
 #. Tag: para
-#: architecture.xml:350
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.context.ManagedSessionContext</literal>: current "
 "sessions are tracked by thread of execution. However, you are responsible to "
@@ -591,13 +545,12 @@
 "this class: it does not open, flush, or close a <literal>Session</literal>."
 msgstr ""
 "<literal>org.hibernate.context.ManagedSessionContext</literal> - スレッドの実"
-"行によって、現在のセッションが追跡されます。 しかし、このクラスのstaticメソッ"
-"ドで <literal>Session</literal> インスタンスを バインド/アンバインドする責任"
-"はあなたにあります。 これは決して <literal>Session</literal> をオープン、フ"
+"行によって、現在のセッションが追跡されます。しかし、このクラスの static メ"
+"ソッドで <literal>Session</literal> インスタンスをバインド/アンバインドする責"
+"任はあなたにあります。これは決して <literal>Session</literal> をオープン、フ"
 "ラッシュ、クローズしません。"
 
 #. Tag: para
-#: architecture.xml:359
 #, fuzzy, no-c-format
 msgid ""
 "The first two implementations provide a \"one session - one database "
@@ -610,25 +563,24 @@
 "utilize the JTA interfaces to demarcate transactions. If you execute in an "
 "EJB container that supports CMT, transaction boundaries are defined "
 "declaratively and you do not need any transaction or session demarcation "
-"operations in your code. Refer to <xref linkend=\"transactions\"/> for more "
+"operations in your code. Refer to <xref linkend=\"transactions\" /> for more "
 "information and code examples."
 msgstr ""
-"始めの2つの実装は、\"1セッション - 1データベーストランザクション\" プログラミ"
-"ングモデルを提供します。 これは <emphasis>リクエストごとのセッション"
+"はじめの2つの実装は、「1セッション - 1データベーストランザクション」プログラ"
+"ミングモデルを提供します。これは <emphasis>リクエストごとのセッション"
 "(session-per-request)</emphasis> としても知られており、使われています。 "
 "Hibernate セッションの開始と終了は、データベーストランザクションの期間で決ま"
-"ります。 JTAを使わない普通のJSEで、プログラム上のトランザクション境界設定を行"
-"うなら、 コードから基礎のトランザクションシステムを隠蔽するために、 "
-"Hibernate <literal>Transaction</literal> APIを使うとよいでしょう。 JTAを使う"
-"なら、トランザクションの境界設定には、JTAインターフェイスを使ってください。 "
-"CMTをサポートするEJBコンテナで実行するつもりなら、トランザクション境界は宣言"
-"的に定義できるため、 コード上でトランザクションやセッションの境界を設定する必"
-"要はありません。 さらに詳細な情報やコードの例は、 <xref linkend="
+"ります。 JTA を使わない普通の JSE で、プログラム上のトランザクション境界設定"
+"を行うなら、コードから基礎のトランザクションシステムを隠蔽するために、 "
+"Hibernate <literal>Transaction</literal> API を使うとよいでしょう。 JTA を使"
+"うなら、トランザクションの境界設定には、 JTA インターフェースを使ってくださ"
+"い。 CMT をサポートする EJB コンテナで実行するつもりなら、トランザクション境"
+"界は宣言的に定義できるため、コード上でトランザクションやセッションの境界を設"
+"定する必要はありません。さらに詳細な情報やコードの例は、 <xref linkend="
 "\"transactions\"/> を参照してください。"
 
 #. Tag: para
-#: architecture.xml:371
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>hibernate.current_session_context_class</literal> configuration "
 "parameter defines which <literal>org.hibernate.context."
@@ -643,10 +595,9 @@
 msgstr ""
 "<literal>hibernate.current_session_context_class</literal> 設定パラメータ"
 "は、 <literal>org.hibernate.context.CurrentSessionContext</literal> のどの実"
-"装を使うかを指定します。 下位互換性のため、このパラメータが設定されず "
+"装を使うかを指定します。下位互換性のため、このパラメータが設定されず "
 "<literal>org.hibernate.transaction.TransactionManagerLookup</literal> が設定"
-"されていた場合、 Hibernateは <literal>org.hibernate.context."
-"JTASessionContext</literal> を使うことに注意してください。 通常このパラメータ"
-"の値には、3つの実装の中から使用する実装クラスの名前を直接指定します。 しか"
-"し、\"jta\", \"thread\", \"managed\"というそれぞれの省略名も用意されていま"
-"す。"
+"されていた場合、 Hibernate は <literal>org.hibernate.context."
+"JTASessionContext</literal> を使うことに注意してください。通常このパラメータ"
+"の値には、3つの実装の中から使用する実装クラスの名前を直接指定します。しかし、"
+"\"jta\"、 \"thread\"、 \"managed\"というそれぞれの省略名も用意されています。"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/association_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/association_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/association_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,30 +1,30 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2010-01-06 17:26+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: association_mapping.xml:30
 #, no-c-format
 msgid "Association Mappings"
 msgstr "関連マッピング"
 
 #. Tag: title
-#: association_mapping.xml:33
 #, no-c-format
 msgid "Introduction"
 msgstr "イントロダクション"
 
 #. Tag: para
-#: association_mapping.xml:35
-#, fuzzy, no-c-format
+#, 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, "
@@ -32,47 +32,44 @@
 "use <literal>Person</literal> and <literal>Address</literal> in all the "
 "examples."
 msgstr ""
-"関連マッピングはしばしば理解が最も難しいものになります。 この章では、基本的な"
-"一つ一つのケースについて述べます。 単方向のマッピングから始め、それから双方向"
-"のケースについて考えていきます。 例として、<literal>Person</literal> と "
+"関連マッピングはしばしば理解が最も難しいものになります。この章では、基本的な"
+"一つ一つのケースについて述べます。単方向のマッピングから始め、それから双方向"
+"のケースについて考えていきます。例として、 <literal>Person</literal> と "
 "<literal>Address</literal> を用います。"
 
 #. Tag: para
-#: association_mapping.xml:43
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Associations will be classified by multiplicity and whether or not they map "
 "to an intervening join table."
 msgstr ""
-"関連は、結合テーブルを入れるかかどうかと、 多重度によって分類することにしま"
+"関連は、結合テーブルを入れるかかどうかと、多重度によって分類することにしま"
 "す。"
 
 #. Tag: para
-#: association_mapping.xml:48
-#, fuzzy, no-c-format
+#, 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 ""
-"すべての例でnot nullの外部キーを使用します。 これはHibernateの要件ではありま"
-"せん。 not null制約を外したとしても、マッピングは問題なく動作します。"
+"null 可能な外部キーは従来型データモデリングの中では良い習慣と見なされていない"
+"ため、すべての例で not null の外部キーを使用します。これは Hibernate の要件で"
+"はありません。 not null 制約を外したとしても、マッピングは問題なく動作しま"
+"す。"
 
 #. Tag: title
-#: association_mapping.xml:58
 #, no-c-format
 msgid "Unidirectional associations"
 msgstr "単方向関連"
 
 #. Tag: title
-#: association_mapping.xml:61 association_mapping.xml:132
 #, fuzzy, no-c-format
 msgid "Many-to-one"
-msgstr "多対一"
+msgstr "many-to-one"
 
 #. Tag: para
-#: association_mapping.xml:63
 #, no-c-format
 msgid ""
 "A <emphasis>unidirectional many-to-one association</emphasis> is the most "
@@ -81,192 +78,57 @@
 "<emphasis>単方向多対一関連</emphasis> は単方向関連の中で最も一般的なもので"
 "す。"
 
-#. Tag: programlisting
-#: association_mapping.xml:68
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:69 association_mapping.xml:185
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: association_mapping.xml:74 association_mapping.xml:145
-#: association_mapping.xml:210
 #, fuzzy, no-c-format
 msgid "One-to-one"
-msgstr "一対一"
+msgstr "one-to-one"
 
 #. Tag: para
-#: association_mapping.xml:76
 #, no-c-format
 msgid ""
 "A <emphasis>unidirectional one-to-one association on a foreign key</"
 "emphasis> is almost identical. The only difference is the column unique "
 "constraint."
 msgstr ""
-"<emphasis>外部キーの単方向一対一関連</emphasis> はほとんど同じものです。 唯一"
+"<emphasis>外部キーの単方向一対一関連</emphasis> はほとんど同じものです。唯一"
 "違うのは、カラムのユニークな制約です。"
 
-#. Tag: programlisting
-#: association_mapping.xml:81
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:82 association_mapping.xml:218
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:84
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>unidirectional one-to-one association on a primary key</"
 "emphasis> usually uses a special id generator In this example, however, we "
 "have reversed the direction of the association:"
 msgstr ""
-"<emphasis>主キーの単方向一対一関連</emphasis> は通常、特別なIDジェネレータを"
-"使います。 (この例では関連の方向が逆になっていることに注意してください)"
+"<emphasis>主キーの単方向一対一関連</emphasis> は通常、特別な ID ジェネレータ"
+"を使います。 (この例では関連の方向が逆になっていることに注意してください)"
 
-#. Tag: programlisting
-#: association_mapping.xml:90
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" constrained=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:91 association_mapping.xml:226
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"create table Person ( personId bigint not null primary key )\n"
-"create table Address ( personId bigint not null primary key )\n"
-"        ]]>"
-msgstr ""
-
 #. Tag: title
-#: association_mapping.xml:96 association_mapping.xml:118
 #, fuzzy, no-c-format
 msgid "One-to-many"
-msgstr "一対多"
+msgstr "one-to-many"
 
 #. Tag: para
-#: association_mapping.xml:98
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>unidirectional one-to-many association on a foreign key</"
 "emphasis> is an unusual case, and is not recommended."
 msgstr ""
-"<emphasis>外部キーの単方向一対多関連</emphasis> はとても特殊なケースで、 あま"
+"<emphasis>外部キーの単方向一対多関連</emphasis> はとても特殊なケースで、あま"
 "り推奨されていません。"
 
-#. Tag: programlisting
-#: association_mapping.xml:103
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\">\n"
-"        <key column=\"personId\" \n"
-"            not-null=\"true\"/>\n"
-"        <one-to-many class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:104
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:106
-#, fuzzy, no-c-format
 msgid "You should instead use a join table for this kind of association."
 msgstr "このような関連のために結合テーブルを使うことをお薦めします。"
 
 #. Tag: title
-#: association_mapping.xml:115
 #, no-c-format
 msgid "Unidirectional associations with join tables"
 msgstr "結合テーブルを使った単方向関連"
 
 #. Tag: para
-#: association_mapping.xml:120
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>unidirectional one-to-many association on a join table</"
 "emphasis> is the preferred option. Specifying <literal>unique=\"true\"</"
@@ -274,200 +136,50 @@
 msgstr ""
 "<emphasis>結合テーブルを使った単方向一対多関連</emphasis> はより好ましいで"
 "す。 <literal>unique=\"true\"</literal> の指定により、多重度が多対多から一対"
-"多 に変わったことに注意して下さい。"
+"多に変わったことに注意して下さい。"
 
-#. Tag: programlisting
-#: association_mapping.xml:126
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:127
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:134
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>unidirectional many-to-one association on a join table</"
 "emphasis> is common when the association is optional. For example:"
 msgstr ""
-"<emphasis>結合テーブルの単方向多対一関連</emphasis> は 関連が任意であるときに"
+"<emphasis>結合テーブルの単方向多対一関連</emphasis> は関連が任意であるときに"
 "非常に一般的なものです。"
 
-#. Tag: programlisting
-#: association_mapping.xml:139
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:140
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:147
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>unidirectional one-to-one association on a join table</emphasis> "
 "is possible, but extremely unusual."
 msgstr ""
-"<emphasis>結合テーブルの単方向一対一関連</emphasis> は、本当に特殊ですが 不可"
+"<emphasis>結合テーブルの単方向一対一関連</emphasis> は、非常に特殊ですが不可"
 "能ではありません。"
 
-#. Tag: programlisting
-#: association_mapping.xml:152
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:153 association_mapping.xml:258
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: association_mapping.xml:158 association_mapping.xml:263
 #, fuzzy, no-c-format
 msgid "Many-to-many"
-msgstr "多対多"
+msgstr "many-to-many"
 
 #. Tag: para
-#: association_mapping.xml:160
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, here is an example of a <emphasis>unidirectional many-to-many "
 "association</emphasis>."
-msgstr "最後に、<emphasis>単方向多対多関連</emphasis> を示します。"
+msgstr "最後に、 <emphasis>単方向多対多関連</emphasis> を示します。"
 
-#. Tag: programlisting
-#: association_mapping.xml:164
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:165 association_mapping.xml:271
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: association_mapping.xml:172
 #, no-c-format
 msgid "Bidirectional associations"
 msgstr "双方向関連"
 
 #. Tag: title
-#: association_mapping.xml:175 association_mapping.xml:236
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "one-to-many / many-to-one"
 msgstr "一対多/多対一"
 
 #. Tag: para
-#: association_mapping.xml:177
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional many-to-one association</emphasis> is the most "
 "common kind of association. The following example illustrates the standard "
@@ -476,34 +188,9 @@
 "<emphasis>双方向多対一関連</emphasis> は最も一般的な関連です。 (標準的な親子"
 "関係です)"
 
-#. Tag: programlisting
-#: association_mapping.xml:183
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <one-to-many class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:187
-#, fuzzy, no-c-format
-msgid ""
 "If you use a <literal>List</literal>, or other indexed collection, set the "
 "<literal>key</literal> column of the foreign key to <literal>not null</"
 "literal>. Hibernate will manage the association from the collections side to "
@@ -512,39 +199,13 @@
 "\"</literal>:"
 msgstr ""
 "<literal>List</literal> (または他のインデックス付きのコレクション)を使うな"
-"ら、 外部キーの <literal>key</literal> カラムを <literal>not null</literal> "
-"に設定し、 コレクション側が各要素のインデックスをメンテナンスするように、 関"
-"連を扱う必要があります (<literal>update=\"false\"</literal> かつ "
-"<literal>insert=\"false\"</literal> と設定して、反対側を仮想的にinverseにしま"
-"す):"
+"ら、外部キーの <literal>key</literal> カラムを <literal>not null</literal> に"
+"設定し、コレクション側が各要素のインデックスをメンテナンスするように、関連を"
+"扱う必要があります (<literal>update=\"false\"</literal> かつ "
+"<literal>insert=\"false\"</literal> と設定して、反対側を仮想的に inverse にし"
+"ます):"
 
-#. Tag: programlisting
-#: association_mapping.xml:195
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"   <id name=\"id\"/>\n"
-"   ...\n"
-"   <many-to-one name=\"address\"\n"
-"      column=\"addressId\"\n"
-"      not-null=\"true\"\n"
-"      insert=\"false\"\n"
-"      update=\"false\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"   <id name=\"id\"/>\n"
-"   ...\n"
-"   <list name=\"people\">\n"
-"      <key column=\"addressId\" not-null=\"true\"/>\n"
-"      <list-index column=\"peopleIdx\"/>\n"
-"      <one-to-many class=\"Person\"/>\n"
-"   </list>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: association_mapping.xml:197
 #, fuzzy, no-c-format
 msgid ""
 "If the underlying foreign key column is <literal>NOT NULL</literal>, it is "
@@ -554,84 +215,35 @@
 "<literal>&lt;column&gt;</literal> element, but on the <literal>&lt;key&gt;</"
 "literal> element."
 msgstr ""
-"もし外部キーカラムが <literal>NOT NULL</literal> であるならば、 コレクション"
+"もし外部キーカラムが <literal>NOT NULL</literal> であるならば、コレクション"
 "マッピングの <literal>&lt;key&gt;</literal> 要素を <literal>not-null=\"true"
-"\"</literal> にすることは重要です。 入れ子になった <literal>&lt;column&gt;</"
+"\"</literal> にすることは重要です。入れ子になった <literal>&lt;column&gt;</"
 "literal> 要素だけではなく、 <literal>&lt;key&gt;</literal> 要素も "
 "<literal>not-null=\"true\"</literal> と定義しないようにしてください。"
 
 #. Tag: para
-#: association_mapping.xml:212
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional one-to-one association on a foreign key</emphasis> "
 "is common:"
 msgstr "<emphasis>外部キーの双方向一対一関連</emphasis> は非常に一般的です。"
 
-#. Tag: programlisting
-#: association_mapping.xml:217
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"   <one-to-one name=\"person\" \n"
-"        property-ref=\"address\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:220
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>bidirectional one-to-one association on a primary key</emphasis> "
 "uses the special id generator:"
 msgstr ""
-"<emphasis>主キーの双方向一対一関連</emphasis> は特殊なIDジェネレータを使いま"
-"す。"
+"<emphasis>主キーの双方向一対一関連</emphasis> は特殊な ID ジェネレータを使い"
+"ます。"
 
-#. Tag: programlisting
-#: association_mapping.xml:225
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <one-to-one name=\"address\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" \n"
-"        constrained=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: association_mapping.xml:233
 #, no-c-format
 msgid "Bidirectional associations with join tables"
 msgstr "結合テーブルを使った双方向関連"
 
 #. Tag: para
-#: association_mapping.xml:238
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is an example of a <emphasis>bidirectional one-to-many "
 "association on a join table</emphasis>. The <literal>inverse=\"true\"</"
@@ -639,62 +251,16 @@
 "the join."
 msgstr ""
 "<emphasis>結合テーブルの双方向一対多関連</emphasis> です。 <literal>inverse="
-"\"true\"</literal> が関連端、コレクション、結合のいずれかに 設定できることに"
-"注意してください。"
+"\"true\"</literal> が関連端、コレクション、結合のいずれかに設定できることに注"
+"意してください。"
 
-#. Tag: programlisting
-#: association_mapping.xml:244
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" \n"
-"        table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        inverse=\"true\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-one name=\"person\"\n"
-"            column=\"personId\"\n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:245
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: association_mapping.xml:250
 #, no-c-format
 msgid "one to one"
 msgstr "一対一"
 
 #. Tag: para
-#: association_mapping.xml:252
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional one-to-one association on a join table</emphasis> "
 "is possible, but extremely unusual."
@@ -702,86 +268,20 @@
 "<emphasis>結合テーブルの双方向一対一関連</emphasis> は非常に特殊ですが、可能"
 "です。"
 
-#. Tag: programlisting
-#: association_mapping.xml:257
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\"\n"
-"        inverse=\"true\">\n"
-"        <key column=\"addressId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"person\"\n"
-"            column=\"personId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:265
-#, fuzzy, no-c-format
-msgid ""
 "Here is an example of a <emphasis>bidirectional many-to-many association</"
 "emphasis>."
-msgstr "最後に、<emphasis>双方向多対多関連</emphasis> を示します。"
+msgstr "最後に、 <emphasis>双方向多対多関連</emphasis> を示します。"
 
-#. Tag: programlisting
-#: association_mapping.xml:269
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-many column=\"personId\"\n"
-"            class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: association_mapping.xml:278
 #, no-c-format
 msgid "More complex association mappings"
 msgstr "より複雑な関連マッピング"
 
 #. Tag: para
-#: association_mapping.xml:280
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "More complex association joins are <emphasis>extremely</emphasis> rare. "
 "Hibernate handles more complex situations by using SQL fragments embedded in "
@@ -790,54 +290,25 @@
 "<literal>effectiveEndDate</literal> and <literal>effectiveStartDate</"
 "literal>columns, it would be mapped as follows:"
 msgstr ""
-"より複雑な関連結合は <emphasis>極めて</emphasis> 稀です。 マッピングドキュメ"
-"ントにSQL文を埋め込むことで、 さらに複雑な状況を扱うことができます。 例えば、"
-"<literal>accountNumber</literal>, <literal>effectiveEndDate</literal>, "
-"<literal>effectiveStartDate</literal> カラムを持つaccount(口座)情報の履歴を"
-"扱うテーブルは、 以下のようにマッピングします。"
+"より複雑な関連結合は <emphasis>極めて</emphasis> 稀です。マッピングドキュメン"
+"トに SQL 文を埋め込むことで、さらに複雑な状況を扱うことができます。例えば、 "
+"<literal>accountNumber</literal> 、 <literal>effectiveEndDate</literal> 、 "
+"<literal>effectiveStartDate</literal> カラムを持つ account (口座)情報の履歴"
+"を扱うテーブルは、以下のようにマッピングします。"
 
-#. Tag: programlisting
-#: association_mapping.xml:289
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<properties name=\"currentAccountKey\">\n"
-"    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
-"    <property name=\"currentAccount\" type=\"boolean\">\n"
-"        <formula>case when effectiveEndDate is null then 1 else 0 end</"
-"formula>\n"
-"    </property>\n"
-"</properties>\n"
-"<property name=\"effectiveEndDate\" type=\"date\"/>\n"
-"<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:291
-#, fuzzy, no-c-format
-msgid ""
 "You can then map an association to the <emphasis>current</emphasis> "
 "instance, the one with null <literal>effectiveEndDate</literal>, by using:"
 msgstr ""
 "そして、関連を <emphasis>現時点の</emphasis> インスタンス "
-"(<literal>effectiveEndDate</literal> がnullであるもの)にマッピングします。 "
-"以下のようになります:"
+"(<literal>effectiveEndDate</literal> が null であるもの)にマッピングしま"
+"す。以下のようになります:"
 
-#. Tag: programlisting
-#: association_mapping.xml:296
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
-"        property-ref=\"currentAccountKey\"\n"
-"        class=\"AccountInfo\">\n"
-"    <column name=\"accountNumber\"/>\n"
-"    <formula>'1'</formula>\n"
-"</many-to-one>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:298
-#, fuzzy, no-c-format
-msgid ""
 "In a more complex example, imagine that the association between "
 "<literal>Employee</literal> and <literal>Organization</literal> is "
 "maintained in an <literal>Employment</literal> table full of historical "
@@ -845,37 +316,818 @@
 "emphasis> employer, the one with the most recent <literal>startDate</"
 "literal>, could be mapped in the following way:"
 msgstr ""
-"さらに複雑な例では、<literal>Employee(従業員)</literal> と "
+"さらに複雑な例では、 <literal>Employee(従業員)</literal> と "
 "<literal>Organization(組織)</literal> 間の関連が <literal>Employment(雇"
-"用)</literal> テーブルで保持される場合を想像してください。 このテーブルには"
-"雇用データの履歴がすべて含まれます。 すると従業員の <emphasis>最も最近の</"
+"用)</literal> テーブルで保持される場合を想像してください。このテーブルには雇"
+"用データの履歴がすべて含まれます。すると従業員の <emphasis>最も最近の</"
 "emphasis> 雇用者を表す関連 (最も最近の <literal>startDate</literal> を持つも"
 "の)は、このようにマッピングできます:"
 
-#. Tag: programlisting
-#: association_mapping.xml:306
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<join>\n"
-"    <key column=\"employeeId\"/>\n"
-"    <subselect>\n"
-"        select employeeId, orgId \n"
-"        from Employments \n"
-"        group by orgId \n"
-"        having startDate = max(startDate)\n"
-"    </subselect>\n"
-"    <many-to-one name=\"mostRecentEmployer\" \n"
-"            class=\"Organization\" \n"
-"            column=\"orgId\"/>\n"
-"</join>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:308
-#, fuzzy, 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やcriteriaクエリを"
-"使う方がより実践的です。"
+"この機能は非常に強力です。しかしこのような場合、普通は HQL や criteria クエリ"
+"を使う方がより実践的です。"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"addressId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ 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 ""
+#~ "create table Person ( personId bigint not null primary key, addressId "
+#~ "bigint not null )\n"
+#~ "create table Address ( addressId bigint not null primary key )"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"addressId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ 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 ""
+#~ "create table Person ( personId bigint not null primary key, addressId "
+#~ "bigint not null unique )\n"
+#~ "create table Address ( addressId bigint not null primary key )"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" constrained=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"foreign\"&gt;\n"
+#~ "            &lt;param name=\"property\"&gt;person&lt;/param&gt;\n"
+#~ "        &lt;/generator&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;one-to-one name=\"person\" constrained=\"true\"/&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[\n"
+#~ "create table Person ( personId bigint not null primary key )\n"
+#~ "create table Address ( personId bigint not null primary key )\n"
+#~ "        ]]>"
+#~ msgstr ""
+#~ "create table Person ( personId bigint not null primary key )\n"
+#~ "create table Address ( personId bigint not null primary key )"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        <one-to-many class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;set name=\"addresses\"&gt;\n"
+#~ "        &lt;key column=\"personId\" \n"
+#~ "            not-null=\"true\"/&gt;\n"
+#~ "        &lt;one-to-many class=\"Address\"/&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"addressId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ 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 ""
+#~ "create table Person ( personId bigint not null primary key )\n"
+#~ "create table Address ( addressId bigint not null primary key, personId "
+#~ "bigint not null )"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;set name=\"addresses\" table=\"PersonAddress\"&gt;\n"
+#~ "        &lt;key column=\"personId\"/&gt;\n"
+#~ "        &lt;many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"addressId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ 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 ""
+#~ "create table Person ( personId bigint not null primary key )\n"
+#~ "create table PersonAddress ( personId not null, addressId bigint \n"
+#~ "    not null primary key )\n"
+#~ "create table Address ( addressId bigint not null primary key )"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\"&gt;\n"
+#~ "        &lt;key column=\"personId\" unique=\"true\"/&gt;\n"
+#~ "        &lt;many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"/&gt;\n"
+#~ "    &lt;/join&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"addressId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ 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 ""
+#~ "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 )"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\"&gt;\n"
+#~ "        &lt;key column=\"personId\" \n"
+#~ "            unique=\"true\"/&gt;\n"
+#~ "        &lt;many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/&gt;\n"
+#~ "    &lt;/join&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"addressId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ 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 ""
+#~ "create table Person ( personId bigint not null primary key )\n"
+#~ "create table PersonAddress ( personId bigint not null primary key, "
+#~ "addressId bigint\n"
+#~ "    not null unique )\n"
+#~ "create table Address ( addressId bigint not null primary key )"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;set name=\"addresses\" table=\"PersonAddress\"&gt;\n"
+#~ "        &lt;key column=\"personId\"/&gt;\n"
+#~ "        &lt;many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"addressId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ 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 ""
+#~ "create table Person ( personId bigint not null primary key )\n"
+#~ "create table PersonAddress ( personId bigint not null, addressId bigint "
+#~ "not null, \n"
+#~ "    primary key (personId, addressId) )\n"
+#~ "create table Address ( addressId bigint not null primary key )"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <one-to-many class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"addressId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;set name=\"people\" inverse=\"true\"&gt;\n"
+#~ "        &lt;key column=\"addressId\"/&gt;\n"
+#~ "        &lt;one-to-many class=\"Person\"/&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <many-to-one name=\"address\"\n"
+#~ "      column=\"addressId\"\n"
+#~ "      not-null=\"true\"\n"
+#~ "      insert=\"false\"\n"
+#~ "      update=\"false\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <list name=\"people\">\n"
+#~ "      <key column=\"addressId\" not-null=\"true\"/>\n"
+#~ "      <list-index column=\"peopleIdx\"/>\n"
+#~ "      <one-to-many class=\"Person\"/>\n"
+#~ "   </list>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "   &lt;id name=\"id\"/&gt;\n"
+#~ "   ...\n"
+#~ "   &lt;many-to-one name=\"address\"\n"
+#~ "      column=\"addressId\"\n"
+#~ "      not-null=\"true\"\n"
+#~ "      insert=\"false\"\n"
+#~ "      update=\"false\"/&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "   &lt;id name=\"id\"/&gt;\n"
+#~ "   ...\n"
+#~ "   &lt;list name=\"people\"&gt;\n"
+#~ "      &lt;key column=\"addressId\" not-null=\"true\"/&gt;\n"
+#~ "      &lt;list-index column=\"peopleIdx\"/&gt;\n"
+#~ "      &lt;one-to-many class=\"Person\"/&gt;\n"
+#~ "   &lt;/list&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "   <one-to-one name=\"person\" \n"
+#~ "        property-ref=\"address\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"addressId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "   &lt;one-to-one name=\"person\" \n"
+#~ "        property-ref=\"address\"/&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"address\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" \n"
+#~ "        constrained=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;one-to-one name=\"address\"/&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"foreign\"&gt;\n"
+#~ "            &lt;param name=\"property\"&gt;person&lt;/param&gt;\n"
+#~ "        &lt;/generator&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;one-to-one name=\"person\" \n"
+#~ "        constrained=\"true\"/&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        inverse=\"true\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;set name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\"&gt;\n"
+#~ "        &lt;key column=\"personId\"/&gt;\n"
+#~ "        &lt;many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"addressId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;join table=\"PersonAddress\" \n"
+#~ "        inverse=\"true\" \n"
+#~ "        optional=\"true\"&gt;\n"
+#~ "        &lt;key column=\"addressId\"/&gt;\n"
+#~ "        &lt;many-to-one name=\"person\"\n"
+#~ "            column=\"personId\"\n"
+#~ "            not-null=\"true\"/&gt;\n"
+#~ "    &lt;/join&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ 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 ""
+#~ "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 )"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\"\n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"addressId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\"&gt;\n"
+#~ "        &lt;key column=\"personId\" \n"
+#~ "            unique=\"true\"/&gt;\n"
+#~ "        &lt;many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/&gt;\n"
+#~ "    &lt;/join&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"addressId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\"\n"
+#~ "        inverse=\"true\"&gt;\n"
+#~ "        &lt;key column=\"addressId\" \n"
+#~ "            unique=\"true\"/&gt;\n"
+#~ "        &lt;many-to-one name=\"person\"\n"
+#~ "            column=\"personId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/&gt;\n"
+#~ "    &lt;/join&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-many column=\"personId\"\n"
+#~ "            class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"personId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;set name=\"addresses\" table=\"PersonAddress\"&gt;\n"
+#~ "        &lt;key column=\"personId\"/&gt;\n"
+#~ "        &lt;many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"addressId\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;set name=\"people\" inverse=\"true\" table=\"PersonAddress\"&gt;\n"
+#~ "        &lt;key column=\"addressId\"/&gt;\n"
+#~ "        &lt;many-to-many column=\"personId\"\n"
+#~ "            class=\"Person\"/&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<properties name=\"currentAccountKey\">\n"
+#~ "    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
+#~ "    <property name=\"currentAccount\" type=\"boolean\">\n"
+#~ "        <formula>case when effectiveEndDate is null then 1 else 0 end</"
+#~ "formula>\n"
+#~ "    </property>\n"
+#~ "</properties>\n"
+#~ "<property name=\"effectiveEndDate\" type=\"date\"/>\n"
+#~ "<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
+#~ msgstr ""
+#~ "&lt;properties name=\"currentAccountKey\"&gt;\n"
+#~ "    &lt;property name=\"accountNumber\" type=\"string\" not-null=\"true\"/"
+#~ "&gt;\n"
+#~ "    &lt;property name=\"currentAccount\" type=\"boolean\"&gt;\n"
+#~ "        &lt;formula&gt;case when effectiveEndDate is null then 1 else 0 "
+#~ "end&lt;/formula&gt;\n"
+#~ "    &lt;/property&gt;\n"
+#~ "&lt;/properties&gt;\n"
+#~ "&lt;property name=\"effectiveEndDate\" type=\"date\"/&gt;\n"
+#~ "&lt;property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/"
+#~ "&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
+#~ "        property-ref=\"currentAccountKey\"\n"
+#~ "        class=\"AccountInfo\">\n"
+#~ "    <column name=\"accountNumber\"/>\n"
+#~ "    <formula>'1'</formula>\n"
+#~ "</many-to-one>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"currentAccountInfo\" \n"
+#~ "        property-ref=\"currentAccountKey\"\n"
+#~ "        class=\"AccountInfo\"&gt;\n"
+#~ "    &lt;column name=\"accountNumber\"/&gt;\n"
+#~ "    &lt;formula&gt;'1'&lt;/formula&gt;\n"
+#~ "&lt;/many-to-one&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<join>\n"
+#~ "    <key column=\"employeeId\"/>\n"
+#~ "    <subselect>\n"
+#~ "        select employeeId, orgId \n"
+#~ "        from Employments \n"
+#~ "        group by orgId \n"
+#~ "        having startDate = max(startDate)\n"
+#~ "    </subselect>\n"
+#~ "    <many-to-one name=\"mostRecentEmployer\" \n"
+#~ "            class=\"Organization\" \n"
+#~ "            column=\"orgId\"/>\n"
+#~ "</join>]]>"
+#~ msgstr ""
+#~ "&lt;join&gt;\n"
+#~ "    &lt;key column=\"employeeId\"/&gt;\n"
+#~ "    &lt;subselect&gt;\n"
+#~ "        select employeeId, orgId \n"
+#~ "        from Employments \n"
+#~ "        group by orgId \n"
+#~ "        having startDate = max(startDate)\n"
+#~ "    &lt;/subselect&gt;\n"
+#~ "    &lt;many-to-one name=\"mostRecentEmployer\" \n"
+#~ "            class=\"Organization\" \n"
+#~ "            column=\"orgId\"/&gt;\n"
+#~ "&lt;/join&gt;"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/basic_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/basic_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/basic_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,154 +1,79 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-06 10:49+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: basic_mapping.xml:29
 #, no-c-format
 msgid "Basic O/R Mapping"
-msgstr "基本的なO/Rマッピング"
+msgstr "基本的な O/R マッピング"
 
 #. Tag: title
-#: basic_mapping.xml:32
 #, no-c-format
 msgid "Mapping declaration"
 msgstr "マッピング定義"
 
 #. Tag: para
-#: basic_mapping.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Object/relational mappings are usually defined in an XML document. The "
 "mapping document is designed to be readable and hand-editable. The mapping "
 "language is Java-centric, meaning that mappings are constructed around "
 "persistent class declarations and not table declarations."
 msgstr ""
-"オブジェクト/リレーショナルマッピングは通常XMLドキュメントで定義します。 マッ"
-"ピングドキュメントは、読みやすく手作業で編集しやすいようにデザインされていま"
-"す。 マッピング言語はJava中心、つまりテーブル定義ではなく永続クラスの定義に基"
-"づいて構築されています。"
+"オブジェクト/リレーショナルマッピングは通常 XML ドキュメントで定義します。"
+"マッピングドキュメントは、読みやすく手作業で編集しやすいようにデザインされて"
+"います。マッピング言語は Java 中心、つまりテーブル定義ではなく永続クラスの定"
+"義に基づいて構築されています。"
 
 #. Tag: para
-#: basic_mapping.xml:41
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please note that even though many Hibernate users choose to write the XML by "
 "hand, a number of tools exist to generate the mapping document. These "
 "include XDoclet, Middlegen and AndroMDA."
 msgstr ""
-"多くのHibernateユーザはXMLマッピングの記述を手作業で行いますが、 XDoclet, "
-"Middlegen, AndroMDAというようなマッピングドキュメントを生成するツールが いく"
-"つか存在します。"
+"多くの Hibernate ユーザーは XML マッピングの記述を手作業で行いますが、 "
+"XDoclet, Middlegen, AndroMDA というようなマッピングドキュメントを生成するツー"
+"ルがいくつか存在することを覚えておいてください。"
 
 #. Tag: para
-#: basic_mapping.xml:47
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is an example mapping:"
 msgstr "サンプルのマッピングから始めましょう:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:51
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"      \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"          \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"        <class name=\"Cat\"\n"
-"            table=\"cats\"\n"
-"            discriminator-value=\"C\">\n"
-"\n"
-"                <id name=\"id\">\n"
-"                        <generator class=\"native\"/>\n"
-"                </id>\n"
-"\n"
-"                <discriminator column=\"subclass\"\n"
-"                     type=\"character\"/>\n"
-"\n"
-"                <property name=\"weight\"/>\n"
-"\n"
-"                <property name=\"birthdate\"\n"
-"                    type=\"date\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"color\"\n"
-"                    type=\"eg.types.ColorUserType\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"sex\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"litterId\"\n"
-"                    column=\"litterId\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <many-to-one name=\"mother\"\n"
-"                    column=\"mother_id\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <set name=\"kittens\"\n"
-"                    inverse=\"true\"\n"
-"                    order-by=\"litter_id\">\n"
-"                        <key column=\"mother_id\"/>\n"
-"                        <one-to-many class=\"Cat\"/>\n"
-"                </set>\n"
-"\n"
-"                <subclass name=\"DomesticCat\"\n"
-"                    discriminator-value=\"D\">\n"
-"\n"
-"                        <property name=\"name\"\n"
-"                            type=\"string\"/>\n"
-"\n"
-"                </subclass>\n"
-"\n"
-"        </class>\n"
-"\n"
-"        <class name=\"Dog\">\n"
-"                <!-- mapping for Dog could go here -->\n"
-"        </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:53
-#, fuzzy, no-c-format
-msgid ""
 "We will now discuss the content of the mapping document. We will only "
 "describe, however, the document elements and attributes that are used by "
 "Hibernate at runtime. The mapping document also contains some extra optional "
 "attributes and elements that affect the database schemas exported by the "
 "schema export tool (for example, the <literal> not-null</literal> attribute)."
 msgstr ""
-"マッピングドキュメントの内容を説明します。。 ただし、ここではHibernateが実行"
-"時に使うドキュメント要素と属性についてのみ説明します。 マッピングドキュメント"
+"マッピングドキュメントの内容を説明します。ただし、ここでは Hibernate が実行時"
+"に使うドキュメント要素と属性についてのみ説明します。マッピングドキュメント"
 "は、いくつかのオプション属性と要素を含んでいます(例えば <literal>not-null</"
-"literal> 属性)。 それらはスキーマエクスポートツールが出力するデータベースス"
+"literal> 属性)。それらはスキーマエクスポートツールが出力するデータベースス"
 "キーマに影響を与えるものです。"
 
 #. Tag: title
-#: basic_mapping.xml:64
 #, no-c-format
 msgid "Doctype"
 msgstr "Doctype"
 
 #. Tag: para
-#: basic_mapping.xml:66
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All XML mappings should declare the doctype shown. The actual DTD can be "
 "found at the URL above, in the directory <literal>hibernate-x.x.x/src/org/"
@@ -157,22 +82,20 @@
 "lookups of the DTD using an Internet connection, check the DTD declaration "
 "against the contents of your classpath."
 msgstr ""
-"XMLマッピングでは、お見せしたようなドキュメント型を必ず定義すべきです。 実際"
-"のDTDは、上記のURLの <literal>hibernate-x.x.x/src/org/hibernate</literal> "
-"ディレクトリ、 または <literal>hibernate.jar</literal> 内にあります。 "
-"Hibernateは常に、そのクラスパス内でDTDを探し始めます。 インターネットにある"
-"DTDファイルを探そうとしたなら、 クラスパスの内容を見て、DTD宣言を確認してくだ"
-"さい。"
+"XML マッピングでは、お見せしたようなドキュメント型を必ず定義すべきです。実際"
+"の DTD は、上記の URL の <literal>hibernate-x.x.x/src/org/hibernate</"
+"literal> ディレクトリ、または <literal>hibernate.jar</literal> 内にありま"
+"す。 Hibernate は常に、そのクラスパス内で DTD を探し始めます。インターネット"
+"にある DTD ファイルを探そうとしたなら、クラスパスの内容を見て、 DTD 宣言を確"
+"認してください。"
 
 #. Tag: title
-#: basic_mapping.xml:76
 #, no-c-format
 msgid "EntityResolver"
-msgstr "エンティティ・リゾルバ"
+msgstr "エンティティリゾルバ"
 
 #. Tag: para
-#: basic_mapping.xml:77
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will first attempt to resolve DTDs in its classpath. It does this "
 "is by registering a custom <literal>org.xml.sax.EntityResolver</literal> "
@@ -180,29 +103,27 @@
 "custom <literal>EntityResolver</literal> recognizes two different systemId "
 "namespaces:"
 msgstr ""
-"前述したように、Hibernateはまずクラスパス内でDTDを解決しようとします。 "
-"<literal>org.xml.sax.EntityResolver</literal> のカスタム実装を XMLファイルを"
-"読み込むためのSAXReaderに登録することによって、DTDを解決します。 このカスタム"
-"の <literal>EntityResolver</literal> は2つの異なるシステムID名前空間を認識し"
-"ます。"
+"前述したように、 Hibernate はまずクラスパス内で DTD を解決しようとします。 "
+"<literal>org.xml.sax.EntityResolver</literal> のカスタム実装を XML ファイルを"
+"読み込むための SAXReader に登録することによって、 DTD を解決します。このカス"
+"タムの <literal>EntityResolver</literal> は2つの異なるシステム ID 名前空間を"
+"認識します。"
 
 #. Tag: para
-#: basic_mapping.xml:85
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "a <literal>hibernate namespace</literal> is recognized whenever the resolver "
 "encounters a systemId starting with <literal>http://hibernate.sourceforge."
 "net/</literal>. The resolver attempts to resolve these entities via the "
 "classloader which loaded the Hibernate classes."
 msgstr ""
-"<literal>Hibernate名前空間</literal> は、リゾルバが <literal>http://"
-"hibernate.sourceforge.net/</literal> で始まるシステムIDに到達したときに、 認"
-"識されます。 そしてリゾルバは、Hibernateのクラスをロードしたクラスローダを用"
-"いて、 これらのエンティティを解決しようとします。"
+"<literal>hibernate namespace</literal> は、リゾルバが <literal>http://"
+"hibernate.sourceforge.net/</literal> で始まるシステム ID に到達したときに認識"
+"されます。そしてリゾルバは、 Hibernate のクラスをロードしたクラスローダを用い"
+"て、これらのエンティティを解決しようとします。"
 
 #. Tag: para
-#: basic_mapping.xml:94
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "a <literal>user namespace</literal> is recognized whenever the resolver "
 "encounters a systemId using a <literal>classpath://</literal> URL protocol. "
@@ -210,60 +131,35 @@
 "thread context classloader and (2) the classloader which loaded the "
 "Hibernate classes."
 msgstr ""
-"<literal>ユーザ名前空間</literal> は、リゾルバが URLプロトコルの "
-"<literal>classpath://</literal> を使ったシステムIDに到達したときに、 認識され"
-"ます。そしてリゾルバは、(1)カレントスレッドのコンテキストクラスローダー、 ま"
-"たは(2)Hibernateのクラスをロードしたクラスローダを使って、 これらのエンティ"
-"ティを解決しようとします。"
+"<literal>user namespace</literal> は、リゾルバが URL プロトコルの "
+"<literal>classpath://</literal> を使ったシステム ID に到達したときに、認識さ"
+"れます。そしてリゾルバは、 (1) カレントスレッドのコンテキストクラスローダー、"
+"または (2) Hibernate のクラスをロードしたクラスローダを使って、これらのエン"
+"ティティを解決しようとします。"
 
 #. Tag: para
-#: basic_mapping.xml:103
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The following is an example of utilizing user namespacing:"
-msgstr "下記は、ユーザ名前空間を使った例です:"
+msgstr "下記は、ユーザー名前空間を使った例です:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:106
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\" [\n"
-"    <!ENTITY types SYSTEM \"classpath://your/domain/types.xml\">\n"
-"]>\n"
-"\n"
-"<hibernate-mapping package=\"your.domain\">\n"
-"    <class name=\"MyEntity\">\n"
-"        <id name=\"id\" type=\"my-custom-id-type\">\n"
-"            ...\n"
-"        </id>\n"
-"    <class>\n"
-"    &types;\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:107
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Where <literal>types.xml</literal> is a resource in the <literal>your."
 "domain</literal> package and contains a custom <link linkend=\"mapping-types-"
 "custom\">typedef</link>."
 msgstr ""
 "ここで <literal>types.xml</literal> は <literal>your.domain</literal> パッ"
-"ケージ内のリソースであり、 カスタム <xref linkend=\"mapping-types-custom"
-"\">typedef</xref> を含むます。"
+"ケージ内のリソースであり、カスタム型定義 <xref linkend=\"mapping-types-custom"
+"\"/> を含みます。"
 
 #. Tag: title
-#: basic_mapping.xml:115
 #, fuzzy, no-c-format
 msgid "Hibernate-mapping"
 msgstr "hibernate-mapping"
 
 #. Tag: para
-#: basic_mapping.xml:117
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This element has several optional attributes. The <literal>schema</literal> "
 "and <literal>catalog</literal> attributes specify that tables referred to in "
@@ -276,47 +172,29 @@
 "literal> attribute allows you to use unqualified class names in the query "
 "language."
 msgstr ""
-"この要素にはいくつかオプション属性があります。<literal>schema</literal> 属性"
-"と <literal>catalog</literal> 属性は、 このマッピングが参照するテーブルが、こ"
-"の属性によって指定されたスキーマと(または)カタログに属することを指定します。 "
+"この要素にはいくつかオプション属性があります。 <literal>schema</literal> 属性"
+"と <literal>catalog</literal> 属性は、このマッピングが参照するテーブルが、こ"
+"の属性によって指定されたスキーマと(または)カタログに属することを指定します。"
 "この属性が指定されると、テーブル名は与えられたスキーマ名とカタログ名で修飾さ"
-"れます。これらの属性が指定されていなければ、 テーブル名は修飾されません。"
+"れます。これらの属性が指定されていなければ、テーブル名は修飾されません。 "
 "<literal>default-cascade</literal> 属性は、 <literal>cascade</literal> 属性を"
-"指定していないプロパティやコレクションに、 どのカスケードスタイルを割り当てる"
-"かを指定します。 <literal>auto-import</literal> 属性は、 クエリ言語内で修飾さ"
+"指定していないプロパティやコレクションに、どのカスケードスタイルを割り当てる"
+"かを指定します。 <literal>auto-import</literal> 属性は、クエリ言語内で修飾さ"
 "れていないクラス名を、デフォルトで使えるようにします。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:138
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping\n"
-"         schema=\"schemaName\"\n"
-"         catalog=\"catalogName\"\n"
-"         default-cascade=\"cascade_style\"\n"
-"         default-access=\"field|property|ClassName\"\n"
-"         default-lazy=\"true|false\"\n"
-"         auto-import=\"true|false\"\n"
-"         package=\"package.name\"\n"
-" />]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:141
-#, fuzzy, no-c-format
 msgid "<literal>schema</literal> (optional): the name of a database schema."
 msgstr "<literal>schema</literal>(オプション):データベーススキーマの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>catalog</literal> (optional): the name of a database catalog."
 msgstr ""
 "<literal>catalog</literal> (オプション):データベースカタログの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:151
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>default-cascade</literal> (optional - defaults to <literal>none</"
 "literal>): a default cascade style."
@@ -325,21 +203,19 @@
 "<literal>none</literal>): デフォルトのカスケードスタイル。"
 
 #. Tag: para
-#: basic_mapping.xml:157
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>default-access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate should use for accessing all properties. "
 "It can be a custom implementation of <literal>PropertyAccessor</literal>."
 msgstr ""
 "<literal>default-access</literal> (オプション - デフォルトは "
-"<literal>property</literal> ): Hibernateがプロパティにアクセスする際に採る"
+"<literal>property</literal> ): Hibernate がプロパティにアクセスする際に取る"
 "べき戦略。 <literal>PropertyAccessor</literal> を実装することでカスタマイズ可"
 "能。"
 
 #. Tag: para
-#: basic_mapping.xml:164
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>default-lazy</literal> (optional - defaults to <literal>true</"
 "literal>): the default value for unspecified <literal>lazy</literal> "
@@ -350,42 +226,38 @@
 "ンマッピングに対するデフォルト値。"
 
 #. Tag: para
-#: basic_mapping.xml:171
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>auto-import</literal> (optional - defaults to <literal>true</"
 "literal>): specifies whether we can use unqualified class names of classes "
 "in this mapping in the query language."
 msgstr ""
 "<literal>auto-import</literal> (オプション - デフォルトは <literal>true</"
-"literal>): クエリ言語内で、(このマッピング内のクラスの)修飾されていないク"
+"literal>):クエリ言語内で、(このマッピング内のクラスの)修飾されていないク"
 "ラス名を使えるかどうかを指定します。"
 
 #. Tag: para
-#: basic_mapping.xml:178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>package</literal> (optional): specifies a package prefix to use for "
 "unqualified class names in the mapping document."
 msgstr ""
 "<literal>package</literal> (オプション): マッピングドキュメント内で修飾されて"
-"いないクラス名に対して割り当てる、 パッケージの接頭辞(prefix)を指定します。"
+"いないクラス名に対して割り当てる、パッケージの接頭辞 (prefix) を指定します。"
 
 #. Tag: para
-#: basic_mapping.xml:186
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you have two persistent classes with the same unqualified name, you "
 "should set <literal>auto-import=\"false\"</literal>. An exception will "
 "result if you attempt to assign two classes to the same \"imported\" name."
 msgstr ""
 "(修飾されていない)同じ名前の永続クラスが2つあるなら、 <literal>auto-import="
-"\"false\"</literal> を設定すべきです。 2つのクラスに”インポートされた”同じ名"
-"前を割り当てようとすると、Hibernateは例外を投げます。"
+"\"false\"</literal> を設定すべきです。2つのクラスに\"インポートされた\"同じ名"
+"前を割り当てようとすると、 Hibernate は例外を送出します。"
 
 #. Tag: para
-#: basic_mapping.xml:192
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>hibernate-mapping</literal> element allows you to nest several "
 "persistent <literal>&lt;class&gt;</literal> mappings, as shown above. It is, "
@@ -396,82 +268,47 @@
 "<literal>Animal.hbm.xml</literal>."
 msgstr ""
 "<literal>hibernate-mapping</literal> 要素は、最初の例で示したようにいくつかの"
-"永続 <literal>&lt;class&gt;</literal> マッピングをネストできます。 しかし、1"
+"永続 <literal>&lt;class&gt;</literal> マッピングをネストできます。しかし、1"
 "つのマッピングファイルではただひとつの永続クラス(またはひとつのクラス階層)に"
-"マッピングするようにし、 さらに永続スーパークラスの後で指定するべきでしょう"
-"(いくつかのツールはこのようなマッピングファイルを想定しています)。 例えば次の"
-"ようになります。: <literal>Cat.hbm.xml</literal> , <literal>Dog.hbm.xml</"
+"マッピングするようにし、さらに永続スーパークラスの後で指定するべきでしょう(い"
+"くつかのツールはこのようなマッピングファイルを想定しています)。例えば次のよう"
+"になります。: <literal>Cat.hbm.xml</literal> , <literal>Dog.hbm.xml</"
 "literal> , または継承を使うなら <literal>Animal.hbm.xml</literal> 。"
 
 #. Tag: title
-#: basic_mapping.xml:205
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Class"
-msgstr "class"
+msgstr "Class"
 
 #. Tag: para
-#: basic_mapping.xml:207
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can declare a persistent class using the <literal>class</literal> "
 "element. For example:"
-msgstr "<literal>class</literal> 要素を使って、永続クラスを宣言できます。"
+msgstr "<literal>class</literal> 要素を使って、永続クラスを宣言できます:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:235
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class\n"
-"        name=\"ClassName\"\n"
-"        table=\"tableName\"\n"
-"        discriminator-value=\"discriminator_value\"\n"
-"        mutable=\"true|false\"\n"
-"        schema=\"owner\"\n"
-"        catalog=\"catalog\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        select-before-update=\"true|false\"\n"
-"        polymorphism=\"implicit|explicit\"\n"
-"        where=\"arbitrary sql where condition\"\n"
-"        persister=\"PersisterClass\"\n"
-"        batch-size=\"N\"\n"
-"        optimistic-lock=\"none|version|dirty|all\"\n"
-"        lazy=\"true|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        check=\"arbitrary sql check condition\"\n"
-"        rowid=\"rowid\"\n"
-"        subselect=\"SQL expression\"\n"
-"        abstract=\"true|false\"\n"
-"        node=\"element-name\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:238
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal> (optional): the fully qualified Java class name of "
 "the persistent class or interface. If this attribute is missing, it is "
 "assumed that the mapping is for a non-POJO entity."
 msgstr ""
-"<literal>name</literal> (オプション):永続クラス(またはインターフェイス)の"
-"完全修飾Javaクラス名。 もしこの属性を指定しなければ、POJOではないエンティティ"
-"に対するマッピングとして扱われます。"
+"<literal>name</literal> (オプション):永続クラス(またはインターフェース)の"
+"完全修飾 Java クラス名。もしこの属性が欠落している場合、 POJO ではないエン"
+"ティティに対するマッピングとして扱われます。"
 
 #. Tag: para
-#: basic_mapping.xml:245
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>table</literal> (optional - defaults to the unqualified class "
 "name): the name of its database table."
 msgstr ""
 "<literal>table</literal> (オプション - デフォルトは修飾されていないクラス"
-"名):データベーステーブルの名前"
+"名):データベーステーブルの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:251
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>discriminator-value</literal> (optional - defaults to the class "
 "name): a value that distinguishes individual subclasses that is used for "
@@ -479,86 +316,70 @@
 "<literal>not null</literal>."
 msgstr ""
 "<literal>discriminator-value</literal> (オプション - デフォルトはクラス名): "
-"ポリモーフィックな振る舞いに使われる個々のサブクラスを識別するための値。 値"
-"は <literal>null</literal> か <literal>not null</literal> のいずれかを取りま"
-"す。"
+"ポリモーフィックな振る舞いに使われる個々のサブクラスを識別するための値。値は "
+"<literal>null</literal> か <literal>not null</literal> のいずれかを取ります。"
 
 #. Tag: para
-#: basic_mapping.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>true</literal>): "
 "specifies that instances of the class are (not) mutable."
 msgstr ""
-"<literal>mutable</literal> (オプション、 デフォルトは <literal>true</"
+"<literal>mutable</literal> (オプション、デフォルトは <literal>true</"
 "literal> ): そのクラスのインスタンスが更新可能(または不可能)であることを指"
 "定します。"
 
 #. Tag: para
-#: basic_mapping.xml:264 basic_mapping.xml:2231
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>schema</literal> (optional): overrides the schema name specified by "
 "the root <literal>&lt;hibernate-mapping&gt;</literal> element."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>schema</literal> (オプション): ルートの <literal>&lt;hibernate-"
-"mapping&gt;</literal> 要素で指定されたスキーマ名をオーバーライドします。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>schema</literal> (オプション): ルートの <literal>&lt;hibernate-"
-"mapping&gt;</literal> 要素で指定したスキーマ名を オーバーライドします。"
+"mapping&gt;</literal> 要素で指定したスキーマ名をオーバーライドします。"
 
 #. Tag: para
-#: basic_mapping.xml:270 basic_mapping.xml:2237
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>catalog</literal> (optional): overrides the catalog name specified "
 "by the root <literal>&lt;hibernate-mapping&gt;</literal> element."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>catalog</literal> (オプション):ルートの <literal>&lt;hibernate-"
-"mapping&gt;</literal> 要素で指定されたカタログ名をオーバーライドします。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>catalog</literal> (オプション): ルートの <literal>&lt;hibernate-"
-"mapping&gt;</literal> 要素で指定したカタログ名を オーバーライドします。"
+"mapping&gt;</literal> 要素で指定したカタログ名をオーバーライドします。"
 
 #. Tag: para
-#: basic_mapping.xml:276
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies an interface to use for lazy "
 "initializing proxies. You can specify the name of the class itself."
 msgstr ""
-"<literal>proxy</literal> (オプション):遅延初期化プロキシに使うインターフェ"
-"イスを指定します。 永続化するクラス名そのものを指定することも可能です。"
+"<literal>proxy</literal> (オプション):遅延初期化プロキシに使うインター"
+"フェースを指定します。永続化するクラス名そのものを指定することも可能です。"
 
 #. Tag: para
-#: basic_mapping.xml:282
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>dynamic-update</literal> (optional - defaults to <literal>false</"
 "literal>): specifies that <literal>UPDATE</literal> SQL should be generated "
 "at runtime and can contain only those columns whose values have changed."
 msgstr ""
 "<literal>dynamic-update</literal> (オプション、 デフォルトは "
-"<literal>false</literal> ): 値が変更されたカラムだけを含むSQLの "
+"<literal>false</literal> ):値が変更されたカラムだけを含む SQL の "
 "<literal>UPDATE</literal> 文を、実行時に生成することを指定します。"
 
 #. Tag: para
-#: basic_mapping.xml:289
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>dynamic-insert</literal> (optional - defaults to <literal>false</"
 "literal>): specifies that <literal>INSERT</literal> SQL should be generated "
 "at runtime and contain only the columns whose values are not null."
 msgstr ""
 "<literal>dynamic-insert</literal> (オプション, デフォルトは <literal>false</"
-"literal> ): 値がnullではないカラムだけを含むSQLの <literal>INSERT</"
+"literal> ):値が null ではないカラムだけを含む SQL の <literal>INSERT</"
 "literal> 文を、実行時に生成することを指定します。"
 
 #. Tag: para
-#: basic_mapping.xml:296
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>select-before-update</literal> (optional - defaults to "
 "<literal>false</literal>): specifies that Hibernate should <emphasis>never</"
@@ -568,40 +389,38 @@
 "Hibernate perform an extra SQL <literal>SELECT</literal> to determine if an "
 "<literal>UPDATE</literal> is actually required."
 msgstr ""
-"<literal>select-before-update</literal> (オプション, デフォルトは "
-"<literal>false</literal>): オブジェクトが変更されたのが確実でないならば、"
-"HibernateがSQLの <literal>UPDATE</literal> を <emphasis>決して実行しない</"
-"emphasis> ことを指定します。 ある特定の場合(実際的には、一時オブジェクトが "
-"<literal>update()</literal> を使い、 新しいセッションと関連付けられた時だ"
-"け)、<literal>UPDATE</literal> が実際に必要かどうかを決定するために、 "
-"Hibernateが余分なSQLの <literal>SELECT</literal> 文を実行することを意味しま"
-"す。"
+"<literal>select-before-update</literal> (オプション、デフォルトは "
+"<literal>false</literal>): オブジェクトが変更されたのが確実でないならば、 "
+"Hibernate が SQL の <literal>UPDATE</literal> を <emphasis>決して実行しない</"
+"emphasis> ことを指定します。ある特定の場合(実際的には、一時オブジェクトが "
+"<literal>update()</literal> を使い、新しいセッションと関連付けられた時だ"
+"け)、 <literal>UPDATE</literal> が実際に必要かどうかを決定するために、 "
+"Hibernate が余分な SQL の <literal>SELECT</literal> 文を実行することを意味し"
+"ます。"
 
 #. Tag: para
-#: basic_mapping.xml:306
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>polymorphism</literal> (optional - defaults to <literal>implicit</"
 "literal>): determines whether implicit or explicit query polymorphism is "
 "used."
 msgstr ""
-"(optional, デフォルトでは <literal>implicit</literal> ): implicit(暗黙)か"
-"explicit(明示)の、 どちらのクエリポリモーフィズムを使うか決定します。"
+"<literal>polymorphism</literal> (オプション、デフォルトでは "
+"<literal>implicit</literal> ): implicit(暗黙)かexplicit(明示)の、どちらの"
+"クエリポリモーフィズムを使うか決定します。"
 
 #. Tag: para
-#: basic_mapping.xml:312
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>where</literal> (optional): specifies an arbitrary SQL "
 "<literal>WHERE</literal> condition to be used when retrieving objects of "
 "this class."
 msgstr ""
 "<literal>where</literal> (オプション): このクラスのオブジェクトを検索する"
-"ときに使用する、任意のSQLの <literal>WHERE</literal> 条件を指定します。"
+"ときに使用する、任意の SQL の <literal>WHERE</literal> 条件を指定します。"
 
 #. Tag: para
-#: basic_mapping.xml:318
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>persister</literal> (optional): specifies a custom "
 "<literal>ClassPersister</literal>."
@@ -610,69 +429,63 @@
 "<literal>ClassPersister</literal> を指定します。"
 
 #. Tag: para
-#: basic_mapping.xml:323
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>batch-size</literal> (optional - defaults to <literal>1</literal>): "
 "specifies a \"batch size\" for fetching instances of this class by "
 "identifier."
 msgstr ""
-"<literal>batch-size</literal> (オプション, デフォルトは <literal>1</"
+"<literal>batch-size</literal> (オプション、デフォルトは <literal>1</"
 "literal> ): 識別子でこのクラスのインスタンスを復元するときの「バッチサイ"
 "ズ」を指定します。"
 
 #. Tag: para
-#: basic_mapping.xml:329
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>version</"
 "literal>): determines the optimistic locking strategy."
 msgstr ""
-"<literal>optimistic-lock</literal> (オプション,デフォルトは "
+"<literal>optimistic-lock</literal> (オプション、デフォルトは "
 "<literal>version</literal> ): 楽観ロック戦略を決定します。"
 
 #. Tag: para
-#: basic_mapping.xml:335
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional): lazy fetching can be disabled by setting "
 "<literal>lazy=\"false\"</literal>."
 msgstr ""
 "<literal>lazy</literal> (オプション): <literal>lazy=\"false\"</literal> と"
-"設定することで、 遅延フェッチができなくなります。"
+"設定することで、遅延フェッチができなくなります。"
 
 #. Tag: para
-#: basic_mapping.xml:341
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>entity-name</literal> (optional - defaults to the class name): "
 "Hibernate3 allows a class to be mapped multiple times, potentially to "
 "different tables. It also allows entity mappings that are represented by "
 "Maps or XML at the Java level. In these cases, you should provide an "
 "explicit arbitrary name for the entity. See <xref linkend=\"persistent-"
-"classes-dynamicmodels\"/> and <xref linkend=\"xml\"/> for more information."
+"classes-dynamicmodels\" /> and <xref linkend=\"xml\" /> for more information."
 msgstr ""
 "<literal>entity-name</literal> (オプション、デフォルトはクラス名): "
-"Hibernate3ではクラスが複数回マッピングでき(場合によっては違うテーブルに対し"
-"ても)、 JavaレベルでMapやXMLで表現されるエンティティマッピングが可能です。 "
-"これらの場合、エンティティに対して任意の名前を、明示的に付けなくてはなりませ"
-"ん。 詳しくは <xref linkend=\"persistent-classes-dynamicmodels\"/> と <xref "
-"linkend=\"xml\"/> を参照してください。"
+"Hibernate3 ではクラスが複数回マッピングでき(場合によっては違うテーブルに対し"
+"ても)、 Java レベルで Map や XML で表現されるエンティティマッピングが可能で"
+"す。これらの場合、エンティティに対して任意の名前を、明示的に付けなくてはなり"
+"ません。 詳しくは <xref linkend=\"persistent-classes-dynamicmodels\"/> と "
+"<xref linkend=\"xml\"/> を参照してください。"
 
 #. Tag: para
-#: basic_mapping.xml:351
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>check</literal> (optional): an SQL expression used to generate a "
 "multi-row <emphasis>check</emphasis> constraint for automatic schema "
 "generation."
 msgstr ""
-"<literal>check</literal> (オプション):自動的にスキーマを生成するために、 "
-"複数行の <emphasis>check</emphasis> 制約を生成するSQL式。"
+"<literal>check</literal> (オプション):自動的にスキーマを生成するために、複"
+"数行の <emphasis>check</emphasis> 制約を生成する SQL 式。"
 
 #. Tag: para
-#: basic_mapping.xml:357
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>rowid</literal> (optional): Hibernate can use ROWIDs on databases. "
 "On Oracle, for example, Hibernate can use the <literal>rowid</literal> extra "
@@ -680,15 +493,14 @@
 "literal>. A ROWID is an implementation detail and represents the physical "
 "location of a stored tuple."
 msgstr ""
-"<literal>rowid</literal> (オプション):Hibernateは、それをサポートしている"
-"データベースでROWIDと 呼ばれるものを使うことができます。 例えばOracleを使って"
-"いるとき、このオプションに <literal>rowid</literal> を設定すれば、 Hiberante"
-"はupdateを高速化するために <literal>rowid</literal> という特別なカラムを使う"
-"ことができます。 ROWIDは詳細な実装であり、保存されたタプルの物理的な位置を表"
-"しています。"
+"<literal>rowid</literal> (オプション): Hibernate は、それをサポートしてい"
+"るデータベースで ROWID と 呼ばれるものを使うことができます。例えば Oracle を"
+"使っているとき、このオプションに <literal>rowid</literal> を設定すれば、 "
+"Hiberante は update を高速化するために <literal>rowid</literal> という特別な"
+"カラムを使うことができます。 ROWID は詳細な実装であり、保存されたタプルの物理"
+"的な位置を表しています。"
 
 #. Tag: para
-#: basic_mapping.xml:364
 #, fuzzy, no-c-format
 msgid ""
 "<literal>subselect</literal> (optional): maps an immutable and read-only "
@@ -696,13 +508,12 @@
 "instead of a base table. See below for more information."
 msgstr ""
 "<literal>subselect</literal> (オプション):不変かつ読み取り専用であるエン"
-"ティティを データベースの副問合せ(subselect)にマッピングします。 もし元の"
-"テーブルの代わりにビューを持ちたければ有用ですが、 そうでないのなら有用ではあ"
-"りません。より詳しい情報は下記を参照してください。"
+"ティティをデータベースの副問合せ(subselect)にマッピングします。もし元のテー"
+"ブルの代わりにビューを持ちたければ有用ですが、そうでないのなら有用ではありま"
+"せん。より詳しい情報は下記を参照してください。"
 
 #. Tag: para
-#: basic_mapping.xml:371
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>abstract</literal> (optional): is used to mark abstract "
 "superclasses in <literal>&lt;union-subclass&gt;</literal> hierarchies."
@@ -711,8 +522,7 @@
 "</literal> 階層内の抽象スーパークラスにマークするために使います。"
 
 #. Tag: para
-#: basic_mapping.xml:379
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is acceptable for the named persistent class to be an interface. You can "
 "declare implementing classes of that interface using the <literal>&lt;"
@@ -720,27 +530,25 @@
 "emphasis> inner class. Specify the class name using the standard form i.e. "
 "<literal>e.g.Foo$Bar</literal>."
 msgstr ""
-"永続クラスの名前にインターフェイスを指定してもまったく問題ありません。 そのと"
-"きは <literal>&lt;subclass&gt;</literal> 要素を使って、 そのインターフェイス"
-"を実装するクラスを定義してください。 <emphasis>static</emphasis> な内部クラス"
-"でも永続化できます。 そのときは標準形式、例えば <literal>eg.Foo$Bar</"
+"永続クラスの名前にインターフェースを指定してもまったく問題ありません。そのと"
+"きは <literal>&lt;subclass&gt;</literal> 要素を使って、そのインターフェースを"
+"実装するクラスを定義してください。 <emphasis>static</emphasis> な内部クラスで"
+"も永続化できます。そのときは標準形式、例えば <literal>eg.Foo&#36;Bar</"
 "literal> を使ってクラス名を指定してください。"
 
 #. Tag: para
-#: basic_mapping.xml:386
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Immutable classes, <literal>mutable=\"false\"</literal>, cannot be updated "
 "or deleted by the application. This allows Hibernate to make some minor "
 "performance optimizations."
 msgstr ""
-"<literal>mutable=\"false\"</literal> 指定をした不変クラスは、 アプリケーショ"
-"ンによる更新や削除が出来ないことがあります。 これにより、Hibernateがパフォー"
-"マンスを少し改善します。"
+"<literal>mutable=\"false\"</literal> 指定をした不変クラスは、アプリケーション"
+"による更新や削除が出来ないことがあります。これにより、 Hibernate がパフォーマ"
+"ンスを少し改善します。"
 
 #. Tag: para
-#: basic_mapping.xml:391
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The optional <literal>proxy</literal> attribute enables lazy initialization "
 "of persistent instances of the class. Hibernate will initially return CGLIB "
@@ -749,14 +557,13 @@
 "proxies\" below."
 msgstr ""
 "オプションの <literal>proxy</literal> 属性により、クラスの永続インスタンスの"
-"遅延初期化が可能になります。 Hibernateは最初に、指定したインターフェイスを実"
-"装したCGLIBプロキシを返します。 実際の永続オブジェクトはプロキシのメソッドを"
-"呼び出すときにロードします。 以下の「遅延初期化のためのプロキシ」を参照してく"
+"遅延初期化が可能になります。 Hibernate は最初に、指定したインターフェースを実"
+"装した CGLIB プロキシを返します。実際の永続オブジェクトはプロキシのメソッドを"
+"呼び出すときにロードします。以下の「遅延初期化のためのプロキシ」を参照してく"
 "ださい。"
 
 #. Tag: para
-#: basic_mapping.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Implicit</emphasis> polymorphism means that instances of the class "
 "will be returned by a query that names any superclass or implemented "
@@ -772,24 +579,23 @@
 "table This allows a \"lightweight\" class that contains a subset of the "
 "table columns."
 msgstr ""
-"<emphasis>暗黙的</emphasis> ポリモーフィズムとは、次の二つを意味しています。 "
-"一つはクラスのインスタンスが、スーパークラスや実装したインターフェイス、また"
-"そのクラスを指定するクエリによって返されることで、 もう一つはそのクラスのサブ"
+" <emphasis>暗黙的</emphasis> ポリモーフィズムとは、次の二つを意味しています。"
+"一つはクラスのインスタンスが、スーパークラスや実装したインターフェース、また"
+"そのクラスを指定するクエリによって返されることで、もう一つはそのクラスのサブ"
 "クラスのインスタンスが、そのクラス自身を指定したクエリによって返されることで"
-"す。 また、<emphasis>明示的</emphasis> ポリモーフィズムとは、次の二つを意味し"
-"ています。 一つはクラスのインスタンスが、そのクラスを明示的に指定したクエリに"
-"よってのみ返されることで、 もう一つはクラスを指定したクエリが、<literal>&lt;"
+"す。また、 <emphasis>明示的</emphasis> ポリモーフィズムとは、次の二つを意味し"
+"ています。一つはクラスのインスタンスが、そのクラスを明示的に指定したクエリに"
+"よってのみ返されることで、もう一つはクラスを指定したクエリが、 <literal>&lt;"
 "class&gt;</literal> 要素の中で <literal>&lt;subclass&gt;</literal> や "
 "<literal>&lt;joined-subclass&gt;</literal> とマッピングされているサブクラスの"
-"インスタンスだけを返すことです。 ほとんどの用途ではデフォルトの "
-"<literal>polymorphism=\"implicit\"</literal> が適切です。 明示的なポリモー"
-"フィズムは、2つの違ったクラスが同じテーブルにマッピングされているときに有用で"
-"す (これによってテーブルカラムのサブセットを含む、「軽量な」クラスが可能にな"
-"ります)。"
+"インスタンスだけを返すことです。ほとんどの用途ではデフォルトの "
+"<literal>polymorphism=\"implicit\"</literal> が適切です。明示的なポリモーフィ"
+"ズムは、2つの違ったクラスが同じテーブルにマッピングされているときに有用です "
+"(これによってテーブルカラムのサブセットを含む、「軽量な」クラスが可能になり"
+"ます)。"
 
 #. Tag: para
-#: basic_mapping.xml:410
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>persister</literal> attribute lets you customize the "
 "persistence strategy used for the class. You can, for example, specify your "
@@ -801,17 +607,16 @@
 "a simple example of \"persistence\" to a <literal>Hashtable</literal>."
 msgstr ""
 "<literal>persister</literal> 属性を指定することで、クラスの永続化戦略をカスタ"
-"マイズできます。 例えば <literal>org.hibernate.persister.EntityPersister</"
-"literal> 自身のサブクラスを指定したり、 また例えばストアドプロシージャコー"
-"ル、フラットファイルへシリアライズ、 LDAPなどを通した永続性を実装する "
-"<literal>org.hibernate.persister.ClassPersister</literal> インターフェイスの"
+"マイズできます。例えば <literal>org.hibernate.persister.EntityPersister</"
+"literal> 自身のサブクラスを指定したり、また例えばストアドプロシージャコール、"
+"フラットファイルへシリアライズ、 LDAP などを通した永続性を実装する "
+"<literal>org.hibernate.persister.ClassPersister</literal> インターフェースの"
 "完全に新しい実装を提供できます。簡単な例として <literal>org.hibernate.test."
-"CustomPersister</literal> を見てください(これは <literal>Hashtable</"
+"CustomPersister</literal> を参照してください(これは <literal>Hashtable</"
 "literal> の「永続化」です)。"
 
 #. Tag: para
-#: basic_mapping.xml:421
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>dynamic-update</literal> and <literal>dynamic-insert</literal> "
 "settings are not inherited by subclasses, so they can also be specified on "
@@ -820,14 +625,13 @@
 "cases, they can actually decrease performance in others."
 msgstr ""
 "<literal>dynamic-update</literal> と <literal>dynamic-insert</literal> の設定"
-"はサブクラスに継承されません。 そのため <literal>&lt;subclass&gt;</literal> "
-"や <literal>&lt;joined-subclass&gt;</literal> 要素を指定することも出来ます。 "
+"はサブクラスに継承されません。そのため <literal>&lt;subclass&gt;</literal> "
+"や <literal>&lt;joined-subclass&gt;</literal> 要素を指定することも出来ます。"
 "これらの設定はパフォーマンスを向上させる事もありますが、落とすこともあります"
 "ので、慎重に使用してください。"
 
 #. Tag: para
-#: basic_mapping.xml:429
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use of <literal>select-before-update</literal> will usually decrease "
 "performance. It is useful to prevent a database update trigger being called "
@@ -835,36 +639,32 @@
 "<literal>Session</literal>."
 msgstr ""
 "<literal>select-before-update</literal> の使用は通常パフォーマンスを落としま"
-"す。 もし <literal>Session</literal> へ分離インスタンスのグラフを再追加するな"
-"ら、 データベース更新のトリガを不必要に呼び出すのを避けるという点で、非常に有"
+"す。もし <literal>Session</literal> へ分離インスタンスのグラフを再追加するな"
+"ら、データベース更新のトリガを不必要に呼び出すのを避けるという点で、非常に有"
 "用です。"
 
 #. Tag: para
-#: basic_mapping.xml:435
 #, no-c-format
 msgid ""
 "If you enable <literal>dynamic-update</literal>, you will have a choice of "
 "optimistic locking strategies:"
 msgstr ""
 "<literal>dynamic-update</literal> を有効にすれば、楽観ロック戦略を選ぶことに"
-"なります。"
+"なります:"
 
 #. Tag: para
-#: basic_mapping.xml:441
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>version</literal>: check the version/timestamp columns"
 msgstr ""
-"<literal>version</literal> バージョン/タイムスタンプカラムをチェックします"
+"<literal>version</literal> バージョン/タイムスタンプカラムをチェックします。"
 
 #. Tag: para
-#: basic_mapping.xml:446
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>all</literal>: check all columns"
 msgstr "<literal>all</literal> すべてのカラムをチェックします。"
 
 #. Tag: para
-#: basic_mapping.xml:451
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>dirty</literal>: check the changed columns, allowing some "
 "concurrent updates"
@@ -873,29 +673,26 @@
 "す。"
 
 #. Tag: para
-#: basic_mapping.xml:456
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>none</literal>: do not use optimistic locking"
-msgstr "<literal>none</literal> 楽観ロックを使用しません"
+msgstr "<literal>none</literal> 楽観ロックを使用しません。"
 
 #. Tag: para
-#: basic_mapping.xml:461
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is <emphasis>strongly</emphasis> recommended that you use version/"
 "timestamp columns for optimistic locking with Hibernate. This strategy "
 "optimizes performance and correctly handles modifications made to detached "
 "instances (i.e. when <literal>Session.merge()</literal> is used)."
 msgstr ""
-"Hibernateで楽観的ロック戦略を使うなら、バージョン/タイムスタンプカラムを使う"
-"ことを <emphasis> 非常に</emphasis> 強くお勧めします。 楽観的ロックはパフォー"
-"マンスの観点からも最適であり、さらに分離インスタンスへの修正 (つまり "
+"Hibernate で楽観的ロック戦略を使うなら、バージョン/タイムスタンプカラムを使う"
+"ことを <emphasis>非常に</emphasis> 強くお勧めします。楽観的ロックはパフォーマ"
+"ンスの観点からも最適であり、さらに分離インスタンスへの修正 (つまり "
 "<literal>Session.marge()</literal> が使われるとき) を正確に扱うことのできる"
 "唯一の戦略でもあります。"
 
 #. Tag: para
-#: basic_mapping.xml:468
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is no difference between a view and a base table for a Hibernate "
 "mapping. This is transparent at the database level, although some DBMS do "
@@ -904,53 +701,32 @@
 "schema). In this case, you can map an immutable and read-only entity to a "
 "given SQL subselect expression:"
 msgstr ""
-"Hibernateのマッピングにとってビューと普通のテーブルの間に違いはなく、 データ"
-"ベースレベルでは透過的です (ただしビューを完全にはサポートしていないDBMSもあ"
-"ります。 特に、更新のあるビューに対してはそうです)。 ビューを使いたくても、"
-"データベースで作成できないことがあります (例えば、レガシースキーマの場"
-"合)。 この場合には、不変かつ読み取り専用のエンティティに与えられたSQLの副問"
-"合せ文をマップできます。"
+"Hibernate のマッピングにとってビューと普通のテーブルの間に違いはなく、データ"
+"ベースレベルでは透過的です(ただしビューを完全にはサポートしていない DBMS も"
+"あります。特に、更新のあるビューに対してはそうです)。ビューを使いたくても、"
+"データベースで作成できないことがあります(例えば、レガシースキーマの場合)。"
+"この場合には、不変かつ読み取り専用のエンティティに与えられた SQL の副問合せ文"
+"をマップできます:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:476
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Summary\">\n"
-"    <subselect>\n"
-"        select item.name, max(bid.amount), count(*)\n"
-"        from item\n"
-"        join bid on bid.item_id = item.id\n"
-"        group by item.name\n"
-"    </subselect>\n"
-"    <synchronize table=\"item\"/>\n"
-"    <synchronize table=\"bid\"/>\n"
-"    <id name=\"name\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:478
-#, fuzzy, no-c-format
-msgid ""
 "Declare the tables to synchronize this entity with, ensuring that auto-flush "
 "happens correctly and that queries against the derived entity do not return "
 "stale data. The <literal>&lt;subselect&gt;</literal> is available both as an "
 "attribute and a nested mapping element."
 msgstr ""
-"テーブルをこのエンティティと同期するように定義してください。 オートフラッシュ"
-"が確実に起こるように、また導出エンティティに対するクエリが古いデータを 返さな"
+"テーブルをこのエンティティと同期するように定義してください。オートフラッシュ"
+"が確実に起こるように、また導出エンティティに対するクエリが古いデータを返さな"
 "いようにするためです。 <literal>&lt;subselect&gt;</literal> は属性とネストし"
 "たマッピング属性のどちらでも利用できます。"
 
 #. Tag: title
-#: basic_mapping.xml:488
-#, no-c-format
-msgid "<title>id</title>"
-msgstr ""
+#, fuzzy, no-c-format
+msgid "id"
+msgstr "uuid"
 
 #. Tag: para
-#: basic_mapping.xml:490
 #, no-c-format
 msgid ""
 "Mapped classes <emphasis>must</emphasis> declare the primary key column of "
@@ -960,43 +736,25 @@
 "column."
 msgstr ""
 "マップされたクラスはデータベーステーブルの主キーカラムを定義 <emphasis>しなけ"
-"ればなりません</emphasis> 。 ほとんどのクラスにはインスタンスのユニークな識別"
-"子を保持するJavaBeansスタイルのプロパティもあります。 <literal>&lt;id&gt;</"
-"literal> 要素は、そのプロパティから主キーカラムへのマッピングを定義します。"
+"ればなりません</emphasis> 。ほとんどのクラスにはインスタンスのユニークな識別"
+"子を保持する JavaBeans スタイルのプロパティも持っています。 <literal>&lt;"
+"id&gt;</literal> 要素は、そのプロパティから主キーカラムへのマッピングを定義し"
+"ます。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:505
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id\n"
-"        name=\"propertyName\"\n"
-"        type=\"typename\"\n"
-"        column=\"column_name\"\n"
-"        unsaved-value=\"null|any|none|undefined|id_value\"\n"
-"        access=\"field|property|ClassName\">\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"\n"
-"        <generator class=\"generatorClass\"/>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:508
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal> (optional): the name of the identifier property."
 msgstr "<literal>name</literal>(オプション):識別子プロパティの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:513 basic_mapping.xml:1351
 #, no-c-format
 msgid ""
 "<literal>type</literal> (optional): a name that indicates the Hibernate type."
-msgstr "<literal>type</literal>(オプション):Hibernateの型を示す名前。"
+msgstr "<literal>type</literal>(オプション): Hibernate の型を示す名前。"
 
 #. Tag: para
-#: basic_mapping.xml:518
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of the primary key column."
@@ -1005,57 +763,29 @@
 "ラムの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:524
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to a \"sensible\" "
 "value): an identifier property value that indicates an instance is newly "
 "instantiated (unsaved), distinguishing it from detached instances that were "
 "saved or loaded in a previous session."
 msgstr ""
-"<literal>unsaved-value</literal>(オプション - デフォルトの値はsensible): "
-"インスタンスが新しくインスタンス化された (セーブされていない)ことを示す、識"
-"別子プロパティの値。 以前のSessionでセーブまたはロードされた一時的インスタン"
-"スと区別するために 使います。"
+"<literal>unsaved-value</literal>(オプション - デフォルトの値は "
+"sensible ): インスタンスが新しくインスタンス化された (セーブされていない)"
+"ことを示す、識別子プロパティの値。以前の Session でセーブまたはロードされた分"
+"離インスタンスと区別するために使います。"
 
 #. Tag: para
-#: basic_mapping.xml:532
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate should use for accessing the property "
 "value."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal>(オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へアクセスするためにHibernateが使う戦略です。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>access</literal> (オプション - デフォルトは <literal>property</"
-"literal> ): Hibernateがプロパティの値にアクセスするために使用すべき戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal>(オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal>(オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal>(オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal>(オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。"
+"literal> ): Hibernate がプロパティの値にアクセスするために使用すべき戦略。"
 
 #. Tag: para
-#: basic_mapping.xml:540
 #, no-c-format
 msgid ""
 "If the <literal>name</literal> attribute is missing, it is assumed that the "
@@ -1065,35 +795,31 @@
 "とみなされます。"
 
 #. Tag: para
-#: basic_mapping.xml:545
 #, no-c-format
 msgid ""
 "The <literal>unsaved-value</literal> attribute is almost never needed in "
 "Hibernate3."
 msgstr ""
-"<literal>unsaved-value</literal> 属性はHibernate3ではほとんどの場合、必要では"
-"ありません。"
+"<literal>unsaved-value</literal> 属性は Hibernate3 ではほとんどの場合、必要で"
+"はありません。"
 
 #. Tag: para
-#: basic_mapping.xml:549
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is an alternative <literal>&lt;composite-id&gt;</literal> declaration "
 "that allows access to legacy data with composite keys. Its use is strongly "
 "discouraged for anything else."
 msgstr ""
 "複合キーを持つレガシーデータにアクセスできるように、 <literal>&lt;composite-"
-"id&gt;</literal> という代替のマッピング定義があります。 しかし他の用途への使"
-"用は全くおすすめできません。"
+"id&gt;</literal> という代替のマッピング定義があります。しかし他の用途への使用"
+"は全くおすすめできません。"
 
 #. Tag: title
-#: basic_mapping.xml:555
 #, no-c-format
 msgid "Generator"
 msgstr "ジェネレータ"
 
 #. Tag: para
-#: basic_mapping.xml:557
 #, no-c-format
 msgid ""
 "The optional <literal>&lt;generator&gt;</literal> child element names a Java "
@@ -1102,47 +828,32 @@
 "generator instance, they are passed using the <literal>&lt;param&gt;</"
 "literal> element."
 msgstr ""
-"オプションの <literal>&lt;generator&gt;</literal> 子要素は、 永続クラスのイン"
-"スタンスのユニークな識別子を生成するために使う、Javaクラスを指定します。 ジェ"
-"ネレータインスタンスの設定、もしくは初期化にパラメータが必要であれば、"
+"オプションの <literal>&lt;generator&gt;</literal> 子要素は、永続クラスのイン"
+"スタンスのユニークな識別子を生成するために使う、 Java クラスを指定します。"
+"ジェネレータインスタンスの設定、もしくは初期化にパラメータが必要であれば、 "
 "<literal>&lt;param&gt;</literal> 要素を使って渡すことができます。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:564
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"org.hibernate.id.TableHiLoGenerator\">\n"
-"                <param name=\"table\">uid_table</param>\n"
-"                <param name=\"column\">next_hi_value_column</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:566
-#, fuzzy, no-c-format
-msgid ""
 "All generators implement the interface <literal>org.hibernate.id."
 "IdentifierGenerator</literal>. This is a very simple interface. Some "
 "applications can choose to provide their own specialized implementations, "
 "however, Hibernate provides a range of built-in implementations. The "
 "shortcut names for the built-in generators are as follows:"
 msgstr ""
-"すべてのジェネレータは、インターフェイス <literal>org.hibernate.id."
-"IdentifierGenerator</literal> を実装します。 これはとても単純なインターフェイ"
-"スなので、特別な実装を独自に用意するアプリケーションもあるかもしれません。 し"
-"かしHibernateは組み込みの実装をいくつも用意しています。 組み込みのジェネレー"
-"タには以下のショートカット名があります: <placeholder-1/>"
+"すべてのジェネレータは、 <literal>org.hibernate.id.IdentifierGenerator</"
+"literal> インターフェースを実装します。これはとても単純なインターフェースなの"
+"で、特別な実装を独自に用意するアプリケーションもあるかもしれません。しかし "
+"Hibernate は組み込みの実装をいくつも用意しています。組み込みのジェネレータに"
+"は以下のショートカット名があります:"
 
-#. Tag: literal
-#: basic_mapping.xml:574
-#, no-c-format
-msgid "increment"
-msgstr "increment"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>increment</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:576
 #, no-c-format
 msgid ""
 "generates identifiers of type <literal>long</literal>, <literal>short</"
@@ -1151,54 +862,48 @@
 "cluster.</emphasis>"
 msgstr ""
 "<literal>long</literal> , <literal>short</literal> , <literal>int</literal> "
-"型の識別子を生成します。 これらは他のプロセスが同じテーブルにデータを挿入しな"
+"型の識別子を生成します。これらは他のプロセスが同じテーブルにデータを挿入しな"
 "いときだけユニークです。 <emphasis>クラスタ内では使わないでください</"
 "emphasis> 。"
 
-#. Tag: literal
-#: basic_mapping.xml:585
-#, no-c-format
-msgid "identity"
-msgstr "identity"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>identity</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:587
 #, no-c-format
 msgid ""
 "supports identity columns in DB2, MySQL, MS SQL Server, Sybase and "
 "HypersonicSQL. The returned identifier is of type <literal>long</literal>, "
 "<literal>short</literal> or <literal>int</literal>."
 msgstr ""
-"DB2, MySQL, MS SQL Server, Sybase, HypersonicSQLの識別子カラムを サポートしま"
-"す。 返される識別子の型は <literal>long</literal> , <literal>short</"
+"DB2, MySQL, MS SQL Server, Sybase, HypersonicSQL の識別子カラムをサポートしま"
+"す。返される識別子の型は <literal>long</literal> , <literal>short</"
 "literal> , <literal>int</literal> のいずれかです。"
 
-#. Tag: literal
-#: basic_mapping.xml:595
-#, no-c-format
-msgid "sequence"
-msgstr "sequence"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>sequence</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:597
 #, no-c-format
 msgid ""
 "uses a sequence in DB2, PostgreSQL, Oracle, SAP DB, McKoi or a generator in "
 "Interbase. The returned identifier is of type <literal>long</literal>, "
 "<literal>short</literal> or <literal>int</literal>"
 msgstr ""
-"DB2, PostgreSQL, Oracle, SAP DB, McKoiのシーケンスや、Interbaseのジェネレータ"
-"を使用します。 返される識別子の型は <literal>long</literal> , "
+"DB2, PostgreSQL, Oracle, SAP DB, McKoi のシーケンスや、 Interbase のジェネ"
+"レータを使用します。返される識別子の型は <literal>long</literal> , "
 "<literal>short</literal> , <literal>int</literal> のいずれかです。"
 
-#. Tag: literal
-#: basic_mapping.xml:605
-#, no-c-format
-msgid "hilo"
-msgstr "hilo"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>hilo</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:607
 #, no-c-format
 msgid ""
 "uses a hi/lo algorithm to efficiently generate identifiers of type "
@@ -1209,19 +914,17 @@
 "database."
 msgstr ""
 "<literal>long</literal> , <literal>short</literal> , <literal>int</literal> "
-"型の識別子を効率的に生成するhi/loアルゴリズムを使います。 hi値のソースとし"
+"型の識別子を効率的に生成する hi/lo アルゴリズムを使います。 hi 値のソースとし"
 "て、テーブルとカラムを与えます(デフォルトではそれぞれ "
 "<literal>hibernate_unique_key</literal> と <literal>next_hi</literal> )。 hi/"
-"loアルゴリズムは特定のデータベースに対してのみユニークな識別子を生成します。"
+"lo アルゴリズムは特定のデータベースに対してのみユニークな識別子を生成します。"
 
-#. Tag: literal
-#: basic_mapping.xml:617
-#, no-c-format
-msgid "seqhilo"
-msgstr "seqhilo"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>seqhilo</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:619
 #, no-c-format
 msgid ""
 "uses a hi/lo algorithm to efficiently generate identifiers of type "
@@ -1229,117 +932,104 @@
 "given a named database sequence."
 msgstr ""
 "<literal>long</literal> , <literal>short</literal> , <literal>int</literal> "
-"型の識別子を効率的に生成するhi/loアルゴリズムを使います。 指定されたデータ"
+"型の識別子を効率的に生成する hi/lo アルゴリズムを使います。指定されたデータ"
 "ベースシーケンスを与えます。"
 
-#. Tag: literal
-#: basic_mapping.xml:627
-#, no-c-format
-msgid "uuid"
-msgstr "uuid"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>uuid</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:629
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "uses a 128-bit UUID algorithm to generate identifiers of type string that "
 "are unique within a network (the IP address is used). The UUID is encoded as "
 "a string of 32 hexadecimal digits in length."
 msgstr ""
-"(IPアドレスが使用される)ネットワーク内でユニークな文字列型の識別子を生成する"
-"ために、 128ビットのUUIDアルゴリズムを使用します。UUIDは長さ32の16進数字の文"
-"字列としてエンコードされます。"
+"( IP アドレスが使用される)ネットワーク内でユニークな文字列型の識別子を生成す"
+"るために、 128 ビットの UUID アルゴリズムを使用します。 UUID は長さ 32 の 16 "
+"進数字の文字列としてエンコードされます。"
 
-#. Tag: literal
-#: basic_mapping.xml:637
-#, no-c-format
-msgid "guid"
-msgstr "guid"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>guid</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:639
 #, no-c-format
 msgid "uses a database-generated GUID string on MS SQL Server and MySQL."
-msgstr "MS SQLサーバとMySQLでデータベースが生成するGUID文字列を使用します。"
+msgstr ""
+"MS SQL サーバーと MySQL でデータベースが生成する GUID 文字列を使用します。"
 
-#. Tag: literal
-#: basic_mapping.xml:645
-#, no-c-format
-msgid "native"
-msgstr "native"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>native</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:647
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "selects <literal>identity</literal>, <literal>sequence</literal> or "
 "<literal>hilo</literal> depending upon the capabilities of the underlying "
 "database."
 msgstr ""
-"使用するデータベースの性能により <literal>identity</literal> , "
-"<literal>sequence</literal> , <literal>hilo</literal> のいずれかが選ばれま"
+"使用するデータベースの性能により <literal>identity</literal> 、 "
+"<literal>sequence</literal> 、 <literal>hilo</literal> のいずれかが選ばれま"
 "す。"
 
-#. Tag: literal
-#: basic_mapping.xml:655
-#, no-c-format
-msgid "assigned"
-msgstr "assigned"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>assigned</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:657
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "lets the application assign an identifier to the object before <literal>save"
 "()</literal> is called. This is the default strategy if no <literal>&lt;"
 "generator&gt;</literal> element is specified."
 msgstr ""
-"<literal>save()</literal> が呼ばれる前に、 アプリケーションがオブジェクトに識"
-"別子を代入できるようにします。 <literal>&lt;generator&gt;</literal> が指定さ"
-"れていなければ、これがデフォルトの戦略になります。"
+"<literal>save()</literal> が呼ばれる前に、アプリケーションがオブジェクトに識"
+"別子を代入できるようにします。 <literal>&lt;generator&gt;</literal> 要素が指"
+"定されていなければ、これがデフォルトの戦略になります。"
 
-#. Tag: literal
-#: basic_mapping.xml:665
-#, no-c-format
-msgid "select"
-msgstr "select"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>select</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:667
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "retrieves a primary key, assigned by a database trigger, by selecting the "
 "row by some unique key and retrieving the primary key value."
 msgstr ""
-"あるユニークキーによる行の選択と主キーの値の復元により、 データベーストリガが"
+"あるユニークキーによる行の選択と主キーの値の復元により、データベーストリガが"
 "割り当てた主キーを取得します。"
 
-#. Tag: literal
-#: basic_mapping.xml:674
-#, no-c-format
-msgid "foreign"
-msgstr "foreign"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>foreign</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:676
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "uses the identifier of another associated object. It is usually used in "
 "conjunction with a <literal>&lt;one-to-one&gt;</literal> primary key "
 "association."
 msgstr ""
-"他の関連オブジェクトの識別子を使います。 普通は、<literal>&lt;one-to-one&gt;"
+"他の関連オブジェクトの識別子を使います。普通は、 <literal>&lt;one-to-one&gt;"
 "</literal> 主キー関連と組み合わせて使います。"
 
-#. Tag: literal
-#: basic_mapping.xml:683
+#. Tag: term
 #, no-c-format
-msgid "sequence-identity"
-msgstr "sequence-identity"
+msgid "<literal>sequence-identity</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:685
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "a specialized sequence generation strategy that utilizes a database sequence "
 "for the actual value generation, but combines this with JDBC3 "
@@ -1348,22 +1038,20 @@
 "drivers targeted for JDK 1.4. Comments on these insert statements are "
 "disabled due to a bug in the Oracle drivers."
 msgstr ""
-"a specialized sequence generation strategy which utilizes a database "
-"sequence for the actual value generation, but combines this with JDBC3 "
-"getGeneratedKeys to actually return the generated identifier value as part "
-"of the insert statement execution. This strategy is only known to be "
-"supported on Oracle 10g drivers targetted for JDK 1.4. Note comments on "
-"these insert statements are disabled due to a bug in the Oracle drivers."
+"実際の値の生成のためにデータベースシーケンスを使用する特別なシーケンス生成戦"
+"略ですが、 JDBC3 getGeneratedKeys と結びついて、 INSERT 文の実行の一部として"
+"生成された識別子の値を実際に返します。この戦略は JDK 1.4 を対象とする Oracle "
+"10g のドライバでサポートされていることが知られています。これらの INSERT 文で"
+"のコメントは Oracle のドライバのバグにより無効にされていることに注意してくだ"
+"さい。"
 
 #. Tag: title
-#: basic_mapping.xml:702
 #, no-c-format
 msgid "Hi/lo algorithm"
 msgstr "Hi/lo アルゴリズム"
 
 #. Tag: para
-#: basic_mapping.xml:703
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>hilo</literal> and <literal>seqhilo</literal> generators "
 "provide two alternate implementations of the hi/lo algorithm. The first "
@@ -1371,82 +1059,52 @@
 "available \"hi\" value. Where supported, the second uses an Oracle-style "
 "sequence."
 msgstr ""
-"<literal>hilo</literal> と <literal>seqhilo</literal> ジェネレータは、 識別子"
-"生成の代表的なアプローチであるhi/loアルゴリズムの2つの代替実装を提供します。 "
-"1番目の実装は、次回に利用される\"hi\"値を保持する「特別な」データベーステーブ"
-"ルを 必要とします。 2番目の実装は、Oracleスタイルのシーケンスを使います(サ"
-"ポートされている場合)。"
+"<literal>hilo</literal> と <literal>seqhilo</literal> ジェネレータは、識別子"
+"生成の代表的なアプローチである hi/lo アルゴリズムの2つの代替実装を提供しま"
+"す。1番目の実装は、次回に利用される \"hi\" 値を保持する「特別な」データベース"
+"テーブルを必要とします。2番目の実装は、 Oracle スタイルのシーケンスを使います"
+"(サポートされている場合)。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:710
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"hilo\">\n"
-"                <param name=\"table\">hi_value</param>\n"
-"                <param name=\"column\">next_value</param>\n"
-"                <param name=\"max_lo\">100</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:712
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"seqhilo\">\n"
-"                <param name=\"sequence\">hi_value</param>\n"
-"                <param name=\"max_lo\">100</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:714
-#, fuzzy, no-c-format
-msgid ""
 "Unfortunately, you cannot use <literal>hilo</literal> when supplying your "
 "own <literal>Connection</literal> to Hibernate. When Hibernate uses an "
 "application server datasource to obtain connections enlisted with JTA, you "
 "must configure the <literal>hibernate.transaction.manager_lookup_class</"
 "literal>."
 msgstr ""
-"残念ながらHibernateへの独自の <literal>Connection</literal> を提供するときに"
-"は、<literal>hilo</literal> を使えません。 HibernateがJTAでリストされている接"
-"続を取得するためにアプリケーションサーバーのデータソースを使用しているときに"
-"は、 <literal>hibernate.transaction.manager_lookup_class</literal> を適切に設"
-"定しなければなりません。"
+"残念ながら Hibernate への独自の <literal>Connection</literal> を提供するとき"
+"には、 <literal>hilo</literal> を使えません。 Hibernate が JTA でリストされて"
+"いる接続を取得するためにアプリケーションサーバーのデータソースを使用している"
+"ときには、 <literal>hibernate.transaction.manager_lookup_class</literal> を適"
+"切に設定しなければなりません。"
 
 #. Tag: title
-#: basic_mapping.xml:723
 #, no-c-format
 msgid "UUID algorithm"
 msgstr "UUID アルゴリズム"
 
 #. Tag: para
-#: basic_mapping.xml:724
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The UUID contains: IP address, startup time of the JVM that is accurate to a "
 "quarter second, system time and a counter value that is unique within the "
 "JVM. It is not possible to obtain a MAC address or memory address from Java "
 "code, so this is the best option without using JNI."
 msgstr ""
-"UUIDには以下のものが含まれます: IPアドレス、JVMのスタートアップタイム(4分の"
-"1秒の正確さ)、 システム時間、(JVMに対してユニークな)カウンタ値。 Javaコー"
-"ドからMACアドレスやメモリアドレスを取得することはできないので、 JNIが使えない"
-"ときの最良の方法です。"
+"UUID には以下のものが含まれます: IP アドレス、 JVM のスタートアップタイム(4"
+"分の1秒の正確さ)、システム時間、( JVM に対してユニークな)カウンタ値。 "
+"Java コードから MAC アドレスやメモリアドレスを取得することはできないので、 "
+"JNI が使えないときの最良の方法です。"
 
 #. Tag: title
-#: basic_mapping.xml:733
 #, no-c-format
 msgid "Identity columns and sequences"
 msgstr "識別子カラムとシーケンス"
 
 #. Tag: para
-#: basic_mapping.xml:734
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For databases that support identity columns (DB2, MySQL, Sybase, MS SQL), "
 "you can use <literal>identity</literal> key generation. For databases that "
@@ -1455,55 +1113,31 @@
 "strategies require two SQL queries to insert a new object. For example:"
 msgstr ""
 "識別子カラムをサポートしているデータベース(DB2, MySQL, Sybase, MS SQL)で"
-"は、 <literal>identity</literal> キー生成を使えます。 シーケンスをサポートす"
-"るデータベース(DB2, Oracle, PostgreSQL, Interbase, McKoi, SAP DB)では、 "
-"<literal>sequence</literal> スタイルのキー生成を使えます。 どちらの戦略も、新"
-"しいオブジェクトを挿入するために、SQLクエリを2つ必要とします。"
+"は、 <literal>identity</literal> キー生成が使えます。シーケンスをサポートする"
+"データベース(DB2, Oracle, PostgreSQL, Interbase, McKoi, SAP DB)では、 "
+"<literal>sequence</literal> スタイルのキー生成が使えます。どちらの戦略も、新"
+"しいオブジェクトを挿入するために、 SQL クエリを2つ必要とします。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:742
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-"        <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">person_id_sequence</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:744
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\" unsaved-value=\"0"
-"\">\n"
-"        <generator class=\"identity\"/>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:746
-#, fuzzy, no-c-format
-msgid ""
 "For cross-platform development, the <literal>native</literal> strategy will, "
 "depending on the capabilities of the underlying database, choose from the "
 "<literal>identity</literal>, <literal>sequence</literal> and <literal>hilo</"
 "literal> strategies."
 msgstr ""
 "クロスプラットフォームの開発では、<literal>native</literal> 戦略は "
-"<literal>identity</literal> , <literal>sequence</literal> , <literal>hilo</"
-"literal> 戦略の中から1つを選択しますが、 これは使用しているデータベースの能力"
+"<literal>identity</literal> 、 <literal>sequence</literal> 、 <literal>hilo</"
+"literal> 戦略の中から1つを選択しますが、これは使用しているデータベースの能力"
 "に依存します。"
 
 #. Tag: title
-#: basic_mapping.xml:754
 #, no-c-format
 msgid "Assigned identifiers"
 msgstr "識別子の割り当て"
 
 #. Tag: para
-#: basic_mapping.xml:755
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want the application to assign identifiers, as opposed to having "
 "Hibernate generate them, you can use the <literal>assigned</literal> "
@@ -1513,16 +1147,15 @@
 "behavior if you do not specify a <literal>&lt;generator&gt;</literal> "
 "element."
 msgstr ""
-"アプリケーションに識別子を割り当てさせたいのであれば(Hibernateが生成するもの"
-"ではなく)、 <literal>assigned</literal> ジェネレータを使うことができます。 "
+"アプリケーションに識別子を割り当てさせたいのであれば( Hibernate が生成するも"
+"のではなく)、 <literal>assigned</literal> ジェネレータを使うことができます。"
 "この特別なジェネレータは、すでにオブジェクトの識別子プロパティに代入された値"
-"を 識別子に使います。このジェネレータは主キーが代理キーの代わりに自然キーであ"
+"を識別子に使います。このジェネレータは主キーが代理キーの代わりに自然キーであ"
 "る場合に使用します。 <literal>&lt;generator&gt;</literal> 要素を指定しない場"
 "合のデフォルトの動作になります。"
 
 #. Tag: para
-#: basic_mapping.xml:764
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>assigned</literal> generator makes Hibernate use "
 "<literal>unsaved-value=\"undefined\"</literal>. This forces Hibernate to go "
@@ -1530,62 +1163,46 @@
 "there is a version or timestamp property, or you define <literal>Interceptor."
 "isUnsaved()</literal>."
 msgstr ""
-"<literal>assigned</literal> ジェネレータを選択すると、 Hibernateは "
-"<literal>unsaved-value=\"undefined\"</literal> を使用します。 そして、バー"
-"ジョンやタイムスタンプのプロパティがない場合や <literal>Interceptor.isUnsaved"
-"()</literal> を定義しなかった場合には、インスタンスが一時的(transient)なもの"
-"であるのか、 またはセッションから分離(detached)したものかどうかを決めるため"
-"に、データベースを調べます。"
+"<literal>assigned</literal> ジェネレータを選択すると、 Hibernate は "
+"<literal>unsaved-value=\"undefined\"</literal> を使います。そして、バージョン"
+"やタイムスタンプのプロパティがない場合や <literal>Interceptor.isUnsaved()</"
+"literal> を定義しなかった場合には、インスタンスが一時的(transient)なものであ"
+"るのか、またはセッションから分離(detached)したものかどうかを決めるために、"
+"データベースを調べます。"
 
 #. Tag: title
-#: basic_mapping.xml:774
 #, no-c-format
 msgid "Primary keys assigned by triggers"
 msgstr "トリガにより割り当てられた主キー"
 
 #. Tag: para
-#: basic_mapping.xml:775
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate does not generate DDL with triggers. It is for legacy schemas only."
 msgstr ""
-"レガシースキーマのためにのみ指定します(Hibernateはトリガを使ってDDLを生成しま"
-"せん)。"
+"レガシースキーマのためにのみ指定します( Hibernate はトリガを使って DDL を生成"
+"しません)。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:779
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-"        <generator class=\"select\">\n"
-"                <param name=\"key\">socialSecurityNumber</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:781
-#, fuzzy, no-c-format
-msgid ""
 "In the above example, there is a unique valued property named "
 "<literal>socialSecurityNumber</literal>. It is defined by the class, as a "
 "natural key and a surrogate key named <literal>person_id</literal>, whose "
 "value is generated by a trigger."
 msgstr ""
-"上の例の中で、クラスで自然キーとして定義された "
+"上記の例の中で、クラスで自然キーとして定義された "
 "<literal>socialSecurityNumber</literal> という名前のユニークな値のプロパティ"
-"と、 値がトリガにより生成される <literal>person_id</literal> という名前の代理"
+"と、値がトリガにより生成される <literal>person_id</literal> という名前の代理"
 "キーがあります。"
 
 #. Tag: title
-#: basic_mapping.xml:793
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Enhanced identifier generators"
-msgstr "Enhanced identifier generators"
+msgstr "識別子の getter メソッド"
 
 #. Tag: para
-#: basic_mapping.xml:795
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Starting with release 3.2.3, there are 2 new generators which represent a re-"
 "thinking of 2 different aspects of identifier generation. The first aspect "
@@ -1595,17 +1212,9 @@
 "the named generators described above, starting in 3.3.x. However, they are "
 "included in the current releases and can be referenced by FQN."
 msgstr ""
-"Starting with release 3.2.3, there are 2 new generators which represent a re-"
-"thinking of 2 different aspects of identifier generation. The first aspect "
-"is database portability; the second is optimization (not having to query the "
-"database for every request for a new identifier value). These two new "
-"generators are intended to take the place of some of the named generators "
-"described above (starting in 3.3.x); however, they are included in the "
-"current releases and can be referenced by FQN."
 
 #. Tag: para
-#: basic_mapping.xml:803
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The first of these new generators is <literal>org.hibernate.id.enhanced."
 "SequenceStyleGenerator</literal> which is intended, firstly, as a "
@@ -1624,100 +1233,68 @@
 "with its table-based generators. This generator has a number of "
 "configuration parameters:"
 msgstr ""
-"The first of these new generators is <literal>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</literal> which is intended firstly as a replacement "
-"for the <literal>sequence</literal> generator and secondly as a better "
-"portability generator than <literal>native</literal> (because "
-"<literal>native</literal> (generally) chooses between <literal>identity</"
-"literal> and <literal>sequence</literal> which have largely different "
-"semantics which can cause subtle isssues in applications eyeing "
-"portability). <literal>org.hibernate.id.enhanced.SequenceStyleGenerator</"
-"literal> however achieves portability in a different manner. It chooses "
-"between using a table or a sequence in the database to store its "
-"incrementing values depending on the capabilities of the dialect being used. "
-"The difference between this and <literal>native</literal> is that table-"
-"based and sequence-based storage have the same exact semantic (in fact "
-"sequences are exactly what Hibernate tries to emmulate with its table-based "
-"generators). This generator has a number of configuration parameters: "
-"<placeholder-1/>"
 
 #. Tag: para
-#: basic_mapping.xml:817
 #, fuzzy, no-c-format
 msgid ""
 "<literal>sequence_name</literal> (optional, defaults to "
 "<literal>hibernate_sequence</literal>): the name of the sequence or table to "
 "be used."
 msgstr ""
-"<literal>sequence_name</literal> (optional, defaults to "
-"<literal>hibernate_sequence</literal>): The name of the sequence (or table) "
-"to be used."
+"<literal>column</literal>(オプション - デフォルトは <literal>class</"
+"literal> ): 識別カラムの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:823
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>initial_value</literal> (optional, defaults to <literal>1</"
 "literal>): the initial value to be retrieved from the sequence/table. In "
 "sequence creation terms, this is analogous to the clause typically named "
 "\"STARTS WITH\"."
 msgstr ""
-"<literal>initial_value</literal> (optional, defaults to <literal>1</"
-"literal>): The initial value to be retrieved from the sequence/table. In "
-"sequence creation terms, this is analogous to the clause typical named "
-"\"STARTS WITH\"."
 
 #. Tag: para
-#: basic_mapping.xml:830
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>increment_size</literal> (optional - defaults to <literal>1</"
 "literal>): the value by which subsequent calls to the sequence/table should "
 "differ. In sequence creation terms, this is analogous to the clause "
 "typically named \"INCREMENT BY\"."
 msgstr ""
-"<literal>increment_size</literal> (optional, defaults to <literal>1</"
-"literal>): The value by which subsequent calls to the sequence/table should "
-"differ. In sequence creation terms, this is analogous to the clause typical "
-"named \"INCREMENT BY\"."
 
 #. Tag: para
-#: basic_mapping.xml:837
 #, fuzzy, no-c-format
 msgid ""
 "<literal>force_table_use</literal> (optional - defaults to <literal>false</"
 "literal>): should we force the use of a table as the backing structure even "
 "though the dialect might support sequence?"
 msgstr ""
-"<literal>force_table_use</literal> (optional, defaults to <literal>false</"
-"literal>): Should we force the use of a table as the backing structure even "
-"though the dialect might support sequence?"
+"<literal>force</literal> (オプション - デフォルトは <literal>false</"
+"literal> ): ルートクラスのすべてのインスタンスを検索する場合であっても、 "
+"Hibernate が使用できる識別カラムの指定を「強制」します。"
 
 #. Tag: para
-#: basic_mapping.xml:844
 #, fuzzy, no-c-format
 msgid ""
 "<literal>value_column</literal> (optional - defaults to <literal>next_val</"
 "literal>): only relevant for table structures, it is the name of the column "
 "on the table which is used to hold the value."
 msgstr ""
-"<literal>value_column</literal> (optional, defaults to <literal>next_val</"
-"literal>): Only relevant for table structures! The name of the column on the "
-"table which is used to hold the value."
+"<literal>column</literal>(オプション - デフォルトは <literal>class</"
+"literal> ): 識別カラムの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:851
 #, fuzzy, no-c-format
 msgid ""
 "<literal>optimizer</literal> (optional - defaults to <literal>none</"
-"literal>): See"
+"literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\" /"
+">"
 msgstr ""
-"<literal>cascade</literal>(オプション - デフォルトは <literal>none</"
-"literal> ): カスケードのスタイル。"
+"<literal>type</literal> (オプション - デフォルトは <literal>integer</"
+"literal> ):バージョン番号の型。"
 
 #. Tag: para
-#: basic_mapping.xml:858
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The second of these new generators is <literal>org.hibernate.id.enhanced."
 "TableGenerator</literal>, which is intended, firstly, as a replacement for "
@@ -1730,148 +1307,109 @@
 "multiple distinctly keyed rows. This generator has a number of configuration "
 "parameters:"
 msgstr ""
-"The second of these new generators is <literal>org.hibernate.id.enhanced."
-"TableGenerator</literal> which is intended firstly as a replacement for the "
-"<literal>table</literal> generator (although it actually functions much more "
-"like <literal>org.hibernate.id.MultipleHiLoPerTableGenerator</literal>) and "
-"secondly as a re-implementation of <literal>org.hibernate.id."
-"MultipleHiLoPerTableGenerator</literal> utilizing the notion of pluggable "
-"optimiziers. Essentially this generator defines a table capable of holding a "
-"number of different increment values simultaneously by using multiple "
-"distinctly keyed rows. This generator has a number of configuration "
-"parameters: <placeholder-1/>"
 
 #. Tag: para
-#: basic_mapping.xml:868
 #, fuzzy, no-c-format
 msgid ""
 "<literal>table_name</literal> (optional - defaults to "
 "<literal>hibernate_sequences</literal>): the name of the table to be used."
 msgstr ""
-"<literal>table_name</literal> (optional, defaults to "
-"<literal>hibernate_sequences</literal>): The name of the table to be used."
+"<literal>type</literal> (オプション - デフォルトは <literal>integer</"
+"literal> ):バージョン番号の型。"
 
 #. Tag: para
-#: basic_mapping.xml:874
 #, fuzzy, no-c-format
 msgid ""
 "<literal>value_column_name</literal> (optional - defaults to "
 "<literal>next_val</literal>): the name of the column on the table that is "
 "used to hold the value."
 msgstr ""
-"<literal>value_column_name</literal> (optional, defaults to "
-"<literal>next_val</literal>): The name of the column on the table which is "
-"used to hold the value."
+"<literal>column</literal>(オプション - デフォルトは <literal>class</"
+"literal> ): 識別カラムの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:880
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>segment_column_name</literal> (optional - defaults to "
 "<literal>sequence_name</literal>): the name of the column on the table that "
 "is used to hold the \"segment key\". This is the value which identifies "
 "which increment value to use."
 msgstr ""
-"<literal>segment_column_name</literal> (optional, defaults to "
-"<literal>sequence_name</literal>): The name of the column on the table which "
-"is used to hold the \"segement key\". This is the value which distinctly "
-"identifies which increment value to use."
 
 #. Tag: para
-#: basic_mapping.xml:887
 #, fuzzy, no-c-format
 msgid ""
 "<literal>segment_value</literal> (optional - defaults to <literal>default</"
 "literal>): The \"segment key\" value for the segment from which we want to "
 "pull increment values for this generator."
 msgstr ""
-"<literal>segment_value</literal> (optional, defaults to <literal>default</"
-"literal>): The \"segment key\" value for the segment from which we want to "
-"pull increment values for this generator."
+"<literal>access</literal> (オプション - デフォルトは <literal>property</"
+"literal> ): Hibernate がプロパティの値にアクセスするために使用すべき戦略。"
 
 #. Tag: para
-#: basic_mapping.xml:894
 #, fuzzy, no-c-format
 msgid ""
 "<literal>segment_value_length</literal> (optional - defaults to "
 "<literal>255</literal>): Used for schema generation; the column size to "
 "create this segment key column."
 msgstr ""
-"<literal>segment_value_length</literal> (optional, defaults to <literal>255</"
-"literal>): Used for schema generation; the column size to create this "
-"segment key column."
+"<literal>column</literal>(オプション - デフォルトは <literal>class</"
+"literal> ): 識別カラムの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:900
 #, fuzzy, no-c-format
 msgid ""
 "<literal>initial_value</literal> (optional - defaults to <literal>1</"
 "literal>): The initial value to be retrieved from the table."
 msgstr ""
-"<literal>initial_value</literal> (optional, defaults to <literal>1</"
-"literal>): The initial value to be retrieved from the table."
+"<literal>type</literal> (オプション - デフォルトは <literal>integer</"
+"literal> ):バージョン番号の型。"
 
 #. Tag: para
-#: basic_mapping.xml:906
 #, fuzzy, no-c-format
 msgid ""
 "<literal>increment_size</literal> (optional - defaults to <literal>1</"
 "literal>): The value by which subsequent calls to the table should differ."
 msgstr ""
-"<literal>increment_size</literal> (optional, defaults to <literal>1</"
-"literal>): The value by which subsequent calls to the table should differ."
+"<literal>type</literal> (オプション - デフォルトは <literal>integer</"
+"literal> ):バージョン番号の型。"
 
 #. Tag: para
-#: basic_mapping.xml:912
 #, fuzzy, no-c-format
 msgid ""
 "<literal>optimizer</literal> (optional - defaults to <literal></literal>): "
-"See"
+"See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\" />"
 msgstr ""
-"<literal>cascade</literal>(オプション - デフォルトは <literal>none</"
-"literal> ): カスケードのスタイル。"
+"<literal>type</literal> (オプション - デフォルトは <literal>integer</"
+"literal> ):バージョン番号の型。"
 
 #. Tag: title
-#: basic_mapping.xml:922
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Identifier generator optimization"
-msgstr "Identifier generator optimization"
+msgstr "識別子の getter メソッド"
 
 #. Tag: para
-#: basic_mapping.xml:923
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For identifier generators that store values in the database, it is "
 "inefficient for them to hit the database on each and every call to generate "
 "a new identifier value. Instead, you can group a bunch of them in memory and "
 "only hit the database when you have exhausted your in-memory value group. "
 "This is the role of the pluggable optimizers. Currently only the two "
-"enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced\"/> "
+"enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced\" /> "
 "support this operation."
 msgstr ""
-"For identifier generators which store values in the database, it is "
-"inefficient for them to hit the database on each and every call to generate "
-"a new identifier value. Instead, you'd ideally want to group a bunch of them "
-"in memory and only hit the database when you have exhausted your in-memory "
-"value group. This is the role of the pluggable optimizers. Currently only "
-"the two enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced"
-"\"/> support this notion. <placeholder-1/>"
 
 #. Tag: para
-#: basic_mapping.xml:931
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>none</literal> (generally this is the default if no optimizer was "
 "specified): this will not perform any optimizations and hit the database for "
 "each and every request."
 msgstr ""
-"<literal>none</literal> (generally this is the default if no optimizer was "
-"specified): This says to not perform any optimizations, and hit the database "
-"each and every request."
 
 #. Tag: para
-#: basic_mapping.xml:937
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>hilo</literal>: applies a hi/lo algorithm around the database "
 "retrieved values. The values from the database for this optimizer are "
@@ -1880,16 +1418,9 @@
 "<literal>increment_size</literal> is multiplied by that value in memory to "
 "define a group \"hi value\"."
 msgstr ""
-"<literal>hilo</literal>: applies a hi/lo algorithm around the database "
-"retrieved values. The values from the database for this optimizer are "
-"expected to be sequential. The values retrieved from the database structure "
-"for this optimizer indicates the \"group number\"; the "
-"<literal>increment_size</literal> is multiplied by that value in memory to "
-"define a group \"hi value\"."
 
 #. Tag: para
-#: basic_mapping.xml:946
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>pooled</literal>: as with the case of <literal>hilo</literal>, this "
 "optimizer attempts to minimize the number of hits to the database. Here, "
@@ -1898,66 +1429,28 @@
 "memory grouping algorithm. Here, <literal>increment_size</literal> refers to "
 "the values coming from the database."
 msgstr ""
-"<literal>pooled</literal>: like was discussed for <literal>hilo</literal>, "
-"this optimizers attempts to minimize the number of hits to the database. "
-"Here, however, we simply store the starting value for the \"next group\" "
-"into the database structure rather than a sequential value in combination "
-"with an in-memory grouping algorithm. <literal>increment_size</literal> here "
-"refers to the values coming from the database."
 
 #. Tag: title
-#: basic_mapping.xml:959
 #, no-c-format
 msgid "composite-id"
 msgstr "composite-id"
 
-#. Tag: programlisting
-#: basic_mapping.xml:961
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<composite-id\n"
-"        name=\"propertyName\"\n"
-"        class=\"ClassName\"\n"
-"        mapped=\"true|false\"\n"
-"        access=\"field|property|ClassName\">\n"
-"        node=\"element-name|.\"\n"
-"\n"
-"        <key-property name=\"propertyName\" type=\"typename\" column="
-"\"column_name\"/>\n"
-"        <key-many-to-one name=\"propertyName class=\"ClassName\" column="
-"\"column_name\"/>\n"
-"        ......\n"
-"</composite-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:963
-#, fuzzy, no-c-format
-msgid ""
 "A table with a composite key can be mapped with multiple properties of the "
 "class as identifier properties. The <literal>&lt;composite-id&gt;</literal> "
 "element accepts <literal>&lt;key-property&gt;</literal> property mappings "
 "and <literal>&lt;key-many-to-one&gt;</literal> mappings as child elements."
 msgstr ""
-"複合キーのあるテーブルに対し、 識別子プロパティとしてクラスの複数のプロパティ"
+"複合キーのあるテーブルに対し、識別子プロパティとしてクラスの複数のプロパティ"
 "をマッピングすることができます。 <literal>&lt;composite-id&gt;</literal> 要素"
 "は、子要素として <literal>&lt;key-property&gt;</literal> プロパティマッピング"
 "と <literal>&lt;key-many-to-one&gt;</literal> マッピングを受け入れます。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:970
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<composite-id>\n"
-"        <key-property name=\"medicareNumber\"/>\n"
-"        <key-property name=\"dependent\"/>\n"
-"</composite-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:972
-#, fuzzy, no-c-format
-msgid ""
 "The persistent class <emphasis>must</emphasis> override <literal>equals()</"
 "literal> and <literal>hashCode()</literal> to implement composite identifier "
 "equality. It must also implement <literal>Serializable</literal>."
@@ -1968,8 +1461,7 @@
 "ればいけません。"
 
 #. Tag: para
-#: basic_mapping.xml:978
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Unfortunately, this approach means that a persistent object is its own "
 "identifier. There is no convenient \"handle\" other than the object itself. "
@@ -1979,15 +1471,14 @@
 "<emphasis>embedded</emphasis> composite identifier, and discourage it for "
 "serious applications."
 msgstr ""
-"残念ながら複合識別子のためのこの方法は、 永続オブジェクトが自身の識別子である"
-"ことを意味しています。 オブジェクト自身を識別子とする以上の便利な「扱い方」は"
-"ありません。 複合キーに関連した永続状態を <literal>load()</literal> 出来るよ"
-"うになる前に、 永続クラス自身をインスタンス化し、識別子プロパティを設定しなけ"
-"ればなりません。 <emphasis> 組み込みの</emphasis> 複合識別子と呼ばれるこのア"
-"プローチは、 本格的なアプリケーションには向いていません。"
+"残念ながら複合識別子のためのこの方法は、永続オブジェクトが自身の識別子である"
+"ことを意味しています。オブジェクト自身を識別子とする以外に便利な「扱い方」は"
+"ありません。複合キーに関連した永続状態を <literal>load()</literal> 出来るよう"
+"になる前に、永続クラス自身をインスタンス化し、識別子プロパティを設定しなけれ"
+"ばなりません。 <emphasis> 組み込みの</emphasis> 複合識別子と呼ばれるこのアプ"
+"ローチは、本格的なアプリケーションには向いていません。"
 
 #. Tag: para
-#: basic_mapping.xml:987
 #, no-c-format
 msgid ""
 "A second approach is what we call a <emphasis>mapped</emphasis> composite "
@@ -1995,24 +1486,13 @@
 "composite-id&gt;</literal> element are duplicated on both the persistent "
 "class and a separate identifier class."
 msgstr ""
-"2つ目の方法は <emphasis> マップされた</emphasis> 複合識別子と呼ばれるもの"
-"で、 <literal>&lt;composite-id&gt;</literal>エレメント内で指定した識別プロパ"
-"ティが 永続クラスと分離した識別子クラスの両方に重複して存在します。"
+"2つ目の方法は <emphasis>マップされた</emphasis> 複合識別子と呼ばれるもので、 "
+"<literal>&lt;composite-id&gt;</literal>エレメント内で指定した識別プロパティが"
+"永続クラスと分離した識別子クラスの両方に重複して存在します。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:993
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<composite-id class=\"MedicareId\" mapped=\"true\">\n"
-"        <key-property name=\"medicareNumber\"/>\n"
-"        <key-property name=\"dependent\"/>\n"
-"</composite-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:995
-#, fuzzy, no-c-format
-msgid ""
 "In this example, both the composite identifier class, <literal>MedicareId</"
 "literal>, and the entity class itself have properties named "
 "<literal>medicareNumber</literal> and <literal>dependent</literal>. The "
@@ -2022,21 +1502,19 @@
 msgstr ""
 "この例では、複合識別子クラス( <literal>MedicareId</literal> )とエンティティ"
 "クラス自身の両方が、 <literal>medicareNumber</literal> と "
-"<literal>dependent</literal> という名前のプロパティを持ちます。 識別子クラス"
-"は、<literal>equals()</literal> と <literal>hashCode()</literal> をオーバライ"
-"ドし、 <literal>Serializable</literal> を実装しなくてはなりません。 この方法"
+"<literal>dependent</literal> という名前のプロパティを持ちます。識別子クラス"
+"は、 <literal>equals()</literal> と <literal>hashCode()</literal> をオーバラ"
+"イドし、 <literal>Serializable</literal> を実装しなくてはなりません。この方法"
 "には、明らかにコードが重複するという不都合があります。"
 
 #. Tag: para
-#: basic_mapping.xml:1004
 #, no-c-format
 msgid ""
 "The following attributes are used to specify a mapped composite identifier:"
-msgstr "次の属性はマッピングした複合識別子を指定するために使用します。"
+msgstr "次の属性はマッピングした複合識別子を指定するために使用します:"
 
 #. Tag: para
-#: basic_mapping.xml:1010
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mapped</literal> (optional - defaults to <literal>false</literal>): "
 "indicates that a mapped composite identifier is used, and that the contained "
@@ -2045,83 +1523,51 @@
 msgstr ""
 "<literal>mapped</literal> (オプション、デフォルトは <literal>false</"
 "literal> ): マッピングした複合識別子が使用されることと、包含されたプロパティ"
-"のマッピングが、 エンティティクラスと複合識別子クラスの両方を参照することを示"
+"のマッピングが、エンティティクラスと複合識別子クラスの両方を参照することを示"
 "します。"
 
 #. Tag: para
-#: basic_mapping.xml:1018
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - but required for a mapped composite "
 "identifier): the class used as a composite identifier."
 msgstr ""
-"<literal>class</literal> (オプション,ただしマッピングした複合識別子には必"
+"<literal>class</literal> (オプション、ただしマッピングした複合識別子には必"
 "須): 複合識別子として使用するクラス。"
 
 #. Tag: para
-#: basic_mapping.xml:1025
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will describe a third, even more convenient approach, where the composite "
 "identifier is implemented as a component class in <xref linkend=\"components-"
-"compositeid\"/>. The attributes described below apply only to this "
+"compositeid\" />. The attributes described below apply only to this "
 "alternative approach:"
 msgstr ""
-"3つ目のさらに便利な方法は、複合識別子を<xref linkend=\"components-compositeid"
-"\"/>内の コンポーネントクラスとして実装することです。 下で記述している属性"
-"は、この代替方法にのみ適用されます。"
+"3つ目のさらに便利な方法は、複合識別子を <xref linkend=\"components-"
+"compositeid\"/> のコンポーネントクラスとして実装することです。下で記述してい"
+"る属性は、この代替方法にのみ適用されます:"
 
 #. Tag: para
-#: basic_mapping.xml:1033
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal> (optional - required for this approach): a property "
 "of component type that holds the composite identifier. Please see chapter 9 "
 "for more information."
 msgstr ""
-"<literal>name</literal> (オプション, このアプローチでは必須): 複合識別子を保"
-"持するコンポーネントタイプのプロパティ(9章を参照してください)."
+"<literal>name</literal> (オプション、このアプローチでは必須): 複合識別子を保"
+"持するコンポーネントタイプのプロパティ(9章を参照してください)。"
 
 #. Tag: para
-#: basic_mapping.xml:1039 basic_mapping.xml:1260 basic_mapping.xml:1372
-#: basic_mapping.xml:1561 basic_mapping.xml:1735 basic_mapping.xml:1905
-#: basic_mapping.xml:2484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate uses for accessing the property value."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal>(オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へアクセスするためにHibernateが使う戦略です。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>access</literal> (オプション - デフォルトは <literal>property</"
-"literal> ): Hibernateがプロパティの値にアクセスするために使用すべき戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal>(オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal>(オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal>(オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal>(オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。"
+"literal> ): Hibernate がプロパティの値にアクセスするために使用すべき戦略。"
 
 #. Tag: para
-#: basic_mapping.xml:1045
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
 "determined by reflection): the component class used as a composite "
@@ -2132,24 +1578,21 @@
 "節を見てください)。"
 
 #. Tag: para
-#: basic_mapping.xml:1052
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The third approach, an <emphasis>identifier component</emphasis>, is "
 "recommended for almost all applications."
 msgstr ""
-"この3つ目の方法は <emphasis> 識別子コンポーネント</emphasis> と呼び、 ほとん"
-"どすべてのアプリケーションに対して推奨する方法です。"
+"この3つ目の方法は <emphasis> 識別子コンポーネント</emphasis> と呼び、ほとんど"
+"すべてのアプリケーションに対して推奨する方法です。"
 
 #. Tag: title
-#: basic_mapping.xml:1060
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Discriminator"
 msgstr "discriminator"
 
 #. Tag: para
-#: basic_mapping.xml:1062
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;discriminator&gt;</literal> element is required for "
 "polymorphic persistence using the table-per-class-hierarchy mapping "
@@ -2161,32 +1604,18 @@
 "<literal>boolean</literal>, <literal>yes_no</literal>, <literal>true_false</"
 "literal>."
 msgstr ""
-"<literal>&lt;discriminator&gt;</literal> 要素は、 table-per-class-hierarchy"
-"マッピング戦略を使うポリモーフィックな永続化に必要であり、 テーブルの識別カラ"
-"ムを定義します。 識別カラムは、ある行に対して永続層がどのサブクラスをインスタ"
-"ンス化するかを 伝えるマーカー値を含んでいます。 以下のような型に制限されま"
-"す: <literal>string</literal> , <literal>character</literal> , "
-"<literal>integer</literal>, <literal>byte</literal> , <literal>short</"
-"literal> , <literal>boolean</literal> , <literal>yes_no</literal> , "
+"<literal>&lt;discriminator&gt;</literal> 要素は、 table-per-class-hierarchy "
+"マッピング戦略を使うポリモーフィックな永続化に必要であり、テーブルの識別カラ"
+"ムを定義します。識別カラムは、ある行に対して永続層がどのサブクラスをインスタ"
+"ンス化するかを伝えるマーカー値を含んでいます。以下のような型に制限されます: "
+"<literal>string</literal> , <literal>character</literal> , <literal>integer</"
+"literal>, <literal>byte</literal> , <literal>short</literal> , "
+"<literal>boolean</literal> , <literal>yes_no</literal> , "
 "<literal>true_false</literal>."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1080
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<discriminator\n"
-"        column=\"discriminator_column\"\n"
-"        type=\"discriminator_type\"\n"
-"        force=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        formula=\"arbitrary sql expression\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1083
-#, fuzzy, no-c-format
-msgid ""
 "<literal>column</literal> (optional - defaults to <literal>class</literal>): "
 "the name of the discriminator column."
 msgstr ""
@@ -2194,18 +1623,16 @@
 "literal> ): 識別カラムの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:1089
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>type</literal> (optional - defaults to <literal>string</literal>): "
 "a name that indicates the Hibernate type"
 msgstr ""
 "<literal>type</literal> (オプション - デフォルトは <literal>string</"
-"literal> ):Hibernateの型を示す名前。"
+"literal> ): Hibernate の型を示す名前。"
 
 #. Tag: para
-#: basic_mapping.xml:1095
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>force</literal> (optional - defaults to <literal>false</literal>): "
 "\"forces\" Hibernate to specify the allowed discriminator values, even when "
@@ -2213,11 +1640,10 @@
 msgstr ""
 "<literal>force</literal> (オプション - デフォルトは <literal>false</"
 "literal> ): ルートクラスのすべてのインスタンスを検索する場合であっても、 "
-"Hibernateが使用できる識別カラムの指定を「強制」します。"
+"Hibernate が使用できる識別カラムの指定を「強制」します。"
 
 #. Tag: para
-#: basic_mapping.xml:1102
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>insert</literal> (optional - defaults to <literal>true</literal>): "
 "set this to <literal>false</literal> if your discriminator column is also "
@@ -2225,23 +1651,21 @@
 "column in SQL <literal>INSERTs</literal>."
 msgstr ""
 "<literal>insert</literal> (オプション - デフォルトは <literal>true</"
-"literal> ): もし識別カラムがマッピングする複合識別子の一部ならば、"
-"<literal>false</literal> と設定してください。 (HibernateにSQLの "
-"<literal>INSERT</literal> には含まれないことを知らせる)"
+"literal> ): もし識別カラムがマッピングする複合識別子の一部ならば、 "
+"<literal>false</literal> と設定してください。 (Hibernate に SQL の "
+"<literal>INSERT</literal> 内のカラムを含ませないよう伝えます。)"
 
 #. Tag: para
-#: basic_mapping.xml:1110
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an arbitrary SQL expression that is "
 "executed when a type has to be evaluated. It allows content-based "
 "discrimination."
 msgstr ""
-"<literal>formula</literal> (オプション)型が評価されるときに実行される任意の"
-"SQL式。 コンテンツベースの識別を可能にします。"
+"<literal>formula</literal> (オプション) 型が評価されるときに実行される任意の "
+"SQL 式。コンテンツベースの識別を可能にします。"
 
 #. Tag: para
-#: basic_mapping.xml:1118
 #, no-c-format
 msgid ""
 "Actual values of the discriminator column are specified by the "
@@ -2253,91 +1677,59 @@
 "定されます。"
 
 #. Tag: para
-#: basic_mapping.xml:1124
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>force</literal> attribute is only useful if the table contains "
 "rows with \"extra\" discriminator values that are not mapped to a persistent "
 "class. This will not usually be the case."
 msgstr ""
-"永続クラスへマッピングされない「余分な」識別値を持つ行が テーブルにあれば、"
-"(そのときに限り)<literal>force</literal> 属性は有効です。 ただし、普通はそ"
-"ういうことはありません。"
+"永続クラスへマッピングされない「余分な」識別値を持つ行がテーブルにあれば、(そ"
+"のときに限り) <literal>force</literal> 属性は有効です。ただし、普通はそうい"
+"うことはありません。"
 
 #. Tag: para
-#: basic_mapping.xml:1130
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>formula</literal> attribute allows you to declare an arbitrary "
 "SQL expression that will be used to evaluate the type of a row. For example:"
 msgstr ""
-"<literal>formula</literal> 属性を使うと、行の型を評価するために任意のSQL式を"
-"宣言できます。"
+"<literal>formula</literal> 属性を使うと、行の型を評価するために任意の SQL 式"
+"を宣言できます:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1135
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<discriminator\n"
-"    formula=\"case when CLASS_TYPE in ('a', 'b', 'c') then 0 else 1 end\"\n"
-"    type=\"integer\"/>]]>"
-msgstr ""
-
-#. Tag: title
-#: basic_mapping.xml:1140
-#, fuzzy, no-c-format
 msgid "Version (optional)"
 msgstr "version(オプション)"
 
 #. Tag: para
-#: basic_mapping.xml:1142
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;version&gt;</literal> element is optional and indicates "
 "that the table contains versioned data. This is particularly useful if you "
 "plan to use <emphasis>long transactions</emphasis>. See below for more "
 "information:"
 msgstr ""
-"<literal>&lt;version&gt;</literal> 要素はオプションであり、 テーブルがバー"
-"ジョンデータを含むことを示します。 これは <emphasis>ロングトランザクション</"
-"emphasis> を使うつもりなら、特に役立ちます(以下を見てください)。"
+"<literal>&lt;version&gt;</literal> 要素はオプションであり、テーブルがバージョ"
+"ンデータを含むことを示します。これは <emphasis>ロングトランザクション</"
+"emphasis> を使うつもりなら、特に役立ちます(以下を参照してください)。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1158
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<version\n"
-"        column=\"version_column\"\n"
-"        name=\"propertyName\"\n"
-"        type=\"typename\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unsaved-value=\"null|negative|undefined\"\n"
-"        generated=\"never|always\"\n"
-"        insert=\"true|false\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1161
-#, fuzzy, no-c-format
-msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of the column holding the version number."
 msgstr ""
-"<literal>column</literal>(オプション - デフォルトはプロパティ名): バージョ"
+"<literal>column</literal> (オプション - デフォルトはプロパティ名): バージョ"
 "ン番号を保持するカラムの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:1167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal>: the name of a property of the persistent class."
 msgstr "<literal>name</literal> :永続クラスのプロパティの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:1172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>type</literal> (optional - defaults to <literal>integer</literal>): "
 "the type of the version number."
@@ -2346,42 +1738,15 @@
 "literal> ):バージョン番号の型。"
 
 #. Tag: para
-#: basic_mapping.xml:1178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate uses to access the property value."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal>(オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へアクセスするためにHibernateが使う戦略です。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>access</literal> (オプション - デフォルトは <literal>property</"
-"literal> ): Hibernateがプロパティの値にアクセスするために使用すべき戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal>(オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal>(オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal>(オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal>(オプション - デフォルトは <literal>property</"
-"literal> ): プロパティの値へのアクセスにHibernateが使う戦略。"
+"literal> ): Hibernate がプロパティの値にアクセスするために使用すべき戦略。"
 
 #. Tag: para
-#: basic_mapping.xml:1184
 #, fuzzy, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to <literal>undefined</"
@@ -2392,13 +1757,12 @@
 msgstr ""
 "<literal>unsaved-value</literal> (オプション - デフォルトは "
 "<literal>undefined</literal> ): インスタンスが新しくインスタンス化されたこ"
-"とを示す (セーブされていないことを示す)バージョンプロパティの値。 以前の"
-"Sessionでセーブまたはロードされた一時的なインスタンスと区別するために 使いま"
-"す。 ( <literal>undefined</literal> は識別子プロパティの値が使われることを指"
-"定します。)"
+"とを示す (セーブされていないことを示す) バージョンプロパティの値。以前の "
+"Session でセーブまたはロードされた分離インスタンスと区別するために使います。 "
+"( <literal>undefined</literal> は識別子プロパティの値が使われることを指定し"
+"ます。)"
 
 #. Tag: para
-#: basic_mapping.xml:1193
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2408,12 +1772,11 @@
 msgstr ""
 "<literal>generated</literal> (オプション - デフォルトは <literal>never</"
 "literal> ): このバージョンのプロパティの値が、データベースによって生成された"
-"ことを指定します。 <xref linkend=\"mapping-generated\">生成プロパティ</xref> "
-"の議論を見てください。"
+"ことを指定します。<xref linkend=\"mapping-generated\"/> 生成プロパティの議論"
+"を参照してください。"
 
 #. Tag: para
-#: basic_mapping.xml:1200
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>insert</literal> (optional - defaults to <literal>true</literal>): "
 "specifies whether the version column should be included in SQL insert "
@@ -2421,24 +1784,22 @@
 "is defined with a default value of <literal>0</literal>."
 msgstr ""
 "<literal>insert</literal> (オプション - デフォルトは <literal>true</"
-"literal> ): SQLのinsert文にバージョン・カラムを含めるべきかどうかを指定しま"
-"す。 もしデータベース・カラムのデフォルト値が <literal>0</literal> と定義され"
-"るときには、 <literal>false</literal> に設定すると良いでしょう。"
+"literal> ): SQLの insert 文にバージョンカラムを含めるべきかどうかを指定しま"
+"す。もしデータベースカラムのデフォルト値が <literal>0</literal> と定義される"
+"ときには、 <literal>false</literal> に設定すると良いでしょう。"
 
 #. Tag: para
-#: basic_mapping.xml:1210
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Version numbers can be of Hibernate type <literal>long</literal>, "
 "<literal>integer</literal>, <literal>short</literal>, <literal>timestamp</"
 "literal> or <literal>calendar</literal>."
 msgstr ""
-"バージョン番号は Hibernateの <literal>long</literal> , <literal>integer</"
-"literal> , <literal>short</literal> , <literal>timestamp</literal> , "
+"バージョン番号は Hibernate の <literal>long</literal> 、 <literal>integer</"
+"literal> 、 <literal>short</literal> 、 <literal>timestamp</literal> 、 "
 "<literal>calendar</literal> 型のいずれかです。"
 
 #. Tag: para
-#: basic_mapping.xml:1215
 #, fuzzy, no-c-format
 msgid ""
 "A version or timestamp property should never be null for a detached "
@@ -2449,53 +1810,36 @@
 "reattachment in Hibernate. It is especially useful for people using assigned "
 "identifiers or composite keys</emphasis>."
 msgstr ""
-"バージョンやタイムスタンプのプロパティは、分離されたインスタンスに対してnull"
-"であってはなりません。 そのためどのような <literal>unsaved-value</literal> 戦"
-"略が指定されても、 Hibernateはnullのバージョンやタイムスタンプを持ったすべて"
-"のインスタンスを、 一時的なものであると判断します。 <emphasis> nullを許容する"
-"バージョンやタイムスタンプのプロパティを定義することは、 過渡的に一時オブジェ"
-"クトとすることを防ぐ簡単な方法です。 特に識別子の割り当てや複合キーを使用して"
-"いるときには特に有用です。</emphasis>"
+"バージョンやタイムスタンプのプロパティは、分離されたインスタンスに対して "
+"null であってはなりません。そのためどのような <literal>unsaved-value</"
+"literal> 戦略が指定されても、 Hibernate は null のバージョンやタイムスタンプ"
+"を持ったすべてのインスタンスを、一時的なものであると判断します。 <emphasis> "
+"null を許容するバージョンやタイムスタンプのプロパティを定義することは、 "
+"Hibernate において過渡的に一時オブジェクトとすることを防ぐ簡単な方法です。特"
+"に識別子の割り当てや複合キーを使用しているときには特に有用です。</emphasis>"
 
 #. Tag: title
-#: basic_mapping.xml:1226
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Timestamp (optional)"
 msgstr "timestamp(オプション)"
 
 #. Tag: para
-#: basic_mapping.xml:1228
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The optional <literal>&lt;timestamp&gt;</literal> element indicates that the "
 "table contains timestamped data. This provides an alternative to versioning. "
 "Timestamps are a less safe implementation of optimistic locking. However, "
 "sometimes the application might use the timestamps in other ways."
 msgstr ""
-"オプションの <literal>&lt;timestamp&gt;</literal> 要素は、 テーブルがタイムス"
-"タンプデータを含むことを示します。 これはバージョン付けの代わりの方法として用"
-"意されています。 タイムスタンプはもともと楽観的ロックにおける安全性の低い実装"
-"です。 しかしアプリケーションは異なる用途で使うこともあるかもしれません。"
+"オプションの <literal>&lt;timestamp&gt;</literal> 要素は、テーブルがタイムス"
+"タンプデータを含むことを示します。これはバージョン付けの代わりの方法として用"
+"意されています。タイムスタンプはもともと楽観的ロックにおける安全性の低い実装"
+"です。しかしアプリケーションはタイムスタンプを異なる用途で使うこともあるかも"
+"しれません。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1244
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<timestamp\n"
-"        column=\"timestamp_column\"\n"
-"        name=\"propertyName\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unsaved-value=\"null|undefined\"\n"
-"        source=\"vm|db\"\n"
-"        generated=\"never|always\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1247
-#, fuzzy, no-c-format
-msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of a column holding the timestamp."
 msgstr ""
@@ -2503,20 +1847,18 @@
 "タンプを保持するカラムの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:1253
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal>: the name of a JavaBeans style property of Java type "
 "<literal>Date</literal> or <literal>Timestamp</literal> of the persistent "
 "class."
 msgstr ""
-"<literal>name</literal> : 永続クラスであるJava の <literal>Date</literal>型 "
-"または <literal>Timestamp</literal> 型 の、JavaBeansスタイルプロパティの名"
+"<literal>name</literal> : 永続クラスである Java の <literal>Date</literal>型"
+"または <literal>Timestamp</literal> 型 の、 JavaBeans スタイルプロパティの名"
 "前。"
 
 #. Tag: para
-#: basic_mapping.xml:1266
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to <literal>null</"
 "literal>): a version property value that indicates that an instance is newly "
@@ -2526,13 +1868,12 @@
 msgstr ""
 "<literal>unsaved-value</literal> (オプション - デフォルトは <literal>null</"
 "literal> ): インスタンスが新しくインスタンス化された (セーブされていない)"
-"ことを示すバージョンプロパティの値。 以前のSessionでセーブまたはロードされた"
-"一時的なインスタンスと 区別するために使われます。 ( <literal>undefined</"
-"literal> と指定すると、 識別子プロパティの値が使われます。)"
+"ことを示すバージョンプロパティの値。以前の Session でセーブまたはロードされた"
+"分離されたインスタンスと区別するために使われます。 ( <literal>undefined</"
+"literal> と指定すると、識別子プロパティの値が使われます。)"
 
 #. Tag: para
-#: basic_mapping.xml:1275
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>source</literal> (optional - defaults to <literal>vm</literal>): "
 "Where should Hibernate retrieve the timestamp value from? From the database, "
@@ -2544,17 +1885,16 @@
 "precision (Oracle 8, for example)."
 msgstr ""
 "<literal>source</literal> (オプション - デフォルトは <literal>vm</"
-"literal> ): Hibernateはどこからタイムスタンプの値を取得するべきでしょうか? "
-"データベースからでしょうか、現在のJVMからでしょうか? データベースによるタイ"
-"ムスタンプは、Hibernateが\"次の値\"を決定するために データベースをヒットしな"
-"ければならないため、オーバヘッドを招きます。 しかしクラスタ環境ではJVMから取"
-"得するより安全です。 データベースの現在のタイムスタンプの取得をサポートする "
-"すべての <literal>データベース方言</literal> が知られているわけではないこと"
-"に 注意してください。また一方で、精密さを欠くために、 ロックで使用するには安"
-"全でないものもあります(例えばOracle 8)。"
+"literal> ): Hibernate はどこからタイムスタンプの値を取得するべきでしょうか?"
+"データベースからでしょうか、現在の JVM からでしょうか?データベースによるタイ"
+"ムスタンプは、 Hibernate が \"次の値\" を決定するためにデータベースをヒットし"
+"なければならないため、オーバヘッドを招きます。しかしクラスタ環境では JVM から"
+"取得するより安全です。データベースの現在のタイムスタンプの取得をサポートする"
+"すべての <literal>Dialect</literal> が知られているわけではないことに注意して"
+"ください。また一方で、精密さを欠くために、ロックで使用するには安全でないもの"
+"もあります (例えば Oracle 8 )。"
 
 #. Tag: para
-#: basic_mapping.xml:1287
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2563,19 +1903,17 @@
 "generated\">generated properties</link> for more information."
 msgstr ""
 "<literal>generated</literal> (オプション - デフォルトは <literal>never</"
-"literal> ): このタイムスタンプ・プロパティの値が、データベースによって生成さ"
-"れることを指定します。 <xref linkend=\"mapping-generated\">生成プロパティ</"
-"xref> を参照してください。"
+"literal> ): このタイムスタンプのプロパティの値が、データベースによって生成さ"
+"れることを指定します。 <xref linkend=\"mapping-generated\"/> 生成プロパティを"
+"参照してください。"
 
 #. Tag: title
-#: basic_mapping.xml:1298 basic_mapping.xml:2890
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "注記"
 
 #. Tag: para
-#: basic_mapping.xml:1299
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>&lt;Timestamp&gt;</literal> is equivalent to <literal>&lt;version "
 "type=\"timestamp\"&gt;</literal>. And <literal>&lt;timestamp source=\"db"
@@ -2588,70 +1926,39 @@
 "</literal> と等価であることに注意してください。"
 
 #. Tag: title
-#: basic_mapping.xml:1311
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Property"
 msgstr "property"
 
 #. Tag: para
-#: basic_mapping.xml:1313
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;property&gt;</literal> element declares a persistent "
 "JavaBean style property of the class."
 msgstr ""
-"<literal>&lt;property&gt;</literal> 要素は、クラスの永続的なJavaBeanスタイル"
-"のプロパティを定義します。"
+"<literal>&lt;property&gt;</literal> 要素は、クラスの永続的な JavaBean スタイ"
+"ルのプロパティを定義します。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1335
-#, no-c-format
-msgid ""
-"<![CDATA[<property\n"
-"        name=\"propertyName\"\n"
-"        column=\"column_name\"\n"
-"        type=\"typename\"\n"
-"        update=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        formula=\"arbitrary SQL expression\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        lazy=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        not-null=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        generated=\"never|insert|always\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        index=\"index_name\"\n"
-"        unique_key=\"unique_key_id\"\n"
-"        length=\"L\"\n"
-"        precision=\"P\"\n"
-"        scale=\"S\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1338
 #, no-c-format
 msgid ""
 "<literal>name</literal>: the name of the property, with an initial lowercase "
 "letter."
-msgstr "<literal>name</literal>:小文字で始まるプロパティ名。"
+msgstr "<literal>name</literal>: 小文字で始まるプロパティ名。"
 
 #. Tag: para
-#: basic_mapping.xml:1344
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of the mapped database table column. This can also be specified by "
 "nested <literal>&lt;column&gt;</literal> element(s)."
 msgstr ""
 "<literal>column</literal>(オプション - デフォルトはプロパティ名): マッピン"
-"グされたデータベーステーブルのカラムの名前。 ネストした <literal>&lt;"
+"グされたデータベーステーブルのカラムの名前。ネストした <literal>&lt;"
 "column&gt;</literal> 要素でも指定できます。"
 
 #. Tag: para
-#: basic_mapping.xml:1356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update, insert</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that the mapped columns should be included in SQL "
@@ -2661,14 +1968,13 @@
 "column(s), or by a trigger or other application."
 msgstr ""
 "<literal>update, insert</literal> (オプション - デフォルトは <literal>true</"
-"literal> ): マッピングされたカラムがSQLの <literal>UPDATE</literal> や "
-"<literal>INSERT</literal> に含まれることを指定します。 両方とも "
-"<literal>false</literal> に設定すると、 同じカラムにマッピングされた他のプロ"
-"パティやトリガや 他のアプリケーションによって初期化された純粋な「導出」プロパ"
+"literal> ): マッピングされたカラムが SQL の <literal>UPDATE</literal> や "
+"<literal>INSERT</literal> に含まれることを指定します。両方とも "
+"<literal>false</literal> に設定すると、同じカラムにマッピングされた他のプロパ"
+"ティやトリガや他のアプリケーションによって初期化された純粋な「導出」プロパ"
 "ティが可能になります。"
 
 #. Tag: para
-#: basic_mapping.xml:1365
 #, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an SQL expression that defines the "
@@ -2676,46 +1982,42 @@
 "not have a column mapping of their own."
 msgstr ""
 "<literal>formula</literal>(オプション): <emphasis>計算</emphasis> プロパ"
-"ティのための値を定義するSQL式。 計算されたプロパティは自身のカラムへのマッピ"
+"ティのための値を定義する SQL 式。計算されたプロパティは自身のカラムへのマッピ"
 "ングがありません。"
 
 #. Tag: para
-#: basic_mapping.xml:1378
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>false</literal>): "
 "specifies that this property should be fetched lazily when the instance "
 "variable is first accessed. It requires build-time bytecode instrumentation."
 msgstr ""
-"<literal>lazy</literal> (optional - デフォルトは <literal>false</literal> ): "
-"インスタンス変数に最初にアクセスしたときに、プロパティを遅延して取得するよう"
-"指定します。 (バイトコード実装を作成する時間が必要になります)。"
+"<literal>lazy</literal> (オプション - デフォルトは <literal>false</"
+"literal> ): インスタンス変数に最初にアクセスしたときに、プロパティを遅延して"
+"取得するよう指定します。 (バイトコード実装を作成する時間が必要になります)。"
 
 #. Tag: para
-#: basic_mapping.xml:1385
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): enables the DDL generation of a unique "
 "constraint for the columns. Also, allow this to be the target of a "
 "<literal>property-ref</literal>."
 msgstr ""
-"<literal>unique</literal> (オプション):カラムにユニーク制約をつけるDDLの生成"
-"を可能にします。 また、<literal>property-ref</literal> のターゲットとすること"
-"もできます。"
+"<literal>unique</literal> (オプション):カラムにユニーク制約をつける DDL の生"
+"成を可能にします。また、 <literal>property-ref</literal> のターゲットとするこ"
+"ともできます。"
 
 #. Tag: para
-#: basic_mapping.xml:1392
 #, fuzzy, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): enables the DDL generation of a "
 "nullability constraint for the columns."
 msgstr ""
-"<literal>not-null</literal> (オプション):カラムにnull値を許可するDDLの生成を"
-"可能にします。"
+"<literal>not-null</literal> (オプション):カラムに null 値を許可する DDL の生"
+"成を可能にします。"
 
 #. Tag: para
-#: basic_mapping.xml:1398 basic_mapping.xml:1581
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to this property do or do not require "
@@ -2724,11 +2026,10 @@
 msgstr ""
 "<literal>optimistic-lock</literal> (オプション - デフォルトは <literal>true</"
 "literal> ): このプロパティの更新に楽観ロックの取得を要求するかどうかを指定し"
-"ます。 言い換えれば、このプロパティがダーティであるときにバージョンを増やすべ"
+"ます。言い換えれば、このプロパティがダーティであるときにバージョンを増やすべ"
 "きかを決定します。"
 
 #. Tag: para
-#: basic_mapping.xml:1406
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2738,45 +2039,39 @@
 msgstr ""
 "<literal>generated</literal> (オプション - デフォルトは <literal>never</"
 "literal> ): プロパティの値が、データベースによって生成されたことを指定しま"
-"す。 <xref linkend=\"mapping-generated\">生成プロパティ</xref> を参照してくだ"
-"さい。"
+"す。 <xref linkend=\"mapping-generated\"/> 生成プロパティを参照してください。"
 
 #. Tag: para
-#: basic_mapping.xml:1415
 #, no-c-format
 msgid "<emphasis>typename</emphasis> could be:"
 msgstr "<emphasis>typename</emphasis> には以下の値が可能です:"
 
 #. Tag: para
-#: basic_mapping.xml:1421
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The name of a Hibernate basic type: <literal>integer, string, character, "
 "date, timestamp, float, binary, serializable, object, blob</literal> etc."
 msgstr ""
-"Hibernateの基本型の名前(例 <literal>integer, string, character, date, "
+"Hibernate の基本型の名前(例 <literal>integer, string, character, date, "
 "timestamp, float, binary, serializable, object, blob</literal> )。"
 
 #. Tag: para
-#: basic_mapping.xml:1427
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The name of a Java class with a default basic type: <literal>int, float, "
 "char, java.lang.String, java.util.Date, java.lang.Integer, java.sql.Clob</"
 "literal> etc."
 msgstr ""
-"デフォルトの基本型のJavaクラス名 (例 <literal>int, float, char, java.lang."
+"デフォルトの基本型の Java クラス名 (例 <literal>int, float, char, java.lang."
 "String, java.util.Date, java.lang.Integer, java.sql.Clob</literal> )。"
 
 #. Tag: para
-#: basic_mapping.xml:1433
 #, no-c-format
 msgid "The name of a serializable Java class."
-msgstr "シリアライズ可能なJavaクラスの名前。"
+msgstr "シリアライズ可能な Java クラスの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:1438
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The class name of a custom type: <literal>com.illflow.type.MyCustomType</"
 "literal> etc."
@@ -2785,8 +2080,7 @@
 "literal> )。"
 
 #. Tag: para
-#: basic_mapping.xml:1444
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you do not specify a type, Hibernate will use reflection upon the named "
 "property and guess the correct Hibernate type. Hibernate will attempt to "
@@ -2796,17 +2090,16 @@
 "DATE</literal> and <literal>Hibernate.TIMESTAMP</literal>, or to specify a "
 "custom type."
 msgstr ""
-"型を指定しなければ、Hibernateは正しいHibernateの型を推測するために、 指定され"
-"たプロパティに対してリフレクションを使います。 Hibernateはルール2, 3, 4をその"
-"順序に使い、 getterプロパティの返り値のクラスの名前を解釈しようとします。 し"
-"かしこれで常に十分であるとは限りません。 場合によっては、<literal>type</"
-"literal> 属性が必要な場合があります。 (例えば <literal>Hibernate.DATE</"
-"literal> と <literal>Hibernate.TIMESTAMP</literal> を区別するため、 またはカ"
-"スタム型を指定するためなどです。)"
+"型を指定しなければ、 Hibernate は正しい Hibernate の型を推測するために、指定"
+"されたプロパティに対してリフレクションを使います。 Hibernate はルール2, 3, 4"
+"をその順序に使い、 getter プロパティの返り値のクラスの名前を解釈しようとしま"
+"す。しかしこれで常に十分であるとは限りません。場合によっては、 "
+"<literal>type</literal> 属性が必要な場合があります。 (例えば "
+"<literal>Hibernate.DATE</literal> と <literal>Hibernate.TIMESTAMP</literal> "
+"を区別するため、またはカスタム型を指定するためなどです。)"
 
 #. Tag: para
-#: basic_mapping.xml:1454
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>access</literal> attribute allows you to control how Hibernate "
 "accesses the property at runtime. By default, Hibernate will call the "
@@ -2816,64 +2109,47 @@
 "a class that implements the interface <literal>org.hibernate.property."
 "PropertyAccessor</literal>."
 msgstr ""
-"<literal>access</literal> 属性で、 実行時にHibernateがどのようにプロパティに"
-"アクセスするかを制御できます。 デフォルトではHibernateはプロパティのget/setの"
-"ペアをコールします。 <literal>access=\"field\"</literal> と指定すれば、 "
-"Hibernateはリフレクションを使いget/setのペアを介さずに、直接フィールドにアク"
-"セスします。 インターフェイス <literal>org.hibernate.property."
-"PropertyAccessor</literal> を 実装するクラスを指定することで、プロパティへの"
-"アクセスに独自の戦略を指定することができます。"
+"<literal>access</literal> 属性で、実行時に Hibernate がどのようにプロパティに"
+"アクセスするかを制御できます。デフォルトでは Hibernate はプロパティの get/"
+"set のペアをコールします。 <literal>access=\"field\"</literal> と指定すれ"
+"ば、 Hibernate はリフレクションを使い get/set のペアを介さずに、直接フィール"
+"ドにアクセスします。インターフェース <literal>org.hibernate.property."
+"PropertyAccessor</literal> を実装するクラスを指定することで、プロパティへのア"
+"クセスに独自の戦略を指定することができます。"
 
 #. Tag: para
-#: basic_mapping.xml:1463
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A powerful feature is derived properties. These properties are by definition "
 "read-only. The property value is computed at load time. You declare the "
 "computation as an SQL expression. This then translates to a <literal>SELECT</"
 "literal> clause subquery in the SQL query that loads an instance:"
 msgstr ""
-"特に強力な特徴は生成プロパティです。 これらのプロパティは当然読み取り専用であ"
-"り、プロパティの値はロード時に計算されます。 計算をSQL式として宣言すると、こ"
-"のプロパティは インスタンスをロードするSQLクエリの <literal>SELECT</literal> "
-"句のサブクエリに変換されます。"
+"特に強力な特徴は生成プロパティです。これらのプロパティは当然読み取り専用であ"
+"り、プロパティの値はロード時に計算されます。計算を SQL 式として宣言すると、こ"
+"のプロパティはインスタンスをロードする SQL クエリの <literal>SELECT</"
+"literal> 句のサブクエリに変換されます:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1470
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"<property name=\"totalPrice\"\n"
-"    formula=\"( SELECT SUM (li.quantity*p.price) FROM LineItem li, Product "
-"p\n"
-"                WHERE li.productId = p.productId\n"
-"                AND li.customerId = customerId\n"
-"                AND li.orderNumber = orderNumber )\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1472
-#, fuzzy, no-c-format
-msgid ""
 "You can reference the entity table by not declaring an alias on a particular "
 "column. This would be <literal>customerId</literal> in the given example. "
 "You can also use the nested <literal>&lt;formula&gt;</literal> mapping "
 "element if you do not want to use the attribute."
 msgstr ""
 "特定のカラム(例では <literal>customerId</literal> がそれにあたります)のエイリ"
-"アスを宣言することなく、 エンティティ自身のテーブルを参照できることに注意して"
-"ください。 もし属性を使用したくなければ、 ネストした <literal>&lt;formula&gt;"
-"</literal> マッピング要素を使えることにも注意してください。"
+"アスを宣言することなく、エンティティ自身のテーブルを参照できることに注意して"
+"ください。もし属性を使用したくなければ、ネストした <literal>&lt;formula&gt;</"
+"literal> マッピング要素を使えることにも注意してください。"
 
 #. Tag: title
-#: basic_mapping.xml:1482
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Many-to-one"
 msgstr "many-to-one"
 
 #. Tag: para
-#: basic_mapping.xml:1484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An ordinary association to another persistent class is declared using a "
 "<literal>many-to-one</literal> element. The relational model is a many-to-"
@@ -2881,76 +2157,35 @@
 "column(s) of the target table."
 msgstr ""
 "他の永続クラスへの通常の関連は <literal>many-to-one</literal> 要素を使って定"
-"義します。 リレーショナルモデルは多対一関連です。 つまりあるテーブルの外部"
-"キーは、ターゲットとなるテーブルの主キーカラムを参照しています。"
+"義します。リレーショナルモデルは多対一関連です。つまりあるテーブルの外部キー"
+"は、ターゲットとなるテーブルの主キーカラムを参照しています。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1512
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<many-to-one\n"
-"        name=\"propertyName\"\n"
-"        column=\"column_name\"\n"
-"        class=\"ClassName\"\n"
-"        cascade=\"cascade_style\"\n"
-"        fetch=\"join|select\"\n"
-"        update=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unique=\"true|false\"\n"
-"        not-null=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        lazy=\"proxy|no-proxy|false\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        formula=\"arbitrary SQL expression\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        embed-xml=\"true|false\"\n"
-"        index=\"index_name\"\n"
-"        unique_key=\"unique_key_id\"\n"
-"        foreign-key=\"foreign_key_name\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1515 basic_mapping.xml:1696 basic_mapping.xml:1882
-#, fuzzy, no-c-format
 msgid "<literal>name</literal>: the name of the property."
 msgstr "<literal>name</literal>:プロパティ名。"
 
 #. Tag: para
-#: basic_mapping.xml:1520 basic_mapping.xml:2311
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>column</literal> (optional): the name of the foreign key column. "
 "This can also be specified by nested <literal>&lt;column&gt;</literal> "
 "element(s)."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>column</literal> (オプション):外部キーカラムの名前。 ネストした "
-"<literal>&lt;column&gt;</literal> 要素でも指定できます。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>column</literal> (オプション):外部キーカラムの名前。 ネストした "
+"<literal>column</literal> (オプション):外部キーカラムの名前。ネストした "
 "<literal>&lt;column&gt;</literal> カラムによっても指定されます。"
 
 #. Tag: para
-#: basic_mapping.xml:1527 basic_mapping.xml:1701
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
 "determined by reflection): the name of the associated class."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>class</literal>(オプション - デフォルトは、 リフレクションにより決"
-"定されるプロパティの型):関連クラスの名前。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>class</literal>(オプション - デフォルトはリフレクションにより決定さ"
 "れるプロパティの型): 関連クラスの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:1533 basic_mapping.xml:1707
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional): specifies which operations should be "
 "cascaded from the parent object to the associated object."
@@ -2959,24 +2194,17 @@
 "へ、どの操作をカスケードするかを指定します。"
 
 #. Tag: para
-#: basic_mapping.xml:1539 basic_mapping.xml:1722
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional - defaults to <literal>select</literal>): "
 "chooses between outer-join fetching or sequential select fetching."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>fetch</literal> (オプション - デフォルトは <literal>select</"
-"literal> ): 外部結合フェッチか順次選択フェッチ(sequential select fetch)を選"
-"択します。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>fetch</literal>(オプション - デフォルトは <literal>select</"
 "literal> ): 外部結合フェッチと順次選択フェッチ(sequential select fetch)の"
 "どちらかを選択します。"
 
 #. Tag: para
-#: basic_mapping.xml:1545
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update, insert</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that the mapped columns should be included in SQL "
@@ -2986,26 +2214,25 @@
 "the same column(s), or by a trigger or other application."
 msgstr ""
 "<literal>update, insert</literal>(オプション - デフォルトは <literal>true</"
-"literal> ): マッピングされたカラムがSQLの <literal>UPDATE</literal> または "
-"<literal>INSERT</literal> 文に含まれることを指定します。 両方とも "
-"<literal>false</literal> に設定すると、 その値が同じカラムにマッピングされた"
-"他のプロパティやトリガや 他のアプリケーションによって初期化された純粋な「導"
-"出」プロパティが可能になります。"
+"literal> ): マッピングされたカラムが SQL の <literal>UPDATE</literal> また"
+"は <literal>INSERT</literal> 文に含まれることを指定します。両方とも "
+"<literal>false</literal> に設定すると、その値が同じカラムにマッピングされた他"
+"のプロパティやトリガや他のアプリケーションによって初期化された純粋な「導出」"
+"プロパティが可能になります。"
 
 #. Tag: para
-#: basic_mapping.xml:1554
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): the name of a property of the "
 "associated class that is joined to this foreign key. If not specified, the "
 "primary key of the associated class is used."
 msgstr ""
-"<literal>property-ref</literal>(オプション): この外部キーに結合された関連"
-"クラスのプロパティ名。 何も指定しなければ、関連クラスの主キーが使われます。"
+"<literal>property-ref</literal>: (オプション) この外部キーに加わる、関連クラ"
+"スのプロパティの名前。指定されていない場合は、関連クラスの主キーが使用されま"
+"す。"
 
 #. Tag: para
-#: basic_mapping.xml:1567
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): enables the DDL generation of a unique "
 "constraint for the foreign-key column. By allowing this to be the target of "
@@ -3013,23 +2240,21 @@
 "one-to-one."
 msgstr ""
 "<literal>unique</literal>(オプション): 外部キーカラムに対してユニーク制約"
-"をつけたDDLの生成を可能にします。 また、<literal>property-ref</literal> の"
-"ターゲットにすることもできます。 これにより関連の多重度を効果的に一対一にしま"
+"をつけた DDL の生成を可能にします。また、 <literal>property-ref</literal> の"
+"ターゲットにすることもできます。これにより関連の多重度を効果的に一対一にしま"
 "す。"
 
 #. Tag: para
-#: basic_mapping.xml:1575
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): enables the DDL generation of a "
 "nullability constraint for the foreign key columns."
 msgstr ""
-"<literal>not-null</literal> (オプション):外部キーカラムに対して、 null値を許"
-"可するDDLの生成を可能にします"
+"<literal>not-null</literal> (オプション): 外部キーカラムに対して、 null 値を"
+"許可する DDL の生成を可能にします。"
 
 #. Tag: para
-#: basic_mapping.xml:1589
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>proxy</literal>): "
 "by default, single point associations are proxied. <literal>lazy=\"no-proxy"
@@ -3041,49 +2266,42 @@
 "<literal>lazy</literal> (オプション - デフォルトは <literal>proxy</"
 "literal> ): デフォルトでは、多重度1の関連がプロキシとなります。 "
 "<literal>lazy=\"no-proxy\"</literal> は、インスタンス変数に最初にアクセスした"
-"ときに、 プロパティを遅延フェッチするよう指定します (ビルド時にバイトコード実"
+"ときに、プロパティを遅延フェッチするよう指定します (ビルド時にバイトコード実"
 "装が必要になります)。 <literal>lazy=\"false\"</literal> は関連を常に即時に"
 "フェッチするよう指定します。"
 
 #. Tag: para
-#: basic_mapping.xml:1599
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-found</literal> (optional - defaults to <literal>exception</"
 "literal>): specifies how foreign keys that reference missing rows will be "
 "handled. <literal>ignore</literal> will treat a missing row as a null "
 "association."
 msgstr ""
-"<literal>not-found</literal> (オプション - デフォルトは <literal>exception</"
-"literal> ): 欠落した行を参照する外部キーをどのように扱うかを指定します。 "
-"<literal>ignore</literal> は欠落した行をnull関連として扱います。"
+"<literal>not-found</literal> (オプション - デフォルトは <literal>exception</"
+"literal>): 参照先の行がない外部キーをどのように扱うかを指定します: "
+"<literal>ignore</literal> を指定すると、行がないことを関連がないものとして扱"
+"います。"
 
 #. Tag: para
-#: basic_mapping.xml:1606 basic_mapping.xml:1760
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>entity-name</literal> (optional): the entity name of the associated "
 "class."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>entity-name</literal> (オプション):関連したクラスのエンティティ"
-"名。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>entity-name</literal> (オプション):関連クラスのエンティティ名"
+"<literal>entity-name</literal> (オプション):関連したクラスのエンティティ名。"
 
 #. Tag: para
-#: basic_mapping.xml:1611
 #, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an SQL expression that defines the "
 "value for a <emphasis>computed</emphasis> foreign key."
 msgstr ""
 "<literal>formula</literal> (オプション): <emphasis> 計算された</emphasis> 外"
-"部キーに対して値を定義するSQL式"
+"部キーに対して値を定義する SQL 式"
 
 #. Tag: para
-#: basic_mapping.xml:1619
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Setting a value of the <literal>cascade</literal> attribute to any "
 "meaningful value other than <literal>none</literal> will propagate certain "
@@ -3093,41 +2311,31 @@
 "second, special values: <literal>delete-orphan</literal>; and third,"
 "<literal>all</literal> comma-separated combinations of operation names: "
 "<literal>cascade=\"persist,merge,evict\"</literal> or <literal>cascade=\"all,"
-"delete-orphan\"</literal>. See <xref linkend=\"objectstate-transitive\"/> "
+"delete-orphan\"</literal>. See <xref linkend=\"objectstate-transitive\" /> "
 "for a full explanation. Note that single valued, many-to-one and one-to-one, "
 "associations do not support orphan delete."
 msgstr ""
 "<literal>cascade</literal> 属性に <literal>none</literal> 以外の意味のある値"
-"をを設定すると、 関連オブジェクトへある操作が伝播することになります。 意味の"
-"ある値とはHibernateの基本操作の名前のことで、 <literal>delete-orphan</"
-"literal> と <literal>all</literal> 、操作名をカンマで区切った組み合わせ (例"
-"えば <literal>cascade=\"persist,merge,evict\"</literal> や <literal>cascade="
-"\"all,delete-orphan\"</literal>)、 またそれだけでなく <literal>persist, "
-"merge, delete, save-update, evict, replicate, lock, refresh</literal> のこと"
-"を指します。 詳しい説明は <xref linkend=\"objectstate-transitive\"/> を見てく"
-"ださい。 値が一つの関連(many-to-oneとone-to-one関連)は、 単独での削除"
-"(orphan delete)をサポートしていないことに注意してください。"
+"を設定すると、関連オブジェクトへある操作が伝播することになります。意味のある"
+"値とは Hibernate の基本操作の名前のことで、 <literal>delete-orphan</literal> "
+"と <literal>all</literal> 、操作名をカンマで区切った組み合わせ (例えば "
+"<literal>cascade=\"persist,merge,evict\"</literal> ã‚„ <literal>cascade=\"all,"
+"delete-orphan\"</literal>)、またそれだけでなく <literal>persist, merge, "
+"delete, save-update, evict, replicate, lock, refresh</literal> のことを指しま"
+"す。詳しい説明は <xref linkend=\"objectstate-transitive\"/> を参照してくださ"
+"い。値が一つの関連 (many-to-one と one-to-one関連) は、単独での削除 (orphan "
+"delete) をサポートしていないことに注意してください。"
 
 #. Tag: para
-#: basic_mapping.xml:1632
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Here is an example of a typical <literal>many-to-one</literal> declaration:"
 msgstr ""
 "典型的な <literal>many-to-one</literal> 宣言は次のようにシンプルです。:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1636
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"product\" class=\"Product\" column=\"PRODUCT_ID"
-"\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1638
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>property-ref</literal> attribute should only be used for "
 "mapping legacy data where a foreign key refers to a unique key of the "
 "associated table other than the primary key. This is a complicated and "
@@ -3137,43 +2345,24 @@
 "the SchemaExport tool."
 msgstr ""
 "<literal>property-ref</literal> 属性は、外部キーが関連付けられたテーブルの、"
-"主キーでない ユニークキーを参照しているレガシーデータをマップするためにだけ使"
-"うべきです。 これは醜いリレーショナルモデルです。 例えば <literal>Product</"
-"literal> クラスが、 主キーでないユニークなシリアルナンバーを持っていると仮定"
-"してみてください。 ( <literal>unique</literal> 属性はSchemaExportツールを"
-"使ったHibernateのDDL生成を制御します。)"
+"主キーでないユニークキーを参照しているレガシーデータをマップするためにだけ使"
+"うべきです。これは醜いリレーショナルモデルです。例えば <literal>Product</"
+"literal> クラスが、主キーでないユニークなシリアルナンバーを持っていると仮定し"
+"てみてください。( <literal>unique</literal> 属性は SchemaExport ツールを使っ"
+"た Hibernate の DDL 生成を制御します。)"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1647
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"serialNumber\" unique=\"true\" type=\"string\" "
-"column=\"SERIAL_NUMBER\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1649
 #, no-c-format
 msgid "Then the mapping for <literal>OrderItem</literal> might use:"
 msgstr ""
 "以下のように <literal>OrderItem</literal> に対してマッピングを使えます:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1653
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"product\" property-ref=\"serialNumber\" column="
-"\"PRODUCT_SERIAL_NUMBER\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1655
-#, fuzzy, no-c-format
 msgid "This is not encouraged, however."
 msgstr "しかし、これは決して推奨できません。"
 
 #. Tag: para
-#: basic_mapping.xml:1659
 #, no-c-format
 msgid ""
 "If the referenced unique key comprises multiple properties of the associated "
@@ -3181,35 +2370,24 @@
 "properties&gt;</literal> element."
 msgstr ""
 "参照したユニークキーが、関連するエンティティの多数のプロパティから構成される"
-"場合、 指定した <literal>&lt;properties&gt;</literal> 要素内で、参照するプロ"
-"パティをマッピングするべきです。"
+"場合、指定した <literal>&lt;properties&gt;</literal> 要素内で、参照するプロパ"
+"ティをマッピングするべきです。"
 
 #. Tag: para
-#: basic_mapping.xml:1664
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the referenced unique key is the property of a component, you can specify "
 "a property path:"
 msgstr ""
 "もし参照したユニークキーがコンポーネントのプロパティである場合は、プロパティ"
-"のパスを指定できます。"
+"のパスを指定できます:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1668
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"owner\" property-ref=\"identity.ssn\" column="
-"\"OWNER_SSN\"/>]]>"
-msgstr ""
-
-#. Tag: title
-#: basic_mapping.xml:1673
-#, fuzzy, no-c-format
 msgid "One-to-one"
 msgstr "one-to-one"
 
 #. Tag: para
-#: basic_mapping.xml:1675
 #, no-c-format
 msgid ""
 "A one-to-one association to another persistent class is declared using a "
@@ -3218,31 +2396,9 @@
 "他の永続クラスへの一対一関連は、<literal>one-to-one</literal> 要素で定義しま"
 "す。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1693
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<one-to-one\n"
-"        name=\"propertyName\"\n"
-"        class=\"ClassName\"\n"
-"        cascade=\"cascade_style\"\n"
-"        constrained=\"true|false\"\n"
-"        fetch=\"join|select\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        formula=\"any SQL expression\"\n"
-"        lazy=\"proxy|no-proxy|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        embed-xml=\"true|false\"\n"
-"        foreign-key=\"foreign_key_name\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1713
-#, fuzzy, no-c-format
-msgid ""
 "<literal>constrained</literal> (optional): specifies that a foreign key "
 "constraint on the primary key of the mapped table and references the table "
 "of the associated class. This option affects the order in which <literal>save"
@@ -3251,26 +2407,24 @@
 "tool."
 msgstr ""
 "<literal>constrained</literal>(オプション): マッピングされたテーブルの主"
-"キーに対する外部キー制約が、 関連クラスのテーブルを参照することを指定しま"
-"す。 このオプションは <literal>save()</literal> と <literal>delete()</"
-"literal> がカスケードされる順序に影響し、 そして関連がプロキシされるかどうか"
-"にも影響します (そしてスキーマエクスポートツールにも使われます)。"
+"キーに対する外部キー制約が、関連クラスのテーブルを参照することを指定します。"
+"このオプションは <literal>save()</literal> と <literal>delete()</literal> が"
+"カスケードされる順序に影響し、そして関連がプロキシされるかどうかにも影響しま"
+"す (そしてスキーマエクスポートツールにも使われます)。"
 
 #. Tag: para
-#: basic_mapping.xml:1728
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): the name of a property of the "
 "associated class that is joined to the primary key of this class. If not "
 "specified, the primary key of the associated class is used."
 msgstr ""
 "<literal>property-ref</literal>(オプション): このクラスの主キーに結合され"
-"た関連クラスのプロパティ名。 指定されなければ、関連クラスの主キーが使われま"
+"た関連クラスのプロパティ名。指定されなければ、関連クラスの主キーが使われま"
 "す。"
 
 #. Tag: para
-#: basic_mapping.xml:1741
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): almost all one-to-one associations "
 "map to the primary key of the owning entity. If this is not the case, you "
@@ -3279,13 +2433,12 @@
 "example."
 msgstr ""
 "<literal>formula</literal> (オプション): ほとんどすべての一対一関連はオーナー"
-"のエンティティの主キーへとマッピングされます。 これ以外の稀な場合は、 他のカ"
-"ラムや、複数のカラム、SQL構文を使った結合するための式を指定できます。 (例は "
+"のエンティティの主キーへとマッピングされます。これ以外の稀な場合は、他のカラ"
+"ムや、複数のカラム、 SQL 構文を使った結合するための式を指定できます。(例は "
 "<literal>org.hibernate.test.onetooneformula</literal> を参照してください。)"
 
 #. Tag: para
-#: basic_mapping.xml:1749
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>proxy</literal>): "
 "by default, single point associations are proxied. <literal>lazy=\"no-proxy"
@@ -3299,47 +2452,42 @@
 "<literal>lazy</literal> (オプション - デフォルトは <literal>proxy</"
 "literal> ): デフォルトでは、多重度1の関連がプロキシとなります。 "
 "<literal>lazy=\"no-proxy\"</literal> は、インスタンス変数に最初にアクセスした"
-"ときに、 プロパティを遅延フェッチするよう指定します (ビルド時にバイトコード実"
+"ときに、プロパティを遅延フェッチするよう指定します (ビルド時にバイトコード実"
 "装が必要になります)。 <literal>lazy=\"false\"</literal> は関連を常に即時に"
 "フェッチするよう指定します。 <emphasis>もし <literal>constrained=\"false\"</"
-"literal> ならば、 プロキシは使用不可能となり、関連を即時にフェッチすることに"
-"注意してください!</emphasis>"
+"literal> ならば、プロキシは使用不可能となり、関連を即時にフェッチすることに注"
+"意してください。</emphasis>"
 
 #. Tag: para
-#: basic_mapping.xml:1767
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "There are two varieties of one-to-one associations:"
 msgstr "一対一関連には2種類あります:"
 
 #. Tag: para
-#: basic_mapping.xml:1771
 #, no-c-format
 msgid "primary key associations"
 msgstr "主キー関連"
 
 #. Tag: para
-#: basic_mapping.xml:1774
 #, no-c-format
 msgid "unique foreign key associations"
 msgstr "ユニーク外部キー関連"
 
 #. Tag: para
-#: basic_mapping.xml:1779
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Primary key associations do not need an extra table column. If two rows are "
 "related by the association, then the two table rows share the same primary "
 "key value. To relate two objects by a primary key association, ensure that "
 "they are assigned the same identifier value."
 msgstr ""
-"主キー関連には、特別なテーブルカラムは必要ありません。 もし2つの行が関連によ"
-"り関係していれば、2つのテーブルは同じ主キーの値を共有します。 そのため2つのオ"
-"ブジェクトを主キー関連によって関連付けたいのであれば、 確実に同じ識別子の値を"
-"代入しなければなりません。"
+"主キー関連には、特別なテーブルカラムは必要ありません。もし2つの行が関連により"
+"関係していれば、2つのテーブルは同じ主キーの値を共有します。そのため2つのオブ"
+"ジェクトを主キー関連によって関連付けたいのであれば、確実に同じ識別子の値を代"
+"入しなければなりません。"
 
 #. Tag: para
-#: basic_mapping.xml:1786
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For a primary key association, add the following mappings to "
 "<literal>Employee</literal> and <literal>Person</literal> respectively:"
@@ -3347,123 +2495,59 @@
 "主キー関連を行うためには、以下のマッピングを <literal>Employee</literal> と "
 "<literal>Person</literal> のそれぞれに追加してください。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1791
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[<one-to-one name=\"person\" class=\"Person\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:1792
-#, no-c-format
 msgid ""
-"<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" constrained=\"true"
-"\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1794
-#, fuzzy, no-c-format
-msgid ""
 "Ensure that the primary keys of the related rows in the PERSON and EMPLOYEE "
 "tables are equal. You use a special Hibernate identifier generation strategy "
 "called <literal>foreign</literal>:"
 msgstr ""
-"ここで、PERSONとEMPLOYEEテーブルの関係する行の主キーが同じであることを確実に"
-"しなければいけません。 ここでは、<literal>foreign</literal> という特殊な"
-"Hibernate識別子生成戦略を使います:"
+"ここで、 PERSON と EMPLOYEE テーブルの関係する行の主キーが同じであることを確"
+"実にしなければいけません。ここでは、 <literal>foreign</literal> という特殊な "
+"Hibernate 識別子生成戦略を使います:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1800
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"person\" table=\"PERSON\">\n"
-"    <id name=\"id\" column=\"PERSON_ID\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">employee</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    ...\n"
-"    <one-to-one name=\"employee\"\n"
-"        class=\"Employee\"\n"
-"        constrained=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1802
-#, fuzzy, no-c-format
-msgid ""
 "A newly saved instance of <literal>Person</literal> is assigned the same "
 "primary key value as the <literal>Employee</literal> instance referred with "
 "the <literal>employee</literal> property of that <literal>Person</literal>."
 msgstr ""
-"<literal>Employee</literal> インスタンスが、<literal>Person</literal> の "
-"<literal>employee</literal> プロパティで参照されるように、 新しくセーブされ"
-"た <literal>Person</literal> のインスタンスには同じ主キーの値が代入されま"
-"す。 新しくセーブする <literal>Person</literal> インスタンスは、 その "
+"<literal>Employee</literal> インスタンスが、 <literal>Person</literal> の "
+"<literal>employee</literal> プロパティで参照されるように、新しくセーブされた "
+"<literal>Person</literal> のインスタンスには同じ主キーの値が代入されます。新"
+"しくセーブする <literal>Person</literal> インスタンスは、その "
 "<literal>Person</literal> の <literal>employee</literal> プロパティが参照す"
 "る <literal>Employee</literal> インスタンスとして同じ主キーが割り当てられま"
 "す。"
 
 #. Tag: para
-#: basic_mapping.xml:1808
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, a foreign key with a unique constraint, from "
 "<literal>Employee</literal> to <literal>Person</literal>, can be expressed "
 "as:"
 msgstr ""
-"もう1つの方法として、<literal>Employee</literal> から <literal>Person</"
-"literal> への ユニーク制約を使った外部キー関連は以下のように表現されます:"
+"もう1つの方法として、 <literal>Employee</literal> から <literal>Person</"
+"literal> へのユニーク制約を使った外部キー関連は以下のように表現されます:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1813
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"person\" class=\"Person\" column=\"PERSON_ID\" "
-"unique=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1815
-#, fuzzy, no-c-format
-msgid ""
 "This association can be made bidirectional by adding the following to the "
 "<literal>Person</literal> mapping:"
 msgstr ""
-"そしてこの関連は、 以下の記述を <literal>Person</literal> のマッピングに追加"
-"することで双方向にすることができます:"
+"そしてこの関連は、以下の記述を <literal>Person</literal> のマッピングに追加す"
+"ることで双方向にすることができます:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1820
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" property-ref="
-"\"person\"/>]]>"
-msgstr ""
-
-#. Tag: title
-#: basic_mapping.xml:1825
-#, fuzzy, no-c-format
 msgid "Natural-id"
 msgstr "natural-id"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1827
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<natural-id mutable=\"true|false\"/>\n"
-"        <property ... />\n"
-"        <many-to-one ... />\n"
-"        ......\n"
-"</natural-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1829
-#, fuzzy, no-c-format
-msgid ""
 "Although we recommend the use of surrogate keys as primary keys, you should "
 "try to identify natural keys for all entities. A natural key is a property "
 "or combination of properties that is unique and non-null. It is also "
@@ -3472,16 +2556,15 @@
 "unique key and nullability constraints and, as a result, your mapping will "
 "be more self-documenting."
 msgstr ""
-"主キーとして代理キーの使用を推奨しますが、 すべてのエンティティに対して自然"
-"キーを識別するようにすべきです。 自然キーはユニークかつ非nullな一つのプロパ"
-"ティ、またはプロパティの連結です。 不変であればさらに良いです。 <literal>&lt;"
+"主キーとして代理キーの使用を推奨しますが、すべてのエンティティに対して自然"
+"キーを識別するようにすべきです。自然キーはユニークかつ非 null な一つのプロパ"
+"ティ、またはプロパティの連結です。不変であればさらに良いです。 <literal>&lt;"
 "natural-id&gt;</literal> 要素内で自然キーのプロパティをマッピングします。 "
-"Hibernateは必然的にユニークかつnull値を許可する制約を生成し、 こうしてマッピ"
-"ングはより自己記述的になります。"
+"Hibernate は必然的にユニークかつ null 値を許可する制約を生成し、こうしてマッ"
+"ピングはより自己記述的になります。"
 
 #. Tag: para
-#: basic_mapping.xml:1838
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you implement <literal>equals()</literal> and "
 "<literal>hashCode()</literal> to compare the natural key properties of the "
@@ -3491,8 +2574,7 @@
 "<literal>hashCode()</literal> の実装を強くお勧めします。"
 
 #. Tag: para
-#: basic_mapping.xml:1843
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This mapping is not intended for use with entities that have natural primary "
 "keys."
@@ -3500,63 +2582,37 @@
 "このマッピングは自然主キーを使ったエンティティでの使用を意図していません。"
 
 #. Tag: para
-#: basic_mapping.xml:1849
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>false</"
 "literal>): by default, natural identifier properties are assumed to be "
 "immutable (constant)."
 msgstr ""
-"<literal>mutable</literal> (オプション, デフォルトは <literal>false</"
+"<literal>mutable</literal> (オプション、 デフォルトは <literal>false</"
 "literal> ): デフォルトでは、自然識別子プロパティは不変(定数)と想定されていま"
 "す。"
 
 #. Tag: title
-#: basic_mapping.xml:1859
 #, fuzzy, no-c-format
 msgid "Component and dynamic-component"
 msgstr "component, dynamic-component"
 
 #. Tag: para
-#: basic_mapping.xml:1861
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element maps properties of a child "
 "object to columns of the table of a parent class. Components can, in turn, "
 "declare their own properties, components or collections. See the \"Component"
 "\" examples below:"
 msgstr ""
-"<literal>&lt;component&gt;</literal> 要素は、 子オブジェクトのプロパティを親"
-"クラスのテーブルのカラムへマッピングします。 コンポーネントは自分のプロパ"
-"ティ、コンポーネント、コレクションの順に定義できます。 以下の「コンポーネン"
-"ト」を見てください。"
+"<literal>&lt;component&gt;</literal> 要素は、子オブジェクトのプロパティを親ク"
+"ラスのテーブルのカラムへマッピングします。コンポーネントは自分のプロパティ、"
+"コンポーネント、コレクションの順に定義できます。以下の「コンポーネント」を見"
+"てください。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1879
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<component\n"
-"        name=\"propertyName\"\n"
-"        class=\"className\"\n"
-"        insert=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        lazy=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        node=\"element-name|.\"\n"
-">\n"
-"\n"
-"        <property ...../>\n"
-"        <many-to-one .... />\n"
-"        ........\n"
-"</component>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1887
-#, fuzzy, no-c-format
-msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
 "determined by reflection): the name of the component (child) class."
 msgstr ""
@@ -3564,48 +2620,37 @@
 "されるプロパティの型): コンポーネント(子)クラスの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:1893 basic_mapping.xml:1982
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>insert</literal>: do the mapped columns appear in SQL "
 "<literal>INSERTs</literal>?"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>insert</literal> :マッピングされたカラムがSQLの <literal>INSERT</"
-"literal> に現れるようにするどうかを指定します。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>insert</literal>:マッピングされたカラムがSQLの <literal>INSERT</"
+"<literal>insert</literal>:マッピングされたカラムが SQL の <literal>INSERT</"
 "literal> に現れるようにするかどうかを指定します。"
 
 #. Tag: para
-#: basic_mapping.xml:1899 basic_mapping.xml:1988
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update</literal>: do the mapped columns appear in SQL "
 "<literal>UPDATEs</literal>?"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>update</literal> : マッピングされたカラムがSQL の <literal>UPDATE</"
-"literal> に現れるようにするかどうかを指定します。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>update</literal>:マッピングされたカラムがSQLの <literal>UPDATE</"
+"<literal>update</literal>:マッピングされたカラムが SQL の <literal>UPDATE</"
 "literal> に現れるようにするかどうかを指定します。"
 
 #. Tag: para
-#: basic_mapping.xml:1911
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>false</literal>): "
 "specifies that this component should be fetched lazily when the instance "
 "variable is first accessed. It requires build-time bytecode instrumentation."
 msgstr ""
-"<literal>lazy</literal> (optional - デフォルトは <literal>false</literal> ): "
-"インスタンス変数に最初にアクセスしたときに、 コンポーネントを遅延してフェッチ"
-"するよう指定します。 (バイトコード実装を作成する時間が必要になります)"
+"<literal>lazy</literal> (オプション - デフォルトは <literal>false</"
+"literal> ): インスタンス変数に最初にアクセスしたときに、コンポーネントを遅延"
+"してフェッチするよう指定します。 (バイトコード実装を作成する時間が必要になり"
+"ます)"
 
 #. Tag: para
-#: basic_mapping.xml:1918
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to this component either do or do not "
@@ -3614,12 +2659,11 @@
 msgstr ""
 "<literal>optimistic-lock</literal> (オプション - デフォルトは <literal>true</"
 "literal> ): このプロパティの更新に、楽観ロックの取得を要求するかどうかを指定"
-"します。 言い換えれば、このプロパティがダーティであるときにバージョンを増やす"
+"します。言い換えれば、このプロパティがダーティであるときにバージョンを増やす"
 "べきかを決定します。"
 
 #. Tag: para
-#: basic_mapping.xml:1926 basic_mapping.xml:2002
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional - defaults to <literal>false</literal>): "
 "specifies that a unique constraint exists upon all mapped columns of the "
@@ -3630,50 +2674,45 @@
 "在するかを指定します。"
 
 #. Tag: para
-#: basic_mapping.xml:1935
 #, no-c-format
 msgid ""
 "The child <literal>&lt;property&gt;</literal> tags map properties of the "
 "child class to table columns."
 msgstr ""
-"子の <literal>&lt;property&gt;</literal> タグで、 子のクラスのプロパティを"
-"テーブルカラムにマッピングします。"
+"子の <literal>&lt;property&gt;</literal> タグで、子のクラスのプロパティをテー"
+"ブルカラムにマッピングします。"
 
 #. Tag: para
-#: basic_mapping.xml:1940
 #, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element allows a <literal>&lt;"
 "parent&gt;</literal> subelement that maps a property of the component class "
 "as a reference back to the containing entity."
 msgstr ""
-"<literal>&lt;component&gt;</literal> 要素は、親エンティティへ戻る参照とし"
-"て、 コンポーネントのクラスのプロパティをマッピングする <literal>&lt;"
-"parent&gt;</literal> サブ要素を許可します。"
+"<literal>&lt;component&gt;</literal> 要素は、親エンティティへ戻る参照として、"
+"コンポーネントのクラスのプロパティをマッピングする <literal>&lt;parent&gt;</"
+"literal> サブ要素を許可します。"
 
 #. Tag: para
-#: basic_mapping.xml:1946
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;dynamic-component&gt;</literal> element allows a "
 "<literal>Map</literal> to be mapped as a component, where the property names "
-"refer to keys of the map. See <xref linkend=\"components-dynamic\"/> for "
+"refer to keys of the map. See <xref linkend=\"components-dynamic\" /> for "
 "more information."
 msgstr ""
 "<literal>&lt;dynamic-component&gt;</literal> 要素は、 <literal>Map</literal> "
-"がコンポーネントとしてマッピングされることを可能にします。 プロパティ名はmap"
+"がコンポーネントとしてマッピングされることを可能にします。プロパティ名は map "
 "のキーを参照します。<xref linkend=\"components-dynamic\"/> を参照してくださ"
 "い。"
 
 #. Tag: title
-#: basic_mapping.xml:1955
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Properties"
-msgstr "properties"
+msgstr "プロパティ"
 
 #. Tag: para
-#: basic_mapping.xml:1957
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;properties&gt;</literal> element allows the definition of a "
 "named, logical grouping of the properties of a class. The most important use "
@@ -3681,43 +2720,23 @@
 "target of a <literal>property-ref</literal>. It is also a convenient way to "
 "define a multi-column unique constraint. For example:"
 msgstr ""
-"<literal>&lt;properties&gt;</literal> 要素はクラスのプロパティの指定された、 "
-"論理的なグルーピングを可能にします。 この構造の最も重要な使用方法は、 "
+"<literal>&lt;properties&gt;</literal> 要素はクラスのプロパティの指定された、"
+"論理的なグルーピングを可能にします。この構造の最も重要な使用方法は、 "
 "<literal>property-ref</literal> のターゲットになるプロパティの結合を許可する"
-"ことです。 それはまた、複数カラムのユニーク制約を定義する簡単な方法でもありま"
+"ことです。それはまた、複数カラムのユニーク制約を定義する簡単な方法でもありま"
 "す。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1973
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<properties\n"
-"        name=\"logicalName\"\n"
-"        insert=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-">\n"
-"\n"
-"        <property ...../>\n"
-"        <many-to-one .... />\n"
-"        ........\n"
-"</properties>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1976
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal>: the logical name of the grouping. It is "
 "<emphasis>not</emphasis> an actual property name."
 msgstr ""
-"<literal>name</literal> : グルーピングの論理名。 実際のプロパティ名では "
+"<literal>name</literal> : グルーピングの論理名。実際のプロパティ名では "
 "<emphasis>ありません</emphasis> 。"
 
 #. Tag: para
-#: basic_mapping.xml:1994
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to these properties either do or do not "
@@ -3726,11 +2745,10 @@
 msgstr ""
 "<literal>optimistic-lock</literal> (オプション - デフォルトは <literal>true</"
 "literal> ): これらのプロパティの更新に楽観的ロックの取得を要求するかどうかを"
-"指定します。 言い換えれば、このプロパティがダーティであるときにバージョンを増"
+"指定します。言い換えれば、このプロパティがダーティであるときにバージョンを増"
 "やすべきかを決定します。"
 
 #. Tag: para
-#: basic_mapping.xml:2011
 #, no-c-format
 msgid ""
 "For example, if we have the following <literal>&lt;properties&gt;</literal> "
@@ -3739,49 +2757,18 @@
 "例えば、もし以下のような <literal>&lt;properties&gt;</literal> マッピングが"
 "あった場合:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2015
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"personNumber\"/>\n"
-"\n"
-"    ...\n"
-"    <properties name=\"name\"\n"
-"            unique=\"true\" update=\"false\">\n"
-"        <property name=\"firstName\"/>\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"lastName\"/>\n"
-"    </properties>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2017
-#, fuzzy, no-c-format
-msgid ""
 "You might have some legacy data association that refers to this unique key "
 "of the <literal>Person</literal> table, instead of to the primary key:"
 msgstr ""
 "主キーの代わりに <literal>Person</literal> テーブルのユニークキーへの参照を持"
-"つ、 レガシーデータの関連を持つかもしれません。:"
+"つ、レガシーデータの関連を持つかもしれません。:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2022
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"person\"\n"
-"         class=\"Person\" property-ref=\"name\">\n"
-"    <column name=\"firstName\"/>\n"
-"    <column name=\"initial\"/>\n"
-"    <column name=\"lastName\"/>\n"
-"</many-to-one>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2024
-#, fuzzy, no-c-format
-msgid ""
 "The use of this outside the context of mapping legacy data is not "
 "recommended."
 msgstr ""
@@ -3789,53 +2776,29 @@
 "せん。"
 
 #. Tag: title
-#: basic_mapping.xml:2032
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Subclass"
 msgstr "subclass"
 
 #. Tag: para
-#: basic_mapping.xml:2034
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Polymorphic persistence requires the declaration of each subclass of the "
 "root persistent class. For the table-per-class-hierarchy mapping strategy, "
 "the <literal>&lt;subclass&gt;</literal> declaration is used. For example:"
 msgstr ""
 "最後にポリモーフィックな永続化には、ルートの永続クラスの各サブクラスの定義が"
-"必要です。 table-per-class-hierarchyマッピング戦略では、 <literal>&lt;"
+"必要です。 table-per-class-hierarchy マッピング戦略では、 <literal>&lt;"
 "subclass&gt;</literal> 定義が使われます。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2047
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<subclass\n"
-"        name=\"ClassName\"\n"
-"        discriminator-value=\"discriminator_value\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\"\n"
-"        extends=\"SuperclassName\">\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</subclass>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2050 basic_mapping.xml:2108 basic_mapping.xml:2171
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal>: the fully qualified class name of the subclass."
 msgstr "<literal>name</literal>:サブクラスの完全修飾されたクラス名。"
 
 #. Tag: para
-#: basic_mapping.xml:2055
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>discriminator-value</literal> (optional - defaults to the class "
 "name): a value that distinguishes individual subclasses."
@@ -3844,43 +2807,25 @@
 "名): 個々のサブクラスを区別するための値。"
 
 #. Tag: para
-#: basic_mapping.xml:2061
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies a class or interface used for "
 "lazy initializing proxies."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal>(オプション): 遅延初期化プロキシに使うクラスやイン"
-"ターフェイスを指定します。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>proxy</literal> (オプション): 遅延初期化プロキシに使用するクラスやイ"
-"ンターフェイスを指定します。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal> (オプション): 遅延初期化プロキシに使用するクラスやイ"
-"ンターフェイスを指定します。"
+"ンターフェースを指定します。"
 
 #. Tag: para
-#: basic_mapping.xml:2067
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>true</literal>): "
 "setting <literal>lazy=\"false\"</literal> disables the use of lazy fetching."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal>(オプション, デフォルトは <literal>true</"
-"literal> ): <literal>lazy=\"false\"</literal> と設定すると、遅延フェッチが"
-"使用できません。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (オプション, デフォルトは <literal>true</literal> ): "
-"<literal>lazy=\"false\"</literal> とすると、遅延フェッチが使用できません。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (オプション, デフォルトは <literal>true</literal> ): "
+"<literal>lazy</literal> (オプション、デフォルトは <literal>true</literal> ): "
 "<literal>lazy=\"false\"</literal> とすると、遅延フェッチが使用できません。"
 
 #. Tag: para
-#: basic_mapping.xml:2075
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Each subclass declares its own persistent properties and subclasses. "
 "<literal>&lt;version&gt;</literal> and <literal>&lt;id&gt;</literal> "
@@ -3889,30 +2834,27 @@
 "this is not specified, the fully qualified Java class name is used."
 msgstr ""
 "各サブクラスでは、永続プロパティとサブクラスを定義します。 <literal>&lt;"
-"version&gt;</literal> と <literal>&lt;id&gt;</literal> プロパティは、 ルート"
-"クラスから継承されると仮定されます。 階層構造におけるサブクラスは、 ユニーク"
-"な <literal>discriminator-value</literal> を定義しなければなりません。 noneが"
-"指定されると、完全修飾されたJavaクラス名が使われます。"
+"version&gt;</literal> と <literal>&lt;id&gt;</literal> プロパティは、ルートク"
+"ラスから継承されると仮定されます。階層構造におけるサブクラスは、ユニークな "
+"<literal>discriminator-value</literal> を定義しなければなりません。 none が指"
+"定されると、完全修飾された Java クラス名が使われます。"
 
 #. Tag: para
-#: basic_mapping.xml:2083 basic_mapping.xml:2141 basic_mapping.xml:2199
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"For information about inheritance mappings see <xref linkend=\"inheritance\"/"
-">."
+"For information about inheritance mappings see <xref linkend=\"inheritance"
+"\" />."
 msgstr ""
-"継承のマッピングに関する情報は <xref linkend=\"inheritance\"/> を見てくださ"
-"い。"
+"継承のマッピングに関する情報は <xref linkend=\"inheritance\"/> を参照してくだ"
+"さい。"
 
 #. Tag: title
-#: basic_mapping.xml:2090
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Joined-subclass"
 msgstr "joined-subclass"
 
 #. Tag: para
-#: basic_mapping.xml:2092
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Each subclass can also be mapped to its own table. This is called the table-"
 "per-subclass mapping strategy. An inherited state is retrieved by joining "
@@ -3920,138 +2862,53 @@
 "subclass&gt;</literal> element. For example:"
 msgstr ""
 "もう1つの方法として、各サブクラスを自身のテーブルへマッピングすることができま"
-"す (table-per-subclass mapping strategy)。 継承した状態はスーパークラスのテー"
+"す (table-per-subclass mapping strategy)。継承した状態はスーパークラスのテー"
 "ブルを使った結合で検索します。 <literal>&lt;joined-subclass&gt;</literal> 要"
 "素を使用します。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2105
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<joined-subclass\n"
-"        name=\"ClassName\"\n"
-"        table=\"tablename\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        schema=\"schema\"\n"
-"        catalog=\"catalog\"\n"
-"        extends=\"SuperclassName\"\n"
-"        persister=\"ClassName\"\n"
-"        subselect=\"SQL expression\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\">\n"
-"\n"
-"        <key .... >\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</joined-subclass>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2113 basic_mapping.xml:2176
-#, fuzzy, no-c-format
 msgid "<literal>table</literal>: the name of the subclass table."
 msgstr "<literal>table</literal> :サブクラステーブルの名前。"
 
 #. Tag: para
-#: basic_mapping.xml:2118 basic_mapping.xml:2181
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies a class or interface to use "
 "for lazy initializing proxies."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal>(オプション): 遅延初期化プロキシに使うクラスやイン"
-"ターフェイスを指定します。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>proxy</literal> (オプション): 遅延初期化プロキシに使用するクラスやイ"
-"ンターフェイスを指定します。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal> (オプション): 遅延初期化プロキシに使用するクラスやイ"
-"ンターフェイスを指定します。"
+"ンターフェースを指定します。"
 
 #. Tag: para
-#: basic_mapping.xml:2124 basic_mapping.xml:2187
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional, defaults to <literal>true</literal>): "
 "setting <literal>lazy=\"false\"</literal> disables the use of lazy fetching."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal>(オプション, デフォルトは <literal>true</"
-"literal> ): <literal>lazy=\"false\"</literal> と設定すると、遅延フェッチが"
-"使用できません。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (オプション, デフォルトは <literal>true</literal> ): "
-"<literal>lazy=\"false\"</literal> とすると、遅延フェッチが使用できません。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (オプション, デフォルトは <literal>true</literal> ): "
+"<literal>lazy</literal> (オプション、デフォルトは <literal>true</literal> ): "
 "<literal>lazy=\"false\"</literal> とすると、遅延フェッチが使用できません。"
 
 #. Tag: para
-#: basic_mapping.xml:2132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A discriminator column is not required for this mapping strategy. Each "
 "subclass must, however, declare a table column holding the object identifier "
 "using the <literal>&lt;key&gt;</literal> element. The mapping at the start "
 "of the chapter would then be re-written as:"
 msgstr ""
-"このマッピング戦略には、識別カラムは必要ありません。 しかし各サブクラスは "
-"<literal>&lt;key&gt;</literal> 要素を使い、 オブジェクト識別子を保持するテー"
-"ブルカラムを定義しなければなりません。 この章の初めのマッピングは以下のように"
-"書き直せます:"
+"このマッピング戦略には、識別カラムは必要ありません。しかし各サブクラスは "
+"<literal>&lt;key&gt;</literal> 要素を使い、オブジェクト識別子を保持するテーブ"
+"ルカラムを定義しなければなりません。この章の初めのマッピングは以下のように書"
+"き直せます:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2139
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"        <class name=\"Cat\" table=\"CATS\">\n"
-"                <id name=\"id\" column=\"uid\" type=\"long\">\n"
-"                        <generator class=\"hilo\"/>\n"
-"                </id>\n"
-"                <property name=\"birthdate\" type=\"date\"/>\n"
-"                <property name=\"color\" not-null=\"true\"/>\n"
-"                <property name=\"sex\" not-null=\"true\"/>\n"
-"                <property name=\"weight\"/>\n"
-"                <many-to-one name=\"mate\"/>\n"
-"                <set name=\"kittens\">\n"
-"                        <key column=\"MOTHER\"/>\n"
-"                        <one-to-many class=\"Cat\"/>\n"
-"                </set>\n"
-"                <joined-subclass name=\"DomesticCat\" table=\"DOMESTIC_CATS"
-"\">\n"
-"                    <key column=\"CAT\"/>\n"
-"                    <property name=\"name\" type=\"string\"/>\n"
-"                </joined-subclass>\n"
-"        </class>\n"
-"\n"
-"        <class name=\"eg.Dog\">\n"
-"                <!-- mapping for Dog could go here -->\n"
-"        </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: title
-#: basic_mapping.xml:2148
-#, fuzzy, no-c-format
 msgid "Union-subclass"
 msgstr "union-subclass"
 
 #. Tag: para
-#: basic_mapping.xml:2150
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A third option is to map only the concrete classes of an inheritance "
 "hierarchy to tables. This is called the table-per-concrete-class strategy. "
@@ -4064,90 +2921,42 @@
 "example:"
 msgstr ""
 "3つ目の選択肢は、継承階層の具象クラスのみをテーブルにマッピングすることです "
-"(the table-per-concrete-class戦略)。 それぞれのテーブルは継承の状態を含めすべ"
-"てのクラスの永続状態を定義します。 Hibernateではその様な継承階層が必ずしも必"
-"要ではありません。 単純にそれぞれのクラスを、 別々の <literal>&lt;class&gt;</"
-"literal> 宣言を使ってマッピングすることができます。 しかしポリモーフィックな"
-"関連(例えば 階層のスーパークラスへの関連)を使いたいなら、 <literal>&lt;union-"
+"(the table-per-concrete-class 戦略)。それぞれのテーブルは継承の状態を含めすべ"
+"てのクラスの永続状態を定義します。 Hibernate ではその様な継承階層が必ずしも必"
+"要ではありません。単純にそれぞれのクラスを、別々の <literal>&lt;class&gt;</"
+"literal> 宣言を使ってマッピングすることができます。しかしポリモーフィックな関"
+"連 (例えば階層のスーパークラスへの関連) を使いたいなら、 <literal>&lt;union-"
 "subclass&gt;</literal> マッピングを使う必要があります。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2168
-#, no-c-format
-msgid ""
-"<![CDATA[<union-subclass\n"
-"        name=\"ClassName\"\n"
-"        table=\"tablename\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        schema=\"schema\"\n"
-"        catalog=\"catalog\"\n"
-"        extends=\"SuperclassName\"\n"
-"        abstract=\"true|false\"\n"
-"        persister=\"ClassName\"\n"
-"        subselect=\"SQL expression\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\">\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</union-subclass>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2195
 #, no-c-format
 msgid ""
 "No discriminator column or key column is required for this mapping strategy."
 msgstr "このマッピング戦略では識別カラムやキーカラムは必要ありません。"
 
 #. Tag: title
-#: basic_mapping.xml:2206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Join"
 msgstr "join"
 
 #. Tag: para
-#: basic_mapping.xml:2208
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Using the <literal>&lt;join&gt;</literal> element, it is possible to map "
 "properties of one class to several tables that have a one-to-one "
 "relationship. For example:"
 msgstr ""
-"<literal>&lt;join&gt;</literal> 要素を使うことで、 1つのクラスのプロパティを"
-"いくつものテーブルにマッピングすることができます。"
+"テーブル間に一対一の関係があるとき、 <literal>&lt;join&gt;</literal> 要素を使"
+"うことで、1つのクラスのプロパティをいくつものテーブルにマッピングすることが"
+"できます。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2222
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<join\n"
-"        table=\"tablename\"\n"
-"        schema=\"owner\"\n"
-"        catalog=\"catalog\"\n"
-"        fetch=\"join|select\"\n"
-"        inverse=\"true|false\"\n"
-"        optional=\"true|false\">\n"
-"\n"
-"        <key ... />\n"
-"\n"
-"        <property ... />\n"
-"        ...\n"
-"</join>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2226
-#, fuzzy, no-c-format
 msgid "<literal>table</literal>: the name of the joined table."
 msgstr "<literal>table</literal> :結合したテーブルの名前"
 
 #. Tag: para
-#: basic_mapping.xml:2243
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional - defaults to <literal>join</literal>): "
 "if set to <literal>join</literal>, the default, Hibernate will use an inner "
@@ -4160,31 +2969,29 @@
 "<literal>&lt;join&gt;</literal> defined by the class and its superclasses."
 msgstr ""
 "<literal>fetch</literal> (オプション - デフォルトは <literal>join</"
-"literal> ): <literal>join</literal> を設定した場合、 Hibernateはデフォルト"
+"literal> ): <literal>join</literal> を設定した場合、 Hibernate はデフォルト"
 "で、クラスやスーパークラスで定義された <literal>&lt;join&gt;</literal> を検索"
 "するのに内部結合を使い、サブクラスで定義された <literal>&lt;join&gt;</"
 "literal> を検索するのに外部結合を使います。 <literal>select</literal> を設定"
-"した場合には、 Hibernateはサブクラスで定義された <literal>&lt;join&gt;</"
-"literal> の選択に順次選択を使います。この場合、 行がサブクラスのインスタンス"
-"を代表することがわかった場合にのみ発行されます。 内部結合はクラスやそのスー"
-"パークラスで定義された <literal>&lt;join&gt;</literal> を検索 するために使用"
-"します。"
+"した場合には、 Hibernate はサブクラスで定義された <literal>&lt;join&gt;</"
+"literal> の選択に順次選択を使います。この場合、行がサブクラスのインスタンスを"
+"代表することがわかった場合にのみ発行されます。内部結合はクラスやそのスーパー"
+"クラスで定義された <literal>&lt;join&gt;</literal> を検索するために使用しま"
+"す。"
 
 #. Tag: para
-#: basic_mapping.xml:2256
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>inverse</literal> (optional - defaults to <literal>false</"
 "literal>): if enabled, Hibernate will not insert or update the properties "
 "defined by this join."
 msgstr ""
 "<literal>inverse</literal> (オプション - デフォルトは <literal>false</"
-"literal> ): もし可能であれば、Hibernateはこの結合で定義されているプロパティに"
-"対し 挿入や更新を行いません。"
+"literal> ): もし可能であれば、 Hibernate はこの結合で定義されているプロパティ"
+"に対し挿入や更新を行いません。"
 
 #. Tag: para
-#: basic_mapping.xml:2263
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optional</literal> (optional - defaults to <literal>false</"
 "literal>): if enabled, Hibernate will insert a row only if the properties "
@@ -4192,88 +2999,51 @@
 "retrieve the properties."
 msgstr ""
 "<literal>optional</literal> (オプション - デフォルトは <literal>false</"
-"literal> ): もし可能であれば、Hibernateはこの結合で定義されたプロパティがnull"
-"でない場合にのみ 行を挿入し、そのプロパティの検索には常に外部結合を使用しま"
-"す。"
+"literal> ): もし可能であれば、 Hibernate はこの結合で定義されたプロパティが "
+"null でない場合にのみ行を挿入し、そのプロパティの検索には常に外部結合を使用し"
+"ます。"
 
 #. Tag: para
-#: basic_mapping.xml:2272
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For example, address information for a person can be mapped to a separate "
 "table while preserving value type semantics for all properties:"
 msgstr ""
 "例えば人のアドレスの情報を分離したテーブルにマッピングすることが可能です (す"
-"べてのプロパティに対して値型のセマンティクスを保持します)。"
+"べてのプロパティに対して値型のセマンティクスを保持します):"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2277
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\"\n"
-"    table=\"PERSON\">\n"
-"\n"
-"    <id name=\"id\" column=\"PERSON_ID\">...</id>\n"
-"\n"
-"    <join table=\"ADDRESS\">\n"
-"        <key column=\"ADDRESS_ID\"/>\n"
-"        <property name=\"address\"/>\n"
-"        <property name=\"zip\"/>\n"
-"        <property name=\"country\"/>\n"
-"    </join>\n"
-"    ...]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2279
-#, fuzzy, no-c-format
-msgid ""
 "This feature is often only useful for legacy data models. We recommend fewer "
 "tables than classes and a fine-grained domain model. However, it is useful "
 "for switching between inheritance mapping strategies in a single hierarchy, "
 "as explained later."
 msgstr ""
-"この特徴はしばしばレガシーデータモデルに対してのみ有用ですが、 クラスよりも少"
-"ないテーブルと、きめの細かいドメインモデルを推奨します。 しかし後で説明するよ"
+"この特徴はしばしばレガシーデータモデルに対してのみ有用ですが、クラスよりも少"
+"ないテーブルと、きめの細かいドメインモデルを推奨します。しかし後で説明するよ"
 "うに、1つのクラス階層で継承のマッピング戦略を切り替える時には有用です。"
 
 #. Tag: title
-#: basic_mapping.xml:2289
 #, no-c-format
-msgid "<title>Key</title>"
+msgid "Key"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2291
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;key&gt;</literal> element has featured a few times within "
 "this guide. It appears anywhere the parent mapping element defines a join to "
 "a new table that references the primary key of the original table. It also "
 "defines the foreign key in the joined table:"
 msgstr ""
-"今まで何度か <literal>&lt;key&gt;</literal> 要素が出てきました。 この要素は新"
-"しいテーブルへの結合を定義したり、 結合テーブルで外部キーを定義したりする親要"
-"素のどこにでも現れ、 オリジナルテーブルの主キーを参照します。"
+"今まで何度か <literal>&lt;key&gt;</literal> 要素が出てきました。この要素は新"
+"しいテーブルへの結合を定義したり、結合テーブルで外部キーを定義したりする親要"
+"素のどこにでも現れ、オリジナルテーブルの主キーを参照します。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2307
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<key\n"
-"        column=\"columnname\"\n"
-"        on-delete=\"noaction|cascade\"\n"
-"        property-ref=\"propertyName\"\n"
-"        not-null=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2318
-#, fuzzy, no-c-format
-msgid ""
 "<literal>on-delete</literal> (optional - defaults to <literal>noaction</"
 "literal>): specifies whether the foreign key constraint has database-level "
 "cascade delete enabled."
@@ -4283,8 +3053,7 @@
 "定します。"
 
 #. Tag: para
-#: basic_mapping.xml:2325
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): specifies that the foreign key "
 "refers to columns that are not the primary key of the original table. It is "
@@ -4295,20 +3064,18 @@
 "す)。"
 
 #. Tag: para
-#: basic_mapping.xml:2332
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): specifies that the foreign key "
 "columns are not nullable. This is implied whenever the foreign key is also "
 "part of the primary key."
 msgstr ""
-"<literal>not-null</literal> (オプション): 外部キーカラムがnull値を許容しない"
-"ことを指定します (このことは外部キーが主キーの一部であることを暗黙的に示しま"
-"す)。"
+"<literal>not-null</literal> (オプション): 外部キーカラムが null 値を許容しな"
+"いことを指定します (このことは外部キーが主キーの一部であることを暗黙的に示し"
+"ます)。"
 
 #. Tag: para
-#: basic_mapping.xml:2339
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update</literal> (optional): specifies that the foreign key should "
 "never be updated. This is implied whenever the foreign key is also part of "
@@ -4319,8 +3086,7 @@
 "す)。"
 
 #. Tag: para
-#: basic_mapping.xml:2346
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): specifies that the foreign key should "
 "have a unique constraint. This is implied whenever the foreign key is also "
@@ -4331,8 +3097,7 @@
 "ます)。"
 
 #. Tag: para
-#: basic_mapping.xml:2354
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For systems where delete performance is important, we recommend that all "
 "keys should be defined <literal>on-delete=\"cascade\"</literal>. Hibernate "
@@ -4341,16 +3106,15 @@
 "that this feature bypasses Hibernate's usual optimistic locking strategy for "
 "versioned data."
 msgstr ""
-"削除のパフォーマンスが重要であるシステムには、 すべてのキーを <literal>on-"
-"delete=\"cascade\"</literal> と定義することを推奨します。 そうすることで"
-"Hibernateは、<literal>DELETE</literal> 文を毎回発行する代わりに、 データベー"
-"スレベルの <literal>ON CASCADE DELETE</literal> 制約を使用します。 この特徴は"
-"バージョン付けられたデータに対するHibernateの通常の楽観的ロック戦略を 無視す"
+"削除のパフォーマンスが重要であるシステムには、すべてのキーを <literal>on-"
+"delete=\"cascade\"</literal> と定義することを推奨します。そうすることで "
+"Hibernate は、 <literal>DELETE</literal> 文を毎回発行する代わりに、データベー"
+"スレベルの <literal>ON CASCADE DELETE</literal> 制約を使用します。この特徴は"
+"バージョン付けられたデータに対する Hibernate の通常の楽観的ロック戦略を無視す"
 "るということに注意してください。"
 
 #. Tag: para
-#: basic_mapping.xml:2362
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>not-null</literal> and <literal>update</literal> attributes are "
 "useful when mapping a unidirectional one-to-many association. If you map a "
@@ -4359,19 +3123,17 @@
 "null=\"true\"&gt;</literal>."
 msgstr ""
 "<literal>not-null</literal> と <literal>update</literal> 属性は、単方向一対多"
-"関連の時には有用です。 単方向一対多関連をnullを許容しない外部キーにマッピング"
-"するときは、 <literal>&lt;key not-null=\"true\"&gt;</literal> を使ってキーカ"
-"ラムを宣言 <emphasis> しなくてはなりません</emphasis> 。"
+"関連の時には有用です。単方向一対多関連を null を許容しない外部キーにマッピン"
+"グするときは、 <literal>&lt;key not-null=\"true\"&gt;</literal> を使ってキー"
+"カラムを宣言 <emphasis> しなくてはなりません</emphasis> 。"
 
 #. Tag: title
-#: basic_mapping.xml:2372
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Column and formula elements"
 msgstr "column と formula 要素"
 
 #. Tag: para
-#: basic_mapping.xml:2373
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Mapping elements which accept a <literal>column</literal> attribute will "
 "alternatively accept a <literal>&lt;column&gt;</literal> subelement. "
@@ -4379,66 +3141,39 @@
 "<literal>formula</literal> attribute. For example:"
 msgstr ""
 "<literal>column</literal> 属性を記述できる任意のマッピング要素はまた、 "
-"<literal>&lt;column&gt;</literal> サブ要素も記述できます。 同様に "
+"<literal>&lt;column&gt;</literal> サブ要素も記述できます。同様に "
 "<literal>&lt;formula&gt;</literal> も <literal>formula</literal> 属性の代替手"
 "段です。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2379
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<column\n"
-"        name=\"column_name\"\n"
-"        length=\"N\"\n"
-"        precision=\"N\"\n"
-"        scale=\"N\"\n"
-"        not-null=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        unique-key=\"multicolumn_unique_key_name\"\n"
-"        index=\"index_name\"\n"
-"        sql-type=\"sql_type_name\"\n"
-"        check=\"SQL expression\"\n"
-"        default=\"SQL expression\"/>]]>"
+"Most of the attributes on <literal>column</literal> provide a means of "
+"tailoring the DDL during automatic schema generation. The <literal>read</"
+"literal> and <literal>write</literal> attributes allow you to specify custom "
+"SQL that Hibernate will use to access the column's value. For more on this, "
+"see the discussion of <link linkend=\"mapping-column-read-and-write\">column "
+"read and write expressions</link>."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2381
-#, no-c-format
-msgid "<![CDATA[<formula>SQL expression</formula>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2383
 #, fuzzy, no-c-format
 msgid ""
-"<literal>column</literal> and <literal>formula</literal> attributes can even "
-"be combined within the same property or association mapping to express, for "
-"example, exotic join conditions."
+"The <literal>column</literal> and <literal>formula</literal> elements can "
+"even be combined within the same property or association mapping to express, "
+"for example, exotic join conditions."
 msgstr ""
 "同じプロパティや関連のマッピングの中で、 <literal>column</literal> と "
-"<literal>formula</literal> 属性を組み合わせることができます。 例えば、特殊な"
-"結合条件などです。"
+"<literal>formula</literal> 属性を組み合わせることができます。例えば、特殊な結"
+"合条件などです。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2389
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"homeAddress\" class=\"Address\"\n"
-"        insert=\"false\" update=\"false\">\n"
-"    <column name=\"person_id\" not-null=\"true\" length=\"10\"/>\n"
-"    <formula>'MAILING'</formula>\n"
-"</many-to-one>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:2394
 #, fuzzy, no-c-format
 msgid "Import"
 msgstr "import"
 
 #. Tag: para
-#: basic_mapping.xml:2396
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your application has two persistent classes with the same name, and you "
 "do not want to specify the fully qualified package name in Hibernate "
@@ -4446,54 +3181,34 @@
 "<literal>auto-import=\"true\"</literal>. You can also import classes and "
 "interfaces that are not explicitly mapped:"
 msgstr ""
-"アプリケーションに同じ名前の2つの永続クラスがあり、 Hibernateクエリで完全修飾"
-"された(パッケージの)名前を指定したくないと仮定します。 そのような場合は "
-"<literal>auto-import=\"true\"</literal> に頼らず、 クラスが「インポート」され"
-"たものであると明示できます。 明示的にマッピングされていないクラスやインター"
-"フェイスでさえもインポートできます。"
+"アプリケーションに同じ名前の2つの永続クラスがあり、 Hibernate クエリで完全修"
+"飾された(パッケージの)名前を指定したくないと仮定します。そのような場合は "
+"<literal>auto-import=\"true\"</literal> に頼らず、クラスが「インポート」され"
+"たものであると明示できます。明示的にマッピングされていないクラスやインター"
+"フェースでさえもインポートできます。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2403
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[<import class=\"java.lang.Object\" rename=\"Universe\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2410
-#, no-c-format
 msgid ""
-"<![CDATA[<import\n"
-"        class=\"ClassName\"\n"
-"        rename=\"ShortName\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2413
-#, fuzzy, no-c-format
-msgid ""
 "<literal>class</literal>: the fully qualified class name of any Java class."
-msgstr "<literal>class</literal>:Javaクラスの完全修飾されたクラス名。"
+msgstr "<literal>class</literal>: Java クラスの完全修飾されたクラス名。"
 
 #. Tag: para
-#: basic_mapping.xml:2418
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>rename</literal> (optional - defaults to the unqualified class "
 "name): a name that can be used in the query language."
 msgstr ""
-"<literal>rename</literal>(オプション - デフォルトは修飾されていないクラス"
+"<literal>rename</literal> (オプション - デフォルトは修飾されていないクラス"
 "名): クエリ言語で使われる名前。"
 
 #. Tag: title
-#: basic_mapping.xml:2429
 #, no-c-format
-msgid "<title>Any</title>"
+msgid "Any"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2431
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is one more type of property mapping. The <literal>&lt;any&gt;</"
 "literal> mapping element defines a polymorphic association to classes from "
@@ -4505,17 +3220,16 @@
 "cases. For example, for audit logs, user session data, etc."
 msgstr ""
 "プロパティマッピングにはさらにもう1つの型があります。 <literal>&lt;any&gt;</"
-"literal> マッピング要素は、 複数のテーブルからクラスへのポリモーフィックな関"
-"連を定義します。 この型のマッピングには必ず複数のカラムが必要です。1番目のカ"
-"ラムは関連エンティティの型を保持します。 残りのカラムは識別子を保持します。こ"
-"の種類の関連には外部キー制約を指定することはできません。 そのためこれは最も使"
-"われることのない(ポリモーフィックな)関連のマッピング方法です。 非常に特別な"
-"場合(例えば、検査ログやユーザセッションデータなど)に限って、これを使うべきで"
+"literal> マッピング要素は、複数のテーブルからクラスへのポリモーフィックな関連"
+"を定義します。この型のマッピングには必ず複数のカラムが必要です。1番目のカラム"
+"は関連エンティティの型を保持します。残りのカラムは識別子を保持します。この種"
+"類の関連には外部キー制約を指定することはできません。そのためこれは最も使われ"
+"ることのない(ポリモーフィックな)関連のマッピング方法です。非常に特別な場合"
+"(例えば、検査ログやユーザーセッションデータなど)に限って、これを使うべきで"
 "す。"
 
 #. Tag: para
-#: basic_mapping.xml:2441
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>meta-type</literal> attribute allows the application to specify "
 "a custom type that maps database column values to persistent classes that "
@@ -4523,69 +3237,31 @@
 "literal>. You must specify the mapping from values of the meta-type to class "
 "names."
 msgstr ""
-"<literal>meta-type</literal> により、 アプリケーションはカスタム型を指定でき"
-"ます。このカスタム型は データベースカラムの値を、<literal>id-type</literal> "
-"で指定した型の 識別子プロパティを持った永続クラスへマッピングします。 meta-"
-"typeの値からクラス名へのマッピングを指定しなければなりません。"
+"<literal>meta-type</literal> により、アプリケーションはカスタム型を指定できま"
+"す。このカスタム型はデータベースカラムの値を、 <literal>id-type</literal> で"
+"指定した型の識別子プロパティを持った永続クラスへマッピングします。 meta-type "
+"の値からクラス名へのマッピングを指定しなければなりません。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2448
-#, no-c-format
-msgid ""
-"<![CDATA[<any name=\"being\" id-type=\"long\" meta-type=\"string\">\n"
-"    <meta-value value=\"TBL_ANIMAL\" class=\"Animal\"/>\n"
-"    <meta-value value=\"TBL_HUMAN\" class=\"Human\"/>\n"
-"    <meta-value value=\"TBL_ALIEN\" class=\"Alien\"/>\n"
-"    <column name=\"table_name\"/>\n"
-"    <column name=\"id\"/>\n"
-"</any>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2459
-#, no-c-format
-msgid ""
-"<![CDATA[<any\n"
-"        name=\"propertyName\"\n"
-"        id-type=\"idtypename\"\n"
-"        meta-type=\"metatypename\"\n"
-"        cascade=\"cascade_style\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        optimistic-lock=\"true|false\"\n"
-">\n"
-"        <meta-value ... />\n"
-"        <meta-value ... />\n"
-"        .....\n"
-"        <column .... />\n"
-"        <column .... />\n"
-"        .....\n"
-"</any>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2462
 #, no-c-format
 msgid "<literal>name</literal>: the property name."
-msgstr "<literal>name</literal>:プロパティ名。"
+msgstr "<literal>name</literal>: プロパティ名。"
 
 #. Tag: para
-#: basic_mapping.xml:2467
 #, no-c-format
 msgid "<literal>id-type</literal>: the identifier type."
-msgstr "<literal>id-type</literal>:識別子の型。"
+msgstr "<literal>id-type</literal>: 識別子の型。"
 
 #. Tag: para
-#: basic_mapping.xml:2472
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>meta-type</literal> (optional - defaults to <literal>string</"
 "literal>): any type that is allowed for a discriminator mapping."
 msgstr ""
 "<literal>meta-type</literal>(オプション - デフォルトは <literal>string</"
-"literal> ): ディスクリミネータマッピングで許された型"
+"literal> ): ディスクリミネータマッピングで許された型。"
 
 #. Tag: para
-#: basic_mapping.xml:2478
 #, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional- defaults to <literal>none</literal>): "
@@ -4595,8 +3271,7 @@
 "literal> ): カスケードのスタイル。"
 
 #. Tag: para
-#: basic_mapping.xml:2490
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to this property either do or do not "
@@ -4605,23 +3280,20 @@
 msgstr ""
 "<literal>optimistic-lock</literal> (オプション - デフォルトは <literal>true</"
 "literal> ): このプロパティの更新に楽観ロックの取得を要求するかどうかを指定し"
-"ます。 言い換えれば、このプロパティがダーティであるときにバージョンを増やすべ"
+"ます。言い換えれば、このプロパティがダーティであるときにバージョンを増やすべ"
 "きかを定義します。"
 
 #. Tag: title
-#: basic_mapping.xml:2505
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Hibernate types"
-msgstr "Hibernateの型"
+msgstr "Hibernate の型"
 
 #. Tag: title
-#: basic_mapping.xml:2508
 #, no-c-format
 msgid "Entities and values"
 msgstr "エンティティと値"
 
 #. Tag: para
-#: basic_mapping.xml:2510
 #, no-c-format
 msgid ""
 "In relation to the persistence service, Java language-level objects are "
@@ -4629,8 +3301,7 @@
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2515
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An <emphasis>entity</emphasis> exists independently of any other objects "
 "holding references to the entity. Contrast this with the usual Java model, "
@@ -4642,19 +3313,18 @@
 "large systems. Entities support circular and shared references. They can "
 "also be versioned."
 msgstr ""
-"<emphasis> エンティティ</emphasis> はエンティティへの参照を保持する、 他のす"
-"べてのオブジェクトから独立して存在します。 参照されないオブジェクトがガベージ"
-"コレクトされてしまう性質を持つ通常のJavaモデルと、 これを比べてみてくださ"
-"い。 (親エンティティから子へ、セーブと削除が <emphasis>カスケード</"
-"emphasis> されうることを除いて) エンティティは明示的にセーブまたは削除されな"
-"ければなりません。 これは到達可能性によるオブジェクト永続化のODMGモデルとは異"
-"なっています。 大規模なシステムでアプリケーションオブジェクトが普通どのように"
-"使われるかにより密接に対応します。 エンティティは循環と参照の共有をサポートし"
-"ます。 またそれらはバージョン付けすることもできます。"
+"<emphasis>エンティティ</emphasis> はエンティティへの参照を保持する、他のすべ"
+"てのオブジェクトから独立して存在します。参照されないオブジェクトがガベージコ"
+"レクトされてしまう性質を持つ通常の Java モデルと、これを比べてみてください。"
+"(親エンティティから子へ、セーブと削除が <emphasis>カスケード</emphasis> され"
+"うることを除いて)エンティティは明示的にセーブまたは削除されなければなりませ"
+"ん。これは到達可能性によるオブジェクト永続化の ODMG モデルとは異なっていま"
+"す。大規模なシステムでアプリケーションオブジェクトが普通どのように使われるか"
+"により密接に対応します。エンティティは循環と参照の共有をサポートします。また"
+"それらはバージョン付けすることもできます。"
 
 #. Tag: para
-#: basic_mapping.xml:2526
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An entity's persistent state consists of references to other entities and "
 "instances of <emphasis>value</emphasis> types. Values are primitives: "
@@ -4666,18 +3336,17 @@
 "no independent identity, so they cannot be shared by two entities or "
 "collections."
 msgstr ""
-"エンティティの永続状態は他のエンティティや <emphasis>値</emphasis> 型の イン"
-"スタンスへの参照から構成されます。 値はプリミティブ、コレクション(コレクショ"
-"ンの内部ではなく)、 コンポーネント、不変オブジェクトです。 エンティティとは違"
-"い、値は(特にコレクションとコンポーネントにおいて)、 到達可能性による永続化"
-"や削除が <emphasis>行われます</emphasis> 。 値オブジェクト(とプリミティブ)"
-"は、包含するエンティティと一緒に永続化や削除が行われるので、 それらを独立に"
-"バージョン付けすることはできません。 値には独立したアイデンティティがないの"
-"で、 複数のエンティティやコレクションがこれを共有することはできません。"
+"エンティティの永続状態は他のエンティティや <emphasis>値</emphasis> 型のインス"
+"タンスへの参照から構成されます。値はプリミティブ、コレクション (コレクション"
+"の内部ではなく)、コンポーネント、不変オブジェクトです。エンティティとは違い、"
+"値は(特にコレクションとコンポーネントにおいて)、到達可能性による永続化や削"
+"除が <emphasis>行われます</emphasis> 。値オブジェクト(とプリミティブ)は、包"
+"含するエンティティと一緒に永続化や削除が行われるので、それらを独立にバージョ"
+"ン付けすることはできません。値には独立したアイデンティティがないので、複数の"
+"エンティティやコレクションがこれを共有することはできません。"
 
 #. Tag: para
-#: basic_mapping.xml:2537
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Until now, we have been using the term \"persistent class\" to refer to "
 "entities. We will continue to do that. Not all user-defined classes with a "
@@ -4691,26 +3360,24 @@
 "single instance of that class, while composition or aggregation usually "
 "translates to a value type."
 msgstr ""
-"これまで「永続クラス」という言葉をエンティティの意味で使ってきました。 これか"
-"らもそうしていきます。 厳密に言うと、永続状態を持つユーザ定義のクラスのすべて"
-"が エンティティというわけではありません。 <emphasis>コンポーネント</"
-"emphasis> は値のセマンティクスを持つユーザ定義クラスです。 <literal>java."
-"lang.String</literal> 型のプロパティもまた値のセマンティクスを持ちます。 定義"
-"するなら、JDKで提供されているすべてのJavaの型(クラス)が値のセマンティクスを持"
-"つといえます。 一方ユーザ定義型は、エンティティや値型のセマンティクスとともに"
-"マッピングできます。 この決定はアプリケーション開発者次第です。 そのクラスの"
-"1つのインスタンスへの共有参照は、 ドメインモデル内のエンティティクラスに対す"
-"る良いヒントになります。 一方合成集約や集約は、通常値型へ変換されます。"
+"これまで「永続クラス」という言葉をエンティティの意味で使ってきました。これか"
+"らもそうしていきます。厳密に言うと、永続状態を持つユーザー定義のクラスのすべ"
+"てがエンティティというわけではありません。 <emphasis>コンポーネント</"
+"emphasis> は値のセマンティクスを持つユーザー定義クラスです。 <literal>java."
+"lang.String</literal> 型のプロパティもまた値のセマンティクスを持ちます。定義"
+"するなら、 JDK で提供されているすべての Java の型 (クラス) が値のセマンティク"
+"スを持つといえます。一方ユーザー定義型は、エンティティや値型のセマンティクス"
+"とともにマッピングできます。この決定はアプリケーション開発者次第です。そのク"
+"ラスの1つのインスタンスへの共有参照は、ドメインモデル内のエンティティクラス"
+"に対する良いヒントになります。一方合成集約や集約は、通常値型へ変換されます。"
 
 #. Tag: para
-#: basic_mapping.xml:2551
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "We will revisit both concepts throughout this reference guide."
 msgstr "本ドキュメントを通して、何度もこの概念を取り上げます。"
 
 #. Tag: para
-#: basic_mapping.xml:2555
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The challenge is to map the Java type system, and the developers' definition "
 "of entities and value types, to the SQL/database type system. The bridge "
@@ -4723,54 +3390,49 @@
 "for standard JDK value types out of the box. You can write your own mapping "
 "types and implement your own custom conversion strategies."
 msgstr ""
-"Java型のシステム(もしくは開発者が定義したエンティティと値型)を SQL/データベー"
-"ス型のシステムにマッピングすることは難しいです。 Hibernateは2つのシステムの"
-"架け橋を提供します。 エンティティに対しては <literal>&lt;class&gt;</literal> "
-"や <literal>&lt;subclass&gt;</literal> などを使用します。 値型に対しては "
-"<literal>&lt;property&gt;</literal> ã‚„ <literal>&lt;component&gt;</literal> "
-"などを、通常 <literal>type</literal> とともに使います。 この属性の値は"
-"Hibernateの <emphasis>マッピング型</emphasis> の名前です。 Hibernateは(標準"
-"JDKの値型に対して)多くの自由なマッピングを提供します。 後で見るように、自身の"
-"マッピング型を記述し、同様にカスタムの変換戦略を実装することができます。"
+"Java 型のシステム (もしくは開発者が定義したエンティティと値型) を SQL /データ"
+"ベース型のシステムにマッピングすることは難しいです。 Hibernate は2つのシステ"
+"ムの架け橋を提供します。エンティティに対しては <literal>&lt;class&gt;</"
+"literal> や <literal>&lt;subclass&gt;</literal> などを使用します。値型に対し"
+"ては <literal>&lt;property&gt;</literal> や <literal>&lt;component&gt;</"
+"literal> などを、通常 <literal>type</literal> と共に使います。この属性の値は "
+"Hibernate の <emphasis>マッピング型</emphasis> の名前です。 Hibernate は (標"
+"準 JDK の値型に対して) 多くの自由なマッピングを提供します。後で見るように、自"
+"身のマッピング型を記述し、同様にカスタムの変換戦略を実装することができます。"
 
 #. Tag: para
-#: basic_mapping.xml:2568
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "With the exception of collections, all built-in Hibernate types support null "
 "semantics."
 msgstr ""
-"コレクションを除く組み込みのHibernateの型はすべて、nullセマンティクスをサポー"
-"トします。"
+"コレクションを除く組み込みの Hibernate の型はすべて、 null セマンティクスをサ"
+"ポートします。"
 
 #. Tag: title
-#: basic_mapping.xml:2575
 #, no-c-format
 msgid "Basic value types"
 msgstr "基本的な型"
 
 #. Tag: para
-#: basic_mapping.xml:2577
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The built-in <emphasis>basic mapping types</emphasis> can be roughly "
 "categorized into the following:"
 msgstr ""
 "組み込みの <emphasis>基本的なマッピング型</emphasis> は大まかに以下のように分"
-"けられます。 <placeholder-1/>"
+"けられます。"
 
-#. Tag: literal
-#: basic_mapping.xml:2582
+#. Tag: term
 #, no-c-format
 msgid ""
-"integer, long, short, float, double, character, byte, boolean, yes_no, "
-"true_false"
+"<literal>integer, long, short, float, double, character, byte, boolean, "
+"yes_no, true_false</literal>"
 msgstr ""
-"integer, long, short, float, double, character, byte, boolean, yes_no, "
-"true_false"
+"<literal>integer, long, short, float, double, character, byte, boolean, "
+"yes_no, true_false</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2585
 #, no-c-format
 msgid ""
 "Type mappings from Java primitives or wrapper classes to appropriate (vendor-"
@@ -4778,70 +3440,62 @@
 "<literal>true_false</literal> are all alternative encodings for a Java "
 "<literal>boolean</literal> or <literal>java.lang.Boolean</literal>."
 msgstr ""
-"Javaのプリミティブやラッパークラスから適切な(ベンダー固有の) SQLカラム型へ"
-"の型マッピング。 <literal>boolean, yes_no</literal> と <literal>true_false</"
-"literal> は、 すべてJavaの <literal>boolean</literal> または <literal>java."
-"lang.Boolean</literal> の代替エンコードです。"
+"Java のプリミティブやラッパークラスから適切な(ベンダー固有の) SQL カラム型"
+"への型マッピング。 <literal>boolean, yes_no</literal> と "
+"<literal>true_false</literal> は、すべて Java の <literal>boolean</literal> "
+"または <literal>java.lang.Boolean</literal> の代替エンコードです。"
 
-#. Tag: literal
-#: basic_mapping.xml:2594
-#, no-c-format
-msgid "string"
-msgstr "string"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>string</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2596
 #, no-c-format
 msgid ""
 "A type mapping from <literal>java.lang.String</literal> to <literal>VARCHAR</"
 "literal> (or Oracle <literal>VARCHAR2</literal>)."
 msgstr ""
-"<literal>java.lang.String</literal> から <literal>VARCHAR</literal> (または"
-"Oracleの <literal>VARCHAR2</literal> )への型マッピング。"
+"<literal>java.lang.String</literal> から <literal>VARCHAR</literal> (または "
+"Oracle の <literal>VARCHAR2</literal> )への型マッピング。"
 
-#. Tag: literal
-#: basic_mapping.xml:2603
+#. Tag: term
 #, no-c-format
-msgid "date, time, timestamp"
-msgstr "date, time, timestamp"
+msgid "<literal>date, time, timestamp</literal>"
+msgstr "<literal>date, time, timestamp</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2605
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Date</literal> and its subclasses to "
 "SQL types <literal>DATE</literal>, <literal>TIME</literal> and "
 "<literal>TIMESTAMP</literal> (or equivalent)."
 msgstr ""
-"<literal>java.util.Date</literal> とそのサブクラスからSQL型の <literal>DATE</"
-"literal>, <literal>TIME</literal> , <literal>TIMESTAMP</literal> (またはそれ"
-"らと等価なもの) への型マッピング。"
+"<literal>java.util.Date</literal> とそのサブクラスから SQL 型の "
+"<literal>DATE</literal> 、 <literal>TIME</literal> 、 <literal>TIMESTAMP</"
+"literal> (またはそれらと等価なもの) への型マッピング。"
 
-#. Tag: literal
-#: basic_mapping.xml:2613
+#. Tag: term
 #, no-c-format
-msgid "calendar, calendar_date"
-msgstr "calendar, calendar_date"
+msgid "<literal>calendar, calendar_date</literal>"
+msgstr "<literal>calendar, calendar_date</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2615
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Calendar</literal> to SQL types "
 "<literal>TIMESTAMP</literal> and <literal>DATE</literal> (or equivalent)."
 msgstr ""
-"<literal>java.util.Calendar</literal> からSQL型 の「 <literal>TIMESTAMP</"
-"literal> , <literal>DATE</literal> (またはそれらと等価なもの)への型マッピン"
+"<literal>java.util.Calendar</literal> から SQL 型 の「 <literal>TIMESTAMP</"
+"literal> 、 <literal>DATE</literal> (またはそれらと等価なもの)への型マッピン"
 "グ。"
 
-#. Tag: literal
-#: basic_mapping.xml:2623
+#. Tag: term
 #, no-c-format
-msgid "big_decimal, big_integer"
-msgstr "big_decimal, big_integer"
+msgid "<literal>big_decimal, big_integer</literal>"
+msgstr "<literal>big_decimal, big_integer</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2625
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.math.BigDecimal</literal> and <literal>java."
@@ -4849,17 +3503,15 @@
 "<literal>NUMBER</literal>)."
 msgstr ""
 "<literal>java.math.BigDecimal</literal> と <literal>java.math.BigInteger</"
-"literal> から <literal>NUMERIC</literal>(またはOracleの <literal>NUMBER</"
+"literal> から <literal>NUMERIC</literal>(または Oracle の <literal>NUMBER</"
 "literal> )への型マッピング。"
 
-#. Tag: literal
-#: basic_mapping.xml:2633
+#. Tag: term
 #, no-c-format
-msgid "locale, timezone, currency"
-msgstr "locale, timezone, currency"
+msgid "<literal>locale, timezone, currency</literal>"
+msgstr "<literal>locale, timezone, currency</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2635
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Locale</literal>, <literal>java.util."
@@ -4869,111 +3521,99 @@
 "mapped to their ISO codes. Instances of <literal>TimeZone</literal> are "
 "mapped to their <literal>ID</literal>."
 msgstr ""
-"<literal>java.util.Locale</literal> , <literal>java.util.TimeZone</"
-"literal> , <literal>java.util.Currency</literal> から <literal>VARCHAR</"
-"literal> (またはOracleの <literal>VARCHAR2</literal> )への型マッピング。 "
-"<literal>Locale</literal> と <literal>Currency</literal> のインスタンスは、 "
-"それらのISOコードにマッピングされます。 <literal>TimeZone</literal> のインス"
-"タンスは、 それらの <literal>ID</literal> にマッピングされます。"
+"<literal>java.util.Locale</literal> 、 <literal>java.util.TimeZone</"
+"literal> 、 <literal>java.util.Currency</literal> から <literal>VARCHAR</"
+"literal> (または Oracle の <literal>VARCHAR2</literal> )への型マッピング。 "
+"<literal>Locale</literal> と <literal>Currency</literal> のインスタンスは、そ"
+"れらの ISO コードにマッピングされます。 <literal>TimeZone</literal> のインス"
+"タンスは、それらの <literal>ID</literal> にマッピングされます。"
 
-#. Tag: literal
-#: basic_mapping.xml:2647
-#, no-c-format
-msgid "class"
-msgstr "class"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>class</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2649
 #, no-c-format
 msgid ""
 "A type mapping from <literal>java.lang.Class</literal> to <literal>VARCHAR</"
 "literal> (or Oracle <literal>VARCHAR2</literal>). A <literal>Class</literal> "
 "is mapped to its fully qualified name."
 msgstr ""
-"<literal>java.lang.Class</literal> から <literal>VARCHAR</literal> (または"
-"Oracleの <literal>VARCHAR2</literal> )への型マッピング。 <literal>Class</"
+"<literal>java.lang.Class</literal> から <literal>VARCHAR</literal> (または "
+"Oracle の <literal>VARCHAR2</literal> )への型マッピング。 <literal>Class</"
 "literal> はその完全修飾された名前にマッピングされます。"
 
-#. Tag: literal
-#: basic_mapping.xml:2657
-#, no-c-format
-msgid "binary"
-msgstr "binary"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>binary</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2659
 #, no-c-format
 msgid "Maps byte arrays to an appropriate SQL binary type."
-msgstr "バイト配列は、適切なSQLのバイナリ型にマッピングされます。"
+msgstr "バイト配列は、適切な SQL のバイナリ型にマッピングされます。"
 
-#. Tag: literal
-#: basic_mapping.xml:2665
-#, no-c-format
-msgid "text"
-msgstr "text"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>text</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2667
 #, no-c-format
 msgid ""
 "Maps long Java strings to a SQL <literal>CLOB</literal> or <literal>TEXT</"
 "literal> type."
 msgstr ""
-"長いJava文字列は、SQLの <literal>CLOB</literal> または <literal>TEXT</"
+"長い Java 文字列は、 SQL の <literal>CLOB</literal> または <literal>TEXT</"
 "literal> 型にマッピングされます。"
 
-#. Tag: literal
-#: basic_mapping.xml:2674
-#, no-c-format
-msgid "serializable"
-msgstr "serializable"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>serializable</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2676
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Maps serializable Java types to an appropriate SQL binary type. You can also "
 "indicate the Hibernate type <literal>serializable</literal> with the name of "
 "a serializable Java class or interface that does not default to a basic type."
 msgstr ""
-"シリアライズ可能なJava型は、適切なSQLのバイナリ型にマッピングされます。 デ"
-"フォルトで基本型ではないシリアライズ可能なJavaクラスや インターフェイスの名前"
-"を指定することで、 Hibernateの型を <literal>serializable</literal> とすること"
-"もできます。"
+"シリアライズ可能な Java 型は、適切な SQL のバイナリ型にマッピングされます。デ"
+"フォルトで基本型ではないシリアライズ可能な Java クラスやインターフェースの名"
+"前を指定することで、 Hibernate の型を <literal>serializable</literal> とする"
+"こともできます。"
 
-#. Tag: literal
-#: basic_mapping.xml:2685
-#, no-c-format
-msgid "clob, blob"
-msgstr "clob, blob"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>clob, blob</literal>"
+msgstr "<literal>calendar, calendar_date</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2687
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Type mappings for the JDBC classes <literal>java.sql.Clob</literal> and "
 "<literal>java.sql.Blob</literal>. These types can be inconvenient for some "
 "applications, since the blob or clob object cannot be reused outside of a "
 "transaction. Driver support is patchy and inconsistent."
 msgstr ""
-"JDBCクラス <literal>java.sql.Clob</literal> と <literal>java.sql.Blob</"
-"literal> に対する型マッピング。 blobやclobオブジェクトはトランザクションの外"
-"では再利用できないため、 アプリケーションによっては不便かもしれません。 (さ"
+"JDBC クラス <literal>java.sql.Clob</literal> と <literal>java.sql.Blob</"
+"literal> に対する型マッピング。 blob や clob オブジェクトはトランザクションの"
+"外では再利用できないため、アプリケーションによっては不便かもしれません。(さ"
 "らにはドライバサポートが一貫していません。)"
 
-#. Tag: literal
-#: basic_mapping.xml:2697
+#. Tag: term
 #, no-c-format
 msgid ""
-"imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
-"imm_serializable, imm_binary"
+"<literal>imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
+"imm_serializable, imm_binary</literal>"
 msgstr ""
-"imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
-"imm_serializable, imm_binary"
+"<literal>imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
+"imm_serializable, imm_binary</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2701
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Type mappings for what are considered mutable Java types. This is where "
 "Hibernate makes certain optimizations appropriate only for immutable Java "
@@ -4983,28 +3623,27 @@
 "have that change made persistent, the application must assign a new, "
 "nonidentical, object to the property."
 msgstr ""
-"ほとんどの場合に可変であるJavaの型に対する型マッピング。 Hibernateは不変な"
-"Javaの型に対しては最適化を行い、 アプリケーションはそれを不変オブジェクトとし"
-"て扱います。 例えば <literal>imm_timestamp</literal> としてマップしたインスタ"
-"ンスに対して、 <literal>Date.setTime()</literal> を呼び出してはなりません。 "
-"プロパティの値を変更しその変更を永続化するためには、 アプリケーションはプロパ"
-"ティに対して新しい(同一でない)オブジェクトを割り当てなければなりません。"
+"ほとんどの場合に可変である Java の型に対する型マッピング。 Hibernate は不変"
+"な Java の型に対しては最適化を行い、アプリケーションはそれを不変オブジェクト"
+"として扱います。例えば <literal>imm_timestamp</literal> としてマップしたイン"
+"スタンスに対して、 <literal>Date.setTime()</literal> を呼び出してはなりませ"
+"ん。プロパティの値を変更しその変更を永続化するためには、アプリケーションはプ"
+"ロパティに対して新しい (同一でない) オブジェクトを割り当てなければなりませ"
+"ん。"
 
 #. Tag: para
-#: basic_mapping.xml:2716
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Unique identifiers of entities and collections can be of any basic type "
 "except <literal>binary</literal>, <literal>blob</literal> and <literal>clob</"
 "literal>. Composite identifiers are also allowed. See below for more "
 "information."
 msgstr ""
-"エンティティとコレクションのユニークな識別子は、<literal>binary</literal> , "
-"<literal>blob</literal> , <literal>clob</literal> を除く、どんな基本型でも構"
-"いません。 (複合識別子でも構いません。以下を見てください。)"
+"エンティティとコレクションのユニークな識別子は、 <literal>binary</"
+"literal> 、 <literal>blob</literal> 、 <literal>clob</literal> を除く、どんな"
+"基本型でも構いません。(複合識別子でも構いません。以下を見てください。)"
 
 #. Tag: para
-#: basic_mapping.xml:2722
 #, no-c-format
 msgid ""
 "The basic value types have corresponding <literal>Type</literal> constants "
@@ -5012,19 +3651,17 @@
 "<literal>Hibernate.STRING</literal> represents the <literal>string</literal> "
 "type."
 msgstr ""
-"基本的な値型には、<literal>org.hibernate.Hibernate</literal> で定義された "
-"<literal>Type</literal> 定数がそれぞれあります。 例えば、<literal>Hibernate."
+"基本的な値型には、 <literal>org.hibernate.Hibernate</literal> で定義された "
+"<literal>Type</literal> 定数がそれぞれあります。例えば、 <literal>Hibernate."
 "STRING</literal> は <literal>string</literal> 型を表現しています。"
 
 #. Tag: title
-#: basic_mapping.xml:2731
 #, no-c-format
 msgid "Custom value types"
 msgstr "カスタム型"
 
 #. Tag: para
-#: basic_mapping.xml:2733
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is relatively easy for developers to create their own value types. For "
 "example, you might want to persist properties of type <literal>java.lang."
@@ -5036,19 +3673,18 @@
 "that is persisted to the columns <literal>FIRST_NAME</literal>, "
 "<literal>INITIAL</literal>, <literal>SURNAME</literal>."
 msgstr ""
-"開発者が独自の値型を作成することは、比較的簡単です。 例えば、<literal>java."
+"開発者が独自の値型を作成することは、比較的簡単です。例えば、 <literal>java."
 "lang.BigInteger</literal> 型のプロパティを <literal>VARCHAR</literal> カラム"
-"に永続化したいかもしれません。 Hibernateはこのための組み込み型を用意していま"
-"せん。 しかしカスタム型は、プロパティ(またはコレクションの要素)を1つのテー"
-"ブルカラムに マッピングするのに制限はありません。 そのため例えば、"
-"<literal>java.lang.String</literal> 型の <literal>getName()</literal> / "
-"<literal>setName()</literal> Javaプロパティを <literal>FIRST_NAME</"
-"literal> , <literal>INITIAL</literal>, <literal>SURNAME</literal> カラムに永"
-"続化できます。"
+"に永続化したいかもしれません。 Hibernate はこのための組み込み型を用意していま"
+"せん。しかしカスタム型は、プロパティ(またはコレクションの要素)を1つのテーブ"
+"ルカラムにマッピングするのに制限はありません。そのため例えば、 <literal>java."
+"lang.String</literal> 型の <literal>getName()</literal> / <literal>setName()"
+"</literal> Java プロパティを <literal>FIRST_NAME</literal> 、 "
+"<literal>INITIAL</literal> 、 <literal>SURNAME</literal> カラムに永続化できま"
+"す。"
 
 #. Tag: para
-#: basic_mapping.xml:2744
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To implement a custom type, implement either <literal>org.hibernate."
 "UserType</literal> or <literal>org.hibernate.CompositeUserType</literal> and "
@@ -5056,35 +3692,22 @@
 "<literal>org.hibernate.test.DoubleStringType</literal> to see the kind of "
 "things that are possible."
 msgstr ""
-"カスタム型を実装するには、<literal>org.hibernate.UserType</literal> または "
-"<literal>org.hibernate.CompositeUserType</literal> を実装し、 型の完全修飾さ"
-"れた名前を使ってプロパティを定義します。 どのような種類のものが可能かを調べる"
-"には、 <literal>org.hibernate.test.DoubleStringType</literal> を確認してくだ"
-"さい。"
+"カスタム型を実装するには、 <literal>org.hibernate.UserType</literal> または "
+"<literal>org.hibernate.CompositeUserType</literal> を実装し、型の完全修飾され"
+"た名前を使ってプロパティを定義します。どのような種類のものが可能かを調べるに"
+"は、 <literal>org.hibernate.test.DoubleStringType</literal> を確認してくださ"
+"い。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2752
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"twoStrings\" type=\"org.hibernate.test."
-"DoubleStringType\">\n"
-"    <column name=\"first_string\"/>\n"
-"    <column name=\"second_string\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2754
 #, no-c-format
 msgid ""
 "Notice the use of <literal>&lt;column&gt;</literal> tags to map a property "
 "to multiple columns."
 msgstr ""
-"<literal>&lt;column&gt;</literal> タグで、 プロパティを複数のカラムへマッピン"
+"<literal>&lt;column&gt;</literal> タグで、プロパティを複数のカラムへマッピン"
 "グできることに注目してください。"
 
 #. Tag: para
-#: basic_mapping.xml:2759
 #, no-c-format
 msgid ""
 "The <literal>CompositeUserType</literal>, <literal>EnhancedUserType</"
@@ -5092,13 +3715,13 @@
 "<literal>UserVersionType</literal> interfaces provide support for more "
 "specialized uses."
 msgstr ""
-"<literal>CompositeUserType</literal> , <literal>EnhancedUserType</literal> , "
-"<literal>UserCollectionType</literal> , <literal>UserVersionType</literal> イ"
-"ンターフェイスは、より特殊な使用法に対してのサポートを提供します。"
+"<literal>CompositeUserType</literal> 、 <literal>EnhancedUserType</"
+"literal> 、 <literal>UserCollectionType</literal> 、 "
+"<literal>UserVersionType</literal> インターフェースは、より特殊な使用法に対し"
+"てのサポートを提供します。"
 
 #. Tag: para
-#: basic_mapping.xml:2765
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can even supply parameters to a <literal>UserType</literal> in the "
 "mapping file. To do this, your <literal>UserType</literal> must implement "
@@ -5107,37 +3730,24 @@
 "type&gt;</literal> element in your mapping files."
 msgstr ""
 "マッピングファイル内で <literal>UserType</literal> へパラメータを提供できま"
-"す。 このためには、<literal>UserType</literal> は <literal>org.hibernate."
-"usertype.ParameterizedType</literal> を実装しなくてはなりません。 カスタム型"
-"パラメータを提供するために、 マッピングファイル内で <literal>&lt;type&gt;</"
+"す。このためには、 <literal>UserType</literal> は <literal>org.hibernate."
+"usertype.ParameterizedType</literal> を実装しなくてはなりません。カスタム型パ"
+"ラメータを提供するために、マッピングファイル内で <literal>&lt;type&gt;</"
 "literal> 要素を使用できます。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2773
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"priority\">\n"
-"    <type name=\"com.mycompany.usertypes.DefaultValueIntegerType\">\n"
-"        <param name=\"default\">0</param>\n"
-"    </type>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2775
 #, no-c-format
 msgid ""
 "The <literal>UserType</literal> can now retrieve the value for the parameter "
 "named <literal>default</literal> from the <literal>Properties</literal> "
 "object passed to it."
 msgstr ""
-"<literal>UserType</literal> は、 引数として渡された <literal>Properties</"
+"<literal>UserType</literal> は、引数として渡された <literal>Properties</"
 "literal> オブジェクトから、 <literal>default</literal> で指定したパラメータに"
 "対する値を検索することができます。"
 
 #. Tag: para
-#: basic_mapping.xml:2780
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you regularly use a certain <literal>UserType</literal>, it is useful to "
 "define a shorter name for it. You can do this using the <literal>&lt;"
@@ -5147,37 +3757,19 @@
 msgstr ""
 "特定の <literal>UserType</literal> を頻繁に使用するならば、短い名前を定義する"
 "と便利になるでしょう。 <literal>&lt;typedef&gt;</literal> 要素を使ってこのよ"
-"うなことが行えます。 Typedefsはカスタム型に名前を割り当てます。 その型がパラ"
-"メータを持つならば、 パラメータのデフォルト値のリストを含むこともできます。"
+"うなことが行えます。 Typedefs はカスタム型に名前を割り当てます。その型がパラ"
+"メータを持つならば、パラメータのデフォルト値のリストを含むこともできます。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2787
-#, no-c-format
-msgid ""
-"<![CDATA[<typedef class=\"com.mycompany.usertypes.DefaultValueIntegerType\" "
-"name=\"default_zero\">\n"
-"    <param name=\"default\">0</param>\n"
-"</typedef>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2789
-#, no-c-format
-msgid "<![CDATA[<property name=\"priority\" type=\"default_zero\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2791
 #, no-c-format
 msgid ""
 "It is also possible to override the parameters supplied in a typedef on a "
 "case-by-case basis by using type parameters on the property mapping."
 msgstr ""
-"プロパティのマッピングで型パラメータを使うことで、 typedefで提供されたパラ"
+"プロパティのマッピングで型パラメータを使うことで、 typedef で提供されたパラ"
 "メータをその都度オーバーライドすることが可能です。"
 
 #. Tag: para
-#: basic_mapping.xml:2796
 #, fuzzy, no-c-format
 msgid ""
 "Even though Hibernate's rich range of built-in types and support for "
@@ -5189,24 +3781,22 @@
 "is abstraction. With a custom type, your mapping documents would be "
 "protected against changes to the way monetary values are represented."
 msgstr ""
-"Hibernateの幅広い組み込み型とコンポーネントに対するサポートは、 カスタム型を"
-"めったに <emphasis>使わない</emphasis> ということを意味します。 それでもな"
-"お、アプリケーションで頻出する(エンティティではない)クラスに対するカスタム型"
-"の使用は、 よいやり方であるとみなされます。 例えば <literal>MonetaryAmount</"
+"Hibernate の幅広い組み込み型とコンポーネントに対するサポートは、カスタム型を"
+"めったに <emphasis>使わない</emphasis> ということを意味します。それでもなお、"
+"アプリケーションで頻出する (エンティティではない) クラスに対するカスタム型の"
+"使用は、よいやり方であるとみなされます。例えば <literal>MonetaryAmount</"
 "literal> クラスはコンポーネントとして簡単にマッピングできますが、 "
-"<literal>CompositeUserType</literal> の良い候補です。 カスタム型を使用する動"
-"機の1つは抽象化です。 カスタム型を使うことで、通貨をどのように表現しようとも "
-"マッピングドキュメントは起こりうる変化に対応できます。"
+"<literal>CompositeUserType</literal> の良い候補です。カスタム型を使用する動機"
+"の1つは抽象化です。カスタム型を使うことで、通貨をどのように表現しようともマッ"
+"ピングドキュメントは起こりうる変化に対応できます。"
 
 #. Tag: title
-#: basic_mapping.xml:2812
 #, no-c-format
 msgid "Mapping a class more than once"
 msgstr "1つのクラスに1つ以上のマッピング"
 
 #. Tag: para
-#: basic_mapping.xml:2813
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to provide more than one mapping for a particular persistent "
 "class. In this case, you must specify an <emphasis>entity name</emphasis> to "
@@ -5215,55 +3805,29 @@
 "entity name when working with persistent objects, when writing queries, or "
 "when mapping associations to the named entity."
 msgstr ""
-"ある永続クラスに、一つ以上のマッピングを提供することが出来ます。 この場合、"
+"ある永続クラスに、一つ以上のマッピングを提供することが出来ます。この場合、"
 "マッピングする2つのエンティティのインスタンスを明確にするために、 <emphasis>"
 "エンティティ名</emphasis> を指定しなければなりません (デフォルトではエンティ"
-"ティ名はクラス名と同じです。)。 永続オブジェクトを扱うとき、クエリを書き込む"
-"とき、 指定されたエンティティへの関連をマッピングするときには、 Hibernateでは"
+"ティ名はクラス名と同じです。)。 Hibernate では、永続オブジェクトを扱うとき、"
+"クエリを書き込むとき、指定されたエンティティへの関連をマッピングするときに、"
 "エンティティ名を指定しなければなりません。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2821
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Contract\" table=\"Contracts\"\n"
-"        entity-name=\"CurrentContract\">\n"
-"    ...\n"
-"    <set name=\"history\" inverse=\"true\"\n"
-"            order-by=\"effectiveEndDate desc\">\n"
-"        <key column=\"currentContractId\"/>\n"
-"        <one-to-many entity-name=\"HistoricalContract\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Contract\" table=\"ContractHistory\"\n"
-"        entity-name=\"HistoricalContract\">\n"
-"    ...\n"
-"    <many-to-one name=\"currentContract\"\n"
-"            column=\"currentContractId\"\n"
-"            entity-name=\"CurrentContract\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2823
-#, fuzzy, no-c-format
-msgid ""
 "Associations are now specified using <literal>entity-name</literal> instead "
 "of <literal>class</literal>."
 msgstr ""
-"関連が<literal>class</literal> の代わりに <literal>entity-name</literal> を"
-"使って、 どのように指定されるのかに注目してください。"
+"関連が <literal>class</literal> の代わりに <literal>entity-name</literal> を"
+"使って、どのように指定されるのかに注目してください。"
 
 #. Tag: title
-#: basic_mapping.xml:2831
 #, no-c-format
 msgid "SQL quoted identifiers"
 msgstr "バッククォートで囲んだ SQL 識別子"
 
 #. Tag: para
-#: basic_mapping.xml:2832
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can force Hibernate to quote an identifier in the generated SQL by "
 "enclosing the table or column name in backticks in the mapping document. "
@@ -5272,48 +3836,32 @@
 "and MySQL uses backticks."
 msgstr ""
 "マッピングドキュメントでテーブルやカラムの名前をバッククォートで囲むことで、 "
-"Hibernateで生成されたSQL中の識別子を引用させることができます。 HibernateはSQL"
-"の <literal>Dialect</literal> に対応する、正しい引用スタイルを使います (普通"
-"はダブルクォートですが、SQL Serverではかぎ括弧、MySQLではバッククォートで"
-"す)。"
+"Hibernate で生成された SQL 中の識別子を引用させることができます。 Hibernate "
+"は SQL の <literal>Dialect</literal> に対応する、正しい引用スタイルを使います"
+"(普通はダブルクォートですが、 SQL Server ではかぎ括弧、 MySQL ではバック"
+"クォートです)。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2839
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"LineItem\" table=\"`Line Item`\">\n"
-"    <id name=\"id\" column=\"`Item Id`\"/><generator class=\"assigned\"/></"
-"id>\n"
-"    <property name=\"itemNumber\" column=\"`Item #`\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:2845
 #, no-c-format
 msgid "Metadata alternatives"
 msgstr "メタデータの代替手段"
 
 #. Tag: para
-#: basic_mapping.xml:2847
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "XML does not suit all users so there are some alternative ways to define O/R "
 "mapping metadata in Hibernate."
 msgstr ""
-"XMLの記述以外に、 HibernateではO/Rマッピングのメタデータを定義する代替方法が"
-"あります。"
+"XML の記述以外に、 Hibernate では O/R マッピングのメタデータを定義する代替方"
+"法があります。"
 
 #. Tag: title
-#: basic_mapping.xml:2852
 #, no-c-format
 msgid "Using XDoclet markup"
 msgstr "XDoclet マークアップの使用"
 
 #. Tag: para
-#: basic_mapping.xml:2854
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Many Hibernate users prefer to embed mapping information directly in "
 "sourcecode using XDoclet <literal>@hibernate.tags</literal>. We do not cover "
@@ -5321,138 +3869,26 @@
 "XDoclet. However, we include the following example of the <literal>Cat</"
 "literal> class with XDoclet mappings:"
 msgstr ""
-"多くのHibernateユーザはXDocletの <literal>@hibernate.tags</literal> を使っ"
-"て、 ソースコード内に直接マッピング情報を埋め込むことを好みます。 これは厳密"
-"に言えばXDocletの分野なので、本ドキュメントではこの方法を対象とはしません。 "
-"しかしXDocletを使った以下の <literal>Cat</literal> マッピングの例を示します。"
+"多くの Hibernate ユーザーは XDoclet の <literal>@hibernate.tags</literal> を"
+"使って、ソースコード内に直接マッピング情報を埋め込むことを好みます。これは厳"
+"密に言えば XDoclet の分野なので、本ドキュメントではこの方法を対象とはしませ"
+"ん。しかし XDoclet を使った以下の <literal>Cat</literal> マッピングの例を示し"
+"ます。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2861
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"import java.util.Date;\n"
-"\n"
-"/**\n"
-" * @hibernate.class\n"
-" *  table=\"CATS\"\n"
-" */\n"
-"public class Cat {\n"
-"    private Long id; // identifier\n"
-"    private Date birthdate;\n"
-"    private Cat mother;\n"
-"    private Set kittens\n"
-"    private Color color;\n"
-"    private char sex;\n"
-"    private float weight;\n"
-"\n"
-"    /*\n"
-"     * @hibernate.id\n"
-"     *  generator-class=\"native\"\n"
-"     *  column=\"CAT_ID\"\n"
-"     */\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"    private void setId(Long id) {\n"
-"        this.id=id;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.many-to-one\n"
-"     *  column=\"PARENT_ID\"\n"
-"     */\n"
-"    public Cat getMother() {\n"
-"        return mother;\n"
-"    }\n"
-"    void setMother(Cat mother) {\n"
-"        this.mother = mother;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"BIRTH_DATE\"\n"
-"     */\n"
-"    public Date getBirthdate() {\n"
-"        return birthdate;\n"
-"    }\n"
-"    void setBirthdate(Date date) {\n"
-"        birthdate = date;\n"
-"    }\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"WEIGHT\"\n"
-"     */\n"
-"    public float getWeight() {\n"
-"        return weight;\n"
-"    }\n"
-"    void setWeight(float weight) {\n"
-"        this.weight = weight;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"COLOR\"\n"
-"     *  not-null=\"true\"\n"
-"     */\n"
-"    public Color getColor() {\n"
-"        return color;\n"
-"    }\n"
-"    void setColor(Color color) {\n"
-"        this.color = color;\n"
-"    }\n"
-"    /**\n"
-"     * @hibernate.set\n"
-"     *  inverse=\"true\"\n"
-"     *  order-by=\"BIRTH_DATE\"\n"
-"     * @hibernate.collection-key\n"
-"     *  column=\"PARENT_ID\"\n"
-"     * @hibernate.collection-one-to-many\n"
-"     */\n"
-"    public Set getKittens() {\n"
-"        return kittens;\n"
-"    }\n"
-"    void setKittens(Set kittens) {\n"
-"        this.kittens = kittens;\n"
-"    }\n"
-"    // addKitten not needed by Hibernate\n"
-"    public void addKitten(Cat kitten) {\n"
-"        kittens.add(kitten);\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"SEX\"\n"
-"     *  not-null=\"true\"\n"
-"     *  update=\"false\"\n"
-"     */\n"
-"    public char getSex() {\n"
-"        return sex;\n"
-"    }\n"
-"    void setSex(char sex) {\n"
-"        this.sex=sex;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2863
-#, fuzzy, no-c-format
 msgid "See the Hibernate website for more examples of XDoclet and Hibernate."
 msgstr ""
-"Hibernateのウェブサイトには、XDocletとHibernateに関するサンプルが多数ありま"
-"す。"
+"Hibernate のウェブサイトには、 XDoclet と Hibernate に関するサンプルが多数あ"
+"ります。"
 
 #. Tag: title
-#: basic_mapping.xml:2870
 #, no-c-format
 msgid "Using JDK 5.0 Annotations"
 msgstr "JDK 5.0 アノテーションの使用"
 
 #. Tag: para
-#: basic_mapping.xml:2872
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "JDK 5.0 introduced XDoclet-style annotations at the language level that are "
 "type-safe and checked at compile time. This mechanism is more powerful than "
@@ -5465,72 +3901,40 @@
 "<emphasis>Hibernate Annotations</emphasis> package as a separate download. "
 "Both EJB3 (JSR-220) and Hibernate3 metadata is supported."
 msgstr ""
-"JDK5.0ではタイプセーフかつコンパイル時にチェックできる、 言語レベルのXDoclet"
-"スタイルのアノテーションを導入しました。 このメカニズムはXDocletのアノテー"
-"ションよりも強力で、ツールやIDEも多くがサポートしています。 例えばIntelliJ "
-"IDEAは、JDK5.0にアノテーションの自動補完と構文の強調表示をサポートしていま"
-"す。 EJB仕様 (JSR-220)の新しいバージョンでは、エンティティビーンに対する主要"
-"なメタデータメカニズムとして JDK5.0のアノテーションを使用しています。 "
-"Hibernate3ではJSR-220 (永続化API)の <literal>EntityManager</literal> を実装"
-"し、 メタデータマッピングに対するサポートは、 別ダウンロードの "
-"<emphasis>Hibernate Annotations</emphasis> パッケージにより利用可能です。 こ"
-"れはEJB3(JSR-220)とHibernate3のメタデータをどちらもサポートしています。"
+"JDK5.0 ではタイプセーフかつコンパイル時にチェックできる、言語レベルの "
+"XDoclet スタイルのアノテーションを導入しました。このメカニズムは XDoclet のア"
+"ノテーションよりも強力で、ツールや IDE も多くがサポートしています。例えば "
+"IntelliJ IDEA は、 JDK5.0 にアノテーションの自動補完と構文の強調表示をサポー"
+"トしています。 EJB 仕様 (JSR-220) の新しいバージョンでは、エンティティ Bean "
+"に対する主要なメタデータメカニズムとして JDK5.0 のアノテーションを使用してい"
+"ます。 Hibernate3 では JSR-220 (永続化 API) の <literal>EntityManager</"
+"literal> を実装し、メタデータマッピングに対するサポートは、別ダウンロードの "
+"<emphasis>Hibernate Annotations</emphasis> パッケージにより利用可能です。これ"
+"は EJB3 (JSR-220) と Hibernate3 のメタデータをどちらもサポートしています。"
 
 #. Tag: para
-#: basic_mapping.xml:2883
 #, no-c-format
 msgid "This is an example of a POJO class annotated as an EJB entity bean:"
-msgstr "以下はEJBのエンティティビーンとして注釈されたPOJOクラスの例です。"
+msgstr "以下は EJB のエンティティ Bean として注釈された POJO クラスの例です:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2887
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[@Entity(access = AccessType.FIELD)\n"
-"public class Customer implements Serializable {\n"
-"\n"
-"    @Id;\n"
-"    Long id;\n"
-"\n"
-"    String firstName;\n"
-"    String lastName;\n"
-"    Date birthday;\n"
-"\n"
-"    @Transient\n"
-"    Integer age;\n"
-"\n"
-"    @Embedded\n"
-"    private Address homeAddress;\n"
-"\n"
-"    @OneToMany(cascade=CascadeType.ALL)\n"
-"    @JoinColumn(name=\"CUSTOMER_ID\")\n"
-"    Set<Order> orders;\n"
-"\n"
-"    // Getter/setter and business methods\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2891
-#, fuzzy, no-c-format
-msgid ""
 "Support for JDK 5.0 Annotations (and JSR-220) is currently under "
 "development. Please refer to the Hibernate Annotations module for more "
 "details."
 msgstr ""
-"JDK5.0のアノテーション(とJSR-220)のサポートは進行中の作業であり、完全ではない"
-"ことに注意してください。 さらに詳しい情報はHibernateのアノテーション・モ"
+"JDK5.0 のアノテーション (と JSR-220) のサポートは進行中の作業であり、完全では"
+"ないことに注意してください。さらに詳しい情報は Hibernate のアノテーションモ"
 "ジュールを参照してください。"
 
 #. Tag: title
-#: basic_mapping.xml:2901
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Generated properties"
 msgstr "生成プロパティ"
 
 #. Tag: para
-#: basic_mapping.xml:2902
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Generated properties are properties that have their values generated by the "
 "database. Typically, Hibernate applications needed to <literal>refresh</"
@@ -5540,16 +3944,15 @@
 "an SQL INSERT or UPDATE for an entity that has defined generated properties, "
 "it immediately issues a select afterwards to retrieve the generated values."
 msgstr ""
-"生成プロパティとは、データベースによって生成された値を持つプロパティです。 通"
-"常、Hibernateアプリケーションは、データベースが値を生成したプロパティを含むオ"
-"ブジェクトを <literal>リフレッシュ</literal> する必要がありました。 しかし、"
-"プロパティが生成されたということをマークすることで、 アプリケーションはリフ"
-"レッシュの責任をHibernateに委譲します。 基本的に、生成プロパティを持つと定義"
-"したエンティティに対して HibernateがINSERTやUPDATEのSQLを発行した後すぐに、 "
-"生成された値を読み込むための SELECT SQL が発行されます。"
+"生成プロパティとは、データベースによって生成された値を持つプロパティです。通"
+"常、 Hibernate アプリケーションは、データベースが値を生成したプロパティを含む"
+"オブジェクトを <literal>リフレッシュ</literal> する必要がありました。しかし、"
+"プロパティが生成されたということをマークすることで、アプリケーションはリフ"
+"レッシュの責任を Hibernate に委譲します。基本的に、生成プロパティを持つと定義"
+"したエンティティに対して Hibernate が INSERT や UPDATE の SQL を発行した後す"
+"ぐに、生成された値を読み込むための SELECT SQL が発行されます。"
 
 #. Tag: para
-#: basic_mapping.xml:2911
 #, fuzzy, no-c-format
 msgid ""
 "Properties marked as generated must additionally be non-insertable and non-"
@@ -5559,23 +3962,20 @@
 "can be marked as generated."
 msgstr ""
 "生成プロパティは、挿入不可能かつ更新不可能でなければなりません。 <xref "
-"linkend=\"mapping-declaration-version\">versions</xref> 、 <xref linkend="
-"\"mapping-declaration-timestamp\">timestamps</xref> 、 <xref linkend="
-"\"mapping-declaration-property\">simple properties</xref> だけが生成されたと"
-"マークできます。"
+"linkend=\"mapping-declaration-version\"/> バージョン、 <xref linkend="
+"\"mapping-declaration-timestamp\"/> タイムスタンプ、 <xref linkend=\"mapping-"
+"declaration-property\"/> 簡単なプロパティだけが生成されたとマークできます。"
 
 #. Tag: para
-#: basic_mapping.xml:2918
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>never</literal> (the default): the given property value is not "
 "generated within the database."
 msgstr ""
-"<literal>never</literal> (デフォルト) - 与えられたプロパティの値は、 データ"
+"<literal>never</literal> (デフォルト) - 与えられたプロパティの値は、データ"
 "ベースから生成されないことを意味します。"
 
 #. Tag: para
-#: basic_mapping.xml:2922
 #, fuzzy, no-c-format
 msgid ""
 "<literal>insert</literal>: the given property value is generated on insert, "
@@ -5585,16 +3985,15 @@
 "\">timestamp</link> properties can be marked as generated, this option is "
 "not available."
 msgstr ""
-"<literal>insert</literal> - 与えられたプロパティの値は挿入時に生成されるが、 "
-"続いて起こる更新時には生成されないこと示します。 作成された日付などは、このカ"
-"テゴリに分類されます。 <xref linkend=\"mapping-declaration-version"
-"\">version</xref> ã‚„ <xref linkend=\"mapping-declaration-timestamp"
-"\">timestamp</xref> の プロパティは生成されたとマークできますが、このオプショ"
-"ンは利用できないことに注意してください。"
+"<literal>insert</literal> - 与えられたプロパティの値は挿入時に生成されるが、"
+"続いて起こる更新時には生成されないこと示します。作成された日付などは、このカ"
+"テゴリに分類されます。 <xref linkend=\"mapping-declaration-version\"/> バー"
+"ジョンや <xref linkend=\"mapping-declaration-timestamp\"/> タイムスタンプのプ"
+"ロパティは生成されたとマークできますが、このオプションは利用できないことに注"
+"意してください。"
 
 #. Tag: para
-#: basic_mapping.xml:2930
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>always</literal>: the property value is generated both on insert "
 "and on update."
@@ -5603,14 +4002,56 @@
 "示します。"
 
 #. Tag: title
-#: basic_mapping.xml:2937
-#, fuzzy, no-c-format
+#, no-c-format
+msgid "Column read and write expressions"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Hibernate allows you to customize the SQL it uses to read and write the "
+"values of columns mapped to <link linkend=\"mapping-declaration-property"
+"\">simple properties</link>. For example, if your database provides a set of "
+"data encryption functions, you can invoke them for individual columns like "
+"this: <programlisting role=\"XML\">&lt;property name=\"creditCardNumber"
+"\"&gt; &lt;column name=\"credit_card_num\" read=\"decrypt(credit_card_num)\" "
+"write=\"encrypt(?)\"/&gt; &lt;/property&gt;</programlisting>"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Hibernate applies the custom expressions automatically whenever the property "
+"is referenced in a query. This functionality is similar to a derived-"
+"property <literal>formula</literal> with two differences:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"The property is backed by one or more columns that are exported as part of "
+"automatic schema generation."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "The property is read-write, not read-only."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"The <literal>write</literal> expression, if specified, must contain exactly "
+"one '?' placeholder for the value."
+msgstr ""
+
+#. Tag: title
+#, no-c-format
 msgid "Auxiliary database objects"
-msgstr "補助的なデータベース・オブジェクト"
+msgstr "補助的なデータベースオブジェクト"
 
 #. Tag: para
-#: basic_mapping.xml:2938
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Auxiliary database objects allow for the CREATE and DROP of arbitrary "
 "database objects. In conjunction with Hibernate's schema evolution tools, "
@@ -5621,142 +4062,1758 @@
 "example, ALTERs, INSERTS, etc.). There are essentially two modes for "
 "defining auxiliary database objects:"
 msgstr ""
-"Hibernateのスキーマ・エボリューションツールと連動することで、 任意のデータ"
-"ベース・オブジェクト(トリガーやストアドプロシージャなど)のCREATEとDROPによ"
-"り、 Hibernateのマッピングファイル内のユーザ・スキーマをすべて定義することが"
-"出来ます。 主にトリガやストアドプロシージャのようなデータベース・オブジェクト"
-"を生成や削除することを意図していますが、 実際には <literal>java.sql."
-"Statement.execute()</literal> メソッドによって実行できる 任意のSQLコマンド"
-"(ALTER、INSERTなど)が実行できます。 補助的なデータベース・オブジェクトを定"
-"義するための、2つの基本的な方法があります。"
+"Hibernate のスキーマエボリューションツールと連動することで、任意のデータベー"
+"スオブジェクト(トリガーやストアドプロシージャなど)の CREATE と DROP によ"
+"り、 Hibernate のマッピングファイル内のユーザースキーマをすべて定義することが"
+"出来ます。主にトリガやストアドプロシージャのようなデータベースオブジェクトを"
+"生成や削除することを意図していますが、実際には <literal>java.sql.Statement."
+"execute()</literal> メソッドによって実行できる任意の SQL コマンド(ALTER、"
+"INSERTなど)が実行できます。補助的なデータベースオブジェクトを定義するため"
+"の、2つの基本的な方法があります。"
 
 #. Tag: para
-#: basic_mapping.xml:2947
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The first mode is to explicitly list the CREATE and DROP commands in the "
 "mapping file:"
 msgstr ""
-"1つ目の方法は、CREATEとDROPコマンドをマッピングファイルの外に、明示的に記載す"
-"ることです。"
+"1つ目の方法は、 CREATE と DROP コマンドをマッピングファイルの外に、明示的に記"
+"載することです:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2951
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <create>CREATE TRIGGER my_trigger ...</create>\n"
-"        <drop>DROP TRIGGER my_trigger</drop>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2952
-#, fuzzy, no-c-format
-msgid ""
 "The second mode is to supply a custom class that constructs the CREATE and "
 "DROP commands. This custom class must implement the <literal>org.hibernate."
 "mapping.AuxiliaryDatabaseObject</literal> interface."
 msgstr ""
-"2つ目の方法は、CREATEとDROPコマンドの組み立て方を知っているカスタムクラスを提"
-"供することです。 このカスタムクラスは <literal>org.hibernate.mapping."
-"AuxiliaryDatabaseObject</literal> インタフェースを 実装しなければなりません。"
+"2つ目の方法は、 CREATE と DROP コマンドの組み立て方を知っているカスタムクラス"
+"を提供することです。このカスタムクラスは <literal>org.hibernate.mapping."
+"AuxiliaryDatabaseObject</literal> インタフェースを実装しなければなりません。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2957
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <definition class=\"MyTriggerDefinition\"/>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2958
-#, fuzzy, no-c-format
-msgid ""
 "Additionally, these database objects can be optionally scoped so that they "
 "only apply when certain dialects are used."
 msgstr ""
-"さらに、あるデータベース方言が使用される時にだけ適用するといったように、 デー"
-"タベース・オブジェクトが使われるケースを限定できます。"
+"さらに、あるデータベース方言が使用される時にだけ適用するといったように、デー"
+"タベースオブジェクトが使われるケースを限定できます。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2962
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <definition class=\"MyTriggerDefinition\"/>\n"
-"        <dialect-scope name=\"org.hibernate.dialect.Oracle9iDialect\"/>\n"
-"        <dialect-scope name=\"org.hibernate.dialect.Oracle10gDialect\"/>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "      \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "          \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"
+#~ "\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "        <class name=\"Cat\"\n"
+#~ "            table=\"cats\"\n"
+#~ "            discriminator-value=\"C\">\n"
+#~ "\n"
+#~ "                <id name=\"id\">\n"
+#~ "                        <generator class=\"native\"/>\n"
+#~ "                </id>\n"
+#~ "\n"
+#~ "                <discriminator column=\"subclass\"\n"
+#~ "                     type=\"character\"/>\n"
+#~ "\n"
+#~ "                <property name=\"weight\"/>\n"
+#~ "\n"
+#~ "                <property name=\"birthdate\"\n"
+#~ "                    type=\"date\"\n"
+#~ "                    not-null=\"true\"\n"
+#~ "                    update=\"false\"/>\n"
+#~ "\n"
+#~ "                <property name=\"color\"\n"
+#~ "                    type=\"eg.types.ColorUserType\"\n"
+#~ "                    not-null=\"true\"\n"
+#~ "                    update=\"false\"/>\n"
+#~ "\n"
+#~ "                <property name=\"sex\"\n"
+#~ "                    not-null=\"true\"\n"
+#~ "                    update=\"false\"/>\n"
+#~ "\n"
+#~ "                <property name=\"litterId\"\n"
+#~ "                    column=\"litterId\"\n"
+#~ "                    update=\"false\"/>\n"
+#~ "\n"
+#~ "                <many-to-one name=\"mother\"\n"
+#~ "                    column=\"mother_id\"\n"
+#~ "                    update=\"false\"/>\n"
+#~ "\n"
+#~ "                <set name=\"kittens\"\n"
+#~ "                    inverse=\"true\"\n"
+#~ "                    order-by=\"litter_id\">\n"
+#~ "                        <key column=\"mother_id\"/>\n"
+#~ "                        <one-to-many class=\"Cat\"/>\n"
+#~ "                </set>\n"
+#~ "\n"
+#~ "                <subclass name=\"DomesticCat\"\n"
+#~ "                    discriminator-value=\"D\">\n"
+#~ "\n"
+#~ "                        <property name=\"name\"\n"
+#~ "                            type=\"string\"/>\n"
+#~ "\n"
+#~ "                </subclass>\n"
+#~ "\n"
+#~ "        </class>\n"
+#~ "\n"
+#~ "        <class name=\"Dog\">\n"
+#~ "                <!-- mapping for Dog could go here -->\n"
+#~ "        </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;?xml version=\"1.0\"?&gt;\n"
+#~ "&lt;!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "      \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "          \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"
+#~ "\"&gt;\n"
+#~ "\n"
+#~ "&lt;hibernate-mapping package=\"eg\"&gt;\n"
+#~ "\n"
+#~ "        &lt;class name=\"Cat\" \n"
+#~ "            table=\"cats\"\n"
+#~ "            discriminator-value=\"C\"&gt;\n"
+#~ "                \n"
+#~ "                &lt;id name=\"id\"&gt;\n"
+#~ "                        &lt;generator class=\"native\"/&gt;\n"
+#~ "                &lt;/id&gt;\n"
+#~ "\n"
+#~ "                &lt;discriminator column=\"subclass\" \n"
+#~ "                     type=\"character\"/&gt;\n"
+#~ "\n"
+#~ "                &lt;property name=\"weight\"/&gt;\n"
+#~ "\n"
+#~ "                &lt;property name=\"birthdate\"\n"
+#~ "                    type=\"date\" \n"
+#~ "                    not-null=\"true\" \n"
+#~ "                    update=\"false\"/&gt;\n"
+#~ "\n"
+#~ "                &lt;property name=\"color\"\n"
+#~ "                    type=\"eg.types.ColorUserType\"\n"
+#~ "                    not-null=\"true\"\n"
+#~ "                    update=\"false\"/&gt;\n"
+#~ "\n"
+#~ "                &lt;property name=\"sex\"\n"
+#~ "                    not-null=\"true\" \n"
+#~ "                    update=\"false\"/&gt;\n"
+#~ "\n"
+#~ "                &lt;property name=\"litterId\"\n"
+#~ "                    column=\"litterId\"\n"
+#~ "                    update=\"false\"/&gt;\n"
+#~ "\n"
+#~ "                &lt;many-to-one name=\"mother\"\n"
+#~ "                    column=\"mother_id\"\n"
+#~ "                    update=\"false\"/&gt;\n"
+#~ "\n"
+#~ "                &lt;set name=\"kittens\"\n"
+#~ "                    inverse=\"true\"\n"
+#~ "                    order-by=\"litter_id\"&gt;\n"
+#~ "                        &lt;key column=\"mother_id\"/&gt;\n"
+#~ "                        &lt;one-to-many class=\"Cat\"/&gt;\n"
+#~ "                &lt;/set&gt;\n"
+#~ "\n"
+#~ "                &lt;subclass name=\"DomesticCat\"\n"
+#~ "                    discriminator-value=\"D\"&gt;\n"
+#~ "\n"
+#~ "                        &lt;property name=\"name\" \n"
+#~ "                            type=\"string\"/&gt;\n"
+#~ "\n"
+#~ "                &lt;/subclass&gt;\n"
+#~ "\n"
+#~ "        &lt;/class&gt;\n"
+#~ "\n"
+#~ "        &lt;class name=\"Dog\"&gt;\n"
+#~ "                &lt;!-- mapping for Dog could go here --&gt;\n"
+#~ "        &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>type</literal> (optional): A name that indicates the Hibernate "
-#~ "type."
-#~ msgstr "<literal>type</literal>(オプション):Hibernateの型を示す名前。"
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\" [\n"
+#~ "    <!ENTITY types SYSTEM \"classpath://your/domain/types.xml\">\n"
+#~ "]>\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"your.domain\">\n"
+#~ "    <class name=\"MyEntity\">\n"
+#~ "        <id name=\"id\" type=\"my-custom-id-type\">\n"
+#~ "            ...\n"
+#~ "        </id>\n"
+#~ "    <class>\n"
+#~ "    &types;\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;?xml version=\"1.0\"?&gt;\n"
+#~ "&lt;!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\" [\n"
+#~ "    &lt;!ENTITY types SYSTEM \"classpath://your/domain/types.xml\"&gt;\n"
+#~ "]&gt;\n"
+#~ "\n"
+#~ "&lt;hibernate-mapping package=\"your.domain\"&gt;\n"
+#~ "    &lt;class name=\"MyEntity\"&gt;\n"
+#~ "        &lt;id name=\"id\" type=\"my-custom-id-type\"&gt;\n"
+#~ "            ...\n"
+#~ "        &lt;/id&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "    &amp; types;\n"
+#~ "&lt;/hibernate-mapping&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>cascade</literal> (optional): Specifies which operations should "
-#~ "be cascaded from the parent object to the associated object."
+#~ "<![CDATA[<hibernate-mapping\n"
+#~ "         schema=\"schemaName\"\n"
+#~ "         catalog=\"catalogName\"\n"
+#~ "         default-cascade=\"cascade_style\"\n"
+#~ "         default-access=\"field|property|ClassName\"\n"
+#~ "         default-lazy=\"true|false\"\n"
+#~ "         auto-import=\"true|false\"\n"
+#~ "         package=\"package.name\"\n"
+#~ " />]]>"
 #~ msgstr ""
-#~ "<literal>cascade</literal>(オプション): どの操作を、親オブジェクトから"
-#~ "関連オブジェクトへとカスケードさせるかを指定します。"
+#~ "&lt;hibernate-mapping\n"
+#~ "         schema=\"schemaName\"\n"
+#~ "         catalog=\"catalogName\"\n"
+#~ "         default-cascade=\"cascade_style\"\n"
+#~ "         default-access=\"field|property|ClassName\"\n"
+#~ "         default-lazy=\"true|false\"\n"
+#~ "         auto-import=\"true|false\"\n"
+#~ "         package=\"package.name\"\n"
+#~ " /&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
-#~ "literal>): Specifies that updates to this property do or do not require "
-#~ "acquisition of the optimistic lock. In other words, dertermines if a "
-#~ "version increment should occur when this property is dirty."
+#~ "<![CDATA[<class\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        table=\"tableName\"\n"
+#~ "        discriminator-value=\"discriminator_value\"\n"
+#~ "        mutable=\"true|false\"\n"
+#~ "        schema=\"owner\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        select-before-update=\"true|false\"\n"
+#~ "        polymorphism=\"implicit|explicit\"\n"
+#~ "        where=\"arbitrary sql where condition\"\n"
+#~ "        persister=\"PersisterClass\"\n"
+#~ "        batch-size=\"N\"\n"
+#~ "        optimistic-lock=\"none|version|dirty|all\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        check=\"arbitrary sql check condition\"\n"
+#~ "        rowid=\"rowid\"\n"
+#~ "        subselect=\"SQL expression\"\n"
+#~ "        abstract=\"true|false\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "/>]]>"
 #~ msgstr ""
-#~ "<literal>optimistic-lock</literal> (オプション - デフォルトは "
-#~ "<literal>true</literal> ): このプロパティの更新に楽観的ロックの取得を要求"
-#~ "するかどうかを指定します。 言い換えれば、このプロパティがダーティであると"
-#~ "きにバージョンを増やすべきかを決定します。"
+#~ "&lt;class\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        table=\"tableName\"\n"
+#~ "        discriminator-value=\"discriminator_value\"\n"
+#~ "        mutable=\"true|false\"\n"
+#~ "        schema=\"owner\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        select-before-update=\"true|false\"\n"
+#~ "        polymorphism=\"implicit|explicit\"\n"
+#~ "        where=\"arbitrary sql where condition\"\n"
+#~ "        persister=\"PersisterClass\"\n"
+#~ "        batch-size=\"N\"\n"
+#~ "        optimistic-lock=\"none|version|dirty|all\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        check=\"arbitrary sql check condition\"\n"
+#~ "        rowid=\"rowid\"\n"
+#~ "        subselect=\"SQL expression\"\n"
+#~ "        abstract=\"true|false\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "/&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "To understand the behaviour of various Java language-level objects with "
-#~ "respect to the persistence service, we need to classify them into two "
-#~ "groups:"
+#~ "<![CDATA[<class name=\"Summary\">\n"
+#~ "    <subselect>\n"
+#~ "        select item.name, max(bid.amount), count(*)\n"
+#~ "        from item\n"
+#~ "        join bid on bid.item_id = item.id\n"
+#~ "        group by item.name\n"
+#~ "    </subselect>\n"
+#~ "    <synchronize table=\"item\"/>\n"
+#~ "    <synchronize table=\"bid\"/>\n"
+#~ "    <id name=\"name\"/>\n"
+#~ "    ...\n"
+#~ "</class>]]>"
 #~ msgstr ""
-#~ "永続サービスに関わる様々なJava言語レベルのオブジェクトの振る舞いを理解する"
-#~ "ためには、 オブジェクトを2つのグループに分ける必要があります:"
+#~ "&lt;class name=\"Summary\"&gt;\n"
+#~ "    &lt;subselect&gt;\n"
+#~ "        select item.name, max(bid.amount), count(*)\n"
+#~ "        from item\n"
+#~ "        join bid on bid.item_id = item.id\n"
+#~ "        group by item.name\n"
+#~ "    &lt;/subselect&gt;\n"
+#~ "    &lt;synchronize table=\"item\"/&gt;\n"
+#~ "    &lt;synchronize table=\"bid\"/&gt;\n"
+#~ "    &lt;id name=\"name\"/&gt;\n"
+#~ "    ...\n"
+#~ "&lt;/class&gt;"
 
 #, fuzzy
-#~ msgid "<literal>class</literal>"
-#~ msgstr "<literal>all</literal> すべてのカラムをチェックします。"
+#~ msgid ""
+#~ "<![CDATA[<id\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        type=\"typename\"\n"
+#~ "        column=\"column_name\"\n"
+#~ "        unsaved-value=\"null|any|none|undefined|id_value\"\n"
+#~ "        access=\"field|property|ClassName\">\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "\n"
+#~ "        <generator class=\"generatorClass\"/>\n"
+#~ "</id>]]>"
+#~ msgstr ""
+#~ "&lt;id\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        type=\"typename\"\n"
+#~ "        column=\"column_name\"\n"
+#~ "        unsaved-value=\"null|any|none|undefined|id_value\"\n"
+#~ "        access=\"field|property|ClassName\"&gt;\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "\n"
+#~ "        &lt;generator class=\"generatorClass\"/&gt;\n"
+#~ "&lt;/id&gt;"
 
-#~ msgid "id"
-#~ msgstr "id"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
+#~ "        <generator class=\"org.hibernate.id.TableHiLoGenerator\">\n"
+#~ "                <param name=\"table\">uid_table</param>\n"
+#~ "                <param name=\"column\">next_hi_value_column</param>\n"
+#~ "        </generator>\n"
+#~ "</id>]]>"
+#~ msgstr ""
+#~ "&lt;id name=\"id\" type=\"long\" column=\"cat_id\"&gt;\n"
+#~ "        &lt;generator class=\"org.hibernate.id.TableHiLoGenerator\"&gt;\n"
+#~ "                &lt;param name=\"table\"&gt;uid_table&lt;/param&gt;\n"
+#~ "                &lt;param name=\"column\"&gt;next_hi_value_column&lt;/"
+#~ "param&gt;\n"
+#~ "        &lt;/generator&gt;\n"
+#~ "&lt;/id&gt;"
 
+#~ msgid "increment"
+#~ msgstr "increment"
+
+#~ msgid "identity"
+#~ msgstr "identity"
+
+#~ msgid "sequence"
+#~ msgstr "sequence"
+
+#~ msgid "hilo"
+#~ msgstr "hilo"
+
+#~ msgid "seqhilo"
+#~ msgstr "seqhilo"
+
+#~ msgid "guid"
+#~ msgstr "guid"
+
+#~ msgid "native"
+#~ msgstr "native"
+
+#~ msgid "assigned"
+#~ msgstr "assigned"
+
+#~ msgid "select"
+#~ msgstr "select"
+
+#~ msgid "foreign"
+#~ msgstr "foreign"
+
+#, fuzzy
 #~ msgid ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal>none</"
-#~ "literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers"
-#~ "\"/>"
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
+#~ "        <generator class=\"hilo\">\n"
+#~ "                <param name=\"table\">hi_value</param>\n"
+#~ "                <param name=\"column\">next_value</param>\n"
+#~ "                <param name=\"max_lo\">100</param>\n"
+#~ "        </generator>\n"
+#~ "</id>]]>"
 #~ msgstr ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal>none</"
-#~ "literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers"
-#~ "\"/>"
+#~ "&lt;id name=\"id\" type=\"long\" column=\"cat_id\"&gt;\n"
+#~ "        &lt;generator class=\"hilo\"&gt;\n"
+#~ "                &lt;param name=\"table\"&gt;hi_value&lt;/param&gt;\n"
+#~ "                &lt;param name=\"column\"&gt;next_value&lt;/param&gt;\n"
+#~ "                &lt;param name=\"max_lo\"&gt;100&lt;/param&gt;\n"
+#~ "        &lt;/generator&gt;\n"
+#~ "&lt;/id&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal/>): See "
-#~ "<xref linkend=\"mapping-declaration-id-enhanced-optimizers\"/>"
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
+#~ "        <generator class=\"seqhilo\">\n"
+#~ "                <param name=\"sequence\">hi_value</param>\n"
+#~ "                <param name=\"max_lo\">100</param>\n"
+#~ "        </generator>\n"
+#~ "</id>]]>"
 #~ msgstr ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal/>): See "
-#~ "<xref linkend=\"mapping-declaration-id-enhanced-optimizers\"/>"
+#~ "&lt;id name=\"id\" type=\"long\" column=\"cat_id\"&gt;\n"
+#~ "        &lt;generator class=\"seqhilo\"&gt;\n"
+#~ "                &lt;param name=\"sequence\"&gt;hi_value&lt;/param&gt;\n"
+#~ "                &lt;param name=\"max_lo\"&gt;100&lt;/param&gt;\n"
+#~ "        &lt;/generator&gt;\n"
+#~ "&lt;/id&gt;"
 
-#~ msgid "key"
-#~ msgstr "key"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
+#~ "        <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">person_id_sequence</param>\n"
+#~ "        </generator>\n"
+#~ "</id>]]>"
+#~ msgstr ""
+#~ "&lt;id name=\"id\" type=\"long\" column=\"person_id\"&gt;\n"
+#~ "        &lt;generator class=\"sequence\"&gt;\n"
+#~ "                &lt;param name=\"sequence\"&gt;person_id_sequence&lt;/"
+#~ "param&gt;\n"
+#~ "        &lt;/generator&gt;\n"
+#~ "&lt;/id&gt;"
 
-#~ msgid "any"
-#~ msgstr "any"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\" unsaved-value="
+#~ "\"0\">\n"
+#~ "        <generator class=\"identity\"/>\n"
+#~ "</id>]]>"
+#~ msgstr ""
+#~ "&lt;id name=\"id\" type=\"long\" column=\"person_id\" unsaved-value=\"0"
+#~ "\"&gt;\n"
+#~ "        &lt;generator class=\"identity\"/&gt;\n"
+#~ "&lt;/id&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
+#~ "        <generator class=\"select\">\n"
+#~ "                <param name=\"key\">socialSecurityNumber</param>\n"
+#~ "        </generator>\n"
+#~ "</id>]]>"
+#~ msgstr ""
+#~ "&lt;id name=\"id\" type=\"long\" column=\"person_id\"&gt;\n"
+#~ "        &lt;generator class=\"select\"&gt;\n"
+#~ "                &lt;param name=\"key\"&gt;socialSecurityNumber&lt;/"
+#~ "param&gt;\n"
+#~ "        &lt;/generator&gt;\n"
+#~ "&lt;/id&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<composite-id\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        mapped=\"true|false\"\n"
+#~ "        access=\"field|property|ClassName\">\n"
+#~ "        node=\"element-name|.\"\n"
+#~ "\n"
+#~ "        <key-property name=\"propertyName\" type=\"typename\" column="
+#~ "\"column_name\"/>\n"
+#~ "        <key-many-to-one name=\"propertyName class=\"ClassName\" column="
+#~ "\"column_name\"/>\n"
+#~ "        ......\n"
+#~ "</composite-id>]]>"
+#~ msgstr ""
+#~ "&lt;composite-id\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        mapped=\"true|false\"\n"
+#~ "        access=\"field|property|ClassName\"&gt;\n"
+#~ "        node=\"element-name|.\"\n"
+#~ "\n"
+#~ "        &lt;key-property name=\"propertyName\" type=\"typename\" column="
+#~ "\"column_name\"/&gt;\n"
+#~ "        &lt;key-many-to-one name=\"propertyName class=\"ClassName\" "
+#~ "column=\"column_name\"/&gt;\n"
+#~ "        ......\n"
+#~ "&lt;/composite-id&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<composite-id>\n"
+#~ "        <key-property name=\"medicareNumber\"/>\n"
+#~ "        <key-property name=\"dependent\"/>\n"
+#~ "</composite-id>]]>"
+#~ msgstr ""
+#~ "&lt;composite-id&gt;\n"
+#~ "        &lt;key-property name=\"medicareNumber\"/&gt;\n"
+#~ "        &lt;key-property name=\"dependent\"/&gt;\n"
+#~ "&lt;/composite-id&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<composite-id class=\"MedicareId\" mapped=\"true\">\n"
+#~ "        <key-property name=\"medicareNumber\"/>\n"
+#~ "        <key-property name=\"dependent\"/>\n"
+#~ "</composite-id>]]>"
+#~ msgstr ""
+#~ "&lt;composite-id class=\"MedicareId\" mapped=\"true\"&gt;\n"
+#~ "        &lt;key-property name=\"medicareNumber\"/&gt;\n"
+#~ "        &lt;key-property name=\"dependent\"/&gt;\n"
+#~ "&lt;/composite-id&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<discriminator\n"
+#~ "        column=\"discriminator_column\"\n"
+#~ "        type=\"discriminator_type\"\n"
+#~ "        force=\"true|false\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        formula=\"arbitrary sql expression\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "&lt;discriminator\n"
+#~ "        column=\"discriminator_column\"\n"
+#~ "        type=\"discriminator_type\"\n"
+#~ "        force=\"true|false\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        formula=\"arbitrary sql expression\"\n"
+#~ "/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<discriminator\n"
+#~ "    formula=\"case when CLASS_TYPE in ('a', 'b', 'c') then 0 else 1 end"
+#~ "\"\n"
+#~ "    type=\"integer\"/>]]>"
+#~ msgstr ""
+#~ "&lt;discriminator\n"
+#~ "    formula=\"case when CLASS_TYPE in ('a', 'b', 'c') then 0 else 1 end"
+#~ "\"\n"
+#~ "    type=\"integer\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<version\n"
+#~ "        column=\"version_column\"\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        type=\"typename\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        unsaved-value=\"null|negative|undefined\"\n"
+#~ "        generated=\"never|always\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "&lt;version\n"
+#~ "        column=\"version_column\"\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        type=\"typename\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        unsaved-value=\"null|negative|undefined\"\n"
+#~ "        generated=\"never|always\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<timestamp\n"
+#~ "        column=\"timestamp_column\"\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        unsaved-value=\"null|undefined\"\n"
+#~ "        source=\"vm|db\"\n"
+#~ "        generated=\"never|always\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "&lt;timestamp\n"
+#~ "        column=\"timestamp_column\"\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        unsaved-value=\"null|undefined\"\n"
+#~ "        source=\"vm|db\"\n"
+#~ "        generated=\"never|always\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        column=\"column_name\"\n"
+#~ "        type=\"typename\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        formula=\"arbitrary SQL expression\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        generated=\"never|insert|always\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "        index=\"index_name\"\n"
+#~ "        unique_key=\"unique_key_id\"\n"
+#~ "        length=\"L\"\n"
+#~ "        precision=\"P\"\n"
+#~ "        scale=\"S\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "&lt;property\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        column=\"column_name\"\n"
+#~ "        type=\"typename\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        formula=\"arbitrary SQL expression\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        generated=\"never|insert|always\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "        index=\"index_name\"\n"
+#~ "        unique_key=\"unique_key_id\"\n"
+#~ "        length=\"L\"\n"
+#~ "        precision=\"P\"\n"
+#~ "        scale=\"S\"\n"
+#~ "/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[\n"
+#~ "<property name=\"totalPrice\"\n"
+#~ "    formula=\"( SELECT SUM (li.quantity*p.price) FROM LineItem li, "
+#~ "Product p\n"
+#~ "                WHERE li.productId = p.productId\n"
+#~ "                AND li.customerId = customerId\n"
+#~ "                AND li.orderNumber = orderNumber )\"/>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"totalPrice\"\n"
+#~ "    formula=\"( SELECT SUM (li.quantity*p.price) FROM LineItem li, "
+#~ "Product p\n"
+#~ "                WHERE li.productId = p.productId\n"
+#~ "                AND li.customerId = customerId\n"
+#~ "                AND li.orderNumber = orderNumber )\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        column=\"column_name\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        cascade=\"cascade_style\"\n"
+#~ "        fetch=\"join|select\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        property-ref=\"propertyNameFromAssociatedClass\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        lazy=\"proxy|no-proxy|false\"\n"
+#~ "        not-found=\"ignore|exception\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        formula=\"arbitrary SQL expression\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "        embed-xml=\"true|false\"\n"
+#~ "        index=\"index_name\"\n"
+#~ "        unique_key=\"unique_key_id\"\n"
+#~ "        foreign-key=\"foreign_key_name\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        column=\"column_name\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        cascade=\"cascade_style\"\n"
+#~ "        fetch=\"join|select\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        property-ref=\"propertyNameFromAssociatedClass\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        lazy=\"proxy|no-proxy|false\"\n"
+#~ "        not-found=\"ignore|exception\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        formula=\"arbitrary SQL expression\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "        embed-xml=\"true|false\"\n"
+#~ "        index=\"index_name\"\n"
+#~ "        unique_key=\"unique_key_id\"\n"
+#~ "        foreign-key=\"foreign_key_name\"\n"
+#~ "/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"product\" class=\"Product\" column="
+#~ "\"PRODUCT_ID\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"product\" class=\"Product\" column=\"PRODUCT_ID\"/"
+#~ "&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"serialNumber\" unique=\"true\" type=\"string\" "
+#~ "column=\"SERIAL_NUMBER\"/>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"serialNumber\" unique=\"true\" type=\"string\" column="
+#~ "\"SERIAL_NUMBER\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"product\" property-ref=\"serialNumber\" "
+#~ "column=\"PRODUCT_SERIAL_NUMBER\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"product\" property-ref=\"serialNumber\" column="
+#~ "\"PRODUCT_SERIAL_NUMBER\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"owner\" property-ref=\"identity.ssn\" column="
+#~ "\"OWNER_SSN\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"owner\" property-ref=\"identity.ssn\" column="
+#~ "\"OWNER_SSN\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<one-to-one\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        cascade=\"cascade_style\"\n"
+#~ "        constrained=\"true|false\"\n"
+#~ "        fetch=\"join|select\"\n"
+#~ "        property-ref=\"propertyNameFromAssociatedClass\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        formula=\"any SQL expression\"\n"
+#~ "        lazy=\"proxy|no-proxy|false\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "        embed-xml=\"true|false\"\n"
+#~ "        foreign-key=\"foreign_key_name\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "&lt;one-to-one\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        cascade=\"cascade_style\"\n"
+#~ "        constrained=\"true|false\"\n"
+#~ "        fetch=\"join|select\"\n"
+#~ "        property-ref=\"propertyNameFromAssociatedClass\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        formula=\"any SQL expression\"\n"
+#~ "        lazy=\"proxy|no-proxy|false\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "        embed-xml=\"true|false\"\n"
+#~ "        foreign-key=\"foreign_key_name\"\n"
+#~ "/&gt;"
+
+#, fuzzy
+#~ msgid "<![CDATA[<one-to-one name=\"person\" class=\"Person\"/>]]>"
+#~ msgstr "&lt;one-to-one name=\"person\" class=\"Person\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" constrained="
+#~ "\"true\"/>]]>"
+#~ msgstr ""
+#~ "&lt;one-to-one name=\"employee\" class=\"Employee\" constrained=\"true\"/"
+#~ "&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"person\" table=\"PERSON\">\n"
+#~ "    <id name=\"id\" column=\"PERSON_ID\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">employee</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    ...\n"
+#~ "    <one-to-one name=\"employee\"\n"
+#~ "        class=\"Employee\"\n"
+#~ "        constrained=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"person\" table=\"PERSON\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"PERSON_ID\"&gt;\n"
+#~ "        &lt;generator class=\"foreign\"&gt;\n"
+#~ "            &lt;param name=\"property\"&gt;employee&lt;/param&gt;\n"
+#~ "        &lt;/generator&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;one-to-one name=\"employee\"\n"
+#~ "        class=\"Employee\"\n"
+#~ "        constrained=\"true\"/&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"person\" class=\"Person\" column=\"PERSON_ID"
+#~ "\" unique=\"true\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"person\" class=\"Person\" column=\"PERSON_ID\" "
+#~ "unique=\"true\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" property-ref="
+#~ "\"person\"/>]]>"
+#~ msgstr ""
+#~ "&lt;one-to-one name\"employee\" class=\"Employee\" property-ref=\"person"
+#~ "\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<natural-id mutable=\"true|false\"/>\n"
+#~ "        <property ... />\n"
+#~ "        <many-to-one ... />\n"
+#~ "        ......\n"
+#~ "</natural-id>]]>"
+#~ msgstr ""
+#~ "&lt;natural-id mutable=\"true|false\"/&gt;\n"
+#~ "        &lt;property ... /&gt;\n"
+#~ "        &lt;many-to-one ... /&gt;\n"
+#~ "        ......\n"
+#~ "&lt;/natural-id&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<component\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        class=\"className\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        node=\"element-name|.\"\n"
+#~ ">\n"
+#~ "\n"
+#~ "        <property ...../>\n"
+#~ "        <many-to-one .... />\n"
+#~ "        ........\n"
+#~ "</component>]]>"
+#~ msgstr ""
+#~ "&lt;component \n"
+#~ "        name=\"propertyName\" \n"
+#~ "        class=\"className\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        node=\"element-name|.\"\n"
+#~ "&gt;\n"
+#~ "        \n"
+#~ "        &lt;property ...../&gt;\n"
+#~ "        &lt;many-to-one .... /&gt;\n"
+#~ "        ........\n"
+#~ "&lt;/component&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<properties\n"
+#~ "        name=\"logicalName\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ ">\n"
+#~ "\n"
+#~ "        <property ...../>\n"
+#~ "        <many-to-one .... />\n"
+#~ "        ........\n"
+#~ "</properties>]]>"
+#~ msgstr ""
+#~ "&lt;properties \n"
+#~ "        name=\"logicalName\" \n"
+#~ "        insert=\"true|false\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "&gt;\n"
+#~ "        \n"
+#~ "        &lt;property ...../&gt;\n"
+#~ "        &lt;many-to-one .... /&gt;\n"
+#~ "        ........\n"
+#~ "&lt;/properties&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"personNumber\"/>\n"
+#~ "\n"
+#~ "    ...\n"
+#~ "    <properties name=\"name\"\n"
+#~ "            unique=\"true\" update=\"false\">\n"
+#~ "        <property name=\"firstName\"/>\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"lastName\"/>\n"
+#~ "    </properties>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"personNumber\"/&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;properties name=\"name\" \n"
+#~ "            unique=\"true\" update=\"false\"&gt;\n"
+#~ "        &lt;property name=\"firstName\"/&gt;\n"
+#~ "        &lt;property name=\"initial\"/&gt;\n"
+#~ "        &lt;property name=\"lastName\"/&gt;\n"
+#~ "    &lt;/properties&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"person\"\n"
+#~ "         class=\"Person\" property-ref=\"name\">\n"
+#~ "    <column name=\"firstName\"/>\n"
+#~ "    <column name=\"initial\"/>\n"
+#~ "    <column name=\"lastName\"/>\n"
+#~ "</many-to-one>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"person\" \n"
+#~ "         class=\"Person\" property-ref=\"name\"&gt;\n"
+#~ "    &lt;column name=\"firstName\"/&gt;\n"
+#~ "    &lt;column name=\"initial\"/&gt;\n"
+#~ "    &lt;column name=\"lastName\"/&gt;\n"
+#~ "&lt;/many-to-one&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<subclass\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        discriminator-value=\"discriminator_value\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "        extends=\"SuperclassName\">\n"
+#~ "\n"
+#~ "        <property .... />\n"
+#~ "        .....\n"
+#~ "</subclass>]]>"
+#~ msgstr ""
+#~ "&lt;subclass\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        discriminator-value=\"discriminator_value\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "        extends=\"SuperclassName\"&gt;\n"
+#~ "\n"
+#~ "        &lt;property .... /&gt;\n"
+#~ "        .....\n"
+#~ "&lt;/subclass&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<joined-subclass\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        table=\"tablename\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        schema=\"schema\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        extends=\"SuperclassName\"\n"
+#~ "        persister=\"ClassName\"\n"
+#~ "        subselect=\"SQL expression\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\">\n"
+#~ "\n"
+#~ "        <key .... >\n"
+#~ "\n"
+#~ "        <property .... />\n"
+#~ "        .....\n"
+#~ "</joined-subclass>]]>"
+#~ msgstr ""
+#~ "&lt;joined-subclass\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        table=\"tablename\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        schema=\"schema\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        extends=\"SuperclassName\"\n"
+#~ "        persister=\"ClassName\"\n"
+#~ "        subselect=\"SQL expression\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\"&gt;\n"
+#~ "\n"
+#~ "        &lt;key .... &gt;\n"
+#~ "\n"
+#~ "        &lt;property .... /&gt;\n"
+#~ "        .....\n"
+#~ "&lt;/joined-subclass&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Mapping DTD//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "        <class name=\"Cat\" table=\"CATS\">\n"
+#~ "                <id name=\"id\" column=\"uid\" type=\"long\">\n"
+#~ "                        <generator class=\"hilo\"/>\n"
+#~ "                </id>\n"
+#~ "                <property name=\"birthdate\" type=\"date\"/>\n"
+#~ "                <property name=\"color\" not-null=\"true\"/>\n"
+#~ "                <property name=\"sex\" not-null=\"true\"/>\n"
+#~ "                <property name=\"weight\"/>\n"
+#~ "                <many-to-one name=\"mate\"/>\n"
+#~ "                <set name=\"kittens\">\n"
+#~ "                        <key column=\"MOTHER\"/>\n"
+#~ "                        <one-to-many class=\"Cat\"/>\n"
+#~ "                </set>\n"
+#~ "                <joined-subclass name=\"DomesticCat\" table="
+#~ "\"DOMESTIC_CATS\">\n"
+#~ "                    <key column=\"CAT\"/>\n"
+#~ "                    <property name=\"name\" type=\"string\"/>\n"
+#~ "                </joined-subclass>\n"
+#~ "        </class>\n"
+#~ "\n"
+#~ "        <class name=\"eg.Dog\">\n"
+#~ "                <!-- mapping for Dog could go here -->\n"
+#~ "        </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;?xml version=\"1.0\"?&gt;\n"
+#~ "&lt;!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Mapping DTD//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"
+#~ "\"&gt;\n"
+#~ "\n"
+#~ "&lt;hibernate-mapping package=\"eg\"&gt;\n"
+#~ "\n"
+#~ "        &lt;class name=\"Cat\" table=\"CATS\"&gt;\n"
+#~ "                &lt;id name=\"id\" column=\"uid\" type=\"long\"&gt;\n"
+#~ "                        &lt;generator class=\"hilo\"/&gt;\n"
+#~ "                &lt;/id&gt;\n"
+#~ "                &lt;property name=\"birthdate\" type=\"date\"/&gt;\n"
+#~ "                &lt;property name=\"color\" not-null=\"true\"/&gt;\n"
+#~ "                &lt;property name=\"sex\" not-null=\"true\"/&gt;\n"
+#~ "                &lt;property name=\"weight\"/&gt;\n"
+#~ "                &lt;many-to-one name=\"mate\"/&gt;\n"
+#~ "                &lt;set name=\"kittens\"&gt;\n"
+#~ "                        &lt;key column=\"MOTHER\"/&gt;\n"
+#~ "                        &lt;one-to-many class=\"Cat\"/&gt;\n"
+#~ "                &lt;/set&gt;\n"
+#~ "                &lt;joined-subclass name=\"DomesticCat\" table="
+#~ "\"DOMESTIC_CATS\"&gt;\n"
+#~ "                    &lt;key column=\"CAT\"/&gt;\n"
+#~ "                    &lt;property name=\"name\" type=\"string\"/&gt;\n"
+#~ "                &lt;/joined-subclass&gt;\n"
+#~ "        &lt;/class&gt;\n"
+#~ "\n"
+#~ "        &lt;class name=\"eg.Dog\"&gt;\n"
+#~ "                &lt;!-- mapping for Dog could go here --&gt;\n"
+#~ "        &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<union-subclass\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        table=\"tablename\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        schema=\"schema\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        extends=\"SuperclassName\"\n"
+#~ "        abstract=\"true|false\"\n"
+#~ "        persister=\"ClassName\"\n"
+#~ "        subselect=\"SQL expression\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\">\n"
+#~ "\n"
+#~ "        <property .... />\n"
+#~ "        .....\n"
+#~ "</union-subclass>]]>"
+#~ msgstr ""
+#~ "&lt;union-subclass\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        table=\"tablename\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        schema=\"schema\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        extends=\"SuperclassName\"\n"
+#~ "        abstract=\"true|false\"\n"
+#~ "        persister=\"ClassName\"\n"
+#~ "        subselect=\"SQL expression\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\"&gt;\n"
+#~ "\n"
+#~ "        &lt;property .... /&gt;\n"
+#~ "        .....\n"
+#~ "&lt;/union-subclass&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<join\n"
+#~ "        table=\"tablename\"\n"
+#~ "        schema=\"owner\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        fetch=\"join|select\"\n"
+#~ "        inverse=\"true|false\"\n"
+#~ "        optional=\"true|false\">\n"
+#~ "\n"
+#~ "        <key ... />\n"
+#~ "\n"
+#~ "        <property ... />\n"
+#~ "        ...\n"
+#~ "</join>]]>"
+#~ msgstr ""
+#~ "&lt;join\n"
+#~ "        table=\"tablename\"\n"
+#~ "        schema=\"owner\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        fetch=\"join|select\"\n"
+#~ "        inverse=\"true|false\"\n"
+#~ "        optional=\"true|false\"&gt;\n"
+#~ "        \n"
+#~ "        &lt;key ... /&gt;\n"
+#~ "        \n"
+#~ "        &lt;property ... /&gt;\n"
+#~ "        ...\n"
+#~ "&lt;/join&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\"\n"
+#~ "    table=\"PERSON\">\n"
+#~ "\n"
+#~ "    <id name=\"id\" column=\"PERSON_ID\">...</id>\n"
+#~ "\n"
+#~ "    <join table=\"ADDRESS\">\n"
+#~ "        <key column=\"ADDRESS_ID\"/>\n"
+#~ "        <property name=\"address\"/>\n"
+#~ "        <property name=\"zip\"/>\n"
+#~ "        <property name=\"country\"/>\n"
+#~ "    </join>\n"
+#~ "    ...]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"\n"
+#~ "    table=\"PERSON\"&gt;\n"
+#~ "\n"
+#~ "    &lt;id name=\"id\" column=\"PERSON_ID\"&gt;...&lt;/id&gt;\n"
+#~ "\n"
+#~ "    &lt;join table=\"ADDRESS\"&gt;\n"
+#~ "        &lt;key column=\"ADDRESS_ID\"/&gt;\n"
+#~ "        &lt;property name=\"address\"/&gt;\n"
+#~ "        &lt;property name=\"zip\"/&gt;\n"
+#~ "        &lt;property name=\"country\"/&gt;\n"
+#~ "    &lt;/join&gt;\n"
+#~ "    ..."
+
+#, fuzzy
+#~ msgid "<title>Key</title>"
+#~ msgstr "<title>key</title>"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<key\n"
+#~ "        column=\"columnname\"\n"
+#~ "        on-delete=\"noaction|cascade\"\n"
+#~ "        property-ref=\"propertyName\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "&lt;key\n"
+#~ "        column=\"columnname\"\n"
+#~ "        on-delete=\"noaction|cascade\"\n"
+#~ "        property-ref=\"propertyName\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<column\n"
+#~ "        name=\"column_name\"\n"
+#~ "        length=\"N\"\n"
+#~ "        precision=\"N\"\n"
+#~ "        scale=\"N\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        unique-key=\"multicolumn_unique_key_name\"\n"
+#~ "        index=\"index_name\"\n"
+#~ "        sql-type=\"sql_type_name\"\n"
+#~ "        check=\"SQL expression\"\n"
+#~ "        default=\"SQL expression\"/>]]>"
+#~ msgstr ""
+#~ "&lt;column\n"
+#~ "        name=\"column_name\"\n"
+#~ "        length=\"N\"\n"
+#~ "        precision=\"N\"\n"
+#~ "        scale=\"N\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        unique-key=\"multicolumn_unique_key_name\"\n"
+#~ "        index=\"index_name\"\n"
+#~ "        sql-type=\"sql_type_name\"\n"
+#~ "        check=\"SQL expression\"\n"
+#~ "        default=\"SQL expression\"/&gt;"
+
+#, fuzzy
+#~ msgid "<![CDATA[<formula>SQL expression</formula>]]>"
+#~ msgstr "&lt;formula&gt;SQL expression&lt;/formula&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"homeAddress\" class=\"Address\"\n"
+#~ "        insert=\"false\" update=\"false\">\n"
+#~ "    <column name=\"person_id\" not-null=\"true\" length=\"10\"/>\n"
+#~ "    <formula>'MAILING'</formula>\n"
+#~ "</many-to-one>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"homeAddress\" class=\"Address\"\n"
+#~ "        insert=\"false\" update=\"false\"&gt;\n"
+#~ "    &lt;column name=\"person_id\" not-null=\"true\" length=\"10\"/&gt;\n"
+#~ "    &lt;formula&gt;'MAILING'&lt;/formula&gt;\n"
+#~ "&lt;/many-to-one&gt;"
+
+#, fuzzy
+#~ msgid "<![CDATA[<import class=\"java.lang.Object\" rename=\"Universe\"/>]]>"
+#~ msgstr "&lt;import class=\"java.lang.Object\" rename=\"Universe\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<import\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        rename=\"ShortName\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "&lt;import\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        rename=\"ShortName\"\n"
+#~ "/&gt;"
+
+#, fuzzy
+#~ msgid "<title>Any</title>"
+#~ msgstr "<title>any</title>"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<any name=\"being\" id-type=\"long\" meta-type=\"string\">\n"
+#~ "    <meta-value value=\"TBL_ANIMAL\" class=\"Animal\"/>\n"
+#~ "    <meta-value value=\"TBL_HUMAN\" class=\"Human\"/>\n"
+#~ "    <meta-value value=\"TBL_ALIEN\" class=\"Alien\"/>\n"
+#~ "    <column name=\"table_name\"/>\n"
+#~ "    <column name=\"id\"/>\n"
+#~ "</any>]]>"
+#~ msgstr ""
+#~ "&lt;any name=\"being\" id-type=\"long\" meta-type=\"string\"&gt;\n"
+#~ "    &lt;meta-value value=\"TBL_ANIMAL\" class=\"Animal\"/&gt;\n"
+#~ "    &lt;meta-value value=\"TBL_HUMAN\" class=\"Human\"/&gt;\n"
+#~ "    &lt;meta-value value=\"TBL_ALIEN\" class=\"Alien\"/&gt;\n"
+#~ "    &lt;column name=\"table_name\"/&gt;\n"
+#~ "    &lt;column name=\"id\"/&gt;\n"
+#~ "&lt;/any&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<any\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        id-type=\"idtypename\"\n"
+#~ "        meta-type=\"metatypename\"\n"
+#~ "        cascade=\"cascade_style\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ ">\n"
+#~ "        <meta-value ... />\n"
+#~ "        <meta-value ... />\n"
+#~ "        .....\n"
+#~ "        <column .... />\n"
+#~ "        <column .... />\n"
+#~ "        .....\n"
+#~ "</any>]]>"
+#~ msgstr ""
+#~ "&lt;any\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        id-type=\"idtypename\"\n"
+#~ "        meta-type=\"metatypename\"\n"
+#~ "        cascade=\"cascade_style\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "&gt;\n"
+#~ "        &lt;meta-value ... /&gt;\n"
+#~ "        &lt;meta-value ... /&gt;\n"
+#~ "        .....\n"
+#~ "        &lt;column .... /&gt;\n"
+#~ "        &lt;column .... /&gt;\n"
+#~ "        .....\n"
+#~ "&lt;/any&gt;"
+
+#~ msgid "string"
+#~ msgstr "string"
+
+#, fuzzy
+#~ msgid "class"
+#~ msgstr "subclass"
+
+#~ msgid "binary"
+#~ msgstr "binary"
+
+#~ msgid "text"
+#~ msgstr "text"
+
+#~ msgid "serializable"
+#~ msgstr "serializable"
+
+#~ msgid "clob, blob"
+#~ msgstr "clob, blob"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"twoStrings\" type=\"org.hibernate.test."
+#~ "DoubleStringType\">\n"
+#~ "    <column name=\"first_string\"/>\n"
+#~ "    <column name=\"second_string\"/>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"twoStrings\" type=\"org.hibernate.test."
+#~ "DoubleStringType\"&gt;\n"
+#~ "    &lt;column name=\"first_string\"/&gt;\n"
+#~ "    &lt;column name=\"second_string\"/&gt;\n"
+#~ "&lt;/property&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"priority\">\n"
+#~ "    <type name=\"com.mycompany.usertypes.DefaultValueIntegerType\">\n"
+#~ "        <param name=\"default\">0</param>\n"
+#~ "    </type>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"priority\"&gt;\n"
+#~ "    &lt;type name=\"com.mycompany.usertypes.DefaultValueIntegerType"
+#~ "\"&gt;\n"
+#~ "        &lt;param name=\"default\"&gt;0&lt;/param&gt;\n"
+#~ "    &lt;/type&gt;\n"
+#~ "&lt;/property&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<typedef class=\"com.mycompany.usertypes.DefaultValueIntegerType"
+#~ "\" name=\"default_zero\">\n"
+#~ "    <param name=\"default\">0</param>\n"
+#~ "</typedef>]]>"
+#~ msgstr ""
+#~ "&lt;typedef class=\"com.mycompany.usertypes.DefaultValueIntegerType\" "
+#~ "name=\"default_zero\"&gt;\n"
+#~ "    &lt;param name=\"default\"&gt;0&lt;/param&gt;\n"
+#~ "&lt;/typedef&gt;"
+
+#, fuzzy
+#~ msgid "<![CDATA[<property name=\"priority\" type=\"default_zero\"/>]]>"
+#~ msgstr "&lt;property name=\"priority\" type=\"default_zero\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Contract\" table=\"Contracts\"\n"
+#~ "        entity-name=\"CurrentContract\">\n"
+#~ "    ...\n"
+#~ "    <set name=\"history\" inverse=\"true\"\n"
+#~ "            order-by=\"effectiveEndDate desc\">\n"
+#~ "        <key column=\"currentContractId\"/>\n"
+#~ "        <one-to-many entity-name=\"HistoricalContract\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Contract\" table=\"ContractHistory\"\n"
+#~ "        entity-name=\"HistoricalContract\">\n"
+#~ "    ...\n"
+#~ "    <many-to-one name=\"currentContract\"\n"
+#~ "            column=\"currentContractId\"\n"
+#~ "            entity-name=\"CurrentContract\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Contract\" table=\"Contracts\" \n"
+#~ "        entity-name=\"CurrentContract\"&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;set name=\"history\" inverse=\"true\" \n"
+#~ "            order-by=\"effectiveEndDate desc\"&gt;\n"
+#~ "        &lt;key column=\"currentContractId\"/&gt;\n"
+#~ "        &lt;one-to-many entity-name=\"HistoricalContract\"/&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Contract\" table=\"ContractHistory\" \n"
+#~ "        entity-name=\"HistoricalContract\"&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;many-to-one name=\"currentContract\" \n"
+#~ "            column=\"currentContractId\" \n"
+#~ "            entity-name=\"CurrentContract\"/&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"LineItem\" table=\"`Line Item`\">\n"
+#~ "    <id name=\"id\" column=\"`Item Id`\"/><generator class=\"assigned\"/"
+#~ "></id>\n"
+#~ "    <property name=\"itemNumber\" column=\"`Item #`\"/>\n"
+#~ "    ...\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"LineItem\" table=\"`Line Item`\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"`Item Id`\"/&gt;&lt;generator class="
+#~ "\"assigned\"/&gt;&lt;/id&gt;\n"
+#~ "    &lt;property name=\"itemNumber\" column=\"`Item #`\"/&gt;\n"
+#~ "    ...\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "import java.util.Set;\n"
+#~ "import java.util.Date;\n"
+#~ "\n"
+#~ "/**\n"
+#~ " * @hibernate.class\n"
+#~ " *  table=\"CATS\"\n"
+#~ " */\n"
+#~ "public class Cat {\n"
+#~ "    private Long id; // identifier\n"
+#~ "    private Date birthdate;\n"
+#~ "    private Cat mother;\n"
+#~ "    private Set kittens\n"
+#~ "    private Color color;\n"
+#~ "    private char sex;\n"
+#~ "    private float weight;\n"
+#~ "\n"
+#~ "    /*\n"
+#~ "     * @hibernate.id\n"
+#~ "     *  generator-class=\"native\"\n"
+#~ "     *  column=\"CAT_ID\"\n"
+#~ "     */\n"
+#~ "    public Long getId() {\n"
+#~ "        return id;\n"
+#~ "    }\n"
+#~ "    private void setId(Long id) {\n"
+#~ "        this.id=id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.many-to-one\n"
+#~ "     *  column=\"PARENT_ID\"\n"
+#~ "     */\n"
+#~ "    public Cat getMother() {\n"
+#~ "        return mother;\n"
+#~ "    }\n"
+#~ "    void setMother(Cat mother) {\n"
+#~ "        this.mother = mother;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"BIRTH_DATE\"\n"
+#~ "     */\n"
+#~ "    public Date getBirthdate() {\n"
+#~ "        return birthdate;\n"
+#~ "    }\n"
+#~ "    void setBirthdate(Date date) {\n"
+#~ "        birthdate = date;\n"
+#~ "    }\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"WEIGHT\"\n"
+#~ "     */\n"
+#~ "    public float getWeight() {\n"
+#~ "        return weight;\n"
+#~ "    }\n"
+#~ "    void setWeight(float weight) {\n"
+#~ "        this.weight = weight;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"COLOR\"\n"
+#~ "     *  not-null=\"true\"\n"
+#~ "     */\n"
+#~ "    public Color getColor() {\n"
+#~ "        return color;\n"
+#~ "    }\n"
+#~ "    void setColor(Color color) {\n"
+#~ "        this.color = color;\n"
+#~ "    }\n"
+#~ "    /**\n"
+#~ "     * @hibernate.set\n"
+#~ "     *  inverse=\"true\"\n"
+#~ "     *  order-by=\"BIRTH_DATE\"\n"
+#~ "     * @hibernate.collection-key\n"
+#~ "     *  column=\"PARENT_ID\"\n"
+#~ "     * @hibernate.collection-one-to-many\n"
+#~ "     */\n"
+#~ "    public Set getKittens() {\n"
+#~ "        return kittens;\n"
+#~ "    }\n"
+#~ "    void setKittens(Set kittens) {\n"
+#~ "        this.kittens = kittens;\n"
+#~ "    }\n"
+#~ "    // addKitten not needed by Hibernate\n"
+#~ "    public void addKitten(Cat kitten) {\n"
+#~ "        kittens.add(kitten);\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"SEX\"\n"
+#~ "     *  not-null=\"true\"\n"
+#~ "     *  update=\"false\"\n"
+#~ "     */\n"
+#~ "    public char getSex() {\n"
+#~ "        return sex;\n"
+#~ "    }\n"
+#~ "    void setSex(char sex) {\n"
+#~ "        this.sex=sex;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "package eg;\n"
+#~ "import java.util.Set;\n"
+#~ "import java.util.Date;\n"
+#~ "\n"
+#~ "/**\n"
+#~ " * @hibernate.class\n"
+#~ " *  table=\"CATS\"\n"
+#~ " */\n"
+#~ "public class Cat {\n"
+#~ "    private Long id; // identifier\n"
+#~ "    private Date birthdate;\n"
+#~ "    private Cat mother;\n"
+#~ "    private Set kittens\n"
+#~ "    private Color color;\n"
+#~ "    private char sex;\n"
+#~ "    private float weight;\n"
+#~ "\n"
+#~ "    /*\n"
+#~ "     * @hibernate.id\n"
+#~ "     *  generator-class=\"native\"\n"
+#~ "     *  column=\"CAT_ID\"\n"
+#~ "     */\n"
+#~ "    public Long getId() {\n"
+#~ "        return id;\n"
+#~ "    }\n"
+#~ "    private void setId(Long id) {\n"
+#~ "        this.id=id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.many-to-one\n"
+#~ "     *  column=\"PARENT_ID\"\n"
+#~ "     */\n"
+#~ "    public Cat getMother() {\n"
+#~ "        return mother;\n"
+#~ "    }\n"
+#~ "    void setMother(Cat mother) {\n"
+#~ "        this.mother = mother;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"BIRTH_DATE\"\n"
+#~ "     */\n"
+#~ "    public Date getBirthdate() {\n"
+#~ "        return birthdate;\n"
+#~ "    }\n"
+#~ "    void setBirthdate(Date date) {\n"
+#~ "        birthdate = date;\n"
+#~ "    }\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"WEIGHT\"\n"
+#~ "     */\n"
+#~ "    public float getWeight() {\n"
+#~ "        return weight;\n"
+#~ "    }\n"
+#~ "    void setWeight(float weight) {\n"
+#~ "        this.weight = weight;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"COLOR\"\n"
+#~ "     *  not-null=\"true\"\n"
+#~ "     */\n"
+#~ "    public Color getColor() {\n"
+#~ "        return color;\n"
+#~ "    }\n"
+#~ "    void setColor(Color color) {\n"
+#~ "        this.color = color;\n"
+#~ "    }\n"
+#~ "    /**\n"
+#~ "     * @hibernate.set\n"
+#~ "     *  inverse=\"true\"\n"
+#~ "     *  order-by=\"BIRTH_DATE\"\n"
+#~ "     * @hibernate.collection-key\n"
+#~ "     *  column=\"PARENT_ID\"\n"
+#~ "     * @hibernate.collection-one-to-many\n"
+#~ "     */\n"
+#~ "    public Set getKittens() {\n"
+#~ "        return kittens;\n"
+#~ "    }\n"
+#~ "    void setKittens(Set kittens) {\n"
+#~ "        this.kittens = kittens;\n"
+#~ "    }\n"
+#~ "    // addKitten not needed by Hibernate\n"
+#~ "    public void addKitten(Cat kitten) {\n"
+#~ "        kittens.add(kitten);\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"SEX\"\n"
+#~ "     *  not-null=\"true\"\n"
+#~ "     *  update=\"false\"\n"
+#~ "     */\n"
+#~ "    public char getSex() {\n"
+#~ "        return sex;\n"
+#~ "    }\n"
+#~ "    void setSex(char sex) {\n"
+#~ "        this.sex=sex;\n"
+#~ "    }\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[@Entity(access = AccessType.FIELD)\n"
+#~ "public class Customer implements Serializable {\n"
+#~ "\n"
+#~ "    @Id;\n"
+#~ "    Long id;\n"
+#~ "\n"
+#~ "    String firstName;\n"
+#~ "    String lastName;\n"
+#~ "    Date birthday;\n"
+#~ "\n"
+#~ "    @Transient\n"
+#~ "    Integer age;\n"
+#~ "\n"
+#~ "    @Embedded\n"
+#~ "    private Address homeAddress;\n"
+#~ "\n"
+#~ "    @OneToMany(cascade=CascadeType.ALL)\n"
+#~ "    @JoinColumn(name=\"CUSTOMER_ID\")\n"
+#~ "    Set<Order> orders;\n"
+#~ "\n"
+#~ "    // Getter/setter and business methods\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "@Entity(access = AccessType.FIELD)\n"
+#~ "public class Customer implements Serializable {\n"
+#~ "\n"
+#~ "    @Id;\n"
+#~ "    Long id;\n"
+#~ "\n"
+#~ "    String firstName;\n"
+#~ "    String lastName;\n"
+#~ "    Date birthday;\n"
+#~ "\n"
+#~ "    @Transient\n"
+#~ "    Integer age;\n"
+#~ "\n"
+#~ "    @Embedded\n"
+#~ "    private Address homeAddress;\n"
+#~ "\n"
+#~ "    @OneToMany(cascade=CascadeType.ALL)\n"
+#~ "    @JoinColumn(name=\"CUSTOMER_ID\")\n"
+#~ "    Set&lt;Order&gt; orders;\n"
+#~ "\n"
+#~ "    // Getter/setter and business methods\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "    ...\n"
+#~ "    <database-object>\n"
+#~ "        <create>CREATE TRIGGER my_trigger ...</create>\n"
+#~ "        <drop>DROP TRIGGER my_trigger</drop>\n"
+#~ "    </database-object>\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;database-object&gt;\n"
+#~ "        &lt;create&gt;CREATE TRIGGER my_trigger ...&lt;/create&gt;\n"
+#~ "        &lt;drop&gt;DROP TRIGGER my_trigger&lt;/drop&gt;\n"
+#~ "    &lt;/database-object&gt;\n"
+#~ "&lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "    ...\n"
+#~ "    <database-object>\n"
+#~ "        <definition class=\"MyTriggerDefinition\"/>\n"
+#~ "    </database-object>\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;database-object&gt;\n"
+#~ "        &lt;definition class=\"MyTriggerDefinition\"/&gt;\n"
+#~ "    &lt;/database-object&gt;\n"
+#~ "&lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "    ...\n"
+#~ "    <database-object>\n"
+#~ "        <definition class=\"MyTriggerDefinition\"/>\n"
+#~ "        <dialect-scope name=\"org.hibernate.dialect.Oracle9iDialect\"/>\n"
+#~ "        <dialect-scope name=\"org.hibernate.dialect.Oracle10gDialect\"/>\n"
+#~ "    </database-object>\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;database-object&gt;\n"
+#~ "        &lt;definition class=\"MyTriggerDefinition\"/&gt;\n"
+#~ "        &lt;dialect-scope name=\"org.hibernate.dialect.Oracle9Dialect\"/"
+#~ "&gt;\n"
+#~ "        &lt;dialect-scope name=\"org.hibernate.dialect.OracleDialect\"/"
+#~ "&gt;\n"
+#~ "    &lt;/database-object&gt;\n"
+#~ "&lt;/hibernate-mapping&gt;"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/batch.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/batch.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/batch.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,207 +1,125 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-13 15:16+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: batch.xml:29
 #, no-c-format
 msgid "Batch processing"
 msgstr "バッチ処理"
 
 #. Tag: para
-#: batch.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A naive approach to inserting 100,000 rows in the database using Hibernate "
 "might look like this:"
 msgstr ""
-"Hibernateを使ってデータベースに100,000行を挿入する愚直な方法は、このようなも"
+"Hibernate を使ってデータベースに100,000行を挿入する愚直な方法は、このようなも"
 "のです:"
 
-#. Tag: programlisting
-#: batch.xml:36
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"}\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:38
-#, fuzzy, no-c-format
-msgid ""
 "This would fall over with an <literal>OutOfMemoryException</literal> "
 "somewhere around the 50,000th row. That is because Hibernate caches all the "
 "newly inserted <literal>Customer</literal> instances in the session-level "
 "cache. In this chapter we will show you how to avoid this problem."
 msgstr ""
 "これは50,000番目の行のあたりで <literal>OutOfMemoryException</literal> で失敗"
-"するでしょう。 Hibernateがセッションレベルキャッシュで、 新しく挿入されたすべ"
+"するでしょう。 Hibernate がセッションレベルキャッシュで、新しく挿入されたすべ"
 "ての <literal>Customer</literal> インスタンスをキャッシュするからです。"
 
 #. Tag: para
-#: batch.xml:45
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are undertaking batch processing you will need to enable the use of "
 "JDBC batching. This is absolutely essential if you want to achieve optimal "
 "performance. Set the JDBC batch size to a reasonable number (10-50, for "
 "example):"
 msgstr ""
-"この章では、この問題を回避する方法を紹介します。 しかしバッチ処理をするなら、"
-"JDBCバッチが使用可能であることが非常に重要です。 そうでなければ手頃なパフォー"
-"マンスが得られません。 JDBCバッチサイズを手頃な数値(例えば、10から50)に設定"
-"してください:"
+"この章では、この問題を回避する方法を紹介します。しかしバッチ処理をするなら、 "
+"JDBC バッチが使用可能であることが非常に重要です。そうでなければ手頃なパフォー"
+"マンスが得られません。 JDBC バッチサイズを手頃な数値(例えば、10から50)に設"
+"定してください:"
 
-#. Tag: programlisting
-#: batch.xml:52
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[hibernate.jdbc.batch_size 20]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:54
-#, fuzzy, no-c-format
 msgid ""
 "Hibernate disables insert batching at the JDBC level transparently if you "
 "use an <literal>identity</literal> identifier generator."
 msgstr ""
-"Note that Hibernate disables insert batching at the JDBC level transparently "
-"if you use an <literal>identiy</literal> identifier generator."
+"<literal>identiy</literal> 識別子生成を使う場合は、Hibernate は JDBC レベルで"
+"インサートバッチングを無効にすることに注意してください。"
 
 #. Tag: para
-#: batch.xml:59
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also do this kind of work in a process where interaction with the "
 "second-level cache is completely disabled:"
 msgstr ""
-"また二次キャッシュが全く効かないプロセスで、 このような作業をしたいと思うかも"
+"また二次キャッシュが全く効かないプロセスで、このような作業をしたいと思うかも"
 "しれません:"
 
-#. Tag: programlisting
-#: batch.xml:64
-#, no-c-format
-msgid "<![CDATA[hibernate.cache.use_second_level_cache false]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:66
 #, no-c-format
 msgid ""
 "However, this is not absolutely necessary, since we can explicitly set the "
 "<literal>CacheMode</literal> to disable interaction with the second-level "
 "cache."
 msgstr ""
-"しかし、これは絶対に必要というわけではありません。 なぜなら明示的に "
-"<literal>CacheMode</literal> を設定して、 二次キャッシュとの相互作用を無効に"
-"することができるからです。"
+"しかし、これは絶対に必要というわけではありません。なぜなら明示的に "
+"<literal>CacheMode</literal> を設定して、二次キャッシュとの相互作用を無効にす"
+"ることができるからです。"
 
 #. Tag: title
-#: batch.xml:72
 #, no-c-format
 msgid "Batch inserts"
 msgstr "バッチ挿入"
 
 #. Tag: para
-#: batch.xml:74
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When making new objects persistent <literal>flush()</literal> and then "
 "<literal>clear()</literal> the session regularly in order to control the "
 "size of the first-level cache."
 msgstr ""
-"新しいオブジェクトを永続化するとき、一次キャッシュのサイズを制限するため、 "
+"新しいオブジェクトを永続化するとき、一次キャッシュのサイズを制限するため、"
 "セッションを <literal>flush()</literal> して <literal>clear()</literal> しな"
 "ければなりません。"
 
-#. Tag: programlisting
-#: batch.xml:80
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"    if ( i % 20 == 0 ) { //20, same as the JDBC batch size\n"
-"        //flush a batch of inserts and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: title
-#: batch.xml:85
 #, no-c-format
 msgid "Batch updates"
 msgstr "バッチ更新"
 
 #. Tag: para
-#: batch.xml:87
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For retrieving and updating data, the same ideas apply. In addition, you "
 "need to use <literal>scroll()</literal> to take advantage of server-side "
 "cursors for queries that return many rows of data."
 msgstr ""
-"データを復元したり更新したりするには同じアイディアを適用します。 それに加え"
-"て、データの行を多く返すクエリに対して有効な サーバーサイドのカーソルの利点を"
+"データを復元したり更新したりするには同じアイディアを適用します。それに加え"
+"て、データの行を多く返すクエリに対して有効なサーバーサイドのカーソルの利点を"
 "生かしたければ <literal>scroll()</literal> を使う必要があります。"
 
-#. Tag: programlisting
-#: batch.xml:93
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-"    .setCacheMode(CacheMode.IGNORE)\n"
-"    .scroll(ScrollMode.FORWARD_ONLY);\n"
-"int count=0;\n"
-"while ( customers.next() ) {\n"
-"    Customer customer = (Customer) customers.get(0);\n"
-"    customer.updateStuff(...);\n"
-"    if ( ++count % 20 == 0 ) {\n"
-"        //flush a batch of updates and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: title
-#: batch.xml:98
 #, no-c-format
 msgid "The StatelessSession interface"
-msgstr "StatelessSessionインターフェイス"
+msgstr "StatelessSession インターフェース"
 
 #. Tag: para
-#: batch.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, Hibernate provides a command-oriented API that can be used "
 "for streaming data to and from the database in the form of detached objects. "
@@ -217,54 +135,33 @@
 "effects. A stateless session is a lower-level abstraction that is much "
 "closer to the underlying JDBC."
 msgstr ""
-"また別の方法として、Hibernateはコマンド指向のAPIを用意しています。 これは分離"
-"オブジェクトの形で、 データベースとのデータストリームのやり取りに使うことがで"
-"きます。 <literal>StatelessSession</literal> は関連する永続コンテキストを持た"
-"ず、 高レベルのライフサイクルセマンティクスの多くを提供しません。 特にステー"
-"トレスセッションは、一時キャッシュを実装せず、 またどのような二次キャッシュや"
-"クエリキャッシュとも相互作用しません。 トランザクショナルなwrite-behindや自動"
-"ダーティチェックも実装しません。 ステートレスセッションを使って行われる操作"
-"が、 関連するインスタンスへカスケードされることは決してありません。 コレク"
-"ションは、ステートレスセッションからは無視されます。 ステートレスセッションを"
-"通して行われる操作は、 Hibernateのイベントモデルやインターセプタの影響を受け"
-"ません。 一時キャッシュを持たないため、 ステートレスセッションは別名を持つ"
-"データに上手く対処できません。 ステートレスセッションは低レベルの抽象化であ"
-"り、JDBCに非常によく似ています。"
+"また別の方法として、 Hibernate はコマンド指向の API を用意しています。これは"
+"分離オブジェクトの形で、データベースとのデータストリームのやり取りに使うこと"
+"ができます。 <literal>StatelessSession</literal> は関連する永続コンテキストを"
+"持たず、高レベルのライフサイクルセマンティクスの多くを提供しません。特にス"
+"テートレスセッションは、一次キャッシュを実装せず、またどのような二次キャッ"
+"シュやクエリキャッシュとも相互作用しません。トランザクショナルな write-"
+"behind や自動ダーティチェックも実装しません。ステートレスセッションを使って行"
+"われる操作が、関連するインスタンスへカスケードされることは決してありません。"
+"コレクションは、ステートレスセッションからは無視されます。ステートレスセッ"
+"ションを通して行われる操作は、 Hibernate のイベントモデルやインターセプタの影"
+"響を受けません。一次キャッシュを持たないため、ステートレスセッションは別名を"
+"持つデータに上手く対処できません。ステートレスセッションは低レベルの抽象化で"
+"あり、 JDBC に非常によく似ています。"
 
-#. Tag: programlisting
-#: batch.xml:114
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[StatelessSession session = sessionFactory.openStatelessSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-"    .scroll(ScrollMode.FORWARD_ONLY);\n"
-"while ( customers.next() ) {\n"
-"    Customer customer = (Customer) customers.get(0);\n"
-"    customer.updateStuff(...);\n"
-"    session.update(customer);\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:116
-#, fuzzy, no-c-format
-msgid ""
 "In this code example, the <literal>Customer</literal> instances returned by "
 "the query are immediately detached. They are never associated with any "
 "persistence context."
 msgstr ""
 "このコード例では、クエリが返す <literal>Customer</literal> インスタンスは即座"
-"に(セッションから)分離されることに注意してください。 これは、どのような永続"
-"コンテキストとも決して関連しません。"
+"に (セッションから) 分離されることに注意してください。これは、どのような永"
+"続コンテキストとも決して関連しません。"
 
 #. Tag: para
-#: batch.xml:122
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>insert(), update()</literal> and <literal>delete()</literal> "
 "operations defined by the <literal>StatelessSession</literal> interface are "
@@ -274,21 +171,20 @@
 "<literal>save(), saveOrUpdate()</literal> and <literal>delete()</literal> "
 "operations defined by the <literal>Session</literal> interface."
 msgstr ""
-"<literal>StatelessSession</literal> インターフェイスで定義されている "
-"<literal>insert(), update(), delete()</literal> は、 低レベルの直接的なデータ"
-"ベース操作と考えられます。 結果として、SQLの <literal>INSERT, UPDATE, "
-"DELETE</literal> がそれぞれ即座に実行されます。 このように、これらは "
-"<literal>Session</literal> インターフェイスで定義されている <literal>save(), "
-"saveOrUpdate(), delete()</literal> とは非常に異なる意味を持ちます。"
+"<literal>StatelessSession</literal> インターフェースで定義されている "
+"<literal>insert(), update()</literal> と <literal>delete()</literal> の操作"
+"は、低レベルの直接的なデータベース操作と考えられます。結果として、 SQL の "
+"<literal>INSERT, UPDATE</literal> または <literal>DELETE</literal> がそれぞれ"
+"即座に実行されます。このように、これらは <literal>Session</literal> インター"
+"フェースで定義されている <literal>save(), saveOrUpdate()</literal> と "
+"<literal>delete()</literal> とは非常に異なる意味を持ちます。"
 
 #. Tag: title
-#: batch.xml:135
 #, no-c-format
 msgid "DML-style operations"
-msgstr "DMLスタイルの操作"
+msgstr "DML スタイルの操作"
 
 #. Tag: para
-#: batch.xml:137
 #, fuzzy, no-c-format
 msgid ""
 "As already discussed, automatic and transparent object/relational mapping is "
@@ -302,17 +198,17 @@
 "\">HQL</link>)."
 msgstr ""
 "すでに議論したように、自動的かつ透過的なオブジェクト/リレーショナルマッピング"
-"は、 オブジェクトの状態の管理であると考えられます。 これはメモリ内のオブジェ"
-"クトの状態を利用できるということです。 そのため(SQLの <literal>データ操作言"
-"語</literal> (DML) 文: <literal>INSERT</literal>, <literal>UPDATE</"
-"literal>, <literal>DELETE</literal> を使って)データベース内のデータを直接操"
-"作しても、 メモリ内の状態には影響を与えません。 しかしHibernateは、バルクSQL"
-"スタイルのDML文実行に対応するメソッドを用意しています。 これはHibernateクエリ"
-"言語(<xref linkend=\"queryhql\">HQL</xref>) を通して実行されます。"
+"は、オブジェクトの状態の管理であると考えられます。これはメモリ内のオブジェク"
+"トの状態を利用できるということです。そのため (SQLの <literal>データ操作言語"
+"</literal> (DML) 文: <literal>INSERT</literal>、 <literal>UPDATE</"
+"literal>、 <literal>DELETE</literal> を使って)データベース内のデータを直接操"
+"作しても、メモリ内の状態には影響を与えません。しかし Hibernate は、バルク "
+"SQL スタイルの DML 文実行に対応するメソッドを用意しています。これは "
+"Hibernate クエリ言語 (<xref linkend=\"queryhql\"/> HQL) を通して実行されま"
+"す。"
 
 #. Tag: para
-#: batch.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The pseudo-syntax for <literal>UPDATE</literal> and <literal>DELETE</"
 "literal> statements is: <literal>( UPDATE | DELETE ) FROM? EntityName (WHERE "
@@ -320,87 +216,61 @@
 msgstr ""
 "<literal>UPDATE</literal> と <literal>DELETE</literal> 文の疑似構文は: "
 "<literal>( UPDATE | DELETE ) FROM? エンティティ名 (WHERE 条件節)?</literal> "
-"です。 注意すべき点がいくつかあります:"
+"です。注意すべき点がいくつかあります:"
 
 #. Tag: para
-#: batch.xml:151
 #, no-c-format
 msgid "Some points to note:"
 msgstr ""
 
 #. Tag: para
-#: batch.xml:157
 #, no-c-format
 msgid "In the from-clause, the FROM keyword is optional"
-msgstr "from節において、FROMキーワードはオプションです。"
+msgstr "from 節において、 FROM キーワードはオプションです。"
 
 #. Tag: para
-#: batch.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There can only be a single entity named in the from-clause. It can, however, "
 "be aliased. If the entity name is aliased, then any property references must "
 "be qualified using that alias. If the entity name is not aliased, then it is "
 "illegal for any property references to be qualified."
 msgstr ""
-"from節では単一のエンティティ名だけが可能で、 任意で別名を付けることができま"
-"す。 エンティティ名に別名が与えられると、どのようなプロパティ参照も、 その別"
-"名を使って修飾しなければなりません。 もしエンティティ名に別名が与えられなけれ"
-"ば、 どのようなプロパティ参照も修飾してはなりません。"
+"from 節では単一のエンティティ名だけが可能で、任意で別名を付けることができま"
+"す。エンティティ名に別名が与えられると、どのようなプロパティ参照も、その別名"
+"を使って修飾しなければなりません。もしエンティティ名に別名が与えられなけれ"
+"ば、どのようなプロパティ参照も修飾してはなりません。"
 
 #. Tag: para
-#: batch.xml:170
 #, fuzzy, no-c-format
 msgid ""
 "No <link linkend=\"queryhql-joins-forms\">joins</link>, either implicit or "
 "explicit, can be specified in a bulk HQL query. Sub-queries can be used in "
 "the where-clause, where the subqueries themselves may contain joins."
 msgstr ""
-"(暗黙的であれ明示的であれ)<xref linkend=\"queryhql-joins-forms\">結合</"
-"xref> をバルクHQLクエリ内で指定することはできません。 サブクエリはwhere節で使"
-"うことができます サブクエリそのものは、結合を含められます。"
+"(暗黙的であれ明示的であれ) <xref linkend=\"queryhql-joins-forms\"/> 結合を"
+"バルク HQL クエリ内で指定することはできません。サブクエリは where 節で使うこ"
+"とができます。サブクエリそのものは、結合を含められます。"
 
 #. Tag: para
-#: batch.xml:177
 #, no-c-format
 msgid "The where-clause is also optional."
-msgstr "where節はオプションです。"
+msgstr "where 節はオプションです。"
 
 #. Tag: para
-#: batch.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As an example, to execute an HQL <literal>UPDATE</literal>, use the "
 "<literal>Query.executeUpdate()</literal> method. The method is named for "
 "those familiar with JDBC's <literal>PreparedStatement.executeUpdate()</"
 "literal>:"
 msgstr ""
-"例として、HQLの <literal>UPDATE</literal> を実行するには、 <literal>Query."
-"executeUpdate()</literal> メソッドを使ってください。 (このメソッドはおなじみ"
-"のJDBC <literal>PreparedStatement.executeUpdate()</literal> から名付けられま"
-"した): d"
+"例として、 HQL の <literal>UPDATE</literal> を実行するには、 <literal>Query."
+"executeUpdate()</literal> メソッドを使ってください。(このメソッドはおなじみ"
+"の JDBC <literal>PreparedStatement.executeUpdate()</literal> から名付けられま"
+"した):"
 
-#. Tag: programlisting
-#: batch.xml:189
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlUpdate = \"update Customer c set c.name = :newName where c.name = :"
-"oldName\";\n"
-"// or String hqlUpdate = \"update Customer set name = :newName where name = :"
-"oldName\";\n"
-"int updatedEntities = s.createQuery( hqlUpdate )\n"
-"        .setString( \"newName\", newName )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:191
 #, fuzzy, no-c-format
 msgid ""
 "In keeping with the EJB3 specification, HQL <literal>UPDATE</literal> "
@@ -413,73 +283,38 @@
 "<literal>VERSIONED</literal> keyword after the <literal>UPDATE</literal> "
 "keyword."
 msgstr ""
-"HQLの <literal>UPDATE</literal> 文は、デフォルトでは、作用するエンティティの "
-"<xref linkend=\"mapping-declaration-version\">version</xref> ã‚„ <xref "
-"linkend=\"mapping-declaration-timestamp\">timestamp</xref> プロパティの値には"
-"影響しません。 これはEJB3の仕様にも受け継がれています。 しかし "
+"HQL の <literal>UPDATE</literal> 文は、デフォルトでは、作用するエンティティ"
+"の <xref linkend=\"mapping-declaration-version\"/> バージョンや <xref "
+"linkend=\"mapping-declaration-timestamp\"/> タイムスタンプのプロパティの値に"
+"は影響しません。これは EJB3 の仕様にも受け継がれています。しかし "
 "<literal>versioned update</literal> を使って、 <literal>version</literal> や "
 "<literal>timestamp</literal> プロパティの値を強制的にリセットさせることができ"
-"ます。 これは <literal>UPDATE</literal> キーワードの後に <literal>VERSIONED</"
+"ます。これは <literal>UPDATE</literal> キーワードの後に <literal>VERSIONED</"
 "literal> キーワードを追加することで行えます。"
 
-#. Tag: programlisting
-#: batch.xml:201
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"String hqlVersionedUpdate = \"update versioned Customer set name = :newName "
-"where name = :oldName\";\n"
-"int updatedEntities = s.createQuery( hqlUpdate )\n"
-"        .setString( \"newName\", newName )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:203
-#, fuzzy, no-c-format
-msgid ""
 "Custom version types, <literal>org.hibernate.usertype.UserVersionType</"
 "literal>, are not allowed in conjunction with a <literal>update versioned</"
 "literal> statement."
 msgstr ""
 "カスタムバージョン型(<literal>org.hibernate.usertype.UserVersionType</"
-"literal>) は <literal>update versioned</literal> 文と一緒に使えないことに注"
-"意してください。"
+"literal>)は <literal>update versioned</literal> 文と一緒に使えないことに注意"
+"してください。"
 
 #. Tag: para
-#: batch.xml:208
 #, no-c-format
 msgid ""
 "To execute an HQL <literal>DELETE</literal>, use the same <literal>Query."
 "executeUpdate()</literal> method:"
 msgstr ""
-"HQLの <literal>DELETE</literal> を実行するには、 同じ <literal>Query."
+"HQL の <literal>DELETE</literal> を実行するには、同じ <literal>Query."
 "executeUpdate()</literal> メソッドを使ってください:"
 
-#. Tag: programlisting
-#: batch.xml:213
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlDelete = \"delete Customer c where c.name = :oldName\";\n"
-"// or String hqlDelete = \"delete Customer where name = :oldName\";\n"
-"int deletedEntities = s.createQuery( hqlDelete )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:215
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>int</literal> value returned by the <literal>Query.executeUpdate"
 "()</literal> method indicates the number of entities effected by the "
 "operation. This may or may not correlate to the number of rows effected in "
@@ -492,16 +327,15 @@
 "joined-subclass tables further down the inheritance hierarchy."
 msgstr ""
 "<literal>Query.executeUpdate()</literal> メソッドが返す <literal>int</"
-"literal> の値は、この操作が影響を及ぼしたエンティティの数です。 これが影響す"
-"るデータベース内の行数と、相互に関係するかどうかを考えてみてください。 HQLバ"
-"ルク操作は、結果として、実際のSQL文が複数実行されることになります。 例えば"
-"joined-subclassです。 返される数は、その文によって影響された実際のエンティ"
-"ティの数を示します。 joined-subclassの例に戻ると、サブクラスの一つに対する削"
-"除は、 そのサブクラスがマッピングされたテーブルだけではなく、 「ルート」テー"
-"ブルと継承階層をさらに下ったjoined-subclassのテーブルの削除になります。"
+"literal> の値は、この操作が影響を及ぼしたエンティティの数です。これが影響する"
+"データベース内の行数と、相互に関係するかどうかを考えてみてください。 HQL バル"
+"ク操作は、結果として、実際の SQL 文が複数実行されることになります。例えば "
+"joined-subclass です。返される数は、その文によって影響された実際のエンティ"
+"ティの数を示します。 joined-subclass の例に戻ると、サブクラスの一つに対する削"
+"除は、そのサブクラスがマッピングされたテーブルだけではなく、「ルート」テーブ"
+"ルと継承階層をさらに下った joined-subclass のテーブルの削除になります。"
 
 #. Tag: para
-#: batch.xml:226
 #, no-c-format
 msgid ""
 "The pseudo-syntax for <literal>INSERT</literal> statements is: "
@@ -509,11 +343,9 @@
 "Some points to note:"
 msgstr ""
 "<literal>INSERT</literal> 文の疑似構文は: <literal>INSERT INTO エンティティ"
-"名 プロパティリスト select文</literal> です。 注意すべき点がいくつかありま"
-"す:"
+"名プロパティリスト select 文</literal> です。注意すべき点がいくつかあります:"
 
 #. Tag: para
-#: batch.xml:234
 #, no-c-format
 msgid ""
 "Only the INSERT INTO ... SELECT ... form is supported; not the INSERT "
@@ -523,8 +355,7 @@
 "INTO ... VALUES ... の形式はサポートされていません。"
 
 #. Tag: para
-#: batch.xml:237
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The properties_list is analogous to the <literal>column specification</"
 "literal> in the SQL <literal>INSERT</literal> statement. For entities "
@@ -533,16 +364,15 @@
 "are not allowed and subclass properties do not make sense. In other words, "
 "<literal>INSERT</literal> statements are inherently non-polymorphic."
 msgstr ""
-"プロパティリストは、SQLの <literal>INSERT</literal> 文における <literal>カラ"
-"ムの仕様</literal> に類似しています。 継承のマッピングに含まれるエンティティ"
-"に対して、 クラスレベルで直接定義されたプロパティだけが、プロパティリストに使"
-"えます。 スーパークラスのプロパティは認められず、サブクラスのプロパティは効果"
-"がありません。 言い換えると <literal>INSERT</literal> 文は、本質的にポリモー"
+"プロパティリストは、 SQL の <literal>INSERT</literal> 文における <literal>カ"
+"ラムの仕様</literal> に類似しています。継承のマッピングに含まれるエンティティ"
+"に対して、クラスレベルで直接定義されたプロパティだけが、プロパティリストに使"
+"えます。スーパークラスのプロパティは認められず、サブクラスのプロパティは効果"
+"がありません。言い換えると <literal>INSERT</literal> 文は、本質的にポリモー"
 "フィックではありません。"
 
 #. Tag: para
-#: batch.xml:247
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "select_statement can be any valid HQL select query, with the caveat that the "
 "return types must match the types expected by the insert. Currently, this is "
@@ -555,19 +385,18 @@
 "TimestampType</literal>, even though the database might not make a "
 "distinction or might be able to handle the conversion."
 msgstr ""
-"select文の返り値の型がinsert文が期待する型とマッチしていれば、 そのselect文は"
-"妥当なHQL selectクエリとなりえます。 現在このチェックをデータベースへ任せるの"
-"ではなく、クエリのコンパイル時にチェックします。 このことは、"
-"<emphasis>equal</emphasis>とは違い、 Hibernateの <literal>Type</literal> 間"
-"の <emphasis>equivalent</emphasis> に関する 問題を引き起こすことに注意してく"
-"ださい。 これは <literal>org.hibernate.type.DataType</literal> として定義され"
-"たプロパティと、 <literal>org.hibernate.type.TimestampType</literal> として定"
-"義されたプロパティの間のミスマッチの問題を引き起こします。 データベースがそれ"
-"らを区別できなくても、変換することができても、この問題は発生します。"
+"select 文の返り値の型が insert 文が期待する型とマッチしていれば、その select "
+"文は妥当な HQL select クエリとなりえます。現在このチェックをデータベースへ任"
+"せるのではなく、クエリのコンパイル時にチェックします。このことは、 "
+"<emphasis>equal</emphasis> とは違い、 Hibernate の <literal>Type</literal> 間"
+"の <emphasis>equivalent</emphasis> に関する問題を引き起こすことに注意してくだ"
+"さい。これは <literal>org.hibernate.type.DateType</literal> として定義された"
+"プロパティと、 <literal>org.hibernate.type.TimestampType</literal> として定義"
+"されたプロパティの間のミスマッチの問題を引き起こします。データベースがそれら"
+"を区別できなくても、変換することができても、この問題は発生します。"
 
 #. Tag: para
-#: batch.xml:259
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For the id property, the insert statement gives you two options. You can "
 "either explicitly specify the id property in the properties_list, in which "
@@ -583,21 +412,21 @@
 "TableHiLoGenerator</literal>, which cannot be used because it does not "
 "expose a selectable way to get its values."
 msgstr ""
-"idプロパティに対して、insert文には二つの選択肢があります。 プロパティリストで"
-"明示的にidプロパティを指定するか (この場合、対応するselect式から値が取られま"
-"す)、 プロパティリストから除外するか (この場合、生成される値が使われます)"
-"のいずれかです。 後者の選択肢は、データベース内を操作するidジェネレータを使う"
-"ときのみ、利用可能です。 この選択肢を採る場合、「インメモリ」型のジェネレータ"
-"を使うと、構文解析時に例外が発生します。 この議論では、インデータベース型ジェ"
-"ネレータは <literal>org.hibernate.id.SequenceGenerator</literal> (とそのサブ"
-"クラス)と、<literal>org.hibernate.id.PostInsertIdentifierGenerator</"
-"literal> の実装であると考えています。 ここで最も注意すべき例外は、"
-"<literal>org.hibernate.id.TableHiLoGenerator</literal> です。 値を取得する選"
-"択可能な方法がないため、このジェネレータを使うことはできません。"
+"id プロパティに対して、 insert 文には二つの選択肢があります。プロパティリスト"
+"で明示的に id プロパティを指定するか (この場合、対応する select 式から値が取"
+"られます)、プロパティリストからそれを除外するかのいずれかです (この場合、生"
+"成される値が使われます)。 後者の選択肢は、データベース内を操作する id ジェネ"
+"レータを使うときのみ、利用可能です。この選択肢を採る場合、「インメモリ」型の"
+"ジェネレータを使うと、構文解析時に例外が発生します。この議論では、インデータ"
+"ベース型ジェネレータは <literal>org.hibernate.id.SequenceGenerator</literal> "
+"(とそのサブクラス) と、 <literal>org.hibernate.id."
+"PostInsertIdentifierGenerator</literal> の実装であると考えています。ここで最"
+"も注意すべき例外は、 <literal>org.hibernate.id.TableHiLoGenerator</literal> "
+"です。値を取得する選択可能な方法がないため、このジェネレータを使うことはでき"
+"ません。"
 
 #. Tag: para
-#: batch.xml:274
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For properties mapped as either <literal>version</literal> or "
 "<literal>timestamp</literal>, the insert statement gives you two options. "
@@ -607,31 +436,251 @@
 "defined by the <literal>org.hibernate.type.VersionType</literal> is used."
 msgstr ""
 "<literal>version</literal> や <literal>timestamp</literal> としてマッピングさ"
-"れるプロパティに対して、 insert文には二つの選択肢があります。 プロパティリス"
-"トで明示的にプロパティを指定するか (この場合、対応するselect式から値が取られ"
-"ます)、 プロパティリストから除外するか (この場合、<literal>org.hibernate."
+"れるプロパティに対して、 insert 文には二つの選択肢があります。プロパティリス"
+"トで明示的にプロパティを指定するか(この場合、対応する select 式から値が取ら"
+"れます)、プロパティリストから除外するか(この場合、 <literal>org.hibernate."
 "type.VersionType</literal> で定義された <literal>シード値</literal> が使われ"
 "ます)のいずれかです。"
 
 #. Tag: para
-#: batch.xml:284
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is an example of an HQL <literal>INSERT</literal> statement "
 "execution:"
-msgstr "HQLの <literal>INSERT</literal> 文の実行例です:"
+msgstr "HQL の <literal>INSERT</literal> 文の実行例です:"
 
-#. Tag: programlisting
-#: batch.xml:288
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlInsert = \"insert into DelinquentAccount (id, name) select c.id, c."
-"name from Customer c where ...\";\n"
-"int createdEntities = s.createQuery( hqlInsert )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "for ( int i=0; i<100000; i++ ) {\n"
+#~ "    Customer customer = new Customer(.....);\n"
+#~ "    session.save(customer);\n"
+#~ "}\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "for ( int i=0; i&lt;100000; i++ ) {\n"
+#~ "    Customer customer = new Customer(.....);\n"
+#~ "    session.save(customer);\n"
+#~ "}\n"
+#~ "tx.commit();\n"
+#~ "session.close();"
+
+#, fuzzy
+#~ msgid "<![CDATA[hibernate.jdbc.batch_size 20]]>"
+#~ msgstr "hibernate.jdbc.batch_size 20"
+
+#, fuzzy
+#~ msgid "<![CDATA[hibernate.cache.use_second_level_cache false]]>"
+#~ msgstr "hibernate.cache.use_second_level_cache false"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "for ( int i=0; i<100000; i++ ) {\n"
+#~ "    Customer customer = new Customer(.....);\n"
+#~ "    session.save(customer);\n"
+#~ "    if ( i % 20 == 0 ) { //20, same as the JDBC batch size\n"
+#~ "        //flush a batch of inserts and release memory:\n"
+#~ "        session.flush();\n"
+#~ "        session.clear();\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "for ( int i=0; i&lt;100000; i++ ) {\n"
+#~ "    Customer customer = new Customer(.....);\n"
+#~ "    session.save(customer);\n"
+#~ "    if ( i &#37; 20 == 0 ) { //20, same as the JDBC batch size\n"
+#~ "        //flush a batch of inserts and release memory:\n"
+#~ "        session.flush();\n"
+#~ "        session.clear();\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
+#~ "    .setCacheMode(CacheMode.IGNORE)\n"
+#~ "    .scroll(ScrollMode.FORWARD_ONLY);\n"
+#~ "int count=0;\n"
+#~ "while ( customers.next() ) {\n"
+#~ "    Customer customer = (Customer) customers.get(0);\n"
+#~ "    customer.updateStuff(...);\n"
+#~ "    if ( ++count % 20 == 0 ) {\n"
+#~ "        //flush a batch of updates and release memory:\n"
+#~ "        session.flush();\n"
+#~ "        session.clear();\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
+#~ "    .setCacheMode(CacheMode.IGNORE)\n"
+#~ "    .scroll(ScrollMode.FORWARD_ONLY);\n"
+#~ "int count=0;\n"
+#~ "while ( customers.next() ) {\n"
+#~ "    Customer customer = (Customer) customers.get(0);\n"
+#~ "    customer.updateStuff(...);\n"
+#~ "    if ( ++count &#37; 20 == 0 ) {\n"
+#~ "        //flush a batch of updates and release memory:\n"
+#~ "        session.flush();\n"
+#~ "        session.clear();\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[StatelessSession session = sessionFactory.openStatelessSession"
+#~ "();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
+#~ "    .scroll(ScrollMode.FORWARD_ONLY);\n"
+#~ "while ( customers.next() ) {\n"
+#~ "    Customer customer = (Customer) customers.get(0);\n"
+#~ "    customer.updateStuff(...);\n"
+#~ "    session.update(customer);\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "StatelessSession session = sessionFactory.openStatelessSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
+#~ "    .scroll(ScrollMode.FORWARD_ONLY);\n"
+#~ "while ( customers.next() ) {\n"
+#~ "    Customer customer = (Customer) customers.get(0);\n"
+#~ "    customer.updateStuff(...);\n"
+#~ "    session.update(customer);\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlUpdate = \"update Customer c set c.name = :newName where c.name "
+#~ "= :oldName\";\n"
+#~ "// or String hqlUpdate = \"update Customer set name = :newName where name "
+#~ "= :oldName\";\n"
+#~ "int updatedEntities = s.createQuery( hqlUpdate )\n"
+#~ "        .setString( \"newName\", newName )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlUpdate = \"update Customer c set c.name = :newName where c.name "
+#~ "= :oldName\";\n"
+#~ "// or String hqlUpdate = \"update Customer set name = :newName where name "
+#~ "= :oldName\";\n"
+#~ "int updatedEntities = s.createQuery( hqlUpdate )\n"
+#~ "        .setString( \"newName\", newName )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "String hqlVersionedUpdate = \"update versioned Customer set name = :"
+#~ "newName where name = :oldName\";\n"
+#~ "int updatedEntities = s.createQuery( hqlUpdate )\n"
+#~ "        .setString( \"newName\", newName )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "String hqlVersionedUpdate = \"update versioned Customer set name = :"
+#~ "newName where name = :oldName\";\n"
+#~ "int updatedEntities = s.createQuery( hqlUpdate )\n"
+#~ "        .setString( \"newName\", newName )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlDelete = \"delete Customer c where c.name = :oldName\";\n"
+#~ "// or String hqlDelete = \"delete Customer where name = :oldName\";\n"
+#~ "int deletedEntities = s.createQuery( hqlDelete )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlDelete = \"delete Customer c where c.name = :oldName\";\n"
+#~ "// or String hqlDelete = \"delete Customer where name = :oldName\";\n"
+#~ "int deletedEntities = s.createQuery( hqlDelete )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlInsert = \"insert into DelinquentAccount (id, name) select c."
+#~ "id, c.name from Customer c where ...\";\n"
+#~ "int createdEntities = s.createQuery( hqlInsert )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlInsert = \"insert into DelinquentAccount (id, name) select c."
+#~ "id, c.name from Customer \n"
+#~ "    c where ...\";\n"
+#~ "int createdEntities = s.createQuery( hqlInsert )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/best_practices.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/best_practices.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/best_practices.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,25 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-20 16:59+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: best_practices.xml:29
 #, no-c-format
 msgid "Best Practices"
 msgstr "ベストプラクティス"
 
 #. Tag: term
-#: best_practices.xml:33
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Write fine-grained classes and map them using <literal>&lt;component&gt;</"
 "literal>:"
@@ -27,7 +28,6 @@
 "ましょう。"
 
 #. Tag: para
-#: best_practices.xml:35
 #, no-c-format
 msgid ""
 "Use an <literal>Address</literal> class to encapsulate <literal>street</"
@@ -35,37 +35,33 @@
 "<literal>postcode</literal>. This encourages code reuse and simplifies "
 "refactoring."
 msgstr ""
-"<literal>street</literal>(通り), <literal>suburb</literal> (都市), "
-"<literal>state</literal>(州), <literal>postcode</literal> (郵便番号)をカ"
-"プセル化する <literal>Address</literal>(住所)クラスを使いましょう。 そうす"
-"ればコードが再利用しやすくなり、リファクタリングも簡単になります。"
+"<literal>street</literal> (通り)、 <literal>suburb</literal> (都市)、 "
+"<literal>state</literal> (州)、 <literal>postcode</literal> (郵便番号)を"
+"カプセル化する <literal>Address</literal> (住所)クラスを使いましょう。そう"
+"すればコードが再利用しやすくなり、リファクタリングも簡単になります。"
 
 #. Tag: term
-#: best_practices.xml:43
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Declare identifier properties on persistent classes:"
 msgstr "永続クラスには識別子プロパティを定義しましょう。"
 
 #. Tag: para
-#: best_practices.xml:45
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate makes identifier properties optional. There are a range of reasons "
 "why you should use them. We recommend that identifiers be 'synthetic', that "
 "is, generated with no business meaning."
 msgstr ""
-"Hibernateでは識別子プロパティはオプションですが、 使用すべき理由がたくさんあ"
-"ります。 識別子は「人工的」(生成された、業務的な意味を持たない) なものにす"
-"ることをおすすめします。"
+"Hibernate では識別子プロパティはオプションですが、使用すべき理由がたくさんあ"
+"ります。識別子は「人工的」(生成された、業務的な意味を持たない)なものにする"
+"ことをおすすめします。"
 
 #. Tag: term
-#: best_practices.xml:53
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Identify natural keys:"
 msgstr "自然キーを見つけましょう。"
 
 #. Tag: para
-#: best_practices.xml:55
 #, no-c-format
 msgid ""
 "Identify natural keys for all entities, and map them using <literal>&lt;"
@@ -74,19 +70,17 @@
 "natural key."
 msgstr ""
 "すべてのエンティティに対して自然キーを見つけて、 <literal>&lt;natural-id&gt;"
-"</literal> でマッピングしましょう。 自然キーを構成するプロパティを比較するた"
-"めに、 <literal>equals()</literal> と <literal>hashCode()</literal> を実装し"
-"ましょう。"
+"</literal> でマッピングしましょう。自然キーを構成するプロパティを比較するため"
+"に、 <literal>equals()</literal> と <literal>hashCode()</literal> を実装しま"
+"しょう。"
 
 #. Tag: term
-#: best_practices.xml:63
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Place each class mapping in its own file:"
 msgstr "クラスのマッピングはそれぞれのクラス専用のファイルに書きましょう。"
 
 #. Tag: para
-#: best_practices.xml:65
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not use a single monolithic mapping document. Map <literal>com.eg.Foo</"
 "literal> in the file <literal>com/eg/Foo.hbm.xml</literal>. This makes "
@@ -94,85 +88,75 @@
 msgstr ""
 "単一の巨大なマッピングドキュメントを使用しないでください。 <literal>com.eg."
 "Foo</literal> クラスなら <literal>com/eg/Foo.hbm.xml</literal> ファイルにマッ"
-"ピングしましょう。 このことは、特にチームでの開発に意味があります。"
+"ピングしましょう。このことは、特にチームでの開発に意味があります。"
 
 #. Tag: term
-#: best_practices.xml:73
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Load mappings as resources:"
 msgstr "リソースとしてマッピングをロードしましょう。"
 
 #. Tag: para
-#: best_practices.xml:75
 #, no-c-format
 msgid "Deploy the mappings along with the classes they map."
-msgstr "マッピングを、それらがマッピングするするクラスと一緒に配置しましょう。"
+msgstr "マッピングを、それらがマッピングするクラスと一緒に配置しましょう。"
 
 #. Tag: term
-#: best_practices.xml:81
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Consider externalizing query strings:"
 msgstr "クエリ文字列を外部に置くことを考えましょう"
 
 #. Tag: para
-#: best_practices.xml:83
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is recommended if your queries call non-ANSI-standard SQL functions. "
 "Externalizing the query strings to mapping files will make the application "
 "more portable."
 msgstr ""
-"クエリがANSI標準でないSQL関数を呼んでいるなら、これはよいプラクティスです。 "
-"クエリ文字列をマッピングファイルへ外出しすればアプリケーションがポータブルに"
-"なります。"
+"クエリが ANSI 標準でない SQL 関数を呼んでいるなら、これはよいプラクティスで"
+"す。クエリ文字列をマッピングファイルへ外出しすればアプリケーションがポータブ"
+"ルになります。"
 
 #. Tag: term
-#: best_practices.xml:91
 #, no-c-format
 msgid "Use bind variables."
 msgstr "バインド変数を使いましょう。"
 
 #. Tag: para
-#: best_practices.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As in JDBC, always replace non-constant values by \"?\". Do not use string "
 "manipulation to bind a non-constant value in a query. You should also "
 "consider using named parameters in queries."
 msgstr ""
-"JDBCの場合と同じように、定数でない値は必ず\"?\"で置き換えましょう。 定数でな"
-"い値をバインドするために、クエリで文字列操作を使ってはいけません。 名前付きの"
-"パラメータを使うようにするとさらに良いです。"
+"JDBC の場合と同じように、定数でない値は必ず \"?\" で置き換えましょう。定数で"
+"ない値をバインドするために、クエリで文字列操作を使ってはいけません。名前付き"
+"のパラメータを使うようにするとさらに良いです。"
 
 #. Tag: term
-#: best_practices.xml:101
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Do not manage your own JDBC connections:"
-msgstr "JDBCコネクションを管理してはいけません。"
+msgstr "JDBC コネクションを管理してはいけません。"
 
 #. Tag: para
-#: best_practices.xml:103
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate allows the application to manage JDBC connections, but his "
 "approach should be considered a last-resort. If you cannot use the built-in "
 "connection providers, consider providing your own implementation of "
 "<literal>org.hibernate.connection.ConnectionProvider</literal>."
 msgstr ""
-"HibernateではアプリケーションがJDBCコネクションを管理することが許されていま"
-"す。 しかしこれは最終手段だと思ってください。 組み込みのコネクションプロバイ"
+"Hibernate ではアプリケーションが JDBC コネクションを管理することが許されてい"
+"ます。しかしこれは最終手段だと思ってください。組み込みのコネクションプロバイ"
 "ダを使うことができなければ、 <literal>org.hibernate.connection."
 "ConnectionProvider</literal> を実装することを考えてください。"
 
 #. Tag: term
-#: best_practices.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Consider using a custom type:"
 msgstr "カスタム型の使用を考えましょう。"
 
 #. Tag: para
-#: best_practices.xml:113
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Suppose you have a Java type from a library that needs to be persisted but "
 "does not provide the accessors needed to map it as a component. You should "
@@ -180,47 +164,44 @@
 "approach frees the application code from implementing transformations to/"
 "from a Hibernate type."
 msgstr ""
-"あるライブラリから持ってきたJava型を永続化する必要があるとしましょう。 しかし"
-"その型には、コンポーネントとしてマッピングするために必要なアクセサがないとし"
-"ます。 このような場合は <literal>org.hibernate.UserType</literal> の実装を考"
-"えるべきです。 そうすればHibernate型との実装変換を心配せずにアプリケーション"
+"あるライブラリから持ってきた Java 型を永続化する必要があるとしましょう。しか"
+"しその型には、コンポーネントとしてマッピングするために必要なアクセサがないと"
+"します。このような場合は <literal>org.hibernate.UserType</literal> の実装を考"
+"えるべきです。そうすれば Hibernate 型との実装変換を心配せずにアプリケーション"
 "のコードを扱えます。"
 
 #. Tag: term
-#: best_practices.xml:122
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Use hand-coded JDBC in bottlenecks:"
-msgstr "ボトルネックを解消するにはJDBCをハンドコードしましょう。"
+msgstr "ボトルネックを解消するには JDBC をハンドコードしましょう。"
 
 #. Tag: para
-#: best_practices.xml:124
 #, fuzzy, no-c-format
 msgid ""
 "In performance-critical areas of the system, some kinds of operations might "
 "benefit from direct JDBC. Do not assume, however, that JDBC is necessarily "
 "faster. Please wait until you <emphasis>know</emphasis> something is a "
 "bottleneck. If you need to use direct JDBC, you can open a Hibernate "
-"<literal>Session</literal> and usingfile:///usr/share/doc/HTML/en-US/index."
-"html that JDBC connection. This way you can still use the same transaction "
-"strategy and underlying connection provider."
+"<literal>Session</literal>, wrap your JDBC operation as a <literal>org."
+"hibernate.jdbc.Work</literal> object and using that JDBC connection. This "
+"way you can still use the same transaction strategy and underlying "
+"connection provider."
 msgstr ""
-"システムのパフォーマンスクリティカルな領域では、 ある種の操作にJDBCを直接使う"
-"と良いかもしれません。 しかし何がボトルネックになっているか <emphasis>はっき"
-"りする</emphasis> までは待ってください。 またJDBCを直接使うからといって、必ず"
-"しも速くなるとは限らないことも理解してください。 JDBCを直接使う必要があれば、"
-"Hibernateの <literal>Session</literal> をオープンして、 JDBCコネクションを使"
-"うと良いかもしれません。 依然として同じトランザクション戦略とコネクションプロ"
-"バイダが使えるからです。"
+"システムのパフォーマンスクリティカルな領域では、ある種の操作に JDBC を直接使"
+"うと良いかもしれません。しかし何がボトルネックになっているか <emphasis>はっき"
+"りする</emphasis> までは待ってください。また JDBC を直接使うからといって、必"
+"ずしも速くなるとは限らないことも理解してください。 JDBC を直接使う必要があれ"
+"ば、 Hibernate の <literal>Session</literal> をオープンして、  JDBC コネク"
+"ションを使うと良いかもしれません。依然として同じトランザクション戦略とコネク"
+"ションプロバイダが使えるからです。"
 
 #. Tag: term
-#: best_practices.xml:134
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Understand <literal>Session</literal> flushing:"
 msgstr "<literal>Session</literal> のフラッシュを理解しましょう。"
 
 #. Tag: para
-#: best_practices.xml:136
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes the Session synchronizes its persistent state with the database. "
 "Performance will be affected if this process occurs too often. You can "
@@ -228,20 +209,18 @@
 "even by changing the order of queries and other operations within a "
 "particular transaction."
 msgstr ""
-"Sessionが永続状態をデータベースと同期させることがときどきあります。 しかしこ"
-"れがあまりに頻繁に起こるようだと、パフォーマンスに影響が出てきます。 自動フ"
+"Session が永続状態をデータベースと同期させることがときどきあります。しかしこ"
+"れがあまりに頻繁に起こるようだと、パフォーマンスに影響が出てきます。自動フ"
 "ラッシュを無効にしたり、特定のトランザクションのクエリや操作の順番を変更する"
-"ことで、 不必要なフラッシュを最小限にできます。"
+"ことで、不必要なフラッシュを最小限にできます。"
 
 #. Tag: term
-#: best_practices.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "In a three tiered architecture, consider using detached objects:"
 msgstr "3層アーキテクチャでは分離オブジェクトの使用を考えましょう。"
 
 #. Tag: para
-#: best_practices.xml:147
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When using a servlet/session bean architecture, you can pass persistent "
 "objects loaded in the session bean to and from the servlet/JSP layer. Use a "
@@ -249,21 +228,19 @@
 "or <literal>Session.saveOrUpdate()</literal> to synchronize objects with the "
 "database."
 msgstr ""
-"サーブレット / セッションビーンアーキテクチャを使うとき、 サーブレット層 / "
-"JSP層間でセッションビーンでロードした永続オブジェクトをやり取りできます。 そ"
-"の際リクエストごとに新しいSessionを使ってください。 また <literal>Session."
+"サーブレット / セッション Bean アーキテクチャを使うとき、サーブレット層 / "
+"JSP 層間でセッション Bean でロードした永続オブジェクトをやり取りできます。そ"
+"の際リクエストごとに新しい Session を使ってください。また <literal>Session."
 "merge()</literal> や <literal>Session.saveOrUpdate()</literal> を使って、オブ"
 "ジェクトとデータベースを同期させてください。"
 
 #. Tag: term
-#: best_practices.xml:156
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "In a two tiered architecture, consider using long persistence contexts:"
 msgstr "2層アーキテクチャでは長い永続コンテキストの使用を考えましょう。"
 
 #. Tag: para
-#: best_practices.xml:158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Database Transactions have to be as short as possible for best scalability. "
 "However, it is often necessary to implement long running "
@@ -278,28 +255,26 @@
 "across more than one application transaction or you will be working with "
 "stale data."
 msgstr ""
-"最高のスケーラビリティを得るには、 データベーストランザクションをできるだけ短"
-"くしなければなりません。 しかし長い間実行する <emphasis>アプリケーショントラ"
-"ンザクション</emphasis> の実装が必要なことはしばしばです。 これはユーザの視点"
-"からは1個の作業単位(unit of work)になります。 アプリケーショントランザク"
-"ションはいくつかのクライアントのリクエスト/レスポンスサイクルにまたがりま"
-"す。 アプリケーショントランザクションの実装に分離オブジェクトを使うのは一般的"
-"です。 そうでなければ、2層アーキテクチャの場合は特に適切なことですが、 アプリ"
-"ケーショントランザクションのライフサイクル全体に対して 単一のオープンな永続化"
-"コンテキスト(セッション)を維持してください。 そして単純にリクエストの最後に"
-"JDBCコネクションから切断し、 次のリクエストの最初に再接続します。 決して複数"
-"のアプリケーショントランザクションユースケースに渡って 1個のSessionを使い回さ"
-"ないでください。 そうでなければ、古いデータで作業することになります。"
+"最高のスケーラビリティを得るには、データベーストランザクションをできるだけ短"
+"くしなければなりません。しかし長い間実行する <emphasis>アプリケーショントラン"
+"ザクション</emphasis> の実装が必要なことはしばしばです。これはユーザーの視点"
+"からは1個の作業単位(unit of work)になります。アプリケーショントランザクショ"
+"ンはいくつかのクライアントのリクエスト/レスポンスサイクルにまたがります。アプ"
+"リケーショントランザクションの実装に分離オブジェクトを使うのは一般的です。そ"
+"うでなければ、2層アーキテクチャの場合は特に適切なことですが、アプリケーション"
+"トランザクションのライフサイクル全体に対して単一のオープンな永続化コンテキス"
+"ト(セッション)を維持してください。そして単純にリクエストの最後に JDBC コネ"
+"クションから切断し、次のリクエストの最初に再接続します。決して複数のアプリ"
+"ケーショントランザクションユースケースに渡って1個の Session を使い回さないで"
+"ください。そうでなければ、古いデータで作業することになります。"
 
 #. Tag: term
-#: best_practices.xml:172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Do not treat exceptions as recoverable:"
 msgstr "例外を復帰可能なものとして扱ってはいけません。"
 
 #. Tag: para
-#: best_practices.xml:174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is more of a necessary practice than a \"best\" practice. When an "
 "exception occurs, roll back the <literal>Transaction</literal> and close the "
@@ -309,23 +284,21 @@
 "instance with the given identifier exists on the database; use "
 "<literal>Session.get()</literal> or a query instead."
 msgstr ""
-"これは「ベスト」プラクティス以上の、必須のプラクティスです。 例外が発生したと"
+"これは「ベスト」プラクティス以上の、必須のプラクティスです。例外が発生したと"
 "きは <literal>Transaction</literal> をロールバックして、 <literal>Session</"
-"literal> をクローズしてください。 そうしないとHibernateはメモリの状態が永続状"
-"態を正確に表現していることを保証できません。 この特別な場合として、与えられた"
-"識別子を持つインスタンスがデータベースに存在するかどうかを判定するために、 "
-"<literal>Session.load()</literal> を使うことはやめてください。 その代わりに "
+"literal> をクローズしてください。そうしないと Hibernate はメモリの状態が永続"
+"状態を正確に表現していることを保証できません。この特別な場合として、与えられ"
+"た識別子を持つインスタンスがデータベースに存在するかどうかを判定するために、 "
+"<literal>Session.load()</literal> を使うことはやめてください。その代わりに "
 "<literal>Session.get()</literal> かクエリを使ってください。"
 
 #. Tag: term
-#: best_practices.xml:184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Prefer lazy fetching for associations:"
 msgstr "関連にはなるべく遅延フェッチを使いましょう。"
 
 #. Tag: para
-#: best_practices.xml:186
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use eager fetching sparingly. Use proxies and lazy collections for most "
 "associations to classes that are not likely to be completely held in the "
@@ -335,27 +308,26 @@
 "to a particular use case, use a query with a <literal>left join fetch</"
 "literal>."
 msgstr ""
-"即時フェッチは控えめにしましょう。 二次キャッシュには完全に保持されないような"
-"クラスの関連には、 プロキシと遅延コレクションを使ってください。 キャッシュさ"
-"れるクラスの関連、つまりキャッシュがヒットする可能性が非常に高い関連は、 "
+"即時フェッチは控えめにしましょう。二次キャッシュには完全に保持されないような"
+"クラスの関連には、プロキシと遅延コレクションを使ってください。キャッシュされ"
+"るクラスの関連、つまりキャッシュがヒットする可能性が非常に高い関連は、 "
 "<literal>lazy=\"false\"</literal> で積極的なフェッチを明示的に無効にしてくだ"
-"さい。 結合フェッチが適切な特定のユースケースには、 クエリで <literal>left "
+"さい。結合フェッチが適切な特定のユースケースには、クエリで <literal>left "
 "join fetch</literal> を使ってください。"
 
 #. Tag: term
-#: best_practices.xml:196
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use the <emphasis>open session in view</emphasis> pattern, or a disciplined "
 "<emphasis>assembly phase</emphasis> to avoid problems with unfetched data:"
 msgstr ""
 "フェッチされていないデータに関わる問題を避けるために、 <emphasis>ビューの中で"
-"オープンセッションを使う(open session in view)</emphasis> パターンか、統制さ"
-"れた <emphasis>組み立てフェーズ(assembly phase)</emphasis> を使いましょう。"
+"オープンセッションを使う (open session in view) </emphasis> パターンか、統制"
+"された <emphasis>組み立てフェーズ (assembly phase) </emphasis> を使いましょ"
+"う。"
 
 #. Tag: para
-#: best_practices.xml:201
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate frees the developer from writing tedious <emphasis>Data Transfer "
 "Objects</emphasis> (DTO). In a traditional EJB architecture, DTOs serve dual "
@@ -370,27 +342,25 @@
 "objects. This is not a limitation of Hibernate. It is a fundamental "
 "requirement of safe transactional data access."
 msgstr ""
-"Hibernateは <emphasis>Data Transfer Objects</emphasis> (DTO)を書く退屈な作業"
-"から開発者を解放します。 伝統的なEJBアーキテクチャではDTOは二つ目的がありま"
-"す: 1つ目は、エンティティビーンがシリアライズされない問題への対策です。 2つ"
-"目は、プレゼンテーション層に制御が戻る前に、 ビューに使われるすべてのデータが"
-"フェッチされて、DTOに復元されるような組み立てフェーズを暗黙的に定義します。 "
-"Hibernateでは1つ目の目的が不要になります。 しかしビューのレンダリング処理の"
-"間、永続コンテキスト(セッション)をオープンにしたままにしなければ、 組み立て"
-"フェーズはまだ必要です(分離オブジェクトの中のどのデータが利用可能かについ"
-"て、 プレゼンテーション層と厳密な取り決めをしているビジネスメソッドを考えてみ"
-"てください)。 これはHibernate側の問題ではありません。 トランザクション内で安"
-"全にデータアクセスするための基本的な要件です。"
+"Hibernate は <emphasis>Data Transfer Objects</emphasis> (DTO) を書く退屈な作"
+"業から開発者を解放します。伝統的な EJB アーキテクチャでは DTO は2つ目的があり"
+"ます: 1つ目は、エンティティ Bean がシリアライズされない問題への対策です。2つ"
+"目は、プレゼンテーション層に制御が戻る前に、ビューに使われるすべてのデータが"
+"フェッチされて、 DTO に復元されるような組み立てフェーズを暗黙的に定義しま"
+"す。 Hibernate では1つ目の目的が不要になります。しかしビューのレンダリング処"
+"理の間、永続コンテキスト(セッション)をオープンにしたままにしなければ、組み"
+"立てフェーズはまだ必要です(分離オブジェクトの中のどのデータが利用可能かにつ"
+"いて、プレゼンテーション層と厳密な取り決めをしているビジネスメソッドを考えて"
+"みてください)。これは Hibernate 側の問題ではありません。トランザクション内で"
+"安全にデータアクセスするための基本的な要件です。"
 
 #. Tag: term
-#: best_practices.xml:215
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Consider abstracting your business logic from Hibernate:"
-msgstr "Hibernateからビジネスロジックを抽象化することを考えましょう。"
+msgstr "Hibernate からビジネスロジックを抽象化することを考えましょう。"
 
 #. Tag: para
-#: best_practices.xml:217
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hide Hibernate data-access code behind an interface. Combine the "
 "<emphasis>DAO</emphasis> and <emphasis>Thread Local Session</emphasis> "
@@ -399,22 +369,20 @@
 "however, intended for \"sufficiently large\" applications. It is not "
 "appropriate for an application with five tables."
 msgstr ""
-"インターフェイスで(Hibernateの)データアクセスコードを隠蔽しましょう。 "
+"インターフェースで(Hibernate の)データアクセスコードを隠蔽しましょう。 "
 "<emphasis>DAO</emphasis> と <emphasis>Thread Local Session</emphasis> パター"
-"ンを組み合わせましょう。 <literal>UserType</literal> でHibernateに関連付ける"
-"と、 ハンドコードしたJDBCで永続化するクラスを持つこともできます。 (このアド"
-"バイスは「十分大きな」アプリケーションに対してのものです。 テーブルが5個しか"
+"ンを組み合わせましょう。 <literal>UserType</literal> で Hibernate に関連付け"
+"ると、ハンドコードした JDBC で永続化するクラスを持つこともできます。(このア"
+"ドバイスは「十分大きな」アプリケーションに対してのものです。テーブルが5個しか"
 "ないようなアプリケーションには当てはまりません。)"
 
 #. Tag: term
-#: best_practices.xml:227
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Do not use exotic association mappings:"
 msgstr "珍しい関連マッピングは使わないようにしましょう。"
 
 #. Tag: para
-#: best_practices.xml:229
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Practical test cases for real many-to-many associations are rare. Most of "
 "the time you need additional information stored in the \"link table\". In "
@@ -423,25 +391,22 @@
 "to-one. For this reason, you should proceed cautiously when using any other "
 "association style."
 msgstr ""
-"よいユースケースに本当の多対多関連があることは稀(まれ)です。 ほとんどの場合"
-"「リンクテーブル」の付加的な情報が必要になります。 この場合、リンククラスに2"
-"つの1対多関連を使う方がずっと良いです。 実際ほとんどの場合関連は1対多と多対1"
-"なので、 他のスタイルの関連を使うときは本当に必要かどうかを考えてみてくださ"
-"い。"
+"よいユースケースに本当の多対多関連があることは稀です。ほとんどの場合「リンク"
+"テーブル」の付加的な情報が必要になります。この場合、リンククラスに2つの一対多"
+"関連を使う方がずっとよいです。実際ほとんどの場合、関連は一対多と多対一なの"
+"で、他のスタイルの関連を使うときは本当に必要かどうかを考えてみてください。"
 
 #. Tag: term
-#: best_practices.xml:239
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Prefer bidirectional associations:"
 msgstr "なるべく双方向関連にしましょう。"
 
 #. Tag: para
-#: best_practices.xml:241
 #, no-c-format
 msgid ""
 "Unidirectional associations are more difficult to query. In a large "
 "application, almost all associations must be navigable in both directions in "
 "queries."
 msgstr ""
-"単方向関連は双方向に比べて検索が難しくなります。 大きなアプリケーションで"
-"は、 ほとんどすべての関連が双方向にナビゲーションできなければなりません。"
+"単方向関連は双方向に比べて検索が難しくなります。大きなアプリケーションでは、"
+"ほとんどすべての関連が双方向にナビゲーションできなければなりません。"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/bibliography.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/bibliography.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/bibliography.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -5,7 +5,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: 2009-07-14 19:55+0000\n"
 "Last-Translator: Automatically generated\n"
 "Language-Team: none\n"
@@ -14,55 +14,36 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: bibliography.xml:27
 #, no-c-format
 msgid "References"
 msgstr ""
 
 #. Tag: title
-#: bibliography.xml:31
 #, no-c-format
 msgid "Patterns of Enterprise Application Architecture"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:34
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Martin</firstname> <surname>Fowler</surname>"
+msgid "Martin"
 msgstr ""
 
-#. Tag: holder
-#: bibliography.xml:41
-#, no-c-format
-msgid "Pearson Education, Inc."
-msgstr ""
-
 #. Tag: title
-#: bibliography.xml:50
 #, no-c-format
 msgid "Java Persistence with Hibernate"
 msgstr ""
 
 #. Tag: subtitle
-#: bibliography.xml:51
 #, no-c-format
 msgid "Second Edition of Hibernate in Action"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:57
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Christian</firstname> <surname>Bauer</surname>"
+msgid "Christian"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:61
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Gavin</firstname> <surname>King</surname>"
+msgid "Gavin"
 msgstr ""
-
-#. Tag: holder
-#: bibliography.xml:68
-#, no-c-format
-msgid "Manning Publications Co."
-msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/collection_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/collection_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/collection_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,56 +1,40 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2010-01-06 16:08+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: collection_mapping.xml:29
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Collection mapping"
 msgstr "コレクションのマッピング"
 
 #. Tag: title
-#: collection_mapping.xml:32
 #, no-c-format
 msgid "Persistent collections"
 msgstr "コレクションの永続化"
 
 #. Tag: para
-#: collection_mapping.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate requires that persistent collection-valued fields be declared as "
 "an interface type. For example:"
 msgstr ""
-"コレクション型のフィールドを永続化するには、 そのコレクション型がインターフェ"
-"イス型である必要があります。 例えば、"
+"コレクション型のフィールドを永続化するには、そのコレクション型がインター"
+"フェース型である必要があります。例えば、"
 
-#. Tag: programlisting
-#: collection_mapping.xml:39
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[public class Product {\n"
-"    private String serialNumber;\n"
-"    private Set parts = new HashSet();\n"
-"    \n"
-"    public Set getParts() { return parts; }\n"
-"    void setParts(Set parts) { this.parts = parts; }\n"
-"    public String getSerialNumber() { return serialNumber; }\n"
-"    void setSerialNumber(String sn) { serialNumber = sn; }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:41
-#, fuzzy, no-c-format
-msgid ""
 "The actual interface might be <literal>java.util.Set</literal>, "
 "<literal>java.util.Collection</literal>, <literal>java.util.List</literal>, "
 "<literal>java.util.Map</literal>, <literal>java.util.SortedSet</literal>, "
@@ -58,17 +42,16 @@
 "like\" means you will have to write an implementation of <literal>org."
 "hibernate.usertype.UserCollectionType</literal>.)"
 msgstr ""
-"実在するインターフェイスには <literal>java.util.Set</literal>、 "
-"<literal>java.util.Collection</literal>、<literal>java.util.List</literal>、 "
-"<literal>java.util.Map</literal>、<literal>java.util.SortedSet</literal>、 "
-"<literal>java.util.SortedMap</literal> などがあります。 または、任意のイン"
-"ターフェイスが使えます! (ただし、任意のインターフェイスを使用する場合は、 "
-"<literal>org.hibernate.usertype.UserCollectionType</literal> の実装クラスを作"
-"成する必要があります。)"
+"実在するインターフェースには <literal>java.util.Set</literal>、 "
+"<literal>java.util.Collection</literal>、 <literal>java.util.List</"
+"literal>、 <literal>java.util.Map</literal>、 <literal>java.util.SortedSet</"
+"literal>、 <literal>java.util.SortedMap</literal> などがあります。または、任"
+"意のインターフェースが使えます。 (ただし、「任意のインターフェース」を使用す"
+"る場合は、 <literal>org.hibernate.usertype.UserCollectionType</literal> の実"
+"装クラスを作成する必要があります。)"
 
 #. Tag: para
-#: collection_mapping.xml:50
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Notice how the instance variable was initialized with an instance of "
 "<literal>HashSet</literal>. This is the best way to initialize collection "
@@ -78,46 +61,29 @@
 "an instance of Hibernate's own implementation of <literal>Set</literal>. Be "
 "aware of the following errors:"
 msgstr ""
-"<literal>HashSet</literal> のインスタンスを持つインスタンス変数が どのように"
-"初期化されるかに注目してみましょう。 これは新たに生成された(永続化されていな"
-"い)コレクション型のプロパティを 初期化する最適な方法です。 (例えば "
+"<literal>HashSet</literal> のインスタンスを持つインスタンス変数がどのように初"
+"期化されるかに注目してみましょう。これは新たに生成された(永続化されていな"
+"い)コレクション型のプロパティを初期化する最適な方法です。 (例えば "
 "<literal>persist()</literal> により)インスタンスを永続化しようとしたとき、 "
-"Hibernateは <literal>HashSet</literal> をHibernate独自の <literal>Set</"
-"literal> の実装クラスに置き換えます。 このため、次のようなエラーには注意が必"
-"要です。"
+"Hibernate は <literal>HashSet</literal> を Hibernate 独自の <literal>Set</"
+"literal> の実装クラスに置き換えます。このため、次のようなエラーには注意が必要"
+"です。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:60
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Cat cat = new DomesticCat();\n"
-"Cat kitten = new DomesticCat();\n"
-"....\n"
-"Set kittens = new HashSet();\n"
-"kittens.add(kitten);\n"
-"cat.setKittens(kittens);\n"
-"session.persist(cat);\n"
-"kittens = cat.getKittens(); // Okay, kittens collection is a Set\n"
-"(HashSet) cat.getKittens(); // Error!]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:62
-#, fuzzy, no-c-format
-msgid ""
 "The persistent collections injected by Hibernate behave like "
 "<literal>HashMap</literal>, <literal>HashSet</literal>, <literal>TreeMap</"
 "literal>, <literal>TreeSet</literal> or <literal>ArrayList</literal>, "
 "depending on the interface type."
 msgstr ""
-"Hibernateにより注入された永続性コレクションは、インターフェイス型に応じて、 "
+"Hibernate により注入された永続性コレクションは、インターフェース型に応じて、 "
 "<literal>HashMap</literal> や <literal>HashSet</literal>、 <literal>TreeMap</"
 "literal>、 <literal>TreeSet</literal>、 <literal>ArrayList</literal> のように"
 "振舞います。"
 
 #. Tag: para
-#: collection_mapping.xml:69
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collections instances have the usual behavior of value types. They are "
 "automatically persisted when referenced by a persistent object and are "
@@ -128,74 +94,56 @@
 "properties do not support null value semantics. Hibernate does not "
 "distinguish between a null collection reference and an empty collection."
 msgstr ""
-"コレクションインスタンスは、値型として普通に振舞います。 永続化オブジェクトに"
-"参照されたときに自動的に永続化され、 参照がなくなったときに自動的に削除されま"
-"す。 もしある永続化オブジェクトから別の永続化オブジェクトに渡されたら、 その"
-"要素は現在のテーブルから別のテーブルに移動するかもしれません。 2つのエンティ"
-"ティが同じコレクションインスタンスを共有してはいけません。 リレーショナルモデ"
-"ルをベースにしているため、コレクション型のプロパティに null値を代入しても意味"
-"がありません。 つまりHibernateは参照先のないコレクションと空のコレクションを"
-"区別しません。"
+"コレクションインスタンスは、値型として普通に振舞います。永続化オブジェクトに"
+"参照されたときに自動的に永続化され、参照がなくなったときに自動的に削除されま"
+"す。もしある永続化オブジェクトから別の永続化オブジェクトに渡されたら、その要"
+"素は現在のテーブルから別のテーブルに移動するかもしれません。2つのエンティ"
+"ティが同じコレクションインスタンスを共有してはいけません。リレーショナルモデ"
+"ルをベースにしているため、コレクション型のプロパティに null 値を代入しても意"
+"味がありません。つまり Hibernate は参照先のないコレクションと空のコレクション"
+"を区別しません。"
 
 #. Tag: para
-#: collection_mapping.xml:80
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use persistent collections the same way you use ordinary Java collections. "
 "However, please ensure you understand the semantics of bidirectional "
 "associations (these are discussed later)."
 msgstr ""
-"しかしそれほど心配しなくても構いません。 普段使っているJavaのコレクションと同"
-"じように、永続化コレクションを使ってください。 双方向関連の意味を理解すればよ"
-"いのです(これは後ほど説明します)。"
+"しかしそれほど心配しなくても構いません。普段使っている Java のコレクションと"
+"同じように、永続化コレクションを使ってください。双方向関連の意味を理解すれば"
+"よいのです(これは後ほど説明します)。"
 
 #. Tag: title
-#: collection_mapping.xml:89
 #, no-c-format
 msgid "Collection mappings"
 msgstr "コレクションのマッピング"
 
 #. Tag: para
-#: collection_mapping.xml:92
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are quite a range of mappings that can be generated for collections "
 "that cover many common relational models. We suggest you experiment with the "
 "schema generation tool so that you understand how various mapping "
 "declarations translate to database tables."
 msgstr ""
-"多くの一般的なリレーショナルモデルをカバーしたために、 コレクションのために利"
-"用できるマッピングにはかなりの幅があります。 様々なマッピング宣言がどのように"
-"データベーステーブルに変換されるかを知るために、 スキーマ生成ツールを使ってみ"
+"多くの一般的なリレーショナルモデルをカバーしたために、コレクションのために利"
+"用できるマッピングにはかなりの幅があります。様々なマッピング宣言がどのように"
+"データベーステーブルに変換されるかを知るために、スキーマ生成ツールを使ってみ"
 "ると良いでしょう。"
 
 #. Tag: para
-#: collection_mapping.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The Hibernate mapping element used for mapping a collection depends upon the "
 "type of interface. For example, a <literal>&lt;set&gt;</literal> element is "
 "used for mapping properties of type <literal>Set</literal>."
 msgstr ""
-"コレクションをマッピングするためのマッピング要素は、インターフェイスの型に依"
-"存します。 例えば、<literal>&lt;set&gt;</literal> 要素は <literal>Set</"
-"literal> 型を マッピングするために使います。"
+"コレクションをマッピングするためのマッピング要素は、インターフェースの型に依"
+"存します。例えば、 <literal>&lt;set&gt;</literal> 要素は <literal>Set</"
+"literal> 型のプロパティをマッピングするために使います。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:105
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Product\">\n"
-"    <id name=\"serialNumber\" column=\"productSerialNumber\"/>\n"
-"    <set name=\"parts\">\n"
-"        <key column=\"productSerialNumber\" not-null=\"true\"/>\n"
-"        <one-to-many class=\"Part\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:107
 #, no-c-format
 msgid ""
 "Apart from <literal>&lt;set&gt;</literal>, there is also <literal>&lt;"
@@ -205,69 +153,36 @@
 "element is representative:"
 msgstr ""
 "マッピング要素には <literal>&lt;set&gt;</literal> の他に <literal>&lt;"
-"list&gt;</literal>、 <literal>&lt;map&gt;</literal>、<literal>&lt;bag&gt;</"
-"literal>、 <literal>&lt;array&gt;</literal>、<literal>&lt;primitive-array&gt;"
-"</literal> があります。 代表として、<literal>&lt;map&gt;</literal> 要素を下記"
-"に示します。"
+"list&gt;</literal>、 <literal>&lt;map&gt;</literal>、 <literal>&lt;bag&gt;</"
+"literal>、 <literal>&lt;array&gt;</literal>、 <literal>&lt;primitive-"
+"array&gt;</literal> があります。代表として、 <literal>&lt;map&gt;</literal> "
+"要素を下記に示します。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:132
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<map\n"
-"    name=\"propertyName\"\n"
-"    table=\"table_name\"\n"
-"    schema=\"schema_name\"\n"
-"    lazy=\"true|extra|false\"\n"
-"    inverse=\"true|false\"\n"
-"    cascade=\"all|none|save-update|delete|all-delete-orphan|delete-orphan\"\n"
-"    sort=\"unsorted|natural|comparatorClass\"\n"
-"    order-by=\"column_name asc|desc\"\n"
-"    where=\"arbitrary sql where condition\"\n"
-"    fetch=\"join|select|subselect\"\n"
-"    batch-size=\"N\"\n"
-"    access=\"field|property|ClassName\"\n"
-"    optimistic-lock=\"true|false\"\n"
-"    mutable=\"true|false\"\n"
-"    node=\"element-name|.\"\n"
-"    embed-xml=\"true|false\"\n"
-">\n"
-"\n"
-"    <key .... />\n"
-"    <map-key .... />\n"
-"    <element .... />\n"
-"</map>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:135
-#, fuzzy, no-c-format
 msgid "<literal>name</literal>: the collection property name"
-msgstr "<literal>name</literal> コレクション型であるプロパティの名前"
+msgstr "<literal>name</literal> :コレクション型であるプロパティの名前"
 
 #. Tag: para
-#: collection_mapping.xml:140
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>table</literal> (optional - defaults to property name): the name of "
 "the collection table. It is not used for one-to-many associations."
 msgstr ""
-"<literal>table</literal> (オプション - デフォルトはプロパティ名)コレクショ"
-"ンテーブルの名前 (一対多関連では使用しません)。"
+"<literal>table</literal> (オプション - デフォルトはプロパティ名):コレク"
+"ションテーブルの名前(一対多関連では使用しません)。"
 
 #. Tag: para
-#: collection_mapping.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>schema</literal> (optional): the name of a table schema to override "
 "the schema declared on the root element"
 msgstr ""
-"<literal>schema</literal> (オプション)テーブルスキーマの名前。 ルート要素で"
-"宣言されているスキーマより優先されます。"
+"<literal>schema</literal> (オプション):テーブルスキーマの名前。ルート要素"
+"で宣言されているスキーマより優先されます。"
 
 #. Tag: para
-#: collection_mapping.xml:152
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>true</literal>): "
 "disables lazy fetching and specifies that the association is always eagerly "
@@ -276,122 +191,113 @@
 "collections."
 msgstr ""
 "<literal>lazy</literal> (オプション - デフォルトは <literal>true</"
-"literal>) 遅延フェッチを無効にし、関連を常に即時にフェッチにするために使用し"
-"ます。 または、「extra-lazy」フェッチを有効にするために使用します。 「extra-"
+"literal>): 遅延フェッチを無効にし、関連を常に即時にフェッチにするために使用"
+"します。または、「extra-lazy」フェッチを有効にするために使用します。「extra-"
 "lazy」フェッチは、ほとんどの操作ではコレクションを初期化しません (非常に大き"
 "なコレクションに適しています)。"
 
 #. Tag: para
-#: collection_mapping.xml:161
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>inverse</literal> (optional - defaults to <literal>false</"
 "literal>): marks this collection as the \"inverse\" end of a bidirectional "
 "association."
 msgstr ""
 "<literal>inverse</literal> (オプション - デフォルトは <literal>false</"
-"literal>) このコレクションが双方向関連の「逆」側であるとマークします。"
+"literal>):このコレクションが双方向関連の「逆」側であるとマークします。"
 
 #. Tag: para
-#: collection_mapping.xml:167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional - defaults to <literal>none</literal>): "
 "enables operations to cascade to child entities."
 msgstr ""
 "<literal>cascade</literal> (オプション - デフォルトは <literal>none</"
-"literal>) 子エンティティへのカスケード操作を有効にします。"
+"literal>):子エンティティへのカスケード操作を有効にします。"
 
 #. Tag: para
-#: collection_mapping.xml:173
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>sort</literal> (optional): specifies a sorted collection with "
 "<literal>natural</literal> sort order or a given comparator class."
 msgstr ""
-"<literal>sort</literal> (オプション)コレクションを自然な順序でソートする場"
-"合は <literal>natural</literal> を指定します。 あるいはComparatorクラスを指定"
-"します。"
+"<literal>sort</literal> (オプション):コレクションを自然な順序でソートする"
+"場合は <literal>natural</literal> を指定します。あるいは Comparator クラスを"
+"指定します。"
 
 #. Tag: para
-#: collection_mapping.xml:179
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>order-by</literal> (optional, JDK1.4 only): specifies a table "
 "column or columns that define the iteration order of the <literal>Map</"
 "literal>, <literal>Set</literal> or bag, together with an optional "
 "<literal>asc</literal> or <literal>desc</literal>."
 msgstr ""
-"<literal>order-by</literal> (オプション、JDK1.4のみ) <literal>Map</"
-"literal>、<literal>Set</literal>、bagのイテレーション順序を定義する テーブル"
-"カラムを指定すると共に、 オプションとして <literal>asc</literal>、"
+"<literal>order-by</literal> (オプション、 JDK1.4 のみ) <literal>Map</"
+"literal>、 <literal>Set</literal>、 bag のイテレーション順序を定義するテーブ"
+"ルカラムを指定すると共に、オプションとして <literal>asc</literal>、 "
 "<literal>desc</literal> を指定します。"
 
 #. Tag: para
-#: collection_mapping.xml:186
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>where</literal> (optional): specifies an arbitrary SQL "
 "<literal>WHERE</literal> condition that is used when retrieving or removing "
 "the collection. This is useful if the collection needs to contain only a "
 "subset of the available data."
 msgstr ""
-"<literal>where</literal> (オプション)コレクションの検索や削除の際に使う 任"
-"意のSQLの<literal>WHERE</literal> 条件を指定します (利用可能なデータの一部分"
-"だけをコレクションが含むべきときに、これは有用です)。"
+"<literal>where</literal> (オプション):コレクションの検索や削除の際に使う任"
+"意の SQL の<literal>WHERE</literal> 条件を指定します (利用可能なデータの一部"
+"分だけをコレクションが含むべきときに、これは有用です)。"
 
 #. Tag: para
-#: collection_mapping.xml:193
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional, defaults to <literal>select</literal>): "
 "chooses between outer-join fetching, fetching by sequential select, and "
 "fetching by sequential subselect."
 msgstr ""
-"<literal>fetch</literal>(オプション - デフォルトは <literal>select</"
-"literal>) 外部結合によるフェッチ、順次選択フェッチ(sequential select "
-"fetch)、 順次サブセレクトフェッチ(sequential subselect fetch)のどれかを選"
-"択してください。"
+"<literal>fetch</literal> (オプション - デフォルトは <literal>select</"
+"literal>):外部結合によるフェッチ、順次選択フェッチ (sequential select "
+"fetch) 、順次サブセレクトフェッチ (sequential subselect fetch) のどれかを"
+"選択してください。"
 
 #. Tag: para
-#: collection_mapping.xml:200
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>batch-size</literal> (optional, defaults to <literal>1</literal>): "
 "specifies a \"batch size\" for lazily fetching instances of this collection."
 msgstr ""
 "<literal>batch-size</literal> (オプション - デフォルトは <literal>1</"
-"literal>) コレクションのインスタンスの遅延フェッチのための「バッチサイズ」を"
-"指定します。"
+"literal>):コレクションのインスタンスの遅延フェッチのための「バッチサイズ」"
+"を指定します。"
 
 #. Tag: para
-#: collection_mapping.xml:206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate uses for accessing the collection property "
 "value."
 msgstr ""
 "<literal>access</literal> (オプション - デフォルトは <literal>property</"
-"literal>) コレクション型プロパティの値にアクセスするために使用する戦略です。"
+"literal>):コレクション型プロパティの値にアクセスするために使用する戦略で"
+"す。"
 
 #. Tag: para
-#: collection_mapping.xml:212
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that changes to the state of the collection results in "
 "increments of the owning entity's version. For one-to-many associations you "
 "may want to disable this setting."
 msgstr ""
-"<literal>optimistic-lock</literal>(オプション - デフォルトは <literal>true</"
-"literal>) コレクションの状態を変えることによって、 そのオーナーであるエン"
-"ティティのバージョンがインクリメントされるかを指定します。 (一対多関連では、"
-"ほとんどの場合において無効に設定するのが妥当です。)"
+"<literal>optimistic-lock</literal> (オプション - デフォルトは "
+"<literal>true</literal>) コレクションの状態を変えることによって、そのオー"
+"ナーであるエンティティのバージョンがインクリメントされるかを指定します。 (一"
+"対多関連では、ほとんどの場合において無効に設定するのが妥当です。)"
 
 #. Tag: para
-#: collection_mapping.xml:220
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>true</literal>): "
 "a value of <literal>false</literal> specifies that the elements of the "
@@ -403,14 +309,12 @@
 "とを表します (ある場合には、少しパフォーマンスを高めます)。"
 
 #. Tag: title
-#: collection_mapping.xml:230
 #, no-c-format
 msgid "Collection foreign keys"
 msgstr "コレクションの外部キー"
 
 #. Tag: para
-#: collection_mapping.xml:232
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collection instances are distinguished in the database by the foreign key of "
 "the entity that owns the collection. This foreign key is referred to as the "
@@ -418,47 +322,33 @@
 "table. The collection key column is mapped by the <literal>&lt;key&gt;</"
 "literal> element."
 msgstr ""
-"コレクションのインスタンスは、データベース内では、 そのコレクションを所有する"
-"エンティティの外部キーによって識別されます。 この外部キーはコレクションテーブ"
-"ルの <emphasis>コレクションキーカラム</emphasis> と呼ばれます。 コレクション"
-"キーカラムは <literal>&lt;key&gt;</literal> 要素によりマッピングします。"
+"コレクションのインスタンスは、データベース内では、そのコレクションを所有する"
+"エンティティの外部キーによって識別されます。この外部キーはコレクションテーブ"
+"ルの <emphasis>コレクションキーカラム</emphasis> (またはカラム) と呼ばれま"
+"す。コレクションキーカラムは <literal>&lt;key&gt;</literal> 要素によりマッピ"
+"ングします。"
 
 #. Tag: para
-#: collection_mapping.xml:240
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There can be a nullability constraint on the foreign key column. For most "
 "collections, this is implied. For unidirectional one-to-many associations, "
 "the foreign key column is nullable by default, so you may need to specify "
 "<literal>not-null=\"true\"</literal>."
 msgstr ""
-"外部キーカラムにはnull設定制約があるかもしれません。 ほとんどのコレクションに"
-"当てはまるでしょう。 単方向の一対多関連において、外部キーカラムはデフォルトで"
-"nullを許す設定になっています。 よって、<literal>not-null=\"true\"</literal> "
-"を指定する必要があるかもしれません。"
+"外部キーカラムには null 設定制約があるかもしれません。ほとんどのコレクション"
+"に当てはまるでしょう。単方向の一対多関連において、外部キーカラムはデフォルト"
+"で null を許す設定になっています。よって、 <literal>not-null=\"true\"</"
+"literal> を指定する必要があるかもしれません。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:247
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[<key column=\"productSerialNumber\" not-null=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:249
-#, fuzzy, no-c-format
 msgid ""
 "The foreign key constraint can use <literal>ON DELETE CASCADE</literal>."
 msgstr ""
 "外部キーの制約が <literal>ON DELETE CASCADE</literal> を使うかもしれません。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:253
-#, no-c-format
-msgid "<![CDATA[<key column=\"productSerialNumber\" on-delete=\"cascade\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:255
 #, no-c-format
 msgid ""
 "See the previous chapter for a full definition of the <literal>&lt;key&gt;</"
@@ -468,14 +358,12 @@
 "ださい。"
 
 #. Tag: title
-#: collection_mapping.xml:263
 #, no-c-format
 msgid "Collection elements"
 msgstr "コレクションの要素"
 
 #. Tag: para
-#: collection_mapping.xml:265
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collections can contain almost any other Hibernate type, including: basic "
 "types, custom types, components and references to other entities. This is an "
@@ -485,16 +373,15 @@
 "latter case, only the \"link\" between the two objects is considered to be a "
 "state held by the collection."
 msgstr ""
-"コレクションは他のHibernateの型のほとんど(すべての基本型、カスタム型、コン"
-"ポーネント、 他のエンティティへの参照)を格納することができます。 次の点は重"
-"要な違いになります。 コレクションに格納されたオブジェクトが「値」セマンティク"
-"スとして扱われるのか (ライフサイクルはコレクションのオーナーに完全に依存しま"
-"す)、 もしくはそれ自身のライフサイクルを持った別のエンティティへの参照である"
-"かのかという違いです。 後者は、2つのオブジェクト間の「リンク」をコレクション"
-"に保持していると見なしているだけです。"
+"コレクションは他の Hibernate の型のほとんど(すべての基本型、カスタム型、コン"
+"ポーネント、他のエンティティへの参照)を格納することができます。次の点は重要"
+"な違いになります。コレクションに格納されたオブジェクトが「値」セマンティクス"
+"として扱われるのか (ライフサイクルはコレクションのオーナーに完全に依存しま"
+"す)、もしくはそれ自身のライフサイクルを持った別のエンティティへの参照である"
+"かのかという違いです。後者は、2つのオブジェクト間の「リンク」をコレクションに"
+"保持していると見なしているだけです。"
 
 #. Tag: para
-#: collection_mapping.xml:274
 #, no-c-format
 msgid ""
 "The contained type is referred to as the <emphasis>collection element type</"
@@ -504,22 +391,20 @@
 "<literal>&lt;many-to-many&gt;</literal>. The first two map elements with "
 "value semantics, the next two are used to map entity associations."
 msgstr ""
-"格納される型は <emphasis>コレクション要素型</emphasis> と呼ばれます。 コレク"
-"ション要素は、<literal>&lt;element&gt;</literal> または <literal>&lt;"
+"格納される型は <emphasis>コレクション要素型</emphasis> と呼ばれます。コレク"
+"ション要素は、 <literal>&lt;element&gt;</literal> または <literal>&lt;"
 "composite-element&gt;</literal> によりマッピングされ、エンティティへの参照の"
 "場合には <literal>&lt;one-to-many&gt;</literal> または <literal>&lt;many-to-"
-"many&gt;</literal> によりマッピングされます。 最初の二つは値として要素をマッ"
-"ピングし、次の二つはエンティティの関連をマッピングするのに使われます。"
+"many&gt;</literal> によりマッピングされます。最初の二つは値として要素をマッピ"
+"ングし、次の二つはエンティティの関連をマッピングするのに使われます。"
 
 #. Tag: title
-#: collection_mapping.xml:286
 #, no-c-format
 msgid "Indexed collections"
 msgstr "インデックス付きのコレクション"
 
 #. Tag: para
-#: collection_mapping.xml:288
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All collection mappings, except those with set and bag semantics, need an "
 "<emphasis>index column</emphasis> in the collection table. An index column "
@@ -533,68 +418,81 @@
 "index&gt;</literal> element. The mapped column contains sequential integers "
 "that are numbered from zero by default."
 msgstr ""
-"setとbagを除く全てのコレクションマッピングには、 コレクションテーブルの中に "
-"<emphasis>インデックス用のカラム</emphasis> が必要です。 そのカラムに、配列"
-"や <literal>List</literal> のインデックス、 もしくは <literal>Map</literal> "
-"のキーをマッピングします。 <literal>Map</literal> のインデックスは、 "
+"set と bag を除く全てのコレクションマッピングには、コレクションテーブルの中"
+"に <emphasis>インデックス用のカラム</emphasis> が必要です。そのカラムに、配列"
+"や <literal>List</literal> のインデックス、もしくは <literal>Map</literal> の"
+"キーをマッピングします。 <literal>Map</literal> のインデックスは、 "
 "<literal>&lt;map-key&gt;</literal> によりマッピングされた基本型か、 "
 "<literal>&lt;map-key-many-to-many&gt;</literal> によりマッピングされたエン"
-"ティティの関連か、 あるいは <literal>&lt;composite-map-key&gt;</literal> によ"
-"りマッピングされたコンポジット型になります。 配列かリストのインデックスは、常"
+"ティティの関連か、あるいは <literal>&lt;composite-map-key&gt;</literal> によ"
+"りマッピングされたコンポジット型になります。配列かリストのインデックスは、常"
 "に <literal>integer</literal> 型で、 <literal>&lt;list-index&gt;</literal> 要"
-"素によりマッピングします。 マッピングされたカラムにはシーケンシャルな整数を格"
-"納します(デフォルトでは0から番号が付けられます)。"
+"素によりマッピングします。マッピングされたカラムにはシーケンシャルな整数を格"
+"納します (デフォルトでは0から番号が付けられます)。"
 
-#. Tag: sect2
-#: collection_mapping.xml:299
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"<literal>column_name</literal> (required): the name of the column holding "
+"the collection index values."
+msgstr "<literal>class</literal> (必須): 関連クラスの名前。"
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"<literal>base</literal> (optional - defaults to <literal>0</literal>): the "
+"value of the index column that corresponds to the first element of the list "
+"or array."
+msgstr ""
+"<literal>cascade</literal> (オプション - デフォルトは <literal>none</"
+"literal>):子エンティティへのカスケード操作を有効にします。"
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"<literal>column</literal> (optional): the name of the column holding the "
+"collection index values."
+msgstr ""
+"<literal>schema</literal> (オプション):テーブルスキーマの名前。ルート要素"
+"で宣言されているスキーマより優先されます。"
+
+#. Tag: para
 #, no-c-format
 msgid ""
-"<programlistingco> <areaspec> <area id=\"index1\" coords=\"2 45\"/> <area id="
-"\"index2\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA[<list-"
-"index \n"
-"        column=\"column_name\"\n"
-"        base=\"0|1|...\"/>]]></programlisting> <calloutlist> <callout "
-"arearefs=\"index1\"> <para> <literal>column_name</literal> (required): the "
-"name of the column holding the collection index values. </para> </callout> "
-"<callout arearefs=\"index1\"> <para> <literal>base</literal> (optional - "
-"defaults to <literal>0</literal>): the value of the index column that "
-"corresponds to the first element of the list or array. </para> </callout> </"
-"calloutlist> </programlistingco> <programlistingco> <areaspec> <area id="
-"\"mapkey1\" coords=\"2 45\"/> <area id=\"mapkey2\" coords=\"3 45\"/> <area "
-"id=\"mapkey3\" coords=\"4 45\"/> </areaspec> <programlisting><![CDATA[<map-"
-"key \n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        type=\"type_name\"\n"
-"        node=\"@attribute-name\"\n"
-"        length=\"N\"/>]]></programlisting> <calloutlist> <callout arearefs="
-"\"mapkey1\"> <para> <literal>column</literal> (optional): the name of the "
-"column holding the collection index values. </para> </callout> <callout "
-"arearefs=\"mapkey2\"> <para> <literal>formula</literal> (optional): a SQL "
-"formula used to evaluate the key of the map. </para> </callout> <callout "
-"arearefs=\"mapkey3\"> <para> <literal>type</literal> (required): the type of "
-"the map keys. </para> </callout> </calloutlist> </programlistingco> "
-"<programlistingco> <areaspec> <area id=\"indexmanytomany1\" coords=\"2 45\"/"
-"> <area id=\"indexmanytomany2\" coords=\"3 45\"/> <area id=\"indexmanytomany3"
-"\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA[<map-key-many-to-"
-"many\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        class=\"ClassName\"\n"
-"/>]]></programlisting> <calloutlist> <callout arearefs=\"indexmanytomany1\"> "
-"<para> <literal>column</literal> (optional): the name of the foreign key "
-"column for the collection index values. </para> </callout> <callout arearefs="
-"\"indexmanytomany2\"> <para> <literal>formula</literal> (optional): a SQ "
-"formula used to evaluate the foreign key of the map key. </para> </callout> "
-"<callout arearefs=\"indexmanytomany3\"> <para> <literal>class</literal> "
-"(required): the entity class used as the map key. </para> </callout> </"
-"calloutlist> </programlistingco>"
+"<literal>formula</literal> (optional): a SQL formula used to evaluate the "
+"key of the map."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:380
 #, fuzzy, no-c-format
+msgid "<literal>type</literal> (required): the type of the map keys."
+msgstr "<literal>class</literal> (必須): 関連クラスの名前。"
+
+#. Tag: para
+#, fuzzy, no-c-format
 msgid ""
+"<literal>column</literal> (optional): the name of the foreign key column for "
+"the collection index values."
+msgstr ""
+"<literal>schema</literal> (オプション):テーブルスキーマの名前。ルート要素"
+"で宣言されているスキーマより優先されます。"
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>formula</literal> (optional): a SQ formula used to evaluate the "
+"foreign key of the map key."
+msgstr ""
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"<literal>class</literal> (required): the entity class used as the map key."
+msgstr "<literal>class</literal> (必須): 関連クラスの名前。"
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
 "If your table does not have an index column, and you still wish to use "
 "<literal>List</literal> as the property type, you can map the property as a "
 "Hibernate <emphasis>&lt;bag&gt;</emphasis>. A bag does not retain its order "
@@ -602,20 +500,18 @@
 "ordered."
 msgstr ""
 "もしテーブルにインデックスカラムがなくても、プロパティ型として "
-"<literal>List</literal> を使いたければ、 Hibernateの <emphasis>&lt;bag&gt;</"
-"emphasis> としてプロパティをマッピングします。 bagはデータベースから復元され"
-"る時、順序を保持しません。 しかし、(メモリ上で)ソートしたり、(SQLで)順序"
-"付けしたり(order by)することもできます。"
+"<literal>List</literal> を使いたければ、 Hibernate の <emphasis>&lt;bag&gt;</"
+"emphasis> としてプロパティをマッピングします。 bag はデータベースから復元され"
+"る時、順序を保持しません。しかし、(メモリ上で)ソートしたり、(SQLで)順序付"
+"けしたり(order by)することもできます。"
 
 #. Tag: title
-#: collection_mapping.xml:390
 #, no-c-format
 msgid "Collections of values and many-to-many associations"
 msgstr "値のコレクションと多対多関連"
 
 #. Tag: para
-#: collection_mapping.xml:392
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Any collection of values or many-to-many associations requires a dedicated "
 "<emphasis>collection table</emphasis> with a foreign key column or columns, "
@@ -623,237 +519,188 @@
 "index column or columns."
 msgstr ""
 "値のコレクションや多対多関連は、専用の <emphasis>コレクションテーブル</"
-"emphasis> が必要です。 このテーブルは、外部キーカラムと、 <emphasis>コレク"
-"ション要素のカラム</emphasis> と、 場合によってはインデックスカラムを持ちま"
-"す。"
+"emphasis> が必要です。このテーブルは、外部キーカラムと、 <emphasis>コレクショ"
+"ン要素のカラム</emphasis> と、場合によってはインデックスカラムを持ちます。"
 
 #. Tag: para
-#: collection_mapping.xml:399
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For a collection of values use the <literal>&lt;element&gt;</literal> tag. "
 "For example:"
 msgstr ""
-"値のコレクションのために、<literal>&lt;element&gt;</literal>タグを使用しま"
+"値のコレクションのために、 <literal>&lt;element&gt;</literal> タグを使用しま"
 "す。"
 
-#. Tag: sect2
-#: collection_mapping.xml:401
-#, no-c-format
+#. Tag: para
+#, fuzzy, no-c-format
 msgid ""
-"<programlistingco> <areaspec> <area id=\"element1b\" coords=\"2 50\"/> <area "
-"id=\"element2b\" coords=\"3 50\"/> <area id=\"element3b\" coords=\"4 50\"/> "
-"</areaspec> <programlisting><![CDATA[<element\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        type=\"typename\"\n"
-"        length=\"L\"\n"
-"        precision=\"P\"\n"
-"        scale=\"S\"\n"
-"        not-null=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        node=\"element-name\"\n"
-"/>]]></programlisting> <calloutlist> <callout arearefs=\"element1b\"> <para> "
 "<literal>column</literal> (optional): the name of the column holding the "
-"collection element values. </para> </callout> <callout arearefs=\"element2b"
-"\"> <para> <literal>formula</literal> (optional): an SQL formula used to "
-"evaluate the element. </para> </callout> <callout arearefs=\"element3b\"> "
-"<para> <literal>type</literal> (required): the type of the collection "
-"element. </para> </callout> </calloutlist> </programlistingco> <para> A "
-"<emphasis>many-to-many association</emphasis> is specified using the "
-"<literal>&lt;many-to-many&gt;</literal> element. </para> <programlistingco> "
-"<areaspec> <area id=\"manytomany1\" coords=\"2 60\"/> <area id=\"manytomany2"
-"\" coords=\"3 60\"/> <area id=\"manytomany3\" coords=\"4 60\"/> <area id="
-"\"manytomany4\" coords=\"5 60\"/> <area id=\"manytomany5\" coords=\"6 60\"/> "
-"<area id=\"manytomany6\" coords=\"7 60\"/> <area id=\"manytomany7\" coords="
-"\"8 60\"/> <area id=\"manytomany8\" coords=\"9 60\"/> </areaspec> "
-"<programlisting><![CDATA[<many-to-many\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        class=\"ClassName\"\n"
-"        fetch=\"select|join\"\n"
-"        unique=\"true|false\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        node=\"element-name\"\n"
-"        embed-xml=\"true|false\"\n"
-"    />]]></programlisting> <calloutlist> <callout arearefs=\"manytomany1\"> "
-"<para> <literal>column</literal> (optional): the name of the element foreign "
-"key column. </para> </callout> <callout arearefs=\"manytomany2\"> <para> "
+"collection element values."
+msgstr ""
+"<literal>schema</literal> (オプション):テーブルスキーマの名前。ルート要素"
+"で宣言されているスキーマより優先されます。"
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
 "<literal>formula</literal> (optional): an SQL formula used to evaluate the "
-"element foreign key value. </para> </callout> <callout arearefs=\"manytomany3"
-"\"> <para> <literal>class</literal> (required): the name of the associated "
-"class. </para> </callout> <callout arearefs=\"manytomany4\"> <para> "
+"element."
+msgstr ""
+"<literal>schema</literal> (オプション):テーブルスキーマの名前。ルート要素"
+"で宣言されているスキーマより優先されます。"
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>type</literal> (required): the type of the collection element."
+msgstr "<literal>class</literal> (必須): 関連クラスの名前。"
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"A <emphasis>many-to-many association</emphasis> is specified using the "
+"<literal>&lt;many-to-many&gt;</literal> element."
+msgstr ""
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"<literal>column</literal> (optional): the name of the element foreign key "
+"column."
+msgstr "<literal>class</literal> (必須): 関連クラスの名前。"
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>formula</literal> (optional): an SQL formula used to evaluate the "
+"element foreign key value."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "<literal>class</literal> (required): the name of the associated class."
+msgstr "<literal>class</literal> (必須): 関連クラスの名前。"
+
+#. Tag: para
+#, no-c-format
+msgid ""
 "<literal>fetch</literal> (optional - defaults to <literal>join</literal>): "
 "enables outer-join or sequential select fetching for this association. This "
 "is a special case; for full eager fetching in a single <literal>SELECT</"
 "literal> of an entity and its many-to-many relationships to other entities, "
 "you would enable <literal>join</literal> fetching,not only of the collection "
 "itself, but also with this attribute on the <literal>&lt;many-to-many&gt;</"
-"literal> nested element. </para> </callout> <callout arearefs=\"manytomany5"
-"\"> <para> <literal>unique</literal> (optional): enables the DDL generation "
-"of a unique constraint for the foreign-key column. This makes the "
-"association multiplicity effectively one-to-many. </para> </callout> "
-"<callout arearefs=\"manytomany6\"> <para> <literal>not-found</literal> "
-"(optional - defaults to <literal>exception</literal>): specifies how foreign "
-"keys that reference missing rows will be handled: <literal>ignore</literal> "
-"will treat a missing row as a null association. </para> </callout> <callout "
-"arearefs=\"manytomany7\"> <para> <literal>entity-name</literal> (optional): "
-"the entity name of the associated class, as an alternative to "
-"<literal>class</literal>. </para> </callout> <callout arearefs=\"manytomany8"
-"\"> <para> <literal>property-ref</literal> (optional): the name of a "
-"property of the associated class that is joined to this foreign key. If not "
-"specified, the primary key of the associated class is used. </para> </"
-"callout> </calloutlist> </programlistingco>"
+"literal> nested element."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:506
 #, no-c-format
-msgid "Here are some examples."
+msgid ""
+"<literal>unique</literal> (optional): enables the DDL generation of a unique "
+"constraint for the foreign-key column. This makes the association "
+"multiplicity effectively one-to-many."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:509
-#, no-c-format
-msgid "A set of strings:"
+#, fuzzy, no-c-format
+msgid ""
+"<literal>not-found</literal> (optional - defaults to <literal>exception</"
+"literal>): specifies how foreign keys that reference missing rows will be "
+"handled: <literal>ignore</literal> will treat a missing row as a null "
+"association."
 msgstr ""
+"<literal>not-found</literal> (オプション - デフォルトは <literal>exception</"
+"literal>): 参照先の行がないキャッシュされた識別子をどのように扱うかを指定し"
+"ます: <literal>ignore</literal> を指定すると、行がないことを関連がないものと"
+"して扱います。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:513
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"names\" table=\"person_names\">\n"
-"    <key column=\"person_id\"/>\n"
-"    <element column=\"person_name\" type=\"string\"/>\n"
-"</set>]]>"
+"<literal>entity-name</literal> (optional): the entity name of the associated "
+"class, as an alternative to <literal>class</literal>."
 msgstr ""
+"<literal>entity-name</literal> (オプション): <literal>class</literal> の代"
+"替である関連クラスのエンティティ名。 <literal>class</literal> の代わりに指定"
+"する、関連クラスのエンティティ名。"
 
 #. Tag: para
-#: collection_mapping.xml:515
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"A bag containing integers with an iteration order determined by the "
-"<literal>order-by</literal> attribute:"
+"<literal>property-ref</literal> (optional): the name of a property of the "
+"associated class that is joined to this foreign key. If not specified, the "
+"primary key of the associated class is used."
 msgstr ""
-"整数値を含むbag(bagは <literal>order-by</literal> 属性によって反復順序が定義"
-"されています)"
 
-#. Tag: programlisting
-#: collection_mapping.xml:520
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<bag name=\"sizes\" \n"
-"        table=\"item_sizes\" \n"
-"        order-by=\"size asc\">\n"
-"    <key column=\"item_id\"/>\n"
-"    <element column=\"size\" type=\"integer\"/>\n"
-"</bag>]]>"
+msgid "Here are some examples."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:522
-#, fuzzy, no-c-format
-msgid "An array of entities, in this case, a many-to-many association:"
-msgstr "エンティティの配列 - この場合、多対多の関連です。"
+#, no-c-format
+msgid "A set of strings:"
+msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:526
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<array name=\"addresses\" \n"
-"        table=\"PersonAddress\" \n"
-"        cascade=\"persist\">\n"
-"    <key column=\"personId\"/>\n"
-"    <list-index column=\"sortOrder\"/>\n"
-"    <many-to-many column=\"addressId\" class=\"Address\"/>\n"
-"</array>]]>"
+"A bag containing integers with an iteration order determined by the "
+"<literal>order-by</literal> attribute:"
 msgstr ""
+"整数値を含む bag (bagは <literal>order-by</literal> 属性によって反復順序が定"
+"義されています):"
 
 #. Tag: para
-#: collection_mapping.xml:528
 #, no-c-format
-msgid "A map from string indices to dates:"
-msgstr "文字列と日付のmap"
+msgid "An array of entities, in this case, a many-to-many association:"
+msgstr "エンティティの配列 - この場合、多対多の関連です。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:532
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<map name=\"holidays\" \n"
-"        table=\"holidays\" \n"
-"        schema=\"dbo\" \n"
-"        order-by=\"hol_name asc\">\n"
-"    <key column=\"id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date\" type=\"date\"/>\n"
-"</map>]]>"
-msgstr ""
+msgid "A map from string indices to dates:"
+msgstr "文字列と日付の map"
 
 #. Tag: para
-#: collection_mapping.xml:534
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A list of components (this is discussed in the next chapter):"
-msgstr "コンポーネントのlist(次の章で詳しく説明します)"
+msgstr "コンポーネントの list (次の章で詳しく説明します)"
 
-#. Tag: programlisting
-#: collection_mapping.xml:538
-#, no-c-format
-msgid ""
-"<![CDATA[<list name=\"carComponents\" \n"
-"        table=\"CarComponents\">\n"
-"    <key column=\"carId\"/>\n"
-"    <list-index column=\"sortOrder\"/>\n"
-"    <composite-element class=\"CarComponent\">\n"
-"        <property name=\"price\"/>\n"
-"        <property name=\"type\"/>\n"
-"        <property name=\"serialNumber\" column=\"serialNum\"/>\n"
-"    </composite-element>\n"
-"</list>]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:543
 #, no-c-format
 msgid "One-to-many associations"
 msgstr "一対多関連"
 
 #. Tag: para
-#: collection_mapping.xml:545
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>one-to-many association</emphasis> links the tables of two "
 "classes via a foreign key with no intervening collection table. This mapping "
 "loses certain semantics of normal Java collections:"
 msgstr ""
-"<emphasis>一対多関連</emphasis> は、コレクション・テーブルを介さず、 外部キー"
-"により2つのクラスのテーブルを関連付けます。 このマッピングは標準的なJavaのコ"
-"レクションのセマンティクスをいくつか失います。"
+"<emphasis>一対多関連</emphasis> は、コレクションテーブルを介さず、外部キーに"
+"より2つのクラスのテーブルを関連付けます。このマッピングは標準的な Java のコレ"
+"クションのセマンティクスをいくつか失います:"
 
 #. Tag: para
-#: collection_mapping.xml:553
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of the contained entity class cannot belong to more than one "
 "instance of the collection."
 msgstr ""
-"エンティティクラスのインスタンスは、 2つ以上のコレクションのインスタンスに属"
-"してはいけません。"
+"エンティティクラスのインスタンスは、2つ以上のコレクションのインスタンスに属し"
+"てはいけません。"
 
 #. Tag: para
-#: collection_mapping.xml:559
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of the contained entity class cannot appear at more than one "
 "value of the collection index."
 msgstr ""
-"コレクションに含まれるエンティティクラスのインスタンスは、 コレクションイン"
+"コレクションに含まれるエンティティクラスのインスタンスは、コレクションイン"
 "デックスの値として2度以上現れてはいけません。"
 
 #. Tag: para
-#: collection_mapping.xml:566
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An association from <literal>Product</literal> to <literal>Part</literal> "
 "requires the existence of a foreign key column and possibly an index column "
@@ -865,29 +712,9 @@
 "クスカラムが必要です。 <literal>&lt;one-to-many&gt;</literal> タグは、これが"
 "一対多関連であることを表しています。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:579
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<one-to-many \n"
-"        class=\"ClassName\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\"\n"
-"        embed-xml=\"true|false\"\n"
-"    />]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:582
-#, fuzzy, no-c-format
-msgid "<literal>class</literal> (required): the name of the associated class."
-msgstr "<literal>class</literal> (必須): 関連クラスの名前。"
-
-#. Tag: para
-#: collection_mapping.xml:587
-#, fuzzy, no-c-format
-msgid ""
 "<literal>not-found</literal> (optional - defaults to <literal>exception</"
 "literal>): specifies how cached identifiers that reference missing rows will "
 "be handled. <literal>ignore</literal> will treat a missing row as a null "
@@ -895,34 +722,21 @@
 msgstr ""
 "<literal>not-found</literal> (オプション - デフォルトは <literal>exception</"
 "literal>): 参照先の行がないキャッシュされた識別子をどのように扱うかを指定し"
-"ます。 <literal>ignore</literal> を指定すると、行がないことを関連がないものと"
+"ます: <literal>ignore</literal> を指定すると、行がないことを関連がないものと"
 "して扱います。"
 
 #. Tag: para
-#: collection_mapping.xml:594
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"<literal>entity-name</literal> (optional): the entity name of the associated "
-"class, as an alternative to <literal>class</literal>."
-msgstr ""
-"<literal>entity-name</literal> (オプション): <literal>class</literal> の代"
-"替である関連クラスのエンティティ名。 <literal>class</literal> の代わりに指定"
-"する、関連クラスのエンティティ名。"
-
-#. Tag: para
-#: collection_mapping.xml:602
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>&lt;one-to-many&gt;</literal> element does not need to declare "
 "any columns. Nor is it necessary to specify the <literal>table</literal> "
 "name anywhere."
 msgstr ""
 "<literal>&lt;one-to-many&gt;</literal> 要素はカラムを宣言する必要がないことに"
-"注意してください。 同様に <literal>テーブル</literal> 名を指定する必要もあり"
-"ません。"
+"注意してください。同様に <literal>テーブル</literal> 名を指定する必要もありま"
+"せん。"
 
 #. Tag: para
-#: collection_mapping.xml:609
 #, fuzzy, no-c-format
 msgid ""
 "If the foreign key column of a <literal>&lt;one-to-many&gt;</literal> "
@@ -935,79 +749,44 @@
 "<emphasis>とても重要な注意:</emphasis> もし <literal>&lt;one-to-many&gt;</"
 "literal> 関連の外部キーカラムが <literal>NOT NULL</literal>と宣言された場"
 "合、 <literal>&lt;key&gt;</literal> マッピングに <literal>not-null=\"true\"</"
-"literal> を宣言するか、 コレクションマッピングに <literal>inverse=\"true\"</"
+"literal> を宣言するか、コレクションマッピングに <literal>inverse=\"true\"</"
 "literal> を付けた上で、 <emphasis>双方向関連を使う</emphasis> 必要がありま"
-"す。 双方向関連についてはこの章の後のほうで説明します。"
+"す。双方向関連についてはこの章の後のほうで説明します。"
 
 #. Tag: para
-#: collection_mapping.xml:619
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following example shows a map of <literal>Part</literal> entities by "
 "name, where <literal>partName</literal> is a persistent property of "
 "<literal>Part</literal>. Notice the use of a formula-based index:"
 msgstr ""
 "次の例は、名称(<literal>Part</literal> の永続的なプロパティである "
-"<literal>partName</literal>) による <literal>Part</literal> エンティティの"
-"mapを表しています。 formulaによるインデックスを使っていることに注意してくださ"
-"い。"
+"<literal>partName</literal>) による <literal>Part</literal> エンティティの "
+"map を表しています。 formula によるインデックスを使っていることに注意してくだ"
+"さい。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:625
-#, no-c-format
-msgid ""
-"<![CDATA[<map name=\"parts\"\n"
-"        cascade=\"all\">\n"
-"    <key column=\"productId\" not-null=\"true\"/>\n"
-"    <map-key formula=\"partName\"/>\n"
-"    <one-to-many class=\"Part\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:631
 #, no-c-format
 msgid "Advanced collection mappings"
-msgstr "高度なコレクション・マッピング"
+msgstr "高度なコレクションマッピング"
 
 #. Tag: title
-#: collection_mapping.xml:634
 #, no-c-format
 msgid "Sorted collections"
 msgstr "ソートされたコレクション"
 
 #. Tag: para
-#: collection_mapping.xml:636
 #, no-c-format
 msgid ""
 "Hibernate supports collections implementing <literal>java.util.SortedMap</"
 "literal> and <literal>java.util.SortedSet</literal>. You must specify a "
 "comparator in the mapping file:"
 msgstr ""
-"Hibernateは <literal>java.util.SortedMap</literal> と <literal>java.util."
-"SortedSet</literal> を実装したコレクションをサポートしています。 開発者はマッ"
-"ピング定義ファイルにコンパレータを指定しなければなりません。"
+"Hibernate は <literal>java.util.SortedMap</literal> と <literal>java.util."
+"SortedSet</literal> を実装したコレクションをサポートしています。開発者はマッ"
+"ピング定義ファイルにコンパレータを指定しなければなりません: "
 
-#. Tag: programlisting
-#: collection_mapping.xml:641
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"aliases\" \n"
-"            table=\"person_aliases\" \n"
-"            sort=\"natural\">\n"
-"    <key column=\"person\"/>\n"
-"    <element column=\"name\" type=\"string\"/>\n"
-"</set>\n"
-"\n"
-"<map name=\"holidays\" sort=\"my.custom.HolidayComparator\">\n"
-"    <key column=\"year_id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date\" type=\"date\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:643
 #, no-c-format
 msgid ""
 "Allowed values of the <literal>sort</literal> attribute are "
@@ -1015,11 +794,10 @@
 "class implementing <literal>java.util.Comparator</literal>."
 msgstr ""
 "<literal>sort</literal> 属性に設定できる値は <literal>unsorted</literal> と "
-"<literal>natural</literal> および、<literal>java.util.Comparator</literal> を"
-"実装したクラスの名前です。"
+"<literal>natural</literal> および、 <literal>java.util.Comparator</literal> "
+"を実装したクラスの名前です。"
 
 #. Tag: para
-#: collection_mapping.xml:649
 #, no-c-format
 msgid ""
 "Sorted collections actually behave like <literal>java.util.TreeSet</literal> "
@@ -1029,8 +807,7 @@
 "<literal>java.util.TreeMap</literal> のように振舞います。"
 
 #. Tag: para
-#: collection_mapping.xml:654
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want the database itself to order the collection elements, use the "
 "<literal>order-by</literal> attribute of <literal>set</literal>, "
@@ -1041,247 +818,142 @@
 msgstr ""
 "もしデータベース自身にコレクションの要素を並べさせたいなら、 <literal>set</"
 "literal> や <literal>bag</literal>、<literal>map</literal> の <literal>order-"
-"by</literal> 属性を使います。 この解決法はJDK1.4、もしくはそれ以上のバージョ"
+"by</literal> 属性を使います。この解決法は JDK1.4 、もしくはそれ以上のバージョ"
 "ンで利用可能です (<literal>LinkedHashSet</literal> または "
-"<literal>LinkedHashMap</literal>を使って実装されています)。 整列はメモリ上で"
-"はなく、SQLクエリ内で実行されます。"
+"<literal>LinkedHashMap</literal>を使って実装されています)。整列はメモリ上で"
+"はなく、 SQL クエリ内で実行されます。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:663
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"aliases\" table=\"person_aliases\" order-by=\"lower"
-"(name) asc\">\n"
-"    <key column=\"person\"/>\n"
-"    <element column=\"name\" type=\"string\"/>\n"
-"</set>\n"
-"\n"
-"<map name=\"holidays\" order-by=\"hol_date, hol_name\">\n"
-"    <key column=\"year_id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date type=\"date\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:666
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "注記"
 
 #. Tag: para
-#: collection_mapping.xml:667
 #, fuzzy, no-c-format
 msgid ""
 "The value of the <literal>order-by</literal> attribute is an SQL ordering, "
 "not an HQL ordering."
 msgstr ""
-"<literal>order-by</literal> 属性の値がSQL命令であって、HQL命令ではないことに"
-"注意してください!"
+"<literal>order-by</literal> 属性の値が SQL 命令であって、 HQL 命令ではないこ"
+"とに注意してください。"
 
 #. Tag: para
-#: collection_mapping.xml:673
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Associations can even be sorted by arbitrary criteria at runtime using a "
 "collection <literal>filter()</literal>:"
 msgstr ""
-"関連は、コレクションの <literal>filter()</literal> を使うことで、 実行時に任"
-"意のcriteriaによってソートすることも可能です。"
+"関連は、コレクションの <literal>filter()</literal> を使うことで、実行時に任意"
+"の criteria によってソートすることも可能です。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:678
-#, no-c-format
-msgid ""
-"<![CDATA[sortedUsers = s.createFilter( group.getUsers(), \"order by this.name"
-"\" ).list();]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:683
 #, no-c-format
 msgid "Bidirectional associations"
 msgstr "双方向関連"
 
 #. Tag: para
-#: collection_mapping.xml:685
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional association</emphasis> allows navigation from both "
 "\"ends\" of the association. Two kinds of bidirectional association are "
 "supported:"
 msgstr ""
 "<emphasis>双方向関連</emphasis> は関連のどちら「側」からでもナビゲーションで"
-"きます。 2種類の双方向関連がサポートされています。 <placeholder-1/>"
+"きます。2種類の双方向関連がサポートされています:"
 
 #. Tag: term
-#: collection_mapping.xml:692
 #, no-c-format
 msgid "one-to-many"
 msgstr "one-to-many"
 
 #. Tag: para
-#: collection_mapping.xml:694
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "set or bag valued at one end and single-valued at the other"
-msgstr "片側がsetかbag、もう片方が単一値です。"
+msgstr "片側が set か bag 、もう片方が単一値です。"
 
 #. Tag: term
-#: collection_mapping.xml:700
 #, no-c-format
 msgid "many-to-many"
 msgstr "many-to-many"
 
 #. Tag: para
-#: collection_mapping.xml:702
 #, no-c-format
 msgid "set or bag valued at both ends"
-msgstr "両側がsetかbagです。"
+msgstr "両側が set か bag です。"
 
 #. Tag: para
-#: collection_mapping.xml:711
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can specify a bidirectional many-to-many association by mapping two many-"
 "to-many associations to the same database table and declaring one end as "
 "<emphasis>inverse</emphasis>. You cannot select an indexed collection."
 msgstr ""
-"2つの多対多関連で同じデータベーステーブルをマッピングし、 片方を "
-"<emphasis>inverse</emphasis> として宣言することで、 双方向の多対多関連を指定"
-"することが出来ます (どちらをinverseに選んだとしても、そちら側にはインデック"
+"2つの多対多関連で同じデータベーステーブルをマッピングし、片方を "
+"<emphasis>inverse</emphasis> として宣言することで、双方向の多対多関連を指定す"
+"ることが出来ます (どちらを inverse に選んだとしても、そちら側にはインデック"
 "ス付きのコレクションは使えません)。"
 
 #. Tag: para
-#: collection_mapping.xml:718
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Here is an example of a bidirectional many-to-many association that "
 "illustrates how each category can have many items and each item can be in "
 "many categories:"
 msgstr ""
-"次に双方向の多対多関連の例を示します。 各カテゴリは多数のアイテムを持つことが"
+"次に双方向の多対多関連の例を示します。各カテゴリは多数のアイテムを持つことが"
 "でき、各アイテムは多くのカテゴリに属することが出来ます。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:723
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Category\">\n"
-"    <id name=\"id\" column=\"CATEGORY_ID\"/>\n"
-"    ...\n"
-"    <bag name=\"items\" table=\"CATEGORY_ITEM\">\n"
-"        <key column=\"CATEGORY_ID\"/>\n"
-"        <many-to-many class=\"Item\" column=\"ITEM_ID\"/>\n"
-"    </bag>\n"
-"</class>\n"
-"\n"
-"<class name=\"Item\">\n"
-"    <id name=\"id\" column=\"ITEM_ID\"/>\n"
-"    ...\n"
-"\n"
-"    <!-- inverse end -->\n"
-"    <bag name=\"categories\" table=\"CATEGORY_ITEM\" inverse=\"true\">\n"
-"        <key column=\"ITEM_ID\"/>\n"
-"        <many-to-many class=\"Category\" column=\"CATEGORY_ID\"/>\n"
-"    </bag>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:725
-#, fuzzy, no-c-format
-msgid ""
 "Changes made only to the inverse end of the association are <emphasis>not</"
 "emphasis> persisted. This means that Hibernate has two representations in "
 "memory for every bidirectional association: one link from A to B and another "
 "link from B to A. This is easier to understand if you think about the Java "
 "object model and how a many-to-many relationship in Javais created:"
 msgstr ""
-"関連のinverse側にのみ行われた変更は永続化 <emphasis>されません</emphasis>。 "
-"これは、Hibernateは全ての双方向関連について、メモリ上に2つの表現を持っている"
-"という意味です。 つまり一つはAからBへのリンクで、もう一つはBからAへのリンクと"
-"いうことです。 Javaのオブジェクトモデルについて考え、Javaで双方向関係をどう"
-"やって作るかを考えれば、 これは理解しやすいです。下記に、Javaでの双方向関連を"
-"示します。"
+"関連の inverse 側にのみ行われた変更は永続化 <emphasis>されません</emphasis>。"
+"これは、 Hibernate は全ての双方向関連について、メモリ上に2つの表現を持ってい"
+"るという意味です。つまり一つは A から B へのリンクで、もう一つは B から A へ"
+"のリンクということです。 Java のオブジェクトモデルについて考え、 Java で双方"
+"向関係をどうやって作るかを考えれば、これは理解しやすいです。下記に、 Java で"
+"の双方向関連を示します。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:733
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"category.getItems().add(item);          // The category now \"knows\" about "
-"the relationship\n"
-"item.getCategories().add(category);     // The item now \"knows\" about the "
-"relationship\n"
-"\n"
-"session.persist(item);                   // The relationship won't be "
-"saved!\n"
-"session.persist(category);               // The relationship will be saved]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:735
 #, no-c-format
 msgid ""
 "The non-inverse side is used to save the in-memory representation to the "
 "database."
 msgstr ""
-"関連のinverseではない側は、メモリ上の表現をデータベースに保存するのに使われま"
-"す。"
+"関連の inverse ではない側は、メモリ上の表現をデータベースに保存するのに使われ"
+"ます。"
 
 #. Tag: para
-#: collection_mapping.xml:739
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can define a bidirectional one-to-many association by mapping a one-to-"
 "many association to the same table column(s) as a many-to-one association "
 "and declaring the many-valued end <literal>inverse=\"true\"</literal>."
 msgstr ""
-"双方向の一対多関連を定義するには、 一対多関連を多対一関連と同じテーブルのカラ"
-"ムにマッピングし、 多側に <literal>inverse=\"true\"</literal> と宣言します。"
+"双方向の一対多関連を定義するには、一対多関連を多対一関連と同じテーブルのカラ"
+"ムにマッピングし、多側に <literal>inverse=\"true\"</literal> と宣言します。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:745
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <set name=\"children\" inverse=\"true\">\n"
-"        <key column=\"parent_id\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:747
-#, fuzzy, no-c-format
-msgid ""
 "Mapping one end of an association with <literal>inverse=\"true\"</literal> "
 "does not affect the operation of cascades as these are orthogonal concepts."
 msgstr ""
-"関連の片側に <literal>inverse=\"true\"</literal> を設定しても、 カスケード操"
-"作に影響を与えません。これらは直交した概念です!"
+"関連の片側に <literal>inverse=\"true\"</literal> を設定しても、カスケード操作"
+"に影響を与えません。これらは直交した概念です。"
 
 #. Tag: title
-#: collection_mapping.xml:755
 #, no-c-format
 msgid "Bidirectional associations with indexed collections"
 msgstr "インデックス付きコレクションと双方向関連"
 
 #. Tag: para
-#: collection_mapping.xml:756
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A bidirectional association where one end is represented as a <literal>&lt;"
 "list&gt;</literal> or <literal>&lt;map&gt;</literal>, requires special "
@@ -1290,155 +962,71 @@
 "collection mapping:"
 msgstr ""
 "片側が <literal>&lt;list&gt;</literal> や <literal>&lt;map&gt;</literal> であ"
-"る 双方向関連は、特によく考える必要があります。 インデックスカラムにマップさ"
-"れる子クラスのプロパティがある場合は、問題ないです。 コレクションのマッピング"
-"で <literal>inverse=\"true\"</literal> を使い続けられます。"
+"る双方向関連は、特によく考える必要があります。インデックスカラムにマップされ"
+"る子クラスのプロパティがある場合は、問題ないです。コレクションのマッピングで "
+"<literal>inverse=\"true\"</literal> を使い続けられます。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:763
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <map name=\"children\" inverse=\"true\">\n"
-"        <key column=\"parent_id\"/>\n"
-"        <map-key column=\"name\" \n"
-"            type=\"string\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </map>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <property name=\"name\" \n"
-"        not-null=\"true\"/>\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:765
-#, fuzzy, no-c-format
-msgid ""
 "If there is no such property on the child class, the association cannot be "
 "considered truly bidirectional. That is, there is information available at "
 "one end of the association that is not available at the other end. In this "
 "case, you cannot map the collection <literal>inverse=\"true\"</literal>. "
 "Instead, you could use the following mapping:"
 msgstr ""
-"しかし、子クラスにそのようなプロパティがない場合は、 関連を真に双方向であると"
+"しかし、子クラスにそのようなプロパティがない場合は、関連を真に双方向であると"
 "考えることができません (関連の片側に利用できる情報がありますが、もう一方には"
-"ありません)。 この場合は、コレクションに <literal>inverse=\"true\"</"
-"literal> をマッピングできません。 代わりに、次のようなマッピングが使えます。"
+"ありません)。この場合は、コレクションに <literal>inverse=\"true\"</literal> "
+"をマッピングできません。代わりに、次のようなマッピングが使えます:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:772
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <map name=\"children\">\n"
-"        <key column=\"parent_id\"\n"
-"            not-null=\"true\"/>\n"
-"        <map-key column=\"name\" \n"
-"            type=\"string\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </map>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        insert=\"false\"\n"
-"        update=\"false\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:774
 #, fuzzy, no-c-format
 msgid ""
 "Note that in this mapping, the collection-valued end of the association is "
 "responsible for updates to the foreign key."
 msgstr ""
-"注意: このマッピングでは、関連のコレクション値の側は、 外部キーをアップデー"
-"トする責任があります。"
+"注意: このマッピングでは、関連のコレクション値の側は、外部キーをアップデート"
+"する責任があります。 <!-- TODO: これは本当にいくつかの不必要なアップデートス"
+"テートメントをもたらすのでしょうか? -->"
 
 #. Tag: title
-#: collection_mapping.xml:782
 #, no-c-format
 msgid "Ternary associations"
 msgstr "3項関連"
 
 #. Tag: para
-#: collection_mapping.xml:784
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are three possible approaches to mapping a ternary association. One "
 "approach is to use a <literal>Map</literal> with an association as its index:"
 msgstr ""
-"3項関連のマッピングには3つのアプローチがあります。 1つ目は関連をインデックス"
-"として <literal>Map</literal> を使用するアプローチです。"
+"3項関連のマッピングには3つのアプローチがあります。1つ目は関連をインデックスと"
+"して <literal>Map</literal> を使用するアプローチです:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:789
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<map name=\"contracts\">\n"
-"    <key column=\"employer_id\" not-null=\"true\"/>\n"
-"    <map-key-many-to-many column=\"employee_id\" class=\"Employee\"/>\n"
-"    <one-to-many class=\"Contract\"/>\n"
-"</map>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: collection_mapping.xml:791
-#, no-c-format
-msgid ""
-"<![CDATA[<map name=\"connections\">\n"
-"    <key column=\"incoming_node_id\"/>\n"
-"    <map-key-many-to-many column=\"outgoing_node_id\" class=\"Node\"/>\n"
-"    <many-to-many column=\"connection_id\" class=\"Connection\"/>\n"
-"</map>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:793
-#, fuzzy, no-c-format
-msgid ""
 "A second approach is to remodel the association as an entity class. This is "
 "the most common approach."
 msgstr ""
-"2つ目は単純に関連をエンティティ・クラスとしてモデルを作り直すアプローチで、 頻"
-"繁に使われます。"
+"2つ目は単純に関連をエンティティクラスとしてモデルを作り直すアプローチで、頻繁"
+"に使われます。"
 
 #. Tag: para
-#: collection_mapping.xml:798
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A final alternative is to use composite elements, which will be discussed "
 "later."
 msgstr ""
-"最後はcomposite要素を使うアプローチです。これに関する議論は後ほど行います。"
+"最後は composite 要素を使うアプローチです。これに関する議論は後ほど行います。"
 
-#. Tag: literal
-#: collection_mapping.xml:805
-#, no-c-format
-msgid "Using an &lt;idbag&gt;"
-msgstr "<literal>&lt;idbag&gt;</literal>の使用"
+#. Tag: title
+#, fuzzy, no-c-format
+msgid "<literal>Using an &lt;idbag&gt;</literal>"
+msgstr "&lt;idbag&gt;の使用"
 
 #. Tag: para
-#: collection_mapping.xml:807
 #, fuzzy, no-c-format
 msgid ""
 "The majority of the many-to-many associations and collections of values "
@@ -1451,476 +1039,961 @@
 "values to a table with a surrogate key."
 msgstr ""
 "複合キーは悪いもので、エンティティは人工の識別子(代理キー)を持つべきであると"
-"いう考え方からは、 多対多関連と値のコレクションを複合キーを用いたテーブルへ"
-"マッピングするのは少し奇妙に感じるかもしれません! 確かにこの考え方には議論の"
-"余地があります。 純粋な関連テーブルは代理キーを使っても利益を得られないように"
+"いう考え方からは、多対多関連と値のコレクションを複合キーを用いたテーブルへ"
+"マッピングするのは少し奇妙に感じるかもしれません。確かにこの考え方には議論の"
+"余地があります。純粋な関連テーブルは代理キーを使っても利益を得られないように"
 "思えるからです (合成値のコレクションは利益がある <emphasis>かも</emphasis> "
-"しれませんが)。 とはいえ、Hibernateは代理キーを持つテーブルへ多対多関連と値"
-"のコレクションを マッピングする機能も備えています。"
+"しれませんが)。とはいえ、 Hibernate は代理キーを持つテーブルへ多対多関連と値"
+"のコレクションをマッピングする機能も備えています。"
 
 #. Tag: para
-#: collection_mapping.xml:817
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;idbag&gt;</literal> element lets you map a <literal>List</"
 "literal> (or <literal>Collection</literal>) with bag semantics. For example:"
 msgstr ""
-"bagのセマンティックスを持った <literal>List</literal>(または "
+"bag のセマンティックスを持った <literal>List</literal>(または "
 "<literal>Collection</literal>)を <literal>&lt;idbag&gt;</literal> 要素にマッ"
 "ピングできます。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:822
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<idbag name=\"lovers\" table=\"LOVERS\">\n"
-"    <collection-id column=\"ID\" type=\"long\">\n"
-"        <generator class=\"sequence\"/>\n"
-"    </collection-id>\n"
-"    <key column=\"PERSON1\"/>\n"
-"    <many-to-many column=\"PERSON2\" class=\"Person\" fetch=\"join\"/>\n"
-"</idbag>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:824
-#, fuzzy, no-c-format
-msgid ""
 "An <literal>&lt;idbag&gt;</literal> has a synthetic id generator, just like "
 "an entity class. A different surrogate key is assigned to each collection "
 "row. Hibernate does not, however, provide any mechanism for discovering the "
 "surrogate key value of a particular row."
 msgstr ""
-"ご存知のように <literal>&lt;idbag&gt;</literal> はエンティティ・クラスのよう"
-"に 人工的なidジェネレータを持っています! 異なる代理キーをそれぞれのコレク"
-"ションの列に割り当てます。 しかしながら、Hibernateはある行の代理キーの値を見"
-"つけ出す機構を持っていません。"
+"ご存知のように <literal>&lt;idbag&gt;</literal> はエンティティクラスのように"
+"人工的な id ジェネレータを持っています。異なる代理キーをそれぞれのコレクショ"
+"ンの列に割り当てます。しかし、 Hibernate はある行の代理キーの値を見つけ出す機"
+"構を持っていません。"
 
 #. Tag: para
-#: collection_mapping.xml:831
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The update performance of an <literal>&lt;idbag&gt;</literal> supersedes a "
 "regular <literal>&lt;bag&gt;</literal>. Hibernate can locate individual rows "
 "efficiently and update or delete them individually, similar to a list, map "
 "or set."
 msgstr ""
-"<literal>&lt;idbag&gt;</literal> を更新するパフォーマンスは 通常の "
-"<literal>&lt;bag&gt;</literal> よりも良いことに注目してください! Hibernateは"
-"個々の行を効果的に見つけることができ、 listやmap、setのように個別にその行を更"
-"新、削除できます。"
+"<literal>&lt;idbag&gt;</literal> を更新するパフォーマンスは通常の "
+"<literal>&lt;bag&gt;</literal> よりも良いことに注目してください。 Hibernate "
+"は個々の行を効果的に見つけることができ、 list や map 、 set のように個別にそ"
+"の行を更新、削除できます。"
 
 #. Tag: para
-#: collection_mapping.xml:837
 #, no-c-format
 msgid ""
 "In the current implementation, the <literal>native</literal> identifier "
 "generation strategy is not supported for <literal>&lt;idbag&gt;</literal> "
 "collection identifiers."
 msgstr ""
-"現在の実装では、<literal>native</literal> というid生成戦略を <literal>&lt;"
+"現在の実装では、 <literal>native</literal> という id 生成戦略を <literal>&lt;"
 "idbag&gt;</literal> コレクションの識別子に対して使えません。"
 
 #. Tag: title
-#: collection_mapping.xml:861
 #, no-c-format
 msgid "Collection examples"
 msgstr "コレクションの例"
 
 #. Tag: para
-#: collection_mapping.xml:863
 #, fuzzy, no-c-format
 msgid "This section covers collection examples."
 msgstr "コレクションの例"
 
 #. Tag: para
-#: collection_mapping.xml:867
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The following class has a collection of <literal>Child</literal> instances:"
 msgstr ""
+"以下のコードを使えば、新しい <literal>Child</literal> を追加することができま"
+"す。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:871
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"\n"
-"public class Parent {\n"
-"    private long id;\n"
-"    private Set children;\n"
-"\n"
-"    public long getId() { return id; }\n"
-"    private void setId(long id) { this.id=id; }\n"
-"\n"
-"    private Set getChildren() { return children; }\n"
-"    private void setChildren(Set children) { this.children=children; }\n"
-"\n"
-"    ....\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:873
 #, fuzzy, no-c-format
 msgid ""
 "If each child has, at most, one parent, the most natural mapping is a one-to-"
 "many association:"
 msgstr ""
 "このクラスは <literal>Child</literal> インスタンスのコレクションを持っていま"
-"す。 もし各々のchildが最大でも一つのparentを持っているならば、最も自然なマッ"
-"ピングは一対多関連です。"
+"す。もし各々の child が最大でも一つの parent を持っているならば、最も自然な"
+"マッピングは一対多関連です。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:879
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:881
 #, no-c-format
 msgid "This maps to the following table definitions:"
 msgstr "これは以下のテーブル定義にマッピングします。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:885
-#, no-c-format
-msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null primary key, name varchar(255), "
-"parent_id bigint )\n"
-"alter table child add constraint childfk0 (parent_id) references parent]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:887
 #, no-c-format
 msgid ""
 "If the parent is <emphasis>required</emphasis>, use a bidirectional one-to-"
 "many association:"
 msgstr ""
-"もしparentが <emphasis>要求</emphasis> されるなら、双方向の一対多関連を使用し"
-"てください。"
+"もし parent が <emphasis>要求</emphasis> されるなら、双方向の一対多関連を使用"
+"してください:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:892
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\" inverse=\"true\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"        <many-to-one name=\"parent\" class=\"Parent\" column=\"parent_id\" "
-"not-null=\"true\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:894
 #, no-c-format
 msgid "Notice the <literal>NOT NULL</literal> constraint:"
 msgstr "<literal>NOT NULL</literal> 制約に注意してください。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:898
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null\n"
-"                     primary key,\n"
-"                     name varchar(255),\n"
-"                     parent_id bigint not null )\n"
-"alter table child add constraint childfk0 (parent_id) references parent]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:900
-#, fuzzy, no-c-format
-msgid ""
 "Alternatively, if this association must be unidirectional you can declare "
 "the <literal>NOT NULL</literal> constraint on the <literal>&lt;key&gt;</"
 "literal> mapping:"
 msgstr ""
 "あるいは、もしこの関連は単方向であるべきと強く主張するのであれば、 "
-"<literal>&lt;key&gt;</literal> に <literal>NOT NULL</literal> 制約を宣言でき"
-"ます。"
+"<literal>&lt;key&gt;</literal> マッピングに <literal>NOT NULL</literal> 制約"
+"を宣言できます:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:906
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\">\n"
-"            <key column=\"parent_id\" not-null=\"true\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:908
-#, fuzzy, no-c-format
-msgid ""
 "On the other hand, if a child has multiple parents, a many-to-many "
 "association is appropriate:"
-msgstr "一方で、もしchildが複数のparentを持てるならば、多対多関連が妥当です。"
-
-#. Tag: programlisting
-#: collection_mapping.xml:913
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\" table=\"childset\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <many-to-many class=\"Child\" column=\"child_id\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
 msgstr ""
+"一方で、もし child が複数の parent を持てるならば、多対多関連が妥当です:"
 
 #. Tag: para
-#: collection_mapping.xml:915
 #, no-c-format
 msgid "Table definitions:"
-msgstr "テーブル定義は以下のようになります。"
+msgstr "テーブル定義は以下のようになります:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:919
-#, no-c-format
-msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null primary key, name varchar(255) )\n"
-"create table childset ( parent_id bigint not null,\n"
-"                        child_id bigint not null,\n"
-"                        primary key ( parent_id, child_id ) )\n"
-"alter table childset add constraint childsetfk0 (parent_id) references "
-"parent\n"
-"alter table childset add constraint childsetfk1 (child_id) references child]]"
-">"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:921
 #, fuzzy, no-c-format
 msgid ""
 "For more examples and a complete explanation of a parent/child relationship "
-"mapping, see <xref linkend=\"example-parentchild\"/> for more information."
+"mapping, see <xref linkend=\"example-parentchild\" /> for more information."
 msgstr ""
-"parent/child関係のマッピングについてのより多くの例や完全な手順が必要であれ"
+"parent/child 関係のマッピングについてのより多くの例や完全な手順が必要であれ"
 "ば、 <xref linkend=\"example-parentchild\"/> をご覧ください。"
 
 #. Tag: para
-#: collection_mapping.xml:926
 #, fuzzy, no-c-format
 msgid "Even more complex association mappings are covered in the next chapter."
 msgstr "また、さらに特殊な関連マッピングも可能です。次の章で詳しく述べます。"
 
-#~ msgid "Collection Mapping"
-#~ msgstr "コレクションのマッピング"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[public class Product {\n"
+#~ "    private String serialNumber;\n"
+#~ "    private Set parts = new HashSet();\n"
+#~ "    \n"
+#~ "    public Set getParts() { return parts; }\n"
+#~ "    void setParts(Set parts) { this.parts = parts; }\n"
+#~ "    public String getSerialNumber() { return serialNumber; }\n"
+#~ "    void setSerialNumber(String sn) { serialNumber = sn; }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "public class Product {\n"
+#~ "    private String serialNumber;\n"
+#~ "    private Set parts = new HashSet();\n"
+#~ "    \n"
+#~ "    public Set getParts() { return parts; }\n"
+#~ "    void setParts(Set parts) { this.parts = parts; }\n"
+#~ "    public String getSerialNumber() { return serialNumber; }\n"
+#~ "    void setSerialNumber(String sn) { serialNumber = sn; }\n"
+#~ "}"
 
-#~ msgid "Some examples, first, a set of strings:"
-#~ msgstr "以下にいくつか例を示します。 まずはStringのsetに関しての例です。"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Cat cat = new DomesticCat();\n"
+#~ "Cat kitten = new DomesticCat();\n"
+#~ "....\n"
+#~ "Set kittens = new HashSet();\n"
+#~ "kittens.add(kitten);\n"
+#~ "cat.setKittens(kittens);\n"
+#~ "session.persist(cat);\n"
+#~ "kittens = cat.getKittens(); // Okay, kittens collection is a Set\n"
+#~ "(HashSet) cat.getKittens(); // Error!]]>"
+#~ msgstr ""
+#~ "Cat cat = new DomesticCat();\n"
+#~ "Cat kitten = new DomesticCat();\n"
+#~ "....\n"
+#~ "Set kittens = new HashSet();\n"
+#~ "kittens.add(kitten);\n"
+#~ "cat.setKittens(kittens);\n"
+#~ "session.persist(cat);\n"
+#~ "kittens = cat.getKittens(); // Okay, kittens collection is a Set\n"
+#~ "(HashSet) cat.getKittens(); // Error!"
 
+#, fuzzy
 #~ msgid ""
-#~ "The previous sections are pretty confusing. So lets look at an example. "
-#~ "This class:"
-#~ msgstr "これまでの節の説明では理解しにくいので、以下の例を見てください。"
+#~ "<![CDATA[<class name=\"Product\">\n"
+#~ "    <id name=\"serialNumber\" column=\"productSerialNumber\"/>\n"
+#~ "    <set name=\"parts\">\n"
+#~ "        <key column=\"productSerialNumber\" not-null=\"true\"/>\n"
+#~ "        <one-to-many class=\"Part\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Product\"&gt;\n"
+#~ "    &lt;id name=\"serialNumber\" column=\"productSerialNumber\"/&gt;\n"
+#~ "    &lt;set name=\"parts\"&gt;\n"
+#~ "        &lt;key column=\"productSerialNumber\" not-null=\"true\"/&gt;\n"
+#~ "        &lt;one-to-many class=\"Part\"/&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>column_name</literal> (required): The name of the column holding "
-#~ "the collection index values."
+#~ "<![CDATA[<map\n"
+#~ "    name=\"propertyName\"\n"
+#~ "    table=\"table_name\"\n"
+#~ "    schema=\"schema_name\"\n"
+#~ "    lazy=\"true|extra|false\"\n"
+#~ "    inverse=\"true|false\"\n"
+#~ "    cascade=\"all|none|save-update|delete|all-delete-orphan|delete-orphan"
+#~ "\"\n"
+#~ "    sort=\"unsorted|natural|comparatorClass\"\n"
+#~ "    order-by=\"column_name asc|desc\"\n"
+#~ "    where=\"arbitrary sql where condition\"\n"
+#~ "    fetch=\"join|select|subselect\"\n"
+#~ "    batch-size=\"N\"\n"
+#~ "    access=\"field|property|ClassName\"\n"
+#~ "    optimistic-lock=\"true|false\"\n"
+#~ "    mutable=\"true|false\"\n"
+#~ "    node=\"element-name|.\"\n"
+#~ "    embed-xml=\"true|false\"\n"
+#~ ">\n"
+#~ "\n"
+#~ "    <key .... />\n"
+#~ "    <map-key .... />\n"
+#~ "    <element .... />\n"
+#~ "</map>]]>"
 #~ msgstr ""
-#~ "<literal>column_name</literal>(必須):コレクションインデックスの値を保持"
-#~ "するカラムの名前。"
+#~ "&lt;map\n"
+#~ "    name=\"propertyName\"\n"
+#~ "    table=\"table_name\"\n"
+#~ "    schema=\"schema_name\"\n"
+#~ "    lazy=\"true|extra|false\"\n"
+#~ "    inverse=\"true|false\"\n"
+#~ "    cascade=\"all|none|save-update|delete|all-delete-orphan|delete-orphan"
+#~ "\"\n"
+#~ "    sort=\"unsorted|natural|comparatorClass\"\n"
+#~ "    order-by=\"column_name asc|desc\"\n"
+#~ "    where=\"arbitrary sql where condition\"\n"
+#~ "    fetch=\"join|select|subselect\"\n"
+#~ "    batch-size=\"N\"\n"
+#~ "    access=\"field|property|ClassName\"\n"
+#~ "    optimistic-lock=\"true|false\"\n"
+#~ "    mutable=\"true|false\"\n"
+#~ "    node=\"element-name|.\"\n"
+#~ "    embed-xml=\"true|false\"\n"
+#~ "&gt;\n"
+#~ "\n"
+#~ "    &lt;key .... /&gt;\n"
+#~ "    &lt;map-key .... /&gt;\n"
+#~ "    &lt;element .... /&gt;\n"
+#~ "&lt;/map&gt;"
 
+#, fuzzy
+#~ msgid "<![CDATA[<key column=\"productSerialNumber\" not-null=\"true\"/>]]>"
+#~ msgstr "&lt;key column=\"productSerialNumber\" not-null=\"true\"/&gt;"
+
+#, fuzzy
 #~ msgid ""
-#~ "<literal>base</literal> (optional, defaults to <literal>0</literal>): The "
-#~ "value of the index column that corresponds to the first element of the "
-#~ "list or array."
+#~ "<![CDATA[<key column=\"productSerialNumber\" on-delete=\"cascade\"/>]]>"
+#~ msgstr "&lt;key column=\"productSerialNumber\" on-delete=\"cascade\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<set name=\"names\" table=\"person_names\">\n"
+#~ "    <key column=\"person_id\"/>\n"
+#~ "    <element column=\"person_name\" type=\"string\"/>\n"
+#~ "</set>]]>"
 #~ msgstr ""
-#~ "<literal>base</literal>(オプション、デフォルトは <literal>0</literal>): "
-#~ "リストもしくは配列の最初の要素に該当するインデックスカラムの値。"
+#~ "&lt;set name=\"names\" table=\"person_names\"&gt;\n"
+#~ "    &lt;key column=\"person_id\"/&gt;\n"
+#~ "    &lt;element column=\"person_name\" type=\"string\"/&gt;\n"
+#~ "&lt;/set&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the column holding the "
-#~ "collection index values."
+#~ "<![CDATA[<bag name=\"sizes\" \n"
+#~ "        table=\"item_sizes\" \n"
+#~ "        order-by=\"size asc\">\n"
+#~ "    <key column=\"item_id\"/>\n"
+#~ "    <element column=\"size\" type=\"integer\"/>\n"
+#~ "</bag>]]>"
 #~ msgstr ""
-#~ "<literal>column</literal>(オプション): コレクションインデックスの値を保"
-#~ "持するカラムの名前。"
+#~ "&lt;bag name=\"sizes\" \n"
+#~ "        table=\"item_sizes\" \n"
+#~ "        order-by=\"size asc\"&gt;\n"
+#~ "    &lt;key column=\"item_id\"/&gt;\n"
+#~ "    &lt;element column=\"size\" type=\"integer\"/&gt;\n"
+#~ "&lt;/bag&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>formula</literal> (optional): A SQL formula used to evaluate the "
-#~ "key of the map."
+#~ "<![CDATA[<array name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\" \n"
+#~ "        cascade=\"persist\">\n"
+#~ "    <key column=\"personId\"/>\n"
+#~ "    <list-index column=\"sortOrder\"/>\n"
+#~ "    <many-to-many column=\"addressId\" class=\"Address\"/>\n"
+#~ "</array>]]>"
 #~ msgstr ""
-#~ "<literal>formula</literal>(オプション): Mapのキーを評価するのに使われる"
-#~ "SQL式。"
+#~ "&lt;array name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\" \n"
+#~ "        cascade=\"persist\"&gt;\n"
+#~ "    &lt;key column=\"personId\"/&gt;\n"
+#~ "    &lt;list-index column=\"sortOrder\"/&gt;\n"
+#~ "    &lt;many-to-many column=\"addressId\" class=\"Address\"/&gt;\n"
+#~ "&lt;/array&gt;"
 
-#~ msgid "<literal>type</literal> (reguired): The type of the map keys."
-#~ msgstr "<literal>type</literal>(必須): Mapのキーの型。"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<map name=\"holidays\" \n"
+#~ "        table=\"holidays\" \n"
+#~ "        schema=\"dbo\" \n"
+#~ "        order-by=\"hol_name asc\">\n"
+#~ "    <key column=\"id\"/>\n"
+#~ "    <map-key column=\"hol_name\" type=\"string\"/>\n"
+#~ "    <element column=\"hol_date\" type=\"date\"/>\n"
+#~ "</map>]]>"
+#~ msgstr ""
+#~ "&lt;map name=\"holidays\" \n"
+#~ "        table=\"holidays\" \n"
+#~ "        schema=\"dbo\" \n"
+#~ "        order-by=\"hol_name asc\"&gt;\n"
+#~ "    &lt;key column=\"id\"/&gt;\n"
+#~ "    &lt;map-key column=\"hol_name\" type=\"string\"/&gt;\n"
+#~ "    &lt;element column=\"hol_date\" type=\"date\"/&gt;\n"
+#~ "&lt;/map&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the foreign key column "
-#~ "for the collection index values."
+#~ "<![CDATA[<list name=\"carComponents\" \n"
+#~ "        table=\"CarComponents\">\n"
+#~ "    <key column=\"carId\"/>\n"
+#~ "    <list-index column=\"sortOrder\"/>\n"
+#~ "    <composite-element class=\"CarComponent\">\n"
+#~ "        <property name=\"price\"/>\n"
+#~ "        <property name=\"type\"/>\n"
+#~ "        <property name=\"serialNumber\" column=\"serialNum\"/>\n"
+#~ "    </composite-element>\n"
+#~ "</list>]]>"
 #~ msgstr ""
-#~ "<literal>column</literal> (オプション): コレクションインデックスの値のた"
-#~ "めの外部キーカラムの名前。"
+#~ "&lt;list name=\"carComponents\" \n"
+#~ "        table=\"CarComponents\"&gt;\n"
+#~ "    &lt;key column=\"carId\"/&gt;\n"
+#~ "    &lt;list-index column=\"sortOrder\"/&gt;\n"
+#~ "    &lt;composite-element class=\"CarComponent\"&gt;\n"
+#~ "        &lt;property name=\"price\"/&gt;\n"
+#~ "        &lt;property name=\"type\"/&gt;\n"
+#~ "        &lt;property name=\"serialNumber\" column=\"serialNum\"/&gt;\n"
+#~ "    &lt;/composite-element&gt;\n"
+#~ "&lt;/list&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>formula</literal> (optional): A SQL formula used to evaluate the "
-#~ "foreign key of the map key."
+#~ "<![CDATA[<one-to-many \n"
+#~ "        class=\"ClassName\"\n"
+#~ "        not-found=\"ignore|exception\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "        embed-xml=\"true|false\"\n"
+#~ "    />]]>"
 #~ msgstr ""
-#~ "<literal>formula</literal> (オプション): Mapのキーのための外部キーを評価"
-#~ "するために使うSQL式。"
+#~ "&lt;one-to-many \n"
+#~ "        class=\"ClassName\"\n"
+#~ "        not-found=\"ignore|exception\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "        embed-xml=\"true|false\"\n"
+#~ "    /&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>class</literal> (required): The entity class used as the map key."
+#~ "<![CDATA[<map name=\"parts\"\n"
+#~ "        cascade=\"all\">\n"
+#~ "    <key column=\"productId\" not-null=\"true\"/>\n"
+#~ "    <map-key formula=\"partName\"/>\n"
+#~ "    <one-to-many class=\"Part\"/>\n"
+#~ "</map>]]>"
 #~ msgstr ""
-#~ "<literal>class</literal> (必須): Mapのキーとして使われるエンティティクラ"
-#~ "ス。"
+#~ "&lt;map name=\"parts\"\n"
+#~ "        cascade=\"all\"&gt;\n"
+#~ "    &lt;key column=\"productId\" not-null=\"true\"/&gt;\n"
+#~ "    &lt;map-key formula=\"partName\"/&gt;\n"
+#~ "    &lt;one-to-many class=\"Part\"/&gt;\n"
+#~ "&lt;/map&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the column holding the "
-#~ "collection element values."
+#~ "<![CDATA[<set name=\"aliases\" \n"
+#~ "            table=\"person_aliases\" \n"
+#~ "            sort=\"natural\">\n"
+#~ "    <key column=\"person\"/>\n"
+#~ "    <element column=\"name\" type=\"string\"/>\n"
+#~ "</set>\n"
+#~ "\n"
+#~ "<map name=\"holidays\" sort=\"my.custom.HolidayComparator\">\n"
+#~ "    <key column=\"year_id\"/>\n"
+#~ "    <map-key column=\"hol_name\" type=\"string\"/>\n"
+#~ "    <element column=\"hol_date\" type=\"date\"/>\n"
+#~ "</map>]]>"
 #~ msgstr ""
-#~ "<literal>column</literal> (オプション): コレクションの要素の値を保持する"
-#~ "カラムの名前。"
+#~ "&lt;set name=\"aliases\" \n"
+#~ "            table=\"person_aliases\" \n"
+#~ "            sort=\"natural\"&gt;\n"
+#~ "    &lt;key column=\"person\"/&gt;\n"
+#~ "    &lt;element column=\"name\" type=\"string\"/&gt;\n"
+#~ "&lt;/set&gt;\n"
+#~ "\n"
+#~ "&lt;map name=\"holidays\" sort=\"my.custom.HolidayComparator\"&gt;\n"
+#~ "    &lt;key column=\"year_id\"/&gt;\n"
+#~ "    &lt;map-key column=\"hol_name\" type=\"string\"/&gt;\n"
+#~ "    &lt;element column=\"hol_date\" type=\"date\"/&gt;\n"
+#~ "&lt;/map&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>formula</literal> (optional): An SQL formula used to evaluate "
-#~ "the element."
+#~ "<![CDATA[<set name=\"aliases\" table=\"person_aliases\" order-by=\"lower"
+#~ "(name) asc\">\n"
+#~ "    <key column=\"person\"/>\n"
+#~ "    <element column=\"name\" type=\"string\"/>\n"
+#~ "</set>\n"
+#~ "\n"
+#~ "<map name=\"holidays\" order-by=\"hol_date, hol_name\">\n"
+#~ "    <key column=\"year_id\"/>\n"
+#~ "    <map-key column=\"hol_name\" type=\"string\"/>\n"
+#~ "    <element column=\"hol_date type=\"date\"/>\n"
+#~ "</map>]]>"
 #~ msgstr ""
-#~ "<literal>formula</literal> (オプション): 要素を評価するために使うSQL式。"
+#~ "&lt;set name=\"aliases\" table=\"person_aliases\" order-by=\"lower(name) "
+#~ "asc\"&gt;\n"
+#~ "    &lt;key column=\"person\"/&gt;\n"
+#~ "    &lt;element column=\"name\" type=\"string\"/&gt;\n"
+#~ "&lt;/set&gt;\n"
+#~ "\n"
+#~ "&lt;map name=\"holidays\" order-by=\"hol_date, hol_name\"&gt;\n"
+#~ "    &lt;key column=\"year_id\"/&gt;\n"
+#~ "    &lt;map-key column=\"hol_name\" type=\"string\"/&gt;\n"
+#~ "    &lt;element column=\"hol_date type=\"date\"/&gt;\n"
+#~ "&lt;/map&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>type</literal> (required): The type of the collection element."
-#~ msgstr "<literal>type</literal> (必須)コレクションの要素の型。"
+#~ "<![CDATA[sortedUsers = s.createFilter( group.getUsers(), \"order by this."
+#~ "name\" ).list();]]>"
+#~ msgstr ""
+#~ "sortedUsers = s.createFilter( group.getUsers(), \"order by this.name\" )."
+#~ "list();"
 
+#, fuzzy
 #~ msgid ""
-#~ "A <emphasis>many-to-many association</emphasis> is specified using the "
-#~ "<literal>&lt;many-to-many&gt;</literal> element."
+#~ "<![CDATA[<class name=\"Category\">\n"
+#~ "    <id name=\"id\" column=\"CATEGORY_ID\"/>\n"
+#~ "    ...\n"
+#~ "    <bag name=\"items\" table=\"CATEGORY_ITEM\">\n"
+#~ "        <key column=\"CATEGORY_ID\"/>\n"
+#~ "        <many-to-many class=\"Item\" column=\"ITEM_ID\"/>\n"
+#~ "    </bag>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Item\">\n"
+#~ "    <id name=\"id\" column=\"ITEM_ID\"/>\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    <!-- inverse end -->\n"
+#~ "    <bag name=\"categories\" table=\"CATEGORY_ITEM\" inverse=\"true\">\n"
+#~ "        <key column=\"ITEM_ID\"/>\n"
+#~ "        <many-to-many class=\"Category\" column=\"CATEGORY_ID\"/>\n"
+#~ "    </bag>\n"
+#~ "</class>]]>"
 #~ msgstr ""
-#~ "<emphasis>多対多関連</emphasis> は <literal>&lt;many-to-many&gt;</"
-#~ "literal> 要素で指定します。"
+#~ "&lt;class name=\"Category\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"CATEGORY_ID\"/&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;bag name=\"items\" table=\"CATEGORY_ITEM\"&gt;\n"
+#~ "        &lt;key column=\"CATEGORY_ID\"/&gt;\n"
+#~ "        &lt;many-to-many class=\"Item\" column=\"ITEM_ID\"/&gt;\n"
+#~ "    &lt;/bag&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Item\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"CATEGORY_ID\"/&gt;\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    &lt;!-- inverse end --&gt;\n"
+#~ "    &lt;bag name=\"categories\" table=\"CATEGORY_ITEM\" inverse=\"true"
+#~ "\"&gt;\n"
+#~ "        &lt;key column=\"ITEM_ID\"/&gt;\n"
+#~ "        &lt;many-to-many class=\"Category\" column=\"CATEGORY_ID\"/&gt;\n"
+#~ "    &lt;/bag&gt;\n"
+#~ "&lt;/class&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the element foreign key "
-#~ "column."
+#~ "<![CDATA[\n"
+#~ "category.getItems().add(item);          // The category now \"knows\" "
+#~ "about the relationship\n"
+#~ "item.getCategories().add(category);     // The item now \"knows\" about "
+#~ "the relationship\n"
+#~ "\n"
+#~ "session.persist(item);                   // The relationship won't be "
+#~ "saved!\n"
+#~ "session.persist(category);               // The relationship will be "
+#~ "saved]]>"
 #~ msgstr ""
-#~ "<literal>column</literal> (オプション): 外部キーカラムの要素の名前。"
+#~ "category.getItems().add(item);          // The category now \"knows\" "
+#~ "about the relationship\n"
+#~ "item.getCategories().add(category);     // The item now \"knows\" about "
+#~ "the relationship\n"
+#~ "\n"
+#~ "session.persist(item);                   // The relationship won't be "
+#~ "saved!\n"
+#~ "session.persist(category);               // The relationship will be saved"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>formula</literal> (optional): An SQL formula used to evaluate "
-#~ "the element foreign key value."
+#~ "<![CDATA[<class name=\"Parent\">\n"
+#~ "    <id name=\"id\" column=\"parent_id\"/>\n"
+#~ "    ....\n"
+#~ "    <set name=\"children\" inverse=\"true\">\n"
+#~ "        <key column=\"parent_id\"/>\n"
+#~ "        <one-to-many class=\"Child\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Child\">\n"
+#~ "    <id name=\"id\" column=\"child_id\"/>\n"
+#~ "    ....\n"
+#~ "    <many-to-one name=\"parent\" \n"
+#~ "        class=\"Parent\" \n"
+#~ "        column=\"parent_id\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>]]>"
 #~ msgstr ""
-#~ "<literal>formula</literal> (オプション): 外部キー値の要素を評価するため"
-#~ "に使うSQL式。"
+#~ "&lt;class name=\"Parent\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"parent_id\"/&gt;\n"
+#~ "    ....\n"
+#~ "    &lt;set name=\"children\" inverse=\"true\"&gt;\n"
+#~ "        &lt;key column=\"parent_id\"/&gt;\n"
+#~ "        &lt;one-to-many class=\"Child\"/&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Child\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"child_id\"/&gt;\n"
+#~ "    ....\n"
+#~ "    &lt;many-to-one name=\"parent\" \n"
+#~ "        class=\"Parent\" \n"
+#~ "        column=\"parent_id\"\n"
+#~ "        not-null=\"true\"/&gt;\n"
+#~ "&lt;/class&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>fetch</literal> (optional - defaults to <literal>join</"
-#~ "literal>): enables outer-join or sequential select fetching for this "
-#~ "association. This is a special case; for full eager fetching (in a single "
-#~ "<literal>SELECT</literal>) of an entity and its many-to-many "
-#~ "relationships to other entities, you would enable <literal>join</literal> "
-#~ "fetching not only of the collection itself, but also with this attribute "
-#~ "on the <literal>&lt;many-to-many&gt;</literal> nested element."
+#~ "<![CDATA[<class name=\"Parent\">\n"
+#~ "    <id name=\"id\" column=\"parent_id\"/>\n"
+#~ "    ....\n"
+#~ "    <map name=\"children\" inverse=\"true\">\n"
+#~ "        <key column=\"parent_id\"/>\n"
+#~ "        <map-key column=\"name\" \n"
+#~ "            type=\"string\"/>\n"
+#~ "        <one-to-many class=\"Child\"/>\n"
+#~ "    </map>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Child\">\n"
+#~ "    <id name=\"id\" column=\"child_id\"/>\n"
+#~ "    ....\n"
+#~ "    <property name=\"name\" \n"
+#~ "        not-null=\"true\"/>\n"
+#~ "    <many-to-one name=\"parent\" \n"
+#~ "        class=\"Parent\" \n"
+#~ "        column=\"parent_id\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>]]>"
 #~ msgstr ""
-#~ "<literal>fetch</literal> (オプション - デフォルトは <literal>join</"
-#~ "literal>): 関連のために、外部結合か順次選択フェッチを有効にします。 これは"
-#~ "特殊なケースですが、エンティティと他のエンティティとの多対多関係を (1つ"
-#~ "の <literal>SELECT</literal> により)完全に即時にフェッチするためには、 そ"
-#~ "のコレクション自体だけでなく、 ネストした要素である <literal>&lt;many-to-"
-#~ "many&gt;</literal> のこの属性についても <literal>join</literal> フェッチを"
-#~ "有効する必要があります。"
+#~ "&lt;class name=\"Parent\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"parent_id\"/&gt;\n"
+#~ "    ....\n"
+#~ "    &lt;map name=\"children\" inverse=\"true\"&gt;\n"
+#~ "        &lt;key column=\"parent_id\"/&gt;\n"
+#~ "        &lt;map-key column=\"name\" \n"
+#~ "            type=\"string\"/&gt;\n"
+#~ "        &lt;one-to-many class=\"Child\"/&gt;\n"
+#~ "    &lt;/map&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Child\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"child_id\"/&gt;\n"
+#~ "    ....\n"
+#~ "    &lt;property name=\"name\" \n"
+#~ "        not-null=\"true\"/&gt;\n"
+#~ "    &lt;many-to-one name=\"parent\" \n"
+#~ "        class=\"Parent\" \n"
+#~ "        column=\"parent_id\"\n"
+#~ "        not-null=\"true\"/&gt;\n"
+#~ "&lt;/class&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>unique</literal> (optional): Enable the DDL generation of a "
-#~ "unique constraint for the foreign-key column. This makes the association "
-#~ "multiplicity effectively one to many."
+#~ "<![CDATA[<class name=\"Parent\">\n"
+#~ "    <id name=\"id\" column=\"parent_id\"/>\n"
+#~ "    ....\n"
+#~ "    <map name=\"children\">\n"
+#~ "        <key column=\"parent_id\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        <map-key column=\"name\" \n"
+#~ "            type=\"string\"/>\n"
+#~ "        <one-to-many class=\"Child\"/>\n"
+#~ "    </map>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Child\">\n"
+#~ "    <id name=\"id\" column=\"child_id\"/>\n"
+#~ "    ....\n"
+#~ "    <many-to-one name=\"parent\" \n"
+#~ "        class=\"Parent\" \n"
+#~ "        column=\"parent_id\"\n"
+#~ "        insert=\"false\"\n"
+#~ "        update=\"false\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>]]>"
 #~ msgstr ""
-#~ "<literal>unique</literal> (オプション): 外部キーカラムのユニーク制約の"
-#~ "DDL生成を有効にします。 これは、関連の多重度を事実上一対多にします。"
+#~ "&lt;class name=\"Parent\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"parent_id\"/&gt;\n"
+#~ "    ....\n"
+#~ "    &lt;map name=\"children\"&gt;\n"
+#~ "        &lt;key column=\"parent_id\"\n"
+#~ "            not-null=\"true\"/&gt;\n"
+#~ "        &lt;map-key column=\"name\" \n"
+#~ "            type=\"string\"/&gt;\n"
+#~ "        &lt;one-to-many class=\"Child\"/&gt;\n"
+#~ "    &lt;/map&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Child\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"child_id\"/&gt;\n"
+#~ "    ....\n"
+#~ "    &lt;many-to-one name=\"parent\" \n"
+#~ "        class=\"Parent\" \n"
+#~ "        column=\"parent_id\"\n"
+#~ "        insert=\"false\"\n"
+#~ "        update=\"false\"\n"
+#~ "        not-null=\"true\"/&gt;\n"
+#~ "&lt;/class&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>not-found</literal> (optional - defaults to <literal>exception</"
-#~ "literal>): Specifies how foreign keys that reference missing rows will be "
-#~ "handled: <literal>ignore</literal> will treat a missing row as a null "
-#~ "association."
+#~ "<![CDATA[<map name=\"contracts\">\n"
+#~ "    <key column=\"employer_id\" not-null=\"true\"/>\n"
+#~ "    <map-key-many-to-many column=\"employee_id\" class=\"Employee\"/>\n"
+#~ "    <one-to-many class=\"Contract\"/>\n"
+#~ "</map>]]>"
 #~ msgstr ""
-#~ "<literal>not-found</literal> (オプション - デフォルトは "
-#~ "<literal>exception</literal>) 参照先の行がない外部キーをどのように扱うか"
-#~ "を指定します。 <literal>ignore</literal> にすると、行がないことを関連が無"
-#~ "いものとして扱います。"
+#~ "&lt;map name=\"contracts\"&gt;\n"
+#~ "    &lt;key column=\"employer_id\" not-null=\"true\"/&gt;\n"
+#~ "    &lt;map-key-many-to-many column=\"employee_id\" class=\"Employee\"/"
+#~ "&gt;\n"
+#~ "    &lt;one-to-many class=\"Contract\"/&gt;\n"
+#~ "&lt;/map&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>property-ref</literal>: (optional) The name of a property of the "
-#~ "associated class that is joined to this foreign key. If not specified, "
-#~ "the primary key of the associated class is used."
+#~ "<![CDATA[<map name=\"connections\">\n"
+#~ "    <key column=\"incoming_node_id\"/>\n"
+#~ "    <map-key-many-to-many column=\"outgoing_node_id\" class=\"Node\"/>\n"
+#~ "    <many-to-many column=\"connection_id\" class=\"Connection\"/>\n"
+#~ "</map>]]>"
 #~ msgstr ""
-#~ "<literal>property-ref</literal>: (オプション) この外部キーに結合する関連"
-#~ "クラスのプロパティ名。 指定しなかった場合は、関連クラスの主キーを使いま"
-#~ "す。"
+#~ "&lt;map name=\"connections\"&gt;\n"
+#~ "    &lt;key column=\"incoming_node_id\"/&gt;\n"
+#~ "    &lt;map-key-many-to-many column=\"outgoing_node_id\" class=\"Node\"/"
+#~ "&gt;\n"
+#~ "    &lt;many-to-many column=\"connection_id\" class=\"Connection\"/&gt;\n"
+#~ "&lt;/map&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<idbag name=\"lovers\" table=\"LOVERS\">\n"
+#~ "    <collection-id column=\"ID\" type=\"long\">\n"
+#~ "        <generator class=\"sequence\"/>\n"
+#~ "    </collection-id>\n"
+#~ "    <key column=\"PERSON1\"/>\n"
+#~ "    <many-to-many column=\"PERSON2\" class=\"Person\" fetch=\"join\"/>\n"
+#~ "</idbag>]]>"
+#~ msgstr ""
+#~ "&lt;idbag name=\"lovers\" table=\"LOVERS\"&gt;\n"
+#~ "    &lt;collection-id column=\"ID\" type=\"long\"&gt;\n"
+#~ "        &lt;generator class=\"sequence\"/&gt;\n"
+#~ "    &lt;/collection-id&gt;\n"
+#~ "    &lt;key column=\"PERSON1\"/&gt;\n"
+#~ "    &lt;many-to-many column=\"PERSON2\" class=\"Person\" fetch=\"join\"/"
+#~ "&gt;\n"
+#~ "&lt;/idbag&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "import java.util.Set;\n"
+#~ "\n"
+#~ "public class Parent {\n"
+#~ "    private long id;\n"
+#~ "    private Set children;\n"
+#~ "\n"
+#~ "    public long getId() { return id; }\n"
+#~ "    private void setId(long id) { this.id=id; }\n"
+#~ "\n"
+#~ "    private Set getChildren() { return children; }\n"
+#~ "    private void setChildren(Set children) { this.children=children; }\n"
+#~ "\n"
+#~ "    ....\n"
+#~ "    ....\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "package eg;\n"
+#~ "import java.util.Set;\n"
+#~ "\n"
+#~ "public class Parent {\n"
+#~ "    private long id;\n"
+#~ "    private Set children;\n"
+#~ "\n"
+#~ "    public long getId() { return id; }\n"
+#~ "    private void setId(long id) { this.id=id; }\n"
+#~ "\n"
+#~ "    private Set getChildren() { return children; }\n"
+#~ "    private void setChildren(Set children) { this.children=children; }\n"
+#~ "\n"
+#~ "    ....\n"
+#~ "    ....\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Parent\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <set name=\"children\">\n"
+#~ "            <key column=\"parent_id\"/>\n"
+#~ "            <one-to-many class=\"Child\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Child\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Parent\"&gt;\n"
+#~ "        &lt;id name=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"sequence\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;set name=\"children\"&gt;\n"
+#~ "            &lt;key column=\"parent_id\"/&gt;\n"
+#~ "            &lt;one-to-many class=\"Child\"/&gt;\n"
+#~ "        &lt;/set&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Child\"&gt;\n"
+#~ "        &lt;id name=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"sequence\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;property name=\"name\"/&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[create table parent ( id bigint not null primary key )\n"
+#~ "create table child ( id bigint not null primary key, name varchar(255), "
+#~ "parent_id bigint )\n"
+#~ "alter table child add constraint childfk0 (parent_id) references parent]]>"
+#~ msgstr ""
+#~ "create table parent ( id bigint not null primary key )\n"
+#~ "create table child ( id bigint not null primary key, name varchar(255), "
+#~ "parent_id bigint )\n"
+#~ "alter table child add constraint childfk0 (parent_id) references parent"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Parent\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <set name=\"children\" inverse=\"true\">\n"
+#~ "            <key column=\"parent_id\"/>\n"
+#~ "            <one-to-many class=\"Child\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Child\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "        <many-to-one name=\"parent\" class=\"Parent\" column=\"parent_id"
+#~ "\" not-null=\"true\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Parent\"&gt;\n"
+#~ "        &lt;id name=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"sequence\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;set name=\"children\" inverse=\"true\"&gt;\n"
+#~ "            &lt;key column=\"parent_id\"/&gt;\n"
+#~ "            &lt;one-to-many class=\"Child\"/&gt;\n"
+#~ "        &lt;/set&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Child\"&gt;\n"
+#~ "        &lt;id name=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"sequence\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;property name=\"name\"/&gt;\n"
+#~ "        &lt;many-to-one name=\"parent\" class=\"Parent\" column="
+#~ "\"parent_id\" not-null=\"true\"/&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[create table parent ( id bigint not null primary key )\n"
+#~ "create table child ( id bigint not null\n"
+#~ "                     primary key,\n"
+#~ "                     name varchar(255),\n"
+#~ "                     parent_id bigint not null )\n"
+#~ "alter table child add constraint childfk0 (parent_id) references parent]]>"
+#~ msgstr ""
+#~ "create table parent ( id bigint not null primary key )\n"
+#~ "create table child ( id bigint not null\n"
+#~ "                     primary key,\n"
+#~ "                     name varchar(255),\n"
+#~ "                     parent_id bigint not null )\n"
+#~ "alter table child add constraint childfk0 (parent_id) references parent"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Parent\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <set name=\"children\">\n"
+#~ "            <key column=\"parent_id\" not-null=\"true\"/>\n"
+#~ "            <one-to-many class=\"Child\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Child\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Parent\"&gt;\n"
+#~ "        &lt;id name=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"sequence\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;set name=\"children\"&gt;\n"
+#~ "            &lt;key column=\"parent_id\" not-null=\"true\"/&gt;\n"
+#~ "            &lt;one-to-many class=\"Child\"/&gt;\n"
+#~ "        &lt;/set&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Child\"&gt;\n"
+#~ "        &lt;id name=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"sequence\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;property name=\"name\"/&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Parent\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <set name=\"children\" table=\"childset\">\n"
+#~ "            <key column=\"parent_id\"/>\n"
+#~ "            <many-to-many class=\"Child\" column=\"child_id\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Child\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Parent\"&gt;\n"
+#~ "        &lt;id name=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"sequence\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;set name=\"children\" table=\"childset\"&gt;\n"
+#~ "            &lt;key column=\"parent_id\"/&gt;\n"
+#~ "            &lt;many-to-many class=\"Child\" column=\"child_id\"/&gt;\n"
+#~ "        &lt;/set&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Child\"&gt;\n"
+#~ "        &lt;id name=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"sequence\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;property name=\"name\"/&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[create table parent ( id bigint not null primary key )\n"
+#~ "create table child ( id bigint not null primary key, name varchar(255) )\n"
+#~ "create table childset ( parent_id bigint not null,\n"
+#~ "                        child_id bigint not null,\n"
+#~ "                        primary key ( parent_id, child_id ) )\n"
+#~ "alter table childset add constraint childsetfk0 (parent_id) references "
+#~ "parent\n"
+#~ "alter table childset add constraint childsetfk1 (child_id) references "
+#~ "child]]>"
+#~ msgstr ""
+#~ "create table parent ( id bigint not null primary key )\n"
+#~ "create table child ( id bigint not null primary key, name varchar(255) )\n"
+#~ "create table childset ( parent_id bigint not null,\n"
+#~ "                        child_id bigint not null,\n"
+#~ "                        primary key ( parent_id, child_id ) )\n"
+#~ "alter table childset add constraint childsetfk0 (parent_id) references "
+#~ "parent\n"
+#~ "alter table childset add constraint childsetfk1 (child_id) references "
+#~ "child"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/component_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/component_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/component_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,164 +1,81 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-07 09:28+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: component_mapping.xml:29
 #, no-c-format
 msgid "Component Mapping"
 msgstr "コンポーネントのマッピング"
 
 #. Tag: para
-#: component_mapping.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The notion of a <emphasis>component</emphasis> is re-used in several "
 "different contexts and purposes throughout Hibernate."
 msgstr ""
-"<emphasis>コンポーネント</emphasis> の概念は、Hibernateを通して様々な状況の中"
-"で 異なる目的のために再利用されます。"
+"<emphasis>コンポーネント</emphasis> の概念は、 Hibernate を通して様々な状況の"
+"中で異なる目的のために再利用されます。"
 
 #. Tag: title
-#: component_mapping.xml:37
 #, no-c-format
 msgid "Dependent objects"
 msgstr "依存オブジェクト"
 
 #. Tag: para
-#: component_mapping.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A component is a contained object that is persisted as a value type and not "
 "an entity reference. The term \"component\" refers to the object-oriented "
 "notion of composition and not to architecture-level components. For example, "
 "you can model a person like this:"
 msgstr ""
-"コンポーネントは、エンティティの参照ではなく値型として永続化された、 包含され"
-"たオブジェクトです。コンポーネントという言葉については、コンポジションという "
-"オブジェクト指向の概念を参照してください(アーキテクチャレベルのコンポーネン"
-"トではありません)。 例えば、以下のPersonモデルのようなものです。"
+"コンポーネントは、エンティティの参照ではなく値型として永続化された、包含され"
+"たオブジェクトです。「コンポーネント」という言葉については、コンポジションと"
+"いうオブジェクト指向の概念を参照してください(アーキテクチャレベルのコンポー"
+"ネントではありません)。例えば、以下の Person モデルのようなものです。"
 
-#. Tag: programlisting
-#: component_mapping.xml:45
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[public class Person {\n"
-"    private java.util.Date birthday;\n"
-"    private Name name;\n"
-"    private String key;\n"
-"    public String getKey() {\n"
-"        return key;\n"
-"    }\n"
-"    private void setKey(String key) {\n"
-"        this.key=key;\n"
-"    }\n"
-"    public java.util.Date getBirthday() {\n"
-"        return birthday;\n"
-"    }\n"
-"    public void setBirthday(java.util.Date birthday) {\n"
-"        this.birthday = birthday;\n"
-"    }\n"
-"    public Name getName() {\n"
-"        return name;\n"
-"    }\n"
-"    public void setName(Name name) {\n"
-"        this.name = name;\n"
-"    }\n"
-"    ......\n"
-"    ......\n"
-"}]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: component_mapping.xml:47
-#, no-c-format
-msgid ""
-"<![CDATA[public class Name {\n"
-"    char initial;\n"
-"    String first;\n"
-"    String last;\n"
-"    public String getFirst() {\n"
-"        return first;\n"
-"    }\n"
-"    void setFirst(String first) {\n"
-"        this.first = first;\n"
-"    }\n"
-"    public String getLast() {\n"
-"        return last;\n"
-"    }\n"
-"    void setLast(String last) {\n"
-"        this.last = last;\n"
-"    }\n"
-"    public char getInitial() {\n"
-"        return initial;\n"
-"    }\n"
-"    void setInitial(char initial) {\n"
-"        this.initial = initial;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:49
-#, fuzzy, no-c-format
-msgid ""
 "Now <literal>Name</literal> can be persisted as a component of "
 "<literal>Person</literal>. <literal>Name</literal> defines getter and setter "
 "methods for its persistent properties, but it does not need to declare any "
 "interfaces or identifier properties."
 msgstr ""
-"いま、<literal>Name</literal> は <literal>Person</literal> のコンポーネントと"
-"して 永続化することが出来ます。ここで <literal>Name</literal> は永続化属性に"
-"対してgetter、 setterメソッドを定義しますが、インターフェイスや識別子プロパ"
-"ティを定義する必要が ないことに注意して下さい。"
+"いま、 <literal>Name</literal> は <literal>Person</literal> のコンポーネント"
+"として永続化することが出来ます。ここで <literal>Name</literal> は永続化属性に"
+"対して getter 、 setter メソッドを定義しますが、インターフェースや識別子プロ"
+"パティを定義する必要がないことに注意して下さい。"
 
 #. Tag: para
-#: component_mapping.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Our Hibernate mapping would look like this:"
 msgstr "マッピング定義は以下のようになります。"
 
-#. Tag: programlisting
-#: component_mapping.xml:60
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-"    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    <property name=\"birthday\" type=\"date\"/>\n"
-"    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
-"optional -->\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </component>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:62
 #, no-c-format
 msgid ""
 "The person table would have the columns <literal>pid</literal>, "
 "<literal>birthday</literal>, <literal>initial</literal>, <literal>first</"
 "literal> and <literal>last</literal>."
 msgstr ""
-"Personテーブルは <literal>pid</literal>、 <literal>birthday</literal>、 "
+"Person テーブルは <literal>pid</literal>、 <literal>birthday</literal>、 "
 "<literal>initial</literal>、 <literal>first</literal>、 <literal>last</"
 "literal> カラムを持ちます。"
 
 #. Tag: para
-#: component_mapping.xml:70
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Like value types, components do not support shared references. In other "
 "words, two persons could have the same name, but the two person objects "
@@ -168,108 +85,69 @@
 "if all component columns are null, then the entire component is null. This "
 "is suitable for most purposes."
 msgstr ""
-"全ての値型のように、コンポーネントは参照の共有をすることができません。 言い換"
-"えると、二人のPersonは同じ名前を持つことができますが、二つのPersonオブジェク"
-"トは \"値が同じだけ\"の別々のnameオブジェクトを含んでいるということです。 コ"
-"ンポーネントのnull値のセマンティクスは <emphasis>アドホック</emphasis> で"
-"す。 コンポーネントのオブジェクトを再読み込みする際、Hibernateはコンポーネン"
-"トのすべてのカラムが nullであるならコンポーネント自体がnullであると考えま"
-"す。 これは大抵の場合問題ありません。"
+"全ての値型のように、コンポーネントは参照の共有をすることができません。言い換"
+"えると、二人の Person は同じ名前を持つことができますが、二つの Person オブ"
+"ジェクトは「値が同じだけ」の別々の name オブジェクトを含んでいるということで"
+"す。コンポーネントの null 値のセマンティクスは <emphasis>アドホック</"
+"emphasis> です。コンポーネントのオブジェクトを再読み込みする際、 Hibernate は"
+"コンポーネントのすべてのカラムが null であるならコンポーネント自体が null で"
+"あると考えます。これは大抵の場合問題ありません。"
 
 #. Tag: para
-#: component_mapping.xml:78
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The properties of a component can be of any Hibernate type (collections, "
 "many-to-one associations, other components, etc). Nested components should "
 "<emphasis>not</emphasis> be considered an exotic usage. Hibernate is "
 "intended to support a fine-grained object model."
 msgstr ""
-"コンポーネントの属性はどんなHibernateの型でも構いません(コレクション、many-"
-"to-one関連、 他のコンポーネントなど)。ネストされたコンポーネントは滅多に使わ"
-"ないと考えるべきでは <emphasis>ありません</emphasis> 。Hibernateは非常にきめ"
-"の細かいオブジェクトモデルをサポートするように意図されています。"
+"コンポーネントの属性はどんな Hibernate の型でも構いません(コレクション、 "
+"many-to-one 関連、他のコンポーネントなど)。ネストされたコンポーネントは滅多"
+"に使わないと考えるべきでは <emphasis>ありません</emphasis> 。 Hibernate は非"
+"常にきめの細かいオブジェクトモデルをサポートするように意図されています。"
 
 #. Tag: para
-#: component_mapping.xml:85
 #, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element allows a <literal>&lt;"
 "parent&gt;</literal> subelement that maps a property of the component class "
 "as a reference back to the containing entity."
 msgstr ""
-"<literal>&lt;component&gt;</literal> 要素は親エンティティへの逆参照として、コ"
-"ンポーネントクラスの 属性をマッピングする <literal>&lt;parent&gt;</literal> "
-"サブ要素を使用できます。"
+"<literal>&lt;component&gt;</literal> 要素は、親エンティティへ戻る参照として、"
+"コンポーネントのクラスのプロパティをマッピングする <literal>&lt;parent&gt;</"
+"literal> サブ要素を許可します。"
 
-#. Tag: programlisting
-#: component_mapping.xml:91
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-"    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    <property name=\"birthday\" type=\"date\"/>\n"
-"    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
-"        <parent name=\"namedPerson\"/> <!-- reference back to the Person --"
-">\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </component>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: component_mapping.xml:96
 #, no-c-format
 msgid "Collections of dependent objects"
 msgstr "従属するオブジェクトのコレクション"
 
 #. Tag: para
-#: component_mapping.xml:98
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collections of components are supported (e.g. an array of type "
 "<literal>Name</literal>). Declare your component collection by replacing the "
 "<literal>&lt;element&gt;</literal> tag with a <literal>&lt;composite-"
 "element&gt;</literal> tag:"
 msgstr ""
-"Hibernateはコンポーネントのコレクションをサポートしています(例えば "
+"Hibernate はコンポーネントのコレクションをサポートしています(例えば "
 "<literal>Name</literal> 型の配列)。 <literal>&lt;element&gt;</literal> タグ"
-"を <literal>&lt;composite-element&gt;</literal> タグに取り替えることにより コ"
+"を <literal>&lt;composite-element&gt;</literal> タグに取り替えることによりコ"
 "ンポーネントコレクションを宣言してください。"
 
-#. Tag: programlisting
-#: component_mapping.xml:105
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
-"    <key column=\"id\"/>\n"
-"    <composite-element class=\"eg.Name\"> <!-- class attribute required -->\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </composite-element>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:108
-#, fuzzy, no-c-format
-msgid ""
 "If you define a <literal>Set</literal> of composite elements, it is "
 "important to implement <literal>equals()</literal> and <literal>hashCode()</"
 "literal> correctly."
 msgstr ""
-"注意: コンポジットエレメントの <literal>Set</literal> を定義したなら、 "
+"注記: コンポジットエレメントの <literal>Set</literal> を定義したなら、 "
 "<literal>equals()</literal> と <literal>hashCode()</literal> を正しく実装する"
 "ことが重要です。"
 
 #. Tag: para
-#: component_mapping.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Composite elements can contain components but not collections. If your "
 "composite element contains components, use the <literal>&lt;nested-composite-"
@@ -280,17 +158,16 @@
 "model and persistence semantics are still slightly different."
 msgstr ""
 "コンポジットエレメントはコレクションを含まず、コンポーネントを含むこともあり"
-"ます。 コンポジットエレメント自身がコンポーネントを含んでいる場合は "
-"<literal>&lt;nested-composite-element&gt;</literal> を 使用してください。コン"
+"ます。コンポジットエレメント自身がコンポーネントを含んでいる場合は "
+"<literal>&lt;nested-composite-element&gt;</literal> を使用してください。コン"
 "ポーネントのコレクション自身がコンポーネントを持つというケースはめったにあり"
-"ません。 この段階までに、one-to-many関連の方がより適切でないかと熟考してくだ"
-"さい。 コンポジットエレメントをエンティティとして再度モデリングしてみてくださ"
-"い。 しかしこれはJavaのモデルとしては同じですが、リレーショナルモデルと永続動"
-"作はまだ若干異なることに注意してください。"
+"ません。この段階までに、 one-to-many 関連の方がより適切でないかと熟考してくだ"
+"さい。コンポジットエレメントをエンティティとして再度モデリングしてみてくださ"
+"い。しかしこれは Java のモデルとしては同じですが、リレーショナルモデルと永続"
+"動作はまだ若干異なることに注意してください。"
 
 #. Tag: para
-#: component_mapping.xml:127
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A composite element mapping does not support null-able properties if you are "
 "using a <literal>&lt;set&gt;</literal>. There is no separate primary key "
@@ -301,17 +178,16 @@
 "literal>, <literal>&lt;bag&gt;</literal> or <literal>&lt;idbag&gt;</literal>."
 msgstr ""
 "もし <literal>&lt;set&gt;</literal> を使用するのであれば、コンポジットエレメ"
-"ントのマッピングがnull値が可能な 属性をサポートしていないことに注意してくださ"
-"い。Hibernateはオブジェクトを削除するとき、 レコードを識別するためにそれぞれ"
-"のカラムの値を使用する必要があるため、null値を持つことが出来ません (コンポ"
-"ジットエレメントテーブルには別の主キーカラムはありません)。 コンポジットエレ"
-"メントにnot-nullの属性のみを使用するか、または <literal>&lt;list&gt;</"
+"ントのマッピングが null 値が可能な属性をサポートしていないことに注意してくだ"
+"さい。 Hibernate はオブジェクトを削除するとき、レコードを識別するためにそれぞ"
+"れのカラムの値を使用する必要があるため、 null 値を持つことが出来ません (コン"
+"ポジットエレメントテーブルには別の主キーカラムはありません)。 コンポジットエ"
+"レメントに not-null の属性のみを使用するか、または <literal>&lt;list&gt;</"
 "literal>、<literal>&lt;map&gt;</literal>、 <literal>&lt;bag&gt;</literal>、"
 "<literal>&lt;idbag&gt;</literal> を選択する必要があります。"
 
 #. Tag: para
-#: component_mapping.xml:138
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A special case of a composite element is a composite element with a nested "
 "<literal>&lt;many-to-one&gt;</literal> element. This mapping allows you to "
@@ -322,89 +198,48 @@
 "<literal>quantity</literal> are properties of the association:"
 msgstr ""
 "コンポジットエレメントの特別なケースとして、ネストされた <literal>&lt;many-"
-"to-one&gt;</literal> 属性を持つ コンポジットエレメントがあります。 このマッピ"
-"ングは、コンポジットエレメントクラスを多対多関連テーブルの 余分なカラムへマッ"
-"ピングします。 次の例は <literal>Order</literal> から、<literal>Item</"
-"literal> への多対多関連です。 <literal>purchaseDate</literal>、"
-"<literal>price</literal>、<literal>quantity</literal> は関連の属性となりま"
-"す。"
+"to-one&gt;</literal> 属性を持つコンポジットエレメントがあります。このマッピン"
+"グは、コンポジットエレメントクラスを多対多関連テーブルの余分なカラムへマッピ"
+"ングします。次の例は <literal>Order</literal> から、<literal>Item</literal> "
+"への多対多関連です。 <literal>purchaseDate</literal>、 <literal>price</"
+"literal>、 <literal>quantity</literal> は関連の属性となります。"
 
-#. Tag: programlisting
-#: component_mapping.xml:148
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"eg.Order\" .... >\n"
-"    ....\n"
-"    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-"        <key column=\"order_id\">\n"
-"        <composite-element class=\"eg.Purchase\">\n"
-"            <property name=\"purchaseDate\"/>\n"
-"            <property name=\"price\"/>\n"
-"            <property name=\"quantity\"/>\n"
-"            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class "
-"attribute is optional -->\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:150
-#, fuzzy, no-c-format
-msgid ""
 "There cannot be a reference to the purchase on the other side for "
 "bidirectional association navigation. Components are value types and do not "
 "allow shared references. A single <literal>Purchase</literal> can be in the "
 "set of an <literal>Order</literal>, but it cannot be referenced by the "
 "<literal>Item</literal> at the same time."
 msgstr ""
-"もちろん、双方向関連のナビゲーションのために反対側からpurchaseへの参照を作る"
-"ことは出来ません。 コンポーネントは値型であり、参照を共有できないことを覚えて"
-"おいてください。 一つの <literal>Purchase</literal> は一つの <literal>Order</"
-"literal> のsetに存在できますが、 同時に <literal>Item</literal> から参照する"
-"ことは出来ません。"
+"もちろん、双方向関連のナビゲーションのために反対側から purchase への参照を作"
+"ることは出来ません。コンポーネントは値型であり、参照を共有できないことを覚え"
+"ておいてください。一つの <literal>Purchase</literal> は一つの "
+"<literal>Order</literal> の set に存在できますが、同時に <literal>Item</"
+"literal> から参照することは出来ません。"
 
 #. Tag: para
-#: component_mapping.xml:158
 #, no-c-format
 msgid "Even ternary (or quaternary, etc) associations are possible:"
 msgstr "3項関連(あるいは4項など)も可能です。"
 
-#. Tag: programlisting
-#: component_mapping.xml:160
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"eg.Order\" .... >\n"
-"    ....\n"
-"    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-"        <key column=\"order_id\">\n"
-"        <composite-element class=\"eg.OrderLine\">\n"
-"            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
-"            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:162
-#, fuzzy, no-c-format
-msgid ""
 "Composite elements can appear in queries using the same syntax as "
 "associations to other entities."
 msgstr ""
-"コンポジットエレメントは他のエンティティへの関連として、 同じシンタックスを"
+"コンポジットエレメントは他のエンティティへの関連として、同じシンタックスを"
 "使っているクエリ内で使用できます。"
 
 #. Tag: title
-#: component_mapping.xml:170
 #, no-c-format
 msgid "Components as Map indices"
-msgstr "Mapのインデックスとしてのコンポーネント"
+msgstr "Map のインデックスとしてのコンポーネント"
 
 #. Tag: para
-#: component_mapping.xml:172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;composite-map-key&gt;</literal> element allows you to map a "
 "component class as the key of a <literal>Map</literal>. Ensure that you "
@@ -412,72 +247,64 @@
 "correctly on the component class."
 msgstr ""
 "<literal>&lt;composite-map-key&gt;</literal> 要素は <literal>Map</literal> の"
-"キーとしてコンポーネントクラスを マッピングします。コンポーネントクラス上で "
+"キーとしてコンポーネントクラスをマッピングします。コンポーネントクラス上で "
 "<literal>hashCode()</literal> と <literal>equals()</literal> を正確にオーバー"
 "ライドしてください。"
 
 #. Tag: title
-#: component_mapping.xml:181
 #, no-c-format
 msgid "Components as composite identifiers"
 msgstr "複合識別子としてのコンポーネント"
 
 #. Tag: para
-#: component_mapping.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can use a component as an identifier of an entity class. Your component "
 "class must satisfy certain requirements:"
 msgstr ""
-"コンポーネントをエンティティクラスの識別子として使うことができます。 コンポー"
+"コンポーネントをエンティティクラスの識別子として使うことができます。コンポー"
 "ネントクラスは以下の条件を満たす必要があります。"
 
 #. Tag: para
-#: component_mapping.xml:190
 #, no-c-format
 msgid "It must implement <literal>java.io.Serializable</literal>."
 msgstr "<literal>java.io.Serializable</literal> を実装しなければなりません。"
 
 #. Tag: para
-#: component_mapping.xml:195
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It must re-implement <literal>equals()</literal> and <literal>hashCode()</"
 "literal> consistently with the database's notion of composite key equality."
 msgstr ""
-"データベース上の複合キーの等価性と矛盾のないように、<literal>equals()</"
+"データベース上の複合キーの等価性と矛盾のないように、 <literal>equals()</"
 "literal> と <literal>hashCode()</literal> を再実装しなければなりません。"
 
 #. Tag: title
-#: component_mapping.xml:204
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "注記"
 
 #. Tag: para
-#: component_mapping.xml:205
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In Hibernate3, although the second requirement is not an absolutely hard "
 "requirement of Hibernate, it is recommended."
 msgstr ""
-"注意: Hibernate3において、2番目の条件は絶対的な条件ではありません。 しかしと"
-"にかく条件を満たしてください。"
+"Hibernate3 において、2番目の条件は絶対的な条件ではありません。それでもやはり"
+"条件を満たしてください。"
 
 #. Tag: para
-#: component_mapping.xml:211
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You cannot use an <literal>IdentifierGenerator</literal> to generate "
 "composite keys. Instead the application must assign its own identifiers."
 msgstr ""
 "複合キーを生成するために <literal>IdentifierGenerator</literal> を使用するこ"
-"とはできません。 代わりにアプリケーションが識別子を割り当てなくてはなりませ"
+"とはできません。代わりにアプリケーションが識別子を割り当てなくてはなりませ"
 "ん。"
 
 #. Tag: para
-#: component_mapping.xml:216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use the <literal>&lt;composite-id&gt;</literal> tag, with nested "
 "<literal>&lt;key-property&gt;</literal> elements, in place of the usual "
@@ -487,181 +314,79 @@
 msgstr ""
 "通常の <literal>&lt;id&gt;</literal> 宣言の代わりに <literal>&lt;composite-"
 "id&gt;</literal> タグを (ネストされた <literal>&lt;key-property&gt;</"
-"literal> 属性と共に)使います。 以下の例では、<literal>OrderLine</literal> ク"
-"ラスは <literal>Order</literal> の(複合)主キーに 依存した主キーを持っていま"
-"す。"
+"literal> 属性と共に) 使います。以下の例では、 <literal>OrderLine</literal> "
+"クラスは <literal>Order</literal> の(複合)主キーに依存した主キーを持ってい"
+"ます。"
 
-#. Tag: programlisting
-#: component_mapping.xml:224
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"OrderLine\">\n"
-"\n"
-"    <composite-id name=\"id\" class=\"OrderLineId\">\n"
-"        <key-property name=\"lineId\"/>\n"
-"        <key-property name=\"orderId\"/>\n"
-"        <key-property name=\"customerId\"/>\n"
-"    </composite-id>\n"
-"\n"
-"    <property name=\"name\"/>\n"
-"\n"
-"    <many-to-one name=\"order\" class=\"Order\"\n"
-"            insert=\"false\" update=\"false\">\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </many-to-one>\n"
-"    ....\n"
-"\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:226
-#, fuzzy, no-c-format
-msgid ""
 "Any foreign keys referencing the <literal>OrderLine</literal> table are now "
 "composite. Declare this in your mappings for other classes. An association "
 "to <literal>OrderLine</literal> is mapped like this:"
 msgstr ""
-"このとき、<literal>OrderLine</literal> テーブルへ関連する外部キーもまた複合で"
-"す。 他のクラスのマッピングでこれを宣言しなければなりません。 "
+"このとき、 <literal>OrderLine</literal> テーブルへ関連する外部キーもまた複合"
+"です。他のクラスのマッピングでこれを宣言しなければなりません。 "
 "<literal>OrderLine</literal> への関連は次のようにマッピングされます。"
 
-#. Tag: programlisting
-#: component_mapping.xml:232
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
-"<!-- the \"class\" attribute is optional, as usual -->\n"
-"    <column name=\"lineId\"/>\n"
-"    <column name=\"orderId\"/>\n"
-"    <column name=\"customerId\"/>\n"
-"</many-to-one>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:235
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The <literal>column</literal> element is an alternative to the "
 "<literal>column</literal> attribute everywhere. Using the <literal>column</"
 "literal> element just gives more declaration options, which are mostly "
 "useful when utilizing <literal>hbm2ddl</literal>"
 msgstr ""
+"(<literal>&lt;column&gt;</literal> タグはどこであっても <literal>column</"
+"literal> 属性の代わりになります。)"
 
 #. Tag: para
-#: component_mapping.xml:244
 #, no-c-format
 msgid ""
 "A <literal>many-to-many</literal> association to <literal>OrderLine</"
 "literal> also uses the composite foreign key:"
 msgstr ""
-"<literal>OrderLine</literal> への <literal>many-to-many</literal> 関連も 複合"
+"<literal>OrderLine</literal> への <literal>many-to-many</literal> 関連も複合"
 "外部キーを使います。"
 
-#. Tag: programlisting
-#: component_mapping.xml:249
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"undeliveredOrderLines\">\n"
-"    <key column name=\"warehouseId\"/>\n"
-"    <many-to-many class=\"OrderLine\">\n"
-"        <column name=\"lineId\"/>\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </many-to-many>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:251
 #, no-c-format
 msgid ""
 "The collection of <literal>OrderLine</literal>s in <literal>Order</literal> "
 "would use:"
 msgstr ""
-"<literal>Order</literal> にある <literal>OrderLine</literal> のコレクション"
-"は 次のものを使用します。"
+"<literal>Order</literal> にある <literal>OrderLine</literal> のコレクションは"
+"次のものを使用します。"
 
-#. Tag: programlisting
-#: component_mapping.xml:256
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
-"    <key>\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </key>\n"
-"    <one-to-many class=\"OrderLine\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:258
-#, fuzzy, no-c-format
 msgid "The <literal>&lt;one-to-many&gt;</literal> element declares no columns."
 msgstr ""
 "(<literal>&lt;one-to-many&gt;</literal> 属性は、例によってカラムを宣言しませ"
 "ん)"
 
 #. Tag: para
-#: component_mapping.xml:262
 #, no-c-format
 msgid ""
 "If <literal>OrderLine</literal> itself owns a collection, it also has a "
 "composite foreign key."
 msgstr ""
-"<literal>OrderLine</literal> 自身がコレクションを持っている場合、 同時に複合"
-"外部キーも持っています。"
+"<literal>OrderLine</literal> 自身がコレクションを持っている場合、同時に複合外"
+"部キーも持っています。"
 
-#. Tag: programlisting
-#: component_mapping.xml:267
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"OrderLine\">\n"
-"    ....\n"
-"    ....\n"
-"    <list name=\"deliveryAttempts\">\n"
-"        <key>   <!-- a collection inherits the composite key type -->\n"
-"            <column name=\"lineId\"/>\n"
-"            <column name=\"orderId\"/>\n"
-"            <column name=\"customerId\"/>\n"
-"        </key>\n"
-"        <list-index column=\"attemptId\" base=\"1\"/>\n"
-"        <composite-element class=\"DeliveryAttempt\">\n"
-"            ...\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: component_mapping.xml:272
 #, no-c-format
 msgid "Dynamic components"
 msgstr "動的コンポーネント"
 
 #. Tag: para
-#: component_mapping.xml:274
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can also map a property of type <literal>Map</literal>:"
 msgstr "<literal>Map</literal> 型のプロパティのマッピングも可能です。"
 
-#. Tag: programlisting
-#: component_mapping.xml:278
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<dynamic-component name=\"userAttributes\">\n"
-"    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
-"    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
-"    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
-"</dynamic-component>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:280
-#, fuzzy, no-c-format
-msgid ""
 "The semantics of a <literal>&lt;dynamic-component&gt;</literal> mapping are "
 "identical to <literal>&lt;component&gt;</literal>. The advantage of this "
 "kind of mapping is the ability to determine the actual properties of the "
@@ -672,14 +397,392 @@
 msgstr ""
 "<literal>&lt;dynamic-component&gt;</literal> マッピングのセマンティクスは "
 "<literal>&lt;component&gt;</literal> と同一のものです。この種のマッピングの利"
-"点は、マッピングドキュメントの編集により、配置時にbeanの属性を 決定できる点で"
-"す。また、DOMパーサを利用して、マッピングドキュメントのランタイム操作が可能で"
-"す。 さらに、<literal>Configuration</literal> オブジェクト経由でHibernateのコ"
-"ンフィグレーション時のメタモデルに アクセス(または変更)が可能です。"
+"点は、マッピングドキュメントの編集により、配置時に Bean の属性を決定できる点"
+"です。また、 DOM パーサを利用して、マッピングドキュメントのランタイム操作が可"
+"能です。さらに、 <literal>Configuration</literal> オブジェクト経由で "
+"Hibernate のコンフィグレーション時のメタモデルにアクセス(または変更)が可能"
+"です。"
 
+#, fuzzy
 #~ msgid ""
-#~ "(Note that the <literal>&lt;column&gt;</literal> tag is an alternative to "
-#~ "the <literal>column</literal> attribute everywhere.)"
+#~ "<![CDATA[public class Person {\n"
+#~ "    private java.util.Date birthday;\n"
+#~ "    private Name name;\n"
+#~ "    private String key;\n"
+#~ "    public String getKey() {\n"
+#~ "        return key;\n"
+#~ "    }\n"
+#~ "    private void setKey(String key) {\n"
+#~ "        this.key=key;\n"
+#~ "    }\n"
+#~ "    public java.util.Date getBirthday() {\n"
+#~ "        return birthday;\n"
+#~ "    }\n"
+#~ "    public void setBirthday(java.util.Date birthday) {\n"
+#~ "        this.birthday = birthday;\n"
+#~ "    }\n"
+#~ "    public Name getName() {\n"
+#~ "        return name;\n"
+#~ "    }\n"
+#~ "    public void setName(Name name) {\n"
+#~ "        this.name = name;\n"
+#~ "    }\n"
+#~ "    ......\n"
+#~ "    ......\n"
+#~ "}]]>"
 #~ msgstr ""
-#~ "(<literal>&lt;column&gt;</literal> タグはどこであっても <literal>column</"
-#~ "literal> 属性の 代わりになります。)"
+#~ "public class Person {\n"
+#~ "    private java.util.Date birthday;\n"
+#~ "    private Name name;\n"
+#~ "    private String key;\n"
+#~ "    public String getKey() {\n"
+#~ "        return key;\n"
+#~ "    }\n"
+#~ "    private void setKey(String key) {\n"
+#~ "        this.key=key;\n"
+#~ "    }\n"
+#~ "    public java.util.Date getBirthday() {\n"
+#~ "        return birthday;\n"
+#~ "    }\n"
+#~ "    public void setBirthday(java.util.Date birthday) {\n"
+#~ "        this.birthday = birthday;\n"
+#~ "    }\n"
+#~ "    public Name getName() {\n"
+#~ "        return name;\n"
+#~ "    }\n"
+#~ "    public void setName(Name name) {\n"
+#~ "        this.name = name;\n"
+#~ "    }\n"
+#~ "    ......\n"
+#~ "    ......\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[public class Name {\n"
+#~ "    char initial;\n"
+#~ "    String first;\n"
+#~ "    String last;\n"
+#~ "    public String getFirst() {\n"
+#~ "        return first;\n"
+#~ "    }\n"
+#~ "    void setFirst(String first) {\n"
+#~ "        this.first = first;\n"
+#~ "    }\n"
+#~ "    public String getLast() {\n"
+#~ "        return last;\n"
+#~ "    }\n"
+#~ "    void setLast(String last) {\n"
+#~ "        this.last = last;\n"
+#~ "    }\n"
+#~ "    public char getInitial() {\n"
+#~ "        return initial;\n"
+#~ "    }\n"
+#~ "    void setInitial(char initial) {\n"
+#~ "        this.initial = initial;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "public class Name {\n"
+#~ "    char initial;\n"
+#~ "    String first;\n"
+#~ "    String last;\n"
+#~ "    public String getFirst() {\n"
+#~ "        return first;\n"
+#~ "    }\n"
+#~ "    void setFirst(String first) {\n"
+#~ "        this.first = first;\n"
+#~ "    }\n"
+#~ "    public String getLast() {\n"
+#~ "        return last;\n"
+#~ "    }\n"
+#~ "    void setLast(String last) {\n"
+#~ "        this.last = last;\n"
+#~ "    }\n"
+#~ "    public char getInitial() {\n"
+#~ "        return initial;\n"
+#~ "    }\n"
+#~ "    void setInitial(char initial) {\n"
+#~ "        this.initial = initial;\n"
+#~ "    }\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
+#~ "optional -->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"eg.Person\" table=\"person\"&gt;\n"
+#~ "    &lt;id name=\"Key\" column=\"pid\" type=\"string\"&gt;\n"
+#~ "        &lt;generator class=\"uuid\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"birthday\" type=\"date\"/&gt;\n"
+#~ "    &lt;component name=\"Name\" class=\"eg.Name\"&gt; &lt;!-- class "
+#~ "attribute optional --&gt;\n"
+#~ "        &lt;property name=\"initial\"/&gt;\n"
+#~ "        &lt;property name=\"first\"/&gt;\n"
+#~ "        &lt;property name=\"last\"/&gt;\n"
+#~ "    &lt;/component&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
+#~ "        <parent name=\"namedPerson\"/> <!-- reference back to the Person "
+#~ "-->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"eg.Person\" table=\"person\"&gt;\n"
+#~ "    &lt;id name=\"Key\" column=\"pid\" type=\"string\"&gt;\n"
+#~ "        &lt;generator class=\"uuid\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"birthday\" type=\"date\"/&gt;\n"
+#~ "    &lt;component name=\"Name\" class=\"eg.Name\" unique=\"true\"&gt;\n"
+#~ "        &lt;parent name=\"namedPerson\"/&gt; &lt;!-- reference back to "
+#~ "the Person --&gt;\n"
+#~ "        &lt;property name=\"initial\"/&gt;\n"
+#~ "        &lt;property name=\"first\"/&gt;\n"
+#~ "        &lt;property name=\"last\"/&gt;\n"
+#~ "    &lt;/component&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
+#~ "    <key column=\"id\"/>\n"
+#~ "    <composite-element class=\"eg.Name\"> <!-- class attribute required --"
+#~ ">\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </composite-element>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "&lt;set name=\"someNames\" table=\"some_names\" lazy=\"true\"&gt;\n"
+#~ "    &lt;key column=\"id\"/&gt;\n"
+#~ "    &lt;composite-element class=\"eg.Name\"&gt; &lt;!-- class attribute "
+#~ "required --&gt;\n"
+#~ "        &lt;property name=\"initial\"/&gt;\n"
+#~ "        &lt;property name=\"first\"/&gt;\n"
+#~ "        &lt;property name=\"last\"/&gt;\n"
+#~ "    &lt;/composite-element&gt;\n"
+#~ "&lt;/set&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.Purchase\">\n"
+#~ "            <property name=\"purchaseDate\"/>\n"
+#~ "            <property name=\"price\"/>\n"
+#~ "            <property name=\"quantity\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class "
+#~ "attribute is optional -->\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"eg.Order\" .... &gt;\n"
+#~ "    ....\n"
+#~ "    &lt;set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true"
+#~ "\"&gt;\n"
+#~ "        &lt;key column=\"order_id\"&gt;\n"
+#~ "        &lt;composite-element class=\"eg.Purchase\"&gt;\n"
+#~ "            &lt;property name=\"purchaseDate\"/&gt;\n"
+#~ "            &lt;property name=\"price\"/&gt;\n"
+#~ "            &lt;property name=\"quantity\"/&gt;\n"
+#~ "            &lt;many-to-one name=\"item\" class=\"eg.Item\"/&gt; &lt;!-- "
+#~ "class attribute is optional --&gt;\n"
+#~ "        &lt;/composite-element&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.OrderLine\">\n"
+#~ "            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"eg.Order\" .... &gt;\n"
+#~ "    ....\n"
+#~ "    &lt;set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true"
+#~ "\"&gt;\n"
+#~ "        &lt;key column=\"order_id\"&gt;\n"
+#~ "        &lt;composite-element class=\"eg.OrderLine\"&gt;\n"
+#~ "            &lt;many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/"
+#~ "&gt;\n"
+#~ "            &lt;many-to-one name=\"item\" class=\"eg.Item\"/&gt;\n"
+#~ "        &lt;/composite-element&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" class=\"OrderLineId\">\n"
+#~ "        <key-property name=\"lineId\"/>\n"
+#~ "        <key-property name=\"orderId\"/>\n"
+#~ "        <key-property name=\"customerId\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\" class=\"Order\"\n"
+#~ "            insert=\"false\" update=\"false\">\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    ....\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"OrderLine\"&gt;\n"
+#~ "    \n"
+#~ "    &lt;composite-id name=\"id\" class=\"OrderLineId\"&gt;\n"
+#~ "        &lt;key-property name=\"lineId\"/&gt;\n"
+#~ "        &lt;key-property name=\"orderId\"/&gt;\n"
+#~ "        &lt;key-property name=\"customerId\"/&gt;\n"
+#~ "    &lt;/composite-id&gt;\n"
+#~ "    \n"
+#~ "    &lt;property name=\"name\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;many-to-one name=\"order\" class=\"Order\"\n"
+#~ "            insert=\"false\" update=\"false\"&gt;\n"
+#~ "        &lt;column name=\"orderId\"/&gt;\n"
+#~ "        &lt;column name=\"customerId\"/&gt;\n"
+#~ "    &lt;/many-to-one&gt;\n"
+#~ "    ....\n"
+#~ "    \n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
+#~ "<!-- the \"class\" attribute is optional, as usual -->\n"
+#~ "    <column name=\"lineId\"/>\n"
+#~ "    <column name=\"orderId\"/>\n"
+#~ "    <column name=\"customerId\"/>\n"
+#~ "</many-to-one>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"orderLine\" class=\"OrderLine\"&gt;\n"
+#~ "&lt;!-- the \"class\" attribute is optional, as usual --&gt;\n"
+#~ "    &lt;column name=\"lineId\"/&gt;\n"
+#~ "    &lt;column name=\"orderId\"/&gt;\n"
+#~ "    &lt;column name=\"customerId\"/&gt;\n"
+#~ "&lt;/many-to-one&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<set name=\"undeliveredOrderLines\">\n"
+#~ "    <key column name=\"warehouseId\"/>\n"
+#~ "    <many-to-many class=\"OrderLine\">\n"
+#~ "        <column name=\"lineId\"/>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-many>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "&lt;set name=\"undeliveredOrderLines\"&gt;\n"
+#~ "    &lt;key column name=\"warehouseId\"/&gt;\n"
+#~ "    &lt;many-to-many class=\"OrderLine\"&gt;\n"
+#~ "        &lt;column name=\"lineId\"/&gt;\n"
+#~ "        &lt;column name=\"orderId\"/&gt;\n"
+#~ "        &lt;column name=\"customerId\"/&gt;\n"
+#~ "    &lt;/many-to-many&gt;\n"
+#~ "&lt;/set&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
+#~ "    <key>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </key>\n"
+#~ "    <one-to-many class=\"OrderLine\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "&lt;set name=\"orderLines\" inverse=\"true\"&gt;\n"
+#~ "    &lt;key&gt;\n"
+#~ "        &lt;column name=\"orderId\"/&gt;\n"
+#~ "        &lt;column name=\"customerId\"/&gt;\n"
+#~ "    &lt;/key&gt;\n"
+#~ "    &lt;one-to-many class=\"OrderLine\"/&gt;\n"
+#~ "&lt;/set&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    ....\n"
+#~ "    ....\n"
+#~ "    <list name=\"deliveryAttempts\">\n"
+#~ "        <key>   <!-- a collection inherits the composite key type -->\n"
+#~ "            <column name=\"lineId\"/>\n"
+#~ "            <column name=\"orderId\"/>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "        </key>\n"
+#~ "        <list-index column=\"attemptId\" base=\"1\"/>\n"
+#~ "        <composite-element class=\"DeliveryAttempt\">\n"
+#~ "            ...\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"OrderLine\"&gt;\n"
+#~ "    ....\n"
+#~ "    ....\n"
+#~ "    &lt;list name=\"deliveryAttempts\"&gt;\n"
+#~ "        &lt;key&gt;   &lt;!-- a collection inherits the composite key "
+#~ "type --&gt;\n"
+#~ "            &lt;column name=\"lineId\"/&gt;\n"
+#~ "            &lt;column name=\"orderId\"/&gt;\n"
+#~ "            &lt;column name=\"customerId\"/&gt;\n"
+#~ "        &lt;/key&gt;\n"
+#~ "        &lt;list-index column=\"attemptId\" base=\"1\"/&gt;\n"
+#~ "        &lt;composite-element class=\"DeliveryAttempt\"&gt;\n"
+#~ "            ...\n"
+#~ "        &lt;/composite-element&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<dynamic-component name=\"userAttributes\">\n"
+#~ "    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
+#~ "    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
+#~ "    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
+#~ "</dynamic-component>]]>"
+#~ msgstr ""
+#~ "&lt;dynamic-component name=\"userAttributes\"&gt;\n"
+#~ "    &lt;property name=\"foo\" column=\"FOO\" type=\"string\"/&gt;\n"
+#~ "    &lt;property name=\"bar\" column=\"BAR\" type=\"integer\"/&gt;\n"
+#~ "    &lt;many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/&gt;\n"
+#~ "&lt;/dynamic-component&gt;"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/configuration.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/configuration.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/configuration.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,25 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2009.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-21 17:12+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: configuration.xml:29
 #, no-c-format
 msgid "Configuration"
 msgstr "設定"
 
 #. Tag: para
-#: configuration.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate is designed to operate in many different environments and, as "
 "such, there is a broad range of configuration parameters. Fortunately, most "
@@ -27,22 +28,20 @@
 "displays the various options. Simply put the example file in your classpath "
 "and customize it to suit your needs."
 msgstr ""
-"Hibernateはさまざまな環境で動作するようにデザインされているため、非常に多くの"
-"設定要素があります。 幸いなことに、Hibernateは、公開されているパッケージの "
+"Hibernate は様々な環境で動作するようにデザインされているため、非常に多くの設"
+"定要素があります。幸いなことに、 Hibernate は、公開されているパッケージの "
 "<literal>etc/</literal> フォルダの <literal>hibernate.properties</literal> "
-"に、ほとんどの設定要素の適切なデフォルト値が記述されています。 この "
+"に、ほとんどの設定要素の適切なデフォルト値が記述されています。この "
 "<literal>hibernate.properties</literal> をクラスパスに設定し、設定要素をカス"
 "タマイズするだけです。"
 
 #. Tag: title
-#: configuration.xml:40
 #, no-c-format
 msgid "Programmatic configuration"
 msgstr "プログラム上の設定"
 
 #. Tag: para
-#: configuration.xml:42
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of <classname>org.hibernate.cfg.Configuration</classname> "
 "represents an entire set of mappings of an application's Java types to an "
@@ -50,104 +49,67 @@
 "used to build an immutable <interfacename>org.hibernate.SessionFactory</"
 "interfacename>. The mappings are compiled from various XML mapping files."
 msgstr ""
-"<literal>org.hibernate.cfg.Configuration</literal> のインスタンスは、 Javaの"
-"型とSQLデータベースのマッピング情報をすべて持っています。 The "
-"<literal>Configuration</literal> は、(不変の) <literal>SessionFactory</"
-"literal> を生成するときに使用します。 複数のXMLマッピングファイルを変換し、"
-"マッピング情報にします。"
+"<classname>org.hibernate.cfg.Configuration</classname> のインスタンスは、 "
+"Java の型と SQL データベースのマッピング情報をすべて持っています。 "
+"<literal>Configuration</literal> は、(不変の) "
+"<interfacename>SessionFactory</interfacename> を生成するときに使用します。複"
+"数の XML マッピングファイルを変換し、マッピング情報にします。"
 
 #. Tag: para
-#: configuration.xml:49
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can obtain a <classname>org.hibernate.cfg.Configuration</classname> "
 "instance by instantiating it directly and specifying XML mapping documents. "
 "If the mapping files are in the classpath, use <literal>addResource()</"
 "literal>. For example:"
 msgstr ""
-"通常、<literal>Configuration</literal> インスタンスは、特定のXMLマッピング"
-"ファイル によって直接初期化されます。もし、マッピングファイルがクラスパスに設"
-"定されている場合、 次のメソッドを使ってください。 <literal>addResource()</"
-"literal> :"
+"通常、 <classname>org.hibernate.cfg.Configuration</classname> インスタンス"
+"は、特定の XML マッピングファイルによって直接初期化されます。もし、マッピング"
+"ファイルがクラスパスに設定されている場合、次のメソッドを使ってください。 "
+"<literal>addResource()</literal> :"
 
-#. Tag: programlisting
-#: configuration.xml:55
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addResource(\"Item.hbm.xml\")\n"
-"    .addResource(\"Bid.hbm.xml\");]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:57
-#, fuzzy, no-c-format
-msgid ""
 "An alternative way is to specify the mapped class and allow Hibernate to "
 "find the mapping document for you:"
 msgstr ""
-"代替案(こちらのほうが良いときもあります)としてマッピングクラスを指定する方法"
-"もあります。Hibernateに、マッピングファイルを 見つけさせてください:"
+"代替案 (こちらのほうが良いときもあります) としてマッピングクラスを指定する方"
+"法もあります。 Hibernate に、マッピングファイルを 見つけさせてください:"
 
-#. Tag: programlisting
-#: configuration.xml:62
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addClass(org.hibernate.auction.Item.class)\n"
-"    .addClass(org.hibernate.auction.Bid.class);]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:64
-#, fuzzy, no-c-format
-msgid ""
 "Hibernate will then search for mapping files named <filename>/org/hibernate/"
 "auction/Item.hbm.xml</filename> and <filename>/org/hibernate/auction/Bid.hbm."
 "xml</filename> in the classpath. This approach eliminates any hardcoded "
 "filenames."
 msgstr ""
-"Hibernateは、クラスパスにある以下のような名前のマッピングファイルを見つけま"
-"す。 <literal>/org/hibernate/auction/Item.hbm.xml</literal> 、 <literal>/org/"
-"hibernate/auction/Bid.hbm.xml</literal> 。 この方法だと、ハードコーディングさ"
-"れたファイル名を排除できます。"
+"Hibernate は、クラスパスにある以下のような名前のマッピングファイルを見つけま"
+"す。 <filename>/org/hibernate/auction/Item.hbm.xml</filename> 、 <filename>/"
+"org/hibernate/auction/Bid.hbm.xml</filename> 。この方法だと、ハードコーディン"
+"グされたファイル名を排除できます。"
 
 #. Tag: para
-#: configuration.xml:70
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <classname>org.hibernate.cfg.Configuration</classname> also allows you to "
 "specify configuration properties. For example:"
 msgstr ""
-"<literal>Configuration</literal> は、設定プロパティを指定することもできます:"
+"<classname>org.hibernate.cfg.Configuration</classname> は、設定プロパティを指"
+"定することもできます:"
 
-#. Tag: programlisting
-#: configuration.xml:75
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addClass(org.hibernate.auction.Item.class)\n"
-"    .addClass(org.hibernate.auction.Bid.class)\n"
-"    .setProperty(\"hibernate.dialect\", \"org.hibernate.dialect."
-"MySQLInnoDBDialect\")\n"
-"    .setProperty(\"hibernate.connection.datasource\", \"java:comp/env/jdbc/"
-"test\")\n"
-"    .setProperty(\"hibernate.order_updates\", \"true\");]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:77
-#, fuzzy, no-c-format
-msgid ""
 "This is not the only way to pass configuration properties to Hibernate. Some "
 "alternative options include:"
 msgstr ""
-"Hibernateに設定プロパティを通す方法は1つではありません。 さまざまなオプション"
+"Hibernate に設定プロパティを渡す方法は1つではありません。さまざまなオプション"
 "を用意しています:"
 
 #. Tag: para
-#: configuration.xml:84
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Pass an instance of <classname>java.util.Properties</classname> to "
 "<literal>Configuration.setProperties()</literal>."
@@ -156,17 +118,15 @@
 "<literal>Configuration.setProperties()</literal> に渡します。"
 
 #. Tag: para
-#: configuration.xml:90
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Place a file named <filename>hibernate.properties</filename> in a root "
 "directory of the classpath."
 msgstr ""
-"<literal>hibernate.properties</literal> を クラスパスのルートディレクトリに置"
+"<literal>hibernate.properties</literal> をクラスパスのルートディレクトリに置"
 "きます。"
 
 #. Tag: para
-#: configuration.xml:95
 #, no-c-format
 msgid ""
 "Set <literal>System</literal> properties using <literal>java -"
@@ -176,43 +136,40 @@
 "literal> を使うように設定します。"
 
 #. Tag: para
-#: configuration.xml:100
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Include <literal>&lt;property&gt;</literal> elements in <literal>hibernate."
 "cfg.xml</literal> (this is discussed later)."
 msgstr ""
-"<literal>&lt;property&gt;</literal> 要素を <literal>hibernate.cfg.xml</"
-"literal> (後述)に設定します。"
+"<literal>&lt;property&gt;</literal> 要素を <filename>hibernate.cfg.xml</"
+"filename> (後述)に設定します。"
 
 #. Tag: para
-#: configuration.xml:107
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "If you want to get started quickly<filename>hibernate.properties</filename> "
 "is the easiest approach."
 msgstr ""
+"<literal>hibernate.properties</literal> をクラスパスのルートディレクトリに置"
+"きます。"
 
 #. Tag: para
-#: configuration.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <classname>org.hibernate.cfg.Configuration</classname> is intended as a "
 "startup-time object that will be discarded once a <literal>SessionFactory</"
 "literal> is created."
 msgstr ""
-"<literal>Configuration</literal> は、起動時にだけあるオブジェクトであり、 一"
-"度 <literal>SessionFactory</literal> を生成した後は、破棄されることを意図して"
-"います。"
+"<classname>org.hibernate.cfg.Configuration</classname> は、起動時にだけあるオ"
+"ブジェクトであり、一度 <literal>SessionFactory</literal> を生成した後は、破棄"
+"されることを意図しています。"
 
 #. Tag: title
-#: configuration.xml:119
 #, no-c-format
 msgid "Obtaining a SessionFactory"
-msgstr "SessionFactoryを取得する"
+msgstr "SessionFactory を取得する"
 
 #. Tag: para
-#: configuration.xml:121
 #, fuzzy, no-c-format
 msgid ""
 "When all mappings have been parsed by the <classname>org.hibernate.cfg."
@@ -220,67 +177,51 @@
 "<interfacename>org.hibernate.Session</interfacename> instances. This factory "
 "is intended to be shared by all application threads:"
 msgstr ""
-"<literal>Configuration</literal> がすべてのマッピング情報を解析したら、 アプ"
-"リケーションは、 <literal>Session</literal> ファクトリインスタンスを取得しま"
-"す。 このSessionFactoryは、Hibernateを使用するすべてのスレッドで共有されるべ"
-"きです。"
+"<classname>org.hibernate.cfg.Configuration</classname> がすべてのマッピング情"
+"報を解析したら、アプリケーションは、 <classname>org.hibernate.Session</"
+"classname> インスタンスのためにファクトリを取得しなければなりません。この "
+"SessionFactory は、 Hibernate を使用するすべてのスレッドで共有されるべきです:"
 
-#. Tag: programlisting
-#: configuration.xml:127
-#, no-c-format
-msgid "<![CDATA[SessionFactory sessions = cfg.buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:129
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate does allow your application to instantiate more than one "
 "<interfacename>org.hibernate.SessionFactory</interfacename>. This is useful "
 "if you are using more than one database."
 msgstr ""
-"Hibernateは、 <literal>SessionFactory</literal> を複数生成することができま"
-"す。 これは、複数のデータベースを使用する場合に便利です。"
+"Hibernate は、アプリケーションが <classname>org.hibernate.SessionFactory</"
+"classname> を複数生成することを可能にします。これは、複数のデータベースを使用"
+"する場合に便利です。"
 
 #. Tag: title
-#: configuration.xml:138
 #, no-c-format
 msgid "JDBC connections"
-msgstr "JDBCコネクション"
+msgstr "JDBC コネクション"
 
 #. Tag: para
-#: configuration.xml:140
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is advisable to have the <interfacename>org.hibernate.SessionFactory</"
 "interfacename> create and pool JDBC connections for you. If you take this "
 "approach, opening a <interfacename>org.hibernate.Session</interfacename> is "
 "as simple as:"
 msgstr ""
-"通常、開発者は <literal>SessionFactory</literal> を生成し、SessionFactoryで"
-"JDBCコネクションをプーリングしたいと考えます。 そのアプローチを採用する場合、"
-"単純に <literal>Session</literal> をオープンしてください:"
+"通常、開発者は <interfacename>org.hibernate.SessionFactory</interfacename> を"
+"生成し、 SessionFactory で JDBC コネクションをプーリングしたいと考えます。そ"
+"のアプローチを採用する場合、単純に <interfacename>org.hibernate.Session</"
+"interfacename> をオープンしてください:"
 
-#. Tag: programlisting
-#: configuration.xml:146
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessions.openSession(); // open a new Session]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:148
-#, fuzzy, no-c-format
-msgid ""
 "Once you start a task that requires access to the database, a JDBC "
 "connection will be obtained from the pool."
 msgstr ""
-"これだけで、プーリングしたJDBCコネクションを使って目的のデータベース にアクセ"
-"スすることができます。"
+"これだけで、プーリングした JDBC コネクションを使って目的のデータベースにアク"
+"セスすることができます。"
 
 #. Tag: para
-#: configuration.xml:153
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Before you can do this, you first need to pass some JDBC connection "
 "properties to Hibernate. All Hibernate property names and semantics are "
@@ -288,106 +229,87 @@
 "The most important settings for JDBC connection configuration are outlined "
 "below."
 msgstr ""
-"そのためには、JDBCコネクションのプロパティをHibernateに設定する必要がありま"
-"す。 すべてのHibernateプロパティ名とセマンティクスは <literal>org.hibernate."
-"cfg.Environment</literal> クラスに定義されています。 この設定はJDBCコネクショ"
-"ン設定の中で一番重要なものです。"
+"そのためには、 JDBC コネクションのプロパティを Hibernate に設定する必要があり"
+"ます。すべての Hibernate プロパティ名とセマンティクスは <classname>org."
+"hibernate.cfg.Environment</classname> クラスに定義されています。この設定は "
+"JDBC コネクション設定の中で一番重要なものです。"
 
 #. Tag: para
-#: configuration.xml:159
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will obtain and pool connections using <classname>java.sql."
 "DriverManager</classname> if you set the following properties:"
 msgstr ""
-"もし、以下のプロパティを設定すると、Hibernateはコネクションを取得する(プール"
-"も)ために <literal>java.sql.DriverManager</literal> を使います。"
+"もし、以下のプロパティを設定すると、 Hibernate はコネクションを取得するために"
+"(プールも) <classname>java.sql.DriverManager</classname> を使います:"
 
 #. Tag: title
-#: configuration.xml:165
 #, no-c-format
 msgid "Hibernate JDBC Properties"
-msgstr "Hibernate JDBCプロパティ"
+msgstr "Hibernate JDBC プロパティ"
 
 #. Tag: entry
-#: configuration.xml:171 configuration.xml:257 configuration.xml:353
-#: configuration.xml:548 configuration.xml:743 configuration.xml:850
-#: configuration.xml:938
 #, no-c-format
 msgid "Property name"
 msgstr "プロパティ名"
 
 #. Tag: entry
-#: configuration.xml:172 configuration.xml:258 configuration.xml:354
-#: configuration.xml:549 configuration.xml:744 configuration.xml:851
-#: configuration.xml:939
 #, no-c-format
 msgid "Purpose"
 msgstr "意味"
 
-#. Tag: property
-#: configuration.xml:178
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.driver_class"
-msgstr "hibernate.connection.driver_class"
+msgid "<property>hibernate.connection.driver_class</property>"
+msgstr "<property>hibernate.connection.driver_class</property>"
 
-#. Tag: emphasis
-#: configuration.xml:181
+#. Tag: entry
 #, no-c-format
-msgid "JDBC driver class"
-msgstr "JDBCドライバクラス"
+msgid "<emphasis>JDBC driver class</emphasis>"
+msgstr "JDBC のドライバークラス"
 
-#. Tag: property
-#: configuration.xml:186
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.url"
-msgstr "hibernate.connection.url"
+msgid "<property>hibernate.connection.url</property>"
+msgstr "<property>hibernate.connection.url</property>"
 
-#. Tag: emphasis
-#: configuration.xml:189
-#, no-c-format
-msgid "JDBC URL"
-msgstr "jdbc URL"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<emphasis>JDBC URL</emphasis>"
+msgstr "JDBC のドライバークラス"
 
-#. Tag: property
-#: configuration.xml:194 configuration.xml:288
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.username"
-msgstr "hibernate.connection.username"
+msgid "<property>hibernate.connection.username</property>"
+msgstr "<property>hibernate.connection.username</property>"
 
-#. Tag: emphasis
-#: configuration.xml:197
-#, no-c-format
-msgid "database user"
-msgstr "database user"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<emphasis>database user</emphasis>"
+msgstr "<emphasis>データベースユーザ</emphasis> (オプション)"
 
-#. Tag: property
-#: configuration.xml:202 configuration.xml:296
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.password"
-msgstr "hibernate.connection.password"
+msgid "<property>hibernate.connection.password</property>"
+msgstr "<property>hibernate.connection.password</property>"
 
-#. Tag: emphasis
-#: configuration.xml:205
-#, no-c-format
-msgid "database user password"
-msgstr "database user password"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<emphasis>database user password</emphasis>"
+msgstr "<emphasis>データベースユーザのパスワード</emphasis> (オプション)"
 
-#. Tag: property
-#: configuration.xml:210
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.pool_size"
-msgstr "hibernate.connection.pool_size"
+msgid "<property>hibernate.connection.pool_size</property>"
+msgstr "<property>hibernate.connection.pool_size</property>"
 
-#. Tag: emphasis
-#: configuration.xml:213
+#. Tag: entry
 #, no-c-format
-msgid "maximum number of pooled connections"
-msgstr "プールするコネクションの最大数"
+msgid "<emphasis>maximum number of pooled connections</emphasis>"
+msgstr "<emphasis>プールするコネクションの最大数</emphasis>"
 
 #. Tag: para
-#: configuration.xml:220
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's own connection pooling algorithm is, however, quite rudimentary. "
 "It is intended to help you get started and is <emphasis>not intended for use "
@@ -397,18 +319,17 @@
 "with connection pool specific settings. This will turn off Hibernate's "
 "internal pool. For example, you might like to use c3p0."
 msgstr ""
-"Hibernateのコネクションプールアルゴリズムは非常に初歩的なものです。 これはす"
-"ぐに始められるようにと用意されたもので、<emphasis>製品として使用することを意"
-"図していません</emphasis> 。 また、パフォーマンスのテストのためのものでもあり"
-"ません。 最高のパフォーマンスと安定性を持ったプールを実現したければ、サード"
+"Hibernate のコネクションプールアルゴリズムは非常に初歩的なものです。これはす"
+"ぐに始められるようにと用意されたもので、 <emphasis>製品として使用することを意"
+"図していません</emphasis> 。また、パフォーマンスのテストのためのものでもあり"
+"ません。最高のパフォーマンスと安定性を持ったプールを実現したければ、サード"
 "パーティのツールをお勧めします。 <literal>hibernate.connection.pool_size</"
-"literal> プロパティに 適切なコネクションプールサイズを記述してください。 この"
-"ままだとHibernateのコネクションプールを使います。 例えば次のようにC3P0を使い"
-"ます。"
+"literal> プロパティと適切なコネクションプールの設定を置き換えてください。これ"
+"により Hibernate のインターナルプールを無効にします。例えば次のように C3P0 を"
+"使います。"
 
 #. Tag: para
-#: configuration.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "C3P0 is an open source JDBC connection pool distributed along with Hibernate "
 "in the <filename>lib</filename> directory. Hibernate will use its "
@@ -418,156 +339,117 @@
 "<filename>hibernate.properties</filename> and the Hibernate web site for "
 "more information."
 msgstr ""
-"C3P0はオープンソースJDBCコネクションプールで、Hibernateの <literal>lib</"
-"literal> ディレクトリにあります。もし、<literal>hibernate.c3p0.*</literal> プ"
-"ロパティを セットすれば、Hibernateは、 <literal>C3P0ConnectionProvider</"
-"literal> を使います。 もしProxoolを使いたい場合は、 <literal>hibernate."
-"properties</literal> パッケージを 参照したり、HibernateのWebサイトでより多く"
-"の情報を取得してください。"
+"C3P0 はオープンソース JDBC コネクションプールで、 Hibernate の <literal>lib</"
+"literal> ディレクトリにあります。もし、 <literal>hibernate.c3p0.*</literal> "
+"プロパティをセットすれば、 Hibernate は、 <literal>C3P0ConnectionProvider</"
+"literal> を使います。もし Proxool を使いたい場合は、 <literal>hibernate."
+"properties</literal> パッケージを参照したり、 Hibernate の Web サイトでより多"
+"くの情報を取得してください。"
 
 #. Tag: para
-#: configuration.xml:238
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is an example <filename>hibernate.properties</filename> file "
 "for c3p0:"
 msgstr ""
-"C3P0用の <literal>hibernate.properties</literal> ファイルを例として示します:"
+"C3P0 用の <literal>hibernate.properties</literal> ファイルを例として示しま"
+"す:"
 
-#. Tag: programlisting
-#: configuration.xml:242
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[hibernate.connection.driver_class = org.postgresql.Driver\n"
-"hibernate.connection.url = jdbc:postgresql://localhost/mydatabase\n"
-"hibernate.connection.username = myuser\n"
-"hibernate.connection.password = secret\n"
-"hibernate.c3p0.min_size=5\n"
-"hibernate.c3p0.max_size=20\n"
-"hibernate.c3p0.timeout=1800\n"
-"hibernate.c3p0.max_statements=50\n"
-"hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:244
-#, fuzzy, no-c-format
-msgid ""
 "For use inside an application server, you should almost always configure "
 "Hibernate to obtain connections from an application server "
 "<interfacename>javax.sql.Datasource</interfacename> registered in JNDI. You "
 "will need to set at least one of the following properties:"
 msgstr ""
-"アプリケーションサーバ上で使う場合は、Hibernateを設定し、 アプリケーション"
-"サーバからコネクションを取得するようにしてください。 <literal>Datasource</"
-"literal> をJNDIに登録します。そして プロパティを以下のように設定してくださ"
-"い。"
+"アプリケーションサーバー上で使う場合は、 Hibernate を設定し、アプリケーション"
+"サーバーからコネクションを取得するようにしてください。 <interfacename>javax."
+"sql.Datasource</interfacename> を JNDI に登録します。そしてプロパティを以下の"
+"ように設定してください:"
 
 #. Tag: title
-#: configuration.xml:251
 #, no-c-format
 msgid "Hibernate Datasource Properties"
 msgstr "Hibernate データソースプロパティ"
 
-#. Tag: property
-#: configuration.xml:264
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.datasource"
-msgstr "hibernate.connection.datasource"
+msgid "<property>hibernate.connection.datasource</property>"
+msgstr "<property>hibernate.connection.datasource</property>"
 
-#. Tag: emphasis
-#: configuration.xml:267
-#, no-c-format
-msgid "datasource JNDI name"
-msgstr "データソースのJNDI名"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<emphasis>datasource JNDI name</emphasis>"
+msgstr "<emphasis>データベースユーザ</emphasis> (オプション)"
 
-#. Tag: property
-#: configuration.xml:272
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jndi.url"
-msgstr "hibernate.jndi.url"
+msgid "<property>hibernate.jndi.url</property>"
+msgstr "<property>hibernate.jndi.url</property>"
 
 #. Tag: entry
-#: configuration.xml:274
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis>URL of the JNDI provider</emphasis> (optional)"
-msgstr "JNDIプロバイダのURL"
+msgstr "<emphasis>JNDI プロバイダの URL</emphasis> (オプション)"
 
-#. Tag: property
-#: configuration.xml:280
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jndi.class"
-msgstr "hibernate.jndi.class"
+msgid "<property>hibernate.jndi.class</property>"
+msgstr "<property>hibernate.jndi.class</property>"
 
 #. Tag: entry
-#: configuration.xml:282
 #, no-c-format
 msgid ""
 "<emphasis>class of the JNDI <literal>InitialContextFactory</literal></"
 "emphasis> (optional)"
 msgstr ""
+"<emphasis>JNDI のクラス <literal>InitialContextFactory</literal></emphasis> "
+"(オプション)"
 
 #. Tag: entry
-#: configuration.xml:290
 #, no-c-format
 msgid "<emphasis>database user</emphasis> (optional)"
-msgstr ""
+msgstr "<emphasis>データベースユーザ</emphasis> (オプション)"
 
 #. Tag: entry
-#: configuration.xml:298
 #, no-c-format
 msgid "<emphasis>database user password</emphasis> (optional)"
-msgstr ""
+msgstr "<emphasis>データベースユーザのパスワード</emphasis> (オプション)"
 
 #. Tag: para
-#: configuration.xml:306
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Here is an example <filename>hibernate.properties</filename> file for an "
 "application server provided JNDI datasource:"
 msgstr ""
-"アプリケーションサーバから提供されたJNDIデータソースを使う "
-"<literal>hibernate.properties</literal> ファイルの例を示します:"
+"アプリケーションサーバーから提供された JNDI データソースを使う "
+"<filename>hibernate.properties</filename> ファイルの例を示します:"
 
-#. Tag: programlisting
-#: configuration.xml:311
-#, no-c-format
-msgid ""
-"<![CDATA[hibernate.connection.datasource = java:/comp/env/jdbc/test\n"
-"hibernate.transaction.factory_class = \\\n"
-"    org.hibernate.transaction.JTATransactionFactory\n"
-"hibernate.transaction.manager_lookup_class = \\\n"
-"    org.hibernate.transaction.JBossTransactionManagerLookup\n"
-"hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:313
 #, no-c-format
 msgid ""
 "JDBC connections obtained from a JNDI datasource will automatically "
 "participate in the container-managed transactions of the application server."
 msgstr ""
-"JNDIデータソースから取得したJDBCコネクションは、アプリケーションサーバの コン"
-"テナ管理トランザクションに自動的に参加します。"
+"JNDI データソースから取得した JDBC コネクションは、アプリケーションサーバーの"
+"コンテナ管理トランザクションに自動的に参加します。"
 
 #. Tag: para
-#: configuration.xml:318
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Arbitrary connection properties can be given by prepending "
 "\"<literal>hibernate.connection</literal>\" to the connection property name. "
 "For example, you can specify a <property>charSet</property> connection "
 "property using <property>hibernate.connection.charSet</property>."
 msgstr ""
-"任意のコネクションプロパティは、与えられた” <literal>hibernate.connnection</"
-"literal> ” プロパティ名によって与えられます。例えば、 <literal>charSet</"
-"literal> を設定したい場合は、 <literal>hibernate.connection.charSet</"
-"literal> を使います。"
+"任意のコネクションプロパティは、追加された \"<literal>hibernate.connnection</"
+"literal>\" プロパティ名によって与えられます。例えば、 <property>charSet</"
+"property> を設定したい場合は、 <property>hibernate.connection.charSet</"
+"property> を使います。"
 
 #. Tag: para
-#: configuration.xml:324
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can define your own plugin strategy for obtaining JDBC connections by "
 "implementing the interface <interfacename>org.hibernate.connection."
@@ -575,29 +457,26 @@
 "implementation via the <property>hibernate.connection.provider_class</"
 "property> property."
 msgstr ""
-"JDBCコネクションを取得する戦略を持つ独自のプラグインを定義する場合は、 "
-"<literal>org.hibernate.connection.ConnectionProvider</literal> インターフェイ"
-"スを 実装してください。そして、実装クラスを <literal>hibernate.connection."
-"provider_class</literal> に設定してください。"
+"JDBC コネクションを取得する戦略を持つ独自のプラグインを定義する場合は、 "
+"<interfacename>org.hibernate.connection.ConnectionProvider</interfacename> イ"
+"ンターフェースを実装してください。そして、実装クラスを <property>hibernate."
+"connection.provider_class</property> に設定してください。"
 
 #. Tag: title
-#: configuration.xml:333
 #, no-c-format
 msgid "Optional configuration properties"
 msgstr "オプション設定プロパティ"
 
 #. Tag: para
-#: configuration.xml:335
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are a number of other properties that control the behavior of "
 "Hibernate at runtime. All are optional and have reasonable default values."
 msgstr ""
-"これらのプロパティはHibernateの挙動を制御するものです。 これらのプロパティは"
-"すべて妥当なデフォルト値があり、任意で設定します。"
+"これらのプロパティはランタイムに Hibernate の挙動を制御するものです。これらの"
+"プロパティはすべて妥当なデフォルト値があり、任意で設定します。"
 
-#. Tag: warning
-#: configuration.xml:341
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Some of these properties are \"system-level\" only.</emphasis> "
@@ -605,46 +484,42 @@
 "literal> or <filename>hibernate.properties</filename>. They "
 "<emphasis>cannot</emphasis> be set by the other techniques described above."
 msgstr ""
-"<emphasis>注意:これらのプロパティは\"システムレベル\"のみです。</emphasis> "
+"<emphasis>注意:これらのプロパティは「システムレベル」のみです。</emphasis> "
 "システムレベルプロパティは <literal>java -Dproperty=value</literal> 、もしく"
-"は <literal>hibernate.properties</literal> でのみ設定可能です。 それ以外の設"
-"定方法は <emphasis>ありません</emphasis> 。"
+"は <literal>hibernate.properties</literal> でのみ設定可能です。それ以外の設定"
+"方法は <emphasis>ありません</emphasis> 。"
 
 #. Tag: title
-#: configuration.xml:347
 #, no-c-format
 msgid "Hibernate Configuration Properties"
-msgstr "Hibernate設定プロパティ"
+msgstr "Hibernate 設定プロパティ"
 
-#. Tag: property
-#: configuration.xml:360
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.dialect"
-msgstr "hibernate.dialect"
+msgid "<property>hibernate.dialect</property>"
+msgstr "<property>hibernate.dialect</property>"
 
 #. Tag: entry
-#: configuration.xml:362
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a Hibernate <classname>org.hibernate.dialect.Dialect</"
 "classname> which allows Hibernate to generate SQL optimized for a particular "
 "relational database."
 msgstr ""
-"Hibernate <placeholder-1/> クラス名が入ります。 これはリレーショナルデータ"
-"ベースごとに最適化されたSQLを生成します。 <placeholder-2/>"
+"Hibernate のクラス名 <classname>org.hibernate.dialect.Dialect</classname> が"
+"入ります。これはリレーショナルデータベースごとに最適化された SQL を生成しま"
+"す。"
 
 #. Tag: para
-#: configuration.xml:365
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>full.classname.of."
 "Dialect</literal>"
 msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例</emphasis><literal>full.classname.of.Dialect</"
+"literal>"
 
 #. Tag: para
-#: configuration.xml:369
 #, no-c-format
 msgid ""
 "In most cases Hibernate will actually be able to choose the correct "
@@ -652,165 +527,135 @@
 "the <literal>JDBC metadata</literal> returned by the JDBC driver."
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:378
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.show_sql"
-msgstr "hibernate.show_sql"
+msgid "<property>hibernate.show_sql</property>"
+msgstr "<property>hibernate.show_sql</property>"
 
 #. Tag: entry
-#: configuration.xml:380
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Write all SQL statements to console. This is an alternative to setting the "
 "log category <literal>org.hibernate.SQL</literal> to <literal>debug</"
 "literal>."
 msgstr ""
-"発行されたすべてのSQLをコンソールに出力します。 これはログカテゴリの "
-"<placeholder-1/> に <placeholder-2/> を設定する方法の代替手段です。 "
-"<placeholder-3/>"
+"発行されたすべての SQL をコンソールに出力します。これはログカテゴリの "
+"<literal>org.hibernate.SQL</literal> に <literal>debug</literal> を設定する方"
+"法の代替手段です。"
 
 #. Tag: para
-#: configuration.xml:384 configuration.xml:396 configuration.xml:490
-#: configuration.xml:503 configuration.xml:516 configuration.xml:529
-#: configuration.xml:583 configuration.xml:610 configuration.xml:623
-#: configuration.xml:678 configuration.xml:906 configuration.xml:921
-#: configuration.xml:1011
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>true</literal> | "
 "<literal>false</literal>"
 msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>true</literal> | "
+"<emphasis role=\"strong\">例</emphasis><literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: property
-#: configuration.xml:392
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.format_sql"
-msgstr "hibernate.format_sql"
+msgid "<property>hibernate.format_sql</property>"
+msgstr "<property>hibernate.format_sql</property>"
 
 #. Tag: entry
-#: configuration.xml:394
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Pretty print the SQL in the log and console."
-msgstr "ログとコンソールのSQLを美しく表示します。 <placeholder-1/>"
+msgstr "ログとコンソールの SQL を整形して表示します。"
 
-#. Tag: property
-#: configuration.xml:404
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_schema"
-msgstr "hibernate.default_schema"
+msgid "<property>hibernate.default_schema</property>"
+msgstr "<property>hibernate.default_schema</property>"
 
 #. Tag: entry
-#: configuration.xml:406
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Qualify unqualified table names with the given schema/tablespace in "
 "generated SQL."
-msgstr ""
-"生成されるSQL文のテーブルに設定するスキーマ/テーブルスペースです。 "
-"<placeholder-1/>"
+msgstr "生成される SQL 文のテーブルに設定するスキーマ/テーブルスペースです。"
 
 #. Tag: para
-#: configuration.xml:409
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>SCHEMA_NAME</literal>"
-msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+msgstr "<emphasis role=\"strong\">例.</emphasis><literal>SCHEMA_NAME</literal>"
 
-#. Tag: property
-#: configuration.xml:417
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_catalog"
-msgstr "hibernate.default_catalog"
+msgid "<property>hibernate.default_catalog</property>"
+msgstr "<property>hibernate.default_catalog</property>"
 
 #. Tag: entry
-#: configuration.xml:419
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Qualifies unqualified table names with the given catalog in generated SQL."
-msgstr "生成されるSQL文のテーブルに設定するカタログです。 <placeholder-1/>"
+msgstr "生成される SQL 文のテーブルに設定するカタログです。"
 
 #. Tag: para
-#: configuration.xml:422
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>CATALOG_NAME</literal>"
-msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+msgstr "<emphasis role=\"strong\">例</emphasis><literal>CATALOG_NAME</literal>"
 
-#. Tag: property
-#: configuration.xml:430
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.session_factory_name"
-msgstr "hibernate.session_factory_name"
+msgid "<property>hibernate.session_factory_name</property>"
+msgstr "<property>hibernate.session_factory_name</property>"
 
 #. Tag: entry
-#: configuration.xml:432
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <interfacename>org.hibernate.SessionFactory</interfacename> will be "
 "automatically bound to this name in JNDI after it has been created."
 msgstr ""
-"<placeholder-1/> は生成後、この名前でJNDIに登録されます。 <placeholder-2/>"
+"<interfacename>org.hibernate.SessionFactory</interfacename> は生成後、この名"
+"前で JNDI に自動的に登録されます。"
 
 #. Tag: para
-#: configuration.xml:435 configuration.xml:877
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>jndi/composite/name</"
 "literal>"
 msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例</emphasis><literal>jndi/composite/name</literal>"
 
-#. Tag: property
-#: configuration.xml:443
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.max_fetch_depth"
-msgstr "hibernate.max_fetch_depth"
+msgid "<property>hibernate.max_fetch_depth</property>"
+msgstr "<property>hibernate.max_fetch_depth</property>"
 
 #. Tag: entry
-#: configuration.xml:445
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sets a maximum \"depth\" for the outer join fetch tree for single-ended "
 "associations (one-to-one, many-to-one). A <literal>0</literal> disables "
 "default outer join fetching."
 msgstr ""
-"外部結合フェッチの最大深度を設定します。結合する関連は 対一関連のみ(一対一、"
-"多対一)です。 <placeholder-1/> を指定すると外部結合フェッチは無効になりま"
-"す。 <placeholder-2/>"
+"外部結合フェッチの最大深度を設定します。結合する関連は対一関連のみ(一対一、"
+"多対一)です。 <literal>0</literal> を指定すると外部結合フェッチは無効になり"
+"ます。"
 
 #. Tag: para
-#: configuration.xml:449
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values between "
 "<literal>0</literal> and <literal>3</literal>"
 msgstr ""
 "<emphasis role=\"strong\">例:</emphasis> 推奨する値は <literal>0</literal> "
-"から <literal>3</literal> です。"
+"から <literal>3</literal> の間です。"
 
-#. Tag: property
-#: configuration.xml:458
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_batch_fetch_size"
-msgstr "hibernate.default_batch_fetch_size"
+msgid "<property>hibernate.default_batch_fetch_size</property>"
+msgstr "<property>hibernate.default_batch_fetch_size</property>"
 
 #. Tag: entry
-#: configuration.xml:460
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Sets a default size for Hibernate batch fetching of associations."
-msgstr "関連フェッチのデフォルトバッチサイズを指定します。 <placeholder-1/>"
+msgstr "関連フェッチのデフォルト Hibernate バッチサイズを指定します。"
 
 #. Tag: para
-#: configuration.xml:462
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values <literal>4</"
 "literal>, <literal>8</literal>, <literal>16</literal>"
@@ -818,24 +663,21 @@
 "<emphasis role=\"strong\">例:</emphasis> 推奨する値は <literal>4</"
 "literal> , <literal>8</literal> , <literal>16</literal> です。"
 
-#. Tag: property
-#: configuration.xml:471
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_entity_mode"
-msgstr "hibernate.default_entity_mode"
+msgid "<property>hibernate.default_entity_mode</property>"
+msgstr "<property>hibernate.default_entity_mode</property>"
 
 #. Tag: entry
-#: configuration.xml:473
 #, fuzzy, no-c-format
 msgid ""
 "Sets a default mode for entity representation for all sessions opened from "
 "this <literal>SessionFactory</literal>"
 msgstr ""
-"<placeholder-1/> からセッションをオープンしたときに 使用するエンティティのデ"
-"フォルトモードを設定します。 <placeholder-2/>"
+"<literal>SessionFactory</literal> からセッションをオープンしたときに使用する"
+"エンティティのデフォルトモードを設定します。"
 
 #. Tag: para
-#: configuration.xml:476
 #, no-c-format
 msgid ""
 "<literal>dynamic-map</literal>, <literal>dom4j</literal>, <literal>pojo</"
@@ -844,206 +686,181 @@
 "<literal>dynamic-map</literal>, <literal>dom4j</literal>, <literal>pojo</"
 "literal>"
 
-#. Tag: property
-#: configuration.xml:484
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.order_updates"
-msgstr "hibernate.order_updates"
+msgid "<property>hibernate.order_updates</property>"
+msgstr "<property>hibernate.order_updates</property>"
 
 #. Tag: entry
-#: configuration.xml:486
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Forces Hibernate to order SQL updates by the primary key value of the items "
 "being updated. This will result in fewer transaction deadlocks in highly "
 "concurrent systems."
 msgstr ""
-"項目が更新されたときに、別のSQLで主キーを更新することを強制します。 この場"
+"項目が更新されたときに、別の SQL で主キーを更新することを強制します。この場"
 "合、同時実行可能なシステムでは、まれにデッドロックが発生する可能性がありま"
-"す。 <placeholder-1/>"
+"す。"
 
-#. Tag: property
-#: configuration.xml:498
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.generate_statistics"
-msgstr "hibernate.generate_statistics"
+msgid "<property>hibernate.generate_statistics</property>"
+msgstr "<property>hibernate.generate_statistics</property>"
 
 #. Tag: entry
-#: configuration.xml:500
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If enabled, Hibernate will collect statistics useful for performance tuning."
 msgstr ""
-"有効の場合、Hibernateはパフォーマンスチューニングに 有効な統計情報を収集しま"
-"す。 <placeholder-1/>"
+"有効の場合、 Hibernate はパフォーマンスチューニングに有効な統計情報を収集しま"
+"す。"
 
-#. Tag: property
-#: configuration.xml:511
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.use_identifier_rollback"
-msgstr "hibernate.use_identifer_rollback"
+msgid "<property>hibernate.use_identifier_rollback</property>"
+msgstr "<property>hibernate.use_identifier_rollback</property>"
 
 #. Tag: entry
-#: configuration.xml:513
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If enabled, generated identifier properties will be reset to default values "
 "when objects are deleted."
 msgstr ""
-"有効の場合、オブジェクトが削除されたときに 識別子プロパティをリセットし、デ"
-"フォルト値にしたものを生成します。 <placeholder-1/>"
+"有効の場合、オブジェクトが削除されたときに識別子プロパティをリセットし、デ"
+"フォルト値にしたものを生成します。"
 
-#. Tag: property
-#: configuration.xml:524
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.use_sql_comments"
-msgstr "hibernate.use_sql_comments"
+msgid "<property>hibernate.use_sql_comments</property>"
+msgstr "<property>hibernate.use_sql_comments</property>"
 
 #. Tag: entry
-#: configuration.xml:526
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If turned on, Hibernate will generate comments inside the SQL, for easier "
 "debugging, defaults to <literal>false</literal>."
 msgstr ""
-"有効の場合、SQL内にコメントを生成します。これはデバックを容易にします。 デ"
-"フォルトの値は <placeholder-1/> です。 <placeholder-2/>"
+"有効の場合、 SQL 内にコメントを生成します。これはデバックを容易にします。デ"
+"フォルトの値は <literal>false</literal> です。"
 
 #. Tag: title
-#: configuration.xml:540
 #, no-c-format
 msgid "Hibernate JDBC and Connection Properties"
 msgstr "Hibernate JDBC とコネクションプロパティ"
 
-#. Tag: property
-#: configuration.xml:555
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.fetch_size"
-msgstr "hibernate.jdbc.fetch_size"
+msgid "<property>hibernate.jdbc.fetch_size</property>"
+msgstr "<property>hibernate.jdbc.fetch_size</property>"
 
 #. Tag: entry
-#: configuration.xml:557
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A non-zero value determines the JDBC fetch size (calls <literal>Statement."
 "setFetchSize()</literal>)."
 msgstr ""
-"値が0でない場合、JDBCフェッチサイズを決定します ( <placeholder-1/> を呼びま"
-"す)。"
+"値が0でない場合、 JDBC フェッチサイズを決定します ( <literal>Statement."
+"setFetchSize()</literal> を呼びます)。"
 
-#. Tag: property
-#: configuration.xml:564
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.batch_size"
-msgstr "hibernate.jdbc.batch_size"
+msgid "<property>hibernate.jdbc.batch_size</property>"
+msgstr "<property>hibernate.jdbc.batch_size</property>"
 
 #. Tag: entry
-#: configuration.xml:566
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A non-zero value enables use of JDBC2 batch updates by Hibernate."
-msgstr ""
-"値が0でない場合、HibernateがJDBC2バッチ更新を使用します。 <placeholder-1/>"
+msgstr "値が0でない場合、 Hibernate が JDBC2 バッチ更新を使用します。"
 
 #. Tag: para
-#: configuration.xml:568
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values between "
 "<literal>5</literal> and <literal>30</literal>"
 msgstr ""
 "<emphasis role=\"strong\">例:</emphasis> 推奨する値は <literal>5</literal> "
-"から <literal>30</literal> です。"
+"から <literal>30</literal> の間です。"
 
-#. Tag: property
-#: configuration.xml:576
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.batch_versioned_data"
-msgstr "hibernate.jdbc.batch_versioned_data"
+msgid "<property>hibernate.jdbc.batch_versioned_data</property>"
+msgstr "<property>hibernate.jdbc.batch_versioned_data</property>"
 
 #. Tag: entry
-#: configuration.xml:578
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Set this property to <literal>true</literal> if your JDBC driver returns "
 "correct row counts from <literal>executeBatch()</literal>. Iit is usually "
 "safe to turn this option on. Hibernate will then use batched DML for "
 "automatically versioned data. Defaults to <literal>false</literal>."
 msgstr ""
-"もしJDBCドライバが <placeholder-1/> によって正確な行数を 返す場合、このプロパ"
-"ティを <placeholder-2/> にしてください (通常はこのオプションをONにしま"
-"す)。 Hibernateは、自動バージョンデータのためバッチDMLを使います。 デフォル"
-"トの値は <placeholder-3/> です。 <placeholder-4/>"
+"もし JDBC ドライバが <literal>executeBatch()</literal> によって正確な行数を返"
+"す場合、このプロパティを <literal>true</literal> にしてください (通常はこの"
+"オプションを ON するのが安全です)。 Hibernate は、自動バージョンデータのため"
+"バッチ DML を使います。デフォルトの値は <literal>false</literal> です。"
 
-#. Tag: property
-#: configuration.xml:591
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.factory_class"
-msgstr "hibernate.jdbc.factory_class"
+msgid "<property>hibernate.jdbc.factory_class</property>"
+msgstr "<property>hibernate.jdbc.factory_class</property>"
 
 #. Tag: entry
-#: configuration.xml:593
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Select a custom <interfacename>org.hibernate.jdbc.Batcher</interfacename>. "
 "Most applications will not need this configuration property."
 msgstr ""
-"カスタム <placeholder-1/> を選びます。 ほとんどのアプリケーションに、この設定"
-"は必要ありません。 <placeholder-2/>"
+"カスタム <interfacename>org.hibernate.jdbc.Batcher</interfacename> を選びま"
+"す。ほとんどのアプリケーションに、この設定プロパティは必要ありません。"
 
 #. Tag: para
-#: configuration.xml:596
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "BatcherFactory</literal>"
 msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例</emphasis><literal>classname.of.BatcherFactory</"
+"literal>"
 
-#. Tag: property
-#: configuration.xml:604
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_scrollable_resultset"
-msgstr "hibernate.jdbc.use_scrollable_resultset"
+msgid "<property>hibernate.jdbc.use_scrollable_resultset</property>"
+msgstr "<property>hibernate.jdbc.use_scrollable_resultset</property>"
 
 #. Tag: entry
-#: configuration.xml:606
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Enables use of JDBC2 scrollable resultsets by Hibernate. This property is "
 "only necessary when using user-supplied JDBC connections. Hibernate uses "
 "connection metadata otherwise."
 msgstr ""
-"スクロール可能なリザルトセットを、Hibernateが使用します。 このプロパティは、"
-"JDBCコネクションがコネクションメタデータを サポートしていることが必須条件にな"
-"ります。 <placeholder-1/>"
+"Hibernate による JDBC2 のスクロール可能なリザルトセットの使用を有効にします。"
+"このプロパティは、ユーザーによって提供された JDBC コネクションを使用している"
+"場合のみ必要で、そうでなければ Hibernate はコネクションメタデータを使用しま"
+"す。"
 
-#. Tag: property
-#: configuration.xml:618
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_streams_for_binary"
-msgstr "hibernate.jdbc.use_streams_for_binary"
+msgid "<property>hibernate.jdbc.use_streams_for_binary</property>"
+msgstr "<property>hibernate.jdbc.use_streams_for_binary</property>"
 
 #. Tag: entry
-#: configuration.xml:620
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use streams when writing/reading <literal>binary</literal> or "
 "<literal>serializable</literal> types to/from JDBC. <emphasis>*system-level "
 "property*</emphasis>"
 msgstr ""
-"JDBCへ/から <placeholder-1/> や <placeholder-2/> の書き込み/読み込みストリー"
-"ムを使います(システムレベルのプロパティ)。 <placeholder-3/>"
+"JDBC へ/から <literal>binary</literal> や <literal>serializable</literal> の"
+"書き込み/読み込みストリームを使います (システムレベルのプロパティ)。"
 
-#. Tag: property
-#: configuration.xml:631
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_get_generated_keys"
-msgstr "hibernate.jdbc.use_get_generated_keys"
+msgid "<property>hibernate.jdbc.use_get_generated_keys</property>"
+msgstr "<property>hibernate.jdbc.use_get_generated_keys</property>"
 
 #. Tag: entry
-#: configuration.xml:633
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Enables use of JDBC3 <literal>PreparedStatement.getGeneratedKeys()</literal> "
 "to retrieve natively generated keys after insert. Requires JDBC3+ driver and "
@@ -1051,97 +868,82 @@
 "identifier generators. By default, it tries to determine the driver "
 "capabilities using connection metadata."
 msgstr ""
-"挿入の後に自動生成された主キーを取得するための JDBC3 <placeholder-1/> の使用"
-"を有効にします。 これはJDBC3+ドライバとJRE1.4+を必要とし、 もしHibernateの識"
-"別子ジェネレータに問題が発生するようならfalseに設定してください。 デフォルト"
-"ではコネクションメタデータを使いドライバの能力を決定します。 <placeholder-2/>"
+"挿入の後に自動生成された主キーを取得するための JDBC3 "
+"<literal>PreparedStatement.getGeneratedKeys()</literal> の使用を有効にしま"
+"す。これは JDBC3+ ドライバと JRE1.4+ を必要とし、もし Hibernate の識別子ジェ"
+"ネレータに問題が発生するようなら false に設定してください。デフォルトではコネ"
+"クションメタデータを使いドライバの能力を決定します。"
 
 #. Tag: para
-#: configuration.xml:639 configuration.xml:769 configuration.xml:781
-#: configuration.xml:795 configuration.xml:833
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>true|false</literal>"
-msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+msgstr "<emphasis role=\"strong\">例</emphasis><literal>true|false</literal>"
 
-#. Tag: property
-#: configuration.xml:647
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.provider_class"
-msgstr "hibernate.connection.provider_class"
+msgid "<property>hibernate.connection.provider_class</property>"
+msgstr "<property>hibernate.connection.provider_class</property>"
 
 #. Tag: entry
-#: configuration.xml:649
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a custom <interfacename>org.hibernate.connection."
 "ConnectionProvider</interfacename> which provides JDBC connections to "
 "Hibernate."
 msgstr ""
-"JDBCコネクションをHibernateに提供する独自の <placeholder-1/> の 名前を指定し"
-"ます。 <placeholder-2/>"
+"JDBC コネクションを Hibernate に提供する独自の <literal>ConnectionProvider</"
+"literal> のクラス名。"
 
 #. Tag: para
-#: configuration.xml:652
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "ConnectionProvider</literal>"
 msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例</emphasis><literal>classname.of."
+"ConnectionProvider</literal>"
 
-#. Tag: property
-#: configuration.xml:660
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.isolation"
-msgstr "hibernate.connection.isolation"
+msgid "<property>hibernate.connection.isolation</property>"
+msgstr "<property>hibernate.connection.isolation</property>"
 
 #. Tag: entry
-#: configuration.xml:662
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sets the JDBC transaction isolation level. Check <interfacename>java.sql."
 "Connection</interfacename> for meaningful values, but note that most "
 "databases do not support all isolation levels and some define additional, "
 "non-standard isolations."
 msgstr ""
-"JDBCトランザクション分離レベルを設定します。 妥当な値を調べるためには "
-"<placeholder-1/> をチェックしてください。 しかし使用するデータベースが、すべ"
-"ての分離レベルをサポートしているとは限りません。 <placeholder-2/>"
+"JDBC トランザクション分離レベルを設定します。妥当な値を調べるためには "
+"<interfacename>java.sql.Connection</interfacename> をチェックしてください。し"
+"かし使用するデータベースが、すべての分離レベルをサポートしているとは限りませ"
+"ん。"
 
 #. Tag: para
-#: configuration.xml:666
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>1, 2, 4, 8</literal>"
-msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+msgstr "<emphasis role=\"strong\">例</emphasis><literal>1, 2, 4, 8</literal>"
 
-#. Tag: property
-#: configuration.xml:674
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.autocommit"
-msgstr "hibernate.connection.autocommit"
+msgid "<property>hibernate.connection.autocommit</property>"
+msgstr "<property>hibernate.connection.autocommit</property>"
 
 #. Tag: entry
-#: configuration.xml:676
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Enables autocommit for JDBC pooled connections (it is not recommended)."
 msgstr ""
-"プールされているJDBCコネクションの自動コミットを有効にする(非推奨)。 "
-"<placeholder-1/>"
+"プールされている JDBC コネクションの自動コミットを有効にする(非推奨)。"
 
-#. Tag: property
-#: configuration.xml:686
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.release_mode"
-msgstr "hibernate.connection.release_mode"
+msgid "<property>hibernate.connection.release_mode</property>"
+msgstr "<property>hibernate.connection.release_mode</property>"
 
 #. Tag: entry
-#: configuration.xml:688
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Specifies when Hibernate should release JDBC connections. By default, a JDBC "
 "connection is held until the session is explicitly closed or disconnected. "
@@ -1153,480 +955,433 @@
 "the JTA and CMT transaction strategies and <literal>after_transaction</"
 "literal> for the JDBC transaction strategy."
 msgstr ""
-"HibernateがJDBCコネクションをリリースするかを指定します。デフォルトでは セッ"
-"ションが明示的にクローズまたは切断されてもコネクションは保持します。 アプリ"
-"ケーションサーバのJTAデータソースの場合、 すべてのJDBCコールの後、強制的にコ"
-"ネクションをリリースするために <placeholder-1/> を 使ってください。 非JTAコネ"
-"クションの場合、各トランザクションが終了したときに <placeholder-2/> を使い、"
-"コネクションをリリースしてください。 <placeholder-3/> にすると、 JTAやCMTトラ"
-"ンザクションの場合、 <placeholder-4/> でクローズし、 JDBCトランザクションの場"
-"合、 <placeholder-5/> でクローズします。 <placeholder-6/><placeholder-7/>"
+"Hibernate がいつ JDBC コネクションをリリースするかを指定します。デフォルトで"
+"はセッションが明示的にクローズまたは切断されてもコネクションは保持します。ア"
+"プリケーションサーバーの JTA データソースの場合、すべての JDBC コールの後、強"
+"制的にコネクションをリリースするために <literal>after_statement</literal> を"
+"使ってください。非 JTA コネクションの場合、各トランザクションが終了したとき"
+"に <literal>after_transaction</literal> を使い、コネクションをリリースしてく"
+"ださい。 <literal>auto</literal> にすると、 JTA や CMT トランザクションの場"
+"合、 <literal>after_statement</literal> でクローズし、 JDBC トランザクション"
+"の場合、 <literal>after_transaction</literal> でクローズします。"
 
 #. Tag: para
-#: configuration.xml:699
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>auto</literal> (default) "
 "| <literal>on_close</literal> | <literal>after_transaction</literal> | "
 "<literal>after_statement</literal>"
 msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>auto</literal> (default) | "
-"<literal>on_close</literal> | <literal>after_transaction</literal> | "
+"<emphasis role=\"strong\">例</emphasis><literal>auto</literal> (デフォルト) "
+"| <literal>on_close</literal> | <literal>after_transaction</literal> | "
 "<literal>after_statement</literal>"
 
 #. Tag: para
-#: configuration.xml:704
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This setting only affects <literal>Session</literal>s returned from "
 "<literal>SessionFactory.openSession</literal>. For <literal>Session</"
 "literal>s obtained through <literal>SessionFactory.getCurrentSession</"
 "literal>, the <literal>CurrentSessionContext</literal> implementation "
 "configured for use controls the connection release mode for those "
-"<literal>Session</literal>s. See"
+"<literal>Session</literal>s. See <xref linkend=\"architecture-current-session"
+"\" />"
 msgstr ""
-"注意してください。この設定は <literal>SessionFactory.openSession</literal> か"
-"ら 取得した <literal>Session</literal> だけに効果があります。 "
-"<literal>SessionFactory.getCurrentSession</literal> を通じて取得した "
-"<literal>Session</literal> では、<literal>CurrentSessionContext</literal> の"
-"実装によって、コネクションのリリースモードを設定します。 <xref linkend="
-"\"architecture-current-session\"/> を参照してください。"
+"この設定は <literal>SessionFactory.openSession</literal> から取得した "
+"<literal>Session</literal> だけに効果があります。 <literal>SessionFactory."
+"getCurrentSession</literal> を通じて取得した <literal>Session</literal> で"
+"は、 <literal>CurrentSessionContext</literal> の実装によって、コネクションの"
+"リリースモードを設定します。 <xref linkend=\"architecture-current-session\"/"
+"> を参照してください。"
 
 #. Tag: entry
-#: configuration.xml:715
 #, no-c-format
 msgid ""
 "<property>hibernate.connection.</property><emphasis>&lt;propertyName&gt;</"
 "emphasis>"
 msgstr ""
+"<property>hibernate.connection.</property><emphasis>&lt;propertyName&gt;</"
+"emphasis>"
 
 #. Tag: entry
-#: configuration.xml:718
 #, no-c-format
 msgid ""
 "Pass the JDBC property <emphasis>&lt;propertyName&gt;</emphasis> to "
 "<literal>DriverManager.getConnection()</literal>."
 msgstr ""
+"JDBC プロパティ <emphasis>&lt;propertyName&gt;</emphasis> を "
+"<literal>DriverManager.getConnection()</literal> に渡します。"
 
 #. Tag: entry
-#: configuration.xml:724
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "<property>hibernate.jndi.</property><emphasis>&lt;propertyName&gt;</emphasis>"
 msgstr ""
+"<literal>hibernate.jndi.</literal><emphasis>&lt;property&gt;</emphasis> ã‚’"
+"使って、システムプロパティとして"
 
 #. Tag: entry
-#: configuration.xml:727
 #, no-c-format
 msgid ""
 "Pass the property <emphasis>&lt;propertyName&gt;</emphasis> to the JNDI "
 "<literal>InitialContextFactory</literal>."
 msgstr ""
+"プロパティ <emphasis>&lt;propertyName&gt;</emphasis> を JNDI "
+"<literal>InitialContextFactory</literal> に渡します。"
 
 #. Tag: title
-#: configuration.xml:737
 #, no-c-format
 msgid "Hibernate Cache Properties"
 msgstr "Hibernate キャッシュプロパティ"
 
-#. Tag: literal
-#: configuration.xml:750
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.provider_class"
-msgstr "hibernate.cache.provider_class"
+msgid "<literal>hibernate.cache.provider_class</literal>"
+msgstr "<literal>hibernate.cache.provider_class</literal>"
 
 #. Tag: entry
-#: configuration.xml:752
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The classname of a custom <literal>CacheProvider</literal>."
-msgstr "カスタム <placeholder-1/> のクラス名です。 <placeholder-2/>"
+msgstr "カスタム <literal>CacheProvider</literal> のクラス名です。"
 
 #. Tag: para
-#: configuration.xml:754
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "CacheProvider</literal>"
 msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例</emphasis><literal>classname.of.CacheProvider</"
+"literal>"
 
-#. Tag: literal
-#: configuration.xml:762
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_minimal_puts"
-msgstr "hibernate.cache.use_minimal_puts"
+msgid "<literal>hibernate.cache.use_minimal_puts</literal>"
+msgstr "<literal>hibernate.cache.use_minimal_puts</literal>"
 
 #. Tag: entry
-#: configuration.xml:764
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Optimizes second-level cache operation to minimize writes, at the cost of "
 "more frequent reads. This setting is most useful for clustered caches and, "
 "in Hibernate3, is enabled by default for clustered cache implementations."
 msgstr ""
-"書き込みを最小限にするために、二次キャッシュの操作を最適化します。 その代わり"
-"に、読み込みがより頻繁に発生するようになります。 このセッティングはクラスタ"
-"キャッシュで役に立ちます。 Hibernate3ではクラスタキャッシュ実装用にデフォルト"
-"では有効になっています。 <placeholder-1/>"
+"書き込みを最小限にするために、二次キャッシュの操作を最適化します。その代わり"
+"に、読み込みがより頻繁に発生するようになります。このセッティングはクラスタ"
+"キャッシュで役に立ちます。 Hibernate3 ではクラスタキャッシュ実装用にデフォル"
+"トでは有効になっています。 "
 
-#. Tag: literal
-#: configuration.xml:777
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_query_cache"
-msgstr "hibernate.cache.use_query_cache"
+msgid "<literal>hibernate.cache.use_query_cache</literal>"
+msgstr "<literal>hibernate.cache.use_query_cache</literal>"
 
 #. Tag: entry
-#: configuration.xml:779
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Enables the query cache. Individual queries still have to be set cachable."
 msgstr ""
 "特定のクエリがキャッシュ可能な場合に、クエリキャッシュを有効にします。 "
-"<placeholder-1/>"
 
-#. Tag: literal
-#: configuration.xml:789
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_second_level_cache"
-msgstr "hibernate.cache.use_second_level_cache"
+msgid "<literal>hibernate.cache.use_second_level_cache</literal>"
+msgstr "<literal>hibernate.cache.use_second_level_cache</literal>"
 
 #. Tag: entry
-#: configuration.xml:791
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Can be used to completely disable the second level cache, which is enabled "
 "by default for classes which specify a <literal>&lt;cache&gt;</literal> "
 "mapping."
 msgstr ""
-"二次キャッシュを完全に無効にする場合に使います。 デフォルトでは有効で、クラス"
-"の <placeholder-1/> マッピング で制御します。 <placeholder-2/>"
+"二次キャッシュを完全に無効にする場合に使います。デフォルトでは有効で、クラス"
+"の <literal>&lt;cache&gt;</literal> マッピングで制御します。"
 
-#. Tag: literal
-#: configuration.xml:803
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.query_cache_factory"
-msgstr "hibernate.cache.query_cache_factory"
+msgid "<literal>hibernate.cache.query_cache_factory</literal>"
+msgstr "<literal>hibernate.cache.query_cache_factory</literal>"
 
 #. Tag: entry
-#: configuration.xml:805
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a custom <literal>QueryCache</literal> interface, defaults "
 "to the built-in <literal>StandardQueryCache</literal>."
 msgstr ""
-"カスタム <placeholder-1/> インターフェイスのクラス名を 指定します。デフォルト"
-"では <placeholder-2/> になります。 <placeholder-3/>"
+"カスタム <literal>QueryCache</literal> インターフェースのクラス名を指定しま"
+"す。デフォルトでは <literal>StandardQueryCache</literal> になります。"
 
 #. Tag: para
-#: configuration.xml:808
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of.QueryCache</"
 "literal>"
 msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of.QueryCache</"
+"literal>"
 
-#. Tag: literal
-#: configuration.xml:816
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.region_prefix"
-msgstr "hibernate.cache.region_prefix"
+msgid "<literal>hibernate.cache.region_prefix</literal>"
+msgstr "<literal>hibernate.cache.region_prefix</literal>"
 
 #. Tag: entry
-#: configuration.xml:818
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A prefix to use for second-level cache region names."
-msgstr "二次キャッシュの領域名の接頭辞です。 <placeholder-1/>"
+msgstr "二次キャッシュの領域名の接頭辞です。"
 
 #. Tag: para
-#: configuration.xml:820
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>prefix</literal>"
-msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+msgstr "<emphasis role=\"strong\">例</emphasis><literal>prefix</literal>"
 
-#. Tag: literal
-#: configuration.xml:828
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_structured_entries"
-msgstr "hibernate.cache.use_structured_entries"
+msgid "<literal>hibernate.cache.use_structured_entries</literal>"
+msgstr "<literal>hibernate.cache.use_structured_entries</literal>"
 
 #. Tag: entry
-#: configuration.xml:830
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Forces Hibernate to store data in the second-level cache in a more human-"
 "friendly format."
 msgstr ""
 "二次キャッシュに格納するデータを、人が理解しやすいフォーマットにします。 "
-"<placeholder-1/>"
 
 #. Tag: title
-#: configuration.xml:844
 #, no-c-format
 msgid "Hibernate Transaction Properties"
 msgstr "Hibernate トランザクションプロパティ"
 
-#. Tag: literal
-#: configuration.xml:857
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.transaction.factory_class"
-msgstr "hibernate.transaction.factory_class"
+msgid "<literal>hibernate.transaction.factory_class</literal>"
+msgstr "<literal>hibernate.transaction.factory_class</literal>"
 
 #. Tag: entry
-#: configuration.xml:859
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a <literal>TransactionFactory</literal> to use with "
 "Hibernate <literal>Transaction</literal> API (defaults to "
 "<literal>JDBCTransactionFactory</literal>)."
 msgstr ""
-"Hibernate <placeholder-1/> APIと一緒に使われる <placeholder-2/> のクラス名で"
-"す。 (デフォルトでは <placeholder-3/> です)。 <placeholder-4/>"
+"Hibernate <literal>Transaction</literal> API と一緒に使われる "
+"<literal>TransactionFactory</literal> のクラス名です。 (デフォルトでは "
+"<literal>JDBCTransactionFactory</literal> です)。"
 
 #. Tag: para
-#: configuration.xml:863
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "TransactionFactory</literal>"
 msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例</emphasis><literal>classname.of."
+"TransactionFactory</literal>>"
 
-#. Tag: literal
-#: configuration.xml:871
+#. Tag: entry
 #, no-c-format
-msgid "jta.UserTransaction"
-msgstr "jta.UserTransaction"
+msgid "<literal>jta.UserTransaction</literal>"
+msgstr "<literal>jta.UserTransaction</literal>"
 
 #. Tag: entry
-#: configuration.xml:873
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A JNDI name used by <literal>JTATransactionFactory</literal> to obtain the "
 "JTA <literal>UserTransaction</literal> from the application server."
 msgstr ""
-"アプリケーションサーバからJTA <placeholder-1/> を取得するために <placeholder-"
-"2/> に使われるJNDI名です。 <placeholder-3/>"
+"アプリケーションサーバーから JTA <literal>UserTransaction</literal> を取得す"
+"るために <literal>JTATransactionFactory</literal> に使われる JNDI 名です。"
 
-#. Tag: literal
-#: configuration.xml:885
-#, no-c-format
-msgid "hibernate.transaction.manager_lookup_class"
-msgstr "hibernate.transaction.manager_lookup_class"
-
 #. Tag: entry
-#: configuration.xml:887
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.manager_lookup_class</literal>"
+msgstr "<literal>hibernate.transaction. manager_lookup_class</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "The classname of a <literal>TransactionManagerLookup</literal>. It is "
 "required when JVM-level caching is enabled or when using hilo generator in a "
 "JTA environment."
 msgstr ""
-"<placeholder-1/> のクラス名です。 JTA環境において、JVMレベルのキャッシュを有"
-"効にするために必要です。 <placeholder-2/>"
+"<literal>TransactionManagerLookup</literal> のクラス名です。 JTA 環境におい"
+"て、 JVM レベルのキャッシュを有効にするときか、 hilo ジェネレータが使用される"
+"ときに必要です。"
 
 #. Tag: para
-#: configuration.xml:891
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "TransactionManagerLookup</literal>"
 msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例</emphasis><literal>classname.of."
+"TransactionManagerLookup</literal>"
 
-#. Tag: literal
-#: configuration.xml:899
-#, no-c-format
-msgid "hibernate.transaction.flush_before_completion"
-msgstr "hibernate.transaction.flush_before_completion"
-
 #. Tag: entry
-#: configuration.xml:901
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.flush_before_completion</literal>"
+msgstr "<literal>hibernate.transaction. flush_before_completion</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "If enabled, the session will be automatically flushed during the before "
 "completion phase of the transaction. Built-in and automatic session context "
-"management is preferred, see <xref linkend=\"architecture-current-session\"/"
+"management is preferred, see <xref linkend=\"architecture-current-session\" /"
 ">."
 msgstr ""
-"有効の場合、トランザクションのcompletionフェーズの前に自動的に セッションをフ"
-"ラッシュします。内臓の自動セッションコンテキスト管理に適しています。 <xref "
-"linkend=\"architecture-current-session\"/>を参照してください。 <placeholder-"
-"1/>"
+"有効の場合、トランザクションの completion フェーズの前に自動的にセッションを"
+"フラッシュします。内蔵の自動セッションコンテキスト管理に適しています。 <xref "
+"linkend=\"architecture-current-session\"/> を参照してください。"
 
-#. Tag: literal
-#: configuration.xml:914
-#, no-c-format
-msgid "hibernate.transaction.auto_close_session"
-msgstr "hibernate.transaction.auto_close_session"
-
 #. Tag: entry
-#: configuration.xml:916
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.auto_close_session</literal>"
+msgstr "<literal>hibernate.transaction. auto_close_session</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "If enabled, the session will be automatically closed during the after "
 "completion phase of the transaction. Built-in and automatic session context "
-"management is preferred, see <xref linkend=\"architecture-current-session\"/"
+"management is preferred, see <xref linkend=\"architecture-current-session\" /"
 ">."
 msgstr ""
-"有効の場合、トランザクションのcompletionフェーズの後に セッションを自動的にク"
-"ローズします。内臓の自動セッションコンテキスト管理に適しています。 <xref "
-"linkend=\"architecture-current-session\"/>を参照してください。 <placeholder-"
-"1/>"
+"有効の場合、トランザクションの completion フェーズの後にセッションを自動的に"
+"クローズします。内蔵の自動セッションコンテキスト管理に適しています。 <xref "
+"linkend=\"architecture-current-session\"/> を参照してください。"
 
 #. Tag: title
-#: configuration.xml:932
 #, no-c-format
 msgid "Miscellaneous Properties"
 msgstr "その他のプロパティ"
 
-#. Tag: literal
-#: configuration.xml:945
-#, no-c-format
-msgid "hibernate.current_session_context_class"
-msgstr "hibernate.current_session_context_class"
-
 #. Tag: entry
-#: configuration.xml:947
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.current_session_context_class</literal>"
+msgstr "<literal>hibernate. current_session_context_class</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "Supply a custom strategy for the scoping of the \"current\" "
 "<literal>Session</literal>. See <xref linkend=\"architecture-current-session"
-"\"/> for more information about the built-in strategies."
+"\" /> for more information about the built-in strategies."
 msgstr ""
-"「現在の」<placeholder-1/> のための(カスタム)戦略を提供します。 ビルトイン"
-"ストラテジーに関するその他の情報については <xref linkend=\"architecture-"
-"current-session\"/>を参照してください。 <placeholder-2/>"
+"「現在の」 <literal>Session</literal> のための(カスタム)戦略を提供します。"
+"ビルトインストラテジーに関するその他の情報については <xref linkend="
+"\"architecture-current-session\"/> を参照してください。"
 
 #. Tag: para
-#: configuration.xml:952
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>jta</literal> | "
 "<literal>thread</literal> | <literal>managed</literal> | <literal>custom."
 "Class</literal>"
 msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>jta</literal> | "
+"<emphasis role=\"strong\">例</emphasis><literal>jta</literal> | "
 "<literal>thread</literal> | <literal>managed</literal> | <literal>custom."
 "Class</literal>"
 
-#. Tag: literal
-#: configuration.xml:961
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.query.factory_class"
-msgstr "hibernate.query.factory_class"
+msgid "<literal>hibernate.query.factory_class</literal>"
+msgstr "<literal>hibernate.query.factory_class</literal>"
 
 #. Tag: entry
-#: configuration.xml:963
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Chooses the HQL parser implementation."
-msgstr "HQLパーサーの実装を選択します。 <placeholder-1/>"
+msgstr "HQL パーサーの実装を選択します。"
 
 #. Tag: para
-#: configuration.xml:965
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>org.hibernate.hql.ast."
 "ASTQueryTranslatorFactory</literal> or <literal>org.hibernate.hql.classic."
 "ClassicQueryTranslatorFactory</literal>"
 msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>org.hibernate.hql.ast."
+"<emphasis role=\"strong\">例</emphasis><literal>org.hibernate.hql.ast."
 "ASTQueryTranslatorFactory</literal> or <literal>org.hibernate.hql.classic."
 "ClassicQueryTranslatorFactory</literal>"
 
-#. Tag: literal
-#: configuration.xml:974
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.query.substitutions"
-msgstr "hibernate.query.substitutions"
+msgid "<literal>hibernate.query.substitutions</literal>"
+msgstr "<literal>hibernate.query.substitutions</literal>"
 
 #. Tag: entry
-#: configuration.xml:976
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Is used to map from tokens in Hibernate queries to SQL tokens (tokens might "
 "be function or literal names, for example)."
 msgstr ""
-"HQLとSQLのトークンをマッピングします。 (例えば、トークンは関数やリテラル名で"
-"す)。 <placeholder-1/>"
+"HQL と SQL のトークンをマッピングします。 (例えば、トークンは関数やリテラル"
+"名です)。"
 
 #. Tag: para
-#: configuration.xml:979
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>hqlLiteral=SQL_LITERAL, "
 "hqlFunction=SQLFUNC</literal>"
 msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例</emphasis><literal>hqlLiteral=SQL_LITERAL, "
+"hqlFunction=SQLFUNC</literal>"
 
-#. Tag: literal
-#: configuration.xml:987
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.hbm2ddl.auto"
-msgstr "hibernate.hbm2ddl.auto"
+msgid "<literal>hibernate.hbm2ddl.auto</literal>"
+msgstr "<literal>hibernate.hbm2ddl.auto</literal>"
 
 #. Tag: entry
-#: configuration.xml:989
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Automatically validates or exports schema DDL to the database when the "
 "<literal>SessionFactory</literal> is created. With <literal>create-drop</"
 "literal>, the database schema will be dropped when the "
 "<literal>SessionFactory</literal> is closed explicitly."
 msgstr ""
-"<placeholder-1/> を生成したときに、 自動的にスキーマDDLをDBに出力します。 "
-"<placeholder-2/> の場合、 <placeholder-3/> を クローズしたときに、データベー"
-"ススキーマをドロップします。 <placeholder-4/>"
+"<literal>SessionFactory</literal> を生成したときに、自動的にスキーマ DDL を有"
+"効にしデータベースに出力します。 <literal>create-drop</literal> の場合、 "
+"<literal>SessionFactory</literal> をクローズしたときに、データベーススキーマ"
+"をドロップします。"
 
 #. Tag: para
-#: configuration.xml:995
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>validate</literal> | "
 "<literal>update</literal> | <literal>create</literal> | <literal>create-"
 "drop</literal>"
 msgstr ""
-"<emphasis role=\"strong\">例:</emphasis><literal>validate</literal> | "
+"<emphasis role=\"strong\">例</emphasis> <literal>validate</literal> | "
 "<literal>update</literal> | <literal>create</literal> | <literal>create-"
 "drop</literal>"
 
-#. Tag: literal
-#: configuration.xml:1004
-#, no-c-format
-msgid "hibernate.cglib.use_reflection_optimizer"
-msgstr "hibernate.cglib.use_reflection_optimizer"
-
 #. Tag: entry
-#: configuration.xml:1006
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.cglib.use_reflection_optimizer</literal>"
+msgstr "<literal>hibernate.cglib. use_reflection_optimizer</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "Enables the use of CGLIB instead of runtime reflection (System-level "
 "property). Reflection can sometimes be useful when troubleshooting. "
 "Hibernate always requires CGLIB even if you turn off the optimizer. You "
 "cannot set this property in <literal>hibernate.cfg.xml</literal>."
 msgstr ""
-"実行時リフレクションの代わりのCGLIBの使用を有効にします (システムレベルのプ"
-"ロパティ) リフレクションはトラブルシューティングのときに役立つことがありま"
-"す。 オプティマイザをオフにしているときでさえ、 Hibernateには必ずCGLIBが必要"
-"なことに注意してください。 このプロパティは <placeholder-1/> で設定できませ"
-"ん。 <placeholder-2/>"
+"実行時リフレクションの代わりの CGLIB の使用を有効にします (システムレベルの"
+"プロパティ) 。リフレクションはトラブルシューティングのときに役立つことがあり"
+"ます。オプティマイザをオフにしているときでさえ、 Hibernate には必ず CGLIB が"
+"必要なことに注意してください。このプロパティは <literal>hibernate.cfg.xml</"
+"literal> で設定できません。"
 
 #. Tag: title
-#: configuration.xml:1022
 #, no-c-format
 msgid "SQL Dialects"
 msgstr "SQL 方言(Dialect)"
 
 #. Tag: para
-#: configuration.xml:1024
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Always set the <literal>hibernate.dialect</literal> property to the correct "
 "<literal>org.hibernate.dialect.Dialect</literal> subclass for your database. "
@@ -1634,315 +1389,264 @@
 "the other properties listed above. This means that you will not have to "
 "specify them manually."
 msgstr ""
-"<literal>hibernate.dialect</literal> プロパティには、 使用するデータベースの"
-"正しい <literal>org.hibernate.dialect.Dialect</literal> のサブクラスを、 必ず"
-"指定すべきです。 しかし方言を指定すれば、Hibernateは上述したプロパティのいく"
-"つかについて、 より適切なデフォルト値を使います。 そうすれば、それらを手作業"
-"で設定する手間が省けます。"
+"<literal>hibernate.dialect</literal> プロパティには、使用するデータベースの正"
+"しい <literal>org.hibernate.dialect.Dialect</literal> のサブクラスを、必ず指"
+"定すべきです。しかし方言を指定すれば、 Hibernate は上述したプロパティのいくつ"
+"かについて、より適切なデフォルト値を使います。そうすれば、それらを手作業で設"
+"定する手間が省けます。"
 
 #. Tag: title
-#: configuration.xml:1032
 #, no-c-format
 msgid "Hibernate SQL Dialects (<literal>hibernate.dialect</literal>)"
 msgstr "Hibernate SQL Dialects (<literal>hibernate.dialect</literal>)"
 
 #. Tag: entry
-#: configuration.xml:1040
 #, no-c-format
 msgid "RDBMS"
 msgstr "RDBMS"
 
 #. Tag: entry
-#: configuration.xml:1041
 #, no-c-format
 msgid "Dialect"
 msgstr "Dialect"
 
 #. Tag: entry
-#: configuration.xml:1046
 #, no-c-format
-msgid "<entry>DB2</entry>"
-msgstr ""
+msgid "DB2"
+msgstr "DB2"
 
-#. Tag: literal
-#: configuration.xml:1046
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2Dialect"
-msgstr "org.hibernate.dialect.DB2Dialect"
+msgid "<literal>org.hibernate.dialect.DB2Dialect</literal>"
+msgstr "<literal>org.hibernate.dialect.DB2Dialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1049
 #, no-c-format
 msgid "DB2 AS/400"
 msgstr "DB2 AS/400"
 
-#. Tag: literal
-#: configuration.xml:1049
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2400Dialect"
-msgstr "org.hibernate.dialect.DB2400Dialect"
+msgid "<literal>org.hibernate.dialect.DB2400Dialect</literal>"
+msgstr "<literal>org.hibernate.dialect.DB2400Dialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1052
 #, no-c-format
 msgid "DB2 OS390"
 msgstr "DB2 OS390"
 
-#. Tag: literal
-#: configuration.xml:1052
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2390Dialect"
-msgstr "org.hibernate.dialect.DB2390Dialect"
+msgid "<literal>org.hibernate.dialect.DB2390Dialect</literal>"
+msgstr "<literal>org.hibernate.dialect.DB2390Dialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1055
 #, no-c-format
 msgid "PostgreSQL"
 msgstr "PostgreSQL"
 
-#. Tag: literal
-#: configuration.xml:1055
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.PostgreSQLDialect"
-msgstr "org.hibernate.dialect.PostgreSQLDialect"
+msgid "<literal>org.hibernate.dialect.PostgreSQLDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.PostgreSQLDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1058
 #, no-c-format
 msgid "MySQL"
 msgstr "MySQL"
 
-#. Tag: literal
-#: configuration.xml:1058
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLDialect"
-msgstr "org.hibernate.dialect.MySQLDialect"
+msgid "<literal>org.hibernate.dialect.MySQLDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MySQLDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1061
 #, no-c-format
 msgid "MySQL with InnoDB"
 msgstr "MySQL with InnoDB"
 
-#. Tag: literal
-#: configuration.xml:1061
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLInnoDBDialect"
-msgstr "org.hibernate.dialect.MySQLInnoDBDialect"
+msgid "<literal>org.hibernate.dialect.MySQLInnoDBDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MySQLInnoDBDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1064
 #, no-c-format
 msgid "MySQL with MyISAM"
 msgstr "MySQL with MyISAM"
 
-#. Tag: literal
-#: configuration.xml:1064
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLMyISAMDialect"
-msgstr "org.hibernate.dialect.MySQLMyISAMDialect"
+msgid "<literal>org.hibernate.dialect.MySQLMyISAMDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MySQLMyISAMDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1067
 #, no-c-format
 msgid "Oracle (any version)"
-msgstr "Oracle (any version)"
+msgstr "Oracle (いずれのバージョンでも)"
 
-#. Tag: literal
-#: configuration.xml:1067
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.OracleDialect"
-msgstr "org.hibernate.dialect.OracleDialect"
+msgid "<literal>org.hibernate.dialect.OracleDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.OracleDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1070
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Oracle 9i"
-msgstr "Oracle 9i/10g"
+msgstr "Oracle 9i"
 
-#. Tag: literal
-#: configuration.xml:1070
-#, fuzzy, no-c-format
-msgid "org.hibernate.dialect.Oracle9iDialect"
-msgstr "org.hibernate.dialect.Oracle9Dialect"
+#. Tag: entry
+#, no-c-format
+msgid "<literal>org.hibernate.dialect.Oracle9iDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.Oracle9iDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1073
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Oracle 10g"
-msgstr "Oracle 9i/10g"
+msgstr "Oracle 10g"
 
-#. Tag: literal
-#: configuration.xml:1073
-#, fuzzy, no-c-format
-msgid "org.hibernate.dialect.Oracle10gDialect"
-msgstr "org.hibernate.dialect.OracleDialect"
+#. Tag: entry
+#, no-c-format
+msgid "<literal>org.hibernate.dialect.Oracle10gDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.Oracle10gDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1076
 #, no-c-format
 msgid "Sybase"
 msgstr "Sybase"
 
-#. Tag: literal
-#: configuration.xml:1076
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SybaseDialect"
-msgstr "org.hibernate.dialect.SybaseDialect"
+msgid "<literal>org.hibernate.dialect.SybaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SybaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1079
 #, no-c-format
 msgid "Sybase Anywhere"
 msgstr "Sybase Anywhere"
 
-#. Tag: literal
-#: configuration.xml:1079
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SybaseAnywhereDialect"
-msgstr "org.hibernate.dialect.SybaseAnywhereDialect"
+msgid "<literal>org.hibernate.dialect.SybaseAnywhereDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SybaseAnywhereDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1082
 #, no-c-format
 msgid "Microsoft SQL Server"
 msgstr "Microsoft SQL Server"
 
-#. Tag: literal
-#: configuration.xml:1082
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SQLServerDialect"
-msgstr "org.hibernate.dialect.SQLServerDialect"
+msgid "<literal>org.hibernate.dialect.SQLServerDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SQLServerDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1085
 #, no-c-format
 msgid "SAP DB"
 msgstr "SAP DB"
 
-#. Tag: literal
-#: configuration.xml:1085
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SAPDBDialect"
-msgstr "org.hibernate.dialect.SAPDBDialect"
+msgid "<literal>org.hibernate.dialect.SAPDBDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SAPDBDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1088
 #, no-c-format
 msgid "Informix"
 msgstr "Informix"
 
-#. Tag: literal
-#: configuration.xml:1088
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.InformixDialect"
-msgstr "org.hibernate.dialect.InformixDialect"
+msgid "<literal>org.hibernate.dialect.InformixDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.InformixDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1091
 #, no-c-format
 msgid "HypersonicSQL"
 msgstr "HypersonicSQL"
 
-#. Tag: literal
-#: configuration.xml:1091
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.HSQLDialect"
-msgstr "org.hibernate.dialect.HSQLDialect"
+msgid "<literal>org.hibernate.dialect.HSQLDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.HSQLDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1094
 #, no-c-format
 msgid "Ingres"
 msgstr "Ingres"
 
-#. Tag: literal
-#: configuration.xml:1094
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.IngresDialect"
-msgstr "org.hibernate.dialect.IngresDialect"
+msgid "<literal>org.hibernate.dialect.IngresDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.IngresDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1097
 #, no-c-format
 msgid "Progress"
 msgstr "Progress"
 
-#. Tag: literal
-#: configuration.xml:1097
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.ProgressDialect"
-msgstr "org.hibernate.dialect.ProgressDialect"
+msgid "<literal>org.hibernate.dialect.ProgressDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.ProgressDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1100
 #, no-c-format
 msgid "Mckoi SQL"
 msgstr "Mckoi SQL"
 
-#. Tag: literal
-#: configuration.xml:1100
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MckoiDialect"
-msgstr "org.hibernate.dialect.MckoiDialect"
+msgid "<literal>org.hibernate.dialect.MckoiDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MckoiDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1103
 #, no-c-format
 msgid "Interbase"
 msgstr "Interbase"
 
-#. Tag: literal
-#: configuration.xml:1103
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.InterbaseDialect"
-msgstr "org.hibernate.dialect.InterbaseDialect"
+msgid "<literal>org.hibernate.dialect.InterbaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.InterbaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1106
 #, no-c-format
 msgid "Pointbase"
 msgstr "Pointbase"
 
-#. Tag: literal
-#: configuration.xml:1106
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.PointbaseDialect"
-msgstr "org.hibernate.dialect.PointbaseDialect"
+msgid "<literal>org.hibernate.dialect.PointbaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.PointbaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1109
 #, no-c-format
 msgid "FrontBase"
 msgstr "FrontBase"
 
-#. Tag: literal
-#: configuration.xml:1109
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.FrontbaseDialect"
-msgstr "org.hibernate.dialect.FrontbaseDialect"
+msgid "<literal>org.hibernate.dialect.FrontbaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.FrontbaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1112
 #, no-c-format
 msgid "Firebird"
 msgstr "Firebird"
 
-#. Tag: literal
-#: configuration.xml:1112
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.FirebirdDialect"
-msgstr "org.hibernate.dialect.FirebirdDialect"
+msgid "<literal>org.hibernate.dialect.FirebirdDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.FirebirdDialect</literal>"
 
 #. Tag: title
-#: configuration.xml:1121
 #, no-c-format
 msgid "Outer Join Fetching"
 msgstr "外部結合フェッチ"
 
 #. Tag: para
-#: configuration.xml:1123
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your database supports ANSI, Oracle or Sybase style outer joins, "
 "<emphasis>outer join fetching</emphasis> will often increase performance by "
@@ -1952,15 +1656,15 @@
 "one, one-to-many, many-to-many and one-to-one associations to be retrieved "
 "in a single SQL <literal>SELECT</literal>."
 msgstr ""
-"もしDBがANSIか、OracleかSybaseスタイルの外部結合をサポートしている場合、 "
-"<emphasis>outer join fetching</emphasis> は、DBのSQL発行回数を節約し パフォー"
-"マンスを良くします。(DB内でより多くの処理コストが発生します) 外部結合フェッ"
-"チは、多対一、一対多、多対多、一対一のオブジェクト関連で グループオブジェクト"
-"を1つのSQLで <literal>SELECT</literal> します。"
+"もしデータベースが ANSI か、 Oracle か Sybase スタイルの外部結合をサポートし"
+"ている場合、 <emphasis>outer join fetching</emphasis> は、データベースの SQL "
+"発行回数を節約しパフォーマンスを良くします(データベース内でより多くの処理コ"
+"ストが発生します)。外部結合フェッチは、多対一、一対多、多対多、一対一のオブ"
+"ジェクト関連でグループオブジェクトを1つの SQL で <literal>SELECT</literal> し"
+"ます。"
 
 #. Tag: para
-#: configuration.xml:1132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Outer join fetching can be disabled <emphasis>globally</emphasis> by setting "
 "the property <literal>hibernate.max_fetch_depth</literal> to <literal>0</"
@@ -1969,26 +1673,25 @@
 "with <literal>fetch=\"join\"</literal>."
 msgstr ""
 "<literal>hibernate.max_fetch_depth</literal> プロパティの値を <literal>0</"
-"literal> にすると Outer join fetchingを <emphasis>すべて</emphasis> 無効にす"
-"ることになります。 <literal>1</literal> やそれ以上の値を設定すると、外部結合"
-"フェッチが有効になり、 一対一と多対一関連が <literal>fetch=\"join\"</"
-"literal> としてマッピングされます。"
+"literal> にすると外部結合フェッチを <emphasis>すべて</emphasis> 無効にするこ"
+"とになります。 <literal>1</literal> やそれ以上の値を設定すると、外部結合"
+"フェッチが有効になり、一対一と多対一関連が <literal>fetch=\"join\"</literal> "
+"としてマッピングされます。"
 
 #. Tag: para
-#: configuration.xml:1140
 #, no-c-format
-msgid "See <xref linkend=\"performance-fetching\"/> for more information."
-msgstr "See <xref linkend=\"performance-fetching\"/> for more information."
+msgid "See <xref linkend=\"performance-fetching\" /> for more information."
+msgstr ""
+"さらに情報が見たければ <xref linkend=\"performance-fetching\"/> を参照してく"
+"ださい。"
 
 #. Tag: title
-#: configuration.xml:1147
 #, no-c-format
 msgid "Binary Streams"
 msgstr "バイナリストリーム"
 
 #. Tag: para
-#: configuration.xml:1149
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Oracle limits the size of <literal>byte</literal> arrays that can be passed "
 "to and/or from its JDBC driver. If you wish to use large instances of "
@@ -1996,85 +1699,65 @@
 "should enable <literal>hibernate.jdbc.use_streams_for_binary</literal>. "
 "<emphasis>This is a system-level setting only.</emphasis>"
 msgstr ""
-"OracleはJDBCドライバとの間でやりとりされる <literal>byte</literal> 配列のサイ"
-"ズを制限します。 <literal>binary</literal> や <literal>serializable</"
+"Oracle は JDBC ドライバとの間でやりとりされる <literal>byte</literal> 配列の"
+"サイズを制限します。 <literal>binary</literal> や <literal>serializable</"
 "literal> 型の大きなインスタンスを使いたければ、 <literal>hibernate.jdbc."
 "use_streams_for_binary</literal> を有効にしてください。 ただし <emphasis>これ"
 "はシステムレベルの設定だけです</emphasis> 。"
 
 #. Tag: title
-#: configuration.xml:1160
 #, no-c-format
 msgid "Second-level and query cache"
-msgstr "2次キャッシュとクエリーキャッシュ"
+msgstr "ニ次キャッシュとクエリキャッシュ"
 
 #. Tag: para
-#: configuration.xml:1162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The properties prefixed by <literal>hibernate.cache</literal> allow you to "
 "use a process or cluster scoped second-level cache system with Hibernate. "
-"See the <xref linkend=\"performance-cache\"/> for more information."
+"See the <xref linkend=\"performance-cache\" /> for more information."
 msgstr ""
-"<literal>hibernate.cache</literal> プロパティ接頭辞は Hibernateでプロセスやク"
-"ラスタ二次キャッシュを使うとことを許可します。 <xref linkend=\"performance-"
-"cache\"/>により多くの詳細があります。"
+"<literal>hibernate.cache</literal> プロパティ接頭辞は Hibernate でプロセスや"
+"クラスタ二次キャッシュを使うとことを許可します。<xref linkend=\"performance-"
+"cache\"/> により多くの詳細があります。"
 
 #. Tag: title
-#: configuration.xml:1172
 #, no-c-format
 msgid "Query Language Substitution"
-msgstr "クエリー言語の置き換え"
+msgstr "クエリ言語の置き換え"
 
 #. Tag: para
-#: configuration.xml:1174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can define new Hibernate query tokens using <literal>hibernate.query."
 "substitutions</literal>. For example:"
 msgstr ""
-"<literal>hibernate.query.substitutions</literal> を使うことで、 新しい"
-"Hibernateクエリトークンを定義できます。 例:"
+"<literal>hibernate.query.substitutions</literal> を使うことで、新しい "
+"Hibernate クエリトークンを定義できます。例:"
 
-#. Tag: programlisting
-#: configuration.xml:1179
-#, no-c-format
-msgid "hibernate.query.substitutions true=1, false=0"
-msgstr "hibernate.query.substitutions true=1, false=0"
-
 #. Tag: para
-#: configuration.xml:1181
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This would cause the tokens <literal>true</literal> and <literal>false</"
 "literal> to be translated to integer literals in the generated SQL."
 msgstr ""
-"これはトークン <literal>true</literal> と <literal>false</literal> を、 生成"
-"されるSQLにおいて整数リテラルに翻訳します。"
+"これはトークン <literal>true</literal> と <literal>false</literal> を、生成さ"
+"れる SQL において整数リテラルに翻訳します。"
 
-#. Tag: programlisting
-#: configuration.xml:1186
-#, no-c-format
-msgid "hibernate.query.substitutions toLowercase=LOWER"
-msgstr "hibernate.query.substitutions toLowercase=LOWER"
-
 #. Tag: para
-#: configuration.xml:1188
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This would allow you to rename the SQL <literal>LOWER</literal> function."
 msgstr ""
-"これはSQLの <literal>LOWER</literal> 関数の名前の付け替えを可能にします。"
+"これは SQL の <literal>LOWER</literal> 関数の名前の付け替えを可能にします。"
 
 #. Tag: title
-#: configuration.xml:1195
 #, no-c-format
 msgid "Hibernate statistics"
 msgstr "Hibernate 統計"
 
 #. Tag: para
-#: configuration.xml:1197
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you enable <literal>hibernate.generate_statistics</literal>, Hibernate "
 "exposes a number of metrics that are useful when tuning a running system via "
@@ -2082,20 +1765,18 @@
 "configured to expose these statistics via JMX. Read the Javadoc of the "
 "interfaces in <literal>org.hibernate.stats</literal> for more information."
 msgstr ""
-"<literal>hibernate.generate_statistics</literal> を有効にした場合、 動作して"
-"いるシステムをチューニングするときに、<literal>SessionFactory.getStatistics()"
-"</literal> を経由して、Hibernateは便利な統計情報を出力します。 JMXを経由して"
-"統計情報を出力することも可能です。 Javadocの <literal>org.hibernate.stats</"
-"literal> パッケージ内の インターフェイスにはより多くの情報があります。"
+"<literal>hibernate.generate_statistics</literal> を有効にした場合、動作してい"
+"るシステムをチューニングするときに、 <literal>SessionFactory.getStatistics()"
+"</literal> を経由して、 Hibernate は便利な統計情報を出力します。 JMX を経由し"
+"て統計情報を出力することも可能です。 Javadoc の <literal>org.hibernate."
+"stats</literal> パッケージ内のインターフェースにはより多くの情報があります。"
 
 #. Tag: title
-#: configuration.xml:1209
 #, no-c-format
 msgid "Logging"
 msgstr "ロギング"
 
 #. Tag: para
-#: configuration.xml:1211
 #, no-c-format
 msgid ""
 "Hibernate utilizes <ulink url=\"http://www.slf4j.org/\">Simple Logging "
@@ -2113,8 +1794,7 @@
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1222
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you familiarize yourself with Hibernate's log "
 "messages. A lot of work has been put into making the Hibernate log as "
@@ -2122,149 +1802,126 @@
 "troubleshooting device. The most interesting log categories are the "
 "following:"
 msgstr ""
-"Hibernateのログメッセージに慣れることを強くおすすめします。 Hibernateのログは"
-"読みやすく、できる限り詳細になるように努力されています。 これは必須のトラブル"
-"シューティングデバイスです。 以下に重要なログのカテゴリを示します。"
+"Hibernate のログメッセージに慣れることを強くおすすめします。 Hibernate のログ"
+"は読みやすく、できる限り詳細になるように努力されています。これは必須のトラブ"
+"ルシューティングデバイスです。以下に重要なログのカテゴリを示します:"
 
 #. Tag: title
-#: configuration.xml:1231
 #, no-c-format
 msgid "Hibernate Log Categories"
 msgstr "Hibernate ログカテゴリ"
 
 #. Tag: entry
-#: configuration.xml:1237
 #, no-c-format
 msgid "Category"
 msgstr "カテゴリ"
 
 #. Tag: entry
-#: configuration.xml:1238
 #, no-c-format
 msgid "Function"
 msgstr "機能"
 
-#. Tag: literal
-#: configuration.xml:1243
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.SQL"
-msgstr "org.hibernate.SQL"
+msgid "<literal>org.hibernate.SQL</literal>"
+msgstr "<literal>org.hibernate.SQL</literal>"
 
 #. Tag: entry
-#: configuration.xml:1244
 #, no-c-format
 msgid "Log all SQL DML statements as they are executed"
-msgstr "実行したすべてのSQL(DDL)ステートメントをロギングします。"
+msgstr "実行したすべての SQL(DDL)ステートメントをロギングします。"
 
-#. Tag: literal
-#: configuration.xml:1247
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.type"
-msgstr "org.hibernate.type"
+msgid "<literal>org.hibernate.type</literal>"
+msgstr "<literal>org.hibernate.type</literal>"
 
 #. Tag: entry
-#: configuration.xml:1248
 #, no-c-format
 msgid "Log all JDBC parameters"
-msgstr "すべてのJDBCパラメータをロギングします。"
+msgstr "すべての JDBC パラメータをロギングします。"
 
-#. Tag: literal
-#: configuration.xml:1251
-#, no-c-format
-msgid "org.hibernate.tool.hbm2ddl"
-msgstr "org.hibernate.tool.hbm2ddl"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.tool.hbm2ddl</literal>"
+msgstr "<literal>org.hibernate.tool. hbm2ddl</literal>"
 
 #. Tag: entry
-#: configuration.xml:1252
 #, no-c-format
 msgid "Log all SQL DDL statements as they are executed"
-msgstr "実行したすべてのSQL(DDL)ステートメントをロギングします。"
+msgstr "実行したすべての SQL(DDL)ステートメントをロギングします。"
 
-#. Tag: literal
-#: configuration.xml:1255
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.pretty"
-msgstr "org.hibernate.pretty"
+msgid "<literal>org.hibernate.pretty</literal>"
+msgstr "<literal>org.hibernate.pretty</literal>"
 
 #. Tag: entry
-#: configuration.xml:1256
 #, no-c-format
 msgid ""
 "Log the state of all entities (max 20 entities) associated with the session "
 "at flush time"
 msgstr ""
-"sessionに関連するすべてのエンティティ(最大20)のフラッシュ時間をロギングし"
-"ます。"
+"session に関連するすべてのエンティティ(最大20)のフラッシュ時間をロギング"
+"します。"
 
-#. Tag: literal
-#: configuration.xml:1262
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.cache"
-msgstr "org.hibernate.cache"
+msgid "<literal>org.hibernate.cache</literal>"
+msgstr "<literal>org.hibernate.cache</literal>"
 
 #. Tag: entry
-#: configuration.xml:1263
 #, no-c-format
 msgid "Log all second-level cache activity"
-msgstr "すべての2次キャッシュの動作をロギングします。"
+msgstr "すべてのニ次キャッシュの動作をロギングします。"
 
-#. Tag: literal
-#: configuration.xml:1266
-#, no-c-format
-msgid "org.hibernate.transaction"
-msgstr "org.hibernate.transaction"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.transaction</literal>"
+msgstr "<literal>org.hibernate. transaction</literal>"
 
 #. Tag: entry
-#: configuration.xml:1267
 #, no-c-format
 msgid "Log transaction related activity"
 msgstr "トランザクションに関連する動作をロギングします。"
 
-#. Tag: literal
-#: configuration.xml:1270
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.jdbc"
-msgstr "org.hibernate.jdbc"
+msgid "<literal>org.hibernate.jdbc</literal>"
+msgstr "<literal>org.hibernate.jdbc</literal>"
 
 #. Tag: entry
-#: configuration.xml:1271
 #, no-c-format
 msgid "Log all JDBC resource acquisition"
-msgstr "JDBCリソース取得をロギングします。"
+msgstr "JDBC リソース取得をロギングします。"
 
-#. Tag: literal
-#: configuration.xml:1274
-#, no-c-format
-msgid "org.hibernate.hql.ast.AST"
-msgstr "org.hibernate.hql.ast.AST"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.hql.ast.AST</literal>"
+msgstr "<literal>org.hibernate.hql. ast.AST</literal>"
 
 #. Tag: entry
-#: configuration.xml:1275
 #, no-c-format
 msgid "Log HQL and SQL ASTs during query parsing"
-msgstr "HQLとSQLのASTのクエリーパースをロギングします。"
+msgstr "HQL と SQL の AST のクエリパースをロギングします。"
 
-#. Tag: literal
-#: configuration.xml:1280
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.secure"
-msgstr "org.hibernate.secure"
+msgid "<literal>org.hibernate.secure</literal>"
+msgstr "<literal>org.hibernate.secure</literal>"
 
 #. Tag: entry
-#: configuration.xml:1281
 #, no-c-format
 msgid "Log all JAAS authorization requests"
-msgstr "すべてのJAAS分析をロギングします。"
+msgstr "すべての JAAS 分析をロギングします。"
 
-#. Tag: literal
-#: configuration.xml:1284
-#, no-c-format
-msgid "org.hibernate"
-msgstr "org.hibernate"
-
 #. Tag: entry
-#: configuration.xml:1285
 #, fuzzy, no-c-format
+msgid "<literal>org.hibernate</literal>"
+msgstr "SessionFactory の JNDI への登録"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "Log everything. This is a lot of information but it is useful for "
 "troubleshooting"
@@ -2273,7 +1930,6 @@
 "便利です)"
 
 #. Tag: para
-#: configuration.xml:1294
 #, no-c-format
 msgid ""
 "When developing applications with Hibernate, you should almost always work "
@@ -2281,31 +1937,28 @@
 "hibernate.SQL</literal>, or, alternatively, the property <literal>hibernate."
 "show_sql</literal> enabled."
 msgstr ""
-"Hibernateでアプリケーションを作成するときは、<literal>org.hibernate.SQL</"
+"Hibernate でアプリケーションを作成するときは、 <literal>org.hibernate.SQL</"
 "literal> カテゴリの <literal>debug</literal> を常に有効にしておいたほうが良い"
-"でしょう。 代替方法として、<literal>hibernate.show_sql</literal> を有効にする"
-"方法があります。"
+"でしょう。代替方法として、 <literal>hibernate.show_sql</literal> プロパティを"
+"有効にする方法があります。"
 
 #. Tag: title
-#: configuration.xml:1304
 #, no-c-format
 msgid "Implementing a <literal>NamingStrategy</literal>"
-msgstr "<literal>NamingStrategy</literal> の実装"
+msgstr "<literal>NamingStrategy</literal> を選択"
 
 #. Tag: para
-#: configuration.xml:1306
 #, no-c-format
 msgid ""
 "The interface <literal>org.hibernate.cfg.NamingStrategy</literal> allows you "
 "to specify a \"naming standard\" for database objects and schema elements."
 msgstr ""
-"インターフェイス <literal>net.sf.hibernate.cfg.NamingStrategy</literal> を使"
-"うと データベースオブジェクトとスキーマ要素のための「命名標準」を指定できま"
+"インターフェース <literal>net.sf.hibernate.cfg.NamingStrategy</literal> を使"
+"うとデータベースオブジェクトとスキーマ要素のための「命名標準」を指定できま"
 "す。"
 
 #. Tag: para
-#: configuration.xml:1311
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can provide rules for automatically generating database identifiers from "
 "Java identifiers or for processing \"logical\" column and table names given "
@@ -2314,53 +1967,38 @@
 "noise (<literal>TBL_</literal> prefixes, for example). The default strategy "
 "used by Hibernate is quite minimal."
 msgstr ""
-"Javaの識別子からデータベースの識別子を自動生成するためのルールや、 マッピング"
-"ファイルで与えた「論理的な」カラムとテーブル名から 「物理的な」テーブルとカラ"
-"ム名を生成するためのルールを用意することができます。 この機能は繰り返しの雑音"
-"(例えば <literal>TBL_</literal> プリフィックス)を取り除き、 マッピングド"
-"キュメントの冗長さを減らすことに役立ちます。 Hibernateが使うデフォルトの戦略"
-"はかなり最小限に近いものです。"
+"Java の識別子からデータベースの識別子を自動生成するためのルールや、マッピング"
+"ファイルで与えた「論理的な」カラムとテーブル名から「物理的な」テーブルとカラ"
+"ム名を生成するためのルールを用意することができます。この機能は繰り返しの雑音"
+"(例えば <literal>TBL_</literal> プリフィックス)を取り除き、マッピングドキュ"
+"メントの冗長さを減らすことに役立ちます。 Hibernate が使うデフォルトの戦略はか"
+"なり最小限に近いものです。"
 
 #. Tag: para
-#: configuration.xml:1320
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can specify a different strategy by calling <literal>Configuration."
 "setNamingStrategy()</literal> before adding mappings:"
 msgstr ""
 "マッピングを追加する前に <literal>Configuration.setNamingStrategy()</"
-"literal> を呼ぶことで 以下のように異なる戦略を指定することができます:"
+"literal> を呼ぶことで以下のように異なる戦略を指定することができます:"
 
-#. Tag: programlisting
-#: configuration.xml:1325
-#, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration()\n"
-"    .setNamingStrategy(ImprovedNamingStrategy.INSTANCE)\n"
-"    .addFile(\"Item.hbm.xml\")\n"
-"    .addFile(\"Bid.hbm.xml\")\n"
-"    .buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1327
 #, no-c-format
 msgid ""
 "<literal>org.hibernate.cfg.ImprovedNamingStrategy</literal> is a built-in "
 "strategy that might be a useful starting point for some applications."
 msgstr ""
 "<literal>org.hibernate.cfg.ImprovedNamingStrategy</literal> は組み込みの戦略"
-"です。 これはいくつかのアプリケーションにとって有用な開始点となるかもしれませ"
+"です。これはいくつかのアプリケーションにとって有用な開始点となるかもしれませ"
 "ん。"
 
 #. Tag: title
-#: configuration.xml:1335
 #, no-c-format
 msgid "XML configuration file"
-msgstr "XML設定ファイル"
+msgstr "XML 設定ファイル"
 
 #. Tag: para
-#: configuration.xml:1337
 #, no-c-format
 msgid ""
 "An alternative approach to configuration is to specify a full configuration "
@@ -2368,69 +2006,23 @@
 "as a replacement for the <literal>hibernate.properties</literal> file or, if "
 "both are present, to override properties."
 msgstr ""
-"もう1つの方法は <literal>hibernate.cfg.xml</literal> という名前のファイルで "
-"十分な設定を指定する方法です。 このファイルは <literal>hibernate.properties</"
-"literal> ファイルの代わりとなります。 もし両方のファイルがあれば、プロパティ"
-"が置き換えられます。"
+"もう1つの方法は <literal>hibernate.cfg.xml</literal> という名前のファイルで十"
+"分な設定を指定する方法です。このファイルは <literal>hibernate.properties</"
+"literal> ファイルの代わりとなります。もし両方のファイルがあれば、プロパティが"
+"置き換えられます。"
 
 #. Tag: para
-#: configuration.xml:1344
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The XML configuration file is by default expected to be in the root of your "
 "<literal>CLASSPATH</literal>. Here is an example:"
 msgstr ""
-"XML設定ファイルは初期設定で <literal>CLASSPATH</literal> に配置してくださ"
-"い。 これが例です:"
+"XML 設定ファイルは初期設定で <literal>CLASSPATH</literal> の root に配置して"
+"ください。これが例です:"
 
-#. Tag: programlisting
-#: configuration.xml:1349
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-"<!DOCTYPE hibernate-configuration PUBLIC\n"
-"    \"-//Hibernate/Hibernate Configuration DTD//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd\">\n"
-"\n"
-"<hibernate-configuration>\n"
-"\n"
-"    <!-- a SessionFactory instance listed as /jndi/name -->\n"
-"    <session-factory\n"
-"        name=\"java:hibernate/SessionFactory\">\n"
-"\n"
-"        <!-- properties -->\n"
-"        <property name=\"connection.datasource\">java:/comp/env/jdbc/MyDB</"
-"property>\n"
-"        <property name=\"dialect\">org.hibernate.dialect.MySQLDialect</"
-"property>\n"
-"        <property name=\"show_sql\">false</property>\n"
-"        <property name=\"transaction.factory_class\">\n"
-"            org.hibernate.transaction.JTATransactionFactory\n"
-"        </property>\n"
-"        <property name=\"jta.UserTransaction\">java:comp/UserTransaction</"
-"property>\n"
-"\n"
-"        <!-- mapping files -->\n"
-"        <mapping resource=\"org/hibernate/auction/Item.hbm.xml\"/>\n"
-"        <mapping resource=\"org/hibernate/auction/Bid.hbm.xml\"/>\n"
-"\n"
-"        <!-- cache settings -->\n"
-"        <class-cache class=\"org.hibernate.auction.Item\" usage=\"read-write"
-"\"/>\n"
-"        <class-cache class=\"org.hibernate.auction.Bid\" usage=\"read-only\"/"
-">\n"
-"        <collection-cache collection=\"org.hibernate.auction.Item.bids\" "
-"usage=\"read-write\"/>\n"
-"\n"
-"    </session-factory>\n"
-"\n"
-"</hibernate-configuration>]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:1351
-#, fuzzy, no-c-format
-msgid ""
 "The advantage of this approach is the externalization of the mapping file "
 "names to configuration. The <literal>hibernate.cfg.xml</literal> is also "
 "more convenient once you have to tune the Hibernate cache. It is your choice "
@@ -2439,56 +2031,34 @@
 "benefits of using the XML syntax."
 msgstr ""
 "見てのとおり、この方法の優位性は設定のためのマッピングファイル名を外出しにで"
-"きることです。 Hibernateキャッシュをチューニングしなければならないのであれ"
+"きることです。 Hibernate キャッシュをチューニングしなければならないのであれ"
 "ば、 <literal>hibernate.cfg.xml</literal> はより便利です。 "
 "<literal>hibernate.properties</literal> と <literal>hibernate.cfg.xml</"
-"literal> の どちらかを使えることを覚えておいてください。 二つは同じもので、違"
-"うところといえばXML構文を使うことの利点だけです。"
+"literal> の どちらかを使えることを覚えておいてください。2つは同じもので、違う"
+"ところといえば XML 構文を使うことの利点だけです。"
 
 #. Tag: para
-#: configuration.xml:1360
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "With the XML configuration, starting Hibernate is then as simple as:"
-msgstr "XML設定を使うことで、Hibernateは以下のようにシンプルになります。"
+msgstr "XML 設定を使うことで、 Hibernate は以下のようにシンプルになります。"
 
-#. Tag: programlisting
-#: configuration.xml:1364
-#, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration().configure()."
-"buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1366
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can select a different XML configuration file using:"
-msgstr "違うXML設定ファイルを使うこともできます。"
+msgstr "違う XML 設定ファイルを使うこともできます。"
 
-#. Tag: programlisting
-#: configuration.xml:1370
-#, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration()\n"
-"    .configure(\"catdb.cfg.xml\")\n"
-"    .buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: title
-#: configuration.xml:1375
 #, no-c-format
 msgid "J2EE Application Server integration"
-msgstr "J2EEアプリケーションサーバとの統合"
+msgstr "J2EE アプリケーションサーバーとの統合"
 
 #. Tag: para
-#: configuration.xml:1377
 #, no-c-format
 msgid "Hibernate has the following integration points for J2EE infrastructure:"
-msgstr "HibernateはJ2EE構造と統合するポイントをサポートしています。"
+msgstr "Hibernate は J2EE 構造と統合するポイントをサポートしています:"
 
 #. Tag: para
-#: configuration.xml:1383
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Container-managed datasources</emphasis>: Hibernate can use JDBC "
 "connections managed by the container and provided through JNDI. Usually, a "
@@ -2499,27 +2069,25 @@
 "(BMT), or you might want to use the optional Hibernate <literal>Transaction</"
 "literal> API for this to keep your code portable."
 msgstr ""
-"<emphasis>コンテナ管理データソース</emphasis>:Hibernateは JNDIが提供し、コン"
-"テナが管理するJDBCコネクションを使用できます。 通常、JTA準拠の "
+"<emphasis>コンテナ管理データソース</emphasis>: Hibernate は JNDI が提供し、"
+"コンテナが管理する JDBC コネクションを使用できます。通常、 JTA 準拠の "
 "<literal>TransactionManager</literal> と <literal>ResourceManager</literal> "
-"がトランザクション管理(CMT)、 特に様々なデータソースにまたがる分散トランザク"
-"ションを扱います。 当然プログラムでトランザクション境界を指定できます(BMT)。 "
-"あるいは、記述したコードのポータビリティを保つために、 オプションのHibernate"
-"の <literal>Transaction</literal> APIを使いたくなるかもしれません。"
+"がトランザクション管理 (CMT)、特に様々なデータソースにまたがる分散トランザク"
+"ションを扱います。当然プログラムでトランザクション境界を指定できます (BMT)。"
+"あるいは、記述したコードのポータビリティを保つために、オプションの Hibernate "
+"の <literal>Transaction</literal> API を使いたくなるかもしれません。"
 
 #. Tag: para
-#: configuration.xml:1398
 #, no-c-format
 msgid ""
 "<emphasis>Automatic JNDI binding</emphasis>: Hibernate can bind its "
 "<literal>SessionFactory</literal> to JNDI after startup."
 msgstr ""
-"<emphasis>自動JNDIバインディング</emphasis>:HibernateはJNDIが立ち上がった後"
-"に <literal>SessionFactory</literal> を生成します。"
+"<emphasis>自動 JNDI バインディング</emphasis>: Hibernate は JNDI が立ち上"
+"がった後に <literal>SessionFactory</literal> を生成します。"
 
 #. Tag: para
-#: configuration.xml:1407
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>JTA Session binding:</emphasis> the Hibernate <literal>Session</"
 "literal> can be automatically bound to the scope of JTA transactions. Simply "
@@ -2529,17 +2097,16 @@
 "demarcation is either declarative (CMT) or programmatic (BMT/"
 "UserTransaction)."
 msgstr ""
-"<emphasis>JTAセッションバインディング</emphasis> : Hibernate "
-"<literal>Session</literal> のトランザクション境界はJTAトランザクションと同じ"
-"になります。 単純に <literal>SessionFactory</literal> をJNDIからlookupして、 "
-"現在の <literal>Session</literal> を取得します。 JTAトランザクションが完了し"
-"たときに、Hibernateが <literal>Session</literal> をフラッシュし、クローズしま"
-"す。 EJBデプロイメントディスクリプタの中に、トランザクション境界を宣言しま"
-"す。"
+"<emphasis> JTA セッションバインディング</emphasis>: Hibernate "
+"<literal>Session</literal> は自動的に JTA トランザクションのスコープにバイン"
+"ドされます。単純に <literal>SessionFactory</literal> を JNDI から lookup し"
+"て、現在の <literal>Session</literal> を取得します。 JTA トランザクションが完"
+"了したときに、 Hibernateが <literal>Session</literal> をフラッシュし、クロー"
+"ズします。トランザクション境界は、宣言 (CMT) することも、プログラム (BMT/"
+"UserTransaction) することも可能です。"
 
 #. Tag: para
-#: configuration.xml:1420
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>JMX deployment:</emphasis> if you have a JMX capable application "
 "server (e.g. JBoss AS), you can choose to deploy Hibernate as a managed "
@@ -2549,35 +2116,32 @@
 "take care of service dependencies (datasource has to be available before "
 "Hibernate starts, etc)."
 msgstr ""
-"<emphasis>JMXデプロイ:</emphasis> もしJMXが使用可能なアプリケーションサーバ"
-"(例えばJBOSS) がある場合、HibernateをMBeanとしてデプロイすることを選べま"
-"す。 これは <literal>Configuration</literal> から <literal>SessionFactory</"
-"literal> を 生成するコードを無くすことができます。 コンテナは "
-"<literal>HibernateService</literal> を起動し、 サービスの依存を理想的に管理し"
-"ます(データソースはHibernateやその他が起動する前に 使用できるようにしなけれ"
-"ばなりません)。"
+"<emphasis> JMX デプロイメント:</emphasis> もし JMX が使用可能なアプリケーショ"
+"ンサーバー(例えば JBoss AS) がある場合、 Hibernate を MBean としてデプロイ"
+"することを選べます。これは <literal>Configuration</literal> から "
+"<literal>SessionFactory</literal> を生成するコードを無くすことができます。コ"
+"ンテナは <literal>HibernateService</literal> を起動し、サービスの依存を理想的"
+"に管理します(データソースは Hibernate やその他が起動する前に使用できるように"
+"しなければなりません)。"
 
 #. Tag: para
-#: configuration.xml:1431
 #, no-c-format
 msgid ""
 "Depending on your environment, you might have to set the configuration "
 "option <literal>hibernate.connection.aggressive_release</literal> to true if "
 "your application server shows \"connection containment\" exceptions."
 msgstr ""
-"環境に依存しますが、もし、アプリケーションサーバが\"connection containment"
-"\"の例外をスローするなら 設定のオプション <literal>hibernate.connection."
-"aggressive_release</literal> をtrueにしてください。"
+"環境に依存しますが、もしアプリケーションサーバーが \"connection containment"
+"\" の例外を出す場合、設定のオプション <literal>hibernate.connection."
+"aggressive_release</literal> を true にしてください。"
 
 #. Tag: title
-#: configuration.xml:1438
 #, no-c-format
 msgid "Transaction strategy configuration"
 msgstr "トランザクション戦略設定"
 
 #. Tag: para
-#: configuration.xml:1440
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The Hibernate <literal>Session</literal> API is independent of any "
 "transaction demarcation system in your architecture. If you let Hibernate "
@@ -2586,15 +2150,14 @@
 "server, you might want to use bean-managed transactions and call the JTA API "
 "and <literal>UserTransaction</literal> when needed."
 msgstr ""
-"Hibernate <literal>Session</literal> APIは、アーキテクチャ内のシステムの管轄"
-"である あらゆるトランザクションに依存しません。 もしコネクションプールのJDBC"
-"を直接使いたい場合、JDBC APIから トランザクションを呼ぶことができます。 も"
-"し、J2EEアプリケーションサーバで動作させるなら、Bean管理トランザクションを使"
-"い、 必要に応じて <literal>UserTransaction</literal> をJTA APIから呼ぶことに"
-"なるでしょう。"
+"Hibernate <literal>Session</literal> API は、アーキテクチャ内のシステムの管轄"
+"であるあらゆるトランザクションに依存しません。もしコネクションプールの JDBC "
+"を直接使いたい場合、 JDBC API から トランザクションを呼ぶことができます。も"
+"し、 J2EE アプリケーションサーバーで動作させるなら、 Bean 管理トランザクショ"
+"ンを使い、必要に応じて <literal>UserTransaction</literal> を JTA API から呼ぶ"
+"ことになるでしょう。"
 
 #. Tag: para
-#: configuration.xml:1448
 #, no-c-format
 msgid ""
 "To keep your code portable between these two (and other) environments we "
@@ -2605,73 +2168,64 @@
 "literal>."
 msgstr ""
 "2つ(それ以上)の環境で互換性のあるコードを維持するために、オプションとして根"
-"本的なシステムを ラッピングするHibernate <literal>Transaction</literal> APIを"
-"推奨します。 Hibernate設定プロパティの <literal>hibernate.transaction."
-"factory_class</literal> を設定することで ある特定の <literal>Transaction</"
+"本的なシステムをラッピングする Hibernate <literal>Transaction</literal> API "
+"を推奨します。 Hibernate 設定プロパティの <literal>hibernate.transaction."
+"factory_class</literal> を設定することで、ある特定の <literal>Transaction</"
 "literal> クラスのインスタンスを持つことができます。"
 
 #. Tag: para
-#: configuration.xml:1455
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "There are three standard, or built-in, choices:"
 msgstr "3つの基本的な(既にある)選択を挙げます:"
 
-#. Tag: literal
-#: configuration.xml:1461
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.JDBCTransactionFactory"
-msgstr "org.hibernate.transaction.JDBCTransactionFactory"
+msgid "<literal>org.hibernate.transaction.JDBCTransactionFactory</literal>"
+msgstr "<literal>org.hibernate.transaction.JDBCTransactionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1463
 #, no-c-format
 msgid "delegates to database (JDBC) transactions (default)"
-msgstr "データベース(JDBC)トランザクションに委譲します(デフォルト)"
+msgstr "データベース (JDBC) トランザクションに委譲します(デフォルト)"
 
-#. Tag: literal
-#: configuration.xml:1467
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.JTATransactionFactory"
-msgstr "org.hibernate.transaction.JTATransactionFactory"
+msgid "<literal>org.hibernate.transaction.JTATransactionFactory</literal>"
+msgstr "<literal>org.hibernate.transaction.JTATransactionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1469
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "delegates to container-managed transactions if an existing transaction is "
 "underway in this context (for example, EJB session bean method). Otherwise, "
 "a new transaction is started and bean-managed transactions are used."
 msgstr ""
-"もし、このコンテキスト(例えば、EJBセッションBeanメソッド)で進行中のトランザ"
-"クションが存在する、もしくは 新しいトランザクションが開始されており、Bean管理"
-"トランザクションが使われている場合、 コンテナ管理トランザクションに委譲しま"
-"す。"
+"もし、このコンテキスト(例えば、 EJB セッション Bean メソッド)で進行中のトラ"
+"ンザクションが存在する場合、コンテナ管理トランザクションに委譲します。そうで"
+"ない場合は、新しいトランザクションが開始されており、 Bean 管理トランザクショ"
+"ンが使われます。"
 
-#. Tag: literal
-#: configuration.xml:1477
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.CMTTransactionFactory"
-msgstr "org.hibernate.transaction.CMTTransactionFactory"
+msgid "<literal>org.hibernate.transaction.CMTTransactionFactory</literal>"
+msgstr "<literal>org.hibernate.transaction.CMTTransactionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1479
 #, no-c-format
 msgid "delegates to container-managed JTA transactions"
-msgstr "コンテナ管理JTAトランザクションに委譲します"
+msgstr "コンテナ管理 JTA トランザクションに委譲します"
 
 #. Tag: para
-#: configuration.xml:1484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also define your own transaction strategies (for a CORBA transaction "
 "service, for example)."
 msgstr ""
-"自分自身のトランザクション戦略(例えば、CORBAトランザクションサービス)を定義"
-"することもできます。"
+"自分自身のトランザクション戦略(例えば、 CORBA トランザクションサービス)を定"
+"義することもできます。"
 
 #. Tag: para
-#: configuration.xml:1489
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Some features in Hibernate (i.e., the second level cache, Contextual "
 "Sessions with JTA, etc.) require access to the JTA "
@@ -2680,174 +2234,173 @@
 "have to specify how Hibernate should obtain a reference to the "
 "<literal>TransactionManager</literal>:"
 msgstr ""
-"Hibernateのいくつかの機能(例えば、二次キャッシュ、JTAによるコンテキストセッ"
-"ション 等)は 管理された環境の中のJTA <literal>TransactionManager</literal> "
-"へのアクセスを要求します。 J2EEがひとつのメカニズムに規格化されていないの"
-"で、 アプリケーションサーバにおいて、Hibernateが "
-"<literal>TransactionManager</literal> のリファレンス を取得する方法を明確にす"
+"Hibernate のいくつかの機能(例えば、二次キャッシュ、 JTA によるコンテキスト"
+"セッション等)は管理された環境の中の JTA <literal>TransactionManager</"
+"literal> へのアクセスを要求します。 J2EE がひとつのメカニズムに規格化されてい"
+"ないので、アプリケーションサーバーにおいて、 Hibernateが "
+"<literal>TransactionManager</literal> のリファレンスを取得する方法を明確にす"
 "る必要があります。"
 
 #. Tag: title
-#: configuration.xml:1497
 #, no-c-format
 msgid "JTA TransactionManagers"
 msgstr "JTA トランザクションマネージャ"
 
 #. Tag: entry
-#: configuration.xml:1503
 #, no-c-format
 msgid "Transaction Factory"
 msgstr "Transaction Factory"
 
 #. Tag: entry
-#: configuration.xml:1504
 #, no-c-format
 msgid "Application Server"
 msgstr "Application Server"
 
-#. Tag: literal
-#: configuration.xml:1509
-#, no-c-format
-msgid "org.hibernate.transaction.JBossTransactionManagerLookup"
-msgstr "org.hibernate.transaction.JBossTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JBossTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JBossTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1510
 #, no-c-format
 msgid "JBoss"
 msgstr "JBoss"
 
-#. Tag: literal
-#: configuration.xml:1513
-#, no-c-format
-msgid "org.hibernate.transaction.WeblogicTransactionManagerLookup"
-msgstr "org.hibernate.transaction.WeblogicTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WeblogicTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. WeblogicTransactionManagerLookup</"
+"literal>"
 
 #. Tag: entry
-#: configuration.xml:1514
 #, no-c-format
 msgid "Weblogic"
 msgstr "Weblogic"
 
-#. Tag: literal
-#: configuration.xml:1517
-#, no-c-format
-msgid "org.hibernate.transaction.WebSphereTransactionManagerLookup"
-msgstr "org.hibernate.transaction.WebSphereTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WebSphereTransactionManagerLookup</"
+"literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. WebSphereTransactionManagerLookup</"
+"literal>"
 
 #. Tag: entry
-#: configuration.xml:1518
 #, no-c-format
 msgid "WebSphere"
 msgstr "WebSphere"
 
-#. Tag: literal
-#: configuration.xml:1521
-#, no-c-format
-msgid "org.hibernate.transaction.WebSphereExtendedJTATransactionLookup"
-msgstr "org.hibernate.transaction.WebSphereExtendedJTATransactionLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WebSphereExtendedJTATransactionLookup</"
+"literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. WebSphereExtendedJTATransactionLookup</"
+"literal>"
 
 #. Tag: entry
-#: configuration.xml:1522
 #, no-c-format
 msgid "WebSphere 6"
 msgstr "WebSphere 6"
 
-#. Tag: literal
-#: configuration.xml:1525
-#, no-c-format
-msgid "org.hibernate.transaction.OrionTransactionManagerLookup"
-msgstr "org.hibernate.transaction.OrionTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.OrionTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. OrionTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1526
 #, no-c-format
 msgid "Orion"
 msgstr "Orion"
 
-#. Tag: literal
-#: configuration.xml:1529
-#, no-c-format
-msgid "org.hibernate.transaction.ResinTransactionManagerLookup"
-msgstr "org.hibernate.transaction.ResinTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.ResinTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. ResinTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1530
 #, no-c-format
 msgid "Resin"
 msgstr "Resin"
 
-#. Tag: literal
-#: configuration.xml:1533
-#, no-c-format
-msgid "org.hibernate.transaction.JOTMTransactionManagerLookup"
-msgstr "org.hibernate.transaction.JOTMTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JOTMTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JOTMTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1534
 #, no-c-format
 msgid "JOTM"
 msgstr "JOTM"
 
-#. Tag: literal
-#: configuration.xml:1537
-#, no-c-format
-msgid "org.hibernate.transaction.JOnASTransactionManagerLookup"
-msgstr "org.hibernate.transaction.JOnASTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JOnASTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JOnASTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1538
 #, no-c-format
 msgid "JOnAS"
 msgstr "JOnAS"
 
-#. Tag: literal
-#: configuration.xml:1541
-#, no-c-format
-msgid "org.hibernate.transaction.JRun4TransactionManagerLookup"
-msgstr "org.hibernate.transaction.JRun4TransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JRun4TransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JRun4TransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1542
 #, no-c-format
 msgid "JRun4"
 msgstr "JRun4"
 
-#. Tag: literal
-#: configuration.xml:1545
-#, no-c-format
-msgid "org.hibernate.transaction.BESTransactionManagerLookup"
-msgstr "org.hibernate.transaction.BESTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.BESTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. BESTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1546
 #, no-c-format
 msgid "Borland ES"
 msgstr "Borland ES"
 
 #. Tag: title
-#: configuration.xml:1555
 #, no-c-format
 msgid "JNDI-bound <literal>SessionFactory</literal>"
-msgstr "<literal>SessionFactory</literal> のJNDIへの登録"
+msgstr "<literal>SessionFactory</literal> の JNDI への登録"
 
 #. Tag: para
-#: configuration.xml:1557
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A JNDI-bound Hibernate <literal>SessionFactory</literal> can simplify the "
 "lookup function of the factory and create new <literal>Session</literal>s. "
 "This is not, however, related to a JNDI bound <literal>Datasource</literal>; "
 "both simply use the same registry."
 msgstr ""
-"JNDIに登録したHibernate <literal>SessionFactory</literal> は単純に ファクトリ"
-"をルックアップし、新しい <literal>Session</literal> を作ります。 これはJNDIに"
-"登録された <literal>Datasource</literal> には関連せず、 お互いにシンプルにこ"
-"れらの登録を使うことに注意してください。"
+"JNDI に登録した Hibernate <literal>SessionFactory</literal> はファクトリの"
+"ルックアップと新しい <literal>Session</literal> の作成を簡易化します。これは "
+"JNDI に登録された <literal>Datasource</literal> には関連せず、両方とも単に同"
+"じ登録を使うことに注意してください。"
 
 #. Tag: para
-#: configuration.xml:1564
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you wish to have the <literal>SessionFactory</literal> bound to a JNDI "
 "namespace, specify a name (e.g. <literal>java:hibernate/SessionFactory</"
@@ -2856,15 +2409,14 @@
 "will not be bound to JNDI. This is especially useful in environments with a "
 "read-only JNDI default implementation (in Tomcat, for example)."
 msgstr ""
-"もし <literal>SessionFactory</literal> をJNDIネームスペースに登録したい場"
-"合、 特別な名前(例えば、 <literal>java:hibernate/SessionFactory</literal> )"
+"もし <literal>SessionFactory</literal> を JNDI ネームスペースに登録したい場"
+"合、特別な名前(例えば、 <literal>java:hibernate/SessionFactory</literal> )"
 "を <literal>hibernate.session_factory_name</literal> プロパティに使ってくださ"
-"い もしこのプロパティを省略した場合、 <literal>SessionFactory</literal> は "
-"JNDIに登録されません。(これはTomcatのようなデフォルト実装でJNDIが読みより専"
-"用の環境の場合特に便利です。)"
+"い。もしこのプロパティを省略した場合、 <literal>SessionFactory</literal> は "
+"JNDI に登録されません。(これは Tomcat のようなデフォルト実装で JNDI が読み取"
+"り専用の環境の場合は特に便利です。)"
 
 #. Tag: para
-#: configuration.xml:1572
 #, no-c-format
 msgid ""
 "When binding the <literal>SessionFactory</literal> to JNDI, Hibernate will "
@@ -2872,14 +2424,13 @@
 "jndi.class</literal> to instantiate an initial context. If they are not "
 "specified, the default <literal>InitialContext</literal> will be used."
 msgstr ""
-"<literal>SessionFactory</literal> をJNDIに登録するとき、Hibernateは "
+"<literal>SessionFactory</literal> を JNDI に登録するとき、 Hibernate は "
 "<literal>hibernate.jndi.url</literal> の値を使用し、<literal>hibernate.jndi."
-"class</literal> をイニシャルコンテキストとして具体化します。 もし何も設定しな"
+"class</literal> をイニシャルコンテキストとして具体化します。もし何も設定しな"
 "い場合は、デフォルトの <literal>InitialContext</literal> を使用します。"
 
 #. Tag: para
-#: configuration.xml:1579
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will automatically place the <literal>SessionFactory</literal> in "
 "JNDI after you call <literal>cfg.buildSessionFactory()</literal>. This means "
@@ -2888,27 +2439,25 @@
 "<literal>HibernateService</literal> (this is discussed later in greater "
 "detail)."
 msgstr ""
-"<literal>cfg.buildSessionFactory()</literal> をコール後 Hibernateは自動的に "
-"<literal>SessionFactory</literal> をJNDIに配置します。 "
-"<literal>HibernateService</literal> と一緒にJMXデプロイメントを使わない限"
-"り、 これはこの呼び出しをアプリケーション内の何らかのスタートアップコード(も"
-"しくはユーティリティクラス) に配置しなければならないことを意味します。(後で"
-"議論します)"
+"<literal>cfg.buildSessionFactory()</literal> をコール後 Hibernate は自動的に "
+"<literal>SessionFactory</literal> を JNDI に配置します。 "
+"<literal>HibernateService</literal> と一緒に JMX デプロイメントを使わない限"
+"り、これはこの呼び出しをアプリケーション内の何らかのスタートアップコード(も"
+"しくはユーティリティクラス) に配置しなければならないことを意味します(後で議"
+"論します)。"
 
 #. Tag: para
-#: configuration.xml:1586
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you use a JNDI <literal>SessionFactory</literal>, an EJB or any other "
 "class, you can obtain the <literal>SessionFactory</literal> using a JNDI "
 "lookup."
 msgstr ""
-"もしJNDI <literal>SessionFactory</literal> を使う場合、EJBや他のクラスは JNDI"
-"ルックアップを使って <literal>SessionFactory</literal> を取得します。"
+"もし JNDI <literal>SessionFactory</literal> を使う場合、 EJB や他のクラスは "
+"JNDI ルックアップを使って <literal>SessionFactory</literal> を取得します。"
 
 #. Tag: para
-#: configuration.xml:1591
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you bind the <literal>SessionFactory</literal> to "
 "JNDI in a managed environment and use a <literal>static</literal> singleton "
@@ -2918,32 +2467,30 @@
 "()</literal>. Note that such a class is also a convenient way to startup "
 "Hibernate&mdash;see chapter 1."
 msgstr ""
-"管理された環境では <literal>SessionFactory</literal> をJNDIにバインドし、 そ"
-"うでなければ <literal>static</literal> シングルトンを使うことを推奨します。 "
-"こういった詳細からアプリケーションコードを保護するために、 "
+"管理された環境では <literal>SessionFactory</literal> を JNDI にバインドし、そ"
+"うでなければ <literal>static</literal> シングルトンを使うことを推奨します。こ"
+"ういった詳細からアプリケーションコードを保護するために、 "
 "<literal>HibernateUtil.getSessionFactory()</literal> のようなヘルパークラスの"
 "中に、 <literal>SessionFactory</literal> をルックアップするコードを隠すことを"
-"推奨します。 このようなヘルパークラスはHibernateを開始する便利な手段でもあり"
-"ます。 &mdash;1章を参照してください。"
+"推奨します。このようなヘルパークラスは Hibernate を開始する便利な手段でもあり"
+"ます。 - 1章を参照してください。"
 
 #. Tag: title
-#: configuration.xml:1603
 #, no-c-format
 msgid "Current Session context management with JTA"
-msgstr "JTAによる現在のセッションコンテキストマネージメント"
+msgstr "JTA による現在のセッションコンテキストマネージメント"
 
 #. Tag: para
-#: configuration.xml:1605
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The easiest way to handle <literal>Sessions</literal> and transactions is "
 "Hibernate's automatic \"current\" <literal>Session</literal> management. For "
-"a discussion of contextual sessions see <link linkend=\"architecture-current-"
-"session\"></link>. Using the <literal>\"jta\"</literal> session context, if "
-"there is no Hibernate <literal>Session</literal> associated with the current "
-"JTA transaction, one will be started and associated with that JTA "
-"transaction the first time you call <literal>sessionFactory.getCurrentSession"
-"()</literal>. The <literal>Session</literal>s retrieved via "
+"a discussion of contextual sessions see <xref linkend=\"architecture-current-"
+"session\" />. Using the <literal>\"jta\"</literal> session context, if there "
+"is no Hibernate <literal>Session</literal> associated with the current JTA "
+"transaction, one will be started and associated with that JTA transaction "
+"the first time you call <literal>sessionFactory.getCurrentSession()</"
+"literal>. The <literal>Session</literal>s retrieved via "
 "<literal>getCurrentSession()</literal> in the<literal>\"jta\"</literal> "
 "context are set to automatically flush before the transaction completes, "
 "close after the transaction completes, and aggressively release JDBC "
@@ -2957,33 +2504,31 @@
 "preferred."
 msgstr ""
 "もっとも簡単に <literal>Session</literal> とトランザクションを扱う方法は、 "
-"Hibernateが自動的に「現在の」 <literal>Session</literal> を管理することで"
-"す。 <xref linkend=\"architecture-current-session\">カレントセッション</"
-"xref> の説明を参照してください。 もし <literal>「JTA」</literal> セッションコ"
-"ンテキストを使った上で、 現在のJTAトランザクションとHibernate "
-"<literal>Session</literal> が関連していない場合は、 最初に "
-"<literal>sessionFactory.getCurrentSession()</literal> をコールし、 JTAトラン"
-"ザクションとの関連付けを行ってください。 <literal>「JTA」</literal> コンテキ"
-"ストの <literal>getCurrentSession()</literal> を 通じて取得した "
-"<literal>Session</literal> は、トランザクションが完了する前に 自動的にフラッ"
-"シュし、完了した後には自動的にクローズします。 また、各ステートメント後にJDBC"
-"コネクションを積極的にリリースします。 これによりJTAトランザクションのライフ"
-"サイクルで <literal>Session</literal> を管理することができ、 ユーザーのコード"
-"からそのような管理をするコードを排除できます。 <literal>UserTransaction</"
-"literal> を通じてJTAをプログラムで管理することができます。 または、(ポータブ"
-"ルなコードであれば)Hibernate <literal>Transaction</literal> APIを トランザク"
-"ション境界として使うこともできます。 EJBコンテナを使うときは、CMTによる宣言的"
-"トランザクション境界が好ましいです。"
+"Hibernate が自動的に「現在の」 <literal>Session</literal> を管理することで"
+"す。 <xref linkend=\"architecture-current-session\"/> カレントセッションの説"
+"明を参照してください。もし <literal>\"jta\"</literal> セッションコンテキスト"
+"を使った上で、現在の JTA トランザクションと Hibernate <literal>Session</"
+"literal> が関連していない場合は、最初に <literal>sessionFactory."
+"getCurrentSession()</literal> をコールし、 JTA トランザクションとの関連付けを"
+"行ってください。 <literal>\"jta\"</literal> コンテキストの "
+"<literal>getCurrentSession()</literal> を通じて取得した <literal>Session</"
+"literal> は、トランザクションが完了する前に自動的にフラッシュし、完了した後に"
+"は自動的にクローズします。また、各ステートメント後に JDBC コネクションを積極"
+"的にリリースします。これにより JTA トランザクションのライフサイクルで "
+"<literal>Session</literal> を管理することができ、ユーザーのコードからそのよう"
+"な管理をするコードを排除できます。 <literal>UserTransaction</literal> を通じ"
+"て JTA をプログラムで管理することができます。または、(ポータブルなコードであ"
+"れば) Hibernate <literal>Transaction</literal> API をトランザクション境界と"
+"して使うこともできます。 EJB コンテナを使うときは、 CMT による宣言的トランザ"
+"クション境界が好ましいです。"
 
 #. Tag: title
-#: configuration.xml:1628
 #, no-c-format
 msgid "JMX deployment"
-msgstr "JMXデプロイメント"
+msgstr "JMX デプロイメント"
 
 #. Tag: para
-#: configuration.xml:1630
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The line <literal>cfg.buildSessionFactory()</literal> still has to be "
 "executed somewhere to get a <literal>SessionFactory</literal> into JNDI. You "
@@ -2991,81 +2536,28 @@
 "the one in <literal>HibernateUtil</literal>, or you can deploy Hibernate as "
 "a <emphasis>managed service</emphasis>."
 msgstr ""
-"<literal>SessionFactory</literal> をJNDIから取得するためには <literal>cfg."
-"buildSessionFactory()</literal> 行をどこかで実行していなければなりません。 あ"
-"なたはこれを、<literal>static</literal> 初期化ブロック内"
+"<literal>SessionFactory</literal> を JNDI から取得するためには <literal>cfg."
+"buildSessionFactory()</literal> 行をどこかで実行していなければなりません。あ"
+"なたはこれを、 <literal>static</literal> 初期化ブロック内"
 "( <literal>HibernateUtil</literal> のような)か <emphasis>managed service</"
-"emphasis> としてHibernateをデプロイするか、どちらかで実行できます。"
+"emphasis> として Hibernate をデプロイするか、どちらかで実行できます。"
 
 #. Tag: para
-#: configuration.xml:1638
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate is distributed with <literal>org.hibernate.jmx.HibernateService</"
 "literal> for deployment on an application server with JMX capabilities, such "
 "as JBoss AS. The actual deployment and configuration is vendor-specific. "
 "Here is an example <literal>jboss-service.xml</literal> for JBoss 4.0.x:"
 msgstr ""
-"JBOSSのようなJMXの機能でアプリケーションサーバにデプロイするために "
-"<literal>org.hibernate.jmx.HibernateService</literal> を使って、配置します。 "
-"実際のデプロイメントと設定はベンダー特有です。 ここで例としてJBOSS 4.0.x用の "
-"<literal>jboss-service.xml</literal> を示します。"
+"JBoss AS のような JMX の機能でアプリケーションサーバーにデプロイするために "
+"<literal>org.hibernate.jmx.HibernateService</literal> を使って、配置します。"
+"実際のデプロイメントと設定はベンダー特有です。ここで例として JBoss 4.0.x 用"
+"の <literal>jboss-service.xml</literal> を示します。"
 
-#. Tag: programlisting
-#: configuration.xml:1645
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<server>\n"
-"\n"
-"<mbean code=\"org.hibernate.jmx.HibernateService\"\n"
-"    name=\"jboss.jca:service=HibernateFactory,name=HibernateFactory\">\n"
-"\n"
-"    <!-- Required services -->\n"
-"    <depends>jboss.jca:service=RARDeployer</depends>\n"
-"    <depends>jboss.jca:service=LocalTxCM,name=HsqlDS</depends>\n"
-"\n"
-"    <!-- Bind the Hibernate service to JNDI -->\n"
-"    <attribute name=\"JndiName\">java:/hibernate/SessionFactory</attribute>\n"
-"\n"
-"    <!-- Datasource settings -->\n"
-"    <attribute name=\"Datasource\">java:HsqlDS</attribute>\n"
-"    <attribute name=\"Dialect\">org.hibernate.dialect.HSQLDialect</"
-"attribute>\n"
-"\n"
-"    <!-- Transaction integration -->\n"
-"    <attribute name=\"TransactionStrategy\">\n"
-"        org.hibernate.transaction.JTATransactionFactory</attribute>\n"
-"    <attribute name=\"TransactionManagerLookupStrategy\">\n"
-"        org.hibernate.transaction.JBossTransactionManagerLookup</attribute>\n"
-"    <attribute name=\"FlushBeforeCompletionEnabled\">true</attribute>\n"
-"    <attribute name=\"AutoCloseSessionEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Fetching options -->\n"
-"    <attribute name=\"MaximumFetchDepth\">5</attribute>\n"
-"\n"
-"    <!-- Second-level caching -->\n"
-"    <attribute name=\"SecondLevelCacheEnabled\">true</attribute>\n"
-"    <attribute name=\"CacheProviderClass\">org.hibernate.cache."
-"EhCacheProvider</attribute>\n"
-"    <attribute name=\"QueryCacheEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Logging -->\n"
-"    <attribute name=\"ShowSqlEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Mapping files -->\n"
-"    <attribute name=\"MapResources\">auction/Item.hbm.xml,auction/Category."
-"hbm.xml</attribute>\n"
-"\n"
-"</mbean>\n"
-"\n"
-"</server>]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:1647
-#, fuzzy, no-c-format
-msgid ""
 "This file is deployed in a directory called <literal>META-INF</literal> and "
 "packaged in a JAR file with the extension <literal>.sar</literal> (service "
 "archive). You also need to package Hibernate, its required third-party "
@@ -3076,213 +2568,338 @@
 "JBoss AS documentation for more information about JMX service and EJB "
 "deployment."
 msgstr ""
-"このファイルは <literal>META-INF</literal> ディレクトリに配置され、 JARファイ"
-"ルを拡張した <literal>.sar</literal> (service archive)でパッケージ化されま"
-"す。 同様にHibernateパッケージも必要です。また、Hibernateはサードパーティのラ"
-"イブラリも要求します。 コンパイルした永続化クラスとそのマッピングファイルも同"
-"様にアーカイブ(.sarファイル)に入れます。 エンタープライズbean(通常はセッ"
-"ションbean)は自身のJARファイルを保持しますが、 1回で(ホット)デプロイ可能な"
-"ユニットのためにメインサービスアーカイブとしてこのEJB JARファイルをインクルー"
-"ドする ことができます。JBossアプリケーションサーバのドキュメントにJXMサービス"
-"と EJBデプロイメントのより多くの情報があります。"
+"このファイルは <literal>META-INF</literal> ディレクトリに配置され、 JAR ファ"
+"イルを拡張した <literal>.sar</literal> (service archive) でパッケージ化されま"
+"す。同様に Hibernate パッケージも必要です。また、 Hibernate はサードパーティ"
+"のライブラリも要求します。コンパイルした永続化クラスとそのマッピングファイル"
+"も同様にアーカイブ(.sarファイル)に入れます。エンタープライズ Bean (通常は"
+"セッション Bean )は自身の JAR ファイルを保持しますが、1回で(ホット)デプロ"
+"イ可能なユニットのためにメインサービスアーカイブとしてこの EJB JAR ファイルを"
+"含めることができます。 JBoss AS のドキュメントに JXM サービスと EJB デプロイ"
+"メントのより多くの情報があります。"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>hibernate.properties</literal> is the easiest approach if you "
-#~ "want to get started quickly."
+#~ "<![CDATA[Configuration cfg = new Configuration()\n"
+#~ "    .addResource(\"Item.hbm.xml\")\n"
+#~ "    .addResource(\"Bid.hbm.xml\");]]>"
 #~ msgstr ""
-#~ "今すぐ始めたいのなら、<literal>hibernate.properties</literal> を使うのが一"
-#~ "番の近道です。"
+#~ "Configuration cfg = new Configuration()\n"
+#~ "    .addResource(\"Item.hbm.xml\")\n"
+#~ "    .addResource(\"Bid.hbm.xml\");"
 
-#~ msgid "Hibernate logs various events using Apache commons-logging."
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Configuration cfg = new Configuration()\n"
+#~ "    .addClass(org.hibernate.auction.Item.class)\n"
+#~ "    .addClass(org.hibernate.auction.Bid.class);]]>"
 #~ msgstr ""
-#~ "HibernateはApache commons-logginを使って、さまざまなイベントをログとして "
-#~ "出力します。"
+#~ "Configuration cfg = new Configuration()\n"
+#~ "    .addClass(org.hibernate.auction.Item.class)\n"
+#~ "    .addClass(org.hibernate.auction.Bid.class);"
 
+#, fuzzy
 #~ msgid ""
-#~ "The commons-logging service will direct output to either Apache Log4j (if "
-#~ "you include <literal>log4j.jar</literal> in your classpath) or JDK1.4 "
-#~ "logging (if running under JDK1.4 or above). You may download Log4j from "
-#~ "<literal>http://jakarta.apache.org</literal>. To use Log4j you will need "
-#~ "to place a <literal>log4j.properties</literal> file in your classpath, an "
-#~ "example properties file is distributed with Hibernate in the <literal>src/"
-#~ "</literal> directory."
+#~ "<![CDATA[Configuration cfg = new Configuration()\n"
+#~ "    .addClass(org.hibernate.auction.Item.class)\n"
+#~ "    .addClass(org.hibernate.auction.Bid.class)\n"
+#~ "    .setProperty(\"hibernate.dialect\", \"org.hibernate.dialect."
+#~ "MySQLInnoDBDialect\")\n"
+#~ "    .setProperty(\"hibernate.connection.datasource\", \"java:comp/env/"
+#~ "jdbc/test\")\n"
+#~ "    .setProperty(\"hibernate.order_updates\", \"true\");]]>"
 #~ msgstr ""
-#~ "commons-loggingサービスは(クラスパスに <literal>log4j.jar</literal> を含"
-#~ "めれば)Apache Log4jに、 また(JDK1.4かそれ以上で実行させれば)JDK1.4 "
-#~ "loggingに直接出力します。 Log4jは <literal>http://jakarta.apache.org</"
-#~ "literal> からダウンロードできます。 Log4jを使うためには、クラスパスに "
-#~ "<literal>log4j.properties</literal> ファイルを配置する必要があります。 例"
-#~ "のプロパティファイルはHibernateと一緒に配布され、それは <literal>src/</"
-#~ "literal> ディレクトリにあります。"
+#~ "Configuration cfg = new Configuration()\n"
+#~ "    .addClass(org.hibernate.auction.Item.class)\n"
+#~ "    .addClass(org.hibernate.auction.Bid.class)\n"
+#~ "    .setProperty(\"hibernate.dialect\", \"org.hibernate.dialect."
+#~ "MySQLInnoDBDialect\")\n"
+#~ "    .setProperty(\"hibernate.connection.datasource\", \"java:comp/env/"
+#~ "jdbc/test\")\n"
+#~ "    .setProperty(\"hibernate.order_updates\", \"true\");"
 
-#~ msgid "<placeholder-1/> (optional)"
-#~ msgstr "<placeholder-1/> (オプション)"
+#, fuzzy
+#~ msgid "<![CDATA[SessionFactory sessions = cfg.buildSessionFactory();]]>"
+#~ msgstr "SessionFactory sessions = cfg.buildSessionFactory();"
 
-#~ msgid "InitialContextFactory"
-#~ msgstr "InitialContextFactory"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Session session = sessions.openSession(); // open a new Session]]"
+#~ ">"
+#~ msgstr "Session session = sessions.openSession(); // open a new Session"
 
-#~ msgid "class of the JNDI <placeholder-1/>"
-#~ msgstr "JNDIクラス <placeholder-1/>"
+#~ msgid "database user"
+#~ msgstr "データベースのユーザー"
 
-#~ msgid "eg."
-#~ msgstr "例:"
+#~ msgid "database user password"
+#~ msgstr "データベースユーザーパスワード"
 
-#~ msgid "full.classname.of.Dialect"
-#~ msgstr "full.classname.of.Dialect"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[hibernate.connection.driver_class = org.postgresql.Driver\n"
+#~ "hibernate.connection.url = jdbc:postgresql://localhost/mydatabase\n"
+#~ "hibernate.connection.username = myuser\n"
+#~ "hibernate.connection.password = secret\n"
+#~ "hibernate.c3p0.min_size=5\n"
+#~ "hibernate.c3p0.max_size=20\n"
+#~ "hibernate.c3p0.timeout=1800\n"
+#~ "hibernate.c3p0.max_statements=50\n"
+#~ "hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
+#~ msgstr ""
+#~ "hibernate.connection.driver_class = org.postgresql.Driver\n"
+#~ "hibernate.connection.url = jdbc:postgresql://localhost/mydatabase\n"
+#~ "hibernate.connection.username = myuser\n"
+#~ "hibernate.connection.password = secret\n"
+#~ "hibernate.c3p0.min_size=5\n"
+#~ "hibernate.c3p0.max_size=20\n"
+#~ "hibernate.c3p0.timeout=1800\n"
+#~ "hibernate.c3p0.max_statements=50\n"
+#~ "hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect"
 
-#~ msgid "debug"
-#~ msgstr "debug"
+#~ msgid "datasource JNDI name"
+#~ msgstr "データソースの JNDI 名"
 
-#~ msgid "SCHEMA_NAME"
-#~ msgstr "SCHEMA_NAME"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[hibernate.connection.datasource = java:/comp/env/jdbc/test\n"
+#~ "hibernate.transaction.factory_class = \\\n"
+#~ "    org.hibernate.transaction.JTATransactionFactory\n"
+#~ "hibernate.transaction.manager_lookup_class = \\\n"
+#~ "    org.hibernate.transaction.JBossTransactionManagerLookup\n"
+#~ "hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
+#~ msgstr ""
+#~ "hibernate.connection.datasource = java:/comp/env/jdbc/test\n"
+#~ "hibernate.transaction.factory_class = &#92;\n"
+#~ "    org.hibernate.transaction.JTATransactionFactory\n"
+#~ "hibernate.transaction.manager_lookup_class = &#92;\n"
+#~ "    org.hibernate.transaction.JBossTransactionManagerLookup\n"
+#~ "hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect"
 
-#~ msgid "CATALOG_NAME"
-#~ msgstr "CATALOG_NAME"
+#~ msgid "<entry>DB2</entry>"
+#~ msgstr "<entry>DB2</entry>"
 
-#~ msgid "SessionFactory"
-#~ msgstr "SessionFactory"
+#~ msgid "hibernate.query.substitutions true=1, false=0"
+#~ msgstr "hibernate.query.substitutions true=1, false=0"
 
-#~ msgid "jndi/composite/name"
-#~ msgstr "jndi/composite/name"
+#~ msgid "hibernate.query.substitutions toLowercase=LOWER"
+#~ msgstr "hibernate.query.substitutions toLowercase=LOWER"
 
-#~ msgid "0"
-#~ msgstr "0"
+#~ msgid "org.hibernate"
+#~ msgstr "org.hibernate"
 
-#~ msgid "false"
-#~ msgstr "false"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[SessionFactory sf = new Configuration()\n"
+#~ "    .setNamingStrategy(ImprovedNamingStrategy.INSTANCE)\n"
+#~ "    .addFile(\"Item.hbm.xml\")\n"
+#~ "    .addFile(\"Bid.hbm.xml\")\n"
+#~ "    .buildSessionFactory();]]>"
+#~ msgstr ""
+#~ "SessionFactory sf = new Configuration()\n"
+#~ "    .setNamingStrategy(ImprovedNamingStrategy.INSTANCE)\n"
+#~ "    .addFile(\"Item.hbm.xml\")\n"
+#~ "    .addFile(\"Bid.hbm.xml\")\n"
+#~ "    .buildSessionFactory();"
 
-#~ msgid "Statement.setFetchSize()"
-#~ msgstr "Statement.setFetchSize()"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
+#~ "<!DOCTYPE hibernate-configuration PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Configuration DTD//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
+#~ "\">\n"
+#~ "\n"
+#~ "<hibernate-configuration>\n"
+#~ "\n"
+#~ "    <!-- a SessionFactory instance listed as /jndi/name -->\n"
+#~ "    <session-factory\n"
+#~ "        name=\"java:hibernate/SessionFactory\">\n"
+#~ "\n"
+#~ "        <!-- properties -->\n"
+#~ "        <property name=\"connection.datasource\">java:/comp/env/jdbc/"
+#~ "MyDB</property>\n"
+#~ "        <property name=\"dialect\">org.hibernate.dialect.MySQLDialect</"
+#~ "property>\n"
+#~ "        <property name=\"show_sql\">false</property>\n"
+#~ "        <property name=\"transaction.factory_class\">\n"
+#~ "            org.hibernate.transaction.JTATransactionFactory\n"
+#~ "        </property>\n"
+#~ "        <property name=\"jta.UserTransaction\">java:comp/UserTransaction</"
+#~ "property>\n"
+#~ "\n"
+#~ "        <!-- mapping files -->\n"
+#~ "        <mapping resource=\"org/hibernate/auction/Item.hbm.xml\"/>\n"
+#~ "        <mapping resource=\"org/hibernate/auction/Bid.hbm.xml\"/>\n"
+#~ "\n"
+#~ "        <!-- cache settings -->\n"
+#~ "        <class-cache class=\"org.hibernate.auction.Item\" usage=\"read-"
+#~ "write\"/>\n"
+#~ "        <class-cache class=\"org.hibernate.auction.Bid\" usage=\"read-only"
+#~ "\"/>\n"
+#~ "        <collection-cache collection=\"org.hibernate.auction.Item.bids\" "
+#~ "usage=\"read-write\"/>\n"
+#~ "\n"
+#~ "    </session-factory>\n"
+#~ "\n"
+#~ "</hibernate-configuration>]]>"
+#~ msgstr ""
+#~ "&lt;?xml version='1.0' encoding='utf-8'?&gt;\n"
+#~ "&lt;!DOCTYPE hibernate-configuration PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Configuration DTD//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
+#~ "\"&gt;\n"
+#~ "\n"
+#~ "&lt;hibernate-configuration&gt;\n"
+#~ "\n"
+#~ "    &lt;!-- a SessionFactory instance listed as /jndi/name --&gt;\n"
+#~ "    &lt;session-factory\n"
+#~ "        name=\"java:hibernate/SessionFactory\"&gt;\n"
+#~ "\n"
+#~ "        &lt;!-- properties --&gt;\n"
+#~ "        &lt;property name=\"connection.datasource\"&gt;java:/comp/env/"
+#~ "jdbc/MyDB&lt;/property&gt;\n"
+#~ "        &lt;property name=\"dialect\"&gt;org.hibernate.dialect."
+#~ "MySQLDialect&lt;/property&gt;\n"
+#~ "        &lt;property name=\"show_sql\"&gt;false&lt;/property&gt;\n"
+#~ "        &lt;property name=\"transaction.factory_class\"&gt;\n"
+#~ "            org.hibernate.transaction.JTATransactionFactory\n"
+#~ "        &lt;/property&gt;\n"
+#~ "        &lt;property name=\"jta.UserTransaction\"&gt;java:comp/"
+#~ "UserTransaction&lt;/property&gt;\n"
+#~ "\n"
+#~ "        &lt;!-- mapping files --&gt;\n"
+#~ "        &lt;mapping resource=\"org/hibernate/auction/Item.hbm.xml\"/&gt;\n"
+#~ "        &lt;mapping resource=\"org/hibernate/auction/Bid.hbm.xml\"/&gt;\n"
+#~ "\n"
+#~ "        &lt;!-- cache settings --&gt;\n"
+#~ "        &lt;class-cache class=\"org.hibernate.auction.Item\" usage=\"read-"
+#~ "write\"/&gt;\n"
+#~ "        &lt;class-cache class=\"org.hibernate.auction.Bid\" usage=\"read-"
+#~ "only\"/&gt;\n"
+#~ "        &lt;collection-cache collection=\"org.hibernate.auction.Item.bids"
+#~ "\" usage=\"read-write\"/&gt;\n"
+#~ "\n"
+#~ "    &lt;/session-factory&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-configuration&gt;"
 
-#~ msgid "true"
-#~ msgstr "executeBatch()"
-
-#~ msgid "executeBatch()"
-#~ msgstr "true"
-
-#~ msgid "Batcher"
-#~ msgstr "Batcher"
-
-#~ msgid "classname.of.BatcherFactory"
-#~ msgstr "classname.of.BatcherFactory"
-
-#~ msgid "binary"
-#~ msgstr "binary"
-
-#~ msgid "serializable"
-#~ msgstr "serializable"
-
-#~ msgid "PreparedStatement.getGeneratedKeys()"
-#~ msgstr "PreparedStatement.getGeneratedKeys()"
-
-#~ msgid "true|false"
-#~ msgstr "true|false"
-
-#~ msgid "ConnectionProvider"
-#~ msgstr "ConnectionProvider"
-
-#~ msgid "classname.of.ConnectionProvider"
-#~ msgstr "classname.of.ConnectionProvider"
-
-#~ msgid "java.sql.Connection"
-#~ msgstr "java.sql.Connection"
-
-#~ msgid "1, 2, 4, 8"
-#~ msgstr "1, 2, 4, 8"
-
-#~ msgid "after_statement"
-#~ msgstr "after_statement"
-
-#~ msgid "after_transaction"
-#~ msgstr "after_transaction"
-
-#~ msgid "auto"
-#~ msgstr "auto"
-
-#~ msgid "hibernate.connection."
-#~ msgstr "&lt;propertyName&gt;"
-
 #, fuzzy
-#~ msgid "&lt;propertyName&gt;"
+#~ msgid ""
+#~ "<![CDATA[SessionFactory sf = new Configuration().configure()."
+#~ "buildSessionFactory();]]>"
 #~ msgstr ""
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "hibernate.connection.<placeholder-1/>\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "propertyName\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "hibernate.jndi.<placeholder-1/>\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "propertyName"
+#~ "SessionFactory sf = new Configuration().configure().buildSessionFactory();"
 
-#~ msgid "DriverManager.getConnection()"
-#~ msgstr "DriverManager.getConnection()"
-
-#~ msgid "Pass the JDBC property <placeholder-1/> to <placeholder-2/>."
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[SessionFactory sf = new Configuration()\n"
+#~ "    .configure(\"catdb.cfg.xml\")\n"
+#~ "    .buildSessionFactory();]]>"
 #~ msgstr ""
-#~ "JDBCの <placeholder-1/> プロパティを、 <placeholder-2/> に渡します。"
+#~ "SessionFactory sf = new Configuration()\n"
+#~ "    .configure(\"catdb.cfg.xml\")\n"
+#~ "    .buildSessionFactory();"
 
-#~ msgid "hibernate.jndi."
-#~ msgstr "&lt;propertyName&gt;"
-
-#~ msgid "Pass the property <placeholder-1/> to the JNDI <placeholder-2/>."
-#~ msgstr "<placeholder-1/> プロパティを、 JNDI <placeholder-2/> に渡します。"
-
-#~ msgid "CacheProvider"
-#~ msgstr "CacheProvider"
-
-#~ msgid "classname.of.CacheProvider"
-#~ msgstr "classname.of.CacheProvider"
-
-#~ msgid "&lt;cache&gt;"
-#~ msgstr "&lt;cache&gt;"
-
-#~ msgid "QueryCache"
-#~ msgstr "QueryCache"
-
-#~ msgid "StandardQueryCache"
-#~ msgstr "StandardQueryCache"
-
-#~ msgid "classname.of.QueryCache"
-#~ msgstr "classname.of.QueryCache"
-
-#~ msgid "prefix"
-#~ msgstr "prefix"
-
-#~ msgid "TransactionFactory"
-#~ msgstr "Transaction"
-
-#~ msgid "Transaction"
-#~ msgstr "TransactionFactory"
-
-#~ msgid "JDBCTransactionFactory"
-#~ msgstr "JDBCTransactionFactory"
-
-#~ msgid "classname.of.TransactionFactory"
-#~ msgstr "classname.of.TransactionFactory"
-
-#~ msgid "JTATransactionFactory"
-#~ msgstr "UserTransaction"
-
-#~ msgid "UserTransaction"
-#~ msgstr "JTATransactionFactory"
-
-#~ msgid "TransactionManagerLookup"
-#~ msgstr "TransactionManagerLookup"
-
-#~ msgid "classname.of.TransactionManagerLookup"
-#~ msgstr "classname.of.TransactionManagerLookup"
-
-#~ msgid "Session"
-#~ msgstr "Session"
-
-#~ msgid "hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC"
-#~ msgstr "hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC"
-
-#~ msgid "create-drop"
-#~ msgstr "create-drop"
-
-#~ msgid "hibernate.cfg.xml"
-#~ msgstr "hibernate.cfg.xml"
-
-#~ msgid "DB2"
-#~ msgstr "DB2"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<server>\n"
+#~ "\n"
+#~ "<mbean code=\"org.hibernate.jmx.HibernateService\"\n"
+#~ "    name=\"jboss.jca:service=HibernateFactory,name=HibernateFactory\">\n"
+#~ "\n"
+#~ "    <!-- Required services -->\n"
+#~ "    <depends>jboss.jca:service=RARDeployer</depends>\n"
+#~ "    <depends>jboss.jca:service=LocalTxCM,name=HsqlDS</depends>\n"
+#~ "\n"
+#~ "    <!-- Bind the Hibernate service to JNDI -->\n"
+#~ "    <attribute name=\"JndiName\">java:/hibernate/SessionFactory</"
+#~ "attribute>\n"
+#~ "\n"
+#~ "    <!-- Datasource settings -->\n"
+#~ "    <attribute name=\"Datasource\">java:HsqlDS</attribute>\n"
+#~ "    <attribute name=\"Dialect\">org.hibernate.dialect.HSQLDialect</"
+#~ "attribute>\n"
+#~ "\n"
+#~ "    <!-- Transaction integration -->\n"
+#~ "    <attribute name=\"TransactionStrategy\">\n"
+#~ "        org.hibernate.transaction.JTATransactionFactory</attribute>\n"
+#~ "    <attribute name=\"TransactionManagerLookupStrategy\">\n"
+#~ "        org.hibernate.transaction.JBossTransactionManagerLookup</"
+#~ "attribute>\n"
+#~ "    <attribute name=\"FlushBeforeCompletionEnabled\">true</attribute>\n"
+#~ "    <attribute name=\"AutoCloseSessionEnabled\">true</attribute>\n"
+#~ "\n"
+#~ "    <!-- Fetching options -->\n"
+#~ "    <attribute name=\"MaximumFetchDepth\">5</attribute>\n"
+#~ "\n"
+#~ "    <!-- Second-level caching -->\n"
+#~ "    <attribute name=\"SecondLevelCacheEnabled\">true</attribute>\n"
+#~ "    <attribute name=\"CacheProviderClass\">org.hibernate.cache."
+#~ "EhCacheProvider</attribute>\n"
+#~ "    <attribute name=\"QueryCacheEnabled\">true</attribute>\n"
+#~ "\n"
+#~ "    <!-- Logging -->\n"
+#~ "    <attribute name=\"ShowSqlEnabled\">true</attribute>\n"
+#~ "\n"
+#~ "    <!-- Mapping files -->\n"
+#~ "    <attribute name=\"MapResources\">auction/Item.hbm.xml,auction/"
+#~ "Category.hbm.xml</attribute>\n"
+#~ "\n"
+#~ "</mbean>\n"
+#~ "\n"
+#~ "</server>]]>"
+#~ msgstr ""
+#~ "&lt;?xml version=\"1.0\"?&gt;\n"
+#~ "&lt;server&gt;\n"
+#~ "\n"
+#~ "&lt;mbean code=\"org.hibernate.jmx.HibernateService\"\n"
+#~ "    name=\"jboss.jca:service=HibernateFactory,name=HibernateFactory"
+#~ "\"&gt;\n"
+#~ "\n"
+#~ "    &lt;!-- Required services --&gt;\n"
+#~ "    &lt;depends&gt;jboss.jca:service=RARDeployer&lt;/depends&gt;\n"
+#~ "    &lt;depends&gt;jboss.jca:service=LocalTxCM,name=HsqlDS&lt;/"
+#~ "depends&gt;\n"
+#~ "\n"
+#~ "    &lt;!-- Bind the Hibernate service to JNDI --&gt;\n"
+#~ "    &lt;attribute name=\"JndiName\"&gt;java:/hibernate/SessionFactory&lt;/"
+#~ "attribute&gt;\n"
+#~ "\n"
+#~ "    &lt;!-- Datasource settings --&gt;\n"
+#~ "    &lt;attribute name=\"Datasource\"&gt;java:HsqlDS&lt;/attribute&gt;\n"
+#~ "    &lt;attribute name=\"Dialect\"&gt;org.hibernate.dialect."
+#~ "HSQLDialect&lt;/attribute&gt;\n"
+#~ "\n"
+#~ "    &lt;!-- Transaction integration --&gt;\n"
+#~ "    &lt;attribute name=\"TransactionStrategy\"&gt;\n"
+#~ "        org.hibernate.transaction.JTATransactionFactory&lt;/"
+#~ "attribute&gt;\n"
+#~ "    &lt;attribute name=\"TransactionManagerLookupStrategy\"&gt;\n"
+#~ "        org.hibernate.transaction.JBossTransactionManagerLookup&lt;/"
+#~ "attribute&gt;\n"
+#~ "    &lt;attribute name=\"FlushBeforeCompletionEnabled\"&gt;true&lt;/"
+#~ "attribute&gt;\n"
+#~ "    &lt;attribute name=\"AutoCloseSessionEnabled\"&gt;true&lt;/"
+#~ "attribute&gt;\n"
+#~ "\n"
+#~ "    &lt;!-- Fetching options --&gt;\n"
+#~ "    &lt;attribute name=\"MaximumFetchDepth\"&gt;5&lt;/attribute&gt;\n"
+#~ "\n"
+#~ "    &lt;!-- Second-level caching --&gt;\n"
+#~ "    &lt;attribute name=\"SecondLevelCacheEnabled\"&gt;true&lt;/"
+#~ "attribute&gt;\n"
+#~ "    &lt;attribute name=\"CacheProviderClass\"&gt;org.hibernate.cache."
+#~ "EhCacheProvider&lt;/attribute&gt;\n"
+#~ "    &lt;attribute name=\"QueryCacheEnabled\"&gt;true&lt;/attribute&gt;\n"
+#~ "\n"
+#~ "    &lt;!-- Logging --&gt;\n"
+#~ "    &lt;attribute name=\"ShowSqlEnabled\"&gt;true&lt;/attribute&gt;\n"
+#~ "\n"
+#~ "    &lt;!-- Mapping files --&gt;\n"
+#~ "    &lt;attribute name=\"MapResources\"&gt;auction/Item.hbm.xml,auction/"
+#~ "Category.hbm.xml&lt;/attribute&gt;\n"
+#~ "\n"
+#~ "&lt;/mbean&gt;\n"
+#~ "\n"
+#~ "&lt;/server&gt;"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/events.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/events.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/events.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,42 +1,41 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2010-01-13 11:47+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: events.xml:29
 #, no-c-format
 msgid "Interceptors and events"
 msgstr "インターセプタとイベント"
 
 #. Tag: para
-#: events.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is useful for the application to react to certain events that occur "
 "inside Hibernate. This allows for the implementation of generic "
 "functionality and the extension of Hibernate functionality."
 msgstr ""
-"アプリケーションがHibernateの内部で発生するイベントに対応できると役に立つこと"
-"があります。 ある種の一般的な機能を実装できるようになり、 またHibernateの機能"
-"を拡張することもできるようになります。"
+"アプリケーションが Hibernate の内部で発生するイベントに対応できると役に立つこ"
+"とがあります。ある種の一般的な機能を実装できるようになり、また Hibernate の機"
+"能を拡張することもできるようになります。"
 
 #. Tag: title
-#: events.xml:38
 #, no-c-format
 msgid "Interceptors"
 msgstr "インターセプタ"
 
 #. Tag: para
-#: events.xml:40
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>Interceptor</literal> interface provides callbacks from the "
 "session to the application, allowing the application to inspect and/or "
@@ -48,118 +47,27 @@
 "<literal>lastUpdateTimestamp</literal> property when an <literal>Auditable</"
 "literal> is updated."
 msgstr ""
-"<literal>Interceptor</literal> インターフェイスを使って、 セッションからアプ"
-"リケーションへコールバックをすることができます。 これにより永続オブジェクトの"
-"保存、更新、削除、読み込みの前に、 アプリケーションがプロパティを検査したり操"
-"作したりできるようになります。 これは監査情報の追跡に利用できます。 下の例で "
+"<literal>Interceptor</literal> インターフェースを使って、セッションからアプリ"
+"ケーションへコールバックをすることができます。これにより永続オブジェクトの保"
+"存、更新、削除、読み込みの前に、アプリケーションがプロパティを検査したり操作"
+"したりできるようになります。これは監査情報の追跡に利用できます。下の例で "
 "<literal>Interceptor</literal> は <literal>Auditable</literal> が作成されると"
 "自動的に <literal>createTimestamp</literal> を設定し、 <literal>Auditable</"
 "literal> が更新されると自動的に <literal>lastUpdateTimestamp</literal> プロパ"
 "ティを更新します。"
 
 #. Tag: para
-#: events.xml:51
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can either implement <literal>Interceptor</literal> directly or extend "
 "<literal>EmptyInterceptor</literal>."
 msgstr ""
-"<literal>Interceptor</literal> を直接実装したり、 (さらによいのは)"
+"<literal>Interceptor</literal> を直接実装したり、 (さらによいのは) "
 "<literal>EmptyInterceptor</literal> を拡張したりできます。"
 
-#. Tag: programlisting
-#: events.xml:56
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[package org.hibernate.test;\n"
-"\n"
-"import java.io.Serializable;\n"
-"import java.util.Date;\n"
-"import java.util.Iterator;\n"
-"\n"
-"import org.hibernate.EmptyInterceptor;\n"
-"import org.hibernate.Transaction;\n"
-"import org.hibernate.type.Type;\n"
-"\n"
-"public class AuditInterceptor extends EmptyInterceptor {\n"
-"\n"
-"    private int updates;\n"
-"    private int creates;\n"
-"    private int loads;\n"
-"\n"
-"    public void onDelete(Object entity,\n"
-"                         Serializable id,\n"
-"                         Object[] state,\n"
-"                         String[] propertyNames,\n"
-"                         Type[] types) {\n"
-"        // do nothing\n"
-"    }\n"
-"\n"
-"    public boolean onFlushDirty(Object entity,\n"
-"                                Serializable id,\n"
-"                                Object[] currentState,\n"
-"                                Object[] previousState,\n"
-"                                String[] propertyNames,\n"
-"                                Type[] types) {\n"
-"\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            updates++;\n"
-"            for ( int i=0; i < propertyNames.length; i++ ) {\n"
-"                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) {\n"
-"                    currentState[i] = new Date();\n"
-"                    return true;\n"
-"                }\n"
-"            }\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public boolean onLoad(Object entity,\n"
-"                          Serializable id,\n"
-"                          Object[] state,\n"
-"                          String[] propertyNames,\n"
-"                          Type[] types) {\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            loads++;\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public boolean onSave(Object entity,\n"
-"                          Serializable id,\n"
-"                          Object[] state,\n"
-"                          String[] propertyNames,\n"
-"                          Type[] types) {\n"
-"\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            creates++;\n"
-"            for ( int i=0; i<propertyNames.length; i++ ) {\n"
-"                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
-"                    state[i] = new Date();\n"
-"                    return true;\n"
-"                }\n"
-"            }\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public void afterTransactionCompletion(Transaction tx) {\n"
-"        if ( tx.wasCommitted() ) {\n"
-"            System.out.println(\"Creations: \" + creates + \", Updates: \" + "
-"updates, \"Loads: \" + loads);\n"
-"        }\n"
-"        updates=0;\n"
-"        creates=0;\n"
-"        loads=0;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:58
-#, fuzzy, no-c-format
-msgid ""
 "There are two kinds of inteceptors: <literal>Session</literal>-scoped and "
 "<literal>SessionFactory</literal>-scoped."
 msgstr ""
@@ -167,26 +75,18 @@
 "と <literal>SessionFactory</literal> スコープのものです。"
 
 #. Tag: para
-#: events.xml:63
 #, no-c-format
 msgid ""
 "A <literal>Session</literal>-scoped interceptor is specified when a session "
 "is opened using one of the overloaded SessionFactory.openSession() methods "
 "accepting an <literal>Interceptor</literal>."
 msgstr ""
-"<literal>Session</literal> スコープのインターセプタは、 セッションをオープン"
-"するときに指定します。 <literal>Interceptor</literal> を引数に取る"
+"<literal>Session</literal> スコープのインターセプタは、セッションをオープンす"
+"るときに指定します。 <literal>Interceptor</literal> を引数に取る "
 "SessionFactory.openSession() のオーバーロードメソッドの一つを使います。"
 
-#. Tag: programlisting
-#: events.xml:69
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:71
-#, fuzzy, no-c-format
 msgid ""
 "A <literal>SessionFactory</literal>-scoped interceptor is registered with "
 "the <literal>Configuration</literal> object prior to building the "
@@ -198,44 +98,34 @@
 "sessions will use this interceptor potentially concurrently."
 msgstr ""
 "<literal>SessionFactory</literal> スコープのインターセプタは "
-"<literal>Configuration</literal> オブジェクトを使って登録します。 これは "
-"<literal>SessionFactory</literal> の構築よりも優先されます。 この場合、提供さ"
+"<literal>Configuration</literal> オブジェクトを使って登録します。これは "
+"<literal>SessionFactory</literal> の構築よりも優先されます。この場合、提供さ"
 "れるインターセプタは <literal>SessionFactory</literal> からオープンされたすべ"
-"てのセッションに適用されます。 これは使用するインターセプタを明示的に指定して"
+"てのセッションに適用されます。これは使用するインターセプタを明示的に指定して"
 "セッションをオープンしない限り、そうなります。 <literal>SessionFactory</"
-"literal> スコープのインターセプタはスレッドセーフでなければなりません。 複数"
-"のセッションが(潜在的に)このインターセプタを同時並行で使用することになるた"
-"め、 セッション固有の状態を格納しないように気をつけてください。"
+"literal> スコープのインターセプタはスレッドセーフでなければなりません。複数の"
+"セッションが (潜在的に) このインターセプタを同時並行で使用することになるた"
+"め、セッション固有の状態を格納しないように気をつけてください。"
 
-#. Tag: programlisting
-#: events.xml:80
-#, no-c-format
-msgid ""
-"<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
-msgstr ""
-
 #. Tag: title
-#: events.xml:85
 #, no-c-format
 msgid "Event system"
 msgstr "イベントシステム"
 
 #. Tag: para
-#: events.xml:87
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you have to react to particular events in your persistence layer, you can "
 "also use the Hibernate3 <emphasis>event</emphasis> architecture. The event "
 "system can be used in addition, or as a replacement, for interceptors."
 msgstr ""
-"永続化層で特定のイベントに対応しなければならない場合、 Hibernate3の "
-"<emphasis>イベント</emphasis> アーキテクチャを使うこともできます。 イベントシ"
+"永続化層で特定のイベントに対応しなければならない場合、 Hibernate3 の "
+"<emphasis>イベント</emphasis> アーキテクチャを使うこともできます。イベントシ"
 "ステムはインターセプタと一緒に使うか、またはインターセプタの代わりとして使う"
 "ことができます。"
 
 #. Tag: para
-#: events.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All the methods of the <literal>Session</literal> interface correlate to an "
 "event. You have a <literal>LoadEvent</literal>, a <literal>FlushEvent</"
@@ -252,33 +142,31 @@
 "processing any <literal>load()</literal> requests made of the "
 "<literal>Session</literal>."
 msgstr ""
-"本質的に <literal>Session</literal> インターフェイスのすべてのメソッドは、 1"
-"個のイベントと相互に関連します。 例えば <literal>LoadEvent</literal>、"
+"本質的に <literal>Session</literal> インターフェースのすべてのメソッドは、1個"
+"のイベントと相互に関連します。例えば <literal>LoadEvent</literal> 、 "
 "<literal>FlushEvent</literal> などがあります (定義済みのイベント型の一覧につ"
-"いては、XML設定ファイルのDTDや <literal>org.hibernate.event</literal> パッ"
-"ケージを調べてください)。 リクエストがこれらのメソッドの1つから作られると"
-"き、 Hibernateの <literal>Session</literal> は適切なイベントを生成し、 そのイ"
-"ベント型に設定されたイベントリスナに渡します。 すばらしいことに、これらのリス"
-"ナはそのメソッドと同じ処理を実装します。 とはいえ、リスナインターフェイスの一"
-"つを自由にカスタム実装できます (つまり、<literal>LoadEvent</literal> は登録"
-"された <literal>LoadEventListener</literal> インターフェイスの実装により処理"
-"されます)。 その場合、その実装には <literal>Session</literal> から作られたど"
-"のような <literal>load()</literal> リクエストをも処理する責任があります。"
+"いては、 XML 設定ファイルの DTD や <literal>org.hibernate.event</literal> "
+"パッケージを調べてください) 。リクエストがこれらのメソッドの1つから作られる"
+"とき、 Hibernate の <literal>Session</literal> は適切なイベントを生成し、その"
+"イベント型に設定されたイベントリスナに渡します。すばらしいことに、これらのリ"
+"スナはそのメソッドと同じ処理を実装します。とはいえ、リスナインターフェースの"
+"一つを自由にカスタム実装できます (つまり、 <literal>LoadEvent</literal> は登"
+"録された <literal>LoadEventListener</literal> インターフェースの実装により処"
+"理されます)。その場合、その実装には <literal>Session</literal> から作られた"
+"どのような <literal>load()</literal> リクエストをも処理する責任があります。"
 
 #. Tag: para
-#: events.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The listeners should be considered singletons. This means they are shared "
 "between requests, and should not save any state as instance variables."
 msgstr ""
-"リスナは事実上シングルトンであると見なせます。 つまりリスナはリクエスト間で共"
-"有されるため、 インスタンス変数として状態を保持するべきではないということで"
+"リスナは事実上シングルトンであると見なせます。つまりリスナはリクエスト間で共"
+"有されるため、インスタンス変数として状態を保持するべきではないということで"
 "す。"
 
 #. Tag: para
-#: events.xml:113
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A custom listener implements the appropriate interface for the event it "
 "wants to process and/or extend one of the convenience base classes (or even "
@@ -289,91 +177,45 @@
 "configuration through the properties file is not supported. Here is an "
 "example of a custom load event listener:"
 msgstr ""
-"カスタムリスナは処理したいイベントについて適切なインターフェイスを実装するべ"
-"きです。 便利な基底クラスのうちの一つを継承してもよいです (またはHibernateが"
-"デフォルトで使用するイベントリスナを継承してもよいです。 すばらしいことに、こ"
-"の目的のために非finalとして宣言されています)。 カスタムリスナは "
+"カスタムリスナは処理したいイベントについて適切なインターフェースを実装するべ"
+"きです。便利な基底クラスのうちの一つを継承してもよいです (または Hibernate "
+"がデフォルトで使用するイベントリスナを継承してもよいです。すばらしいことに、"
+"この目的のために非 final として宣言されています) 。カスタムリスナは "
 "<literal>Configuration</literal> オブジェクトを使ってプログラムから登録する"
-"か、 HibernateのXML設定ファイルで指定できます (プロパティファイルで宣言的に"
-"設定する方法はサポートされていません)。 カスタムロードイベントリスナの例を示"
-"します。"
+"か、 Hibernate の XML 設定ファイルで指定できます (プロパティファイルで宣言的"
+"に設定する方法はサポートされていません) 。カスタムロードイベントリスナの例を"
+"示します:"
 
-#. Tag: programlisting
-#: events.xml:123
-#, no-c-format
-msgid ""
-"<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
-"    // this is the single method defined by the LoadEventListener interface\n"
-"    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
-"loadType)\n"
-"            throws HibernateException {\n"
-"        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
-"getEntityId() ) ) {\n"
-"            throw MySecurityException(\"Unauthorized access\");\n"
-"        }\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:125
 #, no-c-format
 msgid ""
 "You also need a configuration entry telling Hibernate to use the listener in "
 "addition to the default listener:"
-msgstr "デフォルトリスナ以外のリスナを使うには、Hibernateへの設定も必要です:"
-
-#. Tag: programlisting
-#: events.xml:130
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-configuration>\n"
-"    <session-factory>\n"
-"        ...\n"
-"        <event type=\"load\">\n"
-"            <listener class=\"com.eg.MyLoadListener\"/>\n"
-"            <listener class=\"org.hibernate.event.def."
-"DefaultLoadEventListener\"/>\n"
-"        </event>\n"
-"    </session-factory>\n"
-"</hibernate-configuration>]]>"
 msgstr ""
+"デフォルトリスナ以外のリスナを使うには、 Hibernate への設定も必要です:"
 
 #. Tag: para
-#: events.xml:132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Instead, you can register it programmatically:"
 msgstr "またその他に、プログラムで登録する方法もあります:"
 
-#. Tag: programlisting
-#: events.xml:136
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration();\n"
-"LoadEventListener[] stack = { new MyLoadListener(), new "
-"DefaultLoadEventListener() };\n"
-"cfg.EventListeners().setLoadEventListeners(stack);]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:138
-#, fuzzy, no-c-format
-msgid ""
 "Listeners registered declaratively cannot share instances. If the same class "
 "name is used in multiple <literal>&lt;listener/&gt;</literal> elements, each "
 "reference will result in a separate instance of that class. If you need to "
 "share listener instances between listener types you must use the "
 "programmatic registration approach."
 msgstr ""
-"リスナを宣言的に登録すると、そのリスナのインスタンスを共有できません。 複数"
-"の <literal>&lt;listener/&gt;</literal> 要素で同じクラス名が使われると、 それ"
-"ぞれの参照はそのクラスの別々のインスタンスを指すことになります。 リスナ型の間"
-"でリスナインスタンスを共有する必要があれば、 プログラムで登録する方法を採らな"
-"ければなりません。"
+"リスナを宣言的に登録すると、そのリスナのインスタンスを共有できません。複数の "
+"<literal>&lt;listener/&gt;</literal> 要素で同じクラス名が使われると、それぞれ"
+"の参照はそのクラスの別々のインスタンスを指すことになります。リスナ型の間でリ"
+"スナインスタンスを共有する必要があれば、プログラムで登録する方法を採らなけれ"
+"ばなりません。"
 
 #. Tag: para
-#: events.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Why implement an interface and define the specific type during "
 "configuration? A listener implementation could implement multiple event "
@@ -381,59 +223,41 @@
 "registration makes it easier to turn custom listeners on or off during "
 "configuration."
 msgstr ""
-"なぜインターフェイスを実装して、特化した型を設定時に指定するのでしょうか? リ"
-"スナの実装クラスに、複数のイベントリスナインターフェイスを実装できるからで"
-"す。 登録時に追加で型を指定することで、カスタムリスナのon/offを設定時に簡単に"
-"切り替えられます。"
+"なぜインターフェースを実装して、特化した型を設定時に指定するのでしょうか?リ"
+"スナの実装クラスに、複数のイベントリスナインターフェースを実装できるからで"
+"す。登録時に追加で型を指定することで、カスタムリスナの on/off を設定時に簡単"
+"に切り替えられます。"
 
 #. Tag: title
-#: events.xml:156
 #, no-c-format
 msgid "Hibernate declarative security"
-msgstr "Hibernateの宣言的なセキュリティ"
+msgstr "Hibernate の宣言的なセキュリティ"
 
 #. Tag: para
-#: events.xml:157
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Usually, declarative security in Hibernate applications is managed in a "
 "session facade layer. Hibernate3 allows certain actions to be permissioned "
 "via JACC, and authorized via JAAS. This is an optional functionality that is "
 "built on top of the event architecture."
 msgstr ""
-"一般的にHibernateアプリケーションの宣言的なセキュリティは、セッションファサー"
-"ド層で管理します。 現在、Hiberenate3はJACCで許可しかつ、JAASで認証したアク"
-"ションを許しています。 これはイベントアーキテクチャの最上位に組み込まれている"
-"オプションの機能です。"
+"一般的に Hibernate アプリケーションの宣言的なセキュリティは、セッションファ"
+"サード層で管理します。現在、 Hiberenate3 は JACC で許可し、さらに JAAS で認証"
+"したアクションを許しています。これはイベントアーキテクチャの最上位に組み込ま"
+"れているオプションの機能です。"
 
 #. Tag: para
-#: events.xml:163
 #, no-c-format
 msgid ""
 "First, you must configure the appropriate event listeners, to enable the use "
 "of JAAS authorization."
 msgstr ""
-"まず最初に、適切なイベントリスナを設定してJAAS認証を使えるようにしなければな"
-"りません。"
+"まず最初に、適切なイベントリスナを設定して JAAS 認証を使えるようにしなければ"
+"なりません。"
 
-#. Tag: programlisting
-#: events.xml:168
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
-"JACCPreDeleteEventListener\"/>\n"
-"<listener type=\"pre-update\" class=\"org.hibernate.secure."
-"JACCPreUpdateEventListener\"/>\n"
-"<listener type=\"pre-insert\" class=\"org.hibernate.secure."
-"JACCPreInsertEventListener\"/>\n"
-"<listener type=\"pre-load\" class=\"org.hibernate.secure."
-"JACCPreLoadEventListener\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:170
-#, fuzzy, no-c-format
-msgid ""
 "Note that <literal>&lt;listener type=\"...\" class=\"...\"/&gt;</literal> is "
 "shorthand for <literal>&lt;event type=\"...\"&gt;&lt;listener class=\"...\"/"
 "&gt;&lt;/event&gt;</literal> when there is exactly one listener for a "
@@ -445,8 +269,7 @@
 "略形に過ぎないことに注意してください。"
 
 #. Tag: para
-#: events.xml:176
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next, while still in <literal>hibernate.cfg.xml</literal>, bind the "
 "permissions to roles:"
@@ -454,17 +277,284 @@
 "次に、同じく <literal>hibernate.cfg.xml</literal> でロールにパーミッションを"
 "与えてください:"
 
-#. Tag: programlisting
-#: events.xml:180
-#, no-c-format
-msgid ""
-"<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,update,"
-"read\"/>\n"
-"<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:182
 #, no-c-format
 msgid "The role names are the roles understood by your JACC provider."
-msgstr "このロール名は使用するJACCプロバイダに理解されるロールです。"
+msgstr "このロール名は使用する JACC プロバイダに理解されるロールです。"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[package org.hibernate.test;\n"
+#~ "\n"
+#~ "import java.io.Serializable;\n"
+#~ "import java.util.Date;\n"
+#~ "import java.util.Iterator;\n"
+#~ "\n"
+#~ "import org.hibernate.EmptyInterceptor;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.type.Type;\n"
+#~ "\n"
+#~ "public class AuditInterceptor extends EmptyInterceptor {\n"
+#~ "\n"
+#~ "    private int updates;\n"
+#~ "    private int creates;\n"
+#~ "    private int loads;\n"
+#~ "\n"
+#~ "    public void onDelete(Object entity,\n"
+#~ "                         Serializable id,\n"
+#~ "                         Object[] state,\n"
+#~ "                         String[] propertyNames,\n"
+#~ "                         Type[] types) {\n"
+#~ "        // do nothing\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onFlushDirty(Object entity,\n"
+#~ "                                Serializable id,\n"
+#~ "                                Object[] currentState,\n"
+#~ "                                Object[] previousState,\n"
+#~ "                                String[] propertyNames,\n"
+#~ "                                Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            updates++;\n"
+#~ "            for ( int i=0; i < propertyNames.length; i++ ) {\n"
+#~ "                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) "
+#~ "{\n"
+#~ "                    currentState[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onLoad(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            loads++;\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onSave(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            creates++;\n"
+#~ "            for ( int i=0; i<propertyNames.length; i++ ) {\n"
+#~ "                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
+#~ "                    state[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void afterTransactionCompletion(Transaction tx) {\n"
+#~ "        if ( tx.wasCommitted() ) {\n"
+#~ "            System.out.println(\"Creations: \" + creates + \", Updates: "
+#~ "\" + updates, \"Loads: \" + loads);\n"
+#~ "        }\n"
+#~ "        updates=0;\n"
+#~ "        creates=0;\n"
+#~ "        loads=0;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "package org.hibernate.test;\n"
+#~ "\n"
+#~ "import java.io.Serializable;\n"
+#~ "import java.util.Date;\n"
+#~ "import java.util.Iterator;\n"
+#~ "\n"
+#~ "import org.hibernate.EmptyInterceptor;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.type.Type;\n"
+#~ "\n"
+#~ "public class AuditInterceptor extends EmptyInterceptor {\n"
+#~ "\n"
+#~ "    private int updates;\n"
+#~ "    private int creates;\n"
+#~ "    private int loads;\n"
+#~ "\n"
+#~ "    public void onDelete(Object entity,\n"
+#~ "                         Serializable id,\n"
+#~ "                         Object[] state,\n"
+#~ "                         String[] propertyNames,\n"
+#~ "                         Type[] types) {\n"
+#~ "        // do nothing\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onFlushDirty(Object entity,\n"
+#~ "                                Serializable id,\n"
+#~ "                                Object[] currentState,\n"
+#~ "                                Object[] previousState,\n"
+#~ "                                String[] propertyNames,\n"
+#~ "                                Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            updates++;\n"
+#~ "            for ( int i=0; i &lt; propertyNames.length; i++ ) {\n"
+#~ "                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) "
+#~ "{\n"
+#~ "                    currentState[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onLoad(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            loads++;\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onSave(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            creates++;\n"
+#~ "            for ( int i=0; i&lt;propertyNames.length; i++ ) {\n"
+#~ "                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
+#~ "                    state[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void afterTransactionCompletion(Transaction tx) {\n"
+#~ "        if ( tx.wasCommitted() ) {\n"
+#~ "            System.out.println(\"Creations: \" + creates + \", Updates: "
+#~ "\" + updates,\n"
+#~ "                \"Loads: \" + loads);\n"
+#~ "        }\n"
+#~ "        updates=0;\n"
+#~ "        creates=0;\n"
+#~ "        loads=0;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
+#~ msgstr "Session session = sf.openSession( new AuditInterceptor() );"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
+#~ msgstr "new Configuration().setInterceptor( new AuditInterceptor() );"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
+#~ "    // this is the single method defined by the LoadEventListener "
+#~ "interface\n"
+#~ "    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
+#~ "loadType)\n"
+#~ "            throws HibernateException {\n"
+#~ "        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
+#~ "getEntityId() ) ) {\n"
+#~ "            throw MySecurityException(\"Unauthorized access\");\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "public class MyLoadListener implements LoadEventListener {\n"
+#~ "    // this is the single method defined by the LoadEventListener "
+#~ "interface\n"
+#~ "    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
+#~ "loadType)\n"
+#~ "            throws HibernateException {\n"
+#~ "        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
+#~ "getEntityId() ) ) {\n"
+#~ "            throw MySecurityException(\"Unauthorized access\");\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-configuration>\n"
+#~ "    <session-factory>\n"
+#~ "        ...\n"
+#~ "        <event type=\"load\">\n"
+#~ "            <listener class=\"com.eg.MyLoadListener\"/>\n"
+#~ "            <listener class=\"org.hibernate.event.def."
+#~ "DefaultLoadEventListener\"/>\n"
+#~ "        </event>\n"
+#~ "    </session-factory>\n"
+#~ "</hibernate-configuration>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-configuration&gt;\n"
+#~ "    &lt;session-factory&gt;\n"
+#~ "        ...\n"
+#~ "        &lt;event type=\"load\"&gt;\n"
+#~ "            &lt;listener class=\"com.eg.MyLoadListener\"/&gt;\n"
+#~ "            &lt;listener class=\"org.hibernate.event.def."
+#~ "DefaultLoadEventListener\"/&gt;\n"
+#~ "        &lt;/event&gt;\n"
+#~ "    &lt;/session-factory&gt;\n"
+#~ "&lt;/hibernate-configuration&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Configuration cfg = new Configuration();\n"
+#~ "LoadEventListener[] stack = { new MyLoadListener(), new "
+#~ "DefaultLoadEventListener() };\n"
+#~ "cfg.EventListeners().setLoadEventListeners(stack);]]>"
+#~ msgstr ""
+#~ "Configuration cfg = new Configuration();\n"
+#~ "LoadEventListener[] stack = { new MyLoadListener(), new "
+#~ "DefaultLoadEventListener() };\n"
+#~ "cfg.EventListeners().setLoadEventListeners(stack);"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
+#~ "JACCPreDeleteEventListener\"/>\n"
+#~ "<listener type=\"pre-update\" class=\"org.hibernate.secure."
+#~ "JACCPreUpdateEventListener\"/>\n"
+#~ "<listener type=\"pre-insert\" class=\"org.hibernate.secure."
+#~ "JACCPreInsertEventListener\"/>\n"
+#~ "<listener type=\"pre-load\" class=\"org.hibernate.secure."
+#~ "JACCPreLoadEventListener\"/>]]>"
+#~ msgstr ""
+#~ "&lt;listener type=\"pre-delete\" class=\"org.hibernate.secure."
+#~ "JACCPreDeleteEventListener\"/&gt;\n"
+#~ "&lt;listener type=\"pre-update\" class=\"org.hibernate.secure."
+#~ "JACCPreUpdateEventListener\"/&gt;\n"
+#~ "&lt;listener type=\"pre-insert\" class=\"org.hibernate.secure."
+#~ "JACCPreInsertEventListener\"/&gt;\n"
+#~ "&lt;listener type=\"pre-load\" class=\"org.hibernate.secure."
+#~ "JACCPreLoadEventListener\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,"
+#~ "update,read\"/>\n"
+#~ "<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"
+#~ msgstr ""
+#~ "&lt;grant role=\"admin\" entity-name=\"User\" actions=\"insert,update,read"
+#~ "\"/&gt;\n"
+#~ "&lt;grant role=\"su\" entity-name=\"User\" actions=\"*\"/&gt;"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/example_mappings.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/example_mappings.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/example_mappings.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,36 +1,35 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2010-01-20 15:40+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: example_mappings.xml:29
 #, no-c-format
 msgid "Example: Various Mappings"
-msgstr "例:いろいろなマッピング"
+msgstr "例: いろいろなマッピング"
 
 #. Tag: para
-#: example_mappings.xml:32
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This chapters explores some more complex association mappings."
 msgstr "この章では、より複雑な関連のマッピングをいくつか紹介します。"
 
 #. Tag: title
-#: example_mappings.xml:37
 #, no-c-format
 msgid "Employer/Employee"
 msgstr "雇用者/従業員"
 
 #. Tag: para
-#: example_mappings.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following model of the relationship between <literal>Employer</literal> "
 "and <literal>Employee</literal> uses an entity class (<literal>Employment</"
@@ -39,129 +38,28 @@
 "used to model monetary values and employee names."
 msgstr ""
 "<literal>Employer</literal> と <literal>Employee</literal> の関係を表す以下の"
-"モデルは、 関連の表現に実際のエンティティクラス( <literal>Employment</"
-"literal> ) を使います。 なぜなら、同じ2つのパーティに複数の期間雇用されると"
-"いうことがありえるからです。 お金の値と従業員の名前をモデル化するためにコン"
-"ポーネントを使っています。"
+"モデルは、関連の表現に実際のエンティティクラス ( <literal>Employment</"
+"literal> ) を使います。なぜなら、同じ2つのパーティに複数の期間雇用されるとい"
+"うことがありえるからです。お金の値と従業員の名前をモデル化するためにコンポー"
+"ネントを使っています。"
 
 #. Tag: para
-#: example_mappings.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is a possible mapping document:"
 msgstr "マッピングドキュメントの一例です:"
 
-#. Tag: programlisting
-#: example_mappings.xml:60
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"        \n"
-"    <class name=\"Employer\" table=\"employers\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employer_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Employment\" table=\"employment_periods\">\n"
-"\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employment_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"startDate\" column=\"start_date\"/>\n"
-"        <property name=\"endDate\" column=\"end_date\"/>\n"
-"\n"
-"        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
-"            <property name=\"amount\">\n"
-"                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/>\n"
-"            </property>\n"
-"            <property name=\"currency\" length=\"12\"/>\n"
-"        </component>\n"
-"\n"
-"        <many-to-one name=\"employer\" column=\"employer_id\" not-null=\"true"
-"\"/>\n"
-"        <many-to-one name=\"employee\" column=\"employee_id\" not-null=\"true"
-"\"/>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Employee\" table=\"employees\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employee_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"taxfileNumber\"/>\n"
-"        <component name=\"name\" class=\"Name\">\n"
-"            <property name=\"firstName\"/>\n"
-"            <property name=\"initial\"/>\n"
-"            <property name=\"lastName\"/>\n"
-"        </component>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: example_mappings.xml:62
-#, fuzzy, no-c-format
 msgid "Here is the table schema generated by <literal>SchemaExport</literal>."
 msgstr "<literal>SchemaExport</literal> で生成したテーブルスキーマです。"
 
-#. Tag: programlisting
-#: example_mappings.xml:66
-#, no-c-format
-msgid ""
-"<![CDATA[create table employers (\n"
-"    id BIGINT not null, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table employment_periods (\n"
-"    id BIGINT not null,\n"
-"    hourly_rate NUMERIC(12, 2),\n"
-"    currency VARCHAR(12), \n"
-"    employee_id BIGINT not null, \n"
-"    employer_id BIGINT not null, \n"
-"    end_date TIMESTAMP, \n"
-"    start_date TIMESTAMP, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table employees (\n"
-"    id BIGINT not null, \n"
-"    firstName VARCHAR(255), \n"
-"    initial CHAR(1), \n"
-"    lastName VARCHAR(255), \n"
-"    taxfileNumber VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table employment_periods \n"
-"    add constraint employment_periodsFK0 foreign key (employer_id) "
-"references employers\n"
-"alter table employment_periods \n"
-"    add constraint employment_periodsFK1 foreign key (employee_id) "
-"references employees\n"
-"create sequence employee_id_seq\n"
-"create sequence employment_id_seq\n"
-"create sequence employer_id_seq]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:71
 #, no-c-format
 msgid "Author/Work"
 msgstr "作者/作品"
 
 #. Tag: para
-#: example_mappings.xml:73
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Consider the following model of the relationships between <literal>Work</"
 "literal>, <literal>Author</literal> and <literal>Person</literal>. In the "
@@ -171,143 +69,41 @@
 "literal> is represented as one-to-one association. Another possibility would "
 "be to have <literal>Author</literal> extend <literal>Person</literal>."
 msgstr ""
-"<literal>Work</literal> , <literal>Author</literal> そして <literal>Person</"
+"<literal>Work</literal> 、 <literal>Author</literal> そして <literal>Person</"
 "literal> の関係を表す以下のモデルを考えてみてください。 <literal>Work</"
 "literal> と <literal>Author</literal> の関係を多対多関連で表しています。 "
 "<literal>Author</literal> と <literal>Person</literal> の関係は一対一関連とし"
-"て表しています。 他には <literal>Author</literal> が <literal>Person</"
+"て表しています。他には <literal>Author</literal> が <literal>Person</"
 "literal> を拡張するという方法もあります。"
 
 #. Tag: para
-#: example_mappings.xml:91
 #, no-c-format
 msgid ""
 "The following mapping document correctly represents these relationships:"
-msgstr "以下のマッピングドキュメントはこのような関係を正確に表現しています。"
+msgstr "以下のマッピングドキュメントはこのような関係を正確に表現しています:"
 
-#. Tag: programlisting
-#: example_mappings.xml:95
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
-"\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <discriminator column=\"type\" type=\"character\"/>\n"
-"\n"
-"        <property name=\"title\"/>\n"
-"        <set name=\"authors\" table=\"author_work\">\n"
-"            <key column name=\"work_id\"/>\n"
-"            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
-"        </set>\n"
-"\n"
-"        <subclass name=\"Book\" discriminator-value=\"B\">\n"
-"            <property name=\"text\"/>\n"
-"        </subclass>\n"
-"\n"
-"        <subclass name=\"Song\" discriminator-value=\"S\">\n"
-"            <property name=\"tempo\"/>\n"
-"            <property name=\"genre\"/>\n"
-"        </subclass>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Author\" table=\"authors\">\n"
-"\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <!-- The Author must have the same identifier as the Person -->\n"
-"            <generator class=\"assigned\"/> \n"
-"        </id>\n"
-"\n"
-"        <property name=\"alias\"/>\n"
-"        <one-to-one name=\"person\" constrained=\"true\"/>\n"
-"\n"
-"        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
-"            <key column=\"author_id\"/>\n"
-"            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
-"        </set>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Person\" table=\"persons\">\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: example_mappings.xml:97
-#, fuzzy, no-c-format
-msgid ""
 "There are four tables in this mapping: <literal>works</literal>, "
 "<literal>authors</literal> and <literal>persons</literal> hold work, author "
 "and person data respectively. <literal>author_work</literal> is an "
 "association table linking authors to works. Here is the table schema, as "
 "generated by <literal>SchemaExport</literal>:"
 msgstr ""
-"このマッピングには4つのテーブルがあります。 <literal>works</literal> , "
+"このマッピングには4つのテーブルがあります。 <literal>works</literal> 、 "
 "<literal>authors</literal> , <literal>persons</literal> はそれぞれ、仕事、作"
 "者、人のデータを保持します。 <literal>author_work</literal> は作者と作品をリ"
-"ンクする関連テーブルです。 以下は <literal>SchemaExport</literal> で生成した"
+"ンクする関連テーブルです。以下は <literal>SchemaExport</literal> で生成した"
 "テーブルスキーマです。"
 
-#. Tag: programlisting
-#: example_mappings.xml:105
-#, no-c-format
-msgid ""
-"<![CDATA[create table works (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    tempo FLOAT, \n"
-"    genre VARCHAR(255), \n"
-"    text INTEGER, \n"
-"    title VARCHAR(255), \n"
-"    type CHAR(1) not null, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table author_work (\n"
-"    author_id BIGINT not null, \n"
-"    work_id BIGINT not null, \n"
-"    primary key (work_id, author_id)\n"
-")\n"
-"\n"
-"create table authors (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    alias VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table persons (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table authors \n"
-"    add constraint authorsFK0 foreign key (id) references persons\n"
-"alter table author_work \n"
-"    add constraint author_workFK0 foreign key (author_id) references "
-"authors\n"
-"alter table author_work\n"
-"    add constraint author_workFK1 foreign key (work_id) references works]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:110
 #, no-c-format
 msgid "Customer/Order/Product"
 msgstr "顧客/注文/製品"
 
 #. Tag: para
-#: example_mappings.xml:112
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In this section we consider a model of the relationships between "
 "<literal>Customer</literal>, <literal>Order</literal>, <literal>Line Item</"
@@ -319,66 +115,21 @@
 "between <literal>Order</literal> and <literal>Product</literal>. In "
 "Hibernate this is called a composite element."
 msgstr ""
-"さて、 <literal>Customer</literal> , <literal>Order</literal> , "
-"<literal>LineItem</literal><literal>Product</literal> の関係を表すモデルを考"
-"えてみましょう。 <literal>Customer</literal> と <literal>Order</literal> は一"
-"対多の関連ですが、 <literal>Order</literal> / <literal>LineItem</literal> / "
-"<literal>Product</literal> はどのように表現するべきでしょうか? "
-"<literal>LineItem</literal> を、<literal>Order</literal> と "
+"さて、 <literal>Customer</literal> 、 <literal>Order</literal> 、 "
+"<literal>LineItem</literal> 、 <literal>Product</literal> の関係を表すモデル"
+"を考えてみましょう。 <literal>Customer</literal> と <literal>Order</literal> "
+"は一対多の関連ですが、 <literal>Order</literal> / <literal>LineItem</"
+"literal> / <literal>Product</literal> はどのように表現するべきでしょうか? "
+"<literal>LineItem</literal> を、 <literal>Order</literal> と "
 "<literal>Product</literal> の多対多関連を表現する関連クラスとしてマッピングし"
-"ました。 Hibernateではこれをコンポジット要素と呼びます。"
+"ました。 Hibernate ではこれをコンポジット要素と呼びます。"
 
 #. Tag: para
-#: example_mappings.xml:132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The mapping document will look like this:"
 msgstr "マッピングドキュメント:"
 
-#. Tag: programlisting
-#: example_mappings.xml:136
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Customer\" table=\"customers\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"        <set name=\"orders\" inverse=\"true\">\n"
-"            <key column=\"customer_id\"/>\n"
-"            <one-to-many class=\"Order\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Order\" table=\"orders\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"date\"/>\n"
-"        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
-"        <list name=\"lineItems\" table=\"line_items\">\n"
-"            <key column=\"order_id\"/>\n"
-"            <list-index column=\"line_number\"/>\n"
-"            <composite-element class=\"LineItem\">\n"
-"                <property name=\"quantity\"/>\n"
-"                <many-to-one name=\"product\" column=\"product_id\"/>\n"
-"            </composite-element>\n"
-"        </list>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Product\" table=\"products\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"serialNumber\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_mappings.xml:138
 #, no-c-format
 msgid ""
 "<literal>customers</literal>, <literal>orders</literal>, "
@@ -386,401 +137,1137 @@
 "order, order line item and product data respectively. <literal>line_items</"
 "literal> also acts as an association table linking orders with products."
 msgstr ""
-"<literal>customers</literal> , <literal>orders</literal> , "
-"<literal>line_items</literal> , <literal>products</literal> はそれぞれ、顧"
+"<literal>customers</literal> 、 <literal>orders</literal> 、 "
+"<literal>line_items</literal> 、 <literal>products</literal> はそれぞれ、顧"
 "客、注文、注文明細、製品のデータを保持します。 <literal>line_items</literal> "
 "は注文と製品をリンクする関連テーブルとしても働きます。"
 
-#. Tag: programlisting
-#: example_mappings.xml:145
-#, no-c-format
-msgid ""
-"<![CDATA[create table customers (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table orders (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    customer_id BIGINT, \n"
-"    date TIMESTAMP, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table line_items (\n"
-"    line_number INTEGER not null, \n"
-"    order_id BIGINT not null, \n"
-"    product_id BIGINT, \n"
-"    quantity INTEGER, \n"
-"    primary key (order_id, line_number)\n"
-")\n"
-"\n"
-"create table products (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    serialNumber VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table orders \n"
-"    add constraint ordersFK0 foreign key (customer_id) references customers\n"
-"alter table line_items\n"
-"    add constraint line_itemsFK0 foreign key (product_id) references "
-"products\n"
-"alter table line_items\n"
-"    add constraint line_itemsFK1 foreign key (order_id) references orders]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:150
 #, no-c-format
 msgid "Miscellaneous example mappings"
 msgstr "種々雑多なマッピング例"
 
 #. Tag: para
-#: example_mappings.xml:152
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These examples are available from the Hibernate test suite. You will find "
 "many other useful example mappings there by searching in the <literal>test</"
 "literal> folder of the Hibernate distribution."
 msgstr ""
-"ここにある例はすべてHibernateのテストスイートから取りました。 そこには、他に"
-"もたくさんのマッピングの例があります。 Hibernateディストリビューションの "
+"ここにある例はすべて Hibernate のテストスイートから取りました。そこには、他に"
+"もたくさんのマッピングの例があります。 Hibernate ディストリビューションの "
 "<literal>test</literal> フォルダを見てください。"
 
 #. Tag: title
-#: example_mappings.xml:161
 #, no-c-format
 msgid "\"Typed\" one-to-one association"
 msgstr "「型付けされた」一対一関連"
 
-#. Tag: programlisting
-#: example_mappings.xml:162
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"name\"/>\n"
-"    <one-to-one name=\"address\" \n"
-"            cascade=\"all\">\n"
-"        <formula>name</formula>\n"
-"        <formula>'HOME'</formula>\n"
-"    </one-to-one>\n"
-"    <one-to-one name=\"mailingAddress\" \n"
-"            cascade=\"all\">\n"
-"        <formula>name</formula>\n"
-"        <formula>'MAILING'</formula>\n"
-"    </one-to-one>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\" batch-size=\"2\" \n"
-"        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
-"    <composite-id>\n"
-"        <key-many-to-one name=\"person\" \n"
-"                column=\"personName\"/>\n"
-"        <key-property name=\"type\" \n"
-"                column=\"addressType\"/>\n"
-"    </composite-id>\n"
-"    <property name=\"street\" type=\"text\"/>\n"
-"    <property name=\"state\"/>\n"
-"    <property name=\"zip\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:166
 #, no-c-format
 msgid "Composite key example"
 msgstr "複合キーの例"
 
-#. Tag: programlisting
-#: example_mappings.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Customer\">\n"
-"\n"
-"    <id name=\"customerId\"\n"
-"        length=\"10\">\n"
-"        <generator class=\"assigned\"/>\n"
-"    </id>\n"
-"\n"
-"    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
-"    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
-"\n"
-"    <list name=\"orders\"\n"
-"            inverse=\"true\"\n"
-"            cascade=\"save-update\">\n"
-"        <key column=\"customerId\"/>\n"
-"        <index column=\"orderNumber\"/>\n"
-"        <one-to-many class=\"Order\"/>\n"
-"    </list>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
-"    <synchronize table=\"LineItem\"/>\n"
-"    <synchronize table=\"Product\"/>\n"
-"    \n"
-"    <composite-id name=\"id\" \n"
-"            class=\"Order$Id\">\n"
-"        <key-property name=\"customerId\" length=\"10\"/>\n"
-"        <key-property name=\"orderNumber\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"orderDate\" \n"
-"            type=\"calendar_date\"\n"
-"            not-null=\"true\"/>\n"
-"    \n"
-"    <property name=\"total\">\n"
-"        <formula>\n"
-"            ( select sum(li.quantity*p.price) \n"
-"            from LineItem li, Product p \n"
-"            where li.productId = p.productId \n"
-"                and li.customerId = customerId \n"
-"                and li.orderNumber = orderNumber )\n"
-"        </formula>\n"
-"    </property>\n"
-"    \n"
-"    <many-to-one name=\"customer\"\n"
-"            column=\"customerId\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\"/>\n"
-"        \n"
-"    <bag name=\"lineItems\"\n"
-"            fetch=\"join\" \n"
-"            inverse=\"true\"\n"
-"            cascade=\"save-update\">\n"
-"        <key>\n"
-"            <column name=\"customerId\"/>\n"
-"            <column name=\"orderNumber\"/>\n"
-"        </key>\n"
-"        <one-to-many class=\"LineItem\"/>\n"
-"    </bag>\n"
-"    \n"
-"</class>\n"
-"    \n"
-"<class name=\"LineItem\">\n"
-"    \n"
-"    <composite-id name=\"id\" \n"
-"            class=\"LineItem$Id\">\n"
-"        <key-property name=\"customerId\" length=\"10\"/>\n"
-"        <key-property name=\"orderNumber\"/>\n"
-"        <key-property name=\"productId\" length=\"10\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"quantity\"/>\n"
-"    \n"
-"    <many-to-one name=\"order\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\">\n"
-"        <column name=\"customerId\"/>\n"
-"        <column name=\"orderNumber\"/>\n"
-"    </many-to-one>\n"
-"    \n"
-"    <many-to-one name=\"product\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\"\n"
-"            column=\"productId\"/>\n"
-"        \n"
-"</class>\n"
-"\n"
-"<class name=\"Product\">\n"
-"    <synchronize table=\"LineItem\"/>\n"
-"\n"
-"    <id name=\"productId\"\n"
-"        length=\"10\">\n"
-"        <generator class=\"assigned\"/>\n"
-"    </id>\n"
-"    \n"
-"    <property name=\"description\" \n"
-"        not-null=\"true\" \n"
-"        length=\"200\"/>\n"
-"    <property name=\"price\" length=\"3\"/>\n"
-"    <property name=\"numberAvailable\"/>\n"
-"    \n"
-"    <property name=\"numberOrdered\">\n"
-"        <formula>\n"
-"            ( select sum(li.quantity) \n"
-"            from LineItem li \n"
-"            where li.productId = productId )\n"
-"        </formula>\n"
-"    </property>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:171
 #, no-c-format
 msgid "Many-to-many with shared composite key attribute"
 msgstr "複合キー属性を共有する多対多"
 
-#. Tag: programlisting
-#: example_mappings.xml:172
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"User\" table=\"`User`\">\n"
-"    <composite-id>\n"
-"        <key-property name=\"name\"/>\n"
-"        <key-property name=\"org\"/>\n"
-"    </composite-id>\n"
-"    <set name=\"groups\" table=\"UserGroup\">\n"
-"        <key>\n"
-"            <column name=\"userName\"/>\n"
-"            <column name=\"org\"/>\n"
-"        </key>\n"
-"        <many-to-many class=\"Group\">\n"
-"            <column name=\"groupName\"/>\n"
-"            <formula>org</formula>\n"
-"        </many-to-many>\n"
-"    </set>\n"
-"</class>\n"
-"    \n"
-"<class name=\"Group\" table=\"`Group`\">\n"
-"    <composite-id>\n"
-"        <key-property name=\"name\"/>\n"
-"        <key-property name=\"org\"/>\n"
-"    </composite-id>\n"
-"    <property name=\"description\"/>\n"
-"    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
-"        <key>\n"
-"            <column name=\"groupName\"/>\n"
-"            <column name=\"org\"/>\n"
-"        </key>\n"
-"        <many-to-many class=\"User\">\n"
-"            <column name=\"userName\"/>\n"
-"            <formula>org</formula>\n"
-"        </many-to-many>\n"
-"    </set>\n"
-"</class>\n"
-"]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:176
 #, no-c-format
 msgid "Content based discrimination"
-msgstr "discriminationに基づく内容"
+msgstr "discrimination に基づく内容"
 
-#. Tag: programlisting
-#: example_mappings.xml:177
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\"\n"
-"    discriminator-value=\"P\">\n"
-"    \n"
-"    <id name=\"id\" \n"
-"        column=\"person_id\" \n"
-"        unsaved-value=\"0\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    \n"
-"            \n"
-"    <discriminator \n"
-"        type=\"character\">\n"
-"        <formula>\n"
-"            case \n"
-"                when title is not null then 'E' \n"
-"                when salesperson is not null then 'C' \n"
-"                else 'P' \n"
-"            end\n"
-"        </formula>\n"
-"    </discriminator>\n"
-"\n"
-"    <property name=\"name\" \n"
-"        not-null=\"true\"\n"
-"        length=\"80\"/>\n"
-"        \n"
-"    <property name=\"sex\" \n"
-"        not-null=\"true\"\n"
-"        update=\"false\"/>\n"
-"    \n"
-"    <component name=\"address\">\n"
-"        <property name=\"address\"/>\n"
-"        <property name=\"zip\"/>\n"
-"        <property name=\"country\"/>\n"
-"    </component>\n"
-"    \n"
-"    <subclass name=\"Employee\" \n"
-"        discriminator-value=\"E\">\n"
-"            <property name=\"title\"\n"
-"                length=\"20\"/>\n"
-"            <property name=\"salary\"/>\n"
-"            <many-to-one name=\"manager\"/>\n"
-"    </subclass>\n"
-"    \n"
-"    <subclass name=\"Customer\" \n"
-"        discriminator-value=\"C\">\n"
-"            <property name=\"comments\"/>\n"
-"            <many-to-one name=\"salesperson\"/>\n"
-"    </subclass>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:181
 #, no-c-format
 msgid "Associations on alternate keys"
 msgstr "代替キーの関連"
 
-#. Tag: programlisting
-#: example_mappings.xml:182
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    \n"
-"    <id name=\"id\">\n"
-"        <generator class=\"hilo\"/>\n"
-"    </id>\n"
-"    \n"
-"    <property name=\"name\" length=\"100\"/>\n"
-"    \n"
-"    <one-to-one name=\"address\" \n"
-"        property-ref=\"person\"\n"
-"        cascade=\"all\"\n"
-"        fetch=\"join\"/>\n"
-"    \n"
-"    <set name=\"accounts\" \n"
-"        inverse=\"true\">\n"
-"        <key column=\"userId\"\n"
-"            property-ref=\"userId\"/>\n"
-"        <one-to-many class=\"Account\"/>\n"
-"    </set>\n"
-"    \n"
-"    <property name=\"userId\" length=\"8\"/>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"hilo\"/>\n"
-"    </id>\n"
-"\n"
-"    <property name=\"address\" length=\"300\"/>\n"
-"    <property name=\"zip\" length=\"5\"/>\n"
-"    <property name=\"country\" length=\"25\"/>\n"
-"    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Account\">\n"
-"    <id name=\"accountId\" length=\"32\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    \n"
-"    <many-to-one name=\"user\"\n"
-"        column=\"userId\"\n"
-"        property-ref=\"userId\"/>\n"
-"    \n"
-"    <property name=\"type\" not-null=\"true\"/>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "        \n"
+#~ "    <class name=\"Employer\" table=\"employers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employer_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employment\" table=\"employment_periods\">\n"
+#~ "\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employment_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"startDate\" column=\"start_date\"/>\n"
+#~ "        <property name=\"endDate\" column=\"end_date\"/>\n"
+#~ "\n"
+#~ "        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
+#~ "            <property name=\"amount\">\n"
+#~ "                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/"
+#~ ">\n"
+#~ "            </property>\n"
+#~ "            <property name=\"currency\" length=\"12\"/>\n"
+#~ "        </component>\n"
+#~ "\n"
+#~ "        <many-to-one name=\"employer\" column=\"employer_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "        <many-to-one name=\"employee\" column=\"employee_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employee\" table=\"employees\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employee_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"taxfileNumber\"/>\n"
+#~ "        <component name=\"name\" class=\"Name\">\n"
+#~ "            <property name=\"firstName\"/>\n"
+#~ "            <property name=\"initial\"/>\n"
+#~ "            <property name=\"lastName\"/>\n"
+#~ "        </component>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "        \n"
+#~ "    &lt;class name=\"Employer\" table=\"employers\"&gt;\n"
+#~ "        &lt;id name=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"sequence\"&gt;\n"
+#~ "                &lt;param name=\"sequence\"&gt;employer_id_seq&lt;/"
+#~ "param&gt;\n"
+#~ "            &lt;/generator&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;property name=\"name\"/&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Employment\" table=\"employment_periods\"&gt;\n"
+#~ "\n"
+#~ "        &lt;id name=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"sequence\"&gt;\n"
+#~ "                &lt;param name=\"sequence\"&gt;employment_id_seq&lt;/"
+#~ "param&gt;\n"
+#~ "            &lt;/generator&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;property name=\"startDate\" column=\"start_date\"/&gt;\n"
+#~ "        &lt;property name=\"endDate\" column=\"end_date\"/&gt;\n"
+#~ "\n"
+#~ "        &lt;component name=\"hourlyRate\" class=\"MonetaryAmount\"&gt;\n"
+#~ "            &lt;property name=\"amount\"&gt;\n"
+#~ "                &lt;column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)"
+#~ "\"/&gt;\n"
+#~ "            &lt;/property&gt;\n"
+#~ "            &lt;property name=\"currency\" length=\"12\"/&gt;\n"
+#~ "        &lt;/component&gt;\n"
+#~ "\n"
+#~ "        &lt;many-to-one name=\"employer\" column=\"employer_id\" not-null="
+#~ "\"true\"/&gt;\n"
+#~ "        &lt;many-to-one name=\"employee\" column=\"employee_id\" not-null="
+#~ "\"true\"/&gt;\n"
+#~ "\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Employee\" table=\"employees\"&gt;\n"
+#~ "        &lt;id name=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"sequence\"&gt;\n"
+#~ "                &lt;param name=\"sequence\"&gt;employee_id_seq&lt;/"
+#~ "param&gt;\n"
+#~ "            &lt;/generator&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;property name=\"taxfileNumber\"/&gt;\n"
+#~ "        &lt;component name=\"name\" class=\"Name\"&gt;\n"
+#~ "            &lt;property name=\"firstName\"/&gt;\n"
+#~ "            &lt;property name=\"initial\"/&gt;\n"
+#~ "            &lt;property name=\"lastName\"/&gt;\n"
+#~ "        &lt;/component&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
 
-#~ msgid "TODO: put words around this stuff"
-#~ msgstr "TODO: ここに文章を埋める"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[create table employers (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employment_periods (\n"
+#~ "    id BIGINT not null,\n"
+#~ "    hourly_rate NUMERIC(12, 2),\n"
+#~ "    currency VARCHAR(12), \n"
+#~ "    employee_id BIGINT not null, \n"
+#~ "    employer_id BIGINT not null, \n"
+#~ "    end_date TIMESTAMP, \n"
+#~ "    start_date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employees (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    firstName VARCHAR(255), \n"
+#~ "    initial CHAR(1), \n"
+#~ "    lastName VARCHAR(255), \n"
+#~ "    taxfileNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK0 foreign key (employer_id) "
+#~ "references employers\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK1 foreign key (employee_id) "
+#~ "references employees\n"
+#~ "create sequence employee_id_seq\n"
+#~ "create sequence employment_id_seq\n"
+#~ "create sequence employer_id_seq]]>"
+#~ msgstr ""
+#~ "create table employers (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employment_periods (\n"
+#~ "    id BIGINT not null,\n"
+#~ "    hourly_rate NUMERIC(12, 2),\n"
+#~ "    currency VARCHAR(12), \n"
+#~ "    employee_id BIGINT not null, \n"
+#~ "    employer_id BIGINT not null, \n"
+#~ "    end_date TIMESTAMP, \n"
+#~ "    start_date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employees (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    firstName VARCHAR(255), \n"
+#~ "    initial CHAR(1), \n"
+#~ "    lastName VARCHAR(255), \n"
+#~ "    taxfileNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK0 foreign key (employer_id) "
+#~ "references employers\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK1 foreign key (employee_id) "
+#~ "references employees\n"
+#~ "create sequence employee_id_seq\n"
+#~ "create sequence employment_id_seq\n"
+#~ "create sequence employer_id_seq"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <discriminator column=\"type\" type=\"character\"/>\n"
+#~ "\n"
+#~ "        <property name=\"title\"/>\n"
+#~ "        <set name=\"authors\" table=\"author_work\">\n"
+#~ "            <key column name=\"work_id\"/>\n"
+#~ "            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "        <subclass name=\"Book\" discriminator-value=\"B\">\n"
+#~ "            <property name=\"text\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "        <subclass name=\"Song\" discriminator-value=\"S\">\n"
+#~ "            <property name=\"tempo\"/>\n"
+#~ "            <property name=\"genre\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Author\" table=\"authors\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <!-- The Author must have the same identifier as the Person --"
+#~ ">\n"
+#~ "            <generator class=\"assigned\"/> \n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property name=\"alias\"/>\n"
+#~ "        <one-to-one name=\"person\" constrained=\"true\"/>\n"
+#~ "\n"
+#~ "        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
+#~ "            <key column=\"author_id\"/>\n"
+#~ "            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Person\" table=\"persons\">\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Work\" table=\"works\" discriminator-value=\"W"
+#~ "\"&gt;\n"
+#~ "\n"
+#~ "        &lt;id name=\"id\" column=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"native\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;discriminator column=\"type\" type=\"character\"/&gt;\n"
+#~ "\n"
+#~ "        &lt;property name=\"title\"/&gt;\n"
+#~ "        &lt;set name=\"authors\" table=\"author_work\"&gt;\n"
+#~ "            &lt;key column name=\"work_id\"/&gt;\n"
+#~ "            &lt;many-to-many class=\"Author\" column name=\"author_id\"/"
+#~ "&gt;\n"
+#~ "        &lt;/set&gt;\n"
+#~ "\n"
+#~ "        &lt;subclass name=\"Book\" discriminator-value=\"B\"&gt;\n"
+#~ "            &lt;property name=\"text\"/&gt;\n"
+#~ "        &lt;/subclass&gt;\n"
+#~ "\n"
+#~ "        &lt;subclass name=\"Song\" discriminator-value=\"S\"&gt;\n"
+#~ "            &lt;property name=\"tempo\"/&gt;\n"
+#~ "            &lt;property name=\"genre\"/&gt;\n"
+#~ "        &lt;/subclass&gt;\n"
+#~ "\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Author\" table=\"authors\"&gt;\n"
+#~ "\n"
+#~ "        &lt;id name=\"id\" column=\"id\"&gt;\n"
+#~ "            &lt;!-- The Author must have the same identifier as the "
+#~ "Person --&gt;\n"
+#~ "            &lt;generator class=\"assigned\"/&gt; \n"
+#~ "        &lt;/id&gt;\n"
+#~ "\n"
+#~ "        &lt;property name=\"alias\"/&gt;\n"
+#~ "        &lt;one-to-one name=\"person\" constrained=\"true\"/&gt;\n"
+#~ "\n"
+#~ "        &lt;set name=\"works\" table=\"author_work\" inverse=\"true"
+#~ "\"&gt;\n"
+#~ "            &lt;key column=\"author_id\"/&gt;\n"
+#~ "            &lt;many-to-many class=\"Work\" column=\"work_id\"/&gt;\n"
+#~ "        &lt;/set&gt;\n"
+#~ "\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Person\" table=\"persons\"&gt;\n"
+#~ "        &lt;id name=\"id\" column=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"native\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;property name=\"name\"/&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[create table works (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    tempo FLOAT, \n"
+#~ "    genre VARCHAR(255), \n"
+#~ "    text INTEGER, \n"
+#~ "    title VARCHAR(255), \n"
+#~ "    type CHAR(1) not null, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table author_work (\n"
+#~ "    author_id BIGINT not null, \n"
+#~ "    work_id BIGINT not null, \n"
+#~ "    primary key (work_id, author_id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table authors (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    alias VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table persons (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table authors \n"
+#~ "    add constraint authorsFK0 foreign key (id) references persons\n"
+#~ "alter table author_work \n"
+#~ "    add constraint author_workFK0 foreign key (author_id) references "
+#~ "authors\n"
+#~ "alter table author_work\n"
+#~ "    add constraint author_workFK1 foreign key (work_id) references works]]"
+#~ ">"
+#~ msgstr ""
+#~ "create table works (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    tempo FLOAT, \n"
+#~ "    genre VARCHAR(255), \n"
+#~ "    text INTEGER, \n"
+#~ "    title VARCHAR(255), \n"
+#~ "    type CHAR(1) not null, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table author_work (\n"
+#~ "    author_id BIGINT not null, \n"
+#~ "    work_id BIGINT not null, \n"
+#~ "    primary key (work_id, author_id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table authors (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    alias VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table persons (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table authors \n"
+#~ "    add constraint authorsFK0 foreign key (id) references persons\n"
+#~ "alter table author_work \n"
+#~ "    add constraint author_workFK0 foreign key (author_id) references "
+#~ "authors\n"
+#~ "alter table author_work\n"
+#~ "    add constraint author_workFK1 foreign key (work_id) references works"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Customer\" table=\"customers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "        <set name=\"orders\" inverse=\"true\">\n"
+#~ "            <key column=\"customer_id\"/>\n"
+#~ "            <one-to-many class=\"Order\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Order\" table=\"orders\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"date\"/>\n"
+#~ "        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
+#~ "        <list name=\"lineItems\" table=\"line_items\">\n"
+#~ "            <key column=\"order_id\"/>\n"
+#~ "            <list-index column=\"line_number\"/>\n"
+#~ "            <composite-element class=\"LineItem\">\n"
+#~ "                <property name=\"quantity\"/>\n"
+#~ "                <many-to-one name=\"product\" column=\"product_id\"/>\n"
+#~ "            </composite-element>\n"
+#~ "        </list>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Product\" table=\"products\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"serialNumber\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Customer\" table=\"customers\"&gt;\n"
+#~ "        &lt;id name=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"native\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;property name=\"name\"/&gt;\n"
+#~ "        &lt;set name=\"orders\" inverse=\"true\"&gt;\n"
+#~ "            &lt;key column=\"customer_id\"/&gt;\n"
+#~ "            &lt;one-to-many class=\"Order\"/&gt;\n"
+#~ "        &lt;/set&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Order\" table=\"orders\"&gt;\n"
+#~ "        &lt;id name=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"native\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;property name=\"date\"/&gt;\n"
+#~ "        &lt;many-to-one name=\"customer\" column=\"customer_id\"/&gt;\n"
+#~ "        &lt;list name=\"lineItems\" table=\"line_items\"&gt;\n"
+#~ "            &lt;key column=\"order_id\"/&gt;\n"
+#~ "            &lt;list-index column=\"line_number\"/&gt;\n"
+#~ "            &lt;composite-element class=\"LineItem\"&gt;\n"
+#~ "                &lt;property name=\"quantity\"/&gt;\n"
+#~ "                &lt;many-to-one name=\"product\" column=\"product_id\"/"
+#~ "&gt;\n"
+#~ "            &lt;/composite-element&gt;\n"
+#~ "        &lt;/list&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"Product\" table=\"products\"&gt;\n"
+#~ "        &lt;id name=\"id\"&gt;\n"
+#~ "            &lt;generator class=\"native\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;property name=\"serialNumber\"/&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[create table customers (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table orders (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    customer_id BIGINT, \n"
+#~ "    date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table line_items (\n"
+#~ "    line_number INTEGER not null, \n"
+#~ "    order_id BIGINT not null, \n"
+#~ "    product_id BIGINT, \n"
+#~ "    quantity INTEGER, \n"
+#~ "    primary key (order_id, line_number)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table products (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    serialNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table orders \n"
+#~ "    add constraint ordersFK0 foreign key (customer_id) references "
+#~ "customers\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK0 foreign key (product_id) references "
+#~ "products\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK1 foreign key (order_id) references "
+#~ "orders]]>"
+#~ msgstr ""
+#~ "create table customers (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table orders (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    customer_id BIGINT, \n"
+#~ "    date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table line_items (\n"
+#~ "    line_number INTEGER not null, \n"
+#~ "    order_id BIGINT not null, \n"
+#~ "    product_id BIGINT, \n"
+#~ "    quantity INTEGER, \n"
+#~ "    primary key (order_id, line_number)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table products (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    serialNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table orders \n"
+#~ "    add constraint ordersFK0 foreign key (customer_id) references "
+#~ "customers\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK0 foreign key (product_id) references "
+#~ "products\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK1 foreign key (order_id) references orders"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"name\"/>\n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'HOME'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "    <one-to-one name=\"mailingAddress\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'MAILING'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\" batch-size=\"2\" \n"
+#~ "        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-many-to-one name=\"person\" \n"
+#~ "                column=\"personName\"/>\n"
+#~ "        <key-property name=\"type\" \n"
+#~ "                column=\"addressType\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"street\" type=\"text\"/>\n"
+#~ "    <property name=\"state\"/>\n"
+#~ "    <property name=\"zip\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"name\"/&gt;\n"
+#~ "    &lt;one-to-one name=\"address\" \n"
+#~ "            cascade=\"all\"&gt;\n"
+#~ "        &lt;formula&gt;name&lt;/formula&gt;\n"
+#~ "        &lt;formula&gt;'HOME'&lt;/formula&gt;\n"
+#~ "    &lt;/one-to-one&gt;\n"
+#~ "    &lt;one-to-one name=\"mailingAddress\" \n"
+#~ "            cascade=\"all\"&gt;\n"
+#~ "        &lt;formula&gt;name&lt;/formula&gt;\n"
+#~ "        &lt;formula&gt;'MAILING'&lt;/formula&gt;\n"
+#~ "    &lt;/one-to-one&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\" batch-size=\"2\" \n"
+#~ "        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\"&gt;\n"
+#~ "    &lt;composite-id&gt;\n"
+#~ "        &lt;key-many-to-one name=\"person\" \n"
+#~ "                column=\"personName\"/&gt;\n"
+#~ "        &lt;key-property name=\"type\" \n"
+#~ "                column=\"addressType\"/&gt;\n"
+#~ "    &lt;/composite-id&gt;\n"
+#~ "    &lt;property name=\"street\" type=\"text\"/&gt;\n"
+#~ "    &lt;property name=\"state\"/&gt;\n"
+#~ "    &lt;property name=\"zip\"/&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Customer\">\n"
+#~ "\n"
+#~ "    <id name=\"customerId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
+#~ "    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
+#~ "\n"
+#~ "    <list name=\"orders\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key column=\"customerId\"/>\n"
+#~ "        <index column=\"orderNumber\"/>\n"
+#~ "        <one-to-many class=\"Order\"/>\n"
+#~ "    </list>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "    <synchronize table=\"Product\"/>\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"Order$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"orderDate\" \n"
+#~ "            type=\"calendar_date\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"total\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity*p.price) \n"
+#~ "            from LineItem li, Product p \n"
+#~ "            where li.productId = p.productId \n"
+#~ "                and li.customerId = customerId \n"
+#~ "                and li.orderNumber = orderNumber )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"customer\"\n"
+#~ "            column=\"customerId\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        \n"
+#~ "    <bag name=\"lineItems\"\n"
+#~ "            fetch=\"join\" \n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "            <column name=\"orderNumber\"/>\n"
+#~ "        </key>\n"
+#~ "        <one-to-many class=\"LineItem\"/>\n"
+#~ "    </bag>\n"
+#~ "    \n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"LineItem\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"LineItem$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "        <key-property name=\"productId\" length=\"10\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"quantity\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\">\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "        <column name=\"orderNumber\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"product\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            column=\"productId\"/>\n"
+#~ "        \n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Product\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "\n"
+#~ "    <id name=\"productId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"description\" \n"
+#~ "        not-null=\"true\" \n"
+#~ "        length=\"200\"/>\n"
+#~ "    <property name=\"price\" length=\"3\"/>\n"
+#~ "    <property name=\"numberAvailable\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"numberOrdered\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity) \n"
+#~ "            from LineItem li \n"
+#~ "            where li.productId = productId )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Customer\"&gt;\n"
+#~ "\n"
+#~ "    &lt;id name=\"customerId\"\n"
+#~ "        length=\"10\"&gt;\n"
+#~ "        &lt;generator class=\"assigned\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "\n"
+#~ "    &lt;property name=\"name\" not-null=\"true\" length=\"100\"/&gt;\n"
+#~ "    &lt;property name=\"address\" not-null=\"true\" length=\"200\"/&gt;\n"
+#~ "\n"
+#~ "    &lt;list name=\"orders\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\"&gt;\n"
+#~ "        &lt;key column=\"customerId\"/&gt;\n"
+#~ "        &lt;index column=\"orderNumber\"/&gt;\n"
+#~ "        &lt;one-to-many class=\"Order\"/&gt;\n"
+#~ "    &lt;/list&gt;\n"
+#~ "\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\"&gt;\n"
+#~ "    &lt;synchronize table=\"LineItem\"/&gt;\n"
+#~ "    &lt;synchronize table=\"Product\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;composite-id name=\"id\" \n"
+#~ "            class=\"Order&#36;Id\"&gt;\n"
+#~ "        &lt;key-property name=\"customerId\" length=\"10\"/&gt;\n"
+#~ "        &lt;key-property name=\"orderNumber\"/&gt;\n"
+#~ "    &lt;/composite-id&gt;\n"
+#~ "    \n"
+#~ "    &lt;property name=\"orderDate\" \n"
+#~ "            type=\"calendar_date\"\n"
+#~ "            not-null=\"true\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;property name=\"total\"&gt;\n"
+#~ "        &lt;formula&gt;\n"
+#~ "            ( select sum(li.quantity*p.price) \n"
+#~ "            from LineItem li, Product p \n"
+#~ "            where li.productId = p.productId \n"
+#~ "                and li.customerId = customerId \n"
+#~ "                and li.orderNumber = orderNumber )\n"
+#~ "        &lt;/formula&gt;\n"
+#~ "    &lt;/property&gt;\n"
+#~ "    \n"
+#~ "    &lt;many-to-one name=\"customer\"\n"
+#~ "            column=\"customerId\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"/&gt;\n"
+#~ "        \n"
+#~ "    &lt;bag name=\"lineItems\"\n"
+#~ "            fetch=\"join\" \n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\"&gt;\n"
+#~ "        &lt;key&gt;\n"
+#~ "            &lt;column name=\"customerId\"/&gt;\n"
+#~ "            &lt;column name=\"orderNumber\"/&gt;\n"
+#~ "        &lt;/key&gt;\n"
+#~ "        &lt;one-to-many class=\"LineItem\"/&gt;\n"
+#~ "    &lt;/bag&gt;\n"
+#~ "    \n"
+#~ "&lt;/class&gt;\n"
+#~ "    \n"
+#~ "&lt;class name=\"LineItem\"&gt;\n"
+#~ "    \n"
+#~ "    &lt;composite-id name=\"id\" \n"
+#~ "            class=\"LineItem&#36;Id\"&gt;\n"
+#~ "        &lt;key-property name=\"customerId\" length=\"10\"/&gt;\n"
+#~ "        &lt;key-property name=\"orderNumber\"/&gt;\n"
+#~ "        &lt;key-property name=\"productId\" length=\"10\"/&gt;\n"
+#~ "    &lt;/composite-id&gt;\n"
+#~ "    \n"
+#~ "    &lt;property name=\"quantity\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;many-to-one name=\"order\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"&gt;\n"
+#~ "        &lt;column name=\"customerId\"/&gt;\n"
+#~ "        &lt;column name=\"orderNumber\"/&gt;\n"
+#~ "    &lt;/many-to-one&gt;\n"
+#~ "    \n"
+#~ "    &lt;many-to-one name=\"product\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            column=\"productId\"/&gt;\n"
+#~ "        \n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Product\"&gt;\n"
+#~ "    &lt;synchronize table=\"LineItem\"/&gt;\n"
+#~ "\n"
+#~ "    &lt;id name=\"productId\"\n"
+#~ "        length=\"10\"&gt;\n"
+#~ "        &lt;generator class=\"assigned\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    \n"
+#~ "    &lt;property name=\"description\" \n"
+#~ "        not-null=\"true\" \n"
+#~ "        length=\"200\"/&gt;\n"
+#~ "    &lt;property name=\"price\" length=\"3\"/&gt;\n"
+#~ "    &lt;property name=\"numberAvailable\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;property name=\"numberOrdered\"&gt;\n"
+#~ "        &lt;formula&gt;\n"
+#~ "            ( select sum(li.quantity) \n"
+#~ "            from LineItem li \n"
+#~ "            where li.productId = productId )\n"
+#~ "        &lt;/formula&gt;\n"
+#~ "    &lt;/property&gt;\n"
+#~ "    \n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"User\" table=\"`User`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <set name=\"groups\" table=\"UserGroup\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"Group\">\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"Group\" table=\"`Group`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"description\"/>\n"
+#~ "    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"User\">\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"User\" table=\"`User`\"&gt;\n"
+#~ "    &lt;composite-id&gt;\n"
+#~ "        &lt;key-property name=\"name\"/&gt;\n"
+#~ "        &lt;key-property name=\"org\"/&gt;\n"
+#~ "    &lt;/composite-id&gt;\n"
+#~ "    &lt;set name=\"groups\" table=\"UserGroup\"&gt;\n"
+#~ "        &lt;key&gt;\n"
+#~ "            &lt;column name=\"userName\"/&gt;\n"
+#~ "            &lt;column name=\"org\"/&gt;\n"
+#~ "        &lt;/key&gt;\n"
+#~ "        &lt;many-to-many class=\"Group\"&gt;\n"
+#~ "            &lt;column name=\"groupName\"/&gt;\n"
+#~ "            &lt;formula&gt;org&lt;/formula&gt;\n"
+#~ "        &lt;/many-to-many&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "    \n"
+#~ "&lt;class name=\"Group\" table=\"`Group`\"&gt;\n"
+#~ "    &lt;composite-id&gt;\n"
+#~ "        &lt;key-property name=\"name\"/&gt;\n"
+#~ "        &lt;key-property name=\"org\"/&gt;\n"
+#~ "    &lt;/composite-id&gt;\n"
+#~ "    &lt;property name=\"description\"/&gt;\n"
+#~ "    &lt;set name=\"users\" table=\"UserGroup\" inverse=\"true\"&gt;\n"
+#~ "        &lt;key&gt;\n"
+#~ "            &lt;column name=\"groupName\"/&gt;\n"
+#~ "            &lt;column name=\"org\"/&gt;\n"
+#~ "        &lt;/key&gt;\n"
+#~ "        &lt;many-to-many class=\"User\"&gt;\n"
+#~ "            &lt;column name=\"userName\"/&gt;\n"
+#~ "            &lt;formula&gt;org&lt;/formula&gt;\n"
+#~ "        &lt;/many-to-many&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\"\n"
+#~ "    discriminator-value=\"P\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\" \n"
+#~ "        column=\"person_id\" \n"
+#~ "        unsaved-value=\"0\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "            \n"
+#~ "    <discriminator \n"
+#~ "        type=\"character\">\n"
+#~ "        <formula>\n"
+#~ "            case \n"
+#~ "                when title is not null then 'E' \n"
+#~ "                when salesperson is not null then 'C' \n"
+#~ "                else 'P' \n"
+#~ "            end\n"
+#~ "        </formula>\n"
+#~ "    </discriminator>\n"
+#~ "\n"
+#~ "    <property name=\"name\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        length=\"80\"/>\n"
+#~ "        \n"
+#~ "    <property name=\"sex\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        update=\"false\"/>\n"
+#~ "    \n"
+#~ "    <component name=\"address\">\n"
+#~ "        <property name=\"address\"/>\n"
+#~ "        <property name=\"zip\"/>\n"
+#~ "        <property name=\"country\"/>\n"
+#~ "    </component>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Employee\" \n"
+#~ "        discriminator-value=\"E\">\n"
+#~ "            <property name=\"title\"\n"
+#~ "                length=\"20\"/>\n"
+#~ "            <property name=\"salary\"/>\n"
+#~ "            <many-to-one name=\"manager\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Customer\" \n"
+#~ "        discriminator-value=\"C\">\n"
+#~ "            <property name=\"comments\"/>\n"
+#~ "            <many-to-one name=\"salesperson\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"\n"
+#~ "    discriminator-value=\"P\"&gt;\n"
+#~ "    \n"
+#~ "    &lt;id name=\"id\" \n"
+#~ "        column=\"person_id\" \n"
+#~ "        unsaved-value=\"0\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    \n"
+#~ "            \n"
+#~ "    &lt;discriminator \n"
+#~ "        type=\"character\"&gt;\n"
+#~ "        &lt;formula&gt;\n"
+#~ "            case \n"
+#~ "                when title is not null then 'E' \n"
+#~ "                when salesperson is not null then 'C' \n"
+#~ "                else 'P' \n"
+#~ "            end\n"
+#~ "        &lt;/formula&gt;\n"
+#~ "    &lt;/discriminator&gt;\n"
+#~ "\n"
+#~ "    &lt;property name=\"name\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        length=\"80\"/&gt;\n"
+#~ "        \n"
+#~ "    &lt;property name=\"sex\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        update=\"false\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;component name=\"address\"&gt;\n"
+#~ "        &lt;property name=\"address\"/&gt;\n"
+#~ "        &lt;property name=\"zip\"/&gt;\n"
+#~ "        &lt;property name=\"country\"/&gt;\n"
+#~ "    &lt;/component&gt;\n"
+#~ "    \n"
+#~ "    &lt;subclass name=\"Employee\" \n"
+#~ "        discriminator-value=\"E\"&gt;\n"
+#~ "            &lt;property name=\"title\"\n"
+#~ "                length=\"20\"/&gt;\n"
+#~ "            &lt;property name=\"salary\"/&gt;\n"
+#~ "            &lt;many-to-one name=\"manager\"/&gt;\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "    \n"
+#~ "    &lt;subclass name=\"Customer\" \n"
+#~ "        discriminator-value=\"C\"&gt;\n"
+#~ "            &lt;property name=\"comments\"/&gt;\n"
+#~ "            &lt;many-to-one name=\"salesperson\"/&gt;\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "    \n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\" length=\"100\"/>\n"
+#~ "    \n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "        property-ref=\"person\"\n"
+#~ "        cascade=\"all\"\n"
+#~ "        fetch=\"join\"/>\n"
+#~ "    \n"
+#~ "    <set name=\"accounts\" \n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"userId\"\n"
+#~ "            property-ref=\"userId\"/>\n"
+#~ "        <one-to-many class=\"Account\"/>\n"
+#~ "    </set>\n"
+#~ "    \n"
+#~ "    <property name=\"userId\" length=\"8\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"address\" length=\"300\"/>\n"
+#~ "    <property name=\"zip\" length=\"5\"/>\n"
+#~ "    <property name=\"country\" length=\"25\"/>\n"
+#~ "    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Account\">\n"
+#~ "    <id name=\"accountId\" length=\"32\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"user\"\n"
+#~ "        column=\"userId\"\n"
+#~ "        property-ref=\"userId\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"type\" not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    \n"
+#~ "    &lt;id name=\"id\"&gt;\n"
+#~ "        &lt;generator class=\"hilo\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    \n"
+#~ "    &lt;property name=\"name\" length=\"100\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;one-to-one name=\"address\" \n"
+#~ "        property-ref=\"person\"\n"
+#~ "        cascade=\"all\"\n"
+#~ "        fetch=\"join\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;set name=\"accounts\" \n"
+#~ "        inverse=\"true\"&gt;\n"
+#~ "        &lt;key column=\"userId\"\n"
+#~ "            property-ref=\"userId\"/&gt;\n"
+#~ "        &lt;one-to-many class=\"Account\"/&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "    \n"
+#~ "    &lt;property name=\"userId\" length=\"8\"/&gt;\n"
+#~ "\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Address\"&gt;\n"
+#~ "\n"
+#~ "    &lt;id name=\"id\"&gt;\n"
+#~ "        &lt;generator class=\"hilo\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "\n"
+#~ "    &lt;property name=\"address\" length=\"300\"/&gt;\n"
+#~ "    &lt;property name=\"zip\" length=\"5\"/&gt;\n"
+#~ "    &lt;property name=\"country\" length=\"25\"/&gt;\n"
+#~ "    &lt;many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/"
+#~ "&gt;\n"
+#~ "\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Account\"&gt;\n"
+#~ "    &lt;id name=\"accountId\" length=\"32\"&gt;\n"
+#~ "        &lt;generator class=\"uuid\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    \n"
+#~ "    &lt;many-to-one name=\"user\"\n"
+#~ "        column=\"userId\"\n"
+#~ "        property-ref=\"userId\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;property name=\"type\" not-null=\"true\"/&gt;\n"
+#~ "    \n"
+#~ "&lt;/class&gt;"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/example_parentchild.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/example_parentchild.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/example_parentchild.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,25 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-08-17 20:22+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.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 at redhat.com>\n"
+"Language-Team:  <en at 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
-#: example_parentchild.xml:29
 #, no-c-format
 msgid "Example: Parent/Child"
-msgstr "例:親/子供"
+msgstr "例: 親/子供"
 
 #. Tag: para
-#: example_parentchild.xml:31
-#, fuzzy, no-c-format
+#, 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 "
@@ -34,50 +35,46 @@
 "cascades</emphasis> to model a parent/child relationship efficiently and "
 "elegantly."
 msgstr ""
-"新規ユーザがHibernateを使ってまず最初に扱うモデルの一つに、親子型のモデル化が"
-"あります。 このモデル化には二つのアプローチが存在します。とりわけ新規ユーザに"
-"とって、 さまざまな理由から最も便利だと思われるアプローチは、<literal>親</"
-"literal> から <literal>子供</literal> への <literal>&lt;one-to-many&gt;</"
+"新規ユーザーが Hibernate を使ってまず最初に扱うモデルの一つに、親子型のモデル"
+"化があります。このモデル化には二つのアプローチが存在します。とりわけ新規ユー"
+"ザーにとって、さまざまな理由から最も便利だと思われるアプローチは、 <literal>"
+"親</literal> から <literal>子供</literal> への <literal>&lt;one-to-many&gt;</"
 "literal> 関連により <literal>親</literal> と <literal>子供</literal> の両方を"
-"エンティティクラスとしてモデリングする方法です (もう一つの方法は、<literal>"
+"エンティティクラスとしてモデリングする方法です(もう一つの方法は、 <literal>"
 "子供</literal> を <literal>&lt;composite-element&gt;</literal> として定義する"
-"ものです)。 これで(Hibernateにおける)一対多関連のデフォルトのセマンティク"
-"スが、通常の複合要素のマッピングよりも、 親子関係のセマンティクスから遠いこと"
-"がわかります。 それでは親子関係を効率的かつエレガントにモデリングするため"
-"に、 <emphasis>カスケード操作を使った双方向一対多関連</emphasis> の扱い方を説"
-"明します。これはまったく難しいものではありません。"
+"ものです)。これで( Hibernate における)一対多関連のデフォルトのセマンティク"
+"スが、通常の複合要素のマッピングよりも、親子関係のセマンティクスから遠いこと"
+"がわかります。それでは親子関係を効率的かつエレガントにモデリングするために、 "
+"<emphasis>カスケード操作を使った双方向一対多関連</emphasis> の扱い方を説明し"
+"ます。これはまったく難しいものではありません。"
 
 #. Tag: title
-#: example_parentchild.xml:45
 #, no-c-format
 msgid "A note about collections"
 msgstr "コレクションに関する注意"
 
 #. Tag: para
-#: example_parentchild.xml:47
-#, fuzzy, no-c-format
+#, 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のコレクションは自身のエンティティの論理的な部分と考えられ、 決して"
-"包含するエンティティのものではありません。これは致命的な違いです! これは以下"
+"Hibernate のコレクションは自身のエンティティの論理的な部分と考えられ、決して"
+"包含するエンティティのものではありません。これは致命的な違いです。これは以下"
 "のような結果になります:"
 
 #. Tag: para
-#: example_parentchild.xml:54
-#, fuzzy, no-c-format
+#, 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
-#: example_parentchild.xml:60
-#, fuzzy, no-c-format
+#, 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 "
@@ -85,14 +82,13 @@
 "value type instance to the collection will cause its state to be immediately "
 "persistent."
 msgstr ""
-"もしコレクションから削除されたオブジェクトが値型のインスタンス (例えばコンポ"
-"ジットエレメント)だったならば、そのオブジェクトは永続的ではなくなり、 その状"
-"態はデータベースから完全に削除されます。 同じように、値型のインスタンスをコレ"
+"もしコレクションから削除されたオブジェクトが値型のインスタンス(例えばコンポ"
+"ジットエレメント) だったならば、そのオブジェクトは永続的ではなくなり、その状"
+"態はデータベースから完全に削除されます。同じように、値型のインスタンスをコレ"
 "クションに追加すると、その状態はすぐに永続的になります。"
 
 #. Tag: para
-#: example_parentchild.xml:68
-#, fuzzy, no-c-format
+#, 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 "
@@ -100,15 +96,14 @@
 "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
-#: example_parentchild.xml:78
-#, fuzzy, no-c-format
+#, 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 "
@@ -117,19 +112,17 @@
 "bound to the life cycle of the parent."
 msgstr ""
 "その代わりに、デフォルトの動作では、エンティティをコレクションに追加すると単"
-"に二つのエンティティ間のリンクを作成し、 一方エンティティを削除するとリンクも"
-"削除します。これはすべてのケースにおいて非常に適切です。 これが適切でないのは"
+"に二つのエンティティ間のリンクを作成し、一方エンティティを削除するとリンクも"
+"削除します。これはすべてのケースにおいて非常に適切です。これが適切でないのは"
 "親/子関係の場合です。この場合子供の生存は親のライフサイクルに制限されるからで"
 "す。"
 
 #. Tag: title
-#: example_parentchild.xml:88
 #, no-c-format
 msgid "Bidirectional one-to-many"
 msgstr "双方向一対多"
 
 #. Tag: para
-#: example_parentchild.xml:90
 #, no-c-format
 msgid ""
 "Suppose we start with a simple <literal>&lt;one-to-many&gt;</literal> "
@@ -138,90 +131,52 @@
 "<literal>Parent</literal> から <literal>Child</literal> への単純な "
 "<literal>&lt;one-to-many&gt;</literal> 関連から始めるとします。"
 
-#. Tag: programlisting
-#: example_parentchild.xml:95
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:97
-#, fuzzy, no-c-format
 msgid "If we were to execute the following code:"
 msgstr "以下のコードを実行すると、"
 
-#. Tag: programlisting
-#: example_parentchild.xml:101
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = .....;\n"
-"Child c = new Child();\n"
-"p.getChildren().add(c);\n"
-"session.save(c);\n"
-"session.flush();]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:103
 #, no-c-format
 msgid "Hibernate would issue two SQL statements:"
-msgstr "Hibernateは二つのSQL文を発行します:"
+msgstr "Hibernate は二つの SQL 文を発行します:"
 
 #. Tag: para
-#: example_parentchild.xml:109
 #, no-c-format
 msgid ""
 "an <literal>INSERT</literal> to create the record for <literal>c</literal>"
 msgstr ""
-"<literal>c</literal>に対するレコードを生成する<literal>INSERT</literal>"
+"<literal>c</literal> に対するレコードを生成する <literal>INSERT</literal>"
 
 #. Tag: para
-#: example_parentchild.xml:112
 #, no-c-format
 msgid ""
 "an <literal>UPDATE</literal> to create the link from <literal>p</literal> to "
 "<literal>c</literal>"
 msgstr ""
-"<literal>p</literal>から<literal>c</literal>へのリンクを作成する"
+"<literal>p</literal> から <literal>c</literal> へのリンクを作成する "
 "<literal>UPDATE</literal>"
 
 #. Tag: para
-#: example_parentchild.xml:119
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is not only inefficient, but also violates any <literal>NOT NULL</"
 "literal> constraint on the <literal>parent_id</literal> column. You can fix "
 "the nullability constraint violation by specifying <literal>not-null=\"true"
 "\"</literal> in the collection mapping:"
 msgstr ""
-"これは非効率的なだけではなく、<literal>parent_id</literal> カラムにおいて "
-"<literal>NOT NULL</literal> 制約に違反します。 コレクションのマッピングで "
-"<literal>not-null=\"true\"</literal> と指定することで、null制約違反を解決する"
-"ことができます:"
+"これは非効率的なだけではなく、 <literal>parent_id</literal> カラムにおいて "
+"<literal>NOT NULL</literal> 制約に違反します。コレクションのマッピングで "
+"<literal>not-null=\"true\"</literal> と指定することで、 null 制約違反を解決す"
+"ることができます:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:125
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\">\n"
-"    <key column=\"parent_id\" not-null=\"true\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:127
 #, no-c-format
 msgid "However, this is not the recommended solution."
 msgstr "しかしこの解決策は推奨できません。"
 
 #. Tag: para
-#: example_parentchild.xml:130
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The underlying cause of this behavior is that the link (the foreign key "
 "<literal>parent_id</literal>) from <literal>p</literal> to <literal>c</"
@@ -229,24 +184,15 @@
 "object and is therefore not created in the <literal>INSERT</literal>. The "
 "solution is to make the link part of the <literal>Child</literal> mapping."
 msgstr ""
-"この動作の根本的な原因は、<literal>p</literal> から <literal>c</literal> への"
-"リンク (外部キー <literal>parent_id</literal>)は <literal>Child</literal> オ"
-"ブジェクトの状態の一部とは考えられず、 そのため <literal>INSERT</literal> に"
-"よってリンクが生成されないことです。 ですから、解決策はリンクをChildマッピン"
+"この動作の根本的な原因は、 <literal>p</literal> から <literal>c</literal> へ"
+"のリンク(外部キー <literal>parent_id</literal>) は <literal>Child</literal> "
+"オブジェクトの状態の一部とは考えられず、そのため <literal>INSERT</literal> に"
+"よってリンクが生成されないことです。ですから、解決策はリンクを Child マッピン"
 "グの一部にすることです。"
 
-#. Tag: programlisting
-#: example_parentchild.xml:137
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"parent\" column=\"parent_id\" not-null=\"true\"/"
-">]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:139
-#, fuzzy, no-c-format
-msgid ""
 "You also need to add the <literal>parent</literal> property to the "
 "<literal>Child</literal> class."
 msgstr ""
@@ -254,101 +200,51 @@
 "を追加する必要があります。)"
 
 #. Tag: para
-#: example_parentchild.xml:143
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now that the <literal>Child</literal> entity is managing the state of the "
 "link, we tell the collection not to update the link. We use the "
 "<literal>inverse</literal> attribute to do this:"
 msgstr ""
 "それでは <literal>Child</literal> エンティティがリンクの状態を制御するように"
-"なったので、 コレクションがリンクを更新しないようにしましょう。それには "
+"なったので、コレクションがリンクを更新しないようにしましょう。それには "
 "<literal>inverse</literal> 属性を使います。"
 
-#. Tag: programlisting
-#: example_parentchild.xml:148
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:150
-#, fuzzy, no-c-format
 msgid "The following code would be used to add a new <literal>Child</literal>:"
 msgstr ""
 "以下のコードを使えば、新しい <literal>Child</literal> を追加することができま"
 "す。"
 
-#. Tag: programlisting
-#: example_parentchild.xml:154
+#. Tag: para
 #, no-c-format
-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 ""
-
-#. Tag: para
-#: example_parentchild.xml:156
-#, fuzzy, no-c-format
 msgid "Only one SQL <literal>INSERT</literal> would now be issued."
 msgstr ""
-"これにより、SQLの <literal>INSERT</literal> 文が一つだけが発行されるようにな"
-"りました!"
+"これにより、 SQL の <literal>INSERT</literal> 文が一つだけが発行されるように"
+"なりました。"
 
 #. Tag: para
-#: example_parentchild.xml:160
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You could also create an <literal>addChild()</literal> method of "
 "<literal>Parent</literal>."
 msgstr ""
-"もう少し強化するには、<literal>Parent</literal> の <literal>addChild()</"
+"もう少し強化するには、 <literal>Parent</literal> の <literal>addChild()</"
 "literal> メソッドを作成します。"
 
-#. Tag: programlisting
-#: example_parentchild.xml:165
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[public void addChild(Child c) {\n"
-"    c.setParent(this);\n"
-"    children.add(c);\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:167
-#, fuzzy, no-c-format
 msgid "The code to add a <literal>Child</literal> looks like this:"
 msgstr "<literal>Child</literal> を追加するコードはこのようになります。"
 
-#. Tag: programlisting
-#: example_parentchild.xml:171
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: example_parentchild.xml:176
 #, no-c-format
 msgid "Cascading life cycle"
 msgstr "ライフサイクルのカスケード"
 
 #. Tag: para
-#: example_parentchild.xml:178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can address the frustrations of the explicit call to <literal>save()</"
 "literal> by using cascades."
@@ -356,144 +252,74 @@
 "明示的に <literal>save()</literal> をコールするのはまだ煩わしいものです。これ"
 "をカスケードを使って対処します。"
 
-#. Tag: programlisting
-#: example_parentchild.xml:183
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:185
-#, fuzzy, no-c-format
 msgid "This simplifies the code above to:"
 msgstr "これにより先ほどのコードをこのように単純化します"
 
-#. Tag: programlisting
-#: example_parentchild.xml:189
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-"Child c = new Child();\n"
-"p.addChild(c);\n"
-"session.flush();]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:191
-#, fuzzy, no-c-format
-msgid ""
 "Similarly, we do not need to iterate over the children when saving or "
 "deleting a <literal>Parent</literal>. The following removes <literal>p</"
 "literal> and all its children from the database."
 msgstr ""
 "同様に <literal>Parent</literal> を保存または削除するときに、子供を一つ一つ取"
-"り出して扱う必要はありません。 以下のコードは <literal>p</literal> を削除し、"
+"り出して扱う必要はありません。以下のコードは <literal>p</literal> を削除し、"
 "そしてデータベースからその子供をすべて削除します。"
 
-#. Tag: programlisting
-#: example_parentchild.xml:196
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-"session.delete(p);\n"
-"session.flush();]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:198
-#, fuzzy, no-c-format
 msgid "However, the following code:"
 msgstr "しかしこのコードは"
 
-#. Tag: programlisting
-#: example_parentchild.xml:202
+#. Tag: para
 #, no-c-format
 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 ""
-
-#. Tag: para
-#: example_parentchild.xml:204
-#, fuzzy, no-c-format
-msgid ""
 "will not remove <literal>c</literal> from the database. In this case, it "
 "will only remove the link to <literal>p</literal> and cause a <literal>NOT "
 "NULL</literal> constraint violation. You need to explicitly <literal>delete()"
 "</literal> the <literal>Child</literal>."
 msgstr ""
-"データベースから <literal>c</literal> を削除しません。<literal>p</literal> へ"
-"のリンクを削除する (そしてこのケースでは <literal>NOT NULL</literal> 制約違"
+"データベースから <literal>c</literal> を削除しません。 <literal>p</literal> "
+"へのリンクを削除する(そしてこのケースでは <literal>NOT NULL</literal> 制約違"
 "反を引き起こす)だけです。 <literal>Child</literal> の <literal>delete()</"
 "literal> を明示する必要があります。"
 
-#. Tag: programlisting
-#: example_parentchild.xml:210
+#. Tag: para
 #, no-c-format
 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 ""
-
-#. Tag: para
-#: example_parentchild.xml:212
-#, fuzzy, no-c-format
-msgid ""
 "In our case, a <literal>Child</literal> cannot exist without its parent. So "
 "if we remove a <literal>Child</literal> 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> が親なしでは存在できないよう"
-"になりました。 そのため、もしコレクションから <literal>Child</literal> を取り"
-"除く場合、これも削除したいです。 そのためには <literal>cascade=\"all-delete-"
-"orphan\"</literal> を使わなければなりません。"
+"になりました。そのため、もしコレクションから <literal>Child</literal> を取り"
+"除く場合、これも削除します。そのためには <literal>cascade=\"all-delete-orphan"
+"\"</literal> を使わなければなりません。"
 
-#. Tag: programlisting
-#: example_parentchild.xml:218
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all-delete-orphan"
-"\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:220
-#, fuzzy, no-c-format
-msgid ""
 "Even though the collection mapping specifies <literal>inverse=\"true\"</"
 "literal>, cascades are still processed by iterating the collection elements. "
 "If you need an object be saved, deleted or updated by cascade, you must add "
 "it to the collection. It is not enough to simply call <literal>setParent()</"
 "literal>."
 msgstr ""
-"注意:コレクションのマッピングで <literal>inverse=\"true\"</literal> と指定し"
-"ても、 コレクションの要素のイテレーションによって、依然カスケードが実行されま"
-"す。 そのためもしカスケードでオブジェクトをセーブ、削除、更新する必要があるな"
-"ら、 それをコレクションに追加しなければなりません。単に <literal>setParent()"
+"注記:コレクションのマッピングで <literal>inverse=\"true\"</literal> と指定し"
+"ても、コレクションの要素のイテレーションによって、依然カスケードが実行されま"
+"す。そのため、もしカスケードでオブジェクトをセーブ、削除、更新する必要がある"
+"なら、それをコレクションに追加しなければなりません。単に <literal>setParent()"
 "</literal> を呼ぶだけでは不十分です。"
 
 #. Tag: title
-#: example_parentchild.xml:230
 #, no-c-format
 msgid "Cascades and <literal>unsaved-value</literal>"
-msgstr "カスケードと <literal>unsaved-value</literal>"
+msgstr "カスケードと unsaved-value"
 
 #. Tag: para
-#: example_parentchild.xml:232
 #, fuzzy, no-c-format
 msgid ""
 "Suppose we loaded up a <literal>Parent</literal> in one <literal>Session</"
@@ -506,48 +332,34 @@
 "literal> have generated identifier properties of type <literal>Long</"
 "literal>. Hibernate will use the identifier and version/timestamp property "
 "value to determine which of the children are new. (See <xref linkend="
-"\"objectstate-saveorupdate\"/>.) <emphasis>In Hibernate3, it is no longer "
+"\"objectstate-saveorupdate\" />.) <emphasis>In Hibernate3, it is no longer "
 "necessary to specify an <literal>unsaved-value</literal> explicitly.</"
 "emphasis>"
 msgstr ""
-"<literal>Parent</literal> が、ある <literal>Session</literal> でロードされ、"
-"UIのアクションで変更が加えられ、 <literal>update()</literal> を呼んでこの変更"
-"を新しいセッションで永続化したいとします。 <literal>Parent</literal> が子供の"
-"コレクションを持ち、カスケード更新が有効になっているため、 Hibernateはどの子"
-"供が新しくインスタンス化されたか、どれがデータベースの既存の行に相当するのか"
-"を知る必要があります。 <literal>Parent</literal> と <literal>Child</literal> "
-"の両方が <literal>java.lang.Long</literal> 型の識別プロパティを生成したとしま"
-"しょう。 Hibernateはどの子供が新しいものかを決定するために識別プロパティの値"
-"を使います(versionやtimestampプロパティも使えます。 <xref linkend="
-"\"manipulatingdata-updating-detached\"/> 参照)。Hibernate3になって、 明示的"
-"に <literal>unsaved-value</literal> を指定する必要はなくなりました。"
+"<literal>Parent</literal> が、ある <literal>Session</literal> でロードされ、 "
+"UI のアクションで変更が加えられ、 <literal>update()</literal> を呼んでこの変"
+"更を新しいセッションで永続化したいとします。 <literal>Parent</literal> が子供"
+"のコレクションを持ち、カスケード更新が有効になっているため、 Hibernate はどの"
+"子供が新しくインスタンス化されたか、どれがデータベースの既存の行に相当するの"
+"かを知る必要があります。 <literal>Parent</literal> と <literal>Child</"
+"literal> の両方が <literal>Long</literal> 型の識別プロパティを生成したとしま"
+"しょう。 Hibernate はどの子供が新しいものかを決定するために識別プロパティの値"
+"を使います (<xref linkend=\"objectstate-saveorupdate\"/> 参照)。 "
+"<emphasis>Hibernate3 になって、明示的に <literal>unsaved-value</literal> を指"
+"定する必要はなくなりました。</emphasis>"
 
 #. Tag: para
-#: example_parentchild.xml:244
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following code will update <literal>parent</literal> and <literal>child</"
 "literal> and insert <literal>newChild</literal>:"
 msgstr ""
 "以下のコードは <literal>parent</literal> と <literal>child</literal> を更新"
-"し、<literal>newChild</literal> を挿入します。"
+"し、 <literal>newChild</literal> を挿入します。"
 
-#. Tag: programlisting
-#: example_parentchild.xml:249
+#. Tag: para
 #, no-c-format
 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 ""
-
-#. Tag: para
-#: example_parentchild.xml:251
-#, fuzzy, 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 "
@@ -557,34 +369,31 @@
 "cache or, worst case, the database, to see if the row exists."
 msgstr ""
 "これらは生成された識別子の場合には非常に良いのですが、割り当てられた識別子と"
-"複合識別子の場合はどうでしょうか? これはHibernateが、(ユーザにより割り当て"
-"られた識別子を持つ)新しくインスタンス化されたオブジェクトと、 以前のSession"
-"でロードされたオブジェクトを区別できないため、より難しいです。 この場合、"
-"Hibernateはタイムスタンプかバージョンのプロパティのどちらかを使うか、二次"
-"キャッシュに問い合わせます。 最悪の場合、行が存在するかどうかデータベースを見"
-"ます。"
+"複合識別子の場合はどうでしょうか?これは Hibernate が、(ユーザーにより割り当"
+"てられた識別子を持つ)新しくインスタンス化されたオブジェクトと、以前の "
+"Session でロードされたオブジェクトを区別できないため、より難しいです。この場"
+"合、 Hibernate はタイムスタンプかバージョンのプロパティのどちらかを使うか、二"
+"次キャッシュに問い合わせます。最悪の場合、行が存在するかどうかデータベースを"
+"見ます。"
 
 #. Tag: title
-#: example_parentchild.xml:263
 #, no-c-format
 msgid "Conclusion"
 msgstr "結論"
 
 #. Tag: para
-#: example_parentchild.xml:265
-#, fuzzy, no-c-format
+#, 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アプ"
+"れません。しかし実際は、すべて非常に良く動作します。ほとんどの Hibernate アプ"
 "リケーションでは、多くの場面で親子パターンを使用します。"
 
 #. Tag: para
-#: example_parentchild.xml:270
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We mentioned an alternative in the first paragraph. None of the above issues "
 "exist in the case of <literal>&lt;composite-element&gt;</literal> mappings, "
@@ -594,8 +403,200 @@
 "of any entity other than the unique parent."
 msgstr ""
 "最初の段落で代替方法について触れました。上記のような問題は <literal>&lt;"
-"composite-element&gt;</literal> マッピングの場合は存在せず、 にもかかわらずそ"
-"れは確かに親子関係のセマンティクスを持ちます。 しかし残念ながら、複合要素クラ"
-"スには二つの大きな制限があります: 1つは複合要素はコレクションを持つことがで"
-"きないことです。もうひとつは、 ユニークな親ではないエンティティの子供となるべ"
+"composite-element&gt;</literal> マッピングの場合は存在せず、にもかかわらずそ"
+"れは確かに親子関係のセマンティクスを持ちます。しかし残念ながら、複合要素クラ"
+"スには2つの大きな制限があります: 1つは複合要素はコレクションを持つことがで"
+"きないことです。もうひとつは、ユニークな親ではないエンティティの子供となるべ"
 "きではないということです"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<set name=\"children\">\n"
+#~ "    <key column=\"parent_id\"/>\n"
+#~ "    <one-to-many class=\"Child\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "&lt;set name=\"children\"&gt;\n"
+#~ "    &lt;key column=\"parent_id\"/&gt;\n"
+#~ "    &lt;one-to-many class=\"Child\"/&gt;\n"
+#~ "&lt;/set&gt;"
+
+#, 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[<set name=\"children\">\n"
+#~ "    <key column=\"parent_id\" not-null=\"true\"/>\n"
+#~ "    <one-to-many class=\"Child\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "&lt;set name=\"children\"&gt;\n"
+#~ "    &lt;key column=\"parent_id\" not-null=\"true\"/&gt;\n"
+#~ "    &lt;one-to-many class=\"Child\"/&gt;\n"
+#~ "&lt;/set&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"parent\" column=\"parent_id\" not-null=\"true"
+#~ "\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"parent\" column=\"parent_id\" not-null=\"true\"/"
+#~ "&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<set name=\"children\" inverse=\"true\">\n"
+#~ "    <key column=\"parent_id\"/>\n"
+#~ "    <one-to-many class=\"Child\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "&lt;set name=\"children\" inverse=\"true\"&gt;\n"
+#~ "    &lt;key column=\"parent_id\"/&gt;\n"
+#~ "    &lt;one-to-many class=\"Child\"/&gt;\n"
+#~ "&lt;/set&gt;"
+
+#, 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[<set name=\"children\" inverse=\"true\" cascade=\"all\">\n"
+#~ "    <key column=\"parent_id\"/>\n"
+#~ "    <one-to-many class=\"Child\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "&lt;set name=\"children\" inverse=\"true\" cascade=\"all\"&gt;\n"
+#~ "    &lt;key column=\"parent_id\"/&gt;\n"
+#~ "    &lt;one-to-many class=\"Child\"/&gt;\n"
+#~ "&lt;/set&gt;"
+
+#, 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[<set name=\"children\" inverse=\"true\" cascade=\"all-delete-"
+#~ "orphan\">\n"
+#~ "    <key column=\"parent_id\"/>\n"
+#~ "    <one-to-many class=\"Child\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "&lt;set name=\"children\" inverse=\"true\" cascade=\"all-delete-orphan"
+#~ "\"&gt;\n"
+#~ "    &lt;key column=\"parent_id\"/&gt;\n"
+#~ "    &lt;one-to-many class=\"Child\"/&gt;\n"
+#~ "&lt;/set&gt;"
+
+#, 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();"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/example_weblog.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/example_weblog.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/example_weblog.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,484 +1,863 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2010-01-20 15:34+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: example_weblog.xml:29
 #, no-c-format
 msgid "Example: Weblog Application"
-msgstr "例: Weblogアプリケーション"
+msgstr "例: Weblog アプリケーション"
 
 #. Tag: title
-#: example_weblog.xml:32
 #, no-c-format
 msgid "Persistent Classes"
 msgstr "永続クラス"
 
 #. Tag: para
-#: example_weblog.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The persistent classes here represent a weblog and an item posted in a "
 "weblog. They are to be modelled as a standard parent/child relationship, but "
 "we will use an ordered bag, instead of a set:"
 msgstr ""
-"永続クラスがウェブログと、ウェブログに掲示された項目を表しています。 それらは"
-"通常の親子関係としてモデリングされますが、 setではなく順序を持ったbagを使用す"
-"ることにします。"
+"永続クラスがウェブログと、ウェブログに掲示された項目を表しています。それらは"
+"通常の親子関係としてモデリングされますが、 set ではなく順序を持った bag を使"
+"用することにします。"
 
-#. Tag: programlisting
-#: example_weblog.xml:40
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.util.List;\n"
-"\n"
-"public class Blog {\n"
-"    private Long _id;\n"
-"    private String _name;\n"
-"    private List _items;\n"
-"\n"
-"    public Long getId() {\n"
-"        return _id;\n"
-"    }\n"
-"    public List getItems() {\n"
-"        return _items;\n"
-"    }\n"
-"    public String getName() {\n"
-"        return _name;\n"
-"    }\n"
-"    public void setId(Long long1) {\n"
-"        _id = long1;\n"
-"    }\n"
-"    public void setItems(List list) {\n"
-"        _items = list;\n"
-"    }\n"
-"    public void setName(String string) {\n"
-"        _name = string;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: example_weblog.xml:42
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.text.DateFormat;\n"
-"import java.util.Calendar;\n"
-"\n"
-"public class BlogItem {\n"
-"    private Long _id;\n"
-"    private Calendar _datetime;\n"
-"    private String _text;\n"
-"    private String _title;\n"
-"    private Blog _blog;\n"
-"\n"
-"    public Blog getBlog() {\n"
-"        return _blog;\n"
-"    }\n"
-"    public Calendar getDatetime() {\n"
-"        return _datetime;\n"
-"    }\n"
-"    public Long getId() {\n"
-"        return _id;\n"
-"    }\n"
-"    public String getText() {\n"
-"        return _text;\n"
-"    }\n"
-"    public String getTitle() {\n"
-"        return _title;\n"
-"    }\n"
-"    public void setBlog(Blog blog) {\n"
-"        _blog = blog;\n"
-"    }\n"
-"    public void setDatetime(Calendar calendar) {\n"
-"        _datetime = calendar;\n"
-"    }\n"
-"    public void setId(Long long1) {\n"
-"        _id = long1;\n"
-"    }\n"
-"    public void setText(String string) {\n"
-"        _text = string;\n"
-"    }\n"
-"    public void setTitle(String string) {\n"
-"        _title = string;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: example_weblog.xml:47
 #, no-c-format
 msgid "Hibernate Mappings"
-msgstr "Hibernateのマッピング"
+msgstr "Hibernate のマッピング"
 
 #. Tag: para
-#: example_weblog.xml:49
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The XML mappings are now straightforward. For example:"
-msgstr "XMLマッピングは、今ではとても簡単なはずです。"
+msgstr "XML マッピングは、今ではとても簡単なはずです。"
 
-#. Tag: programlisting
-#: example_weblog.xml:53
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"    <class\n"
-"        name=\"Blog\"\n"
-"        table=\"BLOGS\">\n"
-"\n"
-"        <id\n"
-"            name=\"id\"\n"
-"            column=\"BLOG_ID\">\n"
-"\n"
-"            <generator class=\"native\"/>\n"
-"\n"
-"        </id>\n"
-"\n"
-"        <property\n"
-"            name=\"name\"\n"
-"            column=\"NAME\"\n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"\n"
-"        <bag\n"
-"            name=\"items\"\n"
-"            inverse=\"true\"\n"
-"            order-by=\"DATE_TIME\"\n"
-"            cascade=\"all\">\n"
-"\n"
-"            <key column=\"BLOG_ID\"/>\n"
-"            <one-to-many class=\"BlogItem\"/>\n"
-"\n"
-"        </bag>\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: example_weblog.xml:55
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"    <class\n"
-"        name=\"BlogItem\"\n"
-"        table=\"BLOG_ITEMS\"\n"
-"        dynamic-update=\"true\">\n"
-"\n"
-"        <id\n"
-"            name=\"id\"\n"
-"            column=\"BLOG_ITEM_ID\">\n"
-"\n"
-"            <generator class=\"native\"/>\n"
-"\n"
-"        </id>\n"
-"\n"
-"        <property\n"
-"            name=\"title\"\n"
-"            column=\"TITLE\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <property\n"
-"            name=\"text\"\n"
-"            column=\"TEXT\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <property\n"
-"            name=\"datetime\"\n"
-"            column=\"DATE_TIME\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <many-to-one\n"
-"            name=\"blog\"\n"
-"            column=\"BLOG_ID\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_weblog.xml:60
 #, no-c-format
 msgid "Hibernate Code"
-msgstr "Hibernateのコード"
+msgstr "Hibernate のコード"
 
 #. Tag: para
-#: example_weblog.xml:62
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following class demonstrates some of the kinds of things we can do with "
 "these classes using Hibernate:"
 msgstr ""
-"以下のクラスは、 Hibernateでこれらのクラスを使ってできることをいくつか示して"
-"います。"
+"以下のクラスは、 Hibernate でこれらのクラスを使ってできるいくつかのことを示し"
+"ています。"
 
-#. Tag: programlisting
-#: example_weblog.xml:67
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.util.ArrayList;\n"
-"import java.util.Calendar;\n"
-"import java.util.Iterator;\n"
-"import java.util.List;\n"
-"\n"
-"import org.hibernate.HibernateException;\n"
-"import org.hibernate.Query;\n"
-"import org.hibernate.Session;\n"
-"import org.hibernate.SessionFactory;\n"
-"import org.hibernate.Transaction;\n"
-"import org.hibernate.cfg.Configuration;\n"
-"import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
-"\n"
-"public class BlogMain {\n"
-"    \n"
-"    private SessionFactory _sessions;\n"
-"    \n"
-"    public void configure() throws HibernateException {\n"
-"        _sessions = new Configuration()\n"
-"            .addClass(Blog.class)\n"
-"            .addClass(BlogItem.class)\n"
-"            .buildSessionFactory();\n"
-"    }\n"
-"    \n"
-"    public void exportTables() throws HibernateException {\n"
-"        Configuration cfg = new Configuration()\n"
-"            .addClass(Blog.class)\n"
-"            .addClass(BlogItem.class);\n"
-"        new SchemaExport(cfg).create(true, true);\n"
-"    }\n"
-"    \n"
-"    public Blog createBlog(String name) throws HibernateException {\n"
-"        \n"
-"        Blog blog = new Blog();\n"
-"        blog.setName(name);\n"
-"        blog.setItems( new ArrayList() );\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.persist(blog);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return blog;\n"
-"    }\n"
-"    \n"
-"    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
-"                        throws HibernateException {\n"
-"        \n"
-"        BlogItem item = new BlogItem();\n"
-"        item.setTitle(title);\n"
-"        item.setText(text);\n"
-"        item.setBlog(blog);\n"
-"        item.setDatetime( Calendar.getInstance() );\n"
-"        blog.getItems().add(item);\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.update(blog);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return item;\n"
-"    }\n"
-"    \n"
-"    public BlogItem createBlogItem(Long blogid, String title, String text)\n"
-"                        throws HibernateException {\n"
-"        \n"
-"        BlogItem item = new BlogItem();\n"
-"        item.setTitle(title);\n"
-"        item.setText(text);\n"
-"        item.setDatetime( Calendar.getInstance() );\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
-"            item.setBlog(blog);\n"
-"            blog.getItems().add(item);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return item;\n"
-"    }\n"
-"    \n"
-"    public void updateBlogItem(BlogItem item, String text)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        item.setText(text);\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.update(item);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"    }\n"
-"    \n"
-"    public void updateBlogItem(Long itemid, String text)\n"
-"                    throws HibernateException {\n"
-"    \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            BlogItem item = (BlogItem) session.load(BlogItem.class, "
-"itemid);\n"
-"            item.setText(text);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"    }\n"
-"    \n"
-"    public List listAllBlogNamesAndItemCounts(int max)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        List result = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"select blog.id, blog.name, count(blogItem) \" +\n"
-"                \"from Blog as blog \" +\n"
-"                \"left outer join blog.items as blogItem \" +\n"
-"                \"group by blog.name, blog.id \" +\n"
-"                \"order by max(blogItem.datetime)\"\n"
-"            );\n"
-"            q.setMaxResults(max);\n"
-"            result = q.list();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return result;\n"
-"    }\n"
-"    \n"
-"    public Blog getBlogAndAllItems(Long blogid)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        Blog blog = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"from Blog as blog \" +\n"
-"                \"left outer join fetch blog.items \" +\n"
-"                \"where blog.id = :blogid\"\n"
-"            );\n"
-"            q.setParameter(\"blogid\", blogid);\n"
-"            blog  = (Blog) q.uniqueResult();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return blog;\n"
-"    }\n"
-"    \n"
-"    public List listBlogsAndRecentItems() throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        List result = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"from Blog as blog \" +\n"
-"                \"inner join blog.items as blogItem \" +\n"
-"                \"where blogItem.datetime > :minDate\"\n"
-"            );\n"
-"\n"
-"            Calendar cal = Calendar.getInstance();\n"
-"            cal.roll(Calendar.MONTH, false);\n"
-"            q.setCalendar(\"minDate\", cal);\n"
-"            \n"
-"            result = q.list();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return result;\n"
-"    }\n"
-"}]]>"
-msgstr ""
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "public class Blog {\n"
+#~ "    private Long _id;\n"
+#~ "    private String _name;\n"
+#~ "    private List _items;\n"
+#~ "\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public List getItems() {\n"
+#~ "        return _items;\n"
+#~ "    }\n"
+#~ "    public String getName() {\n"
+#~ "        return _name;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setItems(List list) {\n"
+#~ "        _items = list;\n"
+#~ "    }\n"
+#~ "    public void setName(String string) {\n"
+#~ "        _name = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "package eg;\n"
+#~ "\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "public class Blog {\n"
+#~ "    private Long _id;\n"
+#~ "    private String _name;\n"
+#~ "    private List _items;\n"
+#~ "\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public List getItems() {\n"
+#~ "        return _items;\n"
+#~ "    }\n"
+#~ "    public String getName() {\n"
+#~ "        return _name;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setItems(List list) {\n"
+#~ "        _items = list;\n"
+#~ "    }\n"
+#~ "    public void setName(String string) {\n"
+#~ "        _name = string;\n"
+#~ "    }\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.text.DateFormat;\n"
+#~ "import java.util.Calendar;\n"
+#~ "\n"
+#~ "public class BlogItem {\n"
+#~ "    private Long _id;\n"
+#~ "    private Calendar _datetime;\n"
+#~ "    private String _text;\n"
+#~ "    private String _title;\n"
+#~ "    private Blog _blog;\n"
+#~ "\n"
+#~ "    public Blog getBlog() {\n"
+#~ "        return _blog;\n"
+#~ "    }\n"
+#~ "    public Calendar getDatetime() {\n"
+#~ "        return _datetime;\n"
+#~ "    }\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public String getText() {\n"
+#~ "        return _text;\n"
+#~ "    }\n"
+#~ "    public String getTitle() {\n"
+#~ "        return _title;\n"
+#~ "    }\n"
+#~ "    public void setBlog(Blog blog) {\n"
+#~ "        _blog = blog;\n"
+#~ "    }\n"
+#~ "    public void setDatetime(Calendar calendar) {\n"
+#~ "        _datetime = calendar;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setText(String string) {\n"
+#~ "        _text = string;\n"
+#~ "    }\n"
+#~ "    public void setTitle(String string) {\n"
+#~ "        _title = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "package eg;\n"
+#~ "\n"
+#~ "import java.text.DateFormat;\n"
+#~ "import java.util.Calendar;\n"
+#~ "\n"
+#~ "public class BlogItem {\n"
+#~ "    private Long _id;\n"
+#~ "    private Calendar _datetime;\n"
+#~ "    private String _text;\n"
+#~ "    private String _title;\n"
+#~ "    private Blog _blog;\n"
+#~ "\n"
+#~ "    public Blog getBlog() {\n"
+#~ "        return _blog;\n"
+#~ "    }\n"
+#~ "    public Calendar getDatetime() {\n"
+#~ "        return _datetime;\n"
+#~ "    }\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public String getText() {\n"
+#~ "        return _text;\n"
+#~ "    }\n"
+#~ "    public String getTitle() {\n"
+#~ "        return _title;\n"
+#~ "    }\n"
+#~ "    public void setBlog(Blog blog) {\n"
+#~ "        _blog = blog;\n"
+#~ "    }\n"
+#~ "    public void setDatetime(Calendar calendar) {\n"
+#~ "        _datetime = calendar;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setText(String string) {\n"
+#~ "        _text = string;\n"
+#~ "    }\n"
+#~ "    public void setTitle(String string) {\n"
+#~ "        _title = string;\n"
+#~ "    }\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"Blog\"\n"
+#~ "        table=\"BLOGS\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"name\"\n"
+#~ "            column=\"NAME\"\n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "\n"
+#~ "        <bag\n"
+#~ "            name=\"items\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            order-by=\"DATE_TIME\"\n"
+#~ "            cascade=\"all\">\n"
+#~ "\n"
+#~ "            <key column=\"BLOG_ID\"/>\n"
+#~ "            <one-to-many class=\"BlogItem\"/>\n"
+#~ "\n"
+#~ "        </bag>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;?xml version=\"1.0\"?&gt;\n"
+#~ "&lt;!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\"&gt;\n"
+#~ "\n"
+#~ "&lt;hibernate-mapping package=\"eg\"&gt;\n"
+#~ "\n"
+#~ "    &lt;class\n"
+#~ "        name=\"Blog\"\n"
+#~ "        table=\"BLOGS\"&gt;\n"
+#~ "\n"
+#~ "        &lt;id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ID\"&gt;\n"
+#~ "\n"
+#~ "            &lt;generator class=\"native\"/&gt;\n"
+#~ "\n"
+#~ "        &lt;/id&gt;\n"
+#~ "\n"
+#~ "        &lt;property\n"
+#~ "            name=\"name\"\n"
+#~ "            column=\"NAME\"\n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/&gt;\n"
+#~ "\n"
+#~ "        &lt;bag\n"
+#~ "            name=\"items\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            order-by=\"DATE_TIME\"\n"
+#~ "            cascade=\"all\"&gt;\n"
+#~ "\n"
+#~ "            &lt;key column=\"BLOG_ID\"/&gt;\n"
+#~ "            &lt;one-to-many class=\"BlogItem\"/&gt;\n"
+#~ "\n"
+#~ "        &lt;/bag&gt;\n"
+#~ "\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"BlogItem\"\n"
+#~ "        table=\"BLOG_ITEMS\"\n"
+#~ "        dynamic-update=\"true\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ITEM_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"title\"\n"
+#~ "            column=\"TITLE\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"text\"\n"
+#~ "            column=\"TEXT\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"datetime\"\n"
+#~ "            column=\"DATE_TIME\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <many-to-one\n"
+#~ "            name=\"blog\"\n"
+#~ "            column=\"BLOG_ID\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;?xml version=\"1.0\"?&gt;\n"
+#~ "&lt;!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\"&gt;\n"
+#~ "\n"
+#~ "&lt;hibernate-mapping package=\"eg\"&gt;\n"
+#~ "\n"
+#~ "    &lt;class\n"
+#~ "        name=\"BlogItem\"\n"
+#~ "        table=\"BLOG_ITEMS\"\n"
+#~ "        dynamic-update=\"true\"&gt;\n"
+#~ "\n"
+#~ "        &lt;id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ITEM_ID\"&gt;\n"
+#~ "\n"
+#~ "            &lt;generator class=\"native\"/&gt;\n"
+#~ "\n"
+#~ "        &lt;/id&gt;\n"
+#~ "\n"
+#~ "        &lt;property\n"
+#~ "            name=\"title\"\n"
+#~ "            column=\"TITLE\"\n"
+#~ "            not-null=\"true\"/&gt;\n"
+#~ "\n"
+#~ "        &lt;property\n"
+#~ "            name=\"text\"\n"
+#~ "            column=\"TEXT\"\n"
+#~ "            not-null=\"true\"/&gt;\n"
+#~ "\n"
+#~ "        &lt;property\n"
+#~ "            name=\"datetime\"\n"
+#~ "            column=\"DATE_TIME\"\n"
+#~ "            not-null=\"true\"/&gt;\n"
+#~ "\n"
+#~ "        &lt;many-to-one\n"
+#~ "            name=\"blog\"\n"
+#~ "            column=\"BLOG_ID\"\n"
+#~ "            not-null=\"true\"/&gt;\n"
+#~ "\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.ArrayList;\n"
+#~ "import java.util.Calendar;\n"
+#~ "import java.util.Iterator;\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "import org.hibernate.HibernateException;\n"
+#~ "import org.hibernate.Query;\n"
+#~ "import org.hibernate.Session;\n"
+#~ "import org.hibernate.SessionFactory;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.cfg.Configuration;\n"
+#~ "import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
+#~ "\n"
+#~ "public class BlogMain {\n"
+#~ "    \n"
+#~ "    private SessionFactory _sessions;\n"
+#~ "    \n"
+#~ "    public void configure() throws HibernateException {\n"
+#~ "        _sessions = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class)\n"
+#~ "            .buildSessionFactory();\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void exportTables() throws HibernateException {\n"
+#~ "        Configuration cfg = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class);\n"
+#~ "        new SchemaExport(cfg).create(true, true);\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog createBlog(String name) throws HibernateException {\n"
+#~ "        \n"
+#~ "        Blog blog = new Blog();\n"
+#~ "        blog.setName(name);\n"
+#~ "        blog.setItems( new ArrayList() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.persist(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setBlog(blog);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        blog.getItems().add(item);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Long blogid, String title, String "
+#~ "text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
+#~ "            item.setBlog(blog);\n"
+#~ "            blog.getItems().add(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(BlogItem item, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        item.setText(text);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(Long itemid, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "    \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            BlogItem item = (BlogItem) session.load(BlogItem.class, "
+#~ "itemid);\n"
+#~ "            item.setText(text);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listAllBlogNamesAndItemCounts(int max)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"select blog.id, blog.name, count(blogItem) \" +\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join blog.items as blogItem \" +\n"
+#~ "                \"group by blog.name, blog.id \" +\n"
+#~ "                \"order by max(blogItem.datetime)\"\n"
+#~ "            );\n"
+#~ "            q.setMaxResults(max);\n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog getBlogAndAllItems(Long blogid)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        Blog blog = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join fetch blog.items \" +\n"
+#~ "                \"where blog.id = :blogid\"\n"
+#~ "            );\n"
+#~ "            q.setParameter(\"blogid\", blogid);\n"
+#~ "            blog  = (Blog) q.uniqueResult();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listBlogsAndRecentItems() throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"inner join blog.items as blogItem \" +\n"
+#~ "                \"where blogItem.datetime > :minDate\"\n"
+#~ "            );\n"
+#~ "\n"
+#~ "            Calendar cal = Calendar.getInstance();\n"
+#~ "            cal.roll(Calendar.MONTH, false);\n"
+#~ "            q.setCalendar(\"minDate\", cal);\n"
+#~ "            \n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "package eg;\n"
+#~ "\n"
+#~ "import java.util.ArrayList;\n"
+#~ "import java.util.Calendar;\n"
+#~ "import java.util.Iterator;\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "import org.hibernate.HibernateException;\n"
+#~ "import org.hibernate.Query;\n"
+#~ "import org.hibernate.Session;\n"
+#~ "import org.hibernate.SessionFactory;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.cfg.Configuration;\n"
+#~ "import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
+#~ "\n"
+#~ "public class BlogMain {\n"
+#~ "    \n"
+#~ "    private SessionFactory _sessions;\n"
+#~ "    \n"
+#~ "    public void configure() throws HibernateException {\n"
+#~ "        _sessions = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class)\n"
+#~ "            .buildSessionFactory();\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void exportTables() throws HibernateException {\n"
+#~ "        Configuration cfg = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class);\n"
+#~ "        new SchemaExport(cfg).create(true, true);\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog createBlog(String name) throws HibernateException {\n"
+#~ "        \n"
+#~ "        Blog blog = new Blog();\n"
+#~ "        blog.setName(name);\n"
+#~ "        blog.setItems( new ArrayList() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.persist(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setBlog(blog);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        blog.getItems().add(item);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Long blogid, String title, String "
+#~ "text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
+#~ "            item.setBlog(blog);\n"
+#~ "            blog.getItems().add(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(BlogItem item, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        item.setText(text);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(Long itemid, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "    \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            BlogItem item = (BlogItem) session.load(BlogItem.class, "
+#~ "itemid);\n"
+#~ "            item.setText(text);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listAllBlogNamesAndItemCounts(int max)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"select blog.id, blog.name, count(blogItem) \" +\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join blog.items as blogItem \" +\n"
+#~ "                \"group by blog.name, blog.id \" +\n"
+#~ "                \"order by max(blogItem.datetime)\"\n"
+#~ "            );\n"
+#~ "            q.setMaxResults(max);\n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog getBlogAndAllItems(Long blogid)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        Blog blog = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join fetch blog.items \" +\n"
+#~ "                \"where blog.id = :blogid\"\n"
+#~ "            );\n"
+#~ "            q.setParameter(\"blogid\", blogid);\n"
+#~ "            blog  = (Blog) q.uniqueResult();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listBlogsAndRecentItems() throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"inner join blog.items as blogItem \" +\n"
+#~ "                \"where blogItem.datetime &gt; :minDate\"\n"
+#~ "            );\n"
+#~ "\n"
+#~ "            Calendar cal = Calendar.getInstance();\n"
+#~ "            cal.roll(Calendar.MONTH, false);\n"
+#~ "            q.setCalendar(\"minDate\", cal);\n"
+#~ "            \n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "}"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/filters.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/filters.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/filters.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,44 +1,43 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2010-01-18 15:28+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: filters.xml:29
 #, no-c-format
 msgid "Filtering data"
 msgstr "データのフィルタリング"
 
 #. Tag: para
-#: filters.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 provides an innovative new approach to handling data with "
 "\"visibility\" rules. A <emphasis>Hibernate filter</emphasis> is a global, "
 "named, parameterized filter that can be enabled or disabled for a particular "
 "Hibernate session."
 msgstr ""
-"Hibernate3では「可視性」ルールに基づいてデータを扱うための画期的な方法を用意"
+"Hibernate3 では「可視性」ルールに基づいてデータを扱うための画期的な方法を用意"
 "しています。 <emphasis>Hibernate filter</emphasis> はグローバルで、名前付き"
-"で、パラメータ化されたフィルタです。 これはHibernateセッションごとに有効無効"
+"で、パラメータ化されたフィルタです。これは Hibernate セッションごとに有効無効"
 "を切り替えられます。"
 
 #. Tag: title
-#: filters.xml:38
 #, no-c-format
 msgid "Hibernate filters"
-msgstr "Hibernateのフィルタ"
+msgstr "Hibernate のフィルタ"
 
 #. Tag: para
-#: filters.xml:40
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 has the ability to pre-define filter criteria and attach those "
 "filters at both a class level and a collection level. A filter criteria "
@@ -49,17 +48,15 @@
 "parameter values should be. Filters can be used like database views, but "
 "they are parameterized inside the application."
 msgstr ""
-"Hibernate3はフィルタクライテリアをあらかじめ定義し、 これらのフィルタをクラス"
-"やコレクションレベルに加える機能を加えました。 フィルタクライテリアは制約節を"
-"定義する機能です。 これらのフィルタ条件はパラメータ化できるということを除"
-"き、 クラスやさまざまなコレクション要素で利用可能な「where」句に非常によく似て"
-"います。 アプリケーションは、与えられたフィルタを可能にすべきか、 そしてその"
-"パラメータ値を何にすべきかを実行時に決定することができます。 フィルタはデータ"
-"ベースビューのように使用されますが、アプリケーション内ではパラメータ化されま"
-"す。"
+"Hibernate3 はフィルタクライテリアをあらかじめ定義し、これらのフィルタをクラス"
+"やコレクションレベルに加える機能を加えました。フィルタクライテリアは制約節を"
+"定義する機能です。これらのフィルタ条件はパラメータ化できるということを除き、"
+"クラスやさまざまなコレクション要素で利用可能な 「where」 句に非常によく似ていま"
+"す。アプリケーションは、与えられたフィルタを可能にすべきか、そしてそのパラ"
+"メータ値を何にすべきかを実行時に決定することができます。フィルタはデータベー"
+"スビューのように使用されますが、アプリケーション内ではパラメータ化されます。"
 
 #. Tag: para
-#: filters.xml:50
 #, no-c-format
 msgid ""
 "In order to use filters, they must first be defined and then attached to the "
@@ -68,60 +65,26 @@
 "&gt;</literal> element:"
 msgstr ""
 "フィルタを使うためにはまず、適切なマッピング要素に定義、追加しなくてはなりま"
-"せん。 フィルタを定義するためには、 <literal>&lt;hibernate-mapping/&gt;</"
-"literal> 要素内で <literal>&lt;filter-def/&gt;</literal> 要素を使用します。:"
+"せん。フィルタを定義するためには、 <literal>&lt;hibernate-mapping/&gt;</"
+"literal> 要素内で <literal>&lt;filter-def/&gt;</literal> 要素を使用します:"
 
-#. Tag: programlisting
-#: filters.xml:56
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<filter-def name=\"myFilter\">\n"
-"    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
-"</filter-def>]]>"
-msgstr ""
+msgid "This filter can then be attached to a class:"
+msgstr "そうしてフィルタはクラスへと結び付けられます:"
 
 #. Tag: para
-#: filters.xml:58
-#, fuzzy, no-c-format
-msgid "This filter can then be attached to a class:"
-msgstr "そうしてフィルタはクラスへと結び付けられます。:"
-
-#. Tag: programlisting
-#: filters.xml:62
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"myClass\" ...>\n"
-"    ...\n"
-"    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN"
-"\"/>\n"
-"</class>]]>"
-msgstr ""
+msgid "Or, to a collection:"
+msgstr "また、コレクションに対しては次のようになります:"
 
 #. Tag: para
-#: filters.xml:64
-#, fuzzy, no-c-format
-msgid "Or, to a collection:"
-msgstr "また、コレクションに対しては次のようになります。:"
-
-#. Tag: programlisting
-#: filters.xml:68
 #, no-c-format
-msgid ""
-"<![CDATA[<set ...>\n"
-"    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN"
-"\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:70
-#, fuzzy, no-c-format
 msgid "Or, to both or multiples of each at the same time."
-msgstr "どちらに対しても(また、それぞれを複数)同時に設定することもできます。"
+msgstr "どちらに対しても (また、それぞれを複数) 同時に設定することもできます。"
 
 #. Tag: para
-#: filters.xml:74
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The methods on <literal>Session</literal> are: <literal>enableFilter(String "
 "filterName)</literal>, <literal>getEnabledFilter(String filterName)</"
@@ -133,150 +96,78 @@
 "this:"
 msgstr ""
 "<literal>Session</literal> 上のメソッドは <literal>enableFilter(String "
-"filterName)</literal>, <literal>getEnabledFilter(String filterName)</"
-"literal>, <literal>disableFilter(String filterName)</literal> です。 デフォル"
+"filterName)</literal>、 <literal>getEnabledFilter(String filterName)</"
+"literal>、 <literal>disableFilter(String filterName)</literal> です。デフォル"
 "トでは、フィルタは与えられたセッションに対して使用 <emphasis>できません</"
 "emphasis> 。 <literal>Filter</literal> インスタンスを返り値とする "
-"<literal>Session.enableFilter()</literal> メソッドを使うことで、 フィルタは明"
-"示的に使用可能となります。 上で定義した単純なフィルタの使用は、このようになり"
-"ます。:"
+"<literal>Session.enabledFilter()</literal> メソッドを使うことで、フィルタは明"
+"示的に使用可能となります。上で定義した単純なフィルタの使用は、このようになり"
+"ます:"
 
-#. Tag: programlisting
-#: filters.xml:83
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam\", "
-"\"some-value\");]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:85
-#, fuzzy, no-c-format
-msgid ""
 "Methods on the org.hibernate.Filter interface do allow the method-chaining "
 "common to much of Hibernate."
 msgstr ""
-"org.hibernate.Filterインターフェイスのメソッドは、 Hibernateの多くに共通して"
-"いるメソッド連鎖を許していることに注意してください。"
+"org.hibernate.Filter インターフェースのメソッドは、 Hibernate の多くに共通し"
+"ているメソッド連鎖を許していることに注意してください。"
 
 #. Tag: para
-#: filters.xml:89
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is a full example, using temporal data with an effective "
 "record date pattern:"
 msgstr "有効なレコードデータパターンを持つ一時データを使った完全な例です:"
 
-#. Tag: programlisting
-#: filters.xml:93
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<filter-def name=\"effectiveDate\">\n"
-"    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
-"</filter-def>\n"
-"\n"
-"<class name=\"Employee\" ...>\n"
-"...\n"
-"    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department\"/"
-">\n"
-"    <property name=\"effectiveStartDate\" type=\"date\" column=\"eff_start_dt"
-"\"/>\n"
-"    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt\"/"
-">\n"
-"...\n"
-"    <!--\n"
-"        Note that this assumes non-terminal records have an eff_end_dt set "
-"to\n"
-"        a max db date for simplicity-sake\n"
-"    -->\n"
-"    <filter name=\"effectiveDate\"\n"
-"            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Department\" ...>\n"
-"...\n"
-"    <set name=\"employees\" lazy=\"true\">\n"
-"        <key column=\"dept_id\"/>\n"
-"        <one-to-many class=\"Employee\"/>\n"
-"        <filter name=\"effectiveDate\"\n"
-"                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
-">\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:95
-#, fuzzy, no-c-format
-msgid ""
 "In order to ensure that you are provided with currently effective records, "
 "enable the filter on the session prior to retrieving employee data:"
 msgstr ""
-"常に現在の有効レコードを返却することを保証するために、 単純に、社員データの検"
-"索より前にセッション上のフィルタを有効にします。"
+"常に現在の有効レコードを返却することを保証するために、単純に、社員データの検"
+"索より前にセッション上のフィルタを有効にします:"
 
-#. Tag: programlisting
-#: filters.xml:100
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = ...;\n"
-"session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new Date"
-"());\n"
-"List results = session.createQuery(\"from Employee as e where e.salary > :"
-"targetSalary\")\n"
-"         .setLong(\"targetSalary\", new Long(1000000))\n"
-"         .list();\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:102
-#, fuzzy, no-c-format
-msgid ""
 "Even though a salary constraint was mentioned explicitly on the results in "
 "the above HQL, because of the enabled filter, the query will return only "
 "currently active employees who have a salary greater than one million "
 "dollars."
 msgstr ""
-"上記のHQLでは、結果の給料の制約について明示的に触れただけですが、 有効になっ"
+"上記の HQL では、結果の給料の制約について明示的に触れただけですが、有効になっ"
 "ているフィルタのおかげで、このクエリは給料が100万ドル以上の現役の社員だけを返"
 "します。"
 
 #. Tag: para
-#: filters.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want to use filters with outer joining, either through HQL or load "
 "fetching, be careful of the direction of the condition expression. It is "
 "safest to set this up for left outer joining. Place the parameter first "
 "followed by the column name(s) after the operator."
 msgstr ""
-"(HQLかロードフェッチで)外部結合を持つフィルタを使うつもりなら、 条件式の方向"
-"に注意してください。 これは左外部結合のために設定するのが最も安全です。 一般"
-"的に、演算子の後カラム名に続けて最初のパラメータを配置してください。"
+"注記: (HQL かロードフェッチで)外部結合を持つフィルタを使うつもりなら、条件"
+"式の方向に注意してください。これは左外部結合のために設定するのが最も安全で"
+"す。一般的に、演算子の後カラム名に続けて最初のパラメータを配置してください。"
 
 #. Tag: para
-#: filters.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "After being defined, a filter might be attached to multiple entities and/or "
 "collections each with its own condition. This can be problematic when the "
 "conditions are the same each time. Using <literal>&lt;filter-def/&gt;</"
 "literal> allows you to definine a default condition, either as an attribute "
 "or CDATA:"
-msgstr "translator-credits"
-
-#. Tag: programlisting
-#: filters.xml:122
-#, no-c-format
-msgid ""
-"<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</filter-"
-"def>\n"
-"<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"
 msgstr ""
+"定義したあと、フィルタは、それぞれ独自のコンディションを持つ複数のエンティ"
+"ティやコレクションにアタッチされます。コンディションがいつも同じ場合、それは"
+"面倒かもしれません。従って、 <literal>&lt;filter-def/&gt;</literal> は、属性"
+"または CDATA としてデフォルトコンディションを定義することが可能になります:"
 
 #. Tag: para
-#: filters.xml:124
 #, no-c-format
 msgid ""
 "This default condition will be used whenever the filter is attached to "
@@ -284,3 +175,150 @@
 "condition as part of the attachment of the filter that overrides the default "
 "condition in that particular case."
 msgstr ""
+"このデフォルトのコンディションは、コンディションを指定せずに何かにアタッチさ"
+"れる場合いつでも使われます。これは、特定のケースにおいてデフォルトのコンディ"
+"ションをオーバーライドするフィルターのアタッチメントの一部として、特定のコン"
+"ディションを与えることができることを意味します。"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<filter-def name=\"myFilter\">\n"
+#~ "    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
+#~ "</filter-def>]]>"
+#~ msgstr ""
+#~ "&lt;filter-def name=\"myFilter\"&gt;\n"
+#~ "    &lt;filter-param name=\"myFilterParam\" type=\"string\"/&gt;\n"
+#~ "&lt;/filter-def&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"myClass\" ...>\n"
+#~ "    ...\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"myClass\" ...&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<set ...>\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "&lt;set ...&gt;\n"
+#~ "    &lt;filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/&gt;\n"
+#~ "&lt;/set&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam"
+#~ "\", \"some-value\");]]>"
+#~ msgstr ""
+#~ "session.enableFilter(\"myFilter\").setParameter(\"myFilterParam\", \"some-"
+#~ "value\");"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<filter-def name=\"effectiveDate\">\n"
+#~ "    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
+#~ "</filter-def>\n"
+#~ "\n"
+#~ "<class name=\"Employee\" ...>\n"
+#~ "...\n"
+#~ "    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department"
+#~ "\"/>\n"
+#~ "    <property name=\"effectiveStartDate\" type=\"date\" column="
+#~ "\"eff_start_dt\"/>\n"
+#~ "    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt"
+#~ "\"/>\n"
+#~ "...\n"
+#~ "    <!--\n"
+#~ "        Note that this assumes non-terminal records have an eff_end_dt "
+#~ "set to\n"
+#~ "        a max db date for simplicity-sake\n"
+#~ "    -->\n"
+#~ "    <filter name=\"effectiveDate\"\n"
+#~ "            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
+#~ ">\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Department\" ...>\n"
+#~ "...\n"
+#~ "    <set name=\"employees\" lazy=\"true\">\n"
+#~ "        <key column=\"dept_id\"/>\n"
+#~ "        <one-to-many class=\"Employee\"/>\n"
+#~ "        <filter name=\"effectiveDate\"\n"
+#~ "                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt"
+#~ "\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;filter-def name=\"effectiveDate\"&gt;\n"
+#~ "    &lt;filter-param name=\"asOfDate\" type=\"date\"/&gt;\n"
+#~ "&lt;/filter-def&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Employee\" ...&gt;\n"
+#~ "...\n"
+#~ "    &lt;many-to-one name=\"department\" column=\"dept_id\" class="
+#~ "\"Department\"/&gt;\n"
+#~ "    &lt;property name=\"effectiveStartDate\" type=\"date\" column="
+#~ "\"eff_start_dt\"/&gt;\n"
+#~ "    &lt;property name=\"effectiveEndDate\" type=\"date\" column="
+#~ "\"eff_end_dt\"/&gt;\n"
+#~ "...\n"
+#~ "    &lt;!--\n"
+#~ "        Note that this assumes non-terminal records have an eff_end_dt "
+#~ "set to\n"
+#~ "        a max db date for simplicity-sake\n"
+#~ "    --&gt;\n"
+#~ "    &lt;filter name=\"effectiveDate\"\n"
+#~ "            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
+#~ "&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Department\" ...&gt;\n"
+#~ "...\n"
+#~ "    &lt;set name=\"employees\" lazy=\"true\"&gt;\n"
+#~ "        &lt;key column=\"dept_id\"/&gt;\n"
+#~ "        &lt;one-to-many class=\"Employee\"/&gt;\n"
+#~ "        &lt;filter name=\"effectiveDate\"\n"
+#~ "                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt"
+#~ "\"/&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Session session = ...;\n"
+#~ "session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new "
+#~ "Date());\n"
+#~ "List results = session.createQuery(\"from Employee as e where e.salary > :"
+#~ "targetSalary\")\n"
+#~ "         .setLong(\"targetSalary\", new Long(1000000))\n"
+#~ "         .list();\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "Session session = ...;\n"
+#~ "session.enabledFilter(\"effectiveDate\").setParameter(\"asOfDate\", new "
+#~ "Date());\n"
+#~ "List results = session.createQuery(\"from Employee as e where e.salary "
+#~ "&gt; :targetSalary\")\n"
+#~ "         .setLong(\"targetSalary\", new Long(1000000))\n"
+#~ "         .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</"
+#~ "filter-def>\n"
+#~ "<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"
+#~ msgstr ""
+#~ "&lt;filter-def name=\"myFilter\" condition=\"abc &gt; xyz\"&gt;...&lt;/"
+#~ "filter-def&gt;\n"
+#~ "&lt;filter-def name=\"myOtherFilter\"&gt;abc=xyz&lt;/filter-def&gt;"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/inheritance_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/inheritance_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/inheritance_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,74 +1,64 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-07 09:59+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: inheritance_mapping.xml:29
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Inheritance mapping"
 msgstr "継承マッピング"
 
 #. Tag: title
-#: inheritance_mapping.xml:32
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The three strategies"
 msgstr "3つの戦略"
 
 #. Tag: para
-#: inheritance_mapping.xml:34
 #, no-c-format
 msgid "Hibernate supports the three basic inheritance mapping strategies:"
-msgstr "Hibernateは3つの基本的な継承のマッピング戦略をサポートします。"
+msgstr "Hibernate は3つの基本的な継承のマッピング戦略をサポートします。"
 
 #. Tag: para
-#: inheritance_mapping.xml:40
 #, no-c-format
 msgid "table per class hierarchy"
-msgstr "クラス階層ごとのテーブル(table-per-class-hierarchy)"
+msgstr "クラス階層ごとのテーブル (table-per-class-hierarchy)"
 
 #. Tag: para
-#: inheritance_mapping.xml:45
-#, fuzzy, no-c-format
-msgid "<para>table per subclass</para>"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"サブクラスごとのテーブル(table-per-subclass)\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"table per subclass"
+#, no-c-format
+msgid "table per subclass"
+msgstr "サブクラスごとのテーブル (table-per-subclass)"
 
 #. Tag: para
-#: inheritance_mapping.xml:50
 #, no-c-format
 msgid "table per concrete class"
-msgstr "具象クラスごとのテーブル(table-per-concrete-class)"
+msgstr "具象クラスごとのテーブル (table-per-concrete-class)"
 
 #. Tag: para
-#: inheritance_mapping.xml:56
 #, no-c-format
 msgid ""
 "In addition, Hibernate supports a fourth, slightly different kind of "
 "polymorphism:"
 msgstr ""
-"加えて4つ目に、Hibernateはわずかに異なる性質を持ったポリモーフィズムをサポー"
-"トします。"
+"加えて4つ目に、 Hibernate はわずかに異なる性質を持ったポリモーフィズムをサ"
+"ポートします。"
 
 #. Tag: para
-#: inheritance_mapping.xml:63
 #, no-c-format
 msgid "implicit polymorphism"
 msgstr "暗黙的ポリモーフィズム"
 
 #. Tag: para
-#: inheritance_mapping.xml:69
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to use different mapping strategies for different branches of "
 "the same inheritance hierarchy. You can then make use of implicit "
@@ -82,19 +72,18 @@
 "<literal>&lt;join&gt;</literal> elements (see below for an example)."
 msgstr ""
 "同一の継承階層の異なるブランチに対して異なるマッピング戦略を使うことができま"
-"す。 その場合には全体の階層に渡るポリモーフィズムを実現するために暗黙的ポリ"
-"モーフィズムを使用します。 しかし、Hibernateは同じルート <literal>&lt;"
-"class&gt;</literal> 要素内で <literal>&lt;subclass&gt;</literal> マッピング、"
-"<literal>&lt;joined-subclass&gt;</literal> マッピング、 <literal>&lt;union-"
-"subclass&gt;</literal> マッピングの同時使用をサポートしていません。 "
+"す。その場合には全体の階層に渡るポリモーフィズムを実現するために暗黙的ポリ"
+"モーフィズムを使用します。しかし、 Hibernate は同じルート <literal>&lt;"
+"class&gt;</literal> 要素内で <literal>&lt;subclass&gt;</literal> マッピン"
+"グ、 <literal>&lt;joined-subclass&gt;</literal> マッピング、 <literal>&lt;"
+"union-subclass&gt;</literal> マッピングの同時使用をサポートしていません。 "
 "<literal>&lt;subclass&gt;</literal> 要素と <literal>&lt;join&gt;</literal> 要"
-"素を組み合わせることで、 同一 <literal>&lt;class&gt;</literal> 要素内での "
+"素を組み合わせることで、同一 <literal>&lt;class&gt;</literal> 要素内での "
 "table-per-hierarchy 戦略と table-per-subclass 戦略の同時使用は可能です。次の"
 "例を見てください。"
 
 #. Tag: para
-#: inheritance_mapping.xml:83
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to define <literal>subclass</literal>, <literal>union-"
 "subclass</literal>, and <literal>joined-subclass</literal> mappings in "
@@ -107,145 +96,74 @@
 "extends keyword. The ordering inside a single mapping file still needs to be "
 "defined as superclasses before subclasses."
 msgstr ""
-"<literal>subclass</literal>, <literal>union-subclass</literal> と "
+"<literal>subclass</literal>、 <literal>union-subclass</literal> と "
 "<literal>joined-subclass</literal> マッピングを複数のマッピングドキュメントに"
 "定義することが出来、 <literal>hibernate-mapping</literal> の直下に配置しま"
-"す。 これは新しいマッピングファイルを追加するだけで、クラス階層を拡張できると"
-"いうことです。 あらかじめマップしたスーパークラスを指定して、サブクラスマッピ"
-"ングに <literal>extends</literal> 属性を記述しなければなりません。 注意:この"
-"特徴により、以前はマッピング・ドキュメントの順番が重要でした。 Hibernate3から"
-"は、extendsキーワードを使う場合、マッピングドキュメントの順番は問題になりませ"
-"ん。 1つのマッピングファイル内で順番付けを行うときは、 依然として、サブクラ"
+"す。これは新しいマッピングファイルを追加するだけで、クラス階層を拡張できると"
+"いうことです。あらかじめマップしたスーパークラスを指定して、サブクラスマッピ"
+"ングに <literal>extends</literal> 属性を記述しなければなりません。注記:この"
+"特徴により、以前はマッピングドキュメントの順番が重要でした。 Hibernate3 から"
+"は、 extends キーワードを使う場合、マッピングドキュメントの順番は問題になりま"
+"せん。1つのマッピングファイル内で順番付けを行うときは、依然として、サブクラ"
 "スを定義する前にスーパークラスを定義する必要があります。)"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:94
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-" <hibernate-mapping>\n"
-"     <subclass name=\"DomesticCat\" extends=\"Cat\" discriminator-value=\"D"
-"\">\n"
-"          <property name=\"name\" type=\"string\"/>\n"
-"     </subclass>\n"
-" </hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:98
 #, no-c-format
 msgid "Table per class hierarchy"
 msgstr "クラス階層ごとのテーブル(table-per-class-hierarchy)"
 
 #. Tag: para
-#: inheritance_mapping.xml:100
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Suppose we have an interface <literal>Payment</literal> with the "
 "implementors <literal>CreditCardPayment</literal>, <literal>CashPayment</"
 "literal>, and <literal>ChequePayment</literal>. The table per hierarchy "
 "mapping would display in the following way:"
 msgstr ""
-"例えば、インターフェイス <literal>Payment</literal> と、それを実装した "
-"<literal>CreditCardPayment</literal>、<literal>CashPayment</literal>、 "
+"例えば、インターフェース <literal>Payment</literal> と、それを実装した "
+"<literal>CreditCardPayment</literal>、 <literal>CashPayment</literal>、 "
 "<literal>ChequePayment</literal> があるとします。階層ごとのテーブルマッピング"
-"は 以下のようになります。"
+"は以下のようになります:"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:107
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        ...\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: inheritance_mapping.xml:109
-#, fuzzy, no-c-format
-msgid ""
 "Exactly one table is required. There is a limitation of this mapping "
 "strategy: columns declared by the subclasses, such as <literal>CCTYPE</"
 "literal>, cannot have <literal>NOT NULL</literal> constraints."
 msgstr ""
-"ちょうど一つのテーブルが必要です。 このマッピング戦略には一つ大きな制限があり"
+"ちょうど一つのテーブルが必要です。このマッピング戦略には一つ大きな制限があり"
 "ます。 <literal>CCTYPE</literal> のような、サブクラスで宣言されたカラムは "
 "<literal>NOT NULL</literal> 制約を持てません。"
 
 #. Tag: title
-#: inheritance_mapping.xml:118
 #, no-c-format
 msgid "Table per subclass"
-msgstr "サブクラスごとのテーブル(table-per-subclass)"
+msgstr "サブクラスごとのテーブル (table-per-subclass)"
 
 #. Tag: para
-#: inheritance_mapping.xml:120
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A table per subclass mapping looks like this:"
-msgstr "table-per-subclass マッピングは以下のようになります。"
+msgstr "table-per-subclass マッピングは以下のようになります:"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:124
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <joined-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: inheritance_mapping.xml:126
-#, fuzzy, no-c-format
-msgid ""
 "Four tables are required. The three subclass tables have primary key "
 "associations to the superclass table so the relational model is actually a "
 "one-to-one association."
 msgstr ""
-"このマッピングには4つのテーブルが必要です。3つのサブクラステーブルは スーパー"
+"このマッピングには4つのテーブルが必要です。3つのサブクラステーブルはスーパー"
 "クラステーブルとの関連を示す主キーを持っています (実際、関係モデル上は一対一"
 "関連です)。"
 
 #. Tag: title
-#: inheritance_mapping.xml:135
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Table per subclass: using a discriminator"
-msgstr "弁別子を用いた table-per-subclass"
+msgstr "discriminator を用いた table-per-subclass"
 
 #. Tag: para
-#: inheritance_mapping.xml:137
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's implementation of table per subclass does not require a "
 "discriminator column. Other object/relational mappers use a different "
@@ -256,103 +174,40 @@
 "strategy, you can combine the use of <literal>&lt;subclass&gt;</literal> and "
 "<literal>&lt;join&gt;</literal>, as follows:"
 msgstr ""
-"Hibernateの table-per-subclass 実装は、discriminatorカラムを必要としないこと"
-"を覚えておいてください。 Hibernate以外のO/Rマッパーは、table-per-subclass に"
-"異なる実装を用います。 それは、スーパークラスのテーブルにタイプdiscriminator"
-"カラムを必要とします。 このアプローチは実装が困難になりますが、関係の視点から"
-"見ると、より正確なものです。 table-per-subclass 戦略でdiscriminatorカラムを使"
-"いたければ、 <literal>&lt;subclass&gt;</literal> と <literal>&lt;join&gt;</"
-"literal> を以下のように組み合わせて使ってください。"
+"Hibernate の table-per-subclass 実装は、 discriminator カラムを必要としないこ"
+"とを覚えておいてください。 Hibernate 以外の O/R マッパーは、 table-per-"
+"subclass に異なる実装を用います。それは、スーパークラスのテーブルにタイプ "
+"discriminator カラムを必要とします。このアプローチは実装が困難になりますが、"
+"関係の視点から見ると、より正確なものです。 table-per-subclass 戦略で "
+"discriminator カラムを使いたければ、 <literal>&lt;subclass&gt;</literal> と "
+"<literal>&lt;join&gt;</literal> を以下のように組み合わせて使ってください。"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:149
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <join table=\"CREDIT_PAYMENT\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        <join table=\"CASH_PAYMENT\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        <join table=\"CHEQUE_PAYMENT\" fetch=\"select\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:151
 #, no-c-format
 msgid ""
 "The optional <literal>fetch=\"select\"</literal> declaration tells Hibernate "
 "not to fetch the <literal>ChequePayment</literal> subclass data using an "
 "outer join when querying the superclass."
 msgstr ""
-"オプションの <literal>fetch=\"select\"</literal> 宣言は、 スーパークラスのク"
-"エリ実行時に外部結合を使って、 サブクラスの <literal>ChequePayment</literal> "
+"オプションの <literal>fetch=\"select\"</literal> 宣言は、スーパークラスのクエ"
+"リ実行時に外部結合を使って、サブクラスの <literal>ChequePayment</literal> "
 "データを取得しないように指定するためのものです。"
 
 #. Tag: title
-#: inheritance_mapping.xml:160
 #, no-c-format
 msgid "Mixing table per class hierarchy with table per subclass"
 msgstr "table-per-subclass と table-per-class-hierarchy の混合"
 
 #. Tag: para
-#: inheritance_mapping.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can even mix the table per hierarchy and table per subclass strategies "
 "using the following approach:"
 msgstr ""
-"このアプローチを使用すると、table-per-hierarchy と table-per-subclass 戦略を "
+"このアプローチを使用すると、 table-per-hierarchy と table-per-subclass 戦略を"
 "組み合わせる事も可能です。"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <join table=\"CREDIT_PAYMENT\">\n"
-"            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        ...\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:169
 #, no-c-format
 msgid ""
 "For any of these mapping strategies, a polymorphic association to the root "
@@ -360,68 +215,33 @@
 "</literal>."
 msgstr ""
 "いずれのマッピング戦略であっても、ルートである <literal>Payment</literal> ク"
-"ラスへの ポリモーフィックな関連は <literal>&lt;many-to-one&gt;</literal> を"
+"ラスへのポリモーフィックな関連は <literal>&lt;many-to-one&gt;</literal> を"
 "使ってマッピングします。"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:175
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"payment\" column=\"PAYMENT_ID\" class=\"Payment"
-"\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:180
 #, no-c-format
 msgid "Table per concrete class"
 msgstr "具象クラスごとのテーブル(table-per-concrete-class)"
 
 #. Tag: para
-#: inheritance_mapping.xml:182
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are two ways we can map the table per concrete class strategy. First, "
 "you can use <literal>&lt;union-subclass&gt;</literal>."
 msgstr ""
-"table-per-concrete-class 戦略のマッピングに対するアプローチは、2つあります。 "
-"1つ目は <literal>&lt;union-subclass&gt;</literal> を利用する方法です。"
+"table-per-concrete-class 戦略のマッピングに対するアプローチは、2つあります。1"
+"つ目は <literal>&lt;union-subclass&gt;</literal> を利用する方法です。"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:187
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"sequence\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <union-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </union-subclass>\n"
-"    <union-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        ...\n"
-"    </union-subclass>\n"
-"    <union-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        ...\n"
-"    </union-subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:189
 #, no-c-format
 msgid ""
 "Three tables are involved for the subclasses. Each table defines columns for "
 "all properties of the class, including inherited properties."
 msgstr ""
 "サブクラスごとに3つのテーブルが必要です。それぞれのテーブルは、継承プロパティ"
-"を含んだ、 クラスの全てのプロパティに対するカラムを定義します。"
+"を含んだ、クラスの全てのプロパティに対するカラムを定義します。"
 
 #. Tag: para
-#: inheritance_mapping.xml:194
 #, fuzzy, no-c-format
 msgid ""
 "The limitation of this approach is that if a property is mapped on the "
@@ -430,129 +250,78 @@
 "The primary key seed has to be shared across all unioned subclasses of a "
 "hierarchy."
 msgstr ""
-"このアプローチには制限があります。 それは、プロパティがスーパークラスにマッピ"
-"ングされていた場合、 全てのサブクラスにおいてカラム名が同じでなければならない"
-"というものです。 (Hibernateの今後のリリースで緩和されるかもしれません)。 "
-"&lt;union-subclass&gt; を使った table-per-concrete-class 戦略では識別子生成戦"
-"略を使用できません。 主キーを生成するためのシードは、全ての union subclass の"
-"階層内で共有する必要があるからです。"
+"このアプローチには制限があります。それは、プロパティがスーパークラスにマッピ"
+"ングされていた場合、全てのサブクラスにおいてカラム名が同じでなければならない"
+"というものです。(Hibernate の今後のリリースで緩和されるかもしれません)。 "
+"union subclass 継承では識別子生成戦略を使用できません。主キーを生成するための"
+"シードは、全ての union subclass の階層内で共有する必要があるからです。"
 
 #. Tag: para
-#: inheritance_mapping.xml:203
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your superclass is abstract, map it with <literal>abstract=\"true\"</"
 "literal>. If it is not abstract, an additional table (it defaults to "
 "<literal>PAYMENT</literal> in the example above), is needed to hold "
 "instances of the superclass."
 msgstr ""
-"もしスーパークラスが抽象クラスなら、<literal>abstract=\"true\"</literal>と"
-"マッピングします。 もちろん、スーパークラスが抽象クラスでないなら、スーパーク"
-"ラスのインスタンスを 保持するためのテーブルの追加が必要となります(上の例での"
+"もしスーパークラスが抽象クラスなら、 <literal>abstract=\"true\"</literal> と"
+"マッピングします。もちろん、スーパークラスが抽象クラスでないなら、スーパーク"
+"ラスのインスタンスを保持するためのテーブルの追加が必要となります (上の例での"
 "デフォルトは <literal>PAYMENT</literal> )。"
 
 #. Tag: title
-#: inheritance_mapping.xml:213
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Table per concrete class using implicit polymorphism"
 msgstr "暗黙的ポリモーフィズムを用いた table-per-concrete-class"
 
 #. Tag: para
-#: inheritance_mapping.xml:215
 #, no-c-format
 msgid "An alternative approach is to make use of implicit polymorphism:"
-msgstr "もう一つのアプローチは暗黙的ポリモーフィズムの使用です。"
+msgstr "もう一つのアプローチは暗黙的ポリモーフィズムの使用です:"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:219
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-"    ...\n"
-"</class>\n"
-"\n"
-"<class name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CASH_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-"    ...\n"
-"</class>\n"
-"\n"
-"<class name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CHEQUE_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: inheritance_mapping.xml:221
-#, fuzzy, no-c-format
-msgid ""
 "Notice that the <literal>Payment</literal> interface is not mentioned "
 "explicitly. Also notice that properties of <literal>Payment</literal> are "
 "mapped in each of the subclasses. If you want to avoid duplication, consider "
 "using XML entities (for example, <literal>[ &lt;!ENTITY allproperties SYSTEM "
 "\"allproperties.xml\"&gt; ]</literal> in the <literal>DOCTYPE</literal> "
-"declaration and <literal>&amp;allproperties;</literal> in the mapping)."
+"declaration and <literal>&amp;allproperties&semi;</literal> in the mapping)."
 msgstr ""
-"<literal>Payment</literal> インターフェイスがどこにも明示的に示されていないこ"
-"とに注意してください。 そして、<literal>Payment</literal> プロパティがそれぞ"
-"れのサブクラスにマッピングされていることにも注意してください。 もし重複を避け"
-"たいのであれば、XMLエンティティの利用を考えてください。 (例: "
+"<literal>Payment</literal> インターフェースがどこにも明示的に示されていないこ"
+"とに注意してください。そして、 <literal>Payment</literal> プロパティがそれぞ"
+"れのサブクラスにマッピングされていることにも注意してください。もし重複を避け"
+"たいのであれば、 XML エンティティの利用を考えてください。 (例: "
 "<literal>DOCTYPE</literal> 宣言における <literal>[ &lt;!ENTITY allproperties "
 "SYSTEM \"allproperties.xml\"&gt; ]</literal> と、マッピングにおける "
-"<literal>&amp;allproperties;</literal>)"
+"<literal>&amp;allproperties&semi;</literal>)。"
 
 #. Tag: para
-#: inheritance_mapping.xml:231
 #, no-c-format
 msgid ""
 "The disadvantage of this approach is that Hibernate does not generate SQL "
 "<literal>UNION</literal>s when performing polymorphic queries."
 msgstr ""
-"このアプローチの欠点は、Hibernateがポリモーフィックなクエリの実行時にSQL "
+"このアプローチの欠点は、 Hibernate がポリモーフィックなクエリの実行時に SQL "
 "<literal>UNION</literal> を生成しない点です。"
 
 #. Tag: para
-#: inheritance_mapping.xml:236
 #, no-c-format
 msgid ""
 "For this mapping strategy, a polymorphic association to <literal>Payment</"
 "literal> is usually mapped using <literal>&lt;any&gt;</literal>."
 msgstr ""
-"このマッピング戦略に対しては、<literal>Payment</literal> へのポリモーフィック"
-"な関連は 通常、<literal>&lt;any&gt;</literal> を使ってマッピングされます。"
+"このマッピング戦略に対しては、 <literal>Payment</literal> へのポリモーフィッ"
+"クな関連は常に、 <literal>&lt;any&gt;</literal> を使ってマッピングされます。"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:241
-#, no-c-format
-msgid ""
-"<![CDATA[<any name=\"payment\" meta-type=\"string\" id-type=\"long\">\n"
-"    <meta-value value=\"CREDIT\" class=\"CreditCardPayment\"/>\n"
-"    <meta-value value=\"CASH\" class=\"CashPayment\"/>\n"
-"    <meta-value value=\"CHEQUE\" class=\"ChequePayment\"/>\n"
-"    <column name=\"PAYMENT_CLASS\"/>\n"
-"    <column name=\"PAYMENT_ID\"/>\n"
-"</any>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:246
 #, no-c-format
 msgid "Mixing implicit polymorphism with other inheritance mappings"
 msgstr "他の継承マッピングと暗黙的ポリモーフィズムの組み合わせ"
 
 #. Tag: para
-#: inheritance_mapping.xml:248
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Since the subclasses are each mapped in their own <literal>&lt;class&gt;</"
 "literal> element, and since <literal>Payment</literal> is just an "
@@ -560,50 +329,16 @@
 "inheritance hierarchy. You can still use polymorphic queries against the "
 "<literal>Payment</literal> interface."
 msgstr ""
-"このマッピングについての更なる注意点があります。 サブクラスが自身を "
-"<literal>&lt;class&gt;</literal> 要素としてマッピングしているので、 (かつ "
-"<literal>Payment</literal> は単なるインターフェイスなので)、 それぞれのサブ"
-"クラスは簡単にその他の継承階層の一部となります。 (しかも、今までどおり "
-"<literal>Payment</literal> インターフェイスに対するポリモーフィックなクエリ "
-"を使用することができます)"
+"このマッピングについての更なる注意点があります。サブクラスが自身を "
+"<literal>&lt;class&gt;</literal> 要素としてマッピングしているので、(かつ "
+"<literal>Payment</literal> は単なるインターフェースなので)、それぞれのサブク"
+"ラスは簡単にその他の継承階層の一部となります。(しかも、今までどおり "
+"<literal>Payment</literal> インターフェースに対するポリモーフィックなクエリを"
+"使用することができます)"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:256
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"CREDIT_CARD\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"MasterCardPayment\" discriminator-value=\"MDC\"/>\n"
-"    <subclass name=\"VisaPayment\" discriminator-value=\"VISA\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"NonelectronicTransaction\" table=\"NONELECTRONIC_TXN\">\n"
-"    <id name=\"id\" type=\"long\" column=\"TXN_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    ...\n"
-"    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: inheritance_mapping.xml:258
-#, fuzzy, no-c-format
-msgid ""
 "Once again, <literal>Payment</literal> is not mentioned explicitly. If we "
 "execute a query against the <literal>Payment</literal> interface, for "
 "example <literal>from Payment</literal>, Hibernate automatically returns "
@@ -612,229 +347,589 @@
 "literal> and <literal>ChequePayment</literal>, but not instances of "
 "<literal>NonelectronicTransaction</literal>."
 msgstr ""
-"もう一度述べますが、<literal>Payment</literal> は明示的に定義されません。 も"
-"し、<literal>Payment</literal> インターフェイスに対してクエリを実行するなら "
-"(例えば <literal>from Payment</literal> 節を使って)、 Hibernateは自動的に "
-"<literal>CreditCardPayment</literal> (とCreditCardPaymentのサブクラス、"
-"<literal>Payment</literal> の実装であるため)、 および、"
-"<literal>CashPayment</literal> 、<literal>ChequePayment</literal> のインスタ"
+"もう一度述べますが、 <literal>Payment</literal> は明示的に定義されません。も"
+"し、 <literal>Payment</literal> インターフェースに対してクエリを実行するなら "
+"(例えば <literal>from Payment</literal> 節を使って)、 Hibernate は自動的に "
+"<literal>CreditCardPayment</literal> (と CreditCardPayment のサブクラス、 "
+"<literal>Payment</literal> の実装であるため)、および、 "
+"<literal>CashPayment</literal> 、 <literal>ChequePayment</literal> のインスタ"
 "ンスを返します。 <literal>NonelectronicTransaction</literal> インスタンスは返"
 "しません。"
 
 #. Tag: title
-#: inheritance_mapping.xml:273
 #, no-c-format
 msgid "Limitations"
 msgstr "制限"
 
 #. Tag: para
-#: inheritance_mapping.xml:275
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are limitations to the \"implicit polymorphism\" approach to the table "
 "per concrete-class mapping strategy. There are somewhat less restrictive "
 "limitations to <literal>&lt;union-subclass&gt;</literal> mappings."
 msgstr ""
 "table-per-concrete-class マッピング戦略への「暗黙的ポリモーフィズム」アプロー"
-"チには いくつかの制限があります。<literal>&lt;union-subclass&gt;</literal> "
-"マッピングに対しても 少し弱めの制限があります。"
+"チにはいくつかの制限があります。 <literal>&lt;union-subclass&gt;</literal> "
+"マッピングに対しても少し弱めの制限があります。"
 
 #. Tag: para
-#: inheritance_mapping.xml:282
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The following table shows the limitations of table per concrete-class "
 "mappings, and of implicit polymorphism, in Hibernate."
 msgstr ""
-"次のテーブルに、Hibernateにおけるtable-per-concrete-classマッピングの 制限や"
-"暗黙的ポリモーフィズムの制限を示します。"
+"次のテーブルに、 Hibernate における table-per-concrete-class マッピングの制限"
+"や暗黙的ポリモーフィズムの制限を示します。"
 
 #. Tag: title
-#: inheritance_mapping.xml:288
 #, no-c-format
 msgid "Features of inheritance mappings"
 msgstr "継承マッピングの機能"
 
 #. Tag: entry
-#: inheritance_mapping.xml:301
 #, no-c-format
 msgid "Inheritance strategy"
 msgstr "継承戦略"
 
 #. Tag: entry
-#: inheritance_mapping.xml:302
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Polymorphic many-to-one"
-msgstr "多対一のポリモーフィズム"
+msgstr "多対多のポリモーフィズム"
 
 #. Tag: entry
-#: inheritance_mapping.xml:303
 #, no-c-format
 msgid "Polymorphic one-to-one"
 msgstr "一対一のポリモーフィズム"
 
 #. Tag: entry
-#: inheritance_mapping.xml:304
 #, no-c-format
 msgid "Polymorphic one-to-many"
 msgstr "一対多のポリモーフィズム"
 
 #. Tag: entry
-#: inheritance_mapping.xml:305
 #, no-c-format
 msgid "Polymorphic many-to-many"
 msgstr "多対多のポリモーフィズム"
 
 #. Tag: entry
-#: inheritance_mapping.xml:306
 #, no-c-format
 msgid "Polymorphic <literal>load()/get()</literal>"
-msgstr ""
+msgstr "ポリモーフィックな <literal>load()/get()</literal>"
 
 #. Tag: entry
-#: inheritance_mapping.xml:307
 #, no-c-format
 msgid "Polymorphic queries"
 msgstr "ポリモーフィズムを使ったクエリ"
 
 #. Tag: entry
-#: inheritance_mapping.xml:308
 #, no-c-format
 msgid "Polymorphic joins"
 msgstr "ポリモーフィズムを使った結合"
 
 #. Tag: entry
-#: inheritance_mapping.xml:309
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Outer join fetching"
 msgstr "外部結合によるフェッチ"
 
 #. Tag: entry
-#: inheritance_mapping.xml:314
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "table per class-hierarchy"
-msgstr "table per class-hierarchy"
+msgstr "クラス階層ごとのテーブル (table-per-class-hierarchy)"
 
-#. Tag: literal
-#: inheritance_mapping.xml:315 inheritance_mapping.xml:326
-#: inheritance_mapping.xml:337
-#, no-c-format
-msgid "&lt;many-to-one&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;many-to-one&gt;</literal>"
 msgstr "&lt;many-to-one&gt;"
 
-#. Tag: literal
-#: inheritance_mapping.xml:316 inheritance_mapping.xml:327
-#: inheritance_mapping.xml:338
-#, no-c-format
-msgid "&lt;one-to-one&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;one-to-one&gt;</literal>"
 msgstr "&lt;one-to-one&gt;"
 
-#. Tag: literal
-#: inheritance_mapping.xml:317 inheritance_mapping.xml:328
-#, no-c-format
-msgid "&lt;one-to-many&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;one-to-many&gt;</literal>"
 msgstr "&lt;one-to-many&gt;"
 
-#. Tag: literal
-#: inheritance_mapping.xml:318 inheritance_mapping.xml:329
-#: inheritance_mapping.xml:340
-#, no-c-format
-msgid "&lt;many-to-many&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;many-to-many&gt;</literal>"
 msgstr "&lt;many-to-many&gt;"
 
-#. Tag: literal
-#: inheritance_mapping.xml:319 inheritance_mapping.xml:330
-#: inheritance_mapping.xml:341
-#, no-c-format
-msgid "s.get(Payment.class, id)"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>s.get(Payment.class, id)</literal>"
 msgstr "s.get(Payment.class, id)"
 
-#. Tag: literal
-#: inheritance_mapping.xml:320 inheritance_mapping.xml:331
-#: inheritance_mapping.xml:342 inheritance_mapping.xml:353
-#, no-c-format
-msgid "from Payment p"
-msgstr "from Payment p"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>from Payment p</literal>"
+msgstr "ポリモーフィックな <literal>load()/get()</literal>"
 
-#. Tag: literal
-#: inheritance_mapping.xml:321 inheritance_mapping.xml:332
-#: inheritance_mapping.xml:343
+#. Tag: entry
 #, no-c-format
-msgid "from Order o join o.payment p"
-msgstr "from Order o join o.payment p"
+msgid "<literal>from Order o join o.payment p</literal>"
+msgstr ""
 
-#. Tag: emphasis
-#: inheritance_mapping.xml:322 inheritance_mapping.xml:333
-#: inheritance_mapping.xml:344
+#. Tag: entry
 #, no-c-format
-msgid "supported"
-msgstr "サポート"
-
-#. Tag: entry
-#: inheritance_mapping.xml:325
-#, fuzzy, no-c-format
-msgid "<entry>table per subclass</entry>"
+msgid "<emphasis>supported</emphasis>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"サブクラスごとのテーブル(table-per-subclass)\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"table per subclass"
 
 #. Tag: entry
-#: inheritance_mapping.xml:336
 #, no-c-format
 msgid "table per concrete-class (union-subclass)"
 msgstr "table per concrete-class (union-subclass)"
 
 #. Tag: entry
-#: inheritance_mapping.xml:339
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "<literal>&lt;one-to-many&gt;</literal> (for <literal>inverse=\"true\"</"
 "literal> only)"
 msgstr ""
+"<literal>&lt;one-to-many&gt;</literal> ( <literal>inverse=\"true\"</literal> "
+"のために限られる)"
 
 #. Tag: entry
-#: inheritance_mapping.xml:347
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "table per concrete class (implicit polymorphism)"
 msgstr "table per concrete class (implicit polymorphism)"
 
-#. Tag: literal
-#: inheritance_mapping.xml:348
-#, no-c-format
-msgid "&lt;any&gt;"
-msgstr "&lt;any&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;any&gt;</literal>"
+msgstr "ポリモーフィックな <literal>load()/get()</literal>"
 
-#. Tag: emphasis
-#: inheritance_mapping.xml:349 inheritance_mapping.xml:350
-#: inheritance_mapping.xml:354 inheritance_mapping.xml:355
+#. Tag: entry
 #, no-c-format
-msgid "not supported"
-msgstr "サポートしていません"
+msgid "<emphasis>not supported</emphasis>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:351
-#, no-c-format
-msgid "&lt;many-to-any&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;many-to-any&gt;</literal>"
 msgstr "&lt;many-to-any&gt;"
 
-#. Tag: literal
-#: inheritance_mapping.xml:352
-#, no-c-format
+#. Tag: entry
+#, fuzzy, no-c-format
 msgid ""
-"s.createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()"
+"<literal>s.createCriteria(Payment.class).add( Restrictions.idEq(id) )."
+"uniqueResult()</literal>"
 msgstr ""
 "s.createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()"
 
-#~ msgid "load()/get()"
-#~ msgstr "load()/get()"
+#, fuzzy
+#~ msgid "table per class-heirarchy"
+#~ msgstr "table per class-hierarchy"
 
-#~ msgid "Polymorphic <placeholder-1/>"
-#~ msgstr "ポリモーフィズムを使った<placeholder-1/>"
+#, fuzzy
+#~ msgid "Polymorphic many-to-one: <code>&lt;any&gt;</code>"
+#~ msgstr "多対一のポリモーフィズム"
 
-#~ msgid "inverse=\"true\""
-#~ msgstr "inverse=\"true\""
+#~ msgid "<para>table per subclass</para>"
+#~ msgstr "<para>サブクラスごとのテーブル (table-per-subclass) </para>"
 
-#~ msgid "<placeholder-1/> (for <placeholder-2/> only)"
-#~ msgstr "<placeholder-1/> (for <placeholder-2/> only)"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[\n"
+#~ " <hibernate-mapping>\n"
+#~ "     <subclass name=\"DomesticCat\" extends=\"Cat\" discriminator-value="
+#~ "\"D\">\n"
+#~ "          <property name=\"name\" type=\"string\"/>\n"
+#~ "     </subclass>\n"
+#~ " </hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "     &lt;subclass name=\"DomesticCat\" extends=\"Cat\" discriminator-"
+#~ "value=\"D\"&gt;\n"
+#~ "          &lt;property name=\"name\" type=\"string\"/&gt;\n"
+#~ "     &lt;/subclass&gt;\n"
+#~ " &lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
+#~ "    <property name=\"amount\" column=\"AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
+#~ "        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
+#~ "        ...\n"
+#~ "    </subclass>\n"
+#~ "    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
+#~ "        ...\n"
+#~ "    </subclass>\n"
+#~ "    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
+#~ "        ...\n"
+#~ "    </subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Payment\" table=\"PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;discriminator column=\"PAYMENT_TYPE\" type=\"string\"/&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT"
+#~ "\"&gt;\n"
+#~ "        &lt;property name=\"creditCardType\" column=\"CCTYPE\"/&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "    &lt;subclass name=\"CashPayment\" discriminator-value=\"CASH\"&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "    &lt;subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE"
+#~ "\"&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"amount\" column=\"AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "    <joined-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT"
+#~ "\">\n"
+#~ "        <key column=\"PAYMENT_ID\"/>\n"
+#~ "        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
+#~ "        ...\n"
+#~ "    </joined-subclass>\n"
+#~ "    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
+#~ "        <key column=\"PAYMENT_ID\"/>\n"
+#~ "        ...\n"
+#~ "    </joined-subclass>\n"
+#~ "    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
+#~ "        <key column=\"PAYMENT_ID\"/>\n"
+#~ "        ...\n"
+#~ "    </joined-subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Payment\" table=\"PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;joined-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT"
+#~ "\"&gt;\n"
+#~ "        &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "        &lt;property name=\"creditCardType\" column=\"CCTYPE\"/&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/joined-subclass&gt;\n"
+#~ "    &lt;joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\"&gt;\n"
+#~ "        &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/joined-subclass&gt;\n"
+#~ "    &lt;joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT"
+#~ "\"&gt;\n"
+#~ "        &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/joined-subclass&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
+#~ "    <property name=\"amount\" column=\"AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
+#~ "        <join table=\"CREDIT_PAYMENT\">\n"
+#~ "            <key column=\"PAYMENT_ID\"/>\n"
+#~ "            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
+#~ "            ...\n"
+#~ "        </join>\n"
+#~ "    </subclass>\n"
+#~ "    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
+#~ "        <join table=\"CASH_PAYMENT\">\n"
+#~ "            <key column=\"PAYMENT_ID\"/>\n"
+#~ "            ...\n"
+#~ "        </join>\n"
+#~ "    </subclass>\n"
+#~ "    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
+#~ "        <join table=\"CHEQUE_PAYMENT\" fetch=\"select\">\n"
+#~ "            <key column=\"PAYMENT_ID\"/>\n"
+#~ "            ...\n"
+#~ "        </join>\n"
+#~ "    </subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Payment\" table=\"PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;discriminator column=\"PAYMENT_TYPE\" type=\"string\"/&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT"
+#~ "\"&gt;\n"
+#~ "        &lt;join table=\"CREDIT_PAYMENT\"&gt;\n"
+#~ "            &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "            &lt;property name=\"creditCardType\" column=\"CCTYPE\"/&gt;\n"
+#~ "            ...\n"
+#~ "        &lt;/join&gt;\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "    &lt;subclass name=\"CashPayment\" discriminator-value=\"CASH\"&gt;\n"
+#~ "        &lt;join table=\"CASH_PAYMENT\"&gt;\n"
+#~ "            &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "            ...\n"
+#~ "        &lt;/join&gt;\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "    &lt;subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE"
+#~ "\"&gt;\n"
+#~ "        &lt;join table=\"CHEQUE_PAYMENT\" fetch=\"select\"&gt;\n"
+#~ "            &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "            ...\n"
+#~ "        &lt;/join&gt;\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
+#~ "    <property name=\"amount\" column=\"AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
+#~ "        <join table=\"CREDIT_PAYMENT\">\n"
+#~ "            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
+#~ "            ...\n"
+#~ "        </join>\n"
+#~ "    </subclass>\n"
+#~ "    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
+#~ "        ...\n"
+#~ "    </subclass>\n"
+#~ "    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
+#~ "        ...\n"
+#~ "    </subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Payment\" table=\"PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;discriminator column=\"PAYMENT_TYPE\" type=\"string\"/&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT"
+#~ "\"&gt;\n"
+#~ "        &lt;join table=\"CREDIT_PAYMENT\"&gt;\n"
+#~ "            &lt;property name=\"creditCardType\" column=\"CCTYPE\"/&gt;\n"
+#~ "            ...\n"
+#~ "        &lt;/join&gt;\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "    &lt;subclass name=\"CashPayment\" discriminator-value=\"CASH\"&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "    &lt;subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE"
+#~ "\"&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"payment\" column=\"PAYMENT_ID\" class="
+#~ "\"Payment\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"payment\" column=\"PAYMENT_ID\" class=\"Payment\"/"
+#~ "&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Payment\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
+#~ "        <generator class=\"sequence\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"amount\" column=\"AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "    <union-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
+#~ "        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
+#~ "        ...\n"
+#~ "    </union-subclass>\n"
+#~ "    <union-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
+#~ "        ...\n"
+#~ "    </union-subclass>\n"
+#~ "    <union-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
+#~ "        ...\n"
+#~ "    </union-subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Payment\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"sequence\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;union-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT"
+#~ "\"&gt;\n"
+#~ "        &lt;property name=\"creditCardType\" column=\"CCTYPE\"/&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/union-subclass&gt;\n"
+#~ "    &lt;union-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\"&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/union-subclass&gt;\n"
+#~ "    &lt;union-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT"
+#~ "\"&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/union-subclass&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"CASH_PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"CHEQUE_PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"CREDIT_AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"CashPayment\" table=\"CASH_PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"CASH_PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"CASH_AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"CHEQUE_PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"CHEQUE_AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<any name=\"payment\" meta-type=\"string\" id-type=\"long\">\n"
+#~ "    <meta-value value=\"CREDIT\" class=\"CreditCardPayment\"/>\n"
+#~ "    <meta-value value=\"CASH\" class=\"CashPayment\"/>\n"
+#~ "    <meta-value value=\"CHEQUE\" class=\"ChequePayment\"/>\n"
+#~ "    <column name=\"PAYMENT_CLASS\"/>\n"
+#~ "    <column name=\"PAYMENT_ID\"/>\n"
+#~ "</any>]]>"
+#~ msgstr ""
+#~ "&lt;any name=\"payment\" meta-type=\"string\" id-type=\"long\"&gt;\n"
+#~ "    &lt;meta-value value=\"CREDIT\" class=\"CreditCardPayment\"/&gt;\n"
+#~ "    &lt;meta-value value=\"CASH\" class=\"CashPayment\"/&gt;\n"
+#~ "    &lt;meta-value value=\"CHEQUE\" class=\"ChequePayment\"/&gt;\n"
+#~ "    &lt;column name=\"PAYMENT_CLASS\"/&gt;\n"
+#~ "    &lt;column name=\"PAYMENT_ID\"/&gt;\n"
+#~ "&lt;/any&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <discriminator column=\"CREDIT_CARD\" type=\"string\"/>\n"
+#~ "    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "    <subclass name=\"MasterCardPayment\" discriminator-value=\"MDC\"/>\n"
+#~ "    <subclass name=\"VisaPayment\" discriminator-value=\"VISA\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"NonelectronicTransaction\" table=\"NONELECTRONIC_TXN\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"TXN_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    ...\n"
+#~ "    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
+#~ "        <key column=\"PAYMENT_ID\"/>\n"
+#~ "        <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
+#~ "        ...\n"
+#~ "    </joined-subclass>\n"
+#~ "    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
+#~ "        <key column=\"PAYMENT_ID\"/>\n"
+#~ "        <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
+#~ "        ...\n"
+#~ "    </joined-subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;discriminator column=\"CREDIT_CARD\" type=\"string\"/&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"CREDIT_AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;subclass name=\"MasterCardPayment\" discriminator-value=\"MDC\"/"
+#~ "&gt;\n"
+#~ "    &lt;subclass name=\"VisaPayment\" discriminator-value=\"VISA\"/&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"NonelectronicTransaction\" table=\"NONELECTRONIC_TXN"
+#~ "\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"TXN_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\"&gt;\n"
+#~ "        &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "        &lt;property name=\"amount\" column=\"CASH_AMOUNT\"/&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/joined-subclass&gt;\n"
+#~ "    &lt;joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT"
+#~ "\"&gt;\n"
+#~ "        &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "        &lt;property name=\"amount\" column=\"CHEQUE_AMOUNT\"/&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/joined-subclass&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid "<term>table per subclass</term>"
+#~ msgstr "<entry>table per subclass</entry>"
+
+#~ msgid "from Payment p"
+#~ msgstr "from Payment p"
+
+#~ msgid "supported"
+#~ msgstr "サポート"
+
+#~ msgid "&lt;any&gt;"
+#~ msgstr "&lt;any&gt;"
+
+#~ msgid "not supported"
+#~ msgstr "サポートしていません"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/performance.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/performance.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/performance.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,30 +1,30 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-08-17 20:22+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-20 14:25+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: performance.xml:29
 #, no-c-format
 msgid "Improving performance"
 msgstr "パフォーマンスの改善"
 
 #. Tag: title
-#: performance.xml:32
 #, no-c-format
 msgid "Fetching strategies"
 msgstr "フェッチ戦略"
 
 #. Tag: para
-#: performance.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate uses a <emphasis>fetching strategy</emphasis> to retrieve "
 "associated objects if the application needs to navigate the association. "
@@ -32,31 +32,28 @@
 "by a particular HQL or <literal>Criteria</literal> query."
 msgstr ""
 "<emphasis>フェッチ戦略</emphasis> は、アプリケーションが関連をナビゲートする"
-"必要がある ときに、Hibernateが関連オブジェクトを復元するために使用する戦略で"
-"す。フェッチ戦略はO/Rマッピングの メタデータに宣言するか、特定のHQL、 "
+"必要があるときに、 Hibernate が関連オブジェクトを復元するために使用する戦略で"
+"す。フェッチ戦略は O/R マッピングのメタデータに宣言するか、特定の HQL 、 "
 "<literal>Criteria</literal> クエリでオーバーライドします。"
 
 #. Tag: para
-#: performance.xml:41
 #, no-c-format
 msgid "Hibernate3 defines the following fetching strategies:"
-msgstr "Hibernate3は次に示すフェッチ戦略を定義しています。"
+msgstr "Hibernate3 は次に示すフェッチ戦略を定義しています:"
 
 #. Tag: para
-#: performance.xml:47
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Join fetching</emphasis>: Hibernate retrieves the associated "
 "instance or collection in the same <literal>SELECT</literal>, using an "
 "<literal>OUTER JOIN</literal>."
 msgstr ""
-"<emphasis>結合フェッチ</emphasis> - Hibernateは <literal>OUTER JOIN</"
-"literal> を使って、 関連するインスタンスやコレクションを1つの "
+"<emphasis>結合フェッチ</emphasis> - Hibernate は <literal>OUTER JOIN</"
+"literal> を使って、関連するインスタンスやコレクションを1つの "
 "<literal>SELECT</literal> で復元します。"
 
 #. Tag: para
-#: performance.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Select fetching</emphasis>: a second <literal>SELECT</literal> is "
 "used to retrieve the associated entity or collection. Unless you explicitly "
@@ -65,12 +62,11 @@
 msgstr ""
 "<emphasis>セレクトフェッチ</emphasis> - 2回目の <literal>SELECT</literal> で"
 "関連するエンティティやコレクションを復元します。 <literal>lazy=\"false\"</"
-"literal> で明示的に遅延フェッチを無効にしなければ、この2回目のselectは実際に "
-"関連にアクセスしたときのみ実行されるでしょう。"
+"literal> で明示的に遅延フェッチを無効にしなければ、この2回目の select は実際"
+"に関連にアクセスしたときのみ実行されるでしょう。"
 
 #. Tag: para
-#: performance.xml:63
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Subselect fetching</emphasis>: a second <literal>SELECT</literal> "
 "is used to retrieve the associated collections for all entities retrieved in "
@@ -80,13 +76,12 @@
 msgstr ""
 "<emphasis>サブセレクトフェッチ</emphasis> - 2回目の <literal>SELECT</"
 "literal> で、直前のクエリやフェッチで復元したすべての要素に関連するコレクショ"
-"ンを 復元します。 <literal>lazy=\"false\"</literal> で明示的に遅延フェッチを"
-"無効にしなければ、この2回目のselectは実際に 関連にアクセスしたときのみ実行さ"
-"れるでしょう。"
+"ンを復元します。 <literal>lazy=\"false\"</literal> で明示的に遅延フェッチを無"
+"効にしなければ、この2回目の select は実際に関連にアクセスしたときのみ実行され"
+"るでしょう。"
 
 #. Tag: para
-#: performance.xml:72
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Batch fetching</emphasis>: an optimization strategy for select "
 "fetching. Hibernate retrieves a batch of entity instances or collections in "
@@ -94,66 +89,60 @@
 "foreign keys."
 msgstr ""
 "<emphasis>バッチフェッチ</emphasis> - セレクトフェッチのための最適化された戦"
-"略 - Hibernateはエンティティのインスタンスやコレクションの一群を1回の "
+"略 - Hibernate はエンティティのインスタンスやコレクションの一群を1回の "
 "<literal>SELECT</literal> で復元します。これは主キーや外部キーのリストを指定"
-"することに により行います。"
+"することにより行います。"
 
 #. Tag: para
-#: performance.xml:81
 #, no-c-format
 msgid "Hibernate also distinguishes between:"
-msgstr "Hibernateは次に示す戦略とも区別をします。"
+msgstr "Hibernate は次に示す戦略とも区別をします: "
 
 #. Tag: para
-#: performance.xml:87
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Immediate fetching</emphasis>: an association, collection or "
 "attribute is fetched immediately when the owner is loaded."
 msgstr ""
 "<emphasis>即時フェッチ</emphasis> - 所有者のオブジェクトがロードされたとき"
-"に、 関連、コレクションは即時にフェッチされます。"
+"に、関連、コレクションは即時にフェッチされます。"
 
 #. Tag: para
-#: performance.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Lazy collection fetching</emphasis>: a collection is fetched when "
 "the application invokes an operation upon that collection. This is the "
 "default for collections."
 msgstr ""
 "<emphasis>遅延コレクションフェッチ</emphasis> - アプリケーションがコレクショ"
-"ンに 対して操作を行ったときにコレクションをフェッチします。 (これはコレクショ"
-"ンに対するデフォルトの動作です)"
+"ンに対して操作を行ったときにコレクションをフェッチします。(これはコレクション"
+"に対するデフォルトの動作です)"
 
 #. Tag: para
-#: performance.xml:100
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>\"Extra-lazy\" collection fetching</emphasis>: individual elements "
 "of the collection are accessed from the database as needed. Hibernate tries "
 "not to fetch the whole collection into memory unless absolutely needed. It "
 "is suitable for large collections."
 msgstr ""
-"<emphasis>\"特別な遅延\"コレクションフェッチ</emphasis> - コレクションの要素 "
-"1つ1つが独立して、必要なときにデータベースから取得されます。 Hibernateは必"
-"要ないならば、コレクション全体をメモリにフェッチすることは 避けます(とても大"
+"<emphasis>「特別な遅延」コレクションフェッチ</emphasis> - コレクションの要素"
+"1つ1つが独立して、必要なときにデータベースから取得されます。 Hibernate は必"
+"要ないならば、コレクション全体をメモリにフェッチすることは避けます(とても大"
 "きなコレクションに適しています)。"
 
 #. Tag: para
-#: performance.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Proxy fetching</emphasis>: a single-valued association is fetched "
 "when a method other than the identifier getter is invoked upon the "
 "associated object."
 msgstr ""
-"<emphasis>プロキシフェッチ</emphasis> - 単一値関連は、識別子のgetter以外の メ"
-"ソッドが関連オブジェクトで呼び出されるときにフェッチされます。"
+"<emphasis>プロキシフェッチ</emphasis> - 単一値関連は、識別子の getter 以外の"
+"メソッドが関連オブジェクトで呼び出されるときにフェッチされます。"
 
 #. Tag: para
-#: performance.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>\"No-proxy\" fetching</emphasis>: a single-valued association is "
 "fetched when the instance variable is accessed. Compared to proxy fetching, "
@@ -162,28 +151,26 @@
 "visible to the application. This approach requires buildtime bytecode "
 "instrumentation and is rarely necessary."
 msgstr ""
-"<emphasis>\"プロキシなし\"フェッチ</emphasis> - 単一値関連は、インスタンス変"
-"数に アクセスされたときにフェッチされます。プロキシフェッチと比較すると、この"
-"方法は 遅延の度合いが少ない(関連は識別子にアクセスしただけでもフェッチされま"
-"す) ですが、より透過的で、アプリケーションにプロキシが存在しないように見せま"
-"す。 この方法はビルド時のバイトコード組み込みが必要になり、使う場面はまれで"
+"<emphasis>「プロキシなし」フェッチ</emphasis> - 単一値関連は、インスタンス変"
+"数にアクセスされたときにフェッチされます。プロキシフェッチと比較すると、この"
+"方法は遅延の度合いが少ない(関連は識別子にアクセスしただけでもフェッチされま"
+"す)ですが、より透過的で、アプリケーションにプロキシが存在しないように見せま"
+"す。この方法はビルド時のバイトコード組み込みが必要になり、使う場面はまれで"
 "す。"
 
 #. Tag: para
-#: performance.xml:125
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Lazy attribute fetching</emphasis>: an attribute or single valued "
 "association is fetched when the instance variable is accessed. This approach "
 "requires buildtime bytecode instrumentation and is rarely necessary."
 msgstr ""
 "<emphasis>遅延属性フェッチ</emphasis> - 属性や単一値関連は、インスタンス変数"
-"にアクセスした ときにフェッチされます。この方法はビルド時のバイトコード組み込"
-"みが必要になり、 使う場面はまれです。"
+"にアクセスしたときにフェッチされます。この方法はビルド時のバイトコード組み込"
+"みが必要になり、使う場面はまれです。"
 
 #. Tag: para
-#: performance.xml:134
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We have two orthogonal notions here: <emphasis>when</emphasis> is the "
 "association fetched and <emphasis>how</emphasis> is it fetched. It is "
@@ -193,89 +180,67 @@
 "class."
 msgstr ""
 "二つの直行する概念があります: <emphasis>いつ</emphasis> 関連をフェッチする"
-"か、 そして、 <emphasis>どうやって</emphasis> フェッチするか(どんなSQLを使っ"
-"て)。 これらを混同しないでください! <literal>fetch</literal> はパフォーマン"
-"スチューニングに使います。 <literal>lazy</literal> はあるクラスの分離されたイ"
-"ンスタンスのうち、どのデータを常に 使用可能にするかの取り決めを定義します。"
+"か、そして、 <emphasis>どうやって</emphasis> フェッチするか(どんな SQL を"
+"使って)。これらを混同しないでください。 <literal>fetch</literal> はパフォー"
+"マンスチューニングに使います。 <literal>lazy</literal> はあるクラスの分離され"
+"たインスタンスのうち、どのデータを常に使用可能にするかの取り決めを定義しま"
+"す。"
 
 #. Tag: title
-#: performance.xml:143
 #, no-c-format
 msgid "Working with lazy associations"
 msgstr "遅延関連の働き"
 
 #. Tag: para
-#: performance.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "By default, Hibernate3 uses lazy select fetching for collections and lazy "
 "proxy fetching for single-valued associations. These defaults make sense for "
 "most associations in the majority of applications."
 msgstr ""
-"デフォルトでは、Hibernate3はコレクションに対しては遅延セレクトフェッチを使"
-"い、 単一値関連には遅延プロキシフェッチを使います。これらのデフォルト動作はほ"
-"ぼすべての アプリケーションのほぼすべての関連で意味があります。"
+"デフォルトでは、 Hibernate3 はコレクションに対しては遅延セレクトフェッチを使"
+"い、単一値関連には遅延プロキシフェッチを使います。これらのデフォルト動作はほ"
+"ぼすべてのアプリケーションのほぼすべての関連で意味があります。"
 
 #. Tag: para
-#: performance.xml:151
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you set <literal>hibernate.default_batch_fetch_size</literal>, Hibernate "
 "will use the batch fetch optimization for lazy fetching. This optimization "
 "can also be enabled at a more granular level."
 msgstr ""
 "<emphasis>注:</emphasis><literal>hibernate.default_batch_fetch_size</"
-"literal> をセットしたときは、Hibernateは 遅延フェッチのためのバッチフェッチ最"
-"適化を使うでしょう (この最適化はより細かいレベルで有効にすることも出来ま"
+"literal> をセットしたときは、 Hibernate は遅延フェッチのためのバッチフェッチ"
+"最適化を使うでしょう(この最適化はより細かいレベルで有効にすることも出来ま"
 "す)。"
 
 #. Tag: para
-#: performance.xml:158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please be aware that access to a lazy association outside of the context of "
 "an open Hibernate session will result in an exception. For example:"
 msgstr ""
 "しかし、遅延フェッチは知っておかなければならない一つの問題があります。 "
-"Hibernateのsessionをオープンしているコンテキストの外から遅延関連にアクセスす"
-"ると、 例外が発生します。例:"
+"Hibernate の session をオープンしているコンテキストの外から遅延関連にアクセス"
+"すると、例外が発生します。例:"
 
-#. Tag: programlisting
-#: performance.xml:164
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[s = sessions.openSession();\n"
-"Transaction tx = s.beginTransaction();\n"
-"            \n"
-"User u = (User) s.createQuery(\"from User u where u.name=:userName\")\n"
-"    .setString(\"userName\", userName).uniqueResult();\n"
-"Map permissions = u.getPermissions();\n"
-"\n"
-"tx.commit();\n"
-"s.close();\n"
-"\n"
-"Integer accessLevel = (Integer) permissions.get(\"accounts\");  // Error!]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:166
-#, fuzzy, no-c-format
-msgid ""
 "Since the permissions collection was not initialized when the "
 "<literal>Session</literal> was closed, the collection will not be able to "
 "load its state. <emphasis>Hibernate does not support lazy initialization for "
 "detached objects</emphasis>. This can be fixed by moving the code that reads "
 "from the collection to just before the transaction is committed."
 msgstr ""
-"<literal>Session</literal> がクローズされたとき、permissionsコレクションは 初"
-"期化されていないため、このコレクションは自身の状態をロードできません。 "
-"<emphasis>Hibernateは切り離されたオブジェクトの遅延初期化はサポート していま"
-"せん</emphasis> 。修正方法として、コレクションから読み込みを行うコードを トラ"
+"<literal>Session</literal> がクローズされたとき、 permissions コレクションは"
+"初期化されていないため、このコレクションは自身の状態をロードできません。 "
+"<emphasis>Hibernate は切り離されたオブジェクトの遅延初期化はサポートしていま"
+"せん</emphasis> 。修正方法として、コレクションから読み込みを行うコードをトラ"
 "ンザクションをコミットする直前に移動させます。"
 
 #. Tag: para
-#: performance.xml:174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, you can use a non-lazy collection or association, by "
 "specifying <literal>lazy=\"false\"</literal> for the association mapping. "
@@ -284,16 +249,15 @@
 "in your object model, Hibernate will fetch the entire database into memory "
 "in every transaction."
 msgstr ""
-"一方で、 <literal>lazy=\"false\"</literal> を関連マッピングに指定すること"
-"で、 遅延処理をしないコレクションや関連を使うことが出来ます。 しかしながら、"
-"遅延初期化はほぼすべてのコレクションや関連で使われることを 意図しています。も"
-"しあなたのオブジェクトモデルの中に遅延処理をしない関連を 多く定義してしまう"
-"と、Hibernateは最終的にはトランザクション毎に ほぼ完全なデータベースをメモリ"
-"の中にフェッチすることになるでしょう!"
+"一方で、 <literal>lazy=\"false\"</literal> を関連マッピングに指定することで、"
+"遅延処理をしないコレクションや関連を使うことが出来ます。しかしながら、遅延初"
+"期化はほぼすべてのコレクションや関連で使われることを意図しています。もしあな"
+"たのオブジェクトモデルの中に遅延処理をしない関連を多く定義してしまうと、 "
+"Hibernate は最終的にはトランザクション毎にほぼ完全なデータベースをメモリの中"
+"にフェッチすることになるでしょう。"
 
 #. Tag: para
-#: performance.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "On the other hand, you can use join fetching, which is non-lazy by nature, "
 "instead of select fetching in a particular transaction. We will now explain "
@@ -301,93 +265,67 @@
 "choosing a fetch strategy are identical for single-valued associations and "
 "collections."
 msgstr ""
-"他方では、特定のトランザクションにおいてセレクトフェッチの代わりに 結合フェッ"
-"チ(当然これは遅延処理ではなくなります)を選択したいことが 時々あります。これ"
-"からフェッチ戦略をカスタマイズする方法をお見せします。 Hibernate3では、フェッ"
-"チ戦略を選択する仕組みは単一値関連とコレクションで 変わりはありません。"
+"他方では、特定のトランザクションにおいてセレクトフェッチの代わりに結合フェッ"
+"チ(当然これは遅延処理ではなくなります)を選択したいことが時々あります。これ"
+"からフェッチ戦略をカスタマイズする方法をお見せします。 Hibernate3 では、"
+"フェッチ戦略を選択する仕組みは単一値関連とコレクションで変わりはありません。"
 
 #. Tag: title
-#: performance.xml:194
 #, no-c-format
 msgid "Tuning fetch strategies"
 msgstr "フェッチ戦略のチューニング"
 
 #. Tag: para
-#: performance.xml:196
 #, no-c-format
 msgid ""
 "Select fetching (the default) is extremely vulnerable to N+1 selects "
 "problems, so we might want to enable join fetching in the mapping document:"
 msgstr ""
-"セレクトフェッチ(デフォルト)はN+1セレクト問題という大きな弱点があるため、 "
-"マッピング定義で結合フェッチを有効にすることができます。"
+"セレクトフェッチ(デフォルト)は N+1 セレクト問題という大きな弱点があるため、"
+"マッピング定義で結合フェッチを有効にすることができます:"
 
-#. Tag: programlisting
-#: performance.xml:201
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"permissions\" \n"
-"            fetch=\"join\">\n"
-"    <key column=\"userId\"/>\n"
-"    <one-to-many class=\"Permission\"/>\n"
-"</set]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: performance.xml:203
-#, no-c-format
-msgid "<![CDATA[<many-to-one name=\"mother\" class=\"Cat\" fetch=\"join\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:205
 #, no-c-format
 msgid ""
 "The <literal>fetch</literal> strategy defined in the mapping document "
 "affects:"
 msgstr ""
 "マッピング定義で定義した <literal>フェッチ</literal> 戦略は次のものに影響しま"
-"す。"
+"す:"
 
 #. Tag: para
-#: performance.xml:211
 #, no-c-format
 msgid "retrieval via <literal>get()</literal> or <literal>load()</literal>"
 msgstr "<literal>get()</literal> や <literal>load()</literal> による復元"
 
 #. Tag: para
-#: performance.xml:216
 #, no-c-format
 msgid "retrieval that happens implicitly when an association is navigated"
 msgstr "関連にナビゲートしたときに発生する暗黙的な復元"
 
 #. Tag: para
-#: performance.xml:221
 #, no-c-format
 msgid "<literal>Criteria</literal> queries"
 msgstr "<literal>Criteria</literal> クエリ"
 
 #. Tag: para
-#: performance.xml:226
 #, no-c-format
 msgid "HQL queries if <literal>subselect</literal> fetching is used"
-msgstr "<literal>サブセレクト</literal> フェッチを使うHQLクエリ"
+msgstr "<literal>サブセレクト</literal> フェッチを使う HQL クエリ"
 
 #. Tag: para
-#: performance.xml:232
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Irrespective of the fetching strategy you use, the defined non-lazy graph is "
 "guaranteed to be loaded into memory. This might, however, result in several "
 "immediate selects being used to execute a particular HQL query."
 msgstr ""
 "たとえどんなフェッチ戦略を使ったとしても、遅延ではないグラフはメモリに読み込"
-"まれることが 保証されます。つまり、特定のHQLクエリを実行するためにいくつかの"
-"SELECT文が即時実行される ことがあるので注意してください。"
+"まれることが保証されます。つまり、特定の HQL クエリを実行するためにいくつか"
+"の SELECT 文が即時実行されることがあるので注意してください。"
 
 #. Tag: para
-#: performance.xml:238
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Usually, the mapping document is not used to customize fetching. Instead, we "
 "keep the default behavior, and override it for a particular transaction, "
@@ -396,64 +334,49 @@
 "the <literal>Criteria</literal> query API, you would use "
 "<literal>setFetchMode(FetchMode.JOIN)</literal>."
 msgstr ""
-"通常は、マッピング定義でフェッチのカスタマイズは行いません。 代わりに、デフォ"
-"ルトの動作のままにしておいて、HQLで <literal>left join fetch</literal> を 指"
-"定することで特定のトランザクションで動作をオーバーライドします。 これは"
-"Hibernateに初回のセレクトで外部結合を使って関連を先にフェッチするように指定し"
-"ています。 <literal>Criteria</literal> クエリのAPIでは、 "
+"通常は、マッピング定義でフェッチのカスタマイズは行いません。代わりに、デフォ"
+"ルトの動作のままにしておいて、 HQL で <literal>left join fetch</literal> を指"
+"定することで特定のトランザクションで動作をオーバーライドします。これは "
+"Hibernate に初回のセレクトで外部結合を使って関連を先にフェッチするように指定"
+"しています。 <literal>Criteria</literal> クエリの API では、 "
 "<literal>setFetchMode(FetchMode.JOIN)</literal> を使うことが出来ます。"
 
 #. Tag: para
-#: performance.xml:247
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want to change the fetching strategy used by <literal>get()</literal> "
 "or <literal>load()</literal>, you can use a <literal>Criteria</literal> "
 "query. For example:"
 msgstr ""
-"もし <literal>get()</literal> や <literal>load()</literal> で使われる フェッ"
-"チ戦略を変えたいと感じたときには、単純に <literal>Criteria</literal> クエリを"
+"もし <literal>get()</literal> や <literal>load()</literal> で使われるフェッチ"
+"戦略を変えたいと感じたときには、単純に <literal>Criteria</literal> クエリを"
 "使ってください。例:"
 
-#. Tag: programlisting
-#: performance.xml:253
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[User user = (User) session.createCriteria(User.class)\n"
-"                .setFetchMode(\"permissions\", FetchMode.JOIN)\n"
-"                .add( Restrictions.idEq(userId) )\n"
-"                .uniqueResult();]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:255
-#, fuzzy, no-c-format
-msgid ""
 "This is Hibernate's equivalent of what some ORM solutions call a \"fetch plan"
 "\"."
 msgstr ""
-"(これはいくつかのORMソリューションが\"fetch plan\"と呼んでいるものと同じで"
-"す。)"
+"(これはいくつかの ORM ソリューションが \"fetch plan\" と呼んでいるものと同じ"
+"です。)"
 
 #. Tag: para
-#: performance.xml:259
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A completely different approach to problems with N+1 selects is to use the "
 "second-level cache."
 msgstr ""
-"N+1セレクト問題を避けるためのまったく違う方法は、第2レベルキャッシュを使うこ"
+"N+1 セレクト問題を避けるためのまったく違う方法は、第2レベルキャッシュを使うこ"
 "とです。"
 
 #. Tag: title
-#: performance.xml:267
 #, no-c-format
 msgid "Single-ended association proxies"
 msgstr "単一端関連プロキシ"
 
 #. Tag: para
-#: performance.xml:269
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Lazy fetching for collections is implemented using Hibernate's own "
 "implementation of persistent collections. However, a different mechanism is "
@@ -462,27 +385,25 @@
 "proxies for persistent objects using runtime bytecode enhancement which is "
 "accessed via the CGLIB library."
 msgstr ""
-"コレクションの遅延フェッチは、Hibernate自身の実装による永続コレクションを使っ"
-"て 実現しています。しかし、単一端関連における遅延処理では、違う仕組みが 必要"
-"です。対象の関連エンティティはプロキシでなければなりません。Hibernateは (す"
-"ばらしいCGLIBライブラリによる)実行時のバイトコード拡張を 使って永続オブジェ"
-"クトの遅延初期化プロキシを実現しています。"
+"コレクションの遅延フェッチは、 Hibernate 自身の実装による永続コレクションを"
+"使って実現しています。しかし、単一端関連における遅延処理では、違う仕組みが必"
+"要です。対象の関連エンティティはプロキシでなければなりません。 Hibernate は"
+"(すばらしい CGLIB ライブラリによる)実行時のバイトコード拡張を使って永続オブ"
+"ジェクトの遅延初期化プロキシを実現しています。"
 
 #. Tag: para
-#: performance.xml:277
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "At startup, Hibernate3 generates proxies by default for all persistent "
 "classes and uses them to enable lazy fetching of <literal>many-to-one</"
 "literal> and <literal>one-to-one</literal> associations."
 msgstr ""
-"デフォルトでは、Hibernate3は(開始時に)すべての永続クラスのプロキシを生成"
-"し、 それらを使って、 <literal>many-to-one</literal> や <literal>one-to-one</"
-"literal> 関連の 遅延フェッチを可能にしています。"
+"デフォルトでは、 Hibernate3 は(開始時に)すべての永続クラスのプロキシを生成"
+"し、それらを使って、 <literal>many-to-one</literal> や <literal>one-to-one</"
+"literal> 関連の遅延フェッチを可能にしています。"
 
 #. Tag: para
-#: performance.xml:283
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The mapping file may declare an interface to use as the proxy interface for "
 "that class, with the <literal>proxy</literal> attribute. By default, "
@@ -491,36 +412,22 @@
 "constructor is recommended for all persistent classes</emphasis>."
 msgstr ""
 "マッピングファイルで <literal>proxy</literal> 属性によって、クラスのプロキシ"
-"インターフェイスとして 使うインターフェイスを宣言できます。デフォルトでは、"
-"Hibernateはそのクラスのサブクラスを使います。 <emphasis>プロキシクラスは少な"
-"くともパッケージ可視でデフォルトコンストラクタを実装しなければ ならないことに"
-"注意してください。すべての永続クラスにこのコンストラクタを推奨します!</"
+"インターフェースとして使うインターフェースを宣言できます。デフォルトでは、 "
+"Hibernate はそのクラスのサブクラスを使います。 <emphasis>プロキシクラスは少な"
+"くともパッケージ可視でデフォルトコンストラクタを実装しなければならないことに"
+"注意してください。すべての永続クラスにこのコンストラクタを推奨します。</"
 "emphasis>"
 
 #. Tag: para
-#: performance.xml:290
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are potential problems to note when extending this approach to "
 "polymorphic classes.For example:"
 msgstr ""
 "ポリモーフィズムのクラスに対してこの方法を適用するときにいくつか考慮すること"
-"があります。 例:"
+"があります。例:"
 
-#. Tag: programlisting
-#: performance.xml:294
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Cat\" proxy=\"Cat\">\n"
-"    ......\n"
-"    <subclass name=\"DomesticCat\">\n"
-"        .....\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:296
 #, no-c-format
 msgid ""
 "Firstly, instances of <literal>Cat</literal> will never be castable to "
@@ -529,41 +436,14 @@
 msgstr ""
 "第一に、 <literal>Cat</literal> のインスタンスは <literal>DomesticCat</"
 "literal> にキャストできません。たとえ基となるインスタンスが "
-"<literal>DomesticCat</literal> であったとしてもです。"
+"<literal>DomesticCat</literal> であったとしてもです:"
 
-#. Tag: programlisting
-#: performance.xml:302
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);  // instantiate a "
-"proxy (does not hit the db)\n"
-"if ( cat.isDomesticCat() ) {                  // hit the db to initialize "
-"the proxy\n"
-"    DomesticCat dc = (DomesticCat) cat;       // Error!\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:304
-#, fuzzy, no-c-format
 msgid "Secondly, it is possible to break proxy <literal>==</literal>:"
 msgstr "第二に、プロキシの <literal>==</literal> は成立しないことがあります。"
 
-#. Tag: programlisting
-#: performance.xml:308
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);            // "
-"instantiate a Cat proxy\n"
-"DomesticCat dc = \n"
-"        (DomesticCat) session.load(DomesticCat.class, id);  // acquire new "
-"DomesticCat proxy!\n"
-"System.out.println(cat==dc);                            // false]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:310
 #, no-c-format
 msgid ""
 "However, the situation is not quite as bad as it looks. Even though we now "
@@ -571,44 +451,33 @@
 "still be the same object:"
 msgstr ""
 "しかし、これは見かけほど悪い状況というわけではありません。たとえ異なったプロ"
-"キシオブジェクトへの 二つの参照があったとしても、基となるインスタンスは同じオ"
-"ブジェクトです。"
+"キシオブジェクトへの二つの参照があったとしても、基となるインスタンスは同じオ"
+"ブジェクトです:"
 
-#. Tag: programlisting
-#: performance.xml:315
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[cat.setWeight(11.0);  // hit the db to initialize the proxy\n"
-"System.out.println( dc.getWeight() );  // 11.0]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:317
-#, fuzzy, no-c-format
-msgid ""
 "Third, you cannot use a CGLIB proxy for a <literal>final</literal> class or "
 "a class with any <literal>final</literal> methods."
 msgstr ""
 "第三に、 <literal>final</literal> クラスや <literal>final</literal> メソッド"
-"を持つクラスに CGLIBプロキシを使えません。"
+"を持つクラスに CGLIB プロキシを使えません。"
 
 #. Tag: para
-#: performance.xml:322
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, if your persistent object acquires any resources upon instantiation "
 "(e.g. in initializers or default constructor), then those resources will "
 "also be acquired by the proxy. The proxy class is an actual subclass of the "
 "persistent class."
 msgstr ""
-"最後に、もし永続オブジェクトのインスタンス化時(例えば、初期化処理やデフォルト"
-"コンストラクタの中で) になんらかのリソースが必要となるなら、そのリソースもま"
-"たプロキシを通して取得されます。 実際には、プロキシクラスは永続クラスのサブク"
-"ラスです。"
+"最後に、もし永続オブジェクトのインスタンス化時 (例えば、初期化処理やデフォル"
+"トコンストラクタの中で) になんらかのリソースが必要となるなら、そのリソースも"
+"またプロキシを通して取得されます。実際には、プロキシクラスは永続クラスのサブ"
+"クラスです。"
 
 #. Tag: para
-#: performance.xml:328
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These problems are all due to fundamental limitations in Java's single "
 "inheritance model. To avoid these problems your persistent classes must each "
@@ -618,25 +487,12 @@
 "<literal>DomesticCatImpl</literal> implements the interface "
 "<literal>DomesticCat</literal>. For example:"
 msgstr ""
-"これらの問題はJavaの単一継承モデルの原理上の制限のためです。もしこれらの問題"
-"を避けたいのなら、 ビジネスメソッドを宣言したインターフェイスをそれぞれ永続ク"
-"ラスで実装しなければなりません。 マッピングファイルでこれらのインターフェイス"
-"を指定する必要があります。例:"
+"これらの問題は Java の単一継承モデルの原理上の制限のためです。もしこれらの問"
+"題を避けたいのなら、ビジネスメソッドを宣言したインターフェースをそれぞれ永続"
+"クラスで実装しなければなりません。マッピングファイルでこれらのインターフェー"
+"スを指定する必要があります。例:"
 
-#. Tag: programlisting
-#: performance.xml:336
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"CatImpl\" proxy=\"Cat\">\n"
-"    ......\n"
-"    <subclass name=\"DomesticCatImpl\" proxy=\"DomesticCat\">\n"
-"        .....\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:338
 #, fuzzy, no-c-format
 msgid ""
 "Then proxies for instances of <literal>Cat</literal> and "
@@ -645,32 +501,19 @@
 msgstr ""
 "第一に、 <literal>Cat</literal> のインスタンスは <literal>DomesticCat</"
 "literal> にキャストできません。たとえ基となるインスタンスが "
-"<literal>DomesticCat</literal> であったとしてもです。"
+"<literal>DomesticCat</literal> であったとしてもです:"
 
-#. Tag: programlisting
-#: performance.xml:343
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(CatImpl.class, catid);\n"
-"Iterator iter = session.createQuery(\"from CatImpl as cat where cat."
-"name='fritz'\").iterate();\n"
-"Cat fritz = (Cat) iter.next();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:346
 #, no-c-format
 msgid "Note"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:347
 #, fuzzy, no-c-format
 msgid "<literal>list()</literal> does not usually return proxies."
-msgstr "<literal>Criteria</literal> クエリ"
+msgstr "<literal>full join</literal> (たいていの場合使いづらい)"
 
 #. Tag: para
-#: performance.xml:352
 #, no-c-format
 msgid ""
 "Relationships are also lazily initialized. This means you must declare any "
@@ -678,56 +521,50 @@
 "literal>."
 msgstr ""
 "関連も遅延初期化されます。これはプロパティを <literal>Cat</literal> 型で宣言"
-"しなければ ならないことを意味します。 <literal>CatImpl</literal> ではありませ"
+"しなければならないことを意味します。 <literal>CatImpl</literal> ではありませ"
 "ん。"
 
 #. Tag: para
-#: performance.xml:357
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Certain operations do <emphasis>not</emphasis> require proxy initialization:"
 msgstr ""
 "プロキシの初期化を <emphasis>必要としない</emphasis> 操作も存在します。"
 
 #. Tag: para
-#: performance.xml:363
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>equals()</literal>: if the persistent class does not override "
 "<literal>equals()</literal>"
 msgstr ""
-"<literal>equals()</literal> (永続クラスが <literal>equals()</literal> を "
-"オーバーライドしないとき)"
+"<literal>equals()</literal> (永続クラスが <literal>equals()</literal> をオー"
+"バーライドしないとき)"
 
 #. Tag: para
-#: performance.xml:369
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>hashCode()</literal>: if the persistent class does not override "
 "<literal>hashCode()</literal>"
 msgstr ""
-"<literal>hashCode()</literal> (永続クラスが <literal>hashCode()</literal> "
-"を オーバーライドしないとき)"
+"<literal>hashCode()</literal> (永続クラスが <literal>hashCode()</literal> を"
+"オーバーライドしないとき)"
 
 #. Tag: para
-#: performance.xml:375
 #, no-c-format
 msgid "The identifier getter method"
-msgstr "識別子のgetterメソッド"
+msgstr "識別子の getter メソッド"
 
 #. Tag: para
-#: performance.xml:381
 #, no-c-format
 msgid ""
 "Hibernate will detect persistent classes that override <literal>equals()</"
 "literal> or <literal>hashCode()</literal>."
 msgstr ""
-"Hibernateは <literal>equals()</literal> や <literal>hashCode()</literal> を"
-"オーバーライドした 永続クラスを検出します。"
+"Hibernate は <literal>equals()</literal> や <literal>hashCode()</literal> を"
+"オーバーライドした永続クラスを検出します。"
 
 #. Tag: para
-#: performance.xml:386
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "By choosing <literal>lazy=\"no-proxy\"</literal> instead of the default "
 "<literal>lazy=\"proxy\"</literal>, you can avoid problems associated with "
@@ -735,19 +572,17 @@
 "all operations will result in immediate proxy initialization."
 msgstr ""
 "デフォルトの <literal>lazy=\"proxy\"</literal> の代わりに、 <literal>lazy="
-"\"no-proxy\"</literal> を 選んだことで、型変換に関連する問題を回避することが"
-"出来ます。 しかし、ビルド時のバイトコード組み込みが必要になり、どのような操作"
-"であっても、 ただちにプロキシの初期化を行うことになるでしょう。"
+"\"no-proxy\"</literal> を選んだことで、型変換に関連する問題を回避することが出"
+"来ます。しかし、ビルド時のバイトコード組み込みが必要になり、どのような操作で"
+"あっても、ただちにプロキシの初期化を行うことになるでしょう。"
 
 #. Tag: title
-#: performance.xml:396
 #, no-c-format
 msgid "Initializing collections and proxies"
 msgstr "コレクションとプロキシの初期化"
 
 #. Tag: para
-#: performance.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>LazyInitializationException</literal> will be thrown by Hibernate "
 "if an uninitialized collection or proxy is accessed outside of the scope of "
@@ -755,13 +590,12 @@
 "or having the reference to the proxy is in the detached state."
 msgstr ""
 "<literal>LazyInitializationException</literal> は、 <literal>Session</"
-"literal> のスコープ外から 初期化していないコレクションやプロキシにアクセスさ"
-"れたときに、Hibernateによってスローされます。 すなわち、コレクションやプロキ"
-"シへの参照を持つエンティティが分離された状態の時です。"
+"literal> のスコープ外から初期化していないコレクションやプロキシにアクセスされ"
+"たときに、 Hibernate によってスローされます。すなわち、コレクションやプロキシ"
+"への参照を持つエンティティが分離された状態の時です。"
 
 #. Tag: para
-#: performance.xml:404
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes a proxy or collection needs to be initialized before closing the "
 "<literal>Session</literal>. You can force initialization by calling "
@@ -770,14 +604,13 @@
 "and it is not convenient for generic code."
 msgstr ""
 "<literal>Session</literal> をクローズする前にプロキシやコレクションの初期化を"
-"確実に 行いたいときがあります。もちろん、 <literal>cat.getSex()</literal> や "
+"確実に行いたいときがあります。もちろん、 <literal>cat.getSex()</literal> や "
 "<literal>cat.getKittens().size()</literal> などを常に呼び出すことで初期化を強"
-"制することはできます。 しかしこれはコードを読む人を混乱させ、汎用的なコードと"
+"制することはできます。しかしこれはコードを読む人を混乱させ、汎用的なコードと"
 "いう点からも不便です。"
 
 #. Tag: para
-#: performance.xml:411
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The static methods <literal>Hibernate.initialize()</literal> and "
 "<literal>Hibernate.isInitialized()</literal>, provide the application with a "
@@ -787,17 +620,16 @@
 "literal> is still open. <literal>Hibernate.initialize( cat.getKittens() )</"
 "literal> has a similar effect for the collection of kittens."
 msgstr ""
-"staticメソッドの <literal>Hibernate.initialize()</literal> や "
+"static メソッドの <literal>Hibernate.initialize()</literal> や "
 "<literal>Hibernate.isInitialized()</literal> は遅延初期化のコレクションやプロ"
 "キシを扱うときに便利な方法をアプリケーションに提供します。 "
 "<literal>Hibernate.initialize(cat)</literal> は、 <literal>Session</literal> "
 "がオープンしている限りは <literal>cat</literal> プロキシを強制的に初期化しま"
-"す。 <literal>Hibernate.initialize( cat.getKittens() )</literal> はkittensコ"
-"レクションに対して同様の 効果があります。"
+"す。 <literal>Hibernate.initialize( cat.getKittens() )</literal> は kittens "
+"コレクションに対して同様の効果があります。"
 
 #. Tag: para
-#: performance.xml:420
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Another option is to keep the <literal>Session</literal> open until all "
 "required collections and proxies have been loaded. In some application "
@@ -809,15 +641,14 @@
 msgstr ""
 "別の選択肢として、必要なすべてのコレクションやプロキシがロードされるまで "
 "<literal>Session</literal> をオープンにしておく方法があります。いくつかのアプ"
-"リケーションの アーキテクチャでは、特にHibernateによるデータアクセスを行う"
-"コードと、それを使う コードが異なるアプリケーションのレイヤーや、物理的に異な"
-"るプロセッサのときには、 コレクションが初期化されるときに <literal>Session</"
-"literal> がオープンしていることを 保証する問題があります。この問題に対しては2"
-"つの基本的な方法があります。"
+"リケーションのアーキテクチャでは、特に Hibernate によるデータアクセスを行う"
+"コードと、それを使うコードが異なるアプリケーションのレイヤーや、物理的に異な"
+"るプロセッサのときには、コレクションが初期化されるときに <literal>Session</"
+"literal> がオープンしていることを保証する問題があります。この問題に対しては2"
+"つの基本的な方法があります:"
 
 #. Tag: para
-#: performance.xml:431
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In a web-based application, a servlet filter can be used to close the "
 "<literal>Session</literal> only at the end of a user request, once the "
@@ -829,18 +660,17 @@
 "rendering of the view. See the Hibernate Wiki for examples of this \"Open "
 "Session in View\" pattern."
 msgstr ""
-"Webベースのアプリケーションでは、 ビューのレンダリングが完了し、リクエストが"
+"Web ベースのアプリケーションでは、ビューのレンダリングが完了し、リクエストが"
 "終わる一番最後で <literal>Session</literal> をクローズするために、サーブレッ"
 "トフィルタを使うことができます( <emphasis>Open Session in View</emphasis> パ"
 "ターンです)。もちろん、アプリケーション基盤の例外処理の正確性が非常に重要に"
-"なります。 ビューのレンダリング中に例外が発生したときでさえ、ユーザに処理が戻"
-"る前に <literal>Session</literal> のクローズとトランザクションの終了を行う こ"
-"とが不可欠になります。 HibernateのWikiに載っている\"Open Session in View\"パ"
-"ターンの例を参照してください。"
+"なります。ビューのレンダリング中に例外が発生したときでさえ、ユーザーに処理が"
+"戻る前に <literal>Session</literal> のクローズとトランザクションの終了を行う"
+"ことが不可欠になります。 Hibernate の Wiki に載っている \"Open Session in "
+"View\" パターンの例を参照してください。"
 
 #. Tag: para
-#: performance.xml:444
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In an application with a separate business tier, the business logic must "
 "\"prepare\" all collections that the web tier needs before returning. This "
@@ -854,21 +684,20 @@
 "literal>. This is usually easier if you adopt the <emphasis>Command</"
 "emphasis> pattern instead of a <emphasis>Session Facade</emphasis>."
 msgstr ""
-"ビジネス層が分離しているアプリケーションでは、ビジネスロジックは Web層で必要"
-"になるすべてのコレクションを事前に\"準備\"する必要があります。 これは特定の"
-"ユースケースで必要となるプレゼンテーション/Web層に対し、 ビジネス層がすべての"
-"データをロードし、すべてのデータを初期化して返すべきと いうことを意味していま"
-"す。通常は、アプリケーションはWeb層で必要なコレクション それぞれに対して "
-"<literal>Hibernate.initialize()</literal> を呼び出すか (この呼び出しはセッ"
-"ションをクローズする前に行う必要があります)、 Hibernateクエリの "
+"ビジネス層が分離しているアプリケーションでは、ビジネスロジックは Web 層で必要"
+"になるすべてのコレクションを事前に「準備」する必要があります。これは特定の"
+"ユースケースで必要となるプレゼンテーション/ Web 層に対し、ビジネス層がすべて"
+"のデータをロードし、すべてのデータを初期化して返すべきということを意味してい"
+"ます。通常は、アプリケーションは Web 層で必要なコレクションそれぞれに対して "
+"<literal>Hibernate.initialize()</literal> を呼び出すか(この呼び出しはセッ"
+"ションをクローズする前に行う必要があります)、 Hibernate クエリの "
 "<literal>FETCH</literal> 節や <literal>Criteria</literal> の "
-"<literal>FetchMode.JOIN</literal> を使ってコレクションを先に復元します。 普通"
+"<literal>FetchMode.JOIN</literal> を使ってコレクションを先に復元します。普通"
 "は <emphasis>Session Facade</emphasis> パターンの代わりに <emphasis>Command</"
 "emphasis> パターンを採用するほうがより簡単です。"
 
 #. Tag: para
-#: performance.xml:459
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also attach a previously loaded object to a new <literal>Session</"
 "literal> with <literal>merge()</literal> or <literal>lock()</literal> before "
@@ -879,41 +708,30 @@
 "初期化されていないコレクション(もしくは他のプロキシ)にアクセスする前に、 "
 "<literal>merge()</literal> や <literal>lock()</literal> を使って新しい "
 "<literal>Session</literal> に以前にロードされたオブジェクトを追加することも出"
-"来ます。 アドホックなトランザクションのセマンティクスを導入したので、"
-"Hibernateは これを自動的に行わず、 <emphasis>行うべきでもありません</"
-"emphasis> !"
+"来ます。アドホックなトランザクションのセマンティクスを導入したので、 "
+"Hibernate はこれを自動的に行わず、 <emphasis>行うべきでもありません</"
+"emphasis> 。"
 
 #. Tag: para
-#: performance.xml:469
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes you do not want to initialize a large collection, but still need "
 "some information about it, like its size, for example, or a subset of the "
 "data."
 msgstr ""
 "大きなコレクションを初期化したくはないが、コレクションについてのなんらかの情"
-"報(サイズのような) やデータのサブセットを必要とすることがあります。"
+"報(サイズのような)やデータのサブセットを必要とすることがあります。"
 
 #. Tag: para
-#: performance.xml:474
 #, no-c-format
 msgid ""
 "You can use a collection filter to get the size of a collection without "
 "initializing it:"
 msgstr ""
 "コレクションフィルタを使うことで、初期化せずにコレクションのサイズを取得する"
-"ことが出来ます。"
+"ことが出来ます:"
 
-#. Tag: programlisting
-#: performance.xml:478
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) s.createFilter( collection, \"select count(*)\" ).list"
-"().get(0) ).intValue()]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:480
 #, no-c-format
 msgid ""
 "The <literal>createFilter()</literal> method is also used to efficiently "
@@ -921,40 +739,29 @@
 "collection:"
 msgstr ""
 "<literal>createFilter()</literal> メソッドは、コレクション全体を初期化する必"
-"要なしに、コレクションの サブセットを復元するために効果的に使えます。"
+"要なしに、コレクションのサブセットを復元するために効果的に使えます:"
 
-#. Tag: programlisting
-#: performance.xml:485
-#, no-c-format
-msgid ""
-"<![CDATA[s.createFilter( lazyCollection, \"\").setFirstResult(0)."
-"setMaxResults(10).list();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:490
 #, no-c-format
 msgid "Using batch fetching"
 msgstr "バッチフェッチの使用"
 
 #. Tag: para
-#: performance.xml:492
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Using batch fetching, Hibernate can load several uninitialized proxies if "
 "one proxy is accessed. Batch fetching is an optimization of the lazy select "
 "fetching strategy. There are two ways you can configure batch fetching: on "
 "the class level and the collection level."
 msgstr ""
-"Hibernateはバッチフェッチを効率的に使用できます。一つのプロキシ(もしくはコレ"
-"クション)がアクセス されると、Hibernateはいくつかの初期化していないプロキシ"
-"をロードすることができます。バッチフェッチは 遅延セレクトフェッチ戦略に対する"
-"最適化です。バッチフェッチの調整には2つの方法があります。 クラスレベルとコレ"
-"クションレベルです。"
+"Hibernate はバッチフェッチを効率的に使用できます。一つのプロキシ(もしくはコ"
+"レクション)がアクセスされると、 Hibernate はいくつかの初期化していないプロキ"
+"シをロードすることができます。バッチフェッチは遅延セレクトフェッチ戦略に対す"
+"る最適化です。バッチフェッチの調整には2つの方法があります。クラスレベルとコ"
+"レクションレベルです。"
 
 #. Tag: para
-#: performance.xml:498
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Batch fetching for classes/entities is easier to understand. Consider the "
 "following example: at runtime you have 25 <literal>Cat</literal> instances "
@@ -969,33 +776,25 @@
 msgstr ""
 "クラス、要素のバッチフェッチは理解が簡単です。実行時の次の場面を想像してくだ"
 "さい。 <literal>Session</literal> にロードされた25個の <literal>Cat</"
-"literal> インスタンスが存在し、 それぞれの <literal>Cat</literal> は "
+"literal> インスタンスが存在し、それぞれの <literal>Cat</literal> は "
 "<literal>owner</literal> である <literal>Person</literal> への関連を持ちま"
 "す。 <literal>Person</literal> クラスは <literal>lazy=\"true\"</literal> のプ"
-"ロキシでマッピングされています。 もし今すべてのCatに対して繰り返し "
-"<literal>getOwner()</literal> を呼び出すと、Hibernateは デフォルトでは25回の "
-"<literal>SELECT</literal> を実行し、ownerプロキシの復元をします。 この振る舞"
-"いを <literal>Person</literal> のマッピングの <literal>batch-size</literal> "
-"の指定で調整できます。"
+"ロキシでマッピングされています。もし今すべての Cat に対して繰り返し "
+"<literal>getOwner()</literal> を呼び出すと、 Hibernate はデフォルトでは25回"
+"の <literal>SELECT</literal> を実し、 owner プロキシの復元をします。この振る"
+"舞いを <literal>Person</literal> のマッピングの <literal>batch-size</"
+"literal> の指定で調整できます。"
 
-#. Tag: programlisting
-#: performance.xml:508
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[<class name=\"Person\" batch-size=\"10\">...</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:510
-#, fuzzy, no-c-format
 msgid ""
 "Hibernate will now execute only three queries: the pattern is 10, 10, 5."
 msgstr ""
-"Hibernateはクエリを3回だけを実行するようになります。パターンは10, 10, 5で"
+"Hibernate はクエリを3回だけを実行するようになります。パターンは 10, 10, 5 で"
 "す。"
 
 #. Tag: para
-#: performance.xml:514
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also enable batch fetching of collections. For example, if each "
 "<literal>Person</literal> has a lazy collection of <literal>Cat</literal>s, "
@@ -1007,25 +806,14 @@
 msgstr ""
 "コレクションのバッチフェッチも有効にすることが出来ます。例として、それぞれの "
 "<literal>Person</literal> が <literal>Cat</literal> の遅延コレクションを持っ"
-"ており、 10個のPersonが <literal>Sesssion</literal> にロードされたとすると、"
-"すべてのPersonに 対して繰り返し <literal>getCats()</literal> を呼び出すこと"
-"で、計10回の <literal>SELECT</literal> が発生します。もし <literal>Person</"
-"literal> のマッピングで <literal>cats</literal> コレクションのバッチフェッチ"
-"を有効にすれば、Hibernateはコレクションの事前フェッチが出来ます。"
+"ており、 10 個の Person が <literal>Sesssion</literal> にロードされたとする"
+"と、すべての Person に対して繰り返し <literal>getCats()</literal> を呼び出す"
+"ことで、計10回の <literal>SELECT</literal> が発生します。もし "
+"<literal>Person</literal> のマッピングで <literal>cats</literal> コレクション"
+"のバッチフェッチを有効にすれば、 Hibernate はコレクションの事前フェッチが出来"
+"ます。"
 
-#. Tag: programlisting
-#: performance.xml:523
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <set name=\"cats\" batch-size=\"3\">\n"
-"        ...\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:525
 #, no-c-format
 msgid ""
 "With a <literal>batch-size</literal> of 3, Hibernate will load 3, 3, 3, 1 "
@@ -1033,53 +821,106 @@
 "attribute depends on the expected number of uninitialized collections in a "
 "particular <literal>Session</literal>."
 msgstr ""
-"<literal>batch-size</literal> が3なので、Hibernateは4回の <literal>SELECT</"
-"literal> で3個、3個、3個、1個をロードします。繰り返すと、属性の値は特定の "
-"<literal>Session</literal> の中の初期化されていないコレクションの期待数に依存"
-"します。"
+"<literal>batch-size</literal> が 3 なので、 Hibernate は 4 回の "
+"<literal>SELECT</literal> で 3 個、 3 個、 3 個、 1 個をロードします。繰り返"
+"すと、属性の値は特定の <literal>Session</literal> の中の初期化されていないコ"
+"レクションの期待数に依存します。"
 
 #. Tag: para
-#: performance.xml:531
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Batch fetching of collections is particularly useful if you have a nested "
 "tree of items, i.e. the typical bill-of-materials pattern. However, a "
 "<emphasis>nested set</emphasis> or a <emphasis>materialized path</emphasis> "
 "might be a better option for read-mostly trees."
 msgstr ""
-"コレクションのバッチフェッチはアイテムのネストしたツリー、 すなわち、代表的な"
-"部品表のパターンが ある場合に特に有用です。(しかし、読み込みが多いツリーで"
-"は <emphasis>ネストしたset</emphasis> や <emphasis>具体化したパス</emphasis> "
-"がよりよい選択になります。)"
+"コレクションのバッチフェッチはアイテムのネストしたツリー、すなわち、代表的な"
+"部品表のパターンがある場合に特に有用です。(しかし、読み込みが多いツリーでは "
+"<emphasis>ネストした set</emphasis> や <emphasis>具体化したパス</emphasis> が"
+"よりよい選択になります。)"
 
 #. Tag: title
-#: performance.xml:540
 #, no-c-format
 msgid "Using subselect fetching"
 msgstr "サブセレクトフェッチの使用"
 
 #. Tag: para
-#: performance.xml:542
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If one lazy collection or single-valued proxy has to be fetched, Hibernate "
 "will load all of them, re-running the original query in a subselect. This "
 "works in the same way as batch-fetching but without the piecemeal loading."
 msgstr ""
-"一つの遅延コレクションや単一値プロキシがフェッチされなければいけないとき、"
-"Hibernateは それらすべてをロードし、サブセレクトのオリジナルクエリが再度実行"
-"されます。これは バッチフェッチと同じ方法で動き、少しずつのロードは行いませ"
+"一つの遅延コレクションや単一値プロキシがフェッチされなければいけないとき、 "
+"Hibernate はそれらすべてをロードし、サブセレクトのオリジナルクエリが再度実行"
+"されます。これはバッチフェッチと同じ方法で動き、少しずつのロードは行いませ"
 "ん。"
 
 #. Tag: title
-#: performance.xml:553
+#, fuzzy, no-c-format
+msgid "Fetch profiles"
+msgstr "フェッチ戦略"
+
+#. Tag: para
 #, no-c-format
+msgid ""
+"Another way to affect the fetching strategy for loading associated objects "
+"is through something called a fetch profile, which is a named configuration "
+"associated with the <interfacename>org.hibernate.SessionFactory</"
+"interfacename> but enabled, by name, on the <interfacename>org.hibernate."
+"Session</interfacename>. Once enabled on a <interfacename>org.hibernate."
+"Session</interfacename>, the fetch profile wull be in affect for that "
+"<interfacename>org.hibernate.Session</interfacename> until it is explicitly "
+"disabled."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"So what does that mean? Well lets explain that by way of an example. Say we "
+"have the following mappings:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Now normally when you get a reference to a particular customer, that "
+"customer's set of orders will be lazy meaning we will not yet have loaded "
+"those orders from the database. Normally this is a good thing. Now lets say "
+"that you have a certain use case where it is more efficient to load the "
+"customer and their orders together. One way certainly is to use \"dynamic "
+"fetching\" strategies via an HQL or criteria queries. But another option is "
+"to use a fetch profile to achieve that. Just add the following to your "
+"mapping:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "or even:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Now the following code will actually load both the customer <emphasis>and "
+"their orders</emphasis>:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Currently only join style fetch profiles are supported, but they plan is to "
+"support additional styles. See <ulink url=\"http://opensource.atlassian.com/"
+"projects/hibernate/browse/HHH-3414\">HHH-3414</ulink> for details."
+msgstr ""
+
+#. Tag: title
+#, no-c-format
 msgid "Using lazy property fetching"
 msgstr "遅延プロパティフェッチの使用"
 
 #. Tag: para
-#: performance.xml:555
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 supports the lazy fetching of individual properties. This "
 "optimization technique is also known as <emphasis>fetch groups</emphasis>. "
@@ -1089,110 +930,67 @@
 "when legacy tables have hundreds of columns and the data model cannot be "
 "improved."
 msgstr ""
-"Hibernate3はプロパティごとの遅延フェッチをサポートしています。この最適化手法"
+"Hibernate3 はプロパティごとの遅延フェッチをサポートしています。この最適化手法"
 "は <emphasis>グループのフェッチ</emphasis> としても知られています。これはほと"
-"んど 要望から出た機能であることに注意してください。実際には列読み込みの最適化"
-"よりも、 行読み込みの最適化が非常に重要です。 しかし、クラスのいくつかのプロ"
-"パティだけを読み込むことは、既存のテーブルが何百もの列を持ち、 データモデルを"
-"改善できないなどの極端な場合には有用です。"
+"んど要望から出た機能であることに注意してください。実際には列読み込みの最適化"
+"よりも、行読み込みの最適化が非常に重要です。しかし、クラスのいくつかのプロパ"
+"ティだけを読み込むことは、既存のテーブルが何百もの列を持ち、データモデルを改"
+"善できないなどの極端な場合には有用です。"
 
 #. Tag: para
-#: performance.xml:564
 #, no-c-format
 msgid ""
 "To enable lazy property loading, set the <literal>lazy</literal> attribute "
 "on your particular property mappings:"
 msgstr ""
 "遅延プロパティ読み込みを有効にするには、対象のプロパティのマッピングで "
-"<literal>lazy</literal> 属性をセットしてください。"
+"<literal>lazy</literal> 属性をセットしてください:"
 
-#. Tag: programlisting
-#: performance.xml:569
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Document\">\n"
-"       <id name=\"id\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\" length=\"50\"/>\n"
-"    <property name=\"summary\" not-null=\"true\" length=\"200\" lazy=\"true"
-"\"/>\n"
-"    <property name=\"text\" not-null=\"true\" length=\"2000\" lazy=\"true\"/"
-">\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:571
-#, fuzzy, no-c-format
-msgid ""
 "Lazy property loading requires buildtime bytecode instrumentation. If your "
 "persistent classes are not enhanced, Hibernate will ignore lazy property "
 "settings and return to immediate fetching."
 msgstr ""
-"遅延プロパティ読み込みはビルド時のバイトコード組み込みを必要とします!もし 永"
-"続クラスに組み込みがされていないなら、Hibernateは黙って遅延プロパティの設定を"
-"無視して、 即時フェッチに戻します。"
+"遅延プロパティ読み込みはビルド時のバイトコード組み込みを必要とします。もし永"
+"続クラスに組み込みがされていないなら、 Hibernate は黙って遅延プロパティの設定"
+"を無視して、即時フェッチに戻します。"
 
 #. Tag: para
-#: performance.xml:577
 #, no-c-format
 msgid "For bytecode instrumentation, use the following Ant task:"
-msgstr "バイトコード組み込みは以下のAntタスクを使ってください。"
+msgstr "バイトコード組み込みは以下の Ant タスクを使ってください: "
 
-#. Tag: programlisting
-#: performance.xml:581
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<target name=\"instrument\" depends=\"compile\">\n"
-"    <taskdef name=\"instrument\" classname=\"org.hibernate.tool.instrument."
-"InstrumentTask\">\n"
-"        <classpath path=\"${jar.path}\"/>\n"
-"        <classpath path=\"${classes.dir}\"/>\n"
-"        <classpath refid=\"lib.class.path\"/>\n"
-"    </taskdef>\n"
-"\n"
-"    <instrument verbose=\"true\">\n"
-"        <fileset dir=\"${testclasses.dir}/org/hibernate/auction/model\">\n"
-"            <include name=\"*.class\"/>\n"
-"        </fileset>\n"
-"    </instrument>\n"
-"</target>]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:583
-#, fuzzy, no-c-format
-msgid ""
 "A different way of avoiding unnecessary column reads, at least for read-only "
 "transactions, is to use the projection features of HQL or Criteria queries. "
 "This avoids the need for buildtime bytecode processing and is certainly a "
 "preferred solution."
 msgstr ""
-"不要な列を読み込まないための、別の(よりよい?)方法は、少なくとも 読み込みの"
-"みのトランザクションにおいては、HQLやCriteriaクエリの射影 機能を使うことで"
-"す。この方法はビルド時のバイトコード組み込みが不要になり、 より良い解決方法で"
+"不要な列を読み込まないための、別の(よりよい?)方法は、少なくとも読み込みの"
+"みのトランザクションにおいては、 HQL や Criteria クエリの射影機能を使うことで"
+"す。この方法はビルド時のバイトコード組み込みが不要になり、より良い解決方法で"
 "す。"
 
 #. Tag: para
-#: performance.xml:590
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can force the usual eager fetching of properties using <literal>fetch "
 "all properties</literal> in HQL."
 msgstr ""
-"HQLで <literal>fetch all properties</literal> を使うことで、普通どおりの プロ"
+"HQL で <literal>fetch all properties</literal> を使うことで、普通どおりのプロ"
 "パティの即時フェッチングを強制することが出来ます。"
 
 #. Tag: title
-#: performance.xml:600
 #, no-c-format
 msgid "The Second Level Cache"
 msgstr "第2レベルキャッシュ"
 
 #. Tag: para
-#: performance.xml:602
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A Hibernate <literal>Session</literal> is a transaction-level cache of "
 "persistent data. It is possible to configure a cluster or JVM-level "
@@ -1202,16 +1000,16 @@
 "another application. They can, however, be configured to regularly expire "
 "cached data."
 msgstr ""
-"Hibernateの <literal>Session</literal> は永続データのトランザクションレベルの"
-"キャッシュです。 class-by-classとcollection-by-collectionごとの、クラスタレベ"
-"ルやJVMレベル ( <literal>SessionFactory</literal> レベル)のキャッシュを設定"
-"することが出来ます。 クラスタ化されたキャッシュにつなぐことさえ出来ます。しか"
-"し注意してください。 キャッシュは他のアプリケーションによる永続層の変更を 考"
-"慮しません(キャッシュデータを定期的に期限切れにする設定は出来ます)。"
+"Hibernate の <literal>Session</literal> は永続データのトランザクションレベル"
+"のキャッシュです。 class-by-class と collection-by-collection ごとの、クラス"
+"タレベルや JVM レベル ( <literal>SessionFactory</literal> レベル)のキャッ"
+"シュを設定することが出来ます。クラスタ化されたキャッシュにつなぐことさえ出来"
+"ます。しかし注意してください。キャッシュは他のアプリケーションによる永続層の"
+"変更を考慮しません(キャッシュデータを定期的に期限切れにする設定は出来ま"
+"す)。"
 
 #. Tag: para
-#: performance.xml:610
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You have the option to tell Hibernate which caching implementation to use by "
 "specifying the name of a class that implements <literal>org.hibernate.cache."
@@ -1221,190 +1019,156 @@
 "can also implement your own and plug it in as outlined above. Note that "
 "versions prior to 3.2 use EhCache as the default cache provider."
 msgstr ""
-"Hibernateが使用するキャッシュ実装は、<literal>hibernate.cache."
+"Hibernate が使用するキャッシュ実装は、 <literal>hibernate.cache."
 "provider_class</literal> プロパティに <literal>org.hibernate.cache."
 "CacheProvider</literal> を実装したクラス名を指定することで変更できます。 "
-"Hibernateは多くのオープンソースのキャッシュプロバイダをビルトイン実装で持って"
-"います(後にリストがあります)。 加えて、前に説明したように、あなた自身が独自"
-"の実装をして、それを組み込むことも出来ます。 バージョン3.2より前ではEhCacheが"
-"デフォルトのキャッシュプロバイダであることに注意してください。 バージョン3.2"
-"ではこれは当てはまりません。"
+"Hibernate は多くのオープンソースのキャッシュプロバイダをビルトイン実装で持っ"
+"ています(後にリストがあります)。加えて、前に説明したように、あなた自身が独"
+"自の実装をして、それを組み込むことも出来ます。バージョン3.2より前では "
+"EhCache がデフォルトのキャッシュプロバイダであることに注意してください。バー"
+"ジョン3.2ではこれは当てはまりません。"
 
 #. Tag: title
-#: performance.xml:621
 #, no-c-format
 msgid "Cache Providers"
 msgstr "キャッシュプロバイダ"
 
 #. Tag: entry
-#: performance.xml:630 performance.xml:818
 #, no-c-format
 msgid "Cache"
 msgstr "キャッシュ"
 
 #. Tag: entry
-#: performance.xml:631
 #, no-c-format
 msgid "Provider class"
 msgstr "プロバイダクラス"
 
 #. Tag: entry
-#: performance.xml:632
 #, no-c-format
 msgid "Type"
 msgstr "タイプ"
 
 #. Tag: entry
-#: performance.xml:633
 #, no-c-format
 msgid "Cluster Safe"
 msgstr "クラスタセーフ"
 
 #. Tag: entry
-#: performance.xml:634
 #, no-c-format
 msgid "Query Cache Supported"
 msgstr "クエリキャッシュのサポート"
 
 #. Tag: entry
-#: performance.xml:639 performance.xml:827
 #, no-c-format
 msgid "Hashtable (not intended for production use)"
 msgstr "Hashtable(製品用として意図していません)"
 
-#. Tag: literal
-#: performance.xml:640
-#, no-c-format
-msgid "org.hibernate.cache.HashtableCacheProvider"
-msgstr "org.hibernate.cache.HashtableCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.HashtableCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.HashtableCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:641
 #, no-c-format
 msgid "memory"
 msgstr "メモリ"
 
 #. Tag: entry
-#: performance.xml:643 performance.xml:650 performance.xml:657
-#: performance.xml:828 performance.xml:829 performance.xml:830
-#: performance.xml:835 performance.xml:836 performance.xml:837
-#: performance.xml:842 performance.xml:843 performance.xml:844
-#: performance.xml:849 performance.xml:850 performance.xml:856
-#: performance.xml:859 performance.xml:863 performance.xml:866
 #, no-c-format
-msgid "<entry>yes</entry>"
+msgid "yes"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:646 performance.xml:834
 #, no-c-format
 msgid "EHCache"
 msgstr "EHCache"
 
-#. Tag: literal
-#: performance.xml:647
-#, no-c-format
-msgid "org.hibernate.cache.EhCacheProvider"
-msgstr "org.hibernate.cache.EhCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.EhCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.EhCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:648 performance.xml:655
 #, no-c-format
 msgid "memory, disk"
 msgstr "メモリ、ディスク"
 
 #. Tag: entry
-#: performance.xml:653 performance.xml:841
 #, no-c-format
 msgid "OSCache"
 msgstr "OSCache"
 
-#. Tag: literal
-#: performance.xml:654
-#, no-c-format
-msgid "org.hibernate.cache.OSCacheProvider"
-msgstr "org.hibernate.cache.OSCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.OSCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.OSCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:660 performance.xml:848
 #, no-c-format
 msgid "SwarmCache"
 msgstr "SwarmCache"
 
-#. Tag: literal
-#: performance.xml:661
-#, no-c-format
-msgid "org.hibernate.cache.SwarmCacheProvider"
-msgstr "org.hibernate.cache.SwarmCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.SwarmCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.SwarmCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:662
 #, no-c-format
 msgid "clustered (ip multicast)"
-msgstr "クラスタ(ipマルチキャスト)"
+msgstr "クラスタ(ip マルチキャスト)"
 
 #. Tag: entry
-#: performance.xml:663
 #, no-c-format
 msgid "yes (clustered invalidation)"
 msgstr "yes(クラスタ無効化)"
 
 #. Tag: entry
-#: performance.xml:667 performance.xml:855
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "JBoss Cache 1.x"
-msgstr "JBoss TreeCache"
+msgstr ""
 
-#. Tag: literal
-#: performance.xml:668
-#, no-c-format
-msgid "org.hibernate.cache.TreeCacheProvider"
-msgstr "org.hibernate.cache.TreeCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.TreeCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.TreeCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:669 performance.xml:676
 #, no-c-format
 msgid "clustered (ip multicast), transactional"
-msgstr "クラスタ(ipマルチキャスト)、トランザクショナル"
+msgstr "クラスタ(ip マルチキャスト)、トランザクショナル"
 
 #. Tag: entry
-#: performance.xml:670
 #, no-c-format
 msgid "yes (replication)"
 msgstr "yes(複製)"
 
 #. Tag: entry
-#: performance.xml:671 performance.xml:678
 #, no-c-format
 msgid "yes (clock sync req.)"
 msgstr "yes(時刻同期が必要)"
 
 #. Tag: entry
-#: performance.xml:674 performance.xml:862
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "JBoss Cache 2"
-msgstr "JBoss TreeCache"
+msgstr ""
 
-#. Tag: literal
-#: performance.xml:675
+#. Tag: entry
 #, fuzzy, no-c-format
-msgid "org.hibernate.cache.jbc.JBossCacheRegionFactory"
-msgstr "org.hibernate.cache.EhCacheProvider"
+msgid "<literal>org.hibernate.cache.jbc.JBossCacheRegionFactory</literal>"
+msgstr "<literal>org.hibernate.cache.jbc2.JBossCacheRegionFactory</literal>"
 
 #. Tag: entry
-#: performance.xml:677
 #, fuzzy, no-c-format
 msgid "yes (replication or invalidation)"
 msgstr "yes(クラスタ無効化)"
 
 #. Tag: title
-#: performance.xml:685
 #, no-c-format
 msgid "Cache mappings"
 msgstr "キャッシュのマッピング"
 
 #. Tag: para
-#: performance.xml:687
 #, no-c-format
 msgid ""
 "The <literal>&lt;cache&gt;</literal> element of a class or collection "
@@ -1413,56 +1177,41 @@
 "クラスやコレクションのマッピングの <literal>&lt;cache&gt;</literal> 要素は以"
 "下の形式です。"
 
-#. Tag: programlisting
-#: performance.xml:698
-#, no-c-format
-msgid ""
-"<![CDATA[<cache \n"
-"    usage=\"transactional|read-write|nonstrict-read-write|read-only\"\n"
-"    region=\"RegionName\"\n"
-"    include=\"all|non-lazy\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:701
 #, no-c-format
 msgid ""
 "<literal>usage</literal> (required) specifies the caching strategy: "
 "<literal>transactional</literal>, <literal>read-write</literal>, "
 "<literal>nonstrict-read-write</literal> or <literal>read-only</literal>"
 msgstr ""
-"<literal>usage</literal> (required) specifies the caching strategy: "
-"<literal>transactional</literal>, <literal>read-write</literal>, "
-"<literal>nonstrict-read-write</literal> or <literal>read-only</literal>"
+"<literal>usage</literal> (必須) キャッシング戦略を指定します: "
+"<literal>transactional</literal>、 <literal>read-write</literal>、 "
+"<literal>nonstrict-read-write</literal> または <literal>read-only</literal>"
 
 #. Tag: para
-#: performance.xml:710
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>region</literal> (optional: defaults to the class or collection "
 "role name): specifies the name of the second level cache region"
 msgstr ""
-"<literal>region</literal> (optional, defaults to the class or collection "
-"role name) specifies the name of the second level cache region"
+"<literal>region</literal> (オプション、クラスまたはコレクションのロールネーム"
+"のデフォルト) 2次レベルのキャッシュ領域の名前を指定します"
 
 #. Tag: para
-#: performance.xml:717
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>include</literal> (optional: defaults to <literal>all</literal>) "
 "<literal>non-lazy</literal>: specifies that properties of the entity mapped "
 "with <literal>lazy=\"true\"</literal> cannot be cached when attribute-level "
 "lazy fetching is enabled"
 msgstr ""
-"<literal>include</literal> (optional, defaults to <literal>all</literal>) "
-"<literal>non-lazy</literal> specifies that properties of the entity mapped "
-"with <literal>lazy=\"true\"</literal> may not be cached when attribute-level "
-"lazy fetching is enabled"
+"<literal>include</literal> (オプション、 <literal>all</literal> に対してデ"
+"フォルト) <literal>non-lazy</literal> は、 属性レベルの lazy フェチが有効に"
+"なっている場合 <literal>lazy=\"true\"</literal> でマッピングされるエンティ"
+"ティのプロパティはキャッシュされなくてもよいことを指定します。"
 
 #. Tag: para
-#: performance.xml:727
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, you can specify <literal>&lt;class-cache&gt;</literal> and "
 "<literal>&lt;collection-cache&gt;</literal> elements in <literal>hibernate."
@@ -1473,7 +1222,6 @@
 "literal> 要素を指定することも出来ます。"
 
 #. Tag: para
-#: performance.xml:732
 #, no-c-format
 msgid ""
 "The <literal>usage</literal> attribute specifies a <emphasis>cache "
@@ -1483,14 +1231,12 @@
 "を指定します。"
 
 #. Tag: title
-#: performance.xml:739
 #, no-c-format
 msgid "Strategy: read only"
-msgstr "read only戦略"
+msgstr "read only 戦略"
 
 #. Tag: para
-#: performance.xml:741
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your application needs to read, but not modify, instances of a persistent "
 "class, a <literal>read-only</literal> cache can be used. This is the "
@@ -1499,28 +1245,16 @@
 msgstr ""
 "もしアプリケーションが読み込みのみ必要で、永続クラスのインスタンスを変更しな"
 "いなら、 <literal>read-only</literal> キャッシュを使うことが出来ます。これは"
-"もっとも単純で もっともパフォーマンスの良い戦略です。クラスタでの使用も完全に"
+"もっとも単純でもっともパフォーマンスの良い戦略です。クラスタでの使用も完全に"
 "安全です。"
 
-#. Tag: programlisting
-#: performance.xml:747
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Immutable\" mutable=\"false\">\n"
-"    <cache usage=\"read-only\"/>\n"
-"    ....\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:753
 #, no-c-format
 msgid "Strategy: read/write"
-msgstr "read/write戦略"
+msgstr "read/write 戦略"
 
 #. Tag: para
-#: performance.xml:755
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the application needs to update data, a <literal>read-write</literal> "
 "cache might be appropriate. This cache strategy should never be used if "
@@ -1535,40 +1269,25 @@
 "built-in cache providers <emphasis>do not</emphasis> support locking."
 msgstr ""
 "アプリケーションがデータを更新する必要があるなら、 <literal>read-write</"
-"literal> キャッシュが適当かも しれません。このキャッシュ戦略は、シリアライザ"
-"ブルなトランザクション分離レベルが要求されるなら、 決して使うべきではありませ"
-"ん。もしキャッシュがJTA環境で使われるなら、JTA <literal>TransactionManager</"
-"literal> を取得するための方法を示す <literal>hibernate.transaction."
-"manager_lookup_class</literal> プロパティを指定しなければなりません。他の環境"
-"では、 <literal>Session.close()</literal> や <literal>Session.disconnect()</"
-"literal> が呼ばれたときに、確実にトランザクションが完了 していなければなりま"
-"せん。 もしクラスタでこの戦略を使いたいなら、基となるキャッシュの実装がロック"
-"をサポート していることを保証しなければなりません。 組み込みのキャッシュプロ"
-"バイダは <emphasis>サポートしていません</emphasis> 。"
+"literal> キャッシュが適当かもしれません。このキャッシュ戦略は、シリアライザブ"
+"ルなトランザクション分離レベルが要求されるなら、決して使うべきではありませ"
+"ん。もしキャッシュが JTA 環境で使われるなら、 JTA "
+"<literal>TransactionManager</literal> を取得するための方法を示す "
+"<literal>hibernate.transaction.manager_lookup_class</literal> プロパティを指"
+"定しなければなりません。他の環境では、 <literal>Session.close()</literal> や "
+"<literal>Session.disconnect()</literal> が呼ばれたときに、確実にトランザク"
+"ションが完了していなければなりません。もしクラスタでこの戦略を使いたいなら、"
+"基となるキャッシュの実装がロックをサポートしていることを保証しなければなりま"
+"せん。組み込みのキャッシュプロバイダは <emphasis>サポートしていません</"
+"emphasis> 。"
 
-#. Tag: programlisting
-#: performance.xml:766
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Cat\" .... >\n"
-"    <cache usage=\"read-write\"/>\n"
-"    ....\n"
-"    <set name=\"kittens\" ... >\n"
-"        <cache usage=\"read-write\"/>\n"
-"        ....\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:771
 #, no-c-format
 msgid "Strategy: nonstrict read/write"
-msgstr "厳密ではないread/write戦略"
+msgstr "厳密ではない read/write 戦略"
 
 #. Tag: para
-#: performance.xml:773
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the application only occasionally needs to update data (i.e. if it is "
 "extremely unlikely that two transactions would try to update the same item "
@@ -1580,100 +1299,85 @@
 "</literal> or <literal>Session.disconnect()</literal> is called."
 msgstr ""
 "アプリケーションがたまにしかデータを更新する必要はなく(すなわち二つのトラン"
-"ザクションが 同時に同じアイテムを更新しようとすることはほとんど起こらない)、"
-"厳密なトランザクション分離が 要求されないなら、 <literal>nonstrict-read-"
-"write</literal> キャッシュが適当かもしれません。 もしキャッシュがJTA環境で使"
+"ザクションが同時に同じアイテムを更新しようとすることはほとんど起こらない)、"
+"厳密なトランザクション分離が要求されないなら、 <literal>nonstrict-read-"
+"write</literal> キャッシュが適当かもしれません。もしキャッシュが JTA 環境で使"
 "われるなら、 <literal>hibernate.transaction.manager_lookup_class</literal> を"
 "指定しなければなりません。他の環境では、 <literal>Session.close()</literal> "
 "や <literal>Session.disconnect()</literal> が呼ばれたときに、確実にトランザク"
-"ションが完了 していなければなりません。"
+"ションが完了していなければなりません。"
 
 #. Tag: title
-#: performance.xml:785
 #, no-c-format
 msgid "Strategy: transactional"
-msgstr "transactional戦略"
+msgstr "transactional 戦略"
 
 #. Tag: para
-#: performance.xml:787
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>transactional</literal> cache strategy provides support for "
 "fully transactional cache providers such as JBoss TreeCache. Such a cache "
 "can only be used in a JTA environment and you must specify "
 "<literal>hibernate.transaction.manager_lookup_class</literal>."
 msgstr ""
-"<literal>transactional</literal> キャッシュ戦略はJBoss TreeCacheのような完全"
-"なトランザクショナル キャッシュプロバイダのサポートを提供します。 このような"
-"キャッシュはJTA環境でのみ使用可能で、 <literal>hibernate.transaction."
+"<literal>transactional</literal> キャッシュ戦略は JBoss TreeCache のような完"
+"全なトランザクショナルキャッシュプロバイダのサポートを提供します。このような"
+"キャッシュは JTA 環境でのみ使用可能で、 <literal>hibernate.transaction."
 "manager_lookup_class</literal> を指定しなければなりません。"
 
 #. Tag: title
-#: performance.xml:796
 #, fuzzy, no-c-format
 msgid "Cache-provider/concurrency-strategy compatibility"
 msgstr "同時並行性キャッシュ戦略のサポート"
 
 #. Tag: para
-#: performance.xml:799
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "None of the cache providers support all of the cache concurrency strategies."
 msgstr ""
 "すべての同時並行性キャッシュ戦略をサポートしているキャッシュプロバイダはあり"
-"ません。 以下の表はどのプロバイダがどの同時並列性戦略に対応するかを表していま"
-"す。"
+"ません。"
 
 #. Tag: para
-#: performance.xml:804
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table shows which providers are compatible with which "
 "concurrency strategies."
 msgstr ""
-"すべての同時並行性キャッシュ戦略をサポートしているキャッシュプロバイダはあり"
-"ません。 以下の表はどのプロバイダがどの同時並列性戦略に対応するかを表していま"
-"す。"
+"以下の表はどのプロバイダがどの同時並列性戦略に対応するかを表しています。"
 
 #. Tag: title
-#: performance.xml:809
 #, no-c-format
 msgid "Cache Concurrency Strategy Support"
 msgstr "同時並行性キャッシュ戦略のサポート"
 
 #. Tag: entry
-#: performance.xml:819
 #, no-c-format
 msgid "read-only"
 msgstr "read-only"
 
 #. Tag: entry
-#: performance.xml:820
 #, no-c-format
 msgid "nonstrict-read-write"
-msgstr "厳密ではないread-write"
+msgstr "厳密ではない read-write"
 
 #. Tag: entry
-#: performance.xml:821
 #, no-c-format
 msgid "read-write"
 msgstr "read-write"
 
 #. Tag: entry
-#: performance.xml:822
 #, no-c-format
 msgid "transactional"
 msgstr "transactional"
 
 #. Tag: title
-#: performance.xml:877
 #, no-c-format
 msgid "Managing the caches"
 msgstr "キャッシュの管理"
 
 #. Tag: para
-#: performance.xml:879
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Whenever you pass an object to <literal>save()</literal>, <literal>update()</"
 "literal> or <literal>saveOrUpdate()</literal>, and whenever you retrieve an "
@@ -1686,12 +1390,11 @@
 "<literal>saveOrUpdate()</literal> に渡すとき、そして <literal>load()</"
 "literal> 、 <literal>get()</literal> 、 <literal>list()</literal> 、 "
 "<literal>iterate()</literal> 、 <literal>scroll()</literal> を使ってオブジェ"
-"クトを復元するときには常に、 そのオブジェクトは <literal>Session</literal> の"
+"クトを復元するときには常に、そのオブジェクトは <literal>Session</literal> の"
 "内部キャッシュに追加されます。"
 
 #. Tag: para
-#: performance.xml:886
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When <literal>flush()</literal> is subsequently called, the state of that "
 "object will be synchronized with the database. If you do not want this "
@@ -1701,26 +1404,12 @@
 "cache."
 msgstr ""
 "次に <literal>flush()</literal> が呼ばれると、オブジェクトの状態はデータベー"
-"スと同期化されます。 もしこの同期が起こることを望まないときや、膨大な数のオブ"
-"ジェクトを処理していてメモリを効率的に 扱う必要があるときは、 <literal>evict"
-"()</literal> メソッドを使って一次キャッシュから オブジェクトやコレクションを"
-"削除することが出来ます。"
+"スと同期化されます。もしこの同期が起こることを望まないときや、膨大な数のオブ"
+"ジェクトを処理していてメモリを効率的に扱う必要があるときは、 <literal>evict()"
+"</literal> メソッドを使って一次キャッシュからオブジェクトやコレクションを削除"
+"することが出来ます。"
 
-#. Tag: programlisting
-#: performance.xml:894
-#, no-c-format
-msgid ""
-"<![CDATA[ScrollableResult cats = sess.createQuery(\"from Cat as cat\").scroll"
-"(); //a huge result set\n"
-"while ( cats.next() ) {\n"
-"    Cat cat = (Cat) cats.get(0);\n"
-"    doSomethingWithACat(cat);\n"
-"    sess.evict(cat);\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:896
 #, no-c-format
 msgid ""
 "The <literal>Session</literal> also provides a <literal>contains()</literal> "
@@ -1730,52 +1419,36 @@
 "うかを判断するための <literal>contains()</literal> メソッドも提供します。"
 
 #. Tag: para
-#: performance.xml:901
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To evict all objects from the session cache, call <literal>Session.clear()</"
 "literal>"
 msgstr ""
-"すべてのオブジェクトをセッションキャッシュから完全に取り除くには、"
+"すべてのオブジェクトをセッションキャッシュから完全に取り除くには、 "
 "<literal>Session.clear()</literal> を呼び出してください。"
 
 #. Tag: para
-#: performance.xml:905
 #, no-c-format
 msgid ""
 "For the second-level cache, there are methods defined on "
 "<literal>SessionFactory</literal> for evicting the cached state of an "
 "instance, entire class, collection instance or entire collection role."
 msgstr ""
-"二次キャッシュのために、 <literal>SessionFactory</literal> には インスタン"
-"ス、クラス全体、コレクションのインスタンス、コレクション全体をキャッシュから "
-"削除するためのメソッドがそれぞれ定義されています。"
+"二次キャッシュのために、 <literal>SessionFactory</literal> にはインスタンス、"
+"クラス全体、コレクションのインスタンス、コレクション全体をキャッシュから削除"
+"するためのメソッドがそれぞれ定義されています。"
 
-#. Tag: programlisting
-#: performance.xml:911
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sessionFactory.evict(Cat.class, catId); //evict a particular Cat\n"
-"sessionFactory.evict(Cat.class);  //evict all Cats\n"
-"sessionFactory.evictCollection(\"Cat.kittens\", catId); //evict a particular "
-"collection of kittens\n"
-"sessionFactory.evictCollection(\"Cat.kittens\"); //evict all kitten "
-"collections]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:913
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>CacheMode</literal> controls how a particular session interacts "
 "with the second-level cache:"
 msgstr ""
 "<literal>CacheMode</literal> は特定のセッションが二次キャッシュとどのように相"
-"互作用するかを 指定します。"
+"互作用するかを指定します。"
 
 #. Tag: para
-#: performance.xml:920
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.NORMAL</literal>: will read items from and write items to "
 "the second-level cache"
@@ -1784,28 +1457,25 @@
 "キャッシュを使います"
 
 #. Tag: para
-#: performance.xml:925
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.GET</literal>: will read items from the second-level "
 "cache. Do not write to the second-level cache except when updating data"
 msgstr ""
 "<literal>CacheMode.GET</literal> - 読み込みは二次キャッシュから行いますが、"
-"データを 更新した場合を除いて二次キャッシュに書き込みをしません。"
+"データを更新した場合を除いて二次キャッシュに書き込みをしません。"
 
 #. Tag: para
-#: performance.xml:931
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.PUT</literal>: will write items to the second-level "
 "cache. Do not read from the second-level cache"
 msgstr ""
 "<literal>CacheMode.PUT</literal> - 二次キャッシュにアイテムを書き込みますが、"
-"読み込みには 二次キャッシュを使いません。"
+"読み込みには二次キャッシュを使いません。"
 
 #. Tag: para
-#: performance.xml:937
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.REFRESH</literal>: will write items to the second-level "
 "cache. Do not read from the second-level cache. Bypass the effect of "
@@ -1813,109 +1483,125 @@
 "second-level cache for all items read from the database"
 msgstr ""
 "<literal>CacheMode.REFRESH</literal> - 二次キャッシュにアイテムを書き込みます"
-"が、読み込みには 二次キャッシュを使わず、 <literal>hibernate.cache."
+"が、読み込みには二次キャッシュを使わず、 <literal>hibernate.cache."
 "use_minimal_puts</literal> の影響を受けずに、データベースから読み込むすべての"
 "アイテムの二次キャッシュを強制的にリフレッシュします。"
 
 #. Tag: para
-#: performance.xml:945
 #, no-c-format
 msgid ""
 "To browse the contents of a second-level or query cache region, use the "
 "<literal>Statistics</literal> API:"
 msgstr ""
 "二次キャッシュの内容やクエリキャッシュ領域を見るために、 "
-"<literal>Statistics</literal> APIを 使ってください。"
+"<literal>Statistics</literal> API を使ってください:"
 
-#. Tag: programlisting
-#: performance.xml:950
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Map cacheEntries = sessionFactory.getStatistics()\n"
-"        .getSecondLevelCacheStatistics(regionName)\n"
-"        .getEntries();]]>"
+"You will need to enable statistics and, optionally, force Hibernate to keep "
+"the cache entries in a more readable format:"
 msgstr ""
+"統計情報を有効にして、さらにオプションとして、キャッシュエントリを人がより理"
+"解可能な形式で保持することを Hibernate に強制します:"
 
+#. Tag: title
+#, no-c-format
+msgid "The Query Cache"
+msgstr "クエリキャッシュ"
+
 #. Tag: para
-#: performance.xml:952
 #, fuzzy, no-c-format
 msgid ""
-"You will need to enable statistics and, optionally, force Hibernate to keep "
-"the cache entries in a more readable format:"
+"Query result sets can also be cached. This is only useful for queries that "
+"are run frequently with the same parameters."
 msgstr ""
-"統計情報を有効にして、さらにオプションとして、キャッシュエントリを 人がより理"
-"解可能な形式で保持することをHibernateに強制します。"
+"クエリのリザルトセットもキャッシュ出来ます。これは同じパラメータで何度も実行"
+"されるクエリに対してのみ有用です。クエリキャッシュを使うには、まず設定で有効"
+"にしなくてはなりません:"
 
-#. Tag: programlisting
-#: performance.xml:957
+#. Tag: title
 #, no-c-format
+msgid "Enabling query caching"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
 msgid ""
-"<![CDATA[hibernate.generate_statistics true\n"
-"hibernate.cache.use_structured_entries true]]>"
+"Caching of query results introduces some overhead in terms of your "
+"applications normal transactional processing. For example, if you cache "
+"results of a query against Person Hibernate will need to keep track of when "
+"those results should be invalidated because changes have been committed "
+"against Person. That, coupled with the fact that most applications simply "
+"gain no benefit from caching query results, leads Hibernate to disable "
+"caching of query results by default. To use query caching, you will first "
+"need to enable the query cache:"
 msgstr ""
 
-#. Tag: title
-#: performance.xml:962
+#. Tag: para
 #, no-c-format
-msgid "The Query Cache"
-msgstr "クエリキャッシュ"
+msgid "This setting creates two new cache regions:"
+msgstr ""
 
 #. Tag: para
-#: performance.xml:964
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"Query result sets can also be cached. This is only useful for queries that "
-"are run frequently with the same parameters. You will first need to enable "
-"the query cache:"
+"<classname>org.hibernate.cache.StandardQueryCache</classname>, holding the "
+"cached query results"
 msgstr ""
-"クエリのリザルトセットもキャッシュ出来ます。これは同じパラメータで何度も実行"
-"される クエリに対してのみ有用です。クエリキャッシュを使うには、まず設定で有効"
-"にしなくてはなりません。"
 
-#. Tag: programlisting
-#: performance.xml:969
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[hibernate.cache.use_query_cache true]]>"
+msgid ""
+"<classname>org.hibernate.cache.UpdateTimestampsCache</classname>, holding "
+"timestamps of the most recent updates to queryable tables. These are used to "
+"validate the results as they are served from the query cache."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:971
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"This setting creates two new cache regions: one holding cached query result "
-"sets (<literal>org.hibernate.cache.StandardQueryCache</literal>), the other "
-"holding timestamps of the most recent updates to queryable tables "
-"(<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). Note that "
-"the query cache does not cache the state of the actual entities in the "
-"result set; it caches only identifier values and results of value type. The "
-"query cache should always be used in conjunction with the second-level cache."
+"If you configure your underlying cache implementation to use expiry or "
+"timeouts is is very important that the cache timeout of the underlying cache "
+"region for the UpdateTimestampsCache be set to a higher value than the "
+"timeouts of any of the query caches. In fact, we recommend that the the "
+"UpdateTimestampsCache region not be configured for expiry at all. Note, in "
+"particular, that an LRU cache expiry policy is never appropriate."
 msgstr ""
-"この設定は新たに二つのキャッシュ領域の作成を行います。一つはクエリのリザルト"
-"セットの キャッシュ( <literal>org.hibernate.cache.StandardQueryCache</"
-"literal> )を保持し、 もう1つはクエリ可能なテーブルへの最新の更新タイムスタン"
-"プ ( <literal>org.hibernate.cache.UpdateTimestampsCache</literal> )を保持し"
-"ます。 クエリキャッシュはリザルトセットの実際の要素の状態はキャッシュしないこ"
-"とに 注意してください。キャッシュするのは識別子の値と、値型の結果のみです。 "
-"そのため、クエリキャッシュは常に二次キャッシュと一緒に使うべきです。"
 
 #. Tag: para
-#: performance.xml:981
 #, fuzzy, no-c-format
 msgid ""
-"Most queries do not benefit from caching, so by default, queries are not "
-"cached. To enable caching, call <literal>Query.setCacheable(true)</literal>. "
-"This call allows the query to look for existing cache results or add its "
-"results to the cache when it is executed."
+"As mentioned above, most queries do not benefit from caching or their "
+"results. So by default, individual queries are not cached even after "
+"enabling query caching. To enable results caching for a particular query, "
+"call <literal>org.hibernate.Query.setCacheable(true)</literal>. This call "
+"allows the query to look for existing cache results or add its results to "
+"the cache when it is executed."
 msgstr ""
 "ほとんどのクエリはキャッシュの恩恵を受けないので、デフォルトではクエリは"
-"キャッシュされません。 キャッシュを有効にするには、 <literal>Query."
-"setCacheable(true)</literal> を呼び出してください。 そうすればクエリが既存の"
-"キャッシュ結果を探し、クエリ実行時にその結果をキャッシュに追加する ようになり"
+"キャッシュされません。キャッシュを有効にするには、 <literal>Query."
+"setCacheable(true)</literal> を呼び出してください。そうすればクエリが既存の"
+"キャッシュ結果を探し、クエリ実行時にその結果をキャッシュに追加するようになり"
 "ます。"
 
 #. Tag: para
-#: performance.xml:988
+#, no-c-format
+msgid ""
+"The query cache does not cache the state of the actual entities in the "
+"cache; it caches only identifier values and results of value type. For this "
+"reaso, the query cache should always be used in conjunction with the second-"
+"level cache for those entities expected to be cached as part of a query "
+"result cache (just as with collection caching)."
+msgstr ""
+
+#. Tag: title
 #, fuzzy, no-c-format
+msgid "Query cache regions"
+msgstr "クエリキャッシュのサポート"
+
+#. Tag: para
+#, no-c-format
 msgid ""
 "If you require fine-grained control over query cache expiration policies, "
 "you can specify a named cache region for a particular query by calling "
@@ -1925,47 +1611,33 @@
 "setCacheRegion()</literal> を呼び出して特定のクエリに対するキャッシュ領域を指"
 "定することが出来ます。"
 
-#. Tag: programlisting
-#: performance.xml:994
-#, no-c-format
-msgid ""
-"<![CDATA[List blogs = sess.createQuery(\"from Blog blog where blog.blogger "
-"= :blogger\")\n"
-"    .setEntity(\"blogger\", blogger)\n"
-"    .setMaxResults(15)\n"
-"    .setCacheable(true)\n"
-"    .setCacheRegion(\"frontpages\")\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:996
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"If the query should force a refresh of its query cache region, you should "
-"call <literal>Query.setCacheMode(CacheMode.REFRESH)</literal>. This is "
-"particularly useful in cases where underlying data may have been updated via "
-"a separate process (i.e., not modified through Hibernate) and allows the "
-"application to selectively refresh particular query result sets. This is a "
-"more efficient alternative to eviction of a query cache region via "
-"<literal>SessionFactory.evictQueries()</literal>."
+"If you want to force the query cache to refresh one of its regions "
+"(disregard any cached results it finds there) you can use <literal>org."
+"hibernate.Query.setCacheMode(CacheMode.REFRESH)</literal>. In conjunction "
+"with the region you have defined for the given query, Hibernate will "
+"selectively force the results cached in that particular region to be "
+"refreshed. This is particularly useful in cases where underlying data may "
+"have been updated via a separate process and is a far more efficient "
+"alternative to bulk eviction of the region via <literal>org.hibernate."
+"SessionFactory.evictQueries()</literal>."
 msgstr ""
 "クエリが自身のクエリキャッシュ領域のリフレッシュを強制しなければならないな"
 "ら、 <literal>Query.setCacheMode(CacheMode.REFRESH)</literal> を呼び出すべき"
-"です。これは 元となるデータが別のプロセスによって更新されたり(すなわち"
-"Hibernateを通じて更新されない)、 アプリケーションに特定のクエリリザルトセッ"
-"トを選択してリフレッシュさせる場合に特に有用です。 さらに有用なもう一つの方法"
+"です。これは元となるデータが別のプロセスによって更新されたり(すなわち "
+"Hibernate を通じて更新されない)、アプリケーションに特定のクエリリザルトセッ"
+"トを選択してリフレッシュさせる場合に特に有用です。さらに有用なもう一つの方法"
 "は、 <literal>SessionFactory.evictQueries()</literal> によってクエリキャッ"
 "シュ領域を消去することです。"
 
 #. Tag: title
-#: performance.xml:1008
 #, no-c-format
 msgid "Understanding Collection performance"
 msgstr "コレクションのパフォーマンスの理解"
 
 #. Tag: para
-#: performance.xml:1010
 #, no-c-format
 msgid ""
 "In the previous sections we have covered collections and their applications. "
@@ -1974,37 +1646,31 @@
 msgstr ""
 
 #. Tag: title
-#: performance.xml:1017
 #, no-c-format
 msgid "Taxonomy"
 msgstr "分類"
 
 #. Tag: para
-#: performance.xml:1019
 #, no-c-format
 msgid "Hibernate defines three basic kinds of collections:"
-msgstr "Hibernateは3つの基本的なコレクションの種類を定義しています。"
+msgstr "Hibernate は3つの基本的なコレクションの種類を定義しています:"
 
 #. Tag: para
-#: performance.xml:1023
 #, no-c-format
 msgid "collections of values"
 msgstr "値のコレクション"
 
 #. Tag: para
-#: performance.xml:1026
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "one-to-many associations"
 msgstr "一対多関連"
 
 #. Tag: para
-#: performance.xml:1029
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "many-to-many associations"
 msgstr "多対多関連"
 
 #. Tag: para
-#: performance.xml:1033
 #, no-c-format
 msgid ""
 "This classification distinguishes the various table and foreign key "
@@ -2015,32 +1681,28 @@
 "This suggests the following classification:"
 msgstr ""
 "この分類はさまざまなテーブルや外部キー関連を区別しますが、私たちが知る必要の"
-"ある 関連モデルについてほとんどなにも教えてくれません。関連構造やパフォーマン"
-"スの特徴を 完全に理解するには、Hibernateがコレクションの行を更新、削除するた"
-"めに使う主キーの 構造もまた考えなければなりません。これは以下の分類を提示しま"
+"ある関連モデルについてほとんどなにも教えてくれません。関連構造やパフォーマン"
+"スの特徴を完全に理解するには、 Hibernate がコレクションの行を更新、削除するた"
+"めに使う主キーの構造もまた考えなければなりません。これは以下の分類を提示しま"
 "す。"
 
 #. Tag: para
-#: performance.xml:1044
 #, no-c-format
 msgid "indexed collections"
 msgstr "インデックス付きコレクション"
 
 #. Tag: para
-#: performance.xml:1047
 #, no-c-format
 msgid "sets"
 msgstr "set"
 
 #. Tag: para
-#: performance.xml:1050
 #, no-c-format
 msgid "bags"
 msgstr "bag"
 
 #. Tag: para
-#: performance.xml:1054
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All indexed collections (maps, lists, and arrays) have a primary key "
 "consisting of the <literal>&lt;key&gt;</literal> and <literal>&lt;index&gt;</"
@@ -2048,15 +1710,14 @@
 "The primary key can be efficiently indexed and a particular row can be "
 "efficiently located when Hibernate tries to update or delete it."
 msgstr ""
-"すべてのインデックス付きコレクション(map、list、配列)は <literal>&lt;"
-"key&gt;</literal> と <literal>&lt;index&gt;</literal> カラムからなる主キーを"
-"持っています。この場合は コレクションの更新は非常に効率的です。主キーは有用な"
-"インデックスになり、Hibernateが 特定の行を更新または削除するときに、その行を"
-"効率的に見つけることができます。"
+"すべてのインデックス付きコレクション (マップ、リスト、配列) は "
+"<literal>&lt;key&gt;</literal> と <literal>&lt;index&gt;</literal> カラムから"
+"なる主キーを持っています。この場合はコレクションの更新は非常に効率的です。主"
+"キーは有用なインデックスになり、 Hibernate が特定の行を更新または削除するとき"
+"に、その行を効率的に見つけることができます。"
 
 #. Tag: para
-#: performance.xml:1062
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sets have a primary key consisting of <literal>&lt;key&gt;</literal> and "
 "element columns. This can be less efficient for some types of collection "
@@ -2068,28 +1729,26 @@
 "<literal>&lt;set&gt;</literal>, you must declare all columns as <literal>not-"
 "null=\"true\"</literal>."
 msgstr ""
-"setは <literal>&lt;key&gt;</literal> からなる主キーと要素のカラムを持っていま"
-"す。 これはコレクション要素のいくつかの型については効率的ではないかもしれませ"
-"ん。 特に複合要素、大きなテキスト、バイナリフィールドでは非効率です。データ"
-"ベースは 複合主キーに効率的にインデックスを付けることができないからです。一"
-"方、1対多や多対多関連において、 特に人工識別子の場合は同じぐらい効率的です。"
+"set は <literal>&lt;key&gt;</literal> からなる主キーと要素のカラムを持ってい"
+"ます。これはコレクション要素のいくつかの型については効率的ではないかもしれま"
+"せん。特に複合要素、大きなテキスト、バイナリフィールドでは非効率です。データ"
+"ベースは複合主キーに効率的にインデックスを付けることができないからです。一"
+"方、一対多や多対多関連において、特に人工識別子の場合は同じぐらい効率的です。"
 "(余談: <literal>SchemaExport</literal> で実際に <literal>&lt;set&gt;</"
 "literal> の主キーを作りたいなら、すべてのカラムで <literal>not-null=\"true"
 "\"</literal> を宣言しなければなりません。)"
 
 #. Tag: para
-#: performance.xml:1073
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>&lt;idbag&gt;</literal> mappings define a surrogate key, so they "
 "are efficient to update. In fact, they are the best case."
 msgstr ""
-"<literal>&lt;idbag&gt;</literal> マッピングは代理キーを定義します。そのため "
-"更新は常に非常に効率的です。事実上、これは最善のケースです。"
+"<literal>&lt;idbag&gt;</literal> マッピングは代理キーを定義します。そのため更"
+"新は常に非常に効率的です。事実上、これは最善のケースです。"
 
 #. Tag: para
-#: performance.xml:1078
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Bags are the worst case since they permit duplicate element values and, as "
 "they have no index column, no primary key can be defined. Hibernate has no "
@@ -2097,47 +1756,43 @@
 "problem by completely removing in a single <literal>DELETE</literal> and "
 "recreating the collection whenever it changes. This can be inefficient."
 msgstr ""
-"bagは最悪のケースです。bagは要素の値の重複が可能で、インデックスカラムを持た"
-"ないため、 主キーは定義されないかもしれません。Hibernateには重複した行を区別"
-"する方法がありません。 Hibernateはこの問題の解決のために、変更があったときに"
-"は常に完全な削除 (一つの <literal>DELETE</literal> による)を行い、コレク"
-"ションの再作成を行います。 これは非常に非効率的かもしれません。"
+"bag は最悪のケースです。 bag は要素の値の重複が可能で、インデックスカラムを持"
+"たないため、主キーは定義されないかもしれません。 Hibernate には重複した行を区"
+"別する方法がありません。 Hibernate はこの問題の解決のために、変更があったとき"
+"には常に完全な削除(一つの <literal>DELETE</literal> による)を行い、コレク"
+"ションの再作成を行います。これは非常に非効率的かもしれません。"
 
 #. Tag: para
-#: performance.xml:1086
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For a one-to-many association, the \"primary key\" may not be the physical "
 "primary key of the database table. Even in this case, the above "
 "classification is still useful. It reflects how Hibernate \"locates\" "
 "individual rows of the collection."
 msgstr ""
-"1対多関連では、「主キー」はデータベースのテーブルの物理的な 主キーではないか"
+"一対多関連では、「主キー」はデータベースのテーブルの物理的な主キーではないか"
 "もしれないことに注意してください。しかしこの場合でさえ、上記の分類はまだ有用"
-"です。 (Hibernateがコレクションの個々の行をどうやって「見つけるか」を表して"
-"います。)"
+"です。(Hibernateがコレクションの個々の行をどうやって「見つけるか」を表してい"
+"ます。)"
 
 #. Tag: title
-#: performance.xml:1096
 #, no-c-format
 msgid ""
 "Lists, maps, idbags and sets are the most efficient collections to update"
 msgstr "更新にもっとも効率的なコレクション list、map、idbag、set"
 
 #. Tag: para
-#: performance.xml:1098
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "From the discussion above, it should be clear that indexed collections and "
 "sets allow the most efficient operation in terms of adding, removing and "
 "updating elements."
 msgstr ""
-"上での議論から、インデックス付きコレクションと(普通の)setは要素の追加、削"
-"除、 更新でもっとも効率的な操作が出来ることは明らかです。"
+"上での議論から、インデックス付きコレクションと(普通の) set は要素の追加、削"
+"除、更新でもっとも効率的な操作が出来ることは明らかです。"
 
 #. Tag: para
-#: performance.xml:1104
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is, arguably, one more advantage that indexed collections have over "
 "sets for many-to-many associations or collections of values. Because of the "
@@ -2148,15 +1803,14 @@
 "to one-to-many associations."
 msgstr ""
 "ほぼ間違いなく、多対多関連や値のコレクションにおいて、インデックス付きコレク"
-"ションが setよりも優れている点が一つ以上あります。 <literal>Set</literal> は"
-"その 構造のために、Hibernateは要素が「変更」されたときに行を決して "
+"ションが set よりも優れている点が一つ以上あります。 <literal>Set</literal> は"
+"その構造のために、 Hibernate は要素が「変更」されたときに行を決して "
 "<literal>UPDATE</literal> しません。 <literal>Set</literal> への変更は常に"
-"(個々の行の)<literal>INSERT</literal> と <literal>DELETE</literal> によって"
-"行います。繰り返しますが、これは一対多関連には 当てはまりません。"
+"(個々の行の) <literal>INSERT</literal> と <literal>DELETE</literal> によっ"
+"て行います。繰り返しますが、これは一対多関連には当てはまりません。"
 
 #. Tag: para
-#: performance.xml:1113
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "After observing that arrays cannot be lazy, you can conclude that lists, "
 "maps and idbags are the most performant (non-inverse) collection types, with "
@@ -2164,15 +1818,14 @@
 "collection in Hibernate applications. This is because the \"set\" semantics "
 "are most natural in the relational model."
 msgstr ""
-"配列は遅延処理ができないという決まりなので、結論として、list、map、idbagが"
-"もっとも パフォーマンスの良い(inverseではない)コレクションタイプとなりま"
-"す。setも それほど違いはありません。Hibernateのアプリケーションでは、setはコ"
-"レクションのもっとも 共通の種類として期待されます。setの表現は関連モデルでは"
-"もっとも自然だからです。"
+"配列は遅延処理ができないという決まりなので、結論として、list、map、idbag が"
+"もっともパフォーマンスの良い(inverse ではない)コレクションタイプとなりま"
+"す。 set もそれほど違いはありません。 Hibernate のアプリケーションでは、 set "
+"はコレクションのもっとも共通の種類として期待されます。 \"set\" の表現は関連モ"
+"デルではもっとも自然だからです。"
 
 #. Tag: para
-#: performance.xml:1121
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, in well-designed Hibernate domain models, most collections are in "
 "fact one-to-many associations with <literal>inverse=\"true\"</literal>. For "
@@ -2180,20 +1833,18 @@
 "association, and so considerations of collection update performance simply "
 "do not apply."
 msgstr ""
-"しかし、よくデザインされたHibernateのドメインモデルでは、通常もっとも多いコレ"
-"クションは 事実上 <literal>inverse=\"true\"</literal> を指定した1対多関連で"
-"す。これらの関連では、 更新は多対一の関連端で扱われ、コレクションの更新パ"
+"しかし、よくデザインされた Hibernate のドメインモデルでは、通常もっとも多いコ"
+"レクションは事実上 <literal>inverse=\"true\"</literal> を指定した一対多関連で"
+"す。これらの関連では、更新は多対一の関連端で扱われ、コレクションの更新パ"
 "フォーマンスの問題は当てはまりません。"
 
 #. Tag: title
-#: performance.xml:1131
 #, no-c-format
 msgid "Bags and lists are the most efficient inverse collections"
-msgstr "inverseコレクションにもっとも最適なbagとlist"
+msgstr "inverse コレクションにもっとも最適な bag と list"
 
 #. Tag: para
-#: performance.xml:1133
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is a particular case, however, in which bags, and also lists, are much "
 "more performant than sets. For a collection with <literal>inverse=\"true\"</"
@@ -2204,35 +1855,22 @@
 "literal> must always return true for a bag or <literal>List</literal>. This "
 "can make the following common code much faster:"
 msgstr ""
-"bagを見放してしまう前に、bag(そしてlistも)がsetよりもずっとパフォーマンスが"
-"良い特別なケースを 紹介します。 <literal>inverse=\"true\"</literal> のコレク"
-"ション(一般的な1対多関連の使い方など)で、 bagの要素を初期化(フェッチ)する"
-"必要なくbagやlistに要素を追加できます! これは <literal>Collection.add()</"
-"literal> や <literal>Collection.addAll()</literal> はbagや <literal>List</"
-"literal> では常にtrueを返さなければならないからです ( <literal>Set</"
-"literal> とは異なります)。 これは以下の共通処理をより速くすることができま"
-"す。"
+"bag を見放してしまう前に、 bag (そして list も)が set よりもずっとパフォー"
+"マンスが良い特別なケースを紹介します。 <literal>inverse=\"true\"</literal> の"
+"コレクション(一般的な一対多関連の使い方など)で、 bag の要素を初期化(フェッ"
+"チ)する必要なく bag や list に要素を追加できます。これは "
+"<literal>Collection.add()</literal> ã‚„ <literal>Collection.addAll()</"
+"literal> は bag や <literal>List</literal> では常に true を返さなければならな"
+"いからです ( <literal>Set</literal> とは異なります)。これは以下の共通処理を"
+"より速くすることができます。"
 
-#. Tag: programlisting
-#: performance.xml:1143
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = (Parent) sess.load(Parent.class, id);\n"
-"Child c = new Child();\n"
-"c.setParent(p);\n"
-"p.getChildren().add(c);  //no need to fetch the collection!\n"
-"sess.flush();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:1148
 #, no-c-format
 msgid "One shot delete"
 msgstr "一括削除"
 
 #. Tag: para
-#: performance.xml:1150
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Deleting collection elements one by one can sometimes be extremely "
 "inefficient. Hibernate knows not to do that in the case of an newly-empty "
@@ -2240,14 +1878,13 @@
 "this case, Hibernate will issue a single <literal>DELETE</literal>."
 msgstr ""
 "時々、コレクションの要素を一つ一つ削除することは極めて非効率的になることがあ"
-"ります。 Hibernateは愚かではないので、新しい空のコレクションの場合"
+"ります。 Hibernate は愚かではないので、新しい空のコレクションの場合"
 "( <literal>list.clear()</literal> を呼び出した場合など)ではこれをすべきでな"
-"いことを知っています。この場合は、Hibernateは <literal>DELETE</literal> を一"
-"回発行して、それですべて終わります!"
+"いことを知っています。この場合は、 Hibernate は <literal>DELETE</literal> を"
+"一回発行して、それですべて終わります。"
 
 #. Tag: para
-#: performance.xml:1157
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Suppose you added a single element to a collection of size twenty and then "
 "remove two elements. Hibernate will issue one <literal>INSERT</literal> "
@@ -2255,63 +1892,57 @@
 "collection is a bag. This is certainly desirable."
 msgstr ""
 "サイズ20のコレクションに一つの要素を追加し、それから二つの要素を削除するとし"
-"ます。 Hibernateは一つの <literal>INSERT</literal> 文と二つの "
-"<literal>DELETE</literal> 文を発行します (コレクションがbagでなければ)。こ"
-"れは確かに望ましい動作です。"
+"ます。 Hibernate は一つの <literal>INSERT</literal> 文と二つの "
+"<literal>DELETE</literal> 文を発行します (コレクションが bag でなければ)。"
+"これは確かに望ましい動作です。"
 
 #. Tag: para
-#: performance.xml:1163
 #, no-c-format
 msgid ""
 "However, suppose that we remove eighteen elements, leaving two and then add "
 "thee new elements. There are two possible ways to proceed"
 msgstr ""
 "しかし、18個の要素を削除して2つを残し、それから3つ新しい要素を追加するとしま"
-"す。 このとき二つの方法があります。"
+"す。このとき二つの方法があります。"
 
 #. Tag: para
-#: performance.xml:1170
 #, no-c-format
 msgid "delete eighteen rows one by one and then insert three rows"
 msgstr "18行を一つ一つ削除して、3行を追加する"
 
 #. Tag: para
-#: performance.xml:1173
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "remove the whole collection in one SQL <literal>DELETE</literal> and insert "
 "all five current elements one by one"
 msgstr ""
-"コレクション全体を削除( <literal>DELETE</literal> のSQLを一回)し、そして5つ"
-"の要素すべてを (一つずつ)追加する"
+"コレクション全体を削除( <literal>DELETE</literal> の SQL を一回)し、そして5"
+"つの要素すべてを(一つずつ)追加する"
 
 #. Tag: para
-#: performance.xml:1178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate cannot know that the second option is probably quicker. It would "
 "probably be undesirable for Hibernate to be that intuitive as such behavior "
 "might confuse database triggers, etc."
 msgstr ""
-"Hibernateはこの場合に2番目の方法がより速いだろうとわかるほど賢くはありませ"
-"ん。 (そしてHibernateがこのように賢いことも望ましくないでしょう。このような"
-"振る舞いは データベースのトリガなどを混乱させるかもしれません。)"
+"Hibernate はこの場合に2番目の方法がより速いだろうとわかるほど賢くはありませ"
+"ん。(そして Hibernate がこのように賢いことも望ましくないでしょう。このような"
+"振る舞いはデータベースのトリガなどを混乱させるかもしれません。)"
 
 #. Tag: para
-#: performance.xml:1184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Fortunately, you can force this behavior (i.e. the second strategy) at any "
 "time by discarding (i.e. dereferencing) the original collection and "
 "returning a newly instantiated collection with all the current elements."
 msgstr ""
 "幸いにも、元のコレクションを捨て(つまり参照をやめて)、現在の要素をすべて持"
-"つ新しいコレクションの インスタンスを返すことで、いつでもこの振る舞い(2番目"
-"の戦略)を強制することが出来ます。 時にこれはとても便利で強力です。"
+"つ新しいコレクションのインスタンスを返すことで、いつでもこの振る舞い(2番目の"
+"戦略)を強制することが出来ます。時にこれはとても便利で強力です。"
 
 #. Tag: para
-#: performance.xml:1190
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "One-shot-delete does not apply to collections mapped <literal>inverse=\"true"
 "\"</literal>."
@@ -2320,13 +1951,11 @@
 "ンには行いません。"
 
 #. Tag: title
-#: performance.xml:1199
 #, no-c-format
 msgid "Monitoring performance"
 msgstr "パフォーマンスのモニタリング"
 
 #. Tag: para
-#: performance.xml:1201
 #, no-c-format
 msgid ""
 "Optimization is not much use without monitoring and access to performance "
@@ -2335,17 +1964,15 @@
 "<literal>SessionFactory</literal>."
 msgstr ""
 "最適化はモニタリングやパフォーマンスを示す数値がなければ十分に行えません。 "
-"Hibernateは内部処理のすべての範囲の数値を提供します。 Hibernateの統計情報は "
-"<literal>SessionFactory</literal> 単位で取得可能です。"
+"Hibernate は内部処理のすべての範囲の数値を提供します。 Hibernate の統計情報"
+"は <literal>SessionFactory</literal> 単位で取得可能です。"
 
 #. Tag: title
-#: performance.xml:1208
 #, no-c-format
 msgid "Monitoring a SessionFactory"
-msgstr "SessionFactoryのモニタリング"
+msgstr "SessionFactory のモニタリング"
 
 #. Tag: para
-#: performance.xml:1210
 #, no-c-format
 msgid ""
 "You can access <literal>SessionFactory</literal> metrics in two ways. Your "
@@ -2353,58 +1980,26 @@
 "and read or display the <literal>Statistics</literal> yourself."
 msgstr ""
 "<literal>SessionFactory</literal> のメトリクスにアクセスするには2つの方法があ"
-"ります。 最初の方法は、 <literal>sessionFactory.getStatistics()</literal> を"
-"呼び出し、 自分で <literal>Statistics</literal> の読み込みや表示を行います。"
+"ります。最初の方法は、 <literal>sessionFactory.getStatistics()</literal> を呼"
+"び出し、自分で <literal>Statistics</literal> の読み込みや表示を行います。"
 
 #. Tag: para
-#: performance.xml:1216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate can also use JMX to publish metrics if you enable the "
 "<literal>StatisticsService</literal> MBean. You can enable a single MBean "
 "for all your <literal>SessionFactory</literal> or one per factory. See the "
 "following code for minimalistic configuration examples:"
 msgstr ""
-"<literal>StatisticsService</literal> MBeanを有効にしていれば、HibernateはJMX"
-"を使って メトリクスを発行することもできます。1つのMBeanをすべての "
-"<literal>SessionFactory</literal> に対して有効にするか、SessionFactoryごとに"
-"一つのMBeanを有効にすることが出来ます。 最小限の設定例である以下のコードを見"
-"てください。"
+"<literal>StatisticsService</literal> MBean を有効にしていれば、 Hibernate は "
+"JMX を使ってメトリクスを発行することもできます。1つの MBean をすべての "
+"<literal>SessionFactory</literal> に対して有効にするか、 SessionFactory ごと"
+"に一つの MBean を有効にすることが出来ます。最小限の設定例である以下のコードを"
+"見てください:"
 
-#. Tag: programlisting
-#: performance.xml:1223
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// MBean service registration for a specific SessionFactory\n"
-"Hashtable tb = new Hashtable();\n"
-"tb.put(\"type\", \"statistics\");\n"
-"tb.put(\"sessionFactory\", \"myFinancialApp\");\n"
-"ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-"\n"
-"StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-"stats.setSessionFactory(sessionFactory); // Bind the stats to a "
-"SessionFactory\n"
-"server.registerMBean(stats, on); // Register the Mbean on the server]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: performance.xml:1226
-#, no-c-format
-msgid ""
-"<![CDATA[// MBean service registration for all SessionFactory's\n"
-"Hashtable tb = new Hashtable();\n"
-"tb.put(\"type\", \"statistics\");\n"
-"tb.put(\"sessionFactory\", \"all\");\n"
-"ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-"\n"
-"StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-"server.registerMBean(stats, on); // Register the MBean on the server]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:1228
-#, fuzzy, no-c-format
-msgid ""
 "You can activate and deactivate the monitoring for a "
 "<literal>SessionFactory</literal>:"
 msgstr ""
@@ -2412,7 +2007,6 @@
 "とが出来ます。"
 
 #. Tag: para
-#: performance.xml:1233
 #, no-c-format
 msgid ""
 "at configuration time, set <literal>hibernate.generate_statistics</literal> "
@@ -2422,7 +2016,6 @@
 "<literal>false</literal> にします"
 
 #. Tag: para
-#: performance.xml:1240
 #, no-c-format
 msgid ""
 "at runtime: <literal>sf.getStatistics().setStatisticsEnabled(true)</literal> "
@@ -2433,26 +2026,23 @@
 "び出します"
 
 #. Tag: para
-#: performance.xml:1247
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Statistics can be reset programmatically using the <literal>clear()</"
 "literal> method. A summary can be sent to a logger (info level) using the "
 "<literal>logSummary()</literal> method."
 msgstr ""
 "統計は <literal>clear()</literal> メソッドを使って手動でリセットすることが出"
-"来ます。 サマリは <literal>logSummary()</literal> メソッドを使ってloggerに送"
-"ることが出来ます (infoレベルです)。"
+"来ます。サマリは <literal>logSummary()</literal> メソッドを使って logger に送"
+"ることが出来ます(info レベルです)。"
 
 #. Tag: title
-#: performance.xml:1256
 #, no-c-format
 msgid "Metrics"
 msgstr "メトリクス"
 
 #. Tag: para
-#: performance.xml:1258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate provides a number of metrics, from basic information to more "
 "specialized information that is only relevant in certain scenarios. All "
@@ -2460,30 +2050,27 @@
 "interface API, in three categories:"
 msgstr ""
 "多くのものがあります。すべての使用可能なカウンタは <literal>Statistics</"
-"literal> インターフェイスのAPIに書かれており、3つの分類があります。"
+"literal> インターフェースの API に書かれており、3つの分類があります:"
 
 #. Tag: para
-#: performance.xml:1265
 #, no-c-format
 msgid ""
 "Metrics related to the general <literal>Session</literal> usage, such as "
 "number of open sessions, retrieved JDBC connections, etc."
 msgstr ""
-"メトリクスは一般的な <literal>Session</literal> の使い方と関係しています。 "
-"オープンしたセッションの数がJDBCコネクションと関連しているのと同じです。"
+"メトリクスは一般的な <literal>Session</literal> の使い方と関係しています。"
+"オープンしたセッションの数が JDBC コネクションと関連しているのと同じです。"
 
 #. Tag: para
-#: performance.xml:1271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Metrics related to the entities, collections, queries, and caches as a whole "
 "(aka global metrics)."
 msgstr ""
-"メトリクスは要素、コレクション、クエリやキャッシュなど全体に 関係しています"
+"メトリクスは要素、コレクション、クエリやキャッシュなど全体に関係しています"
 "(別名はグローバルメトリクスです)。"
 
 #. Tag: para
-#: performance.xml:1277
 #, no-c-format
 msgid ""
 "Detailed metrics related to a particular entity, collection, query or cache "
@@ -2493,8 +2080,7 @@
 "関係しています。"
 
 #. Tag: para
-#: performance.xml:1284
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For example, you can check the cache hit, miss, and put ratio of entities, "
 "collections and queries, and the average time a query needs. Be aware that "
@@ -2503,13 +2089,12 @@
 "to 10 seconds."
 msgstr ""
 "例として、キャッシュのヒット、ヒットミスや、要素、コレクション、クエリの割"
-"合、クエリの実行に 必要な平均時間を確認できます。ミリ秒の数値はJavaの近似を受"
-"けることに注意してください。 HibernateはJVMの精度に制限され、プラットフォーム"
-"によっては10秒単位でしか正確でないかもしれません。"
+"合、クエリの実行に必要な平均時間を確認できます。ミリ秒の数値は Java の近似を"
+"受けることに注意してください。 Hibernate は JVM の精度に制限され、プラット"
+"フォームによっては10秒単位でしか正確でないかもしれません。"
 
 #. Tag: para
-#: performance.xml:1291
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Simple getters are used to access the global metrics (i.e. not tied to a "
 "particular entity, collection, cache region, etc.). You can access the "
@@ -2521,41 +2106,18 @@
 "literal> API Javadoc for more information. The following code is a simple "
 "example:"
 msgstr ""
-"単純なgetterはグローバルメトリクス(すなわち特定のエンティティ、コレクショ"
-"ン、キャッシュ領域などに縛られない) にアクセスするために使います。特定のエン"
-"ティティ、コレクション、キャッシュ領域のメトリクスは、 それらの名前や、クエリ"
-"のHQL、SQL表現によってアクセスすることが出来ます。さらに詳しい情報は、 "
+"単純な getter はグローバルメトリクス(すなわち特定のエンティティ、コレクショ"
+"ン、キャッシュ領域などに縛られない)にアクセスするために使います。特定のエン"
+"ティティ、コレクション、キャッシュ領域のメトリクスは、それらの名前や、クエリ"
+"の HQL 、 SQL 表現によってアクセスすることが出来ます。さらに詳しい情報は、 "
 "<literal>Statistics</literal> 、 <literal>EntityStatistics</literal> 、 "
 "<literal>CollectionStatistics</literal> 、 "
 "<literal>SecondLevelCacheStatistics</literal> 、 <literal>QueryStatistics</"
-"literal> APIのjavadocを 参照してください。以下のコードは簡単な例です。"
+"literal> API の javadoc を参照してください。以下のコードは簡単な例です:"
 
-#. Tag: programlisting
-#: performance.xml:1301
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Statistics stats = HibernateUtil.sessionFactory.getStatistics();\n"
-"\n"
-"double queryCacheHitCount  = stats.getQueryCacheHitCount();\n"
-"double queryCacheMissCount = stats.getQueryCacheMissCount();\n"
-"double queryCacheHitRatio =\n"
-"  queryCacheHitCount / (queryCacheHitCount + queryCacheMissCount);\n"
-"\n"
-"log.info(\"Query Hit ratio:\" + queryCacheHitRatio);\n"
-"\n"
-"EntityStatistics entityStats =\n"
-"  stats.getEntityStatistics( Cat.class.getName() );\n"
-"long changes =\n"
-"        entityStats.getInsertCount()\n"
-"        + entityStats.getUpdateCount()\n"
-"        + entityStats.getDeleteCount();\n"
-"log.info(Cat.class.getName() + \" changed \" + changes + \"times\"  );]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:1303
-#, fuzzy, no-c-format
-msgid ""
 "You can work on all entities, collections, queries and region caches, by "
 "retrieving the list of names of entities, collections, queries and region "
 "caches using the following methods: <literal>getQueries()</literal>, "
@@ -2565,44 +2127,482 @@
 "すべてのエンティティ、コレクション、クエリ、キャッシュ領域に対して行う場合"
 "は、 <literal>getQueries()</literal> 、 <literal>getEntityNames()</"
 "literal>、 <literal>getCollectionRoleNames()</literal> 、 "
-"<literal>getSecondLevelCacheRegionNames()</literal> メソッドで それぞれの名前"
+"<literal>getSecondLevelCacheRegionNames()</literal> メソッドでそれぞれの名前"
 "のリストを取得することが出来ます。"
 
 #~ msgid ""
-#~ "where <literal>CatImpl</literal> implements the interface <literal>Cat</"
-#~ "literal> and <literal>DomesticCatImpl</literal> implements the interface "
-#~ "<literal>DomesticCat</literal>. Then proxies for instances of "
-#~ "<literal>Cat</literal> and <literal>DomesticCat</literal> may be returned "
-#~ "by <literal>load()</literal> or <literal>iterate()</literal>. (Note that "
-#~ "<literal>list()</literal> does not usually return proxies.)"
+#~ "This setting creates two new cache regions: one holding cached query "
+#~ "result sets (<literal>org.hibernate.cache.StandardQueryCache</literal>), "
+#~ "the other holding timestamps of the most recent updates to queryable "
+#~ "tables (<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). "
+#~ "Note that the query cache does not cache the state of the actual entities "
+#~ "in the result set; it caches only identifier values and results of value "
+#~ "type. The query cache should always be used in conjunction with the "
+#~ "second-level cache."
 #~ msgstr ""
-#~ "<literal>CatImpl</literal> は <literal>Cat</literal> インターフェイスを実"
-#~ "装するのに対し、 <literal>DomesticCatImpl</literal> は "
-#~ "<literal>DomesticCat</literal> を実装します。 すると、 <literal>load()</"
-#~ "literal> や <literal>iterate()</literal> は、 <literal>Cat</literal> や "
-#~ "<literal>DomesticCat</literal> のインスタンスのプロキシを 返します。"
-#~ "( <literal>list()</literal> は通常はプロキシを返さないことに注意してくだ"
-#~ "さい。)"
+#~ "この設定は新たに二つのキャッシュ領域の作成を行います。一つはクエリのリザル"
+#~ "トセットのキャッシュ( <literal>org.hibernate.cache.StandardQueryCache</"
+#~ "literal> )を保持し、もう1つはクエリ可能なテーブルへの最新の更新タイムスタ"
+#~ "ンプ ( <literal>org.hibernate.cache.UpdateTimestampsCache</literal> )を"
+#~ "保持します。クエリキャッシュはリザルトセットの実際の要素の状態はキャッシュ"
+#~ "しないことに注意してください。キャッシュするのは識別子の値と、値型の結果の"
+#~ "みです。そのため、クエリキャッシュは常に二次キャッシュと一緒に使うべきで"
+#~ "す。"
 
+#, fuzzy
 #~ msgid ""
-#~ "We've already spent quite some time talking about collections. In this "
-#~ "section we will highlight a couple more issues about how collections "
-#~ "behave at runtime."
+#~ "<![CDATA[s = sessions.openSession();\n"
+#~ "Transaction tx = s.beginTransaction();\n"
+#~ "            \n"
+#~ "User u = (User) s.createQuery(\"from User u where u.name=:userName\")\n"
+#~ "    .setString(\"userName\", userName).uniqueResult();\n"
+#~ "Map permissions = u.getPermissions();\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "s.close();\n"
+#~ "\n"
+#~ "Integer accessLevel = (Integer) permissions.get(\"accounts\");  // "
+#~ "Error!]]>"
 #~ msgstr ""
-#~ "コレクションの話題にはすでに多くの時間を使いました。この節では コレクショ"
-#~ "ンが実行時にどのように振舞うかについての話題を2、3取り上げます。"
+#~ "s = sessions.openSession();\n"
+#~ "Transaction tx = s.beginTransaction();\n"
+#~ "            \n"
+#~ "User u = (User) s.createQuery(\"from User u where u.name=:userName\")\n"
+#~ "    .setString(\"userName\", userName).uniqueResult();\n"
+#~ "Map permissions = u.getPermissions();\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "s.close();\n"
+#~ "\n"
+#~ "Integer accessLevel = (Integer) permissions.get(\"accounts\");  // Error!"
 
+#, fuzzy
 #~ msgid ""
-#~ "TODO: This doesn't make sense: In the first case, we retrieve and use the "
-#~ "MBean directly. In the second one, we must give the JNDI name in which "
-#~ "the session factory is held before using it. Use "
-#~ "<literal>hibernateStatsBean.setSessionFactoryJNDIName(\"my/JNDI/Name\")</"
-#~ "literal>"
+#~ "<![CDATA[<set name=\"permissions\" \n"
+#~ "            fetch=\"join\">\n"
+#~ "    <key column=\"userId\"/>\n"
+#~ "    <one-to-many class=\"Permission\"/>\n"
+#~ "</set]]>"
 #~ msgstr ""
-#~ "TODO: これは意味がありません。最初のケースは、MBeanを直接復元して使用しま"
-#~ "す。2番目のケースは、 使う前にsession factoryが持っているJNDI名を渡さなけ"
-#~ "ればなりません。 <literal>hibernateStatsBean.setSessionFactoryJNDIName"
-#~ "(\"my/JNDI/Name\")</literal> を使ってください。"
+#~ "&lt;set name=\"permissions\" \n"
+#~ "            fetch=\"join\"&gt;\n"
+#~ "    &lt;key column=\"userId\"/&gt;\n"
+#~ "    &lt;one-to-many class=\"Permission\"/&gt;\n"
+#~ "&lt;/set"
 
-#~ msgid "yes"
-#~ msgstr "yes"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"mother\" class=\"Cat\" fetch=\"join\"/>]]>"
+#~ msgstr "&lt;many-to-one name=\"mother\" class=\"Cat\" fetch=\"join\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[User user = (User) session.createCriteria(User.class)\n"
+#~ "                .setFetchMode(\"permissions\", FetchMode.JOIN)\n"
+#~ "                .add( Restrictions.idEq(userId) )\n"
+#~ "                .uniqueResult();]]>"
+#~ msgstr ""
+#~ "User user = (User) session.createCriteria(User.class)\n"
+#~ "                .setFetchMode(\"permissions\", FetchMode.JOIN)\n"
+#~ "                .add( Restrictions.idEq(userId) )\n"
+#~ "                .uniqueResult();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Cat\" proxy=\"Cat\">\n"
+#~ "    ......\n"
+#~ "    <subclass name=\"DomesticCat\">\n"
+#~ "        .....\n"
+#~ "    </subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Cat\" proxy=\"Cat\"&gt;\n"
+#~ "    ......\n"
+#~ "    &lt;subclass name=\"DomesticCat\"&gt;\n"
+#~ "        .....\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);  // instantiate a "
+#~ "proxy (does not hit the db)\n"
+#~ "if ( cat.isDomesticCat() ) {                  // hit the db to initialize "
+#~ "the proxy\n"
+#~ "    DomesticCat dc = (DomesticCat) cat;       // Error!\n"
+#~ "    ....\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "Cat cat = (Cat) session.load(Cat.class, id);  // instantiate a proxy "
+#~ "(does not hit the db)\n"
+#~ "if ( cat.isDomesticCat() ) {                  // hit the db to initialize "
+#~ "the proxy\n"
+#~ "    DomesticCat dc = (DomesticCat) cat;       // Error!\n"
+#~ "    ....\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);            // "
+#~ "instantiate a Cat proxy\n"
+#~ "DomesticCat dc = \n"
+#~ "        (DomesticCat) session.load(DomesticCat.class, id);  // acquire "
+#~ "new DomesticCat proxy!\n"
+#~ "System.out.println(cat==dc);                            // false]]>"
+#~ msgstr ""
+#~ "Cat cat = (Cat) session.load(Cat.class, id);            // instantiate a "
+#~ "Cat proxy\n"
+#~ "DomesticCat dc = \n"
+#~ "        (DomesticCat) session.load(DomesticCat.class, id);  // acquire "
+#~ "new DomesticCat proxy!\n"
+#~ "System.out.println(cat==dc);                            // false"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[cat.setWeight(11.0);  // hit the db to initialize the proxy\n"
+#~ "System.out.println( dc.getWeight() );  // 11.0]]>"
+#~ msgstr ""
+#~ "cat.setWeight(11.0);  // hit the db to initialize the proxy\n"
+#~ "System.out.println( dc.getWeight() );  // 11.0"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"CatImpl\" proxy=\"Cat\">\n"
+#~ "    ......\n"
+#~ "    <subclass name=\"DomesticCatImpl\" proxy=\"DomesticCat\">\n"
+#~ "        .....\n"
+#~ "    </subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"CatImpl\" proxy=\"Cat\"&gt;\n"
+#~ "    ......\n"
+#~ "    &lt;subclass name=\"DomesticCatImpl\" proxy=\"DomesticCat\"&gt;\n"
+#~ "        .....\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Cat cat = (Cat) session.load(CatImpl.class, catid);\n"
+#~ "Iterator iter = session.createQuery(\"from CatImpl as cat where cat."
+#~ "name='fritz'\").iterate();\n"
+#~ "Cat fritz = (Cat) iter.next();]]>"
+#~ msgstr ""
+#~ "Cat cat = (Cat) session.load(CatImpl.class, catid);\n"
+#~ "Iterator iter = session.iterate(\"from CatImpl as cat where cat."
+#~ "name='fritz'\");\n"
+#~ "Cat fritz = (Cat) iter.next();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[( (Integer) s.createFilter( collection, \"select count(*)\" )."
+#~ "list().get(0) ).intValue()]]>"
+#~ msgstr ""
+#~ "( (Integer) s.createFilter( collection, \"select count(*)\" ).list().get"
+#~ "(0) ).intValue()"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[s.createFilter( lazyCollection, \"\").setFirstResult(0)."
+#~ "setMaxResults(10).list();]]>"
+#~ msgstr ""
+#~ "s.createFilter( lazyCollection, \"\").setFirstResult(0).setMaxResults(10)."
+#~ "list();"
+
+#, fuzzy
+#~ msgid "<![CDATA[<class name=\"Person\" batch-size=\"10\">...</class>]]>"
+#~ msgstr "&lt;class name=\"Person\" batch-size=\"10\"&gt;...&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <set name=\"cats\" batch-size=\"3\">\n"
+#~ "        ...\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;set name=\"cats\" batch-size=\"3\"&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Document\">\n"
+#~ "       <id name=\"id\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"name\" not-null=\"true\" length=\"50\"/>\n"
+#~ "    <property name=\"summary\" not-null=\"true\" length=\"200\" lazy="
+#~ "\"true\"/>\n"
+#~ "    <property name=\"text\" not-null=\"true\" length=\"2000\" lazy=\"true"
+#~ "\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Document\"&gt;\n"
+#~ "       &lt;id name=\"id\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"name\" not-null=\"true\" length=\"50\"/&gt;\n"
+#~ "    &lt;property name=\"summary\" not-null=\"true\" length=\"200\" lazy="
+#~ "\"true\"/&gt;\n"
+#~ "    &lt;property name=\"text\" not-null=\"true\" length=\"2000\" lazy="
+#~ "\"true\"/&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<target name=\"instrument\" depends=\"compile\">\n"
+#~ "    <taskdef name=\"instrument\" classname=\"org.hibernate.tool."
+#~ "instrument.InstrumentTask\">\n"
+#~ "        <classpath path=\"${jar.path}\"/>\n"
+#~ "        <classpath path=\"${classes.dir}\"/>\n"
+#~ "        <classpath refid=\"lib.class.path\"/>\n"
+#~ "    </taskdef>\n"
+#~ "\n"
+#~ "    <instrument verbose=\"true\">\n"
+#~ "        <fileset dir=\"${testclasses.dir}/org/hibernate/auction/model\">\n"
+#~ "            <include name=\"*.class\"/>\n"
+#~ "        </fileset>\n"
+#~ "    </instrument>\n"
+#~ "</target>]]>"
+#~ msgstr ""
+#~ "&lt;target name=\"instrument\" depends=\"compile\"&gt;\n"
+#~ "    &lt;taskdef name=\"instrument\" classname=\"org.hibernate.tool."
+#~ "instrument.InstrumentTask\"&gt;\n"
+#~ "        &lt;classpath path=\"&#36;{jar.path}\"/&gt;\n"
+#~ "        &lt;classpath path=\"&#36;{classes.dir}\"/&gt;\n"
+#~ "        &lt;classpath refid=\"lib.class.path\"/&gt;\n"
+#~ "    &lt;/taskdef&gt;\n"
+#~ "\n"
+#~ "    &lt;instrument verbose=\"true\"&gt;\n"
+#~ "        &lt;fileset dir=\"&#36;{testclasses.dir}/org/hibernate/auction/"
+#~ "model\"&gt;\n"
+#~ "            &lt;include name=\"*.class\"/&gt;\n"
+#~ "        &lt;/fileset&gt;\n"
+#~ "    &lt;/instrument&gt;\n"
+#~ "&lt;/target&gt;"
+
+#~ msgid "<entry>yes</entry>"
+#~ msgstr "<entry>yes</entry>"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<cache \n"
+#~ "    usage=\"transactional|read-write|nonstrict-read-write|read-only\"\n"
+#~ "    region=\"RegionName\"\n"
+#~ "    include=\"all|non-lazy\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "&lt;cache \n"
+#~ "    usage=\"transactional|read-write|nonstrict-read-write|read-only\"\n"
+#~ "    region=\"RegionName\"\n"
+#~ "    include=\"all|non-lazy\"\n"
+#~ "/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Immutable\" mutable=\"false\">\n"
+#~ "    <cache usage=\"read-only\"/>\n"
+#~ "    ....\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"eg.Immutable\" mutable=\"false\"&gt;\n"
+#~ "    &lt;cache usage=\"read-only\"/&gt;\n"
+#~ "    ....\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Cat\" .... >\n"
+#~ "    <cache usage=\"read-write\"/>\n"
+#~ "    ....\n"
+#~ "    <set name=\"kittens\" ... >\n"
+#~ "        <cache usage=\"read-write\"/>\n"
+#~ "        ....\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"eg.Cat\" .... &gt;\n"
+#~ "    &lt;cache usage=\"read-write\"/&gt;\n"
+#~ "    ....\n"
+#~ "    &lt;set name=\"kittens\" ... &gt;\n"
+#~ "        &lt;cache usage=\"read-write\"/&gt;\n"
+#~ "        ....\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[ScrollableResult cats = sess.createQuery(\"from Cat as cat\")."
+#~ "scroll(); //a huge result set\n"
+#~ "while ( cats.next() ) {\n"
+#~ "    Cat cat = (Cat) cats.get(0);\n"
+#~ "    doSomethingWithACat(cat);\n"
+#~ "    sess.evict(cat);\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "ScrollableResult cats = sess.createQuery(\"from Cat as cat\").scroll(); //"
+#~ "a huge result set\n"
+#~ "while ( cats.next() ) {\n"
+#~ "    Cat cat = (Cat) cats.get(0);\n"
+#~ "    doSomethingWithACat(cat);\n"
+#~ "    sess.evict(cat);\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sessionFactory.evict(Cat.class, catId); //evict a particular "
+#~ "Cat\n"
+#~ "sessionFactory.evict(Cat.class);  //evict all Cats\n"
+#~ "sessionFactory.evictCollection(\"Cat.kittens\", catId); //evict a "
+#~ "particular collection of kittens\n"
+#~ "sessionFactory.evictCollection(\"Cat.kittens\"); //evict all kitten "
+#~ "collections]]>"
+#~ msgstr ""
+#~ "sessionFactory.evict(Cat.class, catId); //evict a particular Cat\n"
+#~ "sessionFactory.evict(Cat.class);  //evict all Cats\n"
+#~ "sessionFactory.evictCollection(\"Cat.kittens\", catId); //evict a "
+#~ "particular collection of kittens\n"
+#~ "sessionFactory.evictCollection(\"Cat.kittens\"); //evict all kitten "
+#~ "collections"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Map cacheEntries = sessionFactory.getStatistics()\n"
+#~ "        .getSecondLevelCacheStatistics(regionName)\n"
+#~ "        .getEntries();]]>"
+#~ msgstr ""
+#~ "Map cacheEntries = sessionFactory.getStatistics()\n"
+#~ "        .getSecondLevelCacheStatistics(regionName)\n"
+#~ "        .getEntries();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[hibernate.generate_statistics true\n"
+#~ "hibernate.cache.use_structured_entries true]]>"
+#~ msgstr ""
+#~ "hibernate.generate_statistics true\n"
+#~ "hibernate.cache.use_structured_entries true"
+
+#, fuzzy
+#~ msgid "<![CDATA[hibernate.cache.use_query_cache true]]>"
+#~ msgstr "hibernate.cache.use_query_cache true"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List blogs = sess.createQuery(\"from Blog blog where blog."
+#~ "blogger = :blogger\")\n"
+#~ "    .setEntity(\"blogger\", blogger)\n"
+#~ "    .setMaxResults(15)\n"
+#~ "    .setCacheable(true)\n"
+#~ "    .setCacheRegion(\"frontpages\")\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List blogs = sess.createQuery(\"from Blog blog where blog.blogger = :"
+#~ "blogger\")\n"
+#~ "    .setEntity(\"blogger\", blogger)\n"
+#~ "    .setMaxResults(15)\n"
+#~ "    .setCacheable(true)\n"
+#~ "    .setCacheRegion(\"frontpages\")\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Parent p = (Parent) sess.load(Parent.class, id);\n"
+#~ "Child c = new Child();\n"
+#~ "c.setParent(p);\n"
+#~ "p.getChildren().add(c);  //no need to fetch the collection!\n"
+#~ "sess.flush();]]>"
+#~ msgstr ""
+#~ "Parent p = (Parent) sess.load(Parent.class, id);\n"
+#~ "Child c = new Child();\n"
+#~ "c.setParent(p);\n"
+#~ "p.getChildren().add(c);  //no need to fetch the collection!\n"
+#~ "sess.flush();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[// MBean service registration for a specific SessionFactory\n"
+#~ "Hashtable tb = new Hashtable();\n"
+#~ "tb.put(\"type\", \"statistics\");\n"
+#~ "tb.put(\"sessionFactory\", \"myFinancialApp\");\n"
+#~ "ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
+#~ "\n"
+#~ "StatisticsService stats = new StatisticsService(); // MBean "
+#~ "implementation\n"
+#~ "stats.setSessionFactory(sessionFactory); // Bind the stats to a "
+#~ "SessionFactory\n"
+#~ "server.registerMBean(stats, on); // Register the Mbean on the server]]>"
+#~ msgstr ""
+#~ "// MBean service registration for a specific SessionFactory\n"
+#~ "Hashtable tb = new Hashtable();\n"
+#~ "tb.put(\"type\", \"statistics\");\n"
+#~ "tb.put(\"sessionFactory\", \"myFinancialApp\");\n"
+#~ "ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
+#~ "\n"
+#~ "StatisticsService stats = new StatisticsService(); // MBean "
+#~ "implementation\n"
+#~ "stats.setSessionFactory(sessionFactory); // Bind the stats to a "
+#~ "SessionFactory\n"
+#~ "server.registerMBean(stats, on); // Register the Mbean on the server"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[// MBean service registration for all SessionFactory's\n"
+#~ "Hashtable tb = new Hashtable();\n"
+#~ "tb.put(\"type\", \"statistics\");\n"
+#~ "tb.put(\"sessionFactory\", \"all\");\n"
+#~ "ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
+#~ "\n"
+#~ "StatisticsService stats = new StatisticsService(); // MBean "
+#~ "implementation\n"
+#~ "server.registerMBean(stats, on); // Register the MBean on the server]]>"
+#~ msgstr ""
+#~ "// MBean service registration for all SessionFactory's\n"
+#~ "Hashtable tb = new Hashtable();\n"
+#~ "tb.put(\"type\", \"statistics\");\n"
+#~ "tb.put(\"sessionFactory\", \"all\");\n"
+#~ "ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
+#~ "\n"
+#~ "StatisticsService stats = new StatisticsService(); // MBean "
+#~ "implementation\n"
+#~ "server.registerMBean(stats, on); // Register the MBean on the server"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Statistics stats = HibernateUtil.sessionFactory.getStatistics"
+#~ "();\n"
+#~ "\n"
+#~ "double queryCacheHitCount  = stats.getQueryCacheHitCount();\n"
+#~ "double queryCacheMissCount = stats.getQueryCacheMissCount();\n"
+#~ "double queryCacheHitRatio =\n"
+#~ "  queryCacheHitCount / (queryCacheHitCount + queryCacheMissCount);\n"
+#~ "\n"
+#~ "log.info(\"Query Hit ratio:\" + queryCacheHitRatio);\n"
+#~ "\n"
+#~ "EntityStatistics entityStats =\n"
+#~ "  stats.getEntityStatistics( Cat.class.getName() );\n"
+#~ "long changes =\n"
+#~ "        entityStats.getInsertCount()\n"
+#~ "        + entityStats.getUpdateCount()\n"
+#~ "        + entityStats.getDeleteCount();\n"
+#~ "log.info(Cat.class.getName() + \" changed \" + changes + \"times\"  );]]>"
+#~ msgstr ""
+#~ "Statistics stats = HibernateUtil.sessionFactory.getStatistics();\n"
+#~ "\n"
+#~ "double queryCacheHitCount  = stats.getQueryCacheHitCount();\n"
+#~ "double queryCacheMissCount = stats.getQueryCacheMissCount();\n"
+#~ "double queryCacheHitRatio =\n"
+#~ "  queryCacheHitCount / (queryCacheHitCount + queryCacheMissCount);\n"
+#~ "\n"
+#~ "log.info(\"Query Hit ratio:\" + queryCacheHitRatio);\n"
+#~ "\n"
+#~ "EntityStatistics entityStats =\n"
+#~ "  stats.getEntityStatistics( Cat.class.getName() );\n"
+#~ "long changes =\n"
+#~ "        entityStats.getInsertCount()\n"
+#~ "        + entityStats.getUpdateCount()\n"
+#~ "        + entityStats.getDeleteCount();\n"
+#~ "log.info(Cat.class.getName() + \" changed \" + changes + \"times\"  );"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/persistent_classes.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/persistent_classes.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/persistent_classes.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,25 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-04 13:58+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: persistent_classes.xml:29
 #, no-c-format
 msgid "Persistent Classes"
 msgstr "永続クラス"
 
 #. Tag: para
-#: persistent_classes.xml:31
-#, fuzzy, no-c-format
+#, 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 "
@@ -26,15 +27,14 @@
 "in the persistent state. For example, an instance can instead be transient "
 "or detached."
 msgstr ""
-"永続クラスはビジネス上の問題のエンティティ(例えば、Eコマースアプリケーション"
-"の顧客や注文) を実装するアプリケーションのクラスです。 永続クラスのすべての"
-"インスタンスが永続状態であると見なされるわけではありません。 インスタンスは逆"
+"永続クラスはビジネス上の問題のエンティティ(例えば、 E コマースアプリケーショ"
+"ンの顧客や注文) を実装するアプリケーションのクラスです。永続クラスのすべての"
+"インスタンスが永続状態であると見なされるわけではありません。インスタンスは逆"
 "に一時的(transient)であったり、分離状態(detached)であったりするかもしれま"
 "せん。"
 
 #. Tag: para
-#: persistent_classes.xml:38
-#, fuzzy, no-c-format
+#, 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 "
@@ -42,114 +42,25 @@
 "about the nature of your persistent objects. You can express a domain model "
 "in other ways (using trees of <literal>Map</literal> instances, for example)."
 msgstr ""
-"Plain Old Java Object (POJO)プログラミングモデルとしても知られる いくつかの単"
-"純なルールに従うなら、Hibernateは最もよく働きます。 しかしこれらのルールは難"
-"しいものではありません。 実際Hibernate3は永続オブジェクトの性質にほとんど何の"
-"前提も置いていません。 ドメインモデルは他の方法で表現することもできます。 例"
+"Plain Old Java Object (POJO)プログラミングモデルとしても知られるいくつかの単"
+"純なルールに従うなら、 Hibernate は最もよく働きます。しかしこれらのルールは難"
+"しいものではありません。実際 Hibernate3 は永続オブジェクトの性質にほとんど何"
+"の前提も置いていません。ドメインモデルは他の方法で表現することもできます。例"
 "えば <literal>Map</literal> インスタンスのツリーを使う方法があります。"
 
 #. Tag: title
-#: persistent_classes.xml:47
 #, no-c-format
 msgid "A simple POJO example"
-msgstr "単純なPOJOの例"
+msgstr "単純な POJO の例"
 
 #. Tag: para
-#: persistent_classes.xml:49
 #, fuzzy, no-c-format
 msgid ""
 "Most Java applications require a persistent class representing felines. For "
 "example:"
-msgstr ""
-"ほとんどのJavaアプリケーションにはネコ科の動物を表現する永続クラスが必要で"
-"す。"
+msgstr "以下はネコ科の動物を表現する永続クラスです。"
 
-#. Tag: programlisting
-#: persistent_classes.xml:53
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"import java.util.Date;\n"
-"\n"
-"public class Cat {\n"
-"    private Long id; // identifier\n"
-"\n"
-"    private Date birthdate;\n"
-"    private Color color;\n"
-"    private char sex;\n"
-"    private float weight;\n"
-"    private int litterId;\n"
-"\n"
-"    private Cat mother;\n"
-"    private Set kittens = new HashSet();\n"
-"\n"
-"    private void setId(Long id) {\n"
-"        this.id=id;\n"
-"    }\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"\n"
-"    void setBirthdate(Date date) {\n"
-"        birthdate = date;\n"
-"    }\n"
-"    public Date getBirthdate() {\n"
-"        return birthdate;\n"
-"    }\n"
-"\n"
-"    void setWeight(float weight) {\n"
-"        this.weight = weight;\n"
-"    }\n"
-"    public float getWeight() {\n"
-"        return weight;\n"
-"    }\n"
-"\n"
-"    public Color getColor() {\n"
-"        return color;\n"
-"    }\n"
-"    void setColor(Color color) {\n"
-"        this.color = color;\n"
-"    }\n"
-"\n"
-"    void setSex(char sex) {\n"
-"        this.sex=sex;\n"
-"    }\n"
-"    public char getSex() {\n"
-"        return sex;\n"
-"    }\n"
-"\n"
-"    void setLitterId(int id) {\n"
-"        this.litterId = id;\n"
-"    }\n"
-"    public int getLitterId() {\n"
-"        return litterId;\n"
-"    }\n"
-"\n"
-"    void setMother(Cat mother) {\n"
-"        this.mother = mother;\n"
-"    }\n"
-"    public Cat getMother() {\n"
-"        return mother;\n"
-"    }\n"
-"    void setKittens(Set kittens) {\n"
-"        this.kittens = kittens;\n"
-"    }\n"
-"    public Set getKittens() {\n"
-"        return kittens;\n"
-"    }\n"
-"    \n"
-"    // addKitten not needed by Hibernate\n"
-"    public void addKitten(Cat kitten) {\n"
-"            kitten.setMother(this);\n"
-"        kitten.setLitterId( kittens.size() ); \n"
-"        kittens.add(kitten);\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:55
 #, no-c-format
 msgid ""
 "The four main rules of persistent classes are explored in more detail in the "
@@ -157,14 +68,12 @@
 msgstr ""
 
 #. Tag: title
-#: persistent_classes.xml:61
 #, no-c-format
 msgid "Implement a no-argument constructor"
 msgstr "引数のないコンストラクタを実装する"
 
 #. Tag: para
-#: persistent_classes.xml:63
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Cat</literal> has a no-argument constructor. All persistent classes "
 "must have a default constructor (which can be non-public) so that Hibernate "
@@ -173,21 +82,19 @@
 "<emphasis>package</emphasis> visibility for runtime proxy generation in "
 "Hibernate."
 msgstr ""
-"<literal>Cat</literal> には引数のないコンストラクタがあります。 Hibernateが "
-"<literal>Constructor.newInstance()</literal> を使って永続クラスの インスタン"
-"ス化を行えるように、すべての永続クラスにはデフォルトコンストラクタ (publicで"
-"なくても構いません)がなければなりません。 Hibernateの実行時プロキシ生成のた"
-"めに、少なくとも <emphasis>package</emphasis> の可視性を持つデフォルトコンス"
-"トラクタを強くお勧めします。"
+"<literal>Cat</literal> には引数のないコンストラクタがあります。 Hibernate が "
+"<literal>Constructor.newInstance()</literal> を使って永続クラスのインスタンス"
+"化を行えるように、すべての永続クラスにはデフォルトコンストラクタ (public で"
+"なくても構いません) がなければなりません。 Hibernate の実行時プロキシ生成の"
+"ために、少なくとも <emphasis>package</emphasis> の可視性を持つデフォルトコン"
+"ストラクタを強くお勧めします。"
 
 #. Tag: title
-#: persistent_classes.xml:73
 #, no-c-format
 msgid "Provide an identifier property (optional)"
 msgstr "識別子プロパティを用意する(オプション)"
 
 #. Tag: para
-#: persistent_classes.xml:75
 #, fuzzy, no-c-format
 msgid ""
 "<literal>Cat</literal> has a property called <literal>id</literal>. This "
@@ -199,27 +106,26 @@
 "types (see the section on composite identifiers later in the chapter.)"
 msgstr ""
 "<literal>Cat</literal> には <literal>id</literal> というプロパティがありま"
-"す。 このプロパティはデータベーステーブルの主キーカラムへマッピングされま"
-"す。 このプロパティの名前は何でも構いませんし、型はどのようなプリミティブ型で"
-"も、 プリミティブの「ラッパー」型でも、<literal>java.lang.String</literal> "
-"や <literal>java.util.Date</literal> でも構いません。 (もしレガシーデータ"
-"ベーステーブルが複合キーを持つならば、 今述べたような型のプロパティを持つユー"
-"ザ定義のクラスを使うことさえ可能です。 後で複合識別子の節を見てください。)"
+"す。このプロパティはデータベーステーブルの主キーカラムへマッピングされます。"
+"このプロパティの名前は何でも構いませんし、型はどのようなプリミティブ型でも、"
+"プリミティブの「ラッパー」型でも、 <literal>java.lang.String</literal> や "
+"<literal>java.util.Date</literal> でも構いません。 (もしレガシーデータベース"
+"テーブルが複合キーを持つならば、今述べたような型のプロパティを持つユーザー定"
+"義のクラスを使うことさえ可能です。後で複合識別子のセクションを見てくださ"
+"い。)"
 
 #. Tag: para
-#: persistent_classes.xml:84
 #, 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 ""
-"識別子プロパティは厳密にはオプションです。 これを省略して、Hibernateに内部的"
-"にオブジェクトの識別子を追跡させることは可能です。 しかしおすすめはしません。"
+"識別子プロパティは厳密にはオプションです。これを省略して、 Hibernate に内部的"
+"にオブジェクトの識別子を追跡させることは可能です。しかしお勧めはしません。"
 
 #. Tag: para
-#: persistent_classes.xml:89
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In fact, some functionality is available only to classes that declare an "
 "identifier property:"
@@ -228,71 +134,64 @@
 "す:"
 
 #. Tag: para
-#: persistent_classes.xml:96
 #, fuzzy, no-c-format
 msgid ""
 "Transitive reattachment for detached objects (cascade update or cascade "
-"merge) - see"
+"merge) - see <xref linkend=\"objectstate-transitive\" />"
 msgstr ""
-"分離オブジェクトの連鎖的な再追加(カスケード更新やカスケードマージ)。 <xref "
-"linkend=\"objectstate-transitive\"/> を参照してください。"
+"分離オブジェクトの連鎖的な再追加(カスケード更新やカスケードマージ) - <xref "
+"linkend=\"objectstate-transitive\" />次を参照してください。"
 
-#. Tag: literal
-#: persistent_classes.xml:103
-#, no-c-format
-msgid "Session.saveOrUpdate()"
-msgstr "Session.saveOrUpdate()"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>Session.saveOrUpdate()</literal>"
+msgstr "<xref linkend=\"objectstate-transitive\" />"
 
-#. Tag: literal
-#: persistent_classes.xml:108
-#, no-c-format
-msgid "Session.merge()"
-msgstr "Session.merge()"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>Session.merge()</literal>"
+msgstr "<literal>Session.merge()</literal>"
 
 #. Tag: para
-#: persistent_classes.xml:113
-#, fuzzy, no-c-format
+#, 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 ""
-"永続クラスには、一貫した名前の識別子プロパティを定義することをお勧めします。 "
-"さらにnull値を取れる(つまりプリミティブではない)型を使った方がよいでしょう。"
+"永続クラスには、一貫した名前の識別子プロパティを定義することをお勧めします。"
+"さらに null 値を取れる(つまりプリミティブではない)型を使った方がよいでしょ"
+"う。"
 
 #. Tag: title
-#: persistent_classes.xml:120
 #, no-c-format
 msgid "Prefer non-final classes (optional)"
-msgstr "finalクラスにしない(オプション)"
+msgstr "final クラスにしない(オプション)"
 
 #. Tag: para
-#: persistent_classes.xml:121
 #, no-c-format
 msgid ""
 "A central feature of Hibernate, <emphasis>proxies</emphasis>, depends upon "
 "the persistent class being either non-final, or the implementation of an "
 "interface that declares all public methods."
 msgstr ""
-"Hibernateの中心的な特徴である <emphasis>プロキシ</emphasis> は、 永続クラスが"
-"finalでないこと、またはメソッドを全部publicで宣言している インターフェイスが"
-"実装されているかに依存しています。"
+"Hibernate の中心的な特徴である <emphasis>プロキシ</emphasis> は、永続クラス"
+"が final でないこと、またはメソッドを全部 public で宣言しているインターフェー"
+"スが実装されているかに依存しています。"
 
 #. Tag: para
-#: persistent_classes.xml:126
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can persist <literal>final</literal> 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</literal> クラスを"
-"永続化することはできますが、 遅延関連フェッチに対してプロキシを使うことはでき"
-"なくなります。 これはパフォーマンスチューニングへの選択肢を狭めることになりま"
-"す。"
+"Hibernate でインターフェースを実装していない <literal>final</literal> クラス"
+"を永続化することはできますが、遅延関連フェッチに対してプロキシを使うことはで"
+"きなくなります。これはパフォーマンスチューニングへの選択肢を狭めることになり"
+"ます。"
 
 #. Tag: para
-#: persistent_classes.xml:131
 #, no-c-format
 msgid ""
 "You should also avoid declaring <literal>public final</literal> methods on "
@@ -300,19 +199,17 @@
 "final</literal> method, you must explicitly disable proxying by setting "
 "<literal>lazy=\"false\"</literal>."
 msgstr ""
-"finalではないクラスで <literal>public final</literal> メソッドを定義すること"
+"final ではないクラスで <literal>public final</literal> メソッドを定義すること"
 "も避けるべきです。 <literal>public final</literal> メソッドを持つクラスを使い"
 "たければ、 <literal>lazy=\"false\"</literal> と設定して明示的にプロキシを無効"
 "にしなければなりません。"
 
 #. Tag: title
-#: persistent_classes.xml:139
 #, no-c-format
 msgid "Declare accessors and mutators for persistent fields (optional)"
 msgstr "永続フィールドに対するアクセサとミューテータを定義する(オプション)"
 
 #. Tag: para
-#: persistent_classes.xml:141
 #, fuzzy, no-c-format
 msgid ""
 "<literal>Cat</literal> declares accessor methods for all its persistent "
@@ -324,70 +221,47 @@
 "required, you can switch to direct field access for particular properties."
 msgstr ""
 "<literal>Cat</literal> ではすべての永続フィールドに対してアクセサメソッドを定"
-"義しています。 他の多くのORMツールは、永続インスタンス変数を直接永続化しま"
-"す。 私たちはリレーショナルスキーマとクラスの内部構造を分離する方が良いと信じ"
-"ています。 デフォルトでは、HibernateはJavaBeanスタイルのプロパティを永続化"
+"義しています。他の多くの ORM ツールは、永続インスタンス変数を直接永続化しま"
+"す。私たちはリレーショナルスキーマとクラスの内部構造を分離する方が良いと信じ"
+"ています。デフォルトでは、 Hibernate は JavaBean スタイルのプロパティを永続化"
 "し、 <literal>getFoo</literal>, <literal>isFoo</literal>, <literal>setFoo</"
-"literal> 形式のメソッド名を認識します。 しかし必要なら、特定のプロパティに対"
-"して、直接のフィールドアクセスに切り替えることは可能です。"
+"literal> 形式のメソッド名を認識します。しかし必要なら、特定のプロパティに対し"
+"て、直接のフィールドアクセスに切り替えることは可能です。"
 
 #. Tag: para
-#: persistent_classes.xml:151
 #, no-c-format
 msgid ""
 "Properties need <emphasis>not</emphasis> be declared public - Hibernate can "
 "persist a property with a default, <literal>protected</literal> or "
 "<literal>private</literal> get / set pair."
 msgstr ""
-"プロパティはpublicで宣言する必要は <emphasis>ありません</emphasis> 。 "
-"Hibernateはデフォルト、<literal>protected</literal> もしくは "
-"<literal>private</literal> のget / setのペアを持つプロパティを永続化すること"
-"ができます。"
+"プロパティは public で宣言する必要は <emphasis>ありません</emphasis> 。 "
+"Hibernate はデフォルトで、 <literal>protected</literal> もしくは "
+"<literal>private</literal> の get / set のペアを持つプロパティを永続化するこ"
+"とができます。"
 
 #. Tag: title
-#: persistent_classes.xml:162
 #, no-c-format
 msgid "Implementing inheritance"
 msgstr "継承の実装"
 
 #. Tag: para
-#: persistent_classes.xml:164
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A subclass must also observe the first and second rules. It inherits its "
 "identifier property from the superclass, <literal>Cat</literal>. For example:"
 msgstr ""
-"サブクラスも1番目と2番目のルールを守らなければなりません。 サブクラスはスー"
+"サブクラスも1番目と2番目のルールを守らなければなりません。サブクラスはスー"
 "パークラス <literal>Cat</literal> から識別子プロパティを継承します。"
 
-#. Tag: programlisting
-#: persistent_classes.xml:169
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"public class DomesticCat extends Cat {\n"
-"        private String name;\n"
-"\n"
-"        public String getName() {\n"
-"                return name;\n"
-"        }\n"
-"        protected void setName(String name) {\n"
-"                this.name=name;\n"
-"        }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: persistent_classes.xml:173
 #, no-c-format
 msgid ""
 "Implementing <literal>equals()</literal> and <literal>hashCode()</literal>"
-msgstr "<literal>equals()</literal> と <literal>hashCode()</literal> の実装"
+msgstr "<literal>equals()</literal> と <literal>hashCode()</literal>の実装"
 
 #. Tag: para
-#: persistent_classes.xml:175
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You have to override the <literal>equals()</literal> and <literal>hashCode()"
 "</literal> methods if you:"
@@ -396,8 +270,7 @@
 "literal> メソッドをオーバーライドしなければなりません、"
 
 #. Tag: para
-#: persistent_classes.xml:181
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "intend to put instances of persistent classes in a <literal>Set</literal> "
 "(the recommended way to represent many-valued associations); <emphasis>and</"
@@ -407,14 +280,12 @@
 "関連を表現するおすすめの方法です) <emphasis>そして同時に</emphasis>"
 
 #. Tag: para
-#: persistent_classes.xml:188
 #, no-c-format
 msgid "intend to use reattachment of detached instances"
 msgstr "分離インスタンスをセッションへ再追加する場合。"
 
 #. Tag: para
-#: persistent_classes.xml:194
-#, fuzzy, no-c-format
+#, 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 "
@@ -422,15 +293,14 @@
 "literal> and <literal>hashCode()</literal> if you wish to have meaningful "
 "semantics for <literal>Set</literal>s."
 msgstr ""
-"Hibernateは、永続ID(データベースの行)と、特定のセッションスコープ内に 限定"
-"ですがJavaIDとが等価であることを保証します。 ですから異なるセッションで検索し"
-"たインスタンスを組み合わせる場合、 <literal>Set</literal> に意味のあるセマン"
-"ティクスを持たせようと思っているなら すぐに<literal>equals()</literal> と "
-"<literal>hashCode()</literal> を実装しなければなりません。"
+"Hibernate は、永続 ID (データベースの行)と、特定のセッションスコープ内に限"
+"定ですが Java ID とが等価であることを保証します。ですから異なるセッションで検"
+"索したインスタンスを組み合わせる場合、 <literal>Set</literal> に意味のあるセ"
+"マンティクスを持たせようと思っているならすぐに <literal>equals()</literal> "
+"と <literal>hashCode()</literal> を実装しなければなりません。"
 
 #. Tag: para
-#: persistent_classes.xml:202
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The most obvious way is to implement <literal>equals()</literal>/"
 "<literal>hashCode()</literal> by comparing the identifier value of both "
@@ -449,23 +319,22 @@
 msgstr ""
 "最も明白な方法は、両方のオブジェクトの識別子の値の比較によって "
 "<literal>equals()</literal>と <literal>hashCode()</literal> を実装する方法で"
-"す。 値が同じなら、両者はデータベースの同じ行でなければならないため等しくなり"
+"す。値が同じなら、両者はデータベースの同じ行でなければならないため等しくなり"
 "ます。 (両者が <literal>Set</literal> に追加されても、 <literal>Set</"
 "literal> には1個の要素しかないことになります) 残念なことに、生成された識別子"
-"にはこのアプローチを使うことができません。 Hibernateは永続化されたオブジェク"
-"トへ識別子の値を代入するだけであり、 新しく作成されたインスタンスはどのような"
-"識別子の値も持っていません。 さらに、インスタンスがセーブされておらず、現在 "
-"<literal>Set</literal> の中にあれば、 セーブするとオブジェクトへ識別子の値を"
-"代入することになります。 もし <literal>equals()</literal> と "
-"<literal>hashCode()</literal> が識別子の値に基づいているなら、 ハッシュコード"
-"が変更されると <literal>Set</literal> の規約が破られます。 この問題についての"
-"完全な議論は、Hibernateのウェブサイトを見てください。 これはHibernateの問題で"
-"はなく、オブジェクトの同一性と等価性についての、 通常のJavaのセマンティクスで"
-"あることに注意してください。"
+"にはこのアプローチを使うことができません。 Hibernate は永続化されたオブジェク"
+"トへ識別子の値を代入するだけであり、新しく作成されたインスタンスはどのような"
+"識別子の値も持っていません。さらに、インスタンスがセーブされておらず、現在 "
+"<literal>Set</literal> の中にあれば、セーブするとオブジェクトへ識別子の値を代"
+"入することになります。もし <literal>equals()</literal> と <literal>hashCode()"
+"</literal> が識別子の値に基づいているなら、ハッシュコードが変更されると "
+"<literal>Set</literal> の規約が破られます。この問題についての完全な議論は、 "
+"Hibernate のウェブサイトを見てください。これは Hibernate の問題ではなく、オブ"
+"ジェクトの同一性と等価性についての、通常の Java のセマンティクスであることに"
+"注意してください。"
 
 #. Tag: para
-#: persistent_classes.xml:216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you implement <literal>equals()</literal> and "
 "<literal>hashCode()</literal> using <emphasis>Business key equality</"
@@ -475,78 +344,44 @@
 "emphasis> candidate key):"
 msgstr ""
 "<emphasis>ビジネスキーの等価性</emphasis> を使って、 <literal>equals()</"
-"literal> と <literal>hashCode()</literal> を実装することをお勧めします。 ビジ"
-"ネスキーの等価性とは、<literal>equals()</literal> メソッドが、ビジネスキー、 "
+"literal> と <literal>hashCode()</literal> を実装することをお勧めします。ビジ"
+"ネスキーの等価性とは、 <literal>equals()</literal> メソッドが、ビジネスキー、"
 "つまり現実の世界においてインスタンスを特定するキー(<emphasis>自然</"
 "emphasis> 候補キー) を形成するプロパティだけを比較することを意味します。"
 
-#. Tag: programlisting
-#: persistent_classes.xml:224
-#, no-c-format
-msgid ""
-"<![CDATA[public class Cat {\n"
-"\n"
-"    ...\n"
-"    public boolean equals(Object other) {\n"
-"        if (this == other) return true;\n"
-"        if ( !(other instanceof Cat) ) return false;\n"
-"\n"
-"        final Cat cat = (Cat) other;\n"
-"\n"
-"        if ( !cat.getLitterId().equals( getLitterId() ) ) return false;\n"
-"        if ( !cat.getMother().equals( getMother() ) ) return false;\n"
-"\n"
-"        return true;\n"
-"    }\n"
-"\n"
-"    public int hashCode() {\n"
-"        int result;\n"
-"        result = getMother().hashCode();\n"
-"        result = 29 * result + getLitterId();\n"
-"        return result;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:226
 #, 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 "
+"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\"/> を見てくださ"
-"い)。 更新不可なプロパティやユニークなプロパティは、通常ビジネスキーのよい候"
+"ください (<xref linkend=\"transactions-basics-identity\"/> を参照してくださ"
+"い)。更新不可なプロパティやユニークなプロパティは、通常ビジネスキーのよい候"
 "補です。"
 
 #. Tag: title
-#: persistent_classes.xml:236
 #, no-c-format
 msgid "Dynamic models"
 msgstr "動的モデル"
 
 #. Tag: title
-#: persistent_classes.xml:239
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "注意"
 
-#. Tag: emphasis
-#: persistent_classes.xml:241
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
-"The following features are currently considered experimental and may change "
-"in the near future."
+"<emphasis>The following features are currently considered experimental and "
+"may change in the near future.</emphasis>"
 msgstr ""
-"以下の機能は現在実験段階にあると見なされており、 近い将来変更される可能性があ"
+"以下の機能は現在実験段階にあると見なされており、近い将来変更される可能性があ"
 "ることに注意してください。"
 
 #. Tag: para
-#: persistent_classes.xml:246
-#, fuzzy, no-c-format
+#, 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 "
@@ -554,131 +389,60 @@
 "and the representation of entities as DOM4J trees. With this approach, you "
 "do not write persistent classes, only mapping files."
 msgstr ""
-"永続エンティティは、必ずしも実行時にPOJOクラスやJavaBeanオブジェクトで表現す"
-"る必要はありません。 Hibernateは(実行時に <literal>Map</literal> の "
-"<literal>Map</literal> を使う)動的モデルと、 DOM4Jツリーとしてのエンティティ"
-"の表現もサポートします。 このアプローチを使うと永続クラスを書かず、マッピング"
-"ファイルだけを書くことになります。"
+"永続エンティティは、必ずしも実行時に POJO クラスや JavaBean オブジェクトで表"
+"現する必要はありません。 Hibernate は(実行時に <literal>Map</literal> の "
+"<literal>Map</literal> を使う)動的モデルと、 DOM4J ツリーとしてのエンティ"
+"ティの表現もサポートします。このアプローチを使うと永続クラスを書かず、マッピ"
+"ングファイルだけを書くことになります。"
 
 #. Tag: para
-#: persistent_classes.xml:254
 #, 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>SessionFactory</"
 "literal> using the <literal>default_entity_mode</literal> configuration "
-"option (see <xref linkend=\"configuration-optional-properties\"/>)."
+"option (see <xref linkend=\"configuration-optional-properties\" />)."
 msgstr ""
-"デフォルトでは、Hibernateは通常のPOJOモードで動作します。 "
-"<literal>default_entity_mode</literal> 設定オプションを使って、 特定の "
+"デフォルトでは、 Hibernate は通常の POJO モードで動作します。 "
+"<literal>default_entity_mode</literal> 設定オプションを使って、特定の "
 "<literal>SessionFactory</literal> に対するデフォルトのエンティティ表現モード"
 "を設定することができます (<xref linkend=\"configuration-optional-properties"
 "\"/> を見てください)。"
 
 #. Tag: para
-#: persistent_classes.xml:261
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following examples demonstrate the representation using <literal>Map</"
 "literal>s. First, in the mapping file an <literal>entity-name</literal> has "
 "to be declared instead of, or in addition to, a class name:"
 msgstr ""
-"以下の例では <literal>Map</literal> を使った表現を紹介します。 まずマッピング"
+"以下の例では <literal>Map</literal> を使った表現を紹介します。まずマッピング"
 "ファイルで、クラス名の代わりに(またはそれに加えて) <literal>entity-name</"
 "literal> を定義しなければなりません:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:267
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class entity-name=\"Customer\">\n"
-"\n"
-"        <id name=\"id\"\n"
-"            type=\"long\"\n"
-"            column=\"ID\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"\n"
-"        <property name=\"name\"\n"
-"            column=\"NAME\"\n"
-"            type=\"string\"/>\n"
-"\n"
-"        <property name=\"address\"\n"
-"            column=\"ADDRESS\"\n"
-"            type=\"string\"/>\n"
-"\n"
-"        <many-to-one name=\"organization\"\n"
-"            column=\"ORGANIZATION_ID\"\n"
-"            class=\"Organization\"/>\n"
-"\n"
-"        <bag name=\"orders\"\n"
-"            inverse=\"true\"\n"
-"            lazy=\"false\"\n"
-"            cascade=\"all\">\n"
-"            <key column=\"CUSTOMER_ID\"/>\n"
-"            <one-to-many class=\"Order\"/>\n"
-"        </bag>\n"
-"\n"
-"    </class>\n"
-"    \n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: persistent_classes.xml:269
-#, 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 ""
-"関連がターゲットのクラス名を使って定義していたとしても、 関連のターゲット型も"
-"POJOではなく動的なエンティティでも構わないことに注意してください。"
+"関連がターゲットのクラス名を使って定義していたとしても、関連のターゲット型も "
+"POJO ではなく動的なエンティティでも構わないことに注意してください。"
 
 #. Tag: para
-#: persistent_classes.xml:276
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "After setting the default entity mode to <literal>dynamic-map</literal> for "
 "the <literal>SessionFactory</literal>, you can, at runtime, work with "
 "<literal>Map</literal>s of <literal>Map</literal>s:"
 msgstr ""
 "<literal>SessionFactory</literal> に対してデフォルトのエンティティモードを "
-"<literal>dynamic-map</literal> に設定した後、 実行時に <literal>Map</"
-"literal> の <literal>Map</literal> を使うことができます:"
+"<literal>dynamic-map</literal> に設定した後、実行時に <literal>Map</literal> "
+"の <literal>Map</literal> を使うことができます:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:282
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session s = openSession();\n"
-"Transaction tx = s.beginTransaction();\n"
-"Session s = openSession();\n"
-"\n"
-"// Create a customer\n"
-"Map david = new HashMap();\n"
-"david.put(\"name\", \"David\");\n"
-"\n"
-"// Create an organization\n"
-"Map foobar = new HashMap();\n"
-"foobar.put(\"name\", \"Foobar Inc.\");\n"
-"\n"
-"// Link both\n"
-"david.put(\"organization\", foobar);\n"
-"\n"
-"// Save both\n"
-"s.save(\"Customer\", david);\n"
-"s.save(\"Organization\", foobar);\n"
-"\n"
-"tx.commit();\n"
-"s.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: persistent_classes.xml:284
-#, 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 "
@@ -686,15 +450,14 @@
 "easily be normalized and sound, allowing to add a proper domain model "
 "implementation on top later on."
 msgstr ""
-"動的なマッピングの利点は、エンティティクラスの実装を必要としないため、 プロト"
-"タイピングに要するターンアラウンドタイムが早いということです。 しかしコンパイ"
+"動的なマッピングの利点は、エンティティクラスの実装を必要としないため、プロト"
+"タイピングに要するターンアラウンドタイムが早いということです。しかしコンパイ"
 "ル時の型チェックがないので、実行時に非常に多くの例外処理を扱わなければならな"
-"いでしょう。 Hibernateマッピングのおかげで、データベーススキーマは容易に正規"
-"化でき、健全になり、 後で適切なドメインモデルの実装を追加することが可能になり"
+"いでしょう。 Hibernate マッピングのおかげで、データベーススキーマは容易に正規"
+"化でき、健全になり、後で適切なドメインモデルの実装を追加することが可能になり"
 "ます。"
 
 #. Tag: para
-#: persistent_classes.xml:292
 #, no-c-format
 msgid ""
 "Entity representation modes can also be set on a per <literal>Session</"
@@ -703,28 +466,9 @@
 "エンティティ表現モードは <literal>Session</literal> ごとに設定することも可能"
 "です。"
 
-#. Tag: programlisting
-#: persistent_classes.xml:297
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session dynamicSession = pojoSession.getSession(EntityMode.MAP);\n"
-"\n"
-"// Create a customer\n"
-"Map david = new HashMap();\n"
-"david.put(\"name\", \"David\");\n"
-"dynamicSession.save(\"Customer\", david);\n"
-"...\n"
-"dynamicSession.flush();\n"
-"dynamicSession.close()\n"
-"...\n"
-"// Continue on pojoSession\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: persistent_classes.xml:300
-#, fuzzy, no-c-format
-msgid ""
 "Please note that the call to <literal>getSession()</literal> using an "
 "<literal>EntityMode</literal> is on the <literal>Session</literal> API, not "
 "the <literal>SessionFactory</literal>. That way, the new <literal>Session</"
@@ -736,32 +480,29 @@
 msgstr ""
 "<literal>EntityMode</literal> を使った <literal>getSession()</literal> の呼び"
 "出しは <literal>SessionFactory</literal> ではなく <literal>Session</literal> "
-"APIにあることに注意してください。 その方法では、新しい <literal>Session</"
-"literal> は、ベースとなるJDBCコネクション、 トランザクション、その他のコンテ"
-"キスト情報を共有します。 これは2番目の <literal>Session</literal> では "
+"APIにあることに注意してください。その方法では、新しい <literal>Session</"
+"literal> は、ベースとなる JDBC コネクション、トランザクション、その他のコンテ"
+"キスト情報を共有します。これは2番目の <literal>Session</literal> では "
 "<literal>flush()</literal> と <literal>close()</literal> を呼ぶ必要がないとい"
-"うこと、そのためトランザクションとコネクションの管理を 1番目の作業単位(Unit "
+"うこと、そのためトランザクションとコネクションの管理を1番目の作業単位(Unit "
 "of Work)に任せることができるということです。"
 
 #. Tag: para
-#: persistent_classes.xml:310
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "More information about the XML representation capabilities can be found in "
-"<xref linkend=\"xml\"/>."
+"<xref linkend=\"xml\" />."
 msgstr ""
-"XML表現の能力についてのさらなる情報は <xref linkend=\"xml\"/> で見つかりま"
-"す。"
+"XML 表現の能力についてのさらなる情報は <xref linkend=\"xml\"/> に記述されてい"
+"ます。"
 
 #. Tag: title
-#: persistent_classes.xml:318
 #, no-c-format
 msgid "Tuplizers"
 msgstr "Tuplizer"
 
 #. Tag: para
-#: persistent_classes.xml:320
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.tuple.Tuplizer</literal>, and its sub-interfaces, are "
 "responsible for managing a particular representation of a piece of data "
@@ -773,22 +514,16 @@
 "through its constructor. It also knows how to access the POJO properties "
 "using the defined property accessors."
 msgstr ""
-"<literal>org.hibernate.tuple.Tuplizer</literal> とそのサブインターフェイス"
-"は、 表現の <literal>org.hibernate.EntityMode</literal> を利用して、 データ断"
-"片のある表現の管理に責任を持ちます。 与えられたデータ断片をデータ構造として考"
-"えるなら、Tuplizerはそのようなデータ構造を どのように作成するかを知り、そのよ"
-"うなデータ構造からどのように値を抽出し、 注入するかを知っています。 例えば"
-"POJOエンティティモードでは、対応するTuplizerはコンストラクタを通して、 POJOを"
-"どのように作成するか、定義されたプロパティアクセサを使い、 POJOプロパティにど"
-"のようにアクセスするかを知ります。 Tuplizerには二つのハイレベルの型がありま"
-"す。 それらは、<literal>org.hibernate.tuple.EntityTuplizer</literal> と "
-"<literal>org.hibernate.tuple.ComponentTuplizer</literal> インターフェイスで表"
-"現されます。 <literal>EntityTuplizer</literal> は上で述べたようなエンティティ"
-"に関する契約の管理に責任を持ちます。 一方、<literal>ComponentTuplizer</"
-"literal> はコンポーネントに関する契約の管理に責任を持ちます。"
+"<literal>org.hibernate.tuple.Tuplizer</literal> とそのサブインターフェース"
+"は、表現の <literal>org.hibernate.EntityMode</literal> を利用して、データ断片"
+"のある表現の管理に責任を持ちます。与えられたデータ断片をデータ構造として考え"
+"るなら、 Tuplizer はそのようなデータ構造をどのように作成するかを知り、そのよ"
+"うなデータ構造からどのように値を抽出し、注入するかを知っています。例えば "
+"POJO エンティティモードでは、対応する Tuplizer はコンストラクタを通して、 "
+"POJO をどのように作成するか、定義されたプロパティアクセサを使い、 POJO プロパ"
+"ティにどのようにアクセスするかを知ります。"
 
 #. Tag: para
-#: persistent_classes.xml:330
 #, no-c-format
 msgid ""
 "There are two high-level types of Tuplizers, represented by the <literal>org."
@@ -798,10 +533,15 @@
 "mentioned contracts in regards to entities, while "
 "<literal>ComponentTuplizer</literal>s do the same for components."
 msgstr ""
+"Tuplizer には二つのハイレベルの型があります。それらは、<literal>org."
+"hibernate.tuple.entity.EntityTuplizer</literal> と <literal>org.hibernate."
+"tuple.component.ComponentTuplizer</literal> インターフェースで表現されます。 "
+"<literal>EntityTuplizer</literal> は上で述べたようなエンティティに関する契約"
+"の管理に責任を持ちます。一方、 <literal>ComponentTuplizer</literal> はコン"
+"ポーネントに関する契約の管理に責任を持ちます。"
 
 #. Tag: para
-#: persistent_classes.xml:338
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Users can also plug in their own tuplizers. Perhaps you require that a "
 "<literal>java.util.Map</literal> implementation other than <literal>java."
@@ -812,63 +552,20 @@
 "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> を使うのではなく、 "
-"<literal>java.util.Map</literal> の実装が必要でしょう。 もしくは、おそらくデ"
-"フォルトのものではなく、別のプロキシ生成戦略の定義が必要でしょう。 両者とも、"
-"カスタムのTuplizer実装を定義することで達成されます。 Tuplizerの定義は、管理し"
-"ようとするエンティティやコンポーネントのマッピングに結び付けられます。 顧客エ"
-"ンティティの例に戻ると:"
+"ユーザーは独自の Tuplizer に差し替えることも可能です。おそらく dynamic-map "
+"entity-mode の際に <literal>java.util.HashMap</literal> を使うのではなく、 "
+"<literal>java.util.Map</literal> の実装が必要でしょう。もしくは、おそらくデ"
+"フォルトのものではなく、別のプロキシ生成戦略の定義が必要でしょう。両者とも、"
+"カスタムの Tuplizer 実装を定義することで達成されます。 Tuplizer の定義は、管"
+"理しようとするエンティティやコンポーネントのマッピングに結び付けられます。顧"
+"客エンティティの例は以下になります:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:347
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    <class entity-name=\"Customer\">\n"
-"        <!--\n"
-"            Override the dynamic-map entity-mode\n"
-"            tuplizer for the customer entity\n"
-"        -->\n"
-"        <tuplizer entity-mode=\"dynamic-map\"\n"
-"                class=\"CustomMapTuplizerImpl\"/>\n"
-"\n"
-"        <id name=\"id\" type=\"long\" column=\"ID\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"\n"
-"        <!-- other properties -->\n"
-"        ...\n"
-"    </class>\n"
-"</hibernate-mapping>\n"
-"\n"
-"\n"
-"public class CustomMapTuplizerImpl\n"
-"        extends org.hibernate.tuple.entity.DynamicMapEntityTuplizer {\n"
-"    // override the buildInstantiator() method to plug in our custom map...\n"
-"    protected final Instantiator buildInstantiator(\n"
-"            org.hibernate.mapping.PersistentClass mappingInfo) {\n"
-"        return new CustomMapInstantiator( mappingInfo );\n"
-"    }\n"
-"\n"
-"    private static final class CustomMapInstantiator\n"
-"            extends org.hibernate.tuple.DynamicMapInstantitor {\n"
-"        // override the generateMap() method to return our custom map...\n"
-"            protected final Map generateMap() {\n"
-"                    return new CustomMap();\n"
-"            }\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: persistent_classes.xml:354
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "EntityNameResolvers"
-msgstr ""
+msgstr "エンティティリゾルバ"
 
 #. Tag: para
-#: persistent_classes.xml:356
 #, no-c-format
 msgid ""
 "The <interfacename>org.hibernate.EntityNameResolver</interfacename> "
@@ -886,140 +583,7 @@
 "package for illustration."
 msgstr ""
 
-#. Tag: programlisting
-#: persistent_classes.xml:368
-#, no-c-format
-msgid ""
-"/**\n"
-" * A very trivial JDK Proxy InvocationHandler implementation where we proxy "
-"an interface as\n"
-" * the domain model and simply store persistent state in an internal Map.  "
-"This is an extremely\n"
-" * trivial example meant only for illustration.\n"
-" */\n"
-"public final class DataProxyHandler implements InvocationHandler {\n"
-"        private String entityName;\n"
-"        private HashMap data = new HashMap();\n"
-"\n"
-"        public DataProxyHandler(String entityName, Serializable id) {\n"
-"                this.entityName = entityName;\n"
-"                data.put( \"Id\", id );\n"
-"        }\n"
-"\n"
-"        public Object invoke(Object proxy, Method method, Object[] args) "
-"throws Throwable {\n"
-"                String methodName = method.getName();\n"
-"                if ( methodName.startsWith( \"set\" ) ) {\n"
-"                        String propertyName = methodName.substring( 3 );\n"
-"                        data.put( propertyName, args[0] );\n"
-"                }\n"
-"                else if ( methodName.startsWith( \"get\" ) ) {\n"
-"                        String propertyName = methodName.substring( 3 );\n"
-"                        return data.get( propertyName );\n"
-"                }\n"
-"                else if ( \"toString\".equals( methodName ) ) {\n"
-"                        return entityName + \"#\" + data.get( \"Id\" );\n"
-"                }\n"
-"                else if ( \"hashCode\".equals( methodName ) ) {\n"
-"                        return new Integer( this.hashCode() );\n"
-"                }\n"
-"                return null;\n"
-"        }\n"
-"\n"
-"        public String getEntityName() {\n"
-"                return entityName;\n"
-"        }\n"
-"\n"
-"        public HashMap getData() {\n"
-"                return data;\n"
-"        }\n"
-"}\n"
-"\n"
-"/**\n"
-" *\n"
-" */\n"
-"public class ProxyHelper {\n"
-"    public static String extractEntityName(Object object) {\n"
-"        // Our custom java.lang.reflect.Proxy instances actually bundle\n"
-"        // their appropriate entity name, so we simply extract it from "
-"there\n"
-"        // if this represents one of our proxies; otherwise, we return null\n"
-"        if ( Proxy.isProxyClass( object.getClass() ) ) {\n"
-"            InvocationHandler handler = Proxy.getInvocationHandler"
-"( object );\n"
-"            if ( DataProxyHandler.class.isAssignableFrom( handler.getClass"
-"() ) ) {\n"
-"                DataProxyHandler myHandler = ( DataProxyHandler ) handler;\n"
-"                return myHandler.getEntityName();\n"
-"            }\n"
-"        }\n"
-"        return null;\n"
-"    }\n"
-"\n"
-"    // various other utility methods ....\n"
-"\n"
-"}\n"
-"\n"
-"/**\n"
-" * The EntityNameResolver implementation.\n"
-" * IMPL NOTE : An EntityNameResolver really defines a strategy for how "
-"entity names should be\n"
-" * resolved.  Since this particular impl can handle resolution for all of "
-"our entities we want to\n"
-" * take advantage of the fact that SessionFactoryImpl keeps these in a Set "
-"so that we only ever\n"
-" * have one instance registered.  Why?  Well, when it comes time to resolve "
-"an entity name,\n"
-" * Hibernate must iterate over all the registered resolvers.  So keeping "
-"that number down\n"
-" * helps that process be as speedy as possible.  Hence the equals and "
-"hashCode impls\n"
-" */\n"
-"public class MyEntityNameResolver implements EntityNameResolver {\n"
-"    public static final MyEntityNameResolver INSTANCE = new "
-"MyEntityNameResolver();\n"
-"\n"
-"    public String resolveEntityName(Object entity) {\n"
-"        return ProxyHelper.extractEntityName( entity );\n"
-"    }\n"
-"\n"
-"    public boolean equals(Object obj) {\n"
-"        return getClass().equals( obj.getClass() );\n"
-"    }\n"
-"\n"
-"    public int hashCode() {\n"
-"        return getClass().hashCode();\n"
-"    }\n"
-"}\n"
-"\n"
-"public class MyEntityTuplizer extends PojoEntityTuplizer {\n"
-"        public MyEntityTuplizer(EntityMetamodel entityMetamodel, "
-"PersistentClass mappedEntity) {\n"
-"                super( entityMetamodel, mappedEntity );\n"
-"        }\n"
-"\n"
-"        public EntityNameResolver[] getEntityNameResolvers() {\n"
-"                return new EntityNameResolver[] { MyEntityNameResolver."
-"INSTANCE };\n"
-"        }\n"
-"\n"
-"    public String determineConcreteSubclassEntityName(Object entityInstance, "
-"SessionFactoryImplementor factory) {\n"
-"        String entityName = ProxyHelper.extractEntityName"
-"( entityInstance );\n"
-"        if ( entityName == null ) {\n"
-"            entityName = super.determineConcreteSubclassEntityName"
-"( entityInstance, factory );\n"
-"        }\n"
-"        return entityName;\n"
-"    }\n"
-"\n"
-"    ...\n"
-"}"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:370
 #, no-c-format
 msgid ""
 "In order to register an <interfacename>org.hibernate.EntityNameResolver</"
@@ -1027,7 +591,6 @@
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:374
 #, no-c-format
 msgid ""
 "Implement a custom <link linkend=\"persistent-classes-tuplizers\">Tuplizer</"
@@ -1036,7 +599,6 @@
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:380
 #, no-c-format
 msgid ""
 "Register it with the <classname>org.hibernate.impl.SessionFactoryImpl</"
@@ -1045,11 +607,460 @@
 "<methodname>registerEntityNameResolver</methodname> method."
 msgstr ""
 
-#~ msgid "There are four main rules to follow here:"
-#~ msgstr "従うべき4つのルールがあります:"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "import java.util.Set;\n"
+#~ "import java.util.Date;\n"
+#~ "\n"
+#~ "public class Cat {\n"
+#~ "    private Long id; // identifier\n"
+#~ "\n"
+#~ "    private Date birthdate;\n"
+#~ "    private Color color;\n"
+#~ "    private char sex;\n"
+#~ "    private float weight;\n"
+#~ "    private int litterId;\n"
+#~ "\n"
+#~ "    private Cat mother;\n"
+#~ "    private Set kittens = new HashSet();\n"
+#~ "\n"
+#~ "    private void setId(Long id) {\n"
+#~ "        this.id=id;\n"
+#~ "    }\n"
+#~ "    public Long getId() {\n"
+#~ "        return id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setBirthdate(Date date) {\n"
+#~ "        birthdate = date;\n"
+#~ "    }\n"
+#~ "    public Date getBirthdate() {\n"
+#~ "        return birthdate;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setWeight(float weight) {\n"
+#~ "        this.weight = weight;\n"
+#~ "    }\n"
+#~ "    public float getWeight() {\n"
+#~ "        return weight;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public Color getColor() {\n"
+#~ "        return color;\n"
+#~ "    }\n"
+#~ "    void setColor(Color color) {\n"
+#~ "        this.color = color;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setSex(char sex) {\n"
+#~ "        this.sex=sex;\n"
+#~ "    }\n"
+#~ "    public char getSex() {\n"
+#~ "        return sex;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setLitterId(int id) {\n"
+#~ "        this.litterId = id;\n"
+#~ "    }\n"
+#~ "    public int getLitterId() {\n"
+#~ "        return litterId;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setMother(Cat mother) {\n"
+#~ "        this.mother = mother;\n"
+#~ "    }\n"
+#~ "    public Cat getMother() {\n"
+#~ "        return mother;\n"
+#~ "    }\n"
+#~ "    void setKittens(Set kittens) {\n"
+#~ "        this.kittens = kittens;\n"
+#~ "    }\n"
+#~ "    public Set getKittens() {\n"
+#~ "        return kittens;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    // addKitten not needed by Hibernate\n"
+#~ "    public void addKitten(Cat kitten) {\n"
+#~ "            kitten.setMother(this);\n"
+#~ "        kitten.setLitterId( kittens.size() ); \n"
+#~ "        kittens.add(kitten);\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "package eg;\n"
+#~ "import java.util.Set;\n"
+#~ "import java.util.Date;\n"
+#~ "\n"
+#~ "public class Cat {\n"
+#~ "    private Long id; // identifier\n"
+#~ "\n"
+#~ "    private Date birthdate;\n"
+#~ "    private Color color;\n"
+#~ "    private char sex;\n"
+#~ "    private float weight;\n"
+#~ "    private int litterId;\n"
+#~ "\n"
+#~ "    private Cat mother;\n"
+#~ "    private Set kittens = new HashSet();\n"
+#~ "\n"
+#~ "    private void setId(Long id) {\n"
+#~ "        this.id=id;\n"
+#~ "    }\n"
+#~ "    public Long getId() {\n"
+#~ "        return id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setBirthdate(Date date) {\n"
+#~ "        birthdate = date;\n"
+#~ "    }\n"
+#~ "    public Date getBirthdate() {\n"
+#~ "        return birthdate;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setWeight(float weight) {\n"
+#~ "        this.weight = weight;\n"
+#~ "    }\n"
+#~ "    public float getWeight() {\n"
+#~ "        return weight;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public Color getColor() {\n"
+#~ "        return color;\n"
+#~ "    }\n"
+#~ "    void setColor(Color color) {\n"
+#~ "        this.color = color;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setSex(char sex) {\n"
+#~ "        this.sex=sex;\n"
+#~ "    }\n"
+#~ "    public char getSex() {\n"
+#~ "        return sex;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setLitterId(int id) {\n"
+#~ "        this.litterId = id;\n"
+#~ "    }\n"
+#~ "    public int getLitterId() {\n"
+#~ "        return litterId;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setMother(Cat mother) {\n"
+#~ "        this.mother = mother;\n"
+#~ "    }\n"
+#~ "    public Cat getMother() {\n"
+#~ "        return mother;\n"
+#~ "    }\n"
+#~ "    void setKittens(Set kittens) {\n"
+#~ "        this.kittens = kittens;\n"
+#~ "    }\n"
+#~ "    public Set getKittens() {\n"
+#~ "        return kittens;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    // addKitten not needed by Hibernate\n"
+#~ "    public void addKitten(Cat kitten) {\n"
+#~ "    kitten.setMother(this);\n"
+#~ "kitten.setLitterId( kittens.size() ); \n"
+#~ "        kittens.add(kitten);\n"
+#~ "    }\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "TODO: Document user-extension framework in the property and proxy packages"
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "public class DomesticCat extends Cat {\n"
+#~ "        private String name;\n"
+#~ "\n"
+#~ "        public String getName() {\n"
+#~ "                return name;\n"
+#~ "        }\n"
+#~ "        protected void setName(String name) {\n"
+#~ "                this.name=name;\n"
+#~ "        }\n"
+#~ "}]]>"
 #~ msgstr ""
-#~ "TODO: プロパティとプロキシパッケージのユーザ拡張フレームワークを文書化する"
-#~ "こと"
+#~ "package eg;\n"
+#~ "\n"
+#~ "public class DomesticCat extends Cat {\n"
+#~ "        private String name;\n"
+#~ "\n"
+#~ "        public String getName() {\n"
+#~ "                return name;\n"
+#~ "        }\n"
+#~ "        protected void setName(String name) {\n"
+#~ "                this.name=name;\n"
+#~ "        }\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[public class Cat {\n"
+#~ "\n"
+#~ "    ...\n"
+#~ "    public boolean equals(Object other) {\n"
+#~ "        if (this == other) return true;\n"
+#~ "        if ( !(other instanceof Cat) ) return false;\n"
+#~ "\n"
+#~ "        final Cat cat = (Cat) other;\n"
+#~ "\n"
+#~ "        if ( !cat.getLitterId().equals( getLitterId() ) ) return false;\n"
+#~ "        if ( !cat.getMother().equals( getMother() ) ) return false;\n"
+#~ "\n"
+#~ "        return true;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public int hashCode() {\n"
+#~ "        int result;\n"
+#~ "        result = getMother().hashCode();\n"
+#~ "        result = 29 * result + getLitterId();\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "public class Cat {\n"
+#~ "\n"
+#~ "    ...\n"
+#~ "    public boolean equals(Object other) {\n"
+#~ "        if (this == other) return true;\n"
+#~ "        if ( !(other instanceof Cat) ) return false;\n"
+#~ "\n"
+#~ "        final Cat cat = (Cat) other;\n"
+#~ "\n"
+#~ "        if ( !cat.getLitterId().equals( getLitterId() ) ) return false;\n"
+#~ "        if ( !cat.getMother().equals( getMother() ) ) return false;\n"
+#~ "\n"
+#~ "        return true;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public int hashCode() {\n"
+#~ "        int result;\n"
+#~ "        result = getMother().hashCode();\n"
+#~ "        result = 29 * result + getLitterId();\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class entity-name=\"Customer\">\n"
+#~ "\n"
+#~ "        <id name=\"id\"\n"
+#~ "            type=\"long\"\n"
+#~ "            column=\"ID\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property name=\"name\"\n"
+#~ "            column=\"NAME\"\n"
+#~ "            type=\"string\"/>\n"
+#~ "\n"
+#~ "        <property name=\"address\"\n"
+#~ "            column=\"ADDRESS\"\n"
+#~ "            type=\"string\"/>\n"
+#~ "\n"
+#~ "        <many-to-one name=\"organization\"\n"
+#~ "            column=\"ORGANIZATION_ID\"\n"
+#~ "            class=\"Organization\"/>\n"
+#~ "\n"
+#~ "        <bag name=\"orders\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            lazy=\"false\"\n"
+#~ "            cascade=\"all\">\n"
+#~ "            <key column=\"CUSTOMER_ID\"/>\n"
+#~ "            <one-to-many class=\"Order\"/>\n"
+#~ "        </bag>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "    \n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "\n"
+#~ "    &lt;class entity-name=\"Customer\"&gt;\n"
+#~ "\n"
+#~ "        &lt;id name=\"id\"\n"
+#~ "            type=\"long\"\n"
+#~ "            column=\"ID\"&gt;\n"
+#~ "            &lt;generator class=\"sequence\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "\n"
+#~ "        &lt;property name=\"name\"\n"
+#~ "            column=\"NAME\"\n"
+#~ "            type=\"string\"/&gt;\n"
+#~ "\n"
+#~ "        &lt;property name=\"address\"\n"
+#~ "            column=\"ADDRESS\"\n"
+#~ "            type=\"string\"/&gt;\n"
+#~ "\n"
+#~ "        &lt;many-to-one name=\"organization\"\n"
+#~ "            column=\"ORGANIZATION_ID\"\n"
+#~ "            class=\"Organization\"/&gt;\n"
+#~ "\n"
+#~ "        &lt;bag name=\"orders\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            lazy=\"false\"\n"
+#~ "            cascade=\"all\"&gt;\n"
+#~ "            &lt;key column=\"CUSTOMER_ID\"/&gt;\n"
+#~ "            &lt;one-to-many class=\"Order\"/&gt;\n"
+#~ "        &lt;/bag&gt;\n"
+#~ "\n"
+#~ "    &lt;/class&gt;\n"
+#~ "    \n"
+#~ "&lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Session s = openSession();\n"
+#~ "Transaction tx = s.beginTransaction();\n"
+#~ "Session s = openSession();\n"
+#~ "\n"
+#~ "// Create a customer\n"
+#~ "Map david = new HashMap();\n"
+#~ "david.put(\"name\", \"David\");\n"
+#~ "\n"
+#~ "// Create an organization\n"
+#~ "Map foobar = new HashMap();\n"
+#~ "foobar.put(\"name\", \"Foobar Inc.\");\n"
+#~ "\n"
+#~ "// Link both\n"
+#~ "david.put(\"organization\", foobar);\n"
+#~ "\n"
+#~ "// Save both\n"
+#~ "s.save(\"Customer\", david);\n"
+#~ "s.save(\"Organization\", foobar);\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "s.close();]]>"
+#~ msgstr ""
+#~ "Session s = openSession();\n"
+#~ "Transaction tx = s.beginTransaction();\n"
+#~ "Session s = openSession();\n"
+#~ "\n"
+#~ "// Create a customer\n"
+#~ "Map david = new HashMap();\n"
+#~ "david.put(\"name\", \"David\");\n"
+#~ "\n"
+#~ "// Create an organization\n"
+#~ "Map foobar = new HashMap();\n"
+#~ "foobar.put(\"name\", \"Foobar Inc.\");\n"
+#~ "\n"
+#~ "// Link both\n"
+#~ "david.put(\"organization\", foobar);\n"
+#~ "\n"
+#~ "// Save both\n"
+#~ "s.save(\"Customer\", david);\n"
+#~ "s.save(\"Organization\", foobar);\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "s.close();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Session dynamicSession = pojoSession.getSession(EntityMode."
+#~ "MAP);\n"
+#~ "\n"
+#~ "// Create a customer\n"
+#~ "Map david = new HashMap();\n"
+#~ "david.put(\"name\", \"David\");\n"
+#~ "dynamicSession.save(\"Customer\", david);\n"
+#~ "...\n"
+#~ "dynamicSession.flush();\n"
+#~ "dynamicSession.close()\n"
+#~ "...\n"
+#~ "// Continue on pojoSession\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "Session dynamicSession = pojoSession.getSession(EntityMode.MAP);\n"
+#~ "\n"
+#~ "// Create a customer\n"
+#~ "Map david = new HashMap();\n"
+#~ "david.put(\"name\", \"David\");\n"
+#~ "dynamicSession.save(\"Customer\", david);\n"
+#~ "...\n"
+#~ "dynamicSession.flush();\n"
+#~ "dynamicSession.close()\n"
+#~ "...\n"
+#~ "// Continue on pojoSession"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "    <class entity-name=\"Customer\">\n"
+#~ "        <!--\n"
+#~ "            Override the dynamic-map entity-mode\n"
+#~ "            tuplizer for the customer entity\n"
+#~ "        -->\n"
+#~ "        <tuplizer entity-mode=\"dynamic-map\"\n"
+#~ "                class=\"CustomMapTuplizerImpl\"/>\n"
+#~ "\n"
+#~ "        <id name=\"id\" type=\"long\" column=\"ID\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <!-- other properties -->\n"
+#~ "        ...\n"
+#~ "    </class>\n"
+#~ "</hibernate-mapping>\n"
+#~ "\n"
+#~ "\n"
+#~ "public class CustomMapTuplizerImpl\n"
+#~ "        extends org.hibernate.tuple.entity.DynamicMapEntityTuplizer {\n"
+#~ "    // override the buildInstantiator() method to plug in our custom "
+#~ "map...\n"
+#~ "    protected final Instantiator buildInstantiator(\n"
+#~ "            org.hibernate.mapping.PersistentClass mappingInfo) {\n"
+#~ "        return new CustomMapInstantiator( mappingInfo );\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    private static final class CustomMapInstantiator\n"
+#~ "            extends org.hibernate.tuple.DynamicMapInstantitor {\n"
+#~ "        // override the generateMap() method to return our custom map...\n"
+#~ "            protected final Map generateMap() {\n"
+#~ "                    return new CustomMap();\n"
+#~ "            }\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "    &lt;class entity-name=\"Customer\"&gt;\n"
+#~ "        &lt;!--\n"
+#~ "            Override the dynamic-map entity-mode\n"
+#~ "            tuplizer for the customer entity\n"
+#~ "        --&gt;\n"
+#~ "        &lt;tuplizer entity-mode=\"dynamic-map\"\n"
+#~ "                class=\"CustomMapTuplizerImpl\"/&gt;\n"
+#~ "\n"
+#~ "        &lt;id name=\"id\" type=\"long\" column=\"ID\"&gt;\n"
+#~ "            &lt;generator class=\"sequence\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "\n"
+#~ "        &lt;!-- other properties --&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/class&gt;\n"
+#~ "&lt;/hibernate-mapping&gt;\n"
+#~ "\n"
+#~ "\n"
+#~ "public class CustomMapTuplizerImpl\n"
+#~ "        extends org.hibernate.tuple.entity.DynamicMapEntityTuplizer {\n"
+#~ "    // override the buildInstantiator() method to plug in our custom "
+#~ "map...\n"
+#~ "    protected final Instantiator buildInstantiator(\n"
+#~ "            org.hibernate.mapping.PersistentClass mappingInfo) {\n"
+#~ "        return new CustomMapInstantiator( mappingInfo );\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    private static final class CustomMapInstantiator\n"
+#~ "            extends org.hibernate.tuple.DynamicMapInstantitor {\n"
+#~ "        // override the generateMap() method to return our custom map...\n"
+#~ "    protected final Map generateMap() {\n"
+#~ "    return new CustomMap();\n"
+#~ "    }\n"
+#~ "    }\n"
+#~ "}"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/portability.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/portability.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/portability.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,32 +1,29 @@
-# Language ja-JP translations for PACKAGE package.
-# Automatically generated, 2009.
-#
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: 2009-07-14 19:56+0000\n"
-"Last-Translator: Automatically generated\n"
-"Language-Team: none\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-20 17:03+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: portability.xml:26
 #, no-c-format
 msgid "Database Portability Considerations"
 msgstr ""
 
 #. Tag: title
-#: portability.xml:29
 #, no-c-format
 msgid "Portability Basics"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:31
 #, no-c-format
 msgid ""
 "One of the selling points of Hibernate (and really Object/Relational Mapping "
@@ -40,13 +37,11 @@
 msgstr ""
 
 #. Tag: title
-#: portability.xml:42
 #, no-c-format
 msgid "Dialect"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:44
 #, no-c-format
 msgid ""
 "The first line of portability for Hibernate is the dialect, which is a "
@@ -60,13 +55,11 @@
 msgstr ""
 
 #. Tag: title
-#: portability.xml:55
 #, no-c-format
 msgid "Dialect resolution"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:57
 #, no-c-format
 msgid ""
 "Originally, Hibernate would always require that users specify which dialect "
@@ -77,7 +70,6 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:64
 #, no-c-format
 msgid ""
 "Starting with version 3.2, Hibernate introduced the notion of automatically "
@@ -89,15 +81,14 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:72
 #, no-c-format
 msgid ""
 "Starting with version 3.3, Hibernate has a fare more powerful way to "
 "automatically determine which dialect to should be used by relying on a "
 "series of delegates which implement the <interfacename>org.hibernate.dialect."
 "resolver.DialectResolver</interfacename> which defines only a single method:"
-"<programlisting><![CDATA[public Dialect resolveDialect(DatabaseMetaData "
-"metaData) throws JDBCConnectionException]]></programlisting>. The basic "
+"<programlisting role=\"JAVA\">public Dialect resolveDialect(DatabaseMetaData "
+"metaData) throws JDBCConnectionException</programlisting>. The basic "
 "contract here is that if the resolver 'understands' the given database "
 "metadata then it returns the corresponding Dialect; if not it returns null "
 "and the process continues to the next resolver. The signature also "
@@ -110,7 +101,6 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:85
 #, no-c-format
 msgid ""
 "The cool part about these resolvers is that users can also register their "
@@ -126,13 +116,11 @@
 msgstr ""
 
 #. Tag: title
-#: portability.xml:98
 #, no-c-format
 msgid "Identifier generation"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:100
 #, no-c-format
 msgid ""
 "When considering portability between databases, another important decision "
@@ -151,38 +139,64 @@
 "reference entities within a persistence context it must then issue the "
 "insert immediately when the users requests the entitiy be associated with "
 "the session (like via save() e.g.) regardless of current transactional "
-"semantics. <note> <para> Hibernate was changed slightly once the implication "
-"of this was better understood so that the insert is delayed in cases where "
-"that is feasible. </para> </note> The underlying issue is that the actual "
-"semanctics of the application itself changes in these cases."
+"semantics."
 msgstr ""
 
 #. Tag: para
-#: portability.xml:125
 #, no-c-format
 msgid ""
+"Hibernate was changed slightly once the implication of this was better "
+"understood so that the insert is delayed in cases where that is feasible."
+msgstr ""
+
+#. Tag: note
+#, no-c-format
+msgid ""
+"The underlying issue is that the actual semanctics of the application itself "
+"changes in these cases."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
 "Starting with version 3.2.3, Hibernate comes with a set of <ulink url="
 "\"http://in.relation.to/2082.lace\">enhanced</ulink> identifier generators "
-"targetting portability in a much different way. <note> <para> There are "
-"specifically 2 bundled <emphasis>enhanced</emphasis>generators: "
-"<itemizedlist> <listitem> <para> <classname>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</classname> </para> </listitem> <listitem> <para> "
-"<classname>org.hibernate.id.enhanced.TableGenerator</classname> </para> </"
-"listitem> </itemizedlist> </para> </note> The idea behind these generators "
-"is to port the actual semantics of the identifer value generation to the "
-"different databases. For example, the <classname>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</classname> mimics the behavior of a sequence on "
-"databases which do not support sequences by using a table."
+"targetting portability in a much different way."
 msgstr ""
 
+#. Tag: para
+#, no-c-format
+msgid ""
+"There are specifically 2 bundled <emphasis>enhanced</emphasis>generators:"
+msgstr ""
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname>"
+msgstr ""
+"<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname>"
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<classname>org.hibernate.id.enhanced.TableGenerator</classname>"
+msgstr "<classname>org.hibernate.id.enhanced.TableGenerator</classname>"
+
+#. Tag: note
+#, no-c-format
+msgid ""
+"The idea behind these generators is to port the actual semantics of the "
+"identifer value generation to the different databases. For example, the "
+"<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname> "
+"mimics the behavior of a sequence on databases which do not support "
+"sequences by using a table."
+msgstr ""
+
 #. Tag: title
-#: portability.xml:154
 #, no-c-format
 msgid "Database functions"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:157
 #, no-c-format
 msgid ""
 "This is an area in Hibernate in need of improvement. In terms of portability "
@@ -191,7 +205,6 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:164
 #, no-c-format
 msgid ""
 "SQL functions can be referenced in many ways by users. However, not all "
@@ -202,7 +215,6 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:170
 #, no-c-format
 msgid ""
 "Technically this function registration is handled through the <classname>org."
@@ -213,7 +225,6 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:177
 #, no-c-format
 msgid ""
 "It is sort of implemented such that users can programatically register "
@@ -222,13 +233,11 @@
 msgstr ""
 
 #. Tag: title
-#: portability.xml:187
 #, no-c-format
 msgid "Type mappings"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:189
 #, no-c-format
 msgid "This section scheduled for completion at a later date..."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/preface.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/preface.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/preface.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,23 +1,24 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2009.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-21 17:17+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: preface.xml:29
 #, no-c-format
 msgid "Preface"
 msgstr "前書き"
 
 #. Tag: para
-#: preface.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "Working with object-oriented software and a relational database can be "
@@ -27,29 +28,28 @@
 "representation from an object model to a relational data model with a SQL-"
 "based schema."
 msgstr ""
-"今日の企業環境において、オブジェクト指向ソフトウェアとリレーショナルデータ"
-"ベースに関わる作業は 煩雑で膨大な時間を必要とします。 HibernateはJava環境のオ"
-"ブジェクト/リレーショナルマッピングツールです。 オブジェクト/リレーショナル"
-"マッピング(ORM)とは、 オブジェクトモデルからSQLベーススキーマのリレーショナ"
-"ルデータモデルへと、 データ表現をマッピングする(対応付ける)技術のことです。"
+"オブジェクト指向のソフトウェアやリレーショナルデータベースの使用は、 今日のエ"
+"ンタープライズ環境では非常に繁雑で時間のかかる作業となります。 Hibernate は "
+"Java 環境用のオブジェクト/リレーショナルマッピングツールです。 オブジェクト/"
+"リレーショナルマッピング (ORM) とはデータ表現をオブジェクトモデルから SQL "
+"ベースのスキーマによるリレーショナルデータモデルにマッピングする技術のことを"
+"指します。 "
 
 #. Tag: para
-#: preface.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate not only takes care of the mapping from Java classes to database "
 "tables (and from Java data types to SQL data types), but also provides data "
 "query and retrieval facilities. It can also significantly reduce development "
 "time otherwise spent with manual data handling in SQL and JDBC."
 msgstr ""
-"HibernateはJavaクラスからデータベーステーブルへ(そしてJavaデータ型からSQL"
-"データ型へ) のマッピングを処理するだけではなく、データのクエリと復元の仕組み"
-"も提供します。 このおかげでSQLとJDBCを使った手作業でのデータ処理に費やされて"
-"いた開発時間を大幅に削減できます。"
+"Hibernate は Java クラスからデータベーステーブルへのマッピング(及び Java デー"
+"タタイプから SQL データタイプへのマッピング)を行うだけでなくデータのクエリや"
+"検索機能も提供するため、 SQL や JDBC での手作業によるデータ処理を除き開発に要"
+"する時間を大幅に削減することが可能になります。"
 
 #. Tag: para
-#: preface.xml:46
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's goal is to relieve the developer from 95 percent of common data "
 "persistence related programming tasks. Hibernate may not be the best "
@@ -60,49 +60,47 @@
 "specific SQL code and will help with the common task of result set "
 "translation from a tabular representation to a graph of objects."
 msgstr ""
-"Hibernateの最終目標は、データの永続化に関わる一般的なプログラミング作業の95%"
-"から開発者を解放することです。 Hibernateはビジネスロジックの実装にストアドプ"
-"ロシージャを使う データ中心アプリケーションに対してのベストソリューションであ"
-"るに留まりません。 オブジェクト指向ドメインモデルとJavaベースの中間層でのビジ"
-"ネスロジックに対して最も役に立ちます。 しかしHibernateはベンダ固有のSQLコード"
-"を削減またはカプセル化したり、 表形式からオブジェクトのグラフへとリザルトセッ"
-"トを変換するなどの、 一般的なタスクにも役立つでしょう。"
+"Hibernate の目標は、 開発者にとってのプログラミングにおける一般的なデータ永続"
+"性の作業の 95 % を軽減することです。 Hibernate データベース内でビジネスロジッ"
+"クを実現するストアドプロシージャのみを使用するデータ処理中心のアプリケーショ"
+"ンに対しては最適ではないかもしれませんが、 Java ベースの中間層でのビジネスロ"
+"ジック及びオブジェクト指向のドメインモデルを使用する場合に最も役に立ちます。 "
+"Hibernate は開発者がベンダー固有の SQL コードの除去あるいはカプセル化を行う際"
+"に便利なため、 表形式の表現からオブジェクトのグラフへの結果セットの変換に関す"
+"る一般的な作業に役立ちます。"
 
 #. Tag: para
-#: preface.xml:56
 #, no-c-format
 msgid ""
 "If you are new to Hibernate and Object/Relational Mapping or even Java, "
 "please follow these steps:"
 msgstr ""
-"Hibernateやオブジェクト/リレーショナルマッピング、 さらにはJavaが初めての方"
-"は、以下のステップに従ってください:"
+"Hibernate 及びオブジェクト/リレーショナルマッピング、 あるいは Java が不慣れ"
+"な方は、 次の手順を行ってください。"
 
 #. Tag: para
-#: preface.xml:63
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"Read <xref linkend=\"tutorial\"/> for a tutorial with step-by-step "
+"Read <xref linkend=\"tutorial\" /> for a tutorial with step-by-step "
 "instructions. The source code for the tutorial is included in the "
 "distribution in the <literal>doc/reference/tutorial/</literal> directory."
 msgstr ""
-"<xref linkend=\"tutorial\"/> を読んでください。 段階的に解説していきます。 "
-"チュートリアルのソースコードはディストリビューションの <literal>doc/"
-"reference/tutorial</literal> ディレクトリに含まれています。"
+"ステップバイステップの解説が行われているチュートリアルとして <xref linkend="
+"\"tutorial\"/> をお読みください。 チュートリアルのソースコードはそのディスト"
+"リビューションの <literal>doc/reference/tutorial/</literal> ディレクトリ配下"
+"にあります。"
 
 #. Tag: para
-#: preface.xml:71
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"Read <xref linkend=\"architecture\"/> to understand the environments where "
+"Read <xref linkend=\"architecture\" /> to understand the environments where "
 "Hibernate can be used."
 msgstr ""
-"<xref linkend=\"architecture\"/> を読んで、Hibernateが利用可能な環境を理解し"
-"てください。"
+"Hibernate が使用できる環境について理解するため、 <xref linkend=\"architecture"
+"\"/> をお読みください。"
 
 #. Tag: para
-#: preface.xml:77
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "View the <literal>eg/</literal> directory in the Hibernate distribution. It "
 "contains a simple standalone application. Copy your JDBC driver to the "
@@ -111,62 +109,57 @@
 "command prompt in the distribution directory, type <literal>ant eg</literal> "
 "(using Ant), or under Windows, type <literal>build eg</literal>."
 msgstr ""
-"Hibernateディストリビューションの <literal>eg/</literal> ディレクトリを見てく"
-"ださい。 簡単なスタンドアローンのアプリケーションがあります。 JDBCドライバを "
-"<literal>lib/</literal> ディレクトリにコピーして、 自分のデータベースに合う正"
-"しい値を指定するように <literal>etc/hibernate.properties</literal> を編集して"
-"ください。 ディストリビューションディレクトリから、コマンドプロンプトで "
-"<literal>ant eg</literal> とタイプしてください(Antを使います)。 またWindows"
-"環境では <literal>build eg</literal> とタイプしてください。"
+"Hibernate ディストリビューション内の <literal>eg/</literal> ディレクトリ内を"
+"見てください。 シンプルなスタンドアローンのアプリケーションが含まれていま"
+"す。 ご使用の JDBC ドライバを <literal>lib/</literal> ディレクトリにコピーし"
+"てから使用するデータベースに対して正しい値を指定するよう <literal>etc/"
+"hibernate.properties</literal> を編集します。 ディストリビューションディレク"
+"トリ内のコマンドプロンプトから、 <literal>ant eg</literal> (Ant を使用)と入力"
+"するか、 Windows 環境の場合は <literal>build eg</literal> と入力します。"
 
 #. Tag: para
-#: preface.xml:88
 #, fuzzy, no-c-format
 msgid ""
 "Use this reference documentation as your primary source of information. "
 "Consider reading <biblioref linkend=\"biblio-JPwH\"></biblioref> if you need "
 "more help with application design, or if you prefer a step-by-step tutorial. "
-"Also visit <ulink url=\"http://caveatemptor.hibernate.org\"></ulink> and "
-"download the example application from <biblioref linkend=\"biblio-JPwH\"></"
-"biblioref>."
+"Also visit <ulink url=\"http://caveatemptor.hibernate.org\" /> and download "
+"the example application from <biblioref linkend=\"biblio-JPwH\"></biblioref>."
 msgstr ""
-"このリファレンスドキュメントを第一の情報源として利用してください。 アプリケー"
-"ション設計についてのさらなる情報や段階的なチュートリアルを探しているなら、 "
-"<emphasis>Java Persistence with Hibernate</emphasis>(http://www.manning.com/"
-"bauer2) をおすすめします。 またhttp://caveatemptor.hibernate.orgから Java "
-"Persistence with Hibernateの例題のアプリケーションをダウンロードできます。"
+"おもな情報源として本リファレンスドキュメントをご利用ください。 アプリケーショ"
+"ンのデザインに関する詳細、 ステップバイステップによる解説が必要な場合は、 "
+"<emphasis>Hibernate in Action</emphasis> (http://www.manning.com/bauer) をお"
+"読みになってもいいでしょう。 また、 http://caveatemptor.hibernate.org から "
+"Hibernate in Action のサンプルアプリケーションをダウンロードすることもできま"
+"す。"
 
 #. Tag: para
-#: preface.xml:98
 #, no-c-format
 msgid "FAQs are answered on the Hibernate website."
-msgstr "FAQはHibernateウェブサイトにあります。"
+msgstr "よくある質問とその答え (FAQ) は Hibernate ウェブサイトでご覧ください。"
 
 #. Tag: para
-#: preface.xml:103
 #, fuzzy, no-c-format
 msgid ""
 "Links to third party demos, examples, and tutorials are maintained on the "
 "Hibernate website."
 msgstr ""
-"サードパーティのデモ、例、チュートリアルはHibernateウェブサイトにリンクがあり"
-"ます。"
+"サードパーティのデモ、 サンプル、 チュートリアルなどは Hibernate のウェブサイ"
+"ト上にリンクされています。"
 
 #. Tag: para
-#: preface.xml:109
 #, no-c-format
 msgid ""
 "The Community Area on the Hibernate website is a good resource for design "
 "patterns and various integration solutions (Tomcat, JBoss AS, Struts, EJB, "
 "etc.)."
 msgstr ""
-"Hibernateウェブサイトのコミュニティエリアは、デザインパターンやさまざまな統合"
-"ソリューション (Tomcat, JBoss AS, Struts, EJB, 等)についてのよい情報源で"
-"す。"
+"Hibernate ウェブサイト上の Community Area はデザインのパターンやさまざまな統"
+"合ソリューション (Tomcat、 JBoss AS、 Struts、 EJB など)を検索する上で興味深"
+"いリソースになります。"
 
 #. Tag: para
-#: preface.xml:117
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you have questions, use the user forum linked on the Hibernate website. "
 "We also provide a JIRA issue tracking system for bug reports and feature "
@@ -174,14 +167,13 @@
 "developer mailing list. If you are interested in translating this "
 "documentation into your language, contact us on the developer mailing list."
 msgstr ""
-"質問があればHibernateウェブサイトのユーザフォーラムを活用してください。 また"
-"バグレポートとフィーチャリクエストのためJIRA課題追跡システムを用意していま"
-"す。 Hibernateの開発に興味があれば、開発者メーリングリストに参加してくださ"
-"い。 このドキュメントをあなたの国の言葉に翻訳したい場合は、 開発者メーリング"
-"リストで私たちにコンタクトを取ってください。"
+"質問がある場合は、 Hibernate ウェブサイト上にリンクされたユーザーフォーラムを"
+"ご利用ください。 また、 バグ報告及び今後のリクエストに関しては JIRA (問題追跡"
+"システム) を提供しています。 Hibernate, の開発に興味がある方は、 開発者用メー"
+"リングリストにご参加ください。 本ドキュメントの翻訳に興味がある方は、 開発者"
+"用メーリングリストよりご連絡ください。"
 
 #. Tag: para
-#: preface.xml:125
 #, no-c-format
 msgid ""
 "Commercial development support, production support, and training for "
@@ -190,7 +182,8 @@
 "critical component of the JBoss Enterprise Middleware System (JEMS) suite of "
 "products."
 msgstr ""
-"商用開発のサポート、製品のサポート、HibernateのトレーニングはJBoss Inc.が提供"
-"しています (http://www.hibernate.org/SupportTraining/を見てください)。 "
-"HibernateはProfessional Open Sourceプロジェクト、 そしてJBoss Enterprise "
-"Middleware System(JEMS)プロダクトスイートのクリティカルコンポーネントです。"
+"Hibernate に関する商業用開発サポート、 実稼働サポート、 トレーニングについて"
+"は JBoss Inc よりご利用頂けます (http://www.hibernate.org/SupportTraining/ を"
+"参照)。 Hibernate はプロフェッショナルなオープンソースプロジェクトであり、 "
+"JBoss Enterprise Middleware System (JEMS) スィート製品の重要なコンポーネント"
+"になります。"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/query_criteria.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/query_criteria.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/query_criteria.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,62 +1,51 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-18 13:38+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: query_criteria.xml:29
 #, no-c-format
 msgid "Criteria Queries"
-msgstr "Criteriaクエリ"
+msgstr "Criteria クエリ"
 
 #. Tag: para
-#: query_criteria.xml:31
 #, no-c-format
 msgid "Hibernate features an intuitive, extensible criteria query API."
-msgstr "Hibernateには、直感的で拡張可能なcriteriaクエリAPIが用意されています。"
+msgstr ""
+"Hibernate には、直感的で拡張可能な criteria クエリ API が用意されています。"
 
 #. Tag: title
-#: query_criteria.xml:36
 #, no-c-format
 msgid "Creating a <literal>Criteria</literal> instance"
 msgstr "<literal>Criteria</literal> インスタンスの作成"
 
 #. Tag: para
-#: query_criteria.xml:38
 #, no-c-format
 msgid ""
 "The interface <literal>org.hibernate.Criteria</literal> represents a query "
 "against a particular persistent class. The <literal>Session</literal> is a "
 "factory for <literal>Criteria</literal> instances."
 msgstr ""
-"<literal>org.hibernate.Criteria</literal> インターフェイスは特定の永続性クラ"
+"<literal>org.hibernate.Criteria</literal> インターフェースは特定の永続性クラ"
 "スに対するクエリを表現します。 <literal>Session</literal> は "
 "<literal>Criteria</literal> インスタンスのファクトリです。"
 
-#. Tag: programlisting
-#: query_criteria.xml:44
-#, no-c-format
-msgid ""
-"<![CDATA[Criteria crit = sess.createCriteria(Cat.class);\n"
-"crit.setMaxResults(50);\n"
-"List cats = crit.list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:49
 #, no-c-format
 msgid "Narrowing the result set"
 msgstr "リザルトセットの絞込み"
 
 #. Tag: para
-#: query_criteria.xml:51
 #, no-c-format
 msgid ""
 "An individual query criterion is an instance of the interface <literal>org."
@@ -64,127 +53,54 @@
 "criterion.Restrictions</literal> defines factory methods for obtaining "
 "certain built-in <literal>Criterion</literal> types."
 msgstr ""
-"<literal>org.hibernate.criterion.Criterion</literal> インターフェイスのインス"
-"タンスは、 個別のクエリクライテリオン(問い合わせの判定基準)を表します。 "
+"<literal>org.hibernate.criterion.Criterion</literal> インターフェースのインス"
+"タンスは、個別のクエリクライテリオン(問い合わせの判定基準)を表します。 "
 "<literal>org.hibernate.criterion.Restrictions</literal> クラスは、ある組み込"
 "みの <literal>Criterion</literal> 型を取得するためのファクトリメソッドを持っ"
 "ています。"
 
-#. Tag: programlisting
-#: query_criteria.xml:59
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .add( Restrictions.between(\"weight\", minWeight, maxWeight) )\n"
-"    .list();]]>"
-msgstr ""
+msgid "Restrictions can be grouped logically."
+msgstr "Restriction (限定)は、論理的にグループ化できます。"
 
 #. Tag: para
-#: query_criteria.xml:61
-#, fuzzy, no-c-format
-msgid "Restrictions can be grouped logically."
-msgstr "Restriction(限定)は、論理的にグループ化できます。"
-
-#. Tag: programlisting
-#: query_criteria.xml:65
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .add( Restrictions.or(\n"
-"        Restrictions.eq( \"age\", new Integer(0) ),\n"
-"        Restrictions.isNull(\"age\")\n"
-"    ) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:67
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.in( \"name\", new String[] { \"Fritz\", \"Izi\", \"Pk"
-"\" } ) )\n"
-"    .add( Restrictions.disjunction()\n"
-"        .add( Restrictions.isNull(\"age\") )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(0) ) )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(1) ) )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(2) ) )\n"
-"    ) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:69
-#, fuzzy, no-c-format
-msgid ""
 "There are a range of built-in criterion types (<literal>Restrictions</"
 "literal> subclasses). One of the most useful allows you to specify SQL "
 "directly."
 msgstr ""
-"元々あるCriterion型(<literal>Restrictions</literal> のサブクラス) はかなり"
-"の範囲に及びますが、特に有用なのはSQLを直接指定できるものです。"
+"元々ある Criterion 型(<literal>Restrictions</literal> のサブクラス) はかな"
+"りの範囲に及びますが、特に有用なのは SQL を直接指定できるものです。"
 
-#. Tag: programlisting
-#: query_criteria.xml:74
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.sqlRestriction(\"lower({alias}.name) like lower(?)\", "
-"\"Fritz%\", Hibernate.STRING) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:76
 #, no-c-format
 msgid ""
 "The <literal>{alias}</literal> placeholder with be replaced by the row alias "
 "of the queried entity."
 msgstr ""
-"<literal>{alias}</literal> というプレースホルダは、 問い合わせを受けたエン"
-"ティティの行の別名によって置き換えられます。"
+"<literal>{alias}</literal> というプレースホルダは、問い合わせを受けたエンティ"
+"ティの行の別名によって置き換えられます。"
 
 #. Tag: para
-#: query_criteria.xml:81
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also obtain a criterion from a <literal>Property</literal> instance. "
 "You can create a <literal>Property</literal> by calling <literal>Property."
 "forName()</literal>:"
 msgstr ""
-"criterionを得る別の手段は、 <literal>Property</literal> インスタンスから取得"
+"criterion を得る別の手段は、 <literal>Property</literal> インスタンスから取得"
 "することです。 <literal>Property.forName()</literal> を呼び出して、 "
 "<literal>Property</literal> インスタンスを作成できます。"
 
-#. Tag: programlisting
-#: query_criteria.xml:87
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"Property age = Property.forName(\"age\");\n"
-"List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.disjunction()\n"
-"        .add( age.isNull() )\n"
-"        .add( age.eq( new Integer(0) ) )\n"
-"        .add( age.eq( new Integer(1) ) )\n"
-"        .add( age.eq( new Integer(2) ) )\n"
-"    ) )\n"
-"    .add( Property.forName(\"name\").in( new String[] { \"Fritz\", \"Izi\", "
-"\"Pk\" } ) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:92
 #, no-c-format
 msgid "Ordering the results"
 msgstr "結果の整列"
 
 #. Tag: para
-#: query_criteria.xml:94
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can order the results using <literal>org.hibernate.criterion.Order</"
 "literal>."
@@ -192,87 +108,36 @@
 "<literal>org.hibernate.criterion.Order</literal> を使って結果を並び替えること"
 "ができます。"
 
-#. Tag: programlisting
-#: query_criteria.xml:98
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"F%\")\n"
-"    .addOrder( Order.asc(\"name\") )\n"
-"    .addOrder( Order.desc(\"age\") )\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:100
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Property.forName(\"name\").like(\"F%\") )\n"
-"    .addOrder( Property.forName(\"name\").asc() )\n"
-"    .addOrder( Property.forName(\"age\").desc() )\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:105
 #, no-c-format
 msgid "Associations"
 msgstr "関連"
 
 #. Tag: para
-#: query_criteria.xml:107
 #, no-c-format
 msgid ""
 "By navigating associations using <literal>createCriteria()</literal> you can "
 "specify constraints upon related entities:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:112
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"F%\") )\n"
-"    .createCriteria(\"kittens\")\n"
-"        .add( Restrictions.like(\"name\", \"F%\") )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:114
-#, fuzzy, no-c-format
-msgid ""
 "The second <literal>createCriteria()</literal> returns a new instance of "
 "<literal>Criteria</literal> that refers to the elements of the "
 "<literal>kittens</literal> collection."
 msgstr ""
-"2番目の <literal>createCriteria()</literal> は、<literal>kittens</literal> コ"
-"レクションの要素を参照する新しい <literal>Criteria</literal> インスタンスを返"
-"すことに注意してください。"
+"2番目の <literal>createCriteria()</literal> は、 <literal>kittens</literal> "
+"コレクションの要素を参照する新しい <literal>Criteria</literal> インスタンスを"
+"返すことに注意してください。"
 
 #. Tag: para
-#: query_criteria.xml:120
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is also an alternate form that is useful in certain circumstances:"
 msgstr "以下のような方法も、状況により有用です。"
 
-#. Tag: programlisting
-#: query_criteria.xml:124
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .createAlias(\"kittens\", \"kt\")\n"
-"    .createAlias(\"mate\", \"mt\")\n"
-"    .add( Restrictions.eqProperty(\"kt.name\", \"mt.name\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:126
 #, no-c-format
 msgid ""
 "(<literal>createAlias()</literal> does not create a new instance of "
@@ -282,8 +147,7 @@
 "スタンスを作成しません。)"
 
 #. Tag: para
-#: query_criteria.xml:131
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The kittens collections held by the <literal>Cat</literal> instances "
 "returned by the previous two queries are <emphasis>not</emphasis> pre-"
@@ -291,154 +155,113 @@
 "match the criteria, you must use a <literal>ResultTransformer</literal>."
 msgstr ""
 "前の2つのクエリによって返される <literal>Cat</literal> インスタンスによって保"
-"持されるkittensコレクションは、 criteriaによって事前にフィルタリング "
-"<emphasis>されない</emphasis> ことに注意してください。 もしcriteriaに適合する"
-"kittenを取得したいなら、 <literal>ResultTransformer</literal> を使わなければ"
-"なりません。"
+"持される kittens コレクションは、 criteria によって事前にフィルタリング "
+"<emphasis>されない</emphasis> ことに注意してください。もし criteria に適合す"
+"る kitten を取得したいなら、 <literal>ResultTransformer</literal> を使わなけ"
+"ればなりません。"
 
-#. Tag: programlisting
-#: query_criteria.xml:138
+#. Tag: para
 #, no-c-format
+msgid "Additionally you may manipulate the result set using a left outer join:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .createCriteria(\"kittens\", \"kt\")\n"
-"        .add( Restrictions.eq(\"name\", \"F%\") )\n"
-"    .setResultTransformer(Criteria.ALIAS_TO_ENTITY_MAP)\n"
-"    .list();\n"
-"Iterator iter = cats.iterator();\n"
-"while ( iter.hasNext() ) {\n"
-"    Map map = (Map) iter.next();\n"
-"    Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);\n"
-"    Cat kitten = (Cat) map.get(\"kt\");\n"
-"}]]>"
+"This will return all of the <literal>Cat</literal>s with a mate whose name "
+"starts with \"good\" ordered by their mate's age, and all cats who do not "
+"have a mate. This is useful when there is a need to order or limit in the "
+"database prior to returning complex/large result sets, and removes many "
+"instances where multiple queries would have to be performed and the results "
+"unioned by java in memory."
 msgstr ""
 
+#. Tag: para
+#, no-c-format
+msgid ""
+"Without this feature, first all of the cats without a mate would need to be "
+"loaded in one query."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"A second query would need to retreive the cats with mates who's name started "
+"with \"good\" sorted by the mates age."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "Thirdly, in memory; the lists would need to be joined manually."
+msgstr ""
+
 #. Tag: title
-#: query_criteria.xml:143
 #, no-c-format
 msgid "Dynamic association fetching"
 msgstr "関連の動的フェッチ"
 
 #. Tag: para
-#: query_criteria.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can specify association fetching semantics at runtime using "
 "<literal>setFetchMode()</literal>."
 msgstr ""
-"<literal>setFetchMode()</literal> を使い、 実行時に関連の復元方法を指定しても"
+"<literal>setFetchMode()</literal> を使い、実行時に関連の復元方法を指定しても"
 "よいです。"
 
-#. Tag: programlisting
-#: query_criteria.xml:150
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .setFetchMode(\"mate\", FetchMode.EAGER)\n"
-"    .setFetchMode(\"kittens\", FetchMode.EAGER)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:152
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "This query will fetch both <literal>mate</literal> and <literal>kittens</"
-"literal> by outer join. See <xref linkend=\"performance-fetching\"/> for "
+"literal> by outer join. See <xref linkend=\"performance-fetching\" /> for "
 "more information."
 msgstr ""
 "このクエリは外部結合により <literal>mate</literal> と <literal>kittens</"
-"literal> の両方をフェッチします。 より多くの情報は <xref linkend="
-"\"performance-fetching\"/> を参照してください。"
+"literal> の両方をフェッチします。詳細については <xref linkend=\"performance-"
+"fetching\"/> を参照してください。"
 
 #. Tag: title
-#: query_criteria.xml:160
 #, no-c-format
 msgid "Example queries"
 msgstr "クエリの例"
 
 #. Tag: para
-#: query_criteria.xml:162
 #, no-c-format
 msgid ""
 "The class <literal>org.hibernate.criterion.Example</literal> allows you to "
 "construct a query criterion from a given instance."
 msgstr ""
-"<literal>org.hibernate.criterion.Example</literal> クラスは、 与えられたイン"
-"スタンスからクエリクライテリオンを構築できます。"
+"<literal>org.hibernate.criterion.Example</literal> クラスは、与えられたインス"
+"タンスからクエリクライテリオンを構築できます。"
 
-#. Tag: programlisting
-#: query_criteria.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = new Cat();\n"
-"cat.setSex('F');\n"
-"cat.setColor(Color.BLACK);\n"
-"List results = session.createCriteria(Cat.class)\n"
-"    .add( Example.create(cat) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:169
 #, no-c-format
 msgid ""
 "Version properties, identifiers and associations are ignored. By default, "
 "null valued properties are excluded."
 msgstr ""
-"バージョンプロパティ、識別子、関連は無視されます。 デフォルトではnull値のプロ"
-"パティは除外されます。"
+"バージョンプロパティ、識別子、関連は無視されます。デフォルトでは null 値のプ"
+"ロパティは除外されます。"
 
 #. Tag: para
-#: query_criteria.xml:174
 #, no-c-format
 msgid "You can adjust how the <literal>Example</literal> is applied."
 msgstr ""
-"どのように <literal>Example</literal> を適用するか 調整することができます。"
+"どのように <literal>Example</literal> を適用するか調整することができます。"
 
-#. Tag: programlisting
-#: query_criteria.xml:178
-#, no-c-format
-msgid ""
-"<![CDATA[Example example = Example.create(cat)\n"
-"    .excludeZeroes()           //exclude zero valued properties\n"
-"    .excludeProperty(\"color\")  //exclude the property named \"color\"\n"
-"    .ignoreCase()              //perform case insensitive string "
-"comparisons\n"
-"    .enableLike();             //use like for string comparisons\n"
-"List results = session.createCriteria(Cat.class)\n"
-"    .add(example)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:180
 #, no-c-format
 msgid "You can even use examples to place criteria upon associated objects."
 msgstr ""
-"関連オブジェクトにcriteriaを指定するために、Exampleを使うことも可能です。"
+"関連オブジェクトに criteria を指定するために、 example を使うことも可能です。"
 
-#. Tag: programlisting
-#: query_criteria.xml:184
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .add( Example.create(cat) )\n"
-"    .createCriteria(\"mate\")\n"
-"        .add( Example.create( cat.getMate() ) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:189
 #, no-c-format
 msgid "Projections, aggregation and grouping"
 msgstr "射影、集約、グループ化"
 
 #. Tag: para
-#: query_criteria.xml:190
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The class <literal>org.hibernate.criterion.Projections</literal> is a "
 "factory for <literal>Projection</literal> instances. You can apply a "
@@ -446,79 +269,31 @@
 msgstr ""
 "<literal>org.hibernate.criterion.Projections</literal> クラスは "
 "<literal>Projection</literal> インスタンスのファクトリです。 "
-"<literal>setProjection()</literal> を呼び出すことで、 クエリに射影を適用しま"
+"<literal>setProjection()</literal> を呼び出すことで、クエリに射影を適用しま"
 "す。"
 
-#. Tag: programlisting
-#: query_criteria.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.rowCount() )\n"
-"    .add( Restrictions.eq(\"color\", Color.BLACK) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:198
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount() )\n"
-"        .add( Projections.avg(\"weight\") )\n"
-"        .add( Projections.max(\"weight\") )\n"
-"        .add( Projections.groupProperty(\"color\") )\n"
-"    )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:200
 #, no-c-format
 msgid ""
 "There is no explicit \"group by\" necessary in a criteria query. Certain "
 "projection types are defined to be <emphasis>grouping projections</"
 "emphasis>, which also appear in the SQL <literal>group by</literal> clause."
 msgstr ""
-"必要であっても、criteriaクエリに「group by」を明示する必要はありません。 ある"
-"種のProjection型は <emphasis>グループ化射影</emphasis> として定義され、 SQL"
-"の <literal>group by</literal> 節にも現れます。"
+"必要であっても、 criteria クエリに「group by」を明示する必要はありません。あ"
+"る種の Projection 型は <emphasis>グループ化射影</emphasis> として定義され、 "
+"SQL の <literal>group by</literal> 節にも現れます。"
 
 #. Tag: para
-#: query_criteria.xml:206
 #, fuzzy, no-c-format
 msgid ""
 "An alias can be assigned to a projection so that the projected value can be "
 "referred to in restrictions or orderings. Here are two different ways to do "
 "this:"
 msgstr ""
-"任意で射影に別名を付けられるため、射影される値はrestrictionやordering内から参"
-"照できます。 別名をつける2つの異なる方法を示します。"
+"任意で射影に別名を付けられるため、射影される値は restriction や ordering 内か"
+"ら参照できます。別名をつける2つの異なる方法を示します:"
 
-#. Tag: programlisting
-#: query_criteria.xml:212
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.alias( Projections.groupProperty(\"color\"), "
-"\"colr\" ) )\n"
-"    .addOrder( Order.asc(\"colr\") )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:214
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.groupProperty(\"color\").as(\"colr\") )\n"
-"    .addOrder( Order.asc(\"colr\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:216
 #, no-c-format
 msgid ""
 "The <literal>alias()</literal> and <literal>as()</literal> methods simply "
@@ -526,171 +301,57 @@
 "<literal>Projection</literal>. As a shortcut, you can assign an alias when "
 "you add the projection to a projection list:"
 msgstr ""
-"<literal>alias()</literal> と <literal>as()</literal> メソッドは、 Projection"
-"インスタンスを別の名前の <literal>Projection</literal> インスタンスで ラップ"
-"するだけです。 ショートカットとして、射影を射影リストに追加する際に、別名をつ"
-"けられます。"
+"<literal>alias()</literal> と <literal>as()</literal> メソッドは、 "
+"Projection インスタンスを別の名前の <literal>Projection</literal> インスタン"
+"スでラップするだけです。ショートカットとして、射影を射影リストに追加する際"
+"に、別名をつけられます:"
 
-#. Tag: programlisting
-#: query_criteria.xml:223
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount(), \"catCountByColor\" )\n"
-"        .add( Projections.avg(\"weight\"), \"avgWeight\" )\n"
-"        .add( Projections.max(\"weight\"), \"maxWeight\" )\n"
-"        .add( Projections.groupProperty(\"color\"), \"color\" )\n"
-"    )\n"
-"    .addOrder( Order.desc(\"catCountByColor\") )\n"
-"    .addOrder( Order.desc(\"avgWeight\") )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:225
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Domestic.class, \"cat\")\n"
-"    .createAlias(\"kittens\", \"kit\")\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.property(\"cat.name\"), \"catName\" )\n"
-"        .add( Projections.property(\"kit.name\"), \"kitName\" )\n"
-"    )\n"
-"    .addOrder( Order.asc(\"catName\") )\n"
-"    .addOrder( Order.asc(\"kitName\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:227
 #, no-c-format
 msgid ""
 "You can also use <literal>Property.forName()</literal> to express "
 "projections:"
-msgstr "射影の式に <literal>Property.forName()</literal> も使用できます。"
+msgstr "射影の式に <literal>Property.forName()</literal> も使用できます:"
 
-#. Tag: programlisting
-#: query_criteria.xml:231
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Property.forName(\"name\") )\n"
-"    .add( Property.forName(\"color\").eq(Color.BLACK) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:233
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount().as(\"catCountByColor\") )\n"
-"        .add( Property.forName(\"weight\").avg().as(\"avgWeight\") )\n"
-"        .add( Property.forName(\"weight\").max().as(\"maxWeight\") )\n"
-"        .add( Property.forName(\"color\").group().as(\"color\" )\n"
-"    )\n"
-"    .addOrder( Order.desc(\"catCountByColor\") )\n"
-"    .addOrder( Order.desc(\"avgWeight\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:238
 #, no-c-format
 msgid "Detached queries and subqueries"
 msgstr "クエリおよびサブクエリの分離"
 
 #. Tag: para
-#: query_criteria.xml:239
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>DetachedCriteria</literal> class allows you to create a query "
 "outside the scope of a session and then execute it using an arbitrary "
 "<literal>Session</literal>."
 msgstr ""
-"<literal>DetachedCriteria</literal> クラスにより、 セッションスコープ外にクエ"
-"リを作成できます。 後で、任意の <literal>Session</literal> を使って、実行でき"
+"<literal>DetachedCriteria</literal> クラスにより、セッションスコープ外にクエ"
+"リを作成できます。後で、任意の <literal>Session</literal> を使って、実行でき"
 "ます。"
 
-#. Tag: programlisting
-#: query_criteria.xml:244
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DetachedCriteria query = DetachedCriteria.forClass(Cat.class)\n"
-"    .add( Property.forName(\"sex\").eq('F') );\n"
-"    \n"
-"Session session = ....;\n"
-"Transaction txn = session.beginTransaction();\n"
-"List results = query.getExecutableCriteria(session).setMaxResults(100).list"
-"();\n"
-"txn.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:246
-#, fuzzy, no-c-format
-msgid ""
 "A <literal>DetachedCriteria</literal> can also be used to express a "
 "subquery. Criterion instances involving subqueries can be obtained via "
 "<literal>Subqueries</literal> or <literal>Property</literal>."
 msgstr ""
 "<literal>DetachedCriteria</literal> は、サブクエリを表現するためにも使えま"
-"す。 サブクエリを伴うCriterionインスタンスは、 <literal>Subqueries</literal> "
-"もしくは <literal>Property</literal> から得られます。"
+"す。サブクエリを伴う Criterion インスタンスは、 <literal>Subqueries</"
+"literal> もしくは <literal>Property</literal> から得られます。"
 
-#. Tag: programlisting
-#: query_criteria.xml:252
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria avgWeight = DetachedCriteria.forClass(Cat.class)\n"
-"    .setProjection( Property.forName(\"weight\").avg() );\n"
-"session.createCriteria(Cat.class)\n"
-"    .add( Property.forName(\"weight\").gt(avgWeight) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:254
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria weights = DetachedCriteria.forClass(Cat.class)\n"
-"    .setProjection( Property.forName(\"weight\") );\n"
-"session.createCriteria(Cat.class)\n"
-"    .add( Subqueries.geAll(\"weight\", weights) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:256
-#, fuzzy, no-c-format
 msgid "Correlated subqueries are also possible:"
-msgstr "相互関係があるサブクエリでさえも可能です。"
+msgstr "相互関係があるサブクエリでさえも可能です:"
 
-#. Tag: programlisting
-#: query_criteria.xml:260
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria avgWeightForSex = DetachedCriteria.forClass(Cat."
-"class, \"cat2\")\n"
-"    .setProjection( Property.forName(\"weight\").avg() )\n"
-"    .add( Property.forName(\"cat2.sex\").eqProperty(\"cat.sex\") );\n"
-"session.createCriteria(Cat.class, \"cat\")\n"
-"    .add( Property.forName(\"weight\").gt(avgWeightForSex) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:269
 #, no-c-format
 msgid "Queries by natural identifier"
 msgstr "自然識別子によるクエリ"
 
 #. Tag: para
-#: query_criteria.xml:271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For most queries, including criteria queries, the query cache is not "
 "efficient because query cache invalidation occurs too frequently. However, "
@@ -699,79 +360,544 @@
 "applications, this kind of query occurs frequently. The criteria API "
 "provides special provision for this use case."
 msgstr ""
-"criteriaクエリを含むたいていのクエリにとって、 クエリキャッシュはあまり効率が"
-"よくないです。 なぜなら、クエリキャッシュが頻繁に無効になるためです。 しかし"
-"ながら、キャッシュを無効にするアルゴリズムを最適化できる 特別なクエリの種類が"
-"1つあります。 更新されない自然キーによる検索です。 いくつかのアプリケーショ"
-"ンでは、この種類のクエリが頻繁に現れます。 このような使われ方のために、"
-"criteria APIは特別な対策を提供します。"
+"criteria クエリを含むたいていのクエリにとって、クエリキャッシュはあまり効率が"
+"よくないです。なぜなら、クエリキャッシュが頻繁に無効になるためです。しかしな"
+"がら、キャッシュを無効にするアルゴリズムを最適化できる特別なクエリの種類が1"
+"つあります。更新されない自然キーによる検索です。いくつかのアプリケーションで"
+"は、この種類のクエリが頻繁に現れます。このような使われ方のために、 criteria "
+"API は特別な対策を提供します。"
 
 #. Tag: para
-#: query_criteria.xml:279
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, map the natural key of your entity using <literal>&lt;natural-id&gt;</"
 "literal> and enable use of the second-level cache."
 msgstr ""
-"最初に、<literal>&lt;natural-id&gt;</literal> を使って、 エンティティの自然"
-"キーをマップしてください。 そして、二次キャッシュを有効にします。"
+"最初に、 <literal>&lt;natural-id&gt;</literal> を使って、エンティティの自然"
+"キーをマップしてください。そして、二次キャッシュを有効にします。"
 
-#. Tag: programlisting
-#: query_criteria.xml:284
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"User\">\n"
-"    <cache usage=\"read-write\"/>\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <natural-id>\n"
-"        <property name=\"name\"/>\n"
-"        <property name=\"org\"/>\n"
-"    </natural-id>\n"
-"    <property name=\"password\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:286
-#, fuzzy, no-c-format
-msgid ""
 "This functionality is not intended for use with entities with "
 "<emphasis>mutable</emphasis> natural keys."
 msgstr ""
-"注意: <emphasis>変更される</emphasis> 自然キーを持つエンティティに この機能"
-"を使うのは、意図されていない使い方です。"
+"注記: <emphasis>変更される</emphasis> 自然キーを持つエンティティにこの機能を"
+"使うのは、意図されていない使い方です。"
 
 #. Tag: para
-#: query_criteria.xml:291
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Once you have enabled the Hibernate query cache, the <literal>Restrictions."
 "naturalId()</literal> allows you to make use of the more efficient cache "
 "algorithm."
 msgstr ""
-"これで、<literal>Restrictions.naturalId()</literal> により、 より効率的な"
+"これで、 <literal>Restrictions.naturalId()</literal> により、より効率的な"
 "キャッシュアルゴリズムを使用できます。"
 
-#. Tag: programlisting
-#: query_criteria.xml:297
-#, no-c-format
-msgid ""
-"<![CDATA[session.createCriteria(User.class)\n"
-"    .add( Restrictions.naturalId()\n"
-"        .set(\"name\", \"gavin\")\n"
-"        .set(\"org\", \"hb\") \n"
-"    ).setCacheable(true)\n"
-"    .uniqueResult();]]>"
-msgstr ""
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Criteria crit = sess.createCriteria(Cat.class);\n"
+#~ "crit.setMaxResults(50);\n"
+#~ "List cats = crit.list();]]>"
+#~ msgstr ""
+#~ "Criteria crit = sess.createCriteria(Cat.class);\n"
+#~ "crit.setMaxResults(50);\n"
+#~ "List cats = crit.list();"
 
+#, fuzzy
 #~ msgid ""
-#~ "You may easily specify constraints upon related entities by navigating "
-#~ "associations using <literal>createCriteria()</literal>."
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
+#~ "    .add( Restrictions.between(\"weight\", minWeight, maxWeight) )\n"
+#~ "    .list();]]>"
 #~ msgstr ""
-#~ "<literal>createCriteria()</literal> を使い、関連をナビゲートすることで、 "
-#~ "容易に関係するエンティティに制約を指定できます。"
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"Fritz&#37;\") )\n"
+#~ "    .add( Restrictions.between(\"weight\", minWeight, maxWeight) )\n"
+#~ "    .list();"
 
-#~ msgid "Next, enable the Hibernate query cache."
-#~ msgstr "次に、Hibernateクエリキャッシュを有効にします。"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
+#~ "    .add( Restrictions.or(\n"
+#~ "        Restrictions.eq( \"age\", new Integer(0) ),\n"
+#~ "        Restrictions.isNull(\"age\")\n"
+#~ "    ) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"Fritz&#37;\") )\n"
+#~ "    .add( Restrictions.or(\n"
+#~ "        Restrictions.eq( \"age\", new Integer(0) ),\n"
+#~ "        Restrictions.isNull(\"age\")\n"
+#~ "    ) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.in( \"name\", new String[] { \"Fritz\", \"Izi\", "
+#~ "\"Pk\" } ) )\n"
+#~ "    .add( Restrictions.disjunction()\n"
+#~ "        .add( Restrictions.isNull(\"age\") )\n"
+#~ "        .add( Restrictions.eq(\"age\", new Integer(0) ) )\n"
+#~ "        .add( Restrictions.eq(\"age\", new Integer(1) ) )\n"
+#~ "        .add( Restrictions.eq(\"age\", new Integer(2) ) )\n"
+#~ "    ) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.in( \"name\", new String[] { \"Fritz\", \"Izi\", "
+#~ "\"Pk\" } ) )\n"
+#~ "    .add( Restrictions.disjunction()\n"
+#~ "        .add( Restrictions.isNull(\"age\") )\n"
+#~ "        .add( Restrictions.eq(\"age\", new Integer(0) ) )\n"
+#~ "        .add( Restrictions.eq(\"age\", new Integer(1) ) )\n"
+#~ "        .add( Restrictions.eq(\"age\", new Integer(2) ) )\n"
+#~ "    ) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.sqlRestriction(\"lower({alias}.name) like lower(?)"
+#~ "\", \"Fritz%\", Hibernate.STRING) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.sqlRestriction(\"lower({alias}.name) like lower(?)"
+#~ "\", \"Fritz&#37;\", \n"
+#~ "        Hibernate.STRING) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[\n"
+#~ "Property age = Property.forName(\"age\");\n"
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.disjunction()\n"
+#~ "        .add( age.isNull() )\n"
+#~ "        .add( age.eq( new Integer(0) ) )\n"
+#~ "        .add( age.eq( new Integer(1) ) )\n"
+#~ "        .add( age.eq( new Integer(2) ) )\n"
+#~ "    ) )\n"
+#~ "    .add( Property.forName(\"name\").in( new String[] { \"Fritz\", \"Izi"
+#~ "\", \"Pk\" } ) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "Property age = Property.forName(\"age\");\n"
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.disjunction()\n"
+#~ "        .add( age.isNull() )\n"
+#~ "        .add( age.eq( new Integer(0) ) )\n"
+#~ "        .add( age.eq( new Integer(1) ) )\n"
+#~ "        .add( age.eq( new Integer(2) ) )\n"
+#~ "    ) )\n"
+#~ "    .add( Property.forName(\"name\").in( new String[] { \"Fritz\", \"Izi"
+#~ "\", \"Pk\" } ) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"F%\")\n"
+#~ "    .addOrder( Order.asc(\"name\") )\n"
+#~ "    .addOrder( Order.desc(\"age\") )\n"
+#~ "    .setMaxResults(50)\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"F&#37;\")\n"
+#~ "    .addOrder( Order.asc(\"name\") )\n"
+#~ "    .addOrder( Order.desc(\"age\") )\n"
+#~ "    .setMaxResults(50)\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Property.forName(\"name\").like(\"F%\") )\n"
+#~ "    .addOrder( Property.forName(\"name\").asc() )\n"
+#~ "    .addOrder( Property.forName(\"age\").desc() )\n"
+#~ "    .setMaxResults(50)\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Property.forName(\"name\").like(\"F&#37;\") )\n"
+#~ "    .addOrder( Property.forName(\"name\").asc() )\n"
+#~ "    .addOrder( Property.forName(\"age\").desc() )\n"
+#~ "    .setMaxResults(50)\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"F%\") )\n"
+#~ "    .createCriteria(\"kittens\")\n"
+#~ "        .add( Restrictions.like(\"name\", \"F%\") )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"F&#37;\") )\n"
+#~ "    .createCriteria(\"kittens\")\n"
+#~ "        .add( Restrictions.like(\"name\", \"F&#37;\") )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .createAlias(\"kittens\", \"kt\")\n"
+#~ "    .createAlias(\"mate\", \"mt\")\n"
+#~ "    .add( Restrictions.eqProperty(\"kt.name\", \"mt.name\") )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .createAlias(\"kittens\", \"kt\")\n"
+#~ "    .createAlias(\"mate\", \"mt\")\n"
+#~ "    .add( Restrictions.eqProperty(\"kt.name\", \"mt.name\") )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .createCriteria(\"kittens\", \"kt\")\n"
+#~ "        .add( Restrictions.eq(\"name\", \"F%\") )\n"
+#~ "    .setResultTransformer(Criteria.ALIAS_TO_ENTITY_MAP)\n"
+#~ "    .list();\n"
+#~ "Iterator iter = cats.iterator();\n"
+#~ "while ( iter.hasNext() ) {\n"
+#~ "    Map map = (Map) iter.next();\n"
+#~ "    Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);\n"
+#~ "    Cat kitten = (Cat) map.get(\"kt\");\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .createCriteria(\"kittens\", \"kt\")\n"
+#~ "        .add( Restrictions.eq(\"name\", \"F&#37;\") )\n"
+#~ "    .setResultTransformer(Criteria.ALIAS_TO_ENTITY_MAP)\n"
+#~ "    .list();\n"
+#~ "Iterator iter = cats.iterator();\n"
+#~ "while ( iter.hasNext() ) {\n"
+#~ "    Map map = (Map) iter.next();\n"
+#~ "    Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);\n"
+#~ "    Cat kitten = (Cat) map.get(\"kt\");\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
+#~ "    .setFetchMode(\"mate\", FetchMode.EAGER)\n"
+#~ "    .setFetchMode(\"kittens\", FetchMode.EAGER)\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"Fritz&#37;\") )\n"
+#~ "    .setFetchMode(\"mate\", FetchMode.EAGER)\n"
+#~ "    .setFetchMode(\"kittens\", FetchMode.EAGER)\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Cat cat = new Cat();\n"
+#~ "cat.setSex('F');\n"
+#~ "cat.setColor(Color.BLACK);\n"
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .add( Example.create(cat) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "Cat cat = new Cat();\n"
+#~ "cat.setSex('F');\n"
+#~ "cat.setColor(Color.BLACK);\n"
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .add( Example.create(cat) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Example example = Example.create(cat)\n"
+#~ "    .excludeZeroes()           //exclude zero valued properties\n"
+#~ "    .excludeProperty(\"color\")  //exclude the property named \"color\"\n"
+#~ "    .ignoreCase()              //perform case insensitive string "
+#~ "comparisons\n"
+#~ "    .enableLike();             //use like for string comparisons\n"
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .add(example)\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "Example example = Example.create(cat)\n"
+#~ "    .excludeZeroes()           //exclude zero valued properties\n"
+#~ "    .excludeProperty(\"color\")  //exclude the property named \"color\"\n"
+#~ "    .ignoreCase()              //perform case insensitive string "
+#~ "comparisons\n"
+#~ "    .enableLike();             //use like for string comparisons\n"
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .add(example)\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .add( Example.create(cat) )\n"
+#~ "    .createCriteria(\"mate\")\n"
+#~ "        .add( Example.create( cat.getMate() ) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .add( Example.create(cat) )\n"
+#~ "    .createCriteria(\"mate\")\n"
+#~ "        .add( Example.create( cat.getMate() ) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.rowCount() )\n"
+#~ "    .add( Restrictions.eq(\"color\", Color.BLACK) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.rowCount() )\n"
+#~ "    .add( Restrictions.eq(\"color\", Color.BLACK) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.rowCount() )\n"
+#~ "        .add( Projections.avg(\"weight\") )\n"
+#~ "        .add( Projections.max(\"weight\") )\n"
+#~ "        .add( Projections.groupProperty(\"color\") )\n"
+#~ "    )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.rowCount() )\n"
+#~ "        .add( Projections.avg(\"weight\") )\n"
+#~ "        .add( Projections.max(\"weight\") )\n"
+#~ "        .add( Projections.groupProperty(\"color\") )\n"
+#~ "    )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.alias( Projections.groupProperty(\"color"
+#~ "\"), \"colr\" ) )\n"
+#~ "    .addOrder( Order.asc(\"colr\") )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.alias( Projections.groupProperty(\"color"
+#~ "\"), \"colr\" ) )\n"
+#~ "    .addOrder( Order.asc(\"colr\") )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.groupProperty(\"color\").as(\"colr\") )\n"
+#~ "    .addOrder( Order.asc(\"colr\") )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.groupProperty(\"color\").as(\"colr\") )\n"
+#~ "    .addOrder( Order.asc(\"colr\") )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.rowCount(), \"catCountByColor\" )\n"
+#~ "        .add( Projections.avg(\"weight\"), \"avgWeight\" )\n"
+#~ "        .add( Projections.max(\"weight\"), \"maxWeight\" )\n"
+#~ "        .add( Projections.groupProperty(\"color\"), \"color\" )\n"
+#~ "    )\n"
+#~ "    .addOrder( Order.desc(\"catCountByColor\") )\n"
+#~ "    .addOrder( Order.desc(\"avgWeight\") )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.rowCount(), \"catCountByColor\" )\n"
+#~ "        .add( Projections.avg(\"weight\"), \"avgWeight\" )\n"
+#~ "        .add( Projections.max(\"weight\"), \"maxWeight\" )\n"
+#~ "        .add( Projections.groupProperty(\"color\"), \"color\" )\n"
+#~ "    )\n"
+#~ "    .addOrder( Order.desc(\"catCountByColor\") )\n"
+#~ "    .addOrder( Order.desc(\"avgWeight\") )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Domestic.class, \"cat\")\n"
+#~ "    .createAlias(\"kittens\", \"kit\")\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.property(\"cat.name\"), \"catName\" )\n"
+#~ "        .add( Projections.property(\"kit.name\"), \"kitName\" )\n"
+#~ "    )\n"
+#~ "    .addOrder( Order.asc(\"catName\") )\n"
+#~ "    .addOrder( Order.asc(\"kitName\") )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Domestic.class, \"cat\")\n"
+#~ "    .createAlias(\"kittens\", \"kit\")\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.property(\"cat.name\"), \"catName\" )\n"
+#~ "        .add( Projections.property(\"kit.name\"), \"kitName\" )\n"
+#~ "    )\n"
+#~ "    .addOrder( Order.asc(\"catName\") )\n"
+#~ "    .addOrder( Order.asc(\"kitName\") )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Property.forName(\"name\") )\n"
+#~ "    .add( Property.forName(\"color\").eq(Color.BLACK) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Property.forName(\"name\") )\n"
+#~ "    .add( Property.forName(\"color\").eq(Color.BLACK) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.rowCount().as(\"catCountByColor\") )\n"
+#~ "        .add( Property.forName(\"weight\").avg().as(\"avgWeight\") )\n"
+#~ "        .add( Property.forName(\"weight\").max().as(\"maxWeight\") )\n"
+#~ "        .add( Property.forName(\"color\").group().as(\"color\" )\n"
+#~ "    )\n"
+#~ "    .addOrder( Order.desc(\"catCountByColor\") )\n"
+#~ "    .addOrder( Order.desc(\"avgWeight\") )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.rowCount().as(\"catCountByColor\") )\n"
+#~ "        .add( Property.forName(\"weight\").avg().as(\"avgWeight\") )\n"
+#~ "        .add( Property.forName(\"weight\").max().as(\"maxWeight\") )\n"
+#~ "        .add( Property.forName(\"color\").group().as(\"color\" )\n"
+#~ "    )\n"
+#~ "    .addOrder( Order.desc(\"catCountByColor\") )\n"
+#~ "    .addOrder( Order.desc(\"avgWeight\") )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[DetachedCriteria query = DetachedCriteria.forClass(Cat.class)\n"
+#~ "    .add( Property.forName(\"sex\").eq('F') );\n"
+#~ "    \n"
+#~ "Session session = ....;\n"
+#~ "Transaction txn = session.beginTransaction();\n"
+#~ "List results = query.getExecutableCriteria(session).setMaxResults(100)."
+#~ "list();\n"
+#~ "txn.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "DetachedCriteria query = DetachedCriteria.forClass(Cat.class)\n"
+#~ "    .add( Property.forName(\"sex\").eq('F') );\n"
+#~ "    \n"
+#~ "Session session = ....;\n"
+#~ "Transaction txn = session.beginTransaction();\n"
+#~ "List results = query.getExecutableCriteria(session).setMaxResults(100)."
+#~ "list();\n"
+#~ "txn.commit();\n"
+#~ "session.close();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[DetachedCriteria avgWeight = DetachedCriteria.forClass(Cat."
+#~ "class)\n"
+#~ "    .setProjection( Property.forName(\"weight\").avg() );\n"
+#~ "session.createCriteria(Cat.class)\n"
+#~ "    .add( Property.forName(\"weight\").gt(avgWeight) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "DetachedCriteria avgWeight = DetachedCriteria.forClass(Cat.class)\n"
+#~ "    .setProjection( Property.forName(\"weight\").avg() );\n"
+#~ "session.createCriteria(Cat.class)\n"
+#~ "    .add( Property.forName(\"weight).gt(avgWeight) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[DetachedCriteria weights = DetachedCriteria.forClass(Cat.class)\n"
+#~ "    .setProjection( Property.forName(\"weight\") );\n"
+#~ "session.createCriteria(Cat.class)\n"
+#~ "    .add( Subqueries.geAll(\"weight\", weights) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "DetachedCriteria weights = DetachedCriteria.forClass(Cat.class)\n"
+#~ "    .setProjection( Property.forName(\"weight\") );\n"
+#~ "session.createCriteria(Cat.class)\n"
+#~ "    .add( Subqueries.geAll(\"weight\", weights) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[DetachedCriteria avgWeightForSex = DetachedCriteria.forClass(Cat."
+#~ "class, \"cat2\")\n"
+#~ "    .setProjection( Property.forName(\"weight\").avg() )\n"
+#~ "    .add( Property.forName(\"cat2.sex\").eqProperty(\"cat.sex\") );\n"
+#~ "session.createCriteria(Cat.class, \"cat\")\n"
+#~ "    .add( Property.forName(\"weight\").gt(avgWeightForSex) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "DetachedCriteria avgWeightForSex = DetachedCriteria.forClass(Cat.class, "
+#~ "\"cat2\")\n"
+#~ "    .setProjection( Property.forName(\"weight\").avg() )\n"
+#~ "    .add( Property.forName(\"cat2.sex\").eqProperty(\"cat.sex\") );\n"
+#~ "session.createCriteria(Cat.class, \"cat\")\n"
+#~ "    .add( Property.forName(\"weight).gt(avgWeightForSex) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"User\">\n"
+#~ "    <cache usage=\"read-write\"/>\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"increment\"/>\n"
+#~ "    </id>\n"
+#~ "    <natural-id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "        <property name=\"org\"/>\n"
+#~ "    </natural-id>\n"
+#~ "    <property name=\"password\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"User\"&gt;\n"
+#~ "    &lt;cache usage=\"read-write\"/&gt;\n"
+#~ "    &lt;id name=\"id\"&gt;\n"
+#~ "        &lt;generator class=\"increment\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;natural-id&gt;\n"
+#~ "        &lt;property name=\"name\"/&gt;\n"
+#~ "        &lt;property name=\"org\"/&gt;\n"
+#~ "    &lt;/natural-id&gt;\n"
+#~ "    &lt;property name=\"password\"/&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[session.createCriteria(User.class)\n"
+#~ "    .add( Restrictions.naturalId()\n"
+#~ "        .set(\"name\", \"gavin\")\n"
+#~ "        .set(\"org\", \"hb\") \n"
+#~ "    ).setCacheable(true)\n"
+#~ "    .uniqueResult();]]>"
+#~ msgstr ""
+#~ "session.createCriteria(User.class)\n"
+#~ "    .add( Restrictions.naturalId()\n"
+#~ "        .set(\"name\", \"gavin\")\n"
+#~ "        .set(\"org\", \"hb\") \n"
+#~ "    ).setCacheable(true)\n"
+#~ "    .uniqueResult();"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/query_hql.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/query_hql.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/query_hql.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,42 +1,41 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-13 17:08+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: query_hql.xml:29
 #, no-c-format
 msgid "HQL: The Hibernate Query Language"
-msgstr "HQL: The Hibernate Query Language"
+msgstr "HQL: Hibernate クエリ言語"
 
 #. Tag: para
-#: query_hql.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate uses a powerful query language (HQL) that is similar in appearance "
 "to SQL. Compared with SQL, however, HQL is fully object-oriented and "
 "understands notions like inheritance, polymorphism and association."
 msgstr ""
-"HibernateはSQLに非常によく似た(意図的に似せた)強力な問い合わせ言語を備えてい"
-"ます。 しかしSQLに似た構文に惑わされないでください。HQLは完全にオブジェクト指"
-"向であり、 継承、ポリモーフィズム、関連といった概念を理解します。"
+"Hibernate は SQL に非常によく似た (意図的に似せた) 強力な問い合わせ言語を備え"
+"ています。しかし SQL に似た構文に惑わされないでください。 HQL は完全にオブ"
+"ジェクト指向であり、継承、ポリモーフィズム、関連といった概念を理解します。"
 
 #. Tag: title
-#: query_hql.xml:38
 #, no-c-format
 msgid "Case Sensitivity"
 msgstr "大文字と小文字の区別"
 
 #. Tag: para
-#: query_hql.xml:40
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "With the exception of names of Java classes and properties, queries are case-"
 "insensitive. So <literal>SeLeCT</literal> is the same as <literal>sELEct</"
@@ -44,260 +43,158 @@
 "hibernate.eg.FOO</literal> is not <literal>org.hibernate.eg.Foo</literal>, "
 "and <literal>foo.barSet</literal> is not <literal>foo.BARSET</literal>."
 msgstr ""
-"クエリはJavaのクラス名とプロパティ名を除いて大文字、小文字を区別しません。 "
+"クエリは Java のクラス名とプロパティ名を除いて大文字、小文字を区別しません。"
 "従って <literal>SeLeCT</literal> は <literal>sELEct</literal> と同じで、かつ "
-"<literal>SELECT</literal> とも同じですが <literal>net.sf.hibernate.eg.FOO</"
-"literal> は <literal>net.sf.hibernate.eg.Foo</literal> とは違い、かつ "
+"<literal>SELECT</literal> とも同じですが <literal>org.hibernate.eg.FOO</"
+"literal> は <literal>org.hibernate.eg.Foo</literal> とは違い、かつ "
 "<literal>foo.barSet</literal> は <literal>foo.BARSET</literal> とも違います。"
 
 #. Tag: para
-#: query_hql.xml:51
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This manual uses lowercase HQL keywords. Some users find queries with "
 "uppercase keywords more readable, but this convention is unsuitable for "
 "queries embedded in Java code."
 msgstr ""
-"このマニュアルでは小文字のHQLキーワードを使用します。 大文字のキーワードのク"
-"エリの方が読みやすいと感じるユーザーもいると思います。 ですが、Javaコード内に"
-"埋め込まれたときには見づらいと思います。"
+"このマニュアルでは小文字の HQL キーワードを使用します。大文字のキーワードのク"
+"エリの方が読みやすいと感じるユーザーもいると思います。ですが、 Java コード内"
+"に埋め込まれたときには見づらいと思います。"
 
 #. Tag: title
-#: query_hql.xml:59
 #, no-c-format
 msgid "The from clause"
-msgstr "from節"
+msgstr "from 節"
 
 #. Tag: para
-#: query_hql.xml:61
 #, no-c-format
 msgid "The simplest possible Hibernate query is of the form:"
-msgstr "もっとも単純なHibernateクエリは次の形式です。"
+msgstr "もっとも単純な Hibernate クエリは次の形式です:"
 
-#. Tag: programlisting
-#: query_hql.xml:65
-#, no-c-format
-msgid "<![CDATA[from eg.Cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:67
 #, fuzzy, no-c-format
 msgid ""
 "This returns all instances of the class <literal>eg.Cat</literal>. You do "
 "not usually need to qualify the class name, since <literal>auto-import</"
 "literal> is the default. For example:"
 msgstr ""
-"これは単純に <literal>eg.Cat</literal> クラスのインスタンスをすべて返しま"
-"す。 必ずしもクラス名を修飾する(クラスにパッケージ名を付ける)必要はありませ"
-"ん。 というのも、<literal>auto-import</literal> がデフォルトになっているから"
-"です。 そのためほとんどの場合、このように書くだけで十分です。"
+"これは単純に  <literal>eg.Cat</literal>  クラスのインスタンスをすべて返しま"
+"す。必ずしもクラス名を修飾する(クラスにパッケージ名を付ける)必要はありませ"
+"ん。というのも、 <literal>auto-import</literal> がデフォルトになっているから"
+"です。そのためほとんどの場合、このように書くだけで十分です:"
 
-#. Tag: programlisting
-#: query_hql.xml:73
-#, no-c-format
-msgid "<![CDATA[from Cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:75
 #, no-c-format
 msgid ""
 "In order to refer to the <literal>Cat</literal> in other parts of the query, "
 "you will need to assign an <emphasis>alias</emphasis>. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:81 query_hql.xml:396
-#, no-c-format
-msgid "<![CDATA[from Cat as cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:83
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This query assigns the alias <literal>cat</literal> to <literal>Cat</"
 "literal> instances, so you can use that alias later in the query. The "
 "<literal>as</literal> keyword is optional. You could also write:"
 msgstr ""
 "このクエリでは <literal>Cat</literal> インスタンスに <literal>cat</literal> "
-"という別名を付けています。 そのため、後でこのクエリ内で、この別名を使うことが"
+"という別名を付けています。そのため、後でこのクエリ内で、この別名を使うことが"
 "できます。 <literal>as</literal> キーワードはオプションです。つまりこのように"
 "書くこともできます:"
 
-#. Tag: programlisting
-#: query_hql.xml:89
-#, no-c-format
-msgid "<![CDATA[from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:91
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Multiple classes can appear, resulting in a cartesian product or \"cross\" "
 "join."
-msgstr "直積、あるいはクロス結合によって多数のクラスが出現することもあります。"
-
-#. Tag: programlisting
-#: query_hql.xml:95
-#, no-c-format
-msgid "<![CDATA[from Formula, Parameter]]>"
 msgstr ""
+"直積、あるいは「クロス」結合によって多数のクラスが出現することもあります。"
 
-#. Tag: programlisting
-#: query_hql.xml:96
-#, no-c-format
-msgid "<![CDATA[from Formula as form, Parameter as param]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:98
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is good practice to name query aliases using an initial lowercase as this "
 "is consistent with Java naming standards for local variables (e.g. "
 "<literal>domesticCat</literal>)."
 msgstr ""
-"ローカル変数のJavaのネーミング基準と一致した、 頭文字に小文字を使ったクエリの"
-"別名を付けることはいい習慣です(例えば <literal>domesticCat</literal> )。"
+"ローカル変数の Java のネーミング基準と一致した、頭文字に小文字を使ったクエリ"
+"の別名を付けることはいい習慣です (例えば <literal>domesticCat</literal>)。"
 
 #. Tag: title
-#: query_hql.xml:107
 #, no-c-format
 msgid "Associations and joins"
 msgstr "関連と結合"
 
 #. Tag: para
-#: query_hql.xml:109
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also assign aliases to associated entities or to elements of a "
 "collection of values using a <literal>join</literal>. For example:"
 msgstr ""
-"関連するエンティティあるいは値コレクションの要素にも、<literal>結合</"
+"関連するエンティティあるいは値コレクションの要素にも、 <literal>結合</"
 "literal> を使って別名を割り当てることが出来ます。"
 
-#. Tag: programlisting
-#: query_hql.xml:114
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join cat.mate as mate\n"
-"    left outer join cat.kittens as kitten]]>"
-msgstr ""
+msgid "The supported join types are borrowed from ANSI SQL:"
+msgstr "サポートしている結合のタイプは ANSI SQL と同じです。"
 
-#. Tag: programlisting
-#: query_hql.xml:116
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from Cat as cat left join cat.mate.kittens as kittens]]>"
-msgstr ""
+msgid "<literal>inner join</literal>"
+msgstr "<literal>inner join</literal>"
 
-#. Tag: programlisting
-#: query_hql.xml:118
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from Formula form full join form.parameter param]]>"
-msgstr ""
+msgid "<literal>left outer join</literal>"
+msgstr "<literal>left outer join</literal>"
 
 #. Tag: para
-#: query_hql.xml:120
-#, fuzzy, no-c-format
-msgid "The supported join types are borrowed from ANSI SQL:"
-msgstr "サポートしている結合のタイプはANSI SQLと同じです。"
-
-#. Tag: literal
-#: query_hql.xml:127
 #, no-c-format
-msgid "inner join"
-msgstr "inner join"
+msgid "<literal>right outer join</literal>"
+msgstr "<literal>right outer join</literal>"
 
-#. Tag: literal
-#: query_hql.xml:132
-#, no-c-format
-msgid "left outer join"
-msgstr "left outer join"
-
-#. Tag: literal
-#: query_hql.xml:137
-#, no-c-format
-msgid "right outer join"
-msgstr "right outer join"
-
 #. Tag: para
-#: query_hql.xml:141
 #, no-c-format
 msgid "<literal>full join</literal> (not usually useful)"
 msgstr "<literal>full join</literal> (たいていの場合使いづらい)"
 
 #. Tag: para
-#: query_hql.xml:147
 #, no-c-format
 msgid ""
 "The <literal>inner join</literal>, <literal>left outer join</literal> and "
 "<literal>right outer join</literal> constructs may be abbreviated."
 msgstr ""
-"<literal>inner join</literal>、<literal>left outer join</literal>、"
-"<literal>right outer join</literal>には省略形を使うこともできます。"
+"<literal>inner join</literal>、 <literal>left outer join</literal>、 "
+"<literal>right outer join</literal> には省略形を使うこともできます。"
 
-#. Tag: programlisting
-#: query_hql.xml:152
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    join cat.mate as mate\n"
-"    left join cat.kittens as kitten]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:154
 #, no-c-format
 msgid ""
 "You may supply extra join conditions using the HQL <literal>with</literal> "
 "keyword."
 msgstr ""
-"HQLの <literal>with</literal> キーワードを使うと、結合条件を付け加えることが"
+"HQL の <literal>with</literal> キーワードを使うと、結合条件を付け加えることが"
 "できます。"
 
-#. Tag: programlisting
-#: query_hql.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    left join cat.kittens as kitten\n"
-"        with kitten.bodyWeight > 10.0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:161
 #, fuzzy, no-c-format
 msgid ""
 "A \"fetch\" join allows associations or collections of values to be "
 "initialized along with their parent objects using a single select. This is "
 "particularly useful in the case of a collection. It effectively overrides "
 "the outer join and lazy declarations of the mapping file for associations "
-"and collections. See <xref linkend=\"performance-fetching\"/> for more "
+"and collections. See <xref linkend=\"performance-fetching\" /> for more "
 "information."
 msgstr ""
-"加えて、「フェッチ」結合は関連や値のコレクションを親オブジェクトと一緒に1度の"
-"select句で初期化します。 これは特にコレクションの場合に有用です。これは実質"
-"上、関連とコレクションに対するマッピング定義ファイルの外部結合とlazy初期化の"
-"定義を上書きすることになります。 <xref linkend=\"performance-fetching\"/> に"
-"より多くの情報があります。"
+"加えて、「フェッチ」結合は関連や値のコレクションを親オブジェクトと一緒に1度"
+"の select 句で初期化します。これは特にコレクションの場合に有用です。これは実"
+"質上、関連とコレクションに対するマッピング定義ファイルの外部結合と lazy 初期"
+"化の定義を上書きすることになります。 <xref linkend=\"performance-fetching\"/"
+"> により多くの情報があります。"
 
-#. Tag: programlisting
-#: query_hql.xml:169
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join fetch cat.mate\n"
-"    left join fetch cat.kittens]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:171
-#, fuzzy, no-c-format
-msgid ""
 "A fetch join does not usually need to assign an alias, because the "
 "associated objects should not be used in the <literal>where</literal> clause "
 "(or any other clause). The associated objects are also not returned directly "
@@ -305,26 +202,15 @@
 "The only reason you might need an alias is if you are recursively join "
 "fetching a further collection:"
 msgstr ""
-"結合によるフェッチは関連するオブジェクトが <literal>where</literal> 節(または"
-"他のどんな節でも) で使われてはならないので、通常別名を割り当てる必要がありま"
-"せん。また関連オブジェクトは問い合わせ結果として 直接返されません。代わりに親"
-"オブジェクトを通してアクセスできます。 コレクションを再帰的に結合フェッチする"
-"場合のみ、別名が必要になります。"
+"結合によるフェッチは関連するオブジェクトが <literal>where</literal> 節 (また"
+"は他のどんな節でも) で使われてはならないので、通常別名を割り当てる必要があり"
+"ません。また関連オブジェクトは問い合わせ結果として直接返されません。代わりに"
+"親オブジェクトを通してアクセスできます。コレクションを再帰的に結合フェッチす"
+"る場合のみ、別名が必要になります:"
 
-#. Tag: programlisting
-#: query_hql.xml:179
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join fetch cat.mate\n"
-"    left join fetch cat.kittens child\n"
-"    left join fetch child.kittens]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:181
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>fetch</literal> construct cannot be used in queries called "
 "using <literal>iterate()</literal> (though <literal>scroll()</literal> can "
 "be used). <literal>Fetch</literal> should be used together with "
@@ -342,22 +228,21 @@
 msgstr ""
 "<literal>fetch</literal> 構文は <literal>iterate()</literal> を使ったクエリ呼"
 "び出しで使用できないことに注意してください (一方で <literal>scroll()</"
-"literal> は使用できます)。 また、これらの操作は結果の行に基づいているため、 "
+"literal> は使用できます)。また、これらの操作は結果の行に基づいているため、 "
 "<literal>fetch</literal> は <literal>setMaxResults()</literal> や "
-"<literal>setFirstResult()</literal> と一緒に使用すべきではありません。 通常"
-"eagerなコレクションフェッチをすると重複が出てしまうため、あなたが期待するよう"
-"な行数にはならないのです。 そしてまた <literal>fetch</literal> は、アドホック"
-"な <literal>with</literal> 条件を 一緒に使うこともできません。 一つのクエリで"
+"<literal>setFirstResult()</literal> と一緒に使用すべきではありません。通常 "
+"eager なコレクションフェッチをすると重複が出てしまうため、あなたが期待するよ"
+"うな行数にはならないのです。そしてまた <literal>fetch</literal> は、アドホッ"
+"クな <literal>with</literal> 条件を一緒に使うこともできません。一つのクエリで"
 "複数のコレクションを結合フェッチすることにより直積を作成できるので、この場合"
-"注意してください。 また、複数のコレクションに対する結合フェッチはbagマッピン"
-"グに対して予期せぬ結果をもたらすことがあるので、 この場合のクエリの作成には注"
-"意してください。 最後に <literal>全外部結合によるフェッチ</literal> と "
+"注意してください。また、複数のコレクションに対する結合フェッチは bag マッピン"
+"グに対して予期せぬ結果をもたらすことがあるので、この場合のクエリの作成には注"
+"意してください。最後に <literal>全外部結合によるフェッチ</literal> と "
 "<literal>右外部結合によるフェッチ</literal> は有用ではないことに注意してくだ"
 "さい。"
 
 #. Tag: para
-#: query_hql.xml:196
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are using property-level lazy fetching (with bytecode "
 "instrumentation), it is possible to force Hibernate to fetch the lazy "
@@ -365,53 +250,35 @@
 "properties</literal>."
 msgstr ""
 "もしプロパティレベルの遅延フェッチを使う場合(内部的にバイトコード処理をする"
-"場合)、 <literal>fetch all properties</literal> を使うことで Hibernateに遅延"
-"プロパティを速やかに(最初のクエリで)フェッチさせることができます。"
+"場合)、 <literal>fetch all properties</literal> を使うことで Hibernate に遅"
+"延プロパティを速やかに(最初のクエリで)フェッチさせることができます。"
 
-#. Tag: programlisting
-#: query_hql.xml:202
-#, no-c-format
-msgid "<![CDATA[from Document fetch all properties order by name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:203
-#, no-c-format
-msgid ""
-"<![CDATA[from Document doc fetch all properties where lower(doc.name) like '%"
-"cats%']]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:208
 #, no-c-format
 msgid "Forms of join syntax"
 msgstr "結合構文の形式"
 
 #. Tag: para
-#: query_hql.xml:210
 #, no-c-format
 msgid ""
 "HQL supports two forms of association joining: <literal>implicit</literal> "
 "and <literal>explicit</literal>."
 msgstr ""
-"HQLは2つの関連結合形式をサポートします:<literal>暗黙的</literal> と "
+"HQL は2つの関連結合形式をサポートします: <literal>暗黙的</literal> と "
 "<literal>明示的</literal>。"
 
 #. Tag: para
-#: query_hql.xml:214
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The queries shown in the previous section all use the <literal>explicit</"
 "literal> form, that is, where the join keyword is explicitly used in the "
 "from clause. This is the recommended form."
 msgstr ""
 "これまでのセクションでお見せした使い方はすべて <literal>明示的な</literal> 形"
-"式で、 from節で明示的にjoinキーワードを使っています。 この形式をおすすめしま"
-"す。"
+"式で、 from 節で明示的に join キーワードを使っています。この形式をおすすめし"
+"ます。"
 
 #. Tag: para
-#: query_hql.xml:219
 #, no-c-format
 msgid ""
 "The <literal>implicit</literal> form does not use the join keyword. Instead, "
@@ -419,56 +286,43 @@
 "literal> joins can appear in any of the HQL clauses. <literal>implicit</"
 "literal> join result in inner joins in the resulting SQL statement."
 msgstr ""
-"<literal>暗黙的</literal> フォームは、joinキーワードを使いません。代わりに、"
-"参照する関連に ドット表記を使います。<literal>暗黙的</literal> 結合は、さまざ"
-"まなHQLに出てきます。 <literal>暗黙的</literal> 結合の結果は、SQLステートメン"
-"トの内部結合結果です。"
+"<literal>暗黙的</literal> フォームは、 join キーワードを使いません。代わり"
+"に、参照する関連にドット表記を使います。 <literal>暗黙的</literal> 結合は、さ"
+"まざまな HQL に出てきます。 <literal>暗黙的</literal> 結合の結果は、 SQL ス"
+"テートメントの内部結合結果です。"
 
-#. Tag: programlisting
-#: query_hql.xml:226
-#, no-c-format
-msgid "<![CDATA[from Cat as cat where cat.mate.name like '%s%']]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Referring to identifier property"
-msgstr "Refering to identifier property"
+msgstr "識別子プロパティの参照"
 
 #. Tag: para
-#: query_hql.xml:232
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "There are 2 ways to refer to an entity's identifier property:"
-msgstr ""
-"There are, generally speaking, 2 ways to refer to an entity's identifier "
-"property:"
+msgstr "エンティティの識別子プロパティは、一般的に2つの方法で参照されます:"
 
 #. Tag: para
-#: query_hql.xml:237
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The special property (lowercase) <literal>id</literal> may be used to "
 "reference the identifier property of an entity <emphasis>provided that the "
 "entity does not define a non-identifier property named id</emphasis>."
 msgstr ""
-"The special property (lowercase) <literal>id</literal> may be used to "
-"reference the identifier property of an entity <emphasis>provided that "
-"entity does not define a non-identifier property named id</emphasis>."
+"特別なプロパティ (小文字) <literal>id</literal> は、 <emphasis>id と名付けら"
+"れた非識別子プロパティを定義しないエンティティを与えられた</emphasis> エン"
+"ティティの識別子プロパティを参照するのに使用されます。"
 
 #. Tag: para
-#: query_hql.xml:244
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the entity defines a named identifier property, you can use that property "
 "name."
 msgstr ""
-"If the entity defines a named identifier property, you may use that property "
-"name."
+"もしエンティティが名付けられた識別子プロパティを定義したら、そのプロパティ名"
+"を使用できます。"
 
 #. Tag: para
-#: query_hql.xml:250
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "References to composite identifier properties follow the same naming rules. "
 "If the entity has a non-identifier property named id, the composite "
@@ -476,15 +330,13 @@
 "the special <literal>id</literal> property can be used to reference the "
 "identifier property."
 msgstr ""
-"References to composite identifier properties follow the same naming rules. "
-"If the entity has a non-identifier property named id, the composite "
-"identifier property can only be referenced by its defined named; otherwise, "
-"the special <literal>id</literal> property can be used to rerference the "
-"identifier property."
+"複合識別子プロパティへの参照は同じ命名ルールに従います。もしエンティティが "
+"id と名付けられた非識別子プロパティを持っていたら、複合識別子プロパティはその"
+"定義された名前で参照することができます。そうでないと、特別な <literal>id</"
+"literal> プロパティは、識別子プロパティを参照するのに使用されます。"
 
 #. Tag: para
-#: query_hql.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please note that, starting in version 3.2.2, this has changed significantly. "
 "In previous versions, <literal>id</literal> <emphasis>always</emphasis> "
@@ -492,279 +344,146 @@
 "ramification of that decision was that non-identifier properties named "
 "<literal>id</literal> could never be referenced in Hibernate queries."
 msgstr ""
-"Note: this has changed significantly starting in version 3.2.2. In previous "
-"versions, <literal>id</literal><emphasis>always</emphasis> referred to the "
-"identifier property no matter what its actual name. A ramification of that "
-"decision was that non-identifier properties named <literal>id</literal> "
-"could never be referenced in Hibernate queries."
+"注記: これは、バージョン 3.2.2 から大幅に変更しました。前バージョンでは、 "
+"<literal>id</literal> は、その実際の名前に関係なく <emphasis>常に</emphasis> "
+"識別子プロパティを参照していました。その結果、 <literal>id</literal> と名付け"
+"られた非識別子プロパティは、 Hibernate で決して参照されませんでした。"
 
 #. Tag: title
-#: query_hql.xml:269
 #, no-c-format
 msgid "The select clause"
-msgstr "Select節"
+msgstr "Select 節"
 
 #. Tag: para
-#: query_hql.xml:271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>select</literal> clause picks which objects and properties to "
 "return in the query result set. Consider the following:"
 msgstr ""
 "<literal>select</literal> 節は以下のようにどのオブジェクトと属性をクエリリザ"
-"ルトセットに返すかを選択します。:"
+"ルトセットに返すかを選択します:"
 
-#. Tag: programlisting
-#: query_hql.xml:276
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select mate\n"
-"from Cat as cat\n"
-"    inner join cat.mate as mate]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:278
-#, fuzzy, no-c-format
-msgid ""
 "The query will select <literal>mate</literal>s of other <literal>Cat</"
 "literal>s. You can express this query more compactly as:"
 msgstr ""
 "上記のクエリは他の <literal>Cat</literal> の <literal>mate</literal> を選択し"
-"ます。 実際には次のように、より簡潔に表現できます。:"
+"ます。実際には次のように、より簡潔に表現できます:"
 
-#. Tag: programlisting
-#: query_hql.xml:283
-#, no-c-format
-msgid "<![CDATA[select cat.mate from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:285
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Queries can return properties of any value type including properties of "
 "component type:"
 msgstr ""
 "クエリはコンポーネント型のプロパティを含む、あらゆる値型のプロパティも返せま"
-"す。:"
+"す:"
 
-#. Tag: programlisting
-#: query_hql.xml:289
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat.name from DomesticCat cat\n"
-"where cat.name like 'fri%']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:291
-#, no-c-format
-msgid "<![CDATA[select cust.name.firstName from Customer as cust]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:293
-#, fuzzy, no-c-format
-msgid ""
 "Queries can return multiple objects and/or properties as an array of type "
 "<literal>Object[]</literal>:"
 msgstr ""
-"クエリは複数のオブジェクトと(または)プロパティを <literal>Object[]</literal> "
-"型の配列として返せます。"
+"クエリは複数のオブジェクトと (または) プロパティを <literal>Object[]</"
+"literal> 型の配列として返せます。"
 
-#. Tag: programlisting
-#: query_hql.xml:298
-#, no-c-format
-msgid ""
-"<![CDATA[select mother, offspr, mate.name\n"
-"from DomesticCat as mother\n"
-"    inner join mother.mate as mate\n"
-"    left outer join mother.kittens as offspr]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:300
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Or as a <literal>List</literal>:"
 msgstr "もしくは <literal>List</literal> として、"
 
-#. Tag: programlisting
-#: query_hql.xml:304
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select new list(mother, offspr, mate.name)\n"
-"from DomesticCat as mother\n"
-"    inner join mother.mate as mate\n"
-"    left outer join mother.kittens as offspr]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:306
-#, fuzzy, no-c-format
-msgid ""
 "Or - assuming that the class <literal>Family</literal> has an appropriate "
 "constructor - as an actual typesafe Java object:"
 msgstr ""
 "あるいは <literal>Family</literal> クラスが適切なコンストラクタを持っていると"
 "するならば、"
 
-#. Tag: programlisting
-#: query_hql.xml:310
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select new Family(mother, mate, offspr)\n"
-"from DomesticCat as mother\n"
-"    join mother.mate as mate\n"
-"    left join mother.kittens as offspr]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:313
-#, fuzzy, no-c-format
-msgid ""
 "You can assign aliases to selected expressions using <literal>as</literal>:"
-msgstr "select節に <literal>as</literal> を使って別名をつけることもできます。"
+msgstr "select 節に <literal>as</literal> を使って別名をつけることもできます。"
 
-#. Tag: programlisting
-#: query_hql.xml:317
-#, no-c-format
-msgid ""
-"<![CDATA[select max(bodyWeight) as max, min(bodyWeight) as min, count(*) as "
-"n\n"
-"from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:319
 #, no-c-format
 msgid ""
 "This is most useful when used together with <literal>select new map</"
 "literal>:"
 msgstr "<literal>select new map</literal> と一緒に使うときに最も役立ちます:"
 
-#. Tag: programlisting
-#: query_hql.xml:323
-#, no-c-format
-msgid ""
-"<![CDATA[select new map( max(bodyWeight) as max, min(bodyWeight) as min, "
-"count(*) as n )\n"
-"from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:325
 #, no-c-format
 msgid ""
 "This query returns a <literal>Map</literal> from aliases to selected values."
-msgstr "このクエリは別名からselectした値へ <literal>Map</literal> を返します。"
+msgstr ""
+"このクエリは別名から select した値へ <literal>Map</literal> を返します。"
 
 #. Tag: title
-#: query_hql.xml:332
 #, no-c-format
 msgid "Aggregate functions"
 msgstr "集約関数"
 
 #. Tag: para
-#: query_hql.xml:334
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL queries can even return the results of aggregate functions on properties:"
-msgstr "HQLのクエリはプロパティの集約関数の結果も返せます:"
+msgstr "HQL のクエリはプロパティの集約関数の結果も返せます:"
 
-#. Tag: programlisting
-#: query_hql.xml:338
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[select avg(cat.weight), sum(cat.weight), max(cat.weight), count"
-"(cat)\n"
-"from Cat cat]]>"
-msgstr ""
+msgid "The supported aggregate functions are:"
+msgstr "サポートしている集約関数は以下のものです。"
 
 #. Tag: para
-#: query_hql.xml:349
 #, fuzzy, no-c-format
-msgid "The supported aggregate functions are:"
-msgstr "サポートしている集約関数は以下のものです。"
+msgid "<literal>avg(...), sum(...), min(...), max(...)</literal>"
+msgstr "<literal>avg(...), sum(...), min(...), max(...)</literal>"
 
-#. Tag: literal
-#: query_hql.xml:356
+#. Tag: para
 #, no-c-format
-msgid "avg(...), sum(...), min(...), max(...)"
-msgstr "avg(...), sum(...), min(...), max(...)"
+msgid "<literal>count(*)</literal>"
+msgstr "<literal>count(*)</literal>"
 
-#. Tag: literal
-#: query_hql.xml:361
-#, no-c-format
-msgid "count(*)"
-msgstr "count(*)"
-
-#. Tag: literal
-#: query_hql.xml:366
-#, no-c-format
-msgid "count(...), count(distinct ...), count(all...)"
-msgstr "count(...), count(distinct ...), count(all...)"
-
 #. Tag: para
-#: query_hql.xml:371
 #, fuzzy, no-c-format
+msgid "<literal>count(...), count(distinct ...), count(all...)</literal>"
+msgstr "<literal>count(...), count(distinct ...), count(all...)</literal>"
+
+#. Tag: para
+#, no-c-format
 msgid ""
 "You can use arithmetic operators, concatenation, and recognized SQL "
 "functions in the select clause:"
 msgstr ""
-"select節において算術操作、連結と承認されたSQL関数を使うことができます。"
+"select 節において算術操作、連結と承認された SQL 関数を使うことができます:"
 
-#. Tag: programlisting
-#: query_hql.xml:376
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat.weight + sum(kitten.weight)\n"
-"from Cat cat\n"
-"    join cat.kittens kitten\n"
-"group by cat.id, cat.weight]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:378
-#, no-c-format
-msgid ""
-"<![CDATA[select firstName||' '||initial||' '||upper(lastName) from Person]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:380
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>distinct</literal> and <literal>all</literal> keywords can be "
 "used and have the same semantics as in SQL."
 msgstr ""
-"SQLと同じ意味を持つ <literal>distinct</literal> と <literal>all</literal> "
+"SQL と同じ意味を持つ <literal>distinct</literal> と <literal>all</literal> "
 "キーワードを使うことができます。"
 
-#. Tag: programlisting
-#: query_hql.xml:385
-#, no-c-format
-msgid ""
-"<![CDATA[select distinct cat.name from Cat cat\n"
-"\n"
-"select count(distinct cat.name), count(cat) from Cat cat]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:390
 #, no-c-format
 msgid "Polymorphic queries"
-msgstr "ポリモーフィックなクエリ"
+msgstr "ポリモーフィズムを使ったクエリ"
 
 #. Tag: para
-#: query_hql.xml:392
 #, no-c-format
 msgid "A query like:"
 msgstr "次のようなクエリ:"
 
 #. Tag: para
-#: query_hql.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "returns instances not only of <literal>Cat</literal>, but also of subclasses "
 "like <literal>DomesticCat</literal>. Hibernate queries can name "
@@ -773,154 +492,98 @@
 "that extend that class or implement the interface. The following query would "
 "return all persistent objects:"
 msgstr ""
-"<literal>Cat</literal> インスタンスだけではなく、<literal>DomesticCat</"
-"literal> のようなサブクラスも返されます。Hibernateクエリは <emphasis>どんな</"
-"emphasis> Javaクラスやインターフェイスも <literal>from</literal> 節に入れるこ"
-"とができます。 クエリはそのクラスを拡張した、もしくはインターフェイスを実装し"
-"た全ての永続クラスを返します。 次のクエリは永続オブジェクトをすべて返します:"
+"<literal>Cat</literal> インスタンスだけではなく、 <literal>DomesticCat</"
+"literal> のようなサブクラスも返されます。 Hibernate クエリは <emphasis>どんな"
+"</emphasis> Java クラスやインターフェースも <literal>from</literal> 節に入れ"
+"ることができます。クエリはそのクラスを拡張した、もしくはインターフェースを実"
+"装した全ての永続クラスを返します。次のクエリは永続オブジェクトをすべて返しま"
+"す:"
 
-#. Tag: programlisting
-#: query_hql.xml:406
-#, no-c-format
-msgid "<![CDATA[from java.lang.Object o]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:408
 #, no-c-format
 msgid ""
 "The interface <literal>Named</literal> might be implemented by various "
 "persistent classes:"
 msgstr ""
-"<literal>Named</literal> インターフェイスは様々な永続クラスによって実装されま"
+"<literal>Named</literal> インターフェースは様々な永続クラスによって実装されま"
 "す。:"
 
-#. Tag: programlisting
-#: query_hql.xml:413
-#, no-c-format
-msgid "<![CDATA[from Named n, Named m where n.name = m.name]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:415
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These last two queries will require more than one SQL <literal>SELECT</"
 "literal>. This means that the <literal>order by</literal> clause does not "
 "correctly order the whole result set. It also means you cannot call these "
 "queries using <literal>Query.scroll()</literal>."
 msgstr ""
-"最後の二つのクエリは、二つ以上のSQL <literal>SELECT</literal> を要求している"
-"ことに注意してください。 このことは <literal>order by</literal> 節がリザルト"
-"セット全体を正確には整列しないことを意味します (さらにそれは、<literal>Query."
+"最後の2つのクエリは、2つ以上の SQL <literal>SELECT</literal> を要求しているこ"
+"とに注意してください。このことは <literal>order by</literal> 節がリザルトセッ"
+"ト全体を正確には整列しないことを意味します (さらにそれは、 <literal>Query."
 "scroll()</literal> を使用してこれらのクエリを呼ぶことができないことを意味しま"
 "す。)。"
 
 #. Tag: title
-#: query_hql.xml:424
 #, no-c-format
 msgid "The where clause"
-msgstr "where節"
+msgstr "where 節"
 
 #. Tag: para
-#: query_hql.xml:426
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>where</literal> clause allows you to refine the list of "
 "instances returned. If no alias exists, you can refer to properties by name:"
 msgstr ""
 "<literal>where</literal> 節は返されるインスタンスのリストを絞ることができま"
-"す。 もし別名がない場合、名前でプロパティを参照します。"
+"す。もし別名がない場合、名前でプロパティを参照します。"
 
-#. Tag: programlisting
-#: query_hql.xml:431
-#, no-c-format
-msgid "<![CDATA[from Cat where name='Fritz']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:433
 #, no-c-format
 msgid "If there is an alias, use a qualified property name:"
-msgstr "もし別名がある場合、修飾名を使ってください。"
+msgstr "もし別名がある場合、修飾名を使ってください:"
 
-#. Tag: programlisting
-#: query_hql.xml:437
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from Cat as cat where cat.name='Fritz']]>"
+msgid "This returns instances of <literal>Cat</literal> named 'Fritz'."
 msgstr ""
+"名前が 'Fritz' という <literal>Cat</literal> のインスタンスを返します。"
 
 #. Tag: para
-#: query_hql.xml:439
-#, fuzzy, no-c-format
-msgid "This returns instances of <literal>Cat</literal> named 'Fritz'."
-msgstr "名前が'Fritz'という <literal>Cat</literal> のインスタンスを返します。"
-
-#. Tag: para
-#: query_hql.xml:443
 #, no-c-format
 msgid "The following query:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:446
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select foo\n"
-"from Foo foo, Bar bar\n"
-"where foo.startDate = bar.date]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:448
-#, fuzzy, no-c-format
-msgid ""
 "returns all instances of <literal>Foo</literal> with an instance of "
 "<literal>bar</literal> with a <literal>date</literal> property equal to the "
 "<literal>startDate</literal> property of the <literal>Foo</literal>. "
 "Compound path expressions make the <literal>where</literal> clause extremely "
 "powerful. Consider the following:"
 msgstr ""
-"上のHQLは、<literal>Foo</literal> の <literal>startDate</literal> プロパティ"
-"と等しい <literal>date</literal> プロパティを持った <literal>bar</literal> イ"
-"ンスタンスが存在する、 すべての <literal>Foo</literal> インスタンスを返しま"
-"す。 コンパウンドパス式(例えば「cat.mate.name」)は <literal>where</"
-"literal> 節を非常に強力にします。注目:"
+"上の HQL は、 <literal>Foo</literal> の <literal>startDate</literal> プロパ"
+"ティと等しい <literal>date</literal> プロパティを持った <literal>bar</"
+"literal> インスタンスが存在する、すべての <literal>Foo</literal> インスタンス"
+"を返します。コンパウンドパス式は <literal>where</literal> 節を非常に強力にし"
+"ます。注目:"
 
-#. Tag: programlisting
-#: query_hql.xml:457
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.mate.name is not null]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:459
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This query translates to an SQL query with a table (inner) join. For example:"
 msgstr ""
-"このクエリはテーブル結合(内部結合)を持つSQLクエリに変換されます。 その代わ"
+"このクエリはテーブル結合(内部結合)を持つ SQL クエリに変換されます。その代わ"
 "りに以下のように書くと、"
 
-#. Tag: programlisting
-#: query_hql.xml:464
-#, no-c-format
-msgid ""
-"<![CDATA[from Foo foo\n"
-"where foo.bar.baz.customer.address.city is not null]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:466
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "would result in a query that would require four table joins in SQL."
 msgstr ""
-"もし上のクエリを記述したらクエリ内に4つのテーブル結合を必要とするSQLクエリに"
-"変換されます。"
+"もし上のクエリを記述したらクエリ内に4つのテーブル結合を必要とする SQL クエリ"
+"に変換されます。"
 
 #. Tag: para
-#: query_hql.xml:470
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>=</literal> operator can be used to compare not only "
 "properties, but also instances:"
@@ -928,51 +591,24 @@
 "<literal>=</literal> 演算子は以下のように、プロパティだけでなくインスタンスを"
 "比較するためにも使われます。:"
 
-#. Tag: programlisting
-#: query_hql.xml:475
-#, no-c-format
-msgid "<![CDATA[from Cat cat, Cat rival where cat.mate = rival.mate]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:477
-#, no-c-format
-msgid ""
-"<![CDATA[select cat, mate\n"
-"from Cat cat, Cat mate\n"
-"where cat.mate = mate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:479
 #, fuzzy, no-c-format
 msgid ""
 "The special property (lowercase) <literal>id</literal> can be used to "
 "reference the unique identifier of an object. See <xref linkend=\"queryhql-"
-"identifier-property\"/> for more information."
+"identifier-property\" /> for more information."
 msgstr ""
-"<literal>id</literal> (小文字)は特別なプロパティであり、 オブジェクトのユニー"
-"クな識別子を参照するために使用できます。(さらに、そのプロパティ名を使用できま"
-"す。)"
+"<literal>id</literal> (小文字) は特別なプロパティであり、オブジェクトのユニー"
+"クな識別子を参照するために使用できます。詳細については <xref linkend="
+"\"queryhql-identifier-property\"/> を参照ください。"
 
-#. Tag: programlisting
-#: query_hql.xml:485
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat where cat.id = 123\n"
-"\n"
-"from Cat as cat where cat.mate.id = 69]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:487
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The second query is efficient and does not require a table join."
-msgstr "2番目のクエリは効率的です。テーブル結合が必要ありません!"
+msgstr "2番目のクエリは効率的です。テーブル結合が必要ありません。"
 
 #. Tag: para
-#: query_hql.xml:491
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Properties of composite identifiers can also be used. Consider the following "
 "example where <literal>Person</literal> has composite identifiers consisting "
@@ -980,151 +616,105 @@
 msgstr ""
 "また複合識別子のプロパティも使用できます。ここで <literal>Person</literal> "
 "が <literal>country</literal> と <literal>medicareNumber</literal> からなる複"
-"合識別子を持つと仮定します。"
+"合識別子を持つと仮定します。識別子プロパティ参照についての詳細は、前回と同様"
+"に <xref linkend=\"queryhql-identifier-property\"/> を参照ください。"
 
-#. Tag: programlisting
-#: query_hql.xml:497
-#, no-c-format
-msgid ""
-"<![CDATA[from bank.Person person\n"
-"where person.id.country = 'AU'\n"
-"    and person.id.medicareNumber = 123456]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:499
-#, no-c-format
-msgid ""
-"<![CDATA[from bank.Account account\n"
-"where account.owner.id.country = 'AU'\n"
-"    and account.owner.id.medicareNumber = 123456]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:501
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Once again, the second query does not require a table join."
-msgstr "もう一度言いますが、2番目のクエリにはテーブル結合が必要ありません。"
+msgstr "繰り返しますが、2番目のクエリにはテーブル結合が必要ありません。"
 
 #. Tag: para
-#: query_hql.xml:505
 #, no-c-format
 msgid ""
-"See <xref linkend=\"queryhql-identifier-property\"/> for more information "
+"See <xref linkend=\"queryhql-identifier-property\" /> for more information "
 "regarding referencing identifier properties)"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:510
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The special property <literal>class</literal> accesses the discriminator "
 "value of an instance in the case of polymorphic persistence. A Java class "
 "name embedded in the where clause will be translated to its discriminator "
 "value."
 msgstr ""
-"同様に <literal>class</literal> は特別なプロパティであり、 ポリモーフィックな"
-"永続化におけるインスタンスのdiscriminator値にアクセスします。 where節に埋め込"
-"まれたJavaのクラス名はそのdiscriminator値に変換されます。"
+"同様に <literal>class</literal> は特別なプロパティであり、ポリモーフィックな"
+"永続化におけるインスタンスの discriminator 値にアクセスします。 where 節に埋"
+"め込まれた Java のクラス名はその discriminator 値に変換されます。"
 
-#. Tag: programlisting
-#: query_hql.xml:516
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.class = DomesticCat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:518
 #, fuzzy, no-c-format
 msgid ""
 "You can also use components or composite user types, or properties of said "
-"component types. See <xref linkend=\"queryhql-components\"/> for more "
+"component types. See <xref linkend=\"queryhql-components\" /> for more "
 "information."
 msgstr ""
-"またコンポーネントや複合ユーザ型(またそのコンポーネントのコンポーネントなど)"
-"のプロパティも指定できます。 しかし決して(コンポーネントのプロパティではな"
-"く)コンポーネント型のプロパティで終了するパス式を使わないでください。 例えば"
-"もし <literal>store.owner</literal> が <literal>address</literal> コンポーネ"
-"ントを持つエンティティならば以下のような結果となります。"
+"またコンポーネントや複合ユーザー型、又はそのコンポーネントのプロパティも使用"
+"できます。詳細については、 <xref linkend=\"queryhql-components\"/> を参照下さ"
+"い。"
 
 #. Tag: para
-#: query_hql.xml:523
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An \"any\" type has the special properties <literal>id</literal> and "
 "<literal>class</literal> that allows you to express a join in the following "
 "way (where <literal>AuditLog.item</literal> is a property mapped with "
 "<literal>&lt;any&gt;</literal>):"
 msgstr ""
-"\"any\"型は特別なプロパティである <literal>id</literal> と <literal>class</"
-"literal> を持ち、 以下の方法で結合を表現することを可能にします"
+"\"any\" 型は特別なプロパティである <literal>id</literal> と <literal>class</"
+"literal> を持ち、以下の方法で結合を表現することを可能にします "
 "(<literal>AuditLog.item</literal> は <literal>&lt;any&gt;</literal> でマッピ"
 "ングされたプロパティです)。"
 
-#. Tag: programlisting
-#: query_hql.xml:529
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from AuditLog log, Payment payment\n"
-"where log.item.class = 'Payment' and log.item.id = payment.id]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:531
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>log.item.class</literal> and <literal>payment.class</literal> "
 "would refer to the values of completely different database columns in the "
 "above query."
 msgstr ""
-"<literal>log.item.class</literal> と <literal>payment.class</literal> が 上記"
+"<literal>log.item.class</literal> と <literal>payment.class</literal> が上記"
 "のクエリ中で全く異なるデータベースカラムの値を参照するということに注意してく"
 "ださい。"
 
 #. Tag: title
-#: query_hql.xml:539
 #, no-c-format
 msgid "Expressions"
 msgstr "Expressions 式"
 
 #. Tag: para
-#: query_hql.xml:541
 #, fuzzy, no-c-format
 msgid ""
 "Expressions used in the <literal>where</literal> clause include the "
 "following:"
 msgstr ""
-"SQLの <literal>where</literal> 節で記述することが出来る式のほとんどをHQLでも"
-"記述できます。:"
+"SQL の <literal>where</literal> 節で記述することが出来る式のほとんどを HQL で"
+"も記述できます:"
 
 #. Tag: para
-#: query_hql.xml:548
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "mathematical operators: <literal>+, -, *, /</literal>"
 msgstr "算術演算子:<literal>+, -, *, /</literal>"
 
 #. Tag: para
-#: query_hql.xml:553
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "binary comparison operators: <literal>=, &gt;=, &lt;=, &lt;&gt;, !=, like</"
 "literal>"
 msgstr "2項比較演算子:<literal>=, &gt;=, &lt;=, &lt;&gt;, !=, like</literal>"
 
 #. Tag: para
-#: query_hql.xml:558
 #, no-c-format
 msgid "logical operations <literal>and, or, not</literal>"
 msgstr "論理演算子:<literal>and, or, not</literal>"
 
 #. Tag: para
-#: query_hql.xml:563
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Parentheses <literal>( )</literal> that indicates grouping"
 msgstr "グループ分けを表す括弧:<literal>( )</literal>"
 
 #. Tag: para
-#: query_hql.xml:568
 #, no-c-format
 msgid ""
 "<literal>in</literal>, <literal>not in</literal>, <literal>between</"
@@ -1138,18 +728,16 @@
 "<literal>member of</literal> and <literal>not member of</literal>"
 
 #. Tag: para
-#: query_hql.xml:581
 #, no-c-format
 msgid ""
 "\"Simple\" case, <literal>case ... when ... then ... else ... end</literal>, "
 "and \"searched\" case, <literal>case when ... then ... else ... end</literal>"
 msgstr ""
-"\"シンプル\"なcase <literal>case ... when ... then ... else ... end</"
-"literal>、 \"探索的\"なcase <literal>case when ... then ... else ... end</"
+"\"シンプル\"な case <literal>case ... when ... then ... else ... end</"
+"literal>、 \"探索的\"な case <literal>case when ... then ... else ... end</"
 "literal>"
 
 #. Tag: para
-#: query_hql.xml:587
 #, no-c-format
 msgid ""
 "string concatenation <literal>...||...</literal> or <literal>concat(...,...)"
@@ -1159,8 +747,7 @@
 "</literal>"
 
 #. Tag: para
-#: query_hql.xml:592
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>current_date()</literal>, <literal>current_time()</literal>, and "
 "<literal>current_timestamp()</literal>"
@@ -1169,8 +756,7 @@
 "<literal>current_timestamp()</literal>"
 
 #. Tag: para
-#: query_hql.xml:598
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>second(...)</literal>, <literal>minute(...)</literal>, <literal>hour"
 "(...)</literal>, <literal>day(...)</literal>, <literal>month(...)</literal>, "
@@ -1181,32 +767,28 @@
 "<literal>year(...)</literal>,"
 
 #. Tag: para
-#: query_hql.xml:605
 #, no-c-format
 msgid ""
 "Any function or operator defined by EJB-QL 3.0: <literal>substring(), trim"
 "(), lower(), upper(), length(), locate(), abs(), sqrt(), bit_length(), mod()"
 "</literal>"
 msgstr ""
-"EJB-QL 3.0で定義されている関数や演算子: <literal>substring(), trim(), lower"
-"(), upper(), length(), locate(), abs(), sqrt(), bit_length()</literal>"
+"EJB-QL 3.0 で定義されている関数や演算子: <literal>substring(), trim(), lower"
+"(), upper(), length(), locate(), abs(), sqrt(), bit_length(), mod()</literal>"
 
 #. Tag: para
-#: query_hql.xml:611
 #, no-c-format
 msgid "<literal>coalesce()</literal> and <literal>nullif()</literal>"
 msgstr "<literal>coalesce()</literal> と <literal>nullif()</literal>"
 
 #. Tag: para
-#: query_hql.xml:616
 #, no-c-format
 msgid ""
 "<literal>str()</literal> for converting numeric or temporal values to a "
 "readable string"
-msgstr "数字や時間の値をStringにコンバートする <literal>str()</literal>)"
+msgstr "数字や時間の値を String にコンバートする <literal>str()</literal>"
 
 #. Tag: para
-#: query_hql.xml:622
 #, no-c-format
 msgid ""
 "<literal>cast(... as ...)</literal>, where the second argument is the name "
@@ -1214,24 +796,22 @@
 "<literal>cast()</literal> and <literal>extract()</literal> is supported by "
 "the underlying database"
 msgstr ""
-"2番目の引数がHibernate型の名前である <literal>cast(... as ...)</literal> と "
-"<literal>extract(... from ...)</literal>。 ただし使用するデータベースがANSI "
-"<literal>cast()</literal> と <literal>extract()</literal> をサポートする場合"
-"に限ります。"
+"2番目の引数が Hibernate 型の名前である <literal>cast(... as ...)</literal> "
+"と <literal>extract(... from ...)</literal>。ただし使用するデータベースが "
+"ANSI <literal>cast()</literal> と <literal>extract()</literal> をサポートする"
+"場合に限ります。"
 
 #. Tag: para
-#: query_hql.xml:630
 #, no-c-format
 msgid ""
 "the HQL <literal>index()</literal> function, that applies to aliases of a "
 "joined indexed collection"
 msgstr ""
-"結合したインデックス付きのコレクションの別名に適用されるHQLの <literal>index"
-"()</literal> 関数。"
+"結合したインデックス付きのコレクションの別名に適用される HQL の "
+"<literal>index()</literal> 関数。"
 
 #. Tag: para
-#: query_hql.xml:636
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL functions that take collection-valued path expressions: <literal>size(), "
 "minelement(), maxelement(), minindex(), maxindex()</literal>, along with the "
@@ -1239,33 +819,30 @@
 "functions that can be quantified using <literal>some, all, exists, any, in</"
 "literal>."
 msgstr ""
-"コレクション値のパス式を取るHQL関数: <literal>size(), minelement(), "
+"コレクション値のパス式を取る HQL 関数: <literal>size(), minelement(), "
 "maxelement(), minindex(), maxindex()</literal> 。 <literal>some, all, "
 "exists, any, in</literal> を使って修飾することができる特別な "
 "<literal>elements()</literal> と <literal>indices</literal> 関数と一緒に使い"
 "ます。"
 
 #. Tag: para
-#: query_hql.xml:644
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Any database-supported SQL scalar function like <literal>sign()</literal>, "
 "<literal>trunc()</literal>, <literal>rtrim()</literal>, and <literal>sin()</"
 "literal>"
 msgstr ""
-"<literal>sign()</literal>, <literal>trunc()</literal>, <literal>rtrim()</"
-"literal>, <literal>sin()</literal> のようなデータベースがサポートするSQLスカ"
-"ラ関数。"
+"<literal>sign()</literal>、 <literal>trunc()</literal>、 <literal>rtrim()</"
+"literal>、 <literal>sin()</literal> のようなデータベースがサポートする SQL ス"
+"カラ関数。"
 
 #. Tag: para
-#: query_hql.xml:650
 #, no-c-format
 msgid "JDBC-style positional parameters <literal>?</literal>"
-msgstr "JDBCスタイルの位置パラメータ <literal>?</literal>"
+msgstr "JDBC スタイルの位置パラメータ <literal>?</literal>"
 
 #. Tag: para
-#: query_hql.xml:655
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "named parameters <literal>:name</literal>, <literal>:start_date</literal>, "
 "and <literal>:x1</literal>"
@@ -1274,138 +851,76 @@
 "literal>, <literal>:x1</literal>"
 
 #. Tag: para
-#: query_hql.xml:660
 #, no-c-format
 msgid ""
 "SQL literals <literal>'foo'</literal>, <literal>69</literal>, <literal>6.66E"
 "+2</literal>, <literal>'1970-01-01 10:00:01.0'</literal>"
 msgstr ""
-"SQLリテラル:<literal>'foo'</literal>, <literal>69</literal>, <literal>6.66E"
-"+2</literal>, <literal>'1970-01-01 10:00:01.0'</literal>"
+"SQL リテラル: <literal>'foo'</literal>、 <literal>69</literal>、 "
+"<literal>6.66E+2</literal>、 <literal>'1970-01-01 10:00:01.0'</literal>"
 
 #. Tag: para
-#: query_hql.xml:666
 #, no-c-format
 msgid ""
 "Java <literal>public static final</literal> constants <literal>eg.Color."
 "TABBY</literal>"
 msgstr ""
-"Javaの <literal>public static final</literal> 定数:<literal>eg.Color.TABBY</"
-"literal>"
+"Java の <literal>public static final</literal> 定数: <literal>eg.Color."
+"TABBY</literal>"
 
 #. Tag: para
-#: query_hql.xml:672
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>in</literal> and <literal>between</literal> can be used as follows:"
 msgstr ""
 "<literal>in</literal> と <literal>between</literal> は以下のように使用できま"
-"す。:"
+"す:"
 
-#. Tag: programlisting
-#: query_hql.xml:676
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name between 'A' and 'B']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:678
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat cat where cat.name in ( 'Foo', 'Bar', 'Baz' )]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:680
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The negated forms can be written as follows:"
 msgstr "また、否定形で記述することもできます。"
 
-#. Tag: programlisting
-#: query_hql.xml:684
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name not between 'A' and 'B']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:686
-#, no-c-format
 msgid ""
-"<![CDATA[from DomesticCat cat where cat.name not in ( 'Foo', 'Bar', 'Baz' )]]"
-">"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:688
-#, fuzzy, no-c-format
-msgid ""
 "Similarly, <literal>is null</literal> and <literal>is not null</literal> can "
 "be used to test for null values."
 msgstr ""
-"同様に <literal>is null</literal> や <literal>is not null</literal> はnull値"
-"をテストするために使用できます。"
+"同様に <literal>is null</literal> や <literal>is not null</literal> は null "
+"値をテストするために使用できます。"
 
 #. Tag: para
-#: query_hql.xml:693
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Booleans can be easily used in expressions by declaring HQL query "
 "substitutions in Hibernate configuration:"
 msgstr ""
-"Hibernate設定ファイルでHQL query substitutionsを定義すれば、boolean値を式の中"
-"で簡単に使用できま。:"
+"Hibernate 設定ファイルで HQL query substitutions を定義すれば、 boolean 値を"
+"式の中で簡単に使用できます:"
 
-#. Tag: programlisting
-#: query_hql.xml:698
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"hibernate.query.substitutions\">true 1, false 0</"
-"property>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:700
 #, no-c-format
 msgid ""
 "This will replace the keywords <literal>true</literal> and <literal>false</"
 "literal> with the literals <literal>1</literal> and <literal>0</literal> in "
 "the translated SQL from this HQL:"
 msgstr ""
-"こうすることで下記のHQLをSQLに変換するときに <literal>true</literal> , "
-"<literal>false</literal> キーワードは <literal>1</literal> , <literal>0</"
-"literal> に置き換えられます。:"
+"こうすることで下記の HQL を SQL に変換するときに <literal>true</literal> 、 "
+"<literal>false</literal> キーワードは <literal>1</literal> 、 <literal>0</"
+"literal> に置き換えられます:"
 
-#. Tag: programlisting
-#: query_hql.xml:705
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.alive = true]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:707
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can test the size of a collection with the special property "
 "<literal>size</literal> or the special <literal>size()</literal> function."
 msgstr ""
 "特別なプロパティ <literal>size</literal>、または特別な関数 <literal>size()</"
-"literal> を使ってコレクションのサイズをテストできます。:"
+"literal> を使ってコレクションのサイズをテストできます:"
 
-#. Tag: programlisting
-#: query_hql.xml:712
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.kittens.size > 0]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:714
-#, no-c-format
-msgid "<![CDATA[from Cat cat where size(cat.kittens) > 0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:716
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For indexed collections, you can refer to the minimum and maximum indices "
 "using <literal>minindex</literal> and <literal>maxindex</literal> functions. "
@@ -1413,34 +928,14 @@
 "of basic type using the <literal>minelement</literal> and "
 "<literal>maxelement</literal> functions. For example:"
 msgstr ""
-"インデックス付きのコレクションでは、<literal>minindex</literal> と "
+"インデックス付きのコレクションでは、 <literal>minindex</literal> と "
 "<literal>maxindex</literal> 関数を使って、インデックスの最小値と最大値を参照"
-"できます。 同様に、<literal>minelement</literal> と <literal>maxelement</"
-"literal> を使って、 基本型のコレクション要素の最小値と最大値を参照できます。"
+"できます。同様に、 <literal>minelement</literal> と <literal>maxelement</"
+"literal> を使って、基本型のコレクション要素の最小値と最大値を参照できます。"
 
-#. Tag: programlisting
-#: query_hql.xml:724
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Calendar cal where maxelement(cal.holidays) > current_date]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:726
-#, no-c-format
-msgid "<![CDATA[from Order order where maxindex(order.items) > 100]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:728
-#, no-c-format
-msgid "<![CDATA[from Order order where minelement(order.items) > 10000]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:730
-#, fuzzy, no-c-format
-msgid ""
 "The SQL functions <literal>any, some, all, exists, in</literal> are "
 "supported when passed the element or index set of a collection "
 "(<literal>elements</literal> and <literal>indices</literal> functions) or "
@@ -1448,227 +943,83 @@
 msgstr ""
 "コレクションの要素やインデックスのセット(<literal>elements</literal> と "
 "<literal>indices</literal> 関数)、または副問い合わせ(後述)の結果が受け取れ"
-"るときは、 SQL関数 <literal>any, some, all, exists, in</literal> がサポートさ"
-"れます。"
+"るときは、 SQL 関数 <literal>any, some, all, exists, in</literal> がサポート"
+"されます。"
 
-#. Tag: programlisting
-#: query_hql.xml:736
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select mother from Cat as mother, Cat as kit\n"
-"where kit in elements(foo.kittens)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:738
-#, no-c-format
-msgid ""
-"<![CDATA[select p from NameList list, Person p\n"
-"where p.name = some elements(list.names)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:740
-#, no-c-format
-msgid "<![CDATA[from Cat cat where exists elements(cat.kittens)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:742
-#, no-c-format
-msgid "<![CDATA[from Player p where 3 > all elements(p.scores)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:744
-#, no-c-format
-msgid "<![CDATA[from Show show where 'fizard' in indices(show.acts)]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:746
-#, fuzzy, no-c-format
-msgid ""
 "Note that these constructs - <literal>size</literal>, <literal>elements</"
 "literal>, <literal>indices</literal>, <literal>minindex</literal>, "
 "<literal>maxindex</literal>, <literal>minelement</literal>, "
 "<literal>maxelement</literal> - can only be used in the where clause in "
 "Hibernate3."
 msgstr ""
-"<literal>size</literal>, <literal>elements</literal>, <literal>indices</"
-"literal>, <literal>minindex</literal>, <literal>maxindex</literal>, "
-"<literal>minelement</literal>, <literal>maxelement</literal> はHibernate3の"
-"where節だけで利用可能であることに注意してください。"
+"<literal>size</literal>、 <literal>elements</literal>、 <literal>indices</"
+"literal>、 <literal>minindex</literal>、 <literal>maxindex</literal>、 "
+"<literal>minelement</literal>、 <literal>maxelement</literal> は Hibernate3 "
+"の where 節だけで利用可能であることに注意してください。"
 
 #. Tag: para
-#: query_hql.xml:753
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Elements of indexed collections (arrays, lists, and maps) can be referred to "
 "by index in a where clause only:"
 msgstr ""
-"インデックス付きのコレクション(arrays, lists, maps)の要素は、 インデックス"
-"で参照できます(where節内でのみ)。"
+"インデックス付きのコレクション(arrays, lists, maps)の要素は、インデックスで"
+"参照できます(where節内でのみ):"
 
-#. Tag: programlisting
-#: query_hql.xml:758
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from Order order where order.items[0].id = 1234]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:760
-#, no-c-format
 msgid ""
-"<![CDATA[select person from Person person, Calendar calendar\n"
-"where calendar.holidays['national day'] = person.birthDay\n"
-"    and person.nationality.calendar = calendar]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:762
-#, no-c-format
-msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ order.deliveredItemIndices[0] ] = item and order.id = 11]]"
-">"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:764
-#, no-c-format
-msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ maxindex(order.items) ] = item and order.id = 11]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:766
-#, fuzzy, no-c-format
-msgid ""
 "The expression inside <literal>[]</literal> can even be an arithmetic "
 "expression:"
 msgstr "<literal>[]</literal> 内部の式は、算術式でも構いません。"
 
-#. Tag: programlisting
-#: query_hql.xml:770
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ size(order.items) - 1 ] = item]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:772
-#, fuzzy, no-c-format
-msgid ""
 "HQL also provides the built-in <literal>index()</literal> function for "
 "elements of a one-to-many association or collection of values."
 msgstr ""
-"一対多関連や値のコレクションの要素に対しては、HQLは組み込みの <literal>index"
-"()</literal> 関数も用意しています。"
+"一対多関連や値のコレクションの要素に対しては、 HQL は組み込みの "
+"<literal>index()</literal> 関数も用意しています。"
 
-#. Tag: programlisting
-#: query_hql.xml:777
-#, no-c-format
-msgid ""
-"<![CDATA[select item, index(item) from Order order\n"
-"    join order.items item\n"
-"where index(item) < 5]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:779
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Scalar SQL functions supported by the underlying database can be used:"
 msgstr ""
-"ベースとなるデータベースがサポートしているスカラーSQL関数が使用できます"
+"ベースとなるデータベースがサポートしているスカラー SQL 関数が使用できます:"
 
-#. Tag: programlisting
-#: query_hql.xml:783
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where upper(cat.name) like 'FRI%']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:785
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Consider how much longer and less readable the following query would be in "
 "SQL:"
 msgstr ""
-"もしまだ全てを理解していないなら、下のクエリをSQLでどれだけ長く、読みづらく出"
-"来るか考えてください。:"
+"もしまだ全てを理解していないなら、下のクエリを SQL でどれだけ長く、読みづらく"
+"出来るか考えてください:"
 
-#. Tag: programlisting
-#: query_hql.xml:790
-#, no-c-format
-msgid ""
-"<![CDATA[select cust\n"
-"from Product prod,\n"
-"    Store store\n"
-"    inner join store.customers cust\n"
-"where prod.name = 'widget'\n"
-"    and store.location.name in ( 'Melbourne', 'Sydney' )\n"
-"    and prod = all elements(cust.currentOrder.lineItems)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:792
 #, no-c-format
 msgid "<emphasis>Hint:</emphasis> something like"
 msgstr "<emphasis>ヒント:</emphasis> 例えばこのように出来ます。"
 
-#. Tag: programlisting
-#: query_hql.xml:796
-#, no-c-format
-msgid ""
-"<![CDATA[SELECT cust.name, cust.address, cust.phone, cust.id, cust."
-"current_order\n"
-"FROM customers cust,\n"
-"    stores store,\n"
-"    locations loc,\n"
-"    store_customers sc,\n"
-"    product prod\n"
-"WHERE prod.name = 'widget'\n"
-"    AND store.loc_id = loc.id\n"
-"    AND loc.name IN ( 'Melbourne', 'Sydney' )\n"
-"    AND sc.store_id = store.id\n"
-"    AND sc.cust_id = cust.id\n"
-"    AND prod.id = ALL(\n"
-"        SELECT item.prod_id\n"
-"        FROM line_items item, orders o\n"
-"        WHERE item.order_id = o.id\n"
-"            AND cust.current_order = o.id\n"
-"    )]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:801
 #, no-c-format
 msgid "The order by clause"
-msgstr "order by節"
+msgstr "order by 節"
 
 #. Tag: para
-#: query_hql.xml:803
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The list returned by a query can be ordered by any property of a returned "
 "class or components:"
 msgstr ""
-"クエリが返すlistは、返されるクラスやコンポーネントの任意の属性によって並べ替"
-"えられます。:"
+"クエリが返す list は、返されるクラスやコンポーネントの任意の属性によって並べ"
+"替えられます:"
 
-#. Tag: programlisting
-#: query_hql.xml:807
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat cat\n"
-"order by cat.name asc, cat.weight desc, cat.birthdate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:809
 #, no-c-format
 msgid ""
 "The optional <literal>asc</literal> or <literal>desc</literal> indicate "
@@ -1678,104 +1029,57 @@
 "か降順の整列を示します。"
 
 #. Tag: title
-#: query_hql.xml:816
 #, no-c-format
 msgid "The group by clause"
-msgstr "group by節"
+msgstr "group by 節"
 
 #. Tag: para
-#: query_hql.xml:818
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A query that returns aggregate values can be grouped by any property of a "
 "returned class or components:"
 msgstr ""
 "集約値を返すクエリは、返されるクラスやコンポーネントの任意のプロパティによっ"
-"てグループ化できます。:"
+"てグループ化できます:"
 
-#. Tag: programlisting
-#: query_hql.xml:822
-#, no-c-format
-msgid ""
-"<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
-"from Cat cat\n"
-"group by cat.color]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:824
-#, no-c-format
-msgid ""
-"<![CDATA[select foo.id, avg(name), max(name)\n"
-"from Foo foo join foo.names name\n"
-"group by foo.id]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:826
 #, no-c-format
 msgid "A <literal>having</literal> clause is also allowed."
 msgstr "<literal>having</literal> 節も使えます。"
 
-#. Tag: programlisting
-#: query_hql.xml:830
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
-"from Cat cat\n"
-"group by cat.color\n"
-"having cat.color in (eg.Color.TABBY, eg.Color.BLACK)]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:832
-#, fuzzy, no-c-format
-msgid ""
 "SQL functions and aggregate functions are allowed in the <literal>having</"
 "literal> and <literal>order by</literal> clauses if they are supported by "
 "the underlying database (i.e., not in MySQL)."
 msgstr ""
 "もし使用するデータベースがサポートしているなら、 <literal>having</literal> "
-"と <literal>order by</literal> 節でSQL関数と集約関数が使えます (例えばMySQL"
-"にはありません)。"
+"と <literal>order by</literal> 節で SQL 関数と集約関数が使えます(例えば "
+"MySQL にはありません)。"
 
-#. Tag: programlisting
-#: query_hql.xml:838
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat\n"
-"from Cat cat\n"
-"    join cat.kittens kitten\n"
-"group by cat.id, cat.name, cat.other, cat.properties\n"
-"having avg(kitten.weight) > 100\n"
-"order by count(kitten) asc, sum(kitten.weight) desc]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:840
-#, fuzzy, no-c-format
-msgid ""
 "Neither the <literal>group by</literal> clause nor the <literal>order by</"
 "literal> clause can contain arithmetic expressions. Hibernate also does not "
 "currently expand a grouped entity, so you cannot write <literal>group by "
 "cat</literal> if all properties of <literal>cat</literal> are non-"
 "aggregated. You have to list all non-aggregated properties explicitly."
 msgstr ""
-"Note that neither the <literal>group by</literal> clause nor the "
-"<literal>order by</literal> clause may contain arithmetic expressions. Also "
-"note that Hibernate currently does not expand a grouped entity, so you can't "
-"write <literal>group by cat</literal> if all properties of <literal>cat</"
-"literal> are non-aggregated. You have to list all non-aggregated properties "
-"explicitly."
+"<literal>group by</literal> 節や <literal>order by</literal> 節に算術式を含む"
+"ことができないことに注意してください。また、  Hibernate は今のところグループ"
+"エンティティを拡張しないことにも注意してください。したがって、もし "
+"<literal>cat</literal> の全てのプロパティが非集合体の場合、 <literal>group "
+"by cat</literal> を書くことはできません。全ての非集合体のプロパティを明示的に"
+"リストする必要があります。"
 
 #. Tag: title
-#: query_hql.xml:852
 #, no-c-format
 msgid "Subqueries"
 msgstr "副問い合わせ"
 
 #. Tag: para
-#: query_hql.xml:854
 #, no-c-format
 msgid ""
 "For databases that support subselects, Hibernate supports subqueries within "
@@ -1783,85 +1087,36 @@
 "aggregate function call). Even correlated subqueries (subqueries that refer "
 "to an alias in the outer query) are allowed."
 msgstr ""
-"サブセレクトをサポートするデータベースのため、Hibernateは副問い合わせをサポー"
-"トしています。 副問い合わせは括弧で囲まなければなりません(SQLの集約関数呼び"
-"出しによる事が多いです)。 関連副問い合わせ(外部クエリ中の別名を参照する副問"
-"い合わせのこと)さえ許可されます。"
+"サブセレクトをサポートするデータベースのため、 Hibernate は副問い合わせをサ"
+"ポートしています。副問い合わせは括弧で囲まなければなりません( SQL の集約関数"
+"呼び出しによる事が多いです)。関連副問い合わせ (外部クエリ中の別名を参照する"
+"副問い合わせのこと) さえ許可されます。"
 
-#. Tag: programlisting
-#: query_hql.xml:860
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as fatcat\n"
-"where fatcat.weight > (\n"
-"    select avg(cat.weight) from DomesticCat cat\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:862
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat as cat\n"
-"where cat.name = some (\n"
-"    select name.nickName from Name as name\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:864
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"where not exists (\n"
-"    from Cat as mate where mate.mate = cat\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:866
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat as cat\n"
-"where cat.name not in (\n"
-"    select name.nickName from Name as name\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:868
-#, no-c-format
-msgid ""
-"<![CDATA[select cat.id, (select max(kit.weight) from cat.kitten kit)\n"
-"from Cat as cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:870
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Note that HQL subqueries can occur only in the select or where clauses."
 msgstr ""
-"HQL副問い合わせは、selectまたはwhere節だけで使われることに注意してください。"
+"HQL 副問い合わせは、 select または where 節だけで使われることに注意してくださ"
+"い。"
 
 #. Tag: para
-#: query_hql.xml:874
 #, fuzzy, no-c-format
 msgid ""
 "Note that subqueries can also utilize <literal>row value constructor</"
-"literal> syntax. See <xref linkend=\"queryhql-tuple\"/> for more information."
+"literal> syntax. See <xref linkend=\"queryhql-tuple\" /> for more "
+"information."
 msgstr ""
-"Note that subqueries can also utilize <literal>row value constructor</"
-"literal> syntax. See <xref linkend=\"queryhql-tuple\"/> for more details."
+"サブクエリは <literal>row value constructor</literal> 構文も使用できることを"
+"覚えておいてください。詳細については <xref linkend=\"queryhql-tuple\"/> を参"
+"照してください。"
 
 #. Tag: title
-#: query_hql.xml:882
 #, no-c-format
 msgid "HQL examples"
-msgstr "HQLの例"
+msgstr "HQL の例"
 
 #. Tag: para
-#: query_hql.xml:884
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate queries can be quite powerful and complex. In fact, the power of "
 "the query language is one of Hibernate's main strengths. The following "
@@ -1869,14 +1124,13 @@
 "projects. Please note that most queries you will write will be much simpler "
 "than the following examples."
 msgstr ""
-"Hibernateクエリは非常に強力で複雑にできます。実際、クエリ言語の威力は"
-"Hibernateの主要なセールスポイントの一つです。 ここに最近のプロジェクトで使用"
-"したクエリと非常によく似た例があります。 ほとんどのクエリはこれらの例より簡単"
-"に記述できることに注意してください!"
+"Hibernate クエリは非常に強力で複雑にできます。実際、クエリ言語の威力は "
+"Hibernate の主要なセールスポイントの一つです。ここに最近のプロジェクトで使用"
+"したクエリと非常によく似た例があります。ほとんどのクエリはこれらの例より簡単"
+"に記述できることに注意してください。"
 
 #. Tag: para
-#: query_hql.xml:890
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following query returns the order id, number of items, the given minimum "
 "total value and the total value of the order for all unpaid orders for a "
@@ -1886,68 +1140,23 @@
 "<literal>PRODUCT</literal>, <literal>CATALOG</literal> and <literal>PRICE</"
 "literal> tables has four inner joins and an (uncorrelated) subselect."
 msgstr ""
-"以下のクエリは特定の顧客と与えられた最小の合計値に対する未払い注文の注文ID、 "
-"商品の数、注文の合計を合計値で整列して返します。 価格を決定する際、現在のカタ"
-"ログを使います。結果として返されるSQLクエリは <literal>ORDER</literal>, "
-"<literal>ORDER_LINE</literal>, <literal>PRODUCT</literal>, <literal>CATALOG</"
-"literal> および <literal>PRICE</literal> テーブルに対し4つの内部結合と (関連"
-"しない)副問い合わせを持ちます。"
+"以下のクエリは特定の顧客と与えられた最小の合計値に対する未払い注文の注文 "
+"ID 、商品の数、注文の合計を合計値で整列して返します。価格を決定する際、現在の"
+"カタログを使います。結果として返される SQL クエリは <literal>ORDER</"
+"literal>、 <literal>ORDER_LINE</literal>、 <literal>PRODUCT</literal>、 "
+"<literal>CATALOG</literal> および <literal>PRICE</literal> テーブルに対し4つ"
+"の内部結合と (関連しない) 副問い合わせを持ちます。"
 
-#. Tag: programlisting
-#: query_hql.xml:899
-#, no-c-format
-msgid ""
-"<![CDATA[select order.id, sum(price.amount), count(item)\n"
-"from Order as order\n"
-"    join order.lineItems as item\n"
-"    join item.product as product,\n"
-"    Catalog as catalog\n"
-"    join catalog.prices as price\n"
-"where order.paid = false\n"
-"    and order.customer = :customer\n"
-"    and price.product = product\n"
-"    and catalog.effectiveDate < sysdate\n"
-"    and catalog.effectiveDate >= all (\n"
-"        select cat.effectiveDate\n"
-"        from Catalog as cat\n"
-"        where cat.effectiveDate < sysdate\n"
-"    )\n"
-"group by order\n"
-"having sum(price.amount) > :minAmount\n"
-"order by sum(price.amount) desc]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:901
 #, no-c-format
 msgid ""
 "What a monster! Actually, in real life, I'm not very keen on subqueries, so "
 "my query was really more like this:"
 msgstr ""
-"何て巨大なクエリなのでしょう! 普段私は副問い合わせをあまり使いません。した"
+"何て巨大なクエリなのでしょう。普段私は副問い合わせをあまり使いません。した"
 "がって私のクエリは実際には以下のようになります。:"
 
-#. Tag: programlisting
-#: query_hql.xml:906
-#, no-c-format
-msgid ""
-"<![CDATA[select order.id, sum(price.amount), count(item)\n"
-"from Order as order\n"
-"    join order.lineItems as item\n"
-"    join item.product as product,\n"
-"    Catalog as catalog\n"
-"    join catalog.prices as price\n"
-"where order.paid = false\n"
-"    and order.customer = :customer\n"
-"    and price.product = product\n"
-"    and catalog = :currentCatalog\n"
-"group by order\n"
-"having sum(price.amount) > :minAmount\n"
-"order by sum(price.amount) desc]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:908
 #, no-c-format
 msgid ""
 "The next query counts the number of payments in each status, excluding all "
@@ -1958,58 +1167,21 @@
 "<literal>PAYMENT_STATUS_CHANGE</literal> tables."
 msgstr ""
 "次のクエリは各ステータスの支払い数を数えます。ただしすべての支払いが現在の利"
-"用者による 最新のステータス変更である <literal>AWAITING_APPROVAL</literal> で"
-"ある場合を除きます。 このクエリは2つの内部結合と <literal>PAYMENT</literal>, "
+"用者による最新のステータス変更である <literal>AWAITING_APPROVAL</literal> で"
+"ある場合を除きます。このクエリは2つの内部結合と <literal>PAYMENT</literal>, "
 "<literal>PAYMENT_STATUS</literal> および <literal>PAYMENT_STATUS_CHANGE</"
-"literal> テーブルに対する関連副問い合わせを備えたSQLクエリに変換されます。"
+"literal> テーブルに対する関連副問い合わせを備えた SQL クエリに変換されます。"
 
-#. Tag: programlisting
-#: query_hql.xml:916
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select count(payment), status.name\n"
-"from Payment as payment\n"
-"    join payment.currentStatus as status\n"
-"    join payment.statusChanges as statusChange\n"
-"where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-"    or (\n"
-"        statusChange.timeStamp = (\n"
-"            select max(change.timeStamp)\n"
-"            from PaymentStatusChange change\n"
-"            where change.payment = payment\n"
-"        )\n"
-"        and statusChange.user <> :currentUser\n"
-"    )\n"
-"group by status.name, status.sortOrder\n"
-"order by status.sortOrder]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:918
-#, fuzzy, no-c-format
-msgid ""
 "If the <literal>statusChanges</literal> collection was mapped as a list, "
 "instead of a set, the query would have been much simpler to write."
 msgstr ""
-"もし私がsetの代わりにlistとして <literal>statusChanges</literal> コレクション"
-"を マッピングしたならば、はるかに簡単にクエリを記述できるでしょう。"
+"もし set の代わりに list として <literal>statusChanges</literal> コレクション"
+"をマッピングしたならば、はるかに簡単にクエリを記述できるでしょう。"
 
-#. Tag: programlisting
-#: query_hql.xml:923
-#, no-c-format
-msgid ""
-"<![CDATA[select count(payment), status.name\n"
-"from Payment as payment\n"
-"    join payment.currentStatus as status\n"
-"where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-"    or payment.statusChanges[ maxIndex(payment.statusChanges) ].user <> :"
-"currentUser\n"
-"group by status.name, status.sortOrder\n"
-"order by status.sortOrder]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:925
 #, no-c-format
 msgid ""
 "The next query uses the MS SQL Server <literal>isNull()</literal> function "
@@ -2020,314 +1192,150 @@
 "<literal>ACCOUNT_TYPE</literal>, <literal>ORGANIZATION</literal> and "
 "<literal>ORG_USER</literal> tables."
 msgstr ""
-"次のクエリは現在のユーザが所属する組織に対するアカウントおよび未払いの支払い"
-"を すべて返すMS SQL Server の <literal>isNull()</literal> 関数を使用していま"
-"す。 このクエリは3つの内部結合と1つの外部結合 、 そして <literal>ACCOUNT</"
-"literal>, <literal>PAYMENT</literal>, <literal>PAYMENT_STATUS</literal>, "
-"<literal>ACCOUNT_TYPE</literal>, <literal>ORGANIZATION</literal> および "
-"<literal>ORG_USER</literal> テーブルに対する副問い合わせ持ったSQLに変換されま"
-"す。"
+"次のクエリは現在のユーザーが所属する組織に対するアカウントおよび未払いの支払"
+"いをすべて返す MS SQL Server の <literal>isNull()</literal> 関数を使用してい"
+"ます。このクエリは3つの内部結合と1つの外部結合、そして <literal>ACCOUNT</"
+"literal>、 <literal>PAYMENT</literal>、 <literal>PAYMENT_STATUS</literal>、 "
+"<literal>ACCOUNT_TYPE</literal>、 <literal>ORGANIZATION</literal> および "
+"<literal>ORG_USER</literal> テーブルに対する副問い合わせ持った SQL に変換され"
+"ます。"
 
-#. Tag: programlisting
-#: query_hql.xml:934
-#, no-c-format
-msgid ""
-"<![CDATA[select account, payment\n"
-"from Account as account\n"
-"    left outer join account.payments as payment\n"
-"where :currentUser in elements(account.holder.users)\n"
-"    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
-"PaymentStatus.UNPAID)\n"
-"order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:936
 #, no-c-format
 msgid ""
 "For some databases, we would need to do away with the (correlated) subselect."
 msgstr ""
-"いくつかのデータベースについては、(関連させられた)副問い合わせの使用を避ける"
-"必要があるでしょう。"
+"いくつかのデータベースについては、 (関連させられた) 副問い合わせの使用を避け"
+"る必要があるでしょう。"
 
-#. Tag: programlisting
-#: query_hql.xml:940
-#, no-c-format
-msgid ""
-"<![CDATA[select account, payment\n"
-"from Account as account\n"
-"    join account.holder.users as user\n"
-"    left outer join account.payments as payment\n"
-"where :currentUser = user\n"
-"    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
-"PaymentStatus.UNPAID)\n"
-"order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:945
 #, no-c-format
 msgid "Bulk update and delete"
-msgstr "大量のUPDATEとDELETE"
+msgstr "大量の UPDATE と DELETE"
 
 #. Tag: para
-#: query_hql.xml:947
 #, fuzzy, no-c-format
 msgid ""
 "HQL now supports <literal>update</literal>, <literal>delete</literal> and "
 "<literal>insert ... select ...</literal> statements. See <xref linkend="
-"\"batch-direct\"/> for more information."
+"\"batch-direct\" /> for more information."
 msgstr ""
-"HQLは今は <literal>update</literal> と <literal>delete</literal>、"
-"<literal>insert ... select ...</literal> ステートメントをHQLに入れることをサ"
-"ポートしています。 <xref linkend=\"batch-direct\"/> に詳細があります。"
+"HQL は現在 <literal>update</literal> と <literal>delete</literal>、 "
+"<literal>insert ... select ...</literal> ステートメントをサポートしています。"
+"詳細については <xref linkend=\"batch-direct\"/> を参照ください。"
 
 #. Tag: title
-#: query_hql.xml:955
 #, no-c-format
 msgid "Tips &amp; Tricks"
 msgstr "Tips &amp; Tricks"
 
 #. Tag: para
-#: query_hql.xml:957
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can count the number of query results without returning them:"
-msgstr "実際に結果を返さなくてもクエリの結果数を数えることができます。:"
+msgstr "実際に結果を返さなくてもクエリの結果数を数えることができます:"
 
-#. Tag: programlisting
-#: query_hql.xml:961
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
-"iterate().next() ).intValue()]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:963
 #, no-c-format
 msgid "To order a result by the size of a collection, use the following query:"
 msgstr ""
-"コレクションのサイズにより結果を並べ替えるためには以下のクエリを使用します。:"
+"コレクションのサイズにより結果を並べ替えるためには以下のクエリを使用します:"
 
-#. Tag: programlisting
-#: query_hql.xml:967
-#, no-c-format
-msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User as usr\n"
-"    left join usr.messages as msg\n"
-"group by usr.id, usr.name\n"
-"order by count(msg)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:969
 #, no-c-format
 msgid ""
 "If your database supports subselects, you can place a condition upon "
 "selection size in the where clause of your query:"
 msgstr ""
-"使用しているデータベースがサブセレクトをサポートする場合、クエリのwhere節でサ"
-"イズによる選択条件を設定できます:"
+"使用しているデータベースがサブセレクトをサポートする場合、クエリの where 節で"
+"サイズによる選択条件を設定できます:"
 
-#. Tag: programlisting
-#: query_hql.xml:974
-#, no-c-format
-msgid "<![CDATA[from User usr where size(usr.messages) >= 1]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:976
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "If your database does not support subselects, use the following query:"
 msgstr ""
 "使用しているデータベースがサブセレクトをサポートしない場合は、次のクエリを使"
 "用してください:"
 
-#. Tag: programlisting
-#: query_hql.xml:980
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User usr.name\n"
-"    join usr.messages msg\n"
-"group by usr.id, usr.name\n"
-"having count(msg) >= 1]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:983
-#, fuzzy, no-c-format
-msgid ""
 "As this solution cannot return a <literal>User</literal> with zero messages "
 "because of the inner join, the following form is also useful:"
 msgstr ""
-"内部結合をしているせいで上の解決法がmessageの件数が ゼロの <literal>User</"
-"literal> を返すことができないならば、以下の形式が使えます。"
+"内部結合をしているせいで上の解決法が message の件数がゼロの <literal>User</"
+"literal> を返すことができないならば、以下の形式が使えます:"
 
-#. Tag: programlisting
-#: query_hql.xml:988
-#, no-c-format
-msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User as usr\n"
-"    left join usr.messages as msg\n"
-"group by usr.id, usr.name\n"
-"having count(msg) = 0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:990
 #, no-c-format
 msgid "Properties of a JavaBean can be bound to named query parameters:"
 msgstr ""
-"JavaBeanのプロパティは、名前付きのクエリパラメータに結びつけることが出来ま"
-"す。:"
+"JavaBean のプロパティは、名前付きのクエリパラメータに結びつけることが出来ま"
+"す:"
 
-#. Tag: programlisting
-#: query_hql.xml:994
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = s.createQuery(\"from foo Foo as foo where foo.name=:name "
-"and foo.size=:size\");\n"
-"q.setProperties(fooBean); // fooBean has getName() and getSize()\n"
-"List foos = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:996
 #, no-c-format
 msgid ""
 "Collections are pageable by using the <literal>Query</literal> interface "
 "with a filter:"
 msgstr ""
-"コレクションはフィルタ付き <literal>Query</literal> インターフェイスを使用す"
-"ることでページをつけることができます。:"
+"コレクションはフィルタ付き <literal>Query</literal> インターフェースを使用す"
+"ることでページをつけることができます:"
 
-#. Tag: programlisting
-#: query_hql.xml:1000
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = s.createFilter( collection, \"\" ); // the trivial "
-"filter\n"
-"q.setMaxResults(PAGE_SIZE);\n"
-"q.setFirstResult(PAGE_SIZE * pageNumber);\n"
-"List page = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1002
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Collection elements can be ordered or grouped using a query filter:"
 msgstr ""
-"コレクションの要素はクエリフィルタを使って、並べ替えやグループ分けが出来ま"
-"す。:"
+"コレクションの要素はクエリフィルタを使って、並べ替えやグループ分けが出来ます:"
 
-#. Tag: programlisting
-#: query_hql.xml:1006
-#, no-c-format
-msgid ""
-"<![CDATA[Collection orderedCollection = s.filter( collection, \"order by "
-"this.amount\" );\n"
-"Collection counts = s.filter( collection, \"select this.type, count(this) "
-"group by this.type\" );]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1008
 #, no-c-format
 msgid "You can find the size of a collection without initializing it:"
-msgstr "コレクションを初期化せずにコレクションのサイズを得ることができます。:"
+msgstr "コレクションを初期化せずにコレクションのサイズを得ることができます:"
 
-#. Tag: programlisting
-#: query_hql.xml:1012
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
-"iterate().next() ).intValue();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:1017
 #, no-c-format
 msgid "Components"
-msgstr "translator-credits"
+msgstr "コンポーネント"
 
 #. Tag: para
-#: query_hql.xml:1019
 #, no-c-format
 msgid ""
 "Components can be used similarly to the simple value types that are used in "
 "HQL queries. They can appear in the <literal>select</literal> clause as "
 "follows:"
 msgstr ""
+"HQL クエリでシンプルな値型を使用できるので、コンポーネントは、あらゆる点で使"
+"用できます。これは <literal>select</literal> 節の中に現われます:"
 
-#. Tag: programlisting
-#: query_hql.xml:1024 query_hql.xml:1070
-#, no-c-format
-msgid "<![CDATA[select p.name from Person p]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1025
-#, no-c-format
-msgid "<![CDATA[select p.name.first from Person p]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1027
 #, no-c-format
 msgid ""
 "where the Person's name property is a component. Components can also be used "
 "in the <literal>where</literal> clause:"
 msgstr ""
+"人名のプロパティがコンポーネントの場所。コンポーネントは、 <literal>where</"
+"literal> 節でも使用可能です:"
 
-#. Tag: programlisting
-#: query_hql.xml:1032
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name = :name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1033
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name.first = :firstName]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1035
 #, no-c-format
 msgid "Components can also be used in the <literal>order by</literal> clause:"
-msgstr ""
+msgstr "コンポーネントは <literal>order by</literal> 節でも使用可能です:"
 
-#. Tag: programlisting
-#: query_hql.xml:1039
-#, no-c-format
-msgid "<![CDATA[from Person p order by p.name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1040
-#, no-c-format
-msgid "<![CDATA[from Person p order by p.name.first]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1042
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Another common use of components is in <link linkend=\"queryhql-tuple\">row "
 "value constructors</link>."
 msgstr ""
+"コンポーネントの他の一般的な使用は、 <xref linkend=\"queryhql-tuple\"/> 行値"
+"コンストラクタにあります。"
 
 #. Tag: title
-#: query_hql.xml:1048
 #, no-c-format
 msgid "Row value constructor syntax"
-msgstr ""
+msgstr "行値コンストラクタ構文"
 
 #. Tag: para
-#: query_hql.xml:1050
 #, no-c-format
 msgid ""
 "HQL supports the use of ANSI SQL <literal>row value constructor</literal> "
@@ -2336,71 +1344,983 @@
 "generally referring to multi-valued comparisons, typically associated with "
 "components. Consider an entity Person which defines a name component:"
 msgstr ""
+"下に位置するデータベースが ANSI SQL <literal>row value constructor</literal> "
+"構文 (<literal>tuple</literal> 構文とよばれることもあります) をサポートしてい"
+"ないとしても、 HQL はその使用をサポートしています。ここでは、一般的にコンポー"
+"ネントと連繋するマルチバリュー比較について触れます。ネームコンポーネントを定"
+"義する Person エンティティを考えましょう:"
 
-#. Tag: programlisting
-#: query_hql.xml:1057
-#, no-c-format
-msgid ""
-"<![CDATA[from Person p where p.name.first='John' and p.name."
-"last='Jingleheimer-Schmidt']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1059
 #, no-c-format
 msgid ""
 "That is valid syntax although it is a little verbose. You can make this more "
 "concise by using <literal>row value constructor</literal> syntax:"
 msgstr ""
+"それは少々詳細になりますが、有効な構文です。より簡潔にし、 <literal>row "
+"value constructor</literal> 構文を使用するのがよいでしょう:"
 
-#. Tag: programlisting
-#: query_hql.xml:1064
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name=('John', 'Jingleheimer-Schmidt')]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1066
 #, no-c-format
 msgid ""
 "It can also be useful to specify this in the <literal>select</literal> "
 "clause:"
-msgstr ""
+msgstr "それを <literal>select</literal> 節で指定するのも効果的です。"
 
 #. Tag: para
-#: query_hql.xml:1072
 #, no-c-format
 msgid ""
 "Using <literal>row value constructor</literal> syntax can also be beneficial "
 "when using subqueries that need to compare against multiple values:"
 msgstr ""
+"次に <literal>row value constructor</literal> 構文の使用が有効なときは、サブ"
+"クエリを使用して複数の値と比較する必要があるときです:"
 
-#. Tag: programlisting
-#: query_hql.xml:1077
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"where not ( cat.name, cat.color ) in (\n"
-"    select cat.name, cat.color from DomesticCat cat\n"
-")]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1079
 #, no-c-format
 msgid ""
 "One thing to consider when deciding if you want to use this syntax, is that "
 "the query will be dependent upon the ordering of the component sub-"
 "properties in the metadata."
 msgstr ""
+"この構文を使用するかどうか決定するときに考慮しなければならないことは、クエリ"
+"がメタデータ内のコンポーネントのサブプロパティの順番に依存していることです。"
 
+#, fuzzy
+#~ msgid "<![CDATA[from eg.Cat]]>"
+#~ msgstr "from eg.Cat"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat]]>"
+#~ msgstr "from eg.Cat"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat as cat]]>"
+#~ msgstr "from Cat as cat"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat]]>"
+#~ msgstr "from Cat cat"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Formula, Parameter]]>"
+#~ msgstr "from Formula, Parameter"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Formula as form, Parameter as param]]>"
+#~ msgstr "from Formula as form, Parameter as param"
+
+#, fuzzy
 #~ msgid ""
-#~ "Most of the time, you will need to assign an <emphasis>alias</emphasis>, "
-#~ "since you will want to refer to the <literal>Cat</literal> in other parts "
-#~ "of the query."
+#~ "<![CDATA[from Cat as cat\n"
+#~ "    inner join cat.mate as mate\n"
+#~ "    left outer join cat.kittens as kitten]]>"
 #~ msgstr ""
-#~ "ほとんどの場合クエリのほかの部分で <literal>Cat</literal> を参照するの"
-#~ "で、別名を割り当てる必要があるでしょう。"
+#~ "from Cat as cat\n"
+#~ "    inner join cat.mate as mate\n"
+#~ "    left outer join cat.kittens as kitten"
 
-#~ msgid "or as an actual typesafe Java object,"
-#~ msgstr "または、タイプセーフなJavaオブジェクトを返せます。"
+#, fuzzy
+#~ msgid "<![CDATA[from Cat as cat left join cat.mate.kittens as kittens]]>"
+#~ msgstr "from Cat as cat left join cat.mate.kittens as kittens"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Formula form full join form.parameter param]]>"
+#~ msgstr "from Formula form full join form.parameter param"
+
+#~ msgid "inner join"
+#~ msgstr "inner join"
+
+#~ msgid "left outer join"
+#~ msgstr "left outer join"
+
+#, fuzzy
+#~ msgid "right outer join"
+#~ msgstr "left outer join"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as cat\n"
+#~ "    join cat.mate as mate\n"
+#~ "    left join cat.kittens as kitten]]>"
+#~ msgstr ""
+#~ "from Cat as cat\n"
+#~ "    join cat.mate as mate\n"
+#~ "    left join cat.kittens as kitten"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as cat\n"
+#~ "    left join cat.kittens as kitten\n"
+#~ "        with kitten.bodyWeight > 10.0]]>"
+#~ msgstr ""
+#~ "from Cat as cat\n"
+#~ "    left join cat.kittens as kitten\n"
+#~ "        with kitten.bodyWeight &gt; 10.0"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as cat\n"
+#~ "    inner join fetch cat.mate\n"
+#~ "    left join fetch cat.kittens]]>"
+#~ msgstr ""
+#~ "from Cat as cat\n"
+#~ "    inner join fetch cat.mate\n"
+#~ "    left join fetch cat.kittens"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as cat\n"
+#~ "    inner join fetch cat.mate\n"
+#~ "    left join fetch cat.kittens child\n"
+#~ "    left join fetch child.kittens]]>"
+#~ msgstr ""
+#~ "from Cat as cat\n"
+#~ "    inner join fetch cat.mate\n"
+#~ "    left join fetch cat.kittens child\n"
+#~ "    left join fetch child.kittens"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Document fetch all properties order by name]]>"
+#~ msgstr "from Document fetch all properties order by name"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Document doc fetch all properties where lower(doc.name) "
+#~ "like '%cats%']]>"
+#~ msgstr ""
+#~ "from Document doc fetch all properties where lower(doc.name) like '&#37;"
+#~ "cats&#37;'"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat as cat where cat.mate.name like '%s%']]>"
+#~ msgstr "from Cat as cat where cat.mate.name like '&#37;s&#37;'"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select mate\n"
+#~ "from Cat as cat\n"
+#~ "    inner join cat.mate as mate]]>"
+#~ msgstr ""
+#~ "select mate\n"
+#~ "from Cat as cat\n"
+#~ "    inner join cat.mate as mate"
+
+#, fuzzy
+#~ msgid "<![CDATA[select cat.mate from Cat cat]]>"
+#~ msgstr "select cat.mate from Cat cat"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cat.name from DomesticCat cat\n"
+#~ "where cat.name like 'fri%']]>"
+#~ msgstr ""
+#~ "select cat.name from DomesticCat cat\n"
+#~ "where cat.name like 'fri&#37;'"
+
+#, fuzzy
+#~ msgid "<![CDATA[select cust.name.firstName from Customer as cust]]>"
+#~ msgstr "select cust.name.firstName from Customer as cust"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select mother, offspr, mate.name\n"
+#~ "from DomesticCat as mother\n"
+#~ "    inner join mother.mate as mate\n"
+#~ "    left outer join mother.kittens as offspr]]>"
+#~ msgstr ""
+#~ "select mother, offspr, mate.name\n"
+#~ "from DomesticCat as mother\n"
+#~ "    inner join mother.mate as mate\n"
+#~ "    left outer join mother.kittens as offspr"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select new list(mother, offspr, mate.name)\n"
+#~ "from DomesticCat as mother\n"
+#~ "    inner join mother.mate as mate\n"
+#~ "    left outer join mother.kittens as offspr]]>"
+#~ msgstr ""
+#~ "select new list(mother, offspr, mate.name)\n"
+#~ "from DomesticCat as mother\n"
+#~ "    inner join mother.mate as mate\n"
+#~ "    left outer join mother.kittens as offspr"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select new Family(mother, mate, offspr)\n"
+#~ "from DomesticCat as mother\n"
+#~ "    join mother.mate as mate\n"
+#~ "    left join mother.kittens as offspr]]>"
+#~ msgstr ""
+#~ "select new Family(mother, mate, offspr)\n"
+#~ "from DomesticCat as mother\n"
+#~ "    join mother.mate as mate\n"
+#~ "    left join mother.kittens as offspr"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select max(bodyWeight) as max, min(bodyWeight) as min, count(*) "
+#~ "as n\n"
+#~ "from Cat cat]]>"
+#~ msgstr ""
+#~ "select max(bodyWeight) as max, min(bodyWeight) as min, count(*) as n\n"
+#~ "from Cat cat"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select new map( max(bodyWeight) as max, min(bodyWeight) as min, "
+#~ "count(*) as n )\n"
+#~ "from Cat cat]]>"
+#~ msgstr ""
+#~ "select new map( max(bodyWeight) as max, min(bodyWeight) as min, count(*) "
+#~ "as n )\n"
+#~ "from Cat cat"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select avg(cat.weight), sum(cat.weight), max(cat.weight), count"
+#~ "(cat)\n"
+#~ "from Cat cat]]>"
+#~ msgstr ""
+#~ "select avg(cat.weight), sum(cat.weight), max(cat.weight), count(cat)\n"
+#~ "from Cat cat"
+
+#~ msgid "count(*)"
+#~ msgstr "count(*)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cat.weight + sum(kitten.weight)\n"
+#~ "from Cat cat\n"
+#~ "    join cat.kittens kitten\n"
+#~ "group by cat.id, cat.weight]]>"
+#~ msgstr ""
+#~ "select cat.weight + sum(kitten.weight)\n"
+#~ "from Cat cat\n"
+#~ "    join cat.kittens kitten\n"
+#~ "group by cat.id, cat.weight"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select firstName||' '||initial||' '||upper(lastName) from "
+#~ "Person]]>"
+#~ msgstr "select firstName||' '||initial||' '||upper(lastName) from Person"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select distinct cat.name from Cat cat\n"
+#~ "\n"
+#~ "select count(distinct cat.name), count(cat) from Cat cat]]>"
+#~ msgstr ""
+#~ "select distinct cat.name from Cat cat\n"
+#~ "\n"
+#~ "select count(distinct cat.name), count(cat) from Cat cat"
+
+#, fuzzy
+#~ msgid "<![CDATA[from java.lang.Object o]]>"
+#~ msgstr "from java.lang.Object o"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Named n, Named m where n.name = m.name]]>"
+#~ msgstr "from Named n, Named m where n.name = m.name"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat where name='Fritz']]>"
+#~ msgstr "from Cat where name='Fritz'"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat as cat where cat.name='Fritz']]>"
+#~ msgstr "from Cat as cat where cat.name='Fritz'"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select foo\n"
+#~ "from Foo foo, Bar bar\n"
+#~ "where foo.startDate = bar.date]]>"
+#~ msgstr ""
+#~ "select foo\n"
+#~ "from Foo foo, Bar bar\n"
+#~ "where foo.startDate = bar.date"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat where cat.mate.name is not null]]>"
+#~ msgstr "from Cat cat where cat.mate.name is not null"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Foo foo\n"
+#~ "where foo.bar.baz.customer.address.city is not null]]>"
+#~ msgstr ""
+#~ "from Foo foo\n"
+#~ "where foo.bar.baz.customer.address.city is not null"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat, Cat rival where cat.mate = rival.mate]]>"
+#~ msgstr "from Cat cat, Cat rival where cat.mate = rival.mate"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cat, mate\n"
+#~ "from Cat cat, Cat mate\n"
+#~ "where cat.mate = mate]]>"
+#~ msgstr ""
+#~ "select cat, mate\n"
+#~ "from Cat cat, Cat mate\n"
+#~ "where cat.mate = mate"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as cat where cat.id = 123\n"
+#~ "\n"
+#~ "from Cat as cat where cat.mate.id = 69]]>"
+#~ msgstr ""
+#~ "from Cat as cat where cat.id = 123\n"
+#~ "\n"
+#~ "from Cat as cat where cat.mate.id = 69"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from bank.Person person\n"
+#~ "where person.id.country = 'AU'\n"
+#~ "    and person.id.medicareNumber = 123456]]>"
+#~ msgstr ""
+#~ "from bank.Person person\n"
+#~ "where person.id.country = 'AU'\n"
+#~ "    and person.id.medicareNumber = 123456"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from bank.Account account\n"
+#~ "where account.owner.id.country = 'AU'\n"
+#~ "    and account.owner.id.medicareNumber = 123456]]>"
+#~ msgstr ""
+#~ "from bank.Account account\n"
+#~ "where account.owner.id.country = 'AU'\n"
+#~ "    and account.owner.id.medicareNumber = 123456"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat where cat.class = DomesticCat]]>"
+#~ msgstr "from Cat cat where cat.class = DomesticCat"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from AuditLog log, Payment payment\n"
+#~ "where log.item.class = 'Payment' and log.item.id = payment.id]]>"
+#~ msgstr ""
+#~ "from AuditLog log, Payment payment\n"
+#~ "where log.item.class = 'Payment' and log.item.id = payment.id"
+
+#, fuzzy
+#~ msgid "<![CDATA[from DomesticCat cat where cat.name between 'A' and 'B']]>"
+#~ msgstr "from DomesticCat cat where cat.name between 'A' and 'B'"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from DomesticCat cat where cat.name in ( 'Foo', 'Bar', 'Baz' )]]>"
+#~ msgstr "from DomesticCat cat where cat.name in ( 'Foo', 'Bar', 'Baz' )"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from DomesticCat cat where cat.name not between 'A' and 'B']]>"
+#~ msgstr "from DomesticCat cat where cat.name not between 'A' and 'B'"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from DomesticCat cat where cat.name not in ( 'Foo', 'Bar', "
+#~ "'Baz' )]]>"
+#~ msgstr "from DomesticCat cat where cat.name not in ( 'Foo', 'Bar', 'Baz' )"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"hibernate.query.substitutions\">true 1, false "
+#~ "0</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"hibernate.query.substitutions\"&gt;true 1, false "
+#~ "0&lt;/property&gt;"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat where cat.alive = true]]>"
+#~ msgstr "from Cat cat where cat.alive = true"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat where cat.kittens.size > 0]]>"
+#~ msgstr "from Cat cat where cat.kittens.size &gt; 0"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat where size(cat.kittens) > 0]]>"
+#~ msgstr "from Cat cat where size(cat.kittens) &gt; 0"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Calendar cal where maxelement(cal.holidays) > current_date]]"
+#~ ">"
+#~ msgstr "from Calendar cal where maxelement(cal.holidays) &gt; current_date"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Order order where maxindex(order.items) > 100]]>"
+#~ msgstr "from Order order where maxindex(order.items) &gt; 100"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Order order where minelement(order.items) > 10000]]>"
+#~ msgstr "from Order order where minelement(order.items) &gt; 10000"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select mother from Cat as mother, Cat as kit\n"
+#~ "where kit in elements(foo.kittens)]]>"
+#~ msgstr ""
+#~ "select mother from Cat as mother, Cat as kit\n"
+#~ "where kit in elements(foo.kittens)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select p from NameList list, Person p\n"
+#~ "where p.name = some elements(list.names)]]>"
+#~ msgstr ""
+#~ "select p from NameList list, Person p\n"
+#~ "where p.name = some elements(list.names)"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat where exists elements(cat.kittens)]]>"
+#~ msgstr "from Cat cat where exists elements(cat.kittens)"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Player p where 3 > all elements(p.scores)]]>"
+#~ msgstr "from Player p where 3 &gt; all elements(p.scores)"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Show show where 'fizard' in indices(show.acts)]]>"
+#~ msgstr "from Show show where 'fizard' in indices(show.acts)"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Order order where order.items[0].id = 1234]]>"
+#~ msgstr "from Order order where order.items[0].id = 1234"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select person from Person person, Calendar calendar\n"
+#~ "where calendar.holidays['national day'] = person.birthDay\n"
+#~ "    and person.nationality.calendar = calendar]]>"
+#~ msgstr ""
+#~ "select person from Person person, Calendar calendar\n"
+#~ "where calendar.holidays['national day'] = person.birthDay\n"
+#~ "    and person.nationality.calendar = calendar"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select item from Item item, Order order\n"
+#~ "where order.items[ order.deliveredItemIndices[0] ] = item and order.id = "
+#~ "11]]>"
+#~ msgstr ""
+#~ "select item from Item item, Order order\n"
+#~ "where order.items[ order.deliveredItemIndices[0] ] = item and order.id = "
+#~ "11"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select item from Item item, Order order\n"
+#~ "where order.items[ maxindex(order.items) ] = item and order.id = 11]]>"
+#~ msgstr ""
+#~ "select item from Item item, Order order\n"
+#~ "where order.items[ maxindex(order.items) ] = item and order.id = 11"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select item from Item item, Order order\n"
+#~ "where order.items[ size(order.items) - 1 ] = item]]>"
+#~ msgstr ""
+#~ "select item from Item item, Order order\n"
+#~ "where order.items[ size(order.items) - 1 ] = item"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select item, index(item) from Order order\n"
+#~ "    join order.items item\n"
+#~ "where index(item) < 5]]>"
+#~ msgstr ""
+#~ "select item, index(item) from Order order\n"
+#~ "    join order.items item\n"
+#~ "where index(item) &lt; 5"
+
+#, fuzzy
+#~ msgid "<![CDATA[from DomesticCat cat where upper(cat.name) like 'FRI%']]>"
+#~ msgstr "from DomesticCat cat where upper(cat.name) like 'FRI&#37;'"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cust\n"
+#~ "from Product prod,\n"
+#~ "    Store store\n"
+#~ "    inner join store.customers cust\n"
+#~ "where prod.name = 'widget'\n"
+#~ "    and store.location.name in ( 'Melbourne', 'Sydney' )\n"
+#~ "    and prod = all elements(cust.currentOrder.lineItems)]]>"
+#~ msgstr ""
+#~ "select cust\n"
+#~ "from Product prod,\n"
+#~ "    Store store\n"
+#~ "    inner join store.customers cust\n"
+#~ "where prod.name = 'widget'\n"
+#~ "    and store.location.name in ( 'Melbourne', 'Sydney' )\n"
+#~ "    and prod = all elements(cust.currentOrder.lineItems)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[SELECT cust.name, cust.address, cust.phone, cust.id, cust."
+#~ "current_order\n"
+#~ "FROM customers cust,\n"
+#~ "    stores store,\n"
+#~ "    locations loc,\n"
+#~ "    store_customers sc,\n"
+#~ "    product prod\n"
+#~ "WHERE prod.name = 'widget'\n"
+#~ "    AND store.loc_id = loc.id\n"
+#~ "    AND loc.name IN ( 'Melbourne', 'Sydney' )\n"
+#~ "    AND sc.store_id = store.id\n"
+#~ "    AND sc.cust_id = cust.id\n"
+#~ "    AND prod.id = ALL(\n"
+#~ "        SELECT item.prod_id\n"
+#~ "        FROM line_items item, orders o\n"
+#~ "        WHERE item.order_id = o.id\n"
+#~ "            AND cust.current_order = o.id\n"
+#~ "    )]]>"
+#~ msgstr ""
+#~ "SELECT cust.name, cust.address, cust.phone, cust.id, cust.current_order\n"
+#~ "FROM customers cust,\n"
+#~ "    stores store,\n"
+#~ "    locations loc,\n"
+#~ "    store_customers sc,\n"
+#~ "    product prod\n"
+#~ "WHERE prod.name = 'widget'\n"
+#~ "    AND store.loc_id = loc.id\n"
+#~ "    AND loc.name IN ( 'Melbourne', 'Sydney' )\n"
+#~ "    AND sc.store_id = store.id\n"
+#~ "    AND sc.cust_id = cust.id\n"
+#~ "    AND prod.id = ALL(\n"
+#~ "        SELECT item.prod_id\n"
+#~ "        FROM line_items item, orders o\n"
+#~ "        WHERE item.order_id = o.id\n"
+#~ "            AND cust.current_order = o.id\n"
+#~ "    )"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from DomesticCat cat\n"
+#~ "order by cat.name asc, cat.weight desc, cat.birthdate]]>"
+#~ msgstr ""
+#~ "from DomesticCat cat\n"
+#~ "order by cat.name asc, cat.weight desc, cat.birthdate"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
+#~ "from Cat cat\n"
+#~ "group by cat.color]]>"
+#~ msgstr ""
+#~ "select cat.color, sum(cat.weight), count(cat)\n"
+#~ "from Cat cat\n"
+#~ "group by cat.color"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select foo.id, avg(name), max(name)\n"
+#~ "from Foo foo join foo.names name\n"
+#~ "group by foo.id]]>"
+#~ msgstr ""
+#~ "select foo.id, avg(name), max(name)\n"
+#~ "from Foo foo join foo.names name\n"
+#~ "group by foo.id"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
+#~ "from Cat cat\n"
+#~ "group by cat.color\n"
+#~ "having cat.color in (eg.Color.TABBY, eg.Color.BLACK)]]>"
+#~ msgstr ""
+#~ "select cat.color, sum(cat.weight), count(cat)\n"
+#~ "from Cat cat\n"
+#~ "group by cat.color\n"
+#~ "having cat.color in (eg.Color.TABBY, eg.Color.BLACK)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cat\n"
+#~ "from Cat cat\n"
+#~ "    join cat.kittens kitten\n"
+#~ "group by cat.id, cat.name, cat.other, cat.properties\n"
+#~ "having avg(kitten.weight) > 100\n"
+#~ "order by count(kitten) asc, sum(kitten.weight) desc]]>"
+#~ msgstr ""
+#~ "select cat\n"
+#~ "from Cat cat\n"
+#~ "    join cat.kittens kitten\n"
+#~ "group by cat.id, cat.name, cat.other, cat.properties\n"
+#~ "having avg(kitten.weight) &gt; 100\n"
+#~ "order by count(kitten) asc, sum(kitten.weight) desc"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as fatcat\n"
+#~ "where fatcat.weight > (\n"
+#~ "    select avg(cat.weight) from DomesticCat cat\n"
+#~ ")]]>"
+#~ msgstr ""
+#~ "from Cat as fatcat\n"
+#~ "where fatcat.weight &gt; (\n"
+#~ "    select avg(cat.weight) from DomesticCat cat\n"
+#~ ")"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from DomesticCat as cat\n"
+#~ "where cat.name = some (\n"
+#~ "    select name.nickName from Name as name\n"
+#~ ")]]>"
+#~ msgstr ""
+#~ "from DomesticCat as cat\n"
+#~ "where cat.name = some (\n"
+#~ "    select name.nickName from Name as name\n"
+#~ ")"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as cat\n"
+#~ "where not exists (\n"
+#~ "    from Cat as mate where mate.mate = cat\n"
+#~ ")]]>"
+#~ msgstr ""
+#~ "from Cat as cat\n"
+#~ "where not exists (\n"
+#~ "    from Cat as mate where mate.mate = cat\n"
+#~ ")"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from DomesticCat as cat\n"
+#~ "where cat.name not in (\n"
+#~ "    select name.nickName from Name as name\n"
+#~ ")]]>"
+#~ msgstr ""
+#~ "from DomesticCat as cat\n"
+#~ "where cat.name not in (\n"
+#~ "    select name.nickName from Name as name\n"
+#~ ")"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cat.id, (select max(kit.weight) from cat.kitten kit)\n"
+#~ "from Cat as cat]]>"
+#~ msgstr ""
+#~ "select cat.id, (select max(kit.weight) from cat.kitten kit)\n"
+#~ "from Cat as cat"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select order.id, sum(price.amount), count(item)\n"
+#~ "from Order as order\n"
+#~ "    join order.lineItems as item\n"
+#~ "    join item.product as product,\n"
+#~ "    Catalog as catalog\n"
+#~ "    join catalog.prices as price\n"
+#~ "where order.paid = false\n"
+#~ "    and order.customer = :customer\n"
+#~ "    and price.product = product\n"
+#~ "    and catalog.effectiveDate < sysdate\n"
+#~ "    and catalog.effectiveDate >= all (\n"
+#~ "        select cat.effectiveDate\n"
+#~ "        from Catalog as cat\n"
+#~ "        where cat.effectiveDate < sysdate\n"
+#~ "    )\n"
+#~ "group by order\n"
+#~ "having sum(price.amount) > :minAmount\n"
+#~ "order by sum(price.amount) desc]]>"
+#~ msgstr ""
+#~ "select order.id, sum(price.amount), count(item)\n"
+#~ "from Order as order\n"
+#~ "    join order.lineItems as item\n"
+#~ "    join item.product as product,\n"
+#~ "    Catalog as catalog\n"
+#~ "    join catalog.prices as price\n"
+#~ "where order.paid = false\n"
+#~ "    and order.customer = :customer\n"
+#~ "    and price.product = product\n"
+#~ "    and catalog.effectiveDate &lt; sysdate\n"
+#~ "    and catalog.effectiveDate &gt;= all (\n"
+#~ "        select cat.effectiveDate\n"
+#~ "        from Catalog as cat\n"
+#~ "        where cat.effectiveDate &lt; sysdate\n"
+#~ "    )\n"
+#~ "group by order\n"
+#~ "having sum(price.amount) &gt; :minAmount\n"
+#~ "order by sum(price.amount) desc"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select order.id, sum(price.amount), count(item)\n"
+#~ "from Order as order\n"
+#~ "    join order.lineItems as item\n"
+#~ "    join item.product as product,\n"
+#~ "    Catalog as catalog\n"
+#~ "    join catalog.prices as price\n"
+#~ "where order.paid = false\n"
+#~ "    and order.customer = :customer\n"
+#~ "    and price.product = product\n"
+#~ "    and catalog = :currentCatalog\n"
+#~ "group by order\n"
+#~ "having sum(price.amount) > :minAmount\n"
+#~ "order by sum(price.amount) desc]]>"
+#~ msgstr ""
+#~ "select order.id, sum(price.amount), count(item)\n"
+#~ "from Order as order\n"
+#~ "    join order.lineItems as item\n"
+#~ "    join item.product as product,\n"
+#~ "    Catalog as catalog\n"
+#~ "    join catalog.prices as price\n"
+#~ "where order.paid = false\n"
+#~ "    and order.customer = :customer\n"
+#~ "    and price.product = product\n"
+#~ "    and catalog = :currentCatalog\n"
+#~ "group by order\n"
+#~ "having sum(price.amount) &gt; :minAmount\n"
+#~ "order by sum(price.amount) desc"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select count(payment), status.name\n"
+#~ "from Payment as payment\n"
+#~ "    join payment.currentStatus as status\n"
+#~ "    join payment.statusChanges as statusChange\n"
+#~ "where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
+#~ "    or (\n"
+#~ "        statusChange.timeStamp = (\n"
+#~ "            select max(change.timeStamp)\n"
+#~ "            from PaymentStatusChange change\n"
+#~ "            where change.payment = payment\n"
+#~ "        )\n"
+#~ "        and statusChange.user <> :currentUser\n"
+#~ "    )\n"
+#~ "group by status.name, status.sortOrder\n"
+#~ "order by status.sortOrder]]>"
+#~ msgstr ""
+#~ "select count(payment), status.name\n"
+#~ "from Payment as payment\n"
+#~ "    join payment.currentStatus as status\n"
+#~ "    join payment.statusChanges as statusChange\n"
+#~ "where payment.status.name &lt;&gt; PaymentStatus.AWAITING_APPROVAL\n"
+#~ "    or (\n"
+#~ "        statusChange.timeStamp = (\n"
+#~ "            select max(change.timeStamp)\n"
+#~ "            from PaymentStatusChange change\n"
+#~ "            where change.payment = payment\n"
+#~ "        )\n"
+#~ "        and statusChange.user &lt;&gt; :currentUser\n"
+#~ "    )\n"
+#~ "group by status.name, status.sortOrder\n"
+#~ "order by status.sortOrder"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select count(payment), status.name\n"
+#~ "from Payment as payment\n"
+#~ "    join payment.currentStatus as status\n"
+#~ "where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
+#~ "    or payment.statusChanges[ maxIndex(payment.statusChanges) ].user <> :"
+#~ "currentUser\n"
+#~ "group by status.name, status.sortOrder\n"
+#~ "order by status.sortOrder]]>"
+#~ msgstr ""
+#~ "select count(payment), status.name\n"
+#~ "from Payment as payment\n"
+#~ "    join payment.currentStatus as status\n"
+#~ "where payment.status.name &lt;&gt; PaymentStatus.AWAITING_APPROVAL\n"
+#~ "    or payment.statusChanges[ maxIndex(payment.statusChanges) ].user &lt;"
+#~ "&gt; :currentUser\n"
+#~ "group by status.name, status.sortOrder\n"
+#~ "order by status.sortOrder"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select account, payment\n"
+#~ "from Account as account\n"
+#~ "    left outer join account.payments as payment\n"
+#~ "where :currentUser in elements(account.holder.users)\n"
+#~ "    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
+#~ "PaymentStatus.UNPAID)\n"
+#~ "order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
+#~ msgstr ""
+#~ "select account, payment\n"
+#~ "from Account as account\n"
+#~ "    left outer join account.payments as payment\n"
+#~ "where :currentUser in elements(account.holder.users)\n"
+#~ "    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
+#~ "PaymentStatus.UNPAID)\n"
+#~ "order by account.type.sortOrder, account.accountNumber, payment.dueDate"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select account, payment\n"
+#~ "from Account as account\n"
+#~ "    join account.holder.users as user\n"
+#~ "    left outer join account.payments as payment\n"
+#~ "where :currentUser = user\n"
+#~ "    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
+#~ "PaymentStatus.UNPAID)\n"
+#~ "order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
+#~ msgstr ""
+#~ "select account, payment\n"
+#~ "from Account as account\n"
+#~ "    join account.holder.users as user\n"
+#~ "    left outer join account.payments as payment\n"
+#~ "where :currentUser = user\n"
+#~ "    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
+#~ "PaymentStatus.UNPAID)\n"
+#~ "order by account.type.sortOrder, account.accountNumber, payment.dueDate"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
+#~ "iterate().next() ).intValue()]]>"
+#~ msgstr ""
+#~ "( (Integer) session.iterate(\"select count(*) from ....\").next() )."
+#~ "intValue()"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select usr.id, usr.name\n"
+#~ "from User as usr\n"
+#~ "    left join usr.messages as msg\n"
+#~ "group by usr.id, usr.name\n"
+#~ "order by count(msg)]]>"
+#~ msgstr ""
+#~ "select usr.id, usr.name\n"
+#~ "from User as usr\n"
+#~ "    left join usr.messages as msg\n"
+#~ "group by usr.id, usr.name\n"
+#~ "order by count(msg)"
+
+#, fuzzy
+#~ msgid "<![CDATA[from User usr where size(usr.messages) >= 1]]>"
+#~ msgstr "from User usr where size(usr.messages) &gt;= 1"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select usr.id, usr.name\n"
+#~ "from User usr.name\n"
+#~ "    join usr.messages msg\n"
+#~ "group by usr.id, usr.name\n"
+#~ "having count(msg) >= 1]]>"
+#~ msgstr ""
+#~ "select usr.id, usr.name\n"
+#~ "from User usr.name\n"
+#~ "    join usr.messages msg\n"
+#~ "group by usr.id, usr.name\n"
+#~ "having count(msg) &gt;= 1"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select usr.id, usr.name\n"
+#~ "from User as usr\n"
+#~ "    left join usr.messages as msg\n"
+#~ "group by usr.id, usr.name\n"
+#~ "having count(msg) = 0]]>"
+#~ msgstr ""
+#~ "select usr.id, usr.name\n"
+#~ "from User as usr\n"
+#~ "    left join usr.messages as msg\n"
+#~ "group by usr.id, usr.name\n"
+#~ "having count(msg) = 0"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Query q = s.createQuery(\"from foo Foo as foo where foo.name=:"
+#~ "name and foo.size=:size\");\n"
+#~ "q.setProperties(fooBean); // fooBean has getName() and getSize()\n"
+#~ "List foos = q.list();]]>"
+#~ msgstr ""
+#~ "Query q = s.createQuery(\"from foo Foo as foo where foo.name=:name and "
+#~ "foo.size=:size\");\n"
+#~ "q.setProperties(fooBean); // fooBean has getName() and getSize()\n"
+#~ "List foos = q.list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Query q = s.createFilter( collection, \"\" ); // the trivial "
+#~ "filter\n"
+#~ "q.setMaxResults(PAGE_SIZE);\n"
+#~ "q.setFirstResult(PAGE_SIZE * pageNumber);\n"
+#~ "List page = q.list();]]>"
+#~ msgstr ""
+#~ "Query q = s.createFilter( collection, \"\" ); // the trivial filter\n"
+#~ "q.setMaxResults(PAGE_SIZE);\n"
+#~ "q.setFirstResult(PAGE_SIZE * pageNumber);\n"
+#~ "List page = q.list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Collection orderedCollection = s.filter( collection, \"order by "
+#~ "this.amount\" );\n"
+#~ "Collection counts = s.filter( collection, \"select this.type, count(this) "
+#~ "group by this.type\" );]]>"
+#~ msgstr ""
+#~ "Collection orderedCollection = s.filter( collection, \"order by this."
+#~ "amount\" );\n"
+#~ "Collection counts = s.filter( collection, \"select this.type, count(this) "
+#~ "group by this.type\" );"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
+#~ "iterate().next() ).intValue();]]>"
+#~ msgstr ""
+#~ "( (Integer) session.iterate(\"select count(*) from ....\").next() )."
+#~ "intValue();"
+
+#, fuzzy
+#~ msgid "<![CDATA[select p.name from Person p]]>"
+#~ msgstr "select p.name from from Person p"
+
+#, fuzzy
+#~ msgid "<![CDATA[select p.name.first from Person p]]>"
+#~ msgstr "select p.name.first from from Person p"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Person p where p.name = :name]]>"
+#~ msgstr "from from Person p where p.name = :name"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Person p where p.name.first = :firstName]]>"
+#~ msgstr "from from Person p where p.name.first = :firstName"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Person p order by p.name]]>"
+#~ msgstr "from from Person p order by p.name"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Person p order by p.name.first]]>"
+#~ msgstr "from from Person p order by p.name.first"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Person p where p.name.first='John' and p.name."
+#~ "last='Jingleheimer-Schmidt']]>"
+#~ msgstr ""
+#~ "from Person p where p.name.first='John' and p.name.last='Jingleheimer-"
+#~ "Schmidt'"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Person p where p.name=('John', 'Jingleheimer-Schmidt')]]>"
+#~ msgstr "from Person p where p.name=('John', 'Jingleheimer-Schmidt')"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as cat\n"
+#~ "where not ( cat.name, cat.color ) in (\n"
+#~ "    select cat.name, cat.color from DomesticCat cat\n"
+#~ ")]]>"
+#~ msgstr ""
+#~ "from Cat as cat\n"
+#~ "where not ( cat.name, cat.color ) in (\n"
+#~ "    select cat.name, cat.color from DomesticCat cat\n"
+#~ ")"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/query_sql.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/query_sql.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/query_sql.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,25 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-18 15:09+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: query_sql.xml:29
 #, no-c-format
 msgid "Native SQL"
-msgstr "ネイティブSQL"
+msgstr "ネイティブ SQL"
 
 #. Tag: para
-#: query_sql.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also express queries in the native SQL dialect of your database. "
 "This is useful if you want to utilize database-specific features such as "
@@ -26,118 +27,87 @@
 "provides a clean migration path from a direct SQL/JDBC based application to "
 "Hibernate."
 msgstr ""
-"データベースのネイティブSQL方言を使ってクエリを表現することもできます。 クエ"
-"リヒントやOracleの <literal>CONNECT</literal> キーワードのように、 データベー"
-"ス独自の機能を利用したいときに使えます。 SQL/JDBCを直接使用しているアプリケー"
-"ションからHibernateへの移行も容易にしています。"
+"データベースのネイティブ SQL 方言を使ってクエリを表現することもできます。クエ"
+"リヒントや Oracle の <literal>CONNECT</literal> キーワードのように、データ"
+"ベース独自の機能を利用したいときに使えます。 SQL/JDBC を直接使用しているアプ"
+"リケーションから Hibernate への移行も容易にしています。"
 
 #. Tag: para
-#: query_sql.xml:37
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 allows you to specify handwritten SQL, including stored "
 "procedures, for all create, update, delete, and load operations."
 msgstr ""
-"Hibernate3では、生成、更新、削除、読み込み処理のようなすべての SQL(ストアド"
-"プロシージャを含む)を手書きできます。"
+"Hibernate3 では、生成、更新、削除、読み込み処理のようなすべての SQL (ストア"
+"ドプロシージャを含む)を手書きできます。"
 
 #. Tag: title
-#: query_sql.xml:41
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Using a <literal>SQLQuery</literal>"
-msgstr "<literal>SQLQuery</literal> の使用"
+msgstr "もしくは <literal>List</literal> として、"
 
 #. Tag: para
-#: query_sql.xml:43
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Execution of native SQL queries is controlled via the <literal>SQLQuery</"
 "literal> interface, which is obtained by calling <literal>Session."
 "createSQLQuery()</literal>. The following sections describe how to use this "
 "API for querying."
 msgstr ""
-"ネイティブなSQLクエリの実行は <literal>SQLQuery</literal> インターフェイスを"
-"通して制御します。 <literal>SQLQuery</literal> インターフェイスは "
-"<literal>Session.createSQLQuery()</literal> を呼び出して取得します。 このAPI"
+"ネイティブな SQL クエリの実行は <literal>SQLQuery</literal> インターフェース"
+"を通して制御します。 <literal>SQLQuery</literal> インターフェースは "
+"<literal>Session.createSQLQuery()</literal> を呼び出して取得します。この API "
 "を使って問い合わせする方法を以下で説明します。"
 
 #. Tag: title
-#: query_sql.xml:49
 #, no-c-format
 msgid "Scalar queries"
 msgstr "スカラーのクエリ"
 
 #. Tag: para
-#: query_sql.xml:51
 #, no-c-format
 msgid "The most basic SQL query is to get a list of scalars (values)."
-msgstr "最も基本的なSQLクエリはスカラー(値)のリストを得ることです。"
+msgstr "最も基本的な SQL クエリはスカラー(値)のリストを得ることです。"
 
-#. Tag: programlisting
-#: query_sql.xml:54
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").list();\n"
-"sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").list();\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:56
-#, fuzzy, no-c-format
-msgid ""
 "These will return a List of Object arrays (Object[]) with scalar values for "
 "each column in the CATS table. Hibernate will use ResultSetMetadata to "
 "deduce the actual order and types of the returned scalar values."
 msgstr ""
-"これらはどちらも、CATSテーブルの各カラムのスカラー値を含む Object配列(Object"
-"[])のリストを返します。 返すスカラー値の実際の順番と型を推定するために、 "
-"HibernateはResultSetMetadataを使用します。"
+"これらはどちらも、 CATS テーブルの各カラムのスカラー値を含む Object 配列"
+"(Object[])のリストを返します。返すスカラー値の実際の順番と型を推定するため"
+"に、 Hibernate は ResultSetMetadata を使用します。"
 
 #. Tag: para
-#: query_sql.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To avoid the overhead of using <literal>ResultSetMetadata</literal>, or "
 "simply to be more explicit in what is returned, one can use "
 "<literal>addScalar()</literal>:"
 msgstr ""
-"<literal>ResultSetMetadata</literal> を使用するオーバーヘッドを避けるため、 "
-"もしくは単に何が返されるか明確にするため、<literal>addScalar()</literal> を使"
+"<literal>ResultSetMetadata</literal> を使用するオーバーヘッドを避けるため、も"
+"しくは単に何が返されるか明確にするため、 <literal>addScalar()</literal> を使"
 "えます。"
 
-#. Tag: programlisting
-#: query_sql.xml:65
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-" .addScalar(\"ID\", Hibernate.LONG)\n"
-" .addScalar(\"NAME\", Hibernate.STRING)\n"
-" .addScalar(\"BIRTHDATE\", Hibernate.DATE)\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:67 query_sql.xml:113 query_sql.xml:198 query_sql.xml:349
 #, no-c-format
 msgid "This query specified:"
-msgstr "このクエリで指定されているものを下記に示します。"
+msgstr "このクエリで指定されているものを下記に示します:"
 
 #. Tag: para
-#: query_sql.xml:71 query_sql.xml:117 query_sql.xml:353
 #, no-c-format
 msgid "the SQL query string"
-msgstr "SQLクエリ文字列"
+msgstr "SQL クエリ文字列"
 
 #. Tag: para
-#: query_sql.xml:75
 #, no-c-format
 msgid "the columns and types to return"
 msgstr "返されるカラムと型"
 
 #. Tag: para
-#: query_sql.xml:79
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This will return Object arrays, but now it will not use "
 "<literal>ResultSetMetadata</literal> but will instead explicitly get the ID, "
@@ -146,47 +116,32 @@
 "be returned, even though the query is using <literal>*</literal> and could "
 "return more than the three listed columns."
 msgstr ""
-"これはまだObject配列を返しますが、 <literal>ResultSetMetdata</literal> を使用"
-"しません。 ただし、その代わりに基礎にあるリザルトセットから ID、NAME、"
-"BIRTHDATE カラムをそれぞれ Long、String、Short として明示的に取得します。 こ"
-"れは3つのカラムを返すのみであることも意味します。 たとえ、クエリが "
-"<literal>*</literal> を使用し、 列挙した3つより多くのカラムを返せるとしても"
-"です。"
+"これはまだ Object 配列を返しますが、 <literal>ResultSetMetdata</literal> を使"
+"用しません。ただし、その代わりに基礎にあるリザルトセットから ID、NAME、"
+"BIRTHDATE カラムをそれぞれ Long、String、Short として明示的に取得します。これ"
+"は3つのカラムを返すのみであることも意味します。たとえ、クエリが <literal>*</"
+"literal> を使用し、列挙した3つより多くのカラムを返せるとしてもです。"
 
 #. Tag: para
-#: query_sql.xml:87
 #, no-c-format
 msgid ""
 "It is possible to leave out the type information for all or some of the "
 "scalars."
 msgstr "スカラーの型情報を省くこともできます。"
 
-#. Tag: programlisting
-#: query_sql.xml:90
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-" .addScalar(\"ID\", Hibernate.LONG)\n"
-" .addScalar(\"NAME\")\n"
-" .addScalar(\"BIRTHDATE\")\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:92
-#, fuzzy, no-c-format
-msgid ""
 "This is essentially the same query as before, but now "
 "<literal>ResultSetMetaData</literal> is used to determine the type of NAME "
 "and BIRTHDATE, where as the type of ID is explicitly specified."
 msgstr ""
-"これは本質的に前と同じクエリですが、、 NAME と BIRTHDATE の型を決めるために "
-"<literal>ResultSetMetaData</literal> を使用します。一方、ID の型は明示的に指"
+"これは本質的に前と同じクエリですが、 NAME と BIRTHDATE の型を決めるために "
+"<literal>ResultSetMetaData</literal> を使用します。一方、 ID の型は明示的に指"
 "定されています。"
 
 #. Tag: para
-#: query_sql.xml:96
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "How the java.sql.Types returned from ResultSetMetaData is mapped to "
 "Hibernate types is controlled by the Dialect. If a specific type is not "
@@ -194,18 +149,16 @@
 "it via calls to <literal>registerHibernateType</literal> in the Dialect."
 msgstr ""
 "ResultSetMetaData から返される java.sql.Types を Hibernate の型に マッピング"
-"することは、Dialect が制御します。 明示された型がマッピングされていないか、結"
+"することは、 Dialect が制御します。明示された型がマッピングされていないか、結"
 "果の型が期待したものと異なる場合、 Dialect の "
-"<literal>registerHibernateType</literal> を呼び出し、 カスタマイズできます。"
+"<literal>registerHibernateType</literal> を呼び出し、カスタマイズできます。"
 
 #. Tag: title
-#: query_sql.xml:104
 #, no-c-format
 msgid "Entity queries"
 msgstr "エンティティのクエリ"
 
 #. Tag: para
-#: query_sql.xml:106
 #, no-c-format
 msgid ""
 "The above queries were all about returning scalar values, basically "
@@ -213,40 +166,27 @@
 "get entity objects from a native sql query via <literal>addEntity()</"
 "literal>."
 msgstr ""
-"ここまでのクエリは、すべてスカラー値を返すものでした。 基本的に、リザルトセッ"
-"トから「未加工」の値を返します。 以降では、<literal>addEntity()</literal> に"
-"より、ネイティブSQLクエリから エンティティオブジェクトを取得する方法を示しま"
+"ここまでのクエリは、すべてスカラー値を返すものでした。基本的に、リザルトセッ"
+"トから「未加工」の値を返します。以降では、 <literal>addEntity()</literal> に"
+"より、ネイティブ SQL クエリからエンティティオブジェクトを取得する方法を示しま"
 "す。"
 
-#. Tag: programlisting
-#: query_sql.xml:111
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").addEntity(Cat.class);\n"
-"sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").addEntity(Cat."
-"class);\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:121
 #, no-c-format
 msgid "the entity returned by the query"
-msgstr "クエリが返すエンティティとSQLテーブルの別名"
+msgstr "クエリが返すエンティティと SQL テーブルの別名"
 
 #. Tag: para
-#: query_sql.xml:125
 #, no-c-format
 msgid ""
 "Assuming that Cat is mapped as a class with the columns ID, NAME and "
 "BIRTHDATE the above queries will both return a List where each element is a "
 "Cat entity."
 msgstr ""
-"CatがID, NAME, BIRTHDATEのカラムを使ってクラスにマッピングされる場合、 上記の"
-"クエリはどちらも、要素がCatエンティティであるリストを返します。"
+"Cat が ID 、 NAME 、 BIRTHDATE のカラムを使ってクラスにマッピングされる場合、"
+"上記のクエリはどちらも、要素が Cat エンティティであるリストを返します。"
 
 #. Tag: para
-#: query_sql.xml:129
 #, no-c-format
 msgid ""
 "If the entity is mapped with a <literal>many-to-one</literal> to another "
@@ -257,35 +197,23 @@
 "to-one</literal> to a <literal>Dog</literal>:"
 msgstr ""
 "エンティティを別のエンティティに <literal>多対一</literal> でマッピングしてい"
-"る場合は、 ネイティブクエリを実行する際に、この別のエンティティを返すことも要"
-"求します。 さもなければ、データベース固有の「column not found(カラムが見つか"
-"りません)」エラーが発生します。 * 表記を使用した際は、追加のカラムが自動的に"
-"返されますが、 次の例のように、<literal>Dog</literal> に <literal>多対一</"
-"literal> であることを 明示することを私たちは好みます。"
+"る場合は、ネイティブクエリを実行する際に、この別のエンティティを返すことも要"
+"求します。さもなければ、データベース固有の「column not found(カラムが見つかり"
+"ません)」エラーが発生します。 * 表記を使用した際は、追加のカラムが自動的に返"
+"されますが、次の例のように、 <literal>Dog</literal> に <literal>多対一</"
+"literal> であることを明示することを私たちは好みます。"
 
-#. Tag: programlisting
-#: query_sql.xml:137
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, DOG_ID FROM CATS"
-"\").addEntity(Cat.class);\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:139
 #, no-c-format
 msgid "This will allow cat.getDog() to function properly."
 msgstr "これにより cat.getDog() が正しく機能します。"
 
 #. Tag: title
-#: query_sql.xml:143
 #, no-c-format
 msgid "Handling associations and collections"
 msgstr "関連とコレクションの操作"
 
 #. Tag: para
-#: query_sql.xml:145
 #, no-c-format
 msgid ""
 "It is possible to eagerly join in the <literal>Dog</literal> to avoid the "
@@ -294,24 +222,12 @@
 "association or collection."
 msgstr ""
 "プロキシを初期化するための余分な処理を避けるため、 <literal>Dog</literal> の"
-"中で即時結合できます。 これは <literal>addJoin()</literal> メソッドにより行い"
-"ます。 関連もしくはコレクションに結合できます。"
+"中で即時結合できます。これは <literal>addJoin()</literal> メソッドにより行い"
+"ます。関連もしくはコレクションに結合できます。"
 
-#. Tag: programlisting
-#: query_sql.xml:150
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT c.ID, NAME, BIRTHDATE, DOG_ID, D_ID, "
-"D_NAME FROM CATS c, DOGS d WHERE c.DOG_ID = d.D_ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addJoin(\"cat.dog\");\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:152
-#, fuzzy, no-c-format
-msgid ""
 "In this example, the returned <literal>Cat</literal>'s will have their "
 "<literal>dog</literal> property fully initialized without any extra "
 "roundtrip to the database. Notice that you added an alias name (\"cat\") to "
@@ -319,81 +235,54 @@
 "do the same eager joining for collections, e.g. if the <literal>Cat</"
 "literal> had a one-to-many to <literal>Dog</literal> instead."
 msgstr ""
-"この例の中で、返される <literal>Cat</literal> は、 データベースへの余分処理な"
-"しで、 完全に初期化された <literal>dog</literal> プロパティを持ちます。 結合"
-"対象のプロパティへのパスを指定できるように、 別名(「cat」)を追加したことに"
-"注意してください。 コレクションの即時結合も同じようにできます。 たとえば、"
+"この例の中で、返される <literal>Cat</literal> は、データベースへの余分処理な"
+"しで、完全に初期化された <literal>dog</literal> プロパティを持ちます。結合対"
+"象のプロパティへのパスを指定できるように、別名(「cat」)を追加したことに注意"
+"してください。コレクションの即時結合も同じようにできます。たとえば、 "
 "<literal>Cat</literal> が一対多で <literal>Dog</literal> を持っていた場合、次"
 "のようになります。"
 
-#. Tag: programlisting
-#: query_sql.xml:160
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, D_ID, D_NAME, "
-"CAT_ID FROM CATS c, DOGS d WHERE c.ID = d.CAT_ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addJoin(\"cat.dogs\");\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:162
-#, fuzzy, no-c-format
-msgid ""
 "At this stage you are reaching the limits of what is possible with native "
 "queries, without starting to enhance the sql queries to make them usable in "
 "Hibernate. Problems can arise when returning multiple entities of the same "
 "type or when the default alias/column names are not enough."
 msgstr ""
-"現在のところ、 Hibernateで使いやすくするためのSQLクエリの拡張なしに、 ネイ"
-"ティブクエリで何かを可能にする限界に来ています。 同じ型のエンティティを複数返"
-"す際や、デフォルトの別名や列名で十分ではない場合に、 問題は起こり始めます。"
+"現在のところ、 Hibernate で使いやすくするための SQL クエリの拡張なしに、ネイ"
+"ティブクエリで何かを可能にする限界に来ています。同じ型のエンティティを複数返"
+"す際や、デフォルトの別名や列名で十分ではない場合に、問題は起こり始めます。"
 
 #. Tag: title
-#: query_sql.xml:170
 #, no-c-format
 msgid "Returning multiple entities"
 msgstr "複数エンティティの取得"
 
 #. Tag: para
-#: query_sql.xml:172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Until now, the result set column names are assumed to be the same as the "
 "column names specified in the mapping document. This can be problematic for "
 "SQL queries that join multiple tables, since the same column names can "
 "appear in more than one table."
 msgstr ""
-"ここまでは、リザルトセットのカラム名は、 マッピングファイルで指定されたカラム"
-"名と同じであると仮定していました。 複数のテーブルが同じカラム名を持つ場合があ"
-"るため、 複数テーブルを結合するSQLクエリで問題となる場合があります。"
+"ここまでは、リザルトセットのカラム名は、マッピングドキュメントで指定されたカ"
+"ラム名と同じであると仮定していました。複数のテーブルが同じカラム名を持つ場合"
+"があるため、複数テーブルを結合する SQL クエリで問題となる場合があります。"
 
 #. Tag: para
-#: query_sql.xml:177
 #, no-c-format
 msgid ""
 "Column alias injection is needed in the following query (which most likely "
 "will fail):"
 msgstr ""
-"下記のような(失敗しそうな)クエリでは、 カラム別名インジェクション(column "
-"alias injection)が必要です。"
+"下記のような(失敗しそうな)クエリでは、カラム別名インジェクション(column "
+"alias injection)が必要です:"
 
-#. Tag: programlisting
-#: query_sql.xml:180
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT c.*, m.*  FROM CATS c, CATS m WHERE c."
-"MOTHER_ID = c.ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addEntity(\"mother\", Cat.class)\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:184
-#, fuzzy, no-c-format
-msgid ""
 "The query was intended to return two Cat instances per row: a cat and its "
 "mother. The query will, however, fail because there is a conflict of names; "
 "the instances are mapped to the same column names. Also, on some databases "
@@ -401,48 +290,33 @@
 "NAME\", etc. which are not equal to the columns specified in the mappings "
 "(\"ID\" and \"NAME\")."
 msgstr ""
-"このクエリの意図は、 1行ごとに2つのCatインスタンス、つまり猫とその母親を返"
-"すということです。 同じカラム名にマッピングすることにより名前が衝突するため、"
-"このクエリは失敗します。 ベータベースによっては、返されるカラムの別名が \"c."
-"ID\"、\"c.NAME\" などの形式であり、 マッピングで指定されたカラム(\"ID\" と "
+"このクエリの意図は、1行ごとに2つの Cat インスタンス、つまり猫とその母親を返"
+"すということです。同じカラム名にマッピングすることにより名前が衝突するため、"
+"このクエリは失敗します。ベータベースによっては、返されるカラムの別名が \"c.ID"
+"\"、\"c.NAME\" などの形式であり、マッピングで指定されたカラム(\"ID\" と "
 "\"NAME\")と等しくないため、失敗します。"
 
 #. Tag: para
-#: query_sql.xml:193
 #, no-c-format
 msgid "The following form is not vulnerable to column name duplication:"
-msgstr "下記の形式は、カラム名が重複しても大丈夫です。"
+msgstr "下記の形式は、カラム名が重複しても大丈夫です:"
 
-#. Tag: programlisting
-#: query_sql.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT {cat.*}, {mother.*}  FROM CATS c, CATS "
-"m WHERE c.MOTHER_ID = c.ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addEntity(\"mother\", Cat.class)\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:202
 #, no-c-format
 msgid ""
 "the SQL query string, with placeholders for Hibernate to inject column "
 "aliases"
 msgstr ""
-"SQLクエリ文字列 (Hibernateがカラムの別名を挿入するためのプレースホルダを含"
+"SQL クエリ文字列 (Hibernate がカラムの別名を挿入するためのプレースホルダを含"
 "む)"
 
 #. Tag: para
-#: query_sql.xml:207
 #, no-c-format
 msgid "the entities returned by the query"
 msgstr "クエリによって返されるエンティティ"
 
 #. Tag: para
-#: query_sql.xml:211
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The {cat.*} and {mother.*} notation used above is a shorthand for \"all "
 "properties\". Alternatively, you can list the columns explicitly, but even "
@@ -452,390 +326,287 @@
 "from a different table (cat_log) to the one declared in the mapping "
 "metadata. You can even use the property aliases in the where clause."
 msgstr ""
-"上記で使用している {cat.*} と {mother.*} という表記は、 「すべてのプロパ"
-"ティ」を表す省略形です。 代わりに、明示的にカラムを列挙してもよいですが、 そ"
-"の場合は、Hibernateに各プロパティに対応するSQLカラムの別名を挿入させるべきで"
-"しょう。 カラムの別名のためのプレースホルダは、テーブルの別名によって修飾され"
-"たプロパティ名です。 下記の例では、別のテーブル cat_log から マッピングメタ"
-"データで定義された Cat とその母親を復元します。 もし好むなら、where節の中で"
+"上記で使用している {cat.*} と {mother.*} という表記は、「すべてのプロパティ」"
+"を表す省略形です。代わりに、明示的にカラムを列挙してもよいですが、その場合"
+"は、 Hibernate に各プロパティに対応する SQL カラムの別名を挿入させるべきで"
+"しょう。カラムの別名のためのプレースホルダは、テーブルの別名によって修飾され"
+"たプロパティ名です。下記の例では、別のテーブル cat_log から マッピングメタ"
+"データで定義された Cat とその母親を復元します。もし好むなら、 where 節の中で"
 "も、プロパティの別名を使えます。"
 
-#. Tag: programlisting
-#: query_sql.xml:220
-#, no-c-format
-msgid ""
-"<![CDATA[String sql = \"SELECT ID as {c.id}, NAME as {c.name}, \" + \n"
-"         \"BIRTHDATE as {c.birthDate}, MOTHER_ID as {c.mother}, {mother.*} "
-"\" +\n"
-"         \"FROM CAT_LOG c, CAT_LOG m WHERE {c.mother} = c.ID\";\n"
-"\n"
-"List loggedCats = sess.createSQLQuery(sql)\n"
-"        .addEntity(\"cat\", Cat.class)\n"
-"        .addEntity(\"mother\", Cat.class).list()\n"
-"]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:223
 #, no-c-format
 msgid "Alias and property references"
 msgstr "別名とプロパティのリファレンス"
 
 #. Tag: para
-#: query_sql.xml:225
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In most cases the above alias injection is needed. For queries relating to "
 "more complex mappings, like composite properties, inheritance "
 "discriminators, collections etc., you can use specific aliases that allow "
 "Hibernate to inject the proper aliases."
 msgstr ""
-"多くの場合、上記のような別名インジェクションが必要です。 ただし、複合プロパ"
-"ティ、継承識別子、コレクションなどのような より複雑なマッピングと関連するクエ"
-"リがなければです。 ある特定の別名を使用することにより、Hibernateは適切な別名"
+"多くの場合、上記のような別名インジェクションが必要です。ただし、複合プロパ"
+"ティ、継承識別子、コレクションなどのようなより複雑なマッピングと関連するクエ"
+"リがなければです。ある特定の別名を使用することにより、 Hibernate は適切な別名"
 "を挿入できます。"
 
 #. Tag: para
-#: query_sql.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table shows the different ways you can use the alias "
 "injection. Please note that the alias names in the result are simply "
 "examples; each alias will have a unique and probably different name when "
 "used."
 msgstr ""
-"別名インジェクションとして使用できるものを下表に示します。 注意:下表の別名は"
-"一例です。 それぞれの別名は一意であり、使用する際にはおそらく異なる名前を持ち"
+"別名インジェクションとして使用できるものを下表に示します。注記:下表の別名は"
+"一例です。それぞれの別名は一意であり、使用する際にはおそらく異なる名前を持ち"
 "ます。"
 
 #. Tag: title
-#: query_sql.xml:236
 #, no-c-format
 msgid "Alias injection names"
 msgstr "別名に挿入する名前"
 
 #. Tag: entry
-#: query_sql.xml:247
 #, no-c-format
 msgid "Description"
 msgstr "説明"
 
 #. Tag: entry
-#: query_sql.xml:249
 #, no-c-format
 msgid "Syntax"
 msgstr "æ§‹æ–‡"
 
 #. Tag: entry
-#: query_sql.xml:251
 #, no-c-format
 msgid "Example"
 msgstr "例"
 
 #. Tag: entry
-#: query_sql.xml:257
 #, no-c-format
 msgid "A simple property"
 msgstr "単純なプロパティ"
 
-#. Tag: literal
-#: query_sql.xml:259
-#, no-c-format
-msgid "{[aliasname].[propertyname]"
-msgstr "{[aliasname].[propertyname]}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].[propertyname]</literal>"
+msgstr "<literal>{[aliasname].[propertyname]</literal>"
 
-#. Tag: literal
-#: query_sql.xml:261
-#, no-c-format
-msgid "A_NAME as {item.name}"
-msgstr "A_NAME as {item.name}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>A_NAME as {item.name}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:265
 #, no-c-format
 msgid "A composite property"
 msgstr "複合プロパティ"
 
-#. Tag: literal
-#: query_sql.xml:267
-#, no-c-format
-msgid "{[aliasname].[componentname].[propertyname]}"
-msgstr "{[aliasname].[componentname].[propertyname]}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].[componentname].[propertyname]}</literal>"
+msgstr "<literal>{[aliasname].[componentname].[propertyname]}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:269
-#, no-c-format
-msgid "CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}"
-msgstr "CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}</"
+"literal>"
+msgstr ""
+"<literal>CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}</"
+"literal>"
 
 #. Tag: entry
-#: query_sql.xml:274
 #, no-c-format
 msgid "Discriminator of an entity"
 msgstr "エンティティのクラスを識別する値"
 
-#. Tag: literal
-#: query_sql.xml:276
-#, no-c-format
-msgid "{[aliasname].class}"
-msgstr "{[aliasname].class}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].class}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:278
-#, no-c-format
-msgid "DISC as {item.class}"
-msgstr "DISC as {item.class}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>DISC as {item.class}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:282
 #, no-c-format
 msgid "All properties of an entity"
 msgstr "エンティティの全プロパティ"
 
-#. Tag: literal
-#: query_sql.xml:284 query_sql.xml:332
-#, no-c-format
-msgid "{[aliasname].*}"
-msgstr "{[aliasname].*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].*}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:286
+#. Tag: entry
 #, no-c-format
-msgid "{item.*}"
-msgstr "{item.*}"
+msgid "<literal>{item.*}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:290
 #, no-c-format
 msgid "A collection key"
 msgstr "コレクションのキー"
 
-#. Tag: literal
-#: query_sql.xml:292
-#, no-c-format
-msgid "{[aliasname].key}"
-msgstr "{[aliasname].key}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].key}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:294
-#, no-c-format
-msgid "ORGID as {coll.key}"
-msgstr "ORGID as {coll.key}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>ORGID as {coll.key}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:298
 #, no-c-format
 msgid "The id of an collection"
-msgstr "コレクションのID"
+msgstr "コレクションの ID"
 
-#. Tag: literal
-#: query_sql.xml:300
-#, no-c-format
-msgid "{[aliasname].id}"
-msgstr "{[aliasname].id}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].id}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:302
-#, no-c-format
-msgid "EMPID as {coll.id}"
-msgstr "EMPID as {coll.id}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>EMPID as {coll.id}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:306
 #, no-c-format
 msgid "The element of an collection"
 msgstr "コレクションの要素"
 
-#. Tag: literal
-#: query_sql.xml:308
-#, no-c-format
-msgid "{[aliasname].element}"
-msgstr "{[aliasname].element}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element}</literal>"
+msgstr "<literal>{coll.element.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:310
-#, no-c-format
-msgid "XID as {coll.element}"
-msgstr "XID as {coll.element}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>XID as {coll.element}</literal>"
+msgstr "<literal>{coll.element.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:314
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "property of the element in the collection"
 msgstr "コレクションの要素のプロパティ"
 
-#. Tag: literal
-#: query_sql.xml:316
-#, no-c-format
-msgid "{[aliasname].element.[propertyname]}"
-msgstr "{[aliasname].element.[propertyname]}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element.[propertyname]}</literal>"
+msgstr "<literal>{[aliasname].element.[propertyname]}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:318
-#, no-c-format
-msgid "NAME as {coll.element.name}"
-msgstr "NAME as {coll.element.name}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>NAME as {coll.element.name}</literal>"
+msgstr "<literal>{coll.element.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:322
 #, no-c-format
 msgid "All properties of the element in the collection"
 msgstr "コレクションの要素の全プロパティ"
 
-#. Tag: literal
-#: query_sql.xml:324
-#, no-c-format
-msgid "{[aliasname].element.*}"
-msgstr "{[aliasname].element.*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element.*}</literal>"
+msgstr "<literal>{coll.element.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:326
+#. Tag: entry
 #, no-c-format
-msgid "{coll.element.*}"
-msgstr "{coll.element.*}"
+msgid "<literal>{coll.element.*}</literal>"
+msgstr "<literal>{coll.element.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:330
 #, no-c-format
 msgid "All properties of the the collection"
 msgstr "コレクションの全プロパティ"
 
-#. Tag: literal
-#: query_sql.xml:334
+#. Tag: entry
 #, no-c-format
-msgid "{coll.*}"
-msgstr "{coll.*}"
+msgid "<literal>{coll.*}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: title
-#: query_sql.xml:343
 #, no-c-format
 msgid "Returning non-managed entities"
 msgstr "管理されていないエンティティの取得"
 
 #. Tag: para
-#: query_sql.xml:345
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to apply a ResultTransformer to native SQL queries, allowing "
 "it to return non-managed entities."
 msgstr ""
-"ネイティブSQLクエリに ResultTransformer を適用できます。 下記のように、例え"
+"ネイティブ SQL クエリに ResultTransformer を適用できます。下記のように、例え"
 "ば、管理されていないエンティティを返します。"
 
-#. Tag: programlisting
-#: query_sql.xml:347
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT NAME, BIRTHDATE FROM CATS\")\n"
-"        .setResultTransformer(Transformers.aliasToBean(CatDTO.class))]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:357
 #, no-c-format
 msgid "a result transformer"
 msgstr "結果を変換したもの"
 
 #. Tag: para
-#: query_sql.xml:361
 #, no-c-format
 msgid ""
 "The above query will return a list of <literal>CatDTO</literal> which has "
 "been instantiated and injected the values of NAME and BIRTHNAME into its "
 "corresponding properties or fields."
 msgstr ""
-"上記のクエリは、インスタンス化し、NAME と BIRTHDATE の値を 対応するプロパティ"
+"上記のクエリは、インスタンス化し、 NAME と BIRTHDATE の値を対応するプロパティ"
 "もしくはフィールドに挿入した <literal>CatDTO</literal> のリストを返します。"
 
 #. Tag: title
-#: query_sql.xml:368
 #, no-c-format
 msgid "Handling inheritance"
 msgstr "継承の制御"
 
 #. Tag: para
-#: query_sql.xml:370
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Native SQL queries which query for entities that are mapped as part of an "
 "inheritance must include all properties for the baseclass and all its "
 "subclasses."
 msgstr ""
-"継承の一部としてマッピングされたエンティティを問い合わせるネイティブSQLクエリ"
-"は、 ベースのクラスとそのすべてのサブクラスのプロパティすべてを含まなければな"
-"りません。"
+"継承の一部としてマッピングされたエンティティを問い合わせるネイティブ SQL クエ"
+"リは、ベースのクラスとそのすべてのサブクラスのプロパティすべてを含まなければ"
+"なりません。"
 
 #. Tag: title
-#: query_sql.xml:376
 #, no-c-format
 msgid "Parameters"
 msgstr "パラメータ"
 
 #. Tag: para
-#: query_sql.xml:378
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Native SQL queries support positional as well as named parameters:"
 msgstr ""
-"ネイティブSQLクエリは、以下のように、 名前付きパラメータ(:name)と同様に位置"
-"パラメータをサポートします。"
+"ネイティブ SQL クエリは、以下のように、名前付きパラメータ(:name)と同様に位"
+"置パラメータをサポートします:"
 
-#. Tag: programlisting
-#: query_sql.xml:381
-#, no-c-format
-msgid ""
-"<![CDATA[Query query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME "
-"like ?\").addEntity(Cat.class);\n"
-"List pusList = query.setString(0, \"Pus%\").list();\n"
-"     \n"
-"query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME like :name\")."
-"addEntity(Cat.class);\n"
-"List pusList = query.setString(\"name\", \"Pus%\").list();          ]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:389
 #, no-c-format
 msgid "Named SQL queries"
-msgstr "名前付きSQLクエリ"
+msgstr "名前付き SQL クエリ"
 
 #. Tag: para
-#: query_sql.xml:391
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Named SQL queries can be defined in the mapping document and called in "
 "exactly the same way as a named HQL query. In this case, you do "
 "<emphasis>not</emphasis> need to call <literal>addEntity()</literal>."
 msgstr ""
-"名前付きSQLクエリはマッピングドキュメントで定義することができ、 名前付きHQLク"
-"エリと全く同じ方法で呼ぶことができます。 この場合、<literal>addEntity()</"
-"literal> を呼び出す必要は <emphasis>ない</emphasis> です。"
+"名前付き SQL クエリはマッピングドキュメントで定義することができ、名前付き "
+"HQL クエリと全く同じ方法で呼ぶことができます。この場合、 <literal>addEntity()"
+"</literal> を呼び出す必要は <emphasis>ありません</emphasis> 。"
 
-#. Tag: programlisting
-#: query_sql.xml:396
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"persons\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex}\n"
-"    FROM PERSON person\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_sql.xml:398
-#, no-c-format
-msgid ""
-"<![CDATA[List people = sess.getNamedQuery(\"persons\")\n"
-"    .setString(\"namePattern\", namePattern)\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:400
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>&lt;return-join&gt;</literal> element is use to join "
@@ -846,210 +617,92 @@
 "<literal>&lt;return-join&gt;</literal> と <literal>&lt;load-collection&gt;</"
 "literal> 要素を使います。"
 
-#. Tag: programlisting
-#: query_sql.xml:404
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"personsWith\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex},\n"
-"           address.STREET AS {address.street},\n"
-"           address.CITY AS {address.city},\n"
-"           address.STATE AS {address.state},\n"
-"           address.ZIP AS {address.zip}\n"
-"    FROM PERSON person\n"
-"    JOIN ADDRESS address\n"
-"        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:406
 #, no-c-format
 msgid ""
 "A named SQL query may return a scalar value. You must declare the column "
 "alias and Hibernate type using the <literal>&lt;return-scalar&gt;</literal> "
 "element:"
 msgstr ""
-"名前付きSQLクエリはスカラ値を返すこともできます。 <literal>&lt;return-"
-"scalar&gt;</literal> 要素を使って、 列の別名とHibernateの型を宣言しなければな"
-"りません。"
+"名前付き SQL クエリはスカラ値を返すこともできます。 <literal>&lt;return-"
+"scalar&gt;</literal> 要素を使って、列の別名と Hibernate の型を宣言しなければ"
+"なりません:"
 
-#. Tag: programlisting
-#: query_sql.xml:410
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-"    <return-scalar column=\"name\" type=\"string\"/>\n"
-"    <return-scalar column=\"age\" type=\"long\"/>\n"
-"    SELECT p.NAME AS name,\n"
-"           p.AGE AS age,\n"
-"    FROM PERSON p WHERE p.NAME LIKE 'Hiber%'\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:412
-#, fuzzy, no-c-format
-msgid ""
 "You can externalize the resultset mapping information in a <literal>&lt;"
 "resultset&gt;</literal> element which will allow you to either reuse them "
 "across several named queries or through the <literal>setResultSetMapping()</"
 "literal> API."
 msgstr ""
-"リザルトセットのマッピング情報を <literal>&lt;resultset&gt;</literal> に外出"
-"しすることができます。 複数の名前付きクエリで再利用したり、"
-"<literal>setResultSetMapping()</literal> APIを通して再利用したりできます。"
+"リザルトセットのマッピング情報を <literal>&lt;resultset&gt;</literal> に外部"
+"化することができます。複数の名前付きクエリで再利用したり、 "
+"<literal>setResultSetMapping()</literal> API を通して再利用したりできます。"
 
-#. Tag: programlisting
-#: query_sql.xml:417
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<resultset name=\"personAddress\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
-"</resultset>\n"
-"\n"
-"<sql-query name=\"personsWith\" resultset-ref=\"personAddress\">\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex},\n"
-"           address.STREET AS {address.street},\n"
-"           address.CITY AS {address.city},\n"
-"           address.STATE AS {address.state},\n"
-"           address.ZIP AS {address.zip}\n"
-"    FROM PERSON person\n"
-"    JOIN ADDRESS address\n"
-"        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:419
-#, fuzzy, no-c-format
-msgid ""
 "You can, alternatively, use the resultset mapping information in your hbm "
 "files directly in java code."
 msgstr ""
-"代わりに、hbmファイル内のリザルトセットのマッピング情報を 直接Javaコードの中"
-"で使用できます。"
+"代わりに、 hbm ファイル内のリザルトセットのマッピング情報を直接 Java コードの"
+"中で使用できます。"
 
-#. Tag: programlisting
-#: query_sql.xml:422
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createSQLQuery(\n"
-"        \"select {cat.*}, {kitten.*} from cats cat, cats kitten where kitten."
-"mother = cat.id\"\n"
-"    )\n"
-"    .setResultSetMapping(\"catAndKitten\")\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:425
 #, no-c-format
 msgid "Using return-property to explicitly specify column/alias names"
 msgstr "列と列の別名を明示的に指定するために return-property を使う"
 
 #. Tag: para
-#: query_sql.xml:428
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can explicitly tell Hibernate what column aliases to use with "
 "<literal>&lt;return-property&gt;</literal>, instead of using the <literal>{}"
 "</literal>-syntax to let Hibernate inject its own aliases.For example:"
 msgstr ""
 "別名を挿入するために <literal>{}</literal> 構文を使う代わりに、 <literal>&lt;"
-"return-property&gt;</literal> を使い、 どの列の別名を使うのかを明示できます。"
+"return-property&gt;</literal> を使い、どの列の別名を使うのかを明示できます。"
 
-#. Tag: programlisting
-#: query_sql.xml:433
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-"    <return alias=\"person\" class=\"eg.Person\">\n"
-"        <return-property name=\"name\" column=\"myName\"/>\n"
-"        <return-property name=\"age\" column=\"myAge\"/>\n"
-"        <return-property name=\"sex\" column=\"mySex\"/>\n"
-"    </return>\n"
-"    SELECT person.NAME AS myName,\n"
-"           person.AGE AS myAge,\n"
-"           person.SEX AS mySex,\n"
-"    FROM PERSON person WHERE person.NAME LIKE :name\n"
-"</sql-query>\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:435
-#, fuzzy, no-c-format
-msgid ""
 "<literal>&lt;return-property&gt;</literal> also works with multiple columns. "
 "This solves a limitation with the <literal>{}</literal>-syntax which cannot "
 "allow fine grained control of multi-column properties."
 msgstr ""
-"<literal>&lt;return-property&gt;</literal> は複数の列も扱えます。 これは、複"
-"数列のプロパティをきめ細かく制御できないという、 <literal>{}</literal> 構文の"
-"制限を解決します。"
+"<literal>&lt;return-property&gt;</literal> は複数の列も扱えます。これは、複数"
+"列のプロパティをきめ細かく制御できないという、 <literal>{}</literal> 構文の制"
+"限を解決します。"
 
-#. Tag: programlisting
-#: query_sql.xml:440
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"organizationCurrentEmployments\">\n"
-"    <return alias=\"emp\" class=\"Employment\">\n"
-"        <return-property name=\"salary\">\n"
-"            <return-column name=\"VALUE\"/>\n"
-"            <return-column name=\"CURRENCY\"/>\n"
-"        </return-property>\n"
-"        <return-property name=\"endDate\" column=\"myEndDate\"/>\n"
-"    </return>\n"
-"        SELECT EMPLOYEE AS {emp.employee}, EMPLOYER AS {emp.employer},\n"
-"        STARTDATE AS {emp.startDate}, ENDDATE AS {emp.endDate},\n"
-"        REGIONCODE as {emp.regionCode}, EID AS {emp.id}, VALUE, CURRENCY\n"
-"        FROM EMPLOYMENT\n"
-"        WHERE EMPLOYER = :id AND ENDDATE IS NULL\n"
-"        ORDER BY STARTDATE ASC\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:442
-#, fuzzy, no-c-format
-msgid ""
 "In this example <literal>&lt;return-property&gt;</literal> was used in "
 "combination with the <literal>{}</literal>-syntax for injection. This allows "
 "users to choose how they want to refer column and properties."
 msgstr ""
 "この例では、挿入のための <literal>{}</literal> 構文といっしょに、 "
 "<literal>&lt;return-property&gt;</literal> を使っていることに注意してくださ"
-"い。 列とプロパティをどのように参照するかを選べます。"
+"い。列とプロパティをどのように参照するかを選べます。"
 
 #. Tag: para
-#: query_sql.xml:447
 #, no-c-format
 msgid ""
 "If your mapping has a discriminator you must use <literal>&lt;return-"
 "discriminator&gt;</literal> to specify the discriminator column."
 msgstr ""
 "マッピングに discriminator が含まれている場合、 discriminator の列を指定する"
-"ために、&lt;return-discriminator&gt; を使わなければなりません。"
+"ために、 <literal>&lt;return-discriminator&gt;</literal> を使わなければなりま"
+"せん。"
 
 #. Tag: title
-#: query_sql.xml:453
 #, no-c-format
 msgid "Using stored procedures for querying"
 msgstr "問い合わせするためにストアドプロシージャを使う"
 
 #. Tag: para
-#: query_sql.xml:455
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 provides support for queries via stored procedures and functions. "
 "Most of the following documentation is equivalent for both. The stored "
@@ -1057,80 +710,37 @@
 "able to work with Hibernate. An example of such a stored function in Oracle "
 "9 and higher is as follows:"
 msgstr ""
-"Hibernateはバージョン3から、ストアドプロシージャとストアド関数経由の問い合わ"
-"せが サポートされました。 以降の文書の多くは、両方に当てはまります。 ストアド"
-"プロシージャやストアド関数をHibernateで使うためには、 1番目の出力パラメータと"
+"Hibernate はバージョン3から、ストアドプロシージャとストアド関数経由の問い合わ"
+"せがサポートされました。以降の文書の多くは、両方に当てはまります。ストアドプ"
+"ロシージャやストアド関数を Hibernate で使うためには、1番目の出力パラメータと"
 "してリザルトセットを返さなければなりません。 Oracle 9(もしくはそれ以上のバー"
-"ジョン)のストアドプロシージャの例を以下に示します。"
+"ジョン)のストアドプロシージャの例を以下に示します:"
 
-#. Tag: programlisting
-#: query_sql.xml:461
-#, no-c-format
-msgid ""
-"<![CDATA[CREATE OR REPLACE FUNCTION selectAllEmployments\n"
-"    RETURN SYS_REFCURSOR\n"
-"AS\n"
-"    st_cursor SYS_REFCURSOR;\n"
-"BEGIN\n"
-"    OPEN st_cursor FOR\n"
-" SELECT EMPLOYEE, EMPLOYER,\n"
-" STARTDATE, ENDDATE,\n"
-" REGIONCODE, EID, VALUE, CURRENCY\n"
-" FROM EMPLOYMENT;\n"
-"      RETURN  st_cursor;\n"
-" END;]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:463
 #, no-c-format
 msgid "To use this query in Hibernate you need to map it via a named query."
 msgstr ""
-"Hibernateでこのクエリを使うためには、 名前付きクエリでマッピングする必要があ"
+"Hibernate でこのクエリを使うためには、名前付きクエリでマッピングする必要があ"
 "ります。"
 
-#. Tag: programlisting
-#: query_sql.xml:466
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"selectAllEmployees_SP\" callable=\"true\">\n"
-"    <return alias=\"emp\" class=\"Employment\">\n"
-"        <return-property name=\"employee\" column=\"EMPLOYEE\"/>\n"
-"        <return-property name=\"employer\" column=\"EMPLOYER\"/>\n"
-"        <return-property name=\"startDate\" column=\"STARTDATE\"/>\n"
-"        <return-property name=\"endDate\" column=\"ENDDATE\"/>\n"
-"        <return-property name=\"regionCode\" column=\"REGIONCODE\"/>\n"
-"        <return-property name=\"id\" column=\"EID\"/>\n"
-"        <return-property name=\"salary\">\n"
-"            <return-column name=\"VALUE\"/>\n"
-"            <return-column name=\"CURRENCY\"/>\n"
-"        </return-property>\n"
-"    </return>\n"
-"    { ? = call selectAllEmployments() }\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:468
-#, fuzzy, no-c-format
-msgid ""
 "Stored procedures currently only return scalars and entities. <literal>&lt;"
 "return-join&gt;</literal> and <literal>&lt;load-collection&gt;</literal> are "
 "not supported."
 msgstr ""
-"注意:今のところ、ストアドプロシージャはスカラとエンティティを返すのみです。 "
+"注記:今のところ、ストアドプロシージャはスカラとエンティティを返すのみです。 "
 "<literal>&lt;return-join&gt;</literal> と <literal>&lt;load-collection&gt;</"
 "literal> はサポートされていません。"
 
 #. Tag: title
-#: query_sql.xml:473
 #, no-c-format
 msgid "Rules/limitations for using stored procedures"
 msgstr "ストアドプロシージャを使う上でのルールと制限"
 
 #. Tag: para
-#: query_sql.xml:475
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You cannot use stored procedures with Hibernate unless you follow some "
 "procedure/function rules. If they do not follow those rules they are not "
@@ -1139,45 +749,41 @@
 "different for each database, since database vendors have different stored "
 "procedure semantics/syntax."
 msgstr ""
-"Hibernateでストアドプロシージャや関数を使うためには、 そのプロシージャはいく"
-"つかのルールに準拠する必要があります。 ルールに準拠していないプロシージャは、"
-"Hibernateで使うことはできません。 それでも、準拠していないプロシージャを使い"
+"Hibernate でストアドプロシージャや関数を使うためには、そのプロシージャはいく"
+"つかのルールに準拠する必要があります。ルールに準拠していないプロシージャは、 "
+"Hibernate で使うことはできません。それでも、準拠していないプロシージャを使い"
 "たいのであれば、 <literal>session.connection()</literal> を通じて実行しなけれ"
-"ばなりません。 ルールはデータベースごとに異なります。 ストアドプロシージャの"
-"セマンティックスとシンタックスは、 データベースベンダごとに異なるためです。"
+"ばなりません。ルールはデータベースごとに異なります。ストアドプロシージャのセ"
+"マンティックスとシンタックスは、データベースベンダごとに異なるためです。"
 
 #. Tag: para
-#: query_sql.xml:482
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Stored procedure queries cannot be paged with <literal>setFirstResult()/"
 "setMaxResults()</literal>."
 msgstr ""
-"<literal>setFirstResult()/setMaxResults()</literal> を使って、 ストアドプロ"
+"<literal>setFirstResult()/setMaxResults()</literal> を使って、ストアドプロ"
 "シージャクエリをページ分けすることはできません。"
 
 #. Tag: para
-#: query_sql.xml:485
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The recommended call form is standard SQL92: <literal>{ ? = call functionName"
 "(&lt;parameters&gt;) }</literal> or <literal>{ ? = call procedureName(&lt;"
 "parameters&gt;}</literal>. Native call syntax is not supported."
 msgstr ""
-"推奨する呼び出し方は、標準であるSQL92に従うことです。 <literal>{ ? = call "
+"推奨する呼び出し方は、標準である SQL92 に従うことです。 <literal>{ ? = call "
 "functionName(&lt;parameters&gt;) }</literal> ã‚„ <literal>{ ? = call "
-"procedureName(&lt;parameters&gt;) }</literal> です。 ネイティブな呼び出し構文"
-"はサポートされていません。"
+"procedureName(&lt;parameters&gt;}</literal> です。ネイティブな呼び出し構文は"
+"サポートされていません。"
 
 #. Tag: para
-#: query_sql.xml:490
 #, no-c-format
 msgid "For Oracle the following rules apply:"
-msgstr "Oracleには下記のルールが適用されます。"
+msgstr "Oracle には下記のルールが適用されます:"
 
 #. Tag: para
-#: query_sql.xml:494
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A function must return a result set. The first parameter of a procedure must "
 "be an <literal>OUT</literal> that returns a result set. This is done by "
@@ -1185,131 +791,98 @@
 "you need to define a <literal>REF CURSOR</literal> type. See Oracle "
 "literature for further information."
 msgstr ""
-"関数はリザルトセットを返さなければなりません。 プロシージャの第一引数はリザル"
-"トセットを返すため、 <literal>OUT</literal> でなければなりません。 Oracle 9と"
-"10では、<literal>SYS_REFCURSOR</literal> を使うことによってできます。 Oracle"
-"では <literal>REF CURSOR</literal> 型を定義する必要があります。 Oracleの文献"
-"を参照してください。"
+"関数はリザルトセットを返さなければなりません。プロシージャの第一引数はリザル"
+"トセットを返すため、 <literal>OUT</literal> でなければなりません。 Oracle 9 "
+"と 10 では、 <literal>SYS_REFCURSOR</literal> を使うことによってできます。 "
+"Oracle では <literal>REF CURSOR</literal> 型を定義する必要があります。 "
+"Oracle の文献を参照してください。"
 
 #. Tag: para
-#: query_sql.xml:503
 #, no-c-format
 msgid "For Sybase or MS SQL server the following rules apply:"
-msgstr "SybaseとMS SQLサーバーに適用されるルールを下記に示します。"
+msgstr "Sybase と MS SQL サーバーに適用されるルールを下記に示します:"
 
 #. Tag: para
-#: query_sql.xml:507
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The procedure must return a result set. Note that since these servers can "
 "return multiple result sets and update counts, Hibernate will iterate the "
 "results and take the first result that is a result set as its return value. "
 "Everything else will be discarded."
 msgstr ""
-"プロシージャはリザルトセットを返さなければなりません。 サーバーは複数のリザル"
-"トセットと更新カウントを返しますが、 Hibernateは1つ目のリザルトセットだけを返"
-"すことに注意してください。 その他はすべて捨てられます。"
+"プロシージャはリザルトセットを返さなければなりません。サーバーは複数のリザル"
+"トセットと更新カウントを返しますが、 Hibernate は1つ目のリザルトセットだけを"
+"返すことに注意してください。その他はすべて捨てられます。"
 
 #. Tag: para
-#: query_sql.xml:515
 #, no-c-format
 msgid ""
 "If you can enable <literal>SET NOCOUNT ON</literal> in your procedure it "
 "will probably be more efficient, but this is not a requirement."
 msgstr ""
-"プロシージャの中で <literal>SET NOCOUNT ON</literal> を有効にできれば、 おそ"
-"らく効率がよくなるでしょう。 しかし、これは必要条件ではありません。"
+"プロシージャの中で <literal>SET NOCOUNT ON</literal> を有効にできれば、おそら"
+"く効率がよくなるでしょう。しかし、これは必要条件ではありません。"
 
 #. Tag: title
-#: query_sql.xml:525
 #, no-c-format
 msgid "Custom SQL for create, update and delete"
-msgstr "作成、更新、削除のためのカスタムSQL"
+msgstr "作成、更新、削除のためのカスタム SQL"
 
 #. Tag: para
-#: query_sql.xml:527
 #, no-c-format
 msgid ""
-"Hibernate3 can use custom SQL statements for create, update, and delete "
-"operations. The class and collection persisters in Hibernate already contain "
-"a set of configuration time generated strings (insertsql, deletesql, "
-"updatesql etc.). The mapping tags <literal>&lt;sql-insert&gt;</literal>, "
-"<literal>&lt;sql-delete&gt;</literal>, and <literal>&lt;sql-update&gt;</"
-"literal> override these strings:"
+"Hibernate3 can use custom SQL for create, update, and delete operations. The "
+"SQL can be overridden at the statement level or inidividual column level. "
+"This section describes statement overrides. For columns, see <xref linkend="
+"\"mapping-column-read-and-write\" />."
 msgstr ""
-"Hibernate3は作成、更新、削除処理のためのカスタムSQL文を使用できます。 クラス"
-"とコレクションの永続化機構は、コンフィグレーション時に生成された文字列 "
-"(insertsql、deletesql、updatesqlなど)のセットをすでに保持しています。 これ"
-"らの文字列より、 <literal>&lt;sql-insert&gt;</literal>、 <literal>&lt;sql-"
-"delete&gt;</literal>、 <literal>&lt;sql-update&gt;</literal> というマッピング"
-"タグが優先されます。"
 
-#. Tag: programlisting
-#: query_sql.xml:535
-#, no-c-format
+#. Tag: para
+#, fuzzy, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <sql-insert>INSERT INTO PERSON (NAME, ID) VALUES ( UPPER(?), ? )</sql-"
-"insert>\n"
-"    <sql-update>UPDATE PERSON SET NAME=UPPER(?) WHERE ID=?</sql-update>\n"
-"    <sql-delete>DELETE FROM PERSON WHERE ID=?</sql-delete>\n"
-"</class>]]>"
+"The class and collection persisters in Hibernate already contain a set of "
+"configuration time generated strings (insertsql, deletesql, updatesql etc.). "
+"The mapping tags <literal>&lt;sql-insert&gt;</literal>, <literal>&lt;sql-"
+"delete&gt;</literal>, and <literal>&lt;sql-update&gt;</literal> override "
+"these strings:"
 msgstr ""
+"Hibernate3 は作成、更新、削除処理のためのカスタム SQL 文を使用できます。クラ"
+"スとコレクションの永続化機構は、コンフィグレーション時に生成された文字列 "
+"(insertsql、deletesql、updatesql など)のセットをすでに保持しています。これ"
+"らの文字列より、 <literal>&lt;sql-insert&gt;</literal>、 <literal>&lt;sql-"
+"delete&gt;</literal>、 <literal>&lt;sql-update&gt;</literal> というマッピング"
+"タグが優先されます:"
 
 #. Tag: para
-#: query_sql.xml:537
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The SQL is directly executed in your database, so you can use any dialect "
 "you like. This will reduce the portability of your mapping if you use "
 "database specific SQL."
 msgstr ""
-"SQLを直接データベースで実行するため、好みの方言を自由に使用できます。 データ"
-"ベース独自のSQLを使えば、当然マッピングのポータビリティが下がります。"
+"SQL を直接データベースで実行するため、好みの方言を自由に使用できます。データ"
+"ベース独自の SQL を使えば、当然マッピングのポータビリティが下がります。"
 
 #. Tag: para
-#: query_sql.xml:541
 #, no-c-format
 msgid ""
 "Stored procedures are supported if the <literal>callable</literal> attribute "
 "is set:"
 msgstr ""
-"<literal>callable</literal> 属性をセットすれば、 ストアドプロシージャを使用で"
-"きます。"
+"<literal>callable</literal> 属性をセットすれば、ストアドプロシージャを使用で"
+"きます:"
 
-#. Tag: programlisting
-#: query_sql.xml:544
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <sql-insert callable=\"true\">{call createPerson (?, ?)}</sql-insert>\n"
-"    <sql-delete callable=\"true\">{? = call deletePerson (?)}</sql-delete>\n"
-"    <sql-update callable=\"true\">{? = call updatePerson (?, ?)}</sql-"
-"update>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:546
-#, fuzzy, no-c-format
-msgid ""
 "The order of the positional parameters is vital, as they must be in the same "
 "sequence as Hibernate expects them."
 msgstr ""
-"今のところ、位置パラメータの順番はとても重要です。 すなわち、Hibernateが期待"
+"今のところ、位置パラメータの順番はとても重要です。すなわち、 Hibernate が期待"
 "する順序でなければなりません。"
 
 #. Tag: para
-#: query_sql.xml:549
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can view the expected order by enabling debug logging for the "
 "<literal>org.hibernate.persister.entity</literal> level. With this level "
@@ -1318,153 +891,728 @@
 "your custom SQL in the mapping files, as this will override the Hibernate "
 "generated static SQL."
 msgstr ""
-"<literal>org.hiberante.persister.entity</literal> レベルのデバッグログを 有効"
-"にすることによって、期待される順番を確かめられます。 このレベルを有効にするこ"
-"とにより、エンティティの作成、更新、削除などで 使用される静的なSQLが出力され"
-"ます。 (期待される順序を確認するためには、Hibernateが生成する静的なSQLをオー"
-"バーライドする カスタムSQLをマッピングファイルに含めないことを忘れないでくだ"
-"さい。)"
+"<literal>org.hiberante.persister.entity</literal> レベルのデバッグログを有効"
+"にすることによって、期待される順番を確かめられます。このレベルを有効にするこ"
+"とにより、エンティティの作成、更新、削除などで使用される静的な SQL が出力され"
+"ます。(期待される順序を確認するためには、 Hibernate が生成する静的な SQL を"
+"オーバーライドするカスタム SQL をマッピングファイルに含めないことを忘れないで"
+"ください。)"
 
 #. Tag: para
-#: query_sql.xml:556
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The stored procedures are in most cases required to return the number of "
 "rows inserted, updated and deleted, as Hibernate has some runtime checks for "
 "the success of the statement. Hibernate always registers the first statement "
 "parameter as a numeric output parameter for the CUD operations:"
 msgstr ""
-"ストアドプロシージャは挿入/更新/削除された行数を返す必要があります (読み込み"
-"の場合は、返さないよりは返す方がよいです)。 実行時にHibernateがSQL文の成功を"
-"チェックするからです。 Hibernateは、CUD処理のための数値の出力パラメータとし"
-"て、 SQL文の最初のパラメータをいつも記録します。"
+"ストアドプロシージャは挿入/更新/削除された行数を返す必要があります(読み込み"
+"の場合は、返さないよりは返す方がよいです)。実行時に Hibernate が SQL 文の成"
+"功をチェックするからです。 Hibernate は、 CUD 処理のための数値の出力パラメー"
+"タとして、 SQL 文の最初のパラメータをいつも記録します:"
 
-#. Tag: programlisting
-#: query_sql.xml:562
-#, no-c-format
-msgid ""
-"<![CDATA[CREATE OR REPLACE FUNCTION updatePerson (uid IN NUMBER, uname IN "
-"VARCHAR2)\n"
-"    RETURN NUMBER IS\n"
-"BEGIN\n"
-"\n"
-"    update PERSON\n"
-"    set\n"
-"        NAME = uname,\n"
-"    where\n"
-"        ID = uid;\n"
-"\n"
-"    return SQL%ROWCOUNT;\n"
-"\n"
-"END updatePerson;]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:566
 #, no-c-format
 msgid "Custom SQL for loading"
-msgstr "ロードのためのカスタムSQL"
+msgstr "ロードのためのカスタム SQL"
 
 #. Tag: para
-#: query_sql.xml:568
-#, fuzzy, no-c-format
-msgid "You can also declare your own SQL (or HQL) queries for entity loading:"
-msgstr ""
-"エンティティを読み込むための独自のSQL(もしくはHQL)クエリも宣言できます。"
-
-#. Tag: programlisting
-#: query_sql.xml:571
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"person\">\n"
-"    <return alias=\"pers\" class=\"Person\" lock-mode=\"upgrade\"/>\n"
-"    SELECT NAME AS {pers.name}, ID AS {pers.id}\n"
-"    FROM PERSON\n"
-"    WHERE ID=?\n"
-"    FOR UPDATE\n"
-"</sql-query>]]>"
+"You can also declare your own SQL (or HQL) queries for entity loading. As "
+"with inserts, updates, and deletes, this can be done at the individual "
+"column level as described in <xref linkend=\"mapping-column-read-and-write"
+"\" /> or at the statement level. Here is an example of a statement level "
+"override:"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:573
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is just a named query declaration, as discussed earlier. You can "
 "reference this named query in a class mapping:"
 msgstr ""
-"これは、まさに(以前議論した)名前付きクエリの宣言です。 この名前付きクエリを"
-"クラスのマッピングから参照できます。"
+"これは、まさに(以前議論した)名前付きクエリの宣言です。この名前付きクエリを"
+"クラスのマッピングから参照できます:"
 
-#. Tag: programlisting
-#: query_sql.xml:576
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <loader query-ref=\"person\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:578
 #, no-c-format
 msgid "This even works with stored procedures."
 msgstr "これはストアドプロシージャでさえも動作します。"
 
 #. Tag: para
-#: query_sql.xml:580
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can even define a query for collection loading:"
-msgstr "次のように、コレクションをロードするためのクエリさえ定義してよいです。"
+msgstr "次のように、コレクションをロードするためのクエリさえ定義してよいです:"
 
-#. Tag: programlisting
-#: query_sql.xml:582
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"employments\" inverse=\"true\">\n"
-"    <key/>\n"
-"    <one-to-many class=\"Employment\"/>\n"
-"    <loader query-ref=\"employments\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_sql.xml:584
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"employments\">\n"
-"    <load-collection alias=\"emp\" role=\"Person.employments\"/>\n"
-"    SELECT {emp.*}\n"
-"    FROM EMPLOYMENT emp\n"
-"    WHERE EMPLOYER = :id\n"
-"    ORDER BY STARTDATE ASC, EMPLOYEE ASC\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:586
-#, fuzzy, no-c-format
-msgid ""
 "You can also define an entity loader that loads a collection by join "
 "fetching:"
 msgstr ""
-"次のように、結合フェッチによりコレクションをロードする エンティティローダーを"
-"定義できます。"
+"次のように、結合フェッチによりコレクションをロードするエンティティローダーを"
+"定義できます:"
 
-#. Tag: programlisting
-#: query_sql.xml:589
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"person\">\n"
-"    <return alias=\"pers\" class=\"Person\"/>\n"
-"    <return-join alias=\"emp\" property=\"pers.employments\"/>\n"
-"    SELECT NAME AS {pers.*}, {emp.*}\n"
-"    FROM PERSON pers\n"
-"    LEFT OUTER JOIN EMPLOYMENT emp\n"
-"        ON pers.ID = emp.PERSON_ID\n"
-"    WHERE ID=?\n"
-"</sql-query>]]>"
-msgstr ""
+#~ msgid ""
+#~ "You can also declare your own SQL (or HQL) queries for entity loading:"
+#~ msgstr ""
+#~ "エンティティを読み込むための独自の SQL (もしくは HQL)クエリも宣言できま"
+#~ "す:"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").list();\n"
+#~ "sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").list();\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT * FROM CATS\").list();\n"
+#~ "sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
+#~ " .addScalar(\"ID\", Hibernate.LONG)\n"
+#~ " .addScalar(\"NAME\", Hibernate.STRING)\n"
+#~ " .addScalar(\"BIRTHDATE\", Hibernate.DATE)\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
+#~ " .addScalar(\"ID\", Hibernate.LONG)\n"
+#~ " .addScalar(\"NAME\", Hibernate.STRING)\n"
+#~ " .addScalar(\"BIRTHDATE\", Hibernate.DATE)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
+#~ " .addScalar(\"ID\", Hibernate.LONG)\n"
+#~ " .addScalar(\"NAME\")\n"
+#~ " .addScalar(\"BIRTHDATE\")\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
+#~ " .addScalar(\"ID\", Hibernate.LONG)\n"
+#~ " .addScalar(\"NAME\")\n"
+#~ " .addScalar(\"BIRTHDATE\")"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").addEntity(Cat."
+#~ "class);\n"
+#~ "sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").addEntity"
+#~ "(Cat.class);\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT * FROM CATS\").addEntity(Cat.class);\n"
+#~ "sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").addEntity"
+#~ "(Cat.class);"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, DOG_ID FROM "
+#~ "CATS\").addEntity(Cat.class);\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, DOG_ID FROM CATS\")."
+#~ "addEntity(Cat.class);"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT c.ID, NAME, BIRTHDATE, DOG_ID, "
+#~ "D_ID, D_NAME FROM CATS c, DOGS d WHERE c.DOG_ID = d.D_ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addJoin(\"cat.dog\");\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT c.ID, NAME, BIRTHDATE, DOG_ID, D_ID, D_NAME "
+#~ "FROM CATS c, DOGS d \n"
+#~ "    WHERE c.DOG_ID = d.D_ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addJoin(\"cat.dog\");"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, D_ID, D_NAME, "
+#~ "CAT_ID FROM CATS c, DOGS d WHERE c.ID = d.CAT_ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addJoin(\"cat.dogs\");\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, D_ID, D_NAME, CAT_ID "
+#~ "FROM CATS c, DOGS d\n"
+#~ "    WHERE c.ID = d.CAT_ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addJoin(\"cat.dogs\");"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT c.*, m.*  FROM CATS c, CATS m WHERE "
+#~ "c.MOTHER_ID = c.ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addEntity(\"mother\", Cat.class)\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT c.*, m.*  FROM CATS c, CATS m WHERE c."
+#~ "MOTHER_ID = c.ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addEntity(\"mother\", Cat.class)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT {cat.*}, {mother.*}  FROM CATS c, "
+#~ "CATS m WHERE c.MOTHER_ID = c.ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addEntity(\"mother\", Cat.class)\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT {cat.*}, {mother.*}  FROM CATS c, CATS m "
+#~ "WHERE c.MOTHER_ID = c.ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addEntity(\"mother\", Cat.class)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[String sql = \"SELECT ID as {c.id}, NAME as {c.name}, \" + \n"
+#~ "         \"BIRTHDATE as {c.birthDate}, MOTHER_ID as {c.mother}, {mother."
+#~ "*} \" +\n"
+#~ "         \"FROM CAT_LOG c, CAT_LOG m WHERE {c.mother} = c.ID\";\n"
+#~ "\n"
+#~ "List loggedCats = sess.createSQLQuery(sql)\n"
+#~ "        .addEntity(\"cat\", Cat.class)\n"
+#~ "        .addEntity(\"mother\", Cat.class).list()\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "String sql = \"SELECT ID as {c.id}, NAME as {c.name}, \" + \n"
+#~ "         \"BIRTHDATE as {c.birthDate}, MOTHER_ID as {c.mother}, {mother."
+#~ "*} \" +\n"
+#~ "         \"FROM CAT_LOG c, CAT_LOG m WHERE {c.mother} = c.ID\";\n"
+#~ "\n"
+#~ "List loggedCats = sess.createSQLQuery(sql)\n"
+#~ "        .addEntity(\"cat\", Cat.class)\n"
+#~ "        .addEntity(\"mother\", Cat.class).list()"
+
+#, fuzzy
+#~ msgid "A_NAME as {item.name}"
+#~ msgstr "<literal>A_NAME as {item.name}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].class}"
+#~ msgstr "<literal>{[aliasname].class}</literal>"
+
+#, fuzzy
+#~ msgid "DISC as {item.class}"
+#~ msgstr "<literal>DISC as {item.class}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].*}"
+#~ msgstr "<literal>{[aliasname].*}</literal>"
+
+#~ msgid "{item.*}"
+#~ msgstr "{item.*}"
+
+#, fuzzy
+#~ msgid "{[aliasname].key}"
+#~ msgstr "<literal>{[aliasname].key}</literal>"
+
+#, fuzzy
+#~ msgid "ORGID as {coll.key}"
+#~ msgstr "<literal>ORGID as {coll.key}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].id}"
+#~ msgstr "<literal>{[aliasname].id}</literal>"
+
+#, fuzzy
+#~ msgid "EMPID as {coll.id}"
+#~ msgstr "<literal>EMPID as {coll.id}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].element}"
+#~ msgstr "<literal>{[aliasname].element}</literal>"
+
+#, fuzzy
+#~ msgid "XID as {coll.element}"
+#~ msgstr "<literal>XID as {coll.element}</literal>"
+
+#, fuzzy
+#~ msgid "NAME as {coll.element.name}"
+#~ msgstr "<literal>NAME as {coll.element.name}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].element.*}"
+#~ msgstr "<literal>{[aliasname].element.*}</literal>"
+
+#, fuzzy
+#~ msgid "{coll.element.*}"
+#~ msgstr "{coll.*}"
+
+#~ msgid "{coll.*}"
+#~ msgstr "{coll.*}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT NAME, BIRTHDATE FROM CATS\")\n"
+#~ "        .setResultTransformer(Transformers.aliasToBean(CatDTO.class))]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT NAME, BIRTHDATE FROM CATS\")\n"
+#~ "        .setResultTransformer(Transformers.aliasToBean(CatDTO.class))"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Query query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE "
+#~ "NAME like ?\").addEntity(Cat.class);\n"
+#~ "List pusList = query.setString(0, \"Pus%\").list();\n"
+#~ "     \n"
+#~ "query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME like :name\")."
+#~ "addEntity(Cat.class);\n"
+#~ "List pusList = query.setString(\"name\", \"Pus%\").list();          ]]>"
+#~ msgstr ""
+#~ "Query query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME like ?"
+#~ "\").addEntity(Cat.class);\n"
+#~ "List pusList = query.setString(0, \"Pus&#37;\").list();\n"
+#~ "     \n"
+#~ "query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME like :name\")."
+#~ "addEntity(Cat.class);\n"
+#~ "List pusList = query.setString(\"name\", \"Pus&#37;\").list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"persons\">\n"
+#~ "    <return alias=\"person\" class=\"eg.Person\"/>\n"
+#~ "    SELECT person.NAME AS {person.name},\n"
+#~ "           person.AGE AS {person.age},\n"
+#~ "           person.SEX AS {person.sex}\n"
+#~ "    FROM PERSON person\n"
+#~ "    WHERE person.NAME LIKE :namePattern\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"persons\"&gt;\n"
+#~ "    &lt;return alias=\"person\" class=\"eg.Person\"/&gt;\n"
+#~ "    SELECT person.NAME AS {person.name},\n"
+#~ "           person.AGE AS {person.age},\n"
+#~ "           person.SEX AS {person.sex}\n"
+#~ "    FROM PERSON person\n"
+#~ "    WHERE person.NAME LIKE :namePattern\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List people = sess.getNamedQuery(\"persons\")\n"
+#~ "    .setString(\"namePattern\", namePattern)\n"
+#~ "    .setMaxResults(50)\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List people = sess.getNamedQuery(\"persons\")\n"
+#~ "    .setString(\"namePattern\", namePattern)\n"
+#~ "    .setMaxResults(50)\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"personsWith\">\n"
+#~ "    <return alias=\"person\" class=\"eg.Person\"/>\n"
+#~ "    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
+#~ "    SELECT person.NAME AS {person.name},\n"
+#~ "           person.AGE AS {person.age},\n"
+#~ "           person.SEX AS {person.sex},\n"
+#~ "           address.STREET AS {address.street},\n"
+#~ "           address.CITY AS {address.city},\n"
+#~ "           address.STATE AS {address.state},\n"
+#~ "           address.ZIP AS {address.zip}\n"
+#~ "    FROM PERSON person\n"
+#~ "    JOIN ADDRESS address\n"
+#~ "        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
+#~ "    WHERE person.NAME LIKE :namePattern\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"personsWith\"&gt;\n"
+#~ "    &lt;return alias=\"person\" class=\"eg.Person\"/&gt;\n"
+#~ "    &lt;return-join alias=\"address\" property=\"person.mailingAddress\"/"
+#~ "&gt;\n"
+#~ "    SELECT person.NAME AS {person.name},\n"
+#~ "           person.AGE AS {person.age},\n"
+#~ "           person.SEX AS {person.sex},\n"
+#~ "           adddress.STREET AS {address.street},\n"
+#~ "           adddress.CITY AS {address.city},\n"
+#~ "           adddress.STATE AS {address.state},\n"
+#~ "           adddress.ZIP AS {address.zip}\n"
+#~ "    FROM PERSON person\n"
+#~ "    JOIN ADDRESS adddress\n"
+#~ "        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
+#~ "    WHERE person.NAME LIKE :namePattern\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"mySqlQuery\">\n"
+#~ "    <return-scalar column=\"name\" type=\"string\"/>\n"
+#~ "    <return-scalar column=\"age\" type=\"long\"/>\n"
+#~ "    SELECT p.NAME AS name,\n"
+#~ "           p.AGE AS age,\n"
+#~ "    FROM PERSON p WHERE p.NAME LIKE 'Hiber%'\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"mySqlQuery\"&gt;\n"
+#~ "    &lt;return-scalar column=\"name\" type=\"string\"/&gt;\n"
+#~ "    &lt;return-scalar column=\"age\" type=\"long\"/&gt;\n"
+#~ "    SELECT p.NAME AS name,\n"
+#~ "           p.AGE AS age,\n"
+#~ "    FROM PERSON p WHERE p.NAME LIKE 'Hiber&#37;'\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<resultset name=\"personAddress\">\n"
+#~ "    <return alias=\"person\" class=\"eg.Person\"/>\n"
+#~ "    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
+#~ "</resultset>\n"
+#~ "\n"
+#~ "<sql-query name=\"personsWith\" resultset-ref=\"personAddress\">\n"
+#~ "    SELECT person.NAME AS {person.name},\n"
+#~ "           person.AGE AS {person.age},\n"
+#~ "           person.SEX AS {person.sex},\n"
+#~ "           address.STREET AS {address.street},\n"
+#~ "           address.CITY AS {address.city},\n"
+#~ "           address.STATE AS {address.state},\n"
+#~ "           address.ZIP AS {address.zip}\n"
+#~ "    FROM PERSON person\n"
+#~ "    JOIN ADDRESS address\n"
+#~ "        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
+#~ "    WHERE person.NAME LIKE :namePattern\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;resultset name=\"personAddress\"&gt;\n"
+#~ "    &lt;return alias=\"person\" class=\"eg.Person\"/&gt;\n"
+#~ "    &lt;return-join alias=\"address\" property=\"person.mailingAddress\"/"
+#~ "&gt;\n"
+#~ "&lt;/resultset&gt;\n"
+#~ "\n"
+#~ "&lt;sql-query name=\"personsWith\" resultset-ref=\"personAddress\"&gt;\n"
+#~ "    SELECT person.NAME AS {person.name},\n"
+#~ "           person.AGE AS {person.age},\n"
+#~ "           person.SEX AS {person.sex},\n"
+#~ "           adddress.STREET AS {address.street},\n"
+#~ "           adddress.CITY AS {address.city},\n"
+#~ "           adddress.STATE AS {address.state},\n"
+#~ "           adddress.ZIP AS {address.zip}\n"
+#~ "    FROM PERSON person\n"
+#~ "    JOIN ADDRESS adddress\n"
+#~ "        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
+#~ "    WHERE person.NAME LIKE :namePattern\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createSQLQuery(\n"
+#~ "        \"select {cat.*}, {kitten.*} from cats cat, cats kitten where "
+#~ "kitten.mother = cat.id\"\n"
+#~ "    )\n"
+#~ "    .setResultSetMapping(\"catAndKitten\")\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createSQLQuery(\n"
+#~ "        \"select {cat.*}, {kitten.*} from cats cat, cats kitten where "
+#~ "kitten.mother = cat.id\"\n"
+#~ "    )\n"
+#~ "    .setResultSetMapping(\"catAndKitten\")\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"mySqlQuery\">\n"
+#~ "    <return alias=\"person\" class=\"eg.Person\">\n"
+#~ "        <return-property name=\"name\" column=\"myName\"/>\n"
+#~ "        <return-property name=\"age\" column=\"myAge\"/>\n"
+#~ "        <return-property name=\"sex\" column=\"mySex\"/>\n"
+#~ "    </return>\n"
+#~ "    SELECT person.NAME AS myName,\n"
+#~ "           person.AGE AS myAge,\n"
+#~ "           person.SEX AS mySex,\n"
+#~ "    FROM PERSON person WHERE person.NAME LIKE :name\n"
+#~ "</sql-query>\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"mySqlQuery\"&gt;\n"
+#~ "    &lt;return alias=\"person\" class=\"eg.Person\"&gt;\n"
+#~ "        &lt;return-property name=\"name\" column=\"myName\"/&gt;\n"
+#~ "        &lt;return-property name=\"age\" column=\"myAge\"/&gt;\n"
+#~ "        &lt;return-property name=\"sex\" column=\"mySex\"/&gt;\n"
+#~ "    &lt;/return&gt;\n"
+#~ "    SELECT person.NAME AS myName,\n"
+#~ "           person.AGE AS myAge,\n"
+#~ "           person.SEX AS mySex,\n"
+#~ "    FROM PERSON person WHERE person.NAME LIKE :name\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"organizationCurrentEmployments\">\n"
+#~ "    <return alias=\"emp\" class=\"Employment\">\n"
+#~ "        <return-property name=\"salary\">\n"
+#~ "            <return-column name=\"VALUE\"/>\n"
+#~ "            <return-column name=\"CURRENCY\"/>\n"
+#~ "        </return-property>\n"
+#~ "        <return-property name=\"endDate\" column=\"myEndDate\"/>\n"
+#~ "    </return>\n"
+#~ "        SELECT EMPLOYEE AS {emp.employee}, EMPLOYER AS {emp.employer},\n"
+#~ "        STARTDATE AS {emp.startDate}, ENDDATE AS {emp.endDate},\n"
+#~ "        REGIONCODE as {emp.regionCode}, EID AS {emp.id}, VALUE, CURRENCY\n"
+#~ "        FROM EMPLOYMENT\n"
+#~ "        WHERE EMPLOYER = :id AND ENDDATE IS NULL\n"
+#~ "        ORDER BY STARTDATE ASC\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"organizationCurrentEmployments\"&gt;\n"
+#~ "    &lt;return alias=\"emp\" class=\"Employment\"&gt;\n"
+#~ "        &lt;return-property name=\"salary\"&gt;\n"
+#~ "            &lt;return-column name=\"VALUE\"/&gt;\n"
+#~ "            &lt;return-column name=\"CURRENCY\"/&gt;\n"
+#~ "        &lt;/return-property&gt;\n"
+#~ "        &lt;return-property name=\"endDate\" column=\"myEndDate\"/&gt;\n"
+#~ "    &lt;/return&gt;\n"
+#~ "        SELECT EMPLOYEE AS {emp.employee}, EMPLOYER AS {emp.employer},\n"
+#~ "        STARTDATE AS {emp.startDate}, ENDDATE AS {emp.endDate},\n"
+#~ "        REGIONCODE as {emp.regionCode}, EID AS {emp.id}, VALUE, CURRENCY\n"
+#~ "        FROM EMPLOYMENT\n"
+#~ "        WHERE EMPLOYER = :id AND ENDDATE IS NULL\n"
+#~ "        ORDER BY STARTDATE ASC\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[CREATE OR REPLACE FUNCTION selectAllEmployments\n"
+#~ "    RETURN SYS_REFCURSOR\n"
+#~ "AS\n"
+#~ "    st_cursor SYS_REFCURSOR;\n"
+#~ "BEGIN\n"
+#~ "    OPEN st_cursor FOR\n"
+#~ " SELECT EMPLOYEE, EMPLOYER,\n"
+#~ " STARTDATE, ENDDATE,\n"
+#~ " REGIONCODE, EID, VALUE, CURRENCY\n"
+#~ " FROM EMPLOYMENT;\n"
+#~ "      RETURN  st_cursor;\n"
+#~ " END;]]>"
+#~ msgstr ""
+#~ "CREATE OR REPLACE FUNCTION selectAllEmployments\n"
+#~ "    RETURN SYS_REFCURSOR\n"
+#~ "AS\n"
+#~ "    st_cursor SYS_REFCURSOR;\n"
+#~ "BEGIN\n"
+#~ "    OPEN st_cursor FOR\n"
+#~ " SELECT EMPLOYEE, EMPLOYER,\n"
+#~ " STARTDATE, ENDDATE,\n"
+#~ " REGIONCODE, EID, VALUE, CURRENCY\n"
+#~ " FROM EMPLOYMENT;\n"
+#~ "      RETURN  st_cursor;\n"
+#~ " END;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"selectAllEmployees_SP\" callable=\"true\">\n"
+#~ "    <return alias=\"emp\" class=\"Employment\">\n"
+#~ "        <return-property name=\"employee\" column=\"EMPLOYEE\"/>\n"
+#~ "        <return-property name=\"employer\" column=\"EMPLOYER\"/>\n"
+#~ "        <return-property name=\"startDate\" column=\"STARTDATE\"/>\n"
+#~ "        <return-property name=\"endDate\" column=\"ENDDATE\"/>\n"
+#~ "        <return-property name=\"regionCode\" column=\"REGIONCODE\"/>\n"
+#~ "        <return-property name=\"id\" column=\"EID\"/>\n"
+#~ "        <return-property name=\"salary\">\n"
+#~ "            <return-column name=\"VALUE\"/>\n"
+#~ "            <return-column name=\"CURRENCY\"/>\n"
+#~ "        </return-property>\n"
+#~ "    </return>\n"
+#~ "    { ? = call selectAllEmployments() }\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"selectAllEmployees_SP\" callable=\"true\"&gt;\n"
+#~ "    &lt;return alias=\"emp\" class=\"Employment\"&gt;\n"
+#~ "        &lt;return-property name=\"employee\" column=\"EMPLOYEE\"/&gt;\n"
+#~ "        &lt;return-property name=\"employer\" column=\"EMPLOYER\"/&gt;\n"
+#~ "        &lt;return-property name=\"startDate\" column=\"STARTDATE\"/&gt;\n"
+#~ "        &lt;return-property name=\"endDate\" column=\"ENDDATE\"/&gt;\n"
+#~ "        &lt;return-property name=\"regionCode\" column=\"REGIONCODE\"/"
+#~ "&gt;\n"
+#~ "        &lt;return-property name=\"id\" column=\"EID\"/&gt;\n"
+#~ "        &lt;return-property name=\"salary\"&gt;\n"
+#~ "            &lt;return-column name=\"VALUE\"/&gt;\n"
+#~ "            &lt;return-column name=\"CURRENCY\"/&gt;\n"
+#~ "        &lt;/return-property&gt;\n"
+#~ "    &lt;/return&gt;\n"
+#~ "    { ? = call selectAllEmployments() }\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"increment\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"name\" not-null=\"true\"/>\n"
+#~ "    <sql-insert>INSERT INTO PERSON (NAME, ID) VALUES ( UPPER(?), ? )</sql-"
+#~ "insert>\n"
+#~ "    <sql-update>UPDATE PERSON SET NAME=UPPER(?) WHERE ID=?</sql-update>\n"
+#~ "    <sql-delete>DELETE FROM PERSON WHERE ID=?</sql-delete>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\"&gt;\n"
+#~ "        &lt;generator class=\"increment\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"name\" not-null=\"true\"/&gt;\n"
+#~ "    &lt;sql-insert&gt;INSERT INTO PERSON (NAME, ID) VALUES ( UPPER(?), ? )"
+#~ "&lt;/sql-insert&gt;\n"
+#~ "    &lt;sql-update&gt;UPDATE PERSON SET NAME=UPPER(?) WHERE ID=?&lt;/sql-"
+#~ "update&gt;\n"
+#~ "    &lt;sql-delete&gt;DELETE FROM PERSON WHERE ID=?&lt;/sql-delete&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"increment\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"name\" not-null=\"true\"/>\n"
+#~ "    <sql-insert callable=\"true\">{call createPerson (?, ?)}</sql-"
+#~ "insert>\n"
+#~ "    <sql-delete callable=\"true\">{? = call deletePerson (?)}</sql-"
+#~ "delete>\n"
+#~ "    <sql-update callable=\"true\">{? = call updatePerson (?, ?)}</sql-"
+#~ "update>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\"&gt;\n"
+#~ "        &lt;generator class=\"increment\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"name\" not-null=\"true\"/&gt;\n"
+#~ "    &lt;sql-insert callable=\"true\"&gt;{call createPerson (?, ?)}&lt;/"
+#~ "sql-insert&gt;\n"
+#~ "    &lt;sql-delete callable=\"true\"&gt;{? = call deletePerson (?)}&lt;/"
+#~ "sql-delete&gt;\n"
+#~ "    &lt;sql-update callable=\"true\"&gt;{? = call updatePerson (?, ?)}"
+#~ "&lt;/sql-update&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[CREATE OR REPLACE FUNCTION updatePerson (uid IN NUMBER, uname IN "
+#~ "VARCHAR2)\n"
+#~ "    RETURN NUMBER IS\n"
+#~ "BEGIN\n"
+#~ "\n"
+#~ "    update PERSON\n"
+#~ "    set\n"
+#~ "        NAME = uname,\n"
+#~ "    where\n"
+#~ "        ID = uid;\n"
+#~ "\n"
+#~ "    return SQL%ROWCOUNT;\n"
+#~ "\n"
+#~ "END updatePerson;]]>"
+#~ msgstr ""
+#~ "CREATE OR REPLACE FUNCTION updatePerson (uid IN NUMBER, uname IN "
+#~ "VARCHAR2)\n"
+#~ "    RETURN NUMBER IS\n"
+#~ "BEGIN\n"
+#~ "\n"
+#~ "    update PERSON\n"
+#~ "    set\n"
+#~ "        NAME = uname,\n"
+#~ "    where\n"
+#~ "        ID = uid;\n"
+#~ "\n"
+#~ "    return SQL&#37;ROWCOUNT;\n"
+#~ "\n"
+#~ "END updatePerson;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"person\">\n"
+#~ "    <return alias=\"pers\" class=\"Person\" lock-mode=\"upgrade\"/>\n"
+#~ "    SELECT NAME AS {pers.name}, ID AS {pers.id}\n"
+#~ "    FROM PERSON\n"
+#~ "    WHERE ID=?\n"
+#~ "    FOR UPDATE\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"person\"&gt;\n"
+#~ "    &lt;return alias=\"pers\" class=\"Person\" lock-mode=\"upgrade\"/"
+#~ "&gt;\n"
+#~ "    SELECT NAME AS {pers.name}, ID AS {pers.id}\n"
+#~ "    FROM PERSON\n"
+#~ "    WHERE ID=?\n"
+#~ "    FOR UPDATE\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"increment\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"name\" not-null=\"true\"/>\n"
+#~ "    <loader query-ref=\"person\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\"&gt;\n"
+#~ "        &lt;generator class=\"increment\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"name\" not-null=\"true\"/&gt;\n"
+#~ "    &lt;loader query-ref=\"person\"/&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<set name=\"employments\" inverse=\"true\">\n"
+#~ "    <key/>\n"
+#~ "    <one-to-many class=\"Employment\"/>\n"
+#~ "    <loader query-ref=\"employments\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "&lt;set name=\"employments\" inverse=\"true\"&gt;\n"
+#~ "    &lt;key/&gt;\n"
+#~ "    &lt;one-to-many class=\"Employment\"/&gt;\n"
+#~ "    &lt;loader query-ref=\"employments\"/&gt;\n"
+#~ "&lt;/set&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"employments\">\n"
+#~ "    <load-collection alias=\"emp\" role=\"Person.employments\"/>\n"
+#~ "    SELECT {emp.*}\n"
+#~ "    FROM EMPLOYMENT emp\n"
+#~ "    WHERE EMPLOYER = :id\n"
+#~ "    ORDER BY STARTDATE ASC, EMPLOYEE ASC\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"employments\"&gt;\n"
+#~ "    &lt;load-collection alias=\"emp\" role=\"Person.employments\"/&gt;\n"
+#~ "    SELECT {emp.*}\n"
+#~ "    FROM EMPLOYMENT emp\n"
+#~ "    WHERE EMPLOYER = :id\n"
+#~ "    ORDER BY STARTDATE ASC, EMPLOYEE ASC\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"person\">\n"
+#~ "    <return alias=\"pers\" class=\"Person\"/>\n"
+#~ "    <return-join alias=\"emp\" property=\"pers.employments\"/>\n"
+#~ "    SELECT NAME AS {pers.*}, {emp.*}\n"
+#~ "    FROM PERSON pers\n"
+#~ "    LEFT OUTER JOIN EMPLOYMENT emp\n"
+#~ "        ON pers.ID = emp.PERSON_ID\n"
+#~ "    WHERE ID=?\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"person\"&gt;\n"
+#~ "    &lt;return alias=\"pers\" class=\"Person\"/&gt;\n"
+#~ "    &lt;return-join alias=\"emp\" property=\"pers.employments\"/&gt;\n"
+#~ "    SELECT NAME AS {pers.*}, {emp.*}\n"
+#~ "    FROM PERSON pers\n"
+#~ "    LEFT OUTER JOIN EMPLOYMENT emp\n"
+#~ "        ON pers.ID = emp.PERSON_ID\n"
+#~ "    WHERE ID=?\n"
+#~ "&lt;/sql-query&gt;"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/session_api.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/session_api.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/session_api.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,25 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2010-01-07 14:56+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: session_api.xml:29
 #, no-c-format
 msgid "Working with objects"
 msgstr "オブジェクトを扱う"
 
 #. Tag: para
-#: session_api.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate is a full object/relational mapping solution that not only shields "
 "the developer from the details of the underlying database management system, "
@@ -27,14 +28,13 @@
 "JDBC/SQL persistence layers, a natural object-oriented view of persistence "
 "in Java applications."
 msgstr ""
-"Hibernate は完全なオブジェクト/リレーショナルマッピングソリューションであ"
-"り、 データベース管理システムの詳細を開発者から隠蔽するだけでなく、 オブジェ"
-"クトの <emphasis>状態管理</emphasis> も行います。 これは、JDBC/SQL永続層と同"
-"じようなSQL <literal>文</literal> の管理とは異なり、 Javaアプリケーションにお"
-"ける永続化に対する、とても自然なオブジェクト指向の考え方を提供します。"
+"Hibernate は完全なオブジェクト/リレーショナルマッピングソリューションであり、"
+"データベース管理システムの詳細を開発者から隠蔽するだけでなく、オブジェクトの "
+"<emphasis>状態管理</emphasis> も行います。これは、 JDBC/SQL 永続層と同じよう"
+"な SQL <literal>statements</literal> の管理とは異なり、 Java アプリケーション"
+"における永続化に対する、とても自然なオブジェクト指向の考え方を提供します。"
 
 #. Tag: para
-#: session_api.xml:40
 #, no-c-format
 msgid ""
 "In other words, Hibernate application developers should always think about "
@@ -43,26 +43,23 @@
 "is only relevant for the application developer when tuning the performance "
 "of the system."
 msgstr ""
-"言いかえれば、Hibernateを用いるアプリケーション開発者は、オブジェクトの "
-"<emphasis>状態</emphasis> については 常に意識すべきであり、SQL文の実行につい"
-"ては必ずしもそうではありません。 この部分は、通常、Hibernateが処理し、システ"
-"ムのパフォーマンスをチューニングするときにだけ、 問題になってきます。"
+"言いかえれば、 Hibernate を用いるアプリケーション開発者は、オブジェクトの "
+"<emphasis>状態</emphasis> については常に意識すべきであり、 SQL 文の実行につい"
+"ては必ずしもそうではありません。この部分は、通常、 Hibernate が処理し、システ"
+"ムのパフォーマンスをチューニングするときにだけ、問題になってきます。"
 
 #. Tag: title
-#: session_api.xml:48
 #, no-c-format
 msgid "Hibernate object states"
-msgstr "Hibernateにおけるオブジェクトの状態"
+msgstr "Hibernate におけるオブジェクトの状態"
 
 #. Tag: para
-#: session_api.xml:50
 #, no-c-format
 msgid "Hibernate defines and supports the following object states:"
-msgstr "Hibernateは次のようなオブジェクトの状態を定義し、サポートしています。"
+msgstr "Hibernate は次のようなオブジェクトの状態を定義し、サポートしています:"
 
 #. Tag: para
-#: session_api.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Transient</emphasis> - an object is transient if it has just been "
 "instantiated using the <literal>new</literal> operator, and it is not "
@@ -74,18 +71,17 @@
 "take care of the SQL statements that need to be executed for this "
 "transition)."
 msgstr ""
-"<emphasis> 一時的(Transient) </emphasis> - <literal>new</literal> 演算子を"
-"使って インスタンス化されただけで、 Hibernateの <literal>Session</literal> に"
-"関連付けられていないオブジェクトは、 一時的(transient)です。 それは、データ"
-"ベースに永続的な表現を持たず、識別子となる値は割り当てられていません。 一時的"
-"なインスタンスは、アプリケーションがその参照をどこにも保持しない場合に、 ガ"
-"ベージコレクタによって破棄されます。 オブジェクトを永続的(persistent)な状態に"
-"するためには、Hibernateの <literal>Session</literal> を使いましょう。 (この"
-"状態遷移に必要となるSQL文の発行は、Hibernateに任せましょう。)"
+"<emphasis>Transient</emphasis> - <literal>new</literal> 演算子を使ってインス"
+"タンス化されただけで、 Hibernate の <literal>Session</literal> に関連付けられ"
+"ていないオブジェクトは、 transient です。それは、データベースに永続的な表現を"
+"持たず、識別子となる値は割り当てられていません。 Transient インスタンスは、ア"
+"プリケーションがその参照をどこにも保持しない場合に、ガベージコレクタによって"
+"破棄されます。オブジェクトを永続的 (persistent) な状態にするためには、 "
+"Hibernate の <literal>Session</literal> を使いましょう(この状態遷移に必要と"
+"なる SQL 文の発行は、 Hibernate に任せましょう)。"
 
 #. Tag: para
-#: session_api.xml:68
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Persistent</emphasis> - a persistent instance has a representation "
 "in the database and an identifier value. It might just have been saved or "
@@ -96,18 +92,17 @@
 "statements, or <literal>DELETE</literal> statements when an object should be "
 "made transient."
 msgstr ""
-"<emphasis>永続的(Persistent)</emphasis> - 永続的なインスタンスはデータベース"
-"に 永続的な表現を持ち、識別子となる値を持っています。 それは、セーブされた"
-"り、ロードされたりするかもしれませんが、 定義上は、 <literal>Session</"
-"literal> のスコープの中に存在しています。 Hibernateは、作業単位(Unit of "
-"work)が完了したときに、 永続状態のオブジェクトに加えられた変更を検出し、 オ"
-"ブジェクトの状態とデータベースを同期します。 オブジェクトを一時的(transient)"
-"にするときは、開発者は、手作業で <literal>UPDATE</literal> 文や "
-"<literal>DELETE</literal> 文を実行しません。"
+"<emphasis>永続的 (Persistent)</emphasis> - 永続的なインスタンスはデータベース"
+"に永続的な表現を持ち、識別子となる値を持っています。それは、セーブされたり、"
+"ロードされたりするかもしれませんが、定義上は、 <literal>Session</literal> の"
+"スコープの中に存在しています。 Hibernate は、作業単位(Unit of Work)が完了し"
+"たときに、永続状態のオブジェクトに加えられた変更を検出し、オブジェクトの状態"
+"とデータベースを同期します。オブジェクトを transient にするときは、開発者は、"
+"手作業で <literal>UPDATE</literal> 文や <literal>DELETE</literal> 文を実行し"
+"ません。"
 
 #. Tag: para
-#: session_api.xml:79
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Detached</emphasis> - a detached instance is an object that has "
 "been persistent, but its <literal>Session</literal> has been closed. The "
@@ -119,61 +114,46 @@
 "them <emphasis>application transactions</emphasis>, i.e., a unit of work "
 "from the point of view of the user."
 msgstr ""
-"<emphasis>分離(Detached)</emphasis> - 分離されたインスタンスとは、永続化され"
-"ているが、 それと関連付いていた <literal>Session</literal> がクローズされてい"
-"るオブジェクトのことです。 そのオブジェクトへの参照は、依然として有効です。 "
-"そして、もちろん、分離された状態にあるオブジェクトは、修正することさえできま"
-"す。 分離されたインスタンスは、もう一度永続化したい(そして、すべての変更を永"
-"続化したい)ときに、 新しい <literal>Session</literal> に再追加できます。 こ"
-"の機能は、ユーザが考える時間を必要とするような、長期間に及ぶ作業単位に対する "
-"プログラミングモデルを可能にします。 我々は、これを <emphasis>アプリケーショ"
-"ンのトランザクション(application transactions)</emphasis> と呼んでいます。 "
-"すなわち、ユーザから見た作業単位だということです。"
+"<emphasis>Detached</emphasis> - detached インスタンスとは、永続化されている"
+"が、それと関連付いていた <literal>Session</literal> がクローズされているオブ"
+"ジェクトのことです。そのオブジェクトへの参照は、依然として有効です。そして、"
+"もちろん、detached インスタンスはこの状態に修正することさえできます。 "
+"detached インスタンスは、もう一度永続化したい(そして、すべての変更を永続化し"
+"たい)ときに、新しい <literal>Session</literal> に再追加できます。この機能"
+"は、ユーザーが考える時間を必要とするような、長期間に及ぶ作業単位に対するプロ"
+"グラミングモデルを可能にします。我々は、これを <emphasis>アプリケーションのト"
+"ランザクション(application transactions)</emphasis> と呼んでいます。すなわ"
+"ち、ユーザーから見た作業単位だということです。"
 
 #. Tag: para
-#: session_api.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will now discuss the states and state transitions (and the Hibernate "
 "methods that trigger a transition) in more detail."
 msgstr ""
-"これから、状態と状態遷移(そして、遷移のきっかけとなるHibernateのメソッド)に"
-"ついて 、詳細に述べます。"
+"これから、状態と状態遷移(そして、遷移のきっかけとなる Hibernate のメソッド)"
+"について、詳細に述べます。"
 
 #. Tag: title
-#: session_api.xml:101
 #, no-c-format
 msgid "Making objects persistent"
 msgstr "オブジェクトを永続状態にする"
 
 #. Tag: para
-#: session_api.xml:103
 #, no-c-format
 msgid ""
 "Newly instantiated instances of a a persistent class are considered "
 "<emphasis>transient</emphasis> by Hibernate. We can make a transient "
 "instance <emphasis>persistent</emphasis> by associating it with a session:"
 msgstr ""
-"新しくインスタンス化された永続クラスのインスタンスは、 Hibernateでは "
-"<emphasis>一時的(transient)</emphasis> と見なされます。 以下のように、セッ"
-"ションと関連づけることで、一時的なインスタンスを <emphasis>永続状態"
-"(persistent)</emphasis> にできます。"
+"新しくインスタンス化された永続クラスのインスタンスは、 Hibernate では "
+"<emphasis>transient</emphasis> と見なされます。以下のように、セッションと関連"
+"づけることで、 transient インスタンスを <emphasis>永続状態 (persistent)</"
+"emphasis> にできます。"
 
-#. Tag: programlisting
-#: session_api.xml:110
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DomesticCat fritz = new DomesticCat();\n"
-"fritz.setColor(Color.GINGER);\n"
-"fritz.setSex('M');\n"
-"fritz.setName(\"Fritz\");\n"
-"Long generatedId = (Long) sess.save(fritz);]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:112
-#, fuzzy, no-c-format
-msgid ""
 "If <literal>Cat</literal> has a generated identifier, the identifier is "
 "generated and assigned to the <literal>cat</literal> when <literal>save()</"
 "literal> is called. If <literal>Cat</literal> has an <literal>assigned</"
@@ -184,17 +164,16 @@
 "draft."
 msgstr ""
 "<literal>Cat</literal> クラスの識別子が自動生成されるのであれば、 "
-"<literal>save()</literal> が呼ばれるときに、 識別子が生成され、 "
-"<literal>cat</literal> インスタンスに割り当てられます。 <literal>Cat</"
-"literal> の識別子が他から割り当てられる( <literal>assigned</literal> 識別子"
-"を持つ)か、複合キーであるなら、 <literal>save()</literal> を呼び出す前に、識"
-"別子を割り当てなければなりません。 <literal>save()</literal> の代わりに、"
-"EJB3 の初期ドラフトで定義された <literal>persist()</literal> を使うことも可能"
-"です。"
+"<literal>save()</literal> が呼ばれるときに、識別子が生成され、 <literal>cat</"
+"literal> インスタンスに割り当てられます。 <literal>Cat</literal> の識別子が "
+"<literal>assigned</literal> 識別子を持つか、複合キーであるなら、 "
+"<literal>save()</literal> を呼び出す前に、識別子を <literal>cat</literal> イ"
+"ンスタンスを割り当てなければなりません。 <literal>save()</literal> の代わり"
+"に、 EJB3 の初期ドラフトで定義された <literal>persist()</literal> を使うこと"
+"も可能です。"
 
 #. Tag: para
-#: session_api.xml:124
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>persist()</literal> makes a transient instance persistent. However, "
 "it does not guarantee that the identifier value will be assigned to the "
@@ -204,16 +183,8 @@
 "boundaries. This is useful in long-running conversations with an extended "
 "Session/persistence context."
 msgstr ""
-"<literal>persist()</literal> makes a transient instance persistent. However, "
-"it doesn't guarantee that the identifier value will be assigned to the "
-"persistent instance immediately, the assignment might happen at flush time. "
-"<literal>persist()</literal> also guarantees that it will not execute an "
-"<literal>INSERT</literal> statement if it is called outside of transaction "
-"boundaries. This is useful in long-running conversations with an extended "
-"Session/persistence context."
 
 #. Tag: para
-#: session_api.xml:135
 #, no-c-format
 msgid ""
 "<literal>save()</literal> does guarantee to return an identifier. If an "
@@ -222,39 +193,19 @@
 "you are inside or outside of a transaction. This is problematic in a long-"
 "running conversation with an extended Session/persistence context."
 msgstr ""
-"<literal>save()</literal> does guarantee to return an identifier. If an "
-"INSERT has to be executed to get the identifier ( e.g. \"identity\" "
-"generator, not \"sequence\"), this INSERT happens immediately, no matter if "
-"you are inside or outside of a transaction. This is problematic in a long-"
-"running conversation with an extended Session/persistence context."
 
 #. Tag: para
-#: session_api.xml:145
 #, fuzzy, no-c-format
 msgid ""
 "Alternatively, you can assign the identifier using an overloaded version of "
 "<literal>save()</literal>."
 msgstr ""
-"代わりに、識別子を引数にとる <literal>save()</literal> メソッドを使って、 識"
-"別子を割り当てることもできます。"
+"代わりに、識別子を引数にとる <literal>save()</literal> メソッドを使って、識別"
+"子を割り当てることもできます。"
 
-#. Tag: programlisting
-#: session_api.xml:150
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DomesticCat pk = new DomesticCat();\n"
-"pk.setColor(Color.TABBY);\n"
-"pk.setSex('F');\n"
-"pk.setName(\"PK\");\n"
-"pk.setKittens( new HashSet() );\n"
-"pk.addKitten(fritz);\n"
-"sess.save( pk, new Long(1234) );]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:152
-#, fuzzy, no-c-format
-msgid ""
 "If the object you make persistent has associated objects (e.g. the "
 "<literal>kittens</literal> collection in the previous example), these "
 "objects can be made persistent in any order you like unless you have a "
@@ -264,16 +215,15 @@
 "literal> the objects in the wrong order."
 msgstr ""
 "永続化するオブジェクトが関連オブジェクトを持っている場合 (例えば、前の例にお"
-"ける <literal>kittens</literal> コレクションのように)、 外部キーカラムに、 "
-"<literal>NOT NULL</literal> 制約をつけない限りは、 これらの一連のオブジェクト"
-"をどんな順番で永続化してもかまいません。 外部キー制約を違反する恐れはありませ"
-"ん。 しかし、 <literal>NOT NULL</literal> 制約がある場合、間違った順番でオブ"
-"ジェクトを <literal>save()</literal> してしまうと、 制約に違反するかもしれま"
-"せん。"
+"ける <literal>kittens</literal> コレクションのように)、外部キーカラムに、 "
+"<literal>NOT NULL</literal> 制約をつけない限りは、これらの一連のオブジェクト"
+"をどんな順番で永続化してもかまいません。外部キー制約を違反する恐れはありませ"
+"ん。しかし、 <literal>NOT NULL</literal> 制約がある場合、間違った順番でオブ"
+"ジェクトを <literal>save()</literal> してしまうと、制約に違反するかもしれませ"
+"ん。"
 
 #. Tag: para
-#: session_api.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Usually you do not bother with this detail, as you will normally use "
 "Hibernate's <emphasis>transitive persistence</emphasis> feature to save the "
@@ -281,21 +231,19 @@
 "constraint violations do not occur - Hibernate will take care of everything. "
 "Transitive persistence is discussed later in this chapter."
 msgstr ""
-"関連するオブジェクトを自動的に保存する、 Hibernateの <emphasis>遷移的な永続化"
-"(transitive persistence)</emphasis> 機能を 使うつもりならば、そのような詳細を"
-"気にする必要はありません。 そして、 <literal>NOT NULL</literal> 制約の違反す"
-"ら起こりません。 Hibernateがすべて面倒をみてくれます。遷移的な永続化は、この"
+"関連するオブジェクトを自動的に保存する、 Hibernate の <emphasis>遷移的な永続"
+"化 (transitive persistence)</emphasis> 機能を使うつもりならば、そのような詳細"
+"を気にする必要はありません。そして、 <literal>NOT NULL</literal> 制約の違反す"
+"ら起こりません。 Hibernate がすべて面倒をみてくれます。遷移的な永続化は、この"
 "章の後半に書かれています。"
 
 #. Tag: title
-#: session_api.xml:173
 #, no-c-format
 msgid "Loading an object"
 msgstr "オブジェクトのロード"
 
 #. Tag: para
-#: session_api.xml:175
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>load()</literal> methods of <literal>Session</literal> provide "
 "a way of retrieving a persistent instance if you know its identifier. "
@@ -304,47 +252,19 @@
 msgstr ""
 "永続化されたインスタンスの識別子があらかじめ分かっているなら、 "
 "<literal>Session</literal> の <literal>load()</literal> メソッドを使って、復"
-"元できます。 <literal>load()</literal> は、Class オブジェクトを引数にとり、 "
-"そのクラスのインスタンスを新たに生成し、状態をロードします。 そのインスタンス"
-"の状態は、永続(persistent)状態です。"
+"元できます。 <literal>load()</literal> は、 Class オブジェクトを引数にとり、"
+"そのクラスのインスタンスを新たに生成し、状態をロードします。そのインスタンス"
+"の状態は、永続 (persistent) 状態です。"
 
-#. Tag: programlisting
-#: session_api.xml:182
-#, no-c-format
-msgid "<![CDATA[Cat fritz = (Cat) sess.load(Cat.class, generatedId);]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:184
-#, no-c-format
-msgid ""
-"<![CDATA[// you need to wrap primitive identifiers\n"
-"long id = 1234;\n"
-"DomesticCat pk = (DomesticCat) sess.load( DomesticCat.class, new Long"
-"(id) );]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:186
 #, no-c-format
 msgid "Alternatively, you can load state into a given instance:"
 msgstr ""
-"あるいは、以下のように、既存のインスタンスに状態をロードすることもできます。"
+"あるいは、以下のように、既存のインスタンスに状態をロードすることもできます:"
 
-#. Tag: programlisting
-#: session_api.xml:190
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Cat cat = new DomesticCat();\n"
-"// load pk's state into cat\n"
-"sess.load( cat, new Long(pkId) );\n"
-"Set kittens = cat.getKittens();]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:192
-#, fuzzy, no-c-format
-msgid ""
 "Be aware that <literal>load()</literal> will throw an unrecoverable "
 "exception if there is no matching database row. If the class is mapped with "
 "a proxy, <literal>load()</literal> just returns an uninitialized proxy and "
@@ -354,59 +274,38 @@
 "be loaded as a batch if <literal>batch-size</literal> is defined for the "
 "class mapping."
 msgstr ""
-"DBに該当する行が無い場合、 <literal>load()</literal> は回復不可能な例外を 投"
-"げることに注意しましょう。 そのクラスがプロキシを使ってマッピングされている場"
+"DB に該当する行が無い場合、 <literal>load()</literal> は回復不可能な例外を投"
+"げることに注意しましょう。そのクラスがプロキシを使ってマッピングされている場"
 "合、 <literal>load()</literal> は初期化されていないプロキシを返し、プロキシの"
-"メソッドが呼ばれるまで実際には データベースにアクセスしません。 もし、実際に"
-"データベースからロードせずに、オブジェクトに対する関連を作りたい場合、 この振"
+"メソッドが呼ばれるまで実際にはデータベースにアクセスしません。もし、実際に"
+"データベースからロードせずに、オブジェクトに対する関連を作りたい場合、この振"
 "る舞いはとても役立ちます。 <literal>batch-size</literal> がクラスマッピングに"
-"定義されているならば、 複数のインスタンスを一括でロードすることが可能です。"
+"定義されているならば、複数のインスタンスを一括でロードすることが可能です。"
 
 #. Tag: para
-#: session_api.xml:203
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are not certain that a matching row exists, you should use the "
 "<literal>get()</literal> method which hits the database immediately and "
 "returns null if there is no matching row."
 msgstr ""
 "該当する行が存在することを確信できない場合は、 <literal>get()</literal> メ"
-"ソッドを使うべきです。 それは、データベースにすぐにアクセスし、該当する行が無"
-"い場合はnullを返します。"
+"ソッドを使うべきです。それは、データベースにすぐにアクセスし、該当する行が無"
+"い場合は null を返します。"
 
-#. Tag: programlisting
-#: session_api.xml:209
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id);\n"
-"if (cat==null) {\n"
-"    cat = new Cat();\n"
-"    sess.save(cat, id);\n"
-"}\n"
-"return cat;]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:211
-#, fuzzy, no-c-format
-msgid ""
 "You can even load an object using an SQL <literal>SELECT ... FOR UPDATE</"
 "literal>, using a <literal>LockMode</literal>. See the API documentation for "
 "more information."
 msgstr ""
 "<literal>LockMode</literal> を使えば、 <literal>SELECT ... FOR UPDATE</"
-"literal>というSQLを 使ってオブジェクトをロードすることができます。 詳細な情報"
-"は、APIドキュメントを参照してください。"
+"literal> という SQL を使ってオブジェクトをロードすることができます。詳細な情"
+"報は、 API ドキュメントを参照してください。"
 
-#. Tag: programlisting
-#: session_api.xml:216
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id, LockMode.UPGRADE);]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:218
-#, fuzzy, no-c-format
 msgid ""
 "Any associated instances or contained collections will <emphasis>not</"
 "emphasis> be selected <literal>FOR UPDATE</literal>, unless you decide to "
@@ -414,12 +313,11 @@
 "for the association."
 msgstr ""
 "関連に対するカスケード方法として <literal>lock</literal> や <literal>all</"
-"literal> を 指定しない限り、関連するインスタンスや含まれるコレクションは "
+"literal> を指定しない限り、関連するインスタンスや含まれるコレクションは "
 "<literal>FOR UPDATE</literal> で復元 <emphasis>されない</emphasis> ことに注意"
 "しましょう。"
 
 #. Tag: para
-#: session_api.xml:225
 #, no-c-format
 msgid ""
 "It is possible to re-load an object and all its collections at any time, "
@@ -427,43 +325,31 @@
 "triggers are used to initialize some of the properties of the object."
 msgstr ""
 "<literal>refresh()</literal> メソッドを使うことで、どんなときでも、オブジェク"
-"トやそのコレクションを リロードすることができます。 データベースのトリガが"
-"テーブルを更新した際に、 そのテーブルに対応するオブジェクトのプロパティを同期"
-"する場合、このメソッドが役に立ちます。"
+"トやそのコレクションをリロードすることができます。データベースのトリガがテー"
+"ブルを更新した際に、そのテーブルに対応するオブジェクトのプロパティを同期する"
+"場合、このメソッドが役に立ちます。"
 
-#. Tag: programlisting
-#: session_api.xml:231
-#, no-c-format
-msgid ""
-"<![CDATA[sess.save(cat);\n"
-"sess.flush(); //force the SQL INSERT\n"
-"sess.refresh(cat); //re-read the state (after the trigger executes)]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:233
 #, fuzzy, no-c-format
 msgid ""
 "How much does Hibernate load from the database and how many SQL "
 "<literal>SELECT</literal>s will it use? This depends on the "
 "<emphasis>fetching strategy</emphasis>. This is explained in <xref linkend="
-"\"performance-fetching\"/>."
+"\"performance-fetching\" />."
 msgstr ""
-"大切な問題は、いつも次の点に関するものです。それは、Hibernateがデータベースか"
-"ら、 どのくらいの量を復元するのかと、どのくらいの数のSQLの <literal>SELECT</"
-"literal> 文が使われるのかです。 これは、 <emphasis>フェッチの戦略</emphasis> "
-"によります。これについては、<xref linkend=\"performance-fetching\"/> で説明し"
-"ています。"
+"大切な問題は、いつも次の点に関するものです。それは、 Hibernate がデータベース"
+"から、どのくらいの量を復元するのかと、どのくらいの数の SQL の "
+"<literal>SELECT</literal> 文が使われるのかです。これは、 <emphasis>フェッチの"
+"戦略</emphasis> によります。これについては、 <xref linkend=\"performance-"
+"fetching\"/> で説明しています。"
 
 #. Tag: title
-#: session_api.xml:243
 #, no-c-format
 msgid "Querying"
 msgstr "クエリ"
 
 #. Tag: para
-#: session_api.xml:245
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you do not know the identifiers of the objects you are looking for, you "
 "need a query. Hibernate supports an easy-to-use but powerful object oriented "
@@ -473,20 +359,18 @@
 "from Hibernate for result set conversion into objects."
 msgstr ""
 "探したいオブジェクトの識別子が分からない場合は、クエリが必要になります。 "
-"Hibernateは使いやすくて強力なオブジェクト指向のクエリ言語 (HQL)をサポートして"
-"います。 プログラムによってクエリが作成できるように、Hibernateは洗練された"
-"CriteriaとExampleクエリ機能(QBCとQBE)を サポートしています。ResultSetをオブ"
-"ジェクトに変換するHibernateのオプション機能を使うことで、 データベースのネイ"
-"ティブなSQLでクエリを表現することもできます。"
+"Hibernate は使いやすくて強力なオブジェクト指向のクエリ言語 (HQL) をサポートし"
+"ています。プログラムによってクエリが作成できるように、 Hibernate は洗練され"
+"た Criteria と Example クエリ機能 (QBC と QBE) をサポートしています。 "
+"ResultSet をオブジェクトに変換する Hibernate のオプション機能を使うことで、"
+"データベースのネイティブな SQL でクエリを表現することもできます。"
 
 #. Tag: title
-#: session_api.xml:255
 #, no-c-format
 msgid "Executing queries"
 msgstr "クエリの実行"
 
 #. Tag: para
-#: session_api.xml:257
 #, no-c-format
 msgid ""
 "HQL and native SQL queries are represented with an instance of <literal>org."
@@ -495,46 +379,15 @@
 "always obtain a <literal>Query</literal> using the current <literal>Session</"
 "literal>:"
 msgstr ""
-"HQLやネイティブなSQLクエリは、 <literal>org.hibernate.Query</literal> のイン"
-"スタンスとして表現されます。 このインタフェースは、パラメータバインディングや"
-"ResultSetのハンドリングや クエリの実行を行うメソッドを用意しています。 通"
-"常、 <literal>Query</literal> は、以下に示すように、 その時点の "
+"HQL やネイティブな SQL クエリは、 <literal>org.hibernate.Query</literal> のイ"
+"ンスタンスとして表現されます。このインタフェースは、パラメータバインディング"
+"や ResultSet のハンドリングやクエリの実行を行うメソッドを用意しています。通"
+"常、 <literal>Query</literal> は、以下に示すように、その時点の "
 "<literal>Session</literal> を使って取得します。"
 
-#. Tag: programlisting
-#: session_api.xml:264
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = session.createQuery(\n"
-"    \"from Cat as cat where cat.birthdate < ?\")\n"
-"    .setDate(0, date)\n"
-"    .list();\n"
-"\n"
-"List mothers = session.createQuery(\n"
-"    \"select mother from Cat as cat join cat.mother as mother where cat.name "
-"= ?\")\n"
-"    .setString(0, name)\n"
-"    .list();\n"
-"\n"
-"List kittens = session.createQuery(\n"
-"    \"from Cat as cat where cat.mother = ?\")\n"
-"    .setEntity(0, pk)\n"
-"    .list();\n"
-"\n"
-"Cat mother = (Cat) session.createQuery(\n"
-"    \"select cat.mother from Cat as cat where cat = ?\")\n"
-"    .setEntity(0, izi)\n"
-"    .uniqueResult();]]\n"
-"\n"
-"Query mothersWithKittens = (Cat) session.createQuery(\n"
-"    \"select mother from Cat as mother left join fetch mother.kittens\");\n"
-"Set uniqueMothers = new HashSet(mothersWithKittens.list());]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:266
-#, fuzzy, no-c-format
-msgid ""
 "A query is usually executed by invoking <literal>list()</literal>. The "
 "result of the query will be loaded completely into a collection in memory. "
 "Entity instances retrieved by a query are in a persistent state. The "
@@ -545,23 +398,21 @@
 "a <literal>Set</literal>."
 msgstr ""
 "クエリは、普通、 <literal>list()</literal> を呼び出すことによって実行されま"
-"す。 クエリの結果は、メモリ上にあるコレクションにすべてロードされます。 クエ"
-"リによって復元されたエンティティのインスタンスは、永続状態です。 もし、クエリ"
-"がたった1個のインスタンスを返すと分かっているなら、 <literal>uniqueResult()</"
-"literal> メソッドが手っ取り早い方法です。 即時フェッチを利用したクエリの場"
-"合、ふつう、得られたコレクションには、 ルートのオブジェクトが重複して含まれて"
-"います (しかし、ルートが持つコレクションは初期化(ロード)されています)。 こ"
-"の重複は <literal>Set</literal> を使って取り除くことができます。"
+"す。クエリの結果は、メモリ上にあるコレクションにすべてロードされます。クエリ"
+"によって復元されたエンティティのインスタンスは、永続状態です。もし、クエリが"
+"たった1個のインスタンスを返すと分かっているなら、 <literal>uniqueResult()</"
+"literal> メソッドが手っ取り早い方法です。即時フェッチを利用したクエリの場合、"
+"ふつう、得られたコレクションには、ルートのオブジェクトが重複して含まれていま"
+"す(しかし、ルートが持つコレクションは初期化 (ロード)されています)。この重"
+"複は <literal>Set</literal> を使って取り除くことができます。"
 
 #. Tag: title
-#: session_api.xml:278
 #, no-c-format
 msgid "Iterating results"
 msgstr "結果をイテレートする"
 
 #. Tag: para
-#: session_api.xml:280
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Occasionally, you might be able to achieve better performance by executing "
 "the query using the <literal>iterate()</literal> method. This will usually "
@@ -573,115 +424,53 @@
 "returns identifiers, and <emphasis>n</emphasis> additional selects to "
 "initialize the actual instances."
 msgstr ""
-"時々、 <literal>iterate()</literal> メソッドを使ってクエリを実行することで、 "
-"より良いパフォーマンスを得ることができます。 これは、通常、クエリによって得ら"
-"れた実際のエンティティのインスタンスが、 すでにセッションまたは二次キャッシュ"
-"に存在することが期待できる場合だけです。 それらが、まだキャッシュされていない"
+"時々、 <literal>iterate()</literal> メソッドを使ってクエリを実行することで、"
+"より良いパフォーマンスを得ることができます。これは、通常、クエリによって得ら"
+"れた実際のエンティティのインスタンスが、すでにセッションまたは二次キャッシュ"
+"に存在することが期待できる場合だけです。それらが、まだキャッシュされていない"
 "なら、 <literal>iterate()</literal> は、 <literal>list()</literal> よりも遅"
-"く、簡単なクエリに対しても多くのデータベースアクセスを 必要とします。そのアク"
-"セスとは、識別子だけを取得するための最初のselect1回と、 実際のインスタンスを"
-"初期化するために後から行うn回のselectのことです。"
+"く、簡単なクエリに対しても多くのデータベースアクセスを必要とします。そのアク"
+"セスとは、識別子だけを取得するための最初の select <emphasis>1回</emphasis> "
+"と、実際のインスタンスを初期化するために後から行う <emphasis>n回</emphasis> "
+"の select のことです。"
 
-#. Tag: programlisting
-#: session_api.xml:292
-#, no-c-format
-msgid ""
-"<![CDATA[// fetch ids\n"
-"Iterator iter = sess.createQuery(\"from eg.Qux q order by q.likeliness\")."
-"iterate();\n"
-"while ( iter.hasNext() ) {\n"
-"    Qux qux = (Qux) iter.next();  // fetch the object\n"
-"    // something we couldnt express in the query\n"
-"    if ( qux.calculateComplicatedAlgorithm() ) {\n"
-"        // delete the current instance\n"
-"        iter.remove();\n"
-"        // dont need to process the rest\n"
-"        break;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:296
 #, no-c-format
 msgid "Queries that return tuples"
 msgstr "オブジェクトの組(tuple)を返すクエリ"
 
 #. Tag: para
-#: session_api.xml:298
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate queries sometimes return tuples of objects. Each tuple is returned "
 "as an array:"
 msgstr ""
-"Hibernateのクエリでは、時々、オブジェクトの組を返すことがあります。 その場合"
-"は、各タプルは配列として返されます。"
+"Hibernate のクエリでは、時々、オブジェクトの組を返すことがあります。その場合"
+"は、各タプルは配列として返されます:"
 
-#. Tag: programlisting
-#: session_api.xml:303
-#, no-c-format
-msgid ""
-"<![CDATA[Iterator kittensAndMothers = sess.createQuery(\n"
-"            \"select kitten, mother from Cat kitten join kitten.mother mother"
-"\")\n"
-"            .list()\n"
-"            .iterator();\n"
-"\n"
-"while ( kittensAndMothers.hasNext() ) {\n"
-"    Object[] tuple = (Object[]) kittensAndMothers.next();\n"
-"    Cat kitten = (Cat) tuple[0];\n"
-"    Cat mother = (Cat) tuple[1];\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:308
 #, no-c-format
 msgid "Scalar results"
 msgstr "スカラーの結果"
 
 #. Tag: para
-#: session_api.xml:310
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Queries can specify a property of a class in the <literal>select</literal> "
 "clause. They can even call SQL aggregate functions. Properties or aggregates "
 "are considered \"scalar\" results and not entities in persistent state."
 msgstr ""
 "クエリでは、 <literal>select</literal> 節でクラスのプロパティを指定できま"
-"す。 SQLの集合関数を呼ぶこともできます。プロパティや集合関数は、 (永続状態の"
+"す。 SQL の集合関数を呼ぶこともできます。プロパティや集合関数は、(永続状態の"
 "エンティティではなく)「スカラー値」であると見なされます。"
 
-#. Tag: programlisting
-#: session_api.xml:316
-#, no-c-format
-msgid ""
-"<![CDATA[Iterator results = sess.createQuery(\n"
-"        \"select cat.color, min(cat.birthdate), count(cat) from Cat cat \" "
-"+\n"
-"        \"group by cat.color\")\n"
-"        .list()\n"
-"        .iterator();\n"
-"\n"
-"while ( results.hasNext() ) {\n"
-"    Object[] row = (Object[]) results.next();\n"
-"    Color type = (Color) row[0];\n"
-"    Date oldest = (Date) row[1];\n"
-"    Integer count = (Integer) row[2];\n"
-"    .....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:321
 #, no-c-format
 msgid "Bind parameters"
 msgstr "パラメータのバインド"
 
 #. Tag: para
-#: session_api.xml:323
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Methods on <literal>Query</literal> are provided for binding values to named "
 "parameters or JDBC-style <literal>?</literal> parameters. <emphasis>Contrary "
@@ -689,229 +478,120 @@
 "are identifiers of the form <literal>:name</literal> in the query string. "
 "The advantages of named parameters are as follows:"
 msgstr ""
-"<literal>Query</literal> は、名前付きのパラメータやJDBCスタイルの <literal>?"
-"</literal> パラメータに値をバインドするためのメソッドを持っています。 "
-"<emphasis>JDBCとは違い、Hibernateはパラメータにゼロから番号を振っていきます。"
-"</emphasis> 名前付きのパラメータとは、クエリ文字列のなかにある <literal>:"
-"name</literal> 形式の識別子です。 名前付きパラメータの利点は次の通りです。"
+"<literal>Query</literal> は、名前付きのパラメータや JDBC スタイルの "
+"<literal>?</literal> パラメータに値をバインドするためのメソッドを持っていま"
+"す。 <emphasis> JDBC とは違い、 Hibernate はパラメータにゼロから番号を振って"
+"いきます。</emphasis>名前付きのパラメータとは、クエリ文字列のなかにある "
+"<literal>:name</literal> 形式の識別子です。名前付きパラメータの利点は次の通り"
+"です。"
 
 #. Tag: para
-#: session_api.xml:333
 #, no-c-format
 msgid ""
 "named parameters are insensitive to the order they occur in the query string"
 msgstr "名前付きパラメータは、クエリ文字列に登場する順番と無関係です"
 
 #. Tag: para
-#: session_api.xml:339
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "they can occur multiple times in the same query"
 msgstr "同じクエリ内に複数回登場することができます"
 
 #. Tag: para
-#: session_api.xml:344
 #, no-c-format
 msgid "they are self-documenting"
 msgstr "自分自身を説明します"
 
-#. Tag: programlisting
-#: session_api.xml:350
-#, no-c-format
-msgid ""
-"<![CDATA[//named parameter (preferred)\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name = :name"
-"\");\n"
-"q.setString(\"name\", \"Fritz\");\n"
-"Iterator cats = q.iterate();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:352
-#, no-c-format
-msgid ""
-"<![CDATA[//positional parameter\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name = ?\");\n"
-"q.setString(0, \"Izi\");\n"
-"Iterator cats = q.iterate();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:354
-#, no-c-format
-msgid ""
-"<![CDATA[//named parameter list\n"
-"List names = new ArrayList();\n"
-"names.add(\"Izi\");\n"
-"names.add(\"Fritz\");\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name in (:"
-"namesList)\");\n"
-"q.setParameterList(\"namesList\", names);\n"
-"List cats = q.list();]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:359
 #, no-c-format
 msgid "Pagination"
 msgstr "ページ分け"
 
 #. Tag: para
-#: session_api.xml:361
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you need to specify bounds upon your result set, that is, the maximum "
 "number of rows you want to retrieve and/or the first row you want to "
 "retrieve, you can use methods of the <literal>Query</literal> interface:"
 msgstr ""
-"ResultSetに制限(復元したい最大行数や復元したい最初の行)を加える必要があれ"
-"ば、 以下のように、 <literal>Query</literal> インターフェイスのメソッドを使い"
+"ResultSet に制限(復元したい最大行数や復元したい最初の行)を加える必要があれ"
+"ば、以下のように、 <literal>Query</literal> インターフェースのメソッドを使い"
 "ます。"
 
-#. Tag: programlisting
-#: session_api.xml:367
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = sess.createQuery(\"from DomesticCat cat\");\n"
-"q.setFirstResult(20);\n"
-"q.setMaxResults(10);\n"
-"List cats = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:369
 #, no-c-format
 msgid ""
 "Hibernate knows how to translate this limit query into the native SQL of "
 "your DBMS."
 msgstr ""
-"制限付きのクエリをDBMSのネイティブなSQLに変換する方法を、Hibernateは知ってい"
-"ます。"
+"制限付きのクエリを DBMS のネイティブな SQL に変換する方法を、 Hibernate は"
+"知っています。"
 
 #. Tag: title
-#: session_api.xml:377
 #, no-c-format
 msgid "Scrollable iteration"
 msgstr "スクロール可能なイテレーション"
 
 #. Tag: para
-#: session_api.xml:379
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your JDBC driver supports scrollable <literal>ResultSet</literal>s, the "
 "<literal>Query</literal> interface can be used to obtain a "
 "<literal>ScrollableResults</literal> object that allows flexible navigation "
 "of the query results."
 msgstr ""
-"JDBCドライバがスクロール可能な <literal>ResultSet</literal> をサポートしてい"
-"れば、 <literal>Query</literal> インターフェイスを使って、 "
-"<literal>ScrollableResults</literal> オブジェクトを 取得できます。それを使う"
+"JDBC ドライバがスクロール可能な <literal>ResultSet</literal> をサポートしてい"
+"れば、 <literal>Query</literal> インターフェースを使って、 "
+"<literal>ScrollableResults</literal> オブジェクトを取得できます。それを使う"
 "と、クエリの結果に対して柔軟にナビゲーションできます。"
 
-#. Tag: programlisting
-#: session_api.xml:386
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Query q = sess.createQuery(\"select cat.name, cat from DomesticCat "
-"cat \" +\n"
-"                            \"order by cat.name\");\n"
-"ScrollableResults cats = q.scroll();\n"
-"if ( cats.first() ) {\n"
-"\n"
-"    // find the first name on each page of an alphabetical list of cats by "
-"name\n"
-"    firstNamesOfPages = new ArrayList();\n"
-"    do {\n"
-"        String name = cats.getString(0);\n"
-"        firstNamesOfPages.add(name);\n"
-"    }\n"
-"    while ( cats.scroll(PAGE_SIZE) );\n"
-"\n"
-"    // Now get the first page of cats\n"
-"    pageOfCats = new ArrayList();\n"
-"    cats.beforeFirst();\n"
-"    int i=0;\n"
-"    while( ( PAGE_SIZE > i++ ) && cats.next() ) pageOfCats.add( cats.get"
-"(1) );\n"
-"\n"
-"}\n"
-"cats.close()]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:388
-#, fuzzy, no-c-format
-msgid ""
 "Note that an open database connection and cursor is required for this "
 "functionality. Use <literal>setMaxResult()</literal>/<literal>setFirstResult"
 "()</literal> if you need offline pagination functionality."
 msgstr ""
 "この機能にはオープン状態のデータベースコネクションが必要であることに注意して"
-"ください。 もし、オフラインのページ分け機能が必要であれば、 "
+"ください。もし、オフラインのページ分け機能が必要であれば、 "
 "<literal>setMaxResult()</literal> / <literal>setFirstResult()</literal> を使"
 "いましょう。"
 
 #. Tag: title
-#: session_api.xml:397
 #, no-c-format
 msgid "Externalizing named queries"
 msgstr "名前付きクエリの外出し"
 
 #. Tag: para
-#: session_api.xml:399
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also define named queries in the mapping document. Remember to use a "
 "<literal>CDATA</literal> section if your query contains characters that "
 "could be interpreted as markup."
 msgstr ""
-"マッピングドキュメントに名前付きのクエリを定義することができます。 (マーク"
+"マッピングドキュメントに名前付きのクエリを定義することができます。(マーク"
 "アップと解釈される文字がクエリに含まれるなら、 <literal>CDATA</literal> セク"
-"ションを 使うことを忘れないようにしましょう。)"
+"ションを使うことを忘れないようにしましょう。)"
 
-#. Tag: programlisting
-#: session_api.xml:405
-#, no-c-format
-msgid ""
-"<![CDATA[<query name=\"ByNameAndMaximumWeight\"><![CDATA[\n"
-"    from eg.DomesticCat as cat\n"
-"        where cat.name = ?\n"
-"        and cat.weight > ?\n"
-"] ]></query>]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:407
 #, no-c-format
 msgid "Parameter binding and executing is done programatically:"
 msgstr ""
-"パラメータのバインディングと実行は、以下のようなプログラムで行われます。"
+"パラメータのバインディングと実行は、以下のようなプログラムで行われます:"
 
-#. Tag: programlisting
-#: session_api.xml:411
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Query q = sess.getNamedQuery(\"ByNameAndMaximumWeight\");\n"
-"q.setString(0, name);\n"
-"q.setInt(1, minWeight);\n"
-"List cats = q.list();]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:413
-#, fuzzy, no-c-format
-msgid ""
 "The actual program code is independent of the query language that is used. "
 "You can also define native SQL queries in metadata, or migrate existing "
 "queries to Hibernate by placing them in mapping files."
 msgstr ""
 "実際のプログラムコードは、使われるクエリ言語に依存していないことに注意しま"
-"しょう。 メタデータには、ネイティブSQLクエリを定義することもできます。 また、"
-"既存のクエリをマッピングファイルに移すことで、 Hibernateに移行することもでき"
+"しょう。メタデータには、ネイティブ SQL クエリを定義することもできます。また、"
+"既存のクエリをマッピングファイルに移すことで、 Hibernate に移行することもでき"
 "ます。"
 
 #. Tag: para
-#: session_api.xml:419
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Also note that a query declaration inside a <literal>&lt;hibernate-"
 "mapping&gt;</literal> element requires a global unique name for the query, "
@@ -919,145 +599,94 @@
 "is made unique automatically by prepending the fully qualified name of the "
 "class. For example <literal>eg.Cat.ByNameAndMaximumWeight</literal>."
 msgstr ""
-"<literal>&lt;hibernate-mapping&gt;</literal> の中のクエリ定義は、クエリに対す"
-"る ユニークな名前が必要なことにも注意してください。それに対して、 "
-"<literal>&lt;class&gt;</literal> の中の クエリ定義は、クラスの完全限定名が前"
-"に付けられるので、自動的にユニークな名前になります。 例: <literal>eg.Cat."
+"<literal>&lt;hibernate-mapping&gt;</literal> 要素の中のクエリ定義は、クエリに"
+"対するユニークな名前が必要なことにも注意してください。それに対して、 "
+"<literal>&lt;class&gt;</literal> 要素の中のクエリ定義は、クラスの完全限定名が"
+"前に付けられるので、自動的にユニークな名前になります。例: <literal>eg.Cat."
 "ByNameAndMaximumWeight</literal>"
 
 #. Tag: title
-#: session_api.xml:432
 #, no-c-format
 msgid "Filtering collections"
-msgstr "コレクションのフィルタリング"
+msgstr "フィルタリングコレクション"
 
 #. Tag: para
-#: session_api.xml:433
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A collection <emphasis>filter</emphasis> is a special type of query that can "
 "be applied to a persistent collection or array. The query string can refer "
 "to <literal>this</literal>, meaning the current collection element."
 msgstr ""
 "コレクション <emphasis>フィルタ</emphasis> は、永続化されているコレクションや"
-"配列に適用される 特殊なタイプのクエリです。そのクエリ文字列では、コレクション"
+"配列に適用される特殊なタイプのクエリです。そのクエリ文字列では、コレクション"
 "のその時点での要素を意味する <literal>this</literal> を使います。"
 
-#. Tag: programlisting
-#: session_api.xml:439
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Collection blackKittens = session.createFilter(\n"
-"    pk.getKittens(), \n"
-"    \"where this.color = ?\")\n"
-"    .setParameter( Color.BLACK, Hibernate.custom(ColorUserType.class) )\n"
-"    .list()\n"
-");]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:441
-#, fuzzy, no-c-format
-msgid ""
 "The returned collection is considered a bag that is a copy of the given "
 "collection. The original collection is not modified. This is contrary to the "
 "implication of the name \"filter\", but consistent with expected behavior."
 msgstr ""
-"返されるコレクションはBagとみなされます。そして、それはもとのコレクションのコ"
-"ピーになります。 元のコレクションは修正されません(これは、\"filter\"という名"
-"前の意味とは異なりますが、 期待される動きとは一致しています)。"
+"返されるコレクションは Bag とみなされます。そして、それはもとのコレクションの"
+"コピーになります。元のコレクションは修正されません(これは、 \"filter\" とい"
+"う名前の意味とは異なりますが、期待される動きとは一致しています)。"
 
 #. Tag: para
-#: session_api.xml:447
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Observe that filters do not require a <literal>from</literal> clause, "
 "although they can have one if required. Filters are not limited to returning "
 "the collection elements themselves."
 msgstr ""
 "フィルタには <literal>from</literal> 節が不要であることに気づくでしょう(必要"
-"なら、持つことも可能ですが)。 フィルタは、コレクションの要素自体を返して構い"
+"なら、持つことも可能ですが)。フィルタは、コレクションの要素自体を返して構い"
 "ません。"
 
-#. Tag: programlisting
-#: session_api.xml:452
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Collection blackKittenMates = session.createFilter(\n"
-"    pk.getKittens(), \n"
-"    \"select this.mate where this.color = eg.Color.BLACK.intValue\")\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:454
-#, fuzzy, no-c-format
-msgid ""
 "Even an empty filter query is useful, e.g. to load a subset of elements in a "
 "large collection:"
 msgstr ""
-"クエリを含まないフィルタも役に立ちます。 例えば、非常に大きなコレクションの部"
+"クエリを含まないフィルタも役に立ちます。例えば、非常に大きなコレクションの部"
 "分集合をロードするために使えます。"
 
-#. Tag: programlisting
-#: session_api.xml:459
-#, no-c-format
-msgid ""
-"<![CDATA[Collection tenKittens = session.createFilter(\n"
-"    mother.getKittens(), \"\")\n"
-"    .setFirstResult(0).setMaxResults(10)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:464
 #, no-c-format
 msgid "Criteria queries"
 msgstr "クライテリアのクエリ"
 
 #. Tag: para
-#: session_api.xml:466
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL is extremely powerful, but some developers prefer to build queries "
 "dynamically using an object-oriented API, rather than building query "
 "strings. Hibernate provides an intuitive <literal>Criteria</literal> query "
 "API for these cases:"
 msgstr ""
-"HQLは非常に強力ですが、クエリ文字列を作るよりも、オブジェクト指向のAPIを使っ"
-"て 動的にクエリを作る方を好む開発者もいます。 こういった場合のために、"
-"Hibernateは直感的な <literal>Criteria</literal> クエリAPIを提供しています。"
+"HQL は非常に強力ですが、クエリ文字列を作るよりも、オブジェクト指向の API を"
+"使って動的にクエリを作る方を好む開発者もいます。こういった場合のために、 "
+"Hibernate は直感的な <literal>Criteria</literal> クエリ API を提供していま"
+"す。"
 
-#. Tag: programlisting
-#: session_api.xml:472
-#, no-c-format
-msgid ""
-"<![CDATA[Criteria crit = session.createCriteria(Cat.class);\n"
-"crit.add( Restrictions.eq( \"color\", eg.Color.BLACK ) );\n"
-"crit.setMaxResults(10);\n"
-"List cats = crit.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:474
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The <literal>Criteria</literal> and the associated <literal>Example</"
-"literal> API are discussed in more detail in <xref linkend=\"querycriteria\"/"
-">."
+"literal> API are discussed in more detail in <xref linkend=\"querycriteria"
+"\" />."
 msgstr ""
-"<literal>Criteria</literal> と <literal>Example</literal> APIの詳細は、 "
+"<literal>Criteria</literal> と <literal>Example</literal> API の詳細は、 "
 "<xref linkend=\"querycriteria\"/> に述べられています。"
 
 #. Tag: title
-#: session_api.xml:482
 #, no-c-format
 msgid "Queries in native SQL"
-msgstr "ネイティブSQLのクエリ"
+msgstr "ネイティブ SQL のクエリ"
 
 #. Tag: para
-#: session_api.xml:484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can express a query in SQL, using <literal>createSQLQuery()</literal> "
 "and let Hibernate manage the mapping from result sets to objects. You can at "
@@ -1065,57 +694,31 @@
 "<literal>Connection</literal> directly. If you choose to use the Hibernate "
 "API, you must enclose SQL aliases in braces:"
 msgstr ""
-"<literal>createSQLQuery()</literal> を使って、SQLでクエリを表現することもでき"
-"ます。 そして、Hibernateに、ResultSet からオブジェクトへのマッピングをまかせ"
-"ます。 <literal>session.connection()</literal> を呼べばどんなときでも、直接、"
-"JDBC <literal>Connection</literal> を使用できることを覚えておきましょう。 も"
-"し、Hibernate APIを使うのであれば、下記のようにSQLの別名を括弧でくくらなけれ"
-"ばなりません。"
+"<literal>createSQLQuery()</literal> を使って、 SQL でクエリを表現することもで"
+"きます。そして、 Hibernate に、 ResultSet からオブジェクトへのマッピングをま"
+"かせます。 <literal>session.connection()</literal> を呼べばどんなときでも、直"
+"接、 JDBC <literal>Connection</literal> を使用できることを覚えておきましょ"
+"う。もし、 Hibernate API を使うのであれば、下記のように SQL の別名を括弧でく"
+"くらなければなりません。"
 
-#. Tag: programlisting
-#: session_api.xml:492
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = session.createSQLQuery(\"SELECT {cat.*} FROM CAT {cat} "
-"WHERE ROWNUM<10\")\n"
-"    .addEntity(\"cat\", Cat.class)\n"
-".list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:494
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = session.createSQLQuery(\n"
-"    \"SELECT {cat}.ID AS {cat.id}, {cat}.SEX AS {cat.sex}, \" +\n"
-"           \"{cat}.MATE AS {cat.mate}, {cat}.SUBCLASS AS {cat.class}, ... \" "
-"+\n"
-"    \"FROM CAT {cat} WHERE ROWNUM<10\")\n"
-"    .addEntity(\"cat\", Cat.class)\n"
-".list()]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:496
 #, fuzzy, no-c-format
 msgid ""
 "SQL queries can contain named and positional parameters, just like Hibernate "
 "queries. More information about native SQL queries in Hibernate can be found "
-"in <xref linkend=\"querysql\"/>."
+"in <xref linkend=\"querysql\" />."
 msgstr ""
-"SQLクエリは、Hibernateクエリと同じように、名前付きのパラメータと位置パラメー"
-"タを持つことができます。 HibernateにおけるネイティブなSQLクエリの詳細について"
-"は、 <xref linkend=\"querysql\"/> を参照してください。"
+"SQL クエリは、 Hibernate クエリと同じように、名前付きのパラメータと位置パラ"
+"メータを持つことができます。 Hibernate におけるネイティブな SQL クエリの詳細"
+"については、 <xref linkend=\"querysql\"/> を参照してください。"
 
 #. Tag: title
-#: session_api.xml:507
 #, no-c-format
 msgid "Modifying persistent objects"
 msgstr "永続オブジェクトの修正"
 
 #. Tag: para
-#: session_api.xml:509
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Transactional persistent instances</emphasis> (i.e. objects "
 "loaded, saved, created or queried by the <literal>Session</literal>) can be "
@@ -1128,42 +731,30 @@
 "manipulate it directly while the <literal>Session</literal> is open:"
 msgstr ""
 "<emphasis>処理中の永続インスタンス</emphasis> (例: <literal>Session</"
-"literal> によって、 ロード、セーブ、作成、クエリされたオブジェクト)は、アプ"
-"リケーションに操作されます。 その際に変更された永続状態は、 "
-"<literal>Session</literal> が <emphasis>フラッシュ</emphasis> されるときに、"
-"永続化されます(これは、この章の後半で述べています)。 変更を永続化するため"
-"に、特殊なメソッド( <literal>update()</literal> のようなもの。これは、別の目"
-"的で使用します)を 呼ぶ必要はありません。 オブジェクトの状態を更新する一番簡"
-"単な方法は、オブジェクトを <literal>load()</literal> し、 <literal>Session</"
-"literal> をオープンにしている間に、直接操作することです。"
+"literal> によって、ロード、セーブ、作成、クエリされたオブジェクト)は、アプリ"
+"ケーションに操作されます。その際に変更された永続状態は、 <literal>Session</"
+"literal> が <emphasis>フラッシュ</emphasis> されるときに、永続化されます(こ"
+"れは、この章の後半で述べています)。変更を永続化するために、特殊なメソッド"
+"( <literal>update()</literal> のようなもの。これは、別の目的で使用します)を"
+"呼ぶ必要はありません。オブジェクトの状態を更新する一番簡単な方法は、オブジェ"
+"クトを <literal>load()</literal> し、 <literal>Session</literal> をオープンに"
+"している間に、直接操作することです。"
 
-#. Tag: programlisting
-#: session_api.xml:520
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DomesticCat cat = (DomesticCat) sess.load( Cat.class, new Long"
-"(69) );\n"
-"cat.setName(\"PK\");\n"
-"sess.flush();  // changes to cat are automatically detected and persisted]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:522
-#, fuzzy, no-c-format
-msgid ""
 "Sometimes this programming model is inefficient, as it requires in the same "
 "session both an SQL <literal>SELECT</literal> to load an object and an SQL "
 "<literal>UPDATE</literal> to persist its updated state. Hibernate offers an "
 "alternate approach by using detached instances."
 msgstr ""
-"(オブジェクトをロードするための)SQLの <literal>SELECT</literal> と(更新さ"
-"れた状態を永続化するための) SQLの <literal>UPDATE</literal> が同じセッション"
-"で必要となるので、このプログラミングモデルは、 効率が悪くなる場合がありま"
-"す。 そのため、Hibernateは別の方法を用意しています。それは、インスタンスを分"
-"離する(detached)方法です。"
+"(オブジェクトをロードするための) SQL の <literal>SELECT</literal> と(更新"
+"された状態を永続化するための) SQL の <literal>UPDATE</literal> が同じセッ"
+"ションで必要となるので、このプログラミングモデルは、効率が悪くなる場合があり"
+"ます。そのため、 Hibernate は別の方法を用意しています。それは、 detached イン"
+"スタンスを使用する方法です。"
 
 #. Tag: para
-#: session_api.xml:529
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate does not offer its own API for direct execution of "
@@ -1175,26 +766,26 @@
 "the notion of mass operations conflicts with object/relational mapping for "
 "online transaction processing-oriented applications. Future versions of "
 "Hibernate can, however, provide special mass operation functions. See <xref "
-"linkend=\"batch\"/> for some possible batch operation tricks."
+"linkend=\"batch\" /> for some possible batch operation tricks."
 msgstr ""
-"Hibernateは、 <placeholder-1/> 文や <placeholder-2/> 文を直接実行するAPIを用"
-"意していません。 Hibernateは、 <placeholder-3/> サービスであり、使われるSQL "
-"<placeholder-4/> のことを開発者が考える必要はありません。 JDBCはSQL文を実行す"
-"る完璧なAPIであり、 <placeholder-5/> を呼ぶことで いつでも、JDBC "
-"<placeholder-6/> を開発者は取得できます。 さらに、大量のデータ操作の考え方"
-"は、オンライントランザクション処理向きアプリケーションの オブジェクト/リレー"
-"ショナルマッピングと衝突します。 しかし、Hibernateの今後のバージョンでは、大"
-"量データを処理する特別な機能を提供するかもしれません。 バッチ操作に利用できる"
-"いくつかの工夫については、 <xref linkend=\"batch\"/> を参照してください。"
+"Hibernate は、 <literal>UPDATE</literal> 文や <literal>DELETE</literal> 文を"
+"直接実行する API を用意していません。 Hibernate は、 <emphasis>ステートマネー"
+"ジメント</emphasis> サービスであり、それを使うのに <emphasis>ステートメント</"
+"emphasis> のことを開発者が考える必要はありません。 JDBC は SQL 文を実行する完"
+"璧な API であり、 <literal>session.connection()</literal> を呼ぶことでいつで"
+"も、 JDBC <literal>Connection</literal> を開発者は取得できます。さらに、大量"
+"のデータ操作の考え方は、オンライントランザクション処理向きアプリケーションの"
+"オブジェクト/リレーショナルマッピングと衝突します。しかし、 Hibernate の今後"
+"のバージョンでは、大量データを処理する特別な機能を提供するかもしれません。"
+"バッチ操作に利用できるいくつかの工夫については、 <xref linkend=\"batch\"/> を"
+"参照してください。"
 
 #. Tag: title
-#: session_api.xml:546
 #, no-c-format
 msgid "Modifying detached objects"
-msgstr "分離オブジェクトの修正"
+msgstr "detached オブジェクトの修正"
 
 #. Tag: para
-#: session_api.xml:548
 #, no-c-format
 msgid ""
 "Many applications need to retrieve an object in one transaction, send it to "
@@ -1203,56 +794,36 @@
 "environment usually use versioned data to ensure isolation for the \"long\" "
 "unit of work."
 msgstr ""
-"多くのアプリケーションでは次のことが必要になります。 それは、あるトランザク"
-"ションでオブジェクトを復元し、操作するためにそれをUI層に送り、 その後に、新し"
-"いトランザクションで変更をセーブするといったことです。 並行性の高い環境で、こ"
-"のタイプのアプローチを使うアプリケーションでは、 \"期間の長い\" 作業単位の隔"
+"多くのアプリケーションでは次のことが必要になります。それは、あるトランザク"
+"ションでオブジェクトを復元し、操作するためにそれを UI 層に送り、その後に、新"
+"しいトランザクションで変更をセーブするといったことです。並行性の高い環境で、"
+"このタイプのアプローチを使うアプリケーションでは、「期間の長い」作業単位の隔"
 "離性を保証するために、バージョンデータが通常使われます。"
 
 #. Tag: para
-#: session_api.xml:555
 #, no-c-format
 msgid ""
 "Hibernate supports this model by providing for reattachment of detached "
 "instances using the <literal>Session.update()</literal> or <literal>Session."
 "merge()</literal> methods:"
 msgstr ""
-"Hibernateは、 <literal>Session.update()</literal> や <literal>Session.merge()"
-"</literal> メソッドを 使って、分離インスタンスを再追加することで、このモデル"
-"に対応します。"
+"Hibernate は、 <literal>Session.update()</literal> や <literal>Session.merge"
+"()</literal> メソッドを使って、 detached インスタンスを再追加することで、この"
+"モデルに対応します。"
 
-#. Tag: programlisting
-#: session_api.xml:561
-#, no-c-format
-msgid ""
-"<![CDATA[// in the first session\n"
-"Cat cat = (Cat) firstSession.load(Cat.class, catId);\n"
-"Cat potentialMate = new Cat();\n"
-"firstSession.save(potentialMate);\n"
-"\n"
-"// in a higher layer of the application\n"
-"cat.setMate(potentialMate);\n"
-"\n"
-"// later, in a new session\n"
-"secondSession.update(cat);  // update cat\n"
-"secondSession.update(mate); // update mate]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:563
 #, no-c-format
 msgid ""
 "If the <literal>Cat</literal> with identifier <literal>catId</literal> had "
 "already been loaded by <literal>secondSession</literal> when the application "
 "tried to reattach it, an exception would have been thrown."
 msgstr ""
-"識別子<literal>catId</literal> を持つ <literal>Cat</literal> が、既に "
+"識別子 <literal>catId</literal> を持つ <literal>Cat</literal> が、既に "
 "<literal>secondSession</literal> でロードされていた場合は、再追加しようとした"
 "ときに、例外が投げられます。"
 
 #. Tag: para
-#: session_api.xml:569
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use <literal>update()</literal> if you are certain that the session does not "
 "contain an already persistent instance with the same identifier. Use "
@@ -1262,84 +833,67 @@
 "fresh session, ensuring that the reattachment of your detached instances is "
 "the first operation that is executed."
 msgstr ""
-"同じ識別子を持つ永続インスタンスをセッションが既に保持していないことを 確信で"
-"きるなら <literal>update()</literal> を使いましょう。 そして、セッションの状"
-"態を考えずに、どんな場合でも変更をマージしたい場合は、 <literal>merge()</"
-"literal> を使いましょう。 すなわち、分離オブジェクトの再追加操作が、最初に実"
-"行されることを確実にするために、 通常は <literal>update()</literal> が新しい"
-"セッションのなかで最初に呼ばれるメソッドになります。"
+"同じ識別子を持つ永続インスタンスをセッションが既に保持していないことを確信で"
+"きるなら <literal>update()</literal> を使います。そして、セッションの状態を考"
+"えずに、どんな場合でも変更をマージしたい場合は、 <literal>merge()</literal> "
+"を使います。すなわち、 detached インスタンスの再追加操作が、最初に実行される"
+"ことを確実にするために、通常は <literal>update()</literal> が新しいセッション"
+"のなかで最初に呼ばれるメソッドになります。"
 
 #. Tag: para
-#: session_api.xml:578
 #, fuzzy, no-c-format
 msgid ""
 "The application should individually <literal>update()</literal> detached "
 "instances that are reachable from the given detached instance "
 "<emphasis>only</emphasis> if it wants their state to be updated. This can be "
 "automated using <emphasis>transitive persistence</emphasis>. See <xref "
-"linkend=\"objectstate-transitive\"/> for more information."
+"linkend=\"objectstate-transitive\" /> for more information."
 msgstr ""
-"分離インスタンスから到達可能な、分離インスタンスをアプリケーションは個別に "
-"<literal>update()</literal> すべきです。それは、その状態を更新したい場合に "
-"<emphasis>限り</emphasis> ます。 <emphasis>遷移的な永続化</emphasis> を使え"
-"ば、もちろん自動化できます。 <xref linkend=\"objectstate-transitive\"/> を参"
-"照してください。"
+"detached インスタンスから到達可能な、 detached インスタンスをアプリケーション"
+"は個別に <literal>update()</literal> すべきです。それは、その状態を更新したい"
+"場合に <emphasis>限ります。</emphasis>  <emphasis>遷移的な永続化</emphasis> "
+"を使えば、もちろん自動化できます。<xref linkend=\"objectstate-transitive\"/> "
+"を参照してください。"
 
 #. Tag: para
-#: session_api.xml:585
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>lock()</literal> method also allows an application to "
 "reassociate an object with a new session. However, the detached instance has "
 "to be unmodified."
 msgstr ""
-"メソッドでもまた、新しいセッションにオブジェクトを再関連付けできます。 しか"
-"し、分離インスタンスは無修正でなければなりません。"
+"<literal>lock()</literal> メソッドでもまた、新しいセッションにオブジェクトを"
+"再関連付けできます。しかし、 detached インスタンスは無修正でなければなりませ"
+"ん。"
 
-#. Tag: programlisting
-#: session_api.xml:590
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[//just reassociate:\n"
-"sess.lock(fritz, LockMode.NONE);\n"
-"//do a version check, then reassociate:\n"
-"sess.lock(izi, LockMode.READ);\n"
-"//do a version check, using SELECT ... FOR UPDATE, then reassociate:\n"
-"sess.lock(pk, LockMode.UPGRADE);]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:592
-#, fuzzy, no-c-format
-msgid ""
 "Note that <literal>lock()</literal> can be used with various "
 "<literal>LockMode</literal>s. See the API documentation and the chapter on "
 "transaction handling for more information. Reattachment is not the only "
 "usecase for <literal>lock()</literal>."
 msgstr ""
 "<literal>lock()</literal> は、さまざまな <literal>LockMode</literal> とともに"
-"使うことができます。 詳細は、APIドキュメントとトランザクション処理の章を参照"
-"してください。 再追加のときにだけ、 <literal>lock()</literal> が使われるわけ"
-"ではありません。"
+"使うことができます。詳細は、 API ドキュメントとトランザクション処理の章を参照"
+"してください。再追加のときにだけ、 <literal>lock()</literal> が使われるわけで"
+"はありません。"
 
 #. Tag: para
-#: session_api.xml:599
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Other models for long units of work are discussed in <xref linkend="
-"\"transactions-optimistic\"/>."
+"\"transactions-optimistic\" />."
 msgstr ""
-"期間の長い作業単位の、その他のモデルは、<xref linked=\"transactions-"
+"期間の長い作業単位の、その他のモデルは、 <xref linkend=\"transactions-"
 "optimistic\"/> で述べています。"
 
 #. Tag: title
-#: session_api.xml:606
 #, no-c-format
 msgid "Automatic state detection"
 msgstr "自動的な状態検出"
 
 #. Tag: para
-#: session_api.xml:608
 #, no-c-format
 msgid ""
 "Hibernate users have requested a general purpose method that either saves a "
@@ -1347,32 +901,13 @@
 "detached instances associated with its current identifier. The "
 "<literal>saveOrUpdate()</literal> method implements this functionality."
 msgstr ""
-"Hibernateのユーザは次の2つのケースのどちらにも使える汎用的なメソッドを要求し"
-"ていました。 それは、新しい識別子を生成して一時的なインスタンスをセーブするこ"
-"とと、 その時点の識別子と関連づいている分離インスタンスを更新/再追加すること"
-"のできるメソッドです。 <literal>saveOrUpdate()</literal> はこのような機能を実"
-"現したメソッドです。"
+"Hibernate のユーザーは次の2つのケースのどちらにも使える汎用的なメソッドを要求"
+"していました。それは、新しい識別子を生成して transient インスタンスをセーブす"
+"ることと、その時点の識別子と関連づいている detached インスタンスを更新/再追加"
+"することのできるメソッドです。 <literal>saveOrUpdate()</literal> はこのような"
+"機能を実現したメソッドです。"
 
-#. Tag: programlisting
-#: session_api.xml:615
-#, no-c-format
-msgid ""
-"<![CDATA[// in the first session\n"
-"Cat cat = (Cat) firstSession.load(Cat.class, catID);\n"
-"\n"
-"// in a higher tier of the application\n"
-"Cat mate = new Cat();\n"
-"cat.setMate(mate);\n"
-"\n"
-"// later, in a new session\n"
-"secondSession.saveOrUpdate(cat);   // update existing state (cat has a non-"
-"null id)\n"
-"secondSession.saveOrUpdate(mate);  // save the new instance (mate has a null "
-"id)]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:617
 #, no-c-format
 msgid ""
 "The usage and semantics of <literal>saveOrUpdate()</literal> seems to be "
@@ -1382,49 +917,43 @@
 "<literal>merge()</literal>. Some whole applications will never use either of "
 "these methods."
 msgstr ""
-"<literal>saveOrUpdate()</literal> の使用方法と意味は、 新しいユーザにとって混"
-"乱を招くかもしれません。 まず第一に、あるセッションで使用したインスタンスを別"
-"の新しいセッションで使おうとしない限り、 <literal>update()</literal> や "
+"<literal>saveOrUpdate()</literal> の使用方法と意味は、新しいユーザーにとって"
+"混乱を招くかもしれません。まず第一に、あるセッションで使用したインスタンスを"
+"別の新しいセッションで使おうとしない限り、 <literal>update()</literal> や "
 "<literal>saveOrUpdate()</literal> や <literal>merge()</literal> を使う必要は"
-"ありません。 アプリケーション全体を通じて、これらのメソッドを全く使わないこと"
+"ありません。アプリケーション全体を通じて、これらのメソッドを全く使わないこと"
 "もあります。"
 
 #. Tag: para
-#: session_api.xml:625
 #, no-c-format
 msgid ""
 "Usually <literal>update()</literal> or <literal>saveOrUpdate()</literal> are "
 "used in the following scenario:"
 msgstr ""
 "通常、 <literal>update()</literal> や <literal>saveOrUpdate()</literal> は次"
-"のシナリオで 使われます。"
+"のシナリオで使われます:"
 
 #. Tag: para
-#: session_api.xml:632
 #, no-c-format
 msgid "the application loads an object in the first session"
 msgstr "アプリケーションが最初のセッションでオブジェクトをロードします。"
 
 #. Tag: para
-#: session_api.xml:637
 #, no-c-format
 msgid "the object is passed up to the UI tier"
-msgstr "オブジェクトがUI層に送られます。"
+msgstr "オブジェクトが UI 層に送られます。"
 
 #. Tag: para
-#: session_api.xml:642
 #, no-c-format
 msgid "some modifications are made to the object"
 msgstr "オブジェクトに対して変更が加えられます。"
 
 #. Tag: para
-#: session_api.xml:647
 #, no-c-format
 msgid "the object is passed back down to the business logic tier"
 msgstr "オブジェクトがビジネスロジック層に送られます。"
 
 #. Tag: para
-#: session_api.xml:652
 #, no-c-format
 msgid ""
 "the application persists these modifications by calling <literal>update()</"
@@ -1434,49 +963,42 @@
 "とで、これらの変更を永続化します。"
 
 #. Tag: para
-#: session_api.xml:659
 #, no-c-format
 msgid "<literal>saveOrUpdate()</literal> does the following:"
-msgstr "<literal>saveOrUpdate()</literal> は以下のことを行います。"
+msgstr "<literal>saveOrUpdate()</literal> は以下のことを行います:"
 
 #. Tag: para
-#: session_api.xml:665
 #, no-c-format
 msgid "if the object is already persistent in this session, do nothing"
 msgstr ""
 "オブジェクトがこのセッションで、すでに永続化されていれば、何もしません。"
 
 #. Tag: para
-#: session_api.xml:670
 #, no-c-format
 msgid ""
 "if another object associated with the session has the same identifier, throw "
 "an exception"
 msgstr ""
-"そのセッションに関連づいている別のオブジェクトが同じ識別子を持っているなら、 "
+"そのセッションに関連づいている別のオブジェクトが同じ識別子を持っているなら、"
 "例外を投げます。"
 
 #. Tag: para
-#: session_api.xml:676
 #, no-c-format
 msgid "if the object has no identifier property, <literal>save()</literal> it"
 msgstr ""
 "オブジェクトの識別子が値を持たないならば、 <literal>save()</literal> します。"
 
 #. Tag: para
-#: session_api.xml:681
 #, no-c-format
 msgid ""
 "if the object's identifier has the value assigned to a newly instantiated "
 "object, <literal>save()</literal> it"
 msgstr ""
 "オブジェクトの識別子が値を持ち、その値が新たにインスタンス化されたオブジェク"
-"トのための値である場合、 そのオブジェクトを <literal>save()</literal> しま"
-"す。"
+"トのための値である場合、そのオブジェクトを <literal>save()</literal> します。"
 
 #. Tag: para
-#: session_api.xml:687
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "if the object is versioned by a <literal>&lt;version&gt;</literal> or "
 "<literal>&lt;timestamp&gt;</literal>, and the version property value is the "
@@ -1484,25 +1006,22 @@
 "literal> it"
 msgstr ""
 "オブジェクトが( <literal>&lt;version&gt;</literal> や <literal>&lt;"
-"timestamp&gt;</literal> によって) バージョンづけされていて、バージョンのプロ"
-"パティが値を持ち、 その値が新しくインスタンス化されたオブジェクトのための値で"
-"ある場合、 そのオブジェクトを <literal>save()</literal> します。"
+"timestamp&gt;</literal> によって)バージョンづけされていて、バージョンのプロ"
+"パティが値を持ち、その値が新しくインスタンス化されたオブジェクトのための値で"
+"ある場合、そのオブジェクトを <literal>save()</literal> します。"
 
 #. Tag: para
-#: session_api.xml:695
 #, no-c-format
 msgid "otherwise <literal>update()</literal> the object"
 msgstr ""
 "そうでない場合は、そのオブジェクトを <literal>update()</literal> します。"
 
 #. Tag: para
-#: session_api.xml:701
 #, no-c-format
 msgid "and <literal>merge()</literal> is very different:"
-msgstr "そして、 <literal>merge()</literal> は以下のようにとても異なります。"
+msgstr "そして、 <literal>merge()</literal> は以下のように非常に異なります:"
 
 #. Tag: para
-#: session_api.xml:707
 #, no-c-format
 msgid ""
 "if there is a persistent instance with the same identifier currently "
@@ -1510,43 +1029,38 @@
 "persistent instance"
 msgstr ""
 "同じ識別子を持つ永続化インスタンスがその時点でセッションと関連付いているなら"
-"ば、 引数で受け取ったオブジェクトの状態を永続化インスタンスにコピーします。"
+"ば、引数で受け取ったオブジェクトの状態を永続化インスタンスにコピーします。"
 
 #. Tag: para
-#: session_api.xml:714
 #, no-c-format
 msgid ""
 "if there is no persistent instance currently associated with the session, "
 "try to load it from the database, or create a new persistent instance"
 msgstr ""
-"永続化インスタンスがその時点でセッションに関連付いていないなら、 データベース"
+"永続化インスタンスがその時点でセッションに関連付いていないなら、データベース"
 "からそれをロードするか、あるいは、新しい永続化インスタンスを作成します。"
 
 #. Tag: para
-#: session_api.xml:720
 #, no-c-format
 msgid "the persistent instance is returned"
 msgstr "永続化インスタンスが返されます。"
 
 #. Tag: para
-#: session_api.xml:725
 #, no-c-format
 msgid ""
 "the given instance does not become associated with the session, it remains "
 "detached"
 msgstr ""
-"引数として与えたインスタンスはセッションと関連を持ちません。 それは、分離状態"
+"引数として与えたインスタンスはセッションと関連を持ちません。それは、分離状態"
 "のままです。"
 
 #. Tag: title
-#: session_api.xml:735
 #, no-c-format
 msgid "Deleting persistent objects"
 msgstr "永続オブジェクトの削除"
 
 #. Tag: para
-#: session_api.xml:737
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Session.delete()</literal> will remove an object's state from the "
 "database. Your application, however, can still hold a reference to a deleted "
@@ -1554,19 +1068,12 @@
 "persistent instance, transient."
 msgstr ""
 "<literal>Session.delete()</literal> はオブジェクトの状態をデータベースから削"
-"除します。 もちろん、削除したオブジェクトをアプリケーションが保持したままでも"
-"よいです。 そのため、 <literal>delete()</literal> は永続インスタンスを一時的"
-"にするものと考えるのが一番です。"
+"除します。もちろん、削除したオブジェクトをアプリケーションが保持したままでも"
+"よいです。そのため、 <literal>delete()</literal> は永続インスタンスを "
+"transient にするものと考えるのが一番です。"
 
-#. Tag: programlisting
-#: session_api.xml:744
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[sess.delete(cat);]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:746
-#, fuzzy, no-c-format
 msgid ""
 "You can delete objects in any order, without risk of foreign key constraint "
 "violations. It is still possible to violate a <literal>NOT NULL</literal> "
@@ -1574,50 +1081,28 @@
 "g. if you delete the parent, but forget to delete the children."
 msgstr ""
 "外部キー制約に違反するリスクもなく、好きな順番でオブジェクトを削除することが"
-"できます。 ただし、間違った順番でオブジェクトを削除すると、外部キーカラムの "
-"<literal>NOT NULL</literal> 制約に違反する可能性があります。 例えば、親オブ"
+"できます。ただし、間違った順番でオブジェクトを削除すると、外部キーカラムの "
+"<literal>NOT NULL</literal> 制約に違反する可能性があります。例えば、親オブ"
 "ジェクトを削除したときに、子供オブジェクトを削除し忘れた場合です。"
 
 #. Tag: title
-#: session_api.xml:757
 #, no-c-format
 msgid "Replicating object between two different datastores"
 msgstr "異なる二つのデータストア間でのオブジェクトのレプリケーション"
 
 #. Tag: para
-#: session_api.xml:759
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is sometimes useful to be able to take a graph of persistent instances "
 "and make them persistent in a different datastore, without regenerating "
 "identifier values."
 msgstr ""
-"永続インスタンスのグラフを別のデータストアに永続化する場合に、 識別子の値を再"
+"永続インスタンスのグラフを別のデータストアに永続化する場合に、識別子の値を再"
 "生成せずにすむと便利な場合があります。"
 
-#. Tag: programlisting
-#: session_api.xml:765
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[//retrieve a cat from one database\n"
-"Session session1 = factory1.openSession();\n"
-"Transaction tx1 = session1.beginTransaction();\n"
-"Cat cat = session1.get(Cat.class, catId);\n"
-"tx1.commit();\n"
-"session1.close();\n"
-"\n"
-"//reconcile with a second database\n"
-"Session session2 = factory2.openSession();\n"
-"Transaction tx2 = session2.beginTransaction();\n"
-"session2.replicate(cat, ReplicationMode.LATEST_VERSION);\n"
-"tx2.commit();\n"
-"session2.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:767
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>ReplicationMode</literal> determines how <literal>replicate()</"
 "literal> will deal with conflicts with existing rows in the database:"
 msgstr ""
@@ -1626,49 +1111,44 @@
 "します。"
 
 #. Tag: para
-#: session_api.xml:774
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.IGNORE</literal>: ignores the object when there is "
 "an existing database row with the same identifier"
 msgstr ""
 "<literal>ReplicationMode.IGNORE</literal> - 同じ識別子を持つ行がデータベース"
-"に存在するなら、 そのオブジェクトを無視します。"
+"に存在するなら、そのオブジェクトを無視します。"
 
 #. Tag: para
-#: session_api.xml:780
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.OVERWRITE</literal>: overwrites any existing "
 "database row with the same identifier"
 msgstr ""
-"<literal>ReplicationMode.OVERWRITE</literal> - 同じ識別子を持つ既存の行を す"
-"べて上書きします。"
+"<literal>ReplicationMode.OVERWRITE</literal> - 同じ識別子を持つ既存の行をすべ"
+"て上書きします。"
 
 #. Tag: para
-#: session_api.xml:786
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.EXCEPTION</literal>: throws an exception if there "
 "is an existing database row with the same identifier"
 msgstr ""
 "<literal>ReplicationMode.EXCEPTION</literal> - 同じ識別子を持つ行がデータベー"
-"スに存在するなら、 例外を投げます。"
+"スに存在するなら、例外を投げます。"
 
 #. Tag: para
-#: session_api.xml:792
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.LATEST_VERSION</literal>: overwrites the row if its "
 "version number is earlier than the version number of the object, or ignore "
 "the object otherwise"
 msgstr ""
 "<literal>ReplicationMode.LATEST_VERSION</literal> - 行に保存されているバー"
-"ジョン番号が、 引数のオブジェクトのバージョン番号より古いならば、その行を上書"
+"ジョン番号が、引数のオブジェクトのバージョン番号より古いならば、その行を上書"
 "きします。"
 
 #. Tag: para
-#: session_api.xml:800
 #, no-c-format
 msgid ""
 "Usecases for this feature include reconciling data entered into different "
@@ -1676,110 +1156,96 @@
 "product upgrades, rolling back changes made during non-ACID transactions and "
 "more."
 msgstr ""
-"次のようなケースで、この機能を使用します。 異なるデータベースインスタンスに入"
-"れられたデータの同期、 製品更新時におけるシステム設定情報の更新、非ACIDトラン"
-"ザクションのなかで加えられた変更のロールバックなどです。"
+"次のようなケースで、この機能を使用します。異なるデータベースインスタンスに入"
+"れられたデータの同期、製品更新時におけるシステム設定情報の更新、非 ACID トラ"
+"ンザクションのなかで加えられた変更のロールバックなどです。"
 
 #. Tag: title
-#: session_api.xml:809
 #, no-c-format
 msgid "Flushing the Session"
 msgstr "セッションのフラッシュ"
 
 #. Tag: para
-#: session_api.xml:811
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes the <literal>Session</literal> will execute the SQL statements "
 "needed to synchronize the JDBC connection's state with the state of objects "
 "held in memory. This process, called <emphasis>flush</emphasis>, occurs by "
 "default at the following points:"
 msgstr ""
-"JDBCコネクションの状態とメモリ上のオブジェクトの状態を同期させるために必要な "
-"SQL文を <literal>Session</literal> が実行することがときどきあります。 この処"
-"理 <emphasis>flush</emphasis> は、デフォルトでは次のときに起こります。"
+"JDBC コネクションの状態とメモリ上のオブジェクトの状態を同期させるために必要"
+"な SQL 文を <literal>Session</literal> が実行することがときどきあります。この"
+"処理 <emphasis>flush</emphasis> は、デフォルトでは次のときに起こります。"
 
 #. Tag: para
-#: session_api.xml:820
 #, no-c-format
 msgid "before some query executions"
 msgstr "クエリを実行する前"
 
 #. Tag: para
-#: session_api.xml:825
 #, no-c-format
 msgid "from <literal>org.hibernate.Transaction.commit()</literal>"
 msgstr "<literal>org.hibernate.Transaction.commit()</literal> を実行したとき"
 
 #. Tag: para
-#: session_api.xml:830
 #, no-c-format
 msgid "from <literal>Session.flush()</literal>"
 msgstr "<literal>Session.flush()</literal> を実行したとき"
 
 #. Tag: para
-#: session_api.xml:836
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The SQL statements are issued in the following order:"
-msgstr "SQL文は以下の順番で発行されます。"
+msgstr "SQL 文は以下の順番で発行されます。"
 
 #. Tag: para
-#: session_api.xml:842
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "all entity insertions in the same order the corresponding objects were saved "
 "using <literal>Session.save()</literal>"
 msgstr ""
 "すべてのエンティティの挿入。これは、 <literal>Session.save()</literal> を使っ"
-"てセーブした オブジェクトの順に実行していきます。"
+"てセーブしたオブジェクトの順に実行していきます。"
 
 #. Tag: para
-#: session_api.xml:848
 #, no-c-format
 msgid "all entity updates"
 msgstr "すべてのエンティティの更新"
 
 #. Tag: para
-#: session_api.xml:853
 #, no-c-format
 msgid "all collection deletions"
 msgstr "すべてのコレクションの削除"
 
 #. Tag: para
-#: session_api.xml:858
 #, no-c-format
 msgid "all collection element deletions, updates and insertions"
 msgstr "すべてのコレクションの要素に対する削除、更新、挿入"
 
 #. Tag: para
-#: session_api.xml:863
 #, no-c-format
 msgid "all collection insertions"
 msgstr "すべてのコレクションの挿入"
 
 #. Tag: para
-#: session_api.xml:868
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "all entity deletions in the same order the corresponding objects were "
 "deleted using <literal>Session.delete()</literal>"
 msgstr ""
-"すべてのエンティティの削除。これは、<literal>Session.delete()</literal> を"
-"使って 削除したオブジェクトの順に実行していきます。"
+"すべてのエンティティの削除。これは、 <literal>Session.delete()</literal> を"
+"使って削除したオブジェクトの順に実行していきます。"
 
 #. Tag: para
-#: session_api.xml:875
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An exception is that objects using <literal>native</literal> ID generation "
 "are inserted when they are saved."
 msgstr ""
 "(1つ例外があります。 <literal>native</literal> ID 生成を使ったオブジェクト"
-"は、 それらがセーブされたときに挿入されます。)"
+"は、それらがセーブされたときに挿入されます。)"
 
 #. Tag: para
-#: session_api.xml:880
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Except when you explicitly <literal>flush()</literal>, there are absolutely "
 "no guarantees about <emphasis>when</emphasis> the <literal>Session</literal> "
@@ -1788,13 +1254,12 @@
 "(..)</literal> will never return stale or incorrect data."
 msgstr ""
 "明示的に <literal>flush()</literal> するときを除いて、 <emphasis>いつ</"
-"emphasis><literal>Session</literal> がJDBCをコールするのかについて 絶対的な保"
-"証はありません。ただし、それらが実行される <emphasis>順番</emphasis> だけは "
-"保証されます。 また、Hibernate は、 <literal>Query.list(..)</literal> が古い"
-"データや間違ったデータ返さないことを 保証しています。"
+"emphasis> <literal>Session</literal> が JDBC をコールするのかについて絶対的な"
+"保証はありません。ただし、それらが実行される <emphasis>順番</emphasis> だけは"
+"保証されます。また、 Hibernate は、 <literal>Query.list(..)</literal> が古い"
+"データや間違ったデータ返さないことを保証しています。"
 
 #. Tag: para
-#: session_api.xml:888
 #, fuzzy, no-c-format
 msgid ""
 "It is possible to change the default behavior so that flush occurs less "
@@ -1804,72 +1269,48 @@
 "never flush unless <literal>flush()</literal> is called explicitly. The last "
 "mode is useful for long running units of work, where a <literal>Session</"
 "literal> is kept open and disconnected for a long time (see <xref linkend="
-"\"transactions-optimistic-longsession\"/>)."
+"\"transactions-optimistic-longsession\" />)."
 msgstr ""
 "フラッシュが頻繁に起こらないようにデフォルトの振る舞いを変えることができま"
-"す。 <literal>FlushMode</literal> クラスは3つの異なるモードを定義します。 そ"
-"れは、コミット時にだけフラッシュするモード (Hibernateの "
-"<literal>Transaction</literal> APIが使われる場合だけです)、 説明のあった処理"
-"順に基づいて自動でフラッシュするモード、 <literal>flush()</literal> が明示的"
-"に呼ばれない限りフラッシュしないモードの3つです。 最後のモードは、作業単位が"
-"長期間に及ぶ場合に役に立ちます ( <xref linkend=\"transactions-optimistic-"
-"longsession\"/> を参照してください)。"
+"す。 <literal>FlushMode</literal> クラスは3つの異なるモードを定義します。それ"
+"は、コミット時にだけフラッシュするモード(Hibernate の <literal>Transaction</"
+"literal> API が使われる場合だけです)、説明のあった処理順に基づいて自動でフ"
+"ラッシュするモード、 <literal>flush()</literal> が明示的に呼ばれない限りフ"
+"ラッシュしないモードの3つです。最後のモードは、作業単位が長期間に及ぶ場合に"
+"役に立ちます ( <xref linkend=\"transactions-optimistic-longsession\"/> を参照"
+"してください)。"
 
-#. Tag: programlisting
-#: session_api.xml:898
-#, no-c-format
-msgid ""
-"<![CDATA[sess = sf.openSession();\n"
-"Transaction tx = sess.beginTransaction();\n"
-"sess.setFlushMode(FlushMode.COMMIT); // allow queries to return stale state\n"
-"\n"
-"Cat izi = (Cat) sess.load(Cat.class, id);\n"
-"izi.setName(iznizi);\n"
-"\n"
-"// might return stale data\n"
-"sess.find(\"from Cat as cat left outer join cat.kittens kitten\");\n"
-"\n"
-"// change to izi is not flushed!\n"
-"...\n"
-"tx.commit(); // flush occurs\n"
-"sess.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:900
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "During flush, an exception might occur (e.g. if a DML operation violates a "
 "constraint). Since handling exceptions involves some understanding of "
 "Hibernate's transactional behavior, we discuss it in <xref linkend="
-"\"transactions\"/>."
+"\"transactions\" />."
 msgstr ""
-"フラッシュのとき、例外が発生するかもしれません。 (例えば、DML操作が制約を違"
-"反するような場合です。) 例外処理を理解するためには、Hibernateのトランザク"
-"ションの振る舞いを理解する必要があるため、 <xref linkend=\"transactions\"/> "
-"で説明します。"
+"フラッシュのとき、例外が発生するかもしれません(例えば、 DML 操作が制約を違反"
+"するような場合です)。例外処理を理解するためには、 Hibernate のトランザクショ"
+"ンの振る舞いを理解する必要があるため、 <xref linkend=\"transactions\"/> で説"
+"明します。"
 
 #. Tag: title
-#: session_api.xml:909
 #, no-c-format
 msgid "Transitive persistence"
 msgstr "連鎖的な永続化"
 
 #. Tag: para
-#: session_api.xml:911
 #, no-c-format
 msgid ""
 "It is quite cumbersome to save, delete, or reattach individual objects, "
 "especially if you deal with a graph of associated objects. A common case is "
 "a parent/child relationship. Consider the following example:"
 msgstr ""
-"個々のオブジェクトをセーブしたり、削除したり、再追加したりすることは かなり面"
-"倒です。特に、関連するオブジェクトを扱うような場合には際立ちます。 よくあるの"
-"は、親子関係を扱うケースです。 以下の例を考えてみましょう。"
+"個々のオブジェクトをセーブしたり、削除したり、再追加したりすることはかなり面"
+"倒です。特に、関連するオブジェクトを扱うような場合には際立ちます。よくあるの"
+"は、親子関係を扱うケースです。以下の例を考えてみましょう:"
 
 #. Tag: para
-#: session_api.xml:917
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the children in a parent/child relationship would be value typed (e.g. a "
 "collection of addresses or strings), their life cycle would depend on the "
@@ -1880,17 +1321,16 @@
 "collection. Since value-typed objects cannot have shared references, "
 "Hibernate will detect this and delete the child from the database."
 msgstr ""
-"もし、親子関係の子が値型なら(例えば、住所や文字列のコレクション)、 それらの"
-"ライフサイクルは親に依存しており、便利な状態変化の\"カスケード\"を使うため"
-"に、 追加の作業は必要はありません。 親がセーブされたとき、値型の子オブジェク"
-"トも同じようにセーブされますし、 親が削除されたときは、子も削除されます。その"
-"他の操作も同じです。 コレクションから1つの子を削除するような操作でもうまくい"
-"きます。 すなわち、Hibernateはこの削除操作を検出すると、 値型のオブジェクトは"
-"参照を共有できないので、データベースからその子供を削除します。"
+"もし、親子関係の子が値型なら(例えば、住所や文字列のコレクション)、それらの"
+"ライフサイクルは親に依存しており、便利な状態変化の「カスケード」を使うため"
+"に、追加の作業は必要はありません。親がセーブされたとき、値型の子オブジェクト"
+"も同じようにセーブされますし、親が削除されたときは、子も削除されます。その他"
+"の操作も同じです。コレクションから1つの子を削除するような操作でもうまくいきま"
+"す。すなわち、 Hibernate はこの削除操作を検出すると、値型のオブジェクトは参照"
+"を共有できないので、データベースからその子供を削除します。"
 
 #. Tag: para
-#: session_api.xml:928
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now consider the same scenario with parent and child objects being entities, "
 "not value-types (e.g. categories and items, or parent and child cats). "
@@ -1901,15 +1341,14 @@
 "reachability</emphasis> by default."
 msgstr ""
 "ここで、親と子が値型でなくエンティティであるとして同じシナリオを考えてみま"
-"しょう。 (例えば、カテゴリーと品目の関係や親と子の猫の関係です。) エンティ"
-"ティは、それ自身がライフサイクルを持ち、参照の共有をサポートします。 (そのた"
-"め、コレクションからエンティティを削除することは、 エンティティ自身の削除を意"
-"味しません。) また、エンティティは、デフォルトでは、関連する他のエンティティ"
-"へ 状態をカスケードすることはありません。 Hibernateは <emphasis>到達可能性に"
+"しょう。(例えば、カテゴリーと品目の関係や親と子の猫の関係です。)エンティ"
+"ティは、それ自身がライフサイクルを持ち、参照の共有をサポートします。(そのた"
+"め、コレクションからエンティティを削除することは、エンティティ自身の削除を意"
+"味しません。)また、エンティティは、デフォルトでは、関連する他のエンティティ"
+"へ状態をカスケードすることはありません。 Hibernate は <emphasis>到達可能性に"
 "よる永続化</emphasis> をデフォルトでは実行しません。"
 
 #. Tag: para
-#: session_api.xml:937
 #, no-c-format
 msgid ""
 "For each basic operation of the Hibernate session - including "
@@ -1920,49 +1359,33 @@
 "operation to be cascaded along an association, you must indicate that in the "
 "mapping document. For example:"
 msgstr ""
-"HibernateのSessionの基本操作( <literal>persist(), merge(), saveOrUpdate(), "
-"delete(), lock(), refresh(), evict(), replicate()</literal> が含まれます)に"
-"対して、 それぞれに対応するカスケードスタイルがあります。 それぞれのカスケー"
-"ドスタイルには、 <literal>create, merge, save-update, delete, lock, refresh, "
-"evict, replicate</literal> という名前がついています。 もし、関連に沿ってカス"
-"ケードさせたい操作があるなら、マッピングファイルにそう指定しなければなりませ"
-"ん。 例えば、以下のようにします。"
+"Hibernate の Session の基本操作( <literal>persist(), merge(), saveOrUpdate"
+"(), delete(), lock(), refresh(), evict(), replicate()</literal> が含まれま"
+"す)に対して、それぞれに対応するカスケードスタイルがあります。それぞれのカス"
+"ケードスタイルには、 <literal>create, merge, save-update, delete, lock, "
+"refresh, evict, replicate</literal> という名前がついています。もし、関連に"
+"沿ってカスケードさせたい操作があるなら、マッピングファイルにそう指定しなけれ"
+"ばなりません。例えば、以下のようにします:"
 
-#. Tag: programlisting
-#: session_api.xml:946
-#, no-c-format
-msgid "<![CDATA[<one-to-one name=\"person\" cascade=\"persist\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:948
 #, no-c-format
 msgid "Cascade styles my be combined:"
-msgstr "カスケードスタイルは、組み合わせることができます。"
+msgstr "カスケードスタイルは、組み合わせることができます:"
 
-#. Tag: programlisting
-#: session_api.xml:952
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<one-to-one name=\"person\" cascade=\"persist,delete,lock\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:954
-#, fuzzy, no-c-format
-msgid ""
 "You can even use <literal>cascade=\"all\"</literal> to specify that "
 "<emphasis>all</emphasis> operations should be cascaded along the "
 "association. The default <literal>cascade=\"none\"</literal> specifies that "
 "no operations are to be cascaded."
 msgstr ""
 "<emphasis>すべての</emphasis> 操作を関連に沿ってカスケードするよう指定すると"
-"きは、 <literal>cascade=\"all\"</literal> を使います。 デフォルトの "
+"きは、 <literal>cascade=\"all\"</literal> を使います。デフォルトの "
 "<literal>cascade=\"none\"</literal> は、どの操作もカスケードしないことを意味"
 "します。"
 
 #. Tag: para
-#: session_api.xml:960
 #, no-c-format
 msgid ""
 "A special cascade style, <literal>delete-orphan</literal>, applies only to "
@@ -1971,18 +1394,16 @@
 "association."
 msgstr ""
 "特殊なカスケードスタイル <literal>delete-orphan</literal> は、一対多関連にだ"
-"け 適用できます。 これは、関連から削除された子供のオブジェクトに対して、 "
+"け適用できます。これは、関連から削除された子供のオブジェクトに対して、 "
 "<literal>delete()</literal> 操作が適用されることを意味します。"
 
 #. Tag: para
-#: session_api.xml:967
 #, no-c-format
 msgid "Recommendations:"
 msgstr "おすすめ:"
 
 #. Tag: para
-#: session_api.xml:973
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It does not usually make sense to enable cascade on a <literal>&lt;many-to-"
 "one&gt;</literal> or <literal>&lt;many-to-many&gt;</literal> association. "
@@ -1990,12 +1411,11 @@
 "<literal>&lt;one-to-many&gt;</literal> associations."
 msgstr ""
 "普通、 <literal>&lt;many-to-one&gt;</literal> や <literal>&lt;many-to-"
-"many&gt;</literal> 関連に対しては、 カスケードを設定する意味はありません。 "
+"many&gt;</literal> 関連に対しては、カスケードを設定する意味はありません。 "
 "<literal>&lt;one-to-one&gt;</literal> と <literal>&lt;one-to-many&gt;</"
-"literal> 関連に対しては、 カスケードが役に立つことがあります。"
+"literal> 関連に対しては、カスケードが役に立つことがあります。"
 
 #. Tag: para
-#: session_api.xml:981
 #, no-c-format
 msgid ""
 "If the child object's lifespan is bounded by the lifespan of the parent "
@@ -2003,11 +1423,10 @@
 "<literal>cascade=\"all,delete-orphan\"</literal>."
 msgstr ""
 "子供オブジェクトの寿命が親オブジェクトの寿命に制限を受けるならば、 "
-"<literal>cascade=\"all,delete-orphan\"</literal> を指定し、 子供オブジェクト"
+"<literal>cascade=\"all,delete-orphan\"</literal> を指定し、子供オブジェクト"
 "を <emphasis>ライフサイクルオブジェクト</emphasis> にします。"
 
 #. Tag: para
-#: session_api.xml:988
 #, no-c-format
 msgid ""
 "Otherwise, you might not need cascade at all. But if you think that you will "
@@ -2015,13 +1434,12 @@
 "transaction, and you want to save yourself some typing, consider using "
 "<literal>cascade=\"persist,merge,save-update\"</literal>."
 msgstr ""
-". それ以外の場合は、カスケードはほとんど必要ないでしょう。 しかし、同じトラン"
-"ザクションのなかで親と子が一緒に動作することが多いと思い、 いくらかのコードを"
-"書く手間を省きたいのであれば、 <literal>cascade=\"persist,merge,save-update"
-"\"</literal> を使うことを考えましょう。"
+"それ以外の場合は、カスケードはほとんど必要ないでしょう。しかし、同じトランザ"
+"クションのなかで親と子が一緒に動作することが多いと思い、いくらかのコードを書"
+"く手間を省きたいのであれば、 <literal>cascade=\"persist,merge,save-update\"</"
+"literal> を使うことを考えましょう。"
 
 #. Tag: para
-#: session_api.xml:996
 #, no-c-format
 msgid ""
 "Mapping an association (either a single valued association, or a collection) "
@@ -2030,12 +1448,11 @@
 "delete of the parent results in save/update/delete of the child or children."
 msgstr ""
 "<literal>cascade=\"all\"</literal> でマッピングした関連(単値関連やコレクショ"
-"ン)は、 <emphasis>親子</emphasis> スタイルの関連とマークされます。 それは、"
-"親のセーブ/更新/削除が、子のセーブ/更新/削除を引き起こす関係のことです。"
+"ン)は、 <emphasis>親子</emphasis> スタイルの関連とマークされます。それは、親"
+"のセーブ/更新/削除が、子のセーブ/更新/削除を引き起こす関係のことです。"
 
 #. Tag: para
-#: session_api.xml:1002
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Furthermore, a mere reference to a child from a persistent parent will "
 "result in save/update of the child. This metaphor is incomplete, however. A "
@@ -2046,34 +1463,31 @@
 "relationship are as follows:"
 msgstr ""
 "さらに、永続化された親が子を単に参照しているだけで、子のセーブ/更新を引き起こ"
-"します。 しかし、このメタファーは不完全です。親から参照されなくなった子は、自"
-"動的に削除 <emphasis>されません</emphasis> 。 ただし、 <literal>cascade="
+"します。しかし、このメタファーは不完全です。親から参照されなくなった子は、自"
+"動的に削除 <emphasis>されません</emphasis> 。ただし、 <literal>cascade="
 "\"delete-orphan\"</literal> でマッピングされた <literal>&lt;one-to-many&gt;</"
-"literal> 関連を 除いてです。 親子関係のカスケード操作の正確な意味は以下のよう"
-"になります。"
+"literal> 関連を除いてです。親子関係のカスケード操作の正確な意味は以下のように"
+"なります:"
 
 #. Tag: para
-#: session_api.xml:1013
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>persist()</literal>, all children are "
 "passed to <literal>persist()</literal>"
 msgstr ""
-"親が <literal>persist()</literal> に渡されたならば、 すべての子は "
+"親が <literal>persist()</literal> に渡されたならば、すべての子は "
 "<literal>persist()</literal> に渡されます。"
 
 #. Tag: para
-#: session_api.xml:1019
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>merge()</literal>, all children are passed "
 "to <literal>merge()</literal>"
 msgstr ""
-"<literal>merge()</literal> に渡されたならば、 すべての子は <literal>merge()</"
+"<literal>merge()</literal> に渡されたならば、すべての子は <literal>merge()</"
 "literal> に渡されます。"
 
 #. Tag: para
-#: session_api.xml:1025
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>save()</literal>, <literal>update()</"
@@ -2085,17 +1499,15 @@
 "<literal>saveOrUpdate()</literal> に渡されます。"
 
 #. Tag: para
-#: session_api.xml:1031
 #, no-c-format
 msgid ""
 "If a transient or detached child becomes referenced by a persistent parent, "
 "it is passed to <literal>saveOrUpdate()</literal>"
 msgstr ""
-"一時的または分離状態の子が、永続化された親に参照されたならば、 "
+"transient または detached の子が、永続化された親に参照されたならば、 "
 "<literal>saveOrUpdate()</literal> に渡されます。"
 
 #. Tag: para
-#: session_api.xml:1037
 #, no-c-format
 msgid ""
 "If a parent is deleted, all children are passed to <literal>delete()</"
@@ -2105,7 +1517,6 @@
 "す。"
 
 #. Tag: para
-#: session_api.xml:1042
 #, no-c-format
 msgid ""
 "If a child is dereferenced by a persistent parent, <emphasis>nothing special "
@@ -2114,13 +1525,12 @@
 "case the \"orphaned\" child is deleted."
 msgstr ""
 "子が永続化された親から参照されなくなったときは、 <emphasis>特に何も起こりませ"
-"ん</emphasis> 。 よって、アプリケーションが必要であれば、明示的に削除する必要"
-"があります。 ただし、 <literal>cascade=\"delete-orphan\"</literal> の場合を除"
-"きます。 この場合、「親のない」子は削除されます。"
+"ん</emphasis> 。よって、アプリケーションが必要であれば、明示的に削除する必要"
+"があります。ただし、 <literal>cascade=\"delete-orphan\"</literal> の場合を除"
+"きます。この場合、「親のない」子は削除されます。"
 
 #. Tag: para
-#: session_api.xml:1051
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, note that cascading of operations can be applied to an object graph "
 "at <emphasis>call time</emphasis> or at <emphasis>flush time</emphasis>. All "
@@ -2131,21 +1541,19 @@
 msgstr ""
 "最後に、操作のカスケードがオブジェクトグラフに適用されるのは、 <emphasis>コー"
 "ルした時</emphasis> あるいは、 <emphasis>flushした時</emphasis> であることに"
-"注意してください。 すべての操作は、その操作が実行されたときに、到達可能な関連"
-"するエンティティに対して カスケードが可能ならカスケードします。 しかし、 "
+"注意してください。すべての操作は、その操作が実行されたときに、到達可能な関連"
+"するエンティティに対してカスケードが可能ならカスケードします。しかし、 "
 "<literal>save-upate</literal> と <literal>delete-orphan</literal> は、 "
-"<literal>Session</literal> がflushしている間に、 すべての到達可能な関連するエ"
-"ンティティに伝播します。"
+"<literal>Session</literal> が flush している間に、すべての到達可能な関連する"
+"エンティティに伝播します。"
 
 #. Tag: title
-#: session_api.xml:1063
 #, no-c-format
 msgid "Using metadata"
 msgstr "メタデータの使用"
 
 #. Tag: para
-#: session_api.xml:1065
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate requires a rich meta-level model of all entity and value types. "
 "This model can be useful to the application itself. For example, the "
@@ -2154,63 +1562,671 @@
 "value types) and which objects that should not (e.g. immutable value types "
 "and, possibly, associated entities)."
 msgstr ""
-"Hibernateは、すべてのエンティティと値型の非常にリッチなメタレベルのモデルを必"
-"要とします。 ときどき、このモデルはアプリケーションにとってとても役に立ちま"
-"す。 例えば、アプリケーションは、Hibernateのメタデータを使って、\"賢い\" "
-"ディープコピーアルゴリズムを 実装できるかもしません。そのアルゴリズムとは、ど"
-"のオブジェクトがコピーされるべきか(例:可変の値型)や どのオブジェクトはコ"
-"ピーされないべきか(例:不変な値型や可能なら関連するエンティティ)を 判断でき"
+"Hibernate は、すべてのエンティティと値型の非常にリッチなメタレベルのモデルを"
+"必要とします。ときどき、このモデルはアプリケーションにとってとても役に立ちま"
+"す。例えば、アプリケーションは、 Hibernate のメタデータを使って、「賢い」"
+"ディープコピーアルゴリズムを実装できるかもしません。そのアルゴリズムとは、ど"
+"のオブジェクトがコピーされるべきか(例:可変の値型)やどのオブジェクトはコ"
+"ピーされないべきか(例:不変な値型や可能なら関連するエンティティ)を判断でき"
 "るものです。"
 
 #. Tag: para
-#: session_api.xml:1072
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate exposes metadata via the <literal>ClassMetadata</literal> and "
 "<literal>CollectionMetadata</literal> interfaces and the <literal>Type</"
 "literal> hierarchy. Instances of the metadata interfaces can be obtained "
 "from the <literal>SessionFactory</literal>."
 msgstr ""
-"Hibernateは<literal>ClassMetadata</literal> と<literal>CollectionMetadata</"
-"literal> インタフェースと <literal>Type</literal> 階層を通してメタデータを公"
-"開します。 メタデータインターフェイスのインスタンスは、 "
-"<literal>SessionFactory</literal> から得られます。"
+"Hibernate は <literal>ClassMetadata</literal> と "
+"<literal>CollectionMetadata</literal> インタフェースと <literal>Type</"
+"literal> 階層を通してメタデータを公開します。メタデータインターフェースのイン"
+"スタンスは、 <literal>SessionFactory</literal> から得られます。"
 
-#. Tag: programlisting
-#: session_api.xml:1079
-#, no-c-format
-msgid ""
-"<![CDATA[Cat fritz = ......;\n"
-"ClassMetadata catMeta = sessionfactory.getClassMetadata(Cat.class);\n"
-"\n"
-"Object[] propertyValues = catMeta.getPropertyValues(fritz);\n"
-"String[] propertyNames = catMeta.getPropertyNames();\n"
-"Type[] propertyTypes = catMeta.getPropertyTypes();\n"
-"\n"
-"// get a Map of all properties which are not collections or associations\n"
-"Map namedValues = new HashMap();\n"
-"for ( int i=0; i<propertyNames.length; i++ ) {\n"
-"    if ( !propertyTypes[i].isEntityType() && !propertyTypes[i]."
-"isCollectionType() ) {\n"
-"        namedValues.put( propertyNames[i], propertyValues[i] );\n"
-"    }\n"
-"}]]>"
-msgstr ""
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[DomesticCat fritz = new DomesticCat();\n"
+#~ "fritz.setColor(Color.GINGER);\n"
+#~ "fritz.setSex('M');\n"
+#~ "fritz.setName(\"Fritz\");\n"
+#~ "Long generatedId = (Long) sess.save(fritz);]]>"
+#~ msgstr ""
+#~ "DomesticCat fritz = new DomesticCat();\n"
+#~ "fritz.setColor(Color.GINGER);\n"
+#~ "fritz.setSex('M');\n"
+#~ "fritz.setName(\"Fritz\");\n"
+#~ "Long generatedId = (Long) sess.save(fritz);"
 
-#~ msgid "UPDATE"
-#~ msgstr "UPDATE"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[DomesticCat pk = new DomesticCat();\n"
+#~ "pk.setColor(Color.TABBY);\n"
+#~ "pk.setSex('F');\n"
+#~ "pk.setName(\"PK\");\n"
+#~ "pk.setKittens( new HashSet() );\n"
+#~ "pk.addKitten(fritz);\n"
+#~ "sess.save( pk, new Long(1234) );]]>"
+#~ msgstr ""
+#~ "DomesticCat pk = new DomesticCat();\n"
+#~ "pk.setColor(Color.TABBY);\n"
+#~ "pk.setSex('F');\n"
+#~ "pk.setName(\"PK\");\n"
+#~ "pk.setKittens( new HashSet() );\n"
+#~ "pk.addKitten(fritz);\n"
+#~ "sess.save( pk, new Long(1234) );"
 
-#~ msgid "DELETE"
-#~ msgstr "DELETE"
+#, fuzzy
+#~ msgid "<![CDATA[Cat fritz = (Cat) sess.load(Cat.class, generatedId);]]>"
+#~ msgstr "Cat fritz = (Cat) sess.load(Cat.class, generatedId);"
 
-#~ msgid "state management"
-#~ msgstr "状態管理"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[// you need to wrap primitive identifiers\n"
+#~ "long id = 1234;\n"
+#~ "DomesticCat pk = (DomesticCat) sess.load( DomesticCat.class, new Long"
+#~ "(id) );]]>"
+#~ msgstr ""
+#~ "// you need to wrap primitive identifiers\n"
+#~ "long id = 1234;\n"
+#~ "DomesticCat pk = (DomesticCat) sess.load( DomesticCat.class, new Long"
+#~ "(id) );"
 
-#~ msgid "statements"
-#~ msgstr "æ–‡"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Cat cat = new DomesticCat();\n"
+#~ "// load pk's state into cat\n"
+#~ "sess.load( cat, new Long(pkId) );\n"
+#~ "Set kittens = cat.getKittens();]]>"
+#~ msgstr ""
+#~ "Cat cat = new DomesticCat();\n"
+#~ "// load pk's state into cat\n"
+#~ "sess.load( cat, new Long(pkId) );\n"
+#~ "Set kittens = cat.getKittens();"
 
-#~ msgid "Connection"
-#~ msgstr "session.connection()"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id);\n"
+#~ "if (cat==null) {\n"
+#~ "    cat = new Cat();\n"
+#~ "    sess.save(cat, id);\n"
+#~ "}\n"
+#~ "return cat;]]>"
+#~ msgstr ""
+#~ "Cat cat = (Cat) sess.get(Cat.class, id);\n"
+#~ "if (cat==null) {\n"
+#~ "    cat = new Cat();\n"
+#~ "    sess.save(cat, id);\n"
+#~ "}\n"
+#~ "return cat;"
 
-#~ msgid "session.connection()"
-#~ msgstr "Connection"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id, LockMode.UPGRADE);]]>"
+#~ msgstr "Cat cat = (Cat) sess.get(Cat.class, id, LockMode.UPGRADE);"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.save(cat);\n"
+#~ "sess.flush(); //force the SQL INSERT\n"
+#~ "sess.refresh(cat); //re-read the state (after the trigger executes)]]>"
+#~ msgstr ""
+#~ "sess.save(cat);\n"
+#~ "sess.flush(); //force the SQL INSERT\n"
+#~ "sess.refresh(cat); //re-read the state (after the trigger executes)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = session.createQuery(\n"
+#~ "    \"from Cat as cat where cat.birthdate < ?\")\n"
+#~ "    .setDate(0, date)\n"
+#~ "    .list();\n"
+#~ "\n"
+#~ "List mothers = session.createQuery(\n"
+#~ "    \"select mother from Cat as cat join cat.mother as mother where cat."
+#~ "name = ?\")\n"
+#~ "    .setString(0, name)\n"
+#~ "    .list();\n"
+#~ "\n"
+#~ "List kittens = session.createQuery(\n"
+#~ "    \"from Cat as cat where cat.mother = ?\")\n"
+#~ "    .setEntity(0, pk)\n"
+#~ "    .list();\n"
+#~ "\n"
+#~ "Cat mother = (Cat) session.createQuery(\n"
+#~ "    \"select cat.mother from Cat as cat where cat = ?\")\n"
+#~ "    .setEntity(0, izi)\n"
+#~ "    .uniqueResult();]]\n"
+#~ "\n"
+#~ "Query mothersWithKittens = (Cat) session.createQuery(\n"
+#~ "    \"select mother from Cat as mother left join fetch mother.kittens"
+#~ "\");\n"
+#~ "Set uniqueMothers = new HashSet(mothersWithKittens.list());]]>"
+#~ msgstr ""
+#~ "List cats = session.createQuery(\n"
+#~ "    \"from Cat as cat where cat.birthdate &lt; ?\")\n"
+#~ "    .setDate(0, date)\n"
+#~ "    .list();\n"
+#~ "\n"
+#~ "List mothers = session.createQuery(\n"
+#~ "    \"select mother from Cat as cat join cat.mother as mother where cat."
+#~ "name = ?\")\n"
+#~ "    .setString(0, name)\n"
+#~ "    .list();\n"
+#~ "\n"
+#~ "List kittens = session.createQuery(\n"
+#~ "    \"from Cat as cat where cat.mother = ?\")\n"
+#~ "    .setEntity(0, pk)\n"
+#~ "    .list();\n"
+#~ "\n"
+#~ "Cat mother = (Cat) session.createQuery(\n"
+#~ "    \"select cat.mother from Cat as cat where cat = ?\")\n"
+#~ "    .setEntity(0, izi)\n"
+#~ "    .uniqueResult();]]\n"
+#~ "\n"
+#~ "Query mothersWithKittens = (Cat) session.createQuery(\n"
+#~ "    \"select mother from Cat as mother left join fetch mother.kittens"
+#~ "\");\n"
+#~ "Set uniqueMothers = new HashSet(mothersWithKittens.list());"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[// fetch ids\n"
+#~ "Iterator iter = sess.createQuery(\"from eg.Qux q order by q.likeliness\")."
+#~ "iterate();\n"
+#~ "while ( iter.hasNext() ) {\n"
+#~ "    Qux qux = (Qux) iter.next();  // fetch the object\n"
+#~ "    // something we couldnt express in the query\n"
+#~ "    if ( qux.calculateComplicatedAlgorithm() ) {\n"
+#~ "        // delete the current instance\n"
+#~ "        iter.remove();\n"
+#~ "        // dont need to process the rest\n"
+#~ "        break;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "// fetch ids\n"
+#~ "Iterator iter = sess.createQuery(\"from eg.Qux q order by q.likeliness\")."
+#~ "iterate();\n"
+#~ "while ( iter.hasNext() ) {\n"
+#~ "    Qux qux = (Qux) iter.next();  // fetch the object\n"
+#~ "    // something we couldnt express in the query\n"
+#~ "    if ( qux.calculateComplicatedAlgorithm() ) {\n"
+#~ "        // delete the current instance\n"
+#~ "        iter.remove();\n"
+#~ "        // dont need to process the rest\n"
+#~ "        break;\n"
+#~ "    }\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Iterator kittensAndMothers = sess.createQuery(\n"
+#~ "            \"select kitten, mother from Cat kitten join kitten.mother "
+#~ "mother\")\n"
+#~ "            .list()\n"
+#~ "            .iterator();\n"
+#~ "\n"
+#~ "while ( kittensAndMothers.hasNext() ) {\n"
+#~ "    Object[] tuple = (Object[]) kittensAndMothers.next();\n"
+#~ "    Cat kitten = (Cat) tuple[0];\n"
+#~ "    Cat mother = (Cat) tuple[1];\n"
+#~ "    ....\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "Iterator kittensAndMothers = sess.createQuery(\n"
+#~ "            \"select kitten, mother from Cat kitten join kitten.mother "
+#~ "mother\")\n"
+#~ "            .list()\n"
+#~ "            .iterator();\n"
+#~ "\n"
+#~ "while ( kittensAndMothers.hasNext() ) {\n"
+#~ "    Object[] tuple = (Object[]) kittensAndMothers.next();\n"
+#~ "    Cat kitten  = tuple[0];\n"
+#~ "    Cat mother  = tuple[1];\n"
+#~ "    ....\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Iterator results = sess.createQuery(\n"
+#~ "        \"select cat.color, min(cat.birthdate), count(cat) from Cat cat "
+#~ "\" +\n"
+#~ "        \"group by cat.color\")\n"
+#~ "        .list()\n"
+#~ "        .iterator();\n"
+#~ "\n"
+#~ "while ( results.hasNext() ) {\n"
+#~ "    Object[] row = (Object[]) results.next();\n"
+#~ "    Color type = (Color) row[0];\n"
+#~ "    Date oldest = (Date) row[1];\n"
+#~ "    Integer count = (Integer) row[2];\n"
+#~ "    .....\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "Iterator results = sess.createQuery(\n"
+#~ "        \"select cat.color, min(cat.birthdate), count(cat) from Cat cat "
+#~ "\" +\n"
+#~ "        \"group by cat.color\")\n"
+#~ "        .list()\n"
+#~ "        .iterator();\n"
+#~ "\n"
+#~ "while ( results.hasNext() ) {\n"
+#~ "    Object[] row = (Object[]) results.next();\n"
+#~ "    Color type = (Color) row[0];\n"
+#~ "    Date oldest = (Date) row[1];\n"
+#~ "    Integer count = (Integer) row[2];\n"
+#~ "    .....\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[//named parameter (preferred)\n"
+#~ "Query q = sess.createQuery(\"from DomesticCat cat where cat.name = :name"
+#~ "\");\n"
+#~ "q.setString(\"name\", \"Fritz\");\n"
+#~ "Iterator cats = q.iterate();]]>"
+#~ msgstr ""
+#~ "//named parameter (preferred)\n"
+#~ "Query q = sess.createQuery(\"from DomesticCat cat where cat.name = :name"
+#~ "\");\n"
+#~ "q.setString(\"name\", \"Fritz\");\n"
+#~ "Iterator cats = q.iterate();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[//positional parameter\n"
+#~ "Query q = sess.createQuery(\"from DomesticCat cat where cat.name = ?\");\n"
+#~ "q.setString(0, \"Izi\");\n"
+#~ "Iterator cats = q.iterate();]]>"
+#~ msgstr ""
+#~ "//positional parameter\n"
+#~ "Query q = sess.createQuery(\"from DomesticCat cat where cat.name = ?\");\n"
+#~ "q.setString(0, \"Izi\");\n"
+#~ "Iterator cats = q.iterate();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[//named parameter list\n"
+#~ "List names = new ArrayList();\n"
+#~ "names.add(\"Izi\");\n"
+#~ "names.add(\"Fritz\");\n"
+#~ "Query q = sess.createQuery(\"from DomesticCat cat where cat.name in (:"
+#~ "namesList)\");\n"
+#~ "q.setParameterList(\"namesList\", names);\n"
+#~ "List cats = q.list();]]>"
+#~ msgstr ""
+#~ "//named parameter list\n"
+#~ "List names = new ArrayList();\n"
+#~ "names.add(\"Izi\");\n"
+#~ "names.add(\"Fritz\");\n"
+#~ "Query q = sess.createQuery(\"from DomesticCat cat where cat.name in (:"
+#~ "namesList)\");\n"
+#~ "q.setParameterList(\"namesList\", names);\n"
+#~ "List cats = q.list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Query q = sess.createQuery(\"from DomesticCat cat\");\n"
+#~ "q.setFirstResult(20);\n"
+#~ "q.setMaxResults(10);\n"
+#~ "List cats = q.list();]]>"
+#~ msgstr ""
+#~ "Query q = sess.createQuery(\"from DomesticCat cat\");\n"
+#~ "q.setFirstResult(20);\n"
+#~ "q.setMaxResults(10);\n"
+#~ "List cats = q.list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Query q = sess.createQuery(\"select cat.name, cat from "
+#~ "DomesticCat cat \" +\n"
+#~ "                            \"order by cat.name\");\n"
+#~ "ScrollableResults cats = q.scroll();\n"
+#~ "if ( cats.first() ) {\n"
+#~ "\n"
+#~ "    // find the first name on each page of an alphabetical list of cats "
+#~ "by name\n"
+#~ "    firstNamesOfPages = new ArrayList();\n"
+#~ "    do {\n"
+#~ "        String name = cats.getString(0);\n"
+#~ "        firstNamesOfPages.add(name);\n"
+#~ "    }\n"
+#~ "    while ( cats.scroll(PAGE_SIZE) );\n"
+#~ "\n"
+#~ "    // Now get the first page of cats\n"
+#~ "    pageOfCats = new ArrayList();\n"
+#~ "    cats.beforeFirst();\n"
+#~ "    int i=0;\n"
+#~ "    while( ( PAGE_SIZE > i++ ) && cats.next() ) pageOfCats.add( cats.get"
+#~ "(1) );\n"
+#~ "\n"
+#~ "}\n"
+#~ "cats.close()]]>"
+#~ msgstr ""
+#~ "Query q = sess.createQuery(\"select cat.name, cat from DomesticCat cat \" "
+#~ "+\n"
+#~ "                            \"order by cat.name\");\n"
+#~ "ScrollableResults cats = q.scroll();\n"
+#~ "if ( cats.first() ) {\n"
+#~ "\n"
+#~ "    // find the first name on each page of an alphabetical list of cats "
+#~ "by name\n"
+#~ "    firstNamesOfPages = new ArrayList();\n"
+#~ "    do {\n"
+#~ "        String name = cats.getString(0);\n"
+#~ "        firstNamesOfPages.add(name);\n"
+#~ "    }\n"
+#~ "    while ( cats.scroll(PAGE_SIZE) );\n"
+#~ "\n"
+#~ "    // Now get the first page of cats\n"
+#~ "    pageOfCats = new ArrayList();\n"
+#~ "    cats.beforeFirst();\n"
+#~ "    int i=0;\n"
+#~ "    while( ( PAGE_SIZE &gt; i++ ) &amp;&amp; cats.next() ) pageOfCats.add"
+#~ "( cats.get(1) );\n"
+#~ "\n"
+#~ "}\n"
+#~ "cats.close()"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<query name=\"ByNameAndMaximumWeight\"><![CDATA[\n"
+#~ "    from eg.DomesticCat as cat\n"
+#~ "        where cat.name = ?\n"
+#~ "        and cat.weight > ?\n"
+#~ "] ]></query>]]>"
+#~ msgstr ""
+#~ "&lt;query name=\"ByNameAndMaximumWeight\"&gt;&lt;![CDATA[\n"
+#~ "    from eg.DomesticCat as cat\n"
+#~ "        where cat.name = ?\n"
+#~ "        and cat.weight &gt; ?\n"
+#~ "] ]&gt;&lt;/query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Query q = sess.getNamedQuery(\"ByNameAndMaximumWeight\");\n"
+#~ "q.setString(0, name);\n"
+#~ "q.setInt(1, minWeight);\n"
+#~ "List cats = q.list();]]>"
+#~ msgstr ""
+#~ "Query q = sess.getNamedQuery(\"ByNameAndMaximumWeight\");\n"
+#~ "q.setString(0, name);\n"
+#~ "q.setInt(1, minWeight);\n"
+#~ "List cats = q.list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Collection blackKittens = session.createFilter(\n"
+#~ "    pk.getKittens(), \n"
+#~ "    \"where this.color = ?\")\n"
+#~ "    .setParameter( Color.BLACK, Hibernate.custom(ColorUserType.class) )\n"
+#~ "    .list()\n"
+#~ ");]]>"
+#~ msgstr ""
+#~ "Collection blackKittens = session.createFilter(\n"
+#~ "    pk.getKittens(), \n"
+#~ "    \"where this.color = ?\")\n"
+#~ "    .setParameter( Color.BLACK, Hibernate.custom(ColorUserType.class) )\n"
+#~ "    .list()\n"
+#~ ");"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Collection blackKittenMates = session.createFilter(\n"
+#~ "    pk.getKittens(), \n"
+#~ "    \"select this.mate where this.color = eg.Color.BLACK.intValue\")\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "Collection blackKittenMates = session.createFilter(\n"
+#~ "    pk.getKittens(), \n"
+#~ "    \"select this.mate where this.color = eg.Color.BLACK.intValue\")\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Collection tenKittens = session.createFilter(\n"
+#~ "    mother.getKittens(), \"\")\n"
+#~ "    .setFirstResult(0).setMaxResults(10)\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "Collection tenKittens = session.createFilter(\n"
+#~ "    mother.getKittens(), \"\")\n"
+#~ "    .setFirstResult(0).setMaxResults(10)\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Criteria crit = session.createCriteria(Cat.class);\n"
+#~ "crit.add( Restrictions.eq( \"color\", eg.Color.BLACK ) );\n"
+#~ "crit.setMaxResults(10);\n"
+#~ "List cats = crit.list();]]>"
+#~ msgstr ""
+#~ "Criteria crit = session.createCriteria(Cat.class);\n"
+#~ "crit.add( Expression.eq( \"color\", eg.Color.BLACK ) );\n"
+#~ "crit.setMaxResults(10);\n"
+#~ "List cats = crit.list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = session.createSQLQuery(\"SELECT {cat.*} FROM CAT "
+#~ "{cat} WHERE ROWNUM<10\")\n"
+#~ "    .addEntity(\"cat\", Cat.class)\n"
+#~ ".list();]]>"
+#~ msgstr ""
+#~ "List cats = session.createSQLQuery(\n"
+#~ "    \"SELECT {cat.*} FROM CAT {cat} WHERE ROWNUM&lt;10\",\n"
+#~ "    \"cat\",\n"
+#~ "    Cat.class\n"
+#~ ").list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = session.createSQLQuery(\n"
+#~ "    \"SELECT {cat}.ID AS {cat.id}, {cat}.SEX AS {cat.sex}, \" +\n"
+#~ "           \"{cat}.MATE AS {cat.mate}, {cat}.SUBCLASS AS {cat.class}, ... "
+#~ "\" +\n"
+#~ "    \"FROM CAT {cat} WHERE ROWNUM<10\")\n"
+#~ "    .addEntity(\"cat\", Cat.class)\n"
+#~ ".list()]]>"
+#~ msgstr ""
+#~ "List cats = session.createSQLQuery(\n"
+#~ "    \"SELECT {cat}.ID AS {cat.id}, {cat}.SEX AS {cat.sex}, \" +\n"
+#~ "           \"{cat}.MATE AS {cat.mate}, {cat}.SUBCLASS AS {cat.class}, ... "
+#~ "\" +\n"
+#~ "    \"FROM CAT {cat} WHERE ROWNUM&lt;10\",\n"
+#~ "    \"cat\",\n"
+#~ "    Cat.class\n"
+#~ ").list()"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[DomesticCat cat = (DomesticCat) sess.load( Cat.class, new Long"
+#~ "(69) );\n"
+#~ "cat.setName(\"PK\");\n"
+#~ "sess.flush();  // changes to cat are automatically detected and "
+#~ "persisted]]>"
+#~ msgstr ""
+#~ "DomesticCat cat = (DomesticCat) sess.load( Cat.class, new Long(69) );\n"
+#~ "cat.setName(\"PK\");\n"
+#~ "sess.flush();  // changes to cat are automatically detected and persisted"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[// in the first session\n"
+#~ "Cat cat = (Cat) firstSession.load(Cat.class, catId);\n"
+#~ "Cat potentialMate = new Cat();\n"
+#~ "firstSession.save(potentialMate);\n"
+#~ "\n"
+#~ "// in a higher layer of the application\n"
+#~ "cat.setMate(potentialMate);\n"
+#~ "\n"
+#~ "// later, in a new session\n"
+#~ "secondSession.update(cat);  // update cat\n"
+#~ "secondSession.update(mate); // update mate]]>"
+#~ msgstr ""
+#~ "// in the first session\n"
+#~ "Cat cat = (Cat) firstSession.load(Cat.class, catId);\n"
+#~ "Cat potentialMate = new Cat();\n"
+#~ "firstSession.save(potentialMate);\n"
+#~ "\n"
+#~ "// in a higher layer of the application\n"
+#~ "cat.setMate(potentialMate);\n"
+#~ "\n"
+#~ "// later, in a new session\n"
+#~ "secondSession.update(cat);  // update cat\n"
+#~ "secondSession.update(mate); // update mate"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[//just reassociate:\n"
+#~ "sess.lock(fritz, LockMode.NONE);\n"
+#~ "//do a version check, then reassociate:\n"
+#~ "sess.lock(izi, LockMode.READ);\n"
+#~ "//do a version check, using SELECT ... FOR UPDATE, then reassociate:\n"
+#~ "sess.lock(pk, LockMode.UPGRADE);]]>"
+#~ msgstr ""
+#~ "//just reassociate:\n"
+#~ "sess.lock(fritz, LockMode.NONE);\n"
+#~ "//do a version check, then reassociate:\n"
+#~ "sess.lock(izi, LockMode.READ);\n"
+#~ "//do a version check, using SELECT ... FOR UPDATE, then reassociate:\n"
+#~ "sess.lock(pk, LockMode.UPGRADE);"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[// in the first session\n"
+#~ "Cat cat = (Cat) firstSession.load(Cat.class, catID);\n"
+#~ "\n"
+#~ "// in a higher tier of the application\n"
+#~ "Cat mate = new Cat();\n"
+#~ "cat.setMate(mate);\n"
+#~ "\n"
+#~ "// later, in a new session\n"
+#~ "secondSession.saveOrUpdate(cat);   // update existing state (cat has a "
+#~ "non-null id)\n"
+#~ "secondSession.saveOrUpdate(mate);  // save the new instance (mate has a "
+#~ "null id)]]>"
+#~ msgstr ""
+#~ "// in the first session\n"
+#~ "Cat cat = (Cat) firstSession.load(Cat.class, catID);\n"
+#~ "\n"
+#~ "// in a higher tier of the application\n"
+#~ "Cat mate = new Cat();\n"
+#~ "cat.setMate(mate);\n"
+#~ "\n"
+#~ "// later, in a new session\n"
+#~ "secondSession.saveOrUpdate(cat);   // update existing state (cat has a "
+#~ "non-null id)\n"
+#~ "secondSession.saveOrUpdate(mate);  // save the new instance (mate has a "
+#~ "null id)"
+
+#, fuzzy
+#~ msgid "<![CDATA[sess.delete(cat);]]>"
+#~ msgstr "sess.delete(cat);"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[//retrieve a cat from one database\n"
+#~ "Session session1 = factory1.openSession();\n"
+#~ "Transaction tx1 = session1.beginTransaction();\n"
+#~ "Cat cat = session1.get(Cat.class, catId);\n"
+#~ "tx1.commit();\n"
+#~ "session1.close();\n"
+#~ "\n"
+#~ "//reconcile with a second database\n"
+#~ "Session session2 = factory2.openSession();\n"
+#~ "Transaction tx2 = session2.beginTransaction();\n"
+#~ "session2.replicate(cat, ReplicationMode.LATEST_VERSION);\n"
+#~ "tx2.commit();\n"
+#~ "session2.close();]]>"
+#~ msgstr ""
+#~ "//retrieve a cat from one database\n"
+#~ "Session session1 = factory1.openSession();\n"
+#~ "Transaction tx1 = session1.beginTransaction();\n"
+#~ "Cat cat = session1.get(Cat.class, catId);\n"
+#~ "tx1.commit();\n"
+#~ "session1.close();\n"
+#~ "\n"
+#~ "//reconcile with a second database\n"
+#~ "Session session2 = factory2.openSession();\n"
+#~ "Transaction tx2 = session2.beginTransaction();\n"
+#~ "session2.replicate(cat, ReplicationMode.LATEST_VERSION);\n"
+#~ "tx2.commit();\n"
+#~ "session2.close();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess = sf.openSession();\n"
+#~ "Transaction tx = sess.beginTransaction();\n"
+#~ "sess.setFlushMode(FlushMode.COMMIT); // allow queries to return stale "
+#~ "state\n"
+#~ "\n"
+#~ "Cat izi = (Cat) sess.load(Cat.class, id);\n"
+#~ "izi.setName(iznizi);\n"
+#~ "\n"
+#~ "// might return stale data\n"
+#~ "sess.find(\"from Cat as cat left outer join cat.kittens kitten\");\n"
+#~ "\n"
+#~ "// change to izi is not flushed!\n"
+#~ "...\n"
+#~ "tx.commit(); // flush occurs\n"
+#~ "sess.close();]]>"
+#~ msgstr ""
+#~ "sess = sf.openSession();\n"
+#~ "Transaction tx = sess.beginTransaction();\n"
+#~ "sess.setFlushMode(FlushMode.COMMIT); // allow queries to return stale "
+#~ "state\n"
+#~ "\n"
+#~ "Cat izi = (Cat) sess.load(Cat.class, id);\n"
+#~ "izi.setName(iznizi);\n"
+#~ "\n"
+#~ "// might return stale data\n"
+#~ "sess.find(\"from Cat as cat left outer join cat.kittens kitten\");\n"
+#~ "\n"
+#~ "// change to izi is not flushed!\n"
+#~ "...\n"
+#~ "tx.commit(); // flush occurs\n"
+#~ "sess.close();"
+
+#, fuzzy
+#~ msgid "<![CDATA[<one-to-one name=\"person\" cascade=\"persist\"/>]]>"
+#~ msgstr "&lt;one-to-one name=\"person\" cascade=\"persist\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<one-to-one name=\"person\" cascade=\"persist,delete,lock\"/>]]>"
+#~ msgstr "&lt;one-to-one name=\"person\" cascade=\"persist,delete,lock\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Cat fritz = ......;\n"
+#~ "ClassMetadata catMeta = sessionfactory.getClassMetadata(Cat.class);\n"
+#~ "\n"
+#~ "Object[] propertyValues = catMeta.getPropertyValues(fritz);\n"
+#~ "String[] propertyNames = catMeta.getPropertyNames();\n"
+#~ "Type[] propertyTypes = catMeta.getPropertyTypes();\n"
+#~ "\n"
+#~ "// get a Map of all properties which are not collections or associations\n"
+#~ "Map namedValues = new HashMap();\n"
+#~ "for ( int i=0; i<propertyNames.length; i++ ) {\n"
+#~ "    if ( !propertyTypes[i].isEntityType() && !propertyTypes[i]."
+#~ "isCollectionType() ) {\n"
+#~ "        namedValues.put( propertyNames[i], propertyValues[i] );\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "Cat fritz = ......;\n"
+#~ "ClassMetadata catMeta = sessionfactory.getClassMetadata(Cat.class);\n"
+#~ "\n"
+#~ "Object[] propertyValues = catMeta.getPropertyValues(fritz);\n"
+#~ "String[] propertyNames = catMeta.getPropertyNames();\n"
+#~ "Type[] propertyTypes = catMeta.getPropertyTypes();\n"
+#~ "\n"
+#~ "// get a Map of all properties which are not collections or associations\n"
+#~ "Map namedValues = new HashMap();\n"
+#~ "for ( int i=0; i&lt;propertyNames.length; i++ ) {\n"
+#~ "    if ( !propertyTypes[i].isEntityType() &amp;&amp; !propertyTypes[i]."
+#~ "isCollectionType() ) {\n"
+#~ "        namedValues.put( propertyNames[i], propertyValues[i] );\n"
+#~ "    }\n"
+#~ "}"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/toolset_guide.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/toolset_guide.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/toolset_guide.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,59 +1,57 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2009, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-01-20 15:00+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: toolset_guide.xml:29
 #, no-c-format
 msgid "Toolset Guide"
-msgstr "Toolset Guide ツールセットガイド"
+msgstr "ツールセットガイド"
 
 #. Tag: para
-#: toolset_guide.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Roundtrip engineering with Hibernate is possible using a set of Eclipse "
 "plugins, commandline tools, and Ant tasks."
 msgstr ""
-"Hibernateを使ったラウンドトリップエンジニアリングは、 Eclipseプラグインやコマ"
-"ンドラインツール、もちろんAntタスクを使うことで可能です。"
+"Hibernate を使ったラウンドトリップエンジニアリングは、 Eclipse プラグインやコ"
+"マンドラインツール、もちろん Ant タスクを使うことで可能です。"
 
 #. Tag: para
-#: toolset_guide.xml:36
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Hibernate Tools</emphasis> currently include plugins for the "
 "Eclipse IDE as well as Ant tasks for reverse engineering of existing "
 "databases:"
 msgstr ""
 "<emphasis>Hibernate Tools</emphasis> は現在、既存データベースのリバースエンジ"
-"ニアリングのAntタスクに加えて、EclipseIDEのプラグインを含みます。"
+"ニアリングの Ant タスクに加えて、 Eclipse IDE のプラグインを含みます:"
 
 #. Tag: para
-#: toolset_guide.xml:42
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Mapping Editor:</emphasis> an editor for Hibernate XML mapping "
 "files that supports auto-completion and syntax highlighting. It also "
 "supports semantic auto-completion for class names and property/field names, "
 "making it more versatile than a normal XML editor."
 msgstr ""
-"<emphasis>マッピングエディタ:</emphasis> HibernateのXMLマッピングファイル用の"
-"エディタで、 自動補完と構文強調表示をサポートしています。クラス名やプロパ"
-"ティ/フィールド名に対する自動補完もサポートし、 通常のXMLエディタよりも強力で"
-"す。"
+"<emphasis>マッピングエディタ:</emphasis> Hibernate の XML マッピングファイル"
+"用のエディタで、自動補完と構文強調表示をサポートしています。クラス名やプロパ"
+"ティ/フィールド名に対する自動補完もサポートし、通常の XML エディタよりも強力"
+"です。"
 
 #. Tag: para
-#: toolset_guide.xml:47
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Console:</emphasis> the console is a new view in Eclipse. In "
 "addition to a tree overview of your console configurations, you are also "
@@ -61,14 +59,13 @@
 "relationships. The console allows you to execute HQL queries against your "
 "database and browse the result directly in Eclipse."
 msgstr ""
-"<emphasis>Console:</emphasis> コンソールはエクリプスの新しいビューです。 コン"
+"<emphasis>Console:</emphasis> コンソールはエクリプスの新しいビューです。コン"
 "ソールコンフィギュレーションのツリーオーバービューに加えて、永続クラスとその"
-"関連の相互作用ビューも得られます。 データベースにHQLを実行し、結果を直接エク"
+"関連の相互作用ビューも得られます。データベースに HQL を実行し、結果を直接エク"
 "リプス上で見ることができます。"
 
 #. Tag: para
-#: toolset_guide.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Development Wizards:</emphasis> several wizards are provided with "
 "the Hibernate Eclipse tools. You can use a wizard to quickly generate "
@@ -76,16 +73,15 @@
 "database schema into POJO source files and Hibernate mapping files. The "
 "reverse engineering wizard supports customizable templates."
 msgstr ""
-"<emphasis>開発ウィザード</emphasis> HibernateのEclipseツールはいくつかのウィ"
-"ザードを提供します。 ウィザードを使ってHibernateの設定ファイル(cfg.xml)をすば"
-"やく生成したり、 既存のデータベーススキーマをPOJOのソースファイルとHibernate"
-"のマッピングファイルへと、 完全にリバースエンジニアリングすることができま"
-"す。 リバースエンジニアリングウィザードはカスタマイズ可能なテンプレートをサ"
-"ポートします。"
+"<emphasis>開発ウィザード</emphasis> Hibernate の Eclipse ツールはいくつかの"
+"ウィザードを提供します。ウィザードを使って Hibernate の設定ファイル (cfg."
+"xml) をすばやく生成したり、既存のデータベーススキーマを POJO のソースファイル"
+"と Hibernate のマッピングファイルへと、完全にリバースエンジニアリングすること"
+"ができます。リバースエンジニアリングウィザードはカスタマイズ可能なテンプレー"
+"トをサポートします。"
 
 #. Tag: para
-#: toolset_guide.xml:67
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please refer to the <emphasis>Hibernate Tools</emphasis> package "
 "documentation for more information."
@@ -94,52 +90,47 @@
 "メントを参照してください。"
 
 #. Tag: para
-#: toolset_guide.xml:72
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, the Hibernate main package comes bundled with an integrated tool : "
 "<emphasis>SchemaExport</emphasis> aka <literal>hbm2ddl</literal>.It can even "
 "be used from \"inside\" Hibernate."
 msgstr ""
-"しかし、Hibernateのメインパッケージは <emphasis>SchemaExport</emphasis> 、 別"
-"名 <literal>hbm2ddl</literal> も含みます(Hibernate内でオンザフライで使用でき"
-"ます)。"
+"しかし、 Hibernate のメインパッケージは <emphasis>SchemaExport</emphasis> 、"
+"別名 <literal>hbm2ddl</literal> も含みます(Hibernate 「内」でオンザフライで使"
+"用できます)。"
 
 #. Tag: title
-#: toolset_guide.xml:79
 #, no-c-format
 msgid "Automatic schema generation"
 msgstr "スキーマの自動生成"
 
 #. Tag: para
-#: toolset_guide.xml:81
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "DDL can be generated from your mapping files by a Hibernate utility. The "
 "generated schema includes referential integrity constraints, primary and "
 "foreign keys, for entity and collection tables. Tables and sequences are "
 "also created for mapped identifier generators."
 msgstr ""
-"DDLはHibernateユーティリティによりマッピングファイルから生成することができま"
-"す。 生成されたスキーマはエンティティやコレクションのテーブルに対する参照整合"
-"性制約(主キーと外部キー)を含みます。 テーブルとシーケンスはマッピングする識別"
-"子ジェネレータに対して生成されます。"
+"DDL は Hibernate ユーティリティによりマッピングファイルから生成することができ"
+"ます。生成されたスキーマはエンティティやコレクションのテーブルに対する参照整"
+"合性制約 (主キーと外部キー) を含みます。テーブルとシーケンスはマッピングする"
+"識別子ジェネレータに対して生成されます。"
 
 #. Tag: para
-#: toolset_guide.xml:88
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You <emphasis>must</emphasis> specify a SQL <literal>Dialect</literal> via "
 "the <literal>hibernate.dialect</literal> property when using this tool, as "
 "DDL is highly vendor-specific."
 msgstr ""
-"DDLはベンダー依存なので、このツールを使うときは、<literal>hibernate.dialect</"
-"literal> プロパティでSQLの <literal>方言</literal> を指定 <emphasis>しなけれ"
-"ばなりません</emphasis> 。"
+"DDL はベンダー依存なので、このツールを使うときは、 <literal>hibernate."
+"dialect</literal> プロパティで SQL の <literal>方言</literal> を指定 "
+"<emphasis>しなければなりません</emphasis> 。"
 
 #. Tag: para
-#: toolset_guide.xml:94
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, you must customize your mapping files to improve the generated "
 "schema. The next section covers schema customization."
@@ -148,39 +139,25 @@
 "てください。"
 
 #. Tag: title
-#: toolset_guide.xml:99
 #, no-c-format
 msgid "Customizing the schema"
 msgstr "スキーマのカスタマイズ"
 
 #. Tag: para
-#: toolset_guide.xml:101
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Many Hibernate mapping elements define optional attributes named "
 "<literal>length</literal>, <literal>precision</literal> and <literal>scale</"
 "literal>. You can set the length, precision and scale of a column with this "
 "attribute."
 msgstr ""
-"多くのHibernateのマッピング要素では、オプションの <literal>length</literal> "
-"という名の属性を定義しています。 この属性でカラム長を設定することができます"
-"(またはNUMERIC/DECIMAL型のデータの精度を設定できます)。"
+"多くの Hibernate のマッピング要素では、オプションの <literal>length</"
+"literal>、 <literal>precision</literal>、 <literal>scale</literal> という名の"
+"属性を定義しています。この属性でカラムの長さ、精度、スケールを設定することが"
+"できます。"
 
-#. Tag: programlisting
-#: toolset_guide.xml:108
-#, no-c-format
-msgid "<![CDATA[<property name=\"zip\" length=\"5\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:109
-#, no-c-format
-msgid "<![CDATA[<property name=\"balance\" precision=\"12\" scale=\"2\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Some tags also accept a <literal>not-null</literal> attribute for generating "
 "a <literal>NOT NULL</literal> constraint on table columns, and a "
@@ -191,25 +168,9 @@
 "literal> 制約を生成する)と <literal>unique</literal> 属性(テーブルのカラム"
 "へ <literal>UNIQUE</literal> 制約を生成する)が設定できるタグもあります。"
 
-#. Tag: programlisting
-#: toolset_guide.xml:117
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"bar\" column=\"barId\" not-null=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:119
-#, no-c-format
-msgid ""
-"<![CDATA[<element column=\"serialNumber\" type=\"long\" not-null=\"true\" "
-"unique=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:121
-#, fuzzy, no-c-format
-msgid ""
 "A <literal>unique-key</literal> attribute can be used to group columns in a "
 "single, unique key constraint. Currently, the specified value of the "
 "<literal>unique-key</literal> attribute is <emphasis>not</emphasis> used to "
@@ -217,309 +178,193 @@
 "columns in the mapping file."
 msgstr ""
 "<literal>unique-key</literal> 属性はカラムをグループ化して一つのキー制約にす"
-"るために使われます。 現在、<literal>unique-key</literal> 属性で指定された値は"
-"制約の指定には <emphasis>使われず</emphasis> 、 マッピングファイルでカラムを"
-"グループ化することにのみ使われます。"
+"るために使われます。現在、 <literal>unique-key</literal> 属性で指定された値は"
+"制約の指定には <emphasis>使われず</emphasis> 、マッピングファイルでカラムをグ"
+"ループ化することにのみ使われます。"
 
-#. Tag: programlisting
-#: toolset_guide.xml:129
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"org\" column=\"orgId\" unique-key="
-"\"OrgEmployeeId\"/>\n"
-"<property name=\"employeeId\" unique-key=\"OrgEmployee\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:131
-#, fuzzy, no-c-format
-msgid ""
 "An <literal>index</literal> attribute specifies the name of an index that "
 "will be created using the mapped column or columns. Multiple columns can be "
 "grouped into the same index by simply specifying the same index name."
 msgstr ""
 "<literal>index</literal> 属性はマッピングするカラムを使って生成したインデック"
-"スの名前を指定します。 複数カラムを1つのインデックスにグループ化できます。単"
+"スの名前を指定します。複数カラムを1つのインデックスにグループ化できます。単"
 "に、同じインデックス名を指定するだけです。"
 
-#. Tag: programlisting
-#: toolset_guide.xml:137
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<property name=\"lastName\" index=\"CustName\"/>\n"
-"<property name=\"firstName\" index=\"CustName\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:139
-#, fuzzy, no-c-format
-msgid ""
 "A <literal>foreign-key</literal> attribute can be used to override the name "
 "of any generated foreign key constraint."
 msgstr ""
 "<literal>foreign-key</literal> 属性は、生成された外部キー制約の名前をオーバー"
 "ライドするために使用できます。"
 
-#. Tag: programlisting
-#: toolset_guide.xml:144
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"bar\" column=\"barId\" foreign-key=\"FKFooBar\"/"
-">]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:146
 #, no-c-format
 msgid ""
 "Many mapping elements also accept a child <literal>&lt;column&gt;</literal> "
 "element. This is particularly useful for mapping multi-column types:"
 msgstr ""
 "多くのマッピング要素は、子 <literal>&lt;column&gt;</literal> 要素を記述できま"
-"す。これは複数カラム型のマッピングには特に有用です。"
+"す。これは複数カラム型のマッピングには特に有用です:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:151
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<property name=\"name\" type=\"my.customtypes.Name\"/>\n"
-"    <column name=\"last\" not-null=\"true\" index=\"bar_idx\" length=\"30\"/"
-">\n"
-"    <column name=\"first\" not-null=\"true\" index=\"bar_idx\" length=\"20\"/"
-">\n"
-"    <column name=\"initial\"/>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:153
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>default</literal> attribute allows you to specify a default "
 "value for a column.You should assign the same value to the mapped property "
 "before saving a new instance of the mapped class."
 msgstr ""
 "<literal>default</literal> 属性はカラムのデフォルト値を指定します (マッピング"
-"したクラスの新しいインスタンスを保存する前に、 マッピングしたプロパティへ同じ"
+"したクラスの新しいインスタンスを保存する前に、マッピングしたプロパティへ同じ"
 "値を代入すべきです)。"
 
-#. Tag: programlisting
-#: toolset_guide.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"credits\" type=\"integer\" insert=\"false\">\n"
-"    <column name=\"credits\" default=\"10\"/>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:161
-#, no-c-format
-msgid ""
-"<![CDATA[<version name=\"version\" type=\"integer\" insert=\"false\">\n"
-"    <column name=\"version\" default=\"0\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:163
 #, no-c-format
 msgid ""
 "The <literal>sql-type</literal> attribute allows the user to override the "
 "default mapping of a Hibernate type to SQL datatype."
 msgstr ""
-"<literal>sql-type</literal> 属性で、デフォルトのHibernate型からSQLのデータ型"
-"へのマッピングをオーバーライドできます。"
+"<literal>sql-type</literal> 属性で、デフォルトの Hibernate 型から SQL のデー"
+"タ型へのマッピングをオーバーライドできます。"
 
-#. Tag: programlisting
-#: toolset_guide.xml:168
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"balance\" type=\"float\">\n"
-"    <column name=\"balance\" sql-type=\"decimal(13,3)\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:170
 #, no-c-format
 msgid ""
 "The <literal>check</literal> attribute allows you to specify a check "
 "constraint."
 msgstr "<literal>check</literal> 属性でチェック制約を指定することができます。"
 
-#. Tag: programlisting
-#: toolset_guide.xml:174
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"foo\" type=\"integer\">\n"
-"    <column name=\"foo\" check=\"foo > 10\"/>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:176
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Foo\" table=\"foos\" check=\"bar < 100.0\">\n"
-"    ...\n"
-"    <property name=\"bar\" type=\"float\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:179
 #, no-c-format
 msgid "The following table summarizes these optional attributes."
 msgstr ""
 
 #. Tag: title
-#: toolset_guide.xml:182
 #, no-c-format
 msgid "Summary"
-msgstr "まとめ"
+msgstr "要約"
 
 #. Tag: entry
-#: toolset_guide.xml:189
 #, no-c-format
 msgid "Attribute"
 msgstr "属性"
 
 #. Tag: entry
-#: toolset_guide.xml:190
 #, no-c-format
 msgid "Values"
 msgstr "値"
 
 #. Tag: entry
-#: toolset_guide.xml:191
 #, no-c-format
 msgid "Interpretation"
 msgstr "説明"
 
-#. Tag: literal
-#: toolset_guide.xml:196
+#. Tag: entry
 #, no-c-format
-msgid "length"
-msgstr "length"
+msgid "<literal>length</literal>"
+msgstr "<literal>length</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:197 toolset_guide.xml:202 toolset_guide.xml:207
 #, no-c-format
 msgid "number"
 msgstr "数値"
 
 #. Tag: entry
-#: toolset_guide.xml:198
 #, no-c-format
 msgid "column length"
 msgstr "カラムの長さ"
 
-#. Tag: literal
-#: toolset_guide.xml:201
+#. Tag: entry
 #, no-c-format
-msgid "precision"
-msgstr "precision"
+msgid "<literal>precision</literal>"
+msgstr "<literal>precision</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:203
 #, no-c-format
 msgid "column decimal precision"
-msgstr "カラムのDECIMAL型の精度(precision)"
+msgstr "カラムの DECIMAL 型の精度(precision)"
 
-#. Tag: literal
-#: toolset_guide.xml:206
+#. Tag: entry
 #, no-c-format
-msgid "scale"
-msgstr "scale"
+msgid "<literal>scale</literal>"
+msgstr "<literal>scale</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:208
 #, no-c-format
 msgid "column decimal scale"
-msgstr "カラムのDECIMAL型のスケール(scale)"
+msgstr "カラムの DECIMAL 型のスケール(scale)"
 
-#. Tag: literal
-#: toolset_guide.xml:211
+#. Tag: entry
 #, no-c-format
-msgid "not-null"
-msgstr "not-null"
+msgid "<literal>not-null</literal>"
+msgstr "<literal>not-null</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:212 toolset_guide.xml:217
+#. Tag: entry
 #, no-c-format
-msgid "true|false"
-msgstr "true|false"
+msgid "<literal>true|false</literal>"
+msgstr "<literal>true|false</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:213
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "specifies that the column should be non-nullable"
-msgstr "カラムがnull値を取らないことを指定します"
+msgstr "カラムが null 値を取らないことを指定します"
 
-#. Tag: literal
-#: toolset_guide.xml:216
+#. Tag: entry
 #, no-c-format
-msgid "unique"
-msgstr "unique"
+msgid "<literal>unique</literal>"
+msgstr "<literal>unique</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:218
 #, no-c-format
 msgid "specifies that the column should have a unique constraint"
 msgstr "カラムがユニーク制約を持つことを指定します"
 
-#. Tag: literal
-#: toolset_guide.xml:221
+#. Tag: entry
 #, no-c-format
-msgid "index"
-msgstr "index"
+msgid "<literal>index</literal>"
+msgstr "<literal>index</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:222
+#. Tag: entry
 #, no-c-format
-msgid "index_name"
+msgid "<literal>index_name</literal>"
 msgstr "インデックス名"
 
 #. Tag: entry
-#: toolset_guide.xml:223
 #, no-c-format
 msgid "specifies the name of a (multi-column) index"
 msgstr "(複数カラムの)インデックスの名前を指定します"
 
-#. Tag: literal
-#: toolset_guide.xml:226
+#. Tag: entry
 #, no-c-format
-msgid "unique-key"
-msgstr "unique-key"
+msgid "<literal>unique-key</literal>"
+msgstr "<literal>unique-key</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:227
+#. Tag: entry
 #, no-c-format
-msgid "unique_key_name"
+msgid "<literal>unique_key_name</literal>"
 msgstr "ユニークキー名"
 
 #. Tag: entry
-#: toolset_guide.xml:228
 #, no-c-format
 msgid "specifies the name of a multi-column unique constraint"
 msgstr "複数カラムのユニーク制約の名前を指定します"
 
-#. Tag: literal
-#: toolset_guide.xml:231
+#. Tag: entry
 #, no-c-format
-msgid "foreign-key"
-msgstr "foreign-key"
+msgid "<literal>foreign-key</literal>"
+msgstr "<literal>foreign-key</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:232
-#, no-c-format
-msgid "foreign_key_name"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>foreign_key_name</literal>"
 msgstr "外部キー名"
 
 #. Tag: entry
-#: toolset_guide.xml:233
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "specifies the name of the foreign key constraint generated for an "
 "association, for a <literal>&lt;one-to-one&gt;</literal>, <literal>&lt;many-"
@@ -527,64 +372,57 @@
 "to-many&gt;</literal> mapping element. Note that <literal>inverse=\"true\"</"
 "literal> sides will not be considered by <literal>SchemaExport</literal>."
 msgstr ""
-"specifies the name of the foreign key constraint generated for an "
-"association, for a <placeholder-1/>, <placeholder-2/>, <placeholder-3/>, or "
-"<placeholder-4/> mapping element. Note that <placeholder-5/> sides will not "
-"be considered by <placeholder-6/>."
+"<literal>&lt;one-to-one&gt;</literal>、 <literal>&lt;many-to-one&gt;</"
+"literal>、 <literal>&lt;key&gt;</literal>、 または <literal>&lt;many-to-"
+"many&gt;</literal> マッピングエレメントのために、関連に対して生成された外部"
+"キー制約の名前を指定します。 <literal>inverse=\"true\"</literal> 側は "
+"<literal>SchemaExport</literal> によって考慮されないことに注意してください。"
 
-#. Tag: literal
-#: toolset_guide.xml:243
+#. Tag: entry
 #, no-c-format
-msgid "sql-type"
-msgstr "sql-type"
+msgid "<literal>sql-type</literal>"
+msgstr "<literal>sql-type</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:244
-#, no-c-format
-msgid "SQL column type"
-msgstr "SQLのカラム型"
-
 #. Tag: entry
-#: toolset_guide.xml:245
 #, fuzzy, no-c-format
+msgid "<literal>SQL column type</literal>"
+msgstr "<literal>sql-type</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "overrides the default column type (attribute of <literal>&lt;column&gt;</"
 "literal> element only)"
 msgstr ""
-"デフォルトのカラム型をオーバーライドします( <placeholder-1/> 要素の属性のみ)"
+"デフォルトのカラム型をオーバーライドします ( <literal>&lt;column&gt;</"
+"literal> 要素の属性に限る)"
 
-#. Tag: literal
-#: toolset_guide.xml:251
+#. Tag: entry
 #, no-c-format
-msgid "default"
-msgstr "default"
+msgid "<literal>default</literal>"
+msgstr "<literal>default</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:252 toolset_guide.xml:259
 #, no-c-format
 msgid "SQL expression"
-msgstr "SQL式"
+msgstr "SQL 式"
 
 #. Tag: entry
-#: toolset_guide.xml:253
 #, no-c-format
 msgid "specify a default value for the column"
 msgstr "カラムのデフォルト値を指定します"
 
-#. Tag: literal
-#: toolset_guide.xml:258
+#. Tag: entry
 #, no-c-format
-msgid "check"
-msgstr "check"
+msgid "<literal>check</literal>"
+msgstr "<literal>check</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:260
 #, no-c-format
 msgid "create an SQL check constraint on either column or table"
-msgstr "カラムかテーブルにSQLのチェック制約を作成します"
+msgstr "カラムかテーブルに SQL のチェック制約を作成します"
 
 #. Tag: para
-#: toolset_guide.xml:268
 #, no-c-format
 msgid ""
 "The <literal>&lt;comment&gt;</literal> element allows you to specify "
@@ -593,252 +431,179 @@
 "<literal>&lt;comment&gt;</literal> 要素で生成するスキーマにコメントを指定する"
 "ことができます。"
 
-#. Tag: programlisting
-#: toolset_guide.xml:273
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Customer\" table=\"CurCust\">\n"
-"    <comment>Current customers only</comment>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:275
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"balance\">\n"
-"    <column name=\"bal\">\n"
-"        <comment>Balance in USD</comment>\n"
-"    </column>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:277
-#, fuzzy, no-c-format
-msgid ""
 "This results in a <literal>comment on table</literal> or <literal>comment on "
 "column</literal> statement in the generated DDL where supported."
 msgstr ""
-"これにより、生成したDDLに <literal>comment on table</literal> や "
+"これにより、生成した DDL に <literal>comment on table</literal> や "
 "<literal>comment on column</literal> 文が書かれます。"
 
 #. Tag: title
-#: toolset_guide.xml:286
 #, no-c-format
 msgid "Running the tool"
 msgstr "ツールの実行"
 
 #. Tag: para
-#: toolset_guide.xml:288
 #, no-c-format
 msgid ""
 "The <literal>SchemaExport</literal> tool writes a DDL script to standard out "
 "and/or executes the DDL statements."
 msgstr ""
-"<literal>SchemaExport</literal> は標準出力に対してDDLスクリプトを書き出し、"
-"DDL文を実行したりもします。"
+"<literal>SchemaExport</literal> は標準出力に対して DDL スクリプトを書き出"
+"し、 DDL 文を実行したりもします。"
 
 #. Tag: para
-#: toolset_guide.xml:293
 #, fuzzy, no-c-format
 msgid ""
 "The following table displays the <literal>SchemaExport</literal> command "
 "line options"
-msgstr ""
-"<literal>SchemaExport</literal> Command Line Options <literal>SchemaExport</"
-"literal> のコマンドラインオプション"
+msgstr "<literal>SchemaExport</literal> のコマンドラインオプション"
 
 #. Tag: para
-#: toolset_guide.xml:295
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
 "<literal>org.hibernate.tool.hbm2ddl.SchemaExport</literal> <emphasis>options "
 "mapping_files</emphasis>"
 msgstr ""
+"<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
+"<literal>org.hibernate.tool.hbm2ddl.SchemaExport</literal> <emphasis>options "
+"mapping_files</emphasis>"
 
 #. Tag: title
-#: toolset_guide.xml:301
 #, no-c-format
 msgid "<literal>SchemaExport</literal> Command Line Options"
-msgstr ""
-"<literal>SchemaExport</literal> Command Line Options <literal>SchemaExport</"
-"literal> のコマンドラインオプション"
+msgstr "<literal>SchemaExport</literal> のコマンドラインオプション"
 
 #. Tag: entry
-#: toolset_guide.xml:307 toolset_guide.xml:457 toolset_guide.xml:527
 #, no-c-format
 msgid "Option"
 msgstr "オプション"
 
 #. Tag: entry
-#: toolset_guide.xml:308 toolset_guide.xml:395 toolset_guide.xml:458
-#: toolset_guide.xml:528
 #, no-c-format
 msgid "Description"
 msgstr "説明"
 
-#. Tag: literal
-#: toolset_guide.xml:313 toolset_guide.xml:463
+#. Tag: entry
 #, no-c-format
-msgid "--quiet"
-msgstr "--quiet"
+msgid "<literal>--quiet</literal>"
+msgstr "<literal>--quiet</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:314 toolset_guide.xml:464
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "do not output the script to stdout"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"スクリプトを標準出力に出力しません\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"標準出力にスクリプトを出力しません"
+msgstr "標準出力にスクリプトを出力しません"
 
-#. Tag: literal
-#: toolset_guide.xml:317
+#. Tag: entry
 #, no-c-format
-msgid "--drop"
-msgstr "--drop"
+msgid "<literal>--drop</literal>"
+msgstr "<literal>--drop</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:318
 #, no-c-format
 msgid "only drop the tables"
 msgstr "テーブルの削除だけを行います"
 
-#. Tag: literal
-#: toolset_guide.xml:321
+#. Tag: entry
 #, no-c-format
-msgid "--create"
-msgstr "--create"
+msgid "<literal>--create</literal>"
+msgstr "<literal>--create</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:322
 #, no-c-format
 msgid "only create the tables"
-msgstr "テーブルの生成のみを行います。"
+msgstr "テーブルの生成のみを行います"
 
-#. Tag: literal
-#: toolset_guide.xml:325 toolset_guide.xml:467
+#. Tag: entry
 #, no-c-format
-msgid "--text"
-msgstr "--text"
+msgid "<literal>--text</literal>"
+msgstr "<literal>--text</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:326
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "do not export to the database"
 msgstr "データベースにエクスポートしません"
 
-#. Tag: literal
-#: toolset_guide.xml:329
-#, no-c-format
-msgid "--output=my_schema.ddl"
-msgstr "--output=my_schema.ddl"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--output=my_schema.ddl</literal>"
+msgstr "<literal>scale</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:330
 #, no-c-format
 msgid "output the ddl script to a file"
-msgstr "DDLスクリプトをファイルに出力します"
+msgstr "DDL スクリプトをファイルに出力します"
 
-#. Tag: literal
-#: toolset_guide.xml:333 toolset_guide.xml:471 toolset_guide.xml:533
-#, no-c-format
-msgid "--naming=eg.MyNamingStrategy"
-msgstr "--naming=eg.MyNamingStrategy"
-
 #. Tag: entry
-#: toolset_guide.xml:334 toolset_guide.xml:472 toolset_guide.xml:534
 #, fuzzy, no-c-format
-msgid "select a <literal>NamingStrategy</literal>"
-msgstr "<literal>hibernate.properties</literal> ファイル内で"
+msgid "<literal>--naming=eg.MyNamingStrategy</literal>"
+msgstr "<literal>--naming=eg.MyNamingStrategy</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:337 toolset_guide.xml:479 toolset_guide.xml:541
+#. Tag: entry
 #, no-c-format
-msgid "--config=hibernate.cfg.xml"
-msgstr "--config=hibernate.cfg.xml"
+msgid "select a <literal>NamingStrategy</literal>"
+msgstr "<literal>NamingStrategy</literal> を選択"
 
 #. Tag: entry
-#: toolset_guide.xml:338
+#, fuzzy, no-c-format
+msgid "<literal>--config=hibernate.cfg.xml</literal>"
+msgstr "<literal>hibernate.dialect</literal>"
+
+#. Tag: entry
 #, no-c-format
 msgid "read Hibernate configuration from an XML file"
-msgstr "XMLファイルからHibernateの定義情報を読み込みます"
+msgstr "XML ファイルから Hibernate の定義情報を読み込みます"
 
-#. Tag: literal
-#: toolset_guide.xml:341 toolset_guide.xml:475 toolset_guide.xml:537
+#. Tag: entry
 #, no-c-format
-msgid "--properties=hibernate.properties"
-msgstr "--properties=hibernate.properties"
+msgid "<literal>--properties=hibernate.properties</literal>"
+msgstr "<literal>--properties=hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:342 toolset_guide.xml:476 toolset_guide.xml:538
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "read database properties from a file"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"ファイルからデータベースプロパティを読み込みます\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"ファイルからデータベースプロパティを読み込みます\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"ファイルからデータベースのプロパティを読み込みます"
+msgstr "ファイルからデータベースのプロパティを読み込みます"
 
-#. Tag: literal
-#: toolset_guide.xml:345
+#. Tag: entry
 #, no-c-format
-msgid "--format"
-msgstr "--format"
+msgid "<literal>--format</literal>"
+msgstr "<literal>--format</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:346
 #, no-c-format
 msgid "format the generated SQL nicely in the script"
-msgstr "スクリプト内に生成するSQLを読みやすいようにフォーマットします"
+msgstr "スクリプト内に生成する SQL を読みやすいようにフォーマットします"
 
-#. Tag: literal
-#: toolset_guide.xml:349
+#. Tag: entry
 #, no-c-format
-msgid "--delimiter=;"
-msgstr "--delimiter=x"
+msgid "<literal>--delimiter=;</literal>"
+msgstr "<literal>--delimiter=;</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:350
 #, no-c-format
 msgid "set an end of line delimiter for the script"
 msgstr "スクリプトの行区切り文字を設定します"
 
 #. Tag: para
-#: toolset_guide.xml:356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can even embed <literal>SchemaExport</literal> in your application:"
 msgstr ""
 "アプリケーションに <literal>SchemaExport</literal> を組み込むこともできます:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:360
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaExport(cfg).create(false, true);]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:365
 #, no-c-format
 msgid "Properties"
 msgstr "プロパティ"
 
 #. Tag: para
-#: toolset_guide.xml:367
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Database properties can be specified:"
 msgstr "次のように、データベースのプロパティを指定することができます。"
 
 #. Tag: para
-#: toolset_guide.xml:373
 #, no-c-format
 msgid ""
 "as system properties with <literal>-D</literal><emphasis>&lt;property&gt;</"
@@ -848,236 +613,160 @@
 "プロパティとして"
 
 #. Tag: para
-#: toolset_guide.xml:376
 #, no-c-format
 msgid "in <literal>hibernate.properties</literal>"
 msgstr "<literal>hibernate.properties</literal> ファイル内で"
 
 #. Tag: para
-#: toolset_guide.xml:379
 #, no-c-format
 msgid "in a named properties file with <literal>--properties</literal>"
 msgstr "<literal>--properties</literal> を使って指定したプロパティファイル内で"
 
 #. Tag: para
-#: toolset_guide.xml:383
 #, no-c-format
 msgid "The needed properties are:"
 msgstr "必要なプロパティは以下のものです:"
 
 #. Tag: title
-#: toolset_guide.xml:388
 #, no-c-format
 msgid "SchemaExport Connection Properties"
-msgstr "SchemaExportコネクションプロパティ"
+msgstr "SchemaExport コネクションプロパティ"
 
 #. Tag: entry
-#: toolset_guide.xml:394
 #, no-c-format
 msgid "Property Name"
 msgstr "プロパティ名"
 
-#. Tag: literal
-#: toolset_guide.xml:400
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.driver_class"
-msgstr "hibernate.connection.driver_class"
+msgid "<literal>hibernate.connection.driver_class</literal>"
+msgstr "<literal>hibernate.connection.driver_class</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:401
 #, no-c-format
 msgid "jdbc driver class"
-msgstr "jdbcのドライバークラス"
+msgstr "jdbc のドライバークラス"
 
-#. Tag: literal
-#: toolset_guide.xml:404
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.url"
-msgstr "hibernate.connection.url"
+msgid "<literal>hibernate.connection.url</literal>"
+msgstr "<literal>hibernate.connection.url</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:405
 #, no-c-format
 msgid "jdbc url"
-msgstr "jdbcのurl"
+msgstr "jdbc の url"
 
-#. Tag: literal
-#: toolset_guide.xml:408
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.username"
-msgstr "hibernate.connection.username"
+msgid "<literal>hibernate.connection.username</literal>"
+msgstr "<literal>hibernate.connection.username</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:409
 #, no-c-format
 msgid "database user"
-msgstr "データベースのユーザ"
+msgstr "データベースのユーザー"
 
-#. Tag: literal
-#: toolset_guide.xml:412
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.password"
-msgstr "hibernate.connection.password"
+msgid "<literal>hibernate.connection.password</literal>"
+msgstr "<literal>hibernate.connection.password</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:413
 #, no-c-format
 msgid "user password"
-msgstr "ユーザパスワード"
+msgstr "ユーザーパスワード"
 
-#. Tag: literal
-#: toolset_guide.xml:416
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.dialect"
-msgstr "hibernate.dialect"
+msgid "<literal>hibernate.dialect</literal>"
+msgstr "<literal>hibernate.dialect</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:417
 #, no-c-format
 msgid "dialect"
 msgstr "データベース方言"
 
 #. Tag: title
-#: toolset_guide.xml:426
 #, no-c-format
 msgid "Using Ant"
-msgstr "Antを使用する"
+msgstr "Ant を使用する"
 
 #. Tag: para
-#: toolset_guide.xml:428
 #, no-c-format
 msgid ""
 "You can call <literal>SchemaExport</literal> from your Ant build script:"
 msgstr ""
-"Antのビルドスクリプトから <literal>SchemaExport</literal> を呼び出すことがで"
-"きます。:"
+"Ant のビルドスクリプトから <literal>SchemaExport</literal> を呼び出すことがで"
+"きます:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:432
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemaexport\">\n"
-"    <taskdef name=\"schemaexport\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaExportTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemaexport\n"
-"        properties=\"hibernate.properties\"\n"
-"        quiet=\"no\"\n"
-"        text=\"no\"\n"
-"        drop=\"no\"\n"
-"        delimiter=\";\"\n"
-"        output=\"schema-export.sql\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemaexport>\n"
-"</target>]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:437
 #, no-c-format
 msgid "Incremental schema updates"
 msgstr "インクリメンタルなスキーマ更新"
 
 #. Tag: para
-#: toolset_guide.xml:439
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>SchemaUpdate</literal> tool will update an existing schema with "
 "\"incremental\" changes. The <literal>SchemaUpdate</literal> depends upon "
 "the JDBC metadata API and, as such, will not work with all JDBC drivers."
 msgstr ""
 "<literal>SchemaUpdate</literal> ツールは既存のスキーマをインクリメンタルに更"
-"新します。 <literal>SchemaUpdate</literal> はJDBCのメタデータAPIに強く依存し"
-"ます。 そのため、すべてのJDBCドライバでうまくいくとは限らないことに注意してく"
-"ださい。"
+"新します。 <literal>SchemaUpdate</literal> は JDBC のメタデータ API に強く依"
+"存します。そのため、すべての JDBC ドライバでうまくいくとは限らないことに注意"
+"してください。"
 
 #. Tag: para
-#: toolset_guide.xml:445
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
 "<literal>org.hibernate.tool.hbm2ddl.SchemaUpdate</literal> <emphasis>options "
 "mapping_files</emphasis>"
 msgstr ""
+"<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
+"<literal>org.hibernate.tool.hbm2ddl.SchemaUpdate</literal> <emphasis>options "
+"mapping_files</emphasis>"
 
 #. Tag: title
-#: toolset_guide.xml:451
 #, no-c-format
 msgid "<literal>SchemaUpdate</literal> Command Line Options"
-msgstr "<literal>SchemaUpdate</literal> のコマンドライン・オプション"
+msgstr "<literal>SchemaUpdate</literal> のコマンドラインオプション"
 
 #. Tag: entry
-#: toolset_guide.xml:468
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "do not export the script to the database"
 msgstr "データベースにスクリプトをエクスポートしません"
 
 #. Tag: entry
-#: toolset_guide.xml:480 toolset_guide.xml:542
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "specify a <literal>.cfg.xml</literal> file"
-msgstr "<placeholder-1/> ファイルを指定します"
+msgstr "<literal>.cfg.xml</literal> ファイルを指定"
 
 #. Tag: para
-#: toolset_guide.xml:486
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can embed <literal>SchemaUpdate</literal> in your application:"
 msgstr ""
-"アプリケーションに <literal>SchemaUpdate</literal> を組み込むことができま"
-"す。:"
+"アプリケーションに <literal>SchemaUpdate</literal> を組み込むことができます:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:490
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaUpdate(cfg).execute(false);]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:495
 #, no-c-format
 msgid "Using Ant for incremental schema updates"
-msgstr "インクリメンタルなスキーマ更新に対するAntの使用"
+msgstr "インクリメンタルなスキーマ更新に対する Ant の使用"
 
 #. Tag: para
-#: toolset_guide.xml:497
 #, no-c-format
 msgid "You can call <literal>SchemaUpdate</literal> from the Ant script:"
 msgstr ""
-"Antスクリプトから <literal>SchemaUpdate</literal> を呼び出すことができます:"
+"Ant スクリプトから <literal>SchemaUpdate</literal> を呼び出すことができます:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:501
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemaupdate\">\n"
-"    <taskdef name=\"schemaupdate\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaUpdateTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemaupdate\n"
-"        properties=\"hibernate.properties\"\n"
-"        quiet=\"no\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemaupdate>\n"
-"</target>]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:506
 #, no-c-format
 msgid "Schema validation"
 msgstr "Schema validation"
 
 #. Tag: para
-#: toolset_guide.xml:508
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>SchemaValidator</literal> tool will validate that the existing "
 "database schema \"matches\" your mapping documents. The "
@@ -1086,134 +775,407 @@
 "extremely useful for testing."
 msgstr ""
 "<literal>SchemaValidator</literal> ツールは、既存のデータベーススキーマと作成"
-"したマッピングドキュメントが\"一致する\"ことを検証します。 "
-"<literal>SchemaValidator</literal> はJDBCのメタデータAPIに強く依存することに"
-"注意してください。そのため、すべてのJDBCドライバーで作動するものではありませ"
-"ん。このツールはテスト時に非常に有用です。"
+"したマッピングドキュメントが「一致する」ことを検証します。 "
+"<literal>SchemaValidator</literal> は JDBC のメタデータ API に強く依存するこ"
+"とに注意してください。そのため、すべての JDBC ドライバーで作動するものではあ"
+"りません。このツールはテスト時に非常に有用です。"
 
 #. Tag: para
-#: toolset_guide.xml:514
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
 "<literal>org.hibernate.tool.hbm2ddl.SchemaValidator</literal> "
 "<emphasis>options mapping_files</emphasis>"
 msgstr ""
+"<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
+"<literal>org.hibernate.tool.hbm2ddl.SchemaValidator</literal> "
+"<emphasis>options mapping_files</emphasis>"
 
 #. Tag: para
-#: toolset_guide.xml:518
 #, fuzzy, no-c-format
 msgid ""
 "The following table displays the <literal>SchemaValidator</literal> command "
 "line options:"
-msgstr "<literal>SchemaValidator</literal> のコマンドライン・オプション"
+msgstr "<literal>SchemaValidator</literal> のコマンドラインオプション"
 
 #. Tag: title
-#: toolset_guide.xml:521
 #, no-c-format
 msgid "<literal>SchemaValidator</literal> Command Line Options"
-msgstr "<literal>SchemaValidator</literal> のコマンドライン・オプション"
+msgstr "<literal>SchemaValidator</literal> のコマンドラインオプション"
 
 #. Tag: para
-#: toolset_guide.xml:548
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can embed <literal>SchemaValidator</literal> in your application:"
 msgstr ""
 "<literal>SchemaValidator</literal> をアプリケーションに組み込むことが出来ま"
 "す:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:552
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaValidator(cfg).validate();]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:557
 #, no-c-format
 msgid "Using Ant for schema validation"
-msgstr "スキーマのバリデーションにAntを使用します"
+msgstr "スキーマのバリデーションに Ant を使用します"
 
 #. Tag: para
-#: toolset_guide.xml:559
 #, no-c-format
 msgid "You can call <literal>SchemaValidator</literal> from the Ant script:"
-msgstr "Antスクリプトから <literal>SchemaValidator</literal> を呼び出せます:"
+msgstr "Ant スクリプトから <literal>SchemaValidator</literal> を呼び出せます:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:563
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemavalidate\">\n"
-"    <taskdef name=\"schemavalidator\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaValidatorTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemavalidator\n"
-"        properties=\"hibernate.properties\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemavalidator>\n"
-"</target>]]>"
-msgstr ""
+#, fuzzy
+#~ msgid "<![CDATA[<property name=\"zip\" length=\"5\"/>]]>"
+#~ msgstr "&lt;property name=\"zip\" length=\"5\"/&gt;"
 
-#~ msgid "Ant Tasks:"
-#~ msgstr "Ant Tasks:"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"balance\" precision=\"12\" scale=\"2\"/>]]>"
+#~ msgstr "&lt;property name=\"balance\" precision=\"12\" scale=\"2\"/&gt;"
 
-#~ msgid "&lt;one-to-one&gt;"
-#~ msgstr "&lt;one-to-one&gt;"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"bar\" column=\"barId\" not-null=\"true\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"bar\" column=\"barId\" not-null=\"true\"/&gt;"
 
-#~ msgid "&lt;many-to-one&gt;"
-#~ msgstr "&lt;many-to-one&gt;"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<element column=\"serialNumber\" type=\"long\" not-null=\"true\" "
+#~ "unique=\"true\"/>]]>"
+#~ msgstr ""
+#~ "&lt;element column=\"serialNumber\" type=\"long\" not-null=\"true\" "
+#~ "unique=\"true\"/&gt;"
 
-#~ msgid "&lt;key&gt;"
-#~ msgstr "&lt;key&gt;"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"org\" column=\"orgId\" unique-key="
+#~ "\"OrgEmployeeId\"/>\n"
+#~ "<property name=\"employeeId\" unique-key=\"OrgEmployee\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"org\" column=\"orgId\" unique-key=\"OrgEmployeeId"
+#~ "\"/&gt;\n"
+#~ "&lt;property name=\"employeeId\" unique-key=\"OrgEmployee\"/&gt;"
 
-#~ msgid "&lt;many-to-many&gt;"
-#~ msgstr "&lt;many-to-many&gt;"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"lastName\" index=\"CustName\"/>\n"
+#~ "<property name=\"firstName\" index=\"CustName\"/>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"lastName\" index=\"CustName\"/&gt;\n"
+#~ "&lt;property name=\"firstName\" index=\"CustName\"/&gt;"
 
-#~ msgid "inverse=\"true\""
-#~ msgstr "inverse=\"true\""
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"bar\" column=\"barId\" foreign-key=\"FKFooBar"
+#~ "\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"bar\" column=\"barId\" foreign-key=\"FKFooBar\"/"
+#~ "&gt;"
 
-#~ msgid "SchemaExport"
-#~ msgstr "SchemaExport"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"name\" type=\"my.customtypes.Name\"/>\n"
+#~ "    <column name=\"last\" not-null=\"true\" index=\"bar_idx\" length=\"30"
+#~ "\"/>\n"
+#~ "    <column name=\"first\" not-null=\"true\" index=\"bar_idx\" length=\"20"
+#~ "\"/>\n"
+#~ "    <column name=\"initial\"/>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"name\" type=\"my.customtypes.Name\"/&gt;\n"
+#~ "    &lt;column name=\"last\" not-null=\"true\" index=\"bar_idx\" length="
+#~ "\"30\"/&gt;\n"
+#~ "    &lt;column name=\"first\" not-null=\"true\" index=\"bar_idx\" length="
+#~ "\"20\"/&gt;\n"
+#~ "    &lt;column name=\"initial\"/&gt;\n"
+#~ "&lt;/property&gt;"
 
-#~ msgid "&lt;column&gt;"
-#~ msgstr "&lt;column&gt;"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"credits\" type=\"integer\" insert=\"false\">\n"
+#~ "    <column name=\"credits\" default=\"10\"/>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"credits\" type=\"integer\" insert=\"false\"&gt;\n"
+#~ "    &lt;column name=\"credits\" default=\"10\"/&gt;\n"
+#~ "&lt;/property&gt;"
 
-#~ msgid "java -cp"
-#~ msgstr "java -cp"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<version name=\"version\" type=\"integer\" insert=\"false\">\n"
+#~ "    <column name=\"version\" default=\"0\"/>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;version name=\"version\" type=\"integer\" insert=\"false\"&gt;\n"
+#~ "    &lt;column name=\"version\" default=\"0\"/&gt;\n"
+#~ "&lt;/property&gt;"
 
-#~ msgid "hibernate_classpaths"
-#~ msgstr "hibernate_classpaths"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"balance\" type=\"float\">\n"
+#~ "    <column name=\"balance\" sql-type=\"decimal(13,3)\"/>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"balance\" type=\"float\"&gt;\n"
+#~ "    &lt;column name=\"balance\" sql-type=\"decimal(13,3)\"/&gt;\n"
+#~ "&lt;/property&gt;"
 
-#~ msgid "org.hibernate.tool.hbm2ddl.SchemaExport"
-#~ msgstr "org.hibernate.tool.hbm2ddl.SchemaExport"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"foo\" type=\"integer\">\n"
+#~ "    <column name=\"foo\" check=\"foo > 10\"/>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"foo\" type=\"integer\"&gt;\n"
+#~ "    &lt;column name=\"foo\" check=\"foo &gt; 10\"/&gt;\n"
+#~ "&lt;/property&gt;"
 
-#~ msgid "options mapping_files"
-#~ msgstr "options mapping_files"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Foo\" table=\"foos\" check=\"bar < 100.0\">\n"
+#~ "    ...\n"
+#~ "    <property name=\"bar\" type=\"float\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Foo\" table=\"foos\" check=\"bar &lt; 100.0\"&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;property name=\"bar\" type=\"float\"/&gt;\n"
+#~ "&lt;/class&gt;"
 
-#~ msgid "NamingStrategy"
-#~ msgstr "NamingStrategy"
+#~ msgid "length"
+#~ msgstr "length"
 
+#~ msgid "precision"
+#~ msgstr "precision"
+
+#~ msgid "scale"
+#~ msgstr "scale"
+
+#~ msgid "not-null"
+#~ msgstr "not-null"
+
+#~ msgid "true|false"
+#~ msgstr "true|false"
+
+#~ msgid "unique"
+#~ msgstr "unique"
+
+#~ msgid "index"
+#~ msgstr "index"
+
+#~ msgid "index_name"
+#~ msgstr "インデックス名"
+
+#~ msgid "unique-key"
+#~ msgstr "unique-key"
+
+#~ msgid "unique_key_name"
+#~ msgstr "ユニークキー名"
+
+#~ msgid "foreign-key"
+#~ msgstr "foreign-key"
+
 #, fuzzy
-#~ msgid "select a <placeholder-1/>"
+#~ msgid "foreign_key_name"
+#~ msgstr "foreign-key"
+
+#~ msgid "sql-type"
+#~ msgstr "sql-type"
+
+#, fuzzy
+#~ msgid "SQL column type"
+#~ msgstr "SQL のカラム型"
+
+#~ msgid "default"
+#~ msgstr "default"
+
+#~ msgid "check"
+#~ msgstr "check"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Customer\" table=\"CurCust\">\n"
+#~ "    <comment>Current customers only</comment>\n"
+#~ "    ...\n"
+#~ "</class>]]>"
 #~ msgstr ""
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "<placeholder-1/> を選択します\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "<placeholder-1/> を選択します。\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "<placeholder-1/> を選択します"
+#~ "&lt;class name=\"Customer\" table=\"CurCust\"&gt;\n"
+#~ "    &lt;comment&gt;Current customers only&lt;/comment&gt;\n"
+#~ "    ...\n"
+#~ "&lt;/class&gt;"
 
-#~ msgid "org.hibernate.tool.hbm2ddl.SchemaUpdate"
-#~ msgstr "org.hibernate.tool.hbm2ddl.SchemaUpdate"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"balance\">\n"
+#~ "    <column name=\"bal\">\n"
+#~ "        <comment>Balance in USD</comment>\n"
+#~ "    </column>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"balance\"&gt;\n"
+#~ "    &lt;column name=\"bal\"&gt;\n"
+#~ "        &lt;comment&gt;Balance in USD&lt;/comment&gt;\n"
+#~ "    &lt;/column&gt;\n"
+#~ "&lt;/property&gt;"
 
-#~ msgid ".cfg.xml"
-#~ msgstr ".cfg.xml"
+#~ msgid "--quiet"
+#~ msgstr "--quiet"
 
-#~ msgid "org.hibernate.tool.hbm2ddl.SchemaValidator"
-#~ msgstr "org.hibernate.tool.hbm2ddl.SchemaValidator"
+#~ msgid "--drop"
+#~ msgstr "--drop"
+
+#~ msgid "--create"
+#~ msgstr "--create"
+
+#~ msgid "--text"
+#~ msgstr "--text"
+
+#, fuzzy
+#~ msgid "--output=my_schema.ddl"
+#~ msgstr "<literal>--output=my_schema.ddl</literal>"
+
+#, fuzzy
+#~ msgid "--config=hibernate.cfg.xml"
+#~ msgstr "<literal>--config=hibernate.cfg.xml</literal>"
+
+#~ msgid "--properties=hibernate.properties"
+#~ msgstr "--properties=hibernate.properties"
+
+#~ msgid "--format"
+#~ msgstr "--format"
+
+#~ msgid "--delimiter=;"
+#~ msgstr "--delimiter=x"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Configuration cfg = ....;\n"
+#~ "new SchemaExport(cfg).create(false, true);]]>"
+#~ msgstr ""
+#~ "Configuration cfg = ....;\n"
+#~ "new SchemaExport(cfg).create(false, true);"
+
+#, fuzzy
+#~ msgid "hibernate.connection.driver_class"
+#~ msgstr "hibernate.connection.url"
+
+#~ msgid "hibernate.connection.url"
+#~ msgstr "hibernate.connection.url"
+
+#~ msgid "hibernate.connection.username"
+#~ msgstr "hibernate.connection.username"
+
+#~ msgid "hibernate.connection.password"
+#~ msgstr "hibernate.connection.password"
+
+#~ msgid "hibernate.dialect"
+#~ msgstr "hibernate.dialect"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<target name=\"schemaexport\">\n"
+#~ "    <taskdef name=\"schemaexport\"\n"
+#~ "        classname=\"org.hibernate.tool.hbm2ddl.SchemaExportTask\"\n"
+#~ "        classpathref=\"class.path\"/>\n"
+#~ "    \n"
+#~ "    <schemaexport\n"
+#~ "        properties=\"hibernate.properties\"\n"
+#~ "        quiet=\"no\"\n"
+#~ "        text=\"no\"\n"
+#~ "        drop=\"no\"\n"
+#~ "        delimiter=\";\"\n"
+#~ "        output=\"schema-export.sql\">\n"
+#~ "        <fileset dir=\"src\">\n"
+#~ "            <include name=\"**/*.hbm.xml\"/>\n"
+#~ "        </fileset>\n"
+#~ "    </schemaexport>\n"
+#~ "</target>]]>"
+#~ msgstr ""
+#~ "&lt;target name=\"schemaexport\"&gt;\n"
+#~ "    &lt;taskdef name=\"schemaexport\"\n"
+#~ "        classname=\"org.hibernate.tool.hbm2ddl.SchemaExportTask\"\n"
+#~ "        classpathref=\"class.path\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;schemaexport\n"
+#~ "        properties=\"hibernate.properties\"\n"
+#~ "        quiet=\"no\"\n"
+#~ "        text=\"no\"\n"
+#~ "        drop=\"no\"\n"
+#~ "        delimiter=\";\"\n"
+#~ "        output=\"schema-export.sql\"&gt;\n"
+#~ "        &lt;fileset dir=\"src\"&gt;\n"
+#~ "            &lt;include name=\"**/*.hbm.xml\"/&gt;\n"
+#~ "        &lt;/fileset&gt;\n"
+#~ "    &lt;/schemaexport&gt;\n"
+#~ "&lt;/target&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Configuration cfg = ....;\n"
+#~ "new SchemaUpdate(cfg).execute(false);]]>"
+#~ msgstr ""
+#~ "Configuration cfg = ....;\n"
+#~ "new SchemaUpdate(cfg).execute(false);"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<target name=\"schemaupdate\">\n"
+#~ "    <taskdef name=\"schemaupdate\"\n"
+#~ "        classname=\"org.hibernate.tool.hbm2ddl.SchemaUpdateTask\"\n"
+#~ "        classpathref=\"class.path\"/>\n"
+#~ "    \n"
+#~ "    <schemaupdate\n"
+#~ "        properties=\"hibernate.properties\"\n"
+#~ "        quiet=\"no\">\n"
+#~ "        <fileset dir=\"src\">\n"
+#~ "            <include name=\"**/*.hbm.xml\"/>\n"
+#~ "        </fileset>\n"
+#~ "    </schemaupdate>\n"
+#~ "</target>]]>"
+#~ msgstr ""
+#~ "&lt;target name=\"schemaupdate\"&gt;\n"
+#~ "    &lt;taskdef name=\"schemaupdate\"\n"
+#~ "        classname=\"org.hibernate.tool.hbm2ddl.SchemaUpdateTask\"\n"
+#~ "        classpathref=\"class.path\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;schemaupdate\n"
+#~ "        properties=\"hibernate.properties\"\n"
+#~ "        quiet=\"no\"&gt;\n"
+#~ "        &lt;fileset dir=\"src\"&gt;\n"
+#~ "            &lt;include name=\"**/*.hbm.xml\"/&gt;\n"
+#~ "        &lt;/fileset&gt;\n"
+#~ "    &lt;/schemaupdate&gt;\n"
+#~ "&lt;/target&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Configuration cfg = ....;\n"
+#~ "new SchemaValidator(cfg).validate();]]>"
+#~ msgstr ""
+#~ "Configuration cfg = ....;\n"
+#~ "new SchemaValidator(cfg).validate();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<target name=\"schemavalidate\">\n"
+#~ "    <taskdef name=\"schemavalidator\"\n"
+#~ "        classname=\"org.hibernate.tool.hbm2ddl.SchemaValidatorTask\"\n"
+#~ "        classpathref=\"class.path\"/>\n"
+#~ "    \n"
+#~ "    <schemavalidator\n"
+#~ "        properties=\"hibernate.properties\">\n"
+#~ "        <fileset dir=\"src\">\n"
+#~ "            <include name=\"**/*.hbm.xml\"/>\n"
+#~ "        </fileset>\n"
+#~ "    </schemavalidator>\n"
+#~ "</target>]]>"
+#~ msgstr ""
+#~ "&lt;target name=\"schemavalidate\"&gt;\n"
+#~ "    &lt;taskdef name=\"schemavalidator\"\n"
+#~ "        classname=\"org.hibernate.tool.hbm2ddl.SchemaValidatorTask\"\n"
+#~ "        classpathref=\"class.path\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;schemavalidator\n"
+#~ "        properties=\"hibernate.properties\"&gt;\n"
+#~ "        &lt;fileset dir=\"src\"&gt;\n"
+#~ "            &lt;include name=\"**/*.hbm.xml\"/&gt;\n"
+#~ "        &lt;/fileset&gt;\n"
+#~ "    &lt;/schemaupdate&gt;\n"
+#~ "&lt;/target&gt;"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/transactions.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/transactions.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/transactions.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,25 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-01-13 11:23+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: transactions.xml:29
 #, fuzzy, no-c-format
 msgid "Transactions and Concurrency"
 msgstr "トランザクションと並行性"
 
 #. Tag: para
-#: transactions.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The most important point about Hibernate and concurrency control is that it "
 "is easy to understand. Hibernate directly uses JDBC connections and JTA "
@@ -26,14 +27,14 @@
 "that you spend some time with the JDBC, ANSI, and transaction isolation "
 "specification of your database management system."
 msgstr ""
-"Hibernateと同時実行制御について最も重要な点は、容易に理解できることです。 "
-"Hibernateは新たなロックの振る舞いを追加しておらず、直接JDBCコネクションとJTA"
-"リソースを使用します。 JDBC、ANSI、およびデータベース管理システム(DBMS)のト"
-"ランザクション分離の仕様を 少し時間をかけて勉強することを強く推奨します。"
+"Hibernate と同時実行制御について最も重要な点は、容易に理解できることです。 "
+"Hibernate は新たなロックの振る舞いを追加しておらず、直接 JDBC コネクションと "
+"JTA リソースを使用します。 JDBC 、 ANSI 、およびデータベース管理システム"
+"(DBMS)のトランザクション分離の仕様を少し時間をかけて勉強することを強く推奨"
+"します。"
 
 #. Tag: para
-#: transactions.xml:38
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate does not lock objects in memory. Your application can expect the "
 "behavior as defined by the isolation level of your database transactions. "
@@ -41,15 +42,14 @@
 "cache, Hibernate provides repeatable reads for lookup by identifier and "
 "entity queries and not reporting queries that return scalar values."
 msgstr ""
-"Hibernateはメモリ内のオブジェクトをロックしません。 アプリケーションは、デー"
-"タベーストランザクションの分離レベルで 定義した振る舞いを期待できます。 トラ"
-"ンザクションスコープのキャッシュでもある <literal>Session</literal> のお陰"
-"で、 識別子やクエリにより検索したエンティティはリピータブルリードになります "
-"(スカラー値を返すようなレポートクエリは違います)。"
+"Hibernate はメモリ内のオブジェクトをロックしません。アプリケーションは、デー"
+"タベーストランザクションの分離レベルで定義した振る舞いを期待できます。トラン"
+"ザクションスコープのキャッシュでもある <literal>Session</literal> のお陰で、"
+"識別子やクエリにより検索したエンティティはリピータブルリードになります(スカ"
+"ラー値を返すようなレポートクエリは違います)。"
 
 #. Tag: para
-#: transactions.xml:46
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In addition to versioning for automatic optimistic concurrency control, "
 "Hibernate also offers, using the <literal>SELECT FOR UPDATE</literal> "
@@ -57,13 +57,12 @@
 "concurrency control and this API are discussed later in this chapter."
 msgstr ""
 "バージョニングによる自動的な楽観的同時実行制御に加えて、 <literal>SELECT FOR "
-"UPDATE</literal> 文を使用して、 行を悲観的ロックするための(マイナーな)APIも"
-"提供します。 楽観的同時実行制御とこのAPIについては、この章の後のほうで議論し"
-"ます。"
+"UPDATE</literal> 文を使用して、行を悲観的ロックするための(マイナーな) API "
+"も提供します。楽観的同時実行制御とこの API については、この章の後のほうで議論"
+"します。"
 
 #. Tag: para
-#: transactions.xml:53
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The discussion of concurrency control in Hibernate begins with the "
 "granularity of <literal>Configuration</literal>, <literal>SessionFactory</"
@@ -72,32 +71,29 @@
 msgstr ""
 "データベーストランザクションや長い対話(conversation、ロングトランザクショ"
 "ン)だけでなく、 <literal>Configuration</literal>、<literal>SessionFactory</"
-"literal>、および <literal>Session</literal> という粒度でHibernateが行う同時実"
-"行制御の議論を始めます。"
+"literal>、および <literal>Session</literal> という粒度で Hibernate が行う同時"
+"実行制御の議論を始めます。"
 
 #. Tag: title
-#: transactions.xml:60
 #, no-c-format
 msgid "Session and transaction scopes"
-msgstr "sessionスコープとtransactionスコープ"
+msgstr "session スコープと transaction スコープ"
 
 #. Tag: para
-#: transactions.xml:62
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>SessionFactory</literal> is an expensive-to-create, threadsafe "
 "object, intended to be shared by all application threads. It is created "
 "once, usually on application startup, from a <literal>Configuration</"
 "literal> instance."
 msgstr ""
-"<literal>SessionFactory</literal> は生成することが高価で、 スレッドセーフなオ"
-"ブジェクトです。 よって、アプリケーションのすべてのスレッドで共有すべきで"
-"す。 通常、アプリケーションの起動時に、 <literal>Configuration</literal> イン"
-"スタンスから1度だけ生成します。"
+"<literal>SessionFactory</literal> は生成することが高価で、スレッドセーフなオ"
+"ブジェクトです。よって、アプリケーションのすべてのスレッドで共有すべきです。"
+"通常、アプリケーションの起動時に、 <literal>Configuration</literal> インスタ"
+"ンスから1度だけ生成します。"
 
 #. Tag: para
-#: transactions.xml:68
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>Session</literal> is an inexpensive, non-threadsafe object that "
 "should be used once and then discarded for: a single request, a conversation "
@@ -106,15 +102,14 @@
 "unless it is needed. It will not consume any resources until used."
 msgstr ""
 "<literal>Session</literal> は高価ではなく、スレッドセーフなオブジェクトでもあ"
-"りません。 よって、1つの要求や1つの対話、1つの作業単位(unit of work)に対"
-"して1度だけ使い、 その後で捨てるべきです。 <literal>Session</literal> は必要"
+"りません。よって、1つの要求や1つの対話、1つの作業単位(unit of work)に対"
+"して1度だけ使い、その後で捨てるべきです。 <literal>Session</literal> は必要"
 "になるまで、 JDBC <literal>Connection</literal>(もしくは "
-"<literal>DataSource</literal>)を獲得しません。 ゆえに、実際に使用するときま"
-"でリソースを消費しません。"
+"<literal>DataSource</literal>)を獲得しません。ゆえに、実際に使用するときまで"
+"リソースを消費しません。"
 
 #. Tag: para
-#: transactions.xml:76
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In order to reduce lock contention in the database, a database transaction "
 "has to be as short as possible. Long database transactions will prevent your "
@@ -122,16 +117,15 @@
 "that you hold a database transaction open during user think time until the "
 "unit of work is complete."
 msgstr ""
-"この状況を完了させるために、 データベーストランザクションについても考えなけれ"
-"ばなりません。 データベース内のロックの競合を少なくするために、 データベース"
-"トランザクションは可能な限り短くするべきです。 長いデータベーストランザクショ"
-"ンは、アプリケーションの高い並列実行性を阻害します。 ゆえに、ユーザーが考えて"
-"いる間(作業単位が完了するまで)データベーストランザクションを 開いたままにす"
-"るのは、たいていの場合よい設計とはいえません。"
+"この状況を完了させるために、データベーストランザクションについても考えなけれ"
+"ばなりません。データベース内のロックの競合を少なくするために、データベースト"
+"ランザクションは可能な限り短くするべきです。長いデータベーストランザクション"
+"は、アプリケーションの高い並列実行性を阻害します。ゆえに、ユーザーが考えてい"
+"る間(作業単位が完了するまで)データベーストランザクションを開いたままにする"
+"のは、たいていの場合よい設計とはいえません。"
 
 #. Tag: para
-#: transactions.xml:84
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What is the scope of a unit of work? Can a single Hibernate "
 "<literal>Session</literal> span several database transactions, or is this a "
@@ -139,20 +133,18 @@
 "<literal>Session</literal> and how do you demarcate the database transaction "
 "boundaries? These questions are addressed in the following sections."
 msgstr ""
-"作業単位というスコープとは何でしょうか? 1つのHibernate <literal>Session</"
-"literal> は、 いくつかのデータベーストランザクションをまたがることができるで"
-"しょうか? または、スコープと一対一の関係でしょうか? いつ <literal>Session</"
-"literal> を開き、閉じるべきでしょうか? そして、データベーストランザクション"
-"境界をどのように分けるのでしょうか?"
+"作業単位というスコープとは何でしょうか?1つの Hibernate <literal>Session</"
+"literal> は、いくつかのデータベーストランザクションをまたがることができるで"
+"しょうか?または、スコープと一対一の関係でしょうか?いつ <literal>Session</"
+"literal> を開き、閉じるべきでしょうか?そして、データベーストランザクション境"
+"界をどのように分けるのでしょうか?"
 
 #. Tag: title
-#: transactions.xml:92
 #, no-c-format
 msgid "Unit of work"
 msgstr "作業単位(Unit of work)"
 
 #. Tag: para
-#: transactions.xml:94
 #, no-c-format
 msgid ""
 "First, let's define a unit of work. A unit of work is a design pattern "
@@ -162,14 +154,13 @@
 "citation> In other words, its a series of operations we wish to carry out "
 "against the database together. Basically, it is a transaction, though "
 "fulfilling a unit of work will often span multiple physical database "
-"transactions (see <xref linkend=\"transactions-basics-apptx\"/>). So really "
+"transactions (see <xref linkend=\"transactions-basics-apptx\" />). So really "
 "we are talking about a more abstract notion of a transaction. The term "
 "\"business transaction\" is also sometimes used in lieu of unit of work."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not use the <emphasis>session-per-operation</emphasis> antipattern: do "
 "not open and close a <literal>Session</literal> for every simple database "
@@ -185,25 +176,24 @@
 "clearly defined unit of work. The latter is also more maintainable and "
 "extensible."
 msgstr ""
-"1つ目は、<emphasis>session-per-operation</emphasis> アンチパターンを使っては"
-"いけません。 すなわち、1つのスレッドの中で、単純なデータベース呼び出しのたび"
-"に <literal>Session</literal> を開いて、閉じてはいけません! もちろん、データ"
-"ベーストランザクションについても同様です。 アプリケーション中のデータベース呼"
-"び出しは、 計画されたシーケンス(planned sequence)を使い、 アトミックな作業"
-"単位に分類されます。 (1つのSQL文ごとにコミットする自動コミットが、 使われな"
-"いという意味でもあることに注意してください。 自動コミットは、SQLコンソールで"
-"アドホックな作業をする際に使うものです。 Hibernateは直ちに自動コミットモード"
-"を無効にします。 もしくは、アプリケーションサーバーが無効化することを期待しま"
-"す。) データベーストランザクションはオプションではありません。 データベース"
-"とのすべての通信は、データの読み込みであっても、書き込みであっても、 トランザ"
-"クションの中で行わなければなりません。 説明すると、データ読み込みに対して、自"
-"動コミットは避けるべきです。 なぜなら、多数の小さなトランザクションは、明確に"
-"定義された1つの作業単位と比べて、 パフォーマンスがよくなることはありませ"
-"ん。 後者は保守性や拡張性もよりすぐれています。"
+"1つ目は、 <emphasis>session-per-operation</emphasis> アンチパターンを使って"
+"はいけません。すなわち、1つのスレッドの中で、単純なデータベース呼び出しの度"
+"に <literal>Session</literal> を開いて、閉じてはいけません。もちろん、データ"
+"ベーストランザクションについても同様です。アプリケーション中のデータベース呼"
+"び出しは、計画されたシーケンス(planned sequence)を使い、アトミックな作業単"
+"位に分類されます。(1つの SQL 文ごとにコミットする自動コミットが、使われない"
+"という意味でもあることに注意してください。自動コミットは、 SQL コンソールでア"
+"ドホックな作業をする際に使うものです。 Hibernate は直ちに自動コミットモードを"
+"無効にします。もしくは、アプリケーションサーバーが無効化することを期待しま"
+"す。)データベーストランザクションはオプションではありません。データベースと"
+"のすべての通信は、データの読み込みであっても、書き込みであっても、トランザク"
+"ションの中で行わなければなりません。説明すると、データ読み込みに対して、自動"
+"コミットは避けるべきです。なぜなら、多数の小さなトランザクションは、明確に定"
+"義された1つの作業単位と比べて、パフォーマンスがよくなることはありません。後"
+"者は保守性や拡張性もよりすぐれています。"
 
 #. Tag: para
-#: transactions.xml:126
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The most common pattern in a multi-user client/server application is "
 "<emphasis>session-per-request</emphasis>. In this model, a request from the "
@@ -216,20 +206,19 @@
 "literal>. The relationship between the two is one-to-one and this model is a "
 "perfect fit for many applications."
 msgstr ""
-"マルチユーザーのクライアント/サーバーアプリケーションの中で、 最もよく使われ"
-"るパターンは、<emphasis>session-per-request</emphasis> です。 このモデルの中"
-"では、 クライアントから(Hibernate永続化層が動作する)サーバーへリクエストが"
-"送られ、 新しいHibernate <literal>Session</literal> が開かれます。 そして、こ"
-"の作業単位の中ですべてのデータベース処理が実行されます。 作業が完了した(そし"
+"マルチユーザーのクライアント/サーバーアプリケーションの中で、最もよく使われ"
+"るパターンは、 <emphasis>session-per-request</emphasis> です。このモデルの中"
+"では、クライアントから( Hibernate 永続化層が動作する)サーバーへリクエストが"
+"送られ、新しい Hibernate <literal>Session</literal> が開かれます。そして、こ"
+"の作業単位の中ですべてのデータベース処理が実行されます。作業が完了した(そし"
 "て、クライアントへのレスポンスが準備できた)時点で、 session をフラッシュし、"
-"閉じます。 クライアントの要求を処理するために、1つのデータベーストランザク"
-"ションを使用するでしょう。 <literal>Session</literal> を開き、閉じる際に、 "
-"データベーストランザクションを開始し、コミットします。 二つの関係は一対一で"
-"す。 このモデルは多くのアプリケーションに完全に適合します。"
+"閉じます。クライアントの要求を処理するために、1つのデータベーストランザク"
+"ションを使用するでしょう。 <literal>Session</literal> を開き、閉じる際に、"
+"データベーストランザクションを開始し、コミットします。二つの関係は一対一で"
+"す。このモデルは多くのアプリケーションに完全に適合します。"
 
 #. Tag: para
-#: transactions.xml:138
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The challenge lies in the implementation. Hibernate provides built-in "
 "management of the \"current session\" to simplify this pattern. Start a "
@@ -243,38 +232,36 @@
 "use the Hibernate <literal>Transaction</literal> API shown later in this "
 "chapter."
 msgstr ""
-"以降の実装にチャレンジしてください。 Hibernateは単純なこのパターンのために、"
-"予め組み込まれた 「current session」の管理を提供します。 サーバーリクエストを"
-"処理する際はトランザクションを開始しなければなりません。 そして、レスポンスを"
-"クライアントに送信する前にトランザクションを終わらせます。 好きな方法で実現で"
-"きます。一般的な解決策は <literal>ServletFilter</literal> や サービスメソッド"
-"をポイントカットしてAOPインターセプター、 proxy/interception コンテナです。 "
-"EJBコンテナはEJBセッションビーンをトランザクション境界として アスペクトをクロ"
-"スカットする実装の標準的な方法です(CMTによる宣言的)。 プログラムによるトラ"
-"ンザクション境界を使うと決めた場合、 簡単に使うため、互換性のあるコードにする"
-"ために、 この章の後のほうにあるHibernate <literal>Transaction</literal> APIの"
-"ほうがよいです。"
+"以降の実装にチャレンジしてください。 Hibernate は単純なこのパターンのために、"
+"予め組み込まれた \"current session\" の管理を提供します。サーバーリクエストを"
+"処理する際はトランザクションを開始しなければなりません。そして、レスポンスを"
+"クライアントに送信する前にトランザクションを終わらせます。好きな方法で実現で"
+"きます。一般的な解決策は <literal>ServletFilter</literal> やサービスメソッド"
+"をポイントカットして AOP インターセプター、 proxy/interception コンテナで"
+"す。 EJB コンテナは EJB セッション Bean をトランザクション境界としてアスペク"
+"トをクロスカットする実装の標準的な方法です( CMT による宣言的)。プログラムに"
+"よるトランザクション境界を使うと決めた場合、簡単に使うため、互換性のあるコー"
+"ドにするために、この章の後のほうにある Hibernate <literal>Transaction</"
+"literal> API のほうがよいです。"
 
 #. Tag: para
-#: transactions.xml:150
 #, fuzzy, no-c-format
 msgid ""
 "Your application code can access a \"current session\" to process the "
 "request by calling <literal>sessionFactory.getCurrentSession()</literal>. "
 "You will always get a <literal>Session</literal> scoped to the current "
 "database transaction. This has to be configured for either resource-local or "
-"JTA environments, see <xref linkend=\"architecture-current-session\"/>."
+"JTA environments, see <xref linkend=\"architecture-current-session\" />."
 msgstr ""
-"アプリケーションのコードは、必要なときにどこでも、何回でも、 単に "
-"<literal>sessionFactory.getCurrentSession()</literal> を呼び出すだけで 「現在"
-"のセッション」にアクセスできます。 現在のデータベーストランザクションへの "
-"<literal>セッション</literal> を常に取得します。 リソース・ローカルな環境、も"
-"しくはJTA環境を構成しなければなりません (<xref linkend=\"architecture-"
+"アプリケーションのコードは、必要なときにどこでも、何回でも、単に "
+"<literal>sessionFactory.getCurrentSession()</literal> を呼び出すだけで「現在"
+"のセッション」にアクセスできます。現在のデータベーストランザクションへの "
+"<literal>セッション</literal> を常に取得します。リソースローカルな環境、もし"
+"くは JTA 環境を構成しなければなりません (<xref linkend=\"architecture-"
 "current-session\"/> を参照してください)。"
 
 #. Tag: para
-#: transactions.xml:158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can extend the scope of a <literal>Session</literal> and database "
 "transaction until the \"view has been rendered\". This is especially useful "
@@ -287,24 +274,22 @@
 "examples relating to this <emphasis>Open Session in View</emphasis> pattern."
 msgstr ""
 "ときどき、「ビューを描画する」まで <literal>セッション</literal> とデータベー"
-"ストランザクションのスコープを拡張すると便利なことがあります。 これは、要求の"
-"処理と描画のフェーズを分けている サーブレットアプリケーションにおいて特に役立"
-"ちます。 独自のインターセプタを実装すれば、 ビューを描画するまでデータベース"
-"トランザクションを拡張するのは簡単です。 しかし、コンテナ管理トランザクション"
-"のEJBに頼る場合は、簡単にはできません。 なぜなら、ビューの描画を開始する前"
-"に、EJBのメソッドがリターンした際に、 トランザクションが完了するためです。 こ"
-"の <emphasis>Open Session in View</emphasis> パターンに関連するヒントと例につ"
-"いては、 HibernateのWebサイトやフォーラムを参照してください。"
+"ストランザクションのスコープを拡張すると便利なことがあります。これは、要求の"
+"処理と描画のフェーズを分けているサーブレットアプリケーションにおいて特に役立"
+"ちます。独自のインターセプタを実装すれば、ビューを描画するまでデータベースト"
+"ランザクションを拡張するのは簡単です。しかし、コンテナ管理トランザクションの "
+"EJB に頼る場合は、簡単にはできません。なぜなら、ビューの描画を開始する前に、 "
+"EJB のメソッドがリターンした際に、トランザクションが完了するためです。この "
+"<emphasis>Open Session in View</emphasis> パターンに関連するヒントと例につい"
+"ては、 Hibernate の Web サイトやフォーラムを参照してください。"
 
 #. Tag: title
-#: transactions.xml:173
 #, no-c-format
 msgid "Long conversations"
 msgstr "長い対話"
 
 #. Tag: para
-#: transactions.xml:175
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The session-per-request pattern is not the only way of designing units of "
 "work. Many business processes require a whole series of interactions with "
@@ -312,51 +297,47 @@
 "applications, it is not acceptable for a database transaction to span a user "
 "interaction. Consider the following example:"
 msgstr ""
-"session-per-requestパターンは、作業単位を設計する際に役立つ考えというだけでは"
-"ありません。 多くのビジネスプロセスは、ユーザーとの一連の相互作用全体を要求し"
-"ます。 その相互作用には、データベースアクセスが含まれます。 Webとエンタープラ"
-"イズアプリケーションでは、データベーストランザクションが ユーザとの相互作用に"
-"まで渡ることは許されません。 次の例をよく考えてみてください。"
+"session-per-request パターンは、作業単位を設計する際に役立つ考えというだけで"
+"はありません。多くのビジネスプロセスは、ユーザーとの一連の相互作用全体を要求"
+"します。その相互作用には、データベースアクセスが含まれます。 Web とエンタープ"
+"ライズアプリケーションでは、データベーストランザクションがユーザーとの相互作"
+"用にまで渡ることは許されません。次の例をよく考えてみてください: "
 
 #. Tag: para
-#: transactions.xml:185
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The first screen of a dialog opens. The data seen by the user has been "
 "loaded in a particular <literal>Session</literal> and database transaction. "
 "The user is free to modify the objects."
 msgstr ""
 "ダイアログの最初の画面が開き、個々の <literal>Session</literal> とデータベー"
-"ストランザクションの中でロードされたデータをユーザーに見せます。 ユーザーはオ"
+"ストランザクションの中でロードされたデータをユーザーに見せます。ユーザーはオ"
 "ブジェクトを自由に修正できます。"
 
 #. Tag: para
-#: transactions.xml:192
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The user clicks \"Save\" after 5 minutes and expects their modifications to "
 "be made persistent. The user also expects that they were the only person "
 "editing this information and that no conflicting modification has occurred."
 msgstr ""
-"5分後にユーザーは「Save」をクリックし、修正が永続化されるのを期待します。 ま"
-"た、この情報を編集したのは自分1人だけで、 修正のコンフリクトは発生しないと期"
+"5分後にユーザーは \"Save\" をクリックし、修正が永続化されるのを期待します。ま"
+"た、この情報を編集したのは自分1人だけで、修正のコンフリクトは発生しないと期"
 "待します。"
 
 #. Tag: para
-#: transactions.xml:200
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "From the point of view of the user, we call this unit of work a long-running "
 "<emphasis>conversation</emphasis> or <emphasis>application transaction</"
 "emphasis>. There are many ways to implement this in your application."
 msgstr ""
 "この作業単位を(ユーザーの視点で)長期の <emphasis>対話</emphasis> (もしく"
-"は、<emphasis>アプリケーショントランザクション</emphasis> )と呼びます。 アプ"
+"は、<emphasis>アプリケーショントランザクション</emphasis> )と呼びます。アプ"
 "リケーションにこれを実装する方法はたくさんあります。"
 
 #. Tag: para
-#: transactions.xml:206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A first naive implementation might keep the <literal>Session</literal> and "
 "database transaction open during user think time, with locks held in the "
@@ -364,16 +345,15 @@
 "atomicity. This is an anti-pattern, since lock contention would not allow "
 "the application to scale with the number of concurrent users."
 msgstr ""
-"最初に思いつく実装は、ユーザーが考えている間、<literal>Session</literal> と"
-"データベーストランザクションを開いたままにしておくことです。 同時に修正され"
-"ず、分離と原子性が保証されるように、 データベース内のロックは保持したままにし"
-"ます。 もちろん、これはアンチパターンです。 なぜなら、ロックの競合が発生する"
-"と、 アプリケーションが同時ユーザー数に応じてスケールアップできなくなるからで"
+"最初に思いつく実装は、ユーザーが考えている間、 <literal>Session</literal> と"
+"データベーストランザクションを開いたままにしておくことです。同時に修正され"
+"ず、分離と原子性が保証されるように、データベース内のロックは保持したままにし"
+"ます。もちろん、これはアンチパターンです。なぜなら、ロックの競合が発生する"
+"と、アプリケーションが同時ユーザー数に応じてスケールアップできなくなるからで"
 "す。"
 
 #. Tag: para
-#: transactions.xml:214
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You have to use several database transactions to implement the conversation. "
 "In this case, maintaining isolation of business processes becomes the "
@@ -384,31 +364,29 @@
 "several request/response cycles). This is easier to implement than it might "
 "sound, especially if you utilize some of Hibernate's features:"
 msgstr ""
-"明らかに、対話を実装するためには、 いくつかのデータベーストランザクションを使"
-"用するべきです。 この場合、ビジネスプロセスの分離を維持することは、 アプリ"
-"ケーション層の責務の1つになります。 1つの対話は、 通常いくつかのデータベー"
-"ストランザクションに及びます。 データベーストランザクションの1つのみ(最後の"
-"1つ)が更新したデータを保存し、 他はデータを読むだけであれば、それはアトミッ"
-"クです (例えば、いくつかの要求/応答を繰り返すウィザード形式のダイアロ"
-"グ)。 これは聞くより、実装したほうが簡単です。 Hibernateの機能を使うのであれ"
-"ば、特に簡単です。"
+"明らかに、対話を実装するためには、いくつかのデータベーストランザクションを使"
+"用するべきです。この場合、ビジネスプロセスの分離を維持することは、アプリケー"
+"ション層の責務の1つになります。1つの対話は、通常いくつかのデータベーストラ"
+"ンザクションに及びます。データベーストランザクションの1つのみ(最後の1つ)"
+"が更新したデータを保存し、他はデータを読むだけであれば、それはアトミックです"
+"(例えば、いくつかの要求/応答を繰り返すウィザード形式のダイアログ)。これは"
+"聞くより、実装したほうが簡単です。 Hibernate の機能を使うのであれば、特に簡単"
+"です:"
 
 #. Tag: para
-#: transactions.xml:227
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Automatic Versioning</emphasis>: Hibernate can perform automatic "
 "optimistic concurrency control for you. It can automatically detect if a "
 "concurrent modification occurred during user think time. Check for this at "
 "the end of the conversation."
 msgstr ""
-"<emphasis>自動バージョニング</emphasis> - Hibernateは自動的に楽観的同時実行制"
-"御ができます。 ユーザーが考えている間に同時に修正がおきた場合、自動的に検出で"
-"きます。 通常、対話の終了時にチェックするだけです。"
+"<emphasis>自動バージョニング</emphasis> - Hibernate は自動的に楽観的同時実行"
+"制御ができます。ユーザーが考えている間に同時に修正がおきた場合、自動的に検出"
+"できます。通常、対話の終了時にチェックするだけです。"
 
 #. Tag: para
-#: transactions.xml:235
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Detached Objects</emphasis>: if you decide to use the "
 "<emphasis>session-per-request</emphasis> pattern, all loaded instances will "
@@ -418,16 +396,15 @@
 "versioning is used to isolate concurrent modifications."
 msgstr ""
 "<emphasis>分離(Detached)オブジェクト</emphasis> - すでに議論した "
-"<emphasis>session-per-request</emphasis> パターンを使うと決定した場合、 ロー"
-"ドされたすべてのインスタンスは、ユーザが考えている間は、 セッションから分離さ"
-"れた状態になります。 オブジェクトをセッションに再追加し、修正を永続化できま"
-"す。 これを <emphasis>session-per-request-with-detached-objects</emphasis> パ"
-"ターンと呼びます。 自動バージョニングを使うことで、同時に行われる修正を分離で"
+"<emphasis>session-per-request</emphasis> パターンを使うと決定した場合、ロード"
+"されたすべてのインスタンスは、ユーザーが考えている間は、セッションから分離さ"
+"れた状態になります。オブジェクトをセッションに再追加し、修正を永続化できま"
+"す。これを <emphasis>session-per-request-with-detached-objects</emphasis> パ"
+"ターンと呼びます。自動バージョニングを使うことで、同時に行われる修正を分離で"
 "きます。"
 
 #. Tag: para
-#: transactions.xml:245
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Extended (or Long) Session</emphasis>: the Hibernate "
 "<literal>Session</literal> can be disconnected from the underlying JDBC "
@@ -438,18 +415,17 @@
 "<literal>Session</literal> will not be allowed to be flushed automatically, "
 "but explicitly."
 msgstr ""
-"<emphasis>拡張(もしくは、長い)セッション</emphasis> - Hibernateの "
-"<literal>Session</literal> は、 データベーストランザクションをコミットした"
-"後、 裏で結びついているJDBCコネクションを切断できます。 そして、クライアント"
-"からの新しい要求が発生した際に、再接続できます。 このパターンは、"
+"<emphasis>拡張(もしくは、長い)セッション</emphasis> - Hibernate の "
+"<literal>Session</literal> は、データベーストランザクションをコミットした後、"
+"裏で結びついている JDBC コネクションを切断できます。そして、クライアントから"
+"の新しい要求が発生した際に、再接続できます。このパターンは、 "
 "<emphasis>session-per-conversation</emphasis> という名で知られており、オブ"
-"ジェクトをセッションへ再追加することさえ不要にします。 自動バージョニングを使"
-"うことで、同時に行われる修正を分離できます。 通常 <literal>Session</literal> "
-"を自動的にフラッシュさせず、 明示的にフラッシュします。"
+"ジェクトをセッションへ再追加することさえ不要にします。自動バージョニングを使"
+"うことで、同時に行われる修正を分離できます。通常 <literal>Session</literal> "
+"を自動的にフラッシュさせず、明示的にフラッシュします。"
 
 #. Tag: para
-#: transactions.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Both <emphasis>session-per-request-with-detached-objects</emphasis> and "
 "<emphasis>session-per-conversation</emphasis> have advantages and "
@@ -457,57 +433,50 @@
 "the context of optimistic concurrency control."
 msgstr ""
 "<emphasis>session-per-request-with-detached-objects</emphasis> と "
-"<emphasis>session-per-conversation</emphasis> の2つは、 利点と欠点を持ってい"
-"ます。 これについては、この章の後のほうで、楽観的同時実行制御の文脈の中で議論"
+"<emphasis>session-per-conversation</emphasis> の2つは、利点と欠点を持ってい"
+"ます。これについては、この章の後のほうで、楽観的同時実行制御の文脈の中で議論"
 "します。"
 
 #. Tag: title
-#: transactions.xml:267
 #, no-c-format
 msgid "Considering object identity"
 msgstr "オブジェクト識別子を考える"
 
 #. Tag: para
-#: transactions.xml:269
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An application can concurrently access the same persistent state in two "
 "different <literal>Session</literal>s. However, an instance of a persistent "
 "class is never shared between two <literal>Session</literal> instances. It "
 "is for this reason that there are two different notions of identity:"
 msgstr ""
-"アプリケーションは、2つの異なる <literal>Session</literal> から 同じ永続状態"
-"に同時にアクセスできます。 しかし、2つの <literal>Session</literal> インスタ"
-"ンスが 永続性クラスの1つのインスタンスを共有することはできません。 ゆえに、"
-"識別子には2つの異なる概念があるということになります。"
+"アプリケーションは、2つの異なる <literal>Session</literal> から同じ永続状態"
+"に同時にアクセスできます。しかし、2つの <literal>Session</literal> インスタ"
+"ンスが永続性クラスの1つのインスタンスを共有することはできません。ゆえに、識"
+"別子には2つの異なる概念があるということになります。"
 
 #. Tag: term
-#: transactions.xml:278
 #, no-c-format
 msgid "Database Identity"
 msgstr "データベース識別子"
 
-#. Tag: literal
-#: transactions.xml:281
-#, no-c-format
-msgid "foo.getId().equals( bar.getId() )"
-msgstr "foo.getId().equals( bar.getId() )"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>foo.getId().equals( bar.getId() )</literal>"
+msgstr "<literal>foo.getId().equals( bar.getId() )</literal>"
 
 #. Tag: term
-#: transactions.xml:286
 #, no-c-format
 msgid "JVM Identity"
-msgstr "JVM識別子"
+msgstr "JVM 識別子"
 
-#. Tag: literal
-#: transactions.xml:289
+#. Tag: para
 #, no-c-format
-msgid "foo==bar"
-msgstr "foo==bar"
+msgid "<literal>foo==bar</literal>"
+msgstr ""
 
 #. Tag: para
-#: transactions.xml:295
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For objects attached to a <emphasis>particular</emphasis> <literal>Session</"
 "literal> (i.e., in the scope of a <literal>Session</literal>), the two "
@@ -518,18 +487,17 @@
 "resolved using an optimistic approach and automatic versioning at flush/"
 "commit time."
 msgstr ""
-"<emphasis>個々の</emphasis><literal>Session</literal> に追加されたオブジェク"
+"<emphasis>特定の</emphasis><literal>Session</literal> に追加されたオブジェク"
 "トにとって (すなわち、1つの <literal>Session</literal> のスコープの中で"
-"は)、2つの概念は同じです。 データベース同一性とJVM同一性が一致することを、"
-"Hibernateが保証します。 しかし、アプリケーションが2つの異なるセッションから "
-"「同じ」(永続性識別子の)ビジネスオブジェクトに同時にアクセスする限り、 2つ"
-"のインスタンスは実際に(JVM識別子が)「異なり」ます。 楽観的アプローチによっ"
-"て、(自動バージョニングの)フラッシュ/コミット時に コンフリクトが解決されま"
-"す。"
+"は) 、2つの概念は同じです。データベース同一性と JVM 同一性が一致すること"
+"を、 Hibernate が保証します。しかし、アプリケーションが2つの異なるセッション"
+"から「同じ」(永続性識別子の)ビジネスオブジェクトに同時にアクセスする限り、"
+"2つのインスタンスは実際に( JVM 識別子が)「異なり」ます。楽観的アプローチに"
+"よって、 (自動バージョニングの) フラッシュ/コミット時にコンフリクトが解決"
+"されます。"
 
 #. Tag: para
-#: transactions.xml:304
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This approach leaves Hibernate and the database to worry about concurrency. "
 "It also provides the best scalability, since guaranteeing identity in single-"
@@ -539,17 +507,16 @@
 "<literal>Session</literal>. Within a <literal>Session</literal> the "
 "application can safely use <literal>==</literal> to compare objects."
 msgstr ""
-"このアプローチでは、Hibernateとデータベースに同時実行についての心配が残りま"
-"す。 一方で、最高のスケーラビリティが提供されます。 なぜなら、1スレッドの作"
-"業単位の中で一意性が保証されれば、 高価なロックや同期化が不要になるためで"
-"す。 <literal>Session</literal> ごとに1つのスレッドを貼り付ける限り、 アプリ"
-"ケーションはビジネスオブジェクトをsynchronizeする必要はありません。 "
+"このアプローチでは、 Hibernate とデータベースに同時実行についての心配が残りま"
+"す。一方で、最高のスケーラビリティが提供されます。なぜなら、1スレッドの作業"
+"単位の中で一意性が保証されれば、高価なロックや同期化が不要になるためです。 "
+"<literal>Session</literal> ごとに1つのスレッドを貼り付ける限り、アプリケー"
+"ションはビジネスオブジェクトを synchronize する必要はありません。 "
 "<literal>Session</literal> 内では、アプリケーションはオブジェクトを比較するた"
 "めに、 <literal>==</literal> を安全に使用できます。"
 
 #. Tag: para
-#: transactions.xml:313
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, an application that uses <literal>==</literal> outside of a "
 "<literal>Session</literal> might produce unexpected results. This might "
@@ -572,33 +539,31 @@
 "that this is not a Hibernate issue, but simply how Java object identity and "
 "equality has to be implemented."
 msgstr ""
-"けれども、<literal>Session</literal> の外で <literal>==</literal> を使うアプ"
-"リケーションは、予期しない結果に遭遇します。 これは予期しない場所で起こりえま"
-"す。 例えば、2つの分離インスタンスを同じ <literal>Set</literal> に putしたと"
-"きなどです。 両方とも同じデータベース識別子を持ちます(すなわち、同じ行を表し"
-"ます)。 しかし、分離状態のインスタンスのJVM識別子は当然保証されません。 開発"
+"けれども、 <literal>Session</literal> の外で <literal>==</literal> を使うアプ"
+"リケーションは、予期しない結果に遭遇します。これは予期しない場所で起こりえま"
+"す。例えば、2つの分離インスタンスを同じ <literal>Set</literal> に put したと"
+"きなどです。両方とも同じデータベース識別子を持ちます(すなわち、同じ行を表し"
+"ます)。しかし、分離状態のインスタンスの JVM 識別子は当然保証されません。開発"
 "者は、永続性クラスの <literal>equals()</literal> と <literal>hashCode()</"
 "literal> メソッドをオーバーライドし、オブジェクト等価性の概念を実装すべきで"
-"す。 警告が1つあります。等価性の実装にデータベース識別子を使わないでくださ"
-"い。 ユニークな(普通は不変の)属性の組み合わせであるビジネスキーを使ってくだ"
-"さい。 もし、一時オブジェクトが永続化された場合、データベース識別子が変わりま"
-"す。 一時オブジェクトを(通常分離インスタンスと共に) <literal>Set</literal> "
-"に保持する場合、ハッシュコードが変わるということは、<literal>Set</literal> の"
-"契約を破るということです。 ビジネスキーのための属性は、データベースの主キーほ"
-"ど安定すべきではないです。 オブジェクトが同じ <literal>Set</literal> の中にい"
-"る間だけ、安定を保証すべきです。 この問題のより徹底的な議論は、HibernateのWeb"
-"サイトを参照してください。 また、これはHibernateの問題ではなく、単にJavaオブ"
-"ジェクトの識別子や等価性を どのように実装すべきかということです。"
+"す。警告が1つあります。等価性の実装にデータベース識別子を使わないでくださ"
+"い。ユニークな(普通は不変の)属性の組み合わせであるビジネスキーを使ってくだ"
+"さい。もし、一時オブジェクトが永続化された場合、データベース識別子が変わりま"
+"す。一時オブジェクトを(通常分離インスタンスと共に) <literal>Set</literal> "
+"に保持する場合、ハッシュコードが変わるということは、 <literal>Set</literal> "
+"の契約を破るということです。ビジネスキーのための属性は、データベースの主キー"
+"ほど安定すべきではないです。オブジェクトが同じ <literal>Set</literal> の中に"
+"いる間だけ、安定を保証すべきです。この問題のより徹底的な議論は、 Hibernate "
+"の Web サイトを参照してください。また、これは Hibernate の問題ではなく、単に "
+"Java オブジェクトの識別子や等価性をどのように実装すべきかということです。"
 
 #. Tag: title
-#: transactions.xml:334
 #, no-c-format
 msgid "Common issues"
 msgstr "一般的な問題"
 
 #. Tag: para
-#: transactions.xml:336
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not use the anti-patterns <emphasis>session-per-user-session</emphasis> "
 "or <emphasis>session-per-application</emphasis> (there are, however, rare "
@@ -607,13 +572,12 @@
 "implications before making a design decision:"
 msgstr ""
 "<emphasis>session-per-user-session</emphasis> と <emphasis>session-per-"
-"application</emphasis> アンチパターン は使ってはいけません(もちろん、まれに"
-"例外があります)。 注意:下記の問題のいくつかは、推奨されるパターンとしても出"
-"現します。 設計を決定する前に、裏の意味を理解するようにしてください。"
+"application</emphasis> アンチパターンは使ってはいけません(もちろん、まれに例"
+"外があります)。注記:下記の問題のいくつかは、推奨されるパターンとしても出現"
+"します。設計を決定する前に、裏の意味を理解するようにしてください。"
 
 #. Tag: para
-#: transactions.xml:345
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>Session</literal> is not thread-safe. Things that work "
 "concurrently, like HTTP requests, session beans, or Swing workers, will "
@@ -624,18 +588,17 @@
 "that clicks reload fast enough can use the same <literal>Session</literal> "
 "in two concurrently running threads."
 msgstr ""
-"<literal>Session</literal> はスレッドセーフではありません。 HTTPリクエスト、"
-"セッションBean、Swingワーカーのように、 同時実行が可能なものが "
-"<literal>Session</literal> インスタンスを共有すると、 競合状態を引き起こしま"
-"す。 (後で議論する)<literal>HttpSession</literal> の中で Hibernate "
-"<literal>Session</literal> を保持する場合、 HttpSessionへのアクセスを同期化す"
-"ることを考慮すべきです。 さもなければ、ユーザーが十分早くリロードをクリックす"
-"ると、 同時に走る2つのスレッドの中で、同じ <literal>Session</literal> が使わ"
-"れます。"
+"<literal>Session</literal> はスレッドセーフではありません。 HTTP リクエスト、"
+"セッション Bean 、 Swing ワーカーのように、同時実行が可能なものが "
+"<literal>Session</literal> インスタンスを共有すると、競合状態を引き起こしま"
+"す。(後で議論する) <literal>HttpSession</literal> の中で Hibernate "
+"<literal>Session</literal> を保持する場合、 HttpSession へのアクセスを同期化"
+"することを考慮すべきです。さもなければ、ユーザーが十分早くリロードをクリック"
+"すると、同時に走る2つのスレッドの中で、同じ <literal>Session</literal> が使"
+"われます。"
 
 #. Tag: para
-#: transactions.xml:356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An exception thrown by Hibernate means you have to rollback your database "
 "transaction and close the <literal>Session</literal> immediately (this is "
@@ -647,17 +610,16 @@
 "Usually this is not a problem, because exceptions are not recoverable and "
 "you will have to start over after rollback anyway."
 msgstr ""
-"Hibernateが例外を投げた場合は、データベーストランザクションをロールバック"
-"し、 直ちに <literal>Session</literal> を閉じるべきです(詳細を後で議論しま"
-"す)。 <literal>Session</literal> がアプリケーションに結び付けられているので"
-"あれば、 アプリケーションを停止すべきです。 データベーストランザクションを"
-"ロールバックしても、ビジネスオブジェクトは トランザクションを開始したときの状"
-"態に戻りません。 これは、データベースの状態とビジネスオブジェクトは同期してい"
-"ないことを意味します。 通常これは問題になりません。 なぜなら、例外は回復でき"
-"ないからです。 とにかくロールバックした後にやり直すべきです。"
+"Hibernate が例外を投げた場合は、データベーストランザクションをロールバック"
+"し、直ちに <literal>Session</literal> を閉じるべきです (詳細を後で議論しま"
+"す) 。 <literal>Session</literal> がアプリケーションに結び付けられているので"
+"あれば、アプリケーションを停止すべきです。データベーストランザクションをロー"
+"ルバックしても、ビジネスオブジェクトはトランザクションを開始したときの状態に"
+"戻りません。これは、データベースの状態とビジネスオブジェクトは同期していない"
+"ことを意味します。通常これは問題になりません。なぜなら、例外は回復できないか"
+"らです。とにかくロールバックした後にやり直すべきです。"
 
 #. Tag: para
-#: transactions.xml:368
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>Session</literal> caches every object that is in a persistent "
@@ -666,31 +628,28 @@
 "until you get an OutOfMemoryException. One solution is to call <literal>clear"
 "()</literal> and <literal>evict()</literal> to manage the <literal>Session</"
 "literal> cache, but you should consider a Stored Procedure if you need mass "
-"data operations. Some solutions are shown in <xref linkend=\"batch\"/>. "
+"data operations. Some solutions are shown in <xref linkend=\"batch\" />. "
 "Keeping a <literal>Session</literal> open for the duration of a user session "
 "also means a higher probability of stale data."
 msgstr ""
-"<literal>Session</literal> は永続(persistent)状態のすべてのオブジェクトを "
-"キャッシュします(Hibernateは監視し、ダーティ状態かチェックします)。 これ"
-"は、長い間セッションを開いたままにするか、 非常に多くのデータをロードし続ける"
-"かした場合は、 OutOfMemoryExceptionが発生するまで無限に大きくなることを意味し"
-"ます。 解決策の1つは、<literal>Session</literal> キャッシュを管理するため"
+"<literal>Session</literal> は永続 (persistent) 状態のすべてのオブジェクトを"
+"キャッシュします( Hibernate は監視し、ダーティ状態かチェックします)。これ"
+"は、長い間セッションを開いたままにするか、非常に多くのデータをロードし続ける"
+"かした場合は、 OutOfMemoryException が発生するまで無限に大きくなることを意味"
+"します。解決策の1つは、<literal>Session</literal> キャッシュを管理するため"
 "に、 <literal>clear()</literal> か <literal>evict()</literal> を呼ぶことで"
-"す。 しかし、大きなデータを処理する必要があるなら、 たぶんストアドプロシー"
-"ジャを考慮するべきでしょう。 いくつかの解決策は、<xref linkend=\"batch\"/> で"
-"紹介されています。 ユーザーセッションの間、<literal>Session</literal> を開い"
-"たままにするということは、 データが新鮮でなくなる確率が高くなることを意味しま"
-"す。"
+"す。しかし、大きなデータを処理する必要があるなら、たぶんストアドプロシージャ"
+"を考慮するべきでしょう。いくつかの解決策は、 <xref linkend=\"batch\"/> で紹介"
+"されています。ユーザーセッションの間、 <literal>Session</literal> を開いたま"
+"まにするということは、データが新鮮でなくなる確率が高くなることを意味します。"
 
 #. Tag: title
-#: transactions.xml:386
 #, no-c-format
 msgid "Database transaction demarcation"
 msgstr "データベーストランザクション境界"
 
 #. Tag: para
-#: transactions.xml:388
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Database, or system, transaction boundaries are always necessary. No "
 "communication with the database can occur outside of a database transaction "
@@ -701,18 +660,17 @@
 "transactions explicitly. Certainly, a single database transaction is going "
 "to perform better than many small transactions, even for reading data."
 msgstr ""
-"データベース(もしくはシステム)トランザクションの境界は、常に必要です。 デー"
-"タベーストランザクションの外で、データベースとの通信は起きません (これは自動"
-"コミットモードに慣れている多くの開発者を混乱させるかもしれません)。 読み込む"
-"だけの操作にでも、いつも明確なトランザクション境界を使用してください。 分離レ"
-"ベルとデータベースの能力次第で、これは必要ないかもしれませんが、 常にトランザ"
-"クション境界を明示的に指定しても、マイナス面は全くありません。 確かに、1つの"
-"データベーストランザクションは多数の小さなトランザクションより (データの読み"
-"込みであっても)パフォーマンスがすぐれています。"
+"データベース (もしくはシステム) トランザクションの境界は、常に必要です。"
+"データベーストランザクションの外で、データベースとの通信は起きません (これは"
+"自動コミットモードに慣れている多くの開発者を混乱させるかもしれません) 。読み"
+"込むだけの操作にでも、いつも明確なトランザクション境界を使用してください。分"
+"離レベルとデータベースの能力次第で、これは必要ないかもしれませんが、常にトラ"
+"ンザクション境界を明示的に指定しても、マイナス面は全くありません。確かに、1"
+"つのデータベーストランザクションは多数の小さなトランザクションより (データの"
+"読み込みであっても) パフォーマンスがすぐれています。"
 
 #. Tag: para
-#: transactions.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A Hibernate application can run in non-managed (i.e., standalone, simple "
 "Web- or Swing applications) and managed J2EE environments. In a non-managed "
@@ -724,20 +682,19 @@
 "descriptors of EJB session beans, for example). Programmatic transaction "
 "demarcation is then no longer necessary."
 msgstr ""
-"J2EE環境に管理されていない状態 (すなわち、スタンドアロン、単純なWebやSwingア"
-"プリケーション)でも、 管理された状態でも、Hibernateアプリケーションを実行で"
-"きます。 管理されていない環境では、Hiberanteがデータベースのコネクションプー"
-"ルを提供します。 アプリケーション開発者は、トランザクション境界を手動で設定し"
-"なければなりません。 言い換えると、データベーストランザクションの開始、コミッ"
-"ト、ロールバックを 開発者自身が設定する必要があるということです。 通常、管理"
-"された環境では、コンテナ管理によるトランザクション(CMT)が提供されます。 例"
-"えば、セッションBeanのデプロイメントディスクリプタで宣言的に定義し、 トランザ"
-"クションを組み立てます。 プログラムによるトランザクション境界はもう必要ありま"
-"せん。"
+"J2EE 環境に管理されていない状態 (すなわち、スタンドアロン、単純な Web や "
+"Swing アプリケーション)でも、管理された状態でも、 Hibernate アプリケーション"
+"を実行できます。管理されていない環境では、 Hiberante がデータベースのコネク"
+"ションプールを提供します。アプリケーション開発者は、トランザクション境界を手"
+"動で設定しなければなりません。言い換えると、データベーストランザクションの開"
+"始、コミット、ロールバックを開発者自身が設定する必要があるということです。通"
+"常、管理された環境では、コンテナ管理によるトランザクション (CMT) が提供され"
+"ます。例えば、セッション Bean のデプロイメントディスクリプタで宣言的に定義"
+"し、トランザクションを組み立てます。プログラムによるトランザクション境界はも"
+"う必要ありません。"
 
 #. Tag: para
-#: transactions.xml:408
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, it is often desirable to keep your persistence layer portable "
 "between non-managed resource-local environments, and systems that can rely "
@@ -747,103 +704,71 @@
 "system of your deployment environment. This API is actually optional, but we "
 "strongly encourage its use unless you are in a CMT session bean."
 msgstr ""
-"しかしながら、管理されていないリソース・ローカルな環境と JTAに依存したシステ"
-"ム(CMTではなくBMT)の両方に、 永続化層をポータブルに保つのは、しばしば望まし"
-"いことです。 デプロイ環境のネイティブのトランザクションシステムを呼び出す "
-"<literal>Transaction</literal> というラッパーAPIをHibernateが提供します。 こ"
-"のAPIを使うかは任意ですが、CMTのセッションBeanを使わないのであれば、使うこと"
-"を強く推奨します。"
+"しかしながら、管理されていないリソースローカルな環境と JTA に依存したシステ"
+"ム (CMT ではなく BMT) の両方に、永続化層をポータブルに保つのは、しばしば望"
+"ましいことです。デプロイ環境のネイティブのトランザクションシステムを呼び出す "
+"<literal>Transaction</literal> というラッパー API を Hibernate が提供します。"
+"この API を使うかは任意ですが、 CMT のセッション Bean を使わないのであれば、"
+"使うことを強く推奨します。"
 
 #. Tag: para
-#: transactions.xml:417
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Ending a <literal>Session</literal> usually involves four distinct phases:"
 msgstr ""
-"通常、<literal>Session</literal> 終了は、4つの異なるフェーズを含みます。"
+"通常、 <literal>Session</literal> 終了は、4つの異なるフェーズを含みます:"
 
 #. Tag: para
-#: transactions.xml:423
 #, no-c-format
 msgid "flush the session"
 msgstr "セッションのフラッシュ"
 
 #. Tag: para
-#: transactions.xml:428
 #, no-c-format
 msgid "commit the transaction"
 msgstr "トランザクションのコミット"
 
 #. Tag: para
-#: transactions.xml:433
 #, no-c-format
 msgid "close the session"
 msgstr "セッションのクローズ"
 
 #. Tag: para
-#: transactions.xml:438
 #, no-c-format
 msgid "handle exceptions"
 msgstr "例外のハンドリング"
 
 #. Tag: para
-#: transactions.xml:444
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We discussed Flushing the session earlier, so we will now have a closer look "
 "at transaction demarcation and exception handling in both managed and non-"
 "managed environments."
 msgstr ""
-"セッションのフラッシュについては、前のほうですでに議論しました。 管理された環"
-"境と管理されていない環境の両方について、 トランザクション境界と例外ハンドリン"
-"グをもっと詳しく見ていきましょう。"
+"セッションのフラッシュについては、前の方で既に議論しました。管理された環境と"
+"管理されていない環境の両方について、トランザクション境界と例外ハンドリングを"
+"もっと詳しく見ていきましょう。"
 
 #. Tag: title
-#: transactions.xml:451
 #, no-c-format
 msgid "Non-managed environment"
 msgstr "管理されていない環境"
 
 #. Tag: para
-#: transactions.xml:453
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If a Hibernate persistence layer runs in a non-managed environment, database "
 "connections are usually handled by simple (i.e., non-DataSource) connection "
 "pools from which Hibernate obtains connections as needed. The session/"
 "transaction handling idiom looks like this:"
 msgstr ""
-"Hibernate永続化層を管理されていない環境で実装する場合は、 通常単純なコネク"
-"ションプール(すなわちDataSourceではない)によって、 データベースコネクション"
-"を制御します。 Hibernateはそのコネクションプールから必要なコネクションを取得"
-"します。 セッション/トランザクション制御のイディオムは次のようになります。"
+"Hibernate 永続化層を管理されていない環境で実装する場合は、通常単純なコネク"
+"ションプール (すなわち DataSource ではない) によって、データベースコネク"
+"ションを制御します。 Hibernate はそのコネクションプールから必要なコネクション"
+"を取得します。セッション/トランザクション制御のイディオムは次のようになりま"
+"す:"
 
-#. Tag: programlisting
-#: transactions.xml:460
-#, no-c-format
-msgid ""
-"<![CDATA[// Non-managed environment idiom\n"
-"Session sess = factory.openSession();\n"
-"Transaction tx = null;\n"
-"try {\n"
-"    tx = sess.beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    if (tx != null) tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:462
 #, fuzzy, no-c-format
 msgid ""
 "You do not have to <literal>flush()</literal> the <literal>Session</literal> "
@@ -856,46 +781,25 @@
 msgstr ""
 "明示的に <literal>Session</literal> の <literal>flush()</literal> を呼び出す"
 "べきではなく、 <literal>commit()</literal> を呼び出すことにより、自動的に同期"
-"化処理が実行されます (セッションの <xref linkend=\"objectstate-flushing"
-"\">FlushMode</xref> に依存している)。 <literal>close()</literal> を呼び出す"
-"ことにより、セッションの終わりを明確にします。 <literal>close()</literal> が"
-"暗黙的に行う主なことは、 セッションがJDBCコネクションを開放することです。 上"
-"記のJavaコードはポータブルであり、管理されていない環境とJTA環境の両方で実行で"
+"化処理が実行されます (セッションの <xref linkend=\"objectstate-flushing\"/> "
+"FlushMode に依存している)。 <literal>close()</literal> を呼び出すことによ"
+"り、セッションの終わりを明確にします。 <literal>close()</literal> が暗黙的に"
+"行う主なことは、セッションが JDBC コネクションを開放することです。上記の "
+"Java コードはポータブルであり、管理されていない環境と JTA 環境の両方で実行で"
 "きます。"
 
 #. Tag: para
-#: transactions.xml:471
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As outlined earlier, a much more flexible solution is Hibernate's built-in "
 "\"current session\" context management:"
 msgstr ""
-"より適応性のある解決策は、Hibernateに予め組み込まれている 「current session」"
-"コンテキスト管理です。 言葉で説明するより下記を見たほうが速いでしょう。"
+"より適応性のある解決策は、 Hibernate に予め組み込まれている \"current session"
+"\" コンテキスト管理です。言葉で説明するより下記を見たほうが速いでしょう。"
 
-#. Tag: programlisting
-#: transactions.xml:476
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// Non-managed environment idiom with getCurrentSession()\n"
-"try {\n"
-"    factory.getCurrentSession().beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    factory.getCurrentSession().getTransaction().commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    factory.getCurrentSession().getTransaction().rollback();\n"
-"    throw e; // or display error message\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:478
-#, fuzzy, no-c-format
-msgid ""
 "You will not see these code snippets in a regular application; fatal "
 "(system) exceptions should always be caught at the \"top\". In other words, "
 "the code that executes Hibernate calls in the persistence layer, and the "
@@ -906,37 +810,34 @@
 "this chapter."
 msgstr ""
 "正規のアプリケーションの中では、このようなコードの切れ端を決して見ないでしょ"
-"う。 致命的な(システム)例外は、常に「最上位」でキャッチすべきです。 言い換"
-"えれば、(永続化層で)Hibernate呼び出しを実行するコードと、 "
+"う。致命的な (システム) 例外は、常に「最上位」でキャッチすべきです。言い換"
+"えれば、 (永続化層で) Hibernate 呼び出しを実行するコードと、 "
 "<literal>RuntimeException</literal> を制御する (通常はクリーンアップと終了の"
-"み行うことができる)コードは、別々の層の中にあります。 Hibernateによるカレン"
-"トコンテキスト管理は、この設計をかなり単純にします。 必要なのは、"
-"<literal>SessionFactory</literal> にアクセスすることだけです。 例外処理は、こ"
+"み行うことができる) コードは、別々の層の中にあります。 Hibernate によるカレ"
+"ントコンテキスト管理は、この設計をかなり単純にします。必要なのは、 "
+"<literal>SessionFactory</literal> にアクセスすることだけです。例外処理は、こ"
 "の章の後のほうで議論します。"
 
 #. Tag: para
-#: transactions.xml:488
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You should select <literal>org.hibernate.transaction.JDBCTransactionFactory</"
 "literal>, which is the default, and for the second example select <literal>"
 "\"thread\"</literal> as your <literal>hibernate."
 "current_session_context_class</literal>."
 msgstr ""
-"注意:(デフォルトですが) <literal>org.hibernate.transaction."
-"JDBCTransactionFactory</literal> を選択するべきです。 第2の用例としては、 "
+"注記:(デフォルトですが) <literal>org.hibernate.transaction."
+"JDBCTransactionFactory</literal> を選択するべきです。第2の用例としては、 "
 "<literal>hibernate.current_session_context_class</literal> ã‚’ <literal>"
 "\"thread\"</literal> とするとよいでしょう。"
 
 #. Tag: title
-#: transactions.xml:497
 #, no-c-format
 msgid "Using JTA"
-msgstr "JTAを使用する"
+msgstr "JTA を使用する"
 
 #. Tag: para
-#: transactions.xml:499
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your persistence layer runs in an application server (for example, behind "
 "EJB session beans), every datasource connection obtained by Hibernate will "
@@ -944,113 +845,50 @@
 "standalone JTA implementation and use it without EJB. Hibernate offers two "
 "strategies for JTA integration."
 msgstr ""
-"永続化層をアプリケーションサーバー(例えば、EJBセッションBeanの背後)で実行す"
-"る場合、 Hibernateから取得するすべてのデータソースコネクションは、 自動的にグ"
-"ローバルJTAトランザクションの一部になります。 EJBを使わずに、スタンドアロンの"
-"JTA実装を導入することもできます。 JTA統合のために、Hibernateは2つの戦略を提"
-"供します。"
+"永続化層をアプリケーションサーバー (例えば、 EJB セッション Bean の背後) で"
+"実行する場合、 Hibernate から取得するすべてのデータソースコネクションは、自動"
+"的にグローバル JTA トランザクションの一部になります。 EJB を使わずに、スタン"
+"ドアロンの JTA 実装を導入することもできます。 JTA 統合のために、 Hibernate は"
+"2つの戦略を提供します。"
 
 #. Tag: para
-#: transactions.xml:506
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you use bean-managed transactions (BMT), Hibernate will tell the "
 "application server to start and end a BMT transaction if you use the "
 "<literal>Transaction</literal> API. The transaction management code is "
 "identical to the non-managed environment."
 msgstr ""
-"Bean管理トランザクション(BMT)を使い、<literal>Transaction</literal> APIを使"
-"う場合、 HibernateはアプリケーションサーバーにBMTトランザクションの開始と終わ"
-"りを告げます。 すなわち、トランザクション管理のコードは、管理されない環境と同"
-"じになります。"
+"Bean 管理トランザクション(BMT)を使い、 <literal>Transaction</literal> API "
+"を使う場合、 Hibernate はアプリケーションサーバーに BMT トランザクションの開"
+"始と終わりを告げます。すなわち、トランザクション管理のコードは、管理されない"
+"環境と同じになります。"
 
-#. Tag: programlisting
-#: transactions.xml:512
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// BMT idiom\n"
-"Session sess = factory.openSession();\n"
-"Transaction tx = null;\n"
-"try {\n"
-"    tx = sess.beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    if (tx != null) tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:514
-#, fuzzy, no-c-format
-msgid ""
 "If you want to use a transaction-bound <literal>Session</literal>, that is, "
 "the <literal>getCurrentSession()</literal> functionality for easy context "
 "propagation, use the JTA <literal>UserTransaction</literal> API directly:"
 msgstr ""
-"トランザクション境界として <literal>Session</literal> を使いたい場合、 簡単に"
+"トランザクション境界として <literal>Session</literal> を使いたい場合、簡単に"
 "コンテキストを伝播する機能である <literal>getCurrentSession()</literal> があ"
-"るので、 JTAの <literal>UserTransaction</literal> APIを直接使用すべきでしょ"
+"るので、 JTAの <literal>UserTransaction</literal> API を直接使用すべきでしょ"
 "う。"
 
-#. Tag: programlisting
-#: transactions.xml:520
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// BMT idiom with getCurrentSession()\n"
-"try {\n"
-"    UserTransaction tx = (UserTransaction)new InitialContext()\n"
-"                            .lookup(\"java:comp/UserTransaction\");\n"
-"\n"
-"    tx.begin();\n"
-"\n"
-"    // Do some work on Session bound to transaction\n"
-"    factory.getCurrentSession().load(...);\n"
-"    factory.getCurrentSession().persist(...);\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:522
-#, fuzzy, no-c-format
-msgid ""
 "With CMT, transaction demarcation is completed in session bean deployment "
 "descriptors, not programmatically. The code is reduced to:"
 msgstr ""
-"CMTでは、トランザクション境界をセッションBeanのデプロイメントディスクリプタで"
-"定義し、 プログラムでは行いません。 ゆえに、コードは次のように少なくなりま"
-"す。"
+"CMT では、トランザクション境界をセッション Bean のデプロイメントディスクリプ"
+"タで定義し、プログラムでは行いません。ゆえに、コードは次のように少なくなりま"
+"す:"
 
-#. Tag: programlisting
-#: transactions.xml:527
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// CMT idiom\n"
-" Session sess = factory.getCurrentSession();\n"
-"\n"
-" // do some work\n"
-" ...\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:529
-#, fuzzy, no-c-format
-msgid ""
 "In a CMT/EJB, even rollback happens automatically. An unhandled "
 "<literal>RuntimeException</literal> thrown by a session bean method tells "
 "the container to set the global transaction to rollback. <emphasis>You do "
@@ -1058,16 +896,16 @@
 "BMT or CMT, and you get automatic propagation of the \"current\" Session "
 "bound to the transaction.</emphasis>"
 msgstr ""
-"CMT/EJBの中では、常にロールバックが自動的に実施されます。 なぜなら、セッショ"
-"ンビーンのメソッドにより投げられた制御されていない "
-"<literal>RuntimeException</literal> は、グローバルトランザクションを ロール"
-"バックするようにコンテナに伝えるためです。 <emphasis>これは、BMTもしくはCMTと"
-"いっしょにHibernate <literal>Transaction</literal> APIを使う必要は少しもない"
-"という意味です。</emphasis>"
+"CMT/EJB の中では、常にロールバックが自動的に実施されます。なぜなら、セッショ"
+"ン Bean のメソッドにより投げられた制御されていない "
+"<literal>RuntimeException</literal> は、グローバルトランザクションをロール"
+"バックするようにコンテナに伝えるためです。 <emphasis>これは、 BMT もしくは "
+"CMT と一緒に Hibernate <literal>Transaction</literal> API を使う必要はまった"
+"くないということを意味し、トランザクションにバインドする「現在の」セッション"
+"を自動伝搬できます。</emphasis>"
 
 #. Tag: para
-#: transactions.xml:537
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When configuring Hibernate's transaction factory, choose <literal>org."
 "hibernate.transaction.JTATransactionFactory</literal> if you use JTA "
@@ -1077,18 +915,17 @@
 "your <literal>hibernate.current_session_context_class</literal> is either "
 "unset (backwards compatibility), or is set to <literal>\"jta\"</literal>."
 msgstr ""
-"Hibernateのトランザクションファクトリを設定する際に、 JTAを直接使う(BMTの)"
-"場合は <literal>org.hibernate.transaction.JTATransactionFactory</literal> "
-"を、 CMTセッションビーンの中では <literal>org.hibernate.transaction."
-"CMTTransactionFactory</literal> を 選択すべきだということに注意してくださ"
-"い。 <literal>hibernate.transaction.manager_lookup_class</literal> をセットす"
-"ることも思い出してください。 なお、<literal>hibernate."
-"current_session_context_class</literal> は、 セットしないか(後方互換)、"
+"Hibernate のトランザクションファクトリを設定する際に、 JTA を直接使う (BMT"
+"の) 場合は <literal>org.hibernate.transaction.JTATransactionFactory</"
+"literal> を、 CMT セッション Bean の中では <literal>org.hibernate."
+"transaction.CMTTransactionFactory</literal> を選択すべきだということに注意し"
+"てください。 <literal>hibernate.transaction.manager_lookup_class</literal> を"
+"セットすることも思い出してください。なお、 <literal>hibernate."
+"current_session_context_class</literal> は、セットしないか(後方互換)、 "
 "<literal>\"jta\"</literal> をセットしてください。"
 
 #. Tag: para
-#: transactions.xml:546
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>getCurrentSession()</literal> operation has one downside in a "
 "JTA environment. There is one caveat to the use of <literal>after_statement</"
@@ -1103,28 +940,26 @@
 "using <literal>scroll()</literal> or <literal>iterate()</literal> from the "
 "JTA or CMT code.)"
 msgstr ""
-"<literal>getCurrentSession()</literal> オペレーションは、JTA環境では1つの欠"
-"点を持ちます。 デフォルトで使われる <literal>after_statement</literal> コネク"
-"ションリリースモードを使用する上で、 警告が1つあります。 JTA仕様の愚かな制約"
-"のために、 <literal>scroll()</literal> または <literal>iterate()</literal> が"
-"返した、 閉じられていない <literal>ScrollableResults</literal> または "
-"<literal>Iterator</literal> インスタンスをHibernateが自動的にクリーンアップす"
-"ることはできません。 <literal>finally</literal> ブロックの中で、 "
+"<literal>getCurrentSession()</literal> オペレーションは、 JTA 環境では1つの"
+"欠点を持ちます。デフォルトで使われる <literal>after_statement</literal> コネ"
+"クションリリースモードを使用する上で、警告が1つあります。 JTA 仕様の愚かな制"
+"約のために、 <literal>scroll()</literal> または <literal>iterate()</literal> "
+"が返した、閉じられていない <literal>ScrollableResults</literal> または "
+"<literal>Iterator</literal> インスタンスを Hibernate が自動的にクリーンアップ"
+"することはできません。 <literal>finally</literal> ブロックの中で、 "
 "<literal>ScrollableResults.close()</literal> または <literal>Hibernate.close"
-"(Iterator)</literal> を明示的に呼び出して、 裏に潜んだデータベースカーソルを"
-"解放 <emphasis>しなければなりません</emphasis>。 (もちろん、多くのアプリケー"
-"ションでは、JTAかCMTコードで <literal>scroll()</literal> や <literal>iterate"
-"()</literal> の使用を避けるのは容易です。)"
+"(Iterator)</literal> を明示的に呼び出して、裏に潜んだデータベースカーソルを解"
+"放 <emphasis>しなければなりません</emphasis>。 (もちろん、多くのアプリケー"
+"ションでは、 JTA か CMT コードで <literal>scroll()</literal> や "
+"<literal>iterate()</literal> の使用を避けるのは容易です。)"
 
 #. Tag: title
-#: transactions.xml:562
 #, no-c-format
 msgid "Exception handling"
 msgstr "例外ハンドリング"
 
 #. Tag: para
-#: transactions.xml:564
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the <literal>Session</literal> throws an exception, including any "
 "<literal>SQLException</literal>, immediately rollback the database "
@@ -1135,18 +970,17 @@
 "Ensure that the <literal>Session</literal> will be closed by calling "
 "<literal>close()</literal> in a <literal>finally</literal> block."
 msgstr ""
-"<literal>Session</literal> が例外(<literal>SQLException</literal>を含む)を"
-"投げた場合、 直ちに、データベーストランザクションをロールバックし、"
-"<literal>Session.close()</literal> を呼び、<literal>Session</literal> インス"
-"タンスを破棄すべきです。 <literal>Session</literal> のいくつかのメソッドは、 "
-"セッションの状態を <emphasis>矛盾したまま</emphasis> にします。 Hibernateが投"
-"げた例外を、回復できるものとして扱うことはできません。 <literal>finally</"
+"<literal>Session</literal> が例外 (<literal>SQLException</literal>を含む) "
+"を投げた場合、直ちに、データベーストランザクションをロールバックし、 "
+"<literal>Session.close()</literal> を呼び、 <literal>Session</literal> インス"
+"タンスを破棄すべきです。 <literal>Session</literal> のいくつかのメソッドは、"
+"セッションの状態を <emphasis>矛盾したまま</emphasis> にします。 Hibernate が"
+"投げた例外を、回復できるものとして扱うことはできません。 <literal>finally</"
 "literal> ブロックの中で <literal>close()</literal> を呼んで、 "
 "<literal>Session</literal> を確実に閉じてください。"
 
 #. Tag: para
-#: transactions.xml:575
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>HibernateException</literal>, which wraps most of the errors "
 "that can occur in a Hibernate persistence layer, is an unchecked exception. "
@@ -1159,19 +993,18 @@
 "unchecked exceptions that are not a <literal>HibernateException</literal>. "
 "These are not recoverable and appropriate action should be taken."
 msgstr ""
-"<literal>HibernateException</literal> は、Hibernate永続化層の中で発生する多く"
-"のエラーを ラップする、検査されない例外です(Hibernateの古いバージョンは違い"
-"ました)。 私たちの意見は、アプリケーション開発者に回復不可能な例外を 下層で"
-"キャッチすることを強要すべきではないということです。 多くのシステムでは、検査"
-"されない例外と致命的な例外は、 コールスタックの最初のフレームの1つ(例えば、"
-"最上位の層で)でハンドリングし、 エラーメッセージをアプリケーションユーザーに"
-"表示します (もしくは、他の適切な処理を実施します)。 Hibernateは、"
-"<literal>HibernateException</literal> 以外の検査されない例外も 投げることに注"
-"意してください。 これらもまた、回復不可能であり、適切な処理を実施すべきです。"
+"<literal>HibernateException</literal> は、 Hibernate 永続化層の中で発生する多"
+"くのエラーをラップする、検査されない例外です ( Hibernate の古いバージョンは"
+"違いました) 。私たちの意見は、アプリケーション開発者に回復不可能な例外を下層"
+"でキャッチすることを強要すべきではないということです。多くのシステムでは、検"
+"査されない例外と致命的な例外は、コールスタックの最初のフレームの1つ (例え"
+"ば、最上位の層で) でハンドリングし、エラーメッセージをアプリケーションユー"
+"ザーに表示します (もしくは、他の適切な処理を実施します) 。 Hibernate は、"
+"<literal>HibernateException</literal> 以外の検査されない例外も投げることに注"
+"意してください。これらもまた、回復不可能であり、適切な処理を実施すべきです。"
 
 #. Tag: para
-#: transactions.xml:587
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate wraps <literal>SQLException</literal>s thrown while interacting "
 "with the database in a <literal>JDBCException</literal>. In fact, Hibernate "
@@ -1188,43 +1021,40 @@
 "class for details. The standard <literal>JDBCException</literal> subtypes "
 "are:"
 msgstr ""
-"Hibernateは、データベースとの対話中に投げられた <literal>SQLException</"
-"literal> を <literal>JDBCException</literal> でラップします。 実は、例外をよ"
-"り意味のある <literal>JDBCException</literal> のサブクラスに 変換しようと試み"
-"ます。 元の <literal>SQLException</literal> は、<literal>JDBCException."
-"getCause()</literal> によりいつでも得られます。 Hibernateは、"
+"Hibernate は、データベースとの対話中に投げられた <literal>SQLException</"
+"literal> を <literal>JDBCException</literal> でラップします。実は、例外をより"
+"意味のある <literal>JDBCException</literal> のサブクラスに変換しようと試みま"
+"す。元の <literal>SQLException</literal> は、 <literal>JDBCException.getCause"
+"()</literal> によりいつでも得られます。 Hibernate は、 "
 "<literal>SessionFactory</literal> に追加されている "
-"<literal>SQLExceptionConverter</literal> を使い、<literal>SQLException</"
-"literal> を 適当な <literal>JDBCException</literal> サブクラスに変換します。 "
-"デフォルトでは、<literal>SQLExceptionConverter</literal> は設定されているSQL"
-"方言により 定義されます。 一方で、独自の実装に差し替えることもできます (詳細"
-"は、<literal>SQLExceptionConverterFactory</literal> クラスのJavadocを参照して"
-"ください)。 標準的な <literal>JDBCException</literal> のサブタイプを下記に示"
-"します。"
+"<literal>SQLExceptionConverter</literal> を使い、 <literal>SQLException</"
+"literal> を適当な <literal>JDBCException</literal> サブクラスに変換します。デ"
+"フォルトでは、 <literal>SQLExceptionConverter</literal> は設定されている SQL "
+"方言により定義されます。一方で、独自の実装に差し替えることもできます (詳細"
+"は、 <literal>SQLExceptionConverterFactory</literal> クラスの Javadoc を参照"
+"してください)。標準的な <literal>JDBCException</literal> のサブタイプを下記"
+"に示します。"
 
 #. Tag: para
-#: transactions.xml:603
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>JDBCConnectionException</literal>: indicates an error with the "
 "underlying JDBC communication."
 msgstr ""
-"<literal>JDBCConnectionException</literal> - 基礎となるJDBC通信のエラーを表し"
-"ます。"
+"<literal>JDBCConnectionException</literal> - 基礎となる JDBC 通信のエラーを表"
+"します。"
 
 #. Tag: para
-#: transactions.xml:609
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>SQLGrammarException</literal>: indicates a grammar or syntax "
 "problem with the issued SQL."
 msgstr ""
-"<literal>SQLGrammarException</literal> - 発行するSQLの文法もしくは構文の問題"
-"を表します。"
+"<literal>SQLGrammarException</literal> - 発行する SQL の文法もしくは構文の問"
+"題を表します。"
 
 #. Tag: para
-#: transactions.xml:615
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ConstraintViolationException</literal>: indicates some form of "
 "integrity constraint violation."
@@ -1233,8 +1063,7 @@
 "反を表します。"
 
 #. Tag: para
-#: transactions.xml:621
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockAcquisitionException</literal>: indicates an error acquiring a "
 "lock level necessary to perform the requested operation."
@@ -1243,8 +1072,7 @@
 "要なロックレベルを得る際のエラーを表します。"
 
 #. Tag: para
-#: transactions.xml:627
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>GenericJDBCException</literal>: a generic exception which did not "
 "fall into any of the other categories."
@@ -1253,14 +1081,12 @@
 "な例外です。"
 
 #. Tag: title
-#: transactions.xml:637
 #, no-c-format
 msgid "Transaction timeout"
 msgstr "トランザクションのタイムアウト"
 
 #. Tag: para
-#: transactions.xml:639
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An important feature provided by a managed environment like EJB, that is "
 "never provided for non-managed code, is transaction timeout. Transaction "
@@ -1273,61 +1099,33 @@
 "transaction timeout to JTA. This functionality is abstracted by the "
 "Hibernate <literal>Transaction</literal> object."
 msgstr ""
-"EJBのような管理された環境が提供するきわめて重要な特徴の1つは、 トランザク"
-"ションのタイムアウトです。 これは管理されていないコードには提供できません。 "
-"トランザクションタイムアウトは、不品行なトランザクションが ユーザーにレスポン"
-"スを返さないまま、無期限にリソースを使い続けない ことを保障します。 管理され"
-"た環境(JTA)の外では、Hibernateはこの機能をフルに提供できません。 しかしなが"
-"ら、Hibernateは次のようなデータアクセス操作の制御くらいはできます。 データ"
-"ベースレベルのデッドロックや大きなリザルトセットを返すクエリを 定義されたタイ"
-"ムアウトによって確実に制限します。 管理された環境では、Hibernateはトランザク"
-"ションタイムアウトをJTAに委譲します。 この機能は、Hibernateの "
-"<literal>Transaction</literal> オブジェクトに よって抽象化されています。"
+"EJB のような管理された環境が提供するきわめて重要な特徴の1つは、トランザク"
+"ションのタイムアウトです。これは管理されていないコードには提供できません。ト"
+"ランザクションタイムアウトは、不品行なトランザクションがユーザーにレスポンス"
+"を返さないまま、無期限にリソースを使い続けないことを保障します。管理された環"
+"境 (JTA) の外では、 Hibernate はこの機能をフルに提供できません。しかしなが"
+"ら、 Hibernate は次のようなデータアクセス操作の制御くらいはできます。データ"
+"ベースレベルのデッドロックや大きなリザルトセットを返すクエリを定義されたタイ"
+"ムアウトによって確実に制限します。管理された環境では、 Hibernate はトランザク"
+"ションタイムアウトを JTA に委譲します。この機能は、 Hibernate の "
+"<literal>Transaction</literal> オブジェクトによって抽象化されています。"
 
-#. Tag: programlisting
-#: transactions.xml:652
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"Session sess = factory.openSession();\n"
-"try {\n"
-"    //set transaction timeout to 3 seconds\n"
-"    sess.getTransaction().setTimeout(3);\n"
-"    sess.getTransaction().begin();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    sess.getTransaction().commit()\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    sess.getTransaction().rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:654
-#, fuzzy, no-c-format
-msgid ""
 "<literal>setTimeout()</literal> cannot be called in a CMT bean, where "
 "transaction timeouts must be defined declaratively."
 msgstr ""
-"CMTビーンの中では <literal>setTimeout()</literal> を 呼び出せないことに注意し"
-"てください。 トランザクションタイムアウトは宣言的に定義されるべきです。"
+"CMT Bean の中では <literal>setTimeout()</literal> を呼び出せないことに注意し"
+"てください。トランザクションタイムアウトは宣言的に定義されるべきです。"
 
 #. Tag: title
-#: transactions.xml:664
 #, no-c-format
 msgid "Optimistic concurrency control"
 msgstr "楽観的同時実行制御"
 
 #. Tag: para
-#: transactions.xml:666
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The only approach that is consistent with high concurrency and high "
 "scalability, is optimistic concurrency control with versioning. Version "
@@ -1337,23 +1135,21 @@
 "discuss are in the context of long conversations, but version checking also "
 "has the benefit of preventing lost updates in single database transactions."
 msgstr ""
-"高い並列性と高いスケーラビリティの両方を実現するアプローチは、 バージョニング"
-"を使った楽観的同時実行制御のみです。 更新の衝突を見つけるために(および、更新"
-"が失われるのを防ぐために)、 バージョン番号もしくはタイムスタンプを使って、"
-"バージョンをチェックします。 Hibernateは、楽観的同時実行を行うアプリケーショ"
-"ンコードを書くための アプローチを3つ提供します。 私たちが見せるユースケース"
-"は、長い対話を持ちますが、 バージョンチェックはまだ1つのデータベーストランザ"
-"クションの中で更新を失うことを防ぐ 利点も持っています。"
+"高い並列性と高いスケーラビリティの両方を実現するアプローチは、バージョニング"
+"を使った楽観的同時実行制御のみです。更新の衝突を見つけるために(および、更新"
+"が失われるのを防ぐために)、バージョン番号もしくはタイムスタンプを使って、"
+"バージョンをチェックします。 Hibernate は、楽観的同時実行を行うアプリケーショ"
+"ンコードを書くためのアプローチを3つ提供します。私たちが見せるユースケース"
+"は、長い対話を持ちますが、バージョンチェックはまだ1つのデータベーストランザ"
+"クションの中で更新を失うことを防ぐ利点も持っています。"
 
 #. Tag: title
-#: transactions.xml:677
 #, no-c-format
 msgid "Application version checking"
 msgstr "アプリケーションによるバージョンチェック"
 
 #. Tag: para
-#: transactions.xml:679
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In an implementation without much help from Hibernate, each interaction with "
 "the database occurs in a new <literal>Session</literal> and the developer is "
@@ -1363,48 +1159,28 @@
 "least efficient in terms of database access. It is the approach most similar "
 "to entity EJBs."
 msgstr ""
-"Hibernateにほとんど助けてもらわずに実装するケースです。 データベースとのやり"
-"取りは、それぞれ新しい <literal>Session</literal> の中で起こります。 開発者"
-"は、すべての永続性インスタンスを操作する前に、 データベースから再読み込みする"
-"責務があります。 このアプローチでは、対話トランザクションの分離を守るため"
-"に、 アプリケーション自身がバージョンチェックを行う必要があります。 このアプ"
-"ローチは、データベースアクセスの中では、最も非効率です。 エンティティEJBと最"
-"も似ているアプローチです。"
+"Hibernate にほとんど助けてもらわずに実装するケースです。データベースとのやり"
+"取りは、それぞれ新しい <literal>Session</literal> の中で起こります。開発者"
+"は、すべての永続性インスタンスを操作する前に、データベースから再読み込みする"
+"責務があります。このアプローチでは、対話トランザクションの分離を守るために、"
+"アプリケーション自身がバージョンチェックを行う必要があります。このアプローチ"
+"は、データベースアクセスの中では、最も非効率です。エンティティ EJB と最も似て"
+"いるアプローチです。"
 
-#. Tag: programlisting
-#: transactions.xml:688
-#, no-c-format
-msgid ""
-"<![CDATA[// foo is an instance loaded by a previous Session\n"
-"session = factory.openSession();\n"
-"Transaction t = session.beginTransaction();\n"
-"\n"
-"int oldVersion = foo.getVersion();\n"
-"session.load( foo, foo.getKey() ); // load the current state\n"
-"if ( oldVersion != foo.getVersion() ) throw new StaleObjectStateException"
-"();\n"
-"foo.setProperty(\"bar\");\n"
-"\n"
-"t.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:690
 #, no-c-format
 msgid ""
 "The <literal>version</literal> property is mapped using <literal>&lt;"
 "version&gt;</literal>, and Hibernate will automatically increment it during "
 "flush if the entity is dirty."
 msgstr ""
-"<literal>&lt;version&gt;</literal> を使って、<literal>version</literal> プロ"
-"パティをマッピングします。 Hibernateは、エンティティがダーティである場合、フ"
-"ラッシュし、 その間に <literal>version</literal> プロパティを自動的にインクリ"
+"<literal>&lt;version&gt;</literal> を使って、 <literal>version</literal> プロ"
+"パティをマッピングします。 Hibernate は、エンティティがダーティである場合、フ"
+"ラッシュし、その間に <literal>version</literal> プロパティを自動的にインクリ"
 "メントします。"
 
 #. Tag: para
-#: transactions.xml:696
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are operating in a low-data-concurrency environment, and do not "
 "require version checking, you can use this approach and skip the version "
@@ -1414,15 +1190,14 @@
 "messages or a chance to merge conflicting changes."
 msgstr ""
 "もちろん、データの並列性が低い環境で運用しており、バージョンチェックが不要な"
-"ら、 このアプローチを使い、バージョンチェックをスキップするだけです。 その場"
-"合は、長い対話には、 <emphasis>「最後にコミットしたものが勝つ」</emphasis> が"
-"デフォルトの戦略でしょう。 このアプローチは、アプリケーションのユーザーを混乱"
-"させるかもしれないことを 心に留めて置いてください。それは、エラーメッセージや"
-"競合した変更をマージする機会が ないまま、更新を失う経験をするためです。"
+"ら、このアプローチを使い、バージョンチェックをスキップするだけです。その場合"
+"は、長い対話には、 <emphasis>最後にコミットしたものが勝つ</emphasis> がデフォ"
+"ルトの戦略でしょう。このアプローチは、アプリケーションのユーザーを混乱させる"
+"かもしれないことを心に留めて置いてください。それは、エラーメッセージや競合し"
+"た変更をマージする機会がないまま、更新を失う可能性があるからです。"
 
 #. Tag: para
-#: transactions.xml:705
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Manual version checking is only feasible in trivial circumstances and not "
 "practical for most applications. Often not only single instances, but "
@@ -1431,20 +1206,18 @@
 "literal> or detached instances as the design paradigm."
 msgstr ""
 "確かに、マニュアルによるバージョンチェックは、些細な儀式だけで実行できます"
-"が、 多くのアプリケーションにとって実用的ではありません。 しばしば、1つのイ"
-"ンスタンスだけでなく、 修正されたオブジェクトの完全なグラフをチェックしなけれ"
-"ばなりません。 Hibernateは、設計パラダイムとして、拡張 <literal>Session</"
-"literal> か 分離されたインスタンスを自動的にバージョンチェックします。"
+"が、多くのアプリケーションにとって実用的ではありません。しばしば、1つのイン"
+"スタンスだけでなく、修正されたオブジェクトの完全なグラフをチェックしなければ"
+"なりません。 Hibernate は、設計パラダイムとして、拡張 <literal>Session</"
+"literal> か分離されたインスタンスを自動的にバージョンチェックします。"
 
 #. Tag: title
-#: transactions.xml:716
 #, no-c-format
 msgid "Extended session and automatic versioning"
 msgstr "拡張セッションと自動バージョニング"
 
 #. Tag: para
-#: transactions.xml:718
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A single <literal>Session</literal> instance and its persistent instances "
 "that are used for the whole conversation are known as <emphasis>session-per-"
@@ -1455,15 +1228,14 @@
 "conversation with non-stale data."
 msgstr ""
 "1つの <literal>Session</literal> インスタンスとその永続性インスタンスは、 "
-"<emphasis>session-per-conversation</emphasis> として知られる、 対話全体で使わ"
-"れます。 Hibernateはフラッシュする際に、インスタンスのバージョンをチェックし"
-"ます。 同時に修正されたことを検出すると、例外を投げます。 この例外をキャッチ"
-"して扱うのは、開発者の責任です (一般的な選択肢は、変更をマージするか古くない"
-"データでビジネス対話を 再スタートする機会をユーザーに提供することです)。"
+"<emphasis>session-per-conversation</emphasis> として知られる、対話全体で使わ"
+"れます。 Hibernate はフラッシュする際に、インスタンスのバージョンをチェックし"
+"ます。同時に修正されたことを検出すると、例外を投げます。この例外をキャッチし"
+"て扱うのは、開発者の責任です (一般的な選択肢は、変更をマージするか古くない"
+"データでビジネス対話を再スタートする機会をユーザーに提供することです)。"
 
 #. Tag: para
-#: transactions.xml:727
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>Session</literal> is disconnected from any underlying JDBC "
 "connection when waiting for user interaction. This approach is the most "
@@ -1471,31 +1243,15 @@
 "check or reattach detached instances, nor does it have to reload instances "
 "in every database transaction."
 msgstr ""
-"ユーザーの対話を待っているときは、 <literal>Session</literal> を基礎となる"
-"JDBCコネクションから切り離します。 このアプローチは、データベースアクセスの中"
-"では、最も効率的です。 アプリケーションは、バージョンチェックや分離されたイン"
-"スタンスを再追加すること に関心を持つ必要はありません。また、あらゆるデータ"
-"ベーストランザクションの中で インスタンスを再読み込みする必要はありません。"
+"ユーザーの対話を待っているときは、 <literal>Session</literal> を基礎となる "
+"JDBC コネクションから切り離します。このアプローチは、データベースアクセスの中"
+"では、最も効率的です。アプリケーションは、バージョンチェックや分離されたイン"
+"スタンスを再追加することに関心を持つ必要はありません。また、あらゆるデータ"
+"ベーストランザクションの中でインスタンスを再読み込みする必要はありません。"
 
-#. Tag: programlisting
-#: transactions.xml:735
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// foo is an instance loaded earlier by the old session\n"
-"Transaction t = session.beginTransaction(); // Obtain a new JDBC connection, "
-"start transaction\n"
-"\n"
-"foo.setProperty(\"bar\");\n"
-"\n"
-"session.flush();    // Only for last transaction in conversation\n"
-"t.commit();         // Also return JDBC connection\n"
-"session.close();    // Only for last transaction in conversation]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:736
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>foo</literal> object knows which <literal>Session</literal> it "
 "was loaded in. Beginning a new database transaction on an old session "
 "obtains a new connection and resumes the session. Committing a database "
@@ -1512,23 +1268,22 @@
 "<literal>close()</literal> the session to end the conversation."
 msgstr ""
 "<literal>foo</literal> オブジェクトは、自分をロードした <literal>Session</"
-"literal> をまだ知っています。 古いセッションの上で新しいデータベーストランザ"
-"クションを開始することで、 新しいコネクションを取得し、そのセッションが再開さ"
-"れます。 データベーストランザクションをコミットすることで、 セッションから"
-"JDBCコネクションを切断し、コネクションをプールに返します。 再接続した後、更新"
-"していないデータのバージョンチェックを強制するために、 他のトランザクションに"
-"より更新されているかもしれないオブジェクトに関して、 <literal>LockMode.READ</"
+"literal> をまだ知っています。古いセッションの上で新しいデータベーストランザク"
+"ションを開始することで、新しいコネクションを取得し、そのセッションが再開され"
+"ます。データベーストランザクションをコミットすることで、セッションから JDBC "
+"コネクションを切断し、コネクションをプールに返します。再接続した後、更新して"
+"いないデータのバージョンチェックを強制するために、他のトランザクションにより"
+"更新されているかもしれないオブジェクトに関して、 <literal>LockMode.READ</"
 "literal> をつけて <literal>Session.lock()</literal> を呼び出すことができま"
-"す。 更新して <emphasis>いる</emphasis> データをロックする必要はありません。 "
-"通常、拡張 <literal>Session</literal> に <literal>FlushMode.MANUAL</literal> "
-"をセットします。 最後のデータベーストランザクションの周期でのみ、 対話の中で"
-"変更されたすべてを実際に永続化させるためです。 ゆえに、最後のデータベーストラ"
-"ンザクションのみ <literal>flush()</literal> オペレーションを含みます。そし"
-"て、対話を終わらせるために、 セッションも <literal>close()</literal> します。"
+"す。更新して <emphasis>いる</emphasis> データをロックする必要はありません。通"
+"常、拡張 <literal>Session</literal> に <literal>FlushMode.MANUAL</literal> を"
+"セットします。最後のデータベーストランザクションの周期でのみ、対話の中で変更"
+"されたすべてを実際に永続化させるためです。ゆえに、最後のデータベーストランザ"
+"クションのみ <literal>flush()</literal> オペレーションを含みます。そして、対"
+"話を終わらせるために、セッションも <literal>close()</literal> します。"
 
 #. Tag: para
-#: transactions.xml:751
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This pattern is problematic if the <literal>Session</literal> is too big to "
 "be stored during user think time (for example, an <literal>HttpSession</"
@@ -1539,34 +1294,31 @@
 "have stale data."
 msgstr ""
 "ユーザーが考慮中に、格納することができないくらい <literal>Session</literal> "
-"が大きいのであれば、このパターンは問題があります。 例えば、"
+"が大きいのであれば、このパターンは問題があります。例えば、 "
 "<literal>HttpSession</literal> は可能な限り小さく保つべきです。 "
-"<literal>Session</literal> は(強制的に)1次キャッシュでもあり、 ロードした"
-"オブジェクトをすべて保持します。 おそらく、リクエスト/レスポンスのサイクルが"
-"数回であれば、この戦略が使えます。 1つの対話のためだけに <literal>Session</"
-"literal> を使うべきです。 なぜなら、すぐに新鮮でないデータを持つためです。"
+"<literal>Session</literal> は (強制的に) 1次キャッシュでもあり、ロードした"
+"オブジェクトをすべて保持します。おそらく、リクエスト/レスポンスのサイクルが"
+"数回であれば、この戦略が使えます。1つの対話のためだけに <literal>Session</"
+"literal> を使うべきです。なぜなら、すぐに新鮮でないデータを持つためです。"
 
 #. Tag: title
-#: transactions.xml:762
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "注記"
 
 #. Tag: para
-#: transactions.xml:763
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Earlier versions of Hibernate required explicit disconnection and "
 "reconnection of a <literal>Session</literal>. These methods are deprecated, "
 "as beginning and ending a transaction has the same effect."
 msgstr ""
-"(Hibernateの以前のバージョンは、明示的な <literal>Session</literal> の 切断"
-"と再接続が必要だったことに注意してください。 これらのメソッドは非推奨になりま"
-"した。 なぜなら、トランザクションの開始と終了は同じ効果があるためです。)"
+"Hibernate の以前のバージョンは、明示的な <literal>Session</literal> の切断と"
+"再接続が必要だったことに注意してください。これらのメソッドは非推奨になりまし"
+"た。なぜなら、トランザクションの開始と終了は同じ効果があるためです。"
 
 #. Tag: para
-#: transactions.xml:769
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Keep the disconnected <literal>Session</literal> close to the persistence "
 "layer. Use an EJB stateful session bean to hold the <literal>Session</"
@@ -1574,15 +1326,14 @@
 "or even serialize it to a separate tier, to store it in the "
 "<literal>HttpSession</literal>."
 msgstr ""
-"切断した <literal>Session</literal> を永続化層の近くで保持すべきであることに "
-"注意してください。 言い換えると、3層環境の中で <literal>Session</literal> を"
-"保持するために、 EJBステートフルセッションBeanを使ってください。 "
-"<literal>HttpSession</literal> に格納するために、Web層に転送しないでください "
-"(別の層へのシリアライズもしないでください)。"
+"切断した <literal>Session</literal> を永続化層の近くで保持すべきであることに"
+"注意してください。言い換えると、3層環境の中で <literal>Session</literal> を"
+"保持するために、 EJB ステートフルセッション Bean を使ってください。 "
+"<literal>HttpSession</literal> に格納するために、 Web 層に転送しないでくださ"
+"い (別の層へのシリアライズもしないでください)。"
 
 #. Tag: para
-#: transactions.xml:777
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The extended session pattern, or <emphasis>session-per-conversation</"
 "emphasis>, is more difficult to implement with automatic current session "
@@ -1590,19 +1341,17 @@
 "<literal>CurrentSessionContext</literal> for this. See the Hibernate Wiki "
 "for examples."
 msgstr ""
-"拡張セッションパターン(もしくは、<emphasis>session-per-conversation</"
-"emphasis>)は、 自動的なカレントセッションコンテキスト管理を実施するより難し"
-"い。 このために、あなたは <literal>CurrentSessionContext</literal> の実装を供"
-"給する必要があります。 Hibernate Wikiにある例を参照してください。"
+"拡張セッションパターン (もしくは、 <emphasis>session-per-conversation</"
+"emphasis> ) は、自動的なカレントセッションコンテキスト管理を実施するより難し"
+"い。このために、あなたは <literal>CurrentSessionContext</literal> の実装を供"
+"給する必要があります。 Hibernate Wiki にある例を参照してください。"
 
 #. Tag: title
-#: transactions.xml:787
 #, no-c-format
 msgid "Detached objects and automatic versioning"
 msgstr "デタッチされたオブジェクトと自動バージョニング"
 
 #. Tag: para
-#: transactions.xml:789
 #, no-c-format
 msgid ""
 "Each interaction with the persistent store occurs in a new <literal>Session</"
@@ -1613,41 +1362,25 @@
 "<literal>Session.saveOrUpdate()</literal>, or <literal>Session.merge()</"
 "literal>."
 msgstr ""
-"新しい <literal>Session</literal>により、永続化ストア(訳注:DB)との対話が"
-"発生します。 また一方、同じ永続性インスタンスが、データベースとの対話ごとに再"
-"利用されます。 アプリケーションは、元々は他の <literal>Session</literal> で"
-"ロードされ、 デタッチされたインスタンスの状態を操作します。 そして、"
-"<literal>Session.update()</literal> もしくは、<literal>Session.saveOrUpdate()"
-"</literal>、 <literal>Session.merge()</literal> を使って、それらのインスタン"
-"スを再追加します。"
+"新しい <literal>Session</literal> により、永続化ストア (訳注:DB) との対"
+"話が発生します。また一方、同じ永続性インスタンスが、データベースとの対話ごと"
+"に再利用されます。アプリケーションは、元々は他の <literal>Session</literal> "
+"でロードされ、デタッチされたインスタンスの状態を操作します。そして、 "
+"<literal>Session.update()</literal> もしくは、 <literal>Session.saveOrUpdate"
+"()</literal> 、 <literal>Session.merge()</literal> を使って、それらのインスタ"
+"ンスを再追加します。"
 
-#. Tag: programlisting
-#: transactions.xml:797
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// foo is an instance loaded by a previous Session\n"
-"foo.setProperty(\"bar\");\n"
-"session = factory.openSession();\n"
-"Transaction t = session.beginTransaction();\n"
-"session.saveOrUpdate(foo); // Use merge() if \"foo\" might have been loaded "
-"already\n"
-"t.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:799
-#, fuzzy, no-c-format
-msgid ""
 "Again, Hibernate will check instance versions during flush, throwing an "
 "exception if conflicting updates occurred."
 msgstr ""
-"この場合もやはり、Hibernateはフラッシュする際に、インスタンスのバージョンを"
-"チェックします。 更新の競合が発生した場合には、例外を投げます。"
+"この場合もやはり、 Hibernate はフラッシュする際に、インスタンスのバージョンを"
+"チェックします。更新の競合が発生した場合には、例外を投げます。"
 
 #. Tag: para
-#: transactions.xml:804
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also call <literal>lock()</literal> instead of <literal>update()</"
 "literal>, and use <literal>LockMode.READ</literal> (performing a version "
@@ -1655,19 +1388,17 @@
 "modified."
 msgstr ""
 "オブジェクトが修正されていないことを確信している場合は、 <literal>update()</"
-"literal> の代わりに、<literal>LockMode.READ</literal> を使って、 "
+"literal> の代わりに、 <literal>LockMode.READ</literal> を使って、 "
 "<literal>lock()</literal> を呼び出すこともできます (すべてのキャッシュを迂回"
 "し、バージョンチェックを実施します)。"
 
 #. Tag: title
-#: transactions.xml:813
 #, no-c-format
 msgid "Customizing automatic versioning"
 msgstr "自動バージョニングのカスタマイズ"
 
 #. Tag: para
-#: transactions.xml:815
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can disable Hibernate's automatic version increment for particular "
 "properties and collections by setting the <literal>optimistic-lock</literal> "
@@ -1675,13 +1406,12 @@
 "increment versions if the property is dirty."
 msgstr ""
 "マッピングの <literal>optimistic-lock</literal> 属性に <literal>false</"
-"literal> を設定することにより、特定のプロパティやコレクションのために 自動"
-"バージョンインクリメントを無効にできます。 プロパティがダーティであっても、"
-"バージョンをインクリメントしません。"
+"literal> を設定することにより、特定のプロパティやコレクションのために自動バー"
+"ジョンインクリメントを無効にできます。プロパティがダーティであっても、バー"
+"ジョンをインクリメントしません。"
 
 #. Tag: para
-#: transactions.xml:822
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Legacy database schemas are often static and cannot be modified. Or, other "
 "applications might access the same database and will not know how to handle "
@@ -1694,21 +1424,20 @@
 "long <literal>Session</literal> and not session-per-request-with-detached-"
 "objects)."
 msgstr ""
-"レガシーのデータベーススキーマは、しばしば固定的であり、変更できません。 また"
-"は、他のアプリケーションが同じデータベースにアクセスしなければならず、 そのア"
-"プリケーションはバージョン番号やタイムスタンプさえ操作する方法を知りません。 "
+"レガシーのデータベーススキーマは、しばしば固定的であり、変更できません。また"
+"は、他のアプリケーションが同じデータベースにアクセスしなければならず、そのア"
+"プリケーションはバージョン番号やタイムスタンプさえ操作する方法を知りません。"
 "どちらの場合も、テーブルの特定のカラムを当てにして、バージョニングを行えませ"
-"ん。 バージョンやタイムスタンプのプロパティをマッピングせずに、バージョン"
+"ん。バージョンやタイムスタンプのプロパティをマッピングせずに、バージョン"
 "チェックさせるために、 <literal>&lt;class&gt;</literal> マッピングに "
-"<literal>optimistic-lock=\"all\"</literal> を 指定してください。 行のすべての"
-"フィールドの状態を比較するようになります。 これは、Hibernateが古い状態と新し"
-"い状態を比較できる場合に、 理論的に動作するだけであることに注意してくださ"
-"い。 例えば、session-per-request-with-detached-objects ではなく、 1つの長い "
+"<literal>optimistic-lock=\"all\"</literal> を指定してください。行のすべての"
+"フィールドの状態を比較するようになります。これは、 Hibernate が古い状態と新し"
+"い状態を比較できる場合に、理論的に動作するだけであることに注意してください。"
+"例えば、 session-per-request-with-detached-objects ではなく、1つの長い "
 "<literal>Session</literal> を使う場合です。"
 
 #. Tag: para
-#: transactions.xml:834
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Concurrent modification can be permitted in instances where the changes that "
 "have been made do not overlap. If you set <literal>optimistic-lock=\"dirty"
@@ -1717,12 +1446,11 @@
 msgstr ""
 "ときどき、行われた変更が重ならない限り、同時に行われた変更を受け入れることが"
 "できます。 <literal>&lt;class&gt;</literal> マッピングに <literal>optimistic-"
-"lock=\"dirty\"</literal> を設定した場合、フラッシュする際に、Hibernateはダー"
-"ティフィールドのみを比較します。"
+"lock=\"dirty\"</literal> を設定した場合、フラッシュする際に、 Hibernate は"
+"ダーティフィールドのみを比較します。"
 
 #. Tag: para
-#: transactions.xml:840
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In both cases, with dedicated version/timestamp columns or with a full/dirty "
 "field comparison, Hibernate uses a single <literal>UPDATE</literal> "
@@ -1737,27 +1465,25 @@
 "to <literal>SELECT</literal> the instance to ensure that changes did occur "
 "before updating the row."
 msgstr ""
-"専用のバージョン/タイムスタンプのカラムを使う場合、 もしくはすべて/ダーティ"
-"のフィールドを比較する場合どちらであっても、 Hibernateはエンティティごとに1つ"
-"の <literal>UPDATE</literal> 文を (適切な <literal>WHERE</literal> 節と共"
-"に)使い、 バージョンチェックと情報の更新を行います。 関連するエンティティの"
-"再追加をカスケードするために、 連鎖的な永続化を使用した場合、不必要な更新を実"
-"行するかもしれません。 これは通常問題になりません。 しかし、分離したインスタ"
-"ンスを変更していなくとも、 データベースの <emphasis>on update</emphasis> トリ"
-"ガーが実行されるかもしれません。 <literal>&lt;class&gt;</literal> マッピング"
-"に <literal>select-before-update=\"true\"</literal> を設定することによって、 "
-"この振る舞いをカスタマイズできます。 確実に変更されたかを確認するために、行を"
-"更新する前に、 必ずインスタンスを <literal>SELECT</literal> します。"
+"専用のバージョン/タイムスタンプのカラムを使う場合、もしくはすべて/ダーティ"
+"のフィールドを比較する場合どちらであっても、 Hibernate はエンティティごとに1"
+"つの <literal>UPDATE</literal> 文を (適切な <literal>WHERE</literal> 節と共"
+"に) 使い、バージョンチェックと情報の更新を行います。関連するエンティティの再"
+"追加をカスケードするために、連鎖的な永続化を使用した場合、不必要な更新を実行"
+"するかもしれません。これは通常問題になりません。しかし、分離したインスタンス"
+"を変更していなくとも、データベースの <emphasis>on update</emphasis> トリガー"
+"が実行されるかもしれません。 <literal>&lt;class&gt;</literal> マッピングに "
+"<literal>select-before-update=\"true\"</literal> を設定することによって、この"
+"振る舞いをカスタマイズできます。確実に変更されたかを確認するために、行を更新"
+"する前に、必ずインスタンスを <literal>SELECT</literal> します。"
 
 #. Tag: title
-#: transactions.xml:858
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Pessimistic locking"
 msgstr "悲観的ロック"
 
 #. Tag: para
-#: transactions.xml:860
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is not intended that users spend much time worrying about locking "
 "strategies. It is usually enough to specify an isolation level for the JDBC "
@@ -1765,80 +1491,73 @@
 "advanced users may wish to obtain exclusive pessimistic locks or re-obtain "
 "locks at the start of a new transaction."
 msgstr ""
-"ユーザがロック戦略に悩むのに多くの時間を費やすことを意図していません。 通常"
-"は、JDBCコネクションに分離レベルを指定し、 単にデータベースにすべての仕事をさ"
-"せれば十分です。 しかしながら、高度なユーザは、排他的な悲観的ロックを獲得する"
-"ことか、 新しいトランザクションが開始される際にロックを再獲得することを とき"
-"どき望むかもしれません。"
+"ユーザーがロック戦略に悩むのに多くの時間を費やすことを意図していません。通常"
+"は、 JDBC コネクションに分離レベルを指定し、単にデータベースにすべての仕事を"
+"させれば十分です。しかしながら、高度なユーザーは、排他的な悲観的ロックを獲得"
+"することか、新しいトランザクションが開始される際にロックを再獲得することをと"
+"きどき望むかもしれません。"
 
 #. Tag: para
-#: transactions.xml:867
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will always use the locking mechanism of the database; it never "
 "lock objects in memory."
 msgstr ""
-"Hibernateはいつもデータベースのロックの仕組みを使います。 メモリ内のオブジェ"
-"クトを決してロックしません!"
+"Hibernate はいつもデータベースのロックの仕組みを使います。メモリ内のオブジェ"
+"クトを決してロックしません。"
 
 #. Tag: para
-#: transactions.xml:872
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>LockMode</literal> class defines the different lock levels that "
 "can be acquired by Hibernate. A lock is obtained by the following mechanisms:"
 msgstr ""
-"<literal>LockMode</literal> クラスは、Hibernateが獲得できる異なるロックレベル"
-"を定義します。 以下の仕組みにより、ロックを獲得できます。"
+"<literal>LockMode</literal> クラスは、 Hibernate が獲得できる異なるロックレベ"
+"ルを定義します。以下の仕組みにより、ロックを獲得できます。"
 
 #. Tag: para
-#: transactions.xml:879
 #, no-c-format
 msgid ""
 "<literal>LockMode.WRITE</literal> is acquired automatically when Hibernate "
 "updates or inserts a row."
 msgstr ""
-"<literal>LockMode.WRITE</literal> は、 Hibernateが行を更新もしくは挿入する際"
+"<literal>LockMode.WRITE</literal> は、 Hibernate が行を更新もしくは挿入する際"
 "に自動的に得られます。"
 
 #. Tag: para
-#: transactions.xml:885
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockMode.UPGRADE</literal> can be acquired upon explicit user "
 "request using <literal>SELECT ... FOR UPDATE</literal> on databases which "
 "support that syntax."
 msgstr ""
-"<literal>LockMode.UPGRADE</literal> は、 データベースでサポートされている文"
-"法 <literal>SELECT ... FOR UPDATE</literal> を使った、明示的なユーザー要求に"
-"より得られるかもしれません。"
+"<literal>LockMode.UPGRADE</literal> は、データベースでサポートされている文法 "
+"<literal>SELECT ... FOR UPDATE</literal> を使った、明示的なユーザー要求により"
+"得られるかもしれません。"
 
 #. Tag: para
-#: transactions.xml:891
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockMode.UPGRADE_NOWAIT</literal> can be acquired upon explicit "
 "user request using a <literal>SELECT ... FOR UPDATE NOWAIT</literal> under "
 "Oracle."
 msgstr ""
 "<literal>LockMode.UPGRADE_NOWAIT</literal> は、 Oracle で "
-"<literal>SELECT ... FOR UPDATE NOWAIT</literal> を使った、 明示的なユーザー要"
+"<literal>SELECT ... FOR UPDATE NOWAIT</literal> を使った、明示的なユーザー要"
 "求により得られるかもしれません。"
 
 #. Tag: para
-#: transactions.xml:897
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockMode.READ</literal> is acquired automatically when Hibernate "
 "reads data under Repeatable Read or Serializable isolation level. It can be "
 "re-acquired by explicit user request."
 msgstr ""
-"<literal>LockMode.READ</literal> は、 Repeatable ReadもしくはSerializableの分"
-"離レベルで、データを読んだ際に自動的に得られます。 おそらく、明示的なユーザー"
-"要求により、再取得されます。"
+"<literal>LockMode.READ</literal> は、 Repeatable Read もしくは Serializable "
+"の分離レベルで、データを読んだ際に自動的に得られます。おそらく、明示的なユー"
+"ザー要求により、再取得されます。"
 
 #. Tag: para
-#: transactions.xml:904
 #, no-c-format
 msgid ""
 "<literal>LockMode.NONE</literal> represents the absence of a lock. All "
@@ -1848,20 +1567,18 @@
 "mode."
 msgstr ""
 "<literal>LockMode.NONE</literal> は、ロックしないことを表します。 "
-"<literal>Transaction</literal> の終わりに、 すべてのオブジェクトはこのロック"
+"<literal>Transaction</literal> の終わりに、すべてのオブジェクトはこのロック"
 "モードに切り替わります。 <literal>update()</literal> や <literal>saveOrUpdate"
-"()</literal> を呼び出すことによって、 セッションに関連付けられたオブジェクト"
+"()</literal> を呼び出すことによって、セッションに関連付けられたオブジェクト"
 "も、このロックモードで出発します。"
 
 #. Tag: para
-#: transactions.xml:913
 #, no-c-format
 msgid ""
 "The \"explicit user request\" is expressed in one of the following ways:"
 msgstr "「明示的なユーザー要求」とは、下記の方法の1つで言い表せます。"
 
 #. Tag: para
-#: transactions.xml:919
 #, no-c-format
 msgid ""
 "A call to <literal>Session.load()</literal>, specifying a <literal>LockMode</"
@@ -1871,19 +1588,16 @@
 "び出し。"
 
 #. Tag: para
-#: transactions.xml:924
 #, no-c-format
 msgid "A call to <literal>Session.lock()</literal>."
 msgstr "<literal>Session.lock()</literal> の呼び出し。"
 
 #. Tag: para
-#: transactions.xml:929
 #, no-c-format
 msgid "A call to <literal>Query.setLockMode()</literal>."
 msgstr "<literal>Query.setLockMode()</literal> の呼び出し。"
 
 #. Tag: para
-#: transactions.xml:935
 #, no-c-format
 msgid ""
 "If <literal>Session.load()</literal> is called with <literal>UPGRADE</"
@@ -1895,16 +1609,15 @@
 "object."
 msgstr ""
 "<literal>UPGRADE</literal> もしくは <literal>UPGRADE_NOWAIT</literal> が指定"
-"された <literal>Session.load()</literal> が呼び出され、 かつ要求されたオブ"
-"ジェクトがセッションによってまだロードされていなかった場合は、 "
+"された <literal>Session.load()</literal> が呼び出され、かつ要求されたオブジェ"
+"クトがセッションによってまだロードされていなかった場合は、 "
 "<literal>SELECT ... FOR UPDATE</literal> を使って、オブジェクトがロードされま"
-"す。 <literal>load()</literal> で呼び出されたオブジェクトが、 要求されている"
-"より制限が少ないロックですでにロードされていた場合は、 Hibernateはそのオブ"
-"ジェクトのために、<literal>lock()</literal> を呼び出します。"
+"す。 <literal>load()</literal> で呼び出されたオブジェクトが、要求されているよ"
+"り制限が少ないロックですでにロードされていた場合は、 Hibernate はそのオブジェ"
+"クトのために、 <literal>lock()</literal> を呼び出します。"
 
 #. Tag: para
-#: transactions.xml:944
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Session.lock()</literal> performs a version number check if the "
 "specified lock mode is <literal>READ</literal>, <literal>UPGRADE</literal> "
@@ -1912,33 +1625,30 @@
 "literal> or <literal>UPGRADE_NOWAIT</literal>, <literal>SELECT ... FOR "
 "UPDATE</literal> is used."
 msgstr ""
-"指定されたロックモードが <literal>READ</literal> もしくは、<literal>UPGRADE</"
-"literal>、 <literal>UPGRADE_NOWAIT</literal> だった場合、<literal>Session."
-"lock()</literal> は、バージョン番号のチェックを実施します。 "
+"指定されたロックモードが <literal>READ</literal> もしくは、 "
+"<literal>UPGRADE</literal> 、 <literal>UPGRADE_NOWAIT</literal> だった場合、 "
+"<literal>Session.lock()</literal> は、バージョン番号のチェックを実施します。 "
 "(<literal>UPGRADE</literal> もしくは <literal>UPGRADE_NOWAIT</literal> の場"
 "合、 <literal>SELECT ... FOR UPDATE</literal> が使われます。)"
 
 #. Tag: para
-#: transactions.xml:951
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the requested lock mode is not supported by the database, Hibernate uses "
 "an appropriate alternate mode instead of throwing an exception. This ensures "
 "that applications are portable."
 msgstr ""
-"データベースが要求されたロックモードをサポートしていない場合、 Hibernateは"
-"(例外を投げる代わりに、)適切な代わりのモードを使います。 これは、アプリケー"
+"データベースが要求されたロックモードをサポートしていない場合、 Hibernate は"
+"(例外を投げる代わりに、)適切な代わりのモードを使います。これは、アプリケー"
 "ションがポータブルであることを保証します。"
 
 #. Tag: title
-#: transactions.xml:960
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Connection release modes"
 msgstr "コネクション開放モード"
 
 #. Tag: para
-#: transactions.xml:962
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "One of the legacies of Hibernate 2.x JDBC connection management meant that a "
 "<literal>Session</literal> would obtain a connection when it was first "
@@ -1951,40 +1661,37 @@
 "by the enumerated values of <literal>org.hibernate.ConnectionReleaseMode</"
 "literal>:"
 msgstr ""
-"Hibernateのレガシー(2.x)のJDBCコネクション管理に関する振る舞いは、 最初に必"
-"要とした際に <literal>Session</literal> がコネクションを得るというものでし"
-"た。 そして、セッションが閉じられるまで、そのコネクションを保持しました。 "
-"Hibernate 3.xは、セッションにJDBCコネクションをどのように制御するかを伝える "
-"コネクション開放モードという概念を導入しました。 以降の議論は、構成された "
-"<literal>ConnectionProvider</literal> を通して提供される コネクションに適切で"
-"あることに注意してください。 異なる開放モードは、<literal>org.hibernate."
-"ConnectionReleaseMode</literal> に 列挙された値により確認されます。"
+"Hibernate のレガシー(2.x)の JDBC コネクション管理に関する振る舞いは、最初に"
+"必要とした際に <literal>Session</literal> がコネクションを得るというものでし"
+"た。そして、セッションが閉じられるまで、そのコネクションを保持しました。 "
+"Hibernate 3.x は、セッションに JDBC コネクションをどのように制御するかを伝え"
+"るコネクション開放モードという概念を導入しました。以降の議論は、構成された "
+"<literal>ConnectionProvider</literal> を通して提供されるコネクションに適切で"
+"あることに注意してください。異なる開放モードは、 <literal>org.hibernate."
+"ConnectionReleaseMode</literal> に列挙された値により確認されます。"
 
 #. Tag: para
-#: transactions.xml:976
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ON_CLOSE</literal>: is the legacy behavior described above. The "
 "Hibernate session obtains a connection when it first needs to perform some "
 "JDBC access and maintains that connection until the session is closed."
 msgstr ""
 "<literal>ON_CLOSE</literal> - 本質的に上記で述べたレガシーの振る舞いです。 "
-"Hibernateセッションは最初にJDBCアクセスを実行する必要がある際にコネクションを"
-"得ます。 そして、セッションが閉じられるまで、コネクションを保持します。"
+"Hibernate セッションは最初に JDBC アクセスを実行する必要がある際にコネクショ"
+"ンを得ます。そして、セッションが閉じられるまで、コネクションを保持します。"
 
 #. Tag: para
-#: transactions.xml:983
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>AFTER_TRANSACTION</literal>: releases connections after a "
 "<literal>org.hibernate.Transaction</literal> has been completed."
 msgstr ""
 "<literal>AFTER_TRANSACTION</literal> - <literal>org.hibernate.Transaction</"
-"literal> が完了した後、 コネクションを開放します。"
+"literal> が完了した後、コネクションを開放します。"
 
 #. Tag: para
-#: transactions.xml:989
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>AFTER_STATEMENT</literal> (also referred to as aggressive release): "
 "releases connections after every statement execution. This aggressive "
@@ -1993,26 +1700,24 @@
 "the use of <literal>org.hibernate.ScrollableResults</literal>."
 msgstr ""
 "<literal>AFTER_STATEMENT</literal> (積極的な開放とも呼ばれる) - すべてのス"
-"テートメントがそれぞれ実行された後、コネクションが開放されます。 ステートメン"
-"トがセッションに関連するリソースを開いたままにする場合は、 この積極的な開放は"
-"スキップされます。 今のところ、これが起こるのは <literal>org.hibernate."
+"テートメントがそれぞれ実行された後、コネクションが開放されます。ステートメン"
+"トがセッションに関連するリソースを開いたままにする場合は、この積極的な開放は"
+"スキップされます。今のところ、これが起こるのは <literal>org.hibernate."
 "ScrollableResults</literal> が使われる場合のみです。"
 
 #. Tag: para
-#: transactions.xml:999
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The configuration parameter <literal>hibernate.connection.release_mode</"
 "literal> is used to specify which release mode to use. The possible values "
 "are as follows:"
 msgstr ""
 "コンフィグレーションパラメータの <literal>hibernate.connection.release_mode</"
-"literal> は、使用する開放モードを指定するために使います。 指定できる値は次の"
-"通りです。"
+"literal> は、使用する開放モードを指定するために使います。指定できる値は次の通"
+"りです:"
 
 #. Tag: para
-#: transactions.xml:1006
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>auto</literal> (the default): this choice delegates to the release "
 "mode returned by the <literal>org.hibernate.transaction.TransactionFactory."
@@ -2024,26 +1729,24 @@
 msgstr ""
 "<literal>auto</literal> (デフォルト) - これを選択すると <literal>org."
 "hibernate.transaction.TransactionFactory.getDefaultReleaseMode()</literal> メ"
-"ソッドによって返される開放モードに委譲されます。 このメソッドは、 "
-"JTATransactionFactoryにはConnectionReleaseMode.AFTER_STATEMENTを返し、 "
-"JDBCTransactionFactoryにはConnectionReleaseMode.AFTER_TRANSACTIONを返しま"
-"す。 このデフォルトの振る舞いを変えてうまくいった試しがありません。 それは、"
-"この設定値が原因で起こる障害は、 ユーザコードの中でバグや間違った条件になりや"
+"ソッドによって返される開放モードに委譲されます。このメソッドは、 "
+"JTATransactionFactory には ConnectionReleaseMode.AFTER_STATEMENT を返し、 "
+"JDBCTransactionFactory には ConnectionReleaseMode.AFTER_TRANSACTION を返しま"
+"す。このデフォルトの振る舞いを変えてうまくいった試しがありません。それは、こ"
+"の設定値が原因で起こる障害は、ユーザーコードの中でバグや間違った条件になりや"
 "すいからです。"
 
 #. Tag: para
-#: transactions.xml:1016
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>on_close</literal>: uses ConnectionReleaseMode.ON_CLOSE. This "
 "setting is left for backwards compatibility, but its use is discouraged."
 msgstr ""
-"<literal>on_close</literal> - ConnectionReleaseMode.ON_CLOSEを使います。 この"
+"<literal>on_close</literal> - ConnectionReleaseMode.ON_CLOSE を使います。この"
 "設定は後方互換のために残されていますが、使わないことを強く勧めます。"
 
 #. Tag: para
-#: transactions.xml:1022
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>after_transaction</literal>: uses ConnectionReleaseMode."
 "AFTER_TRANSACTION. This setting should not be used in JTA environments. Also "
@@ -2052,14 +1755,13 @@
 "release mode were AFTER_STATEMENT."
 msgstr ""
 "<literal>after_transaction</literal> - ConnectionReleaseMode."
-"AFTER_TRANSACTIONを使います。 この設定はJTA環境の中では使うべきではありませ"
-"ん。 ConnectionReleaseMode.AFTER_TRANSACTIONを指定し、自動コミットモードの中"
-"では、 開放モードがAFTER_STATEMENTであるかのように、コネクションは開放される"
+"AFTER_TRANSACTION を使います。この設定は JTA 環境の中では使うべきではありませ"
+"ん。 ConnectionReleaseMode.AFTER_TRANSACTION を指定し、自動コミットモードの中"
+"では、開放モードが AFTER_STATEMENT であるかのように、コネクションは開放される"
 "ことに注意してください。"
 
 #. Tag: para
-#: transactions.xml:1030
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>after_statement</literal>: uses ConnectionReleaseMode."
 "AFTER_STATEMENT. Additionally, the configured <literal>ConnectionProvider</"
@@ -2071,11 +1773,287 @@
 "getConnection()</literal> or in auto-commit environments where it does not "
 "matter if we re-establish the same connection."
 msgstr ""
-"<literal>after_statement</literal> - ConnectionReleaseMode.AFTER_STATEMENTã‚’"
-"使います。 さらに、設定された <literal>ConnectionProvider</literal> は、 この"
-"設定 (<literal>supportsAggressiveRelease()</literal>) をサポートするかどうか "
-"を調べるために使用します。 もしそうでない場合、開放モードは"
-"ConnectionReleaseMode.AFTER_TRANSACTION にリセットされます。 この設定は次の環"
-"境でのみ安全です。 それは、<literal>ConnectionProvider.getConnection()</"
-"literal> を呼び出すたびに 基盤となるJDBCコネクションが同じものを取得できる"
-"か、 同じコネクションが得られることが問題とならない自動コミット環境の中です。"
+"<literal>after_statement</literal> - ConnectionReleaseMode.AFTER_STATEMENT ã‚’"
+"使います。さらに、設定された <literal>ConnectionProvider</literal> は、この設"
+"定 (<literal>supportsAggressiveRelease()</literal>) をサポートするかどうかを"
+"調べるために使用します。もしそうでない場合、開放モードは "
+"ConnectionReleaseMode.AFTER_TRANSACTION にリセットされます。この設定は次の環"
+"境でのみ安全です。それは、 <literal>ConnectionProvider.getConnection()</"
+"literal> を呼び出すたびに基盤となる JDBC コネクションが同じものを取得できる"
+"か、同じコネクションが得られることが問題とならない自動コミット環境の中です。"
+
+#~ msgid "foo==bar"
+#~ msgstr "foo==bar"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[// Non-managed environment idiom\n"
+#~ "Session sess = factory.openSession();\n"
+#~ "Transaction tx = null;\n"
+#~ "try {\n"
+#~ "    tx = sess.beginTransaction();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    tx.commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    if (tx != null) tx.rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}\n"
+#~ "finally {\n"
+#~ "    sess.close();\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "// Non-managed environment idiom\n"
+#~ "Session sess = factory.openSession();\n"
+#~ "Transaction tx = null;\n"
+#~ "try {\n"
+#~ "    tx = sess.beginTransaction();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    tx.commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    if (tx != null) tx.rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}\n"
+#~ "finally {\n"
+#~ "    sess.close();\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[// Non-managed environment idiom with getCurrentSession()\n"
+#~ "try {\n"
+#~ "    factory.getCurrentSession().beginTransaction();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    factory.getCurrentSession().getTransaction().commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    factory.getCurrentSession().getTransaction().rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "// Non-managed environment idiom with getCurrentSession()\n"
+#~ "try {\n"
+#~ "    factory.getCurrentSession().beginTransaction();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    factory.getCurrentSession().getTransaction().commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    factory.getCurrentSession().getTransaction().rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[// BMT idiom\n"
+#~ "Session sess = factory.openSession();\n"
+#~ "Transaction tx = null;\n"
+#~ "try {\n"
+#~ "    tx = sess.beginTransaction();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    tx.commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    if (tx != null) tx.rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}\n"
+#~ "finally {\n"
+#~ "    sess.close();\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "// BMT idiom\n"
+#~ "Session sess = factory.openSession();\n"
+#~ "Transaction tx = null;\n"
+#~ "try {\n"
+#~ "    tx = sess.beginTransaction();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    tx.commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    if (tx != null) tx.rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}\n"
+#~ "finally {\n"
+#~ "    sess.close();\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[// BMT idiom with getCurrentSession()\n"
+#~ "try {\n"
+#~ "    UserTransaction tx = (UserTransaction)new InitialContext()\n"
+#~ "                            .lookup(\"java:comp/UserTransaction\");\n"
+#~ "\n"
+#~ "    tx.begin();\n"
+#~ "\n"
+#~ "    // Do some work on Session bound to transaction\n"
+#~ "    factory.getCurrentSession().load(...);\n"
+#~ "    factory.getCurrentSession().persist(...);\n"
+#~ "\n"
+#~ "    tx.commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    tx.rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "// BMT idiom with getCurrentSession()\n"
+#~ "try {\n"
+#~ "    UserTransaction tx = (UserTransaction)new InitialContext()\n"
+#~ "                            .lookup(\"java:comp/UserTransaction\");\n"
+#~ "\n"
+#~ "    tx.begin();\n"
+#~ "\n"
+#~ "    // Do some work on Session bound to transaction\n"
+#~ "    factory.getCurrentSession().load(...);\n"
+#~ "    factory.getCurrentSession().persist(...);\n"
+#~ "\n"
+#~ "    tx.commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    tx.rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[// CMT idiom\n"
+#~ " Session sess = factory.getCurrentSession();\n"
+#~ "\n"
+#~ " // do some work\n"
+#~ " ...\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "// CMT idiom\n"
+#~ " Session sess = factory.getCurrentSession();\n"
+#~ "\n"
+#~ " // do some work\n"
+#~ " ..."
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[\n"
+#~ "Session sess = factory.openSession();\n"
+#~ "try {\n"
+#~ "    //set transaction timeout to 3 seconds\n"
+#~ "    sess.getTransaction().setTimeout(3);\n"
+#~ "    sess.getTransaction().begin();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    sess.getTransaction().commit()\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    sess.getTransaction().rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}\n"
+#~ "finally {\n"
+#~ "    sess.close();\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "Session sess = factory.openSession();\n"
+#~ "try {\n"
+#~ "    //set transaction timeout to 3 seconds\n"
+#~ "    sess.getTransaction().setTimeout(3);\n"
+#~ "    sess.getTransaction().begin();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    sess.getTransaction().commit()\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    sess.getTransaction().rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}\n"
+#~ "finally {\n"
+#~ "    sess.close();\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[// foo is an instance loaded by a previous Session\n"
+#~ "session = factory.openSession();\n"
+#~ "Transaction t = session.beginTransaction();\n"
+#~ "\n"
+#~ "int oldVersion = foo.getVersion();\n"
+#~ "session.load( foo, foo.getKey() ); // load the current state\n"
+#~ "if ( oldVersion != foo.getVersion() ) throw new StaleObjectStateException"
+#~ "();\n"
+#~ "foo.setProperty(\"bar\");\n"
+#~ "\n"
+#~ "t.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "// foo is an instance loaded by a previous Session\n"
+#~ "session = factory.openSession();\n"
+#~ "Transaction t = session.beginTransaction();\n"
+#~ "\n"
+#~ "int oldVersion = foo.getVersion();\n"
+#~ "session.load( foo, foo.getKey() ); // load the current state\n"
+#~ "if ( oldVersion!=foo.getVersion ) throw new StaleObjectStateException();\n"
+#~ "foo.setProperty(\"bar\");\n"
+#~ "\n"
+#~ "t.commit();\n"
+#~ "session.close();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[// foo is an instance loaded earlier by the old session\n"
+#~ "Transaction t = session.beginTransaction(); // Obtain a new JDBC "
+#~ "connection, start transaction\n"
+#~ "\n"
+#~ "foo.setProperty(\"bar\");\n"
+#~ "\n"
+#~ "session.flush();    // Only for last transaction in conversation\n"
+#~ "t.commit();         // Also return JDBC connection\n"
+#~ "session.close();    // Only for last transaction in conversation]]>"
+#~ msgstr ""
+#~ "// foo is an instance loaded earlier by the old session\n"
+#~ "Transaction t = session.beginTransaction(); // Obtain a new JDBC "
+#~ "connection, start transaction\n"
+#~ "\n"
+#~ "foo.setProperty(\"bar\");\n"
+#~ "\n"
+#~ "session.flush();    // Only for last transaction in conversation\n"
+#~ "t.commit();         // Also return JDBC connection\n"
+#~ "session.close();    // Only for last transaction in conversation"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[// foo is an instance loaded by a previous Session\n"
+#~ "foo.setProperty(\"bar\");\n"
+#~ "session = factory.openSession();\n"
+#~ "Transaction t = session.beginTransaction();\n"
+#~ "session.saveOrUpdate(foo); // Use merge() if \"foo\" might have been "
+#~ "loaded already\n"
+#~ "t.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "// foo is an instance loaded by a previous Session\n"
+#~ "foo.setProperty(\"bar\");\n"
+#~ "session = factory.openSession();\n"
+#~ "Transaction t = session.beginTransaction();\n"
+#~ "session.saveOrUpdate(foo); // Use merge() if \"foo\" might have been "
+#~ "loaded already\n"
+#~ "t.commit();\n"
+#~ "session.close();"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/tutorial.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/tutorial.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/tutorial.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,23 +1,24 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2009, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-01-21 16:43+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: tutorial.xml:31
 #, no-c-format
 msgid "Tutorial"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:33
 #, no-c-format
 msgid ""
 "Intended for new users, this chapter provides an step-by-step introduction "
@@ -28,7 +29,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:42
 #, no-c-format
 msgid ""
 "This tutorial expects the user have knowledge of both Java and SQL. If you "
@@ -37,7 +37,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:51
 #, no-c-format
 msgid ""
 "The distribution contains another example application under the "
@@ -45,24 +44,21 @@
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:59
 #, no-c-format
 msgid "Part 1 - The first Hibernate Application"
-msgstr "パート1 - 初めてのHibernateアプリケーション"
+msgstr "パート1 - 初めての Hibernate アプリケーション"
 
 #. Tag: para
-#: tutorial.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For this example, we will set up a small database application that can store "
 "events we want to attend and information about the host(s) of these events."
 msgstr ""
-"仮に小さなデータベースアプリケーションが必要だとしましょう。 そのアプリケー"
-"ションには出席したいイベントと、 そのイベントのホストについての情報を格納する"
+"仮に小さなデータベースアプリケーションが必要だとしましょう。そのアプリケー"
+"ションには出席したいイベントと、そのイベントのホストについての情報を格納する"
 "ものとします。"
 
 #. Tag: para
-#: tutorial.xml:67
 #, no-c-format
 msgid ""
 "Although you can use whatever database you feel comfortable using, we will "
@@ -72,13 +68,11 @@
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:76
 #, no-c-format
 msgid "Setup"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:78
 #, no-c-format
 msgid ""
 "The first thing we need to do is to set up the development environment. We "
@@ -92,7 +86,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:88
 #, no-c-format
 msgid ""
 "We will be using Maven in this tutorial, taking advantage of its transitive "
@@ -100,61 +93,7 @@
 "automatically set up a project for us based on the maven descriptor."
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:94
-#, no-c-format
-msgid ""
-"<![CDATA[<project xmlns=\"http://maven.apache.org/POM/4.0.0\"\n"
-"         xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
-"         xsi:schemaLocation=\"http://maven.apache.org/POM/4.0.0 http://maven."
-"apache.org/xsd/maven-4.0.0.xsd\">\n"
-"\n"
-"    <modelVersion>4.0.0</modelVersion>\n"
-"\n"
-"    <groupId>org.hibernate.tutorials</groupId>\n"
-"    <artifactId>hibernate-tutorial</artifactId>\n"
-"    <version>1.0.0-SNAPSHOT</version>\n"
-"    <name>First Hibernate Tutorial</name>\n"
-"\n"
-"    <build>\n"
-"         <!-- we dont want the version to be part of the generated war file "
-"name -->\n"
-"         <finalName>${artifactId}</finalName>\n"
-"    </build>\n"
-"\n"
-"    <dependencies>\n"
-"        <dependency>\n"
-"            <groupId>org.hibernate</groupId>\n"
-"            <artifactId>hibernate-core</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Because this is a web app, we also have a dependency on the "
-"servlet api. -->\n"
-"        <dependency>\n"
-"            <groupId>javax.servlet</groupId>\n"
-"            <artifactId>servlet-api</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Hibernate uses slf4j for logging, for our purposes here use the "
-"simple backend -->\n"
-"        <dependency>\n"
-"            <groupId>org.slf4j</groupId>\n"
-"            <artifactId>slf4j-simple</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Hibernate gives you a choice of bytecode providers between "
-"cglib and javassist -->\n"
-"        <dependency>\n"
-"            <groupId>javassist</groupId>\n"
-"            <artifactId>javassist</artifactId>\n"
-"        </dependency>\n"
-"    </dependencies>\n"
-"\n"
-"</project>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:97
 #, no-c-format
 msgid ""
 "It is not a requirement to use Maven. If you wish to use something else to "
@@ -173,70 +112,24 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:114
 #, no-c-format
 msgid ""
 "Save this file as <filename>pom.xml</filename> in the project root directory."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:121
 #, no-c-format
 msgid "The first class"
 msgstr "最初のクラス"
 
 #. Tag: para
-#: tutorial.xml:123
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next, we create a class that represents the event we want to store in the "
 "database; it is a simple JavaBean class with some properties:"
 msgstr "次にデータベースに格納するイベントを表すクラスを作成します。"
 
-#. Tag: programlisting
-#: tutorial.xml:128
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.domain;\n"
-"\n"
-"import java.util.Date;\n"
-"\n"
-"public class Event {\n"
-"    private Long id;\n"
-"\n"
-"    private String title;\n"
-"    private Date date;\n"
-"\n"
-"    public Event() {}\n"
-"\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"\n"
-"    private void setId(Long id) {\n"
-"        this.id = id;\n"
-"    }\n"
-"\n"
-"    public Date getDate() {\n"
-"        return date;\n"
-"    }\n"
-"\n"
-"    public void setDate(Date date) {\n"
-"        this.date = date;\n"
-"    }\n"
-"\n"
-"    public String getTitle() {\n"
-"        return title;\n"
-"    }\n"
-"\n"
-"    public void setTitle(String title) {\n"
-"        this.title = title;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:130
 #, fuzzy, no-c-format
 msgid ""
 "This class uses standard JavaBean naming conventions for property getter and "
@@ -245,16 +138,15 @@
 "fields directly, the benefit of accessor methods is robustness for "
 "refactoring."
 msgstr ""
-"ご覧のとおり、このクラスはフィールドがprivateの可視性を持っているのと同時"
-"に、 JavaBean標準のゲッター、セッターメソッドの命名規約に従っています。 この"
-"ような設計は推奨されていますが必須ではありません。 アクセサメソッドを設けるの"
-"はリファクタリングを考えた頑健性のためで、 Hibernateはフィールドに直接アクセ"
-"スすることも可能です。 引数のないコンストラクタは、リフレクションでこのクラス"
-"のインスタンスを作成するために 必要です。"
+"ご覧のとおり、このクラスはフィールドが private の可視性を持っているのと同時"
+"に、 JavaBean 標準のゲッター、セッターメソッドの命名規約に従っています。この"
+"ような設計は推奨されていますが必須ではありません。アクセサメソッドを設けるの"
+"はリファクタリングを考えた頑健性のためで、 Hibernate はフィールドに直接アクセ"
+"スすることも可能です。引数のないコンストラクタは、リフレクションでこのクラス"
+"のインスタンスを作成するために必要です。"
 
 #. Tag: para
-#: tutorial.xml:138
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>id</literal> property holds a unique identifier value for a "
 "particular event. All persistent entity classes (there are less important "
@@ -269,21 +161,20 @@
 "to you and you can match it to fit your application design."
 msgstr ""
 "<literal>id</literal> プロパティは、ある特定のイベントに対するユニークな識別"
-"子の値を保持します。 Hibernateの完全な機能を使いたければ、すべての永続エン"
+"子の値を保持します。 Hibernate の完全な機能を使いたければ、すべての永続エン"
 "ティティクラス (それほど重要ではない依存クラスというものもあります) にこの"
-"ような識別子プロパティが必要になります。 事実上ほとんどのアプリケーション(特"
-"にwebアプリケーション)では、 識別子でオブジェクトを区別する必要があるため、"
-"これは制限というよりも特徴であると考えるべきです。 しかし通常オブジェクトのID"
-"を操作するようなことはしません。 そのためセッターメソッドはprivateにするべき"
-"です。 Hibernateだけがオブジェクトがセーブされたときに識別子へ値を代入しま"
-"す。 Hibernateが(public, private, protected)フィールドに直接アクセスできる"
-"のと同様に、 public, private, protectedのアクセサメソッドにアクセスできるとい"
-"うことがわかるでしょう。 選択はあなたに任されているので、あなたのアプリケー"
-"ションの設計に合わせることができます。"
+"ような識別子プロパティが必要になります。事実上ほとんどのアプリケーション "
+"( 特に web アプリケーション) では、識別子でオブジェクトを区別する必要がある"
+"ため、これは制限というよりも特徴であると考えるべきです。しかし通常オブジェク"
+"トの ID を操作するようなことはしません。そのためセッターメソッドは private に"
+"するべきです。 Hibernate だけがオブジェクトがセーブされたときに識別子へ値を代"
+"入します。 Hibernate が(public, private, protected)フィールドに直接アクセス"
+"できるのと同様に、 public, private, protected のアクセサメソッドにアクセスで"
+"きるということがわかるでしょう。選択はあなたに任されているので、あなたのアプ"
+"リケーションの設計に合わせることができます。"
 
 #. Tag: para
-#: tutorial.xml:153
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The no-argument constructor is a requirement for all persistent classes; "
 "Hibernate has to create objects for you, using Java Reflection. The "
@@ -291,13 +182,12 @@
 "for runtime proxy generation and efficient data retrieval without bytecode "
 "instrumentation."
 msgstr ""
-"引数のないコンストラクタはすべての永続クラスに必須です。 これはHibernateが"
-"Javaのリフレクションを使って、オブジェクトを作成しなければならないためです。 "
-"コンストラクタをprivateにすることは可能ですが、 実行時のプロキシ生成と、バイ"
-"トコード操作なしの効率的なデータの抽出には、 package可視性が必要です。"
+"引数のないコンストラクタはすべての永続クラスに必須です。これは Hibernate が "
+"Java のリフレクションを使って、オブジェクトを作成しなければならないためです。"
+"コンストラクタを private にすることは可能ですが、実行時のプロキシ生成と、バイ"
+"トコード操作なしの効率的なデータの抽出には、 package 可視性が必要です。"
 
 #. Tag: para
-#: tutorial.xml:161
 #, no-c-format
 msgid ""
 "Save this file to the <filename>src/main/java/org/hibernate/tutorial/domain</"
@@ -305,13 +195,11 @@
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:168
 #, no-c-format
 msgid "The mapping file"
 msgstr "マッピングファイル"
 
 #. Tag: para
-#: tutorial.xml:170
 #, no-c-format
 msgid ""
 "Hibernate needs to know how to load and store objects of the persistent "
@@ -319,35 +207,19 @@
 "file tells Hibernate what table in the database it has to access, and what "
 "columns in that table it should use."
 msgstr ""
-"Hibernateは、どのように永続クラスのオブジェクトをロードし格納すればよいかを知"
-"る必要があります。 ここでHibernateマッピングファイルが登場します。 マッピング"
-"ファイルは、データベース内のどのテーブルにアクセスしなければならないか、 その"
-"テーブルのどのカラムを使うべきかを、Hibernateに教えます。"
+"Hibernate は、どのように永続クラスのオブジェクトをロードし格納すればよいかを"
+"知る必要があります。ここで Hibernate マッピングファイルが登場します。マッピン"
+"グファイルは、データベース内のどのテーブルにアクセスしなければならないか、そ"
+"のテーブルのどのカラムを使うべきかを、 Hibernate に教えます。"
 
 #. Tag: para
-#: tutorial.xml:178
 #, no-c-format
 msgid "The basic structure of a mapping file looks like this:"
 msgstr "マッピングファイルの基本的な構造はこのようになります:"
 
-#. Tag: programlisting
-#: tutorial.xml:182
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"[...]\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:184
-#, fuzzy, no-c-format
-msgid ""
 "Hibernate DTD is sophisticated. You can use it for auto-completion of XML "
 "mapping elements and attributes in your editor or IDE. Opening up the DTD "
 "file in your text editor is the easiest way to get an overview of all "
@@ -357,28 +229,26 @@
 "<filename>hibernate-core.jar</filename> (it is also included in the "
 "<filename>hibernate3.jar</filename>, if using the distribution bundle)."
 msgstr ""
-"Hibernate DTDが非常に洗練されていることに注目してください。 このDTDは、エディ"
-"タやIDEでのXMLマッピング要素と属性のオートコンプリーション機能に利用できま"
-"す。 またDTDファイルをテキストエディタで開けてみてください。 というのも、すべ"
-"ての要素と属性を概観し、 コメントやデフォルトの値を見るには一番簡単な方法だか"
-"らです。 Hibernateは、webからDTDファイルをロードせずに、 まずアプリケーション"
-"のクラスパスからこれを探し出そうとすることに注意してください。 DTDファイルは"
-"Hibernateディストリビューションの <literal>src/</literal> ディレクトリと同"
-"様、<literal>hibernate3.jar</literal> にも含まれています。"
+"Hibernate DTD が非常に洗練されていることに注目してください。この DTD は、エ"
+"ディタや IDE での XML マッピング要素と属性のオートコンプリーション機能に利用"
+"できます。また DTD ファイルをテキストエディタで開けてみてください。というの"
+"も、すべての要素と属性を概観し、コメントやデフォルトの値を見るには一番簡単な"
+"方法だからです。 Hibernate は、 web から DTD ファイルをロードせずに、まずアプ"
+"リケーションのクラスパスからこれを探し出そうとすることに注意してください。 "
+"DTD ファイルは Hibernate ディストリビューションの <literal>src/</literal> "
+"ディレクトリと同様、<literal>hibernate3.jar</literal> にも含まれています。"
 
 #. Tag: para
-#: tutorial.xml:197
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will omit the DTD declaration in future examples to shorten the code. It "
 "is, of course, not optional."
 msgstr ""
-"以降の例ではコードを短くするためにDTD宣言を省略します。 当然ですがこれはオプ"
+"以降の例ではコードを短くするために DTD 宣言を省略します。当然ですがこれはオプ"
 "ションではありません。"
 
 #. Tag: para
-#: tutorial.xml:203
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Between the two <literal>hibernate-mapping</literal> tags, include a "
 "<literal>class</literal> element. All persistent entity classes (again, "
@@ -386,27 +256,13 @@
 "entities) need a mapping to a table in the SQL database:"
 msgstr ""
 "2つの <literal>hibernate-mapping</literal> タグの間に <literal>class</"
-"literal> 要素を含めてください。 すべての永続エンティティクラス(念を押します"
-"が、 ファーストクラスのエンティティではない依存クラスというものが後ほど登場し"
-"ます) はSQLデータベース内のテーブルへのこのようなマッピングを必要とします。"
+"literal> 要素を含めてください。すべての永続エンティティクラス(念を押します"
+"が、ファーストクラスのエンティティではない依存クラスというものが後ほど登場し"
+"ます)は SQL データベース内のテーブルへのこのようなマッピングを必要とします。"
 
-#. Tag: programlisting
-#: tutorial.xml:210
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:212
-#, fuzzy, no-c-format
-msgid ""
 "So far we have told Hibernate how to persist and load object of class "
 "<literal>Event</literal> to the table <literal>EVENTS</literal>. Each "
 "instance is now represented by a row in that table. Now we can continue by "
@@ -414,31 +270,15 @@
 "not want to care about handling this identifier, we configure Hibernate's "
 "identifier generation strategy for a surrogate primary key column:"
 msgstr ""
-"これまで私たちは、<literal>Event</literal> クラスのオブジェクトを "
+"これまで私たちは、 <literal>Event</literal> クラスのオブジェクトを "
 "<literal>EVENTS</literal> テーブルに対して、どのように永続化したりロードした"
-"りするのかを Hibernateに教えてきました。そして個々のインスタンスはテーブルの"
-"行として表現されます。 それでは引き続きテーブルの主キーに対するユニークな識別"
-"子プロパティをマッピングしていきます。 さらに、この識別子の扱いに気を使いたく"
-"なかったのと同様に、 代理の主キーカラムに対するHibernateの識別子生成戦略を設"
+"りするのかを Hibernate に教えてきました。そして個々のインスタンスはテーブルの"
+"行として表現されます。それでは引き続きテーブルの主キーに対するユニークな識別"
+"子プロパティをマッピングしていきます。さらに、この識別子の扱いに気を使いたく"
+"なかったのと同様に、代理の主キーカラムに対する Hibernate の識別子生成戦略を設"
 "定します。"
 
-#. Tag: programlisting
-#: tutorial.xml:222
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"        <id name=\"id\" column=\"EVENT_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:224
 #, no-c-format
 msgid ""
 "The <literal>id</literal> element is the declaration of the identifier "
@@ -450,7 +290,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:234
 #, no-c-format
 msgid ""
 "The nested <literal>generator</literal> element specifies the identifier "
@@ -463,45 +302,25 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:246
 #, no-c-format
 msgid ""
 "<literal>native</literal> is no longer consider the best strategy in terms "
-"of portability. for further discussion, see"
+"of portability. for further discussion, see <xref linkend=\"portability-idgen"
+"\" />"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:252
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Lastly, we need to tell Hibernate about the remaining entity class "
 "properties. By default, no properties of the class are considered persistent:"
 msgstr ""
-"最後にクラスの永続プロパティの宣言をマッピングファイルに含めます。 デフォルト"
+"最後にクラスの永続プロパティの宣言をマッピングファイルに含めます。デフォルト"
 "では、クラスのプロパティは永続と見なされません:"
 
-#. Tag: programlisting
-#: tutorial.xml:258
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"        <id name=\"id\" column=\"EVENT_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"date\" type=\"timestamp\" column=\"EVENT_DATE\"/>\n"
-"        <property name=\"title\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:260
-#, fuzzy, no-c-format
-msgid ""
 "Similar to the <literal>id</literal> element, the <literal>name</literal> "
 "attribute of the <literal>property</literal> element tells Hibernate which "
 "getter and setter methods to use. In this case, Hibernate will search for "
@@ -510,12 +329,11 @@
 msgstr ""
 "<literal>id</literal> 要素の場合と同様に、 <literal>property</literal> 要素"
 "の <literal>name</literal> 属性で、どのゲッターとセッターメソッドを使うべきか"
-"をHibernateに教えます。 この例では、Hibernateは <literal>getDate()/setDate()"
-"</literal> と <literal>getTitle()/setTitle()</literal> を 探します。"
+"を Hibernate に教えます。この例では、 Hibernate は <literal>getDate()/setDate"
+"()</literal> と <literal>getTitle()/setTitle()</literal> を探します。"
 
 #. Tag: para
-#: tutorial.xml:271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Why does the <literal>date</literal> property mapping include the "
 "<literal>column</literal> attribute, but the <literal>title</literal> does "
@@ -525,15 +343,14 @@
 "databases so you will need to map it to a different name."
 msgstr ""
 "なぜ <literal>date</literal> プロパティのマッピングには <literal>column</"
-"literal> 属性があり、<literal>title</literal> プロパティにはないのでしょう"
-"か? <literal>column</literal> 属性がなければ、Hibernateはプロパティ名をカラ"
-"ム名として使います。 これは <literal>title</literal> では上手く行きます。 し"
-"かし <literal>date</literal> はほとんどのデータベースで予約語なので、 違う名"
-"前でマッピングした方がよいのです。"
+"literal> 属性があり、 <literal>title</literal> プロパティにはないのでしょう"
+"か? <literal>column</literal> 属性がなければ、 Hibernate はデフォルトでプロ"
+"パティ名をカラム名として使います。これは <literal>title</literal> では上手く"
+"いきます。しかし <literal>date</literal> は、ほとんどのデータベースで予約語な"
+"ので、違う名前でマッピングした方がよいのです。"
 
 #. Tag: para
-#: tutorial.xml:281
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>title</literal> mapping also lacks a <literal>type</literal> "
 "attribute. The types declared and used in the mapping files are not Java "
@@ -551,23 +368,22 @@
 "property with a <literal>timestamp</literal> converter."
 msgstr ""
 "次に興味深いのは <literal>title</literal> マッピングが <literal>type</"
-"literal> 属性をも欠いている点です。 マッピングファイルで宣言して使うtypeは、"
-"おわかりかもしれませんがJavaのデータ型ではありません。 SQLデータベースの型で"
-"もありません。 これは <emphasis>Hibernateマッピング型</emphasis> と呼ばれ"
-"る、 JavaからSQLデータの型へまたはSQLからJavaデータ型へ翻訳するコンバータで"
-"す。 繰り返しになりますが、Hibernateは <literal>type</literal> 属性がマッピン"
-"グファイル内になければ、 正しいコンバージョンとマッピング型を自分で解決しよう"
-"とします。 (Javaクラスのリフレクションを使った)この自動検知は、 場合によっ"
-"てはあなたが期待または必要とするデフォルト値にならないかもしれません。 "
-"<literal>date</literal> プロパティの場合がそうでした。 Hibernateはこの"
-"( <literal>java.util.Date</literal> の)プロパティを SQLの <literal>date</"
+"literal> 属性をも欠いている点です。マッピングファイルで宣言して使う type は、"
+"おわかりかもしれませんが Java のデータ型ではありません。 SQL データベースの型"
+"でもありません。これは <emphasis>Hibernateマッピング型</emphasis> と呼ばれ"
+"る、 Java から SQL データの型へまたは SQL から Java データ型へ翻訳するコン"
+"バータです。繰り返しになりますが、 Hibernate は <literal>type</literal> 属性"
+"がマッピングファイル内になければ、正しいコンバージョンとマッピング型を自分で"
+"解決しようとします。 (Javaクラスのリフレクションを使った)この自動検知は、場"
+"合によってはあなたが期待または必要とするデフォルト値にならないかもしれませ"
+"ん。 <literal>date</literal> プロパティの場合がそうでした。 Hibernate はこの"
+"( <literal>java.util.Date</literal> の)プロパティを SQL の <literal>date</"
 "literal> , <literal>timestamp</literal> , <literal>time</literal> のうち、ど"
 "のカラムにマッピングするべきなのかわかりません。 <literal>timestamp</"
 "literal> コンバータでプロパティをマッピングすることにより、完全な日時を保存し"
 "ます。"
 
 #. Tag: para
-#: tutorial.xml:297
 #, no-c-format
 msgid ""
 "Hibernate makes this mapping type determination using reflection when the "
@@ -577,7 +393,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:304
 #, no-c-format
 msgid ""
 "Save this mapping file as <filename>src/main/resources/org/hibernate/"
@@ -585,13 +400,11 @@
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:312
 #, no-c-format
 msgid "Hibernate configuration"
-msgstr "Hibernateの設定"
+msgstr "Hibernate の設定"
 
 #. Tag: para
-#: tutorial.xml:314
 #, no-c-format
 msgid ""
 "At this point, you should have the persistent class and its mapping file in "
@@ -600,13 +413,11 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:321
 #, no-c-format
 msgid "We do this do that the data remains between runs."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:326
 #, fuzzy, no-c-format
 msgid ""
 "We will utilize the Maven exec plugin to launch the HSQLDB server by "
@@ -618,17 +429,16 @@
 "filename> directory, and start HSQLDB again."
 msgstr ""
 "<literal>data</literal> というディレクトリを開発ディレクトリのルートに作成し"
-"てください。 HSQL DBはここにデータファイルを格納します。 このデータディレクト"
-"リにおいて <literal>java -classpath lib/hsqldb.jar org.hsqldb.Server</"
-"literal> を実行し、 データベースを起動させてください。 動作の開始と、TCP/IPソ"
-"ケットのバインドが確認できます。 後ほど作成するアプリケーションはここに接続し"
-"ます。 もしこのチュートリアル中にデータベースを初期化したければ、 HSQL DBを"
+"てください。 HSQL DB はここにデータファイルを格納します。このデータディレクト"
+"リにおいて <literal>java -classpath ../lib/hsqldb.jar org.hsqldb.Server</"
+"literal> を実行し、データベースを起動させてください。動作の開始と、 TCP/IP ソ"
+"ケットのバインドが確認できます。後ほど作成するアプリケーションはここに接続し"
+"ます。もしこのチュートリアル中にデータベースを初期化したければ、 HSQL DB を"
 "シャットダウンして(作業ウィンドウで <literal>CTRL + C</literal> を押しま"
 "す) <literal>data/</literal> ディレクトリ内のファイルを全て消去した後、 "
-"HSQL DBを再起動します。"
+"HSQL DB を再起動します。"
 
 #. Tag: para
-#: tutorial.xml:337
 #, no-c-format
 msgid ""
 "Hibernate will be connecting to the database on behalf of your application, "
@@ -642,7 +452,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:348
 #, no-c-format
 msgid ""
 "The built-in Hibernate connection pool is in no way intended for production "
@@ -650,109 +459,57 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:354
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For Hibernate's configuration, we can use a simple <literal>hibernate."
 "properties</literal> file, a more sophisticated <literal>hibernate.cfg.xml</"
 "literal> file, or even complete programmatic setup. Most users prefer the "
 "XML configuration file:"
 msgstr ""
-"Hibernateの設定では、単純な <literal>hibernate.properties</literal> ファイ"
-"ル、 それより少し洗練されている <literal>hibernate.cfg.xml</literal> ファイ"
-"ル、 または完全にプログラム上でセットアップする方法が利用できます。 ほとんど"
-"のユーザが好むのはXML設定ファイルです:"
+"Hibernate の設定では、単純な <literal>hibernate.properties</literal> ファイ"
+"ル、それより少し洗練されている <literal>hibernate.cfg.xml</literal> ファイ"
+"ル、または完全にプログラム上でセットアップする方法が利用できます。ほとんどの"
+"ユーザーが好むのは XML 設定ファイルです:"
 
-#. Tag: programlisting
-#: tutorial.xml:360
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-"<!DOCTYPE hibernate-configuration PUBLIC\n"
-"        \"-//Hibernate/Hibernate Configuration DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
-"\">\n"
-"\n"
-"<hibernate-configuration>\n"
-"\n"
-"    <session-factory>\n"
-"\n"
-"        <!-- Database connection settings -->\n"
-"        <property name=\"connection.driver_class\">org.hsqldb.jdbcDriver</"
-"property>\n"
-"        <property name=\"connection.url\">jdbc:hsqldb:hsql://localhost</"
-"property>\n"
-"        <property name=\"connection.username\">sa</property>\n"
-"        <property name=\"connection.password\"></property>\n"
-"\n"
-"        <!-- JDBC connection pool (use the built-in) -->\n"
-"        <property name=\"connection.pool_size\">1</property>\n"
-"\n"
-"        <!-- SQL dialect -->\n"
-"        <property name=\"dialect\">org.hibernate.dialect.HSQLDialect</"
-"property>\n"
-"\n"
-"        <!-- Enable Hibernate's automatic session context management -->\n"
-"        <property name=\"current_session_context_class\">thread</property>\n"
-"\n"
-"        <!-- Disable the second-level cache  -->\n"
-"        <property name=\"cache.provider_class\">org.hibernate.cache."
-"NoCacheProvider</property>\n"
-"\n"
-"        <!-- Echo all executed SQL to stdout -->\n"
-"        <property name=\"show_sql\">true</property>\n"
-"\n"
-"        <!-- Drop and re-create the database schema on startup -->\n"
-"        <property name=\"hbm2ddl.auto\">update</property>\n"
-"\n"
-"        <mapping resource=\"org/hibernate/tutorial/domain/Event.hbm.xml\"/>\n"
-"\n"
-"    </session-factory>\n"
-"\n"
-"</hibernate-configuration>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:363
 #, no-c-format
 msgid "Notice that this configuration file specifies a different DTD"
-msgstr ""
+msgstr "この XML の設定が異なる DTD を使うことに注意してください。"
 
 #. Tag: para
-#: tutorial.xml:366
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You configure Hibernate's <literal>SessionFactory</literal>. SessionFactory "
 "is a global factory responsible for a particular database. If you have "
 "several databases, for easier startup you should use several <literal>&lt;"
 "session-factory&gt;</literal> configurations in several configuration files."
 msgstr ""
-"このXMLの設定が異なるDTDを使うことに注意してください。 特定のデータベースを受"
-"け持つグローバルファクトリであるHibernateの <literal>SessionFactory</"
-"literal> を設定します。 もし複数のデータベースがある場合には、 (スタートアッ"
-"プを簡単にするため)通常いくつかの設定ファイル内で、 いくつかの <literal>&lt;"
-"session-factory&gt;</literal> を使う設定にしてください。"
+"特定のデータベースを受け持つグローバルファクトリである Hibernate の "
+"<literal>SessionFactory</literal> を設定します。もし複数のデータベースがある"
+"場合には、 (スタートアップを簡単にするため)通常いくつかの設定ファイル内で、"
+"いくつかの <literal>&lt;session-factory&gt;</literal> を使う設定にしてくださ"
+"い。"
 
 #. Tag: para
-#: tutorial.xml:373
 #, no-c-format
 msgid ""
 "The first four <literal>property</literal> elements contain the necessary "
 "configuration for the JDBC connection. The dialect <literal>property</"
 "literal> element specifies the particular SQL variant Hibernate generates."
 msgstr ""
+"最初の4つの <literal>property</literal> 要素は JDBC コネクションに必要な設定"
+"を含んでいます。 dialect という名前の <literal>property</literal> 要素は、 "
+"Hibernate が生成する特定の SQL 方言を指定します。"
 
 #. Tag: para
-#: tutorial.xml:380
 #, no-c-format
 msgid ""
 "In most cases, Hibernate is able to properly determine which dialect to use. "
-"See <xref linkend=\"portability-dialectresolver\"/> for more information."
+"See <xref linkend=\"portability-dialectresolver\" /> for more information."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:386
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's automatic session management for persistence contexts is "
 "particularly useful in this context. The <literal>hbm2ddl.auto</literal> "
@@ -762,18 +519,15 @@
 "Ant task. Finally, add the mapping file(s) for persistent classes to the "
 "configuration."
 msgstr ""
-"最初の4つの <literal>property</literal> 要素はJDBCコネクションに必要な設定を"
-"含んでいます。 dialectという名前の <literal>property</literal> 要素は、"
-"Hibernateが生成する特定のSQL方言を指定します。 永続的なコンテキストに対する"
-"Hibernateのセッションの自動管理は、後の例ですぐにわかるように、役に立つことで"
-"しょう。 <literal>hbm2ddl.auto</literal> オプションはデータベーススキーマの自"
-"動生成をonにします。 これは直接データベースに対して生成されます。 当然"
-"(configオプションを削除して)offにしたり、 <literal>SchemaExport</literal> "
-"というAntタスクの助けを借りてファイルにリダイレクトしたりできます。 最後に永"
-"続クラスのためのマッピングファイルを設定に追加します。"
+"永続的なコンテキストに対する Hibernate のセッションの自動管理は、後の例ですぐ"
+"にわかるように、役に立つことでしょう。 <literal>hbm2ddl.auto</literal> オプ"
+"ションはデータベーススキーマの自動生成を on にします。これは直接データベース"
+"に対して生成されます。当然(config オプションを削除して) off にしたり、 "
+"<literal>SchemaExport</literal> という Ant タスクの助けを借りてファイルにリダ"
+"イレクトしたりできます。最後に永続クラスのためのマッピングファイルを設定に追"
+"加します。"
 
 #. Tag: para
-#: tutorial.xml:395
 #, no-c-format
 msgid ""
 "Save this file as <filename>hibernate.cfg.xml</filename> into the "
@@ -781,13 +535,11 @@
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:403
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Building with Maven"
-msgstr "Antによるビルド"
+msgstr "Maven によるビルド"
 
 #. Tag: para
-#: tutorial.xml:405
 #, no-c-format
 msgid ""
 "We will now build the tutorial with Maven. You will need to have Maven "
@@ -798,44 +550,13 @@
 "make sure we can compile everything so far:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:415
-#, no-c-format
-msgid ""
-"<![CDATA[[hibernateTutorial]$ mvn compile\n"
-"[INFO] Scanning for projects...\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] Building First Hibernate Tutorial\n"
-"[INFO]    task-segment: [compile]\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] [resources:resources]\n"
-"[INFO] Using default encoding to copy filtered resources.\n"
-"[INFO] [compiler:compile]\n"
-"[INFO] Compiling 1 source file to /home/steve/projects/sandbox/"
-"hibernateTutorial/target/classes\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] BUILD SUCCESSFUL\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] Total time: 2 seconds\n"
-"[INFO] Finished at: Tue Jun 09 12:25:25 CDT 2009\n"
-"[INFO] Final Memory: 5M/547M\n"
-"[INFO] "
-"------------------------------------------------------------------------]]>"
-msgstr ""
-
 #. Tag: title
-#: tutorial.xml:420
 #, no-c-format
 msgid "Startup and helpers"
 msgstr "スタートアップとヘルパ"
 
 #. Tag: para
-#: tutorial.xml:422
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is time to load and store some <literal>Event</literal> objects, but "
 "first you have to complete the setup with some infrastructure code. You have "
@@ -849,64 +570,29 @@
 "global object that is instantiated once."
 msgstr ""
 "さて <literal>Event</literal> オブジェクトをロードしたり格納したりする準備が"
-"できました。 しかしまずはインフラストラクチャのコードを書いて、セットアップを"
-"完了する必要があります。 まずはHibernateをスタートアップしなければなりませ"
-"ん。 このスタートアップには、グローバルの <literal>SessionFactory</literal> "
-"オブジェクトを生成して、 それをアプリケーションのコードでアクセスしやすい場所"
-"に格納することが含まれます。 <literal>SessionFactory</literal> は新しく "
-"<literal>Session</literal> をオープンすることができます。 <literal>Session</"
-"literal> はシングルスレッドの作業単位(Unit of Work)を表現します。 それに対し"
-"<literal>SessionFactory</literal> はスレッドセーフのグローバルオブジェクトで"
-"あり、 一度だけインスタンス化されます。"
+"できました。しかしまずはインフラストラクチャのコードを書いて、セットアップを"
+"完了する必要があります。まずは Hibernate をスタートアップしなければなりませ"
+"ん。このスタートアップには、グローバルの <literal>SessionFactory</literal> オ"
+"ブジェクトを生成して、それをアプリケーションのコードでアクセスしやすい場所に"
+"格納することが含まれます。 <interfacename>org.hibernate.SessionFactory</"
+"interfacename> は新しく <interfacename>org.hibernate.Session</interfacename> "
+"をオープンすることができます。 <interfacename>org.hibernate.Session</"
+"interfacename> はシングルスレッドの作業単位(Unit of Work)を表現します。それに"
+"対し <interfacename>org.hibernate.SessionFactory</interfacename> はスレッド"
+"セーフのグローバルオブジェクトであり、一度だけインスタンス化されます。"
 
 #. Tag: para
-#: tutorial.xml:436
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will create a <literal>HibernateUtil</literal> helper class that takes "
 "care of startup and makes accessing the <interfacename>org.hibernate."
 "SessionFactory</interfacename> more convenient."
 msgstr ""
-"ここでスタートアップを行い、 便利に <literal>SessionFactory</literal> へアク"
-"セスする <literal>HibernateUtil</literal> ヘルパクラスを作成します。 実装を見"
-"てみましょう:"
+"ここでスタートアップを行い、便利に <interfacename>org.hibernate."
+"SessionFactory</interfacename> へアクセスする <literal>HibernateUtil</"
+"literal> ヘルパクラスを作成します。実装を見てみましょう:"
 
-#. Tag: programlisting
-#: tutorial.xml:442
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.util;\n"
-"\n"
-"import org.hibernate.SessionFactory;\n"
-"import org.hibernate.cfg.Configuration;\n"
-"\n"
-"public class HibernateUtil {\n"
-"\n"
-"    private static final SessionFactory sessionFactory = buildSessionFactory"
-"();\n"
-"\n"
-"    private static SessionFactory buildSessionFactory() {\n"
-"        try {\n"
-"            // Create the SessionFactory from hibernate.cfg.xml\n"
-"            return new Configuration().configure().buildSessionFactory();\n"
-"        }\n"
-"        catch (Throwable ex) {\n"
-"            // Make sure you log the exception, as it might be swallowed\n"
-"            System.err.println(\"Initial SessionFactory creation failed.\" + "
-"ex);\n"
-"            throw new ExceptionInInitializerError(ex);\n"
-"        }\n"
-"    }\n"
-"\n"
-"    public static SessionFactory getSessionFactory() {\n"
-"        return sessionFactory;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:444
 #, no-c-format
 msgid ""
 "Save this code as <filename>src/main/java/org/hibernate/tutorial/util/"
@@ -914,7 +600,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:449
 #, fuzzy, no-c-format
 msgid ""
 "This class not only produces the global <interfacename>org.hibernate."
@@ -924,13 +609,13 @@
 "reference from JNDI in an application server or any other location for that "
 "matter."
 msgstr ""
-"このクラスは静的初期化ブロック(クラスがロードされるときにJVMによって一度だけ"
-"呼ばれる) でグローバルの <literal>SessionFactory</literal> を生成するだけで"
-"はなく、 静的シングルトンの使用を隠蔽します。 アプリケーションサーバーのJNDI"
-"から <literal>SessionFactory</literal> を ルックアップするのと同様です。"
+"このクラスは静的初期化ブロック(クラスがロードされるときに JVM によって一度だ"
+"け呼ばれる) でグローバルの <interfacename>org.hibernate.SessionFactory</"
+"interfacename> を生成するだけではなく、静的シングルトンの使用を隠蔽します。ア"
+"プリケーションサーバーの JNDI から <interfacename>org.hibernate."
+"SessionFactory</interfacename> をルックアップするのと同様です。"
 
 #. Tag: para
-#: tutorial.xml:458
 #, fuzzy, no-c-format
 msgid ""
 "If you give the <interfacename>org.hibernate.SessionFactory</interfacename> "
@@ -940,15 +625,15 @@
 "<literal>HibernateService</literal> to JNDI. Such advanced options are "
 "discussed later."
 msgstr ""
-"設定ファイル内で <literal>SessionFactory</literal> に名前を与えると、 "
-"Hibernateは <literal>SessionFactory</literal> 構築後にJNDIに対しバインドを行"
-"おうとします。 このコードを完全に排除するためには、 JMXデプロイメントを利用し"
-"て JMXを利用できるコンテナをインスタンス化し、 <literal>HibernateService</"
-"literal> をJNDIへバインドすることもできます。 これらの高度なオプションは、"
-"Hibernateのリファレンスドキュメントで説明されています。"
+"設定ファイル内で <interfacename>org.hibernate.SessionFactory</interfacename> "
+"に名前を与えると、 Hibernate は <interfacename>org.hibernate.SessionFactory</"
+"interfacename> 構築後に JNDI に対しバインドを行おうとします。このコードを完全"
+"に排除するためには、 JMX デプロイメントを利用して JMX を利用できるコンテナを"
+"インスタンス化し、 <literal>HibernateService</literal> を JNDI へバインドする"
+"こともできます。これらの高度なオプションは、 Hibernate のリファレンスドキュメ"
+"ントで説明されています。"
 
 #. Tag: para
-#: tutorial.xml:467
 #, fuzzy, no-c-format
 msgid ""
 "You now need to configure a logging system. Hibernate uses commons logging "
@@ -960,86 +645,41 @@
 "configuration, you can change the settings. By default, only the Hibernate "
 "startup message is shown on stdout."
 msgstr ""
-"これは問題なく再コンパイルできるはずです。 最後にロギングシステムを設定する必"
-"要があります。 Hibernateはcommons loggingを使うため、Log4jとJDK 1.4 loggingの"
-"選択をする必要がありません。 ほとんどの開発者が好むのはLog4jです。 Hibernate"
-"ディストリビューション(の<literal>etc/</literal> ディレクトリ)から "
-"<literal>log4j.properties</literal> をあなたの <literal>src</literal> ディレ"
-"クトリ内の <literal>hibernate.cfg.xml</literal> の隣にコピーしてください。 設"
-"定例を見て、冗長な出力がよければ設定を変更してください。 デフォルトでは"
-"Hibernateのスタートアップメッセージだけが標準出力に表示されます。"
+"これは問題なく再コンパイルできるはずです。最後にロギングシステムを設定する必"
+"要があります。 Hibernate は commons logging を使うため、 Log4j と JDK 1.4 "
+"logging の選択をする必要がありません。ほとんどの開発者が好むのは Log4j で"
+"す。 Hibernate ディストリビューションの( <literal>etc/</literal> ディレクト"
+"リ)から <literal>log4j.properties</literal> をあなたの <literal>src</"
+"literal> ディレクトリ内の <literal>hibernate.cfg.xml</literal> の隣にコピーし"
+"てください。設定例を見て、冗長な出力がよければ設定を変更してください。デフォ"
+"ルトでは Hibernate のスタートアップメッセージだけが標準出力に表示されます。"
 
 #. Tag: para
-#: tutorial.xml:477
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The tutorial infrastructure is complete and you are now ready to do some "
 "real work with Hibernate."
 msgstr ""
-"チュートリアルのインフラは完全です。 Hibernateを使って実際の作業をする準備が"
+"チュートリアルのインフラは完全です。 Hibernate を使って実際の作業をする準備が"
 "整いました。"
 
 #. Tag: title
-#: tutorial.xml:485
 #, no-c-format
 msgid "Loading and storing objects"
 msgstr "オブジェクトのロードと格納"
 
 #. Tag: para
-#: tutorial.xml:487
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We are now ready to start doing some real worjk with Hibernate. Let's start "
 "by writing an <literal>EventManager</literal> class with a <literal>main()</"
 "literal> method:"
 msgstr ""
-"ついにオブジェクトのロードと格納にHibernateを使うことができます。 "
+"ついにオブジェクトのロードと格納に Hibernate を使うことができます。 "
 "<literal>main()</literal> メソッドを持つ <literal>EventManager</literal> クラ"
 "スを書きます:"
 
-#. Tag: programlisting
-#: tutorial.xml:493
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial;\n"
-"\n"
-"import org.hibernate.Session;\n"
-"\n"
-"import java.util.*;\n"
-"\n"
-"import org.hibernate.tutorial.domain.Event;\n"
-"import org.hibernate.tutorial.util.HibernateUtil;\n"
-"\n"
-"public class EventManager {\n"
-"\n"
-"    public static void main(String[] args) {\n"
-"        EventManager mgr = new EventManager();\n"
-"\n"
-"        if (args[0].equals(\"store\")) {\n"
-"            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-"        }\n"
-"\n"
-"        HibernateUtil.getSessionFactory().close();\n"
-"    }\n"
-"\n"
-"    private void createAndStoreEvent(String title, Date theDate) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Event theEvent = new Event();\n"
-"        theEvent.setTitle(title);\n"
-"        theEvent.setDate(theDate);\n"
-"        session.save(theEvent);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:495
 #, fuzzy, no-c-format
 msgid ""
 "In <literal>createAndStoreEvent()</literal> we created a new <literal>Event</"
@@ -1047,13 +687,12 @@
 "takes care of the SQL and executes an <literal>INSERT</literal> on the "
 "database."
 msgstr ""
-"新しい <literal>Event</literal> オブジェクトを生成し、それをHibernateに渡しま"
-"す。 今ではHibernateがSQLを処理し、データベースで <literal>INSERT</literal> "
-"を実行します。 実行前に <literal>Session</literal> と <literal>Transaction</"
+"新しい <literal>Event</literal> オブジェクトを生成し、それを Hibernate に渡し"
+"ます。 Hibernate が SQL を処理し、データベースで <literal>INSERT</literal> を"
+"実行します。実行前にl <literal>Session</literal> と <literal>Transaction</"
 "literal> を処理するコードを確認してください。"
 
 #. Tag: para
-#: tutorial.xml:502
 #, fuzzy, no-c-format
 msgid ""
 "A <interface>org.hibernate.Session</interface> is designed to represent a "
@@ -1065,15 +704,15 @@
 "interfacename> API. In this particular case we are using JDBC-based "
 "transactional semantics, but it could also run with JTA."
 msgstr ""
-"<literal>Session</literal> は1つの作業単位(Unit of Work)です。 当分の間、話を"
-"簡単にするために、 <literal>Session</literal> と <literal>Transaction</"
-"literal> の対応を一対一と仮定します。 使用しているトランザクション・システム"
-"(このケースではJTAと共存できる単純なJDBC)からコードを保護するために、 "
-"Hibernate <literal>Session</literal> 上で利用可能な <literal>Transaction</"
-"literal> APIを使用します。"
+"<interface>org.hibernate.Session</interface> は1つの作業単位 (Unit of Work) "
+"です。当分の間、話を簡単にするために、 <interface>org.hibernate.Session</"
+"interface> と <literal>Transaction</literal> の対応を一対一と仮定します。使用"
+"しているトランザクションシステム(このケースでは JTA と共存できる単純な "
+"JDBC)からコードを保護するために、 Hibernate <literal>Session</literal> 上で"
+"利用可能な <interfacename>org.hibernate.Transaction</interfacename> API を使"
+"用します。"
 
 #. Tag: para
-#: tutorial.xml:515
 #, fuzzy, no-c-format
 msgid ""
 "What does <literal>sessionFactory.getCurrentSession()</literal> do? First, "
@@ -1085,17 +724,18 @@
 "xml</filename>? Due to that setting, the context of a current unit of work "
 "is bound to the current Java thread that executes the application."
 msgstr ""
-"<literal>sessionFactory.getCurrentSession()</literal> はなにをするのでしょう"
-"か? まず、いったん <literal>SessionFactory</literal> を取得し保持すれば "
-"( <literal>HibernateUtil</literal> のおかげで簡単です)、このメソッドを何度"
-"でも、 どこからでも呼び出すことが出来ます。 <literal>getCurrentSession()</"
-"literal> メソッドは常に「現在の」作業単位(Unit of Work)を返します。 "
-"<literal>hibernate.cfg.xml</literal> のこの機能の設定で、\"thread\"を指定した"
-"ことを思い出してください。 このため現在の作業単位のスコープは、このアプリケー"
-"ションを実行する現在のJavaスレッドです。 しかしこれで全てではありません。"
+"<literal>sessionFactory.getCurrentSession()</literal> は何をするのでしょう"
+"か?まず、いったん <interfacename>org.hibernate.SessionFactory</"
+"interfacename> を取得し保持すれば ( <literal>HibernateUtil</literal> のおか"
+"げで簡単です)、このメソッドを何度でも、どこからでも呼び出すことができます。 "
+"<literal>getCurrentSession()</literal> メソッドは常に「現在の」作業単位(Unit "
+"of Work)を返します。 <filename>src/main/resources/hibernate.cfg.xml</"
+"filename> のこの機能の設定で、\"thread\"を指定したことを思い出してください。"
+"このため現在の作業単位のスコープは、このアプリケーションを実行する現在の "
+"Java スレッドです。しかしこれで全てではありません。作業単位の開始時と終了時に"
+"はスコープも考慮する必要があります。"
 
 #. Tag: para
-#: tutorial.xml:529
 #, no-c-format
 msgid ""
 "Hibernate offers three methods of current session tracking. The \"thread\" "
@@ -1105,7 +745,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:538
 #, fuzzy, no-c-format
 msgid ""
 "A <interface>org.hibernate.Session</interface> begins when the first call to "
@@ -1117,19 +756,20 @@
 "new <interface>org.hibernate.Session</interface> and can start a new unit of "
 "work."
 msgstr ""
-"<literal>Session</literal> は最初に必要となったとき、つまり最初に "
-"<literal>getCurrentSession()</literal> が 呼ばれたときに開始します。 そのとき"
-"Hibernateにより現在のスレッドに結び付けられます。 トランザクションが終了(コ"
-"ミットもしくはロールバック)したとき、 Hibernateもスレッドから "
-"<literal>Session</literal> を切り離し、クローズします。 再び "
-"<literal>getCurrentSession()</literal> を呼ぶと、 新しい <literal>Session</"
-"literal> を取得して新しい作業単位をスタートできます。 この <emphasis>thread-"
-"bound</emphasis> プログラミング・モデルはHibernateを利用する上で最も人気があ"
-"ります。"
+"<interface>org.hibernate.Session</interface> は最初に必要となったとき、つまり"
+"最初に <literal>getCurrentSession()</literal> が呼ばれたときに開始します。そ"
+"のとき Hibernate により現在のスレッドに結び付けられます。トランザクションが終"
+"了(コミットもしくはロールバック)したとき、 Hibernate もスレッドから "
+"<interface>org.hibernate.Session</interface> を切り離し、クローズします。再"
+"び <literal>getCurrentSession()</literal> を呼ぶと、新しい <interface>org."
+"hibernate.Session</interface> を取得して新しい作業単位をスタートできます。こ"
+"の <emphasis>thread-bound</emphasis> プログラミングモデルは、コードのフレキシ"
+"ブルなレイヤリングを可能にするので、 Hibernate を利用する上で最も人気がありま"
+"す (このチュートリアルで後ほど触れますがトランザクション境界コードはデータア"
+"クセスコードとは区別されます)。"
 
 #. Tag: para
-#: tutorial.xml:551
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Related to the unit of work scope, should the Hibernate <interface>org."
 "hibernate.Session</interface> be used to execute one or several database "
@@ -1143,31 +783,31 @@
 "<emphasis>session-per-operation</emphasis> an anti-pattern. A real web "
 "application is shown later in the tutorial which will help illustrate this."
 msgstr ""
-"Related to the unit of work scope, should the Hibernate <literal>Session</"
-"literal> be used to execute one or several database operations? The above "
-"example uses one <literal>Session</literal> for one operation. This is pure "
-"coincidence, the example is just not complex enough to show any other "
-"approach. The scope of a Hibernate <literal>Session</literal> is flexible "
-"but you should never design your application to use a new Hibernate "
-"<literal>Session</literal> for <emphasis>every</emphasis> database "
-"operation. So even if you see it a few more times in the following (very "
-"trivial) examples, consider <emphasis>session-per-operation</emphasis> an "
-"anti-pattern. A real (web) application is shown later in this tutorial."
+"作業単位 (Unit of Work) の範囲に関して、 Hibernate の <interface>org."
+"hibernate.Session</interface> は1つまたはいくつかのデータベースオペレーション"
+"を実行するために使用されるべきでしょうか?上記の例は、1つのオペレーションで1"
+"つの <interface>org.hibernate.Session</interface> を使用します。これは純粋な"
+"偶然で、例はその他のアプローチを示すほど込み入っていません。 Hibernate の "
+"<interface>org.hibernate.Session</interface> の範囲は柔軟ですが、 <emphasis>"
+"全ての</emphasis> データベースオペレーションのために新しい Hibernate "
+"<interface>org.hibernate.Session</interface> を使用するようにアプリケーション"
+"をデザインするべきではありません。従って、もしそれを以下の (普通の) 例で何度"
+"か見たとしても、アンチパターンである <emphasis>オペレーション毎の Session</"
+"emphasis> を考慮してください。実際の (ウェブ) アプリケーションは、このチュー"
+"トリアルで後に見ることができます。"
 
 #. Tag: para
-#: tutorial.xml:568
 #, fuzzy, no-c-format
 msgid ""
-"See <xref linkend=\"transactions\"/> for more information about transaction "
+"See <xref linkend=\"transactions\" /> for more information about transaction "
 "handling and demarcation. The previous example also skipped any error "
 "handling and rollback."
 msgstr ""
 "トランザクションの扱いと境界の詳しい情報については、 <xref linkend="
-"\"transactions\"/> を見てください。 この例ではエラー処理やロールバックも割愛"
-"します。"
+"\"transactions\"/> を見てください。この例ではエラー処理やロールバックも割愛し"
+"ます。"
 
 #. Tag: para
-#: tutorial.xml:574
 #, no-c-format
 msgid ""
 "To run this, we will make use of the Maven exec plugin to call our class "
@@ -1176,100 +816,52 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:581
 #, no-c-format
 msgid "You may need to perform <command>mvn compile</command> first."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:586
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You should see Hibernate starting up and, depending on your configuration, "
 "lots of log output. Towards the end, the following line will be displayed:"
 msgstr ""
-"コンパイルすると、Hibernateがスタートし、あなたの設定によりますが、 多くのロ"
-"グ出力があるはずです。 その最後には以下の行があるでしょう:"
+"コンパイルすると、 Hibernate がスタートし、設定によりますが、多くのログ出力が"
+"あるはずです。その最後には以下の行があるでしょう:"
 
-#. Tag: programlisting
-#: tutorial.xml:591
-#, no-c-format
-msgid ""
-"<![CDATA[[java] Hibernate: insert into EVENTS (EVENT_DATE, title, EVENT_ID) "
-"values (?, ?, ?)]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:593
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "This is the <literal>INSERT</literal> executed by Hibernate."
-msgstr ""
+msgstr "HQL の <literal>INSERT</literal> 文の実行例です:"
 
 #. Tag: para
-#: tutorial.xml:597
 #, fuzzy, no-c-format
 msgid "To list stored events an option is added to the main method:"
 msgstr ""
-"それでは同じように格納されたイベントの一覧を見ようと思います。 そのためメイン"
+"それでは同じように格納されたイベントの一覧を見ようと思います。そのためメイン"
 "メソッドにオプションを追加します:"
 
-#. Tag: programlisting
-#: tutorial.xml:601
-#, no-c-format
-msgid ""
-"<![CDATA[        if (args[0].equals(\"store\")) {\n"
-"            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-"        }\n"
-"        else if (args[0].equals(\"list\")) {\n"
-"            List events = mgr.listEvents();\n"
-"            for (int i = 0; i < events.size(); i++) {\n"
-"                Event theEvent = (Event) events.get(i);\n"
-"                System.out.println(\n"
-"                        \"Event: \" + theEvent.getTitle() + \" Time: \" + "
-"theEvent.getDate()\n"
-"                );\n"
-"            }\n"
-"        }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:603
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A new <literal>listEvents() method is also added</literal>:"
 msgstr "新しい <literal>listEvents()メソッド</literal> も追加します。"
 
-#. Tag: programlisting
-#: tutorial.xml:607
-#, no-c-format
-msgid ""
-"<![CDATA[    private List listEvents() {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"        List result = session.createQuery(\"from Event\").list();\n"
-"        session.getTransaction().commit();\n"
-"        return result;\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:609
 #, fuzzy, no-c-format
 msgid ""
 "Here, we are using a Hibernate Query Language (HQL) query to load all "
 "existing <literal>Event</literal> objects from the database. Hibernate will "
 "generate the appropriate SQL, send it to the database and populate "
 "<literal>Event</literal> objects with the data. You can create more complex "
-"queries with HQL. See <xref linkend=\"queryhql\"/> for more information."
+"queries with HQL. See <xref linkend=\"queryhql\" /> for more information."
 msgstr ""
 "ここですることは、データベースから存在するすべての <literal>Event</literal> "
-"オブジェクトをロードするHQL (Hibernate Query Language) クエリを使うことで"
-"す。 Hibernateは適切なSQLを生成し、それをデータベースに送り、 そのデータを"
-"使って <literal>Event</literal> オブジェクトを生成します。 当然HQLでさらに複"
+"オブジェクトをロードする HQL (Hibernate Query Language) クエリを使うことで"
+"す。 Hibernate は適切な SQL を生成し、それをデータベースに送り、そのデータを"
+"使って <literal>Event</literal> オブジェクトを生成します。当然 HQL でさらに複"
 "雑なクエリを作成できます。"
 
 #. Tag: para
-#: tutorial.xml:617
 #, no-c-format
 msgid ""
 "Now we can call our new functionality, again using the Maven exec plugin: "
@@ -1278,58 +870,33 @@
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:627
 #, no-c-format
 msgid "Part 2 - Mapping associations"
 msgstr "パート2 - 関連のマッピング"
 
 #. Tag: para
-#: tutorial.xml:629
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "So far we have mapped a single persistent entity class to a table in "
 "isolation. Let's expand on that a bit and add some class associations. We "
 "will add people to the application and store a list of events in which they "
 "participate."
 msgstr ""
-"永続エンティティクラスをテーブルにマッピングしました。 さらにこの上にいくつか"
-"のクラスの関連を追加しましょう。 まず初めにアプリケーションに人々を追加し、彼"
+"永続エンティティクラスをテーブルにマッピングしました。さらにこの上にいくつか"
+"のクラスの関連を追加しましょう。まず初めにアプリケーションに人々を追加し、彼"
 "らが参加するイベントのリストを格納します。"
 
 #. Tag: title
-#: tutorial.xml:637
 #, no-c-format
 msgid "Mapping the Person class"
-msgstr "Personクラスのマッピング"
+msgstr "Person クラスのマッピング"
 
 #. Tag: para
-#: tutorial.xml:639
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The first cut of the <literal>Person</literal> class looks like this:"
 msgstr "最初の <literal>Person</literal> クラスは単純です:"
 
-#. Tag: programlisting
-#: tutorial.xml:643
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.domain;\n"
-"\n"
-"public class Person {\n"
-"\n"
-"    private Long id;\n"
-"    private int age;\n"
-"    private String firstname;\n"
-"    private String lastname;\n"
-"\n"
-"    public Person() {}\n"
-"\n"
-"    // Accessor methods for all properties, private setter for 'id'\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:645
 #, no-c-format
 msgid ""
 "Save this to a file named <filename>src/main/java/org/hibernate/tutorial/"
@@ -1337,65 +904,34 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:650
 #, no-c-format
 msgid ""
 "Next, create the new mapping file as <filename>src/main/resources/org/"
 "hibernate/tutorial/domain/Person.hbm.xml</filename>"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:655
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Person\" table=\"PERSON\">\n"
-"        <id name=\"id\" column=\"PERSON_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"age\"/>\n"
-"        <property name=\"firstname\"/>\n"
-"        <property name=\"lastname\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:657
 #, no-c-format
 msgid "Finally, add the new mapping to Hibernate's configuration:"
-msgstr "最後にHibernateの設定に新しいマッピングを追加してください:"
+msgstr "最後に Hibernate の設定に新しいマッピングを追加してください:"
 
-#. Tag: programlisting
-#: tutorial.xml:661
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<mapping resource=\"events/Event.hbm.xml\"/>\n"
-"<mapping resource=\"events/Person.hbm.xml\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:663
-#, fuzzy, no-c-format
-msgid ""
 "Create an association between these two entities. Persons can participate in "
 "events, and events have participants. The design questions you have to deal "
 "with are: directionality, multiplicity, and collection behavior."
 msgstr ""
-"それではこれら2つのエンティティ間の関連を作成します。 人々がイベントに参加で"
-"き、イベントが参加者を持つのは明らかです。 扱わなければならない設計の問題は、"
+"それではこれら2つのエンティティ間の関連を作成します。人々がイベントに参加で"
+"き、イベントが参加者を持つのは明らかです。扱わなければならない設計の問題は、"
 "方向、多重度、コレクションの振る舞いです。"
 
 #. Tag: title
-#: tutorial.xml:673
 #, no-c-format
 msgid "A unidirectional Set-based association"
-msgstr "単方向Setベース関連"
+msgstr "単方向 Set ベース関連"
 
 #. Tag: para
-#: tutorial.xml:675
 #, fuzzy, no-c-format
 msgid ""
 "By adding a collection of events to the <literal>Person</literal> class, you "
@@ -1406,32 +942,14 @@
 "Set</interfacename> because the collection will not contain duplicate "
 "elements and the ordering is not relevant to our examples:"
 msgstr ""
-"イベントのコレクションを <literal>Person</literal> クラスに追加します。 こう"
-"しておくと、明示的なクエリ、つまりわざわざ<literal>aPerson.getEvents()</"
-"literal>を呼び出さずに、 特定の人に紐付くイベントを簡単にナビゲートすることが"
-"できます。 私たちはJavaのコレクション、<literal>Set</literal> を使います。 コ"
-"レクションは重複要素を持たないし、順番は私たちには意味がないからです。"
+"イベントのコレクションを <literal>Person</literal> クラスに追加します。こうし"
+"ておくと、明示的なクエリ、つまりわざわざ <literal>aPerson.getEvents()</"
+"literal> を呼び出さずに、特定の人に紐付くイベントを簡単にナビゲートすることが"
+"できます。私たちは Java のコレクション、<interfacename>java.util.Set</"
+"interfacename> を使います。コレクションは重複要素を持たないし、順番は私たちに"
+"は意味がないからです。"
 
-#. Tag: programlisting
-#: tutorial.xml:686
-#, no-c-format
-msgid ""
-"<![CDATA[public class Person {\n"
-"\n"
-"    private Set events = new HashSet();\n"
-"\n"
-"    public Set getEvents() {\n"
-"        return events;\n"
-"    }\n"
-"\n"
-"    public void setEvents(Set events) {\n"
-"        this.events = events;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:688
 #, fuzzy, no-c-format
 msgid ""
 "Before mapping this association, let's consider the other side. We could "
@@ -1444,40 +962,19 @@
 "on both sides is called a <emphasis>many-to-many</emphasis> association. "
 "Hence, we use Hibernate's many-to-many mapping:"
 msgstr ""
-"この関連をマッピングする前に、反対側について考えてください。 明らかなことです"
-"が、今はこれを単方向にしただけです。 逆に、 <literal>Event</literal> 側にも別"
-"のコレクションを作ることもできます。 例えば <literal>anEvent.getParticipants"
-"()</literal> のように、 双方向にナビゲートしたければ、そうすることもできま"
-"す。 これは機能的にみて必要ではありません。 特定のイベントに関係するデータを"
-"取得する明確なクエリを、いつでも実行することが出来ました。 この設計の選択は開"
-"発者に任されていて、この議論により明らかなのは関連の多重度です。 つまり両側を"
-"「多」値にする、 <emphasis>多対多</emphasis> と呼ばれる関連です。 そのため"
-"Hibernateのmany-to-manyマッピングを使います:"
+"この関連をマッピングする前に、反対側について考えてください。明らかなことです"
+"が、今はこれを単方向にしただけです。逆に、 <literal>Event</literal> 側にも別"
+"のコレクションを作ることもできます。例えば <literal>anEvent.getParticipants()"
+"</literal> のように、双方向にナビゲートしたければ、そうすることもできます。こ"
+"れは機能的にみて必要ではありません。特定のイベントに関係するデータを取得する"
+"明確なクエリを、いつでも実行することが出来ました。この設計の選択は開発者に任"
+"されていて、この議論により明らかなのは関連の多重度です。つまり両側を「多」値"
+"にする、 <emphasis>多対多</emphasis> と呼ばれる関連です。そのため Hibernate "
+"の多対多マッピングを使います:"
 
-#. Tag: programlisting
-#: tutorial.xml:701
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\" table=\"PERSON\">\n"
-"    <id name=\"id\" column=\"PERSON_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"age\"/>\n"
-"    <property name=\"firstname\"/>\n"
-"    <property name=\"lastname\"/>\n"
-"\n"
-"    <set name=\"events\" table=\"PERSON_EVENT\">\n"
-"        <key column=\"PERSON_ID\"/>\n"
-"        <many-to-many column=\"EVENT_ID\" class=\"Event\"/>\n"
-"    </set>\n"
-"\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:703
-#, fuzzy, no-c-format
-msgid ""
 "Hibernate supports a broad range of collection mappings, a <literal>set</"
 "literal> being most common. For a many-to-many association, or <emphasis>n:"
 "m</emphasis> entity relationship, an association table is required. Each row "
@@ -1490,51 +987,28 @@
 "tell Hibernate the class of the objects in your collection (the class on the "
 "other side of the collection of references)."
 msgstr ""
-"Hibernateはありとあらゆる種類のコレクションマッピングをサポートしています"
-"が、 最も一般的なものが <literal>&lt;set&gt;</literal> です。 多対多関連(ま"
-"たは <emphasis>n:m</emphasis> エンティティリレーションシップ)には、 関連テー"
-"ブルが必要です。 このテーブルのそれぞれの行は、人とイベント間のリンクを表現し"
-"ます。 テーブル名は <literal>set</literal> 要素の <literal>table</literal> 属"
-"性で設定します。 人側の関連の識別子カラム名は <literal>&lt;key&gt;</literal> "
-"要素で、 イベント側のカラム名は <literal>&lt;many-to-many&gt;</literal> の "
-"<literal>column</literal> 属性で定義します。 Hibernateにコレクションのオブ"
-"ジェクトのクラス (正確には、参照のコレクションの反対側のクラス)を教えなけれ"
-"ばなりません。"
+"Hibernate はありとあらゆる種類のコレクションマッピングをサポートしています"
+"が、最も一般的なものが <literal>set</literal> です。 多対多関連(または "
+"<emphasis>n:m</emphasis> エンティティリレーションシップ)には、関連テーブルが"
+"必要です。このテーブルのそれぞれの行は、人とイベント間のリンクを表現します。"
+"テーブル名は <literal>set</literal> 要素の <literal>table</literal> 属性で設"
+"定します。人側の関連の識別子カラム名は <literal>key</literal> 要素で、イベン"
+"ト側のカラム名は <literal>many-to-many</literal> の <literal>column</"
+"literal> 属性で定義します。 Hibernate にコレクションのオブジェクトのクラス "
+"(正確には、参照のコレクションの反対側のクラス)を教えなければなりません。"
 
 #. Tag: para
-#: tutorial.xml:719
 #, no-c-format
 msgid "The database schema for this mapping is therefore:"
-msgstr "そのためこのマッピングのデータベーススキーマは以下のようになります。:"
+msgstr "そのためこのマッピングのデータベーススキーマは以下のようになります:"
 
-#. Tag: programlisting
-#: tutorial.xml:723
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"    _____________        __________________\n"
-"   |             |      |                  |       _____________\n"
-"   |   EVENTS    |      |   PERSON_EVENT   |      |             |\n"
-"   |_____________|      |__________________|      |    PERSON   |\n"
-"   |             |      |                  |      |_____________|\n"
-"   | *EVENT_ID   | <--> | *EVENT_ID        |      |             |\n"
-"   |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  |\n"
-"   |  TITLE      |      |__________________|      |  AGE        |\n"
-"   |_____________|                                |  FIRSTNAME  |\n"
-"                                                  |  LASTNAME   |\n"
-"                                                  |_____________|\n"
-" ]]>"
-msgstr ""
-
 #. Tag: title
-#: tutorial.xml:728
 #, no-c-format
 msgid "Working the association"
 msgstr "関連を働かせる"
 
 #. Tag: para
-#: tutorial.xml:730
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now we will bring some people and events together in a new method in "
 "<literal>EventManager</literal>:"
@@ -1542,25 +1016,7 @@
 "<literal>EventManager</literal> の新しいメソッドで人々とイベントを一緒にしま"
 "しょう:"
 
-#. Tag: programlisting
-#: tutorial.xml:734
-#, no-c-format
-msgid ""
-"<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session.load(Person.class, personId);\n"
-"        Event anEvent = (Event) session.load(Event.class, eventId);\n"
-"        aPerson.getEvents().add(anEvent);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:736
 #, fuzzy, no-c-format
 msgid ""
 "After loading a <literal>Person</literal> and an <literal>Event</literal>, "
@@ -1577,25 +1033,24 @@
 "of a unit of work, is called <emphasis>flushing</emphasis>. In our code, the "
 "unit of work ends with a commit, or rollback, of the database transaction."
 msgstr ""
-"<literal>Person</literal> と <literal>Event</literal> をロードした後、 普通の"
-"コレクションメソッドを使って単純にそのコレクションを修正してください。 ご覧の"
+"<literal>Person</literal> と <literal>Event</literal> をロードした後、普通の"
+"コレクションメソッドを使って単純にそのコレクションを修正してください。ご覧の"
 "とおり <literal>update()</literal> や <literal>save()</literal> の明示的な呼"
-"び出しはありません。 Hibernateは、修正されたことにより更新する必要のあるコレ"
-"クションを自動的に検知します。 これは <emphasis>自動ダーティチェック</"
-"emphasis> と呼ばれ、 オブジェクトの名前やdateプロパティを修正することで試すこ"
-"とも可能です。 それらが <emphasis>永続</emphasis> 状態にある限り、 つまり特定"
-"のHibernate <literal>Session</literal> にバインドされている限り (例えば作業"
-"単位(Unit of Work)の中で単にロードまたはセーブされた)、 Hibernateはどんな変"
-"更もモニターし、遅延書き込み(write-behind)でSQLを実行します。 通常、作業単位"
-"(Unit of Work)の最後にだけ行われるデータベースとメモリの状態を同期させる処理"
-"は、 <emphasis>フラッシュ</emphasis> と呼ばれます。 このコードでは、作業単位"
-"(Unit of Work)はデータベーストランザクションのコミット(もしくはロールバッ"
-"ク)で終了します。 これは、 <literal>CurrentSessionContext</literal> クラスに"
-"対して <literal>thread</literal> を設定したためです。"
+"び出しはありません。 Hibernate は、修正されたことにより更新する必要のあるコレ"
+"クションを自動的に検知します。これは <emphasis>自動ダーティチェック</"
+"emphasis> と呼ばれ、オブジェクトの名前や date プロパティを修正することで試す"
+"ことも可能です。それらが <emphasis>永続</emphasis> 状態にある限り、つまり特定"
+"の Hibernate <literal>Session</literal> にバインドされている限り (例えば作業"
+"単位 (Unit of Work) の中で単にロードまたはセーブされた)、 Hibernate はどんな"
+"変更もモニターし、遅延書き込み (write-behind) で SQL を実行します。通常、作業"
+"単位 (Unit of Work) の最後にだけ行われるデータベースとメモリの状態を同期させ"
+"る処理は、 <emphasis>フラッシュ</emphasis> と呼ばれます。このコードでは、作業"
+"単位 (Unit of Work) はデータベーストランザクションのコミット(もしくはロール"
+"バック)で終了します。これは、 <literal>CurrentSessionContext</literal> クラ"
+"スに対して <literal>thread</literal> を設定したためです。"
 
 #. Tag: para
-#: tutorial.xml:755
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can load person and event in different units of work. Or you can modify "
 "an object outside of a <interfacename>org.hibernate.Session</interfacename>, "
@@ -1603,65 +1058,28 @@
 "is called <emphasis>detached</emphasis>). You can even modify a collection "
 "when it is detached:"
 msgstr ""
-"異なる作業単位(Unit of Work)で人々とイベントをロードすることも当然できます。 "
-"そうでなければ、永続状態にないとき(以前に永続であったなら、この状態を "
-"<emphasis>分離(detached)</emphasis> と呼びます)、 <literal>Session</"
-"literal> の外部でオブジェクトを修正します。 分離されるときにはコレクションを"
-"変更することも可能です:"
+"異なる作業単位 (Unit of Work) で人々とイベントをロードすることも当然できま"
+"す。そうでなければ、永続状態にないとき(以前に永続であったなら、この状態を "
+"<emphasis>分離(detached)</emphasis> と呼びます)、 <interfacename>org."
+"hibernate.Session</interfacename> の外部でオブジェクトを修正します。分離され"
+"るときにはコレクションを変更することも可能です:"
 
-#. Tag: programlisting
-#: tutorial.xml:764
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session\n"
-"                .createQuery(\"select p from Person p left join fetch p."
-"events where p.id = :pid\")\n"
-"                .setParameter(\"pid\", personId)\n"
-"                .uniqueResult(); // Eager fetch the collection so we can use "
-"it detached\n"
-"        Event anEvent = (Event) session.load(Event.class, eventId);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"\n"
-"        // End of first unit of work\n"
-"\n"
-"        aPerson.getEvents().add(anEvent); // aPerson (and its collection) is "
-"detached\n"
-"\n"
-"        // Begin second unit of work\n"
-"\n"
-"        Session session2 = HibernateUtil.getSessionFactory()."
-"getCurrentSession();\n"
-"        session2.beginTransaction();\n"
-"        session2.update(aPerson); // Reattachment of aPerson\n"
-"\n"
-"        session2.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:766
-#, fuzzy, no-c-format
-msgid ""
 "The call to <literal>update</literal> makes a detached object persistent "
 "again by binding it to a new unit of work, so any modifications you made to "
 "it while detached can be saved to the database. This includes any "
 "modifications (additions/deletions) you made to a collection of that entity "
 "object."
 msgstr ""
-"<literal>update</literal> の呼び出しは分離オブジェクトを再び永続化します。 こ"
-"れは、新しい作業単位(Unit of Work)にバインドすると言えるでしょう。 そのため分"
-"離の間に加えられたどのような修正もデータベースにセーブできます。 エンティティ"
-"オブジェクトのコレクションへの修正(追加・削除)も同様にセーブできます。"
+"<literal>update</literal> の呼び出しは分離オブジェクトを再び永続化します。こ"
+"れは、新しい作業単位 (Unit of Work) にバインドすると言えるでしょう。そのため"
+"分離の間に加えられたどのような修正もデータベースにセーブできます。エンティ"
+"ティオブジェクトのコレクションへの修正(追加・削除)も同様にセーブできます。"
 
 #. Tag: para
-#: tutorial.xml:775
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is not much use in our example, but it is an important concept you can "
 "incorporate into your own application. Complete this exercise by adding a "
@@ -1670,31 +1088,16 @@
 "an event - the <literal>save()</literal> method returns it (you might have "
 "to modify some of the previous methods to return that identifier):"
 msgstr ""
-"これは今はあまり使いみちがありませんが、 自分のアプリケーションの設計に組み込"
-"むことができる重要なコンセプトです。 それではこのエクササイズの最後に、 "
-"<literal>EventManager</literal> のメインメソッドに新しいアクションを追加して "
-"コマンドラインから呼び出してみましょう。 人やイベントの識別子が必要なら、 "
+"これは今はあまり使いみちがありませんが、自分のアプリケーションの設計に組み込"
+"むことができる重要なコンセプトです。それではこのエクササイズの最後に、 "
+"<literal>EventManager</literal> のメインメソッドに新しいアクションを追加して"
+"コマンドラインから呼び出してみましょう。人やイベントの識別子が必要なら、 "
 "<literal>save()</literal> メソッドが返してくれます (場合によっては識別子を返"
 "すためにメソッドを修正する必要があるかもしれません)。"
 
-#. Tag: programlisting
-#: tutorial.xml:783
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[        else if (args[0].equals(\"addpersontoevent\")) {\n"
-"            Long eventId = mgr.createAndStoreEvent(\"My Event\", new Date"
-"());\n"
-"            Long personId = mgr.createAndStorePerson(\"Foo\", \"Bar\");\n"
-"            mgr.addPersonToEvent(personId, eventId);\n"
-"            System.out.println(\"Added person \" + personId + \" to event \" "
-"+ eventId);\n"
-"        }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:785
-#, fuzzy, no-c-format
-msgid ""
 "This is an example of an association between two equally important classes : "
 "two entities. As mentioned earlier, there are other classes and types in a "
 "typical model, usually \"less important\". Some you have already seen, like "
@@ -1709,38 +1112,35 @@
 "fact, in a Hibernate application all JDK classes are considered value types."
 msgstr ""
 "これは同じように重要な2つのクラス、つまり2つのエンティティ間の関連の例でし"
-"た。 前に述べたように、典型的なモデルには、普通「比較的重要ではない」他のクラ"
-"スと型があります。 これまでに見たような <literal>int</literal> や "
-"<literal>String</literal> のようなものです。 このようなクラスを <emphasis>値"
-"型</emphasis> と言います。 このインスタンスは特定のエンティティに <emphasis>"
-"依存</emphasis> します。 この型のインスタンスは独自のIDを持ちませんし、 エン"
-"ティティ間で共有されることもありません (ファーストネームが同じだったとして"
-"も、2人の人は同じ <literal>firstname</literal> オブジェクトを参照しませ"
-"ん)。 値型はもちろんJDK内に見つかりますが、それだけではなく (実際、"
-"HibernateアプリケーションにおいてすべてのJDKクラスは値型と見なせます)、 例え"
-"ば <literal>Address</literal> や <literal>MonetaryAmount</literal> のような独"
-"自の依存クラスを書くこともできます。"
+"た。前に述べたように、典型的なモデルには、普通「比較的重要ではない」他のクラ"
+"スと型があります。これまでに見たような <literal>int</literal> や "
+"<classname>java.lang.String</classname> のようなものです。このようなクラスを "
+"<emphasis>値型</emphasis> と言います。このインスタンスは特定のエンティティに "
+"<emphasis>依存</emphasis> します。この型のインスタンスは独自の ID を持ちませ"
+"んし、エンティティ間で共有されることもありません (ファーストネームが同じだっ"
+"たとしても、2人の人は同じ <literal>firstname</literal> オブジェクトを参照しま"
+"せん)。値型はもちろん JDK 内に見つかりますが、それだけではなく (実際、 "
+"Hibernate アプリケーションにおいてすべての JDK クラスは値型と見なせます)、 "
+"例えば <literal>Address</literal> や <literal>MonetaryAmount</literal> のよう"
+"な独自の依存クラスを書くこともできます。"
 
 #. Tag: para
-#: tutorial.xml:803
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also design a collection of value types. This is conceptually "
 "different from a collection of references to other entities, but looks "
 "almost the same in Java."
 msgstr ""
-"値型のコレクションを設計することもできます。 これは他のエンティティへの参照の"
-"コレクションとは概念的に非常に異なりますが、 Javaではほとんど同じように見えま"
-"す。"
+"値型のコレクションを設計することもできます。これは他のエンティティへの参照の"
+"コレクションとは概念的に非常に異なりますが、 Java ではほとんど同じように見え"
+"ます。"
 
 #. Tag: title
-#: tutorial.xml:812
 #, no-c-format
 msgid "Collection of values"
 msgstr "値のコレクション"
 
 #. Tag: para
-#: tutorial.xml:814
 #, no-c-format
 msgid ""
 "Let's add a collection of email addresses to the <literal>Person</literal> "
@@ -1748,41 +1148,14 @@
 "interfacename> of <classname>java.lang.String</classname> instances:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:820
-#, no-c-format
-msgid ""
-"<![CDATA[    private Set emailAddresses = new HashSet();\n"
-"\n"
-"    public Set getEmailAddresses() {\n"
-"        return emailAddresses;\n"
-"    }\n"
-"\n"
-"    public void setEmailAddresses(Set emailAddresses) {\n"
-"        this.emailAddresses = emailAddresses;\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:822
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The mapping of this <literal>Set</literal> is as follows:"
 msgstr "この <literal>Set</literal> のマッピングです:"
 
-#. Tag: programlisting
-#: tutorial.xml:826
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[        <set name=\"emailAddresses\" table=\"PERSON_EMAIL_ADDR\">\n"
-"            <key column=\"PERSON_ID\"/>\n"
-"            <element type=\"string\" column=\"EMAIL_ADDR\"/>\n"
-"        </set>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:828
-#, fuzzy, no-c-format
-msgid ""
 "The difference compared with the earlier mapping is the use of the "
 "<literal>element</literal> part which tells Hibernate that the collection "
 "does not contain references to another entity, but is rather a collection "
@@ -1796,91 +1169,42 @@
 "address values will actually be stored."
 msgstr ""
 "前のマッピングと比べて違うのは <literal>element</literal> の部分ですが、 "
-"Hibernateにこのコレクションが他のエンティティへの参照を含まず、 "
-"<literal>String</literal> 型の要素のコレクションを含むことを教えます。 (小文"
-"字の名前(string)はHibernateのマッピング型またはコンバータであるということで"
-"す)。 繰り返しますが、<literal>set</literal> 要素の <literal>table</"
-"literal> 属性は、 コレクションのためのテーブル名を指定します。 <literal>key</"
-"literal> 要素はコレクションテーブルの外部キーカラム名を定義します。 "
-"<literal>element</literal> 要素の <literal>column</literal> 属性は "
-"<literal>String</literal> の値が実際に格納されるカラムの名前を定義します。"
+"Hibernate にこのコレクションが他のエンティティへの参照を含まず、 "
+"<literal>string</literal> 型の要素のコレクションを含むことを教えます(小文字"
+"の名前 (string) は Hibernate のマッピング型またはコンバータであるということで"
+"す)。繰り返しますが、<literal>set</literal> 要素の <literal>table</literal> "
+"属性は、コレクションのためのテーブル名を指定します。 <literal>key</literal> "
+"要素はコレクションテーブルの外部キーカラム名を定義します。 <literal>element</"
+"literal> 要素の <literal>column</literal> 属性は <literal>string</literal> の"
+"値が実際に格納されるカラムの名前を定義します。"
 
 #. Tag: para
-#: tutorial.xml:844
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is the updated schema:"
 msgstr "更新したスキーマを見てください:"
 
-#. Tag: programlisting
-#: tutorial.xml:848
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"  _____________        __________________\n"
-" |             |      |                  |       _____________\n"
-" |   EVENTS    |      |   PERSON_EVENT   |      |             |       "
-"___________________\n"
-" |_____________|      |__________________|      |    PERSON   |      "
-"|                   |\n"
-" |             |      |                  |      |_____________|      | "
-"PERSON_EMAIL_ADDR |\n"
-" | *EVENT_ID   | <--> | *EVENT_ID        |      |             |      |"
-"___________________|\n"
-" |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  | <--> |  "
-"*PERSON_ID       |\n"
-" |  TITLE      |      |__________________|      |  AGE        |      |  "
-"*EMAIL_ADDR      |\n"
-" |_____________|                                |  FIRSTNAME  |      |"
-"___________________|\n"
-"                                                |  LASTNAME   |\n"
-"                                                |_____________|\n"
-" ]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:850
-#, fuzzy, no-c-format
-msgid ""
 "You can see that the primary key of the collection table is in fact a "
 "composite key that uses both columns. This also implies that there cannot be "
 "duplicate email addresses per person, which is exactly the semantics we need "
 "for a set in Java."
 msgstr ""
 "コレクションテーブルの主キーは、実際は両方のカラムを使った複合キーであること"
-"がわかります。 これは人ごとにEメールアドレスが重複できないということで、 Java"
-"のsetに要求されるセマンティクスそのものです。"
+"がわかります。これは人ごとに E メールアドレスが重複できないということで、 "
+"Java の set に要求されるセマンティクスそのものです。"
 
 #. Tag: para
-#: tutorial.xml:856
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can now try to add elements to this collection, just like we did before "
 "by linking persons and events. It is the same code in Java:"
 msgstr ""
-"以前人とイベントを関連づけたときと全く同じように、 今や試しにコレクションに要"
-"素を追加することができるようになりました。 両方ともJavaでは同じコードです。"
+"以前人とイベントを関連づけたときと全く同じように、今や試しにコレクションに要"
+"素を追加することができるようになりました。 両方とも Java では同じコードです。"
 
-#. Tag: programlisting
-#: tutorial.xml:861
-#, no-c-format
-msgid ""
-"<![CDATA[    private void addEmailToPerson(Long personId, String "
-"emailAddress) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session.load(Person.class, personId);\n"
-"        // adding to the emailAddress collection might trigger a lazy load "
-"of the collection\n"
-"        aPerson.getEmailAddresses().add(emailAddress);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:863
 #, fuzzy, no-c-format
 msgid ""
 "This time we did not use a <emphasis>fetch</emphasis> query to initialize "
@@ -1888,43 +1212,40 @@
 "fetch."
 msgstr ""
 "今回、コレクションの初期化に <emphasis>fetch</emphasis> クエリを使用しません"
-"でした。 そのため、getterメソッドの呼び出しによってコレクションを初期化するた"
-"めのSELECTが 実行されるので、コレクションに要素を追加できます。 SQLのログを監"
-"視して、即時フェッチを使って最適化してください。"
+"でした。そのため、 getter メソッドの呼び出しによってコレクションを初期化する"
+"ための SELECT が実行されるので、コレクションに要素を追加できます。 SQL のログ"
+"を監視して、即時フェッチを使って最適化してください。"
 
 #. Tag: title
-#: tutorial.xml:872
 #, no-c-format
 msgid "Bi-directional associations"
 msgstr "双方向関連"
 
 #. Tag: para
-#: tutorial.xml:874
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next you will map a bi-directional association. You will make the "
 "association between person and event work from both sides in Java. The "
 "database schema does not change, so you will still have many-to-many "
 "multiplicity."
 msgstr ""
-"次に双方向関連をマッピングします。 Javaで両側から人とイベントの関連を動作させ"
-"ます。 もちろん、データベーススキーマは変わりませんが、多重度は多対多のままで"
-"す。 リレーショナルデータベースはネットワークプログラミング言語よりも柔軟なの"
-"で、 ナビゲーションの方向のようなものを必要としません。 データはあらゆるの方"
-"法で見たり復元できるということです。"
+"次に双方向関連をマッピングします。 Java で両側から人とイベントの関連を動作さ"
+"せます。もちろん、データベーススキーマは変わりませんが、多重度は多対多のまま"
+"です。"
 
 #. Tag: para
-#: tutorial.xml:882
 #, no-c-format
 msgid ""
 "A relational database is more flexible than a network programming language, "
 "in that it does not need a navigation direction; data can be viewed and "
 "retrieved in any possible way."
 msgstr ""
+"リレーショナルデータベースはネットワークプログラミング言語よりも柔軟なので、"
+"ナビゲーションの方向のようなものを必要としません。データはあらゆる方法で見た"
+"り復元できるということです。"
 
 #. Tag: para
-#: tutorial.xml:890
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, add a collection of participants to the <literal>Event</literal> "
 "class:"
@@ -1932,45 +1253,17 @@
 "まず <literal>Event</literal> イベントクラスに参加者のコレクションを追加しま"
 "す:"
 
-#. Tag: programlisting
-#: tutorial.xml:895
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    private Set participants = new HashSet();\n"
-"\n"
-"    public Set getParticipants() {\n"
-"        return participants;\n"
-"    }\n"
-"\n"
-"    public void setParticipants(Set participants) {\n"
-"        this.participants = participants;\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:897
-#, fuzzy, no-c-format
-msgid ""
 "Now map this side of the association in <literal>Event.hbm.xml</literal>."
 msgstr ""
 "それでは <literal>Event.hbm.xml</literal> で関連のこちら側をマッピングしてく"
 "ださい。"
 
-#. Tag: programlisting
-#: tutorial.xml:901
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[        <set name=\"participants\" table=\"PERSON_EVENT\" inverse="
-"\"true\">\n"
-"            <key column=\"EVENT_ID\"/>\n"
-"            <many-to-many column=\"PERSON_ID\" class=\"events.Person\"/>\n"
-"        </set>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:903
-#, fuzzy, no-c-format
-msgid ""
 "These are normal <literal>set</literal> mappings in both mapping documents. "
 "Notice that the column names in <literal>key</literal> and <literal>many-to-"
 "many</literal> swap in both mapping documents. The most important addition "
@@ -1978,16 +1271,15 @@
 "<literal>set</literal> element of the <literal>Event</literal>'s collection "
 "mapping."
 msgstr ""
-"ご覧のとおり、いずれのマッピングドキュメント(XMLファイル)でも、普通の "
+"ご覧のとおり、いずれのマッピングドキュメント (XMLファイル) でも、普通の "
 "<literal>set</literal> マッピングを使っています。 <literal>key</literal> と "
-"<literal>many-to-many</literal> のカラム名が、 両方のマッピングドキュメントで"
-"入れ替えになっていることに注目してください。 ここで最も重要な追加項目は、 "
+"<literal>many-to-many</literal> のカラム名が、両方のマッピングドキュメントで"
+"入れ替えになっていることに注目してください。ここで最も重要な追加項目は、 "
 "<literal>Event</literal> のコレクションマッピングの <literal>set</literal> 要"
 "素にある <literal>inverse=\"true\"</literal> 属性です。"
 
 #. Tag: para
-#: tutorial.xml:911
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What this means is that Hibernate should take the other side, the "
 "<literal>Person</literal> class, when it needs to find out information about "
@@ -1995,19 +1287,17 @@
 "see how the bi-directional link between our two entities is created."
 msgstr ""
 "この指定の意味は、2つの間のエンティティ間のリンクについての情報を探す必要があ"
-"るとき、 Hibernateは反対側のエンティティ、つまり <literal>Person</literal> ク"
-"ラスから探すということです。 一度2つのエンティティ間の双方向リンクがどのよう"
-"に作成されるかがわかれば、 これを理解することはとても簡単です。"
+"るとき、 Hibernate は反対側のエンティティ、つまり <literal>Person</literal> "
+"クラスから探すということです。一度2つのエンティティ間の双方向リンクがどのよう"
+"に作成されるかがわかれば、これを理解することはとても簡単です。"
 
 #. Tag: title
-#: tutorial.xml:920
 #, no-c-format
 msgid "Working bi-directional links"
 msgstr "双方向リンクの動作"
 
 #. Tag: para
-#: tutorial.xml:922
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, keep in mind that Hibernate does not affect normal Java semantics. "
 "How did we create a link between a <literal>Person</literal> and an "
@@ -2019,68 +1309,42 @@
 "literal>. This process of \"setting the link on both sides\" is absolutely "
 "necessary with bi-directional links."
 msgstr ""
-"まず、Hibernateが通常のJavaのセマンティクスに影響を及ぼさないことを心に留めて"
-"おいてください。 私たちは、単方向の例としてどのように <literal>Person</"
+"まず、 Hibernate が通常の Java のセマンティクスに影響を及ぼさないことを心に留"
+"めておいてください。私たちは、単方向の例としてどのように <literal>Person</"
 "literal> と <literal>Event</literal> の間のリンクを作成したでしょうか? "
 "<literal>Person</literal> のインスタンスのイベントへの参照のコレクションに "
-"<literal>Event</literal> のインスタンスを追加しました。 そのためこのリンクを"
-"双方向にしたければ、 当たり前ですが反対側にも同じことをしなければなりませ"
-"ん。 <literal>Event</literal> のコレクションに <literal>Person</literal> へ"
-"の 参照を追加するということです。 この「両側でリンクを設定すること」は絶対に"
-"必要なので、決して忘れないでください。"
+"<literal>Event</literal> のインスタンスを追加しました。そのためこのリンクを双"
+"方向にしたければ、当たり前ですが反対側にも同じことをしなければなりません。 "
+"<literal>Event</literal> のコレクションに <literal>Person</literal> への参照"
+"を追加するということです。この「両側でリンクを設定すること」は絶対に必要なの"
+"で、決して忘れないでください。"
 
 #. Tag: para
-#: tutorial.xml:932
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Many developers program defensively and create link management methods to "
 "correctly set both sides (for example, in <literal>Person</literal>):"
 msgstr ""
-"多くの開発者は慎重にプログラムするので、 エンティティの両側に正しく関連を設定"
-"するリンク管理メソッドを作成します。 例えば <literal>Person</literal> では以"
-"下のようになります。:"
+"多くの開発者は慎重にプログラムするので、エンティティの両側に正しく関連を設定"
+"するリンク管理メソッドを作成します。例えば <literal>Person</literal> では以下"
+"のようになります。:"
 
-#. Tag: programlisting
-#: tutorial.xml:937
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    protected Set getEvents() {\n"
-"        return events;\n"
-"    }\n"
-"\n"
-"    protected void setEvents(Set events) {\n"
-"        this.events = events;\n"
-"    }\n"
-"\n"
-"    public void addToEvent(Event event) {\n"
-"        this.getEvents().add(event);\n"
-"        event.getParticipants().add(this);\n"
-"    }\n"
-"\n"
-"    public void removeFromEvent(Event event) {\n"
-"        this.getEvents().remove(event);\n"
-"        event.getParticipants().remove(this);\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:939
-#, fuzzy, no-c-format
-msgid ""
 "The get and set methods for the collection are now protected. This allows "
 "classes in the same package and subclasses to still access the methods, but "
 "prevents everybody else from altering the collections directly. Repeat the "
 "steps for the collection on the other side."
 msgstr ""
-"コレクションのゲットとセットメソッドが現在protectedになっていることに注意して"
-"ください。 これは同じパッケージのクラスやサブクラスのメソッドは依然アクセスが"
-"可能ですが、 (ほとんど)そのパッケージ外のどのクラスでも直接そのコレクション"
-"を台無しにすることを防ぎます。 おそらく反対側のコレクションにも同じことをした"
-"方がいいでしょう。"
+"コレクションのゲットとセットメソッドが現在 protected になっていることに注意し"
+"てください。これは同じパッケージのクラスやサブクラスのメソッドは依然アクセス"
+"が可能ですが、 (ほとんど) そのパッケージ外のどのクラスでも直接そのコレク"
+"ションを台無しにすることを防ぎます。おそらく反対側のコレクションにも同じこと"
+"をした方がいいでしょう。"
 
 #. Tag: para
-#: tutorial.xml:946
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What about the <literal>inverse</literal> mapping attribute? For you, and "
 "for Java, a bi-directional link is simply a matter of setting the references "
@@ -2095,28 +1359,26 @@
 "as <literal>inverse</literal>. In a one-to-many association it has to be the "
 "many-side, and in many-to-many association you can select either side."
 msgstr ""
-"<literal>inverse</literal> マッピング属性とはいったい何でしょうか? 開発者と"
-"Javaにとっては、双方向リンクは単に両側の参照を正しく設定するということです。 "
-"しかしHibernateは(制約違反を避けるために)SQLの <literal>INSERT</literal> "
-"と <literal>UPDATE</literal> 文を正確に変更するための十分な情報を持っていない"
-"ので、 双方向関連プロパティを扱うための何らかの助けを必要とします。 関連の片"
-"側を <literal>inverse</literal> に設定することで、Hibernateは基本的には設定し"
-"た側を無視し、 反対側の <emphasis>鏡</emphasis> として考えます。 これだけで、"
-"Hibernateは方向を持つナビゲーションモデルをSQLデータベーススキーマへ変換する"
-"ときの すべての問題にうまく対処できます。 覚えておかなければならないルールは"
-"簡単です。 双方向関連は必ず片側を <literal>inverse</literal> にする必要がある"
-"ということです。 一対多関連ではそれは多側でなければなりません。 多対多関連で"
-"はどちら側でも構いません。どちらでも違いはありません。"
+"<literal>inverse</literal> マッピング属性とはいったい何でしょうか?開発者と "
+"Java にとっては、双方向リンクは単に両側の参照を正しく設定するということです。"
+"しかし Hibernate は(制約違反を避けるために) SQL の <literal>INSERT</"
+"literal> と <literal>UPDATE</literal> 文を正確に変更するための十分な情報を"
+"持っていないので、双方向関連プロパティを扱うための何らかの助けを必要としま"
+"す。関連の片側を <literal>inverse</literal> に設定することで、 Hibernate は基"
+"本的には設定した側を無視し、反対側の <emphasis>鏡</emphasis> として考えます。"
+"これだけで、 Hibernate は方向を持つナビゲーションモデルを SQL データベースス"
+"キーマへ変換するときのすべての問題にうまく対処できます。覚えておかなければな"
+"らないルールは簡単です。双方向関連は必ず片側を <literal>inverse</literal> に"
+"する必要があるということです。一対多関連ではそれは多側でなければなりません。"
+"多対多関連ではどちら側でも構いません。どちらでも違いはありません。"
 
 #. Tag: title
-#: tutorial.xml:962
 #, no-c-format
 msgid "Part 3 - The EventManager web application"
-msgstr "パート3 - EventManager Webアプリケーション"
+msgstr "パート3 - EventManager Web アプリケーション"
 
 #. Tag: para
-#: tutorial.xml:964
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A Hibernate web application uses <literal>Session</literal> and "
 "<literal>Transaction</literal> almost like a standalone application. "
@@ -2124,76 +1386,29 @@
 "<literal>EventManagerServlet</literal>. This servlet can list all events "
 "stored in the database, and it provides an HTML form to enter new events."
 msgstr ""
-"HibernateのWebアプリケーションは、スタンドアローンのアプリケーションのように "
-"<literal>Session</literal> と <literal>Transaction</literal> を使用します。 "
-"しかしいくつかの一般的なパターンが役立ちます。 ここで "
-"<literal>EventManagerServlet</literal> を作成します。このサーブレットは、 "
-"データベースに格納した全てのイベントをリストにでき、さらにHTMLフォームから新"
-"しいイベントを入力できるものです。"
+"Hibernate の Web アプリケーションは、スタンドアローンのアプリケーションのよう"
+"に <literal>Session</literal> と <literal>Transaction</literal> を使用しま"
+"す。しかしいくつかの一般的なパターンが役立ちます。ここで "
+"<literal>EventManagerServlet</literal> を作成します。このサーブレットは、デー"
+"タベースに格納した全てのイベントをリストにでき、さらに HTML フォームから新し"
+"いイベントを入力できるものです。"
 
 #. Tag: title
-#: tutorial.xml:972
 #, no-c-format
 msgid "Writing the basic servlet"
-msgstr "基本的なServletの記述"
+msgstr "基本的な Servlet の記述"
 
 #. Tag: para
-#: tutorial.xml:974
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First we need create our basic processing servlet. Since our servlet only "
 "handles HTTP <literal>GET</literal> requests, we will only implement the "
 "<literal>doGet()</literal> method:"
 msgstr ""
-"ServletはHTTPの <literal>GET</literal> リクエストのみを処理するので、 "
+"Servlet は HTTP の <literal>GET</literal> リクエストのみを処理するので、 "
 "<literal>doGet()</literal> を実装します。"
 
-#. Tag: programlisting
-#: tutorial.xml:980
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.web;\n"
-"\n"
-"// Imports\n"
-"\n"
-"public class EventManagerServlet extends HttpServlet {\n"
-"\n"
-"    protected void doGet(\n"
-"            HttpServletRequest request,\n"
-"            HttpServletResponse response) throws ServletException, "
-"IOException {\n"
-"\n"
-"        SimpleDateFormat dateFormatter = new SimpleDateFormat( \"dd.MM.yyyy"
-"\" );\n"
-"\n"
-"        try {\n"
-"            // Begin unit of work\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"beginTransaction();\n"
-"\n"
-"            // Process request and render page...\n"
-"\n"
-"            // End unit of work\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"getTransaction().commit();\n"
-"        }\n"
-"        catch (Exception ex) {\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"getTransaction().rollback();\n"
-"            if ( ServletException.class.isInstance( ex ) ) {\n"
-"                throw ( ServletException ) ex;\n"
-"            }\n"
-"            else {\n"
-"                throw new ServletException( ex );\n"
-"            }\n"
-"        }\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:982
 #, no-c-format
 msgid ""
 "Save this servlet as <filename>src/main/java/org/hibernate/tutorial/web/"
@@ -2201,8 +1416,7 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:987
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The pattern applied here is called <emphasis>session-per-request</emphasis>. "
 "When a request hits the servlet, a new Hibernate <literal>Session</literal> "
@@ -2211,16 +1425,15 @@
 "started. All data access occurs inside a transaction irrespective of whether "
 "the data is read or written. Do not use the auto-commit mode in applications."
 msgstr ""
-"これは <emphasis>session-per-request</emphasis> というパターンです。 Servlet"
+"これは <emphasis>session-per-request</emphasis> というパターンです。 Servlet "
 "がリクエストを受け取ると、 <literal>SessionFactory</literal> の "
-"<literal>getCurrentSession()</literal> の最初の呼び出しで、 Hibernateの新し"
-"い <literal>Session</literal> が開かれます。 そのときデータベーストランザク"
-"ションが開始されます。 データの読み書きに関わらず、すべてのデータアクセスはト"
-"ランザクション内で行います。 (アプリケーション内ではオートコミットモードを使"
-"用しません)。"
+"<literal>getCurrentSession()</literal> の最初の呼び出しで、 Hibernate の新し"
+"い <literal>Session</literal> が開かれます。そのときデータベーストランザク"
+"ションが開始されます。データの読み書きに関わらず、すべてのデータアクセスはト"
+"ランザクション内で行います(アプリケーション内ではオートコミットモードを使用"
+"しません)。"
 
 #. Tag: para
-#: tutorial.xml:996
 #, no-c-format
 msgid ""
 "Do <emphasis>not</emphasis> use a new Hibernate <literal>Session</literal> "
@@ -2228,24 +1441,23 @@
 "that is scoped to the whole request. Use <literal>getCurrentSession()</"
 "literal>, so that it is automatically bound to the current Java thread."
 msgstr ""
-"Do <emphasis>not</emphasis> use a new Hibernate <literal>Session</literal> "
-"for every database operation. Use one Hibernate <literal>Session</literal> "
-"that is scoped to the whole request. Use <literal>getCurrentSession()</"
-"literal>, so that it is automatically bound to the current Java thread."
+"全てのデータベースオペレーションで新しい Hibernate <literal>Session</"
+"literal> を使用 <emphasis>しないでください</emphasis> 。全てのリクエストで機"
+"能する、1つの Hibernate <literal>Session</literal> を使用してください。自動"
+"的に現在の Java スレッドにバインドされるので、 <literal>getCurrentSession()</"
+"literal> を使用してください。"
 
 #. Tag: para
-#: tutorial.xml:1003
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next, the possible actions of the request are processed and the response "
 "HTML is rendered. We will get to that part soon."
 msgstr ""
-"次に、リクエストのアクションは処理され、レスポンスであるHTMLが描画されます。 "
-"これについてはすぐに説明します。"
+"次に、リクエストのアクションは処理され、レスポンスである HTML が描画されま"
+"す。これについてはすぐに説明します。"
 
 #. Tag: para
-#: tutorial.xml:1008
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, the unit of work ends when processing and rendering are complete. "
 "If any problems occurred during processing or rendering, an exception will "
@@ -2256,69 +1468,31 @@
 "called <emphasis>Open Session in View</emphasis>. You will need it as soon "
 "as you consider rendering your view in JSP, not in a servlet."
 msgstr ""
-"最後にリクエストの処理とHTML描画が完了したときに、作業単位(Unit of Work)を終"
-"了します。 もし処理や描画中に問題が発生した場合、exceptionが投げられてデータ"
-"ベーストランザクションをロールバックします。 これで <literal>session-per-"
-"request</literal> パターンが完了します。 全てのサーブレットにトランザクション"
+"最後にリクエストの処理と HTML 描画が完了したときに、作業単位 (Unit of Work) "
+"を終了します。もし処理や描画中に問題が発生した場合、例外が送出されててデータ"
+"ベーストランザクションをロールバックします。これで <literal>session-per-"
+"request</literal> パターンが完了します。全てのサーブレットにトランザクション"
 "境界のコードを書く代わりに、サーブレットフィルタに記述することも可能です。 "
 "<emphasis>Open Session in View</emphasis> と呼ばれるこのパターンについては、 "
-"HibernateのWebサイトやWikiを参照してください。 サーブレットではなくJSPでHTML"
-"描画をしようとすると、すぐにこのパターンについての情報が必要になるでしょう。"
+"Hibernate の Web サイトや Wiki を参照してください。サーブレットではなく JSP "
+"で HTML 描画をしようとすると、すぐにこのパターンについての情報が必要になるで"
+"しょう。"
 
 #. Tag: title
-#: tutorial.xml:1022
 #, no-c-format
 msgid "Processing and rendering"
 msgstr "処理と描画"
 
 #. Tag: para
-#: tutorial.xml:1024
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now you can implement the processing of the request and the rendering of the "
 "page."
 msgstr "では、リクエストの処理とページの描画を実装します。"
 
-#. Tag: programlisting
-#: tutorial.xml:1028
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[        // Write HTML header\n"
-"        PrintWriter out = response.getWriter();\n"
-"        out.println(\"<html><head><title>Event Manager</title></head><body>"
-"\");\n"
-"\n"
-"        // Handle actions\n"
-"        if ( \"store\".equals(request.getParameter(\"action\")) ) {\n"
-"\n"
-"            String eventTitle = request.getParameter(\"eventTitle\");\n"
-"            String eventDate = request.getParameter(\"eventDate\");\n"
-"\n"
-"            if ( \"\".equals(eventTitle) || \"\".equals(eventDate) ) {\n"
-"                out.println(\"<b><i>Please enter event title and date.</i></"
-"b>\");\n"
-"            }\n"
-"            else {\n"
-"                createAndStoreEvent(eventTitle, dateFormatter.parse"
-"(eventDate));\n"
-"                out.println(\"<b><i>Added event.</i></b>\");\n"
-"            }\n"
-"        }\n"
-"\n"
-"        // Print page\n"
-"       printEventForm(out);\n"
-"       listEvents(out, dateFormatter);\n"
-"\n"
-"       // Write HTML footer\n"
-"       out.println(\"</body></html>\");\n"
-"       out.flush();\n"
-"       out.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:1030
-#, fuzzy, no-c-format
-msgid ""
 "This coding style, with a mix of Java and HTML, would not scale in a more "
 "complex application&mdash;keep in mind that we are only illustrating basic "
 "Hibernate concepts in this tutorial. The code prints an HTML header and a "
@@ -2326,72 +1500,23 @@
 "events in the database are printed. The first method is trivial and only "
 "outputs HTML:"
 msgstr ""
-"JavaとHTMLが混在するコーディングスタイルは、より複雑なアプリケーションには適"
-"していないでしょう (このチュートリアルでは、基本的なHibernateのコンセプトを"
-"示しているだけであることを覚えておいてください)。 このコードはHTMLのヘッダー"
-"とフッターの記述です。 このページには、イベントを入力するHTMLフォームと、デー"
-"タベースにある全てのイベントのリストが表示されます。 最初のメソッドはごく単純"
-"なHTML出力です。"
+"Java と HTML が混在するコーディングスタイルは、より複雑なアプリケーションには"
+"適していないでしょう (このチュートリアルでは、基本的な Hibernate のコンセプ"
+"トを示しているだけであることを覚えておいてください)。このコードは HTML の"
+"ヘッダーとフッターの記述です。このページには、イベントを入力する HTML フォー"
+"ムと、データベースにある全てのイベントのリストが表示されます。最初のメソッド"
+"はごく単純な HTML 出力です。"
 
-#. Tag: programlisting
-#: tutorial.xml:1039
-#, no-c-format
-msgid ""
-"<![CDATA[    private void printEventForm(PrintWriter out) {\n"
-"        out.println(\"<h2>Add new event:</h2>\");\n"
-"        out.println(\"<form>\");\n"
-"        out.println(\"Title: <input name='eventTitle' length='50'/><br/>"
-"\");\n"
-"        out.println(\"Date (e.g. 24.12.2009): <input name='eventDate' "
-"length='10'/><br/>\");\n"
-"        out.println(\"<input type='submit' name='action' value='store'/>"
-"\");\n"
-"        out.println(\"</form>\");\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1041
 #, no-c-format
 msgid ""
 "The <literal>listEvents()</literal> method uses the Hibernate "
 "<literal>Session</literal> bound to the current thread to execute a query:"
 msgstr ""
 "<literal>listEvents()</literal> メソッドは、現在のスレッドに結びつく "
-"Hibernateの <literal>Session</literal> を使用して、クエリを実行します。"
+"Hibernate の <literal>Session</literal> を使用して、クエリを実行します。"
 
-#. Tag: programlisting
-#: tutorial.xml:1047
-#, no-c-format
-msgid ""
-"<![CDATA[    private void listEvents(PrintWriter out, SimpleDateFormat "
-"dateFormatter) {\n"
-"\n"
-"        List result = HibernateUtil.getSessionFactory()\n"
-"                .getCurrentSession().createCriteria(Event.class).list();\n"
-"        if (result.size() > 0) {\n"
-"            out.println(\"<h2>Events in database:</h2>\");\n"
-"            out.println(\"<table border='1'>\");\n"
-"            out.println(\"<tr>\");\n"
-"            out.println(\"<th>Event title</th>\");\n"
-"            out.println(\"<th>Event date</th>\");\n"
-"            out.println(\"</tr>\");\n"
-"            Iterator it = result.iterator();\n"
-"            while (it.hasNext()) {\n"
-"                Event event = (Event) it.next();\n"
-"                out.println(\"<tr>\");\n"
-"                out.println(\"<td>\" + event.getTitle() + \"</td>\");\n"
-"                out.println(\"<td>\" + dateFormatter.format(event.getDate()) "
-"+ \"</td>\");\n"
-"                out.println(\"</tr>\");\n"
-"            }\n"
-"            out.println(\"</table>\");\n"
-"        }\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1049
 #, no-c-format
 msgid ""
 "Finally, the <literal>store</literal> action is dispatched to the "
@@ -2399,28 +1524,12 @@
 "<literal>Session</literal> of the current thread:"
 msgstr ""
 "最後に、 <literal>store</literal> アクションが <literal>createAndStoreEvent()"
-"</literal> メソッドを 呼び出します。このメソッドでも現在のスレッドの "
+"</literal> メソッドを呼び出します。このメソッドでも現在のスレッドの "
 "<literal>Session</literal> を利用します。"
 
-#. Tag: programlisting
-#: tutorial.xml:1055
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    protected void createAndStoreEvent(String title, Date theDate) "
-"{\n"
-"        Event theEvent = new Event();\n"
-"        theEvent.setTitle(title);\n"
-"        theEvent.setDate(theDate);\n"
-"\n"
-"        HibernateUtil.getSessionFactory()\n"
-"                .getCurrentSession().save(theEvent);\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:1057
-#, fuzzy, no-c-format
-msgid ""
 "The servlet is now complete. A request to the servlet will be processed in a "
 "single <literal>Session</literal> and <literal>Transaction</literal>. As "
 "earlier in the standalone application, Hibernate can automatically bind "
@@ -2430,24 +1539,22 @@
 "data access code into data access objects (the DAO pattern). See the "
 "Hibernate Wiki for more examples."
 msgstr ""
-"これでサーブレットの完成です。 サーブレットへのリクエストは、一つの "
+"これでサーブレットの完成です。サーブレットへのリクエストは、1つの "
 "<literal>Session</literal> と <literal>Transaction</literal> で処理されるで"
-"しょう。 最初のスタンドアローンのアプリケーションのように、 Hibernateは自動的"
-"にこれらのオブジェクトを実行するスレッドに結び付けることができます。 これによ"
-"り、開発者が自由にコードをレイヤー分けでき、 好きな方法で "
-"<literal>SessionFactory</literal> へのアクセスができるようになります。 通常、"
-"開発者はより洗練されたデザインを使用して、データアクセスのコードを データアク"
-"セスオブジェクトに移動するでしょう(DAOパターン)。 より多くの例は、Hibernate"
-"のWikiを参照してください。"
+"しょう。最初のスタンドアローンのアプリケーションのように、 Hibernate は自動的"
+"にこれらのオブジェクトを実行するスレッドに結び付けることができます。これによ"
+"り、開発者が自由にコードをレイヤー分けでき、好きな方法で "
+"<literal>SessionFactory</literal> へのアクセスができるようになります。通常、"
+"開発者はより洗練されたデザインを使用して、データアクセスのコードをデータアク"
+"セスオブジェクトに移動するでしょう(DAOパターン)。より多くの例は、 "
+"Hibernate の Wiki を参照してください。"
 
 #. Tag: title
-#: tutorial.xml:1071
 #, no-c-format
 msgid "Deploying and testing"
 msgstr "デプロイとテスト"
 
 #. Tag: para
-#: tutorial.xml:1073
 #, no-c-format
 msgid ""
 "To deploy this application for testing we must create a Web ARchive (WAR). "
@@ -2455,56 +1562,29 @@
 "web.xml</filename>"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:1079
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
-"<web-app version=\"2.4\"\n"
-"    xmlns=\"http://java.sun.com/xml/ns/j2ee\"\n"
-"    xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
-"    xsi:schemaLocation=\"http://java.sun.com/xml/ns/j2ee http://java.sun.com/"
-"xml/ns/j2ee/web-app_2_4.xsd\">\n"
-"\n"
-"    <servlet>\n"
-"        <servlet-name>Event Manager</servlet-name>\n"
-"        <servlet-class>org.hibernate.tutorial.web.EventManagerServlet</"
-"servlet-class>\n"
-"    </servlet>\n"
-"\n"
-"    <servlet-mapping>\n"
-"        <servlet-name>Event Manager</servlet-name>\n"
-"        <url-pattern>/eventmanager</url-pattern>\n"
-"    </servlet-mapping>\n"
-"</web-app>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:1081
-#, fuzzy, no-c-format
-msgid ""
 "To build and deploy call <literal>mvn package</literal> in your project "
 "directory and copy the <filename>hibernate-tutorial.war</filename> file into "
 "your Tomcat <filename>webapps</filename> directory."
 msgstr ""
-"ビルドとデプロイのために、プロジェクトディレクトリで <literal>ant war</"
-"literal> を呼び出し、 <literal>hibernate-tutorial.war</literal> ファイルを"
-"Tomcatの <literal>webapp</literal> ディレクトリにコピーしてください。 まだ"
-"Tomcatをインストールしていなければ、ダウンロードして、以下のインストールガイ"
-"ドに従ってください。 しかし、このアプリケーションのデプロイするために、Tomcat"
-"の設定を変更する必要はありません。"
+"ビルドとデプロイのために、プロジェクトディレクトリで <literal>mvn package</"
+"literal> を呼び出し、 <literal>hibernate-tutorial.war</literal> ファイルを "
+"Tomcat の <literal>webapp</literal> ディレクトリにコピーしてください。"
 
 #. Tag: para
-#: tutorial.xml:1088
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "If you do not have Tomcat installed, download it from <ulink url=\"http://"
-"tomcat.apache.org/\"></ulink> and follow the installation instructions. Our "
+"tomcat.apache.org/\" /> and follow the installation instructions. Our "
 "application requires no changes to the standard Tomcat configuration."
 msgstr ""
+"まだ Tomcat をインストールしていなければ、ダウンロードして、インストールガイ"
+"ドに従ってください。しかし、このアプリケーションのデプロイするために、 "
+"Tomcat の設定を変更する必要はありません。"
 
 #. Tag: para
-#: tutorial.xml:1096
 #, no-c-format
 msgid ""
 "Once deployed and Tomcat is running, access the application at "
@@ -2514,415 +1594,1202 @@
 "<literal>HibernateUtil</literal> is called) and to get the detailed output "
 "if any exceptions occurs."
 msgstr ""
-"一度デプロイしてTomcatを起動すれば、 <literal>http://localhost:8080/"
-"hibernate-tutorial/eventmanager</literal> で アプリケーションへのアクセスが可"
-"能です。 最初のリクエストが作成したサーブレットに渡ったときに、Tomcatのログ"
-"で Hibernateの初期化処理を確認してください ( <literal>HibernateUtil</"
-"literal> 内の静的初期化ブロックが呼ばれています)。 また、exceptionが発生した"
-"なら詳細を確認してください。"
+"一度デプロイして Tomcat を起動すれば、 <literal>http://localhost:8080/"
+"hibernate-tutorial/eventmanager</literal> でアプリケーションへのアクセスが可"
+"能です。最初のリクエストが作成したサーブレットに渡ったときに、 Tomcat のログ"
+"で Hibernate の初期化処理を確認してください ( <literal>HibernateUtil</"
+"literal> 内の静的初期化ブロックが呼ばれています)。また、例外が発生したなら詳"
+"細を確認してください。"
 
 #. Tag: title
-#: tutorial.xml:1109
 #, no-c-format
 msgid "Summary"
 msgstr "要約"
 
 #. Tag: para
-#: tutorial.xml:1111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This tutorial covered the basics of writing a simple standalone Hibernate "
 "application and a small web application. More tutorials are available from "
 "the Hibernate <ulink url=\"http://hibernate.org\">website</ulink>."
 msgstr ""
-"このチュートリアルでは、簡単なスタンドアローンのHibernateアプリケーションと "
-"小規模のWebアプリケーションを書くための基本を紹介しました。"
+"このチュートリアルでは、簡単なスタンドアローンの Hibernate アプリケーションと"
+"小規模の Web アプリケーションを書くための基本を紹介しました。"
 
-#~ msgid "Introduction to Hibernate"
-#~ msgstr "Hibernateの導入"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[package org.hibernate.tutorial.domain;\n"
+#~ "\n"
+#~ "import java.util.Date;\n"
+#~ "\n"
+#~ "public class Event {\n"
+#~ "    private Long id;\n"
+#~ "\n"
+#~ "    private String title;\n"
+#~ "    private Date date;\n"
+#~ "\n"
+#~ "    public Event() {}\n"
+#~ "\n"
+#~ "    public Long getId() {\n"
+#~ "        return id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    private void setId(Long id) {\n"
+#~ "        this.id = id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public Date getDate() {\n"
+#~ "        return date;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setDate(Date date) {\n"
+#~ "        this.date = date;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public String getTitle() {\n"
+#~ "        return title;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setTitle(String title) {\n"
+#~ "        this.title = title;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "package events;\n"
+#~ "\n"
+#~ "import java.util.Date;\n"
+#~ "\n"
+#~ "public class Event {\n"
+#~ "    private Long id;\n"
+#~ "\n"
+#~ "    private String title;\n"
+#~ "    private Date date;\n"
+#~ "\n"
+#~ "    public Event() {}\n"
+#~ "\n"
+#~ "    public Long getId() {\n"
+#~ "        return id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    private void setId(Long id) {\n"
+#~ "        this.id = id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public Date getDate() {\n"
+#~ "        return date;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setDate(Date date) {\n"
+#~ "        this.date = date;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public String getTitle() {\n"
+#~ "        return title;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setTitle(String title) {\n"
+#~ "        this.title = title;\n"
+#~ "    }\n"
+#~ "}"
 
-#~ msgid "Preface"
-#~ msgstr "前書き"
-
+#, fuzzy
 #~ msgid ""
-#~ "This chapter is an introductory tutorial for new users of Hibernate. We "
-#~ "start with a simple command line application using an in-memory database "
-#~ "and develop it in easy to understand steps."
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
+#~ "[...]\n"
+#~ "</hibernate-mapping>]]>"
 #~ msgstr ""
-#~ "この章はHibernateを初めて使うユーザ向けの入門的なチュートリアルです。 イン"
-#~ "メモリデータベースを使う簡単なコマンドラインアプリケーションから始め、 一"
-#~ "歩一歩わかりやすいやり方で開発を進めます。"
+#~ "&lt;?xml version=\"1.0\"?&gt;\n"
+#~ "&lt;!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"
+#~ "\"&gt;\n"
+#~ "\n"
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "[...]\n"
+#~ "&lt;/hibernate-mapping&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "This tutorial is intended for new users of Hibernate but requires Java "
-#~ "and SQL knowledge. It is based on a tutorial by Michael Gloegl, the third-"
-#~ "party libraries we name are for JDK 1.4 and 5.0. You might need others "
-#~ "for JDK 1.3."
+#~ "<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
+#~ "\n"
+#~ "    <class name=\"Event\" table=\"EVENTS\">\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 #~ msgstr ""
-#~ "このチュートリアルはHibernateを初めて使うユーザを想定していますが、 理解す"
-#~ "るにはJavaとSQLについての知識が必要です。 これはMichael Gloeglの手による"
-#~ "チュートリアルを下敷きにしていますが、 ここでサードパーティライブラリと"
-#~ "言っているのは、JDK 1.4と5.0用のものです。 JDK 1.3を利用するのであれば他の"
-#~ "ライブラリが必要かもしれません。"
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"events.Event\" table=\"EVENTS\"&gt;\n"
+#~ "\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "The source code for the tutorial is included in the distribution in the "
-#~ "<literal>doc/reference/tutorial/</literal> directory."
+#~ "<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
+#~ "\n"
+#~ "    <class name=\"Event\" table=\"EVENTS\">\n"
+#~ "        <id name=\"id\" column=\"EVENT_ID\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 #~ msgstr ""
-#~ "チュートリアルのソースコードはHibernateディストリビューションの "
-#~ "<literal>doc/reference/tutorial/</literal> にあります。"
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"events.Event\" table=\"EVENTS\"&gt;\n"
+#~ "        &lt;id name=\"id\" column=\"EVENT_ID\"&gt;\n"
+#~ "            &lt;generator class=\"native\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "First, we'll create a simple console-based Hibernate application. We use "
-#~ "an Java database (HSQL DB), so we do not have to install any database "
-#~ "server."
+#~ "<![CDATA[\n"
+#~ "<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
+#~ "\n"
+#~ "    <class name=\"Event\" table=\"EVENTS\">\n"
+#~ "        <id name=\"id\" column=\"EVENT_ID\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"date\" type=\"timestamp\" column=\"EVENT_DATE\"/"
+#~ ">\n"
+#~ "        <property name=\"title\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 #~ msgstr ""
-#~ "最初にコンソールベースの簡単なHibernateアプリケーションを作成します。 Java"
-#~ "データベース(HSQL DB)を利用するので、 データベースサーバをインストールす"
-#~ "る必要はありません。"
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"events.Event\" table=\"EVENTS\"&gt;\n"
+#~ "        &lt;id name=\"id\" column=\"EVENT_ID\"&gt;\n"
+#~ "            &lt;generator class=\"native\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;property name=\"date\" type=\"timestamp\" column=\"EVENT_DATE"
+#~ "\"/&gt;\n"
+#~ "        &lt;property name=\"title\"/&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "The first thing we do, is set up our development directory and put all "
-#~ "the Java libraries we need into it. Download the Hibernate distribution "
-#~ "from the Hibernate website. Extract the package and place all required "
-#~ "libraries found in <literal>/lib</literal> into into the <literal>/lib</"
-#~ "literal> directory of your new development working directory. It should "
-#~ "look like this:"
+#~ "<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
+#~ "<!DOCTYPE hibernate-configuration PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Configuration DTD 3.0//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
+#~ "\">\n"
+#~ "\n"
+#~ "<hibernate-configuration>\n"
+#~ "\n"
+#~ "    <session-factory>\n"
+#~ "\n"
+#~ "        <!-- Database connection settings -->\n"
+#~ "        <property name=\"connection.driver_class\">org.hsqldb.jdbcDriver</"
+#~ "property>\n"
+#~ "        <property name=\"connection.url\">jdbc:hsqldb:hsql://localhost</"
+#~ "property>\n"
+#~ "        <property name=\"connection.username\">sa</property>\n"
+#~ "        <property name=\"connection.password\"></property>\n"
+#~ "\n"
+#~ "        <!-- JDBC connection pool (use the built-in) -->\n"
+#~ "        <property name=\"connection.pool_size\">1</property>\n"
+#~ "\n"
+#~ "        <!-- SQL dialect -->\n"
+#~ "        <property name=\"dialect\">org.hibernate.dialect.HSQLDialect</"
+#~ "property>\n"
+#~ "\n"
+#~ "        <!-- Enable Hibernate's automatic session context management -->\n"
+#~ "        <property name=\"current_session_context_class\">thread</"
+#~ "property>\n"
+#~ "\n"
+#~ "        <!-- Disable the second-level cache  -->\n"
+#~ "        <property name=\"cache.provider_class\">org.hibernate.cache."
+#~ "NoCacheProvider</property>\n"
+#~ "\n"
+#~ "        <!-- Echo all executed SQL to stdout -->\n"
+#~ "        <property name=\"show_sql\">true</property>\n"
+#~ "\n"
+#~ "        <!-- Drop and re-create the database schema on startup -->\n"
+#~ "        <property name=\"hbm2ddl.auto\">update</property>\n"
+#~ "\n"
+#~ "        <mapping resource=\"org/hibernate/tutorial/domain/Event.hbm.xml\"/"
+#~ ">\n"
+#~ "\n"
+#~ "    </session-factory>\n"
+#~ "\n"
+#~ "</hibernate-configuration>]]>"
 #~ msgstr ""
-#~ "まず最初にすることは開発用のディレクトリをセットアップして、 必要となるす"
-#~ "べてのJavaライブラリを配置することです。 Hibernateウェブサイトから"
-#~ "Hibernateディストリビューションをダウンロードしてください。 ファイルを解凍"
-#~ "して <literal>/lib</literal> にある必要なライブラリのすべてを、 新しい開発"
-#~ "用ディレクトリの <literal>/lib</literal> ディレクトリに配置してください。 "
-#~ "このようになっているはずです:"
+#~ "&lt;?xml version='1.0' encoding='utf-8'?&gt;\n"
+#~ "&lt;!DOCTYPE hibernate-configuration PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Configuration DTD 3.0//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
+#~ "\"&gt;\n"
+#~ "\n"
+#~ "&lt;hibernate-configuration&gt;\n"
+#~ "\n"
+#~ "    &lt;session-factory&gt;\n"
+#~ "\n"
+#~ "        &lt;!-- Database connection settings --&gt;\n"
+#~ "        &lt;property name=\"connection.driver_class\"&gt;org.hsqldb."
+#~ "jdbcDriver&lt;/property&gt;\n"
+#~ "        &lt;property name=\"connection.url\"&gt;jdbc:hsqldb:hsql://"
+#~ "localhost&lt;/property&gt;\n"
+#~ "        &lt;property name=\"connection.username\"&gt;sa&lt;/property&gt;\n"
+#~ "        &lt;property name=\"connection.password\"&gt;&lt;/property&gt;\n"
+#~ "\n"
+#~ "        &lt;!-- JDBC connection pool (use the built-in) --&gt;\n"
+#~ "        &lt;property name=\"connection.pool_size\"&gt;1&lt;/property&gt;\n"
+#~ "\n"
+#~ "        &lt;!-- SQL dialect --&gt;\n"
+#~ "        &lt;property name=\"dialect\"&gt;org.hibernate.dialect."
+#~ "HSQLDialect&lt;/property&gt;\n"
+#~ "\n"
+#~ "        &lt;!-- Enable Hibernate's automatic session context management --"
+#~ "&gt;\n"
+#~ "        &lt;property name=\"current_session_context_class\"&gt;thread&lt;/"
+#~ "property&gt;\n"
+#~ "\n"
+#~ "        &lt;!-- Disable the second-level cache  --&gt;\n"
+#~ "        &lt;property name=\"cache.provider_class\"&gt;org.hibernate.cache."
+#~ "NoCacheProvider&lt;/property&gt;\n"
+#~ "\n"
+#~ "        &lt;!-- Echo all executed SQL to stdout --&gt;\n"
+#~ "        &lt;property name=\"show_sql\"&gt;true&lt;/property&gt;\n"
+#~ "\n"
+#~ "        &lt;!-- Drop and re-create the database schema on startup --&gt;\n"
+#~ "        &lt;property name=\"hbm2ddl.auto\"&gt;create&lt;/property&gt;\n"
+#~ "\n"
+#~ "        &lt;mapping resource=\"events/Event.hbm.xml\"/&gt;\n"
+#~ "\n"
+#~ "    &lt;/session-factory&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-configuration&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "This is the minimum set of required libraries (note that we also copied "
-#~ "hibernate3.jar, the main archive) for Hibernate <emphasis>at the time of "
-#~ "writing</emphasis>. The Hibernate release you are using might require "
-#~ "more or less libraries. See the <literal>README.txt</literal> file in the "
-#~ "<literal>lib/</literal> directory of the Hibernate distribution for more "
-#~ "information about required and optional third-party libraries. (Actually, "
-#~ "Log4j is not required but preferred by many developers.)"
+#~ "<![CDATA[package org.hibernate.tutorial.util;\n"
+#~ "\n"
+#~ "import org.hibernate.SessionFactory;\n"
+#~ "import org.hibernate.cfg.Configuration;\n"
+#~ "\n"
+#~ "public class HibernateUtil {\n"
+#~ "\n"
+#~ "    private static final SessionFactory sessionFactory = "
+#~ "buildSessionFactory();\n"
+#~ "\n"
+#~ "    private static SessionFactory buildSessionFactory() {\n"
+#~ "        try {\n"
+#~ "            // Create the SessionFactory from hibernate.cfg.xml\n"
+#~ "            return new Configuration().configure().buildSessionFactory"
+#~ "();\n"
+#~ "        }\n"
+#~ "        catch (Throwable ex) {\n"
+#~ "            // Make sure you log the exception, as it might be swallowed\n"
+#~ "            System.err.println(\"Initial SessionFactory creation failed."
+#~ "\" + ex);\n"
+#~ "            throw new ExceptionInInitializerError(ex);\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public static SessionFactory getSessionFactory() {\n"
+#~ "        return sessionFactory;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
 #~ msgstr ""
-#~ "これが <emphasis>本ドキュメント執筆時点での</emphasis> Hibernateの必要最低"
-#~ "限のライブラリです (メインアーカイブのhibernate3.jarもコピーしていること"
-#~ "に注意してください)。 Hibernateのバージョンによってはさらに必要なライブラ"
-#~ "リや、不要なライブラリがあるかもしれません。 Hibernateディストリビューショ"
-#~ "ンの <literal>lib/</literal> ディレクトリにある <literal>README.txt</"
-#~ "literal> ファイルを見てください。 必須またはオプションのサードパーティライ"
-#~ "ブラリについての情報を載せています (実際Log4jは必須ではありませんが、多く"
-#~ "の開発者が好んでいます)。"
+#~ "package util;\n"
+#~ "\n"
+#~ "import org.hibernate.*;\n"
+#~ "import org.hibernate.cfg.*;\n"
+#~ "\n"
+#~ "public class HibernateUtil {\n"
+#~ "\n"
+#~ "    private static final SessionFactory sessionFactory;\n"
+#~ "\n"
+#~ "    static {\n"
+#~ "        try {\n"
+#~ "            // Create the SessionFactory from hibernate.cfg.xml\n"
+#~ "            sessionFactory = new Configuration().configure()."
+#~ "buildSessionFactory();\n"
+#~ "        } catch (Throwable ex) {\n"
+#~ "            // Make sure you log the exception, as it might be swallowed\n"
+#~ "            System.err.println(\"Initial SessionFactory creation failed."
+#~ "\" + ex);\n"
+#~ "            throw new ExceptionInInitializerError(ex);\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public static SessionFactory getSessionFactory() {\n"
+#~ "        return sessionFactory;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "Our first persistent class is a simple JavaBean class with some "
-#~ "properties:"
+#~ "<![CDATA[package org.hibernate.tutorial;\n"
+#~ "\n"
+#~ "import org.hibernate.Session;\n"
+#~ "\n"
+#~ "import java.util.*;\n"
+#~ "\n"
+#~ "import org.hibernate.tutorial.domain.Event;\n"
+#~ "import org.hibernate.tutorial.util.HibernateUtil;\n"
+#~ "\n"
+#~ "public class EventManager {\n"
+#~ "\n"
+#~ "    public static void main(String[] args) {\n"
+#~ "        EventManager mgr = new EventManager();\n"
+#~ "\n"
+#~ "        if (args[0].equals(\"store\")) {\n"
+#~ "            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
+#~ "        }\n"
+#~ "\n"
+#~ "        HibernateUtil.getSessionFactory().close();\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    private void createAndStoreEvent(String title, Date theDate) {\n"
+#~ "        Session session = HibernateUtil.getSessionFactory()."
+#~ "getCurrentSession();\n"
+#~ "        session.beginTransaction();\n"
+#~ "\n"
+#~ "        Event theEvent = new Event();\n"
+#~ "        theEvent.setTitle(title);\n"
+#~ "        theEvent.setDate(theDate);\n"
+#~ "        session.save(theEvent);\n"
+#~ "\n"
+#~ "        session.getTransaction().commit();\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
 #~ msgstr ""
-#~ "最初の永続クラスは、プロパティをいくつか持つシンプルなJavaBeanです:"
+#~ "package events;\n"
+#~ "import org.hibernate.Session;\n"
+#~ "\n"
+#~ "import java.util.Date;\n"
+#~ "\n"
+#~ "import util.HibernateUtil;\n"
+#~ "\n"
+#~ "public class EventManager {\n"
+#~ "\n"
+#~ "    public static void main(String[] args) {\n"
+#~ "        EventManager mgr = new EventManager();\n"
+#~ "\n"
+#~ "        if (args[0].equals(\"store\")) {\n"
+#~ "            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
+#~ "        }\n"
+#~ "\n"
+#~ "        HibernateUtil.getSessionFactory().close();\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    private void createAndStoreEvent(String title, Date theDate) {\n"
+#~ "\n"
+#~ "        Session session = HibernateUtil.getSessionFactory()."
+#~ "getCurrentSession();\n"
+#~ "\n"
+#~ "        session.beginTransaction();\n"
+#~ "\n"
+#~ "        Event theEvent = new Event();\n"
+#~ "        theEvent.setTitle(title);\n"
+#~ "        theEvent.setDate(theDate);\n"
+#~ "\n"
+#~ "        session.save(theEvent);\n"
+#~ "\n"
+#~ "        session.getTransaction().commit();\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "Place this Java source file in a directory called <literal>src</literal> "
-#~ "in the development folder, and in its correct package. The directory "
-#~ "should now look like this:"
+#~ "<![CDATA[[java] Hibernate: insert into EVENTS (EVENT_DATE, title, "
+#~ "EVENT_ID) values (?, ?, ?)]]>"
 #~ msgstr ""
-#~ "開発フォルダの <literal>src</literal> というディレクトリの適切なパッケージ"
-#~ "に、 このJavaソースファイルを配置してください。 この時点でディレクトリは以"
-#~ "下のようになっているはずです:"
+#~ "[java] Hibernate: insert into EVENTS (EVENT_DATE, title, EVENT_ID) values "
+#~ "(?, ?, ?)"
 
-#~ msgid "In the next step, we tell Hibernate about this persistent class."
-#~ msgstr "次のステップでは、Hibernateにこの永続クラスの情報を教えます。"
-
+#, fuzzy
 #~ msgid ""
-#~ "The <literal>id</literal> element is the declaration of the identifer "
-#~ "property, <literal>name=\"id\"</literal> declares the name of the Java "
-#~ "property - Hibernate will use the getter and setter methods to access the "
-#~ "property. The column attribute tells Hibernate which column of the "
-#~ "<literal>EVENTS</literal> table we use for this primary key. The nested "
-#~ "<literal>generator</literal> element specifies the identifier generation "
-#~ "strategy, in this case we used <literal>native</literal>, which picks the "
-#~ "best strategy depending on the configured database (dialect). Hibernate "
-#~ "supports database generated, globally unique, as well as application "
-#~ "assigned identifiers (or any strategy you have written an extension for)."
+#~ "<![CDATA[        if (args[0].equals(\"store\")) {\n"
+#~ "            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
+#~ "        }\n"
+#~ "        else if (args[0].equals(\"list\")) {\n"
+#~ "            List events = mgr.listEvents();\n"
+#~ "            for (int i = 0; i < events.size(); i++) {\n"
+#~ "                Event theEvent = (Event) events.get(i);\n"
+#~ "                System.out.println(\n"
+#~ "                        \"Event: \" + theEvent.getTitle() + \" Time: \" + "
+#~ "theEvent.getDate()\n"
+#~ "                );\n"
+#~ "            }\n"
+#~ "        }]]>"
 #~ msgstr ""
-#~ "<literal>id</literal> 要素は識別子プロパティの宣言であり、 <literal>name="
-#~ "\"id\"</literal> でJavaプロパティの名前を宣言します。 Hibernateはこのプロ"
-#~ "パティへアクセスするためにゲッター、セッターメソッドを使います。 カラム属"
-#~ "性では <literal>EVENTS</literal> テーブルのどのカラムを主キーとして使うの"
-#~ "かを Hibernateに教えます。 入れ子になっている <literal>generator</"
-#~ "literal> 要素は、識別子を生成する時の戦略を指定します。 (この例では "
-#~ "<literal>native</literal> を用いました)。 この要素は、設定したデータベー"
-#~ "ス(dialect)に対する最良な識別子生成戦略を選定するものです。 Hibernate"
-#~ "は、アプリケーションで値を割り当てる戦略(もしくは独自に拡張した戦略)と同"
-#~ "様に、 グローバルにユニークな値をデータベースに生成させる戦略もサポートし"
-#~ "ています。"
+#~ "if (args[0].equals(\"store\")) {\n"
+#~ "    mgr.createAndStoreEvent(\"My Event\", new Date());\n"
+#~ "}\n"
+#~ "else if (args[0].equals(\"list\")) {\n"
+#~ "    List events = mgr.listEvents();\n"
+#~ "    for (int i = 0; i &lt; events.size(); i++) {\n"
+#~ "        Event theEvent = (Event) events.get(i);\n"
+#~ "        System.out.println(\"Event: \" + theEvent.getTitle() +\n"
+#~ "                           \" Time: \" + theEvent.getDate());\n"
+#~ "    }\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "This mapping file should be saved as <literal>Event.hbm.xml</literal>, "
-#~ "right in the directory next to the <literal>Event</literal> Java class "
-#~ "source file. The naming of mapping files can be arbitrary, however the "
-#~ "<literal>hbm.xml</literal> suffix is a convention in the Hibernate "
-#~ "developer community. The directory structure should now look like this:"
+#~ "<![CDATA[    private List listEvents() {\n"
+#~ "        Session session = HibernateUtil.getSessionFactory()."
+#~ "getCurrentSession();\n"
+#~ "        session.beginTransaction();\n"
+#~ "        List result = session.createQuery(\"from Event\").list();\n"
+#~ "        session.getTransaction().commit();\n"
+#~ "        return result;\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "このマッピングファイルは、<literal>Event.hbm.xml</literal> として "
-#~ "<literal>Event</literal> Javaクラスソースファイルのすぐ隣にセーブするべき"
-#~ "です。 マッピングファイルの命名方法は任意ですが、<literal>hbm.xml</"
-#~ "literal> サフィックスがHibernateの開発者のコミュニティ内での習慣となってい"
-#~ "ます。 現在ディレクトリ構造はこのようになっているはずです:"
+#~ "private List listEvents() {\n"
+#~ "\n"
+#~ "    Session session = HibernateUtil.getSessionFactory().getCurrentSession"
+#~ "();\n"
+#~ "\n"
+#~ "    session.beginTransaction();\n"
+#~ "\n"
+#~ "    List result = session.createQuery(\"from Event\").list();\n"
+#~ "\n"
+#~ "    session.getTransaction().commit();\n"
+#~ "\n"
+#~ "    return result;\n"
+#~ "}"
 
-#~ msgid "We continue with the main configuration of Hibernate."
-#~ msgstr "Hibernateの主要な設定を続けます。"
-
+#, fuzzy
 #~ msgid ""
-#~ "We now have a persistent class and its mapping file in place. It is time "
-#~ "to configure Hibernate. Before we do this, we will need a database. HSQL "
-#~ "DB, a java-based SQL DBMS, can be downloaded from the HSQL DB website"
-#~ "(http://hsqldb.org/). Actually, you only need the <literal>hsqldb.jar</"
-#~ "literal> from this download. Place this file in the <literal>lib/</"
-#~ "literal> directory of the development folder."
+#~ "<![CDATA[package org.hibernate.tutorial.domain;\n"
+#~ "\n"
+#~ "public class Person {\n"
+#~ "\n"
+#~ "    private Long id;\n"
+#~ "    private int age;\n"
+#~ "    private String firstname;\n"
+#~ "    private String lastname;\n"
+#~ "\n"
+#~ "    public Person() {}\n"
+#~ "\n"
+#~ "    // Accessor methods for all properties, private setter for 'id'\n"
+#~ "\n"
+#~ "}]]>"
 #~ msgstr ""
-#~ "ここまでで永続クラスとマッピングファイルが揃いました。これからHibernateの"
-#~ "設定を行いますが、 その前にデータベースが必要です。 HSQL DBはJavaベースの"
-#~ "インメモリSQL DBMSであり、HSQL DBウェブサイトからダウンロードできます。 実"
-#~ "際にはダウンロードした中の <literal>hsqldb.jar</literal> だけが必要です。 "
-#~ "このファイルを開発フォルダの <literal>lib/</literal> ディレクトリに配置し"
-#~ "てください。"
+#~ "package events;\n"
+#~ "\n"
+#~ "public class Person {\n"
+#~ "\n"
+#~ "    private Long id;\n"
+#~ "    private int age;\n"
+#~ "    private String firstname;\n"
+#~ "    private String lastname;\n"
+#~ "\n"
+#~ "    public Person() {}\n"
+#~ "\n"
+#~ "    // Accessor methods for all properties, private setter for 'id'\n"
+#~ "\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "Hibernate is the layer in your application which connects to this "
-#~ "database, so it needs connection information. The connections are made "
-#~ "through a JDBC connection pool, which we also have to configure. The "
-#~ "Hibernate distribution contains several open source JDBC connection "
-#~ "pooling tools, but will use the Hibernate built-in connection pool for "
-#~ "this tutorial. Note that you have to copy the required library into your "
-#~ "classpath and use different connection pooling settings if you want to "
-#~ "use a production-quality third party JDBC pooling software."
+#~ "<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
+#~ "\n"
+#~ "    <class name=\"Person\" table=\"PERSON\">\n"
+#~ "        <id name=\"id\" column=\"PERSON_ID\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"age\"/>\n"
+#~ "        <property name=\"firstname\"/>\n"
+#~ "        <property name=\"lastname\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 #~ msgstr ""
-#~ "Hibernateはアプリケーションのデータベースに接続する層なので、 コネクション"
-#~ "の情報が必要になります。 コネクションはJDBCコネクションプールを通じて行わ"
-#~ "れますが、これも設定する必要があります。 Hibernateディストリビューションに"
-#~ "はいくつかのオープンソースのJDBCコネクションプールツールが含まれています"
-#~ "が、 このチュートリアルではHibernateに組み込まれたコネクションプールを使い"
-#~ "ます。 もし製品レベルの品質のサードパーティJDBCコネクションプールソフト"
-#~ "ウェアを使いたければ、 クラスパスに必要なライブラリをコピーして、異なるコ"
-#~ "ネクションプールを設定しなければ ならないことに注意してください。"
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"events.Person\" table=\"PERSON\"&gt;\n"
+#~ "        &lt;id name=\"id\" column=\"PERSON_ID\"&gt;\n"
+#~ "            &lt;generator class=\"native\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;property name=\"age\"/&gt;\n"
+#~ "        &lt;property name=\"firstname\"/&gt;\n"
+#~ "        &lt;property name=\"lastname\"/&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "Copy this file into the source directory, so it will end up in the root "
-#~ "of the classpath. Hibernate automatically looks for a file called "
-#~ "<literal>hibernate.cfg.xml</literal> in the root of the classpath, on "
-#~ "startup."
+#~ "<![CDATA[<mapping resource=\"events/Event.hbm.xml\"/>\n"
+#~ "<mapping resource=\"events/Person.hbm.xml\"/>]]>"
 #~ msgstr ""
-#~ "このファイルをソースディレクトリにコピーしてください。 するとこれはクラス"
-#~ "パスのルートにあることになります。 Hibernateは、スタートアップ時にクラスパ"
-#~ "スのルートで <literal>hibernate.cfg.xml</literal> というファイルを自動的に"
-#~ "探します。"
+#~ "&lt;mapping resource=\"events/Event.hbm.xml\"/&gt;\n"
+#~ "&lt;mapping resource=\"events/Person.hbm.xml\"/&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "We'll now build the tutorial with Ant. You will need to have Ant "
-#~ "installed - get it from the <ulink url=\"http://ant.apache.org/"
-#~ "bindownload.cgi\">Ant download page</ulink>. How to install Ant will not "
-#~ "be covered here. Please refer to the <ulink url=\"http://ant.apache.org/"
-#~ "manual/index.html\">Ant manual</ulink>. After you have installed Ant, we "
-#~ "can start to create the buildfile. It will be called <literal>build.xml</"
-#~ "literal> and placed directly in the development directory."
+#~ "<![CDATA[public class Person {\n"
+#~ "\n"
+#~ "    private Set events = new HashSet();\n"
+#~ "\n"
+#~ "    public Set getEvents() {\n"
+#~ "        return events;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setEvents(Set events) {\n"
+#~ "        this.events = events;\n"
+#~ "    }\n"
+#~ "}]]>"
 #~ msgstr ""
-#~ "それではAntを使ってチュートリアルをビルドしましょう。 それにはAntがインス"
-#~ "トールされていなければなりません。 <ulink url=\"http://ant.apache.org/"
-#~ "bindownload.cgi\">Antダウンロードページ</ulink> からダウンロードしてくださ"
-#~ "い。 Antのインストール方法はここでは説明しませんので、 <ulink url="
-#~ "\"http://ant.apache.org/manual/index.html\">Antマニュアル</ulink> を参照し"
-#~ "てください。 Antをインストールすれば、ビルドファイルの作成を開始できま"
-#~ "す。 このファイルは <literal>build.xml</literal> と呼ばれ、開発ディレクト"
-#~ "リに直接配置します。"
+#~ "public class Person {\n"
+#~ "\n"
+#~ "    private Set events = new HashSet();\n"
+#~ "\n"
+#~ "    public Set getEvents() {\n"
+#~ "        return events;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setEvents(Set events) {\n"
+#~ "        this.events = events;\n"
+#~ "    }\n"
+#~ "}"
 
-#~ msgid "A basic build file looks like this:"
-#~ msgstr "基本的なビルドファイルはこのようになります:"
-
+#, fuzzy
 #~ msgid ""
-#~ "This will tell Ant to add all files in the lib directory ending with "
-#~ "<literal>.jar</literal> to the classpath used for compilation. It will "
-#~ "also copy all non-Java source files to the target directory, e.g. "
-#~ "configuration and Hibernate mapping files. If you now run Ant, you should "
-#~ "get this output:"
+#~ "<![CDATA[<class name=\"Person\" table=\"PERSON\">\n"
+#~ "    <id name=\"id\" column=\"PERSON_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"age\"/>\n"
+#~ "    <property name=\"firstname\"/>\n"
+#~ "    <property name=\"lastname\"/>\n"
+#~ "\n"
+#~ "    <set name=\"events\" table=\"PERSON_EVENT\">\n"
+#~ "        <key column=\"PERSON_ID\"/>\n"
+#~ "        <many-to-many column=\"EVENT_ID\" class=\"Event\"/>\n"
+#~ "    </set>\n"
+#~ "\n"
+#~ "</class>]]>"
 #~ msgstr ""
-#~ "これは <literal>.jar</literal> で終わるlibディレクトリのすべてのファイル"
-#~ "を、 コンパイルに使用するクラスパスに追加することをAntに教えます。 また、"
-#~ "Javaソースファイルでないすべてのファイルをターゲットディレクトリにコピーす"
-#~ "るということでもあります。 例えば設定ファイルやHibernateマッピングファイル"
-#~ "などです。 今Antを実行すると、このような出力があるはずです:"
+#~ "&lt;class name=\"events.Person\" table=\"PERSON\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"PERSON_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"age\"/&gt;\n"
+#~ "    &lt;property name=\"firstname\"/&gt;\n"
+#~ "    &lt;property name=\"lastname\"/&gt;\n"
+#~ "\n"
+#~ "    &lt;set name=\"events\" table=\"PERSON_EVENT\"&gt;\n"
+#~ "        &lt;key column=\"PERSON_ID\"/&gt;\n"
+#~ "        &lt;many-to-many column=\"EVENT_ID\" class=\"events.Event\"/&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "\n"
+#~ "&lt;/class&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "Place <literal>HibernateUtil.java</literal> in the development source "
-#~ "directory, in a package next to <literal>events</literal>:"
+#~ "<![CDATA[\n"
+#~ "    _____________        __________________\n"
+#~ "   |             |      |                  |       _____________\n"
+#~ "   |   EVENTS    |      |   PERSON_EVENT   |      |             |\n"
+#~ "   |_____________|      |__________________|      |    PERSON   |\n"
+#~ "   |             |      |                  |      |_____________|\n"
+#~ "   | *EVENT_ID   | <--> | *EVENT_ID        |      |             |\n"
+#~ "   |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  |\n"
+#~ "   |  TITLE      |      |__________________|      |  AGE        |\n"
+#~ "   |_____________|                                |  FIRSTNAME  |\n"
+#~ "                                                  |  LASTNAME   |\n"
+#~ "                                                  |_____________|\n"
+#~ " ]]>"
 #~ msgstr ""
-#~ "<literal>HibernateUtil.java</literal> を開発ソースディレクトリにある "
-#~ "<literal>events</literal> パッケージの 隣に配置してください。"
+#~ "_____________        __________________\n"
+#~ "   |             |      |                  |       _____________\n"
+#~ "   |   EVENTS    |      |   PERSON_EVENT   |      |             |\n"
+#~ "   |_____________|      |__________________|      |    PERSON   |\n"
+#~ "   |             |      |                  |      |_____________|\n"
+#~ "   | *EVENT_ID   | &lt;--&gt; | *EVENT_ID        |      |             |\n"
+#~ "   |  EVENT_DATE |      | *PERSON_ID       | &lt;--&gt; | *PERSON_ID  |\n"
+#~ "   |  TITLE      |      |__________________|      |  AGE        |\n"
+#~ "   |_____________|                                |  FIRSTNAME  |\n"
+#~ "                                                  |  LASTNAME   |\n"
+#~ "                                                  |_____________|"
 
+#, fuzzy
 #~ msgid ""
-#~ "To run this first routine we have to add a callable target to the Ant "
-#~ "build file:"
+#~ "<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) "
+#~ "{\n"
+#~ "        Session session = HibernateUtil.getSessionFactory()."
+#~ "getCurrentSession();\n"
+#~ "        session.beginTransaction();\n"
+#~ "\n"
+#~ "        Person aPerson = (Person) session.load(Person.class, personId);\n"
+#~ "        Event anEvent = (Event) session.load(Event.class, eventId);\n"
+#~ "        aPerson.getEvents().add(anEvent);\n"
+#~ "\n"
+#~ "        session.getTransaction().commit();\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "この最初のルーチンを実行するには、Antのビルドファイルに呼び出し可能なター"
-#~ "ゲットを 追加しなければなりません:"
+#~ "private void addPersonToEvent(Long personId, Long eventId) {\n"
+#~ "\n"
+#~ "    Session session = HibernateUtil.getSessionFactory().getCurrentSession"
+#~ "();\n"
+#~ "    session.beginTransaction();\n"
+#~ "\n"
+#~ "    Person aPerson = (Person) session.load(Person.class, personId);\n"
+#~ "    Event anEvent = (Event) session.load(Event.class, eventId);\n"
+#~ "\n"
+#~ "    aPerson.getEvents().add(anEvent);\n"
+#~ "\n"
+#~ "    session.getTransaction().commit();\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "The value of the <literal>action</literal> argument is set on the command "
-#~ "line when calling the target:"
+#~ "<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) "
+#~ "{\n"
+#~ "        Session session = HibernateUtil.getSessionFactory()."
+#~ "getCurrentSession();\n"
+#~ "        session.beginTransaction();\n"
+#~ "\n"
+#~ "        Person aPerson = (Person) session\n"
+#~ "                .createQuery(\"select p from Person p left join fetch p."
+#~ "events where p.id = :pid\")\n"
+#~ "                .setParameter(\"pid\", personId)\n"
+#~ "                .uniqueResult(); // Eager fetch the collection so we can "
+#~ "use it detached\n"
+#~ "        Event anEvent = (Event) session.load(Event.class, eventId);\n"
+#~ "\n"
+#~ "        session.getTransaction().commit();\n"
+#~ "\n"
+#~ "        // End of first unit of work\n"
+#~ "\n"
+#~ "        aPerson.getEvents().add(anEvent); // aPerson (and its collection) "
+#~ "is detached\n"
+#~ "\n"
+#~ "        // Begin second unit of work\n"
+#~ "\n"
+#~ "        Session session2 = HibernateUtil.getSessionFactory()."
+#~ "getCurrentSession();\n"
+#~ "        session2.beginTransaction();\n"
+#~ "        session2.update(aPerson); // Reattachment of aPerson\n"
+#~ "\n"
+#~ "        session2.getTransaction().commit();\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "<literal>action</literal> 引数の値は、ターゲットを呼ぶときにコマンドライン"
-#~ "で設定します:"
+#~ "private void addPersonToEvent(Long personId, Long eventId) {\n"
+#~ "\n"
+#~ "    Session session = HibernateUtil.getSessionFactory().getCurrentSession"
+#~ "();\n"
+#~ "    session.beginTransaction();\n"
+#~ "\n"
+#~ "    Person aPerson = (Person) session\n"
+#~ "            .createQuery(\"select p from Person p left join fetch p."
+#~ "events where p.id = :pid\")\n"
+#~ "            .setParameter(\"pid\", personId)\n"
+#~ "            .uniqueResult(); // Eager fetch the collection so we can use "
+#~ "it detached\n"
+#~ "\n"
+#~ "    Event anEvent = (Event) session.load(Event.class, eventId);\n"
+#~ "\n"
+#~ "    session.getTransaction().commit();\n"
+#~ "\n"
+#~ "    // End of first unit of work\n"
+#~ "\n"
+#~ "    aPerson.getEvents().add(anEvent); // aPerson (and its collection) is "
+#~ "detached\n"
+#~ "\n"
+#~ "    // Begin second unit of work\n"
+#~ "\n"
+#~ "    Session session2 = HibernateUtil.getSessionFactory().getCurrentSession"
+#~ "();\n"
+#~ "    session2.beginTransaction();\n"
+#~ "\n"
+#~ "    session2.update(aPerson); // Reattachment of aPerson\n"
+#~ "\n"
+#~ "    session2.getTransaction().commit();\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "This is the <literal>INSERT</literal> executed by Hibernate, the question "
-#~ "marks represent JDBC bind parameters. To see the values bound as "
-#~ "arguments, or to reduce the verbosity of the log, check your "
-#~ "<literal>log4j.properties</literal>."
+#~ "<![CDATA[        else if (args[0].equals(\"addpersontoevent\")) {\n"
+#~ "            Long eventId = mgr.createAndStoreEvent(\"My Event\", new Date"
+#~ "());\n"
+#~ "            Long personId = mgr.createAndStorePerson(\"Foo\", \"Bar\");\n"
+#~ "            mgr.addPersonToEvent(personId, eventId);\n"
+#~ "            System.out.println(\"Added person \" + personId + \" to event "
+#~ "\" + eventId);\n"
+#~ "        }]]>"
 #~ msgstr ""
-#~ "これはHibernateが実行する <literal>INSERT</literal> で、 クエスチョンマー"
-#~ "クはJDBCバインドパラメータを表しています。 引数としてバインドされる値を見"
-#~ "るため、あるいはログの冗長性を減らすためには、 <literal>log4j.properties</"
-#~ "literal> をチェックしてください。"
+#~ "else if (args[0].equals(\"addpersontoevent\")) {\n"
+#~ "    Long eventId = mgr.createAndStoreEvent(\"My Event\", new Date());\n"
+#~ "    Long personId = mgr.createAndStorePerson(\"Foo\", \"Bar\");\n"
+#~ "    mgr.addPersonToEvent(personId, eventId);\n"
+#~ "    System.out.println(\"Added person \" + personId + \" to event \" + "
+#~ "eventId);\n"
+#~ "}"
 
-#~ msgid "Now, to execute and test all of this, follow these steps:"
-#~ msgstr "以下のステップで、すべての実行とテストを行います。"
-
+#, fuzzy
 #~ msgid ""
-#~ "Run <literal>ant run -Daction=store</literal> to store something into the "
-#~ "database and, of course, to generate the database schema before through "
-#~ "hbm2ddl."
+#~ "<![CDATA[    private Set emailAddresses = new HashSet();\n"
+#~ "\n"
+#~ "    public Set getEmailAddresses() {\n"
+#~ "        return emailAddresses;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setEmailAddresses(Set emailAddresses) {\n"
+#~ "        this.emailAddresses = emailAddresses;\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "hbm2ddlを通す前にデータベースのデータを作成し、データベーススキーマを生成"
-#~ "するために、 <literal>ant run -Daction=store</literal> を実行してくださ"
-#~ "い。"
+#~ "private Set emailAddresses = new HashSet();\n"
+#~ "\n"
+#~ "public Set getEmailAddresses() {\n"
+#~ "    return emailAddresses;\n"
+#~ "}\n"
+#~ "\n"
+#~ "public void setEmailAddresses(Set emailAddresses) {\n"
+#~ "    this.emailAddresses = emailAddresses;\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "Now disable hbm2ddl by commenting out the property in your "
-#~ "<literal>hibernate.cfg.xml</literal> file. Usually you only leave it "
-#~ "turned on in continous unit testing, but another run of hbm2ddl would "
-#~ "<emphasis>drop</emphasis> everything you have stored - the "
-#~ "<literal>create</literal> configuration setting actually translates into "
-#~ "\"drop all tables from the schema, then re-create all tables, when the "
-#~ "SessionFactory is build\"."
+#~ "<![CDATA[        <set name=\"emailAddresses\" table=\"PERSON_EMAIL_ADDR"
+#~ "\">\n"
+#~ "            <key column=\"PERSON_ID\"/>\n"
+#~ "            <element type=\"string\" column=\"EMAIL_ADDR\"/>\n"
+#~ "        </set>]]>"
 #~ msgstr ""
-#~ "今は <literal>hibernate.cfg.xml</literal> ファイルのプロパティをコメントア"
-#~ "ウトしてhbm2ddlを無効にしてください。 通常は継続的に単体テストをしている間"
-#~ "はhbm2ddlを有効にしておくのですが、 それ以外の場合にhbm2ddlを起動すると格"
-#~ "納しておいた全てのデータを <emphasis>ドロップ</emphasis> するでしょう。 設"
-#~ "定を <literal>create</literal> にすると、結果として 「SessionFactory生成の"
-#~ "際、スキーマから全てのテーブルをドロップして再作成する」という設定になりま"
-#~ "す。"
+#~ "&lt;set name=\"emailAddresses\" table=\"PERSON_EMAIL_ADDR\"&gt;\n"
+#~ "    &lt;key column=\"PERSON_ID\"/&gt;\n"
+#~ "    &lt;element type=\"string\" column=\"EMAIL_ADDR\"/&gt;\n"
+#~ "&lt;/set&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "If you now call Ant with <literal>-Daction=list</literal>, you should see "
-#~ "the events you have stored so far. You can of course also call the "
-#~ "<literal>store</literal> action a few times more."
+#~ "<![CDATA[\n"
+#~ "  _____________        __________________\n"
+#~ " |             |      |                  |       _____________\n"
+#~ " |   EVENTS    |      |   PERSON_EVENT   |      |             |       "
+#~ "___________________\n"
+#~ " |_____________|      |__________________|      |    PERSON   |      "
+#~ "|                   |\n"
+#~ " |             |      |                  |      |_____________|      | "
+#~ "PERSON_EMAIL_ADDR |\n"
+#~ " | *EVENT_ID   | <--> | *EVENT_ID        |      |             |      |"
+#~ "___________________|\n"
+#~ " |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  | <--> |  "
+#~ "*PERSON_ID       |\n"
+#~ " |  TITLE      |      |__________________|      |  AGE        |      |  "
+#~ "*EMAIL_ADDR      |\n"
+#~ " |_____________|                                |  FIRSTNAME  |      |"
+#~ "___________________|\n"
+#~ "                                                |  LASTNAME   |\n"
+#~ "                                                |_____________|\n"
+#~ " ]]>"
 #~ msgstr ""
-#~ "今 <literal>-Daction=list</literal> と指定してAntを呼ぶと、 これまで格納し"
-#~ "たイベントが見えるはずです。 <literal>store</literal> アクションを数回以上"
-#~ "呼ぶことも可能です。"
+#~ "_____________        __________________\n"
+#~ " |             |      |                  |       _____________\n"
+#~ " |   EVENTS    |      |   PERSON_EVENT   |      |             |       "
+#~ "___________________\n"
+#~ " |_____________|      |__________________|      |    PERSON   |      "
+#~ "|                   |\n"
+#~ " |             |      |                  |      |_____________|      | "
+#~ "PERSON_EMAIL_ADDR |\n"
+#~ " | *EVENT_ID   | &lt;--&gt; | *EVENT_ID        |      |             "
+#~ "|      |___________________|\n"
+#~ " |  EVENT_DATE |      | *PERSON_ID       | &lt;--&gt; | *PERSON_ID  | "
+#~ "&lt;--&gt; |  *PERSON_ID       |\n"
+#~ " |  TITLE      |      |__________________|      |  AGE        |      |  "
+#~ "*EMAIL_ADDR      |\n"
+#~ " |_____________|                                |  FIRSTNAME  |      |"
+#~ "___________________|\n"
+#~ "                                                |  LASTNAME   |\n"
+#~ "                                                |_____________|"
 
+#, fuzzy
 #~ msgid ""
-#~ "Note: Most new Hibernate users fail at this point and we see questions "
-#~ "about <emphasis>Table not found</emphasis> error messages regularly. "
-#~ "However, if you follow the steps outlined above you will not have this "
-#~ "problem, as hbm2ddl creates the database schema on the first run, and "
-#~ "subsequent application restarts will use this schema. If you change the "
-#~ "mapping and/or database schema, you have to re-enable hbm2ddl once again."
+#~ "<![CDATA[    private void addEmailToPerson(Long personId, String "
+#~ "emailAddress) {\n"
+#~ "        Session session = HibernateUtil.getSessionFactory()."
+#~ "getCurrentSession();\n"
+#~ "        session.beginTransaction();\n"
+#~ "\n"
+#~ "        Person aPerson = (Person) session.load(Person.class, personId);\n"
+#~ "        // adding to the emailAddress collection might trigger a lazy "
+#~ "load of the collection\n"
+#~ "        aPerson.getEmailAddresses().add(emailAddress);\n"
+#~ "\n"
+#~ "        session.getTransaction().commit();\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "注意:初めてHibernateに触れる人々の多くがここで失敗するため、"
-#~ "<emphasis>Table not found</emphasis> エラーメッセージに 関する質問を定期的"
-#~ "に見かけます。 しかし上記のステップに従えば、hbm2ddlが最初に実行されたとき"
-#~ "にデータベーススキーマを作成し、 その後の実行においてもこのスキーマを使用"
-#~ "するので、問題は起こらないでしょう。 マッピングやデータベーススキーマを変"
-#~ "更したときは、もう一度hbm2ddlを有効にしてください。"
+#~ "private void addEmailToPerson(Long personId, String emailAddress) {\n"
+#~ "\n"
+#~ "    Session session = HibernateUtil.getSessionFactory().getCurrentSession"
+#~ "();\n"
+#~ "    session.beginTransaction();\n"
+#~ "\n"
+#~ "    Person aPerson = (Person) session.load(Person.class, personId);\n"
+#~ "\n"
+#~ "    // The getEmailAddresses() might trigger a lazy load of the "
+#~ "collection\n"
+#~ "    aPerson.getEmailAddresses().add(emailAddress);\n"
+#~ "\n"
+#~ "    session.getTransaction().commit();\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "Create a new mapping file called <literal>Person.hbm.xml</literal> (don't "
-#~ "forget the DTD reference at the top):"
+#~ "<![CDATA[    private Set participants = new HashSet();\n"
+#~ "\n"
+#~ "    public Set getParticipants() {\n"
+#~ "        return participants;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setParticipants(Set participants) {\n"
+#~ "        this.participants = participants;\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "<literal>Person.hbm.xml</literal> という新しいマッピングファイルを作成して"
-#~ "ください (ファイルの最初にDTDへの参照を忘れずに入れてください):"
+#~ "private Set participants = new HashSet();\n"
+#~ "\n"
+#~ "public Set getParticipants() {\n"
+#~ "    return participants;\n"
+#~ "}\n"
+#~ "\n"
+#~ "public void setParticipants(Set participants) {\n"
+#~ "    this.participants = participants;\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "We need a unidirectional, many-valued associations, implemented with a "
-#~ "<literal>Set</literal>. Let's write the code for this in the Java classes "
-#~ "and then map it:"
+#~ "<![CDATA[        <set name=\"participants\" table=\"PERSON_EVENT\" "
+#~ "inverse=\"true\">\n"
+#~ "            <key column=\"EVENT_ID\"/>\n"
+#~ "            <many-to-many column=\"PERSON_ID\" class=\"events.Person\"/>\n"
+#~ "        </set>]]>"
 #~ msgstr ""
-#~ "<literal>Set</literal> で実装される単方向、多値関連が必要です。 Javaクラス"
-#~ "内に対応するコードを書いてマッピングしましょう:"
+#~ "&lt;set name=\"participants\" table=\"PERSON_EVENT\" inverse=\"true"
+#~ "\"&gt;\n"
+#~ "    &lt;key column=\"EVENT_ID\"/&gt;\n"
+#~ "    &lt;many-to-many column=\"PERSON_ID\" class=\"events.Person\"/&gt;\n"
+#~ "&lt;/set&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "We add a collection of value typed objects to the <literal>Person</"
-#~ "literal> entity. We want to store email addresses, so the type we use is "
-#~ "<literal>String</literal>, and the collection is again a <literal>Set</"
-#~ "literal>:"
+#~ "<![CDATA[    protected Set getEvents() {\n"
+#~ "        return events;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    protected void setEvents(Set events) {\n"
+#~ "        this.events = events;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void addToEvent(Event event) {\n"
+#~ "        this.getEvents().add(event);\n"
+#~ "        event.getParticipants().add(this);\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void removeFromEvent(Event event) {\n"
+#~ "        this.getEvents().remove(event);\n"
+#~ "        event.getParticipants().remove(this);\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "値型オブジェクトのコレクションを <literal>Person</literal> エンティティへ"
-#~ "追加します。 Eメールアドレスを格納したいのですが、<literal>String</"
-#~ "literal> 型を使っているので、 コレクションは再び <literal>Set</literal> で"
-#~ "す:"
+#~ "protected Set getEvents() {\n"
+#~ "    return events;\n"
+#~ "}\n"
+#~ "\n"
+#~ "protected void setEvents(Set events) {\n"
+#~ "    this.events = events;\n"
+#~ "}\n"
+#~ "\n"
+#~ "public void addToEvent(Event event) {\n"
+#~ "    this.getEvents().add(event);\n"
+#~ "    event.getParticipants().add(this);\n"
+#~ "}\n"
+#~ "\n"
+#~ "public void removeFromEvent(Event event) {\n"
+#~ "    this.getEvents().remove(event);\n"
+#~ "    event.getParticipants().remove(this);\n"
+#~ "}"
 
-#~ msgid "Let's turn this into a small web application."
-#~ msgstr "ではこれを小さなWebアプリケーションにしてみましょう。"
-
+#, fuzzy
 #~ msgid ""
-#~ "Create a new class in your source directory, in the <literal>events</"
-#~ "literal> package:"
+#~ "<![CDATA[package org.hibernate.tutorial.web;\n"
+#~ "\n"
+#~ "// Imports\n"
+#~ "\n"
+#~ "public class EventManagerServlet extends HttpServlet {\n"
+#~ "\n"
+#~ "    protected void doGet(\n"
+#~ "            HttpServletRequest request,\n"
+#~ "            HttpServletResponse response) throws ServletException, "
+#~ "IOException {\n"
+#~ "\n"
+#~ "        SimpleDateFormat dateFormatter = new SimpleDateFormat( \"dd.MM."
+#~ "yyyy\" );\n"
+#~ "\n"
+#~ "        try {\n"
+#~ "            // Begin unit of work\n"
+#~ "            HibernateUtil.getSessionFactory().getCurrentSession()."
+#~ "beginTransaction();\n"
+#~ "\n"
+#~ "            // Process request and render page...\n"
+#~ "\n"
+#~ "            // End unit of work\n"
+#~ "            HibernateUtil.getSessionFactory().getCurrentSession()."
+#~ "getTransaction().commit();\n"
+#~ "        }\n"
+#~ "        catch (Exception ex) {\n"
+#~ "            HibernateUtil.getSessionFactory().getCurrentSession()."
+#~ "getTransaction().rollback();\n"
+#~ "            if ( ServletException.class.isInstance( ex ) ) {\n"
+#~ "                throw ( ServletException ) ex;\n"
+#~ "            }\n"
+#~ "            else {\n"
+#~ "                throw new ServletException( ex );\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
 #~ msgstr ""
-#~ "新しいクラスを、ソースディレクトリの <literal>events</literal> パッケージ"
-#~ "に作成してください。"
+#~ "protected void doGet(HttpServletRequest request,\n"
+#~ "                     HttpServletResponse response)\n"
+#~ "        throws ServletException, IOException {\n"
+#~ "\n"
+#~ "    SimpleDateFormat dateFormatter = new SimpleDateFormat(\"dd.MM.yyyy"
+#~ "\");\n"
+#~ "\n"
+#~ "    try {\n"
+#~ "        // Begin unit of work\n"
+#~ "        HibernateUtil.getSessionFactory()\n"
+#~ "                .getCurrentSession().beginTransaction();\n"
+#~ "\n"
+#~ "        // Process request and render page...\n"
+#~ "\n"
+#~ "        // End unit of work\n"
+#~ "        HibernateUtil.getSessionFactory()\n"
+#~ "                .getCurrentSession().getTransaction().commit();\n"
+#~ "\n"
+#~ "    } catch (Exception ex) {\n"
+#~ "        HibernateUtil.getSessionFactory()\n"
+#~ "                .getCurrentSession().getTransaction().rollback();\n"
+#~ "        throw new ServletException(ex);\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "To deploy this application you have to create a web archive, a WAR. Add "
-#~ "the following Ant target to your <literal>build.xml</literal>:"
+#~ "<![CDATA[        // Write HTML header\n"
+#~ "        PrintWriter out = response.getWriter();\n"
+#~ "        out.println(\"<html><head><title>Event Manager</title></"
+#~ "head><body>\");\n"
+#~ "\n"
+#~ "        // Handle actions\n"
+#~ "        if ( \"store\".equals(request.getParameter(\"action\")) ) {\n"
+#~ "\n"
+#~ "            String eventTitle = request.getParameter(\"eventTitle\");\n"
+#~ "            String eventDate = request.getParameter(\"eventDate\");\n"
+#~ "\n"
+#~ "            if ( \"\".equals(eventTitle) || \"\".equals(eventDate) ) {\n"
+#~ "                out.println(\"<b><i>Please enter event title and date.</"
+#~ "i></b>\");\n"
+#~ "            }\n"
+#~ "            else {\n"
+#~ "                createAndStoreEvent(eventTitle, dateFormatter.parse"
+#~ "(eventDate));\n"
+#~ "                out.println(\"<b><i>Added event.</i></b>\");\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "\n"
+#~ "        // Print page\n"
+#~ "       printEventForm(out);\n"
+#~ "       listEvents(out, dateFormatter);\n"
+#~ "\n"
+#~ "       // Write HTML footer\n"
+#~ "       out.println(\"</body></html>\");\n"
+#~ "       out.flush();\n"
+#~ "       out.close();]]>"
 #~ msgstr ""
-#~ "このアプリケーションのデプロイのために、Webアーカイブ(WAR)を作成してくだ"
-#~ "さい。 以下のAntターゲットを <literal>build.xml</literal> に加えてくださ"
-#~ "い。"
+#~ "// Write HTML header\n"
+#~ "PrintWriter out = response.getWriter();\n"
+#~ "out.println(\"&lt;html&gt;&lt;head&gt;&lt;title&gt;Event Manager&lt;/"
+#~ "title&gt;&lt;/head&gt;&lt;body&gt;\");\n"
+#~ "\n"
+#~ "// Handle actions\n"
+#~ "if ( \"store\".equals(request.getParameter(\"action\")) ) {\n"
+#~ "\n"
+#~ "    String eventTitle = request.getParameter(\"eventTitle\");\n"
+#~ "    String eventDate = request.getParameter(\"eventDate\");\n"
+#~ "\n"
+#~ "    if ( \"\".equals(eventTitle) || \"\".equals(eventDate) ) {\n"
+#~ "        out.println(\"&lt;b&gt;&lt;i&gt;Please enter event title and date."
+#~ "&lt;/i&gt;&lt;/b&gt;\");\n"
+#~ "    } else {\n"
+#~ "        createAndStoreEvent(eventTitle, dateFormatter.parse(eventDate));\n"
+#~ "        out.println(\"&lt;b&gt;&lt;i&gt;Added event.&lt;/i&gt;&lt;/b&gt;"
+#~ "\");\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "\n"
+#~ "// Print page\n"
+#~ "printEventForm(out);\n"
+#~ "listEvents(out, dateFormatter);\n"
+#~ "\n"
+#~ "// Write HTML footer\n"
+#~ "out.println(\"&lt;/body&gt;&lt;/html&gt;\");\n"
+#~ "out.flush();\n"
+#~ "out.close();"
 
+#, fuzzy
 #~ msgid ""
-#~ "This target creates a file called <literal>hibernate-tutorial.war</"
-#~ "literal> in your project directory. It packages all libraries and the "
-#~ "<literal>web.xml</literal> descriptor, which is expected in the base "
-#~ "directory of your project:"
+#~ "<![CDATA[    private void printEventForm(PrintWriter out) {\n"
+#~ "        out.println(\"<h2>Add new event:</h2>\");\n"
+#~ "        out.println(\"<form>\");\n"
+#~ "        out.println(\"Title: <input name='eventTitle' length='50'/><br/>"
+#~ "\");\n"
+#~ "        out.println(\"Date (e.g. 24.12.2009): <input name='eventDate' "
+#~ "length='10'/><br/>\");\n"
+#~ "        out.println(\"<input type='submit' name='action' value='store'/>"
+#~ "\");\n"
+#~ "        out.println(\"</form>\");\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "このターゲットは <literal>hibernate-tutorial.war</literal> というファイル"
-#~ "を プロジェクトディレクトリに作成します。 このファイルはすべてのライブラリ"
-#~ "と <literal>web.xml</literal> 記述子を含んでおり、 プロジェクトのベース"
-#~ "ディレクトリに置かれることを期待されます。"
+#~ "private void printEventForm(PrintWriter out) {\n"
+#~ "    out.println(\"&lt;h2&gt;Add new event:&lt;/h2&gt;\");\n"
+#~ "    out.println(\"&lt;form&gt;\");\n"
+#~ "    out.println(\"Title: &lt;input name='eventTitle' length='50'/&gt;&lt;"
+#~ "br/&gt;\");\n"
+#~ "    out.println(\"Date (e.g. 24.12.2009): &lt;input name='eventDate' "
+#~ "length='10'/&gt;&lt;br/&gt;\");\n"
+#~ "    out.println(\"&lt;input type='submit' name='action' value='store'/&gt;"
+#~ "\");\n"
+#~ "    out.println(\"&lt;/form&gt;\");\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "Before you compile and deploy the web application, note that an "
-#~ "additional library is required: <literal>jsdk.jar</literal>. This is the "
-#~ "Java servlet development kit, if you don't have this library already, get "
-#~ "it from the Sun website and copy it to your library directory. However, "
-#~ "it will be only used for compliation and excluded from the WAR package."
+#~ "<![CDATA[    private void listEvents(PrintWriter out, SimpleDateFormat "
+#~ "dateFormatter) {\n"
+#~ "\n"
+#~ "        List result = HibernateUtil.getSessionFactory()\n"
+#~ "                .getCurrentSession().createCriteria(Event.class).list();\n"
+#~ "        if (result.size() > 0) {\n"
+#~ "            out.println(\"<h2>Events in database:</h2>\");\n"
+#~ "            out.println(\"<table border='1'>\");\n"
+#~ "            out.println(\"<tr>\");\n"
+#~ "            out.println(\"<th>Event title</th>\");\n"
+#~ "            out.println(\"<th>Event date</th>\");\n"
+#~ "            out.println(\"</tr>\");\n"
+#~ "            Iterator it = result.iterator();\n"
+#~ "            while (it.hasNext()) {\n"
+#~ "                Event event = (Event) it.next();\n"
+#~ "                out.println(\"<tr>\");\n"
+#~ "                out.println(\"<td>\" + event.getTitle() + \"</td>\");\n"
+#~ "                out.println(\"<td>\" + dateFormatter.format(event.getDate"
+#~ "()) + \"</td>\");\n"
+#~ "                out.println(\"</tr>\");\n"
+#~ "            }\n"
+#~ "            out.println(\"</table>\");\n"
+#~ "        }\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "Webアプリケーションのコンパイルとデプロイの前に、 <literal>jsdk.jar</"
-#~ "literal> という 追加のライブラリが必要なことに注意してください。 これは"
-#~ "Javaサーブレットの開発キットです。 もしまだこのライブラリを持っていないな"
-#~ "ら、Sunのウェブサイトで入手して、 ライブラリディレクトリにコピーしてくださ"
-#~ "い。 しかし、これはコンパイルにのみ使用され、WARパッケージからは除外されま"
-#~ "す。"
+#~ "private void listEvents(PrintWriter out, SimpleDateFormat dateFormatter) "
+#~ "{\n"
+#~ "\n"
+#~ "    List result = HibernateUtil.getSessionFactory()\n"
+#~ "                    .getCurrentSession().createCriteria(Event.class).list"
+#~ "();\n"
+#~ "    if (result.size() &gt; 0) {\n"
+#~ "        out.println(\"&lt;h2&gt;Events in database:&lt;/h2&gt;\");\n"
+#~ "        out.println(\"&lt;table border='1'&gt;\");\n"
+#~ "        out.println(\"&lt;tr&gt;\");\n"
+#~ "        out.println(\"&lt;th&gt;Event title&lt;/th&gt;\");\n"
+#~ "        out.println(\"&lt;th&gt;Event date&lt;/th&gt;\");\n"
+#~ "        out.println(\"&lt;/tr&gt;\");\n"
+#~ "        for (Iterator it = result.iterator(); it.hasNext();) {\n"
+#~ "            Event event = (Event) it.next();\n"
+#~ "            out.println(\"&lt;tr&gt;\");\n"
+#~ "            out.println(\"&lt;td&gt;\" + event.getTitle() + \"&lt;/td&gt;"
+#~ "\");\n"
+#~ "            out.println(\"&lt;td&gt;\" + dateFormatter.format(event."
+#~ "getDate()) + \"&lt;/td&gt;\");\n"
+#~ "            out.println(\"&lt;/tr&gt;\");\n"
+#~ "        }\n"
+#~ "        out.println(\"&lt;/table&gt;\");\n"
+#~ "    }\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "If you already feel confident with Hibernate, continue browsing through "
-#~ "the reference documentation table of contents for topics you find "
-#~ "interesting - most asked are transactional processing (<xref linkend="
-#~ "\"transactions\"/>), fetch performance (<xref linkend=\"performance\"/>), "
-#~ "or the usage of the API (<xref linkend=\"objectstate\"/>) and the query "
-#~ "features (<xref linkend=\"objectstate-querying\"/>)."
+#~ "<![CDATA[    protected void createAndStoreEvent(String title, Date "
+#~ "theDate) {\n"
+#~ "        Event theEvent = new Event();\n"
+#~ "        theEvent.setTitle(title);\n"
+#~ "        theEvent.setDate(theDate);\n"
+#~ "\n"
+#~ "        HibernateUtil.getSessionFactory()\n"
+#~ "                .getCurrentSession().save(theEvent);\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "もうHibernateに自信があれば、リファレンスドキュメントの目次に目を通して、 "
-#~ "面白そうだと思うトピックを探してください。 最も頻繁に質問があるのは、トラ"
-#~ "ンザクション処理(<xref linkend=\"transactions\"/>)、 フェッチのパフォー"
-#~ "マンス(<xref linkend=\"performance\"/>)、 APIの使い方(<xref linkend="
-#~ "\"objectstate\"/>)とクエリ (<xref linkend=\"objectstate-querying\"/>)で"
-#~ "す。"
+#~ "protected void createAndStoreEvent(String title, Date theDate) {\n"
+#~ "    Event theEvent = new Event();\n"
+#~ "    theEvent.setTitle(title);\n"
+#~ "    theEvent.setDate(theDate);\n"
+#~ "\n"
+#~ "    HibernateUtil.getSessionFactory()\n"
+#~ "                    .getCurrentSession().save(theEvent);\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "Don't forget to check the Hibernate website for more (specialized) "
-#~ "tutorials."
+#~ "<![CDATA[<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
+#~ "<web-app version=\"2.4\"\n"
+#~ "    xmlns=\"http://java.sun.com/xml/ns/j2ee\"\n"
+#~ "    xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
+#~ "    xsi:schemaLocation=\"http://java.sun.com/xml/ns/j2ee http://java.sun."
+#~ "com/xml/ns/j2ee/web-app_2_4.xsd\">\n"
+#~ "\n"
+#~ "    <servlet>\n"
+#~ "        <servlet-name>Event Manager</servlet-name>\n"
+#~ "        <servlet-class>org.hibernate.tutorial.web.EventManagerServlet</"
+#~ "servlet-class>\n"
+#~ "    </servlet>\n"
+#~ "\n"
+#~ "    <servlet-mapping>\n"
+#~ "        <servlet-name>Event Manager</servlet-name>\n"
+#~ "        <url-pattern>/eventmanager</url-pattern>\n"
+#~ "    </servlet-mapping>\n"
+#~ "</web-app>]]>"
 #~ msgstr ""
-#~ "さらに(特別な)チュートリアルが必要なら、Hibernateウェブサイトを忘れずに"
-#~ "チェックしてください。"
+#~ "&lt;?xml version=\"1.0\" encoding=\"UTF-8\"?&gt;\n"
+#~ "&lt;web-app version=\"2.4\"\n"
+#~ "    xmlns=\"http://java.sun.com/xml/ns/j2ee\"\n"
+#~ "    xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
+#~ "    xsi:schemaLocation=\"http://java.sun.com/xml/ns/j2ee\n"
+#~ "        http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd\"&gt;\n"
+#~ "\n"
+#~ "    &lt;servlet&gt;\n"
+#~ "        &lt;servlet-name&gt;Event Manager&lt;/servlet-name&gt;\n"
+#~ "        &lt;servlet-class&gt;events.EventManagerServlet&lt;/servlet-"
+#~ "class&gt;\n"
+#~ "    &lt;/servlet&gt;\n"
+#~ "\n"
+#~ "    &lt;servlet-mapping&gt;\n"
+#~ "        &lt;servlet-name&gt;Event Manager&lt;/servlet-name&gt;\n"
+#~ "        &lt;url-pattern&gt;/eventmanager&lt;/url-pattern&gt;\n"
+#~ "    &lt;/servlet-mapping&gt;\n"
+#~ "&lt;/web-app&gt;"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/content/xml.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/content/xml.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/content/xml.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,50 +1,50 @@
+# translation of Collection_Mapping.po to
+# Xi HUANG <xhuang at redhat.com>, 2007, 2010.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2010-01-18 15:42+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: xml.xml:29
 #, no-c-format
 msgid "XML Mapping"
-msgstr "XMLマッピング"
+msgstr "XML マッピング"
 
-#. Tag: emphasis
-#: xml.xml:31
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
-"XML Mapping is an experimental feature in Hibernate 3.0 and is currently "
-"under active development."
+"<emphasis> XML Mapping is an experimental feature in Hibernate 3.0 and is "
+"currently under active development. </emphasis>"
 msgstr ""
-"XMLマッピングはHibernate3.0では試験的な機能であり、非常に活動的に開発中です。"
+"XML マッピングは Hibernate3.0 では試験的な機能であり、非常に活動的に開発中で"
+"す。"
 
 #. Tag: title
-#: xml.xml:37
 #, no-c-format
 msgid "Working with XML data"
-msgstr "XMLデータでの作業"
+msgstr "XML データでの作業"
 
 #. Tag: para
-#: xml.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate allows you to work with persistent XML data in much the same way "
 "you work with persistent POJOs. A parsed XML tree can be thought of as "
 "another way of representing the relational data at the object level, instead "
 "of POJOs."
 msgstr ""
-"Hibernateでは永続性のPOJOを使って作業するのとほぼ同じようなやり方で、 永続性"
-"のXMLデータを使って作業できます。"
+"Hibernate では永続性の POJO を使って作業するのとほぼ同じようなやり方で、永続"
+"性の XML データを使って作業できます。解析された XML ツリーは POJO の代わりに"
+"オブジェクトレベルで関係データを表わす別の方法であるとみなされています。"
 
 #. Tag: para
-#: xml.xml:46
 #, no-c-format
 msgid ""
 "Hibernate supports dom4j as API for manipulating XML trees. You can write "
@@ -55,170 +55,102 @@
 "(), saveOrUpdate(), merge(), delete(), replicate()</literal> (merging is not "
 "yet supported)."
 msgstr ""
-"HibernateはXMLツリーを操作するためのAPIとしてdom4jをサポートしています。 デー"
-"タベースからdom4jのツリーを復元するクエリを書くことができ、 ツリーに対して"
-"行った修正は自動的にデータベースと同期されます。 またXMLドキュメントを取得す"
-"ることができ、dom4jを使ってドキュメントをパースし、 Hibernateの任意の基本操作"
-"を使ってデータベースへ書き込むことができます。: つまり、<literal>persist(), "
-"saveOrUpdate(), merge(), delete(), replicate()</literal> 操作です(マージはま"
-"だサポートしていません)。"
+"Hibernate は XML ツリーを操作するための API として dom4j をサポートしていま"
+"す。データベースから dom4j のツリーを復元するクエリを書くことができ、ツリーに"
+"対して行った修正は自動的にデータベースと同期されます。また XML ドキュメントを"
+"取得することができ、 dom4j を使ってドキュメントをパースし、 Hibernate の任意"
+"の基本操作を使ってデータベースへ書き込むことができます。: つまり、 "
+"<literal>persist(), saveOrUpdate(), merge(), delete(), replicate()</literal> "
+"操作です (マージはまだサポートしていません)。"
 
 #. Tag: para
-#: xml.xml:56
 #, no-c-format
 msgid ""
 "This feature has many applications including data import/export, "
 "externalization of entity data via JMS or SOAP and XSLT-based reporting."
 msgstr ""
-"データのインポート/エクスポート、 JMSによるエンティティデータの外部化やSOAP、"
-"XSLTベースのレポートなど、 この機能には多くの用途があります。"
+"データのインポート/エクスポート、 JMS によるエンティティデータの外部化や "
+"SOAP 、 XSLT ベースのレポートなど、この機能には多くの用途があります。"
 
 #. Tag: para
-#: xml.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A single mapping can be used to simultaneously map properties of a class and "
 "nodes of an XML document to the database, or, if there is no class to map, "
 "it can be used to map just the XML."
 msgstr ""
-"単一のマッピングは、クラスのプロパティとXMLドキュメントのノードを 同時にデー"
-"タベースへマッピングするために使うことができます。 またマッピングするクラスが"
-"なければ、 XMLだけをマッピングするために使うことができます。"
+"単一のマッピングは、クラスのプロパティと XML ドキュメントのノードを同時にデー"
+"タベースへマッピングするために使うことができます。またマッピングするクラスが"
+"なければ、 XML だけをマッピングするために使うことができます。"
 
 #. Tag: title
-#: xml.xml:68
 #, no-c-format
 msgid "Specifying XML and class mapping together"
-msgstr "XMLとクラスのマッピングを同時に指定する"
+msgstr "XML とクラスのマッピングを同時に指定する"
 
 #. Tag: para
-#: xml.xml:70
 #, no-c-format
 msgid "Here is an example of mapping a POJO and XML simultaneously:"
-msgstr "これはPOJOとXMLを同時にマッピングする例です。:"
+msgstr "これは POJO と XML を同時にマッピングする例です:"
 
-#. Tag: programlisting
-#: xml.xml:74
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Account\" \n"
-"        table=\"ACCOUNTS\" \n"
-"        node=\"account\">\n"
-"        \n"
-"    <id name=\"accountId\" \n"
-"            column=\"ACCOUNT_ID\" \n"
-"            node=\"@id\"/>\n"
-"            \n"
-"    <many-to-one name=\"customer\" \n"
-"            column=\"CUSTOMER_ID\" \n"
-"            node=\"customer/@id\" \n"
-"            embed-xml=\"false\"/>\n"
-"            \n"
-"    <property name=\"balance\" \n"
-"            column=\"BALANCE\" \n"
-"            node=\"balance\"/>\n"
-"            \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: xml.xml:78
 #, no-c-format
 msgid "Specifying only an XML mapping"
-msgstr "XMLマッピングだけを指定する"
+msgstr "XML マッピングだけを指定する"
 
 #. Tag: para
-#: xml.xml:80
 #, no-c-format
 msgid "Here is an example where there is no POJO class:"
-msgstr "これはPOJOクラスがないマッピングの例です。:"
+msgstr "これは POJO クラスがないマッピングの例です:"
 
-#. Tag: programlisting
-#: xml.xml:84
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class entity-name=\"Account\" \n"
-"        table=\"ACCOUNTS\" \n"
-"        node=\"account\">\n"
-"        \n"
-"    <id name=\"id\" \n"
-"            column=\"ACCOUNT_ID\" \n"
-"            node=\"@id\" \n"
-"            type=\"string\"/>\n"
-"            \n"
-"    <many-to-one name=\"customerId\" \n"
-"            column=\"CUSTOMER_ID\" \n"
-"            node=\"customer/@id\" \n"
-"            embed-xml=\"false\" \n"
-"            entity-name=\"Customer\"/>\n"
-"            \n"
-"    <property name=\"balance\" \n"
-"            column=\"BALANCE\" \n"
-"            node=\"balance\" \n"
-"            type=\"big_decimal\"/>\n"
-"            \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: xml.xml:86
-#, fuzzy, no-c-format
-msgid ""
 "This mapping allows you to access the data as a dom4j tree, or as a graph of "
 "property name/value pairs or java <literal>Map</literal>s. The property "
 "names are purely logical constructs that can be referred to in HQL queries."
 msgstr ""
-"このマッピングにより、dom4jツリーか、 プロパティ名/値の組のグラフ(javaの "
-"<literal>Map</literal>)として データにアクセスできます。 プロパティの名前"
-"は、HQLクエリー内で参照できる純粋な論理構造です。"
+"このマッピングにより、 dom4j ツリーか、プロパティ名/値の組のグラフ(java の "
+"<literal>Map</literal>)としてデータにアクセスできます。プロパティの名前は、 "
+"HQL クエリ内で参照できる純粋な論理構造です。"
 
 #. Tag: title
-#: xml.xml:97
 #, no-c-format
 msgid "XML mapping metadata"
-msgstr "XMLマッピングのメタデータ"
+msgstr "XML マッピングのメタデータ"
 
 #. Tag: para
-#: xml.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A range of Hibernate mapping elements accept the <literal>node</literal> "
 "attribute. This lets you specify the name of an XML attribute or element "
 "that holds the property or entity data. The format of the <literal>node</"
 "literal> attribute must be one of the following:"
 msgstr ""
-"多くのHibernateのマッピング要素は <literal>node</literal> 属性が使用できま"
-"す。 これによりXML属性の名前やプロパティやエンティティデータを保持する要素を"
-"指定できます。 <literal>node</literal> 属性のフォーマットは以下の中の1つでな"
-"ければなりません。:"
+"多くの Hibernate のマッピング要素は <literal>node</literal> 属性が使用できま"
+"す。これにより XML 属性の名前やプロパティやエンティティデータを保持する要素を"
+"指定できます。 <literal>node</literal> 属性のフォーマットは以下の中の1つでな"
+"ければなりません:"
 
 #. Tag: para
-#: xml.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>\"element-name\"</literal>: map to the named XML element"
 msgstr ""
-"<literal>\"element-name\"</literal> - 指定したXML要素へマッピングします"
+"<literal>\"element-name\"</literal> - 指定した XML 要素へマッピングします"
 
 #. Tag: para
-#: xml.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>\"@attribute-name\"</literal>: map to the named XML attribute"
 msgstr ""
-"<literal>\"@attribute-name\"</literal> - 指定したXML属性へマッピングします"
+"<literal>\"@attribute-name\"</literal> - 指定した XML 属性へマッピングします"
 
 #. Tag: para
-#: xml.xml:114
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>\".\"</literal>: map to the parent element"
-msgstr "<literal>\".\"</literal> - 親要素へマッピングします"
+msgstr "<literal>\".\"</literal> - 親要素へマッピングします"
 
 #. Tag: para
-#: xml.xml:117
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>\"element-name/@attribute-name\"</literal>: map to the named "
 "attribute of the named element"
@@ -227,8 +159,7 @@
 "定した属性へマッピングします"
 
 #. Tag: para
-#: xml.xml:124
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For collections and single valued associations, there is an additional "
 "<literal>embed-xml</literal> attribute. If <literal>embed-xml=\"true\"</"
@@ -238,204 +169,373 @@
 "then only the referenced identifier value will appear in the XML for single "
 "point associations and collections will not appear at all."
 msgstr ""
-"コレクションと単一の値の関連に対して、 おまけの <literal>embed-xml</literal> "
-"属性があります。 デフォルトの <literal>embed-xml=\"true\"</literal> と設定し"
-"た場合、 関連するエンティティ(値型のコレクション)のXMLツリーは、 直接関連を所"
-"有するエンティティのXMLツリー内に埋め込まれます。 反対に、<literal>embed-xml="
-"\"false\"</literal> と設定した場合、 参照される識別子の値だけが多重度1側の関"
-"連に対するXMLに現れ、 単純にコレクションはまったく現れなくなります。"
+"コレクションと単一の値の関連に対して、おまけの <literal>embed-xml</literal> "
+"属性があります。デフォルトの <literal>embed-xml=\"true\"</literal> と設定した"
+"場合、関連するエンティティ (値型のコレクション) の XML ツリーは、直接関連を所"
+"有するエンティティの XML ツリー内に埋め込まれます。反対に、 <literal>embed-"
+"xml=\"false\"</literal> と設定した場合、参照される識別子の値だけが多重度1側"
+"の関連に対する XML に現れ、単純にコレクションはまったく現れなくなります。"
 
 #. Tag: para
-#: xml.xml:134
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not leave <literal>embed-xml=\"true\"</literal> for too many "
 "associations, since XML does not deal well with circularity."
 msgstr ""
 "あまりに多くの関連に対して <literal>embed-xml=\"true\"</literal> としたままに"
-"するのは注意すべきです。 XMLは循環をうまく扱えません。"
+"するのは注意すべきです。 XML は循環をうまく扱えません。"
 
-#. Tag: programlisting
-#: xml.xml:139
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Customer\" \n"
-"        table=\"CUSTOMER\" \n"
-"        node=\"customer\">\n"
-"        \n"
-"    <id name=\"id\" \n"
-"            column=\"CUST_ID\" \n"
-"            node=\"@id\"/>\n"
-"            \n"
-"    <map name=\"accounts\" \n"
-"            node=\".\" \n"
-"            embed-xml=\"true\">\n"
-"        <key column=\"CUSTOMER_ID\" \n"
-"                not-null=\"true\"/>\n"
-"        <map-key column=\"SHORT_DESC\" \n"
-"                node=\"@short-desc\" \n"
-"                type=\"string\"/>\n"
-"        <one-to-many entity-name=\"Account\"\n"
-"                embed-xml=\"false\" \n"
-"                node=\"account\"/>\n"
-"    </map>\n"
-"    \n"
-"    <component name=\"name\" \n"
-"            node=\"name\">\n"
-"        <property name=\"firstName\" \n"
-"                node=\"first-name\"/>\n"
-"        <property name=\"initial\" \n"
-"                node=\"initial\"/>\n"
-"        <property name=\"lastName\" \n"
-"                node=\"last-name\"/>\n"
-"    </component>\n"
-"    \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: xml.xml:141
-#, fuzzy, no-c-format
-msgid ""
 "In this case, the collection of account ids is embedded, but not the actual "
 "account data. The following HQL query:"
 msgstr ""
-"この例では、実際のaccountのデータではなく、 accountのidのコレクションを埋め込"
-"むことにしました。 続きのHQLクエリです:"
+"この例では、実際の account のデータではなく、 account の id のコレクションを"
+"埋め込むことにしました。続きの HQL クエリです:"
 
-#. Tag: programlisting
-#: xml.xml:146
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[from Customer c left join fetch c.accounts where c.lastName like :"
-"lastName]]>"
-msgstr ""
-
-#. Tag: para
-#: xml.xml:148
-#, fuzzy, no-c-format
 msgid "would return datasets such as this:"
-msgstr "このようなデータセットを返すでしょう"
+msgstr "このようなデータセットを返すでしょう:"
 
-#. Tag: programlisting
-#: xml.xml:152
-#, no-c-format
-msgid ""
-"<![CDATA[<customer id=\"123456789\">\n"
-"    <account short-desc=\"Savings\">987632567</account>\n"
-"    <account short-desc=\"Credit Card\">985612323</account>\n"
-"    <name>\n"
-"        <first-name>Gavin</first-name>\n"
-"        <initial>A</initial>\n"
-"        <last-name>King</last-name>\n"
-"    </name>\n"
-"    ...\n"
-"</customer>]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:154
 #, no-c-format
 msgid ""
 "If you set <literal>embed-xml=\"true\"</literal> on the <literal>&lt;one-to-"
 "many&gt;</literal> mapping, the data might look more like this:"
 msgstr ""
 "<literal>&lt;one-to-many&gt;</literal> マッピングで <literal>embed-xml=\"true"
-"\"</literal> と設定した場合、 データはこのようになるでしょう。"
+"\"</literal> と設定した場合、データはこのようになるでしょう。"
 
-#. Tag: programlisting
-#: xml.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[<customer id=\"123456789\">\n"
-"    <account id=\"987632567\" short-desc=\"Savings\">\n"
-"        <customer id=\"123456789\"/>\n"
-"        <balance>100.29</balance>\n"
-"    </account>\n"
-"    <account id=\"985612323\" short-desc=\"Credit Card\">\n"
-"        <customer id=\"123456789\"/>\n"
-"        <balance>-2370.34</balance>\n"
-"    </account>\n"
-"    <name>\n"
-"        <first-name>Gavin</first-name>\n"
-"        <initial>A</initial>\n"
-"        <last-name>King</last-name>\n"
-"    </name>\n"
-"    ...\n"
-"</customer>]]>"
-msgstr ""
-
 #. Tag: title
-#: xml.xml:165
 #, no-c-format
 msgid "Manipulating XML data"
-msgstr "XMLデータを扱う"
+msgstr "XML データを扱う"
 
 #. Tag: para
-#: xml.xml:167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also re-read and update XML documents in the application. You can do "
 "this by obtaining a dom4j session:"
 msgstr ""
-"XMLドキュメントを、アプリケーション内で再読み込みや更新をしてみましょう。 以"
-"下ではdom4jのセッションを取得することで行います。:"
+"XML ドキュメントを、アプリケーション内で再読み込みや更新をしてみましょう。以"
+"下では dom4j のセッションを取得することで行います:"
 
-#. Tag: programlisting
-#: xml.xml:172
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Document doc = ....;\n"
-"       \n"
-"Session session = factory.openSession();\n"
-"Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"List results = dom4jSession\n"
-"    .createQuery(\"from Customer c left join fetch c.accounts where c."
-"lastName like :lastName\")\n"
-"    .list();\n"
-"for ( int i=0; i<results.size(); i++ ) {\n"
-"    //add the customer data to the XML document\n"
-"    Element customer = (Element) results.get(i);\n"
-"    doc.add(customer);\n"
-"}\n"
-"\n"
-"tx.commit();\n"
-"session.close();]]>"
+"When implementing XML-based data import/export, it is useful to combine this "
+"feature with Hibernate's <literal>replicate()</literal> operation."
 msgstr ""
+"XML ベースのデータのインポート/エクスポートを実装するために、 Hibernate の "
+"<literal>replicate()</literal> 操作をこの機能に結びつけるのは極めて有効です。"
 
-#. Tag: programlisting
-#: xml.xml:174
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = factory.openSession();\n"
-"Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"Element cust = (Element) dom4jSession.get(\"Customer\", customerId);\n"
-"for ( int i=0; i<results.size(); i++ ) {\n"
-"    Element customer = (Element) results.get(i);\n"
-"    //change the customer name in the XML and database\n"
-"    Element name = customer.element(\"name\");\n"
-"    name.element(\"first-name\").setText(firstName);\n"
-"    name.element(\"initial\").setText(initial);\n"
-"    name.element(\"last-name\").setText(lastName);\n"
-"}\n"
-"\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Account\" \n"
+#~ "        table=\"ACCOUNTS\" \n"
+#~ "        node=\"account\">\n"
+#~ "        \n"
+#~ "    <id name=\"accountId\" \n"
+#~ "            column=\"ACCOUNT_ID\" \n"
+#~ "            node=\"@id\"/>\n"
+#~ "            \n"
+#~ "    <many-to-one name=\"customer\" \n"
+#~ "            column=\"CUSTOMER_ID\" \n"
+#~ "            node=\"customer/@id\" \n"
+#~ "            embed-xml=\"false\"/>\n"
+#~ "            \n"
+#~ "    <property name=\"balance\" \n"
+#~ "            column=\"BALANCE\" \n"
+#~ "            node=\"balance\"/>\n"
+#~ "            \n"
+#~ "    ...\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Account\" \n"
+#~ "        table=\"ACCOUNTS\" \n"
+#~ "        node=\"account\"&gt;\n"
+#~ "        \n"
+#~ "    &lt;id name=\"accountId\" \n"
+#~ "            column=\"ACCOUNT_ID\" \n"
+#~ "            node=\"@id\"/&gt;\n"
+#~ "            \n"
+#~ "    &lt;many-to-one name=\"customer\" \n"
+#~ "            column=\"CUSTOMER_ID\" \n"
+#~ "            node=\"customer/@id\" \n"
+#~ "            embed-xml=\"false\"/&gt;\n"
+#~ "            \n"
+#~ "    &lt;property name=\"balance\" \n"
+#~ "            column=\"BALANCE\" \n"
+#~ "            node=\"balance\"/&gt;\n"
+#~ "            \n"
+#~ "    ...\n"
+#~ "    \n"
+#~ "&lt;/class&gt;"
 
-#. Tag: para
-#: xml.xml:176
-#, fuzzy, no-c-format
-msgid ""
-"When implementing XML-based data import/export, it is useful to combine this "
-"feature with Hibernate's <literal>replicate()</literal> operation."
-msgstr ""
-"XMLベースのデータのインポート/エクスポートを実装するために、 Hibernateの "
-"<literal>replicate()</literal> 操作をこの機能を結びつけるのは 極めて有効で"
-"す。"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class entity-name=\"Account\" \n"
+#~ "        table=\"ACCOUNTS\" \n"
+#~ "        node=\"account\">\n"
+#~ "        \n"
+#~ "    <id name=\"id\" \n"
+#~ "            column=\"ACCOUNT_ID\" \n"
+#~ "            node=\"@id\" \n"
+#~ "            type=\"string\"/>\n"
+#~ "            \n"
+#~ "    <many-to-one name=\"customerId\" \n"
+#~ "            column=\"CUSTOMER_ID\" \n"
+#~ "            node=\"customer/@id\" \n"
+#~ "            embed-xml=\"false\" \n"
+#~ "            entity-name=\"Customer\"/>\n"
+#~ "            \n"
+#~ "    <property name=\"balance\" \n"
+#~ "            column=\"BALANCE\" \n"
+#~ "            node=\"balance\" \n"
+#~ "            type=\"big_decimal\"/>\n"
+#~ "            \n"
+#~ "    ...\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class entity-name=\"Account\" \n"
+#~ "        table=\"ACCOUNTS\" \n"
+#~ "        node=\"account\"&gt;\n"
+#~ "        \n"
+#~ "    &lt;id name=\"id\" \n"
+#~ "            column=\"ACCOUNT_ID\" \n"
+#~ "            node=\"@id\" \n"
+#~ "            type=\"string\"/&gt;\n"
+#~ "            \n"
+#~ "    &lt;many-to-one name=\"customerId\" \n"
+#~ "            column=\"CUSTOMER_ID\" \n"
+#~ "            node=\"customer/@id\" \n"
+#~ "            embed-xml=\"false\" \n"
+#~ "            entity-name=\"Customer\"/&gt;\n"
+#~ "            \n"
+#~ "    &lt;property name=\"balance\" \n"
+#~ "            column=\"BALANCE\" \n"
+#~ "            node=\"balance\" \n"
+#~ "            type=\"big_decimal\"/&gt;\n"
+#~ "            \n"
+#~ "    ...\n"
+#~ "    \n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Customer\" \n"
+#~ "        table=\"CUSTOMER\" \n"
+#~ "        node=\"customer\">\n"
+#~ "        \n"
+#~ "    <id name=\"id\" \n"
+#~ "            column=\"CUST_ID\" \n"
+#~ "            node=\"@id\"/>\n"
+#~ "            \n"
+#~ "    <map name=\"accounts\" \n"
+#~ "            node=\".\" \n"
+#~ "            embed-xml=\"true\">\n"
+#~ "        <key column=\"CUSTOMER_ID\" \n"
+#~ "                not-null=\"true\"/>\n"
+#~ "        <map-key column=\"SHORT_DESC\" \n"
+#~ "                node=\"@short-desc\" \n"
+#~ "                type=\"string\"/>\n"
+#~ "        <one-to-many entity-name=\"Account\"\n"
+#~ "                embed-xml=\"false\" \n"
+#~ "                node=\"account\"/>\n"
+#~ "    </map>\n"
+#~ "    \n"
+#~ "    <component name=\"name\" \n"
+#~ "            node=\"name\">\n"
+#~ "        <property name=\"firstName\" \n"
+#~ "                node=\"first-name\"/>\n"
+#~ "        <property name=\"initial\" \n"
+#~ "                node=\"initial\"/>\n"
+#~ "        <property name=\"lastName\" \n"
+#~ "                node=\"last-name\"/>\n"
+#~ "    </component>\n"
+#~ "    \n"
+#~ "    ...\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Customer\" \n"
+#~ "        table=\"CUSTOMER\" \n"
+#~ "        node=\"customer\"&gt;\n"
+#~ "        \n"
+#~ "    &lt;id name=\"id\" \n"
+#~ "            column=\"CUST_ID\" \n"
+#~ "            node=\"@id\"/&gt;\n"
+#~ "            \n"
+#~ "    &lt;map name=\"accounts\" \n"
+#~ "            node=\".\" \n"
+#~ "            embed-xml=\"true\"&gt;\n"
+#~ "        &lt;key column=\"CUSTOMER_ID\" \n"
+#~ "                not-null=\"true\"/&gt;\n"
+#~ "        &lt;map-key column=\"SHORT_DESC\" \n"
+#~ "                node=\"@short-desc\" \n"
+#~ "                type=\"string\"/&gt;\n"
+#~ "        &lt;one-to-many entity-name=\"Account\"\n"
+#~ "                embed-xml=\"false\" \n"
+#~ "                node=\"account\"/&gt;\n"
+#~ "    &lt;/map&gt;\n"
+#~ "    \n"
+#~ "    &lt;component name=\"name\" \n"
+#~ "            node=\"name\"&gt;\n"
+#~ "        &lt;property name=\"firstName\" \n"
+#~ "                node=\"first-name\"/&gt;\n"
+#~ "        &lt;property name=\"initial\" \n"
+#~ "                node=\"initial\"/&gt;\n"
+#~ "        &lt;property name=\"lastName\" \n"
+#~ "                node=\"last-name\"/&gt;\n"
+#~ "    &lt;/component&gt;\n"
+#~ "    \n"
+#~ "    ...\n"
+#~ "    \n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Customer c left join fetch c.accounts where c.lastName "
+#~ "like :lastName]]>"
+#~ msgstr ""
+#~ "from Customer c left join fetch c.accounts where c.lastName like :lastName"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<customer id=\"123456789\">\n"
+#~ "    <account short-desc=\"Savings\">987632567</account>\n"
+#~ "    <account short-desc=\"Credit Card\">985612323</account>\n"
+#~ "    <name>\n"
+#~ "        <first-name>Gavin</first-name>\n"
+#~ "        <initial>A</initial>\n"
+#~ "        <last-name>King</last-name>\n"
+#~ "    </name>\n"
+#~ "    ...\n"
+#~ "</customer>]]>"
+#~ msgstr ""
+#~ "&lt;customer id=\"123456789\"&gt;\n"
+#~ "    &lt;account short-desc=\"Savings\"&gt;987632567&lt;/account&gt;\n"
+#~ "    &lt;account short-desc=\"Credit Card\"&gt;985612323&lt;/account&gt;\n"
+#~ "    &lt;name&gt;\n"
+#~ "        &lt;first-name&gt;Gavin&lt;/first-name&gt;\n"
+#~ "        &lt;initial&gt;A&lt;/initial&gt;\n"
+#~ "        &lt;last-name&gt;King&lt;/last-name&gt;\n"
+#~ "    &lt;/name&gt;\n"
+#~ "    ...\n"
+#~ "&lt;/customer&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<customer id=\"123456789\">\n"
+#~ "    <account id=\"987632567\" short-desc=\"Savings\">\n"
+#~ "        <customer id=\"123456789\"/>\n"
+#~ "        <balance>100.29</balance>\n"
+#~ "    </account>\n"
+#~ "    <account id=\"985612323\" short-desc=\"Credit Card\">\n"
+#~ "        <customer id=\"123456789\"/>\n"
+#~ "        <balance>-2370.34</balance>\n"
+#~ "    </account>\n"
+#~ "    <name>\n"
+#~ "        <first-name>Gavin</first-name>\n"
+#~ "        <initial>A</initial>\n"
+#~ "        <last-name>King</last-name>\n"
+#~ "    </name>\n"
+#~ "    ...\n"
+#~ "</customer>]]>"
+#~ msgstr ""
+#~ "&lt;customer id=\"123456789\"&gt;\n"
+#~ "    &lt;account id=\"987632567\" short-desc=\"Savings\"&gt;\n"
+#~ "        &lt;customer id=\"123456789\"/&gt;\n"
+#~ "        &lt;balance&gt;100.29&lt;/balance&gt;\n"
+#~ "    &lt;/account&gt;\n"
+#~ "    &lt;account id=\"985612323\" short-desc=\"Credit Card\"&gt;\n"
+#~ "        &lt;customer id=\"123456789\"/&gt;\n"
+#~ "        &lt;balance&gt;-2370.34&lt;/balance&gt;\n"
+#~ "    &lt;/account&gt;\n"
+#~ "    &lt;name&gt;\n"
+#~ "        &lt;first-name&gt;Gavin&lt;/first-name&gt;\n"
+#~ "        &lt;initial&gt;A&lt;/initial&gt;\n"
+#~ "        &lt;last-name&gt;King&lt;/last-name&gt;\n"
+#~ "    &lt;/name&gt;\n"
+#~ "    ...\n"
+#~ "&lt;/customer&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Document doc = ....;\n"
+#~ "       \n"
+#~ "Session session = factory.openSession();\n"
+#~ "Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "List results = dom4jSession\n"
+#~ "    .createQuery(\"from Customer c left join fetch c.accounts where c."
+#~ "lastName like :lastName\")\n"
+#~ "    .list();\n"
+#~ "for ( int i=0; i<results.size(); i++ ) {\n"
+#~ "    //add the customer data to the XML document\n"
+#~ "    Element customer = (Element) results.get(i);\n"
+#~ "    doc.add(customer);\n"
+#~ "}\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "Document doc = ....;\n"
+#~ "       \n"
+#~ "Session session = factory.openSession();\n"
+#~ "Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "List results = dom4jSession\n"
+#~ "    .createQuery(\"from Customer c left join fetch c.accounts where c."
+#~ "lastName like :lastName\")\n"
+#~ "    .list();\n"
+#~ "for ( int i=0; i&lt;results.size(); i++ ) {\n"
+#~ "    //add the customer data to the XML document\n"
+#~ "    Element customer = (Element) results.get(i);\n"
+#~ "    doc.add(customer);\n"
+#~ "}\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "session.close();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Session session = factory.openSession();\n"
+#~ "Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "Element cust = (Element) dom4jSession.get(\"Customer\", customerId);\n"
+#~ "for ( int i=0; i<results.size(); i++ ) {\n"
+#~ "    Element customer = (Element) results.get(i);\n"
+#~ "    //change the customer name in the XML and database\n"
+#~ "    Element name = customer.element(\"name\");\n"
+#~ "    name.element(\"first-name\").setText(firstName);\n"
+#~ "    name.element(\"initial\").setText(initial);\n"
+#~ "    name.element(\"last-name\").setText(lastName);\n"
+#~ "}\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "Session session = factory.openSession();\n"
+#~ "Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "Element cust = (Element) dom4jSession.get(\"Customer\", customerId);\n"
+#~ "for ( int i=0; i&lt;results.size(); i++ ) {\n"
+#~ "    Element customer = (Element) results.get(i);\n"
+#~ "    //change the customer name in the XML and database\n"
+#~ "    Element name = customer.element(\"name\");\n"
+#~ "    name.element(\"first-name\").setText(firstName);\n"
+#~ "    name.element(\"initial\").setText(initial);\n"
+#~ "    name.element(\"last-name\").setText(lastName);\n"
+#~ "}\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "session.close();"

Modified: core/trunk/documentation/manual/src/main/docbook/ja-JP/legal_notice.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ja-JP/legal_notice.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ja-JP/legal_notice.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,35 +2,33 @@
 msgid ""
 msgstr ""
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:23\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
 "Content-Type: text/plain; charset=UTF-8\n"
 
 #. Tag: title
-#: legal_notice.xml:28
 #, no-c-format
 msgid "Legal Notice"
 msgstr "Legal Notice"
 
-#. Tag: address
-#: legal_notice.xml:30
-#, no-c-format
+#. Tag: para
+#, fuzzy, no-c-format
 msgid ""
-"<street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
-"state><postcode>27606-2072</postcode><country>USA</country> <phone>Phone: +1 "
-"919 754 3700</phone> <phone>Phone: 888 733 4281</phone> <fax>Fax: +1 919 754 "
-"3701</fax> <pob>PO Box 13588</pob><city>Research Triangle Park</city>, "
-"<state>NC</state><postcode>27709</postcode><country>USA</country>"
+"<address> <street>1801 Varsity Drive</street> <city>Raleigh</city>, "
+"<state>NC</state><postcode>27606-2072</postcode><country>USA</country> "
+"<phone>Phone: +1 919 754 3700</phone> <phone>Phone: 888 733 4281</phone> "
+"<fax>Fax: +1 919 754 3701</fax> <pob>PO Box 13588</pob><city>Research "
+"Triangle Park</city>, <state>NC</state><postcode>27709</"
+"postcode><country>USA</country> </address>"
 msgstr ""
-"<street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
+"<address> <street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
 "state><postcode>27606-2072</postcode><country>USA</country> <phone>Phone: +1 "
 "919 754 3700</phone> <phone>Phone: 888 733 4281</phone> <fax>Fax: +1 919 754 "
 "3701</fax> <pob>PO Box 13588</pob><city>Research Triangle Park</city>, "
-"<state>NC</state><postcode>27709</postcode><country>USA</country>"
+"<state>NC</state><postcode>27709</postcode><country>USA</country> </address>"
 
 #. Tag: para
-#: legal_notice.xml:39
 #, fuzzy, no-c-format
 msgid ""
 "Copyright <trademark class=\"copyright\"></trademark> 2007 by Red Hat, Inc. "
@@ -46,7 +44,6 @@
 "Public License</ulink>, as published by the Free Software Foundation."
 
 #. Tag: para
-#: legal_notice.xml:45
 #, no-c-format
 msgid ""
 "Red Hat and the Red Hat \"Shadow Man\" logo are registered trademarks of Red "
@@ -56,7 +53,6 @@
 "Hat, Inc. in the United States and other countries."
 
 #. Tag: para
-#: legal_notice.xml:48
 #, no-c-format
 msgid ""
 "All other trademarks referenced herein are the property of their respective "
@@ -66,13 +62,11 @@
 "owners."
 
 #. Tag: para
-#: legal_notice.xml:51
 #, no-c-format
 msgid "The GPG fingerprint of the security at redhat.com key is:"
 msgstr "The GPG fingerprint of the security at redhat.com key is:"
 
 #. Tag: para
-#: legal_notice.xml:54
 #, no-c-format
 msgid "CA 20 86 86 2B D6 9D FC 65 F6 EC C4 21 91 80 CD DB 42 A6 0E"
 msgstr "CA 20 86 86 2B D6 9D FC 65 F6 EC C4 21 91 80 CD DB 42 A6 0E"

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/Hibernate_Reference.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/Hibernate_Reference.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/Hibernate_Reference.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,32 +1,30 @@
+# SOME DESCRIPTIVE TITLE.
+# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+#
 #, fuzzy
 msgid ""
 msgstr ""
+"Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-11T05:38:14\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Content-Type: text/plain; charset=UTF-8\n"
+"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: Hibernate_Reference.xml:35
 #, no-c-format
 msgid "HIBERNATE - Relational Persistence for Idiomatic Java"
-msgstr "HIBERNATE - 개성있는 자바를 위한 관계 영속"
+msgstr ""
 
 #. Tag: subtitle
-#: Hibernate_Reference.xml:36
 #, no-c-format
 msgid "Hibernate Reference Documentation"
-msgstr "하이버네이트 참조 문서"
+msgstr ""
 
-#. Tag: holder
-#: Hibernate_Reference.xml:51
+#. Tag: releaseinfo
 #, no-c-format
-msgid "&copyrightHolder;"
-msgstr "&copyrightHolder;"
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+msgid "&versionNumber;"
+msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/author_group.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/author_group.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/author_group.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -5,7 +5,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: 2009-07-14 19:55+0000\n"
 "Last-Translator: Automatically generated\n"
 "Language-Team: none\n"
@@ -13,209 +13,137 @@
 "Content-Type: text/plain; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
-#. Tag: author
-#: author_group.xml:27
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Gavin</firstname> <surname>King</surname>"
+msgid "Gavin"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:31
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Christian</firstname> <surname>Bauer</surname>"
+msgid "Christian"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:35
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Max</firstname> <othername>Rydahl</othername> <surname>Andersen</"
-"surname>"
+msgid "Max"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:40
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<author><firstname>Emmanuel</firstname> <surname>Bernard</surname></author>"
+msgid "Emmanuel"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:44
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Steve</firstname> <surname>Ebersole</surname>"
+msgid "Steve"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:49
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>James</firstname> <surname>Cobb</surname>"
+msgid "James"
 msgstr ""
 
-#. Tag: shortaffil
-#: author_group.xml:53 author_group.xml:60
+#. Tag: firstname
 #, no-c-format
-msgid "Graphic Design"
+msgid "Cheyenne"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:56
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Cheyenne</firstname> <surname>Weaver</surname>"
+msgid "Vincent"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:69
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<othername><![CDATA[Bernardo Antonio Buffa Colom&#x00e9]]></othername> "
-"<email>kreimer at bbs.frc.utn.edu.ar</email>"
+msgid "Sebastien"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:79
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Vincent</firstname> <surname>Ricard</surname>"
+msgid "Michael"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:83
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Sebastien</firstname> <surname>Cesbron</surname>"
+msgid "Baptiste"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:87
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Michael</firstname> <surname>Courcy</surname>"
+msgid "Anthony"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:91
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Vincent</firstname> <surname>Giguère</surname>"
+msgid "Alvaro"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:95
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Baptiste</firstname> <surname>Mathus</surname>"
+msgid "Anderson"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:99
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<othercredit><firstname>Emmanuel</firstname> <surname>Bernard</surname></"
-"othercredit>"
+msgid "Daniel Vieira"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:103
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Anthony</firstname> <surname>Patricio</surname>"
+msgid "Francisco"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:113
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Alvaro</firstname> <surname>Netto</surname> "
-"<email>alvaronetto at cetip.com.br</email>"
+msgid "Gamarra"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:118
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Anderson</firstname> <surname>Braulio</surname> "
-"<email>andersonbraulio at gmail.com</email>"
+msgid "Luiz Carlos"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:123
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Daniel Vieira</firstname> <surname>Costa</surname> "
-"<email>danielvc at gmail.com</email>"
+msgid "Marcel"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:128
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Francisco</firstname> <surname>gamarra</surname> <email>francisco."
-"gamarra at gmail.com</email>"
+msgid "Paulo"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:133
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Gamarra</firstname> <email>mauricio.gamarra at gmail.com</email>"
+msgid "Pablo L."
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:137
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Luiz Carlos</firstname> <surname>Rodrigues</surname> "
-"<email>luizcarlos_rodrigues at yahoo.com.br</email>"
+msgid "Renato"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:142
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Marcel</firstname> <surname>Castelo</surname> <email>marcel."
-"castelo at gmail.com</email>"
+msgid "Rogério"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:147
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Paulo</firstname> <surname>César</surname> <email>paulocol at gmail."
-"com</email>"
+msgid "Wanderson"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:152
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Pablo L.</firstname> <surname>de Miranda</surname> "
-"<email>pablolmiranda at gmail.com</email>"
+msgid "Cao"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:157
+#. Tag: orgname
 #, no-c-format
-msgid ""
-"<firstname>Renato</firstname> <surname>Deggau</surname> <email>rdeggau at gmail."
-"com</email>"
+msgid "RedSaga"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:162
+#. Tag: contrib
 #, no-c-format
-msgid ""
-"<firstname>Rogério</firstname> <surname>Araújo</surname> "
-"<email>rgildoaraujo at yahoo.com.br</email>"
+msgid "Translation Lead"
 msgstr ""
-
-#. Tag: othercredit
-#: author_group.xml:167
-#, no-c-format
-msgid ""
-"<firstname>Wanderson</firstname> <surname>Siqueira</surname> "
-"<email>wandersonxs at gmail.com</email>"
-msgstr ""
-
-#. Tag: othercredit
-#: author_group.xml:178
-#, no-c-format
-msgid ""
-"<firstname>Cao</firstname> <surname>Xiaogang</surname> <affiliation> "
-"<orgname>RedSaga</orgname> </affiliation> <contrib>Translation Lead</"
-"contrib> <email>caoxg at yahoo.com</email>"
-msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/architecture.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/architecture.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/architecture.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: 2010-01-12 20:35+0900\n"
 "Last-Translator: Jongdae Kim <jdkim528 at korea.com>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,314 +11,580 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: architecture.xml:30
 #, no-c-format
 msgid "Architecture"
 msgstr "아키텍처"
 
 #. Tag: title
-#: architecture.xml:33
 #, no-c-format
 msgid "Overview"
 msgstr "개요"
 
 #. Tag: para
-#: architecture.xml:35
 #, no-c-format
-msgid "The diagram below provides a high-level view of the Hibernate architecture:"
+msgid ""
+"The diagram below provides a high-level view of the Hibernate architecture:"
 msgstr "아래 다이어그램은 Hibernate 아키텍처에 대한 높은 수준의 뷰를 제공한다:"
 
 #. Tag: para
-#: architecture.xml:48
 #, no-c-format
-msgid "We do not have the scope in this document to provide a more detailed view of all the runtime architectures available; Hibernate is flexible and supports several different approaches. We will, however, show the two extremes: \"minimal\" architecture and \"comprehensive\" architecture."
-msgstr "우리가 이용 가능한 모든 런타임 아키텍처들에 대한 보다 상세한 개요를 제공하는 것은 이 문서의 범위를 넘어선다; Hibernate는 유연하며 몇몇 다른 접근법들을 제공한다. 하지만 우리는 두 가지 극단을 보여줄 것이다. \"최소\" 아키텍처와 \"종합\" 아키텍처."
+msgid ""
+"We do not have the scope in this document to provide a more detailed view of "
+"all the runtime architectures available; Hibernate is flexible and supports "
+"several different approaches. We will, however, show the two extremes: "
+"\"minimal\" architecture and \"comprehensive\" architecture."
+msgstr ""
+"우리가 이용 가능한 모든 런타임 아키텍처들에 대한 보다 상세한 개요를 제공하는 "
+"것은 이 문서의 범위를 넘어선다; Hibernate는 유연하며 몇몇 다른 접근법들을 제"
+"공한다. 하지만 우리는 두 가지 극단을 보여줄 것이다. \"최소\" 아키텍처와 \"종"
+"합\" 아키텍처."
 
 #. Tag: para
-#: architecture.xml:54
 #, no-c-format
-msgid "This next diagram illustrates how Hibernate utilizes database and configuration data to provide persistence services, and persistent objects, to the application."
-msgstr "이 다음 다이어그램은  하이버네이트가 영속화 서비스들과 영속 객체들을 어플리케이션에 제공하기 위해 데이터베이스와 컨피그레이션 데이터를 어떻게 이용하는지를 설명한다."
+msgid ""
+"This next diagram illustrates how Hibernate utilizes database and "
+"configuration data to provide persistence services, and persistent objects, "
+"to the application."
+msgstr ""
+"이 다음 다이어그램은  하이버네이트가 영속화 서비스들과 영속 객체들을 어플리케"
+"이션에 제공하기 위해 데이터베이스와 컨피그레이션 데이터를 어떻게 이용하는지"
+"를 설명한다."
 
 #. Tag: para
-#: architecture.xml:59
 #, no-c-format
-msgid "The \"minimal\" architecture has the application provide its own JDBC connections and manage its own transactions. This approach uses a minimal subset of Hibernate's APIs:"
-msgstr "\"최소\" 아키텍처는 어플리케이션으로 하여금 그것 자신의 JDBC 커넥션들을 가지고 그것 자신의 트랜잭션들을 관리하도록 한다. 이 접근법은 하이버네이트 API의 최소 부분집합을 사용한다:"
+msgid ""
+"The \"minimal\" architecture has the application provide its own JDBC "
+"connections and manage its own transactions. This approach uses a minimal "
+"subset of Hibernate's APIs:"
+msgstr ""
+"\"최소\" 아키텍처는 어플리케이션으로 하여금 그것 자신의 JDBC 커넥션들을 가지"
+"고 그것 자신의 트랜잭션들을 관리하도록 한다. 이 접근법은 하이버네이트 API의 "
+"최소 부분집합을 사용한다:"
 
 #. Tag: para
-#: architecture.xml:74
 #, no-c-format
-msgid "The \"comprehensive\" architecture abstracts the application away from the underlying JDBC/JTA APIs and allows Hibernate to manage the details."
-msgstr "\"종합\" 아키텍처는 기본 JDBC/JTA로부터 어플리케이션을 추상화 시키고 Hibernate로 하여금 세부적인 것을 관리하도록 한다."
+msgid ""
+"The \"comprehensive\" architecture abstracts the application away from the "
+"underlying JDBC/JTA APIs and allows Hibernate to manage the details."
+msgstr ""
+"\"종합\" 아키텍처는 기본 JDBC/JTA로부터 어플리케이션을 추상화 시키고 "
+"Hibernate로 하여금 세부적인 것을 관리하도록 한다."
 
 #. Tag: para
-#: architecture.xml:88
 #, no-c-format
 msgid "Here are some definitions of the objects depicted in the diagrams:"
 msgstr "다음은 다이어그램에 도해되어 있는 객체들에 대한 몇가지 정의들이다:"
 
 #. Tag: term
-#: architecture.xml:93
 #, no-c-format
 msgid "SessionFactory (<literal>org.hibernate.SessionFactory</literal>)"
 msgstr "SessionFactory (<literal>org.hibernate.SessionFactory</literal>)"
 
 #. Tag: para
-#: architecture.xml:95
 #, no-c-format
-msgid "A threadsafe, immutable cache of compiled mappings for a single database. A factory for <literal>Session</literal> and a client of <literal>ConnectionProvider</literal>, <literal>SessionFactory</literal> can hold an optional (second-level) cache of data that is reusable between transactions at a process, or cluster, level."
-msgstr "단일 데이터베이스에 대해 컴파일된 매핑들에 관한 쓰레드안전한, 불변 캐시. <literal>Session</literal>을 위한 팩토리와 <literal>ConnectionProvider</literal>, <literal>SessionFactory</literal>의 클라이언트는 프로세스 레벨 또는 클러스터 레벨에서 트랜잭션들 사이에 재사용이 가능한 데이터에 대한 선택적인 (second-level) 캐시를 보유할 수 있다."
+msgid ""
+"A threadsafe, immutable cache of compiled mappings for a single database. A "
+"factory for <literal>Session</literal> and a client of "
+"<literal>ConnectionProvider</literal>, <literal>SessionFactory</literal> can "
+"hold an optional (second-level) cache of data that is reusable between "
+"transactions at a process, or cluster, level."
+msgstr ""
+"단일 데이터베이스에 대해 컴파일된 매핑들에 관한 쓰레드안전한, 불변 캐시. "
+"<literal>Session</literal>을 위한 팩토리와 <literal>ConnectionProvider</"
+"literal>, <literal>SessionFactory</literal>의 클라이언트는 프로세스 레벨 또"
+"는 클러스터 레벨에서 트랜잭션들 사이에 재사용이 가능한 데이터에 대한 선택적"
+"인 (second-level) 캐시를 보유할 수 있다."
 
 #. Tag: term
-#: architecture.xml:105
 #, no-c-format
 msgid "Session (<literal>org.hibernate.Session</literal>)"
 msgstr "Session (<literal>org.hibernate.Session</literal>)"
 
 #. Tag: para
-#: architecture.xml:107
 #, no-c-format
-msgid "A single-threaded, short-lived object representing a conversation between the application and the persistent store. It wraps a JDBC connection and is a factory for <literal>Transaction</literal>. <literal>Session</literal> holds a mandatory first-level cache of persistent objects that are used when navigating the object graph or looking up objects by identifier."
-msgstr "어플리케이션과 영속 저장소 사이의 대화를 표현하는 단일 쓰레드이면서 수명이 짧은 객체. 그것은 JDBC 커넥션을 포장하며, <literal>Transaction</literal>을 위한 팩토리이다. <literal>Session</literal>은 객체 그래프를 네비게이트 하거나 식별자로서 객체들을 탐색할 때 사용되는 영속 객체들에 대한 필수적인 첫 번째 레벨 캐시를 보유하고 있다."
+msgid ""
+"A single-threaded, short-lived object representing a conversation between "
+"the application and the persistent store. It wraps a JDBC connection and is "
+"a factory for <literal>Transaction</literal>. <literal>Session</literal> "
+"holds a mandatory first-level cache of persistent objects that are used when "
+"navigating the object graph or looking up objects by identifier."
+msgstr ""
+"어플리케이션과 영속 저장소 사이의 대화를 표현하는 단일 쓰레드이면서 수명이 짧"
+"은 객체. 그것은 JDBC 커넥션을 포장하며, <literal>Transaction</literal>을 위"
+"한 팩토리이다. <literal>Session</literal>은 객체 그래프를 네비게이트 하거나 "
+"식별자로서 객체들을 탐색할 때 사용되는 영속 객체들에 대한 필수적인 첫 번째 레"
+"벨 캐시를 보유하고 있다."
 
 #. Tag: term
-#: architecture.xml:117
 #, no-c-format
 msgid "Persistent objects and collections"
 msgstr "영속 객체들과 콜렉션들"
 
 #. Tag: para
-#: architecture.xml:119
 #, no-c-format
-msgid "Short-lived, single threaded objects containing persistent state and business function. These can be ordinary JavaBeans/POJOs. They are associated with exactly one <literal>Session</literal>. Once the <literal>Session</literal> is closed, they will be detached and free to use in any application layer (for example, directly as data transfer objects to and from presentation)."
-msgstr "영속 상태와 비지니스 기능을 포함하는 수명이 짧은, 단일 쓰레드 객체들. 이것들은 통상의 자바빈즈/POJO들일 수 있다. 그것들은 정확히 한 개의 <literal>Session</literal>과 연관지워진다. <literal>Session</literal>이 닫히는 순간, 그것들은 분리될 것이고 임의의 어플리케이션 계층에서 사용이 자유로워진다(예를 들면. 직접적으로 프리젠테이션 계층 사이의 데이터 전송 객체들로서)."
+msgid ""
+"Short-lived, single threaded objects containing persistent state and "
+"business function. These can be ordinary JavaBeans/POJOs. They are "
+"associated with exactly one <literal>Session</literal>. Once the "
+"<literal>Session</literal> is closed, they will be detached and free to use "
+"in any application layer (for example, directly as data transfer objects to "
+"and from presentation)."
+msgstr ""
+"영속 상태와 비지니스 기능을 포함하는 수명이 짧은, 단일 쓰레드 객체들. 이것들"
+"은 통상의 자바빈즈/POJO들일 수 있다. 그것들은 정확히 한 개의 "
+"<literal>Session</literal>과 연관지워진다. <literal>Session</literal>이 닫히"
+"는 순간, 그것들은 분리될 것이고 임의의 어플리케이션 계층에서 사용이 자유로워"
+"진다(예를 들면. 직접적으로 프리젠테이션 계층 사이의 데이터 전송 객체들로서)."
 
 #. Tag: term
-#: architecture.xml:129
 #, no-c-format
 msgid "Transient and detached objects and collections"
 msgstr "전이(Transient, 필자 주-과도) 객체들과 콜렉션들"
 
 #. Tag: para
-#: architecture.xml:131
 #, no-c-format
-msgid "Instances of persistent classes that are not currently associated with a <literal>Session</literal>. They may have been instantiated by the application and not yet persisted, or they may have been instantiated by a closed <literal>Session</literal>."
-msgstr "현재 <literal>Session</literal>과 연관되어 있지 않은 영속 클래스들의 인스턴스들. 그것들은 어플리케이션에 의해 초기화 되었고 아직 영속화 되지 않았거나 그것들은 닫힌 <literal>Session</literal>에 의해 초기화 되었을 수 있다."
+msgid ""
+"Instances of persistent classes that are not currently associated with a "
+"<literal>Session</literal>. They may have been instantiated by the "
+"application and not yet persisted, or they may have been instantiated by a "
+"closed <literal>Session</literal>."
+msgstr ""
+"현재 <literal>Session</literal>과 연관되어 있지 않은 영속 클래스들의 인스턴스"
+"들. 그것들은 어플리케이션에 의해 초기화 되었고 아직 영속화 되지 않았거나 그것"
+"들은 닫힌 <literal>Session</literal>에 의해 초기화 되었을 수 있다."
 
 #. Tag: term
-#: architecture.xml:140
 #, no-c-format
 msgid "Transaction (<literal>org.hibernate.Transaction</literal>)"
 msgstr "Transaction (<literal>org.hibernate.Transaction</literal>)"
 
 #. Tag: para
-#: architecture.xml:142
 #, no-c-format
-msgid "(Optional) A single-threaded, short-lived object used by the application to specify atomic units of work. It abstracts the application from the underlying JDBC, JTA or CORBA transaction. A <literal>Session</literal> might span several <literal>Transaction</literal>s in some cases. However, transaction demarcation, either using the underlying API or <literal>Transaction</literal>, is never optional."
-msgstr "(옵션) 어플리케이션에 의해 작업의 원자 단위를 지정하는데 사용되는 단일 쓰레드인, 수명이 짧은 객체. 그것은 기본 JDBC, JTA 또는 CORBA 트랜잭션으로부터 어플리케이션을 추상화 시킨다. 몇몇 경우들에서 하나의 <literal>Session</literal>은 여러 개의 <literal>Transaction</literal>들에 걸쳐져 있을 수 있다. 하지만 기본 API 또는 <literal>Transaction</literal> 중 어느것을 사용하는 트랜잭션 경계 설정은 결코 옵션이 아니다."
+msgid ""
+"(Optional) A single-threaded, short-lived object used by the application to "
+"specify atomic units of work. It abstracts the application from the "
+"underlying JDBC, JTA or CORBA transaction. A <literal>Session</literal> "
+"might span several <literal>Transaction</literal>s in some cases. However, "
+"transaction demarcation, either using the underlying API or "
+"<literal>Transaction</literal>, is never optional."
+msgstr ""
+"(옵션) 어플리케이션에 의해 작업의 원자 단위를 지정하는데 사용되는 단일 쓰레드"
+"인, 수명이 짧은 객체. 그것은 기본 JDBC, JTA 또는 CORBA 트랜잭션으로부터 어플"
+"리케이션을 추상화 시킨다. 몇몇 경우들에서 하나의 <literal>Session</literal>"
+"은 여러 개의 <literal>Transaction</literal>들에 걸쳐져 있을 수 있다. 하지만 "
+"기본 API 또는 <literal>Transaction</literal> 중 어느것을 사용하는 트랜잭션 경"
+"계 설정은 결코 옵션이 아니다."
 
 #. Tag: term
-#: architecture.xml:153
 #, no-c-format
-msgid "ConnectionProvider (<literal>org.hibernate.connection.ConnectionProvider</literal>)"
-msgstr "ConnectionProvider (<literal>org.hibernate.connection.ConnectionProvider</literal>)"
+msgid ""
+"ConnectionProvider (<literal>org.hibernate.connection.ConnectionProvider</"
+"literal>)"
+msgstr ""
+"ConnectionProvider (<literal>org.hibernate.connection.ConnectionProvider</"
+"literal>)"
 
 #. Tag: para
-#: architecture.xml:155
 #, no-c-format
-msgid "(Optional) A factory for, and pool of, JDBC connections. It abstracts the application from underlying <literal>Datasource</literal> or <literal>DriverManager</literal>. It is not exposed to application, but it can be extended and/or implemented by the developer."
-msgstr "(옵션) JDBC 연결들을 위한 팩토리, 그리고 그것들의 pool. 그것은 기본 <literal>Datasource</literal> 또는 <literal>DriverManager</literal>로부터 어플리케이션을 추상화 시킨다. 그것은 어플리케이션에 노출되지 않지만, 그것은 개발자에 의해 확장 그리고/또는 구현 될 수 있다."
+msgid ""
+"(Optional) A factory for, and pool of, JDBC connections. It abstracts the "
+"application from underlying <literal>Datasource</literal> or "
+"<literal>DriverManager</literal>. It is not exposed to application, but it "
+"can be extended and/or implemented by the developer."
+msgstr ""
+"(옵션) JDBC 연결들을 위한 팩토리, 그리고 그것들의 pool. 그것은 기본 "
+"<literal>Datasource</literal> 또는 <literal>DriverManager</literal>로부터 어"
+"플리케이션을 추상화 시킨다. 그것은 어플리케이션에 노출되지 않지만, 그것은 개"
+"발자에 의해 확장 그리고/또는 구현 될 수 있다."
 
 #. Tag: term
-#: architecture.xml:163
 #, no-c-format
-msgid "TransactionFactory (<literal>org.hibernate.TransactionFactory</literal>)"
-msgstr "TransactionFactory (<literal>org.hibernate.TransactionFactory</literal>)"
+msgid ""
+"TransactionFactory (<literal>org.hibernate.TransactionFactory</literal>)"
+msgstr ""
+"TransactionFactory (<literal>org.hibernate.TransactionFactory</literal>)"
 
 #. Tag: para
-#: architecture.xml:165
 #, no-c-format
-msgid "(Optional) A factory for <literal>Transaction</literal> instances. It is not exposed to the application, but it can be extended and/or implemented by the developer."
-msgstr "(옵션) <literal>Transaction</literal> 인스턴스들을 위한 팩토리. 그것은 어플리케이션에 노출되지 않지만, 그것은  개발자에 의해 확장 그리고/또는 구현 될 수 있다."
+msgid ""
+"(Optional) A factory for <literal>Transaction</literal> instances. It is not "
+"exposed to the application, but it can be extended and/or implemented by the "
+"developer."
+msgstr ""
+"(옵션) <literal>Transaction</literal> 인스턴스들을 위한 팩토리. 그것은 어플리"
+"케이션에 노출되지 않지만, 그것은  개발자에 의해 확장 그리고/또는 구현 될 수 "
+"있다."
 
-#. Tag: emphasis
-#: architecture.xml:172
-#, no-c-format
-msgid "Extension Interfaces"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<emphasis>Extension Interfaces</emphasis>"
 msgstr "Extension Interfaces"
 
 #. Tag: para
-#: architecture.xml:174
 #, no-c-format
-msgid "Hibernate offers a range of optional extension interfaces you can implement to customize the behavior of your persistence layer. See the API documentation for details."
-msgstr "하이버네이트는 당신이 당신의 영속 계층의 행위를 맞춤화 시키기 위해 구현할 수 있는 선택적인 확장 인터페이스들의 영역을 제공한다. 상세한 것은 API 문서를 보라."
+msgid ""
+"Hibernate offers a range of optional extension interfaces you can implement "
+"to customize the behavior of your persistence layer. See the API "
+"documentation for details."
+msgstr ""
+"하이버네이트는 당신이 당신의 영속 계층의 행위를 맞춤화 시키기 위해 구현할 수 "
+"있는 선택적인 확장 인터페이스들의 영역을 제공한다. 상세한 것은 API 문서를 보"
+"라."
 
 #. Tag: para
-#: architecture.xml:183
 #, no-c-format
-msgid "Given a \"minimal\" architecture, the application bypasses the <literal>Transaction</literal>/<literal>TransactionFactory</literal> and/or <literal>ConnectionProvider</literal> APIs to communicate with JTA or JDBC directly."
-msgstr "\"최소\" 아키텍처의 경우, 어플리케이션은 JTA 또는 JDBC와 직접 통신하기 위해 <literal>Transaction</literal>/<literal>TransactionFactory</literal> 그리고/또는 <literal>ConnectionProvider</literal> API들을 무시한다."
+msgid ""
+"Given a \"minimal\" architecture, the application bypasses the "
+"<literal>Transaction</literal>/<literal>TransactionFactory</literal> and/or "
+"<literal>ConnectionProvider</literal> APIs to communicate with JTA or JDBC "
+"directly."
+msgstr ""
+"\"최소\" 아키텍처의 경우, 어플리케이션은 JTA 또는 JDBC와 직접 통신하기 위해 "
+"<literal>Transaction</literal>/<literal>TransactionFactory</literal> 그리고/"
+"또는 <literal>ConnectionProvider</literal> API들을 무시한다."
 
 #. Tag: title
-#: architecture.xml:191
 #, no-c-format
 msgid "Instance states"
 msgstr "인스턴스 상태들"
 
 #. Tag: para
-#: architecture.xml:192
 #, no-c-format
-msgid "An instance of a persistent class can be in one of three different states. These states are defined in relation to a <emphasis>persistence context</emphasis>. The Hibernate <literal>Session</literal> object is the persistence context. The three different states are as follows:"
-msgstr "영속 클래스들의 인스턴스는 세개의 상태들 중 하나에 놓여질 수 있다. 이들 상태들은 <emphasis>영속 컨텍스트</emphasis>에 관련하여 정의된다. 하이버네이트 <literal>Session</literal> 객체는 영속 컨텍스트이다. 세 개의 다른 상태들은 다음과 같다:"
+msgid ""
+"An instance of a persistent class can be in one of three different states. "
+"These states are defined in relation to a <emphasis>persistence context</"
+"emphasis>. The Hibernate <literal>Session</literal> object is the "
+"persistence context. The three different states are as follows:"
+msgstr ""
+"영속 클래스들의 인스턴스는 세개의 상태들 중 하나에 놓여질 수 있다. 이들 상태"
+"들은 <emphasis>영속 컨텍스트</emphasis>에 관련하여 정의된다. 하이버네이트 "
+"<literal>Session</literal> 객체는 영속 컨텍스트이다. 세 개의 다른 상태들은 다"
+"음과 같다:"
 
 #. Tag: term
-#: architecture.xml:200
 #, no-c-format
 msgid "transient"
 msgstr "transient"
 
 #. Tag: para
-#: architecture.xml:202
 #, no-c-format
-msgid "The instance is not associated with any persistence context. It has no persistent identity or primary key value."
-msgstr "그 인스턴스는 임의의 영속 컨텍스트와 연관지워져 있지 않다. 그것은 영속 식별자 또는 프라이머리 키 값을 갖지 않는다."
+msgid ""
+"The instance is not associated with any persistence context. It has no "
+"persistent identity or primary key value."
+msgstr ""
+"그 인스턴스는 임의의 영속 컨텍스트와 연관지워져 있지 않다. 그것은 영속 식별"
+"자 또는 프라이머리 키 값을 갖지 않는다."
 
 #. Tag: term
-#: architecture.xml:210
 #, no-c-format
 msgid "persistent"
 msgstr "persistent"
 
 #. Tag: para
-#: architecture.xml:212
 #, no-c-format
-msgid "The instance is currently associated with a persistence context. It has a persistent identity (primary key value) and can have a corresponding row in the database. For a particular persistence context, Hibernate <emphasis>guarantees</emphasis> that persistent identity is equivalent to Java identity in relation to the in-memory location of the object."
-msgstr "그 인스턴스는 현재 영속 컨텍스트와 연관되어 있다. 그것은 영속 식별자(프라이머리 키 값)을 갖고 있고 데이터베이스 내에서 하나의 대응하는 행을 가질 수 있다. 특정 영속 컨텍스트의 경우, 하이버네이트는 영속 식별자가 객체의 메모리 내 위치에 관하여 자바 식별자와 동등함을 <emphasis>보증한다</emphasis>."
+msgid ""
+"The instance is currently associated with a persistence context. It has a "
+"persistent identity (primary key value) and can have a corresponding row in "
+"the database. For a particular persistence context, Hibernate "
+"<emphasis>guarantees</emphasis> that persistent identity is equivalent to "
+"Java identity in relation to the in-memory location of the object."
+msgstr ""
+"그 인스턴스는 현재 영속 컨텍스트와 연관되어 있다. 그것은 영속 식별자(프라이머"
+"리 키 값)을 갖고 있고 데이터베이스 내에서 하나의 대응하는 행을 가질 수 있다. "
+"특정 영속 컨텍스트의 경우, 하이버네이트는 영속 식별자가 객체의 메모리 내 위치"
+"에 관하여 자바 식별자와 동등함을 <emphasis>보증한다</emphasis>."
 
 #. Tag: term
-#: architecture.xml:224
 #, no-c-format
 msgid "detached"
 msgstr "detached"
 
 #. Tag: para
-#: architecture.xml:226
 #, no-c-format
-msgid "The instance was once associated with a persistence context, but that context was closed, or the instance was serialized to another process. It has a persistent identity and can have a corresponding row in the database. For detached instances, Hibernate does not guarantee the relationship between persistent identity and Java identity."
-msgstr "그 인스턴스는 일단 영속 컨텍스트와 연관되었지만, 그 컨텍스트가 닫혀졌거나, 또는 그 인스턴스가 또 다른 프로세스에 직렬화 되었다. 그것은 영속 식별자를 갖고 있으며, 데이터베이스 내에서 하나의 대응하는 행을 가질 수 있다. 분리된 인스턴스들의 경우, 하이버네이트는 영속 식별자와 자바 식별자 사이의 관계를 보증하지 않는다."
+msgid ""
+"The instance was once associated with a persistence context, but that "
+"context was closed, or the instance was serialized to another process. It "
+"has a persistent identity and can have a corresponding row in the database. "
+"For detached instances, Hibernate does not guarantee the relationship "
+"between persistent identity and Java identity."
+msgstr ""
+"그 인스턴스는 일단 영속 컨텍스트와 연관되었지만, 그 컨텍스트가 닫혀졌거나, 또"
+"는 그 인스턴스가 또 다른 프로세스에 직렬화 되었다. 그것은 영속 식별자를 갖고 "
+"있으며, 데이터베이스 내에서 하나의 대응하는 행을 가질 수 있다. 분리된 인스턴"
+"스들의 경우, 하이버네이트는 영속 식별자와 자바 식별자 사이의 관계를 보증하지 "
+"않는다."
 
 #. Tag: title
-#: architecture.xml:241
 #, no-c-format
 msgid "JMX Integration"
 msgstr "JMX 통합"
 
 #. Tag: para
-#: architecture.xml:243
 #, no-c-format
-msgid "JMX is the J2EE standard for the management of Java components. Hibernate can be managed via a JMX standard service. AN MBean implementation is provided in the distribution: <literal>org.hibernate.jmx.HibernateService</literal>."
-msgstr "JMX는 자바 컴포넌트 관리를 위한 J2EE 표준이다. 하이버네이트는 JMX 표준 서비스를 통해 관리될 수 있다. 하나의 MBean 구현이 배포본 내에 제공된다: <literal>org.hibernate.jmx.HibernateService</literal>."
+msgid ""
+"JMX is the J2EE standard for the management of Java components. Hibernate "
+"can be managed via a JMX standard service. AN MBean implementation is "
+"provided in the distribution: <literal>org.hibernate.jmx.HibernateService</"
+"literal>."
+msgstr ""
+"JMX는 자바 컴포넌트 관리를 위한 J2EE 표준이다. 하이버네이트는 JMX 표준 서비스"
+"를 통해 관리될 수 있다. 하나의 MBean 구현이 배포본 내에 제공된다: "
+"<literal>org.hibernate.jmx.HibernateService</literal>."
 
 #. Tag: para
-#: architecture.xml:249
 #, no-c-format
-msgid "For an example of how to deploy Hibernate as a JMX service on the JBoss Application Server, please see the JBoss User Guide. JBoss AS also provides these benefits if you deploy using JMX:"
-msgstr "JBoss 어플리케이션 서버 상에 JMX 서비스로서 하이버네이트를 배포하는 방법에 대한 예제는 JBoss 사용자 가이드를 보길 바란다. 당신이 JMX를 사용하여 배포할 경우, JBoss AS는 또한 다음 이점들을 제공한다: "
+msgid ""
+"For an example of how to deploy Hibernate as a JMX service on the JBoss "
+"Application Server, please see the JBoss User Guide. JBoss AS also provides "
+"these benefits if you deploy using JMX:"
+msgstr ""
+"JBoss 어플리케이션 서버 상에 JMX 서비스로서 하이버네이트를 배포하는 방법에 대"
+"한 예제는 JBoss 사용자 가이드를 보길 바란다. 당신이 JMX를 사용하여 배포할 경"
+"우, JBoss AS는 또한 다음 이점들을 제공한다: "
 
 #. Tag: para
-#: architecture.xml:257
 #, no-c-format
-msgid "<emphasis>Session Management</emphasis>: the Hibernate <literal>Session</literal>'s life cycle can be automatically bound to the scope of a JTA transaction. This means that you no longer have to manually open and close the <literal>Session</literal>; this becomes the job of a JBoss EJB interceptor. You also do not have to worry about transaction demarcation in your code (if you would like to write a portable persistence layer use the optional Hibernate <literal>Transaction</literal> API for this). You call the <literal>HibernateContext</literal> to access a <literal>Session</literal>."
-msgstr "<emphasis>세션 관리</emphasis>: 하이버네이트 <literal>Session</literal>의 생명주기는 JTA 트랜잭션의 영역에 자동적으로 묶여질 수 있다. 이것은 당신이 <literal>Session</literal>을 더 이상 수작업으로 열거나 닫지 않아도 됨을 의미한다; 이것은 JBoss 인터셉터의 작업이 된다. 당신은 또한 더 이상 당신의 코드 내에서 트랜잭션 격리에 대해 걱정하지 않아도 된다(만일 당신이 이식가능한 영속 계층을 작성하고자 원할 경우 이것을 위해 선택적으로 하이버네이트 <literal>Transaction</literal> API를 사용하라). 당신은 <literal>Session</literal>에 접근하기 위해 <literal>HibernateContext</literal>를 호출한다."
+msgid ""
+"<emphasis>Session Management</emphasis>: the Hibernate <literal>Session</"
+"literal>'s life cycle can be automatically bound to the scope of a JTA "
+"transaction. This means that you no longer have to manually open and close "
+"the <literal>Session</literal>; this becomes the job of a JBoss EJB "
+"interceptor. You also do not have to worry about transaction demarcation in "
+"your code (if you would like to write a portable persistence layer use the "
+"optional Hibernate <literal>Transaction</literal> API for this). You call "
+"the <literal>HibernateContext</literal> to access a <literal>Session</"
+"literal>."
+msgstr ""
+"<emphasis>세션 관리</emphasis>: 하이버네이트 <literal>Session</literal>의 생"
+"명주기는 JTA 트랜잭션의 영역에 자동적으로 묶여질 수 있다. 이것은 당신이 "
+"<literal>Session</literal>을 더 이상 수작업으로 열거나 닫지 않아도 됨을 의미"
+"한다; 이것은 JBoss 인터셉터의 작업이 된다. 당신은 또한 더 이상 당신의 코드 내"
+"에서 트랜잭션 격리에 대해 걱정하지 않아도 된다(만일 당신이 이식가능한 영속 계"
+"층을 작성하고자 원할 경우 이것을 위해 선택적으로 하이버네이트 "
+"<literal>Transaction</literal> API를 사용하라). 당신은 <literal>Session</"
+"literal>에 접근하기 위해 <literal>HibernateContext</literal>를 호출한다."
 
 #. Tag: para
-#: architecture.xml:269
 #, no-c-format
-msgid "<emphasis>HAR deployment</emphasis>: the Hibernate JMX service is deployed using a JBoss service deployment descriptor in an EAR and/or SAR file, as it supports all the usual configuration options of a Hibernate <literal>SessionFactory</literal>. However, you still need to name all your mapping files in the deployment descriptor. If you use the optional HAR deployment, JBoss will automatically detect all mapping files in your HAR file."
-msgstr "<emphasis>HAR 배포</emphasis>: JBoss가 하이버네이트 <literal>SessionFactory</literal>의 거의 모든 구성 옵션들을 지원하므로, 하이버네이트 JMS 서비스는 JBoss 서비스 배포 디스크립터를 사용하여 EAR 그리고/또는 SAR 파일로서 배포된다. 하지만 당신은 여전히 배포 디스크립터 내에 모든 당신의 매핑 파일들을 명명할 필요가 있다. 만일 당신이 선택적인 HAR 배포를 사용할 경우, JBoss는 당신의 HAR 파일 내에 있는 모든 매핑 파일들을 자동적으로 검출할 것이다."
+msgid ""
+"<emphasis>HAR deployment</emphasis>: the Hibernate JMX service is deployed "
+"using a JBoss service deployment descriptor in an EAR and/or SAR file, as it "
+"supports all the usual configuration options of a Hibernate "
+"<literal>SessionFactory</literal>. However, you still need to name all your "
+"mapping files in the deployment descriptor. If you use the optional HAR "
+"deployment, JBoss will automatically detect all mapping files in your HAR "
+"file."
+msgstr ""
+"<emphasis>HAR 배포</emphasis>: JBoss가 하이버네이트 <literal>SessionFactory</"
+"literal>의 거의 모든 구성 옵션들을 지원하므로, 하이버네이트 JMS 서비스는 "
+"JBoss 서비스 배포 디스크립터를 사용하여 EAR 그리고/또는 SAR 파일로서 배포된"
+"다. 하지만 당신은 여전히 배포 디스크립터 내에 모든 당신의 매핑 파일들을 명명"
+"할 필요가 있다. 만일 당신이 선택적인 HAR 배포를 사용할 경우, JBoss는 당신의 "
+"HAR 파일 내에 있는 모든 매핑 파일들을 자동적으로 검출할 것이다."
 
 #. Tag: para
-#: architecture.xml:280
 #, no-c-format
-msgid "Consult the JBoss AS user guide for more information about these options."
-msgstr "이들 옵션들에 대한 추가 정보는 JBoss 어플리케이션 서버 사용자 가이드를 참조하라."
+msgid ""
+"Consult the JBoss AS user guide for more information about these options."
+msgstr ""
+"이들 옵션들에 대한 추가 정보는 JBoss 어플리케이션 서버 사용자 가이드를 참조하"
+"라."
 
 #. Tag: para
-#: architecture.xml:284
-#, no-c-format
-msgid "Another feature available as a JMX service is runtime Hibernate statistics. See <xref linkend=\"configuration-optional-statistics\"/> for more information."
-msgstr "JMX 서비스로서 이용 가능한 또다른 특징은 런타임 하이버네이트 통계이다. 부가 정보는 <xref linkend=\"configuration-optional-statistics\"/>를 보라."
+#, fuzzy, no-c-format
+msgid ""
+"Another feature available as a JMX service is runtime Hibernate statistics. "
+"See <xref linkend=\"configuration-optional-statistics\" /> for more "
+"information."
+msgstr ""
+"JMX 서비스로서 이용 가능한 또다른 특징은 런타임 하이버네이트 통계이다. 부가 "
+"정보는 <xref linkend=\"configuration-optional-statistics\"/>를 보라."
 
 #. Tag: title
-#: architecture.xml:291
 #, no-c-format
 msgid "JCA Support"
 msgstr "JCA 지원"
 
 #. Tag: para
-#: architecture.xml:292
 #, no-c-format
-msgid "Hibernate can also be configured as a JCA connector. Please see the website for more information. Please note, however, that at this stage Hibernate JCA support is under development."
-msgstr "하이버네이트는 또한 JCA 커넥터로서 구성될 수도 있다. 부가 정보는 웹 사이트를 보길 바란다. 하지만 현 단게에서 하이버네이트 JCA 지원은 개발 중에 있음을 염두에 두길 바란다."
+msgid ""
+"Hibernate can also be configured as a JCA connector. Please see the website "
+"for more information. Please note, however, that at this stage Hibernate JCA "
+"support is under development."
+msgstr ""
+"하이버네이트는 또한 JCA 커넥터로서 구성될 수도 있다. 부가 정보는 웹 사이트를 "
+"보길 바란다. 하지만 현 단게에서 하이버네이트 JCA 지원은 개발 중에 있음을 염두"
+"에 두길 바란다."
 
 #. Tag: title
-#: architecture.xml:299
 #, no-c-format
 msgid "Contextual sessions"
 msgstr "컨텍스트의 세션들"
 
 #. Tag: para
-#: architecture.xml:300
 #, no-c-format
-msgid "Most applications using Hibernate need some form of \"contextual\" session, where a given session is in effect throughout the scope of a given context. However, across applications the definition of what constitutes a context is typically different; different contexts define different scopes to the notion of current. Applications using Hibernate prior to version 3.0 tended to utilize either home-grown <literal>ThreadLocal</literal>-based contextual sessions, helper classes such as <literal>HibernateUtil</literal>, or utilized third-party frameworks, such as Spring or Pico, which provided proxy/interception-based contextual sessions."
-msgstr "하이버네이트를 사용하는 대부분의 어플리케이션들은 \"컨텍스트상의(contextual)\" 세션에 대한 어떤 형식을 필요로 하며, 여기서 주어진 세션은 주어진 컨텍스트의 영역 내에서 효과가 있다. 하지만 어플리케이션들을 가로질러 어던 컨텍스트를 구성하는 것에 대한 정의는 일반적으로 다르다; 그리고 다른 컨텍스트들이 현재라고 하는 개념에 대해 다른 영역들을 정의한다. 버전 3.0 이전의 하이버네이트를 사용하는 어플리케이션들은 <literal>HibernateUtil</literal>과 같은 helper 클래스들인, 자가생산된 <literal>ThreadLocal</literal>-기반의 컨텍스트 세션들을 활용하려고 했거나, 프락시/인터셉션 기반의 컨텍스트 세션들을 제공해주었던, Spring이나 Pico와 같은 제 3의 프레임웍들을 활용했다."
+msgid ""
+"Most applications using Hibernate need some form of \"contextual\" session, "
+"where a given session is in effect throughout the scope of a given context. "
+"However, across applications the definition of what constitutes a context is "
+"typically different; different contexts define different scopes to the "
+"notion of current. Applications using Hibernate prior to version 3.0 tended "
+"to utilize either home-grown <literal>ThreadLocal</literal>-based contextual "
+"sessions, helper classes such as <literal>HibernateUtil</literal>, or "
+"utilized third-party frameworks, such as Spring or Pico, which provided "
+"proxy/interception-based contextual sessions."
+msgstr ""
+"하이버네이트를 사용하는 대부분의 어플리케이션들은 \"컨텍스트상의(contextual)"
+"\" 세션에 대한 어떤 형식을 필요로 하며, 여기서 주어진 세션은 주어진 컨텍스트"
+"의 영역 내에서 효과가 있다. 하지만 어플리케이션들을 가로질러 어던 컨텍스트를 "
+"구성하는 것에 대한 정의는 일반적으로 다르다; 그리고 다른 컨텍스트들이 현재라"
+"고 하는 개념에 대해 다른 영역들을 정의한다. 버전 3.0 이전의 하이버네이트를 사"
+"용하는 어플리케이션들은 <literal>HibernateUtil</literal>과 같은 helper 클래스"
+"들인, 자가생산된 <literal>ThreadLocal</literal>-기반의 컨텍스트 세션들을 활용"
+"하려고 했거나, 프락시/인터셉션 기반의 컨텍스트 세션들을 제공해주었던, Spring"
+"이나 Pico와 같은 제 3의 프레임웍들을 활용했다."
 
 #. Tag: para
-#: architecture.xml:309
 #, no-c-format
-msgid "Starting with version 3.0.1, Hibernate added the <literal>SessionFactory.getCurrentSession()</literal> method. Initially, this assumed usage of <literal>JTA</literal> transactions, where the <literal>JTA</literal> transaction defined both the scope and context of a current session. Given the maturity of the numerous stand-alone <literal>JTA TransactionManager</literal> implementations, most, if not all, applications should be using <literal>JTA</literal> transaction management, whether or not they are deployed into a <literal>J2EE</literal> container. Based on that, the <literal>JTA</literal>-based contextual sessions are all you need to use."
-msgstr "버전 3.0.1에서부터, 하이버네이트는 <literal>SessionFactory.getCurrentSession()</literal> 메소드를 추가했다. 초기에 이것은 <literal>JTA</literal> 트랜잭션 사용을 전제했으며, <literal>JTA</literal> 트랜잭션은 현 세션의 영역 및 컨텍스트 둘 다 정의했다. 많은 스탠드얼론 <literal>JTA TransactionManager</literal> 구현들이 성숙되면, 전부는 아니겠지만, 대부분의 어플리케이션들이 <literal>J2EE</literal> 컨테이너 내로 배포되든 그렇지 않든 간에 대부분의 어플리케이션들이 <literal>JTA</literal> 트랜잭션 관리를 사용하게 될 것이다. 그것에 기초하면, <literal>JTA</literal>에 기반한 컨텍스트 세션들은 당신이 사용할 필요가 있는 모든 것이다."
+msgid ""
+"Starting with version 3.0.1, Hibernate added the <literal>SessionFactory."
+"getCurrentSession()</literal> method. Initially, this assumed usage of "
+"<literal>JTA</literal> transactions, where the <literal>JTA</literal> "
+"transaction defined both the scope and context of a current session. Given "
+"the maturity of the numerous stand-alone <literal>JTA TransactionManager</"
+"literal> implementations, most, if not all, applications should be using "
+"<literal>JTA</literal> transaction management, whether or not they are "
+"deployed into a <literal>J2EE</literal> container. Based on that, the "
+"<literal>JTA</literal>-based contextual sessions are all you need to use."
+msgstr ""
+"버전 3.0.1에서부터, 하이버네이트는 <literal>SessionFactory.getCurrentSession"
+"()</literal> 메소드를 추가했다. 초기에 이것은 <literal>JTA</literal> 트랜잭"
+"션 사용을 전제했으며, <literal>JTA</literal> 트랜잭션은 현 세션의 영역 및 컨"
+"텍스트 둘 다 정의했다. 많은 스탠드얼론 <literal>JTA TransactionManager</"
+"literal> 구현들이 성숙되면, 전부는 아니겠지만, 대부분의 어플리케이션들이 "
+"<literal>J2EE</literal> 컨테이너 내로 배포되든 그렇지 않든 간에 대부분의 어플"
+"리케이션들이 <literal>JTA</literal> 트랜잭션 관리를 사용하게 될 것이다. 그것"
+"에 기초하면, <literal>JTA</literal>에 기반한 컨텍스트 세션들은 당신이 사용할 "
+"필요가 있는 모든 것이다."
 
 #. Tag: para
-#: architecture.xml:319
 #, no-c-format
-msgid "However, as of version 3.1, the processing behind <literal>SessionFactory.getCurrentSession()</literal> is now pluggable. To that end, a new extension interface, <literal>org.hibernate.context.CurrentSessionContext</literal>, and a new configuration parameter, <literal>hibernate.current_session_context_class</literal>, have been added to allow pluggability of the scope and context of defining current sessions."
-msgstr "하지만 현재 버전 3.1에서  <literal>SessionFactory.getCurrentSession()</literal> 이면의 처리과정이 이제 플러그 가능하다. 그것으로 인해, 하나의 새로운 확장 인터페이스, <literal>org.hibernate.context.CurrentSessionContext</literal>)와 하나의 새로운 구성 파라미터, <literal>hibernate.current_session_context_class</literal>가 현재 세션들을 정의하는 영역 및 컨텍스트의 플러그 가능성을 허용하도록 추가되었다."
+msgid ""
+"However, as of version 3.1, the processing behind <literal>SessionFactory."
+"getCurrentSession()</literal> is now pluggable. To that end, a new extension "
+"interface, <literal>org.hibernate.context.CurrentSessionContext</literal>, "
+"and a new configuration parameter, <literal>hibernate."
+"current_session_context_class</literal>, have been added to allow "
+"pluggability of the scope and context of defining current sessions."
+msgstr ""
+"하지만 현재 버전 3.1에서  <literal>SessionFactory.getCurrentSession()</"
+"literal> 이면의 처리과정이 이제 플러그 가능하다. 그것으로 인해, 하나의 새로"
+"운 확장 인터페이스, <literal>org.hibernate.context.CurrentSessionContext</"
+"literal>)와 하나의 새로운 구성 파라미터, <literal>hibernate."
+"current_session_context_class</literal>가 현재 세션들을 정의하는 영역 및 컨텍"
+"스트의 플러그 가능성을 허용하도록 추가되었다."
 
 #. Tag: para
-#: architecture.xml:326
 #, no-c-format
-msgid "See the Javadocs for the <literal>org.hibernate.context.CurrentSessionContext</literal> interface for a detailed discussion of its contract. It defines a single method, <literal>currentSession()</literal>, by which the implementation is responsible for tracking the current contextual session. Out-of-the-box, Hibernate comes with three implementations of this interface:"
-msgstr "그것의 계약에 대한 상세한 논의는 <literal>org.hibernate.context.CurrentSessionContext</literal> 인터페이스에 관한 javadocs를 보라. 그것은 하나의 메소드, <literal>currentSession()</literal>를 정의하며, 그 구현은 현재의 컨텍스트 상의 세션을 추적할 책임이 있다. 비공식적으로, Hibernate는 이 인터페이스에 대한 세 개의 구현들을 부수적으로 포함하고 있다."
+msgid ""
+"See the Javadocs for the <literal>org.hibernate.context."
+"CurrentSessionContext</literal> interface for a detailed discussion of its "
+"contract. It defines a single method, <literal>currentSession()</literal>, "
+"by which the implementation is responsible for tracking the current "
+"contextual session. Out-of-the-box, Hibernate comes with three "
+"implementations of this interface:"
+msgstr ""
+"그것의 계약에 대한 상세한 논의는 <literal>org.hibernate.context."
+"CurrentSessionContext</literal> 인터페이스에 관한 javadocs를 보라. 그것은 하"
+"나의 메소드, <literal>currentSession()</literal>를 정의하며, 그 구현은 현재"
+"의 컨텍스트 상의 세션을 추적할 책임이 있다. 비공식적으로, Hibernate는 이 인터"
+"페이스에 대한 세 개의 구현들을 부수적으로 포함하고 있다."
 
 #. Tag: para
-#: architecture.xml:336
 #, no-c-format
-msgid "<literal>org.hibernate.context.JTASessionContext</literal>: current sessions are tracked and scoped by a <literal>JTA</literal> transaction. The processing here is exactly the same as in the older JTA-only approach. See the Javadocs for details."
-msgstr "<literal>org.hibernate.context.JTASessionContext</literal>: 현재 세션들은 <literal>JTA</literal> 트랜잭션에 의해 추적되고 영역화 된다. 여기서 처리는 예전의 JTA-전용 접근법과 정확하게 같다. 상세한 것은 Javadocs를 보라."
+msgid ""
+"<literal>org.hibernate.context.JTASessionContext</literal>: current sessions "
+"are tracked and scoped by a <literal>JTA</literal> transaction. The "
+"processing here is exactly the same as in the older JTA-only approach. See "
+"the Javadocs for details."
+msgstr ""
+"<literal>org.hibernate.context.JTASessionContext</literal>: 현재 세션들은 "
+"<literal>JTA</literal> 트랜잭션에 의해 추적되고 영역화 된다. 여기서 처리는 예"
+"전의 JTA-전용 접근법과 정확하게 같다. 상세한 것은 Javadocs를 보라."
 
 #. Tag: para
-#: architecture.xml:344
 #, no-c-format
-msgid "<literal>org.hibernate.context.ThreadLocalSessionContext</literal>:current sessions are tracked by thread of execution. See the Javadocs for details."
-msgstr "<literal>org.hibernate.context.ThreadLocalSessionContext</literal> :현재 세션들은 실행 쓰레드에 의해 추적된다. 상세한 것은 다시 javadocs를 보라."
+msgid ""
+"<literal>org.hibernate.context.ThreadLocalSessionContext</literal>:current "
+"sessions are tracked by thread of execution. See the Javadocs for details."
+msgstr ""
+"<literal>org.hibernate.context.ThreadLocalSessionContext</literal> :현재 세션"
+"들은 실행 쓰레드에 의해 추적된다. 상세한 것은 다시 javadocs를 보라."
 
 #. Tag: para
-#: architecture.xml:350
 #, no-c-format
-msgid "<literal>org.hibernate.context.ManagedSessionContext</literal>: current sessions are tracked by thread of execution. However, you are responsible to bind and unbind a <literal>Session</literal> instance with static methods on this class: it does not open, flush, or close a <literal>Session</literal>."
-msgstr "<literal>org.hibernate.context.ManagedSessionContext</literal> : 현재 세션들은 실행 쓰레드에 의해 추적된다. 하지만 <literal>Session</literal> 인스턴스를 이 클래스 상에 있는 static 메소드들에 바인딩시키고 언바인딩 시킬 책임이 당신에게 있다: 그것은 <literal>Session</literal>을 열지도 flush 시키거나 닫지 않는다."
+msgid ""
+"<literal>org.hibernate.context.ManagedSessionContext</literal>: current "
+"sessions are tracked by thread of execution. However, you are responsible to "
+"bind and unbind a <literal>Session</literal> instance with static methods on "
+"this class: it does not open, flush, or close a <literal>Session</literal>."
+msgstr ""
+"<literal>org.hibernate.context.ManagedSessionContext</literal> : 현재 세션들"
+"은 실행 쓰레드에 의해 추적된다. 하지만 <literal>Session</literal> 인스턴스를 "
+"이 클래스 상에 있는 static 메소드들에 바인딩시키고 언바인딩 시킬 책임이 당신"
+"에게 있다: 그것은 <literal>Session</literal>을 열지도 flush 시키거나 닫지 않"
+"는다."
 
 #. Tag: para
-#: architecture.xml:359
-#, no-c-format
-msgid "The first two implementations provide a \"one session - one database transaction\" programming model. This is also also known and used as <emphasis>session-per-request</emphasis>. The beginning and end of a Hibernate session is defined by the duration of a database transaction. If you use programmatic transaction demarcation in plain JSE without JTA, you are advised to use the Hibernate <literal>Transaction</literal> API to hide the underlying transaction system from your code. If you use JTA, you can utilize the JTA interfaces to demarcate transactions. If you execute in an EJB container that supports CMT, transaction boundaries are defined declaratively and you do not need any transaction or session demarcation operations in your code. Refer to <xref linkend=\"transactions\"/> for more information and code examples."
-msgstr "첫 두 개의 구현들은 \"한 개의 세션 - 한 개의 데이터베이스 트랜잭션\" 프로그래밍 모형을 제공한다. 이것은 또한  <emphasis>요청 당 세션</emphasis>으로 알려져 있고 사용된다. 하이버네이트 세션의 시작과 끝은 데이터베이스 트랜잭션의 존속 기간에 의해 정의된다. 만일 당신이 JTA없이 평범한 JSE에서 프로그램 상의 트랜잭션 격리를 사용할 경우, 당신에게 당신의 코드에서 기본 트랜잭션 시스템을 은폐시키는데 하이버네이트 <literal>Transaction</literal> API를 사용하도록 권장된다.만일 당신이 CMT를 지원하는 EJB 컨테이너 내에서 실행할 경우, 트랜잭션 경계들은 선언적으로 정의되며 당신이 당신의 코드에 임의의 트랜잭션 또는 세션 경계설정 오퍼레이션을 필요로 하지 않는다. 만일 당신이 CMT를 지원하는 하나의 EJB 컨테이너에서 실행할 경우!
 , 트랜잭션 경계들이 선언적으로 정의되고 당신은 당신의 코드 내에서 어떠한 트랜잭션이나 세션 경계구분 오퍼레이션들을 필요로 하지 않는다. 부가 정보와 코드 예제들은 <xref linkend=\"transactions\"/>를 참조하라."
+#, fuzzy, no-c-format
+msgid ""
+"The first two implementations provide a \"one session - one database "
+"transaction\" programming model. This is also also known and used as "
+"<emphasis>session-per-request</emphasis>. The beginning and end of a "
+"Hibernate session is defined by the duration of a database transaction. If "
+"you use programmatic transaction demarcation in plain JSE without JTA, you "
+"are advised to use the Hibernate <literal>Transaction</literal> API to hide "
+"the underlying transaction system from your code. If you use JTA, you can "
+"utilize the JTA interfaces to demarcate transactions. If you execute in an "
+"EJB container that supports CMT, transaction boundaries are defined "
+"declaratively and you do not need any transaction or session demarcation "
+"operations in your code. Refer to <xref linkend=\"transactions\" /> for more "
+"information and code examples."
+msgstr ""
+"첫 두 개의 구현들은 \"한 개의 세션 - 한 개의 데이터베이스 트랜잭션\" 프로그래"
+"밍 모형을 제공한다. 이것은 또한  <emphasis>요청 당 세션</emphasis>으로 알려"
+"져 있고 사용된다. 하이버네이트 세션의 시작과 끝은 데이터베이스 트랜잭션의 존"
+"속 기간에 의해 정의된다. 만일 당신이 JTA없이 평범한 JSE에서 프로그램 상의 트"
+"랜잭션 격리를 사용할 경우, 당신에게 당신의 코드에서 기본 트랜잭션 시스템을 은"
+"폐시키는데 하이버네이트 <literal>Transaction</literal> API를 사용하도록 권장"
+"된다.만일 당신이 CMT를 지원하는 EJB 컨테이너 내에서 실행할 경우, 트랜잭션 경"
+"계들은 선언적으로 정의되며 당신이 당신의 코드에 임의의 트랜잭션 또는 세션 경"
+"계설정 오퍼레이션을 필요로 하지 않는다. 만일 당신이 CMT를 지원하는 하나의 "
+"EJB 컨테이너에서 실행할 경우, 트랜잭션 경계들이 선언적으로 정의되고 당신은 당"
+"신의 코드 내에서 어떠한 트랜잭션이나 세션 경계구분 오퍼레이션들을 필요로 하"
+"지 않는다. 부가 정보와 코드 예제들은 <xref linkend=\"transactions\"/>를 참조"
+"하라."
 
 #. Tag: para
-#: architecture.xml:371
 #, no-c-format
-msgid "The <literal>hibernate.current_session_context_class</literal> configuration parameter defines which <literal>org.hibernate.context.CurrentSessionContext</literal> implementation should be used. For backwards compatibility, if this configuration parameter is not set but a <literal>org.hibernate.transaction.TransactionManagerLookup</literal> is configured, Hibernate will use the <literal>org.hibernate.context.JTASessionContext</literal>. Typically, the value of this parameter would just name the implementation class to use. For the three out-of-the-box implementations, however, there are three corresponding short names: \"jta\", \"thread\", and \"managed\"."
-msgstr "<literal>hibernate.current_session_context_class</literal> 구성 파라미터는 어느 <literal>org.hibernate.context.CurrentSessionContext</literal> 구현이 사용될 것인지를 정의한다. 역호환을 위해. 만일 이 구성 파라미터가 설정되지 않지만 하나의 <literal>org.hibernate.transaction.TransactionManagerLookup</literal>이 구성되는 경우에, 하이버네이트는 <literal>org.hibernate.context.JTASessionContext</literal>를 사용할 것이다. 일반적으로, 이 파라미터의 값은 단지 사용할 구현 클래스를 명명할 것이다; 하지만 세 개의 비공식적인 구현들에 대해, 세 개의 대응하는 짧은 이름들 \"jta\"와 \"thread\", 그리고 \"managed\"가 존재한다."
-
+msgid ""
+"The <literal>hibernate.current_session_context_class</literal> configuration "
+"parameter defines which <literal>org.hibernate.context."
+"CurrentSessionContext</literal> implementation should be used. For backwards "
+"compatibility, if this configuration parameter is not set but a <literal>org."
+"hibernate.transaction.TransactionManagerLookup</literal> is configured, "
+"Hibernate will use the <literal>org.hibernate.context.JTASessionContext</"
+"literal>. Typically, the value of this parameter would just name the "
+"implementation class to use. For the three out-of-the-box implementations, "
+"however, there are three corresponding short names: \"jta\", \"thread\", and "
+"\"managed\"."
+msgstr ""
+"<literal>hibernate.current_session_context_class</literal> 구성 파라미터는 어"
+"느 <literal>org.hibernate.context.CurrentSessionContext</literal> 구현이 사용"
+"될 것인지를 정의한다. 역호환을 위해. 만일 이 구성 파라미터가 설정되지 않지만 "
+"하나의 <literal>org.hibernate.transaction.TransactionManagerLookup</literal>"
+"이 구성되는 경우에, 하이버네이트는 <literal>org.hibernate.context."
+"JTASessionContext</literal>를 사용할 것이다. 일반적으로, 이 파라미터의 값은 "
+"단지 사용할 구현 클래스를 명명할 것이다; 하지만 세 개의 비공식적인 구현들에 "
+"대해, 세 개의 대응하는 짧은 이름들 \"jta\"와 \"thread\", 그리고 \"managed"
+"\"가 존재한다."

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/association_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/association_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/association_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: 2010-01-12 20:59+0900\n"
 "Last-Translator: Jongdae Kim <jdkim528 at korea.com>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,1085 +11,1108 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: association_mapping.xml:30
 #, no-c-format
 msgid "Association Mappings"
 msgstr "연관 매핑들"
 
 #. Tag: title
-#: association_mapping.xml:33
 #, no-c-format
 msgid "Introduction"
 msgstr "개요"
 
 #. Tag: para
-#: association_mapping.xml:35
 #, 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</literal> and <literal>Address</literal> in all the examples."
-msgstr "연관 매핑들은 종종 정확하게 구현하는 것이 가장 어려운 것이다. 이 절에서 우리는 단방향 매핑들에서 시작하여, 양방향 매핑의 경우까지 하나씩 몇몇 정규적인 경우들을 논의할 것이다. 우리는 모든 예제들에서 <literal>Person</literal>과 <literal>Address</literal>를 사용할 것이다."
+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</literal> and <literal>Address</literal> in all the "
+"examples."
+msgstr ""
+"연관 매핑들은 종종 정확하게 구현하는 것이 가장 어려운 것이다. 이 절에서 우리"
+"는 단방향 매핑들에서 시작하여, 양방향 매핑의 경우까지 하나씩 몇몇 정규적인 경"
+"우들을 논의할 것이다. 우리는 모든 예제들에서 <literal>Person</literal>과 "
+"<literal>Address</literal>를 사용할 것이다."
 
 #. Tag: para
-#: association_mapping.xml:43
 #, no-c-format
-msgid "Associations will be classified by multiplicity and whether or not they map to an intervening join table."
-msgstr "연관들은 다가성 그리고 중재하는 join 테이블로 매핑시킬 것인지 여부에 따라 분류될 것이다."
+msgid ""
+"Associations will be classified by multiplicity and whether or not they map "
+"to an intervening join table."
+msgstr ""
+"연관들은 다가성 그리고 중재하는 join 테이블로 매핑시킬 것인지 여부에 따라 분"
+"류될 것이다."
 
 #. Tag: para
-#: association_mapping.xml:48
 #, 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 "널값이 허용되는 외래 키들은 전통적인 데이터 모델링에서 좋은 사례로 간주되지 않으므로, 우리의 예제들은 널 값이 허용되는 외래 키들을 사용하지 않는다. 이것은 하이버네이트의 사양이 아니며, 당신이 널 허용 컨스트레인트들을 드롭시킬 경우에 매핑들이 동작할 것이다."
+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 ""
+"널값이 허용되는 외래 키들은 전통적인 데이터 모델링에서 좋은 사례로 간주되지 "
+"않으므로, 우리의 예제들은 널 값이 허용되는 외래 키들을 사용하지 않는다. 이것"
+"은 하이버네이트의 사양이 아니며, 당신이 널 허용 컨스트레인트들을 드롭시킬 경"
+"우에 매핑들이 동작할 것이다."
 
 #. Tag: title
-#: association_mapping.xml:58
 #, no-c-format
 msgid "Unidirectional associations"
 msgstr "단방향 연관들"
 
 #. Tag: title
-#: association_mapping.xml:61
-#: association_mapping.xml:132
 #, no-c-format
 msgid "Many-to-one"
 msgstr "다-대-일"
 
 #. Tag: para
-#: association_mapping.xml:63
 #, no-c-format
-msgid "A <emphasis>unidirectional many-to-one association</emphasis> is the most common kind of unidirectional association."
-msgstr "<emphasis>단방향 many-to-one 연관</emphasis>은 가장 공통적인 종류의 단방향 연관이다."
-
-#. Tag: programlisting
-#: association_mapping.xml:68
-#, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
+"A <emphasis>unidirectional many-to-one association</emphasis> is the most "
+"common kind of unidirectional association."
 msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
+"<emphasis>단방향 many-to-one 연관</emphasis>은 가장 공통적인 종류의 단방향 연"
+"관이다."
 
-#. Tag: programlisting
-#: association_mapping.xml:69
-#: association_mapping.xml:185
-#, no-c-format
-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"
-"        ]]>"
-
 #. Tag: title
-#: association_mapping.xml:74
-#: association_mapping.xml:145
-#: association_mapping.xml:210
 #, no-c-format
 msgid "One-to-one"
 msgstr "일-대-일"
 
 #. Tag: para
-#: association_mapping.xml:76
 #, no-c-format
-msgid "A <emphasis>unidirectional one-to-one association on a foreign key</emphasis> is almost identical. The only difference is the column unique constraint."
-msgstr "<emphasis>foreign 키에 대한 단방향 one-to-one 연관은 대개 아주 동일하다.</emphasis> 유일한 차이점은 컬럼 유일(unique) 컨스트레인트이다."
-
-#. Tag: programlisting
-#: association_mapping.xml:81
-#, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
+"A <emphasis>unidirectional one-to-one association on a foreign key</"
+"emphasis> is almost identical. The only difference is the column unique "
+"constraint."
 msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
+"<emphasis>foreign 키에 대한 단방향 one-to-one 연관은 대개 아주 동일하다.</"
+"emphasis> 유일한 차이점은 컬럼 유일(unique) 컨스트레인트이다."
 
-#. Tag: programlisting
-#: association_mapping.xml:82
-#: association_mapping.xml:218
-#, no-c-format
-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"
-"        ]]>"
-
 #. Tag: para
-#: association_mapping.xml:84
 #, no-c-format
-msgid "A <emphasis>unidirectional one-to-one association on a primary key</emphasis> usually uses a special id generator In this example, however, we have reversed the direction of the association:"
-msgstr "<emphasis>프라이머리 키에 대한 단방향 일-대-일 연관</emphasis>은 대개 특별한 id 생성자를 사용한다. 하지만 이 예제에서 우리는 연관의 방향을 역전시켰다:"
-
-#. Tag: programlisting
-#: association_mapping.xml:90
-#, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" constrained=\"true\"/>\n"
-"</class>]]>"
+"A <emphasis>unidirectional one-to-one association on a primary key</"
+"emphasis> usually uses a special id generator In this example, however, we "
+"have reversed the direction of the association:"
 msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" constrained=\"true\"/>\n"
-"</class>]]>"
+"<emphasis>프라이머리 키에 대한 단방향 일-대-일 연관</emphasis>은 대개 특별한 "
+"id 생성자를 사용한다. 하지만 이 예제에서 우리는 연관의 방향을 역전시켰다:"
 
-#. Tag: programlisting
-#: association_mapping.xml:91
-#: association_mapping.xml:226
-#, no-c-format
-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"
-"        ]]>"
-
 #. Tag: title
-#: association_mapping.xml:96
-#: association_mapping.xml:118
 #, no-c-format
 msgid "One-to-many"
 msgstr "일-대-다 "
 
 #. Tag: para
-#: association_mapping.xml:98
 #, no-c-format
-msgid "A <emphasis>unidirectional one-to-many association on a foreign key</emphasis> is an unusual case, and is not recommended."
-msgstr "<emphasis>외래 키에 대한 단방향 일-대-다 연관</emphasis>은 색다른 경우이며, 권장되지 않는다."
-
-#. Tag: programlisting
-#: association_mapping.xml:103
-#, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\">\n"
-"        <key column=\"personId\" \n"
-"            not-null=\"true\"/>\n"
-"        <one-to-many class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
+"A <emphasis>unidirectional one-to-many association on a foreign key</"
+"emphasis> is an unusual case, and is not recommended."
 msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\">\n"
-"        <key column=\"personId\" \n"
-"            not-null=\"true\"/>\n"
-"        <one-to-many class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
+"<emphasis>외래 키에 대한 단방향 일-대-다 연관</emphasis>은 색다른 경우이며, "
+"권장되지 않는다."
 
-#. Tag: programlisting
-#: association_mapping.xml:104
-#, no-c-format
-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"
-"        ]]>"
-
 #. Tag: para
-#: association_mapping.xml:106
 #, no-c-format
 msgid "You should instead use a join table for this kind of association."
-msgstr "대신에 당신은 이런 종류의 연관에 대해 하나의 join 테이블을 사용해야 한다."
+msgstr ""
+"대신에 당신은 이런 종류의 연관에 대해 하나의 join 테이블을 사용해야 한다."
 
 #. Tag: title
-#: association_mapping.xml:115
 #, no-c-format
 msgid "Unidirectional associations with join tables"
 msgstr "join 테이블들에 대한 단방향 연관들"
 
 #. Tag: para
-#: association_mapping.xml:120
 #, no-c-format
-msgid "A <emphasis>unidirectional one-to-many association on a join table</emphasis> is the preferred option. Specifying <literal>unique=\"true\"</literal>, changes the multiplicity from many-to-many to one-to-many."
-msgstr "<emphasis>join 테이블에 대한 단방향 일-대-다 연관</emphasis>은 선호되는 옵션이다. <literal>unique=\"true\"</literal>를 지정하여, 다-대-다에서 일-대-다로 다중값을 변경시켜라."
-
-#. Tag: programlisting
-#: association_mapping.xml:126
-#, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
+"A <emphasis>unidirectional one-to-many association on a join table</"
+"emphasis> is the preferred option. Specifying <literal>unique=\"true\"</"
+"literal>, changes the multiplicity from many-to-many to one-to-many."
 msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
+"<emphasis>join 테이블에 대한 단방향 일-대-다 연관</emphasis>은 선호되는 옵션"
+"이다. <literal>unique=\"true\"</literal>를 지정하여, 다-대-다에서 일-대-다로 "
+"다중값을 변경시켜라."
 
-#. Tag: programlisting
-#: association_mapping.xml:127
-#, no-c-format
-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"
-"        ]]>"
-
 #. Tag: para
-#: association_mapping.xml:134
 #, no-c-format
-msgid "A <emphasis>unidirectional many-to-one association on a join table</emphasis> is common when the association is optional. For example:"
-msgstr "<emphasis>join 테이블에 대한 단방향 다-대-일 연관</emphasis>은 그 연관이 선택적일 때 공통적이다. 예를 들면:"
-
-#. Tag: programlisting
-#: association_mapping.xml:139
-#, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
+"A <emphasis>unidirectional many-to-one association on a join table</"
+"emphasis> is common when the association is optional. For example:"
 msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
+"<emphasis>join 테이블에 대한 단방향 다-대-일 연관</emphasis>은 그 연관이 선택"
+"적일 때 공통적이다. 예를 들면:"
 
-#. Tag: programlisting
-#: association_mapping.xml:140
-#, no-c-format
-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"
-"        ]]>"
-
 #. Tag: para
-#: association_mapping.xml:147
 #, no-c-format
-msgid "A <emphasis>unidirectional one-to-one association on a join table</emphasis> is possible, but extremely unusual."
-msgstr "<emphasis>join 테이블에 대한 단방향 일-대-일 연관</emphasis>은 가능하지만, 극히 통상적이지 않다."
-
-#. Tag: programlisting
-#: association_mapping.xml:152
-#, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
+"A <emphasis>unidirectional one-to-one association on a join table</emphasis> "
+"is possible, but extremely unusual."
 msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
+"<emphasis>join 테이블에 대한 단방향 일-대-일 연관</emphasis>은 가능하지만, 극"
+"히 통상적이지 않다."
 
-#. Tag: programlisting
-#: association_mapping.xml:153
-#: association_mapping.xml:258
-#, no-c-format
-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"
-"        ]]>"
-
 #. Tag: title
-#: association_mapping.xml:158
-#: association_mapping.xml:263
 #, no-c-format
 msgid "Many-to-many"
 msgstr "다-대-다"
 
 #. Tag: para
-#: association_mapping.xml:160
 #, no-c-format
-msgid "Finally, here is an example of a <emphasis>unidirectional many-to-many association</emphasis>."
-msgstr "마지막으로, 다음은 <emphasis>단방향 다-대-다 연관</emphasis>에 대한 예제이다."
-
-#. Tag: programlisting
-#: association_mapping.xml:164
-#, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
+"Finally, here is an example of a <emphasis>unidirectional many-to-many "
+"association</emphasis>."
 msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
+"마지막으로, 다음은 <emphasis>단방향 다-대-다 연관</emphasis>에 대한 예제이다."
 
-#. Tag: programlisting
-#: association_mapping.xml:165
-#: association_mapping.xml:271
-#, no-c-format
-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"
-"        ]]>"
-
 #. Tag: title
-#: association_mapping.xml:172
 #, no-c-format
 msgid "Bidirectional associations"
 msgstr "양방향 연관들"
 
 #. Tag: title
-#: association_mapping.xml:175
-#: association_mapping.xml:236
 #, no-c-format
 msgid "one-to-many / many-to-one"
 msgstr "일-대-다 / 다-대-일"
 
 #. Tag: para
-#: association_mapping.xml:177
 #, no-c-format
-msgid "A <emphasis>bidirectional many-to-one association</emphasis> is the most common kind of association. The following example illustrates the standard parent/child relationship."
-msgstr "<emphasis>양방향 다-대-일 연관</emphasis>은 가장 공통된 종류의 연관이다. 다음 예제는 표준 부모/자식 관계를 설명한다."
-
-#. Tag: programlisting
-#: association_mapping.xml:183
-#, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <one-to-many class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
+"A <emphasis>bidirectional many-to-one association</emphasis> is the most "
+"common kind of association. The following example illustrates the standard "
+"parent/child relationship."
 msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <one-to-many class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
+"<emphasis>양방향 다-대-일 연관</emphasis>은 가장 공통된 종류의 연관이다. 다"
+"음 예제는 표준 부모/자식 관계를 설명한다."
 
 #. Tag: para
-#: association_mapping.xml:187
 #, no-c-format
-msgid "If you use a <literal>List</literal>, or other indexed collection, set the <literal>key</literal> column of the foreign key to <literal>not null</literal>. Hibernate will manage the association from the collections side to maintain the index of each element, making the other side virtually inverse by setting <literal>update=\"false\"</literal> and <literal>insert=\"false\"</literal>:"
-msgstr "만일 당신이 <literal>List</literal>, 또는 다른 인덱싱 된 콜렉션을 사용할 경우, 외래 키의 <literal>key</literal> 컬럼을 <literal>not null</literal>로 설정하라. 하이버네이트는 각각의 요소의 인덱스를 관리하기 위해 <literal>update=\"false\"</literal>와 <literal>insert=\"false\"</literal>를 설정하여 다른 측을 가상적으로 역행시킴으로서 콜렉션들 측에서 그 연관을 관리할 것이다:"
-
-#. Tag: programlisting
-#: association_mapping.xml:195
-#, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"   <id name=\"id\"/>\n"
-"   ...\n"
-"   <many-to-one name=\"address\"\n"
-"      column=\"addressId\"\n"
-"      not-null=\"true\"\n"
-"      insert=\"false\"\n"
-"      update=\"false\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"   <id name=\"id\"/>\n"
-"   ...\n"
-"   <list name=\"people\">\n"
-"      <key column=\"addressId\" not-null=\"true\"/>\n"
-"      <list-index column=\"peopleIdx\"/>\n"
-"      <one-to-many class=\"Person\"/>\n"
-"   </list>\n"
-"</class>]]>"
+"If you use a <literal>List</literal>, or other indexed collection, set the "
+"<literal>key</literal> column of the foreign key to <literal>not null</"
+"literal>. Hibernate will manage the association from the collections side to "
+"maintain the index of each element, making the other side virtually inverse "
+"by setting <literal>update=\"false\"</literal> and <literal>insert=\"false"
+"\"</literal>:"
 msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"   <id name=\"id\"/>\n"
-"   ...\n"
-"   <many-to-one name=\"address\"\n"
-"      column=\"addressId\"\n"
-"      not-null=\"true\"\n"
-"      insert=\"false\"\n"
-"      update=\"false\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"   <id name=\"id\"/>\n"
-"   ...\n"
-"   <list name=\"people\">\n"
-"      <key column=\"addressId\" not-null=\"true\"/>\n"
-"      <list-index column=\"peopleIdx\"/>\n"
-"      <one-to-many class=\"Person\"/>\n"
-"   </list>\n"
-"</class>]]>"
+"만일 당신이 <literal>List</literal>, 또는 다른 인덱싱 된 콜렉션을 사용할 경"
+"우, 외래 키의 <literal>key</literal> 컬럼을 <literal>not null</literal>로 설"
+"정하라. 하이버네이트는 각각의 요소의 인덱스를 관리하기 위해 <literal>update="
+"\"false\"</literal>와 <literal>insert=\"false\"</literal>를 설정하여 다른 측"
+"을 가상적으로 역행시킴으로서 콜렉션들 측에서 그 연관을 관리할 것이다:"
 
 #. Tag: para
-#: association_mapping.xml:197
 #, no-c-format
-msgid "If the underlying foreign key column is <literal>NOT NULL</literal>, it is important that you define <literal>not-null=\"true\"</literal> on the <literal>&lt;key&gt;</literal> element of the collection mapping. Do not only declare <literal>not-null=\"true\"</literal> on a possible nested <literal>&lt;column&gt;</literal> element, but on the <literal>&lt;key&gt;</literal> element."
-msgstr "만일 기본 외래 키 컬럼이 <literal>NOT NULL</literal>일 경우, 당신이 콜렉션 매핑의 <literal>&lt;key&gt;</literal>에 <literal>not-null=\"true\"</literal>를 정의하는 것이 중요하다. <literal>not-null=\"true\"</literal>를  가능한 내포된 <literal>&lt;column&gt;</literal> 요소 뿐만 아니라, <literal>&lt;key&gt;</literal> 요소 상에도 선언하라."
+msgid ""
+"If the underlying foreign key column is <literal>NOT NULL</literal>, it is "
+"important that you define <literal>not-null=\"true\"</literal> on the "
+"<literal>&lt;key&gt;</literal> element of the collection mapping. Do not "
+"only declare <literal>not-null=\"true\"</literal> on a possible nested "
+"<literal>&lt;column&gt;</literal> element, but on the <literal>&lt;key&gt;</"
+"literal> element."
+msgstr ""
+"만일 기본 외래 키 컬럼이 <literal>NOT NULL</literal>일 경우, 당신이 콜렉션 매"
+"핑의 <literal>&lt;key&gt;</literal>에 <literal>not-null=\"true\"</literal>를 "
+"정의하는 것이 중요하다. <literal>not-null=\"true\"</literal>를  가능한 내포"
+"된 <literal>&lt;column&gt;</literal> 요소 뿐만 아니라, <literal>&lt;key&gt;</"
+"literal> 요소 상에도 선언하라."
 
 #. Tag: para
-#: association_mapping.xml:212
 #, no-c-format
-msgid "A <emphasis>bidirectional one-to-one association on a foreign key</emphasis> is common:"
+msgid ""
+"A <emphasis>bidirectional one-to-one association on a foreign key</emphasis> "
+"is common:"
 msgstr "<emphasis>외래 키에 대한 양방향일-대-일 연관</emphasis>은 공통적이다:"
 
-#. Tag: programlisting
-#: association_mapping.xml:217
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"   <one-to-one name=\"person\" \n"
-"        property-ref=\"address\"/>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"   <one-to-one name=\"person\" \n"
-"        property-ref=\"address\"/>\n"
-"</class>]]>"
-
 #. Tag: para
-#: association_mapping.xml:220
 #, no-c-format
-msgid "A <emphasis>bidirectional one-to-one association on a primary key</emphasis> uses the special id generator:"
-msgstr "<emphasis>프라이머리 키에 대한 양방향 일-대-일 연관</emphasis>은 특별한 id 생성자를 사용한다:"
-
-#. Tag: programlisting
-#: association_mapping.xml:225
-#, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <one-to-one name=\"address\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" \n"
-"        constrained=\"true\"/>\n"
-"</class>]]>"
+"A <emphasis>bidirectional one-to-one association on a primary key</emphasis> "
+"uses the special id generator:"
 msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <one-to-one name=\"address\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" \n"
-"        constrained=\"true\"/>\n"
-"</class>]]>"
+"<emphasis>프라이머리 키에 대한 양방향 일-대-일 연관</emphasis>은 특별한 id 생"
+"성자를 사용한다:"
 
 #. Tag: title
-#: association_mapping.xml:233
 #, no-c-format
 msgid "Bidirectional associations with join tables"
 msgstr "join 테이블들에 대한 양방향 연관들"
 
 #. Tag: para
-#: association_mapping.xml:238
 #, no-c-format
-msgid "The following is an example of a <emphasis>bidirectional one-to-many association on a join table</emphasis>. The <literal>inverse=\"true\"</literal> can go on either end of the association, on the collection, or on the join."
-msgstr "다음은 <emphasis>join 테이블에 대한 양방향 일-대-다 연관</emphasis>에 대한 예제이다. <literal>inverse=\"true\"</literal>는 연관의 어느 측이든지, 콜렉션 측에도, 또는 join 측에도 쓸 수 있다."
-
-#. Tag: programlisting
-#: association_mapping.xml:244
-#, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" \n"
-"        table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        inverse=\"true\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-one name=\"person\"\n"
-"            column=\"personId\"\n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
+"The following is an example of a <emphasis>bidirectional one-to-many "
+"association on a join table</emphasis>. The <literal>inverse=\"true\"</"
+"literal> can go on either end of the association, on the collection, or on "
+"the join."
 msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" \n"
-"        table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        inverse=\"true\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-one name=\"person\"\n"
-"            column=\"personId\"\n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
+"다음은 <emphasis>join 테이블에 대한 양방향 일-대-다 연관</emphasis>에 대한 예"
+"제이다. <literal>inverse=\"true\"</literal>는 연관의 어느 측이든지, 콜렉션 측"
+"에도, 또는 join 측에도 쓸 수 있다."
 
-#. Tag: programlisting
-#: association_mapping.xml:245
-#, no-c-format
-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"
-"        ]]>"
-
 #. Tag: title
-#: association_mapping.xml:250
 #, no-c-format
 msgid "one to one"
 msgstr "one to one"
 
 #. Tag: para
-#: association_mapping.xml:252
 #, no-c-format
-msgid "A <emphasis>bidirectional one-to-one association on a join table</emphasis> is possible, but extremely unusual."
-msgstr "<emphasis>join 테이블에 대한 양방향 일-대-일 연관</emphasis>이 가능하지만, 극히 통상적이지 않다."
-
-#. Tag: programlisting
-#: association_mapping.xml:257
-#, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\"\n"
-"        inverse=\"true\">\n"
-"        <key column=\"addressId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"person\"\n"
-"            column=\"personId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
+"A <emphasis>bidirectional one-to-one association on a join table</emphasis> "
+"is possible, but extremely unusual."
 msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\"\n"
-"        inverse=\"true\">\n"
-"        <key column=\"addressId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"person\"\n"
-"            column=\"personId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
+"<emphasis>join 테이블에 대한 양방향 일-대-일 연관</emphasis>이 가능하지만, 극"
+"히 통상적이지 않다."
 
 #. Tag: para
-#: association_mapping.xml:265
 #, no-c-format
-msgid "Here is an example of a <emphasis>bidirectional many-to-many association</emphasis>."
+msgid ""
+"Here is an example of a <emphasis>bidirectional many-to-many association</"
+"emphasis>."
 msgstr "이것은 <emphasis>양방향 다-대-다 연관</emphasis>에 대한 예제이다."
 
-#. Tag: programlisting
-#: association_mapping.xml:269
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-many column=\"personId\"\n"
-"            class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-many column=\"personId\"\n"
-"            class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
-
 #. Tag: title
-#: association_mapping.xml:278
 #, no-c-format
 msgid "More complex association mappings"
 msgstr "보다 복잡한 연관 매핑들"
 
 #. Tag: para
-#: association_mapping.xml:280
 #, no-c-format
-msgid "More complex association joins are <emphasis>extremely</emphasis> 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>, <literal>effectiveEndDate</literal> and <literal>effectiveStartDate</literal>columns, it would be mapped as follows:"
-msgstr "보다 복잡한 연관 join들은 <emphasis>극히</emphasis> 드물다. 하이버네이트는 매핑 문서들 내에 삽입된 SQL 조각들을 사용하여 보다 복잡한 상황들을 처리한다. 예를 들어, 만일 계좌 내역 정보 데이터를 가진 테이블이 <literal>accountNumber</literal>, <literal>effectiveEndDate</literal> 그리고 <literal>effectiveStartDate</literal> 컬럼들을 정의하고 있다면, 그것은 다음과 같이 매핑될 것이다:"
-
-#. Tag: programlisting
-#: association_mapping.xml:289
-#, no-c-format
 msgid ""
-"<![CDATA[<properties name=\"currentAccountKey\">\n"
-"    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
-"    <property name=\"currentAccount\" type=\"boolean\">\n"
-"        <formula>case when effectiveEndDate is null then 1 else 0 end</formula>\n"
-"    </property>\n"
-"</properties>\n"
-"<property name=\"effectiveEndDate\" type=\"date\"/>\n"
-"<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
+"More complex association joins are <emphasis>extremely</emphasis> 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>, "
+"<literal>effectiveEndDate</literal> and <literal>effectiveStartDate</"
+"literal>columns, it would be mapped as follows:"
 msgstr ""
-"<![CDATA[<properties name=\"currentAccountKey\">\n"
-"    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
-"    <property name=\"currentAccount\" type=\"boolean\">\n"
-"        <formula>case when effectiveEndDate is null then 1 else 0 end</formula>\n"
-"    </property>\n"
-"</properties>\n"
-"<property name=\"effectiveEndDate\" type=\"date\"/>\n"
-"<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
+"보다 복잡한 연관 join들은 <emphasis>극히</emphasis> 드물다. 하이버네이트는 매"
+"핑 문서들 내에 삽입된 SQL 조각들을 사용하여 보다 복잡한 상황들을 처리한다. 예"
+"를 들어, 만일 계좌 내역 정보 데이터를 가진 테이블이 <literal>accountNumber</"
+"literal>, <literal>effectiveEndDate</literal> 그리고 "
+"<literal>effectiveStartDate</literal> 컬럼들을 정의하고 있다면, 그것은 다음"
+"과 같이 매핑될 것이다:"
 
 #. Tag: para
-#: association_mapping.xml:291
 #, no-c-format
-msgid "You can then map an association to the <emphasis>current</emphasis> instance, the one with null <literal>effectiveEndDate</literal>, by using:"
-msgstr "그때 당신은 다음을 사용하여 하나의 연관을 널이 허용되는 <literal>effectiveEndDate</literal>를 가진, <emphasis>current</emphasis> 인스턴스에 매핑시킬 수 있다:"
-
-#. Tag: programlisting
-#: association_mapping.xml:296
-#, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
-"        property-ref=\"currentAccountKey\"\n"
-"        class=\"AccountInfo\">\n"
-"    <column name=\"accountNumber\"/>\n"
-"    <formula>'1'</formula>\n"
-"</many-to-one>]]>"
+"You can then map an association to the <emphasis>current</emphasis> "
+"instance, the one with null <literal>effectiveEndDate</literal>, by using:"
 msgstr ""
-"<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
-"        property-ref=\"currentAccountKey\"\n"
-"        class=\"AccountInfo\">\n"
-"    <column name=\"accountNumber\"/>\n"
-"    <formula>'1'</formula>\n"
-"</many-to-one>]]>"
+"그때 당신은 다음을 사용하여 하나의 연관을 널이 허용되는 "
+"<literal>effectiveEndDate</literal>를 가진, <emphasis>current</emphasis> 인스"
+"턴스에 매핑시킬 수 있다:"
 
 #. Tag: para
-#: association_mapping.xml:298
 #, no-c-format
-msgid "In a more complex example, imagine that the association between <literal>Employee</literal> and <literal>Organization</literal> is maintained in an <literal>Employment</literal> table full of historical employment data. An association to the employee's <emphasis>most recent</emphasis> employer, the one with the most recent <literal>startDate</literal>, could be mapped in the following way:"
-msgstr "보다 복잡한 예제에서, <literal>Employee</literal>와 <literal>Organization</literal> 사이의 연관이 전체 고용 내역 데이터를 가진 <literal>Employment</literal> 테이블 내에 유지된다고 가정하자. 종업원의 <emphasis>가장 최근의</emphasis> 고용주에 대한 연관, 가장 최근의 <literal>startDate</literal>를 가진 연관이 다음 방법으로 매핑될 수 있다:"
-
-#. Tag: programlisting
-#: association_mapping.xml:306
-#, no-c-format
 msgid ""
-"<![CDATA[<join>\n"
-"    <key column=\"employeeId\"/>\n"
-"    <subselect>\n"
-"        select employeeId, orgId \n"
-"        from Employments \n"
-"        group by orgId \n"
-"        having startDate = max(startDate)\n"
-"    </subselect>\n"
-"    <many-to-one name=\"mostRecentEmployer\" \n"
-"            class=\"Organization\" \n"
-"            column=\"orgId\"/>\n"
-"</join>]]>"
+"In a more complex example, imagine that the association between "
+"<literal>Employee</literal> and <literal>Organization</literal> is "
+"maintained in an <literal>Employment</literal> table full of historical "
+"employment data. An association to the employee's <emphasis>most recent</"
+"emphasis> employer, the one with the most recent <literal>startDate</"
+"literal>, could be mapped in the following way:"
 msgstr ""
-"<![CDATA[<join>\n"
-"    <key column=\"employeeId\"/>\n"
-"    <subselect>\n"
-"        select employeeId, orgId \n"
-"        from Employments \n"
-"        group by orgId \n"
-"        having startDate = max(startDate)\n"
-"    </subselect>\n"
-"    <many-to-one name=\"mostRecentEmployer\" \n"
-"            class=\"Organization\" \n"
-"            column=\"orgId\"/>\n"
-"</join>]]>"
+"보다 복잡한 예제에서, <literal>Employee</literal>와 <literal>Organization</"
+"literal> 사이의 연관이 전체 고용 내역 데이터를 가진 <literal>Employment</"
+"literal> 테이블 내에 유지된다고 가정하자. 종업원의 <emphasis>가장 최근의</"
+"emphasis> 고용주에 대한 연관, 가장 최근의 <literal>startDate</literal>를 가"
+"진 연관이 다음 방법으로 매핑될 수 있다:"
 
 #. Tag: para
-#: association_mapping.xml:308
 #, 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이나 criteria 질의를 사용하여 이들 종류의 경우들을 처리하는 것이 보다 실용적이다."
+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이나 criteria 질의를 사용하"
+"여 이들 종류의 경우들을 처리하는 것이 보다 실용적이다."
 
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" constrained=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        <one-to-many class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        <one-to-many class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <one-to-many class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <one-to-many class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <many-to-one name=\"address\"\n"
+#~ "      column=\"addressId\"\n"
+#~ "      not-null=\"true\"\n"
+#~ "      insert=\"false\"\n"
+#~ "      update=\"false\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <list name=\"people\">\n"
+#~ "      <key column=\"addressId\" not-null=\"true\"/>\n"
+#~ "      <list-index column=\"peopleIdx\"/>\n"
+#~ "      <one-to-many class=\"Person\"/>\n"
+#~ "   </list>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <many-to-one name=\"address\"\n"
+#~ "      column=\"addressId\"\n"
+#~ "      not-null=\"true\"\n"
+#~ "      insert=\"false\"\n"
+#~ "      update=\"false\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <list name=\"people\">\n"
+#~ "      <key column=\"addressId\" not-null=\"true\"/>\n"
+#~ "      <list-index column=\"peopleIdx\"/>\n"
+#~ "      <one-to-many class=\"Person\"/>\n"
+#~ "   </list>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "   <one-to-one name=\"person\" \n"
+#~ "        property-ref=\"address\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "   <one-to-one name=\"person\" \n"
+#~ "        property-ref=\"address\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"address\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" \n"
+#~ "        constrained=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"address\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" \n"
+#~ "        constrained=\"true\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        inverse=\"true\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        inverse=\"true\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\"\n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"addressId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\"\n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"addressId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-many column=\"personId\"\n"
+#~ "            class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-many column=\"personId\"\n"
+#~ "            class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<properties name=\"currentAccountKey\">\n"
+#~ "    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
+#~ "    <property name=\"currentAccount\" type=\"boolean\">\n"
+#~ "        <formula>case when effectiveEndDate is null then 1 else 0 end</"
+#~ "formula>\n"
+#~ "    </property>\n"
+#~ "</properties>\n"
+#~ "<property name=\"effectiveEndDate\" type=\"date\"/>\n"
+#~ "<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<properties name=\"currentAccountKey\">\n"
+#~ "    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
+#~ "    <property name=\"currentAccount\" type=\"boolean\">\n"
+#~ "        <formula>case when effectiveEndDate is null then 1 else 0 end</"
+#~ "formula>\n"
+#~ "    </property>\n"
+#~ "</properties>\n"
+#~ "<property name=\"effectiveEndDate\" type=\"date\"/>\n"
+#~ "<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
+#~ "        property-ref=\"currentAccountKey\"\n"
+#~ "        class=\"AccountInfo\">\n"
+#~ "    <column name=\"accountNumber\"/>\n"
+#~ "    <formula>'1'</formula>\n"
+#~ "</many-to-one>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
+#~ "        property-ref=\"currentAccountKey\"\n"
+#~ "        class=\"AccountInfo\">\n"
+#~ "    <column name=\"accountNumber\"/>\n"
+#~ "    <formula>'1'</formula>\n"
+#~ "</many-to-one>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<join>\n"
+#~ "    <key column=\"employeeId\"/>\n"
+#~ "    <subselect>\n"
+#~ "        select employeeId, orgId \n"
+#~ "        from Employments \n"
+#~ "        group by orgId \n"
+#~ "        having startDate = max(startDate)\n"
+#~ "    </subselect>\n"
+#~ "    <many-to-one name=\"mostRecentEmployer\" \n"
+#~ "            class=\"Organization\" \n"
+#~ "            column=\"orgId\"/>\n"
+#~ "</join>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<join>\n"
+#~ "    <key column=\"employeeId\"/>\n"
+#~ "    <subselect>\n"
+#~ "        select employeeId, orgId \n"
+#~ "        from Employments \n"
+#~ "        group by orgId \n"
+#~ "        having startDate = max(startDate)\n"
+#~ "    </subselect>\n"
+#~ "    <many-to-one name=\"mostRecentEmployer\" \n"
+#~ "            class=\"Organization\" \n"
+#~ "            column=\"orgId\"/>\n"
+#~ "</join>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/basic_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/basic_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/basic_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,19 +11,16 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: basic_mapping.xml:29
 #, no-c-format
 msgid "Basic O/R Mapping"
 msgstr "기본 O/R 매핑"
 
 #. Tag: title
-#: basic_mapping.xml:32
 #, no-c-format
 msgid "Mapping declaration"
 msgstr "매핑 선언"
 
 #. Tag: para
-#: basic_mapping.xml:34
 #, fuzzy, no-c-format
 msgid ""
 "Object/relational mappings are usually defined in an XML document. The "
@@ -36,7 +33,6 @@
 "아닌, 영속 클래스 선언들로 생성된다는 의미에서 자바 중심적이다."
 
 #. Tag: para
-#: basic_mapping.xml:41
 #, fuzzy, no-c-format
 msgid ""
 "Please note that even though many Hibernate users choose to write the XML by "
@@ -48,83 +44,11 @@
 "도구들이 존재한다는 점을 노트하라."
 
 #. Tag: para
-#: basic_mapping.xml:47
 #, fuzzy, no-c-format
 msgid "Here is an example mapping:"
 msgstr "예제 매핑으로 시작하자:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:51
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"      \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"          \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"        <class name=\"Cat\"\n"
-"            table=\"cats\"\n"
-"            discriminator-value=\"C\">\n"
-"\n"
-"                <id name=\"id\">\n"
-"                        <generator class=\"native\"/>\n"
-"                </id>\n"
-"\n"
-"                <discriminator column=\"subclass\"\n"
-"                     type=\"character\"/>\n"
-"\n"
-"                <property name=\"weight\"/>\n"
-"\n"
-"                <property name=\"birthdate\"\n"
-"                    type=\"date\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"color\"\n"
-"                    type=\"eg.types.ColorUserType\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"sex\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"litterId\"\n"
-"                    column=\"litterId\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <many-to-one name=\"mother\"\n"
-"                    column=\"mother_id\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <set name=\"kittens\"\n"
-"                    inverse=\"true\"\n"
-"                    order-by=\"litter_id\">\n"
-"                        <key column=\"mother_id\"/>\n"
-"                        <one-to-many class=\"Cat\"/>\n"
-"                </set>\n"
-"\n"
-"                <subclass name=\"DomesticCat\"\n"
-"                    discriminator-value=\"D\">\n"
-"\n"
-"                        <property name=\"name\"\n"
-"                            type=\"string\"/>\n"
-"\n"
-"                </subclass>\n"
-"\n"
-"        </class>\n"
-"\n"
-"        <class name=\"Dog\">\n"
-"                <!-- mapping for Dog could go here -->\n"
-"        </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:53
 #, fuzzy, no-c-format
 msgid ""
 "We will now discuss the content of the mapping document. We will only "
@@ -140,13 +64,11 @@
 "성.)"
 
 #. Tag: title
-#: basic_mapping.xml:64
 #, no-c-format
 msgid "Doctype"
 msgstr "Doctype"
 
 #. Tag: para
-#: basic_mapping.xml:66
 #, fuzzy, no-c-format
 msgid ""
 "All XML mappings should declare the doctype shown. The actual DTD can be "
@@ -164,13 +86,11 @@
 "당신의 DTD 선언을 체크하라."
 
 #. Tag: title
-#: basic_mapping.xml:76
 #, no-c-format
 msgid "EntityResolver"
 msgstr "EntityResolver"
 
 #. Tag: para
-#: basic_mapping.xml:77
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate will first attempt to resolve DTDs in its classpath. It does this "
@@ -186,7 +106,6 @@
 "의 다른 systemId namespace들을 인지해낸다."
 
 #. Tag: para
-#: basic_mapping.xml:85
 #, fuzzy, no-c-format
 msgid ""
 "a <literal>hibernate namespace</literal> is recognized whenever the resolver "
@@ -200,7 +119,6 @@
 "엔티티들을 해석하려고 시도한다."
 
 #. Tag: para
-#: basic_mapping.xml:94
 #, fuzzy, no-c-format
 msgid ""
 "a <literal>user namespace</literal> is recognized whenever the resolver "
@@ -215,34 +133,11 @@
 "스로더를 통해 이들 엔티티들을 해석하려고 시도할 것이다."
 
 #. Tag: para
-#: basic_mapping.xml:103
 #, fuzzy, no-c-format
 msgid "The following is an example of utilizing user namespacing:"
 msgstr "user namespacing을 활용하는 예제:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:106
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\" [\n"
-"    <!ENTITY types SYSTEM \"classpath://your/domain/types.xml\">\n"
-"]>\n"
-"\n"
-"<hibernate-mapping package=\"your.domain\">\n"
-"    <class name=\"MyEntity\">\n"
-"        <id name=\"id\" type=\"my-custom-id-type\">\n"
-"            ...\n"
-"        </id>\n"
-"    <class>\n"
-"    &types;\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:107
 #, no-c-format
 msgid ""
 "Where <literal>types.xml</literal> is a resource in the <literal>your."
@@ -254,13 +149,11 @@
 "xref>를 포함한다."
 
 #. Tag: title
-#: basic_mapping.xml:115
 #, fuzzy, no-c-format
 msgid "Hibernate-mapping"
 msgstr "hibernate-mapping"
 
 #. Tag: para
-#: basic_mapping.xml:117
 #, fuzzy, no-c-format
 msgid ""
 "This element has several optional attributes. The <literal>schema</literal> "
@@ -284,35 +177,17 @@
 "를 지정한다. <literal>auto-import</literal> 속성은 디폴트로 우리가 질의 언어 "
 "속에서 수식어가 붙지 않은(unqualified) 클래스 이름들을 사용하게 할 것이다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:138
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping\n"
-"         schema=\"schemaName\"\n"
-"         catalog=\"catalogName\"\n"
-"         default-cascade=\"cascade_style\"\n"
-"         default-access=\"field|property|ClassName\"\n"
-"         default-lazy=\"true|false\"\n"
-"         auto-import=\"true|false\"\n"
-"         package=\"package.name\"\n"
-" />]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:141
 #, fuzzy, no-c-format
 msgid "<literal>schema</literal> (optional): the name of a database schema."
 msgstr "<literal>schema</literal> (옵션): 데이터베이스 스키마의 이름."
 
 #. Tag: para
-#: basic_mapping.xml:146
 #, fuzzy, no-c-format
 msgid "<literal>catalog</literal> (optional): the name of a database catalog."
 msgstr "<literal>catalog</literal> (옵션): 데이터베이스 카다록의 이름."
 
 #. Tag: para
-#: basic_mapping.xml:151
 #, fuzzy, no-c-format
 msgid ""
 "<literal>default-cascade</literal> (optional - defaults to <literal>none</"
@@ -322,7 +197,6 @@
 "literal>): 디폴트 cascade 스타일."
 
 #. Tag: para
-#: basic_mapping.xml:157
 #, fuzzy, no-c-format
 msgid ""
 "<literal>default-access</literal> (optional - defaults to <literal>property</"
@@ -334,7 +208,6 @@
 "<literal>PropertyAccessor</literal>에 대한 맞춤형 구현일 수 있다."
 
 #. Tag: para
-#: basic_mapping.xml:164
 #, fuzzy, no-c-format
 msgid ""
 "<literal>default-lazy</literal> (optional - defaults to <literal>true</"
@@ -346,7 +219,6 @@
 "대한 디폴트 값."
 
 #. Tag: para
-#: basic_mapping.xml:171
 #, fuzzy, no-c-format
 msgid ""
 "<literal>auto-import</literal> (optional - defaults to <literal>true</"
@@ -358,7 +230,6 @@
 "이름들을 사용할 수 있는지를 지정한다."
 
 #. Tag: para
-#: basic_mapping.xml:178
 #, fuzzy, no-c-format
 msgid ""
 "<literal>package</literal> (optional): specifies a package prefix to use for "
@@ -368,7 +239,6 @@
 "스 이름들에 대해 가정할 패키지 접두어를 지정한다."
 
 #. Tag: para
-#: basic_mapping.xml:186
 #, fuzzy, no-c-format
 msgid ""
 "If you have two persistent classes with the same unqualified name, you "
@@ -381,7 +251,6 @@
 "할 경우에 Hibernate는 예외상황을 던질 것이다."
 
 #. Tag: para
-#: basic_mapping.xml:192
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>hibernate-mapping</literal> element allows you to nest several "
@@ -401,13 +270,11 @@
 "는 <literal>Animal.hbm.xml</literal>."
 
 #. Tag: title
-#: basic_mapping.xml:205
 #, fuzzy, no-c-format
 msgid "Class"
 msgstr "class"
 
 #. Tag: para
-#: basic_mapping.xml:207
 #, fuzzy, no-c-format
 msgid ""
 "You can declare a persistent class using the <literal>class</literal> "
@@ -416,38 +283,7 @@
 "당신은 <literal>class</literal> 요소를 사용하여 영속 클래스를 선언할 수도 있"
 "다:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:235
-#, no-c-format
-msgid ""
-"<![CDATA[<class\n"
-"        name=\"ClassName\"\n"
-"        table=\"tableName\"\n"
-"        discriminator-value=\"discriminator_value\"\n"
-"        mutable=\"true|false\"\n"
-"        schema=\"owner\"\n"
-"        catalog=\"catalog\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        select-before-update=\"true|false\"\n"
-"        polymorphism=\"implicit|explicit\"\n"
-"        where=\"arbitrary sql where condition\"\n"
-"        persister=\"PersisterClass\"\n"
-"        batch-size=\"N\"\n"
-"        optimistic-lock=\"none|version|dirty|all\"\n"
-"        lazy=\"true|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        check=\"arbitrary sql check condition\"\n"
-"        rowid=\"rowid\"\n"
-"        subselect=\"SQL expression\"\n"
-"        abstract=\"true|false\"\n"
-"        node=\"element-name\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:238
 #, fuzzy, no-c-format
 msgid ""
 "<literal>name</literal> (optional): the fully qualified Java class name of "
@@ -459,7 +295,6 @@
 "고 가정된다."
 
 #. Tag: para
-#: basic_mapping.xml:245
 #, fuzzy, no-c-format
 msgid ""
 "<literal>table</literal> (optional - defaults to the unqualified class "
@@ -469,7 +304,6 @@
 "의 데이터베이스 테이블의 이름."
 
 #. Tag: para
-#: basic_mapping.xml:251
 #, fuzzy, no-c-format
 msgid ""
 "<literal>discriminator-value</literal> (optional - defaults to the class "
@@ -482,7 +316,6 @@
 "값들은<literal>null</literal>과 <literal>not null</literal>을 포함한다."
 
 #. Tag: para
-#: basic_mapping.xml:258
 #, fuzzy, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>true</literal>): "
@@ -492,7 +325,6 @@
 "들의 인스턴스들이 가변적인지를 (가변적이지 않은지를) 지정한다."
 
 #. Tag: para
-#: basic_mapping.xml:264 basic_mapping.xml:2231
 #, fuzzy, no-c-format
 msgid ""
 "<literal>schema</literal> (optional): overrides the schema name specified by "
@@ -506,7 +338,6 @@
 "literal> 요소에 의해 지정된 스키마 이름을 오버라이드 시킨다"
 
 #. Tag: para
-#: basic_mapping.xml:270 basic_mapping.xml:2237
 #, fuzzy, no-c-format
 msgid ""
 "<literal>catalog</literal> (optional): overrides the catalog name specified "
@@ -520,7 +351,6 @@
 "literal> 요소에 의해 지정된 카타록 이름을 오버라이드 시킨다."
 
 #. Tag: para
-#: basic_mapping.xml:276
 #, fuzzy, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies an interface to use for lazy "
@@ -530,7 +360,6 @@
 "스를 지정한다. 당신은 클래스 그 자체의 이름을 지정할 수 도 있다."
 
 #. Tag: para
-#: basic_mapping.xml:282
 #, fuzzy, no-c-format
 msgid ""
 "<literal>dynamic-update</literal> (optional - defaults to <literal>false</"
@@ -542,7 +371,6 @@
 "값들이 변경된 그들 컬럼들 만을 포함할 것인지를 지정한다."
 
 #. Tag: para
-#: basic_mapping.xml:289
 #, fuzzy, no-c-format
 msgid ""
 "<literal>dynamic-insert</literal> (optional - defaults to <literal>false</"
@@ -554,7 +382,6 @@
 "의 값이 null이 아닌 컬럼들 만을 포함할 것인지를 지정한다."
 
 #. Tag: para
-#: basic_mapping.xml:296
 #, fuzzy, no-c-format
 msgid ""
 "<literal>select-before-update</literal> (optional - defaults to "
@@ -574,7 +401,6 @@
 "Hibernate는 특별한 SQL <literal>SELECT</literal>를 실행할 것임을 의미한다."
 
 #. Tag: para
-#: basic_mapping.xml:306
 #, fuzzy, no-c-format
 msgid ""
 "<literal>polymorphism</literal> (optional - defaults to <literal>implicit</"
@@ -586,7 +412,6 @@
 "것인지를 결정한다."
 
 #. Tag: para
-#: basic_mapping.xml:312
 #, fuzzy, no-c-format
 msgid ""
 "<literal>where</literal> (optional): specifies an arbitrary SQL "
@@ -597,7 +422,6 @@
 "인 SQL <literal>WHERE</literal> 조건을 지정한다"
 
 #. Tag: para
-#: basic_mapping.xml:318
 #, fuzzy, no-c-format
 msgid ""
 "<literal>persister</literal> (optional): specifies a custom "
@@ -607,7 +431,6 @@
 "를 지정한다."
 
 #. Tag: para
-#: basic_mapping.xml:323
 #, fuzzy, no-c-format
 msgid ""
 "<literal>batch-size</literal> (optional - defaults to <literal>1</literal>): "
@@ -618,7 +441,6 @@
 "에 의해 이 클래스의 인스턴스들을 페치시키는 \"배치 사이즈\"를 지정한다."
 
 #. Tag: para
-#: basic_mapping.xml:329
 #, fuzzy, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>version</"
@@ -628,7 +450,6 @@
 "literal>): optimistic 잠금 방도를 결정한다."
 
 #. Tag: para
-#: basic_mapping.xml:335
 #, fuzzy, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional): lazy fetching can be disabled by setting "
@@ -638,7 +459,6 @@
 "로써 Lazy fetching이 전체적으로 사용불가능하게 될 수 있다."
 
 #. Tag: para
-#: basic_mapping.xml:341
 #, fuzzy, no-c-format
 msgid ""
 "<literal>entity-name</literal> (optional - defaults to the class name): "
@@ -646,7 +466,7 @@
 "different tables. It also allows entity mappings that are represented by "
 "Maps or XML at the Java level. In these cases, you should provide an "
 "explicit arbitrary name for the entity. See <xref linkend=\"persistent-"
-"classes-dynamicmodels\"/> and <xref linkend=\"xml\"/> for more information."
+"classes-dynamicmodels\" /> and <xref linkend=\"xml\" /> for more information."
 msgstr ""
 "<literal>entity-name</literal>(옵션, 디폴트는 클래스 이름): Hibernate3는 하나"
 "의 클래스가 (잠정적으로 다른 테이블들로) 여러번 매핑되는 것을 허용해주고, "
@@ -659,7 +479,6 @@
 "\"persistent-classes-dynamicmodels\"/>과 <xref linkend=\"xml\"/>을 보라."
 
 #. Tag: para
-#: basic_mapping.xml:351
 #, fuzzy, no-c-format
 msgid ""
 "<literal>check</literal> (optional): an SQL expression used to generate a "
@@ -670,7 +489,6 @@
 "<emphasis>check</emphasis> constraint를 생성시키는데 사용되는 SQL 표현식."
 
 #. Tag: para
-#: basic_mapping.xml:357
 #, fuzzy, no-c-format
 msgid ""
 "<literal>rowid</literal> (optional): Hibernate can use ROWIDs on databases. "
@@ -686,7 +504,6 @@
 "튜플(tuple)의 물리적이니 위치를 표현한다."
 
 #. Tag: para
-#: basic_mapping.xml:364
 #, fuzzy, no-c-format
 msgid ""
 "<literal>subselect</literal> (optional): maps an immutable and read-only "
@@ -698,7 +515,6 @@
 "용하지만, 사용을 자제하라. 추가 정보는 아래를 보라."
 
 #. Tag: para
-#: basic_mapping.xml:371
 #, fuzzy, no-c-format
 msgid ""
 "<literal>abstract</literal> (optional): is used to mark abstract "
@@ -708,7 +524,6 @@
 "literal> 계층 구조들 내에서 abstract 슈퍼클래스들을 마크하는데 사용된다."
 
 #. Tag: para
-#: basic_mapping.xml:379
 #, fuzzy, no-c-format
 msgid ""
 "It is acceptable for the named persistent class to be an interface. You can "
@@ -724,7 +539,6 @@
 "Foo$Bar</literal>를 사용하여 클래스 이름을 지정해야 한다."
 
 #. Tag: para
-#: basic_mapping.xml:386
 #, fuzzy, no-c-format
 msgid ""
 "Immutable classes, <literal>mutable=\"false\"</literal>, cannot be updated "
@@ -736,7 +550,6 @@
 "떤 마이너 퍼포먼스 최적화를 행하게끔 허용해준다."
 
 #. Tag: para
-#: basic_mapping.xml:391
 #, fuzzy, no-c-format
 msgid ""
 "The optional <literal>proxy</literal> attribute enables lazy initialization "
@@ -751,7 +564,6 @@
 "출될 때 로드될 것이다. 아래 \"Lazy 초기화를 위한 프락시들\"을 보라."
 
 #. Tag: para
-#: basic_mapping.xml:398
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Implicit</emphasis> polymorphism means that instances of the class "
@@ -782,7 +594,6 @@
 "\"경량급\" 클래스를 허용한다)."
 
 #. Tag: para
-#: basic_mapping.xml:410
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>persister</literal> attribute lets you customize the "
@@ -804,7 +615,6 @@
 "<literal>org.hibernate.test.CustomPersister</literal>를 보라."
 
 #. Tag: para
-#: basic_mapping.xml:421
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>dynamic-update</literal> and <literal>dynamic-insert</literal> "
@@ -820,7 +630,6 @@
 "만 다른 경우들에서는 퍼포먼스를 실제로 감소시킬 수도 있다. 적절하게 사용하라."
 
 #. Tag: para
-#: basic_mapping.xml:429
 #, fuzzy, no-c-format
 msgid ""
 "Use of <literal>select-before-update</literal> will usually decrease "
@@ -834,7 +643,6 @@
 "방지하는데 매우 유용하다."
 
 #. Tag: para
-#: basic_mapping.xml:435
 #, no-c-format
 msgid ""
 "If you enable <literal>dynamic-update</literal>, you will have a choice of "
@@ -844,19 +652,16 @@
 "optimistic 잠금 전략들을 선택하게 될 것이다:"
 
 #. Tag: para
-#: basic_mapping.xml:441
 #, fuzzy, no-c-format
 msgid "<literal>version</literal>: check the version/timestamp columns"
 msgstr "<literal>version</literal>은 version/timestamp 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:446
 #, fuzzy, no-c-format
 msgid "<literal>all</literal>: check all columns"
 msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:451
 #, fuzzy, no-c-format
 msgid ""
 "<literal>dirty</literal>: check the changed columns, allowing some "
@@ -866,13 +671,11 @@
 "을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:456
 #, fuzzy, no-c-format
 msgid "<literal>none</literal>: do not use optimistic locking"
 msgstr "<literal>none</literal>은 optimistic 잠금을 사용하지 않는다"
 
 #. Tag: para
-#: basic_mapping.xml:461
 #, fuzzy, no-c-format
 msgid ""
 "It is <emphasis>strongly</emphasis> recommended that you use version/"
@@ -887,7 +690,6 @@
 "용될 때)."
 
 #. Tag: para
-#: basic_mapping.xml:468
 #, fuzzy, no-c-format
 msgid ""
 "There is no difference between a view and a base table for a Hibernate "
@@ -904,26 +706,7 @@
 "터베이스 속에 뷰를 생성시킬 수 없다. 이 경우에, 당신은 불변의 읽기 전용 엔티"
 "티를 주어진 SQL subselect 표현식으로 매핑시킬 수 있다:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:476
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Summary\">\n"
-"    <subselect>\n"
-"        select item.name, max(bid.amount), count(*)\n"
-"        from item\n"
-"        join bid on bid.item_id = item.id\n"
-"        group by item.name\n"
-"    </subselect>\n"
-"    <synchronize table=\"item\"/>\n"
-"    <synchronize table=\"bid\"/>\n"
-"    <id name=\"name\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:478
 #, fuzzy, no-c-format
 msgid ""
 "Declare the tables to synchronize this entity with, ensuring that auto-flush "
@@ -937,13 +720,11 @@
 "양자로서 이용 가능하다."
 
 #. Tag: title
-#: basic_mapping.xml:488
 #, no-c-format
-msgid "<title>id</title>"
-msgstr ""
+msgid "id"
+msgstr "id"
 
 #. Tag: para
-#: basic_mapping.xml:490
 #, no-c-format
 msgid ""
 "Mapped classes <emphasis>must</emphasis> declare the primary key column of "
@@ -957,38 +738,19 @@
 "는 자바빈즈-스타일 프로퍼티를 가질 것이다. <literal>&lt;id&gt;</literal> 요소"
 "는 그 프로퍼티로부터 프라이머리 키 컬럼으로의 매핑을 정의한다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:505
-#, no-c-format
-msgid ""
-"<![CDATA[<id\n"
-"        name=\"propertyName\"\n"
-"        type=\"typename\"\n"
-"        column=\"column_name\"\n"
-"        unsaved-value=\"null|any|none|undefined|id_value\"\n"
-"        access=\"field|property|ClassName\">\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"\n"
-"        <generator class=\"generatorClass\"/>\n"
-"</id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:508
 #, fuzzy, no-c-format
 msgid ""
 "<literal>name</literal> (optional): the name of the identifier property."
 msgstr "<literal>name</literal> (옵션): 식별자 프로퍼티의 이름."
 
 #. Tag: para
-#: basic_mapping.xml:513 basic_mapping.xml:1351
 #, no-c-format
 msgid ""
 "<literal>type</literal> (optional): a name that indicates the Hibernate type."
 msgstr "<literal>type</literal> (옵션): Hibernate 타입을 나타내는 이름."
 
 #. Tag: para
-#: basic_mapping.xml:518
 #, fuzzy, no-c-format
 msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
@@ -998,7 +760,6 @@
 "의 이름."
 
 #. Tag: para
-#: basic_mapping.xml:524
 #, fuzzy, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to a \"sensible\" "
@@ -1012,7 +773,6 @@
 "자 프로퍼티 값."
 
 #. Tag: para
-#: basic_mapping.xml:532
 #, fuzzy, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
@@ -1048,7 +808,6 @@
 "Hibernate가 프로퍼티 값에 접근하는데 사용할 방도."
 
 #. Tag: para
-#: basic_mapping.xml:540
 #, no-c-format
 msgid ""
 "If the <literal>name</literal> attribute is missing, it is assumed that the "
@@ -1058,7 +817,6 @@
 "다고 가정된다."
 
 #. Tag: para
-#: basic_mapping.xml:545
 #, no-c-format
 msgid ""
 "The <literal>unsaved-value</literal> attribute is almost never needed in "
@@ -1067,7 +825,6 @@
 "<literal>unsaved-value</literal> 속성은 Hibernate3에서는 거의 필요하지 않다."
 
 #. Tag: para
-#: basic_mapping.xml:549
 #, fuzzy, no-c-format
 msgid ""
 "There is an alternative <literal>&lt;composite-id&gt;</literal> declaration "
@@ -1079,13 +836,11 @@
 "것에 대한 그것의 사용에 대해 강력하게 반대한다."
 
 #. Tag: title
-#: basic_mapping.xml:555
 #, no-c-format
 msgid "Generator"
 msgstr "Generator"
 
 #. Tag: para
-#: basic_mapping.xml:557
 #, no-c-format
 msgid ""
 "The optional <literal>&lt;generator&gt;</literal> child element names a Java "
@@ -1099,20 +854,7 @@
 "만일 임의의 파라미터들이 생성기 인스턴스를 구성하거나 초기화 시키는데 필요할 "
 "경우, 그것들은 <literal>&lt;param&gt;</literal> 요소 를 사용하여 전달된다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:564
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"org.hibernate.id.TableHiLoGenerator\">\n"
-"                <param name=\"table\">uid_table</param>\n"
-"                <param name=\"column\">next_hi_value_column</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:566
 #, fuzzy, no-c-format
 msgid ""
 "All generators implement the interface <literal>org.hibernate.id."
@@ -1127,14 +869,12 @@
 "미리 빈드된 구현들의 영역들을 제공한다. 빌드-인 생성기(generator)들에 대한 단"
 "축 이름들이 존재한다: <placeholder-1/>"
 
-#. Tag: literal
-#: basic_mapping.xml:574
-#, no-c-format
-msgid "increment"
-msgstr "increment"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>increment</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:576
 #, no-c-format
 msgid ""
 "generates identifiers of type <literal>long</literal>, <literal>short</"
@@ -1147,14 +887,12 @@
 "literal> 타입의 식별자들을 생성시킨다. <emphasis>클러스터 내에서는 사용하지 "
 "말라.</emphasis>"
 
-#. Tag: literal
-#: basic_mapping.xml:585
-#, no-c-format
-msgid "identity"
-msgstr "identity"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>identity</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:587
 #, no-c-format
 msgid ""
 "supports identity columns in DB2, MySQL, MS SQL Server, Sybase and "
@@ -1165,14 +903,12 @@
 "반환되는 식별자는 <literal>long</literal>, <literal>short</literal> 또는 "
 "<literal>int</literal> 타입이다."
 
-#. Tag: literal
-#: basic_mapping.xml:595
-#, no-c-format
-msgid "sequence"
-msgstr "sequence"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>sequence</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:597
 #, no-c-format
 msgid ""
 "uses a sequence in DB2, PostgreSQL, Oracle, SAP DB, McKoi or a generator in "
@@ -1183,14 +919,12 @@
 "생성기(generator)를 사용한다. 반환되는 식별자는 <literal>long</literal>, "
 "<literal>short</literal> 또는 <literal>int</literal> 타입이다."
 
-#. Tag: literal
-#: basic_mapping.xml:605
-#, no-c-format
-msgid "hilo"
-msgstr "hilo"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>hilo</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:607
 #, no-c-format
 msgid ""
 "uses a hi/lo algorithm to efficiently generate identifiers of type "
@@ -1206,14 +940,12 @@
 "들을 효과적으로 생성시키는데 hi/lo 알고리즘을 사용한다. hi/lo 알고리즘은 특"
 "정 데이터베이스에 대해서만 유일한 식별자들을 생성시킨다."
 
-#. Tag: literal
-#: basic_mapping.xml:617
-#, no-c-format
-msgid "seqhilo"
-msgstr "seqhilo"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>seqhilo</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:619
 #, no-c-format
 msgid ""
 "uses a hi/lo algorithm to efficiently generate identifiers of type "
@@ -1224,14 +956,12 @@
 "<literal>short</literal> 또는 <literal>int</literal> 타입의 식별자들을 효과적"
 "으로 생성시키는데 hi/lo 알고리즘을 사용한다."
 
-#. Tag: literal
-#: basic_mapping.xml:627
-#, no-c-format
-msgid "uuid"
-msgstr "uuid"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>uuid</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:629
 #, fuzzy, no-c-format
 msgid ""
 "uses a 128-bit UUID algorithm to generate identifiers of type string that "
@@ -1242,26 +972,22 @@
 "위해 128 비트 UUID 알고리즘을 사용한다. UUID는 길이가 32인 16진수들의 문자열"
 "로서 인코딩 된다."
 
-#. Tag: literal
-#: basic_mapping.xml:637
-#, no-c-format
-msgid "guid"
-msgstr "guid"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>guid</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:639
 #, no-c-format
 msgid "uses a database-generated GUID string on MS SQL Server and MySQL."
 msgstr "MS SQL Server와 MySQL 상에서 데이터베이스 생성 GUID 문자열을 사용한다."
 
-#. Tag: literal
-#: basic_mapping.xml:645
-#, no-c-format
-msgid "native"
-msgstr "native"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>native</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:647
 #, fuzzy, no-c-format
 msgid ""
 "selects <literal>identity</literal>, <literal>sequence</literal> or "
@@ -1271,14 +997,12 @@
 "기본 데이터베이스의 가용성들에 의존하여 <literal>identity</literal>, "
 "<literal>sequence</literal> 또는 <literal>hilo</literal>를 찾아낸다."
 
-#. Tag: literal
-#: basic_mapping.xml:655
-#, no-c-format
-msgid "assigned"
-msgstr "assigned"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>assigned</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:657
 #, fuzzy, no-c-format
 msgid ""
 "lets the application assign an identifier to the object before <literal>save"
@@ -1289,14 +1013,12 @@
 "체에 할당하도록 한다. <literal>&lt;generator&gt;</literal> 요소가 지정되지 않"
 "을 경우 이것이 디폴트 방도이다."
 
-#. Tag: literal
-#: basic_mapping.xml:665
-#, no-c-format
-msgid "select"
-msgstr "select"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>select</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:667
 #, fuzzy, no-c-format
 msgid ""
 "retrieves a primary key, assigned by a database trigger, by selecting the "
@@ -1305,14 +1027,12 @@
 "어떤 유일 키에 의해 행을 select하고 프라이머리 키 값을 검색함으로써 데이터베"
 "이스 트리거에 의해 할당된 프라이머리 키를 검색한다."
 
-#. Tag: literal
-#: basic_mapping.xml:674
-#, no-c-format
-msgid "foreign"
-msgstr "foreign"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>foreign</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:676
 #, fuzzy, no-c-format
 msgid ""
 "uses the identifier of another associated object. It is usually used in "
@@ -1322,14 +1042,12 @@
 "또 다른 연관된 객체의 식별자를 사용한다. 대개 <literal>&lt;one-to-one&gt;</"
 "literal> 프라이머리 키 연관관계와 함께 사용된다."
 
-#. Tag: literal
-#: basic_mapping.xml:683
-#, no-c-format
-msgid "sequence-identity"
-msgstr "sequence-identity"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>sequence-identity</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:685
 #, fuzzy, no-c-format
 msgid ""
 "a specialized sequence generation strategy that utilizes a database sequence "
@@ -1347,13 +1065,11 @@
 "게 되어 있음을 노트하라."
 
 #. Tag: title
-#: basic_mapping.xml:702
 #, no-c-format
 msgid "Hi/lo algorithm"
 msgstr "Hi/lo algorithm"
 
 #. Tag: para
-#: basic_mapping.xml:703
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>hilo</literal> and <literal>seqhilo</literal> generators "
@@ -1368,33 +1084,7 @@
 "\" 데이터베이스 테이블을 필요로 한다. 두 번째는 (지원되는) Oracle 스타일의 시"
 "퀀스를 사용한다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:710
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"hilo\">\n"
-"                <param name=\"table\">hi_value</param>\n"
-"                <param name=\"column\">next_value</param>\n"
-"                <param name=\"max_lo\">100</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:712
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"seqhilo\">\n"
-"                <param name=\"sequence\">hi_value</param>\n"
-"                <param name=\"max_lo\">100</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:714
 #, fuzzy, no-c-format
 msgid ""
 "Unfortunately, you cannot use <literal>hilo</literal> when supplying your "
@@ -1410,13 +1100,11 @@
 "해야 한다."
 
 #. Tag: title
-#: basic_mapping.xml:723
 #, no-c-format
 msgid "UUID algorithm"
 msgstr "UUID 알고리즘"
 
 #. Tag: para
-#: basic_mapping.xml:724
 #, fuzzy, no-c-format
 msgid ""
 "The UUID contains: IP address, startup time of the JVM that is accurate to a "
@@ -1430,13 +1118,11 @@
 "최상의 것이다."
 
 #. Tag: title
-#: basic_mapping.xml:733
 #, no-c-format
 msgid "Identity columns and sequences"
 msgstr "식별 컬럼들과 시퀀스들"
 
 #. Tag: para
-#: basic_mapping.xml:734
 #, fuzzy, no-c-format
 msgid ""
 "For databases that support identity columns (DB2, MySQL, Sybase, MS SQL), "
@@ -1451,29 +1137,7 @@
 "당신은 <literal>sequence</literal> 스타일 키 생성을 사용할 수도 있다. 이들 방"
 "도들 모두 새로운 객체를 insert하기 위해 두 개의 SQL 질의들을 필요로 한다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:742
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-"        <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">person_id_sequence</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:744
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\" unsaved-value=\"0"
-"\">\n"
-"        <generator class=\"identity\"/>\n"
-"</id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:746
 #, fuzzy, no-c-format
 msgid ""
 "For cross-platform development, the <literal>native</literal> strategy will, "
@@ -1486,13 +1150,11 @@
 "literal>, <literal>hilo</literal> 방도 중에서 선택될 것이다."
 
 #. Tag: title
-#: basic_mapping.xml:754
 #, no-c-format
 msgid "Assigned identifiers"
 msgstr "할당된 식별자들"
 
 #. Tag: para
-#: basic_mapping.xml:755
 #, fuzzy, no-c-format
 msgid ""
 "If you want the application to assign identifiers, as opposed to having "
@@ -1512,7 +1174,6 @@
 "트 특징이다"
 
 #. Tag: para
-#: basic_mapping.xml:764
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>assigned</literal> generator makes Hibernate use "
@@ -1529,13 +1190,11 @@
 "록 한다."
 
 #. Tag: title
-#: basic_mapping.xml:774
 #, no-c-format
 msgid "Primary keys assigned by triggers"
 msgstr "트리거들에 의해 할당된 프라이머리 키들"
 
 #. Tag: para
-#: basic_mapping.xml:775
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate does not generate DDL with triggers. It is for legacy schemas only."
@@ -1543,19 +1202,7 @@
 "리거시 스키마에 대해서만(Hibernate는 트리거들을 가진 DDL을 생성시키지 않는"
 "다)."
 
-#. Tag: programlisting
-#: basic_mapping.xml:779
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-"        <generator class=\"select\">\n"
-"                <param name=\"key\">socialSecurityNumber</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:781
 #, fuzzy, no-c-format
 msgid ""
 "In the above example, there is a unique valued property named "
@@ -1568,13 +1215,11 @@
 "생성되는 <literal>person_id</literal>로 명명된 대용키가 존재한다."
 
 #. Tag: title
-#: basic_mapping.xml:793
 #, no-c-format
 msgid "Enhanced identifier generators"
 msgstr "NOT TRANSLATED!Enhanced identifier generators"
 
 #. Tag: para
-#: basic_mapping.xml:795
 #, fuzzy, no-c-format
 msgid ""
 "Starting with release 3.2.3, there are 2 new generators which represent a re-"
@@ -1594,7 +1239,6 @@
 "current releases and can be referenced by FQN."
 
 #. Tag: para
-#: basic_mapping.xml:803
 #, fuzzy, no-c-format
 msgid ""
 "The first of these new generators is <literal>org.hibernate.id.enhanced."
@@ -1632,7 +1276,6 @@
 "<placeholder-1/>"
 
 #. Tag: para
-#: basic_mapping.xml:817
 #, fuzzy, no-c-format
 msgid ""
 "<literal>sequence_name</literal> (optional, defaults to "
@@ -1644,7 +1287,6 @@
 "to be used."
 
 #. Tag: para
-#: basic_mapping.xml:823
 #, fuzzy, no-c-format
 msgid ""
 "<literal>initial_value</literal> (optional, defaults to <literal>1</"
@@ -1658,7 +1300,6 @@
 "\"STARTS WITH\"."
 
 #. Tag: para
-#: basic_mapping.xml:830
 #, fuzzy, no-c-format
 msgid ""
 "<literal>increment_size</literal> (optional - defaults to <literal>1</"
@@ -1672,7 +1313,6 @@
 "named \"INCREMENT BY\"."
 
 #. Tag: para
-#: basic_mapping.xml:837
 #, fuzzy, no-c-format
 msgid ""
 "<literal>force_table_use</literal> (optional - defaults to <literal>false</"
@@ -1684,7 +1324,6 @@
 "though the dialect might support sequence?"
 
 #. Tag: para
-#: basic_mapping.xml:844
 #, fuzzy, no-c-format
 msgid ""
 "<literal>value_column</literal> (optional - defaults to <literal>next_val</"
@@ -1696,17 +1335,16 @@
 "table which is used to hold the value."
 
 #. Tag: para
-#: basic_mapping.xml:851
 #, fuzzy, no-c-format
 msgid ""
 "<literal>optimizer</literal> (optional - defaults to <literal>none</"
-"literal>): See"
+"literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\" /"
+">"
 msgstr ""
-"<literal>cascade</literal> (optional- defaults to <literal>none</literal>): "
-"cascade 스타일."
+"<literal>optimizer</literal> (optional, defaults to <literal>none</"
+"literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\"/>"
 
 #. Tag: para
-#: basic_mapping.xml:858
 #, fuzzy, no-c-format
 msgid ""
 "The second of these new generators is <literal>org.hibernate.id.enhanced."
@@ -1732,7 +1370,6 @@
 "parameters: <placeholder-1/>"
 
 #. Tag: para
-#: basic_mapping.xml:868
 #, fuzzy, no-c-format
 msgid ""
 "<literal>table_name</literal> (optional - defaults to "
@@ -1742,7 +1379,6 @@
 "<literal>hibernate_sequences</literal>): The name of the table to be used."
 
 #. Tag: para
-#: basic_mapping.xml:874
 #, fuzzy, no-c-format
 msgid ""
 "<literal>value_column_name</literal> (optional - defaults to "
@@ -1754,7 +1390,6 @@
 "used to hold the value."
 
 #. Tag: para
-#: basic_mapping.xml:880
 #, fuzzy, no-c-format
 msgid ""
 "<literal>segment_column_name</literal> (optional - defaults to "
@@ -1768,7 +1403,6 @@
 "identifies which increment value to use."
 
 #. Tag: para
-#: basic_mapping.xml:887
 #, fuzzy, no-c-format
 msgid ""
 "<literal>segment_value</literal> (optional - defaults to <literal>default</"
@@ -1780,7 +1414,6 @@
 "pull increment values for this generator."
 
 #. Tag: para
-#: basic_mapping.xml:894
 #, fuzzy, no-c-format
 msgid ""
 "<literal>segment_value_length</literal> (optional - defaults to "
@@ -1792,7 +1425,6 @@
 "segment key column."
 
 #. Tag: para
-#: basic_mapping.xml:900
 #, fuzzy, no-c-format
 msgid ""
 "<literal>initial_value</literal> (optional - defaults to <literal>1</"
@@ -1802,7 +1434,6 @@
 "literal>): The initial value to be retrieved from the table."
 
 #. Tag: para
-#: basic_mapping.xml:906
 #, fuzzy, no-c-format
 msgid ""
 "<literal>increment_size</literal> (optional - defaults to <literal>1</"
@@ -1812,23 +1443,20 @@
 "literal>): The value by which subsequent calls to the table should differ."
 
 #. Tag: para
-#: basic_mapping.xml:912
 #, fuzzy, no-c-format
 msgid ""
 "<literal>optimizer</literal> (optional - defaults to <literal></literal>): "
-"See"
+"See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\" />"
 msgstr ""
-"<literal>cascade</literal> (optional- defaults to <literal>none</literal>): "
-"cascade 스타일."
+"<literal>optimizer</literal> (optional, defaults to <literal>none</"
+"literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\"/>"
 
 #. Tag: title
-#: basic_mapping.xml:922
 #, no-c-format
 msgid "Identifier generator optimization"
 msgstr "NOT TRANSLATED! Identifier generator optimization"
 
 #. Tag: para
-#: basic_mapping.xml:923
 #, fuzzy, no-c-format
 msgid ""
 "For identifier generators that store values in the database, it is "
@@ -1836,7 +1464,7 @@
 "a new identifier value. Instead, you can group a bunch of them in memory and "
 "only hit the database when you have exhausted your in-memory value group. "
 "This is the role of the pluggable optimizers. Currently only the two "
-"enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced\"/> "
+"enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced\" /> "
 "support this operation."
 msgstr ""
 "For identifier generators which store values in the database, it is "
@@ -1848,7 +1476,6 @@
 "\"/> support this notion. <placeholder-1/>"
 
 #. Tag: para
-#: basic_mapping.xml:931
 #, fuzzy, no-c-format
 msgid ""
 "<literal>none</literal> (generally this is the default if no optimizer was "
@@ -1860,7 +1487,6 @@
 "each and every request."
 
 #. Tag: para
-#: basic_mapping.xml:937
 #, fuzzy, no-c-format
 msgid ""
 "<literal>hilo</literal>: applies a hi/lo algorithm around the database "
@@ -1878,7 +1504,6 @@
 "define a group \"hi value\"."
 
 #. Tag: para
-#: basic_mapping.xml:946
 #, fuzzy, no-c-format
 msgid ""
 "<literal>pooled</literal>: as with the case of <literal>hilo</literal>, this "
@@ -1896,32 +1521,11 @@
 "refers to the values coming from the database."
 
 #. Tag: title
-#: basic_mapping.xml:959
 #, no-c-format
 msgid "composite-id"
 msgstr "composite-id"
 
-#. Tag: programlisting
-#: basic_mapping.xml:961
-#, no-c-format
-msgid ""
-"<![CDATA[<composite-id\n"
-"        name=\"propertyName\"\n"
-"        class=\"ClassName\"\n"
-"        mapped=\"true|false\"\n"
-"        access=\"field|property|ClassName\">\n"
-"        node=\"element-name|.\"\n"
-"\n"
-"        <key-property name=\"propertyName\" type=\"typename\" column="
-"\"column_name\"/>\n"
-"        <key-many-to-one name=\"propertyName class=\"ClassName\" column="
-"\"column_name\"/>\n"
-"        ......\n"
-"</composite-id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:963
 #, fuzzy, no-c-format
 msgid ""
 "A table with a composite key can be mapped with multiple properties of the "
@@ -1934,18 +1538,7 @@
 "는 자식 요소들로서 <literal>&lt;key-property&gt;</literal> 프로퍼티 매핑과 "
 "<literal>&lt;key-many-to-one&gt;</literal> 매핑들을 허용한다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:970
-#, no-c-format
-msgid ""
-"<![CDATA[<composite-id>\n"
-"        <key-property name=\"medicareNumber\"/>\n"
-"        <key-property name=\"dependent\"/>\n"
-"</composite-id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:972
 #, fuzzy, no-c-format
 msgid ""
 "The persistent class <emphasis>must</emphasis> override <literal>equals()</"
@@ -1958,7 +1551,6 @@
 "을 구현해야 한다."
 
 #. Tag: para
-#: basic_mapping.xml:978
 #, fuzzy, no-c-format
 msgid ""
 "Unfortunately, this approach means that a persistent object is its own "
@@ -1977,7 +1569,6 @@
 "composite 식별자로 부르고, 중대한 어플리케이션들에 대해 그것을 억제시킨다."
 
 #. Tag: para
-#: basic_mapping.xml:987
 #, no-c-format
 msgid ""
 "A second approach is what we call a <emphasis>mapped</emphasis> composite "
@@ -1990,18 +1581,7 @@
 "기서 식별자 프로퍼티들은 영속 클래스와 별도의 식별자 클래스 양자 상에 중복된"
 "다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:993
-#, no-c-format
-msgid ""
-"<![CDATA[<composite-id class=\"MedicareId\" mapped=\"true\">\n"
-"        <key-property name=\"medicareNumber\"/>\n"
-"        <key-property name=\"dependent\"/>\n"
-"</composite-id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:995
 #, fuzzy, no-c-format
 msgid ""
 "In this example, both the composite identifier class, <literal>MedicareId</"
@@ -2019,14 +1599,12 @@
 "명백한&mdash;코드 중복이다."
 
 #. Tag: para
-#: basic_mapping.xml:1004
 #, no-c-format
 msgid ""
 "The following attributes are used to specify a mapped composite identifier:"
 msgstr "다음 속성들은 매핑된 composite 식별자를 지정하는데 사용된다:"
 
 #. Tag: para
-#: basic_mapping.xml:1010
 #, fuzzy, no-c-format
 msgid ""
 "<literal>mapped</literal> (optional - defaults to <literal>false</literal>): "
@@ -2039,7 +1617,6 @@
 "래스와 composite 식별자 클래스 양자를 참조함을 나타낸다."
 
 #. Tag: para
-#: basic_mapping.xml:1018
 #, fuzzy, no-c-format
 msgid ""
 "<literal>class</literal> (optional - but required for a mapped composite "
@@ -2049,12 +1626,11 @@
 "서는 필수적임): 하나의 composite 식별자로서 사용되는 클래스."
 
 #. Tag: para
-#: basic_mapping.xml:1025
 #, fuzzy, no-c-format
 msgid ""
 "We will describe a third, even more convenient approach, where the composite "
 "identifier is implemented as a component class in <xref linkend=\"components-"
-"compositeid\"/>. The attributes described below apply only to this "
+"compositeid\" />. The attributes described below apply only to this "
 "alternative approach:"
 msgstr ""
 "우리는 <xref linkend=\"components-compositeid\"/>에서 composite 식별자가 하나"
@@ -2062,7 +1638,6 @@
 "이다. 아래에 설명되어 있는 속성들은 이 대체적인 접근법에만 적용된다:"
 
 #. Tag: para
-#: basic_mapping.xml:1033
 #, fuzzy, no-c-format
 msgid ""
 "<literal>name</literal> (optional - required for this approach): a property "
@@ -2073,9 +1648,6 @@
 "component 식별자를 소유하는 컴포넌트 타입의 프로퍼티(9장을 보라)."
 
 #. Tag: para
-#: basic_mapping.xml:1039 basic_mapping.xml:1260 basic_mapping.xml:1372
-#: basic_mapping.xml:1561 basic_mapping.xml:1735 basic_mapping.xml:1905
-#: basic_mapping.xml:2484
 #, fuzzy, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
@@ -2110,7 +1682,6 @@
 "Hibernate가 프로퍼티 값에 접근하는데 사용할 방도."
 
 #. Tag: para
-#: basic_mapping.xml:1045
 #, fuzzy, no-c-format
 msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
@@ -2121,7 +1692,6 @@
 "타입): 하나의 composite 식별자로서 사용되는 컴포넌트 클래스(다음 절을 보라)."
 
 #. Tag: para
-#: basic_mapping.xml:1052
 #, fuzzy, no-c-format
 msgid ""
 "The third approach, an <emphasis>identifier component</emphasis>, is "
@@ -2131,13 +1701,11 @@
 "리케이션들에 대해 우리가 권장하는 것이다."
 
 #. Tag: title
-#: basic_mapping.xml:1060
 #, fuzzy, no-c-format
 msgid "Discriminator"
 msgstr "discriminator"
 
 #. Tag: para
-#: basic_mapping.xml:1062
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>&lt;discriminator&gt;</literal> element is required for "
@@ -2159,21 +1727,7 @@
 "literal>, <literal>short</literal>, <literal>boolean</literal>, "
 "<literal>yes_no</literal>, <literal>true_false</literal>."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1080
-#, no-c-format
-msgid ""
-"<![CDATA[<discriminator\n"
-"        column=\"discriminator_column\"\n"
-"        type=\"discriminator_type\"\n"
-"        force=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        formula=\"arbitrary sql expression\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1083
 #, fuzzy, no-c-format
 msgid ""
 "<literal>column</literal> (optional - defaults to <literal>class</literal>): "
@@ -2183,7 +1737,6 @@
 "discriminator 컬럼명."
 
 #. Tag: para
-#: basic_mapping.xml:1089
 #, fuzzy, no-c-format
 msgid ""
 "<literal>type</literal> (optional - defaults to <literal>string</literal>): "
@@ -2193,7 +1746,6 @@
 "Hibernate 타입을 나타내는 이름"
 
 #. Tag: para
-#: basic_mapping.xml:1095
 #, fuzzy, no-c-format
 msgid ""
 "<literal>force</literal> (optional - defaults to <literal>false</literal>): "
@@ -2205,7 +1757,6 @@
 "discriminator 값들을 지정하도록 \"강제한다\"."
 
 #. Tag: para
-#: basic_mapping.xml:1102
 #, fuzzy, no-c-format
 msgid ""
 "<literal>insert</literal> (optional - defaults to <literal>true</literal>): "
@@ -2219,7 +1770,6 @@
 "literal>들 속에 그 컬럼을 포함하지 않도록 통보한다.)"
 
 #. Tag: para
-#: basic_mapping.xml:1110
 #, fuzzy, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an arbitrary SQL expression that is "
@@ -2230,7 +1780,6 @@
 "SQL 표현식. 컨텐츠 기반의 판별을 허용해준다."
 
 #. Tag: para
-#: basic_mapping.xml:1118
 #, no-c-format
 msgid ""
 "Actual values of the discriminator column are specified by the "
@@ -2242,7 +1791,6 @@
 "literal> 속성에 의해 지정된다."
 
 #. Tag: para
-#: basic_mapping.xml:1124
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>force</literal> attribute is only useful if the table contains "
@@ -2254,7 +1802,6 @@
 "그 경우가 아닐 것이다."
 
 #. Tag: para
-#: basic_mapping.xml:1130
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>formula</literal> attribute allows you to declare an arbitrary "
@@ -2263,23 +1810,12 @@
 "<literal>formula</literal> 속성을 사용하여 당신은 행의 타입을 판단하는데 사용"
 "될 임의의 SQL 표현식을 선언할 수 있다:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1135
-#, no-c-format
-msgid ""
-"<![CDATA[<discriminator\n"
-"    formula=\"case when CLASS_TYPE in ('a', 'b', 'c') then 0 else 1 end\"\n"
-"    type=\"integer\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:1140
 #, fuzzy, no-c-format
 msgid "Version (optional)"
 msgstr "version (옵션)"
 
 #. Tag: para
-#: basic_mapping.xml:1142
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>&lt;version&gt;</literal> element is optional and indicates "
@@ -2291,24 +1827,7 @@
 "를 포함한다는 것을 나타낸다. 이것은 당신이 <emphasis>긴 트랜잭션(long "
 "transaction)들</emphasis>을 사용할 계획이라면 특히 유용하다 (아래를 보라)."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1158
-#, no-c-format
-msgid ""
-"<![CDATA[<version\n"
-"        column=\"version_column\"\n"
-"        name=\"propertyName\"\n"
-"        type=\"typename\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unsaved-value=\"null|negative|undefined\"\n"
-"        generated=\"never|always\"\n"
-"        insert=\"true|false\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1161
 #, fuzzy, no-c-format
 msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
@@ -2318,14 +1837,12 @@
 "럼의 이름."
 
 #. Tag: para
-#: basic_mapping.xml:1167
 #, fuzzy, no-c-format
 msgid ""
 "<literal>name</literal>: the name of a property of the persistent class."
 msgstr "<literal>name</literal>: 영속 클래스의 프로퍼티 명."
 
 #. Tag: para
-#: basic_mapping.xml:1172
 #, fuzzy, no-c-format
 msgid ""
 "<literal>type</literal> (optional - defaults to <literal>integer</literal>): "
@@ -2335,7 +1852,6 @@
 "호의 타입."
 
 #. Tag: para
-#: basic_mapping.xml:1178
 #, fuzzy, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
@@ -2370,7 +1886,6 @@
 "Hibernate가 프로퍼티 값에 접근하는데 사용할 방도."
 
 #. Tag: para
-#: basic_mapping.xml:1184
 #, fuzzy, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to <literal>undefined</"
@@ -2385,7 +1900,6 @@
 "(<literal>undefined</literal>는 식별자 프로퍼티 값이 사용될 것임을 지정한다.)"
 
 #. Tag: para
-#: basic_mapping.xml:1193
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2399,7 +1913,6 @@
 "보라."
 
 #. Tag: para
-#: basic_mapping.xml:1200
 #, fuzzy, no-c-format
 msgid ""
 "<literal>insert</literal> (optional - defaults to <literal>true</literal>): "
@@ -2413,7 +1926,6 @@
 "literal>로 설정될 수 있다."
 
 #. Tag: para
-#: basic_mapping.xml:1210
 #, fuzzy, no-c-format
 msgid ""
 "Version numbers can be of Hibernate type <literal>long</literal>, "
@@ -2425,7 +1937,6 @@
 "<literal>calendar</literal> 타입일 수 있다."
 
 #. Tag: para
-#: basic_mapping.xml:1215
 #, fuzzy, no-c-format
 msgid ""
 "A version or timestamp property should never be null for a detached "
@@ -2445,13 +1956,11 @@
 "히 유용하다!</emphasis>"
 
 #. Tag: title
-#: basic_mapping.xml:1226
 #, fuzzy, no-c-format
 msgid "Timestamp (optional)"
 msgstr "timestamp (옵션)"
 
 #. Tag: para
-#: basic_mapping.xml:1228
 #, fuzzy, no-c-format
 msgid ""
 "The optional <literal>&lt;timestamp&gt;</literal> element indicates that the "
@@ -2464,23 +1973,7 @@
 "Timestamp은 고유하게 optimistic 잠금에 대한 다소 안전한 구현이다. 하지만 때때"
 "로 어플리케이션은 다른 방법들로 timestamp들을 사용할 수도 있다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1244
-#, no-c-format
-msgid ""
-"<![CDATA[<timestamp\n"
-"        column=\"timestamp_column\"\n"
-"        name=\"propertyName\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unsaved-value=\"null|undefined\"\n"
-"        source=\"vm|db\"\n"
-"        generated=\"never|always\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1247
 #, fuzzy, no-c-format
 msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
@@ -2490,7 +1983,6 @@
 "는 컬럼 명."
 
 #. Tag: para
-#: basic_mapping.xml:1253
 #, fuzzy, no-c-format
 msgid ""
 "<literal>name</literal>: the name of a JavaBeans style property of Java type "
@@ -2501,7 +1993,6 @@
 "는 <literal>Timestamp</literal> 타입을 가진 자바빈즈 스타일의 프로퍼티 이름."
 
 #. Tag: para
-#: basic_mapping.xml:1266
 #, fuzzy, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to <literal>null</"
@@ -2516,7 +2007,6 @@
 "(<literal>undefined</literal>는 식별자 프로퍼티 값이 사용될 것임을 지정한다.)"
 
 #. Tag: para
-#: basic_mapping.xml:1275
 #, fuzzy, no-c-format
 msgid ""
 "<literal>source</literal> (optional - defaults to <literal>vm</literal>): "
@@ -2538,7 +2028,6 @@
 "에 있어 사용이 안전하지 않을 수 있음을 노트하라(예를 들면 오라클 8)."
 
 #. Tag: para
-#: basic_mapping.xml:1287
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2551,13 +2040,11 @@
 "linkend=\"mapping-generated\">산출되는 프로퍼티들</xref>에 대한 논의들 보라."
 
 #. Tag: title
-#: basic_mapping.xml:1298 basic_mapping.xml:2890
 #, no-c-format
 msgid "Note"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1299
 #, fuzzy, no-c-format
 msgid ""
 "<literal>&lt;Timestamp&gt;</literal> is equivalent to <literal>&lt;version "
@@ -2571,13 +2058,11 @@
 "literal>과 같다"
 
 #. Tag: title
-#: basic_mapping.xml:1311
 #, fuzzy, no-c-format
 msgid "Property"
 msgstr "프로퍼티"
 
 #. Tag: para
-#: basic_mapping.xml:1313
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>&lt;property&gt;</literal> element declares a persistent "
@@ -2586,34 +2071,7 @@
 "<literal>&lt;property&gt;</literal> 요소는 클래스의 자바빈즈 스타일의 영속 프"
 "로퍼티를 선언한다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1335
-#, no-c-format
-msgid ""
-"<![CDATA[<property\n"
-"        name=\"propertyName\"\n"
-"        column=\"column_name\"\n"
-"        type=\"typename\"\n"
-"        update=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        formula=\"arbitrary SQL expression\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        lazy=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        not-null=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        generated=\"never|insert|always\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        index=\"index_name\"\n"
-"        unique_key=\"unique_key_id\"\n"
-"        length=\"L\"\n"
-"        precision=\"P\"\n"
-"        scale=\"S\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1338
 #, no-c-format
 msgid ""
 "<literal>name</literal>: the name of the property, with an initial lowercase "
@@ -2621,7 +2079,6 @@
 msgstr "<literal>name</literal>: 첫 소문자로 시작하는 프로퍼티 이름."
 
 #. Tag: para
-#: basic_mapping.xml:1344
 #, fuzzy, no-c-format
 msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
@@ -2633,7 +2090,6 @@
 "literal> 요소(들)에 의해 지정될 수도 있다."
 
 #. Tag: para
-#: basic_mapping.xml:1356
 #, fuzzy, no-c-format
 msgid ""
 "<literal>update, insert</literal> (optional - defaults to <literal>true</"
@@ -2651,7 +2107,6 @@
 "기화 되는 순수하게 \"파생된(derived)\" 프로퍼티를 허용해준다."
 
 #. Tag: para
-#: basic_mapping.xml:1365
 #, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an SQL expression that defines the "
@@ -2663,7 +2118,6 @@
 "매핑을 갖지 않는다."
 
 #. Tag: para
-#: basic_mapping.xml:1378
 #, fuzzy, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>false</literal>): "
@@ -2675,7 +2129,6 @@
 "(빌드-시 바이트코드 수단을 필요로 한다)."
 
 #. Tag: para
-#: basic_mapping.xml:1385
 #, fuzzy, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): enables the DDL generation of a unique "
@@ -2687,7 +2140,6 @@
 "는 것을 허용해준다."
 
 #. Tag: para
-#: basic_mapping.xml:1392
 #, fuzzy, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): enables the DDL generation of a "
@@ -2697,7 +2149,6 @@
 "DDL 생성을 가능하게 만든다."
 
 #. Tag: para
-#: basic_mapping.xml:1398 basic_mapping.xml:1581
 #, fuzzy, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
@@ -2711,7 +2162,6 @@
 "버전 증가가 발생할 경우인지를 결정한다."
 
 #. Tag: para
-#: basic_mapping.xml:1406
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2724,13 +2174,11 @@
 "linkend=\"mapping-generated\">산출되는 프로퍼티들</xref>에 대한 논의를 보라."
 
 #. Tag: para
-#: basic_mapping.xml:1415
 #, no-c-format
 msgid "<emphasis>typename</emphasis> could be:"
 msgstr "<emphasis>typename</emphasis>은 다음일 수 있다:"
 
 #. Tag: para
-#: basic_mapping.xml:1421
 #, fuzzy, no-c-format
 msgid ""
 "The name of a Hibernate basic type: <literal>integer, string, character, "
@@ -2740,7 +2188,6 @@
 "date, timestamp, float, binary, serializable, object, blob</literal>)."
 
 #. Tag: para
-#: basic_mapping.xml:1427
 #, fuzzy, no-c-format
 msgid ""
 "The name of a Java class with a default basic type: <literal>int, float, "
@@ -2752,13 +2199,11 @@
 "literal>)."
 
 #. Tag: para
-#: basic_mapping.xml:1433
 #, no-c-format
 msgid "The name of a serializable Java class."
 msgstr "serializable Java 클래스의 이름."
 
 #. Tag: para
-#: basic_mapping.xml:1438
 #, fuzzy, no-c-format
 msgid ""
 "The class name of a custom type: <literal>com.illflow.type.MyCustomType</"
@@ -2768,7 +2213,6 @@
 "literal>)."
 
 #. Tag: para
-#: basic_mapping.xml:1444
 #, fuzzy, no-c-format
 msgid ""
 "If you do not specify a type, Hibernate will use reflection upon the named "
@@ -2788,7 +2232,6 @@
 "이를 구별하기 위해, 또는 맞춤 타입을 지정하기 위해.)"
 
 #. Tag: para
-#: basic_mapping.xml:1454
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>access</literal> attribute allows you to control how Hibernate "
@@ -2808,7 +2251,6 @@
 "티 접근을 위한 당신 자신의 방도를 지정할 수도 있다."
 
 #. Tag: para
-#: basic_mapping.xml:1463
 #, fuzzy, no-c-format
 msgid ""
 "A powerful feature is derived properties. These properties are by definition "
@@ -2821,21 +2263,7 @@
 "선언하고, 이것은 인스턴스를 로드시키는 SQL 질의 내의 <literal>SELECT</"
 "literal> 절 서브질의로 번역된다:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1470
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"<property name=\"totalPrice\"\n"
-"    formula=\"( SELECT SUM (li.quantity*p.price) FROM LineItem li, Product "
-"p\n"
-"                WHERE li.productId = p.productId\n"
-"                AND li.customerId = customerId\n"
-"                AND li.orderNumber = orderNumber )\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1472
 #, fuzzy, no-c-format
 msgid ""
 "You can reference the entity table by not declaring an alias on a particular "
@@ -2849,13 +2277,11 @@
 "<literal>&lt;formula&gt;</literal> 매핑 요소를 사용할 수 있음을 노트하라."
 
 #. Tag: title
-#: basic_mapping.xml:1482
 #, fuzzy, no-c-format
 msgid "Many-to-one"
 msgstr "many-to-one"
 
 #. Tag: para
-#: basic_mapping.xml:1484
 #, fuzzy, no-c-format
 msgid ""
 "An ordinary association to another persistent class is declared using a "
@@ -2868,43 +2294,12 @@
 "블 내에 있는 foreign 키는 대상 테이블의 프라이머리 키 컬럼(들)을 참조하고 있"
 "다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1512
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one\n"
-"        name=\"propertyName\"\n"
-"        column=\"column_name\"\n"
-"        class=\"ClassName\"\n"
-"        cascade=\"cascade_style\"\n"
-"        fetch=\"join|select\"\n"
-"        update=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unique=\"true|false\"\n"
-"        not-null=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        lazy=\"proxy|no-proxy|false\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        formula=\"arbitrary SQL expression\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        embed-xml=\"true|false\"\n"
-"        index=\"index_name\"\n"
-"        unique_key=\"unique_key_id\"\n"
-"        foreign-key=\"foreign_key_name\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1515 basic_mapping.xml:1696 basic_mapping.xml:1882
 #, fuzzy, no-c-format
 msgid "<literal>name</literal>: the name of the property."
 msgstr "<literal>name</literal>: 프로퍼티의 이름."
 
 #. Tag: para
-#: basic_mapping.xml:1520 basic_mapping.xml:2311
 #, fuzzy, no-c-format
 msgid ""
 "<literal>column</literal> (optional): the name of the foreign key column. "
@@ -2919,7 +2314,6 @@
 "된 <literal>&lt;column&gt;</literal> 요소(들)에 의해 지정될 수 있다."
 
 #. Tag: para
-#: basic_mapping.xml:1527 basic_mapping.xml:1701
 #, fuzzy, no-c-format
 msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
@@ -2929,7 +2323,6 @@
 "타입): 연관된 클래스의 이름."
 
 #. Tag: para
-#: basic_mapping.xml:1533 basic_mapping.xml:1707
 #, fuzzy, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional): specifies which operations should be "
@@ -2939,7 +2332,6 @@
 "객체로 케스케이드 될 것인지를 지정한다."
 
 #. Tag: para
-#: basic_mapping.xml:1539 basic_mapping.xml:1722
 #, fuzzy, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional - defaults to <literal>select</literal>): "
@@ -2953,7 +2345,6 @@
 "join 페칭 또는 순차적인 select 페칭 중에서 선택하라."
 
 #. Tag: para
-#: basic_mapping.xml:1545
 #, fuzzy, no-c-format
 msgid ""
 "<literal>update, insert</literal> (optional - defaults to <literal>true</"
@@ -2971,7 +2362,6 @@
 "연관관계 값을 허용한다."
 
 #. Tag: para
-#: basic_mapping.xml:1554
 #, fuzzy, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): the name of a property of the "
@@ -2983,7 +2373,6 @@
 "다."
 
 #. Tag: para
-#: basic_mapping.xml:1567
 #, fuzzy, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): enables the DDL generation of a unique "
@@ -2997,7 +2386,6 @@
 "일로 만든다."
 
 #. Tag: para
-#: basic_mapping.xml:1575
 #, fuzzy, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): enables the DDL generation of a "
@@ -3007,7 +2395,6 @@
 "스트레인트의 DDL 생성을 가능하도록 해준다."
 
 #. Tag: para
-#: basic_mapping.xml:1589
 #, fuzzy, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>proxy</literal>): "
@@ -3024,7 +2411,6 @@
 "는 그 연관이 항상 eagerly 페치될 것임을 지정한다."
 
 #. Tag: para
-#: basic_mapping.xml:1599
 #, fuzzy, no-c-format
 msgid ""
 "<literal>not-found</literal> (optional - defaults to <literal>exception</"
@@ -3038,7 +2424,6 @@
 "것이다."
 
 #. Tag: para
-#: basic_mapping.xml:1606 basic_mapping.xml:1760
 #, fuzzy, no-c-format
 msgid ""
 "<literal>entity-name</literal> (optional): the entity name of the associated "
@@ -3046,7 +2431,6 @@
 msgstr "<literal>entity-name</literal> (옵션): 연관된 클래스의 엔티티 이름."
 
 #. Tag: para
-#: basic_mapping.xml:1611
 #, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an SQL expression that defines the "
@@ -3056,7 +2440,6 @@
 "대한 값을 정의하는 SQL 표현식."
 
 #. Tag: para
-#: basic_mapping.xml:1619
 #, fuzzy, no-c-format
 msgid ""
 "Setting a value of the <literal>cascade</literal> attribute to any "
@@ -3067,7 +2450,7 @@
 "second, special values: <literal>delete-orphan</literal>; and third,"
 "<literal>all</literal> comma-separated combinations of operation names: "
 "<literal>cascade=\"persist,merge,evict\"</literal> or <literal>cascade=\"all,"
-"delete-orphan\"</literal>. See <xref linkend=\"objectstate-transitive\"/> "
+"delete-orphan\"</literal>. See <xref linkend=\"objectstate-transitive\" /> "
 "for a full explanation. Note that single valued, many-to-one and one-to-one, "
 "associations do not support orphan delete."
 msgstr ""
@@ -3083,23 +2466,13 @@
 "과 one-to-one 연관)은 orphan delete를 지원하지 않음을 노트하라."
 
 #. Tag: para
-#: basic_mapping.xml:1632
 #, fuzzy, no-c-format
 msgid ""
 "Here is an example of a typical <literal>many-to-one</literal> declaration:"
 msgstr ""
 "일반적인 <literal>many-to-one</literal> 선언은 다음과 같이 간단하게 보여진다:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1636
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"product\" class=\"Product\" column=\"PRODUCT_ID"
-"\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1638
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>property-ref</literal> attribute should only be used for "
@@ -3117,37 +2490,18 @@
 "(<literal>unique</literal> 속성은 SchemaExport 도구로 Hibernate의 DDL 생성을 "
 "제어한다.)"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1647
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"serialNumber\" unique=\"true\" type=\"string\" "
-"column=\"SERIAL_NUMBER\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1649
 #, no-c-format
 msgid "Then the mapping for <literal>OrderItem</literal> might use:"
 msgstr ""
 "그런 다음 <literal>OrderItem</literal>에 대한 매핑은 다음을 사용할 것이다:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1653
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"product\" property-ref=\"serialNumber\" column="
-"\"PRODUCT_SERIAL_NUMBER\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1655
 #, fuzzy, no-c-format
 msgid "This is not encouraged, however."
 msgstr "하지만 이것은 확실히 권장되지 않는다."
 
 #. Tag: para
-#: basic_mapping.xml:1659
 #, no-c-format
 msgid ""
 "If the referenced unique key comprises multiple properties of the associated "
@@ -3159,7 +2513,6 @@
 "매핑할 것이다."
 
 #. Tag: para
-#: basic_mapping.xml:1664
 #, fuzzy, no-c-format
 msgid ""
 "If the referenced unique key is the property of a component, you can specify "
@@ -3168,22 +2521,12 @@
 "만일 참조된 유일키가 컴포넌트의 프로퍼티일 경우, 당신은 하나의 프로퍼티 경로"
 "를 지정할 수 있다:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1668
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"owner\" property-ref=\"identity.ssn\" column="
-"\"OWNER_SSN\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:1673
 #, fuzzy, no-c-format
 msgid "One-to-one"
 msgstr "one-to-one"
 
 #. Tag: para
-#: basic_mapping.xml:1675
 #, no-c-format
 msgid ""
 "A one-to-one association to another persistent class is declared using a "
@@ -3192,29 +2535,7 @@
 "또 다른 영속 클래스에 대한 one-to-one 연관관계는 <literal>one-to-one</"
 "literal> 요소를 사용하여 선언된다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1693
-#, no-c-format
-msgid ""
-"<![CDATA[<one-to-one\n"
-"        name=\"propertyName\"\n"
-"        class=\"ClassName\"\n"
-"        cascade=\"cascade_style\"\n"
-"        constrained=\"true|false\"\n"
-"        fetch=\"join|select\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        formula=\"any SQL expression\"\n"
-"        lazy=\"proxy|no-proxy|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        embed-xml=\"true|false\"\n"
-"        foreign-key=\"foreign_key_name\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1713
 #, fuzzy, no-c-format
 msgid ""
 "<literal>constrained</literal> (optional): specifies that a foreign key "
@@ -3231,7 +2552,6 @@
 "(또한 스키마 내보내기 도구에 의해 사용된다)."
 
 #. Tag: para
-#: basic_mapping.xml:1728
 #, fuzzy, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): the name of a property of the "
@@ -3243,7 +2563,6 @@
 "리 키가 사용된다."
 
 #. Tag: para
-#: basic_mapping.xml:1741
 #, fuzzy, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): almost all one-to-one associations "
@@ -3259,7 +2578,6 @@
 "라.)"
 
 #. Tag: para
-#: basic_mapping.xml:1749
 #, fuzzy, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>proxy</literal>): "
@@ -3280,25 +2598,21 @@
 "eager 페치시킬 것이다!</emphasis>"
 
 #. Tag: para
-#: basic_mapping.xml:1767
 #, fuzzy, no-c-format
 msgid "There are two varieties of one-to-one associations:"
 msgstr "one-to-one 연관관계에는 두 가지 변종이 존재한다:"
 
 #. Tag: para
-#: basic_mapping.xml:1771
 #, no-c-format
 msgid "primary key associations"
 msgstr "프라이머리 키 연관관계들"
 
 #. Tag: para
-#: basic_mapping.xml:1774
 #, no-c-format
 msgid "unique foreign key associations"
 msgstr "유일 foreign 키 연관관계들"
 
 #. Tag: para
-#: basic_mapping.xml:1779
 #, fuzzy, no-c-format
 msgid ""
 "Primary key associations do not need an extra table column. If two rows are "
@@ -3313,7 +2627,6 @@
 "야 한다!"
 
 #. Tag: para
-#: basic_mapping.xml:1786
 #, fuzzy, no-c-format
 msgid ""
 "For a primary key association, add the following mappings to "
@@ -3322,22 +2635,7 @@
 "프라이머리 키 연관에 대해, 다음 매핑들을 <literal>Employee</literal>와 "
 "<literal>Person</literal> 각각에 추가하라."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1791
-#, no-c-format
-msgid "<![CDATA[<one-to-one name=\"person\" class=\"Person\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:1792
-#, no-c-format
-msgid ""
-"<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" constrained=\"true"
-"\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1794
 #, fuzzy, no-c-format
 msgid ""
 "Ensure that the primary keys of the related rows in the PERSON and EMPLOYEE "
@@ -3348,25 +2646,7 @@
 "이 동일함을 확실히 해야 한다! 우리는 <literal>foreign</literal>로 명명되는 특"
 "별한 Hibernate 식별자 생성 방도를 사용한다:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1800
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"person\" table=\"PERSON\">\n"
-"    <id name=\"id\" column=\"PERSON_ID\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">employee</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    ...\n"
-"    <one-to-one name=\"employee\"\n"
-"        class=\"Employee\"\n"
-"        constrained=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1802
 #, fuzzy, no-c-format
 msgid ""
 "A newly saved instance of <literal>Person</literal> is assigned the same "
@@ -3378,7 +2658,6 @@
 "된 <literal>Employee</literal> 인스턴스와 동일한 프라이머리 키를 할당받는다."
 
 #. Tag: para
-#: basic_mapping.xml:1808
 #, fuzzy, no-c-format
 msgid ""
 "Alternatively, a foreign key with a unique constraint, from "
@@ -3388,16 +2667,7 @@
 "달리, <literal>Employee</literal>로부터 <literal>Person</literal>으로의 유일 "
 "컨스트레인트를 가진 하나의 foreign key는 다음과 같이 표현될 수 있다:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1813
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"person\" class=\"Person\" column=\"PERSON_ID\" "
-"unique=\"true\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1815
 #, fuzzy, no-c-format
 msgid ""
 "This association can be made bidirectional by adding the following to the "
@@ -3406,33 +2676,12 @@
 "그리고 이 연관은 다음을 <literal>Person</literal> 매핑에 추가함으로써 양방향"
 "이 될 수 있다:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1820
-#, no-c-format
-msgid ""
-"<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" property-ref="
-"\"person\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:1825
 #, fuzzy, no-c-format
 msgid "Natural-id"
 msgstr "natural-id"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1827
-#, no-c-format
-msgid ""
-"<![CDATA[<natural-id mutable=\"true|false\"/>\n"
-"        <property ... />\n"
-"        <many-to-one ... />\n"
-"        ......\n"
-"</natural-id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1829
 #, fuzzy, no-c-format
 msgid ""
 "Although we recommend the use of surrogate keys as primary keys, you should "
@@ -3452,7 +2701,6 @@
 "핑은 보다 자가 설명적이게 될 것이다."
 
 #. Tag: para
-#: basic_mapping.xml:1838
 #, fuzzy, no-c-format
 msgid ""
 "It is recommended that you implement <literal>equals()</literal> and "
@@ -3464,7 +2712,6 @@
 "력하게 권장한다."
 
 #. Tag: para
-#: basic_mapping.xml:1843
 #, fuzzy, no-c-format
 msgid ""
 "This mapping is not intended for use with entities that have natural primary "
@@ -3474,7 +2721,6 @@
 "아니다."
 
 #. Tag: para
-#: basic_mapping.xml:1849
 #, fuzzy, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>false</"
@@ -3485,13 +2731,11 @@
 "로, narutal 식별자 프로퍼티들은 변경될 수 없는 것(상수)으로 가정된다."
 
 #. Tag: title
-#: basic_mapping.xml:1859
 #, fuzzy, no-c-format
 msgid "Component and dynamic-component"
 msgstr "component, dynamic-component"
 
 #. Tag: para
-#: basic_mapping.xml:1861
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element maps properties of a child "
@@ -3503,30 +2747,7 @@
 "래스에 대한 테이블의 컬럼들로 매핑시킨다. 컴포넌트들은 그것들 자신의 프로퍼티"
 "들, 컴포넌트들, 또는 콜렉션들을 선언한다. 이래 \"컴포넌트들\"을 보라."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1879
-#, no-c-format
-msgid ""
-"<![CDATA[<component\n"
-"        name=\"propertyName\"\n"
-"        class=\"className\"\n"
-"        insert=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        lazy=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        node=\"element-name|.\"\n"
-">\n"
-"\n"
-"        <property ...../>\n"
-"        <many-to-one .... />\n"
-"        ........\n"
-"</component>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1887
 #, fuzzy, no-c-format
 msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
@@ -3536,7 +2757,6 @@
 "타입): 컴포넌트(자식) 클래스의 이름."
 
 #. Tag: para
-#: basic_mapping.xml:1893 basic_mapping.xml:1982
 #, fuzzy, no-c-format
 msgid ""
 "<literal>insert</literal>: do the mapped columns appear in SQL "
@@ -3550,7 +2770,6 @@
 "에 나타날 것인가?"
 
 #. Tag: para
-#: basic_mapping.xml:1899 basic_mapping.xml:1988
 #, fuzzy, no-c-format
 msgid ""
 "<literal>update</literal>: do the mapped columns appear in SQL "
@@ -3564,7 +2783,6 @@
 "에 나타날 것인가?"
 
 #. Tag: para
-#: basic_mapping.xml:1911
 #, fuzzy, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>false</literal>): "
@@ -3576,7 +2794,6 @@
 "부를 지정한다 (빌드 시 바이트코드 수단을 필요로 한다)."
 
 #. Tag: para
-#: basic_mapping.xml:1918
 #, fuzzy, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
@@ -3590,7 +2807,6 @@
 "발생할 것인지 여부를 결정한다."
 
 #. Tag: para
-#: basic_mapping.xml:1926 basic_mapping.xml:2002
 #, fuzzy, no-c-format
 msgid ""
 "<literal>unique</literal> (optional - defaults to <literal>false</literal>): "
@@ -3601,7 +2817,6 @@
 "스트레인트가 컴포넌트의 모든 매핑된 컬럼들에 대해 존재하는지 여부를 지정한다."
 
 #. Tag: para
-#: basic_mapping.xml:1935
 #, no-c-format
 msgid ""
 "The child <literal>&lt;property&gt;</literal> tags map properties of the "
@@ -3611,7 +2826,6 @@
 "테이블 컬럼들로 매핑시킨다."
 
 #. Tag: para
-#: basic_mapping.xml:1940
 #, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element allows a <literal>&lt;"
@@ -3623,12 +2837,11 @@
 "요소를 허용한다."
 
 #. Tag: para
-#: basic_mapping.xml:1946
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>&lt;dynamic-component&gt;</literal> element allows a "
 "<literal>Map</literal> to be mapped as a component, where the property names "
-"refer to keys of the map. See <xref linkend=\"components-dynamic\"/> for "
+"refer to keys of the map. See <xref linkend=\"components-dynamic\" /> for "
 "more information."
 msgstr ""
 "<literal>&lt;dynamic-component&gt;</literal> 요소는 컴포넌트로서 매핑될"
@@ -3636,13 +2849,11 @@
 "한다. <xref linkend=\"components-dynamic\"/>을 보라."
 
 #. Tag: title
-#: basic_mapping.xml:1955
 #, fuzzy, no-c-format
 msgid "Properties"
 msgstr "properties"
 
 #. Tag: para
-#: basic_mapping.xml:1957
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>&lt;properties&gt;</literal> element allows the definition of a "
@@ -3657,26 +2868,7 @@
 "준다는 점이다. 또한 그것은 다중 컬럼 유일 컨스트레인느를 정의하는 편리한 방법"
 "이다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1973
-#, no-c-format
-msgid ""
-"<![CDATA[<properties\n"
-"        name=\"logicalName\"\n"
-"        insert=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-">\n"
-"\n"
-"        <property ...../>\n"
-"        <many-to-one .... />\n"
-"        ........\n"
-"</properties>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1976
 #, fuzzy, no-c-format
 msgid ""
 "<literal>name</literal>: the logical name of the grouping. It is "
@@ -3686,7 +2878,6 @@
 "<emphasis>아니다</emphasis>."
 
 #. Tag: para
-#: basic_mapping.xml:1994
 #, fuzzy, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
@@ -3700,7 +2891,6 @@
 "생할 것인지 여부를 결정한다."
 
 #. Tag: para
-#: basic_mapping.xml:2011
 #, no-c-format
 msgid ""
 "For example, if we have the following <literal>&lt;properties&gt;</literal> "
@@ -3709,25 +2899,7 @@
 "예를 들어, 만일 우리가 다음 <literal>&lt;properties&gt;</literal> 매핑을 가"
 "질 경우:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2015
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"personNumber\"/>\n"
-"\n"
-"    ...\n"
-"    <properties name=\"name\"\n"
-"            unique=\"true\" update=\"false\">\n"
-"        <property name=\"firstName\"/>\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"lastName\"/>\n"
-"    </properties>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2017
 #, fuzzy, no-c-format
 msgid ""
 "You might have some legacy data association that refers to this unique key "
@@ -3736,20 +2908,7 @@
 "그 때 우리는 프라이머리 키가 아닌, <literal>Person</literal> 테이블의 이 유"
 "일 키를 참조하는 어떤 리거시 데이터 연관을 가질 수 있다:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2022
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"person\"\n"
-"         class=\"Person\" property-ref=\"name\">\n"
-"    <column name=\"firstName\"/>\n"
-"    <column name=\"initial\"/>\n"
-"    <column name=\"lastName\"/>\n"
-"</many-to-one>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2024
 #, fuzzy, no-c-format
 msgid ""
 "The use of this outside the context of mapping legacy data is not "
@@ -3759,13 +2918,11 @@
 "는 것을 권장하지 않는다."
 
 #. Tag: title
-#: basic_mapping.xml:2032
 #, fuzzy, no-c-format
 msgid "Subclass"
 msgstr "subclass"
 
 #. Tag: para
-#: basic_mapping.xml:2034
 #, fuzzy, no-c-format
 msgid ""
 "Polymorphic persistence requires the declaration of each subclass of the "
@@ -3776,28 +2933,7 @@
 "필요로 한다.(권장되는) table-per-class-hierarchy(테이블 당 클래스 계층구조) "
 "매핑 방도의 경우, <literal>&lt;subclass&gt;</literal> 선언이 사용된다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2047
-#, no-c-format
-msgid ""
-"<![CDATA[<subclass\n"
-"        name=\"ClassName\"\n"
-"        discriminator-value=\"discriminator_value\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\"\n"
-"        extends=\"SuperclassName\">\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</subclass>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2050 basic_mapping.xml:2108 basic_mapping.xml:2171
 #, fuzzy, no-c-format
 msgid ""
 "<literal>name</literal>: the fully qualified class name of the subclass."
@@ -3810,7 +2946,6 @@
 "<literal>name</literal>: 서브클래스의 전체 수식어가 붙은 클래스 명."
 
 #. Tag: para
-#: basic_mapping.xml:2055
 #, fuzzy, no-c-format
 msgid ""
 "<literal>discriminator-value</literal> (optional - defaults to the class "
@@ -3820,7 +2955,6 @@
 "서브클래스들을 구분짓는 값."
 
 #. Tag: para
-#: basic_mapping.xml:2061
 #, fuzzy, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies a class or interface used for "
@@ -3837,7 +2971,6 @@
 "스 또는 인터페이스를 지정한다."
 
 #. Tag: para
-#: basic_mapping.xml:2067
 #, fuzzy, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>true</literal>): "
@@ -3855,7 +2988,6 @@
 "<literal>lazy=\"false\"</literal> 설정은 lazy 페칭을 사용불가능하게 만든다."
 
 #. Tag: para
-#: basic_mapping.xml:2075
 #, fuzzy, no-c-format
 msgid ""
 "Each subclass declares its own persistent properties and subclasses. "
@@ -3871,21 +3003,18 @@
 "다. none이 지정될 경우, 전체 수식어가 붙은 자바 클래스 이름이 사용된다."
 
 #. Tag: para
-#: basic_mapping.xml:2083 basic_mapping.xml:2141 basic_mapping.xml:2199
 #, fuzzy, no-c-format
 msgid ""
-"For information about inheritance mappings see <xref linkend=\"inheritance\"/"
-">."
+"For information about inheritance mappings see <xref linkend=\"inheritance"
+"\" />."
 msgstr "상속 매핑들에 대한 정보는 <xref linkend=\"inheritance\"/>을 보라."
 
 #. Tag: title
-#: basic_mapping.xml:2090
 #, fuzzy, no-c-format
 msgid "Joined-subclass"
 msgstr "joined-subclass"
 
 #. Tag: para
-#: basic_mapping.xml:2092
 #, fuzzy, no-c-format
 msgid ""
 "Each subclass can also be mapped to its own table. This is called the table-"
@@ -3897,40 +3026,12 @@
 "per-subclass 매핑 방도). 상속된 상태는 슈퍼클래스의 테이블과 조인함으로써 검"
 "색된다. 우리는 <literal>&lt;joined-subclass&gt;</literal> 요소를 사용한다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2105
-#, no-c-format
-msgid ""
-"<![CDATA[<joined-subclass\n"
-"        name=\"ClassName\"\n"
-"        table=\"tablename\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        schema=\"schema\"\n"
-"        catalog=\"catalog\"\n"
-"        extends=\"SuperclassName\"\n"
-"        persister=\"ClassName\"\n"
-"        subselect=\"SQL expression\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\">\n"
-"\n"
-"        <key .... >\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</joined-subclass>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2113 basic_mapping.xml:2176
 #, fuzzy, no-c-format
 msgid "<literal>table</literal>: the name of the subclass table."
 msgstr "<literal>table</literal>: 서브클래스 테이블의 이름."
 
 #. Tag: para
-#: basic_mapping.xml:2118 basic_mapping.xml:2181
 #, fuzzy, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies a class or interface to use "
@@ -3947,7 +3048,6 @@
 "스 또는 인터페이스를 지정한다."
 
 #. Tag: para
-#: basic_mapping.xml:2124 basic_mapping.xml:2187
 #, fuzzy, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional, defaults to <literal>true</literal>): "
@@ -3965,7 +3065,6 @@
 "<literal>lazy=\"false\"</literal> 설정은 lazy 페칭을 사용불가능하게 만든다."
 
 #. Tag: para
-#: basic_mapping.xml:2132
 #, fuzzy, no-c-format
 msgid ""
 "A discriminator column is not required for this mapping strategy. Each "
@@ -3978,52 +3077,12 @@
 "는 테이블 컬럼을 선언해야 한다. 이 장의 시작 부분에 있는 매핑은 다음과 같이 "
 "다시 작성될 것이다:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2139
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"        <class name=\"Cat\" table=\"CATS\">\n"
-"                <id name=\"id\" column=\"uid\" type=\"long\">\n"
-"                        <generator class=\"hilo\"/>\n"
-"                </id>\n"
-"                <property name=\"birthdate\" type=\"date\"/>\n"
-"                <property name=\"color\" not-null=\"true\"/>\n"
-"                <property name=\"sex\" not-null=\"true\"/>\n"
-"                <property name=\"weight\"/>\n"
-"                <many-to-one name=\"mate\"/>\n"
-"                <set name=\"kittens\">\n"
-"                        <key column=\"MOTHER\"/>\n"
-"                        <one-to-many class=\"Cat\"/>\n"
-"                </set>\n"
-"                <joined-subclass name=\"DomesticCat\" table=\"DOMESTIC_CATS"
-"\">\n"
-"                    <key column=\"CAT\"/>\n"
-"                    <property name=\"name\" type=\"string\"/>\n"
-"                </joined-subclass>\n"
-"        </class>\n"
-"\n"
-"        <class name=\"eg.Dog\">\n"
-"                <!-- mapping for Dog could go here -->\n"
-"        </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:2148
 #, fuzzy, no-c-format
 msgid "Union-subclass"
 msgstr "union-subclass"
 
 #. Tag: para
-#: basic_mapping.xml:2150
 #, fuzzy, no-c-format
 msgid ""
 "A third option is to map only the concrete classes of an inheritance "
@@ -4045,46 +3104,18 @@
 "관)을 사용하고자 원할 경우, 당신은 <literal>&lt;union-subclass&gt;</literal> "
 "매핑을 사용할 필요가 있다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2168
-#, no-c-format
-msgid ""
-"<![CDATA[<union-subclass\n"
-"        name=\"ClassName\"\n"
-"        table=\"tablename\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        schema=\"schema\"\n"
-"        catalog=\"catalog\"\n"
-"        extends=\"SuperclassName\"\n"
-"        abstract=\"true|false\"\n"
-"        persister=\"ClassName\"\n"
-"        subselect=\"SQL expression\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\">\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</union-subclass>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2195
 #, no-c-format
 msgid ""
 "No discriminator column or key column is required for this mapping strategy."
 msgstr "이 매핑 방도에는 판별자 컬럼이나 키 컬럼이 필요하지 않다."
 
 #. Tag: title
-#: basic_mapping.xml:2206
 #, fuzzy, no-c-format
 msgid "Join"
 msgstr "join"
 
 #. Tag: para
-#: basic_mapping.xml:2208
 #, fuzzy, no-c-format
 msgid ""
 "Using the <literal>&lt;join&gt;</literal> element, it is possible to map "
@@ -4095,33 +3126,12 @@
 "존재할 때, 하나의 클래스에 속한 프로퍼티들을 여러 테이블들로 매핑시키는 것이 "
 "가능하다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2222
-#, no-c-format
-msgid ""
-"<![CDATA[<join\n"
-"        table=\"tablename\"\n"
-"        schema=\"owner\"\n"
-"        catalog=\"catalog\"\n"
-"        fetch=\"join|select\"\n"
-"        inverse=\"true|false\"\n"
-"        optional=\"true|false\">\n"
-"\n"
-"        <key ... />\n"
-"\n"
-"        <property ... />\n"
-"        ...\n"
-"</join>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2226
 #, fuzzy, no-c-format
 msgid "<literal>table</literal>: the name of the joined table."
 msgstr "<literal>table</literal>: 조인된 테이블의 이름."
 
 #. Tag: para
-#: basic_mapping.xml:2243
 #, fuzzy, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional - defaults to <literal>join</literal>): "
@@ -4146,7 +3156,6 @@
 "<literal>&lt;join&gt;</literal>을 검색하는데 사용될 것이다."
 
 #. Tag: para
-#: basic_mapping.xml:2256
 #, fuzzy, no-c-format
 msgid ""
 "<literal>inverse</literal> (optional - defaults to <literal>false</"
@@ -4158,7 +3167,6 @@
 "이트하려고 시도하지 않을 것이다."
 
 #. Tag: para
-#: basic_mapping.xml:2263
 #, fuzzy, no-c-format
 msgid ""
 "<literal>optional</literal> (optional - defaults to <literal>false</"
@@ -4172,7 +3180,6 @@
 "용할 것이다."
 
 #. Tag: para
-#: basic_mapping.xml:2272
 #, fuzzy, no-c-format
 msgid ""
 "For example, address information for a person can be mapped to a separate "
@@ -4181,26 +3188,7 @@
 "예를 들어, (모든 프로퍼티들에 대해 value 타입 의미를 유지하면서) 개인의 주소 "
 "정보는 별도의 테이블에 매핑될 수 있다:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2277
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\"\n"
-"    table=\"PERSON\">\n"
-"\n"
-"    <id name=\"id\" column=\"PERSON_ID\">...</id>\n"
-"\n"
-"    <join table=\"ADDRESS\">\n"
-"        <key column=\"ADDRESS_ID\"/>\n"
-"        <property name=\"address\"/>\n"
-"        <property name=\"zip\"/>\n"
-"        <property name=\"country\"/>\n"
-"    </join>\n"
-"    ...]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2279
 #, fuzzy, no-c-format
 msgid ""
 "This feature is often only useful for legacy data models. We recommend fewer "
@@ -4214,13 +3202,11 @@
 "는 것에 유용하다."
 
 #. Tag: title
-#: basic_mapping.xml:2289
-#, no-c-format
-msgid "<title>Key</title>"
-msgstr ""
+#, fuzzy, no-c-format
+msgid "Key"
+msgstr "key"
 
 #. Tag: para
-#: basic_mapping.xml:2291
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>&lt;key&gt;</literal> element has featured a few times within "
@@ -4233,22 +3219,7 @@
 "타나고, 그것은 조인된 테이블의 foreign 키를 정의하고, 그것은 원래의 테이블의 "
 "프라이머리 키를 참조한다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2307
-#, no-c-format
-msgid ""
-"<![CDATA[<key\n"
-"        column=\"columnname\"\n"
-"        on-delete=\"noaction|cascade\"\n"
-"        property-ref=\"propertyName\"\n"
-"        not-null=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2318
 #, fuzzy, no-c-format
 msgid ""
 "<literal>on-delete</literal> (optional - defaults to <literal>noaction</"
@@ -4260,7 +3231,6 @@
 "록 할 것인지 여부를 지정한다."
 
 #. Tag: para
-#: basic_mapping.xml:2325
 #, fuzzy, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): specifies that the foreign key "
@@ -4271,7 +3241,6 @@
 "머리 키가 아닌 컬럼들을 참조함을 지정한다. (리거시 데이터에 제공됨.)"
 
 #. Tag: para
-#: basic_mapping.xml:2332
 #, fuzzy, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): specifies that the foreign key "
@@ -4282,7 +3251,6 @@
 "다(이것은 foreign 키가 또한 프라이머리 키의 부분일 때마다 함축된다)."
 
 #. Tag: para
-#: basic_mapping.xml:2339
 #, fuzzy, no-c-format
 msgid ""
 "<literal>update</literal> (optional): specifies that the foreign key should "
@@ -4293,7 +3261,6 @@
 "지정한다(이것은 foreign 키가 또한 프라이머리 키의 부분일 때마다 함축된다)."
 
 #. Tag: para
-#: basic_mapping.xml:2346
 #, fuzzy, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): specifies that the foreign key should "
@@ -4305,7 +3272,6 @@
 "다)."
 
 #. Tag: para
-#: basic_mapping.xml:2354
 #, fuzzy, no-c-format
 msgid ""
 "For systems where delete performance is important, we recommend that all "
@@ -4323,7 +3289,6 @@
 "있어라."
 
 #. Tag: para
-#: basic_mapping.xml:2362
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>not-null</literal> and <literal>update</literal> attributes are "
@@ -4339,13 +3304,11 @@
 "emphasis>."
 
 #. Tag: title
-#: basic_mapping.xml:2372
 #, fuzzy, no-c-format
 msgid "Column and formula elements"
 msgstr "column 요소와 formula 요소"
 
 #. Tag: para
-#: basic_mapping.xml:2373
 #, fuzzy, no-c-format
 msgid ""
 "Mapping elements which accept a <literal>column</literal> attribute will "
@@ -4357,61 +3320,34 @@
 "column&gt;</literal> 서브요소를 수용할 것이다. 비슷하게 <literal>&lt;"
 "formula&gt;</literal>는 <literal>formula</literal> 속성에 대한 대안이다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2379
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<column\n"
-"        name=\"column_name\"\n"
-"        length=\"N\"\n"
-"        precision=\"N\"\n"
-"        scale=\"N\"\n"
-"        not-null=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        unique-key=\"multicolumn_unique_key_name\"\n"
-"        index=\"index_name\"\n"
-"        sql-type=\"sql_type_name\"\n"
-"        check=\"SQL expression\"\n"
-"        default=\"SQL expression\"/>]]>"
+"Most of the attributes on <literal>column</literal> provide a means of "
+"tailoring the DDL during automatic schema generation. The <literal>read</"
+"literal> and <literal>write</literal> attributes allow you to specify custom "
+"SQL that Hibernate will use to access the column's value. For more on this, "
+"see the discussion of <link linkend=\"mapping-column-read-and-write\">column "
+"read and write expressions</link>."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2381
-#, no-c-format
-msgid "<![CDATA[<formula>SQL expression</formula>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2383
 #, fuzzy, no-c-format
 msgid ""
-"<literal>column</literal> and <literal>formula</literal> attributes can even "
-"be combined within the same property or association mapping to express, for "
-"example, exotic join conditions."
+"The <literal>column</literal> and <literal>formula</literal> elements can "
+"even be combined within the same property or association mapping to express, "
+"for example, exotic join conditions."
 msgstr ""
 "<literal>column</literal> 속성과 <literal>formula</literal> 속성은 예를 들어 "
 "신종 조인 조건들을 표현하기 위해 동일한 property 또는 연관관계 매핑 내에 결합"
 "될 수 있다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2389
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"homeAddress\" class=\"Address\"\n"
-"        insert=\"false\" update=\"false\">\n"
-"    <column name=\"person_id\" not-null=\"true\" length=\"10\"/>\n"
-"    <formula>'MAILING'</formula>\n"
-"</many-to-one>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:2394
 #, fuzzy, no-c-format
 msgid "Import"
 msgstr "import"
 
 #. Tag: para
-#: basic_mapping.xml:2396
 #, fuzzy, no-c-format
 msgid ""
 "If your application has two persistent classes with the same name, and you "
@@ -4426,24 +3362,7 @@
 "의존하기 보다 명시적으로 \"임포트 될 \" 것이다. 당신은 심지어 명시적으로 매핑"
 "되지 않는 클래스들과 인터페이스들을 임포트 시킬 수(가져오기 할 수) 있다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2403
-#, no-c-format
-msgid "<![CDATA[<import class=\"java.lang.Object\" rename=\"Universe\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2410
-#, no-c-format
-msgid ""
-"<![CDATA[<import\n"
-"        class=\"ClassName\"\n"
-"        rename=\"ShortName\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2413
 #, fuzzy, no-c-format
 msgid ""
 "<literal>class</literal>: the fully qualified class name of any Java class."
@@ -4452,7 +3371,6 @@
 "름."
 
 #. Tag: para
-#: basic_mapping.xml:2418
 #, fuzzy, no-c-format
 msgid ""
 "<literal>rename</literal> (optional - defaults to the unqualified class "
@@ -4462,13 +3380,11 @@
 "질의 언어 내에서 사용될 이름."
 
 #. Tag: title
-#: basic_mapping.xml:2429
-#, no-c-format
-msgid "<title>Any</title>"
-msgstr ""
+#, fuzzy, no-c-format
+msgid "Any"
+msgstr "any"
 
 #. Tag: para
-#: basic_mapping.xml:2431
 #, fuzzy, no-c-format
 msgid ""
 "There is one more type of property mapping. The <literal>&lt;any&gt;</"
@@ -4490,7 +3406,6 @@
 "에서만 이것을 사용해야 한다."
 
 #. Tag: para
-#: basic_mapping.xml:2441
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>meta-type</literal> attribute allows the application to specify "
@@ -4504,54 +3419,17 @@
 "을 가진 영속 클래스들로 매핑시키는 맞춤형 타입을 지정하도록 한다. 당신은 "
 "meta-type의 값들로부터 클래스 이름들로의 매핑을 지정해야 한다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2448
-#, no-c-format
-msgid ""
-"<![CDATA[<any name=\"being\" id-type=\"long\" meta-type=\"string\">\n"
-"    <meta-value value=\"TBL_ANIMAL\" class=\"Animal\"/>\n"
-"    <meta-value value=\"TBL_HUMAN\" class=\"Human\"/>\n"
-"    <meta-value value=\"TBL_ALIEN\" class=\"Alien\"/>\n"
-"    <column name=\"table_name\"/>\n"
-"    <column name=\"id\"/>\n"
-"</any>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2459
-#, no-c-format
-msgid ""
-"<![CDATA[<any\n"
-"        name=\"propertyName\"\n"
-"        id-type=\"idtypename\"\n"
-"        meta-type=\"metatypename\"\n"
-"        cascade=\"cascade_style\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        optimistic-lock=\"true|false\"\n"
-">\n"
-"        <meta-value ... />\n"
-"        <meta-value ... />\n"
-"        .....\n"
-"        <column .... />\n"
-"        <column .... />\n"
-"        .....\n"
-"</any>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2462
 #, no-c-format
 msgid "<literal>name</literal>: the property name."
 msgstr "<literal>name</literal>: 프로퍼티 이름."
 
 #. Tag: para
-#: basic_mapping.xml:2467
 #, no-c-format
 msgid "<literal>id-type</literal>: the identifier type."
 msgstr "<literal>id-type</literal>: 식별자 타입."
 
 #. Tag: para
-#: basic_mapping.xml:2472
 #, fuzzy, no-c-format
 msgid ""
 "<literal>meta-type</literal> (optional - defaults to <literal>string</"
@@ -4561,7 +3439,6 @@
 "discriminator 매핑에 허용되는 임의의 타입."
 
 #. Tag: para
-#: basic_mapping.xml:2478
 #, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional- defaults to <literal>none</literal>): "
@@ -4571,7 +3448,6 @@
 "cascade 스타일."
 
 #. Tag: para
-#: basic_mapping.xml:2490
 #, fuzzy, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
@@ -4585,19 +3461,16 @@
 "할 것인지 여부를 정의한다."
 
 #. Tag: title
-#: basic_mapping.xml:2505
 #, fuzzy, no-c-format
 msgid "Hibernate types"
 msgstr "Hibernate 타입들"
 
 #. Tag: title
-#: basic_mapping.xml:2508
 #, no-c-format
 msgid "Entities and values"
 msgstr "엔티티들과 값들"
 
 #. Tag: para
-#: basic_mapping.xml:2510
 #, no-c-format
 msgid ""
 "In relation to the persistence service, Java language-level objects are "
@@ -4605,7 +3478,6 @@
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2515
 #, fuzzy, no-c-format
 msgid ""
 "An <emphasis>entity</emphasis> exists independently of any other objects "
@@ -4628,7 +3500,6 @@
 "다. 그것들 또한 버전화 될 수 있다."
 
 #. Tag: para
-#: basic_mapping.xml:2526
 #, fuzzy, no-c-format
 msgid ""
 "An entity's persistent state consists of references to other entities and "
@@ -4651,7 +3522,6 @@
 "의 엔티티들이나 콜렉션들에 의해 공유될 수 없다."
 
 #. Tag: para
-#: basic_mapping.xml:2537
 #, fuzzy, no-c-format
 msgid ""
 "Until now, we have been using the term \"persistent class\" to refer to "
@@ -4678,13 +3548,11 @@
 "composition이나 aggregation은 대개 value 타입으로 변환된다."
 
 #. Tag: para
-#: basic_mapping.xml:2551
 #, fuzzy, no-c-format
 msgid "We will revisit both concepts throughout this reference guide."
 msgstr "우리는 문서를 통해 두 개념들을 다시 고찰할 것이다."
 
 #. Tag: para
-#: basic_mapping.xml:2555
 #, fuzzy, no-c-format
 msgid ""
 "The challenge is to map the Java type system, and the developers' definition "
@@ -4710,7 +3578,6 @@
 "현할 수 있다."
 
 #. Tag: para
-#: basic_mapping.xml:2568
 #, fuzzy, no-c-format
 msgid ""
 "With the exception of collections, all built-in Hibernate types support null "
@@ -4719,13 +3586,11 @@
 "콜렉션들을 제외한 모든 미리 빌드된 Hibernate 타입들은 null 의미를 지원한다."
 
 #. Tag: title
-#: basic_mapping.xml:2575
 #, no-c-format
 msgid "Basic value types"
 msgstr "기본 value 타입들"
 
 #. Tag: para
-#: basic_mapping.xml:2577
 #, fuzzy, no-c-format
 msgid ""
 "The built-in <emphasis>basic mapping types</emphasis> can be roughly "
@@ -4734,18 +3599,16 @@
 "미리-만들어진 <emphasis>기본 매핑 타입들</emphasis>은 대략 다음과 같이 카테고"
 "리로 분류된다 <placeholder-1/>"
 
-#. Tag: literal
-#: basic_mapping.xml:2582
-#, no-c-format
+#. Tag: term
+#, fuzzy, no-c-format
 msgid ""
-"integer, long, short, float, double, character, byte, boolean, yes_no, "
-"true_false"
+"<literal>integer, long, short, float, double, character, byte, boolean, "
+"yes_no, true_false</literal>"
 msgstr ""
 "integer, long, short, float, double, character, byte, boolean, yes_no, "
 "true_false"
 
 #. Tag: para
-#: basic_mapping.xml:2585
 #, no-c-format
 msgid ""
 "Type mappings from Java primitives or wrapper classes to appropriate (vendor-"
@@ -4758,14 +3621,12 @@
 "<literal>true_false</literal>는 Java <literal>boolean</literal>이나 "
 "<literal>java.lang.Boolean</literal>에 대한 모든 대체적인 인코딩들이다."
 
-#. Tag: literal
-#: basic_mapping.xml:2594
-#, no-c-format
-msgid "string"
-msgstr "string"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>string</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:2596
 #, no-c-format
 msgid ""
 "A type mapping from <literal>java.lang.String</literal> to <literal>VARCHAR</"
@@ -4774,14 +3635,12 @@
 "<literal>java.lang.String</literal>으로부터 <literal>VARCHAR</literal> (또는 "
 "Oracle <literal>VARCHAR2</literal>)로의 타입 매핑."
 
-#. Tag: literal
-#: basic_mapping.xml:2603
-#, no-c-format
-msgid "date, time, timestamp"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>date, time, timestamp</literal>"
 msgstr "date, time, timestamp"
 
 #. Tag: para
-#: basic_mapping.xml:2605
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Date</literal> and its subclasses to "
@@ -4792,14 +3651,12 @@
 "<literal>DATE</literal>, <literal>TIME</literal>, <literal>TIMESTAMP</"
 "literal> (또는 등가물)로의 타입 매핑들."
 
-#. Tag: literal
-#: basic_mapping.xml:2613
-#, no-c-format
-msgid "calendar, calendar_date"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>calendar, calendar_date</literal>"
 msgstr "calendar, calendar_date"
 
 #. Tag: para
-#: basic_mapping.xml:2615
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Calendar</literal> to SQL types "
@@ -4808,14 +3665,12 @@
 "<literal>java.util.Calendar</literal>로부터 SQL 타입들인 <literal>TIMESTAMP</"
 "literal>, <literal>DATE</literal> (또는 등가물)로의 타입 매핑들."
 
-#. Tag: literal
-#: basic_mapping.xml:2623
-#, no-c-format
-msgid "big_decimal, big_integer"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>big_decimal, big_integer</literal>"
 msgstr "big_decimal, big_integer"
 
 #. Tag: para
-#: basic_mapping.xml:2625
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.math.BigDecimal</literal> and <literal>java."
@@ -4826,14 +3681,12 @@
 "literal>로부터 <literal>NUMERIC</literal> (또는 Oracle <literal>NUMBER</"
 "literal>)로의 타입 매핑들."
 
-#. Tag: literal
-#: basic_mapping.xml:2633
-#, no-c-format
-msgid "locale, timezone, currency"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>locale, timezone, currency</literal>"
 msgstr "locale, timezone, currency"
 
 #. Tag: para
-#: basic_mapping.xml:2635
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Locale</literal>, <literal>java.util."
@@ -4850,14 +3703,12 @@
 "매핑된다. <literal>TimeZone</literal>의 인스턴스들은 그것들의 <literal>ID</"
 "literal>로 매핑된다."
 
-#. Tag: literal
-#: basic_mapping.xml:2647
-#, no-c-format
-msgid "class"
-msgstr "class"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>class</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:2649
 #, no-c-format
 msgid ""
 "A type mapping from <literal>java.lang.Class</literal> to <literal>VARCHAR</"
@@ -4868,26 +3719,22 @@
 "Oracle <literal>VARCHAR2</literal>)로의 타입 매핑. <literal>Class</literal>"
 "는 그것의 전체 수식어가 붙은 이름으로 매핑된다."
 
-#. Tag: literal
-#: basic_mapping.xml:2657
-#, no-c-format
-msgid "binary"
-msgstr "binary"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>binary</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:2659
 #, no-c-format
 msgid "Maps byte arrays to an appropriate SQL binary type."
 msgstr "byte 배열들을 적절한 SQL binary 타입으로 매핑시킨다."
 
-#. Tag: literal
-#: basic_mapping.xml:2665
-#, no-c-format
-msgid "text"
-msgstr "text"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>text</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:2667
 #, no-c-format
 msgid ""
 "Maps long Java strings to a SQL <literal>CLOB</literal> or <literal>TEXT</"
@@ -4896,14 +3743,12 @@
 "long Java 문자열을 SQL <literal>CLOB</literal> 또는 <literal>TEXT</literal> "
 "타입으로 매핑시킨다"
 
-#. Tag: literal
-#: basic_mapping.xml:2674
-#, no-c-format
-msgid "serializable"
-msgstr "serializable"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>serializable</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:2676
 #, fuzzy, no-c-format
 msgid ""
 "Maps serializable Java types to an appropriate SQL binary type. You can also "
@@ -4914,14 +3759,12 @@
 "한 디폴트로 기본 타입이 아닌 serializable 자바 클래스 또는 인터페이스의 이름"
 "을 가진 Hibernate 타입 <literal>serializable</literal>을 나타낼 수도 있다."
 
-#. Tag: literal
-#: basic_mapping.xml:2685
-#, no-c-format
-msgid "clob, blob"
-msgstr "clob, blob"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>clob, blob</literal>"
+msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
 
 #. Tag: para
-#: basic_mapping.xml:2687
 #, fuzzy, no-c-format
 msgid ""
 "Type mappings for the JDBC classes <literal>java.sql.Clob</literal> and "
@@ -4934,18 +3777,16 @@
 "냐하면 blob 또는 clob 객체는 트랜잭션 외부에서 재사용될 수 없기 때문이다.(게"
 "다가 드라이버 지원이 비일관적이고 페치되어야 한다)"
 
-#. Tag: literal
-#: basic_mapping.xml:2697
-#, no-c-format
+#. Tag: term
+#, fuzzy, no-c-format
 msgid ""
-"imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
-"imm_serializable, imm_binary"
+"<literal>imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
+"imm_serializable, imm_binary</literal>"
 msgstr ""
 "imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
 "imm_serializable, imm_binary"
 
 #. Tag: para
-#: basic_mapping.xml:2701
 #, fuzzy, no-c-format
 msgid ""
 "Type mappings for what are considered mutable Java types. This is where "
@@ -4965,7 +3806,6 @@
 "를 그 프로퍼티에 할당해야 한다."
 
 #. Tag: para
-#: basic_mapping.xml:2716
 #, fuzzy, no-c-format
 msgid ""
 "Unique identifiers of entities and collections can be of any basic type "
@@ -4978,7 +3818,6 @@
 "어느 것일 수 있다. (Composite 식별자들이 또한 허용된다. 아래를 보라.)"
 
 #. Tag: para
-#: basic_mapping.xml:2722
 #, no-c-format
 msgid ""
 "The basic value types have corresponding <literal>Type</literal> constants "
@@ -4992,13 +3831,11 @@
 "다."
 
 #. Tag: title
-#: basic_mapping.xml:2731
 #, no-c-format
 msgid "Custom value types"
 msgstr "맞춤형 value 타입들"
 
 #. Tag: para
-#: basic_mapping.xml:2733
 #, fuzzy, no-c-format
 msgid ""
 "It is relatively easy for developers to create their own value types. For "
@@ -5022,7 +3859,6 @@
 "literal>/ <literal>setName()</literal>를 가질 수 있다."
 
 #. Tag: para
-#: basic_mapping.xml:2744
 #, fuzzy, no-c-format
 msgid ""
 "To implement a custom type, implement either <literal>org.hibernate."
@@ -5036,19 +3872,7 @@
 "수식어가 붙은 클래스명을 사용하여 프로퍼티들을 선언하라. 가능한 종류의 것들"
 "을 보려면 <literal>org.hibernate.test.DoubleStringType</literal>을 체크하라."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2752
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"twoStrings\" type=\"org.hibernate.test."
-"DoubleStringType\">\n"
-"    <column name=\"first_string\"/>\n"
-"    <column name=\"second_string\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2754
 #, no-c-format
 msgid ""
 "Notice the use of <literal>&lt;column&gt;</literal> tags to map a property "
@@ -5058,7 +3882,6 @@
 "literal> 태그의 사용을 주목하라."
 
 #. Tag: para
-#: basic_mapping.xml:2759
 #, no-c-format
 msgid ""
 "The <literal>CompositeUserType</literal>, <literal>EnhancedUserType</"
@@ -5071,7 +3894,6 @@
 "literal> 인터페이스들은 더 많은 특화된 사용들을 위한 지원을 제공한다."
 
 #. Tag: para
-#: basic_mapping.xml:2765
 #, fuzzy, no-c-format
 msgid ""
 "You can even supply parameters to a <literal>UserType</literal> in the "
@@ -5086,19 +3908,7 @@
 "해야 한다. 당신의 맞춤형 타입에 파라미터들을 제공하기 위해, 당신은 당신의 매"
 "핑 파일들 속에 <literal>&lt;type&gt;</literal> 요소를 사용할 수 있다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2773
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"priority\">\n"
-"    <type name=\"com.mycompany.usertypes.DefaultValueIntegerType\">\n"
-"        <param name=\"default\">0</param>\n"
-"    </type>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2775
 #, no-c-format
 msgid ""
 "The <literal>UserType</literal> can now retrieve the value for the parameter "
@@ -5110,7 +3920,6 @@
 "검색할 수 있다."
 
 #. Tag: para
-#: basic_mapping.xml:2780
 #, fuzzy, no-c-format
 msgid ""
 "If you regularly use a certain <literal>UserType</literal>, it is useful to "
@@ -5125,24 +3934,7 @@
 "고, 또한 만일 그 타입이 파라미터화 된 경우에 디폴트 파라미터 값들의 리스트를 "
 "포함할 수도 있다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2787
-#, no-c-format
-msgid ""
-"<![CDATA[<typedef class=\"com.mycompany.usertypes.DefaultValueIntegerType\" "
-"name=\"default_zero\">\n"
-"    <param name=\"default\">0</param>\n"
-"</typedef>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2789
-#, no-c-format
-msgid "<![CDATA[<property name=\"priority\" type=\"default_zero\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2791
 #, no-c-format
 msgid ""
 "It is also possible to override the parameters supplied in a typedef on a "
@@ -5152,7 +3944,6 @@
 "공된 파라미터들을 오버라이드 시키는 것이 가능하다."
 
 #. Tag: para
-#: basic_mapping.xml:2796
 #, fuzzy, no-c-format
 msgid ""
 "Even though Hibernate's rich range of built-in types and support for "
@@ -5175,13 +3966,11 @@
 "경들에 대해 장차 검증될 것이다."
 
 #. Tag: title
-#: basic_mapping.xml:2812
 #, no-c-format
 msgid "Mapping a class more than once"
 msgstr "하나의 클래스를 한 번 이상 매핑하기"
 
 #. Tag: para
-#: basic_mapping.xml:2813
 #, fuzzy, no-c-format
 msgid ""
 "It is possible to provide more than one mapping for a particular persistent "
@@ -5198,31 +3987,7 @@
 "할 때, 질의들을 작성할 때, 또는 명명된 엔티티에 대한 연관들을 매핑할 때 당신"
 "으로 하여금 엔티티 이름을 지정하도록 한다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2821
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Contract\" table=\"Contracts\"\n"
-"        entity-name=\"CurrentContract\">\n"
-"    ...\n"
-"    <set name=\"history\" inverse=\"true\"\n"
-"            order-by=\"effectiveEndDate desc\">\n"
-"        <key column=\"currentContractId\"/>\n"
-"        <one-to-many entity-name=\"HistoricalContract\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Contract\" table=\"ContractHistory\"\n"
-"        entity-name=\"HistoricalContract\">\n"
-"    ...\n"
-"    <many-to-one name=\"currentContract\"\n"
-"            column=\"currentContractId\"\n"
-"            entity-name=\"CurrentContract\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2823
 #, fuzzy, no-c-format
 msgid ""
 "Associations are now specified using <literal>entity-name</literal> instead "
@@ -5232,13 +3997,11 @@
 "을 사용하여 어떻게 지정되는지를 주목하라."
 
 #. Tag: title
-#: basic_mapping.xml:2831
 #, no-c-format
 msgid "SQL quoted identifiers"
 msgstr "SQL 인용부호 표시된 식별자들"
 
 #. Tag: para
-#: basic_mapping.xml:2832
 #, fuzzy, no-c-format
 msgid ""
 "You can force Hibernate to quote an identifier in the generated SQL by "
@@ -5253,26 +4016,12 @@
 "할 것이다(대개 이중 인용부호 이지만, SQL Server의 경우에는 모난 괄호들이고 "
 "MySQL의 경우에는 역인용부호(`))."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2839
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"LineItem\" table=\"`Line Item`\">\n"
-"    <id name=\"id\" column=\"`Item Id`\"/><generator class=\"assigned\"/></"
-"id>\n"
-"    <property name=\"itemNumber\" column=\"`Item #`\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:2845
 #, no-c-format
 msgid "Metadata alternatives"
 msgstr "Metadata 대안들"
 
 #. Tag: para
-#: basic_mapping.xml:2847
 #, fuzzy, no-c-format
 msgid ""
 "XML does not suit all users so there are some alternative ways to define O/R "
@@ -5282,13 +4031,11 @@
 "정의하는 몇몇 대안적인 방법들이 존재한다."
 
 #. Tag: title
-#: basic_mapping.xml:2852
 #, no-c-format
 msgid "Using XDoclet markup"
 msgstr "XDoclet 마크업 사용하기"
 
 #. Tag: para
-#: basic_mapping.xml:2854
 #, fuzzy, no-c-format
 msgid ""
 "Many Hibernate users prefer to embed mapping information directly in "
@@ -5303,130 +4050,17 @@
 "으로 간주되기 때문이다. 하지만 우리는 XDoclet 매핑들을 가진 <literal>Cat</"
 "literal> 클래스에 관한 다음 예제를 포함한다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2861
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"import java.util.Date;\n"
-"\n"
-"/**\n"
-" * @hibernate.class\n"
-" *  table=\"CATS\"\n"
-" */\n"
-"public class Cat {\n"
-"    private Long id; // identifier\n"
-"    private Date birthdate;\n"
-"    private Cat mother;\n"
-"    private Set kittens\n"
-"    private Color color;\n"
-"    private char sex;\n"
-"    private float weight;\n"
-"\n"
-"    /*\n"
-"     * @hibernate.id\n"
-"     *  generator-class=\"native\"\n"
-"     *  column=\"CAT_ID\"\n"
-"     */\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"    private void setId(Long id) {\n"
-"        this.id=id;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.many-to-one\n"
-"     *  column=\"PARENT_ID\"\n"
-"     */\n"
-"    public Cat getMother() {\n"
-"        return mother;\n"
-"    }\n"
-"    void setMother(Cat mother) {\n"
-"        this.mother = mother;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"BIRTH_DATE\"\n"
-"     */\n"
-"    public Date getBirthdate() {\n"
-"        return birthdate;\n"
-"    }\n"
-"    void setBirthdate(Date date) {\n"
-"        birthdate = date;\n"
-"    }\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"WEIGHT\"\n"
-"     */\n"
-"    public float getWeight() {\n"
-"        return weight;\n"
-"    }\n"
-"    void setWeight(float weight) {\n"
-"        this.weight = weight;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"COLOR\"\n"
-"     *  not-null=\"true\"\n"
-"     */\n"
-"    public Color getColor() {\n"
-"        return color;\n"
-"    }\n"
-"    void setColor(Color color) {\n"
-"        this.color = color;\n"
-"    }\n"
-"    /**\n"
-"     * @hibernate.set\n"
-"     *  inverse=\"true\"\n"
-"     *  order-by=\"BIRTH_DATE\"\n"
-"     * @hibernate.collection-key\n"
-"     *  column=\"PARENT_ID\"\n"
-"     * @hibernate.collection-one-to-many\n"
-"     */\n"
-"    public Set getKittens() {\n"
-"        return kittens;\n"
-"    }\n"
-"    void setKittens(Set kittens) {\n"
-"        this.kittens = kittens;\n"
-"    }\n"
-"    // addKitten not needed by Hibernate\n"
-"    public void addKitten(Cat kitten) {\n"
-"        kittens.add(kitten);\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"SEX\"\n"
-"     *  not-null=\"true\"\n"
-"     *  update=\"false\"\n"
-"     */\n"
-"    public char getSex() {\n"
-"        return sex;\n"
-"    }\n"
-"    void setSex(char sex) {\n"
-"        this.sex=sex;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2863
 #, fuzzy, no-c-format
 msgid "See the Hibernate website for more examples of XDoclet and Hibernate."
 msgstr "XDoclet과 ibernate에 관한 추가 예제들은 Hibernate 웹 사이트를 보라."
 
 #. Tag: title
-#: basic_mapping.xml:2870
 #, no-c-format
 msgid "Using JDK 5.0 Annotations"
 msgstr "JDK 5.0 Annotations 사용하기"
 
 #. Tag: para
-#: basic_mapping.xml:2872
 #, fuzzy, no-c-format
 msgid ""
 "JDK 5.0 introduced XDoclet-style annotations at the language level that are "
@@ -5451,41 +4085,11 @@
 "(JSR-220)과 Hibernate3 metadata 양자가 지원된다."
 
 #. Tag: para
-#: basic_mapping.xml:2883
 #, no-c-format
 msgid "This is an example of a POJO class annotated as an EJB entity bean:"
 msgstr "다음은 EJB 엔티티 빈으로서 주석이 붙은 POJO 클래스에 관한 예제이다:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2887
-#, no-c-format
-msgid ""
-"<![CDATA[@Entity(access = AccessType.FIELD)\n"
-"public class Customer implements Serializable {\n"
-"\n"
-"    @Id;\n"
-"    Long id;\n"
-"\n"
-"    String firstName;\n"
-"    String lastName;\n"
-"    Date birthday;\n"
-"\n"
-"    @Transient\n"
-"    Integer age;\n"
-"\n"
-"    @Embedded\n"
-"    private Address homeAddress;\n"
-"\n"
-"    @OneToMany(cascade=CascadeType.ALL)\n"
-"    @JoinColumn(name=\"CUSTOMER_ID\")\n"
-"    Set<Order> orders;\n"
-"\n"
-"    // Getter/setter and business methods\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2891
 #, fuzzy, no-c-format
 msgid ""
 "Support for JDK 5.0 Annotations (and JSR-220) is currently under "
@@ -5496,13 +4100,11 @@
 "완성되지 않았음을 노트하라. 상세한 것은 Hibernate Anotations를 참조하라."
 
 #. Tag: title
-#: basic_mapping.xml:2901
 #, fuzzy, no-c-format
 msgid "Generated properties"
 msgstr "산출되는 프로퍼티들"
 
 #. Tag: para
-#: basic_mapping.xml:2902
 #, fuzzy, no-c-format
 msgid ""
 "Generated properties are properties that have their values generated by the "
@@ -5522,7 +4124,6 @@
 "로 직후에 산출되는 값들을 검색하기 위해 하나의 select 명령을 내린다."
 
 #. Tag: para
-#: basic_mapping.xml:2911
 #, fuzzy, no-c-format
 msgid ""
 "Properties marked as generated must additionally be non-insertable and non-"
@@ -5539,7 +4140,6 @@
 "단순 프로퍼티들</xref> 만이 generated로 마크될 수 있다."
 
 #. Tag: para
-#: basic_mapping.xml:2918
 #, fuzzy, no-c-format
 msgid ""
 "<literal>never</literal> (the default): the given property value is not "
@@ -5549,7 +4149,6 @@
 "에 생성되지 않을 것임을 의미한다."
 
 #. Tag: para
-#: basic_mapping.xml:2922
 #, fuzzy, no-c-format
 msgid ""
 "<literal>insert</literal>: the given property value is generated on insert, "
@@ -5567,7 +4166,6 @@
 "라도, 이 옵션은 거기서 이용 불가능함을 노트하라..."
 
 #. Tag: para
-#: basic_mapping.xml:2930
 #, fuzzy, no-c-format
 msgid ""
 "<literal>always</literal>: the property value is generated both on insert "
@@ -5577,13 +4175,55 @@
 "성됨을 기술한다."
 
 #. Tag: title
-#: basic_mapping.xml:2937
+#, no-c-format
+msgid "Column read and write expressions"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Hibernate allows you to customize the SQL it uses to read and write the "
+"values of columns mapped to <link linkend=\"mapping-declaration-property"
+"\">simple properties</link>. For example, if your database provides a set of "
+"data encryption functions, you can invoke them for individual columns like "
+"this: <programlisting role=\"XML\">&lt;property name=\"creditCardNumber"
+"\"&gt; &lt;column name=\"credit_card_num\" read=\"decrypt(credit_card_num)\" "
+"write=\"encrypt(?)\"/&gt; &lt;/property&gt;</programlisting>"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Hibernate applies the custom expressions automatically whenever the property "
+"is referenced in a query. This functionality is similar to a derived-"
+"property <literal>formula</literal> with two differences:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"The property is backed by one or more columns that are exported as part of "
+"automatic schema generation."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "The property is read-write, not read-only."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"The <literal>write</literal> expression, if specified, must contain exactly "
+"one '?' placeholder for the value."
+msgstr ""
+
+#. Tag: title
 #, fuzzy, no-c-format
 msgid "Auxiliary database objects"
 msgstr "보조 데이터베이스 객체들"
 
 #. Tag: para
-#: basic_mapping.xml:2938
 #, fuzzy, no-c-format
 msgid ""
 "Auxiliary database objects allow for the CREATE and DROP of arbitrary "
@@ -5604,7 +4244,6 @@
 "을 정의하는 두 가지 모드들이 본질적으로 존재한다..."
 
 #. Tag: para
-#: basic_mapping.xml:2947
 #, fuzzy, no-c-format
 msgid ""
 "The first mode is to explicitly list the CREATE and DROP commands in the "
@@ -5613,21 +4252,7 @@
 "첫 번째 모드는 매핑 파일 바깥에서 CREATE 및 DROP 명령들을 명시적으로 나열하"
 "는 것이다:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2951
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <create>CREATE TRIGGER my_trigger ...</create>\n"
-"        <drop>DROP TRIGGER my_trigger</drop>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2952
 #, fuzzy, no-c-format
 msgid ""
 "The second mode is to supply a custom class that constructs the CREATE and "
@@ -5638,20 +4263,7 @@
 "춤 클래스를 제공하는 것이다. 이 맞춤 클래스는 <literal>org.hibernate.mapping."
 "AuxiliaryDatabaseObject</literal> 인터페이스를 구현해야 한다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2957
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <definition class=\"MyTriggerDefinition\"/>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2958
 #, fuzzy, no-c-format
 msgid ""
 "Additionally, these database objects can be optionally scoped so that they "
@@ -5660,21 +4272,77 @@
 "덧붙여 이들 데이터베이스 객체들은 어떤 dialect들이 사용될 때 그것들이 단지 적"
 "용될 수 있도록 선택적으로 변동될 수 있다."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2962
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <definition class=\"MyTriggerDefinition\"/>\n"
-"        <dialect-scope name=\"org.hibernate.dialect.Oracle9iDialect\"/>\n"
-"        <dialect-scope name=\"org.hibernate.dialect.Oracle10gDialect\"/>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
+#~ msgid "increment"
+#~ msgstr "increment"
 
+#~ msgid "identity"
+#~ msgstr "identity"
+
+#~ msgid "sequence"
+#~ msgstr "sequence"
+
+#~ msgid "hilo"
+#~ msgstr "hilo"
+
+#~ msgid "seqhilo"
+#~ msgstr "seqhilo"
+
+#~ msgid "uuid"
+#~ msgstr "uuid"
+
+#~ msgid "guid"
+#~ msgstr "guid"
+
+#~ msgid "native"
+#~ msgstr "native"
+
+#~ msgid "assigned"
+#~ msgstr "assigned"
+
+#~ msgid "select"
+#~ msgstr "select"
+
+#~ msgid "foreign"
+#~ msgstr "foreign"
+
+#~ msgid "sequence-identity"
+#~ msgstr "sequence-identity"
+
+#, fuzzy
 #~ msgid ""
+#~ "<literal>optimizer</literal> (optional - defaults to <literal>none</"
+#~ "literal>): See"
+#~ msgstr ""
+#~ "<literal>cascade</literal> (optional- defaults to <literal>none</"
+#~ "literal>): cascade 스타일."
+
+#, fuzzy
+#~ msgid ""
+#~ "<literal>optimizer</literal> (optional - defaults to <literal></"
+#~ "literal>): See"
+#~ msgstr ""
+#~ "<literal>cascade</literal> (optional- defaults to <literal>none</"
+#~ "literal>): cascade 스타일."
+
+#~ msgid "string"
+#~ msgstr "string"
+
+#~ msgid "class"
+#~ msgstr "class"
+
+#~ msgid "binary"
+#~ msgstr "binary"
+
+#~ msgid "text"
+#~ msgstr "text"
+
+#~ msgid "serializable"
+#~ msgstr "serializable"
+
+#~ msgid "clob, blob"
+#~ msgstr "clob, blob"
+
+#~ msgid ""
 #~ "<literal>type</literal> (optional): A name that indicates the Hibernate "
 #~ "type."
 #~ msgstr "<literal>type</literal> (옵션): Hibernate 타입을 나타내는 이름."
@@ -5705,31 +4373,9 @@
 #~ "영속 서비스에 관한 여러 Java 언어-레벨의 객체들을 이해하기 위해, 우리는 그"
 #~ "것들을 다음 두 개의 그룹들로 분류할 필요가 있다:"
 
-#, fuzzy
-#~ msgid "<literal>class</literal>"
-#~ msgstr "<literal>all</literal>은 모든 컬럼들을 체크한다"
-
-#~ msgid "id"
-#~ msgstr "id"
-
 #~ msgid ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal>none</"
-#~ "literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers"
-#~ "\"/>"
-#~ msgstr ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal>none</"
-#~ "literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers"
-#~ "\"/>"
-
-#~ msgid ""
 #~ "<literal>optimizer</literal> (optional, defaults to <literal/>): See "
 #~ "<xref linkend=\"mapping-declaration-id-enhanced-optimizers\"/>"
 #~ msgstr ""
 #~ "<literal>optimizer</literal> (optional, defaults to <literal/>): See "
 #~ "<xref linkend=\"mapping-declaration-id-enhanced-optimizers\"/>"
-
-#~ msgid "key"
-#~ msgstr "key"
-
-#~ msgid "any"
-#~ msgstr "any"

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/batch.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/batch.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/batch.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2010-01-12 23:26+0900\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: 2010-01-12 23:37+0900\n"
 "Last-Translator: Jongdae Kim <jdkim528 at korea.com>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,458 +11,665 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: batch.xml:29
 #, no-c-format
 msgid "Batch processing"
 msgstr "Batch 처리"
 
 #. Tag: para
-#: batch.xml:31
 #, no-c-format
-msgid "A naive approach to inserting 100,000 rows in the database using Hibernate might look like this:"
-msgstr "하이버네이트를 사용하여 데이터베이스 내에서 100,000 개의 행들을 삽입시키는 원시 접근법은 다음과 같을 수 있다:"
-
-#. Tag: programlisting
-#: batch.xml:36
-#, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"}\n"
-"tx.commit();\n"
-"session.close();]]>"
+"A naive approach to inserting 100,000 rows in the database using Hibernate "
+"might look like this:"
 msgstr ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"}\n"
-"tx.commit();\n"
-"session.close();]]>"
+"하이버네이트를 사용하여 데이터베이스 내에서 100,000 개의 행들을 삽입시키는 원"
+"시 접근법은 다음과 같을 수 있다:"
 
 #. Tag: para
-#: batch.xml:38
 #, no-c-format
-msgid "This would fall over with an <literal>OutOfMemoryException</literal> somewhere around the 50,000th row. That is because Hibernate caches all the newly inserted <literal>Customer</literal> instances in the session-level cache. In this chapter we will show you how to avoid this problem."
-msgstr "이것은 50 000번째 행 근처에서 <literal>OutOfMemoryException</literal>으로 떨어질 것이다. 그것은 하이버네이트가 모든 새로이 삽입된 <literal>Customer</literal> 인스턴스들을 session-level 캐시 내에 캐시시키기 때문이다. 이 장에서 우리는 이 문제를 회피하는 방법을 보여줄 것이다."
+msgid ""
+"This would fall over with an <literal>OutOfMemoryException</literal> "
+"somewhere around the 50,000th row. That is because Hibernate caches all the "
+"newly inserted <literal>Customer</literal> instances in the session-level "
+"cache. In this chapter we will show you how to avoid this problem."
+msgstr ""
+"이것은 50 000번째 행 근처에서 <literal>OutOfMemoryException</literal>으로 떨"
+"어질 것이다. 그것은 하이버네이트가 모든 새로이 삽입된 <literal>Customer</"
+"literal> 인스턴스들을 session-level 캐시 내에 캐시시키기 때문이다. 이 장에서 "
+"우리는 이 문제를 회피하는 방법을 보여줄 것이다."
 
 #. Tag: para
-#: batch.xml:45
 #, no-c-format
-msgid "If you are undertaking batch processing you will need to enable the use of JDBC batching. This is absolutely essential if you want to achieve optimal performance. Set the JDBC batch size to a reasonable number (10-50, for example):"
-msgstr "만일 당신이 배치 처리를 행하는 중이라면, 당신은 JDBC 배치 사용을 이용 가능하도록 할 필요가 있을 것이다. 만일 당신이 최적의 성능을 성취하고자 원한다면 이것이 절대적으로 필수적이다. JDBC 배치 사이즈를 적당한 숫자로 설정하라(예를 들면,10-50):"
+msgid ""
+"If you are undertaking batch processing you will need to enable the use of "
+"JDBC batching. This is absolutely essential if you want to achieve optimal "
+"performance. Set the JDBC batch size to a reasonable number (10-50, for "
+"example):"
+msgstr ""
+"만일 당신이 배치 처리를 행하는 중이라면, 당신은 JDBC 배치 사용을 이용 가능하"
+"도록 할 필요가 있을 것이다. 만일 당신이 최적의 성능을 성취하고자 원한다면 이"
+"것이 절대적으로 필수적이다. JDBC 배치 사이즈를 적당한 숫자로 설정하라(예를 들"
+"ë©´,10-50):"
 
-#. Tag: programlisting
-#: batch.xml:52
-#, no-c-format
-msgid "<![CDATA[hibernate.jdbc.batch_size 20]]>"
-msgstr "<![CDATA[hibernate.jdbc.batch_size 20]]>"
-
 #. Tag: para
-#: batch.xml:54
 #, no-c-format
-msgid "Hibernate disables insert batching at the JDBC level transparently if you use an <literal>identity</literal> identifier generator."
-msgstr "만일 당신이 <literal>identiy</literal> 식별자 생성자를 사용할 경우에 하이버네이트는 JDBC 레벨에서 투명하게 insert 배치작업을 사용불가능하도록 만든다."
+msgid ""
+"Hibernate disables insert batching at the JDBC level transparently if you "
+"use an <literal>identity</literal> identifier generator."
+msgstr ""
+"만일 당신이 <literal>identiy</literal> 식별자 생성자를 사용할 경우에 하이버네"
+"이트는 JDBC 레벨에서 투명하게 insert 배치작업을 사용불가능하도록 만든다."
 
 #. Tag: para
-#: batch.xml:59
 #, no-c-format
-msgid "You can also do this kind of work in a process where interaction with the second-level cache is completely disabled:"
-msgstr "당신은 또한 second-level 캐시를 가진 상호작용이 전적으로 사용불가능한 프로세스 내에서 이런 종류의 작업을 행할 수 있다:"
+msgid ""
+"You can also do this kind of work in a process where interaction with the "
+"second-level cache is completely disabled:"
+msgstr ""
+"당신은 또한 second-level 캐시를 가진 상호작용이 전적으로 사용불가능한 프로세"
+"스 내에서 이런 종류의 작업을 행할 수 있다:"
 
-#. Tag: programlisting
-#: batch.xml:64
-#, no-c-format
-msgid "<![CDATA[hibernate.cache.use_second_level_cache false]]>"
-msgstr "<![CDATA[hibernate.cache.use_second_level_cache false]]>"
-
 #. Tag: para
-#: batch.xml:66
 #, no-c-format
-msgid "However, this is not absolutely necessary, since we can explicitly set the <literal>CacheMode</literal> to disable interaction with the second-level cache."
-msgstr "하지만 이것은 절대적으로 필요하지 않다. 왜냐하면 우리는 second-level 캐시와의 상호작용을 불가능하도록 하기 위해 명시적으로 <literal>CacheMode</literal>를 설정할 수 있기 때문이다."
+msgid ""
+"However, this is not absolutely necessary, since we can explicitly set the "
+"<literal>CacheMode</literal> to disable interaction with the second-level "
+"cache."
+msgstr ""
+"하지만 이것은 절대적으로 필요하지 않다. 왜냐하면 우리는 second-level 캐시와"
+"의 상호작용을 불가능하도록 하기 위해 명시적으로 <literal>CacheMode</literal>"
+"를 설정할 수 있기 때문이다."
 
 #. Tag: title
-#: batch.xml:72
 #, no-c-format
 msgid "Batch inserts"
 msgstr "Batch inserts"
 
 #. Tag: para
-#: batch.xml:74
 #, no-c-format
-msgid "When making new objects persistent <literal>flush()</literal> and then <literal>clear()</literal> the session regularly in order to control the size of the first-level cache."
-msgstr "새로운 객체들을 영속화 시킬 때 당신은 first-level 캐시의 사이즈를 제어하기 위해 세션을 정기적으로 <literal>flush()</literal> 시키고 나서 <literal>clear()</literal> 하라."
-
-#. Tag: programlisting
-#: batch.xml:80
-#, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"    if ( i % 20 == 0 ) { //20, same as the JDBC batch size\n"
-"        //flush a batch of inserts and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
+"When making new objects persistent <literal>flush()</literal> and then "
+"<literal>clear()</literal> the session regularly in order to control the "
+"size of the first-level cache."
 msgstr ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"    if ( i % 20 == 0 ) { //20, same as the JDBC batch size\n"
-"        //flush a batch of inserts and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
+"새로운 객체들을 영속화 시킬 때 당신은 first-level 캐시의 사이즈를 제어하기 위"
+"해 세션을 정기적으로 <literal>flush()</literal> 시키고 나서 <literal>clear()"
+"</literal> 하라."
 
 #. Tag: title
-#: batch.xml:85
 #, no-c-format
 msgid "Batch updates"
 msgstr "Batch updates"
 
 #. Tag: para
-#: batch.xml:87
 #, no-c-format
-msgid "For retrieving and updating data, the same ideas apply. In addition, you need to use <literal>scroll()</literal> to take advantage of server-side cursors for queries that return many rows of data."
-msgstr "데이터 검색하고 업데이트할 때, 동일한 개념들이 적용된다. 게다가 당신은 많은 데이터 행들을 반환하는 질의들을 위한 서버-측 커서들의 장점을 취하하기 위해 <literal>scroll()</literal>을 사용할 필요가 있다."
-
-#. Tag: programlisting
-#: batch.xml:93
-#, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-"    .setCacheMode(CacheMode.IGNORE)\n"
-"    .scroll(ScrollMode.FORWARD_ONLY);\n"
-"int count=0;\n"
-"while ( customers.next() ) {\n"
-"    Customer customer = (Customer) customers.get(0);\n"
-"    customer.updateStuff(...);\n"
-"    if ( ++count % 20 == 0 ) {\n"
-"        //flush a batch of updates and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
+"For retrieving and updating data, the same ideas apply. In addition, you "
+"need to use <literal>scroll()</literal> to take advantage of server-side "
+"cursors for queries that return many rows of data."
 msgstr ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-"    .setCacheMode(CacheMode.IGNORE)\n"
-"    .scroll(ScrollMode.FORWARD_ONLY);\n"
-"int count=0;\n"
-"while ( customers.next() ) {\n"
-"    Customer customer = (Customer) customers.get(0);\n"
-"    customer.updateStuff(...);\n"
-"    if ( ++count % 20 == 0 ) {\n"
-"        //flush a batch of updates and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
+"데이터 검색하고 업데이트할 때, 동일한 개념들이 적용된다. 게다가 당신은 많은 "
+"데이터 행들을 반환하는 질의들을 위한 서버-측 커서들의 장점을 취하하기 위해 "
+"<literal>scroll()</literal>을 사용할 필요가 있다."
 
 #. Tag: title
-#: batch.xml:98
 #, no-c-format
 msgid "The StatelessSession interface"
 msgstr "StatelessSession 인터페이스"
 
 #. Tag: para
-#: batch.xml:99
 #, no-c-format
-msgid "Alternatively, Hibernate provides a command-oriented API that can be used for streaming data to and from the database in the form of detached objects. A <literal>StatelessSession</literal> has no persistence context associated with it and does not provide many of the higher-level life cycle semantics. In particular, a stateless session does not implement a first-level cache nor interact with any second-level or query cache. It does not implement transactional write-behind or automatic dirty checking. Operations performed using a stateless session never cascade to associated instances. Collections are ignored by a stateless session. Operations performed via a stateless session bypass Hibernate's event model and interceptors. Due to the lack of a first-level cache, Stateless sessions are vulnerable to data aliasing effects. A stateless session is a lower-level abstraction that is much closer to the underlying JDBC."
-msgstr "다른 방법으로 하이버네이트는 분리된(detached) 객체들의 형식으로 데이터베이스로 그리고 데이터베이스로부터 데이터를 스트리밍하는데 사용될 수 있는 명령-지향 API를 제공한다. <literal>StatelessSession</literal>은 그것과 연관된 영속 컨텍스트를 ê°–ì§€ 않고 많은 보다 높은 레벨의 생명 주기 의미를 제공하지 않는다. 특히 하나의 상태 없는 세션은 첫 번째 레벨 캐시를 구현하지 않으며 임의의 두 번째 레벨 캐시 또는 질의 캐시와 상호작용하지 않는다. 그것은 트랜잭션 상의 쓰기-이면(write-behind)의 체킹이나 자동적인 dirty 체킹을 구현하지 않는다. 상태 없는 세션을 사용하여 수행된 연산들은 ê²°ì½” 연관된 인스턴스들에 대해 케스케이드 되지 않는다. 콜렉션들은 상태 없는 세션에 의해 무시된다. 상태없는 세션을 통해 수행된 연산들은 하이ë!
 ²„네이트의 이벤트 모형과 인터셉터들을 우회한다. 첫번째-레벨의 캐시의 부재으로 인해, 상태없는 세션들은 데이터 alias 효과들에 취약하다. 상태없는 세션은 기반 JDBC에 훨씬 더 가까운 하나의 보다 낮은 레벨의 추상이다."
-
-#. Tag: programlisting
-#: batch.xml:114
-#, no-c-format
 msgid ""
-"<![CDATA[StatelessSession session = sessionFactory.openStatelessSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-"    .scroll(ScrollMode.FORWARD_ONLY);\n"
-"while ( customers.next() ) {\n"
-"    Customer customer = (Customer) customers.get(0);\n"
-"    customer.updateStuff(...);\n"
-"    session.update(customer);\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
+"Alternatively, Hibernate provides a command-oriented API that can be used "
+"for streaming data to and from the database in the form of detached objects. "
+"A <literal>StatelessSession</literal> has no persistence context associated "
+"with it and does not provide many of the higher-level life cycle semantics. "
+"In particular, a stateless session does not implement a first-level cache "
+"nor interact with any second-level or query cache. It does not implement "
+"transactional write-behind or automatic dirty checking. Operations performed "
+"using a stateless session never cascade to associated instances. Collections "
+"are ignored by a stateless session. Operations performed via a stateless "
+"session bypass Hibernate's event model and interceptors. Due to the lack of "
+"a first-level cache, Stateless sessions are vulnerable to data aliasing "
+"effects. A stateless session is a lower-level abstraction that is much "
+"closer to the underlying JDBC."
 msgstr ""
-"<![CDATA[StatelessSession session = sessionFactory.openStatelessSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-"    .scroll(ScrollMode.FORWARD_ONLY);\n"
-"while ( customers.next() ) {\n"
-"    Customer customer = (Customer) customers.get(0);\n"
-"    customer.updateStuff(...);\n"
-"    session.update(customer);\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
+"다른 방법으로 하이버네이트는 분리된(detached) 객체들의 형식으로 데이터베이스"
+"로 그리고 데이터베이스로부터 데이터를 스트리밍하는데 사용될 수 있는 명령-지"
+"향 API를 제공한다. <literal>StatelessSession</literal>은 그것과 연관된 영속 "
+"컨텍스트를 갖지 않고 많은 보다 높은 레벨의 생명 주기 의미를 제공하지 않는다. "
+"특히 하나의 상태 없는 세션은 첫 번째 레벨 캐시를 구현하지 않으며 임의의 두 번"
+"째 레벨 캐시 또는 질의 캐시와 상호작용하지 않는다. 그것은 트랜잭션 상의 쓰기-"
+"이면(write-behind)의 체킹이나 자동적인 dirty 체킹을 구현하지 않는다. 상태 없"
+"는 세션을 사용하여 수행된 연산들은 결코 연관된 인스턴스들에 대해 케스케이드 "
+"되지 않는다. 콜렉션들은 상태 없는 세션에 의해 무시된다. 상태없는 세션을 통해 "
+"수행된 연산들은 하이버네이트의 이벤트 모형과 인터셉터들을 우회한다. 첫번째-레"
+"벨의 캐시의 부재으로 인해, 상태없는 세션들은 데이터 alias 효과들에 취약하다. "
+"상태없는 세션은 기반 JDBC에 훨씬 더 가까운 하나의 보다 낮은 레벨의 추상이다."
 
 #. Tag: para
-#: batch.xml:116
 #, no-c-format
-msgid "In this code example, the <literal>Customer</literal> instances returned by the query are immediately detached. They are never associated with any persistence context."
-msgstr "이 코드 예제에서, 질의에 의해 반환된 <literal>Customer</literal> 인스턴스들은 곧바고 분리된다(detached). 그것들은 임의의 영속 컨텍스트와 결코 연관되지 않는다."
+msgid ""
+"In this code example, the <literal>Customer</literal> instances returned by "
+"the query are immediately detached. They are never associated with any "
+"persistence context."
+msgstr ""
+"이 코드 예제에서, 질의에 의해 반환된 <literal>Customer</literal> 인스턴스들"
+"은 곧바고 분리된다(detached). 그것들은 임의의 영속 컨텍스트와 결코 연관되지 "
+"않는다."
 
 #. Tag: para
-#: batch.xml:122
 #, no-c-format
-msgid "The <literal>insert(), update()</literal> and <literal>delete()</literal> operations defined by the <literal>StatelessSession</literal> interface are considered to be direct database row-level operations. They result in the immediate execution of a SQL <literal>INSERT, UPDATE</literal> or <literal>DELETE</literal> respectively. They have different semantics to the <literal>save(), saveOrUpdate()</literal> and <literal>delete()</literal> operations defined by the <literal>Session</literal> interface."
-msgstr "<literal>StatelessSession</literal> 인터페이스에 의해 정의된 <literal>insert(), update()</literal> 그리고 <literal>delete()</literal> 연산들은 직접적인 데이터베이스 행 레벨의 연산들로 갖주된다. 그것들은 각각 하나의 SQL <literal>INSERT, UPDATE</literal> 또는 <literal>DELETE</literal>의 즉각적인 실행으로 귀결된다. 그것들은 <literal>Session</literal> 인터페이스에 의해 정의된 <literal>save(), saveOrUpdate()</literal>와 <literal>delete()</literal> 연산들과는 다른 의미들을 갖는다."
+msgid ""
+"The <literal>insert(), update()</literal> and <literal>delete()</literal> "
+"operations defined by the <literal>StatelessSession</literal> interface are "
+"considered to be direct database row-level operations. They result in the "
+"immediate execution of a SQL <literal>INSERT, UPDATE</literal> or "
+"<literal>DELETE</literal> respectively. They have different semantics to the "
+"<literal>save(), saveOrUpdate()</literal> and <literal>delete()</literal> "
+"operations defined by the <literal>Session</literal> interface."
+msgstr ""
+"<literal>StatelessSession</literal> 인터페이스에 의해 정의된 <literal>insert"
+"(), update()</literal> 그리고 <literal>delete()</literal> 연산들은 직접적인 "
+"데이터베이스 행 레벨의 연산들로 갖주된다. 그것들은 각각 하나의 SQL "
+"<literal>INSERT, UPDATE</literal> 또는 <literal>DELETE</literal>의 즉각적인 "
+"실행으로 귀결된다. 그것들은 <literal>Session</literal> 인터페이스에 의해 정의"
+"된 <literal>save(), saveOrUpdate()</literal>와 <literal>delete()</literal> 연"
+"산들과는 다른 의미들을 갖는다."
 
 #. Tag: title
-#: batch.xml:135
 #, no-c-format
 msgid "DML-style operations"
 msgstr "DML-스타일 연산들"
 
 #. Tag: para
-#: batch.xml:137
 #, no-c-format
-msgid "As already discussed, automatic and transparent object/relational mapping is concerned with the management of the object state. The object state is available in memory. This means that manipulating data directly in the database (using the SQL <literal>Data Manipulation Language</literal> (DML) the statements: <literal>INSERT</literal>, <literal>UPDATE</literal>, <literal>DELETE</literal>) will not affect in-memory state. However, Hibernate provides methods for bulk SQL-style DML statement execution that is performed through the Hibernate Query Language (<link linkend=\"queryhql\">HQL</link>)."
-msgstr "이미 논의했듯이, 자동적이고 투명한 객체/관계형 매핑은 객체 상태에 대한 관리와 관계된다. 객체의 상태는 메모리 내에서 이용 가능하다. (SQL <literal>데이터 처리 언어</literal>(DML) 문장들 : <literal>INSERT</literal>, <literal>UPDATE</literal>, <literal>DELETE</literal>를 사용하여) 데이터베이스에서 직접 데이터 처리하는 것이 메모리 내 상태에 영향을 주지 않음을 의미한다. 하지만 하이버네이트는 하이버네이트 질의 언어(<xref linkend=\"queryhql\">HQL</xref>)를 통해 실행되는 대량 SQL-스타일의 DML 문장 실행을 위한 메소드들을 제공한다."
+msgid ""
+"As already discussed, automatic and transparent object/relational mapping is "
+"concerned with the management of the object state. The object state is "
+"available in memory. This means that manipulating data directly in the "
+"database (using the SQL <literal>Data Manipulation Language</literal> (DML) "
+"the statements: <literal>INSERT</literal>, <literal>UPDATE</literal>, "
+"<literal>DELETE</literal>) will not affect in-memory state. However, "
+"Hibernate provides methods for bulk SQL-style DML statement execution that "
+"is performed through the Hibernate Query Language (<link linkend=\"queryhql"
+"\">HQL</link>)."
+msgstr ""
+"이미 논의했듯이, 자동적이고 투명한 객체/관계형 매핑은 객체 상태에 대한 관리"
+"와 관계된다. 객체의 상태는 메모리 내에서 이용 가능하다. (SQL <literal>데이터 "
+"처리 언어</literal>(DML) 문장들 : <literal>INSERT</literal>, "
+"<literal>UPDATE</literal>, <literal>DELETE</literal>를 사용하여) 데이터베이스"
+"에서 직접 데이터 처리하는 것이 메모리 내 상태에 영향을 주지 않음을 의미한다. "
+"하지만 하이버네이트는 하이버네이트 질의 언어(<xref linkend=\"queryhql\">HQL</"
+"xref>)를 통해 실행되는 대량 SQL-스타일의 DML 문장 실행을 위한 메소드들을 제공"
+"한다."
 
 #. Tag: para
-#: batch.xml:146
 #, no-c-format
-msgid "The pseudo-syntax for <literal>UPDATE</literal> and <literal>DELETE</literal> statements is: <literal>( UPDATE | DELETE ) FROM? EntityName (WHERE where_conditions)?</literal>."
-msgstr "<literal>UPDATE</literal>와 <literal>DELETE</literal> 문장들에 대한 유사 구문은 다음과 같다: <literal>( UPDATE | DELETE ) FROM? EntityName (WHERE where_conditions)?</literal>."
+msgid ""
+"The pseudo-syntax for <literal>UPDATE</literal> and <literal>DELETE</"
+"literal> statements is: <literal>( UPDATE | DELETE ) FROM? EntityName (WHERE "
+"where_conditions)?</literal>."
+msgstr ""
+"<literal>UPDATE</literal>와 <literal>DELETE</literal> 문장들에 대한 유사 구문"
+"은 다음과 같다: <literal>( UPDATE | DELETE ) FROM? EntityName (WHERE "
+"where_conditions)?</literal>."
 
 #. Tag: para
-#: batch.xml:151
 #, no-c-format
 msgid "Some points to note:"
 msgstr "노트할 몇 가지:"
 
 #. Tag: para
-#: batch.xml:157
 #, no-c-format
 msgid "In the from-clause, the FROM keyword is optional"
 msgstr "from-절에서, FROM 키워드는 옵션이다"
 
 #. Tag: para
-#: batch.xml:162
 #, no-c-format
-msgid "There can only be a single entity named in the from-clause. It can, however, be aliased. If the entity name is aliased, then any property references must be qualified using that alias. If the entity name is not aliased, then it is illegal for any property references to be qualified."
-msgstr "from-절 내에 단지 명명된 한 개의 엔티티가 존재할 수 있다. 하지만 그것은 선택적으로 alias될 수 있다. 만일 엔티티 이름이 alias되면, 그때 임의의 프로퍼티 참조들은 그 alias를 사용하여 수식되어야 한다; 만일 엔티티 이름이 alias되지 않을 경우, 임의의 프로퍼티 참조들이 수식되는 것은 규칙에 어긋난다."
+msgid ""
+"There can only be a single entity named in the from-clause. It can, however, "
+"be aliased. If the entity name is aliased, then any property references must "
+"be qualified using that alias. If the entity name is not aliased, then it is "
+"illegal for any property references to be qualified."
+msgstr ""
+"from-절 내에 단지 명명된 한 개의 엔티티가 존재할 수 있다. 하지만 그것은 선택"
+"적으로 alias될 수 있다. 만일 엔티티 이름이 alias되면, 그때 임의의 프로퍼티 참"
+"조들은 그 alias를 사용하여 수식되어야 한다; 만일 엔티티 이름이 alias되지 않"
+"을 경우, 임의의 프로퍼티 참조들이 수식되는 것은 규칙에 어긋난다."
 
 #. Tag: para
-#: batch.xml:170
 #, no-c-format
-msgid "No <link linkend=\"queryhql-joins-forms\">joins</link>, either implicit or explicit, can be specified in a bulk HQL query. Sub-queries can be used in the where-clause, where the subqueries themselves may contain joins."
-msgstr "함축적이든 명시적이든 <xref linkend=\"queryhql-joins-forms\">join들</xref>은 대량 HQL 질의 속에 지정될 수 없다. 서브-질의들이 where-절에 사용될 수 있는데, 여기서 서브질의들 그 자신들은 조인들을 포함할 수 있다."
+msgid ""
+"No <link linkend=\"queryhql-joins-forms\">joins</link>, either implicit or "
+"explicit, can be specified in a bulk HQL query. Sub-queries can be used in "
+"the where-clause, where the subqueries themselves may contain joins."
+msgstr ""
+"함축적이든 명시적이든 <xref linkend=\"queryhql-joins-forms\">join들</xref>은 "
+"대량 HQL 질의 속에 지정될 수 없다. 서브-질의들이 where-절에 사용될 수 있는"
+"데, 여기서 서브질의들 그 자신들은 조인들을 포함할 수 있다."
 
 #. Tag: para
-#: batch.xml:177
 #, no-c-format
 msgid "The where-clause is also optional."
 msgstr "where-절 또한 옵션이다."
 
 #. Tag: para
-#: batch.xml:183
 #, no-c-format
-msgid "As an example, to execute an HQL <literal>UPDATE</literal>, use the <literal>Query.executeUpdate()</literal> method. The method is named for those familiar with JDBC's <literal>PreparedStatement.executeUpdate()</literal>:"
-msgstr "하나의 예제로서, 한 개의 HQL <literal>UPDATE</literal>를 실행하기 위해, <literal>Query.executeUpdate()</literal> 메소드를 사용하라. 그 메소드는 JDBC의 <literal>PreparedStatement.executeUpdate()</literal>와 유사하게 명명된다:"
-
-#. Tag: programlisting
-#: batch.xml:189
-#, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlUpdate = \"update Customer c set c.name = :newName where c.name = :oldName\";\n"
-"// or String hqlUpdate = \"update Customer set name = :newName where name = :oldName\";\n"
-"int updatedEntities = s.createQuery( hqlUpdate )\n"
-"        .setString( \"newName\", newName )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
+"As an example, to execute an HQL <literal>UPDATE</literal>, use the "
+"<literal>Query.executeUpdate()</literal> method. The method is named for "
+"those familiar with JDBC's <literal>PreparedStatement.executeUpdate()</"
+"literal>:"
 msgstr ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlUpdate = \"update Customer c set c.name = :newName where c.name = :oldName\";\n"
-"// or String hqlUpdate = \"update Customer set name = :newName where name = :oldName\";\n"
-"int updatedEntities = s.createQuery( hqlUpdate )\n"
-"        .setString( \"newName\", newName )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
+"하나의 예제로서, 한 개의 HQL <literal>UPDATE</literal>를 실행하기 위해, "
+"<literal>Query.executeUpdate()</literal> 메소드를 사용하라. 그 메소드는 JDBC"
+"의 <literal>PreparedStatement.executeUpdate()</literal>와 유사하게 명명된다:"
 
 #. Tag: para
-#: batch.xml:191
 #, no-c-format
-msgid "In keeping with the EJB3 specification, HQL <literal>UPDATE</literal> statements, by default, do not effect the <link linkend=\"mapping-declaration-version\">version</link> or the <link linkend=\"mapping-declaration-timestamp\">timestamp</link> property values for the affected entities. However, you can force Hibernate to reset the <literal>version</literal> or <literal>timestamp</literal> property values through the use of a <literal>versioned update</literal>. This is achieved by adding the <literal>VERSIONED</literal> keyword after the <literal>UPDATE</literal> keyword."
-msgstr "이것은 EJB3 명세서에서 유지되고 있듯이, HQL <literal>UPDATE</literal> 문장들은 디폴트로 영향받는 엔티티들에 대한 <xref linkend=\"mapping-declaration-version\">version</xref> 또는 <xref linkend=\"mapping-declaration-timestamp\">timestamp</xref> 프로퍼티 값들에 영향을 주지 않는다. 하지만 당신은 하이버네이트로 하여금 <literal>versioned update</literal>의 사용을 통해 <literal>version</literal> 또는 <literal>timestamp</literal> 프로퍼티 값들을 적절하게 재설정하도록 강제시킬 수 있다. 이것은 <literal>UPDATE</literal> 키워드 뒤에 <literal>VERSIONED</literal> 키워드를 추가시킴으로써 달성된다."
-
-#. Tag: programlisting
-#: batch.xml:201
-#, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"String hqlVersionedUpdate = \"update versioned Customer set name = :newName where name = :oldName\";\n"
-"int updatedEntities = s.createQuery( hqlUpdate )\n"
-"        .setString( \"newName\", newName )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
+"In keeping with the EJB3 specification, HQL <literal>UPDATE</literal> "
+"statements, by default, do not effect the <link linkend=\"mapping-"
+"declaration-version\">version</link> or the <link linkend=\"mapping-"
+"declaration-timestamp\">timestamp</link> property values for the affected "
+"entities. However, you can force Hibernate to reset the <literal>version</"
+"literal> or <literal>timestamp</literal> property values through the use of "
+"a <literal>versioned update</literal>. This is achieved by adding the "
+"<literal>VERSIONED</literal> keyword after the <literal>UPDATE</literal> "
+"keyword."
 msgstr ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"String hqlVersionedUpdate = \"update versioned Customer set name = :newName where name = :oldName\";\n"
-"int updatedEntities = s.createQuery( hqlUpdate )\n"
-"        .setString( \"newName\", newName )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
+"이것은 EJB3 명세서에서 유지되고 있듯이, HQL <literal>UPDATE</literal> 문장들"
+"은 디폴트로 영향받는 엔티티들에 대한 <xref linkend=\"mapping-declaration-"
+"version\">version</xref> 또는 <xref linkend=\"mapping-declaration-timestamp"
+"\">timestamp</xref> 프로퍼티 값들에 영향을 주지 않는다. 하지만 당신은 하이버"
+"네이트로 하여금 <literal>versioned update</literal>의 사용을 통해 "
+"<literal>version</literal> 또는 <literal>timestamp</literal> 프로퍼티 값들을 "
+"적절하게 재설정하도록 강제시킬 수 있다. 이것은 <literal>UPDATE</literal> 키워"
+"드 뒤에 <literal>VERSIONED</literal> 키워드를 추가시킴으로써 달성된다."
 
 #. Tag: para
-#: batch.xml:203
 #, no-c-format
-msgid "Custom version types, <literal>org.hibernate.usertype.UserVersionType</literal>, are not allowed in conjunction with a <literal>update versioned</literal> statement."
-msgstr "맞춤형 version 타입들, <literal>org.hibernate.usertype.UserVersionType</literal>은 <literal>update versioned</literal>과 문장과 함께 사용하는 것이 허용되지 않는다."
+msgid ""
+"Custom version types, <literal>org.hibernate.usertype.UserVersionType</"
+"literal>, are not allowed in conjunction with a <literal>update versioned</"
+"literal> statement."
+msgstr ""
+"맞춤형 version 타입들, <literal>org.hibernate.usertype.UserVersionType</"
+"literal>은 <literal>update versioned</literal>과 문장과 함께 사용하는 것이 허"
+"용되지 않는다."
 
 #. Tag: para
-#: batch.xml:208
 #, no-c-format
-msgid "To execute an HQL <literal>DELETE</literal>, use the same <literal>Query.executeUpdate()</literal> method:"
-msgstr "HQL <literal>DELETE</literal>를 실행하려면, 같은 메소드 <literal>Query.executeUpdate()</literal>를 사용하라:"
-
-#. Tag: programlisting
-#: batch.xml:213
-#, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlDelete = \"delete Customer c where c.name = :oldName\";\n"
-"// or String hqlDelete = \"delete Customer where name = :oldName\";\n"
-"int deletedEntities = s.createQuery( hqlDelete )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
+"To execute an HQL <literal>DELETE</literal>, use the same <literal>Query."
+"executeUpdate()</literal> method:"
 msgstr ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlDelete = \"delete Customer c where c.name = :oldName\";\n"
-"// or String hqlDelete = \"delete Customer where name = :oldName\";\n"
-"int deletedEntities = s.createQuery( hqlDelete )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
+"HQL <literal>DELETE</literal>를 실행하려면, 같은 메소드 <literal>Query."
+"executeUpdate()</literal>를 사용하라:"
 
 #. Tag: para
-#: batch.xml:215
 #, no-c-format
-msgid "The <literal>int</literal> value returned by the <literal>Query.executeUpdate()</literal> method indicates the number of entities effected by the operation. This may or may not correlate to the number of rows effected in the database. An HQL bulk operation might result in multiple actual SQL statements being executed (for joined-subclass, for example). The returned number indicates the number of actual entities affected by the statement. Going back to the example of joined-subclass, a delete against one of the subclasses may actually result in deletes against not just the table to which that subclass is mapped, but also the \"root\" table and potentially joined-subclass tables further down the inheritance hierarchy."
-msgstr "<literal>Query.executeUpdate()</literal> 메소드에 의해 반환되는 <literal>int</literal> 값은 그 오퍼레이션에 의해 영향받은 엔티티들의 개수를 나타낸다. 이것이 데이터베이스 내에서 영향받은 행들의 개수와 상관이 있을 수도 없을 수도 있다. HQL 대량 오퍼레이션은 (예를 들어 joined-subclass에 대해) 실행 중인 여러 개의 실제 SQL 문장들로 귀결될 수 있다. 반환되는 숫자는 그 문장에 의해 영향받은 실제 엔티티들의 개수를 나타낸다. joined-subclass 예제로 되돌아가면, 서브클래스들 중 하나에 대한 삭제는 단지 그 서브클래스가 매핑되어 있는 테이블에 대한 삭제로 귀결될 뿐만 아니라 또한 \"루트\" 테이블과 상속 계층에서 더 내려온 잠정적으로 조인된-서브클래스 테이블들에 대한 삭제들로 귀결될 수 있다."
+msgid ""
+"The <literal>int</literal> value returned by the <literal>Query.executeUpdate"
+"()</literal> method indicates the number of entities effected by the "
+"operation. This may or may not correlate to the number of rows effected in "
+"the database. An HQL bulk operation might result in multiple actual SQL "
+"statements being executed (for joined-subclass, for example). The returned "
+"number indicates the number of actual entities affected by the statement. "
+"Going back to the example of joined-subclass, a delete against one of the "
+"subclasses may actually result in deletes against not just the table to "
+"which that subclass is mapped, but also the \"root\" table and potentially "
+"joined-subclass tables further down the inheritance hierarchy."
+msgstr ""
+"<literal>Query.executeUpdate()</literal> 메소드에 의해 반환되는 "
+"<literal>int</literal> 값은 그 오퍼레이션에 의해 영향받은 엔티티들의 개수를 "
+"나타낸다. 이것이 데이터베이스 내에서 영향받은 행들의 개수와 상관이 있을 수도 "
+"없을 수도 있다. HQL 대량 오퍼레이션은 (예를 들어 joined-subclass에 대해) 실"
+"행 중인 여러 개의 실제 SQL 문장들로 귀결될 수 있다. 반환되는 숫자는 그 문장"
+"에 의해 영향받은 실제 엔티티들의 개수를 나타낸다. joined-subclass 예제로 되돌"
+"아가면, 서브클래스들 중 하나에 대한 삭제는 단지 그 서브클래스가 매핑되어 있"
+"는 테이블에 대한 삭제로 귀결될 뿐만 아니라 또한 \"루트\" 테이블과 상속 계층에"
+"서 더 내려온 잠정적으로 조인된-서브클래스 테이블들에 대한 삭제들로 귀결될 수 "
+"있다."
 
 #. Tag: para
-#: batch.xml:226
 #, no-c-format
-msgid "The pseudo-syntax for <literal>INSERT</literal> statements is: <literal>INSERT INTO EntityName properties_list select_statement</literal>. Some points to note:"
-msgstr "장래의 배포본들에서 전달될 대량 HQL 오퍼레이션들에 대한 몇 가지 제한들이 현재 존재함을 노트하라; 상세한 것은 JIRA 로드맵을 참조하라. <literal>INSERT</literal> 문장들을 위한 유사-구문은 다음과 같다: <literal>INSERT INTO EntityName properties_list select_statement</literal>. 노트할 몇 가지:"
+msgid ""
+"The pseudo-syntax for <literal>INSERT</literal> statements is: "
+"<literal>INSERT INTO EntityName properties_list select_statement</literal>. "
+"Some points to note:"
+msgstr ""
+"장래의 배포본들에서 전달될 대량 HQL 오퍼레이션들에 대한 몇 가지 제한들이 현"
+"재 존재함을 노트하라; 상세한 것은 JIRA 로드맵을 참조하라. <literal>INSERT</"
+"literal> 문장들을 위한 유사-구문은 다음과 같다: <literal>INSERT INTO "
+"EntityName properties_list select_statement</literal>. 노트할 몇 가지:"
 
 #. Tag: para
-#: batch.xml:234
 #, no-c-format
-msgid "Only the INSERT INTO ... SELECT ... form is supported; not the INSERT INTO ... VALUES ... form."
-msgstr "오직 INSERT INTO ... SELECT ... 형식 만일 지원된다; INSERT INTO ... VALUES ... 형식은 지원되지 않는다."
+msgid ""
+"Only the INSERT INTO ... SELECT ... form is supported; not the INSERT "
+"INTO ... VALUES ... form."
+msgstr ""
+"오직 INSERT INTO ... SELECT ... 형식 만일 지원된다; INSERT INTO ... "
+"VALUES ... 형식은 지원되지 않는다."
 
 #. Tag: para
-#: batch.xml:237
 #, no-c-format
-msgid "The properties_list is analogous to the <literal>column specification</literal> in the SQL <literal>INSERT</literal> statement. For entities involved in mapped inheritance, only properties directly defined on that given class-level can be used in the properties_list. Superclass properties are not allowed and subclass properties do not make sense. In other words, <literal>INSERT</literal> statements are inherently non-polymorphic."
-msgstr "properties_list는 SQL <literal>INSERT</literal> 문장에서 <literal>컬럼 명세</literal>와 유사하다. 매핑된 상속에 참여하는 엔티티들의 경우, 그 주어진 클래스-레벨 상에 직접 정의된 프로퍼티들 만이 properties_list에 사용될 수 있다. 슈퍼클래스 프로퍼티들은 허용되지 않고, 서브클래스 프로퍼티들은 의미가 없다. 달리 말해 <literal>INSERT</literal> 문장들은 본래적으로 다형적이지 않다(non-polymorphic)."
+msgid ""
+"The properties_list is analogous to the <literal>column specification</"
+"literal> in the SQL <literal>INSERT</literal> statement. For entities "
+"involved in mapped inheritance, only properties directly defined on that "
+"given class-level can be used in the properties_list. Superclass properties "
+"are not allowed and subclass properties do not make sense. In other words, "
+"<literal>INSERT</literal> statements are inherently non-polymorphic."
+msgstr ""
+"properties_list는 SQL <literal>INSERT</literal> 문장에서 <literal>컬럼 명세</"
+"literal>와 유사하다. 매핑된 상속에 참여하는 엔티티들의 경우, 그 주어진 클래"
+"스-레벨 상에 직접 정의된 프로퍼티들 만이 properties_list에 사용될 수 있다. 슈"
+"퍼클래스 프로퍼티들은 허용되지 않고, 서브클래스 프로퍼티들은 의미가 없다. 달"
+"리 말해 <literal>INSERT</literal> 문장들은 본래적으로 다형적이지 않다(non-"
+"polymorphic)."
 
 #. Tag: para
-#: batch.xml:247
 #, no-c-format
-msgid "select_statement can be any valid HQL select query, with the caveat that the return types must match the types expected by the insert. Currently, this is checked during query compilation rather than allowing the check to relegate to the database. This might, however, cause problems between Hibernate <literal>Type</literal>s which are <emphasis>equivalent</emphasis> as opposed to <emphasis>equal</emphasis>. This might cause issues with mismatches between a property defined as a <literal>org.hibernate.type.DateType</literal> and a property defined as a <literal>org.hibernate.type.TimestampType</literal>, even though the database might not make a distinction or might be able to handle the conversion."
-msgstr "반환 타입들이 insert에 의해 기대되는 타입들과 일치해야 한다는 단서 하에, select_statement는 임의의 유효한 HQL select 질의일 수 있다. 현재 이것은 데이터베이스로 강등시킬 체크를 허용하기 보다는 질의 컴파일 동안에 체크된다. 하지만 이것은 <emphasis>equal</emphasis>과는 대조적으로 <emphasis>등가인(equivalent)</emphasis> Hibernate <literal>Type</literal>들 사이에 문제점들을 일으킬 수도 있다. 비록 데이터베이스가 구별할수 없거나 변환을 처리할 수 있을 지라도, 이것은 <literal>org.hibernate.type.DateType</literal>로 정의된 프로퍼티와 <literal>org.hibernate.type.TimestampType</literal>으로 정의된 프로퍼티 사이에 불일치 쟁점들을 유발시킬 수도 있다."
+msgid ""
+"select_statement can be any valid HQL select query, with the caveat that the "
+"return types must match the types expected by the insert. Currently, this is "
+"checked during query compilation rather than allowing the check to relegate "
+"to the database. This might, however, cause problems between Hibernate "
+"<literal>Type</literal>s which are <emphasis>equivalent</emphasis> as "
+"opposed to <emphasis>equal</emphasis>. This might cause issues with "
+"mismatches between a property defined as a <literal>org.hibernate.type."
+"DateType</literal> and a property defined as a <literal>org.hibernate.type."
+"TimestampType</literal>, even though the database might not make a "
+"distinction or might be able to handle the conversion."
+msgstr ""
+"반환 타입들이 insert에 의해 기대되는 타입들과 일치해야 한다는 단서 하에, "
+"select_statement는 임의의 유효한 HQL select 질의일 수 있다. 현재 이것은 데이"
+"터베이스로 강등시킬 체크를 허용하기 보다는 질의 컴파일 동안에 체크된다. 하지"
+"만 이것은 <emphasis>equal</emphasis>과는 대조적으로 <emphasis>등가인"
+"(equivalent)</emphasis> Hibernate <literal>Type</literal>들 사이에 문제점들"
+"을 일으킬 수도 있다. 비록 데이터베이스가 구별할수 없거나 변환을 처리할 수 있"
+"을 지라도, 이것은 <literal>org.hibernate.type.DateType</literal>로 정의된 프"
+"로퍼티와 <literal>org.hibernate.type.TimestampType</literal>으로 정의된 프로"
+"퍼티 사이에 불일치 쟁점들을 유발시킬 수도 있다."
 
 #. Tag: para
-#: batch.xml:259
 #, no-c-format
-msgid "For the id property, the insert statement gives you two options. You can either explicitly specify the id property in the properties_list, in which case its value is taken from the corresponding select expression, or omit it from the properties_list, in which case a generated value is used. This latter option is only available when using id generators that operate in the database; attempting to use this option with any \"in memory\" type generators will cause an exception during parsing. For the purposes of this discussion, in-database generators are considered to be <literal>org.hibernate.id.SequenceGenerator</literal> (and its subclasses) and any implementers of <literal>org.hibernate.id.PostInsertIdentifierGenerator</literal>. The most notable exception here is <literal>org.hibernate.id.TableHiLoGenerator</literal>, which cannot be used because it does not expose a selectable way to get its values."
-msgstr "id 프로퍼티의 경우, insert 문장은 당신에게 두 개의 옵션을 준다. 당신은 properties_list 내에 id 프로퍼티를 명시적으로 지정할 수 있는데 이 경우에 그것의 값은 대응하는 SELECT 표현식으로부터 얻어진다. 또는 properties_list에서 그것을 생략할 수 있는데 이 경우에 생성된 값이 사용된다. 이 후자의 옵션의 데이터베이스 내에서 연산되는 id 연산자들을 사용할 때에만 이용 가능하다; 임의의 \"메모리 ë‚´\" 타입 생성기들로서 이 옵션을 사용하고자 시도하는 것은 파싱 동안에 예외상황을 일으킬 것이다. 이 논의의 목적 상, 데이터베이스 ë‚´ 생성기들은 <literal>org.hibernate.id.SequenceGenerator</literal> (그리고 그것의 서브클래스들) 그리고 임의의 <literal>org.hibernate.id.PostInsertIdentifierGenerator</literal>의 구현자들이라고 간주된다. 여기서 가장 주목할 만한 예ì!
 ™¸ëŠ” <literal>org.hibernate.id.TableHiLoGenerator</literal>인데, 그것이 그것의 값들을 얻기 위한 select 가능한 방법을 노출시키지 않기 때문에 사용될 수 없다."
+msgid ""
+"For the id property, the insert statement gives you two options. You can "
+"either explicitly specify the id property in the properties_list, in which "
+"case its value is taken from the corresponding select expression, or omit it "
+"from the properties_list, in which case a generated value is used. This "
+"latter option is only available when using id generators that operate in the "
+"database; attempting to use this option with any \"in memory\" type "
+"generators will cause an exception during parsing. For the purposes of this "
+"discussion, in-database generators are considered to be <literal>org."
+"hibernate.id.SequenceGenerator</literal> (and its subclasses) and any "
+"implementers of <literal>org.hibernate.id.PostInsertIdentifierGenerator</"
+"literal>. The most notable exception here is <literal>org.hibernate.id."
+"TableHiLoGenerator</literal>, which cannot be used because it does not "
+"expose a selectable way to get its values."
+msgstr ""
+"id 프로퍼티의 경우, insert 문장은 당신에게 두 개의 옵션을 준다. 당신은 "
+"properties_list 내에 id 프로퍼티를 명시적으로 지정할 수 있는데 이 경우에 그것"
+"의 값은 대응하는 SELECT 표현식으로부터 얻어진다. 또는 properties_list에서 그"
+"것을 생략할 수 있는데 이 경우에 생성된 값이 사용된다. 이 후자의 옵션의 데이터"
+"베이스 내에서 연산되는 id 연산자들을 사용할 때에만 이용 가능하다; 임의의 \"메"
+"모리 내\" 타입 생성기들로서 이 옵션을 사용하고자 시도하는 것은 파싱 동안에 예"
+"외상황을 일으킬 것이다. 이 논의의 목적 상, 데이터베이스 내 생성기들은 "
+"<literal>org.hibernate.id.SequenceGenerator</literal> (그리고 그것의 서브클래"
+"스들) 그리고 임의의 <literal>org.hibernate.id.PostInsertIdentifierGenerator</"
+"literal>의 구현자들이라고 간주된다. 여기서 가장 주목할 만한 예외는 "
+"<literal>org.hibernate.id.TableHiLoGenerator</literal>인데, 그것이 그것의 값"
+"들을 얻기 위한 select 가능한 방법을 노출시키지 않기 때문에 사용될 수 없다."
 
 #. Tag: para
-#: batch.xml:274
 #, no-c-format
-msgid "For properties mapped as either <literal>version</literal> or <literal>timestamp</literal>, the insert statement gives you two options. You can either specify the property in the properties_list, in which case its value is taken from the corresponding select expressions, or omit it from the properties_list, in which case the <literal>seed value</literal> defined by the <literal>org.hibernate.type.VersionType</literal> is used."
-msgstr "<literal>version</literal> 또는 <literal>timestamp</literal>로 매핑된 프로퍼티들의 경우에, insert 문장은 당신에게 두 개의 옵션들을 준다. 당신은 properties_list 내에 그 프로퍼티를 지정할 수 있는데 그 경우 그것의 값이 대응하는 select 표현식으로부터 얻어진다. 또는 당신은 properties_list에서 그것을 생략할 수 있는데 그 경우에 <literal>org.hibernate.type.VersionType</literal>에 의해 정의된 <literal>seed value</literal> 값이 사용된다."
+msgid ""
+"For properties mapped as either <literal>version</literal> or "
+"<literal>timestamp</literal>, the insert statement gives you two options. "
+"You can either specify the property in the properties_list, in which case "
+"its value is taken from the corresponding select expressions, or omit it "
+"from the properties_list, in which case the <literal>seed value</literal> "
+"defined by the <literal>org.hibernate.type.VersionType</literal> is used."
+msgstr ""
+"<literal>version</literal> 또는 <literal>timestamp</literal>로 매핑된 프로퍼"
+"티들의 경우에, insert 문장은 당신에게 두 개의 옵션들을 준다. 당신은 "
+"properties_list 내에 그 프로퍼티를 지정할 수 있는데 그 경우 그것의 값이 대응"
+"하는 select 표현식으로부터 얻어진다. 또는 당신은 properties_list에서 그것을 "
+"생략할 수 있는데 그 경우에 <literal>org.hibernate.type.VersionType</literal>"
+"에 의해 정의된 <literal>seed value</literal> 값이 사용된다."
 
 #. Tag: para
-#: batch.xml:284
 #, no-c-format
-msgid "The following is an example of an HQL <literal>INSERT</literal> statement execution:"
+msgid ""
+"The following is an example of an HQL <literal>INSERT</literal> statement "
+"execution:"
 msgstr "다음은 HQL <literal>INSERT</literal> 문장 실행 예제이다:"
 
-#. Tag: programlisting
-#: batch.xml:288
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlInsert = \"insert into DelinquentAccount (id, name) select c.id, c.name from Customer c where ...\";\n"
-"int createdEntities = s.createQuery( hqlInsert )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlInsert = \"insert into DelinquentAccount (id, name) select c.id, c.name from Customer c where ...\";\n"
-"int createdEntities = s.createQuery( hqlInsert )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "for ( int i=0; i<100000; i++ ) {\n"
+#~ "    Customer customer = new Customer(.....);\n"
+#~ "    session.save(customer);\n"
+#~ "}\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "for ( int i=0; i<100000; i++ ) {\n"
+#~ "    Customer customer = new Customer(.....);\n"
+#~ "    session.save(customer);\n"
+#~ "}\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
 
+#~ msgid "<![CDATA[hibernate.jdbc.batch_size 20]]>"
+#~ msgstr "<![CDATA[hibernate.jdbc.batch_size 20]]>"
+
+#~ msgid "<![CDATA[hibernate.cache.use_second_level_cache false]]>"
+#~ msgstr "<![CDATA[hibernate.cache.use_second_level_cache false]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "for ( int i=0; i<100000; i++ ) {\n"
+#~ "    Customer customer = new Customer(.....);\n"
+#~ "    session.save(customer);\n"
+#~ "    if ( i % 20 == 0 ) { //20, same as the JDBC batch size\n"
+#~ "        //flush a batch of inserts and release memory:\n"
+#~ "        session.flush();\n"
+#~ "        session.clear();\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "for ( int i=0; i<100000; i++ ) {\n"
+#~ "    Customer customer = new Customer(.....);\n"
+#~ "    session.save(customer);\n"
+#~ "    if ( i % 20 == 0 ) { //20, same as the JDBC batch size\n"
+#~ "        //flush a batch of inserts and release memory:\n"
+#~ "        session.flush();\n"
+#~ "        session.clear();\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
+#~ "    .setCacheMode(CacheMode.IGNORE)\n"
+#~ "    .scroll(ScrollMode.FORWARD_ONLY);\n"
+#~ "int count=0;\n"
+#~ "while ( customers.next() ) {\n"
+#~ "    Customer customer = (Customer) customers.get(0);\n"
+#~ "    customer.updateStuff(...);\n"
+#~ "    if ( ++count % 20 == 0 ) {\n"
+#~ "        //flush a batch of updates and release memory:\n"
+#~ "        session.flush();\n"
+#~ "        session.clear();\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
+#~ "    .setCacheMode(CacheMode.IGNORE)\n"
+#~ "    .scroll(ScrollMode.FORWARD_ONLY);\n"
+#~ "int count=0;\n"
+#~ "while ( customers.next() ) {\n"
+#~ "    Customer customer = (Customer) customers.get(0);\n"
+#~ "    customer.updateStuff(...);\n"
+#~ "    if ( ++count % 20 == 0 ) {\n"
+#~ "        //flush a batch of updates and release memory:\n"
+#~ "        session.flush();\n"
+#~ "        session.clear();\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[StatelessSession session = sessionFactory.openStatelessSession"
+#~ "();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
+#~ "    .scroll(ScrollMode.FORWARD_ONLY);\n"
+#~ "while ( customers.next() ) {\n"
+#~ "    Customer customer = (Customer) customers.get(0);\n"
+#~ "    customer.updateStuff(...);\n"
+#~ "    session.update(customer);\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[StatelessSession session = sessionFactory.openStatelessSession"
+#~ "();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
+#~ "    .scroll(ScrollMode.FORWARD_ONLY);\n"
+#~ "while ( customers.next() ) {\n"
+#~ "    Customer customer = (Customer) customers.get(0);\n"
+#~ "    customer.updateStuff(...);\n"
+#~ "    session.update(customer);\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlUpdate = \"update Customer c set c.name = :newName where c.name "
+#~ "= :oldName\";\n"
+#~ "// or String hqlUpdate = \"update Customer set name = :newName where name "
+#~ "= :oldName\";\n"
+#~ "int updatedEntities = s.createQuery( hqlUpdate )\n"
+#~ "        .setString( \"newName\", newName )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlUpdate = \"update Customer c set c.name = :newName where c.name "
+#~ "= :oldName\";\n"
+#~ "// or String hqlUpdate = \"update Customer set name = :newName where name "
+#~ "= :oldName\";\n"
+#~ "int updatedEntities = s.createQuery( hqlUpdate )\n"
+#~ "        .setString( \"newName\", newName )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "String hqlVersionedUpdate = \"update versioned Customer set name = :"
+#~ "newName where name = :oldName\";\n"
+#~ "int updatedEntities = s.createQuery( hqlUpdate )\n"
+#~ "        .setString( \"newName\", newName )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "String hqlVersionedUpdate = \"update versioned Customer set name = :"
+#~ "newName where name = :oldName\";\n"
+#~ "int updatedEntities = s.createQuery( hqlUpdate )\n"
+#~ "        .setString( \"newName\", newName )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlDelete = \"delete Customer c where c.name = :oldName\";\n"
+#~ "// or String hqlDelete = \"delete Customer where name = :oldName\";\n"
+#~ "int deletedEntities = s.createQuery( hqlDelete )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlDelete = \"delete Customer c where c.name = :oldName\";\n"
+#~ "// or String hqlDelete = \"delete Customer where name = :oldName\";\n"
+#~ "int deletedEntities = s.createQuery( hqlDelete )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlInsert = \"insert into DelinquentAccount (id, name) select c."
+#~ "id, c.name from Customer c where ...\";\n"
+#~ "int createdEntities = s.createQuery( hqlInsert )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlInsert = \"insert into DelinquentAccount (id, name) select c."
+#~ "id, c.name from Customer c where ...\";\n"
+#~ "int createdEntities = s.createQuery( hqlInsert )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/best_practices.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/best_practices.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/best_practices.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,13 +11,11 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: best_practices.xml:29
 #, no-c-format
 msgid "Best Practices"
 msgstr "최상의 실전 경험들"
 
 #. Tag: term
-#: best_practices.xml:33
 #, fuzzy, no-c-format
 msgid ""
 "Write fine-grained classes and map them using <literal>&lt;component&gt;</"
@@ -27,7 +25,6 @@
 "하여 그것들을 매핑하라."
 
 #. Tag: para
-#: best_practices.xml:35
 #, no-c-format
 msgid ""
 "Use an <literal>Address</literal> class to encapsulate <literal>street</"
@@ -41,13 +38,11 @@
 "화 시킨다."
 
 #. Tag: term
-#: best_practices.xml:43
 #, fuzzy, no-c-format
 msgid "Declare identifier properties on persistent classes:"
 msgstr "영속 클래스들에 대해 식별자 프로퍼티들을 선언하라."
 
 #. Tag: para
-#: best_practices.xml:45
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate makes identifier properties optional. There are a range of reasons "
@@ -59,13 +54,11 @@
 "(synthetic)'이 되는(비지니스 의미 없이 생성되는) 것을 권장한다."
 
 #. Tag: term
-#: best_practices.xml:53
 #, fuzzy, no-c-format
 msgid "Identify natural keys:"
 msgstr "고유 키들을 식별하라."
 
 #. Tag: para
-#: best_practices.xml:55
 #, no-c-format
 msgid ""
 "Identify natural keys for all entities, and map them using <literal>&lt;"
@@ -79,13 +72,11 @@
 "라."
 
 #. Tag: term
-#: best_practices.xml:63
 #, fuzzy, no-c-format
 msgid "Place each class mapping in its own file:"
 msgstr "각각의 클래스 매핑을 그것 자신의 파일 내에 위치지워라."
 
 #. Tag: para
-#: best_practices.xml:65
 #, fuzzy, no-c-format
 msgid ""
 "Do not use a single monolithic mapping document. Map <literal>com.eg.Foo</"
@@ -97,25 +88,21 @@
 "서 특히 좋은 의미를 준다."
 
 #. Tag: term
-#: best_practices.xml:73
 #, fuzzy, no-c-format
 msgid "Load mappings as resources:"
 msgstr "매핑들을 리소스들로서 로드시켜라."
 
 #. Tag: para
-#: best_practices.xml:75
 #, no-c-format
 msgid "Deploy the mappings along with the classes they map."
 msgstr "그것들이 매핑하는 클래스들에 따라서 매핑들을 배치하라"
 
 #. Tag: term
-#: best_practices.xml:81
 #, fuzzy, no-c-format
 msgid "Consider externalizing query strings:"
 msgstr "질의 문자열들을 객관화 시키는 것을 고려하라."
 
 #. Tag: para
-#: best_practices.xml:83
 #, fuzzy, no-c-format
 msgid ""
 "This is recommended if your queries call non-ANSI-standard SQL functions. "
@@ -127,13 +114,11 @@
 "이식성 있도록 만들어줄 것이다."
 
 #. Tag: term
-#: best_practices.xml:91
 #, no-c-format
 msgid "Use bind variables."
 msgstr "바인드 변수들을 사용하라."
 
 #. Tag: para
-#: best_practices.xml:93
 #, fuzzy, no-c-format
 msgid ""
 "As in JDBC, always replace non-constant values by \"?\". Do not use string "
@@ -145,13 +130,11 @@
 "된 파라미터들을 사용하는 것을 고려하라."
 
 #. Tag: term
-#: best_practices.xml:101
 #, fuzzy, no-c-format
 msgid "Do not manage your own JDBC connections:"
 msgstr "당신 자신의 JDBC 커넥션들을 관리하지 말라."
 
 #. Tag: para
-#: best_practices.xml:103
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate allows the application to manage JDBC connections, but his "
@@ -166,13 +149,11 @@
 "라."
 
 #. Tag: term
-#: best_practices.xml:111
 #, fuzzy, no-c-format
 msgid "Consider using a custom type:"
 msgstr "맞춤형 타입 사용을 고려하라."
 
 #. Tag: para
-#: best_practices.xml:113
 #, fuzzy, no-c-format
 msgid ""
 "Suppose you have a Java type from a library that needs to be persisted but "
@@ -188,22 +169,21 @@
 "을 구현하는 것으로부터 어플리케이션 코드를 자유롭게 해준다."
 
 #. Tag: term
-#: best_practices.xml:122
 #, fuzzy, no-c-format
 msgid "Use hand-coded JDBC in bottlenecks:"
 msgstr "병목 지점들에서 수작업으로 코딩된 JDBC를 사용하라."
 
 #. Tag: para
-#: best_practices.xml:124
 #, fuzzy, no-c-format
 msgid ""
 "In performance-critical areas of the system, some kinds of operations might "
 "benefit from direct JDBC. Do not assume, however, that JDBC is necessarily "
 "faster. Please wait until you <emphasis>know</emphasis> something is a "
 "bottleneck. If you need to use direct JDBC, you can open a Hibernate "
-"<literal>Session</literal> and usingfile:///usr/share/doc/HTML/en-US/index."
-"html that JDBC connection. This way you can still use the same transaction "
-"strategy and underlying connection provider."
+"<literal>Session</literal>, wrap your JDBC operation as a <literal>org."
+"hibernate.jdbc.Work</literal> object and using that JDBC connection. This "
+"way you can still use the same transaction strategy and underlying "
+"connection provider."
 msgstr ""
 "시스템의 퍼포먼스가 중대한 영역들에서, 몇몇 종류의 오퍼레이션들은 직접적인 "
 "JDBC에서 이득을 본다. 그러나 당신이 어떤 것이 병목인지를 <emphasis>알기</"
@@ -214,13 +194,11 @@
 "히 사용할 수 있다"
 
 #. Tag: term
-#: best_practices.xml:134
 #, fuzzy, no-c-format
 msgid "Understand <literal>Session</literal> flushing:"
 msgstr "<literal>Session</literal> flushing을 이해하라."
 
 #. Tag: para
-#: best_practices.xml:136
 #, fuzzy, no-c-format
 msgid ""
 "Sometimes the Session synchronizes its persistent state with the database. "
@@ -236,14 +214,12 @@
 "소화 시킬 수 있다."
 
 #. Tag: term
-#: best_practices.xml:145
 #, fuzzy, no-c-format
 msgid "In a three tiered architecture, consider using detached objects:"
 msgstr ""
 "3-tier 아키텍처에서, <literal>saveOrUpdate()</literal> 사용을 고려하라."
 
 #. Tag: para
-#: best_practices.xml:147
 #, fuzzy, no-c-format
 msgid ""
 "When using a servlet/session bean architecture, you can pass persistent "
@@ -259,14 +235,12 @@
 "</literal>를 사용하라."
 
 #. Tag: term
-#: best_practices.xml:156
 #, fuzzy, no-c-format
 msgid "In a two tiered architecture, consider using long persistence contexts:"
 msgstr ""
 "2-tier 아키텍처에서, 수명이 긴 영속 컨텍스트들을 사용하는 것을 고려하라."
 
 #. Tag: para
-#: best_practices.xml:158
 #, fuzzy, no-c-format
 msgid ""
 "Database Transactions have to be as short as possible for best scalability. "
@@ -295,13 +269,11 @@
 "이다."
 
 #. Tag: term
-#: best_practices.xml:172
 #, fuzzy, no-c-format
 msgid "Do not treat exceptions as recoverable:"
 msgstr "예외상황들을 복구가능한 것으로서 다루지 말라."
 
 #. Tag: para
-#: best_practices.xml:174
 #, fuzzy, no-c-format
 msgid ""
 "This is more of a necessary practice than a \"best\" practice. When an "
@@ -321,13 +293,11 @@
 "get()</literal> 또는 하나의 질의를 사용하라."
 
 #. Tag: term
-#: best_practices.xml:184
 #, fuzzy, no-c-format
 msgid "Prefer lazy fetching for associations:"
 msgstr "연관들에 대한 lazy 페칭을 선호하라."
 
 #. Tag: para
-#: best_practices.xml:186
 #, fuzzy, no-c-format
 msgid ""
 "Use eager fetching sparingly. Use proxies and lazy collections for most "
@@ -346,7 +316,6 @@
 "절할 때, 하나의 <literal>left join fetch</literal>를 가진 질의를 사용하라."
 
 #. Tag: term
-#: best_practices.xml:196
 #, fuzzy, no-c-format
 msgid ""
 "Use the <emphasis>open session in view</emphasis> pattern, or a disciplined "
@@ -357,7 +326,6 @@
 "단계(assembly phase)</emphasis>를 사용하라."
 
 #. Tag: para
-#: best_practices.xml:201
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate frees the developer from writing tedious <emphasis>Data Transfer "
@@ -387,13 +355,11 @@
 "다."
 
 #. Tag: term
-#: best_practices.xml:215
 #, fuzzy, no-c-format
 msgid "Consider abstracting your business logic from Hibernate:"
 msgstr "Hibernate에서 당신의 비지니스 로직을 추상화 시키는 것을 고려하라."
 
 #. Tag: para
-#: best_practices.xml:217
 #, fuzzy, no-c-format
 msgid ""
 "Hide Hibernate data-access code behind an interface. Combine the "
@@ -411,13 +377,11 @@
 "을 가진 어플리케이션에 대해서는 적절하지 않다!)"
 
 #. Tag: term
-#: best_practices.xml:227
 #, fuzzy, no-c-format
 msgid "Do not use exotic association mappings:"
 msgstr "신종의 연관 매핑을 사용하지 말라."
 
 #. Tag: para
-#: best_practices.xml:229
 #, fuzzy, no-c-format
 msgid ""
 "Practical test cases for real many-to-many associations are rare. Most of "
@@ -435,13 +399,11 @@
 "를 당신 스스로 질문하라."
 
 #. Tag: term
-#: best_practices.xml:239
 #, fuzzy, no-c-format
 msgid "Prefer bidirectional associations:"
 msgstr "양방향 연관들을 선호하라."
 
 #. Tag: para
-#: best_practices.xml:241
 #, no-c-format
 msgid ""
 "Unidirectional associations are more difficult to query. In a large "

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/bibliography.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/bibliography.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/bibliography.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -5,7 +5,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: 2009-07-14 19:55+0000\n"
 "Last-Translator: Automatically generated\n"
 "Language-Team: none\n"
@@ -14,55 +14,36 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: bibliography.xml:27
 #, no-c-format
 msgid "References"
 msgstr ""
 
 #. Tag: title
-#: bibliography.xml:31
 #, no-c-format
 msgid "Patterns of Enterprise Application Architecture"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:34
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Martin</firstname> <surname>Fowler</surname>"
+msgid "Martin"
 msgstr ""
 
-#. Tag: holder
-#: bibliography.xml:41
-#, no-c-format
-msgid "Pearson Education, Inc."
-msgstr ""
-
 #. Tag: title
-#: bibliography.xml:50
 #, no-c-format
 msgid "Java Persistence with Hibernate"
 msgstr ""
 
 #. Tag: subtitle
-#: bibliography.xml:51
 #, no-c-format
 msgid "Second Edition of Hibernate in Action"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:57
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Christian</firstname> <surname>Bauer</surname>"
+msgid "Christian"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:61
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Gavin</firstname> <surname>King</surname>"
+msgid "Gavin"
 msgstr ""
-
-#. Tag: holder
-#: bibliography.xml:68
-#, no-c-format
-msgid "Manning Publications Co."
-msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/collection_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/collection_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/collection_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,19 +11,16 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: collection_mapping.xml:29
 #, fuzzy, no-c-format
 msgid "Collection mapping"
 msgstr "콜렉션 매핑들"
 
 #. Tag: title
-#: collection_mapping.xml:32
 #, no-c-format
 msgid "Persistent collections"
 msgstr "영속 콜렉션들"
 
 #. Tag: para
-#: collection_mapping.xml:34
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate requires that persistent collection-valued fields be declared as "
@@ -32,23 +29,7 @@
 "예를 들어 Hibernate는 영속 콜렉션-값을 가진 필드들이 인터페이스 타입으로서 선"
 "언될 것을 필요로 한다:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:39
-#, no-c-format
-msgid ""
-"<![CDATA[public class Product {\n"
-"    private String serialNumber;\n"
-"    private Set parts = new HashSet();\n"
-"    \n"
-"    public Set getParts() { return parts; }\n"
-"    void setParts(Set parts) { this.parts = parts; }\n"
-"    public String getSerialNumber() { return serialNumber; }\n"
-"    void setSerialNumber(String sn) { serialNumber = sn; }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:41
 #, fuzzy, no-c-format
 msgid ""
 "The actual interface might be <literal>java.util.Set</literal>, "
@@ -66,7 +47,6 @@
 "UserCollectionType</literal>에 대한 구현을 작성해야 함을 의미한다.)"
 
 #. Tag: para
-#: collection_mapping.xml:50
 #, fuzzy, no-c-format
 msgid ""
 "Notice how the instance variable was initialized with an instance of "
@@ -85,23 +65,7 @@
 "Hibernate 자신의 구현의 인스턴스로 대체시킬 것이다. 다음과 같은 오류들을 관찰"
 "하라:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:60
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = new DomesticCat();\n"
-"Cat kitten = new DomesticCat();\n"
-"....\n"
-"Set kittens = new HashSet();\n"
-"kittens.add(kitten);\n"
-"cat.setKittens(kittens);\n"
-"session.persist(cat);\n"
-"kittens = cat.getKittens(); // Okay, kittens collection is a Set\n"
-"(HashSet) cat.getKittens(); // Error!]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:62
 #, fuzzy, no-c-format
 msgid ""
 "The persistent collections injected by Hibernate behave like "
@@ -115,7 +79,6 @@
 "이 행위한다."
 
 #. Tag: para
-#: collection_mapping.xml:69
 #, fuzzy, no-c-format
 msgid ""
 "Collections instances have the usual behavior of value types. They are "
@@ -136,7 +99,6 @@
 "Hibernate는 null 콜렉션 참조와 공백의 콜렉션 사이를 구별 짓지 않는다."
 
 #. Tag: para
-#: collection_mapping.xml:80
 #, fuzzy, no-c-format
 msgid ""
 "Use persistent collections the same way you use ordinary Java collections. "
@@ -149,13 +111,11 @@
 "됨)."
 
 #. Tag: title
-#: collection_mapping.xml:89
 #, no-c-format
 msgid "Collection mappings"
 msgstr "콜렉션 매핑들"
 
 #. Tag: para
-#: collection_mapping.xml:92
 #, fuzzy, no-c-format
 msgid ""
 "There are quite a range of mappings that can be generated for collections "
@@ -168,7 +128,6 @@
 "방법을 당신이 느끼려면 스키마 생성 도구로 실험할 것을 우리는 제안한다."
 
 #. Tag: para
-#: collection_mapping.xml:99
 #, fuzzy, no-c-format
 msgid ""
 "The Hibernate mapping element used for mapping a collection depends upon the "
@@ -179,21 +138,7 @@
 "다. 예를 들어<literal>&lt;set&gt;</literal> 요소는 <literal>Set</literal> 타"
 "입의 매핑 프로퍼티들에 사용된다"
 
-#. Tag: programlisting
-#: collection_mapping.xml:105
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Product\">\n"
-"    <id name=\"serialNumber\" column=\"productSerialNumber\"/>\n"
-"    <set name=\"parts\">\n"
-"        <key column=\"productSerialNumber\" not-null=\"true\"/>\n"
-"        <one-to-many class=\"Part\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:107
 #, no-c-format
 msgid ""
 "Apart from <literal>&lt;set&gt;</literal>, there is also <literal>&lt;"
@@ -207,43 +152,12 @@
 "<literal>&lt;array&gt;</literal>, 그리고 <literal>&lt;map&gt;</literal> 매핑 "
 "요소들이 존재한다. <literal>&lt;map&gt;</literal> 요소가 대표적이다:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:132
-#, no-c-format
-msgid ""
-"<![CDATA[<map\n"
-"    name=\"propertyName\"\n"
-"    table=\"table_name\"\n"
-"    schema=\"schema_name\"\n"
-"    lazy=\"true|extra|false\"\n"
-"    inverse=\"true|false\"\n"
-"    cascade=\"all|none|save-update|delete|all-delete-orphan|delete-orphan\"\n"
-"    sort=\"unsorted|natural|comparatorClass\"\n"
-"    order-by=\"column_name asc|desc\"\n"
-"    where=\"arbitrary sql where condition\"\n"
-"    fetch=\"join|select|subselect\"\n"
-"    batch-size=\"N\"\n"
-"    access=\"field|property|ClassName\"\n"
-"    optimistic-lock=\"true|false\"\n"
-"    mutable=\"true|false\"\n"
-"    node=\"element-name|.\"\n"
-"    embed-xml=\"true|false\"\n"
-">\n"
-"\n"
-"    <key .... />\n"
-"    <map-key .... />\n"
-"    <element .... />\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:135
 #, fuzzy, no-c-format
 msgid "<literal>name</literal>: the collection property name"
 msgstr "<literal>name</literal> 콜렉션 프로퍼티 이름"
 
 #. Tag: para
-#: collection_mapping.xml:140
 #, fuzzy, no-c-format
 msgid ""
 "<literal>table</literal> (optional - defaults to property name): the name of "
@@ -253,7 +167,6 @@
 "(one-to-many 연관관계들에 대해서는 사용되지 않음)"
 
 #. Tag: para
-#: collection_mapping.xml:146
 #, fuzzy, no-c-format
 msgid ""
 "<literal>schema</literal> (optional): the name of a table schema to override "
@@ -263,7 +176,6 @@
 "키는 테이블 스키마의 이름"
 
 #. Tag: para
-#: collection_mapping.xml:152
 #, fuzzy, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>true</literal>): "
@@ -278,7 +190,6 @@
 "용 가능하도록 하는데(매우 큰 콜렉션들에 적당함) 사용될 수 있다"
 
 #. Tag: para
-#: collection_mapping.xml:161
 #, fuzzy, no-c-format
 msgid ""
 "<literal>inverse</literal> (optional - defaults to <literal>false</"
@@ -289,7 +200,6 @@
 "션을 양방향 연관관계의 \"inverse\" 끝(end)으로 표시한다"
 
 #. Tag: para
-#: collection_mapping.xml:167
 #, fuzzy, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional - defaults to <literal>none</literal>): "
@@ -299,7 +209,6 @@
 "션들이 자식 엔티티들에 대해 케스케이드하는 것을 이용 가능하게 한다"
 
 #. Tag: para
-#: collection_mapping.xml:173
 #, fuzzy, no-c-format
 msgid ""
 "<literal>sort</literal> (optional): specifies a sorted collection with "
@@ -309,7 +218,6 @@
 "(sorted) 콜렉션 또는 주어진 comparator 클래스를 지정한다"
 
 #. Tag: para
-#: collection_mapping.xml:179
 #, fuzzy, no-c-format
 msgid ""
 "<literal>order-by</literal> (optional, JDK1.4 only): specifies a table "
@@ -322,7 +230,6 @@
 "literal> 또는 bag의 반복 순서를 정의하는 테이블 컬럼(또는 컬럼들)을 지정한다"
 
 #. Tag: para
-#: collection_mapping.xml:186
 #, fuzzy, no-c-format
 msgid ""
 "<literal>where</literal> (optional): specifies an arbitrary SQL "
@@ -335,7 +242,6 @@
 "이터의 부분집합 만을 포함할 경우에 유용하다)"
 
 #. Tag: para
-#: collection_mapping.xml:193
 #, fuzzy, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional, defaults to <literal>select</literal>): "
@@ -347,7 +253,6 @@
 "선택하라."
 
 #. Tag: para
-#: collection_mapping.xml:200
 #, fuzzy, no-c-format
 msgid ""
 "<literal>batch-size</literal> (optional, defaults to <literal>1</literal>): "
@@ -357,7 +262,6 @@
 "의 lazily fetching 인스턴스에 대해 \"배치 사이즈\"를 지정하라."
 
 #. Tag: para
-#: collection_mapping.xml:206
 #, fuzzy, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
@@ -368,7 +272,6 @@
 "Hibernate가 콜렉션 프로퍼티 값에 접근하는데 사용할 방도."
 
 #. Tag: para
-#: collection_mapping.xml:212
 #, fuzzy, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
@@ -382,7 +285,6 @@
 "하는 것이 종종 합당하다.)"
 
 #. Tag: para
-#: collection_mapping.xml:220
 #, fuzzy, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>true</literal>): "
@@ -395,13 +297,11 @@
 "다. (몇몇 경우들에서 마이너 퍼포먼스 최적화)."
 
 #. Tag: title
-#: collection_mapping.xml:230
 #, no-c-format
 msgid "Collection foreign keys"
 msgstr "콜렉션 foreign 키들"
 
 #. Tag: para
-#: collection_mapping.xml:232
 #, fuzzy, no-c-format
 msgid ""
 "Collection instances are distinguished in the database by the foreign key of "
@@ -416,7 +316,6 @@
 "<literal>&lt;key&gt;</literal> 요소에 의해 매핑된다."
 
 #. Tag: para
-#: collection_mapping.xml:240
 #, fuzzy, no-c-format
 msgid ""
 "There can be a nullability constraint on the foreign key column. For most "
@@ -429,14 +328,7 @@
 "우, foreign 키는 디폴트로 null 허용 가능하여서, 당신은 <literal>not-null="
 "\"true\"</literal>를 지정할 필요가 있을 수 있다."
 
-#. Tag: programlisting
-#: collection_mapping.xml:247
-#, no-c-format
-msgid "<![CDATA[<key column=\"productSerialNumber\" not-null=\"true\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:249
 #, fuzzy, no-c-format
 msgid ""
 "The foreign key constraint can use <literal>ON DELETE CASCADE</literal>."
@@ -444,14 +336,7 @@
 "foreign 키 컨스트레인트는 <literal>ON DELETE CASCADE</literal>를 사용할 수도 "
 "있다."
 
-#. Tag: programlisting
-#: collection_mapping.xml:253
-#, no-c-format
-msgid "<![CDATA[<key column=\"productSerialNumber\" on-delete=\"cascade\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:255
 #, no-c-format
 msgid ""
 "See the previous chapter for a full definition of the <literal>&lt;key&gt;</"
@@ -459,13 +344,11 @@
 msgstr "<literal>&lt;key&gt;</literal> 요소에 대한 전체 정의는 앞 장을 보라."
 
 #. Tag: title
-#: collection_mapping.xml:263
 #, no-c-format
 msgid "Collection elements"
 msgstr "콜렉션 요소들"
 
 #. Tag: para
-#: collection_mapping.xml:265
 #, fuzzy, no-c-format
 msgid ""
 "Collections can contain almost any other Hibernate type, including: basic "
@@ -484,7 +367,6 @@
 "들 사이의 \"링크\" 만이 그 콜렉션에 의해 소유된 상태로 간주된다."
 
 #. Tag: para
-#: collection_mapping.xml:274
 #, no-c-format
 msgid ""
 "The contained type is referred to as the <emphasis>collection element type</"
@@ -502,13 +384,11 @@
 "데 사용된다."
 
 #. Tag: title
-#: collection_mapping.xml:286
 #, no-c-format
 msgid "Indexed collections"
 msgstr "인덱싱 된 콜렉션들"
 
 #. Tag: para
-#: collection_mapping.xml:288
 #, fuzzy, no-c-format
 msgid ""
 "All collection mappings, except those with set and bag semantics, need an "
@@ -534,56 +414,74 @@
 "</literal> 요소를 사용하여 매핑된다. 매핑된 컬럼은 순차적인 정수들을 포함한다"
 "(디폴트로 0에서 시작하는 번호가 붙여짐)."
 
-#. Tag: sect2
-#: collection_mapping.xml:299
-#, no-c-format
+#. Tag: para
+#, fuzzy, no-c-format
 msgid ""
-"<programlistingco> <areaspec> <area id=\"index1\" coords=\"2 45\"/> <area id="
-"\"index2\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA[<list-"
-"index \n"
-"        column=\"column_name\"\n"
-"        base=\"0|1|...\"/>]]></programlisting> <calloutlist> <callout "
-"arearefs=\"index1\"> <para> <literal>column_name</literal> (required): the "
-"name of the column holding the collection index values. </para> </callout> "
-"<callout arearefs=\"index1\"> <para> <literal>base</literal> (optional - "
-"defaults to <literal>0</literal>): the value of the index column that "
-"corresponds to the first element of the list or array. </para> </callout> </"
-"calloutlist> </programlistingco> <programlistingco> <areaspec> <area id="
-"\"mapkey1\" coords=\"2 45\"/> <area id=\"mapkey2\" coords=\"3 45\"/> <area "
-"id=\"mapkey3\" coords=\"4 45\"/> </areaspec> <programlisting><![CDATA[<map-"
-"key \n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        type=\"type_name\"\n"
-"        node=\"@attribute-name\"\n"
-"        length=\"N\"/>]]></programlisting> <calloutlist> <callout arearefs="
-"\"mapkey1\"> <para> <literal>column</literal> (optional): the name of the "
-"column holding the collection index values. </para> </callout> <callout "
-"arearefs=\"mapkey2\"> <para> <literal>formula</literal> (optional): a SQL "
-"formula used to evaluate the key of the map. </para> </callout> <callout "
-"arearefs=\"mapkey3\"> <para> <literal>type</literal> (required): the type of "
-"the map keys. </para> </callout> </calloutlist> </programlistingco> "
-"<programlistingco> <areaspec> <area id=\"indexmanytomany1\" coords=\"2 45\"/"
-"> <area id=\"indexmanytomany2\" coords=\"3 45\"/> <area id=\"indexmanytomany3"
-"\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA[<map-key-many-to-"
-"many\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        class=\"ClassName\"\n"
-"/>]]></programlisting> <calloutlist> <callout arearefs=\"indexmanytomany1\"> "
-"<para> <literal>column</literal> (optional): the name of the foreign key "
-"column for the collection index values. </para> </callout> <callout arearefs="
-"\"indexmanytomany2\"> <para> <literal>formula</literal> (optional): a SQ "
-"formula used to evaluate the foreign key of the map key. </para> </callout> "
-"<callout arearefs=\"indexmanytomany3\"> <para> <literal>class</literal> "
-"(required): the entity class used as the map key. </para> </callout> </"
-"calloutlist> </programlistingco>"
+"<literal>column_name</literal> (required): the name of the column holding "
+"the collection index values."
 msgstr ""
+"<literal>column_name</literal> (필수): 콜렉션 인덱스 값들을 보관하는 컬럼의 "
+"이름."
 
 #. Tag: para
-#: collection_mapping.xml:380
 #, fuzzy, no-c-format
 msgid ""
+"<literal>base</literal> (optional - defaults to <literal>0</literal>): the "
+"value of the index column that corresponds to the first element of the list "
+"or array."
+msgstr ""
+"<literal>base</literal> (옵션, 디폴트는 <literal>0</literal>): 리스트 또는 배"
+"열의 첫 번째 요소에 대응하는 인덱스 컬럼의 값."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"<literal>column</literal> (optional): the name of the column holding the "
+"collection index values."
+msgstr ""
+"<literal>column</literal> (옵션): 콜렉션 인덱스 값들을 보관하는 컬럼의 이름."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"<literal>formula</literal> (optional): a SQL formula used to evaluate the "
+"key of the map."
+msgstr ""
+"<literal>formula</literal> (옵션): map의 키를 평가하는데 사용되는 SQL "
+"formula."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>type</literal> (required): the type of the map keys."
+msgstr "<literal>type</literal> (필수): The type of the map 키들의 타입"
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"<literal>column</literal> (optional): the name of the foreign key column for "
+"the collection index values."
+msgstr ""
+"<literal>column</literal> (옵션): 콜렉션 인덱스 값들에 대한 foreign 키 컬럼"
+"의 이름."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"<literal>formula</literal> (optional): a SQ formula used to evaluate the "
+"foreign key of the map key."
+msgstr ""
+"<literal>formula</literal> (옵션): map의 foreign 키를 평가하는데 사용되는 "
+"SQL formula."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"<literal>class</literal> (required): the entity class used as the map key."
+msgstr "<literal>class</literal> (필수): map 키로서 사용되는 엔티티 클래스."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
 "If your table does not have an index column, and you still wish to use "
 "<literal>List</literal> as the property type, you can map the property as a "
 "Hibernate <emphasis>&lt;bag&gt;</emphasis>. A bag does not retain its order "
@@ -597,13 +495,11 @@
 "로 정렬(sorting)되거나 ordering될 수도 있다."
 
 #. Tag: title
-#: collection_mapping.xml:390
 #, no-c-format
 msgid "Collections of values and many-to-many associations"
 msgstr "값들을 가진 콜렉션들과 many-to-many 연관들"
 
 #. Tag: para
-#: collection_mapping.xml:392
 #, fuzzy, no-c-format
 msgid ""
 "Any collection of values or many-to-many associations requires a dedicated "
@@ -616,7 +512,6 @@
 "들이나 컬럼들을 가진 전용 <emphasis>콜렉션 테이블</emphasis>을 필요로 한다."
 
 #. Tag: para
-#: collection_mapping.xml:399
 #, fuzzy, no-c-format
 msgid ""
 "For a collection of values use the <literal>&lt;element&gt;</literal> tag. "
@@ -625,101 +520,133 @@
 "값들을 가진 콜렉션의 경우, 우리는 <literal>&lt;element&gt;</literal> 태그를 "
 "사용한다."
 
-#. Tag: sect2
-#: collection_mapping.xml:401
-#, no-c-format
+#. Tag: para
+#, fuzzy, no-c-format
 msgid ""
-"<programlistingco> <areaspec> <area id=\"element1b\" coords=\"2 50\"/> <area "
-"id=\"element2b\" coords=\"3 50\"/> <area id=\"element3b\" coords=\"4 50\"/> "
-"</areaspec> <programlisting><![CDATA[<element\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        type=\"typename\"\n"
-"        length=\"L\"\n"
-"        precision=\"P\"\n"
-"        scale=\"S\"\n"
-"        not-null=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        node=\"element-name\"\n"
-"/>]]></programlisting> <calloutlist> <callout arearefs=\"element1b\"> <para> "
 "<literal>column</literal> (optional): the name of the column holding the "
-"collection element values. </para> </callout> <callout arearefs=\"element2b"
-"\"> <para> <literal>formula</literal> (optional): an SQL formula used to "
-"evaluate the element. </para> </callout> <callout arearefs=\"element3b\"> "
-"<para> <literal>type</literal> (required): the type of the collection "
-"element. </para> </callout> </calloutlist> </programlistingco> <para> A "
-"<emphasis>many-to-many association</emphasis> is specified using the "
-"<literal>&lt;many-to-many&gt;</literal> element. </para> <programlistingco> "
-"<areaspec> <area id=\"manytomany1\" coords=\"2 60\"/> <area id=\"manytomany2"
-"\" coords=\"3 60\"/> <area id=\"manytomany3\" coords=\"4 60\"/> <area id="
-"\"manytomany4\" coords=\"5 60\"/> <area id=\"manytomany5\" coords=\"6 60\"/> "
-"<area id=\"manytomany6\" coords=\"7 60\"/> <area id=\"manytomany7\" coords="
-"\"8 60\"/> <area id=\"manytomany8\" coords=\"9 60\"/> </areaspec> "
-"<programlisting><![CDATA[<many-to-many\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        class=\"ClassName\"\n"
-"        fetch=\"select|join\"\n"
-"        unique=\"true|false\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        node=\"element-name\"\n"
-"        embed-xml=\"true|false\"\n"
-"    />]]></programlisting> <calloutlist> <callout arearefs=\"manytomany1\"> "
-"<para> <literal>column</literal> (optional): the name of the element foreign "
-"key column. </para> </callout> <callout arearefs=\"manytomany2\"> <para> "
+"collection element values."
+msgstr ""
+"<literal>column</literal> (옵션): 콜렉션 요소 값들을 소유하는 컬럼의 이름."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
 "<literal>formula</literal> (optional): an SQL formula used to evaluate the "
-"element foreign key value. </para> </callout> <callout arearefs=\"manytomany3"
-"\"> <para> <literal>class</literal> (required): the name of the associated "
-"class. </para> </callout> <callout arearefs=\"manytomany4\"> <para> "
+"element."
+msgstr ""
+"<literal>formula</literal> (옵션): 요소를 평가하는데 사용되는 SQL formula."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>type</literal> (required): the type of the collection element."
+msgstr "<literal>type</literal> (필수): 콜렉션 요소의 타입."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"A <emphasis>many-to-many association</emphasis> is specified using the "
+"<literal>&lt;many-to-many&gt;</literal> element."
+msgstr ""
+"<emphasis>many-to-many association</emphasis> 연관은 <literal>&lt;many-to-"
+"many&gt;</literal> 요소를 사용하여 지정된다."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"<literal>column</literal> (optional): the name of the element foreign key "
+"column."
+msgstr "<literal>column</literal> (옵션): 요소 foreign 키 컬럼의 이름."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"<literal>formula</literal> (optional): an SQL formula used to evaluate the "
+"element foreign key value."
+msgstr ""
+"<literal>formula</literal> (옵션): 요소 foreign 키 값을 평가하는데 사용되는 "
+"SQL formula."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>class</literal> (required): the name of the associated class."
+msgstr "<literal>class</literal> (필수): 연관된 클래스의 이름."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
 "<literal>fetch</literal> (optional - defaults to <literal>join</literal>): "
 "enables outer-join or sequential select fetching for this association. This "
 "is a special case; for full eager fetching in a single <literal>SELECT</"
 "literal> of an entity and its many-to-many relationships to other entities, "
 "you would enable <literal>join</literal> fetching,not only of the collection "
 "itself, but also with this attribute on the <literal>&lt;many-to-many&gt;</"
-"literal> nested element. </para> </callout> <callout arearefs=\"manytomany5"
-"\"> <para> <literal>unique</literal> (optional): enables the DDL generation "
-"of a unique constraint for the foreign-key column. This makes the "
-"association multiplicity effectively one-to-many. </para> </callout> "
-"<callout arearefs=\"manytomany6\"> <para> <literal>not-found</literal> "
-"(optional - defaults to <literal>exception</literal>): specifies how foreign "
-"keys that reference missing rows will be handled: <literal>ignore</literal> "
-"will treat a missing row as a null association. </para> </callout> <callout "
-"arearefs=\"manytomany7\"> <para> <literal>entity-name</literal> (optional): "
-"the entity name of the associated class, as an alternative to "
-"<literal>class</literal>. </para> </callout> <callout arearefs=\"manytomany8"
-"\"> <para> <literal>property-ref</literal> (optional): the name of a "
-"property of the associated class that is joined to this foreign key. If not "
-"specified, the primary key of the associated class is used. </para> </"
-"callout> </calloutlist> </programlistingco>"
+"literal> nested element."
 msgstr ""
+"<literal>fetch</literal> (옵션 - 디폴트는 <literal>join</literal>): 이 연관"
+"에 대해 outer-join 페칭 또는 sequential select 페칭을 이용 가능하게 만든다. "
+"이것은 특별한 경우이다; 엔티티 그리고 다른 엔티티들과 그것의 many-to-many 관"
+"계들에 대한 (하나의 <literal>SELECT</literal> 내에서) 전체 eager 페칭의 경"
+"우, 당신은 콜렉션 그 자체에 대해서 뿐만 아니라 내포된 요소 <literal>&lt;many-"
+"to-many&gt;</literal> 상의 이 속성에 대해 <literal>join</literal> 페칭을 이"
+"용 가능하게 할 것이다."
 
 #. Tag: para
-#: collection_mapping.xml:506
+#, fuzzy, no-c-format
+msgid ""
+"<literal>unique</literal> (optional): enables the DDL generation of a unique "
+"constraint for the foreign-key column. This makes the association "
+"multiplicity effectively one-to-many."
+msgstr ""
+"<literal>unique</literal> (옵션): foreign-key 컬럼에 대한 유일 컨스트레인트"
+"의 DDL 생성을 가능하도록 한다. 이것은 연관 다중성 (association multiplicity)"
+"을 효율적으로 one to many로 만든다."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"<literal>not-found</literal> (optional - defaults to <literal>exception</"
+"literal>): specifies how foreign keys that reference missing rows will be "
+"handled: <literal>ignore</literal> will treat a missing row as a null "
+"association."
+msgstr ""
+"<literal>not-found</literal> (옵션 - 디폴트는 <literal>exception</literal>): "
+"누락된 행들을 참조하는 foreign 키들이 어떻게 처리될 것인지를 지정한다: "
+"<literal>ignore</literal>는 누락된 한 행을 한 개의 연관으로 다룰 것이다."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"<literal>entity-name</literal> (optional): the entity name of the associated "
+"class, as an alternative to <literal>class</literal>."
+msgstr ""
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"<literal>entity-name</literal> (옵션): <literal>class</literal>에 대한 하나"
+"의 대안으로서, 연관된 클래스의 엔티티 이름.\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"<literal>entity-name</literal> (옵션): <literal>class</literal>에 대한 대안으"
+"로서, 연관된 클래스의 엔티티 이름."
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"<literal>property-ref</literal> (optional): the name of a property of the "
+"associated class that is joined to this foreign key. If not specified, the "
+"primary key of the associated class is used."
+msgstr ""
+"<literal>property-ref</literal>: (옵션) 이 foreign 키에 조인된 연관 클래스의 "
+"프로퍼티의 이름. 지정되지 않을 경우, 연관 클래스의 프라이머리 키가 사용된다."
+
+#. Tag: para
 #, no-c-format
 msgid "Here are some examples."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:509
 #, no-c-format
 msgid "A set of strings:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:513
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"names\" table=\"person_names\">\n"
-"    <key column=\"person_id\"/>\n"
-"    <element column=\"person_name\" type=\"string\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:515
 #, fuzzy, no-c-format
 msgid ""
 "A bag containing integers with an iteration order determined by the "
@@ -728,87 +655,27 @@
 "(<literal>order-by</literal> 속성에 의해 결정되는 반복 순서를 가진) 정수들을 "
 "포함하는 bag :"
 
-#. Tag: programlisting
-#: collection_mapping.xml:520
-#, no-c-format
-msgid ""
-"<![CDATA[<bag name=\"sizes\" \n"
-"        table=\"item_sizes\" \n"
-"        order-by=\"size asc\">\n"
-"    <key column=\"item_id\"/>\n"
-"    <element column=\"size\" type=\"integer\"/>\n"
-"</bag>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:522
 #, fuzzy, no-c-format
 msgid "An array of entities, in this case, a many-to-many association:"
 msgstr "엔티티들을 가진 배열 - 이 경우에, many to many 연관 :"
 
-#. Tag: programlisting
-#: collection_mapping.xml:526
-#, no-c-format
-msgid ""
-"<![CDATA[<array name=\"addresses\" \n"
-"        table=\"PersonAddress\" \n"
-"        cascade=\"persist\">\n"
-"    <key column=\"personId\"/>\n"
-"    <list-index column=\"sortOrder\"/>\n"
-"    <many-to-many column=\"addressId\" class=\"Address\"/>\n"
-"</array>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:528
 #, no-c-format
 msgid "A map from string indices to dates:"
 msgstr "날짜들에 대한 문자열 인덱스들을 가진 map :"
 
-#. Tag: programlisting
-#: collection_mapping.xml:532
-#, no-c-format
-msgid ""
-"<![CDATA[<map name=\"holidays\" \n"
-"        table=\"holidays\" \n"
-"        schema=\"dbo\" \n"
-"        order-by=\"hol_name asc\">\n"
-"    <key column=\"id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date\" type=\"date\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:534
 #, fuzzy, no-c-format
 msgid "A list of components (this is discussed in the next chapter):"
 msgstr "컴포넌트들의 리스트(다음 장에서 논의됨):"
 
-#. Tag: programlisting
-#: collection_mapping.xml:538
-#, no-c-format
-msgid ""
-"<![CDATA[<list name=\"carComponents\" \n"
-"        table=\"CarComponents\">\n"
-"    <key column=\"carId\"/>\n"
-"    <list-index column=\"sortOrder\"/>\n"
-"    <composite-element class=\"CarComponent\">\n"
-"        <property name=\"price\"/>\n"
-"        <property name=\"type\"/>\n"
-"        <property name=\"serialNumber\" column=\"serialNum\"/>\n"
-"    </composite-element>\n"
-"</list>]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:543
 #, no-c-format
 msgid "One-to-many associations"
 msgstr "One-to-many 연관들"
 
 #. Tag: para
-#: collection_mapping.xml:545
 #, fuzzy, no-c-format
 msgid ""
 "A <emphasis>one-to-many association</emphasis> links the tables of two "
@@ -820,7 +687,6 @@
 "렉션들의 어떤 의미를 상실한다:"
 
 #. Tag: para
-#: collection_mapping.xml:553
 #, fuzzy, no-c-format
 msgid ""
 "An instance of the contained entity class cannot belong to more than one "
@@ -830,7 +696,6 @@
 "않을 수 있다"
 
 #. Tag: para
-#: collection_mapping.xml:559
 #, fuzzy, no-c-format
 msgid ""
 "An instance of the contained entity class cannot appear at more than one "
@@ -840,7 +705,6 @@
 "지 않을 수 있다"
 
 #. Tag: para
-#: collection_mapping.xml:566
 #, fuzzy, no-c-format
 msgid ""
 "An association from <literal>Product</literal> to <literal>Part</literal> "
@@ -853,28 +717,8 @@
 "한다. <literal>&lt;one-to-many&gt;</literal> 태그는 이것이 one to many 연관임"
 "을 나타낸다."
 
-#. Tag: programlisting
-#: collection_mapping.xml:579
-#, no-c-format
-msgid ""
-"<![CDATA[<one-to-many \n"
-"        class=\"ClassName\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\"\n"
-"        embed-xml=\"true|false\"\n"
-"    />]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:582
 #, fuzzy, no-c-format
-msgid "<literal>class</literal> (required): the name of the associated class."
-msgstr "<literal>class</literal> (필수): 연관된 클래스의 이름."
-
-#. Tag: para
-#: collection_mapping.xml:587
-#, fuzzy, no-c-format
 msgid ""
 "<literal>not-found</literal> (optional - defaults to <literal>exception</"
 "literal>): specifies how cached identifiers that reference missing rows will "
@@ -886,23 +730,8 @@
 "<literal>ignore</literal>는 누락된 한 행을 한 개의 연관으로 다룰 것이다."
 
 #. Tag: para
-#: collection_mapping.xml:594
 #, fuzzy, no-c-format
 msgid ""
-"<literal>entity-name</literal> (optional): the entity name of the associated "
-"class, as an alternative to <literal>class</literal>."
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>entity-name</literal> (옵션): <literal>class</literal>에 대한 하나"
-"의 대안으로서, 연관된 클래스의 엔티티 이름.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>entity-name</literal> (옵션): <literal>class</literal>에 대한 대안으"
-"로서, 연관된 클래스의 엔티티 이름."
-
-#. Tag: para
-#: collection_mapping.xml:602
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>&lt;one-to-many&gt;</literal> element does not need to declare "
 "any columns. Nor is it necessary to specify the <literal>table</literal> "
 "name anywhere."
@@ -912,7 +741,6 @@
 "수적이지 않다."
 
 #. Tag: para
-#: collection_mapping.xml:609
 #, fuzzy, no-c-format
 msgid ""
 "If the foreign key column of a <literal>&lt;one-to-many&gt;</literal> "
@@ -930,7 +758,6 @@
 "들에 대한 논의는 이 장의 뒷부분을 보라."
 
 #. Tag: para
-#: collection_mapping.xml:619
 #, fuzzy, no-c-format
 msgid ""
 "The following example shows a map of <literal>Part</literal> entities by "
@@ -941,32 +768,17 @@
 "기서 <literal>partName</literal>은 <literal>Part</literal>의 영속 프로퍼티이"
 "다). formula-기반 index의 사용을 주목하라."
 
-#. Tag: programlisting
-#: collection_mapping.xml:625
-#, no-c-format
-msgid ""
-"<![CDATA[<map name=\"parts\"\n"
-"        cascade=\"all\">\n"
-"    <key column=\"productId\" not-null=\"true\"/>\n"
-"    <map-key formula=\"partName\"/>\n"
-"    <one-to-many class=\"Part\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:631
 #, no-c-format
 msgid "Advanced collection mappings"
 msgstr "개선된 콜렉션 매핑들"
 
 #. Tag: title
-#: collection_mapping.xml:634
 #, no-c-format
 msgid "Sorted collections"
 msgstr "Sorted 콜렉션들"
 
 #. Tag: para
-#: collection_mapping.xml:636
 #, no-c-format
 msgid ""
 "Hibernate supports collections implementing <literal>java.util.SortedMap</"
@@ -977,26 +789,7 @@
 "SortedSet</literal>를 구현하는 콜렉션들을 지원한다. 당신은 매핑 파일 속에 하"
 "나의 comparator를 지정해야 한다:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:641
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"aliases\" \n"
-"            table=\"person_aliases\" \n"
-"            sort=\"natural\">\n"
-"    <key column=\"person\"/>\n"
-"    <element column=\"name\" type=\"string\"/>\n"
-"</set>\n"
-"\n"
-"<map name=\"holidays\" sort=\"my.custom.HolidayComparator\">\n"
-"    <key column=\"year_id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date\" type=\"date\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:643
 #, no-c-format
 msgid ""
 "Allowed values of the <literal>sort</literal> attribute are "
@@ -1008,7 +801,6 @@
 "구현하는 클래스의 이름이다."
 
 #. Tag: para
-#: collection_mapping.xml:649
 #, no-c-format
 msgid ""
 "Sorted collections actually behave like <literal>java.util.TreeSet</literal> "
@@ -1018,7 +810,6 @@
 "util.TreeMap</literal>처럼 행동한다."
 
 #. Tag: para
-#: collection_mapping.xml:654
 #, fuzzy, no-c-format
 msgid ""
 "If you want the database itself to order the collection elements, use the "
@@ -1035,31 +826,12 @@
 "또는 <literal>LinkedHashMap</literal>을 사용하여 구현된다). 이것은 메모리 내"
 "가 아닌, SQL 질의 내에서 순서지움(ordering)을 수행한다."
 
-#. Tag: programlisting
-#: collection_mapping.xml:663
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"aliases\" table=\"person_aliases\" order-by=\"lower"
-"(name) asc\">\n"
-"    <key column=\"person\"/>\n"
-"    <element column=\"name\" type=\"string\"/>\n"
-"</set>\n"
-"\n"
-"<map name=\"holidays\" order-by=\"hol_date, hol_name\">\n"
-"    <key column=\"year_id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date type=\"date\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:666
 #, no-c-format
 msgid "Note"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:667
 #, fuzzy, no-c-format
 msgid ""
 "The value of the <literal>order-by</literal> attribute is an SQL ordering, "
@@ -1069,7 +841,6 @@
 "순서지움(ordering)임을 노트하라!"
 
 #. Tag: para
-#: collection_mapping.xml:673
 #, fuzzy, no-c-format
 msgid ""
 "Associations can even be sorted by arbitrary criteria at runtime using a "
@@ -1078,22 +849,12 @@
 "연관들은 콜렉션 <literal>filter()</literal>를 사용하여 실행 시에 어떤 임의의 "
 "criteria(기준)을 사용하여 정렬(sort)될 수도 있다."
 
-#. Tag: programlisting
-#: collection_mapping.xml:678
-#, no-c-format
-msgid ""
-"<![CDATA[sortedUsers = s.createFilter( group.getUsers(), \"order by this.name"
-"\" ).list();]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:683
 #, no-c-format
 msgid "Bidirectional associations"
 msgstr "양방향 연관들"
 
 #. Tag: para
-#: collection_mapping.xml:685
 #, fuzzy, no-c-format
 msgid ""
 "A <emphasis>bidirectional association</emphasis> allows navigation from both "
@@ -1104,31 +865,26 @@
 "을 허용한다. 두 가지 종류의 양방향 연관들이 지원된다: <placeholder-1/>"
 
 #. Tag: term
-#: collection_mapping.xml:692
 #, no-c-format
 msgid "one-to-many"
 msgstr "one-to-many"
 
 #. Tag: para
-#: collection_mapping.xml:694
 #, fuzzy, no-c-format
 msgid "set or bag valued at one end and single-valued at the other"
 msgstr "한쪽 끝에 set 또는 bag 값을 갖고, 다른 쪽 긑에 단일 값을 가진 연관"
 
 #. Tag: term
-#: collection_mapping.xml:700
 #, no-c-format
 msgid "many-to-many"
 msgstr "many-to-many"
 
 #. Tag: para
-#: collection_mapping.xml:702
 #, no-c-format
 msgid "set or bag valued at both ends"
 msgstr "양 끝에서 set 또는 bag 값을 가진 연관"
 
 #. Tag: para
-#: collection_mapping.xml:711
 #, fuzzy, no-c-format
 msgid ""
 "You can specify a bidirectional many-to-many association by mapping two many-"
@@ -1141,7 +897,6 @@
 "many 연관을 지정할 수도 있다."
 
 #. Tag: para
-#: collection_mapping.xml:718
 #, fuzzy, no-c-format
 msgid ""
 "Here is an example of a bidirectional many-to-many association that "
@@ -1151,33 +906,7 @@
 "다음은 양방향 many-to-many 연관에 관한 예제이다; 각각의 카테고리는 많은 아이"
 "템들을 가질 수 있고 각각의 아이템은 많은 카테고리들 속에 있을 수 있다:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:723
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Category\">\n"
-"    <id name=\"id\" column=\"CATEGORY_ID\"/>\n"
-"    ...\n"
-"    <bag name=\"items\" table=\"CATEGORY_ITEM\">\n"
-"        <key column=\"CATEGORY_ID\"/>\n"
-"        <many-to-many class=\"Item\" column=\"ITEM_ID\"/>\n"
-"    </bag>\n"
-"</class>\n"
-"\n"
-"<class name=\"Item\">\n"
-"    <id name=\"id\" column=\"ITEM_ID\"/>\n"
-"    ...\n"
-"\n"
-"    <!-- inverse end -->\n"
-"    <bag name=\"categories\" table=\"CATEGORY_ITEM\" inverse=\"true\">\n"
-"        <key column=\"ITEM_ID\"/>\n"
-"        <many-to-many class=\"Category\" column=\"CATEGORY_ID\"/>\n"
-"    </bag>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:725
 #, fuzzy, no-c-format
 msgid ""
 "Changes made only to the inverse end of the association are <emphasis>not</"
@@ -1192,23 +921,7 @@
 "의 또 다른 링크. 만일 당신이 자바 객체 모형에 대해 그리고 자바에서 many-to-"
 "many 관계를 생성시키는 방법에 대해 생각하면 이것은 이해하기가 더 쉽다:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:733
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"category.getItems().add(item);          // The category now \"knows\" about "
-"the relationship\n"
-"item.getCategories().add(category);     // The item now \"knows\" about the "
-"relationship\n"
-"\n"
-"session.persist(item);                   // The relationship won't be "
-"saved!\n"
-"session.persist(category);               // The relationship will be saved]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:735
 #, no-c-format
 msgid ""
 "The non-inverse side is used to save the in-memory representation to the "
@@ -1216,7 +929,6 @@
 msgstr "non-inverse 측은 메모리 내 표상을 데이터베이스로 저장하는데 사용된다."
 
 #. Tag: para
-#: collection_mapping.xml:739
 #, fuzzy, no-c-format
 msgid ""
 "You can define a bidirectional one-to-many association by mapping a one-to-"
@@ -1227,31 +939,7 @@
 "컬럼(들)로 매핑하고 many-값을 가진 끝(end)을 <literal>inverse=\"true\"</"
 "literal>로 선언함으로써 하나의 양방향 연관을 정의할 수도 있다."
 
-#. Tag: programlisting
-#: collection_mapping.xml:745
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <set name=\"children\" inverse=\"true\">\n"
-"        <key column=\"parent_id\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:747
 #, fuzzy, no-c-format
 msgid ""
 "Mapping one end of an association with <literal>inverse=\"true\"</literal> "
@@ -1262,13 +950,11 @@
 "다!"
 
 #. Tag: title
-#: collection_mapping.xml:755
 #, no-c-format
 msgid "Bidirectional associations with indexed collections"
 msgstr "인덱싱된 콜렉션들을 가진 양방향 연관들"
 
 #. Tag: para
-#: collection_mapping.xml:756
 #, fuzzy, no-c-format
 msgid ""
 "A bidirectional association where one end is represented as a <literal>&lt;"
@@ -1283,35 +969,7 @@
 "는 콜렉션 매핑 상에 <literal>inverse=\"true\"</literal>를 사용하여 계속할 수 "
 "있다:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:763
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <map name=\"children\" inverse=\"true\">\n"
-"        <key column=\"parent_id\"/>\n"
-"        <map-key column=\"name\" \n"
-"            type=\"string\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </map>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <property name=\"name\" \n"
-"        not-null=\"true\"/>\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:765
 #, fuzzy, no-c-format
 msgid ""
 "If there is no such property on the child class, the association cannot be "
@@ -1326,36 +984,7 @@
 "<literal>inverse=\"true\"</literal>로 매핑시킬 수 없다. 대신에 우리는 다음 매"
 "핑을 사용할 수 있다:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:772
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <map name=\"children\">\n"
-"        <key column=\"parent_id\"\n"
-"            not-null=\"true\"/>\n"
-"        <map-key column=\"name\" \n"
-"            type=\"string\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </map>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        insert=\"false\"\n"
-"        update=\"false\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:774
 #, fuzzy, no-c-format
 msgid ""
 "Note that in this mapping, the collection-valued end of the association is "
@@ -1365,13 +994,11 @@
 "이 있음을 노트하라."
 
 #. Tag: title
-#: collection_mapping.xml:782
 #, no-c-format
 msgid "Ternary associations"
 msgstr "Ternary associations(세겹 연관들)"
 
 #. Tag: para
-#: collection_mapping.xml:784
 #, fuzzy, no-c-format
 msgid ""
 "There are three possible approaches to mapping a ternary association. One "
@@ -1380,30 +1007,7 @@
 "세 겹의 연관을 매핑하는 세 가지 가능한 접근법들이 존재한다. 하나의 접근법은 "
 "그것의 인덱스로서 연관관계를 가진 <literal>Map</literal>을 사용하는 것이다:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:789
-#, no-c-format
-msgid ""
-"<![CDATA[<map name=\"contracts\">\n"
-"    <key column=\"employer_id\" not-null=\"true\"/>\n"
-"    <map-key-many-to-many column=\"employee_id\" class=\"Employee\"/>\n"
-"    <one-to-many class=\"Contract\"/>\n"
-"</map>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: collection_mapping.xml:791
-#, no-c-format
-msgid ""
-"<![CDATA[<map name=\"connections\">\n"
-"    <key column=\"incoming_node_id\"/>\n"
-"    <map-key-many-to-many column=\"outgoing_node_id\" class=\"Node\"/>\n"
-"    <many-to-many column=\"connection_id\" class=\"Connection\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:793
 #, fuzzy, no-c-format
 msgid ""
 "A second approach is to remodel the association as an entity class. This is "
@@ -1413,7 +1017,6 @@
 "이것은 우리가 가장 공통적으로 사용하는 접근법이다."
 
 #. Tag: para
-#: collection_mapping.xml:798
 #, fuzzy, no-c-format
 msgid ""
 "A final alternative is to use composite elements, which will be discussed "
@@ -1421,14 +1024,12 @@
 msgstr ""
 "마지막 대안은 우리가 나중에 논의하게 될 composite 요소들을 사용하는 것이다."
 
-#. Tag: literal
-#: collection_mapping.xml:805
-#, no-c-format
-msgid "Using an &lt;idbag&gt;"
+#. Tag: title
+#, fuzzy, no-c-format
+msgid "<literal>Using an &lt;idbag&gt;</literal>"
 msgstr "<literal>&lt;idbag&gt;</literal> 사용하기"
 
 #. Tag: para
-#: collection_mapping.xml:807
 #, fuzzy, no-c-format
 msgid ""
 "The majority of the many-to-many associations and collections of values "
@@ -1451,7 +1052,6 @@
 "는 것을 당신에게 허용해주는 특징을 제공한다."
 
 #. Tag: para
-#: collection_mapping.xml:817
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>&lt;idbag&gt;</literal> element lets you map a <literal>List</"
@@ -1461,21 +1061,7 @@
 "literal>(또는 <literal>Collection</literal>)을 매핑하도록 당신에게 허용해준"
 "다."
 
-#. Tag: programlisting
-#: collection_mapping.xml:822
-#, no-c-format
-msgid ""
-"<![CDATA[<idbag name=\"lovers\" table=\"LOVERS\">\n"
-"    <collection-id column=\"ID\" type=\"long\">\n"
-"        <generator class=\"sequence\"/>\n"
-"    </collection-id>\n"
-"    <key column=\"PERSON1\"/>\n"
-"    <many-to-many column=\"PERSON2\" class=\"Person\" fetch=\"join\"/>\n"
-"</idbag>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:824
 #, fuzzy, no-c-format
 msgid ""
 "An <literal>&lt;idbag&gt;</literal> has a synthetic id generator, just like "
@@ -1489,7 +1075,6 @@
 "즘을 제공하지 않는다."
 
 #. Tag: para
-#: collection_mapping.xml:831
 #, fuzzy, no-c-format
 msgid ""
 "The update performance of an <literal>&lt;idbag&gt;</literal> supersedes a "
@@ -1503,7 +1088,6 @@
 "로 업데이트 하거나 삭제시킬 수 있다."
 
 #. Tag: para
-#: collection_mapping.xml:837
 #, no-c-format
 msgid ""
 "In the current implementation, the <literal>native</literal> identifier "
@@ -1514,48 +1098,22 @@
 "idbag&gt;</literal> 콜렉션 식별자들에 대해 지원되지 않는다."
 
 #. Tag: title
-#: collection_mapping.xml:861
 #, no-c-format
 msgid "Collection examples"
 msgstr "콜렉션 예제들"
 
 #. Tag: para
-#: collection_mapping.xml:863
 #, fuzzy, no-c-format
 msgid "This section covers collection examples."
 msgstr "콜렉션 예제들"
 
 #. Tag: para
-#: collection_mapping.xml:867
 #, no-c-format
 msgid ""
 "The following class has a collection of <literal>Child</literal> instances:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:871
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"\n"
-"public class Parent {\n"
-"    private long id;\n"
-"    private Set children;\n"
-"\n"
-"    public long getId() { return id; }\n"
-"    private void setId(long id) { this.id=id; }\n"
-"\n"
-"    private Set getChildren() { return children; }\n"
-"    private void setChildren(Set children) { this.children=children; }\n"
-"\n"
-"    ....\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:873
 #, fuzzy, no-c-format
 msgid ""
 "If each child has, at most, one parent, the most natural mapping is a one-to-"
@@ -1565,50 +1123,12 @@
 "일 각각의 자식이 최소한 한 개의 부모를 가질 경우, 대부분의 고유한 매핑은 one-"
 "to-many 연관이다:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:879
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:881
 #, no-c-format
 msgid "This maps to the following table definitions:"
 msgstr "이것은 다음 테이블 정의들로 매핑된다:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:885
-#, no-c-format
-msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null primary key, name varchar(255), "
-"parent_id bigint )\n"
-"alter table child add constraint childfk0 (parent_id) references parent]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:887
 #, no-c-format
 msgid ""
 "If the parent is <emphasis>required</emphasis>, use a bidirectional one-to-"
@@ -1617,54 +1137,12 @@
 "만일 부모가 <emphasis>필수적</emphasis>이라면, 양방향 one-to-many 연관관계를 "
 "사용하라:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:892
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\" inverse=\"true\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"        <many-to-one name=\"parent\" class=\"Parent\" column=\"parent_id\" "
-"not-null=\"true\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:894
 #, no-c-format
 msgid "Notice the <literal>NOT NULL</literal> constraint:"
 msgstr "<literal>NOT NULL</literal> 컨스트레인트를 주목하라:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:898
-#, no-c-format
-msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null\n"
-"                     primary key,\n"
-"                     name varchar(255),\n"
-"                     parent_id bigint not null )\n"
-"alter table child add constraint childfk0 (parent_id) references parent]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:900
 #, fuzzy, no-c-format
 msgid ""
 "Alternatively, if this association must be unidirectional you can declare "
@@ -1675,34 +1153,7 @@
 "우, 당신은 <literal>&lt;key&gt;</literal> 매핑 상에 <literal>NOT NULL</"
 "literal> 컨스트레인트를 선언할 수 있다:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:906
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\">\n"
-"            <key column=\"parent_id\" not-null=\"true\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:908
 #, fuzzy, no-c-format
 msgid ""
 "On the other hand, if a child has multiple parents, a many-to-many "
@@ -1711,65 +1162,21 @@
 "반면에, 만일 자식이 여러 부모들을 가질 수 있을 경우, many-to-many 연관이 적절"
 "하다:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:913
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\" table=\"childset\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <many-to-many class=\"Child\" column=\"child_id\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:915
 #, no-c-format
 msgid "Table definitions:"
 msgstr "테이블 정의들:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:919
-#, no-c-format
-msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null primary key, name varchar(255) )\n"
-"create table childset ( parent_id bigint not null,\n"
-"                        child_id bigint not null,\n"
-"                        primary key ( parent_id, child_id ) )\n"
-"alter table childset add constraint childsetfk0 (parent_id) references "
-"parent\n"
-"alter table childset add constraint childsetfk1 (child_id) references child]]"
-">"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:921
 #, fuzzy, no-c-format
 msgid ""
 "For more examples and a complete explanation of a parent/child relationship "
-"mapping, see <xref linkend=\"example-parentchild\"/> for more information."
+"mapping, see <xref linkend=\"example-parentchild\" /> for more information."
 msgstr ""
 "부모/자식 관계 매핑을 연습하는 더 많은 예제들과 전체 리허설은 <xref linkend="
 "\"example-parentchild\"/>를 보라."
 
 #. Tag: para
-#: collection_mapping.xml:926
 #, fuzzy, no-c-format
 msgid "Even more complex association mappings are covered in the next chapter."
 msgstr ""
@@ -1786,134 +1193,3 @@
 #~ "The previous sections are pretty confusing. So lets look at an example. "
 #~ "This class:"
 #~ msgstr "앞의 절들은 꽤 혼동스럽다. 따라서 예제를 살펴보자. 다음 클래스:"
-
-#~ msgid ""
-#~ "<literal>column_name</literal> (required): The name of the column holding "
-#~ "the collection index values."
-#~ msgstr ""
-#~ "<literal>column_name</literal> (필수): 콜렉션 인덱스 값들을 보관하는 컬럼"
-#~ "의 이름."
-
-#~ msgid ""
-#~ "<literal>base</literal> (optional, defaults to <literal>0</literal>): The "
-#~ "value of the index column that corresponds to the first element of the "
-#~ "list or array."
-#~ msgstr ""
-#~ "<literal>base</literal> (옵션, 디폴트는 <literal>0</literal>): 리스트 또"
-#~ "는 배열의 첫 번째 요소에 대응하는 인덱스 컬럼의 값."
-
-#~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the column holding the "
-#~ "collection index values."
-#~ msgstr ""
-#~ "<literal>column</literal> (옵션): 콜렉션 인덱스 값들을 보관하는 컬럼의 이"
-#~ "름."
-
-#~ msgid ""
-#~ "<literal>formula</literal> (optional): A SQL formula used to evaluate the "
-#~ "key of the map."
-#~ msgstr ""
-#~ "<literal>formula</literal> (옵션): map의 키를 평가하는데 사용되는 SQL "
-#~ "formula."
-
-#~ msgid "<literal>type</literal> (reguired): The type of the map keys."
-#~ msgstr "<literal>type</literal> (필수): The type of the map 키들의 타입"
-
-#~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the foreign key column "
-#~ "for the collection index values."
-#~ msgstr ""
-#~ "<literal>column</literal> (옵션): 콜렉션 인덱스 값들에 대한 foreign 키 컬"
-#~ "럼의 이름."
-
-#~ msgid ""
-#~ "<literal>formula</literal> (optional): A SQL formula used to evaluate the "
-#~ "foreign key of the map key."
-#~ msgstr ""
-#~ "<literal>formula</literal> (옵션): map의 foreign 키를 평가하는데 사용되는 "
-#~ "SQL formula."
-
-#~ msgid ""
-#~ "<literal>class</literal> (required): The entity class used as the map key."
-#~ msgstr "<literal>class</literal> (필수): map 키로서 사용되는 엔티티 클래스."
-
-#~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the column holding the "
-#~ "collection element values."
-#~ msgstr ""
-#~ "<literal>column</literal> (옵션): 콜렉션 요소 값들을 소유하는 컬럼의 이름."
-
-#~ msgid ""
-#~ "<literal>formula</literal> (optional): An SQL formula used to evaluate "
-#~ "the element."
-#~ msgstr ""
-#~ "<literal>formula</literal> (옵션): 요소를 평가하는데 사용되는 SQL formula."
-
-#~ msgid ""
-#~ "<literal>type</literal> (required): The type of the collection element."
-#~ msgstr "<literal>type</literal> (필수): 콜렉션 요소의 타입."
-
-#~ msgid ""
-#~ "A <emphasis>many-to-many association</emphasis> is specified using the "
-#~ "<literal>&lt;many-to-many&gt;</literal> element."
-#~ msgstr ""
-#~ "<emphasis>many-to-many association</emphasis> 연관은 <literal>&lt;many-to-"
-#~ "many&gt;</literal> 요소를 사용하여 지정된다."
-
-#~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the element foreign key "
-#~ "column."
-#~ msgstr "<literal>column</literal> (옵션): 요소 foreign 키 컬럼의 이름."
-
-#~ msgid ""
-#~ "<literal>formula</literal> (optional): An SQL formula used to evaluate "
-#~ "the element foreign key value."
-#~ msgstr ""
-#~ "<literal>formula</literal> (옵션): 요소 foreign 키 값을 평가하는데 사용되"
-#~ "는 SQL formula."
-
-#~ msgid ""
-#~ "<literal>fetch</literal> (optional - defaults to <literal>join</"
-#~ "literal>): enables outer-join or sequential select fetching for this "
-#~ "association. This is a special case; for full eager fetching (in a single "
-#~ "<literal>SELECT</literal>) of an entity and its many-to-many "
-#~ "relationships to other entities, you would enable <literal>join</literal> "
-#~ "fetching not only of the collection itself, but also with this attribute "
-#~ "on the <literal>&lt;many-to-many&gt;</literal> nested element."
-#~ msgstr ""
-#~ "<literal>fetch</literal> (옵션 - 디폴트는 <literal>join</literal>): 이 연"
-#~ "관에 대해 outer-join 페칭 또는 sequential select 페칭을 이용 가능하게 만든"
-#~ "다. 이것은 특별한 경우이다; 엔티티 그리고 다른 엔티티들과 그것의 many-to-"
-#~ "many 관계들에 대한 (하나의 <literal>SELECT</literal> 내에서) 전체 eager 페"
-#~ "칭의 경우, 당신은 콜렉션 그 자체에 대해서 뿐만 아니라 내포된 요소 "
-#~ "<literal>&lt;many-to-many&gt;</literal> 상의 이 속성에 대해 "
-#~ "<literal>join</literal> 페칭을 이용 가능하게 할 것이다."
-
-#~ msgid ""
-#~ "<literal>unique</literal> (optional): Enable the DDL generation of a "
-#~ "unique constraint for the foreign-key column. This makes the association "
-#~ "multiplicity effectively one to many."
-#~ msgstr ""
-#~ "<literal>unique</literal> (옵션): foreign-key 컬럼에 대한 유일 컨스트레인"
-#~ "트의 DDL 생성을 가능하도록 한다. 이것은 연관 다중성 (association "
-#~ "multiplicity)을 효율적으로 one to many로 만든다."
-
-#~ msgid ""
-#~ "<literal>not-found</literal> (optional - defaults to <literal>exception</"
-#~ "literal>): Specifies how foreign keys that reference missing rows will be "
-#~ "handled: <literal>ignore</literal> will treat a missing row as a null "
-#~ "association."
-#~ msgstr ""
-#~ "<literal>not-found</literal> (옵션 - 디폴트는 <literal>exception</"
-#~ "literal>): 누락된 행들을 참조하는 foreign 키들이 어떻게 처리될 것인지를 지"
-#~ "정한다: <literal>ignore</literal>는 누락된 한 행을 한 개의 연관으로 다룰 "
-#~ "것이다."
-
-#~ msgid ""
-#~ "<literal>property-ref</literal>: (optional) The name of a property of the "
-#~ "associated class that is joined to this foreign key. If not specified, "
-#~ "the primary key of the associated class is used."
-#~ msgstr ""
-#~ "<literal>property-ref</literal>: (옵션) 이 foreign 키에 조인된 연관 클래스"
-#~ "의 프로퍼티의 이름. 지정되지 않을 경우, 연관 클래스의 프라이머리 키가 사용"
-#~ "된다."

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/component_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/component_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/component_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,13 +11,11 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: component_mapping.xml:29
 #, no-c-format
 msgid "Component Mapping"
 msgstr "Component 매핑"
 
 #. Tag: para
-#: component_mapping.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "The notion of a <emphasis>component</emphasis> is re-used in several "
@@ -27,13 +25,11 @@
 "컨텍스트들 내에서 재사용된다."
 
 #. Tag: title
-#: component_mapping.xml:37
 #, no-c-format
 msgid "Dependent objects"
 msgstr "종속 객체들"
 
 #. Tag: para
-#: component_mapping.xml:39
 #, fuzzy, no-c-format
 msgid ""
 "A component is a contained object that is persisted as a value type and not "
@@ -46,68 +42,7 @@
 "composition(구성,합성)에 대한 객체-지향적인 개념을 언급한다. 예를 들어 당신"
 "은 다음과 같이 개인을 모형화 시킬 수도 있다:"
 
-#. Tag: programlisting
-#: component_mapping.xml:45
-#, no-c-format
-msgid ""
-"<![CDATA[public class Person {\n"
-"    private java.util.Date birthday;\n"
-"    private Name name;\n"
-"    private String key;\n"
-"    public String getKey() {\n"
-"        return key;\n"
-"    }\n"
-"    private void setKey(String key) {\n"
-"        this.key=key;\n"
-"    }\n"
-"    public java.util.Date getBirthday() {\n"
-"        return birthday;\n"
-"    }\n"
-"    public void setBirthday(java.util.Date birthday) {\n"
-"        this.birthday = birthday;\n"
-"    }\n"
-"    public Name getName() {\n"
-"        return name;\n"
-"    }\n"
-"    public void setName(Name name) {\n"
-"        this.name = name;\n"
-"    }\n"
-"    ......\n"
-"    ......\n"
-"}]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: component_mapping.xml:47
-#, no-c-format
-msgid ""
-"<![CDATA[public class Name {\n"
-"    char initial;\n"
-"    String first;\n"
-"    String last;\n"
-"    public String getFirst() {\n"
-"        return first;\n"
-"    }\n"
-"    void setFirst(String first) {\n"
-"        this.first = first;\n"
-"    }\n"
-"    public String getLast() {\n"
-"        return last;\n"
-"    }\n"
-"    void setLast(String last) {\n"
-"        this.last = last;\n"
-"    }\n"
-"    public char getInitial() {\n"
-"        return initial;\n"
-"    }\n"
-"    void setInitial(char initial) {\n"
-"        this.initial = initial;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:49
 #, fuzzy, no-c-format
 msgid ""
 "Now <literal>Name</literal> can be persisted as a component of "
@@ -121,31 +56,11 @@
 "퍼티들을 선언하는 것을 필요로 하지 않음을 주목하라."
 
 #. Tag: para
-#: component_mapping.xml:56
 #, fuzzy, no-c-format
 msgid "Our Hibernate mapping would look like this:"
 msgstr "우리의 Hibernate 매핑은 다음과 같을 것이다:"
 
-#. Tag: programlisting
-#: component_mapping.xml:60
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-"    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    <property name=\"birthday\" type=\"date\"/>\n"
-"    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
-"optional -->\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </component>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:62
 #, no-c-format
 msgid ""
 "The person table would have the columns <literal>pid</literal>, "
@@ -157,7 +72,6 @@
 "literal> 컬럼들을 가질 것이다."
 
 #. Tag: para
-#: component_mapping.xml:70
 #, fuzzy, no-c-format
 msgid ""
 "Like value types, components do not support shared references. In other "
@@ -176,7 +90,6 @@
 "체 컴포넌트가 null이라고 가정할 것이다. 이것은 대부분의 용도에 맞을 것이다."
 
 #. Tag: para
-#: component_mapping.xml:78
 #, fuzzy, no-c-format
 msgid ""
 "The properties of a component can be of any Hibernate type (collections, "
@@ -190,7 +103,6 @@
 "을 지원하도록 고안되어있다."
 
 #. Tag: para
-#: component_mapping.xml:85
 #, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element allows a <literal>&lt;"
@@ -201,33 +113,12 @@
 "되는 엔티티에 대한 역 참조로서 매핑시키는 <literal>&lt;parent&gt;</literal> "
 "서브요소를 허용한다."
 
-#. Tag: programlisting
-#: component_mapping.xml:91
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-"    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    <property name=\"birthday\" type=\"date\"/>\n"
-"    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
-"        <parent name=\"namedPerson\"/> <!-- reference back to the Person --"
-">\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </component>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: component_mapping.xml:96
 #, no-c-format
 msgid "Collections of dependent objects"
 msgstr "종속 객체들을 가진 콜렉션들"
 
 #. Tag: para
-#: component_mapping.xml:98
 #, fuzzy, no-c-format
 msgid ""
 "Collections of components are supported (e.g. an array of type "
@@ -240,22 +131,7 @@
 "composite-element&gt;</literal> 태그로 대체시켜서 당신의 컴포넌트 콜렉션을 선"
 "언하라."
 
-#. Tag: programlisting
-#: component_mapping.xml:105
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
-"    <key column=\"id\"/>\n"
-"    <composite-element class=\"eg.Name\"> <!-- class attribute required -->\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </composite-element>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:108
 #, fuzzy, no-c-format
 msgid ""
 "If you define a <literal>Set</literal> of composite elements, it is "
@@ -267,7 +143,6 @@
 "게 구현하는 것이 매우 중요하다."
 
 #. Tag: para
-#: component_mapping.xml:115
 #, fuzzy, no-c-format
 msgid ""
 "Composite elements can contain components but not collections. If your "
@@ -287,7 +162,6 @@
 "들이 동일할지라도, 관계형 모형과 영속화 의미들은 여전히 약간 다르다."
 
 #. Tag: para
-#: component_mapping.xml:127
 #, fuzzy, no-c-format
 msgid ""
 "A composite element mapping does not support null-able properties if you are "
@@ -309,7 +183,6 @@
 "야 한다."
 
 #. Tag: para
-#: component_mapping.xml:138
 #, fuzzy, no-c-format
 msgid ""
 "A special case of a composite element is a composite element with a nested "
@@ -328,27 +201,7 @@
 "<literal>price</literal>, 그리고 <literal>quantity</literal>는 연관의 프로퍼"
 "티들이다:"
 
-#. Tag: programlisting
-#: component_mapping.xml:148
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Order\" .... >\n"
-"    ....\n"
-"    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-"        <key column=\"order_id\">\n"
-"        <composite-element class=\"eg.Purchase\">\n"
-"            <property name=\"purchaseDate\"/>\n"
-"            <property name=\"price\"/>\n"
-"            <property name=\"quantity\"/>\n"
-"            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class "
-"attribute is optional -->\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:150
 #, fuzzy, no-c-format
 msgid ""
 "There cannot be a reference to the purchase on the other side for "
@@ -364,29 +217,11 @@
 "literal>에 의해 참조될 수 없다."
 
 #. Tag: para
-#: component_mapping.xml:158
 #, no-c-format
 msgid "Even ternary (or quaternary, etc) associations are possible:"
 msgstr "심지어 세겹의(또는 네 겹의, 기타) 연관들이 가능하다:"
 
-#. Tag: programlisting
-#: component_mapping.xml:160
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Order\" .... >\n"
-"    ....\n"
-"    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-"        <key column=\"order_id\">\n"
-"        <composite-element class=\"eg.OrderLine\">\n"
-"            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
-"            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:162
 #, fuzzy, no-c-format
 msgid ""
 "Composite elements can appear in queries using the same syntax as "
@@ -396,13 +231,11 @@
 "들 내에 나타날 수도 있다."
 
 #. Tag: title
-#: component_mapping.xml:170
 #, no-c-format
 msgid "Components as Map indices"
 msgstr "Map 인덱스들로서 컴포넌트들"
 
 #. Tag: para
-#: component_mapping.xml:172
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>&lt;composite-map-key&gt;</literal> element allows you to map a "
@@ -416,13 +249,11 @@
 "literal>를 정확하게 오버라이드 시키도록 하라."
 
 #. Tag: title
-#: component_mapping.xml:181
 #, no-c-format
 msgid "Components as composite identifiers"
 msgstr "composite 식별자들로서 컴포넌트들"
 
 #. Tag: para
-#: component_mapping.xml:183
 #, fuzzy, no-c-format
 msgid ""
 "You can use a component as an identifier of an entity class. Your component "
@@ -432,13 +263,11 @@
 "할 수도 있다. 당신의 컴포넌트 클래스는 어떤 사양들을 충족시켜야 한다:"
 
 #. Tag: para
-#: component_mapping.xml:190
 #, no-c-format
 msgid "It must implement <literal>java.io.Serializable</literal>."
 msgstr "그것은 <literal>java.io.Serializable</literal>을 구현해야 한다."
 
 #. Tag: para
-#: component_mapping.xml:195
 #, fuzzy, no-c-format
 msgid ""
 "It must re-implement <literal>equals()</literal> and <literal>hashCode()</"
@@ -449,13 +278,11 @@
 "한다."
 
 #. Tag: title
-#: component_mapping.xml:204
 #, no-c-format
 msgid "Note"
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:205
 #, fuzzy, no-c-format
 msgid ""
 "In Hibernate3, although the second requirement is not an absolutely hard "
@@ -465,7 +292,6 @@
 "니다. 그러나 아무튼 그것을 행하라."
 
 #. Tag: para
-#: component_mapping.xml:211
 #, fuzzy, no-c-format
 msgid ""
 "You cannot use an <literal>IdentifierGenerator</literal> to generate "
@@ -475,7 +301,6 @@
 "사용할 수 없다. 대신에 어플리케이션은 그것 자신의 식별자들을 할당해야 한다."
 
 #. Tag: para
-#: component_mapping.xml:216
 #, fuzzy, no-c-format
 msgid ""
 "Use the <literal>&lt;composite-id&gt;</literal> tag, with nested "
@@ -490,32 +315,7 @@
 "<literal>Order</literal>의 (composite) 프라이머리 키에 의존하는 프라이머리 키"
 "를 갖는다."
 
-#. Tag: programlisting
-#: component_mapping.xml:224
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"OrderLine\">\n"
-"\n"
-"    <composite-id name=\"id\" class=\"OrderLineId\">\n"
-"        <key-property name=\"lineId\"/>\n"
-"        <key-property name=\"orderId\"/>\n"
-"        <key-property name=\"customerId\"/>\n"
-"    </composite-id>\n"
-"\n"
-"    <property name=\"name\"/>\n"
-"\n"
-"    <many-to-one name=\"order\" class=\"Order\"\n"
-"            insert=\"false\" update=\"false\">\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </many-to-one>\n"
-"    ....\n"
-"\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:226
 #, fuzzy, no-c-format
 msgid ""
 "Any foreign keys referencing the <literal>OrderLine</literal> table are now "
@@ -527,20 +327,7 @@
 "야 한다. <literal>OrderLine</literal>에 대한 하나의 연관은 다음과 같이 매핑"
 "될 것이다:"
 
-#. Tag: programlisting
-#: component_mapping.xml:232
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
-"<!-- the \"class\" attribute is optional, as usual -->\n"
-"    <column name=\"lineId\"/>\n"
-"    <column name=\"orderId\"/>\n"
-"    <column name=\"customerId\"/>\n"
-"</many-to-one>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:235
 #, no-c-format
 msgid ""
 "The <literal>column</literal> element is an alternative to the "
@@ -550,7 +337,6 @@
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:244
 #, no-c-format
 msgid ""
 "A <literal>many-to-many</literal> association to <literal>OrderLine</"
@@ -559,22 +345,7 @@
 "<literal>OrderLine</literal>에 대한 <literal>many-to-many</literal> 연관은 또"
 "한 composite foreign 키를 사용한다:"
 
-#. Tag: programlisting
-#: component_mapping.xml:249
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"undeliveredOrderLines\">\n"
-"    <key column name=\"warehouseId\"/>\n"
-"    <many-to-many class=\"OrderLine\">\n"
-"        <column name=\"lineId\"/>\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </many-to-many>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:251
 #, no-c-format
 msgid ""
 "The collection of <literal>OrderLine</literal>s in <literal>Order</literal> "
@@ -583,21 +354,7 @@
 "<literal>Order</literal>에서 <literal>OrderLine</literal>들의 콜렉션이 사용"
 "될 것이다:"
 
-#. Tag: programlisting
-#: component_mapping.xml:256
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
-"    <key>\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </key>\n"
-"    <one-to-many class=\"OrderLine\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:258
 #, fuzzy, no-c-format
 msgid "The <literal>&lt;one-to-many&gt;</literal> element declares no columns."
 msgstr ""
@@ -605,7 +362,6 @@
 "않는다.)"
 
 #. Tag: para
-#: component_mapping.xml:262
 #, no-c-format
 msgid ""
 "If <literal>OrderLine</literal> itself owns a collection, it also has a "
@@ -614,52 +370,17 @@
 "만일 <literal>OrderLine</literal> 자체가 하나의 콜렉션을 소유할 경우, 그것은 "
 "또한 하나의 composite foreign 키를 갖는다."
 
-#. Tag: programlisting
-#: component_mapping.xml:267
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"OrderLine\">\n"
-"    ....\n"
-"    ....\n"
-"    <list name=\"deliveryAttempts\">\n"
-"        <key>   <!-- a collection inherits the composite key type -->\n"
-"            <column name=\"lineId\"/>\n"
-"            <column name=\"orderId\"/>\n"
-"            <column name=\"customerId\"/>\n"
-"        </key>\n"
-"        <list-index column=\"attemptId\" base=\"1\"/>\n"
-"        <composite-element class=\"DeliveryAttempt\">\n"
-"            ...\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: component_mapping.xml:272
 #, no-c-format
 msgid "Dynamic components"
 msgstr "동적인 컴포넌트들"
 
 #. Tag: para
-#: component_mapping.xml:274
 #, fuzzy, no-c-format
 msgid "You can also map a property of type <literal>Map</literal>:"
 msgstr "당신은 <literal>Map</literal> 타입의 프로퍼티를 매핑시킬 수도 있다:"
 
-#. Tag: programlisting
-#: component_mapping.xml:278
-#, no-c-format
-msgid ""
-"<![CDATA[<dynamic-component name=\"userAttributes\">\n"
-"    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
-"    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
-"    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
-"</dynamic-component>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:280
 #, fuzzy, no-c-format
 msgid ""
 "The semantics of a <literal>&lt;dynamic-component&gt;</literal> mapping are "

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/configuration.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/configuration.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/configuration.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,13 +11,11 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: configuration.xml:29
 #, no-c-format
 msgid "Configuration"
 msgstr "구성"
 
 #. Tag: para
-#: configuration.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate is designed to operate in many different environments and, as "
@@ -34,13 +32,11 @@
 "classpath 경로 속에 그 파일을 집어넣고 그것을 커스트마이징하기만 해야 한다."
 
 #. Tag: title
-#: configuration.xml:40
 #, no-c-format
 msgid "Programmatic configuration"
 msgstr "프로그램 상의 구성"
 
 #. Tag: para
-#: configuration.xml:42
 #, fuzzy, no-c-format
 msgid ""
 "An instance of <classname>org.hibernate.cfg.Configuration</classname> "
@@ -55,7 +51,6 @@
 "를 빌드하는데 사용된다. 매핑들은 여러 XML 매핑 파일들로부터 컴파일 된다."
 
 #. Tag: para
-#: configuration.xml:49
 #, fuzzy, no-c-format
 msgid ""
 "You can obtain a <classname>org.hibernate.cfg.Configuration</classname> "
@@ -68,17 +63,7 @@
 "다. 만일 매핑 파일들이 classpath 내에 있다면, <literal>addResource()</"
 "literal>를 사용하라:"
 
-#. Tag: programlisting
-#: configuration.xml:55
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addResource(\"Item.hbm.xml\")\n"
-"    .addResource(\"Bid.hbm.xml\");]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:57
 #, fuzzy, no-c-format
 msgid ""
 "An alternative way is to specify the mapped class and allow Hibernate to "
@@ -87,17 +72,7 @@
 "(때때로 더 나은) 다른 방법은 매핑된 클래스를 지정하는 것이고, Hibernate로 하"
 "여금 당신을 위해 매핑 문서를 찾도록 하라:"
 
-#. Tag: programlisting
-#: configuration.xml:62
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addClass(org.hibernate.auction.Item.class)\n"
-"    .addClass(org.hibernate.auction.Bid.class);]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:64
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate will then search for mapping files named <filename>/org/hibernate/"
@@ -111,7 +86,6 @@
 "제거한다."
 
 #. Tag: para
-#: configuration.xml:70
 #, fuzzy, no-c-format
 msgid ""
 "A <classname>org.hibernate.cfg.Configuration</classname> also allows you to "
@@ -120,22 +94,7 @@
 "<literal>Configuration</literal>은 또한 구성 프로퍼티들을 지정하는 것을 허용"
 "해준다:"
 
-#. Tag: programlisting
-#: configuration.xml:75
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addClass(org.hibernate.auction.Item.class)\n"
-"    .addClass(org.hibernate.auction.Bid.class)\n"
-"    .setProperty(\"hibernate.dialect\", \"org.hibernate.dialect."
-"MySQLInnoDBDialect\")\n"
-"    .setProperty(\"hibernate.connection.datasource\", \"java:comp/env/jdbc/"
-"test\")\n"
-"    .setProperty(\"hibernate.order_updates\", \"true\");]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:77
 #, fuzzy, no-c-format
 msgid ""
 "This is not the only way to pass configuration properties to Hibernate. Some "
@@ -145,7 +104,6 @@
 "여러 가지 옵션들은 다음을 포함한다:"
 
 #. Tag: para
-#: configuration.xml:84
 #, fuzzy, no-c-format
 msgid ""
 "Pass an instance of <classname>java.util.Properties</classname> to "
@@ -155,7 +113,6 @@
 "setProperties()</literal>에 전달한다 ."
 
 #. Tag: para
-#: configuration.xml:90
 #, fuzzy, no-c-format
 msgid ""
 "Place a file named <filename>hibernate.properties</filename> in a root "
@@ -165,7 +122,6 @@
 "운다."
 
 #. Tag: para
-#: configuration.xml:95
 #, no-c-format
 msgid ""
 "Set <literal>System</literal> properties using <literal>java -"
@@ -175,7 +131,6 @@
 "literal> 프로퍼티들을 설정한다."
 
 #. Tag: para
-#: configuration.xml:100
 #, fuzzy, no-c-format
 msgid ""
 "Include <literal>&lt;property&gt;</literal> elements in <literal>hibernate."
@@ -185,7 +140,6 @@
 "소들을 포함한다 (나중에 논의됨)."
 
 #. Tag: para
-#: configuration.xml:107
 #, no-c-format
 msgid ""
 "If you want to get started quickly<filename>hibernate.properties</filename> "
@@ -193,7 +147,6 @@
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:111
 #, fuzzy, no-c-format
 msgid ""
 "The <classname>org.hibernate.cfg.Configuration</classname> is intended as a "
@@ -204,13 +157,11 @@
 "<literal>SessionFactory</literal>가 생성되면 폐기되게끔 예정되어 있다."
 
 #. Tag: title
-#: configuration.xml:119
 #, no-c-format
 msgid "Obtaining a SessionFactory"
 msgstr "SessionFactory 얻기"
 
 #. Tag: para
-#: configuration.xml:121
 #, fuzzy, no-c-format
 msgid ""
 "When all mappings have been parsed by the <classname>org.hibernate.cfg."
@@ -222,14 +173,7 @@
 "이션은 <literal>Session</literal> 인스턴스들에 대한 팩토리를 얻어야 한다. 이 "
 "팩토리는 모든 어플리케이션 쓰레드들에 의해 공유되도록 고안되었다:"
 
-#. Tag: programlisting
-#: configuration.xml:127
-#, no-c-format
-msgid "<![CDATA[SessionFactory sessions = cfg.buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:129
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate does allow your application to instantiate more than one "
@@ -241,13 +185,11 @@
 "이 하나 이상의 데이터베이스를 사용하는 경우에 유용하다."
 
 #. Tag: title
-#: configuration.xml:138
 #, no-c-format
 msgid "JDBC connections"
 msgstr "JDBC 커넥션들"
 
 #. Tag: para
-#: configuration.xml:140
 #, fuzzy, no-c-format
 msgid ""
 "It is advisable to have the <interfacename>org.hibernate.SessionFactory</"
@@ -259,15 +201,7 @@
 "션들을 생성시키고 풀링시키는 것을 원한다. 만일 당신이 이 접근법을 취할 경우, "
 "한 개의 <literal>Session</literal>을 여는 것은 다음과 같이 간단하다:"
 
-#. Tag: programlisting
-#: configuration.xml:146
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessions.openSession(); // open a new Session]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:148
 #, fuzzy, no-c-format
 msgid ""
 "Once you start a task that requires access to the database, a JDBC "
@@ -277,7 +211,6 @@
 "JDBC 커넥션이 그 풀로부터 얻어질 것이다."
 
 #. Tag: para
-#: configuration.xml:153
 #, fuzzy, no-c-format
 msgid ""
 "Before you can do this, you first need to pass some JDBC connection "
@@ -292,7 +225,6 @@
 "우리는 이제 JDBC 커넥션 구성을 위한 가장 중요한 설정들을 설명할 것이다."
 
 #. Tag: para
-#: configuration.xml:159
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate will obtain and pool connections using <classname>java.sql."
@@ -303,89 +235,71 @@
 "이다):"
 
 #. Tag: title
-#: configuration.xml:165
 #, no-c-format
 msgid "Hibernate JDBC Properties"
 msgstr "Hibernate JDBC 프로퍼티들"
 
 #. Tag: entry
-#: configuration.xml:171 configuration.xml:257 configuration.xml:353
-#: configuration.xml:548 configuration.xml:743 configuration.xml:850
-#: configuration.xml:938
 #, no-c-format
 msgid "Property name"
 msgstr "프로퍼티 이름"
 
 #. Tag: entry
-#: configuration.xml:172 configuration.xml:258 configuration.xml:354
-#: configuration.xml:549 configuration.xml:744 configuration.xml:851
-#: configuration.xml:939
 #, no-c-format
 msgid "Purpose"
 msgstr "용도"
 
-#. Tag: property
-#: configuration.xml:178
-#, no-c-format
-msgid "hibernate.connection.driver_class"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.connection.driver_class</property>"
 msgstr "hibernate.connection.driver_class"
 
-#. Tag: emphasis
-#: configuration.xml:181
-#, no-c-format
-msgid "JDBC driver class"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<emphasis>JDBC driver class</emphasis>"
 msgstr "jdbc 드라이버 클래스"
 
-#. Tag: property
-#: configuration.xml:186
-#, no-c-format
-msgid "hibernate.connection.url"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.connection.url</property>"
 msgstr "hibernate.connection.url"
 
-#. Tag: emphasis
-#: configuration.xml:189
+#. Tag: entry
 #, no-c-format
-msgid "JDBC URL"
-msgstr "jdbc URL"
+msgid "<emphasis>JDBC URL</emphasis>"
+msgstr ""
 
-#. Tag: property
-#: configuration.xml:194 configuration.xml:288
-#, no-c-format
-msgid "hibernate.connection.username"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.connection.username</property>"
 msgstr "hibernate.connection.username"
 
-#. Tag: emphasis
-#: configuration.xml:197
-#, no-c-format
-msgid "database user"
-msgstr "데이터베이스 사용자"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<emphasis>database user</emphasis>"
+msgstr "데이터베이스 사용자 패스워드"
 
-#. Tag: property
-#: configuration.xml:202 configuration.xml:296
-#, no-c-format
-msgid "hibernate.connection.password"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.connection.password</property>"
 msgstr "hibernate.connection.password"
 
-#. Tag: emphasis
-#: configuration.xml:205
-#, no-c-format
-msgid "database user password"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<emphasis>database user password</emphasis>"
 msgstr "데이터베이스 사용자 패스워드"
 
-#. Tag: property
-#: configuration.xml:210
-#, no-c-format
-msgid "hibernate.connection.pool_size"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.connection.pool_size</property>"
 msgstr "hibernate.connection.pool_size"
 
-#. Tag: emphasis
-#: configuration.xml:213
-#, no-c-format
-msgid "maximum number of pooled connections"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<emphasis>maximum number of pooled connections</emphasis>"
 msgstr "풀링된 커넥션들의 최대 개수"
 
 #. Tag: para
-#: configuration.xml:220
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate's own connection pooling algorithm is, however, quite rudimentary. "
@@ -404,7 +318,6 @@
 "부 pool을 오프시킬 것이다. 예를 들어 당신은 C3P0를 사용할 수도 있다."
 
 #. Tag: para
-#: configuration.xml:230
 #, fuzzy, no-c-format
 msgid ""
 "C3P0 is an open source JDBC connection pool distributed along with Hibernate "
@@ -423,7 +336,6 @@
 "literal>를 참조하고 추가 정보는 Hibernate 웹 사이트를 참조하라."
 
 #. Tag: para
-#: configuration.xml:238
 #, fuzzy, no-c-format
 msgid ""
 "The following is an example <filename>hibernate.properties</filename> file "
@@ -432,23 +344,7 @@
 "다음은 C3P0에 대한 사용하는 예제 <literal>hibernate.properties</literal> 파일"
 "이다:"
 
-#. Tag: programlisting
-#: configuration.xml:242
-#, no-c-format
-msgid ""
-"<![CDATA[hibernate.connection.driver_class = org.postgresql.Driver\n"
-"hibernate.connection.url = jdbc:postgresql://localhost/mydatabase\n"
-"hibernate.connection.username = myuser\n"
-"hibernate.connection.password = secret\n"
-"hibernate.c3p0.min_size=5\n"
-"hibernate.c3p0.max_size=20\n"
-"hibernate.c3p0.timeout=1800\n"
-"hibernate.c3p0.max_statements=50\n"
-"hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:244
 #, fuzzy, no-c-format
 msgid ""
 "For use inside an application server, you should almost always configure "
@@ -462,43 +358,36 @@
 "있을 것이다."
 
 #. Tag: title
-#: configuration.xml:251
 #, no-c-format
 msgid "Hibernate Datasource Properties"
 msgstr "Hibernate Datasource Properties"
 
-#. Tag: property
-#: configuration.xml:264
-#, no-c-format
-msgid "hibernate.connection.datasource"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.connection.datasource</property>"
 msgstr "hibernate.connection.datasource"
 
-#. Tag: emphasis
-#: configuration.xml:267
-#, no-c-format
-msgid "datasource JNDI name"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<emphasis>datasource JNDI name</emphasis>"
 msgstr "데이터소스 JNDI 이름"
 
-#. Tag: property
-#: configuration.xml:272
-#, no-c-format
-msgid "hibernate.jndi.url"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.jndi.url</property>"
 msgstr "hibernate.jndi.url"
 
 #. Tag: entry
-#: configuration.xml:274
 #, fuzzy, no-c-format
 msgid "<emphasis>URL of the JNDI provider</emphasis> (optional)"
 msgstr "JNDI 프로바이더의 URL"
 
-#. Tag: property
-#: configuration.xml:280
-#, no-c-format
-msgid "hibernate.jndi.class"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.jndi.class</property>"
 msgstr "hibernate.jndi.class"
 
 #. Tag: entry
-#: configuration.xml:282
 #, no-c-format
 msgid ""
 "<emphasis>class of the JNDI <literal>InitialContextFactory</literal></"
@@ -506,19 +395,16 @@
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:290
 #, no-c-format
 msgid "<emphasis>database user</emphasis> (optional)"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:298
 #, no-c-format
 msgid "<emphasis>database user password</emphasis> (optional)"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:306
 #, fuzzy, no-c-format
 msgid ""
 "Here is an example <filename>hibernate.properties</filename> file for an "
@@ -527,20 +413,7 @@
 "다음은 어플리케이션 서버 제공 JNDI 데이터소스용 예제 <literal>hibernate."
 "properties</literal> 파일이다:"
 
-#. Tag: programlisting
-#: configuration.xml:311
-#, no-c-format
-msgid ""
-"<![CDATA[hibernate.connection.datasource = java:/comp/env/jdbc/test\n"
-"hibernate.transaction.factory_class = \\\n"
-"    org.hibernate.transaction.JTATransactionFactory\n"
-"hibernate.transaction.manager_lookup_class = \\\n"
-"    org.hibernate.transaction.JBossTransactionManagerLookup\n"
-"hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:313
 #, no-c-format
 msgid ""
 "JDBC connections obtained from a JNDI datasource will automatically "
@@ -550,7 +423,6 @@
 "의해 관리되는 트랜잭션들에 자동적으로 참여할 것이다."
 
 #. Tag: para
-#: configuration.xml:318
 #, fuzzy, no-c-format
 msgid ""
 "Arbitrary connection properties can be given by prepending "
@@ -564,7 +436,6 @@
 "literal>을 지정할 수도 있다."
 
 #. Tag: para
-#: configuration.xml:324
 #, fuzzy, no-c-format
 msgid ""
 "You can define your own plugin strategy for obtaining JDBC connections by "
@@ -579,13 +450,11 @@
 "하여 맞춤형 구현을 선택할 수도 있다."
 
 #. Tag: title
-#: configuration.xml:333
 #, no-c-format
 msgid "Optional configuration properties"
 msgstr "선택적인 구성 프로퍼티들"
 
 #. Tag: para
-#: configuration.xml:335
 #, fuzzy, no-c-format
 msgid ""
 "There are a number of other properties that control the behavior of "
@@ -594,8 +463,7 @@
 "실행 시에 Hibernate의 행위를 제어하는 많은 다른 프로퍼티들이 존재한다. 모든 "
 "것이 옵션이지만 합당한 디폴트 값들을 갖는다."
 
-#. Tag: warning
-#: configuration.xml:341
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Some of these properties are \"system-level\" only.</emphasis> "
@@ -610,19 +478,16 @@
 "emphasis>."
 
 #. Tag: title
-#: configuration.xml:347
 #, no-c-format
 msgid "Hibernate Configuration Properties"
 msgstr "Hibernate 구성 프로퍼티들"
 
-#. Tag: property
-#: configuration.xml:360
-#, no-c-format
-msgid "hibernate.dialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.dialect</property>"
 msgstr "hibernate.dialect"
 
 #. Tag: entry
-#: configuration.xml:362
 #, fuzzy, no-c-format
 msgid ""
 "The classname of a Hibernate <classname>org.hibernate.dialect.Dialect</"
@@ -633,7 +498,6 @@
 "해주는 Hibernate <placeholder-1/>의 클래스명. <placeholder-2/>"
 
 #. Tag: para
-#: configuration.xml:365
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>full.classname.of."
@@ -643,7 +507,6 @@
 "<literal>false</literal>"
 
 #. Tag: para
-#: configuration.xml:369
 #, no-c-format
 msgid ""
 "In most cases Hibernate will actually be able to choose the correct "
@@ -651,14 +514,12 @@
 "the <literal>JDBC metadata</literal> returned by the JDBC driver."
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:378
-#, no-c-format
-msgid "hibernate.show_sql"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.show_sql</property>"
 msgstr "hibernate.show_sql"
 
 #. Tag: entry
-#: configuration.xml:380
 #, fuzzy, no-c-format
 msgid ""
 "Write all SQL statements to console. This is an alternative to setting the "
@@ -669,11 +530,6 @@
 "<placeholder-2/>로 설정하는 것에 대한 하나의 다른 방법이다. <placeholder-3/>"
 
 #. Tag: para
-#: configuration.xml:384 configuration.xml:396 configuration.xml:490
-#: configuration.xml:503 configuration.xml:516 configuration.xml:529
-#: configuration.xml:583 configuration.xml:610 configuration.xml:623
-#: configuration.xml:678 configuration.xml:906 configuration.xml:921
-#: configuration.xml:1011
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>true</literal> | "
@@ -682,26 +538,22 @@
 "<emphasis role=\"strong\">예.</emphasis><literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: property
-#: configuration.xml:392
-#, no-c-format
-msgid "hibernate.format_sql"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.format_sql</property>"
 msgstr "hibernate.format_sql"
 
 #. Tag: entry
-#: configuration.xml:394
 #, fuzzy, no-c-format
 msgid "Pretty print the SQL in the log and console."
 msgstr "로그와 콘솔 속에 SQL을 깔끔하게 프린트한다. <placeholder-1/>"
 
-#. Tag: property
-#: configuration.xml:404
-#, no-c-format
-msgid "hibernate.default_schema"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.default_schema</property>"
 msgstr "hibernate.default_schema"
 
 #. Tag: entry
-#: configuration.xml:406
 #, fuzzy, no-c-format
 msgid ""
 "Qualify unqualified table names with the given schema/tablespace in "
@@ -711,7 +563,6 @@
 "한다. <placeholder-1/>"
 
 #. Tag: para
-#: configuration.xml:409
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>SCHEMA_NAME</literal>"
@@ -719,14 +570,12 @@
 "<emphasis role=\"strong\">예.</emphasis><literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: property
-#: configuration.xml:417
-#, no-c-format
-msgid "hibernate.default_catalog"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.default_catalog</property>"
 msgstr "hibernate.default_catalog"
 
 #. Tag: entry
-#: configuration.xml:419
 #, fuzzy, no-c-format
 msgid ""
 "Qualifies unqualified table names with the given catalog in generated SQL."
@@ -735,7 +584,6 @@
 "<placeholder-1/>"
 
 #. Tag: para
-#: configuration.xml:422
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>CATALOG_NAME</literal>"
@@ -743,14 +591,12 @@
 "<emphasis role=\"strong\">예.</emphasis><literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: property
-#: configuration.xml:430
-#, no-c-format
-msgid "hibernate.session_factory_name"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.session_factory_name</property>"
 msgstr "hibernate.session_factory_name"
 
 #. Tag: entry
-#: configuration.xml:432
 #, fuzzy, no-c-format
 msgid ""
 "The <interfacename>org.hibernate.SessionFactory</interfacename> will be "
@@ -760,7 +606,6 @@
 "드 될 것이다. <placeholder-2/>"
 
 #. Tag: para
-#: configuration.xml:435 configuration.xml:877
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>jndi/composite/name</"
@@ -769,14 +614,12 @@
 "<emphasis role=\"strong\">예.</emphasis><literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: property
-#: configuration.xml:443
-#, no-c-format
-msgid "hibernate.max_fetch_depth"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.max_fetch_depth</property>"
 msgstr "hibernate.max_fetch_depth"
 
 #. Tag: entry
-#: configuration.xml:445
 #, fuzzy, no-c-format
 msgid ""
 "Sets a maximum \"depth\" for the outer join fetch tree for single-ended "
@@ -788,7 +631,6 @@
 "을 사용불가능하게 만든다. <placeholder-2/>"
 
 #. Tag: para
-#: configuration.xml:449
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values between "
@@ -797,21 +639,18 @@
 "<emphasis role=\"strong\">예.</emphasis><literal>0</literal>과 <literal>3</"
 "literal> 사이의 값들이권장된다"
 
-#. Tag: property
-#: configuration.xml:458
-#, no-c-format
-msgid "hibernate.default_batch_fetch_size"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.default_batch_fetch_size</property>"
 msgstr "hibernate.default_batch_fetch_size"
 
 #. Tag: entry
-#: configuration.xml:460
 #, fuzzy, no-c-format
 msgid "Sets a default size for Hibernate batch fetching of associations."
 msgstr ""
 "연관들의 Hibernate 배치 페칭에 대한 디폴트 크기를 설정한다. <placeholder-1/>"
 
 #. Tag: para
-#: configuration.xml:462
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values <literal>4</"
@@ -820,14 +659,12 @@
 "<emphasis role=\"strong\">예.</emphasis> 권장되는 값들은 <literal>4</"
 "literal>, <literal>8</literal>, <literal>16</literal>"
 
-#. Tag: property
-#: configuration.xml:471
-#, no-c-format
-msgid "hibernate.default_entity_mode"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.default_entity_mode</property>"
 msgstr "hibernate.default_entity_mode"
 
 #. Tag: entry
-#: configuration.xml:473
 #, fuzzy, no-c-format
 msgid ""
 "Sets a default mode for entity representation for all sessions opened from "
@@ -837,7 +674,6 @@
 "로 설정한다 <placeholder-2/>"
 
 #. Tag: para
-#: configuration.xml:476
 #, no-c-format
 msgid ""
 "<literal>dynamic-map</literal>, <literal>dom4j</literal>, <literal>pojo</"
@@ -846,14 +682,12 @@
 "<literal>dynamic-map</literal>, <literal>dom4j</literal>, <literal>pojo</"
 "literal>"
 
-#. Tag: property
-#: configuration.xml:484
-#, no-c-format
-msgid "hibernate.order_updates"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.order_updates</property>"
 msgstr "hibernate.order_updates"
 
 #. Tag: entry
-#: configuration.xml:486
 #, fuzzy, no-c-format
 msgid ""
 "Forces Hibernate to order SQL updates by the primary key value of the items "
@@ -864,14 +698,12 @@
 "(ordering)지워지도록 Hibernate에게 강제시킨다. 이것은 고도의 동시성 시스템들"
 "에서 더 적은 트랜잭션 데드락(deadlock)들로 귀결될 것이다 <placeholder-1/>"
 
-#. Tag: property
-#: configuration.xml:498
-#, no-c-format
-msgid "hibernate.generate_statistics"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.generate_statistics</property>"
 msgstr "hibernate.generate_statistics"
 
 #. Tag: entry
-#: configuration.xml:500
 #, fuzzy, no-c-format
 msgid ""
 "If enabled, Hibernate will collect statistics useful for performance tuning."
@@ -879,14 +711,12 @@
 "이용 가능하게 되면, Hibernate는 퍼포먼스 튜닝에 유용한 통계들을 수집할 것이"
 "다. <placeholder-1/>"
 
-#. Tag: property
-#: configuration.xml:511
-#, no-c-format
-msgid "hibernate.use_identifier_rollback"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.use_identifier_rollback</property>"
 msgstr "hibernate.use_identifer_rollback"
 
 #. Tag: entry
-#: configuration.xml:513
 #, fuzzy, no-c-format
 msgid ""
 "If enabled, generated identifier properties will be reset to default values "
@@ -895,14 +725,12 @@
 "이용 가능하게 되면, 객체가 삭제될 때 생성된 식별자 프로퍼티들은 디폴트 값들"
 "로 재설정될 것이다. <placeholder-1/>"
 
-#. Tag: property
-#: configuration.xml:524
-#, no-c-format
-msgid "hibernate.use_sql_comments"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.use_sql_comments</property>"
 msgstr "hibernate.use_sql_comments"
 
 #. Tag: entry
-#: configuration.xml:526
 #, fuzzy, no-c-format
 msgid ""
 "If turned on, Hibernate will generate comments inside the SQL, for easier "
@@ -912,19 +740,16 @@
 "성시킬 것이다. 디폴트는 <placeholder-1/>. <placeholder-2/>"
 
 #. Tag: title
-#: configuration.xml:540
 #, no-c-format
 msgid "Hibernate JDBC and Connection Properties"
 msgstr "Hibernate JDBC 및 커넥션 프로퍼티들"
 
-#. Tag: property
-#: configuration.xml:555
-#, no-c-format
-msgid "hibernate.jdbc.fetch_size"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.jdbc.fetch_size</property>"
 msgstr "hibernate.jdbc.fetch_size"
 
 #. Tag: entry
-#: configuration.xml:557
 #, fuzzy, no-c-format
 msgid ""
 "A non-zero value determines the JDBC fetch size (calls <literal>Statement."
@@ -932,14 +757,12 @@
 msgstr ""
 "0 아닌 값은 JDBC fetch 사이즈를 결정한다(<placeholder-1/>을 호출한다 )."
 
-#. Tag: property
-#: configuration.xml:564
-#, no-c-format
-msgid "hibernate.jdbc.batch_size"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.jdbc.batch_size</property>"
 msgstr "hibernate.jdbc.batch_size"
 
 #. Tag: entry
-#: configuration.xml:566
 #, fuzzy, no-c-format
 msgid "A non-zero value enables use of JDBC2 batch updates by Hibernate."
 msgstr ""
@@ -947,7 +770,6 @@
 "다. <placeholder-1/>"
 
 #. Tag: para
-#: configuration.xml:568
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values between "
@@ -956,14 +778,12 @@
 "<emphasis role=\"strong\">예.</emphasis><literal>5</literal>와 <literal>30</"
 "literal> 사이의 값들이 권장된다"
 
-#. Tag: property
-#: configuration.xml:576
-#, no-c-format
-msgid "hibernate.jdbc.batch_versioned_data"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.jdbc.batch_versioned_data</property>"
 msgstr "hibernate.jdbc.batch_versioned_data"
 
 #. Tag: entry
-#: configuration.xml:578
 #, fuzzy, no-c-format
 msgid ""
 "Set this property to <literal>true</literal> if your JDBC driver returns "
@@ -977,14 +797,12 @@
 "치화된(batched) DML을 사용할 것이다. 디폴트는 <placeholder-3/>. <placeholder-"
 "4/>"
 
-#. Tag: property
-#: configuration.xml:591
-#, no-c-format
-msgid "hibernate.jdbc.factory_class"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.jdbc.factory_class</property>"
 msgstr "hibernate.jdbc.factory_class"
 
 #. Tag: entry
-#: configuration.xml:593
 #, fuzzy, no-c-format
 msgid ""
 "Select a custom <interfacename>org.hibernate.jdbc.Batcher</interfacename>. "
@@ -994,7 +812,6 @@
 "티를 필요로 하지 않을 것이다. <placeholder-2/>"
 
 #. Tag: para
-#: configuration.xml:596
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
@@ -1003,14 +820,12 @@
 "<emphasis role=\"strong\">예.</emphasis><literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: property
-#: configuration.xml:604
-#, no-c-format
-msgid "hibernate.jdbc.use_scrollable_resultset"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.jdbc.use_scrollable_resultset</property>"
 msgstr "hibernate.jdbc.use_scrollable_resultset"
 
 #. Tag: entry
-#: configuration.xml:606
 #, fuzzy, no-c-format
 msgid ""
 "Enables use of JDBC2 scrollable resultsets by Hibernate. This property is "
@@ -1021,14 +836,12 @@
 "로퍼티는 사용자가 제공한 JDBC커넥션들을 사용할 때에만 필수적이고, 그 밖의 경"
 "우 Hibernate는 커넥션 메타데이터를 사용한다. <placeholder-1/>"
 
-#. Tag: property
-#: configuration.xml:618
-#, no-c-format
-msgid "hibernate.jdbc.use_streams_for_binary"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.jdbc.use_streams_for_binary</property>"
 msgstr "hibernate.jdbc.use_streams_for_binary"
 
 #. Tag: entry
-#: configuration.xml:620
 #, fuzzy, no-c-format
 msgid ""
 "Use streams when writing/reading <literal>binary</literal> or "
@@ -1038,14 +851,12 @@
 "FUZZY! <placeholder-1/> 또는 <placeholder-2/> 타입들을 읽어들일 때 스트림들"
 "을 사용한다(시스템-레벨 프로퍼티). <placeholder-3/>"
 
-#. Tag: property
-#: configuration.xml:631
-#, no-c-format
-msgid "hibernate.jdbc.use_get_generated_keys"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.jdbc.use_get_generated_keys</property>"
 msgstr "hibernate.jdbc.use_get_generated_keys"
 
 #. Tag: entry
-#: configuration.xml:633
 #, fuzzy, no-c-format
 msgid ""
 "Enables use of JDBC3 <literal>PreparedStatement.getGeneratedKeys()</literal> "
@@ -1061,22 +872,18 @@
 "라. <placeholder-2/>"
 
 #. Tag: para
-#: configuration.xml:639 configuration.xml:769 configuration.xml:781
-#: configuration.xml:795 configuration.xml:833
 #, fuzzy, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>true|false</literal>"
 msgstr ""
 "<emphasis role=\"strong\">예.</emphasis><literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: property
-#: configuration.xml:647
-#, no-c-format
-msgid "hibernate.connection.provider_class"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.connection.provider_class</property>"
 msgstr "hibernate.connection.provider_class"
 
 #. Tag: entry
-#: configuration.xml:649
 #, fuzzy, no-c-format
 msgid ""
 "The classname of a custom <interfacename>org.hibernate.connection."
@@ -1087,7 +894,6 @@
 "<placeholder-2/>"
 
 #. Tag: para
-#: configuration.xml:652
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
@@ -1096,14 +902,12 @@
 "<emphasis role=\"strong\">예.</emphasis><literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: property
-#: configuration.xml:660
-#, no-c-format
-msgid "hibernate.connection.isolation"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.connection.isolation</property>"
 msgstr "hibernate.connection.isolation"
 
 #. Tag: entry
-#: configuration.xml:662
 #, fuzzy, no-c-format
 msgid ""
 "Sets the JDBC transaction isolation level. Check <interfacename>java.sql."
@@ -1116,35 +920,30 @@
 "않음을 노트하라. <placeholder-2/>"
 
 #. Tag: para
-#: configuration.xml:666
 #, fuzzy, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>1, 2, 4, 8</literal>"
 msgstr ""
 "<emphasis role=\"strong\">예.</emphasis><literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: property
-#: configuration.xml:674
-#, no-c-format
-msgid "hibernate.connection.autocommit"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.connection.autocommit</property>"
 msgstr "hibernate.connection.autocommit"
 
 #. Tag: entry
-#: configuration.xml:676
 #, fuzzy, no-c-format
 msgid "Enables autocommit for JDBC pooled connections (it is not recommended)."
 msgstr ""
 "JDBC 풀링된 커넥션들에 대해 자동커밋을 이용 가능하도록 한다(권장되지 않음). "
 "<placeholder-1/>"
 
-#. Tag: property
-#: configuration.xml:686
-#, no-c-format
-msgid "hibernate.connection.release_mode"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<property>hibernate.connection.release_mode</property>"
 msgstr "hibernate.connection.release_mode"
 
 #. Tag: entry
-#: configuration.xml:688
 #, fuzzy, no-c-format
 msgid ""
 "Specifies when Hibernate should release JDBC connections. By default, a JDBC "
@@ -1167,7 +966,6 @@
 "5/>를 선택할 것이다. <placeholder-6/><placeholder-7/>"
 
 #. Tag: para
-#: configuration.xml:699
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>auto</literal> (default) "
@@ -1179,7 +977,6 @@
 "<literal>after_statement</literal>"
 
 #. Tag: para
-#: configuration.xml:704
 #, fuzzy, no-c-format
 msgid ""
 "This setting only affects <literal>Session</literal>s returned from "
@@ -1187,7 +984,8 @@
 "literal>s obtained through <literal>SessionFactory.getCurrentSession</"
 "literal>, the <literal>CurrentSessionContext</literal> implementation "
 "configured for use controls the connection release mode for those "
-"<literal>Session</literal>s. See"
+"<literal>Session</literal>s. See <xref linkend=\"architecture-current-session"
+"\" />"
 msgstr ""
 "이 설정이 <literal>SessionFactory.openSession</literal>로부터 반환된 "
 "<literal>Session</literal>들에만 영향을 준다는 점을 노트하라. "
@@ -1198,7 +996,6 @@
 "session\"/>를 보라."
 
 #. Tag: entry
-#: configuration.xml:715
 #, no-c-format
 msgid ""
 "<property>hibernate.connection.</property><emphasis>&lt;propertyName&gt;</"
@@ -1206,7 +1003,6 @@
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:718
 #, no-c-format
 msgid ""
 "Pass the JDBC property <emphasis>&lt;propertyName&gt;</emphasis> to "
@@ -1214,14 +1010,12 @@
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:724
 #, no-c-format
 msgid ""
 "<property>hibernate.jndi.</property><emphasis>&lt;propertyName&gt;</emphasis>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:727
 #, no-c-format
 msgid ""
 "Pass the property <emphasis>&lt;propertyName&gt;</emphasis> to the JNDI "
@@ -1229,25 +1023,21 @@
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:737
 #, no-c-format
 msgid "Hibernate Cache Properties"
 msgstr "Hibernate Cache 프로퍼티들"
 
-#. Tag: literal
-#: configuration.xml:750
-#, no-c-format
-msgid "hibernate.cache.provider_class"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.cache.provider_class</literal>"
 msgstr "hibernate.cache.provider_class"
 
 #. Tag: entry
-#: configuration.xml:752
 #, fuzzy, no-c-format
 msgid "The classname of a custom <literal>CacheProvider</literal>."
 msgstr "맞춤형 <placeholder-1/>의 클래스명. <placeholder-2/>"
 
 #. Tag: para
-#: configuration.xml:754
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
@@ -1256,14 +1046,12 @@
 "<emphasis role=\"strong\">예.</emphasis><literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: literal
-#: configuration.xml:762
-#, no-c-format
-msgid "hibernate.cache.use_minimal_puts"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.cache.use_minimal_puts</literal>"
 msgstr "hibernate.cache.use_minimal_puts"
 
 #. Tag: entry
-#: configuration.xml:764
 #, fuzzy, no-c-format
 msgid ""
 "Optimizes second-level cache operation to minimize writes, at the cost of "
@@ -1275,14 +1063,12 @@
 "고, Hibernate3에서는 클러스터링된 캐시 구현들에 대해 디폴트로 이용 가능하다. "
 "<placeholder-1/>"
 
-#. Tag: literal
-#: configuration.xml:777
-#, no-c-format
-msgid "hibernate.cache.use_query_cache"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.cache.use_query_cache</literal>"
 msgstr "hibernate.cache.use_query_cache"
 
 #. Tag: entry
-#: configuration.xml:779
 #, fuzzy, no-c-format
 msgid ""
 "Enables the query cache. Individual queries still have to be set cachable."
@@ -1290,14 +1076,12 @@
 "질의 캐시를 가능하게 만든다. 개별 질의들은 여전히 캐시 가능한 것으로 설정되어"
 "야 한다. <placeholder-1/>"
 
-#. Tag: literal
-#: configuration.xml:789
-#, no-c-format
-msgid "hibernate.cache.use_second_level_cache"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.cache.use_second_level_cache</literal>"
 msgstr "hibernate.cache.use_second_level_cache"
 
 #. Tag: entry
-#: configuration.xml:791
 #, fuzzy, no-c-format
 msgid ""
 "Can be used to completely disable the second level cache, which is enabled "
@@ -1308,14 +1092,12 @@
 "<placeholder-1/> 매핑을 지정하는 클래스들에 대해 디폴트로 이용 가능이다. "
 "<placeholder-2/>"
 
-#. Tag: literal
-#: configuration.xml:803
-#, no-c-format
-msgid "hibernate.cache.query_cache_factory"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.cache.query_cache_factory</literal>"
 msgstr "hibernate.cache.query_cache_factory"
 
 #. Tag: entry
-#: configuration.xml:805
 #, fuzzy, no-c-format
 msgid ""
 "The classname of a custom <literal>QueryCache</literal> interface, defaults "
@@ -1325,7 +1107,6 @@
 "<placeholder-2/>. <placeholder-3/>"
 
 #. Tag: para
-#: configuration.xml:808
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of.QueryCache</"
@@ -1334,34 +1115,29 @@
 "<emphasis role=\"strong\">예.</emphasis><literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: literal
-#: configuration.xml:816
-#, no-c-format
-msgid "hibernate.cache.region_prefix"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.cache.region_prefix</literal>"
 msgstr "hibernate.cache.region_prefix"
 
 #. Tag: entry
-#: configuration.xml:818
 #, fuzzy, no-c-format
 msgid "A prefix to use for second-level cache region names."
 msgstr "second-level 캐시 영역 이름들에 사용할 접두어. <placeholder-1/>"
 
 #. Tag: para
-#: configuration.xml:820
 #, fuzzy, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>prefix</literal>"
 msgstr ""
 "<emphasis role=\"strong\">예.</emphasis><literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: literal
-#: configuration.xml:828
-#, no-c-format
-msgid "hibernate.cache.use_structured_entries"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.cache.use_structured_entries</literal>"
 msgstr "hibernate.cache.use_structured_entries"
 
 #. Tag: entry
-#: configuration.xml:830
 #, fuzzy, no-c-format
 msgid ""
 "Forces Hibernate to store data in the second-level cache in a more human-"
@@ -1371,19 +1147,16 @@
 "Hibernate에게 강제시킨다.. <placeholder-1/>"
 
 #. Tag: title
-#: configuration.xml:844
 #, no-c-format
 msgid "Hibernate Transaction Properties"
 msgstr "Hibernate 트랜잭션 프로퍼티들"
 
-#. Tag: literal
-#: configuration.xml:857
-#, no-c-format
-msgid "hibernate.transaction.factory_class"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.factory_class</literal>"
 msgstr "hibernate.transaction.factory_class"
 
 #. Tag: entry
-#: configuration.xml:859
 #, fuzzy, no-c-format
 msgid ""
 "The classname of a <literal>TransactionFactory</literal> to use with "
@@ -1394,7 +1167,6 @@
 "트는 <placeholder-3/>). <placeholder-4/>"
 
 #. Tag: para
-#: configuration.xml:863
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
@@ -1403,14 +1175,12 @@
 "<emphasis role=\"strong\">예.</emphasis><literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: literal
-#: configuration.xml:871
-#, no-c-format
-msgid "jta.UserTransaction"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>jta.UserTransaction</literal>"
 msgstr "jta.UserTransaction"
 
 #. Tag: entry
-#: configuration.xml:873
 #, fuzzy, no-c-format
 msgid ""
 "A JNDI name used by <literal>JTATransactionFactory</literal> to obtain the "
@@ -1419,14 +1189,12 @@
 "어플리케이션 서버로부터 JTA <placeholder-1/>을 얻기 위해 <placeholder-2/>에 "
 "의해 사용되는 JNDI 이름. <placeholder-3/>"
 
-#. Tag: literal
-#: configuration.xml:885
-#, no-c-format
-msgid "hibernate.transaction.manager_lookup_class"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.manager_lookup_class</literal>"
 msgstr "hibernate.transaction.manager_lookup_class"
 
 #. Tag: entry
-#: configuration.xml:887
 #, fuzzy, no-c-format
 msgid ""
 "The classname of a <literal>TransactionManagerLookup</literal>. It is "
@@ -1437,7 +1205,6 @@
 "서 hilo generator를 사용할 때 필요하다. <placeholder-2/>"
 
 #. Tag: para
-#: configuration.xml:891
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
@@ -1446,19 +1213,17 @@
 "<emphasis role=\"strong\">예.</emphasis><literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: literal
-#: configuration.xml:899
-#, no-c-format
-msgid "hibernate.transaction.flush_before_completion"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.flush_before_completion</literal>"
 msgstr "hibernate.transaction.flush_before_completion"
 
 #. Tag: entry
-#: configuration.xml:901
 #, fuzzy, no-c-format
 msgid ""
 "If enabled, the session will be automatically flushed during the before "
 "completion phase of the transaction. Built-in and automatic session context "
-"management is preferred, see <xref linkend=\"architecture-current-session\"/"
+"management is preferred, see <xref linkend=\"architecture-current-session\" /"
 ">."
 msgstr ""
 "만일 사용가능하도록 되면, 세션은 트랜잭션의 before completion 단계 동안에 자"
@@ -1466,50 +1231,44 @@
 "는데, <xref linkend=\"architecture-current-session\"/>를 보라. <placeholder-"
 "1/>"
 
-#. Tag: literal
-#: configuration.xml:914
-#, no-c-format
-msgid "hibernate.transaction.auto_close_session"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.auto_close_session</literal>"
 msgstr "hibernate.transaction.auto_close_session"
 
 #. Tag: entry
-#: configuration.xml:916
 #, fuzzy, no-c-format
 msgid ""
 "If enabled, the session will be automatically closed during the after "
 "completion phase of the transaction. Built-in and automatic session context "
-"management is preferred, see <xref linkend=\"architecture-current-session\"/"
+"management is preferred, see <xref linkend=\"architecture-current-session\" /"
 ">."
 msgstr ""
 "만일 사용가능토록 하면, after completion 단계 동안에 세션이 자동적으로 닫혀"
 "질 것이다. (CMT에 대해 Hibernate를 사용할 때 매우 유용하다.) <placeholder-1/>"
 
 #. Tag: title
-#: configuration.xml:932
 #, no-c-format
 msgid "Miscellaneous Properties"
 msgstr "여러가지 프로퍼티들"
 
-#. Tag: literal
-#: configuration.xml:945
-#, no-c-format
-msgid "hibernate.current_session_context_class"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.current_session_context_class</literal>"
 msgstr "hibernate.current_session_context_class"
 
 #. Tag: entry
-#: configuration.xml:947
 #, fuzzy, no-c-format
 msgid ""
 "Supply a custom strategy for the scoping of the \"current\" "
 "<literal>Session</literal>. See <xref linkend=\"architecture-current-session"
-"\"/> for more information about the built-in strategies."
+"\" /> for more information about the built-in strategies."
 msgstr ""
 "\"현재\" <placeholder-1/>의 영역화를 위한 하나의 (맞춤) 방도를 제공한다. 빌드"
 "되어 있는 방도들에 대한 추가 정보는 <xref linkend=\"architecture-current-"
 "session\"/>를 보라. <placeholder-2/>"
 
 #. Tag: para
-#: configuration.xml:952
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>jta</literal> | "
@@ -1520,20 +1279,17 @@
 "<literal>thread</literal> | <literal>managed</literal> | <literal>custom."
 "Class</literal>"
 
-#. Tag: literal
-#: configuration.xml:961
-#, no-c-format
-msgid "hibernate.query.factory_class"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.query.factory_class</literal>"
 msgstr "hibernate.query.factory_class"
 
 #. Tag: entry
-#: configuration.xml:963
 #, fuzzy, no-c-format
 msgid "Chooses the HQL parser implementation."
 msgstr "Chooses the HQL 파서 구현을 선택한다. <placeholder-1/>"
 
 #. Tag: para
-#: configuration.xml:965
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>org.hibernate.hql.ast."
@@ -1544,14 +1300,12 @@
 "ASTQueryTranslatorFactory</literal> or <literal>org.hibernate.hql.classic."
 "ClassicQueryTranslatorFactory</literal>"
 
-#. Tag: literal
-#: configuration.xml:974
-#, no-c-format
-msgid "hibernate.query.substitutions"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.query.substitutions</literal>"
 msgstr "hibernate.query.substitutions"
 
 #. Tag: entry
-#: configuration.xml:976
 #, fuzzy, no-c-format
 msgid ""
 "Is used to map from tokens in Hibernate queries to SQL tokens (tokens might "
@@ -1561,7 +1315,6 @@
 "수 이름 또는 리터럴 이름일 수 있다). <placeholder-1/>"
 
 #. Tag: para
-#: configuration.xml:979
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>hqlLiteral=SQL_LITERAL, "
@@ -1570,14 +1323,12 @@
 "<emphasis role=\"strong\">예.</emphasis><literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: literal
-#: configuration.xml:987
-#, no-c-format
-msgid "hibernate.hbm2ddl.auto"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.hbm2ddl.auto</literal>"
 msgstr "hibernate.hbm2ddl.auto"
 
 #. Tag: entry
-#: configuration.xml:989
 #, fuzzy, no-c-format
 msgid ""
 "Automatically validates or exports schema DDL to the database when the "
@@ -1590,7 +1341,6 @@
 "적으로 닫혀질 때 데이터베이스 스키마가 드롭될 것이다. <placeholder-4/>"
 
 #. Tag: para
-#: configuration.xml:995
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>validate</literal> | "
@@ -1601,14 +1351,12 @@
 "<literal>update</literal> | <literal>create</literal> | <literal>create-"
 "drop</literal>"
 
-#. Tag: literal
-#: configuration.xml:1004
-#, no-c-format
-msgid "hibernate.cglib.use_reflection_optimizer"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.cglib.use_reflection_optimizer</literal>"
 msgstr "hibernate.cglib.use_reflection_optimizer"
 
 #. Tag: entry
-#: configuration.xml:1006
 #, fuzzy, no-c-format
 msgid ""
 "Enables the use of CGLIB instead of runtime reflection (System-level "
@@ -1622,13 +1370,11 @@
 "<placeholder-1/> 속에 이 프로퍼티를 설정할수 없다. <placeholder-2/>"
 
 #. Tag: title
-#: configuration.xml:1022
 #, no-c-format
 msgid "SQL Dialects"
 msgstr "SQL Dialects"
 
 #. Tag: para
-#: configuration.xml:1024
 #, fuzzy, no-c-format
 msgid ""
 "Always set the <literal>hibernate.dialect</literal> property to the correct "
@@ -1644,307 +1390,256 @@
 "몇몇에 대해 의미있는 디폴트들을 사용할 것이다."
 
 #. Tag: title
-#: configuration.xml:1032
 #, no-c-format
 msgid "Hibernate SQL Dialects (<literal>hibernate.dialect</literal>)"
 msgstr "Hibernate SQL Dialects (<literal>hibernate.dialect</literal>)"
 
 #. Tag: entry
-#: configuration.xml:1040
 #, no-c-format
 msgid "RDBMS"
 msgstr "RDBMS"
 
 #. Tag: entry
-#: configuration.xml:1041
 #, no-c-format
 msgid "Dialect"
 msgstr "Dialect"
 
 #. Tag: entry
-#: configuration.xml:1046
 #, no-c-format
-msgid "<entry>DB2</entry>"
-msgstr ""
+msgid "DB2"
+msgstr "DB2"
 
-#. Tag: literal
-#: configuration.xml:1046
-#, no-c-format
-msgid "org.hibernate.dialect.DB2Dialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.DB2Dialect</literal>"
 msgstr "org.hibernate.dialect.DB2Dialect"
 
 #. Tag: entry
-#: configuration.xml:1049
 #, no-c-format
 msgid "DB2 AS/400"
 msgstr "DB2 AS/400"
 
-#. Tag: literal
-#: configuration.xml:1049
-#, no-c-format
-msgid "org.hibernate.dialect.DB2400Dialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.DB2400Dialect</literal>"
 msgstr "org.hibernate.dialect.DB2400Dialect"
 
 #. Tag: entry
-#: configuration.xml:1052
 #, no-c-format
 msgid "DB2 OS390"
 msgstr "DB2 OS390"
 
-#. Tag: literal
-#: configuration.xml:1052
-#, no-c-format
-msgid "org.hibernate.dialect.DB2390Dialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.DB2390Dialect</literal>"
 msgstr "org.hibernate.dialect.DB2390Dialect"
 
 #. Tag: entry
-#: configuration.xml:1055
 #, no-c-format
 msgid "PostgreSQL"
 msgstr "PostgreSQL"
 
-#. Tag: literal
-#: configuration.xml:1055
-#, no-c-format
-msgid "org.hibernate.dialect.PostgreSQLDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.PostgreSQLDialect</literal>"
 msgstr "org.hibernate.dialect.PostgreSQLDialect"
 
 #. Tag: entry
-#: configuration.xml:1058
 #, no-c-format
 msgid "MySQL"
 msgstr "MySQL"
 
-#. Tag: literal
-#: configuration.xml:1058
-#, no-c-format
-msgid "org.hibernate.dialect.MySQLDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.MySQLDialect</literal>"
 msgstr "org.hibernate.dialect.MySQLDialect"
 
 #. Tag: entry
-#: configuration.xml:1061
 #, no-c-format
 msgid "MySQL with InnoDB"
 msgstr "MySQL with InnoDB"
 
-#. Tag: literal
-#: configuration.xml:1061
-#, no-c-format
-msgid "org.hibernate.dialect.MySQLInnoDBDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.MySQLInnoDBDialect</literal>"
 msgstr "org.hibernate.dialect.MySQLInnoDBDialect"
 
 #. Tag: entry
-#: configuration.xml:1064
 #, no-c-format
 msgid "MySQL with MyISAM"
 msgstr "MySQL with MyISAM"
 
-#. Tag: literal
-#: configuration.xml:1064
-#, no-c-format
-msgid "org.hibernate.dialect.MySQLMyISAMDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.MySQLMyISAMDialect</literal>"
 msgstr "org.hibernate.dialect.MySQLMyISAMDialect"
 
 #. Tag: entry
-#: configuration.xml:1067
 #, no-c-format
 msgid "Oracle (any version)"
 msgstr "Oracle (any version)"
 
-#. Tag: literal
-#: configuration.xml:1067
-#, no-c-format
-msgid "org.hibernate.dialect.OracleDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.OracleDialect</literal>"
 msgstr "org.hibernate.dialect.OracleDialect"
 
 #. Tag: entry
-#: configuration.xml:1070
 #, fuzzy, no-c-format
 msgid "Oracle 9i"
 msgstr "Oracle 9i/10g"
 
-#. Tag: literal
-#: configuration.xml:1070
+#. Tag: entry
 #, fuzzy, no-c-format
-msgid "org.hibernate.dialect.Oracle9iDialect"
+msgid "<literal>org.hibernate.dialect.Oracle9iDialect</literal>"
 msgstr "org.hibernate.dialect.Oracle9Dialect"
 
 #. Tag: entry
-#: configuration.xml:1073
 #, fuzzy, no-c-format
 msgid "Oracle 10g"
 msgstr "Oracle 9i/10g"
 
-#. Tag: literal
-#: configuration.xml:1073
+#. Tag: entry
 #, fuzzy, no-c-format
-msgid "org.hibernate.dialect.Oracle10gDialect"
+msgid "<literal>org.hibernate.dialect.Oracle10gDialect</literal>"
 msgstr "org.hibernate.dialect.OracleDialect"
 
 #. Tag: entry
-#: configuration.xml:1076
 #, no-c-format
 msgid "Sybase"
 msgstr "Sybase"
 
-#. Tag: literal
-#: configuration.xml:1076
-#, no-c-format
-msgid "org.hibernate.dialect.SybaseDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.SybaseDialect</literal>"
 msgstr "org.hibernate.dialect.SybaseDialect"
 
 #. Tag: entry
-#: configuration.xml:1079
 #, no-c-format
 msgid "Sybase Anywhere"
 msgstr "Sybase Anywhere"
 
-#. Tag: literal
-#: configuration.xml:1079
-#, no-c-format
-msgid "org.hibernate.dialect.SybaseAnywhereDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.SybaseAnywhereDialect</literal>"
 msgstr "org.hibernate.dialect.SybaseAnywhereDialect"
 
 #. Tag: entry
-#: configuration.xml:1082
 #, no-c-format
 msgid "Microsoft SQL Server"
 msgstr "Microsoft SQL Server"
 
-#. Tag: literal
-#: configuration.xml:1082
-#, no-c-format
-msgid "org.hibernate.dialect.SQLServerDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.SQLServerDialect</literal>"
 msgstr "org.hibernate.dialect.SQLServerDialect"
 
 #. Tag: entry
-#: configuration.xml:1085
 #, no-c-format
 msgid "SAP DB"
 msgstr "SAP DB"
 
-#. Tag: literal
-#: configuration.xml:1085
-#, no-c-format
-msgid "org.hibernate.dialect.SAPDBDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.SAPDBDialect</literal>"
 msgstr "org.hibernate.dialect.SAPDBDialect"
 
 #. Tag: entry
-#: configuration.xml:1088
 #, no-c-format
 msgid "Informix"
 msgstr "Informix"
 
-#. Tag: literal
-#: configuration.xml:1088
-#, no-c-format
-msgid "org.hibernate.dialect.InformixDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.InformixDialect</literal>"
 msgstr "org.hibernate.dialect.InformixDialect"
 
 #. Tag: entry
-#: configuration.xml:1091
 #, no-c-format
 msgid "HypersonicSQL"
 msgstr "HypersonicSQL"
 
-#. Tag: literal
-#: configuration.xml:1091
-#, no-c-format
-msgid "org.hibernate.dialect.HSQLDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.HSQLDialect</literal>"
 msgstr "org.hibernate.dialect.HSQLDialect"
 
 #. Tag: entry
-#: configuration.xml:1094
 #, no-c-format
 msgid "Ingres"
 msgstr "Ingres"
 
-#. Tag: literal
-#: configuration.xml:1094
-#, no-c-format
-msgid "org.hibernate.dialect.IngresDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.IngresDialect</literal>"
 msgstr "org.hibernate.dialect.IngresDialect"
 
 #. Tag: entry
-#: configuration.xml:1097
 #, no-c-format
 msgid "Progress"
 msgstr "Progress"
 
-#. Tag: literal
-#: configuration.xml:1097
-#, no-c-format
-msgid "org.hibernate.dialect.ProgressDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.ProgressDialect</literal>"
 msgstr "org.hibernate.dialect.ProgressDialect"
 
 #. Tag: entry
-#: configuration.xml:1100
 #, no-c-format
 msgid "Mckoi SQL"
 msgstr "Mckoi SQL"
 
-#. Tag: literal
-#: configuration.xml:1100
-#, no-c-format
-msgid "org.hibernate.dialect.MckoiDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.MckoiDialect</literal>"
 msgstr "org.hibernate.dialect.MckoiDialect"
 
 #. Tag: entry
-#: configuration.xml:1103
 #, no-c-format
 msgid "Interbase"
 msgstr "Interbase"
 
-#. Tag: literal
-#: configuration.xml:1103
-#, no-c-format
-msgid "org.hibernate.dialect.InterbaseDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.InterbaseDialect</literal>"
 msgstr "org.hibernate.dialect.InterbaseDialect"
 
 #. Tag: entry
-#: configuration.xml:1106
 #, no-c-format
 msgid "Pointbase"
 msgstr "Pointbase"
 
-#. Tag: literal
-#: configuration.xml:1106
-#, no-c-format
-msgid "org.hibernate.dialect.PointbaseDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.PointbaseDialect</literal>"
 msgstr "org.hibernate.dialect.PointbaseDialect"
 
 #. Tag: entry
-#: configuration.xml:1109
 #, no-c-format
 msgid "FrontBase"
 msgstr "FrontBase"
 
-#. Tag: literal
-#: configuration.xml:1109
-#, no-c-format
-msgid "org.hibernate.dialect.FrontbaseDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.FrontbaseDialect</literal>"
 msgstr "org.hibernate.dialect.FrontbaseDialect"
 
 #. Tag: entry
-#: configuration.xml:1112
 #, no-c-format
 msgid "Firebird"
 msgstr "Firebird"
 
-#. Tag: literal
-#: configuration.xml:1112
-#, no-c-format
-msgid "org.hibernate.dialect.FirebirdDialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.dialect.FirebirdDialect</literal>"
 msgstr "org.hibernate.dialect.FirebirdDialect"
 
 #. Tag: title
-#: configuration.xml:1121
 #, no-c-format
 msgid "Outer Join Fetching"
 msgstr "Outer Join Fetching"
 
 #. Tag: para
-#: configuration.xml:1123
 #, fuzzy, no-c-format
 msgid ""
 "If your database supports ANSI, Oracle or Sybase style outer joins, "
@@ -1964,7 +1659,6 @@
 "<literal>SELECT</literal> 속에서 검색되게끔 허용해준다."
 
 #. Tag: para
-#: configuration.xml:1132
 #, fuzzy, no-c-format
 msgid ""
 "Outer join fetching can be disabled <emphasis>globally</emphasis> by setting "
@@ -1980,19 +1674,16 @@
 "outer join fetching을 사용 가능하도록 만든다."
 
 #. Tag: para
-#: configuration.xml:1140
-#, no-c-format
-msgid "See <xref linkend=\"performance-fetching\"/> for more information."
+#, fuzzy, no-c-format
+msgid "See <xref linkend=\"performance-fetching\" /> for more information."
 msgstr "추가 정보는 <xref linkend=\"performance-fetching\"/>를 보라."
 
 #. Tag: title
-#: configuration.xml:1147
 #, no-c-format
 msgid "Binary Streams"
 msgstr "Binary Streams"
 
 #. Tag: para
-#: configuration.xml:1149
 #, fuzzy, no-c-format
 msgid ""
 "Oracle limits the size of <literal>byte</literal> arrays that can be passed "
@@ -2008,31 +1699,27 @@
 "능하게 해야 할 것이다. <emphasis>이것은 오직 시스템 레벨 설정이다.</emphasis>"
 
 #. Tag: title
-#: configuration.xml:1160
 #, no-c-format
 msgid "Second-level and query cache"
 msgstr "Second-level 캐시와 query 캐시"
 
 #. Tag: para
-#: configuration.xml:1162
 #, fuzzy, no-c-format
 msgid ""
 "The properties prefixed by <literal>hibernate.cache</literal> allow you to "
 "use a process or cluster scoped second-level cache system with Hibernate. "
-"See the <xref linkend=\"performance-cache\"/> for more information."
+"See the <xref linkend=\"performance-cache\" /> for more information."
 msgstr ""
 "<literal>hibernate.cache</literal> 접두어가 붙은 프로퍼티들은 Hibernate에 대"
 "해 프로세스 또는 클러스터 범위의 두 번째 레벨 캐시 시스템을 사용하는 것을 허"
 "용해준다. 상세한 것은 <xref linkend=\"performance-cache\"/>를 보라."
 
 #. Tag: title
-#: configuration.xml:1172
 #, no-c-format
 msgid "Query Language Substitution"
 msgstr "Query Language 치환"
 
 #. Tag: para
-#: configuration.xml:1174
 #, fuzzy, no-c-format
 msgid ""
 "You can define new Hibernate query tokens using <literal>hibernate.query."
@@ -2041,14 +1728,7 @@
 "당신은 <literal>hibernate.query.substitutions</literal>을 사용하여 새로운 "
 "Hibernate 질의 토큰들을 정의할 수 있다. 예를 들어:"
 
-#. Tag: programlisting
-#: configuration.xml:1179
-#, no-c-format
-msgid "hibernate.query.substitutions true=1, false=0"
-msgstr "hibernate.query.substitutions true=1, false=0"
-
 #. Tag: para
-#: configuration.xml:1181
 #, fuzzy, no-c-format
 msgid ""
 "This would cause the tokens <literal>true</literal> and <literal>false</"
@@ -2057,14 +1737,7 @@
 "은<literal>true</literal>와 <literal>false</literal> 토큰들이 생성된 SQL 내에"
 "서 정수 리터럴들로 번역되도록 강제할 것이다."
 
-#. Tag: programlisting
-#: configuration.xml:1186
-#, no-c-format
-msgid "hibernate.query.substitutions toLowercase=LOWER"
-msgstr "hibernate.query.substitutions toLowercase=LOWER"
-
 #. Tag: para
-#: configuration.xml:1188
 #, fuzzy, no-c-format
 msgid ""
 "This would allow you to rename the SQL <literal>LOWER</literal> function."
@@ -2073,13 +1746,11 @@
 "허용해 줄 것이다"
 
 #. Tag: title
-#: configuration.xml:1195
 #, no-c-format
 msgid "Hibernate statistics"
 msgstr "Hibernate 통계"
 
 #. Tag: para
-#: configuration.xml:1197
 #, fuzzy, no-c-format
 msgid ""
 "If you enable <literal>hibernate.generate_statistics</literal>, Hibernate "
@@ -2096,13 +1767,11 @@
 "Javadoc를 읽어라."
 
 #. Tag: title
-#: configuration.xml:1209
 #, no-c-format
 msgid "Logging"
 msgstr "로깅"
 
 #. Tag: para
-#: configuration.xml:1211
 #, no-c-format
 msgid ""
 "Hibernate utilizes <ulink url=\"http://www.slf4j.org/\">Simple Logging "
@@ -2120,7 +1789,6 @@
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1222
 #, fuzzy, no-c-format
 msgid ""
 "It is recommended that you familiarize yourself with Hibernate's log "
@@ -2135,67 +1803,56 @@
 "다음에 있다:"
 
 #. Tag: title
-#: configuration.xml:1231
 #, no-c-format
 msgid "Hibernate Log Categories"
 msgstr "Hibernate 로그 카테고리들"
 
 #. Tag: entry
-#: configuration.xml:1237
 #, no-c-format
 msgid "Category"
 msgstr "카테고리"
 
 #. Tag: entry
-#: configuration.xml:1238
 #, no-c-format
 msgid "Function"
 msgstr "기능"
 
-#. Tag: literal
-#: configuration.xml:1243
-#, no-c-format
-msgid "org.hibernate.SQL"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.SQL</literal>"
 msgstr "org.hibernate.SQL"
 
 #. Tag: entry
-#: configuration.xml:1244
 #, no-c-format
 msgid "Log all SQL DML statements as they are executed"
 msgstr "SQL DML 문장들이 실행될 때 그것들 모두를 로그 시킨다"
 
-#. Tag: literal
-#: configuration.xml:1247
-#, no-c-format
-msgid "org.hibernate.type"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.type</literal>"
 msgstr "org.hibernate.type"
 
 #. Tag: entry
-#: configuration.xml:1248
 #, no-c-format
 msgid "Log all JDBC parameters"
 msgstr "모든 JDBC 파라미터들을 로그시킨다"
 
-#. Tag: literal
-#: configuration.xml:1251
-#, no-c-format
-msgid "org.hibernate.tool.hbm2ddl"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.tool.hbm2ddl</literal>"
 msgstr "org.hibernate.tool.hbm2ddl"
 
 #. Tag: entry
-#: configuration.xml:1252
 #, no-c-format
 msgid "Log all SQL DDL statements as they are executed"
 msgstr "SQL DDL 문장들이 실행될 때 그것들 모두를 로그 시킨다"
 
-#. Tag: literal
-#: configuration.xml:1255
-#, no-c-format
-msgid "org.hibernate.pretty"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.pretty</literal>"
 msgstr "org.hibernate.pretty"
 
 #. Tag: entry
-#: configuration.xml:1256
 #, no-c-format
 msgid ""
 "Log the state of all entities (max 20 entities) associated with the session "
@@ -2204,74 +1861,62 @@
 "flush 시점에서 세션과 연관된 모든 엔티티들(최대 20개의 엔티티들)의 상태를 로"
 "그 시킨다"
 
-#. Tag: literal
-#: configuration.xml:1262
-#, no-c-format
-msgid "org.hibernate.cache"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache</literal>"
 msgstr "org.hibernate.cache"
 
 #. Tag: entry
-#: configuration.xml:1263
 #, no-c-format
 msgid "Log all second-level cache activity"
 msgstr "모든 second-level 캐시 액티비티를 로그시킨다"
 
-#. Tag: literal
-#: configuration.xml:1266
-#, no-c-format
-msgid "org.hibernate.transaction"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.transaction</literal>"
 msgstr "org.hibernate.transaction"
 
 #. Tag: entry
-#: configuration.xml:1267
 #, no-c-format
 msgid "Log transaction related activity"
 msgstr "트랜잭션 관련 액티비티를 로그 시킨다"
 
-#. Tag: literal
-#: configuration.xml:1270
-#, no-c-format
-msgid "org.hibernate.jdbc"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.jdbc</literal>"
 msgstr "org.hibernate.jdbc"
 
 #. Tag: entry
-#: configuration.xml:1271
 #, no-c-format
 msgid "Log all JDBC resource acquisition"
 msgstr "모든 JDBC 리소스 취득을 로그 시킨다"
 
-#. Tag: literal
-#: configuration.xml:1274
-#, no-c-format
-msgid "org.hibernate.hql.ast.AST"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.hql.ast.AST</literal>"
 msgstr "org.hibernate.hql.ast.AST"
 
 #. Tag: entry
-#: configuration.xml:1275
 #, no-c-format
 msgid "Log HQL and SQL ASTs during query parsing"
 msgstr "질의 파싱 동안에 HQL AST와 SQL AST를 로그시킨다"
 
-#. Tag: literal
-#: configuration.xml:1280
-#, no-c-format
-msgid "org.hibernate.secure"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.secure</literal>"
 msgstr "org.hibernate.secure"
 
 #. Tag: entry
-#: configuration.xml:1281
 #, no-c-format
 msgid "Log all JAAS authorization requests"
 msgstr "모든 JAAS 허가 요청들을 로그시킨다"
 
-#. Tag: literal
-#: configuration.xml:1284
-#, no-c-format
-msgid "org.hibernate"
-msgstr "org.hibernate"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate</literal>"
+msgstr "JNDI-bound <literal>SessionFactory</literal>"
 
 #. Tag: entry
-#: configuration.xml:1285
 #, fuzzy, no-c-format
 msgid ""
 "Log everything. This is a lot of information but it is useful for "
@@ -2279,7 +1924,6 @@
 msgstr "모든 것을 로그시킨다(많은 정보이지만, 문제해결에 매우 유용하다)"
 
 #. Tag: para
-#: configuration.xml:1294
 #, no-c-format
 msgid ""
 "When developing applications with Hibernate, you should almost always work "
@@ -2293,13 +1937,11 @@
 "티를 이용가능하게 하여 작업해야 할 것이다."
 
 #. Tag: title
-#: configuration.xml:1304
 #, no-c-format
 msgid "Implementing a <literal>NamingStrategy</literal>"
 msgstr "<literal>NamingStrategy</literal> 구현하기"
 
 #. Tag: para
-#: configuration.xml:1306
 #, no-c-format
 msgid ""
 "The interface <literal>org.hibernate.cfg.NamingStrategy</literal> allows you "
@@ -2310,7 +1952,6 @@
 "용해준다."
 
 #. Tag: para
-#: configuration.xml:1311
 #, fuzzy, no-c-format
 msgid ""
 "You can provide rules for automatically generating database identifiers from "
@@ -2328,7 +1969,6 @@
 "주 작은 작품이다."
 
 #. Tag: para
-#: configuration.xml:1320
 #, fuzzy, no-c-format
 msgid ""
 "You can specify a different strategy by calling <literal>Configuration."
@@ -2337,19 +1977,7 @@
 "당신은 매핑들을 추가하기 이전에 <literal>Configuration.setNamingStrategy()</"
 "literal>를 호출함으로써 다른 방도를 지정할 수 있다:"
 
-#. Tag: programlisting
-#: configuration.xml:1325
-#, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration()\n"
-"    .setNamingStrategy(ImprovedNamingStrategy.INSTANCE)\n"
-"    .addFile(\"Item.hbm.xml\")\n"
-"    .addFile(\"Bid.hbm.xml\")\n"
-"    .buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1327
 #, no-c-format
 msgid ""
 "<literal>org.hibernate.cfg.ImprovedNamingStrategy</literal> is a built-in "
@@ -2359,13 +1987,11 @@
 "션들에 대한 유용한 시작점일 수 있는 미리 빌드된 방도이다."
 
 #. Tag: title
-#: configuration.xml:1335
 #, no-c-format
 msgid "XML configuration file"
 msgstr "XML 구성 파일"
 
 #. Tag: para
-#: configuration.xml:1337
 #, no-c-format
 msgid ""
 "An alternative approach to configuration is to specify a full configuration "
@@ -2379,7 +2005,6 @@
 "로퍼티들을 중복정의하는데 사용될 수 있다."
 
 #. Tag: para
-#: configuration.xml:1344
 #, fuzzy, no-c-format
 msgid ""
 "The XML configuration file is by default expected to be in the root of your "
@@ -2388,52 +2013,7 @@
 "XML 구성 파일은 디폴트로 당신의 <literal>CLASSPATH</literal>의 루트에 존재하"
 "는 것이 기대된다. 다음은 예제이다:"
 
-#. Tag: programlisting
-#: configuration.xml:1349
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-"<!DOCTYPE hibernate-configuration PUBLIC\n"
-"    \"-//Hibernate/Hibernate Configuration DTD//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd\">\n"
-"\n"
-"<hibernate-configuration>\n"
-"\n"
-"    <!-- a SessionFactory instance listed as /jndi/name -->\n"
-"    <session-factory\n"
-"        name=\"java:hibernate/SessionFactory\">\n"
-"\n"
-"        <!-- properties -->\n"
-"        <property name=\"connection.datasource\">java:/comp/env/jdbc/MyDB</"
-"property>\n"
-"        <property name=\"dialect\">org.hibernate.dialect.MySQLDialect</"
-"property>\n"
-"        <property name=\"show_sql\">false</property>\n"
-"        <property name=\"transaction.factory_class\">\n"
-"            org.hibernate.transaction.JTATransactionFactory\n"
-"        </property>\n"
-"        <property name=\"jta.UserTransaction\">java:comp/UserTransaction</"
-"property>\n"
-"\n"
-"        <!-- mapping files -->\n"
-"        <mapping resource=\"org/hibernate/auction/Item.hbm.xml\"/>\n"
-"        <mapping resource=\"org/hibernate/auction/Bid.hbm.xml\"/>\n"
-"\n"
-"        <!-- cache settings -->\n"
-"        <class-cache class=\"org.hibernate.auction.Item\" usage=\"read-write"
-"\"/>\n"
-"        <class-cache class=\"org.hibernate.auction.Bid\" usage=\"read-only\"/"
-">\n"
-"        <collection-cache collection=\"org.hibernate.auction.Item.bids\" "
-"usage=\"read-write\"/>\n"
-"\n"
-"    </session-factory>\n"
-"\n"
-"</hibernate-configuration>]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1351
 #, fuzzy, no-c-format
 msgid ""
 "The advantage of this approach is the externalization of the mapping file "
@@ -2451,48 +2031,26 @@
 "것임을 노트하라."
 
 #. Tag: para
-#: configuration.xml:1360
 #, fuzzy, no-c-format
 msgid "With the XML configuration, starting Hibernate is then as simple as:"
 msgstr "Hibernate 구성으로, Hibernate를 시작하는 것은 다음과 같이 간단하다"
 
-#. Tag: programlisting
-#: configuration.xml:1364
-#, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration().configure()."
-"buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1366
 #, fuzzy, no-c-format
 msgid "You can select a different XML configuration file using:"
 msgstr "당신은 다음을 사용하여 다른 XML 구성 파일을 찾아낼 수 있다"
 
-#. Tag: programlisting
-#: configuration.xml:1370
-#, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration()\n"
-"    .configure(\"catdb.cfg.xml\")\n"
-"    .buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: title
-#: configuration.xml:1375
 #, no-c-format
 msgid "J2EE Application Server integration"
 msgstr "J2EE 어플리케이션 서버 통합"
 
 #. Tag: para
-#: configuration.xml:1377
 #, no-c-format
 msgid "Hibernate has the following integration points for J2EE infrastructure:"
 msgstr "Hibernate는 J2EE 인프라스트럭처에 대한 다음 통합 점들을 갖고 있다:"
 
 #. Tag: para
-#: configuration.xml:1383
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Container-managed datasources</emphasis>: Hibernate can use JDBC "
@@ -2513,7 +2071,6 @@
 "Hibernate <literal>Transaction</literal> API를 사용하고자 원할 수도 있다."
 
 #. Tag: para
-#: configuration.xml:1398
 #, no-c-format
 msgid ""
 "<emphasis>Automatic JNDI binding</emphasis>: Hibernate can bind its "
@@ -2523,7 +2080,6 @@
 "<literal>SessionFactory</literal>를 JNDI에 바인드 시킬 수 있다."
 
 #. Tag: para
-#: configuration.xml:1407
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>JTA Session binding:</emphasis> the Hibernate <literal>Session</"
@@ -2543,7 +2099,6 @@
 "UserTransaction))이다."
 
 #. Tag: para
-#: configuration.xml:1420
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>JMX deployment:</emphasis> if you have a JMX capable application "
@@ -2563,7 +2118,6 @@
 "Hibernate가 시작되기 전에 이용 가능해야 한다)."
 
 #. Tag: para
-#: configuration.xml:1431
 #, no-c-format
 msgid ""
 "Depending on your environment, you might have to set the configuration "
@@ -2576,13 +2130,11 @@
 "될 수도 있다."
 
 #. Tag: title
-#: configuration.xml:1438
 #, no-c-format
 msgid "Transaction strategy configuration"
 msgstr "트랜잭션 방도 구성"
 
 #. Tag: para
-#: configuration.xml:1440
 #, fuzzy, no-c-format
 msgid ""
 "The Hibernate <literal>Session</literal> API is independent of any "
@@ -2600,7 +2152,6 @@
 "<literal>UserTransaction</literal>을 호출하고자 원할 수 있다."
 
 #. Tag: para
-#: configuration.xml:1448
 #, no-c-format
 msgid ""
 "To keep your code portable between these two (and other) environments we "
@@ -2618,31 +2169,26 @@
 "다."
 
 #. Tag: para
-#: configuration.xml:1455
 #, fuzzy, no-c-format
 msgid "There are three standard, or built-in, choices:"
 msgstr "세 개의 표준(미리 만들어진) 선택들이 존재한다:"
 
-#. Tag: literal
-#: configuration.xml:1461
-#, no-c-format
-msgid "org.hibernate.transaction.JDBCTransactionFactory"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.transaction.JDBCTransactionFactory</literal>"
 msgstr "org.hibernate.transaction.JDBCTransactionFactory"
 
 #. Tag: para
-#: configuration.xml:1463
 #, no-c-format
 msgid "delegates to database (JDBC) transactions (default)"
 msgstr "데이터베이스 (JDBC) 트랜잭션들에게 위임시킨다(디폴트)"
 
-#. Tag: literal
-#: configuration.xml:1467
-#, no-c-format
-msgid "org.hibernate.transaction.JTATransactionFactory"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.transaction.JTATransactionFactory</literal>"
 msgstr "org.hibernate.transaction.JTATransactionFactory"
 
 #. Tag: para
-#: configuration.xml:1469
 #, fuzzy, no-c-format
 msgid ""
 "delegates to container-managed transactions if an existing transaction is "
@@ -2653,20 +2199,17 @@
 "중일 경우에 container-managed transaction에게 위임시키고, 그 밖의 경우 새로"
 "운 트랜잭션이 시작되고 bean-managed transaction이 사용된다."
 
-#. Tag: literal
-#: configuration.xml:1477
-#, no-c-format
-msgid "org.hibernate.transaction.CMTTransactionFactory"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.transaction.CMTTransactionFactory</literal>"
 msgstr "org.hibernate.transaction.CMTTransactionFactory"
 
 #. Tag: para
-#: configuration.xml:1479
 #, no-c-format
 msgid "delegates to container-managed JTA transactions"
 msgstr "container-managed JTA 트랜잭션들에게 위임시킨다"
 
 #. Tag: para
-#: configuration.xml:1484
 #, fuzzy, no-c-format
 msgid ""
 "You can also define your own transaction strategies (for a CORBA transaction "
@@ -2676,7 +2219,6 @@
 "의할 수도 있다."
 
 #. Tag: para
-#: configuration.xml:1489
 #, fuzzy, no-c-format
 msgid ""
 "Some features in Hibernate (i.e., the second level cache, Contextual "
@@ -2693,151 +2235,138 @@
 "한다. 왜냐하면 J2EE가 한 개의 메커니즘을 표준화 시키고 있지 않기 때문이다:"
 
 #. Tag: title
-#: configuration.xml:1497
 #, no-c-format
 msgid "JTA TransactionManagers"
 msgstr "JTA TransactionManagers"
 
 #. Tag: entry
-#: configuration.xml:1503
 #, no-c-format
 msgid "Transaction Factory"
 msgstr "트랜잭션 팩토리"
 
 #. Tag: entry
-#: configuration.xml:1504
 #, no-c-format
 msgid "Application Server"
 msgstr "어플리케이션 서버"
 
-#. Tag: literal
-#: configuration.xml:1509
-#, no-c-format
-msgid "org.hibernate.transaction.JBossTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JBossTransactionManagerLookup</literal>"
 msgstr "org.hibernate.transaction.JBossTransactionManagerLookup"
 
 #. Tag: entry
-#: configuration.xml:1510
 #, no-c-format
 msgid "JBoss"
 msgstr "JBoss"
 
-#. Tag: literal
-#: configuration.xml:1513
-#, no-c-format
-msgid "org.hibernate.transaction.WeblogicTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WeblogicTransactionManagerLookup</literal>"
 msgstr "org.hibernate.transaction.WeblogicTransactionManagerLookup"
 
 #. Tag: entry
-#: configuration.xml:1514
 #, no-c-format
 msgid "Weblogic"
 msgstr "Weblogic"
 
-#. Tag: literal
-#: configuration.xml:1517
-#, no-c-format
-msgid "org.hibernate.transaction.WebSphereTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WebSphereTransactionManagerLookup</"
+"literal>"
 msgstr "org.hibernate.transaction.WebSphereTransactionManagerLookup"
 
 #. Tag: entry
-#: configuration.xml:1518
 #, no-c-format
 msgid "WebSphere"
 msgstr "WebSphere"
 
-#. Tag: literal
-#: configuration.xml:1521
-#, no-c-format
-msgid "org.hibernate.transaction.WebSphereExtendedJTATransactionLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WebSphereExtendedJTATransactionLookup</"
+"literal>"
 msgstr "org.hibernate.transaction.WebSphereExtendedJTATransactionLookup"
 
 #. Tag: entry
-#: configuration.xml:1522
 #, no-c-format
 msgid "WebSphere 6"
 msgstr "WebSphere 6"
 
-#. Tag: literal
-#: configuration.xml:1525
-#, no-c-format
-msgid "org.hibernate.transaction.OrionTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.OrionTransactionManagerLookup</literal>"
 msgstr "org.hibernate.transaction.OrionTransactionManagerLookup"
 
 #. Tag: entry
-#: configuration.xml:1526
 #, no-c-format
 msgid "Orion"
 msgstr "Orion"
 
-#. Tag: literal
-#: configuration.xml:1529
-#, no-c-format
-msgid "org.hibernate.transaction.ResinTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.ResinTransactionManagerLookup</literal>"
 msgstr "org.hibernate.transaction.ResinTransactionManagerLookup"
 
 #. Tag: entry
-#: configuration.xml:1530
 #, no-c-format
 msgid "Resin"
 msgstr "Resin"
 
-#. Tag: literal
-#: configuration.xml:1533
-#, no-c-format
-msgid "org.hibernate.transaction.JOTMTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JOTMTransactionManagerLookup</literal>"
 msgstr "org.hibernate.transaction.JOTMTransactionManagerLookup"
 
 #. Tag: entry
-#: configuration.xml:1534
 #, no-c-format
 msgid "JOTM"
 msgstr "JOTM"
 
-#. Tag: literal
-#: configuration.xml:1537
-#, no-c-format
-msgid "org.hibernate.transaction.JOnASTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JOnASTransactionManagerLookup</literal>"
 msgstr "org.hibernate.transaction.JOnASTransactionManagerLookup"
 
 #. Tag: entry
-#: configuration.xml:1538
 #, no-c-format
 msgid "JOnAS"
 msgstr "JOnAS"
 
-#. Tag: literal
-#: configuration.xml:1541
-#, no-c-format
-msgid "org.hibernate.transaction.JRun4TransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JRun4TransactionManagerLookup</literal>"
 msgstr "org.hibernate.transaction.JRun4TransactionManagerLookup"
 
 #. Tag: entry
-#: configuration.xml:1542
 #, no-c-format
 msgid "JRun4"
 msgstr "JRun4"
 
-#. Tag: literal
-#: configuration.xml:1545
-#, no-c-format
-msgid "org.hibernate.transaction.BESTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.BESTransactionManagerLookup</literal>"
 msgstr "org.hibernate.transaction.BESTransactionManagerLookup"
 
 #. Tag: entry
-#: configuration.xml:1546
 #, no-c-format
 msgid "Borland ES"
 msgstr "Borland ES"
 
 #. Tag: title
-#: configuration.xml:1555
 #, no-c-format
 msgid "JNDI-bound <literal>SessionFactory</literal>"
 msgstr "JNDI-bound <literal>SessionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1557
 #, fuzzy, no-c-format
 msgid ""
 "A JNDI-bound Hibernate <literal>SessionFactory</literal> can simplify the "
@@ -2851,7 +2380,6 @@
 "단순하게 둘 다 동일한 레지스트리를 사용한다는 점을 노트하라!"
 
 #. Tag: para
-#: configuration.xml:1564
 #, fuzzy, no-c-format
 msgid ""
 "If you wish to have the <literal>SessionFactory</literal> bound to a JNDI "
@@ -2870,7 +2398,6 @@
 "다.)"
 
 #. Tag: para
-#: configuration.xml:1572
 #, no-c-format
 msgid ""
 "When binding the <literal>SessionFactory</literal> to JNDI, Hibernate will "
@@ -2885,7 +2412,6 @@
 "될 것이다."
 
 #. Tag: para
-#: configuration.xml:1579
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate will automatically place the <literal>SessionFactory</literal> in "
@@ -2902,7 +2428,6 @@
 "떤 시작 코드 (또는 유틸리티 클래스) 내에서 이것을 호출할 것임을 의미한다."
 
 #. Tag: para
-#: configuration.xml:1586
 #, fuzzy, no-c-format
 msgid ""
 "If you use a JNDI <literal>SessionFactory</literal>, an EJB or any other "
@@ -2914,7 +2439,6 @@
 "literal>를 얻을 수 있다."
 
 #. Tag: para
-#: configuration.xml:1591
 #, fuzzy, no-c-format
 msgid ""
 "It is recommended that you bind the <literal>SessionFactory</literal> to "
@@ -2934,23 +2458,21 @@
 "임을 노트하라&mdash; 1장을 보라."
 
 #. Tag: title
-#: configuration.xml:1603
 #, no-c-format
 msgid "Current Session context management with JTA"
 msgstr "Current Session context management with JTA"
 
 #. Tag: para
-#: configuration.xml:1605
 #, fuzzy, no-c-format
 msgid ""
 "The easiest way to handle <literal>Sessions</literal> and transactions is "
 "Hibernate's automatic \"current\" <literal>Session</literal> management. For "
-"a discussion of contextual sessions see <link linkend=\"architecture-current-"
-"session\"></link>. Using the <literal>\"jta\"</literal> session context, if "
-"there is no Hibernate <literal>Session</literal> associated with the current "
-"JTA transaction, one will be started and associated with that JTA "
-"transaction the first time you call <literal>sessionFactory.getCurrentSession"
-"()</literal>. The <literal>Session</literal>s retrieved via "
+"a discussion of contextual sessions see <xref linkend=\"architecture-current-"
+"session\" />. Using the <literal>\"jta\"</literal> session context, if there "
+"is no Hibernate <literal>Session</literal> associated with the current JTA "
+"transaction, one will be started and associated with that JTA transaction "
+"the first time you call <literal>sessionFactory.getCurrentSession()</"
+"literal>. The <literal>Session</literal>s retrieved via "
 "<literal>getCurrentSession()</literal> in the<literal>\"jta\"</literal> "
 "context are set to automatically flush before the transaction completes, "
 "close after the transaction completes, and aggressively release JDBC "
@@ -3001,13 +2523,11 @@
 "의 경우에 선언적인 트랜잭션 경계설정이 선호된다."
 
 #. Tag: title
-#: configuration.xml:1628
 #, no-c-format
 msgid "JMX deployment"
 msgstr "JMX 배치"
 
 #. Tag: para
-#: configuration.xml:1630
 #, fuzzy, no-c-format
 msgid ""
 "The line <literal>cfg.buildSessionFactory()</literal> still has to be "
@@ -3023,7 +2543,6 @@
 "<emphasis>managed service</emphasis>로서 배치할 수 있다."
 
 #. Tag: para
-#: configuration.xml:1638
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate is distributed with <literal>org.hibernate.jmx.HibernateService</"
@@ -3036,59 +2555,7 @@
 "다. 실제 배치와 구성은 벤더 지정적이다. 다음은 JBoss 4.0.x를 위한 "
 "<literal>jboss-service.xml</literal> 예제이다:"
 
-#. Tag: programlisting
-#: configuration.xml:1645
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<server>\n"
-"\n"
-"<mbean code=\"org.hibernate.jmx.HibernateService\"\n"
-"    name=\"jboss.jca:service=HibernateFactory,name=HibernateFactory\">\n"
-"\n"
-"    <!-- Required services -->\n"
-"    <depends>jboss.jca:service=RARDeployer</depends>\n"
-"    <depends>jboss.jca:service=LocalTxCM,name=HsqlDS</depends>\n"
-"\n"
-"    <!-- Bind the Hibernate service to JNDI -->\n"
-"    <attribute name=\"JndiName\">java:/hibernate/SessionFactory</attribute>\n"
-"\n"
-"    <!-- Datasource settings -->\n"
-"    <attribute name=\"Datasource\">java:HsqlDS</attribute>\n"
-"    <attribute name=\"Dialect\">org.hibernate.dialect.HSQLDialect</"
-"attribute>\n"
-"\n"
-"    <!-- Transaction integration -->\n"
-"    <attribute name=\"TransactionStrategy\">\n"
-"        org.hibernate.transaction.JTATransactionFactory</attribute>\n"
-"    <attribute name=\"TransactionManagerLookupStrategy\">\n"
-"        org.hibernate.transaction.JBossTransactionManagerLookup</attribute>\n"
-"    <attribute name=\"FlushBeforeCompletionEnabled\">true</attribute>\n"
-"    <attribute name=\"AutoCloseSessionEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Fetching options -->\n"
-"    <attribute name=\"MaximumFetchDepth\">5</attribute>\n"
-"\n"
-"    <!-- Second-level caching -->\n"
-"    <attribute name=\"SecondLevelCacheEnabled\">true</attribute>\n"
-"    <attribute name=\"CacheProviderClass\">org.hibernate.cache."
-"EhCacheProvider</attribute>\n"
-"    <attribute name=\"QueryCacheEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Logging -->\n"
-"    <attribute name=\"ShowSqlEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Mapping files -->\n"
-"    <attribute name=\"MapResources\">auction/Item.hbm.xml,auction/Category."
-"hbm.xml</attribute>\n"
-"\n"
-"</mbean>\n"
-"\n"
-"</server>]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1647
 #, fuzzy, no-c-format
 msgid ""
 "This file is deployed in a directory called <literal>META-INF</literal> and "
@@ -3110,6 +2577,21 @@
 "위해 메인 서비스 아카이브 속에 이 EJB JAR 파일을 포함시킬 수도 있다. JMX 서비"
 "스와 EJB 배치에 관한 추가 정보는 JBoss AS 문서를 참조하라."
 
+#~ msgid "JDBC URL"
+#~ msgstr "jdbc URL"
+
+#~ msgid "database user"
+#~ msgstr "데이터베이스 사용자"
+
+#~ msgid "hibernate.query.substitutions true=1, false=0"
+#~ msgstr "hibernate.query.substitutions true=1, false=0"
+
+#~ msgid "hibernate.query.substitutions toLowercase=LOWER"
+#~ msgstr "hibernate.query.substitutions toLowercase=LOWER"
+
+#~ msgid "org.hibernate"
+#~ msgstr "org.hibernate"
+
 #~ msgid ""
 #~ "<literal>hibernate.properties</literal> is the easiest approach if you "
 #~ "want to get started quickly."
@@ -3306,6 +2788,3 @@
 
 #~ msgid "hibernate.cfg.xml"
 #~ msgstr "hibernate.cfg.xml"
-
-#~ msgid "DB2"
-#~ msgstr "DB2"

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/events.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/events.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/events.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,13 +11,11 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: events.xml:29
 #, no-c-format
 msgid "Interceptors and events"
 msgstr "인터셉터들과 이벤트들"
 
 #. Tag: para
-#: events.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "It is useful for the application to react to certain events that occur "
@@ -29,13 +27,11 @@
 "기능의 구현을 허용해준다."
 
 #. Tag: title
-#: events.xml:38
 #, no-c-format
 msgid "Interceptors"
 msgstr "인터셉터들"
 
 #. Tag: para
-#: events.xml:40
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>Interceptor</literal> interface provides callbacks from the "
@@ -58,7 +54,6 @@
 "literal> 프로퍼티를 업데이트 한다."
 
 #. Tag: para
-#: events.xml:51
 #, fuzzy, no-c-format
 msgid ""
 "You can either implement <literal>Interceptor</literal> directly or extend "
@@ -67,97 +62,7 @@
 "당신은 <literal>Interceptor</literal>를 직접 구현해야 하거나 (더 좋게는) "
 "<literal>EmptyInterceptor</literal>를 확장(extend)해야 한다."
 
-#. Tag: programlisting
-#: events.xml:56
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.test;\n"
-"\n"
-"import java.io.Serializable;\n"
-"import java.util.Date;\n"
-"import java.util.Iterator;\n"
-"\n"
-"import org.hibernate.EmptyInterceptor;\n"
-"import org.hibernate.Transaction;\n"
-"import org.hibernate.type.Type;\n"
-"\n"
-"public class AuditInterceptor extends EmptyInterceptor {\n"
-"\n"
-"    private int updates;\n"
-"    private int creates;\n"
-"    private int loads;\n"
-"\n"
-"    public void onDelete(Object entity,\n"
-"                         Serializable id,\n"
-"                         Object[] state,\n"
-"                         String[] propertyNames,\n"
-"                         Type[] types) {\n"
-"        // do nothing\n"
-"    }\n"
-"\n"
-"    public boolean onFlushDirty(Object entity,\n"
-"                                Serializable id,\n"
-"                                Object[] currentState,\n"
-"                                Object[] previousState,\n"
-"                                String[] propertyNames,\n"
-"                                Type[] types) {\n"
-"\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            updates++;\n"
-"            for ( int i=0; i < propertyNames.length; i++ ) {\n"
-"                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) {\n"
-"                    currentState[i] = new Date();\n"
-"                    return true;\n"
-"                }\n"
-"            }\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public boolean onLoad(Object entity,\n"
-"                          Serializable id,\n"
-"                          Object[] state,\n"
-"                          String[] propertyNames,\n"
-"                          Type[] types) {\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            loads++;\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public boolean onSave(Object entity,\n"
-"                          Serializable id,\n"
-"                          Object[] state,\n"
-"                          String[] propertyNames,\n"
-"                          Type[] types) {\n"
-"\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            creates++;\n"
-"            for ( int i=0; i<propertyNames.length; i++ ) {\n"
-"                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
-"                    state[i] = new Date();\n"
-"                    return true;\n"
-"                }\n"
-"            }\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public void afterTransactionCompletion(Transaction tx) {\n"
-"        if ( tx.wasCommitted() ) {\n"
-"            System.out.println(\"Creations: \" + creates + \", Updates: \" + "
-"updates, \"Loads: \" + loads);\n"
-"        }\n"
-"        updates=0;\n"
-"        creates=0;\n"
-"        loads=0;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:58
 #, fuzzy, no-c-format
 msgid ""
 "There are two kinds of inteceptors: <literal>Session</literal>-scoped and "
@@ -167,7 +72,6 @@
 "화 그리고 <literal>SessionFactory</literal>-영역화."
 
 #. Tag: para
-#: events.xml:63
 #, no-c-format
 msgid ""
 "A <literal>Session</literal>-scoped interceptor is specified when a session "
@@ -178,14 +82,7 @@
 "<literal>Interceptor</literal>를 수용하는 오버로드된 SessionFactory."
 "openSession() 메소드들 중 하나를 사용하여 열릴 때 지정된다."
 
-#. Tag: programlisting
-#: events.xml:69
-#, no-c-format
-msgid "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:71
 #, fuzzy, no-c-format
 msgid ""
 "A <literal>SessionFactory</literal>-scoped interceptor is registered with "
@@ -206,21 +103,12 @@
 "야 한다. 왜냐하면 다중 세션들은 (잠정적으로) 이 인터셉터를 동시적으로 사용할 "
 "것이기 때문이다."
 
-#. Tag: programlisting
-#: events.xml:80
-#, no-c-format
-msgid ""
-"<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
-msgstr ""
-
 #. Tag: title
-#: events.xml:85
 #, no-c-format
 msgid "Event system"
 msgstr "이벤트 시스템"
 
 #. Tag: para
-#: events.xml:87
 #, fuzzy, no-c-format
 msgid ""
 "If you have to react to particular events in your persistence layer, you can "
@@ -233,7 +121,6 @@
 "있다."
 
 #. Tag: para
-#: events.xml:93
 #, fuzzy, no-c-format
 msgid ""
 "All the methods of the <literal>Session</literal> interface correlate to an "
@@ -266,7 +153,6 @@
 "이 있을 것이다."
 
 #. Tag: para
-#: events.xml:108
 #, fuzzy, no-c-format
 msgid ""
 "The listeners should be considered singletons. This means they are shared "
@@ -277,7 +163,6 @@
 "장하지 말아야 함을 의미한다."
 
 #. Tag: para
-#: events.xml:113
 #, fuzzy, no-c-format
 msgid ""
 "A custom listener implements the appropriate interface for the event it "
@@ -297,25 +182,7 @@
 "에 지정될 수 있다 (properties 파일을 통한 선언적인 구성은 지원되지 않는다). "
 "다음은 맞춤형 load 이벤트 리스너에 대한 예제이다:"
 
-#. Tag: programlisting
-#: events.xml:123
-#, no-c-format
-msgid ""
-"<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
-"    // this is the single method defined by the LoadEventListener interface\n"
-"    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
-"loadType)\n"
-"            throws HibernateException {\n"
-"        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
-"getEntityId() ) ) {\n"
-"            throw MySecurityException(\"Unauthorized access\");\n"
-"        }\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:125
 #, no-c-format
 msgid ""
 "You also need a configuration entry telling Hibernate to use the listener in "
@@ -324,40 +191,12 @@
 "당신은 또한 디폴트 리스너에 덧붙여 그 리스너를 사용하도록 Hibernate에게 알려"
 "주는 구성 엔트리를 필요로 한다:"
 
-#. Tag: programlisting
-#: events.xml:130
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-configuration>\n"
-"    <session-factory>\n"
-"        ...\n"
-"        <event type=\"load\">\n"
-"            <listener class=\"com.eg.MyLoadListener\"/>\n"
-"            <listener class=\"org.hibernate.event.def."
-"DefaultLoadEventListener\"/>\n"
-"        </event>\n"
-"    </session-factory>\n"
-"</hibernate-configuration>]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:132
 #, fuzzy, no-c-format
 msgid "Instead, you can register it programmatically:"
 msgstr "대신에 당신은 그것을 프로그래밍 방식으로 등록할 수도 있다:"
 
-#. Tag: programlisting
-#: events.xml:136
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = new Configuration();\n"
-"LoadEventListener[] stack = { new MyLoadListener(), new "
-"DefaultLoadEventListener() };\n"
-"cfg.EventListeners().setLoadEventListeners(stack);]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:138
 #, fuzzy, no-c-format
 msgid ""
 "Listeners registered declaratively cannot share instances. If the same class "
@@ -373,7 +212,6 @@
 "당신은 프로그래밍 방식의 등록 접근법을 사용해야 한다."
 
 #. Tag: para
-#: events.xml:146
 #, fuzzy, no-c-format
 msgid ""
 "Why implement an interface and define the specific type during "
@@ -388,13 +226,11 @@
 "전환시키는 것을 더 쉽게 해준다."
 
 #. Tag: title
-#: events.xml:156
 #, no-c-format
 msgid "Hibernate declarative security"
 msgstr "Hibernate 선언적인 보안"
 
 #. Tag: para
-#: events.xml:157
 #, fuzzy, no-c-format
 msgid ""
 "Usually, declarative security in Hibernate applications is managed in a "
@@ -408,7 +244,6 @@
 "션 기능이다."
 
 #. Tag: para
-#: events.xml:163
 #, no-c-format
 msgid ""
 "First, you must configure the appropriate event listeners, to enable the use "
@@ -417,22 +252,7 @@
 "먼저, 당신은 JAAS authorization 사용을 이용 가능하도록 하기 위해 적절한 이벤"
 "트 리스터들을 구성해야 한다."
 
-#. Tag: programlisting
-#: events.xml:168
-#, no-c-format
-msgid ""
-"<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
-"JACCPreDeleteEventListener\"/>\n"
-"<listener type=\"pre-update\" class=\"org.hibernate.secure."
-"JACCPreUpdateEventListener\"/>\n"
-"<listener type=\"pre-insert\" class=\"org.hibernate.secure."
-"JACCPreInsertEventListener\"/>\n"
-"<listener type=\"pre-load\" class=\"org.hibernate.secure."
-"JACCPreLoadEventListener\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:170
 #, fuzzy, no-c-format
 msgid ""
 "Note that <literal>&lt;listener type=\"...\" class=\"...\"/&gt;</literal> is "
@@ -446,7 +266,6 @@
 "축형임을 노트하라."
 
 #. Tag: para
-#: events.xml:176
 #, fuzzy, no-c-format
 msgid ""
 "Next, while still in <literal>hibernate.cfg.xml</literal>, bind the "
@@ -455,17 +274,7 @@
 "다음으로, 여전히 <literal>hibernate.cfg.xml</literal> 내에서 퍼미션들을 role"
 "들에 바인드 시킨다 :"
 
-#. Tag: programlisting
-#: events.xml:180
-#, no-c-format
-msgid ""
-"<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,update,"
-"read\"/>\n"
-"<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:182
 #, no-c-format
 msgid "The role names are the roles understood by your JACC provider."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/example_mappings.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/example_mappings.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/example_mappings.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,25 +11,21 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: example_mappings.xml:29
 #, no-c-format
 msgid "Example: Various Mappings"
 msgstr "예제: 여러 가지 매핑들"
 
 #. Tag: para
-#: example_mappings.xml:32
 #, fuzzy, no-c-format
 msgid "This chapters explores some more complex association mappings."
 msgstr "이 장은 몇몇 보다 복잡한 연관 매핑들을 보여준다."
 
 #. Tag: title
-#: example_mappings.xml:37
 #, no-c-format
 msgid "Employer/Employee"
 msgstr "Employer/Employee"
 
 #. Tag: para
-#: example_mappings.xml:39
 #, fuzzy, no-c-format
 msgid ""
 "The following model of the relationship between <literal>Employer</literal> "
@@ -45,124 +41,23 @@
 "화 시키는데 사용된다."
 
 #. Tag: para
-#: example_mappings.xml:56
 #, fuzzy, no-c-format
 msgid "Here is a possible mapping document:"
 msgstr "다음은 가능한 매핑 문서이다:"
 
-#. Tag: programlisting
-#: example_mappings.xml:60
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"        \n"
-"    <class name=\"Employer\" table=\"employers\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employer_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Employment\" table=\"employment_periods\">\n"
-"\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employment_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"startDate\" column=\"start_date\"/>\n"
-"        <property name=\"endDate\" column=\"end_date\"/>\n"
-"\n"
-"        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
-"            <property name=\"amount\">\n"
-"                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/>\n"
-"            </property>\n"
-"            <property name=\"currency\" length=\"12\"/>\n"
-"        </component>\n"
-"\n"
-"        <many-to-one name=\"employer\" column=\"employer_id\" not-null=\"true"
-"\"/>\n"
-"        <many-to-one name=\"employee\" column=\"employee_id\" not-null=\"true"
-"\"/>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Employee\" table=\"employees\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employee_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"taxfileNumber\"/>\n"
-"        <component name=\"name\" class=\"Name\">\n"
-"            <property name=\"firstName\"/>\n"
-"            <property name=\"initial\"/>\n"
-"            <property name=\"lastName\"/>\n"
-"        </component>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_mappings.xml:62
 #, fuzzy, no-c-format
 msgid "Here is the table schema generated by <literal>SchemaExport</literal>."
 msgstr ""
 "그리고 다음은 <literal>SchemaExport</literal>에 의해 생성된 테이블 스키마이"
 "다."
 
-#. Tag: programlisting
-#: example_mappings.xml:66
-#, no-c-format
-msgid ""
-"<![CDATA[create table employers (\n"
-"    id BIGINT not null, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table employment_periods (\n"
-"    id BIGINT not null,\n"
-"    hourly_rate NUMERIC(12, 2),\n"
-"    currency VARCHAR(12), \n"
-"    employee_id BIGINT not null, \n"
-"    employer_id BIGINT not null, \n"
-"    end_date TIMESTAMP, \n"
-"    start_date TIMESTAMP, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table employees (\n"
-"    id BIGINT not null, \n"
-"    firstName VARCHAR(255), \n"
-"    initial CHAR(1), \n"
-"    lastName VARCHAR(255), \n"
-"    taxfileNumber VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table employment_periods \n"
-"    add constraint employment_periodsFK0 foreign key (employer_id) "
-"references employers\n"
-"alter table employment_periods \n"
-"    add constraint employment_periodsFK1 foreign key (employee_id) "
-"references employees\n"
-"create sequence employee_id_seq\n"
-"create sequence employment_id_seq\n"
-"create sequence employer_id_seq]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:71
 #, no-c-format
 msgid "Author/Work"
 msgstr "Author/Work"
 
 #. Tag: para
-#: example_mappings.xml:73
 #, fuzzy, no-c-format
 msgid ""
 "Consider the following model of the relationships between <literal>Work</"
@@ -182,71 +77,12 @@
 "것이다."
 
 #. Tag: para
-#: example_mappings.xml:91
 #, no-c-format
 msgid ""
 "The following mapping document correctly represents these relationships:"
 msgstr "다음 매핑 문서는 이들 관계들을 정확하게 표현한다:"
 
-#. Tag: programlisting
-#: example_mappings.xml:95
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
-"\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <discriminator column=\"type\" type=\"character\"/>\n"
-"\n"
-"        <property name=\"title\"/>\n"
-"        <set name=\"authors\" table=\"author_work\">\n"
-"            <key column name=\"work_id\"/>\n"
-"            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
-"        </set>\n"
-"\n"
-"        <subclass name=\"Book\" discriminator-value=\"B\">\n"
-"            <property name=\"text\"/>\n"
-"        </subclass>\n"
-"\n"
-"        <subclass name=\"Song\" discriminator-value=\"S\">\n"
-"            <property name=\"tempo\"/>\n"
-"            <property name=\"genre\"/>\n"
-"        </subclass>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Author\" table=\"authors\">\n"
-"\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <!-- The Author must have the same identifier as the Person -->\n"
-"            <generator class=\"assigned\"/> \n"
-"        </id>\n"
-"\n"
-"        <property name=\"alias\"/>\n"
-"        <one-to-one name=\"person\" constrained=\"true\"/>\n"
-"\n"
-"        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
-"            <key column=\"author_id\"/>\n"
-"            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
-"        </set>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Person\" table=\"persons\">\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_mappings.xml:97
 #, fuzzy, no-c-format
 msgid ""
 "There are four tables in this mapping: <literal>works</literal>, "
@@ -261,55 +97,12 @@
 "을 작업들에 연결시키는 연관 테이블이다. 다음은 <literal>SchemaExport</"
 "literal>에 의해 생성된 테이블 스키마이다."
 
-#. Tag: programlisting
-#: example_mappings.xml:105
-#, no-c-format
-msgid ""
-"<![CDATA[create table works (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    tempo FLOAT, \n"
-"    genre VARCHAR(255), \n"
-"    text INTEGER, \n"
-"    title VARCHAR(255), \n"
-"    type CHAR(1) not null, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table author_work (\n"
-"    author_id BIGINT not null, \n"
-"    work_id BIGINT not null, \n"
-"    primary key (work_id, author_id)\n"
-")\n"
-"\n"
-"create table authors (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    alias VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table persons (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table authors \n"
-"    add constraint authorsFK0 foreign key (id) references persons\n"
-"alter table author_work \n"
-"    add constraint author_workFK0 foreign key (author_id) references "
-"authors\n"
-"alter table author_work\n"
-"    add constraint author_workFK1 foreign key (work_id) references works]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:110
 #, no-c-format
 msgid "Customer/Order/Product"
 msgstr "Customer/Order/Product"
 
 #. Tag: para
-#: example_mappings.xml:112
 #, fuzzy, no-c-format
 msgid ""
 "In this section we consider a model of the relationships between "
@@ -333,56 +126,11 @@
 "다."
 
 #. Tag: para
-#: example_mappings.xml:132
 #, fuzzy, no-c-format
 msgid "The mapping document will look like this:"
 msgstr "매핑 문서:"
 
-#. Tag: programlisting
-#: example_mappings.xml:136
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Customer\" table=\"customers\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"        <set name=\"orders\" inverse=\"true\">\n"
-"            <key column=\"customer_id\"/>\n"
-"            <one-to-many class=\"Order\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Order\" table=\"orders\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"date\"/>\n"
-"        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
-"        <list name=\"lineItems\" table=\"line_items\">\n"
-"            <key column=\"order_id\"/>\n"
-"            <list-index column=\"line_number\"/>\n"
-"            <composite-element class=\"LineItem\">\n"
-"                <property name=\"quantity\"/>\n"
-"                <many-to-one name=\"product\" column=\"product_id\"/>\n"
-"            </composite-element>\n"
-"        </list>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Product\" table=\"products\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"serialNumber\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_mappings.xml:138
 #, no-c-format
 msgid ""
 "<literal>customers</literal>, <literal>orders</literal>, "
@@ -396,54 +144,12 @@
 "<literal>line_items</literal>는 또한 주문들을 제품들과 연결시키는 연관 테이블"
 "로서 동작한다."
 
-#. Tag: programlisting
-#: example_mappings.xml:145
-#, no-c-format
-msgid ""
-"<![CDATA[create table customers (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table orders (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    customer_id BIGINT, \n"
-"    date TIMESTAMP, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table line_items (\n"
-"    line_number INTEGER not null, \n"
-"    order_id BIGINT not null, \n"
-"    product_id BIGINT, \n"
-"    quantity INTEGER, \n"
-"    primary key (order_id, line_number)\n"
-")\n"
-"\n"
-"create table products (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    serialNumber VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table orders \n"
-"    add constraint ordersFK0 foreign key (customer_id) references customers\n"
-"alter table line_items\n"
-"    add constraint line_itemsFK0 foreign key (product_id) references "
-"products\n"
-"alter table line_items\n"
-"    add constraint line_itemsFK1 foreign key (order_id) references orders]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:150
 #, no-c-format
 msgid "Miscellaneous example mappings"
 msgstr "기타 예제 매핑들"
 
 #. Tag: para
-#: example_mappings.xml:152
 #, fuzzy, no-c-format
 msgid ""
 "These examples are available from the Hibernate test suite. You will find "
@@ -455,337 +161,29 @@
 "literal> 폴더를 살펴보라."
 
 #. Tag: title
-#: example_mappings.xml:161
 #, no-c-format
 msgid "\"Typed\" one-to-one association"
 msgstr "\"형식화된(Typed)\" one-to-one 연관"
 
-#. Tag: programlisting
-#: example_mappings.xml:162
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"name\"/>\n"
-"    <one-to-one name=\"address\" \n"
-"            cascade=\"all\">\n"
-"        <formula>name</formula>\n"
-"        <formula>'HOME'</formula>\n"
-"    </one-to-one>\n"
-"    <one-to-one name=\"mailingAddress\" \n"
-"            cascade=\"all\">\n"
-"        <formula>name</formula>\n"
-"        <formula>'MAILING'</formula>\n"
-"    </one-to-one>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\" batch-size=\"2\" \n"
-"        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
-"    <composite-id>\n"
-"        <key-many-to-one name=\"person\" \n"
-"                column=\"personName\"/>\n"
-"        <key-property name=\"type\" \n"
-"                column=\"addressType\"/>\n"
-"    </composite-id>\n"
-"    <property name=\"street\" type=\"text\"/>\n"
-"    <property name=\"state\"/>\n"
-"    <property name=\"zip\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:166
 #, no-c-format
 msgid "Composite key example"
 msgstr "Composite 키 예제"
 
-#. Tag: programlisting
-#: example_mappings.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Customer\">\n"
-"\n"
-"    <id name=\"customerId\"\n"
-"        length=\"10\">\n"
-"        <generator class=\"assigned\"/>\n"
-"    </id>\n"
-"\n"
-"    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
-"    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
-"\n"
-"    <list name=\"orders\"\n"
-"            inverse=\"true\"\n"
-"            cascade=\"save-update\">\n"
-"        <key column=\"customerId\"/>\n"
-"        <index column=\"orderNumber\"/>\n"
-"        <one-to-many class=\"Order\"/>\n"
-"    </list>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
-"    <synchronize table=\"LineItem\"/>\n"
-"    <synchronize table=\"Product\"/>\n"
-"    \n"
-"    <composite-id name=\"id\" \n"
-"            class=\"Order$Id\">\n"
-"        <key-property name=\"customerId\" length=\"10\"/>\n"
-"        <key-property name=\"orderNumber\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"orderDate\" \n"
-"            type=\"calendar_date\"\n"
-"            not-null=\"true\"/>\n"
-"    \n"
-"    <property name=\"total\">\n"
-"        <formula>\n"
-"            ( select sum(li.quantity*p.price) \n"
-"            from LineItem li, Product p \n"
-"            where li.productId = p.productId \n"
-"                and li.customerId = customerId \n"
-"                and li.orderNumber = orderNumber )\n"
-"        </formula>\n"
-"    </property>\n"
-"    \n"
-"    <many-to-one name=\"customer\"\n"
-"            column=\"customerId\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\"/>\n"
-"        \n"
-"    <bag name=\"lineItems\"\n"
-"            fetch=\"join\" \n"
-"            inverse=\"true\"\n"
-"            cascade=\"save-update\">\n"
-"        <key>\n"
-"            <column name=\"customerId\"/>\n"
-"            <column name=\"orderNumber\"/>\n"
-"        </key>\n"
-"        <one-to-many class=\"LineItem\"/>\n"
-"    </bag>\n"
-"    \n"
-"</class>\n"
-"    \n"
-"<class name=\"LineItem\">\n"
-"    \n"
-"    <composite-id name=\"id\" \n"
-"            class=\"LineItem$Id\">\n"
-"        <key-property name=\"customerId\" length=\"10\"/>\n"
-"        <key-property name=\"orderNumber\"/>\n"
-"        <key-property name=\"productId\" length=\"10\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"quantity\"/>\n"
-"    \n"
-"    <many-to-one name=\"order\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\">\n"
-"        <column name=\"customerId\"/>\n"
-"        <column name=\"orderNumber\"/>\n"
-"    </many-to-one>\n"
-"    \n"
-"    <many-to-one name=\"product\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\"\n"
-"            column=\"productId\"/>\n"
-"        \n"
-"</class>\n"
-"\n"
-"<class name=\"Product\">\n"
-"    <synchronize table=\"LineItem\"/>\n"
-"\n"
-"    <id name=\"productId\"\n"
-"        length=\"10\">\n"
-"        <generator class=\"assigned\"/>\n"
-"    </id>\n"
-"    \n"
-"    <property name=\"description\" \n"
-"        not-null=\"true\" \n"
-"        length=\"200\"/>\n"
-"    <property name=\"price\" length=\"3\"/>\n"
-"    <property name=\"numberAvailable\"/>\n"
-"    \n"
-"    <property name=\"numberOrdered\">\n"
-"        <formula>\n"
-"            ( select sum(li.quantity) \n"
-"            from LineItem li \n"
-"            where li.productId = productId )\n"
-"        </formula>\n"
-"    </property>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:171
 #, no-c-format
 msgid "Many-to-many with shared composite key attribute"
 msgstr "공유된 합성 키 속성을 가진 Many-to-many"
 
-#. Tag: programlisting
-#: example_mappings.xml:172
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"User\" table=\"`User`\">\n"
-"    <composite-id>\n"
-"        <key-property name=\"name\"/>\n"
-"        <key-property name=\"org\"/>\n"
-"    </composite-id>\n"
-"    <set name=\"groups\" table=\"UserGroup\">\n"
-"        <key>\n"
-"            <column name=\"userName\"/>\n"
-"            <column name=\"org\"/>\n"
-"        </key>\n"
-"        <many-to-many class=\"Group\">\n"
-"            <column name=\"groupName\"/>\n"
-"            <formula>org</formula>\n"
-"        </many-to-many>\n"
-"    </set>\n"
-"</class>\n"
-"    \n"
-"<class name=\"Group\" table=\"`Group`\">\n"
-"    <composite-id>\n"
-"        <key-property name=\"name\"/>\n"
-"        <key-property name=\"org\"/>\n"
-"    </composite-id>\n"
-"    <property name=\"description\"/>\n"
-"    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
-"        <key>\n"
-"            <column name=\"groupName\"/>\n"
-"            <column name=\"org\"/>\n"
-"        </key>\n"
-"        <many-to-many class=\"User\">\n"
-"            <column name=\"userName\"/>\n"
-"            <formula>org</formula>\n"
-"        </many-to-many>\n"
-"    </set>\n"
-"</class>\n"
-"]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:176
 #, no-c-format
 msgid "Content based discrimination"
 msgstr "내용 기반 판별"
 
-#. Tag: programlisting
-#: example_mappings.xml:177
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\"\n"
-"    discriminator-value=\"P\">\n"
-"    \n"
-"    <id name=\"id\" \n"
-"        column=\"person_id\" \n"
-"        unsaved-value=\"0\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    \n"
-"            \n"
-"    <discriminator \n"
-"        type=\"character\">\n"
-"        <formula>\n"
-"            case \n"
-"                when title is not null then 'E' \n"
-"                when salesperson is not null then 'C' \n"
-"                else 'P' \n"
-"            end\n"
-"        </formula>\n"
-"    </discriminator>\n"
-"\n"
-"    <property name=\"name\" \n"
-"        not-null=\"true\"\n"
-"        length=\"80\"/>\n"
-"        \n"
-"    <property name=\"sex\" \n"
-"        not-null=\"true\"\n"
-"        update=\"false\"/>\n"
-"    \n"
-"    <component name=\"address\">\n"
-"        <property name=\"address\"/>\n"
-"        <property name=\"zip\"/>\n"
-"        <property name=\"country\"/>\n"
-"    </component>\n"
-"    \n"
-"    <subclass name=\"Employee\" \n"
-"        discriminator-value=\"E\">\n"
-"            <property name=\"title\"\n"
-"                length=\"20\"/>\n"
-"            <property name=\"salary\"/>\n"
-"            <many-to-one name=\"manager\"/>\n"
-"    </subclass>\n"
-"    \n"
-"    <subclass name=\"Customer\" \n"
-"        discriminator-value=\"C\">\n"
-"            <property name=\"comments\"/>\n"
-"            <many-to-one name=\"salesperson\"/>\n"
-"    </subclass>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:181
 #, no-c-format
 msgid "Associations on alternate keys"
 msgstr "대체 키들에 대한 연관들"
 
-#. Tag: programlisting
-#: example_mappings.xml:182
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    \n"
-"    <id name=\"id\">\n"
-"        <generator class=\"hilo\"/>\n"
-"    </id>\n"
-"    \n"
-"    <property name=\"name\" length=\"100\"/>\n"
-"    \n"
-"    <one-to-one name=\"address\" \n"
-"        property-ref=\"person\"\n"
-"        cascade=\"all\"\n"
-"        fetch=\"join\"/>\n"
-"    \n"
-"    <set name=\"accounts\" \n"
-"        inverse=\"true\">\n"
-"        <key column=\"userId\"\n"
-"            property-ref=\"userId\"/>\n"
-"        <one-to-many class=\"Account\"/>\n"
-"    </set>\n"
-"    \n"
-"    <property name=\"userId\" length=\"8\"/>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"hilo\"/>\n"
-"    </id>\n"
-"\n"
-"    <property name=\"address\" length=\"300\"/>\n"
-"    <property name=\"zip\" length=\"5\"/>\n"
-"    <property name=\"country\" length=\"25\"/>\n"
-"    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Account\">\n"
-"    <id name=\"accountId\" length=\"32\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    \n"
-"    <many-to-one name=\"user\"\n"
-"        column=\"userId\"\n"
-"        property-ref=\"userId\"/>\n"
-"    \n"
-"    <property name=\"type\" not-null=\"true\"/>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #~ msgid "TODO: put words around this stuff"
 #~ msgstr "TODO: 이 내용을 둘러싼 말들을 집어넣을 것."

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/example_parentchild.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/example_parentchild.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/example_parentchild.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-08-17 20:22+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,13 +11,11 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: example_parentchild.xml:29
 #, no-c-format
 msgid "Example: Parent/Child"
 msgstr "예제: 부모/자식"
 
 #. Tag: para
-#: example_parentchild.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "One of the first things that new users want to do with Hibernate is to model "
@@ -49,13 +47,11 @@
 "다!"
 
 #. Tag: title
-#: example_parentchild.xml:45
 #, no-c-format
 msgid "A note about collections"
 msgstr "콜렉션들에 관한 노트"
 
 #. Tag: para
-#: example_parentchild.xml:47
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate collections are considered to be a logical part of their owning "
@@ -67,7 +63,6 @@
 "음은 다음 결과들을 갖는다:"
 
 #. Tag: para
-#: example_parentchild.xml:54
 #, fuzzy, no-c-format
 msgid ""
 "When you remove/add an object from/to a collection, the version number of "
@@ -77,7 +72,6 @@
 "버전 번호가 증가된다."
 
 #. Tag: para
-#: example_parentchild.xml:60
 #, fuzzy, no-c-format
 msgid ""
 "If an object that was removed from a collection is an instance of a value "
@@ -92,7 +86,6 @@
 "가시키는 것은 그것의 상태가 즉시 영속화 되도록 강제시킬 것이다."
 
 #. Tag: para
-#: example_parentchild.xml:68
 #, fuzzy, no-c-format
 msgid ""
 "Conversely, if an entity is removed from a collection (a one-to-many or many-"
@@ -108,7 +101,6 @@
 "티가 영속화 되도록 강제시키지 않는다."
 
 #. Tag: para
-#: example_parentchild.xml:78
 #, fuzzy, no-c-format
 msgid ""
 "Adding an entity to a collection, by default, merely creates a link between "
@@ -124,13 +116,11 @@
 "있다."
 
 #. Tag: title
-#: example_parentchild.xml:88
 #, no-c-format
 msgid "Bidirectional one-to-many"
 msgstr "ì–‘ë°©í–¥ one-to-many"
 
 #. Tag: para
-#: example_parentchild.xml:90
 #, no-c-format
 msgid ""
 "Suppose we start with a simple <literal>&lt;one-to-many&gt;</literal> "
@@ -139,41 +129,17 @@
 "<literal>Parent</literal>로부터 <literal>Child</literal>로의 간단한 "
 "<literal>&lt;one-to-many&gt;</literal> 연관관계로 시작한다고 가정하자."
 
-#. Tag: programlisting
-#: example_parentchild.xml:95
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:97
 #, fuzzy, no-c-format
 msgid "If we were to execute the following code:"
 msgstr "우리가 다음 코드를 실행시켰다면"
 
-#. Tag: programlisting
-#: example_parentchild.xml:101
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = .....;\n"
-"Child c = new Child();\n"
-"p.getChildren().add(c);\n"
-"session.save(c);\n"
-"session.flush();]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:103
 #, no-c-format
 msgid "Hibernate would issue two SQL statements:"
 msgstr "Hibernate는 두 개의 SQL 문장들을 실행할 것이다:"
 
 #. Tag: para
-#: example_parentchild.xml:109
 #, no-c-format
 msgid ""
 "an <literal>INSERT</literal> to create the record for <literal>c</literal>"
@@ -181,7 +147,6 @@
 "<literal>c</literal>에 대한 레코드를 생성시키는 <literal>INSERT</literal>"
 
 #. Tag: para
-#: example_parentchild.xml:112
 #, no-c-format
 msgid ""
 "an <literal>UPDATE</literal> to create the link from <literal>p</literal> to "
@@ -191,7 +156,6 @@
 "<literal>UPDATE</literal>"
 
 #. Tag: para
-#: example_parentchild.xml:119
 #, fuzzy, no-c-format
 msgid ""
 "This is not only inefficient, but also violates any <literal>NOT NULL</"
@@ -204,24 +168,12 @@
 "에서 <literal>not-null=\"true\"</literal>를 지정함으로써 null 허용 가능 컨스"
 "트레인트 위반을 정정할 수 있다:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:125
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\">\n"
-"    <key column=\"parent_id\" not-null=\"true\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:127
 #, no-c-format
 msgid "However, this is not the recommended solution."
 msgstr "하지만 이것은 권장되는 해결책이 아니다."
 
 #. Tag: para
-#: example_parentchild.xml:130
 #, fuzzy, no-c-format
 msgid ""
 "The underlying cause of this behavior is that the link (the foreign key "
@@ -236,16 +188,7 @@
 "지 않는다는 점이다. 따라서 해결책은 <literal>Child</literal> 매핑의 링크 부분"
 "을 만드는 것이다."
 
-#. Tag: programlisting
-#: example_parentchild.xml:137
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"parent\" column=\"parent_id\" not-null=\"true\"/"
-">]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:139
 #, fuzzy, no-c-format
 msgid ""
 "You also need to add the <literal>parent</literal> property to the "
@@ -255,7 +198,6 @@
 "래스에 추가시킬 필요가 있다.)"
 
 #. Tag: para
-#: example_parentchild.xml:143
 #, fuzzy, no-c-format
 msgid ""
 "Now that the <literal>Child</literal> entity is managing the state of the "
@@ -266,44 +208,19 @@
 "고, 우리는 링크를 업데이트 시키지 말도록 콜렉션에게 통보한다. 우리는 "
 "<literal>inverse</literal> 속성을 사용한다."
 
-#. Tag: programlisting
-#: example_parentchild.xml:148
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:150
 #, fuzzy, no-c-format
 msgid "The following code would be used to add a new <literal>Child</literal>:"
 msgstr ""
 "다음 코드는 새로운 <literal>Child</literal>를 추가시키는데 사용될 것이다"
 
-#. Tag: programlisting
-#: example_parentchild.xml:154
-#, no-c-format
-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 ""
-
 #. Tag: para
-#: example_parentchild.xml:156
 #, fuzzy, no-c-format
 msgid "Only one SQL <literal>INSERT</literal> would now be issued."
 msgstr ""
 "그리고 이제, 유일하게 한 개의 SQL <literal>INSERT</literal>가 실행될 것이다!"
 
 #. Tag: para
-#: example_parentchild.xml:160
 #, fuzzy, no-c-format
 msgid ""
 "You could also create an <literal>addChild()</literal> method of "
@@ -312,41 +229,17 @@
 "약간 거칠게, 우리는 <literal>Parent</literal>의 <literal>addChild()</"
 "literal> 메소드를 생성시킬 수 있다."
 
-#. Tag: programlisting
-#: example_parentchild.xml:165
-#, no-c-format
-msgid ""
-"<![CDATA[public void addChild(Child c) {\n"
-"    c.setParent(this);\n"
-"    children.add(c);\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:167
 #, fuzzy, no-c-format
 msgid "The code to add a <literal>Child</literal> looks like this:"
 msgstr "이제, <literal>Child</literal>를 추가하는 코드는 다음과 같다"
 
-#. Tag: programlisting
-#: example_parentchild.xml:171
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: example_parentchild.xml:176
 #, no-c-format
 msgid "Cascading life cycle"
 msgstr "케스케이딩 생명주기"
 
 #. Tag: para
-#: example_parentchild.xml:178
 #, fuzzy, no-c-format
 msgid ""
 "You can address the frustrations of the explicit call to <literal>save()</"
@@ -355,34 +248,12 @@
 "<literal>save()</literal>에 대한 명시적인 호출은 여전히 성가시다. 우리는 케스"
 "케이딩을 사용하여 이것을 얘기할 것이다."
 
-#. Tag: programlisting
-#: example_parentchild.xml:183
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:185
 #, fuzzy, no-c-format
 msgid "This simplifies the code above to:"
 msgstr "다음은 위의 코드를 단순화 시킨다"
 
-#. Tag: programlisting
-#: example_parentchild.xml:189
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-"Child c = new Child();\n"
-"p.addChild(c);\n"
-"session.flush();]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:191
 #, fuzzy, no-c-format
 msgid ""
 "Similarly, we do not need to iterate over the children when saving or "
@@ -393,34 +264,12 @@
 "해 반복하는 것을 필요로 하지 않는다. 다음은 데이터베이스로부터 <literal>p</"
 "literal>와 모든 그것의 자식들을 제거시킨다."
 
-#. Tag: programlisting
-#: example_parentchild.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-"session.delete(p);\n"
-"session.flush();]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:198
 #, fuzzy, no-c-format
 msgid "However, the following code:"
 msgstr "하지만, 다음 코드"
 
-#. Tag: programlisting
-#: example_parentchild.xml:202
-#, no-c-format
-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 ""
-
 #. Tag: para
-#: example_parentchild.xml:204
 #, fuzzy, no-c-format
 msgid ""
 "will not remove <literal>c</literal> from the database. In this case, it "
@@ -434,19 +283,7 @@
 "적으로 <literal>Child</literal>를 <literal>delete()</literal> 시킬 필요가 있"
 "다."
 
-#. Tag: programlisting
-#: example_parentchild.xml:210
-#, no-c-format
-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 ""
-
 #. Tag: para
-#: example_parentchild.xml:212
 #, fuzzy, no-c-format
 msgid ""
 "In our case, a <literal>Child</literal> cannot exist without its parent. So "
@@ -459,19 +296,7 @@
 "literal>를 제거할 경우, 우리는 그것이 정말로 삭제되기를 원한다. 이를 위해 우"
 "리는 <literal>cascade=\"all-delete-orphan\"</literal>을 사용해야 한다."
 
-#. Tag: programlisting
-#: example_parentchild.xml:218
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all-delete-orphan"
-"\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:220
 #, fuzzy, no-c-format
 msgid ""
 "Even though the collection mapping specifies <literal>inverse=\"true\"</"
@@ -487,13 +312,11 @@
 "</literal>를 호출하는 것으로는 충분하지 않다."
 
 #. Tag: title
-#: example_parentchild.xml:230
 #, no-c-format
 msgid "Cascades and <literal>unsaved-value</literal>"
 msgstr "케스케이드들과 <literal>unsaved-value</literal>"
 
 #. Tag: para
-#: example_parentchild.xml:232
 #, fuzzy, no-c-format
 msgid ""
 "Suppose we loaded up a <literal>Parent</literal> in one <literal>Session</"
@@ -506,7 +329,7 @@
 "literal> have generated identifier properties of type <literal>Long</"
 "literal>. Hibernate will use the identifier and version/timestamp property "
 "value to determine which of the children are new. (See <xref linkend="
-"\"objectstate-saveorupdate\"/>.) <emphasis>In Hibernate3, it is no longer "
+"\"objectstate-saveorupdate\" />.) <emphasis>In Hibernate3, it is no longer "
 "necessary to specify an <literal>unsaved-value</literal> explicitly.</"
 "emphasis>"
 msgstr ""
@@ -524,7 +347,6 @@
 "로 지정할 필요가 없다.</emphasis>"
 
 #. Tag: para
-#: example_parentchild.xml:244
 #, fuzzy, no-c-format
 msgid ""
 "The following code will update <literal>parent</literal> and <literal>child</"
@@ -533,20 +355,7 @@
 "다음 코드는 <literal>parent</literal>와 <literal>child</literal>를 업데이트하"
 "고 <literal>newChild</literal>를 삽입시킬 것이다."
 
-#. Tag: programlisting
-#: example_parentchild.xml:249
-#, no-c-format
-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 ""
-
 #. Tag: para
-#: example_parentchild.xml:251
 #, fuzzy, no-c-format
 msgid ""
 "This may be suitable for the case of a generated identifier, but what about "
@@ -566,13 +375,11 @@
 "존재하는지를 알기 위해 데이터베이스를 질의할 것이다."
 
 #. Tag: title
-#: example_parentchild.xml:263
 #, no-c-format
 msgid "Conclusion"
 msgstr "ê²°ë¡ "
 
 #. Tag: para
-#: example_parentchild.xml:265
 #, fuzzy, no-c-format
 msgid ""
 "The sections we have just covered can be a bit confusing. However, in "
@@ -584,7 +391,6 @@
 "들은 많은 장소들에서 부모/자식 패턴을 사용한다."
 
 #. Tag: para
-#: example_parentchild.xml:270
 #, fuzzy, no-c-format
 msgid ""
 "We mentioned an alternative in the first paragraph. None of the above issues "

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/example_weblog.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/example_weblog.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/example_weblog.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,19 +11,16 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: example_weblog.xml:29
 #, no-c-format
 msgid "Example: Weblog Application"
 msgstr "예제: Weblog 어플리케이션"
 
 #. Tag: title
-#: example_weblog.xml:32
 #, no-c-format
 msgid "Persistent Classes"
 msgstr "영속 클래스들"
 
 #. Tag: para
-#: example_weblog.xml:34
 #, fuzzy, no-c-format
 msgid ""
 "The persistent classes here represent a weblog and an item posted in a "
@@ -34,203 +31,22 @@
 "표준 부모/자식 관계로 모형화 될 것이지만, 우리는 set 대신에 순서지워진 bag를 "
 "사용할 것이다."
 
-#. Tag: programlisting
-#: example_weblog.xml:40
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.util.List;\n"
-"\n"
-"public class Blog {\n"
-"    private Long _id;\n"
-"    private String _name;\n"
-"    private List _items;\n"
-"\n"
-"    public Long getId() {\n"
-"        return _id;\n"
-"    }\n"
-"    public List getItems() {\n"
-"        return _items;\n"
-"    }\n"
-"    public String getName() {\n"
-"        return _name;\n"
-"    }\n"
-"    public void setId(Long long1) {\n"
-"        _id = long1;\n"
-"    }\n"
-"    public void setItems(List list) {\n"
-"        _items = list;\n"
-"    }\n"
-"    public void setName(String string) {\n"
-"        _name = string;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: example_weblog.xml:42
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.text.DateFormat;\n"
-"import java.util.Calendar;\n"
-"\n"
-"public class BlogItem {\n"
-"    private Long _id;\n"
-"    private Calendar _datetime;\n"
-"    private String _text;\n"
-"    private String _title;\n"
-"    private Blog _blog;\n"
-"\n"
-"    public Blog getBlog() {\n"
-"        return _blog;\n"
-"    }\n"
-"    public Calendar getDatetime() {\n"
-"        return _datetime;\n"
-"    }\n"
-"    public Long getId() {\n"
-"        return _id;\n"
-"    }\n"
-"    public String getText() {\n"
-"        return _text;\n"
-"    }\n"
-"    public String getTitle() {\n"
-"        return _title;\n"
-"    }\n"
-"    public void setBlog(Blog blog) {\n"
-"        _blog = blog;\n"
-"    }\n"
-"    public void setDatetime(Calendar calendar) {\n"
-"        _datetime = calendar;\n"
-"    }\n"
-"    public void setId(Long long1) {\n"
-"        _id = long1;\n"
-"    }\n"
-"    public void setText(String string) {\n"
-"        _text = string;\n"
-"    }\n"
-"    public void setTitle(String string) {\n"
-"        _title = string;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: example_weblog.xml:47
 #, no-c-format
 msgid "Hibernate Mappings"
 msgstr "Hibernate 매핑들"
 
 #. Tag: para
-#: example_weblog.xml:49
 #, fuzzy, no-c-format
 msgid "The XML mappings are now straightforward. For example:"
 msgstr "XML 매핑들은 이제 매우 간단해질 것이다."
 
-#. Tag: programlisting
-#: example_weblog.xml:53
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"    <class\n"
-"        name=\"Blog\"\n"
-"        table=\"BLOGS\">\n"
-"\n"
-"        <id\n"
-"            name=\"id\"\n"
-"            column=\"BLOG_ID\">\n"
-"\n"
-"            <generator class=\"native\"/>\n"
-"\n"
-"        </id>\n"
-"\n"
-"        <property\n"
-"            name=\"name\"\n"
-"            column=\"NAME\"\n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"\n"
-"        <bag\n"
-"            name=\"items\"\n"
-"            inverse=\"true\"\n"
-"            order-by=\"DATE_TIME\"\n"
-"            cascade=\"all\">\n"
-"\n"
-"            <key column=\"BLOG_ID\"/>\n"
-"            <one-to-many class=\"BlogItem\"/>\n"
-"\n"
-"        </bag>\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: example_weblog.xml:55
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"    <class\n"
-"        name=\"BlogItem\"\n"
-"        table=\"BLOG_ITEMS\"\n"
-"        dynamic-update=\"true\">\n"
-"\n"
-"        <id\n"
-"            name=\"id\"\n"
-"            column=\"BLOG_ITEM_ID\">\n"
-"\n"
-"            <generator class=\"native\"/>\n"
-"\n"
-"        </id>\n"
-"\n"
-"        <property\n"
-"            name=\"title\"\n"
-"            column=\"TITLE\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <property\n"
-"            name=\"text\"\n"
-"            column=\"TEXT\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <property\n"
-"            name=\"datetime\"\n"
-"            column=\"DATE_TIME\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <many-to-one\n"
-"            name=\"blog\"\n"
-"            column=\"BLOG_ID\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_weblog.xml:60
 #, no-c-format
 msgid "Hibernate Code"
 msgstr "Hibernate 코드"
 
 #. Tag: para
-#: example_weblog.xml:62
 #, fuzzy, no-c-format
 msgid ""
 "The following class demonstrates some of the kinds of things we can do with "
@@ -238,247 +54,3 @@
 msgstr ""
 "다음 클래스는 우리가 Hibernate를 사용하여 이들 클래스들로 행할 수 있는 몇몇 "
 "종류의 것들을 설명한다."
-
-#. Tag: programlisting
-#: example_weblog.xml:67
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.util.ArrayList;\n"
-"import java.util.Calendar;\n"
-"import java.util.Iterator;\n"
-"import java.util.List;\n"
-"\n"
-"import org.hibernate.HibernateException;\n"
-"import org.hibernate.Query;\n"
-"import org.hibernate.Session;\n"
-"import org.hibernate.SessionFactory;\n"
-"import org.hibernate.Transaction;\n"
-"import org.hibernate.cfg.Configuration;\n"
-"import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
-"\n"
-"public class BlogMain {\n"
-"    \n"
-"    private SessionFactory _sessions;\n"
-"    \n"
-"    public void configure() throws HibernateException {\n"
-"        _sessions = new Configuration()\n"
-"            .addClass(Blog.class)\n"
-"            .addClass(BlogItem.class)\n"
-"            .buildSessionFactory();\n"
-"    }\n"
-"    \n"
-"    public void exportTables() throws HibernateException {\n"
-"        Configuration cfg = new Configuration()\n"
-"            .addClass(Blog.class)\n"
-"            .addClass(BlogItem.class);\n"
-"        new SchemaExport(cfg).create(true, true);\n"
-"    }\n"
-"    \n"
-"    public Blog createBlog(String name) throws HibernateException {\n"
-"        \n"
-"        Blog blog = new Blog();\n"
-"        blog.setName(name);\n"
-"        blog.setItems( new ArrayList() );\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.persist(blog);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return blog;\n"
-"    }\n"
-"    \n"
-"    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
-"                        throws HibernateException {\n"
-"        \n"
-"        BlogItem item = new BlogItem();\n"
-"        item.setTitle(title);\n"
-"        item.setText(text);\n"
-"        item.setBlog(blog);\n"
-"        item.setDatetime( Calendar.getInstance() );\n"
-"        blog.getItems().add(item);\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.update(blog);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return item;\n"
-"    }\n"
-"    \n"
-"    public BlogItem createBlogItem(Long blogid, String title, String text)\n"
-"                        throws HibernateException {\n"
-"        \n"
-"        BlogItem item = new BlogItem();\n"
-"        item.setTitle(title);\n"
-"        item.setText(text);\n"
-"        item.setDatetime( Calendar.getInstance() );\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
-"            item.setBlog(blog);\n"
-"            blog.getItems().add(item);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return item;\n"
-"    }\n"
-"    \n"
-"    public void updateBlogItem(BlogItem item, String text)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        item.setText(text);\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.update(item);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"    }\n"
-"    \n"
-"    public void updateBlogItem(Long itemid, String text)\n"
-"                    throws HibernateException {\n"
-"    \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            BlogItem item = (BlogItem) session.load(BlogItem.class, "
-"itemid);\n"
-"            item.setText(text);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"    }\n"
-"    \n"
-"    public List listAllBlogNamesAndItemCounts(int max)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        List result = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"select blog.id, blog.name, count(blogItem) \" +\n"
-"                \"from Blog as blog \" +\n"
-"                \"left outer join blog.items as blogItem \" +\n"
-"                \"group by blog.name, blog.id \" +\n"
-"                \"order by max(blogItem.datetime)\"\n"
-"            );\n"
-"            q.setMaxResults(max);\n"
-"            result = q.list();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return result;\n"
-"    }\n"
-"    \n"
-"    public Blog getBlogAndAllItems(Long blogid)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        Blog blog = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"from Blog as blog \" +\n"
-"                \"left outer join fetch blog.items \" +\n"
-"                \"where blog.id = :blogid\"\n"
-"            );\n"
-"            q.setParameter(\"blogid\", blogid);\n"
-"            blog  = (Blog) q.uniqueResult();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return blog;\n"
-"    }\n"
-"    \n"
-"    public List listBlogsAndRecentItems() throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        List result = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"from Blog as blog \" +\n"
-"                \"inner join blog.items as blogItem \" +\n"
-"                \"where blogItem.datetime > :minDate\"\n"
-"            );\n"
-"\n"
-"            Calendar cal = Calendar.getInstance();\n"
-"            cal.roll(Calendar.MONTH, false);\n"
-"            q.setCalendar(\"minDate\", cal);\n"
-"            \n"
-"            result = q.list();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return result;\n"
-"    }\n"
-"}]]>"
-msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/filters.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/filters.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/filters.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,13 +11,11 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: filters.xml:29
 #, no-c-format
 msgid "Filtering data"
 msgstr "데이터 필터링하기"
 
 #. Tag: para
-#: filters.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate3 provides an innovative new approach to handling data with "
@@ -31,13 +29,11 @@
 "라미터화 된 필터이다."
 
 #. Tag: title
-#: filters.xml:38
 #, no-c-format
 msgid "Hibernate filters"
 msgstr "Hibernate 필터들"
 
 #. Tag: para
-#: filters.xml:40
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate3 has the ability to pre-define filter criteria and attach those "
@@ -59,7 +55,6 @@
 "화 된다."
 
 #. Tag: para
-#: filters.xml:50
 #, no-c-format
 msgid ""
 "In order to use filters, they must first be defined and then attached to the "
@@ -71,56 +66,22 @@
 "가되어야 한다. 필터를 정의하기 위해, <literal>&lt;hibernate-mapping/&gt;</"
 "literal> 요소 내부에 <literal>&lt;filter-def/&gt;</literal> 요소를 사용하라:"
 
-#. Tag: programlisting
-#: filters.xml:56
-#, no-c-format
-msgid ""
-"<![CDATA[<filter-def name=\"myFilter\">\n"
-"    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
-"</filter-def>]]>"
-msgstr ""
-
 #. Tag: para
-#: filters.xml:58
 #, fuzzy, no-c-format
 msgid "This filter can then be attached to a class:"
 msgstr "그때 이 필터는 클래스에 첨가될 수 있다:"
 
-#. Tag: programlisting
-#: filters.xml:62
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"myClass\" ...>\n"
-"    ...\n"
-"    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN"
-"\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: filters.xml:64
 #, fuzzy, no-c-format
 msgid "Or, to a collection:"
 msgstr "또는 콜렉션에 첨가될 수 있다:"
 
-#. Tag: programlisting
-#: filters.xml:68
-#, no-c-format
-msgid ""
-"<![CDATA[<set ...>\n"
-"    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN"
-"\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: filters.xml:70
 #, fuzzy, no-c-format
 msgid "Or, to both or multiples of each at the same time."
 msgstr "또는 동시에 양자에(또는 각각의 여러번) 첨가될 수 있다."
 
 #. Tag: para
-#: filters.xml:74
 #, fuzzy, no-c-format
 msgid ""
 "The methods on <literal>Session</literal> are: <literal>enableFilter(String "
@@ -141,16 +102,7 @@
 "<literal>Filter</literal> 인터페이스의 인스턴스를 반환한다. 위에 정의된 간단"
 "한 필터를 사용하면, 이것은 다음과 같을 것이다:"
 
-#. Tag: programlisting
-#: filters.xml:83
-#, no-c-format
-msgid ""
-"<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam\", "
-"\"some-value\");]]>"
-msgstr ""
-
 #. Tag: para
-#: filters.xml:85
 #, fuzzy, no-c-format
 msgid ""
 "Methods on the org.hibernate.Filter interface do allow the method-chaining "
@@ -160,53 +112,13 @@
 "method-chaining을 허용한다는 점을 노트하라."
 
 #. Tag: para
-#: filters.xml:89
 #, fuzzy, no-c-format
 msgid ""
 "The following is a full example, using temporal data with an effective "
 "record date pattern:"
 msgstr "유효한 기록 날짜 패턴을 가진 시간 데이터를 사용하는 전체 예제 :"
 
-#. Tag: programlisting
-#: filters.xml:93
-#, no-c-format
-msgid ""
-"<![CDATA[<filter-def name=\"effectiveDate\">\n"
-"    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
-"</filter-def>\n"
-"\n"
-"<class name=\"Employee\" ...>\n"
-"...\n"
-"    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department\"/"
-">\n"
-"    <property name=\"effectiveStartDate\" type=\"date\" column=\"eff_start_dt"
-"\"/>\n"
-"    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt\"/"
-">\n"
-"...\n"
-"    <!--\n"
-"        Note that this assumes non-terminal records have an eff_end_dt set "
-"to\n"
-"        a max db date for simplicity-sake\n"
-"    -->\n"
-"    <filter name=\"effectiveDate\"\n"
-"            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Department\" ...>\n"
-"...\n"
-"    <set name=\"employees\" lazy=\"true\">\n"
-"        <key column=\"dept_id\"/>\n"
-"        <one-to-many class=\"Employee\"/>\n"
-"        <filter name=\"effectiveDate\"\n"
-"                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
-">\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: filters.xml:95
 #, fuzzy, no-c-format
 msgid ""
 "In order to ensure that you are provided with currently effective records, "
@@ -215,22 +127,7 @@
 "그때 당신이 현재 유효한 레코드들을 항상 얻는 것을 확실히 하기 위해, employee "
 "데이터를 검색하기 전에 세션 상에 필터를 간단하게 이용 가능하게 하라:"
 
-#. Tag: programlisting
-#: filters.xml:100
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = ...;\n"
-"session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new Date"
-"());\n"
-"List results = session.createQuery(\"from Employee as e where e.salary > :"
-"targetSalary\")\n"
-"         .setLong(\"targetSalary\", new Long(1000000))\n"
-"         .list();\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: filters.xml:102
 #, fuzzy, no-c-format
 msgid ""
 "Even though a salary constraint was mentioned explicitly on the results in "
@@ -243,7 +140,6 @@
 "인 현재 채용중인 직원들만을 반환할 것이다."
 
 #. Tag: para
-#: filters.xml:108
 #, fuzzy, no-c-format
 msgid ""
 "If you want to use filters with outer joining, either through HQL or load "
@@ -257,7 +153,6 @@
 "첫번째에 파라미터를 위치지워라."
 
 #. Tag: para
-#: filters.xml:115
 #, fuzzy, no-c-format
 msgid ""
 "After being defined, a filter might be attached to multiple entities and/or "
@@ -271,17 +166,7 @@
 "다. 따라서 <literal>&lt;filter-def/&gt;</literal>은 attribute 든 CDATA 든 어"
 "느것이든 디폴트 조건을 정의하는 것을 허용해준다:"
 
-#. Tag: programlisting
-#: filters.xml:122
-#, no-c-format
-msgid ""
-"<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</filter-"
-"def>\n"
-"<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"
-msgstr ""
-
 #. Tag: para
-#: filters.xml:124
 #, fuzzy, no-c-format
 msgid ""
 "This default condition will be used whenever the filter is attached to "

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/inheritance_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/inheritance_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/inheritance_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,43 +11,36 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: inheritance_mapping.xml:29
 #, fuzzy, no-c-format
 msgid "Inheritance mapping"
 msgstr "상속 매핑"
 
 #. Tag: title
-#: inheritance_mapping.xml:32
 #, fuzzy, no-c-format
 msgid "The three strategies"
 msgstr "세 가지 방도들"
 
 #. Tag: para
-#: inheritance_mapping.xml:34
 #, no-c-format
 msgid "Hibernate supports the three basic inheritance mapping strategies:"
 msgstr "Hibernate는 세 가지 기본적인 상속 매핑 방도들을 지원한다:"
 
 #. Tag: para
-#: inheritance_mapping.xml:40
 #, no-c-format
 msgid "table per class hierarchy"
 msgstr "table per class hierarchy"
 
 #. Tag: para
-#: inheritance_mapping.xml:45
 #, fuzzy, no-c-format
-msgid "<para>table per subclass</para>"
-msgstr "table per subclass"
+msgid "table per subclass"
+msgstr "Table per subclass"
 
 #. Tag: para
-#: inheritance_mapping.xml:50
 #, no-c-format
 msgid "table per concrete class"
 msgstr "table per concrete class"
 
 #. Tag: para
-#: inheritance_mapping.xml:56
 #, no-c-format
 msgid ""
 "In addition, Hibernate supports a fourth, slightly different kind of "
@@ -55,13 +48,11 @@
 msgstr "게다가 Hibernate는 네 번째의 약간 다른 종류의 다형성을 지원한다:"
 
 #. Tag: para
-#: inheritance_mapping.xml:63
 #, no-c-format
 msgid "implicit polymorphism"
 msgstr "implicit polymorphism(함축적인 다형성)"
 
 #. Tag: para
-#: inheritance_mapping.xml:69
 #, fuzzy, no-c-format
 msgid ""
 "It is possible to use different mapping strategies for different branches of "
@@ -86,7 +77,6 @@
 "도와 table per subclass 방도를 함께 혼합시키는 것이 가능하다(아래를 보라)."
 
 #. Tag: para
-#: inheritance_mapping.xml:83
 #, fuzzy, no-c-format
 msgid ""
 "It is possible to define <literal>subclass</literal>, <literal>union-"
@@ -110,27 +100,12 @@
 "의 순서는 extends 키워드를 사용할 때 상관없다. 하나의 매핑 파일 내의 순서는 "
 "여전히 서브클래스들에 앞서 슈퍼클래스들을 정의하는데 여전히 필요하다."
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:94
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-" <hibernate-mapping>\n"
-"     <subclass name=\"DomesticCat\" extends=\"Cat\" discriminator-value=\"D"
-"\">\n"
-"          <property name=\"name\" type=\"string\"/>\n"
-"     </subclass>\n"
-" </hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:98
 #, no-c-format
 msgid "Table per class hierarchy"
 msgstr "Table per class hierarchy"
 
 #. Tag: para
-#: inheritance_mapping.xml:100
 #, fuzzy, no-c-format
 msgid ""
 "Suppose we have an interface <literal>Payment</literal> with the "
@@ -143,32 +118,7 @@
 "<literal>Payment</literal>를 갖고 있다고 가정하자. table per hierarchy 매핑"
 "은 다음과 같을 것이다:"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:107
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        ...\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:109
 #, fuzzy, no-c-format
 msgid ""
 "Exactly one table is required. There is a limitation of this mapping "
@@ -180,45 +130,16 @@
 "은 <literal>NOT NULL</literal> 컨스트레인트들을 가질 수 없다."
 
 #. Tag: title
-#: inheritance_mapping.xml:118
 #, no-c-format
 msgid "Table per subclass"
 msgstr "Table per subclass"
 
 #. Tag: para
-#: inheritance_mapping.xml:120
 #, fuzzy, no-c-format
 msgid "A table per subclass mapping looks like this:"
 msgstr "table per subclass 매핑은 다음과 같을 것이다:"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:124
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <joined-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:126
 #, fuzzy, no-c-format
 msgid ""
 "Four tables are required. The three subclass tables have primary key "
@@ -230,13 +151,11 @@
 "one 연관이다)."
 
 #. Tag: title
-#: inheritance_mapping.xml:135
 #, fuzzy, no-c-format
 msgid "Table per subclass: using a discriminator"
 msgstr "discriminator를 사용하는, table per subclass"
 
 #. Tag: para
-#: inheritance_mapping.xml:137
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate's implementation of table per subclass does not require a "
@@ -257,41 +176,7 @@
 "이 <literal>&lt;subclass&gt;</literal>와 <literal>&lt;join&gt;</literal>의 사"
 "용을 결합시킬 수도 있다:"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:149
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <join table=\"CREDIT_PAYMENT\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        <join table=\"CASH_PAYMENT\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        <join table=\"CHEQUE_PAYMENT\" fetch=\"select\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:151
 #, no-c-format
 msgid ""
 "The optional <literal>fetch=\"select\"</literal> declaration tells Hibernate "
@@ -303,13 +188,11 @@
 "치시키지 않도록 Hibernate에게 알려준다."
 
 #. Tag: title
-#: inheritance_mapping.xml:160
 #, no-c-format
 msgid "Mixing table per class hierarchy with table per subclass"
 msgstr "table per class hierarchy와 table per subclass를 혼합하기"
 
 #. Tag: para
-#: inheritance_mapping.xml:162
 #, fuzzy, no-c-format
 msgid ""
 "You can even mix the table per hierarchy and table per subclass strategies "
@@ -318,34 +201,7 @@
 "당신은 이 접근법을 사용하여 table per hierarchy 방도와 table per subclass 방"
 "도를 혼합시킬 수 있다:"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <join table=\"CREDIT_PAYMENT\">\n"
-"            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        ...\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:169
 #, no-c-format
 msgid ""
 "For any of these mapping strategies, a polymorphic association to the root "
@@ -356,22 +212,12 @@
 "대한 하나의 다형성 연관은 <literal>&lt;many-to-one&gt;</literal>을 사용하여 "
 "매핑된다."
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:175
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"payment\" column=\"PAYMENT_ID\" class=\"Payment"
-"\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:180
 #, no-c-format
 msgid "Table per concrete class"
 msgstr "Table per concrete class"
 
 #. Tag: para
-#: inheritance_mapping.xml:182
 #, fuzzy, no-c-format
 msgid ""
 "There are two ways we can map the table per concrete class strategy. First, "
@@ -381,31 +227,7 @@
 "이 존재한다. 첫 번째는 <literal>&lt;union-subclass&gt;</literal>를 사용하는 "
 "것이다."
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:187
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"sequence\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <union-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </union-subclass>\n"
-"    <union-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        ...\n"
-"    </union-subclass>\n"
-"    <union-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        ...\n"
-"    </union-subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:189
 #, no-c-format
 msgid ""
 "Three tables are involved for the subclasses. Each table defines columns for "
@@ -415,7 +237,6 @@
 "퍼티들을 포함하여, 그 클래스의 모든 프로퍼티들에 대한 컬럼들을 정의한다."
 
 #. Tag: para
-#: inheritance_mapping.xml:194
 #, fuzzy, no-c-format
 msgid ""
 "The limitation of this approach is that if a property is mapped on the "
@@ -431,7 +252,6 @@
 "계층구조의 모든 unioned 서브클래스들을 가로질러 공유되어야 한다."
 
 #. Tag: para
-#: inheritance_mapping.xml:203
 #, fuzzy, no-c-format
 msgid ""
 "If your superclass is abstract, map it with <literal>abstract=\"true\"</"
@@ -445,48 +265,16 @@
 "스들을 소유하는데 필요하다."
 
 #. Tag: title
-#: inheritance_mapping.xml:213
 #, fuzzy, no-c-format
 msgid "Table per concrete class using implicit polymorphism"
 msgstr "함축적인 다형성을 사용하는, table per concrete class"
 
 #. Tag: para
-#: inheritance_mapping.xml:215
 #, no-c-format
 msgid "An alternative approach is to make use of implicit polymorphism:"
 msgstr "대안적인 접근법은 함축적인 다형성을 사용하는 것이다:"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:219
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-"    ...\n"
-"</class>\n"
-"\n"
-"<class name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CASH_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-"    ...\n"
-"</class>\n"
-"\n"
-"<class name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CHEQUE_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:221
 #, fuzzy, no-c-format
 msgid ""
 "Notice that the <literal>Payment</literal> interface is not mentioned "
@@ -494,18 +282,17 @@
 "mapped in each of the subclasses. If you want to avoid duplication, consider "
 "using XML entities (for example, <literal>[ &lt;!ENTITY allproperties SYSTEM "
 "\"allproperties.xml\"&gt; ]</literal> in the <literal>DOCTYPE</literal> "
-"declaration and <literal>&amp;allproperties;</literal> in the mapping)."
+"declaration and <literal>&amp;allproperties&semi;</literal> in the mapping)."
 msgstr ""
 "어느 곳에서도 우리가 명시적으로 <literal>Payment</literal> 인터페이스를 언급"
 "하지 않음을 주목하라. 또한 <literal>Payment</literal>의 프로퍼티들이 서브클래"
 "스들 각각에서 매핑된다는 점을 주목하라. 만일 당신이 중복을 피하고자 원한다"
 "면, XML 엔티티들을 사용하는 것을 고려하라(예를 들어 매핑에서 "
-"<literal>DOCTYPE</literal> 선언과 <literal>&amp;allproperties;</literal>에서 "
+"<literal>DOCTYPE</literal> 선언과 <literal>&amp;allproperties&semi;</literal>에서 "
 "<literal>[ &lt;!ENTITY allproperties SYSTEM \"allproperties.xml\"&gt; ]</"
 "literal>)."
 
 #. Tag: para
-#: inheritance_mapping.xml:231
 #, no-c-format
 msgid ""
 "The disadvantage of this approach is that Hibernate does not generate SQL "
@@ -515,7 +302,6 @@
 "<literal>UNION</literal>들을 생성시키는 않는다는 점이다."
 
 #. Tag: para
-#: inheritance_mapping.xml:236
 #, no-c-format
 msgid ""
 "For this mapping strategy, a polymorphic association to <literal>Payment</"
@@ -524,27 +310,12 @@
 "이 매핑 방도의 경우, <literal>Payment</literal>에 대한 하나의 다형성 연관은 "
 "대개 <literal>&lt;any&gt;</literal>를 사용하여 매핑된다."
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:241
-#, no-c-format
-msgid ""
-"<![CDATA[<any name=\"payment\" meta-type=\"string\" id-type=\"long\">\n"
-"    <meta-value value=\"CREDIT\" class=\"CreditCardPayment\"/>\n"
-"    <meta-value value=\"CASH\" class=\"CashPayment\"/>\n"
-"    <meta-value value=\"CHEQUE\" class=\"ChequePayment\"/>\n"
-"    <column name=\"PAYMENT_CLASS\"/>\n"
-"    <column name=\"PAYMENT_ID\"/>\n"
-"</any>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:246
 #, no-c-format
 msgid "Mixing implicit polymorphism with other inheritance mappings"
 msgstr "함축적인 다형성을 다른 상속 매핑들과 혼합하기"
 
 #. Tag: para
-#: inheritance_mapping.xml:248
 #, fuzzy, no-c-format
 msgid ""
 "Since the subclasses are each mapped in their own <literal>&lt;class&gt;</"
@@ -559,41 +330,7 @@
 "게 또 다른 상속 계층구조의 부분일 수 있다! (그리고 당신은 <literal>Payment</"
 "literal> 인터페이스에 대해 여전히 다형성 질의들을 사용할 수 있다.)"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:256
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"CREDIT_CARD\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"MasterCardPayment\" discriminator-value=\"MDC\"/>\n"
-"    <subclass name=\"VisaPayment\" discriminator-value=\"VISA\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"NonelectronicTransaction\" table=\"NONELECTRONIC_TXN\">\n"
-"    <id name=\"id\" type=\"long\" column=\"TXN_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    ...\n"
-"    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:258
 #, fuzzy, no-c-format
 msgid ""
 "Once again, <literal>Payment</literal> is not mentioned explicitly. If we "
@@ -613,13 +350,11 @@
 "<literal>NonelectronicTransaction</literal>의 인스턴스들을 반환하지 않는다."
 
 #. Tag: title
-#: inheritance_mapping.xml:273
 #, no-c-format
 msgid "Limitations"
 msgstr "제약들"
 
 #. Tag: para
-#: inheritance_mapping.xml:275
 #, fuzzy, no-c-format
 msgid ""
 "There are limitations to the \"implicit polymorphism\" approach to the table "
@@ -631,7 +366,6 @@
 "서는 다소 덜 제한적인 제약들이 존재한다:"
 
 #. Tag: para
-#: inheritance_mapping.xml:282
 #, no-c-format
 msgid ""
 "The following table shows the limitations of table per concrete-class "
@@ -641,140 +375,106 @@
 "고 함축적인 다형성에 대한 제약들을 보여준다."
 
 #. Tag: title
-#: inheritance_mapping.xml:288
 #, no-c-format
 msgid "Features of inheritance mappings"
 msgstr "상속 매핑들의 특징들"
 
 #. Tag: entry
-#: inheritance_mapping.xml:301
 #, no-c-format
 msgid "Inheritance strategy"
 msgstr "상속 방도"
 
 #. Tag: entry
-#: inheritance_mapping.xml:302
 #, no-c-format
 msgid "Polymorphic many-to-one"
 msgstr "다형성 다대일"
 
 #. Tag: entry
-#: inheritance_mapping.xml:303
 #, no-c-format
 msgid "Polymorphic one-to-one"
 msgstr "다형성 일대일"
 
 #. Tag: entry
-#: inheritance_mapping.xml:304
 #, no-c-format
 msgid "Polymorphic one-to-many"
 msgstr "다형성 일대다"
 
 #. Tag: entry
-#: inheritance_mapping.xml:305
 #, no-c-format
 msgid "Polymorphic many-to-many"
 msgstr "다형성 다대다"
 
 #. Tag: entry
-#: inheritance_mapping.xml:306
 #, no-c-format
 msgid "Polymorphic <literal>load()/get()</literal>"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:307
 #, no-c-format
 msgid "Polymorphic queries"
 msgstr "다형성 질의들"
 
 #. Tag: entry
-#: inheritance_mapping.xml:308
 #, no-c-format
 msgid "Polymorphic joins"
 msgstr "다형성 조인들"
 
 #. Tag: entry
-#: inheritance_mapping.xml:309
 #, no-c-format
 msgid "Outer join fetching"
 msgstr "Outer 조인 페칭"
 
 #. Tag: entry
-#: inheritance_mapping.xml:314
 #, no-c-format
 msgid "table per class-hierarchy"
 msgstr "table per class-hierarchy"
 
-#. Tag: literal
-#: inheritance_mapping.xml:315 inheritance_mapping.xml:326
-#: inheritance_mapping.xml:337
-#, no-c-format
-msgid "&lt;many-to-one&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;many-to-one&gt;</literal>"
 msgstr "&lt;many-to-one&gt;"
 
-#. Tag: literal
-#: inheritance_mapping.xml:316 inheritance_mapping.xml:327
-#: inheritance_mapping.xml:338
-#, no-c-format
-msgid "&lt;one-to-one&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;one-to-one&gt;</literal>"
 msgstr "&lt;one-to-one&gt;"
 
-#. Tag: literal
-#: inheritance_mapping.xml:317 inheritance_mapping.xml:328
-#, no-c-format
-msgid "&lt;one-to-many&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;one-to-many&gt;</literal>"
 msgstr "&lt;one-to-many&gt;"
 
-#. Tag: literal
-#: inheritance_mapping.xml:318 inheritance_mapping.xml:329
-#: inheritance_mapping.xml:340
-#, no-c-format
-msgid "&lt;many-to-many&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;many-to-many&gt;</literal>"
 msgstr "&lt;many-to-many&gt;"
 
-#. Tag: literal
-#: inheritance_mapping.xml:319 inheritance_mapping.xml:330
-#: inheritance_mapping.xml:341
-#, no-c-format
-msgid "s.get(Payment.class, id)"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>s.get(Payment.class, id)</literal>"
 msgstr "s.get(Payment.class, id)"
 
-#. Tag: literal
-#: inheritance_mapping.xml:320 inheritance_mapping.xml:331
-#: inheritance_mapping.xml:342 inheritance_mapping.xml:353
+#. Tag: entry
 #, no-c-format
-msgid "from Payment p"
-msgstr "from Payment p"
+msgid "<literal>from Payment p</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:321 inheritance_mapping.xml:332
-#: inheritance_mapping.xml:343
-#, no-c-format
-msgid "from Order o join o.payment p"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>from Order o join o.payment p</literal>"
 msgstr "from Order o join o.payment p"
 
-#. Tag: emphasis
-#: inheritance_mapping.xml:322 inheritance_mapping.xml:333
-#: inheritance_mapping.xml:344
+#. Tag: entry
 #, no-c-format
-msgid "supported"
-msgstr "지원됨"
+msgid "<emphasis>supported</emphasis>"
+msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:325
-#, fuzzy, no-c-format
-msgid "<entry>table per subclass</entry>"
-msgstr "table per subclass"
-
-#. Tag: entry
-#: inheritance_mapping.xml:336
 #, no-c-format
 msgid "table per concrete-class (union-subclass)"
 msgstr "table per concrete-class (union-subclass)"
 
 #. Tag: entry
-#: inheritance_mapping.xml:339
 #, no-c-format
 msgid ""
 "<literal>&lt;one-to-many&gt;</literal> (for <literal>inverse=\"true\"</"
@@ -782,38 +482,53 @@
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:347
 #, no-c-format
 msgid "table per concrete class (implicit polymorphism)"
 msgstr "table per concrete class (implicit polymorphism)"
 
-#. Tag: literal
-#: inheritance_mapping.xml:348
+#. Tag: entry
 #, no-c-format
-msgid "&lt;any&gt;"
-msgstr "&lt;any&gt;"
+msgid "<literal>&lt;any&gt;</literal>"
+msgstr ""
 
-#. Tag: emphasis
-#: inheritance_mapping.xml:349 inheritance_mapping.xml:350
-#: inheritance_mapping.xml:354 inheritance_mapping.xml:355
+#. Tag: entry
 #, no-c-format
-msgid "not supported"
-msgstr "지원되지 않음"
+msgid "<emphasis>not supported</emphasis>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:351
-#, no-c-format
-msgid "&lt;many-to-any&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;many-to-any&gt;</literal>"
 msgstr "&lt;many-to-any&gt;"
 
-#. Tag: literal
-#: inheritance_mapping.xml:352
-#, no-c-format
+#. Tag: entry
+#, fuzzy, no-c-format
 msgid ""
-"s.createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()"
+"<literal>s.createCriteria(Payment.class).add( Restrictions.idEq(id) )."
+"uniqueResult()</literal>"
 msgstr ""
 "s.createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()"
 
+#, fuzzy
+#~ msgid "<para>table per subclass</para>"
+#~ msgstr "table per subclass"
+
+#~ msgid "from Payment p"
+#~ msgstr "from Payment p"
+
+#~ msgid "supported"
+#~ msgstr "지원됨"
+
+#, fuzzy
+#~ msgid "<entry>table per subclass</entry>"
+#~ msgstr "table per subclass"
+
+#~ msgid "&lt;any&gt;"
+#~ msgstr "&lt;any&gt;"
+
+#~ msgid "not supported"
+#~ msgstr "지원되지 않음"
+
 #~ msgid "load()/get()"
 #~ msgstr "load()/get()"
 

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/performance.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/performance.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/performance.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-08-17 20:22+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,19 +11,16 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: performance.xml:29
 #, no-c-format
 msgid "Improving performance"
 msgstr "퍼포먼스 개선하기"
 
 #. Tag: title
-#: performance.xml:32
 #, no-c-format
 msgid "Fetching strategies"
 msgstr "페칭 방도들"
 
 #. Tag: para
-#: performance.xml:34
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate uses a <emphasis>fetching strategy</emphasis> to retrieve "
@@ -37,13 +34,11 @@
 "<literal>Criteria</literal> 질의에 의해 오버라이드 될 수도 있다."
 
 #. Tag: para
-#: performance.xml:41
 #, no-c-format
 msgid "Hibernate3 defines the following fetching strategies:"
 msgstr "Hibernate3는 다음 페칭 방도들을 정의한다:"
 
 #. Tag: para
-#: performance.xml:47
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Join fetching</emphasis>: Hibernate retrieves the associated "
@@ -55,7 +50,6 @@
 "을 검색한다."
 
 #. Tag: para
-#: performance.xml:54
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Select fetching</emphasis>: a second <literal>SELECT</literal> is "
@@ -69,7 +63,6 @@
 "이 두 번째 select는 당신이 그 연관에 실제로 액세스할 때 오직 실행될 것이다."
 
 #. Tag: para
-#: performance.xml:63
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Subselect fetching</emphasis>: a second <literal>SELECT</literal> "
@@ -85,7 +78,6 @@
 "그 연관에 접근할 때 오직 실행될 것이다."
 
 #. Tag: para
-#: performance.xml:72
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Batch fetching</emphasis>: an optimization strategy for select "
@@ -99,13 +91,11 @@
 "를 검색한다."
 
 #. Tag: para
-#: performance.xml:81
 #, no-c-format
 msgid "Hibernate also distinguishes between:"
 msgstr "Hibernate는 또한 다음 사이를 구별 짓는다:"
 
 #. Tag: para
-#: performance.xml:87
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Immediate fetching</emphasis>: an association, collection or "
@@ -115,7 +105,6 @@
 "성이 즉시 페치된다."
 
 #. Tag: para
-#: performance.xml:93
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Lazy collection fetching</emphasis>: a collection is fetched when "
@@ -127,7 +116,6 @@
 "다.)"
 
 #. Tag: para
-#: performance.xml:100
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>\"Extra-lazy\" collection fetching</emphasis>: individual elements "
@@ -140,7 +128,6 @@
 "체 콜렉션을 메모리 내로 페치하려고 시도하지 않는다(매우 큰 콜렉션에 적합함)"
 
 #. Tag: para
-#: performance.xml:108
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Proxy fetching</emphasis>: a single-valued association is fetched "
@@ -151,7 +138,6 @@
 "객체에 대해 호출될 때 단일 값 연관이 페치된다."
 
 #. Tag: para
-#: performance.xml:115
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>\"No-proxy\" fetching</emphasis>: a single-valued association is "
@@ -168,7 +154,6 @@
 "코드 수단을 필요로 하며 드물게 필요하다."
 
 #. Tag: para
-#: performance.xml:125
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Lazy attribute fetching</emphasis>: an attribute or single valued "
@@ -180,7 +165,6 @@
 "게 필요하다."
 
 #. Tag: para
-#: performance.xml:134
 #, fuzzy, no-c-format
 msgid ""
 "We have two orthogonal notions here: <emphasis>when</emphasis> is the "
@@ -198,13 +182,11 @@
 "할 수 있다."
 
 #. Tag: title
-#: performance.xml:143
 #, no-c-format
 msgid "Working with lazy associations"
 msgstr "lazy 연관들로 작업하기"
 
 #. Tag: para
-#: performance.xml:145
 #, fuzzy, no-c-format
 msgid ""
 "By default, Hibernate3 uses lazy select fetching for collections and lazy "
@@ -216,7 +198,6 @@
 "션들에서 거의 모든 연관들에 대해 유의미하다."
 
 #. Tag: para
-#: performance.xml:151
 #, fuzzy, no-c-format
 msgid ""
 "If you set <literal>hibernate.default_batch_fetch_size</literal>, Hibernate "
@@ -229,7 +210,6 @@
 "에서 이용 가능할 수 있다)."
 
 #. Tag: para
-#: performance.xml:158
 #, fuzzy, no-c-format
 msgid ""
 "Please be aware that access to a lazy association outside of the context of "
@@ -239,25 +219,7 @@
 "Hibernate 세션 컨텍스트 외부에서 lazy 연관에 대한 접근은 예외상황으로 귀결될 "
 "것이다. 예를 들면 :"
 
-#. Tag: programlisting
-#: performance.xml:164
-#, no-c-format
-msgid ""
-"<![CDATA[s = sessions.openSession();\n"
-"Transaction tx = s.beginTransaction();\n"
-"            \n"
-"User u = (User) s.createQuery(\"from User u where u.name=:userName\")\n"
-"    .setString(\"userName\", userName).uniqueResult();\n"
-"Map permissions = u.getPermissions();\n"
-"\n"
-"tx.commit();\n"
-"s.close();\n"
-"\n"
-"Integer accessLevel = (Integer) permissions.get(\"accounts\");  // Error!]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:166
 #, fuzzy, no-c-format
 msgid ""
 "Since the permissions collection was not initialized when the "
@@ -273,7 +235,6 @@
 "키는 것이다."
 
 #. Tag: para
-#: performance.xml:174
 #, fuzzy, no-c-format
 msgid ""
 "Alternatively, you can use a non-lazy collection or association, by "
@@ -291,7 +252,6 @@
 "될 것이다!"
 
 #. Tag: para
-#: performance.xml:183
 #, fuzzy, no-c-format
 msgid ""
 "On the other hand, you can use join fetching, which is non-lazy by nature, "
@@ -306,13 +266,11 @@
 "단일 값 연관들과 콜렉션들에 대해 동일하다."
 
 #. Tag: title
-#: performance.xml:194
 #, no-c-format
 msgid "Tuning fetch strategies"
 msgstr "페치 방도들을 튜닝하기"
 
 #. Tag: para
-#: performance.xml:196
 #, no-c-format
 msgid ""
 "Select fetching (the default) is extremely vulnerable to N+1 selects "
@@ -321,25 +279,7 @@
 "select 페칭(디폴트)은 N+1 selects 문제점들에 매우 취약해서, 우리는 매핑 문서"
 "에서 join 페칭을 사용 가능하게 하기를 원할 수도 있다:"
 
-#. Tag: programlisting
-#: performance.xml:201
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"permissions\" \n"
-"            fetch=\"join\">\n"
-"    <key column=\"userId\"/>\n"
-"    <one-to-many class=\"Permission\"/>\n"
-"</set]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: performance.xml:203
-#, no-c-format
-msgid "<![CDATA[<many-to-one name=\"mother\" class=\"Cat\" fetch=\"join\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:205
 #, no-c-format
 msgid ""
 "The <literal>fetch</literal> strategy defined in the mapping document "
@@ -348,31 +288,26 @@
 "매핑 문서 내에 정의된 <literal>fetch</literal> 방도는 다음에 영향을 준다:"
 
 #. Tag: para
-#: performance.xml:211
 #, no-c-format
 msgid "retrieval via <literal>get()</literal> or <literal>load()</literal>"
 msgstr "<literal>get()</literal> 또는 <literal>load()</literal>를 통한 검색"
 
 #. Tag: para
-#: performance.xml:216
 #, no-c-format
 msgid "retrieval that happens implicitly when an association is navigated"
 msgstr "연관이 네비게이트될 때 함축적으로 발생하는 검색"
 
 #. Tag: para
-#: performance.xml:221
 #, no-c-format
 msgid "<literal>Criteria</literal> queries"
 msgstr "<literal>Criteria</literal> 질의들"
 
 #. Tag: para
-#: performance.xml:226
 #, no-c-format
 msgid "HQL queries if <literal>subselect</literal> fetching is used"
 msgstr "<literal>subselect</literal> 페칭이 사용될 경우에 HQL 질의들"
 
 #. Tag: para
-#: performance.xml:232
 #, fuzzy, no-c-format
 msgid ""
 "Irrespective of the fetching strategy you use, the defined non-lazy graph is "
@@ -384,7 +319,6 @@
 "사용되는 몇몇 즉시적인 select들로 귀결될 수 있음을 노트하라."
 
 #. Tag: para
-#: performance.xml:238
 #, fuzzy, no-c-format
 msgid ""
 "Usually, the mapping document is not used to customize fetching. Instead, we "
@@ -402,7 +336,6 @@
 "<literal>setFetchMode(FetchMode.JOIN)</literal>을 사용한다."
 
 #. Tag: para
-#: performance.xml:247
 #, fuzzy, no-c-format
 msgid ""
 "If you want to change the fetching strategy used by <literal>get()</literal> "
@@ -413,18 +346,7 @@
 "용된 페칭 방도를 변경시킬 수 있기를 당신이 원한다고 느낄 경우, 단순하게 "
 "<literal>Criteria</literal> 질의를 사용하라. 예를 들면:"
 
-#. Tag: programlisting
-#: performance.xml:253
-#, no-c-format
-msgid ""
-"<![CDATA[User user = (User) session.createCriteria(User.class)\n"
-"                .setFetchMode(\"permissions\", FetchMode.JOIN)\n"
-"                .add( Restrictions.idEq(userId) )\n"
-"                .uniqueResult();]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:255
 #, fuzzy, no-c-format
 msgid ""
 "This is Hibernate's equivalent of what some ORM solutions call a \"fetch plan"
@@ -434,7 +356,6 @@
 "등가물이다.)"
 
 #. Tag: para
-#: performance.xml:259
 #, fuzzy, no-c-format
 msgid ""
 "A completely different approach to problems with N+1 selects is to use the "
@@ -444,13 +365,11 @@
 "시를 사용하는 것이다."
 
 #. Tag: title
-#: performance.xml:267
 #, no-c-format
 msgid "Single-ended association proxies"
 msgstr "Single-ended 연관 프락시"
 
 #. Tag: para
-#: performance.xml:269
 #, fuzzy, no-c-format
 msgid ""
 "Lazy fetching for collections is implemented using Hibernate's own "
@@ -467,7 +386,6 @@
 "기화 프락시들을 구현한다."
 
 #. Tag: para
-#: performance.xml:277
 #, fuzzy, no-c-format
 msgid ""
 "At startup, Hibernate3 generates proxies by default for all persistent "
@@ -479,7 +397,6 @@
 "관에 대해 lazy 페칭을 이용 가능하게 하는데 그것들을 사용한다."
 
 #. Tag: para
-#: performance.xml:283
 #, fuzzy, no-c-format
 msgid ""
 "The mapping file may declare an interface to use as the proxy interface for "
@@ -495,7 +412,6 @@
 "든 영속 클래스들에 대해 이 생성자를 권장한다!</emphasis>"
 
 #. Tag: para
-#: performance.xml:290
 #, fuzzy, no-c-format
 msgid ""
 "There are potential problems to note when extending this approach to "
@@ -504,20 +420,7 @@
 "다형성 클래스들에 대해 이 접근법을 확장할 때 의식해야 하는 몇몇 난처함들이 존"
 "재한다. 예를 들면."
 
-#. Tag: programlisting
-#: performance.xml:294
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Cat\" proxy=\"Cat\">\n"
-"    ......\n"
-"    <subclass name=\"DomesticCat\">\n"
-"        .....\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:296
 #, no-c-format
 msgid ""
 "Firstly, instances of <literal>Cat</literal> will never be castable to "
@@ -528,39 +431,12 @@
 "인 경우조차도, <literal>Cat</literal>의 인스턴스들은 결코 "
 "<literal>DomesticCat</literal>으로 타입캐스트가 가능하지 않을 것이다:"
 
-#. Tag: programlisting
-#: performance.xml:302
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);  // instantiate a "
-"proxy (does not hit the db)\n"
-"if ( cat.isDomesticCat() ) {                  // hit the db to initialize "
-"the proxy\n"
-"    DomesticCat dc = (DomesticCat) cat;       // Error!\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:304
 #, fuzzy, no-c-format
 msgid "Secondly, it is possible to break proxy <literal>==</literal>:"
 msgstr "두번째로, 프락시 <literal>==</literal>를 파기할 가능성이 있다."
 
-#. Tag: programlisting
-#: performance.xml:308
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);            // "
-"instantiate a Cat proxy\n"
-"DomesticCat dc = \n"
-"        (DomesticCat) session.load(DomesticCat.class, id);  // acquire new "
-"DomesticCat proxy!\n"
-"System.out.println(cat==dc);                            // false]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:310
 #, no-c-format
 msgid ""
 "However, the situation is not quite as bad as it looks. Even though we now "
@@ -571,16 +447,7 @@
 "프락시 객체들에 대한 두 개의 참조를 가질지라도, 기본 인스턴스는 여전히 동일"
 "한 객체들일 것이다:"
 
-#. Tag: programlisting
-#: performance.xml:315
-#, no-c-format
-msgid ""
-"<![CDATA[cat.setWeight(11.0);  // hit the db to initialize the proxy\n"
-"System.out.println( dc.getWeight() );  // 11.0]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:317
 #, fuzzy, no-c-format
 msgid ""
 "Third, you cannot use a CGLIB proxy for a <literal>final</literal> class or "
@@ -590,7 +457,6 @@
 "literal> 메소드들을 가진 클래스에 대해 CGLIB 프락시를 사용하지 않을 수 있다."
 
 #. Tag: para
-#: performance.xml:322
 #, fuzzy, no-c-format
 msgid ""
 "Finally, if your persistent object acquires any resources upon instantiation "
@@ -604,7 +470,6 @@
 "브클래스이다."
 
 #. Tag: para
-#: performance.xml:328
 #, fuzzy, no-c-format
 msgid ""
 "These problems are all due to fundamental limitations in Java's single "
@@ -620,20 +485,7 @@
 "지니스 메소드들을 선언하는 인터페이스를 구현해야 한다. 당신은 매핑 파일 속에 "
 "이들 인터페이스들을 지정해야 한다. 예를 들면."
 
-#. Tag: programlisting
-#: performance.xml:336
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"CatImpl\" proxy=\"Cat\">\n"
-"    ......\n"
-"    <subclass name=\"DomesticCatImpl\" proxy=\"DomesticCat\">\n"
-"        .....\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:338
 #, fuzzy, no-c-format
 msgid ""
 "Then proxies for instances of <literal>Cat</literal> and "
@@ -644,30 +496,17 @@
 "인 경우조차도, <literal>Cat</literal>의 인스턴스들은 결코 "
 "<literal>DomesticCat</literal>으로 타입캐스트가 가능하지 않을 것이다:"
 
-#. Tag: programlisting
-#: performance.xml:343
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(CatImpl.class, catid);\n"
-"Iterator iter = session.createQuery(\"from CatImpl as cat where cat."
-"name='fritz'\").iterate();\n"
-"Cat fritz = (Cat) iter.next();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:346
 #, no-c-format
 msgid "Note"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:347
 #, fuzzy, no-c-format
 msgid "<literal>list()</literal> does not usually return proxies."
 msgstr "<literal>Criteria</literal> 질의들"
 
 #. Tag: para
-#: performance.xml:352
 #, no-c-format
 msgid ""
 "Relationships are also lazily initialized. This means you must declare any "
@@ -679,7 +518,6 @@
 "야 함을 의미한다."
 
 #. Tag: para
-#: performance.xml:357
 #, fuzzy, no-c-format
 msgid ""
 "Certain operations do <emphasis>not</emphasis> require proxy initialization:"
@@ -687,7 +525,6 @@
 "어떤 오퍼레이션들은 프락시 초기화를 필요로 하지 <emphasis>않는다</emphasis>"
 
 #. Tag: para
-#: performance.xml:363
 #, fuzzy, no-c-format
 msgid ""
 "<literal>equals()</literal>: if the persistent class does not override "
@@ -697,7 +534,6 @@
 "를 오버라이드 시키지 않는 경우"
 
 #. Tag: para
-#: performance.xml:369
 #, fuzzy, no-c-format
 msgid ""
 "<literal>hashCode()</literal>: if the persistent class does not override "
@@ -707,13 +543,11 @@
 "literal>를 오버라이드 시키지 않는 경우"
 
 #. Tag: para
-#: performance.xml:375
 #, no-c-format
 msgid "The identifier getter method"
 msgstr "식별자 getter 메소드"
 
 #. Tag: para
-#: performance.xml:381
 #, no-c-format
 msgid ""
 "Hibernate will detect persistent classes that override <literal>equals()</"
@@ -723,7 +557,6 @@
 "오버라이드 시키는 영속 클래스들을 검출할 것이다."
 
 #. Tag: para
-#: performance.xml:386
 #, fuzzy, no-c-format
 msgid ""
 "By choosing <literal>lazy=\"no-proxy\"</literal> instead of the default "
@@ -737,13 +570,11 @@
 "프락시 초기화로 귀결될 것이다."
 
 #. Tag: title
-#: performance.xml:396
 #, no-c-format
 msgid "Initializing collections and proxies"
 msgstr "콜렉션들과 프락시들을 초기화 시키기"
 
 #. Tag: para
-#: performance.xml:398
 #, fuzzy, no-c-format
 msgid ""
 "A <literal>LazyInitializationException</literal> will be thrown by Hibernate "
@@ -757,7 +588,6 @@
 "literal>이 Hibernate에 의해 던져질 것이다."
 
 #. Tag: para
-#: performance.xml:404
 #, fuzzy, no-c-format
 msgid ""
 "Sometimes a proxy or collection needs to be initialized before closing the "
@@ -773,7 +603,6 @@
 "코드로 편의적이지 않다."
 
 #. Tag: para
-#: performance.xml:411
 #, fuzzy, no-c-format
 msgid ""
 "The static methods <literal>Hibernate.initialize()</literal> and "
@@ -793,7 +622,6 @@
 "kittens의 콜렉션에 대해 유사한 효과를 갖는다."
 
 #. Tag: para
-#: performance.xml:420
 #, fuzzy, no-c-format
 msgid ""
 "Another option is to keep the <literal>Session</literal> open until all "
@@ -812,7 +640,6 @@
 "히 하는 문제일 수 있다. 이 쟁점을 다루는 두 가지 기본 방법들이 존재한다:"
 
 #. Tag: para
-#: performance.xml:431
 #, fuzzy, no-c-format
 msgid ""
 "In a web-based application, a servlet filter can be used to close the "
@@ -834,7 +661,6 @@
 "다. 이 \"Open Session in View\" 패턴에 관한 예제들은 Hibernate 위키를 보라."
 
 #. Tag: para
-#: performance.xml:444
 #, fuzzy, no-c-format
 msgid ""
 "In an application with a separate business tier, the business logic must "
@@ -861,7 +687,6 @@
 "emphasis> 패턴을 채택할 경우에 더 쉽다."
 
 #. Tag: para
-#: performance.xml:459
 #, fuzzy, no-c-format
 msgid ""
 "You can also attach a previously loaded object to a new <literal>Session</"
@@ -878,7 +703,6 @@
 "이기 때문이다!"
 
 #. Tag: para
-#: performance.xml:469
 #, fuzzy, no-c-format
 msgid ""
 "Sometimes you do not want to initialize a large collection, but still need "
@@ -889,7 +713,6 @@
 "의 사이즈와 같은) 그것에 대한 어떤 정보 또는 데이터의 부분집합을 필요로 한다."
 
 #. Tag: para
-#: performance.xml:474
 #, no-c-format
 msgid ""
 "You can use a collection filter to get the size of a collection without "
@@ -898,16 +721,7 @@
 "당신은 그것을 초기화 시키지 않고서 콜렉션의 사이즈를 얻는데 콜렉션 필터를 사"
 "용할 수 있다:"
 
-#. Tag: programlisting
-#: performance.xml:478
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) s.createFilter( collection, \"select count(*)\" ).list"
-"().get(0) ).intValue()]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:480
 #, no-c-format
 msgid ""
 "The <literal>createFilter()</literal> method is also used to efficiently "
@@ -917,22 +731,12 @@
 "<literal>createFilter()</literal> 메소드는 또한 전체 콜렉션을 초기화 시킬 필"
 "요 없이 콜렉션의 부분집합들을 효율적으로 검색하는데 사용된다:"
 
-#. Tag: programlisting
-#: performance.xml:485
-#, no-c-format
-msgid ""
-"<![CDATA[s.createFilter( lazyCollection, \"\").setFirstResult(0)."
-"setMaxResults(10).list();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:490
 #, no-c-format
 msgid "Using batch fetching"
 msgstr "batch 페칭 사용하기"
 
 #. Tag: para
-#: performance.xml:492
 #, fuzzy, no-c-format
 msgid ""
 "Using batch fetching, Hibernate can load several uninitialized proxies if "
@@ -947,7 +751,6 @@
 "고 콜렉션 레벨에서."
 
 #. Tag: para
-#: performance.xml:498
 #, fuzzy, no-c-format
 msgid ""
 "Batch fetching for classes/entities is easier to understand. Consider the "
@@ -973,14 +776,7 @@
 "<literal>Person</literal> 매핑에서 <literal>batch-size</literal>를 지정함으로"
 "써 이 동작을 튜닝시킬 수 있다:"
 
-#. Tag: programlisting
-#: performance.xml:508
-#, no-c-format
-msgid "<![CDATA[<class name=\"Person\" batch-size=\"10\">...</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:510
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate will now execute only three queries: the pattern is 10, 10, 5."
@@ -989,7 +785,6 @@
 "다."
 
 #. Tag: para
-#: performance.xml:514
 #, fuzzy, no-c-format
 msgid ""
 "You can also enable batch fetching of collections. For example, if each "
@@ -1010,19 +805,7 @@
 "batch 페칭을 사용가능하게 할 경우, Hibernate는 콜렉션들을 미리-페치 시킬 수 "
 "있다:"
 
-#. Tag: programlisting
-#: performance.xml:523
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <set name=\"cats\" batch-size=\"3\">\n"
-"        ...\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:525
 #, no-c-format
 msgid ""
 "With a <literal>batch-size</literal> of 3, Hibernate will load 3, 3, 3, 1 "
@@ -1036,7 +819,6 @@
 "에 의존한다."
 
 #. Tag: para
-#: performance.xml:531
 #, fuzzy, no-c-format
 msgid ""
 "Batch fetching of collections is particularly useful if you have a nested "
@@ -1050,13 +832,11 @@
 "은 옵션일 수 있을지라도) 콜렉션들에 대한 batch 페칭이 특히 유용하다."
 
 #. Tag: title
-#: performance.xml:540
 #, no-c-format
 msgid "Using subselect fetching"
 msgstr "subselect 페칭 사용하기"
 
 #. Tag: para
-#: performance.xml:542
 #, fuzzy, no-c-format
 msgid ""
 "If one lazy collection or single-valued proxy has to be fetched, Hibernate "
@@ -1068,13 +848,69 @@
 "다. 이것은 조각난 로딩 없이 batch 페칭과 동일한 방식으로 동작한다."
 
 #. Tag: title
-#: performance.xml:553
+#, fuzzy, no-c-format
+msgid "Fetch profiles"
+msgstr "페칭 방도들"
+
+#. Tag: para
 #, no-c-format
+msgid ""
+"Another way to affect the fetching strategy for loading associated objects "
+"is through something called a fetch profile, which is a named configuration "
+"associated with the <interfacename>org.hibernate.SessionFactory</"
+"interfacename> but enabled, by name, on the <interfacename>org.hibernate."
+"Session</interfacename>. Once enabled on a <interfacename>org.hibernate."
+"Session</interfacename>, the fetch profile wull be in affect for that "
+"<interfacename>org.hibernate.Session</interfacename> until it is explicitly "
+"disabled."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"So what does that mean? Well lets explain that by way of an example. Say we "
+"have the following mappings:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Now normally when you get a reference to a particular customer, that "
+"customer's set of orders will be lazy meaning we will not yet have loaded "
+"those orders from the database. Normally this is a good thing. Now lets say "
+"that you have a certain use case where it is more efficient to load the "
+"customer and their orders together. One way certainly is to use \"dynamic "
+"fetching\" strategies via an HQL or criteria queries. But another option is "
+"to use a fetch profile to achieve that. Just add the following to your "
+"mapping:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "or even:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Now the following code will actually load both the customer <emphasis>and "
+"their orders</emphasis>:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Currently only join style fetch profiles are supported, but they plan is to "
+"support additional styles. See <ulink url=\"http://opensource.atlassian.com/"
+"projects/hibernate/browse/HHH-3414\">HHH-3414</ulink> for details."
+msgstr ""
+
+#. Tag: title
+#, no-c-format
 msgid "Using lazy property fetching"
 msgstr "lazy 프로퍼티 페칭 사용하기"
 
 #. Tag: para
-#: performance.xml:555
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate3 supports the lazy fetching of individual properties. This "
@@ -1093,7 +929,6 @@
 "몇 프로퍼티들을 로드시키는 것 만이 유용할 수도 있다."
 
 #. Tag: para
-#: performance.xml:564
 #, no-c-format
 msgid ""
 "To enable lazy property loading, set the <literal>lazy</literal> attribute "
@@ -1102,24 +937,7 @@
 "lazy 프로퍼티 로딩을 이용가능하게 하려면, 당신의 특정 property 매핑들에 대해 "
 "<literal>lazy</literal> 속성을 설정하라:"
 
-#. Tag: programlisting
-#: performance.xml:569
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Document\">\n"
-"       <id name=\"id\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\" length=\"50\"/>\n"
-"    <property name=\"summary\" not-null=\"true\" length=\"200\" lazy=\"true"
-"\"/>\n"
-"    <property name=\"text\" not-null=\"true\" length=\"2000\" lazy=\"true\"/"
-">\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:571
 #, fuzzy, no-c-format
 msgid ""
 "Lazy property loading requires buildtime bytecode instrumentation. If your "
@@ -1131,33 +949,11 @@
 "시하고 즉각적인 페칭으로 후퇴할 것이다."
 
 #. Tag: para
-#: performance.xml:577
 #, no-c-format
 msgid "For bytecode instrumentation, use the following Ant task:"
 msgstr "bytecode 수단으로, 다음 Ant 태스크를 사용하라:"
 
-#. Tag: programlisting
-#: performance.xml:581
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"instrument\" depends=\"compile\">\n"
-"    <taskdef name=\"instrument\" classname=\"org.hibernate.tool.instrument."
-"InstrumentTask\">\n"
-"        <classpath path=\"${jar.path}\"/>\n"
-"        <classpath path=\"${classes.dir}\"/>\n"
-"        <classpath refid=\"lib.class.path\"/>\n"
-"    </taskdef>\n"
-"\n"
-"    <instrument verbose=\"true\">\n"
-"        <fileset dir=\"${testclasses.dir}/org/hibernate/auction/model\">\n"
-"            <include name=\"*.class\"/>\n"
-"        </fileset>\n"
-"    </instrument>\n"
-"</target>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:583
 #, fuzzy, no-c-format
 msgid ""
 "A different way of avoiding unnecessary column reads, at least for read-only "
@@ -1171,7 +967,6 @@
 "호되는 해결책이다."
 
 #. Tag: para
-#: performance.xml:590
 #, fuzzy, no-c-format
 msgid ""
 "You can force the usual eager fetching of properties using <literal>fetch "
@@ -1181,13 +976,11 @@
 "에 대한 통상의 eager 페칭을 강제시킬 수 있다."
 
 #. Tag: title
-#: performance.xml:600
 #, no-c-format
 msgid "The Second Level Cache"
 msgstr "두번째 레벨 캐시"
 
 #. Tag: para
-#: performance.xml:602
 #, fuzzy, no-c-format
 msgid ""
 "A Hibernate <literal>Session</literal> is a transaction-level cache of "
@@ -1206,7 +999,6 @@
 "른 어플리케이션에 의해 영속 저장소에 대해 행해진 변경들을 결코 알지 못한다."
 
 #. Tag: para
-#: performance.xml:610
 #, fuzzy, no-c-format
 msgid ""
 "You have the option to tell Hibernate which caching implementation to use by "
@@ -1240,43 +1032,36 @@
 "폴트 내장이 아니다."
 
 #. Tag: title
-#: performance.xml:621
 #, no-c-format
 msgid "Cache Providers"
 msgstr "캐시 프로바이더들"
 
 #. Tag: entry
-#: performance.xml:630 performance.xml:818
 #, no-c-format
 msgid "Cache"
 msgstr "캐시"
 
 #. Tag: entry
-#: performance.xml:631
 #, no-c-format
 msgid "Provider class"
 msgstr "프로바이더 클래스"
 
 #. Tag: entry
-#: performance.xml:632
 #, no-c-format
 msgid "Type"
 msgstr "타입"
 
 #. Tag: entry
-#: performance.xml:633
 #, no-c-format
 msgid "Cluster Safe"
 msgstr "클러스터 안전"
 
 #. Tag: entry
-#: performance.xml:634
 #, no-c-format
 msgid "Query Cache Supported"
 msgstr "질의 캐시 지원"
 
 #. Tag: entry
-#: performance.xml:639 performance.xml:827
 #, fuzzy, no-c-format
 msgid "Hashtable (not intended for production use)"
 msgstr ""
@@ -1285,139 +1070,144 @@
 "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "Hashtable (제품용으로 고안되지 않음)"
 
-#. Tag: literal
-#: performance.xml:640
-#, no-c-format
-msgid "org.hibernate.cache.HashtableCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.HashtableCacheProvider</literal>"
 msgstr "org.hibernate.cache.HashtableCacheProvider"
 
 #. Tag: entry
-#: performance.xml:641
 #, no-c-format
 msgid "memory"
 msgstr "memory"
 
 #. Tag: entry
-#: performance.xml:643 performance.xml:650 performance.xml:657
-#: performance.xml:828 performance.xml:829 performance.xml:830
-#: performance.xml:835 performance.xml:836 performance.xml:837
-#: performance.xml:842 performance.xml:843 performance.xml:844
-#: performance.xml:849 performance.xml:850 performance.xml:856
-#: performance.xml:859 performance.xml:863 performance.xml:866
-#, no-c-format
-msgid "<entry>yes</entry>"
+#, fuzzy, no-c-format
+msgid "yes"
 msgstr ""
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"yes\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"yes\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"yes\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"예\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"예\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"예\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"예\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"예\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"예\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"예\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"예\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"예\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"예\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"예\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"예\n"
+"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
+"예"
 
 #. Tag: entry
-#: performance.xml:646 performance.xml:834
 #, no-c-format
 msgid "EHCache"
 msgstr "EHCache"
 
-#. Tag: literal
-#: performance.xml:647
-#, no-c-format
-msgid "org.hibernate.cache.EhCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.EhCacheProvider</literal>"
 msgstr "org.hibernate.cache.EhCacheProvider"
 
 #. Tag: entry
-#: performance.xml:648 performance.xml:655
 #, no-c-format
 msgid "memory, disk"
 msgstr "memory, disk"
 
 #. Tag: entry
-#: performance.xml:653 performance.xml:841
 #, no-c-format
 msgid "OSCache"
 msgstr "OSCache"
 
-#. Tag: literal
-#: performance.xml:654
-#, no-c-format
-msgid "org.hibernate.cache.OSCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.OSCacheProvider</literal>"
 msgstr "org.hibernate.cache.OSCacheProvider"
 
 #. Tag: entry
-#: performance.xml:660 performance.xml:848
 #, no-c-format
 msgid "SwarmCache"
 msgstr "SwarmCache"
 
-#. Tag: literal
-#: performance.xml:661
-#, no-c-format
-msgid "org.hibernate.cache.SwarmCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.SwarmCacheProvider</literal>"
 msgstr "org.hibernate.cache.SwarmCacheProvider"
 
 #. Tag: entry
-#: performance.xml:662
 #, no-c-format
 msgid "clustered (ip multicast)"
 msgstr "clustered (ip multicast)"
 
 #. Tag: entry
-#: performance.xml:663
 #, no-c-format
 msgid "yes (clustered invalidation)"
 msgstr "yes (clustered invalidation)"
 
 #. Tag: entry
-#: performance.xml:667 performance.xml:855
 #, fuzzy, no-c-format
 msgid "JBoss Cache 1.x"
 msgstr "JBoss TreeCache"
 
-#. Tag: literal
-#: performance.xml:668
-#, no-c-format
-msgid "org.hibernate.cache.TreeCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.TreeCacheProvider</literal>"
 msgstr "org.hibernate.cache.TreeCacheProvider"
 
 #. Tag: entry
-#: performance.xml:669 performance.xml:676
 #, no-c-format
 msgid "clustered (ip multicast), transactional"
 msgstr "clustered (ip multicast), transactional"
 
 #. Tag: entry
-#: performance.xml:670
 #, no-c-format
 msgid "yes (replication)"
 msgstr "yes (replication)"
 
 #. Tag: entry
-#: performance.xml:671 performance.xml:678
 #, no-c-format
 msgid "yes (clock sync req.)"
 msgstr "yes (clock sync req.)"
 
 #. Tag: entry
-#: performance.xml:674 performance.xml:862
 #, fuzzy, no-c-format
 msgid "JBoss Cache 2"
 msgstr "JBoss TreeCache"
 
-#. Tag: literal
-#: performance.xml:675
+#. Tag: entry
 #, fuzzy, no-c-format
-msgid "org.hibernate.cache.jbc.JBossCacheRegionFactory"
+msgid "<literal>org.hibernate.cache.jbc.JBossCacheRegionFactory</literal>"
 msgstr "org.hibernate.cache.EhCacheProvider"
 
 #. Tag: entry
-#: performance.xml:677
 #, fuzzy, no-c-format
 msgid "yes (replication or invalidation)"
 msgstr "yes (clustered invalidation)"
 
 #. Tag: title
-#: performance.xml:685
 #, no-c-format
 msgid "Cache mappings"
 msgstr "Cache 매핑들"
 
 #. Tag: para
-#: performance.xml:687
 #, no-c-format
 msgid ""
 "The <literal>&lt;cache&gt;</literal> element of a class or collection "
@@ -1426,19 +1216,7 @@
 "클래스 또는 콜렉션 매핑의 <literal>&lt;cache&gt;</literal> 요소는 다음 형식"
 "을 갖는다:"
 
-#. Tag: programlisting
-#: performance.xml:698
-#, no-c-format
-msgid ""
-"<![CDATA[<cache \n"
-"    usage=\"transactional|read-write|nonstrict-read-write|read-only\"\n"
-"    region=\"RegionName\"\n"
-"    include=\"all|non-lazy\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:701
 #, no-c-format
 msgid ""
 "<literal>usage</literal> (required) specifies the caching strategy: "
@@ -1450,7 +1228,6 @@
 "literal> 또는 <literal>read-only</literal>"
 
 #. Tag: para
-#: performance.xml:710
 #, fuzzy, no-c-format
 msgid ""
 "<literal>region</literal> (optional: defaults to the class or collection "
@@ -1460,7 +1237,6 @@
 "second level 캐시 영역의 이름을 지정한다"
 
 #. Tag: para
-#: performance.xml:717
 #, fuzzy, no-c-format
 msgid ""
 "<literal>include</literal> (optional: defaults to <literal>all</literal>) "
@@ -1474,7 +1250,6 @@
 "다"
 
 #. Tag: para
-#: performance.xml:727
 #, fuzzy, no-c-format
 msgid ""
 "Alternatively, you can specify <literal>&lt;class-cache&gt;</literal> and "
@@ -1486,7 +1261,6 @@
 "</literal> 요소들을 지정할 수도 있다."
 
 #. Tag: para
-#: performance.xml:732
 #, no-c-format
 msgid ""
 "The <literal>usage</literal> attribute specifies a <emphasis>cache "
@@ -1496,13 +1270,11 @@
 "한다."
 
 #. Tag: title
-#: performance.xml:739
 #, no-c-format
 msgid "Strategy: read only"
 msgstr "방도: 읽기 전용"
 
 #. Tag: para
-#: performance.xml:741
 #, fuzzy, no-c-format
 msgid ""
 "If your application needs to read, but not modify, instances of a persistent "
@@ -1515,24 +1287,12 @@
 "다. 이것은 가장 간단한 최상의 퍼포먼스를 위한 방도이다. 그것은 클러스터 내 사"
 "용에는 완벽하게 안전하다."
 
-#. Tag: programlisting
-#: performance.xml:747
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Immutable\" mutable=\"false\">\n"
-"    <cache usage=\"read-only\"/>\n"
-"    ....\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:753
 #, no-c-format
 msgid "Strategy: read/write"
 msgstr "방도: 읽기/쓰기"
 
 #. Tag: para
-#: performance.xml:755
 #, fuzzy, no-c-format
 msgid ""
 "If the application needs to update data, a <literal>read-write</literal> "
@@ -1559,28 +1319,12 @@
 "실히 해야 한다. 미리 만들어진 캐시 프로바이더들은 그렇게 행하지 <emphasis>않"
 "는다</emphasis>."
 
-#. Tag: programlisting
-#: performance.xml:766
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Cat\" .... >\n"
-"    <cache usage=\"read-write\"/>\n"
-"    ....\n"
-"    <set name=\"kittens\" ... >\n"
-"        <cache usage=\"read-write\"/>\n"
-"        ....\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:771
 #, no-c-format
 msgid "Strategy: nonstrict read/write"
 msgstr "방도: 엄격하지 않은 읽기/쓰기"
 
 #. Tag: para
-#: performance.xml:773
 #, fuzzy, no-c-format
 msgid ""
 "If the application only occasionally needs to update data (i.e. if it is "
@@ -1602,13 +1346,11 @@
 "literal>가 호출될 때 트랜잭션이 완료되도록 확실히 해야 한다."
 
 #. Tag: title
-#: performance.xml:785
 #, no-c-format
 msgid "Strategy: transactional"
 msgstr "방도: transactional"
 
 #. Tag: para
-#: performance.xml:787
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>transactional</literal> cache strategy provides support for "
@@ -1622,13 +1364,11 @@
 "manager_lookup_class</literal>를 지정해야 한다."
 
 #. Tag: title
-#: performance.xml:796
 #, fuzzy, no-c-format
 msgid "Cache-provider/concurrency-strategy compatibility"
 msgstr "캐시 동시성 방도 지원"
 
 #. Tag: para
-#: performance.xml:799
 #, fuzzy, no-c-format
 msgid ""
 "None of the cache providers support all of the cache concurrency strategies."
@@ -1637,7 +1377,6 @@
 "음 테이블은 어느 프로바이더들이 어느 동시성 방도들과 호환되는지를 보여준다."
 
 #. Tag: para
-#: performance.xml:804
 #, fuzzy, no-c-format
 msgid ""
 "The following table shows which providers are compatible with which "
@@ -1647,43 +1386,36 @@
 "음 테이블은 어느 프로바이더들이 어느 동시성 방도들과 호환되는지를 보여준다."
 
 #. Tag: title
-#: performance.xml:809
 #, no-c-format
 msgid "Cache Concurrency Strategy Support"
 msgstr "캐시 동시성 방도 지원"
 
 #. Tag: entry
-#: performance.xml:819
 #, no-c-format
 msgid "read-only"
 msgstr "읽기 전용"
 
 #. Tag: entry
-#: performance.xml:820
 #, no-c-format
 msgid "nonstrict-read-write"
 msgstr "엄격하지 않은 읽기-쓰기"
 
 #. Tag: entry
-#: performance.xml:821
 #, no-c-format
 msgid "read-write"
 msgstr "읽기-쓰기"
 
 #. Tag: entry
-#: performance.xml:822
 #, no-c-format
 msgid "transactional"
 msgstr "transactional"
 
 #. Tag: title
-#: performance.xml:877
 #, no-c-format
 msgid "Managing the caches"
 msgstr "캐시들을 관리하기"
 
 #. Tag: para
-#: performance.xml:879
 #, fuzzy, no-c-format
 msgid ""
 "Whenever you pass an object to <literal>save()</literal>, <literal>update()</"
@@ -1701,7 +1433,6 @@
 "다."
 
 #. Tag: para
-#: performance.xml:886
 #, fuzzy, no-c-format
 msgid ""
 "When <literal>flush()</literal> is subsequently called, the state of that "
@@ -1717,21 +1448,7 @@
 "을 경우, <literal>evict()</literal> 메소드는 first-level 캐시로부터 그 객체"
 "와 그것의 콜렉션들을 제거하는데 사용될 수 있다."
 
-#. Tag: programlisting
-#: performance.xml:894
-#, no-c-format
-msgid ""
-"<![CDATA[ScrollableResult cats = sess.createQuery(\"from Cat as cat\").scroll"
-"(); //a huge result set\n"
-"while ( cats.next() ) {\n"
-"    Cat cat = (Cat) cats.get(0);\n"
-"    doSomethingWithACat(cat);\n"
-"    sess.evict(cat);\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:896
 #, no-c-format
 msgid ""
 "The <literal>Session</literal> also provides a <literal>contains()</literal> "
@@ -1741,7 +1458,6 @@
 "하는데 <literal>contains()</literal> 메소드를 제공한다."
 
 #. Tag: para
-#: performance.xml:901
 #, fuzzy, no-c-format
 msgid ""
 "To evict all objects from the session cache, call <literal>Session.clear()</"
@@ -1751,7 +1467,6 @@
 "clear()</literal>를 호출하라."
 
 #. Tag: para
-#: performance.xml:905
 #, no-c-format
 msgid ""
 "For the second-level cache, there are methods defined on "
@@ -1762,20 +1477,7 @@
 "전체 콜렉션 role의 캐시된 상태를 퇴거시키는 <literal>SessionFactory</"
 "literal> 상에 정의된 메소드들이 존재한다."
 
-#. Tag: programlisting
-#: performance.xml:911
-#, no-c-format
-msgid ""
-"<![CDATA[sessionFactory.evict(Cat.class, catId); //evict a particular Cat\n"
-"sessionFactory.evict(Cat.class);  //evict all Cats\n"
-"sessionFactory.evictCollection(\"Cat.kittens\", catId); //evict a particular "
-"collection of kittens\n"
-"sessionFactory.evictCollection(\"Cat.kittens\"); //evict all kitten "
-"collections]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:913
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>CacheMode</literal> controls how a particular session interacts "
@@ -1785,7 +1487,6 @@
 "용하는지를 제어한다"
 
 #. Tag: para
-#: performance.xml:920
 #, fuzzy, no-c-format
 msgid ""
 "<literal>CacheMode.NORMAL</literal>: will read items from and write items to "
@@ -1795,7 +1496,6 @@
 "들이고 second-level 캐시로 아이템들을 기록한다"
 
 #. Tag: para
-#: performance.xml:925
 #, fuzzy, no-c-format
 msgid ""
 "<literal>CacheMode.GET</literal>: will read items from the second-level "
@@ -1805,7 +1505,6 @@
 "이지만, 데이터를 업데이트할 때를 제외하면 second-level 캐시로 기록하지 않는다"
 
 #. Tag: para
-#: performance.xml:931
 #, fuzzy, no-c-format
 msgid ""
 "<literal>CacheMode.PUT</literal>: will write items to the second-level "
@@ -1815,7 +1514,6 @@
 "만, second-level 캐시로부터 읽어들이지 않는다"
 
 #. Tag: para
-#: performance.xml:937
 #, fuzzy, no-c-format
 msgid ""
 "<literal>CacheMode.REFRESH</literal>: will write items to the second-level "
@@ -1829,7 +1527,6 @@
 "cache.use_minimal_puts</literal>의 효과를 무시한다"
 
 #. Tag: para
-#: performance.xml:945
 #, no-c-format
 msgid ""
 "To browse the contents of a second-level or query cache region, use the "
@@ -1838,17 +1535,7 @@
 "second-level 캐시 또는 질의 캐시 영역의 내용물을 브라우징하려면 "
 "<literal>Statistics</literal> API를 사용하라:"
 
-#. Tag: programlisting
-#: performance.xml:950
-#, no-c-format
-msgid ""
-"<![CDATA[Map cacheEntries = sessionFactory.getStatistics()\n"
-"        .getSecondLevelCacheStatistics(regionName)\n"
-"        .getEntries();]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:952
 #, fuzzy, no-c-format
 msgid ""
 "You will need to enable statistics and, optionally, force Hibernate to keep "
@@ -1858,66 +1545,79 @@
 "을 보다 인간에게 이해가능한 형식으로 유지시키도록 강제시키는 것이 필요할 것이"
 "다:"
 
-#. Tag: programlisting
-#: performance.xml:957
-#, no-c-format
-msgid ""
-"<![CDATA[hibernate.generate_statistics true\n"
-"hibernate.cache.use_structured_entries true]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:962
 #, no-c-format
 msgid "The Query Cache"
 msgstr "질의 캐시"
 
 #. Tag: para
-#: performance.xml:964
 #, fuzzy, no-c-format
 msgid ""
 "Query result sets can also be cached. This is only useful for queries that "
-"are run frequently with the same parameters. You will first need to enable "
-"the query cache:"
+"are run frequently with the same parameters."
 msgstr ""
 "질의 결과 셋들이 또한 캐시될 수도 있다. 이것은 동일한 파라미터들을 가지고 자"
 "주 실행되는 질의들에만 유용하다. 질의 캐시를 사용하기 위해 당신은 먼저 그것"
 "을 이용 가능하도록 해야 한다:"
 
-#. Tag: programlisting
-#: performance.xml:969
+#. Tag: title
 #, no-c-format
-msgid "<![CDATA[hibernate.cache.use_query_cache true]]>"
+msgid "Enabling query caching"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:971
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"This setting creates two new cache regions: one holding cached query result "
-"sets (<literal>org.hibernate.cache.StandardQueryCache</literal>), the other "
-"holding timestamps of the most recent updates to queryable tables "
-"(<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). Note that "
-"the query cache does not cache the state of the actual entities in the "
-"result set; it caches only identifier values and results of value type. The "
-"query cache should always be used in conjunction with the second-level cache."
+"Caching of query results introduces some overhead in terms of your "
+"applications normal transactional processing. For example, if you cache "
+"results of a query against Person Hibernate will need to keep track of when "
+"those results should be invalidated because changes have been committed "
+"against Person. That, coupled with the fact that most applications simply "
+"gain no benefit from caching query results, leads Hibernate to disable "
+"caching of query results by default. To use query caching, you will first "
+"need to enable the query cache:"
 msgstr ""
-"이 설정은 두 개의 새로운 캐시 영역들 - 캐시된 질의 결과 셋들을 보관하는 것 "
-"(<literal>org.hibernate.cache.StandardQueryCache</literal>), 질의 가능한 테이"
-"블들에 대한 가장 최신 업데이트들에 대한 timestamp들을 보관하는 다른 것 "
-"(<literal>org.hibernate.cache.UpdateTimestampsCache</literal>)-의 생성을 강제"
-"한다 . 질의 캐시는 결과 셋 내에 실제 엔티티들의 상태를 캐시시키지 않음을 노트"
-"하라; 그것은 오직 식별자 값들과 값 타입의 결과들 만을 캐시시킨다. 따라서 질"
-"의 캐시는 항상 second-level 캐시와 함께 사용되어야 한다."
 
 #. Tag: para
-#: performance.xml:981
+#, no-c-format
+msgid "This setting creates two new cache regions:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<classname>org.hibernate.cache.StandardQueryCache</classname>, holding the "
+"cached query results"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<classname>org.hibernate.cache.UpdateTimestampsCache</classname>, holding "
+"timestamps of the most recent updates to queryable tables. These are used to "
+"validate the results as they are served from the query cache."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"If you configure your underlying cache implementation to use expiry or "
+"timeouts is is very important that the cache timeout of the underlying cache "
+"region for the UpdateTimestampsCache be set to a higher value than the "
+"timeouts of any of the query caches. In fact, we recommend that the the "
+"UpdateTimestampsCache region not be configured for expiry at all. Note, in "
+"particular, that an LRU cache expiry policy is never appropriate."
+msgstr ""
+
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
-"Most queries do not benefit from caching, so by default, queries are not "
-"cached. To enable caching, call <literal>Query.setCacheable(true)</literal>. "
-"This call allows the query to look for existing cache results or add its "
-"results to the cache when it is executed."
+"As mentioned above, most queries do not benefit from caching or their "
+"results. So by default, individual queries are not cached even after "
+"enabling query caching. To enable results caching for a particular query, "
+"call <literal>org.hibernate.Query.setCacheable(true)</literal>. This call "
+"allows the query to look for existing cache results or add its results to "
+"the cache when it is executed."
 msgstr ""
 "대부분의 질의들은 캐싱으로부터 이점이 없기에, 디폴트로 질의들은 캐시되지 않는"
 "다. 캐싱을 이용 가능하도록 하려면, <literal>Query.setCacheable(true)</"
@@ -1925,8 +1625,22 @@
 "거나 질의가 실행될 때 그것의 결과들을 캐시에 추가하는 것을 허용해준다."
 
 #. Tag: para
-#: performance.xml:988
+#, no-c-format
+msgid ""
+"The query cache does not cache the state of the actual entities in the "
+"cache; it caches only identifier values and results of value type. For this "
+"reaso, the query cache should always be used in conjunction with the second-"
+"level cache for those entities expected to be cached as part of a query "
+"result cache (just as with collection caching)."
+msgstr ""
+
+#. Tag: title
 #, fuzzy, no-c-format
+msgid "Query cache regions"
+msgstr "질의 캐시 지원"
+
+#. Tag: para
+#, fuzzy, no-c-format
 msgid ""
 "If you require fine-grained control over query cache expiration policies, "
 "you can specify a named cache region for a particular query by calling "
@@ -1936,30 +1650,18 @@
 "은 <literal>Query.setCacheRegion()</literal>을 호출함으로써 특별한 질의에 대"
 "해 명명되니 캐시 영역을 지정할 수도 있다."
 
-#. Tag: programlisting
-#: performance.xml:994
-#, no-c-format
-msgid ""
-"<![CDATA[List blogs = sess.createQuery(\"from Blog blog where blog.blogger "
-"= :blogger\")\n"
-"    .setEntity(\"blogger\", blogger)\n"
-"    .setMaxResults(15)\n"
-"    .setCacheable(true)\n"
-"    .setCacheRegion(\"frontpages\")\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:996
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"If the query should force a refresh of its query cache region, you should "
-"call <literal>Query.setCacheMode(CacheMode.REFRESH)</literal>. This is "
-"particularly useful in cases where underlying data may have been updated via "
-"a separate process (i.e., not modified through Hibernate) and allows the "
-"application to selectively refresh particular query result sets. This is a "
-"more efficient alternative to eviction of a query cache region via "
-"<literal>SessionFactory.evictQueries()</literal>."
+"If you want to force the query cache to refresh one of its regions "
+"(disregard any cached results it finds there) you can use <literal>org."
+"hibernate.Query.setCacheMode(CacheMode.REFRESH)</literal>. In conjunction "
+"with the region you have defined for the given query, Hibernate will "
+"selectively force the results cached in that particular region to be "
+"refreshed. This is particularly useful in cases where underlying data may "
+"have been updated via a separate process and is a far more efficient "
+"alternative to bulk eviction of the region via <literal>org.hibernate."
+"SessionFactory.evictQueries()</literal>."
 msgstr ""
 "만일 질의가 그것의 질의 캐시 영역의 갱신을 강제시켜야 하는 경우에, 당신은 "
 "<literal>Query.setCacheMode(CacheMode.REFRESH)</literal>를 호출해야 한다. 이"
@@ -1970,13 +1672,11 @@
 "시키는 보다 효과적인 대안이다."
 
 #. Tag: title
-#: performance.xml:1008
 #, no-c-format
 msgid "Understanding Collection performance"
 msgstr "콜렉션 퍼포먼스 이해하기"
 
 #. Tag: para
-#: performance.xml:1010
 #, no-c-format
 msgid ""
 "In the previous sections we have covered collections and their applications. "
@@ -1985,37 +1685,31 @@
 msgstr ""
 
 #. Tag: title
-#: performance.xml:1017
 #, no-c-format
 msgid "Taxonomy"
 msgstr "분류"
 
 #. Tag: para
-#: performance.xml:1019
 #, no-c-format
 msgid "Hibernate defines three basic kinds of collections:"
 msgstr "Hibernate는 세 가지 기본적인 종류의 콜렉션들을 정의한다:"
 
 #. Tag: para
-#: performance.xml:1023
 #, no-c-format
 msgid "collections of values"
 msgstr "값들을 가진 콜렉션들"
 
 #. Tag: para
-#: performance.xml:1026
 #, fuzzy, no-c-format
 msgid "one-to-many associations"
 msgstr "one to many 연관들"
 
 #. Tag: para
-#: performance.xml:1029
 #, fuzzy, no-c-format
 msgid "many-to-many associations"
 msgstr "many to many 연관들"
 
 #. Tag: para
-#: performance.xml:1033
 #, no-c-format
 msgid ""
 "This classification distinguishes the various table and foreign key "
@@ -2032,25 +1726,21 @@
 "한다. 이것은 다음 분류를 제안한다:"
 
 #. Tag: para
-#: performance.xml:1044
 #, no-c-format
 msgid "indexed collections"
 msgstr "인덱싱 된 콜렉션들"
 
 #. Tag: para
-#: performance.xml:1047
 #, no-c-format
 msgid "sets"
 msgstr "set들"
 
 #. Tag: para
-#: performance.xml:1050
 #, no-c-format
 msgid "bags"
 msgstr "bag들"
 
 #. Tag: para
-#: performance.xml:1054
 #, fuzzy, no-c-format
 msgid ""
 "All indexed collections (maps, lists, and arrays) have a primary key "
@@ -2066,7 +1756,6 @@
 "고 특정 행은 효율적으로 위치지워질 수 있다."
 
 #. Tag: para
-#: performance.xml:1062
 #, fuzzy, no-c-format
 msgid ""
 "Sets have a primary key consisting of <literal>&lt;key&gt;</literal> and "
@@ -2090,7 +1779,6 @@
 "로 선언해야 한다.)"
 
 #. Tag: para
-#: performance.xml:1073
 #, fuzzy, no-c-format
 msgid ""
 "<literal>&lt;idbag&gt;</literal> mappings define a surrogate key, so they "
@@ -2100,7 +1788,6 @@
 "상 업데이트에 매우 효율적이다. 사실, 그것들은 최상의 경우이다."
 
 #. Tag: para
-#: performance.xml:1078
 #, fuzzy, no-c-format
 msgid ""
 "Bags are the worst case since they permit duplicate element values and, as "
@@ -2116,7 +1803,6 @@
 "문제를 해결한다. 이것은 매우 비효율적이다."
 
 #. Tag: para
-#: performance.xml:1086
 #, fuzzy, no-c-format
 msgid ""
 "For a one-to-many association, the \"primary key\" may not be the physical "
@@ -2130,14 +1816,12 @@
 "영한다.)"
 
 #. Tag: title
-#: performance.xml:1096
 #, no-c-format
 msgid ""
 "Lists, maps, idbags and sets are the most efficient collections to update"
 msgstr "List, map, idbag, set들은 update에 가장 효율적인 콜렉션들이다"
 
 #. Tag: para
-#: performance.xml:1098
 #, fuzzy, no-c-format
 msgid ""
 "From the discussion above, it should be clear that indexed collections and "
@@ -2148,7 +1832,6 @@
 "고 업데이트함에 있어 가장 효율적인 오퍼레이션을 허용해준다."
 
 #. Tag: para
-#: performance.xml:1104
 #, fuzzy, no-c-format
 msgid ""
 "There is, arguably, one more advantage that indexed collections have over "
@@ -2168,7 +1851,6 @@
 "다."
 
 #. Tag: para
-#: performance.xml:1113
 #, fuzzy, no-c-format
 msgid ""
 "After observing that arrays cannot be lazy, you can conclude that lists, "
@@ -2184,7 +1866,6 @@
 "한 것이기 때문이다."
 
 #. Tag: para
-#: performance.xml:1121
 #, fuzzy, no-c-format
 msgid ""
 "However, in well-designed Hibernate domain models, most collections are in "
@@ -2199,13 +1880,11 @@
 "고, 따라서 콜렉션 업데이트 퍼포먼스에 대한 검토들은 단순히 적용되지 않는다."
 
 #. Tag: title
-#: performance.xml:1131
 #, no-c-format
 msgid "Bags and lists are the most efficient inverse collections"
 msgstr "Bag들과 list들은 가장 효율적인 inverse 콜렉션들이다"
 
 #. Tag: para
-#: performance.xml:1133
 #, fuzzy, no-c-format
 msgid ""
 "There is a particular case, however, in which bags, and also lists, are much "
@@ -2226,25 +1905,12 @@
 "상 bag 또는 <literal>List</literal>에 대해 true를 반환해야하기 때문이다. 이것"
 "은 훨씬 다음 공통적인 코드를 더 빠르게 만들 수 있다."
 
-#. Tag: programlisting
-#: performance.xml:1143
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = (Parent) sess.load(Parent.class, id);\n"
-"Child c = new Child();\n"
-"c.setParent(p);\n"
-"p.getChildren().add(c);  //no need to fetch the collection!\n"
-"sess.flush();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:1148
 #, no-c-format
 msgid "One shot delete"
 msgstr "원 샷 delete"
 
 #. Tag: para
-#: performance.xml:1150
 #, fuzzy, no-c-format
 msgid ""
 "Deleting collection elements one by one can sometimes be extremely "
@@ -2259,7 +1925,6 @@
 "을 내릴 것이고 우리는 모두 행했다!"
 
 #. Tag: para
-#: performance.xml:1157
 #, fuzzy, no-c-format
 msgid ""
 "Suppose you added a single element to a collection of size twenty and then "
@@ -2273,7 +1938,6 @@
 "령 내릴 것이다. 이것은 확실히 마음에 든다."
 
 #. Tag: para
-#: performance.xml:1163
 #, no-c-format
 msgid ""
 "However, suppose that we remove eighteen elements, leaving two and then add "
@@ -2284,13 +1948,11 @@
 "다."
 
 #. Tag: para
-#: performance.xml:1170
 #, no-c-format
 msgid "delete eighteen rows one by one and then insert three rows"
 msgstr "하나씩 열 여덟 개의 행들을 삭제한 다음에 세 개의 행들을 삽입시킨다"
 
 #. Tag: para
-#: performance.xml:1173
 #, fuzzy, no-c-format
 msgid ""
 "remove the whole collection in one SQL <literal>DELETE</literal> and insert "
@@ -2300,7 +1962,6 @@
 "의 현재 요소들을 (하나씩) insert 시킨다"
 
 #. Tag: para
-#: performance.xml:1178
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate cannot know that the second option is probably quicker. It would "
@@ -2313,7 +1974,6 @@
 "다.)"
 
 #. Tag: para
-#: performance.xml:1184
 #, fuzzy, no-c-format
 msgid ""
 "Fortunately, you can force this behavior (i.e. the second strategy) at any "
@@ -2325,7 +1985,6 @@
 "시킬 수 있다. 이것은 시간이 흐름에 따라 매우 유용하고 강력해질 수 있다."
 
 #. Tag: para
-#: performance.xml:1190
 #, fuzzy, no-c-format
 msgid ""
 "One-shot-delete does not apply to collections mapped <literal>inverse=\"true"
@@ -2335,13 +1994,11 @@
 "매핑된 콜렉션들에 적용되지 않는다."
 
 #. Tag: title
-#: performance.xml:1199
 #, no-c-format
 msgid "Monitoring performance"
 msgstr "퍼포먼스 모니터링하기"
 
 #. Tag: para
-#: performance.xml:1201
 #, no-c-format
 msgid ""
 "Optimization is not much use without monitoring and access to performance "
@@ -2355,13 +2012,11 @@
 "이용 가능하다."
 
 #. Tag: title
-#: performance.xml:1208
 #, no-c-format
 msgid "Monitoring a SessionFactory"
 msgstr "SessionFactory 모니터링 하기"
 
 #. Tag: para
-#: performance.xml:1210
 #, no-c-format
 msgid ""
 "You can access <literal>SessionFactory</literal> metrics in two ways. Your "
@@ -2374,7 +2029,6 @@
 "레이 하는 것이다."
 
 #. Tag: para
-#: performance.xml:1216
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate can also use JMX to publish metrics if you enable the "
@@ -2387,38 +2041,7 @@
 "당신의<literal>SessionFactory</literal>에 대해 한 개의 MBean 또는 팩토리 당 "
 "한 개를 이용 가능하게 할 수 있다. 최소한의 구성 예제들은 다음 코드를 보라:"
 
-#. Tag: programlisting
-#: performance.xml:1223
-#, no-c-format
-msgid ""
-"<![CDATA[// MBean service registration for a specific SessionFactory\n"
-"Hashtable tb = new Hashtable();\n"
-"tb.put(\"type\", \"statistics\");\n"
-"tb.put(\"sessionFactory\", \"myFinancialApp\");\n"
-"ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-"\n"
-"StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-"stats.setSessionFactory(sessionFactory); // Bind the stats to a "
-"SessionFactory\n"
-"server.registerMBean(stats, on); // Register the Mbean on the server]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: performance.xml:1226
-#, no-c-format
-msgid ""
-"<![CDATA[// MBean service registration for all SessionFactory's\n"
-"Hashtable tb = new Hashtable();\n"
-"tb.put(\"type\", \"statistics\");\n"
-"tb.put(\"sessionFactory\", \"all\");\n"
-"ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-"\n"
-"StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-"server.registerMBean(stats, on); // Register the MBean on the server]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:1228
 #, fuzzy, no-c-format
 msgid ""
 "You can activate and deactivate the monitoring for a "
@@ -2428,7 +2051,6 @@
 "수 있다"
 
 #. Tag: para
-#: performance.xml:1233
 #, no-c-format
 msgid ""
 "at configuration time, set <literal>hibernate.generate_statistics</literal> "
@@ -2438,7 +2060,6 @@
 "<literal>false</literal>"
 
 #. Tag: para
-#: performance.xml:1240
 #, no-c-format
 msgid ""
 "at runtime: <literal>sf.getStatistics().setStatisticsEnabled(true)</literal> "
@@ -2448,7 +2069,6 @@
 "는 <literal>hibernateStatsBean.setStatisticsEnabled(true)</literal>"
 
 #. Tag: para
-#: performance.xml:1247
 #, fuzzy, no-c-format
 msgid ""
 "Statistics can be reset programmatically using the <literal>clear()</"
@@ -2460,13 +2080,11 @@
 "를 사용하여 logger(info 레벨)에게 전송될 수 있다."
 
 #. Tag: title
-#: performance.xml:1256
 #, no-c-format
 msgid "Metrics"
 msgstr "Metrics"
 
 #. Tag: para
-#: performance.xml:1258
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate provides a number of metrics, from basic information to more "
@@ -2480,7 +2098,6 @@
 "다:"
 
 #. Tag: para
-#: performance.xml:1265
 #, no-c-format
 msgid ""
 "Metrics related to the general <literal>Session</literal> usage, such as "
@@ -2490,7 +2107,6 @@
 "<literal>Session</literal> 사용에 관련된 metrics."
 
 #. Tag: para
-#: performance.xml:1271
 #, fuzzy, no-c-format
 msgid ""
 "Metrics related to the entities, collections, queries, and caches as a whole "
@@ -2500,7 +2116,6 @@
 "metrics로 알려져 있음),"
 
 #. Tag: para
-#: performance.xml:1277
 #, no-c-format
 msgid ""
 "Detailed metrics related to a particular entity, collection, query or cache "
@@ -2508,7 +2123,6 @@
 msgstr "특정한 엔티티, 콜렉션, 질의 또는 캐시 영역에 관련된 상세 metrics."
 
 #. Tag: para
-#: performance.xml:1284
 #, fuzzy, no-c-format
 msgid ""
 "For example, you can check the cache hit, miss, and put ratio of entities, "
@@ -2524,7 +2138,6 @@
 "있다."
 
 #. Tag: para
-#: performance.xml:1291
 #, fuzzy, no-c-format
 msgid ""
 "Simple getters are used to access the global metrics (i.e. not tied to a "
@@ -2547,30 +2160,7 @@
 "<literal>QueryStatistics</literal>를 참조하라. 다음 코드는 간단한 예제를 보여"
 "준다:"
 
-#. Tag: programlisting
-#: performance.xml:1301
-#, no-c-format
-msgid ""
-"<![CDATA[Statistics stats = HibernateUtil.sessionFactory.getStatistics();\n"
-"\n"
-"double queryCacheHitCount  = stats.getQueryCacheHitCount();\n"
-"double queryCacheMissCount = stats.getQueryCacheMissCount();\n"
-"double queryCacheHitRatio =\n"
-"  queryCacheHitCount / (queryCacheHitCount + queryCacheMissCount);\n"
-"\n"
-"log.info(\"Query Hit ratio:\" + queryCacheHitRatio);\n"
-"\n"
-"EntityStatistics entityStats =\n"
-"  stats.getEntityStatistics( Cat.class.getName() );\n"
-"long changes =\n"
-"        entityStats.getInsertCount()\n"
-"        + entityStats.getUpdateCount()\n"
-"        + entityStats.getDeleteCount();\n"
-"log.info(Cat.class.getName() + \" changed \" + changes + \"times\"  );]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:1303
 #, fuzzy, no-c-format
 msgid ""
 "You can work on all entities, collections, queries and region caches, by "
@@ -2585,7 +2175,26 @@
 "<literal>getEntityNames()</literal>, <literal>getCollectionRoleNames()</"
 "literal>, 그리고 <literal>getSecondLevelCacheRegionNames()</literal>."
 
+#, fuzzy
 #~ msgid ""
+#~ "This setting creates two new cache regions: one holding cached query "
+#~ "result sets (<literal>org.hibernate.cache.StandardQueryCache</literal>), "
+#~ "the other holding timestamps of the most recent updates to queryable "
+#~ "tables (<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). "
+#~ "Note that the query cache does not cache the state of the actual entities "
+#~ "in the result set; it caches only identifier values and results of value "
+#~ "type. The query cache should always be used in conjunction with the "
+#~ "second-level cache."
+#~ msgstr ""
+#~ "이 설정은 두 개의 새로운 캐시 영역들 - 캐시된 질의 결과 셋들을 보관하는 "
+#~ "것 (<literal>org.hibernate.cache.StandardQueryCache</literal>), 질의 가능"
+#~ "한 테이블들에 대한 가장 최신 업데이트들에 대한 timestamp들을 보관하는 다"
+#~ "른 것 (<literal>org.hibernate.cache.UpdateTimestampsCache</literal>)-의 생"
+#~ "성을 강제한다 . 질의 캐시는 결과 셋 내에 실제 엔티티들의 상태를 캐시시키"
+#~ "지 않음을 노트하라; 그것은 오직 식별자 값들과 값 타입의 결과들 만을 캐시시"
+#~ "킨다. 따라서 질의 캐시는 항상 second-level 캐시와 함께 사용되어야 한다."
+
+#~ msgid ""
 #~ "where <literal>CatImpl</literal> implements the interface <literal>Cat</"
 #~ "literal> and <literal>DomesticCatImpl</literal> implements the interface "
 #~ "<literal>DomesticCat</literal>. Then proxies for instances of "
@@ -2621,39 +2230,3 @@
 #~ "한다. 두 번째 경우에 우리는 JNDI 이름을 사용하기 전에 세션 팩토리가 보관하"
 #~ "고 있는 JNDI 이름을 부여해야 한다. <literal>hibernateStatsBean."
 #~ "setSessionFactoryJNDIName(\"my/JNDI/Name\")</literal>을 사용하라."
-
-#, fuzzy
-#~ msgid "yes"
-#~ msgstr ""
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "yes\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "yes\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "yes\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "예\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "예\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "예\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "예\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "예\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "예\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "예\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "예\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "예\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "예\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "예\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "예\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "예"

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/persistent_classes.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/persistent_classes.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/persistent_classes.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,13 +11,11 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: persistent_classes.xml:29
 #, no-c-format
 msgid "Persistent Classes"
 msgstr "영속 클래스들"
 
 #. Tag: para
-#: persistent_classes.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "Persistent classes are classes in an application that implement the entities "
@@ -32,7 +30,6 @@
 "스턴스는 transient 또는 detached 상태일 수 있다."
 
 #. Tag: para
-#: persistent_classes.xml:38
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate works best if these classes follow some simple rules, also known "
@@ -49,13 +46,11 @@
 "기."
 
 #. Tag: title
-#: persistent_classes.xml:47
 #, no-c-format
 msgid "A simple POJO example"
 msgstr "간단한 POJO 예제"
 
 #. Tag: para
-#: persistent_classes.xml:49
 #, fuzzy, no-c-format
 msgid ""
 "Most Java applications require a persistent class representing felines. For "
@@ -64,92 +59,7 @@
 "대부분의 자바 어플리케이션들은 고양이과들을 표현하는 영속 클래스를 필요로 한"
 "다."
 
-#. Tag: programlisting
-#: persistent_classes.xml:53
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"import java.util.Date;\n"
-"\n"
-"public class Cat {\n"
-"    private Long id; // identifier\n"
-"\n"
-"    private Date birthdate;\n"
-"    private Color color;\n"
-"    private char sex;\n"
-"    private float weight;\n"
-"    private int litterId;\n"
-"\n"
-"    private Cat mother;\n"
-"    private Set kittens = new HashSet();\n"
-"\n"
-"    private void setId(Long id) {\n"
-"        this.id=id;\n"
-"    }\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"\n"
-"    void setBirthdate(Date date) {\n"
-"        birthdate = date;\n"
-"    }\n"
-"    public Date getBirthdate() {\n"
-"        return birthdate;\n"
-"    }\n"
-"\n"
-"    void setWeight(float weight) {\n"
-"        this.weight = weight;\n"
-"    }\n"
-"    public float getWeight() {\n"
-"        return weight;\n"
-"    }\n"
-"\n"
-"    public Color getColor() {\n"
-"        return color;\n"
-"    }\n"
-"    void setColor(Color color) {\n"
-"        this.color = color;\n"
-"    }\n"
-"\n"
-"    void setSex(char sex) {\n"
-"        this.sex=sex;\n"
-"    }\n"
-"    public char getSex() {\n"
-"        return sex;\n"
-"    }\n"
-"\n"
-"    void setLitterId(int id) {\n"
-"        this.litterId = id;\n"
-"    }\n"
-"    public int getLitterId() {\n"
-"        return litterId;\n"
-"    }\n"
-"\n"
-"    void setMother(Cat mother) {\n"
-"        this.mother = mother;\n"
-"    }\n"
-"    public Cat getMother() {\n"
-"        return mother;\n"
-"    }\n"
-"    void setKittens(Set kittens) {\n"
-"        this.kittens = kittens;\n"
-"    }\n"
-"    public Set getKittens() {\n"
-"        return kittens;\n"
-"    }\n"
-"    \n"
-"    // addKitten not needed by Hibernate\n"
-"    public void addKitten(Cat kitten) {\n"
-"            kitten.setMother(this);\n"
-"        kitten.setLitterId( kittens.size() ); \n"
-"        kittens.add(kitten);\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:55
 #, no-c-format
 msgid ""
 "The four main rules of persistent classes are explored in more detail in the "
@@ -157,13 +67,11 @@
 msgstr ""
 
 #. Tag: title
-#: persistent_classes.xml:61
 #, no-c-format
 msgid "Implement a no-argument constructor"
 msgstr "아규먼트 없는 생성자를 구현하라"
 
 #. Tag: para
-#: persistent_classes.xml:63
 #, fuzzy, no-c-format
 msgid ""
 "<literal>Cat</literal> has a no-argument constructor. All persistent classes "
@@ -181,13 +89,11 @@
 "다."
 
 #. Tag: title
-#: persistent_classes.xml:73
 #, no-c-format
 msgid "Provide an identifier property (optional)"
 msgstr "identifier 프로퍼티를 제공하라(옵션)"
 
 #. Tag: para
-#: persistent_classes.xml:75
 #, fuzzy, no-c-format
 msgid ""
 "<literal>Cat</literal> has a property called <literal>id</literal>. This "
@@ -207,7 +113,6 @@
 "의 클래스를 사용할 수도 있다 - 나중에 composite 식별자들에 대한 절을 보라)"
 
 #. Tag: para
-#: persistent_classes.xml:84
 #, no-c-format
 msgid ""
 "The identifier property is strictly optional. You can leave them off and let "
@@ -219,7 +124,6 @@
 "우리는 이것을 권장하지 않는다."
 
 #. Tag: para
-#: persistent_classes.xml:89
 #, fuzzy, no-c-format
 msgid ""
 "In fact, some functionality is available only to classes that declare an "
@@ -229,29 +133,25 @@
 "능하다:"
 
 #. Tag: para
-#: persistent_classes.xml:96
 #, fuzzy, no-c-format
 msgid ""
 "Transitive reattachment for detached objects (cascade update or cascade "
-"merge) - see"
+"merge) - see <xref linkend=\"objectstate-transitive\" />"
 msgstr ""
 "detached 객체들에 대한 Transitive reattachment(cascade update 또는 cascade "
 "merge) - <xref linkend=\"objectstate-transitive\"/>"
 
-#. Tag: literal
-#: persistent_classes.xml:103
-#, no-c-format
-msgid "Session.saveOrUpdate()"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>Session.saveOrUpdate()</literal>"
 msgstr "Session.saveOrUpdate()"
 
-#. Tag: literal
-#: persistent_classes.xml:108
-#, no-c-format
-msgid "Session.merge()"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>Session.merge()</literal>"
 msgstr "Session.merge()"
 
 #. Tag: para
-#: persistent_classes.xml:113
 #, fuzzy, no-c-format
 msgid ""
 "We recommend that you declare consistently-named identifier properties on "
@@ -262,13 +162,11 @@
 "primitive)을 사용할 것을 권장한다."
 
 #. Tag: title
-#: persistent_classes.xml:120
 #, no-c-format
 msgid "Prefer non-final classes (optional)"
 msgstr "final이 아닌 클래스들을 선호하라(옵션)"
 
 #. Tag: para
-#: persistent_classes.xml:121
 #, no-c-format
 msgid ""
 "A central feature of Hibernate, <emphasis>proxies</emphasis>, depends upon "
@@ -280,7 +178,6 @@
 "클래스들에 의존한다."
 
 #. Tag: para
-#: persistent_classes.xml:126
 #, fuzzy, no-c-format
 msgid ""
 "You can persist <literal>final</literal> classes that do not implement an "
@@ -294,7 +191,6 @@
 "옵션들을 제한시킬 것이다."
 
 #. Tag: para
-#: persistent_classes.xml:131
 #, no-c-format
 msgid ""
 "You should also avoid declaring <literal>public final</literal> methods on "
@@ -308,13 +204,11 @@
 "literal>를 설정함으로써 명시적으로 프락싱을 사용 불가능하도록 해야 한다."
 
 #. Tag: title
-#: persistent_classes.xml:139
 #, no-c-format
 msgid "Declare accessors and mutators for persistent fields (optional)"
 msgstr "영속 필드들을 위한 accessor들과 mutator들을 선언하라(옵션)"
 
 #. Tag: para
-#: persistent_classes.xml:141
 #, fuzzy, no-c-format
 msgid ""
 "<literal>Cat</literal> declares accessor methods for all its persistent "
@@ -334,7 +228,6 @@
 "정 프로퍼티에 대한 직접적인 필드 접근으로 전환할 수도 있다."
 
 #. Tag: para
-#: persistent_classes.xml:151
 #, no-c-format
 msgid ""
 "Properties need <emphasis>not</emphasis> be declared public - Hibernate can "
@@ -346,13 +239,11 @@
 "literal> get/set 쌍을 가진 프로퍼티를 영속화 시킬 수 있다."
 
 #. Tag: title
-#: persistent_classes.xml:162
 #, no-c-format
 msgid "Implementing inheritance"
 msgstr "상속 구현하기"
 
 #. Tag: para
-#: persistent_classes.xml:164
 #, fuzzy, no-c-format
 msgid ""
 "A subclass must also observe the first and second rules. It inherits its "
@@ -362,33 +253,13 @@
 "퍼클래스 <literal>Cat</literal>으로부터 그것의 identifier 프로퍼티를 상속받는"
 "다."
 
-#. Tag: programlisting
-#: persistent_classes.xml:169
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"public class DomesticCat extends Cat {\n"
-"        private String name;\n"
-"\n"
-"        public String getName() {\n"
-"                return name;\n"
-"        }\n"
-"        protected void setName(String name) {\n"
-"                this.name=name;\n"
-"        }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: persistent_classes.xml:173
 #, no-c-format
 msgid ""
 "Implementing <literal>equals()</literal> and <literal>hashCode()</literal>"
 msgstr "<literal>equals()</literal>와 <literal>hashCode()</literal> 구현하기"
 
 #. Tag: para
-#: persistent_classes.xml:175
 #, fuzzy, no-c-format
 msgid ""
 "You have to override the <literal>equals()</literal> and <literal>hashCode()"
@@ -398,7 +269,6 @@
 "<literal>hashCode()</literal> 메소드들을 오버라이드 시켜야 한다."
 
 #. Tag: para
-#: persistent_classes.xml:181
 #, fuzzy, no-c-format
 msgid ""
 "intend to put instances of persistent classes in a <literal>Set</literal> "
@@ -409,13 +279,11 @@
 "도하고 (many-valued 연관들에 대해 권장되는 방법) <emphasis>그리고</emphasis>"
 
 #. Tag: para
-#: persistent_classes.xml:188
 #, no-c-format
 msgid "intend to use reattachment of detached instances"
 msgstr "detached 인스턴스들의 reattachment(재첨부)를 사용하고자 의도하는"
 
 #. Tag: para
-#: persistent_classes.xml:194
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate guarantees equivalence of persistent identity (database row) and "
@@ -431,7 +299,6 @@
 "literal>를 구현해야 한다."
 
 #. Tag: para
-#: persistent_classes.xml:202
 #, fuzzy, no-c-format
 msgid ""
 "The most obvious way is to implement <literal>equals()</literal>/"
@@ -465,7 +332,6 @@
 "체 identity와 equality에 관한 통상의 자바 의미론임을 노트하라."
 
 #. Tag: para
-#: persistent_classes.xml:216
 #, fuzzy, no-c-format
 msgid ""
 "It is recommended that you implement <literal>equals()</literal> and "
@@ -481,41 +347,11 @@
 "서 우리의 인스턴스를 식별하게 될 키(<emphasis>natural</emphasis> 후보 키)를 "
 "형성하는 프로퍼티들만을 비교한다는 점을 의미한다 :"
 
-#. Tag: programlisting
-#: persistent_classes.xml:224
-#, no-c-format
-msgid ""
-"<![CDATA[public class Cat {\n"
-"\n"
-"    ...\n"
-"    public boolean equals(Object other) {\n"
-"        if (this == other) return true;\n"
-"        if ( !(other instanceof Cat) ) return false;\n"
-"\n"
-"        final Cat cat = (Cat) other;\n"
-"\n"
-"        if ( !cat.getLitterId().equals( getLitterId() ) ) return false;\n"
-"        if ( !cat.getMother().equals( getMother() ) ) return false;\n"
-"\n"
-"        return true;\n"
-"    }\n"
-"\n"
-"    public int hashCode() {\n"
-"        int result;\n"
-"        result = getMother().hashCode();\n"
-"        result = 29 * result + getLitterId();\n"
-"        return result;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:226
 #, 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 "
+"candidate (see <xref linkend=\"transactions-basics-identity\" />). Immutable "
 "or unique properties are usually good candidates for a business key."
 msgstr ""
 "하나의 비지니스 키는 데이터베이스 프라이머리 키 후보 만큼 견고하지 않아야 한"
@@ -524,29 +360,25 @@
 "보들이다."
 
 #. Tag: title
-#: persistent_classes.xml:236
 #, no-c-format
 msgid "Dynamic models"
 msgstr "동적인 모형들"
 
 #. Tag: title
-#: persistent_classes.xml:239
 #, no-c-format
 msgid "Note"
 msgstr ""
 
-#. Tag: emphasis
-#: persistent_classes.xml:241
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
-"The following features are currently considered experimental and may change "
-"in the near future."
+"<emphasis>The following features are currently considered experimental and "
+"may change in the near future.</emphasis>"
 msgstr ""
 "다음 특징들은 현재 실험적으로 고려되고 있으며 장래에는 변경될 수 있음을 노트"
 "하라."
 
 #. Tag: para
-#: persistent_classes.xml:246
 #, fuzzy, no-c-format
 msgid ""
 "Persistent entities do not necessarily have to be represented as POJO "
@@ -562,13 +394,12 @@
 "작성하지 않고, 오직 매핑 파일들 만을 작성한다."
 
 #. Tag: para
-#: persistent_classes.xml:254
 #, 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>SessionFactory</"
 "literal> using the <literal>default_entity_mode</literal> configuration "
-"option (see <xref linkend=\"configuration-optional-properties\"/>)."
+"option (see <xref linkend=\"configuration-optional-properties\" />)."
 msgstr ""
 "디폴트로, Hibernate는 통산의 POJO 모드로 동작한다. 당신은 "
 "<literal>default_entity_mode</literal> 구성 옵션을 사용하여 특별한 "
@@ -576,7 +407,6 @@
 "있다 (<xref linkend=\"configuration-optional-properties\"/>을 보라)."
 
 #. Tag: para
-#: persistent_classes.xml:261
 #, fuzzy, no-c-format
 msgid ""
 "The following examples demonstrate the representation using <literal>Map</"
@@ -587,47 +417,7 @@
 "파일에서, <literal>entity-name</literal>은 클래스 이름 대신에(또는 클래스 이"
 "름에 덧붙여) 선언되어야 한다:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:267
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class entity-name=\"Customer\">\n"
-"\n"
-"        <id name=\"id\"\n"
-"            type=\"long\"\n"
-"            column=\"ID\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"\n"
-"        <property name=\"name\"\n"
-"            column=\"NAME\"\n"
-"            type=\"string\"/>\n"
-"\n"
-"        <property name=\"address\"\n"
-"            column=\"ADDRESS\"\n"
-"            type=\"string\"/>\n"
-"\n"
-"        <many-to-one name=\"organization\"\n"
-"            column=\"ORGANIZATION_ID\"\n"
-"            class=\"Organization\"/>\n"
-"\n"
-"        <bag name=\"orders\"\n"
-"            inverse=\"true\"\n"
-"            lazy=\"false\"\n"
-"            cascade=\"all\">\n"
-"            <key column=\"CUSTOMER_ID\"/>\n"
-"            <one-to-many class=\"Order\"/>\n"
-"        </bag>\n"
-"\n"
-"    </class>\n"
-"    \n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:269
 #, fuzzy, no-c-format
 msgid ""
 "Even though associations are declared using target class names, the target "
@@ -637,7 +427,6 @@
 "들의 대상(target) 타입은 또한 POJO가 아닌 동적인 엔티티일 수 있음을 노트하라."
 
 #. Tag: para
-#: persistent_classes.xml:276
 #, fuzzy, no-c-format
 msgid ""
 "After setting the default entity mode to <literal>dynamic-map</literal> for "
@@ -648,35 +437,7 @@
 "<literal>dynamic-map</literal>으로 설정한 후에, 우리는 <literal>Map</literal>"
 "들을 가진 <literal>Map</literal>들에 대해 실행 시에 작업할 수 있다:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:282
-#, no-c-format
-msgid ""
-"<![CDATA[Session s = openSession();\n"
-"Transaction tx = s.beginTransaction();\n"
-"Session s = openSession();\n"
-"\n"
-"// Create a customer\n"
-"Map david = new HashMap();\n"
-"david.put(\"name\", \"David\");\n"
-"\n"
-"// Create an organization\n"
-"Map foobar = new HashMap();\n"
-"foobar.put(\"name\", \"Foobar Inc.\");\n"
-"\n"
-"// Link both\n"
-"david.put(\"organization\", foobar);\n"
-"\n"
-"// Save both\n"
-"s.save(\"Customer\", david);\n"
-"s.save(\"Organization\", foobar);\n"
-"\n"
-"tx.commit();\n"
-"s.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:284
 #, fuzzy, no-c-format
 msgid ""
 "One of the main advantages of dynamic mapping is quick turnaround time for "
@@ -693,7 +454,6 @@
 "규화 되고 소리가 울려 퍼질 수 있다."
 
 #. Tag: para
-#: persistent_classes.xml:292
 #, no-c-format
 msgid ""
 "Entity representation modes can also be set on a per <literal>Session</"
@@ -702,26 +462,7 @@
 "엔티티 표현 모드들은 또한 하나의 단위 <literal>Session</literal> 기준에 대해 "
 "설정될 수 있다:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:297
-#, no-c-format
-msgid ""
-"<![CDATA[Session dynamicSession = pojoSession.getSession(EntityMode.MAP);\n"
-"\n"
-"// Create a customer\n"
-"Map david = new HashMap();\n"
-"david.put(\"name\", \"David\");\n"
-"dynamicSession.save(\"Customer\", david);\n"
-"...\n"
-"dynamicSession.flush();\n"
-"dynamicSession.close()\n"
-"...\n"
-"// Continue on pojoSession\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:300
 #, fuzzy, no-c-format
 msgid ""
 "Please note that the call to <literal>getSession()</literal> using an "
@@ -743,23 +484,20 @@
 "다."
 
 #. Tag: para
-#: persistent_classes.xml:310
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "More information about the XML representation capabilities can be found in "
-"<xref linkend=\"xml\"/>."
+"<xref linkend=\"xml\" />."
 msgstr ""
 "XML 표현 가용성들에 대한 추가 정보는 <xref linkend=\"xml\"/>에서 찾을 수 있"
 "다."
 
 #. Tag: title
-#: persistent_classes.xml:318
 #, no-c-format
 msgid "Tuplizers"
 msgstr "Tuplizer들"
 
 #. Tag: para
-#: persistent_classes.xml:320
 #, fuzzy, no-c-format
 msgid ""
 "<literal>org.hibernate.tuple.Tuplizer</literal>, and its sub-interfaces, are "
@@ -789,7 +527,6 @@
 "한다."
 
 #. Tag: para
-#: persistent_classes.xml:330
 #, no-c-format
 msgid ""
 "There are two high-level types of Tuplizers, represented by the <literal>org."
@@ -801,7 +538,6 @@
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:338
 #, fuzzy, no-c-format
 msgid ""
 "Users can also plug in their own tuplizers. Perhaps you require that a "
@@ -821,55 +557,12 @@
 "들 정의들은 그것들이 관리할 수단인 엔티티 매핑 또는 컴포넌트 매핑에 첨부된"
 "다. 우리의 고객 엔티티에 대한 예제로 되돌아가면:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:347
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    <class entity-name=\"Customer\">\n"
-"        <!--\n"
-"            Override the dynamic-map entity-mode\n"
-"            tuplizer for the customer entity\n"
-"        -->\n"
-"        <tuplizer entity-mode=\"dynamic-map\"\n"
-"                class=\"CustomMapTuplizerImpl\"/>\n"
-"\n"
-"        <id name=\"id\" type=\"long\" column=\"ID\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"\n"
-"        <!-- other properties -->\n"
-"        ...\n"
-"    </class>\n"
-"</hibernate-mapping>\n"
-"\n"
-"\n"
-"public class CustomMapTuplizerImpl\n"
-"        extends org.hibernate.tuple.entity.DynamicMapEntityTuplizer {\n"
-"    // override the buildInstantiator() method to plug in our custom map...\n"
-"    protected final Instantiator buildInstantiator(\n"
-"            org.hibernate.mapping.PersistentClass mappingInfo) {\n"
-"        return new CustomMapInstantiator( mappingInfo );\n"
-"    }\n"
-"\n"
-"    private static final class CustomMapInstantiator\n"
-"            extends org.hibernate.tuple.DynamicMapInstantitor {\n"
-"        // override the generateMap() method to return our custom map...\n"
-"            protected final Map generateMap() {\n"
-"                    return new CustomMap();\n"
-"            }\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: persistent_classes.xml:354
 #, no-c-format
 msgid "EntityNameResolvers"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:356
 #, no-c-format
 msgid ""
 "The <interfacename>org.hibernate.EntityNameResolver</interfacename> "
@@ -887,140 +580,7 @@
 "package for illustration."
 msgstr ""
 
-#. Tag: programlisting
-#: persistent_classes.xml:368
-#, no-c-format
-msgid ""
-"/**\n"
-" * A very trivial JDK Proxy InvocationHandler implementation where we proxy "
-"an interface as\n"
-" * the domain model and simply store persistent state in an internal Map.  "
-"This is an extremely\n"
-" * trivial example meant only for illustration.\n"
-" */\n"
-"public final class DataProxyHandler implements InvocationHandler {\n"
-"        private String entityName;\n"
-"        private HashMap data = new HashMap();\n"
-"\n"
-"        public DataProxyHandler(String entityName, Serializable id) {\n"
-"                this.entityName = entityName;\n"
-"                data.put( \"Id\", id );\n"
-"        }\n"
-"\n"
-"        public Object invoke(Object proxy, Method method, Object[] args) "
-"throws Throwable {\n"
-"                String methodName = method.getName();\n"
-"                if ( methodName.startsWith( \"set\" ) ) {\n"
-"                        String propertyName = methodName.substring( 3 );\n"
-"                        data.put( propertyName, args[0] );\n"
-"                }\n"
-"                else if ( methodName.startsWith( \"get\" ) ) {\n"
-"                        String propertyName = methodName.substring( 3 );\n"
-"                        return data.get( propertyName );\n"
-"                }\n"
-"                else if ( \"toString\".equals( methodName ) ) {\n"
-"                        return entityName + \"#\" + data.get( \"Id\" );\n"
-"                }\n"
-"                else if ( \"hashCode\".equals( methodName ) ) {\n"
-"                        return new Integer( this.hashCode() );\n"
-"                }\n"
-"                return null;\n"
-"        }\n"
-"\n"
-"        public String getEntityName() {\n"
-"                return entityName;\n"
-"        }\n"
-"\n"
-"        public HashMap getData() {\n"
-"                return data;\n"
-"        }\n"
-"}\n"
-"\n"
-"/**\n"
-" *\n"
-" */\n"
-"public class ProxyHelper {\n"
-"    public static String extractEntityName(Object object) {\n"
-"        // Our custom java.lang.reflect.Proxy instances actually bundle\n"
-"        // their appropriate entity name, so we simply extract it from "
-"there\n"
-"        // if this represents one of our proxies; otherwise, we return null\n"
-"        if ( Proxy.isProxyClass( object.getClass() ) ) {\n"
-"            InvocationHandler handler = Proxy.getInvocationHandler"
-"( object );\n"
-"            if ( DataProxyHandler.class.isAssignableFrom( handler.getClass"
-"() ) ) {\n"
-"                DataProxyHandler myHandler = ( DataProxyHandler ) handler;\n"
-"                return myHandler.getEntityName();\n"
-"            }\n"
-"        }\n"
-"        return null;\n"
-"    }\n"
-"\n"
-"    // various other utility methods ....\n"
-"\n"
-"}\n"
-"\n"
-"/**\n"
-" * The EntityNameResolver implementation.\n"
-" * IMPL NOTE : An EntityNameResolver really defines a strategy for how "
-"entity names should be\n"
-" * resolved.  Since this particular impl can handle resolution for all of "
-"our entities we want to\n"
-" * take advantage of the fact that SessionFactoryImpl keeps these in a Set "
-"so that we only ever\n"
-" * have one instance registered.  Why?  Well, when it comes time to resolve "
-"an entity name,\n"
-" * Hibernate must iterate over all the registered resolvers.  So keeping "
-"that number down\n"
-" * helps that process be as speedy as possible.  Hence the equals and "
-"hashCode impls\n"
-" */\n"
-"public class MyEntityNameResolver implements EntityNameResolver {\n"
-"    public static final MyEntityNameResolver INSTANCE = new "
-"MyEntityNameResolver();\n"
-"\n"
-"    public String resolveEntityName(Object entity) {\n"
-"        return ProxyHelper.extractEntityName( entity );\n"
-"    }\n"
-"\n"
-"    public boolean equals(Object obj) {\n"
-"        return getClass().equals( obj.getClass() );\n"
-"    }\n"
-"\n"
-"    public int hashCode() {\n"
-"        return getClass().hashCode();\n"
-"    }\n"
-"}\n"
-"\n"
-"public class MyEntityTuplizer extends PojoEntityTuplizer {\n"
-"        public MyEntityTuplizer(EntityMetamodel entityMetamodel, "
-"PersistentClass mappedEntity) {\n"
-"                super( entityMetamodel, mappedEntity );\n"
-"        }\n"
-"\n"
-"        public EntityNameResolver[] getEntityNameResolvers() {\n"
-"                return new EntityNameResolver[] { MyEntityNameResolver."
-"INSTANCE };\n"
-"        }\n"
-"\n"
-"    public String determineConcreteSubclassEntityName(Object entityInstance, "
-"SessionFactoryImplementor factory) {\n"
-"        String entityName = ProxyHelper.extractEntityName"
-"( entityInstance );\n"
-"        if ( entityName == null ) {\n"
-"            entityName = super.determineConcreteSubclassEntityName"
-"( entityInstance, factory );\n"
-"        }\n"
-"        return entityName;\n"
-"    }\n"
-"\n"
-"    ...\n"
-"}"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:370
 #, no-c-format
 msgid ""
 "In order to register an <interfacename>org.hibernate.EntityNameResolver</"
@@ -1028,7 +588,6 @@
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:374
 #, no-c-format
 msgid ""
 "Implement a custom <link linkend=\"persistent-classes-tuplizers\">Tuplizer</"
@@ -1037,7 +596,6 @@
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:380
 #, no-c-format
 msgid ""
 "Register it with the <classname>org.hibernate.impl.SessionFactoryImpl</"

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/portability.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/portability.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/portability.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -5,7 +5,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:22\n"
 "PO-Revision-Date: 2009-07-14 19:56+0000\n"
 "Last-Translator: Automatically generated\n"
 "Language-Team: none\n"
@@ -14,19 +14,16 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: portability.xml:26
 #, no-c-format
 msgid "Database Portability Considerations"
 msgstr ""
 
 #. Tag: title
-#: portability.xml:29
 #, no-c-format
 msgid "Portability Basics"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:31
 #, no-c-format
 msgid ""
 "One of the selling points of Hibernate (and really Object/Relational Mapping "
@@ -40,13 +37,11 @@
 msgstr ""
 
 #. Tag: title
-#: portability.xml:42
 #, no-c-format
 msgid "Dialect"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:44
 #, no-c-format
 msgid ""
 "The first line of portability for Hibernate is the dialect, which is a "
@@ -60,13 +55,11 @@
 msgstr ""
 
 #. Tag: title
-#: portability.xml:55
 #, no-c-format
 msgid "Dialect resolution"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:57
 #, no-c-format
 msgid ""
 "Originally, Hibernate would always require that users specify which dialect "
@@ -77,7 +70,6 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:64
 #, no-c-format
 msgid ""
 "Starting with version 3.2, Hibernate introduced the notion of automatically "
@@ -89,15 +81,14 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:72
 #, no-c-format
 msgid ""
 "Starting with version 3.3, Hibernate has a fare more powerful way to "
 "automatically determine which dialect to should be used by relying on a "
 "series of delegates which implement the <interfacename>org.hibernate.dialect."
 "resolver.DialectResolver</interfacename> which defines only a single method:"
-"<programlisting><![CDATA[public Dialect resolveDialect(DatabaseMetaData "
-"metaData) throws JDBCConnectionException]]></programlisting>. The basic "
+"<programlisting role=\"JAVA\">public Dialect resolveDialect(DatabaseMetaData "
+"metaData) throws JDBCConnectionException</programlisting>. The basic "
 "contract here is that if the resolver 'understands' the given database "
 "metadata then it returns the corresponding Dialect; if not it returns null "
 "and the process continues to the next resolver. The signature also "
@@ -110,7 +101,6 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:85
 #, no-c-format
 msgid ""
 "The cool part about these resolvers is that users can also register their "
@@ -126,13 +116,11 @@
 msgstr ""
 
 #. Tag: title
-#: portability.xml:98
 #, no-c-format
 msgid "Identifier generation"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:100
 #, no-c-format
 msgid ""
 "When considering portability between databases, another important decision "
@@ -151,38 +139,63 @@
 "reference entities within a persistence context it must then issue the "
 "insert immediately when the users requests the entitiy be associated with "
 "the session (like via save() e.g.) regardless of current transactional "
-"semantics. <note> <para> Hibernate was changed slightly once the implication "
-"of this was better understood so that the insert is delayed in cases where "
-"that is feasible. </para> </note> The underlying issue is that the actual "
-"semanctics of the application itself changes in these cases."
+"semantics."
 msgstr ""
 
 #. Tag: para
-#: portability.xml:125
 #, no-c-format
 msgid ""
+"Hibernate was changed slightly once the implication of this was better "
+"understood so that the insert is delayed in cases where that is feasible."
+msgstr ""
+
+#. Tag: note
+#, no-c-format
+msgid ""
+"The underlying issue is that the actual semanctics of the application itself "
+"changes in these cases."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
 "Starting with version 3.2.3, Hibernate comes with a set of <ulink url="
 "\"http://in.relation.to/2082.lace\">enhanced</ulink> identifier generators "
-"targetting portability in a much different way. <note> <para> There are "
-"specifically 2 bundled <emphasis>enhanced</emphasis>generators: "
-"<itemizedlist> <listitem> <para> <classname>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</classname> </para> </listitem> <listitem> <para> "
-"<classname>org.hibernate.id.enhanced.TableGenerator</classname> </para> </"
-"listitem> </itemizedlist> </para> </note> The idea behind these generators "
-"is to port the actual semantics of the identifer value generation to the "
-"different databases. For example, the <classname>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</classname> mimics the behavior of a sequence on "
-"databases which do not support sequences by using a table."
+"targetting portability in a much different way."
 msgstr ""
 
+#. Tag: para
+#, no-c-format
+msgid ""
+"There are specifically 2 bundled <emphasis>enhanced</emphasis>generators:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname>"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "<classname>org.hibernate.id.enhanced.TableGenerator</classname>"
+msgstr ""
+
+#. Tag: note
+#, no-c-format
+msgid ""
+"The idea behind these generators is to port the actual semantics of the "
+"identifer value generation to the different databases. For example, the "
+"<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname> "
+"mimics the behavior of a sequence on databases which do not support "
+"sequences by using a table."
+msgstr ""
+
 #. Tag: title
-#: portability.xml:154
 #, no-c-format
 msgid "Database functions"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:157
 #, no-c-format
 msgid ""
 "This is an area in Hibernate in need of improvement. In terms of portability "
@@ -191,7 +204,6 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:164
 #, no-c-format
 msgid ""
 "SQL functions can be referenced in many ways by users. However, not all "
@@ -202,7 +214,6 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:170
 #, no-c-format
 msgid ""
 "Technically this function registration is handled through the <classname>org."
@@ -213,7 +224,6 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:177
 #, no-c-format
 msgid ""
 "It is sort of implemented such that users can programatically register "
@@ -222,13 +232,11 @@
 msgstr ""
 
 #. Tag: title
-#: portability.xml:187
 #, no-c-format
 msgid "Type mappings"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:189
 #, no-c-format
 msgid "This section scheduled for completion at a later date..."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/preface.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/preface.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/preface.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,13 +11,11 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: preface.xml:29
 #, no-c-format
 msgid "Preface"
 msgstr "머리말"
 
 #. Tag: para
-#: preface.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "Working with object-oriented software and a relational database can be "
@@ -34,7 +32,6 @@
 "하는 기술을 언급한다."
 
 #. Tag: para
-#: preface.xml:39
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate not only takes care of the mapping from Java classes to database "
@@ -48,7 +45,6 @@
 "시간을 현저하게 단축시켜줄 수 있다."
 
 #. Tag: para
-#: preface.xml:46
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate's goal is to relieve the developer from 95 percent of common data "
@@ -69,7 +65,6 @@
 "객체들의 그래프로 결과 셋을 변환하는 공통된 태스크를 도와줄 것이다."
 
 #. Tag: para
-#: preface.xml:56
 #, no-c-format
 msgid ""
 "If you are new to Hibernate and Object/Relational Mapping or even Java, "
@@ -79,10 +74,9 @@
 "면, 다음 단계들을 따르기 바란다:"
 
 #. Tag: para
-#: preface.xml:63
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"Read <xref linkend=\"tutorial\"/> for a tutorial with step-by-step "
+"Read <xref linkend=\"tutorial\" /> for a tutorial with step-by-step "
 "instructions. The source code for the tutorial is included in the "
 "distribution in the <literal>doc/reference/tutorial/</literal> directory."
 msgstr ""
@@ -91,17 +85,15 @@
 "tutorial/</literal> 디렉토리에 포함되어 있다."
 
 #. Tag: para
-#: preface.xml:71
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"Read <xref linkend=\"architecture\"/> to understand the environments where "
+"Read <xref linkend=\"architecture\" /> to understand the environments where "
 "Hibernate can be used."
 msgstr ""
 "Hibernate가 사용될 수 있는 환경을 이해려면 <xref linkend=\"architecture\"/> "
 "를 읽어라."
 
 #. Tag: para
-#: preface.xml:77
 #, fuzzy, no-c-format
 msgid ""
 "View the <literal>eg/</literal> directory in the Hibernate distribution. It "
@@ -120,15 +112,13 @@
 "이프 하라."
 
 #. Tag: para
-#: preface.xml:88
 #, fuzzy, no-c-format
 msgid ""
 "Use this reference documentation as your primary source of information. "
 "Consider reading <biblioref linkend=\"biblio-JPwH\"></biblioref> if you need "
 "more help with application design, or if you prefer a step-by-step tutorial. "
-"Also visit <ulink url=\"http://caveatemptor.hibernate.org\"></ulink> and "
-"download the example application from <biblioref linkend=\"biblio-JPwH\"></"
-"biblioref>."
+"Also visit <ulink url=\"http://caveatemptor.hibernate.org\" /> and download "
+"the example application from <biblioref linkend=\"biblio-JPwH\"></biblioref>."
 msgstr ""
 "당신의 주된 정보의 소스로서 이 참조 문서를 사용하라. 만일 어플리케이션 설계"
 "에 대해 더 많은 도움을 필요로 하거나 당신이 단계적인 튜토리얼을 선호한다면 "
@@ -137,13 +127,11 @@
 "여 Java Persistence with Hibernate용 예제 어플리케이션을 다운로드 하라."
 
 #. Tag: para
-#: preface.xml:98
 #, no-c-format
 msgid "FAQs are answered on the Hibernate website."
 msgstr "FAQ들은 Hibernate 웹 사이트 상에 답변되어 있다."
 
 #. Tag: para
-#: preface.xml:103
 #, fuzzy, no-c-format
 msgid ""
 "Links to third party demos, examples, and tutorials are maintained on the "
@@ -153,7 +141,6 @@
 "있다."
 
 #. Tag: para
-#: preface.xml:109
 #, no-c-format
 msgid ""
 "The Community Area on the Hibernate website is a good resource for design "
@@ -164,7 +151,6 @@
 "(Tomcat, JBoss AS, Struts, EJB 등.)에 관한 좋은 리소스이다."
 
 #. Tag: para
-#: preface.xml:117
 #, fuzzy, no-c-format
 msgid ""
 "If you have questions, use the user forum linked on the Hibernate website. "
@@ -180,7 +166,6 @@
 "에 접촉하라."
 
 #. Tag: para
-#: preface.xml:125
 #, no-c-format
 msgid ""
 "Commercial development support, production support, and training for "

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/query_criteria.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/query_criteria.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/query_criteria.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,25 +11,21 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: query_criteria.xml:29
 #, no-c-format
 msgid "Criteria Queries"
 msgstr "Criteria 질의들"
 
 #. Tag: para
-#: query_criteria.xml:31
 #, no-c-format
 msgid "Hibernate features an intuitive, extensible criteria query API."
 msgstr "Hibernate는 직관적인, 확장 가능한 criteria query API를 특징 짓는다."
 
 #. Tag: title
-#: query_criteria.xml:36
 #, no-c-format
 msgid "Creating a <literal>Criteria</literal> instance"
 msgstr "<literal>Criteria</literal> 인스턴스 생성하기"
 
 #. Tag: para
-#: query_criteria.xml:38
 #, no-c-format
 msgid ""
 "The interface <literal>org.hibernate.Criteria</literal> represents a query "
@@ -40,23 +36,12 @@
 "한 질의를 표현한다. <literal>Session</literal>은 <literal>Criteria</literal> "
 "인스턴스들에 대한 팩토리이다."
 
-#. Tag: programlisting
-#: query_criteria.xml:44
-#, no-c-format
-msgid ""
-"<![CDATA[Criteria crit = sess.createCriteria(Cat.class);\n"
-"crit.setMaxResults(50);\n"
-"List cats = crit.list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:49
 #, no-c-format
 msgid "Narrowing the result set"
 msgstr "결과 셋 제한하기"
 
 #. Tag: para
-#: query_criteria.xml:51
 #, no-c-format
 msgid ""
 "An individual query criterion is an instance of the interface <literal>org."
@@ -69,53 +54,12 @@
 "literal> 클래스는 어떤 미리 만들어진 <literal>Criterion</literal> 타입들을 얻"
 "는 팩토리 메소드들을 정의한다."
 
-#. Tag: programlisting
-#: query_criteria.xml:59
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .add( Restrictions.between(\"weight\", minWeight, maxWeight) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:61
 #, fuzzy, no-c-format
 msgid "Restrictions can be grouped logically."
 msgstr "제한들은 논리적으로 그룹지워질 수도 있다."
 
-#. Tag: programlisting
-#: query_criteria.xml:65
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .add( Restrictions.or(\n"
-"        Restrictions.eq( \"age\", new Integer(0) ),\n"
-"        Restrictions.isNull(\"age\")\n"
-"    ) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:67
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.in( \"name\", new String[] { \"Fritz\", \"Izi\", \"Pk"
-"\" } ) )\n"
-"    .add( Restrictions.disjunction()\n"
-"        .add( Restrictions.isNull(\"age\") )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(0) ) )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(1) ) )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(2) ) )\n"
-"    ) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:69
 #, fuzzy, no-c-format
 msgid ""
 "There are a range of built-in criterion types (<literal>Restrictions</"
@@ -126,18 +70,7 @@
 "의 영역이 꽤 존재하지만, 특히 유용한 것은 당신으로 하여금 SQL을 직접 지정하도"
 "록 해준다."
 
-#. Tag: programlisting
-#: query_criteria.xml:74
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.sqlRestriction(\"lower({alias}.name) like lower(?)\", "
-"\"Fritz%\", Hibernate.STRING) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:76
 #, no-c-format
 msgid ""
 "The <literal>{alias}</literal> placeholder with be replaced by the row alias "
@@ -147,7 +80,6 @@
 "placeholder."
 
 #. Tag: para
-#: query_criteria.xml:81
 #, fuzzy, no-c-format
 msgid ""
 "You can also obtain a criterion from a <literal>Property</literal> instance. "
@@ -158,32 +90,12 @@
 "터 그것을 얻는 것이다. 당신은 <literal>Property.forName()</literal>을 호출하"
 "여 <literal>Property</literal>를 생성시킬 수 있다."
 
-#. Tag: programlisting
-#: query_criteria.xml:87
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"Property age = Property.forName(\"age\");\n"
-"List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.disjunction()\n"
-"        .add( age.isNull() )\n"
-"        .add( age.eq( new Integer(0) ) )\n"
-"        .add( age.eq( new Integer(1) ) )\n"
-"        .add( age.eq( new Integer(2) ) )\n"
-"    ) )\n"
-"    .add( Property.forName(\"name\").in( new String[] { \"Fritz\", \"Izi\", "
-"\"Pk\" } ) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:92
 #, no-c-format
 msgid "Ordering the results"
 msgstr "결과들을 순서지우기(ordering)"
 
 #. Tag: para
-#: query_criteria.xml:94
 #, fuzzy, no-c-format
 msgid ""
 "You can order the results using <literal>org.hibernate.criterion.Order</"
@@ -192,57 +104,19 @@
 "당신은 <literal>org.hibernate.criterion.Order</literal>를 사용하여 결과들을 "
 "순서(ordering)지울 수 있다."
 
-#. Tag: programlisting
-#: query_criteria.xml:98
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"F%\")\n"
-"    .addOrder( Order.asc(\"name\") )\n"
-"    .addOrder( Order.desc(\"age\") )\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:100
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Property.forName(\"name\").like(\"F%\") )\n"
-"    .addOrder( Property.forName(\"name\").asc() )\n"
-"    .addOrder( Property.forName(\"age\").desc() )\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:105
 #, no-c-format
 msgid "Associations"
 msgstr "연관들"
 
 #. Tag: para
-#: query_criteria.xml:107
 #, no-c-format
 msgid ""
 "By navigating associations using <literal>createCriteria()</literal> you can "
 "specify constraints upon related entities:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:112
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"F%\") )\n"
-"    .createCriteria(\"kittens\")\n"
-"        .add( Restrictions.like(\"name\", \"F%\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:114
 #, fuzzy, no-c-format
 msgid ""
 "The second <literal>createCriteria()</literal> returns a new instance of "
@@ -254,25 +128,12 @@
 "을 참조한다는 점을 노트하라."
 
 #. Tag: para
-#: query_criteria.xml:120
 #, fuzzy, no-c-format
 msgid ""
 "There is also an alternate form that is useful in certain circumstances:"
 msgstr "다음 대체 형식은 어떤 환경들에서 유용하다."
 
-#. Tag: programlisting
-#: query_criteria.xml:124
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .createAlias(\"kittens\", \"kt\")\n"
-"    .createAlias(\"mate\", \"mt\")\n"
-"    .add( Restrictions.eqProperty(\"kt.name\", \"mt.name\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:126
 #, no-c-format
 msgid ""
 "(<literal>createAlias()</literal> does not create a new instance of "
@@ -282,7 +143,6 @@
 "턴스를 생성시키지 않는다.)"
 
 #. Tag: para
-#: query_criteria.xml:131
 #, fuzzy, no-c-format
 msgid ""
 "The kittens collections held by the <literal>Cat</literal> instances "
@@ -296,31 +156,47 @@
 "들을 단지 검색하고자 원할 경우, 당신은 하나의 <literal>ResultTransformer</"
 "literal>를 사용해야 한다."
 
-#. Tag: programlisting
-#: query_criteria.xml:138
+#. Tag: para
 #, no-c-format
+msgid "Additionally you may manipulate the result set using a left outer join:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .createCriteria(\"kittens\", \"kt\")\n"
-"        .add( Restrictions.eq(\"name\", \"F%\") )\n"
-"    .setResultTransformer(Criteria.ALIAS_TO_ENTITY_MAP)\n"
-"    .list();\n"
-"Iterator iter = cats.iterator();\n"
-"while ( iter.hasNext() ) {\n"
-"    Map map = (Map) iter.next();\n"
-"    Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);\n"
-"    Cat kitten = (Cat) map.get(\"kt\");\n"
-"}]]>"
+"This will return all of the <literal>Cat</literal>s with a mate whose name "
+"starts with \"good\" ordered by their mate's age, and all cats who do not "
+"have a mate. This is useful when there is a need to order or limit in the "
+"database prior to returning complex/large result sets, and removes many "
+"instances where multiple queries would have to be performed and the results "
+"unioned by java in memory."
 msgstr ""
 
+#. Tag: para
+#, no-c-format
+msgid ""
+"Without this feature, first all of the cats without a mate would need to be "
+"loaded in one query."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"A second query would need to retreive the cats with mates who's name started "
+"with \"good\" sorted by the mates age."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "Thirdly, in memory; the lists would need to be joined manually."
+msgstr ""
+
 #. Tag: title
-#: query_criteria.xml:143
 #, no-c-format
 msgid "Dynamic association fetching"
 msgstr "동적인 연관 페칭"
 
 #. Tag: para
-#: query_criteria.xml:145
 #, fuzzy, no-c-format
 msgid ""
 "You can specify association fetching semantics at runtime using "
@@ -329,23 +205,11 @@
 "당신은 <literal>setFetchMode()</literal>를 사용하여 실행 시에 연관 페칭 의미"
 "를 지정할 수 있다."
 
-#. Tag: programlisting
-#: query_criteria.xml:150
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .setFetchMode(\"mate\", FetchMode.EAGER)\n"
-"    .setFetchMode(\"kittens\", FetchMode.EAGER)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:152
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "This query will fetch both <literal>mate</literal> and <literal>kittens</"
-"literal> by outer join. See <xref linkend=\"performance-fetching\"/> for "
+"literal> by outer join. See <xref linkend=\"performance-fetching\" /> for "
 "more information."
 msgstr ""
 "이 질의는 outer 조인으로 <literal>mate</literal>와 <literal>kittens</"
@@ -353,13 +217,11 @@
 "fetching\"/>을 보라."
 
 #. Tag: title
-#: query_criteria.xml:160
 #, no-c-format
 msgid "Example queries"
 msgstr "예제 질의들"
 
 #. Tag: para
-#: query_criteria.xml:162
 #, no-c-format
 msgid ""
 "The class <literal>org.hibernate.criterion.Example</literal> allows you to "
@@ -368,20 +230,7 @@
 "<literal>org.hibernate.criterion.Example</literal> 클래스는 주어진 인스턴스로"
 "부터 질의 기준(criterion)을 구조화 시키는 것을 당신에게 허용해준다."
 
-#. Tag: programlisting
-#: query_criteria.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = new Cat();\n"
-"cat.setSex('F');\n"
-"cat.setColor(Color.BLACK);\n"
-"List results = session.createCriteria(Cat.class)\n"
-"    .add( Example.create(cat) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:169
 #, no-c-format
 msgid ""
 "Version properties, identifiers and associations are ignored. By default, "
@@ -391,53 +240,23 @@
 "이 제외된다."
 
 #. Tag: para
-#: query_criteria.xml:174
 #, no-c-format
 msgid "You can adjust how the <literal>Example</literal> is applied."
 msgstr "당신은 <literal>Example</literal>이 적용되는 방법을 조정할 수 있다."
 
-#. Tag: programlisting
-#: query_criteria.xml:178
-#, no-c-format
-msgid ""
-"<![CDATA[Example example = Example.create(cat)\n"
-"    .excludeZeroes()           //exclude zero valued properties\n"
-"    .excludeProperty(\"color\")  //exclude the property named \"color\"\n"
-"    .ignoreCase()              //perform case insensitive string "
-"comparisons\n"
-"    .enableLike();             //use like for string comparisons\n"
-"List results = session.createCriteria(Cat.class)\n"
-"    .add(example)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:180
 #, no-c-format
 msgid "You can even use examples to place criteria upon associated objects."
 msgstr ""
 "당신은 연관된 객체들에 대한 criteria(기준)을 위치지우는데 examples를 사용할 "
 "수 있다."
 
-#. Tag: programlisting
-#: query_criteria.xml:184
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .add( Example.create(cat) )\n"
-"    .createCriteria(\"mate\")\n"
-"        .add( Example.create( cat.getMate() ) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:189
 #, no-c-format
 msgid "Projections, aggregation and grouping"
 msgstr "Projections, aggregation 그리고 grouping"
 
 #. Tag: para
-#: query_criteria.xml:190
 #, fuzzy, no-c-format
 msgid ""
 "The class <literal>org.hibernate.criterion.Projections</literal> is a "
@@ -449,32 +268,7 @@
 "<literal>setProjection()</literal>을 호출하여 하나의 질의에 projection(투사,"
 "투영)을 적용시킨다."
 
-#. Tag: programlisting
-#: query_criteria.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.rowCount() )\n"
-"    .add( Restrictions.eq(\"color\", Color.BLACK) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:198
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount() )\n"
-"        .add( Projections.avg(\"weight\") )\n"
-"        .add( Projections.max(\"weight\") )\n"
-"        .add( Projections.groupProperty(\"color\") )\n"
-"    )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:200
 #, no-c-format
 msgid ""
 "There is no explicit \"group by\" necessary in a criteria query. Certain "
@@ -486,7 +280,6 @@
 "고, 그것은 또한 SQL <literal>group by</literal> 절 속에 나타난다."
 
 #. Tag: para
-#: query_criteria.xml:206
 #, fuzzy, no-c-format
 msgid ""
 "An alias can be assigned to a projection so that the projected value can be "
@@ -497,29 +290,7 @@
 "(restriction)들 또는 ordering들 내에서 참조될 수 있다. 다음은 이것을 행하는 "
 "두 개의 다른 방법들이다:"
 
-#. Tag: programlisting
-#: query_criteria.xml:212
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.alias( Projections.groupProperty(\"color\"), "
-"\"colr\" ) )\n"
-"    .addOrder( Order.asc(\"colr\") )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:214
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.groupProperty(\"color\").as(\"colr\") )\n"
-"    .addOrder( Order.asc(\"colr\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:216
 #, no-c-format
 msgid ""
 "The <literal>alias()</literal> and <literal>as()</literal> methods simply "
@@ -532,39 +303,7 @@
 "턴스를 간단하게 포장한다. 지름길로서, 당신이 projection을 projection 리스트"
 "에 추가할 때 당신은 alias를 할당할 수 있다:"
 
-#. Tag: programlisting
-#: query_criteria.xml:223
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount(), \"catCountByColor\" )\n"
-"        .add( Projections.avg(\"weight\"), \"avgWeight\" )\n"
-"        .add( Projections.max(\"weight\"), \"maxWeight\" )\n"
-"        .add( Projections.groupProperty(\"color\"), \"color\" )\n"
-"    )\n"
-"    .addOrder( Order.desc(\"catCountByColor\") )\n"
-"    .addOrder( Order.desc(\"avgWeight\") )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:225
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Domestic.class, \"cat\")\n"
-"    .createAlias(\"kittens\", \"kit\")\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.property(\"cat.name\"), \"catName\" )\n"
-"        .add( Projections.property(\"kit.name\"), \"kitName\" )\n"
-"    )\n"
-"    .addOrder( Order.asc(\"catName\") )\n"
-"    .addOrder( Order.asc(\"kitName\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:227
 #, no-c-format
 msgid ""
 "You can also use <literal>Property.forName()</literal> to express "
@@ -573,40 +312,12 @@
 "당신은 또한 projection들을 표현하는데 <literal>Property.forName()</literal>"
 "을 사용할 수 있다:"
 
-#. Tag: programlisting
-#: query_criteria.xml:231
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Property.forName(\"name\") )\n"
-"    .add( Property.forName(\"color\").eq(Color.BLACK) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:233
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount().as(\"catCountByColor\") )\n"
-"        .add( Property.forName(\"weight\").avg().as(\"avgWeight\") )\n"
-"        .add( Property.forName(\"weight\").max().as(\"maxWeight\") )\n"
-"        .add( Property.forName(\"color\").group().as(\"color\" )\n"
-"    )\n"
-"    .addOrder( Order.desc(\"catCountByColor\") )\n"
-"    .addOrder( Order.desc(\"avgWeight\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:238
 #, no-c-format
 msgid "Detached queries and subqueries"
 msgstr "Detached 질의들과 서브질의들"
 
 #. Tag: para
-#: query_criteria.xml:239
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>DetachedCriteria</literal> class allows you to create a query "
@@ -617,23 +328,7 @@
 "의를 생성시키도록 하고, 그런 다음 나중에 어떤 임의의 <literal>Session</"
 "literal>을 사용하여 그것을 실행하도록 한다."
 
-#. Tag: programlisting
-#: query_criteria.xml:244
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria query = DetachedCriteria.forClass(Cat.class)\n"
-"    .add( Property.forName(\"sex\").eq('F') );\n"
-"    \n"
-"Session session = ....;\n"
-"Transaction txn = session.beginTransaction();\n"
-"List results = query.getExecutableCriteria(session).setMaxResults(100).list"
-"();\n"
-"txn.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:246
 #, fuzzy, no-c-format
 msgid ""
 "A <literal>DetachedCriteria</literal> can also be used to express a "
@@ -644,55 +339,17 @@
 "브질의들을 포함하는 Criterion 인스턴스들은 <literal>Subqueries</literal> 또"
 "는 <literal>Property</literal>를 통해 얻어질 수 있다."
 
-#. Tag: programlisting
-#: query_criteria.xml:252
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria avgWeight = DetachedCriteria.forClass(Cat.class)\n"
-"    .setProjection( Property.forName(\"weight\").avg() );\n"
-"session.createCriteria(Cat.class)\n"
-"    .add( Property.forName(\"weight\").gt(avgWeight) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:254
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria weights = DetachedCriteria.forClass(Cat.class)\n"
-"    .setProjection( Property.forName(\"weight\") );\n"
-"session.createCriteria(Cat.class)\n"
-"    .add( Subqueries.geAll(\"weight\", weights) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:256
 #, fuzzy, no-c-format
 msgid "Correlated subqueries are also possible:"
 msgstr "심지어 상관관계 지워진 서브질의들이 가능하다:"
 
-#. Tag: programlisting
-#: query_criteria.xml:260
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria avgWeightForSex = DetachedCriteria.forClass(Cat."
-"class, \"cat2\")\n"
-"    .setProjection( Property.forName(\"weight\").avg() )\n"
-"    .add( Property.forName(\"cat2.sex\").eqProperty(\"cat.sex\") );\n"
-"session.createCriteria(Cat.class, \"cat\")\n"
-"    .add( Property.forName(\"weight\").gt(avgWeightForSex) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:269
 #, no-c-format
 msgid "Queries by natural identifier"
 msgstr "natural 식별자에 의한 질의들"
 
 #. Tag: para
-#: query_criteria.xml:271
 #, fuzzy, no-c-format
 msgid ""
 "For most queries, including criteria queries, the query cache is not "
@@ -709,7 +366,6 @@
 "질의가 자주 발생한다. criteria API는 이 쓰임새를 위한 특별한 설비를 제공한다."
 
 #. Tag: para
-#: query_criteria.xml:279
 #, fuzzy, no-c-format
 msgid ""
 "First, map the natural key of your entity using <literal>&lt;natural-id&gt;</"
@@ -719,25 +375,7 @@
 "티에 대한 natural 키를 매핑 시켜야 하고, second-level 캐시 사용을 가능하게 해"
 "야 한다."
 
-#. Tag: programlisting
-#: query_criteria.xml:284
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"User\">\n"
-"    <cache usage=\"read-write\"/>\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <natural-id>\n"
-"        <property name=\"name\"/>\n"
-"        <property name=\"org\"/>\n"
-"    </natural-id>\n"
-"    <property name=\"password\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:286
 #, fuzzy, no-c-format
 msgid ""
 "This functionality is not intended for use with entities with "
@@ -747,7 +385,6 @@
 "도로 고안되어 있지 않음을 노트하라."
 
 #. Tag: para
-#: query_criteria.xml:291
 #, fuzzy, no-c-format
 msgid ""
 "Once you have enabled the Hibernate query cache, the <literal>Restrictions."
@@ -757,18 +394,6 @@
 "이제 <literal>Restrictions.naturalId()</literal>는 캐시 알고리즘을 보다 효율"
 "적으로 사용할 수 있도록 우리에게 허용해준다."
 
-#. Tag: programlisting
-#: query_criteria.xml:297
-#, no-c-format
-msgid ""
-"<![CDATA[session.createCriteria(User.class)\n"
-"    .add( Restrictions.naturalId()\n"
-"        .set(\"name\", \"gavin\")\n"
-"        .set(\"org\", \"hb\") \n"
-"    ).setCacheable(true)\n"
-"    .uniqueResult();]]>"
-msgstr ""
-
 #~ msgid ""
 #~ "You may easily specify constraints upon related entities by navigating "
 #~ "associations using <literal>createCriteria()</literal>."

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/query_hql.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/query_hql.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/query_hql.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,13 +11,11 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: query_hql.xml:29
 #, no-c-format
 msgid "HQL: The Hibernate Query Language"
 msgstr "HQL: 하이버네이트 질의 언어(Hibernate Query Language)"
 
 #. Tag: para
-#: query_hql.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate uses a powerful query language (HQL) that is similar in appearance "
@@ -29,13 +27,11 @@
 "성 그리고 연관과 같은 개념들을 이해하여서, 전체적으로 객체 지향적이다."
 
 #. Tag: title
-#: query_hql.xml:38
 #, no-c-format
 msgid "Case Sensitivity"
 msgstr "대소문자 구분"
 
 #. Tag: para
-#: query_hql.xml:40
 #, fuzzy, no-c-format
 msgid ""
 "With the exception of names of Java classes and properties, queries are case-"
@@ -51,7 +47,6 @@
 "literal>은 <literal>foo.BARSET</literal>과 같지 않다."
 
 #. Tag: para
-#: query_hql.xml:51
 #, fuzzy, no-c-format
 msgid ""
 "This manual uses lowercase HQL keywords. Some users find queries with "
@@ -63,25 +58,16 @@
 "이 컨벤션이 추하다는 점을 발견한다."
 
 #. Tag: title
-#: query_hql.xml:59
 #, no-c-format
 msgid "The from clause"
 msgstr "from ì ˆ"
 
 #. Tag: para
-#: query_hql.xml:61
 #, no-c-format
 msgid "The simplest possible Hibernate query is of the form:"
 msgstr "가장 간단한 가능한 Hibernate 질의는 다음 형식이다:"
 
-#. Tag: programlisting
-#: query_hql.xml:65
-#, no-c-format
-msgid "<![CDATA[from eg.Cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:67
 #, fuzzy, no-c-format
 msgid ""
 "This returns all instances of the class <literal>eg.Cat</literal>. You do "
@@ -93,28 +79,14 @@
 "import</literal>가 디폴트이기 때문이다. 따라서 우리는 대개 항상 단지 다음과 "
 "같이 작성한다:"
 
-#. Tag: programlisting
-#: query_hql.xml:73
-#, no-c-format
-msgid "<![CDATA[from Cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:75
 #, no-c-format
 msgid ""
 "In order to refer to the <literal>Cat</literal> in other parts of the query, "
 "you will need to assign an <emphasis>alias</emphasis>. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:81 query_hql.xml:396
-#, no-c-format
-msgid "<![CDATA[from Cat as cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:83
 #, fuzzy, no-c-format
 msgid ""
 "This query assigns the alias <literal>cat</literal> to <literal>Cat</"
@@ -126,14 +98,7 @@
 "<literal>as</literal> 키워드는 옵션이다; 우리는 또한 다음과 같이 작성할 수 있"
 "다:"
 
-#. Tag: programlisting
-#: query_hql.xml:89
-#, no-c-format
-msgid "<![CDATA[from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:91
 #, fuzzy, no-c-format
 msgid ""
 "Multiple classes can appear, resulting in a cartesian product or \"cross\" "
@@ -142,20 +107,7 @@
 "여러 개의 클래스들은 cartesian product(카티젼 곱) 또는 \"크로스\" 조인으로 귀"
 "결되어 나타날 수도 있다."
 
-#. Tag: programlisting
-#: query_hql.xml:95
-#, no-c-format
-msgid "<![CDATA[from Formula, Parameter]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:96
-#, no-c-format
-msgid "<![CDATA[from Formula as form, Parameter as param]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:98
 #, fuzzy, no-c-format
 msgid ""
 "It is good practice to name query aliases using an initial lowercase as this "
@@ -167,13 +119,11 @@
 "<literal>domesticCat</literal>)."
 
 #. Tag: title
-#: query_hql.xml:107
 #, no-c-format
 msgid "Associations and joins"
 msgstr "연관들과 조인들"
 
 #. Tag: para
-#: query_hql.xml:109
 #, fuzzy, no-c-format
 msgid ""
 "You can also assign aliases to associated entities or to elements of a "
@@ -182,59 +132,32 @@
 "우리는 또한 <literal>join</literal>을 사용하여 , 연관된 엔티티들에 또는 값들"
 "을 가진 콜렉션의 요소들에도 alias들을 할당할 수도 있다."
 
-#. Tag: programlisting
-#: query_hql.xml:114
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join cat.mate as mate\n"
-"    left outer join cat.kittens as kitten]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:116
-#, no-c-format
-msgid "<![CDATA[from Cat as cat left join cat.mate.kittens as kittens]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:118
-#, no-c-format
-msgid "<![CDATA[from Formula form full join form.parameter param]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:120
 #, fuzzy, no-c-format
 msgid "The supported join types are borrowed from ANSI SQL:"
 msgstr "지원되는 join 타입들은 ANSI SQL로부터 빌려왔다"
 
-#. Tag: literal
-#: query_hql.xml:127
-#, no-c-format
-msgid "inner join"
-msgstr "inner join"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>inner join</literal>"
+msgstr "또는 <literal>List</literal>로서,"
 
-#. Tag: literal
-#: query_hql.xml:132
-#, no-c-format
-msgid "left outer join"
-msgstr "left outer join"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>left outer join</literal>"
+msgstr "<literal>full join</literal> (대개 유용하지 않음)"
 
-#. Tag: literal
-#: query_hql.xml:137
-#, no-c-format
-msgid "right outer join"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>right outer join</literal>"
 msgstr "right outer join"
 
 #. Tag: para
-#: query_hql.xml:141
 #, no-c-format
 msgid "<literal>full join</literal> (not usually useful)"
 msgstr "<literal>full join</literal> (대개 유용하지 않음)"
 
 #. Tag: para
-#: query_hql.xml:147
 #, no-c-format
 msgid ""
 "The <literal>inner join</literal>, <literal>left outer join</literal> and "
@@ -243,17 +166,7 @@
 "<literal>inner join</literal>, <literal>left outer join</literal>, 그리고 "
 "<literal>right outer join</literal> 구조체들이 약칭될 수 있다."
 
-#. Tag: programlisting
-#: query_hql.xml:152
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    join cat.mate as mate\n"
-"    left join cat.kittens as kitten]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:154
 #, no-c-format
 msgid ""
 "You may supply extra join conditions using the HQL <literal>with</literal> "
@@ -262,24 +175,14 @@
 "당신은 HQL <literal>with</literal> 키워드를 사용하여 특별한 조인 조건들을 제"
 "공할 수 있다."
 
-#. Tag: programlisting
-#: query_hql.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    left join cat.kittens as kitten\n"
-"        with kitten.bodyWeight > 10.0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:161
 #, fuzzy, no-c-format
 msgid ""
 "A \"fetch\" join allows associations or collections of values to be "
 "initialized along with their parent objects using a single select. This is "
 "particularly useful in the case of a collection. It effectively overrides "
 "the outer join and lazy declarations of the mapping file for associations "
-"and collections. See <xref linkend=\"performance-fetching\"/> for more "
+"and collections. See <xref linkend=\"performance-fetching\" /> for more "
 "information."
 msgstr ""
 "게다가, \"fetch\" join은 값들을 가진 콜렉션들이나 연관관계들이 한 개의 select"
@@ -288,17 +191,7 @@
 "의 outer join과 lazy 선언들을 효율적으로 오버라이드 시킨다. 추가 정보는 "
 "<xref linkend=\"performance-fetching\"/>을 보라."
 
-#. Tag: programlisting
-#: query_hql.xml:169
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join fetch cat.mate\n"
-"    left join fetch cat.kittens]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:171
 #, fuzzy, no-c-format
 msgid ""
 "A fetch join does not usually need to assign an alias, because the "
@@ -314,18 +207,7 @@
 "은 부모 객체를 통해 접근될 수 있다. 우리가 alias를 필요로 할 수 있는 유일한 "
 "이유는 더 많은 콜렉션들을 재귀적으로 조인 페칭시키는 경우이다:"
 
-#. Tag: programlisting
-#: query_hql.xml:179
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join fetch cat.mate\n"
-"    left join fetch cat.kittens child\n"
-"    left join fetch child.kittens]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:181
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>fetch</literal> construct cannot be used in queries called "
@@ -358,7 +240,6 @@
 "literal>와 <literal>right join fetch</literal>는 의미가 없다."
 
 #. Tag: para
-#: query_hql.xml:196
 #, fuzzy, no-c-format
 msgid ""
 "If you are using property-level lazy fetching (with bytecode "
@@ -370,28 +251,12 @@
 "Hibernate로 하여금 <literal>fetch all properties</literal>를 사용하여 (첫 번"
 "째 질의에서) lazy 프로퍼티들을 즉시 페치하도록 강제시키는 것이 가능하다."
 
-#. Tag: programlisting
-#: query_hql.xml:202
-#, no-c-format
-msgid "<![CDATA[from Document fetch all properties order by name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:203
-#, no-c-format
-msgid ""
-"<![CDATA[from Document doc fetch all properties where lower(doc.name) like '%"
-"cats%']]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:208
 #, no-c-format
 msgid "Forms of join syntax"
 msgstr "join 구문의 형식들"
 
 #. Tag: para
-#: query_hql.xml:210
 #, no-c-format
 msgid ""
 "HQL supports two forms of association joining: <literal>implicit</literal> "
@@ -401,7 +266,6 @@
 "<literal>명시적</literal>."
 
 #. Tag: para
-#: query_hql.xml:214
 #, fuzzy, no-c-format
 msgid ""
 "The queries shown in the previous section all use the <literal>explicit</"
@@ -412,7 +276,6 @@
 "는 <literal>명시적인</literal> 형식을 사용한다. 이것은 권장되는 형식이다."
 
 #. Tag: para
-#: query_hql.xml:219
 #, no-c-format
 msgid ""
 "The <literal>implicit</literal> form does not use the join keyword. Instead, "
@@ -425,27 +288,18 @@
 "인</literal> 조인들은 임의의 HQL 절들내에 나타날 수 있다. <literal>함축적인</"
 "literal> join은 결과되는 SQL 문장에서 inner join으로 귀결된다."
 
-#. Tag: programlisting
-#: query_hql.xml:226
-#, no-c-format
-msgid "<![CDATA[from Cat as cat where cat.mate.name like '%s%']]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:230
 #, fuzzy, no-c-format
 msgid "Referring to identifier property"
 msgstr "식별자 속성 참조하기"
 
 #. Tag: para
-#: query_hql.xml:232
 #, fuzzy, no-c-format
 msgid "There are 2 ways to refer to an entity's identifier property:"
 msgstr ""
 "개략적으로 말하자면, 엔티티의 식별자 속성을 참조하는 2가지 방법들이 존재한다:"
 
 #. Tag: para
-#: query_hql.xml:237
 #, fuzzy, no-c-format
 msgid ""
 "The special property (lowercase) <literal>id</literal> may be used to "
@@ -457,7 +311,6 @@
 "참조하는데 사용될 수 있다."
 
 #. Tag: para
-#: query_hql.xml:244
 #, fuzzy, no-c-format
 msgid ""
 "If the entity defines a named identifier property, you can use that property "
@@ -467,7 +320,6 @@
 "용할 수도 있다."
 
 #. Tag: para
-#: query_hql.xml:250
 #, fuzzy, no-c-format
 msgid ""
 "References to composite identifier properties follow the same naming rules. "
@@ -482,7 +334,6 @@
 "literal> 속성이 식별자 속성을 참조하는데 사용될 수 있다."
 
 #. Tag: para
-#: query_hql.xml:258
 #, fuzzy, no-c-format
 msgid ""
 "Please note that, starting in version 3.2.2, this has changed significantly. "
@@ -497,13 +348,11 @@
 "비식별자 속성들이 Hibernate 질의들 내에서 결코 참조될 수 없었다는 점이었다."
 
 #. Tag: title
-#: query_hql.xml:269
 #, no-c-format
 msgid "The select clause"
 msgstr "select ì ˆ"
 
 #. Tag: para
-#: query_hql.xml:271
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>select</literal> clause picks which objects and properties to "
@@ -512,17 +361,7 @@
 "<literal>select</literal> 절은 질의 결과 셋 속에 반환할 객체들과 프로퍼티들"
 "이 어느 것인지를 골라 내도록 강제한다. 다음을 검토하자:"
 
-#. Tag: programlisting
-#: query_hql.xml:276
-#, no-c-format
-msgid ""
-"<![CDATA[select mate\n"
-"from Cat as cat\n"
-"    inner join cat.mate as mate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:278
 #, fuzzy, no-c-format
 msgid ""
 "The query will select <literal>mate</literal>s of other <literal>Cat</"
@@ -532,14 +371,7 @@
 "것이다. 실제로 당신은 이 질의들을 다음과 같이 보다 축약형으로 표현할수도 있"
 "다:"
 
-#. Tag: programlisting
-#: query_hql.xml:283
-#, no-c-format
-msgid "<![CDATA[select cat.mate from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:285
 #, fuzzy, no-c-format
 msgid ""
 "Queries can return properties of any value type including properties of "
@@ -548,22 +380,7 @@
 "질의들은 컴포넌트 타입의 프로퍼티들을 포함하는 임의의 값 타입의 프로퍼티들을 "
 "반환할 수도 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:289
-#, no-c-format
-msgid ""
-"<![CDATA[select cat.name from DomesticCat cat\n"
-"where cat.name like 'fri%']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:291
-#, no-c-format
-msgid "<![CDATA[select cust.name.firstName from Customer as cust]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:293
 #, fuzzy, no-c-format
 msgid ""
 "Queries can return multiple objects and/or properties as an array of type "
@@ -573,52 +390,19 @@
 "들은 여러 객체들 그리고/또는 프로퍼티들을 <literal>Object[]</literal> 타입의 "
 "배열로서,"
 
-#. Tag: programlisting
-#: query_hql.xml:298
-#, no-c-format
-msgid ""
-"<![CDATA[select mother, offspr, mate.name\n"
-"from DomesticCat as mother\n"
-"    inner join mother.mate as mate\n"
-"    left outer join mother.kittens as offspr]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:300
 #, fuzzy, no-c-format
 msgid "Or as a <literal>List</literal>:"
 msgstr "또는 <literal>List</literal>로서,"
 
-#. Tag: programlisting
-#: query_hql.xml:304
-#, no-c-format
-msgid ""
-"<![CDATA[select new list(mother, offspr, mate.name)\n"
-"from DomesticCat as mother\n"
-"    inner join mother.mate as mate\n"
-"    left outer join mother.kittens as offspr]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:306
 #, fuzzy, no-c-format
 msgid ""
 "Or - assuming that the class <literal>Family</literal> has an appropriate "
 "constructor - as an actual typesafe Java object:"
 msgstr "반환할 수도 있다."
 
-#. Tag: programlisting
-#: query_hql.xml:310
-#, no-c-format
-msgid ""
-"<![CDATA[select new Family(mother, mate, offspr)\n"
-"from DomesticCat as mother\n"
-"    join mother.mate as mate\n"
-"    left join mother.kittens as offspr]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:313
 #, fuzzy, no-c-format
 msgid ""
 "You can assign aliases to selected expressions using <literal>as</literal>:"
@@ -626,17 +410,7 @@
 "당신은 <literal>as</literal>를 사용하여 select되는 표현식들에 alias들을 할당"
 "할 수 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:317
-#, no-c-format
-msgid ""
-"<![CDATA[select max(bodyWeight) as max, min(bodyWeight) as min, count(*) as "
-"n\n"
-"from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:319
 #, no-c-format
 msgid ""
 "This is most useful when used together with <literal>select new map</"
@@ -644,17 +418,7 @@
 msgstr ""
 "다음은 <literal>select new map</literal>과 함께 사용될 때 가장 유용하다:"
 
-#. Tag: programlisting
-#: query_hql.xml:323
-#, no-c-format
-msgid ""
-"<![CDATA[select new map( max(bodyWeight) as max, min(bodyWeight) as min, "
-"count(*) as n )\n"
-"from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:325
 #, no-c-format
 msgid ""
 "This query returns a <literal>Map</literal> from aliases to selected values."
@@ -663,13 +427,11 @@
 "반환한다."
 
 #. Tag: title
-#: query_hql.xml:332
 #, no-c-format
 msgid "Aggregate functions"
 msgstr "집계 함수들"
 
 #. Tag: para
-#: query_hql.xml:334
 #, fuzzy, no-c-format
 msgid ""
 "HQL queries can even return the results of aggregate functions on properties:"
@@ -677,41 +439,27 @@
 "HQL 질의들은 프로퍼티들에 대한 집계(aggregate) 함수들의 결과들을 반환할수도 "
 "있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:338
-#, no-c-format
-msgid ""
-"<![CDATA[select avg(cat.weight), sum(cat.weight), max(cat.weight), count"
-"(cat)\n"
-"from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:349
 #, fuzzy, no-c-format
 msgid "The supported aggregate functions are:"
 msgstr "지원되는 집계 함수들은 다음과 같다"
 
-#. Tag: literal
-#: query_hql.xml:356
-#, no-c-format
-msgid "avg(...), sum(...), min(...), max(...)"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>avg(...), sum(...), min(...), max(...)</literal>"
 msgstr "avg(...), sum(...), min(...), max(...)"
 
-#. Tag: literal
-#: query_hql.xml:361
-#, no-c-format
-msgid "count(*)"
-msgstr "count(*)"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>count(*)</literal>"
+msgstr "또는 <literal>List</literal>로서,"
 
-#. Tag: literal
-#: query_hql.xml:366
-#, no-c-format
-msgid "count(...), count(distinct ...), count(all...)"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>count(...), count(distinct ...), count(all...)</literal>"
 msgstr "count(...), count(distinct ...), count(all...)"
 
 #. Tag: para
-#: query_hql.xml:371
 #, fuzzy, no-c-format
 msgid ""
 "You can use arithmetic operators, concatenation, and recognized SQL "
@@ -720,25 +468,7 @@
 "당신은 select 절 속에 산술 연산자들, 연결 연산자, 그리고 인지된 SQL 함수들을 "
 "사용할 수 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:376
-#, no-c-format
-msgid ""
-"<![CDATA[select cat.weight + sum(kitten.weight)\n"
-"from Cat cat\n"
-"    join cat.kittens kitten\n"
-"group by cat.id, cat.weight]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:378
-#, no-c-format
-msgid ""
-"<![CDATA[select firstName||' '||initial||' '||upper(lastName) from Person]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:380
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>distinct</literal> and <literal>all</literal> keywords can be "
@@ -747,29 +477,17 @@
 "<literal>distinct</literal> 키워드와 all <literal>all</literal>가 사용될 수 "
 "있고 SQL의 경우와 동일한 의미를 갖는다."
 
-#. Tag: programlisting
-#: query_hql.xml:385
-#, no-c-format
-msgid ""
-"<![CDATA[select distinct cat.name from Cat cat\n"
-"\n"
-"select count(distinct cat.name), count(cat) from Cat cat]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:390
 #, no-c-format
 msgid "Polymorphic queries"
 msgstr "Polymorphic(다형성) 질의들"
 
 #. Tag: para
-#: query_hql.xml:392
 #, no-c-format
 msgid "A query like:"
 msgstr "다음과 같은 질의:"
 
 #. Tag: para
-#: query_hql.xml:398
 #, fuzzy, no-c-format
 msgid ""
 "returns instances not only of <literal>Cat</literal>, but also of subclasses "
@@ -786,14 +504,7 @@
 "스를 구현하는 모든 영속 클래스들의 인스턴스들을 반환할 것이다. 다음 질의는 모"
 "든 영속 객체들을 반환할 것이다:"
 
-#. Tag: programlisting
-#: query_hql.xml:406
-#, no-c-format
-msgid "<![CDATA[from java.lang.Object o]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:408
 #, no-c-format
 msgid ""
 "The interface <literal>Named</literal> might be implemented by various "
@@ -802,14 +513,7 @@
 "인터페이스 <literal>Named</literal>는 여러 가지 영속 클래스들에 의해 구현될 "
 "수도 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:413
-#, no-c-format
-msgid "<![CDATA[from Named n, Named m where n.name = m.name]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:415
 #, fuzzy, no-c-format
 msgid ""
 "These last two queries will require more than one SQL <literal>SELECT</"
@@ -823,13 +527,11 @@
 "scroll()</literal>을 사용하여 이들 질의들을 호출할 수 없음을 의미한다)."
 
 #. Tag: title
-#: query_hql.xml:424
 #, no-c-format
 msgid "The where clause"
 msgstr "where ì ˆ"
 
 #. Tag: para
-#: query_hql.xml:426
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>where</literal> clause allows you to refine the list of "
@@ -839,49 +541,24 @@
 "에게 허용해준다. 만일 alias가 존재하지 않을 경우, 당신은 이름에 의해 프로퍼티"
 "들을 참조할 수도 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:431
-#, no-c-format
-msgid "<![CDATA[from Cat where name='Fritz']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:433
 #, no-c-format
 msgid "If there is an alias, use a qualified property name:"
 msgstr ""
 "만일 한 개의 alias가 존재할 경우, 하나의 수식어가 붙은 프로퍼티 이름을 사용하"
 "라:"
 
-#. Tag: programlisting
-#: query_hql.xml:437
-#, no-c-format
-msgid "<![CDATA[from Cat as cat where cat.name='Fritz']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:439
 #, fuzzy, no-c-format
 msgid "This returns instances of <literal>Cat</literal> named 'Fritz'."
 msgstr "는 'Fritz'로 명명된 <literal>Cat</literal>의 인스턴스들을 반환한다."
 
 #. Tag: para
-#: query_hql.xml:443
 #, no-c-format
 msgid "The following query:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:446
-#, no-c-format
-msgid ""
-"<![CDATA[select foo\n"
-"from Foo foo, Bar bar\n"
-"where foo.startDate = bar.date]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:448
 #, fuzzy, no-c-format
 msgid ""
 "returns all instances of <literal>Foo</literal> with an instance of "
@@ -896,14 +573,7 @@
 "현식들은 <literal>where</literal> 절을 매우 강력하게 만들어준다. 다음을 검토"
 "하자:"
 
-#. Tag: programlisting
-#: query_hql.xml:457
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.mate.name is not null]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:459
 #, fuzzy, no-c-format
 msgid ""
 "This query translates to an SQL query with a table (inner) join. For example:"
@@ -911,23 +581,13 @@
 "이 질의는 테이블 (inner) join을 가진 SQL 질의로 번역된다. 만일 당신이 다음과 "
 "같은 어떤 것을 작성했다면"
 
-#. Tag: programlisting
-#: query_hql.xml:464
-#, no-c-format
-msgid ""
-"<![CDATA[from Foo foo\n"
-"where foo.bar.baz.customer.address.city is not null]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:466
 #, fuzzy, no-c-format
 msgid "would result in a query that would require four table joins in SQL."
 msgstr ""
 "당신은 SQL에서 네 개의 테이블 join들을 필요로 하는 하나의 질의로 끝낼 것이다."
 
 #. Tag: para
-#: query_hql.xml:470
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>=</literal> operator can be used to compare not only "
@@ -936,50 +596,23 @@
 "<literal>=</literal> 연산자는 프로퍼티들 뿐만 아니라 또한 인스턴스들을 비교하"
 "는데 사용될 수 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:475
-#, no-c-format
-msgid "<![CDATA[from Cat cat, Cat rival where cat.mate = rival.mate]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:477
-#, no-c-format
-msgid ""
-"<![CDATA[select cat, mate\n"
-"from Cat cat, Cat mate\n"
-"where cat.mate = mate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:479
 #, fuzzy, no-c-format
 msgid ""
 "The special property (lowercase) <literal>id</literal> can be used to "
 "reference the unique identifier of an object. See <xref linkend=\"queryhql-"
-"identifier-property\"/> for more information."
+"identifier-property\" /> for more information."
 msgstr ""
 "특별한 프로퍼티(소문자) <literal>id</literal>는 객체의 유일 식별자를 참조하는"
 "데 사용될 수 있다. 추가 정보는 <xref linkend=\"queryhql-identifier-property"
 "\"/>를 보라."
 
-#. Tag: programlisting
-#: query_hql.xml:485
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat where cat.id = 123\n"
-"\n"
-"from Cat as cat where cat.mate.id = 69]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:487
 #, fuzzy, no-c-format
 msgid "The second query is efficient and does not require a table join."
 msgstr "두 번째 질의가 효율적이다. 테이블 join이 필요 없다!"
 
 #. Tag: para
-#: query_hql.xml:491
 #, fuzzy, no-c-format
 msgid ""
 "Properties of composite identifiers can also be used. Consider the following "
@@ -992,40 +625,19 @@
 "자. 식별자 속성들을 참조하는 것과 관련된 추가 정보는 다시 <xref linkend="
 "\"queryhql-identifier-property\"/>를 보라."
 
-#. Tag: programlisting
-#: query_hql.xml:497
-#, no-c-format
-msgid ""
-"<![CDATA[from bank.Person person\n"
-"where person.id.country = 'AU'\n"
-"    and person.id.medicareNumber = 123456]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:499
-#, no-c-format
-msgid ""
-"<![CDATA[from bank.Account account\n"
-"where account.owner.id.country = 'AU'\n"
-"    and account.owner.id.medicareNumber = 123456]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:501
 #, fuzzy, no-c-format
 msgid "Once again, the second query does not require a table join."
 msgstr "다시 한번, 두 번째 질의는 테이블 join을 필요로 하지 않는다."
 
 #. Tag: para
-#: query_hql.xml:505
 #, no-c-format
 msgid ""
-"See <xref linkend=\"queryhql-identifier-property\"/> for more information "
+"See <xref linkend=\"queryhql-identifier-property\" /> for more information "
 "regarding referencing identifier properties)"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:510
 #, fuzzy, no-c-format
 msgid ""
 "The special property <literal>class</literal> accesses the discriminator "
@@ -1038,18 +650,11 @@
 "스한다. where 절 속에 삽입된 Java 클래스 이름은 그것의 판별자(discriminator) "
 "값으로 변환될 것이다."
 
-#. Tag: programlisting
-#: query_hql.xml:516
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.class = DomesticCat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:518
 #, fuzzy, no-c-format
 msgid ""
 "You can also use components or composite user types, or properties of said "
-"component types. See <xref linkend=\"queryhql-components\"/> for more "
+"component types. See <xref linkend=\"queryhql-components\" /> for more "
 "information."
 msgstr ""
 "당신은 또한 컴포넌트들 또는 composite 사용자 타입들, 또는 명명된 컴포넌트 타"
@@ -1057,7 +662,6 @@
 "components\"/>를 보라."
 
 #. Tag: para
-#: query_hql.xml:523
 #, fuzzy, no-c-format
 msgid ""
 "An \"any\" type has the special properties <literal>id</literal> and "
@@ -1070,16 +674,7 @@
 "기서 <literal>AuditLog.item</literal>은 <literal>&lt;any&gt;</literal>로 매핑"
 "된 프로퍼티이다)."
 
-#. Tag: programlisting
-#: query_hql.xml:529
-#, no-c-format
-msgid ""
-"<![CDATA[from AuditLog log, Payment payment\n"
-"where log.item.class = 'Payment' and log.item.id = payment.id]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:531
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>log.item.class</literal> and <literal>payment.class</literal> "
@@ -1090,13 +685,11 @@
 "질의 내에서 완전히 다른 데이터베이스 컬럼들의 값들을 참조할 것임을 노트하라."
 
 #. Tag: title
-#: query_hql.xml:539
 #, no-c-format
 msgid "Expressions"
 msgstr "표현식들"
 
 #. Tag: para
-#: query_hql.xml:541
 #, fuzzy, no-c-format
 msgid ""
 "Expressions used in the <literal>where</literal> clause include the "
@@ -1106,13 +699,11 @@
 "있는 대부분의 종류의 것들을 포함한다:"
 
 #. Tag: para
-#: query_hql.xml:548
 #, fuzzy, no-c-format
 msgid "mathematical operators: <literal>+, -, *, /</literal>"
 msgstr "산술 연산자들 <literal>+, -, *, /</literal>"
 
 #. Tag: para
-#: query_hql.xml:553
 #, fuzzy, no-c-format
 msgid ""
 "binary comparison operators: <literal>=, &gt;=, &lt;=, &lt;&gt;, !=, like</"
@@ -1121,19 +712,16 @@
 "바이너리 비교 연산자들 <literal>=, &gt;=, &lt;=, &lt;&gt;, !=, like</literal>"
 
 #. Tag: para
-#: query_hql.xml:558
 #, no-c-format
 msgid "logical operations <literal>and, or, not</literal>"
 msgstr "논리 연산들 <literal>and, or, not</literal>"
 
 #. Tag: para
-#: query_hql.xml:563
 #, fuzzy, no-c-format
 msgid "Parentheses <literal>( )</literal> that indicates grouping"
 msgstr "그룹핑을 나타내는 괄호들 <literal>( )</literal>, indicating grouping"
 
 #. Tag: para
-#: query_hql.xml:568
 #, no-c-format
 msgid ""
 "<literal>in</literal>, <literal>not in</literal>, <literal>between</"
@@ -1147,7 +735,6 @@
 "<literal>member of</literal> and <literal>not member of</literal>"
 
 #. Tag: para
-#: query_hql.xml:581
 #, no-c-format
 msgid ""
 "\"Simple\" case, <literal>case ... when ... then ... else ... end</literal>, "
@@ -1158,7 +745,6 @@
 "literal>"
 
 #. Tag: para
-#: query_hql.xml:587
 #, no-c-format
 msgid ""
 "string concatenation <literal>...||...</literal> or <literal>concat(...,...)"
@@ -1167,7 +753,6 @@
 "문자열 연결 <literal>...||...</literal> or <literal>concat(...,...)</literal>"
 
 #. Tag: para
-#: query_hql.xml:592
 #, fuzzy, no-c-format
 msgid ""
 "<literal>current_date()</literal>, <literal>current_time()</literal>, and "
@@ -1177,7 +762,6 @@
 "<literal>current_timestamp()</literal>"
 
 #. Tag: para
-#: query_hql.xml:598
 #, fuzzy, no-c-format
 msgid ""
 "<literal>second(...)</literal>, <literal>minute(...)</literal>, <literal>hour"
@@ -1189,7 +773,6 @@
 "<literal>year(...)</literal>,"
 
 #. Tag: para
-#: query_hql.xml:605
 #, no-c-format
 msgid ""
 "Any function or operator defined by EJB-QL 3.0: <literal>substring(), trim"
@@ -1201,13 +784,11 @@
 "mod()</literal>"
 
 #. Tag: para
-#: query_hql.xml:611
 #, no-c-format
 msgid "<literal>coalesce()</literal> and <literal>nullif()</literal>"
 msgstr "<literal>coalesce()</literal> 그리고 <literal>nullif()</literal>"
 
 #. Tag: para
-#: query_hql.xml:616
 #, no-c-format
 msgid ""
 "<literal>str()</literal> for converting numeric or temporal values to a "
@@ -1217,7 +798,6 @@
 "()</literal>"
 
 #. Tag: para
-#: query_hql.xml:622
 #, no-c-format
 msgid ""
 "<literal>cast(... as ...)</literal>, where the second argument is the name "
@@ -1231,7 +811,6 @@
 "literal>."
 
 #. Tag: para
-#: query_hql.xml:630
 #, no-c-format
 msgid ""
 "the HQL <literal>index()</literal> function, that applies to aliases of a "
@@ -1241,7 +820,6 @@
 "함수"
 
 #. Tag: para
-#: query_hql.xml:636
 #, fuzzy, no-c-format
 msgid ""
 "HQL functions that take collection-valued path expressions: <literal>size(), "
@@ -1257,7 +835,6 @@
 "literal>."
 
 #. Tag: para
-#: query_hql.xml:644
 #, fuzzy, no-c-format
 msgid ""
 "Any database-supported SQL scalar function like <literal>sign()</literal>, "
@@ -1269,13 +846,11 @@
 "라 함수"
 
 #. Tag: para
-#: query_hql.xml:650
 #, no-c-format
 msgid "JDBC-style positional parameters <literal>?</literal>"
 msgstr "JDBC-스타일 위치 파라미터들 <literal>?</literal>"
 
 #. Tag: para
-#: query_hql.xml:655
 #, fuzzy, no-c-format
 msgid ""
 "named parameters <literal>:name</literal>, <literal>:start_date</literal>, "
@@ -1285,7 +860,6 @@
 "<literal>:x1</literal>"
 
 #. Tag: para
-#: query_hql.xml:660
 #, no-c-format
 msgid ""
 "SQL literals <literal>'foo'</literal>, <literal>69</literal>, <literal>6.66E"
@@ -1295,7 +869,6 @@
 "+2</literal>, <literal>'1970-01-01 10:00:01.0'</literal>"
 
 #. Tag: para
-#: query_hql.xml:666
 #, no-c-format
 msgid ""
 "Java <literal>public static final</literal> constants <literal>eg.Color."
@@ -1305,7 +878,6 @@
 "literal>"
 
 #. Tag: para
-#: query_hql.xml:672
 #, fuzzy, no-c-format
 msgid ""
 "<literal>in</literal> and <literal>between</literal> can be used as follows:"
@@ -1313,41 +885,12 @@
 "<literal>in</literal> 과 <literal>between</literal>은 다음과 같이 사용될 수 "
 "있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:676
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name between 'A' and 'B']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:678
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat cat where cat.name in ( 'Foo', 'Bar', 'Baz' )]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:680
 #, fuzzy, no-c-format
 msgid "The negated forms can be written as follows:"
 msgstr "그리고 부정형들은 다음과 같이 작성될 수 있다"
 
-#. Tag: programlisting
-#: query_hql.xml:684
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name not between 'A' and 'B']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:686
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat cat where cat.name not in ( 'Foo', 'Bar', 'Baz' )]]"
-">"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:688
 #, fuzzy, no-c-format
 msgid ""
 "Similarly, <literal>is null</literal> and <literal>is not null</literal> can "
@@ -1357,7 +900,6 @@
 "null 값들을 테스트하는데 사용될 수 있다."
 
 #. Tag: para
-#: query_hql.xml:693
 #, fuzzy, no-c-format
 msgid ""
 "Booleans can be easily used in expressions by declaring HQL query "
@@ -1366,16 +908,7 @@
 "Boolean들은 Hibernate 구성 내에 HQL 질의 치환들을 선언함으로써 표현식들 내에 "
 "쉽게 사용될 수 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:698
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"hibernate.query.substitutions\">true 1, false 0</"
-"property>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:700
 #, no-c-format
 msgid ""
 "This will replace the keywords <literal>true</literal> and <literal>false</"
@@ -1386,14 +919,7 @@
 "이 HQL로부터 번역된 SQL에서 리터럴 <literal>1</literal>과 <literal>0</"
 "literal>으로 대체될 것이다:"
 
-#. Tag: programlisting
-#: query_hql.xml:705
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.alive = true]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:707
 #, fuzzy, no-c-format
 msgid ""
 "You can test the size of a collection with the special property "
@@ -1402,20 +928,7 @@
 "당신은 특별한 프로퍼티 <literal>size</literal>로서 또는 특별한 <literal>size"
 "()</literal> 함수로서 콜렉션의 사이즈를 테스트할 수 있다."
 
-#. Tag: programlisting
-#: query_hql.xml:712
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.kittens.size > 0]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:714
-#, no-c-format
-msgid "<![CDATA[from Cat cat where size(cat.kittens) > 0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:716
 #, fuzzy, no-c-format
 msgid ""
 "For indexed collections, you can refer to the minimum and maximum indices "
@@ -1430,27 +943,7 @@
 "<literal>maxelement</literal> 함수를 사용하여 기본 타입을 가진 콜렉션의 최소 "
 "요소 및 최대 요소를 참조할 수 있다."
 
-#. Tag: programlisting
-#: query_hql.xml:724
-#, no-c-format
-msgid ""
-"<![CDATA[from Calendar cal where maxelement(cal.holidays) > current_date]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:726
-#, no-c-format
-msgid "<![CDATA[from Order order where maxindex(order.items) > 100]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:728
-#, no-c-format
-msgid "<![CDATA[from Order order where minelement(order.items) > 10000]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:730
 #, fuzzy, no-c-format
 msgid ""
 "The SQL functions <literal>any, some, all, exists, in</literal> are "
@@ -1462,42 +955,7 @@
 "는 인덱스 세트(<literal>elements</literal> 함수와 <literal>indices</literal> "
 "함수), 또는 서브질의의 결과를 전달했을 때 지원된다(아래를 보라)."
 
-#. Tag: programlisting
-#: query_hql.xml:736
-#, no-c-format
-msgid ""
-"<![CDATA[select mother from Cat as mother, Cat as kit\n"
-"where kit in elements(foo.kittens)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:738
-#, no-c-format
-msgid ""
-"<![CDATA[select p from NameList list, Person p\n"
-"where p.name = some elements(list.names)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:740
-#, no-c-format
-msgid "<![CDATA[from Cat cat where exists elements(cat.kittens)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:742
-#, no-c-format
-msgid "<![CDATA[from Player p where 3 > all elements(p.scores)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:744
-#, no-c-format
-msgid "<![CDATA[from Show show where 'fizard' in indices(show.acts)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:746
 #, fuzzy, no-c-format
 msgid ""
 "Note that these constructs - <literal>size</literal>, <literal>elements</"
@@ -1512,7 +970,6 @@
 "Hibernate3에서 where 절 내에서만 사용될 것임을 노트하라."
 
 #. Tag: para
-#: query_hql.xml:753
 #, fuzzy, no-c-format
 msgid ""
 "Elements of indexed collections (arrays, lists, and maps) can be referred to "
@@ -1521,56 +978,14 @@
 "인덱싱 된 콜렉션들의 요소들(배열들, 리스트들, map들)은 인덱스에 의해 참조될 "
 "수 있다(where 절 안에서만):"
 
-#. Tag: programlisting
-#: query_hql.xml:758
-#, no-c-format
-msgid "<![CDATA[from Order order where order.items[0].id = 1234]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:760
-#, no-c-format
-msgid ""
-"<![CDATA[select person from Person person, Calendar calendar\n"
-"where calendar.holidays['national day'] = person.birthDay\n"
-"    and person.nationality.calendar = calendar]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:762
-#, no-c-format
-msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ order.deliveredItemIndices[0] ] = item and order.id = 11]]"
-">"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:764
-#, no-c-format
-msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ maxindex(order.items) ] = item and order.id = 11]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:766
 #, fuzzy, no-c-format
 msgid ""
 "The expression inside <literal>[]</literal> can even be an arithmetic "
 "expression:"
 msgstr "<literal>[]</literal> 내부의 표현식은 산술 표현실일 수 있다."
 
-#. Tag: programlisting
-#: query_hql.xml:770
-#, no-c-format
-msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ size(order.items) - 1 ] = item]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:772
 #, fuzzy, no-c-format
 msgid ""
 "HQL also provides the built-in <literal>index()</literal> function for "
@@ -1579,29 +994,12 @@
 "HQL은 또한 one-to-many 연관 또는 값들을 가진 콜렉션의 요소들에 대해 미리 만들"
 "어진 <literal>index()</literal> 함수를 제공한다."
 
-#. Tag: programlisting
-#: query_hql.xml:777
-#, no-c-format
-msgid ""
-"<![CDATA[select item, index(item) from Order order\n"
-"    join order.items item\n"
-"where index(item) < 5]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:779
 #, fuzzy, no-c-format
 msgid "Scalar SQL functions supported by the underlying database can be used:"
 msgstr "기본 데이터베이스에 의해 제공되는 Scalar SQL 함수들이 사용될 수도 있다"
 
-#. Tag: programlisting
-#: query_hql.xml:783
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where upper(cat.name) like 'FRI%']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:785
 #, fuzzy, no-c-format
 msgid ""
 "Consider how much longer and less readable the following query would be in "
@@ -1610,57 +1008,17 @@
 "당신이 아직 이 모든 것을 납득하지 못한다면, SQL 내에서 다음 질의가 가독성이 "
 "얼마나 많고 적은지를 생각해보라:"
 
-#. Tag: programlisting
-#: query_hql.xml:790
-#, no-c-format
-msgid ""
-"<![CDATA[select cust\n"
-"from Product prod,\n"
-"    Store store\n"
-"    inner join store.customers cust\n"
-"where prod.name = 'widget'\n"
-"    and store.location.name in ( 'Melbourne', 'Sydney' )\n"
-"    and prod = all elements(cust.currentOrder.lineItems)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:792
 #, no-c-format
 msgid "<emphasis>Hint:</emphasis> something like"
 msgstr "<emphasis>힌트</emphasis> : 다음과 같은 어떤 것"
 
-#. Tag: programlisting
-#: query_hql.xml:796
-#, no-c-format
-msgid ""
-"<![CDATA[SELECT cust.name, cust.address, cust.phone, cust.id, cust."
-"current_order\n"
-"FROM customers cust,\n"
-"    stores store,\n"
-"    locations loc,\n"
-"    store_customers sc,\n"
-"    product prod\n"
-"WHERE prod.name = 'widget'\n"
-"    AND store.loc_id = loc.id\n"
-"    AND loc.name IN ( 'Melbourne', 'Sydney' )\n"
-"    AND sc.store_id = store.id\n"
-"    AND sc.cust_id = cust.id\n"
-"    AND prod.id = ALL(\n"
-"        SELECT item.prod_id\n"
-"        FROM line_items item, orders o\n"
-"        WHERE item.order_id = o.id\n"
-"            AND cust.current_order = o.id\n"
-"    )]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:801
 #, no-c-format
 msgid "The order by clause"
 msgstr "order by ì ˆ"
 
 #. Tag: para
-#: query_hql.xml:803
 #, fuzzy, no-c-format
 msgid ""
 "The list returned by a query can be ordered by any property of a returned "
@@ -1669,16 +1027,7 @@
 "질의에 의해 반환된 리스트는 반환된 클래스 또는 컴포넌트들의 프로퍼티에 의해 "
 "순서(ordering)지워질 수 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:807
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat cat\n"
-"order by cat.name asc, cat.weight desc, cat.birthdate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:809
 #, no-c-format
 msgid ""
 "The optional <literal>asc</literal> or <literal>desc</literal> indicate "
@@ -1688,13 +1037,11 @@
 "순 또는 내림차순 정렬을 나타낸다."
 
 #. Tag: title
-#: query_hql.xml:816
 #, no-c-format
 msgid "The group by clause"
 msgstr "group by ì ˆ"
 
 #. Tag: para
-#: query_hql.xml:818
 #, fuzzy, no-c-format
 msgid ""
 "A query that returns aggregate values can be grouped by any property of a "
@@ -1703,42 +1050,12 @@
 "aggregate 값들을 반환하는 질의는 반환된 클래스나 컴포넌트들의 프로퍼티에 의"
 "해 그룹지워질 수 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:822
-#, no-c-format
-msgid ""
-"<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
-"from Cat cat\n"
-"group by cat.color]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:824
-#, no-c-format
-msgid ""
-"<![CDATA[select foo.id, avg(name), max(name)\n"
-"from Foo foo join foo.names name\n"
-"group by foo.id]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:826
 #, no-c-format
 msgid "A <literal>having</literal> clause is also allowed."
 msgstr "또한 <literal>having</literal> 절이 허용된다."
 
-#. Tag: programlisting
-#: query_hql.xml:830
-#, no-c-format
-msgid ""
-"<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
-"from Cat cat\n"
-"group by cat.color\n"
-"having cat.color in (eg.Color.TABBY, eg.Color.BLACK)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:832
 #, fuzzy, no-c-format
 msgid ""
 "SQL functions and aggregate functions are allowed in the <literal>having</"
@@ -1749,20 +1066,7 @@
 "MySQL은 지원되지 않는다) <literal>having</literal> 절과 <literal>order by</"
 "literal> 절 속에 허용된다."
 
-#. Tag: programlisting
-#: query_hql.xml:838
-#, no-c-format
-msgid ""
-"<![CDATA[select cat\n"
-"from Cat cat\n"
-"    join cat.kittens kitten\n"
-"group by cat.id, cat.name, cat.other, cat.properties\n"
-"having avg(kitten.weight) > 100\n"
-"order by count(kitten) asc, sum(kitten.weight) desc]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:840
 #, fuzzy, no-c-format
 msgid ""
 "Neither the <literal>group by</literal> clause nor the <literal>order by</"
@@ -1778,13 +1082,11 @@
 "라. 당신은 명시적으로 모든 집계되지 않는 속성들을 리스트해야 한다."
 
 #. Tag: title
-#: query_hql.xml:852
 #, no-c-format
 msgid "Subqueries"
 msgstr "서브질의들"
 
 #. Tag: para
-#: query_hql.xml:854
 #, no-c-format
 msgid ""
 "For databases that support subselects, Hibernate supports subqueries within "
@@ -1797,79 +1099,28 @@
 "해). 심지어 서로 상관된 서브질의들(외부 질의 내에서 alias를 참조하는 서브질의"
 "들)이 허용된다."
 
-#. Tag: programlisting
-#: query_hql.xml:860
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as fatcat\n"
-"where fatcat.weight > (\n"
-"    select avg(cat.weight) from DomesticCat cat\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:862
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat as cat\n"
-"where cat.name = some (\n"
-"    select name.nickName from Name as name\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:864
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"where not exists (\n"
-"    from Cat as mate where mate.mate = cat\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:866
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat as cat\n"
-"where cat.name not in (\n"
-"    select name.nickName from Name as name\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:868
-#, no-c-format
-msgid ""
-"<![CDATA[select cat.id, (select max(kit.weight) from cat.kitten kit)\n"
-"from Cat as cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:870
 #, fuzzy, no-c-format
 msgid "Note that HQL subqueries can occur only in the select or where clauses."
 msgstr ""
 "HQL 서브질의들이 select 절 또는 where 절 내에서만 일어날 수 있음을 노트하라."
 
 #. Tag: para
-#: query_hql.xml:874
 #, fuzzy, no-c-format
 msgid ""
 "Note that subqueries can also utilize <literal>row value constructor</"
-"literal> syntax. See <xref linkend=\"queryhql-tuple\"/> for more information."
+"literal> syntax. See <xref linkend=\"queryhql-tuple\" /> for more "
+"information."
 msgstr ""
 "서브질의들은 또한 <literal>row value constructor</literal> 구문을 활용할 수 "
 "있다. 상세한 것은 <xref linkend=\"queryhql-tuple\"/>를 보라."
 
 #. Tag: title
-#: query_hql.xml:882
 #, no-c-format
 msgid "HQL examples"
 msgstr "HQL 예제들"
 
 #. Tag: para
-#: query_hql.xml:884
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate queries can be quite powerful and complex. In fact, the power of "
@@ -1884,7 +1135,6 @@
 "의 질의들은 이것들보다 훨씬 간단하다는 점을 노트하라!"
 
 #. Tag: para
-#: query_hql.xml:890
 #, fuzzy, no-c-format
 msgid ""
 "The following query returns the order id, number of items, the given minimum "
@@ -1903,32 +1153,7 @@
 "<literal>PRICE</literal> 테이블들에 대한 네 개의 inner 조인들과 한 개의(상관"
 "지워지지 않은) subselect를 갖고 있다."
 
-#. Tag: programlisting
-#: query_hql.xml:899
-#, no-c-format
-msgid ""
-"<![CDATA[select order.id, sum(price.amount), count(item)\n"
-"from Order as order\n"
-"    join order.lineItems as item\n"
-"    join item.product as product,\n"
-"    Catalog as catalog\n"
-"    join catalog.prices as price\n"
-"where order.paid = false\n"
-"    and order.customer = :customer\n"
-"    and price.product = product\n"
-"    and catalog.effectiveDate < sysdate\n"
-"    and catalog.effectiveDate >= all (\n"
-"        select cat.effectiveDate\n"
-"        from Catalog as cat\n"
-"        where cat.effectiveDate < sysdate\n"
-"    )\n"
-"group by order\n"
-"having sum(price.amount) > :minAmount\n"
-"order by sum(price.amount) desc]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:901
 #, no-c-format
 msgid ""
 "What a monster! Actually, in real life, I'm not very keen on subqueries, so "
@@ -1937,27 +1162,7 @@
 "괴물 같은 것! 실제로 실 생활에서, 나는 서브질의들을 매우 좋아하지 않아서, 나"
 "의 질의는 실제로 다음과 같았다:"
 
-#. Tag: programlisting
-#: query_hql.xml:906
-#, no-c-format
-msgid ""
-"<![CDATA[select order.id, sum(price.amount), count(item)\n"
-"from Order as order\n"
-"    join order.lineItems as item\n"
-"    join item.product as product,\n"
-"    Catalog as catalog\n"
-"    join catalog.prices as price\n"
-"where order.paid = false\n"
-"    and order.customer = :customer\n"
-"    and price.product = product\n"
-"    and catalog = :currentCatalog\n"
-"group by order\n"
-"having sum(price.amount) > :minAmount\n"
-"order by sum(price.amount) desc]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:908
 #, no-c-format
 msgid ""
 "The next query counts the number of payments in each status, excluding all "
@@ -1974,29 +1179,7 @@
 "literal> 테이블들에 대한 두 개의 inner 조인들과 하나의 상관관계 지워진 "
 "subselect를 가진 SQL 질의로 변환된다."
 
-#. Tag: programlisting
-#: query_hql.xml:916
-#, no-c-format
-msgid ""
-"<![CDATA[select count(payment), status.name\n"
-"from Payment as payment\n"
-"    join payment.currentStatus as status\n"
-"    join payment.statusChanges as statusChange\n"
-"where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-"    or (\n"
-"        statusChange.timeStamp = (\n"
-"            select max(change.timeStamp)\n"
-"            from PaymentStatusChange change\n"
-"            where change.payment = payment\n"
-"        )\n"
-"        and statusChange.user <> :currentUser\n"
-"    )\n"
-"group by status.name, status.sortOrder\n"
-"order by status.sortOrder]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:918
 #, fuzzy, no-c-format
 msgid ""
 "If the <literal>statusChanges</literal> collection was mapped as a list, "
@@ -2005,22 +1188,7 @@
 "만일 내가 <literal>statusChanges</literal> 콜렉션을 set가 아닌 list로 매핑했"
 "다면, 그 질의는 작성하기가 훨씬 더 간단했을 것이다."
 
-#. Tag: programlisting
-#: query_hql.xml:923
-#, no-c-format
-msgid ""
-"<![CDATA[select count(payment), status.name\n"
-"from Payment as payment\n"
-"    join payment.currentStatus as status\n"
-"where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-"    or payment.statusChanges[ maxIndex(payment.statusChanges) ].user <> :"
-"currentUser\n"
-"group by status.name, status.sortOrder\n"
-"order by status.sortOrder]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:925
 #, no-c-format
 msgid ""
 "The next query uses the MS SQL Server <literal>isNull()</literal> function "
@@ -2039,21 +1207,7 @@
 "세 개의 inner 조인들, 하나의 outer 조인, 그리고 하나의 subselect를 가진 한 개"
 "의 SQL 질의로 번역된다."
 
-#. Tag: programlisting
-#: query_hql.xml:934
-#, no-c-format
-msgid ""
-"<![CDATA[select account, payment\n"
-"from Account as account\n"
-"    left outer join account.payments as payment\n"
-"where :currentUser in elements(account.holder.users)\n"
-"    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
-"PaymentStatus.UNPAID)\n"
-"order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:936
 #, no-c-format
 msgid ""
 "For some databases, we would need to do away with the (correlated) subselect."
@@ -2061,80 +1215,41 @@
 "몇몇 데이터베이스들의 경우, 우리는 (상관관계 지워진) subselect를 없앨 필요가 "
 "있을 것이다."
 
-#. Tag: programlisting
-#: query_hql.xml:940
-#, no-c-format
-msgid ""
-"<![CDATA[select account, payment\n"
-"from Account as account\n"
-"    join account.holder.users as user\n"
-"    left outer join account.payments as payment\n"
-"where :currentUser = user\n"
-"    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
-"PaymentStatus.UNPAID)\n"
-"order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:945
 #, no-c-format
 msgid "Bulk update and delete"
 msgstr "대량 update와 delete"
 
 #. Tag: para
-#: query_hql.xml:947
 #, fuzzy, no-c-format
 msgid ""
 "HQL now supports <literal>update</literal>, <literal>delete</literal> and "
 "<literal>insert ... select ...</literal> statements. See <xref linkend="
-"\"batch-direct\"/> for more information."
+"\"batch-direct\" /> for more information."
 msgstr ""
 "HQL은 이제 <literal>update</literal>, <literal>delete</literal> 그리고 "
 "<literal>insert ... select ...</literal> 문장들을 지원한다. 상세한 것은 "
 "<xref linkend=\"batch-direct\"/>를 보라."
 
 #. Tag: title
-#: query_hql.xml:955
 #, no-c-format
 msgid "Tips &amp; Tricks"
 msgstr "팁들 &amp; 트릭들"
 
 #. Tag: para
-#: query_hql.xml:957
 #, fuzzy, no-c-format
 msgid "You can count the number of query results without returning them:"
 msgstr ""
 "당신은 실제로 질의 결과들을 반환하지 않고서 그것들(질의 결과들)의 개수를 카운"
 "트할 수 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:961
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
-"iterate().next() ).intValue()]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:963
 #, no-c-format
 msgid "To order a result by the size of a collection, use the following query:"
 msgstr ""
 "콜렉션의 크기에 따라 결과를 순서(ordering)지우려면, 다음 질의를 사용하라:"
 
-#. Tag: programlisting
-#: query_hql.xml:967
-#, no-c-format
-msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User as usr\n"
-"    left join usr.messages as msg\n"
-"group by usr.id, usr.name\n"
-"order by count(msg)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:969
 #, no-c-format
 msgid ""
 "If your database supports subselects, you can place a condition upon "
@@ -2143,33 +1258,14 @@
 "만일 당신의 데이터베이스가 subselect들을 지원할 경우, 당신은 당신의 질의의 "
 "where 절 내에 selection 사이즈에 대한 조건을 위치지울 수 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:974
-#, no-c-format
-msgid "<![CDATA[from User usr where size(usr.messages) >= 1]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:976
 #, fuzzy, no-c-format
 msgid "If your database does not support subselects, use the following query:"
 msgstr ""
 "만일 당신의 데이터베이스가 subselect를 지원하지 않을 경우, 다음 질의를 사용하"
 "라:"
 
-#. Tag: programlisting
-#: query_hql.xml:980
-#, no-c-format
-msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User usr.name\n"
-"    join usr.messages msg\n"
-"group by usr.id, usr.name\n"
-"having count(msg) >= 1]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:983
 #, fuzzy, no-c-format
 msgid ""
 "As this solution cannot return a <literal>User</literal> with zero messages "
@@ -2178,36 +1274,13 @@
 "이 해결책이 inner 조인 때문에 0개의 메시지를 가진 <literal>User</literal>를 "
 "반환할 수 없으므로, 다음 형식이 또한 유용하다:"
 
-#. Tag: programlisting
-#: query_hql.xml:988
-#, no-c-format
-msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User as usr\n"
-"    left join usr.messages as msg\n"
-"group by usr.id, usr.name\n"
-"having count(msg) = 0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:990
 #, no-c-format
 msgid "Properties of a JavaBean can be bound to named query parameters:"
 msgstr ""
 "하나의 JavaBean의 프로퍼티들은 명명된 질의 파라미터들에 바인드될 수 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:994
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = s.createQuery(\"from foo Foo as foo where foo.name=:name "
-"and foo.size=:size\");\n"
-"q.setProperties(fooBean); // fooBean has getName() and getSize()\n"
-"List foos = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:996
 #, no-c-format
 msgid ""
 "Collections are pageable by using the <literal>Query</literal> interface "
@@ -2216,57 +1289,24 @@
 "콜렉션들은 필터를 가진 <literal>Query</literal> 인터페이스를 사용하여 쪼매김"
 "하는 것이 가능하다:"
 
-#. Tag: programlisting
-#: query_hql.xml:1000
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = s.createFilter( collection, \"\" ); // the trivial "
-"filter\n"
-"q.setMaxResults(PAGE_SIZE);\n"
-"q.setFirstResult(PAGE_SIZE * pageNumber);\n"
-"List page = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1002
 #, fuzzy, no-c-format
 msgid "Collection elements can be ordered or grouped using a query filter:"
 msgstr ""
 "콜렉션 요소들은 질의 필터를 사용하여 순서(ordering)지워지거나 그룹지워질 수 "
 "도 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:1006
-#, no-c-format
-msgid ""
-"<![CDATA[Collection orderedCollection = s.filter( collection, \"order by "
-"this.amount\" );\n"
-"Collection counts = s.filter( collection, \"select this.type, count(this) "
-"group by this.type\" );]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1008
 #, no-c-format
 msgid "You can find the size of a collection without initializing it:"
 msgstr "당신은 콜렉션을 초기화 하지 않고서 그것(콜렉션)의 크기를 찾을 수 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:1012
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
-"iterate().next() ).intValue();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:1017
 #, no-c-format
 msgid "Components"
 msgstr "컴포넌트들"
 
 #. Tag: para
-#: query_hql.xml:1019
 #, fuzzy, no-c-format
 msgid ""
 "Components can be used similarly to the simple value types that are used in "
@@ -2277,20 +1317,7 @@
 "으로 사용될 수 있다. 그것들은 <literal>select</literal> 절 내에 나타날 수 있"
 "다."
 
-#. Tag: programlisting
-#: query_hql.xml:1024 query_hql.xml:1070
-#, no-c-format
-msgid "<![CDATA[select p.name from Person p]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1025
-#, no-c-format
-msgid "<![CDATA[select p.name.first from Person p]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1027
 #, no-c-format
 msgid ""
 "where the Person's name property is a component. Components can also be used "
@@ -2299,38 +1326,12 @@
 "여기서 Person의 name 속성은 컴포넌트이다. 컴포넌트들은 또한 <literal>where</"
 "literal> 절 내에 사용될 수 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:1032
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name = :name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1033
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name.first = :firstName]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1035
 #, no-c-format
 msgid "Components can also be used in the <literal>order by</literal> clause:"
 msgstr "컴포넌트들은 또한 <literal>order by</literal> 절 내에 사용될 수 있다:"
 
-#. Tag: programlisting
-#: query_hql.xml:1039
-#, no-c-format
-msgid "<![CDATA[from Person p order by p.name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1040
-#, no-c-format
-msgid "<![CDATA[from Person p order by p.name.first]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1042
 #, no-c-format
 msgid ""
 "Another common use of components is in <link linkend=\"queryhql-tuple\">row "
@@ -2340,13 +1341,11 @@
 "\">row value constructors</xref>에 있다."
 
 #. Tag: title
-#: query_hql.xml:1048
 #, no-c-format
 msgid "Row value constructor syntax"
 msgstr "Row value constructor 구문"
 
 #. Tag: para
-#: query_hql.xml:1050
 #, fuzzy, no-c-format
 msgid ""
 "HQL supports the use of ANSI SQL <literal>row value constructor</literal> "
@@ -2361,16 +1360,7 @@
 "넌트들과 연관되어 있는 다중-값 비교들을 일반적으로 언급하고 있다. name 컴포넌"
 "트를 정의하는 Person 엔티티를 검토하자:"
 
-#. Tag: programlisting
-#: query_hql.xml:1057
-#, no-c-format
-msgid ""
-"<![CDATA[from Person p where p.name.first='John' and p.name."
-"last='Jingleheimer-Schmidt']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1059
 #, fuzzy, no-c-format
 msgid ""
 "That is valid syntax although it is a little verbose. You can make this more "
@@ -2379,14 +1369,7 @@
 "비록 약간 장황스럽지만 그것은 유효한 구문이다. 이것을 약간 더 간결하게 만들"
 "고 <literal>row value constructor</literal> 구문을 사용하는 것이 좋다:"
 
-#. Tag: programlisting
-#: query_hql.xml:1064
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name=('John', 'Jingleheimer-Schmidt')]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1066
 #, no-c-format
 msgid ""
 "It can also be useful to specify this in the <literal>select</literal> "
@@ -2395,7 +1378,6 @@
 "<literal>select</literal>절 내에 이것을 지정하는 것이 또한 유용할 수 있다:"
 
 #. Tag: para
-#: query_hql.xml:1072
 #, fuzzy, no-c-format
 msgid ""
 "Using <literal>row value constructor</literal> syntax can also be beneficial "
@@ -2404,18 +1386,7 @@
 "<literal>row value constructor</literal> 구문을 사용하는 또 다른 경우는 다중 "
 "값들에 대해 비교할 필요가 있는 서브 질의들을 사용할 때이다:"
 
-#. Tag: programlisting
-#: query_hql.xml:1077
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"where not ( cat.name, cat.color ) in (\n"
-"    select cat.name, cat.color from DomesticCat cat\n"
-")]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1079
 #, fuzzy, no-c-format
 msgid ""
 "One thing to consider when deciding if you want to use this syntax, is that "
@@ -2425,6 +1396,15 @@
 "만일 당신이 이 구문을 사용하고자 원할 경우에 고려해야 할 한 가지는 질의가 메"
 "타데이터 내에 있는 컴포넌트 서브-속성들의 순서에 종속될 것이라는 점이다."
 
+#~ msgid "inner join"
+#~ msgstr "inner join"
+
+#~ msgid "left outer join"
+#~ msgstr "left outer join"
+
+#~ msgid "count(*)"
+#~ msgstr "count(*)"
+
 #~ msgid ""
 #~ "Most of the time, you will need to assign an <emphasis>alias</emphasis>, "
 #~ "since you will want to refer to the <literal>Cat</literal> in other parts "

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/query_sql.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/query_sql.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/query_sql.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,13 +11,11 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: query_sql.xml:29
 #, no-c-format
 msgid "Native SQL"
 msgstr "Native SQL"
 
 #. Tag: para
-#: query_sql.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "You can also express queries in the native SQL dialect of your database. "
@@ -33,7 +31,6 @@
 "료한 이전 경로를 제공한다."
 
 #. Tag: para
-#: query_sql.xml:37
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate3 allows you to specify handwritten SQL, including stored "
@@ -44,13 +41,11 @@
 "다."
 
 #. Tag: title
-#: query_sql.xml:41
 #, no-c-format
 msgid "Using a <literal>SQLQuery</literal>"
 msgstr "<literal>SQLQuery</literal> 사용하기"
 
 #. Tag: para
-#: query_sql.xml:43
 #, fuzzy, no-c-format
 msgid ""
 "Execution of native SQL queries is controlled via the <literal>SQLQuery</"
@@ -63,28 +58,16 @@
 "다. 다음은 이 API를 질의에 사용하는 방법을 설명한다."
 
 #. Tag: title
-#: query_sql.xml:49
 #, no-c-format
 msgid "Scalar queries"
 msgstr "스칼라 질의들"
 
 #. Tag: para
-#: query_sql.xml:51
 #, no-c-format
 msgid "The most basic SQL query is to get a list of scalars (values)."
 msgstr "가장 기본적인 SQL 질의는 스칼라들(값들)의 목록을 얻는 것이다."
 
-#. Tag: programlisting
-#: query_sql.xml:54
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").list();\n"
-"sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").list();\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:56
 #, fuzzy, no-c-format
 msgid ""
 "These will return a List of Object arrays (Object[]) with scalar values for "
@@ -96,7 +79,6 @@
 "제 순서와 타입들을 도출하는데 ResultSetMetadata를 사용할 것이다."
 
 #. Tag: para
-#: query_sql.xml:61
 #, fuzzy, no-c-format
 msgid ""
 "To avoid the overhead of using <literal>ResultSetMetadata</literal>, or "
@@ -107,37 +89,22 @@
 "환되는 것을 보다 명시적이게끔 하기 위해 우리는 <literal>addScalar()</literal>"
 "를 사용할 수 있다."
 
-#. Tag: programlisting
-#: query_sql.xml:65
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-" .addScalar(\"ID\", Hibernate.LONG)\n"
-" .addScalar(\"NAME\", Hibernate.STRING)\n"
-" .addScalar(\"BIRTHDATE\", Hibernate.DATE)\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:67 query_sql.xml:113 query_sql.xml:198 query_sql.xml:349
 #, no-c-format
 msgid "This query specified:"
 msgstr "이 질의는 다음을 지정했다:"
 
 #. Tag: para
-#: query_sql.xml:71 query_sql.xml:117 query_sql.xml:353
 #, no-c-format
 msgid "the SQL query string"
 msgstr "SQL 질의 문자열"
 
 #. Tag: para
-#: query_sql.xml:75
 #, no-c-format
 msgid "the columns and types to return"
 msgstr "반환할 컬럼들과 타입들"
 
 #. Tag: para
-#: query_sql.xml:79
 #, fuzzy, no-c-format
 msgid ""
 "This will return Object arrays, but now it will not use "
@@ -155,26 +122,13 @@
 "세 개의 컬럼들 만이 반환될 것임을 의미한다."
 
 #. Tag: para
-#: query_sql.xml:87
 #, no-c-format
 msgid ""
 "It is possible to leave out the type information for all or some of the "
 "scalars."
 msgstr "스칼라들 중 몇몇 또는 전부에 대한 타입 정보를 남겨두는 것이 가능하다."
 
-#. Tag: programlisting
-#: query_sql.xml:90
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-" .addScalar(\"ID\", Hibernate.LONG)\n"
-" .addScalar(\"NAME\")\n"
-" .addScalar(\"BIRTHDATE\")\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:92
 #, fuzzy, no-c-format
 msgid ""
 "This is essentially the same query as before, but now "
@@ -186,7 +140,6 @@
 "로 NAME과 BIRTHDATE의 타입을 결정하는데 사용된다."
 
 #. Tag: para
-#: query_sql.xml:96
 #, fuzzy, no-c-format
 msgid ""
 "How the java.sql.Types returned from ResultSetMetaData is mapped to "
@@ -201,13 +154,11 @@
 "시키는 것이 가능하다."
 
 #. Tag: title
-#: query_sql.xml:104
 #, no-c-format
 msgid "Entity queries"
 msgstr "Entity 질의들"
 
 #. Tag: para
-#: query_sql.xml:106
 #, no-c-format
 msgid ""
 "The above queries were all about returning scalar values, basically "
@@ -219,24 +170,12 @@
 "본적으로 반환하는 것에 대한 전부였다. 다음은 <literal>addEntity()</literal>"
 "를 통해 native sql 질의로부터 엔티티 객체들을 얻는 방법을 보여준다."
 
-#. Tag: programlisting
-#: query_sql.xml:111
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").addEntity(Cat.class);\n"
-"sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").addEntity(Cat."
-"class);\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:121
 #, no-c-format
 msgid "the entity returned by the query"
 msgstr "그 질의에 의해 반환되는 엔티티"
 
 #. Tag: para
-#: query_sql.xml:125
 #, no-c-format
 msgid ""
 "Assuming that Cat is mapped as a class with the columns ID, NAME and "
@@ -247,7 +186,6 @@
 "둘다 각각의 요소가 하나의 Cat 엔티티인 하나의 List를 반환할 것이다."
 
 #. Tag: para
-#: query_sql.xml:129
 #, no-c-format
 msgid ""
 "If the entity is mapped with a <literal>many-to-one</literal> to another "
@@ -264,29 +202,17 @@
 "음 <literal>Dog</literal>에 대한 <literal>many-to-one</literal> 예제에서처럼 "
 "명시적인 것을 더 선호한다:"
 
-#. Tag: programlisting
-#: query_sql.xml:137
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, DOG_ID FROM CATS"
-"\").addEntity(Cat.class);\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:139
 #, no-c-format
 msgid "This will allow cat.getDog() to function properly."
 msgstr "이것은 cat.getDog()이 고유하게 기능하는 것을 허용한다."
 
 #. Tag: title
-#: query_sql.xml:143
 #, no-c-format
 msgid "Handling associations and collections"
 msgstr "연관들과 콜렉션들을 처리하기"
 
 #. Tag: para
-#: query_sql.xml:145
 #, no-c-format
 msgid ""
 "It is possible to eagerly join in the <literal>Dog</literal> to avoid the "
@@ -299,19 +225,7 @@
 "<literal>addJoin()</literal> 메소드를 통해 행해지는데, 그것은 연관이나 콜렉"
 "션 내에서 조인시키는 것을 당신에게 허용해준다."
 
-#. Tag: programlisting
-#: query_sql.xml:150
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT c.ID, NAME, BIRTHDATE, DOG_ID, D_ID, "
-"D_NAME FROM CATS c, DOGS d WHERE c.DOG_ID = d.D_ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addJoin(\"cat.dog\");\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:152
 #, fuzzy, no-c-format
 msgid ""
 "In this example, the returned <literal>Cat</literal>'s will have their "
@@ -328,19 +242,7 @@
 "<literal>Cat</literal>이 <literal>Dog</literal>에 대해 one-to-many를 가질 경"
 "우, 콜렉션들에 대해 동일한 eager joining을 행하는 것이 가능하다."
 
-#. Tag: programlisting
-#: query_sql.xml:160
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, D_ID, D_NAME, "
-"CAT_ID FROM CATS c, DOGS d WHERE c.ID = d.CAT_ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addJoin(\"cat.dogs\");\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:162
 #, fuzzy, no-c-format
 msgid ""
 "At this stage you are reaching the limits of what is possible with native "
@@ -354,13 +256,11 @@
 "또는 디폴트 alias/column 이름들이 충분하지 않을 때 발생하기 시작한다."
 
 #. Tag: title
-#: query_sql.xml:170
 #, no-c-format
 msgid "Returning multiple entities"
 msgstr "여러 개의 엔티티들을 반환하기"
 
 #. Tag: para
-#: query_sql.xml:172
 #, fuzzy, no-c-format
 msgid ""
 "Until now, the result set column names are assumed to be the same as the "
@@ -374,26 +274,13 @@
 "다."
 
 #. Tag: para
-#: query_sql.xml:177
 #, no-c-format
 msgid ""
 "Column alias injection is needed in the following query (which most likely "
 "will fail):"
 msgstr "컬럼 alias 주입은 다음 질의(아마 실패할 것이다)에서 필요하다:"
 
-#. Tag: programlisting
-#: query_sql.xml:180
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT c.*, m.*  FROM CATS c, CATS m WHERE c."
-"MOTHER_ID = c.ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addEntity(\"mother\", Cat.class)\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:184
 #, fuzzy, no-c-format
 msgid ""
 "The query was intended to return two Cat instances per row: a cat and its "
@@ -410,24 +297,11 @@
 "\" 등의 형식일 것이다."
 
 #. Tag: para
-#: query_sql.xml:193
 #, no-c-format
 msgid "The following form is not vulnerable to column name duplication:"
 msgstr "다음 형식은 컬럼 이름 중복 취약점을 갖지 않는다:"
 
-#. Tag: programlisting
-#: query_sql.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT {cat.*}, {mother.*}  FROM CATS c, CATS "
-"m WHERE c.MOTHER_ID = c.ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addEntity(\"mother\", Cat.class)\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:202
 #, no-c-format
 msgid ""
 "the SQL query string, with placeholders for Hibernate to inject column "
@@ -436,13 +310,11 @@
 "컬럼 alias들을 주입하기 위한 Hibernate용 placeholder들을 가진 SQL 질의 문자열"
 
 #. Tag: para
-#: query_sql.xml:207
 #, no-c-format
 msgid "the entities returned by the query"
 msgstr "그 질의에 의해 반환되는 엔티티들"
 
 #. Tag: para
-#: query_sql.xml:211
 #, fuzzy, no-c-format
 msgid ""
 "The {cat.*} and {mother.*} notation used above is a shorthand for \"all "
@@ -461,29 +333,12 @@
 "터 내에 선언된 것으로의 Cat들과 그것들의 mother들을 검색한다. 우리는 우리가 "
 "좋다면 심지어 where 절 내에 프로퍼티 alias를 사용할 수도 있음을 주지하라."
 
-#. Tag: programlisting
-#: query_sql.xml:220
-#, no-c-format
-msgid ""
-"<![CDATA[String sql = \"SELECT ID as {c.id}, NAME as {c.name}, \" + \n"
-"         \"BIRTHDATE as {c.birthDate}, MOTHER_ID as {c.mother}, {mother.*} "
-"\" +\n"
-"         \"FROM CAT_LOG c, CAT_LOG m WHERE {c.mother} = c.ID\";\n"
-"\n"
-"List loggedCats = sess.createSQLQuery(sql)\n"
-"        .addEntity(\"cat\", Cat.class)\n"
-"        .addEntity(\"mother\", Cat.class).list()\n"
-"]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:223
 #, no-c-format
 msgid "Alias and property references"
 msgstr "alias 참조와 프로퍼티 참조"
 
 #. Tag: para
-#: query_sql.xml:225
 #, fuzzy, no-c-format
 msgid ""
 "In most cases the above alias injection is needed. For queries relating to "
@@ -497,7 +352,6 @@
 "데 사용될 몇몇 특별한 alias들이 존재한다."
 
 #. Tag: para
-#: query_sql.xml:230
 #, fuzzy, no-c-format
 msgid ""
 "The following table shows the different ways you can use the alias "
@@ -510,211 +364,178 @@
 "과 아마 다른 이름을 가질 것이다."
 
 #. Tag: title
-#: query_sql.xml:236
 #, no-c-format
 msgid "Alias injection names"
 msgstr "alias 주입 이름들"
 
 #. Tag: entry
-#: query_sql.xml:247
 #, no-c-format
 msgid "Description"
 msgstr "설명"
 
 #. Tag: entry
-#: query_sql.xml:249
 #, no-c-format
 msgid "Syntax"
 msgstr "구문"
 
 #. Tag: entry
-#: query_sql.xml:251
 #, no-c-format
 msgid "Example"
 msgstr "예제"
 
 #. Tag: entry
-#: query_sql.xml:257
 #, no-c-format
 msgid "A simple property"
 msgstr "간단한 프로퍼티"
 
-#. Tag: literal
-#: query_sql.xml:259
-#, no-c-format
-msgid "{[aliasname].[propertyname]"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].[propertyname]</literal>"
 msgstr "{[aliasname].[propertyname]"
 
-#. Tag: literal
-#: query_sql.xml:261
-#, no-c-format
-msgid "A_NAME as {item.name}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>A_NAME as {item.name}</literal>"
 msgstr "A_NAME as {item.name}"
 
 #. Tag: entry
-#: query_sql.xml:265
 #, no-c-format
 msgid "A composite property"
 msgstr "composite 프로퍼티"
 
-#. Tag: literal
-#: query_sql.xml:267
-#, no-c-format
-msgid "{[aliasname].[componentname].[propertyname]}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].[componentname].[propertyname]}</literal>"
 msgstr "{[aliasname].[componentname].[propertyname]}"
 
-#. Tag: literal
-#: query_sql.xml:269
-#, no-c-format
-msgid "CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}</"
+"literal>"
 msgstr "CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}"
 
 #. Tag: entry
-#: query_sql.xml:274
 #, no-c-format
 msgid "Discriminator of an entity"
 msgstr "엔티티의 판별자(Discriminator)"
 
-#. Tag: literal
-#: query_sql.xml:276
-#, no-c-format
-msgid "{[aliasname].class}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].class}</literal>"
 msgstr "{[aliasname].class}"
 
-#. Tag: literal
-#: query_sql.xml:278
-#, no-c-format
-msgid "DISC as {item.class}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>DISC as {item.class}</literal>"
 msgstr "DISC as {item.class}"
 
 #. Tag: entry
-#: query_sql.xml:282
 #, no-c-format
 msgid "All properties of an entity"
 msgstr "엔티티의 모든 프로퍼티들"
 
-#. Tag: literal
-#: query_sql.xml:284 query_sql.xml:332
-#, no-c-format
-msgid "{[aliasname].*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].*}</literal>"
 msgstr "{[aliasname].*}"
 
-#. Tag: literal
-#: query_sql.xml:286
-#, no-c-format
-msgid "{item.*}"
-msgstr "{item.*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{item.*}</literal>"
+msgstr "<literal>SQLQuery</literal> 사용하기"
 
 #. Tag: entry
-#: query_sql.xml:290
 #, no-c-format
 msgid "A collection key"
 msgstr "콜렉션 키"
 
-#. Tag: literal
-#: query_sql.xml:292
-#, no-c-format
-msgid "{[aliasname].key}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].key}</literal>"
 msgstr "{[aliasname].key}"
 
-#. Tag: literal
-#: query_sql.xml:294
-#, no-c-format
-msgid "ORGID as {coll.key}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>ORGID as {coll.key}</literal>"
 msgstr "ORGID as {coll.key}"
 
 #. Tag: entry
-#: query_sql.xml:298
 #, no-c-format
 msgid "The id of an collection"
 msgstr "콜렉션의 id"
 
-#. Tag: literal
-#: query_sql.xml:300
-#, no-c-format
-msgid "{[aliasname].id}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].id}</literal>"
 msgstr "{[aliasname].id}"
 
-#. Tag: literal
-#: query_sql.xml:302
-#, no-c-format
-msgid "EMPID as {coll.id}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>EMPID as {coll.id}</literal>"
 msgstr "EMPID as {coll.id}"
 
 #. Tag: entry
-#: query_sql.xml:306
 #, no-c-format
 msgid "The element of an collection"
 msgstr "콜렉션의 요소"
 
-#. Tag: literal
-#: query_sql.xml:308
-#, no-c-format
-msgid "{[aliasname].element}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element}</literal>"
 msgstr "{[aliasname].element}"
 
-#. Tag: literal
-#: query_sql.xml:310
-#, no-c-format
-msgid "XID as {coll.element}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>XID as {coll.element}</literal>"
 msgstr "XID as {coll.element}"
 
 #. Tag: entry
-#: query_sql.xml:314
 #, fuzzy, no-c-format
 msgid "property of the element in the collection"
 msgstr "콜렉션 내에 있는 요소의 프로퍼티"
 
-#. Tag: literal
-#: query_sql.xml:316
-#, no-c-format
-msgid "{[aliasname].element.[propertyname]}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element.[propertyname]}</literal>"
 msgstr "{[aliasname].element.[propertyname]}"
 
-#. Tag: literal
-#: query_sql.xml:318
-#, no-c-format
-msgid "NAME as {coll.element.name}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>NAME as {coll.element.name}</literal>"
 msgstr "NAME as {coll.element.name}"
 
 #. Tag: entry
-#: query_sql.xml:322
 #, no-c-format
 msgid "All properties of the element in the collection"
 msgstr "콜렉션 내에 있는 요소의 모든 프로퍼티들"
 
-#. Tag: literal
-#: query_sql.xml:324
-#, no-c-format
-msgid "{[aliasname].element.*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element.*}</literal>"
 msgstr "{[aliasname].element.*}"
 
-#. Tag: literal
-#: query_sql.xml:326
-#, no-c-format
-msgid "{coll.element.*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{coll.element.*}</literal>"
 msgstr "{coll.element.*}"
 
 #. Tag: entry
-#: query_sql.xml:330
 #, no-c-format
 msgid "All properties of the the collection"
 msgstr "콜렉션의 모든 프로퍼티들"
 
-#. Tag: literal
-#: query_sql.xml:334
-#, no-c-format
-msgid "{coll.*}"
-msgstr "{coll.*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{coll.*}</literal>"
+msgstr "<literal>SQLQuery</literal> 사용하기"
 
 #. Tag: title
-#: query_sql.xml:343
 #, no-c-format
 msgid "Returning non-managed entities"
 msgstr "non-managed 엔티티들을 반환하기"
 
 #. Tag: para
-#: query_sql.xml:345
 #, fuzzy, no-c-format
 msgid ""
 "It is possible to apply a ResultTransformer to native SQL queries, allowing "
@@ -723,22 +544,12 @@
 "native sql 질의에 ResultTransformer를 적용하는 것이 가능하다. 예를 들어 non-"
 "managed 엔티티들을 반환하기 위해 ResultTransformer를 허용하는 것."
 
-#. Tag: programlisting
-#: query_sql.xml:347
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT NAME, BIRTHDATE FROM CATS\")\n"
-"        .setResultTransformer(Transformers.aliasToBean(CatDTO.class))]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:357
 #, no-c-format
 msgid "a result transformer"
 msgstr "결과 변환자(transformer)"
 
 #. Tag: para
-#: query_sql.xml:361
 #, no-c-format
 msgid ""
 "The above query will return a list of <literal>CatDTO</literal> which has "
@@ -750,13 +561,11 @@
 "literal>의 리스트를 반환할 것이다."
 
 #. Tag: title
-#: query_sql.xml:368
 #, no-c-format
 msgid "Handling inheritance"
 msgstr "상속 처리하기"
 
 #. Tag: para
-#: query_sql.xml:370
 #, fuzzy, no-c-format
 msgid ""
 "Native SQL queries which query for entities that are mapped as part of an "
@@ -767,39 +576,22 @@
 "의 모든 프로퍼티들을 포함해야 하고 그 모든 것이 서브클래스화 되어야 한다."
 
 #. Tag: title
-#: query_sql.xml:376
 #, no-c-format
 msgid "Parameters"
 msgstr "파라미터들"
 
 #. Tag: para
-#: query_sql.xml:378
 #, fuzzy, no-c-format
 msgid "Native SQL queries support positional as well as named parameters:"
 msgstr ""
 "Native sql 질의들은 위치 파라미터들 뿐만 아니라 명명된 파라미터들을 지원한다:"
 
-#. Tag: programlisting
-#: query_sql.xml:381
-#, no-c-format
-msgid ""
-"<![CDATA[Query query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME "
-"like ?\").addEntity(Cat.class);\n"
-"List pusList = query.setString(0, \"Pus%\").list();\n"
-"     \n"
-"query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME like :name\")."
-"addEntity(Cat.class);\n"
-"List pusList = query.setString(\"name\", \"Pus%\").list();          ]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:389
 #, no-c-format
 msgid "Named SQL queries"
 msgstr "명명된 SQL 질의들"
 
 #. Tag: para
-#: query_sql.xml:391
 #, fuzzy, no-c-format
 msgid ""
 "Named SQL queries can be defined in the mapping document and called in "
@@ -810,32 +602,7 @@
 "정확하게 호출될 수도 있다. 이 경우에, 우리는 <literal>addEntity()</literal> "
 "호출을 필요로 하지 <emphasis>않는다</emphasis>."
 
-#. Tag: programlisting
-#: query_sql.xml:396
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"persons\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex}\n"
-"    FROM PERSON person\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_sql.xml:398
-#, no-c-format
-msgid ""
-"<![CDATA[List people = sess.getNamedQuery(\"persons\")\n"
-"    .setString(\"namePattern\", namePattern)\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:400
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>&lt;return-join&gt;</literal> element is use to join "
@@ -846,29 +613,7 @@
 "collection&gt;</literal> 요소는 연관들을 조인시키고 콜렉션들을 각각 초기화 시"
 "키는 질의들을 정의하는데 사용된다."
 
-#. Tag: programlisting
-#: query_sql.xml:404
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"personsWith\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex},\n"
-"           address.STREET AS {address.street},\n"
-"           address.CITY AS {address.city},\n"
-"           address.STATE AS {address.state},\n"
-"           address.ZIP AS {address.zip}\n"
-"    FROM PERSON person\n"
-"    JOIN ADDRESS address\n"
-"        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:406
 #, no-c-format
 msgid ""
 "A named SQL query may return a scalar value. You must declare the column "
@@ -879,21 +624,7 @@
 "scalar&gt;</literal> 요소를 사용하여 컬럼 alias와 Hibernate 타입을 선언해야 "
 "한다:"
 
-#. Tag: programlisting
-#: query_sql.xml:410
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-"    <return-scalar column=\"name\" type=\"string\"/>\n"
-"    <return-scalar column=\"age\" type=\"long\"/>\n"
-"    SELECT p.NAME AS name,\n"
-"           p.AGE AS age,\n"
-"    FROM PERSON p WHERE p.NAME LIKE 'Hiber%'\n"
-"</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:412
 #, fuzzy, no-c-format
 msgid ""
 "You can externalize the resultset mapping information in a <literal>&lt;"
@@ -906,32 +637,7 @@
 "용하기 위해 <literal>&lt;resultset&gt;</literal> 요소 속에 결과셋 매핑 정보들"
 "을 구체화 시킬 수 있다."
 
-#. Tag: programlisting
-#: query_sql.xml:417
-#, no-c-format
-msgid ""
-"<![CDATA[<resultset name=\"personAddress\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
-"</resultset>\n"
-"\n"
-"<sql-query name=\"personsWith\" resultset-ref=\"personAddress\">\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex},\n"
-"           address.STREET AS {address.street},\n"
-"           address.CITY AS {address.city},\n"
-"           address.STATE AS {address.state},\n"
-"           address.ZIP AS {address.zip}\n"
-"    FROM PERSON person\n"
-"    JOIN ADDRESS address\n"
-"        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:419
 #, fuzzy, no-c-format
 msgid ""
 "You can, alternatively, use the resultset mapping information in your hbm "
@@ -940,26 +646,12 @@
 "다른방법으로 당신은 당신의 hbm 파일들 내에 직접 자바 코드로 된 결과셋 매핑 정"
 "보를 사용할 수 있다."
 
-#. Tag: programlisting
-#: query_sql.xml:422
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createSQLQuery(\n"
-"        \"select {cat.*}, {kitten.*} from cats cat, cats kitten where kitten."
-"mother = cat.id\"\n"
-"    )\n"
-"    .setResultSetMapping(\"catAndKitten\")\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:425
 #, no-c-format
 msgid "Using return-property to explicitly specify column/alias names"
 msgstr "명시적으로 column/alias 이름들을 지정하는데 return-property 사용하기"
 
 #. Tag: para
-#: query_sql.xml:428
 #, fuzzy, no-c-format
 msgid ""
 "You can explicitly tell Hibernate what column aliases to use with "
@@ -971,26 +663,7 @@
 "literal>로서 당신은 사용할 컬럼 alias들이 무엇인지를 Hibernate에게 명시적으"
 "로 알려줄 수 있다."
 
-#. Tag: programlisting
-#: query_sql.xml:433
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-"    <return alias=\"person\" class=\"eg.Person\">\n"
-"        <return-property name=\"name\" column=\"myName\"/>\n"
-"        <return-property name=\"age\" column=\"myAge\"/>\n"
-"        <return-property name=\"sex\" column=\"mySex\"/>\n"
-"    </return>\n"
-"    SELECT person.NAME AS myName,\n"
-"           person.AGE AS myAge,\n"
-"           person.SEX AS mySex,\n"
-"    FROM PERSON person WHERE person.NAME LIKE :name\n"
-"</sql-query>\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:435
 #, fuzzy, no-c-format
 msgid ""
 "<literal>&lt;return-property&gt;</literal> also works with multiple columns. "
@@ -1001,29 +674,7 @@
 "다. 이것은 다중-컬럼 프로퍼티들에 대한 fine grained 제어를 허용할 수 없는 "
 "<literal>{}</literal>-구문을 가진 제약을 해결해준다."
 
-#. Tag: programlisting
-#: query_sql.xml:440
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"organizationCurrentEmployments\">\n"
-"    <return alias=\"emp\" class=\"Employment\">\n"
-"        <return-property name=\"salary\">\n"
-"            <return-column name=\"VALUE\"/>\n"
-"            <return-column name=\"CURRENCY\"/>\n"
-"        </return-property>\n"
-"        <return-property name=\"endDate\" column=\"myEndDate\"/>\n"
-"    </return>\n"
-"        SELECT EMPLOYEE AS {emp.employee}, EMPLOYER AS {emp.employer},\n"
-"        STARTDATE AS {emp.startDate}, ENDDATE AS {emp.endDate},\n"
-"        REGIONCODE as {emp.regionCode}, EID AS {emp.id}, VALUE, CURRENCY\n"
-"        FROM EMPLOYMENT\n"
-"        WHERE EMPLOYER = :id AND ENDDATE IS NULL\n"
-"        ORDER BY STARTDATE ASC\n"
-"</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:442
 #, fuzzy, no-c-format
 msgid ""
 "In this example <literal>&lt;return-property&gt;</literal> was used in "
@@ -1036,7 +687,6 @@
 "용해줌으로써."
 
 #. Tag: para
-#: query_sql.xml:447
 #, no-c-format
 msgid ""
 "If your mapping has a discriminator you must use <literal>&lt;return-"
@@ -1047,13 +697,11 @@
 "한다."
 
 #. Tag: title
-#: query_sql.xml:453
 #, no-c-format
 msgid "Using stored procedures for querying"
 msgstr "질의를 위한 내장 프로시저 사용하기"
 
 #. Tag: para
-#: query_sql.xml:455
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate3 provides support for queries via stored procedures and functions. "
@@ -1067,55 +715,14 @@
 "동작하는 것이 가능하도록 첫 번째 out-파라미터로서 한 개의 결과셋을 반환해야 "
 "한다. Oracle9 이상의 버전에서 그런 내장 프로시저에 대한 예제는 다음과 같다:"
 
-#. Tag: programlisting
-#: query_sql.xml:461
-#, no-c-format
-msgid ""
-"<![CDATA[CREATE OR REPLACE FUNCTION selectAllEmployments\n"
-"    RETURN SYS_REFCURSOR\n"
-"AS\n"
-"    st_cursor SYS_REFCURSOR;\n"
-"BEGIN\n"
-"    OPEN st_cursor FOR\n"
-" SELECT EMPLOYEE, EMPLOYER,\n"
-" STARTDATE, ENDDATE,\n"
-" REGIONCODE, EID, VALUE, CURRENCY\n"
-" FROM EMPLOYMENT;\n"
-"      RETURN  st_cursor;\n"
-" END;]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:463
 #, no-c-format
 msgid "To use this query in Hibernate you need to map it via a named query."
 msgstr ""
 "Hibernate에서 이 질의를 사용하기 위해 당신은 하나의 명명된 질의(a named "
 "query)를 통해 그것을 매핑할 필요가 있다."
 
-#. Tag: programlisting
-#: query_sql.xml:466
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"selectAllEmployees_SP\" callable=\"true\">\n"
-"    <return alias=\"emp\" class=\"Employment\">\n"
-"        <return-property name=\"employee\" column=\"EMPLOYEE\"/>\n"
-"        <return-property name=\"employer\" column=\"EMPLOYER\"/>\n"
-"        <return-property name=\"startDate\" column=\"STARTDATE\"/>\n"
-"        <return-property name=\"endDate\" column=\"ENDDATE\"/>\n"
-"        <return-property name=\"regionCode\" column=\"REGIONCODE\"/>\n"
-"        <return-property name=\"id\" column=\"EID\"/>\n"
-"        <return-property name=\"salary\">\n"
-"            <return-column name=\"VALUE\"/>\n"
-"            <return-column name=\"CURRENCY\"/>\n"
-"        </return-property>\n"
-"    </return>\n"
-"    { ? = call selectAllEmployments() }\n"
-"</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:468
 #, fuzzy, no-c-format
 msgid ""
 "Stored procedures currently only return scalars and entities. <literal>&lt;"
@@ -1127,13 +734,11 @@
 "literal>은 지원되지 않는다."
 
 #. Tag: title
-#: query_sql.xml:473
 #, no-c-format
 msgid "Rules/limitations for using stored procedures"
 msgstr "내장 프로시저들을 사용하는 규칙들/제약들"
 
 #. Tag: para
-#: query_sql.xml:475
 #, fuzzy, no-c-format
 msgid ""
 "You cannot use stored procedures with Hibernate unless you follow some "
@@ -1151,7 +756,6 @@
 "을 갖고 있기 때문에, 규칙들은 각각의 데이터베이스에 따라 차이가 난다."
 
 #. Tag: para
-#: query_sql.xml:482
 #, fuzzy, no-c-format
 msgid ""
 "Stored procedure queries cannot be paged with <literal>setFirstResult()/"
@@ -1161,7 +765,6 @@
 "서 쪽매김 될 수 없다."
 
 #. Tag: para
-#: query_sql.xml:485
 #, fuzzy, no-c-format
 msgid ""
 "The recommended call form is standard SQL92: <literal>{ ? = call functionName"
@@ -1173,13 +776,11 @@
 "parameters&gt;}</literal>. Native 호출 구문은 지원되지 않는다."
 
 #. Tag: para
-#: query_sql.xml:490
 #, no-c-format
 msgid "For Oracle the following rules apply:"
 msgstr "Oracle의 경우 다음 규칙들이 적용된다:"
 
 #. Tag: para
-#: query_sql.xml:494
 #, fuzzy, no-c-format
 msgid ""
 "A function must return a result set. The first parameter of a procedure must "
@@ -1195,13 +796,11 @@
 "는데, Oracle 보고서를 보라."
 
 #. Tag: para
-#: query_sql.xml:503
 #, no-c-format
 msgid "For Sybase or MS SQL server the following rules apply:"
 msgstr "Sybase 또는 MS SQL server의 경우 다음 규칙들이 적용된다:"
 
 #. Tag: para
-#: query_sql.xml:507
 #, fuzzy, no-c-format
 msgid ""
 "The procedure must return a result set. Note that since these servers can "
@@ -1215,7 +814,6 @@
 "이다. 그 밖의 모든 것은 폐기될 것이다."
 
 #. Tag: para
-#: query_sql.xml:515
 #, no-c-format
 msgid ""
 "If you can enable <literal>SET NOCOUNT ON</literal> in your procedure it "
@@ -1226,22 +824,28 @@
 "이 아니다."
 
 #. Tag: title
-#: query_sql.xml:525
 #, no-c-format
 msgid "Custom SQL for create, update and delete"
 msgstr "create, update 그리고 delete를 위한 맞춤형 SQL"
 
 #. Tag: para
-#: query_sql.xml:527
 #, no-c-format
 msgid ""
-"Hibernate3 can use custom SQL statements for create, update, and delete "
-"operations. The class and collection persisters in Hibernate already contain "
-"a set of configuration time generated strings (insertsql, deletesql, "
-"updatesql etc.). The mapping tags <literal>&lt;sql-insert&gt;</literal>, "
-"<literal>&lt;sql-delete&gt;</literal>, and <literal>&lt;sql-update&gt;</"
-"literal> override these strings:"
+"Hibernate3 can use custom SQL for create, update, and delete operations. The "
+"SQL can be overridden at the statement level or inidividual column level. "
+"This section describes statement overrides. For columns, see <xref linkend="
+"\"mapping-column-read-and-write\" />."
 msgstr ""
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"The class and collection persisters in Hibernate already contain a set of "
+"configuration time generated strings (insertsql, deletesql, updatesql etc.). "
+"The mapping tags <literal>&lt;sql-insert&gt;</literal>, <literal>&lt;sql-"
+"delete&gt;</literal>, and <literal>&lt;sql-update&gt;</literal> override "
+"these strings:"
+msgstr ""
 "Hibernate3는 create, update, delete 오퍼레이션들을 위한 맞춤형 문장들을 사용"
 "할 수 있다. Hibernate에서 클래스와 콜렉션 영속자들은 구성 시에 생성된 문자열"
 "들의 집합(insertsql, deletesql, updatesql 등)을 이미 포함하고 있다. "
@@ -1249,24 +853,7 @@
 "literal>, <literal>&lt;sql-update&gt;</literal> 매핑 태그들은 이들 문자열들"
 "을 오버라이드 시킨다:"
 
-#. Tag: programlisting
-#: query_sql.xml:535
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <sql-insert>INSERT INTO PERSON (NAME, ID) VALUES ( UPPER(?), ? )</sql-"
-"insert>\n"
-"    <sql-update>UPDATE PERSON SET NAME=UPPER(?) WHERE ID=?</sql-update>\n"
-"    <sql-delete>DELETE FROM PERSON WHERE ID=?</sql-delete>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:537
 #, fuzzy, no-c-format
 msgid ""
 "The SQL is directly executed in your database, so you can use any dialect "
@@ -1278,7 +865,6 @@
 "용할 경우 이것은 물론 당신의 매핑의 이식성을 감소시킬 것이다."
 
 #. Tag: para
-#: query_sql.xml:541
 #, no-c-format
 msgid ""
 "Stored procedures are supported if the <literal>callable</literal> attribute "
@@ -1286,24 +872,7 @@
 msgstr ""
 "만일 <literal>callable</literal> 속성이 설정되면 내장 프로시저들이 지원된다:"
 
-#. Tag: programlisting
-#: query_sql.xml:544
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <sql-insert callable=\"true\">{call createPerson (?, ?)}</sql-insert>\n"
-"    <sql-delete callable=\"true\">{? = call deletePerson (?)}</sql-delete>\n"
-"    <sql-update callable=\"true\">{? = call updatePerson (?, ?)}</sql-"
-"update>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:546
 #, fuzzy, no-c-format
 msgid ""
 "The order of the positional parameters is vital, as they must be in the same "
@@ -1313,7 +882,6 @@
 "로, 위치 파라미터들의 순서는 현재 절대적으로 중요하다."
 
 #. Tag: para
-#: query_sql.xml:549
 #, fuzzy, no-c-format
 msgid ""
 "You can view the expected order by enabling debug logging for the "
@@ -1331,7 +899,6 @@
 "염두에 두라.)"
 
 #. Tag: para
-#: query_sql.xml:556
 #, fuzzy, no-c-format
 msgid ""
 "The stored procedures are in most cases required to return the number of "
@@ -1345,54 +912,22 @@
 "CUD 오퍼레이션들에 대한 숫자 출력 파라미터로서 첫 번째 문장 파라미터를 등록시"
 "킨다:"
 
-#. Tag: programlisting
-#: query_sql.xml:562
-#, no-c-format
-msgid ""
-"<![CDATA[CREATE OR REPLACE FUNCTION updatePerson (uid IN NUMBER, uname IN "
-"VARCHAR2)\n"
-"    RETURN NUMBER IS\n"
-"BEGIN\n"
-"\n"
-"    update PERSON\n"
-"    set\n"
-"        NAME = uname,\n"
-"    where\n"
-"        ID = uid;\n"
-"\n"
-"    return SQL%ROWCOUNT;\n"
-"\n"
-"END updatePerson;]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:566
 #, no-c-format
 msgid "Custom SQL for loading"
 msgstr "로딩을 위한 맞춤형 SQL"
 
 #. Tag: para
-#: query_sql.xml:568
-#, fuzzy, no-c-format
-msgid "You can also declare your own SQL (or HQL) queries for entity loading:"
-msgstr ""
-"당신은 또한 엔티티 로딩을 위한 당신 자신의 SQL (또는 HQL)을 선언할 수도 있다:"
-
-#. Tag: programlisting
-#: query_sql.xml:571
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"person\">\n"
-"    <return alias=\"pers\" class=\"Person\" lock-mode=\"upgrade\"/>\n"
-"    SELECT NAME AS {pers.name}, ID AS {pers.id}\n"
-"    FROM PERSON\n"
-"    WHERE ID=?\n"
-"    FOR UPDATE\n"
-"</sql-query>]]>"
+"You can also declare your own SQL (or HQL) queries for entity loading. As "
+"with inserts, updates, and deletes, this can be done at the individual "
+"column level as described in <xref linkend=\"mapping-column-read-and-write"
+"\" /> or at the statement level. Here is an example of a statement level "
+"override:"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:573
 #, fuzzy, no-c-format
 msgid ""
 "This is just a named query declaration, as discussed earlier. You can "
@@ -1401,57 +936,17 @@
 "이것은 앞서 논의했듯이 단지 명명된 질의 선언이다. 당신은 class 매핑 속에 이 "
 "명명된 질의를 참조할 수 있다:"
 
-#. Tag: programlisting
-#: query_sql.xml:576
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <loader query-ref=\"person\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:578
 #, no-c-format
 msgid "This even works with stored procedures."
 msgstr "이것은 심지어 내장 프로시저들에 동작한다."
 
 #. Tag: para
-#: query_sql.xml:580
 #, fuzzy, no-c-format
 msgid "You can even define a query for collection loading:"
 msgstr "당신은 콜렉션 로딩을 위한 한 개의 질의를 정의할 수도 있다:"
 
-#. Tag: programlisting
-#: query_sql.xml:582
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"employments\" inverse=\"true\">\n"
-"    <key/>\n"
-"    <one-to-many class=\"Employment\"/>\n"
-"    <loader query-ref=\"employments\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_sql.xml:584
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"employments\">\n"
-"    <load-collection alias=\"emp\" role=\"Person.employments\"/>\n"
-"    SELECT {emp.*}\n"
-"    FROM EMPLOYMENT emp\n"
-"    WHERE EMPLOYER = :id\n"
-"    ORDER BY STARTDATE ASC, EMPLOYEE ASC\n"
-"</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:586
 #, fuzzy, no-c-format
 msgid ""
 "You can also define an entity loader that loads a collection by join "
@@ -1460,17 +955,15 @@
 "당신은 심지어 조인 페칭에 의해 하나의 콜렉션을 로드시키는 하나의 엔티티를 정"
 "의할 수 있다:"
 
-#. Tag: programlisting
-#: query_sql.xml:589
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"person\">\n"
-"    <return alias=\"pers\" class=\"Person\"/>\n"
-"    <return-join alias=\"emp\" property=\"pers.employments\"/>\n"
-"    SELECT NAME AS {pers.*}, {emp.*}\n"
-"    FROM PERSON pers\n"
-"    LEFT OUTER JOIN EMPLOYMENT emp\n"
-"        ON pers.ID = emp.PERSON_ID\n"
-"    WHERE ID=?\n"
-"</sql-query>]]>"
-msgstr ""
+#~ msgid "{item.*}"
+#~ msgstr "{item.*}"
+
+#~ msgid "{coll.*}"
+#~ msgstr "{coll.*}"
+
+#, fuzzy
+#~ msgid ""
+#~ "You can also declare your own SQL (or HQL) queries for entity loading:"
+#~ msgstr ""
+#~ "당신은 또한 엔티티 로딩을 위한 당신 자신의 SQL (또는 HQL)을 선언할 수도 있"
+#~ "다:"

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/session_api.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/session_api.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/session_api.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,13 +11,11 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: session_api.xml:29
 #, no-c-format
 msgid "Working with objects"
 msgstr "객체들로 작업하기"
 
 #. Tag: para
-#: session_api.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate is a full object/relational mapping solution that not only shields "
@@ -34,7 +32,6 @@
 "케이션들에서 영속에 관한 매우 고유한 객체-지향적 관점이다."
 
 #. Tag: para
-#: session_api.xml:40
 #, no-c-format
 msgid ""
 "In other words, Hibernate application developers should always think about "
@@ -49,19 +46,16 @@
 "리케이션 개발자와 유일하게 관련된다."
 
 #. Tag: title
-#: session_api.xml:48
 #, no-c-format
 msgid "Hibernate object states"
 msgstr "Hibernate 객체 상태들"
 
 #. Tag: para
-#: session_api.xml:50
 #, no-c-format
 msgid "Hibernate defines and supports the following object states:"
 msgstr "Hibernate 다음 객체 상태들을 정의하고 지원한다:"
 
 #. Tag: para
-#: session_api.xml:56
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Transient</emphasis> - an object is transient if it has just been "
@@ -84,7 +78,6 @@
 "<literal>Session</literal>을 사용하라."
 
 #. Tag: para
-#: session_api.xml:68
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Persistent</emphasis> - a persistent instance has a representation "
@@ -105,7 +98,6 @@
 "나 <literal>DELETE</literal> 문장들을 수작업으로 실행하지 않는다."
 
 #. Tag: para
-#: session_api.xml:79
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Detached</emphasis> - a detached instance is an object that has "
@@ -128,7 +120,6 @@
 "emphasis>, 즉 사용자의 관점의 작업 단위라고 부른다."
 
 #. Tag: para
-#: session_api.xml:93
 #, fuzzy, no-c-format
 msgid ""
 "We will now discuss the states and state transitions (and the Hibernate "
@@ -138,13 +129,11 @@
 "Hibernate 메소드들)을 상세하게 논의할 것이다."
 
 #. Tag: title
-#: session_api.xml:101
 #, no-c-format
 msgid "Making objects persistent"
 msgstr "객체들을 영속화 시키기"
 
 #. Tag: para
-#: session_api.xml:103
 #, no-c-format
 msgid ""
 "Newly instantiated instances of a a persistent class are considered "
@@ -155,19 +144,7 @@
 "<emphasis>transient</emphasis>로 간주된다. 우리는 그것을 세션과 연관지어서 "
 "transient 인스턴스를 <emphasis>영속화</emphasis> 시킬 수 있다:"
 
-#. Tag: programlisting
-#: session_api.xml:110
-#, no-c-format
-msgid ""
-"<![CDATA[DomesticCat fritz = new DomesticCat();\n"
-"fritz.setColor(Color.GINGER);\n"
-"fritz.setSex('M');\n"
-"fritz.setName(\"Fritz\");\n"
-"Long generatedId = (Long) sess.save(fritz);]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:112
 #, fuzzy, no-c-format
 msgid ""
 "If <literal>Cat</literal> has a generated identifier, the identifier is "
@@ -188,7 +165,6 @@
 "()</literal>를 사용할 수도 있다."
 
 #. Tag: para
-#: session_api.xml:124
 #, fuzzy, no-c-format
 msgid ""
 "<literal>persist()</literal> makes a transient instance persistent. However, "
@@ -208,7 +184,6 @@
 "extended Session/persistence context."
 
 #. Tag: para
-#: session_api.xml:135
 #, no-c-format
 msgid ""
 "<literal>save()</literal> does guarantee to return an identifier. If an "
@@ -224,7 +199,6 @@
 "running conversation with an extended Session/persistence context."
 
 #. Tag: para
-#: session_api.xml:145
 #, fuzzy, no-c-format
 msgid ""
 "Alternatively, you can assign the identifier using an overloaded version of "
@@ -233,21 +207,7 @@
 "다른 방법으로, 당신은 <literal>save()</literal>의 오버로드된 버전을 사용하여 "
 "식별자를 할당할 수 있다."
 
-#. Tag: programlisting
-#: session_api.xml:150
-#, no-c-format
-msgid ""
-"<![CDATA[DomesticCat pk = new DomesticCat();\n"
-"pk.setColor(Color.TABBY);\n"
-"pk.setSex('F');\n"
-"pk.setName(\"PK\");\n"
-"pk.setKittens( new HashSet() );\n"
-"pk.addKitten(fritz);\n"
-"sess.save( pk, new Long(1234) );]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:152
 #, fuzzy, no-c-format
 msgid ""
 "If the object you make persistent has associated objects (e.g. the "
@@ -267,7 +227,6 @@
 "<literal>NOT NULL</literal> 컨스트레인트를 위배할 수도 있다."
 
 #. Tag: para
-#: session_api.xml:162
 #, fuzzy, no-c-format
 msgid ""
 "Usually you do not bother with this detail, as you will normally use "
@@ -284,13 +243,11 @@
 "논의된다."
 
 #. Tag: title
-#: session_api.xml:173
 #, no-c-format
 msgid "Loading an object"
 msgstr "객체를 로드시키기"
 
 #. Tag: para
-#: session_api.xml:175
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>load()</literal> methods of <literal>Session</literal> provide "
@@ -304,40 +261,12 @@
 "체를 취하고 그 상태를 영속(persistent) 상태로 그 클래스의 새로이 초기화 된 인"
 "스턴스 속으로 로드시킬 것이다."
 
-#. Tag: programlisting
-#: session_api.xml:182
-#, no-c-format
-msgid "<![CDATA[Cat fritz = (Cat) sess.load(Cat.class, generatedId);]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:184
-#, no-c-format
-msgid ""
-"<![CDATA[// you need to wrap primitive identifiers\n"
-"long id = 1234;\n"
-"DomesticCat pk = (DomesticCat) sess.load( DomesticCat.class, new Long"
-"(id) );]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:186
 #, no-c-format
 msgid "Alternatively, you can load state into a given instance:"
 msgstr "다른 방법으로 당신은 주어진 인스턴스 속으로 상태를 로드시킬 수 있다:"
 
-#. Tag: programlisting
-#: session_api.xml:190
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = new DomesticCat();\n"
-"// load pk's state into cat\n"
-"sess.load( cat, new Long(pkId) );\n"
-"Set kittens = cat.getKittens();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:192
 #, fuzzy, no-c-format
 msgid ""
 "Be aware that <literal>load()</literal> will throw an unrecoverable "
@@ -360,7 +289,6 @@
 "허용해준다."
 
 #. Tag: para
-#: session_api.xml:203
 #, fuzzy, no-c-format
 msgid ""
 "If you are not certain that a matching row exists, you should use the "
@@ -372,20 +300,7 @@
 "literal> 메소드)는 데이터베이스에 즉시 접속하고 만일 일치하는 행이 없을 경우 "
 "null을 반환한다."
 
-#. Tag: programlisting
-#: session_api.xml:209
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id);\n"
-"if (cat==null) {\n"
-"    cat = new Cat();\n"
-"    sess.save(cat, id);\n"
-"}\n"
-"return cat;]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:211
 #, fuzzy, no-c-format
 msgid ""
 "You can even load an object using an SQL <literal>SELECT ... FOR UPDATE</"
@@ -396,14 +311,7 @@
 "FOR UPDATE</literal>를 사용하여 하나의 객체를 로드시킬 수도 있다. 추가 정보"
 "는 API 문서를 보라."
 
-#. Tag: programlisting
-#: session_api.xml:216
-#, no-c-format
-msgid "<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id, LockMode.UPGRADE);]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:218
 #, fuzzy, no-c-format
 msgid ""
 "Any associated instances or contained collections will <emphasis>not</"
@@ -417,7 +325,6 @@
 "라."
 
 #. Tag: para
-#: session_api.xml:225
 #, no-c-format
 msgid ""
 "It is possible to re-load an object and all its collections at any time, "
@@ -428,23 +335,13 @@
 "그것의 콜렉션들을 다시 로드시키는 것이 가능하다. 데이터베이스 트리거들이 그 "
 "객체의 프로퍼티들 중 어떤 것을 초기화 시키는데 사용될 때 이것이 유용하다."
 
-#. Tag: programlisting
-#: session_api.xml:231
-#, no-c-format
-msgid ""
-"<![CDATA[sess.save(cat);\n"
-"sess.flush(); //force the SQL INSERT\n"
-"sess.refresh(cat); //re-read the state (after the trigger executes)]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:233
 #, fuzzy, no-c-format
 msgid ""
 "How much does Hibernate load from the database and how many SQL "
 "<literal>SELECT</literal>s will it use? This depends on the "
 "<emphasis>fetching strategy</emphasis>. This is explained in <xref linkend="
-"\"performance-fetching\"/>."
+"\"performance-fetching\" />."
 msgstr ""
 "중요한 질문이 대개 이 지점에서 나타난다: Hibernate는 데이터베이로부터 그것을 "
 "얼마나 많이 로드시키고 그리고 얼마나 많은 SQL <literal>SELECT</literal>들이 "
@@ -452,13 +349,11 @@
 "linkend=\"performance-fetching\"/>에 설명되어 있다."
 
 #. Tag: title
-#: session_api.xml:243
 #, no-c-format
 msgid "Querying"
 msgstr "질의하기"
 
 #. Tag: para
-#: session_api.xml:245
 #, fuzzy, no-c-format
 msgid ""
 "If you do not know the identifiers of the objects you are looking for, you "
@@ -476,13 +371,11 @@
 "native SQL 속에 당신의 질의를 표현할 수도 있다."
 
 #. Tag: title
-#: session_api.xml:255
 #, no-c-format
 msgid "Executing queries"
 msgstr "질의들을 실행하기"
 
 #. Tag: para
-#: session_api.xml:257
 #, no-c-format
 msgid ""
 "HQL and native SQL queries are represented with an instance of <literal>org."
@@ -497,38 +390,7 @@
 "<literal>Session</literal>을 사용하여 하나의 <literal>Query</literal>를 얻는"
 "다:"
 
-#. Tag: programlisting
-#: session_api.xml:264
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = session.createQuery(\n"
-"    \"from Cat as cat where cat.birthdate < ?\")\n"
-"    .setDate(0, date)\n"
-"    .list();\n"
-"\n"
-"List mothers = session.createQuery(\n"
-"    \"select mother from Cat as cat join cat.mother as mother where cat.name "
-"= ?\")\n"
-"    .setString(0, name)\n"
-"    .list();\n"
-"\n"
-"List kittens = session.createQuery(\n"
-"    \"from Cat as cat where cat.mother = ?\")\n"
-"    .setEntity(0, pk)\n"
-"    .list();\n"
-"\n"
-"Cat mother = (Cat) session.createQuery(\n"
-"    \"select cat.mother from Cat as cat where cat = ?\")\n"
-"    .setEntity(0, izi)\n"
-"    .uniqueResult();]]\n"
-"\n"
-"Query mothersWithKittens = (Cat) session.createQuery(\n"
-"    \"select mother from Cat as mother left join fetch mother.kittens\");\n"
-"Set uniqueMothers = new HashSet(mothersWithKittens.list());]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:266
 #, fuzzy, no-c-format
 msgid ""
 "A query is usually executed by invoking <literal>list()</literal>. The "
@@ -550,13 +412,11 @@
 "들 중복들을 간단하게 필터링할 수 있다."
 
 #. Tag: title
-#: session_api.xml:278
 #, no-c-format
 msgid "Iterating results"
 msgstr "결과들을 반복하기"
 
 #. Tag: para
-#: session_api.xml:280
 #, fuzzy, no-c-format
 msgid ""
 "Occasionally, you might be able to achieve better performance by executing "
@@ -579,33 +439,12 @@
 "스턴스들을 초기화 시키는 추가적인 select들에 대해 <emphasis>n</emphasis> 번"
 "의 접속을 필요로 할 수 있다."
 
-#. Tag: programlisting
-#: session_api.xml:292
-#, no-c-format
-msgid ""
-"<![CDATA[// fetch ids\n"
-"Iterator iter = sess.createQuery(\"from eg.Qux q order by q.likeliness\")."
-"iterate();\n"
-"while ( iter.hasNext() ) {\n"
-"    Qux qux = (Qux) iter.next();  // fetch the object\n"
-"    // something we couldnt express in the query\n"
-"    if ( qux.calculateComplicatedAlgorithm() ) {\n"
-"        // delete the current instance\n"
-"        iter.remove();\n"
-"        // dont need to process the rest\n"
-"        break;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:296
 #, no-c-format
 msgid "Queries that return tuples"
 msgstr "튜플들을 반환하는 질의들"
 
 #. Tag: para
-#: session_api.xml:298
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate queries sometimes return tuples of objects. Each tuple is returned "
@@ -614,32 +453,12 @@
 "Hibernate 질의들은 때때로 객체들의 튜플들을 반환하고, 그 경우에 각각의 튜플"
 "은 배열로서 반환된다:"
 
-#. Tag: programlisting
-#: session_api.xml:303
-#, no-c-format
-msgid ""
-"<![CDATA[Iterator kittensAndMothers = sess.createQuery(\n"
-"            \"select kitten, mother from Cat kitten join kitten.mother mother"
-"\")\n"
-"            .list()\n"
-"            .iterator();\n"
-"\n"
-"while ( kittensAndMothers.hasNext() ) {\n"
-"    Object[] tuple = (Object[]) kittensAndMothers.next();\n"
-"    Cat kitten = (Cat) tuple[0];\n"
-"    Cat mother = (Cat) tuple[1];\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:308
 #, no-c-format
 msgid "Scalar results"
 msgstr "스칼라 결과들"
 
 #. Tag: para
-#: session_api.xml:310
 #, fuzzy, no-c-format
 msgid ""
 "Queries can specify a property of a class in the <literal>select</literal> "
@@ -651,34 +470,12 @@
 "퍼티들이나 aggregate들은 \"스칼라\" 결과들(그리고 영속 상태에 있는 엔티티들"
 "이 아닌 것으)로 간주된다."
 
-#. Tag: programlisting
-#: session_api.xml:316
-#, no-c-format
-msgid ""
-"<![CDATA[Iterator results = sess.createQuery(\n"
-"        \"select cat.color, min(cat.birthdate), count(cat) from Cat cat \" "
-"+\n"
-"        \"group by cat.color\")\n"
-"        .list()\n"
-"        .iterator();\n"
-"\n"
-"while ( results.hasNext() ) {\n"
-"    Object[] row = (Object[]) results.next();\n"
-"    Color type = (Color) row[0];\n"
-"    Date oldest = (Date) row[1];\n"
-"    Integer count = (Integer) row[2];\n"
-"    .....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:321
 #, no-c-format
 msgid "Bind parameters"
 msgstr "바인드 프라미터들"
 
 #. Tag: para
-#: session_api.xml:323
 #, fuzzy, no-c-format
 msgid ""
 "Methods on <literal>Query</literal> are provided for binding values to named "
@@ -694,67 +491,27 @@
 "다. 명명된 파라미터들의 장점들은 다음과 같다:"
 
 #. Tag: para
-#: session_api.xml:333
 #, no-c-format
 msgid ""
 "named parameters are insensitive to the order they occur in the query string"
 msgstr "명명된 파라미터들은 그것들이 질의 문자열 내에 발생하는 순서에 관계없다"
 
 #. Tag: para
-#: session_api.xml:339
 #, fuzzy, no-c-format
 msgid "they can occur multiple times in the same query"
 msgstr "그것들은 동일한 질의 내에서 여러 번 발생할 수 있다"
 
 #. Tag: para
-#: session_api.xml:344
 #, no-c-format
 msgid "they are self-documenting"
 msgstr "그것은 자기-설명적이다"
 
-#. Tag: programlisting
-#: session_api.xml:350
-#, no-c-format
-msgid ""
-"<![CDATA[//named parameter (preferred)\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name = :name"
-"\");\n"
-"q.setString(\"name\", \"Fritz\");\n"
-"Iterator cats = q.iterate();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:352
-#, no-c-format
-msgid ""
-"<![CDATA[//positional parameter\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name = ?\");\n"
-"q.setString(0, \"Izi\");\n"
-"Iterator cats = q.iterate();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:354
-#, no-c-format
-msgid ""
-"<![CDATA[//named parameter list\n"
-"List names = new ArrayList();\n"
-"names.add(\"Izi\");\n"
-"names.add(\"Fritz\");\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name in (:"
-"namesList)\");\n"
-"q.setParameterList(\"namesList\", names);\n"
-"List cats = q.list();]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:359
 #, no-c-format
 msgid "Pagination"
 msgstr "쪽매김"
 
 #. Tag: para
-#: session_api.xml:361
 #, fuzzy, no-c-format
 msgid ""
 "If you need to specify bounds upon your result set, that is, the maximum "
@@ -765,18 +522,7 @@
 "또는 당신이 검색하고자 원하는 첫 번째 행)을 지정할 필요가 있다면 당신은 "
 "<literal>Query</literal> 인터페이스의 메소드들을 사용해야 한다:"
 
-#. Tag: programlisting
-#: session_api.xml:367
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = sess.createQuery(\"from DomesticCat cat\");\n"
-"q.setFirstResult(20);\n"
-"q.setMaxResults(10);\n"
-"List cats = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:369
 #, no-c-format
 msgid ""
 "Hibernate knows how to translate this limit query into the native SQL of "
@@ -786,13 +532,11 @@
 "있다."
 
 #. Tag: title
-#: session_api.xml:377
 #, no-c-format
 msgid "Scrollable iteration"
 msgstr "스크롤 가능한 iteration"
 
 #. Tag: para
-#: session_api.xml:379
 #, fuzzy, no-c-format
 msgid ""
 "If your JDBC driver supports scrollable <literal>ResultSet</literal>s, the "
@@ -805,38 +549,7 @@
 "literal> 객체를 얻는데 사용될 수 있고, 그것은 질의 결과들에 대한 유연한 네비"
 "게이션을 허용해준다."
 
-#. Tag: programlisting
-#: session_api.xml:386
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = sess.createQuery(\"select cat.name, cat from DomesticCat "
-"cat \" +\n"
-"                            \"order by cat.name\");\n"
-"ScrollableResults cats = q.scroll();\n"
-"if ( cats.first() ) {\n"
-"\n"
-"    // find the first name on each page of an alphabetical list of cats by "
-"name\n"
-"    firstNamesOfPages = new ArrayList();\n"
-"    do {\n"
-"        String name = cats.getString(0);\n"
-"        firstNamesOfPages.add(name);\n"
-"    }\n"
-"    while ( cats.scroll(PAGE_SIZE) );\n"
-"\n"
-"    // Now get the first page of cats\n"
-"    pageOfCats = new ArrayList();\n"
-"    cats.beforeFirst();\n"
-"    int i=0;\n"
-"    while( ( PAGE_SIZE > i++ ) && cats.next() ) pageOfCats.add( cats.get"
-"(1) );\n"
-"\n"
-"}\n"
-"cats.close()]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:388
 #, fuzzy, no-c-format
 msgid ""
 "Note that an open database connection and cursor is required for this "
@@ -848,13 +561,11 @@
 "<literal>setFirstResult()</literal>를 사용하라."
 
 #. Tag: title
-#: session_api.xml:397
 #, no-c-format
 msgid "Externalizing named queries"
 msgstr "명명된 질의들을 구체화 시키기"
 
 #. Tag: para
-#: session_api.xml:399
 #, fuzzy, no-c-format
 msgid ""
 "You can also define named queries in the mapping document. Remember to use a "
@@ -865,35 +576,12 @@
 "가 마크업으로서 해석될 수 있는 문자들을 포함할 경우에 <literal>CDATA</"
 "literal> 섹션을 사용하는 것을 기억하라))"
 
-#. Tag: programlisting
-#: session_api.xml:405
-#, no-c-format
-msgid ""
-"<![CDATA[<query name=\"ByNameAndMaximumWeight\"><![CDATA[\n"
-"    from eg.DomesticCat as cat\n"
-"        where cat.name = ?\n"
-"        and cat.weight > ?\n"
-"] ]></query>]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:407
 #, no-c-format
 msgid "Parameter binding and executing is done programatically:"
 msgstr "파라미터 바인딩과 실행은 프로그램 상으로 행해진다:"
 
-#. Tag: programlisting
-#: session_api.xml:411
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = sess.getNamedQuery(\"ByNameAndMaximumWeight\");\n"
-"q.setString(0, name);\n"
-"q.setInt(1, minWeight);\n"
-"List cats = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:413
 #, fuzzy, no-c-format
 msgid ""
 "The actual program code is independent of the query language that is used. "
@@ -905,7 +593,6 @@
 "들을 위치지움으로써 기존 질의들을 Hibernate로 이전시킬 수도 있음을 노트하라."
 
 #. Tag: para
-#: session_api.xml:419
 #, fuzzy, no-c-format
 msgid ""
 "Also note that a query declaration inside a <literal>&lt;hibernate-"
@@ -921,13 +608,11 @@
 "ByNameAndMaximumWeight</literal>."
 
 #. Tag: title
-#: session_api.xml:432
 #, no-c-format
 msgid "Filtering collections"
 msgstr "콜렉션들을 필터링 하기"
 
 #. Tag: para
-#: session_api.xml:433
 #, fuzzy, no-c-format
 msgid ""
 "A collection <emphasis>filter</emphasis> is a special type of query that can "
@@ -938,20 +623,7 @@
 "의의 특별한 타입이다. 질의 문자열은 현재의 콜렉션 요소를 의미하는 "
 "<literal>this</literal>를 참조할 수 있다."
 
-#. Tag: programlisting
-#: session_api.xml:439
-#, no-c-format
-msgid ""
-"<![CDATA[Collection blackKittens = session.createFilter(\n"
-"    pk.getKittens(), \n"
-"    \"where this.color = ?\")\n"
-"    .setParameter( Color.BLACK, Hibernate.custom(ColorUserType.class) )\n"
-"    .list()\n"
-");]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:441
 #, fuzzy, no-c-format
 msgid ""
 "The returned collection is considered a bag that is a copy of the given "
@@ -963,7 +635,6 @@
 "이지만, 예상되는 행위와 일치된다)."
 
 #. Tag: para
-#: session_api.xml:447
 #, fuzzy, no-c-format
 msgid ""
 "Observe that filters do not require a <literal>from</literal> clause, "
@@ -974,18 +645,7 @@
 "에 필터들이 한 개의 from 절을 가질 수 있을지라도). 필터들은 콜렉션 요소들 자"
 "체들을 반환하는 것으로 한정되지 않는다."
 
-#. Tag: programlisting
-#: session_api.xml:452
-#, no-c-format
-msgid ""
-"<![CDATA[Collection blackKittenMates = session.createFilter(\n"
-"    pk.getKittens(), \n"
-"    \"select this.mate where this.color = eg.Color.BLACK.intValue\")\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:454
 #, fuzzy, no-c-format
 msgid ""
 "Even an empty filter query is useful, e.g. to load a subset of elements in a "
@@ -994,24 +654,12 @@
 "심지어 하나의 공백의 필터 질의도 예를 들어 거대한 콜렉션 내에 있는 요소들의 "
 "부분집합들을 로드시키는데 유용하다:"
 
-#. Tag: programlisting
-#: session_api.xml:459
-#, no-c-format
-msgid ""
-"<![CDATA[Collection tenKittens = session.createFilter(\n"
-"    mother.getKittens(), \"\")\n"
-"    .setFirstResult(0).setMaxResults(10)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:464
 #, no-c-format
 msgid "Criteria queries"
 msgstr "Criteria 질의들"
 
 #. Tag: para
-#: session_api.xml:466
 #, fuzzy, no-c-format
 msgid ""
 "HQL is extremely powerful, but some developers prefer to build queries "
@@ -1023,35 +671,22 @@
 "향 API를 사용하여 동적으로 질의들을 빌드시키는 것을 선호한다. Hibernate는 이"
 "들 경우들을 위한 직관적인 <literal>Criteria</literal> query API를 제공한다:"
 
-#. Tag: programlisting
-#: session_api.xml:472
-#, no-c-format
-msgid ""
-"<![CDATA[Criteria crit = session.createCriteria(Cat.class);\n"
-"crit.add( Restrictions.eq( \"color\", eg.Color.BLACK ) );\n"
-"crit.setMaxResults(10);\n"
-"List cats = crit.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:474
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The <literal>Criteria</literal> and the associated <literal>Example</"
-"literal> API are discussed in more detail in <xref linkend=\"querycriteria\"/"
-">."
+"literal> API are discussed in more detail in <xref linkend=\"querycriteria"
+"\" />."
 msgstr ""
 "<literal>Criteria</literal>와 연관된 <literal>Example</literal> API 는 <xref "
 "linkend=\"querycriteria\"/>에서 상세하게 논의된다."
 
 #. Tag: title
-#: session_api.xml:482
 #, no-c-format
 msgid "Queries in native SQL"
 msgstr "native SQL에서 질의들"
 
 #. Tag: para
-#: session_api.xml:484
 #, fuzzy, no-c-format
 msgid ""
 "You can express a query in SQL, using <literal>createSQLQuery()</literal> "
@@ -1067,49 +702,23 @@
 "하라. 만일 당신이 Hibernate API를 사용하고자 선택한 경우에 , 당신은 SQL alias"
 "들을 중괄호들 속에 포함시켜야 한다:"
 
-#. Tag: programlisting
-#: session_api.xml:492
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = session.createSQLQuery(\"SELECT {cat.*} FROM CAT {cat} "
-"WHERE ROWNUM<10\")\n"
-"    .addEntity(\"cat\", Cat.class)\n"
-".list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:494
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = session.createSQLQuery(\n"
-"    \"SELECT {cat}.ID AS {cat.id}, {cat}.SEX AS {cat.sex}, \" +\n"
-"           \"{cat}.MATE AS {cat.mate}, {cat}.SUBCLASS AS {cat.class}, ... \" "
-"+\n"
-"    \"FROM CAT {cat} WHERE ROWNUM<10\")\n"
-"    .addEntity(\"cat\", Cat.class)\n"
-".list()]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:496
 #, fuzzy, no-c-format
 msgid ""
 "SQL queries can contain named and positional parameters, just like Hibernate "
 "queries. More information about native SQL queries in Hibernate can be found "
-"in <xref linkend=\"querysql\"/>."
+"in <xref linkend=\"querysql\" />."
 msgstr ""
 "SQL 질의들은 Hibernate 질의들처럼 명명된 파라미터들과 위치 파라미터들을 포함"
 "할 수도 있다. SQL 질의들에 대한 추가 정보는 <xref linkend=\"querysql\"/>에서 "
 "찾을 수 있다."
 
 #. Tag: title
-#: session_api.xml:507
 #, no-c-format
 msgid "Modifying persistent objects"
 msgstr "영속 객체들을 변경하기"
 
 #. Tag: para
-#: session_api.xml:509
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Transactional persistent instances</emphasis> (i.e. objects "
@@ -1132,18 +741,7 @@
 "<literal>Session</literal>이 열려 있는 동안, 그것을 <literal>load()</literal>"
 "시키고 나서, 그것을 직접 처리하는 것이다:"
 
-#. Tag: programlisting
-#: session_api.xml:520
-#, no-c-format
-msgid ""
-"<![CDATA[DomesticCat cat = (DomesticCat) sess.load( Cat.class, new Long"
-"(69) );\n"
-"cat.setName(\"PK\");\n"
-"sess.flush();  // changes to cat are automatically detected and persisted]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:522
 #, fuzzy, no-c-format
 msgid ""
 "Sometimes this programming model is inefficient, as it requires in the same "
@@ -1158,7 +756,6 @@
 "제공한다."
 
 #. Tag: para
-#: session_api.xml:529
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate does not offer its own API for direct execution of "
@@ -1170,7 +767,7 @@
 "the notion of mass operations conflicts with object/relational mapping for "
 "online transaction processing-oriented applications. Future versions of "
 "Hibernate can, however, provide special mass operation functions. See <xref "
-"linkend=\"batch\"/> for some possible batch operation tricks."
+"linkend=\"batch\" /> for some possible batch operation tricks."
 msgstr ""
 "Hibernate는 <placeholder-1/> 문장 또는 <placeholder-2/> 문장의 직접적인 실행"
 "을 위한 그것 자신의 API를 제공하지 않음을 노트하라. Hibernate는 하나의 "
@@ -1183,13 +780,11 @@
 "이션 트릭들에 대해서는 <xref linkend=\"batch\"/>을 보라."
 
 #. Tag: title
-#: session_api.xml:546
 #, no-c-format
 msgid "Modifying detached objects"
 msgstr "detached 객체들을 변경시키기"
 
 #. Tag: para
-#: session_api.xml:548
 #, no-c-format
 msgid ""
 "Many applications need to retrieve an object in one transaction, send it to "
@@ -1205,7 +800,6 @@
 "터를 사용한다."
 
 #. Tag: para
-#: session_api.xml:555
 #, no-c-format
 msgid ""
 "Hibernate supports this model by providing for reattachment of detached "
@@ -1216,25 +810,7 @@
 "merge()</literal> 메소드를 사용하여 detached 인스턴스들의 재첨부를 제공함으로"
 "써 이 모형을 지원한다:"
 
-#. Tag: programlisting
-#: session_api.xml:561
-#, no-c-format
-msgid ""
-"<![CDATA[// in the first session\n"
-"Cat cat = (Cat) firstSession.load(Cat.class, catId);\n"
-"Cat potentialMate = new Cat();\n"
-"firstSession.save(potentialMate);\n"
-"\n"
-"// in a higher layer of the application\n"
-"cat.setMate(potentialMate);\n"
-"\n"
-"// later, in a new session\n"
-"secondSession.update(cat);  // update cat\n"
-"secondSession.update(mate); // update mate]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:563
 #, no-c-format
 msgid ""
 "If the <literal>Cat</literal> with identifier <literal>catId</literal> had "
@@ -1246,7 +822,6 @@
 "이 그것을 다시 재첨부하려고 시도할 때, 예외상황이 던져졌을 것이다."
 
 #. Tag: para
-#: session_api.xml:569
 #, fuzzy, no-c-format
 msgid ""
 "Use <literal>update()</literal> if you are certain that the session does not "
@@ -1266,14 +841,13 @@
 "첫 번째 메소드이다."
 
 #. Tag: para
-#: session_api.xml:578
 #, fuzzy, no-c-format
 msgid ""
 "The application should individually <literal>update()</literal> detached "
 "instances that are reachable from the given detached instance "
 "<emphasis>only</emphasis> if it wants their state to be updated. This can be "
 "automated using <emphasis>transitive persistence</emphasis>. See <xref "
-"linkend=\"objectstate-transitive\"/> for more information."
+"linkend=\"objectstate-transitive\" /> for more information."
 msgstr ""
 "어플리케이션은 만일 그것이 detached 인스턴스들의 상태가 또한 업데이트 되는 것"
 "을 원할 경우에<emphasis>만</emphasis> 주어진 detached 인스턴스로부터 도달 가"
@@ -1282,7 +856,6 @@
 "하여 자동화 될 수 있고, <xref linkend=\"objectstate-transitive\"/>를 보라."
 
 #. Tag: para
-#: session_api.xml:585
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>lock()</literal> method also allows an application to "
@@ -1293,20 +866,7 @@
 "시 연관시키는것을 어플리케이션에게 허용해준다. 하지만 detached 인스턴스는 변"
 "경되지 않아야 한다!"
 
-#. Tag: programlisting
-#: session_api.xml:590
-#, no-c-format
-msgid ""
-"<![CDATA[//just reassociate:\n"
-"sess.lock(fritz, LockMode.NONE);\n"
-"//do a version check, then reassociate:\n"
-"sess.lock(izi, LockMode.READ);\n"
-"//do a version check, using SELECT ... FOR UPDATE, then reassociate:\n"
-"sess.lock(pk, LockMode.UPGRADE);]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:592
 #, fuzzy, no-c-format
 msgid ""
 "Note that <literal>lock()</literal> can be used with various "
@@ -1319,23 +879,20 @@
 "첨부는 <literal>lock()</literal>에 대한 유일한 쓰임새는 아니다."
 
 #. Tag: para
-#: session_api.xml:599
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Other models for long units of work are discussed in <xref linkend="
-"\"transactions-optimistic\"/>."
+"\"transactions-optimistic\" />."
 msgstr ""
 "긴 작업 단위에 대한 다른 모형들은 <xref linkend=\"transactions-optimistic\"/>"
 "에서 논의된다."
 
 #. Tag: title
-#: session_api.xml:606
 #, no-c-format
 msgid "Automatic state detection"
 msgstr "자동적인 상태 검출"
 
 #. Tag: para
-#: session_api.xml:608
 #, no-c-format
 msgid ""
 "Hibernate users have requested a general purpose method that either saves a "
@@ -1348,26 +905,7 @@
 "일반적인 용도의 메소드를 요청했다. <literal>saveOrUpdate()</literal> 메소드"
 "는 이 기능을 구현한다."
 
-#. Tag: programlisting
-#: session_api.xml:615
-#, no-c-format
-msgid ""
-"<![CDATA[// in the first session\n"
-"Cat cat = (Cat) firstSession.load(Cat.class, catID);\n"
-"\n"
-"// in a higher tier of the application\n"
-"Cat mate = new Cat();\n"
-"cat.setMate(mate);\n"
-"\n"
-"// later, in a new session\n"
-"secondSession.saveOrUpdate(cat);   // update existing state (cat has a non-"
-"null id)\n"
-"secondSession.saveOrUpdate(mate);  // save the new instance (mate has a null "
-"id)]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:617
 #, no-c-format
 msgid ""
 "The usage and semantics of <literal>saveOrUpdate()</literal> seems to be "
@@ -1385,7 +923,6 @@
 "코 사용하지 않을 것이다."
 
 #. Tag: para
-#: session_api.xml:625
 #, no-c-format
 msgid ""
 "Usually <literal>update()</literal> or <literal>saveOrUpdate()</literal> are "
@@ -1395,31 +932,26 @@
 "음 시나리오에서 사용된다:"
 
 #. Tag: para
-#: session_api.xml:632
 #, no-c-format
 msgid "the application loads an object in the first session"
 msgstr "어플리케이션이 첫 번째 세션 내에 객체를 로드시킨다"
 
 #. Tag: para
-#: session_api.xml:637
 #, no-c-format
 msgid "the object is passed up to the UI tier"
 msgstr "객체가 UI 티어로 전달된다"
 
 #. Tag: para
-#: session_api.xml:642
 #, no-c-format
 msgid "some modifications are made to the object"
 msgstr "몇몇 변경들이 그 객체에 행해진다"
 
 #. Tag: para
-#: session_api.xml:647
 #, no-c-format
 msgid "the object is passed back down to the business logic tier"
 msgstr "객체가 비지니스 로직 티어로 전달된다"
 
 #. Tag: para
-#: session_api.xml:652
 #, no-c-format
 msgid ""
 "the application persists these modifications by calling <literal>update()</"
@@ -1429,20 +961,17 @@
 "들 변경들을 영속화 시킨다"
 
 #. Tag: para
-#: session_api.xml:659
 #, no-c-format
 msgid "<literal>saveOrUpdate()</literal> does the following:"
 msgstr "<literal>saveOrUpdate()</literal>는 다음을 행한다:"
 
 #. Tag: para
-#: session_api.xml:665
 #, no-c-format
 msgid "if the object is already persistent in this session, do nothing"
 msgstr ""
 "만일 객체가 이 세션 내에서 이미 영속화 되어 있을 경우, 아무것도 행하지 않는다"
 
 #. Tag: para
-#: session_api.xml:670
 #, no-c-format
 msgid ""
 "if another object associated with the session has the same identifier, throw "
@@ -1452,7 +981,6 @@
 "진다"
 
 #. Tag: para
-#: session_api.xml:676
 #, no-c-format
 msgid "if the object has no identifier property, <literal>save()</literal> it"
 msgstr ""
@@ -1460,7 +988,6 @@
 "literal> 시킨다"
 
 #. Tag: para
-#: session_api.xml:681
 #, no-c-format
 msgid ""
 "if the object's identifier has the value assigned to a newly instantiated "
@@ -1470,7 +997,6 @@
 "<literal>save()</literal> 시킨다"
 
 #. Tag: para
-#: session_api.xml:687
 #, fuzzy, no-c-format
 msgid ""
 "if the object is versioned by a <literal>&lt;version&gt;</literal> or "
@@ -1484,19 +1010,16 @@
 "literal> 시킨다"
 
 #. Tag: para
-#: session_api.xml:695
 #, no-c-format
 msgid "otherwise <literal>update()</literal> the object"
 msgstr "그 밖의 경우 그 객체를 <literal>update()</literal> 시킨다"
 
 #. Tag: para
-#: session_api.xml:701
 #, no-c-format
 msgid "and <literal>merge()</literal> is very different:"
 msgstr "그리고 <literal>merge()</literal>는 매우 다르다:"
 
 #. Tag: para
-#: session_api.xml:707
 #, no-c-format
 msgid ""
 "if there is a persistent instance with the same identifier currently "
@@ -1507,7 +1030,6 @@
 "어진 객체의 상태를 영속 인스턴스 상으로 복사한다"
 
 #. Tag: para
-#: session_api.xml:714
 #, no-c-format
 msgid ""
 "if there is no persistent instance currently associated with the session, "
@@ -1518,13 +1040,11 @@
 "다"
 
 #. Tag: para
-#: session_api.xml:720
 #, no-c-format
 msgid "the persistent instance is returned"
 msgstr "영속 인스턴스가 반환된다"
 
 #. Tag: para
-#: session_api.xml:725
 #, no-c-format
 msgid ""
 "the given instance does not become associated with the session, it remains "
@@ -1533,13 +1053,11 @@
 "주어진 인스턴스는 세션과 연관되지 않고, 그것은 detached 상태에 머무른다"
 
 #. Tag: title
-#: session_api.xml:735
 #, no-c-format
 msgid "Deleting persistent objects"
 msgstr "영속 객체들을 삭제하기"
 
 #. Tag: para
-#: session_api.xml:737
 #, fuzzy, no-c-format
 msgid ""
 "<literal>Session.delete()</literal> will remove an object's state from the "
@@ -1552,14 +1070,7 @@
 "할 것이다. 영속 인스턴스를 transient로 만들 때 <literal>delete()</literal>를 "
 "생각하는 것이 최상이다."
 
-#. Tag: programlisting
-#: session_api.xml:744
-#, no-c-format
-msgid "<![CDATA[sess.delete(cat);]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:746
 #, fuzzy, no-c-format
 msgid ""
 "You can delete objects in any order, without risk of foreign key constraint "
@@ -1574,13 +1085,11 @@
 "는 것을 잊은 경우."
 
 #. Tag: title
-#: session_api.xml:757
 #, no-c-format
 msgid "Replicating object between two different datastores"
 msgstr "두 개의 다른 데이터저장소들 사이에 객체들을 복제하기"
 
 #. Tag: para
-#: session_api.xml:759
 #, fuzzy, no-c-format
 msgid ""
 "It is sometimes useful to be able to take a graph of persistent instances "
@@ -1590,27 +1099,7 @@
 "영속 인스턴스들의 그래프를 취하고 식별자 값들을 다시 생성시키지 않고서 그것들"
 "을 다른 저장소 속에 영속화 시키는 것을 가능하도록 만드는 것이 종종 유용하다."
 
-#. Tag: programlisting
-#: session_api.xml:765
-#, no-c-format
-msgid ""
-"<![CDATA[//retrieve a cat from one database\n"
-"Session session1 = factory1.openSession();\n"
-"Transaction tx1 = session1.beginTransaction();\n"
-"Cat cat = session1.get(Cat.class, catId);\n"
-"tx1.commit();\n"
-"session1.close();\n"
-"\n"
-"//reconcile with a second database\n"
-"Session session2 = factory2.openSession();\n"
-"Transaction tx2 = session2.beginTransaction();\n"
-"session2.replicate(cat, ReplicationMode.LATEST_VERSION);\n"
-"tx2.commit();\n"
-"session2.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:767
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>ReplicationMode</literal> determines how <literal>replicate()</"
@@ -1620,7 +1109,6 @@
 "베이스 내에 있는 기존의 행들과의 충돌을 처리하게될 방법을 결정한다."
 
 #. Tag: para
-#: session_api.xml:774
 #, fuzzy, no-c-format
 msgid ""
 "<literal>ReplicationMode.IGNORE</literal>: ignores the object when there is "
@@ -1630,7 +1118,6 @@
 "베이스 행이 존재할 경우에 그 객체를 무시한다"
 
 #. Tag: para
-#: session_api.xml:780
 #, fuzzy, no-c-format
 msgid ""
 "<literal>ReplicationMode.OVERWRITE</literal>: overwrites any existing "
@@ -1640,7 +1127,6 @@
 "의 데이터베이스 행을 덮어 쓴다"
 
 #. Tag: para
-#: session_api.xml:786
 #, fuzzy, no-c-format
 msgid ""
 "<literal>ReplicationMode.EXCEPTION</literal>: throws an exception if there "
@@ -1650,7 +1136,6 @@
 "존 데이터베이스 행이 존재할 경우에 예외상황을 던진다"
 
 #. Tag: para
-#: session_api.xml:792
 #, fuzzy, no-c-format
 msgid ""
 "<literal>ReplicationMode.LATEST_VERSION</literal>: overwrites the row if its "
@@ -1661,7 +1146,6 @@
 "버전 번호 보다 이전의 것이면 덮어쓰고, 그 밖의 경우에 그 객체를 무시한다"
 
 #. Tag: para
-#: session_api.xml:800
 #, no-c-format
 msgid ""
 "Usecases for this feature include reconciling data entered into different "
@@ -1674,13 +1158,11 @@
 "션들 동안에 행해진 변경들을 롤백시키기 등을 포함한다."
 
 #. Tag: title
-#: session_api.xml:809
 #, no-c-format
 msgid "Flushing the Session"
 msgstr "Session을 flush 시키기"
 
 #. Tag: para
-#: session_api.xml:811
 #, fuzzy, no-c-format
 msgid ""
 "Sometimes the <literal>Session</literal> will execute the SQL statements "
@@ -1694,31 +1176,26 @@
 "다"
 
 #. Tag: para
-#: session_api.xml:820
 #, no-c-format
 msgid "before some query executions"
 msgstr "몇몇 질의들이 실행되기 전에"
 
 #. Tag: para
-#: session_api.xml:825
 #, no-c-format
 msgid "from <literal>org.hibernate.Transaction.commit()</literal>"
 msgstr "<literal>org.hibernate.Transaction.commit()</literal> 시점에서"
 
 #. Tag: para
-#: session_api.xml:830
 #, no-c-format
 msgid "from <literal>Session.flush()</literal>"
 msgstr "<literal>Session.flush()</literal> 시점에서"
 
 #. Tag: para
-#: session_api.xml:836
 #, fuzzy, no-c-format
 msgid "The SQL statements are issued in the following order:"
 msgstr "SQL 문장들이 다음 순서로 실행 명령이 내려진다"
 
 #. Tag: para
-#: session_api.xml:842
 #, fuzzy, no-c-format
 msgid ""
 "all entity insertions in the same order the corresponding objects were saved "
@@ -1728,31 +1205,26 @@
 "과 같은 순서로, 모든 엔티티 삽입들"
 
 #. Tag: para
-#: session_api.xml:848
 #, no-c-format
 msgid "all entity updates"
 msgstr "모든 엔티티 업데이트들"
 
 #. Tag: para
-#: session_api.xml:853
 #, no-c-format
 msgid "all collection deletions"
 msgstr "모든 콜렉션 삭제들"
 
 #. Tag: para
-#: session_api.xml:858
 #, no-c-format
 msgid "all collection element deletions, updates and insertions"
 msgstr "모든 콜렉션 요소 삭제들, 업데이트들 그리고 삽입들"
 
 #. Tag: para
-#: session_api.xml:863
 #, no-c-format
 msgid "all collection insertions"
 msgstr "모든 콜렉션 삽입들"
 
 #. Tag: para
-#: session_api.xml:868
 #, fuzzy, no-c-format
 msgid ""
 "all entity deletions in the same order the corresponding objects were "
@@ -1762,7 +1234,6 @@
 "것과 같은 순서로 모든 엔티티 삭제들."
 
 #. Tag: para
-#: session_api.xml:875
 #, fuzzy, no-c-format
 msgid ""
 "An exception is that objects using <literal>native</literal> ID generation "
@@ -1772,7 +1243,6 @@
 "는 객체들이 insert 되는 점이다.)"
 
 #. Tag: para
-#: session_api.xml:880
 #, fuzzy, no-c-format
 msgid ""
 "Except when you explicitly <literal>flush()</literal>, there are absolutely "
@@ -1789,7 +1259,6 @@
 "반환하지 않을 것임을 보장한다."
 
 #. Tag: para
-#: session_api.xml:888
 #, fuzzy, no-c-format
 msgid ""
 "It is possible to change the default behavior so that flush occurs less "
@@ -1799,7 +1268,7 @@
 "never flush unless <literal>flush()</literal> is called explicitly. The last "
 "mode is useful for long running units of work, where a <literal>Session</"
 "literal> is kept open and disconnected for a long time (see <xref linkend="
-"\"transactions-optimistic-longsession\"/>)."
+"\"transactions-optimistic-longsession\" />)."
 msgstr ""
 "flush가 너무 자주 발생하지 않도록 디폴트 행위를 변경하는 것이 가능하다. "
 "<literal>FlushMode</literal> 클래스는 세 개의 다른 모드들을 정의한다: 오직 커"
@@ -1810,34 +1279,13 @@
 "literal>은 열려진채로 유지되고 오랜 시간 동안 연결이 해제된 채로 유지된다. "
 "(<xref linkend=\"transactions-optimistic-longsession\"/>를 보라)."
 
-#. Tag: programlisting
-#: session_api.xml:898
-#, no-c-format
-msgid ""
-"<![CDATA[sess = sf.openSession();\n"
-"Transaction tx = sess.beginTransaction();\n"
-"sess.setFlushMode(FlushMode.COMMIT); // allow queries to return stale state\n"
-"\n"
-"Cat izi = (Cat) sess.load(Cat.class, id);\n"
-"izi.setName(iznizi);\n"
-"\n"
-"// might return stale data\n"
-"sess.find(\"from Cat as cat left outer join cat.kittens kitten\");\n"
-"\n"
-"// change to izi is not flushed!\n"
-"...\n"
-"tx.commit(); // flush occurs\n"
-"sess.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:900
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "During flush, an exception might occur (e.g. if a DML operation violates a "
 "constraint). Since handling exceptions involves some understanding of "
 "Hibernate's transactional behavior, we discuss it in <xref linkend="
-"\"transactions\"/>."
+"\"transactions\" />."
 msgstr ""
 "flush 동안에, 하나의 예외상황이 발생할 수도 있다(예를 들면. 만일 DML 오퍼레이"
 "션이 컨스트레인트를 위반할 경우). 예외상황들을 처리하는 것은 Hibernatem의 트"
@@ -1845,13 +1293,11 @@
 "\"/>에서 그것을 논의한다."
 
 #. Tag: title
-#: session_api.xml:909
 #, no-c-format
 msgid "Transitive persistence"
 msgstr "Transitive persistence(전이 영속)"
 
 #. Tag: para
-#: session_api.xml:911
 #, no-c-format
 msgid ""
 "It is quite cumbersome to save, delete, or reattach individual objects, "
@@ -1863,7 +1309,6 @@
 "식 관계이다. 다음 예제를 검토하자:"
 
 #. Tag: para
-#: session_api.xml:917
 #, fuzzy, no-c-format
 msgid ""
 "If the children in a parent/child relationship would be value typed (e.g. a "
@@ -1885,7 +1330,6 @@
 "스로부터 그 자식을 삭제시킨다."
 
 #. Tag: para
-#: session_api.xml:928
 #, fuzzy, no-c-format
 msgid ""
 "Now consider the same scenario with parent and child objects being entities, "
@@ -1906,7 +1350,6 @@
 "다."
 
 #. Tag: para
-#: session_api.xml:937
 #, no-c-format
 msgid ""
 "For each basic operation of the Hibernate session - including "
@@ -1925,27 +1368,12 @@
 "의 연관에 따라 케스케이딩되는 것을 원할 경우, 당신은 매핑 문서 내에 그것을 지"
 "시해야 한다. 예를 들면:"
 
-#. Tag: programlisting
-#: session_api.xml:946
-#, no-c-format
-msgid "<![CDATA[<one-to-one name=\"person\" cascade=\"persist\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:948
 #, no-c-format
 msgid "Cascade styles my be combined:"
 msgstr "케스케이딩 스타일들이 결합될 수도 있다:"
 
-#. Tag: programlisting
-#: session_api.xml:952
-#, no-c-format
-msgid ""
-"<![CDATA[<one-to-one name=\"person\" cascade=\"persist,delete,lock\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:954
 #, fuzzy, no-c-format
 msgid ""
 "You can even use <literal>cascade=\"all\"</literal> to specify that "
@@ -1959,7 +1387,6 @@
 "을 것임을 지정한다."
 
 #. Tag: para
-#: session_api.xml:960
 #, no-c-format
 msgid ""
 "A special cascade style, <literal>delete-orphan</literal>, applies only to "
@@ -1972,13 +1399,11 @@
 "로부터 제거되는 임의의 자식 객체에 적용되어야 함을 나타낸다."
 
 #. Tag: para
-#: session_api.xml:967
 #, no-c-format
 msgid "Recommendations:"
 msgstr "권장사항들 :"
 
 #. Tag: para
-#: session_api.xml:973
 #, fuzzy, no-c-format
 msgid ""
 "It does not usually make sense to enable cascade on a <literal>&lt;many-to-"
@@ -1992,7 +1417,6 @@
 "one-to-many&gt;</literal> 연관에 대해 종종 유용하다."
 
 #. Tag: para
-#: session_api.xml:981
 #, no-c-format
 msgid ""
 "If the child object's lifespan is bounded by the lifespan of the parent "
@@ -2004,7 +1428,6 @@
 "<emphasis>생명 주기 객체</emphasis>로 만들어라."
 
 #. Tag: para
-#: session_api.xml:988
 #, no-c-format
 msgid ""
 "Otherwise, you might not need cascade at all. But if you think that you will "
@@ -2019,7 +1442,6 @@
 "하라."
 
 #. Tag: para
-#: session_api.xml:996
 #, no-c-format
 msgid ""
 "Mapping an association (either a single valued association, or a collection) "
@@ -2033,7 +1455,6 @@
 "타일의 관계로 마크한다."
 
 #. Tag: para
-#: session_api.xml:1002
 #, fuzzy, no-c-format
 msgid ""
 "Furthermore, a mere reference to a child from a persistent parent will "
@@ -2052,7 +1473,6 @@
 "케이딩 오퍼레이션의 정확한 의미는 다음과 같다:"
 
 #. Tag: para
-#: session_api.xml:1013
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>persist()</literal>, all children are "
@@ -2062,7 +1482,6 @@
 "<literal>persist()</literal>에 전달된다"
 
 #. Tag: para
-#: session_api.xml:1019
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>merge()</literal>, all children are passed "
@@ -2072,7 +1491,6 @@
 "<literal>merge()</literal>에 전달된다"
 
 #. Tag: para
-#: session_api.xml:1025
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>save()</literal>, <literal>update()</"
@@ -2084,7 +1502,6 @@
 "<literal>saveOrUpdate()</literal>에 전달된다"
 
 #. Tag: para
-#: session_api.xml:1031
 #, no-c-format
 msgid ""
 "If a transient or detached child becomes referenced by a persistent parent, "
@@ -2094,7 +1511,6 @@
 "<literal>saveOrUpdate()</literal>에 전달된다"
 
 #. Tag: para
-#: session_api.xml:1037
 #, no-c-format
 msgid ""
 "If a parent is deleted, all children are passed to <literal>delete()</"
@@ -2103,7 +1519,6 @@
 "만일 부모가 삭제될 경우, 모든 자식들이 <literal>delete()</literal>에 전달된다"
 
 #. Tag: para
-#: session_api.xml:1042
 #, no-c-format
 msgid ""
 "If a child is dereferenced by a persistent parent, <emphasis>nothing special "
@@ -2118,7 +1533,6 @@
 "우 자식이 삭제된다."
 
 #. Tag: para
-#: session_api.xml:1051
 #, fuzzy, no-c-format
 msgid ""
 "Finally, note that cascading of operations can be applied to an object graph "
@@ -2136,13 +1550,11 @@
 "flush 동안에 도달 가능한 모든 연관된 엔티티들에 대해 이행적(transitive)이다."
 
 #. Tag: title
-#: session_api.xml:1063
 #, no-c-format
 msgid "Using metadata"
 msgstr "메타데이터 사용하기"
 
 #. Tag: para
-#: session_api.xml:1065
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate requires a rich meta-level model of all entity and value types. "
@@ -2160,7 +1572,6 @@
 "copy 알고리즘을 구현하는데 Hibernate의 메타데이터를 사용할 수도 있다."
 
 #. Tag: para
-#: session_api.xml:1072
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate exposes metadata via the <literal>ClassMetadata</literal> and "
@@ -2173,27 +1584,6 @@
 "literal> 계층구조를 통해 메타데이터를 노출시킨다. 메타데이터 인터페이스들의 "
 "인스턴스들은 <literal>SessionFactory</literal>로부터 얻어질 수도 있다."
 
-#. Tag: programlisting
-#: session_api.xml:1079
-#, no-c-format
-msgid ""
-"<![CDATA[Cat fritz = ......;\n"
-"ClassMetadata catMeta = sessionfactory.getClassMetadata(Cat.class);\n"
-"\n"
-"Object[] propertyValues = catMeta.getPropertyValues(fritz);\n"
-"String[] propertyNames = catMeta.getPropertyNames();\n"
-"Type[] propertyTypes = catMeta.getPropertyTypes();\n"
-"\n"
-"// get a Map of all properties which are not collections or associations\n"
-"Map namedValues = new HashMap();\n"
-"for ( int i=0; i<propertyNames.length; i++ ) {\n"
-"    if ( !propertyTypes[i].isEntityType() && !propertyTypes[i]."
-"isCollectionType() ) {\n"
-"        namedValues.put( propertyNames[i], propertyValues[i] );\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #~ msgid "UPDATE"
 #~ msgstr "UPDATE"
 

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/toolset_guide.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/toolset_guide.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/toolset_guide.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,13 +11,11 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: toolset_guide.xml:29
 #, no-c-format
 msgid "Toolset Guide"
 msgstr "도구셋 안내"
 
 #. Tag: para
-#: toolset_guide.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "Roundtrip engineering with Hibernate is possible using a set of Eclipse "
@@ -27,7 +25,6 @@
 "들, 뿐만 아니라 Ant 태스크들을 사용하여 가능하다."
 
 #. Tag: para
-#: toolset_guide.xml:36
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Hibernate Tools</emphasis> currently include plugins for the "
@@ -39,7 +36,6 @@
 "하고 있다:"
 
 #. Tag: para
-#: toolset_guide.xml:42
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Mapping Editor:</emphasis> an editor for Hibernate XML mapping "
@@ -53,7 +49,6 @@
 "론적 자동 완성 기능을 지원한다."
 
 #. Tag: para
-#: toolset_guide.xml:47
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Console:</emphasis> the console is a new view in Eclipse. In "
@@ -69,7 +64,6 @@
 "해준다."
 
 #. Tag: para
-#: toolset_guide.xml:54
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Development Wizards:</emphasis> several wizards are provided with "
@@ -85,7 +79,6 @@
 "지니어링 마법사는 맞춤 가능한 템플릿들을 제공한다."
 
 #. Tag: para
-#: toolset_guide.xml:67
 #, fuzzy, no-c-format
 msgid ""
 "Please refer to the <emphasis>Hibernate Tools</emphasis> package "
@@ -95,7 +88,6 @@
 "하길 바란다."
 
 #. Tag: para
-#: toolset_guide.xml:72
 #, fuzzy, no-c-format
 msgid ""
 "However, the Hibernate main package comes bundled with an integrated tool : "
@@ -107,13 +99,11 @@
 "emphasis> 별칭은 <literal>hbm2ddl</literal>."
 
 #. Tag: title
-#: toolset_guide.xml:79
 #, no-c-format
 msgid "Automatic schema generation"
 msgstr "자동적인 스키마 생성"
 
 #. Tag: para
-#: toolset_guide.xml:81
 #, fuzzy, no-c-format
 msgid ""
 "DDL can be generated from your mapping files by a Hibernate utility. The "
@@ -127,7 +117,6 @@
 "식별자 생성기들에 대해 생성된다."
 
 #. Tag: para
-#: toolset_guide.xml:88
 #, fuzzy, no-c-format
 msgid ""
 "You <emphasis>must</emphasis> specify a SQL <literal>Dialect</literal> via "
@@ -139,7 +128,6 @@
 "정<emphasis>해야 한다</emphasis>."
 
 #. Tag: para
-#: toolset_guide.xml:94
 #, fuzzy, no-c-format
 msgid ""
 "First, you must customize your mapping files to improve the generated "
@@ -148,13 +136,11 @@
 "먼저 생성된 스키마를 개선시키기 위해 당신의 매핑 파일들을 맞춤화 시켜라."
 
 #. Tag: title
-#: toolset_guide.xml:99
 #, no-c-format
 msgid "Customizing the schema"
 msgstr "스키마 맞춤화 시키기"
 
 #. Tag: para
-#: toolset_guide.xml:101
 #, fuzzy, no-c-format
 msgid ""
 "Many Hibernate mapping elements define optional attributes named "
@@ -169,20 +155,7 @@
 "<literal>scale</literal>로 명명된 옵션 속성들을 정의하고 있다. 당신은 이 속성"
 "으로서 컬럼이 길이, 정밀도, 크기를 설정할 수 있다."
 
-#. Tag: programlisting
-#: toolset_guide.xml:108
-#, no-c-format
-msgid "<![CDATA[<property name=\"zip\" length=\"5\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:109
-#, no-c-format
-msgid "<![CDATA[<property name=\"balance\" precision=\"12\" scale=\"2\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:111
 #, fuzzy, no-c-format
 msgid ""
 "Some tags also accept a <literal>not-null</literal> attribute for generating "
@@ -195,23 +168,7 @@
 "<literal>UNIQUE</literal> 컨스트레인트를 생성시키는) <literal>unique</"
 "literal> 속성을 수용한다."
 
-#. Tag: programlisting
-#: toolset_guide.xml:117
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"bar\" column=\"barId\" not-null=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:119
-#, no-c-format
-msgid ""
-"<![CDATA[<element column=\"serialNumber\" type=\"long\" not-null=\"true\" "
-"unique=\"true\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:121
 #, fuzzy, no-c-format
 msgid ""
 "A <literal>unique-key</literal> attribute can be used to group columns in a "
@@ -225,17 +182,7 @@
 "된 값은 산출된 DDL내에서 컨스트레인트를 명명하는데 사용되지 <emphasis>않고</"
 "emphasis>, 오직 매핑 파일 내에서 컬럼들을 그룹 지우는데 사용된다."
 
-#. Tag: programlisting
-#: toolset_guide.xml:129
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"org\" column=\"orgId\" unique-key="
-"\"OrgEmployeeId\"/>\n"
-"<property name=\"employeeId\" unique-key=\"OrgEmployee\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:131
 #, fuzzy, no-c-format
 msgid ""
 "An <literal>index</literal> attribute specifies the name of an index that "
@@ -246,16 +193,7 @@
 "덱스의 이름을 지정한다. 간단하게 동일한 인덱스 이름을 지정함으로써 여러 컬럼"
 "들이 동일한 인덱스 내로 그룹지워질 수도 있다."
 
-#. Tag: programlisting
-#: toolset_guide.xml:137
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"lastName\" index=\"CustName\"/>\n"
-"<property name=\"firstName\" index=\"CustName\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:139
 #, fuzzy, no-c-format
 msgid ""
 "A <literal>foreign-key</literal> attribute can be used to override the name "
@@ -264,16 +202,7 @@
 "<literal>foreign-key</literal> 속성은 임의의 산출된 foreign 키 컨스트레인트"
 "의 이름을 오버라이드 시키는데 사용될 수 도 있다."
 
-#. Tag: programlisting
-#: toolset_guide.xml:144
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"bar\" column=\"barId\" foreign-key=\"FKFooBar\"/"
-">]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:146
 #, no-c-format
 msgid ""
 "Many mapping elements also accept a child <literal>&lt;column&gt;</literal> "
@@ -282,21 +211,7 @@
 "많은 매핑 요소들은 또한 하나의 자식 <literal>&lt;column&gt;</literal> 요소를 "
 "허용한다. 이것은 특히 다중 컬럼 타입들을 매핑하는데 유용하다:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:151
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"name\" type=\"my.customtypes.Name\"/>\n"
-"    <column name=\"last\" not-null=\"true\" index=\"bar_idx\" length=\"30\"/"
-">\n"
-"    <column name=\"first\" not-null=\"true\" index=\"bar_idx\" length=\"20\"/"
-">\n"
-"    <column name=\"initial\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:153
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>default</literal> attribute allows you to specify a default "
@@ -309,26 +224,7 @@
 "다(당신은 매핑된 클래스의 새로운 인스턴스를 저장하기 전에 매핑된 프로퍼티에 "
 "동일한 값을 할당하게 될 것이다)."
 
-#. Tag: programlisting
-#: toolset_guide.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"credits\" type=\"integer\" insert=\"false\">\n"
-"    <column name=\"credits\" default=\"10\"/>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:161
-#, no-c-format
-msgid ""
-"<![CDATA[<version name=\"version\" type=\"integer\" insert=\"false\">\n"
-"    <column name=\"version\" default=\"0\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:163
 #, no-c-format
 msgid ""
 "The <literal>sql-type</literal> attribute allows the user to override the "
@@ -337,17 +233,7 @@
 "<literal>sql-type</literal> 속성은 SQL 데이터타입에 대한 Hibernate 타입의 디"
 "폴트 매핑을 오버라이드 시키는 것을 사용자에게 허용해준다."
 
-#. Tag: programlisting
-#: toolset_guide.xml:168
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"balance\" type=\"float\">\n"
-"    <column name=\"balance\" sql-type=\"decimal(13,3)\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:170
 #, no-c-format
 msgid ""
 "The <literal>check</literal> attribute allows you to specify a check "
@@ -356,177 +242,132 @@
 "<literal>check</literal> 속성은 check 컨스트레인트를 지정하는 것을 당신에게 "
 "허용해준다."
 
-#. Tag: programlisting
-#: toolset_guide.xml:174
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"foo\" type=\"integer\">\n"
-"    <column name=\"foo\" check=\"foo > 10\"/>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:176
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Foo\" table=\"foos\" check=\"bar < 100.0\">\n"
-"    ...\n"
-"    <property name=\"bar\" type=\"float\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:179
 #, no-c-format
 msgid "The following table summarizes these optional attributes."
 msgstr ""
 
 #. Tag: title
-#: toolset_guide.xml:182
 #, no-c-format
 msgid "Summary"
 msgstr "요약"
 
 #. Tag: entry
-#: toolset_guide.xml:189
 #, no-c-format
 msgid "Attribute"
 msgstr "속성"
 
 #. Tag: entry
-#: toolset_guide.xml:190
 #, no-c-format
 msgid "Values"
 msgstr "값들"
 
 #. Tag: entry
-#: toolset_guide.xml:191
 #, no-c-format
 msgid "Interpretation"
 msgstr "해석"
 
-#. Tag: literal
-#: toolset_guide.xml:196
-#, no-c-format
-msgid "length"
-msgstr "length"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>length</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:197 toolset_guide.xml:202 toolset_guide.xml:207
 #, no-c-format
 msgid "number"
 msgstr "number"
 
 #. Tag: entry
-#: toolset_guide.xml:198
 #, no-c-format
 msgid "column length"
 msgstr "컬럼 길이"
 
-#. Tag: literal
-#: toolset_guide.xml:201
-#, no-c-format
-msgid "precision"
-msgstr "precision"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>precision</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:203
 #, no-c-format
 msgid "column decimal precision"
 msgstr "컬럼 decimal 정밀도"
 
-#. Tag: literal
-#: toolset_guide.xml:206
-#, no-c-format
-msgid "scale"
-msgstr "scale"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>scale</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:208
 #, no-c-format
 msgid "column decimal scale"
 msgstr "컬럼 decimal 크기"
 
-#. Tag: literal
-#: toolset_guide.xml:211
-#, no-c-format
-msgid "not-null"
-msgstr "not-null"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>not-null</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
-#. Tag: literal
-#: toolset_guide.xml:212 toolset_guide.xml:217
-#, no-c-format
-msgid "true|false"
-msgstr "true|false"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>true|false</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:213
 #, fuzzy, no-c-format
 msgid "specifies that the column should be non-nullable"
 msgstr "컬럼이 null이 아니어야 함을 지정한다"
 
-#. Tag: literal
-#: toolset_guide.xml:216
-#, no-c-format
-msgid "unique"
-msgstr "unique"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>unique</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:218
 #, no-c-format
 msgid "specifies that the column should have a unique constraint"
 msgstr "컬럼이 하나의 유일 컨스트레인트를 가져야함을 지정한다"
 
-#. Tag: literal
-#: toolset_guide.xml:221
-#, no-c-format
-msgid "index"
-msgstr "index"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>index</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
-#. Tag: literal
-#: toolset_guide.xml:222
-#, no-c-format
-msgid "index_name"
-msgstr "index_name"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>index_name</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:223
 #, no-c-format
 msgid "specifies the name of a (multi-column) index"
 msgstr "(다중-컬럼) 인덱스의 이름을 지정한다"
 
-#. Tag: literal
-#: toolset_guide.xml:226
-#, no-c-format
-msgid "unique-key"
-msgstr "unique-key"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>unique-key</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
-#. Tag: literal
-#: toolset_guide.xml:227
-#, no-c-format
-msgid "unique_key_name"
-msgstr "unique_key_name"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>unique_key_name</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:228
 #, no-c-format
 msgid "specifies the name of a multi-column unique constraint"
 msgstr "다중-컬럼 유일 컨스트레인트의 이름을 지정한다"
 
-#. Tag: literal
-#: toolset_guide.xml:231
-#, no-c-format
-msgid "foreign-key"
-msgstr "foreign-key"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>foreign-key</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
-#. Tag: literal
-#: toolset_guide.xml:232
-#, no-c-format
-msgid "foreign_key_name"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>foreign_key_name</literal>"
 msgstr "foreign_key_name"
 
 #. Tag: entry
-#: toolset_guide.xml:233
 #, fuzzy, no-c-format
 msgid ""
 "specifies the name of the foreign key constraint generated for an "
@@ -540,20 +381,17 @@
 "다.<placeholder-5/> 측들은 <placeholder-6/>에 의해 고려되지 않을 것임을 노트"
 "하라."
 
-#. Tag: literal
-#: toolset_guide.xml:243
-#, no-c-format
-msgid "sql-type"
-msgstr "sql-type"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>sql-type</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
-#. Tag: literal
-#: toolset_guide.xml:244
-#, no-c-format
-msgid "SQL column type"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>SQL column type</literal>"
 msgstr "SQL column type"
 
 #. Tag: entry
-#: toolset_guide.xml:245
 #, fuzzy, no-c-format
 msgid ""
 "overrides the default column type (attribute of <literal>&lt;column&gt;</"
@@ -561,38 +399,32 @@
 msgstr ""
 "디폴트 컬럼 타입을 오버라이드 시킨다 (<placeholder-1/> 요소의 속성에만)"
 
-#. Tag: literal
-#: toolset_guide.xml:251
-#, no-c-format
-msgid "default"
-msgstr "default"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>default</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:252 toolset_guide.xml:259
 #, no-c-format
 msgid "SQL expression"
 msgstr "SQL expression"
 
 #. Tag: entry
-#: toolset_guide.xml:253
 #, no-c-format
 msgid "specify a default value for the column"
 msgstr "컬럼에 대한 디폴트 값을 지정한다"
 
-#. Tag: literal
-#: toolset_guide.xml:258
-#, no-c-format
-msgid "check"
-msgstr "check"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>check</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:260
 #, no-c-format
 msgid "create an SQL check constraint on either column or table"
 msgstr "컬럼 또는 테이블에 대한 SQL check 컨스트레인트를 생성시킨다"
 
 #. Tag: para
-#: toolset_guide.xml:268
 #, no-c-format
 msgid ""
 "The <literal>&lt;comment&gt;</literal> element allows you to specify "
@@ -601,29 +433,7 @@
 "<literal>&lt;comment&gt;</literal> 요소는 생성된 스키마에 대한 주석들을 지정"
 "하는 것을 당신에게 허용해준다."
 
-#. Tag: programlisting
-#: toolset_guide.xml:273
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Customer\" table=\"CurCust\">\n"
-"    <comment>Current customers only</comment>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:275
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"balance\">\n"
-"    <column name=\"bal\">\n"
-"        <comment>Balance in USD</comment>\n"
-"    </column>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:277
 #, fuzzy, no-c-format
 msgid ""
 "This results in a <literal>comment on table</literal> or <literal>comment on "
@@ -633,13 +443,11 @@
 "는 <literal>comment on column</literal> 문장으로 귀결된다."
 
 #. Tag: title
-#: toolset_guide.xml:286
 #, no-c-format
 msgid "Running the tool"
 msgstr "도구 실행하기"
 
 #. Tag: para
-#: toolset_guide.xml:288
 #, no-c-format
 msgid ""
 "The <literal>SchemaExport</literal> tool writes a DDL script to standard out "
@@ -649,7 +457,6 @@
 "고/하거나 DDL 문장들을 실행시킨다."
 
 #. Tag: para
-#: toolset_guide.xml:293
 #, fuzzy, no-c-format
 msgid ""
 "The following table displays the <literal>SchemaExport</literal> command "
@@ -657,7 +464,6 @@
 msgstr "<literal>SchemaExport</literal> 명령 라인 옵션들"
 
 #. Tag: para
-#: toolset_guide.xml:295
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
@@ -666,116 +472,96 @@
 msgstr ""
 
 #. Tag: title
-#: toolset_guide.xml:301
 #, no-c-format
 msgid "<literal>SchemaExport</literal> Command Line Options"
 msgstr "<literal>SchemaExport</literal> 명령 라인 옵션들"
 
 #. Tag: entry
-#: toolset_guide.xml:307 toolset_guide.xml:457 toolset_guide.xml:527
 #, no-c-format
 msgid "Option"
 msgstr "옵션"
 
 #. Tag: entry
-#: toolset_guide.xml:308 toolset_guide.xml:395 toolset_guide.xml:458
-#: toolset_guide.xml:528
 #, no-c-format
 msgid "Description"
 msgstr "설명"
 
-#. Tag: literal
-#: toolset_guide.xml:313 toolset_guide.xml:463
-#, no-c-format
-msgid "--quiet"
-msgstr "--quiet"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--quiet</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:314 toolset_guide.xml:464
 #, fuzzy, no-c-format
 msgid "do not output the script to stdout"
 msgstr "스크립트를 표준출력으로 출력하지 않는다"
 
-#. Tag: literal
-#: toolset_guide.xml:317
-#, no-c-format
-msgid "--drop"
-msgstr "--drop"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--drop</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:318
 #, no-c-format
 msgid "only drop the tables"
 msgstr "오직 테이블들을 드롭시킨다"
 
-#. Tag: literal
-#: toolset_guide.xml:321
-#, no-c-format
-msgid "--create"
-msgstr "--create"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--create</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:322
 #, no-c-format
 msgid "only create the tables"
 msgstr "오직 테이블들을 생성시킨다"
 
-#. Tag: literal
-#: toolset_guide.xml:325 toolset_guide.xml:467
-#, no-c-format
-msgid "--text"
-msgstr "--text"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--text</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:326
 #, fuzzy, no-c-format
 msgid "do not export to the database"
 msgstr "데이터베이스로 내보내기 하지 않는다"
 
-#. Tag: literal
-#: toolset_guide.xml:329
-#, no-c-format
-msgid "--output=my_schema.ddl"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--output=my_schema.ddl</literal>"
 msgstr "--output=my_schema.ddl"
 
 #. Tag: entry
-#: toolset_guide.xml:330
 #, no-c-format
 msgid "output the ddl script to a file"
 msgstr "ddl 스크립트를 파일로 출력한다"
 
-#. Tag: literal
-#: toolset_guide.xml:333 toolset_guide.xml:471 toolset_guide.xml:533
-#, no-c-format
-msgid "--naming=eg.MyNamingStrategy"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--naming=eg.MyNamingStrategy</literal>"
 msgstr "--naming=eg.MyNamingStrategy"
 
 #. Tag: entry
-#: toolset_guide.xml:334 toolset_guide.xml:472 toolset_guide.xml:534
 #, fuzzy, no-c-format
 msgid "select a <literal>NamingStrategy</literal>"
 msgstr "<literal>hibernate.properties</literal> 내에서"
 
-#. Tag: literal
-#: toolset_guide.xml:337 toolset_guide.xml:479 toolset_guide.xml:541
-#, no-c-format
-msgid "--config=hibernate.cfg.xml"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--config=hibernate.cfg.xml</literal>"
 msgstr "--config=hibernate.cfg.xml"
 
 #. Tag: entry
-#: toolset_guide.xml:338
 #, no-c-format
 msgid "read Hibernate configuration from an XML file"
 msgstr "XML 파일로부터 Hibernate 구성을 읽어들인다"
 
-#. Tag: literal
-#: toolset_guide.xml:341 toolset_guide.xml:475 toolset_guide.xml:537
-#, no-c-format
-msgid "--properties=hibernate.properties"
-msgstr "--properties=hibernate.properties"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--properties=hibernate.properties</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:342 toolset_guide.xml:476 toolset_guide.xml:538
 #, fuzzy, no-c-format
 msgid "read database properties from a file"
 msgstr ""
@@ -786,60 +572,44 @@
 "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "파일로부터 데이터베이스 프로퍼티들을 읽어들인다"
 
-#. Tag: literal
-#: toolset_guide.xml:345
-#, no-c-format
-msgid "--format"
-msgstr "--format"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--format</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:346
 #, no-c-format
 msgid "format the generated SQL nicely in the script"
 msgstr "생성된 SQL을 스크립트 내에 좋게 형식지운다"
 
-#. Tag: literal
-#: toolset_guide.xml:349
-#, no-c-format
-msgid "--delimiter=;"
-msgstr "--delimiter=;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--delimiter=;</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:350
 #, no-c-format
 msgid "set an end of line delimiter for the script"
 msgstr "스크립트를 위한 라인 경계의 끝을 설정한다"
 
 #. Tag: para
-#: toolset_guide.xml:356
 #, fuzzy, no-c-format
 msgid "You can even embed <literal>SchemaExport</literal> in your application:"
 msgstr ""
 "당신은 당신의 어플리케이션 내에 <literal>SchemaExport</literal>를 삽입시킬 수"
 "도 있다:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:360
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaExport(cfg).create(false, true);]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:365
 #, no-c-format
 msgid "Properties"
 msgstr "프로퍼티들"
 
 #. Tag: para
-#: toolset_guide.xml:367
 #, fuzzy, no-c-format
 msgid "Database properties can be specified:"
 msgstr "데이터베이스 프로퍼티들은 다음과 같이 지정될 수 있다"
 
 #. Tag: para
-#: toolset_guide.xml:373
 #, no-c-format
 msgid ""
 "as system properties with <literal>-D</literal><emphasis>&lt;property&gt;</"
@@ -849,103 +619,86 @@
 "퍼티로서"
 
 #. Tag: para
-#: toolset_guide.xml:376
 #, no-c-format
 msgid "in <literal>hibernate.properties</literal>"
 msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: para
-#: toolset_guide.xml:379
 #, no-c-format
 msgid "in a named properties file with <literal>--properties</literal>"
 msgstr "<literal>--properties</literal>를 가진 명명된 프로퍼티들 내에서"
 
 #. Tag: para
-#: toolset_guide.xml:383
 #, no-c-format
 msgid "The needed properties are:"
 msgstr "필요한 프로퍼티들은 다음과 같다:"
 
 #. Tag: title
-#: toolset_guide.xml:388
 #, no-c-format
 msgid "SchemaExport Connection Properties"
 msgstr "SchemaExport 커넥션 프로퍼티들"
 
 #. Tag: entry
-#: toolset_guide.xml:394
 #, no-c-format
 msgid "Property Name"
 msgstr "프로퍼티 이름"
 
-#. Tag: literal
-#: toolset_guide.xml:400
-#, no-c-format
-msgid "hibernate.connection.driver_class"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.driver_class</literal>"
 msgstr "hibernate.connection.driver_class"
 
 #. Tag: entry
-#: toolset_guide.xml:401
 #, no-c-format
 msgid "jdbc driver class"
 msgstr "jdbc 드라이버 클래스"
 
-#. Tag: literal
-#: toolset_guide.xml:404
-#, no-c-format
-msgid "hibernate.connection.url"
-msgstr "hibernate.connection.url"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.url</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:405
 #, no-c-format
 msgid "jdbc url"
 msgstr "jdbc url"
 
-#. Tag: literal
-#: toolset_guide.xml:408
-#, no-c-format
-msgid "hibernate.connection.username"
-msgstr "hibernate.connection.username"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.username</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:409
 #, no-c-format
 msgid "database user"
 msgstr "데이터베이스 사용자"
 
-#. Tag: literal
-#: toolset_guide.xml:412
-#, no-c-format
-msgid "hibernate.connection.password"
-msgstr "hibernate.connection.password"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.password</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:413
 #, no-c-format
 msgid "user password"
 msgstr "사용자 패스워드"
 
-#. Tag: literal
-#: toolset_guide.xml:416
-#, no-c-format
-msgid "hibernate.dialect"
-msgstr "hibernate.dialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.dialect</literal>"
+msgstr "<literal>hibernate.properties</literal> 내에서"
 
 #. Tag: entry
-#: toolset_guide.xml:417
 #, no-c-format
 msgid "dialect"
 msgstr "dialect"
 
 #. Tag: title
-#: toolset_guide.xml:426
 #, no-c-format
 msgid "Using Ant"
 msgstr "Ant 사용하기"
 
 #. Tag: para
-#: toolset_guide.xml:428
 #, no-c-format
 msgid ""
 "You can call <literal>SchemaExport</literal> from your Ant build script:"
@@ -953,37 +706,12 @@
 "당신은 당신의 Ant 빌드 스크립트에서 <literal>SchemaExport</literal>를 호출할 "
 "수 있다:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:432
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemaexport\">\n"
-"    <taskdef name=\"schemaexport\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaExportTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemaexport\n"
-"        properties=\"hibernate.properties\"\n"
-"        quiet=\"no\"\n"
-"        text=\"no\"\n"
-"        drop=\"no\"\n"
-"        delimiter=\";\"\n"
-"        output=\"schema-export.sql\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemaexport>\n"
-"</target>]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:437
 #, no-c-format
 msgid "Incremental schema updates"
 msgstr "점증하는 스키마 업데이트들"
 
 #. Tag: para
-#: toolset_guide.xml:439
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>SchemaUpdate</literal> tool will update an existing schema with "
@@ -996,7 +724,6 @@
 "라."
 
 #. Tag: para
-#: toolset_guide.xml:445
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
@@ -1005,79 +732,44 @@
 msgstr ""
 
 #. Tag: title
-#: toolset_guide.xml:451
 #, no-c-format
 msgid "<literal>SchemaUpdate</literal> Command Line Options"
 msgstr "<literal>SchemaUpdate</literal> 명령 라인 옵션들"
 
 #. Tag: entry
-#: toolset_guide.xml:468
 #, fuzzy, no-c-format
 msgid "do not export the script to the database"
 msgstr "스크립트를 데이터베이스로 내보내기 하지 않는다"
 
 #. Tag: entry
-#: toolset_guide.xml:480 toolset_guide.xml:542
 #, fuzzy, no-c-format
 msgid "specify a <literal>.cfg.xml</literal> file"
 msgstr "<placeholder-1/> 파일을 지정한다"
 
 #. Tag: para
-#: toolset_guide.xml:486
 #, fuzzy, no-c-format
 msgid "You can embed <literal>SchemaUpdate</literal> in your application:"
 msgstr ""
 "당신은 당신의 어플리케이션 내에 <literal>SchemaUpdate</literal>를 삽입시킬 "
 "수 있다:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:490
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaUpdate(cfg).execute(false);]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:495
 #, no-c-format
 msgid "Using Ant for incremental schema updates"
 msgstr "점증하는 스키마 업데이트들에 Ant 사용하기"
 
 #. Tag: para
-#: toolset_guide.xml:497
 #, no-c-format
 msgid "You can call <literal>SchemaUpdate</literal> from the Ant script:"
 msgstr ""
 "당신은 Ant 스크립트에서<literal>SchemaUpdate</literal>를 호출할 수 있다:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:501
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemaupdate\">\n"
-"    <taskdef name=\"schemaupdate\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaUpdateTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemaupdate\n"
-"        properties=\"hibernate.properties\"\n"
-"        quiet=\"no\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemaupdate>\n"
-"</target>]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:506
 #, no-c-format
 msgid "Schema validation"
 msgstr "스키마 유효성 검사"
 
 #. Tag: para
-#: toolset_guide.xml:508
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>SchemaValidator</literal> tool will validate that the existing "
@@ -1093,7 +785,6 @@
 "극히 유용하다."
 
 #. Tag: para
-#: toolset_guide.xml:514
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
@@ -1102,7 +793,6 @@
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:518
 #, fuzzy, no-c-format
 msgid ""
 "The following table displays the <literal>SchemaValidator</literal> command "
@@ -1110,58 +800,103 @@
 msgstr "<literal>SchemaValidator</literal> 명령 라인 옵션들"
 
 #. Tag: title
-#: toolset_guide.xml:521
 #, no-c-format
 msgid "<literal>SchemaValidator</literal> Command Line Options"
 msgstr "<literal>SchemaValidator</literal> 명령 라인 옵션들"
 
 #. Tag: para
-#: toolset_guide.xml:548
 #, fuzzy, no-c-format
 msgid "You can embed <literal>SchemaValidator</literal> in your application:"
 msgstr ""
 "당신은 당신의 어플리케이션 내에 <literal>SchemaValidator</literal>을 삽입시"
 "킬 수 도 있다:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:552
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaValidator(cfg).validate();]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:557
 #, no-c-format
 msgid "Using Ant for schema validation"
 msgstr "스키마 유효성 검사를 위해 Ant 사용하기"
 
 #. Tag: para
-#: toolset_guide.xml:559
 #, no-c-format
 msgid "You can call <literal>SchemaValidator</literal> from the Ant script:"
 msgstr ""
 "당신은 Ant 스크립트에서 <literal>SchemaValidator</literal>를 호출할 수 있다:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:563
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemavalidate\">\n"
-"    <taskdef name=\"schemavalidator\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaValidatorTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemavalidator\n"
-"        properties=\"hibernate.properties\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemavalidator>\n"
-"</target>]]>"
-msgstr ""
+#~ msgid "length"
+#~ msgstr "length"
 
+#~ msgid "precision"
+#~ msgstr "precision"
+
+#~ msgid "scale"
+#~ msgstr "scale"
+
+#~ msgid "not-null"
+#~ msgstr "not-null"
+
+#~ msgid "true|false"
+#~ msgstr "true|false"
+
+#~ msgid "unique"
+#~ msgstr "unique"
+
+#~ msgid "index"
+#~ msgstr "index"
+
+#~ msgid "index_name"
+#~ msgstr "index_name"
+
+#~ msgid "unique-key"
+#~ msgstr "unique-key"
+
+#~ msgid "unique_key_name"
+#~ msgstr "unique_key_name"
+
+#~ msgid "foreign-key"
+#~ msgstr "foreign-key"
+
+#~ msgid "sql-type"
+#~ msgstr "sql-type"
+
+#~ msgid "default"
+#~ msgstr "default"
+
+#~ msgid "check"
+#~ msgstr "check"
+
+#~ msgid "--quiet"
+#~ msgstr "--quiet"
+
+#~ msgid "--drop"
+#~ msgstr "--drop"
+
+#~ msgid "--create"
+#~ msgstr "--create"
+
+#~ msgid "--text"
+#~ msgstr "--text"
+
+#~ msgid "--properties=hibernate.properties"
+#~ msgstr "--properties=hibernate.properties"
+
+#~ msgid "--format"
+#~ msgstr "--format"
+
+#~ msgid "--delimiter=;"
+#~ msgstr "--delimiter=;"
+
+#~ msgid "hibernate.connection.url"
+#~ msgstr "hibernate.connection.url"
+
+#~ msgid "hibernate.connection.username"
+#~ msgstr "hibernate.connection.username"
+
+#~ msgid "hibernate.connection.password"
+#~ msgstr "hibernate.connection.password"
+
+#~ msgid "hibernate.dialect"
+#~ msgstr "hibernate.dialect"
+
 #~ msgid "Ant Tasks:"
 #~ msgstr "Ant 태스크들:"
 

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/transactions.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/transactions.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/transactions.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,13 +11,11 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: transactions.xml:29
 #, fuzzy, no-c-format
 msgid "Transactions and Concurrency"
 msgstr "트랜잭션들과 동시성"
 
 #. Tag: para
-#: transactions.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "The most important point about Hibernate and concurrency control is that it "
@@ -32,7 +30,6 @@
 "랜잭션 격리 명세에 약간의 시간을 할애할 것을 매우 권장한다."
 
 #. Tag: para
-#: transactions.xml:38
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate does not lock objects in memory. Your application can expect the "
@@ -48,7 +45,6 @@
 "읽기를 제공한다."
 
 #. Tag: para
-#: transactions.xml:46
 #, fuzzy, no-c-format
 msgid ""
 "In addition to versioning for automatic optimistic concurrency control, "
@@ -62,7 +58,6 @@
 "이 장의 뒷부분에서 논의된다."
 
 #. Tag: para
-#: transactions.xml:53
 #, fuzzy, no-c-format
 msgid ""
 "The discussion of concurrency control in Hibernate begins with the "
@@ -76,13 +71,11 @@
 "시작한다."
 
 #. Tag: title
-#: transactions.xml:60
 #, no-c-format
 msgid "Session and transaction scopes"
 msgstr "세션 영역과 트랜잭션 영역"
 
 #. Tag: para
-#: transactions.xml:62
 #, fuzzy, no-c-format
 msgid ""
 "A <literal>SessionFactory</literal> is an expensive-to-create, threadsafe "
@@ -96,7 +89,6 @@
 "생성된다."
 
 #. Tag: para
-#: transactions.xml:68
 #, fuzzy, no-c-format
 msgid ""
 "A <literal>Session</literal> is an inexpensive, non-threadsafe object that "
@@ -112,7 +104,6 @@
 "지 않을 것이므로, 사용될 때까지 리소스들을 소비하지 않는다."
 
 #. Tag: para
-#: transactions.xml:76
 #, fuzzy, no-c-format
 msgid ""
 "In order to reduce lock contention in the database, a database transaction "
@@ -129,7 +120,6 @@
 "는 것은 대개 결코 좋은 설계는 아니다."
 
 #. Tag: para
-#: transactions.xml:84
 #, fuzzy, no-c-format
 msgid ""
 "What is the scope of a unit of work? Can a single Hibernate "
@@ -144,13 +134,11 @@
 "그리고 당신은 데이터베이스 트랜잭션 경계들을 어떻게 한정하는가?"
 
 #. Tag: title
-#: transactions.xml:92
 #, no-c-format
 msgid "Unit of work"
 msgstr "작업 단위"
 
 #. Tag: para
-#: transactions.xml:94
 #, no-c-format
 msgid ""
 "First, let's define a unit of work. A unit of work is a design pattern "
@@ -160,13 +148,12 @@
 "citation> In other words, its a series of operations we wish to carry out "
 "against the database together. Basically, it is a transaction, though "
 "fulfilling a unit of work will often span multiple physical database "
-"transactions (see <xref linkend=\"transactions-basics-apptx\"/>). So really "
+"transactions (see <xref linkend=\"transactions-basics-apptx\" />). So really "
 "we are talking about a more abstract notion of a transaction. The term "
 "\"business transaction\" is also sometimes used in lieu of unit of work."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:111
 #, fuzzy, no-c-format
 msgid ""
 "Do not use the <emphasis>session-per-operation</emphasis> antipattern: do "
@@ -200,7 +187,6 @@
 "씬 더 유지가능하고 확장적이다."
 
 #. Tag: para
-#: transactions.xml:126
 #, fuzzy, no-c-format
 msgid ""
 "The most common pattern in a multi-user client/server application is "
@@ -226,7 +212,6 @@
 "적합하다."
 
 #. Tag: para
-#: transactions.xml:138
 #, fuzzy, no-c-format
 msgid ""
 "The challenge lies in the implementation. Hibernate provides built-in "
@@ -254,14 +239,13 @@
 "literal>을 선호하라."
 
 #. Tag: para
-#: transactions.xml:150
 #, fuzzy, no-c-format
 msgid ""
 "Your application code can access a \"current session\" to process the "
 "request by calling <literal>sessionFactory.getCurrentSession()</literal>. "
 "You will always get a <literal>Session</literal> scoped to the current "
 "database transaction. This has to be configured for either resource-local or "
-"JTA environments, see <xref linkend=\"architecture-current-session\"/>."
+"JTA environments, see <xref linkend=\"architecture-current-session\" />."
 msgstr ""
 "당신의 어플리케이션 코드는 어디서든 필요할 때 종종 <literal>sessionFactory."
 "getCurrentSession()</literal>을 간단히 호출함으로써 요청을 처리할 \"현재 세션"
@@ -271,7 +255,6 @@
 "session\"/>을 보라."
 
 #. Tag: para
-#: transactions.xml:158
 #, fuzzy, no-c-format
 msgid ""
 "You can extend the scope of a <literal>Session</literal> and database "
@@ -295,13 +278,11 @@
 "emphasis> 패턴을 둘러싼 팁들과 예제들은 Hibernate 웹 사이트와 포럼을 보라."
 
 #. Tag: title
-#: transactions.xml:173
 #, no-c-format
 msgid "Long conversations"
 msgstr "장기간의 대화"
 
 #. Tag: para
-#: transactions.xml:175
 #, fuzzy, no-c-format
 msgid ""
 "The session-per-request pattern is not the only way of designing units of "
@@ -317,7 +298,6 @@
 "용되지 않는다. 다음 예제를 검토하자:"
 
 #. Tag: para
-#: transactions.xml:185
 #, fuzzy, no-c-format
 msgid ""
 "The first screen of a dialog opens. The data seen by the user has been "
@@ -329,7 +309,6 @@
 "객체들을 변경시키는 것이 자유롭다."
 
 #. Tag: para
-#: transactions.xml:192
 #, fuzzy, no-c-format
 msgid ""
 "The user clicks \"Save\" after 5 minutes and expects their modifications to "
@@ -341,7 +320,6 @@
 "를 기대한다."
 
 #. Tag: para
-#: transactions.xml:200
 #, fuzzy, no-c-format
 msgid ""
 "From the point of view of the user, we call this unit of work a long-running "
@@ -354,7 +332,6 @@
 "재한다."
 
 #. Tag: para
-#: transactions.xml:206
 #, fuzzy, no-c-format
 msgid ""
 "A first naive implementation might keep the <literal>Session</literal> and "
@@ -370,7 +347,6 @@
 "용 숫자를 높이는 것을 허용하지 않을 것이기 때문이다."
 
 #. Tag: para
-#: transactions.xml:214
 #, fuzzy, no-c-format
 msgid ""
 "You have to use several database transactions to implement the conversation. "
@@ -393,7 +369,6 @@
 "쉽다:"
 
 #. Tag: para
-#: transactions.xml:227
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Automatic Versioning</emphasis>: Hibernate can perform automatic "
@@ -407,7 +382,6 @@
 "의 끝에서 체크한다."
 
 #. Tag: para
-#: transactions.xml:235
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Detached Objects</emphasis>: if you decide to use the "
@@ -426,7 +400,6 @@
 "변경들을 격리시키는데 사용된다."
 
 #. Tag: para
-#: transactions.xml:245
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Extended (or Long) Session</emphasis>: the Hibernate "
@@ -447,7 +420,6 @@
 "flush되는 것이 허용되지 않지만 명시적으로 flush되는 것은 허용된다."
 
 #. Tag: para
-#: transactions.xml:258
 #, fuzzy, no-c-format
 msgid ""
 "Both <emphasis>session-per-request-with-detached-objects</emphasis> and "
@@ -461,13 +433,11 @@
 "한다."
 
 #. Tag: title
-#: transactions.xml:267
 #, no-c-format
 msgid "Considering object identity"
 msgstr "객체 identity 고려하기"
 
 #. Tag: para
-#: transactions.xml:269
 #, fuzzy, no-c-format
 msgid ""
 "An application can concurrently access the same persistent state in two "
@@ -481,31 +451,26 @@
 "identity에 대한 두 개의 다른 개념들이 존재한다:"
 
 #. Tag: term
-#: transactions.xml:278
 #, no-c-format
 msgid "Database Identity"
 msgstr "데이터베이스 Identity"
 
-#. Tag: literal
-#: transactions.xml:281
-#, no-c-format
-msgid "foo.getId().equals( bar.getId() )"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>foo.getId().equals( bar.getId() )</literal>"
 msgstr "foo.getId().equals( bar.getId() )"
 
 #. Tag: term
-#: transactions.xml:286
 #, no-c-format
 msgid "JVM Identity"
 msgstr "JVM Identity"
 
-#. Tag: literal
-#: transactions.xml:289
+#. Tag: para
 #, no-c-format
-msgid "foo==bar"
-msgstr "foo==bar"
+msgid "<literal>foo==bar</literal>"
+msgstr ""
 
 #. Tag: para
-#: transactions.xml:295
 #, fuzzy, no-c-format
 msgid ""
 "For objects attached to a <emphasis>particular</emphasis> <literal>Session</"
@@ -526,7 +491,6 @@
 "여, optimistic 접근법을 사용하여 해결된다."
 
 #. Tag: para
-#: transactions.xml:304
 #, fuzzy, no-c-format
 msgid ""
 "This approach leaves Hibernate and the database to worry about concurrency. "
@@ -546,7 +510,6 @@
 "<literal>==</literal>를 안전하게 사용할 수가 있다."
 
 #. Tag: para
-#: transactions.xml:313
 #, fuzzy, no-c-format
 msgid ""
 "However, an application that uses <literal>==</literal> outside of a "
@@ -591,13 +554,11 @@
 "가 구현되어야 하는 방법임을 노트하라."
 
 #. Tag: title
-#: transactions.xml:334
 #, no-c-format
 msgid "Common issues"
 msgstr "공통된 쟁점들"
 
 #. Tag: para
-#: transactions.xml:336
 #, fuzzy, no-c-format
 msgid ""
 "Do not use the anti-patterns <emphasis>session-per-user-session</emphasis> "
@@ -613,7 +574,6 @@
 "들을 확실히 이해하라:"
 
 #. Tag: para
-#: transactions.xml:345
 #, fuzzy, no-c-format
 msgid ""
 "A <literal>Session</literal> is not thread-safe. Things that work "
@@ -635,7 +595,6 @@
 "에서 동일한 <literal>Session</literal>을 사용할 수도 있다."
 
 #. Tag: para
-#: transactions.xml:356
 #, fuzzy, no-c-format
 msgid ""
 "An exception thrown by Hibernate means you have to rollback your database "
@@ -658,7 +617,6 @@
 "이 아니고 당신이 어떻게든 롤백 후에 시작해야 하기 때문이다."
 
 #. Tag: para
-#: transactions.xml:368
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>Session</literal> caches every object that is in a persistent "
@@ -667,7 +625,7 @@
 "until you get an OutOfMemoryException. One solution is to call <literal>clear"
 "()</literal> and <literal>evict()</literal> to manage the <literal>Session</"
 "literal> cache, but you should consider a Stored Procedure if you need mass "
-"data operations. Some solutions are shown in <xref linkend=\"batch\"/>. "
+"data operations. Some solutions are shown in <xref linkend=\"batch\" />. "
 "Keeping a <literal>Session</literal> open for the duration of a user session "
 "also means a higher probability of stale data."
 msgstr ""
@@ -684,13 +642,11 @@
 "데이터에 대한 높은 확률을 의미한다."
 
 #. Tag: title
-#: transactions.xml:386
 #, no-c-format
 msgid "Database transaction demarcation"
 msgstr "데이터베이스 트랜잭션 경계 설정"
 
 #. Tag: para
-#: transactions.xml:388
 #, fuzzy, no-c-format
 msgid ""
 "Database, or system, transaction boundaries are always necessary. No "
@@ -712,7 +668,6 @@
 "작은 트랜잭션들의 경우보다는 더 좋게 수행될 것이다."
 
 #. Tag: para
-#: transactions.xml:398
 #, fuzzy, no-c-format
 msgid ""
 "A Hibernate application can run in non-managed (i.e., standalone, simple "
@@ -736,7 +691,6 @@
 "더 이상 필요하지 않다."
 
 #. Tag: para
-#: transactions.xml:408
 #, fuzzy, no-c-format
 msgid ""
 "However, it is often desirable to keep your persistence layer portable "
@@ -756,7 +710,6 @@
 "한 그것의 사용을 강력하게 권장한다."
 
 #. Tag: para
-#: transactions.xml:417
 #, fuzzy, no-c-format
 msgid ""
 "Ending a <literal>Session</literal> usually involves four distinct phases:"
@@ -764,31 +717,26 @@
 "대개 <literal>Session</literal> 종료는 네 개의 구분되는 단계들을 수반한다:"
 
 #. Tag: para
-#: transactions.xml:423
 #, no-c-format
 msgid "flush the session"
 msgstr "세션을 flush 시킨다"
 
 #. Tag: para
-#: transactions.xml:428
 #, no-c-format
 msgid "commit the transaction"
 msgstr "트랜잭션을 커밋 시킨다"
 
 #. Tag: para
-#: transactions.xml:433
 #, no-c-format
 msgid "close the session"
 msgstr "세션을 닫는다"
 
 #. Tag: para
-#: transactions.xml:438
 #, no-c-format
 msgid "handle exceptions"
 msgstr "예외상황들을 처리한다"
 
 #. Tag: para
-#: transactions.xml:444
 #, fuzzy, no-c-format
 msgid ""
 "We discussed Flushing the session earlier, so we will now have a closer look "
@@ -800,13 +748,11 @@
 "다."
 
 #. Tag: title
-#: transactions.xml:451
 #, no-c-format
 msgid "Non-managed environment"
 msgstr "관리되지 않는 환경"
 
 #. Tag: para
-#: transactions.xml:453
 #, fuzzy, no-c-format
 msgid ""
 "If a Hibernate persistence layer runs in a non-managed environment, database "
@@ -819,32 +765,7 @@
 "한 (예를 들면 DataSource가 아닌) 커넥션 풀(pool)들로부터 처리된다. session/"
 "transaction 처리 관용구는 다음과 같다:"
 
-#. Tag: programlisting
-#: transactions.xml:460
-#, no-c-format
-msgid ""
-"<![CDATA[// Non-managed environment idiom\n"
-"Session sess = factory.openSession();\n"
-"Transaction tx = null;\n"
-"try {\n"
-"    tx = sess.beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    if (tx != null) tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:462
 #, fuzzy, no-c-format
 msgid ""
 "You do not have to <literal>flush()</literal> the <literal>Session</literal> "
@@ -864,7 +785,6 @@
 "에서 이식성이 있고 실행된다."
 
 #. Tag: para
-#: transactions.xml:471
 #, fuzzy, no-c-format
 msgid ""
 "As outlined earlier, a much more flexible solution is Hibernate's built-in "
@@ -873,27 +793,7 @@
 "보다 더 유연한 해결책은 앞서 설명했듯이 Hibernate의 미리 빌드되어 있는 \"현"
 "재 세션\" 컨텍스트 관리이다:"
 
-#. Tag: programlisting
-#: transactions.xml:476
-#, no-c-format
-msgid ""
-"<![CDATA[// Non-managed environment idiom with getCurrentSession()\n"
-"try {\n"
-"    factory.getCurrentSession().beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    factory.getCurrentSession().getTransaction().commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    factory.getCurrentSession().getTransaction().rollback();\n"
-"    throw e; // or display error message\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:478
 #, fuzzy, no-c-format
 msgid ""
 "You will not see these code snippets in a regular application; fatal "
@@ -915,7 +815,6 @@
 "부분에서 논의된다."
 
 #. Tag: para
-#: transactions.xml:488
 #, fuzzy, no-c-format
 msgid ""
 "You should select <literal>org.hibernate.transaction.JDBCTransactionFactory</"
@@ -928,13 +827,11 @@
 "current_session_context_class</literal>를 선택해야 함을 노트하라."
 
 #. Tag: title
-#: transactions.xml:497
 #, no-c-format
 msgid "Using JTA"
 msgstr "JTA 사용하기"
 
 #. Tag: para
-#: transactions.xml:499
 #, fuzzy, no-c-format
 msgid ""
 "If your persistence layer runs in an application server (for example, behind "
@@ -950,7 +847,6 @@
 "방도들을 제공한다."
 
 #. Tag: para
-#: transactions.xml:506
 #, fuzzy, no-c-format
 msgid ""
 "If you use bean-managed transactions (BMT), Hibernate will tell the "
@@ -963,32 +859,7 @@
 "료하도록 어플리케이션 서버에게 알려줄 것이다. 따라서 트랜잭션 관리 코드는 "
 "non-managed 환경과 동일하다."
 
-#. Tag: programlisting
-#: transactions.xml:512
-#, no-c-format
-msgid ""
-"<![CDATA[// BMT idiom\n"
-"Session sess = factory.openSession();\n"
-"Transaction tx = null;\n"
-"try {\n"
-"    tx = sess.beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    if (tx != null) tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:514
 #, fuzzy, no-c-format
 msgid ""
 "If you want to use a transaction-bound <literal>Session</literal>, that is, "
@@ -999,31 +870,7 @@
 "을 위한 <literal>getCurrentSession()</literal> 기능을 사용하고자 원할 경우, "
 "당신은 JTA <literal>UserTransaction</literal> API를 직접 사용해야 할 것이다:"
 
-#. Tag: programlisting
-#: transactions.xml:520
-#, no-c-format
-msgid ""
-"<![CDATA[// BMT idiom with getCurrentSession()\n"
-"try {\n"
-"    UserTransaction tx = (UserTransaction)new InitialContext()\n"
-"                            .lookup(\"java:comp/UserTransaction\");\n"
-"\n"
-"    tx.begin();\n"
-"\n"
-"    // Do some work on Session bound to transaction\n"
-"    factory.getCurrentSession().load(...);\n"
-"    factory.getCurrentSession().persist(...);\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:522
 #, fuzzy, no-c-format
 msgid ""
 "With CMT, transaction demarcation is completed in session bean deployment "
@@ -1032,20 +879,7 @@
 "CMT의 경우, 트랜잭션 관할[경계 설정]은 프로그램 상이 아닌, session bean 배치 "
 "디스크립터들 속에서 행해진다. 그러므로 코드는 다음으로 감소된다:"
 
-#. Tag: programlisting
-#: transactions.xml:527
-#, no-c-format
-msgid ""
-"<![CDATA[// CMT idiom\n"
-" Session sess = factory.getCurrentSession();\n"
-"\n"
-" // do some work\n"
-" ...\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:529
 #, fuzzy, no-c-format
 msgid ""
 "In a CMT/EJB, even rollback happens automatically. An unhandled "
@@ -1064,7 +898,6 @@
 "emphasis>"
 
 #. Tag: para
-#: transactions.xml:537
 #, fuzzy, no-c-format
 msgid ""
 "When configuring Hibernate's transaction factory, choose <literal>org."
@@ -1085,7 +918,6 @@
 "또는 <literal>\"jta\"</literal>로 설정되도록 하라."
 
 #. Tag: para
-#: transactions.xml:546
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>getCurrentSession()</literal> operation has one downside in a "
@@ -1115,13 +947,11 @@
 "쉽게 피할 수 있다.)"
 
 #. Tag: title
-#: transactions.xml:562
 #, no-c-format
 msgid "Exception handling"
 msgstr "예외상황 처리"
 
 #. Tag: para
-#: transactions.xml:564
 #, fuzzy, no-c-format
 msgid ""
 "If the <literal>Session</literal> throws an exception, including any "
@@ -1143,7 +973,6 @@
 "를 호출하여 닫혀지도록 확실히 하라."
 
 #. Tag: para
-#: transactions.xml:575
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>HibernateException</literal>, which wraps most of the errors "
@@ -1169,7 +998,6 @@
 "가능하지 않고 적절한 액션이 취해져야 한다."
 
 #. Tag: para
-#: transactions.xml:587
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate wraps <literal>SQLException</literal>s thrown while interacting "
@@ -1201,7 +1029,6 @@
 "를 보라). 표준 <literal>JDBCException</literal> 서브타입은 다음과 같다:"
 
 #. Tag: para
-#: transactions.xml:603
 #, fuzzy, no-c-format
 msgid ""
 "<literal>JDBCConnectionException</literal>: indicates an error with the "
@@ -1211,7 +1038,6 @@
 "타낸다."
 
 #. Tag: para
-#: transactions.xml:609
 #, fuzzy, no-c-format
 msgid ""
 "<literal>SQLGrammarException</literal>: indicates a grammar or syntax "
@@ -1221,7 +1047,6 @@
 "제점을 나타낸다."
 
 #. Tag: para
-#: transactions.xml:615
 #, fuzzy, no-c-format
 msgid ""
 "<literal>ConstraintViolationException</literal>: indicates some form of "
@@ -1231,7 +1056,6 @@
 "떤 형식을 나타낸다."
 
 #. Tag: para
-#: transactions.xml:621
 #, fuzzy, no-c-format
 msgid ""
 "<literal>LockAcquisitionException</literal>: indicates an error acquiring a "
@@ -1241,7 +1065,6 @@
 "필수적인 잠금 레벨을 획득하는 오류를 나타낸다."
 
 #. Tag: para
-#: transactions.xml:627
 #, fuzzy, no-c-format
 msgid ""
 "<literal>GenericJDBCException</literal>: a generic exception which did not "
@@ -1251,13 +1074,11 @@
 "되지 않았던 일반적인 예외상황."
 
 #. Tag: title
-#: transactions.xml:637
 #, no-c-format
 msgid "Transaction timeout"
 msgstr "트랜잭션 타임아웃"
 
 #. Tag: para
-#: transactions.xml:639
 #, fuzzy, no-c-format
 msgid ""
 "An important feature provided by a managed environment like EJB, that is "
@@ -1282,33 +1103,7 @@
 "다. 이 기능은 Hibernate <literal>Transaction</literal> 객체에 의해 추상화 된"
 "다."
 
-#. Tag: programlisting
-#: transactions.xml:652
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"Session sess = factory.openSession();\n"
-"try {\n"
-"    //set transaction timeout to 3 seconds\n"
-"    sess.getTransaction().setTimeout(3);\n"
-"    sess.getTransaction().begin();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    sess.getTransaction().commit()\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    sess.getTransaction().rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:654
 #, fuzzy, no-c-format
 msgid ""
 "<literal>setTimeout()</literal> cannot be called in a CMT bean, where "
@@ -1318,13 +1113,11 @@
 "라. 여기서 트랜잭션 타임아웃들은 선언적으로 정의되어야 한다."
 
 #. Tag: title
-#: transactions.xml:664
 #, no-c-format
 msgid "Optimistic concurrency control"
 msgstr "Optimistic 동시성 제어"
 
 #. Tag: para
-#: transactions.xml:666
 #, fuzzy, no-c-format
 msgid ""
 "The only approach that is consistent with high concurrency and high "
@@ -1344,13 +1137,11 @@
 "지하는 이점을 갖고 있다."
 
 #. Tag: title
-#: transactions.xml:677
 #, no-c-format
 msgid "Application version checking"
 msgstr "어플리케이션 버전 체킹"
 
 #. Tag: para
-#: transactions.xml:679
 #, fuzzy, no-c-format
 msgid ""
 "In an implementation without much help from Hibernate, each interaction with "
@@ -1367,26 +1158,7 @@
 "드시킬 책임이 있다. 이 접근법은 대화 트랜잭션을 확실히 격리시키기 위해 그것 "
 "자신의 버전 체킹을 수행하도록 어플리케이션에게 강제시킨다."
 
-#. Tag: programlisting
-#: transactions.xml:688
-#, no-c-format
-msgid ""
-"<![CDATA[// foo is an instance loaded by a previous Session\n"
-"session = factory.openSession();\n"
-"Transaction t = session.beginTransaction();\n"
-"\n"
-"int oldVersion = foo.getVersion();\n"
-"session.load( foo, foo.getKey() ); // load the current state\n"
-"if ( oldVersion != foo.getVersion() ) throw new StaleObjectStateException"
-"();\n"
-"foo.setProperty(\"bar\");\n"
-"\n"
-"t.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:690
 #, no-c-format
 msgid ""
 "The <literal>version</literal> property is mapped using <literal>&lt;"
@@ -1398,7 +1170,6 @@
 "킬 것이다."
 
 #. Tag: para
-#: transactions.xml:696
 #, fuzzy, no-c-format
 msgid ""
 "If you are operating in a low-data-concurrency environment, and do not "
@@ -1416,7 +1187,6 @@
 "들을 병합시킬 기회 없이 업데이트들 손실을 겪을 수도 있기 때문이다."
 
 #. Tag: para
-#: transactions.xml:705
 #, fuzzy, no-c-format
 msgid ""
 "Manual version checking is only feasible in trivial circumstances and not "
@@ -1432,13 +1202,11 @@
 "전 체킹을 제공한다."
 
 #. Tag: title
-#: transactions.xml:716
 #, no-c-format
 msgid "Extended session and automatic versioning"
 msgstr "확장된 세션과 자동적인 버전화"
 
 #. Tag: para
-#: transactions.xml:718
 #, fuzzy, no-c-format
 msgid ""
 "A single <literal>Session</literal> instance and its persistent instances "
@@ -1462,7 +1230,6 @@
 "되지 않은 데이터를 가지고 비지니스 대화를 재시작하는 기회이다)."
 
 #. Tag: para
-#: transactions.xml:727
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>Session</literal> is disconnected from any underlying JDBC "
@@ -1477,23 +1244,7 @@
 "에 그 자체 관계할 필요가 없거나 그것은 모든 데이터베이스 트랜잭션에서 인스턴"
 "스들을 다시 로드시킬 필요가 없다."
 
-#. Tag: programlisting
-#: transactions.xml:735
-#, no-c-format
-msgid ""
-"<![CDATA[// foo is an instance loaded earlier by the old session\n"
-"Transaction t = session.beginTransaction(); // Obtain a new JDBC connection, "
-"start transaction\n"
-"\n"
-"foo.setProperty(\"bar\");\n"
-"\n"
-"session.flush();    // Only for last transaction in conversation\n"
-"t.commit();         // Also return JDBC connection\n"
-"session.close();    // Only for last transaction in conversation]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:736
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>foo</literal> object knows which <literal>Session</literal> it "
@@ -1528,7 +1279,6 @@
 "<literal>close()</literal>할 것이다."
 
 #. Tag: para
-#: transactions.xml:751
 #, fuzzy, no-c-format
 msgid ""
 "This pattern is problematic if the <literal>Session</literal> is too big to "
@@ -1548,13 +1298,11 @@
 "은 또한 곧 실없는 데이터가 될 것이기 때문이다."
 
 #. Tag: title
-#: transactions.xml:762
 #, no-c-format
 msgid "Note"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:763
 #, fuzzy, no-c-format
 msgid ""
 "Earlier versions of Hibernate required explicit disconnection and "
@@ -1566,7 +1314,6 @@
 "효과를 가지므로, 이들 방법들은 진부하게 되었다.)"
 
 #. Tag: para
-#: transactions.xml:769
 #, fuzzy, no-c-format
 msgid ""
 "Keep the disconnected <literal>Session</literal> close to the persistence "
@@ -1582,7 +1329,6 @@
 "에 전송하지 말라 (또는 그것을 별도의 티어에 직렬화 시키지도 말라)."
 
 #. Tag: para
-#: transactions.xml:777
 #, fuzzy, no-c-format
 msgid ""
 "The extended session pattern, or <emphasis>session-per-conversation</"
@@ -1597,13 +1343,11 @@
 "며, 예제들은 Hibernate Wiki를 보라."
 
 #. Tag: title
-#: transactions.xml:787
 #, no-c-format
 msgid "Detached objects and automatic versioning"
 msgstr "Detached 객체들과 자동적인 버전화"
 
 #. Tag: para
-#: transactions.xml:789
 #, no-c-format
 msgid ""
 "Each interaction with the persistent store occurs in a new <literal>Session</"
@@ -1621,22 +1365,7 @@
 "</literal>, <literal>Session.saveOrUpdate()</literal>, <literal>Session.merge"
 "()</literal>를 사용하여 그것들을 다시 첨부시킨다."
 
-#. Tag: programlisting
-#: transactions.xml:797
-#, no-c-format
-msgid ""
-"<![CDATA[// foo is an instance loaded by a previous Session\n"
-"foo.setProperty(\"bar\");\n"
-"session = factory.openSession();\n"
-"Transaction t = session.beginTransaction();\n"
-"session.saveOrUpdate(foo); // Use merge() if \"foo\" might have been loaded "
-"already\n"
-"t.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:799
 #, fuzzy, no-c-format
 msgid ""
 "Again, Hibernate will check instance versions during flush, throwing an "
@@ -1646,7 +1375,6 @@
 "이 발생할 경우에 예외상황을 던질 것이다."
 
 #. Tag: para
-#: transactions.xml:804
 #, fuzzy, no-c-format
 msgid ""
 "You can also call <literal>lock()</literal> instead of <literal>update()</"
@@ -1660,13 +1388,11 @@
 "용할 수 있다."
 
 #. Tag: title
-#: transactions.xml:813
 #, no-c-format
 msgid "Customizing automatic versioning"
 msgstr "자동적인 버전화를 맞춤화 시키기"
 
 #. Tag: para
-#: transactions.xml:815
 #, fuzzy, no-c-format
 msgid ""
 "You can disable Hibernate's automatic version increment for particular "
@@ -1680,7 +1406,6 @@
 "dirty 일 경우에 더 이상 버전을 증가시키지 않을 것이다."
 
 #. Tag: para
-#: transactions.xml:822
 #, fuzzy, no-c-format
 msgid ""
 "Legacy database schemas are often static and cannot be modified. Or, other "
@@ -1706,7 +1431,6 @@
 "으로만 동작함을 노트하라."
 
 #. Tag: para
-#: transactions.xml:834
 #, fuzzy, no-c-format
 msgid ""
 "Concurrent modification can be permitted in instances where the changes that "
@@ -1720,7 +1444,6 @@
 "비교만 할 것이다."
 
 #. Tag: para
-#: transactions.xml:840
 #, fuzzy, no-c-format
 msgid ""
 "In both cases, with dedicated version/timestamp columns or with a full/dirty "
@@ -1750,13 +1473,11 @@
 "징을 맞춤화 시킬 수 있다."
 
 #. Tag: title
-#: transactions.xml:858
 #, fuzzy, no-c-format
 msgid "Pessimistic locking"
 msgstr "Pessimistic 잠금"
 
 #. Tag: para
-#: transactions.xml:860
 #, fuzzy, no-c-format
 msgid ""
 "It is not intended that users spend much time worrying about locking "
@@ -1772,7 +1493,6 @@
 "작 시에 잠금들을 다시 얻고자 원할 수도 있다."
 
 #. Tag: para
-#: transactions.xml:867
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate will always use the locking mechanism of the database; it never "
@@ -1782,7 +1502,6 @@
 "을 항상 사용할 것이다!"
 
 #. Tag: para
-#: transactions.xml:872
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>LockMode</literal> class defines the different lock levels that "
@@ -1792,7 +1511,6 @@
 "금 레벨들을 정의한다. 잠금은 다음 메커니즘들에 의해 얻어진다:"
 
 #. Tag: para
-#: transactions.xml:879
 #, no-c-format
 msgid ""
 "<literal>LockMode.WRITE</literal> is acquired automatically when Hibernate "
@@ -1802,7 +1520,6 @@
 "insert 할 때 자동적으로 획득된다."
 
 #. Tag: para
-#: transactions.xml:885
 #, fuzzy, no-c-format
 msgid ""
 "<literal>LockMode.UPGRADE</literal> can be acquired upon explicit user "
@@ -1814,7 +1531,6 @@
 "literal>를 사용하여 명시적인 사용자 요청 상에서 얻어질 수 있다."
 
 #. Tag: para
-#: transactions.xml:891
 #, fuzzy, no-c-format
 msgid ""
 "<literal>LockMode.UPGRADE_NOWAIT</literal> can be acquired upon explicit "
@@ -1826,7 +1542,6 @@
 "도 있다."
 
 #. Tag: para
-#: transactions.xml:897
 #, fuzzy, no-c-format
 msgid ""
 "<literal>LockMode.READ</literal> is acquired automatically when Hibernate "
@@ -1838,7 +1553,6 @@
 "질 수도 있다. 명시적인 사용자 요청에 의해 다시 얻어질 수도 있다."
 
 #. Tag: para
-#: transactions.xml:904
 #, no-c-format
 msgid ""
 "<literal>LockMode.NONE</literal> represents the absence of a lock. All "
@@ -1853,14 +1567,12 @@
 "출을 통해 세션과 연관된 객체들이 또한 이 잠금 모드로 시작된다."
 
 #. Tag: para
-#: transactions.xml:913
 #, no-c-format
 msgid ""
 "The \"explicit user request\" is expressed in one of the following ways:"
 msgstr "\"명시적인 사용자 요청\"은 다음 방법들 중 하나로 표현된다:"
 
 #. Tag: para
-#: transactions.xml:919
 #, no-c-format
 msgid ""
 "A call to <literal>Session.load()</literal>, specifying a <literal>LockMode</"
@@ -1870,19 +1582,16 @@
 "한 호출."
 
 #. Tag: para
-#: transactions.xml:924
 #, no-c-format
 msgid "A call to <literal>Session.lock()</literal>."
 msgstr "<literal>Session.lock()</literal>에 대한 호출."
 
 #. Tag: para
-#: transactions.xml:929
 #, no-c-format
 msgid "A call to <literal>Query.setLockMode()</literal>."
 msgstr "<literal>Query.setLockMode()</literal>에 대한 호출."
 
 #. Tag: para
-#: transactions.xml:935
 #, no-c-format
 msgid ""
 "If <literal>Session.load()</literal> is called with <literal>UPGRADE</"
@@ -1901,7 +1610,6 @@
 "그 객체에 대해 <literal>lock()</literal>을 호출한다."
 
 #. Tag: para
-#: transactions.xml:944
 #, fuzzy, no-c-format
 msgid ""
 "<literal>Session.lock()</literal> performs a version number check if the "
@@ -1917,7 +1625,6 @@
 "literal>가 사용된다.)"
 
 #. Tag: para
-#: transactions.xml:951
 #, fuzzy, no-c-format
 msgid ""
 "If the requested lock mode is not supported by the database, Hibernate uses "
@@ -1929,13 +1636,11 @@
 "이 이식 가능할 것임을 확실히 해준다."
 
 #. Tag: title
-#: transactions.xml:960
 #, fuzzy, no-c-format
 msgid "Connection release modes"
 msgstr "연결 해제 모드들"
 
 #. Tag: para
-#: transactions.xml:962
 #, fuzzy, no-c-format
 msgid ""
 "One of the legacies of Hibernate 2.x JDBC connection management meant that a "
@@ -1959,7 +1664,6 @@
 "ConnectionReleaseMode</literal>의 열거된 값들에 의해 식별된다:"
 
 #. Tag: para
-#: transactions.xml:976
 #, fuzzy, no-c-format
 msgid ""
 "<literal>ON_CLOSE</literal>: is the legacy behavior described above. The "
@@ -1971,7 +1675,6 @@
 "넥션을 보관할 필요가 있을 때 하나의 커넥션을 획득한다."
 
 #. Tag: para
-#: transactions.xml:983
 #, fuzzy, no-c-format
 msgid ""
 "<literal>AFTER_TRANSACTION</literal>: releases connections after a "
@@ -1981,7 +1684,6 @@
 "Transaction</literal>이 완료된 후에 연결들을 해제하라고 말한다."
 
 #. Tag: para
-#: transactions.xml:989
 #, fuzzy, no-c-format
 msgid ""
 "<literal>AFTER_STATEMENT</literal> (also referred to as aggressive release): "
@@ -1997,7 +1699,6 @@
 "ScrollableResults</literal>의 사용을 통해서이다."
 
 #. Tag: para
-#: transactions.xml:999
 #, fuzzy, no-c-format
 msgid ""
 "The configuration parameter <literal>hibernate.connection.release_mode</"
@@ -2008,7 +1709,6 @@
 "release_mode</literal>가 사용된다. 가능한 값들은 다음과 같다:"
 
 #. Tag: para
-#: transactions.xml:1006
 #, fuzzy, no-c-format
 msgid ""
 "<literal>auto</literal> (the default): this choice delegates to the release "
@@ -2029,7 +1729,6 @@
 "다."
 
 #. Tag: para
-#: transactions.xml:1016
 #, fuzzy, no-c-format
 msgid ""
 "<literal>on_close</literal>: uses ConnectionReleaseMode.ON_CLOSE. This "
@@ -2040,7 +1739,6 @@
 "는다."
 
 #. Tag: para
-#: transactions.xml:1022
 #, fuzzy, no-c-format
 msgid ""
 "<literal>after_transaction</literal>: uses ConnectionReleaseMode."
@@ -2056,7 +1754,6 @@
 "AFTER_STATEMENT인 것처럼 해제될 것임을 또한 노트하라."
 
 #. Tag: para
-#: transactions.xml:1030
 #, fuzzy, no-c-format
 msgid ""
 "<literal>after_statement</literal>: uses ConnectionReleaseMode."
@@ -2077,3 +1774,6 @@
 "<literal>ConnectionProvider.getConnection()</literal>을 호출할 때마다 우리가 "
 "동일한 기본 JDBC 커넥션을 다시 필요로 할 수 있는 환경들에서 또는 우리가 동일"
 "한 커넥션을 얻는 것에 상관없는 auto-commit 환경에서 오직 안전하다."
+
+#~ msgid "foo==bar"
+#~ msgstr "foo==bar"

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/tutorial.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/tutorial.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/tutorial.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\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 at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,13 +11,11 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: tutorial.xml:31
 #, no-c-format
 msgid "Tutorial"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:33
 #, no-c-format
 msgid ""
 "Intended for new users, this chapter provides an step-by-step introduction "
@@ -28,7 +26,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:42
 #, no-c-format
 msgid ""
 "This tutorial expects the user have knowledge of both Java and SQL. If you "
@@ -37,7 +34,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:51
 #, no-c-format
 msgid ""
 "The distribution contains another example application under the "
@@ -45,13 +41,11 @@
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:59
 #, no-c-format
 msgid "Part 1 - The first Hibernate Application"
 msgstr "파트 1 - 첫 번째 Hibernate 어플리케이션"
 
 #. Tag: para
-#: tutorial.xml:61
 #, fuzzy, no-c-format
 msgid ""
 "For this example, we will set up a small database application that can store "
@@ -61,7 +55,6 @@
 "어플리케이션과 이들 이벤트들의 호스트들에 대한 정보를 필요로 한다고 가정하자."
 
 #. Tag: para
-#: tutorial.xml:67
 #, no-c-format
 msgid ""
 "Although you can use whatever database you feel comfortable using, we will "
@@ -71,13 +64,11 @@
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:76
 #, no-c-format
 msgid "Setup"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:78
 #, no-c-format
 msgid ""
 "The first thing we need to do is to set up the development environment. We "
@@ -91,7 +82,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:88
 #, no-c-format
 msgid ""
 "We will be using Maven in this tutorial, taking advantage of its transitive "
@@ -99,61 +89,7 @@
 "automatically set up a project for us based on the maven descriptor."
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:94
-#, no-c-format
-msgid ""
-"<![CDATA[<project xmlns=\"http://maven.apache.org/POM/4.0.0\"\n"
-"         xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
-"         xsi:schemaLocation=\"http://maven.apache.org/POM/4.0.0 http://maven."
-"apache.org/xsd/maven-4.0.0.xsd\">\n"
-"\n"
-"    <modelVersion>4.0.0</modelVersion>\n"
-"\n"
-"    <groupId>org.hibernate.tutorials</groupId>\n"
-"    <artifactId>hibernate-tutorial</artifactId>\n"
-"    <version>1.0.0-SNAPSHOT</version>\n"
-"    <name>First Hibernate Tutorial</name>\n"
-"\n"
-"    <build>\n"
-"         <!-- we dont want the version to be part of the generated war file "
-"name -->\n"
-"         <finalName>${artifactId}</finalName>\n"
-"    </build>\n"
-"\n"
-"    <dependencies>\n"
-"        <dependency>\n"
-"            <groupId>org.hibernate</groupId>\n"
-"            <artifactId>hibernate-core</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Because this is a web app, we also have a dependency on the "
-"servlet api. -->\n"
-"        <dependency>\n"
-"            <groupId>javax.servlet</groupId>\n"
-"            <artifactId>servlet-api</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Hibernate uses slf4j for logging, for our purposes here use the "
-"simple backend -->\n"
-"        <dependency>\n"
-"            <groupId>org.slf4j</groupId>\n"
-"            <artifactId>slf4j-simple</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Hibernate gives you a choice of bytecode providers between "
-"cglib and javassist -->\n"
-"        <dependency>\n"
-"            <groupId>javassist</groupId>\n"
-"            <artifactId>javassist</artifactId>\n"
-"        </dependency>\n"
-"    </dependencies>\n"
-"\n"
-"</project>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:97
 #, no-c-format
 msgid ""
 "It is not a requirement to use Maven. If you wish to use something else to "
@@ -172,20 +108,17 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:114
 #, no-c-format
 msgid ""
 "Save this file as <filename>pom.xml</filename> in the project root directory."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:121
 #, no-c-format
 msgid "The first class"
 msgstr "첫 번째 클래스"
 
 #. Tag: para
-#: tutorial.xml:123
 #, fuzzy, no-c-format
 msgid ""
 "Next, we create a class that represents the event we want to store in the "
@@ -194,50 +127,7 @@
 "다음으로 우리는 우리가 데이터베이스 속에 저장시키고자 원하는 이벤트를 표현하"
 "는 한 개의 클래스를 생성시킨다."
 
-#. Tag: programlisting
-#: tutorial.xml:128
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.domain;\n"
-"\n"
-"import java.util.Date;\n"
-"\n"
-"public class Event {\n"
-"    private Long id;\n"
-"\n"
-"    private String title;\n"
-"    private Date date;\n"
-"\n"
-"    public Event() {}\n"
-"\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"\n"
-"    private void setId(Long id) {\n"
-"        this.id = id;\n"
-"    }\n"
-"\n"
-"    public Date getDate() {\n"
-"        return date;\n"
-"    }\n"
-"\n"
-"    public void setDate(Date date) {\n"
-"        this.date = date;\n"
-"    }\n"
-"\n"
-"    public String getTitle() {\n"
-"        return title;\n"
-"    }\n"
-"\n"
-"    public void setTitle(String title) {\n"
-"        this.title = title;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:130
 #, fuzzy, no-c-format
 msgid ""
 "This class uses standard JavaBean naming conventions for property getter and "
@@ -254,7 +144,6 @@
 "다."
 
 #. Tag: para
-#: tutorial.xml:138
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>id</literal> property holds a unique identifier value for a "
@@ -282,7 +171,6 @@
 "있으며, 당신은 당신의 어플리케이션 설계에 적합하도록 그것을 부합시킬 수 있다."
 
 #. Tag: para
-#: tutorial.xml:153
 #, fuzzy, no-c-format
 msgid ""
 "The no-argument constructor is a requirement for all persistent classes; "
@@ -297,7 +185,6 @@
 "없는 효율적인 데이터 검색에 필요하다."
 
 #. Tag: para
-#: tutorial.xml:161
 #, no-c-format
 msgid ""
 "Save this file to the <filename>src/main/java/org/hibernate/tutorial/domain</"
@@ -305,13 +192,11 @@
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:168
 #, no-c-format
 msgid "The mapping file"
 msgstr "The mapping file"
 
 #. Tag: para
-#: tutorial.xml:170
 #, no-c-format
 msgid ""
 "Hibernate needs to know how to load and store objects of the persistent "
@@ -325,27 +210,11 @@
 "사용해야 하는 그 테이블 내의 컬럼들이 무엇인지를 Hibernate에게 알려준다."
 
 #. Tag: para
-#: tutorial.xml:178
 #, no-c-format
 msgid "The basic structure of a mapping file looks like this:"
 msgstr "매핑 파일의 기본 구조는 다음과 같다:"
 
-#. Tag: programlisting
-#: tutorial.xml:182
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"[...]\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:184
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate DTD is sophisticated. You can use it for auto-completion of XML "
@@ -367,7 +236,6 @@
 "Hibernate 배포본의 <literal>src/</literal> 디렉토리 속에 포함되어 있다."
 
 #. Tag: para
-#: tutorial.xml:197
 #, fuzzy, no-c-format
 msgid ""
 "We will omit the DTD declaration in future examples to shorten the code. It "
@@ -377,7 +245,6 @@
 "것은 물론 옵션이 아니다."
 
 #. Tag: para
-#: tutorial.xml:203
 #, fuzzy, no-c-format
 msgid ""
 "Between the two <literal>hibernate-mapping</literal> tags, include a "
@@ -390,21 +257,7 @@
 "수 있고, 그것은 첫번째-급의 엔티티들이 아니다)은 SQL 데이터베이스 내의 테이블"
 "에 대한 그런 매핑을 필요로 한다:"
 
-#. Tag: programlisting
-#: tutorial.xml:210
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:212
 #, fuzzy, no-c-format
 msgid ""
 "So far we have told Hibernate how to persist and load object of class "
@@ -421,23 +274,7 @@
 "리는 대용 키 프라이머리 키 컬럼에 대한 Hibernate의 식별자 생성 방도를 구성한"
 "다:"
 
-#. Tag: programlisting
-#: tutorial.xml:222
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"        <id name=\"id\" column=\"EVENT_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:224
 #, no-c-format
 msgid ""
 "The <literal>id</literal> element is the declaration of the identifier "
@@ -449,7 +286,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:234
 #, no-c-format
 msgid ""
 "The nested <literal>generator</literal> element specifies the identifier "
@@ -462,15 +298,14 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:246
 #, no-c-format
 msgid ""
 "<literal>native</literal> is no longer consider the best strategy in terms "
-"of portability. for further discussion, see"
+"of portability. for further discussion, see <xref linkend=\"portability-idgen"
+"\" />"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:252
 #, fuzzy, no-c-format
 msgid ""
 "Lastly, we need to tell Hibernate about the remaining entity class "
@@ -479,26 +314,7 @@
 "마지막으로 우리는 매핑 파일 속에서 클래스의 영속 프로퍼티들에 대한 선언들을 "
 "포함한다. 디폴트로, 클래스의 프로퍼티들은 영속적인 것으로 간주되지 않는다:"
 
-#. Tag: programlisting
-#: tutorial.xml:258
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"        <id name=\"id\" column=\"EVENT_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"date\" type=\"timestamp\" column=\"EVENT_DATE\"/>\n"
-"        <property name=\"title\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:260
 #, fuzzy, no-c-format
 msgid ""
 "Similar to the <literal>id</literal> element, the <literal>name</literal> "
@@ -514,7 +330,6 @@
 "게 될 것이다."
 
 #. Tag: para
-#: tutorial.xml:271
 #, fuzzy, no-c-format
 msgid ""
 "Why does the <literal>date</literal> property mapping include the "
@@ -532,7 +347,6 @@
 "는 그것을 다른 이름으로 더 좋게 매핑 시킨다."
 
 #. Tag: para
-#: tutorial.xml:281
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>title</literal> mapping also lacks a <literal>type</literal> "
@@ -567,7 +381,6 @@
 "고 선언한다."
 
 #. Tag: para
-#: tutorial.xml:297
 #, no-c-format
 msgid ""
 "Hibernate makes this mapping type determination using reflection when the "
@@ -577,7 +390,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:304
 #, no-c-format
 msgid ""
 "Save this mapping file as <filename>src/main/resources/org/hibernate/"
@@ -585,13 +397,11 @@
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:312
 #, no-c-format
 msgid "Hibernate configuration"
 msgstr "Hibernate 구성"
 
 #. Tag: para
-#: tutorial.xml:314
 #, no-c-format
 msgid ""
 "At this point, you should have the persistent class and its mapping file in "
@@ -600,13 +410,11 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:321
 #, no-c-format
 msgid "We do this do that the data remains between runs."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:326
 #, fuzzy, no-c-format
 msgid ""
 "We will utilize the Maven exec plugin to launch the HSQLDB server by "
@@ -628,7 +436,6 @@
 "에 있는 모든 파일들을 삭제하고 다시 HSQL DB를 시작하라."
 
 #. Tag: para
-#: tutorial.xml:337
 #, no-c-format
 msgid ""
 "Hibernate will be connecting to the database on behalf of your application, "
@@ -642,7 +449,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:348
 #, no-c-format
 msgid ""
 "The built-in Hibernate connection pool is in no way intended for production "
@@ -650,7 +456,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:354
 #, fuzzy, no-c-format
 msgid ""
 "For Hibernate's configuration, we can use a simple <literal>hibernate."
@@ -663,63 +468,12 @@
 "xml</literal> 파일, 또는 심지어 완전한 프로그램 상의 설정을 사용할 수 있다. "
 "대부분의 사용자들은 XMl 구성 파일을 선호한다:"
 
-#. Tag: programlisting
-#: tutorial.xml:360
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-"<!DOCTYPE hibernate-configuration PUBLIC\n"
-"        \"-//Hibernate/Hibernate Configuration DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
-"\">\n"
-"\n"
-"<hibernate-configuration>\n"
-"\n"
-"    <session-factory>\n"
-"\n"
-"        <!-- Database connection settings -->\n"
-"        <property name=\"connection.driver_class\">org.hsqldb.jdbcDriver</"
-"property>\n"
-"        <property name=\"connection.url\">jdbc:hsqldb:hsql://localhost</"
-"property>\n"
-"        <property name=\"connection.username\">sa</property>\n"
-"        <property name=\"connection.password\"></property>\n"
-"\n"
-"        <!-- JDBC connection pool (use the built-in) -->\n"
-"        <property name=\"connection.pool_size\">1</property>\n"
-"\n"
-"        <!-- SQL dialect -->\n"
-"        <property name=\"dialect\">org.hibernate.dialect.HSQLDialect</"
-"property>\n"
-"\n"
-"        <!-- Enable Hibernate's automatic session context management -->\n"
-"        <property name=\"current_session_context_class\">thread</property>\n"
-"\n"
-"        <!-- Disable the second-level cache  -->\n"
-"        <property name=\"cache.provider_class\">org.hibernate.cache."
-"NoCacheProvider</property>\n"
-"\n"
-"        <!-- Echo all executed SQL to stdout -->\n"
-"        <property name=\"show_sql\">true</property>\n"
-"\n"
-"        <!-- Drop and re-create the database schema on startup -->\n"
-"        <property name=\"hbm2ddl.auto\">update</property>\n"
-"\n"
-"        <mapping resource=\"org/hibernate/tutorial/domain/Event.hbm.xml\"/>\n"
-"\n"
-"    </session-factory>\n"
-"\n"
-"</hibernate-configuration>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:363
 #, no-c-format
 msgid "Notice that this configuration file specifies a different DTD"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:366
 #, fuzzy, no-c-format
 msgid ""
 "You configure Hibernate's <literal>SessionFactory</literal>. SessionFactory "
@@ -734,7 +488,6 @@
 "factory&gt;</literal> 구성들을 사용하라."
 
 #. Tag: para
-#: tutorial.xml:373
 #, no-c-format
 msgid ""
 "The first four <literal>property</literal> elements contain the necessary "
@@ -743,15 +496,13 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:380
 #, no-c-format
 msgid ""
 "In most cases, Hibernate is able to properly determine which dialect to use. "
-"See <xref linkend=\"portability-dialectresolver\"/> for more information."
+"See <xref linkend=\"portability-dialectresolver\" /> for more information."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:386
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate's automatic session management for persistence contexts is "
@@ -771,7 +522,6 @@
 "수 있다. 마지막으로 우리는 영속 클래스들을 위한 매핑 파일(들)을 추가시킨다."
 
 #. Tag: para
-#: tutorial.xml:395
 #, no-c-format
 msgid ""
 "Save this file as <filename>hibernate.cfg.xml</filename> into the "
@@ -779,13 +529,11 @@
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:403
 #, fuzzy, no-c-format
 msgid "Building with Maven"
 msgstr "Ant로 빌드하기"
 
 #. Tag: para
-#: tutorial.xml:405
 #, no-c-format
 msgid ""
 "We will now build the tutorial with Maven. You will need to have Maven "
@@ -796,43 +544,12 @@
 "make sure we can compile everything so far:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:415
-#, no-c-format
-msgid ""
-"<![CDATA[[hibernateTutorial]$ mvn compile\n"
-"[INFO] Scanning for projects...\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] Building First Hibernate Tutorial\n"
-"[INFO]    task-segment: [compile]\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] [resources:resources]\n"
-"[INFO] Using default encoding to copy filtered resources.\n"
-"[INFO] [compiler:compile]\n"
-"[INFO] Compiling 1 source file to /home/steve/projects/sandbox/"
-"hibernateTutorial/target/classes\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] BUILD SUCCESSFUL\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] Total time: 2 seconds\n"
-"[INFO] Finished at: Tue Jun 09 12:25:25 CDT 2009\n"
-"[INFO] Final Memory: 5M/547M\n"
-"[INFO] "
-"------------------------------------------------------------------------]]>"
-msgstr ""
-
 #. Tag: title
-#: tutorial.xml:420
 #, no-c-format
 msgid "Startup and helpers"
 msgstr "시작과 helper들"
 
 #. Tag: para
-#: tutorial.xml:422
 #, fuzzy, no-c-format
 msgid ""
 "It is time to load and store some <literal>Event</literal> objects, but "
@@ -856,7 +573,6 @@
 "전역 객체이다."
 
 #. Tag: para
-#: tutorial.xml:436
 #, fuzzy, no-c-format
 msgid ""
 "We will create a <literal>HibernateUtil</literal> helper class that takes "
@@ -868,42 +584,7 @@
 "<emphasis>ThreadLocal Session</emphasis> 패턴이 여기서 유용하며, 우리는 현재"
 "의 작업 단위를 현재의 쓰레드와 연관지워 유지한다. 구현을 살펴보자:"
 
-#. Tag: programlisting
-#: tutorial.xml:442
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.util;\n"
-"\n"
-"import org.hibernate.SessionFactory;\n"
-"import org.hibernate.cfg.Configuration;\n"
-"\n"
-"public class HibernateUtil {\n"
-"\n"
-"    private static final SessionFactory sessionFactory = buildSessionFactory"
-"();\n"
-"\n"
-"    private static SessionFactory buildSessionFactory() {\n"
-"        try {\n"
-"            // Create the SessionFactory from hibernate.cfg.xml\n"
-"            return new Configuration().configure().buildSessionFactory();\n"
-"        }\n"
-"        catch (Throwable ex) {\n"
-"            // Make sure you log the exception, as it might be swallowed\n"
-"            System.err.println(\"Initial SessionFactory creation failed.\" + "
-"ex);\n"
-"            throw new ExceptionInInitializerError(ex);\n"
-"        }\n"
-"    }\n"
-"\n"
-"    public static SessionFactory getSessionFactory() {\n"
-"        return sessionFactory;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:444
 #, no-c-format
 msgid ""
 "Save this code as <filename>src/main/java/org/hibernate/tutorial/util/"
@@ -911,7 +592,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:449
 #, fuzzy, no-c-format
 msgid ""
 "This class not only produces the global <interfacename>org.hibernate."
@@ -930,7 +610,6 @@
 "</literal>에 대한 호출은 쓰레드와 현재 연관되어 있는 작업 단위를 종료시킨다."
 
 #. Tag: para
-#: tutorial.xml:458
 #, fuzzy, no-c-format
 msgid ""
 "If you give the <interfacename>org.hibernate.SessionFactory</interfacename> "
@@ -952,7 +631,6 @@
 "으로 바인드시킬 수 있을 것이다."
 
 #. Tag: para
-#: tutorial.xml:467
 #, fuzzy, no-c-format
 msgid ""
 "You now need to configure a logging system. Hibernate uses commons logging "
@@ -974,7 +652,6 @@
 "Hibernate 시작 메시지는 stdout 상에 보여진다."
 
 #. Tag: para
-#: tutorial.xml:477
 #, fuzzy, no-c-format
 msgid ""
 "The tutorial infrastructure is complete and you are now ready to do some "
@@ -984,13 +661,11 @@
 "을 행할 준비가 되어 있다."
 
 #. Tag: title
-#: tutorial.xml:485
 #, no-c-format
 msgid "Loading and storing objects"
 msgstr "객체 로딩과 객체 저장"
 
 #. Tag: para
-#: tutorial.xml:487
 #, fuzzy, no-c-format
 msgid ""
 "We are now ready to start doing some real worjk with Hibernate. Let's start "
@@ -1001,49 +676,7 @@
 "우리는 한 개의 <literal>main()</literal> 메소드를 가진 한 개의 "
 "<literal>EventManager</literal> 클래스를 작성한다:"
 
-#. Tag: programlisting
-#: tutorial.xml:493
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial;\n"
-"\n"
-"import org.hibernate.Session;\n"
-"\n"
-"import java.util.*;\n"
-"\n"
-"import org.hibernate.tutorial.domain.Event;\n"
-"import org.hibernate.tutorial.util.HibernateUtil;\n"
-"\n"
-"public class EventManager {\n"
-"\n"
-"    public static void main(String[] args) {\n"
-"        EventManager mgr = new EventManager();\n"
-"\n"
-"        if (args[0].equals(\"store\")) {\n"
-"            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-"        }\n"
-"\n"
-"        HibernateUtil.getSessionFactory().close();\n"
-"    }\n"
-"\n"
-"    private void createAndStoreEvent(String title, Date theDate) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Event theEvent = new Event();\n"
-"        theEvent.setTitle(title);\n"
-"        theEvent.setDate(theDate);\n"
-"        session.save(theEvent);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:495
 #, fuzzy, no-c-format
 msgid ""
 "In <literal>createAndStoreEvent()</literal> we created a new <literal>Event</"
@@ -1058,7 +691,6 @@
 "펴보자."
 
 #. Tag: para
-#: tutorial.xml:502
 #, fuzzy, no-c-format
 msgid ""
 "A <interface>org.hibernate.Session</interface> is designed to represent a "
@@ -1078,7 +710,6 @@
 "가능한 <literal>Transaction</literal> API를 사용한다."
 
 #. Tag: para
-#: tutorial.xml:515
 #, fuzzy, no-c-format
 msgid ""
 "What does <literal>sessionFactory.getCurrentSession()</literal> do? First, "
@@ -1101,7 +732,6 @@
 "scope(영역), 작업 단위가 시작될 때와 작업 단위가 종료될 때를 고려해야 한다."
 
 #. Tag: para
-#: tutorial.xml:529
 #, no-c-format
 msgid ""
 "Hibernate offers three methods of current session tracking. The \"thread\" "
@@ -1111,7 +741,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:538
 #, fuzzy, no-c-format
 msgid ""
 "A <interface>org.hibernate.Session</interface> begins when the first call to "
@@ -1136,7 +765,6 @@
 "질 수 있는데, 우리는 이 튜토리얼의 뒷부분에서 이것을 다룰 것이다.)."
 
 #. Tag: para
-#: tutorial.xml:551
 #, fuzzy, no-c-format
 msgid ""
 "Related to the unit of work scope, should the Hibernate <interface>org."
@@ -1164,10 +792,9 @@
 "진다."
 
 #. Tag: para
-#: tutorial.xml:568
 #, fuzzy, no-c-format
 msgid ""
-"See <xref linkend=\"transactions\"/> for more information about transaction "
+"See <xref linkend=\"transactions\" /> for more information about transaction "
 "handling and demarcation. The previous example also skipped any error "
 "handling and rollback."
 msgstr ""
@@ -1175,7 +802,6 @@
 ">을 살펴보라. 우리는 또한 앞의 예제에서 임의의 오류 처리와 롤백을 생략했다."
 
 #. Tag: para
-#: tutorial.xml:574
 #, no-c-format
 msgid ""
 "To run this, we will make use of the Maven exec plugin to call our class "
@@ -1184,13 +810,11 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:581
 #, no-c-format
 msgid "You may need to perform <command>mvn compile</command> first."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:586
 #, fuzzy, no-c-format
 msgid ""
 "You should see Hibernate starting up and, depending on your configuration, "
@@ -1199,78 +823,33 @@
 "컴파일, 구성에 따른 Hibernate 시작 후에, 당신은 많은 로그 출력을 보게 될 것이"
 "다. 끝에서 당신은 다음 라인을 발견할 것이다:"
 
-#. Tag: programlisting
-#: tutorial.xml:591
-#, no-c-format
-msgid ""
-"<![CDATA[[java] Hibernate: insert into EVENTS (EVENT_DATE, title, EVENT_ID) "
-"values (?, ?, ?)]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:593
 #, no-c-format
 msgid "This is the <literal>INSERT</literal> executed by Hibernate."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:597
 #, fuzzy, no-c-format
 msgid "To list stored events an option is added to the main method:"
 msgstr ""
 "이제 우리는 마찬가지로 저장된 이벤트들을 열거하고자 원하며, 우리는 main 메소"
 "드에 한 개의 옵션을 추가한다:"
 
-#. Tag: programlisting
-#: tutorial.xml:601
-#, no-c-format
-msgid ""
-"<![CDATA[        if (args[0].equals(\"store\")) {\n"
-"            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-"        }\n"
-"        else if (args[0].equals(\"list\")) {\n"
-"            List events = mgr.listEvents();\n"
-"            for (int i = 0; i < events.size(); i++) {\n"
-"                Event theEvent = (Event) events.get(i);\n"
-"                System.out.println(\n"
-"                        \"Event: \" + theEvent.getTitle() + \" Time: \" + "
-"theEvent.getDate()\n"
-"                );\n"
-"            }\n"
-"        }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:603
 #, fuzzy, no-c-format
 msgid "A new <literal>listEvents() method is also added</literal>:"
 msgstr ""
 "우리는 또한 새로운 <literal>listEvents() method</literal> 메소드를 추가 시킨"
 "다:"
 
-#. Tag: programlisting
-#: tutorial.xml:607
-#, no-c-format
-msgid ""
-"<![CDATA[    private List listEvents() {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"        List result = session.createQuery(\"from Event\").list();\n"
-"        session.getTransaction().commit();\n"
-"        return result;\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:609
 #, fuzzy, no-c-format
 msgid ""
 "Here, we are using a Hibernate Query Language (HQL) query to load all "
 "existing <literal>Event</literal> objects from the database. Hibernate will "
 "generate the appropriate SQL, send it to the database and populate "
 "<literal>Event</literal> objects with the data. You can create more complex "
-"queries with HQL. See <xref linkend=\"queryhql\"/> for more information."
+"queries with HQL. See <xref linkend=\"queryhql\" /> for more information."
 msgstr ""
 "여기서 우리가 행할 것은 데이터베이스로부터 모든 존재하는 <literal>Event</"
 "literal> 객체들을 로드시키기 위해 HQL (Hibernate Query Language) 질의를 사용"
@@ -1279,7 +858,6 @@
 "물론 HQL로서 보다 복잡한 질의들을 생성시킬 수 있다."
 
 #. Tag: para
-#: tutorial.xml:617
 #, no-c-format
 msgid ""
 "Now we can call our new functionality, again using the Maven exec plugin: "
@@ -1288,13 +866,11 @@
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:627
 #, no-c-format
 msgid "Part 2 - Mapping associations"
 msgstr "파트 2 - 연관들을 매핑하기"
 
 #. Tag: para
-#: tutorial.xml:629
 #, fuzzy, no-c-format
 msgid ""
 "So far we have mapped a single persistent entity class to a table in "
@@ -1307,39 +883,16 @@
 "람들을 추가하고 그들이 참여하는 이벤트들의 목록을 저장할 것이다."
 
 #. Tag: title
-#: tutorial.xml:637
 #, no-c-format
 msgid "Mapping the Person class"
 msgstr "Person 클래스 매핑하기"
 
 #. Tag: para
-#: tutorial.xml:639
 #, fuzzy, no-c-format
 msgid "The first cut of the <literal>Person</literal> class looks like this:"
 msgstr "클래스의 첫 번째 장면은 간단하다:"
 
-#. Tag: programlisting
-#: tutorial.xml:643
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.domain;\n"
-"\n"
-"public class Person {\n"
-"\n"
-"    private Long id;\n"
-"    private int age;\n"
-"    private String firstname;\n"
-"    private String lastname;\n"
-"\n"
-"    public Person() {}\n"
-"\n"
-"    // Accessor methods for all properties, private setter for 'id'\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:645
 #, no-c-format
 msgid ""
 "Save this to a file named <filename>src/main/java/org/hibernate/tutorial/"
@@ -1347,47 +900,18 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:650
 #, no-c-format
 msgid ""
 "Next, create the new mapping file as <filename>src/main/resources/org/"
 "hibernate/tutorial/domain/Person.hbm.xml</filename>"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:655
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Person\" table=\"PERSON\">\n"
-"        <id name=\"id\" column=\"PERSON_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"age\"/>\n"
-"        <property name=\"firstname\"/>\n"
-"        <property name=\"lastname\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:657
 #, no-c-format
 msgid "Finally, add the new mapping to Hibernate's configuration:"
 msgstr "마지막으로 새로운 매핑을 Hibernate의 구성에 추가하라:"
 
-#. Tag: programlisting
-#: tutorial.xml:661
-#, no-c-format
-msgid ""
-"<![CDATA[<mapping resource=\"events/Event.hbm.xml\"/>\n"
-"<mapping resource=\"events/Person.hbm.xml\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:663
 #, fuzzy, no-c-format
 msgid ""
 "Create an association between these two entities. Persons can participate in "
@@ -1400,13 +924,11 @@
 "(multiplicity), 그리고 콜렉션 특징."
 
 #. Tag: title
-#: tutorial.xml:673
 #, no-c-format
 msgid "A unidirectional Set-based association"
 msgstr "단방향 Set-기반의 연관"
 
 #. Tag: para
-#: tutorial.xml:675
 #, fuzzy, no-c-format
 msgid ""
 "By adding a collection of events to the <literal>Person</literal> class, you "
@@ -1424,26 +946,7 @@
 "literal>를 사용한다. 왜냐하면 그 콜렉션은 중복 요소들을 포함하기 않을 것이고 "
 "그 순서가 우리와 관련되어 있지 않기 때문이다."
 
-#. Tag: programlisting
-#: tutorial.xml:686
-#, no-c-format
-msgid ""
-"<![CDATA[public class Person {\n"
-"\n"
-"    private Set events = new HashSet();\n"
-"\n"
-"    public Set getEvents() {\n"
-"        return events;\n"
-"    }\n"
-"\n"
-"    public void setEvents(Set events) {\n"
-"        this.events = events;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:688
 #, fuzzy, no-c-format
 msgid ""
 "Before mapping this association, let's consider the other side. We could "
@@ -1465,28 +968,7 @@
 "to-many</emphasis> 연관이라고 명명한다. 그러므로 우리는 Hibernate의 many-to-"
 "many 매핑을 사용한다:"
 
-#. Tag: programlisting
-#: tutorial.xml:701
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\" table=\"PERSON\">\n"
-"    <id name=\"id\" column=\"PERSON_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"age\"/>\n"
-"    <property name=\"firstname\"/>\n"
-"    <property name=\"lastname\"/>\n"
-"\n"
-"    <set name=\"events\" table=\"PERSON_EVENT\">\n"
-"        <key column=\"PERSON_ID\"/>\n"
-"        <many-to-many column=\"EVENT_ID\" class=\"Event\"/>\n"
-"    </set>\n"
-"\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:703
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate supports a broad range of collection mappings, a <literal>set</"
@@ -1513,38 +995,16 @@
 "에 있는 클래스)를 Hibernate에게 알려주어야 한다."
 
 #. Tag: para
-#: tutorial.xml:719
 #, no-c-format
 msgid "The database schema for this mapping is therefore:"
 msgstr "따라서 이 매핑을 위한 데이터베이스 스키마는 다음과 같다:"
 
-#. Tag: programlisting
-#: tutorial.xml:723
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"    _____________        __________________\n"
-"   |             |      |                  |       _____________\n"
-"   |   EVENTS    |      |   PERSON_EVENT   |      |             |\n"
-"   |_____________|      |__________________|      |    PERSON   |\n"
-"   |             |      |                  |      |_____________|\n"
-"   | *EVENT_ID   | <--> | *EVENT_ID        |      |             |\n"
-"   |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  |\n"
-"   |  TITLE      |      |__________________|      |  AGE        |\n"
-"   |_____________|                                |  FIRSTNAME  |\n"
-"                                                  |  LASTNAME   |\n"
-"                                                  |_____________|\n"
-" ]]>"
-msgstr ""
-
 #. Tag: title
-#: tutorial.xml:728
 #, no-c-format
 msgid "Working the association"
 msgstr "연관들에 작업하기"
 
 #. Tag: para
-#: tutorial.xml:730
 #, fuzzy, no-c-format
 msgid ""
 "Now we will bring some people and events together in a new method in "
@@ -1553,25 +1013,7 @@
 "<literal>EventManager</literal> 속에 있는 한 개의 새로운 메소드 내에 몇몇 사"
 "람들과 이벤트들을 함께 가져오자:"
 
-#. Tag: programlisting
-#: tutorial.xml:734
-#, no-c-format
-msgid ""
-"<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session.load(Person.class, personId);\n"
-"        Event anEvent = (Event) session.load(Event.class, eventId);\n"
-"        aPerson.getEvents().add(anEvent);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:736
 #, fuzzy, no-c-format
 msgid ""
 "After loading a <literal>Person</literal> and an <literal>Event</literal>, "
@@ -1605,7 +1047,6 @@
 "션의 커밋(또는 롤백)으로 끝이난다."
 
 #. Tag: para
-#: tutorial.xml:755
 #, fuzzy, no-c-format
 msgid ""
 "You can load person and event in different units of work. Or you can modify "
@@ -1620,43 +1061,7 @@
 "상태를 <emphasis>detached</emphasis>라고 부른다). (매우 사실적이지 않은) 코"
 "드 내에서 이것은 다음과 같을 수 있다:"
 
-#. Tag: programlisting
-#: tutorial.xml:764
-#, no-c-format
-msgid ""
-"<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session\n"
-"                .createQuery(\"select p from Person p left join fetch p."
-"events where p.id = :pid\")\n"
-"                .setParameter(\"pid\", personId)\n"
-"                .uniqueResult(); // Eager fetch the collection so we can use "
-"it detached\n"
-"        Event anEvent = (Event) session.load(Event.class, eventId);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"\n"
-"        // End of first unit of work\n"
-"\n"
-"        aPerson.getEvents().add(anEvent); // aPerson (and its collection) is "
-"detached\n"
-"\n"
-"        // Begin second unit of work\n"
-"\n"
-"        Session session2 = HibernateUtil.getSessionFactory()."
-"getCurrentSession();\n"
-"        session2.beginTransaction();\n"
-"        session2.update(aPerson); // Reattachment of aPerson\n"
-"\n"
-"        session2.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:766
 #, fuzzy, no-c-format
 msgid ""
 "The call to <literal>update</literal> makes a detached object persistent "
@@ -1672,7 +1077,6 @@
 "(추가/삭제)를 포함한다."
 
 #. Tag: para
-#: tutorial.xml:775
 #, fuzzy, no-c-format
 msgid ""
 "This is not much use in our example, but it is an important concept you can "
@@ -1690,22 +1094,7 @@
 "literal> 메소드가 그것을 반환시킨다(당신은 그 식별자를 반환시키는 앞의 메소드"
 "들 중 몇몇을 변경시켜야 할 것이다):"
 
-#. Tag: programlisting
-#: tutorial.xml:783
-#, no-c-format
-msgid ""
-"<![CDATA[        else if (args[0].equals(\"addpersontoevent\")) {\n"
-"            Long eventId = mgr.createAndStoreEvent(\"My Event\", new Date"
-"());\n"
-"            Long personId = mgr.createAndStorePerson(\"Foo\", \"Bar\");\n"
-"            mgr.addPersonToEvent(personId, eventId);\n"
-"            System.out.println(\"Added person \" + personId + \" to event \" "
-"+ eventId);\n"
-"        }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:785
 #, fuzzy, no-c-format
 msgid ""
 "This is an example of an association between two equally important classes : "
@@ -1736,7 +1125,6 @@
 "<literal>MonetaryAmount</literal>을 작성할 수 있다."
 
 #. Tag: para
-#: tutorial.xml:803
 #, fuzzy, no-c-format
 msgid ""
 "You can also design a collection of value types. This is conceptually "
@@ -1748,13 +1136,11 @@
 "진다."
 
 #. Tag: title
-#: tutorial.xml:812
 #, no-c-format
 msgid "Collection of values"
 msgstr "값들을 가진 콜렉션"
 
 #. Tag: para
-#: tutorial.xml:814
 #, no-c-format
 msgid ""
 "Let's add a collection of email addresses to the <literal>Person</literal> "
@@ -1762,39 +1148,12 @@
 "interfacename> of <classname>java.lang.String</classname> instances:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:820
-#, no-c-format
-msgid ""
-"<![CDATA[    private Set emailAddresses = new HashSet();\n"
-"\n"
-"    public Set getEmailAddresses() {\n"
-"        return emailAddresses;\n"
-"    }\n"
-"\n"
-"    public void setEmailAddresses(Set emailAddresses) {\n"
-"        this.emailAddresses = emailAddresses;\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:822
 #, fuzzy, no-c-format
 msgid "The mapping of this <literal>Set</literal> is as follows:"
 msgstr "이 <literal>Set</literal>에 대한 매핑은 다음과 같다:"
 
-#. Tag: programlisting
-#: tutorial.xml:826
-#, no-c-format
-msgid ""
-"<![CDATA[        <set name=\"emailAddresses\" table=\"PERSON_EMAIL_ADDR\">\n"
-"            <key column=\"PERSON_ID\"/>\n"
-"            <element type=\"string\" column=\"EMAIL_ADDR\"/>\n"
-"        </set>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:828
 #, fuzzy, no-c-format
 msgid ""
 "The difference compared with the earlier mapping is the use of the "
@@ -1820,39 +1179,11 @@
 "속성은 <literal>String</literal> 값들이 실제로 저장될 컬럼 이름을 정의한다."
 
 #. Tag: para
-#: tutorial.xml:844
 #, fuzzy, no-c-format
 msgid "Here is the updated schema:"
 msgstr "업데이트된 스키마를 살펴보라:"
 
-#. Tag: programlisting
-#: tutorial.xml:848
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"  _____________        __________________\n"
-" |             |      |                  |       _____________\n"
-" |   EVENTS    |      |   PERSON_EVENT   |      |             |       "
-"___________________\n"
-" |_____________|      |__________________|      |    PERSON   |      "
-"|                   |\n"
-" |             |      |                  |      |_____________|      | "
-"PERSON_EMAIL_ADDR |\n"
-" | *EVENT_ID   | <--> | *EVENT_ID        |      |             |      |"
-"___________________|\n"
-" |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  | <--> |  "
-"*PERSON_ID       |\n"
-" |  TITLE      |      |__________________|      |  AGE        |      |  "
-"*EMAIL_ADDR      |\n"
-" |_____________|                                |  FIRSTNAME  |      |"
-"___________________|\n"
-"                                                |  LASTNAME   |\n"
-"                                                |_____________|\n"
-" ]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:850
 #, fuzzy, no-c-format
 msgid ""
 "You can see that the primary key of the collection table is in fact a "
@@ -1866,7 +1197,6 @@
 "미론이다."
 
 #. Tag: para
-#: tutorial.xml:856
 #, fuzzy, no-c-format
 msgid ""
 "You can now try to add elements to this collection, just like we did before "
@@ -1876,27 +1206,7 @@
 "요소들을 시도하고 이 콜렉션에 추가할 수 있다. 그것은 Java에서 동일한 코드이"
 "다."
 
-#. Tag: programlisting
-#: tutorial.xml:861
-#, no-c-format
-msgid ""
-"<![CDATA[    private void addEmailToPerson(Long personId, String "
-"emailAddress) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session.load(Person.class, personId);\n"
-"        // adding to the emailAddress collection might trigger a lazy load "
-"of the collection\n"
-"        aPerson.getEmailAddresses().add(emailAddress);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:863
 #, fuzzy, no-c-format
 msgid ""
 "This time we did not use a <emphasis>fetch</emphasis> query to initialize "
@@ -1910,13 +1220,11 @@
 "라."
 
 #. Tag: title
-#: tutorial.xml:872
 #, no-c-format
 msgid "Bi-directional associations"
 msgstr "Bi-directional associations"
 
 #. Tag: para
-#: tutorial.xml:874
 #, fuzzy, no-c-format
 msgid ""
 "Next you will map a bi-directional association. You will make the "
@@ -1932,7 +1240,6 @@
 "고 검색될 수 있다."
 
 #. Tag: para
-#: tutorial.xml:882
 #, no-c-format
 msgid ""
 "A relational database is more flexible than a network programming language, "
@@ -1941,7 +1248,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:890
 #, fuzzy, no-c-format
 msgid ""
 "First, add a collection of participants to the <literal>Event</literal> "
@@ -1950,41 +1256,13 @@
 "먼저, 참여자들을 가진 한 개의 콜렉션을 <literal>Event</literal> Event 클래스"
 "에 추가시켜라:"
 
-#. Tag: programlisting
-#: tutorial.xml:895
-#, no-c-format
-msgid ""
-"<![CDATA[    private Set participants = new HashSet();\n"
-"\n"
-"    public Set getParticipants() {\n"
-"        return participants;\n"
-"    }\n"
-"\n"
-"    public void setParticipants(Set participants) {\n"
-"        this.participants = participants;\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:897
 #, fuzzy, no-c-format
 msgid ""
 "Now map this side of the association in <literal>Event.hbm.xml</literal>."
 msgstr "이제 <literal>Event.hbm.xml</literal> 내에 연관의 이 쪽도 매핑하라."
 
-#. Tag: programlisting
-#: tutorial.xml:901
-#, no-c-format
-msgid ""
-"<![CDATA[        <set name=\"participants\" table=\"PERSON_EVENT\" inverse="
-"\"true\">\n"
-"            <key column=\"EVENT_ID\"/>\n"
-"            <many-to-many column=\"PERSON_ID\" class=\"events.Person\"/>\n"
-"        </set>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:903
 #, fuzzy, no-c-format
 msgid ""
 "These are normal <literal>set</literal> mappings in both mapping documents. "
@@ -2001,7 +1279,6 @@
 "내에 있는 <literal>inverse=\"true\"</literal> 속성이다."
 
 #. Tag: para
-#: tutorial.xml:911
 #, fuzzy, no-c-format
 msgid ""
 "What this means is that Hibernate should take the other side, the "
@@ -2015,13 +1292,11 @@
 "해하기가 훨씬 더 쉬울 것이다."
 
 #. Tag: title
-#: tutorial.xml:920
 #, no-c-format
 msgid "Working bi-directional links"
 msgstr "양방향 링크들에 작업하기"
 
 #. Tag: para
-#: tutorial.xml:922
 #, fuzzy, no-c-format
 msgid ""
 "First, keep in mind that Hibernate does not affect normal Java semantics. "
@@ -2045,7 +1320,6 @@
 "것을 행하는 것을 결코 잊지 말아야 한다."
 
 #. Tag: para
-#: tutorial.xml:932
 #, fuzzy, no-c-format
 msgid ""
 "Many developers program defensively and create link management methods to "
@@ -2054,31 +1328,7 @@
 "많은 개발자들은 방비책을 프로그램하고 양 측들을 정확하게 설정하기 위한 하나"
 "의 링크 관리 메소드들을 생성시킨다. 예를 들면 <literal>Person</literal>에서 :"
 
-#. Tag: programlisting
-#: tutorial.xml:937
-#, no-c-format
-msgid ""
-"<![CDATA[    protected Set getEvents() {\n"
-"        return events;\n"
-"    }\n"
-"\n"
-"    protected void setEvents(Set events) {\n"
-"        this.events = events;\n"
-"    }\n"
-"\n"
-"    public void addToEvent(Event event) {\n"
-"        this.getEvents().add(event);\n"
-"        event.getParticipants().add(this);\n"
-"    }\n"
-"\n"
-"    public void removeFromEvent(Event event) {\n"
-"        this.getEvents().remove(event);\n"
-"        event.getParticipants().remove(this);\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:939
 #, fuzzy, no-c-format
 msgid ""
 "The get and set methods for the collection are now protected. This allows "
@@ -2092,7 +1342,6 @@
 "금지시킨다. 당신은 다른 측 상에 있는 콜렉션에 대해 동일한 것을 행할 것이다."
 
 #. Tag: para
-#: tutorial.xml:946
 #, fuzzy, no-c-format
 msgid ""
 "What about the <literal>inverse</literal> mapping attribute? For you, and "
@@ -2123,13 +1372,11 @@
 "이든 선택할 수 있으며 차이점은 없다."
 
 #. Tag: title
-#: tutorial.xml:962
 #, no-c-format
 msgid "Part 3 - The EventManager web application"
 msgstr "파트 3 - EventManager 웹 어플리케이션"
 
 #. Tag: para
-#: tutorial.xml:964
 #, fuzzy, no-c-format
 msgid ""
 "A Hibernate web application uses <literal>Session</literal> and "
@@ -2145,13 +1392,11 @@
 "열할 수 있고, 그것은 새로운 이벤트들을 입력하기 위한 HTML form을 제공한다."
 
 #. Tag: title
-#: tutorial.xml:972
 #, no-c-format
 msgid "Writing the basic servlet"
 msgstr "기본 서블릿 작성하기"
 
 #. Tag: para
-#: tutorial.xml:974
 #, fuzzy, no-c-format
 msgid ""
 "First we need create our basic processing servlet. Since our servlet only "
@@ -2161,52 +1406,7 @@
 "서블릿은 HTTP <literal>GET</literal> 요청들 만을 처리하므로, 우리가 구현하는 "
 "메소드는 <literal>doGet()</literal>이다:"
 
-#. Tag: programlisting
-#: tutorial.xml:980
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.web;\n"
-"\n"
-"// Imports\n"
-"\n"
-"public class EventManagerServlet extends HttpServlet {\n"
-"\n"
-"    protected void doGet(\n"
-"            HttpServletRequest request,\n"
-"            HttpServletResponse response) throws ServletException, "
-"IOException {\n"
-"\n"
-"        SimpleDateFormat dateFormatter = new SimpleDateFormat( \"dd.MM.yyyy"
-"\" );\n"
-"\n"
-"        try {\n"
-"            // Begin unit of work\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"beginTransaction();\n"
-"\n"
-"            // Process request and render page...\n"
-"\n"
-"            // End unit of work\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"getTransaction().commit();\n"
-"        }\n"
-"        catch (Exception ex) {\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"getTransaction().rollback();\n"
-"            if ( ServletException.class.isInstance( ex ) ) {\n"
-"                throw ( ServletException ) ex;\n"
-"            }\n"
-"            else {\n"
-"                throw new ServletException( ex );\n"
-"            }\n"
-"        }\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:982
 #, no-c-format
 msgid ""
 "Save this servlet as <filename>src/main/java/org/hibernate/tutorial/web/"
@@ -2214,7 +1414,6 @@
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:987
 #, fuzzy, no-c-format
 msgid ""
 "The pattern applied here is called <emphasis>session-per-request</emphasis>. "
@@ -2233,7 +1432,6 @@
 "commit 모드를 사용하지 않는다)."
 
 #. Tag: para
-#: tutorial.xml:996
 #, no-c-format
 msgid ""
 "Do <emphasis>not</emphasis> use a new Hibernate <literal>Session</literal> "
@@ -2248,7 +1446,6 @@
 "하라."
 
 #. Tag: para
-#: tutorial.xml:1003
 #, fuzzy, no-c-format
 msgid ""
 "Next, the possible actions of the request are processed and the response "
@@ -2258,7 +1455,6 @@
 "장 그부분으로 갈 것이다."
 
 #. Tag: para
-#: tutorial.xml:1008
 #, fuzzy, no-c-format
 msgid ""
 "Finally, the unit of work ends when processing and rendering are complete. "
@@ -2280,57 +1476,18 @@
 "할 때 그것을 필요로 할 것이다."
 
 #. Tag: title
-#: tutorial.xml:1022
 #, no-c-format
 msgid "Processing and rendering"
 msgstr "프로세싱과 렌더링"
 
 #. Tag: para
-#: tutorial.xml:1024
 #, fuzzy, no-c-format
 msgid ""
 "Now you can implement the processing of the request and the rendering of the "
 "page."
 msgstr "요청의 처리와 페이지의 렌더링을 구현하자."
 
-#. Tag: programlisting
-#: tutorial.xml:1028
-#, no-c-format
-msgid ""
-"<![CDATA[        // Write HTML header\n"
-"        PrintWriter out = response.getWriter();\n"
-"        out.println(\"<html><head><title>Event Manager</title></head><body>"
-"\");\n"
-"\n"
-"        // Handle actions\n"
-"        if ( \"store\".equals(request.getParameter(\"action\")) ) {\n"
-"\n"
-"            String eventTitle = request.getParameter(\"eventTitle\");\n"
-"            String eventDate = request.getParameter(\"eventDate\");\n"
-"\n"
-"            if ( \"\".equals(eventTitle) || \"\".equals(eventDate) ) {\n"
-"                out.println(\"<b><i>Please enter event title and date.</i></"
-"b>\");\n"
-"            }\n"
-"            else {\n"
-"                createAndStoreEvent(eventTitle, dateFormatter.parse"
-"(eventDate));\n"
-"                out.println(\"<b><i>Added event.</i></b>\");\n"
-"            }\n"
-"        }\n"
-"\n"
-"        // Print page\n"
-"       printEventForm(out);\n"
-"       listEvents(out, dateFormatter);\n"
-"\n"
-"       // Write HTML footer\n"
-"       out.println(\"</body></html>\");\n"
-"       out.flush();\n"
-"       out.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1030
 #, fuzzy, no-c-format
 msgid ""
 "This coding style, with a mix of Java and HTML, would not scale in a more "
@@ -2347,25 +1504,7 @@
 "든 이벤트들의 목록이 프린트된다. 첫 번째 메소드는 시행적이고 오직 HTML을 출력"
 "한다:"
 
-#. Tag: programlisting
-#: tutorial.xml:1039
-#, no-c-format
-msgid ""
-"<![CDATA[    private void printEventForm(PrintWriter out) {\n"
-"        out.println(\"<h2>Add new event:</h2>\");\n"
-"        out.println(\"<form>\");\n"
-"        out.println(\"Title: <input name='eventTitle' length='50'/><br/>"
-"\");\n"
-"        out.println(\"Date (e.g. 24.12.2009): <input name='eventDate' "
-"length='10'/><br/>\");\n"
-"        out.println(\"<input type='submit' name='action' value='store'/>"
-"\");\n"
-"        out.println(\"</form>\");\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1041
 #, no-c-format
 msgid ""
 "The <literal>listEvents()</literal> method uses the Hibernate "
@@ -2374,38 +1513,7 @@
 "<literal>listEvents()</literal> 메소드는 하나의 질의를 실행하기 위해서 현재"
 "의 쓰레드에 결합된 Hibernate <literal>Session</literal>을 사용한다:"
 
-#. Tag: programlisting
-#: tutorial.xml:1047
-#, no-c-format
-msgid ""
-"<![CDATA[    private void listEvents(PrintWriter out, SimpleDateFormat "
-"dateFormatter) {\n"
-"\n"
-"        List result = HibernateUtil.getSessionFactory()\n"
-"                .getCurrentSession().createCriteria(Event.class).list();\n"
-"        if (result.size() > 0) {\n"
-"            out.println(\"<h2>Events in database:</h2>\");\n"
-"            out.println(\"<table border='1'>\");\n"
-"            out.println(\"<tr>\");\n"
-"            out.println(\"<th>Event title</th>\");\n"
-"            out.println(\"<th>Event date</th>\");\n"
-"            out.println(\"</tr>\");\n"
-"            Iterator it = result.iterator();\n"
-"            while (it.hasNext()) {\n"
-"                Event event = (Event) it.next();\n"
-"                out.println(\"<tr>\");\n"
-"                out.println(\"<td>\" + event.getTitle() + \"</td>\");\n"
-"                out.println(\"<td>\" + dateFormatter.format(event.getDate()) "
-"+ \"</td>\");\n"
-"                out.println(\"</tr>\");\n"
-"            }\n"
-"            out.println(\"</table>\");\n"
-"        }\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1049
 #, no-c-format
 msgid ""
 "Finally, the <literal>store</literal> action is dispatched to the "
@@ -2416,23 +1524,7 @@
 "literal> 메소드로 디스패치된다. 그것은 현재 쓰레드의 <literal>Session</"
 "literal>을 사용한다:"
 
-#. Tag: programlisting
-#: tutorial.xml:1055
-#, no-c-format
-msgid ""
-"<![CDATA[    protected void createAndStoreEvent(String title, Date theDate) "
-"{\n"
-"        Event theEvent = new Event();\n"
-"        theEvent.setTitle(title);\n"
-"        theEvent.setDate(theDate);\n"
-"\n"
-"        HibernateUtil.getSessionFactory()\n"
-"                .getCurrentSession().save(theEvent);\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1057
 #, fuzzy, no-c-format
 msgid ""
 "The servlet is now complete. A request to the servlet will be processed in a "
@@ -2454,13 +1546,11 @@
 "키를 보라."
 
 #. Tag: title
-#: tutorial.xml:1071
 #, no-c-format
 msgid "Deploying and testing"
 msgstr "배치하기 그리고 테스트하기"
 
 #. Tag: para
-#: tutorial.xml:1073
 #, no-c-format
 msgid ""
 "To deploy this application for testing we must create a Web ARchive (WAR). "
@@ -2468,32 +1558,7 @@
 "web.xml</filename>"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:1079
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
-"<web-app version=\"2.4\"\n"
-"    xmlns=\"http://java.sun.com/xml/ns/j2ee\"\n"
-"    xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
-"    xsi:schemaLocation=\"http://java.sun.com/xml/ns/j2ee http://java.sun.com/"
-"xml/ns/j2ee/web-app_2_4.xsd\">\n"
-"\n"
-"    <servlet>\n"
-"        <servlet-name>Event Manager</servlet-name>\n"
-"        <servlet-class>org.hibernate.tutorial.web.EventManagerServlet</"
-"servlet-class>\n"
-"    </servlet>\n"
-"\n"
-"    <servlet-mapping>\n"
-"        <servlet-name>Event Manager</servlet-name>\n"
-"        <url-pattern>/eventmanager</url-pattern>\n"
-"    </servlet-mapping>\n"
-"</web-app>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1081
 #, fuzzy, no-c-format
 msgid ""
 "To build and deploy call <literal>mvn package</literal> in your project "
@@ -2507,16 +1572,14 @@
 "을 배치하기 위해 임의의 Tomcat 구성을 변경하지 않아야 한다."
 
 #. Tag: para
-#: tutorial.xml:1088
 #, no-c-format
 msgid ""
 "If you do not have Tomcat installed, download it from <ulink url=\"http://"
-"tomcat.apache.org/\"></ulink> and follow the installation instructions. Our "
+"tomcat.apache.org/\" /> and follow the installation instructions. Our "
 "application requires no changes to the standard Tomcat configuration."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:1096
 #, no-c-format
 msgid ""
 "Once deployed and Tomcat is running, access the application at "
@@ -2534,13 +1597,11 @@
 "록 하라."
 
 #. Tag: title
-#: tutorial.xml:1109
 #, no-c-format
 msgid "Summary"
 msgstr "요약"
 
 #. Tag: para
-#: tutorial.xml:1111
 #, fuzzy, no-c-format
 msgid ""
 "This tutorial covered the basics of writing a simple standalone Hibernate "

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/content/xml.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/content/xml.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/content/xml.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,7 +2,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:23\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
 "Language-Team: LANGUAGE <LL at li.org>\n"
@@ -11,29 +11,25 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: xml.xml:29
 #, no-c-format
 msgid "XML Mapping"
 msgstr "XML 매핑"
 
-#. Tag: emphasis
-#: xml.xml:31
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
-"XML Mapping is an experimental feature in Hibernate 3.0 and is currently "
-"under active development."
+"<emphasis> XML Mapping is an experimental feature in Hibernate 3.0 and is "
+"currently under active development. </emphasis>"
 msgstr ""
 "이것은 Hibernate3.0에서 실험적인 특징이고 매우 활동적으로 개발 중에 있음을 노"
 "트하라."
 
 #. Tag: title
-#: xml.xml:37
 #, no-c-format
 msgid "Working with XML data"
 msgstr "XML 데이터로 작업하기"
 
 #. Tag: para
-#: xml.xml:39
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate allows you to work with persistent XML data in much the same way "
@@ -48,7 +44,6 @@
 "수 있다."
 
 #. Tag: para
-#: xml.xml:46
 #, no-c-format
 msgid ""
 "Hibernate supports dom4j as API for manipulating XML trees. You can write "
@@ -68,7 +63,6 @@
 "literal>(merging(병합)은 아직 지원되지 않는다)."
 
 #. Tag: para
-#: xml.xml:56
 #, no-c-format
 msgid ""
 "This feature has many applications including data import/export, "
@@ -78,7 +72,6 @@
 "통한 엔티티 데이터의 구체화를 포함하는 많은 어플리케이션들을 갖는다."
 
 #. Tag: para
-#: xml.xml:61
 #, fuzzy, no-c-format
 msgid ""
 "A single mapping can be used to simultaneously map properties of a class and "
@@ -90,86 +83,26 @@
 "것은 단지 XML을 매핑시키는데 사용될 수도 있다."
 
 #. Tag: title
-#: xml.xml:68
 #, no-c-format
 msgid "Specifying XML and class mapping together"
 msgstr "XML과 클래스 매핑을 함께 지정하기"
 
 #. Tag: para
-#: xml.xml:70
 #, no-c-format
 msgid "Here is an example of mapping a POJO and XML simultaneously:"
 msgstr "다음은 POJO와 XML을 동시에 매핑시키는 예제이다 :"
 
-#. Tag: programlisting
-#: xml.xml:74
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Account\" \n"
-"        table=\"ACCOUNTS\" \n"
-"        node=\"account\">\n"
-"        \n"
-"    <id name=\"accountId\" \n"
-"            column=\"ACCOUNT_ID\" \n"
-"            node=\"@id\"/>\n"
-"            \n"
-"    <many-to-one name=\"customer\" \n"
-"            column=\"CUSTOMER_ID\" \n"
-"            node=\"customer/@id\" \n"
-"            embed-xml=\"false\"/>\n"
-"            \n"
-"    <property name=\"balance\" \n"
-"            column=\"BALANCE\" \n"
-"            node=\"balance\"/>\n"
-"            \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: xml.xml:78
 #, no-c-format
 msgid "Specifying only an XML mapping"
 msgstr "XML 매핑만을 지정하기"
 
 #. Tag: para
-#: xml.xml:80
 #, no-c-format
 msgid "Here is an example where there is no POJO class:"
 msgstr "다음은 POJO 클래스가 존재하지 않는 예제이다:"
 
-#. Tag: programlisting
-#: xml.xml:84
-#, no-c-format
-msgid ""
-"<![CDATA[<class entity-name=\"Account\" \n"
-"        table=\"ACCOUNTS\" \n"
-"        node=\"account\">\n"
-"        \n"
-"    <id name=\"id\" \n"
-"            column=\"ACCOUNT_ID\" \n"
-"            node=\"@id\" \n"
-"            type=\"string\"/>\n"
-"            \n"
-"    <many-to-one name=\"customerId\" \n"
-"            column=\"CUSTOMER_ID\" \n"
-"            node=\"customer/@id\" \n"
-"            embed-xml=\"false\" \n"
-"            entity-name=\"Customer\"/>\n"
-"            \n"
-"    <property name=\"balance\" \n"
-"            column=\"BALANCE\" \n"
-"            node=\"balance\" \n"
-"            type=\"big_decimal\"/>\n"
-"            \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:86
 #, fuzzy, no-c-format
 msgid ""
 "This mapping allows you to access the data as a dom4j tree, or as a graph of "
@@ -182,13 +115,11 @@
 "다."
 
 #. Tag: title
-#: xml.xml:97
 #, no-c-format
 msgid "XML mapping metadata"
 msgstr "XML 매핑 메타데이터"
 
 #. Tag: para
-#: xml.xml:99
 #, fuzzy, no-c-format
 msgid ""
 "A range of Hibernate mapping elements accept the <literal>node</literal> "
@@ -201,26 +132,22 @@
 "하도록 한다. <literal>node</literal> 속성의 포맷은 다음 중 하나이어야 한다:"
 
 #. Tag: para
-#: xml.xml:108
 #, fuzzy, no-c-format
 msgid "<literal>\"element-name\"</literal>: map to the named XML element"
 msgstr "<literal>\"element-name\"</literal> - 명명된 XML 요소로 매핑시킨다"
 
 #. Tag: para
-#: xml.xml:111
 #, fuzzy, no-c-format
 msgid "<literal>\"@attribute-name\"</literal>: map to the named XML attribute"
 msgstr ""
 "<literal>\"@attribute-name\"</literal> - 명명된 XML 속성으로 매핑시킨다"
 
 #. Tag: para
-#: xml.xml:114
 #, fuzzy, no-c-format
 msgid "<literal>\".\"</literal>: map to the parent element"
 msgstr "<literal>\".\"</literal> - 부모 요소로 매핑 시킨다"
 
 #. Tag: para
-#: xml.xml:117
 #, fuzzy, no-c-format
 msgid ""
 "<literal>\"element-name/@attribute-name\"</literal>: map to the named "
@@ -230,7 +157,6 @@
 "성으로 매핑시킨다"
 
 #. Tag: para
-#: xml.xml:124
 #, fuzzy, no-c-format
 msgid ""
 "For collections and single valued associations, there is an additional "
@@ -249,7 +175,6 @@
 "인트 연관들에 대해 나타날 것이고 콜렉션들은 단순히 전혀 나타나지 않을 것이다."
 
 #. Tag: para
-#: xml.xml:134
 #, fuzzy, no-c-format
 msgid ""
 "Do not leave <literal>embed-xml=\"true\"</literal> for too many "
@@ -259,48 +184,7 @@
 "지 말도록 주의해야 한다. 왜냐하면 XML이 순환적으로 잘 처리하지 못하기 때문이"
 "다!"
 
-#. Tag: programlisting
-#: xml.xml:139
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Customer\" \n"
-"        table=\"CUSTOMER\" \n"
-"        node=\"customer\">\n"
-"        \n"
-"    <id name=\"id\" \n"
-"            column=\"CUST_ID\" \n"
-"            node=\"@id\"/>\n"
-"            \n"
-"    <map name=\"accounts\" \n"
-"            node=\".\" \n"
-"            embed-xml=\"true\">\n"
-"        <key column=\"CUSTOMER_ID\" \n"
-"                not-null=\"true\"/>\n"
-"        <map-key column=\"SHORT_DESC\" \n"
-"                node=\"@short-desc\" \n"
-"                type=\"string\"/>\n"
-"        <one-to-many entity-name=\"Account\"\n"
-"                embed-xml=\"false\" \n"
-"                node=\"account\"/>\n"
-"    </map>\n"
-"    \n"
-"    <component name=\"name\" \n"
-"            node=\"name\">\n"
-"        <property name=\"firstName\" \n"
-"                node=\"first-name\"/>\n"
-"        <property name=\"initial\" \n"
-"                node=\"initial\"/>\n"
-"        <property name=\"lastName\" \n"
-"                node=\"last-name\"/>\n"
-"    </component>\n"
-"    \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:141
 #, fuzzy, no-c-format
 msgid ""
 "In this case, the collection of account ids is embedded, but not the actual "
@@ -309,38 +193,12 @@
 "이 경우에, 우리는 실제 account 데이터가 아닌, account id들을 가진 콜렉션을 삽"
 "입시키기로 결정했다. 다음 HQL 질의:"
 
-#. Tag: programlisting
-#: xml.xml:146
-#, no-c-format
-msgid ""
-"<![CDATA[from Customer c left join fetch c.accounts where c.lastName like :"
-"lastName]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:148
 #, fuzzy, no-c-format
 msgid "would return datasets such as this:"
 msgstr "는 다음과 같은 데이터셋들을 반환할 것이다:"
 
-#. Tag: programlisting
-#: xml.xml:152
-#, no-c-format
-msgid ""
-"<![CDATA[<customer id=\"123456789\">\n"
-"    <account short-desc=\"Savings\">987632567</account>\n"
-"    <account short-desc=\"Credit Card\">985612323</account>\n"
-"    <name>\n"
-"        <first-name>Gavin</first-name>\n"
-"        <initial>A</initial>\n"
-"        <last-name>King</last-name>\n"
-"    </name>\n"
-"    ...\n"
-"</customer>]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:154
 #, no-c-format
 msgid ""
 "If you set <literal>embed-xml=\"true\"</literal> on the <literal>&lt;one-to-"
@@ -350,36 +208,12 @@
 "<literal>embed-xml=\"true\"</literal>를 설정할 경우, 데이터는 다음과 같이 보"
 "일 수도 있다:"
 
-#. Tag: programlisting
-#: xml.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[<customer id=\"123456789\">\n"
-"    <account id=\"987632567\" short-desc=\"Savings\">\n"
-"        <customer id=\"123456789\"/>\n"
-"        <balance>100.29</balance>\n"
-"    </account>\n"
-"    <account id=\"985612323\" short-desc=\"Credit Card\">\n"
-"        <customer id=\"123456789\"/>\n"
-"        <balance>-2370.34</balance>\n"
-"    </account>\n"
-"    <name>\n"
-"        <first-name>Gavin</first-name>\n"
-"        <initial>A</initial>\n"
-"        <last-name>King</last-name>\n"
-"    </name>\n"
-"    ...\n"
-"</customer>]]>"
-msgstr ""
-
 #. Tag: title
-#: xml.xml:165
 #, no-c-format
 msgid "Manipulating XML data"
 msgstr "XML 데이터 처리하기"
 
 #. Tag: para
-#: xml.xml:167
 #, fuzzy, no-c-format
 msgid ""
 "You can also re-read and update XML documents in the application. You can do "
@@ -388,54 +222,7 @@
 "우리의 어플리케이션 내에서 XML 문서들을 다시 읽어들이고 업데이트 시키자. 우리"
 "는 dom4j 세션을 얻어서 이것을 행한다:"
 
-#. Tag: programlisting
-#: xml.xml:172
-#, no-c-format
-msgid ""
-"<![CDATA[Document doc = ....;\n"
-"       \n"
-"Session session = factory.openSession();\n"
-"Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"List results = dom4jSession\n"
-"    .createQuery(\"from Customer c left join fetch c.accounts where c."
-"lastName like :lastName\")\n"
-"    .list();\n"
-"for ( int i=0; i<results.size(); i++ ) {\n"
-"    //add the customer data to the XML document\n"
-"    Element customer = (Element) results.get(i);\n"
-"    doc.add(customer);\n"
-"}\n"
-"\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: xml.xml:174
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = factory.openSession();\n"
-"Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"Element cust = (Element) dom4jSession.get(\"Customer\", customerId);\n"
-"for ( int i=0; i<results.size(); i++ ) {\n"
-"    Element customer = (Element) results.get(i);\n"
-"    //change the customer name in the XML and database\n"
-"    Element name = customer.element(\"name\");\n"
-"    name.element(\"first-name\").setText(firstName);\n"
-"    name.element(\"initial\").setText(initial);\n"
-"    name.element(\"last-name\").setText(lastName);\n"
-"}\n"
-"\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:176
 #, fuzzy, no-c-format
 msgid ""
 "When implementing XML-based data import/export, it is useful to combine this "

Modified: core/trunk/documentation/manual/src/main/docbook/ko-KR/legal_notice.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/ko-KR/legal_notice.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/ko-KR/legal_notice.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,26 +2,25 @@
 msgid ""
 msgstr ""
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:23\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
 "Content-Type: text/plain; charset=UTF-8\n"
 
 #. Tag: title
-#: legal_notice.xml:28
 #, no-c-format
 msgid "Legal Notice"
 msgstr "Legal Notice"
 
-#. Tag: address
-#: legal_notice.xml:30
-#, no-c-format
+#. Tag: para
+#, fuzzy, no-c-format
 msgid ""
-"<street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
-"state><postcode>27606-2072</postcode><country>USA</country> <phone>Phone: +1 "
-"919 754 3700</phone> <phone>Phone: 888 733 4281</phone> <fax>Fax: +1 919 754 "
-"3701</fax> <pob>PO Box 13588</pob><city>Research Triangle Park</city>, "
-"<state>NC</state><postcode>27709</postcode><country>USA</country>"
+"<address> <street>1801 Varsity Drive</street> <city>Raleigh</city>, "
+"<state>NC</state><postcode>27606-2072</postcode><country>USA</country> "
+"<phone>Phone: +1 919 754 3700</phone> <phone>Phone: 888 733 4281</phone> "
+"<fax>Fax: +1 919 754 3701</fax> <pob>PO Box 13588</pob><city>Research "
+"Triangle Park</city>, <state>NC</state><postcode>27709</"
+"postcode><country>USA</country> </address>"
 msgstr ""
 "<street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
 "state><postcode>27606-2072</postcode><country>USA</country> <phone>Phone: +1 "
@@ -30,7 +29,6 @@
 "<state>NC</state><postcode>27709</postcode><country>USA</country>"
 
 #. Tag: para
-#: legal_notice.xml:39
 #, fuzzy, no-c-format
 msgid ""
 "Copyright <trademark class=\"copyright\"></trademark> 2007 by Red Hat, Inc. "
@@ -46,7 +44,6 @@
 "Public License</ulink>, as published by the Free Software Foundation."
 
 #. Tag: para
-#: legal_notice.xml:45
 #, no-c-format
 msgid ""
 "Red Hat and the Red Hat \"Shadow Man\" logo are registered trademarks of Red "
@@ -56,7 +53,6 @@
 "Hat, Inc. in the United States and other countries."
 
 #. Tag: para
-#: legal_notice.xml:48
 #, no-c-format
 msgid ""
 "All other trademarks referenced herein are the property of their respective "
@@ -66,13 +62,11 @@
 "owners."
 
 #. Tag: para
-#: legal_notice.xml:51
 #, no-c-format
 msgid "The GPG fingerprint of the security at redhat.com key is:"
 msgstr "The GPG fingerprint of the security at redhat.com key is:"
 
 #. Tag: para
-#: legal_notice.xml:54
 #, no-c-format
 msgid "CA 20 86 86 2B D6 9D FC 65 F6 EC C4 21 91 80 CD DB 42 A6 0E"
 msgstr "CA 20 86 86 2B D6 9D FC 65 F6 EC C4 21 91 80 CD DB 42 A6 0E"

Modified: core/trunk/documentation/manual/src/main/docbook/pot/Hibernate_Reference.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/Hibernate_Reference.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/Hibernate_Reference.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,34 +1,29 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:14\n"
+"PO-Revision-Date: 2010-02-11T05:38:14\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: Hibernate_Reference.xml:35
 #, no-c-format
 msgid "HIBERNATE - Relational Persistence for Idiomatic Java"
 msgstr ""
 
 #. Tag: subtitle
-#: Hibernate_Reference.xml:36
 #, no-c-format
 msgid "Hibernate Reference Documentation"
 msgstr ""
 
-#. Tag: holder
-#: Hibernate_Reference.xml:51
+#. Tag: releaseinfo
 #, no-c-format
-msgid "&copyrightHolder;"
+msgid "&versionNumber;"
 msgstr ""
 

Modified: core/trunk/documentation/manual/src/main/docbook/pot/author_group.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/author_group.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/author_group.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,190 +1,149 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:14\n"
+"PO-Revision-Date: 2010-02-11T05:38:14\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
-#. Tag: author
-#: author_group.xml:27
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Gavin</firstname> <surname>King</surname>"
+msgid "Gavin"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:31
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Christian</firstname> <surname>Bauer</surname>"
+msgid "Christian"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:35
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Max</firstname> <othername>Rydahl</othername> <surname>Andersen</surname>"
+msgid "Max"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:40
+#. Tag: firstname
 #, no-c-format
-msgid "<author><firstname>Emmanuel</firstname> <surname>Bernard</surname></author>"
+msgid "Emmanuel"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:44
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Steve</firstname> <surname>Ebersole</surname>"
+msgid "Steve"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:49
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>James</firstname> <surname>Cobb</surname>"
+msgid "James"
 msgstr ""
 
-#. Tag: shortaffil
-#: author_group.xml:53 author_group.xml:60
+#. Tag: firstname
 #, no-c-format
-msgid "Graphic Design"
+msgid "Cheyenne"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:56
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Cheyenne</firstname> <surname>Weaver</surname>"
+msgid "Vincent"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:69
+#. Tag: firstname
 #, no-c-format
-msgid "<othername><![CDATA[Bernardo Antonio Buffa Colom&#x00e9]]></othername> <email>kreimer at bbs.frc.utn.edu.ar</email>"
+msgid "Sebastien"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:79
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Vincent</firstname> <surname>Ricard</surname>"
+msgid "Michael"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:83
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Sebastien</firstname> <surname>Cesbron</surname>"
+msgid "Baptiste"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:87
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Michael</firstname> <surname>Courcy</surname>"
+msgid "Anthony"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:91
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Vincent</firstname> <surname>Giguère</surname>"
+msgid "Alvaro"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:95
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Baptiste</firstname> <surname>Mathus</surname>"
+msgid "Anderson"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:99
+#. Tag: firstname
 #, no-c-format
-msgid "<othercredit><firstname>Emmanuel</firstname> <surname>Bernard</surname></othercredit>"
+msgid "Daniel Vieira"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:103
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Anthony</firstname> <surname>Patricio</surname>"
+msgid "Francisco"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:113
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Alvaro</firstname> <surname>Netto</surname> <email>alvaronetto at cetip.com.br</email>"
+msgid "Gamarra"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:118
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Anderson</firstname> <surname>Braulio</surname> <email>andersonbraulio at gmail.com</email>"
+msgid "Luiz Carlos"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:123
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Daniel Vieira</firstname> <surname>Costa</surname> <email>danielvc at gmail.com</email>"
+msgid "Marcel"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:128
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Francisco</firstname> <surname>gamarra</surname> <email>francisco.gamarra at gmail.com</email>"
+msgid "Paulo"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:133
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Gamarra</firstname> <email>mauricio.gamarra at gmail.com</email>"
+msgid "Pablo L."
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:137
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Luiz Carlos</firstname> <surname>Rodrigues</surname> <email>luizcarlos_rodrigues at yahoo.com.br</email>"
+msgid "Renato"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:142
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Marcel</firstname> <surname>Castelo</surname> <email>marcel.castelo at gmail.com</email>"
+msgid "Rogério"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:147
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Paulo</firstname> <surname>César</surname> <email>paulocol at gmail.com</email>"
+msgid "Wanderson"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:152
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Pablo L.</firstname> <surname>de Miranda</surname> <email>pablolmiranda at gmail.com</email>"
+msgid "Cao"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:157
+#. Tag: orgname
 #, no-c-format
-msgid "<firstname>Renato</firstname> <surname>Deggau</surname> <email>rdeggau at gmail.com</email>"
+msgid "RedSaga"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:162
+#. Tag: contrib
 #, no-c-format
-msgid "<firstname>Rogério</firstname> <surname>Araújo</surname> <email>rgildoaraujo at yahoo.com.br</email>"
+msgid "Translation Lead"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:167
-#, no-c-format
-msgid "<firstname>Wanderson</firstname> <surname>Siqueira</surname> <email>wandersonxs at gmail.com</email>"
-msgstr ""
-
-#. Tag: othercredit
-#: author_group.xml:178
-#, no-c-format
-msgid "<firstname>Cao</firstname> <surname>Xiaogang</surname> <affiliation> <orgname>RedSaga</orgname> </affiliation> <contrib>Translation Lead</contrib> <email>caoxg at yahoo.com</email>"
-msgstr ""
-

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/architecture.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/architecture.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/architecture.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,327 +1,273 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:14\n"
+"PO-Revision-Date: 2010-02-11T05:38:14\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: architecture.xml:30
 #, no-c-format
 msgid "Architecture"
 msgstr ""
 
 #. Tag: title
-#: architecture.xml:33
 #, no-c-format
 msgid "Overview"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:35
 #, no-c-format
 msgid "The diagram below provides a high-level view of the Hibernate architecture:"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:48
 #, no-c-format
 msgid "We do not have the scope in this document to provide a more detailed view of all the runtime architectures available; Hibernate is flexible and supports several different approaches. We will, however, show the two extremes: \"minimal\" architecture and \"comprehensive\" architecture."
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:54
 #, no-c-format
 msgid "This next diagram illustrates how Hibernate utilizes database and configuration data to provide persistence services, and persistent objects, to the application."
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:59
 #, no-c-format
 msgid "The \"minimal\" architecture has the application provide its own JDBC connections and manage its own transactions. This approach uses a minimal subset of Hibernate's APIs:"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:74
 #, no-c-format
 msgid "The \"comprehensive\" architecture abstracts the application away from the underlying JDBC/JTA APIs and allows Hibernate to manage the details."
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:88
 #, no-c-format
 msgid "Here are some definitions of the objects depicted in the diagrams:"
 msgstr ""
 
 #. Tag: term
-#: architecture.xml:93
 #, no-c-format
 msgid "SessionFactory (<literal>org.hibernate.SessionFactory</literal>)"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:95
 #, no-c-format
 msgid "A threadsafe, immutable cache of compiled mappings for a single database. A factory for <literal>Session</literal> and a client of <literal>ConnectionProvider</literal>, <literal>SessionFactory</literal> can hold an optional (second-level) cache of data that is reusable between transactions at a process, or cluster, level."
 msgstr ""
 
 #. Tag: term
-#: architecture.xml:105
 #, no-c-format
 msgid "Session (<literal>org.hibernate.Session</literal>)"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:107
 #, no-c-format
 msgid "A single-threaded, short-lived object representing a conversation between the application and the persistent store. It wraps a JDBC connection and is a factory for <literal>Transaction</literal>. <literal>Session</literal> holds a mandatory first-level cache of persistent objects that are used when navigating the object graph or looking up objects by identifier."
 msgstr ""
 
 #. Tag: term
-#: architecture.xml:117
 #, no-c-format
 msgid "Persistent objects and collections"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:119
 #, no-c-format
 msgid "Short-lived, single threaded objects containing persistent state and business function. These can be ordinary JavaBeans/POJOs. They are associated with exactly one <literal>Session</literal>. Once the <literal>Session</literal> is closed, they will be detached and free to use in any application layer (for example, directly as data transfer objects to and from presentation)."
 msgstr ""
 
 #. Tag: term
-#: architecture.xml:129
 #, no-c-format
 msgid "Transient and detached objects and collections"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:131
 #, no-c-format
 msgid "Instances of persistent classes that are not currently associated with a <literal>Session</literal>. They may have been instantiated by the application and not yet persisted, or they may have been instantiated by a closed <literal>Session</literal>."
 msgstr ""
 
 #. Tag: term
-#: architecture.xml:140
 #, no-c-format
 msgid "Transaction (<literal>org.hibernate.Transaction</literal>)"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:142
 #, no-c-format
 msgid "(Optional) A single-threaded, short-lived object used by the application to specify atomic units of work. It abstracts the application from the underlying JDBC, JTA or CORBA transaction. A <literal>Session</literal> might span several <literal>Transaction</literal>s in some cases. However, transaction demarcation, either using the underlying API or <literal>Transaction</literal>, is never optional."
 msgstr ""
 
 #. Tag: term
-#: architecture.xml:153
 #, no-c-format
 msgid "ConnectionProvider (<literal>org.hibernate.connection.ConnectionProvider</literal>)"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:155
 #, no-c-format
 msgid "(Optional) A factory for, and pool of, JDBC connections. It abstracts the application from underlying <literal>Datasource</literal> or <literal>DriverManager</literal>. It is not exposed to application, but it can be extended and/or implemented by the developer."
 msgstr ""
 
 #. Tag: term
-#: architecture.xml:163
 #, no-c-format
 msgid "TransactionFactory (<literal>org.hibernate.TransactionFactory</literal>)"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:165
 #, no-c-format
 msgid "(Optional) A factory for <literal>Transaction</literal> instances. It is not exposed to the application, but it can be extended and/or implemented by the developer."
 msgstr ""
 
-#. Tag: emphasis
-#: architecture.xml:172
+#. Tag: term
 #, no-c-format
-msgid "Extension Interfaces"
+msgid "<emphasis>Extension Interfaces</emphasis>"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:174
 #, no-c-format
 msgid "Hibernate offers a range of optional extension interfaces you can implement to customize the behavior of your persistence layer. See the API documentation for details."
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:183
 #, no-c-format
 msgid "Given a \"minimal\" architecture, the application bypasses the <literal>Transaction</literal>/<literal>TransactionFactory</literal> and/or <literal>ConnectionProvider</literal> APIs to communicate with JTA or JDBC directly."
 msgstr ""
 
 #. Tag: title
-#: architecture.xml:191
 #, no-c-format
 msgid "Instance states"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:192
 #, no-c-format
 msgid "An instance of a persistent class can be in one of three different states. These states are defined in relation to a <emphasis>persistence context</emphasis>. The Hibernate <literal>Session</literal> object is the persistence context. The three different states are as follows:"
 msgstr ""
 
 #. Tag: term
-#: architecture.xml:200
 #, no-c-format
 msgid "transient"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:202
 #, no-c-format
 msgid "The instance is not associated with any persistence context. It has no persistent identity or primary key value."
 msgstr ""
 
 #. Tag: term
-#: architecture.xml:210
 #, no-c-format
 msgid "persistent"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:212
 #, no-c-format
 msgid "The instance is currently associated with a persistence context. It has a persistent identity (primary key value) and can have a corresponding row in the database. For a particular persistence context, Hibernate <emphasis>guarantees</emphasis> that persistent identity is equivalent to Java identity in relation to the in-memory location of the object."
 msgstr ""
 
 #. Tag: term
-#: architecture.xml:224
 #, no-c-format
 msgid "detached"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:226
 #, no-c-format
 msgid "The instance was once associated with a persistence context, but that context was closed, or the instance was serialized to another process. It has a persistent identity and can have a corresponding row in the database. For detached instances, Hibernate does not guarantee the relationship between persistent identity and Java identity."
 msgstr ""
 
 #. Tag: title
-#: architecture.xml:241
 #, no-c-format
 msgid "JMX Integration"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:243
 #, no-c-format
 msgid "JMX is the J2EE standard for the management of Java components. Hibernate can be managed via a JMX standard service. AN MBean implementation is provided in the distribution: <literal>org.hibernate.jmx.HibernateService</literal>."
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:249
 #, no-c-format
 msgid "For an example of how to deploy Hibernate as a JMX service on the JBoss Application Server, please see the JBoss User Guide. JBoss AS also provides these benefits if you deploy using JMX:"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:257
 #, no-c-format
 msgid "<emphasis>Session Management</emphasis>: the Hibernate <literal>Session</literal>'s life cycle can be automatically bound to the scope of a JTA transaction. This means that you no longer have to manually open and close the <literal>Session</literal>; this becomes the job of a JBoss EJB interceptor. You also do not have to worry about transaction demarcation in your code (if you would like to write a portable persistence layer use the optional Hibernate <literal>Transaction</literal> API for this). You call the <literal>HibernateContext</literal> to access a <literal>Session</literal>."
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:269
 #, no-c-format
 msgid "<emphasis>HAR deployment</emphasis>: the Hibernate JMX service is deployed using a JBoss service deployment descriptor in an EAR and/or SAR file, as it supports all the usual configuration options of a Hibernate <literal>SessionFactory</literal>. However, you still need to name all your mapping files in the deployment descriptor. If you use the optional HAR deployment, JBoss will automatically detect all mapping files in your HAR file."
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:280
 #, no-c-format
 msgid "Consult the JBoss AS user guide for more information about these options."
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:284
 #, no-c-format
-msgid "Another feature available as a JMX service is runtime Hibernate statistics. See <xref linkend=\"configuration-optional-statistics\"/> for more information."
+msgid "Another feature available as a JMX service is runtime Hibernate statistics. See <xref linkend=\"configuration-optional-statistics\" /> for more information."
 msgstr ""
 
 #. Tag: title
-#: architecture.xml:291
 #, no-c-format
 msgid "JCA Support"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:292
 #, no-c-format
 msgid "Hibernate can also be configured as a JCA connector. Please see the website for more information. Please note, however, that at this stage Hibernate JCA support is under development."
 msgstr ""
 
 #. Tag: title
-#: architecture.xml:299
 #, no-c-format
 msgid "Contextual sessions"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:300
 #, no-c-format
 msgid "Most applications using Hibernate need some form of \"contextual\" session, where a given session is in effect throughout the scope of a given context. However, across applications the definition of what constitutes a context is typically different; different contexts define different scopes to the notion of current. Applications using Hibernate prior to version 3.0 tended to utilize either home-grown <literal>ThreadLocal</literal>-based contextual sessions, helper classes such as <literal>HibernateUtil</literal>, or utilized third-party frameworks, such as Spring or Pico, which provided proxy/interception-based contextual sessions."
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:309
 #, no-c-format
 msgid "Starting with version 3.0.1, Hibernate added the <literal>SessionFactory.getCurrentSession()</literal> method. Initially, this assumed usage of <literal>JTA</literal> transactions, where the <literal>JTA</literal> transaction defined both the scope and context of a current session. Given the maturity of the numerous stand-alone <literal>JTA TransactionManager</literal> implementations, most, if not all, applications should be using <literal>JTA</literal> transaction management, whether or not they are deployed into a <literal>J2EE</literal> container. Based on that, the <literal>JTA</literal>-based contextual sessions are all you need to use."
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:319
 #, no-c-format
 msgid "However, as of version 3.1, the processing behind <literal>SessionFactory.getCurrentSession()</literal> is now pluggable. To that end, a new extension interface, <literal>org.hibernate.context.CurrentSessionContext</literal>, and a new configuration parameter, <literal>hibernate.current_session_context_class</literal>, have been added to allow pluggability of the scope and context of defining current sessions."
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:326
 #, no-c-format
 msgid "See the Javadocs for the <literal>org.hibernate.context.CurrentSessionContext</literal> interface for a detailed discussion of its contract. It defines a single method, <literal>currentSession()</literal>, by which the implementation is responsible for tracking the current contextual session. Out-of-the-box, Hibernate comes with three implementations of this interface:"
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:336
 #, no-c-format
 msgid "<literal>org.hibernate.context.JTASessionContext</literal>: current sessions are tracked and scoped by a <literal>JTA</literal> transaction. The processing here is exactly the same as in the older JTA-only approach. See the Javadocs for details."
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:344
 #, no-c-format
 msgid "<literal>org.hibernate.context.ThreadLocalSessionContext</literal>:current sessions are tracked by thread of execution. See the Javadocs for details."
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:350
 #, no-c-format
 msgid "<literal>org.hibernate.context.ManagedSessionContext</literal>: current sessions are tracked by thread of execution. However, you are responsible to bind and unbind a <literal>Session</literal> instance with static methods on this class: it does not open, flush, or close a <literal>Session</literal>."
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:359
 #, no-c-format
-msgid "The first two implementations provide a \"one session - one database transaction\" programming model. This is also also known and used as <emphasis>session-per-request</emphasis>. The beginning and end of a Hibernate session is defined by the duration of a database transaction. If you use programmatic transaction demarcation in plain JSE without JTA, you are advised to use the Hibernate <literal>Transaction</literal> API to hide the underlying transaction system from your code. If you use JTA, you can utilize the JTA interfaces to demarcate transactions. If you execute in an EJB container that supports CMT, transaction boundaries are defined declaratively and you do not need any transaction or session demarcation operations in your code. Refer to <xref linkend=\"transactions\"/> for more information and code examples."
+msgid "The first two implementations provide a \"one session - one database transaction\" programming model. This is also also known and used as <emphasis>session-per-request</emphasis>. The beginning and end of a Hibernate session is defined by the duration of a database transaction. If you use programmatic transaction demarcation in plain JSE without JTA, you are advised to use the Hibernate <literal>Transaction</literal> API to hide the underlying transaction system from your code. If you use JTA, you can utilize the JTA interfaces to demarcate transactions. If you execute in an EJB container that supports CMT, transaction boundaries are defined declaratively and you do not need any transaction or session demarcation operations in your code. Refer to <xref linkend=\"transactions\" /> for more information and code examples."
 msgstr ""
 
 #. Tag: para
-#: architecture.xml:371
 #, no-c-format
 msgid "The <literal>hibernate.current_session_context_class</literal> configuration parameter defines which <literal>org.hibernate.context.CurrentSessionContext</literal> implementation should be used. For backwards compatibility, if this configuration parameter is not set but a <literal>org.hibernate.transaction.TransactionManagerLookup</literal> is configured, Hibernate will use the <literal>org.hibernate.context.JTASessionContext</literal>. Typically, the value of this parameter would just name the implementation class to use. For the three out-of-the-box implementations, however, there are three corresponding short names: \"jta\", \"thread\", and \"managed\"."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/association_mapping.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/association_mapping.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/association_mapping.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,743 +1,198 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:14\n"
+"PO-Revision-Date: 2010-02-11T05:38:14\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: association_mapping.xml:30
 #, no-c-format
 msgid "Association Mappings"
 msgstr ""
 
 #. Tag: title
-#: association_mapping.xml:33
 #, no-c-format
 msgid "Introduction"
 msgstr ""
 
 #. Tag: para
-#: association_mapping.xml:35
 #, 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</literal> and <literal>Address</literal> in all the examples."
 msgstr ""
 
 #. Tag: para
-#: association_mapping.xml:43
 #, no-c-format
 msgid "Associations will be classified by multiplicity and whether or not they map to an intervening join table."
 msgstr ""
 
 #. Tag: para
-#: association_mapping.xml:48
 #, 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 ""
 
 #. Tag: title
-#: association_mapping.xml:58
 #, no-c-format
 msgid "Unidirectional associations"
 msgstr ""
 
 #. Tag: title
-#: association_mapping.xml:61 association_mapping.xml:132
 #, no-c-format
 msgid "Many-to-one"
 msgstr ""
 
 #. Tag: para
-#: association_mapping.xml:63
 #, no-c-format
 msgid "A <emphasis>unidirectional many-to-one association</emphasis> is the most common kind of unidirectional association."
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:68
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <many-to-one name=\"address\" \n"
-      "        column=\"addressId\"\n"
-      "        not-null=\"true\"/>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "    <id name=\"id\" column=\"addressId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:69 association_mapping.xml:185
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: association_mapping.xml:74 association_mapping.xml:145 association_mapping.xml:210
 #, no-c-format
 msgid "One-to-one"
 msgstr ""
 
 #. Tag: para
-#: association_mapping.xml:76
 #, no-c-format
 msgid "A <emphasis>unidirectional one-to-one association on a foreign key</emphasis> is almost identical. The only difference is the column unique constraint."
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:81
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <many-to-one name=\"address\" \n"
-      "        column=\"addressId\" \n"
-      "        unique=\"true\"\n"
-      "        not-null=\"true\"/>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "    <id name=\"id\" column=\"addressId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:82 association_mapping.xml:218
-#, no-c-format
-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 ""
-
 #. Tag: para
-#: association_mapping.xml:84
 #, no-c-format
 msgid "A <emphasis>unidirectional one-to-one association on a primary key</emphasis> usually uses a special id generator In this example, however, we have reversed the direction of the association:"
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:90
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"foreign\">\n"
-      "            <param name=\"property\">person</param>\n"
-      "        </generator>\n"
-      "    </id>\n"
-      "    <one-to-one name=\"person\" constrained=\"true\"/>\n"
-      "</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:91 association_mapping.xml:226
-#, no-c-format
-msgid ""
-      "<![CDATA[\n"
-      "create table Person ( personId bigint not null primary key )\n"
-      "create table Address ( personId bigint not null primary key )\n"
-      "        ]]>"
-msgstr ""
-
 #. Tag: title
-#: association_mapping.xml:96 association_mapping.xml:118
 #, no-c-format
 msgid "One-to-many"
 msgstr ""
 
 #. Tag: para
-#: association_mapping.xml:98
 #, no-c-format
 msgid "A <emphasis>unidirectional one-to-many association on a foreign key</emphasis> is an unusual case, and is not recommended."
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:103
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <set name=\"addresses\">\n"
-      "        <key column=\"personId\" \n"
-      "            not-null=\"true\"/>\n"
-      "        <one-to-many class=\"Address\"/>\n"
-      "    </set>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "    <id name=\"id\" column=\"addressId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:104
-#, no-c-format
-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 ""
-
 #. Tag: para
-#: association_mapping.xml:106
 #, no-c-format
 msgid "You should instead use a join table for this kind of association."
 msgstr ""
 
 #. Tag: title
-#: association_mapping.xml:115
 #, no-c-format
 msgid "Unidirectional associations with join tables"
 msgstr ""
 
 #. Tag: para
-#: association_mapping.xml:120
 #, no-c-format
 msgid "A <emphasis>unidirectional one-to-many association on a join table</emphasis> is the preferred option. Specifying <literal>unique=\"true\"</literal>, changes the multiplicity from many-to-many to one-to-many."
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:126
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <set name=\"addresses\" table=\"PersonAddress\">\n"
-      "        <key column=\"personId\"/>\n"
-      "        <many-to-many column=\"addressId\"\n"
-      "            unique=\"true\"\n"
-      "            class=\"Address\"/>\n"
-      "    </set>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "    <id name=\"id\" column=\"addressId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:127
-#, no-c-format
-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 ""
-
 #. Tag: para
-#: association_mapping.xml:134
 #, no-c-format
 msgid "A <emphasis>unidirectional many-to-one association on a join table</emphasis> is common when the association is optional. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:139
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <join table=\"PersonAddress\" \n"
-      "        optional=\"true\">\n"
-      "        <key column=\"personId\" unique=\"true\"/>\n"
-      "        <many-to-one name=\"address\"\n"
-      "            column=\"addressId\" \n"
-      "            not-null=\"true\"/>\n"
-      "    </join>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "    <id name=\"id\" column=\"addressId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:140
-#, no-c-format
-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 ""
-
 #. Tag: para
-#: association_mapping.xml:147
 #, no-c-format
 msgid "A <emphasis>unidirectional one-to-one association on a join table</emphasis> is possible, but extremely unusual."
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:152
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <join table=\"PersonAddress\" \n"
-      "        optional=\"true\">\n"
-      "        <key column=\"personId\" \n"
-      "            unique=\"true\"/>\n"
-      "        <many-to-one name=\"address\"\n"
-      "            column=\"addressId\" \n"
-      "            not-null=\"true\"\n"
-      "            unique=\"true\"/>\n"
-      "    </join>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "    <id name=\"id\" column=\"addressId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:153 association_mapping.xml:258
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: association_mapping.xml:158 association_mapping.xml:263
 #, no-c-format
 msgid "Many-to-many"
 msgstr ""
 
 #. Tag: para
-#: association_mapping.xml:160
 #, no-c-format
 msgid "Finally, here is an example of a <emphasis>unidirectional many-to-many association</emphasis>."
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:164
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <set name=\"addresses\" table=\"PersonAddress\">\n"
-      "        <key column=\"personId\"/>\n"
-      "        <many-to-many column=\"addressId\"\n"
-      "            class=\"Address\"/>\n"
-      "    </set>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "    <id name=\"id\" column=\"addressId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:165 association_mapping.xml:271
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: association_mapping.xml:172
 #, no-c-format
 msgid "Bidirectional associations"
 msgstr ""
 
 #. Tag: title
-#: association_mapping.xml:175 association_mapping.xml:236
 #, no-c-format
 msgid "one-to-many / many-to-one"
 msgstr ""
 
 #. Tag: para
-#: association_mapping.xml:177
 #, no-c-format
 msgid "A <emphasis>bidirectional many-to-one association</emphasis> is the most common kind of association. The following example illustrates the standard parent/child relationship."
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:183
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <many-to-one name=\"address\" \n"
-      "        column=\"addressId\"\n"
-      "        not-null=\"true\"/>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "    <id name=\"id\" column=\"addressId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <set name=\"people\" inverse=\"true\">\n"
-      "        <key column=\"addressId\"/>\n"
-      "        <one-to-many class=\"Person\"/>\n"
-      "    </set>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: association_mapping.xml:187
 #, no-c-format
 msgid "If you use a <literal>List</literal>, or other indexed collection, set the <literal>key</literal> column of the foreign key to <literal>not null</literal>. Hibernate will manage the association from the collections side to maintain the index of each element, making the other side virtually inverse by setting <literal>update=\"false\"</literal> and <literal>insert=\"false\"</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:195
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "   <id name=\"id\"/>\n"
-      "   ...\n"
-      "   <many-to-one name=\"address\"\n"
-      "      column=\"addressId\"\n"
-      "      not-null=\"true\"\n"
-      "      insert=\"false\"\n"
-      "      update=\"false\"/>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "   <id name=\"id\"/>\n"
-      "   ...\n"
-      "   <list name=\"people\">\n"
-      "      <key column=\"addressId\" not-null=\"true\"/>\n"
-      "      <list-index column=\"peopleIdx\"/>\n"
-      "      <one-to-many class=\"Person\"/>\n"
-      "   </list>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: association_mapping.xml:197
 #, no-c-format
 msgid "If the underlying foreign key column is <literal>NOT NULL</literal>, it is important that you define <literal>not-null=\"true\"</literal> on the <literal>&lt;key&gt;</literal> element of the collection mapping. Do not only declare <literal>not-null=\"true\"</literal> on a possible nested <literal>&lt;column&gt;</literal> element, but on the <literal>&lt;key&gt;</literal> element."
 msgstr ""
 
 #. Tag: para
-#: association_mapping.xml:212
 #, no-c-format
 msgid "A <emphasis>bidirectional one-to-one association on a foreign key</emphasis> is common:"
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:217
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <many-to-one name=\"address\" \n"
-      "        column=\"addressId\" \n"
-      "        unique=\"true\"\n"
-      "        not-null=\"true\"/>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "    <id name=\"id\" column=\"addressId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "   <one-to-one name=\"person\" \n"
-      "        property-ref=\"address\"/>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: association_mapping.xml:220
 #, no-c-format
 msgid "A <emphasis>bidirectional one-to-one association on a primary key</emphasis> uses the special id generator:"
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:225
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <one-to-one name=\"address\"/>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"foreign\">\n"
-      "            <param name=\"property\">person</param>\n"
-      "        </generator>\n"
-      "    </id>\n"
-      "    <one-to-one name=\"person\" \n"
-      "        constrained=\"true\"/>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: association_mapping.xml:233
 #, no-c-format
 msgid "Bidirectional associations with join tables"
 msgstr ""
 
 #. Tag: para
-#: association_mapping.xml:238
 #, no-c-format
 msgid "The following is an example of a <emphasis>bidirectional one-to-many association on a join table</emphasis>. The <literal>inverse=\"true\"</literal> can go on either end of the association, on the collection, or on the join."
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:244
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <set name=\"addresses\" \n"
-      "        table=\"PersonAddress\">\n"
-      "        <key column=\"personId\"/>\n"
-      "        <many-to-many column=\"addressId\"\n"
-      "            unique=\"true\"\n"
-      "            class=\"Address\"/>\n"
-      "    </set>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "    <id name=\"id\" column=\"addressId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <join table=\"PersonAddress\" \n"
-      "        inverse=\"true\" \n"
-      "        optional=\"true\">\n"
-      "        <key column=\"addressId\"/>\n"
-      "        <many-to-one name=\"person\"\n"
-      "            column=\"personId\"\n"
-      "            not-null=\"true\"/>\n"
-      "    </join>\n"
-      "</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:245
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: association_mapping.xml:250
 #, no-c-format
 msgid "one to one"
 msgstr ""
 
 #. Tag: para
-#: association_mapping.xml:252
 #, no-c-format
 msgid "A <emphasis>bidirectional one-to-one association on a join table</emphasis> is possible, but extremely unusual."
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:257
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <join table=\"PersonAddress\" \n"
-      "        optional=\"true\">\n"
-      "        <key column=\"personId\" \n"
-      "            unique=\"true\"/>\n"
-      "        <many-to-one name=\"address\"\n"
-      "            column=\"addressId\" \n"
-      "            not-null=\"true\"\n"
-      "            unique=\"true\"/>\n"
-      "    </join>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "    <id name=\"id\" column=\"addressId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <join table=\"PersonAddress\" \n"
-      "        optional=\"true\"\n"
-      "        inverse=\"true\">\n"
-      "        <key column=\"addressId\" \n"
-      "            unique=\"true\"/>\n"
-      "        <many-to-one name=\"person\"\n"
-      "            column=\"personId\" \n"
-      "            not-null=\"true\"\n"
-      "            unique=\"true\"/>\n"
-      "    </join>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: association_mapping.xml:265
 #, no-c-format
 msgid "Here is an example of a <emphasis>bidirectional many-to-many association</emphasis>."
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:269
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\" column=\"personId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <set name=\"addresses\" table=\"PersonAddress\">\n"
-      "        <key column=\"personId\"/>\n"
-      "        <many-to-many column=\"addressId\"\n"
-      "            class=\"Address\"/>\n"
-      "    </set>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "    <id name=\"id\" column=\"addressId\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
-      "        <key column=\"addressId\"/>\n"
-      "        <many-to-many column=\"personId\"\n"
-      "            class=\"Person\"/>\n"
-      "    </set>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: association_mapping.xml:278
 #, no-c-format
 msgid "More complex association mappings"
 msgstr ""
 
 #. Tag: para
-#: association_mapping.xml:280
 #, no-c-format
 msgid "More complex association joins are <emphasis>extremely</emphasis> 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>, <literal>effectiveEndDate</literal> and <literal>effectiveStartDate</literal>columns, it would be mapped as follows:"
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:289
-#, no-c-format
-msgid ""
-      "<![CDATA[<properties name=\"currentAccountKey\">\n"
-      "    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
-      "    <property name=\"currentAccount\" type=\"boolean\">\n"
-      "        <formula>case when effectiveEndDate is null then 1 else 0 end</formula>\n"
-      "    </property>\n"
-      "</properties>\n"
-      "<property name=\"effectiveEndDate\" type=\"date\"/>\n"
-      "<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: association_mapping.xml:291
 #, no-c-format
 msgid "You can then map an association to the <emphasis>current</emphasis> instance, the one with null <literal>effectiveEndDate</literal>, by using:"
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:296
-#, no-c-format
-msgid ""
-      "<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
-      "        property-ref=\"currentAccountKey\"\n"
-      "        class=\"AccountInfo\">\n"
-      "    <column name=\"accountNumber\"/>\n"
-      "    <formula>'1'</formula>\n"
-      "</many-to-one>]]>"
-msgstr ""
-
 #. Tag: para
-#: association_mapping.xml:298
 #, no-c-format
 msgid "In a more complex example, imagine that the association between <literal>Employee</literal> and <literal>Organization</literal> is maintained in an <literal>Employment</literal> table full of historical employment data. An association to the employee's <emphasis>most recent</emphasis> employer, the one with the most recent <literal>startDate</literal>, could be mapped in the following way:"
 msgstr ""
 
-#. Tag: programlisting
-#: association_mapping.xml:306
-#, no-c-format
-msgid ""
-      "<![CDATA[<join>\n"
-      "    <key column=\"employeeId\"/>\n"
-      "    <subselect>\n"
-      "        select employeeId, orgId \n"
-      "        from Employments \n"
-      "        group by orgId \n"
-      "        having startDate = max(startDate)\n"
-      "    </subselect>\n"
-      "    <many-to-one name=\"mostRecentEmployer\" \n"
-      "            class=\"Organization\" \n"
-      "            column=\"orgId\"/>\n"
-      "</join>]]>"
-msgstr ""
-
 #. Tag: para
-#: association_mapping.xml:308
 #, 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 ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/basic_mapping.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/basic_mapping.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/basic_mapping.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,3360 +1,1959 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: basic_mapping.xml:29
 #, no-c-format
 msgid "Basic O/R Mapping"
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:32
 #, no-c-format
 msgid "Mapping declaration"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:34
 #, no-c-format
 msgid "Object/relational mappings are usually defined in an XML document. The mapping document is designed to be readable and hand-editable. The mapping language is Java-centric, meaning that mappings are constructed around persistent class declarations and not table declarations."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:41
 #, no-c-format
 msgid "Please note that even though many Hibernate users choose to write the XML by hand, a number of tools exist to generate the mapping document. These include XDoclet, Middlegen and AndroMDA."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:47
 #, no-c-format
 msgid "Here is an example mapping:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:51
-#, no-c-format
-msgid ""
-      "<![CDATA[<?xml version=\"1.0\"?>\n"
-      "<!DOCTYPE hibernate-mapping PUBLIC\n"
-      "      \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-      "          \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-      "\n"
-      "<hibernate-mapping package=\"eg\">\n"
-      "\n"
-      "        <class name=\"Cat\"\n"
-      "            table=\"cats\"\n"
-      "            discriminator-value=\"C\">\n"
-      "\n"
-      "                <id name=\"id\">\n"
-      "                        <generator class=\"native\"/>\n"
-      "                </id>\n"
-      "\n"
-      "                <discriminator column=\"subclass\"\n"
-      "                     type=\"character\"/>\n"
-      "\n"
-      "                <property name=\"weight\"/>\n"
-      "\n"
-      "                <property name=\"birthdate\"\n"
-      "                    type=\"date\"\n"
-      "                    not-null=\"true\"\n"
-      "                    update=\"false\"/>\n"
-      "\n"
-      "                <property name=\"color\"\n"
-      "                    type=\"eg.types.ColorUserType\"\n"
-      "                    not-null=\"true\"\n"
-      "                    update=\"false\"/>\n"
-      "\n"
-      "                <property name=\"sex\"\n"
-      "                    not-null=\"true\"\n"
-      "                    update=\"false\"/>\n"
-      "\n"
-      "                <property name=\"litterId\"\n"
-      "                    column=\"litterId\"\n"
-      "                    update=\"false\"/>\n"
-      "\n"
-      "                <many-to-one name=\"mother\"\n"
-      "                    column=\"mother_id\"\n"
-      "                    update=\"false\"/>\n"
-      "\n"
-      "                <set name=\"kittens\"\n"
-      "                    inverse=\"true\"\n"
-      "                    order-by=\"litter_id\">\n"
-      "                        <key column=\"mother_id\"/>\n"
-      "                        <one-to-many class=\"Cat\"/>\n"
-      "                </set>\n"
-      "\n"
-      "                <subclass name=\"DomesticCat\"\n"
-      "                    discriminator-value=\"D\">\n"
-      "\n"
-      "                        <property name=\"name\"\n"
-      "                            type=\"string\"/>\n"
-      "\n"
-      "                </subclass>\n"
-      "\n"
-      "        </class>\n"
-      "\n"
-      "        <class name=\"Dog\">\n"
-      "                <!-- mapping for Dog could go here -->\n"
-      "        </class>\n"
-      "\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:53
 #, no-c-format
 msgid "We will now discuss the content of the mapping document. We will only describe, however, the document elements and attributes that are used by Hibernate at runtime. The mapping document also contains some extra optional attributes and elements that affect the database schemas exported by the schema export tool (for example, the <literal> not-null</literal> attribute)."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:64
 #, no-c-format
 msgid "Doctype"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:66
 #, no-c-format
 msgid "All XML mappings should declare the doctype shown. The actual DTD can be found at the URL above, in the directory <literal>hibernate-x.x.x/src/org/hibernate </literal>, or in <literal>hibernate3.jar</literal>. Hibernate will always look for the DTD in its classpath first. If you experience lookups of the DTD using an Internet connection, check the DTD declaration against the contents of your classpath."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:76
 #, no-c-format
 msgid "EntityResolver"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:77
 #, no-c-format
 msgid "Hibernate will first attempt to resolve DTDs in its classpath. It does this is by registering a custom <literal>org.xml.sax.EntityResolver</literal> implementation with the SAXReader it uses to read in the xml files. This custom <literal>EntityResolver</literal> recognizes two different systemId namespaces:"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:85
 #, no-c-format
 msgid "a <literal>hibernate namespace</literal> is recognized whenever the resolver encounters a systemId starting with <literal>http://hibernate.sourceforge.net/</literal>. The resolver attempts to resolve these entities via the classloader which loaded the Hibernate classes."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:94
 #, no-c-format
 msgid "a <literal>user namespace</literal> is recognized whenever the resolver encounters a systemId using a <literal>classpath://</literal> URL protocol. The resolver will attempt to resolve these entities via (1) the current thread context classloader and (2) the classloader which loaded the Hibernate classes."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:103
 #, no-c-format
 msgid "The following is an example of utilizing user namespacing:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:106
-#, no-c-format
-msgid ""
-      "<![CDATA[<?xml version=\"1.0\"?>\n"
-      "<!DOCTYPE hibernate-mapping PUBLIC\n"
-      "        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-      "        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\" [\n"
-      "    <!ENTITY types SYSTEM \"classpath://your/domain/types.xml\">\n"
-      "]>\n"
-      "\n"
-      "<hibernate-mapping package=\"your.domain\">\n"
-      "    <class name=\"MyEntity\">\n"
-      "        <id name=\"id\" type=\"my-custom-id-type\">\n"
-      "            ...\n"
-      "        </id>\n"
-      "    <class>\n"
-      "    &types;\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:107
 #, no-c-format
 msgid "Where <literal>types.xml</literal> is a resource in the <literal>your.domain</literal> package and contains a custom <link linkend=\"mapping-types-custom\">typedef</link>."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:115
 #, no-c-format
 msgid "Hibernate-mapping"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:117
 #, no-c-format
 msgid "This element has several optional attributes. The <literal>schema</literal> and <literal>catalog</literal> attributes specify that tables referred to in this mapping belong to the named schema and/or catalog. If they are specified, tablenames will be qualified by the given schema and catalog names. If they are missing, tablenames will be unqualified. The <literal>default-cascade</literal> attribute specifies what cascade style should be assumed for properties and collections that do not specify a <literal>cascade</literal> attribute. By default, the <literal>auto-import</literal> attribute allows you to use unqualified class names in the query language."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:138
-#, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping\n"
-      "         schema=\"schemaName\"\n"
-      "         catalog=\"catalogName\"\n"
-      "         default-cascade=\"cascade_style\"\n"
-      "         default-access=\"field|property|ClassName\"\n"
-      "         default-lazy=\"true|false\"\n"
-      "         auto-import=\"true|false\"\n"
-      "         package=\"package.name\"\n"
-      " />]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:141
 #, no-c-format
 msgid "<literal>schema</literal> (optional): the name of a database schema."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:146
 #, no-c-format
 msgid "<literal>catalog</literal> (optional): the name of a database catalog."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:151
 #, no-c-format
 msgid "<literal>default-cascade</literal> (optional - defaults to <literal>none</literal>): a default cascade style."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:157
 #, no-c-format
 msgid "<literal>default-access</literal> (optional - defaults to <literal>property</literal>): the strategy Hibernate should use for accessing all properties. It can be a custom implementation of <literal>PropertyAccessor</literal>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:164
 #, no-c-format
 msgid "<literal>default-lazy</literal> (optional - defaults to <literal>true</literal>): the default value for unspecified <literal>lazy</literal> attributes of class and collection mappings."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:171
 #, no-c-format
 msgid "<literal>auto-import</literal> (optional - defaults to <literal>true</literal>): specifies whether we can use unqualified class names of classes in this mapping in the query language."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:178
 #, no-c-format
 msgid "<literal>package</literal> (optional): specifies a package prefix to use for unqualified class names in the mapping document."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:186
 #, no-c-format
 msgid "If you have two persistent classes with the same unqualified name, you should set <literal>auto-import=\"false\"</literal>. An exception will result if you attempt to assign two classes to the same \"imported\" name."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:192
 #, no-c-format
 msgid "The <literal>hibernate-mapping</literal> element allows you to nest several persistent <literal>&lt;class&gt;</literal> mappings, as shown above. It is, however, good practice (and expected by some tools) to map only a single persistent class, or a single class hierarchy, in one mapping file and name it after the persistent superclass. For example, <literal>Cat.hbm.xml</literal>, <literal>Dog.hbm.xml</literal>, or if using inheritance, <literal>Animal.hbm.xml</literal>."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:205
 #, no-c-format
 msgid "Class"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:207
 #, no-c-format
 msgid "You can declare a persistent class using the <literal>class</literal> element. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:235
-#, no-c-format
-msgid ""
-      "<![CDATA[<class\n"
-      "        name=\"ClassName\"\n"
-      "        table=\"tableName\"\n"
-      "        discriminator-value=\"discriminator_value\"\n"
-      "        mutable=\"true|false\"\n"
-      "        schema=\"owner\"\n"
-      "        catalog=\"catalog\"\n"
-      "        proxy=\"ProxyInterface\"\n"
-      "        dynamic-update=\"true|false\"\n"
-      "        dynamic-insert=\"true|false\"\n"
-      "        select-before-update=\"true|false\"\n"
-      "        polymorphism=\"implicit|explicit\"\n"
-      "        where=\"arbitrary sql where condition\"\n"
-      "        persister=\"PersisterClass\"\n"
-      "        batch-size=\"N\"\n"
-      "        optimistic-lock=\"none|version|dirty|all\"\n"
-      "        lazy=\"true|false\"\n"
-      "        entity-name=\"EntityName\"\n"
-      "        check=\"arbitrary sql check condition\"\n"
-      "        rowid=\"rowid\"\n"
-      "        subselect=\"SQL expression\"\n"
-      "        abstract=\"true|false\"\n"
-      "        node=\"element-name\"\n"
-      "/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:238
 #, no-c-format
 msgid "<literal>name</literal> (optional): the fully qualified Java class name of the persistent class or interface. If this attribute is missing, it is assumed that the mapping is for a non-POJO entity."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:245
 #, no-c-format
 msgid "<literal>table</literal> (optional - defaults to the unqualified class name): the name of its database table."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:251
 #, no-c-format
 msgid "<literal>discriminator-value</literal> (optional - defaults to the class name): a value that distinguishes individual subclasses that is used for polymorphic behavior. Acceptable values include <literal>null</literal> and <literal>not null</literal>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:258
 #, no-c-format
 msgid "<literal>mutable</literal> (optional - defaults to <literal>true</literal>): specifies that instances of the class are (not) mutable."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:264 basic_mapping.xml:2231
 #, no-c-format
 msgid "<literal>schema</literal> (optional): overrides the schema name specified by the root <literal>&lt;hibernate-mapping&gt;</literal> element."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:270 basic_mapping.xml:2237
 #, no-c-format
 msgid "<literal>catalog</literal> (optional): overrides the catalog name specified by the root <literal>&lt;hibernate-mapping&gt;</literal> element."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:276
 #, no-c-format
 msgid "<literal>proxy</literal> (optional): specifies an interface to use for lazy initializing proxies. You can specify the name of the class itself."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:282
 #, no-c-format
 msgid "<literal>dynamic-update</literal> (optional - defaults to <literal>false</literal>): specifies that <literal>UPDATE</literal> SQL should be generated at runtime and can contain only those columns whose values have changed."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:289
 #, no-c-format
 msgid "<literal>dynamic-insert</literal> (optional - defaults to <literal>false</literal>): specifies that <literal>INSERT</literal> SQL should be generated at runtime and contain only the columns whose values are not null."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:296
 #, no-c-format
 msgid "<literal>select-before-update</literal> (optional - defaults to <literal>false</literal>): specifies that Hibernate should <emphasis>never</emphasis> perform an SQL <literal>UPDATE</literal> unless it is certain that an object is actually modified. Only when a transient object has been associated with a new session using <literal>update()</literal>, will Hibernate perform an extra SQL <literal>SELECT</literal> to determine if an <literal>UPDATE</literal> is actually required."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:306
 #, no-c-format
 msgid "<literal>polymorphism</literal> (optional - defaults to <literal>implicit</literal>): determines whether implicit or explicit query polymorphism is used."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:312
 #, no-c-format
 msgid "<literal>where</literal> (optional): specifies an arbitrary SQL <literal>WHERE</literal> condition to be used when retrieving objects of this class."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:318
 #, no-c-format
 msgid "<literal>persister</literal> (optional): specifies a custom <literal>ClassPersister</literal>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:323
 #, no-c-format
 msgid "<literal>batch-size</literal> (optional - defaults to <literal>1</literal>): specifies a \"batch size\" for fetching instances of this class by identifier."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:329
 #, no-c-format
 msgid "<literal>optimistic-lock</literal> (optional - defaults to <literal>version</literal>): determines the optimistic locking strategy."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:335
 #, no-c-format
 msgid "<literal>lazy</literal> (optional): lazy fetching can be disabled by setting <literal>lazy=\"false\"</literal>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:341
 #, no-c-format
-msgid "<literal>entity-name</literal> (optional - defaults to the class name): Hibernate3 allows a class to be mapped multiple times, potentially to different tables. It also allows entity mappings that are represented by Maps or XML at the Java level. In these cases, you should provide an explicit arbitrary name for the entity. See <xref linkend=\"persistent-classes-dynamicmodels\"/> and <xref linkend=\"xml\"/> for more information."
+msgid "<literal>entity-name</literal> (optional - defaults to the class name): Hibernate3 allows a class to be mapped multiple times, potentially to different tables. It also allows entity mappings that are represented by Maps or XML at the Java level. In these cases, you should provide an explicit arbitrary name for the entity. See <xref linkend=\"persistent-classes-dynamicmodels\" /> and <xref linkend=\"xml\" /> for more information."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:351
 #, no-c-format
 msgid "<literal>check</literal> (optional): an SQL expression used to generate a multi-row <emphasis>check</emphasis> constraint for automatic schema generation."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:357
 #, no-c-format
 msgid "<literal>rowid</literal> (optional): Hibernate can use ROWIDs on databases. On Oracle, for example, Hibernate can use the <literal>rowid</literal> extra column for fast updates once this option has been set to <literal>rowid</literal>. A ROWID is an implementation detail and represents the physical location of a stored tuple."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:364
 #, no-c-format
 msgid "<literal>subselect</literal> (optional): maps an immutable and read-only entity to a database subselect. This is useful if you want to have a view instead of a base table. See below for more information."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:371
 #, no-c-format
 msgid "<literal>abstract</literal> (optional): is used to mark abstract superclasses in <literal>&lt;union-subclass&gt;</literal> hierarchies."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:379
 #, no-c-format
 msgid "It is acceptable for the named persistent class to be an interface. You can declare implementing classes of that interface using the <literal>&lt;subclass&gt;</literal> element. You can persist any <emphasis>static</emphasis> inner class. Specify the class name using the standard form i.e. <literal>e.g.Foo$Bar</literal>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:386
 #, no-c-format
 msgid "Immutable classes, <literal>mutable=\"false\"</literal>, cannot be updated or deleted by the application. This allows Hibernate to make some minor performance optimizations."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:391
 #, no-c-format
 msgid "The optional <literal>proxy</literal> attribute enables lazy initialization of persistent instances of the class. Hibernate will initially return CGLIB proxies that implement the named interface. The persistent object will load when a method of the proxy is invoked. See \"Initializing collections and proxies\" below."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:398
 #, no-c-format
 msgid "<emphasis>Implicit</emphasis> polymorphism means that instances of the class will be returned by a query that names any superclass or implemented interface or class, and that instances of any subclass of the class will be returned by a query that names the class itself. <emphasis>Explicit</emphasis> polymorphism means that class instances will be returned only by queries that explicitly name that class. Queries that name the class will return only instances of subclasses mapped inside this <literal>&lt;class&gt;</literal> declaration as a <literal>&lt;subclass&gt;</literal> or <literal>&lt;joined-subclass&gt;</literal>. For most purposes, the default <literal>polymorphism=\"implicit\"</literal> is appropriate. Explicit polymorphism is useful when two different classes are mapped to the same table This allows a \"lightweight\" class that contains a subset of the table columns."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:410
 #, no-c-format
 msgid "The <literal>persister</literal> attribute lets you customize the persistence strategy used for the class. You can, for example, specify your own subclass of <literal>org.hibernate.persister.EntityPersister</literal>, or you can even provide a completely new implementation of the interface <literal>org.hibernate.persister.ClassPersister</literal> that implements, for example, persistence via stored procedure calls, serialization to flat files or LDAP. See <literal>org.hibernate.test.CustomPersister</literal> for a simple example of \"persistence\" to a <literal>Hashtable</literal>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:421
 #, no-c-format
 msgid "The <literal>dynamic-update</literal> and <literal>dynamic-insert</literal> settings are not inherited by subclasses, so they can also be specified on the <literal>&lt;subclass&gt;</literal> or <literal>&lt;joined-subclass&gt;</literal> elements. Although these settings can increase performance in some cases, they can actually decrease performance in others."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:429
 #, no-c-format
 msgid "Use of <literal>select-before-update</literal> will usually decrease performance. It is useful to prevent a database update trigger being called unnecessarily if you reattach a graph of detached instances to a <literal>Session</literal>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:435
 #, no-c-format
 msgid "If you enable <literal>dynamic-update</literal>, you will have a choice of optimistic locking strategies:"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:441
 #, no-c-format
 msgid "<literal>version</literal>: check the version/timestamp columns"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:446
 #, no-c-format
 msgid "<literal>all</literal>: check all columns"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:451
 #, no-c-format
 msgid "<literal>dirty</literal>: check the changed columns, allowing some concurrent updates"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:456
 #, no-c-format
 msgid "<literal>none</literal>: do not use optimistic locking"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:461
 #, no-c-format
 msgid "It is <emphasis>strongly</emphasis> recommended that you use version/timestamp columns for optimistic locking with Hibernate. This strategy optimizes performance and correctly handles modifications made to detached instances (i.e. when <literal>Session.merge()</literal> is used)."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:468
 #, no-c-format
 msgid "There is no difference between a view and a base table for a Hibernate mapping. This is transparent at the database level, although some DBMS do not support views properly, especially with updates. Sometimes you want to use a view, but you cannot create one in the database (i.e. with a legacy schema). In this case, you can map an immutable and read-only entity to a given SQL subselect expression:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:476
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Summary\">\n"
-      "    <subselect>\n"
-      "        select item.name, max(bid.amount), count(*)\n"
-      "        from item\n"
-      "        join bid on bid.item_id = item.id\n"
-      "        group by item.name\n"
-      "    </subselect>\n"
-      "    <synchronize table=\"item\"/>\n"
-      "    <synchronize table=\"bid\"/>\n"
-      "    <id name=\"name\"/>\n"
-      "    ...\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:478
 #, no-c-format
 msgid "Declare the tables to synchronize this entity with, ensuring that auto-flush happens correctly and that queries against the derived entity do not return stale data. The <literal>&lt;subselect&gt;</literal> is available both as an attribute and a nested mapping element."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:488
 #, no-c-format
-msgid "<title>id</title>"
+msgid "id"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:490
 #, no-c-format
 msgid "Mapped classes <emphasis>must</emphasis> declare the primary key column of the database table. Most classes will also have a JavaBeans-style property holding the unique identifier of an instance. The <literal>&lt;id&gt;</literal> element defines the mapping from that property to the primary key column."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:505
-#, no-c-format
-msgid ""
-      "<![CDATA[<id\n"
-      "        name=\"propertyName\"\n"
-      "        type=\"typename\"\n"
-      "        column=\"column_name\"\n"
-      "        unsaved-value=\"null|any|none|undefined|id_value\"\n"
-      "        access=\"field|property|ClassName\">\n"
-      "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-      "\n"
-      "        <generator class=\"generatorClass\"/>\n"
-      "</id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:508
 #, no-c-format
 msgid "<literal>name</literal> (optional): the name of the identifier property."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:513 basic_mapping.xml:1351
 #, no-c-format
 msgid "<literal>type</literal> (optional): a name that indicates the Hibernate type."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:518
 #, no-c-format
 msgid "<literal>column</literal> (optional - defaults to the property name): the name of the primary key column."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:524
 #, no-c-format
 msgid "<literal>unsaved-value</literal> (optional - defaults to a \"sensible\" value): an identifier property value that indicates an instance is newly instantiated (unsaved), distinguishing it from detached instances that were saved or loaded in a previous session."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:532
 #, no-c-format
 msgid "<literal>access</literal> (optional - defaults to <literal>property</literal>): the strategy Hibernate should use for accessing the property value."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:540
 #, no-c-format
 msgid "If the <literal>name</literal> attribute is missing, it is assumed that the class has no identifier property."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:545
 #, no-c-format
 msgid "The <literal>unsaved-value</literal> attribute is almost never needed in Hibernate3."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:549
 #, no-c-format
 msgid "There is an alternative <literal>&lt;composite-id&gt;</literal> declaration that allows access to legacy data with composite keys. Its use is strongly discouraged for anything else."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:555
 #, no-c-format
 msgid "Generator"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:557
 #, no-c-format
 msgid "The optional <literal>&lt;generator&gt;</literal> child element names a Java class used to generate unique identifiers for instances of the persistent class. If any parameters are required to configure or initialize the generator instance, they are passed using the <literal>&lt;param&gt;</literal> element."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:564
-#, no-c-format
-msgid ""
-      "<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-      "        <generator class=\"org.hibernate.id.TableHiLoGenerator\">\n"
-      "                <param name=\"table\">uid_table</param>\n"
-      "                <param name=\"column\">next_hi_value_column</param>\n"
-      "        </generator>\n"
-      "</id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:566
 #, no-c-format
 msgid "All generators implement the interface <literal>org.hibernate.id.IdentifierGenerator</literal>. This is a very simple interface. Some applications can choose to provide their own specialized implementations, however, Hibernate provides a range of built-in implementations. The shortcut names for the built-in generators are as follows:"
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:574
+#. Tag: term
 #, no-c-format
-msgid "increment"
+msgid "<literal>increment</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:576
 #, no-c-format
 msgid "generates identifiers of type <literal>long</literal>, <literal>short</literal> or <literal>int</literal> that are unique only when no other process is inserting data into the same table. <emphasis>Do not use in a cluster.</emphasis>"
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:585
+#. Tag: term
 #, no-c-format
-msgid "identity"
+msgid "<literal>identity</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:587
 #, no-c-format
 msgid "supports identity columns in DB2, MySQL, MS SQL Server, Sybase and HypersonicSQL. The returned identifier is of type <literal>long</literal>, <literal>short</literal> or <literal>int</literal>."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:595
+#. Tag: term
 #, no-c-format
-msgid "sequence"
+msgid "<literal>sequence</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:597
 #, no-c-format
 msgid "uses a sequence in DB2, PostgreSQL, Oracle, SAP DB, McKoi or a generator in Interbase. The returned identifier is of type <literal>long</literal>, <literal>short</literal> or <literal>int</literal>"
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:605
+#. Tag: term
 #, no-c-format
-msgid "hilo"
+msgid "<literal>hilo</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:607
 #, no-c-format
 msgid "uses a hi/lo algorithm to efficiently generate identifiers of type <literal>long</literal>, <literal>short</literal> or <literal>int</literal>, given a table and column (by default <literal>hibernate_unique_key</literal> and <literal>next_hi</literal> respectively) as a source of hi values. The hi/lo algorithm generates identifiers that are unique only for a particular database."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:617
+#. Tag: term
 #, no-c-format
-msgid "seqhilo"
+msgid "<literal>seqhilo</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:619
 #, no-c-format
 msgid "uses a hi/lo algorithm to efficiently generate identifiers of type <literal>long</literal>, <literal>short</literal> or <literal>int</literal>, given a named database sequence."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:627
+#. Tag: term
 #, no-c-format
-msgid "uuid"
+msgid "<literal>uuid</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:629
 #, no-c-format
 msgid "uses a 128-bit UUID algorithm to generate identifiers of type string that are unique within a network (the IP address is used). The UUID is encoded as a string of 32 hexadecimal digits in length."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:637
+#. Tag: term
 #, no-c-format
-msgid "guid"
+msgid "<literal>guid</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:639
 #, no-c-format
 msgid "uses a database-generated GUID string on MS SQL Server and MySQL."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:645
+#. Tag: term
 #, no-c-format
-msgid "native"
+msgid "<literal>native</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:647
 #, no-c-format
 msgid "selects <literal>identity</literal>, <literal>sequence</literal> or <literal>hilo</literal> depending upon the capabilities of the underlying database."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:655
+#. Tag: term
 #, no-c-format
-msgid "assigned"
+msgid "<literal>assigned</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:657
 #, no-c-format
 msgid "lets the application assign an identifier to the object before <literal>save()</literal> is called. This is the default strategy if no <literal>&lt;generator&gt;</literal> element is specified."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:665
+#. Tag: term
 #, no-c-format
-msgid "select"
+msgid "<literal>select</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:667
 #, no-c-format
 msgid "retrieves a primary key, assigned by a database trigger, by selecting the row by some unique key and retrieving the primary key value."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:674
+#. Tag: term
 #, no-c-format
-msgid "foreign"
+msgid "<literal>foreign</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:676
 #, no-c-format
 msgid "uses the identifier of another associated object. It is usually used in conjunction with a <literal>&lt;one-to-one&gt;</literal> primary key association."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:683
+#. Tag: term
 #, no-c-format
-msgid "sequence-identity"
+msgid "<literal>sequence-identity</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:685
 #, no-c-format
 msgid "a specialized sequence generation strategy that utilizes a database sequence for the actual value generation, but combines this with JDBC3 getGeneratedKeys to return the generated identifier value as part of the insert statement execution. This strategy is only supported on Oracle 10g drivers targeted for JDK 1.4. Comments on these insert statements are disabled due to a bug in the Oracle drivers."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:702
 #, no-c-format
 msgid "Hi/lo algorithm"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:703
 #, no-c-format
 msgid "The <literal>hilo</literal> and <literal>seqhilo</literal> generators provide two alternate implementations of the hi/lo algorithm. The first implementation requires a \"special\" database table to hold the next available \"hi\" value. Where supported, the second uses an Oracle-style sequence."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:710
-#, no-c-format
-msgid ""
-      "<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-      "        <generator class=\"hilo\">\n"
-      "                <param name=\"table\">hi_value</param>\n"
-      "                <param name=\"column\">next_value</param>\n"
-      "                <param name=\"max_lo\">100</param>\n"
-      "        </generator>\n"
-      "</id>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:712
-#, no-c-format
-msgid ""
-      "<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-      "        <generator class=\"seqhilo\">\n"
-      "                <param name=\"sequence\">hi_value</param>\n"
-      "                <param name=\"max_lo\">100</param>\n"
-      "        </generator>\n"
-      "</id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:714
 #, no-c-format
 msgid "Unfortunately, you cannot use <literal>hilo</literal> when supplying your own <literal>Connection</literal> to Hibernate. When Hibernate uses an application server datasource to obtain connections enlisted with JTA, you must configure the <literal>hibernate.transaction.manager_lookup_class</literal>."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:723
 #, no-c-format
 msgid "UUID algorithm"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:724
 #, no-c-format
 msgid "The UUID contains: IP address, startup time of the JVM that is accurate to a quarter second, system time and a counter value that is unique within the JVM. It is not possible to obtain a MAC address or memory address from Java code, so this is the best option without using JNI."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:733
 #, no-c-format
 msgid "Identity columns and sequences"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:734
 #, no-c-format
 msgid "For databases that support identity columns (DB2, MySQL, Sybase, MS SQL), you can use <literal>identity</literal> key generation. For databases that support sequences (DB2, Oracle, PostgreSQL, Interbase, McKoi, SAP DB) you can use <literal>sequence</literal> style key generation. Both of these strategies require two SQL queries to insert a new object. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:742
-#, no-c-format
-msgid ""
-      "<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-      "        <generator class=\"sequence\">\n"
-      "                <param name=\"sequence\">person_id_sequence</param>\n"
-      "        </generator>\n"
-      "</id>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:744
-#, no-c-format
-msgid ""
-      "<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\" unsaved-value=\"0\">\n"
-      "        <generator class=\"identity\"/>\n"
-      "</id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:746
 #, no-c-format
 msgid "For cross-platform development, the <literal>native</literal> strategy will, depending on the capabilities of the underlying database, choose from the <literal>identity</literal>, <literal>sequence</literal> and <literal>hilo</literal> strategies."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:754
 #, no-c-format
 msgid "Assigned identifiers"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:755
 #, no-c-format
 msgid "If you want the application to assign identifiers, as opposed to having Hibernate generate them, you can use the <literal>assigned</literal> generator. This special generator uses the identifier value already assigned to the object's identifier property. The generator is used when the primary key is a natural key instead of a surrogate key. This is the default behavior if you do not specify a <literal>&lt;generator&gt;</literal> element."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:764
 #, no-c-format
 msgid "The <literal>assigned</literal> generator makes Hibernate use <literal>unsaved-value=\"undefined\"</literal>. This forces Hibernate to go to the database to determine if an instance is transient or detached, unless there is a version or timestamp property, or you define <literal>Interceptor.isUnsaved()</literal>."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:774
 #, no-c-format
 msgid "Primary keys assigned by triggers"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:775
 #, no-c-format
 msgid "Hibernate does not generate DDL with triggers. It is for legacy schemas only."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:779
-#, no-c-format
-msgid ""
-      "<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-      "        <generator class=\"select\">\n"
-      "                <param name=\"key\">socialSecurityNumber</param>\n"
-      "        </generator>\n"
-      "</id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:781
 #, no-c-format
 msgid "In the above example, there is a unique valued property named <literal>socialSecurityNumber</literal>. It is defined by the class, as a natural key and a surrogate key named <literal>person_id</literal>, whose value is generated by a trigger."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:793
 #, no-c-format
 msgid "Enhanced identifier generators"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:795
 #, no-c-format
 msgid "Starting with release 3.2.3, there are 2 new generators which represent a re-thinking of 2 different aspects of identifier generation. The first aspect is database portability; the second is optimization Optimization means that you do not have to query the database for every request for a new identifier value. These two new generators are intended to take the place of some of the named generators described above, starting in 3.3.x. However, they are included in the current releases and can be referenced by FQN."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:803
 #, no-c-format
 msgid "The first of these new generators is <literal>org.hibernate.id.enhanced.SequenceStyleGenerator</literal> which is intended, firstly, as a replacement for the <literal>sequence</literal> generator and, secondly, as a better portability generator than <literal>native</literal>. This is because <literal>native</literal> generally chooses between <literal>identity</literal> and <literal>sequence</literal> which have largely different semantics that can cause subtle issues in applications eyeing portability. <literal>org.hibernate.id.enhanced.SequenceStyleGenerator</literal>, however, achieves portability in a different manner. It chooses between a table or a sequence in the database to store its incrementing values, depending on the capabilities of the dialect being used. The difference between this and <literal>native</literal> is that table-based and sequence-based storage have the same exact semantic. In fact, sequences are exactly what Hibernate tries to emulate with!
  its table-based generators. This generator has a number of configuration parameters:"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:817
 #, no-c-format
 msgid "<literal>sequence_name</literal> (optional, defaults to <literal>hibernate_sequence</literal>): the name of the sequence or table to be used."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:823
 #, no-c-format
 msgid "<literal>initial_value</literal> (optional, defaults to <literal>1</literal>): the initial value to be retrieved from the sequence/table. In sequence creation terms, this is analogous to the clause typically named \"STARTS WITH\"."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:830
 #, no-c-format
 msgid "<literal>increment_size</literal> (optional - defaults to <literal>1</literal>): the value by which subsequent calls to the sequence/table should differ. In sequence creation terms, this is analogous to the clause typically named \"INCREMENT BY\"."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:837
 #, no-c-format
 msgid "<literal>force_table_use</literal> (optional - defaults to <literal>false</literal>): should we force the use of a table as the backing structure even though the dialect might support sequence?"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:844
 #, no-c-format
 msgid "<literal>value_column</literal> (optional - defaults to <literal>next_val</literal>): only relevant for table structures, it is the name of the column on the table which is used to hold the value."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:851
 #, no-c-format
-msgid "<literal>optimizer</literal> (optional - defaults to <literal>none</literal>): See"
+msgid "<literal>optimizer</literal> (optional - defaults to <literal>none</literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\" />"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:858
 #, no-c-format
 msgid "The second of these new generators is <literal>org.hibernate.id.enhanced.TableGenerator</literal>, which is intended, firstly, as a replacement for the <literal>table</literal> generator, even though it actually functions much more like <literal>org.hibernate.id.MultipleHiLoPerTableGenerator</literal>, and secondly, as a re-implementation of <literal>org.hibernate.id.MultipleHiLoPerTableGenerator</literal> that utilizes the notion of pluggable optimizers. Essentially this generator defines a table capable of holding a number of different increment values simultaneously by using multiple distinctly keyed rows. This generator has a number of configuration parameters:"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:868
 #, no-c-format
 msgid "<literal>table_name</literal> (optional - defaults to <literal>hibernate_sequences</literal>): the name of the table to be used."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:874
 #, no-c-format
 msgid "<literal>value_column_name</literal> (optional - defaults to <literal>next_val</literal>): the name of the column on the table that is used to hold the value."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:880
 #, no-c-format
 msgid "<literal>segment_column_name</literal> (optional - defaults to <literal>sequence_name</literal>): the name of the column on the table that is used to hold the \"segment key\". This is the value which identifies which increment value to use."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:887
 #, no-c-format
 msgid "<literal>segment_value</literal> (optional - defaults to <literal>default</literal>): The \"segment key\" value for the segment from which we want to pull increment values for this generator."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:894
 #, no-c-format
 msgid "<literal>segment_value_length</literal> (optional - defaults to <literal>255</literal>): Used for schema generation; the column size to create this segment key column."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:900
 #, no-c-format
 msgid "<literal>initial_value</literal> (optional - defaults to <literal>1</literal>): The initial value to be retrieved from the table."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:906
 #, no-c-format
 msgid "<literal>increment_size</literal> (optional - defaults to <literal>1</literal>): The value by which subsequent calls to the table should differ."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:912
 #, no-c-format
-msgid "<literal>optimizer</literal> (optional - defaults to <literal></literal>): See"
+msgid "<literal>optimizer</literal> (optional - defaults to <literal></literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\" />"
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:922
 #, no-c-format
 msgid "Identifier generator optimization"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:923
 #, no-c-format
-msgid "For identifier generators that store values in the database, it is inefficient for them to hit the database on each and every call to generate a new identifier value. Instead, you can group a bunch of them in memory and only hit the database when you have exhausted your in-memory value group. This is the role of the pluggable optimizers. Currently only the two enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced\"/> support this operation."
+msgid "For identifier generators that store values in the database, it is inefficient for them to hit the database on each and every call to generate a new identifier value. Instead, you can group a bunch of them in memory and only hit the database when you have exhausted your in-memory value group. This is the role of the pluggable optimizers. Currently only the two enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced\" /> support this operation."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:931
 #, no-c-format
 msgid "<literal>none</literal> (generally this is the default if no optimizer was specified): this will not perform any optimizations and hit the database for each and every request."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:937
 #, no-c-format
 msgid "<literal>hilo</literal>: applies a hi/lo algorithm around the database retrieved values. The values from the database for this optimizer are expected to be sequential. The values retrieved from the database structure for this optimizer indicates the \"group number\". The <literal>increment_size</literal> is multiplied by that value in memory to define a group \"hi value\"."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:946
 #, no-c-format
 msgid "<literal>pooled</literal>: as with the case of <literal>hilo</literal>, this optimizer attempts to minimize the number of hits to the database. Here, however, we simply store the starting value for the \"next group\" into the database structure rather than a sequential value in combination with an in-memory grouping algorithm. Here, <literal>increment_size</literal> refers to the values coming from the database."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:959
 #, no-c-format
 msgid "composite-id"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:961
-#, no-c-format
-msgid ""
-      "<![CDATA[<composite-id\n"
-      "        name=\"propertyName\"\n"
-      "        class=\"ClassName\"\n"
-      "        mapped=\"true|false\"\n"
-      "        access=\"field|property|ClassName\">\n"
-      "        node=\"element-name|.\"\n"
-      "\n"
-      "        <key-property name=\"propertyName\" type=\"typename\" column=\"column_name\"/>\n"
-      "        <key-many-to-one name=\"propertyName class=\"ClassName\" column=\"column_name\"/>\n"
-      "        ......\n"
-      "</composite-id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:963
 #, no-c-format
 msgid "A table with a composite key can be mapped with multiple properties of the class as identifier properties. The <literal>&lt;composite-id&gt;</literal> element accepts <literal>&lt;key-property&gt;</literal> property mappings and <literal>&lt;key-many-to-one&gt;</literal> mappings as child elements."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:970
-#, no-c-format
-msgid ""
-      "<![CDATA[<composite-id>\n"
-      "        <key-property name=\"medicareNumber\"/>\n"
-      "        <key-property name=\"dependent\"/>\n"
-      "</composite-id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:972
 #, no-c-format
 msgid "The persistent class <emphasis>must</emphasis> override <literal>equals()</literal> and <literal>hashCode()</literal> to implement composite identifier equality. It must also implement <literal>Serializable</literal>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:978
 #, no-c-format
 msgid "Unfortunately, this approach means that a persistent object is its own identifier. There is no convenient \"handle\" other than the object itself. You must instantiate an instance of the persistent class itself and populate its identifier properties before you can <literal>load()</literal> the persistent state associated with a composite key. We call this approach an <emphasis>embedded</emphasis> composite identifier, and discourage it for serious applications."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:987
 #, no-c-format
 msgid "A second approach is what we call a <emphasis>mapped</emphasis> composite identifier, where the identifier properties named inside the <literal>&lt;composite-id&gt;</literal> element are duplicated on both the persistent class and a separate identifier class."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:993
-#, no-c-format
-msgid ""
-      "<![CDATA[<composite-id class=\"MedicareId\" mapped=\"true\">\n"
-      "        <key-property name=\"medicareNumber\"/>\n"
-      "        <key-property name=\"dependent\"/>\n"
-      "</composite-id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:995
 #, no-c-format
 msgid "In this example, both the composite identifier class, <literal>MedicareId</literal>, and the entity class itself have properties named <literal>medicareNumber</literal> and <literal>dependent</literal>. The identifier class must override <literal>equals()</literal> and <literal>hashCode()</literal> and implement <literal>Serializable</literal>. The main disadvantage of this approach is code duplication."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1004
 #, no-c-format
 msgid "The following attributes are used to specify a mapped composite identifier:"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1010
 #, no-c-format
 msgid "<literal>mapped</literal> (optional - defaults to <literal>false</literal>): indicates that a mapped composite identifier is used, and that the contained property mappings refer to both the entity class and the composite identifier class."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1018
 #, no-c-format
 msgid "<literal>class</literal> (optional - but required for a mapped composite identifier): the class used as a composite identifier."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1025
 #, no-c-format
-msgid "We will describe a third, even more convenient approach, where the composite identifier is implemented as a component class in <xref linkend=\"components-compositeid\"/>. The attributes described below apply only to this alternative approach:"
+msgid "We will describe a third, even more convenient approach, where the composite identifier is implemented as a component class in <xref linkend=\"components-compositeid\" />. The attributes described below apply only to this alternative approach:"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1033
 #, no-c-format
 msgid "<literal>name</literal> (optional - required for this approach): a property of component type that holds the composite identifier. Please see chapter 9 for more information."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1039 basic_mapping.xml:1260 basic_mapping.xml:1372 basic_mapping.xml:1561 basic_mapping.xml:1735 basic_mapping.xml:1905 basic_mapping.xml:2484
 #, no-c-format
 msgid "<literal>access</literal> (optional - defaults to <literal>property</literal>): the strategy Hibernate uses for accessing the property value."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1045
 #, no-c-format
 msgid "<literal>class</literal> (optional - defaults to the property type determined by reflection): the component class used as a composite identifier. Please see the next section for more information."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1052
 #, no-c-format
 msgid "The third approach, an <emphasis>identifier component</emphasis>, is recommended for almost all applications."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:1060
 #, no-c-format
 msgid "Discriminator"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1062
 #, no-c-format
 msgid "The <literal>&lt;discriminator&gt;</literal> element is required for polymorphic persistence using the table-per-class-hierarchy mapping strategy. It declares a discriminator column of the table. The discriminator column contains marker values that tell the persistence layer what subclass to instantiate for a particular row. A restricted set of types can be used: <literal>string</literal>, <literal>character</literal>, <literal>integer</literal>, <literal>byte</literal>, <literal>short</literal>, <literal>boolean</literal>, <literal>yes_no</literal>, <literal>true_false</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1080
-#, no-c-format
-msgid ""
-      "<![CDATA[<discriminator\n"
-      "        column=\"discriminator_column\"\n"
-      "        type=\"discriminator_type\"\n"
-      "        force=\"true|false\"\n"
-      "        insert=\"true|false\"\n"
-      "        formula=\"arbitrary sql expression\"\n"
-      "/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1083
 #, no-c-format
 msgid "<literal>column</literal> (optional - defaults to <literal>class</literal>): the name of the discriminator column."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1089
 #, no-c-format
 msgid "<literal>type</literal> (optional - defaults to <literal>string</literal>): a name that indicates the Hibernate type"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1095
 #, no-c-format
 msgid "<literal>force</literal> (optional - defaults to <literal>false</literal>): \"forces\" Hibernate to specify the allowed discriminator values, even when retrieving all instances of the root class."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1102
 #, no-c-format
 msgid "<literal>insert</literal> (optional - defaults to <literal>true</literal>): set this to <literal>false</literal> if your discriminator column is also part of a mapped composite identifier. It tells Hibernate not to include the column in SQL <literal>INSERTs</literal>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1110
 #, no-c-format
 msgid "<literal>formula</literal> (optional): an arbitrary SQL expression that is executed when a type has to be evaluated. It allows content-based discrimination."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1118
 #, no-c-format
 msgid "Actual values of the discriminator column are specified by the <literal>discriminator-value</literal> attribute of the <literal>&lt;class&gt;</literal> and <literal>&lt;subclass&gt;</literal> elements."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1124
 #, no-c-format
 msgid "The <literal>force</literal> attribute is only useful if the table contains rows with \"extra\" discriminator values that are not mapped to a persistent class. This will not usually be the case."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1130
 #, no-c-format
 msgid "The <literal>formula</literal> attribute allows you to declare an arbitrary SQL expression that will be used to evaluate the type of a row. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1135
-#, no-c-format
-msgid ""
-      "<![CDATA[<discriminator\n"
-      "    formula=\"case when CLASS_TYPE in ('a', 'b', 'c') then 0 else 1 end\"\n"
-      "    type=\"integer\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:1140
 #, no-c-format
 msgid "Version (optional)"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1142
 #, no-c-format
 msgid "The <literal>&lt;version&gt;</literal> element is optional and indicates that the table contains versioned data. This is particularly useful if you plan to use <emphasis>long transactions</emphasis>. See below for more information:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1158
-#, no-c-format
-msgid ""
-      "<![CDATA[<version\n"
-      "        column=\"version_column\"\n"
-      "        name=\"propertyName\"\n"
-      "        type=\"typename\"\n"
-      "        access=\"field|property|ClassName\"\n"
-      "        unsaved-value=\"null|negative|undefined\"\n"
-      "        generated=\"never|always\"\n"
-      "        insert=\"true|false\"\n"
-      "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-      "/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1161
 #, no-c-format
 msgid "<literal>column</literal> (optional - defaults to the property name): the name of the column holding the version number."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1167
 #, no-c-format
 msgid "<literal>name</literal>: the name of a property of the persistent class."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1172
 #, no-c-format
 msgid "<literal>type</literal> (optional - defaults to <literal>integer</literal>): the type of the version number."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1178
 #, no-c-format
 msgid "<literal>access</literal> (optional - defaults to <literal>property</literal>): the strategy Hibernate uses to access the property value."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1184
 #, no-c-format
 msgid "<literal>unsaved-value</literal> (optional - defaults to <literal>undefined</literal>): a version property value that indicates that an instance is newly instantiated (unsaved), distinguishing it from detached instances that were saved or loaded in a previous session. <literal>Undefined</literal> specifies that the identifier property value should be used."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1193
 #, no-c-format
 msgid "<literal>generated</literal> (optional - defaults to <literal>never</literal>): specifies that this version property value is generated by the database. See the discussion of <link linkend=\"mapping-generated\">generated properties</link> for more information."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1200
 #, no-c-format
 msgid "<literal>insert</literal> (optional - defaults to <literal>true</literal>): specifies whether the version column should be included in SQL insert statements. It can be set to <literal>false</literal> if the database column is defined with a default value of <literal>0</literal>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1210
 #, no-c-format
 msgid "Version numbers can be of Hibernate type <literal>long</literal>, <literal>integer</literal>, <literal>short</literal>, <literal>timestamp</literal> or <literal>calendar</literal>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1215
 #, no-c-format
 msgid "A version or timestamp property should never be null for a detached instance. Hibernate will detect any instance with a null version or timestamp as transient, irrespective of what other <literal>unsaved-value</literal> strategies are specified. <emphasis>Declaring a nullable version or timestamp property is an easy way to avoid problems with transitive reattachment in Hibernate. It is especially useful for people using assigned identifiers or composite keys</emphasis>."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:1226
 #, no-c-format
 msgid "Timestamp (optional)"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1228
 #, no-c-format
 msgid "The optional <literal>&lt;timestamp&gt;</literal> element indicates that the table contains timestamped data. This provides an alternative to versioning. Timestamps are a less safe implementation of optimistic locking. However, sometimes the application might use the timestamps in other ways."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1244
-#, no-c-format
-msgid ""
-      "<![CDATA[<timestamp\n"
-      "        column=\"timestamp_column\"\n"
-      "        name=\"propertyName\"\n"
-      "        access=\"field|property|ClassName\"\n"
-      "        unsaved-value=\"null|undefined\"\n"
-      "        source=\"vm|db\"\n"
-      "        generated=\"never|always\"\n"
-      "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-      "/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1247
 #, no-c-format
 msgid "<literal>column</literal> (optional - defaults to the property name): the name of a column holding the timestamp."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1253
 #, no-c-format
 msgid "<literal>name</literal>: the name of a JavaBeans style property of Java type <literal>Date</literal> or <literal>Timestamp</literal> of the persistent class."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1266
 #, no-c-format
 msgid "<literal>unsaved-value</literal> (optional - defaults to <literal>null</literal>): a version property value that indicates that an instance is newly instantiated (unsaved), distinguishing it from detached instances that were saved or loaded in a previous session. <literal>Undefined</literal> specifies that the identifier property value should be used."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1275
 #, no-c-format
 msgid "<literal>source</literal> (optional - defaults to <literal>vm</literal>): Where should Hibernate retrieve the timestamp value from? From the database, or from the current JVM? Database-based timestamps incur an overhead because Hibernate must hit the database in order to determine the \"next value\". It is safer to use in clustered environments. Not all <literal>Dialects</literal> are known to support the retrieval of the database's current timestamp. Others may also be unsafe for usage in locking due to lack of precision (Oracle 8, for example)."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1287
 #, no-c-format
 msgid "<literal>generated</literal> (optional - defaults to <literal>never</literal>): specifies that this timestamp property value is actually generated by the database. See the discussion of <link linkend=\"mapping-generated\">generated properties</link> for more information."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:1298 basic_mapping.xml:2890
 #, no-c-format
 msgid "Note"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1299
 #, no-c-format
 msgid "<literal>&lt;Timestamp&gt;</literal> is equivalent to <literal>&lt;version type=\"timestamp\"&gt;</literal>. And <literal>&lt;timestamp source=\"db\"&gt;</literal> is equivalent to <literal>&lt;version type=\"dbtimestamp\"&gt;</literal>"
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:1311
 #, no-c-format
 msgid "Property"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1313
 #, no-c-format
 msgid "The <literal>&lt;property&gt;</literal> element declares a persistent JavaBean style property of the class."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1335
-#, no-c-format
-msgid ""
-      "<![CDATA[<property\n"
-      "        name=\"propertyName\"\n"
-      "        column=\"column_name\"\n"
-      "        type=\"typename\"\n"
-      "        update=\"true|false\"\n"
-      "        insert=\"true|false\"\n"
-      "        formula=\"arbitrary SQL expression\"\n"
-      "        access=\"field|property|ClassName\"\n"
-      "        lazy=\"true|false\"\n"
-      "        unique=\"true|false\"\n"
-      "        not-null=\"true|false\"\n"
-      "        optimistic-lock=\"true|false\"\n"
-      "        generated=\"never|insert|always\"\n"
-      "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-      "        index=\"index_name\"\n"
-      "        unique_key=\"unique_key_id\"\n"
-      "        length=\"L\"\n"
-      "        precision=\"P\"\n"
-      "        scale=\"S\"\n"
-      "/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1338
 #, no-c-format
 msgid "<literal>name</literal>: the name of the property, with an initial lowercase letter."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1344
 #, no-c-format
 msgid "<literal>column</literal> (optional - defaults to the property name): the name of the mapped database table column. This can also be specified by nested <literal>&lt;column&gt;</literal> element(s)."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1356
 #, no-c-format
 msgid "<literal>update, insert</literal> (optional - defaults to <literal>true</literal>): specifies that the mapped columns should be included in SQL <literal>UPDATE</literal> and/or <literal>INSERT</literal> statements. Setting both to <literal>false</literal> allows a pure \"derived\" property whose value is initialized from some other property that maps to the same column(s), or by a trigger or other application."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1365
 #, no-c-format
 msgid "<literal>formula</literal> (optional): an SQL expression that defines the value for a <emphasis>computed</emphasis> property. Computed properties do not have a column mapping of their own."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1378
 #, no-c-format
 msgid "<literal>lazy</literal> (optional - defaults to <literal>false</literal>): specifies that this property should be fetched lazily when the instance variable is first accessed. It requires build-time bytecode instrumentation."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1385
 #, no-c-format
 msgid "<literal>unique</literal> (optional): enables the DDL generation of a unique constraint for the columns. Also, allow this to be the target of a <literal>property-ref</literal>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1392
 #, no-c-format
 msgid "<literal>not-null</literal> (optional): enables the DDL generation of a nullability constraint for the columns."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1398 basic_mapping.xml:1581
 #, no-c-format
 msgid "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</literal>): specifies that updates to this property do or do not require acquisition of the optimistic lock. In other words, it determines if a version increment should occur when this property is dirty."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1406
 #, no-c-format
 msgid "<literal>generated</literal> (optional - defaults to <literal>never</literal>): specifies that this property value is actually generated by the database. See the discussion of <link linkend=\"mapping-generated\">generated properties</link> for more information."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1415
 #, no-c-format
 msgid "<emphasis>typename</emphasis> could be:"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1421
 #, no-c-format
 msgid "The name of a Hibernate basic type: <literal>integer, string, character, date, timestamp, float, binary, serializable, object, blob</literal> etc."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1427
 #, no-c-format
 msgid "The name of a Java class with a default basic type: <literal>int, float, char, java.lang.String, java.util.Date, java.lang.Integer, java.sql.Clob</literal> etc."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1433
 #, no-c-format
 msgid "The name of a serializable Java class."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1438
 #, no-c-format
 msgid "The class name of a custom type: <literal>com.illflow.type.MyCustomType</literal> etc."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1444
 #, no-c-format
 msgid "If you do not specify a type, Hibernate will use reflection upon the named property and guess the correct Hibernate type. Hibernate will attempt to interpret the name of the return class of the property getter using, in order, rules 2, 3, and 4. In certain cases you will need the <literal>type</literal> attribute. For example, to distinguish between <literal>Hibernate.DATE</literal> and <literal>Hibernate.TIMESTAMP</literal>, or to specify a custom type."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1454
 #, no-c-format
 msgid "The <literal>access</literal> attribute allows you to control how Hibernate accesses the property at runtime. By default, Hibernate will call the property get/set pair. If you specify <literal>access=\"field\"</literal>, Hibernate will bypass the get/set pair and access the field directly using reflection. You can specify your own strategy for property access by naming a class that implements the interface <literal>org.hibernate.property.PropertyAccessor</literal>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1463
 #, no-c-format
 msgid "A powerful feature is derived properties. These properties are by definition read-only. The property value is computed at load time. You declare the computation as an SQL expression. This then translates to a <literal>SELECT</literal> clause subquery in the SQL query that loads an instance:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1470
-#, no-c-format
-msgid ""
-      "<![CDATA[\n"
-      "<property name=\"totalPrice\"\n"
-      "    formula=\"( SELECT SUM (li.quantity*p.price) FROM LineItem li, Product p\n"
-      "                WHERE li.productId = p.productId\n"
-      "                AND li.customerId = customerId\n"
-      "                AND li.orderNumber = orderNumber )\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1472
 #, no-c-format
 msgid "You can reference the entity table by not declaring an alias on a particular column. This would be <literal>customerId</literal> in the given example. You can also use the nested <literal>&lt;formula&gt;</literal> mapping element if you do not want to use the attribute."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:1482
 #, no-c-format
 msgid "Many-to-one"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1484
 #, no-c-format
 msgid "An ordinary association to another persistent class is declared using a <literal>many-to-one</literal> element. The relational model is a many-to-one association; a foreign key in one table is referencing the primary key column(s) of the target table."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1512
-#, no-c-format
-msgid ""
-      "<![CDATA[<many-to-one\n"
-      "        name=\"propertyName\"\n"
-      "        column=\"column_name\"\n"
-      "        class=\"ClassName\"\n"
-      "        cascade=\"cascade_style\"\n"
-      "        fetch=\"join|select\"\n"
-      "        update=\"true|false\"\n"
-      "        insert=\"true|false\"\n"
-      "        property-ref=\"propertyNameFromAssociatedClass\"\n"
-      "        access=\"field|property|ClassName\"\n"
-      "        unique=\"true|false\"\n"
-      "        not-null=\"true|false\"\n"
-      "        optimistic-lock=\"true|false\"\n"
-      "        lazy=\"proxy|no-proxy|false\"\n"
-      "        not-found=\"ignore|exception\"\n"
-      "        entity-name=\"EntityName\"\n"
-      "        formula=\"arbitrary SQL expression\"\n"
-      "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-      "        embed-xml=\"true|false\"\n"
-      "        index=\"index_name\"\n"
-      "        unique_key=\"unique_key_id\"\n"
-      "        foreign-key=\"foreign_key_name\"\n"
-      "/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1515 basic_mapping.xml:1696 basic_mapping.xml:1882
 #, no-c-format
 msgid "<literal>name</literal>: the name of the property."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1520 basic_mapping.xml:2311
 #, no-c-format
 msgid "<literal>column</literal> (optional): the name of the foreign key column. This can also be specified by nested <literal>&lt;column&gt;</literal> element(s)."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1527 basic_mapping.xml:1701
 #, no-c-format
 msgid "<literal>class</literal> (optional - defaults to the property type determined by reflection): the name of the associated class."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1533 basic_mapping.xml:1707
 #, no-c-format
 msgid "<literal>cascade</literal> (optional): specifies which operations should be cascaded from the parent object to the associated object."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1539 basic_mapping.xml:1722
 #, no-c-format
 msgid "<literal>fetch</literal> (optional - defaults to <literal>select</literal>): chooses between outer-join fetching or sequential select fetching."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1545
 #, no-c-format
 msgid "<literal>update, insert</literal> (optional - defaults to <literal>true</literal>): specifies that the mapped columns should be included in SQL <literal>UPDATE</literal> and/or <literal>INSERT</literal> statements. Setting both to <literal>false</literal> allows a pure \"derived\" association whose value is initialized from another property that maps to the same column(s), or by a trigger or other application."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1554
 #, no-c-format
 msgid "<literal>property-ref</literal> (optional): the name of a property of the associated class that is joined to this foreign key. If not specified, the primary key of the associated class is used."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1567
 #, no-c-format
 msgid "<literal>unique</literal> (optional): enables the DDL generation of a unique constraint for the foreign-key column. By allowing this to be the target of a <literal>property-ref</literal>, you can make the association multiplicity one-to-one."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1575
 #, no-c-format
 msgid "<literal>not-null</literal> (optional): enables the DDL generation of a nullability constraint for the foreign key columns."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1589
 #, no-c-format
 msgid "<literal>lazy</literal> (optional - defaults to <literal>proxy</literal>): by default, single point associations are proxied. <literal>lazy=\"no-proxy\"</literal> specifies that the property should be fetched lazily when the instance variable is first accessed. This requires build-time bytecode instrumentation. <literal>lazy=\"false\"</literal> specifies that the association will always be eagerly fetched."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1599
 #, no-c-format
 msgid "<literal>not-found</literal> (optional - defaults to <literal>exception</literal>): specifies how foreign keys that reference missing rows will be handled. <literal>ignore</literal> will treat a missing row as a null association."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1606 basic_mapping.xml:1760
 #, no-c-format
 msgid "<literal>entity-name</literal> (optional): the entity name of the associated class."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1611
 #, no-c-format
 msgid "<literal>formula</literal> (optional): an SQL expression that defines the value for a <emphasis>computed</emphasis> foreign key."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1619
 #, no-c-format
-msgid "Setting a value of the <literal>cascade</literal> attribute to any meaningful value other than <literal>none</literal> will propagate certain operations to the associated object. The meaningful values are divided into three categories. First, basic operations, which include: <literal>persist, merge, delete, save-update, evict, replicate, lock and refresh</literal>; second, special values: <literal>delete-orphan</literal>; and third,<literal>all</literal> comma-separated combinations of operation names: <literal>cascade=\"persist,merge,evict\"</literal> or <literal>cascade=\"all,delete-orphan\"</literal>. See <xref linkend=\"objectstate-transitive\"/> for a full explanation. Note that single valued, many-to-one and one-to-one, associations do not support orphan delete."
+msgid "Setting a value of the <literal>cascade</literal> attribute to any meaningful value other than <literal>none</literal> will propagate certain operations to the associated object. The meaningful values are divided into three categories. First, basic operations, which include: <literal>persist, merge, delete, save-update, evict, replicate, lock and refresh</literal>; second, special values: <literal>delete-orphan</literal>; and third,<literal>all</literal> comma-separated combinations of operation names: <literal>cascade=\"persist,merge,evict\"</literal> or <literal>cascade=\"all,delete-orphan\"</literal>. See <xref linkend=\"objectstate-transitive\" /> for a full explanation. Note that single valued, many-to-one and one-to-one, associations do not support orphan delete."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1632
 #, no-c-format
 msgid "Here is an example of a typical <literal>many-to-one</literal> declaration:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1636
-#, no-c-format
-msgid "<![CDATA[<many-to-one name=\"product\" class=\"Product\" column=\"PRODUCT_ID\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1638
 #, no-c-format
 msgid "The <literal>property-ref</literal> attribute should only be used for mapping legacy data where a foreign key refers to a unique key of the associated table other than the primary key. This is a complicated and confusing relational model. For example, if the <literal>Product</literal> class had a unique serial number that is not the primary key. The <literal>unique</literal> attribute controls Hibernate's DDL generation with the SchemaExport tool."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1647
-#, no-c-format
-msgid "<![CDATA[<property name=\"serialNumber\" unique=\"true\" type=\"string\" column=\"SERIAL_NUMBER\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1649
 #, no-c-format
 msgid "Then the mapping for <literal>OrderItem</literal> might use:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1653
-#, no-c-format
-msgid "<![CDATA[<many-to-one name=\"product\" property-ref=\"serialNumber\" column=\"PRODUCT_SERIAL_NUMBER\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1655
 #, no-c-format
 msgid "This is not encouraged, however."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1659
 #, no-c-format
 msgid "If the referenced unique key comprises multiple properties of the associated entity, you should map the referenced properties inside a named <literal>&lt;properties&gt;</literal> element."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1664
 #, no-c-format
 msgid "If the referenced unique key is the property of a component, you can specify a property path:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1668
-#, no-c-format
-msgid "<![CDATA[<many-to-one name=\"owner\" property-ref=\"identity.ssn\" column=\"OWNER_SSN\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:1673
 #, no-c-format
 msgid "One-to-one"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1675
 #, no-c-format
 msgid "A one-to-one association to another persistent class is declared using a <literal>one-to-one</literal> element."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1693
-#, no-c-format
-msgid ""
-      "<![CDATA[<one-to-one\n"
-      "        name=\"propertyName\"\n"
-      "        class=\"ClassName\"\n"
-      "        cascade=\"cascade_style\"\n"
-      "        constrained=\"true|false\"\n"
-      "        fetch=\"join|select\"\n"
-      "        property-ref=\"propertyNameFromAssociatedClass\"\n"
-      "        access=\"field|property|ClassName\"\n"
-      "        formula=\"any SQL expression\"\n"
-      "        lazy=\"proxy|no-proxy|false\"\n"
-      "        entity-name=\"EntityName\"\n"
-      "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-      "        embed-xml=\"true|false\"\n"
-      "        foreign-key=\"foreign_key_name\"\n"
-      "/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1713
 #, no-c-format
 msgid "<literal>constrained</literal> (optional): specifies that a foreign key constraint on the primary key of the mapped table and references the table of the associated class. This option affects the order in which <literal>save()</literal> and <literal>delete()</literal> are cascaded, and determines whether the association can be proxied. It is also used by the schema export tool."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1728
 #, no-c-format
 msgid "<literal>property-ref</literal> (optional): the name of a property of the associated class that is joined to the primary key of this class. If not specified, the primary key of the associated class is used."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1741
 #, no-c-format
 msgid "<literal>formula</literal> (optional): almost all one-to-one associations map to the primary key of the owning entity. If this is not the case, you can specify another column, columns or expression to join on using an SQL formula. See <literal>org.hibernate.test.onetooneformula</literal> for an example."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1749
 #, no-c-format
 msgid "<literal>lazy</literal> (optional - defaults to <literal>proxy</literal>): by default, single point associations are proxied. <literal>lazy=\"no-proxy\"</literal> specifies that the property should be fetched lazily when the instance variable is first accessed. It requires build-time bytecode instrumentation. <literal>lazy=\"false\"</literal> specifies that the association will always be eagerly fetched. <emphasis>Note that if <literal>constrained=\"false\"</literal>, proxying is impossible and Hibernate will eagerly fetch the association</emphasis>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1767
 #, no-c-format
 msgid "There are two varieties of one-to-one associations:"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1771
 #, no-c-format
 msgid "primary key associations"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1774
 #, no-c-format
 msgid "unique foreign key associations"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1779
 #, no-c-format
 msgid "Primary key associations do not need an extra table column. If two rows are related by the association, then the two table rows share the same primary key value. To relate two objects by a primary key association, ensure that they are assigned the same identifier value."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1786
 #, no-c-format
 msgid "For a primary key association, add the following mappings to <literal>Employee</literal> and <literal>Person</literal> respectively:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1791
-#, no-c-format
-msgid "<![CDATA[<one-to-one name=\"person\" class=\"Person\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:1792
-#, no-c-format
-msgid "<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" constrained=\"true\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1794
 #, no-c-format
 msgid "Ensure that the primary keys of the related rows in the PERSON and EMPLOYEE tables are equal. You use a special Hibernate identifier generation strategy called <literal>foreign</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1800
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"person\" table=\"PERSON\">\n"
-      "    <id name=\"id\" column=\"PERSON_ID\">\n"
-      "        <generator class=\"foreign\">\n"
-      "            <param name=\"property\">employee</param>\n"
-      "        </generator>\n"
-      "    </id>\n"
-      "    ...\n"
-      "    <one-to-one name=\"employee\"\n"
-      "        class=\"Employee\"\n"
-      "        constrained=\"true\"/>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1802
 #, no-c-format
 msgid "A newly saved instance of <literal>Person</literal> is assigned the same primary key value as the <literal>Employee</literal> instance referred with the <literal>employee</literal> property of that <literal>Person</literal>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1808
 #, no-c-format
 msgid "Alternatively, a foreign key with a unique constraint, from <literal>Employee</literal> to <literal>Person</literal>, can be expressed as:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1813
-#, no-c-format
-msgid "<![CDATA[<many-to-one name=\"person\" class=\"Person\" column=\"PERSON_ID\" unique=\"true\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1815
 #, no-c-format
 msgid "This association can be made bidirectional by adding the following to the <literal>Person</literal> mapping:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1820
-#, no-c-format
-msgid "<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" property-ref=\"person\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:1825
 #, no-c-format
 msgid "Natural-id"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1827
-#, no-c-format
-msgid ""
-      "<![CDATA[<natural-id mutable=\"true|false\"/>\n"
-      "        <property ... />\n"
-      "        <many-to-one ... />\n"
-      "        ......\n"
-      "</natural-id>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1829
 #, no-c-format
 msgid "Although we recommend the use of surrogate keys as primary keys, you should try to identify natural keys for all entities. A natural key is a property or combination of properties that is unique and non-null. It is also immutable. Map the properties of the natural key inside the <literal>&lt;natural-id&gt;</literal> element. Hibernate will generate the necessary unique key and nullability constraints and, as a result, your mapping will be more self-documenting."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1838
 #, no-c-format
 msgid "It is recommended that you implement <literal>equals()</literal> and <literal>hashCode()</literal> to compare the natural key properties of the entity."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1843
 #, no-c-format
 msgid "This mapping is not intended for use with entities that have natural primary keys."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1849
 #, no-c-format
 msgid "<literal>mutable</literal> (optional - defaults to <literal>false</literal>): by default, natural identifier properties are assumed to be immutable (constant)."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:1859
 #, no-c-format
 msgid "Component and dynamic-component"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1861
 #, no-c-format
 msgid "The <literal>&lt;component&gt;</literal> element maps properties of a child object to columns of the table of a parent class. Components can, in turn, declare their own properties, components or collections. See the \"Component\" examples below:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1879
-#, no-c-format
-msgid ""
-      "<![CDATA[<component\n"
-      "        name=\"propertyName\"\n"
-      "        class=\"className\"\n"
-      "        insert=\"true|false\"\n"
-      "        update=\"true|false\"\n"
-      "        access=\"field|property|ClassName\"\n"
-      "        lazy=\"true|false\"\n"
-      "        optimistic-lock=\"true|false\"\n"
-      "        unique=\"true|false\"\n"
-      "        node=\"element-name|.\"\n"
-      ">\n"
-      "\n"
-      "        <property ...../>\n"
-      "        <many-to-one .... />\n"
-      "        ........\n"
-      "</component>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1887
 #, no-c-format
 msgid "<literal>class</literal> (optional - defaults to the property type determined by reflection): the name of the component (child) class."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1893 basic_mapping.xml:1982
 #, no-c-format
 msgid "<literal>insert</literal>: do the mapped columns appear in SQL <literal>INSERTs</literal>?"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1899 basic_mapping.xml:1988
 #, no-c-format
 msgid "<literal>update</literal>: do the mapped columns appear in SQL <literal>UPDATEs</literal>?"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1911
 #, no-c-format
 msgid "<literal>lazy</literal> (optional - defaults to <literal>false</literal>): specifies that this component should be fetched lazily when the instance variable is first accessed. It requires build-time bytecode instrumentation."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1918
 #, no-c-format
 msgid "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</literal>): specifies that updates to this component either do or do not require acquisition of the optimistic lock. It determines if a version increment should occur when this property is dirty."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1926 basic_mapping.xml:2002
 #, no-c-format
 msgid "<literal>unique</literal> (optional - defaults to <literal>false</literal>): specifies that a unique constraint exists upon all mapped columns of the component."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1935
 #, no-c-format
 msgid "The child <literal>&lt;property&gt;</literal> tags map properties of the child class to table columns."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1940
 #, no-c-format
 msgid "The <literal>&lt;component&gt;</literal> element allows a <literal>&lt;parent&gt;</literal> subelement that maps a property of the component class as a reference back to the containing entity."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1946
 #, no-c-format
-msgid "The <literal>&lt;dynamic-component&gt;</literal> element allows a <literal>Map</literal> to be mapped as a component, where the property names refer to keys of the map. See <xref linkend=\"components-dynamic\"/> for more information."
+msgid "The <literal>&lt;dynamic-component&gt;</literal> element allows a <literal>Map</literal> to be mapped as a component, where the property names refer to keys of the map. See <xref linkend=\"components-dynamic\" /> for more information."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:1955
 #, no-c-format
 msgid "Properties"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1957
 #, no-c-format
 msgid "The <literal>&lt;properties&gt;</literal> element allows the definition of a named, logical grouping of the properties of a class. The most important use of the construct is that it allows a combination of properties to be the target of a <literal>property-ref</literal>. It is also a convenient way to define a multi-column unique constraint. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:1973
-#, no-c-format
-msgid ""
-      "<![CDATA[<properties\n"
-      "        name=\"logicalName\"\n"
-      "        insert=\"true|false\"\n"
-      "        update=\"true|false\"\n"
-      "        optimistic-lock=\"true|false\"\n"
-      "        unique=\"true|false\"\n"
-      ">\n"
-      "\n"
-      "        <property ...../>\n"
-      "        <many-to-one .... />\n"
-      "        ........\n"
-      "</properties>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1976
 #, no-c-format
 msgid "<literal>name</literal>: the logical name of the grouping. It is <emphasis>not</emphasis> an actual property name."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:1994
 #, no-c-format
 msgid "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</literal>): specifies that updates to these properties either do or do not require acquisition of the optimistic lock. It determines if a version increment should occur when these properties are dirty."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2011
 #, no-c-format
 msgid "For example, if we have the following <literal>&lt;properties&gt;</literal> mapping:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2015
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"personNumber\"/>\n"
-      "\n"
-      "    ...\n"
-      "    <properties name=\"name\"\n"
-      "            unique=\"true\" update=\"false\">\n"
-      "        <property name=\"firstName\"/>\n"
-      "        <property name=\"initial\"/>\n"
-      "        <property name=\"lastName\"/>\n"
-      "    </properties>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2017
 #, no-c-format
 msgid "You might have some legacy data association that refers to this unique key of the <literal>Person</literal> table, instead of to the primary key:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2022
-#, no-c-format
-msgid ""
-      "<![CDATA[<many-to-one name=\"person\"\n"
-      "         class=\"Person\" property-ref=\"name\">\n"
-      "    <column name=\"firstName\"/>\n"
-      "    <column name=\"initial\"/>\n"
-      "    <column name=\"lastName\"/>\n"
-      "</many-to-one>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2024
 #, no-c-format
 msgid "The use of this outside the context of mapping legacy data is not recommended."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2032
 #, no-c-format
 msgid "Subclass"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2034
 #, no-c-format
 msgid "Polymorphic persistence requires the declaration of each subclass of the root persistent class. For the table-per-class-hierarchy mapping strategy, the <literal>&lt;subclass&gt;</literal> declaration is used. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2047
-#, no-c-format
-msgid ""
-      "<![CDATA[<subclass\n"
-      "        name=\"ClassName\"\n"
-      "        discriminator-value=\"discriminator_value\"\n"
-      "        proxy=\"ProxyInterface\"\n"
-      "        lazy=\"true|false\"\n"
-      "        dynamic-update=\"true|false\"\n"
-      "        dynamic-insert=\"true|false\"\n"
-      "        entity-name=\"EntityName\"\n"
-      "        node=\"element-name\"\n"
-      "        extends=\"SuperclassName\">\n"
-      "\n"
-      "        <property .... />\n"
-      "        .....\n"
-      "</subclass>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2050 basic_mapping.xml:2108 basic_mapping.xml:2171
 #, no-c-format
 msgid "<literal>name</literal>: the fully qualified class name of the subclass."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2055
 #, no-c-format
 msgid "<literal>discriminator-value</literal> (optional - defaults to the class name): a value that distinguishes individual subclasses."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2061
 #, no-c-format
 msgid "<literal>proxy</literal> (optional): specifies a class or interface used for lazy initializing proxies."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2067
 #, no-c-format
 msgid "<literal>lazy</literal> (optional - defaults to <literal>true</literal>): setting <literal>lazy=\"false\"</literal> disables the use of lazy fetching."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2075
 #, no-c-format
 msgid "Each subclass declares its own persistent properties and subclasses. <literal>&lt;version&gt;</literal> and <literal>&lt;id&gt;</literal> properties are assumed to be inherited from the root class. Each subclass in a hierarchy must define a unique <literal>discriminator-value</literal>. If this is not specified, the fully qualified Java class name is used."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2083 basic_mapping.xml:2141 basic_mapping.xml:2199
 #, no-c-format
-msgid "For information about inheritance mappings see <xref linkend=\"inheritance\"/>."
+msgid "For information about inheritance mappings see <xref linkend=\"inheritance\" />."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2090
 #, no-c-format
 msgid "Joined-subclass"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2092
 #, no-c-format
 msgid "Each subclass can also be mapped to its own table. This is called the table-per-subclass mapping strategy. An inherited state is retrieved by joining with the table of the superclass. To do this you use the <literal>&lt;joined-subclass&gt;</literal> element. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2105
-#, no-c-format
-msgid ""
-      "<![CDATA[<joined-subclass\n"
-      "        name=\"ClassName\"\n"
-      "        table=\"tablename\"\n"
-      "        proxy=\"ProxyInterface\"\n"
-      "        lazy=\"true|false\"\n"
-      "        dynamic-update=\"true|false\"\n"
-      "        dynamic-insert=\"true|false\"\n"
-      "        schema=\"schema\"\n"
-      "        catalog=\"catalog\"\n"
-      "        extends=\"SuperclassName\"\n"
-      "        persister=\"ClassName\"\n"
-      "        subselect=\"SQL expression\"\n"
-      "        entity-name=\"EntityName\"\n"
-      "        node=\"element-name\">\n"
-      "\n"
-      "        <key .... >\n"
-      "\n"
-      "        <property .... />\n"
-      "        .....\n"
-      "</joined-subclass>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2113 basic_mapping.xml:2176
 #, no-c-format
 msgid "<literal>table</literal>: the name of the subclass table."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2118 basic_mapping.xml:2181
 #, no-c-format
 msgid "<literal>proxy</literal> (optional): specifies a class or interface to use for lazy initializing proxies."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2124 basic_mapping.xml:2187
 #, no-c-format
 msgid "<literal>lazy</literal> (optional, defaults to <literal>true</literal>): setting <literal>lazy=\"false\"</literal> disables the use of lazy fetching."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2132
 #, no-c-format
 msgid "A discriminator column is not required for this mapping strategy. Each subclass must, however, declare a table column holding the object identifier using the <literal>&lt;key&gt;</literal> element. The mapping at the start of the chapter would then be re-written as:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2139
-#, no-c-format
-msgid ""
-      "<![CDATA[<?xml version=\"1.0\"?>\n"
-      "<!DOCTYPE hibernate-mapping PUBLIC\n"
-      "        \"-//Hibernate/Hibernate Mapping DTD//EN\"\n"
-      "        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-      "\n"
-      "<hibernate-mapping package=\"eg\">\n"
-      "\n"
-      "        <class name=\"Cat\" table=\"CATS\">\n"
-      "                <id name=\"id\" column=\"uid\" type=\"long\">\n"
-      "                        <generator class=\"hilo\"/>\n"
-      "                </id>\n"
-      "                <property name=\"birthdate\" type=\"date\"/>\n"
-      "                <property name=\"color\" not-null=\"true\"/>\n"
-      "                <property name=\"sex\" not-null=\"true\"/>\n"
-      "                <property name=\"weight\"/>\n"
-      "                <many-to-one name=\"mate\"/>\n"
-      "                <set name=\"kittens\">\n"
-      "                        <key column=\"MOTHER\"/>\n"
-      "                        <one-to-many class=\"Cat\"/>\n"
-      "                </set>\n"
-      "                <joined-subclass name=\"DomesticCat\" table=\"DOMESTIC_CATS\">\n"
-      "                    <key column=\"CAT\"/>\n"
-      "                    <property name=\"name\" type=\"string\"/>\n"
-      "                </joined-subclass>\n"
-      "        </class>\n"
-      "\n"
-      "        <class name=\"eg.Dog\">\n"
-      "                <!-- mapping for Dog could go here -->\n"
-      "        </class>\n"
-      "\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:2148
 #, no-c-format
 msgid "Union-subclass"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2150
 #, no-c-format
 msgid "A third option is to map only the concrete classes of an inheritance hierarchy to tables. This is called the table-per-concrete-class strategy. Each table defines all persistent states of the class, including the inherited state. In Hibernate, it is not necessary to explicitly map such inheritance hierarchies. You can map each class with a separate <literal>&lt;class&gt;</literal> declaration. However, if you wish use polymorphic associations (e.g. an association to the superclass of your hierarchy), you need to use the <literal>&lt;union-subclass&gt;</literal> mapping. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2168
-#, no-c-format
-msgid ""
-      "<![CDATA[<union-subclass\n"
-      "        name=\"ClassName\"\n"
-      "        table=\"tablename\"\n"
-      "        proxy=\"ProxyInterface\"\n"
-      "        lazy=\"true|false\"\n"
-      "        dynamic-update=\"true|false\"\n"
-      "        dynamic-insert=\"true|false\"\n"
-      "        schema=\"schema\"\n"
-      "        catalog=\"catalog\"\n"
-      "        extends=\"SuperclassName\"\n"
-      "        abstract=\"true|false\"\n"
-      "        persister=\"ClassName\"\n"
-      "        subselect=\"SQL expression\"\n"
-      "        entity-name=\"EntityName\"\n"
-      "        node=\"element-name\">\n"
-      "\n"
-      "        <property .... />\n"
-      "        .....\n"
-      "</union-subclass>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2195
 #, no-c-format
 msgid "No discriminator column or key column is required for this mapping strategy."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2206
 #, no-c-format
 msgid "Join"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2208
 #, no-c-format
 msgid "Using the <literal>&lt;join&gt;</literal> element, it is possible to map properties of one class to several tables that have a one-to-one relationship. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2222
-#, no-c-format
-msgid ""
-      "<![CDATA[<join\n"
-      "        table=\"tablename\"\n"
-      "        schema=\"owner\"\n"
-      "        catalog=\"catalog\"\n"
-      "        fetch=\"join|select\"\n"
-      "        inverse=\"true|false\"\n"
-      "        optional=\"true|false\">\n"
-      "\n"
-      "        <key ... />\n"
-      "\n"
-      "        <property ... />\n"
-      "        ...\n"
-      "</join>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2226
 #, no-c-format
 msgid "<literal>table</literal>: the name of the joined table."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2243
 #, no-c-format
 msgid "<literal>fetch</literal> (optional - defaults to <literal>join</literal>): if set to <literal>join</literal>, the default, Hibernate will use an inner join to retrieve a <literal>&lt;join&gt;</literal> defined by a class or its superclasses. It will use an outer join for a <literal>&lt;join&gt;</literal> defined by a subclass. If set to <literal>select</literal> then Hibernate will use a sequential select for a <literal>&lt;join&gt;</literal> defined on a subclass. This will be issued only if a row represents an instance of the subclass. Inner joins will still be used to retrieve a <literal>&lt;join&gt;</literal> defined by the class and its superclasses."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2256
 #, no-c-format
 msgid "<literal>inverse</literal> (optional - defaults to <literal>false</literal>): if enabled, Hibernate will not insert or update the properties defined by this join."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2263
 #, no-c-format
 msgid "<literal>optional</literal> (optional - defaults to <literal>false</literal>): if enabled, Hibernate will insert a row only if the properties defined by this join are non-null. It will always use an outer join to retrieve the properties."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2272
 #, no-c-format
 msgid "For example, address information for a person can be mapped to a separate table while preserving value type semantics for all properties:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2277
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\"\n"
-      "    table=\"PERSON\">\n"
-      "\n"
-      "    <id name=\"id\" column=\"PERSON_ID\">...</id>\n"
-      "\n"
-      "    <join table=\"ADDRESS\">\n"
-      "        <key column=\"ADDRESS_ID\"/>\n"
-      "        <property name=\"address\"/>\n"
-      "        <property name=\"zip\"/>\n"
-      "        <property name=\"country\"/>\n"
-      "    </join>\n"
-      "    ...]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2279
 #, no-c-format
 msgid "This feature is often only useful for legacy data models. We recommend fewer tables than classes and a fine-grained domain model. However, it is useful for switching between inheritance mapping strategies in a single hierarchy, as explained later."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2289
 #, no-c-format
-msgid "<title>Key</title>"
+msgid "Key"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2291
 #, no-c-format
 msgid "The <literal>&lt;key&gt;</literal> element has featured a few times within this guide. It appears anywhere the parent mapping element defines a join to a new table that references the primary key of the original table. It also defines the foreign key in the joined table:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2307
-#, no-c-format
-msgid ""
-      "<![CDATA[<key\n"
-      "        column=\"columnname\"\n"
-      "        on-delete=\"noaction|cascade\"\n"
-      "        property-ref=\"propertyName\"\n"
-      "        not-null=\"true|false\"\n"
-      "        update=\"true|false\"\n"
-      "        unique=\"true|false\"\n"
-      "/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2318
 #, no-c-format
 msgid "<literal>on-delete</literal> (optional - defaults to <literal>noaction</literal>): specifies whether the foreign key constraint has database-level cascade delete enabled."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2325
 #, no-c-format
 msgid "<literal>property-ref</literal> (optional): specifies that the foreign key refers to columns that are not the primary key of the original table. It is provided for legacy data."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2332
 #, no-c-format
 msgid "<literal>not-null</literal> (optional): specifies that the foreign key columns are not nullable. This is implied whenever the foreign key is also part of the primary key."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2339
 #, no-c-format
 msgid "<literal>update</literal> (optional): specifies that the foreign key should never be updated. This is implied whenever the foreign key is also part of the primary key."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2346
 #, no-c-format
 msgid "<literal>unique</literal> (optional): specifies that the foreign key should have a unique constraint. This is implied whenever the foreign key is also the primary key."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2354
 #, no-c-format
 msgid "For systems where delete performance is important, we recommend that all keys should be defined <literal>on-delete=\"cascade\"</literal>. Hibernate uses a database-level <literal>ON CASCADE DELETE</literal> constraint, instead of many individual <literal>DELETE</literal> statements. Be aware that this feature bypasses Hibernate's usual optimistic locking strategy for versioned data."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2362
 #, no-c-format
 msgid "The <literal>not-null</literal> and <literal>update</literal> attributes are useful when mapping a unidirectional one-to-many association. If you map a unidirectional one-to-many association to a non-nullable foreign key, you <emphasis>must</emphasis> declare the key column using <literal>&lt;key not-null=\"true\"&gt;</literal>."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2372
 #, no-c-format
 msgid "Column and formula elements"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2373
 #, no-c-format
 msgid "Mapping elements which accept a <literal>column</literal> attribute will alternatively accept a <literal>&lt;column&gt;</literal> subelement. Likewise, <literal>&lt;formula&gt;</literal> is an alternative to the <literal>formula</literal> attribute. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2379
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[<column\n"
-      "        name=\"column_name\"\n"
-      "        length=\"N\"\n"
-      "        precision=\"N\"\n"
-      "        scale=\"N\"\n"
-      "        not-null=\"true|false\"\n"
-      "        unique=\"true|false\"\n"
-      "        unique-key=\"multicolumn_unique_key_name\"\n"
-      "        index=\"index_name\"\n"
-      "        sql-type=\"sql_type_name\"\n"
-      "        check=\"SQL expression\"\n"
-      "        default=\"SQL expression\"/>]]>"
+msgid "Most of the attributes on <literal>column</literal> provide a means of tailoring the DDL during automatic schema generation. The <literal>read</literal> and <literal>write</literal> attributes allow you to specify custom SQL that Hibernate will use to access the column's value. For more on this, see the discussion of <link linkend=\"mapping-column-read-and-write\">column read and write expressions</link>."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2381
-#, no-c-format
-msgid "<![CDATA[<formula>SQL expression</formula>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2383
 #, no-c-format
-msgid "<literal>column</literal> and <literal>formula</literal> attributes can even be combined within the same property or association mapping to express, for example, exotic join conditions."
+msgid "The <literal>column</literal> and <literal>formula</literal> elements can even be combined within the same property or association mapping to express, for example, exotic join conditions."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2389
-#, no-c-format
-msgid ""
-      "<![CDATA[<many-to-one name=\"homeAddress\" class=\"Address\"\n"
-      "        insert=\"false\" update=\"false\">\n"
-      "    <column name=\"person_id\" not-null=\"true\" length=\"10\"/>\n"
-      "    <formula>'MAILING'</formula>\n"
-      "</many-to-one>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:2394
 #, no-c-format
 msgid "Import"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2396
 #, no-c-format
 msgid "If your application has two persistent classes with the same name, and you do not want to specify the fully qualified package name in Hibernate queries, classes can be \"imported\" explicitly, rather than relying upon <literal>auto-import=\"true\"</literal>. You can also import classes and interfaces that are not explicitly mapped:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2403
-#, no-c-format
-msgid "<![CDATA[<import class=\"java.lang.Object\" rename=\"Universe\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2410
-#, no-c-format
-msgid ""
-      "<![CDATA[<import\n"
-      "        class=\"ClassName\"\n"
-      "        rename=\"ShortName\"\n"
-      "/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2413
 #, no-c-format
 msgid "<literal>class</literal>: the fully qualified class name of any Java class."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2418
 #, no-c-format
 msgid "<literal>rename</literal> (optional - defaults to the unqualified class name): a name that can be used in the query language."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2429
 #, no-c-format
-msgid "<title>Any</title>"
+msgid "Any"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2431
 #, no-c-format
 msgid "There is one more type of property mapping. The <literal>&lt;any&gt;</literal> mapping element defines a polymorphic association to classes from multiple tables. This type of mapping requires more than one column. The first column contains the type of the associated entity. The remaining columns contain the identifier. It is impossible to specify a foreign key constraint for this kind of association. This is not the usual way of mapping polymorphic associations and you should use this only in special cases. For example, for audit logs, user session data, etc."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2441
 #, no-c-format
 msgid "The <literal>meta-type</literal> attribute allows the application to specify a custom type that maps database column values to persistent classes that have identifier properties of the type specified by <literal>id-type</literal>. You must specify the mapping from values of the meta-type to class names."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2448
-#, no-c-format
-msgid ""
-      "<![CDATA[<any name=\"being\" id-type=\"long\" meta-type=\"string\">\n"
-      "    <meta-value value=\"TBL_ANIMAL\" class=\"Animal\"/>\n"
-      "    <meta-value value=\"TBL_HUMAN\" class=\"Human\"/>\n"
-      "    <meta-value value=\"TBL_ALIEN\" class=\"Alien\"/>\n"
-      "    <column name=\"table_name\"/>\n"
-      "    <column name=\"id\"/>\n"
-      "</any>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2459
-#, no-c-format
-msgid ""
-      "<![CDATA[<any\n"
-      "        name=\"propertyName\"\n"
-      "        id-type=\"idtypename\"\n"
-      "        meta-type=\"metatypename\"\n"
-      "        cascade=\"cascade_style\"\n"
-      "        access=\"field|property|ClassName\"\n"
-      "        optimistic-lock=\"true|false\"\n"
-      ">\n"
-      "        <meta-value ... />\n"
-      "        <meta-value ... />\n"
-      "        .....\n"
-      "        <column .... />\n"
-      "        <column .... />\n"
-      "        .....\n"
-      "</any>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2462
 #, no-c-format
 msgid "<literal>name</literal>: the property name."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2467
 #, no-c-format
 msgid "<literal>id-type</literal>: the identifier type."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2472
 #, no-c-format
 msgid "<literal>meta-type</literal> (optional - defaults to <literal>string</literal>): any type that is allowed for a discriminator mapping."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2478
 #, no-c-format
 msgid "<literal>cascade</literal> (optional- defaults to <literal>none</literal>): the cascade style."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2490
 #, no-c-format
 msgid "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</literal>): specifies that updates to this property either do or do not require acquisition of the optimistic lock. It defines whether a version increment should occur if this property is dirty."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2505
 #, no-c-format
 msgid "Hibernate types"
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2508
 #, no-c-format
 msgid "Entities and values"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2510
 #, no-c-format
 msgid "In relation to the persistence service, Java language-level objects are classified into two groups:"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2515
 #, no-c-format
 msgid "An <emphasis>entity</emphasis> exists independently of any other objects holding references to the entity. Contrast this with the usual Java model, where an unreferenced object is garbage collected. Entities must be explicitly saved and deleted. Saves and deletions, however, can be <emphasis>cascaded</emphasis> from a parent entity to its children. This is different from the ODMG model of object persistence by reachability and corresponds more closely to how application objects are usually used in large systems. Entities support circular and shared references. They can also be versioned."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2526
 #, no-c-format
 msgid "An entity's persistent state consists of references to other entities and instances of <emphasis>value</emphasis> types. Values are primitives: collections (not what is inside a collection), components and certain immutable objects. Unlike entities, values in particular collections and components, <emphasis>are</emphasis> persisted and deleted by reachability. Since value objects and primitives are persisted and deleted along with their containing entity, they cannot be independently versioned. Values have no independent identity, so they cannot be shared by two entities or collections."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2537
 #, no-c-format
 msgid "Until now, we have been using the term \"persistent class\" to refer to entities. We will continue to do that. Not all user-defined classes with a persistent state, however, are entities. A <emphasis>component</emphasis> is a user-defined class with value semantics. A Java property of type <literal>java.lang.String</literal> also has value semantics. Given this definition, all types (classes) provided by the JDK have value type semantics in Java, while user-defined types can be mapped with entity or value type semantics. This decision is up to the application developer. An entity class in a domain model will normally have shared references to a single instance of that class, while composition or aggregation usually translates to a value type."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2551
 #, no-c-format
 msgid "We will revisit both concepts throughout this reference guide."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2555
 #, no-c-format
 msgid "The challenge is to map the Java type system, and the developers' definition of entities and value types, to the SQL/database type system. The bridge between both systems is provided by Hibernate. For entities, <literal>&lt;class&gt;</literal>, <literal>&lt;subclass&gt;</literal> and so on are used. For value types we use <literal>&lt;property&gt;</literal>, <literal>&lt;component&gt;</literal>etc., that usually have a <literal>type</literal> attribute. The value of this attribute is the name of a Hibernate <emphasis>mapping type</emphasis>. Hibernate provides a range of mappings for standard JDK value types out of the box. You can write your own mapping types and implement your own custom conversion strategies."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2568
 #, no-c-format
 msgid "With the exception of collections, all built-in Hibernate types support null semantics."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2575
 #, no-c-format
 msgid "Basic value types"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2577
 #, no-c-format
 msgid "The built-in <emphasis>basic mapping types</emphasis> can be roughly categorized into the following:"
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:2582
+#. Tag: term
 #, no-c-format
-msgid "integer, long, short, float, double, character, byte, boolean, yes_no, true_false"
+msgid "<literal>integer, long, short, float, double, character, byte, boolean, yes_no, true_false</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2585
 #, no-c-format
 msgid "Type mappings from Java primitives or wrapper classes to appropriate (vendor-specific) SQL column types. <literal>boolean, yes_no</literal> and <literal>true_false</literal> are all alternative encodings for a Java <literal>boolean</literal> or <literal>java.lang.Boolean</literal>."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:2594
+#. Tag: term
 #, no-c-format
-msgid "string"
+msgid "<literal>string</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2596
 #, no-c-format
 msgid "A type mapping from <literal>java.lang.String</literal> to <literal>VARCHAR</literal> (or Oracle <literal>VARCHAR2</literal>)."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:2603
+#. Tag: term
 #, no-c-format
-msgid "date, time, timestamp"
+msgid "<literal>date, time, timestamp</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2605
 #, no-c-format
 msgid "Type mappings from <literal>java.util.Date</literal> and its subclasses to SQL types <literal>DATE</literal>, <literal>TIME</literal> and <literal>TIMESTAMP</literal> (or equivalent)."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:2613
+#. Tag: term
 #, no-c-format
-msgid "calendar, calendar_date"
+msgid "<literal>calendar, calendar_date</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2615
 #, no-c-format
 msgid "Type mappings from <literal>java.util.Calendar</literal> to SQL types <literal>TIMESTAMP</literal> and <literal>DATE</literal> (or equivalent)."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:2623
+#. Tag: term
 #, no-c-format
-msgid "big_decimal, big_integer"
+msgid "<literal>big_decimal, big_integer</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2625
 #, no-c-format
 msgid "Type mappings from <literal>java.math.BigDecimal</literal> and <literal>java.math.BigInteger</literal> to <literal>NUMERIC</literal> (or Oracle <literal>NUMBER</literal>)."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:2633
+#. Tag: term
 #, no-c-format
-msgid "locale, timezone, currency"
+msgid "<literal>locale, timezone, currency</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2635
 #, no-c-format
 msgid "Type mappings from <literal>java.util.Locale</literal>, <literal>java.util.TimeZone</literal> and <literal>java.util.Currency</literal> to <literal>VARCHAR</literal> (or Oracle <literal>VARCHAR2</literal>). Instances of <literal>Locale</literal> and <literal>Currency</literal> are mapped to their ISO codes. Instances of <literal>TimeZone</literal> are mapped to their <literal>ID</literal>."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:2647
+#. Tag: term
 #, no-c-format
-msgid "class"
+msgid "<literal>class</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2649
 #, no-c-format
 msgid "A type mapping from <literal>java.lang.Class</literal> to <literal>VARCHAR</literal> (or Oracle <literal>VARCHAR2</literal>). A <literal>Class</literal> is mapped to its fully qualified name."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:2657
+#. Tag: term
 #, no-c-format
-msgid "binary"
+msgid "<literal>binary</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2659
 #, no-c-format
 msgid "Maps byte arrays to an appropriate SQL binary type."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:2665
+#. Tag: term
 #, no-c-format
-msgid "text"
+msgid "<literal>text</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2667
 #, no-c-format
 msgid "Maps long Java strings to a SQL <literal>CLOB</literal> or <literal>TEXT</literal> type."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:2674
+#. Tag: term
 #, no-c-format
-msgid "serializable"
+msgid "<literal>serializable</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2676
 #, no-c-format
 msgid "Maps serializable Java types to an appropriate SQL binary type. You can also indicate the Hibernate type <literal>serializable</literal> with the name of a serializable Java class or interface that does not default to a basic type."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:2685
+#. Tag: term
 #, no-c-format
-msgid "clob, blob"
+msgid "<literal>clob, blob</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2687
 #, no-c-format
 msgid "Type mappings for the JDBC classes <literal>java.sql.Clob</literal> and <literal>java.sql.Blob</literal>. These types can be inconvenient for some applications, since the blob or clob object cannot be reused outside of a transaction. Driver support is patchy and inconsistent."
 msgstr ""
 
-#. Tag: literal
-#: basic_mapping.xml:2697
+#. Tag: term
 #, no-c-format
-msgid "imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, imm_serializable, imm_binary"
+msgid "<literal>imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, imm_serializable, imm_binary</literal>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2701
 #, no-c-format
 msgid "Type mappings for what are considered mutable Java types. This is where Hibernate makes certain optimizations appropriate only for immutable Java types, and the application treats the object as immutable. For example, you should not call <literal>Date.setTime()</literal> for an instance mapped as <literal>imm_timestamp</literal>. To change the value of the property, and have that change made persistent, the application must assign a new, nonidentical, object to the property."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2716
 #, no-c-format
 msgid "Unique identifiers of entities and collections can be of any basic type except <literal>binary</literal>, <literal>blob</literal> and <literal>clob</literal>. Composite identifiers are also allowed. See below for more information."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2722
 #, no-c-format
 msgid "The basic value types have corresponding <literal>Type</literal> constants defined on <literal>org.hibernate.Hibernate</literal>. For example, <literal>Hibernate.STRING</literal> represents the <literal>string</literal> type."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2731
 #, no-c-format
 msgid "Custom value types"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2733
 #, no-c-format
 msgid "It is relatively easy for developers to create their own value types. For example, you might want to persist properties of type <literal>java.lang.BigInteger</literal> to <literal>VARCHAR</literal> columns. Hibernate does not provide a built-in type for this. Custom types are not limited to mapping a property, or collection element, to a single table column. So, for example, you might have a Java property <literal>getName()</literal>/<literal>setName()</literal> of type <literal>java.lang.String</literal> that is persisted to the columns <literal>FIRST_NAME</literal>, <literal>INITIAL</literal>, <literal>SURNAME</literal>."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2744
 #, no-c-format
 msgid "To implement a custom type, implement either <literal>org.hibernate.UserType</literal> or <literal>org.hibernate.CompositeUserType</literal> and declare properties using the fully qualified classname of the type. View <literal>org.hibernate.test.DoubleStringType</literal> to see the kind of things that are possible."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2752
-#, no-c-format
-msgid ""
-      "<![CDATA[<property name=\"twoStrings\" type=\"org.hibernate.test.DoubleStringType\">\n"
-      "    <column name=\"first_string\"/>\n"
-      "    <column name=\"second_string\"/>\n"
-      "</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2754
 #, no-c-format
 msgid "Notice the use of <literal>&lt;column&gt;</literal> tags to map a property to multiple columns."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2759
 #, no-c-format
 msgid "The <literal>CompositeUserType</literal>, <literal>EnhancedUserType</literal>, <literal>UserCollectionType</literal>, and <literal>UserVersionType</literal> interfaces provide support for more specialized uses."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2765
 #, no-c-format
 msgid "You can even supply parameters to a <literal>UserType</literal> in the mapping file. To do this, your <literal>UserType</literal> must implement the <literal>org.hibernate.usertype.ParameterizedType</literal> interface. To supply parameters to your custom type, you can use the <literal>&lt;type&gt;</literal> element in your mapping files."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2773
-#, no-c-format
-msgid ""
-      "<![CDATA[<property name=\"priority\">\n"
-      "    <type name=\"com.mycompany.usertypes.DefaultValueIntegerType\">\n"
-      "        <param name=\"default\">0</param>\n"
-      "    </type>\n"
-      "</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2775
 #, no-c-format
 msgid "The <literal>UserType</literal> can now retrieve the value for the parameter named <literal>default</literal> from the <literal>Properties</literal> object passed to it."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2780
 #, no-c-format
 msgid "If you regularly use a certain <literal>UserType</literal>, it is useful to define a shorter name for it. You can do this using the <literal>&lt;typedef&gt;</literal> element. Typedefs assign a name to a custom type, and can also contain a list of default parameter values if the type is parameterized."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2787
-#, no-c-format
-msgid ""
-      "<![CDATA[<typedef class=\"com.mycompany.usertypes.DefaultValueIntegerType\" name=\"default_zero\">\n"
-      "    <param name=\"default\">0</param>\n"
-      "</typedef>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2789
-#, no-c-format
-msgid "<![CDATA[<property name=\"priority\" type=\"default_zero\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2791
 #, no-c-format
 msgid "It is also possible to override the parameters supplied in a typedef on a case-by-case basis by using type parameters on the property mapping."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2796
 #, no-c-format
 msgid "Even though Hibernate's rich range of built-in types and support for components means you will rarely need to use a custom type, it is considered good practice to use custom types for non-entity classes that occur frequently in your application. For example, a <literal>MonetaryAmount</literal> class is a good candidate for a <literal>CompositeUserType</literal>, even though it could be mapped as a component. One reason for this is abstraction. With a custom type, your mapping documents would be protected against changes to the way monetary values are represented."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2812
 #, no-c-format
 msgid "Mapping a class more than once"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2813
 #, no-c-format
 msgid "It is possible to provide more than one mapping for a particular persistent class. In this case, you must specify an <emphasis>entity name</emphasis> to disambiguate between instances of the two mapped entities. By default, the entity name is the same as the class name. Hibernate lets you specify the entity name when working with persistent objects, when writing queries, or when mapping associations to the named entity."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2821
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Contract\" table=\"Contracts\"\n"
-      "        entity-name=\"CurrentContract\">\n"
-      "    ...\n"
-      "    <set name=\"history\" inverse=\"true\"\n"
-      "            order-by=\"effectiveEndDate desc\">\n"
-      "        <key column=\"currentContractId\"/>\n"
-      "        <one-to-many entity-name=\"HistoricalContract\"/>\n"
-      "    </set>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Contract\" table=\"ContractHistory\"\n"
-      "        entity-name=\"HistoricalContract\">\n"
-      "    ...\n"
-      "    <many-to-one name=\"currentContract\"\n"
-      "            column=\"currentContractId\"\n"
-      "            entity-name=\"CurrentContract\"/>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2823
 #, no-c-format
 msgid "Associations are now specified using <literal>entity-name</literal> instead of <literal>class</literal>."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2831
 #, no-c-format
 msgid "SQL quoted identifiers"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2832
 #, no-c-format
 msgid "You can force Hibernate to quote an identifier in the generated SQL by enclosing the table or column name in backticks in the mapping document. Hibernate will use the correct quotation style for the SQL <literal>Dialect</literal>. This is usually double quotes, but the SQL Server uses brackets and MySQL uses backticks."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2839
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"LineItem\" table=\"`Line Item`\">\n"
-      "    <id name=\"id\" column=\"`Item Id`\"/><generator class=\"assigned\"/></id>\n"
-      "    <property name=\"itemNumber\" column=\"`Item #`\"/>\n"
-      "    ...\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:2845
 #, no-c-format
 msgid "Metadata alternatives"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2847
 #, no-c-format
 msgid "XML does not suit all users so there are some alternative ways to define O/R mapping metadata in Hibernate."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2852
 #, no-c-format
 msgid "Using XDoclet markup"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2854
 #, no-c-format
 msgid "Many Hibernate users prefer to embed mapping information directly in sourcecode using XDoclet <literal>@hibernate.tags</literal>. We do not cover this approach in this reference guide since it is considered part of XDoclet. However, we include the following example of the <literal>Cat</literal> class with XDoclet mappings:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2861
-#, no-c-format
-msgid ""
-      "<![CDATA[package eg;\n"
-      "import java.util.Set;\n"
-      "import java.util.Date;\n"
-      "\n"
-      "/**\n"
-      " * @hibernate.class\n"
-      " *  table=\"CATS\"\n"
-      " */\n"
-      "public class Cat {\n"
-      "    private Long id; // identifier\n"
-      "    private Date birthdate;\n"
-      "    private Cat mother;\n"
-      "    private Set kittens\n"
-      "    private Color color;\n"
-      "    private char sex;\n"
-      "    private float weight;\n"
-      "\n"
-      "    /*\n"
-      "     * @hibernate.id\n"
-      "     *  generator-class=\"native\"\n"
-      "     *  column=\"CAT_ID\"\n"
-      "     */\n"
-      "    public Long getId() {\n"
-      "        return id;\n"
-      "    }\n"
-      "    private void setId(Long id) {\n"
-      "        this.id=id;\n"
-      "    }\n"
-      "\n"
-      "    /**\n"
-      "     * @hibernate.many-to-one\n"
-      "     *  column=\"PARENT_ID\"\n"
-      "     */\n"
-      "    public Cat getMother() {\n"
-      "        return mother;\n"
-      "    }\n"
-      "    void setMother(Cat mother) {\n"
-      "        this.mother = mother;\n"
-      "    }\n"
-      "\n"
-      "    /**\n"
-      "     * @hibernate.property\n"
-      "     *  column=\"BIRTH_DATE\"\n"
-      "     */\n"
-      "    public Date getBirthdate() {\n"
-      "        return birthdate;\n"
-      "    }\n"
-      "    void setBirthdate(Date date) {\n"
-      "        birthdate = date;\n"
-      "    }\n"
-      "    /**\n"
-      "     * @hibernate.property\n"
-      "     *  column=\"WEIGHT\"\n"
-      "     */\n"
-      "    public float getWeight() {\n"
-      "        return weight;\n"
-      "    }\n"
-      "    void setWeight(float weight) {\n"
-      "        this.weight = weight;\n"
-      "    }\n"
-      "\n"
-      "    /**\n"
-      "     * @hibernate.property\n"
-      "     *  column=\"COLOR\"\n"
-      "     *  not-null=\"true\"\n"
-      "     */\n"
-      "    public Color getColor() {\n"
-      "        return color;\n"
-      "    }\n"
-      "    void setColor(Color color) {\n"
-      "        this.color = color;\n"
-      "    }\n"
-      "    /**\n"
-      "     * @hibernate.set\n"
-      "     *  inverse=\"true\"\n"
-      "     *  order-by=\"BIRTH_DATE\"\n"
-      "     * @hibernate.collection-key\n"
-      "     *  column=\"PARENT_ID\"\n"
-      "     * @hibernate.collection-one-to-many\n"
-      "     */\n"
-      "    public Set getKittens() {\n"
-      "        return kittens;\n"
-      "    }\n"
-      "    void setKittens(Set kittens) {\n"
-      "        this.kittens = kittens;\n"
-      "    }\n"
-      "    // addKitten not needed by Hibernate\n"
-      "    public void addKitten(Cat kitten) {\n"
-      "        kittens.add(kitten);\n"
-      "    }\n"
-      "\n"
-      "    /**\n"
-      "     * @hibernate.property\n"
-      "     *  column=\"SEX\"\n"
-      "     *  not-null=\"true\"\n"
-      "     *  update=\"false\"\n"
-      "     */\n"
-      "    public char getSex() {\n"
-      "        return sex;\n"
-      "    }\n"
-      "    void setSex(char sex) {\n"
-      "        this.sex=sex;\n"
-      "    }\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2863
 #, no-c-format
 msgid "See the Hibernate website for more examples of XDoclet and Hibernate."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2870
 #, no-c-format
 msgid "Using JDK 5.0 Annotations"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2872
 #, no-c-format
 msgid "JDK 5.0 introduced XDoclet-style annotations at the language level that are type-safe and checked at compile time. This mechanism is more powerful than XDoclet annotations and better supported by tools and IDEs. IntelliJ IDEA, for example, supports auto-completion and syntax highlighting of JDK 5.0 annotations. The new revision of the EJB specification (JSR-220) uses JDK 5.0 annotations as the primary metadata mechanism for entity beans. Hibernate3 implements the <literal>EntityManager</literal> of JSR-220 (the persistence API). Support for mapping metadata is available via the <emphasis>Hibernate Annotations</emphasis> package as a separate download. Both EJB3 (JSR-220) and Hibernate3 metadata is supported."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2883
 #, no-c-format
 msgid "This is an example of a POJO class annotated as an EJB entity bean:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2887
-#, no-c-format
-msgid ""
-      "<![CDATA[@Entity(access = AccessType.FIELD)\n"
-      "public class Customer implements Serializable {\n"
-      "\n"
-      "    @Id;\n"
-      "    Long id;\n"
-      "\n"
-      "    String firstName;\n"
-      "    String lastName;\n"
-      "    Date birthday;\n"
-      "\n"
-      "    @Transient\n"
-      "    Integer age;\n"
-      "\n"
-      "    @Embedded\n"
-      "    private Address homeAddress;\n"
-      "\n"
-      "    @OneToMany(cascade=CascadeType.ALL)\n"
-      "    @JoinColumn(name=\"CUSTOMER_ID\")\n"
-      "    Set<Order> orders;\n"
-      "\n"
-      "    // Getter/setter and business methods\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2891
 #, no-c-format
 msgid "Support for JDK 5.0 Annotations (and JSR-220) is currently under development. Please refer to the Hibernate Annotations module for more details."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2901
 #, no-c-format
 msgid "Generated properties"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2902
 #, no-c-format
 msgid "Generated properties are properties that have their values generated by the database. Typically, Hibernate applications needed to <literal>refresh</literal> objects that contain any properties for which the database was generating values. Marking properties as generated, however, lets the application delegate this responsibility to Hibernate. When Hibernate issues an SQL INSERT or UPDATE for an entity that has defined generated properties, it immediately issues a select afterwards to retrieve the generated values."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2911
 #, no-c-format
 msgid "Properties marked as generated must additionally be non-insertable and non-updateable. Only <link linkend=\"mapping-declaration-version\">versions</link>, <link linkend=\"mapping-declaration-timestamp\">timestamps</link>, and <link linkend=\"mapping-declaration-property\">simple properties</link>, can be marked as generated."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2918
 #, no-c-format
 msgid "<literal>never</literal> (the default): the given property value is not generated within the database."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2922
 #, no-c-format
 msgid "<literal>insert</literal>: the given property value is generated on insert, but is not regenerated on subsequent updates. Properties like created-date fall into this category. Even though <link linkend=\"mapping-declaration-version\">version</link> and <link linkend=\"mapping-declaration-timestamp\">timestamp</link> properties can be marked as generated, this option is not available."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2930
 #, no-c-format
 msgid "<literal>always</literal>: the property value is generated both on insert and on update."
 msgstr ""
 
 #. Tag: title
-#: basic_mapping.xml:2937
 #, no-c-format
-msgid "Auxiliary database objects"
+msgid "Column read and write expressions"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2938
 #, no-c-format
-msgid "Auxiliary database objects allow for the CREATE and DROP of arbitrary database objects. In conjunction with Hibernate's schema evolution tools, they have the ability to fully define a user schema within the Hibernate mapping files. Although designed specifically for creating and dropping things like triggers or stored procedures, any SQL command that can be run via a <literal>java.sql.Statement.execute()</literal> method is valid (for example, ALTERs, INSERTS, etc.). There are essentially two modes for defining auxiliary database objects:"
+msgid "Hibernate allows you to customize the SQL it uses to read and write the values of columns mapped to <link linkend=\"mapping-declaration-property\">simple properties</link>. For example, if your database provides a set of data encryption functions, you can invoke them for individual columns like this: <programlisting role=\"XML\">&lt;property name=\"creditCardNumber\"&gt; &lt;column name=\"credit_card_num\" read=\"decrypt(credit_card_num)\" write=\"encrypt(?)\"/&gt; &lt;/property&gt;</programlisting>"
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2947
 #, no-c-format
-msgid "The first mode is to explicitly list the CREATE and DROP commands in the mapping file:"
+msgid "Hibernate applies the custom expressions automatically whenever the property is referenced in a query. This functionality is similar to a derived-property <literal>formula</literal> with two differences:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2951
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping>\n"
-      "    ...\n"
-      "    <database-object>\n"
-      "        <create>CREATE TRIGGER my_trigger ...</create>\n"
-      "        <drop>DROP TRIGGER my_trigger</drop>\n"
-      "    </database-object>\n"
-      "</hibernate-mapping>]]>"
+msgid "The property is backed by one or more columns that are exported as part of automatic schema generation."
 msgstr ""
 
 #. Tag: para
-#: basic_mapping.xml:2952
 #, no-c-format
-msgid "The second mode is to supply a custom class that constructs the CREATE and DROP commands. This custom class must implement the <literal>org.hibernate.mapping.AuxiliaryDatabaseObject</literal> interface."
+msgid "The property is read-write, not read-only."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2957
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping>\n"
-      "    ...\n"
-      "    <database-object>\n"
-      "        <definition class=\"MyTriggerDefinition\"/>\n"
-      "    </database-object>\n"
-      "</hibernate-mapping>]]>"
+msgid "The <literal>write</literal> expression, if specified, must contain exactly one '?' placeholder for the value."
 msgstr ""
 
+#. Tag: title
+#, no-c-format
+msgid "Auxiliary database objects"
+msgstr ""
+
 #. Tag: para
-#: basic_mapping.xml:2958
 #, no-c-format
-msgid "Additionally, these database objects can be optionally scoped so that they only apply when certain dialects are used."
+msgid "Auxiliary database objects allow for the CREATE and DROP of arbitrary database objects. In conjunction with Hibernate's schema evolution tools, they have the ability to fully define a user schema within the Hibernate mapping files. Although designed specifically for creating and dropping things like triggers or stored procedures, any SQL command that can be run via a <literal>java.sql.Statement.execute()</literal> method is valid (for example, ALTERs, INSERTS, etc.). There are essentially two modes for defining auxiliary database objects:"
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2962
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping>\n"
-      "    ...\n"
-      "    <database-object>\n"
-      "        <definition class=\"MyTriggerDefinition\"/>\n"
-      "        <dialect-scope name=\"org.hibernate.dialect.Oracle9iDialect\"/>\n"
-      "        <dialect-scope name=\"org.hibernate.dialect.Oracle10gDialect\"/>\n"
-      "    </database-object>\n"
-      "</hibernate-mapping>]]>"
+msgid "The first mode is to explicitly list the CREATE and DROP commands in the mapping file:"
 msgstr ""
 
+#. Tag: para
+#, no-c-format
+msgid "The second mode is to supply a custom class that constructs the CREATE and DROP commands. This custom class must implement the <literal>org.hibernate.mapping.AuxiliaryDatabaseObject</literal> interface."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "Additionally, these database objects can be optionally scoped so that they only apply when certain dialects are used."
+msgstr ""
+

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/batch.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/batch.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/batch.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,379 +1,189 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: batch.xml:29
 #, no-c-format
 msgid "Batch processing"
 msgstr ""
 
 #. Tag: para
-#: batch.xml:31
 #, no-c-format
 msgid "A naive approach to inserting 100,000 rows in the database using Hibernate might look like this:"
 msgstr ""
 
-#. Tag: programlisting
-#: batch.xml:36
-#, no-c-format
-msgid ""
-      "<![CDATA[Session session = sessionFactory.openSession();\n"
-      "Transaction tx = session.beginTransaction();\n"
-      "for ( int i=0; i<100000; i++ ) {\n"
-      "    Customer customer = new Customer(.....);\n"
-      "    session.save(customer);\n"
-      "}\n"
-      "tx.commit();\n"
-      "session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:38
 #, no-c-format
 msgid "This would fall over with an <literal>OutOfMemoryException</literal> somewhere around the 50,000th row. That is because Hibernate caches all the newly inserted <literal>Customer</literal> instances in the session-level cache. In this chapter we will show you how to avoid this problem."
 msgstr ""
 
 #. Tag: para
-#: batch.xml:45
 #, no-c-format
 msgid "If you are undertaking batch processing you will need to enable the use of JDBC batching. This is absolutely essential if you want to achieve optimal performance. Set the JDBC batch size to a reasonable number (10-50, for example):"
 msgstr ""
 
-#. Tag: programlisting
-#: batch.xml:52
-#, no-c-format
-msgid "<![CDATA[hibernate.jdbc.batch_size 20]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:54
 #, no-c-format
 msgid "Hibernate disables insert batching at the JDBC level transparently if you use an <literal>identity</literal> identifier generator."
 msgstr ""
 
 #. Tag: para
-#: batch.xml:59
 #, no-c-format
 msgid "You can also do this kind of work in a process where interaction with the second-level cache is completely disabled:"
 msgstr ""
 
-#. Tag: programlisting
-#: batch.xml:64
-#, no-c-format
-msgid "<![CDATA[hibernate.cache.use_second_level_cache false]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:66
 #, no-c-format
 msgid "However, this is not absolutely necessary, since we can explicitly set the <literal>CacheMode</literal> to disable interaction with the second-level cache."
 msgstr ""
 
 #. Tag: title
-#: batch.xml:72
 #, no-c-format
 msgid "Batch inserts"
 msgstr ""
 
 #. Tag: para
-#: batch.xml:74
 #, no-c-format
 msgid "When making new objects persistent <literal>flush()</literal> and then <literal>clear()</literal> the session regularly in order to control the size of the first-level cache."
 msgstr ""
 
-#. Tag: programlisting
-#: batch.xml:80
-#, no-c-format
-msgid ""
-      "<![CDATA[Session session = sessionFactory.openSession();\n"
-      "Transaction tx = session.beginTransaction();\n"
-      "   \n"
-      "for ( int i=0; i<100000; i++ ) {\n"
-      "    Customer customer = new Customer(.....);\n"
-      "    session.save(customer);\n"
-      "    if ( i % 20 == 0 ) { //20, same as the JDBC batch size\n"
-      "        //flush a batch of inserts and release memory:\n"
-      "        session.flush();\n"
-      "        session.clear();\n"
-      "    }\n"
-      "}\n"
-      "   \n"
-      "tx.commit();\n"
-      "session.close();]]>"
-msgstr ""
-
 #. Tag: title
-#: batch.xml:85
 #, no-c-format
 msgid "Batch updates"
 msgstr ""
 
 #. Tag: para
-#: batch.xml:87
 #, no-c-format
 msgid "For retrieving and updating data, the same ideas apply. In addition, you need to use <literal>scroll()</literal> to take advantage of server-side cursors for queries that return many rows of data."
 msgstr ""
 
-#. Tag: programlisting
-#: batch.xml:93
-#, no-c-format
-msgid ""
-      "<![CDATA[Session session = sessionFactory.openSession();\n"
-      "Transaction tx = session.beginTransaction();\n"
-      "   \n"
-      "ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-      "    .setCacheMode(CacheMode.IGNORE)\n"
-      "    .scroll(ScrollMode.FORWARD_ONLY);\n"
-      "int count=0;\n"
-      "while ( customers.next() ) {\n"
-      "    Customer customer = (Customer) customers.get(0);\n"
-      "    customer.updateStuff(...);\n"
-      "    if ( ++count % 20 == 0 ) {\n"
-      "        //flush a batch of updates and release memory:\n"
-      "        session.flush();\n"
-      "        session.clear();\n"
-      "    }\n"
-      "}\n"
-      "   \n"
-      "tx.commit();\n"
-      "session.close();]]>"
-msgstr ""
-
 #. Tag: title
-#: batch.xml:98
 #, no-c-format
 msgid "The StatelessSession interface"
 msgstr ""
 
 #. Tag: para
-#: batch.xml:99
 #, no-c-format
 msgid "Alternatively, Hibernate provides a command-oriented API that can be used for streaming data to and from the database in the form of detached objects. A <literal>StatelessSession</literal> has no persistence context associated with it and does not provide many of the higher-level life cycle semantics. In particular, a stateless session does not implement a first-level cache nor interact with any second-level or query cache. It does not implement transactional write-behind or automatic dirty checking. Operations performed using a stateless session never cascade to associated instances. Collections are ignored by a stateless session. Operations performed via a stateless session bypass Hibernate's event model and interceptors. Due to the lack of a first-level cache, Stateless sessions are vulnerable to data aliasing effects. A stateless session is a lower-level abstraction that is much closer to the underlying JDBC."
 msgstr ""
 
-#. Tag: programlisting
-#: batch.xml:114
-#, no-c-format
-msgid ""
-      "<![CDATA[StatelessSession session = sessionFactory.openStatelessSession();\n"
-      "Transaction tx = session.beginTransaction();\n"
-      "   \n"
-      "ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-      "    .scroll(ScrollMode.FORWARD_ONLY);\n"
-      "while ( customers.next() ) {\n"
-      "    Customer customer = (Customer) customers.get(0);\n"
-      "    customer.updateStuff(...);\n"
-      "    session.update(customer);\n"
-      "}\n"
-      "   \n"
-      "tx.commit();\n"
-      "session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:116
 #, no-c-format
 msgid "In this code example, the <literal>Customer</literal> instances returned by the query are immediately detached. They are never associated with any persistence context."
 msgstr ""
 
 #. Tag: para
-#: batch.xml:122
 #, no-c-format
 msgid "The <literal>insert(), update()</literal> and <literal>delete()</literal> operations defined by the <literal>StatelessSession</literal> interface are considered to be direct database row-level operations. They result in the immediate execution of a SQL <literal>INSERT, UPDATE</literal> or <literal>DELETE</literal> respectively. They have different semantics to the <literal>save(), saveOrUpdate()</literal> and <literal>delete()</literal> operations defined by the <literal>Session</literal> interface."
 msgstr ""
 
 #. Tag: title
-#: batch.xml:135
 #, no-c-format
 msgid "DML-style operations"
 msgstr ""
 
 #. Tag: para
-#: batch.xml:137
 #, no-c-format
 msgid "As already discussed, automatic and transparent object/relational mapping is concerned with the management of the object state. The object state is available in memory. This means that manipulating data directly in the database (using the SQL <literal>Data Manipulation Language</literal> (DML) the statements: <literal>INSERT</literal>, <literal>UPDATE</literal>, <literal>DELETE</literal>) will not affect in-memory state. However, Hibernate provides methods for bulk SQL-style DML statement execution that is performed through the Hibernate Query Language (<link linkend=\"queryhql\">HQL</link>)."
 msgstr ""
 
 #. Tag: para
-#: batch.xml:146
 #, no-c-format
 msgid "The pseudo-syntax for <literal>UPDATE</literal> and <literal>DELETE</literal> statements is: <literal>( UPDATE | DELETE ) FROM? EntityName (WHERE where_conditions)?</literal>."
 msgstr ""
 
 #. Tag: para
-#: batch.xml:151
 #, no-c-format
 msgid "Some points to note:"
 msgstr ""
 
 #. Tag: para
-#: batch.xml:157
 #, no-c-format
 msgid "In the from-clause, the FROM keyword is optional"
 msgstr ""
 
 #. Tag: para
-#: batch.xml:162
 #, no-c-format
 msgid "There can only be a single entity named in the from-clause. It can, however, be aliased. If the entity name is aliased, then any property references must be qualified using that alias. If the entity name is not aliased, then it is illegal for any property references to be qualified."
 msgstr ""
 
 #. Tag: para
-#: batch.xml:170
 #, no-c-format
 msgid "No <link linkend=\"queryhql-joins-forms\">joins</link>, either implicit or explicit, can be specified in a bulk HQL query. Sub-queries can be used in the where-clause, where the subqueries themselves may contain joins."
 msgstr ""
 
 #. Tag: para
-#: batch.xml:177
 #, no-c-format
 msgid "The where-clause is also optional."
 msgstr ""
 
 #. Tag: para
-#: batch.xml:183
 #, no-c-format
 msgid "As an example, to execute an HQL <literal>UPDATE</literal>, use the <literal>Query.executeUpdate()</literal> method. The method is named for those familiar with JDBC's <literal>PreparedStatement.executeUpdate()</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: batch.xml:189
-#, no-c-format
-msgid ""
-      "<![CDATA[Session session = sessionFactory.openSession();\n"
-      "Transaction tx = session.beginTransaction();\n"
-      "\n"
-      "String hqlUpdate = \"update Customer c set c.name = :newName where c.name = :oldName\";\n"
-      "// or String hqlUpdate = \"update Customer set name = :newName where name = :oldName\";\n"
-      "int updatedEntities = s.createQuery( hqlUpdate )\n"
-      "        .setString( \"newName\", newName )\n"
-      "        .setString( \"oldName\", oldName )\n"
-      "        .executeUpdate();\n"
-      "tx.commit();\n"
-      "session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:191
 #, no-c-format
 msgid "In keeping with the EJB3 specification, HQL <literal>UPDATE</literal> statements, by default, do not effect the <link linkend=\"mapping-declaration-version\">version</link> or the <link linkend=\"mapping-declaration-timestamp\">timestamp</link> property values for the affected entities. However, you can force Hibernate to reset the <literal>version</literal> or <literal>timestamp</literal> property values through the use of a <literal>versioned update</literal>. This is achieved by adding the <literal>VERSIONED</literal> keyword after the <literal>UPDATE</literal> keyword."
 msgstr ""
 
-#. Tag: programlisting
-#: batch.xml:201
-#, no-c-format
-msgid ""
-      "<![CDATA[Session session = sessionFactory.openSession();\n"
-      "Transaction tx = session.beginTransaction();\n"
-      "String hqlVersionedUpdate = \"update versioned Customer set name = :newName where name = :oldName\";\n"
-      "int updatedEntities = s.createQuery( hqlUpdate )\n"
-      "        .setString( \"newName\", newName )\n"
-      "        .setString( \"oldName\", oldName )\n"
-      "        .executeUpdate();\n"
-      "tx.commit();\n"
-      "session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:203
 #, no-c-format
 msgid "Custom version types, <literal>org.hibernate.usertype.UserVersionType</literal>, are not allowed in conjunction with a <literal>update versioned</literal> statement."
 msgstr ""
 
 #. Tag: para
-#: batch.xml:208
 #, no-c-format
 msgid "To execute an HQL <literal>DELETE</literal>, use the same <literal>Query.executeUpdate()</literal> method:"
 msgstr ""
 
-#. Tag: programlisting
-#: batch.xml:213
-#, no-c-format
-msgid ""
-      "<![CDATA[Session session = sessionFactory.openSession();\n"
-      "Transaction tx = session.beginTransaction();\n"
-      "\n"
-      "String hqlDelete = \"delete Customer c where c.name = :oldName\";\n"
-      "// or String hqlDelete = \"delete Customer where name = :oldName\";\n"
-      "int deletedEntities = s.createQuery( hqlDelete )\n"
-      "        .setString( \"oldName\", oldName )\n"
-      "        .executeUpdate();\n"
-      "tx.commit();\n"
-      "session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:215
 #, no-c-format
 msgid "The <literal>int</literal> value returned by the <literal>Query.executeUpdate()</literal> method indicates the number of entities effected by the operation. This may or may not correlate to the number of rows effected in the database. An HQL bulk operation might result in multiple actual SQL statements being executed (for joined-subclass, for example). The returned number indicates the number of actual entities affected by the statement. Going back to the example of joined-subclass, a delete against one of the subclasses may actually result in deletes against not just the table to which that subclass is mapped, but also the \"root\" table and potentially joined-subclass tables further down the inheritance hierarchy."
 msgstr ""
 
 #. Tag: para
-#: batch.xml:226
 #, no-c-format
 msgid "The pseudo-syntax for <literal>INSERT</literal> statements is: <literal>INSERT INTO EntityName properties_list select_statement</literal>. Some points to note:"
 msgstr ""
 
 #. Tag: para
-#: batch.xml:234
 #, no-c-format
 msgid "Only the INSERT INTO ... SELECT ... form is supported; not the INSERT INTO ... VALUES ... form."
 msgstr ""
 
 #. Tag: para
-#: batch.xml:237
 #, no-c-format
 msgid "The properties_list is analogous to the <literal>column specification</literal> in the SQL <literal>INSERT</literal> statement. For entities involved in mapped inheritance, only properties directly defined on that given class-level can be used in the properties_list. Superclass properties are not allowed and subclass properties do not make sense. In other words, <literal>INSERT</literal> statements are inherently non-polymorphic."
 msgstr ""
 
 #. Tag: para
-#: batch.xml:247
 #, no-c-format
 msgid "select_statement can be any valid HQL select query, with the caveat that the return types must match the types expected by the insert. Currently, this is checked during query compilation rather than allowing the check to relegate to the database. This might, however, cause problems between Hibernate <literal>Type</literal>s which are <emphasis>equivalent</emphasis> as opposed to <emphasis>equal</emphasis>. This might cause issues with mismatches between a property defined as a <literal>org.hibernate.type.DateType</literal> and a property defined as a <literal>org.hibernate.type.TimestampType</literal>, even though the database might not make a distinction or might be able to handle the conversion."
 msgstr ""
 
 #. Tag: para
-#: batch.xml:259
 #, no-c-format
 msgid "For the id property, the insert statement gives you two options. You can either explicitly specify the id property in the properties_list, in which case its value is taken from the corresponding select expression, or omit it from the properties_list, in which case a generated value is used. This latter option is only available when using id generators that operate in the database; attempting to use this option with any \"in memory\" type generators will cause an exception during parsing. For the purposes of this discussion, in-database generators are considered to be <literal>org.hibernate.id.SequenceGenerator</literal> (and its subclasses) and any implementers of <literal>org.hibernate.id.PostInsertIdentifierGenerator</literal>. The most notable exception here is <literal>org.hibernate.id.TableHiLoGenerator</literal>, which cannot be used because it does not expose a selectable way to get its values."
 msgstr ""
 
 #. Tag: para
-#: batch.xml:274
 #, no-c-format
 msgid "For properties mapped as either <literal>version</literal> or <literal>timestamp</literal>, the insert statement gives you two options. You can either specify the property in the properties_list, in which case its value is taken from the corresponding select expressions, or omit it from the properties_list, in which case the <literal>seed value</literal> defined by the <literal>org.hibernate.type.VersionType</literal> is used."
 msgstr ""
 
 #. Tag: para
-#: batch.xml:284
 #, no-c-format
 msgid "The following is an example of an HQL <literal>INSERT</literal> statement execution:"
 msgstr ""
 
-#. Tag: programlisting
-#: batch.xml:288
-#, no-c-format
-msgid ""
-      "<![CDATA[Session session = sessionFactory.openSession();\n"
-      "Transaction tx = session.beginTransaction();\n"
-      "\n"
-      "String hqlInsert = \"insert into DelinquentAccount (id, name) select c.id, c.name from Customer c where ...\";\n"
-      "int createdEntities = s.createQuery( hqlInsert )\n"
-      "        .executeUpdate();\n"
-      "tx.commit();\n"
-      "session.close();]]>"
-msgstr ""
-

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/best_practices.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/best_practices.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/best_practices.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,249 +1,208 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: best_practices.xml:29
 #, no-c-format
 msgid "Best Practices"
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:33
 #, no-c-format
 msgid "Write fine-grained classes and map them using <literal>&lt;component&gt;</literal>:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:35
 #, no-c-format
 msgid "Use an <literal>Address</literal> class to encapsulate <literal>street</literal>, <literal>suburb</literal>, <literal>state</literal>, <literal>postcode</literal>. This encourages code reuse and simplifies refactoring."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:43
 #, no-c-format
 msgid "Declare identifier properties on persistent classes:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:45
 #, no-c-format
 msgid "Hibernate makes identifier properties optional. There are a range of reasons why you should use them. We recommend that identifiers be 'synthetic', that is, generated with no business meaning."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:53
 #, no-c-format
 msgid "Identify natural keys:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:55
 #, no-c-format
 msgid "Identify natural keys for all entities, and map them using <literal>&lt;natural-id&gt;</literal>. Implement <literal>equals()</literal> and <literal>hashCode()</literal> to compare the properties that make up the natural key."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:63
 #, no-c-format
 msgid "Place each class mapping in its own file:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:65
 #, no-c-format
 msgid "Do not use a single monolithic mapping document. Map <literal>com.eg.Foo</literal> in the file <literal>com/eg/Foo.hbm.xml</literal>. This makes sense, particularly in a team environment."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:73
 #, no-c-format
 msgid "Load mappings as resources:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:75
 #, no-c-format
 msgid "Deploy the mappings along with the classes they map."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:81
 #, no-c-format
 msgid "Consider externalizing query strings:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:83
 #, no-c-format
 msgid "This is recommended if your queries call non-ANSI-standard SQL functions. Externalizing the query strings to mapping files will make the application more portable."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:91
 #, no-c-format
 msgid "Use bind variables."
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:93
 #, no-c-format
 msgid "As in JDBC, always replace non-constant values by \"?\". Do not use string manipulation to bind a non-constant value in a query. You should also consider using named parameters in queries."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:101
 #, no-c-format
 msgid "Do not manage your own JDBC connections:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:103
 #, no-c-format
 msgid "Hibernate allows the application to manage JDBC connections, but his approach should be considered a last-resort. If you cannot use the built-in connection providers, consider providing your own implementation of <literal>org.hibernate.connection.ConnectionProvider</literal>."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:111
 #, no-c-format
 msgid "Consider using a custom type:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:113
 #, no-c-format
 msgid "Suppose you have a Java type from a library that needs to be persisted but does not provide the accessors needed to map it as a component. You should consider implementing <literal>org.hibernate.UserType</literal>. This approach frees the application code from implementing transformations to/from a Hibernate type."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:122
 #, no-c-format
 msgid "Use hand-coded JDBC in bottlenecks:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:124
 #, no-c-format
-msgid "In performance-critical areas of the system, some kinds of operations might benefit from direct JDBC. Do not assume, however, that JDBC is necessarily faster. Please wait until you <emphasis>know</emphasis> something is a bottleneck. If you need to use direct JDBC, you can open a Hibernate <literal>Session</literal> and usingfile:///usr/share/doc/HTML/en-US/index.html that JDBC connection. This way you can still use the same transaction strategy and underlying connection provider."
+msgid "In performance-critical areas of the system, some kinds of operations might benefit from direct JDBC. Do not assume, however, that JDBC is necessarily faster. Please wait until you <emphasis>know</emphasis> something is a bottleneck. If you need to use direct JDBC, you can open a Hibernate <literal>Session</literal>, wrap your JDBC operation as a <literal>org.hibernate.jdbc.Work</literal> object and using that JDBC connection. This way you can still use the same transaction strategy and underlying connection provider."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:134
 #, no-c-format
 msgid "Understand <literal>Session</literal> flushing:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:136
 #, no-c-format
 msgid "Sometimes the Session synchronizes its persistent state with the database. Performance will be affected if this process occurs too often. You can sometimes minimize unnecessary flushing by disabling automatic flushing, or even by changing the order of queries and other operations within a particular transaction."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:145
 #, no-c-format
 msgid "In a three tiered architecture, consider using detached objects:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:147
 #, no-c-format
 msgid "When using a servlet/session bean architecture, you can pass persistent objects loaded in the session bean to and from the servlet/JSP layer. Use a new session to service each request. Use <literal>Session.merge()</literal> or <literal>Session.saveOrUpdate()</literal> to synchronize objects with the database."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:156
 #, no-c-format
 msgid "In a two tiered architecture, consider using long persistence contexts:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:158
 #, no-c-format
 msgid "Database Transactions have to be as short as possible for best scalability. However, it is often necessary to implement long running <emphasis>application transactions</emphasis>, a single unit-of-work from the point of view of a user. An application transaction might span several client request/response cycles. It is common to use detached objects to implement application transactions. An appropriate alternative in a two tiered architecture, is to maintain a single open persistence contact session for the whole life cycle of the application transaction. Then simply disconnect from the JDBC connection at the end of each request and reconnect at the beginning of the subsequent request. Never share a single session across more than one application transaction or you will be working with stale data."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:172
 #, no-c-format
 msgid "Do not treat exceptions as recoverable:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:174
 #, no-c-format
 msgid "This is more of a necessary practice than a \"best\" practice. When an exception occurs, roll back the <literal>Transaction</literal> and close the <literal>Session</literal>. If you do not do this, Hibernate cannot guarantee that in-memory state accurately represents the persistent state. For example, do not use <literal>Session.load()</literal> to determine if an instance with the given identifier exists on the database; use <literal>Session.get()</literal> or a query instead."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:184
 #, no-c-format
 msgid "Prefer lazy fetching for associations:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:186
 #, no-c-format
 msgid "Use eager fetching sparingly. Use proxies and lazy collections for most associations to classes that are not likely to be completely held in the second-level cache. For associations to cached classes, where there is an a extremely high probability of a cache hit, explicitly disable eager fetching using <literal>lazy=\"false\"</literal>. When join fetching is appropriate to a particular use case, use a query with a <literal>left join fetch</literal>."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:196
 #, no-c-format
 msgid "Use the <emphasis>open session in view</emphasis> pattern, or a disciplined <emphasis>assembly phase</emphasis> to avoid problems with unfetched data:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:201
 #, no-c-format
 msgid "Hibernate frees the developer from writing tedious <emphasis>Data Transfer Objects</emphasis> (DTO). In a traditional EJB architecture, DTOs serve dual purposes: first, they work around the problem that entity beans are not serializable; second, they implicitly define an assembly phase where all data to be used by the view is fetched and marshalled into the DTOs before returning control to the presentation tier. Hibernate eliminates the first purpose. Unless you are prepared to hold the persistence context (the session) open across the view rendering process, you will still need an assembly phase. Think of your business methods as having a strict contract with the presentation tier about what data is available in the detached objects. This is not a limitation of Hibernate. It is a fundamental requirement of safe transactional data access."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:215
 #, no-c-format
 msgid "Consider abstracting your business logic from Hibernate:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:217
 #, no-c-format
 msgid "Hide Hibernate data-access code behind an interface. Combine the <emphasis>DAO</emphasis> and <emphasis>Thread Local Session</emphasis> patterns. You can even have some classes persisted by handcoded JDBC associated to Hibernate via a <literal>UserType</literal>. This advice is, however, intended for \"sufficiently large\" applications. It is not appropriate for an application with five tables."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:227
 #, no-c-format
 msgid "Do not use exotic association mappings:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:229
 #, no-c-format
 msgid "Practical test cases for real many-to-many associations are rare. Most of the time you need additional information stored in the \"link table\". In this case, it is much better to use two one-to-many associations to an intermediate link class. In fact, most associations are one-to-many and many-to-one. For this reason, you should proceed cautiously when using any other association style."
 msgstr ""
 
 #. Tag: term
-#: best_practices.xml:239
 #, no-c-format
 msgid "Prefer bidirectional associations:"
 msgstr ""
 
 #. Tag: para
-#: best_practices.xml:241
 #, no-c-format
 msgid "Unidirectional associations are more difficult to query. In a large application, almost all associations must be navigable in both directions in queries."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/bibliography.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/bibliography.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/bibliography.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,70 +1,49 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: bibliography.xml:27
 #, no-c-format
 msgid "References"
 msgstr ""
 
 #. Tag: title
-#: bibliography.xml:31
 #, no-c-format
 msgid "Patterns of Enterprise Application Architecture"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:34
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Martin</firstname> <surname>Fowler</surname>"
+msgid "Martin"
 msgstr ""
 
-#. Tag: holder
-#: bibliography.xml:41
-#, no-c-format
-msgid "Pearson Education, Inc."
-msgstr ""
-
 #. Tag: title
-#: bibliography.xml:50
 #, no-c-format
 msgid "Java Persistence with Hibernate"
 msgstr ""
 
 #. Tag: subtitle
-#: bibliography.xml:51
 #, no-c-format
 msgid "Second Edition of Hibernate in Action"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:57
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Christian</firstname> <surname>Bauer</surname>"
+msgid "Christian"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:61
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Gavin</firstname> <surname>King</surname>"
+msgid "Gavin"
 msgstr ""
 
-#. Tag: holder
-#: bibliography.xml:68
-#, no-c-format
-msgid "Manning Publications Co."
-msgstr ""
-

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/collection_mapping.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/collection_mapping.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/collection_mapping.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,1210 +1,623 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: collection_mapping.xml:29
 #, no-c-format
 msgid "Collection mapping"
 msgstr ""
 
 #. Tag: title
-#: collection_mapping.xml:32
 #, no-c-format
 msgid "Persistent collections"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:34
 #, no-c-format
 msgid "Hibernate requires that persistent collection-valued fields be declared as an interface type. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:39
-#, no-c-format
-msgid ""
-      "<![CDATA[public class Product {\n"
-      "    private String serialNumber;\n"
-      "    private Set parts = new HashSet();\n"
-      "    \n"
-      "    public Set getParts() { return parts; }\n"
-      "    void setParts(Set parts) { this.parts = parts; }\n"
-      "    public String getSerialNumber() { return serialNumber; }\n"
-      "    void setSerialNumber(String sn) { serialNumber = sn; }\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:41
 #, no-c-format
 msgid "The actual interface might be <literal>java.util.Set</literal>, <literal>java.util.Collection</literal>, <literal>java.util.List</literal>, <literal>java.util.Map</literal>, <literal>java.util.SortedSet</literal>, <literal>java.util.SortedMap</literal> or anything you like (\"anything you like\" means you will have to write an implementation of <literal>org.hibernate.usertype.UserCollectionType</literal>.)"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:50
 #, no-c-format
 msgid "Notice how the instance variable was initialized with an instance of <literal>HashSet</literal>. This is the best way to initialize collection valued properties of newly instantiated (non-persistent) instances. When you make the instance persistent, by calling <literal>persist()</literal> for example, Hibernate will actually replace the <literal>HashSet</literal> with an instance of Hibernate's own implementation of <literal>Set</literal>. Be aware of the following errors:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:60
-#, no-c-format
-msgid ""
-      "<![CDATA[Cat cat = new DomesticCat();\n"
-      "Cat kitten = new DomesticCat();\n"
-      "....\n"
-      "Set kittens = new HashSet();\n"
-      "kittens.add(kitten);\n"
-      "cat.setKittens(kittens);\n"
-      "session.persist(cat);\n"
-      "kittens = cat.getKittens(); // Okay, kittens collection is a Set\n"
-      "(HashSet) cat.getKittens(); // Error!]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:62
 #, no-c-format
 msgid "The persistent collections injected by Hibernate behave like <literal>HashMap</literal>, <literal>HashSet</literal>, <literal>TreeMap</literal>, <literal>TreeSet</literal> or <literal>ArrayList</literal>, depending on the interface type."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:69
 #, no-c-format
 msgid "Collections instances have the usual behavior of value types. They are automatically persisted when referenced by a persistent object and are automatically deleted when unreferenced. If a collection is passed from one persistent object to another, its elements might be moved from one table to another. Two entities cannot share a reference to the same collection instance. Due to the underlying relational model, collection-valued properties do not support null value semantics. Hibernate does not distinguish between a null collection reference and an empty collection."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:80
 #, no-c-format
 msgid "Use persistent collections the same way you use ordinary Java collections. However, please ensure you understand the semantics of bidirectional associations (these are discussed later)."
 msgstr ""
 
 #. Tag: title
-#: collection_mapping.xml:89
 #, no-c-format
 msgid "Collection mappings"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:92
 #, no-c-format
 msgid "There are quite a range of mappings that can be generated for collections that cover many common relational models. We suggest you experiment with the schema generation tool so that you understand how various mapping declarations translate to database tables."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:99
 #, no-c-format
 msgid "The Hibernate mapping element used for mapping a collection depends upon the type of interface. For example, a <literal>&lt;set&gt;</literal> element is used for mapping properties of type <literal>Set</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:105
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Product\">\n"
-      "    <id name=\"serialNumber\" column=\"productSerialNumber\"/>\n"
-      "    <set name=\"parts\">\n"
-      "        <key column=\"productSerialNumber\" not-null=\"true\"/>\n"
-      "        <one-to-many class=\"Part\"/>\n"
-      "    </set>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:107
 #, no-c-format
 msgid "Apart from <literal>&lt;set&gt;</literal>, there is also <literal>&lt;list&gt;</literal>, <literal>&lt;map&gt;</literal>, <literal>&lt;bag&gt;</literal>, <literal>&lt;array&gt;</literal> and <literal>&lt;primitive-array&gt;</literal> mapping elements. The <literal>&lt;map&gt;</literal> element is representative:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:132
-#, no-c-format
-msgid ""
-      "<![CDATA[<map\n"
-      "    name=\"propertyName\"\n"
-      "    table=\"table_name\"\n"
-      "    schema=\"schema_name\"\n"
-      "    lazy=\"true|extra|false\"\n"
-      "    inverse=\"true|false\"\n"
-      "    cascade=\"all|none|save-update|delete|all-delete-orphan|delete-orphan\"\n"
-      "    sort=\"unsorted|natural|comparatorClass\"\n"
-      "    order-by=\"column_name asc|desc\"\n"
-      "    where=\"arbitrary sql where condition\"\n"
-      "    fetch=\"join|select|subselect\"\n"
-      "    batch-size=\"N\"\n"
-      "    access=\"field|property|ClassName\"\n"
-      "    optimistic-lock=\"true|false\"\n"
-      "    mutable=\"true|false\"\n"
-      "    node=\"element-name|.\"\n"
-      "    embed-xml=\"true|false\"\n"
-      ">\n"
-      "\n"
-      "    <key .... />\n"
-      "    <map-key .... />\n"
-      "    <element .... />\n"
-      "</map>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:135
 #, no-c-format
 msgid "<literal>name</literal>: the collection property name"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:140
 #, no-c-format
 msgid "<literal>table</literal> (optional - defaults to property name): the name of the collection table. It is not used for one-to-many associations."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:146
 #, no-c-format
 msgid "<literal>schema</literal> (optional): the name of a table schema to override the schema declared on the root element"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:152
 #, no-c-format
 msgid "<literal>lazy</literal> (optional - defaults to <literal>true</literal>): disables lazy fetching and specifies that the association is always eagerly fetched. It can also be used to enable \"extra-lazy\" fetching where most operations do not initialize the collection. This is suitable for large collections."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:161
 #, no-c-format
 msgid "<literal>inverse</literal> (optional - defaults to <literal>false</literal>): marks this collection as the \"inverse\" end of a bidirectional association."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:167
 #, no-c-format
 msgid "<literal>cascade</literal> (optional - defaults to <literal>none</literal>): enables operations to cascade to child entities."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:173
 #, no-c-format
 msgid "<literal>sort</literal> (optional): specifies a sorted collection with <literal>natural</literal> sort order or a given comparator class."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:179
 #, no-c-format
 msgid "<literal>order-by</literal> (optional, JDK1.4 only): specifies a table column or columns that define the iteration order of the <literal>Map</literal>, <literal>Set</literal> or bag, together with an optional <literal>asc</literal> or <literal>desc</literal>."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:186
 #, no-c-format
 msgid "<literal>where</literal> (optional): specifies an arbitrary SQL <literal>WHERE</literal> condition that is used when retrieving or removing the collection. This is useful if the collection needs to contain only a subset of the available data."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:193
 #, no-c-format
 msgid "<literal>fetch</literal> (optional, defaults to <literal>select</literal>): chooses between outer-join fetching, fetching by sequential select, and fetching by sequential subselect."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:200
 #, no-c-format
 msgid "<literal>batch-size</literal> (optional, defaults to <literal>1</literal>): specifies a \"batch size\" for lazily fetching instances of this collection."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:206
 #, no-c-format
 msgid "<literal>access</literal> (optional - defaults to <literal>property</literal>): the strategy Hibernate uses for accessing the collection property value."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:212
 #, no-c-format
 msgid "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</literal>): specifies that changes to the state of the collection results in increments of the owning entity's version. For one-to-many associations you may want to disable this setting."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:220
 #, no-c-format
 msgid "<literal>mutable</literal> (optional - defaults to <literal>true</literal>): a value of <literal>false</literal> specifies that the elements of the collection never change. This allows for minor performance optimization in some cases."
 msgstr ""
 
 #. Tag: title
-#: collection_mapping.xml:230
 #, no-c-format
 msgid "Collection foreign keys"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:232
 #, no-c-format
 msgid "Collection instances are distinguished in the database by the foreign key of the entity that owns the collection. This foreign key is referred to as the <emphasis>collection key column</emphasis>, or columns, of the collection table. The collection key column is mapped by the <literal>&lt;key&gt;</literal> element."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:240
 #, no-c-format
 msgid "There can be a nullability constraint on the foreign key column. For most collections, this is implied. For unidirectional one-to-many associations, the foreign key column is nullable by default, so you may need to specify <literal>not-null=\"true\"</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:247
-#, no-c-format
-msgid "<![CDATA[<key column=\"productSerialNumber\" not-null=\"true\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:249
 #, no-c-format
 msgid "The foreign key constraint can use <literal>ON DELETE CASCADE</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:253
-#, no-c-format
-msgid "<![CDATA[<key column=\"productSerialNumber\" on-delete=\"cascade\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:255
 #, no-c-format
 msgid "See the previous chapter for a full definition of the <literal>&lt;key&gt;</literal> element."
 msgstr ""
 
 #. Tag: title
-#: collection_mapping.xml:263
 #, no-c-format
 msgid "Collection elements"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:265
 #, no-c-format
 msgid "Collections can contain almost any other Hibernate type, including: basic types, custom types, components and references to other entities. This is an important distinction. An object in a collection might be handled with \"value\" semantics (its life cycle fully depends on the collection owner), or it might be a reference to another entity with its own life cycle. In the latter case, only the \"link\" between the two objects is considered to be a state held by the collection."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:274
 #, no-c-format
 msgid "The contained type is referred to as the <emphasis>collection element type</emphasis>. Collection elements are mapped by <literal>&lt;element&gt;</literal> or <literal>&lt;composite-element&gt;</literal>, or in the case of entity references, with <literal>&lt;one-to-many&gt;</literal> or <literal>&lt;many-to-many&gt;</literal>. The first two map elements with value semantics, the next two are used to map entity associations."
 msgstr ""
 
 #. Tag: title
-#: collection_mapping.xml:286
 #, no-c-format
 msgid "Indexed collections"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:288
 #, no-c-format
 msgid "All collection mappings, except those with set and bag semantics, need an <emphasis>index column</emphasis> in the collection table. An index column is a column that maps to an array index, or <literal>List</literal> index, or <literal>Map</literal> key. The index of a <literal>Map</literal> may be of any basic type, mapped with <literal>&lt;map-key&gt;</literal>. It can be an entity reference mapped with <literal>&lt;map-key-many-to-many&gt;</literal>, or it can be a composite type mapped with <literal>&lt;composite-map-key&gt;</literal>. The index of an array or list is always of type <literal>integer</literal> and is mapped using the <literal>&lt;list-index&gt;</literal> element. The mapped column contains sequential integers that are numbered from zero by default."
 msgstr ""
 
-#. Tag: sect2
-#: collection_mapping.xml:299
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<programlistingco> <areaspec> <area id=\"index1\" coords=\"2 45\"/> <area id=\"index2\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA[<list-index \n"
-      "        column=\"column_name\"\n"
-      "        base=\"0|1|...\"/>]]></programlisting> <calloutlist> <callout arearefs=\"index1\"> <para> <literal>column_name</literal> (required): the name of the column holding the collection index values. </para> </callout> <callout arearefs=\"index1\"> <para> <literal>base</literal> (optional - defaults to <literal>0</literal>): the value of the index column that corresponds to the first element of the list or array. </para> </callout> </calloutlist> </programlistingco> <programlistingco> <areaspec> <area id=\"mapkey1\" coords=\"2 45\"/> <area id=\"mapkey2\" coords=\"3 45\"/> <area id=\"mapkey3\" coords=\"4 45\"/> </areaspec> <programlisting><![CDATA[<map-key \n"
-      "        column=\"column_name\"\n"
-      "        formula=\"any SQL expression\"\n"
-      "        type=\"type_name\"\n"
-      "        node=\"@attribute-name\"\n"
-      "        length=\"N\"/>]]></programlisting> <calloutlist> <callout arearefs=\"mapkey1\"> <para> <literal>column</literal> (optional): the name of the column holding the collection index values. </para> </callout> <callout arearefs=\"mapkey2\"> <para> <literal>formula</literal> (optional): a SQL formula used to evaluate the key of the map. </para> </callout> <callout arearefs=\"mapkey3\"> <para> <literal>type</literal> (required): the type of the map keys. </para> </callout> </calloutlist> </programlistingco> <programlistingco> <areaspec> <area id=\"indexmanytomany1\" coords=\"2 45\"/> <area id=\"indexmanytomany2\" coords=\"3 45\"/> <area id=\"indexmanytomany3\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA[<map-key-many-to-many\n"
-      "        column=\"column_name\"\n"
-      "        formula=\"any SQL expression\"\n"
-      "        class=\"ClassName\"\n"
-      "/>]]></programlisting> <calloutlist> <callout arearefs=\"indexmanytomany1\"> <para> <literal>column</literal> (optional): the name of the foreign key column for the collection index values. </para> </callout> <callout arearefs=\"indexmanytomany2\"> <para> <literal>formula</literal> (optional): a SQ formula used to evaluate the foreign key of the map key. </para> </callout> <callout arearefs=\"indexmanytomany3\"> <para> <literal>class</literal> (required): the entity class used as the map key. </para> </callout> </calloutlist> </programlistingco>"
+msgid "<literal>column_name</literal> (required): the name of the column holding the collection index values."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:380
 #, no-c-format
+msgid "<literal>base</literal> (optional - defaults to <literal>0</literal>): the value of the index column that corresponds to the first element of the list or array."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "<literal>column</literal> (optional): the name of the column holding the collection index values."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "<literal>formula</literal> (optional): a SQL formula used to evaluate the key of the map."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "<literal>type</literal> (required): the type of the map keys."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "<literal>column</literal> (optional): the name of the foreign key column for the collection index values."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "<literal>formula</literal> (optional): a SQ formula used to evaluate the foreign key of the map key."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "<literal>class</literal> (required): the entity class used as the map key."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
 msgid "If your table does not have an index column, and you still wish to use <literal>List</literal> as the property type, you can map the property as a Hibernate <emphasis>&lt;bag&gt;</emphasis>. A bag does not retain its order when it is retrieved from the database, but it can be optionally sorted or ordered."
 msgstr ""
 
 #. Tag: title
-#: collection_mapping.xml:390
 #, no-c-format
 msgid "Collections of values and many-to-many associations"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:392
 #, no-c-format
 msgid "Any collection of values or many-to-many associations requires a dedicated <emphasis>collection table</emphasis> with a foreign key column or columns, <emphasis>collection element column</emphasis> or columns, and possibly an index column or columns."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:399
 #, no-c-format
 msgid "For a collection of values use the <literal>&lt;element&gt;</literal> tag. For example:"
 msgstr ""
 
-#. Tag: sect2
-#: collection_mapping.xml:401
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<programlistingco> <areaspec> <area id=\"element1b\" coords=\"2 50\"/> <area id=\"element2b\" coords=\"3 50\"/> <area id=\"element3b\" coords=\"4 50\"/> </areaspec> <programlisting><![CDATA[<element\n"
-      "        column=\"column_name\"\n"
-      "        formula=\"any SQL expression\"\n"
-      "        type=\"typename\"\n"
-      "        length=\"L\"\n"
-      "        precision=\"P\"\n"
-      "        scale=\"S\"\n"
-      "        not-null=\"true|false\"\n"
-      "        unique=\"true|false\"\n"
-      "        node=\"element-name\"\n"
-      "/>]]></programlisting> <calloutlist> <callout arearefs=\"element1b\"> <para> <literal>column</literal> (optional): the name of the column holding the collection element values. </para> </callout> <callout arearefs=\"element2b\"> <para> <literal>formula</literal> (optional): an SQL formula used to evaluate the element. </para> </callout> <callout arearefs=\"element3b\"> <para> <literal>type</literal> (required): the type of the collection element. </para> </callout> </calloutlist> </programlistingco> <para> A <emphasis>many-to-many association</emphasis> is specified using the <literal>&lt;many-to-many&gt;</literal> element. </para> <programlistingco> <areaspec> <area id=\"manytomany1\" coords=\"2 60\"/> <area id=\"manytomany2\" coords=\"3 60\"/> <area id=\"manytomany3\" coords=\"4 60\"/> <area id=\"manytomany4\" coords=\"5 60\"/> <area id=\"manytomany5\" coords=\"6 60\"/> <area id=\"manytomany6\" coords=\"7 60\"/> <area id=\"manytomany7\" coords=\"8 60\"/> <area id=\!
 "manytomany8\" coords=\"9 60\"/> </areaspec> <programlisting><![CDATA[<many-to-many\n"
-      "        column=\"column_name\"\n"
-      "        formula=\"any SQL expression\"\n"
-      "        class=\"ClassName\"\n"
-      "        fetch=\"select|join\"\n"
-      "        unique=\"true|false\"\n"
-      "        not-found=\"ignore|exception\"\n"
-      "        entity-name=\"EntityName\"\n"
-      "        property-ref=\"propertyNameFromAssociatedClass\"\n"
-      "        node=\"element-name\"\n"
-      "        embed-xml=\"true|false\"\n"
-      "    />]]></programlisting> <calloutlist> <callout arearefs=\"manytomany1\"> <para> <literal>column</literal> (optional): the name of the element foreign key column. </para> </callout> <callout arearefs=\"manytomany2\"> <para> <literal>formula</literal> (optional): an SQL formula used to evaluate the element foreign key value. </para> </callout> <callout arearefs=\"manytomany3\"> <para> <literal>class</literal> (required): the name of the associated class. </para> </callout> <callout arearefs=\"manytomany4\"> <para> <literal>fetch</literal> (optional - defaults to <literal>join</literal>): enables outer-join or sequential select fetching for this association. This is a special case; for full eager fetching in a single <literal>SELECT</literal> of an entity and its many-to-many relationships to other entities, you would enable <literal>join</literal> fetching,not only of the collection itself, but also with this attribute on the <literal>&lt;many-to-many&gt;</literal> !
 nested element. </para> </callout> <callout arearefs=\"manytomany5\"> <para> <literal>unique</literal> (optional): enables the DDL generation of a unique constraint for the foreign-key column. This makes the association multiplicity effectively one-to-many. </para> </callout> <callout arearefs=\"manytomany6\"> <para> <literal>not-found</literal> (optional - defaults to <literal>exception</literal>): specifies how foreign keys that reference missing rows will be handled: <literal>ignore</literal> will treat a missing row as a null association. </para> </callout> <callout arearefs=\"manytomany7\"> <para> <literal>entity-name</literal> (optional): the entity name of the associated class, as an alternative to <literal>class</literal>. </para> </callout> <callout arearefs=\"manytomany8\"> <para> <literal>property-ref</literal> (optional): the name of a property of the associated class that is joined to this foreign key. If not specified, the primary key of the associated class i!
 s used. </para> </callout> </calloutlist> </programlistingco>"
+msgid "<literal>column</literal> (optional): the name of the column holding the collection element values."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:506
 #, no-c-format
-msgid "Here are some examples."
+msgid "<literal>formula</literal> (optional): an SQL formula used to evaluate the element."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:509
 #, no-c-format
-msgid "A set of strings:"
+msgid "<literal>type</literal> (required): the type of the collection element."
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:513
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[<set name=\"names\" table=\"person_names\">\n"
-      "    <key column=\"person_id\"/>\n"
-      "    <element column=\"person_name\" type=\"string\"/>\n"
-      "</set>]]>"
+msgid "A <emphasis>many-to-many association</emphasis> is specified using the <literal>&lt;many-to-many&gt;</literal> element."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:515
 #, no-c-format
-msgid "A bag containing integers with an iteration order determined by the <literal>order-by</literal> attribute:"
+msgid "<literal>column</literal> (optional): the name of the element foreign key column."
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:520
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[<bag name=\"sizes\" \n"
-      "        table=\"item_sizes\" \n"
-      "        order-by=\"size asc\">\n"
-      "    <key column=\"item_id\"/>\n"
-      "    <element column=\"size\" type=\"integer\"/>\n"
-      "</bag>]]>"
+msgid "<literal>formula</literal> (optional): an SQL formula used to evaluate the element foreign key value."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:522
 #, no-c-format
-msgid "An array of entities, in this case, a many-to-many association:"
+msgid "<literal>class</literal> (required): the name of the associated class."
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:526
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[<array name=\"addresses\" \n"
-      "        table=\"PersonAddress\" \n"
-      "        cascade=\"persist\">\n"
-      "    <key column=\"personId\"/>\n"
-      "    <list-index column=\"sortOrder\"/>\n"
-      "    <many-to-many column=\"addressId\" class=\"Address\"/>\n"
-      "</array>]]>"
+msgid "<literal>fetch</literal> (optional - defaults to <literal>join</literal>): enables outer-join or sequential select fetching for this association. This is a special case; for full eager fetching in a single <literal>SELECT</literal> of an entity and its many-to-many relationships to other entities, you would enable <literal>join</literal> fetching,not only of the collection itself, but also with this attribute on the <literal>&lt;many-to-many&gt;</literal> nested element."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:528
 #, no-c-format
-msgid "A map from string indices to dates:"
+msgid "<literal>unique</literal> (optional): enables the DDL generation of a unique constraint for the foreign-key column. This makes the association multiplicity effectively one-to-many."
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:532
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[<map name=\"holidays\" \n"
-      "        table=\"holidays\" \n"
-      "        schema=\"dbo\" \n"
-      "        order-by=\"hol_name asc\">\n"
-      "    <key column=\"id\"/>\n"
-      "    <map-key column=\"hol_name\" type=\"string\"/>\n"
-      "    <element column=\"hol_date\" type=\"date\"/>\n"
-      "</map>]]>"
+msgid "<literal>not-found</literal> (optional - defaults to <literal>exception</literal>): specifies how foreign keys that reference missing rows will be handled: <literal>ignore</literal> will treat a missing row as a null association."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:534
 #, no-c-format
-msgid "A list of components (this is discussed in the next chapter):"
+msgid "<literal>entity-name</literal> (optional): the entity name of the associated class, as an alternative to <literal>class</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:538
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[<list name=\"carComponents\" \n"
-      "        table=\"CarComponents\">\n"
-      "    <key column=\"carId\"/>\n"
-      "    <list-index column=\"sortOrder\"/>\n"
-      "    <composite-element class=\"CarComponent\">\n"
-      "        <property name=\"price\"/>\n"
-      "        <property name=\"type\"/>\n"
-      "        <property name=\"serialNumber\" column=\"serialNum\"/>\n"
-      "    </composite-element>\n"
-      "</list>]]>"
+msgid "<literal>property-ref</literal> (optional): the name of a property of the associated class that is joined to this foreign key. If not specified, the primary key of the associated class is used."
 msgstr ""
 
-#. Tag: title
-#: collection_mapping.xml:543
+#. Tag: para
 #, no-c-format
-msgid "One-to-many associations"
+msgid "Here are some examples."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:545
 #, no-c-format
-msgid "A <emphasis>one-to-many association</emphasis> links the tables of two classes via a foreign key with no intervening collection table. This mapping loses certain semantics of normal Java collections:"
+msgid "A set of strings:"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:553
 #, no-c-format
-msgid "An instance of the contained entity class cannot belong to more than one instance of the collection."
+msgid "A bag containing integers with an iteration order determined by the <literal>order-by</literal> attribute:"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:559
 #, no-c-format
-msgid "An instance of the contained entity class cannot appear at more than one value of the collection index."
+msgid "An array of entities, in this case, a many-to-many association:"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:566
 #, no-c-format
-msgid "An association from <literal>Product</literal> to <literal>Part</literal> requires the existence of a foreign key column and possibly an index column to the <literal>Part</literal> table. A <literal>&lt;one-to-many&gt;</literal> tag indicates that this is a one-to-many association."
+msgid "A map from string indices to dates:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:579
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[<one-to-many \n"
-      "        class=\"ClassName\"\n"
-      "        not-found=\"ignore|exception\"\n"
-      "        entity-name=\"EntityName\"\n"
-      "        node=\"element-name\"\n"
-      "        embed-xml=\"true|false\"\n"
-      "    />]]>"
+msgid "A list of components (this is discussed in the next chapter):"
 msgstr ""
 
+#. Tag: title
+#, no-c-format
+msgid "One-to-many associations"
+msgstr ""
+
 #. Tag: para
-#: collection_mapping.xml:582
 #, no-c-format
-msgid "<literal>class</literal> (required): the name of the associated class."
+msgid "A <emphasis>one-to-many association</emphasis> links the tables of two classes via a foreign key with no intervening collection table. This mapping loses certain semantics of normal Java collections:"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:587
 #, no-c-format
-msgid "<literal>not-found</literal> (optional - defaults to <literal>exception</literal>): specifies how cached identifiers that reference missing rows will be handled. <literal>ignore</literal> will treat a missing row as a null association."
+msgid "An instance of the contained entity class cannot belong to more than one instance of the collection."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:594
 #, no-c-format
-msgid "<literal>entity-name</literal> (optional): the entity name of the associated class, as an alternative to <literal>class</literal>."
+msgid "An instance of the contained entity class cannot appear at more than one value of the collection index."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:602
 #, no-c-format
-msgid "The <literal>&lt;one-to-many&gt;</literal> element does not need to declare any columns. Nor is it necessary to specify the <literal>table</literal> name anywhere."
+msgid "An association from <literal>Product</literal> to <literal>Part</literal> requires the existence of a foreign key column and possibly an index column to the <literal>Part</literal> table. A <literal>&lt;one-to-many&gt;</literal> tag indicates that this is a one-to-many association."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:609
 #, no-c-format
-msgid "If the foreign key column of a <literal>&lt;one-to-many&gt;</literal> association is declared <literal>NOT NULL</literal>, you must declare the <literal>&lt;key&gt;</literal> mapping <literal>not-null=\"true\"</literal> or <emphasis>use a bidirectional association</emphasis> with the collection mapping marked <literal>inverse=\"true\"</literal>. See the discussion of bidirectional associations later in this chapter for more information."
+msgid "<literal>not-found</literal> (optional - defaults to <literal>exception</literal>): specifies how cached identifiers that reference missing rows will be handled. <literal>ignore</literal> will treat a missing row as a null association."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:619
 #, no-c-format
-msgid "The following example shows a map of <literal>Part</literal> entities by name, where <literal>partName</literal> is a persistent property of <literal>Part</literal>. Notice the use of a formula-based index:"
+msgid "The <literal>&lt;one-to-many&gt;</literal> element does not need to declare any columns. Nor is it necessary to specify the <literal>table</literal> name anywhere."
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:625
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[<map name=\"parts\"\n"
-      "        cascade=\"all\">\n"
-      "    <key column=\"productId\" not-null=\"true\"/>\n"
-      "    <map-key formula=\"partName\"/>\n"
-      "    <one-to-many class=\"Part\"/>\n"
-      "</map>]]>"
+msgid "If the foreign key column of a <literal>&lt;one-to-many&gt;</literal> association is declared <literal>NOT NULL</literal>, you must declare the <literal>&lt;key&gt;</literal> mapping <literal>not-null=\"true\"</literal> or <emphasis>use a bidirectional association</emphasis> with the collection mapping marked <literal>inverse=\"true\"</literal>. See the discussion of bidirectional associations later in this chapter for more information."
 msgstr ""
 
+#. Tag: para
+#, no-c-format
+msgid "The following example shows a map of <literal>Part</literal> entities by name, where <literal>partName</literal> is a persistent property of <literal>Part</literal>. Notice the use of a formula-based index:"
+msgstr ""
+
 #. Tag: title
-#: collection_mapping.xml:631
 #, no-c-format
 msgid "Advanced collection mappings"
 msgstr ""
 
 #. Tag: title
-#: collection_mapping.xml:634
 #, no-c-format
 msgid "Sorted collections"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:636
 #, no-c-format
 msgid "Hibernate supports collections implementing <literal>java.util.SortedMap</literal> and <literal>java.util.SortedSet</literal>. You must specify a comparator in the mapping file:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:641
-#, no-c-format
-msgid ""
-      "<![CDATA[<set name=\"aliases\" \n"
-      "            table=\"person_aliases\" \n"
-      "            sort=\"natural\">\n"
-      "    <key column=\"person\"/>\n"
-      "    <element column=\"name\" type=\"string\"/>\n"
-      "</set>\n"
-      "\n"
-      "<map name=\"holidays\" sort=\"my.custom.HolidayComparator\">\n"
-      "    <key column=\"year_id\"/>\n"
-      "    <map-key column=\"hol_name\" type=\"string\"/>\n"
-      "    <element column=\"hol_date\" type=\"date\"/>\n"
-      "</map>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:643
 #, no-c-format
 msgid "Allowed values of the <literal>sort</literal> attribute are <literal>unsorted</literal>, <literal>natural</literal> and the name of a class implementing <literal>java.util.Comparator</literal>."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:649
 #, no-c-format
 msgid "Sorted collections actually behave like <literal>java.util.TreeSet</literal> or <literal>java.util.TreeMap</literal>."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:654
 #, no-c-format
 msgid "If you want the database itself to order the collection elements, use the <literal>order-by</literal> attribute of <literal>set</literal>, <literal>bag</literal> or <literal>map</literal> mappings. This solution is only available under JDK 1.4 or higher and is implemented using <literal>LinkedHashSet</literal> or <literal>LinkedHashMap</literal>. This performs the ordering in the SQL query and not in the memory."
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:663
-#, no-c-format
-msgid ""
-      "<![CDATA[<set name=\"aliases\" table=\"person_aliases\" order-by=\"lower(name) asc\">\n"
-      "    <key column=\"person\"/>\n"
-      "    <element column=\"name\" type=\"string\"/>\n"
-      "</set>\n"
-      "\n"
-      "<map name=\"holidays\" order-by=\"hol_date, hol_name\">\n"
-      "    <key column=\"year_id\"/>\n"
-      "    <map-key column=\"hol_name\" type=\"string\"/>\n"
-      "    <element column=\"hol_date type=\"date\"/>\n"
-      "</map>]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:666
 #, no-c-format
 msgid "Note"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:667
 #, no-c-format
 msgid "The value of the <literal>order-by</literal> attribute is an SQL ordering, not an HQL ordering."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:673
 #, no-c-format
 msgid "Associations can even be sorted by arbitrary criteria at runtime using a collection <literal>filter()</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:678
-#, no-c-format
-msgid "<![CDATA[sortedUsers = s.createFilter( group.getUsers(), \"order by this.name\" ).list();]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:683
 #, no-c-format
 msgid "Bidirectional associations"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:685
 #, no-c-format
 msgid "A <emphasis>bidirectional association</emphasis> allows navigation from both \"ends\" of the association. Two kinds of bidirectional association are supported:"
 msgstr ""
 
 #. Tag: term
-#: collection_mapping.xml:692
 #, no-c-format
 msgid "one-to-many"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:694
 #, no-c-format
 msgid "set or bag valued at one end and single-valued at the other"
 msgstr ""
 
 #. Tag: term
-#: collection_mapping.xml:700
 #, no-c-format
 msgid "many-to-many"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:702
 #, no-c-format
 msgid "set or bag valued at both ends"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:711
 #, no-c-format
 msgid "You can specify a bidirectional many-to-many association by mapping two many-to-many associations to the same database table and declaring one end as <emphasis>inverse</emphasis>. You cannot select an indexed collection."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:718
 #, no-c-format
 msgid "Here is an example of a bidirectional many-to-many association that illustrates how each category can have many items and each item can be in many categories:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:723
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Category\">\n"
-      "    <id name=\"id\" column=\"CATEGORY_ID\"/>\n"
-      "    ...\n"
-      "    <bag name=\"items\" table=\"CATEGORY_ITEM\">\n"
-      "        <key column=\"CATEGORY_ID\"/>\n"
-      "        <many-to-many class=\"Item\" column=\"ITEM_ID\"/>\n"
-      "    </bag>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Item\">\n"
-      "    <id name=\"id\" column=\"ITEM_ID\"/>\n"
-      "    ...\n"
-      "\n"
-      "    <!-- inverse end -->\n"
-      "    <bag name=\"categories\" table=\"CATEGORY_ITEM\" inverse=\"true\">\n"
-      "        <key column=\"ITEM_ID\"/>\n"
-      "        <many-to-many class=\"Category\" column=\"CATEGORY_ID\"/>\n"
-      "    </bag>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:725
 #, no-c-format
 msgid "Changes made only to the inverse end of the association are <emphasis>not</emphasis> persisted. This means that Hibernate has two representations in memory for every bidirectional association: one link from A to B and another link from B to A. This is easier to understand if you think about the Java object model and how a many-to-many relationship in Javais created:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:733
-#, no-c-format
-msgid ""
-      "<![CDATA[\n"
-      "category.getItems().add(item);          // The category now \"knows\" about the relationship\n"
-      "item.getCategories().add(category);     // The item now \"knows\" about the relationship\n"
-      "\n"
-      "session.persist(item);                   // The relationship won't be saved!\n"
-      "session.persist(category);               // The relationship will be saved]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:735
 #, no-c-format
 msgid "The non-inverse side is used to save the in-memory representation to the database."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:739
 #, no-c-format
 msgid "You can define a bidirectional one-to-many association by mapping a one-to-many association to the same table column(s) as a many-to-one association and declaring the many-valued end <literal>inverse=\"true\"</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:745
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Parent\">\n"
-      "    <id name=\"id\" column=\"parent_id\"/>\n"
-      "    ....\n"
-      "    <set name=\"children\" inverse=\"true\">\n"
-      "        <key column=\"parent_id\"/>\n"
-      "        <one-to-many class=\"Child\"/>\n"
-      "    </set>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Child\">\n"
-      "    <id name=\"id\" column=\"child_id\"/>\n"
-      "    ....\n"
-      "    <many-to-one name=\"parent\" \n"
-      "        class=\"Parent\" \n"
-      "        column=\"parent_id\"\n"
-      "        not-null=\"true\"/>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:747
 #, no-c-format
 msgid "Mapping one end of an association with <literal>inverse=\"true\"</literal> does not affect the operation of cascades as these are orthogonal concepts."
 msgstr ""
 
 #. Tag: title
-#: collection_mapping.xml:755
 #, no-c-format
 msgid "Bidirectional associations with indexed collections"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:756
 #, no-c-format
 msgid "A bidirectional association where one end is represented as a <literal>&lt;list&gt;</literal> or <literal>&lt;map&gt;</literal>, requires special consideration. If there is a property of the child class that maps to the index column you can use <literal>inverse=\"true\"</literal> on the collection mapping:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:763
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Parent\">\n"
-      "    <id name=\"id\" column=\"parent_id\"/>\n"
-      "    ....\n"
-      "    <map name=\"children\" inverse=\"true\">\n"
-      "        <key column=\"parent_id\"/>\n"
-      "        <map-key column=\"name\" \n"
-      "            type=\"string\"/>\n"
-      "        <one-to-many class=\"Child\"/>\n"
-      "    </map>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Child\">\n"
-      "    <id name=\"id\" column=\"child_id\"/>\n"
-      "    ....\n"
-      "    <property name=\"name\" \n"
-      "        not-null=\"true\"/>\n"
-      "    <many-to-one name=\"parent\" \n"
-      "        class=\"Parent\" \n"
-      "        column=\"parent_id\"\n"
-      "        not-null=\"true\"/>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:765
 #, no-c-format
 msgid "If there is no such property on the child class, the association cannot be considered truly bidirectional. That is, there is information available at one end of the association that is not available at the other end. In this case, you cannot map the collection <literal>inverse=\"true\"</literal>. Instead, you could use the following mapping:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:772
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Parent\">\n"
-      "    <id name=\"id\" column=\"parent_id\"/>\n"
-      "    ....\n"
-      "    <map name=\"children\">\n"
-      "        <key column=\"parent_id\"\n"
-      "            not-null=\"true\"/>\n"
-      "        <map-key column=\"name\" \n"
-      "            type=\"string\"/>\n"
-      "        <one-to-many class=\"Child\"/>\n"
-      "    </map>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Child\">\n"
-      "    <id name=\"id\" column=\"child_id\"/>\n"
-      "    ....\n"
-      "    <many-to-one name=\"parent\" \n"
-      "        class=\"Parent\" \n"
-      "        column=\"parent_id\"\n"
-      "        insert=\"false\"\n"
-      "        update=\"false\"\n"
-      "        not-null=\"true\"/>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:774
 #, no-c-format
 msgid "Note that in this mapping, the collection-valued end of the association is responsible for updates to the foreign key."
 msgstr ""
 
 #. Tag: title
-#: collection_mapping.xml:782
 #, no-c-format
 msgid "Ternary associations"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:784
 #, no-c-format
 msgid "There are three possible approaches to mapping a ternary association. One approach is to use a <literal>Map</literal> with an association as its index:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:789
-#, no-c-format
-msgid ""
-      "<![CDATA[<map name=\"contracts\">\n"
-      "    <key column=\"employer_id\" not-null=\"true\"/>\n"
-      "    <map-key-many-to-many column=\"employee_id\" class=\"Employee\"/>\n"
-      "    <one-to-many class=\"Contract\"/>\n"
-      "</map>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: collection_mapping.xml:791
-#, no-c-format
-msgid ""
-      "<![CDATA[<map name=\"connections\">\n"
-      "    <key column=\"incoming_node_id\"/>\n"
-      "    <map-key-many-to-many column=\"outgoing_node_id\" class=\"Node\"/>\n"
-      "    <many-to-many column=\"connection_id\" class=\"Connection\"/>\n"
-      "</map>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:793
 #, no-c-format
 msgid "A second approach is to remodel the association as an entity class. This is the most common approach."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:798
 #, no-c-format
 msgid "A final alternative is to use composite elements, which will be discussed later."
 msgstr ""
 
-#. Tag: literal
-#: collection_mapping.xml:805
+#. Tag: title
 #, no-c-format
-msgid "Using an &lt;idbag&gt;"
+msgid "<literal>Using an &lt;idbag&gt;</literal>"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:807
 #, no-c-format
 msgid "The majority of the many-to-many associations and collections of values shown previously all map to tables with composite keys, even though it has been have suggested that entities should have synthetic identifiers (surrogate keys). A pure association table does not seem to benefit much from a surrogate key, although a collection of composite values <emphasis>might</emphasis>. It is for this reason that Hibernate provides a feature that allows you to map many-to-many associations and collections of values to a table with a surrogate key."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:817
 #, no-c-format
 msgid "The <literal>&lt;idbag&gt;</literal> element lets you map a <literal>List</literal> (or <literal>Collection</literal>) with bag semantics. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:822
-#, no-c-format
-msgid ""
-      "<![CDATA[<idbag name=\"lovers\" table=\"LOVERS\">\n"
-      "    <collection-id column=\"ID\" type=\"long\">\n"
-      "        <generator class=\"sequence\"/>\n"
-      "    </collection-id>\n"
-      "    <key column=\"PERSON1\"/>\n"
-      "    <many-to-many column=\"PERSON2\" class=\"Person\" fetch=\"join\"/>\n"
-      "</idbag>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:824
 #, no-c-format
 msgid "An <literal>&lt;idbag&gt;</literal> has a synthetic id generator, just like an entity class. A different surrogate key is assigned to each collection row. Hibernate does not, however, provide any mechanism for discovering the surrogate key value of a particular row."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:831
 #, no-c-format
 msgid "The update performance of an <literal>&lt;idbag&gt;</literal> supersedes a regular <literal>&lt;bag&gt;</literal>. Hibernate can locate individual rows efficiently and update or delete them individually, similar to a list, map or set."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:837
 #, no-c-format
 msgid "In the current implementation, the <literal>native</literal> identifier generation strategy is not supported for <literal>&lt;idbag&gt;</literal> collection identifiers."
 msgstr ""
 
 #. Tag: title
-#: collection_mapping.xml:861
 #, no-c-format
 msgid "Collection examples"
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:863
 #, no-c-format
 msgid "This section covers collection examples."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:867
 #, no-c-format
 msgid "The following class has a collection of <literal>Child</literal> instances:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:871
-#, no-c-format
-msgid ""
-      "<![CDATA[package eg;\n"
-      "import java.util.Set;\n"
-      "\n"
-      "public class Parent {\n"
-      "    private long id;\n"
-      "    private Set children;\n"
-      "\n"
-      "    public long getId() { return id; }\n"
-      "    private void setId(long id) { this.id=id; }\n"
-      "\n"
-      "    private Set getChildren() { return children; }\n"
-      "    private void setChildren(Set children) { this.children=children; }\n"
-      "\n"
-      "    ....\n"
-      "    ....\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:873
 #, no-c-format
 msgid "If each child has, at most, one parent, the most natural mapping is a one-to-many association:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:879
-#, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping>\n"
-      "\n"
-      "    <class name=\"Parent\">\n"
-      "        <id name=\"id\">\n"
-      "            <generator class=\"sequence\"/>\n"
-      "        </id>\n"
-      "        <set name=\"children\">\n"
-      "            <key column=\"parent_id\"/>\n"
-      "            <one-to-many class=\"Child\"/>\n"
-      "        </set>\n"
-      "    </class>\n"
-      "\n"
-      "    <class name=\"Child\">\n"
-      "        <id name=\"id\">\n"
-      "            <generator class=\"sequence\"/>\n"
-      "        </id>\n"
-      "        <property name=\"name\"/>\n"
-      "    </class>\n"
-      "\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:881
 #, no-c-format
 msgid "This maps to the following table definitions:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:885
-#, no-c-format
-msgid ""
-      "<![CDATA[create table parent ( id bigint not null primary key )\n"
-      "create table child ( id bigint not null primary key, name varchar(255), parent_id bigint )\n"
-      "alter table child add constraint childfk0 (parent_id) references parent]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:887
 #, no-c-format
 msgid "If the parent is <emphasis>required</emphasis>, use a bidirectional one-to-many association:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:892
-#, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping>\n"
-      "\n"
-      "    <class name=\"Parent\">\n"
-      "        <id name=\"id\">\n"
-      "            <generator class=\"sequence\"/>\n"
-      "        </id>\n"
-      "        <set name=\"children\" inverse=\"true\">\n"
-      "            <key column=\"parent_id\"/>\n"
-      "            <one-to-many class=\"Child\"/>\n"
-      "        </set>\n"
-      "    </class>\n"
-      "\n"
-      "    <class name=\"Child\">\n"
-      "        <id name=\"id\">\n"
-      "            <generator class=\"sequence\"/>\n"
-      "        </id>\n"
-      "        <property name=\"name\"/>\n"
-      "        <many-to-one name=\"parent\" class=\"Parent\" column=\"parent_id\" not-null=\"true\"/>\n"
-      "    </class>\n"
-      "\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:894
 #, no-c-format
 msgid "Notice the <literal>NOT NULL</literal> constraint:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:898
-#, no-c-format
-msgid ""
-      "<![CDATA[create table parent ( id bigint not null primary key )\n"
-      "create table child ( id bigint not null\n"
-      "                     primary key,\n"
-      "                     name varchar(255),\n"
-      "                     parent_id bigint not null )\n"
-      "alter table child add constraint childfk0 (parent_id) references parent]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:900
 #, no-c-format
 msgid "Alternatively, if this association must be unidirectional you can declare the <literal>NOT NULL</literal> constraint on the <literal>&lt;key&gt;</literal> mapping:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:906
-#, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping>\n"
-      "\n"
-      "    <class name=\"Parent\">\n"
-      "        <id name=\"id\">\n"
-      "            <generator class=\"sequence\"/>\n"
-      "        </id>\n"
-      "        <set name=\"children\">\n"
-      "            <key column=\"parent_id\" not-null=\"true\"/>\n"
-      "            <one-to-many class=\"Child\"/>\n"
-      "        </set>\n"
-      "    </class>\n"
-      "\n"
-      "    <class name=\"Child\">\n"
-      "        <id name=\"id\">\n"
-      "            <generator class=\"sequence\"/>\n"
-      "        </id>\n"
-      "        <property name=\"name\"/>\n"
-      "    </class>\n"
-      "\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:908
 #, no-c-format
 msgid "On the other hand, if a child has multiple parents, a many-to-many association is appropriate:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:913
-#, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping>\n"
-      "\n"
-      "    <class name=\"Parent\">\n"
-      "        <id name=\"id\">\n"
-      "            <generator class=\"sequence\"/>\n"
-      "        </id>\n"
-      "        <set name=\"children\" table=\"childset\">\n"
-      "            <key column=\"parent_id\"/>\n"
-      "            <many-to-many class=\"Child\" column=\"child_id\"/>\n"
-      "        </set>\n"
-      "    </class>\n"
-      "\n"
-      "    <class name=\"Child\">\n"
-      "        <id name=\"id\">\n"
-      "            <generator class=\"sequence\"/>\n"
-      "        </id>\n"
-      "        <property name=\"name\"/>\n"
-      "    </class>\n"
-      "\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:915
 #, no-c-format
 msgid "Table definitions:"
 msgstr ""
 
-#. Tag: programlisting
-#: collection_mapping.xml:919
-#, no-c-format
-msgid ""
-      "<![CDATA[create table parent ( id bigint not null primary key )\n"
-      "create table child ( id bigint not null primary key, name varchar(255) )\n"
-      "create table childset ( parent_id bigint not null,\n"
-      "                        child_id bigint not null,\n"
-      "                        primary key ( parent_id, child_id ) )\n"
-      "alter table childset add constraint childsetfk0 (parent_id) references parent\n"
-      "alter table childset add constraint childsetfk1 (child_id) references child]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:921
 #, no-c-format
-msgid "For more examples and a complete explanation of a parent/child relationship mapping, see <xref linkend=\"example-parentchild\"/> for more information."
+msgid "For more examples and a complete explanation of a parent/child relationship mapping, see <xref linkend=\"example-parentchild\" /> for more information."
 msgstr ""
 
 #. Tag: para
-#: collection_mapping.xml:926
 #, no-c-format
 msgid "Even more complex association mappings are covered in the next chapter."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/component_mapping.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/component_mapping.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/component_mapping.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,481 +1,203 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: component_mapping.xml:29
 #, no-c-format
 msgid "Component Mapping"
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:31
 #, no-c-format
 msgid "The notion of a <emphasis>component</emphasis> is re-used in several different contexts and purposes throughout Hibernate."
 msgstr ""
 
 #. Tag: title
-#: component_mapping.xml:37
 #, no-c-format
 msgid "Dependent objects"
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:39
 #, no-c-format
 msgid "A component is a contained object that is persisted as a value type and not an entity reference. The term \"component\" refers to the object-oriented notion of composition and not to architecture-level components. For example, you can model a person like this:"
 msgstr ""
 
-#. Tag: programlisting
-#: component_mapping.xml:45
-#, no-c-format
-msgid ""
-      "<![CDATA[public class Person {\n"
-      "    private java.util.Date birthday;\n"
-      "    private Name name;\n"
-      "    private String key;\n"
-      "    public String getKey() {\n"
-      "        return key;\n"
-      "    }\n"
-      "    private void setKey(String key) {\n"
-      "        this.key=key;\n"
-      "    }\n"
-      "    public java.util.Date getBirthday() {\n"
-      "        return birthday;\n"
-      "    }\n"
-      "    public void setBirthday(java.util.Date birthday) {\n"
-      "        this.birthday = birthday;\n"
-      "    }\n"
-      "    public Name getName() {\n"
-      "        return name;\n"
-      "    }\n"
-      "    public void setName(Name name) {\n"
-      "        this.name = name;\n"
-      "    }\n"
-      "    ......\n"
-      "    ......\n"
-      "}]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: component_mapping.xml:47
-#, no-c-format
-msgid ""
-      "<![CDATA[public class Name {\n"
-      "    char initial;\n"
-      "    String first;\n"
-      "    String last;\n"
-      "    public String getFirst() {\n"
-      "        return first;\n"
-      "    }\n"
-      "    void setFirst(String first) {\n"
-      "        this.first = first;\n"
-      "    }\n"
-      "    public String getLast() {\n"
-      "        return last;\n"
-      "    }\n"
-      "    void setLast(String last) {\n"
-      "        this.last = last;\n"
-      "    }\n"
-      "    public char getInitial() {\n"
-      "        return initial;\n"
-      "    }\n"
-      "    void setInitial(char initial) {\n"
-      "        this.initial = initial;\n"
-      "    }\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:49
 #, no-c-format
 msgid "Now <literal>Name</literal> can be persisted as a component of <literal>Person</literal>. <literal>Name</literal> defines getter and setter methods for its persistent properties, but it does not need to declare any interfaces or identifier properties."
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:56
 #, no-c-format
 msgid "Our Hibernate mapping would look like this:"
 msgstr ""
 
-#. Tag: programlisting
-#: component_mapping.xml:60
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-      "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-      "        <generator class=\"uuid\"/>\n"
-      "    </id>\n"
-      "    <property name=\"birthday\" type=\"date\"/>\n"
-      "    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute optional -->\n"
-      "        <property name=\"initial\"/>\n"
-      "        <property name=\"first\"/>\n"
-      "        <property name=\"last\"/>\n"
-      "    </component>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:62
 #, no-c-format
 msgid "The person table would have the columns <literal>pid</literal>, <literal>birthday</literal>, <literal>initial</literal>, <literal>first</literal> and <literal>last</literal>."
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:70
 #, no-c-format
 msgid "Like value types, components do not support shared references. In other words, two persons could have the same name, but the two person objects would contain two independent name objects that were only \"the same\" by value. The null value semantics of a component are <emphasis>ad hoc</emphasis>. When reloading the containing object, Hibernate will assume that if all component columns are null, then the entire component is null. This is suitable for most purposes."
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:78
 #, no-c-format
 msgid "The properties of a component can be of any Hibernate type (collections, many-to-one associations, other components, etc). Nested components should <emphasis>not</emphasis> be considered an exotic usage. Hibernate is intended to support a fine-grained object model."
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:85
 #, no-c-format
 msgid "The <literal>&lt;component&gt;</literal> element allows a <literal>&lt;parent&gt;</literal> subelement that maps a property of the component class as a reference back to the containing entity."
 msgstr ""
 
-#. Tag: programlisting
-#: component_mapping.xml:91
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-      "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-      "        <generator class=\"uuid\"/>\n"
-      "    </id>\n"
-      "    <property name=\"birthday\" type=\"date\"/>\n"
-      "    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
-      "        <parent name=\"namedPerson\"/> <!-- reference back to the Person -->\n"
-      "        <property name=\"initial\"/>\n"
-      "        <property name=\"first\"/>\n"
-      "        <property name=\"last\"/>\n"
-      "    </component>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: component_mapping.xml:96
 #, no-c-format
 msgid "Collections of dependent objects"
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:98
 #, no-c-format
 msgid "Collections of components are supported (e.g. an array of type <literal>Name</literal>). Declare your component collection by replacing the <literal>&lt;element&gt;</literal> tag with a <literal>&lt;composite-element&gt;</literal> tag:"
 msgstr ""
 
-#. Tag: programlisting
-#: component_mapping.xml:105
-#, no-c-format
-msgid ""
-      "<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
-      "    <key column=\"id\"/>\n"
-      "    <composite-element class=\"eg.Name\"> <!-- class attribute required -->\n"
-      "        <property name=\"initial\"/>\n"
-      "        <property name=\"first\"/>\n"
-      "        <property name=\"last\"/>\n"
-      "    </composite-element>\n"
-      "</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:108
 #, no-c-format
 msgid "If you define a <literal>Set</literal> of composite elements, it is important to implement <literal>equals()</literal> and <literal>hashCode()</literal> correctly."
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:115
 #, no-c-format
 msgid "Composite elements can contain components but not collections. If your composite element contains components, use the <literal>&lt;nested-composite-element&gt;</literal> tag. This case is a collection of components which themselves have components. You may want to consider if a one-to-many association is more appropriate. Remodel the composite element as an entity, but be aware that even though the Java model is the same, the relational model and persistence semantics are still slightly different."
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:127
 #, no-c-format
 msgid "A composite element mapping does not support null-able properties if you are using a <literal>&lt;set&gt;</literal>. There is no separate primary key column in the composite element table. Hibernate uses each column's value to identify a record when deleting objects, which is not possible with null values. You have to either use only not-null properties in a composite-element or choose a <literal>&lt;list&gt;</literal>, <literal>&lt;map&gt;</literal>, <literal>&lt;bag&gt;</literal> or <literal>&lt;idbag&gt;</literal>."
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:138
 #, no-c-format
 msgid "A special case of a composite element is a composite element with a nested <literal>&lt;many-to-one&gt;</literal> element. This mapping allows you to map extra columns of a many-to-many association table to the composite element class. The following is a many-to-many association from <literal>Order</literal> to <literal>Item</literal>, where <literal>purchaseDate</literal>, <literal>price</literal> and <literal>quantity</literal> are properties of the association:"
 msgstr ""
 
-#. Tag: programlisting
-#: component_mapping.xml:148
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"eg.Order\" .... >\n"
-      "    ....\n"
-      "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-      "        <key column=\"order_id\">\n"
-      "        <composite-element class=\"eg.Purchase\">\n"
-      "            <property name=\"purchaseDate\"/>\n"
-      "            <property name=\"price\"/>\n"
-      "            <property name=\"quantity\"/>\n"
-      "            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class attribute is optional -->\n"
-      "        </composite-element>\n"
-      "    </set>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:150
 #, no-c-format
 msgid "There cannot be a reference to the purchase on the other side for bidirectional association navigation. Components are value types and do not allow shared references. A single <literal>Purchase</literal> can be in the set of an <literal>Order</literal>, but it cannot be referenced by the <literal>Item</literal> at the same time."
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:158
 #, no-c-format
 msgid "Even ternary (or quaternary, etc) associations are possible:"
 msgstr ""
 
-#. Tag: programlisting
-#: component_mapping.xml:160
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"eg.Order\" .... >\n"
-      "    ....\n"
-      "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-      "        <key column=\"order_id\">\n"
-      "        <composite-element class=\"eg.OrderLine\">\n"
-      "            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
-      "            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
-      "        </composite-element>\n"
-      "    </set>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:162
 #, no-c-format
 msgid "Composite elements can appear in queries using the same syntax as associations to other entities."
 msgstr ""
 
 #. Tag: title
-#: component_mapping.xml:170
 #, no-c-format
 msgid "Components as Map indices"
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:172
 #, no-c-format
 msgid "The <literal>&lt;composite-map-key&gt;</literal> element allows you to map a component class as the key of a <literal>Map</literal>. Ensure that you override <literal>hashCode()</literal> and <literal>equals()</literal> correctly on the component class."
 msgstr ""
 
 #. Tag: title
-#: component_mapping.xml:181
 #, no-c-format
 msgid "Components as composite identifiers"
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:183
 #, no-c-format
 msgid "You can use a component as an identifier of an entity class. Your component class must satisfy certain requirements:"
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:190
 #, no-c-format
 msgid "It must implement <literal>java.io.Serializable</literal>."
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:195
 #, no-c-format
 msgid "It must re-implement <literal>equals()</literal> and <literal>hashCode()</literal> consistently with the database's notion of composite key equality."
 msgstr ""
 
 #. Tag: title
-#: component_mapping.xml:204
 #, no-c-format
 msgid "Note"
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:205
 #, no-c-format
 msgid "In Hibernate3, although the second requirement is not an absolutely hard requirement of Hibernate, it is recommended."
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:211
 #, no-c-format
 msgid "You cannot use an <literal>IdentifierGenerator</literal> to generate composite keys. Instead the application must assign its own identifiers."
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:216
 #, no-c-format
 msgid "Use the <literal>&lt;composite-id&gt;</literal> tag, with nested <literal>&lt;key-property&gt;</literal> elements, in place of the usual <literal>&lt;id&gt;</literal> declaration. For example, the <literal>OrderLine</literal> class has a primary key that depends upon the (composite) primary key of <literal>Order</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: component_mapping.xml:224
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"OrderLine\">\n"
-      "\n"
-      "    <composite-id name=\"id\" class=\"OrderLineId\">\n"
-      "        <key-property name=\"lineId\"/>\n"
-      "        <key-property name=\"orderId\"/>\n"
-      "        <key-property name=\"customerId\"/>\n"
-      "    </composite-id>\n"
-      "\n"
-      "    <property name=\"name\"/>\n"
-      "\n"
-      "    <many-to-one name=\"order\" class=\"Order\"\n"
-      "            insert=\"false\" update=\"false\">\n"
-      "        <column name=\"orderId\"/>\n"
-      "        <column name=\"customerId\"/>\n"
-      "    </many-to-one>\n"
-      "    ....\n"
-      "\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:226
 #, no-c-format
 msgid "Any foreign keys referencing the <literal>OrderLine</literal> table are now composite. Declare this in your mappings for other classes. An association to <literal>OrderLine</literal> is mapped like this:"
 msgstr ""
 
-#. Tag: programlisting
-#: component_mapping.xml:232
-#, no-c-format
-msgid ""
-      "<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
-      "<!-- the \"class\" attribute is optional, as usual -->\n"
-      "    <column name=\"lineId\"/>\n"
-      "    <column name=\"orderId\"/>\n"
-      "    <column name=\"customerId\"/>\n"
-      "</many-to-one>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:235
 #, no-c-format
 msgid "The <literal>column</literal> element is an alternative to the <literal>column</literal> attribute everywhere. Using the <literal>column</literal> element just gives more declaration options, which are mostly useful when utilizing <literal>hbm2ddl</literal>"
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:244
 #, no-c-format
 msgid "A <literal>many-to-many</literal> association to <literal>OrderLine</literal> also uses the composite foreign key:"
 msgstr ""
 
-#. Tag: programlisting
-#: component_mapping.xml:249
-#, no-c-format
-msgid ""
-      "<![CDATA[<set name=\"undeliveredOrderLines\">\n"
-      "    <key column name=\"warehouseId\"/>\n"
-      "    <many-to-many class=\"OrderLine\">\n"
-      "        <column name=\"lineId\"/>\n"
-      "        <column name=\"orderId\"/>\n"
-      "        <column name=\"customerId\"/>\n"
-      "    </many-to-many>\n"
-      "</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:251
 #, no-c-format
 msgid "The collection of <literal>OrderLine</literal>s in <literal>Order</literal> would use:"
 msgstr ""
 
-#. Tag: programlisting
-#: component_mapping.xml:256
-#, no-c-format
-msgid ""
-      "<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
-      "    <key>\n"
-      "        <column name=\"orderId\"/>\n"
-      "        <column name=\"customerId\"/>\n"
-      "    </key>\n"
-      "    <one-to-many class=\"OrderLine\"/>\n"
-      "</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:258
 #, no-c-format
 msgid "The <literal>&lt;one-to-many&gt;</literal> element declares no columns."
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:262
 #, no-c-format
 msgid "If <literal>OrderLine</literal> itself owns a collection, it also has a composite foreign key."
 msgstr ""
 
-#. Tag: programlisting
-#: component_mapping.xml:267
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"OrderLine\">\n"
-      "    ....\n"
-      "    ....\n"
-      "    <list name=\"deliveryAttempts\">\n"
-      "        <key>   <!-- a collection inherits the composite key type -->\n"
-      "            <column name=\"lineId\"/>\n"
-      "            <column name=\"orderId\"/>\n"
-      "            <column name=\"customerId\"/>\n"
-      "        </key>\n"
-      "        <list-index column=\"attemptId\" base=\"1\"/>\n"
-      "        <composite-element class=\"DeliveryAttempt\">\n"
-      "            ...\n"
-      "        </composite-element>\n"
-      "    </set>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: component_mapping.xml:272
 #, no-c-format
 msgid "Dynamic components"
 msgstr ""
 
 #. Tag: para
-#: component_mapping.xml:274
 #, no-c-format
 msgid "You can also map a property of type <literal>Map</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: component_mapping.xml:278
-#, no-c-format
-msgid ""
-      "<![CDATA[<dynamic-component name=\"userAttributes\">\n"
-      "    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
-      "    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
-      "    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
-      "</dynamic-component>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:280
 #, no-c-format
 msgid "The semantics of a <literal>&lt;dynamic-component&gt;</literal> mapping are identical to <literal>&lt;component&gt;</literal>. The advantage of this kind of mapping is the ability to determine the actual properties of the bean at deployment time just by editing the mapping document. Runtime manipulation of the mapping document is also possible, using a DOM parser. You can also access, and change, Hibernate's configuration-time metamodel via the <literal>Configuration</literal> object."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/configuration.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/configuration.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/configuration.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,2188 +1,1663 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: configuration.xml:29
 #, no-c-format
 msgid "Configuration"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:31
 #, no-c-format
 msgid "Hibernate is designed to operate in many different environments and, as such, there is a broad range of configuration parameters. Fortunately, most have sensible default values and Hibernate is distributed with an example <literal>hibernate.properties</literal> file in <literal>etc/</literal> that displays the various options. Simply put the example file in your classpath and customize it to suit your needs."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:40
 #, no-c-format
 msgid "Programmatic configuration"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:42
 #, no-c-format
 msgid "An instance of <classname>org.hibernate.cfg.Configuration</classname> represents an entire set of mappings of an application's Java types to an SQL database. The <classname>org.hibernate.cfg.Configuration</classname> is used to build an immutable <interfacename>org.hibernate.SessionFactory</interfacename>. The mappings are compiled from various XML mapping files."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:49
 #, no-c-format
 msgid "You can obtain a <classname>org.hibernate.cfg.Configuration</classname> instance by instantiating it directly and specifying XML mapping documents. If the mapping files are in the classpath, use <literal>addResource()</literal>. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: configuration.xml:55
-#, no-c-format
-msgid ""
-      "<![CDATA[Configuration cfg = new Configuration()\n"
-      "    .addResource(\"Item.hbm.xml\")\n"
-      "    .addResource(\"Bid.hbm.xml\");]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:57
 #, no-c-format
 msgid "An alternative way is to specify the mapped class and allow Hibernate to find the mapping document for you:"
 msgstr ""
 
-#. Tag: programlisting
-#: configuration.xml:62
-#, no-c-format
-msgid ""
-      "<![CDATA[Configuration cfg = new Configuration()\n"
-      "    .addClass(org.hibernate.auction.Item.class)\n"
-      "    .addClass(org.hibernate.auction.Bid.class);]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:64
 #, no-c-format
 msgid "Hibernate will then search for mapping files named <filename>/org/hibernate/auction/Item.hbm.xml</filename> and <filename>/org/hibernate/auction/Bid.hbm.xml</filename> in the classpath. This approach eliminates any hardcoded filenames."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:70
 #, no-c-format
 msgid "A <classname>org.hibernate.cfg.Configuration</classname> also allows you to specify configuration properties. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: configuration.xml:75
-#, no-c-format
-msgid ""
-      "<![CDATA[Configuration cfg = new Configuration()\n"
-      "    .addClass(org.hibernate.auction.Item.class)\n"
-      "    .addClass(org.hibernate.auction.Bid.class)\n"
-      "    .setProperty(\"hibernate.dialect\", \"org.hibernate.dialect.MySQLInnoDBDialect\")\n"
-      "    .setProperty(\"hibernate.connection.datasource\", \"java:comp/env/jdbc/test\")\n"
-      "    .setProperty(\"hibernate.order_updates\", \"true\");]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:77
 #, no-c-format
 msgid "This is not the only way to pass configuration properties to Hibernate. Some alternative options include:"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:84
 #, no-c-format
 msgid "Pass an instance of <classname>java.util.Properties</classname> to <literal>Configuration.setProperties()</literal>."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:90
 #, no-c-format
 msgid "Place a file named <filename>hibernate.properties</filename> in a root directory of the classpath."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:95
 #, no-c-format
 msgid "Set <literal>System</literal> properties using <literal>java -Dproperty=value</literal>."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:100
 #, no-c-format
 msgid "Include <literal>&lt;property&gt;</literal> elements in <literal>hibernate.cfg.xml</literal> (this is discussed later)."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:107
 #, no-c-format
 msgid "If you want to get started quickly<filename>hibernate.properties</filename> is the easiest approach."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:111
 #, no-c-format
 msgid "The <classname>org.hibernate.cfg.Configuration</classname> is intended as a startup-time object that will be discarded once a <literal>SessionFactory</literal> is created."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:119
 #, no-c-format
 msgid "Obtaining a SessionFactory"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:121
 #, no-c-format
 msgid "When all mappings have been parsed by the <classname>org.hibernate.cfg.Configuration</classname>, the application must obtain a factory for <interfacename>org.hibernate.Session</interfacename> instances. This factory is intended to be shared by all application threads:"
 msgstr ""
 
-#. Tag: programlisting
-#: configuration.xml:127
-#, no-c-format
-msgid "<![CDATA[SessionFactory sessions = cfg.buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:129
 #, no-c-format
 msgid "Hibernate does allow your application to instantiate more than one <interfacename>org.hibernate.SessionFactory</interfacename>. This is useful if you are using more than one database."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:138
 #, no-c-format
 msgid "JDBC connections"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:140
 #, no-c-format
 msgid "It is advisable to have the <interfacename>org.hibernate.SessionFactory</interfacename> create and pool JDBC connections for you. If you take this approach, opening a <interfacename>org.hibernate.Session</interfacename> is as simple as:"
 msgstr ""
 
-#. Tag: programlisting
-#: configuration.xml:146
-#, no-c-format
-msgid "<![CDATA[Session session = sessions.openSession(); // open a new Session]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:148
 #, no-c-format
 msgid "Once you start a task that requires access to the database, a JDBC connection will be obtained from the pool."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:153
 #, no-c-format
 msgid "Before you can do this, you first need to pass some JDBC connection properties to Hibernate. All Hibernate property names and semantics are defined on the class <classname>org.hibernate.cfg.Environment</classname>. The most important settings for JDBC connection configuration are outlined below."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:159
 #, no-c-format
 msgid "Hibernate will obtain and pool connections using <classname>java.sql.DriverManager</classname> if you set the following properties:"
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:165
 #, no-c-format
 msgid "Hibernate JDBC Properties"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:171 configuration.xml:257 configuration.xml:353 configuration.xml:548 configuration.xml:743 configuration.xml:850 configuration.xml:938
 #, no-c-format
 msgid "Property name"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:172 configuration.xml:258 configuration.xml:354 configuration.xml:549 configuration.xml:744 configuration.xml:851 configuration.xml:939
 #, no-c-format
 msgid "Purpose"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:178
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.driver_class"
+msgid "<property>hibernate.connection.driver_class</property>"
 msgstr ""
 
-#. Tag: emphasis
-#: configuration.xml:181
+#. Tag: entry
 #, no-c-format
-msgid "JDBC driver class"
+msgid "<emphasis>JDBC driver class</emphasis>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:186
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.url"
+msgid "<property>hibernate.connection.url</property>"
 msgstr ""
 
-#. Tag: emphasis
-#: configuration.xml:189
+#. Tag: entry
 #, no-c-format
-msgid "JDBC URL"
+msgid "<emphasis>JDBC URL</emphasis>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:194 configuration.xml:288
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.username"
+msgid "<property>hibernate.connection.username</property>"
 msgstr ""
 
-#. Tag: emphasis
-#: configuration.xml:197
+#. Tag: entry
 #, no-c-format
-msgid "database user"
+msgid "<emphasis>database user</emphasis>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:202 configuration.xml:296
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.password"
+msgid "<property>hibernate.connection.password</property>"
 msgstr ""
 
-#. Tag: emphasis
-#: configuration.xml:205
+#. Tag: entry
 #, no-c-format
-msgid "database user password"
+msgid "<emphasis>database user password</emphasis>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:210
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.pool_size"
+msgid "<property>hibernate.connection.pool_size</property>"
 msgstr ""
 
-#. Tag: emphasis
-#: configuration.xml:213
+#. Tag: entry
 #, no-c-format
-msgid "maximum number of pooled connections"
+msgid "<emphasis>maximum number of pooled connections</emphasis>"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:220
 #, no-c-format
 msgid "Hibernate's own connection pooling algorithm is, however, quite rudimentary. It is intended to help you get started and is <emphasis>not intended for use in a production system</emphasis>, or even for performance testing. You should use a third party pool for best performance and stability. Just replace the <property>hibernate.connection.pool_size</property> property with connection pool specific settings. This will turn off Hibernate's internal pool. For example, you might like to use c3p0."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:230
 #, no-c-format
 msgid "C3P0 is an open source JDBC connection pool distributed along with Hibernate in the <filename>lib</filename> directory. Hibernate will use its <classname>org.hibernate.connection.C3P0ConnectionProvider</classname> for connection pooling if you set <property>hibernate.c3p0.*</property> properties. If you would like to use Proxool, refer to the packaged <filename>hibernate.properties</filename> and the Hibernate web site for more information."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:238
 #, no-c-format
 msgid "The following is an example <filename>hibernate.properties</filename> file for c3p0:"
 msgstr ""
 
-#. Tag: programlisting
-#: configuration.xml:242
-#, no-c-format
-msgid ""
-      "<![CDATA[hibernate.connection.driver_class = org.postgresql.Driver\n"
-      "hibernate.connection.url = jdbc:postgresql://localhost/mydatabase\n"
-      "hibernate.connection.username = myuser\n"
-      "hibernate.connection.password = secret\n"
-      "hibernate.c3p0.min_size=5\n"
-      "hibernate.c3p0.max_size=20\n"
-      "hibernate.c3p0.timeout=1800\n"
-      "hibernate.c3p0.max_statements=50\n"
-      "hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:244
 #, no-c-format
 msgid "For use inside an application server, you should almost always configure Hibernate to obtain connections from an application server <interfacename>javax.sql.Datasource</interfacename> registered in JNDI. You will need to set at least one of the following properties:"
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:251
 #, no-c-format
 msgid "Hibernate Datasource Properties"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:264
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.datasource"
+msgid "<property>hibernate.connection.datasource</property>"
 msgstr ""
 
-#. Tag: emphasis
-#: configuration.xml:267
+#. Tag: entry
 #, no-c-format
-msgid "datasource JNDI name"
+msgid "<emphasis>datasource JNDI name</emphasis>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:272
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jndi.url"
+msgid "<property>hibernate.jndi.url</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:274
 #, no-c-format
 msgid "<emphasis>URL of the JNDI provider</emphasis> (optional)"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:280
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jndi.class"
+msgid "<property>hibernate.jndi.class</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:282
 #, no-c-format
 msgid "<emphasis>class of the JNDI <literal>InitialContextFactory</literal></emphasis> (optional)"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:290
 #, no-c-format
 msgid "<emphasis>database user</emphasis> (optional)"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:298
 #, no-c-format
 msgid "<emphasis>database user password</emphasis> (optional)"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:306
 #, no-c-format
 msgid "Here is an example <filename>hibernate.properties</filename> file for an application server provided JNDI datasource:"
 msgstr ""
 
-#. Tag: programlisting
-#: configuration.xml:311
-#, no-c-format
-msgid ""
-      "<![CDATA[hibernate.connection.datasource = java:/comp/env/jdbc/test\n"
-      "hibernate.transaction.factory_class = \\\n"
-      "    org.hibernate.transaction.JTATransactionFactory\n"
-      "hibernate.transaction.manager_lookup_class = \\\n"
-      "    org.hibernate.transaction.JBossTransactionManagerLookup\n"
-      "hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:313
 #, no-c-format
 msgid "JDBC connections obtained from a JNDI datasource will automatically participate in the container-managed transactions of the application server."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:318
 #, no-c-format
 msgid "Arbitrary connection properties can be given by prepending \"<literal>hibernate.connection</literal>\" to the connection property name. For example, you can specify a <property>charSet</property> connection property using <property>hibernate.connection.charSet</property>."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:324
 #, no-c-format
 msgid "You can define your own plugin strategy for obtaining JDBC connections by implementing the interface <interfacename>org.hibernate.connection.ConnectionProvider</interfacename>, and specifying your custom implementation via the <property>hibernate.connection.provider_class</property> property."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:333
 #, no-c-format
 msgid "Optional configuration properties"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:335
 #, no-c-format
 msgid "There are a number of other properties that control the behavior of Hibernate at runtime. All are optional and have reasonable default values."
 msgstr ""
 
-#. Tag: warning
-#: configuration.xml:341
+#. Tag: para
 #, no-c-format
 msgid "<emphasis>Some of these properties are \"system-level\" only.</emphasis> System-level properties can be set only via <literal>java -Dproperty=value</literal> or <filename>hibernate.properties</filename>. They <emphasis>cannot</emphasis> be set by the other techniques described above."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:347
 #, no-c-format
 msgid "Hibernate Configuration Properties"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:360
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.dialect"
+msgid "<property>hibernate.dialect</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:362
 #, no-c-format
 msgid "The classname of a Hibernate <classname>org.hibernate.dialect.Dialect</classname> which allows Hibernate to generate SQL optimized for a particular relational database."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:365
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>full.classname.of.Dialect</literal>"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:369
 #, no-c-format
 msgid "In most cases Hibernate will actually be able to choose the correct <classname>org.hibernate.dialect.Dialect</classname> implementation based on the <literal>JDBC metadata</literal> returned by the JDBC driver."
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:378
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.show_sql"
+msgid "<property>hibernate.show_sql</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:380
 #, no-c-format
 msgid "Write all SQL statements to console. This is an alternative to setting the log category <literal>org.hibernate.SQL</literal> to <literal>debug</literal>."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:384 configuration.xml:396 configuration.xml:490 configuration.xml:503 configuration.xml:516 configuration.xml:529 configuration.xml:583 configuration.xml:610 configuration.xml:623 configuration.xml:678 configuration.xml:906 configuration.xml:921 configuration.xml:1011
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>true</literal> | <literal>false</literal>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:392
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.format_sql"
+msgid "<property>hibernate.format_sql</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:394
 #, no-c-format
 msgid "Pretty print the SQL in the log and console."
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:404
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_schema"
+msgid "<property>hibernate.default_schema</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:406
 #, no-c-format
 msgid "Qualify unqualified table names with the given schema/tablespace in generated SQL."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:409
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>SCHEMA_NAME</literal>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:417
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_catalog"
+msgid "<property>hibernate.default_catalog</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:419
 #, no-c-format
 msgid "Qualifies unqualified table names with the given catalog in generated SQL."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:422
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>CATALOG_NAME</literal>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:430
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.session_factory_name"
+msgid "<property>hibernate.session_factory_name</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:432
 #, no-c-format
 msgid "The <interfacename>org.hibernate.SessionFactory</interfacename> will be automatically bound to this name in JNDI after it has been created."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:435 configuration.xml:877
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>jndi/composite/name</literal>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:443
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.max_fetch_depth"
+msgid "<property>hibernate.max_fetch_depth</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:445
 #, no-c-format
 msgid "Sets a maximum \"depth\" for the outer join fetch tree for single-ended associations (one-to-one, many-to-one). A <literal>0</literal> disables default outer join fetching."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:449
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> recommended values between <literal>0</literal> and <literal>3</literal>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:458
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_batch_fetch_size"
+msgid "<property>hibernate.default_batch_fetch_size</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:460
 #, no-c-format
 msgid "Sets a default size for Hibernate batch fetching of associations."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:462
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> recommended values <literal>4</literal>, <literal>8</literal>, <literal>16</literal>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:471
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_entity_mode"
+msgid "<property>hibernate.default_entity_mode</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:473
 #, no-c-format
 msgid "Sets a default mode for entity representation for all sessions opened from this <literal>SessionFactory</literal>"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:476
 #, no-c-format
 msgid "<literal>dynamic-map</literal>, <literal>dom4j</literal>, <literal>pojo</literal>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:484
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.order_updates"
+msgid "<property>hibernate.order_updates</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:486
 #, no-c-format
 msgid "Forces Hibernate to order SQL updates by the primary key value of the items being updated. This will result in fewer transaction deadlocks in highly concurrent systems."
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:498
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.generate_statistics"
+msgid "<property>hibernate.generate_statistics</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:500
 #, no-c-format
 msgid "If enabled, Hibernate will collect statistics useful for performance tuning."
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:511
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.use_identifier_rollback"
+msgid "<property>hibernate.use_identifier_rollback</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:513
 #, no-c-format
 msgid "If enabled, generated identifier properties will be reset to default values when objects are deleted."
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:524
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.use_sql_comments"
+msgid "<property>hibernate.use_sql_comments</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:526
 #, no-c-format
 msgid "If turned on, Hibernate will generate comments inside the SQL, for easier debugging, defaults to <literal>false</literal>."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:540
 #, no-c-format
 msgid "Hibernate JDBC and Connection Properties"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:555
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.fetch_size"
+msgid "<property>hibernate.jdbc.fetch_size</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:557
 #, no-c-format
 msgid "A non-zero value determines the JDBC fetch size (calls <literal>Statement.setFetchSize()</literal>)."
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:564
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.batch_size"
+msgid "<property>hibernate.jdbc.batch_size</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:566
 #, no-c-format
 msgid "A non-zero value enables use of JDBC2 batch updates by Hibernate."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:568
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> recommended values between <literal>5</literal> and <literal>30</literal>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:576
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.batch_versioned_data"
+msgid "<property>hibernate.jdbc.batch_versioned_data</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:578
 #, no-c-format
 msgid "Set this property to <literal>true</literal> if your JDBC driver returns correct row counts from <literal>executeBatch()</literal>. Iit is usually safe to turn this option on. Hibernate will then use batched DML for automatically versioned data. Defaults to <literal>false</literal>."
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:591
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.factory_class"
+msgid "<property>hibernate.jdbc.factory_class</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:593
 #, no-c-format
 msgid "Select a custom <interfacename>org.hibernate.jdbc.Batcher</interfacename>. Most applications will not need this configuration property."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:596
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of.BatcherFactory</literal>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:604
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_scrollable_resultset"
+msgid "<property>hibernate.jdbc.use_scrollable_resultset</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:606
 #, no-c-format
 msgid "Enables use of JDBC2 scrollable resultsets by Hibernate. This property is only necessary when using user-supplied JDBC connections. Hibernate uses connection metadata otherwise."
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:618
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_streams_for_binary"
+msgid "<property>hibernate.jdbc.use_streams_for_binary</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:620
 #, no-c-format
 msgid "Use streams when writing/reading <literal>binary</literal> or <literal>serializable</literal> types to/from JDBC. <emphasis>*system-level property*</emphasis>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:631
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_get_generated_keys"
+msgid "<property>hibernate.jdbc.use_get_generated_keys</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:633
 #, no-c-format
 msgid "Enables use of JDBC3 <literal>PreparedStatement.getGeneratedKeys()</literal> to retrieve natively generated keys after insert. Requires JDBC3+ driver and JRE1.4+, set to false if your driver has problems with the Hibernate identifier generators. By default, it tries to determine the driver capabilities using connection metadata."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:639 configuration.xml:769 configuration.xml:781 configuration.xml:795 configuration.xml:833
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>true|false</literal>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:647
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.provider_class"
+msgid "<property>hibernate.connection.provider_class</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:649
 #, no-c-format
 msgid "The classname of a custom <interfacename>org.hibernate.connection.ConnectionProvider</interfacename> which provides JDBC connections to Hibernate."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:652
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of.ConnectionProvider</literal>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:660
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.isolation"
+msgid "<property>hibernate.connection.isolation</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:662
 #, no-c-format
 msgid "Sets the JDBC transaction isolation level. Check <interfacename>java.sql.Connection</interfacename> for meaningful values, but note that most databases do not support all isolation levels and some define additional, non-standard isolations."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:666
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>1, 2, 4, 8</literal>"
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:674
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.autocommit"
+msgid "<property>hibernate.connection.autocommit</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:676
 #, no-c-format
 msgid "Enables autocommit for JDBC pooled connections (it is not recommended)."
 msgstr ""
 
-#. Tag: property
-#: configuration.xml:686
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.release_mode"
+msgid "<property>hibernate.connection.release_mode</property>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:688
 #, no-c-format
 msgid "Specifies when Hibernate should release JDBC connections. By default, a JDBC connection is held until the session is explicitly closed or disconnected. For an application server JTA datasource, use <literal>after_statement</literal> to aggressively release connections after every JDBC call. For a non-JTA connection, it often makes sense to release the connection at the end of each transaction, by using <literal>after_transaction</literal>. <literal>auto</literal> will choose <literal>after_statement</literal> for the JTA and CMT transaction strategies and <literal>after_transaction</literal> for the JDBC transaction strategy."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:699
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>auto</literal> (default) | <literal>on_close</literal> | <literal>after_transaction</literal> | <literal>after_statement</literal>"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:704
 #, no-c-format
-msgid "This setting only affects <literal>Session</literal>s returned from <literal>SessionFactory.openSession</literal>. For <literal>Session</literal>s obtained through <literal>SessionFactory.getCurrentSession</literal>, the <literal>CurrentSessionContext</literal> implementation configured for use controls the connection release mode for those <literal>Session</literal>s. See"
+msgid "This setting only affects <literal>Session</literal>s returned from <literal>SessionFactory.openSession</literal>. For <literal>Session</literal>s obtained through <literal>SessionFactory.getCurrentSession</literal>, the <literal>CurrentSessionContext</literal> implementation configured for use controls the connection release mode for those <literal>Session</literal>s. See <xref linkend=\"architecture-current-session\" />"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:715
 #, no-c-format
 msgid "<property>hibernate.connection.</property><emphasis>&lt;propertyName&gt;</emphasis>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:718
 #, no-c-format
 msgid "Pass the JDBC property <emphasis>&lt;propertyName&gt;</emphasis> to <literal>DriverManager.getConnection()</literal>."
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:724
 #, no-c-format
 msgid "<property>hibernate.jndi.</property><emphasis>&lt;propertyName&gt;</emphasis>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:727
 #, no-c-format
 msgid "Pass the property <emphasis>&lt;propertyName&gt;</emphasis> to the JNDI <literal>InitialContextFactory</literal>."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:737
 #, no-c-format
 msgid "Hibernate Cache Properties"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:750
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.provider_class"
+msgid "<literal>hibernate.cache.provider_class</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:752
 #, no-c-format
 msgid "The classname of a custom <literal>CacheProvider</literal>."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:754
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of.CacheProvider</literal>"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:762
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_minimal_puts"
+msgid "<literal>hibernate.cache.use_minimal_puts</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:764
 #, no-c-format
 msgid "Optimizes second-level cache operation to minimize writes, at the cost of more frequent reads. This setting is most useful for clustered caches and, in Hibernate3, is enabled by default for clustered cache implementations."
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:777
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_query_cache"
+msgid "<literal>hibernate.cache.use_query_cache</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:779
 #, no-c-format
 msgid "Enables the query cache. Individual queries still have to be set cachable."
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:789
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_second_level_cache"
+msgid "<literal>hibernate.cache.use_second_level_cache</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:791
 #, no-c-format
 msgid "Can be used to completely disable the second level cache, which is enabled by default for classes which specify a <literal>&lt;cache&gt;</literal> mapping."
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:803
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.query_cache_factory"
+msgid "<literal>hibernate.cache.query_cache_factory</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:805
 #, no-c-format
 msgid "The classname of a custom <literal>QueryCache</literal> interface, defaults to the built-in <literal>StandardQueryCache</literal>."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:808
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of.QueryCache</literal>"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:816
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.region_prefix"
+msgid "<literal>hibernate.cache.region_prefix</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:818
 #, no-c-format
 msgid "A prefix to use for second-level cache region names."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:820
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>prefix</literal>"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:828
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_structured_entries"
+msgid "<literal>hibernate.cache.use_structured_entries</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:830
 #, no-c-format
 msgid "Forces Hibernate to store data in the second-level cache in a more human-friendly format."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:844
 #, no-c-format
 msgid "Hibernate Transaction Properties"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:857
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.transaction.factory_class"
+msgid "<literal>hibernate.transaction.factory_class</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:859
 #, no-c-format
 msgid "The classname of a <literal>TransactionFactory</literal> to use with Hibernate <literal>Transaction</literal> API (defaults to <literal>JDBCTransactionFactory</literal>)."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:863
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of.TransactionFactory</literal>"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:871
+#. Tag: entry
 #, no-c-format
-msgid "jta.UserTransaction"
+msgid "<literal>jta.UserTransaction</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:873
 #, no-c-format
 msgid "A JNDI name used by <literal>JTATransactionFactory</literal> to obtain the JTA <literal>UserTransaction</literal> from the application server."
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:885
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.transaction.manager_lookup_class"
+msgid "<literal>hibernate.transaction.manager_lookup_class</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:887
 #, no-c-format
 msgid "The classname of a <literal>TransactionManagerLookup</literal>. It is required when JVM-level caching is enabled or when using hilo generator in a JTA environment."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:891
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of.TransactionManagerLookup</literal>"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:899
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.transaction.flush_before_completion"
+msgid "<literal>hibernate.transaction.flush_before_completion</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:901
 #, no-c-format
-msgid "If enabled, the session will be automatically flushed during the before completion phase of the transaction. Built-in and automatic session context management is preferred, see <xref linkend=\"architecture-current-session\"/>."
+msgid "If enabled, the session will be automatically flushed during the before completion phase of the transaction. Built-in and automatic session context management is preferred, see <xref linkend=\"architecture-current-session\" />."
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:914
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.transaction.auto_close_session"
+msgid "<literal>hibernate.transaction.auto_close_session</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:916
 #, no-c-format
-msgid "If enabled, the session will be automatically closed during the after completion phase of the transaction. Built-in and automatic session context management is preferred, see <xref linkend=\"architecture-current-session\"/>."
+msgid "If enabled, the session will be automatically closed during the after completion phase of the transaction. Built-in and automatic session context management is preferred, see <xref linkend=\"architecture-current-session\" />."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:932
 #, no-c-format
 msgid "Miscellaneous Properties"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:945
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.current_session_context_class"
+msgid "<literal>hibernate.current_session_context_class</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:947
 #, no-c-format
-msgid "Supply a custom strategy for the scoping of the \"current\" <literal>Session</literal>. See <xref linkend=\"architecture-current-session\"/> for more information about the built-in strategies."
+msgid "Supply a custom strategy for the scoping of the \"current\" <literal>Session</literal>. See <xref linkend=\"architecture-current-session\" /> for more information about the built-in strategies."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:952
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>jta</literal> | <literal>thread</literal> | <literal>managed</literal> | <literal>custom.Class</literal>"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:961
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.query.factory_class"
+msgid "<literal>hibernate.query.factory_class</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:963
 #, no-c-format
 msgid "Chooses the HQL parser implementation."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:965
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>org.hibernate.hql.ast.ASTQueryTranslatorFactory</literal> or <literal>org.hibernate.hql.classic.ClassicQueryTranslatorFactory</literal>"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:974
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.query.substitutions"
+msgid "<literal>hibernate.query.substitutions</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:976
 #, no-c-format
 msgid "Is used to map from tokens in Hibernate queries to SQL tokens (tokens might be function or literal names, for example)."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:979
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC</literal>"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:987
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.hbm2ddl.auto"
+msgid "<literal>hibernate.hbm2ddl.auto</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:989
 #, no-c-format
 msgid "Automatically validates or exports schema DDL to the database when the <literal>SessionFactory</literal> is created. With <literal>create-drop</literal>, the database schema will be dropped when the <literal>SessionFactory</literal> is closed explicitly."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:995
 #, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>validate</literal> | <literal>update</literal> | <literal>create</literal> | <literal>create-drop</literal>"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1004
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cglib.use_reflection_optimizer"
+msgid "<literal>hibernate.cglib.use_reflection_optimizer</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1006
 #, no-c-format
 msgid "Enables the use of CGLIB instead of runtime reflection (System-level property). Reflection can sometimes be useful when troubleshooting. Hibernate always requires CGLIB even if you turn off the optimizer. You cannot set this property in <literal>hibernate.cfg.xml</literal>."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1022
 #, no-c-format
 msgid "SQL Dialects"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1024
 #, no-c-format
 msgid "Always set the <literal>hibernate.dialect</literal> property to the correct <literal>org.hibernate.dialect.Dialect</literal> subclass for your database. If you specify a dialect, Hibernate will use sensible defaults for some of the other properties listed above. This means that you will not have to specify them manually."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1032
 #, no-c-format
 msgid "Hibernate SQL Dialects (<literal>hibernate.dialect</literal>)"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1040
 #, no-c-format
 msgid "RDBMS"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1041
 #, no-c-format
 msgid "Dialect"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1046
 #, no-c-format
-msgid "<entry>DB2</entry>"
+msgid "DB2"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1046
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2Dialect"
+msgid "<literal>org.hibernate.dialect.DB2Dialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1049
 #, no-c-format
 msgid "DB2 AS/400"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1049
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2400Dialect"
+msgid "<literal>org.hibernate.dialect.DB2400Dialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1052
 #, no-c-format
 msgid "DB2 OS390"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1052
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2390Dialect"
+msgid "<literal>org.hibernate.dialect.DB2390Dialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1055
 #, no-c-format
 msgid "PostgreSQL"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1055
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.PostgreSQLDialect"
+msgid "<literal>org.hibernate.dialect.PostgreSQLDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1058
 #, no-c-format
 msgid "MySQL"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1058
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLDialect"
+msgid "<literal>org.hibernate.dialect.MySQLDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1061
 #, no-c-format
 msgid "MySQL with InnoDB"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1061
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLInnoDBDialect"
+msgid "<literal>org.hibernate.dialect.MySQLInnoDBDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1064
 #, no-c-format
 msgid "MySQL with MyISAM"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1064
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLMyISAMDialect"
+msgid "<literal>org.hibernate.dialect.MySQLMyISAMDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1067
 #, no-c-format
 msgid "Oracle (any version)"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1067
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.OracleDialect"
+msgid "<literal>org.hibernate.dialect.OracleDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1070
 #, no-c-format
 msgid "Oracle 9i"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1070
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.Oracle9iDialect"
+msgid "<literal>org.hibernate.dialect.Oracle9iDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1073
 #, no-c-format
 msgid "Oracle 10g"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1073
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.Oracle10gDialect"
+msgid "<literal>org.hibernate.dialect.Oracle10gDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1076
 #, no-c-format
 msgid "Sybase"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1076
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SybaseDialect"
+msgid "<literal>org.hibernate.dialect.SybaseDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1079
 #, no-c-format
 msgid "Sybase Anywhere"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1079
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SybaseAnywhereDialect"
+msgid "<literal>org.hibernate.dialect.SybaseAnywhereDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1082
 #, no-c-format
 msgid "Microsoft SQL Server"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1082
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SQLServerDialect"
+msgid "<literal>org.hibernate.dialect.SQLServerDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1085
 #, no-c-format
 msgid "SAP DB"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1085
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SAPDBDialect"
+msgid "<literal>org.hibernate.dialect.SAPDBDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1088
 #, no-c-format
 msgid "Informix"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1088
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.InformixDialect"
+msgid "<literal>org.hibernate.dialect.InformixDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1091
 #, no-c-format
 msgid "HypersonicSQL"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1091
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.HSQLDialect"
+msgid "<literal>org.hibernate.dialect.HSQLDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1094
 #, no-c-format
 msgid "Ingres"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1094
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.IngresDialect"
+msgid "<literal>org.hibernate.dialect.IngresDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1097
 #, no-c-format
 msgid "Progress"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1097
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.ProgressDialect"
+msgid "<literal>org.hibernate.dialect.ProgressDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1100
 #, no-c-format
 msgid "Mckoi SQL"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1100
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MckoiDialect"
+msgid "<literal>org.hibernate.dialect.MckoiDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1103
 #, no-c-format
 msgid "Interbase"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1103
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.InterbaseDialect"
+msgid "<literal>org.hibernate.dialect.InterbaseDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1106
 #, no-c-format
 msgid "Pointbase"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1106
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.PointbaseDialect"
+msgid "<literal>org.hibernate.dialect.PointbaseDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1109
 #, no-c-format
 msgid "FrontBase"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1109
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.FrontbaseDialect"
+msgid "<literal>org.hibernate.dialect.FrontbaseDialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1112
 #, no-c-format
 msgid "Firebird"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1112
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.FirebirdDialect"
+msgid "<literal>org.hibernate.dialect.FirebirdDialect</literal>"
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1121
 #, no-c-format
 msgid "Outer Join Fetching"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1123
 #, no-c-format
 msgid "If your database supports ANSI, Oracle or Sybase style outer joins, <emphasis>outer join fetching</emphasis> will often increase performance by limiting the number of round trips to and from the database. This is, however, at the cost of possibly more work performed by the database itself. Outer join fetching allows a whole graph of objects connected by many-to-one, one-to-many, many-to-many and one-to-one associations to be retrieved in a single SQL <literal>SELECT</literal>."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1132
 #, no-c-format
 msgid "Outer join fetching can be disabled <emphasis>globally</emphasis> by setting the property <literal>hibernate.max_fetch_depth</literal> to <literal>0</literal>. A setting of <literal>1</literal> or higher enables outer join fetching for one-to-one and many-to-one associations that have been mapped with <literal>fetch=\"join\"</literal>."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1140
 #, no-c-format
-msgid "See <xref linkend=\"performance-fetching\"/> for more information."
+msgid "See <xref linkend=\"performance-fetching\" /> for more information."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1147
 #, no-c-format
 msgid "Binary Streams"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1149
 #, no-c-format
 msgid "Oracle limits the size of <literal>byte</literal> arrays that can be passed to and/or from its JDBC driver. If you wish to use large instances of <literal>binary</literal> or <literal>serializable</literal> type, you should enable <literal>hibernate.jdbc.use_streams_for_binary</literal>. <emphasis>This is a system-level setting only.</emphasis>"
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1160
 #, no-c-format
 msgid "Second-level and query cache"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1162
 #, no-c-format
-msgid "The properties prefixed by <literal>hibernate.cache</literal> allow you to use a process or cluster scoped second-level cache system with Hibernate. See the <xref linkend=\"performance-cache\"/> for more information."
+msgid "The properties prefixed by <literal>hibernate.cache</literal> allow you to use a process or cluster scoped second-level cache system with Hibernate. See the <xref linkend=\"performance-cache\" /> for more information."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1172
 #, no-c-format
 msgid "Query Language Substitution"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1174
 #, no-c-format
 msgid "You can define new Hibernate query tokens using <literal>hibernate.query.substitutions</literal>. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: configuration.xml:1179
-#, no-c-format
-msgid "hibernate.query.substitutions true=1, false=0"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1181
 #, no-c-format
 msgid "This would cause the tokens <literal>true</literal> and <literal>false</literal> to be translated to integer literals in the generated SQL."
 msgstr ""
 
-#. Tag: programlisting
-#: configuration.xml:1186
-#, no-c-format
-msgid "hibernate.query.substitutions toLowercase=LOWER"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1188
 #, no-c-format
 msgid "This would allow you to rename the SQL <literal>LOWER</literal> function."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1195
 #, no-c-format
 msgid "Hibernate statistics"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1197
 #, no-c-format
 msgid "If you enable <literal>hibernate.generate_statistics</literal>, Hibernate exposes a number of metrics that are useful when tuning a running system via <literal>SessionFactory.getStatistics()</literal>. Hibernate can even be configured to expose these statistics via JMX. Read the Javadoc of the interfaces in <literal>org.hibernate.stats</literal> for more information."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1209
 #, no-c-format
 msgid "Logging"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1211
 #, no-c-format
 msgid "Hibernate utilizes <ulink url=\"http://www.slf4j.org/\">Simple Logging Facade for Java</ulink> (SLF4J) in order to log various system events. SLF4J can direct your logging output to several logging frameworks (NOP, Simple, log4j version 1.2, JDK 1.4 logging, JCL or logback) depending on your chosen binding. In order to setup logging you will need <filename>slf4j-api.jar</filename> in your classpath together with the jar file for your preferred binding - <filename>slf4j-log4j12.jar</filename> in the case of Log4J. See the SLF4J <ulink url=\"http://www.slf4j.org/manual.html\">documentation</ulink> for more detail. To use Log4j you will also need to place a <filename>log4j.properties</filename> file in your classpath. An example properties file is distributed with Hibernate in the <literal>src/</literal> directory."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1222
 #, no-c-format
 msgid "It is recommended that you familiarize yourself with Hibernate's log messages. A lot of work has been put into making the Hibernate log as detailed as possible, without making it unreadable. It is an essential troubleshooting device. The most interesting log categories are the following:"
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1231
 #, no-c-format
 msgid "Hibernate Log Categories"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1237
 #, no-c-format
 msgid "Category"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1238
 #, no-c-format
 msgid "Function"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1243
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.SQL"
+msgid "<literal>org.hibernate.SQL</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1244
 #, no-c-format
 msgid "Log all SQL DML statements as they are executed"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1247
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.type"
+msgid "<literal>org.hibernate.type</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1248
 #, no-c-format
 msgid "Log all JDBC parameters"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1251
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.tool.hbm2ddl"
+msgid "<literal>org.hibernate.tool.hbm2ddl</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1252
 #, no-c-format
 msgid "Log all SQL DDL statements as they are executed"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1255
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.pretty"
+msgid "<literal>org.hibernate.pretty</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1256
 #, no-c-format
 msgid "Log the state of all entities (max 20 entities) associated with the session at flush time"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1262
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.cache"
+msgid "<literal>org.hibernate.cache</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1263
 #, no-c-format
 msgid "Log all second-level cache activity"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1266
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.transaction"
+msgid "<literal>org.hibernate.transaction</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1267
 #, no-c-format
 msgid "Log transaction related activity"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1270
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.jdbc"
+msgid "<literal>org.hibernate.jdbc</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1271
 #, no-c-format
 msgid "Log all JDBC resource acquisition"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1274
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.hql.ast.AST"
+msgid "<literal>org.hibernate.hql.ast.AST</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1275
 #, no-c-format
 msgid "Log HQL and SQL ASTs during query parsing"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1280
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.secure"
+msgid "<literal>org.hibernate.secure</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1281
 #, no-c-format
 msgid "Log all JAAS authorization requests"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1284
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate"
+msgid "<literal>org.hibernate</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1285
 #, no-c-format
 msgid "Log everything. This is a lot of information but it is useful for troubleshooting"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1294
 #, no-c-format
 msgid "When developing applications with Hibernate, you should almost always work with <literal>debug</literal> enabled for the category <literal>org.hibernate.SQL</literal>, or, alternatively, the property <literal>hibernate.show_sql</literal> enabled."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1304
 #, no-c-format
 msgid "Implementing a <literal>NamingStrategy</literal>"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1306
 #, no-c-format
 msgid "The interface <literal>org.hibernate.cfg.NamingStrategy</literal> allows you to specify a \"naming standard\" for database objects and schema elements."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1311
 #, no-c-format
 msgid "You can provide rules for automatically generating database identifiers from Java identifiers or for processing \"logical\" column and table names given in the mapping file into \"physical\" table and column names. This feature helps reduce the verbosity of the mapping document, eliminating repetitive noise (<literal>TBL_</literal> prefixes, for example). The default strategy used by Hibernate is quite minimal."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1320
 #, no-c-format
 msgid "You can specify a different strategy by calling <literal>Configuration.setNamingStrategy()</literal> before adding mappings:"
 msgstr ""
 
-#. Tag: programlisting
-#: configuration.xml:1325
-#, no-c-format
-msgid ""
-      "<![CDATA[SessionFactory sf = new Configuration()\n"
-      "    .setNamingStrategy(ImprovedNamingStrategy.INSTANCE)\n"
-      "    .addFile(\"Item.hbm.xml\")\n"
-      "    .addFile(\"Bid.hbm.xml\")\n"
-      "    .buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1327
 #, no-c-format
 msgid "<literal>org.hibernate.cfg.ImprovedNamingStrategy</literal> is a built-in strategy that might be a useful starting point for some applications."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1335
 #, no-c-format
 msgid "XML configuration file"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1337
 #, no-c-format
 msgid "An alternative approach to configuration is to specify a full configuration in a file named <literal>hibernate.cfg.xml</literal>. This file can be used as a replacement for the <literal>hibernate.properties</literal> file or, if both are present, to override properties."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1344
 #, no-c-format
 msgid "The XML configuration file is by default expected to be in the root of your <literal>CLASSPATH</literal>. Here is an example:"
 msgstr ""
 
-#. Tag: programlisting
-#: configuration.xml:1349
-#, no-c-format
-msgid ""
-      "<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-      "<!DOCTYPE hibernate-configuration PUBLIC\n"
-      "    \"-//Hibernate/Hibernate Configuration DTD//EN\"\n"
-      "    \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd\">\n"
-      "\n"
-      "<hibernate-configuration>\n"
-      "\n"
-      "    <!-- a SessionFactory instance listed as /jndi/name -->\n"
-      "    <session-factory\n"
-      "        name=\"java:hibernate/SessionFactory\">\n"
-      "\n"
-      "        <!-- properties -->\n"
-      "        <property name=\"connection.datasource\">java:/comp/env/jdbc/MyDB</property>\n"
-      "        <property name=\"dialect\">org.hibernate.dialect.MySQLDialect</property>\n"
-      "        <property name=\"show_sql\">false</property>\n"
-      "        <property name=\"transaction.factory_class\">\n"
-      "            org.hibernate.transaction.JTATransactionFactory\n"
-      "        </property>\n"
-      "        <property name=\"jta.UserTransaction\">java:comp/UserTransaction</property>\n"
-      "\n"
-      "        <!-- mapping files -->\n"
-      "        <mapping resource=\"org/hibernate/auction/Item.hbm.xml\"/>\n"
-      "        <mapping resource=\"org/hibernate/auction/Bid.hbm.xml\"/>\n"
-      "\n"
-      "        <!-- cache settings -->\n"
-      "        <class-cache class=\"org.hibernate.auction.Item\" usage=\"read-write\"/>\n"
-      "        <class-cache class=\"org.hibernate.auction.Bid\" usage=\"read-only\"/>\n"
-      "        <collection-cache collection=\"org.hibernate.auction.Item.bids\" usage=\"read-write\"/>\n"
-      "\n"
-      "    </session-factory>\n"
-      "\n"
-      "</hibernate-configuration>]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1351
 #, no-c-format
 msgid "The advantage of this approach is the externalization of the mapping file names to configuration. The <literal>hibernate.cfg.xml</literal> is also more convenient once you have to tune the Hibernate cache. It is your choice to use either <literal>hibernate.properties</literal> or <literal>hibernate.cfg.xml</literal>. Both are equivalent, except for the above mentioned benefits of using the XML syntax."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1360
 #, no-c-format
 msgid "With the XML configuration, starting Hibernate is then as simple as:"
 msgstr ""
 
-#. Tag: programlisting
-#: configuration.xml:1364
-#, no-c-format
-msgid "<![CDATA[SessionFactory sf = new Configuration().configure().buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1366
 #, no-c-format
 msgid "You can select a different XML configuration file using:"
 msgstr ""
 
-#. Tag: programlisting
-#: configuration.xml:1370
-#, no-c-format
-msgid ""
-      "<![CDATA[SessionFactory sf = new Configuration()\n"
-      "    .configure(\"catdb.cfg.xml\")\n"
-      "    .buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: title
-#: configuration.xml:1375
 #, no-c-format
 msgid "J2EE Application Server integration"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1377
 #, no-c-format
 msgid "Hibernate has the following integration points for J2EE infrastructure:"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1383
 #, no-c-format
 msgid "<emphasis>Container-managed datasources</emphasis>: Hibernate can use JDBC connections managed by the container and provided through JNDI. Usually, a JTA compatible <literal>TransactionManager</literal> and a <literal>ResourceManager</literal> take care of transaction management (CMT), especially distributed transaction handling across several datasources. You can also demarcate transaction boundaries programmatically (BMT), or you might want to use the optional Hibernate <literal>Transaction</literal> API for this to keep your code portable."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1398
 #, no-c-format
 msgid "<emphasis>Automatic JNDI binding</emphasis>: Hibernate can bind its <literal>SessionFactory</literal> to JNDI after startup."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1407
 #, no-c-format
 msgid "<emphasis>JTA Session binding:</emphasis> the Hibernate <literal>Session</literal> can be automatically bound to the scope of JTA transactions. Simply lookup the <literal>SessionFactory</literal> from JNDI and get the current <literal>Session</literal>. Let Hibernate manage flushing and closing the <literal>Session</literal> when your JTA transaction completes. Transaction demarcation is either declarative (CMT) or programmatic (BMT/UserTransaction)."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1420
 #, no-c-format
 msgid "<emphasis>JMX deployment:</emphasis> if you have a JMX capable application server (e.g. JBoss AS), you can choose to deploy Hibernate as a managed MBean. This saves you the one line startup code to build your <literal>SessionFactory</literal> from a <literal>Configuration</literal>. The container will startup your <literal>HibernateService</literal> and also take care of service dependencies (datasource has to be available before Hibernate starts, etc)."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1431
 #, no-c-format
 msgid "Depending on your environment, you might have to set the configuration option <literal>hibernate.connection.aggressive_release</literal> to true if your application server shows \"connection containment\" exceptions."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1438
 #, no-c-format
 msgid "Transaction strategy configuration"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1440
 #, no-c-format
 msgid "The Hibernate <literal>Session</literal> API is independent of any transaction demarcation system in your architecture. If you let Hibernate use JDBC directly through a connection pool, you can begin and end your transactions by calling the JDBC API. If you run in a J2EE application server, you might want to use bean-managed transactions and call the JTA API and <literal>UserTransaction</literal> when needed."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1448
 #, no-c-format
 msgid "To keep your code portable between these two (and other) environments we recommend the optional Hibernate <literal>Transaction</literal> API, which wraps and hides the underlying system. You have to specify a factory class for <literal>Transaction</literal> instances by setting the Hibernate configuration property <literal>hibernate.transaction.factory_class</literal>."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1455
 #, no-c-format
 msgid "There are three standard, or built-in, choices:"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1461
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.JDBCTransactionFactory"
+msgid "<literal>org.hibernate.transaction.JDBCTransactionFactory</literal>"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1463
 #, no-c-format
 msgid "delegates to database (JDBC) transactions (default)"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1467
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.JTATransactionFactory"
+msgid "<literal>org.hibernate.transaction.JTATransactionFactory</literal>"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1469
 #, no-c-format
 msgid "delegates to container-managed transactions if an existing transaction is underway in this context (for example, EJB session bean method). Otherwise, a new transaction is started and bean-managed transactions are used."
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1477
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.CMTTransactionFactory"
+msgid "<literal>org.hibernate.transaction.CMTTransactionFactory</literal>"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1479
 #, no-c-format
 msgid "delegates to container-managed JTA transactions"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1484
 #, no-c-format
 msgid "You can also define your own transaction strategies (for a CORBA transaction service, for example)."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1489
 #, no-c-format
 msgid "Some features in Hibernate (i.e., the second level cache, Contextual Sessions with JTA, etc.) require access to the JTA <literal>TransactionManager</literal> in a managed environment. In an application server, since J2EE does not standardize a single mechanism, you have to specify how Hibernate should obtain a reference to the <literal>TransactionManager</literal>:"
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1497
 #, no-c-format
 msgid "JTA TransactionManagers"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1503
 #, no-c-format
 msgid "Transaction Factory"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1504
 #, no-c-format
 msgid "Application Server"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1509
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.transaction.JBossTransactionManagerLookup"
+msgid "<literal>org.hibernate.transaction.JBossTransactionManagerLookup</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1510
 #, no-c-format
 msgid "JBoss"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1513
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.transaction.WeblogicTransactionManagerLookup"
+msgid "<literal>org.hibernate.transaction.WeblogicTransactionManagerLookup</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1514
 #, no-c-format
 msgid "Weblogic"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1517
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.transaction.WebSphereTransactionManagerLookup"
+msgid "<literal>org.hibernate.transaction.WebSphereTransactionManagerLookup</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1518
 #, no-c-format
 msgid "WebSphere"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1521
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.transaction.WebSphereExtendedJTATransactionLookup"
+msgid "<literal>org.hibernate.transaction.WebSphereExtendedJTATransactionLookup</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1522
 #, no-c-format
 msgid "WebSphere 6"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1525
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.transaction.OrionTransactionManagerLookup"
+msgid "<literal>org.hibernate.transaction.OrionTransactionManagerLookup</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1526
 #, no-c-format
 msgid "Orion"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1529
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.transaction.ResinTransactionManagerLookup"
+msgid "<literal>org.hibernate.transaction.ResinTransactionManagerLookup</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1530
 #, no-c-format
 msgid "Resin"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1533
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.transaction.JOTMTransactionManagerLookup"
+msgid "<literal>org.hibernate.transaction.JOTMTransactionManagerLookup</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1534
 #, no-c-format
 msgid "JOTM"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1537
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.transaction.JOnASTransactionManagerLookup"
+msgid "<literal>org.hibernate.transaction.JOnASTransactionManagerLookup</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1538
 #, no-c-format
 msgid "JOnAS"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1541
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.transaction.JRun4TransactionManagerLookup"
+msgid "<literal>org.hibernate.transaction.JRun4TransactionManagerLookup</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1542
 #, no-c-format
 msgid "JRun4"
 msgstr ""
 
-#. Tag: literal
-#: configuration.xml:1545
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.transaction.BESTransactionManagerLookup"
+msgid "<literal>org.hibernate.transaction.BESTransactionManagerLookup</literal>"
 msgstr ""
 
 #. Tag: entry
-#: configuration.xml:1546
 #, no-c-format
 msgid "Borland ES"
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1555
 #, no-c-format
 msgid "JNDI-bound <literal>SessionFactory</literal>"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1557
 #, no-c-format
 msgid "A JNDI-bound Hibernate <literal>SessionFactory</literal> can simplify the lookup function of the factory and create new <literal>Session</literal>s. This is not, however, related to a JNDI bound <literal>Datasource</literal>; both simply use the same registry."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1564
 #, no-c-format
 msgid "If you wish to have the <literal>SessionFactory</literal> bound to a JNDI namespace, specify a name (e.g. <literal>java:hibernate/SessionFactory</literal>) using the property <literal>hibernate.session_factory_name</literal>. If this property is omitted, the <literal>SessionFactory</literal> will not be bound to JNDI. This is especially useful in environments with a read-only JNDI default implementation (in Tomcat, for example)."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1572
 #, no-c-format
 msgid "When binding the <literal>SessionFactory</literal> to JNDI, Hibernate will use the values of <literal>hibernate.jndi.url</literal>, <literal>hibernate.jndi.class</literal> to instantiate an initial context. If they are not specified, the default <literal>InitialContext</literal> will be used."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1579
 #, no-c-format
 msgid "Hibernate will automatically place the <literal>SessionFactory</literal> in JNDI after you call <literal>cfg.buildSessionFactory()</literal>. This means you will have this call in some startup code, or utility class in your application, unless you use JMX deployment with the <literal>HibernateService</literal> (this is discussed later in greater detail)."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1586
 #, no-c-format
 msgid "If you use a JNDI <literal>SessionFactory</literal>, an EJB or any other class, you can obtain the <literal>SessionFactory</literal> using a JNDI lookup."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1591
 #, no-c-format
 msgid "It is recommended that you bind the <literal>SessionFactory</literal> to JNDI in a managed environment and use a <literal>static</literal> singleton otherwise. To shield your application code from these details, we also recommend to hide the actual lookup code for a <literal>SessionFactory</literal> in a helper class, such as <literal>HibernateUtil.getSessionFactory()</literal>. Note that such a class is also a convenient way to startup Hibernate&mdash;see chapter 1."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1603
 #, no-c-format
 msgid "Current Session context management with JTA"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1605
 #, no-c-format
-msgid "The easiest way to handle <literal>Sessions</literal> and transactions is Hibernate's automatic \"current\" <literal>Session</literal> management. For a discussion of contextual sessions see <link linkend=\"architecture-current-session\"></link>. Using the <literal>\"jta\"</literal> session context, if there is no Hibernate <literal>Session</literal> associated with the current JTA transaction, one will be started and associated with that JTA transaction the first time you call <literal>sessionFactory.getCurrentSession()</literal>. The <literal>Session</literal>s retrieved via <literal>getCurrentSession()</literal> in the<literal>\"jta\"</literal> context are set to automatically flush before the transaction completes, close after the transaction completes, and aggressively release JDBC connections after each statement. This allows the <literal>Session</literal>s to be managed by the life cycle of the JTA transaction to which it is associated, keeping user code clean!
  of such management concerns. Your code can either use JTA programmatically through <literal>UserTransaction</literal>, or (recommended for portable code) use the Hibernate <literal>Transaction</literal> API to set transaction boundaries. If you run in an EJB container, declarative transaction demarcation with CMT is preferred."
+msgid "The easiest way to handle <literal>Sessions</literal> and transactions is Hibernate's automatic \"current\" <literal>Session</literal> management. For a discussion of contextual sessions see <xref linkend=\"architecture-current-session\" />. Using the <literal>\"jta\"</literal> session context, if there is no Hibernate <literal>Session</literal> associated with the current JTA transaction, one will be started and associated with that JTA transaction the first time you call <literal>sessionFactory.getCurrentSession()</literal>. The <literal>Session</literal>s retrieved via <literal>getCurrentSession()</literal> in the<literal>\"jta\"</literal> context are set to automatically flush before the transaction completes, close after the transaction completes, and aggressively release JDBC connections after each statement. This allows the <literal>Session</literal>s to be managed by the life cycle of the JTA transaction to which it is associated, keeping user code clean of s!
 uch management concerns. Your code can either use JTA programmatically through <literal>UserTransaction</literal>, or (recommended for portable code) use the Hibernate <literal>Transaction</literal> API to set transaction boundaries. If you run in an EJB container, declarative transaction demarcation with CMT is preferred."
 msgstr ""
 
 #. Tag: title
-#: configuration.xml:1628
 #, no-c-format
 msgid "JMX deployment"
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1630
 #, no-c-format
 msgid "The line <literal>cfg.buildSessionFactory()</literal> still has to be executed somewhere to get a <literal>SessionFactory</literal> into JNDI. You can do this either in a <literal>static</literal> initializer block, like the one in <literal>HibernateUtil</literal>, or you can deploy Hibernate as a <emphasis>managed service</emphasis>."
 msgstr ""
 
 #. Tag: para
-#: configuration.xml:1638
 #, no-c-format
 msgid "Hibernate is distributed with <literal>org.hibernate.jmx.HibernateService</literal> for deployment on an application server with JMX capabilities, such as JBoss AS. The actual deployment and configuration is vendor-specific. Here is an example <literal>jboss-service.xml</literal> for JBoss 4.0.x:"
 msgstr ""
 
-#. Tag: programlisting
-#: configuration.xml:1645
-#, no-c-format
-msgid ""
-      "<![CDATA[<?xml version=\"1.0\"?>\n"
-      "<server>\n"
-      "\n"
-      "<mbean code=\"org.hibernate.jmx.HibernateService\"\n"
-      "    name=\"jboss.jca:service=HibernateFactory,name=HibernateFactory\">\n"
-      "\n"
-      "    <!-- Required services -->\n"
-      "    <depends>jboss.jca:service=RARDeployer</depends>\n"
-      "    <depends>jboss.jca:service=LocalTxCM,name=HsqlDS</depends>\n"
-      "\n"
-      "    <!-- Bind the Hibernate service to JNDI -->\n"
-      "    <attribute name=\"JndiName\">java:/hibernate/SessionFactory</attribute>\n"
-      "\n"
-      "    <!-- Datasource settings -->\n"
-      "    <attribute name=\"Datasource\">java:HsqlDS</attribute>\n"
-      "    <attribute name=\"Dialect\">org.hibernate.dialect.HSQLDialect</attribute>\n"
-      "\n"
-      "    <!-- Transaction integration -->\n"
-      "    <attribute name=\"TransactionStrategy\">\n"
-      "        org.hibernate.transaction.JTATransactionFactory</attribute>\n"
-      "    <attribute name=\"TransactionManagerLookupStrategy\">\n"
-      "        org.hibernate.transaction.JBossTransactionManagerLookup</attribute>\n"
-      "    <attribute name=\"FlushBeforeCompletionEnabled\">true</attribute>\n"
-      "    <attribute name=\"AutoCloseSessionEnabled\">true</attribute>\n"
-      "\n"
-      "    <!-- Fetching options -->\n"
-      "    <attribute name=\"MaximumFetchDepth\">5</attribute>\n"
-      "\n"
-      "    <!-- Second-level caching -->\n"
-      "    <attribute name=\"SecondLevelCacheEnabled\">true</attribute>\n"
-      "    <attribute name=\"CacheProviderClass\">org.hibernate.cache.EhCacheProvider</attribute>\n"
-      "    <attribute name=\"QueryCacheEnabled\">true</attribute>\n"
-      "\n"
-      "    <!-- Logging -->\n"
-      "    <attribute name=\"ShowSqlEnabled\">true</attribute>\n"
-      "\n"
-      "    <!-- Mapping files -->\n"
-      "    <attribute name=\"MapResources\">auction/Item.hbm.xml,auction/Category.hbm.xml</attribute>\n"
-      "\n"
-      "</mbean>\n"
-      "\n"
-      "</server>]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1647
 #, no-c-format
 msgid "This file is deployed in a directory called <literal>META-INF</literal> and packaged in a JAR file with the extension <literal>.sar</literal> (service archive). You also need to package Hibernate, its required third-party libraries, your compiled persistent classes, as well as your mapping files in the same archive. Your enterprise beans (usually session beans) can be kept in their own JAR file, but you can include this EJB JAR file in the main service archive to get a single (hot-)deployable unit. Consult the JBoss AS documentation for more information about JMX service and EJB deployment."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/events.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/events.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/events.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,310 +1,128 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: events.xml:29
 #, no-c-format
 msgid "Interceptors and events"
 msgstr ""
 
 #. Tag: para
-#: events.xml:31
 #, no-c-format
 msgid "It is useful for the application to react to certain events that occur inside Hibernate. This allows for the implementation of generic functionality and the extension of Hibernate functionality."
 msgstr ""
 
 #. Tag: title
-#: events.xml:38
 #, no-c-format
 msgid "Interceptors"
 msgstr ""
 
 #. Tag: para
-#: events.xml:40
 #, no-c-format
 msgid "The <literal>Interceptor</literal> interface provides callbacks from the session to the application, allowing the application to inspect and/or manipulate properties of a persistent object before it is saved, updated, deleted or loaded. One possible use for this is to track auditing information. For example, the following <literal>Interceptor</literal> automatically sets the <literal>createTimestamp</literal> when an <literal>Auditable</literal> is created and updates the <literal>lastUpdateTimestamp</literal> property when an <literal>Auditable</literal> is updated."
 msgstr ""
 
 #. Tag: para
-#: events.xml:51
 #, no-c-format
 msgid "You can either implement <literal>Interceptor</literal> directly or extend <literal>EmptyInterceptor</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: events.xml:56
-#, no-c-format
-msgid ""
-      "<![CDATA[package org.hibernate.test;\n"
-      "\n"
-      "import java.io.Serializable;\n"
-      "import java.util.Date;\n"
-      "import java.util.Iterator;\n"
-      "\n"
-      "import org.hibernate.EmptyInterceptor;\n"
-      "import org.hibernate.Transaction;\n"
-      "import org.hibernate.type.Type;\n"
-      "\n"
-      "public class AuditInterceptor extends EmptyInterceptor {\n"
-      "\n"
-      "    private int updates;\n"
-      "    private int creates;\n"
-      "    private int loads;\n"
-      "\n"
-      "    public void onDelete(Object entity,\n"
-      "                         Serializable id,\n"
-      "                         Object[] state,\n"
-      "                         String[] propertyNames,\n"
-      "                         Type[] types) {\n"
-      "        // do nothing\n"
-      "    }\n"
-      "\n"
-      "    public boolean onFlushDirty(Object entity,\n"
-      "                                Serializable id,\n"
-      "                                Object[] currentState,\n"
-      "                                Object[] previousState,\n"
-      "                                String[] propertyNames,\n"
-      "                                Type[] types) {\n"
-      "\n"
-      "        if ( entity instanceof Auditable ) {\n"
-      "            updates++;\n"
-      "            for ( int i=0; i < propertyNames.length; i++ ) {\n"
-      "                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) {\n"
-      "                    currentState[i] = new Date();\n"
-      "                    return true;\n"
-      "                }\n"
-      "            }\n"
-      "        }\n"
-      "        return false;\n"
-      "    }\n"
-      "\n"
-      "    public boolean onLoad(Object entity,\n"
-      "                          Serializable id,\n"
-      "                          Object[] state,\n"
-      "                          String[] propertyNames,\n"
-      "                          Type[] types) {\n"
-      "        if ( entity instanceof Auditable ) {\n"
-      "            loads++;\n"
-      "        }\n"
-      "        return false;\n"
-      "    }\n"
-      "\n"
-      "    public boolean onSave(Object entity,\n"
-      "                          Serializable id,\n"
-      "                          Object[] state,\n"
-      "                          String[] propertyNames,\n"
-      "                          Type[] types) {\n"
-      "\n"
-      "        if ( entity instanceof Auditable ) {\n"
-      "            creates++;\n"
-      "            for ( int i=0; i<propertyNames.length; i++ ) {\n"
-      "                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
-      "                    state[i] = new Date();\n"
-      "                    return true;\n"
-      "                }\n"
-      "            }\n"
-      "        }\n"
-      "        return false;\n"
-      "    }\n"
-      "\n"
-      "    public void afterTransactionCompletion(Transaction tx) {\n"
-      "        if ( tx.wasCommitted() ) {\n"
-      "            System.out.println(\"Creations: \" + creates + \", Updates: \" + updates, \"Loads: \" + loads);\n"
-      "        }\n"
-      "        updates=0;\n"
-      "        creates=0;\n"
-      "        loads=0;\n"
-      "    }\n"
-      "\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:58
 #, no-c-format
 msgid "There are two kinds of inteceptors: <literal>Session</literal>-scoped and <literal>SessionFactory</literal>-scoped."
 msgstr ""
 
 #. Tag: para
-#: events.xml:63
 #, no-c-format
 msgid "A <literal>Session</literal>-scoped interceptor is specified when a session is opened using one of the overloaded SessionFactory.openSession() methods accepting an <literal>Interceptor</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: events.xml:69
-#, no-c-format
-msgid "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:71
 #, no-c-format
 msgid "A <literal>SessionFactory</literal>-scoped interceptor is registered with the <literal>Configuration</literal> object prior to building the <literal>SessionFactory</literal>. Unless a session is opened explicitly specifying the interceptor to use, the supplied interceptor will be applied to all sessions opened from that <literal>SessionFactory</literal>. <literal>SessionFactory</literal>-scoped interceptors must be thread safe. Ensure that you do not store session-specific states, since multiple sessions will use this interceptor potentially concurrently."
 msgstr ""
 
-#. Tag: programlisting
-#: events.xml:80
-#, no-c-format
-msgid "<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
-msgstr ""
-
 #. Tag: title
-#: events.xml:85
 #, no-c-format
 msgid "Event system"
 msgstr ""
 
 #. Tag: para
-#: events.xml:87
 #, no-c-format
 msgid "If you have to react to particular events in your persistence layer, you can also use the Hibernate3 <emphasis>event</emphasis> architecture. The event system can be used in addition, or as a replacement, for interceptors."
 msgstr ""
 
 #. Tag: para
-#: events.xml:93
 #, no-c-format
 msgid "All the methods of the <literal>Session</literal> interface correlate to an event. You have a <literal>LoadEvent</literal>, a <literal>FlushEvent</literal>, etc. Consult the XML configuration-file DTD or the <literal>org.hibernate.event</literal> package for the full list of defined event types. When a request is made of one of these methods, the Hibernate <literal>Session</literal> generates an appropriate event and passes it to the configured event listeners for that type. Out-of-the-box, these listeners implement the same processing in which those methods always resulted. However, you are free to implement a customization of one of the listener interfaces (i.e., the <literal>LoadEvent</literal> is processed by the registered implementation of the <literal>LoadEventListener</literal> interface), in which case their implementation would be responsible for processing any <literal>load()</literal> requests made of the <literal>Session</literal>."
 msgstr ""
 
 #. Tag: para
-#: events.xml:108
 #, no-c-format
 msgid "The listeners should be considered singletons. This means they are shared between requests, and should not save any state as instance variables."
 msgstr ""
 
 #. Tag: para
-#: events.xml:113
 #, no-c-format
 msgid "A custom listener implements the appropriate interface for the event it wants to process and/or extend one of the convenience base classes (or even the default event listeners used by Hibernate out-of-the-box as these are declared non-final for this purpose). Custom listeners can either be registered programmatically through the <literal>Configuration</literal> object, or specified in the Hibernate configuration XML. Declarative configuration through the properties file is not supported. Here is an example of a custom load event listener:"
 msgstr ""
 
-#. Tag: programlisting
-#: events.xml:123
-#, no-c-format
-msgid ""
-      "<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
-      "    // this is the single method defined by the LoadEventListener interface\n"
-      "    public void onLoad(LoadEvent event, LoadEventListener.LoadType loadType)\n"
-      "            throws HibernateException {\n"
-      "        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event.getEntityId() ) ) {\n"
-      "            throw MySecurityException(\"Unauthorized access\");\n"
-      "        }\n"
-      "    }\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:125
 #, no-c-format
 msgid "You also need a configuration entry telling Hibernate to use the listener in addition to the default listener:"
 msgstr ""
 
-#. Tag: programlisting
-#: events.xml:130
-#, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-configuration>\n"
-      "    <session-factory>\n"
-      "        ...\n"
-      "        <event type=\"load\">\n"
-      "            <listener class=\"com.eg.MyLoadListener\"/>\n"
-      "            <listener class=\"org.hibernate.event.def.DefaultLoadEventListener\"/>\n"
-      "        </event>\n"
-      "    </session-factory>\n"
-      "</hibernate-configuration>]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:132
 #, no-c-format
 msgid "Instead, you can register it programmatically:"
 msgstr ""
 
-#. Tag: programlisting
-#: events.xml:136
-#, no-c-format
-msgid ""
-      "<![CDATA[Configuration cfg = new Configuration();\n"
-      "LoadEventListener[] stack = { new MyLoadListener(), new DefaultLoadEventListener() };\n"
-      "cfg.EventListeners().setLoadEventListeners(stack);]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:138
 #, no-c-format
 msgid "Listeners registered declaratively cannot share instances. If the same class name is used in multiple <literal>&lt;listener/&gt;</literal> elements, each reference will result in a separate instance of that class. If you need to share listener instances between listener types you must use the programmatic registration approach."
 msgstr ""
 
 #. Tag: para
-#: events.xml:146
 #, no-c-format
 msgid "Why implement an interface and define the specific type during configuration? A listener implementation could implement multiple event listener interfaces. Having the type additionally defined during registration makes it easier to turn custom listeners on or off during configuration."
 msgstr ""
 
 #. Tag: title
-#: events.xml:156
 #, no-c-format
 msgid "Hibernate declarative security"
 msgstr ""
 
 #. Tag: para
-#: events.xml:157
 #, no-c-format
 msgid "Usually, declarative security in Hibernate applications is managed in a session facade layer. Hibernate3 allows certain actions to be permissioned via JACC, and authorized via JAAS. This is an optional functionality that is built on top of the event architecture."
 msgstr ""
 
 #. Tag: para
-#: events.xml:163
 #, no-c-format
 msgid "First, you must configure the appropriate event listeners, to enable the use of JAAS authorization."
 msgstr ""
 
-#. Tag: programlisting
-#: events.xml:168
-#, no-c-format
-msgid ""
-      "<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure.JACCPreDeleteEventListener\"/>\n"
-      "<listener type=\"pre-update\" class=\"org.hibernate.secure.JACCPreUpdateEventListener\"/>\n"
-      "<listener type=\"pre-insert\" class=\"org.hibernate.secure.JACCPreInsertEventListener\"/>\n"
-      "<listener type=\"pre-load\" class=\"org.hibernate.secure.JACCPreLoadEventListener\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:170
 #, no-c-format
 msgid "Note that <literal>&lt;listener type=\"...\" class=\"...\"/&gt;</literal> is shorthand for <literal>&lt;event type=\"...\"&gt;&lt;listener class=\"...\"/&gt;&lt;/event&gt;</literal> when there is exactly one listener for a particular event type."
 msgstr ""
 
 #. Tag: para
-#: events.xml:176
 #, no-c-format
 msgid "Next, while still in <literal>hibernate.cfg.xml</literal>, bind the permissions to roles:"
 msgstr ""
 
-#. Tag: programlisting
-#: events.xml:180
-#, no-c-format
-msgid ""
-      "<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,update,read\"/>\n"
-      "<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:182
 #, no-c-format
 msgid "The role names are the roles understood by your JACC provider."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/example_mappings.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/example_mappings.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/example_mappings.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,717 +1,119 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: example_mappings.xml:29
 #, no-c-format
 msgid "Example: Various Mappings"
 msgstr ""
 
 #. Tag: para
-#: example_mappings.xml:32
 #, no-c-format
 msgid "This chapters explores some more complex association mappings."
 msgstr ""
 
 #. Tag: title
-#: example_mappings.xml:37
 #, no-c-format
 msgid "Employer/Employee"
 msgstr ""
 
 #. Tag: para
-#: example_mappings.xml:39
 #, no-c-format
 msgid "The following model of the relationship between <literal>Employer</literal> and <literal>Employee</literal> uses an entity class (<literal>Employment</literal>) to represent the association. You can do this when there might be more than one period of employment for the same two parties. Components are used to model monetary values and employee names."
 msgstr ""
 
 #. Tag: para
-#: example_mappings.xml:56
 #, no-c-format
 msgid "Here is a possible mapping document:"
 msgstr ""
 
-#. Tag: programlisting
-#: example_mappings.xml:60
-#, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping>\n"
-      "        \n"
-      "    <class name=\"Employer\" table=\"employers\">\n"
-      "        <id name=\"id\">\n"
-      "            <generator class=\"sequence\">\n"
-      "                <param name=\"sequence\">employer_id_seq</param>\n"
-      "            </generator>\n"
-      "        </id>\n"
-      "        <property name=\"name\"/>\n"
-      "    </class>\n"
-      "\n"
-      "    <class name=\"Employment\" table=\"employment_periods\">\n"
-      "\n"
-      "        <id name=\"id\">\n"
-      "            <generator class=\"sequence\">\n"
-      "                <param name=\"sequence\">employment_id_seq</param>\n"
-      "            </generator>\n"
-      "        </id>\n"
-      "        <property name=\"startDate\" column=\"start_date\"/>\n"
-      "        <property name=\"endDate\" column=\"end_date\"/>\n"
-      "\n"
-      "        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
-      "            <property name=\"amount\">\n"
-      "                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/>\n"
-      "            </property>\n"
-      "            <property name=\"currency\" length=\"12\"/>\n"
-      "        </component>\n"
-      "\n"
-      "        <many-to-one name=\"employer\" column=\"employer_id\" not-null=\"true\"/>\n"
-      "        <many-to-one name=\"employee\" column=\"employee_id\" not-null=\"true\"/>\n"
-      "\n"
-      "    </class>\n"
-      "\n"
-      "    <class name=\"Employee\" table=\"employees\">\n"
-      "        <id name=\"id\">\n"
-      "            <generator class=\"sequence\">\n"
-      "                <param name=\"sequence\">employee_id_seq</param>\n"
-      "            </generator>\n"
-      "        </id>\n"
-      "        <property name=\"taxfileNumber\"/>\n"
-      "        <component name=\"name\" class=\"Name\">\n"
-      "            <property name=\"firstName\"/>\n"
-      "            <property name=\"initial\"/>\n"
-      "            <property name=\"lastName\"/>\n"
-      "        </component>\n"
-      "    </class>\n"
-      "\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_mappings.xml:62
 #, no-c-format
 msgid "Here is the table schema generated by <literal>SchemaExport</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: example_mappings.xml:66
-#, no-c-format
-msgid ""
-      "<![CDATA[create table employers (\n"
-      "    id BIGINT not null, \n"
-      "    name VARCHAR(255), \n"
-      "    primary key (id)\n"
-      ")\n"
-      "\n"
-      "create table employment_periods (\n"
-      "    id BIGINT not null,\n"
-      "    hourly_rate NUMERIC(12, 2),\n"
-      "    currency VARCHAR(12), \n"
-      "    employee_id BIGINT not null, \n"
-      "    employer_id BIGINT not null, \n"
-      "    end_date TIMESTAMP, \n"
-      "    start_date TIMESTAMP, \n"
-      "    primary key (id)\n"
-      ")\n"
-      "\n"
-      "create table employees (\n"
-      "    id BIGINT not null, \n"
-      "    firstName VARCHAR(255), \n"
-      "    initial CHAR(1), \n"
-      "    lastName VARCHAR(255), \n"
-      "    taxfileNumber VARCHAR(255), \n"
-      "    primary key (id)\n"
-      ")\n"
-      "\n"
-      "alter table employment_periods \n"
-      "    add constraint employment_periodsFK0 foreign key (employer_id) references employers\n"
-      "alter table employment_periods \n"
-      "    add constraint employment_periodsFK1 foreign key (employee_id) references employees\n"
-      "create sequence employee_id_seq\n"
-      "create sequence employment_id_seq\n"
-      "create sequence employer_id_seq]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:71
 #, no-c-format
 msgid "Author/Work"
 msgstr ""
 
 #. Tag: para
-#: example_mappings.xml:73
 #, no-c-format
 msgid "Consider the following model of the relationships between <literal>Work</literal>, <literal>Author</literal> and <literal>Person</literal>. In the example, the relationship between <literal>Work</literal> and <literal>Author</literal> is represented as a many-to-many association and the relationship between <literal>Author</literal> and <literal>Person</literal> is represented as one-to-one association. Another possibility would be to have <literal>Author</literal> extend <literal>Person</literal>."
 msgstr ""
 
 #. Tag: para
-#: example_mappings.xml:91
 #, no-c-format
 msgid "The following mapping document correctly represents these relationships:"
 msgstr ""
 
-#. Tag: programlisting
-#: example_mappings.xml:95
-#, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping>\n"
-      "\n"
-      "    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
-      "\n"
-      "        <id name=\"id\" column=\"id\">\n"
-      "            <generator class=\"native\"/>\n"
-      "        </id>\n"
-      "        <discriminator column=\"type\" type=\"character\"/>\n"
-      "\n"
-      "        <property name=\"title\"/>\n"
-      "        <set name=\"authors\" table=\"author_work\">\n"
-      "            <key column name=\"work_id\"/>\n"
-      "            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
-      "        </set>\n"
-      "\n"
-      "        <subclass name=\"Book\" discriminator-value=\"B\">\n"
-      "            <property name=\"text\"/>\n"
-      "        </subclass>\n"
-      "\n"
-      "        <subclass name=\"Song\" discriminator-value=\"S\">\n"
-      "            <property name=\"tempo\"/>\n"
-      "            <property name=\"genre\"/>\n"
-      "        </subclass>\n"
-      "\n"
-      "    </class>\n"
-      "\n"
-      "    <class name=\"Author\" table=\"authors\">\n"
-      "\n"
-      "        <id name=\"id\" column=\"id\">\n"
-      "            <!-- The Author must have the same identifier as the Person -->\n"
-      "            <generator class=\"assigned\"/> \n"
-      "        </id>\n"
-      "\n"
-      "        <property name=\"alias\"/>\n"
-      "        <one-to-one name=\"person\" constrained=\"true\"/>\n"
-      "\n"
-      "        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
-      "            <key column=\"author_id\"/>\n"
-      "            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
-      "        </set>\n"
-      "\n"
-      "    </class>\n"
-      "\n"
-      "    <class name=\"Person\" table=\"persons\">\n"
-      "        <id name=\"id\" column=\"id\">\n"
-      "            <generator class=\"native\"/>\n"
-      "        </id>\n"
-      "        <property name=\"name\"/>\n"
-      "    </class>\n"
-      "\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_mappings.xml:97
 #, no-c-format
 msgid "There are four tables in this mapping: <literal>works</literal>, <literal>authors</literal> and <literal>persons</literal> hold work, author and person data respectively. <literal>author_work</literal> is an association table linking authors to works. Here is the table schema, as generated by <literal>SchemaExport</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: example_mappings.xml:105
-#, no-c-format
-msgid ""
-      "<![CDATA[create table works (\n"
-      "    id BIGINT not null generated by default as identity, \n"
-      "    tempo FLOAT, \n"
-      "    genre VARCHAR(255), \n"
-      "    text INTEGER, \n"
-      "    title VARCHAR(255), \n"
-      "    type CHAR(1) not null, \n"
-      "    primary key (id)\n"
-      ")\n"
-      "\n"
-      "create table author_work (\n"
-      "    author_id BIGINT not null, \n"
-      "    work_id BIGINT not null, \n"
-      "    primary key (work_id, author_id)\n"
-      ")\n"
-      "\n"
-      "create table authors (\n"
-      "    id BIGINT not null generated by default as identity, \n"
-      "    alias VARCHAR(255), \n"
-      "    primary key (id)\n"
-      ")\n"
-      "\n"
-      "create table persons (\n"
-      "    id BIGINT not null generated by default as identity, \n"
-      "    name VARCHAR(255), \n"
-      "    primary key (id)\n"
-      ")\n"
-      "\n"
-      "alter table authors \n"
-      "    add constraint authorsFK0 foreign key (id) references persons\n"
-      "alter table author_work \n"
-      "    add constraint author_workFK0 foreign key (author_id) references authors\n"
-      "alter table author_work\n"
-      "    add constraint author_workFK1 foreign key (work_id) references works]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:110
 #, no-c-format
 msgid "Customer/Order/Product"
 msgstr ""
 
 #. Tag: para
-#: example_mappings.xml:112
 #, no-c-format
 msgid "In this section we consider a model of the relationships between <literal>Customer</literal>, <literal>Order</literal>, <literal>Line Item</literal> and <literal>Product</literal>. There is a one-to-many association between <literal>Customer</literal> and <literal>Order</literal>, but how can you represent <literal>Order</literal> / <literal>LineItem</literal> / <literal>Product</literal>? In the example, <literal>LineItem</literal> is mapped as an association class representing the many-to-many association between <literal>Order</literal> and <literal>Product</literal>. In Hibernate this is called a composite element."
 msgstr ""
 
 #. Tag: para
-#: example_mappings.xml:132
 #, no-c-format
 msgid "The mapping document will look like this:"
 msgstr ""
 
-#. Tag: programlisting
-#: example_mappings.xml:136
-#, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping>\n"
-      "\n"
-      "    <class name=\"Customer\" table=\"customers\">\n"
-      "        <id name=\"id\">\n"
-      "            <generator class=\"native\"/>\n"
-      "        </id>\n"
-      "        <property name=\"name\"/>\n"
-      "        <set name=\"orders\" inverse=\"true\">\n"
-      "            <key column=\"customer_id\"/>\n"
-      "            <one-to-many class=\"Order\"/>\n"
-      "        </set>\n"
-      "    </class>\n"
-      "\n"
-      "    <class name=\"Order\" table=\"orders\">\n"
-      "        <id name=\"id\">\n"
-      "            <generator class=\"native\"/>\n"
-      "        </id>\n"
-      "        <property name=\"date\"/>\n"
-      "        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
-      "        <list name=\"lineItems\" table=\"line_items\">\n"
-      "            <key column=\"order_id\"/>\n"
-      "            <list-index column=\"line_number\"/>\n"
-      "            <composite-element class=\"LineItem\">\n"
-      "                <property name=\"quantity\"/>\n"
-      "                <many-to-one name=\"product\" column=\"product_id\"/>\n"
-      "            </composite-element>\n"
-      "        </list>\n"
-      "    </class>\n"
-      "\n"
-      "    <class name=\"Product\" table=\"products\">\n"
-      "        <id name=\"id\">\n"
-      "            <generator class=\"native\"/>\n"
-      "        </id>\n"
-      "        <property name=\"serialNumber\"/>\n"
-      "    </class>\n"
-      "\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_mappings.xml:138
 #, no-c-format
 msgid "<literal>customers</literal>, <literal>orders</literal>, <literal>line_items</literal> and <literal>products</literal> hold customer, order, order line item and product data respectively. <literal>line_items</literal> also acts as an association table linking orders with products."
 msgstr ""
 
-#. Tag: programlisting
-#: example_mappings.xml:145
-#, no-c-format
-msgid ""
-      "<![CDATA[create table customers (\n"
-      "    id BIGINT not null generated by default as identity, \n"
-      "    name VARCHAR(255), \n"
-      "    primary key (id)\n"
-      ")\n"
-      "\n"
-      "create table orders (\n"
-      "    id BIGINT not null generated by default as identity, \n"
-      "    customer_id BIGINT, \n"
-      "    date TIMESTAMP, \n"
-      "    primary key (id)\n"
-      ")\n"
-      "\n"
-      "create table line_items (\n"
-      "    line_number INTEGER not null, \n"
-      "    order_id BIGINT not null, \n"
-      "    product_id BIGINT, \n"
-      "    quantity INTEGER, \n"
-      "    primary key (order_id, line_number)\n"
-      ")\n"
-      "\n"
-      "create table products (\n"
-      "    id BIGINT not null generated by default as identity, \n"
-      "    serialNumber VARCHAR(255), \n"
-      "    primary key (id)\n"
-      ")\n"
-      "\n"
-      "alter table orders \n"
-      "    add constraint ordersFK0 foreign key (customer_id) references customers\n"
-      "alter table line_items\n"
-      "    add constraint line_itemsFK0 foreign key (product_id) references products\n"
-      "alter table line_items\n"
-      "    add constraint line_itemsFK1 foreign key (order_id) references orders]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:150
 #, no-c-format
 msgid "Miscellaneous example mappings"
 msgstr ""
 
 #. Tag: para
-#: example_mappings.xml:152
 #, no-c-format
 msgid "These examples are available from the Hibernate test suite. You will find many other useful example mappings there by searching in the <literal>test</literal> folder of the Hibernate distribution."
 msgstr ""
 
 #. Tag: title
-#: example_mappings.xml:161
 #, no-c-format
 msgid "\"Typed\" one-to-one association"
 msgstr ""
 
-#. Tag: programlisting
-#: example_mappings.xml:162
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"name\"/>\n"
-      "    <one-to-one name=\"address\" \n"
-      "            cascade=\"all\">\n"
-      "        <formula>name</formula>\n"
-      "        <formula>'HOME'</formula>\n"
-      "    </one-to-one>\n"
-      "    <one-to-one name=\"mailingAddress\" \n"
-      "            cascade=\"all\">\n"
-      "        <formula>name</formula>\n"
-      "        <formula>'MAILING'</formula>\n"
-      "    </one-to-one>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\" batch-size=\"2\" \n"
-      "        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
-      "    <composite-id>\n"
-      "        <key-many-to-one name=\"person\" \n"
-      "                column=\"personName\"/>\n"
-      "        <key-property name=\"type\" \n"
-      "                column=\"addressType\"/>\n"
-      "    </composite-id>\n"
-      "    <property name=\"street\" type=\"text\"/>\n"
-      "    <property name=\"state\"/>\n"
-      "    <property name=\"zip\"/>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:166
 #, no-c-format
 msgid "Composite key example"
 msgstr ""
 
-#. Tag: programlisting
-#: example_mappings.xml:167
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Customer\">\n"
-      "\n"
-      "    <id name=\"customerId\"\n"
-      "        length=\"10\">\n"
-      "        <generator class=\"assigned\"/>\n"
-      "    </id>\n"
-      "\n"
-      "    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
-      "    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
-      "\n"
-      "    <list name=\"orders\"\n"
-      "            inverse=\"true\"\n"
-      "            cascade=\"save-update\">\n"
-      "        <key column=\"customerId\"/>\n"
-      "        <index column=\"orderNumber\"/>\n"
-      "        <one-to-many class=\"Order\"/>\n"
-      "    </list>\n"
-      "\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
-      "    <synchronize table=\"LineItem\"/>\n"
-      "    <synchronize table=\"Product\"/>\n"
-      "    \n"
-      "    <composite-id name=\"id\" \n"
-      "            class=\"Order$Id\">\n"
-      "        <key-property name=\"customerId\" length=\"10\"/>\n"
-      "        <key-property name=\"orderNumber\"/>\n"
-      "    </composite-id>\n"
-      "    \n"
-      "    <property name=\"orderDate\" \n"
-      "            type=\"calendar_date\"\n"
-      "            not-null=\"true\"/>\n"
-      "    \n"
-      "    <property name=\"total\">\n"
-      "        <formula>\n"
-      "            ( select sum(li.quantity*p.price) \n"
-      "            from LineItem li, Product p \n"
-      "            where li.productId = p.productId \n"
-      "                and li.customerId = customerId \n"
-      "                and li.orderNumber = orderNumber )\n"
-      "        </formula>\n"
-      "    </property>\n"
-      "    \n"
-      "    <many-to-one name=\"customer\"\n"
-      "            column=\"customerId\"\n"
-      "            insert=\"false\"\n"
-      "            update=\"false\" \n"
-      "            not-null=\"true\"/>\n"
-      "        \n"
-      "    <bag name=\"lineItems\"\n"
-      "            fetch=\"join\" \n"
-      "            inverse=\"true\"\n"
-      "            cascade=\"save-update\">\n"
-      "        <key>\n"
-      "            <column name=\"customerId\"/>\n"
-      "            <column name=\"orderNumber\"/>\n"
-      "        </key>\n"
-      "        <one-to-many class=\"LineItem\"/>\n"
-      "    </bag>\n"
-      "    \n"
-      "</class>\n"
-      "    \n"
-      "<class name=\"LineItem\">\n"
-      "    \n"
-      "    <composite-id name=\"id\" \n"
-      "            class=\"LineItem$Id\">\n"
-      "        <key-property name=\"customerId\" length=\"10\"/>\n"
-      "        <key-property name=\"orderNumber\"/>\n"
-      "        <key-property name=\"productId\" length=\"10\"/>\n"
-      "    </composite-id>\n"
-      "    \n"
-      "    <property name=\"quantity\"/>\n"
-      "    \n"
-      "    <many-to-one name=\"order\"\n"
-      "            insert=\"false\"\n"
-      "            update=\"false\" \n"
-      "            not-null=\"true\">\n"
-      "        <column name=\"customerId\"/>\n"
-      "        <column name=\"orderNumber\"/>\n"
-      "    </many-to-one>\n"
-      "    \n"
-      "    <many-to-one name=\"product\"\n"
-      "            insert=\"false\"\n"
-      "            update=\"false\" \n"
-      "            not-null=\"true\"\n"
-      "            column=\"productId\"/>\n"
-      "        \n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Product\">\n"
-      "    <synchronize table=\"LineItem\"/>\n"
-      "\n"
-      "    <id name=\"productId\"\n"
-      "        length=\"10\">\n"
-      "        <generator class=\"assigned\"/>\n"
-      "    </id>\n"
-      "    \n"
-      "    <property name=\"description\" \n"
-      "        not-null=\"true\" \n"
-      "        length=\"200\"/>\n"
-      "    <property name=\"price\" length=\"3\"/>\n"
-      "    <property name=\"numberAvailable\"/>\n"
-      "    \n"
-      "    <property name=\"numberOrdered\">\n"
-      "        <formula>\n"
-      "            ( select sum(li.quantity) \n"
-      "            from LineItem li \n"
-      "            where li.productId = productId )\n"
-      "        </formula>\n"
-      "    </property>\n"
-      "    \n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:171
 #, no-c-format
 msgid "Many-to-many with shared composite key attribute"
 msgstr ""
 
-#. Tag: programlisting
-#: example_mappings.xml:172
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"User\" table=\"`User`\">\n"
-      "    <composite-id>\n"
-      "        <key-property name=\"name\"/>\n"
-      "        <key-property name=\"org\"/>\n"
-      "    </composite-id>\n"
-      "    <set name=\"groups\" table=\"UserGroup\">\n"
-      "        <key>\n"
-      "            <column name=\"userName\"/>\n"
-      "            <column name=\"org\"/>\n"
-      "        </key>\n"
-      "        <many-to-many class=\"Group\">\n"
-      "            <column name=\"groupName\"/>\n"
-      "            <formula>org</formula>\n"
-      "        </many-to-many>\n"
-      "    </set>\n"
-      "</class>\n"
-      "    \n"
-      "<class name=\"Group\" table=\"`Group`\">\n"
-      "    <composite-id>\n"
-      "        <key-property name=\"name\"/>\n"
-      "        <key-property name=\"org\"/>\n"
-      "    </composite-id>\n"
-      "    <property name=\"description\"/>\n"
-      "    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
-      "        <key>\n"
-      "            <column name=\"groupName\"/>\n"
-      "            <column name=\"org\"/>\n"
-      "        </key>\n"
-      "        <many-to-many class=\"User\">\n"
-      "            <column name=\"userName\"/>\n"
-      "            <formula>org</formula>\n"
-      "        </many-to-many>\n"
-      "    </set>\n"
-      "</class>\n"
-      "]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:176
 #, no-c-format
 msgid "Content based discrimination"
 msgstr ""
 
-#. Tag: programlisting
-#: example_mappings.xml:177
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\"\n"
-      "    discriminator-value=\"P\">\n"
-      "    \n"
-      "    <id name=\"id\" \n"
-      "        column=\"person_id\" \n"
-      "        unsaved-value=\"0\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    \n"
-      "            \n"
-      "    <discriminator \n"
-      "        type=\"character\">\n"
-      "        <formula>\n"
-      "            case \n"
-      "                when title is not null then 'E' \n"
-      "                when salesperson is not null then 'C' \n"
-      "                else 'P' \n"
-      "            end\n"
-      "        </formula>\n"
-      "    </discriminator>\n"
-      "\n"
-      "    <property name=\"name\" \n"
-      "        not-null=\"true\"\n"
-      "        length=\"80\"/>\n"
-      "        \n"
-      "    <property name=\"sex\" \n"
-      "        not-null=\"true\"\n"
-      "        update=\"false\"/>\n"
-      "    \n"
-      "    <component name=\"address\">\n"
-      "        <property name=\"address\"/>\n"
-      "        <property name=\"zip\"/>\n"
-      "        <property name=\"country\"/>\n"
-      "    </component>\n"
-      "    \n"
-      "    <subclass name=\"Employee\" \n"
-      "        discriminator-value=\"E\">\n"
-      "            <property name=\"title\"\n"
-      "                length=\"20\"/>\n"
-      "            <property name=\"salary\"/>\n"
-      "            <many-to-one name=\"manager\"/>\n"
-      "    </subclass>\n"
-      "    \n"
-      "    <subclass name=\"Customer\" \n"
-      "        discriminator-value=\"C\">\n"
-      "            <property name=\"comments\"/>\n"
-      "            <many-to-one name=\"salesperson\"/>\n"
-      "    </subclass>\n"
-      "    \n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:181
 #, no-c-format
 msgid "Associations on alternate keys"
 msgstr ""
 
-#. Tag: programlisting
-#: example_mappings.xml:182
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    \n"
-      "    <id name=\"id\">\n"
-      "        <generator class=\"hilo\"/>\n"
-      "    </id>\n"
-      "    \n"
-      "    <property name=\"name\" length=\"100\"/>\n"
-      "    \n"
-      "    <one-to-one name=\"address\" \n"
-      "        property-ref=\"person\"\n"
-      "        cascade=\"all\"\n"
-      "        fetch=\"join\"/>\n"
-      "    \n"
-      "    <set name=\"accounts\" \n"
-      "        inverse=\"true\">\n"
-      "        <key column=\"userId\"\n"
-      "            property-ref=\"userId\"/>\n"
-      "        <one-to-many class=\"Account\"/>\n"
-      "    </set>\n"
-      "    \n"
-      "    <property name=\"userId\" length=\"8\"/>\n"
-      "\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Address\">\n"
-      "\n"
-      "    <id name=\"id\">\n"
-      "        <generator class=\"hilo\"/>\n"
-      "    </id>\n"
-      "\n"
-      "    <property name=\"address\" length=\"300\"/>\n"
-      "    <property name=\"zip\" length=\"5\"/>\n"
-      "    <property name=\"country\" length=\"25\"/>\n"
-      "    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
-      "\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Account\">\n"
-      "    <id name=\"accountId\" length=\"32\">\n"
-      "        <generator class=\"uuid\"/>\n"
-      "    </id>\n"
-      "    \n"
-      "    <many-to-one name=\"user\"\n"
-      "        column=\"userId\"\n"
-      "        property-ref=\"userId\"/>\n"
-      "    \n"
-      "    <property name=\"type\" not-null=\"true\"/>\n"
-      "    \n"
-      "</class>]]>"
-msgstr ""
-

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/example_parentchild.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/example_parentchild.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/example_parentchild.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,396 +1,203 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-08-17 20:22+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: example_parentchild.xml:29
 #, no-c-format
 msgid "Example: Parent/Child"
 msgstr ""
 
 #. Tag: para
-#: example_parentchild.xml:31
 #, 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</literal> and <literal>Child</literal> as entity classes with a <literal>&lt;one-to-many&gt;</literal> association from <literal>Parent</literal> to <literal>Child</literal>. The alternative approach is to declare the <literal>Child</literal> as a <literal>&lt;composite-element&gt;</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 ""
 
 #. Tag: title
-#: example_parentchild.xml:45
 #, no-c-format
 msgid "A note about collections"
 msgstr ""
 
 #. Tag: para
-#: example_parentchild.xml:47
 #, 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 ""
 
 #. Tag: para
-#: example_parentchild.xml:54
 #, 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
-#: example_parentchild.xml:60
 #, 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
-#: example_parentchild.xml:68
 #, 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
-#: example_parentchild.xml:78
 #, 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
-#: example_parentchild.xml:88
 #, no-c-format
 msgid "Bidirectional one-to-many"
 msgstr ""
 
 #. Tag: para
-#: example_parentchild.xml:90
 #, no-c-format
 msgid "Suppose we start with a simple <literal>&lt;one-to-many&gt;</literal> association from <literal>Parent</literal> to <literal>Child</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: example_parentchild.xml:95
-#, no-c-format
-msgid ""
-      "<![CDATA[<set name=\"children\">\n"
-      "    <key column=\"parent_id\"/>\n"
-      "    <one-to-many class=\"Child\"/>\n"
-      "</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:97
 #, no-c-format
 msgid "If we were to execute the following code:"
 msgstr ""
 
-#. Tag: programlisting
-#: example_parentchild.xml:101
-#, no-c-format
-msgid ""
-      "<![CDATA[Parent p = .....;\n"
-      "Child c = new Child();\n"
-      "p.getChildren().add(c);\n"
-      "session.save(c);\n"
-      "session.flush();]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:103
 #, no-c-format
 msgid "Hibernate would issue two SQL statements:"
 msgstr ""
 
 #. Tag: para
-#: example_parentchild.xml:109
 #, no-c-format
 msgid "an <literal>INSERT</literal> to create the record for <literal>c</literal>"
 msgstr ""
 
 #. Tag: para
-#: example_parentchild.xml:112
 #, no-c-format
 msgid "an <literal>UPDATE</literal> to create the link from <literal>p</literal> to <literal>c</literal>"
 msgstr ""
 
 #. Tag: para
-#: example_parentchild.xml:119
 #, no-c-format
 msgid "This is not only inefficient, but also violates any <literal>NOT NULL</literal> constraint on the <literal>parent_id</literal> column. You can fix the nullability constraint violation by specifying <literal>not-null=\"true\"</literal> in the collection mapping:"
 msgstr ""
 
-#. Tag: programlisting
-#: example_parentchild.xml:125
-#, no-c-format
-msgid ""
-      "<![CDATA[<set name=\"children\">\n"
-      "    <key column=\"parent_id\" not-null=\"true\"/>\n"
-      "    <one-to-many class=\"Child\"/>\n"
-      "</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:127
 #, no-c-format
 msgid "However, this is not the recommended solution."
 msgstr ""
 
 #. Tag: para
-#: example_parentchild.xml:130
 #, no-c-format
 msgid "The underlying cause of this behavior is that the link (the foreign key <literal>parent_id</literal>) from <literal>p</literal> to <literal>c</literal> is not considered part of the state of the <literal>Child</literal> object and is therefore not created in the <literal>INSERT</literal>. The solution is to make the link part of the <literal>Child</literal> mapping."
 msgstr ""
 
-#. Tag: programlisting
-#: example_parentchild.xml:137
-#, no-c-format
-msgid "<![CDATA[<many-to-one name=\"parent\" column=\"parent_id\" not-null=\"true\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:139
 #, no-c-format
 msgid "You also need to add the <literal>parent</literal> property to the <literal>Child</literal> class."
 msgstr ""
 
 #. Tag: para
-#: example_parentchild.xml:143
 #, no-c-format
 msgid "Now that the <literal>Child</literal> entity is managing the state of the link, we tell the collection not to update the link. We use the <literal>inverse</literal> attribute to do this:"
 msgstr ""
 
-#. Tag: programlisting
-#: example_parentchild.xml:148
-#, no-c-format
-msgid ""
-      "<![CDATA[<set name=\"children\" inverse=\"true\">\n"
-      "    <key column=\"parent_id\"/>\n"
-      "    <one-to-many class=\"Child\"/>\n"
-      "</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:150
 #, no-c-format
 msgid "The following code would be used to add a new <literal>Child</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: example_parentchild.xml:154
-#, no-c-format
-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 ""
-
 #. Tag: para
-#: example_parentchild.xml:156
 #, no-c-format
 msgid "Only one SQL <literal>INSERT</literal> would now be issued."
 msgstr ""
 
 #. Tag: para
-#: example_parentchild.xml:160
 #, no-c-format
 msgid "You could also create an <literal>addChild()</literal> method of <literal>Parent</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: example_parentchild.xml:165
-#, no-c-format
-msgid ""
-      "<![CDATA[public void addChild(Child c) {\n"
-      "    c.setParent(this);\n"
-      "    children.add(c);\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:167
 #, no-c-format
 msgid "The code to add a <literal>Child</literal> looks like this:"
 msgstr ""
 
-#. Tag: programlisting
-#: example_parentchild.xml:171
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: example_parentchild.xml:176
 #, no-c-format
 msgid "Cascading life cycle"
 msgstr ""
 
 #. Tag: para
-#: example_parentchild.xml:178
 #, no-c-format
 msgid "You can address the frustrations of the explicit call to <literal>save()</literal> by using cascades."
 msgstr ""
 
-#. Tag: programlisting
-#: example_parentchild.xml:183
-#, no-c-format
-msgid ""
-      "<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all\">\n"
-      "    <key column=\"parent_id\"/>\n"
-      "    <one-to-many class=\"Child\"/>\n"
-      "</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:185
 #, no-c-format
 msgid "This simplifies the code above to:"
 msgstr ""
 
-#. Tag: programlisting
-#: example_parentchild.xml:189
-#, no-c-format
-msgid ""
-      "<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-      "Child c = new Child();\n"
-      "p.addChild(c);\n"
-      "session.flush();]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:191
 #, no-c-format
 msgid "Similarly, we do not need to iterate over the children when saving or deleting a <literal>Parent</literal>. The following removes <literal>p</literal> and all its children from the database."
 msgstr ""
 
-#. Tag: programlisting
-#: example_parentchild.xml:196
-#, no-c-format
-msgid ""
-      "<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-      "session.delete(p);\n"
-      "session.flush();]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:198
 #, no-c-format
 msgid "However, the following code:"
 msgstr ""
 
-#. Tag: programlisting
-#: example_parentchild.xml:202
-#, no-c-format
-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 ""
-
 #. Tag: para
-#: example_parentchild.xml:204
 #, no-c-format
 msgid "will not remove <literal>c</literal> from the database. In this case, it will only remove the link to <literal>p</literal> and cause a <literal>NOT NULL</literal> constraint violation. You need to explicitly <literal>delete()</literal> the <literal>Child</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: example_parentchild.xml:210
-#, no-c-format
-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 ""
-
 #. Tag: para
-#: example_parentchild.xml:212
 #, no-c-format
 msgid "In our case, a <literal>Child</literal> cannot exist without its parent. So if we remove a <literal>Child</literal> from the collection, we do want it to be deleted. To do this, we must use <literal>cascade=\"all-delete-orphan\"</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: example_parentchild.xml:218
-#, no-c-format
-msgid ""
-      "<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all-delete-orphan\">\n"
-      "    <key column=\"parent_id\"/>\n"
-      "    <one-to-many class=\"Child\"/>\n"
-      "</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:220
 #, no-c-format
 msgid "Even though the collection mapping specifies <literal>inverse=\"true\"</literal>, cascades are still processed by iterating the collection elements. If you need an object be saved, deleted or updated by cascade, you must add it to the collection. It is not enough to simply call <literal>setParent()</literal>."
 msgstr ""
 
 #. Tag: title
-#: example_parentchild.xml:230
 #, no-c-format
 msgid "Cascades and <literal>unsaved-value</literal>"
 msgstr ""
 
 #. Tag: para
-#: example_parentchild.xml:232
 #, no-c-format
-msgid "Suppose we loaded up a <literal>Parent</literal> in one <literal>Session</literal>, made some changes in a UI action and wanted to persist these changes in a new session by calling <literal>update()</literal>. The <literal>Parent</literal> 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</literal> and <literal>Child</literal> have generated identifier properties of type <literal>Long</literal>. Hibernate will use the identifier and version/timestamp property value to determine which of the children are new. (See <xref linkend=\"objectstate-saveorupdate\"/>.) <emphasis>In Hibernate3, it is no longer necessary to specify an <literal>unsaved-value</literal> explicitly.</emphasis>"
+msgid "Suppose we loaded up a <literal>Parent</literal> in one <literal>Session</literal>, made some changes in a UI action and wanted to persist these changes in a new session by calling <literal>update()</literal>. The <literal>Parent</literal> 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</literal> and <literal>Child</literal> have generated identifier properties of type <literal>Long</literal>. Hibernate will use the identifier and version/timestamp property value to determine which of the children are new. (See <xref linkend=\"objectstate-saveorupdate\" />.) <emphasis>In Hibernate3, it is no longer necessary to specify an <literal>unsaved-value</literal> explicitly.</emphasis>"
 msgstr ""
 
 #. Tag: para
-#: example_parentchild.xml:244
 #, no-c-format
 msgid "The following code will update <literal>parent</literal> and <literal>child</literal> and insert <literal>newChild</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: example_parentchild.xml:249
-#, no-c-format
-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 ""
-
 #. Tag: para
-#: example_parentchild.xml:251
 #, 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 ""
 
 #. Tag: title
-#: example_parentchild.xml:263
 #, no-c-format
 msgid "Conclusion"
 msgstr ""
 
 #. Tag: para
-#: example_parentchild.xml:265
 #, 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 ""
 
 #. Tag: para
-#: example_parentchild.xml:270
 #, no-c-format
 msgid "We mentioned an alternative in the first paragraph. None of the above issues exist in the case of <literal>&lt;composite-element&gt;</literal> 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 ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/example_weblog.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/example_weblog.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/example_weblog.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,478 +1,49 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: example_weblog.xml:29
 #, no-c-format
 msgid "Example: Weblog Application"
 msgstr ""
 
 #. Tag: title
-#: example_weblog.xml:32
 #, no-c-format
 msgid "Persistent Classes"
 msgstr ""
 
 #. Tag: para
-#: example_weblog.xml:34
 #, no-c-format
 msgid "The persistent classes here represent a weblog and an item posted in a weblog. They are to be modelled as a standard parent/child relationship, but we will use an ordered bag, instead of a set:"
 msgstr ""
 
-#. Tag: programlisting
-#: example_weblog.xml:40
-#, no-c-format
-msgid ""
-      "<![CDATA[package eg;\n"
-      "\n"
-      "import java.util.List;\n"
-      "\n"
-      "public class Blog {\n"
-      "    private Long _id;\n"
-      "    private String _name;\n"
-      "    private List _items;\n"
-      "\n"
-      "    public Long getId() {\n"
-      "        return _id;\n"
-      "    }\n"
-      "    public List getItems() {\n"
-      "        return _items;\n"
-      "    }\n"
-      "    public String getName() {\n"
-      "        return _name;\n"
-      "    }\n"
-      "    public void setId(Long long1) {\n"
-      "        _id = long1;\n"
-      "    }\n"
-      "    public void setItems(List list) {\n"
-      "        _items = list;\n"
-      "    }\n"
-      "    public void setName(String string) {\n"
-      "        _name = string;\n"
-      "    }\n"
-      "}]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: example_weblog.xml:42
-#, no-c-format
-msgid ""
-      "<![CDATA[package eg;\n"
-      "\n"
-      "import java.text.DateFormat;\n"
-      "import java.util.Calendar;\n"
-      "\n"
-      "public class BlogItem {\n"
-      "    private Long _id;\n"
-      "    private Calendar _datetime;\n"
-      "    private String _text;\n"
-      "    private String _title;\n"
-      "    private Blog _blog;\n"
-      "\n"
-      "    public Blog getBlog() {\n"
-      "        return _blog;\n"
-      "    }\n"
-      "    public Calendar getDatetime() {\n"
-      "        return _datetime;\n"
-      "    }\n"
-      "    public Long getId() {\n"
-      "        return _id;\n"
-      "    }\n"
-      "    public String getText() {\n"
-      "        return _text;\n"
-      "    }\n"
-      "    public String getTitle() {\n"
-      "        return _title;\n"
-      "    }\n"
-      "    public void setBlog(Blog blog) {\n"
-      "        _blog = blog;\n"
-      "    }\n"
-      "    public void setDatetime(Calendar calendar) {\n"
-      "        _datetime = calendar;\n"
-      "    }\n"
-      "    public void setId(Long long1) {\n"
-      "        _id = long1;\n"
-      "    }\n"
-      "    public void setText(String string) {\n"
-      "        _text = string;\n"
-      "    }\n"
-      "    public void setTitle(String string) {\n"
-      "        _title = string;\n"
-      "    }\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: title
-#: example_weblog.xml:47
 #, no-c-format
 msgid "Hibernate Mappings"
 msgstr ""
 
 #. Tag: para
-#: example_weblog.xml:49
 #, no-c-format
 msgid "The XML mappings are now straightforward. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: example_weblog.xml:53
-#, no-c-format
-msgid ""
-      "<![CDATA[<?xml version=\"1.0\"?>\n"
-      "<!DOCTYPE hibernate-mapping PUBLIC\n"
-      "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-      "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-      "\n"
-      "<hibernate-mapping package=\"eg\">\n"
-      "\n"
-      "    <class\n"
-      "        name=\"Blog\"\n"
-      "        table=\"BLOGS\">\n"
-      "\n"
-      "        <id\n"
-      "            name=\"id\"\n"
-      "            column=\"BLOG_ID\">\n"
-      "\n"
-      "            <generator class=\"native\"/>\n"
-      "\n"
-      "        </id>\n"
-      "\n"
-      "        <property\n"
-      "            name=\"name\"\n"
-      "            column=\"NAME\"\n"
-      "            not-null=\"true\"\n"
-      "            unique=\"true\"/>\n"
-      "\n"
-      "        <bag\n"
-      "            name=\"items\"\n"
-      "            inverse=\"true\"\n"
-      "            order-by=\"DATE_TIME\"\n"
-      "            cascade=\"all\">\n"
-      "\n"
-      "            <key column=\"BLOG_ID\"/>\n"
-      "            <one-to-many class=\"BlogItem\"/>\n"
-      "\n"
-      "        </bag>\n"
-      "\n"
-      "    </class>\n"
-      "\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: example_weblog.xml:55
-#, no-c-format
-msgid ""
-      "<![CDATA[<?xml version=\"1.0\"?>\n"
-      "<!DOCTYPE hibernate-mapping PUBLIC\n"
-      "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-      "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-      "\n"
-      "<hibernate-mapping package=\"eg\">\n"
-      "\n"
-      "    <class\n"
-      "        name=\"BlogItem\"\n"
-      "        table=\"BLOG_ITEMS\"\n"
-      "        dynamic-update=\"true\">\n"
-      "\n"
-      "        <id\n"
-      "            name=\"id\"\n"
-      "            column=\"BLOG_ITEM_ID\">\n"
-      "\n"
-      "            <generator class=\"native\"/>\n"
-      "\n"
-      "        </id>\n"
-      "\n"
-      "        <property\n"
-      "            name=\"title\"\n"
-      "            column=\"TITLE\"\n"
-      "            not-null=\"true\"/>\n"
-      "\n"
-      "        <property\n"
-      "            name=\"text\"\n"
-      "            column=\"TEXT\"\n"
-      "            not-null=\"true\"/>\n"
-      "\n"
-      "        <property\n"
-      "            name=\"datetime\"\n"
-      "            column=\"DATE_TIME\"\n"
-      "            not-null=\"true\"/>\n"
-      "\n"
-      "        <many-to-one\n"
-      "            name=\"blog\"\n"
-      "            column=\"BLOG_ID\"\n"
-      "            not-null=\"true\"/>\n"
-      "\n"
-      "    </class>\n"
-      "\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_weblog.xml:60
 #, no-c-format
 msgid "Hibernate Code"
 msgstr ""
 
 #. Tag: para
-#: example_weblog.xml:62
 #, no-c-format
 msgid "The following class demonstrates some of the kinds of things we can do with these classes using Hibernate:"
 msgstr ""
 
-#. Tag: programlisting
-#: example_weblog.xml:67
-#, no-c-format
-msgid ""
-      "<![CDATA[package eg;\n"
-      "\n"
-      "import java.util.ArrayList;\n"
-      "import java.util.Calendar;\n"
-      "import java.util.Iterator;\n"
-      "import java.util.List;\n"
-      "\n"
-      "import org.hibernate.HibernateException;\n"
-      "import org.hibernate.Query;\n"
-      "import org.hibernate.Session;\n"
-      "import org.hibernate.SessionFactory;\n"
-      "import org.hibernate.Transaction;\n"
-      "import org.hibernate.cfg.Configuration;\n"
-      "import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
-      "\n"
-      "public class BlogMain {\n"
-      "    \n"
-      "    private SessionFactory _sessions;\n"
-      "    \n"
-      "    public void configure() throws HibernateException {\n"
-      "        _sessions = new Configuration()\n"
-      "            .addClass(Blog.class)\n"
-      "            .addClass(BlogItem.class)\n"
-      "            .buildSessionFactory();\n"
-      "    }\n"
-      "    \n"
-      "    public void exportTables() throws HibernateException {\n"
-      "        Configuration cfg = new Configuration()\n"
-      "            .addClass(Blog.class)\n"
-      "            .addClass(BlogItem.class);\n"
-      "        new SchemaExport(cfg).create(true, true);\n"
-      "    }\n"
-      "    \n"
-      "    public Blog createBlog(String name) throws HibernateException {\n"
-      "        \n"
-      "        Blog blog = new Blog();\n"
-      "        blog.setName(name);\n"
-      "        blog.setItems( new ArrayList() );\n"
-      "        \n"
-      "        Session session = _sessions.openSession();\n"
-      "        Transaction tx = null;\n"
-      "        try {\n"
-      "            tx = session.beginTransaction();\n"
-      "            session.persist(blog);\n"
-      "            tx.commit();\n"
-      "        }\n"
-      "        catch (HibernateException he) {\n"
-      "            if (tx!=null) tx.rollback();\n"
-      "            throw he;\n"
-      "        }\n"
-      "        finally {\n"
-      "            session.close();\n"
-      "        }\n"
-      "        return blog;\n"
-      "    }\n"
-      "    \n"
-      "    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
-      "                        throws HibernateException {\n"
-      "        \n"
-      "        BlogItem item = new BlogItem();\n"
-      "        item.setTitle(title);\n"
-      "        item.setText(text);\n"
-      "        item.setBlog(blog);\n"
-      "        item.setDatetime( Calendar.getInstance() );\n"
-      "        blog.getItems().add(item);\n"
-      "        \n"
-      "        Session session = _sessions.openSession();\n"
-      "        Transaction tx = null;\n"
-      "        try {\n"
-      "            tx = session.beginTransaction();\n"
-      "            session.update(blog);\n"
-      "            tx.commit();\n"
-      "        }\n"
-      "        catch (HibernateException he) {\n"
-      "            if (tx!=null) tx.rollback();\n"
-      "            throw he;\n"
-      "        }\n"
-      "        finally {\n"
-      "            session.close();\n"
-      "        }\n"
-      "        return item;\n"
-      "    }\n"
-      "    \n"
-      "    public BlogItem createBlogItem(Long blogid, String title, String text)\n"
-      "                        throws HibernateException {\n"
-      "        \n"
-      "        BlogItem item = new BlogItem();\n"
-      "        item.setTitle(title);\n"
-      "        item.setText(text);\n"
-      "        item.setDatetime( Calendar.getInstance() );\n"
-      "        \n"
-      "        Session session = _sessions.openSession();\n"
-      "        Transaction tx = null;\n"
-      "        try {\n"
-      "            tx = session.beginTransaction();\n"
-      "            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
-      "            item.setBlog(blog);\n"
-      "            blog.getItems().add(item);\n"
-      "            tx.commit();\n"
-      "        }\n"
-      "        catch (HibernateException he) {\n"
-      "            if (tx!=null) tx.rollback();\n"
-      "            throw he;\n"
-      "        }\n"
-      "        finally {\n"
-      "            session.close();\n"
-      "        }\n"
-      "        return item;\n"
-      "    }\n"
-      "    \n"
-      "    public void updateBlogItem(BlogItem item, String text)\n"
-      "                    throws HibernateException {\n"
-      "        \n"
-      "        item.setText(text);\n"
-      "        \n"
-      "        Session session = _sessions.openSession();\n"
-      "        Transaction tx = null;\n"
-      "        try {\n"
-      "            tx = session.beginTransaction();\n"
-      "            session.update(item);\n"
-      "            tx.commit();\n"
-      "        }\n"
-      "        catch (HibernateException he) {\n"
-      "            if (tx!=null) tx.rollback();\n"
-      "            throw he;\n"
-      "        }\n"
-      "        finally {\n"
-      "            session.close();\n"
-      "        }\n"
-      "    }\n"
-      "    \n"
-      "    public void updateBlogItem(Long itemid, String text)\n"
-      "                    throws HibernateException {\n"
-      "    \n"
-      "        Session session = _sessions.openSession();\n"
-      "        Transaction tx = null;\n"
-      "        try {\n"
-      "            tx = session.beginTransaction();\n"
-      "            BlogItem item = (BlogItem) session.load(BlogItem.class, itemid);\n"
-      "            item.setText(text);\n"
-      "            tx.commit();\n"
-      "        }\n"
-      "        catch (HibernateException he) {\n"
-      "            if (tx!=null) tx.rollback();\n"
-      "            throw he;\n"
-      "        }\n"
-      "        finally {\n"
-      "            session.close();\n"
-      "        }\n"
-      "    }\n"
-      "    \n"
-      "    public List listAllBlogNamesAndItemCounts(int max)\n"
-      "                    throws HibernateException {\n"
-      "        \n"
-      "        Session session = _sessions.openSession();\n"
-      "        Transaction tx = null;\n"
-      "        List result = null;\n"
-      "        try {\n"
-      "            tx = session.beginTransaction();\n"
-      "            Query q = session.createQuery(\n"
-      "                \"select blog.id, blog.name, count(blogItem) \" +\n"
-      "                \"from Blog as blog \" +\n"
-      "                \"left outer join blog.items as blogItem \" +\n"
-      "                \"group by blog.name, blog.id \" +\n"
-      "                \"order by max(blogItem.datetime)\"\n"
-      "            );\n"
-      "            q.setMaxResults(max);\n"
-      "            result = q.list();\n"
-      "            tx.commit();\n"
-      "        }\n"
-      "        catch (HibernateException he) {\n"
-      "            if (tx!=null) tx.rollback();\n"
-      "            throw he;\n"
-      "        }\n"
-      "        finally {\n"
-      "            session.close();\n"
-      "        }\n"
-      "        return result;\n"
-      "    }\n"
-      "    \n"
-      "    public Blog getBlogAndAllItems(Long blogid)\n"
-      "                    throws HibernateException {\n"
-      "        \n"
-      "        Session session = _sessions.openSession();\n"
-      "        Transaction tx = null;\n"
-      "        Blog blog = null;\n"
-      "        try {\n"
-      "            tx = session.beginTransaction();\n"
-      "            Query q = session.createQuery(\n"
-      "                \"from Blog as blog \" +\n"
-      "                \"left outer join fetch blog.items \" +\n"
-      "                \"where blog.id = :blogid\"\n"
-      "            );\n"
-      "            q.setParameter(\"blogid\", blogid);\n"
-      "            blog  = (Blog) q.uniqueResult();\n"
-      "            tx.commit();\n"
-      "        }\n"
-      "        catch (HibernateException he) {\n"
-      "            if (tx!=null) tx.rollback();\n"
-      "            throw he;\n"
-      "        }\n"
-      "        finally {\n"
-      "            session.close();\n"
-      "        }\n"
-      "        return blog;\n"
-      "    }\n"
-      "    \n"
-      "    public List listBlogsAndRecentItems() throws HibernateException {\n"
-      "        \n"
-      "        Session session = _sessions.openSession();\n"
-      "        Transaction tx = null;\n"
-      "        List result = null;\n"
-      "        try {\n"
-      "            tx = session.beginTransaction();\n"
-      "            Query q = session.createQuery(\n"
-      "                \"from Blog as blog \" +\n"
-      "                \"inner join blog.items as blogItem \" +\n"
-      "                \"where blogItem.datetime > :minDate\"\n"
-      "            );\n"
-      "\n"
-      "            Calendar cal = Calendar.getInstance();\n"
-      "            cal.roll(Calendar.MONTH, false);\n"
-      "            q.setCalendar(\"minDate\", cal);\n"
-      "            \n"
-      "            result = q.list();\n"
-      "            tx.commit();\n"
-      "        }\n"
-      "        catch (HibernateException he) {\n"
-      "            if (tx!=null) tx.rollback();\n"
-      "            throw he;\n"
-      "        }\n"
-      "        finally {\n"
-      "            session.close();\n"
-      "        }\n"
-      "        return result;\n"
-      "    }\n"
-      "}]]>"
-msgstr ""
-

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/filters.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/filters.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/filters.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,198 +1,93 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: filters.xml:29
 #, no-c-format
 msgid "Filtering data"
 msgstr ""
 
 #. Tag: para
-#: filters.xml:31
 #, no-c-format
 msgid "Hibernate3 provides an innovative new approach to handling data with \"visibility\" rules. A <emphasis>Hibernate filter</emphasis> is a global, named, parameterized filter that can be enabled or disabled for a particular Hibernate session."
 msgstr ""
 
 #. Tag: title
-#: filters.xml:38
 #, no-c-format
 msgid "Hibernate filters"
 msgstr ""
 
 #. Tag: para
-#: filters.xml:40
 #, no-c-format
 msgid "Hibernate3 has the ability to pre-define filter criteria and attach those filters at both a class level and a collection level. A filter criteria allows you to define a restriction clause similar to the existing \"where\" attribute available on the class and various collection elements. These filter conditions, however, can be parameterized. The application can then decide at runtime whether certain filters should be enabled and what their parameter values should be. Filters can be used like database views, but they are parameterized inside the application."
 msgstr ""
 
 #. Tag: para
-#: filters.xml:50
 #, no-c-format
 msgid "In order to use filters, they must first be defined and then attached to the appropriate mapping elements. To define a filter, use the <literal>&lt;filter-def/&gt;</literal> element within a <literal>&lt;hibernate-mapping/&gt;</literal> element:"
 msgstr ""
 
-#. Tag: programlisting
-#: filters.xml:56
-#, no-c-format
-msgid ""
-      "<![CDATA[<filter-def name=\"myFilter\">\n"
-      "    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
-      "</filter-def>]]>"
-msgstr ""
-
 #. Tag: para
-#: filters.xml:58
 #, no-c-format
 msgid "This filter can then be attached to a class:"
 msgstr ""
 
-#. Tag: programlisting
-#: filters.xml:62
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"myClass\" ...>\n"
-      "    ...\n"
-      "    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN\"/>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: filters.xml:64
 #, no-c-format
 msgid "Or, to a collection:"
 msgstr ""
 
-#. Tag: programlisting
-#: filters.xml:68
-#, no-c-format
-msgid ""
-      "<![CDATA[<set ...>\n"
-      "    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN\"/>\n"
-      "</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: filters.xml:70
 #, no-c-format
 msgid "Or, to both or multiples of each at the same time."
 msgstr ""
 
 #. Tag: para
-#: filters.xml:74
 #, no-c-format
 msgid "The methods on <literal>Session</literal> are: <literal>enableFilter(String filterName)</literal>, <literal>getEnabledFilter(String filterName)</literal>, and <literal>disableFilter(String filterName)</literal>. By default, filters are <emphasis>not</emphasis> enabled for a given session. Filters must be enabled through use of the <literal>Session.enableFilter()</literal> method, which returns an instance of the <literal>Filter</literal> interface. If you used the simple filter defined above, it would look like this:"
 msgstr ""
 
-#. Tag: programlisting
-#: filters.xml:83
-#, no-c-format
-msgid "<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam\", \"some-value\");]]>"
-msgstr ""
-
 #. Tag: para
-#: filters.xml:85
 #, no-c-format
 msgid "Methods on the org.hibernate.Filter interface do allow the method-chaining common to much of Hibernate."
 msgstr ""
 
 #. Tag: para
-#: filters.xml:89
 #, no-c-format
 msgid "The following is a full example, using temporal data with an effective record date pattern:"
 msgstr ""
 
-#. Tag: programlisting
-#: filters.xml:93
-#, no-c-format
-msgid ""
-      "<![CDATA[<filter-def name=\"effectiveDate\">\n"
-      "    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
-      "</filter-def>\n"
-      "\n"
-      "<class name=\"Employee\" ...>\n"
-      "...\n"
-      "    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department\"/>\n"
-      "    <property name=\"effectiveStartDate\" type=\"date\" column=\"eff_start_dt\"/>\n"
-      "    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt\"/>\n"
-      "...\n"
-      "    <!--\n"
-      "        Note that this assumes non-terminal records have an eff_end_dt set to\n"
-      "        a max db date for simplicity-sake\n"
-      "    -->\n"
-      "    <filter name=\"effectiveDate\"\n"
-      "            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"Department\" ...>\n"
-      "...\n"
-      "    <set name=\"employees\" lazy=\"true\">\n"
-      "        <key column=\"dept_id\"/>\n"
-      "        <one-to-many class=\"Employee\"/>\n"
-      "        <filter name=\"effectiveDate\"\n"
-      "                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/>\n"
-      "    </set>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: filters.xml:95
 #, no-c-format
 msgid "In order to ensure that you are provided with currently effective records, enable the filter on the session prior to retrieving employee data:"
 msgstr ""
 
-#. Tag: programlisting
-#: filters.xml:100
-#, no-c-format
-msgid ""
-      "<![CDATA[Session session = ...;\n"
-      "session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new Date());\n"
-      "List results = session.createQuery(\"from Employee as e where e.salary > :targetSalary\")\n"
-      "         .setLong(\"targetSalary\", new Long(1000000))\n"
-      "         .list();\n"
-      "]]>"
-msgstr ""
-
 #. Tag: para
-#: filters.xml:102
 #, no-c-format
 msgid "Even though a salary constraint was mentioned explicitly on the results in the above HQL, because of the enabled filter, the query will return only currently active employees who have a salary greater than one million dollars."
 msgstr ""
 
 #. Tag: para
-#: filters.xml:108
 #, no-c-format
 msgid "If you want to use filters with outer joining, either through HQL or load fetching, be careful of the direction of the condition expression. It is safest to set this up for left outer joining. Place the parameter first followed by the column name(s) after the operator."
 msgstr ""
 
 #. Tag: para
-#: filters.xml:115
 #, no-c-format
 msgid "After being defined, a filter might be attached to multiple entities and/or collections each with its own condition. This can be problematic when the conditions are the same each time. Using <literal>&lt;filter-def/&gt;</literal> allows you to definine a default condition, either as an attribute or CDATA:"
 msgstr ""
 
-#. Tag: programlisting
-#: filters.xml:122
-#, no-c-format
-msgid ""
-      "<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</filter-def>\n"
-      "<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"
-msgstr ""
-
 #. Tag: para
-#: filters.xml:124
 #, no-c-format
 msgid "This default condition will be used whenever the filter is attached to something without specifying a condition. This means you can give a specific condition as part of the attachment of the filter that overrides the default condition in that particular case."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/inheritance_mapping.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/inheritance_mapping.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/inheritance_mapping.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,631 +1,334 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: inheritance_mapping.xml:29
 #, no-c-format
 msgid "Inheritance mapping"
 msgstr ""
 
 #. Tag: title
-#: inheritance_mapping.xml:32
 #, no-c-format
 msgid "The three strategies"
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:34
 #, no-c-format
 msgid "Hibernate supports the three basic inheritance mapping strategies:"
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:40
 #, no-c-format
 msgid "table per class hierarchy"
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:45
 #, no-c-format
-msgid "<para>table per subclass</para>"
+msgid "table per subclass"
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:50
 #, no-c-format
 msgid "table per concrete class"
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:56
 #, no-c-format
 msgid "In addition, Hibernate supports a fourth, slightly different kind of polymorphism:"
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:63
 #, no-c-format
 msgid "implicit polymorphism"
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:69
 #, no-c-format
 msgid "It is possible to use different mapping strategies for different branches of the same inheritance hierarchy. You can then make use of implicit polymorphism to achieve polymorphism across the whole hierarchy. However, Hibernate does not support mixing <literal>&lt;subclass&gt;</literal>, <literal>&lt;joined-subclass&gt;</literal> and <literal>&lt;union-subclass&gt;</literal> mappings under the same root <literal>&lt;class&gt;</literal> element. It is possible to mix together the table per hierarchy and table per subclass strategies under the the same <literal>&lt;class&gt;</literal> element, by combining the <literal>&lt;subclass&gt;</literal> and <literal>&lt;join&gt;</literal> elements (see below for an example)."
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:83
 #, no-c-format
 msgid "It is possible to define <literal>subclass</literal>, <literal>union-subclass</literal>, and <literal>joined-subclass</literal> mappings in separate mapping documents directly beneath <literal>hibernate-mapping</literal>. This allows you to extend a class hierarchy by adding a new mapping file. You must specify an <literal>extends</literal> attribute in the subclass mapping, naming a previously mapped superclass. Previously this feature made the ordering of the mapping documents important. Since Hibernate3, the ordering of mapping files is irrelevant when using the extends keyword. The ordering inside a single mapping file still needs to be defined as superclasses before subclasses."
 msgstr ""
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:94
-#, no-c-format
-msgid ""
-      "<![CDATA[\n"
-      " <hibernate-mapping>\n"
-      "     <subclass name=\"DomesticCat\" extends=\"Cat\" discriminator-value=\"D\">\n"
-      "          <property name=\"name\" type=\"string\"/>\n"
-      "     </subclass>\n"
-      " </hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:98
 #, no-c-format
 msgid "Table per class hierarchy"
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:100
 #, no-c-format
 msgid "Suppose we have an interface <literal>Payment</literal> with the implementors <literal>CreditCardPayment</literal>, <literal>CashPayment</literal>, and <literal>ChequePayment</literal>. The table per hierarchy mapping would display in the following way:"
 msgstr ""
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:107
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-      "    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-      "    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-      "    ...\n"
-      "    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-      "        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-      "        ...\n"
-      "    </subclass>\n"
-      "    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-      "        ...\n"
-      "    </subclass>\n"
-      "    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-      "        ...\n"
-      "    </subclass>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:109
 #, no-c-format
 msgid "Exactly one table is required. There is a limitation of this mapping strategy: columns declared by the subclasses, such as <literal>CCTYPE</literal>, cannot have <literal>NOT NULL</literal> constraints."
 msgstr ""
 
 #. Tag: title
-#: inheritance_mapping.xml:118
 #, no-c-format
 msgid "Table per subclass"
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:120
 #, no-c-format
 msgid "A table per subclass mapping looks like this:"
 msgstr ""
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:124
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-      "    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-      "    ...\n"
-      "    <joined-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-      "        <key column=\"PAYMENT_ID\"/>\n"
-      "        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-      "        ...\n"
-      "    </joined-subclass>\n"
-      "    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-      "        <key column=\"PAYMENT_ID\"/>\n"
-      "        ...\n"
-      "    </joined-subclass>\n"
-      "    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-      "        <key column=\"PAYMENT_ID\"/>\n"
-      "        ...\n"
-      "    </joined-subclass>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:126
 #, no-c-format
 msgid "Four tables are required. The three subclass tables have primary key associations to the superclass table so the relational model is actually a one-to-one association."
 msgstr ""
 
 #. Tag: title
-#: inheritance_mapping.xml:135
 #, no-c-format
 msgid "Table per subclass: using a discriminator"
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:137
 #, no-c-format
 msgid "Hibernate's implementation of table per subclass does not require a discriminator column. Other object/relational mappers use a different implementation of table per subclass that requires a type discriminator column in the superclass table. The approach taken by Hibernate is much more difficult to implement, but arguably more correct from a relational point of view. If you want to use a discriminator column with the table per subclass strategy, you can combine the use of <literal>&lt;subclass&gt;</literal> and <literal>&lt;join&gt;</literal>, as follows:"
 msgstr ""
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:149
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-      "    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-      "    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-      "    ...\n"
-      "    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-      "        <join table=\"CREDIT_PAYMENT\">\n"
-      "            <key column=\"PAYMENT_ID\"/>\n"
-      "            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-      "            ...\n"
-      "        </join>\n"
-      "    </subclass>\n"
-      "    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-      "        <join table=\"CASH_PAYMENT\">\n"
-      "            <key column=\"PAYMENT_ID\"/>\n"
-      "            ...\n"
-      "        </join>\n"
-      "    </subclass>\n"
-      "    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-      "        <join table=\"CHEQUE_PAYMENT\" fetch=\"select\">\n"
-      "            <key column=\"PAYMENT_ID\"/>\n"
-      "            ...\n"
-      "        </join>\n"
-      "    </subclass>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:151
 #, no-c-format
 msgid "The optional <literal>fetch=\"select\"</literal> declaration tells Hibernate not to fetch the <literal>ChequePayment</literal> subclass data using an outer join when querying the superclass."
 msgstr ""
 
 #. Tag: title
-#: inheritance_mapping.xml:160
 #, no-c-format
 msgid "Mixing table per class hierarchy with table per subclass"
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:162
 #, no-c-format
 msgid "You can even mix the table per hierarchy and table per subclass strategies using the following approach:"
 msgstr ""
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:167
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-      "    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-      "    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-      "    ...\n"
-      "    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-      "        <join table=\"CREDIT_PAYMENT\">\n"
-      "            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-      "            ...\n"
-      "        </join>\n"
-      "    </subclass>\n"
-      "    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-      "        ...\n"
-      "    </subclass>\n"
-      "    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-      "        ...\n"
-      "    </subclass>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:169
 #, no-c-format
 msgid "For any of these mapping strategies, a polymorphic association to the root <literal>Payment</literal> class is mapped using <literal>&lt;many-to-one&gt;</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:175
-#, no-c-format
-msgid "<![CDATA[<many-to-one name=\"payment\" column=\"PAYMENT_ID\" class=\"Payment\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:180
 #, no-c-format
 msgid "Table per concrete class"
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:182
 #, no-c-format
 msgid "There are two ways we can map the table per concrete class strategy. First, you can use <literal>&lt;union-subclass&gt;</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:187
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Payment\">\n"
-      "    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-      "        <generator class=\"sequence\"/>\n"
-      "    </id>\n"
-      "    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-      "    ...\n"
-      "    <union-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-      "        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-      "        ...\n"
-      "    </union-subclass>\n"
-      "    <union-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-      "        ...\n"
-      "    </union-subclass>\n"
-      "    <union-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-      "        ...\n"
-      "    </union-subclass>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:189
 #, no-c-format
 msgid "Three tables are involved for the subclasses. Each table defines columns for all properties of the class, including inherited properties."
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:194
 #, no-c-format
 msgid "The limitation of this approach is that if a property is mapped on the superclass, the column name must be the same on all subclass tables. The identity generator strategy is not allowed in union subclass inheritance. The primary key seed has to be shared across all unioned subclasses of a hierarchy."
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:203
 #, no-c-format
 msgid "If your superclass is abstract, map it with <literal>abstract=\"true\"</literal>. If it is not abstract, an additional table (it defaults to <literal>PAYMENT</literal> in the example above), is needed to hold instances of the superclass."
 msgstr ""
 
 #. Tag: title
-#: inheritance_mapping.xml:213
 #, no-c-format
 msgid "Table per concrete class using implicit polymorphism"
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:215
 #, no-c-format
 msgid "An alternative approach is to make use of implicit polymorphism:"
 msgstr ""
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:219
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-      "    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-      "    ...\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-      "    <id name=\"id\" type=\"long\" column=\"CASH_PAYMENT_ID\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-      "    ...\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-      "    <id name=\"id\" type=\"long\" column=\"CHEQUE_PAYMENT_ID\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-      "    ...\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:221
 #, no-c-format
-msgid "Notice that the <literal>Payment</literal> interface is not mentioned explicitly. Also notice that properties of <literal>Payment</literal> are mapped in each of the subclasses. If you want to avoid duplication, consider using XML entities (for example, <literal>[ &lt;!ENTITY allproperties SYSTEM \"allproperties.xml\"&gt; ]</literal> in the <literal>DOCTYPE</literal> declaration and <literal>&amp;allproperties;</literal> in the mapping)."
+msgid "Notice that the <literal>Payment</literal> interface is not mentioned explicitly. Also notice that properties of <literal>Payment</literal> are mapped in each of the subclasses. If you want to avoid duplication, consider using XML entities (for example, <literal>[ &lt;!ENTITY allproperties SYSTEM \"allproperties.xml\"&gt; ]</literal> in the <literal>DOCTYPE</literal> declaration and <literal>&amp;allproperties&semi;</literal> in the mapping)."
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:231
 #, no-c-format
 msgid "The disadvantage of this approach is that Hibernate does not generate SQL <literal>UNION</literal>s when performing polymorphic queries."
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:236
 #, no-c-format
 msgid "For this mapping strategy, a polymorphic association to <literal>Payment</literal> is usually mapped using <literal>&lt;any&gt;</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:241
-#, no-c-format
-msgid ""
-      "<![CDATA[<any name=\"payment\" meta-type=\"string\" id-type=\"long\">\n"
-      "    <meta-value value=\"CREDIT\" class=\"CreditCardPayment\"/>\n"
-      "    <meta-value value=\"CASH\" class=\"CashPayment\"/>\n"
-      "    <meta-value value=\"CHEQUE\" class=\"ChequePayment\"/>\n"
-      "    <column name=\"PAYMENT_CLASS\"/>\n"
-      "    <column name=\"PAYMENT_ID\"/>\n"
-      "</any>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:246
 #, no-c-format
 msgid "Mixing implicit polymorphism with other inheritance mappings"
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:248
 #, no-c-format
 msgid "Since the subclasses are each mapped in their own <literal>&lt;class&gt;</literal> element, and since <literal>Payment</literal> is just an interface), each of the subclasses could easily be part of another inheritance hierarchy. You can still use polymorphic queries against the <literal>Payment</literal> interface."
 msgstr ""
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:256
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-      "    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <discriminator column=\"CREDIT_CARD\" type=\"string\"/>\n"
-      "    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-      "    ...\n"
-      "    <subclass name=\"MasterCardPayment\" discriminator-value=\"MDC\"/>\n"
-      "    <subclass name=\"VisaPayment\" discriminator-value=\"VISA\"/>\n"
-      "</class>\n"
-      "\n"
-      "<class name=\"NonelectronicTransaction\" table=\"NONELECTRONIC_TXN\">\n"
-      "    <id name=\"id\" type=\"long\" column=\"TXN_ID\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    ...\n"
-      "    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-      "        <key column=\"PAYMENT_ID\"/>\n"
-      "        <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-      "        ...\n"
-      "    </joined-subclass>\n"
-      "    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-      "        <key column=\"PAYMENT_ID\"/>\n"
-      "        <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-      "        ...\n"
-      "    </joined-subclass>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:258
 #, no-c-format
 msgid "Once again, <literal>Payment</literal> is not mentioned explicitly. If we execute a query against the <literal>Payment</literal> interface, for example <literal>from Payment</literal>, Hibernate automatically returns instances of <literal>CreditCardPayment</literal> (and its subclasses, since they also implement <literal>Payment</literal>), <literal>CashPayment</literal> and <literal>ChequePayment</literal>, but not instances of <literal>NonelectronicTransaction</literal>."
 msgstr ""
 
 #. Tag: title
-#: inheritance_mapping.xml:273
 #, no-c-format
 msgid "Limitations"
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:275
 #, no-c-format
 msgid "There are limitations to the \"implicit polymorphism\" approach to the table per concrete-class mapping strategy. There are somewhat less restrictive limitations to <literal>&lt;union-subclass&gt;</literal> mappings."
 msgstr ""
 
 #. Tag: para
-#: inheritance_mapping.xml:282
 #, no-c-format
 msgid "The following table shows the limitations of table per concrete-class mappings, and of implicit polymorphism, in Hibernate."
 msgstr ""
 
 #. Tag: title
-#: inheritance_mapping.xml:288
 #, no-c-format
 msgid "Features of inheritance mappings"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:301
 #, no-c-format
 msgid "Inheritance strategy"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:302
 #, no-c-format
 msgid "Polymorphic many-to-one"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:303
 #, no-c-format
 msgid "Polymorphic one-to-one"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:304
 #, no-c-format
 msgid "Polymorphic one-to-many"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:305
 #, no-c-format
 msgid "Polymorphic many-to-many"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:306
 #, no-c-format
 msgid "Polymorphic <literal>load()/get()</literal>"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:307
 #, no-c-format
 msgid "Polymorphic queries"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:308
 #, no-c-format
 msgid "Polymorphic joins"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:309
 #, no-c-format
 msgid "Outer join fetching"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:314
 #, no-c-format
 msgid "table per class-hierarchy"
 msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:315 inheritance_mapping.xml:326 inheritance_mapping.xml:337
+#. Tag: entry
 #, no-c-format
-msgid "&lt;many-to-one&gt;"
+msgid "<literal>&lt;many-to-one&gt;</literal>"
 msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:316 inheritance_mapping.xml:327 inheritance_mapping.xml:338
+#. Tag: entry
 #, no-c-format
-msgid "&lt;one-to-one&gt;"
+msgid "<literal>&lt;one-to-one&gt;</literal>"
 msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:317 inheritance_mapping.xml:328
+#. Tag: entry
 #, no-c-format
-msgid "&lt;one-to-many&gt;"
+msgid "<literal>&lt;one-to-many&gt;</literal>"
 msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:318 inheritance_mapping.xml:329 inheritance_mapping.xml:340
+#. Tag: entry
 #, no-c-format
-msgid "&lt;many-to-many&gt;"
+msgid "<literal>&lt;many-to-many&gt;</literal>"
 msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:319 inheritance_mapping.xml:330 inheritance_mapping.xml:341
+#. Tag: entry
 #, no-c-format
-msgid "s.get(Payment.class, id)"
+msgid "<literal>s.get(Payment.class, id)</literal>"
 msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:320 inheritance_mapping.xml:331 inheritance_mapping.xml:342 inheritance_mapping.xml:353
+#. Tag: entry
 #, no-c-format
-msgid "from Payment p"
+msgid "<literal>from Payment p</literal>"
 msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:321 inheritance_mapping.xml:332 inheritance_mapping.xml:343
+#. Tag: entry
 #, no-c-format
-msgid "from Order o join o.payment p"
+msgid "<literal>from Order o join o.payment p</literal>"
 msgstr ""
 
-#. Tag: emphasis
-#: inheritance_mapping.xml:322 inheritance_mapping.xml:333 inheritance_mapping.xml:344
-#, no-c-format
-msgid "supported"
-msgstr ""
-
 #. Tag: entry
-#: inheritance_mapping.xml:325
 #, no-c-format
-msgid "<entry>table per subclass</entry>"
+msgid "<emphasis>supported</emphasis>"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:336
 #, no-c-format
 msgid "table per concrete-class (union-subclass)"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:339
 #, no-c-format
 msgid "<literal>&lt;one-to-many&gt;</literal> (for <literal>inverse=\"true\"</literal> only)"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:347
 #, no-c-format
 msgid "table per concrete class (implicit polymorphism)"
 msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:348
+#. Tag: entry
 #, no-c-format
-msgid "&lt;any&gt;"
+msgid "<literal>&lt;any&gt;</literal>"
 msgstr ""
 
-#. Tag: emphasis
-#: inheritance_mapping.xml:349 inheritance_mapping.xml:350 inheritance_mapping.xml:354 inheritance_mapping.xml:355
+#. Tag: entry
 #, no-c-format
-msgid "not supported"
+msgid "<emphasis>not supported</emphasis>"
 msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:351
+#. Tag: entry
 #, no-c-format
-msgid "&lt;many-to-any&gt;"
+msgid "<literal>&lt;many-to-any&gt;</literal>"
 msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:352
+#. Tag: entry
 #, no-c-format
-msgid "s.createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()"
+msgid "<literal>s.createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()</literal>"
 msgstr ""
 

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/performance.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/performance.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/performance.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,1561 +1,1103 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-08-17 20:22+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: performance.xml:29
 #, no-c-format
 msgid "Improving performance"
 msgstr ""
 
 #. Tag: title
-#: performance.xml:32
 #, no-c-format
 msgid "Fetching strategies"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:34
 #, no-c-format
 msgid "Hibernate uses a <emphasis>fetching strategy</emphasis> to retrieve associated objects if the application needs to navigate the association. Fetch strategies can be declared in the O/R mapping metadata, or over-ridden by a particular HQL or <literal>Criteria</literal> query."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:41
 #, no-c-format
 msgid "Hibernate3 defines the following fetching strategies:"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:47
 #, no-c-format
 msgid "<emphasis>Join fetching</emphasis>: Hibernate retrieves the associated instance or collection in the same <literal>SELECT</literal>, using an <literal>OUTER JOIN</literal>."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:54
 #, no-c-format
 msgid "<emphasis>Select fetching</emphasis>: a second <literal>SELECT</literal> is used to retrieve the associated entity or collection. Unless you explicitly disable lazy fetching by specifying <literal>lazy=\"false\"</literal>, this second select will only be executed when you access the association."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:63
 #, no-c-format
 msgid "<emphasis>Subselect fetching</emphasis>: a second <literal>SELECT</literal> is used to retrieve the associated collections for all entities retrieved in a previous query or fetch. Unless you explicitly disable lazy fetching by specifying <literal>lazy=\"false\"</literal>, this second select will only be executed when you access the association."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:72
 #, no-c-format
 msgid "<emphasis>Batch fetching</emphasis>: an optimization strategy for select fetching. Hibernate retrieves a batch of entity instances or collections in a single <literal>SELECT</literal> by specifying a list of primary or foreign keys."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:81
 #, no-c-format
 msgid "Hibernate also distinguishes between:"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:87
 #, no-c-format
 msgid "<emphasis>Immediate fetching</emphasis>: an association, collection or attribute is fetched immediately when the owner is loaded."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:93
 #, no-c-format
 msgid "<emphasis>Lazy collection fetching</emphasis>: a collection is fetched when the application invokes an operation upon that collection. This is the default for collections."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:100
 #, no-c-format
 msgid "<emphasis>\"Extra-lazy\" collection fetching</emphasis>: individual elements of the collection are accessed from the database as needed. Hibernate tries not to fetch the whole collection into memory unless absolutely needed. It is suitable for large collections."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:108
 #, no-c-format
 msgid "<emphasis>Proxy fetching</emphasis>: a single-valued association is fetched when a method other than the identifier getter is invoked upon the associated object."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:115
 #, no-c-format
 msgid "<emphasis>\"No-proxy\" fetching</emphasis>: a single-valued association is fetched when the instance variable is accessed. Compared to proxy fetching, this approach is less lazy; the association is fetched even when only the identifier is accessed. It is also more transparent, since no proxy is visible to the application. This approach requires buildtime bytecode instrumentation and is rarely necessary."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:125
 #, no-c-format
 msgid "<emphasis>Lazy attribute fetching</emphasis>: an attribute or single valued association is fetched when the instance variable is accessed. This approach requires buildtime bytecode instrumentation and is rarely necessary."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:134
 #, no-c-format
 msgid "We have two orthogonal notions here: <emphasis>when</emphasis> is the association fetched and <emphasis>how</emphasis> is it fetched. It is important that you do not confuse them. We use <literal>fetch</literal> to tune performance. We can use <literal>lazy</literal> to define a contract for what data is always available in any detached instance of a particular class."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:143
 #, no-c-format
 msgid "Working with lazy associations"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:145
 #, no-c-format
 msgid "By default, Hibernate3 uses lazy select fetching for collections and lazy proxy fetching for single-valued associations. These defaults make sense for most associations in the majority of applications."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:151
 #, no-c-format
 msgid "If you set <literal>hibernate.default_batch_fetch_size</literal>, Hibernate will use the batch fetch optimization for lazy fetching. This optimization can also be enabled at a more granular level."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:158
 #, no-c-format
 msgid "Please be aware that access to a lazy association outside of the context of an open Hibernate session will result in an exception. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:164
-#, no-c-format
-msgid ""
-      "<![CDATA[s = sessions.openSession();\n"
-      "Transaction tx = s.beginTransaction();\n"
-      "            \n"
-      "User u = (User) s.createQuery(\"from User u where u.name=:userName\")\n"
-      "    .setString(\"userName\", userName).uniqueResult();\n"
-      "Map permissions = u.getPermissions();\n"
-      "\n"
-      "tx.commit();\n"
-      "s.close();\n"
-      "\n"
-      "Integer accessLevel = (Integer) permissions.get(\"accounts\");  // Error!]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:166
 #, no-c-format
 msgid "Since the permissions collection was not initialized when the <literal>Session</literal> was closed, the collection will not be able to load its state. <emphasis>Hibernate does not support lazy initialization for detached objects</emphasis>. This can be fixed by moving the code that reads from the collection to just before the transaction is committed."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:174
 #, no-c-format
 msgid "Alternatively, you can use a non-lazy collection or association, by specifying <literal>lazy=\"false\"</literal> for the association mapping. However, it is intended that lazy initialization be used for almost all collections and associations. If you define too many non-lazy associations in your object model, Hibernate will fetch the entire database into memory in every transaction."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:183
 #, no-c-format
 msgid "On the other hand, you can use join fetching, which is non-lazy by nature, instead of select fetching in a particular transaction. We will now explain how to customize the fetching strategy. In Hibernate3, the mechanisms for choosing a fetch strategy are identical for single-valued associations and collections."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:194
 #, no-c-format
 msgid "Tuning fetch strategies"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:196
 #, no-c-format
 msgid "Select fetching (the default) is extremely vulnerable to N+1 selects problems, so we might want to enable join fetching in the mapping document:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:201
-#, no-c-format
-msgid ""
-      "<![CDATA[<set name=\"permissions\" \n"
-      "            fetch=\"join\">\n"
-      "    <key column=\"userId\"/>\n"
-      "    <one-to-many class=\"Permission\"/>\n"
-      "</set]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: performance.xml:203
-#, no-c-format
-msgid "<![CDATA[<many-to-one name=\"mother\" class=\"Cat\" fetch=\"join\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:205
 #, no-c-format
 msgid "The <literal>fetch</literal> strategy defined in the mapping document affects:"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:211
 #, no-c-format
 msgid "retrieval via <literal>get()</literal> or <literal>load()</literal>"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:216
 #, no-c-format
 msgid "retrieval that happens implicitly when an association is navigated"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:221
 #, no-c-format
 msgid "<literal>Criteria</literal> queries"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:226
 #, no-c-format
 msgid "HQL queries if <literal>subselect</literal> fetching is used"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:232
 #, no-c-format
 msgid "Irrespective of the fetching strategy you use, the defined non-lazy graph is guaranteed to be loaded into memory. This might, however, result in several immediate selects being used to execute a particular HQL query."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:238
 #, no-c-format
 msgid "Usually, the mapping document is not used to customize fetching. Instead, we keep the default behavior, and override it for a particular transaction, using <literal>left join fetch</literal> in HQL. This tells Hibernate to fetch the association eagerly in the first select, using an outer join. In the <literal>Criteria</literal> query API, you would use <literal>setFetchMode(FetchMode.JOIN)</literal>."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:247
 #, no-c-format
 msgid "If you want to change the fetching strategy used by <literal>get()</literal> or <literal>load()</literal>, you can use a <literal>Criteria</literal> query. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:253
-#, no-c-format
-msgid ""
-      "<![CDATA[User user = (User) session.createCriteria(User.class)\n"
-      "                .setFetchMode(\"permissions\", FetchMode.JOIN)\n"
-      "                .add( Restrictions.idEq(userId) )\n"
-      "                .uniqueResult();]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:255
 #, no-c-format
 msgid "This is Hibernate's equivalent of what some ORM solutions call a \"fetch plan\"."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:259
 #, no-c-format
 msgid "A completely different approach to problems with N+1 selects is to use the second-level cache."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:267
 #, no-c-format
 msgid "Single-ended association proxies"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:269
 #, no-c-format
 msgid "Lazy fetching for collections is implemented using Hibernate's own implementation of persistent collections. However, a different mechanism is needed for lazy behavior in single-ended associations. The target entity of the association must be proxied. Hibernate implements lazy initializing proxies for persistent objects using runtime bytecode enhancement which is accessed via the CGLIB library."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:277
 #, no-c-format
 msgid "At startup, Hibernate3 generates proxies by default for all persistent classes and uses them to enable lazy fetching of <literal>many-to-one</literal> and <literal>one-to-one</literal> associations."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:283
 #, no-c-format
 msgid "The mapping file may declare an interface to use as the proxy interface for that class, with the <literal>proxy</literal> attribute. By default, Hibernate uses a subclass of the class. <emphasis>The proxied class must implement a default constructor with at least package visibility. This constructor is recommended for all persistent classes</emphasis>."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:290
 #, no-c-format
 msgid "There are potential problems to note when extending this approach to polymorphic classes.For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:294
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Cat\" proxy=\"Cat\">\n"
-      "    ......\n"
-      "    <subclass name=\"DomesticCat\">\n"
-      "        .....\n"
-      "    </subclass>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:296
 #, no-c-format
 msgid "Firstly, instances of <literal>Cat</literal> will never be castable to <literal>DomesticCat</literal>, even if the underlying instance is an instance of <literal>DomesticCat</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:302
-#, no-c-format
-msgid ""
-      "<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);  // instantiate a proxy (does not hit the db)\n"
-      "if ( cat.isDomesticCat() ) {                  // hit the db to initialize the proxy\n"
-      "    DomesticCat dc = (DomesticCat) cat;       // Error!\n"
-      "    ....\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:304
 #, no-c-format
 msgid "Secondly, it is possible to break proxy <literal>==</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:308
-#, no-c-format
-msgid ""
-      "<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);            // instantiate a Cat proxy\n"
-      "DomesticCat dc = \n"
-      "        (DomesticCat) session.load(DomesticCat.class, id);  // acquire new DomesticCat proxy!\n"
-      "System.out.println(cat==dc);                            // false]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:310
 #, no-c-format
 msgid "However, the situation is not quite as bad as it looks. Even though we now have two references to different proxy objects, the underlying instance will still be the same object:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:315
-#, no-c-format
-msgid ""
-      "<![CDATA[cat.setWeight(11.0);  // hit the db to initialize the proxy\n"
-      "System.out.println( dc.getWeight() );  // 11.0]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:317
 #, no-c-format
 msgid "Third, you cannot use a CGLIB proxy for a <literal>final</literal> class or a class with any <literal>final</literal> methods."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:322
 #, no-c-format
 msgid "Finally, if your persistent object acquires any resources upon instantiation (e.g. in initializers or default constructor), then those resources will also be acquired by the proxy. The proxy class is an actual subclass of the persistent class."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:328
 #, no-c-format
 msgid "These problems are all due to fundamental limitations in Java's single inheritance model. To avoid these problems your persistent classes must each implement an interface that declares its business methods. You should specify these interfaces in the mapping file where <literal>CatImpl</literal> implements the interface <literal>Cat</literal> and <literal>DomesticCatImpl</literal> implements the interface <literal>DomesticCat</literal>. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:336
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"CatImpl\" proxy=\"Cat\">\n"
-      "    ......\n"
-      "    <subclass name=\"DomesticCatImpl\" proxy=\"DomesticCat\">\n"
-      "        .....\n"
-      "    </subclass>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:338
 #, no-c-format
 msgid "Then proxies for instances of <literal>Cat</literal> and <literal>DomesticCat</literal> can be returned by <literal>load()</literal> or <literal>iterate()</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:343
-#, no-c-format
-msgid ""
-      "<![CDATA[Cat cat = (Cat) session.load(CatImpl.class, catid);\n"
-      "Iterator iter = session.createQuery(\"from CatImpl as cat where cat.name='fritz'\").iterate();\n"
-      "Cat fritz = (Cat) iter.next();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:346
 #, no-c-format
 msgid "Note"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:347
 #, no-c-format
 msgid "<literal>list()</literal> does not usually return proxies."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:352
 #, no-c-format
 msgid "Relationships are also lazily initialized. This means you must declare any properties to be of type <literal>Cat</literal>, not <literal>CatImpl</literal>."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:357
 #, no-c-format
 msgid "Certain operations do <emphasis>not</emphasis> require proxy initialization:"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:363
 #, no-c-format
 msgid "<literal>equals()</literal>: if the persistent class does not override <literal>equals()</literal>"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:369
 #, no-c-format
 msgid "<literal>hashCode()</literal>: if the persistent class does not override <literal>hashCode()</literal>"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:375
 #, no-c-format
 msgid "The identifier getter method"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:381
 #, no-c-format
 msgid "Hibernate will detect persistent classes that override <literal>equals()</literal> or <literal>hashCode()</literal>."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:386
 #, no-c-format
 msgid "By choosing <literal>lazy=\"no-proxy\"</literal> instead of the default <literal>lazy=\"proxy\"</literal>, you can avoid problems associated with typecasting. However, buildtime bytecode instrumentation is required, and all operations will result in immediate proxy initialization."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:396
 #, no-c-format
 msgid "Initializing collections and proxies"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:398
 #, no-c-format
 msgid "A <literal>LazyInitializationException</literal> will be thrown by Hibernate if an uninitialized collection or proxy is accessed outside of the scope of the <literal>Session</literal>, i.e., when the entity owning the collection or having the reference to the proxy is in the detached state."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:404
 #, no-c-format
 msgid "Sometimes a proxy or collection needs to be initialized before closing the <literal>Session</literal>. You can force initialization by calling <literal>cat.getSex()</literal> or <literal>cat.getKittens().size()</literal>, for example. However, this can be confusing to readers of the code and it is not convenient for generic code."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:411
 #, no-c-format
 msgid "The static methods <literal>Hibernate.initialize()</literal> and <literal>Hibernate.isInitialized()</literal>, provide the application with a convenient way of working with lazily initialized collections or proxies. <literal>Hibernate.initialize(cat)</literal> will force the initialization of a proxy, <literal>cat</literal>, as long as its <literal>Session</literal> is still open. <literal>Hibernate.initialize( cat.getKittens() )</literal> has a similar effect for the collection of kittens."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:420
 #, no-c-format
 msgid "Another option is to keep the <literal>Session</literal> open until all required collections and proxies have been loaded. In some application architectures, particularly where the code that accesses data using Hibernate, and the code that uses it are in different application layers or different physical processes, it can be a problem to ensure that the <literal>Session</literal> is open when a collection is initialized. There are two basic ways to deal with this issue:"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:431
 #, no-c-format
 msgid "In a web-based application, a servlet filter can be used to close the <literal>Session</literal> only at the end of a user request, once the rendering of the view is complete (the <emphasis>Open Session in View</emphasis> pattern). Of course, this places heavy demands on the correctness of the exception handling of your application infrastructure. It is vitally important that the <literal>Session</literal> is closed and the transaction ended before returning to the user, even when an exception occurs during rendering of the view. See the Hibernate Wiki for examples of this \"Open Session in View\" pattern."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:444
 #, no-c-format
 msgid "In an application with a separate business tier, the business logic must \"prepare\" all collections that the web tier needs before returning. This means that the business tier should load all the data and return all the data already initialized to the presentation/web tier that is required for a particular use case. Usually, the application calls <literal>Hibernate.initialize()</literal> for each collection that will be needed in the web tier (this call must occur before the session is closed) or retrieves the collection eagerly using a Hibernate query with a <literal>FETCH</literal> clause or a <literal>FetchMode.JOIN</literal> in <literal>Criteria</literal>. This is usually easier if you adopt the <emphasis>Command</emphasis> pattern instead of a <emphasis>Session Facade</emphasis>."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:459
 #, no-c-format
 msgid "You can also attach a previously loaded object to a new <literal>Session</literal> with <literal>merge()</literal> or <literal>lock()</literal> before accessing uninitialized collections or other proxies. Hibernate does not, and certainly <emphasis>should</emphasis> not, do this automatically since it would introduce impromptu transaction semantics."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:469
 #, no-c-format
 msgid "Sometimes you do not want to initialize a large collection, but still need some information about it, like its size, for example, or a subset of the data."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:474
 #, no-c-format
 msgid "You can use a collection filter to get the size of a collection without initializing it:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:478
-#, no-c-format
-msgid "<![CDATA[( (Integer) s.createFilter( collection, \"select count(*)\" ).list().get(0) ).intValue()]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:480
 #, no-c-format
 msgid "The <literal>createFilter()</literal> method is also used to efficiently retrieve subsets of a collection without needing to initialize the whole collection:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:485
-#, no-c-format
-msgid "<![CDATA[s.createFilter( lazyCollection, \"\").setFirstResult(0).setMaxResults(10).list();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:490
 #, no-c-format
 msgid "Using batch fetching"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:492
 #, no-c-format
 msgid "Using batch fetching, Hibernate can load several uninitialized proxies if one proxy is accessed. Batch fetching is an optimization of the lazy select fetching strategy. There are two ways you can configure batch fetching: on the class level and the collection level."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:498
 #, no-c-format
 msgid "Batch fetching for classes/entities is easier to understand. Consider the following example: at runtime you have 25 <literal>Cat</literal> instances loaded in a <literal>Session</literal>, and each <literal>Cat</literal> has a reference to its <literal>owner</literal>, a <literal>Person</literal>. The <literal>Person</literal> class is mapped with a proxy, <literal>lazy=\"true\"</literal>. If you now iterate through all cats and call <literal>getOwner()</literal> on each, Hibernate will, by default, execute 25 <literal>SELECT</literal> statements to retrieve the proxied owners. You can tune this behavior by specifying a <literal>batch-size</literal> in the mapping of <literal>Person</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:508
-#, no-c-format
-msgid "<![CDATA[<class name=\"Person\" batch-size=\"10\">...</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:510
 #, no-c-format
 msgid "Hibernate will now execute only three queries: the pattern is 10, 10, 5."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:514
 #, no-c-format
 msgid "You can also enable batch fetching of collections. For example, if each <literal>Person</literal> has a lazy collection of <literal>Cat</literal>s, and 10 persons are currently loaded in the <literal>Session</literal>, iterating through all persons will generate 10 <literal>SELECT</literal>s, one for every call to <literal>getCats()</literal>. If you enable batch fetching for the <literal>cats</literal> collection in the mapping of <literal>Person</literal>, Hibernate can pre-fetch collections:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:523
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <set name=\"cats\" batch-size=\"3\">\n"
-      "        ...\n"
-      "    </set>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:525
 #, no-c-format
 msgid "With a <literal>batch-size</literal> of 3, Hibernate will load 3, 3, 3, 1 collections in four <literal>SELECT</literal>s. Again, the value of the attribute depends on the expected number of uninitialized collections in a particular <literal>Session</literal>."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:531
 #, no-c-format
 msgid "Batch fetching of collections is particularly useful if you have a nested tree of items, i.e. the typical bill-of-materials pattern. However, a <emphasis>nested set</emphasis> or a <emphasis>materialized path</emphasis> might be a better option for read-mostly trees."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:540
 #, no-c-format
 msgid "Using subselect fetching"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:542
 #, no-c-format
 msgid "If one lazy collection or single-valued proxy has to be fetched, Hibernate will load all of them, re-running the original query in a subselect. This works in the same way as batch-fetching but without the piecemeal loading."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:553
 #, no-c-format
-msgid "Using lazy property fetching"
+msgid "Fetch profiles"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:555
 #, no-c-format
-msgid "Hibernate3 supports the lazy fetching of individual properties. This optimization technique is also known as <emphasis>fetch groups</emphasis>. Please note that this is mostly a marketing feature; optimizing row reads is much more important than optimization of column reads. However, only loading some properties of a class could be useful in extreme cases. For example, when legacy tables have hundreds of columns and the data model cannot be improved."
+msgid "Another way to affect the fetching strategy for loading associated objects is through something called a fetch profile, which is a named configuration associated with the <interfacename>org.hibernate.SessionFactory</interfacename> but enabled, by name, on the <interfacename>org.hibernate.Session</interfacename>. Once enabled on a <interfacename>org.hibernate.Session</interfacename>, the fetch profile wull be in affect for that <interfacename>org.hibernate.Session</interfacename> until it is explicitly disabled."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:564
 #, no-c-format
-msgid "To enable lazy property loading, set the <literal>lazy</literal> attribute on your particular property mappings:"
+msgid "So what does that mean? Well lets explain that by way of an example. Say we have the following mappings:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:569
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Document\">\n"
-      "       <id name=\"id\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <property name=\"name\" not-null=\"true\" length=\"50\"/>\n"
-      "    <property name=\"summary\" not-null=\"true\" length=\"200\" lazy=\"true\"/>\n"
-      "    <property name=\"text\" not-null=\"true\" length=\"2000\" lazy=\"true\"/>\n"
-      "</class>]]>"
+msgid "Now normally when you get a reference to a particular customer, that customer's set of orders will be lazy meaning we will not yet have loaded those orders from the database. Normally this is a good thing. Now lets say that you have a certain use case where it is more efficient to load the customer and their orders together. One way certainly is to use \"dynamic fetching\" strategies via an HQL or criteria queries. But another option is to use a fetch profile to achieve that. Just add the following to your mapping:"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:571
 #, no-c-format
-msgid "Lazy property loading requires buildtime bytecode instrumentation. If your persistent classes are not enhanced, Hibernate will ignore lazy property settings and return to immediate fetching."
+msgid "or even:"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:577
 #, no-c-format
-msgid "For bytecode instrumentation, use the following Ant task:"
+msgid "Now the following code will actually load both the customer <emphasis>and their orders</emphasis>:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:581
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[<target name=\"instrument\" depends=\"compile\">\n"
-      "    <taskdef name=\"instrument\" classname=\"org.hibernate.tool.instrument.InstrumentTask\">\n"
-      "        <classpath path=\"${jar.path}\"/>\n"
-      "        <classpath path=\"${classes.dir}\"/>\n"
-      "        <classpath refid=\"lib.class.path\"/>\n"
-      "    </taskdef>\n"
-      "\n"
-      "    <instrument verbose=\"true\">\n"
-      "        <fileset dir=\"${testclasses.dir}/org/hibernate/auction/model\">\n"
-      "            <include name=\"*.class\"/>\n"
-      "        </fileset>\n"
-      "    </instrument>\n"
-      "</target>]]>"
+msgid "Currently only join style fetch profiles are supported, but they plan is to support additional styles. See <ulink url=\"http://opensource.atlassian.com/projects/hibernate/browse/HHH-3414\">HHH-3414</ulink> for details."
 msgstr ""
 
+#. Tag: title
+#, no-c-format
+msgid "Using lazy property fetching"
+msgstr ""
+
 #. Tag: para
-#: performance.xml:583
 #, no-c-format
+msgid "Hibernate3 supports the lazy fetching of individual properties. This optimization technique is also known as <emphasis>fetch groups</emphasis>. Please note that this is mostly a marketing feature; optimizing row reads is much more important than optimization of column reads. However, only loading some properties of a class could be useful in extreme cases. For example, when legacy tables have hundreds of columns and the data model cannot be improved."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "To enable lazy property loading, set the <literal>lazy</literal> attribute on your particular property mappings:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "Lazy property loading requires buildtime bytecode instrumentation. If your persistent classes are not enhanced, Hibernate will ignore lazy property settings and return to immediate fetching."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "For bytecode instrumentation, use the following Ant task:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
 msgid "A different way of avoiding unnecessary column reads, at least for read-only transactions, is to use the projection features of HQL or Criteria queries. This avoids the need for buildtime bytecode processing and is certainly a preferred solution."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:590
 #, no-c-format
 msgid "You can force the usual eager fetching of properties using <literal>fetch all properties</literal> in HQL."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:600
 #, no-c-format
 msgid "The Second Level Cache"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:602
 #, no-c-format
 msgid "A Hibernate <literal>Session</literal> is a transaction-level cache of persistent data. It is possible to configure a cluster or JVM-level (<literal>SessionFactory</literal>-level) cache on a class-by-class and collection-by-collection basis. You can even plug in a clustered cache. Be aware that caches are not aware of changes made to the persistent store by another application. They can, however, be configured to regularly expire cached data."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:610
 #, no-c-format
 msgid "You have the option to tell Hibernate which caching implementation to use by specifying the name of a class that implements <literal>org.hibernate.cache.CacheProvider</literal> using the property <literal>hibernate.cache.provider_class</literal>. Hibernate is bundled with a number of built-in integrations with the open-source cache providers that are listed below. You can also implement your own and plug it in as outlined above. Note that versions prior to 3.2 use EhCache as the default cache provider."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:621
 #, no-c-format
 msgid "Cache Providers"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:630 performance.xml:818
 #, no-c-format
 msgid "Cache"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:631
 #, no-c-format
 msgid "Provider class"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:632
 #, no-c-format
 msgid "Type"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:633
 #, no-c-format
 msgid "Cluster Safe"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:634
 #, no-c-format
 msgid "Query Cache Supported"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:639 performance.xml:827
 #, no-c-format
 msgid "Hashtable (not intended for production use)"
 msgstr ""
 
-#. Tag: literal
-#: performance.xml:640
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.cache.HashtableCacheProvider"
+msgid "<literal>org.hibernate.cache.HashtableCacheProvider</literal>"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:641
 #, no-c-format
 msgid "memory"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:643 performance.xml:650 performance.xml:657 performance.xml:828 performance.xml:829 performance.xml:830 performance.xml:835 performance.xml:836 performance.xml:837 performance.xml:842 performance.xml:843 performance.xml:844 performance.xml:849 performance.xml:850 performance.xml:856 performance.xml:859 performance.xml:863 performance.xml:866
 #, no-c-format
-msgid "<entry>yes</entry>"
+msgid "yes"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:646 performance.xml:834
 #, no-c-format
 msgid "EHCache"
 msgstr ""
 
-#. Tag: literal
-#: performance.xml:647
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.cache.EhCacheProvider"
+msgid "<literal>org.hibernate.cache.EhCacheProvider</literal>"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:648 performance.xml:655
 #, no-c-format
 msgid "memory, disk"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:653 performance.xml:841
 #, no-c-format
 msgid "OSCache"
 msgstr ""
 
-#. Tag: literal
-#: performance.xml:654
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.cache.OSCacheProvider"
+msgid "<literal>org.hibernate.cache.OSCacheProvider</literal>"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:660 performance.xml:848
 #, no-c-format
 msgid "SwarmCache"
 msgstr ""
 
-#. Tag: literal
-#: performance.xml:661
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.cache.SwarmCacheProvider"
+msgid "<literal>org.hibernate.cache.SwarmCacheProvider</literal>"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:662
 #, no-c-format
 msgid "clustered (ip multicast)"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:663
 #, no-c-format
 msgid "yes (clustered invalidation)"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:667 performance.xml:855
 #, no-c-format
 msgid "JBoss Cache 1.x"
 msgstr ""
 
-#. Tag: literal
-#: performance.xml:668
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.cache.TreeCacheProvider"
+msgid "<literal>org.hibernate.cache.TreeCacheProvider</literal>"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:669 performance.xml:676
 #, no-c-format
 msgid "clustered (ip multicast), transactional"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:670
 #, no-c-format
 msgid "yes (replication)"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:671 performance.xml:678
 #, no-c-format
 msgid "yes (clock sync req.)"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:674 performance.xml:862
 #, no-c-format
 msgid "JBoss Cache 2"
 msgstr ""
 
-#. Tag: literal
-#: performance.xml:675
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.cache.jbc.JBossCacheRegionFactory"
+msgid "<literal>org.hibernate.cache.jbc.JBossCacheRegionFactory</literal>"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:677
 #, no-c-format
 msgid "yes (replication or invalidation)"
 msgstr ""
 
 #. Tag: title
-#: performance.xml:685
 #, no-c-format
 msgid "Cache mappings"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:687
 #, no-c-format
 msgid "The <literal>&lt;cache&gt;</literal> element of a class or collection mapping has the following form:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:698
-#, no-c-format
-msgid ""
-      "<![CDATA[<cache \n"
-      "    usage=\"transactional|read-write|nonstrict-read-write|read-only\"\n"
-      "    region=\"RegionName\"\n"
-      "    include=\"all|non-lazy\"\n"
-      "/>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:701
 #, no-c-format
 msgid "<literal>usage</literal> (required) specifies the caching strategy: <literal>transactional</literal>, <literal>read-write</literal>, <literal>nonstrict-read-write</literal> or <literal>read-only</literal>"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:710
 #, no-c-format
 msgid "<literal>region</literal> (optional: defaults to the class or collection role name): specifies the name of the second level cache region"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:717
 #, no-c-format
 msgid "<literal>include</literal> (optional: defaults to <literal>all</literal>) <literal>non-lazy</literal>: specifies that properties of the entity mapped with <literal>lazy=\"true\"</literal> cannot be cached when attribute-level lazy fetching is enabled"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:727
 #, no-c-format
 msgid "Alternatively, you can specify <literal>&lt;class-cache&gt;</literal> and <literal>&lt;collection-cache&gt;</literal> elements in <literal>hibernate.cfg.xml</literal>."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:732
 #, no-c-format
 msgid "The <literal>usage</literal> attribute specifies a <emphasis>cache concurrency strategy</emphasis>."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:739
 #, no-c-format
 msgid "Strategy: read only"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:741
 #, no-c-format
 msgid "If your application needs to read, but not modify, instances of a persistent class, a <literal>read-only</literal> cache can be used. This is the simplest and optimal performing strategy. It is even safe for use in a cluster."
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:747
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"eg.Immutable\" mutable=\"false\">\n"
-      "    <cache usage=\"read-only\"/>\n"
-      "    ....\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:753
 #, no-c-format
 msgid "Strategy: read/write"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:755
 #, no-c-format
 msgid "If the application needs to update data, a <literal>read-write</literal> cache might be appropriate. This cache strategy should never be used if serializable transaction isolation level is required. If the cache is used in a JTA environment, you must specify the property <literal>hibernate.transaction.manager_lookup_class</literal> and naming a strategy for obtaining the JTA <literal>TransactionManager</literal>. In other environments, you should ensure that the transaction is completed when <literal>Session.close()</literal> or <literal>Session.disconnect()</literal> is called. If you want to use this strategy in a cluster, you should ensure that the underlying cache implementation supports locking. The built-in cache providers <emphasis>do not</emphasis> support locking."
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:766
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"eg.Cat\" .... >\n"
-      "    <cache usage=\"read-write\"/>\n"
-      "    ....\n"
-      "    <set name=\"kittens\" ... >\n"
-      "        <cache usage=\"read-write\"/>\n"
-      "        ....\n"
-      "    </set>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:771
 #, no-c-format
 msgid "Strategy: nonstrict read/write"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:773
 #, no-c-format
 msgid "If the application only occasionally needs to update data (i.e. if it is extremely unlikely that two transactions would try to update the same item simultaneously), and strict transaction isolation is not required, a <literal>nonstrict-read-write</literal> cache might be appropriate. If the cache is used in a JTA environment, you must specify <literal>hibernate.transaction.manager_lookup_class</literal>. In other environments, you should ensure that the transaction is completed when <literal>Session.close()</literal> or <literal>Session.disconnect()</literal> is called."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:785
 #, no-c-format
 msgid "Strategy: transactional"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:787
 #, no-c-format
 msgid "The <literal>transactional</literal> cache strategy provides support for fully transactional cache providers such as JBoss TreeCache. Such a cache can only be used in a JTA environment and you must specify <literal>hibernate.transaction.manager_lookup_class</literal>."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:796
 #, no-c-format
 msgid "Cache-provider/concurrency-strategy compatibility"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:799
 #, no-c-format
 msgid "None of the cache providers support all of the cache concurrency strategies."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:804
 #, no-c-format
 msgid "The following table shows which providers are compatible with which concurrency strategies."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:809
 #, no-c-format
 msgid "Cache Concurrency Strategy Support"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:819
 #, no-c-format
 msgid "read-only"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:820
 #, no-c-format
 msgid "nonstrict-read-write"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:821
 #, no-c-format
 msgid "read-write"
 msgstr ""
 
 #. Tag: entry
-#: performance.xml:822
 #, no-c-format
 msgid "transactional"
 msgstr ""
 
 #. Tag: title
-#: performance.xml:877
 #, no-c-format
 msgid "Managing the caches"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:879
 #, no-c-format
 msgid "Whenever you pass an object to <literal>save()</literal>, <literal>update()</literal> or <literal>saveOrUpdate()</literal>, and whenever you retrieve an object using <literal>load()</literal>, <literal>get()</literal>, <literal>list()</literal>, <literal>iterate()</literal> or <literal>scroll()</literal>, that object is added to the internal cache of the <literal>Session</literal>."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:886
 #, no-c-format
 msgid "When <literal>flush()</literal> is subsequently called, the state of that object will be synchronized with the database. If you do not want this synchronization to occur, or if you are processing a huge number of objects and need to manage memory efficiently, the <literal>evict()</literal> method can be used to remove the object and its collections from the first-level cache."
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:894
-#, no-c-format
-msgid ""
-      "<![CDATA[ScrollableResult cats = sess.createQuery(\"from Cat as cat\").scroll(); //a huge result set\n"
-      "while ( cats.next() ) {\n"
-      "    Cat cat = (Cat) cats.get(0);\n"
-      "    doSomethingWithACat(cat);\n"
-      "    sess.evict(cat);\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:896
 #, no-c-format
 msgid "The <literal>Session</literal> also provides a <literal>contains()</literal> method to determine if an instance belongs to the session cache."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:901
 #, no-c-format
 msgid "To evict all objects from the session cache, call <literal>Session.clear()</literal>"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:905
 #, no-c-format
 msgid "For the second-level cache, there are methods defined on <literal>SessionFactory</literal> for evicting the cached state of an instance, entire class, collection instance or entire collection role."
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:911
-#, no-c-format
-msgid ""
-      "<![CDATA[sessionFactory.evict(Cat.class, catId); //evict a particular Cat\n"
-      "sessionFactory.evict(Cat.class);  //evict all Cats\n"
-      "sessionFactory.evictCollection(\"Cat.kittens\", catId); //evict a particular collection of kittens\n"
-      "sessionFactory.evictCollection(\"Cat.kittens\"); //evict all kitten collections]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:913
 #, no-c-format
 msgid "The <literal>CacheMode</literal> controls how a particular session interacts with the second-level cache:"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:920
 #, no-c-format
 msgid "<literal>CacheMode.NORMAL</literal>: will read items from and write items to the second-level cache"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:925
 #, no-c-format
 msgid "<literal>CacheMode.GET</literal>: will read items from the second-level cache. Do not write to the second-level cache except when updating data"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:931
 #, no-c-format
 msgid "<literal>CacheMode.PUT</literal>: will write items to the second-level cache. Do not read from the second-level cache"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:937
 #, no-c-format
 msgid "<literal>CacheMode.REFRESH</literal>: will write items to the second-level cache. Do not read from the second-level cache. Bypass the effect of <literal>hibernate.cache.use_minimal_puts</literal> forcing a refresh of the second-level cache for all items read from the database"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:945
 #, no-c-format
 msgid "To browse the contents of a second-level or query cache region, use the <literal>Statistics</literal> API:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:950
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[Map cacheEntries = sessionFactory.getStatistics()\n"
-      "        .getSecondLevelCacheStatistics(regionName)\n"
-      "        .getEntries();]]>"
+msgid "You will need to enable statistics and, optionally, force Hibernate to keep the cache entries in a more readable format:"
 msgstr ""
 
-#. Tag: para
-#: performance.xml:952
+#. Tag: title
 #, no-c-format
-msgid "You will need to enable statistics and, optionally, force Hibernate to keep the cache entries in a more readable format:"
+msgid "The Query Cache"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:957
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[hibernate.generate_statistics true\n"
-      "hibernate.cache.use_structured_entries true]]>"
+msgid "Query result sets can also be cached. This is only useful for queries that are run frequently with the same parameters."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:962
 #, no-c-format
-msgid "The Query Cache"
+msgid "Enabling query caching"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:964
 #, no-c-format
-msgid "Query result sets can also be cached. This is only useful for queries that are run frequently with the same parameters. You will first need to enable the query cache:"
+msgid "Caching of query results introduces some overhead in terms of your applications normal transactional processing. For example, if you cache results of a query against Person Hibernate will need to keep track of when those results should be invalidated because changes have been committed against Person. That, coupled with the fact that most applications simply gain no benefit from caching query results, leads Hibernate to disable caching of query results by default. To use query caching, you will first need to enable the query cache:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:969
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[hibernate.cache.use_query_cache true]]>"
+msgid "This setting creates two new cache regions:"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:971
 #, no-c-format
-msgid "This setting creates two new cache regions: one holding cached query result sets (<literal>org.hibernate.cache.StandardQueryCache</literal>), the other holding timestamps of the most recent updates to queryable tables (<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). Note that the query cache does not cache the state of the actual entities in the result set; it caches only identifier values and results of value type. The query cache should always be used in conjunction with the second-level cache."
+msgid "<classname>org.hibernate.cache.StandardQueryCache</classname>, holding the cached query results"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:981
 #, no-c-format
-msgid "Most queries do not benefit from caching, so by default, queries are not cached. To enable caching, call <literal>Query.setCacheable(true)</literal>. This call allows the query to look for existing cache results or add its results to the cache when it is executed."
+msgid "<classname>org.hibernate.cache.UpdateTimestampsCache</classname>, holding timestamps of the most recent updates to queryable tables. These are used to validate the results as they are served from the query cache."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:988
 #, no-c-format
-msgid "If you require fine-grained control over query cache expiration policies, you can specify a named cache region for a particular query by calling <literal>Query.setCacheRegion()</literal>."
+msgid "If you configure your underlying cache implementation to use expiry or timeouts is is very important that the cache timeout of the underlying cache region for the UpdateTimestampsCache be set to a higher value than the timeouts of any of the query caches. In fact, we recommend that the the UpdateTimestampsCache region not be configured for expiry at all. Note, in particular, that an LRU cache expiry policy is never appropriate."
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:994
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[List blogs = sess.createQuery(\"from Blog blog where blog.blogger = :blogger\")\n"
-      "    .setEntity(\"blogger\", blogger)\n"
-      "    .setMaxResults(15)\n"
-      "    .setCacheable(true)\n"
-      "    .setCacheRegion(\"frontpages\")\n"
-      "    .list();]]>"
+msgid "As mentioned above, most queries do not benefit from caching or their results. So by default, individual queries are not cached even after enabling query caching. To enable results caching for a particular query, call <literal>org.hibernate.Query.setCacheable(true)</literal>. This call allows the query to look for existing cache results or add its results to the cache when it is executed."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:996
 #, no-c-format
-msgid "If the query should force a refresh of its query cache region, you should call <literal>Query.setCacheMode(CacheMode.REFRESH)</literal>. This is particularly useful in cases where underlying data may have been updated via a separate process (i.e., not modified through Hibernate) and allows the application to selectively refresh particular query result sets. This is a more efficient alternative to eviction of a query cache region via <literal>SessionFactory.evictQueries()</literal>."
+msgid "The query cache does not cache the state of the actual entities in the cache; it caches only identifier values and results of value type. For this reaso, the query cache should always be used in conjunction with the second-level cache for those entities expected to be cached as part of a query result cache (just as with collection caching)."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:1008
 #, no-c-format
+msgid "Query cache regions"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "If you require fine-grained control over query cache expiration policies, you can specify a named cache region for a particular query by calling <literal>Query.setCacheRegion()</literal>."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "If you want to force the query cache to refresh one of its regions (disregard any cached results it finds there) you can use <literal>org.hibernate.Query.setCacheMode(CacheMode.REFRESH)</literal>. In conjunction with the region you have defined for the given query, Hibernate will selectively force the results cached in that particular region to be refreshed. This is particularly useful in cases where underlying data may have been updated via a separate process and is a far more efficient alternative to bulk eviction of the region via <literal>org.hibernate.SessionFactory.evictQueries()</literal>."
+msgstr ""
+
+#. Tag: title
+#, no-c-format
 msgid "Understanding Collection performance"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1010
 #, no-c-format
 msgid "In the previous sections we have covered collections and their applications. In this section we explore some more issues in relation to collections at runtime."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:1017
 #, no-c-format
 msgid "Taxonomy"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1019
 #, no-c-format
 msgid "Hibernate defines three basic kinds of collections:"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1023
 #, no-c-format
 msgid "collections of values"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1026
 #, no-c-format
 msgid "one-to-many associations"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1029
 #, no-c-format
 msgid "many-to-many associations"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1033
 #, no-c-format
 msgid "This classification distinguishes the various table and foreign key relationships but does not tell us quite everything we need to know about the relational model. To fully understand the relational structure and performance characteristics, we must also consider the structure of the primary key that is used by Hibernate to update or delete collection rows. This suggests the following classification:"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1044
 #, no-c-format
 msgid "indexed collections"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1047
 #, no-c-format
 msgid "sets"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1050
 #, no-c-format
 msgid "bags"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1054
 #, no-c-format
 msgid "All indexed collections (maps, lists, and arrays) have a primary key consisting of the <literal>&lt;key&gt;</literal> and <literal>&lt;index&gt;</literal> columns. In this case, collection updates are extremely efficient. The primary key can be efficiently indexed and a particular row can be efficiently located when Hibernate tries to update or delete it."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1062
 #, no-c-format
 msgid "Sets have a primary key consisting of <literal>&lt;key&gt;</literal> and element columns. This can be less efficient for some types of collection element, particularly composite elements or large text or binary fields, as the database may not be able to index a complex primary key as efficiently. However, for one-to-many or many-to-many associations, particularly in the case of synthetic identifiers, it is likely to be just as efficient. If you want <literal>SchemaExport</literal> to actually create the primary key of a <literal>&lt;set&gt;</literal>, you must declare all columns as <literal>not-null=\"true\"</literal>."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1073
 #, no-c-format
 msgid "<literal>&lt;idbag&gt;</literal> mappings define a surrogate key, so they are efficient to update. In fact, they are the best case."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1078
 #, no-c-format
 msgid "Bags are the worst case since they permit duplicate element values and, as they have no index column, no primary key can be defined. Hibernate has no way of distinguishing between duplicate rows. Hibernate resolves this problem by completely removing in a single <literal>DELETE</literal> and recreating the collection whenever it changes. This can be inefficient."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1086
 #, no-c-format
 msgid "For a one-to-many association, the \"primary key\" may not be the physical primary key of the database table. Even in this case, the above classification is still useful. It reflects how Hibernate \"locates\" individual rows of the collection."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:1096
 #, no-c-format
 msgid "Lists, maps, idbags and sets are the most efficient collections to update"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1098
 #, no-c-format
 msgid "From the discussion above, it should be clear that indexed collections and sets allow the most efficient operation in terms of adding, removing and updating elements."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1104
 #, no-c-format
 msgid "There is, arguably, one more advantage that indexed collections have over sets for many-to-many associations or collections of values. Because of the structure of a <literal>Set</literal>, Hibernate does not <literal>UPDATE</literal> a row when an element is \"changed\". Changes to a <literal>Set</literal> always work via <literal>INSERT</literal> and <literal>DELETE</literal> of individual rows. Once again, this consideration does not apply to one-to-many associations."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1113
 #, no-c-format
 msgid "After observing that arrays cannot be lazy, you can conclude that lists, maps and idbags are the most performant (non-inverse) collection types, with sets not far behind. You can expect sets to be the most common kind of collection in Hibernate applications. This is because the \"set\" semantics are most natural in the relational model."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1121
 #, no-c-format
 msgid "However, in well-designed Hibernate domain models, most collections are in fact one-to-many associations with <literal>inverse=\"true\"</literal>. For these associations, the update is handled by the many-to-one end of the association, and so considerations of collection update performance simply do not apply."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:1131
 #, no-c-format
 msgid "Bags and lists are the most efficient inverse collections"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1133
 #, no-c-format
 msgid "There is a particular case, however, in which bags, and also lists, are much more performant than sets. For a collection with <literal>inverse=\"true\"</literal>, the standard bidirectional one-to-many relationship idiom, for example, we can add elements to a bag or list without needing to initialize (fetch) the bag elements. This is because, unlike a <literal>set</literal>, <literal>Collection.add()</literal> or <literal>Collection.addAll()</literal> must always return true for a bag or <literal>List</literal>. This can make the following common code much faster:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:1143
-#, no-c-format
-msgid ""
-      "<![CDATA[Parent p = (Parent) sess.load(Parent.class, id);\n"
-      "Child c = new Child();\n"
-      "c.setParent(p);\n"
-      "p.getChildren().add(c);  //no need to fetch the collection!\n"
-      "sess.flush();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:1148
 #, no-c-format
 msgid "One shot delete"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1150
 #, no-c-format
 msgid "Deleting collection elements one by one can sometimes be extremely inefficient. Hibernate knows not to do that in the case of an newly-empty collection (if you called <literal>list.clear()</literal>, for example). In this case, Hibernate will issue a single <literal>DELETE</literal>."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1157
 #, no-c-format
 msgid "Suppose you added a single element to a collection of size twenty and then remove two elements. Hibernate will issue one <literal>INSERT</literal> statement and two <literal>DELETE</literal> statements, unless the collection is a bag. This is certainly desirable."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1163
 #, no-c-format
 msgid "However, suppose that we remove eighteen elements, leaving two and then add thee new elements. There are two possible ways to proceed"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1170
 #, no-c-format
 msgid "delete eighteen rows one by one and then insert three rows"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1173
 #, no-c-format
 msgid "remove the whole collection in one SQL <literal>DELETE</literal> and insert all five current elements one by one"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1178
 #, no-c-format
 msgid "Hibernate cannot know that the second option is probably quicker. It would probably be undesirable for Hibernate to be that intuitive as such behavior might confuse database triggers, etc."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1184
 #, no-c-format
 msgid "Fortunately, you can force this behavior (i.e. the second strategy) at any time by discarding (i.e. dereferencing) the original collection and returning a newly instantiated collection with all the current elements."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1190
 #, no-c-format
 msgid "One-shot-delete does not apply to collections mapped <literal>inverse=\"true\"</literal>."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:1199
 #, no-c-format
 msgid "Monitoring performance"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1201
 #, no-c-format
 msgid "Optimization is not much use without monitoring and access to performance numbers. Hibernate provides a full range of figures about its internal operations. Statistics in Hibernate are available per <literal>SessionFactory</literal>."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:1208
 #, no-c-format
 msgid "Monitoring a SessionFactory"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1210
 #, no-c-format
 msgid "You can access <literal>SessionFactory</literal> metrics in two ways. Your first option is to call <literal>sessionFactory.getStatistics()</literal> and read or display the <literal>Statistics</literal> yourself."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1216
 #, no-c-format
 msgid "Hibernate can also use JMX to publish metrics if you enable the <literal>StatisticsService</literal> MBean. You can enable a single MBean for all your <literal>SessionFactory</literal> or one per factory. See the following code for minimalistic configuration examples:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:1223
-#, no-c-format
-msgid ""
-      "<![CDATA[// MBean service registration for a specific SessionFactory\n"
-      "Hashtable tb = new Hashtable();\n"
-      "tb.put(\"type\", \"statistics\");\n"
-      "tb.put(\"sessionFactory\", \"myFinancialApp\");\n"
-      "ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-      "\n"
-      "StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-      "stats.setSessionFactory(sessionFactory); // Bind the stats to a SessionFactory\n"
-      "server.registerMBean(stats, on); // Register the Mbean on the server]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: performance.xml:1226
-#, no-c-format
-msgid ""
-      "<![CDATA[// MBean service registration for all SessionFactory's\n"
-      "Hashtable tb = new Hashtable();\n"
-      "tb.put(\"type\", \"statistics\");\n"
-      "tb.put(\"sessionFactory\", \"all\");\n"
-      "ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-      "\n"
-      "StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-      "server.registerMBean(stats, on); // Register the MBean on the server]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:1228
 #, no-c-format
 msgid "You can activate and deactivate the monitoring for a <literal>SessionFactory</literal>:"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1233
 #, no-c-format
 msgid "at configuration time, set <literal>hibernate.generate_statistics</literal> to <literal>false</literal>"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1240
 #, no-c-format
 msgid "at runtime: <literal>sf.getStatistics().setStatisticsEnabled(true)</literal> or <literal>hibernateStatsBean.setStatisticsEnabled(true)</literal>"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1247
 #, no-c-format
 msgid "Statistics can be reset programmatically using the <literal>clear()</literal> method. A summary can be sent to a logger (info level) using the <literal>logSummary()</literal> method."
 msgstr ""
 
 #. Tag: title
-#: performance.xml:1256
 #, no-c-format
 msgid "Metrics"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1258
 #, no-c-format
 msgid "Hibernate provides a number of metrics, from basic information to more specialized information that is only relevant in certain scenarios. All available counters are described in the <literal>Statistics</literal> interface API, in three categories:"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1265
 #, no-c-format
 msgid "Metrics related to the general <literal>Session</literal> usage, such as number of open sessions, retrieved JDBC connections, etc."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1271
 #, no-c-format
 msgid "Metrics related to the entities, collections, queries, and caches as a whole (aka global metrics)."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1277
 #, no-c-format
 msgid "Detailed metrics related to a particular entity, collection, query or cache region."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1284
 #, no-c-format
 msgid "For example, you can check the cache hit, miss, and put ratio of entities, collections and queries, and the average time a query needs. Be aware that the number of milliseconds is subject to approximation in Java. Hibernate is tied to the JVM precision and on some platforms this might only be accurate to 10 seconds."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:1291
 #, no-c-format
 msgid "Simple getters are used to access the global metrics (i.e. not tied to a particular entity, collection, cache region, etc.). You can access the metrics of a particular entity, collection or cache region through its name, and through its HQL or SQL representation for queries. Please refer to the <literal>Statistics</literal>, <literal>EntityStatistics</literal>, <literal>CollectionStatistics</literal>, <literal>SecondLevelCacheStatistics</literal>, and <literal>QueryStatistics</literal> API Javadoc for more information. The following code is a simple example:"
 msgstr ""
 
-#. Tag: programlisting
-#: performance.xml:1301
-#, no-c-format
-msgid ""
-      "<![CDATA[Statistics stats = HibernateUtil.sessionFactory.getStatistics();\n"
-      "\n"
-      "double queryCacheHitCount  = stats.getQueryCacheHitCount();\n"
-      "double queryCacheMissCount = stats.getQueryCacheMissCount();\n"
-      "double queryCacheHitRatio =\n"
-      "  queryCacheHitCount / (queryCacheHitCount + queryCacheMissCount);\n"
-      "\n"
-      "log.info(\"Query Hit ratio:\" + queryCacheHitRatio);\n"
-      "\n"
-      "EntityStatistics entityStats =\n"
-      "  stats.getEntityStatistics( Cat.class.getName() );\n"
-      "long changes =\n"
-      "        entityStats.getInsertCount()\n"
-      "        + entityStats.getUpdateCount()\n"
-      "        + entityStats.getDeleteCount();\n"
-      "log.info(Cat.class.getName() + \" changed \" + changes + \"times\"  );]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:1303
 #, no-c-format
 msgid "You can work on all entities, collections, queries and region caches, by retrieving the list of names of entities, collections, queries and region caches using the following methods: <literal>getQueries()</literal>, <literal>getEntityNames()</literal>, <literal>getCollectionRoleNames()</literal>, and <literal>getSecondLevelCacheRegionNames()</literal>."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/persistent_classes.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/persistent_classes.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/persistent_classes.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,709 +1,283 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-08-17 20:22+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: persistent_classes.xml:29
 #, no-c-format
 msgid "Persistent Classes"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:31
 #, 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 ""
 
 #. Tag: para
-#: persistent_classes.xml:38
 #, 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</literal> instances, for example)."
 msgstr ""
 
 #. Tag: title
-#: persistent_classes.xml:47
 #, no-c-format
 msgid "A simple POJO example"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:49
 #, no-c-format
 msgid "Most Java applications require a persistent class representing felines. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: persistent_classes.xml:53
-#, no-c-format
-msgid ""
-      "<![CDATA[package eg;\n"
-      "import java.util.Set;\n"
-      "import java.util.Date;\n"
-      "\n"
-      "public class Cat {\n"
-      "    private Long id; // identifier\n"
-      "\n"
-      "    private Date birthdate;\n"
-      "    private Color color;\n"
-      "    private char sex;\n"
-      "    private float weight;\n"
-      "    private int litterId;\n"
-      "\n"
-      "    private Cat mother;\n"
-      "    private Set kittens = new HashSet();\n"
-      "\n"
-      "    private void setId(Long id) {\n"
-      "        this.id=id;\n"
-      "    }\n"
-      "    public Long getId() {\n"
-      "        return id;\n"
-      "    }\n"
-      "\n"
-      "    void setBirthdate(Date date) {\n"
-      "        birthdate = date;\n"
-      "    }\n"
-      "    public Date getBirthdate() {\n"
-      "        return birthdate;\n"
-      "    }\n"
-      "\n"
-      "    void setWeight(float weight) {\n"
-      "        this.weight = weight;\n"
-      "    }\n"
-      "    public float getWeight() {\n"
-      "        return weight;\n"
-      "    }\n"
-      "\n"
-      "    public Color getColor() {\n"
-      "        return color;\n"
-      "    }\n"
-      "    void setColor(Color color) {\n"
-      "        this.color = color;\n"
-      "    }\n"
-      "\n"
-      "    void setSex(char sex) {\n"
-      "        this.sex=sex;\n"
-      "    }\n"
-      "    public char getSex() {\n"
-      "        return sex;\n"
-      "    }\n"
-      "\n"
-      "    void setLitterId(int id) {\n"
-      "        this.litterId = id;\n"
-      "    }\n"
-      "    public int getLitterId() {\n"
-      "        return litterId;\n"
-      "    }\n"
-      "\n"
-      "    void setMother(Cat mother) {\n"
-      "        this.mother = mother;\n"
-      "    }\n"
-      "    public Cat getMother() {\n"
-      "        return mother;\n"
-      "    }\n"
-      "    void setKittens(Set kittens) {\n"
-      "        this.kittens = kittens;\n"
-      "    }\n"
-      "    public Set getKittens() {\n"
-      "        return kittens;\n"
-      "    }\n"
-      "    \n"
-      "    // addKitten not needed by Hibernate\n"
-      "    public void addKitten(Cat kitten) {\n"
-      "            kitten.setMother(this);\n"
-      "        kitten.setLitterId( kittens.size() ); \n"
-      "        kittens.add(kitten);\n"
-      "    }\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:55
 #, no-c-format
 msgid "The four main rules of persistent classes are explored in more detail in the following sections."
 msgstr ""
 
 #. Tag: title
-#: persistent_classes.xml:61
 #, no-c-format
 msgid "Implement a no-argument constructor"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:63
 #, no-c-format
 msgid "<literal>Cat</literal> 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()</literal>. It is recommended that you have a default constructor with at least <emphasis>package</emphasis> visibility for runtime proxy generation in Hibernate."
 msgstr ""
 
 #. Tag: title
-#: persistent_classes.xml:73
 #, no-c-format
 msgid "Provide an identifier property (optional)"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:75
 #, no-c-format
 msgid "<literal>Cat</literal> has a property called <literal>id</literal>. 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</literal> or <literal>java.util.Date</literal>. 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 ""
 
 #. Tag: para
-#: persistent_classes.xml:84
 #, 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 ""
 
 #. Tag: para
-#: persistent_classes.xml:89
 #, no-c-format
 msgid "In fact, some functionality is available only to classes that declare an identifier property:"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:96
 #, no-c-format
-msgid "Transitive reattachment for detached objects (cascade update or cascade merge) - see"
+msgid "Transitive reattachment for detached objects (cascade update or cascade merge) - see <xref linkend=\"objectstate-transitive\" />"
 msgstr ""
 
-#. Tag: literal
-#: persistent_classes.xml:103
+#. Tag: para
 #, no-c-format
-msgid "Session.saveOrUpdate()"
+msgid "<literal>Session.saveOrUpdate()</literal>"
 msgstr ""
 
-#. Tag: literal
-#: persistent_classes.xml:108
+#. Tag: para
 #, no-c-format
-msgid "Session.merge()"
+msgid "<literal>Session.merge()</literal>"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:113
 #, 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 ""
 
 #. Tag: title
-#: persistent_classes.xml:120
 #, no-c-format
 msgid "Prefer non-final classes (optional)"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:121
 #, no-c-format
 msgid "A central feature of Hibernate, <emphasis>proxies</emphasis>, depends upon the persistent class being either non-final, or the implementation of an interface that declares all public methods."
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:126
 #, no-c-format
 msgid "You can persist <literal>final</literal> 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 ""
 
 #. Tag: para
-#: persistent_classes.xml:131
 #, no-c-format
 msgid "You should also avoid declaring <literal>public final</literal> 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\"</literal>."
 msgstr ""
 
 #. Tag: title
-#: persistent_classes.xml:139
 #, no-c-format
 msgid "Declare accessors and mutators for persistent fields (optional)"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:141
 #, no-c-format
 msgid "<literal>Cat</literal> 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>getFoo</literal>, <literal>isFoo</literal> and <literal>setFoo</literal>. If required, you can switch to direct field access for particular properties."
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:151
 #, no-c-format
 msgid "Properties need <emphasis>not</emphasis> be declared public - Hibernate can persist a property with a default, <literal>protected</literal> or <literal>private</literal> get / set pair."
 msgstr ""
 
 #. Tag: title
-#: persistent_classes.xml:162
 #, no-c-format
 msgid "Implementing inheritance"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:164
 #, no-c-format
 msgid "A subclass must also observe the first and second rules. It inherits its identifier property from the superclass, <literal>Cat</literal>. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: persistent_classes.xml:169
-#, no-c-format
-msgid ""
-      "<![CDATA[package eg;\n"
-      "\n"
-      "public class DomesticCat extends Cat {\n"
-      "        private String name;\n"
-      "\n"
-      "        public String getName() {\n"
-      "                return name;\n"
-      "        }\n"
-      "        protected void setName(String name) {\n"
-      "                this.name=name;\n"
-      "        }\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: title
-#: persistent_classes.xml:173
 #, no-c-format
 msgid "Implementing <literal>equals()</literal> and <literal>hashCode()</literal>"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:175
 #, no-c-format
 msgid "You have to override the <literal>equals()</literal> and <literal>hashCode()</literal> methods if you:"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:181
 #, no-c-format
 msgid "intend to put instances of persistent classes in a <literal>Set</literal> (the recommended way to represent many-valued associations); <emphasis>and</emphasis>"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:188
 #, no-c-format
 msgid "intend to use reattachment of detached instances"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:194
 #, 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()</literal> and <literal>hashCode()</literal> if you wish to have meaningful semantics for <literal>Set</literal>s."
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:202
 #, no-c-format
 msgid "The most obvious way is to implement <literal>equals()</literal>/<literal>hashCode()</literal> 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</literal>, you will only have one element in the <literal>Set</literal>). 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</literal>, saving it will assign an identifier value to the object. If <literal>equals()</literal> and <literal>hashCode()</literal> are based on the identifier value, the hash code would change, breaking the contract of the <literal>Set</literal>. See the Hibernate website for a full discussion of this problem. This is not a Hibernate issue, but normal Ja!
 va semantics of object identity and equality."
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:216
 #, no-c-format
 msgid "It is recommended that you implement <literal>equals()</literal> and <literal>hashCode()</literal> using <emphasis>Business key equality</emphasis>. Business key equality means that the <literal>equals()</literal> 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</emphasis> candidate key):"
 msgstr ""
 
-#. Tag: programlisting
-#: persistent_classes.xml:224
-#, no-c-format
-msgid ""
-      "<![CDATA[public class Cat {\n"
-      "\n"
-      "    ...\n"
-      "    public boolean equals(Object other) {\n"
-      "        if (this == other) return true;\n"
-      "        if ( !(other instanceof Cat) ) return false;\n"
-      "\n"
-      "        final Cat cat = (Cat) other;\n"
-      "\n"
-      "        if ( !cat.getLitterId().equals( getLitterId() ) ) return false;\n"
-      "        if ( !cat.getMother().equals( getMother() ) ) return false;\n"
-      "\n"
-      "        return true;\n"
-      "    }\n"
-      "\n"
-      "    public int hashCode() {\n"
-      "        int result;\n"
-      "        result = getMother().hashCode();\n"
-      "        result = 29 * result + getLitterId();\n"
-      "        return result;\n"
-      "    }\n"
-      "\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:226
 #, 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."
+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 ""
 
 #. Tag: title
-#: persistent_classes.xml:236
 #, no-c-format
 msgid "Dynamic models"
 msgstr ""
 
 #. Tag: title
-#: persistent_classes.xml:239
 #, no-c-format
 msgid "Note"
 msgstr ""
 
-#. Tag: emphasis
-#: persistent_classes.xml:241
+#. Tag: para
 #, no-c-format
-msgid "The following features are currently considered experimental and may change in the near future."
+msgid "<emphasis>The following features are currently considered experimental and may change in the near future.</emphasis>"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:246
 #, 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>Map</literal>s of <literal>Map</literal>s at runtime) and the representation of entities as DOM4J trees. With this approach, you do not write persistent classes, only mapping files."
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:254
 #, no-c-format
-msgid "By default, Hibernate works in normal POJO mode. You can set a default entity representation mode for a particular <literal>SessionFactory</literal> using the <literal>default_entity_mode</literal> configuration option (see <xref linkend=\"configuration-optional-properties\"/>)."
+msgid "By default, Hibernate works in normal POJO mode. You can set a default entity representation mode for a particular <literal>SessionFactory</literal> using the <literal>default_entity_mode</literal> configuration option (see <xref linkend=\"configuration-optional-properties\" />)."
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:261
 #, no-c-format
 msgid "The following examples demonstrate the representation using <literal>Map</literal>s. First, in the mapping file an <literal>entity-name</literal> has to be declared instead of, or in addition to, a class name:"
 msgstr ""
 
-#. Tag: programlisting
-#: persistent_classes.xml:267
-#, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping>\n"
-      "\n"
-      "    <class entity-name=\"Customer\">\n"
-      "\n"
-      "        <id name=\"id\"\n"
-      "            type=\"long\"\n"
-      "            column=\"ID\">\n"
-      "            <generator class=\"sequence\"/>\n"
-      "        </id>\n"
-      "\n"
-      "        <property name=\"name\"\n"
-      "            column=\"NAME\"\n"
-      "            type=\"string\"/>\n"
-      "\n"
-      "        <property name=\"address\"\n"
-      "            column=\"ADDRESS\"\n"
-      "            type=\"string\"/>\n"
-      "\n"
-      "        <many-to-one name=\"organization\"\n"
-      "            column=\"ORGANIZATION_ID\"\n"
-      "            class=\"Organization\"/>\n"
-      "\n"
-      "        <bag name=\"orders\"\n"
-      "            inverse=\"true\"\n"
-      "            lazy=\"false\"\n"
-      "            cascade=\"all\">\n"
-      "            <key column=\"CUSTOMER_ID\"/>\n"
-      "            <one-to-many class=\"Order\"/>\n"
-      "        </bag>\n"
-      "\n"
-      "    </class>\n"
-      "    \n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:269
 #, 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 ""
 
 #. Tag: para
-#: persistent_classes.xml:276
 #, no-c-format
 msgid "After setting the default entity mode to <literal>dynamic-map</literal> for the <literal>SessionFactory</literal>, you can, at runtime, work with <literal>Map</literal>s of <literal>Map</literal>s:"
 msgstr ""
 
-#. Tag: programlisting
-#: persistent_classes.xml:282
-#, no-c-format
-msgid ""
-      "<![CDATA[Session s = openSession();\n"
-      "Transaction tx = s.beginTransaction();\n"
-      "Session s = openSession();\n"
-      "\n"
-      "// Create a customer\n"
-      "Map david = new HashMap();\n"
-      "david.put(\"name\", \"David\");\n"
-      "\n"
-      "// Create an organization\n"
-      "Map foobar = new HashMap();\n"
-      "foobar.put(\"name\", \"Foobar Inc.\");\n"
-      "\n"
-      "// Link both\n"
-      "david.put(\"organization\", foobar);\n"
-      "\n"
-      "// Save both\n"
-      "s.save(\"Customer\", david);\n"
-      "s.save(\"Organization\", foobar);\n"
-      "\n"
-      "tx.commit();\n"
-      "s.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:284
 #, 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 ""
 
 #. Tag: para
-#: persistent_classes.xml:292
 #, no-c-format
 msgid "Entity representation modes can also be set on a per <literal>Session</literal> basis:"
 msgstr ""
 
-#. Tag: programlisting
-#: persistent_classes.xml:297
-#, no-c-format
-msgid ""
-      "<![CDATA[Session dynamicSession = pojoSession.getSession(EntityMode.MAP);\n"
-      "\n"
-      "// Create a customer\n"
-      "Map david = new HashMap();\n"
-      "david.put(\"name\", \"David\");\n"
-      "dynamicSession.save(\"Customer\", david);\n"
-      "...\n"
-      "dynamicSession.flush();\n"
-      "dynamicSession.close()\n"
-      "...\n"
-      "// Continue on pojoSession\n"
-      "]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:300
 #, no-c-format
 msgid "Please note that the call to <literal>getSession()</literal> using an <literal>EntityMode</literal> is on the <literal>Session</literal> API, not the <literal>SessionFactory</literal>. That way, the new <literal>Session</literal> shares the underlying JDBC connection, transaction, and other context information. This means you do not have to call <literal>flush()</literal> and <literal>close()</literal> on the secondary <literal>Session</literal>, and also leave the transaction and connection handling to the primary unit of work."
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:310
 #, no-c-format
-msgid "More information about the XML representation capabilities can be found in <xref linkend=\"xml\"/>."
+msgid "More information about the XML representation capabilities can be found in <xref linkend=\"xml\" />."
 msgstr ""
 
 #. Tag: title
-#: persistent_classes.xml:318
 #, no-c-format
 msgid "Tuplizers"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:320
 #, no-c-format
 msgid "<literal>org.hibernate.tuple.Tuplizer</literal>, and its sub-interfaces, are responsible for managing a particular representation of a piece of data given that representation's <literal>org.hibernate.EntityMode</literal>. 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 ""
 
 #. Tag: para
-#: persistent_classes.xml:330
 #, no-c-format
 msgid "There are two high-level types of Tuplizers, represented by the <literal>org.hibernate.tuple.entity.EntityTuplizer</literal> and <literal>org.hibernate.tuple.component.ComponentTuplizer</literal> interfaces. <literal>EntityTuplizer</literal>s are responsible for managing the above mentioned contracts in regards to entities, while <literal>ComponentTuplizer</literal>s do the same for components."
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:338
 #, no-c-format
 msgid "Users can also plug in their own tuplizers. Perhaps you require that a <literal>java.util.Map</literal> implementation other than <literal>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 ""
 
-#. Tag: programlisting
-#: persistent_classes.xml:347
-#, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping>\n"
-      "    <class entity-name=\"Customer\">\n"
-      "        <!--\n"
-      "            Override the dynamic-map entity-mode\n"
-      "            tuplizer for the customer entity\n"
-      "        -->\n"
-      "        <tuplizer entity-mode=\"dynamic-map\"\n"
-      "                class=\"CustomMapTuplizerImpl\"/>\n"
-      "\n"
-      "        <id name=\"id\" type=\"long\" column=\"ID\">\n"
-      "            <generator class=\"sequence\"/>\n"
-      "        </id>\n"
-      "\n"
-      "        <!-- other properties -->\n"
-      "        ...\n"
-      "    </class>\n"
-      "</hibernate-mapping>\n"
-      "\n"
-      "\n"
-      "public class CustomMapTuplizerImpl\n"
-      "        extends org.hibernate.tuple.entity.DynamicMapEntityTuplizer {\n"
-      "    // override the buildInstantiator() method to plug in our custom map...\n"
-      "    protected final Instantiator buildInstantiator(\n"
-      "            org.hibernate.mapping.PersistentClass mappingInfo) {\n"
-      "        return new CustomMapInstantiator( mappingInfo );\n"
-      "    }\n"
-      "\n"
-      "    private static final class CustomMapInstantiator\n"
-      "            extends org.hibernate.tuple.DynamicMapInstantitor {\n"
-      "        // override the generateMap() method to return our custom map...\n"
-      "            protected final Map generateMap() {\n"
-      "                    return new CustomMap();\n"
-      "            }\n"
-      "    }\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: title
-#: persistent_classes.xml:354
 #, no-c-format
 msgid "EntityNameResolvers"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:356
 #, no-c-format
 msgid "The <interfacename>org.hibernate.EntityNameResolver</interfacename> interface is a contract for resolving the entity name of a given entity instance. The interface defines a single method <methodname>resolveEntityName</methodname> 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</interfacename> 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: programlisting
-#: persistent_classes.xml:368
-#, no-c-format
-msgid ""
-      "/**\n"
-      " * A very trivial JDK Proxy InvocationHandler implementation where we proxy an interface as\n"
-      " * the domain model and simply store persistent state in an internal Map.  This is an extremely\n"
-      " * trivial example meant only for illustration.\n"
-      " */\n"
-      "public final class DataProxyHandler implements InvocationHandler {\n"
-      "        private String entityName;\n"
-      "        private HashMap data = new HashMap();\n"
-      "\n"
-      "        public DataProxyHandler(String entityName, Serializable id) {\n"
-      "                this.entityName = entityName;\n"
-      "                data.put( \"Id\", id );\n"
-      "        }\n"
-      "\n"
-      "        public Object invoke(Object proxy, Method method, Object[] args) throws Throwable {\n"
-      "                String methodName = method.getName();\n"
-      "                if ( methodName.startsWith( \"set\" ) ) {\n"
-      "                        String propertyName = methodName.substring( 3 );\n"
-      "                        data.put( propertyName, args[0] );\n"
-      "                }\n"
-      "                else if ( methodName.startsWith( \"get\" ) ) {\n"
-      "                        String propertyName = methodName.substring( 3 );\n"
-      "                        return data.get( propertyName );\n"
-      "                }\n"
-      "                else if ( \"toString\".equals( methodName ) ) {\n"
-      "                        return entityName + \"#\" + data.get( \"Id\" );\n"
-      "                }\n"
-      "                else if ( \"hashCode\".equals( methodName ) ) {\n"
-      "                        return new Integer( this.hashCode() );\n"
-      "                }\n"
-      "                return null;\n"
-      "        }\n"
-      "\n"
-      "        public String getEntityName() {\n"
-      "                return entityName;\n"
-      "        }\n"
-      "\n"
-      "        public HashMap getData() {\n"
-      "                return data;\n"
-      "        }\n"
-      "}\n"
-      "\n"
-      "/**\n"
-      " *\n"
-      " */\n"
-      "public class ProxyHelper {\n"
-      "    public static String extractEntityName(Object object) {\n"
-      "        // Our custom java.lang.reflect.Proxy instances actually bundle\n"
-      "        // their appropriate entity name, so we simply extract it from there\n"
-      "        // if this represents one of our proxies; otherwise, we return null\n"
-      "        if ( Proxy.isProxyClass( object.getClass() ) ) {\n"
-      "            InvocationHandler handler = Proxy.getInvocationHandler( object );\n"
-      "            if ( DataProxyHandler.class.isAssignableFrom( handler.getClass() ) ) {\n"
-      "                DataProxyHandler myHandler = ( DataProxyHandler ) handler;\n"
-      "                return myHandler.getEntityName();\n"
-      "            }\n"
-      "        }\n"
-      "        return null;\n"
-      "    }\n"
-      "\n"
-      "    // various other utility methods ....\n"
-      "\n"
-      "}\n"
-      "\n"
-      "/**\n"
-      " * The EntityNameResolver implementation.\n"
-      " * IMPL NOTE : An EntityNameResolver really defines a strategy for how entity names should be\n"
-      " * resolved.  Since this particular impl can handle resolution for all of our entities we want to\n"
-      " * take advantage of the fact that SessionFactoryImpl keeps these in a Set so that we only ever\n"
-      " * have one instance registered.  Why?  Well, when it comes time to resolve an entity name,\n"
-      " * Hibernate must iterate over all the registered resolvers.  So keeping that number down\n"
-      " * helps that process be as speedy as possible.  Hence the equals and hashCode impls\n"
-      " */\n"
-      "public class MyEntityNameResolver implements EntityNameResolver {\n"
-      "    public static final MyEntityNameResolver INSTANCE = new MyEntityNameResolver();\n"
-      "\n"
-      "    public String resolveEntityName(Object entity) {\n"
-      "        return ProxyHelper.extractEntityName( entity );\n"
-      "    }\n"
-      "\n"
-      "    public boolean equals(Object obj) {\n"
-      "        return getClass().equals( obj.getClass() );\n"
-      "    }\n"
-      "\n"
-      "    public int hashCode() {\n"
-      "        return getClass().hashCode();\n"
-      "    }\n"
-      "}\n"
-      "\n"
-      "public class MyEntityTuplizer extends PojoEntityTuplizer {\n"
-      "        public MyEntityTuplizer(EntityMetamodel entityMetamodel, PersistentClass mappedEntity) {\n"
-      "                super( entityMetamodel, mappedEntity );\n"
-      "        }\n"
-      "\n"
-      "        public EntityNameResolver[] getEntityNameResolvers() {\n"
-      "                return new EntityNameResolver[] { MyEntityNameResolver.INSTANCE };\n"
-      "        }\n"
-      "\n"
-      "    public String determineConcreteSubclassEntityName(Object entityInstance, SessionFactoryImplementor factory) {\n"
-      "        String entityName = ProxyHelper.extractEntityName( entityInstance );\n"
-      "        if ( entityName == null ) {\n"
-      "            entityName = super.determineConcreteSubclassEntityName( entityInstance, factory );\n"
-      "        }\n"
-      "        return entityName;\n"
-      "    }\n"
-      "\n"
-      "    ...\n"
-      "}"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:370
 #, no-c-format
 msgid "In order to register an <interfacename>org.hibernate.EntityNameResolver</interfacename> users must either:"
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:374
 #, no-c-format
 msgid "Implement a custom <link linkend=\"persistent-classes-tuplizers\">Tuplizer</link>, implementing the <methodname>getEntityNameResolvers</methodname> method."
 msgstr ""
 
 #. Tag: para
-#: persistent_classes.xml:380
 #, no-c-format
 msgid "Register it with the <classname>org.hibernate.impl.SessionFactoryImpl</classname> (which is the implementation class for <interfacename>org.hibernate.SessionFactory</interfacename>) using the <methodname>registerEntityNameResolver</methodname> method."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/portability.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/portability.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/portability.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,135 +1,143 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: portability.xml:26
 #, no-c-format
 msgid "Database Portability Considerations"
 msgstr ""
 
 #. Tag: title
-#: portability.xml:29
 #, no-c-format
 msgid "Portability Basics"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:31
 #, no-c-format
 msgid "One of the selling points of Hibernate (and really Object/Relational Mapping as a whole) is the notion of database portability. This could mean an internal IT user migrating from one database vendor to another, or it could mean a framework or deployable application consuming Hibernate to simultaneously target multiple database products by their users. Regardless of the exact scenario, the basic idea is that you want Hibernate to help you run against any number of databases without changes to your code, and ideally without any changes to the mapping metadata."
 msgstr ""
 
 #. Tag: title
-#: portability.xml:42
 #, no-c-format
 msgid "Dialect"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:44
 #, no-c-format
 msgid "The first line of portability for Hibernate is the dialect, which is a specialization of the <classname>org.hibernate.dialect.Dialect</classname> contract. A dialect encapsulates all the differences in how Hibernate must communicate with a particular database to accomplish some task like getting a sequence value or structuring a SELECT query. Hibernate bundles a wide range of dialects for many of the most popular databases. If you find that your particular database is not among them, it is not terribly difficult to write your own."
 msgstr ""
 
 #. Tag: title
-#: portability.xml:55
 #, no-c-format
 msgid "Dialect resolution"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:57
 #, no-c-format
 msgid "Originally, Hibernate would always require that users specify which dialect to use. In the case of users looking to simultaneously target multiple databases with their build that was problematic. Generally this required their users to configure the Hibernate dialect or defining their own method of setting that value."
 msgstr ""
 
 #. Tag: para
-#: portability.xml:64
 #, no-c-format
 msgid "Starting with version 3.2, Hibernate introduced the notion of automatically detecting the dialect to use based on the <interfacename>java.sql.DatabaseMetaData</interfacename> obtained from a <interfacename>java.sql.Connection</interfacename> to that database. This was much better, expect that this resolution was limited to databases Hibernate know about ahead of time and was in no way configurable or overrideable."
 msgstr ""
 
 #. Tag: para
-#: portability.xml:72
 #, no-c-format
-msgid "Starting with version 3.3, Hibernate has a fare more powerful way to automatically determine which dialect to should be used by relying on a series of delegates which implement the <interfacename>org.hibernate.dialect.resolver.DialectResolver</interfacename> which defines only a single method:<programlisting><![CDATA[public Dialect resolveDialect(DatabaseMetaData metaData) throws JDBCConnectionException]]></programlisting>. The basic contract here is that if the resolver 'understands' the given database metadata then it returns the corresponding Dialect; if not it returns null and the process continues to the next resolver. The signature also identifies <exceptionname>org.hibernate.exception.JDBCConnectionException</exceptionname> as possibly being thrown. A JDBCConnectionException here is interpreted to imply a \"non transient\" (aka non-recoverable) connection problem and is used to indicate an immediate stop to resolution attempts. All other exceptions result in a!
  warning and continuing on to the next resolver."
+msgid "Starting with version 3.3, Hibernate has a fare more powerful way to automatically determine which dialect to should be used by relying on a series of delegates which implement the <interfacename>org.hibernate.dialect.resolver.DialectResolver</interfacename> which defines only a single method:<programlisting role=\"JAVA\">public Dialect resolveDialect(DatabaseMetaData metaData) throws JDBCConnectionException</programlisting>. The basic contract here is that if the resolver 'understands' the given database metadata then it returns the corresponding Dialect; if not it returns null and the process continues to the next resolver. The signature also identifies <exceptionname>org.hibernate.exception.JDBCConnectionException</exceptionname> as possibly being thrown. A JDBCConnectionException here is interpreted to imply a \"non transient\" (aka non-recoverable) connection problem and is used to indicate an immediate stop to resolution attempts. All other exceptions result in!
  a warning and continuing on to the next resolver."
 msgstr ""
 
 #. Tag: para
-#: portability.xml:85
 #, no-c-format
 msgid "The cool part about these resolvers is that users can also register their own custom resolvers which will be processed ahead of the built-in Hibernate ones. This might be useful in a number of different situations: it allows easy integration for auto-detection of dialects beyond those shipped with HIbernate itself; it allows you to specify to use a custom dialect when a particular database is recognized; etc. To register one or more resolvers, simply specify them (seperated by commas, tabs or spaces) using the 'hibernate.dialect_resolvers' configuration setting (see the <constant>DIALECT_RESOLVERS</constant> constant on <classname>org.hibernate.cfg.Environment</classname>)."
 msgstr ""
 
 #. Tag: title
-#: portability.xml:98
 #, no-c-format
 msgid "Identifier generation"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:100
 #, no-c-format
-msgid "When considering portability between databases, another important decision is selecting the identifier generation stratagy you want to use. Originally Hibernate provided the <emphasis>native</emphasis> generator for this purpose, which was intended to select between a <emphasis>sequence</emphasis>, <emphasis>identity</emphasis>, or <emphasis>table</emphasis> strategy depending on the capability of the underlying database. However, an insidious implication of this approach comes about when targtetting some databases which support <emphasis>identity</emphasis> generation and some which do not. <emphasis>identity</emphasis> generation relies on the SQL definition of an IDENTITY (or auto-increment) column to manage the identifier value; it is what is known as a post-insert generation strategy becauase the insert must actually happen before we can know the identifier value. Because Hibernate relies on this identifier value to uniquely reference entities within a persisten!
 ce context it must then issue the insert immediately when the users requests the entitiy be associated with the session (like via save() e.g.) regardless of current transactional semantics. <note> <para> Hibernate was changed slightly once the implication of this was better understood so that the insert is delayed in cases where that is feasible. </para> </note> The underlying issue is that the actual semanctics of the application itself changes in these cases."
+msgid "When considering portability between databases, another important decision is selecting the identifier generation stratagy you want to use. Originally Hibernate provided the <emphasis>native</emphasis> generator for this purpose, which was intended to select between a <emphasis>sequence</emphasis>, <emphasis>identity</emphasis>, or <emphasis>table</emphasis> strategy depending on the capability of the underlying database. However, an insidious implication of this approach comes about when targtetting some databases which support <emphasis>identity</emphasis> generation and some which do not. <emphasis>identity</emphasis> generation relies on the SQL definition of an IDENTITY (or auto-increment) column to manage the identifier value; it is what is known as a post-insert generation strategy becauase the insert must actually happen before we can know the identifier value. Because Hibernate relies on this identifier value to uniquely reference entities within a persisten!
 ce context it must then issue the insert immediately when the users requests the entitiy be associated with the session (like via save() e.g.) regardless of current transactional semantics."
 msgstr ""
 
 #. Tag: para
-#: portability.xml:125
 #, no-c-format
-msgid "Starting with version 3.2.3, Hibernate comes with a set of <ulink url=\"http://in.relation.to/2082.lace\">enhanced</ulink> identifier generators targetting portability in a much different way. <note> <para> There are specifically 2 bundled <emphasis>enhanced</emphasis>generators: <itemizedlist> <listitem> <para> <classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname> </para> </listitem> <listitem> <para> <classname>org.hibernate.id.enhanced.TableGenerator</classname> </para> </listitem> </itemizedlist> </para> </note> The idea behind these generators is to port the actual semantics of the identifer value generation to the different databases. For example, the <classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname> mimics the behavior of a sequence on databases which do not support sequences by using a table."
+msgid "Hibernate was changed slightly once the implication of this was better understood so that the insert is delayed in cases where that is feasible."
 msgstr ""
 
+#. Tag: note
+#, no-c-format
+msgid "The underlying issue is that the actual semanctics of the application itself changes in these cases."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "Starting with version 3.2.3, Hibernate comes with a set of <ulink url=\"http://in.relation.to/2082.lace\">enhanced</ulink> identifier generators targetting portability in a much different way."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "There are specifically 2 bundled <emphasis>enhanced</emphasis>generators:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname>"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "<classname>org.hibernate.id.enhanced.TableGenerator</classname>"
+msgstr ""
+
+#. Tag: note
+#, no-c-format
+msgid "The idea behind these generators is to port the actual semantics of the identifer value generation to the different databases. For example, the <classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname> mimics the behavior of a sequence on databases which do not support sequences by using a table."
+msgstr ""
+
 #. Tag: title
-#: portability.xml:154
 #, no-c-format
 msgid "Database functions"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:157
 #, no-c-format
 msgid "This is an area in Hibernate in need of improvement. In terms of portability concerns, this function handling currently works pretty well from HQL; however, it is quite lacking in all other aspects."
 msgstr ""
 
 #. Tag: para
-#: portability.xml:164
 #, no-c-format
 msgid "SQL functions can be referenced in many ways by users. However, not all databases support the same set of functions. Hibernate, provides a means of mapping a <emphasis>logical</emphasis> function name to a a delegate which knows how to render that particular function, perhaps even using a totally different physical function call."
 msgstr ""
 
 #. Tag: para
-#: portability.xml:170
 #, no-c-format
 msgid "Technically this function registration is handled through the <classname>org.hibernate.dialect.function.SQLFunctionRegistry</classname> class which is intended to allow users to provide custom function definitions without having to provide a custom dialect. This specific behavior is not fully completed as of yet."
 msgstr ""
 
 #. Tag: para
-#: portability.xml:177
 #, no-c-format
 msgid "It is sort of implemented such that users can programatically register functions with the <classname>org.hibernate.cfg.Configuration</classname> and those functions will be recognized for HQL."
 msgstr ""
 
 #. Tag: title
-#: portability.xml:187
 #, no-c-format
 msgid "Type mappings"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:189
 #, no-c-format
 msgid "This section scheduled for completion at a later date..."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/preface.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/preface.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/preface.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,99 +1,83 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: preface.xml:29
 #, no-c-format
 msgid "Preface"
 msgstr ""
 
 #. Tag: para
-#: preface.xml:31
 #, no-c-format
 msgid "Working with object-oriented software and a relational database can be cumbersome and time consuming in today's enterprise environments. Hibernate is an Object/Relational Mapping tool for Java environments. The term Object/Relational Mapping (ORM) refers to the technique of mapping a data representation from an object model to a relational data model with a SQL-based schema."
 msgstr ""
 
 #. Tag: para
-#: preface.xml:39
 #, no-c-format
 msgid "Hibernate not only takes care of the mapping from Java classes to database tables (and from Java data types to SQL data types), but also provides data query and retrieval facilities. It can also significantly reduce development time otherwise spent with manual data handling in SQL and JDBC."
 msgstr ""
 
 #. Tag: para
-#: preface.xml:46
 #, no-c-format
 msgid "Hibernate's goal is to relieve the developer from 95 percent of common data persistence related programming tasks. Hibernate may not be the best solution for data-centric applications that only use stored-procedures to implement the business logic in the database, it is most useful with object-oriented domain models and business logic in the Java-based middle-tier. However, Hibernate can certainly help you to remove or encapsulate vendor-specific SQL code and will help with the common task of result set translation from a tabular representation to a graph of objects."
 msgstr ""
 
 #. Tag: para
-#: preface.xml:56
 #, no-c-format
 msgid "If you are new to Hibernate and Object/Relational Mapping or even Java, please follow these steps:"
 msgstr ""
 
 #. Tag: para
-#: preface.xml:63
 #, no-c-format
-msgid "Read <xref linkend=\"tutorial\"/> for a tutorial with step-by-step instructions. The source code for the tutorial is included in the distribution in the <literal>doc/reference/tutorial/</literal> directory."
+msgid "Read <xref linkend=\"tutorial\" /> for a tutorial with step-by-step instructions. The source code for the tutorial is included in the distribution in the <literal>doc/reference/tutorial/</literal> directory."
 msgstr ""
 
 #. Tag: para
-#: preface.xml:71
 #, no-c-format
-msgid "Read <xref linkend=\"architecture\"/> to understand the environments where Hibernate can be used."
+msgid "Read <xref linkend=\"architecture\" /> to understand the environments where Hibernate can be used."
 msgstr ""
 
 #. Tag: para
-#: preface.xml:77
 #, no-c-format
 msgid "View the <literal>eg/</literal> directory in the Hibernate distribution. It contains a simple standalone application. Copy your JDBC driver to the <literal>lib/</literal> directory and edit <literal>etc/hibernate.properties</literal>, specifying correct values for your database. From a command prompt in the distribution directory, type <literal>ant eg</literal> (using Ant), or under Windows, type <literal>build eg</literal>."
 msgstr ""
 
 #. Tag: para
-#: preface.xml:88
 #, no-c-format
-msgid "Use this reference documentation as your primary source of information. Consider reading <biblioref linkend=\"biblio-JPwH\"></biblioref> if you need more help with application design, or if you prefer a step-by-step tutorial. Also visit <ulink url=\"http://caveatemptor.hibernate.org\"></ulink> and download the example application from <biblioref linkend=\"biblio-JPwH\"></biblioref>."
+msgid "Use this reference documentation as your primary source of information. Consider reading <biblioref linkend=\"biblio-JPwH\"></biblioref> if you need more help with application design, or if you prefer a step-by-step tutorial. Also visit <ulink url=\"http://caveatemptor.hibernate.org\" /> and download the example application from <biblioref linkend=\"biblio-JPwH\"></biblioref>."
 msgstr ""
 
 #. Tag: para
-#: preface.xml:98
 #, no-c-format
 msgid "FAQs are answered on the Hibernate website."
 msgstr ""
 
 #. Tag: para
-#: preface.xml:103
 #, no-c-format
 msgid "Links to third party demos, examples, and tutorials are maintained on the Hibernate website."
 msgstr ""
 
 #. Tag: para
-#: preface.xml:109
 #, no-c-format
 msgid "The Community Area on the Hibernate website is a good resource for design patterns and various integration solutions (Tomcat, JBoss AS, Struts, EJB, etc.)."
 msgstr ""
 
 #. Tag: para
-#: preface.xml:117
 #, no-c-format
 msgid "If you have questions, use the user forum linked on the Hibernate website. We also provide a JIRA issue tracking system for bug reports and feature requests. If you are interested in the development of Hibernate, join the developer mailing list. If you are interested in translating this documentation into your language, contact us on the developer mailing list."
 msgstr ""
 
 #. Tag: para
-#: preface.xml:125
 #, no-c-format
 msgid "Commercial development support, production support, and training for Hibernate is available through JBoss Inc. (see http://www.hibernate.org/SupportTraining/). Hibernate is a Professional Open Source project and a critical component of the JBoss Enterprise Middleware System (JEMS) suite of products."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/query_criteria.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/query_criteria.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/query_criteria.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,624 +1,244 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: query_criteria.xml:29
 #, no-c-format
 msgid "Criteria Queries"
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:31
 #, no-c-format
 msgid "Hibernate features an intuitive, extensible criteria query API."
 msgstr ""
 
 #. Tag: title
-#: query_criteria.xml:36
 #, no-c-format
 msgid "Creating a <literal>Criteria</literal> instance"
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:38
 #, no-c-format
 msgid "The interface <literal>org.hibernate.Criteria</literal> represents a query against a particular persistent class. The <literal>Session</literal> is a factory for <literal>Criteria</literal> instances."
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:44
-#, no-c-format
-msgid ""
-      "<![CDATA[Criteria crit = sess.createCriteria(Cat.class);\n"
-      "crit.setMaxResults(50);\n"
-      "List cats = crit.list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:49
 #, no-c-format
 msgid "Narrowing the result set"
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:51
 #, no-c-format
 msgid "An individual query criterion is an instance of the interface <literal>org.hibernate.criterion.Criterion</literal>. The class <literal>org.hibernate.criterion.Restrictions</literal> defines factory methods for obtaining certain built-in <literal>Criterion</literal> types."
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:59
-#, no-c-format
-msgid ""
-      "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-      "    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-      "    .add( Restrictions.between(\"weight\", minWeight, maxWeight) )\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:61
 #, no-c-format
 msgid "Restrictions can be grouped logically."
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:65
-#, no-c-format
-msgid ""
-      "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-      "    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-      "    .add( Restrictions.or(\n"
-      "        Restrictions.eq( \"age\", new Integer(0) ),\n"
-      "        Restrictions.isNull(\"age\")\n"
-      "    ) )\n"
-      "    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:67
-#, no-c-format
-msgid ""
-      "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-      "    .add( Restrictions.in( \"name\", new String[] { \"Fritz\", \"Izi\", \"Pk\" } ) )\n"
-      "    .add( Restrictions.disjunction()\n"
-      "        .add( Restrictions.isNull(\"age\") )\n"
-      "        .add( Restrictions.eq(\"age\", new Integer(0) ) )\n"
-      "        .add( Restrictions.eq(\"age\", new Integer(1) ) )\n"
-      "        .add( Restrictions.eq(\"age\", new Integer(2) ) )\n"
-      "    ) )\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:69
 #, no-c-format
 msgid "There are a range of built-in criterion types (<literal>Restrictions</literal> subclasses). One of the most useful allows you to specify SQL directly."
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:74
-#, no-c-format
-msgid ""
-      "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-      "    .add( Restrictions.sqlRestriction(\"lower({alias}.name) like lower(?)\", \"Fritz%\", Hibernate.STRING) )\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:76
 #, no-c-format
 msgid "The <literal>{alias}</literal> placeholder with be replaced by the row alias of the queried entity."
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:81
 #, no-c-format
 msgid "You can also obtain a criterion from a <literal>Property</literal> instance. You can create a <literal>Property</literal> by calling <literal>Property.forName()</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:87
-#, no-c-format
-msgid ""
-      "<![CDATA[\n"
-      "Property age = Property.forName(\"age\");\n"
-      "List cats = sess.createCriteria(Cat.class)\n"
-      "    .add( Restrictions.disjunction()\n"
-      "        .add( age.isNull() )\n"
-      "        .add( age.eq( new Integer(0) ) )\n"
-      "        .add( age.eq( new Integer(1) ) )\n"
-      "        .add( age.eq( new Integer(2) ) )\n"
-      "    ) )\n"
-      "    .add( Property.forName(\"name\").in( new String[] { \"Fritz\", \"Izi\", \"Pk\" } ) )\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:92
 #, no-c-format
 msgid "Ordering the results"
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:94
 #, no-c-format
 msgid "You can order the results using <literal>org.hibernate.criterion.Order</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:98
+#. Tag: title
 #, no-c-format
-msgid ""
-      "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-      "    .add( Restrictions.like(\"name\", \"F%\")\n"
-      "    .addOrder( Order.asc(\"name\") )\n"
-      "    .addOrder( Order.desc(\"age\") )\n"
-      "    .setMaxResults(50)\n"
-      "    .list();]]>"
+msgid "Associations"
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:100
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-      "    .add( Property.forName(\"name\").like(\"F%\") )\n"
-      "    .addOrder( Property.forName(\"name\").asc() )\n"
-      "    .addOrder( Property.forName(\"age\").desc() )\n"
-      "    .setMaxResults(50)\n"
-      "    .list();]]>"
+msgid "By navigating associations using <literal>createCriteria()</literal> you can specify constraints upon related entities:"
 msgstr ""
 
-#. Tag: title
-#: query_criteria.xml:105
+#. Tag: para
 #, no-c-format
-msgid "Associations"
+msgid "The second <literal>createCriteria()</literal> returns a new instance of <literal>Criteria</literal> that refers to the elements of the <literal>kittens</literal> collection."
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:107
 #, no-c-format
-msgid "By navigating associations using <literal>createCriteria()</literal> you can specify constraints upon related entities:"
+msgid "There is also an alternate form that is useful in certain circumstances:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:112
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-      "    .add( Restrictions.like(\"name\", \"F%\") )\n"
-      "    .createCriteria(\"kittens\")\n"
-      "        .add( Restrictions.like(\"name\", \"F%\") )\n"
-      "    .list();]]>"
+msgid "(<literal>createAlias()</literal> does not create a new instance of <literal>Criteria</literal>.)"
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:114
 #, no-c-format
-msgid "The second <literal>createCriteria()</literal> returns a new instance of <literal>Criteria</literal> that refers to the elements of the <literal>kittens</literal> collection."
+msgid "The kittens collections held by the <literal>Cat</literal> instances returned by the previous two queries are <emphasis>not</emphasis> pre-filtered by the criteria. If you want to retrieve just the kittens that match the criteria, you must use a <literal>ResultTransformer</literal>."
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:120
 #, no-c-format
-msgid "There is also an alternate form that is useful in certain circumstances:"
+msgid "Additionally you may manipulate the result set using a left outer join:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:124
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-      "    .createAlias(\"kittens\", \"kt\")\n"
-      "    .createAlias(\"mate\", \"mt\")\n"
-      "    .add( Restrictions.eqProperty(\"kt.name\", \"mt.name\") )\n"
-      "    .list();]]>"
+msgid "This will return all of the <literal>Cat</literal>s with a mate whose name starts with \"good\" ordered by their mate's age, and all cats who do not have a mate. This is useful when there is a need to order or limit in the database prior to returning complex/large result sets, and removes many instances where multiple queries would have to be performed and the results unioned by java in memory."
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:126
 #, no-c-format
-msgid "(<literal>createAlias()</literal> does not create a new instance of <literal>Criteria</literal>.)"
+msgid "Without this feature, first all of the cats without a mate would need to be loaded in one query."
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:131
 #, no-c-format
-msgid "The kittens collections held by the <literal>Cat</literal> instances returned by the previous two queries are <emphasis>not</emphasis> pre-filtered by the criteria. If you want to retrieve just the kittens that match the criteria, you must use a <literal>ResultTransformer</literal>."
+msgid "A second query would need to retreive the cats with mates who's name started with \"good\" sorted by the mates age."
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:138
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-      "    .createCriteria(\"kittens\", \"kt\")\n"
-      "        .add( Restrictions.eq(\"name\", \"F%\") )\n"
-      "    .setResultTransformer(Criteria.ALIAS_TO_ENTITY_MAP)\n"
-      "    .list();\n"
-      "Iterator iter = cats.iterator();\n"
-      "while ( iter.hasNext() ) {\n"
-      "    Map map = (Map) iter.next();\n"
-      "    Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);\n"
-      "    Cat kitten = (Cat) map.get(\"kt\");\n"
-      "}]]>"
+msgid "Thirdly, in memory; the lists would need to be joined manually."
 msgstr ""
 
 #. Tag: title
-#: query_criteria.xml:143
 #, no-c-format
 msgid "Dynamic association fetching"
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:145
 #, no-c-format
 msgid "You can specify association fetching semantics at runtime using <literal>setFetchMode()</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:150
-#, no-c-format
-msgid ""
-      "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-      "    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-      "    .setFetchMode(\"mate\", FetchMode.EAGER)\n"
-      "    .setFetchMode(\"kittens\", FetchMode.EAGER)\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:152
 #, no-c-format
-msgid "This query will fetch both <literal>mate</literal> and <literal>kittens</literal> by outer join. See <xref linkend=\"performance-fetching\"/> for more information."
+msgid "This query will fetch both <literal>mate</literal> and <literal>kittens</literal> by outer join. See <xref linkend=\"performance-fetching\" /> for more information."
 msgstr ""
 
 #. Tag: title
-#: query_criteria.xml:160
 #, no-c-format
 msgid "Example queries"
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:162
 #, no-c-format
 msgid "The class <literal>org.hibernate.criterion.Example</literal> allows you to construct a query criterion from a given instance."
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:167
-#, no-c-format
-msgid ""
-      "<![CDATA[Cat cat = new Cat();\n"
-      "cat.setSex('F');\n"
-      "cat.setColor(Color.BLACK);\n"
-      "List results = session.createCriteria(Cat.class)\n"
-      "    .add( Example.create(cat) )\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:169
 #, no-c-format
 msgid "Version properties, identifiers and associations are ignored. By default, null valued properties are excluded."
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:174
 #, no-c-format
 msgid "You can adjust how the <literal>Example</literal> is applied."
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:178
-#, no-c-format
-msgid ""
-      "<![CDATA[Example example = Example.create(cat)\n"
-      "    .excludeZeroes()           //exclude zero valued properties\n"
-      "    .excludeProperty(\"color\")  //exclude the property named \"color\"\n"
-      "    .ignoreCase()              //perform case insensitive string comparisons\n"
-      "    .enableLike();             //use like for string comparisons\n"
-      "List results = session.createCriteria(Cat.class)\n"
-      "    .add(example)\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:180
 #, no-c-format
 msgid "You can even use examples to place criteria upon associated objects."
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:184
-#, no-c-format
-msgid ""
-      "<![CDATA[List results = session.createCriteria(Cat.class)\n"
-      "    .add( Example.create(cat) )\n"
-      "    .createCriteria(\"mate\")\n"
-      "        .add( Example.create( cat.getMate() ) )\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:189
 #, no-c-format
 msgid "Projections, aggregation and grouping"
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:190
 #, no-c-format
 msgid "The class <literal>org.hibernate.criterion.Projections</literal> is a factory for <literal>Projection</literal> instances. You can apply a projection to a query by calling <literal>setProjection()</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:196
-#, no-c-format
-msgid ""
-      "<![CDATA[List results = session.createCriteria(Cat.class)\n"
-      "    .setProjection( Projections.rowCount() )\n"
-      "    .add( Restrictions.eq(\"color\", Color.BLACK) )\n"
-      "    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:198
-#, no-c-format
-msgid ""
-      "<![CDATA[List results = session.createCriteria(Cat.class)\n"
-      "    .setProjection( Projections.projectionList()\n"
-      "        .add( Projections.rowCount() )\n"
-      "        .add( Projections.avg(\"weight\") )\n"
-      "        .add( Projections.max(\"weight\") )\n"
-      "        .add( Projections.groupProperty(\"color\") )\n"
-      "    )\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:200
 #, no-c-format
 msgid "There is no explicit \"group by\" necessary in a criteria query. Certain projection types are defined to be <emphasis>grouping projections</emphasis>, which also appear in the SQL <literal>group by</literal> clause."
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:206
 #, no-c-format
 msgid "An alias can be assigned to a projection so that the projected value can be referred to in restrictions or orderings. Here are two different ways to do this:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:212
-#, no-c-format
-msgid ""
-      "<![CDATA[List results = session.createCriteria(Cat.class)\n"
-      "    .setProjection( Projections.alias( Projections.groupProperty(\"color\"), \"colr\" ) )\n"
-      "    .addOrder( Order.asc(\"colr\") )\n"
-      "    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:214
-#, no-c-format
-msgid ""
-      "<![CDATA[List results = session.createCriteria(Cat.class)\n"
-      "    .setProjection( Projections.groupProperty(\"color\").as(\"colr\") )\n"
-      "    .addOrder( Order.asc(\"colr\") )\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:216
 #, no-c-format
 msgid "The <literal>alias()</literal> and <literal>as()</literal> methods simply wrap a projection instance in another, aliased, instance of <literal>Projection</literal>. As a shortcut, you can assign an alias when you add the projection to a projection list:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:223
-#, no-c-format
-msgid ""
-      "<![CDATA[List results = session.createCriteria(Cat.class)\n"
-      "    .setProjection( Projections.projectionList()\n"
-      "        .add( Projections.rowCount(), \"catCountByColor\" )\n"
-      "        .add( Projections.avg(\"weight\"), \"avgWeight\" )\n"
-      "        .add( Projections.max(\"weight\"), \"maxWeight\" )\n"
-      "        .add( Projections.groupProperty(\"color\"), \"color\" )\n"
-      "    )\n"
-      "    .addOrder( Order.desc(\"catCountByColor\") )\n"
-      "    .addOrder( Order.desc(\"avgWeight\") )\n"
-      "    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:225
-#, no-c-format
-msgid ""
-      "<![CDATA[List results = session.createCriteria(Domestic.class, \"cat\")\n"
-      "    .createAlias(\"kittens\", \"kit\")\n"
-      "    .setProjection( Projections.projectionList()\n"
-      "        .add( Projections.property(\"cat.name\"), \"catName\" )\n"
-      "        .add( Projections.property(\"kit.name\"), \"kitName\" )\n"
-      "    )\n"
-      "    .addOrder( Order.asc(\"catName\") )\n"
-      "    .addOrder( Order.asc(\"kitName\") )\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:227
 #, no-c-format
 msgid "You can also use <literal>Property.forName()</literal> to express projections:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:231
-#, no-c-format
-msgid ""
-      "<![CDATA[List results = session.createCriteria(Cat.class)\n"
-      "    .setProjection( Property.forName(\"name\") )\n"
-      "    .add( Property.forName(\"color\").eq(Color.BLACK) )\n"
-      "    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:233
-#, no-c-format
-msgid ""
-      "<![CDATA[List results = session.createCriteria(Cat.class)\n"
-      "    .setProjection( Projections.projectionList()\n"
-      "        .add( Projections.rowCount().as(\"catCountByColor\") )\n"
-      "        .add( Property.forName(\"weight\").avg().as(\"avgWeight\") )\n"
-      "        .add( Property.forName(\"weight\").max().as(\"maxWeight\") )\n"
-      "        .add( Property.forName(\"color\").group().as(\"color\" )\n"
-      "    )\n"
-      "    .addOrder( Order.desc(\"catCountByColor\") )\n"
-      "    .addOrder( Order.desc(\"avgWeight\") )\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:238
 #, no-c-format
 msgid "Detached queries and subqueries"
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:239
 #, no-c-format
 msgid "The <literal>DetachedCriteria</literal> class allows you to create a query outside the scope of a session and then execute it using an arbitrary <literal>Session</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:244
-#, no-c-format
-msgid ""
-      "<![CDATA[DetachedCriteria query = DetachedCriteria.forClass(Cat.class)\n"
-      "    .add( Property.forName(\"sex\").eq('F') );\n"
-      "    \n"
-      "Session session = ....;\n"
-      "Transaction txn = session.beginTransaction();\n"
-      "List results = query.getExecutableCriteria(session).setMaxResults(100).list();\n"
-      "txn.commit();\n"
-      "session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:246
 #, no-c-format
 msgid "A <literal>DetachedCriteria</literal> can also be used to express a subquery. Criterion instances involving subqueries can be obtained via <literal>Subqueries</literal> or <literal>Property</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:252
-#, no-c-format
-msgid ""
-      "<![CDATA[DetachedCriteria avgWeight = DetachedCriteria.forClass(Cat.class)\n"
-      "    .setProjection( Property.forName(\"weight\").avg() );\n"
-      "session.createCriteria(Cat.class)\n"
-      "    .add( Property.forName(\"weight\").gt(avgWeight) )\n"
-      "    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:254
-#, no-c-format
-msgid ""
-      "<![CDATA[DetachedCriteria weights = DetachedCriteria.forClass(Cat.class)\n"
-      "    .setProjection( Property.forName(\"weight\") );\n"
-      "session.createCriteria(Cat.class)\n"
-      "    .add( Subqueries.geAll(\"weight\", weights) )\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:256
 #, no-c-format
 msgid "Correlated subqueries are also possible:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:260
-#, no-c-format
-msgid ""
-      "<![CDATA[DetachedCriteria avgWeightForSex = DetachedCriteria.forClass(Cat.class, \"cat2\")\n"
-      "    .setProjection( Property.forName(\"weight\").avg() )\n"
-      "    .add( Property.forName(\"cat2.sex\").eqProperty(\"cat.sex\") );\n"
-      "session.createCriteria(Cat.class, \"cat\")\n"
-      "    .add( Property.forName(\"weight\").gt(avgWeightForSex) )\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:269
 #, no-c-format
 msgid "Queries by natural identifier"
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:271
 #, no-c-format
 msgid "For most queries, including criteria queries, the query cache is not efficient because query cache invalidation occurs too frequently. However, there is a special kind of query where you can optimize the cache invalidation algorithm: lookups by a constant natural key. In some applications, this kind of query occurs frequently. The criteria API provides special provision for this use case."
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:279
 #, no-c-format
 msgid "First, map the natural key of your entity using <literal>&lt;natural-id&gt;</literal> and enable use of the second-level cache."
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:284
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"User\">\n"
-      "    <cache usage=\"read-write\"/>\n"
-      "    <id name=\"id\">\n"
-      "        <generator class=\"increment\"/>\n"
-      "    </id>\n"
-      "    <natural-id>\n"
-      "        <property name=\"name\"/>\n"
-      "        <property name=\"org\"/>\n"
-      "    </natural-id>\n"
-      "    <property name=\"password\"/>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:286
 #, no-c-format
 msgid "This functionality is not intended for use with entities with <emphasis>mutable</emphasis> natural keys."
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:291
 #, no-c-format
 msgid "Once you have enabled the Hibernate query cache, the <literal>Restrictions.naturalId()</literal> allows you to make use of the more efficient cache algorithm."
 msgstr ""
 
-#. Tag: programlisting
-#: query_criteria.xml:297
-#, no-c-format
-msgid ""
-      "<![CDATA[session.createCriteria(User.class)\n"
-      "    .add( Restrictions.naturalId()\n"
-      "        .set(\"name\", \"gavin\")\n"
-      "        .set(\"org\", \"hb\") \n"
-      "    ).setCacheable(true)\n"
-      "    .uniqueResult();]]>"
-msgstr ""
-

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/query_hql.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/query_hql.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/query_hql.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,1798 +1,793 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: query_hql.xml:29
 #, no-c-format
 msgid "HQL: The Hibernate Query Language"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:31
 #, no-c-format
 msgid "Hibernate uses a powerful query language (HQL) that is similar in appearance to SQL. Compared with SQL, however, HQL is fully object-oriented and understands notions like inheritance, polymorphism and association."
 msgstr ""
 
 #. Tag: title
-#: query_hql.xml:38
 #, no-c-format
 msgid "Case Sensitivity"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:40
 #, no-c-format
 msgid "With the exception of names of Java classes and properties, queries are case-insensitive. So <literal>SeLeCT</literal> is the same as <literal>sELEct</literal> is the same as <literal>SELECT</literal>, but <literal>org.hibernate.eg.FOO</literal> is not <literal>org.hibernate.eg.Foo</literal>, and <literal>foo.barSet</literal> is not <literal>foo.BARSET</literal>."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:51
 #, no-c-format
 msgid "This manual uses lowercase HQL keywords. Some users find queries with uppercase keywords more readable, but this convention is unsuitable for queries embedded in Java code."
 msgstr ""
 
 #. Tag: title
-#: query_hql.xml:59
 #, no-c-format
 msgid "The from clause"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:61
 #, no-c-format
 msgid "The simplest possible Hibernate query is of the form:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:65
-#, no-c-format
-msgid "<![CDATA[from eg.Cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:67
 #, no-c-format
 msgid "This returns all instances of the class <literal>eg.Cat</literal>. You do not usually need to qualify the class name, since <literal>auto-import</literal> is the default. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:73
-#, no-c-format
-msgid "<![CDATA[from Cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:75
 #, no-c-format
 msgid "In order to refer to the <literal>Cat</literal> in other parts of the query, you will need to assign an <emphasis>alias</emphasis>. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:81 query_hql.xml:396
-#, no-c-format
-msgid "<![CDATA[from Cat as cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:83
 #, no-c-format
 msgid "This query assigns the alias <literal>cat</literal> to <literal>Cat</literal> instances, so you can use that alias later in the query. The <literal>as</literal> keyword is optional. You could also write:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:89
-#, no-c-format
-msgid "<![CDATA[from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:91
 #, no-c-format
 msgid "Multiple classes can appear, resulting in a cartesian product or \"cross\" join."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:95
-#, no-c-format
-msgid "<![CDATA[from Formula, Parameter]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:96
-#, no-c-format
-msgid "<![CDATA[from Formula as form, Parameter as param]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:98
 #, no-c-format
 msgid "It is good practice to name query aliases using an initial lowercase as this is consistent with Java naming standards for local variables (e.g. <literal>domesticCat</literal>)."
 msgstr ""
 
 #. Tag: title
-#: query_hql.xml:107
 #, no-c-format
 msgid "Associations and joins"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:109
 #, no-c-format
 msgid "You can also assign aliases to associated entities or to elements of a collection of values using a <literal>join</literal>. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:114
-#, no-c-format
-msgid ""
-      "<![CDATA[from Cat as cat\n"
-      "    inner join cat.mate as mate\n"
-      "    left outer join cat.kittens as kitten]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:116
-#, no-c-format
-msgid "<![CDATA[from Cat as cat left join cat.mate.kittens as kittens]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:118
-#, no-c-format
-msgid "<![CDATA[from Formula form full join form.parameter param]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:120
 #, no-c-format
 msgid "The supported join types are borrowed from ANSI SQL:"
 msgstr ""
 
-#. Tag: literal
-#: query_hql.xml:127
+#. Tag: para
 #, no-c-format
-msgid "inner join"
+msgid "<literal>inner join</literal>"
 msgstr ""
 
-#. Tag: literal
-#: query_hql.xml:132
+#. Tag: para
 #, no-c-format
-msgid "left outer join"
+msgid "<literal>left outer join</literal>"
 msgstr ""
 
-#. Tag: literal
-#: query_hql.xml:137
+#. Tag: para
 #, no-c-format
-msgid "right outer join"
+msgid "<literal>right outer join</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:141
 #, no-c-format
 msgid "<literal>full join</literal> (not usually useful)"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:147
 #, no-c-format
 msgid "The <literal>inner join</literal>, <literal>left outer join</literal> and <literal>right outer join</literal> constructs may be abbreviated."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:152
-#, no-c-format
-msgid ""
-      "<![CDATA[from Cat as cat\n"
-      "    join cat.mate as mate\n"
-      "    left join cat.kittens as kitten]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:154
 #, no-c-format
 msgid "You may supply extra join conditions using the HQL <literal>with</literal> keyword."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:159
-#, no-c-format
-msgid ""
-      "<![CDATA[from Cat as cat\n"
-      "    left join cat.kittens as kitten\n"
-      "        with kitten.bodyWeight > 10.0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:161
 #, no-c-format
-msgid "A \"fetch\" join allows associations or collections of values to be initialized along with their parent objects using a single select. This is particularly useful in the case of a collection. It effectively overrides the outer join and lazy declarations of the mapping file for associations and collections. See <xref linkend=\"performance-fetching\"/> for more information."
+msgid "A \"fetch\" join allows associations or collections of values to be initialized along with their parent objects using a single select. This is particularly useful in the case of a collection. It effectively overrides the outer join and lazy declarations of the mapping file for associations and collections. See <xref linkend=\"performance-fetching\" /> for more information."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:169
-#, no-c-format
-msgid ""
-      "<![CDATA[from Cat as cat\n"
-      "    inner join fetch cat.mate\n"
-      "    left join fetch cat.kittens]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:171
 #, no-c-format
 msgid "A fetch join does not usually need to assign an alias, because the associated objects should not be used in the <literal>where</literal> clause (or any other clause). The associated objects are also not returned directly in the query results. Instead, they may be accessed via the parent object. The only reason you might need an alias is if you are recursively join fetching a further collection:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:179
-#, no-c-format
-msgid ""
-      "<![CDATA[from Cat as cat\n"
-      "    inner join fetch cat.mate\n"
-      "    left join fetch cat.kittens child\n"
-      "    left join fetch child.kittens]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:181
 #, no-c-format
 msgid "The <literal>fetch</literal> construct cannot be used in queries called using <literal>iterate()</literal> (though <literal>scroll()</literal> can be used). <literal>Fetch</literal> should be used together with <literal>setMaxResults()</literal> or <literal>setFirstResult()</literal>, as these operations are based on the result rows which usually contain duplicates for eager collection fetching, hence, the number of rows is not what you would expect. <literal>Fetch</literal> should also not be used together with impromptu <literal>with</literal> condition. It is possible to create a cartesian product by join fetching more than one collection in a query, so take care in this case. Join fetching multiple collection roles can produce unexpected results for bag mappings, so user discretion is advised when formulating queries in this case. Finally, note that <literal>full join fetch</literal> and <literal>right join fetch</literal> are not meaningful."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:196
 #, no-c-format
 msgid "If you are using property-level lazy fetching (with bytecode instrumentation), it is possible to force Hibernate to fetch the lazy properties in the first query immediately using <literal>fetch all properties</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:202
-#, no-c-format
-msgid "<![CDATA[from Document fetch all properties order by name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:203
-#, no-c-format
-msgid "<![CDATA[from Document doc fetch all properties where lower(doc.name) like '%cats%']]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:208
 #, no-c-format
 msgid "Forms of join syntax"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:210
 #, no-c-format
 msgid "HQL supports two forms of association joining: <literal>implicit</literal> and <literal>explicit</literal>."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:214
 #, no-c-format
 msgid "The queries shown in the previous section all use the <literal>explicit</literal> form, that is, where the join keyword is explicitly used in the from clause. This is the recommended form."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:219
 #, no-c-format
 msgid "The <literal>implicit</literal> form does not use the join keyword. Instead, the associations are \"dereferenced\" using dot-notation. <literal>implicit</literal> joins can appear in any of the HQL clauses. <literal>implicit</literal> join result in inner joins in the resulting SQL statement."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:226
-#, no-c-format
-msgid "<![CDATA[from Cat as cat where cat.mate.name like '%s%']]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:230
 #, no-c-format
 msgid "Referring to identifier property"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:232
 #, no-c-format
 msgid "There are 2 ways to refer to an entity's identifier property:"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:237
 #, no-c-format
 msgid "The special property (lowercase) <literal>id</literal> may be used to reference the identifier property of an entity <emphasis>provided that the entity does not define a non-identifier property named id</emphasis>."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:244
 #, no-c-format
 msgid "If the entity defines a named identifier property, you can use that property name."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:250
 #, no-c-format
 msgid "References to composite identifier properties follow the same naming rules. If the entity has a non-identifier property named id, the composite identifier property can only be referenced by its defined named. Otherwise, the special <literal>id</literal> property can be used to reference the identifier property."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:258
 #, no-c-format
 msgid "Please note that, starting in version 3.2.2, this has changed significantly. In previous versions, <literal>id</literal> <emphasis>always</emphasis> referred to the identifier property regardless of its actual name. A ramification of that decision was that non-identifier properties named <literal>id</literal> could never be referenced in Hibernate queries."
 msgstr ""
 
 #. Tag: title
-#: query_hql.xml:269
 #, no-c-format
 msgid "The select clause"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:271
 #, no-c-format
 msgid "The <literal>select</literal> clause picks which objects and properties to return in the query result set. Consider the following:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:276
-#, no-c-format
-msgid ""
-      "<![CDATA[select mate\n"
-      "from Cat as cat\n"
-      "    inner join cat.mate as mate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:278
 #, no-c-format
 msgid "The query will select <literal>mate</literal>s of other <literal>Cat</literal>s. You can express this query more compactly as:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:283
-#, no-c-format
-msgid "<![CDATA[select cat.mate from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:285
 #, no-c-format
 msgid "Queries can return properties of any value type including properties of component type:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:289
-#, no-c-format
-msgid ""
-      "<![CDATA[select cat.name from DomesticCat cat\n"
-      "where cat.name like 'fri%']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:291
-#, no-c-format
-msgid "<![CDATA[select cust.name.firstName from Customer as cust]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:293
 #, no-c-format
 msgid "Queries can return multiple objects and/or properties as an array of type <literal>Object[]</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:298
-#, no-c-format
-msgid ""
-      "<![CDATA[select mother, offspr, mate.name\n"
-      "from DomesticCat as mother\n"
-      "    inner join mother.mate as mate\n"
-      "    left outer join mother.kittens as offspr]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:300
 #, no-c-format
 msgid "Or as a <literal>List</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:304
-#, no-c-format
-msgid ""
-      "<![CDATA[select new list(mother, offspr, mate.name)\n"
-      "from DomesticCat as mother\n"
-      "    inner join mother.mate as mate\n"
-      "    left outer join mother.kittens as offspr]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:306
 #, no-c-format
 msgid "Or - assuming that the class <literal>Family</literal> has an appropriate constructor - as an actual typesafe Java object:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:310
-#, no-c-format
-msgid ""
-      "<![CDATA[select new Family(mother, mate, offspr)\n"
-      "from DomesticCat as mother\n"
-      "    join mother.mate as mate\n"
-      "    left join mother.kittens as offspr]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:313
 #, no-c-format
 msgid "You can assign aliases to selected expressions using <literal>as</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:317
-#, no-c-format
-msgid ""
-      "<![CDATA[select max(bodyWeight) as max, min(bodyWeight) as min, count(*) as n\n"
-      "from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:319
 #, no-c-format
 msgid "This is most useful when used together with <literal>select new map</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:323
-#, no-c-format
-msgid ""
-      "<![CDATA[select new map( max(bodyWeight) as max, min(bodyWeight) as min, count(*) as n )\n"
-      "from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:325
 #, no-c-format
 msgid "This query returns a <literal>Map</literal> from aliases to selected values."
 msgstr ""
 
 #. Tag: title
-#: query_hql.xml:332
 #, no-c-format
 msgid "Aggregate functions"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:334
 #, no-c-format
 msgid "HQL queries can even return the results of aggregate functions on properties:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:338
-#, no-c-format
-msgid ""
-      "<![CDATA[select avg(cat.weight), sum(cat.weight), max(cat.weight), count(cat)\n"
-      "from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:349
 #, no-c-format
 msgid "The supported aggregate functions are:"
 msgstr ""
 
-#. Tag: literal
-#: query_hql.xml:356
+#. Tag: para
 #, no-c-format
-msgid "avg(...), sum(...), min(...), max(...)"
+msgid "<literal>avg(...), sum(...), min(...), max(...)</literal>"
 msgstr ""
 
-#. Tag: literal
-#: query_hql.xml:361
+#. Tag: para
 #, no-c-format
-msgid "count(*)"
+msgid "<literal>count(*)</literal>"
 msgstr ""
 
-#. Tag: literal
-#: query_hql.xml:366
+#. Tag: para
 #, no-c-format
-msgid "count(...), count(distinct ...), count(all...)"
+msgid "<literal>count(...), count(distinct ...), count(all...)</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:371
 #, no-c-format
 msgid "You can use arithmetic operators, concatenation, and recognized SQL functions in the select clause:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:376
-#, no-c-format
-msgid ""
-      "<![CDATA[select cat.weight + sum(kitten.weight)\n"
-      "from Cat cat\n"
-      "    join cat.kittens kitten\n"
-      "group by cat.id, cat.weight]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:378
-#, no-c-format
-msgid "<![CDATA[select firstName||' '||initial||' '||upper(lastName) from Person]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:380
 #, no-c-format
 msgid "The <literal>distinct</literal> and <literal>all</literal> keywords can be used and have the same semantics as in SQL."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:385
-#, no-c-format
-msgid ""
-      "<![CDATA[select distinct cat.name from Cat cat\n"
-      "\n"
-      "select count(distinct cat.name), count(cat) from Cat cat]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:390
 #, no-c-format
 msgid "Polymorphic queries"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:392
 #, no-c-format
 msgid "A query like:"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:398
 #, no-c-format
 msgid "returns instances not only of <literal>Cat</literal>, but also of subclasses like <literal>DomesticCat</literal>. Hibernate queries can name <emphasis>any</emphasis> Java class or interface in the <literal>from</literal> clause. The query will return instances of all persistent classes that extend that class or implement the interface. The following query would return all persistent objects:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:406
-#, no-c-format
-msgid "<![CDATA[from java.lang.Object o]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:408
 #, no-c-format
 msgid "The interface <literal>Named</literal> might be implemented by various persistent classes:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:413
-#, no-c-format
-msgid "<![CDATA[from Named n, Named m where n.name = m.name]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:415
 #, no-c-format
 msgid "These last two queries will require more than one SQL <literal>SELECT</literal>. This means that the <literal>order by</literal> clause does not correctly order the whole result set. It also means you cannot call these queries using <literal>Query.scroll()</literal>."
 msgstr ""
 
 #. Tag: title
-#: query_hql.xml:424
 #, no-c-format
 msgid "The where clause"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:426
 #, no-c-format
 msgid "The <literal>where</literal> clause allows you to refine the list of instances returned. If no alias exists, you can refer to properties by name:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:431
-#, no-c-format
-msgid "<![CDATA[from Cat where name='Fritz']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:433
 #, no-c-format
 msgid "If there is an alias, use a qualified property name:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:437
-#, no-c-format
-msgid "<![CDATA[from Cat as cat where cat.name='Fritz']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:439
 #, no-c-format
 msgid "This returns instances of <literal>Cat</literal> named 'Fritz'."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:443
 #, no-c-format
 msgid "The following query:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:446
-#, no-c-format
-msgid ""
-      "<![CDATA[select foo\n"
-      "from Foo foo, Bar bar\n"
-      "where foo.startDate = bar.date]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:448
 #, no-c-format
 msgid "returns all instances of <literal>Foo</literal> with an instance of <literal>bar</literal> with a <literal>date</literal> property equal to the <literal>startDate</literal> property of the <literal>Foo</literal>. Compound path expressions make the <literal>where</literal> clause extremely powerful. Consider the following:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:457
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.mate.name is not null]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:459
 #, no-c-format
 msgid "This query translates to an SQL query with a table (inner) join. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:464
-#, no-c-format
-msgid ""
-      "<![CDATA[from Foo foo\n"
-      "where foo.bar.baz.customer.address.city is not null]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:466
 #, no-c-format
 msgid "would result in a query that would require four table joins in SQL."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:470
 #, no-c-format
 msgid "The <literal>=</literal> operator can be used to compare not only properties, but also instances:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:475
-#, no-c-format
-msgid "<![CDATA[from Cat cat, Cat rival where cat.mate = rival.mate]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:477
-#, no-c-format
-msgid ""
-      "<![CDATA[select cat, mate\n"
-      "from Cat cat, Cat mate\n"
-      "where cat.mate = mate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:479
 #, no-c-format
-msgid "The special property (lowercase) <literal>id</literal> can be used to reference the unique identifier of an object. See <xref linkend=\"queryhql-identifier-property\"/> for more information."
+msgid "The special property (lowercase) <literal>id</literal> can be used to reference the unique identifier of an object. See <xref linkend=\"queryhql-identifier-property\" /> for more information."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:485
-#, no-c-format
-msgid ""
-      "<![CDATA[from Cat as cat where cat.id = 123\n"
-      "\n"
-      "from Cat as cat where cat.mate.id = 69]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:487
 #, no-c-format
 msgid "The second query is efficient and does not require a table join."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:491
 #, no-c-format
 msgid "Properties of composite identifiers can also be used. Consider the following example where <literal>Person</literal> has composite identifiers consisting of <literal>country</literal> and <literal>medicareNumber</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:497
-#, no-c-format
-msgid ""
-      "<![CDATA[from bank.Person person\n"
-      "where person.id.country = 'AU'\n"
-      "    and person.id.medicareNumber = 123456]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:499
-#, no-c-format
-msgid ""
-      "<![CDATA[from bank.Account account\n"
-      "where account.owner.id.country = 'AU'\n"
-      "    and account.owner.id.medicareNumber = 123456]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:501
 #, no-c-format
 msgid "Once again, the second query does not require a table join."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:505
 #, no-c-format
-msgid "See <xref linkend=\"queryhql-identifier-property\"/> for more information regarding referencing identifier properties)"
+msgid "See <xref linkend=\"queryhql-identifier-property\" /> for more information regarding referencing identifier properties)"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:510
 #, no-c-format
 msgid "The special property <literal>class</literal> accesses the discriminator value of an instance in the case of polymorphic persistence. A Java class name embedded in the where clause will be translated to its discriminator value."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:516
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.class = DomesticCat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:518
 #, no-c-format
-msgid "You can also use components or composite user types, or properties of said component types. See <xref linkend=\"queryhql-components\"/> for more information."
+msgid "You can also use components or composite user types, or properties of said component types. See <xref linkend=\"queryhql-components\" /> for more information."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:523
 #, no-c-format
 msgid "An \"any\" type has the special properties <literal>id</literal> and <literal>class</literal> that allows you to express a join in the following way (where <literal>AuditLog.item</literal> is a property mapped with <literal>&lt;any&gt;</literal>):"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:529
-#, no-c-format
-msgid ""
-      "<![CDATA[from AuditLog log, Payment payment\n"
-      "where log.item.class = 'Payment' and log.item.id = payment.id]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:531
 #, no-c-format
 msgid "The <literal>log.item.class</literal> and <literal>payment.class</literal> would refer to the values of completely different database columns in the above query."
 msgstr ""
 
 #. Tag: title
-#: query_hql.xml:539
 #, no-c-format
 msgid "Expressions"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:541
 #, no-c-format
 msgid "Expressions used in the <literal>where</literal> clause include the following:"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:548
 #, no-c-format
 msgid "mathematical operators: <literal>+, -, *, /</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:553
 #, no-c-format
 msgid "binary comparison operators: <literal>=, &gt;=, &lt;=, &lt;&gt;, !=, like</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:558
 #, no-c-format
 msgid "logical operations <literal>and, or, not</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:563
 #, no-c-format
 msgid "Parentheses <literal>( )</literal> that indicates grouping"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:568
 #, no-c-format
 msgid "<literal>in</literal>, <literal>not in</literal>, <literal>between</literal>, <literal>is null</literal>, <literal>is not null</literal>, <literal>is empty</literal>, <literal>is not empty</literal>, <literal>member of</literal> and <literal>not member of</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:581
 #, no-c-format
 msgid "\"Simple\" case, <literal>case ... when ... then ... else ... end</literal>, and \"searched\" case, <literal>case when ... then ... else ... end</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:587
 #, no-c-format
 msgid "string concatenation <literal>...||...</literal> or <literal>concat(...,...)</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:592
 #, no-c-format
 msgid "<literal>current_date()</literal>, <literal>current_time()</literal>, and <literal>current_timestamp()</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:598
 #, no-c-format
 msgid "<literal>second(...)</literal>, <literal>minute(...)</literal>, <literal>hour(...)</literal>, <literal>day(...)</literal>, <literal>month(...)</literal>, and <literal>year(...)</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:605
 #, no-c-format
 msgid "Any function or operator defined by EJB-QL 3.0: <literal>substring(), trim(), lower(), upper(), length(), locate(), abs(), sqrt(), bit_length(), mod()</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:611
 #, no-c-format
 msgid "<literal>coalesce()</literal> and <literal>nullif()</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:616
 #, no-c-format
 msgid "<literal>str()</literal> for converting numeric or temporal values to a readable string"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:622
 #, no-c-format
 msgid "<literal>cast(... as ...)</literal>, where the second argument is the name of a Hibernate type, and <literal>extract(... from ...)</literal> if ANSI <literal>cast()</literal> and <literal>extract()</literal> is supported by the underlying database"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:630
 #, no-c-format
 msgid "the HQL <literal>index()</literal> function, that applies to aliases of a joined indexed collection"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:636
 #, no-c-format
 msgid "HQL functions that take collection-valued path expressions: <literal>size(), minelement(), maxelement(), minindex(), maxindex()</literal>, along with the special <literal>elements()</literal> and <literal>indices</literal> functions that can be quantified using <literal>some, all, exists, any, in</literal>."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:644
 #, no-c-format
 msgid "Any database-supported SQL scalar function like <literal>sign()</literal>, <literal>trunc()</literal>, <literal>rtrim()</literal>, and <literal>sin()</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:650
 #, no-c-format
 msgid "JDBC-style positional parameters <literal>?</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:655
 #, no-c-format
 msgid "named parameters <literal>:name</literal>, <literal>:start_date</literal>, and <literal>:x1</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:660
 #, no-c-format
 msgid "SQL literals <literal>'foo'</literal>, <literal>69</literal>, <literal>6.66E+2</literal>, <literal>'1970-01-01 10:00:01.0'</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:666
 #, no-c-format
 msgid "Java <literal>public static final</literal> constants <literal>eg.Color.TABBY</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:672
 #, no-c-format
 msgid "<literal>in</literal> and <literal>between</literal> can be used as follows:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:676
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name between 'A' and 'B']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:678
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name in ( 'Foo', 'Bar', 'Baz' )]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:680
 #, no-c-format
 msgid "The negated forms can be written as follows:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:684
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name not between 'A' and 'B']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:686
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name not in ( 'Foo', 'Bar', 'Baz' )]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:688
 #, no-c-format
 msgid "Similarly, <literal>is null</literal> and <literal>is not null</literal> can be used to test for null values."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:693
 #, no-c-format
 msgid "Booleans can be easily used in expressions by declaring HQL query substitutions in Hibernate configuration:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:698
-#, no-c-format
-msgid "<![CDATA[<property name=\"hibernate.query.substitutions\">true 1, false 0</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:700
 #, no-c-format
 msgid "This will replace the keywords <literal>true</literal> and <literal>false</literal> with the literals <literal>1</literal> and <literal>0</literal> in the translated SQL from this HQL:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:705
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.alive = true]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:707
 #, no-c-format
 msgid "You can test the size of a collection with the special property <literal>size</literal> or the special <literal>size()</literal> function."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:712
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.kittens.size > 0]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:714
-#, no-c-format
-msgid "<![CDATA[from Cat cat where size(cat.kittens) > 0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:716
 #, no-c-format
 msgid "For indexed collections, you can refer to the minimum and maximum indices using <literal>minindex</literal> and <literal>maxindex</literal> functions. Similarly, you can refer to the minimum and maximum elements of a collection of basic type using the <literal>minelement</literal> and <literal>maxelement</literal> functions. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:724
-#, no-c-format
-msgid "<![CDATA[from Calendar cal where maxelement(cal.holidays) > current_date]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:726
-#, no-c-format
-msgid "<![CDATA[from Order order where maxindex(order.items) > 100]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:728
-#, no-c-format
-msgid "<![CDATA[from Order order where minelement(order.items) > 10000]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:730
 #, no-c-format
 msgid "The SQL functions <literal>any, some, all, exists, in</literal> are supported when passed the element or index set of a collection (<literal>elements</literal> and <literal>indices</literal> functions) or the result of a subquery (see below):"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:736
-#, no-c-format
-msgid ""
-      "<![CDATA[select mother from Cat as mother, Cat as kit\n"
-      "where kit in elements(foo.kittens)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:738
-#, no-c-format
-msgid ""
-      "<![CDATA[select p from NameList list, Person p\n"
-      "where p.name = some elements(list.names)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:740
-#, no-c-format
-msgid "<![CDATA[from Cat cat where exists elements(cat.kittens)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:742
-#, no-c-format
-msgid "<![CDATA[from Player p where 3 > all elements(p.scores)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:744
-#, no-c-format
-msgid "<![CDATA[from Show show where 'fizard' in indices(show.acts)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:746
 #, no-c-format
 msgid "Note that these constructs - <literal>size</literal>, <literal>elements</literal>, <literal>indices</literal>, <literal>minindex</literal>, <literal>maxindex</literal>, <literal>minelement</literal>, <literal>maxelement</literal> - can only be used in the where clause in Hibernate3."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:753
 #, no-c-format
 msgid "Elements of indexed collections (arrays, lists, and maps) can be referred to by index in a where clause only:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:758
-#, no-c-format
-msgid "<![CDATA[from Order order where order.items[0].id = 1234]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:760
-#, no-c-format
-msgid ""
-      "<![CDATA[select person from Person person, Calendar calendar\n"
-      "where calendar.holidays['national day'] = person.birthDay\n"
-      "    and person.nationality.calendar = calendar]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:762
-#, no-c-format
-msgid ""
-      "<![CDATA[select item from Item item, Order order\n"
-      "where order.items[ order.deliveredItemIndices[0] ] = item and order.id = 11]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:764
-#, no-c-format
-msgid ""
-      "<![CDATA[select item from Item item, Order order\n"
-      "where order.items[ maxindex(order.items) ] = item and order.id = 11]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:766
 #, no-c-format
 msgid "The expression inside <literal>[]</literal> can even be an arithmetic expression:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:770
-#, no-c-format
-msgid ""
-      "<![CDATA[select item from Item item, Order order\n"
-      "where order.items[ size(order.items) - 1 ] = item]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:772
 #, no-c-format
 msgid "HQL also provides the built-in <literal>index()</literal> function for elements of a one-to-many association or collection of values."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:777
-#, no-c-format
-msgid ""
-      "<![CDATA[select item, index(item) from Order order\n"
-      "    join order.items item\n"
-      "where index(item) < 5]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:779
 #, no-c-format
 msgid "Scalar SQL functions supported by the underlying database can be used:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:783
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where upper(cat.name) like 'FRI%']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:785
 #, no-c-format
 msgid "Consider how much longer and less readable the following query would be in SQL:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:790
-#, no-c-format
-msgid ""
-      "<![CDATA[select cust\n"
-      "from Product prod,\n"
-      "    Store store\n"
-      "    inner join store.customers cust\n"
-      "where prod.name = 'widget'\n"
-      "    and store.location.name in ( 'Melbourne', 'Sydney' )\n"
-      "    and prod = all elements(cust.currentOrder.lineItems)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:792
 #, no-c-format
 msgid "<emphasis>Hint:</emphasis> something like"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:796
-#, no-c-format
-msgid ""
-      "<![CDATA[SELECT cust.name, cust.address, cust.phone, cust.id, cust.current_order\n"
-      "FROM customers cust,\n"
-      "    stores store,\n"
-      "    locations loc,\n"
-      "    store_customers sc,\n"
-      "    product prod\n"
-      "WHERE prod.name = 'widget'\n"
-      "    AND store.loc_id = loc.id\n"
-      "    AND loc.name IN ( 'Melbourne', 'Sydney' )\n"
-      "    AND sc.store_id = store.id\n"
-      "    AND sc.cust_id = cust.id\n"
-      "    AND prod.id = ALL(\n"
-      "        SELECT item.prod_id\n"
-      "        FROM line_items item, orders o\n"
-      "        WHERE item.order_id = o.id\n"
-      "            AND cust.current_order = o.id\n"
-      "    )]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:801
 #, no-c-format
 msgid "The order by clause"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:803
 #, no-c-format
 msgid "The list returned by a query can be ordered by any property of a returned class or components:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:807
-#, no-c-format
-msgid ""
-      "<![CDATA[from DomesticCat cat\n"
-      "order by cat.name asc, cat.weight desc, cat.birthdate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:809
 #, no-c-format
 msgid "The optional <literal>asc</literal> or <literal>desc</literal> indicate ascending or descending order respectively."
 msgstr ""
 
 #. Tag: title
-#: query_hql.xml:816
 #, no-c-format
 msgid "The group by clause"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:818
 #, no-c-format
 msgid "A query that returns aggregate values can be grouped by any property of a returned class or components:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:822
-#, no-c-format
-msgid ""
-      "<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
-      "from Cat cat\n"
-      "group by cat.color]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:824
-#, no-c-format
-msgid ""
-      "<![CDATA[select foo.id, avg(name), max(name)\n"
-      "from Foo foo join foo.names name\n"
-      "group by foo.id]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:826
 #, no-c-format
 msgid "A <literal>having</literal> clause is also allowed."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:830
-#, no-c-format
-msgid ""
-      "<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
-      "from Cat cat\n"
-      "group by cat.color\n"
-      "having cat.color in (eg.Color.TABBY, eg.Color.BLACK)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:832
 #, no-c-format
 msgid "SQL functions and aggregate functions are allowed in the <literal>having</literal> and <literal>order by</literal> clauses if they are supported by the underlying database (i.e., not in MySQL)."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:838
-#, no-c-format
-msgid ""
-      "<![CDATA[select cat\n"
-      "from Cat cat\n"
-      "    join cat.kittens kitten\n"
-      "group by cat.id, cat.name, cat.other, cat.properties\n"
-      "having avg(kitten.weight) > 100\n"
-      "order by count(kitten) asc, sum(kitten.weight) desc]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:840
 #, no-c-format
 msgid "Neither the <literal>group by</literal> clause nor the <literal>order by</literal> clause can contain arithmetic expressions. Hibernate also does not currently expand a grouped entity, so you cannot write <literal>group by cat</literal> if all properties of <literal>cat</literal> are non-aggregated. You have to list all non-aggregated properties explicitly."
 msgstr ""
 
 #. Tag: title
-#: query_hql.xml:852
 #, no-c-format
 msgid "Subqueries"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:854
 #, no-c-format
 msgid "For databases that support subselects, Hibernate supports subqueries within queries. A subquery must be surrounded by parentheses (often by an SQL aggregate function call). Even correlated subqueries (subqueries that refer to an alias in the outer query) are allowed."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:860
-#, no-c-format
-msgid ""
-      "<![CDATA[from Cat as fatcat\n"
-      "where fatcat.weight > (\n"
-      "    select avg(cat.weight) from DomesticCat cat\n"
-      ")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:862
-#, no-c-format
-msgid ""
-      "<![CDATA[from DomesticCat as cat\n"
-      "where cat.name = some (\n"
-      "    select name.nickName from Name as name\n"
-      ")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:864
-#, no-c-format
-msgid ""
-      "<![CDATA[from Cat as cat\n"
-      "where not exists (\n"
-      "    from Cat as mate where mate.mate = cat\n"
-      ")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:866
-#, no-c-format
-msgid ""
-      "<![CDATA[from DomesticCat as cat\n"
-      "where cat.name not in (\n"
-      "    select name.nickName from Name as name\n"
-      ")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:868
-#, no-c-format
-msgid ""
-      "<![CDATA[select cat.id, (select max(kit.weight) from cat.kitten kit)\n"
-      "from Cat as cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:870
 #, no-c-format
 msgid "Note that HQL subqueries can occur only in the select or where clauses."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:874
 #, no-c-format
-msgid "Note that subqueries can also utilize <literal>row value constructor</literal> syntax. See <xref linkend=\"queryhql-tuple\"/> for more information."
+msgid "Note that subqueries can also utilize <literal>row value constructor</literal> syntax. See <xref linkend=\"queryhql-tuple\" /> for more information."
 msgstr ""
 
 #. Tag: title
-#: query_hql.xml:882
 #, no-c-format
 msgid "HQL examples"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:884
 #, no-c-format
 msgid "Hibernate queries can be quite powerful and complex. In fact, the power of the query language is one of Hibernate's main strengths. The following example queries are similar to queries that have been used on recent projects. Please note that most queries you will write will be much simpler than the following examples."
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:890
 #, no-c-format
 msgid "The following query returns the order id, number of items, the given minimum total value and the total value of the order for all unpaid orders for a particular customer. The results are ordered by total value. In determining the prices, it uses the current catalog. The resulting SQL query, against the <literal>ORDER</literal>, <literal>ORDER_LINE</literal>, <literal>PRODUCT</literal>, <literal>CATALOG</literal> and <literal>PRICE</literal> tables has four inner joins and an (uncorrelated) subselect."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:899
-#, no-c-format
-msgid ""
-      "<![CDATA[select order.id, sum(price.amount), count(item)\n"
-      "from Order as order\n"
-      "    join order.lineItems as item\n"
-      "    join item.product as product,\n"
-      "    Catalog as catalog\n"
-      "    join catalog.prices as price\n"
-      "where order.paid = false\n"
-      "    and order.customer = :customer\n"
-      "    and price.product = product\n"
-      "    and catalog.effectiveDate < sysdate\n"
-      "    and catalog.effectiveDate >= all (\n"
-      "        select cat.effectiveDate\n"
-      "        from Catalog as cat\n"
-      "        where cat.effectiveDate < sysdate\n"
-      "    )\n"
-      "group by order\n"
-      "having sum(price.amount) > :minAmount\n"
-      "order by sum(price.amount) desc]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:901
 #, no-c-format
 msgid "What a monster! Actually, in real life, I'm not very keen on subqueries, so my query was really more like this:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:906
-#, no-c-format
-msgid ""
-      "<![CDATA[select order.id, sum(price.amount), count(item)\n"
-      "from Order as order\n"
-      "    join order.lineItems as item\n"
-      "    join item.product as product,\n"
-      "    Catalog as catalog\n"
-      "    join catalog.prices as price\n"
-      "where order.paid = false\n"
-      "    and order.customer = :customer\n"
-      "    and price.product = product\n"
-      "    and catalog = :currentCatalog\n"
-      "group by order\n"
-      "having sum(price.amount) > :minAmount\n"
-      "order by sum(price.amount) desc]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:908
 #, no-c-format
 msgid "The next query counts the number of payments in each status, excluding all payments in the <literal>AWAITING_APPROVAL</literal> status where the most recent status change was made by the current user. It translates to an SQL query with two inner joins and a correlated subselect against the <literal>PAYMENT</literal>, <literal>PAYMENT_STATUS</literal> and <literal>PAYMENT_STATUS_CHANGE</literal> tables."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:916
-#, no-c-format
-msgid ""
-      "<![CDATA[select count(payment), status.name\n"
-      "from Payment as payment\n"
-      "    join payment.currentStatus as status\n"
-      "    join payment.statusChanges as statusChange\n"
-      "where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-      "    or (\n"
-      "        statusChange.timeStamp = (\n"
-      "            select max(change.timeStamp)\n"
-      "            from PaymentStatusChange change\n"
-      "            where change.payment = payment\n"
-      "        )\n"
-      "        and statusChange.user <> :currentUser\n"
-      "    )\n"
-      "group by status.name, status.sortOrder\n"
-      "order by status.sortOrder]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:918
 #, no-c-format
 msgid "If the <literal>statusChanges</literal> collection was mapped as a list, instead of a set, the query would have been much simpler to write."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:923
-#, no-c-format
-msgid ""
-      "<![CDATA[select count(payment), status.name\n"
-      "from Payment as payment\n"
-      "    join payment.currentStatus as status\n"
-      "where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-      "    or payment.statusChanges[ maxIndex(payment.statusChanges) ].user <> :currentUser\n"
-      "group by status.name, status.sortOrder\n"
-      "order by status.sortOrder]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:925
 #, no-c-format
 msgid "The next query uses the MS SQL Server <literal>isNull()</literal> function to return all the accounts and unpaid payments for the organization to which the current user belongs. It translates to an SQL query with three inner joins, an outer join and a subselect against the <literal>ACCOUNT</literal>, <literal>PAYMENT</literal>, <literal>PAYMENT_STATUS</literal>, <literal>ACCOUNT_TYPE</literal>, <literal>ORGANIZATION</literal> and <literal>ORG_USER</literal> tables."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:934
-#, no-c-format
-msgid ""
-      "<![CDATA[select account, payment\n"
-      "from Account as account\n"
-      "    left outer join account.payments as payment\n"
-      "where :currentUser in elements(account.holder.users)\n"
-      "    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, PaymentStatus.UNPAID)\n"
-      "order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:936
 #, no-c-format
 msgid "For some databases, we would need to do away with the (correlated) subselect."
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:940
-#, no-c-format
-msgid ""
-      "<![CDATA[select account, payment\n"
-      "from Account as account\n"
-      "    join account.holder.users as user\n"
-      "    left outer join account.payments as payment\n"
-      "where :currentUser = user\n"
-      "    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, PaymentStatus.UNPAID)\n"
-      "order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:945
 #, no-c-format
 msgid "Bulk update and delete"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:947
 #, no-c-format
-msgid "HQL now supports <literal>update</literal>, <literal>delete</literal> and <literal>insert ... select ...</literal> statements. See <xref linkend=\"batch-direct\"/> for more information."
+msgid "HQL now supports <literal>update</literal>, <literal>delete</literal> and <literal>insert ... select ...</literal> statements. See <xref linkend=\"batch-direct\" /> for more information."
 msgstr ""
 
 #. Tag: title
-#: query_hql.xml:955
 #, no-c-format
 msgid "Tips &amp; Tricks"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:957
 #, no-c-format
 msgid "You can count the number of query results without returning them:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:961
-#, no-c-format
-msgid "<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\").iterate().next() ).intValue()]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:963
 #, no-c-format
 msgid "To order a result by the size of a collection, use the following query:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:967
-#, no-c-format
-msgid ""
-      "<![CDATA[select usr.id, usr.name\n"
-      "from User as usr\n"
-      "    left join usr.messages as msg\n"
-      "group by usr.id, usr.name\n"
-      "order by count(msg)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:969
 #, no-c-format
 msgid "If your database supports subselects, you can place a condition upon selection size in the where clause of your query:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:974
-#, no-c-format
-msgid "<![CDATA[from User usr where size(usr.messages) >= 1]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:976
 #, no-c-format
 msgid "If your database does not support subselects, use the following query:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:980
-#, no-c-format
-msgid ""
-      "<![CDATA[select usr.id, usr.name\n"
-      "from User usr.name\n"
-      "    join usr.messages msg\n"
-      "group by usr.id, usr.name\n"
-      "having count(msg) >= 1]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:983
 #, no-c-format
 msgid "As this solution cannot return a <literal>User</literal> with zero messages because of the inner join, the following form is also useful:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:988
-#, no-c-format
-msgid ""
-      "<![CDATA[select usr.id, usr.name\n"
-      "from User as usr\n"
-      "    left join usr.messages as msg\n"
-      "group by usr.id, usr.name\n"
-      "having count(msg) = 0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:990
 #, no-c-format
 msgid "Properties of a JavaBean can be bound to named query parameters:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:994
-#, no-c-format
-msgid ""
-      "<![CDATA[Query q = s.createQuery(\"from foo Foo as foo where foo.name=:name and foo.size=:size\");\n"
-      "q.setProperties(fooBean); // fooBean has getName() and getSize()\n"
-      "List foos = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:996
 #, no-c-format
 msgid "Collections are pageable by using the <literal>Query</literal> interface with a filter:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:1000
-#, no-c-format
-msgid ""
-      "<![CDATA[Query q = s.createFilter( collection, \"\" ); // the trivial filter\n"
-      "q.setMaxResults(PAGE_SIZE);\n"
-      "q.setFirstResult(PAGE_SIZE * pageNumber);\n"
-      "List page = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1002
 #, no-c-format
 msgid "Collection elements can be ordered or grouped using a query filter:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:1006
-#, no-c-format
-msgid ""
-      "<![CDATA[Collection orderedCollection = s.filter( collection, \"order by this.amount\" );\n"
-      "Collection counts = s.filter( collection, \"select this.type, count(this) group by this.type\" );]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1008
 #, no-c-format
 msgid "You can find the size of a collection without initializing it:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:1012
-#, no-c-format
-msgid "<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\").iterate().next() ).intValue();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:1017
 #, no-c-format
 msgid "Components"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:1019
 #, no-c-format
 msgid "Components can be used similarly to the simple value types that are used in HQL queries. They can appear in the <literal>select</literal> clause as follows:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:1024 query_hql.xml:1070
-#, no-c-format
-msgid "<![CDATA[select p.name from Person p]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1025
-#, no-c-format
-msgid "<![CDATA[select p.name.first from Person p]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1027
 #, no-c-format
 msgid "where the Person's name property is a component. Components can also be used in the <literal>where</literal> clause:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:1032
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name = :name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1033
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name.first = :firstName]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1035
 #, no-c-format
 msgid "Components can also be used in the <literal>order by</literal> clause:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:1039
-#, no-c-format
-msgid "<![CDATA[from Person p order by p.name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1040
-#, no-c-format
-msgid "<![CDATA[from Person p order by p.name.first]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1042
 #, no-c-format
 msgid "Another common use of components is in <link linkend=\"queryhql-tuple\">row value constructors</link>."
 msgstr ""
 
 #. Tag: title
-#: query_hql.xml:1048
 #, no-c-format
 msgid "Row value constructor syntax"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:1050
 #, no-c-format
 msgid "HQL supports the use of ANSI SQL <literal>row value constructor</literal> syntax, sometimes referred to AS <literal>tuple</literal> syntax, even though the underlying database may not support that notion. Here, we are generally referring to multi-valued comparisons, typically associated with components. Consider an entity Person which defines a name component:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:1057
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name.first='John' and p.name.last='Jingleheimer-Schmidt']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1059
 #, no-c-format
 msgid "That is valid syntax although it is a little verbose. You can make this more concise by using <literal>row value constructor</literal> syntax:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:1064
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name=('John', 'Jingleheimer-Schmidt')]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1066
 #, no-c-format
 msgid "It can also be useful to specify this in the <literal>select</literal> clause:"
 msgstr ""
 
 #. Tag: para
-#: query_hql.xml:1072
 #, no-c-format
 msgid "Using <literal>row value constructor</literal> syntax can also be beneficial when using subqueries that need to compare against multiple values:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_hql.xml:1077
-#, no-c-format
-msgid ""
-      "<![CDATA[from Cat as cat\n"
-      "where not ( cat.name, cat.color ) in (\n"
-      "    select cat.name, cat.color from DomesticCat cat\n"
-      ")]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1079
 #, no-c-format
 msgid "One thing to consider when deciding if you want to use this syntax, is that the query will be dependent upon the ordering of the component sub-properties in the metadata."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/query_sql.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/query_sql.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/query_sql.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,1112 +1,594 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: query_sql.xml:29
 #, no-c-format
 msgid "Native SQL"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:31
 #, no-c-format
 msgid "You can also express queries in the native SQL dialect of your database. This is useful if you want to utilize database-specific features such as query hints or the <literal>CONNECT</literal> keyword in Oracle. It also provides a clean migration path from a direct SQL/JDBC based application to Hibernate."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:37
 #, no-c-format
 msgid "Hibernate3 allows you to specify handwritten SQL, including stored procedures, for all create, update, delete, and load operations."
 msgstr ""
 
 #. Tag: title
-#: query_sql.xml:41
 #, no-c-format
 msgid "Using a <literal>SQLQuery</literal>"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:43
 #, no-c-format
 msgid "Execution of native SQL queries is controlled via the <literal>SQLQuery</literal> interface, which is obtained by calling <literal>Session.createSQLQuery()</literal>. The following sections describe how to use this API for querying."
 msgstr ""
 
 #. Tag: title
-#: query_sql.xml:49
 #, no-c-format
 msgid "Scalar queries"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:51
 #, no-c-format
 msgid "The most basic SQL query is to get a list of scalars (values)."
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:54
-#, no-c-format
-msgid ""
-      "<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").list();\n"
-      "sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").list();\n"
-      "]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:56
 #, no-c-format
 msgid "These will return a List of Object arrays (Object[]) with scalar values for each column in the CATS table. Hibernate will use ResultSetMetadata to deduce the actual order and types of the returned scalar values."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:61
 #, no-c-format
 msgid "To avoid the overhead of using <literal>ResultSetMetadata</literal>, or simply to be more explicit in what is returned, one can use <literal>addScalar()</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:65
-#, no-c-format
-msgid ""
-      "<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-      " .addScalar(\"ID\", Hibernate.LONG)\n"
-      " .addScalar(\"NAME\", Hibernate.STRING)\n"
-      " .addScalar(\"BIRTHDATE\", Hibernate.DATE)\n"
-      "]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:67 query_sql.xml:113 query_sql.xml:198 query_sql.xml:349
 #, no-c-format
 msgid "This query specified:"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:71 query_sql.xml:117 query_sql.xml:353
 #, no-c-format
 msgid "the SQL query string"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:75
 #, no-c-format
 msgid "the columns and types to return"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:79
 #, no-c-format
 msgid "This will return Object arrays, but now it will not use <literal>ResultSetMetadata</literal> but will instead explicitly get the ID, NAME and BIRTHDATE column as respectively a Long, String and a Short from the underlying resultset. This also means that only these three columns will be returned, even though the query is using <literal>*</literal> and could return more than the three listed columns."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:87
 #, no-c-format
 msgid "It is possible to leave out the type information for all or some of the scalars."
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:90
-#, no-c-format
-msgid ""
-      "<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-      " .addScalar(\"ID\", Hibernate.LONG)\n"
-      " .addScalar(\"NAME\")\n"
-      " .addScalar(\"BIRTHDATE\")\n"
-      "]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:92
 #, no-c-format
 msgid "This is essentially the same query as before, but now <literal>ResultSetMetaData</literal> is used to determine the type of NAME and BIRTHDATE, where as the type of ID is explicitly specified."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:96
 #, no-c-format
 msgid "How the java.sql.Types returned from ResultSetMetaData is mapped to Hibernate types is controlled by the Dialect. If a specific type is not mapped, or does not result in the expected type, it is possible to customize it via calls to <literal>registerHibernateType</literal> in the Dialect."
 msgstr ""
 
 #. Tag: title
-#: query_sql.xml:104
 #, no-c-format
 msgid "Entity queries"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:106
 #, no-c-format
 msgid "The above queries were all about returning scalar values, basically returning the \"raw\" values from the resultset. The following shows how to get entity objects from a native sql query via <literal>addEntity()</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:111
-#, no-c-format
-msgid ""
-      "<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").addEntity(Cat.class);\n"
-      "sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").addEntity(Cat.class);\n"
-      "]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:121
 #, no-c-format
 msgid "the entity returned by the query"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:125
 #, no-c-format
 msgid "Assuming that Cat is mapped as a class with the columns ID, NAME and BIRTHDATE the above queries will both return a List where each element is a Cat entity."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:129
 #, no-c-format
 msgid "If the entity is mapped with a <literal>many-to-one</literal> to another entity it is required to also return this when performing the native query, otherwise a database specific \"column not found\" error will occur. The additional columns will automatically be returned when using the * notation, but we prefer to be explicit as in the following example for a <literal>many-to-one</literal> to a <literal>Dog</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:137
-#, no-c-format
-msgid ""
-      "<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, DOG_ID FROM CATS\").addEntity(Cat.class);\n"
-      "]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:139
 #, no-c-format
 msgid "This will allow cat.getDog() to function properly."
 msgstr ""
 
 #. Tag: title
-#: query_sql.xml:143
 #, no-c-format
 msgid "Handling associations and collections"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:145
 #, no-c-format
 msgid "It is possible to eagerly join in the <literal>Dog</literal> to avoid the possible extra roundtrip for initializing the proxy. This is done via the <literal>addJoin()</literal> method, which allows you to join in an association or collection."
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:150
-#, no-c-format
-msgid ""
-      "<![CDATA[sess.createSQLQuery(\"SELECT c.ID, NAME, BIRTHDATE, DOG_ID, D_ID, D_NAME FROM CATS c, DOGS d WHERE c.DOG_ID = d.D_ID\")\n"
-      " .addEntity(\"cat\", Cat.class)\n"
-      " .addJoin(\"cat.dog\");\n"
-      "]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:152
 #, no-c-format
 msgid "In this example, the returned <literal>Cat</literal>'s will have their <literal>dog</literal> property fully initialized without any extra roundtrip to the database. Notice that you added an alias name (\"cat\") to be able to specify the target property path of the join. It is possible to do the same eager joining for collections, e.g. if the <literal>Cat</literal> had a one-to-many to <literal>Dog</literal> instead."
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:160
-#, no-c-format
-msgid ""
-      "<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, D_ID, D_NAME, CAT_ID FROM CATS c, DOGS d WHERE c.ID = d.CAT_ID\")\n"
-      " .addEntity(\"cat\", Cat.class)\n"
-      " .addJoin(\"cat.dogs\");\n"
-      "]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:162
 #, no-c-format
 msgid "At this stage you are reaching the limits of what is possible with native queries, without starting to enhance the sql queries to make them usable in Hibernate. Problems can arise when returning multiple entities of the same type or when the default alias/column names are not enough."
 msgstr ""
 
 #. Tag: title
-#: query_sql.xml:170
 #, no-c-format
 msgid "Returning multiple entities"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:172
 #, no-c-format
 msgid "Until now, the result set column names are assumed to be the same as the column names specified in the mapping document. This can be problematic for SQL queries that join multiple tables, since the same column names can appear in more than one table."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:177
 #, no-c-format
 msgid "Column alias injection is needed in the following query (which most likely will fail):"
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:180
-#, no-c-format
-msgid ""
-      "<![CDATA[sess.createSQLQuery(\"SELECT c.*, m.*  FROM CATS c, CATS m WHERE c.MOTHER_ID = c.ID\")\n"
-      " .addEntity(\"cat\", Cat.class)\n"
-      " .addEntity(\"mother\", Cat.class)\n"
-      "]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:184
 #, no-c-format
 msgid "The query was intended to return two Cat instances per row: a cat and its mother. The query will, however, fail because there is a conflict of names; the instances are mapped to the same column names. Also, on some databases the returned column aliases will most likely be on the form \"c.ID\", \"c.NAME\", etc. which are not equal to the columns specified in the mappings (\"ID\" and \"NAME\")."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:193
 #, no-c-format
 msgid "The following form is not vulnerable to column name duplication:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:196
-#, no-c-format
-msgid ""
-      "<![CDATA[sess.createSQLQuery(\"SELECT {cat.*}, {mother.*}  FROM CATS c, CATS m WHERE c.MOTHER_ID = c.ID\")\n"
-      " .addEntity(\"cat\", Cat.class)\n"
-      " .addEntity(\"mother\", Cat.class)\n"
-      "]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:202
 #, no-c-format
 msgid "the SQL query string, with placeholders for Hibernate to inject column aliases"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:207
 #, no-c-format
 msgid "the entities returned by the query"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:211
 #, no-c-format
 msgid "The {cat.*} and {mother.*} notation used above is a shorthand for \"all properties\". Alternatively, you can list the columns explicitly, but even in this case Hibernate injects the SQL column aliases for each property. The placeholder for a column alias is just the property name qualified by the table alias. In the following example, you retrieve Cats and their mothers from a different table (cat_log) to the one declared in the mapping metadata. You can even use the property aliases in the where clause."
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:220
-#, no-c-format
-msgid ""
-      "<![CDATA[String sql = \"SELECT ID as {c.id}, NAME as {c.name}, \" + \n"
-      "         \"BIRTHDATE as {c.birthDate}, MOTHER_ID as {c.mother}, {mother.*} \" +\n"
-      "         \"FROM CAT_LOG c, CAT_LOG m WHERE {c.mother} = c.ID\";\n"
-      "\n"
-      "List loggedCats = sess.createSQLQuery(sql)\n"
-      "        .addEntity(\"cat\", Cat.class)\n"
-      "        .addEntity(\"mother\", Cat.class).list()\n"
-      "]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:223
 #, no-c-format
 msgid "Alias and property references"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:225
 #, no-c-format
 msgid "In most cases the above alias injection is needed. For queries relating to more complex mappings, like composite properties, inheritance discriminators, collections etc., you can use specific aliases that allow Hibernate to inject the proper aliases."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:230
 #, no-c-format
 msgid "The following table shows the different ways you can use the alias injection. Please note that the alias names in the result are simply examples; each alias will have a unique and probably different name when used."
 msgstr ""
 
 #. Tag: title
-#: query_sql.xml:236
 #, no-c-format
 msgid "Alias injection names"
 msgstr ""
 
 #. Tag: entry
-#: query_sql.xml:247
 #, no-c-format
 msgid "Description"
 msgstr ""
 
 #. Tag: entry
-#: query_sql.xml:249
 #, no-c-format
 msgid "Syntax"
 msgstr ""
 
 #. Tag: entry
-#: query_sql.xml:251
 #, no-c-format
 msgid "Example"
 msgstr ""
 
 #. Tag: entry
-#: query_sql.xml:257
 #, no-c-format
 msgid "A simple property"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:259
+#. Tag: entry
 #, no-c-format
-msgid "{[aliasname].[propertyname]"
+msgid "<literal>{[aliasname].[propertyname]</literal>"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:261
+#. Tag: entry
 #, no-c-format
-msgid "A_NAME as {item.name}"
+msgid "<literal>A_NAME as {item.name}</literal>"
 msgstr ""
 
 #. Tag: entry
-#: query_sql.xml:265
 #, no-c-format
 msgid "A composite property"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:267
+#. Tag: entry
 #, no-c-format
-msgid "{[aliasname].[componentname].[propertyname]}"
+msgid "<literal>{[aliasname].[componentname].[propertyname]}</literal>"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:269
+#. Tag: entry
 #, no-c-format
-msgid "CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}"
+msgid "<literal>CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}</literal>"
 msgstr ""
 
 #. Tag: entry
-#: query_sql.xml:274
 #, no-c-format
 msgid "Discriminator of an entity"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:276
+#. Tag: entry
 #, no-c-format
-msgid "{[aliasname].class}"
+msgid "<literal>{[aliasname].class}</literal>"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:278
+#. Tag: entry
 #, no-c-format
-msgid "DISC as {item.class}"
+msgid "<literal>DISC as {item.class}</literal>"
 msgstr ""
 
 #. Tag: entry
-#: query_sql.xml:282
 #, no-c-format
 msgid "All properties of an entity"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:284 query_sql.xml:332
+#. Tag: entry
 #, no-c-format
-msgid "{[aliasname].*}"
+msgid "<literal>{[aliasname].*}</literal>"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:286
+#. Tag: entry
 #, no-c-format
-msgid "{item.*}"
+msgid "<literal>{item.*}</literal>"
 msgstr ""
 
 #. Tag: entry
-#: query_sql.xml:290
 #, no-c-format
 msgid "A collection key"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:292
+#. Tag: entry
 #, no-c-format
-msgid "{[aliasname].key}"
+msgid "<literal>{[aliasname].key}</literal>"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:294
+#. Tag: entry
 #, no-c-format
-msgid "ORGID as {coll.key}"
+msgid "<literal>ORGID as {coll.key}</literal>"
 msgstr ""
 
 #. Tag: entry
-#: query_sql.xml:298
 #, no-c-format
 msgid "The id of an collection"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:300
+#. Tag: entry
 #, no-c-format
-msgid "{[aliasname].id}"
+msgid "<literal>{[aliasname].id}</literal>"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:302
+#. Tag: entry
 #, no-c-format
-msgid "EMPID as {coll.id}"
+msgid "<literal>EMPID as {coll.id}</literal>"
 msgstr ""
 
 #. Tag: entry
-#: query_sql.xml:306
 #, no-c-format
 msgid "The element of an collection"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:308
+#. Tag: entry
 #, no-c-format
-msgid "{[aliasname].element}"
+msgid "<literal>{[aliasname].element}</literal>"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:310
+#. Tag: entry
 #, no-c-format
-msgid "XID as {coll.element}"
+msgid "<literal>XID as {coll.element}</literal>"
 msgstr ""
 
 #. Tag: entry
-#: query_sql.xml:314
 #, no-c-format
 msgid "property of the element in the collection"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:316
+#. Tag: entry
 #, no-c-format
-msgid "{[aliasname].element.[propertyname]}"
+msgid "<literal>{[aliasname].element.[propertyname]}</literal>"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:318
+#. Tag: entry
 #, no-c-format
-msgid "NAME as {coll.element.name}"
+msgid "<literal>NAME as {coll.element.name}</literal>"
 msgstr ""
 
 #. Tag: entry
-#: query_sql.xml:322
 #, no-c-format
 msgid "All properties of the element in the collection"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:324
+#. Tag: entry
 #, no-c-format
-msgid "{[aliasname].element.*}"
+msgid "<literal>{[aliasname].element.*}</literal>"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:326
+#. Tag: entry
 #, no-c-format
-msgid "{coll.element.*}"
+msgid "<literal>{coll.element.*}</literal>"
 msgstr ""
 
 #. Tag: entry
-#: query_sql.xml:330
 #, no-c-format
 msgid "All properties of the the collection"
 msgstr ""
 
-#. Tag: literal
-#: query_sql.xml:334
+#. Tag: entry
 #, no-c-format
-msgid "{coll.*}"
+msgid "<literal>{coll.*}</literal>"
 msgstr ""
 
 #. Tag: title
-#: query_sql.xml:343
 #, no-c-format
 msgid "Returning non-managed entities"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:345
 #, no-c-format
 msgid "It is possible to apply a ResultTransformer to native SQL queries, allowing it to return non-managed entities."
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:347
-#, no-c-format
-msgid ""
-      "<![CDATA[sess.createSQLQuery(\"SELECT NAME, BIRTHDATE FROM CATS\")\n"
-      "        .setResultTransformer(Transformers.aliasToBean(CatDTO.class))]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:357
 #, no-c-format
 msgid "a result transformer"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:361
 #, no-c-format
 msgid "The above query will return a list of <literal>CatDTO</literal> which has been instantiated and injected the values of NAME and BIRTHNAME into its corresponding properties or fields."
 msgstr ""
 
 #. Tag: title
-#: query_sql.xml:368
 #, no-c-format
 msgid "Handling inheritance"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:370
 #, no-c-format
 msgid "Native SQL queries which query for entities that are mapped as part of an inheritance must include all properties for the baseclass and all its subclasses."
 msgstr ""
 
 #. Tag: title
-#: query_sql.xml:376
 #, no-c-format
 msgid "Parameters"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:378
 #, no-c-format
 msgid "Native SQL queries support positional as well as named parameters:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:381
-#, no-c-format
-msgid ""
-      "<![CDATA[Query query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME like ?\").addEntity(Cat.class);\n"
-      "List pusList = query.setString(0, \"Pus%\").list();\n"
-      "     \n"
-      "query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME like :name\").addEntity(Cat.class);\n"
-      "List pusList = query.setString(\"name\", \"Pus%\").list();          ]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:389
 #, no-c-format
 msgid "Named SQL queries"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:391
 #, no-c-format
 msgid "Named SQL queries can be defined in the mapping document and called in exactly the same way as a named HQL query. In this case, you do <emphasis>not</emphasis> need to call <literal>addEntity()</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:396
-#, no-c-format
-msgid ""
-      "<![CDATA[<sql-query name=\"persons\">\n"
-      "    <return alias=\"person\" class=\"eg.Person\"/>\n"
-      "    SELECT person.NAME AS {person.name},\n"
-      "           person.AGE AS {person.age},\n"
-      "           person.SEX AS {person.sex}\n"
-      "    FROM PERSON person\n"
-      "    WHERE person.NAME LIKE :namePattern\n"
-      "</sql-query>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_sql.xml:398
-#, no-c-format
-msgid ""
-      "<![CDATA[List people = sess.getNamedQuery(\"persons\")\n"
-      "    .setString(\"namePattern\", namePattern)\n"
-      "    .setMaxResults(50)\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:400
 #, no-c-format
 msgid "The <literal>&lt;return-join&gt;</literal> element is use to join associations and the <literal>&lt;load-collection&gt;</literal> element is used to define queries which initialize collections,"
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:404
-#, no-c-format
-msgid ""
-      "<![CDATA[<sql-query name=\"personsWith\">\n"
-      "    <return alias=\"person\" class=\"eg.Person\"/>\n"
-      "    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
-      "    SELECT person.NAME AS {person.name},\n"
-      "           person.AGE AS {person.age},\n"
-      "           person.SEX AS {person.sex},\n"
-      "           address.STREET AS {address.street},\n"
-      "           address.CITY AS {address.city},\n"
-      "           address.STATE AS {address.state},\n"
-      "           address.ZIP AS {address.zip}\n"
-      "    FROM PERSON person\n"
-      "    JOIN ADDRESS address\n"
-      "        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-      "    WHERE person.NAME LIKE :namePattern\n"
-      "</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:406
 #, no-c-format
 msgid "A named SQL query may return a scalar value. You must declare the column alias and Hibernate type using the <literal>&lt;return-scalar&gt;</literal> element:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:410
-#, no-c-format
-msgid ""
-      "<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-      "    <return-scalar column=\"name\" type=\"string\"/>\n"
-      "    <return-scalar column=\"age\" type=\"long\"/>\n"
-      "    SELECT p.NAME AS name,\n"
-      "           p.AGE AS age,\n"
-      "    FROM PERSON p WHERE p.NAME LIKE 'Hiber%'\n"
-      "</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:412
 #, no-c-format
 msgid "You can externalize the resultset mapping information in a <literal>&lt;resultset&gt;</literal> element which will allow you to either reuse them across several named queries or through the <literal>setResultSetMapping()</literal> API."
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:417
-#, no-c-format
-msgid ""
-      "<![CDATA[<resultset name=\"personAddress\">\n"
-      "    <return alias=\"person\" class=\"eg.Person\"/>\n"
-      "    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
-      "</resultset>\n"
-      "\n"
-      "<sql-query name=\"personsWith\" resultset-ref=\"personAddress\">\n"
-      "    SELECT person.NAME AS {person.name},\n"
-      "           person.AGE AS {person.age},\n"
-      "           person.SEX AS {person.sex},\n"
-      "           address.STREET AS {address.street},\n"
-      "           address.CITY AS {address.city},\n"
-      "           address.STATE AS {address.state},\n"
-      "           address.ZIP AS {address.zip}\n"
-      "    FROM PERSON person\n"
-      "    JOIN ADDRESS address\n"
-      "        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-      "    WHERE person.NAME LIKE :namePattern\n"
-      "</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:419
 #, no-c-format
 msgid "You can, alternatively, use the resultset mapping information in your hbm files directly in java code."
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:422
-#, no-c-format
-msgid ""
-      "<![CDATA[List cats = sess.createSQLQuery(\n"
-      "        \"select {cat.*}, {kitten.*} from cats cat, cats kitten where kitten.mother = cat.id\"\n"
-      "    )\n"
-      "    .setResultSetMapping(\"catAndKitten\")\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:425
 #, no-c-format
 msgid "Using return-property to explicitly specify column/alias names"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:428
 #, no-c-format
 msgid "You can explicitly tell Hibernate what column aliases to use with <literal>&lt;return-property&gt;</literal>, instead of using the <literal>{}</literal>-syntax to let Hibernate inject its own aliases.For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:433
-#, no-c-format
-msgid ""
-      "<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-      "    <return alias=\"person\" class=\"eg.Person\">\n"
-      "        <return-property name=\"name\" column=\"myName\"/>\n"
-      "        <return-property name=\"age\" column=\"myAge\"/>\n"
-      "        <return-property name=\"sex\" column=\"mySex\"/>\n"
-      "    </return>\n"
-      "    SELECT person.NAME AS myName,\n"
-      "           person.AGE AS myAge,\n"
-      "           person.SEX AS mySex,\n"
-      "    FROM PERSON person WHERE person.NAME LIKE :name\n"
-      "</sql-query>\n"
-      "]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:435
 #, no-c-format
 msgid "<literal>&lt;return-property&gt;</literal> also works with multiple columns. This solves a limitation with the <literal>{}</literal>-syntax which cannot allow fine grained control of multi-column properties."
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:440
-#, no-c-format
-msgid ""
-      "<![CDATA[<sql-query name=\"organizationCurrentEmployments\">\n"
-      "    <return alias=\"emp\" class=\"Employment\">\n"
-      "        <return-property name=\"salary\">\n"
-      "            <return-column name=\"VALUE\"/>\n"
-      "            <return-column name=\"CURRENCY\"/>\n"
-      "        </return-property>\n"
-      "        <return-property name=\"endDate\" column=\"myEndDate\"/>\n"
-      "    </return>\n"
-      "        SELECT EMPLOYEE AS {emp.employee}, EMPLOYER AS {emp.employer},\n"
-      "        STARTDATE AS {emp.startDate}, ENDDATE AS {emp.endDate},\n"
-      "        REGIONCODE as {emp.regionCode}, EID AS {emp.id}, VALUE, CURRENCY\n"
-      "        FROM EMPLOYMENT\n"
-      "        WHERE EMPLOYER = :id AND ENDDATE IS NULL\n"
-      "        ORDER BY STARTDATE ASC\n"
-      "</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:442
 #, no-c-format
 msgid "In this example <literal>&lt;return-property&gt;</literal> was used in combination with the <literal>{}</literal>-syntax for injection. This allows users to choose how they want to refer column and properties."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:447
 #, no-c-format
 msgid "If your mapping has a discriminator you must use <literal>&lt;return-discriminator&gt;</literal> to specify the discriminator column."
 msgstr ""
 
 #. Tag: title
-#: query_sql.xml:453
 #, no-c-format
 msgid "Using stored procedures for querying"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:455
 #, no-c-format
 msgid "Hibernate3 provides support for queries via stored procedures and functions. Most of the following documentation is equivalent for both. The stored procedure/function must return a resultset as the first out-parameter to be able to work with Hibernate. An example of such a stored function in Oracle 9 and higher is as follows:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:461
-#, no-c-format
-msgid ""
-      "<![CDATA[CREATE OR REPLACE FUNCTION selectAllEmployments\n"
-      "    RETURN SYS_REFCURSOR\n"
-      "AS\n"
-      "    st_cursor SYS_REFCURSOR;\n"
-      "BEGIN\n"
-      "    OPEN st_cursor FOR\n"
-      " SELECT EMPLOYEE, EMPLOYER,\n"
-      " STARTDATE, ENDDATE,\n"
-      " REGIONCODE, EID, VALUE, CURRENCY\n"
-      " FROM EMPLOYMENT;\n"
-      "      RETURN  st_cursor;\n"
-      " END;]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:463
 #, no-c-format
 msgid "To use this query in Hibernate you need to map it via a named query."
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:466
-#, no-c-format
-msgid ""
-      "<![CDATA[<sql-query name=\"selectAllEmployees_SP\" callable=\"true\">\n"
-      "    <return alias=\"emp\" class=\"Employment\">\n"
-      "        <return-property name=\"employee\" column=\"EMPLOYEE\"/>\n"
-      "        <return-property name=\"employer\" column=\"EMPLOYER\"/>\n"
-      "        <return-property name=\"startDate\" column=\"STARTDATE\"/>\n"
-      "        <return-property name=\"endDate\" column=\"ENDDATE\"/>\n"
-      "        <return-property name=\"regionCode\" column=\"REGIONCODE\"/>\n"
-      "        <return-property name=\"id\" column=\"EID\"/>\n"
-      "        <return-property name=\"salary\">\n"
-      "            <return-column name=\"VALUE\"/>\n"
-      "            <return-column name=\"CURRENCY\"/>\n"
-      "        </return-property>\n"
-      "    </return>\n"
-      "    { ? = call selectAllEmployments() }\n"
-      "</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:468
 #, no-c-format
 msgid "Stored procedures currently only return scalars and entities. <literal>&lt;return-join&gt;</literal> and <literal>&lt;load-collection&gt;</literal> are not supported."
 msgstr ""
 
 #. Tag: title
-#: query_sql.xml:473
 #, no-c-format
 msgid "Rules/limitations for using stored procedures"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:475
 #, no-c-format
 msgid "You cannot use stored procedures with Hibernate unless you follow some procedure/function rules. If they do not follow those rules they are not usable with Hibernate. If you still want to use these procedures you have to execute them via <literal>session.connection()</literal>. The rules are different for each database, since database vendors have different stored procedure semantics/syntax."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:482
 #, no-c-format
 msgid "Stored procedure queries cannot be paged with <literal>setFirstResult()/setMaxResults()</literal>."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:485
 #, no-c-format
 msgid "The recommended call form is standard SQL92: <literal>{ ? = call functionName(&lt;parameters&gt;) }</literal> or <literal>{ ? = call procedureName(&lt;parameters&gt;}</literal>. Native call syntax is not supported."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:490
 #, no-c-format
 msgid "For Oracle the following rules apply:"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:494
 #, no-c-format
 msgid "A function must return a result set. The first parameter of a procedure must be an <literal>OUT</literal> that returns a result set. This is done by using a <literal>SYS_REFCURSOR</literal> type in Oracle 9 or 10. In Oracle you need to define a <literal>REF CURSOR</literal> type. See Oracle literature for further information."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:503
 #, no-c-format
 msgid "For Sybase or MS SQL server the following rules apply:"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:507
 #, no-c-format
 msgid "The procedure must return a result set. Note that since these servers can return multiple result sets and update counts, Hibernate will iterate the results and take the first result that is a result set as its return value. Everything else will be discarded."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:515
 #, no-c-format
 msgid "If you can enable <literal>SET NOCOUNT ON</literal> in your procedure it will probably be more efficient, but this is not a requirement."
 msgstr ""
 
 #. Tag: title
-#: query_sql.xml:525
 #, no-c-format
 msgid "Custom SQL for create, update and delete"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:527
 #, no-c-format
-msgid "Hibernate3 can use custom SQL statements for create, update, and delete operations. The class and collection persisters in Hibernate already contain a set of configuration time generated strings (insertsql, deletesql, updatesql etc.). The mapping tags <literal>&lt;sql-insert&gt;</literal>, <literal>&lt;sql-delete&gt;</literal>, and <literal>&lt;sql-update&gt;</literal> override these strings:"
+msgid "Hibernate3 can use custom SQL for create, update, and delete operations. The SQL can be overridden at the statement level or inidividual column level. This section describes statement overrides. For columns, see <xref linkend=\"mapping-column-read-and-write\" />."
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:535
+#. Tag: para
 #, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\">\n"
-      "        <generator class=\"increment\"/>\n"
-      "    </id>\n"
-      "    <property name=\"name\" not-null=\"true\"/>\n"
-      "    <sql-insert>INSERT INTO PERSON (NAME, ID) VALUES ( UPPER(?), ? )</sql-insert>\n"
-      "    <sql-update>UPDATE PERSON SET NAME=UPPER(?) WHERE ID=?</sql-update>\n"
-      "    <sql-delete>DELETE FROM PERSON WHERE ID=?</sql-delete>\n"
-      "</class>]]>"
+msgid "The class and collection persisters in Hibernate already contain a set of configuration time generated strings (insertsql, deletesql, updatesql etc.). The mapping tags <literal>&lt;sql-insert&gt;</literal>, <literal>&lt;sql-delete&gt;</literal>, and <literal>&lt;sql-update&gt;</literal> override these strings:"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:537
 #, no-c-format
 msgid "The SQL is directly executed in your database, so you can use any dialect you like. This will reduce the portability of your mapping if you use database specific SQL."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:541
 #, no-c-format
 msgid "Stored procedures are supported if the <literal>callable</literal> attribute is set:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:544
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\">\n"
-      "        <generator class=\"increment\"/>\n"
-      "    </id>\n"
-      "    <property name=\"name\" not-null=\"true\"/>\n"
-      "    <sql-insert callable=\"true\">{call createPerson (?, ?)}</sql-insert>\n"
-      "    <sql-delete callable=\"true\">{? = call deletePerson (?)}</sql-delete>\n"
-      "    <sql-update callable=\"true\">{? = call updatePerson (?, ?)}</sql-update>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:546
 #, no-c-format
 msgid "The order of the positional parameters is vital, as they must be in the same sequence as Hibernate expects them."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:549
 #, no-c-format
 msgid "You can view the expected order by enabling debug logging for the <literal>org.hibernate.persister.entity</literal> level. With this level enabled, Hibernate will print out the static SQL that is used to create, update, delete etc. entities. To view the expected sequence, do not include your custom SQL in the mapping files, as this will override the Hibernate generated static SQL."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:556
 #, no-c-format
 msgid "The stored procedures are in most cases required to return the number of rows inserted, updated and deleted, as Hibernate has some runtime checks for the success of the statement. Hibernate always registers the first statement parameter as a numeric output parameter for the CUD operations:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:562
-#, no-c-format
-msgid ""
-      "<![CDATA[CREATE OR REPLACE FUNCTION updatePerson (uid IN NUMBER, uname IN VARCHAR2)\n"
-      "    RETURN NUMBER IS\n"
-      "BEGIN\n"
-      "\n"
-      "    update PERSON\n"
-      "    set\n"
-      "        NAME = uname,\n"
-      "    where\n"
-      "        ID = uid;\n"
-      "\n"
-      "    return SQL%ROWCOUNT;\n"
-      "\n"
-      "END updatePerson;]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:566
 #, no-c-format
 msgid "Custom SQL for loading"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:568
 #, no-c-format
-msgid "You can also declare your own SQL (or HQL) queries for entity loading:"
+msgid "You can also declare your own SQL (or HQL) queries for entity loading. As with inserts, updates, and deletes, this can be done at the individual column level as described in <xref linkend=\"mapping-column-read-and-write\" /> or at the statement level. Here is an example of a statement level override:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:571
-#, no-c-format
-msgid ""
-      "<![CDATA[<sql-query name=\"person\">\n"
-      "    <return alias=\"pers\" class=\"Person\" lock-mode=\"upgrade\"/>\n"
-      "    SELECT NAME AS {pers.name}, ID AS {pers.id}\n"
-      "    FROM PERSON\n"
-      "    WHERE ID=?\n"
-      "    FOR UPDATE\n"
-      "</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:573
 #, no-c-format
 msgid "This is just a named query declaration, as discussed earlier. You can reference this named query in a class mapping:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:576
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\">\n"
-      "    <id name=\"id\">\n"
-      "        <generator class=\"increment\"/>\n"
-      "    </id>\n"
-      "    <property name=\"name\" not-null=\"true\"/>\n"
-      "    <loader query-ref=\"person\"/>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:578
 #, no-c-format
 msgid "This even works with stored procedures."
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:580
 #, no-c-format
 msgid "You can even define a query for collection loading:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:582
-#, no-c-format
-msgid ""
-      "<![CDATA[<set name=\"employments\" inverse=\"true\">\n"
-      "    <key/>\n"
-      "    <one-to-many class=\"Employment\"/>\n"
-      "    <loader query-ref=\"employments\"/>\n"
-      "</set>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_sql.xml:584
-#, no-c-format
-msgid ""
-      "<![CDATA[<sql-query name=\"employments\">\n"
-      "    <load-collection alias=\"emp\" role=\"Person.employments\"/>\n"
-      "    SELECT {emp.*}\n"
-      "    FROM EMPLOYMENT emp\n"
-      "    WHERE EMPLOYER = :id\n"
-      "    ORDER BY STARTDATE ASC, EMPLOYEE ASC\n"
-      "</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:586
 #, no-c-format
 msgid "You can also define an entity loader that loads a collection by join fetching:"
 msgstr ""
 
-#. Tag: programlisting
-#: query_sql.xml:589
-#, no-c-format
-msgid ""
-      "<![CDATA[<sql-query name=\"person\">\n"
-      "    <return alias=\"pers\" class=\"Person\"/>\n"
-      "    <return-join alias=\"emp\" property=\"pers.employments\"/>\n"
-      "    SELECT NAME AS {pers.*}, {emp.*}\n"
-      "    FROM PERSON pers\n"
-      "    LEFT OUTER JOIN EMPLOYMENT emp\n"
-      "        ON pers.ID = emp.PERSON_ID\n"
-      "    WHERE ID=?\n"
-      "</sql-query>]]>"
-msgstr ""
-

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/session_api.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/session_api.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/session_api.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,1354 +1,759 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-02-11T05:38:15\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: session_api.xml:29
 #, no-c-format
 msgid "Working with objects"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:31
 #, no-c-format
 msgid "Hibernate is a full object/relational mapping solution that not only shields the developer from the details of the underlying database management system, but also offers <emphasis>state management</emphasis> of objects. This is, contrary to the management of SQL <literal>statements</literal> in common JDBC/SQL persistence layers, a natural object-oriented view of persistence in Java applications."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:40
 #, no-c-format
 msgid "In other words, Hibernate application developers should always think about the <emphasis>state</emphasis> of their objects, and not necessarily about the execution of SQL statements. This part is taken care of by Hibernate and is only relevant for the application developer when tuning the performance of the system."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:48
 #, no-c-format
 msgid "Hibernate object states"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:50
 #, no-c-format
 msgid "Hibernate defines and supports the following object states:"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:56
 #, no-c-format
 msgid "<emphasis>Transient</emphasis> - an object is transient if it has just been instantiated using the <literal>new</literal> operator, and it is not associated with a Hibernate <literal>Session</literal>. It has no persistent representation in the database and no identifier value has been assigned. Transient instances will be destroyed by the garbage collector if the application does not hold a reference anymore. Use the Hibernate <literal>Session</literal> to make an object persistent (and let Hibernate take care of the SQL statements that need to be executed for this transition)."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:68
 #, no-c-format
 msgid "<emphasis>Persistent</emphasis> - a persistent instance has a representation in the database and an identifier value. It might just have been saved or loaded, however, it is by definition in the scope of a <literal>Session</literal>. Hibernate will detect any changes made to an object in persistent state and synchronize the state with the database when the unit of work completes. Developers do not execute manual <literal>UPDATE</literal> statements, or <literal>DELETE</literal> statements when an object should be made transient."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:79
 #, no-c-format
 msgid "<emphasis>Detached</emphasis> - a detached instance is an object that has been persistent, but its <literal>Session</literal> has been closed. The reference to the object is still valid, of course, and the detached instance might even be modified in this state. A detached instance can be reattached to a new <literal>Session</literal> at a later point in time, making it (and all the modifications) persistent again. This feature enables a programming model for long running units of work that require user think-time. We call them <emphasis>application transactions</emphasis>, i.e., a unit of work from the point of view of the user."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:93
 #, no-c-format
 msgid "We will now discuss the states and state transitions (and the Hibernate methods that trigger a transition) in more detail."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:101
 #, no-c-format
 msgid "Making objects persistent"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:103
 #, no-c-format
 msgid "Newly instantiated instances of a a persistent class are considered <emphasis>transient</emphasis> by Hibernate. We can make a transient instance <emphasis>persistent</emphasis> by associating it with a session:"
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:110
-#, no-c-format
-msgid ""
-      "<![CDATA[DomesticCat fritz = new DomesticCat();\n"
-      "fritz.setColor(Color.GINGER);\n"
-      "fritz.setSex('M');\n"
-      "fritz.setName(\"Fritz\");\n"
-      "Long generatedId = (Long) sess.save(fritz);]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:112
 #, no-c-format
 msgid "If <literal>Cat</literal> has a generated identifier, the identifier is generated and assigned to the <literal>cat</literal> when <literal>save()</literal> is called. If <literal>Cat</literal> has an <literal>assigned</literal> identifier, or a composite key, the identifier should be assigned to the <literal>cat</literal> instance before calling <literal>save()</literal>. You can also use <literal>persist()</literal> instead of <literal>save()</literal>, with the semantics defined in the EJB3 early draft."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:124
 #, no-c-format
 msgid "<literal>persist()</literal> makes a transient instance persistent. However, it does not guarantee that the identifier value will be assigned to the persistent instance immediately, the assignment might happen at flush time. <literal>persist()</literal> also guarantees that it will not execute an <literal>INSERT</literal> statement if it is called outside of transaction boundaries. This is useful in long-running conversations with an extended Session/persistence context."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:135
 #, no-c-format
 msgid "<literal>save()</literal> does guarantee to return an identifier. If an INSERT has to be executed to get the identifier ( e.g. \"identity\" generator, not \"sequence\"), this INSERT happens immediately, no matter if you are inside or outside of a transaction. This is problematic in a long-running conversation with an extended Session/persistence context."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:145
 #, no-c-format
 msgid "Alternatively, you can assign the identifier using an overloaded version of <literal>save()</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:150
-#, no-c-format
-msgid ""
-      "<![CDATA[DomesticCat pk = new DomesticCat();\n"
-      "pk.setColor(Color.TABBY);\n"
-      "pk.setSex('F');\n"
-      "pk.setName(\"PK\");\n"
-      "pk.setKittens( new HashSet() );\n"
-      "pk.addKitten(fritz);\n"
-      "sess.save( pk, new Long(1234) );]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:152
 #, no-c-format
 msgid "If the object you make persistent has associated objects (e.g. the <literal>kittens</literal> collection in the previous example), these objects can be made persistent in any order you like unless you have a <literal>NOT NULL</literal> constraint upon a foreign key column. There is never a risk of violating foreign key constraints. However, you might violate a <literal>NOT NULL</literal> constraint if you <literal>save()</literal> the objects in the wrong order."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:162
 #, no-c-format
 msgid "Usually you do not bother with this detail, as you will normally use Hibernate's <emphasis>transitive persistence</emphasis> feature to save the associated objects automatically. Then, even <literal>NOT NULL</literal> constraint violations do not occur - Hibernate will take care of everything. Transitive persistence is discussed later in this chapter."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:173
 #, no-c-format
 msgid "Loading an object"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:175
 #, no-c-format
 msgid "The <literal>load()</literal> methods of <literal>Session</literal> provide a way of retrieving a persistent instance if you know its identifier. <literal>load()</literal> takes a class object and loads the state into a newly instantiated instance of that class in a persistent state."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:182
-#, no-c-format
-msgid "<![CDATA[Cat fritz = (Cat) sess.load(Cat.class, generatedId);]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:184
-#, no-c-format
-msgid ""
-      "<![CDATA[// you need to wrap primitive identifiers\n"
-      "long id = 1234;\n"
-      "DomesticCat pk = (DomesticCat) sess.load( DomesticCat.class, new Long(id) );]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:186
 #, no-c-format
 msgid "Alternatively, you can load state into a given instance:"
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:190
-#, no-c-format
-msgid ""
-      "<![CDATA[Cat cat = new DomesticCat();\n"
-      "// load pk's state into cat\n"
-      "sess.load( cat, new Long(pkId) );\n"
-      "Set kittens = cat.getKittens();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:192
 #, no-c-format
 msgid "Be aware that <literal>load()</literal> will throw an unrecoverable exception if there is no matching database row. If the class is mapped with a proxy, <literal>load()</literal> just returns an uninitialized proxy and does not actually hit the database until you invoke a method of the proxy. This is useful if you wish to create an association to an object without actually loading it from the database. It also allows multiple instances to be loaded as a batch if <literal>batch-size</literal> is defined for the class mapping."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:203
 #, no-c-format
 msgid "If you are not certain that a matching row exists, you should use the <literal>get()</literal> method which hits the database immediately and returns null if there is no matching row."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:209
-#, no-c-format
-msgid ""
-      "<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id);\n"
-      "if (cat==null) {\n"
-      "    cat = new Cat();\n"
-      "    sess.save(cat, id);\n"
-      "}\n"
-      "return cat;]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:211
 #, no-c-format
 msgid "You can even load an object using an SQL <literal>SELECT ... FOR UPDATE</literal>, using a <literal>LockMode</literal>. See the API documentation for more information."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:216
-#, no-c-format
-msgid "<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id, LockMode.UPGRADE);]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:218
 #, no-c-format
 msgid "Any associated instances or contained collections will <emphasis>not</emphasis> be selected <literal>FOR UPDATE</literal>, unless you decide to specify <literal>lock</literal> or <literal>all</literal> as a cascade style for the association."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:225
 #, no-c-format
 msgid "It is possible to re-load an object and all its collections at any time, using the <literal>refresh()</literal> method. This is useful when database triggers are used to initialize some of the properties of the object."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:231
-#, no-c-format
-msgid ""
-      "<![CDATA[sess.save(cat);\n"
-      "sess.flush(); //force the SQL INSERT\n"
-      "sess.refresh(cat); //re-read the state (after the trigger executes)]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:233
 #, no-c-format
-msgid "How much does Hibernate load from the database and how many SQL <literal>SELECT</literal>s will it use? This depends on the <emphasis>fetching strategy</emphasis>. This is explained in <xref linkend=\"performance-fetching\"/>."
+msgid "How much does Hibernate load from the database and how many SQL <literal>SELECT</literal>s will it use? This depends on the <emphasis>fetching strategy</emphasis>. This is explained in <xref linkend=\"performance-fetching\" />."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:243
 #, no-c-format
 msgid "Querying"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:245
 #, no-c-format
 msgid "If you do not know the identifiers of the objects you are looking for, you need a query. Hibernate supports an easy-to-use but powerful object oriented query language (HQL). For programmatic query creation, Hibernate supports a sophisticated Criteria and Example query feature (QBC and QBE). You can also express your query in the native SQL of your database, with optional support from Hibernate for result set conversion into objects."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:255
 #, no-c-format
 msgid "Executing queries"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:257
 #, no-c-format
 msgid "HQL and native SQL queries are represented with an instance of <literal>org.hibernate.Query</literal>. This interface offers methods for parameter binding, result set handling, and for the execution of the actual query. You always obtain a <literal>Query</literal> using the current <literal>Session</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:264
-#, no-c-format
-msgid ""
-      "<![CDATA[List cats = session.createQuery(\n"
-      "    \"from Cat as cat where cat.birthdate < ?\")\n"
-      "    .setDate(0, date)\n"
-      "    .list();\n"
-      "\n"
-      "List mothers = session.createQuery(\n"
-      "    \"select mother from Cat as cat join cat.mother as mother where cat.name = ?\")\n"
-      "    .setString(0, name)\n"
-      "    .list();\n"
-      "\n"
-      "List kittens = session.createQuery(\n"
-      "    \"from Cat as cat where cat.mother = ?\")\n"
-      "    .setEntity(0, pk)\n"
-      "    .list();\n"
-      "\n"
-      "Cat mother = (Cat) session.createQuery(\n"
-      "    \"select cat.mother from Cat as cat where cat = ?\")\n"
-      "    .setEntity(0, izi)\n"
-      "    .uniqueResult();]]\n"
-      "\n"
-      "Query mothersWithKittens = (Cat) session.createQuery(\n"
-      "    \"select mother from Cat as mother left join fetch mother.kittens\");\n"
-      "Set uniqueMothers = new HashSet(mothersWithKittens.list());]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:266
 #, no-c-format
 msgid "A query is usually executed by invoking <literal>list()</literal>. The result of the query will be loaded completely into a collection in memory. Entity instances retrieved by a query are in a persistent state. The <literal>uniqueResult()</literal> method offers a shortcut if you know your query will only return a single object. Queries that make use of eager fetching of collections usually return duplicates of the root objects, but with their collections initialized. You can filter these duplicates through a <literal>Set</literal>."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:278
 #, no-c-format
 msgid "Iterating results"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:280
 #, no-c-format
 msgid "Occasionally, you might be able to achieve better performance by executing the query using the <literal>iterate()</literal> method. This will usually be the case if you expect that the actual entity instances returned by the query will already be in the session or second-level cache. If they are not already cached, <literal>iterate()</literal> will be slower than <literal>list()</literal> and might require many database hits for a simple query, usually <emphasis>1</emphasis> for the initial select which only returns identifiers, and <emphasis>n</emphasis> additional selects to initialize the actual instances."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:292
-#, no-c-format
-msgid ""
-      "<![CDATA[// fetch ids\n"
-      "Iterator iter = sess.createQuery(\"from eg.Qux q order by q.likeliness\").iterate();\n"
-      "while ( iter.hasNext() ) {\n"
-      "    Qux qux = (Qux) iter.next();  // fetch the object\n"
-      "    // something we couldnt express in the query\n"
-      "    if ( qux.calculateComplicatedAlgorithm() ) {\n"
-      "        // delete the current instance\n"
-      "        iter.remove();\n"
-      "        // dont need to process the rest\n"
-      "        break;\n"
-      "    }\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:296
 #, no-c-format
 msgid "Queries that return tuples"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:298
 #, no-c-format
 msgid "Hibernate queries sometimes return tuples of objects. Each tuple is returned as an array:"
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:303
-#, no-c-format
-msgid ""
-      "<![CDATA[Iterator kittensAndMothers = sess.createQuery(\n"
-      "            \"select kitten, mother from Cat kitten join kitten.mother mother\")\n"
-      "            .list()\n"
-      "            .iterator();\n"
-      "\n"
-      "while ( kittensAndMothers.hasNext() ) {\n"
-      "    Object[] tuple = (Object[]) kittensAndMothers.next();\n"
-      "    Cat kitten = (Cat) tuple[0];\n"
-      "    Cat mother = (Cat) tuple[1];\n"
-      "    ....\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:308
 #, no-c-format
 msgid "Scalar results"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:310
 #, no-c-format
 msgid "Queries can specify a property of a class in the <literal>select</literal> clause. They can even call SQL aggregate functions. Properties or aggregates are considered \"scalar\" results and not entities in persistent state."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:316
-#, no-c-format
-msgid ""
-      "<![CDATA[Iterator results = sess.createQuery(\n"
-      "        \"select cat.color, min(cat.birthdate), count(cat) from Cat cat \" +\n"
-      "        \"group by cat.color\")\n"
-      "        .list()\n"
-      "        .iterator();\n"
-      "\n"
-      "while ( results.hasNext() ) {\n"
-      "    Object[] row = (Object[]) results.next();\n"
-      "    Color type = (Color) row[0];\n"
-      "    Date oldest = (Date) row[1];\n"
-      "    Integer count = (Integer) row[2];\n"
-      "    .....\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:321
 #, no-c-format
 msgid "Bind parameters"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:323
 #, no-c-format
 msgid "Methods on <literal>Query</literal> are provided for binding values to named parameters or JDBC-style <literal>?</literal> parameters. <emphasis>Contrary to JDBC, Hibernate numbers parameters from zero.</emphasis> Named parameters are identifiers of the form <literal>:name</literal> in the query string. The advantages of named parameters are as follows:"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:333
 #, no-c-format
 msgid "named parameters are insensitive to the order they occur in the query string"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:339
 #, no-c-format
 msgid "they can occur multiple times in the same query"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:344
 #, no-c-format
 msgid "they are self-documenting"
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:350
-#, no-c-format
-msgid ""
-      "<![CDATA[//named parameter (preferred)\n"
-      "Query q = sess.createQuery(\"from DomesticCat cat where cat.name = :name\");\n"
-      "q.setString(\"name\", \"Fritz\");\n"
-      "Iterator cats = q.iterate();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:352
-#, no-c-format
-msgid ""
-      "<![CDATA[//positional parameter\n"
-      "Query q = sess.createQuery(\"from DomesticCat cat where cat.name = ?\");\n"
-      "q.setString(0, \"Izi\");\n"
-      "Iterator cats = q.iterate();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:354
-#, no-c-format
-msgid ""
-      "<![CDATA[//named parameter list\n"
-      "List names = new ArrayList();\n"
-      "names.add(\"Izi\");\n"
-      "names.add(\"Fritz\");\n"
-      "Query q = sess.createQuery(\"from DomesticCat cat where cat.name in (:namesList)\");\n"
-      "q.setParameterList(\"namesList\", names);\n"
-      "List cats = q.list();]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:359
 #, no-c-format
 msgid "Pagination"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:361
 #, no-c-format
 msgid "If you need to specify bounds upon your result set, that is, the maximum number of rows you want to retrieve and/or the first row you want to retrieve, you can use methods of the <literal>Query</literal> interface:"
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:367
-#, no-c-format
-msgid ""
-      "<![CDATA[Query q = sess.createQuery(\"from DomesticCat cat\");\n"
-      "q.setFirstResult(20);\n"
-      "q.setMaxResults(10);\n"
-      "List cats = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:369
 #, no-c-format
 msgid "Hibernate knows how to translate this limit query into the native SQL of your DBMS."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:377
 #, no-c-format
 msgid "Scrollable iteration"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:379
 #, no-c-format
 msgid "If your JDBC driver supports scrollable <literal>ResultSet</literal>s, the <literal>Query</literal> interface can be used to obtain a <literal>ScrollableResults</literal> object that allows flexible navigation of the query results."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:386
-#, no-c-format
-msgid ""
-      "<![CDATA[Query q = sess.createQuery(\"select cat.name, cat from DomesticCat cat \" +\n"
-      "                            \"order by cat.name\");\n"
-      "ScrollableResults cats = q.scroll();\n"
-      "if ( cats.first() ) {\n"
-      "\n"
-      "    // find the first name on each page of an alphabetical list of cats by name\n"
-      "    firstNamesOfPages = new ArrayList();\n"
-      "    do {\n"
-      "        String name = cats.getString(0);\n"
-      "        firstNamesOfPages.add(name);\n"
-      "    }\n"
-      "    while ( cats.scroll(PAGE_SIZE) );\n"
-      "\n"
-      "    // Now get the first page of cats\n"
-      "    pageOfCats = new ArrayList();\n"
-      "    cats.beforeFirst();\n"
-      "    int i=0;\n"
-      "    while( ( PAGE_SIZE > i++ ) && cats.next() ) pageOfCats.add( cats.get(1) );\n"
-      "\n"
-      "}\n"
-      "cats.close()]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:388
 #, no-c-format
 msgid "Note that an open database connection and cursor is required for this functionality. Use <literal>setMaxResult()</literal>/<literal>setFirstResult()</literal> if you need offline pagination functionality."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:397
 #, no-c-format
 msgid "Externalizing named queries"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:399
 #, no-c-format
 msgid "You can also define named queries in the mapping document. Remember to use a <literal>CDATA</literal> section if your query contains characters that could be interpreted as markup."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:405
-#, no-c-format
-msgid ""
-      "<![CDATA[<query name=\"ByNameAndMaximumWeight\"><![CDATA[\n"
-      "    from eg.DomesticCat as cat\n"
-      "        where cat.name = ?\n"
-      "        and cat.weight > ?\n"
-      "] ]></query>]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:407
 #, no-c-format
 msgid "Parameter binding and executing is done programatically:"
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:411
-#, no-c-format
-msgid ""
-      "<![CDATA[Query q = sess.getNamedQuery(\"ByNameAndMaximumWeight\");\n"
-      "q.setString(0, name);\n"
-      "q.setInt(1, minWeight);\n"
-      "List cats = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:413
 #, no-c-format
 msgid "The actual program code is independent of the query language that is used. You can also define native SQL queries in metadata, or migrate existing queries to Hibernate by placing them in mapping files."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:419
 #, no-c-format
 msgid "Also note that a query declaration inside a <literal>&lt;hibernate-mapping&gt;</literal> element requires a global unique name for the query, while a query declaration inside a <literal>&lt;class&gt;</literal> element is made unique automatically by prepending the fully qualified name of the class. For example <literal>eg.Cat.ByNameAndMaximumWeight</literal>."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:432
 #, no-c-format
 msgid "Filtering collections"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:433
 #, no-c-format
 msgid "A collection <emphasis>filter</emphasis> is a special type of query that can be applied to a persistent collection or array. The query string can refer to <literal>this</literal>, meaning the current collection element."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:439
-#, no-c-format
-msgid ""
-      "<![CDATA[Collection blackKittens = session.createFilter(\n"
-      "    pk.getKittens(), \n"
-      "    \"where this.color = ?\")\n"
-      "    .setParameter( Color.BLACK, Hibernate.custom(ColorUserType.class) )\n"
-      "    .list()\n"
-      ");]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:441
 #, no-c-format
 msgid "The returned collection is considered a bag that is a copy of the given collection. The original collection is not modified. This is contrary to the implication of the name \"filter\", but consistent with expected behavior."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:447
 #, no-c-format
 msgid "Observe that filters do not require a <literal>from</literal> clause, although they can have one if required. Filters are not limited to returning the collection elements themselves."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:452
-#, no-c-format
-msgid ""
-      "<![CDATA[Collection blackKittenMates = session.createFilter(\n"
-      "    pk.getKittens(), \n"
-      "    \"select this.mate where this.color = eg.Color.BLACK.intValue\")\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:454
 #, no-c-format
 msgid "Even an empty filter query is useful, e.g. to load a subset of elements in a large collection:"
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:459
-#, no-c-format
-msgid ""
-      "<![CDATA[Collection tenKittens = session.createFilter(\n"
-      "    mother.getKittens(), \"\")\n"
-      "    .setFirstResult(0).setMaxResults(10)\n"
-      "    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:464
 #, no-c-format
 msgid "Criteria queries"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:466
 #, no-c-format
 msgid "HQL is extremely powerful, but some developers prefer to build queries dynamically using an object-oriented API, rather than building query strings. Hibernate provides an intuitive <literal>Criteria</literal> query API for these cases:"
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:472
-#, no-c-format
-msgid ""
-      "<![CDATA[Criteria crit = session.createCriteria(Cat.class);\n"
-      "crit.add( Restrictions.eq( \"color\", eg.Color.BLACK ) );\n"
-      "crit.setMaxResults(10);\n"
-      "List cats = crit.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:474
 #, no-c-format
-msgid "The <literal>Criteria</literal> and the associated <literal>Example</literal> API are discussed in more detail in <xref linkend=\"querycriteria\"/>."
+msgid "The <literal>Criteria</literal> and the associated <literal>Example</literal> API are discussed in more detail in <xref linkend=\"querycriteria\" />."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:482
 #, no-c-format
 msgid "Queries in native SQL"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:484
 #, no-c-format
 msgid "You can express a query in SQL, using <literal>createSQLQuery()</literal> and let Hibernate manage the mapping from result sets to objects. You can at any time call <literal>session.connection()</literal> and use the JDBC <literal>Connection</literal> directly. If you choose to use the Hibernate API, you must enclose SQL aliases in braces:"
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:492
-#, no-c-format
-msgid ""
-      "<![CDATA[List cats = session.createSQLQuery(\"SELECT {cat.*} FROM CAT {cat} WHERE ROWNUM<10\")\n"
-      "    .addEntity(\"cat\", Cat.class)\n"
-      ".list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:494
-#, no-c-format
-msgid ""
-      "<![CDATA[List cats = session.createSQLQuery(\n"
-      "    \"SELECT {cat}.ID AS {cat.id}, {cat}.SEX AS {cat.sex}, \" +\n"
-      "           \"{cat}.MATE AS {cat.mate}, {cat}.SUBCLASS AS {cat.class}, ... \" +\n"
-      "    \"FROM CAT {cat} WHERE ROWNUM<10\")\n"
-      "    .addEntity(\"cat\", Cat.class)\n"
-      ".list()]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:496
 #, no-c-format
-msgid "SQL queries can contain named and positional parameters, just like Hibernate queries. More information about native SQL queries in Hibernate can be found in <xref linkend=\"querysql\"/>."
+msgid "SQL queries can contain named and positional parameters, just like Hibernate queries. More information about native SQL queries in Hibernate can be found in <xref linkend=\"querysql\" />."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:507
 #, no-c-format
 msgid "Modifying persistent objects"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:509
 #, no-c-format
 msgid "<emphasis>Transactional persistent instances</emphasis> (i.e. objects loaded, saved, created or queried by the <literal>Session</literal>) can be manipulated by the application, and any changes to persistent state will be persisted when the <literal>Session</literal> is <emphasis>flushed</emphasis>. This is discussed later in this chapter. There is no need to call a particular method (like <literal>update()</literal>, which has a different purpose) to make your modifications persistent. The most straightforward way to update the state of an object is to <literal>load()</literal> it and then manipulate it directly while the <literal>Session</literal> is open:"
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:520
-#, no-c-format
-msgid ""
-      "<![CDATA[DomesticCat cat = (DomesticCat) sess.load( Cat.class, new Long(69) );\n"
-      "cat.setName(\"PK\");\n"
-      "sess.flush();  // changes to cat are automatically detected and persisted]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:522
 #, no-c-format
 msgid "Sometimes this programming model is inefficient, as it requires in the same session both an SQL <literal>SELECT</literal> to load an object and an SQL <literal>UPDATE</literal> to persist its updated state. Hibernate offers an alternate approach by using detached instances."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:529
 #, no-c-format
-msgid "Hibernate does not offer its own API for direct execution of <literal>UPDATE</literal> or <literal>DELETE</literal> statements. Hibernate is a <emphasis>state management</emphasis> service, you do not have to think in <emphasis>statements</emphasis> to use it. JDBC is a perfect API for executing SQL statements, you can get a JDBC <literal>Connection</literal> at any time by calling <literal>session.connection()</literal>. Furthermore, the notion of mass operations conflicts with object/relational mapping for online transaction processing-oriented applications. Future versions of Hibernate can, however, provide special mass operation functions. See <xref linkend=\"batch\"/> for some possible batch operation tricks."
+msgid "Hibernate does not offer its own API for direct execution of <literal>UPDATE</literal> or <literal>DELETE</literal> statements. Hibernate is a <emphasis>state management</emphasis> service, you do not have to think in <emphasis>statements</emphasis> to use it. JDBC is a perfect API for executing SQL statements, you can get a JDBC <literal>Connection</literal> at any time by calling <literal>session.connection()</literal>. Furthermore, the notion of mass operations conflicts with object/relational mapping for online transaction processing-oriented applications. Future versions of Hibernate can, however, provide special mass operation functions. See <xref linkend=\"batch\" /> for some possible batch operation tricks."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:546
 #, no-c-format
 msgid "Modifying detached objects"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:548
 #, no-c-format
 msgid "Many applications need to retrieve an object in one transaction, send it to the UI layer for manipulation, then save the changes in a new transaction. Applications that use this kind of approach in a high-concurrency environment usually use versioned data to ensure isolation for the \"long\" unit of work."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:555
 #, no-c-format
 msgid "Hibernate supports this model by providing for reattachment of detached instances using the <literal>Session.update()</literal> or <literal>Session.merge()</literal> methods:"
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:561
-#, no-c-format
-msgid ""
-      "<![CDATA[// in the first session\n"
-      "Cat cat = (Cat) firstSession.load(Cat.class, catId);\n"
-      "Cat potentialMate = new Cat();\n"
-      "firstSession.save(potentialMate);\n"
-      "\n"
-      "// in a higher layer of the application\n"
-      "cat.setMate(potentialMate);\n"
-      "\n"
-      "// later, in a new session\n"
-      "secondSession.update(cat);  // update cat\n"
-      "secondSession.update(mate); // update mate]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:563
 #, no-c-format
 msgid "If the <literal>Cat</literal> with identifier <literal>catId</literal> had already been loaded by <literal>secondSession</literal> when the application tried to reattach it, an exception would have been thrown."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:569
 #, no-c-format
 msgid "Use <literal>update()</literal> if you are certain that the session does not contain an already persistent instance with the same identifier. Use <literal>merge()</literal> if you want to merge your modifications at any time without consideration of the state of the session. In other words, <literal>update()</literal> is usually the first method you would call in a fresh session, ensuring that the reattachment of your detached instances is the first operation that is executed."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:578
 #, no-c-format
-msgid "The application should individually <literal>update()</literal> detached instances that are reachable from the given detached instance <emphasis>only</emphasis> if it wants their state to be updated. This can be automated using <emphasis>transitive persistence</emphasis>. See <xref linkend=\"objectstate-transitive\"/> for more information."
+msgid "The application should individually <literal>update()</literal> detached instances that are reachable from the given detached instance <emphasis>only</emphasis> if it wants their state to be updated. This can be automated using <emphasis>transitive persistence</emphasis>. See <xref linkend=\"objectstate-transitive\" /> for more information."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:585
 #, no-c-format
 msgid "The <literal>lock()</literal> method also allows an application to reassociate an object with a new session. However, the detached instance has to be unmodified."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:590
-#, no-c-format
-msgid ""
-      "<![CDATA[//just reassociate:\n"
-      "sess.lock(fritz, LockMode.NONE);\n"
-      "//do a version check, then reassociate:\n"
-      "sess.lock(izi, LockMode.READ);\n"
-      "//do a version check, using SELECT ... FOR UPDATE, then reassociate:\n"
-      "sess.lock(pk, LockMode.UPGRADE);]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:592
 #, no-c-format
 msgid "Note that <literal>lock()</literal> can be used with various <literal>LockMode</literal>s. See the API documentation and the chapter on transaction handling for more information. Reattachment is not the only usecase for <literal>lock()</literal>."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:599
 #, no-c-format
-msgid "Other models for long units of work are discussed in <xref linkend=\"transactions-optimistic\"/>."
+msgid "Other models for long units of work are discussed in <xref linkend=\"transactions-optimistic\" />."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:606
 #, no-c-format
 msgid "Automatic state detection"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:608
 #, no-c-format
 msgid "Hibernate users have requested a general purpose method that either saves a transient instance by generating a new identifier or updates/reattaches the detached instances associated with its current identifier. The <literal>saveOrUpdate()</literal> method implements this functionality."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:615
-#, no-c-format
-msgid ""
-      "<![CDATA[// in the first session\n"
-      "Cat cat = (Cat) firstSession.load(Cat.class, catID);\n"
-      "\n"
-      "// in a higher tier of the application\n"
-      "Cat mate = new Cat();\n"
-      "cat.setMate(mate);\n"
-      "\n"
-      "// later, in a new session\n"
-      "secondSession.saveOrUpdate(cat);   // update existing state (cat has a non-null id)\n"
-      "secondSession.saveOrUpdate(mate);  // save the new instance (mate has a null id)]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:617
 #, no-c-format
 msgid "The usage and semantics of <literal>saveOrUpdate()</literal> seems to be confusing for new users. Firstly, so long as you are not trying to use instances from one session in another new session, you should not need to use <literal>update()</literal>, <literal>saveOrUpdate()</literal>, or <literal>merge()</literal>. Some whole applications will never use either of these methods."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:625
 #, no-c-format
 msgid "Usually <literal>update()</literal> or <literal>saveOrUpdate()</literal> are used in the following scenario:"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:632
 #, no-c-format
 msgid "the application loads an object in the first session"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:637
 #, no-c-format
 msgid "the object is passed up to the UI tier"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:642
 #, no-c-format
 msgid "some modifications are made to the object"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:647
 #, no-c-format
 msgid "the object is passed back down to the business logic tier"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:652
 #, no-c-format
 msgid "the application persists these modifications by calling <literal>update()</literal> in a second session"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:659
 #, no-c-format
 msgid "<literal>saveOrUpdate()</literal> does the following:"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:665
 #, no-c-format
 msgid "if the object is already persistent in this session, do nothing"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:670
 #, no-c-format
 msgid "if another object associated with the session has the same identifier, throw an exception"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:676
 #, no-c-format
 msgid "if the object has no identifier property, <literal>save()</literal> it"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:681
 #, no-c-format
 msgid "if the object's identifier has the value assigned to a newly instantiated object, <literal>save()</literal> it"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:687
 #, no-c-format
 msgid "if the object is versioned by a <literal>&lt;version&gt;</literal> or <literal>&lt;timestamp&gt;</literal>, and the version property value is the same value assigned to a newly instantiated object, <literal>save()</literal> it"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:695
 #, no-c-format
 msgid "otherwise <literal>update()</literal> the object"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:701
 #, no-c-format
 msgid "and <literal>merge()</literal> is very different:"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:707
 #, no-c-format
 msgid "if there is a persistent instance with the same identifier currently associated with the session, copy the state of the given object onto the persistent instance"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:714
 #, no-c-format
 msgid "if there is no persistent instance currently associated with the session, try to load it from the database, or create a new persistent instance"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:720
 #, no-c-format
 msgid "the persistent instance is returned"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:725
 #, no-c-format
 msgid "the given instance does not become associated with the session, it remains detached"
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:735
 #, no-c-format
 msgid "Deleting persistent objects"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:737
 #, no-c-format
 msgid "<literal>Session.delete()</literal> will remove an object's state from the database. Your application, however, can still hold a reference to a deleted object. It is best to think of <literal>delete()</literal> as making a persistent instance, transient."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:744
-#, no-c-format
-msgid "<![CDATA[sess.delete(cat);]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:746
 #, no-c-format
 msgid "You can delete objects in any order, without risk of foreign key constraint violations. It is still possible to violate a <literal>NOT NULL</literal> constraint on a foreign key column by deleting objects in the wrong order, e.g. if you delete the parent, but forget to delete the children."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:757
 #, no-c-format
 msgid "Replicating object between two different datastores"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:759
 #, no-c-format
 msgid "It is sometimes useful to be able to take a graph of persistent instances and make them persistent in a different datastore, without regenerating identifier values."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:765
-#, no-c-format
-msgid ""
-      "<![CDATA[//retrieve a cat from one database\n"
-      "Session session1 = factory1.openSession();\n"
-      "Transaction tx1 = session1.beginTransaction();\n"
-      "Cat cat = session1.get(Cat.class, catId);\n"
-      "tx1.commit();\n"
-      "session1.close();\n"
-      "\n"
-      "//reconcile with a second database\n"
-      "Session session2 = factory2.openSession();\n"
-      "Transaction tx2 = session2.beginTransaction();\n"
-      "session2.replicate(cat, ReplicationMode.LATEST_VERSION);\n"
-      "tx2.commit();\n"
-      "session2.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:767
 #, no-c-format
 msgid "The <literal>ReplicationMode</literal> determines how <literal>replicate()</literal> will deal with conflicts with existing rows in the database:"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:774
 #, no-c-format
 msgid "<literal>ReplicationMode.IGNORE</literal>: ignores the object when there is an existing database row with the same identifier"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:780
 #, no-c-format
 msgid "<literal>ReplicationMode.OVERWRITE</literal>: overwrites any existing database row with the same identifier"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:786
 #, no-c-format
 msgid "<literal>ReplicationMode.EXCEPTION</literal>: throws an exception if there is an existing database row with the same identifier"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:792
 #, no-c-format
 msgid "<literal>ReplicationMode.LATEST_VERSION</literal>: overwrites the row if its version number is earlier than the version number of the object, or ignore the object otherwise"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:800
 #, no-c-format
 msgid "Usecases for this feature include reconciling data entered into different database instances, upgrading system configuration information during product upgrades, rolling back changes made during non-ACID transactions and more."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:809
 #, no-c-format
 msgid "Flushing the Session"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:811
 #, no-c-format
 msgid "Sometimes the <literal>Session</literal> will execute the SQL statements needed to synchronize the JDBC connection's state with the state of objects held in memory. This process, called <emphasis>flush</emphasis>, occurs by default at the following points:"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:820
 #, no-c-format
 msgid "before some query executions"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:825
 #, no-c-format
 msgid "from <literal>org.hibernate.Transaction.commit()</literal>"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:830
 #, no-c-format
 msgid "from <literal>Session.flush()</literal>"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:836
 #, no-c-format
 msgid "The SQL statements are issued in the following order:"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:842
 #, no-c-format
 msgid "all entity insertions in the same order the corresponding objects were saved using <literal>Session.save()</literal>"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:848
 #, no-c-format
 msgid "all entity updates"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:853
 #, no-c-format
 msgid "all collection deletions"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:858
 #, no-c-format
 msgid "all collection element deletions, updates and insertions"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:863
 #, no-c-format
 msgid "all collection insertions"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:868
 #, no-c-format
 msgid "all entity deletions in the same order the corresponding objects were deleted using <literal>Session.delete()</literal>"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:875
 #, no-c-format
 msgid "An exception is that objects using <literal>native</literal> ID generation are inserted when they are saved."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:880
 #, no-c-format
 msgid "Except when you explicitly <literal>flush()</literal>, there are absolutely no guarantees about <emphasis>when</emphasis> the <literal>Session</literal> executes the JDBC calls, only the <emphasis>order</emphasis> in which they are executed. However, Hibernate does guarantee that the <literal>Query.list(..)</literal> will never return stale or incorrect data."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:888
 #, no-c-format
-msgid "It is possible to change the default behavior so that flush occurs less frequently. The <literal>FlushMode</literal> class defines three different modes: only flush at commit time when the Hibernate <literal>Transaction</literal> API is used, flush automatically using the explained routine, or never flush unless <literal>flush()</literal> is called explicitly. The last mode is useful for long running units of work, where a <literal>Session</literal> is kept open and disconnected for a long time (see <xref linkend=\"transactions-optimistic-longsession\"/>)."
+msgid "It is possible to change the default behavior so that flush occurs less frequently. The <literal>FlushMode</literal> class defines three different modes: only flush at commit time when the Hibernate <literal>Transaction</literal> API is used, flush automatically using the explained routine, or never flush unless <literal>flush()</literal> is called explicitly. The last mode is useful for long running units of work, where a <literal>Session</literal> is kept open and disconnected for a long time (see <xref linkend=\"transactions-optimistic-longsession\" />)."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:898
-#, no-c-format
-msgid ""
-      "<![CDATA[sess = sf.openSession();\n"
-      "Transaction tx = sess.beginTransaction();\n"
-      "sess.setFlushMode(FlushMode.COMMIT); // allow queries to return stale state\n"
-      "\n"
-      "Cat izi = (Cat) sess.load(Cat.class, id);\n"
-      "izi.setName(iznizi);\n"
-      "\n"
-      "// might return stale data\n"
-      "sess.find(\"from Cat as cat left outer join cat.kittens kitten\");\n"
-      "\n"
-      "// change to izi is not flushed!\n"
-      "...\n"
-      "tx.commit(); // flush occurs\n"
-      "sess.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:900
 #, no-c-format
-msgid "During flush, an exception might occur (e.g. if a DML operation violates a constraint). Since handling exceptions involves some understanding of Hibernate's transactional behavior, we discuss it in <xref linkend=\"transactions\"/>."
+msgid "During flush, an exception might occur (e.g. if a DML operation violates a constraint). Since handling exceptions involves some understanding of Hibernate's transactional behavior, we discuss it in <xref linkend=\"transactions\" />."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:909
 #, no-c-format
 msgid "Transitive persistence"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:911
 #, no-c-format
 msgid "It is quite cumbersome to save, delete, or reattach individual objects, especially if you deal with a graph of associated objects. A common case is a parent/child relationship. Consider the following example:"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:917
 #, no-c-format
 msgid "If the children in a parent/child relationship would be value typed (e.g. a collection of addresses or strings), their life cycle would depend on the parent and no further action would be required for convenient \"cascading\" of state changes. When the parent is saved, the value-typed child objects are saved and when the parent is deleted, the children will be deleted, etc. This works for operations such as the removal of a child from the collection. Since value-typed objects cannot have shared references, Hibernate will detect this and delete the child from the database."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:928
 #, no-c-format
 msgid "Now consider the same scenario with parent and child objects being entities, not value-types (e.g. categories and items, or parent and child cats). Entities have their own life cycle and support shared references. Removing an entity from the collection does not mean it can be deleted), and there is by default no cascading of state from one entity to any other associated entities. Hibernate does not implement <emphasis>persistence by reachability</emphasis> by default."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:937
 #, no-c-format
 msgid "For each basic operation of the Hibernate session - including <literal>persist(), merge(), saveOrUpdate(), delete(), lock(), refresh(), evict(), replicate()</literal> - there is a corresponding cascade style. Respectively, the cascade styles are named <literal>create, merge, save-update, delete, lock, refresh, evict, replicate</literal>. If you want an operation to be cascaded along an association, you must indicate that in the mapping document. For example:"
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:946
-#, no-c-format
-msgid "<![CDATA[<one-to-one name=\"person\" cascade=\"persist\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:948
 #, no-c-format
 msgid "Cascade styles my be combined:"
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:952
-#, no-c-format
-msgid "<![CDATA[<one-to-one name=\"person\" cascade=\"persist,delete,lock\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:954
 #, no-c-format
 msgid "You can even use <literal>cascade=\"all\"</literal> to specify that <emphasis>all</emphasis> operations should be cascaded along the association. The default <literal>cascade=\"none\"</literal> specifies that no operations are to be cascaded."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:960
 #, no-c-format
 msgid "A special cascade style, <literal>delete-orphan</literal>, applies only to one-to-many associations, and indicates that the <literal>delete()</literal> operation should be applied to any child object that is removed from the association."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:967
 #, no-c-format
 msgid "Recommendations:"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:973
 #, no-c-format
 msgid "It does not usually make sense to enable cascade on a <literal>&lt;many-to-one&gt;</literal> or <literal>&lt;many-to-many&gt;</literal> association. Cascade is often useful for <literal>&lt;one-to-one&gt;</literal> and <literal>&lt;one-to-many&gt;</literal> associations."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:981
 #, no-c-format
 msgid "If the child object's lifespan is bounded by the lifespan of the parent object, make it a <emphasis>life cycle object</emphasis> by specifying <literal>cascade=\"all,delete-orphan\"</literal>."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:988
 #, no-c-format
 msgid "Otherwise, you might not need cascade at all. But if you think that you will often be working with the parent and children together in the same transaction, and you want to save yourself some typing, consider using <literal>cascade=\"persist,merge,save-update\"</literal>."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:996
 #, no-c-format
 msgid "Mapping an association (either a single valued association, or a collection) with <literal>cascade=\"all\"</literal> marks the association as a <emphasis>parent/child</emphasis> style relationship where save/update/delete of the parent results in save/update/delete of the child or children."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:1002
 #, no-c-format
 msgid "Furthermore, a mere reference to a child from a persistent parent will result in save/update of the child. This metaphor is incomplete, however. A child which becomes unreferenced by its parent is <emphasis>not</emphasis> automatically deleted, except in the case of a <literal>&lt;one-to-many&gt;</literal> association mapped with <literal>cascade=\"delete-orphan\"</literal>. The precise semantics of cascading operations for a parent/child relationship are as follows:"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:1013
 #, no-c-format
 msgid "If a parent is passed to <literal>persist()</literal>, all children are passed to <literal>persist()</literal>"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:1019
 #, no-c-format
 msgid "If a parent is passed to <literal>merge()</literal>, all children are passed to <literal>merge()</literal>"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:1025
 #, no-c-format
 msgid "If a parent is passed to <literal>save()</literal>, <literal>update()</literal> or <literal>saveOrUpdate()</literal>, all children are passed to <literal>saveOrUpdate()</literal>"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:1031
 #, no-c-format
 msgid "If a transient or detached child becomes referenced by a persistent parent, it is passed to <literal>saveOrUpdate()</literal>"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:1037
 #, no-c-format
 msgid "If a parent is deleted, all children are passed to <literal>delete()</literal>"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:1042
 #, no-c-format
 msgid "If a child is dereferenced by a persistent parent, <emphasis>nothing special happens</emphasis> - the application should explicitly delete the child if necessary - unless <literal>cascade=\"delete-orphan\"</literal>, in which case the \"orphaned\" child is deleted."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:1051
 #, no-c-format
 msgid "Finally, note that cascading of operations can be applied to an object graph at <emphasis>call time</emphasis> or at <emphasis>flush time</emphasis>. All operations, if enabled, are cascaded to associated entities reachable when the operation is executed. However, <literal>save-update</literal> and <literal>delete-orphan</literal> are transitive for all associated entities reachable during flush of the <literal>Session</literal>."
 msgstr ""
 
 #. Tag: title
-#: session_api.xml:1063
 #, no-c-format
 msgid "Using metadata"
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:1065
 #, no-c-format
 msgid "Hibernate requires a rich meta-level model of all entity and value types. This model can be useful to the application itself. For example, the application might use Hibernate's metadata to implement a \"smart\" deep-copy algorithm that understands which objects should be copied (eg. mutable value types) and which objects that should not (e.g. immutable value types and, possibly, associated entities)."
 msgstr ""
 
 #. Tag: para
-#: session_api.xml:1072
 #, no-c-format
 msgid "Hibernate exposes metadata via the <literal>ClassMetadata</literal> and <literal>CollectionMetadata</literal> interfaces and the <literal>Type</literal> hierarchy. Instances of the metadata interfaces can be obtained from the <literal>SessionFactory</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: session_api.xml:1079
-#, no-c-format
-msgid ""
-      "<![CDATA[Cat fritz = ......;\n"
-      "ClassMetadata catMeta = sessionfactory.getClassMetadata(Cat.class);\n"
-      "\n"
-      "Object[] propertyValues = catMeta.getPropertyValues(fritz);\n"
-      "String[] propertyNames = catMeta.getPropertyNames();\n"
-      "Type[] propertyTypes = catMeta.getPropertyTypes();\n"
-      "\n"
-      "// get a Map of all properties which are not collections or associations\n"
-      "Map namedValues = new HashMap();\n"
-      "for ( int i=0; i<propertyNames.length; i++ ) {\n"
-      "    if ( !propertyTypes[i].isEntityType() && !propertyTypes[i].isCollectionType() ) {\n"
-      "        namedValues.put( propertyNames[i], propertyValues[i] );\n"
-      "    }\n"
-      "}]]>"
-msgstr ""
-

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/toolset_guide.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/toolset_guide.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/toolset_guide.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,962 +1,629 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-02-11T05:38:16\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: toolset_guide.xml:29
 #, no-c-format
 msgid "Toolset Guide"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:31
 #, no-c-format
 msgid "Roundtrip engineering with Hibernate is possible using a set of Eclipse plugins, commandline tools, and Ant tasks."
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:36
 #, no-c-format
 msgid "<emphasis>Hibernate Tools</emphasis> currently include plugins for the Eclipse IDE as well as Ant tasks for reverse engineering of existing databases:"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:42
 #, no-c-format
 msgid "<emphasis>Mapping Editor:</emphasis> an editor for Hibernate XML mapping files that supports auto-completion and syntax highlighting. It also supports semantic auto-completion for class names and property/field names, making it more versatile than a normal XML editor."
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:47
 #, no-c-format
 msgid "<emphasis>Console:</emphasis> the console is a new view in Eclipse. In addition to a tree overview of your console configurations, you are also provided with an interactive view of your persistent classes and their relationships. The console allows you to execute HQL queries against your database and browse the result directly in Eclipse."
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:54
 #, no-c-format
 msgid "<emphasis>Development Wizards:</emphasis> several wizards are provided with the Hibernate Eclipse tools. You can use a wizard to quickly generate Hibernate configuration (cfg.xml) files, or to reverse engineer an existing database schema into POJO source files and Hibernate mapping files. The reverse engineering wizard supports customizable templates."
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:67
 #, no-c-format
 msgid "Please refer to the <emphasis>Hibernate Tools</emphasis> package documentation for more information."
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:72
 #, no-c-format
 msgid "However, the Hibernate main package comes bundled with an integrated tool : <emphasis>SchemaExport</emphasis> aka <literal>hbm2ddl</literal>.It can even be used from \"inside\" Hibernate."
 msgstr ""
 
 #. Tag: title
-#: toolset_guide.xml:79
 #, no-c-format
 msgid "Automatic schema generation"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:81
 #, no-c-format
 msgid "DDL can be generated from your mapping files by a Hibernate utility. The generated schema includes referential integrity constraints, primary and foreign keys, for entity and collection tables. Tables and sequences are also created for mapped identifier generators."
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:88
 #, no-c-format
 msgid "You <emphasis>must</emphasis> specify a SQL <literal>Dialect</literal> via the <literal>hibernate.dialect</literal> property when using this tool, as DDL is highly vendor-specific."
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:94
 #, no-c-format
 msgid "First, you must customize your mapping files to improve the generated schema. The next section covers schema customization."
 msgstr ""
 
 #. Tag: title
-#: toolset_guide.xml:99
 #, no-c-format
 msgid "Customizing the schema"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:101
 #, no-c-format
 msgid "Many Hibernate mapping elements define optional attributes named <literal>length</literal>, <literal>precision</literal> and <literal>scale</literal>. You can set the length, precision and scale of a column with this attribute."
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:108
-#, no-c-format
-msgid "<![CDATA[<property name=\"zip\" length=\"5\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:109
-#, no-c-format
-msgid "<![CDATA[<property name=\"balance\" precision=\"12\" scale=\"2\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:111
 #, no-c-format
 msgid "Some tags also accept a <literal>not-null</literal> attribute for generating a <literal>NOT NULL</literal> constraint on table columns, and a <literal>unique</literal> attribute for generating <literal>UNIQUE</literal> constraint on table columns."
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:117
-#, no-c-format
-msgid "<![CDATA[<many-to-one name=\"bar\" column=\"barId\" not-null=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:119
-#, no-c-format
-msgid "<![CDATA[<element column=\"serialNumber\" type=\"long\" not-null=\"true\" unique=\"true\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:121
 #, no-c-format
 msgid "A <literal>unique-key</literal> attribute can be used to group columns in a single, unique key constraint. Currently, the specified value of the <literal>unique-key</literal> attribute is <emphasis>not</emphasis> used to name the constraint in the generated DDL. It is only used to group the columns in the mapping file."
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:129
-#, no-c-format
-msgid ""
-      "<![CDATA[<many-to-one name=\"org\" column=\"orgId\" unique-key=\"OrgEmployeeId\"/>\n"
-      "<property name=\"employeeId\" unique-key=\"OrgEmployee\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:131
 #, no-c-format
 msgid "An <literal>index</literal> attribute specifies the name of an index that will be created using the mapped column or columns. Multiple columns can be grouped into the same index by simply specifying the same index name."
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:137
-#, no-c-format
-msgid ""
-      "<![CDATA[<property name=\"lastName\" index=\"CustName\"/>\n"
-      "<property name=\"firstName\" index=\"CustName\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:139
 #, no-c-format
 msgid "A <literal>foreign-key</literal> attribute can be used to override the name of any generated foreign key constraint."
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:144
-#, no-c-format
-msgid "<![CDATA[<many-to-one name=\"bar\" column=\"barId\" foreign-key=\"FKFooBar\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:146
 #, no-c-format
 msgid "Many mapping elements also accept a child <literal>&lt;column&gt;</literal> element. This is particularly useful for mapping multi-column types:"
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:151
-#, no-c-format
-msgid ""
-      "<![CDATA[<property name=\"name\" type=\"my.customtypes.Name\"/>\n"
-      "    <column name=\"last\" not-null=\"true\" index=\"bar_idx\" length=\"30\"/>\n"
-      "    <column name=\"first\" not-null=\"true\" index=\"bar_idx\" length=\"20\"/>\n"
-      "    <column name=\"initial\"/>\n"
-      "</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:153
 #, no-c-format
 msgid "The <literal>default</literal> attribute allows you to specify a default value for a column.You should assign the same value to the mapped property before saving a new instance of the mapped class."
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:159
-#, no-c-format
-msgid ""
-      "<![CDATA[<property name=\"credits\" type=\"integer\" insert=\"false\">\n"
-      "    <column name=\"credits\" default=\"10\"/>\n"
-      "</property>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:161
-#, no-c-format
-msgid ""
-      "<![CDATA[<version name=\"version\" type=\"integer\" insert=\"false\">\n"
-      "    <column name=\"version\" default=\"0\"/>\n"
-      "</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:163
 #, no-c-format
 msgid "The <literal>sql-type</literal> attribute allows the user to override the default mapping of a Hibernate type to SQL datatype."
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:168
-#, no-c-format
-msgid ""
-      "<![CDATA[<property name=\"balance\" type=\"float\">\n"
-      "    <column name=\"balance\" sql-type=\"decimal(13,3)\"/>\n"
-      "</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:170
 #, no-c-format
 msgid "The <literal>check</literal> attribute allows you to specify a check constraint."
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:174
-#, no-c-format
-msgid ""
-      "<![CDATA[<property name=\"foo\" type=\"integer\">\n"
-      "    <column name=\"foo\" check=\"foo > 10\"/>\n"
-      "</property>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:176
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Foo\" table=\"foos\" check=\"bar < 100.0\">\n"
-      "    ...\n"
-      "    <property name=\"bar\" type=\"float\"/>\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:179
 #, no-c-format
 msgid "The following table summarizes these optional attributes."
 msgstr ""
 
 #. Tag: title
-#: toolset_guide.xml:182
 #, no-c-format
 msgid "Summary"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:189
 #, no-c-format
 msgid "Attribute"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:190
 #, no-c-format
 msgid "Values"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:191
 #, no-c-format
 msgid "Interpretation"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:196
+#. Tag: entry
 #, no-c-format
-msgid "length"
+msgid "<literal>length</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:197 toolset_guide.xml:202 toolset_guide.xml:207
 #, no-c-format
 msgid "number"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:198
 #, no-c-format
 msgid "column length"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:201
+#. Tag: entry
 #, no-c-format
-msgid "precision"
+msgid "<literal>precision</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:203
 #, no-c-format
 msgid "column decimal precision"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:206
+#. Tag: entry
 #, no-c-format
-msgid "scale"
+msgid "<literal>scale</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:208
 #, no-c-format
 msgid "column decimal scale"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:211
+#. Tag: entry
 #, no-c-format
-msgid "not-null"
+msgid "<literal>not-null</literal>"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:212 toolset_guide.xml:217
+#. Tag: entry
 #, no-c-format
-msgid "true|false"
+msgid "<literal>true|false</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:213
 #, no-c-format
 msgid "specifies that the column should be non-nullable"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:216
+#. Tag: entry
 #, no-c-format
-msgid "unique"
+msgid "<literal>unique</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:218
 #, no-c-format
 msgid "specifies that the column should have a unique constraint"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:221
+#. Tag: entry
 #, no-c-format
-msgid "index"
+msgid "<literal>index</literal>"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:222
+#. Tag: entry
 #, no-c-format
-msgid "index_name"
+msgid "<literal>index_name</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:223
 #, no-c-format
 msgid "specifies the name of a (multi-column) index"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:226
+#. Tag: entry
 #, no-c-format
-msgid "unique-key"
+msgid "<literal>unique-key</literal>"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:227
+#. Tag: entry
 #, no-c-format
-msgid "unique_key_name"
+msgid "<literal>unique_key_name</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:228
 #, no-c-format
 msgid "specifies the name of a multi-column unique constraint"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:231
+#. Tag: entry
 #, no-c-format
-msgid "foreign-key"
+msgid "<literal>foreign-key</literal>"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:232
+#. Tag: entry
 #, no-c-format
-msgid "foreign_key_name"
+msgid "<literal>foreign_key_name</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:233
 #, no-c-format
 msgid "specifies the name of the foreign key constraint generated for an association, for a <literal>&lt;one-to-one&gt;</literal>, <literal>&lt;many-to-one&gt;</literal>, <literal>&lt;key&gt;</literal>, or <literal>&lt;many-to-many&gt;</literal> mapping element. Note that <literal>inverse=\"true\"</literal> sides will not be considered by <literal>SchemaExport</literal>."
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:243
+#. Tag: entry
 #, no-c-format
-msgid "sql-type"
+msgid "<literal>sql-type</literal>"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:244
+#. Tag: entry
 #, no-c-format
-msgid "SQL column type"
+msgid "<literal>SQL column type</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:245
 #, no-c-format
 msgid "overrides the default column type (attribute of <literal>&lt;column&gt;</literal> element only)"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:251
+#. Tag: entry
 #, no-c-format
-msgid "default"
+msgid "<literal>default</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:252 toolset_guide.xml:259
 #, no-c-format
 msgid "SQL expression"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:253
 #, no-c-format
 msgid "specify a default value for the column"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:258
+#. Tag: entry
 #, no-c-format
-msgid "check"
+msgid "<literal>check</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:260
 #, no-c-format
 msgid "create an SQL check constraint on either column or table"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:268
 #, no-c-format
 msgid "The <literal>&lt;comment&gt;</literal> element allows you to specify comments for the generated schema."
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:273
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Customer\" table=\"CurCust\">\n"
-      "    <comment>Current customers only</comment>\n"
-      "    ...\n"
-      "</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:275
-#, no-c-format
-msgid ""
-      "<![CDATA[<property name=\"balance\">\n"
-      "    <column name=\"bal\">\n"
-      "        <comment>Balance in USD</comment>\n"
-      "    </column>\n"
-      "</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:277
 #, no-c-format
 msgid "This results in a <literal>comment on table</literal> or <literal>comment on column</literal> statement in the generated DDL where supported."
 msgstr ""
 
 #. Tag: title
-#: toolset_guide.xml:286
 #, no-c-format
 msgid "Running the tool"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:288
 #, no-c-format
 msgid "The <literal>SchemaExport</literal> tool writes a DDL script to standard out and/or executes the DDL statements."
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:293
 #, no-c-format
 msgid "The following table displays the <literal>SchemaExport</literal> command line options"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:295
 #, no-c-format
 msgid "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> <literal>org.hibernate.tool.hbm2ddl.SchemaExport</literal> <emphasis>options mapping_files</emphasis>"
 msgstr ""
 
 #. Tag: title
-#: toolset_guide.xml:301
 #, no-c-format
 msgid "<literal>SchemaExport</literal> Command Line Options"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:307 toolset_guide.xml:457 toolset_guide.xml:527
 #, no-c-format
 msgid "Option"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:308 toolset_guide.xml:395 toolset_guide.xml:458 toolset_guide.xml:528
 #, no-c-format
 msgid "Description"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:313 toolset_guide.xml:463
+#. Tag: entry
 #, no-c-format
-msgid "--quiet"
+msgid "<literal>--quiet</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:314 toolset_guide.xml:464
 #, no-c-format
 msgid "do not output the script to stdout"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:317
+#. Tag: entry
 #, no-c-format
-msgid "--drop"
+msgid "<literal>--drop</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:318
 #, no-c-format
 msgid "only drop the tables"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:321
+#. Tag: entry
 #, no-c-format
-msgid "--create"
+msgid "<literal>--create</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:322
 #, no-c-format
 msgid "only create the tables"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:325 toolset_guide.xml:467
+#. Tag: entry
 #, no-c-format
-msgid "--text"
+msgid "<literal>--text</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:326
 #, no-c-format
 msgid "do not export to the database"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:329
+#. Tag: entry
 #, no-c-format
-msgid "--output=my_schema.ddl"
+msgid "<literal>--output=my_schema.ddl</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:330
 #, no-c-format
 msgid "output the ddl script to a file"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:333 toolset_guide.xml:471 toolset_guide.xml:533
+#. Tag: entry
 #, no-c-format
-msgid "--naming=eg.MyNamingStrategy"
+msgid "<literal>--naming=eg.MyNamingStrategy</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:334 toolset_guide.xml:472 toolset_guide.xml:534
 #, no-c-format
 msgid "select a <literal>NamingStrategy</literal>"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:337 toolset_guide.xml:479 toolset_guide.xml:541
+#. Tag: entry
 #, no-c-format
-msgid "--config=hibernate.cfg.xml"
+msgid "<literal>--config=hibernate.cfg.xml</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:338
 #, no-c-format
 msgid "read Hibernate configuration from an XML file"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:341 toolset_guide.xml:475 toolset_guide.xml:537
+#. Tag: entry
 #, no-c-format
-msgid "--properties=hibernate.properties"
+msgid "<literal>--properties=hibernate.properties</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:342 toolset_guide.xml:476 toolset_guide.xml:538
 #, no-c-format
 msgid "read database properties from a file"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:345
+#. Tag: entry
 #, no-c-format
-msgid "--format"
+msgid "<literal>--format</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:346
 #, no-c-format
 msgid "format the generated SQL nicely in the script"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:349
+#. Tag: entry
 #, no-c-format
-msgid "--delimiter=;"
+msgid "<literal>--delimiter=;</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:350
 #, no-c-format
 msgid "set an end of line delimiter for the script"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:356
 #, no-c-format
 msgid "You can even embed <literal>SchemaExport</literal> in your application:"
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:360
-#, no-c-format
-msgid ""
-      "<![CDATA[Configuration cfg = ....;\n"
-      "new SchemaExport(cfg).create(false, true);]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:365
 #, no-c-format
 msgid "Properties"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:367
 #, no-c-format
 msgid "Database properties can be specified:"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:373
 #, no-c-format
 msgid "as system properties with <literal>-D</literal><emphasis>&lt;property&gt;</emphasis>"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:376
 #, no-c-format
 msgid "in <literal>hibernate.properties</literal>"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:379
 #, no-c-format
 msgid "in a named properties file with <literal>--properties</literal>"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:383
 #, no-c-format
 msgid "The needed properties are:"
 msgstr ""
 
 #. Tag: title
-#: toolset_guide.xml:388
 #, no-c-format
 msgid "SchemaExport Connection Properties"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:394
 #, no-c-format
 msgid "Property Name"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:400
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.driver_class"
+msgid "<literal>hibernate.connection.driver_class</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:401
 #, no-c-format
 msgid "jdbc driver class"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:404
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.url"
+msgid "<literal>hibernate.connection.url</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:405
 #, no-c-format
 msgid "jdbc url"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:408
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.username"
+msgid "<literal>hibernate.connection.username</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:409
 #, no-c-format
 msgid "database user"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:412
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.password"
+msgid "<literal>hibernate.connection.password</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:413
 #, no-c-format
 msgid "user password"
 msgstr ""
 
-#. Tag: literal
-#: toolset_guide.xml:416
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.dialect"
+msgid "<literal>hibernate.dialect</literal>"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:417
 #, no-c-format
 msgid "dialect"
 msgstr ""
 
 #. Tag: title
-#: toolset_guide.xml:426
 #, no-c-format
 msgid "Using Ant"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:428
 #, no-c-format
 msgid "You can call <literal>SchemaExport</literal> from your Ant build script:"
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:432
-#, no-c-format
-msgid ""
-      "<![CDATA[<target name=\"schemaexport\">\n"
-      "    <taskdef name=\"schemaexport\"\n"
-      "        classname=\"org.hibernate.tool.hbm2ddl.SchemaExportTask\"\n"
-      "        classpathref=\"class.path\"/>\n"
-      "    \n"
-      "    <schemaexport\n"
-      "        properties=\"hibernate.properties\"\n"
-      "        quiet=\"no\"\n"
-      "        text=\"no\"\n"
-      "        drop=\"no\"\n"
-      "        delimiter=\";\"\n"
-      "        output=\"schema-export.sql\">\n"
-      "        <fileset dir=\"src\">\n"
-      "            <include name=\"**/*.hbm.xml\"/>\n"
-      "        </fileset>\n"
-      "    </schemaexport>\n"
-      "</target>]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:437
 #, no-c-format
 msgid "Incremental schema updates"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:439
 #, no-c-format
 msgid "The <literal>SchemaUpdate</literal> tool will update an existing schema with \"incremental\" changes. The <literal>SchemaUpdate</literal> depends upon the JDBC metadata API and, as such, will not work with all JDBC drivers."
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:445
 #, no-c-format
 msgid "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> <literal>org.hibernate.tool.hbm2ddl.SchemaUpdate</literal> <emphasis>options mapping_files</emphasis>"
 msgstr ""
 
 #. Tag: title
-#: toolset_guide.xml:451
 #, no-c-format
 msgid "<literal>SchemaUpdate</literal> Command Line Options"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:468
 #, no-c-format
 msgid "do not export the script to the database"
 msgstr ""
 
 #. Tag: entry
-#: toolset_guide.xml:480 toolset_guide.xml:542
 #, no-c-format
 msgid "specify a <literal>.cfg.xml</literal> file"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:486
 #, no-c-format
 msgid "You can embed <literal>SchemaUpdate</literal> in your application:"
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:490
-#, no-c-format
-msgid ""
-      "<![CDATA[Configuration cfg = ....;\n"
-      "new SchemaUpdate(cfg).execute(false);]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:495
 #, no-c-format
 msgid "Using Ant for incremental schema updates"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:497
 #, no-c-format
 msgid "You can call <literal>SchemaUpdate</literal> from the Ant script:"
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:501
-#, no-c-format
-msgid ""
-      "<![CDATA[<target name=\"schemaupdate\">\n"
-      "    <taskdef name=\"schemaupdate\"\n"
-      "        classname=\"org.hibernate.tool.hbm2ddl.SchemaUpdateTask\"\n"
-      "        classpathref=\"class.path\"/>\n"
-      "    \n"
-      "    <schemaupdate\n"
-      "        properties=\"hibernate.properties\"\n"
-      "        quiet=\"no\">\n"
-      "        <fileset dir=\"src\">\n"
-      "            <include name=\"**/*.hbm.xml\"/>\n"
-      "        </fileset>\n"
-      "    </schemaupdate>\n"
-      "</target>]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:506
 #, no-c-format
 msgid "Schema validation"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:508
 #, no-c-format
 msgid "The <literal>SchemaValidator</literal> tool will validate that the existing database schema \"matches\" your mapping documents. The <literal>SchemaValidator</literal> depends heavily upon the JDBC metadata API and, as such, will not work with all JDBC drivers. This tool is extremely useful for testing."
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:514
 #, no-c-format
 msgid "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> <literal>org.hibernate.tool.hbm2ddl.SchemaValidator</literal> <emphasis>options mapping_files</emphasis>"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:518
 #, no-c-format
 msgid "The following table displays the <literal>SchemaValidator</literal> command line options:"
 msgstr ""
 
 #. Tag: title
-#: toolset_guide.xml:521
 #, no-c-format
 msgid "<literal>SchemaValidator</literal> Command Line Options"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:548
 #, no-c-format
 msgid "You can embed <literal>SchemaValidator</literal> in your application:"
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:552
-#, no-c-format
-msgid ""
-      "<![CDATA[Configuration cfg = ....;\n"
-      "new SchemaValidator(cfg).validate();]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:557
 #, no-c-format
 msgid "Using Ant for schema validation"
 msgstr ""
 
 #. Tag: para
-#: toolset_guide.xml:559
 #, no-c-format
 msgid "You can call <literal>SchemaValidator</literal> from the Ant script:"
 msgstr ""
 
-#. Tag: programlisting
-#: toolset_guide.xml:563
-#, no-c-format
-msgid ""
-      "<![CDATA[<target name=\"schemavalidate\">\n"
-      "    <taskdef name=\"schemavalidator\"\n"
-      "        classname=\"org.hibernate.tool.hbm2ddl.SchemaValidatorTask\"\n"
-      "        classpathref=\"class.path\"/>\n"
-      "    \n"
-      "    <schemavalidator\n"
-      "        properties=\"hibernate.properties\">\n"
-      "        <fileset dir=\"src\">\n"
-      "            <include name=\"**/*.hbm.xml\"/>\n"
-      "        </fileset>\n"
-      "    </schemavalidator>\n"
-      "</target>]]>"
-msgstr ""
-

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/transactions.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/transactions.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/transactions.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,960 +1,658 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-02-11T05:38:16\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: transactions.xml:29
 #, no-c-format
 msgid "Transactions and Concurrency"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:31
 #, no-c-format
 msgid "The most important point about Hibernate and concurrency control is that it is easy to understand. Hibernate directly uses JDBC connections and JTA resources without adding any additional locking behavior. It is recommended that you spend some time with the JDBC, ANSI, and transaction isolation specification of your database management system."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:38
 #, no-c-format
 msgid "Hibernate does not lock objects in memory. Your application can expect the behavior as defined by the isolation level of your database transactions. Through <literal>Session</literal>, which is also a transaction-scoped cache, Hibernate provides repeatable reads for lookup by identifier and entity queries and not reporting queries that return scalar values."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:46
 #, no-c-format
 msgid "In addition to versioning for automatic optimistic concurrency control, Hibernate also offers, using the <literal>SELECT FOR UPDATE</literal> syntax, a (minor) API for pessimistic locking of rows. Optimistic concurrency control and this API are discussed later in this chapter."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:53
 #, no-c-format
 msgid "The discussion of concurrency control in Hibernate begins with the granularity of <literal>Configuration</literal>, <literal>SessionFactory</literal>, and <literal>Session</literal>, as well as database transactions and long conversations."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:60
 #, no-c-format
 msgid "Session and transaction scopes"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:62
 #, no-c-format
 msgid "A <literal>SessionFactory</literal> is an expensive-to-create, threadsafe object, intended to be shared by all application threads. It is created once, usually on application startup, from a <literal>Configuration</literal> instance."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:68
 #, no-c-format
 msgid "A <literal>Session</literal> is an inexpensive, non-threadsafe object that should be used once and then discarded for: a single request, a conversation or a single unit of work. A <literal>Session</literal> will not obtain a JDBC <literal>Connection</literal>, or a <literal>Datasource</literal>, unless it is needed. It will not consume any resources until used."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:76
 #, no-c-format
 msgid "In order to reduce lock contention in the database, a database transaction has to be as short as possible. Long database transactions will prevent your application from scaling to a highly concurrent load. It is not recommended that you hold a database transaction open during user think time until the unit of work is complete."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:84
 #, no-c-format
 msgid "What is the scope of a unit of work? Can a single Hibernate <literal>Session</literal> span several database transactions, or is this a one-to-one relationship of scopes? When should you open and close a <literal>Session</literal> and how do you demarcate the database transaction boundaries? These questions are addressed in the following sections."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:92
 #, no-c-format
 msgid "Unit of work"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:94
 #, no-c-format
-msgid "First, let's define a unit of work. A unit of work is a design pattern described by Martin Fowler as <quote> [maintaining] a list of objects affected by a business transaction and coordinates the writing out of changes and the resolution of concurrency problems. </quote><citation>PoEAA</citation> In other words, its a series of operations we wish to carry out against the database together. Basically, it is a transaction, though fulfilling a unit of work will often span multiple physical database transactions (see <xref linkend=\"transactions-basics-apptx\"/>). So really we are talking about a more abstract notion of a transaction. The term \"business transaction\" is also sometimes used in lieu of unit of work."
+msgid "First, let's define a unit of work. A unit of work is a design pattern described by Martin Fowler as <quote> [maintaining] a list of objects affected by a business transaction and coordinates the writing out of changes and the resolution of concurrency problems. </quote><citation>PoEAA</citation> In other words, its a series of operations we wish to carry out against the database together. Basically, it is a transaction, though fulfilling a unit of work will often span multiple physical database transactions (see <xref linkend=\"transactions-basics-apptx\" />). So really we are talking about a more abstract notion of a transaction. The term \"business transaction\" is also sometimes used in lieu of unit of work."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:111
 #, no-c-format
 msgid "Do not use the <emphasis>session-per-operation</emphasis> antipattern: do not open and close a <literal>Session</literal> for every simple database call in a single thread. The same is true for database transactions. Database calls in an application are made using a planned sequence; they are grouped into atomic units of work. This also means that auto-commit after every single SQL statement is useless in an application as this mode is intended for ad-hoc SQL console work. Hibernate disables, or expects the application server to disable, auto-commit mode immediately. Database transactions are never optional. All communication with a database has to occur inside a transaction. Auto-commit behavior for reading data should be avoided, as many small transactions are unlikely to perform better than one clearly defined unit of work. The latter is also more maintainable and extensible."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:126
 #, no-c-format
 msgid "The most common pattern in a multi-user client/server application is <emphasis>session-per-request</emphasis>. In this model, a request from the client is sent to the server, where the Hibernate persistence layer runs. A new Hibernate <literal>Session</literal> is opened, and all database operations are executed in this unit of work. On completion of the work, and once the response for the client has been prepared, the session is flushed and closed. Use a single database transaction to serve the clients request, starting and committing it when you open and close the <literal>Session</literal>. The relationship between the two is one-to-one and this model is a perfect fit for many applications."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:138
 #, no-c-format
 msgid "The challenge lies in the implementation. Hibernate provides built-in management of the \"current session\" to simplify this pattern. Start a transaction when a server request has to be processed, and end the transaction before the response is sent to the client. Common solutions are <literal>ServletFilter</literal>, AOP interceptor with a pointcut on the service methods, or a proxy/interception container. An EJB container is a standardized way to implement cross-cutting aspects such as transaction demarcation on EJB session beans, declaratively with CMT. If you use programmatic transaction demarcation, for ease of use and code portability use the Hibernate <literal>Transaction</literal> API shown later in this chapter."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:150
 #, no-c-format
-msgid "Your application code can access a \"current session\" to process the request by calling <literal>sessionFactory.getCurrentSession()</literal>. You will always get a <literal>Session</literal> scoped to the current database transaction. This has to be configured for either resource-local or JTA environments, see <xref linkend=\"architecture-current-session\"/>."
+msgid "Your application code can access a \"current session\" to process the request by calling <literal>sessionFactory.getCurrentSession()</literal>. You will always get a <literal>Session</literal> scoped to the current database transaction. This has to be configured for either resource-local or JTA environments, see <xref linkend=\"architecture-current-session\" />."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:158
 #, no-c-format
 msgid "You can extend the scope of a <literal>Session</literal> and database transaction until the \"view has been rendered\". This is especially useful in servlet applications that utilize a separate rendering phase after the request has been processed. Extending the database transaction until view rendering, is achieved by implementing your own interceptor. However, this will be difficult if you rely on EJBs with container-managed transactions. A transaction will be completed when an EJB method returns, before rendering of any view can start. See the Hibernate website and forum for tips and examples relating to this <emphasis>Open Session in View</emphasis> pattern."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:173
 #, no-c-format
 msgid "Long conversations"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:175
 #, no-c-format
 msgid "The session-per-request pattern is not the only way of designing units of work. Many business processes require a whole series of interactions with the user that are interleaved with database accesses. In web and enterprise applications, it is not acceptable for a database transaction to span a user interaction. Consider the following example:"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:185
 #, no-c-format
 msgid "The first screen of a dialog opens. The data seen by the user has been loaded in a particular <literal>Session</literal> and database transaction. The user is free to modify the objects."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:192
 #, no-c-format
 msgid "The user clicks \"Save\" after 5 minutes and expects their modifications to be made persistent. The user also expects that they were the only person editing this information and that no conflicting modification has occurred."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:200
 #, no-c-format
 msgid "From the point of view of the user, we call this unit of work a long-running <emphasis>conversation</emphasis> or <emphasis>application transaction</emphasis>. There are many ways to implement this in your application."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:206
 #, no-c-format
 msgid "A first naive implementation might keep the <literal>Session</literal> and database transaction open during user think time, with locks held in the database to prevent concurrent modification and to guarantee isolation and atomicity. This is an anti-pattern, since lock contention would not allow the application to scale with the number of concurrent users."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:214
 #, no-c-format
 msgid "You have to use several database transactions to implement the conversation. In this case, maintaining isolation of business processes becomes the partial responsibility of the application tier. A single conversation usually spans several database transactions. It will be atomic if only one of these database transactions (the last one) stores the updated data. All others simply read data (for example, in a wizard-style dialog spanning several request/response cycles). This is easier to implement than it might sound, especially if you utilize some of Hibernate's features:"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:227
 #, no-c-format
 msgid "<emphasis>Automatic Versioning</emphasis>: Hibernate can perform automatic optimistic concurrency control for you. It can automatically detect if a concurrent modification occurred during user think time. Check for this at the end of the conversation."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:235
 #, no-c-format
 msgid "<emphasis>Detached Objects</emphasis>: if you decide to use the <emphasis>session-per-request</emphasis> pattern, all loaded instances will be in the detached state during user think time. Hibernate allows you to reattach the objects and persist the modifications. The pattern is called <emphasis>session-per-request-with-detached-objects</emphasis>. Automatic versioning is used to isolate concurrent modifications."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:245
 #, no-c-format
 msgid "<emphasis>Extended (or Long) Session</emphasis>: the Hibernate <literal>Session</literal> can be disconnected from the underlying JDBC connection after the database transaction has been committed and reconnected when a new client request occurs. This pattern is known as <emphasis>session-per-conversation</emphasis> and makes even reattachment unnecessary. Automatic versioning is used to isolate concurrent modifications and the <literal>Session</literal> will not be allowed to be flushed automatically, but explicitly."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:258
 #, no-c-format
 msgid "Both <emphasis>session-per-request-with-detached-objects</emphasis> and <emphasis>session-per-conversation</emphasis> have advantages and disadvantages. These disadvantages are discussed later in this chapter in the context of optimistic concurrency control."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:267
 #, no-c-format
 msgid "Considering object identity"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:269
 #, no-c-format
 msgid "An application can concurrently access the same persistent state in two different <literal>Session</literal>s. However, an instance of a persistent class is never shared between two <literal>Session</literal> instances. It is for this reason that there are two different notions of identity:"
 msgstr ""
 
 #. Tag: term
-#: transactions.xml:278
 #, no-c-format
 msgid "Database Identity"
 msgstr ""
 
-#. Tag: literal
-#: transactions.xml:281
+#. Tag: para
 #, no-c-format
-msgid "foo.getId().equals( bar.getId() )"
+msgid "<literal>foo.getId().equals( bar.getId() )</literal>"
 msgstr ""
 
 #. Tag: term
-#: transactions.xml:286
 #, no-c-format
 msgid "JVM Identity"
 msgstr ""
 
-#. Tag: literal
-#: transactions.xml:289
+#. Tag: para
 #, no-c-format
-msgid "foo==bar"
+msgid "<literal>foo==bar</literal>"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:295
 #, no-c-format
 msgid "For objects attached to a <emphasis>particular</emphasis> <literal>Session</literal> (i.e., in the scope of a <literal>Session</literal>), the two notions are equivalent and JVM identity for database identity is guaranteed by Hibernate. While the application might concurrently access the \"same\" (persistent identity) business object in two different sessions, the two instances will actually be \"different\" (JVM identity). Conflicts are resolved using an optimistic approach and automatic versioning at flush/commit time."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:304
 #, no-c-format
 msgid "This approach leaves Hibernate and the database to worry about concurrency. It also provides the best scalability, since guaranteeing identity in single-threaded units of work means that it does not need expensive locking or other means of synchronization. The application does not need to synchronize on any business object, as long as it maintains a single thread per <literal>Session</literal>. Within a <literal>Session</literal> the application can safely use <literal>==</literal> to compare objects."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:313
 #, no-c-format
 msgid "However, an application that uses <literal>==</literal> outside of a <literal>Session</literal> might produce unexpected results. This might occur even in some unexpected places. For example, if you put two detached instances into the same <literal>Set</literal>, both might have the same database identity (i.e., they represent the same row). JVM identity, however, is by definition not guaranteed for instances in a detached state. The developer has to override the <literal>equals()</literal> and <literal>hashCode()</literal> methods in persistent classes and implement their own notion of object equality. There is one caveat: never use the database identifier to implement equality. Use a business key that is a combination of unique, usually immutable, attributes. The database identifier will change if a transient object is made persistent. If the transient instance (usually together with detached instances) is held in a <literal>Set</literal>, changing the hashcode bre!
 aks the contract of the <literal>Set</literal>. Attributes for business keys do not have to be as stable as database primary keys; you only have to guarantee stability as long as the objects are in the same <literal>Set</literal>. See the Hibernate website for a more thorough discussion of this issue. Please note that this is not a Hibernate issue, but simply how Java object identity and equality has to be implemented."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:334
 #, no-c-format
 msgid "Common issues"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:336
 #, no-c-format
 msgid "Do not use the anti-patterns <emphasis>session-per-user-session</emphasis> or <emphasis>session-per-application</emphasis> (there are, however, rare exceptions to this rule). Some of the following issues might also arise within the recommended patterns, so ensure that you understand the implications before making a design decision:"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:345
 #, no-c-format
 msgid "A <literal>Session</literal> is not thread-safe. Things that work concurrently, like HTTP requests, session beans, or Swing workers, will cause race conditions if a <literal>Session</literal> instance is shared. If you keep your Hibernate <literal>Session</literal> in your <literal>HttpSession</literal> (this is discussed later in the chapter), you should consider synchronizing access to your Http session. Otherwise, a user that clicks reload fast enough can use the same <literal>Session</literal> in two concurrently running threads."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:356
 #, no-c-format
 msgid "An exception thrown by Hibernate means you have to rollback your database transaction and close the <literal>Session</literal> immediately (this is discussed in more detail later in the chapter). If your <literal>Session</literal> is bound to the application, you have to stop the application. Rolling back the database transaction does not put your business objects back into the state they were at the start of the transaction. This means that the database state and the business objects will be out of sync. Usually this is not a problem, because exceptions are not recoverable and you will have to start over after rollback anyway."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:368
 #, no-c-format
-msgid "The <literal>Session</literal> caches every object that is in a persistent state (watched and checked for dirty state by Hibernate). If you keep it open for a long time or simply load too much data, it will grow endlessly until you get an OutOfMemoryException. One solution is to call <literal>clear()</literal> and <literal>evict()</literal> to manage the <literal>Session</literal> cache, but you should consider a Stored Procedure if you need mass data operations. Some solutions are shown in <xref linkend=\"batch\"/>. Keeping a <literal>Session</literal> open for the duration of a user session also means a higher probability of stale data."
+msgid "The <literal>Session</literal> caches every object that is in a persistent state (watched and checked for dirty state by Hibernate). If you keep it open for a long time or simply load too much data, it will grow endlessly until you get an OutOfMemoryException. One solution is to call <literal>clear()</literal> and <literal>evict()</literal> to manage the <literal>Session</literal> cache, but you should consider a Stored Procedure if you need mass data operations. Some solutions are shown in <xref linkend=\"batch\" />. Keeping a <literal>Session</literal> open for the duration of a user session also means a higher probability of stale data."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:386
 #, no-c-format
 msgid "Database transaction demarcation"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:388
 #, no-c-format
 msgid "Database, or system, transaction boundaries are always necessary. No communication with the database can occur outside of a database transaction (this seems to confuse many developers who are used to the auto-commit mode). Always use clear transaction boundaries, even for read-only operations. Depending on your isolation level and database capabilities this might not be required, but there is no downside if you always demarcate transactions explicitly. Certainly, a single database transaction is going to perform better than many small transactions, even for reading data."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:398
 #, no-c-format
 msgid "A Hibernate application can run in non-managed (i.e., standalone, simple Web- or Swing applications) and managed J2EE environments. In a non-managed environment, Hibernate is usually responsible for its own database connection pool. The application developer has to manually set transaction boundaries (begin, commit, or rollback database transactions) themselves. A managed environment usually provides container-managed transactions (CMT), with the transaction assembly defined declaratively (in deployment descriptors of EJB session beans, for example). Programmatic transaction demarcation is then no longer necessary."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:408
 #, no-c-format
 msgid "However, it is often desirable to keep your persistence layer portable between non-managed resource-local environments, and systems that can rely on JTA but use BMT instead of CMT. In both cases use programmatic transaction demarcation. Hibernate offers a wrapper API called <literal>Transaction</literal> that translates into the native transaction system of your deployment environment. This API is actually optional, but we strongly encourage its use unless you are in a CMT session bean."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:417
 #, no-c-format
 msgid "Ending a <literal>Session</literal> usually involves four distinct phases:"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:423
 #, no-c-format
 msgid "flush the session"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:428
 #, no-c-format
 msgid "commit the transaction"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:433
 #, no-c-format
 msgid "close the session"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:438
 #, no-c-format
 msgid "handle exceptions"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:444
 #, no-c-format
 msgid "We discussed Flushing the session earlier, so we will now have a closer look at transaction demarcation and exception handling in both managed and non-managed environments."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:451
 #, no-c-format
 msgid "Non-managed environment"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:453
 #, no-c-format
 msgid "If a Hibernate persistence layer runs in a non-managed environment, database connections are usually handled by simple (i.e., non-DataSource) connection pools from which Hibernate obtains connections as needed. The session/transaction handling idiom looks like this:"
 msgstr ""
 
-#. Tag: programlisting
-#: transactions.xml:460
-#, no-c-format
-msgid ""
-      "<![CDATA[// Non-managed environment idiom\n"
-      "Session sess = factory.openSession();\n"
-      "Transaction tx = null;\n"
-      "try {\n"
-      "    tx = sess.beginTransaction();\n"
-      "\n"
-      "    // do some work\n"
-      "    ...\n"
-      "\n"
-      "    tx.commit();\n"
-      "}\n"
-      "catch (RuntimeException e) {\n"
-      "    if (tx != null) tx.rollback();\n"
-      "    throw e; // or display error message\n"
-      "}\n"
-      "finally {\n"
-      "    sess.close();\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:462
 #, no-c-format
 msgid "You do not have to <literal>flush()</literal> the <literal>Session</literal> explicitly: the call to <literal>commit()</literal> automatically triggers the synchronization depending on the <link linkend=\"objectstate-flushing\">FlushMode</link> for the session. A call to <literal>close()</literal> marks the end of a session. The main implication of <literal>close()</literal> is that the JDBC connection will be relinquished by the session. This Java code is portable and runs in both non-managed and JTA environments."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:471
 #, no-c-format
 msgid "As outlined earlier, a much more flexible solution is Hibernate's built-in \"current session\" context management:"
 msgstr ""
 
-#. Tag: programlisting
-#: transactions.xml:476
-#, no-c-format
-msgid ""
-      "<![CDATA[// Non-managed environment idiom with getCurrentSession()\n"
-      "try {\n"
-      "    factory.getCurrentSession().beginTransaction();\n"
-      "\n"
-      "    // do some work\n"
-      "    ...\n"
-      "\n"
-      "    factory.getCurrentSession().getTransaction().commit();\n"
-      "}\n"
-      "catch (RuntimeException e) {\n"
-      "    factory.getCurrentSession().getTransaction().rollback();\n"
-      "    throw e; // or display error message\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:478
 #, no-c-format
 msgid "You will not see these code snippets in a regular application; fatal (system) exceptions should always be caught at the \"top\". In other words, the code that executes Hibernate calls in the persistence layer, and the code that handles <literal>RuntimeException</literal> (and usually can only clean up and exit), are in different layers. The current context management by Hibernate can significantly simplify this design by accessing a <literal>SessionFactory</literal>. Exception handling is discussed later in this chapter."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:488
 #, no-c-format
 msgid "You should select <literal>org.hibernate.transaction.JDBCTransactionFactory</literal>, which is the default, and for the second example select <literal>\"thread\"</literal> as your <literal>hibernate.current_session_context_class</literal>."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:497
 #, no-c-format
 msgid "Using JTA"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:499
 #, no-c-format
 msgid "If your persistence layer runs in an application server (for example, behind EJB session beans), every datasource connection obtained by Hibernate will automatically be part of the global JTA transaction. You can also install a standalone JTA implementation and use it without EJB. Hibernate offers two strategies for JTA integration."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:506
 #, no-c-format
 msgid "If you use bean-managed transactions (BMT), Hibernate will tell the application server to start and end a BMT transaction if you use the <literal>Transaction</literal> API. The transaction management code is identical to the non-managed environment."
 msgstr ""
 
-#. Tag: programlisting
-#: transactions.xml:512
-#, no-c-format
-msgid ""
-      "<![CDATA[// BMT idiom\n"
-      "Session sess = factory.openSession();\n"
-      "Transaction tx = null;\n"
-      "try {\n"
-      "    tx = sess.beginTransaction();\n"
-      "\n"
-      "    // do some work\n"
-      "    ...\n"
-      "\n"
-      "    tx.commit();\n"
-      "}\n"
-      "catch (RuntimeException e) {\n"
-      "    if (tx != null) tx.rollback();\n"
-      "    throw e; // or display error message\n"
-      "}\n"
-      "finally {\n"
-      "    sess.close();\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:514
 #, no-c-format
 msgid "If you want to use a transaction-bound <literal>Session</literal>, that is, the <literal>getCurrentSession()</literal> functionality for easy context propagation, use the JTA <literal>UserTransaction</literal> API directly:"
 msgstr ""
 
-#. Tag: programlisting
-#: transactions.xml:520
-#, no-c-format
-msgid ""
-      "<![CDATA[// BMT idiom with getCurrentSession()\n"
-      "try {\n"
-      "    UserTransaction tx = (UserTransaction)new InitialContext()\n"
-      "                            .lookup(\"java:comp/UserTransaction\");\n"
-      "\n"
-      "    tx.begin();\n"
-      "\n"
-      "    // Do some work on Session bound to transaction\n"
-      "    factory.getCurrentSession().load(...);\n"
-      "    factory.getCurrentSession().persist(...);\n"
-      "\n"
-      "    tx.commit();\n"
-      "}\n"
-      "catch (RuntimeException e) {\n"
-      "    tx.rollback();\n"
-      "    throw e; // or display error message\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:522
 #, no-c-format
 msgid "With CMT, transaction demarcation is completed in session bean deployment descriptors, not programmatically. The code is reduced to:"
 msgstr ""
 
-#. Tag: programlisting
-#: transactions.xml:527
-#, no-c-format
-msgid ""
-      "<![CDATA[// CMT idiom\n"
-      " Session sess = factory.getCurrentSession();\n"
-      "\n"
-      " // do some work\n"
-      " ...\n"
-      "]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:529
 #, no-c-format
 msgid "In a CMT/EJB, even rollback happens automatically. An unhandled <literal>RuntimeException</literal> thrown by a session bean method tells the container to set the global transaction to rollback. <emphasis>You do not need to use the Hibernate <literal>Transaction</literal> API at all with BMT or CMT, and you get automatic propagation of the \"current\" Session bound to the transaction.</emphasis>"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:537
 #, no-c-format
 msgid "When configuring Hibernate's transaction factory, choose <literal>org.hibernate.transaction.JTATransactionFactory</literal> if you use JTA directly (BMT), and <literal>org.hibernate.transaction.CMTTransactionFactory</literal> in a CMT session bean. Remember to also set <literal>hibernate.transaction.manager_lookup_class</literal>. Ensure that your <literal>hibernate.current_session_context_class</literal> is either unset (backwards compatibility), or is set to <literal>\"jta\"</literal>."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:546
 #, no-c-format
 msgid "The <literal>getCurrentSession()</literal> operation has one downside in a JTA environment. There is one caveat to the use of <literal>after_statement</literal> connection release mode, which is then used by default. Due to a limitation of the JTA spec, it is not possible for Hibernate to automatically clean up any unclosed <literal>ScrollableResults</literal> or <literal>Iterator</literal> instances returned by <literal>scroll()</literal> or <literal>iterate()</literal>. You <emphasis>must</emphasis> release the underlying database cursor by calling <literal>ScrollableResults.close()</literal> or <literal>Hibernate.close(Iterator)</literal> explicitly from a <literal>finally</literal> block. Most applications can easily avoid using <literal>scroll()</literal> or <literal>iterate()</literal> from the JTA or CMT code.)"
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:562
 #, no-c-format
 msgid "Exception handling"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:564
 #, no-c-format
 msgid "If the <literal>Session</literal> throws an exception, including any <literal>SQLException</literal>, immediately rollback the database transaction, call <literal>Session.close()</literal> and discard the <literal>Session</literal> instance. Certain methods of <literal>Session</literal> will <emphasis>not</emphasis> leave the session in a consistent state. No exception thrown by Hibernate can be treated as recoverable. Ensure that the <literal>Session</literal> will be closed by calling <literal>close()</literal> in a <literal>finally</literal> block."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:575
 #, no-c-format
 msgid "The <literal>HibernateException</literal>, which wraps most of the errors that can occur in a Hibernate persistence layer, is an unchecked exception. It was not in older versions of Hibernate. In our opinion, we should not force the application developer to catch an unrecoverable exception at a low layer. In most systems, unchecked and fatal exceptions are handled in one of the first frames of the method call stack (i.e., in higher layers) and either an error message is presented to the application user or some other appropriate action is taken. Note that Hibernate might also throw other unchecked exceptions that are not a <literal>HibernateException</literal>. These are not recoverable and appropriate action should be taken."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:587
 #, no-c-format
 msgid "Hibernate wraps <literal>SQLException</literal>s thrown while interacting with the database in a <literal>JDBCException</literal>. In fact, Hibernate will attempt to convert the exception into a more meaningful subclass of <literal>JDBCException</literal>. The underlying <literal>SQLException</literal> is always available via <literal>JDBCException.getCause()</literal>. Hibernate converts the <literal>SQLException</literal> into an appropriate <literal>JDBCException</literal> subclass using the <literal>SQLExceptionConverter</literal> attached to the <literal>SessionFactory</literal>. By default, the <literal>SQLExceptionConverter</literal> is defined by the configured dialect. However, it is also possible to plug in a custom implementation. See the javadocs for the <literal>SQLExceptionConverterFactory</literal> class for details. The standard <literal>JDBCException</literal> subtypes are:"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:603
 #, no-c-format
 msgid "<literal>JDBCConnectionException</literal>: indicates an error with the underlying JDBC communication."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:609
 #, no-c-format
 msgid "<literal>SQLGrammarException</literal>: indicates a grammar or syntax problem with the issued SQL."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:615
 #, no-c-format
 msgid "<literal>ConstraintViolationException</literal>: indicates some form of integrity constraint violation."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:621
 #, no-c-format
 msgid "<literal>LockAcquisitionException</literal>: indicates an error acquiring a lock level necessary to perform the requested operation."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:627
 #, no-c-format
 msgid "<literal>GenericJDBCException</literal>: a generic exception which did not fall into any of the other categories."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:637
 #, no-c-format
 msgid "Transaction timeout"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:639
 #, no-c-format
 msgid "An important feature provided by a managed environment like EJB, that is never provided for non-managed code, is transaction timeout. Transaction timeouts ensure that no misbehaving transaction can indefinitely tie up resources while returning no response to the user. Outside a managed (JTA) environment, Hibernate cannot fully provide this functionality. However, Hibernate can at least control data access operations, ensuring that database level deadlocks and queries with huge result sets are limited by a defined timeout. In a managed environment, Hibernate can delegate transaction timeout to JTA. This functionality is abstracted by the Hibernate <literal>Transaction</literal> object."
 msgstr ""
 
-#. Tag: programlisting
-#: transactions.xml:652
-#, no-c-format
-msgid ""
-      "<![CDATA[\n"
-      "Session sess = factory.openSession();\n"
-      "try {\n"
-      "    //set transaction timeout to 3 seconds\n"
-      "    sess.getTransaction().setTimeout(3);\n"
-      "    sess.getTransaction().begin();\n"
-      "\n"
-      "    // do some work\n"
-      "    ...\n"
-      "\n"
-      "    sess.getTransaction().commit()\n"
-      "}\n"
-      "catch (RuntimeException e) {\n"
-      "    sess.getTransaction().rollback();\n"
-      "    throw e; // or display error message\n"
-      "}\n"
-      "finally {\n"
-      "    sess.close();\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:654
 #, no-c-format
 msgid "<literal>setTimeout()</literal> cannot be called in a CMT bean, where transaction timeouts must be defined declaratively."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:664
 #, no-c-format
 msgid "Optimistic concurrency control"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:666
 #, no-c-format
 msgid "The only approach that is consistent with high concurrency and high scalability, is optimistic concurrency control with versioning. Version checking uses version numbers, or timestamps, to detect conflicting updates and to prevent lost updates. Hibernate provides three possible approaches to writing application code that uses optimistic concurrency. The use cases we discuss are in the context of long conversations, but version checking also has the benefit of preventing lost updates in single database transactions."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:677
 #, no-c-format
 msgid "Application version checking"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:679
 #, no-c-format
 msgid "In an implementation without much help from Hibernate, each interaction with the database occurs in a new <literal>Session</literal> and the developer is responsible for reloading all persistent instances from the database before manipulating them. The application is forced to carry out its own version checking to ensure conversation transaction isolation. This approach is the least efficient in terms of database access. It is the approach most similar to entity EJBs."
 msgstr ""
 
-#. Tag: programlisting
-#: transactions.xml:688
-#, no-c-format
-msgid ""
-      "<![CDATA[// foo is an instance loaded by a previous Session\n"
-      "session = factory.openSession();\n"
-      "Transaction t = session.beginTransaction();\n"
-      "\n"
-      "int oldVersion = foo.getVersion();\n"
-      "session.load( foo, foo.getKey() ); // load the current state\n"
-      "if ( oldVersion != foo.getVersion() ) throw new StaleObjectStateException();\n"
-      "foo.setProperty(\"bar\");\n"
-      "\n"
-      "t.commit();\n"
-      "session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:690
 #, no-c-format
 msgid "The <literal>version</literal> property is mapped using <literal>&lt;version&gt;</literal>, and Hibernate will automatically increment it during flush if the entity is dirty."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:696
 #, no-c-format
 msgid "If you are operating in a low-data-concurrency environment, and do not require version checking, you can use this approach and skip the version check. In this case, <emphasis>last commit wins</emphasis> is the default strategy for long conversations. Be aware that this might confuse the users of the application, as they might experience lost updates without error messages or a chance to merge conflicting changes."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:705
 #, no-c-format
 msgid "Manual version checking is only feasible in trivial circumstances and not practical for most applications. Often not only single instances, but complete graphs of modified objects, have to be checked. Hibernate offers automatic version checking with either an extended <literal>Session</literal> or detached instances as the design paradigm."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:716
 #, no-c-format
 msgid "Extended session and automatic versioning"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:718
 #, no-c-format
 msgid "A single <literal>Session</literal> instance and its persistent instances that are used for the whole conversation are known as <emphasis>session-per-conversation</emphasis>. Hibernate checks instance versions at flush time, throwing an exception if concurrent modification is detected. It is up to the developer to catch and handle this exception. Common options are the opportunity for the user to merge changes or to restart the business conversation with non-stale data."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:727
 #, no-c-format
 msgid "The <literal>Session</literal> is disconnected from any underlying JDBC connection when waiting for user interaction. This approach is the most efficient in terms of database access. The application does not version check or reattach detached instances, nor does it have to reload instances in every database transaction."
 msgstr ""
 
-#. Tag: programlisting
-#: transactions.xml:735
-#, no-c-format
-msgid ""
-      "<![CDATA[// foo is an instance loaded earlier by the old session\n"
-      "Transaction t = session.beginTransaction(); // Obtain a new JDBC connection, start transaction\n"
-      "\n"
-      "foo.setProperty(\"bar\");\n"
-      "\n"
-      "session.flush();    // Only for last transaction in conversation\n"
-      "t.commit();         // Also return JDBC connection\n"
-      "session.close();    // Only for last transaction in conversation]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:736
 #, no-c-format
 msgid "The <literal>foo</literal> object knows which <literal>Session</literal> it was loaded in. Beginning a new database transaction on an old session obtains a new connection and resumes the session. Committing a database transaction disconnects a session from the JDBC connection and returns the connection to the pool. After reconnection, to force a version check on data you are not updating, you can call <literal>Session.lock()</literal> with <literal>LockMode.READ</literal> on any objects that might have been updated by another transaction. You do not need to lock any data that you <emphasis>are</emphasis> updating. Usually you would set <literal>FlushMode.MANUAL</literal> on an extended <literal>Session</literal>, so that only the last database transaction cycle is allowed to actually persist all modifications made in this conversation. Only this last database transaction will include the <literal>flush()</literal> operation, and then <literal>close()</literal> the se!
 ssion to end the conversation."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:751
 #, no-c-format
 msgid "This pattern is problematic if the <literal>Session</literal> is too big to be stored during user think time (for example, an <literal>HttpSession</literal> should be kept as small as possible). As the <literal>Session</literal> is also the first-level cache and contains all loaded objects, we can probably use this strategy only for a few request/response cycles. Use a <literal>Session</literal> only for a single conversation as it will soon have stale data."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:762
 #, no-c-format
 msgid "Note"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:763
 #, no-c-format
 msgid "Earlier versions of Hibernate required explicit disconnection and reconnection of a <literal>Session</literal>. These methods are deprecated, as beginning and ending a transaction has the same effect."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:769
 #, no-c-format
 msgid "Keep the disconnected <literal>Session</literal> close to the persistence layer. Use an EJB stateful session bean to hold the <literal>Session</literal> in a three-tier environment. Do not transfer it to the web layer, or even serialize it to a separate tier, to store it in the <literal>HttpSession</literal>."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:777
 #, no-c-format
 msgid "The extended session pattern, or <emphasis>session-per-conversation</emphasis>, is more difficult to implement with automatic current session context management. You need to supply your own implementation of the <literal>CurrentSessionContext</literal> for this. See the Hibernate Wiki for examples."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:787
 #, no-c-format
 msgid "Detached objects and automatic versioning"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:789
 #, no-c-format
 msgid "Each interaction with the persistent store occurs in a new <literal>Session</literal>. However, the same persistent instances are reused for each interaction with the database. The application manipulates the state of detached instances originally loaded in another <literal>Session</literal> and then reattaches them using <literal>Session.update()</literal>, <literal>Session.saveOrUpdate()</literal>, or <literal>Session.merge()</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: transactions.xml:797
-#, no-c-format
-msgid ""
-      "<![CDATA[// foo is an instance loaded by a previous Session\n"
-      "foo.setProperty(\"bar\");\n"
-      "session = factory.openSession();\n"
-      "Transaction t = session.beginTransaction();\n"
-      "session.saveOrUpdate(foo); // Use merge() if \"foo\" might have been loaded already\n"
-      "t.commit();\n"
-      "session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:799
 #, no-c-format
 msgid "Again, Hibernate will check instance versions during flush, throwing an exception if conflicting updates occurred."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:804
 #, no-c-format
 msgid "You can also call <literal>lock()</literal> instead of <literal>update()</literal>, and use <literal>LockMode.READ</literal> (performing a version check and bypassing all caches) if you are sure that the object has not been modified."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:813
 #, no-c-format
 msgid "Customizing automatic versioning"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:815
 #, no-c-format
 msgid "You can disable Hibernate's automatic version increment for particular properties and collections by setting the <literal>optimistic-lock</literal> mapping attribute to <literal>false</literal>. Hibernate will then no longer increment versions if the property is dirty."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:822
 #, no-c-format
 msgid "Legacy database schemas are often static and cannot be modified. Or, other applications might access the same database and will not know how to handle version numbers or even timestamps. In both cases, versioning cannot rely on a particular column in a table. To force a version check with a comparison of the state of all fields in a row but without a version or timestamp property mapping, turn on <literal>optimistic-lock=\"all\"</literal> in the <literal>&lt;class&gt;</literal> mapping. This conceptually only works if Hibernate can compare the old and the new state (i.e., if you use a single long <literal>Session</literal> and not session-per-request-with-detached-objects)."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:834
 #, no-c-format
 msgid "Concurrent modification can be permitted in instances where the changes that have been made do not overlap. If you set <literal>optimistic-lock=\"dirty\"</literal> when mapping the <literal>&lt;class&gt;</literal>, Hibernate will only compare dirty fields during flush."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:840
 #, no-c-format
 msgid "In both cases, with dedicated version/timestamp columns or with a full/dirty field comparison, Hibernate uses a single <literal>UPDATE</literal> statement, with an appropriate <literal>WHERE</literal> clause, per entity to execute the version check and update the information. If you use transitive persistence to cascade reattachment to associated entities, Hibernate may execute unnecessary updates. This is usually not a problem, but <emphasis>on update</emphasis> triggers in the database might be executed even when no changes have been made to detached instances. You can customize this behavior by setting <literal>select-before-update=\"true\"</literal> in the <literal>&lt;class&gt;</literal> mapping, forcing Hibernate to <literal>SELECT</literal> the instance to ensure that changes did occur before updating the row."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:858
 #, no-c-format
 msgid "Pessimistic locking"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:860
 #, no-c-format
 msgid "It is not intended that users spend much time worrying about locking strategies. It is usually enough to specify an isolation level for the JDBC connections and then simply let the database do all the work. However, advanced users may wish to obtain exclusive pessimistic locks or re-obtain locks at the start of a new transaction."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:867
 #, no-c-format
 msgid "Hibernate will always use the locking mechanism of the database; it never lock objects in memory."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:872
 #, no-c-format
 msgid "The <literal>LockMode</literal> class defines the different lock levels that can be acquired by Hibernate. A lock is obtained by the following mechanisms:"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:879
 #, no-c-format
 msgid "<literal>LockMode.WRITE</literal> is acquired automatically when Hibernate updates or inserts a row."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:885
 #, no-c-format
 msgid "<literal>LockMode.UPGRADE</literal> can be acquired upon explicit user request using <literal>SELECT ... FOR UPDATE</literal> on databases which support that syntax."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:891
 #, no-c-format
 msgid "<literal>LockMode.UPGRADE_NOWAIT</literal> can be acquired upon explicit user request using a <literal>SELECT ... FOR UPDATE NOWAIT</literal> under Oracle."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:897
 #, no-c-format
 msgid "<literal>LockMode.READ</literal> is acquired automatically when Hibernate reads data under Repeatable Read or Serializable isolation level. It can be re-acquired by explicit user request."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:904
 #, no-c-format
 msgid "<literal>LockMode.NONE</literal> represents the absence of a lock. All objects switch to this lock mode at the end of a <literal>Transaction</literal>. Objects associated with the session via a call to <literal>update()</literal> or <literal>saveOrUpdate()</literal> also start out in this lock mode."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:913
 #, no-c-format
 msgid "The \"explicit user request\" is expressed in one of the following ways:"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:919
 #, no-c-format
 msgid "A call to <literal>Session.load()</literal>, specifying a <literal>LockMode</literal>."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:924
 #, no-c-format
 msgid "A call to <literal>Session.lock()</literal>."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:929
 #, no-c-format
 msgid "A call to <literal>Query.setLockMode()</literal>."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:935
 #, no-c-format
 msgid "If <literal>Session.load()</literal> is called with <literal>UPGRADE</literal> or <literal>UPGRADE_NOWAIT</literal>, and the requested object was not yet loaded by the session, the object is loaded using <literal>SELECT ... FOR UPDATE</literal>. If <literal>load()</literal> is called for an object that is already loaded with a less restrictive lock than the one requested, Hibernate calls <literal>lock()</literal> for that object."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:944
 #, no-c-format
 msgid "<literal>Session.lock()</literal> performs a version number check if the specified lock mode is <literal>READ</literal>, <literal>UPGRADE</literal> or <literal>UPGRADE_NOWAIT</literal>. In the case of <literal>UPGRADE</literal> or <literal>UPGRADE_NOWAIT</literal>, <literal>SELECT ... FOR UPDATE</literal> is used."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:951
 #, no-c-format
 msgid "If the requested lock mode is not supported by the database, Hibernate uses an appropriate alternate mode instead of throwing an exception. This ensures that applications are portable."
 msgstr ""
 
 #. Tag: title
-#: transactions.xml:960
 #, no-c-format
 msgid "Connection release modes"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:962
 #, no-c-format
 msgid "One of the legacies of Hibernate 2.x JDBC connection management meant that a <literal>Session</literal> would obtain a connection when it was first required and then maintain that connection until the session was closed. Hibernate 3.x introduced the notion of connection release modes that would instruct a session how to handle its JDBC connections. The following discussion is pertinent only to connections provided through a configured <literal>ConnectionProvider</literal>. User-supplied connections are outside the breadth of this discussion. The different release modes are identified by the enumerated values of <literal>org.hibernate.ConnectionReleaseMode</literal>:"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:976
 #, no-c-format
 msgid "<literal>ON_CLOSE</literal>: is the legacy behavior described above. The Hibernate session obtains a connection when it first needs to perform some JDBC access and maintains that connection until the session is closed."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:983
 #, no-c-format
 msgid "<literal>AFTER_TRANSACTION</literal>: releases connections after a <literal>org.hibernate.Transaction</literal> has been completed."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:989
 #, no-c-format
 msgid "<literal>AFTER_STATEMENT</literal> (also referred to as aggressive release): releases connections after every statement execution. This aggressive releasing is skipped if that statement leaves open resources associated with the given session. Currently the only situation where this occurs is through the use of <literal>org.hibernate.ScrollableResults</literal>."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:999
 #, no-c-format
 msgid "The configuration parameter <literal>hibernate.connection.release_mode</literal> is used to specify which release mode to use. The possible values are as follows:"
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:1006
 #, no-c-format
 msgid "<literal>auto</literal> (the default): this choice delegates to the release mode returned by the <literal>org.hibernate.transaction.TransactionFactory.getDefaultReleaseMode()</literal> method. For JTATransactionFactory, this returns ConnectionReleaseMode.AFTER_STATEMENT; for JDBCTransactionFactory, this returns ConnectionReleaseMode.AFTER_TRANSACTION. Do not change this default behavior as failures due to the value of this setting tend to indicate bugs and/or invalid assumptions in user code."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:1016
 #, no-c-format
 msgid "<literal>on_close</literal>: uses ConnectionReleaseMode.ON_CLOSE. This setting is left for backwards compatibility, but its use is discouraged."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:1022
 #, no-c-format
 msgid "<literal>after_transaction</literal>: uses ConnectionReleaseMode.AFTER_TRANSACTION. This setting should not be used in JTA environments. Also note that with ConnectionReleaseMode.AFTER_TRANSACTION, if a session is considered to be in auto-commit mode, connections will be released as if the release mode were AFTER_STATEMENT."
 msgstr ""
 
 #. Tag: para
-#: transactions.xml:1030
 #, no-c-format
 msgid "<literal>after_statement</literal>: uses ConnectionReleaseMode.AFTER_STATEMENT. Additionally, the configured <literal>ConnectionProvider</literal> is consulted to see if it supports this setting (<literal>supportsAggressiveRelease()</literal>). If not, the release mode is reset to ConnectionReleaseMode.AFTER_TRANSACTION. This setting is only safe in environments where we can either re-acquire the same underlying JDBC connection each time you make a call into <literal>ConnectionProvider.getConnection()</literal> or in auto-commit environments where it does not matter if we re-establish the same connection."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/tutorial.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/tutorial.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/tutorial.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,1582 +1,698 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-02-11T05:38:16\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: tutorial.xml:31
 #, no-c-format
 msgid "Tutorial"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:33
 #, no-c-format
 msgid "Intended for new users, this chapter provides an step-by-step introduction to Hibernate, starting with a simple application using an in-memory database. The tutorial is based on an earlier tutorial developed by Michael Gloegl. All code is contained in the <filename>tutorials/web</filename> directory of the project source."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:42
 #, no-c-format
 msgid "This tutorial expects the user have knowledge of both Java and SQL. If you have a limited knowledge of JAVA or SQL, it is advised that you start with a good introduction to that technology prior to attempting to learn Hibernate."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:51
 #, no-c-format
 msgid "The distribution contains another example application under the <filename>tutorial/eg</filename> project source directory."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:59
 #, no-c-format
 msgid "Part 1 - The first Hibernate Application"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:61
 #, no-c-format
 msgid "For this example, we will set up a small database application that can store events we want to attend and information about the host(s) of these events."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:67
 #, no-c-format
 msgid "Although you can use whatever database you feel comfortable using, we will use <ulink url=\"http://hsqldb.org/\">HSQLDB</ulink> (an in-memory, Java database) to avoid describing installation/setup of any particular database servers."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:76
 #, no-c-format
 msgid "Setup"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:78
 #, no-c-format
 msgid "The first thing we need to do is to set up the development environment. We will be using the \"standard layout\" advocated by alot of build tools such as <ulink url=\"http://maven.org\">Maven</ulink>. Maven, in particular, has a good resource describing this <ulink url=\"http://maven.apache.org/guides/introduction/introduction-to-the-standard-directory-layout.html\">layout</ulink>. As this tutorial is to be a web application, we will be creating and making use of <filename>src/main/java</filename>, <filename>src/main/resources</filename> and <filename>src/main/webapp</filename> directories."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:88
 #, no-c-format
 msgid "We will be using Maven in this tutorial, taking advantage of its transitive dependency management capabilities as well as the ability of many IDEs to automatically set up a project for us based on the maven descriptor."
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:94
-#, no-c-format
-msgid ""
-      "<![CDATA[<project xmlns=\"http://maven.apache.org/POM/4.0.0\"\n"
-      "         xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
-      "         xsi:schemaLocation=\"http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd\">\n"
-      "\n"
-      "    <modelVersion>4.0.0</modelVersion>\n"
-      "\n"
-      "    <groupId>org.hibernate.tutorials</groupId>\n"
-      "    <artifactId>hibernate-tutorial</artifactId>\n"
-      "    <version>1.0.0-SNAPSHOT</version>\n"
-      "    <name>First Hibernate Tutorial</name>\n"
-      "\n"
-      "    <build>\n"
-      "         <!-- we dont want the version to be part of the generated war file name -->\n"
-      "         <finalName>${artifactId}</finalName>\n"
-      "    </build>\n"
-      "\n"
-      "    <dependencies>\n"
-      "        <dependency>\n"
-      "            <groupId>org.hibernate</groupId>\n"
-      "            <artifactId>hibernate-core</artifactId>\n"
-      "        </dependency>\n"
-      "\n"
-      "        <!-- Because this is a web app, we also have a dependency on the servlet api. -->\n"
-      "        <dependency>\n"
-      "            <groupId>javax.servlet</groupId>\n"
-      "            <artifactId>servlet-api</artifactId>\n"
-      "        </dependency>\n"
-      "\n"
-      "        <!-- Hibernate uses slf4j for logging, for our purposes here use the simple backend -->\n"
-      "        <dependency>\n"
-      "            <groupId>org.slf4j</groupId>\n"
-      "            <artifactId>slf4j-simple</artifactId>\n"
-      "        </dependency>\n"
-      "\n"
-      "        <!-- Hibernate gives you a choice of bytecode providers between cglib and javassist -->\n"
-      "        <dependency>\n"
-      "            <groupId>javassist</groupId>\n"
-      "            <artifactId>javassist</artifactId>\n"
-      "        </dependency>\n"
-      "    </dependencies>\n"
-      "\n"
-      "</project>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:97
 #, no-c-format
 msgid "It is not a requirement to use Maven. If you wish to use something else to build this tutoial (such as Ant), the layout will remain the same. The only change is that you will need to manually account for all the needed dependencies. If you use something like <ulink url=\"http://ant.apache.org/ivy/\">Ivy</ulink> providing transitive dependency management you would still use the dependencies mentioned below. Otherwise, you'd need to grab <emphasis>all</emphasis> dependencies, both explicit and transitive, and add them to the project's classpath. If working from the Hibernate distribution bundle, this would mean <filename>hibernate3.jar</filename>, all artifacts in the <filename>lib/required</filename> directory and all files from either the <filename>lib/bytecode/cglib</filename> or <filename>lib/bytecode/javassist</filename> directory; additionally you will need both the servlet-api jar and one of the slf4j logging backends."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:114
 #, no-c-format
 msgid "Save this file as <filename>pom.xml</filename> in the project root directory."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:121
 #, no-c-format
 msgid "The first class"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:123
 #, no-c-format
 msgid "Next, we create a class that represents the event we want to store in the database; it is a simple JavaBean class with some properties:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:128
-#, no-c-format
-msgid ""
-      "<![CDATA[package org.hibernate.tutorial.domain;\n"
-      "\n"
-      "import java.util.Date;\n"
-      "\n"
-      "public class Event {\n"
-      "    private Long id;\n"
-      "\n"
-      "    private String title;\n"
-      "    private Date date;\n"
-      "\n"
-      "    public Event() {}\n"
-      "\n"
-      "    public Long getId() {\n"
-      "        return id;\n"
-      "    }\n"
-      "\n"
-      "    private void setId(Long id) {\n"
-      "        this.id = id;\n"
-      "    }\n"
-      "\n"
-      "    public Date getDate() {\n"
-      "        return date;\n"
-      "    }\n"
-      "\n"
-      "    public void setDate(Date date) {\n"
-      "        this.date = date;\n"
-      "    }\n"
-      "\n"
-      "    public String getTitle() {\n"
-      "        return title;\n"
-      "    }\n"
-      "\n"
-      "    public void setTitle(String title) {\n"
-      "        this.title = title;\n"
-      "    }\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:130
 #, no-c-format
 msgid "This class uses standard JavaBean naming conventions for property getter and setter methods, as well as private visibility for the fields. Although this is the recommended design, it is not required. Hibernate can also access fields directly, the benefit of accessor methods is robustness for refactoring."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:138
 #, no-c-format
 msgid "The <literal>id</literal> property holds a unique identifier value for a particular event. All persistent entity classes (there are less important dependent classes as well) will need such an identifier property if we want to use the full feature set of Hibernate. In fact, most applications, especially web applications, need to distinguish objects by identifier, so you should consider this a feature rather than a limitation. However, we usually do not manipulate the identity of an object, hence the setter method should be private. Only Hibernate will assign identifiers when an object is saved. Hibernate can access public, private, and protected accessor methods, as well as public, private and protected fields directly. The choice is up to you and you can match it to fit your application design."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:153
 #, no-c-format
 msgid "The no-argument constructor is a requirement for all persistent classes; Hibernate has to create objects for you, using Java Reflection. The constructor can be private, however package or public visibility is required for runtime proxy generation and efficient data retrieval without bytecode instrumentation."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:161
 #, no-c-format
 msgid "Save this file to the <filename>src/main/java/org/hibernate/tutorial/domain</filename> directory."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:168
 #, no-c-format
 msgid "The mapping file"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:170
 #, no-c-format
 msgid "Hibernate needs to know how to load and store objects of the persistent class. This is where the Hibernate mapping file comes into play. The mapping file tells Hibernate what table in the database it has to access, and what columns in that table it should use."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:178
 #, no-c-format
 msgid "The basic structure of a mapping file looks like this:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:182
-#, no-c-format
-msgid ""
-      "<![CDATA[<?xml version=\"1.0\"?>\n"
-      "<!DOCTYPE hibernate-mapping PUBLIC\n"
-      "        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-      "        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-      "\n"
-      "<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-      "[...]\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:184
 #, no-c-format
 msgid "Hibernate DTD is sophisticated. You can use it for auto-completion of XML mapping elements and attributes in your editor or IDE. Opening up the DTD file in your text editor is the easiest way to get an overview of all elements and attributes, and to view the defaults, as well as some comments. Hibernate will not load the DTD file from the web, but first look it up from the classpath of the application. The DTD file is included in <filename>hibernate-core.jar</filename> (it is also included in the <filename>hibernate3.jar</filename>, if using the distribution bundle)."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:197
 #, no-c-format
 msgid "We will omit the DTD declaration in future examples to shorten the code. It is, of course, not optional."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:203
 #, no-c-format
 msgid "Between the two <literal>hibernate-mapping</literal> tags, include a <literal>class</literal> element. All persistent entity classes (again, there might be dependent classes later on, which are not first-class entities) need a mapping to a table in the SQL database:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:210
-#, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-      "\n"
-      "    <class name=\"Event\" table=\"EVENTS\">\n"
-      "\n"
-      "    </class>\n"
-      "\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:212
 #, no-c-format
 msgid "So far we have told Hibernate how to persist and load object of class <literal>Event</literal> to the table <literal>EVENTS</literal>. Each instance is now represented by a row in that table. Now we can continue by mapping the unique identifier property to the tables primary key. As we do not want to care about handling this identifier, we configure Hibernate's identifier generation strategy for a surrogate primary key column:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:222
-#, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-      "\n"
-      "    <class name=\"Event\" table=\"EVENTS\">\n"
-      "        <id name=\"id\" column=\"EVENT_ID\">\n"
-      "            <generator class=\"native\"/>\n"
-      "        </id>\n"
-      "    </class>\n"
-      "\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:224
 #, no-c-format
 msgid "The <literal>id</literal> element is the declaration of the identifier property. The <literal>name=\"id\"</literal> mapping attribute declares the name of the JavaBean property and tells Hibernate to use the <literal>getId()</literal> and <literal>setId()</literal> methods to access the property. The column attribute tells Hibernate which column of the <literal>EVENTS</literal> table holds the primary key value."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:234
 #, no-c-format
 msgid "The nested <literal>generator</literal> element specifies the identifier generation strategy (aka how are identifier values generated?). In this case we choose <literal>native</literal>, which offers a level of portability depending on the configured database dialect. Hibernate supports database generated, globally unique, as well as application assigned, identifiers. Identifier value generation is also one of Hibernate's many extension points and you can plugin in your own strategy."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:246
 #, no-c-format
-msgid "<literal>native</literal> is no longer consider the best strategy in terms of portability. for further discussion, see"
+msgid "<literal>native</literal> is no longer consider the best strategy in terms of portability. for further discussion, see <xref linkend=\"portability-idgen\" />"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:252
 #, no-c-format
 msgid "Lastly, we need to tell Hibernate about the remaining entity class properties. By default, no properties of the class are considered persistent:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:258
-#, no-c-format
-msgid ""
-      "<![CDATA[\n"
-      "<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-      "\n"
-      "    <class name=\"Event\" table=\"EVENTS\">\n"
-      "        <id name=\"id\" column=\"EVENT_ID\">\n"
-      "            <generator class=\"native\"/>\n"
-      "        </id>\n"
-      "        <property name=\"date\" type=\"timestamp\" column=\"EVENT_DATE\"/>\n"
-      "        <property name=\"title\"/>\n"
-      "    </class>\n"
-      "\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:260
 #, no-c-format
 msgid "Similar to the <literal>id</literal> element, the <literal>name</literal> attribute of the <literal>property</literal> element tells Hibernate which getter and setter methods to use. In this case, Hibernate will search for <literal>getDate()</literal>, <literal>setDate()</literal>, <literal>getTitle()</literal> and <literal>setTitle()</literal> methods."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:271
 #, no-c-format
 msgid "Why does the <literal>date</literal> property mapping include the <literal>column</literal> attribute, but the <literal>title</literal> does not? Without the <literal>column</literal> attribute, Hibernate by default uses the property name as the column name. This works for <literal>title</literal>, however, <literal>date</literal> is a reserved keyword in most databases so you will need to map it to a different name."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:281
 #, no-c-format
 msgid "The <literal>title</literal> mapping also lacks a <literal>type</literal> attribute. The types declared and used in the mapping files are not Java data types; they are not SQL database types either. These types are called <emphasis>Hibernate mapping types</emphasis>, converters which can translate from Java to SQL data types and vice versa. Again, Hibernate will try to determine the correct conversion and mapping type itself if the <literal>type</literal> attribute is not present in the mapping. In some cases this automatic detection using Reflection on the Java class might not have the default you expect or need. This is the case with the <literal>date</literal> property. Hibernate cannot know if the property, which is of <literal>java.util.Date</literal>, should map to a SQL <literal>date</literal>, <literal>timestamp</literal>, or <literal>time</literal> column. Full date and time information is preserved by mapping the property with a <literal>timestamp</literal>!
  converter."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:297
 #, no-c-format
 msgid "Hibernate makes this mapping type determination using reflection when the mapping files are processed. This can take time and resources, so if startup performance is important you should consider explicitly defining the type to use."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:304
 #, no-c-format
 msgid "Save this mapping file as <filename>src/main/resources/org/hibernate/tutorial/domain/Event.hbm.xml</filename>."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:312
 #, no-c-format
 msgid "Hibernate configuration"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:314
 #, no-c-format
 msgid "At this point, you should have the persistent class and its mapping file in place. It is now time to configure Hibernate. First let's set up HSQLDB to run in \"server mode\""
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:321
 #, no-c-format
 msgid "We do this do that the data remains between runs."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:326
 #, no-c-format
 msgid "We will utilize the Maven exec plugin to launch the HSQLDB server by running: <command> mvn exec:java -Dexec.mainClass=\"org.hsqldb.Server\" -Dexec.args=\"-database.0 file:target/data/tutorial\"</command> You will see it start up and bind to a TCP/IP socket; this is where our application will connect later. If you want to start with a fresh database during this tutorial, shutdown HSQLDB, delete all files in the <filename>target/data</filename> directory, and start HSQLDB again."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:337
 #, no-c-format
 msgid "Hibernate will be connecting to the database on behalf of your application, so it needs to know how to obtain connections. For this tutorial we will be using a standalone connection pool (as opposed to a <interfacename>javax.sql.DataSource</interfacename>). Hibernate comes with support for two third-party open source JDBC connection pools: <ulink url=\"https://sourceforge.net/projects/c3p0\">c3p0</ulink> and <ulink url=\"http://proxool.sourceforge.net/\">proxool</ulink>. However, we will be using the Hibernate built-in connection pool for this tutorial."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:348
 #, no-c-format
 msgid "The built-in Hibernate connection pool is in no way intended for production use. It lacks several features found on any decent connection pool."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:354
 #, no-c-format
 msgid "For Hibernate's configuration, we can use a simple <literal>hibernate.properties</literal> file, a more sophisticated <literal>hibernate.cfg.xml</literal> file, or even complete programmatic setup. Most users prefer the XML configuration file:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:360
-#, no-c-format
-msgid ""
-      "<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-      "<!DOCTYPE hibernate-configuration PUBLIC\n"
-      "        \"-//Hibernate/Hibernate Configuration DTD 3.0//EN\"\n"
-      "        \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd\">\n"
-      "\n"
-      "<hibernate-configuration>\n"
-      "\n"
-      "    <session-factory>\n"
-      "\n"
-      "        <!-- Database connection settings -->\n"
-      "        <property name=\"connection.driver_class\">org.hsqldb.jdbcDriver</property>\n"
-      "        <property name=\"connection.url\">jdbc:hsqldb:hsql://localhost</property>\n"
-      "        <property name=\"connection.username\">sa</property>\n"
-      "        <property name=\"connection.password\"></property>\n"
-      "\n"
-      "        <!-- JDBC connection pool (use the built-in) -->\n"
-      "        <property name=\"connection.pool_size\">1</property>\n"
-      "\n"
-      "        <!-- SQL dialect -->\n"
-      "        <property name=\"dialect\">org.hibernate.dialect.HSQLDialect</property>\n"
-      "\n"
-      "        <!-- Enable Hibernate's automatic session context management -->\n"
-      "        <property name=\"current_session_context_class\">thread</property>\n"
-      "\n"
-      "        <!-- Disable the second-level cache  -->\n"
-      "        <property name=\"cache.provider_class\">org.hibernate.cache.NoCacheProvider</property>\n"
-      "\n"
-      "        <!-- Echo all executed SQL to stdout -->\n"
-      "        <property name=\"show_sql\">true</property>\n"
-      "\n"
-      "        <!-- Drop and re-create the database schema on startup -->\n"
-      "        <property name=\"hbm2ddl.auto\">update</property>\n"
-      "\n"
-      "        <mapping resource=\"org/hibernate/tutorial/domain/Event.hbm.xml\"/>\n"
-      "\n"
-      "    </session-factory>\n"
-      "\n"
-      "</hibernate-configuration>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:363
 #, no-c-format
 msgid "Notice that this configuration file specifies a different DTD"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:366
 #, no-c-format
 msgid "You configure Hibernate's <literal>SessionFactory</literal>. SessionFactory is a global factory responsible for a particular database. If you have several databases, for easier startup you should use several <literal>&lt;session-factory&gt;</literal> configurations in several configuration files."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:373
 #, no-c-format
 msgid "The first four <literal>property</literal> elements contain the necessary configuration for the JDBC connection. The dialect <literal>property</literal> element specifies the particular SQL variant Hibernate generates."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:380
 #, no-c-format
-msgid "In most cases, Hibernate is able to properly determine which dialect to use. See <xref linkend=\"portability-dialectresolver\"/> for more information."
+msgid "In most cases, Hibernate is able to properly determine which dialect to use. See <xref linkend=\"portability-dialectresolver\" /> for more information."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:386
 #, no-c-format
 msgid "Hibernate's automatic session management for persistence contexts is particularly useful in this context. The <literal>hbm2ddl.auto</literal> option turns on automatic generation of database schemas directly into the database. This can also be turned off by removing the configuration option, or redirected to a file with the help of the <literal>SchemaExport</literal> Ant task. Finally, add the mapping file(s) for persistent classes to the configuration."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:395
 #, no-c-format
 msgid "Save this file as <filename>hibernate.cfg.xml</filename> into the <filename>src/main/resources</filename> directory."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:403
 #, no-c-format
 msgid "Building with Maven"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:405
 #, no-c-format
 msgid "We will now build the tutorial with Maven. You will need to have Maven installed; it is available from the <ulink url=\"http://maven.apache.org/download.html\">Maven download page</ulink>. Maven will read the <filename>/pom.xml</filename> file we created earlier and know how to perform some basic project tasks. First, lets run the <literal>compile</literal> goal to make sure we can compile everything so far:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:415
-#, no-c-format
-msgid ""
-      "<![CDATA[[hibernateTutorial]$ mvn compile\n"
-      "[INFO] Scanning for projects...\n"
-      "[INFO] ------------------------------------------------------------------------\n"
-      "[INFO] Building First Hibernate Tutorial\n"
-      "[INFO]    task-segment: [compile]\n"
-      "[INFO] ------------------------------------------------------------------------\n"
-      "[INFO] [resources:resources]\n"
-      "[INFO] Using default encoding to copy filtered resources.\n"
-      "[INFO] [compiler:compile]\n"
-      "[INFO] Compiling 1 source file to /home/steve/projects/sandbox/hibernateTutorial/target/classes\n"
-      "[INFO] ------------------------------------------------------------------------\n"
-      "[INFO] BUILD SUCCESSFUL\n"
-      "[INFO] ------------------------------------------------------------------------\n"
-      "[INFO] Total time: 2 seconds\n"
-      "[INFO] Finished at: Tue Jun 09 12:25:25 CDT 2009\n"
-      "[INFO] Final Memory: 5M/547M\n"
-      "[INFO] ------------------------------------------------------------------------]]>"
-msgstr ""
-
 #. Tag: title
-#: tutorial.xml:420
 #, no-c-format
 msgid "Startup and helpers"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:422
 #, no-c-format
 msgid "It is time to load and store some <literal>Event</literal> objects, but first you have to complete the setup with some infrastructure code. You have to startup Hibernate by building a global <interfacename>org.hibernate.SessionFactory</interfacename> object and storing it somewhere for easy access in application code. A <interfacename>org.hibernate.SessionFactory</interfacename> is used to obtain <interfacename>org.hibernate.Session</interfacename> instances. A <interfacename>org.hibernate.Session</interfacename> represents a single-threaded unit of work. The <interfacename>org.hibernate.SessionFactory</interfacename> is a thread-safe global object that is instantiated once."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:436
 #, no-c-format
 msgid "We will create a <literal>HibernateUtil</literal> helper class that takes care of startup and makes accessing the <interfacename>org.hibernate.SessionFactory</interfacename> more convenient."
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:442
-#, no-c-format
-msgid ""
-      "<![CDATA[package org.hibernate.tutorial.util;\n"
-      "\n"
-      "import org.hibernate.SessionFactory;\n"
-      "import org.hibernate.cfg.Configuration;\n"
-      "\n"
-      "public class HibernateUtil {\n"
-      "\n"
-      "    private static final SessionFactory sessionFactory = buildSessionFactory();\n"
-      "\n"
-      "    private static SessionFactory buildSessionFactory() {\n"
-      "        try {\n"
-      "            // Create the SessionFactory from hibernate.cfg.xml\n"
-      "            return new Configuration().configure().buildSessionFactory();\n"
-      "        }\n"
-      "        catch (Throwable ex) {\n"
-      "            // Make sure you log the exception, as it might be swallowed\n"
-      "            System.err.println(\"Initial SessionFactory creation failed.\" + ex);\n"
-      "            throw new ExceptionInInitializerError(ex);\n"
-      "        }\n"
-      "    }\n"
-      "\n"
-      "    public static SessionFactory getSessionFactory() {\n"
-      "        return sessionFactory;\n"
-      "    }\n"
-      "\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:444
 #, no-c-format
 msgid "Save this code as <filename>src/main/java/org/hibernate/tutorial/util/HibernateUtil.java</filename>"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:449
 #, no-c-format
 msgid "This class not only produces the global <interfacename>org.hibernate.SessionFactory</interfacename> reference in its static initializer; it also hides the fact that it uses a static singleton. We might just as well have looked up the <interfacename>org.hibernate.SessionFactory</interfacename> reference from JNDI in an application server or any other location for that matter."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:458
 #, no-c-format
 msgid "If you give the <interfacename>org.hibernate.SessionFactory</interfacename> a name in your configuration, Hibernate will try to bind it to JNDI under that name after it has been built. Another, better option is to use a JMX deployment and let the JMX-capable container instantiate and bind a <literal>HibernateService</literal> to JNDI. Such advanced options are discussed later."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:467
 #, no-c-format
 msgid "You now need to configure a logging system. Hibernate uses commons logging and provides two choices: Log4j and JDK 1.4 logging. Most developers prefer Log4j: copy <literal>log4j.properties</literal> from the Hibernate distribution in the <literal>etc/</literal> directory to your <literal>src</literal> directory, next to <literal>hibernate.cfg.xml</literal>. If you prefer to have more verbose output than that provided in the example configuration, you can change the settings. By default, only the Hibernate startup message is shown on stdout."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:477
 #, no-c-format
 msgid "The tutorial infrastructure is complete and you are now ready to do some real work with Hibernate."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:485
 #, no-c-format
 msgid "Loading and storing objects"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:487
 #, no-c-format
 msgid "We are now ready to start doing some real worjk with Hibernate. Let's start by writing an <literal>EventManager</literal> class with a <literal>main()</literal> method:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:493
-#, no-c-format
-msgid ""
-      "<![CDATA[package org.hibernate.tutorial;\n"
-      "\n"
-      "import org.hibernate.Session;\n"
-      "\n"
-      "import java.util.*;\n"
-      "\n"
-      "import org.hibernate.tutorial.domain.Event;\n"
-      "import org.hibernate.tutorial.util.HibernateUtil;\n"
-      "\n"
-      "public class EventManager {\n"
-      "\n"
-      "    public static void main(String[] args) {\n"
-      "        EventManager mgr = new EventManager();\n"
-      "\n"
-      "        if (args[0].equals(\"store\")) {\n"
-      "            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-      "        }\n"
-      "\n"
-      "        HibernateUtil.getSessionFactory().close();\n"
-      "    }\n"
-      "\n"
-      "    private void createAndStoreEvent(String title, Date theDate) {\n"
-      "        Session session = HibernateUtil.getSessionFactory().getCurrentSession();\n"
-      "        session.beginTransaction();\n"
-      "\n"
-      "        Event theEvent = new Event();\n"
-      "        theEvent.setTitle(title);\n"
-      "        theEvent.setDate(theDate);\n"
-      "        session.save(theEvent);\n"
-      "\n"
-      "        session.getTransaction().commit();\n"
-      "    }\n"
-      "\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:495
 #, no-c-format
 msgid "In <literal>createAndStoreEvent()</literal> we created a new <literal>Event</literal> object and handed it over to Hibernate. At that point, Hibernate takes care of the SQL and executes an <literal>INSERT</literal> on the database."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:502
 #, no-c-format
 msgid "A <interface>org.hibernate.Session</interface> is designed to represent a single unit of work (a single atmoic piece of work to be performed). For now we will keep things simple and assume a one-to-one granularity between a Hibernate <interface>org.hibernate.Session</interface> and a database transaction. To shield our code from the actual underlying transaction system we use the Hibernate <interfacename>org.hibernate.Transaction</interfacename> API. In this particular case we are using JDBC-based transactional semantics, but it could also run with JTA."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:515
 #, no-c-format
 msgid "What does <literal>sessionFactory.getCurrentSession()</literal> do? First, you can call it as many times and anywhere you like once you get hold of your <interfacename>org.hibernate.SessionFactory</interfacename>. The <literal>getCurrentSession()</literal> method always returns the \"current\" unit of work. Remember that we switched the configuration option for this mechanism to \"thread\" in our <filename>src/main/resources/hibernate.cfg.xml</filename>? Due to that setting, the context of a current unit of work is bound to the current Java thread that executes the application."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:529
 #, no-c-format
 msgid "Hibernate offers three methods of current session tracking. The \"thread\" based method is not intended for production use; it is merely useful for prototyping and tutorials such as this one. Current session tracking is discussed in more detail later on."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:538
 #, no-c-format
 msgid "A <interface>org.hibernate.Session</interface> begins when the first call to <literal>getCurrentSession()</literal> is made for the current thread. It is then bound by Hibernate to the current thread. When the transaction ends, either through commit or rollback, Hibernate automatically unbinds the <interface>org.hibernate.Session</interface> from the thread and closes it for you. If you call <literal>getCurrentSession()</literal> again, you get a new <interface>org.hibernate.Session</interface> and can start a new unit of work."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:551
 #, no-c-format
 msgid "Related to the unit of work scope, should the Hibernate <interface>org.hibernate.Session</interface> be used to execute one or several database operations? The above example uses one <interface>org.hibernate.Session</interface> for one operation. However this is pure coincidence; the example is just not complex enough to show any other approach. The scope of a Hibernate <interface>org.hibernate.Session</interface> is flexible but you should never design your application to use a new Hibernate <interface>org.hibernate.Session</interface> for <emphasis>every</emphasis> database operation. Even though it is used in the following examples, consider <emphasis>session-per-operation</emphasis> an anti-pattern. A real web application is shown later in the tutorial which will help illustrate this."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:568
 #, no-c-format
-msgid "See <xref linkend=\"transactions\"/> for more information about transaction handling and demarcation. The previous example also skipped any error handling and rollback."
+msgid "See <xref linkend=\"transactions\" /> for more information about transaction handling and demarcation. The previous example also skipped any error handling and rollback."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:574
 #, no-c-format
 msgid "To run this, we will make use of the Maven exec plugin to call our class with the necessary classpath setup: <command>mvn exec:java -Dexec.mainClass=\"org.hibernate.tutorial.EventManager\" -Dexec.args=\"store\"</command>"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:581
 #, no-c-format
 msgid "You may need to perform <command>mvn compile</command> first."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:586
 #, no-c-format
 msgid "You should see Hibernate starting up and, depending on your configuration, lots of log output. Towards the end, the following line will be displayed:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:591
-#, no-c-format
-msgid "<![CDATA[[java] Hibernate: insert into EVENTS (EVENT_DATE, title, EVENT_ID) values (?, ?, ?)]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:593
 #, no-c-format
 msgid "This is the <literal>INSERT</literal> executed by Hibernate."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:597
 #, no-c-format
 msgid "To list stored events an option is added to the main method:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:601
-#, no-c-format
-msgid ""
-      "<![CDATA[        if (args[0].equals(\"store\")) {\n"
-      "            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-      "        }\n"
-      "        else if (args[0].equals(\"list\")) {\n"
-      "            List events = mgr.listEvents();\n"
-      "            for (int i = 0; i < events.size(); i++) {\n"
-      "                Event theEvent = (Event) events.get(i);\n"
-      "                System.out.println(\n"
-      "                        \"Event: \" + theEvent.getTitle() + \" Time: \" + theEvent.getDate()\n"
-      "                );\n"
-      "            }\n"
-      "        }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:603
 #, no-c-format
 msgid "A new <literal>listEvents() method is also added</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:607
-#, no-c-format
-msgid ""
-      "<![CDATA[    private List listEvents() {\n"
-      "        Session session = HibernateUtil.getSessionFactory().getCurrentSession();\n"
-      "        session.beginTransaction();\n"
-      "        List result = session.createQuery(\"from Event\").list();\n"
-      "        session.getTransaction().commit();\n"
-      "        return result;\n"
-      "    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:609
 #, no-c-format
-msgid "Here, we are using a Hibernate Query Language (HQL) query to load all existing <literal>Event</literal> objects from the database. Hibernate will generate the appropriate SQL, send it to the database and populate <literal>Event</literal> objects with the data. You can create more complex queries with HQL. See <xref linkend=\"queryhql\"/> for more information."
+msgid "Here, we are using a Hibernate Query Language (HQL) query to load all existing <literal>Event</literal> objects from the database. Hibernate will generate the appropriate SQL, send it to the database and populate <literal>Event</literal> objects with the data. You can create more complex queries with HQL. See <xref linkend=\"queryhql\" /> for more information."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:617
 #, no-c-format
 msgid "Now we can call our new functionality, again using the Maven exec plugin: <command>mvn exec:java -Dexec.mainClass=\"org.hibernate.tutorial.EventManager\" -Dexec.args=\"list\"</command>"
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:627
 #, no-c-format
 msgid "Part 2 - Mapping associations"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:629
 #, no-c-format
 msgid "So far we have mapped a single persistent entity class to a table in isolation. Let's expand on that a bit and add some class associations. We will add people to the application and store a list of events in which they participate."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:637
 #, no-c-format
 msgid "Mapping the Person class"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:639
 #, no-c-format
 msgid "The first cut of the <literal>Person</literal> class looks like this:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:643
-#, no-c-format
-msgid ""
-      "<![CDATA[package org.hibernate.tutorial.domain;\n"
-      "\n"
-      "public class Person {\n"
-      "\n"
-      "    private Long id;\n"
-      "    private int age;\n"
-      "    private String firstname;\n"
-      "    private String lastname;\n"
-      "\n"
-      "    public Person() {}\n"
-      "\n"
-      "    // Accessor methods for all properties, private setter for 'id'\n"
-      "\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:645
 #, no-c-format
 msgid "Save this to a file named <filename>src/main/java/org/hibernate/tutorial/domain/Person.java</filename>"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:650
 #, no-c-format
 msgid "Next, create the new mapping file as <filename>src/main/resources/org/hibernate/tutorial/domain/Person.hbm.xml</filename>"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:655
-#, no-c-format
-msgid ""
-      "<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-      "\n"
-      "    <class name=\"Person\" table=\"PERSON\">\n"
-      "        <id name=\"id\" column=\"PERSON_ID\">\n"
-      "            <generator class=\"native\"/>\n"
-      "        </id>\n"
-      "        <property name=\"age\"/>\n"
-      "        <property name=\"firstname\"/>\n"
-      "        <property name=\"lastname\"/>\n"
-      "    </class>\n"
-      "\n"
-      "</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:657
 #, no-c-format
 msgid "Finally, add the new mapping to Hibernate's configuration:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:661
-#, no-c-format
-msgid ""
-      "<![CDATA[<mapping resource=\"events/Event.hbm.xml\"/>\n"
-      "<mapping resource=\"events/Person.hbm.xml\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:663
 #, no-c-format
 msgid "Create an association between these two entities. Persons can participate in events, and events have participants. The design questions you have to deal with are: directionality, multiplicity, and collection behavior."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:673
 #, no-c-format
 msgid "A unidirectional Set-based association"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:675
 #, no-c-format
 msgid "By adding a collection of events to the <literal>Person</literal> class, you can easily navigate to the events for a particular person, without executing an explicit query - by calling <literal>Person#getEvents</literal>. Multi-valued associations are represented in Hibernate by one of the Java Collection Framework contracts; here we choose a <interfacename>java.util.Set</interfacename> because the collection will not contain duplicate elements and the ordering is not relevant to our examples:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:686
-#, no-c-format
-msgid ""
-      "<![CDATA[public class Person {\n"
-      "\n"
-      "    private Set events = new HashSet();\n"
-      "\n"
-      "    public Set getEvents() {\n"
-      "        return events;\n"
-      "    }\n"
-      "\n"
-      "    public void setEvents(Set events) {\n"
-      "        this.events = events;\n"
-      "    }\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:688
 #, no-c-format
 msgid "Before mapping this association, let's consider the other side. We could just keep this unidirectional or create another collection on the <literal>Event</literal>, if we wanted to be able to navigate it from both directions. This is not necessary, from a functional perspective. You can always execute an explicit query to retrieve the participants for a particular event. This is a design choice left to you, but what is clear from this discussion is the multiplicity of the association: \"many\" valued on both sides is called a <emphasis>many-to-many</emphasis> association. Hence, we use Hibernate's many-to-many mapping:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:701
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Person\" table=\"PERSON\">\n"
-      "    <id name=\"id\" column=\"PERSON_ID\">\n"
-      "        <generator class=\"native\"/>\n"
-      "    </id>\n"
-      "    <property name=\"age\"/>\n"
-      "    <property name=\"firstname\"/>\n"
-      "    <property name=\"lastname\"/>\n"
-      "\n"
-      "    <set name=\"events\" table=\"PERSON_EVENT\">\n"
-      "        <key column=\"PERSON_ID\"/>\n"
-      "        <many-to-many column=\"EVENT_ID\" class=\"Event\"/>\n"
-      "    </set>\n"
-      "\n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:703
 #, no-c-format
 msgid "Hibernate supports a broad range of collection mappings, a <literal>set</literal> being most common. For a many-to-many association, or <emphasis>n:m</emphasis> entity relationship, an association table is required. Each row in this table represents a link between a person and an event. The table name is decalred using the <literal>table</literal> attribute of the <literal>set</literal> element. The identifier column name in the association, for the person side, is defined with the <literal>key</literal> element, the column name for the event's side with the <literal>column</literal> attribute of the <literal>many-to-many</literal>. You also have to tell Hibernate the class of the objects in your collection (the class on the other side of the collection of references)."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:719
 #, no-c-format
 msgid "The database schema for this mapping is therefore:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:723
-#, no-c-format
-msgid ""
-      "<![CDATA[\n"
-      "    _____________        __________________\n"
-      "   |             |      |                  |       _____________\n"
-      "   |   EVENTS    |      |   PERSON_EVENT   |      |             |\n"
-      "   |_____________|      |__________________|      |    PERSON   |\n"
-      "   |             |      |                  |      |_____________|\n"
-      "   | *EVENT_ID   | <--> | *EVENT_ID        |      |             |\n"
-      "   |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  |\n"
-      "   |  TITLE      |      |__________________|      |  AGE        |\n"
-      "   |_____________|                                |  FIRSTNAME  |\n"
-      "                                                  |  LASTNAME   |\n"
-      "                                                  |_____________|\n"
-      " ]]>"
-msgstr ""
-
 #. Tag: title
-#: tutorial.xml:728
 #, no-c-format
 msgid "Working the association"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:730
 #, no-c-format
 msgid "Now we will bring some people and events together in a new method in <literal>EventManager</literal>:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:734
-#, no-c-format
-msgid ""
-      "<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) {\n"
-      "        Session session = HibernateUtil.getSessionFactory().getCurrentSession();\n"
-      "        session.beginTransaction();\n"
-      "\n"
-      "        Person aPerson = (Person) session.load(Person.class, personId);\n"
-      "        Event anEvent = (Event) session.load(Event.class, eventId);\n"
-      "        aPerson.getEvents().add(anEvent);\n"
-      "\n"
-      "        session.getTransaction().commit();\n"
-      "    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:736
 #, no-c-format
 msgid "After loading a <literal>Person</literal> and an <literal>Event</literal>, simply modify the collection using the normal collection methods. There is no explicit call to <literal>update()</literal> or <literal>save()</literal>; Hibernate automatically detects that the collection has been modified and needs to be updated. This is called <emphasis>automatic dirty checking</emphasis>. You can also try it by modifying the name or the date property of any of your objects. As long as they are in <emphasis>persistent</emphasis> state, that is, bound to a particular Hibernate <interfacename>org.hibernate.Session</interfacename>, Hibernate monitors any changes and executes SQL in a write-behind fashion. The process of synchronizing the memory state with the database, usually only at the end of a unit of work, is called <emphasis>flushing</emphasis>. In our code, the unit of work ends with a commit, or rollback, of the database transaction."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:755
 #, no-c-format
 msgid "You can load person and event in different units of work. Or you can modify an object outside of a <interfacename>org.hibernate.Session</interfacename>, when it is not in persistent state (if it was persistent before, this state is called <emphasis>detached</emphasis>). You can even modify a collection when it is detached:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:764
-#, no-c-format
-msgid ""
-      "<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) {\n"
-      "        Session session = HibernateUtil.getSessionFactory().getCurrentSession();\n"
-      "        session.beginTransaction();\n"
-      "\n"
-      "        Person aPerson = (Person) session\n"
-      "                .createQuery(\"select p from Person p left join fetch p.events where p.id = :pid\")\n"
-      "                .setParameter(\"pid\", personId)\n"
-      "                .uniqueResult(); // Eager fetch the collection so we can use it detached\n"
-      "        Event anEvent = (Event) session.load(Event.class, eventId);\n"
-      "\n"
-      "        session.getTransaction().commit();\n"
-      "\n"
-      "        // End of first unit of work\n"
-      "\n"
-      "        aPerson.getEvents().add(anEvent); // aPerson (and its collection) is detached\n"
-      "\n"
-      "        // Begin second unit of work\n"
-      "\n"
-      "        Session session2 = HibernateUtil.getSessionFactory().getCurrentSession();\n"
-      "        session2.beginTransaction();\n"
-      "        session2.update(aPerson); // Reattachment of aPerson\n"
-      "\n"
-      "        session2.getTransaction().commit();\n"
-      "    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:766
 #, no-c-format
 msgid "The call to <literal>update</literal> makes a detached object persistent again by binding it to a new unit of work, so any modifications you made to it while detached can be saved to the database. This includes any modifications (additions/deletions) you made to a collection of that entity object."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:775
 #, no-c-format
 msgid "This is not much use in our example, but it is an important concept you can incorporate into your own application. Complete this exercise by adding a new action to the main method of the <literal>EventManager</literal> and call it from the command line. If you need the identifiers of a person and an event - the <literal>save()</literal> method returns it (you might have to modify some of the previous methods to return that identifier):"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:783
-#, no-c-format
-msgid ""
-      "<![CDATA[        else if (args[0].equals(\"addpersontoevent\")) {\n"
-      "            Long eventId = mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-      "            Long personId = mgr.createAndStorePerson(\"Foo\", \"Bar\");\n"
-      "            mgr.addPersonToEvent(personId, eventId);\n"
-      "            System.out.println(\"Added person \" + personId + \" to event \" + eventId);\n"
-      "        }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:785
 #, no-c-format
 msgid "This is an example of an association between two equally important classes : two entities. As mentioned earlier, there are other classes and types in a typical model, usually \"less important\". Some you have already seen, like an <literal>int</literal> or a <classname>java.lang.String</classname>. We call these classes <emphasis>value types</emphasis>, and their instances <emphasis>depend</emphasis> on a particular entity. Instances of these types do not have their own identity, nor are they shared between entities. Two persons do not reference the same <literal>firstname</literal> object, even if they have the same first name. Value types cannot only be found in the JDK , but you can also write dependent classes yourself such as an <literal>Address</literal> or <literal>MonetaryAmount</literal> class. In fact, in a Hibernate application all JDK classes are considered value types."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:803
 #, no-c-format
 msgid "You can also design a collection of value types. This is conceptually different from a collection of references to other entities, but looks almost the same in Java."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:812
 #, no-c-format
 msgid "Collection of values"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:814
 #, no-c-format
 msgid "Let's add a collection of email addresses to the <literal>Person</literal> entity. This will be represented as a <interfacename>java.util.Set</interfacename> of <classname>java.lang.String</classname> instances:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:820
-#, no-c-format
-msgid ""
-      "<![CDATA[    private Set emailAddresses = new HashSet();\n"
-      "\n"
-      "    public Set getEmailAddresses() {\n"
-      "        return emailAddresses;\n"
-      "    }\n"
-      "\n"
-      "    public void setEmailAddresses(Set emailAddresses) {\n"
-      "        this.emailAddresses = emailAddresses;\n"
-      "    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:822
 #, no-c-format
 msgid "The mapping of this <literal>Set</literal> is as follows:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:826
-#, no-c-format
-msgid ""
-      "<![CDATA[        <set name=\"emailAddresses\" table=\"PERSON_EMAIL_ADDR\">\n"
-      "            <key column=\"PERSON_ID\"/>\n"
-      "            <element type=\"string\" column=\"EMAIL_ADDR\"/>\n"
-      "        </set>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:828
 #, no-c-format
 msgid "The difference compared with the earlier mapping is the use of the <literal>element</literal> part which tells Hibernate that the collection does not contain references to another entity, but is rather a collection whose elements are values types, here specifically of type <literal>string</literal>. The lowercase name tells you it is a Hibernate mapping type/converter. Again the <literal>table</literal> attribute of the <literal>set</literal> element determines the table name for the collection. The <literal>key</literal> element defines the foreign-key column name in the collection table. The <literal>column</literal> attribute in the <literal>element</literal> element defines the column name where the email address values will actually be stored."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:844
 #, no-c-format
 msgid "Here is the updated schema:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:848
-#, no-c-format
-msgid ""
-      "<![CDATA[\n"
-      "  _____________        __________________\n"
-      " |             |      |                  |       _____________\n"
-      " |   EVENTS    |      |   PERSON_EVENT   |      |             |       ___________________\n"
-      " |_____________|      |__________________|      |    PERSON   |      |                   |\n"
-      " |             |      |                  |      |_____________|      | PERSON_EMAIL_ADDR |\n"
-      " | *EVENT_ID   | <--> | *EVENT_ID        |      |             |      |___________________|\n"
-      " |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  | <--> |  *PERSON_ID       |\n"
-      " |  TITLE      |      |__________________|      |  AGE        |      |  *EMAIL_ADDR      |\n"
-      " |_____________|                                |  FIRSTNAME  |      |___________________|\n"
-      "                                                |  LASTNAME   |\n"
-      "                                                |_____________|\n"
-      " ]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:850
 #, no-c-format
 msgid "You can see that the primary key of the collection table is in fact a composite key that uses both columns. This also implies that there cannot be duplicate email addresses per person, which is exactly the semantics we need for a set in Java."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:856
 #, no-c-format
 msgid "You can now try to add elements to this collection, just like we did before by linking persons and events. It is the same code in Java:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:861
-#, no-c-format
-msgid ""
-      "<![CDATA[    private void addEmailToPerson(Long personId, String emailAddress) {\n"
-      "        Session session = HibernateUtil.getSessionFactory().getCurrentSession();\n"
-      "        session.beginTransaction();\n"
-      "\n"
-      "        Person aPerson = (Person) session.load(Person.class, personId);\n"
-      "        // adding to the emailAddress collection might trigger a lazy load of the collection\n"
-      "        aPerson.getEmailAddresses().add(emailAddress);\n"
-      "\n"
-      "        session.getTransaction().commit();\n"
-      "    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:863
 #, no-c-format
 msgid "This time we did not use a <emphasis>fetch</emphasis> query to initialize the collection. Monitor the SQL log and try to optimize this with an eager fetch."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:872
 #, no-c-format
 msgid "Bi-directional associations"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:874
 #, no-c-format
 msgid "Next you will map a bi-directional association. You will make the association between person and event work from both sides in Java. The database schema does not change, so you will still have many-to-many multiplicity."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:882
 #, no-c-format
 msgid "A relational database is more flexible than a network programming language, in that it does not need a navigation direction; data can be viewed and retrieved in any possible way."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:890
 #, no-c-format
 msgid "First, add a collection of participants to the <literal>Event</literal> class:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:895
-#, no-c-format
-msgid ""
-      "<![CDATA[    private Set participants = new HashSet();\n"
-      "\n"
-      "    public Set getParticipants() {\n"
-      "        return participants;\n"
-      "    }\n"
-      "\n"
-      "    public void setParticipants(Set participants) {\n"
-      "        this.participants = participants;\n"
-      "    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:897
 #, no-c-format
 msgid "Now map this side of the association in <literal>Event.hbm.xml</literal>."
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:901
-#, no-c-format
-msgid ""
-      "<![CDATA[        <set name=\"participants\" table=\"PERSON_EVENT\" inverse=\"true\">\n"
-      "            <key column=\"EVENT_ID\"/>\n"
-      "            <many-to-many column=\"PERSON_ID\" class=\"events.Person\"/>\n"
-      "        </set>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:903
 #, no-c-format
 msgid "These are normal <literal>set</literal> mappings in both mapping documents. Notice that the column names in <literal>key</literal> and <literal>many-to-many</literal> swap in both mapping documents. The most important addition here is the <literal>inverse=\"true\"</literal> attribute in the <literal>set</literal> element of the <literal>Event</literal>'s collection mapping."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:911
 #, no-c-format
 msgid "What this means is that Hibernate should take the other side, the <literal>Person</literal> class, when it needs to find out information about the link between the two. This will be a lot easier to understand once you see how the bi-directional link between our two entities is created."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:920
 #, no-c-format
 msgid "Working bi-directional links"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:922
 #, no-c-format
 msgid "First, keep in mind that Hibernate does not affect normal Java semantics. How did we create a link between a <literal>Person</literal> and an <literal>Event</literal> in the unidirectional example? You add an instance of <literal>Event</literal> to the collection of event references, of an instance of <literal>Person</literal>. If you want to make this link bi-directional, you have to do the same on the other side by adding a <literal>Person</literal> reference to the collection in an <literal>Event</literal>. This process of \"setting the link on both sides\" is absolutely necessary with bi-directional links."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:932
 #, no-c-format
 msgid "Many developers program defensively and create link management methods to correctly set both sides (for example, in <literal>Person</literal>):"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:937
-#, no-c-format
-msgid ""
-      "<![CDATA[    protected Set getEvents() {\n"
-      "        return events;\n"
-      "    }\n"
-      "\n"
-      "    protected void setEvents(Set events) {\n"
-      "        this.events = events;\n"
-      "    }\n"
-      "\n"
-      "    public void addToEvent(Event event) {\n"
-      "        this.getEvents().add(event);\n"
-      "        event.getParticipants().add(this);\n"
-      "    }\n"
-      "\n"
-      "    public void removeFromEvent(Event event) {\n"
-      "        this.getEvents().remove(event);\n"
-      "        event.getParticipants().remove(this);\n"
-      "    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:939
 #, no-c-format
 msgid "The get and set methods for the collection are now protected. This allows classes in the same package and subclasses to still access the methods, but prevents everybody else from altering the collections directly. Repeat the steps for the collection on the other side."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:946
 #, no-c-format
 msgid "What about the <literal>inverse</literal> mapping attribute? For you, and for Java, a bi-directional link is simply a matter of setting the references on both sides correctly. Hibernate, however, does not have enough information to correctly arrange SQL <literal>INSERT</literal> and <literal>UPDATE</literal> statements (to avoid constraint violations). Making one side of the association <literal>inverse</literal> tells Hibernate to consider it a <emphasis>mirror</emphasis> of the other side. That is all that is necessary for Hibernate to resolve any issues that arise when transforming a directional navigation model to a SQL database schema. The rules are straightforward: all bi-directional associations need one side as <literal>inverse</literal>. In a one-to-many association it has to be the many-side, and in many-to-many association you can select either side."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:962
 #, no-c-format
 msgid "Part 3 - The EventManager web application"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:964
 #, no-c-format
 msgid "A Hibernate web application uses <literal>Session</literal> and <literal>Transaction</literal> almost like a standalone application. However, some common patterns are useful. You can now write an <literal>EventManagerServlet</literal>. This servlet can list all events stored in the database, and it provides an HTML form to enter new events."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:972
 #, no-c-format
 msgid "Writing the basic servlet"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:974
 #, no-c-format
 msgid "First we need create our basic processing servlet. Since our servlet only handles HTTP <literal>GET</literal> requests, we will only implement the <literal>doGet()</literal> method:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:980
-#, no-c-format
-msgid ""
-      "<![CDATA[package org.hibernate.tutorial.web;\n"
-      "\n"
-      "// Imports\n"
-      "\n"
-      "public class EventManagerServlet extends HttpServlet {\n"
-      "\n"
-      "    protected void doGet(\n"
-      "            HttpServletRequest request,\n"
-      "            HttpServletResponse response) throws ServletException, IOException {\n"
-      "\n"
-      "        SimpleDateFormat dateFormatter = new SimpleDateFormat( \"dd.MM.yyyy\" );\n"
-      "\n"
-      "        try {\n"
-      "            // Begin unit of work\n"
-      "            HibernateUtil.getSessionFactory().getCurrentSession().beginTransaction();\n"
-      "\n"
-      "            // Process request and render page...\n"
-      "\n"
-      "            // End unit of work\n"
-      "            HibernateUtil.getSessionFactory().getCurrentSession().getTransaction().commit();\n"
-      "        }\n"
-      "        catch (Exception ex) {\n"
-      "            HibernateUtil.getSessionFactory().getCurrentSession().getTransaction().rollback();\n"
-      "            if ( ServletException.class.isInstance( ex ) ) {\n"
-      "                throw ( ServletException ) ex;\n"
-      "            }\n"
-      "            else {\n"
-      "                throw new ServletException( ex );\n"
-      "            }\n"
-      "        }\n"
-      "    }\n"
-      "\n"
-      "}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:982
 #, no-c-format
 msgid "Save this servlet as <filename>src/main/java/org/hibernate/tutorial/web/EventManagerServlet.java</filename>"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:987
 #, no-c-format
 msgid "The pattern applied here is called <emphasis>session-per-request</emphasis>. When a request hits the servlet, a new Hibernate <literal>Session</literal> is opened through the first call to <literal>getCurrentSession()</literal> on the <literal>SessionFactory</literal>. A database transaction is then started. All data access occurs inside a transaction irrespective of whether the data is read or written. Do not use the auto-commit mode in applications."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:996
 #, no-c-format
 msgid "Do <emphasis>not</emphasis> use a new Hibernate <literal>Session</literal> for every database operation. Use one Hibernate <literal>Session</literal> that is scoped to the whole request. Use <literal>getCurrentSession()</literal>, so that it is automatically bound to the current Java thread."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:1003
 #, no-c-format
 msgid "Next, the possible actions of the request are processed and the response HTML is rendered. We will get to that part soon."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:1008
 #, no-c-format
 msgid "Finally, the unit of work ends when processing and rendering are complete. If any problems occurred during processing or rendering, an exception will be thrown and the database transaction rolled back. This completes the <literal>session-per-request</literal> pattern. Instead of the transaction demarcation code in every servlet, you could also write a servlet filter. See the Hibernate website and Wiki for more information about this pattern called <emphasis>Open Session in View</emphasis>. You will need it as soon as you consider rendering your view in JSP, not in a servlet."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:1022
 #, no-c-format
 msgid "Processing and rendering"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:1024
 #, no-c-format
 msgid "Now you can implement the processing of the request and the rendering of the page."
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:1028
-#, no-c-format
-msgid ""
-      "<![CDATA[        // Write HTML header\n"
-      "        PrintWriter out = response.getWriter();\n"
-      "        out.println(\"<html><head><title>Event Manager</title></head><body>\");\n"
-      "\n"
-      "        // Handle actions\n"
-      "        if ( \"store\".equals(request.getParameter(\"action\")) ) {\n"
-      "\n"
-      "            String eventTitle = request.getParameter(\"eventTitle\");\n"
-      "            String eventDate = request.getParameter(\"eventDate\");\n"
-      "\n"
-      "            if ( \"\".equals(eventTitle) || \"\".equals(eventDate) ) {\n"
-      "                out.println(\"<b><i>Please enter event title and date.</i></b>\");\n"
-      "            }\n"
-      "            else {\n"
-      "                createAndStoreEvent(eventTitle, dateFormatter.parse(eventDate));\n"
-      "                out.println(\"<b><i>Added event.</i></b>\");\n"
-      "            }\n"
-      "        }\n"
-      "\n"
-      "        // Print page\n"
-      "       printEventForm(out);\n"
-      "       listEvents(out, dateFormatter);\n"
-      "\n"
-      "       // Write HTML footer\n"
-      "       out.println(\"</body></html>\");\n"
-      "       out.flush();\n"
-      "       out.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1030
 #, no-c-format
 msgid "This coding style, with a mix of Java and HTML, would not scale in a more complex application&mdash;keep in mind that we are only illustrating basic Hibernate concepts in this tutorial. The code prints an HTML header and a footer. Inside this page, an HTML form for event entry and a list of all events in the database are printed. The first method is trivial and only outputs HTML:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:1039
-#, no-c-format
-msgid ""
-      "<![CDATA[    private void printEventForm(PrintWriter out) {\n"
-      "        out.println(\"<h2>Add new event:</h2>\");\n"
-      "        out.println(\"<form>\");\n"
-      "        out.println(\"Title: <input name='eventTitle' length='50'/><br/>\");\n"
-      "        out.println(\"Date (e.g. 24.12.2009): <input name='eventDate' length='10'/><br/>\");\n"
-      "        out.println(\"<input type='submit' name='action' value='store'/>\");\n"
-      "        out.println(\"</form>\");\n"
-      "    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1041
 #, no-c-format
 msgid "The <literal>listEvents()</literal> method uses the Hibernate <literal>Session</literal> bound to the current thread to execute a query:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:1047
-#, no-c-format
-msgid ""
-      "<![CDATA[    private void listEvents(PrintWriter out, SimpleDateFormat dateFormatter) {\n"
-      "\n"
-      "        List result = HibernateUtil.getSessionFactory()\n"
-      "                .getCurrentSession().createCriteria(Event.class).list();\n"
-      "        if (result.size() > 0) {\n"
-      "            out.println(\"<h2>Events in database:</h2>\");\n"
-      "            out.println(\"<table border='1'>\");\n"
-      "            out.println(\"<tr>\");\n"
-      "            out.println(\"<th>Event title</th>\");\n"
-      "            out.println(\"<th>Event date</th>\");\n"
-      "            out.println(\"</tr>\");\n"
-      "            Iterator it = result.iterator();\n"
-      "            while (it.hasNext()) {\n"
-      "                Event event = (Event) it.next();\n"
-      "                out.println(\"<tr>\");\n"
-      "                out.println(\"<td>\" + event.getTitle() + \"</td>\");\n"
-      "                out.println(\"<td>\" + dateFormatter.format(event.getDate()) + \"</td>\");\n"
-      "                out.println(\"</tr>\");\n"
-      "            }\n"
-      "            out.println(\"</table>\");\n"
-      "        }\n"
-      "    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1049
 #, no-c-format
 msgid "Finally, the <literal>store</literal> action is dispatched to the <literal>createAndStoreEvent()</literal> method, which also uses the <literal>Session</literal> of the current thread:"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:1055
-#, no-c-format
-msgid ""
-      "<![CDATA[    protected void createAndStoreEvent(String title, Date theDate) {\n"
-      "        Event theEvent = new Event();\n"
-      "        theEvent.setTitle(title);\n"
-      "        theEvent.setDate(theDate);\n"
-      "\n"
-      "        HibernateUtil.getSessionFactory()\n"
-      "                .getCurrentSession().save(theEvent);\n"
-      "    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1057
 #, no-c-format
 msgid "The servlet is now complete. A request to the servlet will be processed in a single <literal>Session</literal> and <literal>Transaction</literal>. As earlier in the standalone application, Hibernate can automatically bind these objects to the current thread of execution. This gives you the freedom to layer your code and access the <literal>SessionFactory</literal> in any way you like. Usually you would use a more sophisticated design and move the data access code into data access objects (the DAO pattern). See the Hibernate Wiki for more examples."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:1071
 #, no-c-format
 msgid "Deploying and testing"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:1073
 #, no-c-format
 msgid "To deploy this application for testing we must create a Web ARchive (WAR). First we must define the WAR descriptor as <filename>src/main/webapp/WEB-INF/web.xml</filename>"
 msgstr ""
 
-#. Tag: programlisting
-#: tutorial.xml:1079
-#, no-c-format
-msgid ""
-      "<![CDATA[<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
-      "<web-app version=\"2.4\"\n"
-      "    xmlns=\"http://java.sun.com/xml/ns/j2ee\"\n"
-      "    xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
-      "    xsi:schemaLocation=\"http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd\">\n"
-      "\n"
-      "    <servlet>\n"
-      "        <servlet-name>Event Manager</servlet-name>\n"
-      "        <servlet-class>org.hibernate.tutorial.web.EventManagerServlet</servlet-class>\n"
-      "    </servlet>\n"
-      "\n"
-      "    <servlet-mapping>\n"
-      "        <servlet-name>Event Manager</servlet-name>\n"
-      "        <url-pattern>/eventmanager</url-pattern>\n"
-      "    </servlet-mapping>\n"
-      "</web-app>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1081
 #, no-c-format
 msgid "To build and deploy call <literal>mvn package</literal> in your project directory and copy the <filename>hibernate-tutorial.war</filename> file into your Tomcat <filename>webapps</filename> directory."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:1088
 #, no-c-format
-msgid "If you do not have Tomcat installed, download it from <ulink url=\"http://tomcat.apache.org/\"></ulink> and follow the installation instructions. Our application requires no changes to the standard Tomcat configuration."
+msgid "If you do not have Tomcat installed, download it from <ulink url=\"http://tomcat.apache.org/\" /> and follow the installation instructions. Our application requires no changes to the standard Tomcat configuration."
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:1096
 #, no-c-format
 msgid "Once deployed and Tomcat is running, access the application at <literal>http://localhost:8080/hibernate-tutorial/eventmanager</literal>. Make sure you watch the Tomcat log to see Hibernate initialize when the first request hits your servlet (the static initializer in <literal>HibernateUtil</literal> is called) and to get the detailed output if any exceptions occurs."
 msgstr ""
 
 #. Tag: title
-#: tutorial.xml:1109
 #, no-c-format
 msgid "Summary"
 msgstr ""
 
 #. Tag: para
-#: tutorial.xml:1111
 #, no-c-format
 msgid "This tutorial covered the basics of writing a simple standalone Hibernate application and a small web application. More tutorials are available from the Hibernate <ulink url=\"http://hibernate.org\">website</ulink>."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/content/xml.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/content/xml.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/content/xml.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,355 +1,143 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-02-11T05:38:16\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: xml.xml:29
 #, no-c-format
 msgid "XML Mapping"
 msgstr ""
 
-#. Tag: emphasis
-#: xml.xml:31
+#. Tag: para
 #, no-c-format
-msgid "XML Mapping is an experimental feature in Hibernate 3.0 and is currently under active development."
+msgid "<emphasis> XML Mapping is an experimental feature in Hibernate 3.0 and is currently under active development. </emphasis>"
 msgstr ""
 
 #. Tag: title
-#: xml.xml:37
 #, no-c-format
 msgid "Working with XML data"
 msgstr ""
 
 #. Tag: para
-#: xml.xml:39
 #, no-c-format
 msgid "Hibernate allows you to work with persistent XML data in much the same way you work with persistent POJOs. A parsed XML tree can be thought of as another way of representing the relational data at the object level, instead of POJOs."
 msgstr ""
 
 #. Tag: para
-#: xml.xml:46
 #, no-c-format
 msgid "Hibernate supports dom4j as API for manipulating XML trees. You can write queries that retrieve dom4j trees from the database and have any modification you make to the tree automatically synchronized to the database. You can even take an XML document, parse it using dom4j, and write it to the database with any of Hibernate's basic operations: <literal>persist(), saveOrUpdate(), merge(), delete(), replicate()</literal> (merging is not yet supported)."
 msgstr ""
 
 #. Tag: para
-#: xml.xml:56
 #, no-c-format
 msgid "This feature has many applications including data import/export, externalization of entity data via JMS or SOAP and XSLT-based reporting."
 msgstr ""
 
 #. Tag: para
-#: xml.xml:61
 #, no-c-format
 msgid "A single mapping can be used to simultaneously map properties of a class and nodes of an XML document to the database, or, if there is no class to map, it can be used to map just the XML."
 msgstr ""
 
 #. Tag: title
-#: xml.xml:68
 #, no-c-format
 msgid "Specifying XML and class mapping together"
 msgstr ""
 
 #. Tag: para
-#: xml.xml:70
 #, no-c-format
 msgid "Here is an example of mapping a POJO and XML simultaneously:"
 msgstr ""
 
-#. Tag: programlisting
-#: xml.xml:74
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Account\" \n"
-      "        table=\"ACCOUNTS\" \n"
-      "        node=\"account\">\n"
-      "        \n"
-      "    <id name=\"accountId\" \n"
-      "            column=\"ACCOUNT_ID\" \n"
-      "            node=\"@id\"/>\n"
-      "            \n"
-      "    <many-to-one name=\"customer\" \n"
-      "            column=\"CUSTOMER_ID\" \n"
-      "            node=\"customer/@id\" \n"
-      "            embed-xml=\"false\"/>\n"
-      "            \n"
-      "    <property name=\"balance\" \n"
-      "            column=\"BALANCE\" \n"
-      "            node=\"balance\"/>\n"
-      "            \n"
-      "    ...\n"
-      "    \n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: xml.xml:78
 #, no-c-format
 msgid "Specifying only an XML mapping"
 msgstr ""
 
 #. Tag: para
-#: xml.xml:80
 #, no-c-format
 msgid "Here is an example where there is no POJO class:"
 msgstr ""
 
-#. Tag: programlisting
-#: xml.xml:84
-#, no-c-format
-msgid ""
-      "<![CDATA[<class entity-name=\"Account\" \n"
-      "        table=\"ACCOUNTS\" \n"
-      "        node=\"account\">\n"
-      "        \n"
-      "    <id name=\"id\" \n"
-      "            column=\"ACCOUNT_ID\" \n"
-      "            node=\"@id\" \n"
-      "            type=\"string\"/>\n"
-      "            \n"
-      "    <many-to-one name=\"customerId\" \n"
-      "            column=\"CUSTOMER_ID\" \n"
-      "            node=\"customer/@id\" \n"
-      "            embed-xml=\"false\" \n"
-      "            entity-name=\"Customer\"/>\n"
-      "            \n"
-      "    <property name=\"balance\" \n"
-      "            column=\"BALANCE\" \n"
-      "            node=\"balance\" \n"
-      "            type=\"big_decimal\"/>\n"
-      "            \n"
-      "    ...\n"
-      "    \n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:86
 #, no-c-format
 msgid "This mapping allows you to access the data as a dom4j tree, or as a graph of property name/value pairs or java <literal>Map</literal>s. The property names are purely logical constructs that can be referred to in HQL queries."
 msgstr ""
 
 #. Tag: title
-#: xml.xml:97
 #, no-c-format
 msgid "XML mapping metadata"
 msgstr ""
 
 #. Tag: para
-#: xml.xml:99
 #, no-c-format
 msgid "A range of Hibernate mapping elements accept the <literal>node</literal> attribute. This lets you specify the name of an XML attribute or element that holds the property or entity data. The format of the <literal>node</literal> attribute must be one of the following:"
 msgstr ""
 
 #. Tag: para
-#: xml.xml:108
 #, no-c-format
 msgid "<literal>\"element-name\"</literal>: map to the named XML element"
 msgstr ""
 
 #. Tag: para
-#: xml.xml:111
 #, no-c-format
 msgid "<literal>\"@attribute-name\"</literal>: map to the named XML attribute"
 msgstr ""
 
 #. Tag: para
-#: xml.xml:114
 #, no-c-format
 msgid "<literal>\".\"</literal>: map to the parent element"
 msgstr ""
 
 #. Tag: para
-#: xml.xml:117
 #, no-c-format
 msgid "<literal>\"element-name/@attribute-name\"</literal>: map to the named attribute of the named element"
 msgstr ""
 
 #. Tag: para
-#: xml.xml:124
 #, no-c-format
 msgid "For collections and single valued associations, there is an additional <literal>embed-xml</literal> attribute. If <literal>embed-xml=\"true\"</literal>, the default, the XML tree for the associated entity (or collection of value type) will be embedded directly in the XML tree for the entity that owns the association. Otherwise, if <literal>embed-xml=\"false\"</literal>, then only the referenced identifier value will appear in the XML for single point associations and collections will not appear at all."
 msgstr ""
 
 #. Tag: para
-#: xml.xml:134
 #, no-c-format
 msgid "Do not leave <literal>embed-xml=\"true\"</literal> for too many associations, since XML does not deal well with circularity."
 msgstr ""
 
-#. Tag: programlisting
-#: xml.xml:139
-#, no-c-format
-msgid ""
-      "<![CDATA[<class name=\"Customer\" \n"
-      "        table=\"CUSTOMER\" \n"
-      "        node=\"customer\">\n"
-      "        \n"
-      "    <id name=\"id\" \n"
-      "            column=\"CUST_ID\" \n"
-      "            node=\"@id\"/>\n"
-      "            \n"
-      "    <map name=\"accounts\" \n"
-      "            node=\".\" \n"
-      "            embed-xml=\"true\">\n"
-      "        <key column=\"CUSTOMER_ID\" \n"
-      "                not-null=\"true\"/>\n"
-      "        <map-key column=\"SHORT_DESC\" \n"
-      "                node=\"@short-desc\" \n"
-      "                type=\"string\"/>\n"
-      "        <one-to-many entity-name=\"Account\"\n"
-      "                embed-xml=\"false\" \n"
-      "                node=\"account\"/>\n"
-      "    </map>\n"
-      "    \n"
-      "    <component name=\"name\" \n"
-      "            node=\"name\">\n"
-      "        <property name=\"firstName\" \n"
-      "                node=\"first-name\"/>\n"
-      "        <property name=\"initial\" \n"
-      "                node=\"initial\"/>\n"
-      "        <property name=\"lastName\" \n"
-      "                node=\"last-name\"/>\n"
-      "    </component>\n"
-      "    \n"
-      "    ...\n"
-      "    \n"
-      "</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:141
 #, no-c-format
 msgid "In this case, the collection of account ids is embedded, but not the actual account data. The following HQL query:"
 msgstr ""
 
-#. Tag: programlisting
-#: xml.xml:146
-#, no-c-format
-msgid "<![CDATA[from Customer c left join fetch c.accounts where c.lastName like :lastName]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:148
 #, no-c-format
 msgid "would return datasets such as this:"
 msgstr ""
 
-#. Tag: programlisting
-#: xml.xml:152
-#, no-c-format
-msgid ""
-      "<![CDATA[<customer id=\"123456789\">\n"
-      "    <account short-desc=\"Savings\">987632567</account>\n"
-      "    <account short-desc=\"Credit Card\">985612323</account>\n"
-      "    <name>\n"
-      "        <first-name>Gavin</first-name>\n"
-      "        <initial>A</initial>\n"
-      "        <last-name>King</last-name>\n"
-      "    </name>\n"
-      "    ...\n"
-      "</customer>]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:154
 #, no-c-format
 msgid "If you set <literal>embed-xml=\"true\"</literal> on the <literal>&lt;one-to-many&gt;</literal> mapping, the data might look more like this:"
 msgstr ""
 
-#. Tag: programlisting
-#: xml.xml:159
-#, no-c-format
-msgid ""
-      "<![CDATA[<customer id=\"123456789\">\n"
-      "    <account id=\"987632567\" short-desc=\"Savings\">\n"
-      "        <customer id=\"123456789\"/>\n"
-      "        <balance>100.29</balance>\n"
-      "    </account>\n"
-      "    <account id=\"985612323\" short-desc=\"Credit Card\">\n"
-      "        <customer id=\"123456789\"/>\n"
-      "        <balance>-2370.34</balance>\n"
-      "    </account>\n"
-      "    <name>\n"
-      "        <first-name>Gavin</first-name>\n"
-      "        <initial>A</initial>\n"
-      "        <last-name>King</last-name>\n"
-      "    </name>\n"
-      "    ...\n"
-      "</customer>]]>"
-msgstr ""
-
 #. Tag: title
-#: xml.xml:165
 #, no-c-format
 msgid "Manipulating XML data"
 msgstr ""
 
 #. Tag: para
-#: xml.xml:167
 #, no-c-format
 msgid "You can also re-read and update XML documents in the application. You can do this by obtaining a dom4j session:"
 msgstr ""
 
-#. Tag: programlisting
-#: xml.xml:172
-#, no-c-format
-msgid ""
-      "<![CDATA[Document doc = ....;\n"
-      "       \n"
-      "Session session = factory.openSession();\n"
-      "Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-      "Transaction tx = session.beginTransaction();\n"
-      "\n"
-      "List results = dom4jSession\n"
-      "    .createQuery(\"from Customer c left join fetch c.accounts where c.lastName like :lastName\")\n"
-      "    .list();\n"
-      "for ( int i=0; i<results.size(); i++ ) {\n"
-      "    //add the customer data to the XML document\n"
-      "    Element customer = (Element) results.get(i);\n"
-      "    doc.add(customer);\n"
-      "}\n"
-      "\n"
-      "tx.commit();\n"
-      "session.close();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: xml.xml:174
-#, no-c-format
-msgid ""
-      "<![CDATA[Session session = factory.openSession();\n"
-      "Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-      "Transaction tx = session.beginTransaction();\n"
-      "\n"
-      "Element cust = (Element) dom4jSession.get(\"Customer\", customerId);\n"
-      "for ( int i=0; i<results.size(); i++ ) {\n"
-      "    Element customer = (Element) results.get(i);\n"
-      "    //change the customer name in the XML and database\n"
-      "    Element name = customer.element(\"name\");\n"
-      "    name.element(\"first-name\").setText(firstName);\n"
-      "    name.element(\"initial\").setText(initial);\n"
-      "    name.element(\"last-name\").setText(lastName);\n"
-      "}\n"
-      "\n"
-      "tx.commit();\n"
-      "session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:176
 #, no-c-format
 msgid "When implementing XML-based data import/export, it is useful to combine this feature with Hibernate's <literal>replicate()</literal> operation."
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pot/legal_notice.pot
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pot/legal_notice.pot	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pot/legal_notice.pot	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,57 +1,48 @@
-# SOME DESCRIPTIVE TITLE.
-# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+# 
+# AUTHOR <EMAIL at ADDRESS>, YEAR.
 #
-#, fuzzy
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
-"Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"Project-Id-Version: 0\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-02-11T05:38:16\n"
+"Last-Translator: Automatically generated\n"
+"Language-Team: None\n"
 "MIME-Version: 1.0\n"
-"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Type: application/x-publican; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: legal_notice.xml:28
 #, no-c-format
 msgid "Legal Notice"
 msgstr ""
 
-#. Tag: address
-#: legal_notice.xml:30
+#. Tag: para
 #, no-c-format
-msgid "<street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</state><postcode>27606-2072</postcode><country>USA</country> <phone>Phone: +1 919 754 3700</phone> <phone>Phone: 888 733 4281</phone> <fax>Fax: +1 919 754 3701</fax> <pob>PO Box 13588</pob><city>Research Triangle Park</city>, <state>NC</state><postcode>27709</postcode><country>USA</country>"
+msgid "<address> <street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</state><postcode>27606-2072</postcode><country>USA</country> <phone>Phone: +1 919 754 3700</phone> <phone>Phone: 888 733 4281</phone> <fax>Fax: +1 919 754 3701</fax> <pob>PO Box 13588</pob><city>Research Triangle Park</city>, <state>NC</state><postcode>27709</postcode><country>USA</country> </address>"
 msgstr ""
 
 #. Tag: para
-#: legal_notice.xml:39
 #, no-c-format
 msgid "Copyright <trademark class=\"copyright\"></trademark> 2007 by Red Hat, Inc. This copyrighted material is made available to anyone wishing to use, modify, copy, or redistribute it subject to the terms and conditions of the GNU <ulink url=\"http://www.gnu.org/licenses/lgpl-2.1.html\">Lesser General Public License</ulink>, as published by the Free Software Foundation."
 msgstr ""
 
 #. Tag: para
-#: legal_notice.xml:45
 #, no-c-format
 msgid "Red Hat and the Red Hat \"Shadow Man\" logo are registered trademarks of Red Hat, Inc. in the United States and other countries."
 msgstr ""
 
 #. Tag: para
-#: legal_notice.xml:48
 #, no-c-format
 msgid "All other trademarks referenced herein are the property of their respective owners."
 msgstr ""
 
 #. Tag: para
-#: legal_notice.xml:51
 #, no-c-format
 msgid "The GPG fingerprint of the security at redhat.com key is:"
 msgstr ""
 
 #. Tag: para
-#: legal_notice.xml:54
 #, no-c-format
 msgid "CA 20 86 86 2B D6 9D FC 65 F6 EC C4 21 91 80 CD DB 42 A6 0E"
 msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/Hibernate_Reference.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/Hibernate_Reference.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/Hibernate_Reference.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,32 +1,30 @@
+# SOME DESCRIPTIVE TITLE.
+# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+#
 #, fuzzy
 msgid ""
 msgstr ""
+"Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-11T05:38:14\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Content-Type: text/plain; charset=UTF-8\n"
+"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: Hibernate_Reference.xml:35
 #, no-c-format
 msgid "HIBERNATE - Relational Persistence for Idiomatic Java"
-msgstr "HIBERNATE - Relational Persistence for Idiomatic Java"
+msgstr ""
 
 #. Tag: subtitle
-#: Hibernate_Reference.xml:36
 #, no-c-format
 msgid "Hibernate Reference Documentation"
-msgstr "Documentação da Referência do Hibernate"
+msgstr ""
 
-#. Tag: holder
-#: Hibernate_Reference.xml:51
+#. Tag: releaseinfo
 #, no-c-format
-msgid "&copyrightHolder;"
-msgstr "&copyrightHolder;"
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+msgid "&versionNumber;"
+msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/author_group.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/author_group.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/author_group.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -5,7 +5,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: 2009-07-14 19:55+0000\n"
 "Last-Translator: Automatically generated\n"
 "Language-Team: none\n"
@@ -13,209 +13,137 @@
 "Content-Type: text/plain; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
-#. Tag: author
-#: author_group.xml:27
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Gavin</firstname> <surname>King</surname>"
+msgid "Gavin"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:31
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Christian</firstname> <surname>Bauer</surname>"
+msgid "Christian"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:35
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Max</firstname> <othername>Rydahl</othername> <surname>Andersen</"
-"surname>"
+msgid "Max"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:40
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<author><firstname>Emmanuel</firstname> <surname>Bernard</surname></author>"
+msgid "Emmanuel"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:44
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Steve</firstname> <surname>Ebersole</surname>"
+msgid "Steve"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:49
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>James</firstname> <surname>Cobb</surname>"
+msgid "James"
 msgstr ""
 
-#. Tag: shortaffil
-#: author_group.xml:53 author_group.xml:60
+#. Tag: firstname
 #, no-c-format
-msgid "Graphic Design"
+msgid "Cheyenne"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:56
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Cheyenne</firstname> <surname>Weaver</surname>"
+msgid "Vincent"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:69
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<othername><![CDATA[Bernardo Antonio Buffa Colom&#x00e9]]></othername> "
-"<email>kreimer at bbs.frc.utn.edu.ar</email>"
+msgid "Sebastien"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:79
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Vincent</firstname> <surname>Ricard</surname>"
+msgid "Michael"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:83
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Sebastien</firstname> <surname>Cesbron</surname>"
+msgid "Baptiste"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:87
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Michael</firstname> <surname>Courcy</surname>"
+msgid "Anthony"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:91
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Vincent</firstname> <surname>Giguère</surname>"
+msgid "Alvaro"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:95
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Baptiste</firstname> <surname>Mathus</surname>"
+msgid "Anderson"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:99
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<othercredit><firstname>Emmanuel</firstname> <surname>Bernard</surname></"
-"othercredit>"
+msgid "Daniel Vieira"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:103
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Anthony</firstname> <surname>Patricio</surname>"
+msgid "Francisco"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:113
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Alvaro</firstname> <surname>Netto</surname> "
-"<email>alvaronetto at cetip.com.br</email>"
+msgid "Gamarra"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:118
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Anderson</firstname> <surname>Braulio</surname> "
-"<email>andersonbraulio at gmail.com</email>"
+msgid "Luiz Carlos"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:123
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Daniel Vieira</firstname> <surname>Costa</surname> "
-"<email>danielvc at gmail.com</email>"
+msgid "Marcel"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:128
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Francisco</firstname> <surname>gamarra</surname> <email>francisco."
-"gamarra at gmail.com</email>"
+msgid "Paulo"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:133
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Gamarra</firstname> <email>mauricio.gamarra at gmail.com</email>"
+msgid "Pablo L."
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:137
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Luiz Carlos</firstname> <surname>Rodrigues</surname> "
-"<email>luizcarlos_rodrigues at yahoo.com.br</email>"
+msgid "Renato"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:142
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Marcel</firstname> <surname>Castelo</surname> <email>marcel."
-"castelo at gmail.com</email>"
+msgid "Rogério"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:147
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Paulo</firstname> <surname>César</surname> <email>paulocol at gmail."
-"com</email>"
+msgid "Wanderson"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:152
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Pablo L.</firstname> <surname>de Miranda</surname> "
-"<email>pablolmiranda at gmail.com</email>"
+msgid "Cao"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:157
+#. Tag: orgname
 #, no-c-format
-msgid ""
-"<firstname>Renato</firstname> <surname>Deggau</surname> <email>rdeggau at gmail."
-"com</email>"
+msgid "RedSaga"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:162
+#. Tag: contrib
 #, no-c-format
-msgid ""
-"<firstname>Rogério</firstname> <surname>Araújo</surname> "
-"<email>rgildoaraujo at yahoo.com.br</email>"
+msgid "Translation Lead"
 msgstr ""
-
-#. Tag: othercredit
-#: author_group.xml:167
-#, no-c-format
-msgid ""
-"<firstname>Wanderson</firstname> <surname>Siqueira</surname> "
-"<email>wandersonxs at gmail.com</email>"
-msgstr ""
-
-#. Tag: othercredit
-#: author_group.xml:178
-#, no-c-format
-msgid ""
-"<firstname>Cao</firstname> <surname>Xiaogang</surname> <affiliation> "
-"<orgname>RedSaga</orgname> </affiliation> <contrib>Translation Lead</"
-"contrib> <email>caoxg at yahoo.com</email>"
-msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/architecture.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/architecture.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/architecture.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,102 +1,196 @@
+# translation of architecture.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: architecture\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2009-12-18 14:20+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: architecture.xml:30
 #, no-c-format
 msgid "Architecture"
 msgstr "Arquitetura"
 
 #. Tag: title
-#: architecture.xml:33
 #, no-c-format
 msgid "Overview"
 msgstr "Visão Geral"
 
 #. Tag: para
-#: architecture.xml:35
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The diagram below provides a high-level view of the Hibernate architecture:"
-msgstr "Uma visão bem ampla da arquitetura do Hibernate:"
+msgstr ""
+"O diagrama abaixo fornece uma visão de altíssimo nível da arquitetura do "
+"Hibernate:"
 
 #. Tag: para
-#: architecture.xml:48
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We do not have the scope in this document to provide a more detailed view of "
 "all the runtime architectures available; Hibernate is flexible and supports "
 "several different approaches. We will, however, show the two extremes: "
 "\"minimal\" architecture and \"comprehensive\" architecture."
 msgstr ""
-"Nós gostaríamos de mostrar uma visão mais detalhada da arquitetura em "
-"execução. Infelizmente, o Hibernate é muito flexível e suporta várias "
-"aproximações. Nós iremos mostrar os dois extremos. Na arquitetura mais "
-"simples o aplicativo fornece suas próprias conexões JDBC e gerencia suas "
-"transações. Esta abordagem usa o mínimo de subconjuntos das APIs do "
-"Hibernate:"
+"Nós não temos o escopo neste documento para mostrar uma visão mais detalhada "
+"da arquitetura em execução. O Hibernate é muito flexível e suporta várias "
+"abordagens. Mostraremos os dois extremos. No entanto, nós apresentaremos os "
+"dois extremos: arquitetura \"mínima\" e arquitetura \"compreensiva\". "
 
 #. Tag: para
-#: architecture.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This next diagram illustrates how Hibernate utilizes database and "
 "configuration data to provide persistence services, and persistent objects, "
 "to the application."
 msgstr ""
-"Esse diagrama mostra o Hibernate usando o banco de dados e a configuração de "
-"dados para prover persistência de serviços (e persistência de objetos) para "
-"o aplicativo."
+"Este diagrama mostra o Hibernate usando o banco de dados e a configuração de "
+"dados para prover persistência de serviços e persistência de objetos para o "
+"aplicativo."
 
 #. Tag: para
-#: architecture.xml:59
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The \"minimal\" architecture has the application provide its own JDBC "
 "connections and manage its own transactions. This approach uses a minimal "
 "subset of Hibernate's APIs:"
 msgstr ""
-"Nós gostaríamos de mostrar uma visão mais detalhada da arquitetura em "
-"execução. Infelizmente, o Hibernate é muito flexível e suporta várias "
-"aproximações. Nós iremos mostrar os dois extremos. Na arquitetura mais "
-"simples o aplicativo fornece suas próprias conexões JDBC e gerencia suas "
-"transações. Esta abordagem usa o mínimo de subconjuntos das APIs do "
-"Hibernate:"
+"Na arquitetura \"mínima\", o aplicativo fornece suas próprias conexões JDBC "
+"e gerencia suas transações. Esta abordagem usa o mínimo de subconjuntos das "
+"APIs do Hibernate:"
 
 #. Tag: para
-#: architecture.xml:74
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The \"comprehensive\" architecture abstracts the application away from the "
 "underlying JDBC/JTA APIs and allows Hibernate to manage the details."
 msgstr ""
-"A arquitetura \"completa\" abstrai a aplicação de ter de lidar diretamente "
-"com JDBC/JTA e APIs e deixa o Hibernate tomar conta dos detalhes."
+"A arquitetura \"compreensiva\" abstrai a aplicação do JDBC/JTA e APIs "
+"adjacentes e deixa o Hibernate tomar conta dos detalhes."
 
 #. Tag: para
-#: architecture.xml:88
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here are some definitions of the objects depicted in the diagrams:"
-msgstr "Algumas definições dos objetos do diagrama: <placeholder-1/>"
+msgstr "Algumas definições dos objetos descritos nos diagramas: "
 
 #. Tag: term
-#: architecture.xml:93
 #, no-c-format
 msgid "SessionFactory (<literal>org.hibernate.SessionFactory</literal>)"
 msgstr "SessionFactory (<literal>org.hibernate.SessionFactory</literal>)"
 
 #. Tag: para
-#: architecture.xml:95
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A threadsafe, immutable cache of compiled mappings for a single database. A "
 "factory for <literal>Session</literal> and a client of "
@@ -104,21 +198,19 @@
 "hold an optional (second-level) cache of data that is reusable between "
 "transactions at a process, or cluster, level."
 msgstr ""
-"Um cache threadsafe (imutáveis) composto de identidades compiladas para um "
-"único banco de dados. Uma fabrica para <literal>Session</literal> e um "
-"cliente de <literal>ConnectionProvider</literal>. Pode conter um cachê "
-"opcional de dados (segundo nível) reutilizáveis entre transações, no nível "
-"de processo- ou cluster."
+"O threadsafe, cachê imutável composto de mapeamentos compilados para um "
+"único banco de dados. Uma fábrica para <literal>Session</literal> e um "
+"cliente de <literal>ConnectionProvider</literal>, <literal>SessionFactory</"
+"literal> pode conter um cachê opcional de dados (segundo nível) "
+"reutilizáveis entre transações, no nível de processo ou cluster."
 
 #. Tag: term
-#: architecture.xml:105
 #, no-c-format
 msgid "Session (<literal>org.hibernate.Session</literal>)"
 msgstr "Session (<literal>org.hibernate.Session</literal>)"
 
 #. Tag: para
-#: architecture.xml:107
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A single-threaded, short-lived object representing a conversation between "
 "the application and the persistent store. It wraps a JDBC connection and is "
@@ -126,21 +218,20 @@
 "holds a mandatory first-level cache of persistent objects that are used when "
 "navigating the object graph or looking up objects by identifier."
 msgstr ""
-"Objeto single-threaded, de vida curta, representando uma conversação entre o "
+"Objeto single-threaded, de vida curta, representa uma conversação entre o "
 "aplicativo e o armazenamento persistente. Cria uma camada sobre uma conexão "
-"JDBC. É uma fabrica de <literal>Transaction</literal>. Possui um cachê "
-"obrigatório (primeiro nível) de objetos persistentes, usado para navegação "
-"no gráficos de objetos e pesquisa de objetos pelo identificador."
+"JDBC. É uma fabrica de <literal>Transaction</literal>. A <literal>Session</"
+"literal> possui um cachê obrigatório (primeiro nível) de objetos "
+"persistentes, usado para navegação nos gráficos de objetos e pesquisa de "
+"objetos pelo identificador."
 
 #. Tag: term
-#: architecture.xml:117
 #, no-c-format
 msgid "Persistent objects and collections"
 msgstr "Objetos persistentes e coleções"
 
 #. Tag: para
-#: architecture.xml:119
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Short-lived, single threaded objects containing persistent state and "
 "business function. These can be ordinary JavaBeans/POJOs. They are "
@@ -150,21 +241,20 @@
 "and from presentation)."
 msgstr ""
 "Objetos, de vida curta, single threaded contendo estado persistente e função "
-"de negócios. Esses podem ser JavaBeans/POJOs, onde única coisa especial "
+"de negócios. Esses podem ser JavaBeans/POJOs, onde a única coisa especial "
 "sobre eles é que são associados a (exatamente uma) <literal>Session</"
 "literal>. Quando a <literal>Session</literal> é fechada, eles são separados "
-"e liberados para serem usados dentro de qualquer camada da aplicacao (Ex. "
-"diretamente como data transfer objects de e para a camada de apresentação)"
+"e liberados para serem usados dentro de qualquer camada da aplicação (Ex. "
+"diretamente como objetos de transferência de dados de e para a camada de "
+"apresentação)."
 
 #. Tag: term
-#: architecture.xml:129
 #, no-c-format
 msgid "Transient and detached objects and collections"
-msgstr "Objetos e coleções desatachados e transientes"
+msgstr "Objetos e coleções desanexados e transientes"
 
 #. Tag: para
-#: architecture.xml:131
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Instances of persistent classes that are not currently associated with a "
 "<literal>Session</literal>. They may have been instantiated by the "
@@ -173,18 +263,16 @@
 msgstr ""
 "Instâncias de classes persistentes que ainda não estão associadas a uma "
 "<literal>Session</literal>. Eles podem ter sido instanciados pela aplicação "
-"e não persistido (ainda) ou eles foram instanciados por uma "
-"<literal>Session</literal> que foi encerrada."
+"e não persistidos (ainda) ou eles foram instanciados por uma "
+"<literal>Session</literal> encerrada."
 
 #. Tag: term
-#: architecture.xml:140
 #, no-c-format
 msgid "Transaction (<literal>org.hibernate.Transaction</literal>)"
 msgstr "Transaction (<literal>org.hibernate.Transaction</literal>)"
 
 #. Tag: para
-#: architecture.xml:142
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "(Optional) A single-threaded, short-lived object used by the application to "
 "specify atomic units of work. It abstracts the application from the "
@@ -194,65 +282,59 @@
 "<literal>Transaction</literal>, is never optional."
 msgstr ""
 "(Opcional) Objeto de vida curta, single threaded, usado pela aplicação para "
-"especificar unidades atômicas de trabalho. Abstrai o aplicativo de lidar "
-"diretamente com transações JDBC, JTA ou CORBA. Uma <literal>Session</"
-"literal> pode, em alguns casos, iniciar várias <literal>Transaction</"
-"literal>s. Entretanto, a demarcação da transação, mesmo utilizando API ou "
-"Transaction subjacentes, nunca é opcional!"
+"especificar unidades atômicas de trabalho. Abstrai o aplicativo das "
+"transações JDBC, JTA ou CORBA adjacentes. Uma <literal>Session</literal> "
+"pode, em alguns casos, iniciar várias <literal>Transaction</literal>s. "
+"Entretanto, a demarcação da transação, mesmo utilizando API ou "
+"<literal>Transaction</literal> subjacentes, nunca é opcional."
 
 #. Tag: term
-#: architecture.xml:153
 #, no-c-format
 msgid ""
 "ConnectionProvider (<literal>org.hibernate.connection.ConnectionProvider</"
 "literal>)"
 msgstr ""
-"ConnectionProvider (<literal>org.hibernate.connection.ConnectionProvider</"
+"Connection Provider (<literal>org.hibernate.connection.ConnectionProvider</"
 "literal>)"
 
 #. Tag: para
-#: architecture.xml:155
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "(Optional) A factory for, and pool of, JDBC connections. It abstracts the "
 "application from underlying <literal>Datasource</literal> or "
 "<literal>DriverManager</literal>. It is not exposed to application, but it "
 "can be extended and/or implemented by the developer."
 msgstr ""
-"(Opcional) Uma fábrica de (e combinações de) conexões JDBC. Abstrai a "
-"aplicação de lidar diretamente com <literal>Datasource</literal> ou "
-"<literal>DriverManager</literal>. Não exposto para a aplicação, mas pode ser "
-"implementado ou estendido pelo programador."
+"(Opcional) Uma fábrica de, e pool de, conexões JDBC. Abstrai a aplicação dos "
+"<literal>Datasource</literal> ou <literal>DriverManager</literal> "
+"adjacentes. Não exposto para a aplicação, mas pode ser implementado ou "
+"estendido pelo programador. "
 
 #. Tag: term
-#: architecture.xml:163
 #, no-c-format
 msgid ""
 "TransactionFactory (<literal>org.hibernate.TransactionFactory</literal>)"
 msgstr ""
-"TransactionFactory (<literal>org.hibernate.TransactionFactory</literal>)"
+"Transaction Factory (<literal>org.hibernate.TransactionFactory</literal>)"
 
 #. Tag: para
-#: architecture.xml:165
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "(Optional) A factory for <literal>Transaction</literal> instances. It is not "
 "exposed to the application, but it can be extended and/or implemented by the "
 "developer."
 msgstr ""
 "(Opcional) Uma fábrica para instâncias de <literal>Transaction</literal>. "
-"Não exposta a aplicação, mas pode ser extendida/implementada pelo "
+"Não exposta a aplicação, mas pode ser estendida/implementada pelo "
 "programador."
 
-#. Tag: emphasis
-#: architecture.xml:172
-#, no-c-format
-msgid "Extension Interfaces"
-msgstr "Extension Interfaces"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<emphasis>Extension Interfaces</emphasis>"
+msgstr "<emphasis>Interfaces de Extensão</emphasis>"
 
 #. Tag: para
-#: architecture.xml:174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate offers a range of optional extension interfaces you can implement "
 "to customize the behavior of your persistence layer. See the API "
@@ -260,31 +342,28 @@
 msgstr ""
 "O Hibernate oferece várias opções de interfaces estendidas que você pode "
 "implementar para customizar sua camada persistente. Veja a documentação da "
-"API para maiores detalhes."
+"API para maiores detalhes. "
 
 #. Tag: para
-#: architecture.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Given a \"minimal\" architecture, the application bypasses the "
 "<literal>Transaction</literal>/<literal>TransactionFactory</literal> and/or "
 "<literal>ConnectionProvider</literal> APIs to communicate with JTA or JDBC "
 "directly."
 msgstr ""
-"Dada uma arquitetura simples, o aplicativo passa pelas APIs "
+"Dada uma arquitetura \"mínima\", o aplicativo passa pelas APIs "
 "<literal>Transaction</literal>/<literal>TransactionFactory</literal> e/ou "
 "<literal>ConnectionProvider</literal> para se comunicar diretamente com a "
 "transação JTA ou JDBC."
 
 #. Tag: title
-#: architecture.xml:191
 #, no-c-format
 msgid "Instance states"
 msgstr "Estados de instância"
 
 #. Tag: para
-#: architecture.xml:192
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of a persistent class can be in one of three different states. "
 "These states are defined in relation to a <emphasis>persistence context</"
@@ -294,33 +373,29 @@
 "Uma instância de classes persistentes pode estar em um dos três diferentes "
 "estados, que são definidos respeitando um <emphasis>contexto persistente</"
 "emphasis>. O objeto <literal>Session</literal> do Hibernate é o contexto "
-"persistente:"
+"persistente. Os três diferentes estados são os seguintes:"
 
 #. Tag: term
-#: architecture.xml:200
 #, no-c-format
 msgid "transient"
 msgstr "transiente"
 
 #. Tag: para
-#: architecture.xml:202
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The instance is not associated with any persistence context. It has no "
 "persistent identity or primary key value."
 msgstr ""
-"A instância não é, e nunca foi associada com nenhum contexto persistente. "
-"Não possui uma identidade persistente (valor de chave primária)."
+"A instância não é associada a nenhum contexto persistente. Não possui uma "
+"identidade persistente ou valor de chave primária."
 
 #. Tag: term
-#: architecture.xml:210
 #, no-c-format
 msgid "persistent"
 msgstr "persistente"
 
 #. Tag: para
-#: architecture.xml:212
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The instance is currently associated with a persistence context. It has a "
 "persistent identity (primary key value) and can have a corresponding row in "
@@ -330,19 +405,17 @@
 msgstr ""
 "A instância está atualmente associada a um contexto persistente. Possui uma "
 "identidade persistente (valor de chave primária) e, talvez, correspondente a "
-"um registro no banco de dados. Para um contexto persistente em particular, o "
-"Hibernate <emphasis>guarantees</emphasis> que a identidade persistente é "
-"equivalente a identidade Java (na localização em memória do objeto)."
+"uma fila no banco de dados. Para um contexto persistente em particular, o "
+"Hibernate <emphasis>garante</emphasis> que a identidade persistente é "
+"equivalente à identidade Java (na localização em memória do objeto)."
 
 #. Tag: term
-#: architecture.xml:224
 #, no-c-format
 msgid "detached"
-msgstr "desatachado"
+msgstr "desanexado"
 
 #. Tag: para
-#: architecture.xml:226
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The instance was once associated with a persistence context, but that "
 "context was closed, or the instance was serialized to another process. It "
@@ -352,45 +425,42 @@
 msgstr ""
 "A instância foi associada com um contexto persistente, porém este contexto "
 "foi fechado, ou a instância foi serializada por outro processo. Possui uma "
-"identidade persistente, e, talvez, correspondenta a um registro no banco de "
-"dados. Para instâncias desatachadas, o Hibernate não garante o "
-"relacionamento entre identidade persistente e identidade Java."
+"identidade persistente, e, talvez, corresponda a uma fila no banco de dados. "
+"Para instâncias desanexadas, o Hibernate não garante o relacionamento entre "
+"identidade persistente e identidade Java."
 
 #. Tag: title
-#: architecture.xml:241
 #, no-c-format
 msgid "JMX Integration"
 msgstr "Integração JMX"
 
 #. Tag: para
-#: architecture.xml:243
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "JMX is the J2EE standard for the management of Java components. Hibernate "
 "can be managed via a JMX standard service. AN MBean implementation is "
 "provided in the distribution: <literal>org.hibernate.jmx.HibernateService</"
 "literal>."
 msgstr ""
-"JMX é padrão J2EE para manipulação de componentes Java. O Hibernate pode ser "
-"manipulado por um serviço JMX padrão. Nós fornecemos uma implementação do "
-"MBean na distribuição, <literal>org.hibernate.jmx.HibernateService</literal>."
+"JMX é o padrão do J2EE para manipulação de componentes Java. O Hibernate "
+"pode ser manipulado por um serviço JMX padrão. Nós fornecemos uma "
+"implementação do MBean na distribuição: <literal>org.hibernate.jmx."
+"HibernateService</literal>."
 
 #. Tag: para
-#: architecture.xml:249
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For an example of how to deploy Hibernate as a JMX service on the JBoss "
 "Application Server, please see the JBoss User Guide. JBoss AS also provides "
 "these benefits if you deploy using JMX:"
 msgstr ""
-"Para um exemplo de como instalar o Hibernate como um serviço JMX em um "
-"servidor de aplicativo JBoss, por favor, consulte o manual do usuário do "
-"JBoss. No JBoss As, você poderá ver os benefícios de de se fazer o deploy "
-"usando JMX:"
+"Para um exemplo de como implementar o Hibernate como um serviço JMX em um "
+"Servidor de Aplicativo JBoss, por favor, consulte o Guia do Usuário do "
+"JBoss. No JBoss As, você poderá ver os benefícios de se fazer a "
+"implementação usando JMX:"
 
 #. Tag: para
-#: architecture.xml:257
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Session Management</emphasis>: the Hibernate <literal>Session</"
 "literal>'s life cycle can be automatically bound to the scope of a JTA "
@@ -405,17 +475,15 @@
 "<emphasis>Session Management:</emphasis> O ciclo de vida de uma "
 "<literal>Session</literal> do Hibernate pode ser automaticamente conectada a "
 "um escopo de transação JTA. Isso significa que você não precisará mais abrir "
-"e fechar manualmente uma <literal>Session</literal>, isso se torna trabalho "
-"para um interceptor EJB do JBoss . Você também não precisa se preocupar, "
-"nunca mais, com demarcação de transação em seu código (a não ser que você "
-"prefira escrever uma camada persistente portável, para isso, use a API "
-"opcional do Hibernate <literal>Transaction</literal>). Você deve chamar "
-"<literal>HibernateContext</literal> para acessar uma <literal>Session</"
-"literal>."
+"e fechar manualmente uma <literal>Session</literal>, isso se torna uma "
+"tarefa para um interceptor EJB do JBoss. Você também não precisará mais se "
+"preocupar com demarcação de transação em seu código (caso você prefira "
+"escrever uma camada persistente portável, use a API opcional do Hibernate "
+"<literal>Transaction</literal>). Você deve chamar <literal>HibernateContext</"
+"literal> para acessar uma <literal>Session</literal>."
 
 #. Tag: para
-#: architecture.xml:269
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>HAR deployment</emphasis>: the Hibernate JMX service is deployed "
 "using a JBoss service deployment descriptor in an EAR and/or SAR file, as it "
@@ -425,17 +493,16 @@
 "deployment, JBoss will automatically detect all mapping files in your HAR "
 "file."
 msgstr ""
-"<emphasis>HAR deployment:</emphasis>: Normalmente você faz o deploy de um "
-"serviço JMX do Hibernate usando um serviço descritor de deploy do JBoss (em "
-"um EAR e/ou arquivo SAR), que suporta todas as configurações usuais de uma "
+"<emphasis>HAR deployment:</emphasis>: Normalmente você implementa o serviço "
+"JMX do Hibernate usando um serviço descritor de implementação do JBoss em um "
+"EAR e/ou arquivo SAR, que suporta todas as configurações comuns de uma "
 "<literal>SessionFactory</literal> do Hibernate. Entretanto, você ainda "
 "precisa nomear todos os seus arquivos de mapeamento no descritor de "
-"deploração. Se você decidir usar o deploy opcional HAR, o JBoss irá "
-"automaticamente detectar todos os seus arquivos de mapeamento no seu arquivo "
-"HAR."
+"implementação. Se você decidir usar a implementaçao opcional HAR, o JBoss "
+"irá automaticamente detectar todos os seus arquivos de mapeamento no seu "
+"arquivo HAR."
 
 #. Tag: para
-#: architecture.xml:280
 #, no-c-format
 msgid ""
 "Consult the JBoss AS user guide for more information about these options."
@@ -444,47 +511,39 @@
 "sobre essas opções."
 
 #. Tag: para
-#: architecture.xml:284
 #, fuzzy, no-c-format
 msgid ""
 "Another feature available as a JMX service is runtime Hibernate statistics. "
-"See <xref linkend=\"configuration-optional-statistics\"/> for more "
+"See <xref linkend=\"configuration-optional-statistics\" /> for more "
 "information."
 msgstr ""
-"Another feature available as a JMX service are runtime Hibernate statistics. "
-"See <xref linkend=\"configuration-optional-statistics\"/>. Outra opção "
-"disponível como um serviço JMX são as estatísticas de execução do Hibernate. "
-"Veja a <xref linkend=\"configuration-optional-statistics\"/>."
+"Outra opção disponível como um serviço JMX são as estatísticas de execução "
+"do Hibernate. Veja a <xref linkend=\"configuration-optional-statistics\"/> "
+"para maiores informações."
 
 #. Tag: title
-#: architecture.xml:291
 #, no-c-format
 msgid "JCA Support"
 msgstr "Suporte JCA"
 
 #. Tag: para
-#: architecture.xml:292
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate can also be configured as a JCA connector. Please see the website "
 "for more information. Please note, however, that at this stage Hibernate JCA "
 "support is under development."
 msgstr ""
-"Hibernate may also be configured as a JCA connector. Please see the website "
-"for more details. Please note that Hibernate JCA support is still considered "
-"experimental. O Hibernate pode também ser configurado como um conector JCA. "
-"Por favor, visite o website para maiores detalhes. Entretanto, note que o "
-"suporte JCA do Hibernate ainda é considerado experimental."
+"O Hibernate pode também ser configurado como um conector JCA. Por favor, "
+"visite o website para maiores detalhes. Observe também, que o suporte do JCA "
+"do Hibernate ainda é considerado experimental."
 
 #. Tag: title
-#: architecture.xml:299
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Contextual sessions"
-msgstr "Sessões contextuais"
+msgstr "Sessões Contextuais"
 
 #. Tag: para
-#: architecture.xml:300
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Most applications using Hibernate need some form of \"contextual\" session, "
 "where a given session is in effect throughout the scope of a given context. "
@@ -496,18 +555,18 @@
 "utilized third-party frameworks, such as Spring or Pico, which provided "
 "proxy/interception-based contextual sessions."
 msgstr ""
-"Muitas aplicações que usam o Hibernate necessita de algum tipo de sessão "
-"\"contextual\", onde uma sessão dada é na verdade um escopo de um contexto. "
-"Entretanto, através de aplicações a definição sobre um contexto é geralmente "
-"diferente; e contextos diferentes definem escopos diferentes. Aplicações "
-"usando versões anteriores ao Hibernate 3.0 tendem a utilizar tanto sessões "
-"contextuais baseadas em <literal>ThreadLocal</literal>, classes utilitárias "
-"como <literal>HibernateUtil</literal>, ou utilizar frameworks de terceiros"
-"(como Spring ou Pico) que provê sessões contextuais baseadas em proxy."
+"A maioria das aplicações que usa o Hibernate necessita de algum tipo de "
+"sessão \"contextual\", onde uma sessão dada é na verdade um escopo de um "
+"contexto. Entretanto, através de aplicações, a definição sobre um contexto é "
+"geralmente diferente; e contextos diferentes definem escopos diferentes. "
+"Aplicações usando versões anteriores ao Hibernate 3.0 tendem a utilizar "
+"tanto sessões contextuais baseadas em <literal>ThreadLocal</literal>, "
+"classes utilitárias como <literal>HibernateUtil</literal>, ou utilizar "
+"frameworks de terceiros (como Spring ou Pico) que provê sessões contextuais "
+"baseadas em proxy."
 
 #. Tag: para
-#: architecture.xml:309
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Starting with version 3.0.1, Hibernate added the <literal>SessionFactory."
 "getCurrentSession()</literal> method. Initially, this assumed usage of "
@@ -521,18 +580,17 @@
 msgstr ""
 "A partir da versão 3.0.1, o Hibernate adicionou o método "
 "<literal>SessionFactory.getCurrentSession()</literal>. Inicialmente, este "
-"assume o uso de transações <literal>JTA</literal>, onde a transação "
-"<literal>JTA</literal> define tanto o escopo quanto o contexto de uma sessão "
-"atual. O time do Hibernate mantém este recurso, desenvolvendo as diversas "
-"implementações do <literal>JTA TransactionManager</literal>, a maioria (se "
-"não todos) aplicativos deveria utilizar o gerenciador de transações "
-"<literal>JTA</literal> sendo ou não instalados dentro de um container "
-"<literal>J2EE</literal>. Baseado neste recurso, você deveria sempre utilizar "
-"sessões contextuais baseadas em <literal>JTA</literal>."
+"considerou o uso de transações <literal>JTA</literal>, onde a transação "
+"<literal>JTA</literal> definia tanto o escopo quanto o contexto de uma "
+"sessão atual. Dada a maturidade de diversas implementações autônomas "
+"disponíveis do <literal>JTA TransactionManager</literal>, a maioria (se não "
+"todos) dos aplicativos deveria utilizar o gerenciador de transações "
+"<literal>JTA</literal> sendo ou não instalados dentro de um recipiente "
+"<literal>J2EE</literal>. Baseado neste recurso, você deve sempre utilizar "
+"sessões contextuais baseadas em <literal>JTA</literal>. "
 
 #. Tag: para
-#: architecture.xml:319
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, as of version 3.1, the processing behind <literal>SessionFactory."
 "getCurrentSession()</literal> is now pluggable. To that end, a new extension "
@@ -541,8 +599,8 @@
 "current_session_context_class</literal>, have been added to allow "
 "pluggability of the scope and context of defining current sessions."
 msgstr ""
-"Entretanto, na versão 3.1, o processo por trás do método "
-"<literal>SessionFactory.getCurrentSession()</literal> é agora plugavel. Com "
+"Entretanto, a partir da versão 3.1, o processo por trás do método "
+"<literal>SessionFactory.getCurrentSession()</literal> é agora plugável. Com "
 "isso, uma nova interface (<literal>org.hibernate.context."
 "CurrentSessionContext</literal>) e um novo parâmetro de configuração "
 "(<literal>hibernate.current_session_context_class</literal>) foram "
@@ -550,8 +608,7 @@
 "definição de sessões correntes."
 
 #. Tag: para
-#: architecture.xml:326
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "See the Javadocs for the <literal>org.hibernate.context."
 "CurrentSessionContext</literal> interface for a detailed discussion of its "
@@ -560,54 +617,50 @@
 "contextual session. Out-of-the-box, Hibernate comes with three "
 "implementations of this interface:"
 msgstr ""
-"De uma olhada em Javadocs sobre a interface <literal>org.hibernate.context."
+"Consulte no Javadocs sobre a interface <literal>org.hibernate.context."
 "CurrentSessionContext</literal> para uma discussão detalhada. Ela define um "
-"método único, <literal>currentSession()</literal>, com o qual a "
-"implementação é responsável por rastrear a sessão contextual corrente. Por "
-"fora do \"encapsulamento\", o Hibernate possui duas implementações dessa "
-"interface."
+"método único, <literal>currentSession()</literal>, pelo qual a implementação "
+"é responsável por rastrear a sessão contextual atual. Fora da caixa, o "
+"Hibernate surge com três implementações dessa interface:"
 
 #. Tag: para
-#: architecture.xml:336
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.context.JTASessionContext</literal>: current sessions "
 "are tracked and scoped by a <literal>JTA</literal> transaction. The "
 "processing here is exactly the same as in the older JTA-only approach. See "
 "the Javadocs for details."
 msgstr ""
-"<literal>org.hibernate.context.JTASessionContext</literal> - As sessões "
+"<literal>org.hibernate.context.JTASessionContext</literal>: As sessões "
 "correntes são rastreadas e recebem um escopo por uma transação <literal>JTA</"
-"literal>. O processamento aqui é exatamente igual ao antigo processo JTA. "
-"Consulte em Javadocs para maiores detalhes."
+"literal>. O processamento aqui é exatamente igual à abordagem anterior do "
+"JTA somente. Consulte em Javadocs para maiores detalhes."
 
 #. Tag: para
-#: architecture.xml:344
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.context.ThreadLocalSessionContext</literal>:current "
 "sessions are tracked by thread of execution. See the Javadocs for details."
 msgstr ""
 "<literal>org.hibernate.context.ThreadLocalSessionContext</literal> - As "
 "sessões correntes são rastreadas por uma thread de execução. Novamente, "
-"consulte em Javadocs para maiores detalhes."
+"consulte em Javadocs para maiores detalhes. "
 
 #. Tag: para
-#: architecture.xml:350
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.context.ManagedSessionContext</literal>: current "
 "sessions are tracked by thread of execution. However, you are responsible to "
 "bind and unbind a <literal>Session</literal> instance with static methods on "
 "this class: it does not open, flush, or close a <literal>Session</literal>."
 msgstr ""
-"<literal>org.hibernate.context.ManagedSessionContext</literal> - current "
-"sessions are tracked by thread of execution. However, you are responsible to "
-"bind and unbind a <literal>Session</literal> instance with static methods on "
-"this class, it does never open, flush, or close a <literal>Session</literal>."
+"<literal>org.hibernate.context.ManagedSessionContext</literal>. As sessões "
+"atuais são rastreadas por uma thread de execução. Entretanto, você é "
+"responsável por vincular e desvincular uma instância <literal>Session</"
+"literal> com métodos estáticos nesta classe, que nunca abre, libera ou fecha "
+"uma <literal>Session</literal>. "
 
 #. Tag: para
-#: architecture.xml:359
 #, fuzzy, no-c-format
 msgid ""
 "The first two implementations provide a \"one session - one database "
@@ -620,25 +673,24 @@
 "utilize the JTA interfaces to demarcate transactions. If you execute in an "
 "EJB container that supports CMT, transaction boundaries are defined "
 "declaratively and you do not need any transaction or session demarcation "
-"operations in your code. Refer to <xref linkend=\"transactions\"/> for more "
+"operations in your code. Refer to <xref linkend=\"transactions\" /> for more "
 "information and code examples."
 msgstr ""
-"As duas primeiras implementações usam o modelo de programação \"uma sessão – "
-"uma transação do banco de dados\", também conhecida e usado como "
+"As duas primeiras implementações usam o modelo de programação \"uma sessão - "
+"uma transação do banco de dados\", também conhecida e usada como "
 "<emphasis>sessão por requisição</emphasis>. O começo e o fim de uma sessão "
 "Hibernate é definida pela duração da transação do banco de dados. Se você "
-"usa demarcação programática de transação (por exemplo. em J2SE puro ou com "
-"JTA /UserTransaction/BMT), você é recomendado a usar a API Hibernate "
-"<literal>Transaction</literal> para esconder a base do sistema de transação "
-"do seu código. Se você executa em um container EJB que suporta CMT, os "
-"limites das transações são definidas declarativamente e você não necessita "
-"de qualquer transação ou operação de demarcação de sessão no seu código. "
-"Consulte o <xref linkend=\"transactions\"/> para mais informações exemplos "
-"de código."
+"usar a demarcação programática de transação em JSE puro sem JTA, recomenda-"
+"se que utilize a API Hibernate <literal>Transaction</literal> para esconder "
+"o sistema de transação adjacente do seu código. Se você utiliza o JTA, use "
+"as interfaces JTA para demarcar as transações. Se você executar em um "
+"recipiente EJB que suporta CMT, os limites das transações são definidas "
+"declarativamente e você não precisará de qualquer transação ou operação de "
+"demarcação de sessão no seu código. Consulte o <xref linkend=\"transactions"
+"\"/> para mais informações e exemplos de código."
 
 #. Tag: para
-#: architecture.xml:371
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>hibernate.current_session_context_class</literal> configuration "
 "parameter defines which <literal>org.hibernate.context."
@@ -652,12 +704,12 @@
 "\"managed\"."
 msgstr ""
 "O parâmetro de configuração <literal>hibernate."
-"current_session_context_class</literal> define que a implementação "
+"current_session_context_class</literal> define qual implementação "
 "<literal>org.hibernate.context.CurrentSessionContext</literal> deve ser "
 "usada. Note que para compatibilidade anterior, se este parâmetro de "
-"configuração não é determinado mas um <literal>org.hibernate.transaction."
-"TransactionManagerLookup</literal> é configurado, Hibernate usará o "
+"configuração não for determinado mas um <literal>org.hibernate.transaction."
+"TransactionManagerLookup</literal> for configurado, Hibernate usará o "
 "<literal>org.hibernate.context.JTASessionContext</literal>. Tipicamente, o "
 "valor deste parâmetro nomearia apenas a classe de implementação para usar; "
-"para as duas implementações out-of-the-box, entretanto, há três pequenos "
-"nomes correspondentes, \"jta\", \"thread\", and \"managed\"."
+"para as três implementações fora da caixa, entretanto, há dois pequenos "
+"nomes correspondentes, \"jta\", \"thread\", e \"managed\"."

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/association_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/association_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/association_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,30 +1,134 @@
+# translation of association_mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: association_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2009-11-16 14:59+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: association_mapping.xml:30
 #, no-c-format
 msgid "Association Mappings"
-msgstr "Mapeamento de Associações"
+msgstr "Mapeamento de associações "
 
 #. Tag: title
-#: association_mapping.xml:33
 #, no-c-format
 msgid "Introduction"
 msgstr "Introdução"
 
 #. Tag: para
-#: association_mapping.xml:35
-#, fuzzy, no-c-format
+#, 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, "
@@ -32,51 +136,45 @@
 "use <literal>Person</literal> and <literal>Address</literal> in all the "
 "examples."
 msgstr ""
-"Mapeamentos de associações são freqüentemente a coisa mais difícil de se "
-"acertar. Nesta seção nós passaremos pêlos casos canônicos um pôr um, "
+"Os mapeamentos de associações são, geralmente, os mais difíceis de se "
+"acertar. Nesta seção nós examinaremos pelos casos canônicos um por um, "
 "começando com mapeamentos unidirecionais e considerando os casos "
-"bidirecionais. Nos vamos usar <literal>Person</literal> e <literal>Address</"
+"bidirecionais. Usaremos <literal>Person</literal> e <literal>Address</"
 "literal> em todos os exemplos."
 
 #. Tag: para
-#: association_mapping.xml:43
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Associations will be classified by multiplicity and whether or not they map "
 "to an intervening join table."
 msgstr ""
-"Nós classificaremos as associações pelo seu mapeamento ou a falta do mesmo, "
-"sua intervenção na tabela associativa, e pela sua multiplicidade."
+"Classificaremos as associações pela sua multiplicidade e se elas mapeiam ou "
+"não uma intervenção na tabela associativa."
 
 #. Tag: para
-#: association_mapping.xml:48
-#, fuzzy, no-c-format
+#, 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 ""
-"O uso de chaves estrangeiras não obrigatórias não é considerada uma boa "
-"prática na modelagem de dados tradicional, assim todos nossos exemplos usam "
-"chaves estrangeiras obrigatórias. Esta não é uma exigência do Hibernate, e "
-"todas as mapeamentos funcionarão se você remover as constraints de "
-"obrigatoriedade."
+"O uso de chaves externas anuláveis não é considerado uma boa prática na "
+"modelagem de dados tradicional, assim todos os nossos exemplos usam chaves "
+"externas anuláveis. Esta não é uma exigência do Hibernate, e todos os "
+"mapeamentos funcionarão se você remover as restrições de anulabilidade."
 
 #. Tag: title
-#: association_mapping.xml:58
 #, no-c-format
 msgid "Unidirectional associations"
 msgstr "Associações Unidirecionais"
 
 #. Tag: title
-#: association_mapping.xml:61 association_mapping.xml:132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Many-to-one"
-msgstr "muitos para um"
+msgstr "Muitos-para-um"
 
 #. Tag: para
-#: association_mapping.xml:63
 #, no-c-format
 msgid ""
 "A <emphasis>unidirectional many-to-one association</emphasis> is the most "
@@ -85,445 +183,126 @@
 "Uma <emphasis>associação unidirecional muitos-para-um</emphasis> é o tipo "
 "mais comum de associação unidirecional."
 
-#. Tag: programlisting
-#: association_mapping.xml:68
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:69 association_mapping.xml:185
-#, no-c-format
-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 ""
-
-#. Tag: title
-#: association_mapping.xml:74 association_mapping.xml:145
-#: association_mapping.xml:210
-#, fuzzy, no-c-format
 msgid "One-to-one"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"um para um\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"um para um\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"um para um\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"one to one"
+msgstr "Um-para-um"
 
 #. Tag: para
-#: association_mapping.xml:76
 #, no-c-format
 msgid ""
 "A <emphasis>unidirectional one-to-one association on a foreign key</"
 "emphasis> is almost identical. The only difference is the column unique "
 "constraint."
 msgstr ""
-"Uma <emphasis>associação unidirecional um-para-um em uma chave estrangeira </"
-"emphasis> é quase idêntica. A única diferença é a constraint unique na "
-"coluna."
+"Uma <emphasis>associação unidirecional um-para-um em uma chave externa </"
+"emphasis> é quase idêntica. A única diferença é a restrição única na coluna."
 
-#. Tag: programlisting
-#: association_mapping.xml:81
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:82 association_mapping.xml:218
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:84
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>unidirectional one-to-one association on a primary key</"
 "emphasis> usually uses a special id generator In this example, however, we "
 "have reversed the direction of the association:"
 msgstr ""
-"Uma <emphasis>associação unidirecional um-para-um na chave primaria</"
-"emphasis> geralmente usa um gerador de id special. ( Note que nós invertemos "
-"a direção da associação nesse exemplo)."
+"Uma <emphasis>associação unidirecional um-para-um na chave primária</"
+"emphasis> geralmente usa um gerador de id especial. Note que nós invertemos "
+"a direção da associação nesse exemplo."
 
-#. Tag: programlisting
-#: association_mapping.xml:90
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" constrained=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:91 association_mapping.xml:226
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"create table Person ( personId bigint not null primary key )\n"
-"create table Address ( personId bigint not null primary key )\n"
-"        ]]>"
-msgstr ""
-
-#. Tag: title
-#: association_mapping.xml:96 association_mapping.xml:118
-#, fuzzy, no-c-format
 msgid "One-to-many"
-msgstr "um para muitos"
+msgstr "Um-para-muitos"
 
 #. Tag: para
-#: association_mapping.xml:98
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>unidirectional one-to-many association on a foreign key</"
 "emphasis> is an unusual case, and is not recommended."
 msgstr ""
-"Uma <emphasis>associação unidirecional um-para-muitos em uma chave "
-"estrangeira</emphasis> é um caso muito incomum, e realmente não é "
-"recomendada."
+"Uma <emphasis>associação unidirecional um-para-muitos em uma chave externa</"
+"emphasis> é um caso muito incomum, e realmente não é recomendada."
 
-#. Tag: programlisting
-#: association_mapping.xml:103
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\">\n"
-"        <key column=\"personId\" \n"
-"            not-null=\"true\"/>\n"
-"        <one-to-many class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:104
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:106
-#, fuzzy, no-c-format
 msgid "You should instead use a join table for this kind of association."
 msgstr ""
-"Nós achamos que é melhor usar uma tabela associativa para este tipo de "
-"associação."
+"Acreditamos ser melhor usar uma tabela associativa para este tipo de "
+"associação. "
 
 #. Tag: title
-#: association_mapping.xml:115
 #, no-c-format
 msgid "Unidirectional associations with join tables"
 msgstr "Associações Unidirecionais com tabelas associativas"
 
 #. Tag: para
-#: association_mapping.xml:120
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>unidirectional one-to-many association on a join table</"
 "emphasis> is the preferred option. Specifying <literal>unique=\"true\"</"
 "literal>, changes the multiplicity from many-to-many to one-to-many."
 msgstr ""
 "Uma <emphasis>associação um-para-muitos unidirecional usando uma tabela "
-"associativa</emphasis> e o mais comum. Note que se especificarmos "
-"<literal>unique=\"true\"</literal>, estaremos modificando a cardinalidade de "
-"muitos-para-muitos para um-para-muitos."
+"associativa</emphasis> é o mais comum. Note que se especificarmos "
+"<literal>unique=\"true\"</literal>, estaremos modificando a multiplicidade "
+"de muitos-para-muitos para um-para-muitos."
 
-#. Tag: programlisting
-#: association_mapping.xml:126
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:127
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:134
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>unidirectional many-to-one association on a join table</"
 "emphasis> is common when the association is optional. For example:"
 msgstr ""
 "Uma <emphasis>associação unidirecional muitos-para-um em uma tabela "
-"associativa</emphasis> é bastante comum quando a associação for opcional."
+"associativa</emphasis> é bastante comum quando a associação for opcional. "
 
-#. Tag: programlisting
-#: association_mapping.xml:139
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:140
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:147
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>unidirectional one-to-one association on a join table</emphasis> "
 "is possible, but extremely unusual."
 msgstr ""
 "Uma <emphasis>associação unidirecional um-para-um em uma tabela associativa</"
-"emphasis> é extremamente incomum, mas possível."
+"emphasis> é extremamente incomum, mas possível. "
 
-#. Tag: programlisting
-#: association_mapping.xml:152
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:153 association_mapping.xml:258
-#, no-c-format
-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 ""
-
-#. Tag: title
-#: association_mapping.xml:158 association_mapping.xml:263
-#, fuzzy, no-c-format
 msgid "Many-to-many"
-msgstr "muitos para muitos"
+msgstr "Muitos-para-muitos "
 
 #. Tag: para
-#: association_mapping.xml:160
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, here is an example of a <emphasis>unidirectional many-to-many "
 "association</emphasis>."
 msgstr ""
 "Finalmente, nós temos a <emphasis>associação unidirecional muitos-para- "
-"muitos</emphasis>."
+"muitos</emphasis>. "
 
-#. Tag: programlisting
-#: association_mapping.xml:164
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:165 association_mapping.xml:271
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: association_mapping.xml:172
 #, no-c-format
 msgid "Bidirectional associations"
 msgstr "Associações Bidirecionais"
 
 #. Tag: title
-#: association_mapping.xml:175 association_mapping.xml:236
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "one-to-many / many-to-one"
-msgstr "um para muitos / muitos para um"
+msgstr "Um-para-muitos/muitos-para-um"
 
 #. Tag: para
-#: association_mapping.xml:177
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional many-to-one association</emphasis> is the most "
 "common kind of association. The following example illustrates the standard "
 "parent/child relationship."
 msgstr ""
 "Uma <emphasis>associação bidirecional muitos-para-um</emphasis> é o tipo "
-"mais comum de associação. (Esse é o relacionamento padrão pai / filho. )"
+"mais comum de associação. A seguinte amostra ilustra o relacionamento padrão "
+"pai/filho. )"
 
-#. Tag: programlisting
-#: association_mapping.xml:183
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <one-to-many class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:187
-#, fuzzy, no-c-format
-msgid ""
 "If you use a <literal>List</literal>, or other indexed collection, set the "
 "<literal>key</literal> column of the foreign key to <literal>not null</"
 "literal>. Hibernate will manage the association from the collections side to "
@@ -531,42 +310,16 @@
 "by setting <literal>update=\"false\"</literal> and <literal>insert=\"false"
 "\"</literal>:"
 msgstr ""
-"Se você usar uma <literal>List</literal> ( ou outra coleção indexada ), você "
-"precisa especificar a coluna <literal>chave</literal> estrangeira como not "
-"null, e deixar o Hibernate administrar a associação do lado da coleção para "
-"que seja mantido o índice de cada elemento da coleção (fazendo com que o "
-"outro lado seja virtualmente inverso setando <literal>update=\"false\"</"
-"literal> e <literal>insert=\"false\"</literal>):"
+"Se você usar uma <literal>List</literal> ou outra coleção indexada, você "
+"precisará especificar a coluna <literal>key</literal>  da chave externa como "
+"<literal>not null</literal>. O Hibernate administrará a associação do lado "
+"da coleção para que seja mantido o índice de cada elemento da coleção "
+"(fazendo com que o outro lado seja virtualmente inverso ajustando "
+"<literal>update=\"false\"</literal> e <literal>insert=\"false\"</literal>):"
 
-#. Tag: programlisting
-#: association_mapping.xml:195
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"   <id name=\"id\"/>\n"
-"   ...\n"
-"   <many-to-one name=\"address\"\n"
-"      column=\"addressId\"\n"
-"      not-null=\"true\"\n"
-"      insert=\"false\"\n"
-"      update=\"false\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"   <id name=\"id\"/>\n"
-"   ...\n"
-"   <list name=\"people\">\n"
-"      <key column=\"addressId\" not-null=\"true\"/>\n"
-"      <list-index column=\"peopleIdx\"/>\n"
-"      <one-to-many class=\"Person\"/>\n"
-"   </list>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:197
-#, fuzzy, no-c-format
-msgid ""
 "If the underlying foreign key column is <literal>NOT NULL</literal>, it is "
 "important that you define <literal>not-null=\"true\"</literal> on the "
 "<literal>&lt;key&gt;</literal> element of the collection mapping. Do not "
@@ -574,248 +327,79 @@
 "<literal>&lt;column&gt;</literal> element, but on the <literal>&lt;key&gt;</"
 "literal> element."
 msgstr ""
-"É importante que você defina <literal>not-null=\"true\"</literal> no "
-"elemento <literal>&lt;key&gt;</literal> no mapeamento na coleção se a coluna "
-"de chave estrangeira for <literal>NOT NULL</literal>. Não declare como "
-"<literal>not-null=\"true\"</literal> apenas um elemento aninhado "
-"<literal>&lt;column&gt;</literal>, mas sim o elemento <literal>&lt;key&gt;</"
-"literal>."
+"Caso uma coluna chave externa adjacente for <literal>NOT NULL</literal>, é "
+"importante que você defina <literal>not-null=\"true\"</literal> no elemento "
+"<literal>&lt;key&gt;</literal> no mapeamento na coleção se a coluna de chave "
+"externa para <literal>NOT NULL</literal>. Não declare como <literal>not-null="
+"\"true\"</literal> apenas um elemento aninhado <literal>&lt;column&gt;</"
+"literal>, mas sim o elemento <literal>&lt;key&gt;</literal>."
 
 #. Tag: para
-#: association_mapping.xml:212
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional one-to-one association on a foreign key</emphasis> "
 "is common:"
 msgstr ""
-"Uma <emphasis>associação bidirecional um para um em uma chave estrangeira</"
-"emphasis> é bastante comum."
+"Uma <emphasis>associação bidirecional um para um em uma chave externa </"
+"emphasis> é bastante comum:"
 
-#. Tag: programlisting
-#: association_mapping.xml:217
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"   <one-to-one name=\"person\" \n"
-"        property-ref=\"address\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:220
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>bidirectional one-to-one association on a primary key</emphasis> "
 "uses the special id generator:"
 msgstr ""
 "Uma <emphasis>associação bidirecional um para um em uma chave primária</"
-"emphasis> usa um gerador de id especial."
+"emphasis> usa um gerador de id especial:"
 
-#. Tag: programlisting
-#: association_mapping.xml:225
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <one-to-one name=\"address\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" \n"
-"        constrained=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: association_mapping.xml:233
 #, no-c-format
 msgid "Bidirectional associations with join tables"
 msgstr "Associações Bidirecionais com tabelas associativas"
 
 #. Tag: para
-#: association_mapping.xml:238
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is an example of a <emphasis>bidirectional one-to-many "
 "association on a join table</emphasis>. The <literal>inverse=\"true\"</"
 "literal> can go on either end of the association, on the collection, or on "
 "the join."
 msgstr ""
-"Uma <emphasis>associação bidirecional um para muitos em uma tabela "
-"associativa</emphasis>. Veja que <literal>inverse=\"true\"</literal> pode "
-"ser colocado em qualquer ponta associação, na coleção, ou no join."
+"Segue abaixo uma amostra da <emphasis>associação bidirecional um para muitos "
+"em uma tabela de união</emphasis>. Veja que <literal>inverse=\"true\"</"
+"literal> pode ser colocado em qualquer ponta da associação, na coleção, ou "
+"na união."
 
-#. Tag: programlisting
-#: association_mapping.xml:244
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" \n"
-"        table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        inverse=\"true\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-one name=\"person\"\n"
-"            column=\"personId\"\n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:245
-#, no-c-format
-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 ""
-
-#. Tag: title
-#: association_mapping.xml:250
-#, fuzzy, no-c-format
 msgid "one to one"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"um para um\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"um para um\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"um para um\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"one to one"
+msgstr "Um para um"
 
 #. Tag: para
-#: association_mapping.xml:252
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional one-to-one association on a join table</emphasis> "
 "is possible, but extremely unusual."
 msgstr ""
-"Uma <emphasis>associação bidirecional um-para-um em uma tabela de "
-"associação</emphasis> é algo bastante incomum, mas possivel."
+"Uma <emphasis>associação bidirecional um-para-um em uma tabela de união</"
+"emphasis> é algo bastante incomum, mas possível."
 
-#. Tag: programlisting
-#: association_mapping.xml:257
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\"\n"
-"        inverse=\"true\">\n"
-"        <key column=\"addressId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"person\"\n"
-"            column=\"personId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:265
-#, fuzzy, no-c-format
-msgid ""
 "Here is an example of a <emphasis>bidirectional many-to-many association</"
 "emphasis>."
 msgstr ""
-"Finally, we have a <emphasis>bidirectional many-to-many association</"
-"emphasis>. Finalmente, nós temos uma associação bidirecional de muitos para "
-"muitos."
+"Finalmente, nós temos uma <emphasis>associação bidirecional de muitos para "
+"muitos</emphasis>."
 
-#. Tag: programlisting
-#: association_mapping.xml:269
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-many column=\"personId\"\n"
-"            class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: association_mapping.xml:278
 #, no-c-format
 msgid "More complex association mappings"
 msgstr "Mapeamento de associações mais complexas"
 
 #. Tag: para
-#: association_mapping.xml:280
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "More complex association joins are <emphasis>extremely</emphasis> rare. "
 "Hibernate handles more complex situations by using SQL fragments embedded in "
@@ -824,61 +408,25 @@
 "<literal>effectiveEndDate</literal> and <literal>effectiveStartDate</"
 "literal>columns, it would be mapped as follows:"
 msgstr ""
-"More complex association joins are <emphasis>extremely</emphasis> rare. "
-"Hibernate makes it possible to handle more complex situations using SQL "
-"fragments embedded in the mapping document. For example, if a table with "
-"historical account information data defines <literal>accountNumber</"
-"literal>, <literal>effectiveEndDate</literal> and "
-"<literal>effectiveStartDate</literal>columns, mapped as follows: Joins de "
-"associações mais complexas são extremamente raros. O Hibernate torna "
-"possível tratar mapeamentos mais complexos usando fragmentos de SQL "
-"embutidos no documento de mapeamento. Por exemplo, se uma tabela com "
-"informações de dados históricos de uma conta define a coluna accountNumber, "
-"effectiveEndDate e effectiveStartDate, mapeadas assim como segue:"
+"Uniões de associações mais complexas são <emphasis>extremamente</emphasis> "
+"raras. O Hibernate possibilita o tratamento de mapeamentos mais complexos, "
+"usando fragmentos de SQL embutidos no documento de mapeamento. Por exemplo, "
+"se uma tabela com informações de dados históricos de uma conta define as "
+"colunas <literal>accountNumber</literal>, <literal>effectiveEndDate</"
+"literal> e <literal>effectiveStartDate</literal>, mapeadas assim como segue:"
 
-#. Tag: programlisting
-#: association_mapping.xml:289
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<properties name=\"currentAccountKey\">\n"
-"    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
-"    <property name=\"currentAccount\" type=\"boolean\">\n"
-"        <formula>case when effectiveEndDate is null then 1 else 0 end</"
-"formula>\n"
-"    </property>\n"
-"</properties>\n"
-"<property name=\"effectiveEndDate\" type=\"date\"/>\n"
-"<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:291
-#, fuzzy, no-c-format
-msgid ""
 "You can then map an association to the <emphasis>current</emphasis> "
 "instance, the one with null <literal>effectiveEndDate</literal>, by using:"
 msgstr ""
-"Then we can map an association to the <emphasis>current</emphasis> instance "
-"(the one with null <literal>effectiveEndDate</literal>) using: Então nós "
-"podemos mapear uma associação para a instância corrente (aquela com a "
-"effectiveEndDate igual a null) usando:"
+"Então nós podemos mapear uma associação para a instância <emphasis>atual</"
+"emphasis>, aquela com <literal>effectiveEndDate</literal> nulo, usando:"
 
-#. Tag: programlisting
-#: association_mapping.xml:296
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
-"        property-ref=\"currentAccountKey\"\n"
-"        class=\"AccountInfo\">\n"
-"    <column name=\"accountNumber\"/>\n"
-"    <formula>'1'</formula>\n"
-"</many-to-one>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:298
-#, fuzzy, no-c-format
-msgid ""
 "In a more complex example, imagine that the association between "
 "<literal>Employee</literal> and <literal>Organization</literal> is "
 "maintained in an <literal>Employment</literal> table full of historical "
@@ -886,44 +434,806 @@
 "emphasis> employer, the one with the most recent <literal>startDate</"
 "literal>, could be mapped in the following way:"
 msgstr ""
-"In a more complex example, imagine that the association between "
-"<literal>Employee</literal> and <literal>Organization</literal> is "
-"maintained in an <literal>Employment</literal> table full of historical "
-"employment data. Then an association to the employee's <emphasis>most "
-"recent</emphasis> employer (the one with the most recent <literal>startDate</"
-"literal>) might be mapped this way: Em um exemplo mais complexo, imagine que "
-"a associação entre Employee e Organization é mantida em uma tabela "
-"Employment cheia de dados históricos do trabalho. Então a associação do "
-"funcionário mais recentemente empregado (aquele com a mais recente "
-"startDate) deve ser mapeado desta maneira:"
+"Em um exemplo mais complexo, imagine que a associação entre "
+"<literal>Employee</literal> e <literal>Organization</literal> é mantida em "
+"uma tabela <literal>Employment</literal> cheia de dados históricos do "
+"trabalho. Então a associação do funcionário <emphasis>mais recentemente</"
+"emphasis> e empregado, aquele com a mais recente <literal>startDate</"
+"literal>, deve ser mapeado desta maneira: "
 
-#. Tag: programlisting
-#: association_mapping.xml:306
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<join>\n"
-"    <key column=\"employeeId\"/>\n"
-"    <subselect>\n"
-"        select employeeId, orgId \n"
-"        from Employments \n"
-"        group by orgId \n"
-"        having startDate = max(startDate)\n"
-"    </subselect>\n"
-"    <many-to-one name=\"mostRecentEmployer\" \n"
-"            class=\"Organization\" \n"
-"            column=\"orgId\"/>\n"
-"</join>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:308
-#, fuzzy, 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 ""
-"You can get quite creative with this functionality, but it is usually more "
-"practical to handle these kinds of cases using HQL or a criteria query. Você "
-"pode ser criativo com esta funcionalidade, mas geralmente é mais prático "
-"tratar estes tipos de casos, usando uma pesquisa HQL ou uma pesquisa por "
-"criteria."
+"Esta funcionalidade permite um grau de criatividade e flexibilidade, mas "
+"geralmente é mais prático tratar estes tipos de casos, usando uma pesquisa "
+"HQL ou uma pesquisa por critério."
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" constrained=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        <one-to-many class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        <one-to-many class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <one-to-many class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <one-to-many class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <many-to-one name=\"address\"\n"
+#~ "      column=\"addressId\"\n"
+#~ "      not-null=\"true\"\n"
+#~ "      insert=\"false\"\n"
+#~ "      update=\"false\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <list name=\"people\">\n"
+#~ "      <key column=\"addressId\" not-null=\"true\"/>\n"
+#~ "      <list-index column=\"peopleIdx\"/>\n"
+#~ "      <one-to-many class=\"Person\"/>\n"
+#~ "   </list>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <many-to-one name=\"address\"\n"
+#~ "      column=\"addressId\"\n"
+#~ "      not-null=\"true\"\n"
+#~ "      insert=\"false\"\n"
+#~ "      update=\"false\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <list name=\"people\">\n"
+#~ "      <key column=\"addressId\" not-null=\"true\"/>\n"
+#~ "      <list-index column=\"peopleIdx\"/>\n"
+#~ "      <one-to-many class=\"Person\"/>\n"
+#~ "   </list>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "   <one-to-one name=\"person\" \n"
+#~ "        property-ref=\"address\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "   <one-to-one name=\"person\" \n"
+#~ "        property-ref=\"address\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"address\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" \n"
+#~ "        constrained=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"address\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" \n"
+#~ "        constrained=\"true\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        inverse=\"true\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        inverse=\"true\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\"\n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"addressId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\"\n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"addressId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-many column=\"personId\"\n"
+#~ "            class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-many column=\"personId\"\n"
+#~ "            class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<properties name=\"currentAccountKey\">\n"
+#~ "    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
+#~ "    <property name=\"currentAccount\" type=\"boolean\">\n"
+#~ "        <formula>case when effectiveEndDate is null then 1 else 0 end</"
+#~ "formula>\n"
+#~ "    </property>\n"
+#~ "</properties>\n"
+#~ "<property name=\"effectiveEndDate\" type=\"date\"/>\n"
+#~ "<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<properties name=\"currentAccountKey\">\n"
+#~ "    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
+#~ "    <property name=\"currentAccount\" type=\"boolean\">\n"
+#~ "        <formula>case when effectiveEndDate is null then 1 else 0 end</"
+#~ "formula>\n"
+#~ "    </property>\n"
+#~ "</properties>\n"
+#~ "<property name=\"effectiveEndDate\" type=\"date\"/>\n"
+#~ "<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
+#~ "        property-ref=\"currentAccountKey\"\n"
+#~ "        class=\"AccountInfo\">\n"
+#~ "    <column name=\"accountNumber\"/>\n"
+#~ "    <formula>'1'</formula>\n"
+#~ "</many-to-one>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
+#~ "        property-ref=\"currentAccountKey\"\n"
+#~ "        class=\"AccountInfo\">\n"
+#~ "    <column name=\"accountNumber\"/>\n"
+#~ "    <formula>'1'</formula>\n"
+#~ "</many-to-one>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<join>\n"
+#~ "    <key column=\"employeeId\"/>\n"
+#~ "    <subselect>\n"
+#~ "        select employeeId, orgId \n"
+#~ "        from Employments \n"
+#~ "        group by orgId \n"
+#~ "        having startDate = max(startDate)\n"
+#~ "    </subselect>\n"
+#~ "    <many-to-one name=\"mostRecentEmployer\" \n"
+#~ "            class=\"Organization\" \n"
+#~ "            column=\"orgId\"/>\n"
+#~ "</join>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<join>\n"
+#~ "    <key column=\"employeeId\"/>\n"
+#~ "    <subselect>\n"
+#~ "        select employeeId, orgId \n"
+#~ "        from Employments \n"
+#~ "        group by orgId \n"
+#~ "        having startDate = max(startDate)\n"
+#~ "    </subselect>\n"
+#~ "    <many-to-one name=\"mostRecentEmployer\" \n"
+#~ "            class=\"Organization\" \n"
+#~ "            column=\"orgId\"/>\n"
+#~ "</join>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/basic_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/basic_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/basic_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,155 +1,185 @@
+# translation of basic_mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: basic_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-19 07:43+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: basic_mapping.xml:29
 #, no-c-format
 msgid "Basic O/R Mapping"
-msgstr "Mapeamento O/R Bassico"
+msgstr "Mapeamento O/R Básico"
 
 #. Tag: title
-#: basic_mapping.xml:32
 #, no-c-format
 msgid "Mapping declaration"
 msgstr "Declaração de mapeamento"
 
 #. Tag: para
-#: basic_mapping.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Object/relational mappings are usually defined in an XML document. The "
 "mapping document is designed to be readable and hand-editable. The mapping "
 "language is Java-centric, meaning that mappings are constructed around "
 "persistent class declarations and not table declarations."
 msgstr ""
-"Object/relational mappings are usually defined in an XML document. The "
-"mapping document is designed to be readable and hand-editable. The mapping "
-"language is Java-centric, meaning that mappings are constructed around "
-"persistent class declarations, not table declarations."
+"O mapeamento de objeto/relacional é geralmente definido em um documento XML. "
+"O documento de mapeamento é criado para ser de leitura e editável "
+"manualmente. A linguagem do mapeamento é Java-centric, ou seja, os "
+"mapeamentos são construídos em torno de declarações de classe persistente e "
+"não de declarações de tabelas. "
 
 #. Tag: para
-#: basic_mapping.xml:41
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please note that even though many Hibernate users choose to write the XML by "
 "hand, a number of tools exist to generate the mapping document. These "
 "include XDoclet, Middlegen and AndroMDA."
 msgstr ""
-"Note that, even though many Hibernate users choose to write the XML by hand, "
-"a number of tools exist to generate the mapping document, including XDoclet, "
-"Middlegen and AndroMDA."
+"Note que, embora muitos usuários do Hibernate escolham gravar o XML "
+"manualmente, existem diversas ferramentas para gerar o documento de "
+"mapeamento, incluindo o XDoclet Middlegen e AndroMDA."
 
 #. Tag: para
-#: basic_mapping.xml:47
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is an example mapping:"
-msgstr "Lets kick off with an example mapping:"
+msgstr "Vamos iniciar com um exemplo de mapeamento:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:51
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"      \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"          \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"        <class name=\"Cat\"\n"
-"            table=\"cats\"\n"
-"            discriminator-value=\"C\">\n"
-"\n"
-"                <id name=\"id\">\n"
-"                        <generator class=\"native\"/>\n"
-"                </id>\n"
-"\n"
-"                <discriminator column=\"subclass\"\n"
-"                     type=\"character\"/>\n"
-"\n"
-"                <property name=\"weight\"/>\n"
-"\n"
-"                <property name=\"birthdate\"\n"
-"                    type=\"date\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"color\"\n"
-"                    type=\"eg.types.ColorUserType\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"sex\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"litterId\"\n"
-"                    column=\"litterId\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <many-to-one name=\"mother\"\n"
-"                    column=\"mother_id\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <set name=\"kittens\"\n"
-"                    inverse=\"true\"\n"
-"                    order-by=\"litter_id\">\n"
-"                        <key column=\"mother_id\"/>\n"
-"                        <one-to-many class=\"Cat\"/>\n"
-"                </set>\n"
-"\n"
-"                <subclass name=\"DomesticCat\"\n"
-"                    discriminator-value=\"D\">\n"
-"\n"
-"                        <property name=\"name\"\n"
-"                            type=\"string\"/>\n"
-"\n"
-"                </subclass>\n"
-"\n"
-"        </class>\n"
-"\n"
-"        <class name=\"Dog\">\n"
-"                <!-- mapping for Dog could go here -->\n"
-"        </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:53
-#, fuzzy, no-c-format
-msgid ""
 "We will now discuss the content of the mapping document. We will only "
 "describe, however, the document elements and attributes that are used by "
 "Hibernate at runtime. The mapping document also contains some extra optional "
 "attributes and elements that affect the database schemas exported by the "
 "schema export tool (for example, the <literal> not-null</literal> attribute)."
 msgstr ""
-"Discutir agora o conteúdo deste documento de mapeamento. Iremos apenas "
-"descrever os elementos do documento e atributos que são utilizados pelo "
+"Discutiremos agora o conteúdo deste documento de mapeamento. Iremos apenas "
+"descrever os elementos do documento e funções que são utilizadas pelo "
 "Hibernate em tempo de execução. O documento de mapeamento também contém "
-"alguns atributos adicionais e opcionais além de elementos que afetam os "
+"algumas funções adicionais e opcionais além de elementos que afetam os "
 "esquemas de banco de dados exportados pela ferramenta de exportação de "
-"esquemas. (Por exemplo, o atributo <literal>not-null</literal>)."
+"esquemas. (Por exemplo, o atributo <literal>not-null</literal>). "
 
 #. Tag: title
-#: basic_mapping.xml:64
 #, no-c-format
 msgid "Doctype"
 msgstr "Doctype"
 
 #. Tag: para
-#: basic_mapping.xml:66
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All XML mappings should declare the doctype shown. The actual DTD can be "
 "found at the URL above, in the directory <literal>hibernate-x.x.x/src/org/"
@@ -163,17 +193,15 @@
 "org/ hibernate </literal> ou no <literal>hibernate3.jar</literal>. O "
 "Hibernate sempre irá procurar pelo DTD inicialmente no seu classpath. Se "
 "você tentar localizar o DTD usando uma conexão de internet, compare a "
-"declaração do seu DTD com o conteúdo do seu classpath"
+"declaração do seu DTD com o conteúdo do seu classpath."
 
 #. Tag: title
-#: basic_mapping.xml:76
 #, no-c-format
 msgid "EntityResolver"
-msgstr "EntityResolver"
+msgstr "Solucionador de Entidade"
 
 #. Tag: para
-#: basic_mapping.xml:77
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will first attempt to resolve DTDs in its classpath. It does this "
 "is by registering a custom <literal>org.xml.sax.EntityResolver</literal> "
@@ -181,30 +209,27 @@
 "custom <literal>EntityResolver</literal> recognizes two different systemId "
 "namespaces:"
 msgstr ""
-"As mentioned previously, Hibernate will first attempt to resolve DTDs in its "
-"classpath. The manner in which it does this is by registering a custom "
-"<literal>org.xml.sax.EntityResolver</literal> implementation with the "
-"SAXReader it uses to read in the xml files. This custom "
-"<literal>EntityResolver</literal> recognizes two different systemId "
-"namespaces."
+"O Hibernate irá primeiro tentar solucionar os DTDs em seus classpath. Isto é "
+"feito, registrando uma implementação <literal>org.xml.sax.EntityResolver</"
+"literal> personalizada com o SAXReader que ele utiliza para ler os arquivos "
+"xml. Este <literal>EntityResolver</literal> personalizado, reconhece dois "
+"nomes de espaço de sistemas Id diferentes:"
 
 #. Tag: para
-#: basic_mapping.xml:85
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "a <literal>hibernate namespace</literal> is recognized whenever the resolver "
 "encounters a systemId starting with <literal>http://hibernate.sourceforge."
 "net/</literal>. The resolver attempts to resolve these entities via the "
 "classloader which loaded the Hibernate classes."
 msgstr ""
-"a <literal>hibernate namespace</literal> is recognized whenever the resolver "
-"encounteres a systemId starting with <literal>http://hibernate.sourceforge."
-"net/</literal>; the resolver attempts to resolve these entities via the "
-"classlaoder which loaded the Hibernate classes."
+"Um <literal>hibernate namespace</literal> é reconhecido quando um "
+"solucionador encontra um systema Id iniciando com <literal>http://hibernate."
+"sourceforge.net/</literal>. O solucionador tenta solucionar estas entidades "
+"através do carregador de classe que carregou as classes do Hibernate. "
 
 #. Tag: para
-#: basic_mapping.xml:94
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "a <literal>user namespace</literal> is recognized whenever the resolver "
 "encounters a systemId using a <literal>classpath://</literal> URL protocol. "
@@ -212,60 +237,35 @@
 "thread context classloader and (2) the classloader which loaded the "
 "Hibernate classes."
 msgstr ""
-"a <literal>user namespace</literal> is recognized whenever the resolver "
-"encounteres a systemId using a <literal>classpath://</literal> URL protocol; "
-"the resolver will attempt to resolve these entities via (1) the current "
-"thread context classloader and (2) the classloader which loaded the "
-"Hibernate classes."
+"Um <literal>user namespace</literal> é reconhecido quando um solucionador "
+"encontra um sistema Id, utilizando um protocolo URL de <literal>classpath://"
+"</literal>. O solucionador tentará solucionar estas entidades através do "
+"carregador de classe do contexto de thread atual (1) e o carregador de "
+"classe (2) que carregou as classes do Hibernate. "
 
 #. Tag: para
-#: basic_mapping.xml:103
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The following is an example of utilizing user namespacing:"
-msgstr "An example of utilizing user namespacing:"
+msgstr "Um exemplo de utilização do espaço de nome do usuário:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:106
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\" [\n"
-"    <!ENTITY types SYSTEM \"classpath://your/domain/types.xml\">\n"
-"]>\n"
-"\n"
-"<hibernate-mapping package=\"your.domain\">\n"
-"    <class name=\"MyEntity\">\n"
-"        <id name=\"id\" type=\"my-custom-id-type\">\n"
-"            ...\n"
-"        </id>\n"
-"    <class>\n"
-"    &types;\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:107
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Where <literal>types.xml</literal> is a resource in the <literal>your."
 "domain</literal> package and contains a custom <link linkend=\"mapping-types-"
 "custom\">typedef</link>."
 msgstr ""
-"Where <literal>types.xml</literal> is a resource in the <literal>your."
-"domain</literal> package and contains a custom <xref linkend=\"mapping-types-"
-"custom\">typedef</xref>."
+"Onde <literal>types.xml</literal> é um recurso no pacote <literal>your."
+"domain</literal> e contém um <xref linkend=\"mapping-types-custom\"/> "
+"personalizado."
 
 #. Tag: title
-#: basic_mapping.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Hibernate-mapping"
-msgstr "hibernate-mapping"
+msgstr "Mapeamento do Hibernate"
 
 #. Tag: para
-#: basic_mapping.xml:117
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This element has several optional attributes. The <literal>schema</literal> "
 "and <literal>catalog</literal> attributes specify that tables referred to in "
@@ -278,119 +278,96 @@
 "literal> attribute allows you to use unqualified class names in the query "
 "language."
 msgstr ""
-"Este elemento tem diversos atributos opcionais. Os atributos "
+"Este elemento possui diversos atributos opcionais. Os atributos "
 "<literal>schema</literal> e <literal>catalog</literal> especificam que "
-"tabelas referenciadas neste mapeamento pertencem ao esquema e/ou ao catalogo "
-"nomeado. Se especificados, os nomes das tabelas irão ser qualificados no "
-"schema ou catalog dado. Se não, os nomes das tabelas não serão qualificados. "
-"O atributo <literal>default-cascade </literal> especifica qual estilo de "
-"cascata será assumido pelas propriedades e coleções que não especificarm um "
-"atributo <literal>cascade</literal>. O atributo <literal>auto-import</"
-"literal> nos deixa utilizar nomes de classes não qualificados na linguagem "
-"de consulta, por default."
+"tabelas referenciadas neste mapeamento pertencem ao esquema e/ou ao catálogo "
+"nomeado. Se especificados, os nomes das tabelas serão qualificados no "
+"esquema ou catálogo dado. Se não, os nomes das tabelas não serão "
+"qualificados. O atributo <literal>default-cascade</literal> especifica qual "
+"estilo de cascata será considerado pelas propriedades e coleções que não "
+"especificarem uma função <literal>cascade</literal>. A função <literal>auto-"
+"import</literal> nos deixa utilizar nomes de classes não qualificados na "
+"linguagem de consulta, por padrão."
 
-#. Tag: programlisting
-#: basic_mapping.xml:138
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping\n"
-"         schema=\"schemaName\"\n"
-"         catalog=\"catalogName\"\n"
-"         default-cascade=\"cascade_style\"\n"
-"         default-access=\"field|property|ClassName\"\n"
-"         default-lazy=\"true|false\"\n"
-"         auto-import=\"true|false\"\n"
-"         package=\"package.name\"\n"
-" />]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:141
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>schema</literal> (optional): the name of a database schema."
 msgstr ""
-"<literal>schema</literal> (opcional): O nome do esquema do banco de dados."
+"<literal>schema</literal> (opcional): O nome do esquema do banco de dados. "
 
 #. Tag: para
-#: basic_mapping.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>catalog</literal> (optional): the name of a database catalog."
 msgstr ""
-"<literal>catalog</literal> (opcional): O nome do catálogo do banco de dados."
+"<literal>catalog</literal> (opcional): O nome do catálogo do banco de dados. "
 
 #. Tag: para
-#: basic_mapping.xml:151
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>default-cascade</literal> (optional - defaults to <literal>none</"
 "literal>): a default cascade style."
 msgstr ""
-"<literal>default-cascade</literal> (opcional – default é <literal>nenhum </"
-"literal>): Um estilo cascata default."
+"<literal>default-cascade</literal> (opcional – o padrão é <literal>none</"
+"literal>): Um estilo cascata padrão."
 
 #. Tag: para
-#: basic_mapping.xml:157
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>default-access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate should use for accessing all properties. "
 "It can be a custom implementation of <literal>PropertyAccessor</literal>."
 msgstr ""
-"<literal>default-access</literal> (opcional – default é <literal>property</"
+"<literal>default-access</literal> (opcional – o padrão é <literal>property</"
 "literal>): A estratégia que o Hibernate deve utilizar para acessar todas as "
-"propridades. Pode ser uma implementação própria de "
+"propridades. Pode ser uma implementação personalizada de "
 "<literal>PropertyAccessor</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:164
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>default-lazy</literal> (optional - defaults to <literal>true</"
 "literal>): the default value for unspecified <literal>lazy</literal> "
 "attributes of class and collection mappings."
 msgstr ""
-"<literal>default-lazy</literal> (opcional - default é <literal>true</"
-"literal>): O valor default para atributos <literal>lazy</literal> da classe "
-"e dos mapeamentos de coleções."
+"<literal>default-lazy</literal> (opcional - o padrão é <literal>true</"
+"literal>): O valor padrão para atributos <literal>lazy</literal> não "
+"especificados da classe e dos mapeamentos de coleções."
 
 #. Tag: para
-#: basic_mapping.xml:171
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>auto-import</literal> (optional - defaults to <literal>true</"
 "literal>): specifies whether we can use unqualified class names of classes "
 "in this mapping in the query language."
 msgstr ""
-"<literal>auto-import</literal> ((opcional - default é <literal>true</"
-"literal>): Especifica se nós podemos usar nomes de classess não qualificados "
-"(das classes deste mapeamento) na linguagem de consulta."
+"<literal>auto-import</literal> (opcional - o padrão é <literal>true</"
+"literal>): Especifica se podemos usar nomes de classes não qualificados, das "
+"classes deste mapeamento, na linguagem de consulta."
 
 #. Tag: para
-#: basic_mapping.xml:178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>package</literal> (optional): specifies a package prefix to use for "
 "unqualified class names in the mapping document."
 msgstr ""
-"<literal>package</literal> (opcional): Especifica um prefixo da package para "
-"assumir para nomes de classes não qualificadas no documento de mapeamento."
+"<literal>package</literal> (opcional): Especifica um prefixo do pacote a ser "
+"considerado para nomes de classes não qualificadas no documento de "
+"mapeamento. "
 
 #. Tag: para
-#: basic_mapping.xml:186
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you have two persistent classes with the same unqualified name, you "
 "should set <literal>auto-import=\"false\"</literal>. An exception will "
 "result if you attempt to assign two classes to the same \"imported\" name."
 msgstr ""
-"Se voce tem duas classes persistentes com o mesmo nome (não qualificadas), "
-"você deve setar <literal>auto-import=\"false\"</literal>. O Hibernate irá "
-"gerar uma exceção se você tentar setar duas classes para o mesmo nome "
-"\"importado\"."
+"Se você tem duas classes persistentes com o mesmo nome (não qualificadas), "
+"você deve ajustar <literal>auto-import=\"false\"</literal>. Caso você tentar "
+"ajustar duas classes para o mesmo nome \"importado\", isto resultará numa "
+"exceção."
 
 #. Tag: para
-#: basic_mapping.xml:192
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>hibernate-mapping</literal> element allows you to nest several "
 "persistent <literal>&lt;class&gt;</literal> mappings, as shown above. It is, "
@@ -400,177 +377,125 @@
 "literal>, <literal>Dog.hbm.xml</literal>, or if using inheritance, "
 "<literal>Animal.hbm.xml</literal>."
 msgstr ""
-"Observe que o elemento <literal>hibernate-mapping</literal> permite a você "
-"aninhar diversos mapeamentos de <literal>&lt;class&gt;</literal> "
+"Observe que o elemento <literal>hibernate-mapping</literal> permite que você "
+"aninhe diversos mapeamentos de <literal>&lt;class&gt;</literal> "
 "persistentes, como mostrado abaixo. Entretanto, é uma boa prática (e "
-"esperado por algumas ferramentas)o mapeamento de apenas uma classe "
+"esperado por algumas ferramentas) o mapeamento de apenas uma classe "
 "persistente simples (ou uma hierarquia de classes simples) em um arquivo de "
-"mapeamento e nomea-la após a superclasse persistente, por exemplo: "
+"mapeamento e nomeá-la após a superclasse persistente, por exemplo: "
 "<literal>Cat.hbm.xml</literal>, <literal>Dog.hbm.xml</literal>, ou se "
-"estiver usando herança, <literal>Animal.hbm.xml</literal>."
+"estiver usando herança, <literal>Animal.hbm.xml</literal>. "
 
 #. Tag: title
-#: basic_mapping.xml:205
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Class"
-msgstr "class"
+msgstr "Classe"
 
 #. Tag: para
-#: basic_mapping.xml:207
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can declare a persistent class using the <literal>class</literal> "
 "element. For example:"
 msgstr ""
 "Você pode declarar uma classe persistente utilizando o elemento "
-"<literal>class</literal>:"
+"<literal>class</literal>. Por exemplo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:235
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class\n"
-"        name=\"ClassName\"\n"
-"        table=\"tableName\"\n"
-"        discriminator-value=\"discriminator_value\"\n"
-"        mutable=\"true|false\"\n"
-"        schema=\"owner\"\n"
-"        catalog=\"catalog\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        select-before-update=\"true|false\"\n"
-"        polymorphism=\"implicit|explicit\"\n"
-"        where=\"arbitrary sql where condition\"\n"
-"        persister=\"PersisterClass\"\n"
-"        batch-size=\"N\"\n"
-"        optimistic-lock=\"none|version|dirty|all\"\n"
-"        lazy=\"true|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        check=\"arbitrary sql check condition\"\n"
-"        rowid=\"rowid\"\n"
-"        subselect=\"SQL expression\"\n"
-"        abstract=\"true|false\"\n"
-"        node=\"element-name\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:238
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal> (optional): the fully qualified Java class name of "
 "the persistent class or interface. If this attribute is missing, it is "
 "assumed that the mapping is for a non-POJO entity."
 msgstr ""
 "<literal>name</literal> (opcional): O nome da classe Java inteiramente "
-"qualificado da classe persistente (ou interface); Se o atributo é ausente, "
-"assume-se que o mapeamento é para intidades não-POJO."
+"qualificado da classe persistente (ou interface). Se a função é ausente, "
+"assume-se que o mapeamento é para entidades não-POJO. "
 
 #. Tag: para
-#: basic_mapping.xml:245
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>table</literal> (optional - defaults to the unqualified class "
 "name): the name of its database table."
 msgstr ""
-"<literal>table</literal> (opcional – default para nomes de classes não "
-"qualificadas) O nome da sua tabela do banco de dados."
+"<literal>table</literal> (opcional – padrão para nomes de classes não "
+"qualificadas): O nome da sua tabela do banco de dados."
 
 #. Tag: para
-#: basic_mapping.xml:251
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>discriminator-value</literal> (optional - defaults to the class "
 "name): a value that distinguishes individual subclasses that is used for "
 "polymorphic behavior. Acceptable values include <literal>null</literal> and "
 "<literal>not null</literal>."
 msgstr ""
-"<literal>discriminator-value</literal> (opcional – default para o nome da "
+"<literal>discriminator-value</literal> (opcional – padrão para o nome da "
 "classe): Um valor que distingue subclasses individuais, usadas para o "
-"comportamento polimorfico. Valores aceitos incluem <literal>null</literal> e "
-"<literal>not null</literal>"
+"comportamento polimórfico. Valores aceitos incluem <literal>null</literal> e "
+"<literal>not null</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>true</literal>): "
 "specifies that instances of the class are (not) mutable."
 msgstr ""
-"<literal>mutable</literal> (opcional - valor default <literal>true</"
-"literal>): Especifica que instancias da classe são (ou não) mutáveis"
+"<literal>mutable</literal> (opcional - valor padrão <literal>true</"
+"literal>): Especifica quais instâncias da classe são (ou não) mutáveis."
 
 #. Tag: para
-#: basic_mapping.xml:264 basic_mapping.xml:2231
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>schema</literal> (optional): overrides the schema name specified by "
 "the root <literal>&lt;hibernate-mapping&gt;</literal> element."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>schema</literal> (opcional): Sobrepõe o nome do esquema "
-"especificado pelo elemento root <literal>&lt;hibernate-mapping&gt;</"
-"literal>.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>schema</literal> (opcional): Sobrepõe o nome do esquema "
-"especificado pelo elemento raiz <literal>&lt;hibernate-mapping&gt;</literal>."
+"especificado pelo elemento raíz <literal>&lt;hibernate-mapping&gt;</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:270 basic_mapping.xml:2237
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>catalog</literal> (optional): overrides the catalog name specified "
 "by the root <literal>&lt;hibernate-mapping&gt;</literal> element."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>catalog</literal> (opcional): Sobrepõe o nome do catálogo "
-"especificado pelo elemento root <literal>&lt;hibernate-mapping&gt;</"
-"literal>.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>catalog</literal> (opcional): Sobrepõe o nome do catálogo "
-"especificado pelo elemento raiz<literal>&lt;hibernate-mapping&gt;</literal>."
+"especificado pelo elemento raíz <literal>&lt;hibernate-mapping&gt;</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:276
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies an interface to use for lazy "
 "initializing proxies. You can specify the name of the class itself."
 msgstr ""
-"<literal>proxy</literal> (opcional): Especifica um interface para ser "
-"utilizada pelos proxies de inicialização tardia. Você pode especificar o "
-"nome da própria classe."
+"<literal>proxy</literal> (opcional): Especifica uma interface para ser "
+"utilizada pelos proxies de inicialização lazy. Você pode especificar o nome "
+"da própria classe. "
 
 #. Tag: para
-#: basic_mapping.xml:282
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>dynamic-update</literal> (optional - defaults to <literal>false</"
 "literal>): specifies that <literal>UPDATE</literal> SQL should be generated "
 "at runtime and can contain only those columns whose values have changed."
 msgstr ""
-"<literal>dynamic-update</literal> (opcional, valor default <literal>false</"
+"<literal>dynamic-update</literal> (opcional, valor padrão <literal>false</"
 "literal>): Especifica que o SQL de <literal>UPDATE</literal> deve ser gerado "
 "em tempo de execução e conter apenas aquelas colunas cujos valores foram "
-"alterados."
+"alterados. "
 
 #. Tag: para
-#: basic_mapping.xml:289
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>dynamic-insert</literal> (optional - defaults to <literal>false</"
 "literal>): specifies that <literal>INSERT</literal> SQL should be generated "
 "at runtime and contain only the columns whose values are not null."
 msgstr ""
-"<literal>dynamic-insert</literal> (opcional, valor default <literal>false</"
+"<literal>dynamic-insert</literal> (opcional, valor padrão <literal>falso</"
 "literal>): Especifica que o SQL de <literal>INSERT</literal> deve ser gerado "
 "em tempo de execução e conter apenas aquelas colunas cujos valores não estão "
-"nulos."
+"nulos. "
 
 #. Tag: para
-#: basic_mapping.xml:296
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>select-before-update</literal> (optional - defaults to "
 "<literal>false</literal>): specifies that Hibernate should <emphasis>never</"
@@ -580,116 +505,106 @@
 "Hibernate perform an extra SQL <literal>SELECT</literal> to determine if an "
 "<literal>UPDATE</literal> is actually required."
 msgstr ""
-"<literal>select-before-update</literal> (opcional, valor default "
-"<literal>false</literal>): Especifica que o Hibernate <emphasis>never</"
+"<literal>select-before-update</literal> (opcional, valor padrão "
+"<literal>false</literal>): Especifica que o Hibernate <emphasis>nunca</"
 "emphasis> deve executar um SQL de <literal>UPDATE</literal> a não ser que "
-"com certeza um objeto está atualmente modificado. Em certos casos "
-"(atualmente, apenas quando um objeto transiente foi associado com uma nova "
-"sessão utilizando <literal>update()</literal>), isto significa que o "
-"Hibernate ira executar uma instrução SQL de <literal>SELECT</literal> "
-"adicional para determinar se um <literal>UPDATE</literal> é necessário nesse "
-"momento."
+"seja certo que um objeto está atualmente modificado. Em certos casos (na "
+"verdade, apenas quando um objeto transiente foi associado a uma nova sessão "
+"utilizando <literal>update()</literal>), isto significa que o Hibernate irá "
+"executar uma instrução SQL de <literal>SELECT</literal> adicional para "
+"determinar se um <literal>UPDATE</literal> é necessário nesse momento."
 
 #. Tag: para
-#: basic_mapping.xml:306
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>polymorphism</literal> (optional - defaults to <literal>implicit</"
 "literal>): determines whether implicit or explicit query polymorphism is "
 "used."
 msgstr ""
-"<literal>polymorphism</literal> (opcional, default para <literal>implicit</"
-"literal>): Determina se deve ser utilizado a query polimorfica implicita ou "
-"explicitamente."
+"<literal>polymorphism</literal> (opcional, padrão para <literal>implicit</"
+"literal>): Determina se deve ser utilizado a consulta polimórfica implícita "
+"ou explicitamente. "
 
 #. Tag: para
-#: basic_mapping.xml:312
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>where</literal> (optional): specifies an arbitrary SQL "
 "<literal>WHERE</literal> condition to be used when retrieving objects of "
 "this class."
 msgstr ""
-"<literal>where</literal> (opicional) especifica um comando SQL "
+"<literal>where</literal> (opicional): Especifica um comando SQL "
 "<literal>WHERE</literal> arbitrário para ser usado quando da recuperação de "
 "objetos desta classe."
 
 #. Tag: para
-#: basic_mapping.xml:318
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>persister</literal> (optional): specifies a custom "
 "<literal>ClassPersister</literal>."
 msgstr ""
-"<literal>persister</literal> (opcional): Espeicifca uma "
+"<literal>persister</literal> (opcional): Especifica uma "
 "<literal>ClassPersister</literal> customizada."
 
 #. Tag: para
-#: basic_mapping.xml:323
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>batch-size</literal> (optional - defaults to <literal>1</literal>): "
 "specifies a \"batch size\" for fetching instances of this class by "
 "identifier."
 msgstr ""
-"<literal>batch-size</literal> (opcional, valor default <literal>1</literal>) "
-"especifica um \"tamanho de lote\" para a recuperação de instancias desta "
-"classe pelo identificador."
+"<literal>batch-size</literal> (opcional, valor padrão <literal>1</literal>) "
+"Especifica um \"tamanho de lote\" para a recuperação de instâncias desta "
+"classe pela identificação."
 
 #. Tag: para
-#: basic_mapping.xml:329
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>version</"
 "literal>): determines the optimistic locking strategy."
 msgstr ""
-"<literal>optimistic-lock</literal> (octional, valor default "
-"<literal>version</literal>): Determina a estratégia de bloqueio."
+"<literal>optimistic-lock</literal> (opcional, valor padrão <literal>version</"
+"literal>): Determina a estratégia de bloqueio."
 
 #. Tag: para
-#: basic_mapping.xml:335
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional): lazy fetching can be disabled by setting "
 "<literal>lazy=\"false\"</literal>."
 msgstr ""
-"<literal>lazy</literal> (opcional): A recuperação tardia pode ser "
-"completamente desabilitada, setando <literal>lazy=\"false\"</literal>."
+"<literal>lazy</literal> (opcional): A recuperação lazy pode ser "
+"completamente desabilitada, ajustando <literal>lazy=\"false\"</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:341
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>entity-name</literal> (optional - defaults to the class name): "
 "Hibernate3 allows a class to be mapped multiple times, potentially to "
 "different tables. It also allows entity mappings that are represented by "
 "Maps or XML at the Java level. In these cases, you should provide an "
 "explicit arbitrary name for the entity. See <xref linkend=\"persistent-"
-"classes-dynamicmodels\"/> and <xref linkend=\"xml\"/> for more information."
+"classes-dynamicmodels\" /> and <xref linkend=\"xml\" /> for more information."
 msgstr ""
-"<literal>entity-name</literal> (opcional, default para o nome da classe): O "
-"Hibernate3 permite uma classe ser mapeada multiplas vezes, (potencialmente,"
-"para diferentes tabelas), e permite mapeamentos de entidades que são "
-"representadas por Maps ou XML no nível Java. Nestes casos, você deve "
+"<literal>entity-name</literal> (opcional - padrão para o nome da classe): O "
+"Hibernate3 permite uma classe ser mapeada múltiplas vezes, potencialmente "
+"para diferentes tabelas. Além disso, isto permite mapeamentos de entidades "
+"que são representadas por Maps ou XML no nível Java. Nestes casos, você deve "
 "especificar um nome arbitrário explicitamente para a entidade. Veja <xref "
 "linkend=\"persistent-classes-dynamicmodels\"/> e <xref linkend=\"xml\"/> "
 "para maiores informações."
 
 #. Tag: para
-#: basic_mapping.xml:351
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>check</literal> (optional): an SQL expression used to generate a "
 "multi-row <emphasis>check</emphasis> constraint for automatic schema "
 "generation."
 msgstr ""
 "<literal>check</literal> (opcional): Uma expressão SQL utilizada para gerar "
-"uma constraint de <emphasis>verificação</emphasis> de múltiplas linhas para "
-"a geração automática do esquema."
+"uma restrição de <emphasis>verificação</emphasis> de múltiplas linhas para a "
+"geração automática do esquema. "
 
 #. Tag: para
-#: basic_mapping.xml:357
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>rowid</literal> (optional): Hibernate can use ROWIDs on databases. "
 "On Oracle, for example, Hibernate can use the <literal>rowid</literal> extra "
@@ -697,41 +612,36 @@
 "literal>. A ROWID is an implementation detail and represents the physical "
 "location of a stored tuple."
 msgstr ""
-"<literal>rowid</literal> (opcional): O Hibernate poder usar as assim "
+"<literal>rowid</literal> (opcional): O Hibernate poder usar as então "
 "chamadas ROWIDs em bancos de dados que a suportam. Por exemplo, no Oracle, o "
 "Hibernate pode utilizar a coluna extra rowid para atualizações mais rápidas "
 "se você configurar esta opção para <literal>rowid</literal>. Um ROWID é uma "
 "implementação que representa de maneira detalhada a localização física de "
-"uma determinada tupla armazenado."
+"uma determinada tuple armazenada. "
 
 #. Tag: para
-#: basic_mapping.xml:364
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>subselect</literal> (optional): maps an immutable and read-only "
 "entity to a database subselect. This is useful if you want to have a view "
 "instead of a base table. See below for more information."
 msgstr ""
-"<literal>subselect</literal> (optional): Maps an immutable and read-only "
-"entity to a database subselect. Useful if you want to have a view instead of "
-"a base table, but don't. See below for more information. <literal>subselect</"
-"literal> (opcional): Mapeia uma entidade imutavel e somente de leitura para "
-"um subconjunto do banco de dados. Útil se você quiser ter uma view em vez de "
-"uma tabela. Veja abaixo para mais informações."
+"<literal>subselect</literal> (opcional): Mapeia uma entidade imutável e "
+"somente de leitura para um subconjunto do banco de dados. Útil se você "
+"quiser ter uma visão, ao invés de uma tabela. Veja abaixo para mais "
+"informações. "
 
 #. Tag: para
-#: basic_mapping.xml:371
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>abstract</literal> (optional): is used to mark abstract "
 "superclasses in <literal>&lt;union-subclass&gt;</literal> hierarchies."
 msgstr ""
 "<literal>abstract</literal> (opcional): Utilizada para marcar superclasses "
-"abstratas em hierarquias <literal>&lt;union-subclass&gt;</literal>."
+"abstratas em hierarquias <literal>&lt;union-subclass&gt;</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:379
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is acceptable for the named persistent class to be an interface. You can "
 "declare implementing classes of that interface using the <literal>&lt;"
@@ -739,28 +649,26 @@
 "emphasis> inner class. Specify the class name using the standard form i.e. "
 "<literal>e.g.Foo$Bar</literal>."
 msgstr ""
-"É perfeitamente aceitável para uma classe persitente nomeada ser uma "
-"interface. Você deverá então declarar as classes implementadas desta "
-"interface utilizando o elemento <literal>&lt;subclass&gt;</literal>. Você "
-"pode persistir qualquer classe de aninhada <emphasis>estatica</emphasis>. "
-"Você deverá especificar o nome da classe usando a forma padrão, por exemplo: "
-"<literal>eg.Foo$Bar</literal>."
+"É perfeitamente aceitável uma classe persitente nomeada ser uma interface. "
+"Você deverá então declarar as classes implementadas desta interface "
+"utilizando o elemento <literal>&lt;subclass&gt;</literal>. Você pode "
+"persistir qualquer classe interna <emphasis>estática</emphasis>. Você deverá "
+"especificar o nome da classe usando a forma padrão, por exemplo: <literal>eg."
+"Foo&#36;Bar</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:386
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Immutable classes, <literal>mutable=\"false\"</literal>, cannot be updated "
 "or deleted by the application. This allows Hibernate to make some minor "
 "performance optimizations."
 msgstr ""
 "Classes imutáveis, <literal>mutable=\"false\"</literal>, não podem ser "
-"modificadas ou excluídas pela aplicação. Isso permite ao Hibernate fazer "
-"alguns aperfeiçoamentos de performance."
+"modificadas ou excluídas pela aplicação. Isso permite que o Hibernate "
+"aperfeiçoe o desempenho. "
 
 #. Tag: para
-#: basic_mapping.xml:391
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The optional <literal>proxy</literal> attribute enables lazy initialization "
 "of persistent instances of the class. Hibernate will initially return CGLIB "
@@ -768,15 +676,14 @@
 "when a method of the proxy is invoked. See \"Initializing collections and "
 "proxies\" below."
 msgstr ""
-"O atributo opcional <literal>proxy</literal> habilita a inicialização tardia "
-"das instâncias persistentes da classe. O Hibernate irá retornar CGLIB "
-"proxies como implementado na interface nomeada. O objeto persistente atual "
-"será carregado quando um método do proxy for invocado. Veja \"Inicializando "
-"coleções e proxies\" abaixo."
+"A função opcional <literal>proxy</literal> habilita a inicialização lazy das "
+"instâncias persistentes da classe. O Hibernate irá retornar CGLIB proxies "
+"como implementado na interface nomeada. O objeto persistente atual será "
+"carregado quando um método do proxy for invocado. Veja \"Inicialização de "
+"Coleções e Proxies\" abaixo. "
 
 #. Tag: para
-#: basic_mapping.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Implicit</emphasis> polymorphism means that instances of the class "
 "will be returned by a query that names any superclass or implemented "
@@ -793,22 +700,22 @@
 "table columns."
 msgstr ""
 "Polimorfismo <emphasis>implícito</emphasis> significa que instâncias de uma "
-"classe serão retornada por uma query que dá nome a qualquer superclasse ou "
-"interface implementada, ou a classe e as instancias de qualquer subclasse da "
-"classe será retornada por umq query que nomeia a classe por si. Polimorfismo "
-"<emphasis>explícito</emphasis> significa que instancias da classe serão "
-"retornadas apenas por queries que explicitamente nomeiam a classe e que "
-"queries que nomeiam as classes irão retornar apenas instancias de subclasses "
-"mapeadas dentro da declaração <literal>&lt;class&gt;</literal> como uma "
-"<literal>&lt;subclass&gt;</literal> ou <literal>&lt;joined-subclass&gt;</"
-"literal>. Para a maioria dos casos, o valor default <literal>polymorphism="
-"\"implicit\"</literal>, é apropriado. Polimorfismo explicito é útil quando "
-"duas classes distintas estão mapeadas para a mesma tabela (isso permite um "
-"classe \"peso leve\" que contem um subconjunto de colunas da tabela)."
+"classe serão retornadas por uma consulta que dá nome a qualquer superclasse "
+"ou interface e classe implementada, além das instâncias de qualquer "
+"subclasse da classe serão retornadas por uma consulta que nomeia a classe "
+"por si. Polimorfismo <emphasis>explícito</emphasis> significa que instâncias "
+"da classe serão retornadas apenas por consultas que explicitamente nomeiam a "
+"classe e que as consultas que nomeiam as classes irão retornar apenas "
+"instâncias de subclasses mapeadas dentro da declaração <literal>&lt;class&gt;"
+"</literal> como uma <literal>&lt;subclass&gt;</literal> ou <literal>&lt;"
+"joined-subclass&gt;</literal>. Para a maioria dos casos, o valor padrão "
+"<literal>polymorphism=\"implicit\"</literal>, é apropriado. Polimorfismo "
+"explicito é útil quando duas classes distintas estão mapeadas para a mesma "
+"tabela. Isso aceita uma classe \"peso leve\" que contém um subconjunto de "
+"colunas da tabela. "
 
 #. Tag: para
-#: basic_mapping.xml:410
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>persister</literal> attribute lets you customize the "
 "persistence strategy used for the class. You can, for example, specify your "
@@ -821,17 +728,16 @@
 msgstr ""
 "O atributo <literal>persister</literal> deixa você customizar a estratégia "
 "de persistência utilizada para a classe. Você pode, por exemplo, especificar "
-"sua prórpia subclasse do <literal>org.hibernate.persister.EntityPersister</"
+"sua própria subclasse do <literal>org.hibernate.persister.EntityPersister</"
 "literal> ou você pode criar uma implementação completamente nova da "
 "interface <literal>org.hibernate.persister.ClassPersister</literal> que "
-"implementa a persistência através de, por exemplo, chamadas a stored "
-"procedeures, serialização de arquivos flat ou LDAP. Veja <literal>org."
-"hibernate.test.CustomPersister</literal> para um exemplo simples (de "
-"\"persistencia\" para uma <literal>Hashtable</literal>)."
+"implementa a persistência através de, por exemplo, chamadas a procedimentos "
+"armazenados, serialização de arquivos planos ou LDAP. Veja <literal>org."
+"hibernate.test.CustomPersister</literal> para um exemplo simples de "
+"\"persistência\" para uma <literal>Hashtable</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:421
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>dynamic-update</literal> and <literal>dynamic-insert</literal> "
 "settings are not inherited by subclasses, so they can also be specified on "
@@ -840,28 +746,26 @@
 "cases, they can actually decrease performance in others."
 msgstr ""
 "Observe que as configurações <literal>dynamic-update</literal> e "
-"<literal>dynamic-insert</literal> não sao herdadas pelas subclasses e assim "
-"podem tambem ser especificadas em elementos <literal>&lt;subclass&gt;</"
-"literal> or <literal>&lt;joined-subclass&gt;</literal>. Estas configurações "
-"podem incrementar a performance em alguns casos, mas pode realmente diminuir "
-"a performance em outras. Use-as de forma bastante criteriosa."
+"<literal>dynamic-insert</literal> não são herdadas pelas subclasses e assim "
+"podem também ser especificadas em elementos <literal>&lt;subclass&gt;</"
+"literal> ou <literal>&lt;joined-subclass&gt;</literal>. Estas configurações "
+"podem incrementar o desempenho em alguns casos, mas podem realmente diminuir "
+"o desempenho em outras. "
 
 #. Tag: para
-#: basic_mapping.xml:429
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use of <literal>select-before-update</literal> will usually decrease "
 "performance. It is useful to prevent a database update trigger being called "
 "unnecessarily if you reattach a graph of detached instances to a "
 "<literal>Session</literal>."
 msgstr ""
-"O uso de <literal>select-before-update</literal> geralmente irá diminuir a "
-"performance. Ela é muito útil para prevenir que uma trigger de atualização "
-"no banco de dados seja ativada desnecessariamente, se você reconectar um nó "
-"de uma instancia desconectada em uma <literal>Session</literal>."
+"O uso de <literal>select-before-update</literal> geralmente irá diminuir o "
+"desempenho. Ela é muito útil para prevenir que um trigger de atualização no "
+"banco de dados seja ativado desnecessariamente, se você reconectar um nó de "
+"uma instância desconectada em uma <literal>Session</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:435
 #, no-c-format
 msgid ""
 "If you enable <literal>dynamic-update</literal>, you will have a choice of "
@@ -871,51 +775,45 @@
 "estratégia de bloqueio otimista:"
 
 #. Tag: para
-#: basic_mapping.xml:441
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>version</literal>: check the version/timestamp columns"
-msgstr "<literal>version</literal> verifica a versão e a hora das colunas"
+msgstr "<literal>version</literal>: verifica as colunas de versão/timestamp"
 
 #. Tag: para
-#: basic_mapping.xml:446
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>all</literal>: check all columns"
-msgstr "<literal>all</literal> cverifica todas as colunas"
+msgstr "<literal>all</literal>: verifica todas as colunas"
 
 #. Tag: para
-#: basic_mapping.xml:451
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>dirty</literal>: check the changed columns, allowing some "
 "concurrent updates"
 msgstr ""
-"<literal>dirty</literal> verifica as colunas modificadas, permitindo alguns "
-"updates concorrentes"
+"<literal>dirty</literal>: verifica as colunas modificadas, permitindo "
+"algumas atualizações concorrentes"
 
 #. Tag: para
-#: basic_mapping.xml:456
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>none</literal>: do not use optimistic locking"
-msgstr "<literal>none</literal> não utiliza o bloqueio otimista"
+msgstr "<literal>none</literal>: não utiliza o bloqueio otimista"
 
 #. Tag: para
-#: basic_mapping.xml:461
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is <emphasis>strongly</emphasis> recommended that you use version/"
 "timestamp columns for optimistic locking with Hibernate. This strategy "
 "optimizes performance and correctly handles modifications made to detached "
 "instances (i.e. when <literal>Session.merge()</literal> is used)."
 msgstr ""
-"Nós <emphasis>recomendamos</emphasis> com muita enfase que você utilize a "
-"versão e a hora das colunas para o bloqueio otimista com o Hibernate. Esta é "
-"a melhor estratégia com respeito a performance e é a única estratégia que "
-"trata corretamente as modificações efetuadas em instancias desconectadas "
-"(por exemplo, quando <literal>Session.merge()</literal> é utilizado)."
+"Nós <emphasis>realmente</emphasis> recomendamos que você utilize as colunas "
+"de versão/timestamp para o bloqueio otimista com o Hibernate. Esta é a "
+"melhor estratégia em relação ao desempenho e é a única estratégia que trata "
+"corretamente as modificações efetuadas em instâncias desconectadas (por "
+"exemplo, quando <literal>Session.merge()</literal> é utilizado)."
 
 #. Tag: para
-#: basic_mapping.xml:468
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is no difference between a view and a base table for a Hibernate "
 "mapping. This is transparent at the database level, although some DBMS do "
@@ -924,54 +822,34 @@
 "schema). In this case, you can map an immutable and read-only entity to a "
 "given SQL subselect expression:"
 msgstr ""
-"Não ha diferença entre uma view e uma tabela para o mapeamento do Hibernate, "
-"e como esperado isto é transparente no nível do banco de dados (observe que "
-"alguns bancos de dados não suportam views apropriadamente, especialmente com "
-"updates). Algumas vezes, você quer utilizar uma view, ma snão pode cria-la "
-"no banco de dados (por exemplo, com um esquema legado). Neste caso, você "
-"pode mapear uma entidade imutável e de somente leitura, para uma dada "
-"expressão SQL, que representa um subselect:"
+"Não há diferença entre uma visão e uma tabela para o mapeamento do "
+"Hibernate, e como esperado isto é transparente no nível do banco de dados, "
+"mesmo que alguns bancos de dados não suportam visões apropriadamente, "
+"especialmente com atualizações. Algumas vezes, você quer utilizar uma visão, "
+"mas não pode criá-la no banco de dados (por exemplo, com um esquema legado). "
+"Neste caso, você pode mapear uma entidade imutável e de somente leitura, "
+"para uma dada expressão de subseleção SQL: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:476
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Summary\">\n"
-"    <subselect>\n"
-"        select item.name, max(bid.amount), count(*)\n"
-"        from item\n"
-"        join bid on bid.item_id = item.id\n"
-"        group by item.name\n"
-"    </subselect>\n"
-"    <synchronize table=\"item\"/>\n"
-"    <synchronize table=\"bid\"/>\n"
-"    <id name=\"name\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:478
-#, fuzzy, no-c-format
-msgid ""
 "Declare the tables to synchronize this entity with, ensuring that auto-flush "
 "happens correctly and that queries against the derived entity do not return "
 "stale data. The <literal>&lt;subselect&gt;</literal> is available both as an "
 "attribute and a nested mapping element."
 msgstr ""
-"Declare as tabelas para sincronizar com esta entidade, garantindo que o auto-"
-"flush ocorra corretamente, e que as queries para esta entidade derivada não "
-"retornem dados desatualizados. O <literal>&lt;subselect&gt;</literal> está "
-"disponível tanto como um atributo como um elemento mapeado nested."
+"Declare as tabelas para sincronizar com esta entidade, garantindo que a auto-"
+"liberação ocorra corretamente, e que as consultas para esta entidade "
+"derivada não retornem dados desatualizados. O <literal>&lt;subselect&gt;</"
+"literal> está disponível tanto como um atributo como um elemento mapeado "
+"aninhado."
 
 #. Tag: title
-#: basic_mapping.xml:488
 #, no-c-format
-msgid "<title>id</title>"
-msgstr ""
+msgid "id"
+msgstr "id"
 
 #. Tag: para
-#: basic_mapping.xml:490
 #, no-c-format
 msgid ""
 "Mapped classes <emphasis>must</emphasis> declare the primary key column of "
@@ -980,152 +858,94 @@
 "literal> element defines the mapping from that property to the primary key "
 "column."
 msgstr ""
-"Classes mapeadas <emphasis>precisam</emphasis> declarar a coluna de chave "
-"primaria da tabela do banco de dados. Muitas classes irão tambem ter uma "
-"propriedade ao estilo Java-Beans declarando o identificador unico de uma "
-"instancia. O elemento <literal>&lt;id&gt;</literal> define o mapeamento "
+"Classes mapeadas <emphasis>devem</emphasis> declarar a coluna de chave "
+"primária da tabela do banco de dados. Muitas classes irão também ter uma "
+"propriedade ao estilo Java-Beans declarando o identificador único de uma "
+"instância. O elemento <literal>&lt;id&gt;</literal> define o mapeamento "
 "desta propriedade para a chave primária."
 
-#. Tag: programlisting
-#: basic_mapping.xml:505
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id\n"
-"        name=\"propertyName\"\n"
-"        type=\"typename\"\n"
-"        column=\"column_name\"\n"
-"        unsaved-value=\"null|any|none|undefined|id_value\"\n"
-"        access=\"field|property|ClassName\">\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"\n"
-"        <generator class=\"generatorClass\"/>\n"
-"</id>]]>"
+"<literal>name</literal> (optional): the name of the identifier property."
 msgstr ""
+"<literal>name</literal> (opcional): O nome da propriedade do identificador."
 
 #. Tag: para
-#: basic_mapping.xml:508
-#, fuzzy, no-c-format
-msgid ""
-"<literal>name</literal> (optional): the name of the identifier property."
-msgstr "<literal>name</literal> (opcional): O nome do identificador."
-
-#. Tag: para
-#: basic_mapping.xml:513 basic_mapping.xml:1351
 #, no-c-format
 msgid ""
 "<literal>type</literal> (optional): a name that indicates the Hibernate type."
 msgstr ""
-"<literal>type</literal> (opcional): um nome que indica o tipo Hibernate."
+"<literal>type</literal> (opcional): um nome que indica o tipo de Hibernate."
 
 #. Tag: para
-#: basic_mapping.xml:518
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of the primary key column."
 msgstr ""
-"<literal>column</literal> (opcional – default para o a propridade name): O "
-"nome coluna chave primaria."
+"<literal>column</literal> (opcional – padrão para o nome da propridade): O "
+"nome coluna chave primária."
 
 #. Tag: para
-#: basic_mapping.xml:524
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to a \"sensible\" "
 "value): an identifier property value that indicates an instance is newly "
 "instantiated (unsaved), distinguishing it from detached instances that were "
 "saved or loaded in a previous session."
 msgstr ""
-"<literal>unsaved-value</literal> (opcional - default para um valor \"sensível"
-"\"): Uma propriedade de identificação que indica que a instancia foi "
-"novamente instanciada (unsaved), diferenciando de instancias desconectadas "
-"que foram salvas ou carregadas em uma sessão anterior."
+"<literal>unsaved-value</literal> (opcional - padrão para um valor \"sensível"
+"\"): O valor da propriedade de identificação que indica que a instância foi "
+"novamente instanciada (unsaved), diferenciando de instâncias desconectadas "
+"que foram salvas ou carregadas em uma sessão anterior. "
 
 #. Tag: para
-#: basic_mapping.xml:532
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate should use for accessing the property "
 "value."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default <literal>property</"
+"<literal>access</literal> (opcional - padrão para <literal>property</"
 "literal>): A estratégia que o Hiberante deve utilizar para acessar o valor "
-"da propriedade\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default <literal>property</"
-"literal>): A estartégia Hibernate que deve ser utilizada para acessar o "
-"valor da propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default <literal>property</"
-"literal>): A estratégia Hibernate que deve ser usada para acessar o valor da "
-"propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default para <literal>property</"
-"literal>): A estretagia Hibernate que deve ser utilizada para acessar o "
-"valor da propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional – valor default <literal>property</"
-"literal>): A estratégia que o Hibernate deve utilizar para acessar o valor "
-"da propriedade\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default <literal>property</"
-"literal>): A estrategia que o Hibernate deve utilizar para acessar o valor "
-"da propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default padrão "
-"<literal>property</literal>): A estratégia que o Hibernate pode usar para "
-"acessar o valor da propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional – valor default <literal>property</"
-"literal>): A estratégia que o Hibernate pode usar para acessar o valor da "
-"propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional – valor default <literal>property</"
-"literal>): A estratégia que o hibernate deve usar para acessar o valor da "
-"propriedade."
+"da propriedade."
 
 #. Tag: para
-#: basic_mapping.xml:540
 #, no-c-format
 msgid ""
 "If the <literal>name</literal> attribute is missing, it is assumed that the "
 "class has no identifier property."
 msgstr ""
-"Se o atributo <literal>name</literal> não for declarado, assume-se que a "
+"Se a função <literal>name</literal> não for declarada, considera-se que a "
 "classe não tem a propriedade de identificação."
 
 #. Tag: para
-#: basic_mapping.xml:545
 #, no-c-format
 msgid ""
 "The <literal>unsaved-value</literal> attribute is almost never needed in "
 "Hibernate3."
 msgstr ""
-"O atributo <literal>unsaved-value</literal> não é mais necessário no "
-"Hibernate 3."
+"A função <literal>unsaved-value</literal> não é mais necessária no Hibernate "
+"3."
 
 #. Tag: para
-#: basic_mapping.xml:549
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is an alternative <literal>&lt;composite-id&gt;</literal> declaration "
 "that allows access to legacy data with composite keys. Its use is strongly "
 "discouraged for anything else."
 msgstr ""
-"Há declaração alternativa <literal>&lt;composite-id&gt;</literal> permite o "
-"acesso a dados legados com chaves compostas. Nós desencorajamos fortemente o "
-"seu uso por qualquer pessoa."
+"Há uma declaração alternativa <literal>&lt;composite-id&gt;</literal> que "
+"permite o acesso à dados legados com chaves compostas. Nós realmente "
+"desencorajamos o uso deste para qualquer outra função."
 
 #. Tag: title
-#: basic_mapping.xml:555
 #, no-c-format
 msgid "Generator"
-msgstr "Generator"
+msgstr "Gerador"
 
 #. Tag: para
-#: basic_mapping.xml:557
 #, no-c-format
 msgid ""
 "The optional <literal>&lt;generator&gt;</literal> child element names a Java "
@@ -1135,48 +955,33 @@
 "literal> element."
 msgstr ""
 "O elemento filho opcional <literal>&lt;generator&gt;</literal> nomeia uma "
-"classe Java usada para gerar identificadores unicos para instancias de uma "
+"classe Java usada para gerar identificadores únicos para instâncias de uma "
 "classe persistente. Se algum parâmetro é requerido para configurar ou "
-"inicializar a instancia geradora, eles são passados utilizando o elemento "
+"inicializar a instância geradora, eles são passados utilizando o elemento "
 "<literal>&lt;param&gt;</literal>."
 
-#. Tag: programlisting
-#: basic_mapping.xml:564
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"org.hibernate.id.TableHiLoGenerator\">\n"
-"                <param name=\"table\">uid_table</param>\n"
-"                <param name=\"column\">next_hi_value_column</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:566
-#, fuzzy, no-c-format
-msgid ""
 "All generators implement the interface <literal>org.hibernate.id."
 "IdentifierGenerator</literal>. This is a very simple interface. Some "
 "applications can choose to provide their own specialized implementations, "
 "however, Hibernate provides a range of built-in implementations. The "
 "shortcut names for the built-in generators are as follows:"
 msgstr ""
-"Todos os generators implementam a interface <literal>org.hibernate.id."
-"IdentifierGenerator</literal>. Esta é uma interface bem simples; algumas "
-"aplicações podem prover sua própria implementação esepecializada. "
-"Entretanto, o Hibernate disponibiliza um conjunto de implementações "
-"internamente. Há nomes de atalhos para estes generators próprios: "
-"<placeholder-1/>"
+"Todos os geradores implementam a interface <literal>org.hibernate.id."
+"IdentifierGenerator</literal>. Esta é uma interface bem simples. Algumas "
+"aplicações podem prover suas próprias implementações especializadas, "
+"entretanto, o Hibernate disponibiliza um conjunto de implementações "
+"internamente. Há nomes de atalhos para estes geradores internos, conforme "
+"segue abaixo: "
 
-#. Tag: literal
-#: basic_mapping.xml:574
+#. Tag: term
 #, no-c-format
-msgid "increment"
-msgstr "increment"
+msgid "<literal>increment</literal>"
+msgstr "<literal>increment</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:576
 #, no-c-format
 msgid ""
 "generates identifiers of type <literal>long</literal>, <literal>short</"
@@ -1185,54 +990,48 @@
 "cluster.</emphasis>"
 msgstr ""
 "gera identificadores dos tipos <literal>long</literal>, <literal>short</"
-"literal> ou <literal>int</literal> que são unicos apenas quando nenhum outro "
+"literal> ou <literal>int</literal> que são únicos apenas quando nenhum outro "
 "processo está inserindo dados na mesma tabela. <emphasis>Não utilize em "
 "ambientes de cluster.</emphasis>"
 
-#. Tag: literal
-#: basic_mapping.xml:585
+#. Tag: term
 #, no-c-format
-msgid "identity"
-msgstr "identity"
+msgid "<literal>identity</literal>"
+msgstr "<literal>identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:587
 #, no-c-format
 msgid ""
 "supports identity columns in DB2, MySQL, MS SQL Server, Sybase and "
 "HypersonicSQL. The returned identifier is of type <literal>long</literal>, "
 "<literal>short</literal> or <literal>int</literal>."
 msgstr ""
-"suporta colunas de identidade em DB2, MySQL, MS SQL Server, Sybase e "
+"suporta colunas de identidade em DB2, MySQL, Servidor MS SQL, Sybase e "
 "HypersonicSQL. O identificador retornado é do tipo <literal>long</literal>, "
 "<literal>short</literal> ou <literal>int</literal>."
 
-#. Tag: literal
-#: basic_mapping.xml:595
+#. Tag: term
 #, no-c-format
-msgid "sequence"
-msgstr "sequence"
+msgid "<literal>sequence</literal>"
+msgstr "<literal>sequence</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:597
 #, no-c-format
 msgid ""
 "uses a sequence in DB2, PostgreSQL, Oracle, SAP DB, McKoi or a generator in "
 "Interbase. The returned identifier is of type <literal>long</literal>, "
 "<literal>short</literal> or <literal>int</literal>"
 msgstr ""
-"utiliza uma sequence em DB2, PostgreSQL, Oracle, SAP DB, McKoi ou um "
-"generator no Interbase. O identificador de retorno é do tipo <literal> long</"
+"utiliza uma seqüência em DB2, PostgreSQL, Oracle, SAP DB, McKoi ou um "
+"gerador no Interbase. O identificador de retorno é do tipo <literal> long</"
 "literal>, <literal>short</literal> ou <literal>int</literal>."
 
-#. Tag: literal
-#: basic_mapping.xml:605
+#. Tag: term
 #, no-c-format
-msgid "hilo"
-msgstr "hilo"
+msgid "<literal>hilo</literal>"
+msgstr "<literal>hilo</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:607
 #, no-c-format
 msgid ""
 "uses a hi/lo algorithm to efficiently generate identifiers of type "
@@ -1244,140 +1043,124 @@
 msgstr ""
 "utiliza um algoritmo hi/lo para gerar de forma eficiente identificadores do "
 "tipo <literal>long</literal>, <literal>short</literal> ou <literal>int</"
-"literal>, a partir de uma tabela e coluna fornecida (por default "
+"literal>, a partir de uma tabela e coluna fornecida (por padrão "
 "<literal>hibernate_unique_key</literal> e <literal>next_hi</literal>) como "
 "fonte para os valores hi. O algoritmo hi/lo gera identificadores que são "
-"únicos apenas para um banco de dados particular."
+"únicos apenas para um banco de dados específico."
 
-#. Tag: literal
-#: basic_mapping.xml:617
+#. Tag: term
 #, no-c-format
-msgid "seqhilo"
-msgstr "seqhilo"
+msgid "<literal>seqhilo</literal>"
+msgstr "<literal>seqhilo</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:619
 #, no-c-format
 msgid ""
 "uses a hi/lo algorithm to efficiently generate identifiers of type "
 "<literal>long</literal>, <literal>short</literal> or <literal>int</literal>, "
 "given a named database sequence."
 msgstr ""
-"utiliza um algoritmo hi/lo para gerar de forma eficinete identificadores do "
+"utiliza um algoritmo hi/lo para gerar de forma eficiente identificadores do "
 "tipo <literal>long</literal>, <literal>short</literal> ou <literal>int</"
-"literal>, a partir de uma sequence de banco de dados fornecida."
+"literal>, a partir de uma seqüência de banco de dados fornecida."
 
-#. Tag: literal
-#: basic_mapping.xml:627
+#. Tag: term
 #, no-c-format
-msgid "uuid"
-msgstr "uuid"
+msgid "<literal>uuid</literal>"
+msgstr "<literal>uuid</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:629
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "uses a 128-bit UUID algorithm to generate identifiers of type string that "
 "are unique within a network (the IP address is used). The UUID is encoded as "
 "a string of 32 hexadecimal digits in length."
 msgstr ""
-"utiliza um algortimo UUID de 128-bits para gerar identificadores do tipo "
-"string, unicos em uma rede(o endereço IP é utilizado). O UUID é codificado "
-"como um string de digitos hexadecimais de tamanho 32."
+"utiliza um algorítimo UUID de 128-bits para gerar identificadores do tipo "
+"string, únicos em uma rede (o endereço IP é utilizado). O UUID é codificado "
+"como um string de dígitos hexadecimais de tamanho 32."
 
-#. Tag: literal
-#: basic_mapping.xml:637
+#. Tag: term
 #, no-c-format
-msgid "guid"
-msgstr "guid"
+msgid "<literal>guid</literal>"
+msgstr "<literal>guid</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:639
 #, no-c-format
 msgid "uses a database-generated GUID string on MS SQL Server and MySQL."
 msgstr ""
-"utiliza um string GUID gerado pelo banco de dados no MS SQL Server e MySQL."
+"utiliza um string GUID gerado pelo banco de dados no Servidor MS SQL e MySQL."
 
-#. Tag: literal
-#: basic_mapping.xml:645
+#. Tag: term
 #, no-c-format
-msgid "native"
-msgstr "native"
+msgid "<literal>native</literal>"
+msgstr "<literal>native</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:647
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "selects <literal>identity</literal>, <literal>sequence</literal> or "
 "<literal>hilo</literal> depending upon the capabilities of the underlying "
 "database."
 msgstr ""
-"seleciona entre <literal>identity</literal>, <literal>sequence</literal> ou "
+"seleciona entre <literal>identity</literal>, <literal>sequence</literal>ou "
 "<literal>hilo</literal> dependendo das capacidades do banco de dados "
 "utilizado."
 
-#. Tag: literal
-#: basic_mapping.xml:655
+#. Tag: term
 #, no-c-format
-msgid "assigned"
-msgstr "assigned"
+msgid "<literal>assigned</literal>"
+msgstr "<literal>assigned</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:657
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "lets the application assign an identifier to the object before <literal>save"
 "()</literal> is called. This is the default strategy if no <literal>&lt;"
 "generator&gt;</literal> element is specified."
 msgstr ""
 "deixa a aplicação definir um identificador para o objeto antes que o "
-"<literal>save()</literal> seja chamado. Esta é a estratégia default se "
-"nenhum elemento <literal>&lt;generator&gt;</literal> é especificado."
+"<literal>save()</literal> seja chamado. Esta é a estratégia padrão caso "
+"nenhum elemento <literal>&lt;generator&gt;</literal> seja especificado. "
 
-#. Tag: literal
-#: basic_mapping.xml:665
+#. Tag: term
 #, no-c-format
-msgid "select"
-msgstr "select"
+msgid "<literal>select</literal>"
+msgstr "<literal>select</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:667
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "retrieves a primary key, assigned by a database trigger, by selecting the "
 "row by some unique key and retrieving the primary key value."
 msgstr ""
-"retorna a chave primaria recuperada por uma trigger do banco de dados, "
-"selecionado uma linha pela chave única e recuperando o valor da chave "
+"retorna a chave primária recuperada por um trigger do banco de dados, "
+"selecionando uma linha pela chave única e recuperando o valor da chave "
 "primária."
 
-#. Tag: literal
-#: basic_mapping.xml:674
+#. Tag: term
 #, no-c-format
-msgid "foreign"
-msgstr "foreign"
+msgid "<literal>foreign</literal>"
+msgstr "<literal>foreign</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:676
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "uses the identifier of another associated object. It is usually used in "
 "conjunction with a <literal>&lt;one-to-one&gt;</literal> primary key "
 "association."
 msgstr ""
 "utiliza o identificador de um outro objeto associado. Normalmente utilizado "
-"em conjunto com uma associaçõa de chave primária do tipo <literal>&lt;one-to-"
+"em conjunto com uma associação de chave primária do tipo <literal>&lt;one-to-"
 "one&gt;</literal>."
 
-#. Tag: literal
-#: basic_mapping.xml:683
+#. Tag: term
 #, no-c-format
-msgid "sequence-identity"
-msgstr "sequence-identity"
+msgid "<literal>sequence-identity</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:685
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "a specialized sequence generation strategy that utilizes a database sequence "
 "for the actual value generation, but combines this with JDBC3 "
@@ -1386,22 +1169,21 @@
 "drivers targeted for JDK 1.4. Comments on these insert statements are "
 "disabled due to a bug in the Oracle drivers."
 msgstr ""
-"a specialized sequence generation strategy which utilizes a database "
-"sequence for the actual value generation, but combines this with JDBC3 "
-"getGeneratedKeys to actually return the generated identifier value as part "
-"of the insert statement execution. This strategy is only known to be "
-"supported on Oracle 10g drivers targetted for JDK 1.4. Note comments on "
-"these insert statements are disabled due to a bug in the Oracle drivers."
+"uma estratégia de geração de seqüência especializada que use uma seqüência "
+"de banco de dados para a geração de valor atual, mas combina isto com JDBC3 "
+"getGeneratedKeys para de fato retornar o valor do identificador gerado como "
+"parte da execução de instrução de inserção. Esta estratégia é somente "
+"conhecida para suportar drivers da Oracle 10g, focados em JDK 1.4. Note que "
+"os comentários sobre estas instruções de inserção estão desabilitados devido "
+"a um bug nos drivers da Oracle. "
 
 #. Tag: title
-#: basic_mapping.xml:702
 #, no-c-format
 msgid "Hi/lo algorithm"
 msgstr "Algoritmo Hi/lo"
 
 #. Tag: para
-#: basic_mapping.xml:703
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>hilo</literal> and <literal>seqhilo</literal> generators "
 "provide two alternate implementations of the hi/lo algorithm. The first "
@@ -1412,80 +1194,51 @@
 "Os geradores <literal>hilo</literal> e <literal>seqhilo</literal> fornecem "
 "duas implementações alternativas do algoritmo hi/lo, uma solução "
 "preferencial para a geração de identificadores. A primeira implementação "
-"requer uma tabela especial do banco de dados para manter o proximo valor \"hi"
-"\" disponível. A segunda utiliza uma seqüência do estilo Oracle (quando "
+"requer uma tabela \"especial\" do banco de dados para manter o próximo valor "
+"\"hi\" disponível. A segunda utiliza uma seqüência do estilo Oracle (quando "
 "suportado)."
 
-#. Tag: programlisting
-#: basic_mapping.xml:710
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"hilo\">\n"
-"                <param name=\"table\">hi_value</param>\n"
-"                <param name=\"column\">next_value</param>\n"
-"                <param name=\"max_lo\">100</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:712
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"seqhilo\">\n"
-"                <param name=\"sequence\">hi_value</param>\n"
-"                <param name=\"max_lo\">100</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:714
-#, fuzzy, no-c-format
-msgid ""
 "Unfortunately, you cannot use <literal>hilo</literal> when supplying your "
 "own <literal>Connection</literal> to Hibernate. When Hibernate uses an "
 "application server datasource to obtain connections enlisted with JTA, you "
 "must configure the <literal>hibernate.transaction.manager_lookup_class</"
 "literal>."
 msgstr ""
-"Infelizemente, voce não pode utilizar <literal>hilo</literal> quando estiver "
-"fornecendo sia propria <literal>Connection</literal> para o Hibernate. "
-"Quando o Hibernate está usando um datasource do servidor de aplicações para "
-"obter conexões suportadas com JTA, você precisa configurar adequadamente o "
-"<literal>hibernate.transaction.manager_lookup_class</literal>."
+"Infelizmente, você não pode utilizar <literal>hilo</literal> quando estiver "
+"fornecendo sua própria <literal>Connection</literal> para o Hibernate. "
+"Quando o Hibernate estiver usando uma fonte de dados do servidor de "
+"aplicações para obter conexões suportadas com JTA, você precisará configurar "
+"adequadamente o <literal>hibernate.transaction.manager_lookup_class</"
+"literal>. "
 
 #. Tag: title
-#: basic_mapping.xml:723
 #, no-c-format
 msgid "UUID algorithm"
-msgstr "UUID algorithm"
+msgstr "Algoritmo UUID"
 
 #. Tag: para
-#: basic_mapping.xml:724
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The UUID contains: IP address, startup time of the JVM that is accurate to a "
 "quarter second, system time and a counter value that is unique within the "
 "JVM. It is not possible to obtain a MAC address or memory address from Java "
 "code, so this is the best option without using JNI."
 msgstr ""
-"O UUID contem: o endereço IP, hora de inicio da JVM (com precisão de um "
-"quarto de segundo), a hora do sistema e um valor contador (unico dentro da "
-"JVM). Não é possivel obter o endereço MAC ou um endereço de memória do "
-"código Java, assim este é o melhor que pode ser feito sem utilizar JNI."
+"O UUID contém: o endereço IP, hora de início da JVM que é com precisão de um "
+"quarto de segundo, a hora do sistema e um valor contador que é único dentro "
+"da JVM. Não é possível obter o endereço MAC ou um endereço de memória do "
+"código Java, portanto este é o melhor que pode ser feito sem utilizar JNI."
 
 #. Tag: title
-#: basic_mapping.xml:733
 #, no-c-format
 msgid "Identity columns and sequences"
-msgstr "Colunas de identidade e sequencias"
+msgstr "Colunas de identidade e seqüências"
 
 #. Tag: para
-#: basic_mapping.xml:734
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For databases that support identity columns (DB2, MySQL, Sybase, MS SQL), "
 "you can use <literal>identity</literal> key generation. For databases that "
@@ -1496,54 +1249,30 @@
 "Para bancos de dados que suportam colunas de identidade (DB2, MySQL, Sybase, "
 "MS SQL), você pode utilizar uma geração de chave <literal>identity</"
 "literal>. Para bancos de dados que suportam sequencias (DB2, Oracle, "
-"PostgreSQL, Interbase, McKoi, SAP DB) voce pode utilizar a geração de chaves "
+"PostgreSQL, Interbase, McKoi, SAP DB) você pode utilizar a geração de chaves "
 "no estilo <literal>sequence</literal>. As duas estratégias requerem duas "
-"consultas SQL para inserir um novo objeto."
+"consultas SQL para inserir um novo objeto. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:742
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-"        <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">person_id_sequence</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:744
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\" unsaved-value=\"0"
-"\">\n"
-"        <generator class=\"identity\"/>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:746
-#, fuzzy, no-c-format
-msgid ""
 "For cross-platform development, the <literal>native</literal> strategy will, "
 "depending on the capabilities of the underlying database, choose from the "
 "<literal>identity</literal>, <literal>sequence</literal> and <literal>hilo</"
 "literal> strategies."
 msgstr ""
 "Para desenvolvimento multi-plataforma, a estratégia <literal>native</"
-"literal> irá escolher entre as estratégias i <literal>identity</literal>, "
+"literal> irá escolher entre as estratégias <literal>identity</literal>, "
 "<literal>sequence</literal> e <literal>hilo</literal>, dependendo das "
 "capacidades do banco de dados utilizado."
 
 #. Tag: title
-#: basic_mapping.xml:754
 #, no-c-format
 msgid "Assigned identifiers"
-msgstr "Identificadores especificados"
+msgstr "Identificadores atribuídos"
 
 #. Tag: para
-#: basic_mapping.xml:755
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want the application to assign identifiers, as opposed to having "
 "Hibernate generate them, you can use the <literal>assigned</literal> "
@@ -1553,17 +1282,16 @@
 "behavior if you do not specify a <literal>&lt;generator&gt;</literal> "
 "element."
 msgstr ""
-"Se você quer que a aplicação especifique os identificadores (em vez do "
-"Hibernate gerá-los) você deve utilizar o gerador <literal>assigned</"
+"Se você quiser que a aplicação especifique os identificadores, em vez do "
+"Hibernate gerá-los, você deve utilizar o gerador <literal>assigned</"
 "literal>. Este gerador especial irá utilizar o valor do identificador "
 "especificado para a propriedade de identificação do objeto. Este gerador é "
-"usado quando a chave primaria é a chave natural em vez de uma surrogate key. "
-"Este é o comportamento padrão se você não especificar um elemento "
-"<literal>&lt;generator&gt;</literal>."
+"usado quando a chave primária é a chave natural em vez de uma chave "
+"substituta. Este é o comportamento padrão se você não especificar um "
+"elemento <literal>&lt;generator&gt;</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:764
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>assigned</literal> generator makes Hibernate use "
 "<literal>unsaved-value=\"undefined\"</literal>. This forces Hibernate to go "
@@ -1571,40 +1299,26 @@
 "there is a version or timestamp property, or you define <literal>Interceptor."
 "isUnsaved()</literal>."
 msgstr ""
-"Escolher o gerador <literal>assigned</literal> faz com que o Hibernate "
-"utilize <literal>unsaved-value=\"undefined\"</literal>, forçando o Hibernate "
-"ir até o banco de dados para determinar se uma instância está transiente ou "
-"desasociada, a menos que haja uma versão ou uma propriedade timestamp, ou "
-"você pode definir <literal>Interceptor.isUnsaved()</literal>."
+"A escolha do gerador <literal>assigned</literal> faz com que o Hibernate "
+"utilize <literal>unsaved-value=\"undefined\"</literal>. Isto força o "
+"Hibernate ir até o banco de dados para determinar se uma instância está "
+"transiente ou desacoplada, a não ser que haja uma versão ou uma propriedade "
+"de timestamp, ou que você definia <literal>Interceptor.isUnsaved()</literal>."
 
 #. Tag: title
-#: basic_mapping.xml:774
 #, no-c-format
 msgid "Primary keys assigned by triggers"
 msgstr "Chaves primárias geradas por triggers"
 
 #. Tag: para
-#: basic_mapping.xml:775
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate does not generate DDL with triggers. It is for legacy schemas only."
-msgstr "Apenas para sistemas legados (o Hibernate nao gera DDL com triggers)."
+msgstr "O Hibernate não gera DDL com triggers, apenas para sistemas legados."
 
-#. Tag: programlisting
-#: basic_mapping.xml:779
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-"        <generator class=\"select\">\n"
-"                <param name=\"key\">socialSecurityNumber</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:781
-#, fuzzy, no-c-format
-msgid ""
 "In the above example, there is a unique valued property named "
 "<literal>socialSecurityNumber</literal>. It is defined by the class, as a "
 "natural key and a surrogate key named <literal>person_id</literal>, whose "
@@ -1612,18 +1326,16 @@
 msgstr ""
 "No exemplo acima, há uma única propriedade com valor nomeada "
 "<literal>socialSecurityNumber</literal> definida pela classe, uma chave "
-"natural, e uma surrogate key nomeada <literal>person_id</literal> cujo valor "
-"é gerado pro uma trigger."
+"natural, e uma chave substituta nomeada <literal>person_id</literal> cujo "
+"valor é gerado por um trigger."
 
 #. Tag: title
-#: basic_mapping.xml:793
 #, no-c-format
 msgid "Enhanced identifier generators"
-msgstr "Enhanced identifier generators"
+msgstr "Aprimoração dos geradores de identificador"
 
 #. Tag: para
-#: basic_mapping.xml:795
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Starting with release 3.2.3, there are 2 new generators which represent a re-"
 "thinking of 2 different aspects of identifier generation. The first aspect "
@@ -1633,17 +1345,17 @@
 "the named generators described above, starting in 3.3.x. However, they are "
 "included in the current releases and can be referenced by FQN."
 msgstr ""
-"Starting with release 3.2.3, there are 2 new generators which represent a re-"
-"thinking of 2 different aspects of identifier generation. The first aspect "
-"is database portability; the second is optimization (not having to query the "
-"database for every request for a new identifier value). These two new "
-"generators are intended to take the place of some of the named generators "
-"described above (starting in 3.3.x); however, they are included in the "
-"current releases and can be referenced by FQN."
+"Iniciando com a liberação 3.2.3, existem dois novos geradores que "
+"representam uma reavaliação de dois diferentes aspectos da geração "
+"identificadora. O primeiro aspecto é a portabilidade do banco de dados, o "
+"segundo é a otimização. A otimização significa que você não precisa "
+"questionar o banco de dados a cada solicitação para um novo valor de "
+"identificador. Estes dois geradores possuem por intenção substituir alguns "
+"dos geradores nomeados acima, começando em 3.3.x. No entanto, eles estão "
+"incluídos nas liberações atuais e podem ser referenciados pelo FQN."
 
 #. Tag: para
-#: basic_mapping.xml:803
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The first of these new generators is <literal>org.hibernate.id.enhanced."
 "SequenceStyleGenerator</literal> which is intended, firstly, as a "
@@ -1662,100 +1374,95 @@
 "with its table-based generators. This generator has a number of "
 "configuration parameters:"
 msgstr ""
-"The first of these new generators is <literal>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</literal> which is intended firstly as a replacement "
-"for the <literal>sequence</literal> generator and secondly as a better "
-"portability generator than <literal>native</literal> (because "
-"<literal>native</literal> (generally) chooses between <literal>identity</"
-"literal> and <literal>sequence</literal> which have largely different "
-"semantics which can cause subtle isssues in applications eyeing "
-"portability). <literal>org.hibernate.id.enhanced.SequenceStyleGenerator</"
-"literal> however achieves portability in a different manner. It chooses "
-"between using a table or a sequence in the database to store its "
-"incrementing values depending on the capabilities of the dialect being used. "
-"The difference between this and <literal>native</literal> is that table-"
-"based and sequence-based storage have the same exact semantic (in fact "
-"sequences are exactly what Hibernate tries to emmulate with its table-based "
-"generators). This generator has a number of configuration parameters: "
-"<placeholder-1/>"
+"A primeira destas novas gerações é a <literal>org.hibernate.id.enhanced."
+"SequenceStyleGenerator</literal> que primeiramente é uma substituição para o "
+"gerador <literal>sequence</literal> e, segundo, um melhor gerador de "
+"portabilidade que o <literal>native</literal>. Isto é devido ao "
+"<literal>native</literal> normalmente escolher entre <literal>identity</"
+"literal> e <literal>sequence</literal>, que são semânticas extremamente "
+"diferentes das quais podem causar problemas súbitos em portabilidade de "
+"observação de aplicativos. No entanto, o <literal>org.hibernate.id.enhanced."
+"SequenceStyleGenerator</literal> atinge a portabilidade numa maneira "
+"diferente. Ele escolhe entre uma tabela ou uma seqüência no banco de dados "
+"para armazenar seus valores de incrementação, dependendo nas capacidades do "
+"dialeto sendo usado. A diferença entre isto e o <literal>native</literal> é "
+"que o armazenamento baseado na tabela e seqüência possuem exatamente a mesma "
+"semântica. Na realidade, as seqüências são exatamente o que o Hibernate "
+"tenta imitar com os próprios geradores baseados na tabela. Este gerador "
+"possui um número de parâmetros de configuração: "
 
 #. Tag: para
-#: basic_mapping.xml:817
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>sequence_name</literal> (optional, defaults to "
 "<literal>hibernate_sequence</literal>): the name of the sequence or table to "
 "be used."
 msgstr ""
-"<literal>sequence_name</literal> (optional, defaults to "
-"<literal>hibernate_sequence</literal>): The name of the sequence (or table) "
-"to be used."
+"<literal>sequence_name</literal> (opcional - valor padrão "
+"<literal>hibernate_sequence</literal>) o nome da seqüência ou tabela a ser "
+"usada."
 
 #. Tag: para
-#: basic_mapping.xml:823
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>initial_value</literal> (optional, defaults to <literal>1</"
 "literal>): the initial value to be retrieved from the sequence/table. In "
 "sequence creation terms, this is analogous to the clause typically named "
 "\"STARTS WITH\"."
 msgstr ""
-"<literal>initial_value</literal> (optional, defaults to <literal>1</"
-"literal>): The initial value to be retrieved from the sequence/table. In "
-"sequence creation terms, this is analogous to the clause typical named "
-"\"STARTS WITH\"."
+"<literal>initial_value</literal> (opcional - padrão para <literal>1</"
+"literal>) O valor inicial a ser restaurado a partir da seqüência/tabela. Em "
+"termos da criação de seqüência, isto é análogo à cláusula tipicamente "
+"nomeada \"STARTS WITH\"."
 
 #. Tag: para
-#: basic_mapping.xml:830
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>increment_size</literal> (optional - defaults to <literal>1</"
 "literal>): the value by which subsequent calls to the sequence/table should "
 "differ. In sequence creation terms, this is analogous to the clause "
 "typically named \"INCREMENT BY\"."
 msgstr ""
-"<literal>increment_size</literal> (optional, defaults to <literal>1</"
-"literal>): The value by which subsequent calls to the sequence/table should "
-"differ. In sequence creation terms, this is analogous to the clause typical "
-"named \"INCREMENT BY\"."
+"<literal>increment_size</literal> (opcional - padrão para <literal>1</"
+"literal>): o valor pelo qual as chamadas para a seqüência/tabela devem "
+"diferenciar-se. Nos termos da criação da seqüência, isto é análogo à "
+"cláusula tipicamente nomeada \"INCREMENT BY\"."
 
 #. Tag: para
-#: basic_mapping.xml:837
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>force_table_use</literal> (optional - defaults to <literal>false</"
 "literal>): should we force the use of a table as the backing structure even "
 "though the dialect might support sequence?"
 msgstr ""
-"<literal>force_table_use</literal> (optional, defaults to <literal>false</"
-"literal>): Should we force the use of a table as the backing structure even "
-"though the dialect might support sequence?"
+"<literal>force_table_use</literal> (opcional - padrão para <literal>false</"
+"literal>): devemos forçar o uso de uma tabela como uma estrutura de reforço, "
+"mesmo que o dialeto possa suportar a seqüência?"
 
 #. Tag: para
-#: basic_mapping.xml:844
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>value_column</literal> (optional - defaults to <literal>next_val</"
 "literal>): only relevant for table structures, it is the name of the column "
 "on the table which is used to hold the value."
 msgstr ""
-"<literal>value_column</literal> (optional, defaults to <literal>next_val</"
-"literal>): Only relevant for table structures! The name of the column on the "
-"table which is used to hold the value."
+"<literal>value_column</literal> (opcional - padrão para <literal>next_val</"
+"literal>): apenas relevante para estruturas de tabela, este é o nome da "
+"coluna onde na tabela que é usado para manter o valor."
 
 #. Tag: para
-#: basic_mapping.xml:851
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimizer</literal> (optional - defaults to <literal>none</"
-"literal>): See"
+"literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\" /"
+">"
 msgstr ""
-"<literal>cascade</literal> (opcional – valor default <literal>none</"
-"literal>): o estilo do cascade."
+"<literal>optimizer</literal> (opcional – padrão para <literal>none</"
+"literal>): Veja <xref linkend=\"mapping-declaration-id-enhanced-optimizers"
+"\" />"
 
 #. Tag: para
-#: basic_mapping.xml:858
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The second of these new generators is <literal>org.hibernate.id.enhanced."
 "TableGenerator</literal>, which is intended, firstly, as a replacement for "
@@ -1768,148 +1475,137 @@
 "multiple distinctly keyed rows. This generator has a number of configuration "
 "parameters:"
 msgstr ""
-"The second of these new generators is <literal>org.hibernate.id.enhanced."
-"TableGenerator</literal> which is intended firstly as a replacement for the "
-"<literal>table</literal> generator (although it actually functions much more "
-"like <literal>org.hibernate.id.MultipleHiLoPerTableGenerator</literal>) and "
-"secondly as a re-implementation of <literal>org.hibernate.id."
-"MultipleHiLoPerTableGenerator</literal> utilizing the notion of pluggable "
-"optimiziers. Essentially this generator defines a table capable of holding a "
-"number of different increment values simultaneously by using multiple "
-"distinctly keyed rows. This generator has a number of configuration "
-"parameters: <placeholder-1/>"
+"O segundo destes novos geradores é o <literal>org.hibernate.id.enhanced."
+"TableGenerator</literal>, que primeiramente é uma substituição para o "
+"gerador <literal>table</literal>, mesmo que isto funcione muito mais como um "
+"<literal>org.hibernate.id.MultipleHiLoPerTableGenerator</literal>, e "
+"segundo, como uma reimplementação do <literal>org.hibernate.id."
+"MultipleHiLoPerTableGenerator</literal> que utiliza a noção dos otimizadores "
+"pugláveis. Basicamente, este gerador define uma tabela capacitada de manter "
+"um número de valores de incremento simultâneo pelo uso múltiplo de filas de "
+"chaves distintas. Este gerador possui um número de parâmetros de "
+"configuração."
 
 #. Tag: para
-#: basic_mapping.xml:868
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>table_name</literal> (optional - defaults to "
 "<literal>hibernate_sequences</literal>): the name of the table to be used."
 msgstr ""
-"<literal>table_name</literal> (optional, defaults to "
-"<literal>hibernate_sequences</literal>): The name of the table to be used."
+"<literal>table_name</literal> (opcional - padrão para "
+"<literal>hibernate_sequences</literal>): O nome da tabela a ser usado."
 
 #. Tag: para
-#: basic_mapping.xml:874
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>value_column_name</literal> (optional - defaults to "
 "<literal>next_val</literal>): the name of the column on the table that is "
 "used to hold the value."
 msgstr ""
-"<literal>value_column_name</literal> (optional, defaults to "
-"<literal>next_val</literal>): The name of the column on the table which is "
-"used to hold the value."
+"<literal>value_column_name</literal> (opcional - padrão para "
+"<literal>next_val</literal>): o nome da coluna na tabela que é usado para "
+"manter o valor."
 
 #. Tag: para
-#: basic_mapping.xml:880
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>segment_column_name</literal> (optional - defaults to "
 "<literal>sequence_name</literal>): the name of the column on the table that "
 "is used to hold the \"segment key\". This is the value which identifies "
 "which increment value to use."
 msgstr ""
-"<literal>segment_column_name</literal> (optional, defaults to "
-"<literal>sequence_name</literal>): The name of the column on the table which "
-"is used to hold the \"segement key\". This is the value which distinctly "
-"identifies which increment value to use."
+"<literal>segment_column_name</literal> (opcional - padrão para "
+"<literal>sequence_name</literal>) O nome da coluna da tabela que é usado "
+"para manter a \"chave de segmento\". Este é o valor que identifica qual "
+"valor de incremento a ser usado."
 
 #. Tag: para
-#: basic_mapping.xml:887
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>segment_value</literal> (optional - defaults to <literal>default</"
 "literal>): The \"segment key\" value for the segment from which we want to "
 "pull increment values for this generator."
 msgstr ""
-"<literal>segment_value</literal> (optional, defaults to <literal>default</"
-"literal>): The \"segment key\" value for the segment from which we want to "
-"pull increment values for this generator."
+"<literal>base</literal> (opcional - padrão para <literal>default</literal>) "
+"O valor da \"chave de segmento\" para o segmento pelo qual nós queremos "
+"obter os valores de incremento para este gerador."
 
 #. Tag: para
-#: basic_mapping.xml:894
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>segment_value_length</literal> (optional - defaults to "
 "<literal>255</literal>): Used for schema generation; the column size to "
 "create this segment key column."
 msgstr ""
-"<literal>segment_value_length</literal> (optional, defaults to <literal>255</"
-"literal>): Used for schema generation; the column size to create this "
-"segment key column."
+"<literal>segment_value_length</literal> (opcional - padrão para "
+"<literal>255</literal>): Usado para a geração do esquema. O tamanho da "
+"coluna para criar esta coluna de chave de segmento."
 
 #. Tag: para
-#: basic_mapping.xml:900
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>initial_value</literal> (optional - defaults to <literal>1</"
 "literal>): The initial value to be retrieved from the table."
 msgstr ""
-"<literal>initial_value</literal> (optional, defaults to <literal>1</"
-"literal>): The initial value to be retrieved from the table."
+"<literal>initial_value</literal> (opcional - valor padrão para <literal>1</"
+"literal>): O valor inicial a ser restaurado a partir da tabela."
 
 #. Tag: para
-#: basic_mapping.xml:906
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>increment_size</literal> (optional - defaults to <literal>1</"
 "literal>): The value by which subsequent calls to the table should differ."
 msgstr ""
-"<literal>increment_size</literal> (optional, defaults to <literal>1</"
-"literal>): The value by which subsequent calls to the table should differ."
+"<literal>increment_size</literal> (opcional - padrão para <literal>1</"
+"literal>): O valor pelo qual as chamadas subseqüentes para a tabela devem "
+"diferir-se."
 
 #. Tag: para
-#: basic_mapping.xml:912
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimizer</literal> (optional - defaults to <literal></literal>): "
-"See"
+"See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\" />"
 msgstr ""
-"<literal>cascade</literal> (opcional – valor default <literal>none</"
-"literal>): o estilo do cascade."
+"<literal>optimizer</literal> (opcional – padrão para <literal></literal>): "
+"Consulte <xref linkend=\"mapping-declaration-id-enhanced-optimizers\" />"
 
 #. Tag: title
-#: basic_mapping.xml:922
 #, no-c-format
 msgid "Identifier generator optimization"
-msgstr "Identifier generator optimization"
+msgstr "Otimização do Gerador de Identificação"
 
 #. Tag: para
-#: basic_mapping.xml:923
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For identifier generators that store values in the database, it is "
 "inefficient for them to hit the database on each and every call to generate "
 "a new identifier value. Instead, you can group a bunch of them in memory and "
 "only hit the database when you have exhausted your in-memory value group. "
 "This is the role of the pluggable optimizers. Currently only the two "
-"enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced\"/> "
+"enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced\" /> "
 "support this operation."
 msgstr ""
-"For identifier generators which store values in the database, it is "
-"inefficient for them to hit the database on each and every call to generate "
-"a new identifier value. Instead, you'd ideally want to group a bunch of them "
-"in memory and only hit the database when you have exhausted your in-memory "
-"value group. This is the role of the pluggable optimizers. Currently only "
-"the two enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced"
-"\"/> support this notion. <placeholder-1/>"
+"Para os geradores de identificação que armazenam valores no banco de dados, "
+"é ineficiente para os mesmos atingirem o banco de dados em cada e toda "
+"chamada para gerar um valor de identificação novo. Ao invés disto, você pode "
+"agrupá-los na memória e apenas alcançar o banco de dados quando exceder o "
+"grupo de valor em memória. Esta é a função dos otimizadores pugláveis. "
+"Atualmente, apenas dois geradores aprimorados suportam esta operação. (<xref "
+"linkend=\"mapping-declaration-id-enhanced\"/>)"
 
 #. Tag: para
-#: basic_mapping.xml:931
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>none</literal> (generally this is the default if no optimizer was "
 "specified): this will not perform any optimizations and hit the database for "
 "each and every request."
 msgstr ""
-"<literal>none</literal> (generally this is the default if no optimizer was "
-"specified): This says to not perform any optimizations, and hit the database "
-"each and every request."
+"<literal>none</literal> (geralmente este é o padrão, caso nenhum otimizador "
+"for especificado): isto não executará quaisquer otimizações e alcançará o "
+"banco de dados para cada e toda solicitação."
 
 #. Tag: para
-#: basic_mapping.xml:937
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>hilo</literal>: applies a hi/lo algorithm around the database "
 "retrieved values. The values from the database for this optimizer are "
@@ -1918,16 +1614,15 @@
 "<literal>increment_size</literal> is multiplied by that value in memory to "
 "define a group \"hi value\"."
 msgstr ""
-"<literal>hilo</literal>: applies a hi/lo algorithm around the database "
-"retrieved values. The values from the database for this optimizer are "
-"expected to be sequential. The values retrieved from the database structure "
-"for this optimizer indicates the \"group number\"; the "
-"<literal>increment_size</literal> is multiplied by that value in memory to "
-"define a group \"hi value\"."
+"<literal>hilo</literal>: aplica-se ao algoritmo em volta dos valores "
+"restaurados do banco de dados. Espera-se que os valores a partir do banco de "
+"dados para este otimizador sejam seqüenciais. Os valores restaurados a "
+"partir da estrutura do banco de dados para este otimizador indica um "
+"\"número de grupo\". O <literal>increment_size</literal> é multiplicado pelo "
+"valor em memória para definir um grupo \"hi value\"."
 
 #. Tag: para
-#: basic_mapping.xml:946
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>pooled</literal>: as with the case of <literal>hilo</literal>, this "
 "optimizer attempts to minimize the number of hits to the database. Here, "
@@ -1936,79 +1631,47 @@
 "memory grouping algorithm. Here, <literal>increment_size</literal> refers to "
 "the values coming from the database."
 msgstr ""
-"<literal>pooled</literal>: like was discussed for <literal>hilo</literal>, "
-"this optimizers attempts to minimize the number of hits to the database. "
-"Here, however, we simply store the starting value for the \"next group\" "
-"into the database structure rather than a sequential value in combination "
-"with an in-memory grouping algorithm. <literal>increment_size</literal> here "
-"refers to the values coming from the database."
+"<literal>pooled</literal>: assim como o caso do <literal>hilo</literal>, "
+"este otimizador tenta minimizar o número de tentativas no banco de dados. No "
+"entanto, nós simplesmente implementamos o valor de inicialização para o "
+"\"próximo grupo\" na estrutura do banco de dados ao invés do valor "
+"seqüencial na combinação com um algoritmo de agrupamento em memória. Neste "
+"caso, o <literal>increment_size</literal> refere-se aos valores de entrada a "
+"partir do banco de dados."
 
 #. Tag: title
-#: basic_mapping.xml:959
 #, no-c-format
 msgid "composite-id"
-msgstr "composite-id"
+msgstr "Composição-id"
 
-#. Tag: programlisting
-#: basic_mapping.xml:961
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<composite-id\n"
-"        name=\"propertyName\"\n"
-"        class=\"ClassName\"\n"
-"        mapped=\"true|false\"\n"
-"        access=\"field|property|ClassName\">\n"
-"        node=\"element-name|.\"\n"
-"\n"
-"        <key-property name=\"propertyName\" type=\"typename\" column="
-"\"column_name\"/>\n"
-"        <key-many-to-one name=\"propertyName class=\"ClassName\" column="
-"\"column_name\"/>\n"
-"        ......\n"
-"</composite-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:963
-#, fuzzy, no-c-format
-msgid ""
 "A table with a composite key can be mapped with multiple properties of the "
 "class as identifier properties. The <literal>&lt;composite-id&gt;</literal> "
 "element accepts <literal>&lt;key-property&gt;</literal> property mappings "
 "and <literal>&lt;key-many-to-one&gt;</literal> mappings as child elements."
 msgstr ""
-"Para tabelas com uma chave composta, você pode mapear múltiplas propriedades "
-"da classe como propriedades de identificação. O elemento <literal>&lt;"
-"composite-id&gt;</literal> aceita o mapeamento da propriedade <literal>&lt;"
-"key-property&gt;</literal> e mapeamentos <literal>&lt;key-many-to-one&gt;</"
-"literal>como elements filhos."
+"Uma tabela com uma chave composta, pode ser mapeada com múltiplas "
+"propriedades da classe como propriedades de identificação. O elemento "
+"<literal>&lt;composite-id&gt;</literal> aceita o mapeamento da propriedade "
+"<literal>&lt;key-property&gt;</literal> e mapeamentos <literal>&lt;key-many-"
+"to-one&gt;</literal>como elementos filhos."
 
-#. Tag: programlisting
-#: basic_mapping.xml:970
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<composite-id>\n"
-"        <key-property name=\"medicareNumber\"/>\n"
-"        <key-property name=\"dependent\"/>\n"
-"</composite-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:972
-#, fuzzy, no-c-format
-msgid ""
 "The persistent class <emphasis>must</emphasis> override <literal>equals()</"
 "literal> and <literal>hashCode()</literal> to implement composite identifier "
 "equality. It must also implement <literal>Serializable</literal>."
 msgstr ""
-"Sua classe persistente <emphasis>precisa</emphasis> sobre escrever "
-"<literal>equals()</literal> e <literal>hashCode()</literal> para implementar "
+"A classe persistente <emphasis>precisa</emphasis> substituir <literal>equals"
+"()</literal> e <literal>hashCode()</literal> para implementar "
 "identificadores compostos igualmente. E precisa também implementar "
 "<literal>Serializable</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:978
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Unfortunately, this approach means that a persistent object is its own "
 "identifier. There is no convenient \"handle\" other than the object itself. "
@@ -2019,16 +1682,15 @@
 "serious applications."
 msgstr ""
 "Infelizmente, esta solução para um identificador composto significa que um "
-"objeto persistente é seu próprio identificador. Não há outro \"handle\" que "
-"o próprio objeto. Você mesmo precisa instanciar uma instância de outra "
-"classe persistente e preencher suas propriedades de identificação antes que "
-"você possa dar um <literal>load()</literal> para o estado persistente "
-"associado com uma chave composta. Nos chamamos esta solução de identificador "
-"composto <emphasis>embedded</emphasis> e não aconselhamos para aplicações "
-"sérias."
+"objeto persistente é seu próprio identificador. Não há outro \"handle\" "
+"conveniente a não ser o próprio objeto. Você mesmo precisa instanciar uma "
+"instância de outra classe persistente e preencher suas propriedades de "
+"identificação antes que você possa dar um <literal>load()</literal> para o "
+"estado persistente associado com uma chave composta. Nós chamamos esta "
+"solução de identificador composto <emphasis>incorporado</emphasis> e não "
+"aconselhamos para aplicações sérias."
 
 #. Tag: para
-#: basic_mapping.xml:987
 #, no-c-format
 msgid ""
 "A second approach is what we call a <emphasis>mapped</emphasis> composite "
@@ -2036,25 +1698,14 @@
 "composite-id&gt;</literal> element are duplicated on both the persistent "
 "class and a separate identifier class."
 msgstr ""
-"Uma segunda solução é o que podemos chamar de identificador composto "
-"<emphasis>mapped</emphasis> quando a propriedades de identificação nomeadas "
-"dentro do elemento <literal>&lt;composite-id&gt;</literal> estão duplicadas "
-"tando na classe persistente como em uma classe de identificação separada."
+"Uma segunda solução seria chamar de identificador composto <emphasis>mapped</"
+"emphasis> quando a propriedades de identificação nomeadas dentro do elemento "
+"<literal>&lt;composite-id&gt;</literal> estão duplicadas tanto na classe "
+"persistente como em uma classe de identificação separada."
 
-#. Tag: programlisting
-#: basic_mapping.xml:993
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<composite-id class=\"MedicareId\" mapped=\"true\">\n"
-"        <key-property name=\"medicareNumber\"/>\n"
-"        <key-property name=\"dependent\"/>\n"
-"</composite-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:995
-#, fuzzy, no-c-format
-msgid ""
 "In this example, both the composite identifier class, <literal>MedicareId</"
 "literal>, and the entity class itself have properties named "
 "<literal>medicareNumber</literal> and <literal>dependent</literal>. The "
@@ -2062,149 +1713,106 @@
 "<literal>hashCode()</literal> and implement <literal>Serializable</literal>. "
 "The main disadvantage of this approach is code duplication."
 msgstr ""
-"No exemplo, ambas as classes de identificação compostas, "
-"<literal>MedicareId</literal>, e a própria classe entidade tem propriedades "
-"nomeadas <literal>medicareNumber</literal> e <literal>dependent</literal>. A "
-"classe identificadora precisa sobrepor <literal>equals()</literal> e "
-"<literal>hashCode()</literal> e implementar <literal>Serializable</literal>. "
-"A desvantagem desta solução é obvia – duplicação de código."
+"No exemplo, ambas as classes de identificadores compostas, "
+"<literal>MedicareId</literal>, e a própria classe entidade possuem "
+"propriedades nomeadas <literal>medicareNumber</literal> e "
+"<literal>dependent</literal>. A classe identificadora precisa sobrepor "
+"<literal>equals()</literal> e <literal>hashCode()</literal> e implementar "
+"<literal>Serializable</literal>. A desvantagem desta solução é óbvia: "
+"duplicação de código."
 
 #. Tag: para
-#: basic_mapping.xml:1004
 #, no-c-format
 msgid ""
 "The following attributes are used to specify a mapped composite identifier:"
 msgstr ""
-"Os seguintes atributos ão utilizados para especificar o mapeamento de um "
+"As seguintes funções são utilizadas para especificar o mapeamento de um "
 "identificador composto:"
 
 #. Tag: para
-#: basic_mapping.xml:1010
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mapped</literal> (optional - defaults to <literal>false</literal>): "
 "indicates that a mapped composite identifier is used, and that the contained "
 "property mappings refer to both the entity class and the composite "
 "identifier class."
 msgstr ""
-"<literal>mapped</literal> mapped (opcional, valor default <literal>false </"
-"literal>): indica que um identificar composto mapeado é usado, e que as "
-"propriedades de mapeamento contidas refere-se tanto a classe entidade e a "
-"classe de identificação composta."
+"<literal>mapped</literal> (opcional, <literal>false</literal> por padrão): "
+"Indica que um identificar composto mapeado é usado, e que as propriedades de "
+"mapeamento contidas refere-se tanto à classe entidade quanto à classe de "
+"identificação composta."
 
 #. Tag: para
-#: basic_mapping.xml:1018
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - but required for a mapped composite "
 "identifier): the class used as a composite identifier."
 msgstr ""
-"<literal>class</literal> (opcional, mas requerida para um identificar "
-"composto mapeado): A classe usada como um identificador composto."
+"<literal>class</literal> (opcional, mas requerida para um identificador "
+"composto mapeado): A classe usada como um identificador composto. "
 
 #. Tag: para
-#: basic_mapping.xml:1025
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will describe a third, even more convenient approach, where the composite "
 "identifier is implemented as a component class in <xref linkend=\"components-"
-"compositeid\"/>. The attributes described below apply only to this "
+"compositeid\" />. The attributes described below apply only to this "
 "alternative approach:"
 msgstr ""
-"Nós iremos descrever uma terceira e as vezes mais conveniente solução, onde "
-"o identificador composto é implementado como uma classe componente na <xref "
-"linkend=\"components-compositeid\"/>. Os atributos descritos abaixo aplicam-"
-"se apenas para esta solução:"
+"Descreveremos uma abordagem terciária e até mais conveniente, onde o "
+"identificador da composição é implementado como uma classe componente na "
+"<xref linkend=\"components-compositeid\"/>. Os atributos descritos abaixo "
+"aplicam-se apenas para esta abordagem: "
 
 #. Tag: para
-#: basic_mapping.xml:1033
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal> (optional - required for this approach): a property "
 "of component type that holds the composite identifier. Please see chapter 9 "
 "for more information."
 msgstr ""
-"<literal>name</literal> (opcional, requerida para esta solução): Uma "
-"propriedade do tipo componente que armazena o identificador composto (veja "
-"capítulo 9)"
+"<literal>name</literal> (opcional, requerida para esta abordagem): Uma "
+"propriedade do tipo componente que armazena o identificador composto. Para "
+"maiores informações, por favor consulte o capítulo 9."
 
 #. Tag: para
-#: basic_mapping.xml:1039 basic_mapping.xml:1260 basic_mapping.xml:1372
-#: basic_mapping.xml:1561 basic_mapping.xml:1735 basic_mapping.xml:1905
-#: basic_mapping.xml:2484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate uses for accessing the property value."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default <literal>property</"
+"<literal>access</literal> (opcional - padrão  para <literal>property</"
 "literal>): A estratégia que o Hiberante deve utilizar para acessar o valor "
-"da propriedade\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default <literal>property</"
-"literal>): A estartégia Hibernate que deve ser utilizada para acessar o "
-"valor da propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default <literal>property</"
-"literal>): A estratégia Hibernate que deve ser usada para acessar o valor da "
-"propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default para <literal>property</"
-"literal>): A estretagia Hibernate que deve ser utilizada para acessar o "
-"valor da propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional – valor default <literal>property</"
-"literal>): A estratégia que o Hibernate deve utilizar para acessar o valor "
-"da propriedade\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default <literal>property</"
-"literal>): A estrategia que o Hibernate deve utilizar para acessar o valor "
-"da propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default padrão "
-"<literal>property</literal>): A estratégia que o Hibernate pode usar para "
-"acessar o valor da propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional – valor default <literal>property</"
-"literal>): A estratégia que o Hibernate pode usar para acessar o valor da "
-"propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional – valor default <literal>property</"
-"literal>): A estratégia que o hibernate deve usar para acessar o valor da "
-"propriedade."
+"da propriedade."
 
 #. Tag: para
-#: basic_mapping.xml:1045
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
 "determined by reflection): the component class used as a composite "
 "identifier. Please see the next section for more information."
 msgstr ""
-"<literal>class</literal> (opcional - valor default para o tipo de "
-"propriedade determiando por reflexão) : A classe componente utilizada como "
-"um identificador composto (veja a próxima sessão)."
+"<literal>class</literal> (opcional - valor padrão para o tipo de propriedade "
+"determinando por reflexão): A classe componente utilizada como um "
+"identificador composto. Por favor consulte a próxima seção para maiores "
+"informações."
 
 #. Tag: para
-#: basic_mapping.xml:1052
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The third approach, an <emphasis>identifier component</emphasis>, is "
 "recommended for almost all applications."
 msgstr ""
-"Esta terceira solução, um <emphasis>componente de identificação</emphasis>, "
-"é o que nós recomendamos para a maioria das aplicações."
+"Esta terceira abordagem, um <emphasis>componente identificador</emphasis>, é "
+"a que nós recomendamos para a maioria das aplicações. "
 
 #. Tag: title
-#: basic_mapping.xml:1060
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Discriminator"
-msgstr "discriminator"
+msgstr "Discriminador "
 
 #. Tag: para
-#: basic_mapping.xml:1062
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;discriminator&gt;</literal> element is required for "
 "polymorphic persistence using the table-per-class-hierarchy mapping "
@@ -2217,140 +1825,108 @@
 "literal>."
 msgstr ""
 "O elemento <literal>&lt;discriminator&gt;</literal> é necessário para "
-"persistência polimórfica utilizando a estratégia de mapeamento table-per-"
-"class-hierarchy e declara uma coluna discriminadora da tabela. A coluna "
-"discriminadora contem valores de marcação que dizem a camada de persistência "
-"qual subclasse instanciar para uma linha particular. Um restrito conjunto de "
-"tipos que podem ser utilizados: <literal>string</literal>, "
-"<literal>character</literal>, <literal>integer</literal>, <literal>byte</"
-"literal>, <literal>short</literal>, <literal>boolean</literal>, "
-"<literal>yes_no</literal>, <literal>true_false</literal>."
+"persistência polimórfica utilizando a estratégia de mapeamento de tabela-por-"
+"classe-hierárquica e declara uma coluna discriminadora da tabela. A coluna "
+"discriminadora contém valores de marcação que informam à camada de "
+"persistência qual subclasse instanciar para uma linha em específico. Um "
+"restrito conjunto de tipos que podem ser utilizados: <literal>string</"
+"literal>, <literal>character</literal>, <literal>integer</literal>, "
+"<literal>byte</literal>, <literal>short</literal>, <literal>boolean</"
+"literal>, <literal>yes_no</literal>, <literal>true_false</literal>."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1080
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<discriminator\n"
-"        column=\"discriminator_column\"\n"
-"        type=\"discriminator_type\"\n"
-"        force=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        formula=\"arbitrary sql expression\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1083
-#, fuzzy, no-c-format
-msgid ""
 "<literal>column</literal> (optional - defaults to <literal>class</literal>): "
 "the name of the discriminator column."
 msgstr ""
-"<literal>column</literal> (opcional - valor default <literal>class</"
-"literal>) o nome da coluna discriminadora"
+"<literal>column</literal> (opcional - padrão para <literal>class</literal>): "
+"O nome da coluna discriminadora."
 
 #. Tag: para
-#: basic_mapping.xml:1089
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>type</literal> (optional - defaults to <literal>string</literal>): "
 "a name that indicates the Hibernate type"
 msgstr ""
-"<literal>type</literal> (opcional - valor default <literal>string</literal>) "
-"o nome que indica o tipo Hibernate"
+"<literal>type</literal> (opcional - padrão para <literal>string</literal>): "
+"O nome que indica o tipo Hibernate."
 
 #. Tag: para
-#: basic_mapping.xml:1095
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>force</literal> (optional - defaults to <literal>false</literal>): "
 "\"forces\" Hibernate to specify the allowed discriminator values, even when "
 "retrieving all instances of the root class."
 msgstr ""
-"<literal>force</literal> (opcional - valor default <literal>false</literal>) "
-"\"força\" o Hibernate a especificar valores discriminadores permitidos mesmo "
-"quando recuperando todas as instancias da classe root."
+"<literal>force</literal> (opcional - valor padrão <literal>false</literal>): "
+"\"Força\" o Hibernate a especificar valores discriminadores permitidos mesmo "
+"quando recuperando todas as instâncias da classe raíz. "
 
 #. Tag: para
-#: basic_mapping.xml:1102
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>insert</literal> (optional - defaults to <literal>true</literal>): "
 "set this to <literal>false</literal> if your discriminator column is also "
 "part of a mapped composite identifier. It tells Hibernate not to include the "
 "column in SQL <literal>INSERTs</literal>."
 msgstr ""
-"<literal>insert</literal> (opcional - valor default para <literal>true</"
-"literal>) sete isto para <literal>false</literal> se sua coluna "
-"discriminadora é também parte do identificador composto mapeado. (Diz ao "
+"<literal>insert</literal> (opcional - valor padrão para <literal>true</"
+"literal>) Ajuste para <literal>false</literal> se sua coluna discriminadora "
+"também fizer parte do identificador composto mapeado. (Isto informa ao "
 "Hibernate para não incluir a coluna em comandos SQL <literal>INSERT</"
 "literal>s)."
 
 #. Tag: para
-#: basic_mapping.xml:1110
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an arbitrary SQL expression that is "
 "executed when a type has to be evaluated. It allows content-based "
 "discrimination."
 msgstr ""
-"<literal>formula</literal> (opcional) uma expressão SQL arbitraria que é e "
-"xecutada quando um tipo tem que ser avaliado. Permite discriminação baseada "
-"em conteúdo."
+"<literal>formula</literal> (opcional): Uma expressão SQL arbitrária que é "
+"executada quando um tipo tem que ser avaliado. Permite discriminação baseada "
+"em conteúdo. "
 
 #. Tag: para
-#: basic_mapping.xml:1118
 #, no-c-format
 msgid ""
 "Actual values of the discriminator column are specified by the "
 "<literal>discriminator-value</literal> attribute of the <literal>&lt;"
 "class&gt;</literal> and <literal>&lt;subclass&gt;</literal> elements."
 msgstr ""
-"Valores atuais de uma coluna discriminada são especificados pelo atributo "
+"Valores atuais de uma coluna discriminada são especificados pela função "
 "<literal>discriminator-value</literal> da <literal>&lt;class&gt;</literal> e "
 "elementos da <literal>&lt;subclass&gt;</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:1124
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>force</literal> attribute is only useful if the table contains "
 "rows with \"extra\" discriminator values that are not mapped to a persistent "
 "class. This will not usually be the case."
 msgstr ""
-"O atributo <literal>force</literal> é util (apenas) em tabelas contendo "
+"O atributo <literal>force</literal> é útil (apenas) em tabelas contendo "
 "linhas com valores discriminadores \"extras\" que não estão mapeados para "
 "uma classe persistente. Este não é geralmente o caso."
 
 #. Tag: para
-#: basic_mapping.xml:1130
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>formula</literal> attribute allows you to declare an arbitrary "
 "SQL expression that will be used to evaluate the type of a row. For example:"
 msgstr ""
-"Usando o atributo <literal>formula</literal> voce pode declarar uma "
-"expressão SQL arbitrária que sera utilizada para avaliar o tipo de uma "
-"linha :"
+"Usando o atributo <literal>formula</literal> você pode declarar uma "
+"expressão SQL arbitrária que será utilizada para avaliar o tipo de uma "
+"linha. Por exemplo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1135
-#, no-c-format
-msgid ""
-"<![CDATA[<discriminator\n"
-"    formula=\"case when CLASS_TYPE in ('a', 'b', 'c') then 0 else 1 end\"\n"
-"    type=\"integer\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:1140
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Version (optional)"
-msgstr "version (optional)"
+msgstr "Versão (opcional) "
 
 #. Tag: para
-#: basic_mapping.xml:1142
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;version&gt;</literal> element is optional and indicates "
 "that the table contains versioned data. This is particularly useful if you "
@@ -2359,98 +1935,45 @@
 msgstr ""
 "O elemento <literal>&lt;version&gt;</literal> é opcional e indica que a "
 "tabela possui dados versionados. Isto é particularmente útil se você planeja "
-"utilizar <emphasis>transações longas</emphasis> (veja abaixo):"
+"utilizar <emphasis>transações longas</emphasis>. Veja abaixo maiores "
+"informações: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1158
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<version\n"
-"        column=\"version_column\"\n"
-"        name=\"propertyName\"\n"
-"        type=\"typename\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unsaved-value=\"null|negative|undefined\"\n"
-"        generated=\"never|always\"\n"
-"        insert=\"true|false\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1161
-#, fuzzy, no-c-format
-msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of the column holding the version number."
 msgstr ""
-"<literal>column</literal> (opcional - default a a propriedade name): O nome "
-"da coluna mantendo o numero da versão"
+"<literal>column</literal> (opcional - tem como padrão o nome da propriedade "
+"name): O nome da coluna mantendo o número da versão."
 
 #. Tag: para
-#: basic_mapping.xml:1167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal>: the name of a property of the persistent class."
-msgstr "<literal>name</literal>: O nome da propriedade da classe persistente."
+msgstr "<literal>name</literal>: O nome da propriedade da classe persistente. "
 
 #. Tag: para
-#: basic_mapping.xml:1172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>type</literal> (optional - defaults to <literal>integer</literal>): "
 "the type of the version number."
 msgstr ""
-"<literal>type</literal> (opcional - valor default para <literal>integer</"
-"literal>): O tipo do numero da versão"
+"<literal>type</literal> (opcional - padrão para <literal>integer</literal>): "
+"O tipo do número da versão."
 
 #. Tag: para
-#: basic_mapping.xml:1178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate uses to access the property value."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default <literal>property</"
+"<literal>access</literal> (opcional - padrão para <literal>property</"
 "literal>): A estratégia que o Hiberante deve utilizar para acessar o valor "
-"da propriedade\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default <literal>property</"
-"literal>): A estartégia Hibernate que deve ser utilizada para acessar o "
-"valor da propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default <literal>property</"
-"literal>): A estratégia Hibernate que deve ser usada para acessar o valor da "
-"propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default para <literal>property</"
-"literal>): A estretagia Hibernate que deve ser utilizada para acessar o "
-"valor da propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional – valor default <literal>property</"
-"literal>): A estratégia que o Hibernate deve utilizar para acessar o valor "
-"da propriedade\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default <literal>property</"
-"literal>): A estrategia que o Hibernate deve utilizar para acessar o valor "
-"da propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional - valor default padrão "
-"<literal>property</literal>): A estratégia que o Hibernate pode usar para "
-"acessar o valor da propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional – valor default <literal>property</"
-"literal>): A estratégia que o Hibernate pode usar para acessar o valor da "
-"propriedade.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (opcional – valor default <literal>property</"
-"literal>): A estratégia que o hibernate deve usar para acessar o valor da "
-"propriedade."
+"da propriedade."
 
 #. Tag: para
-#: basic_mapping.xml:1184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to <literal>undefined</"
 "literal>): a version property value that indicates that an instance is newly "
@@ -2458,15 +1981,14 @@
 "saved or loaded in a previous session. <literal>Undefined</literal> "
 "specifies that the identifier property value should be used."
 msgstr ""
-"<literal>unsaved-value</literal> (opcional – valor default para "
+"<literal>unsaved-value</literal> (opcional – valor padrão para "
 "<literal>undefined </literal>): Um valor para a propriedade versão que "
-"indica que uma instancia é uma nova instanciada (unsaved), distinguindo de "
-"instancias desconectadas que foram salvas ou carregadas em sessões "
-"anteriores. ((<literal>undefined</literal> especifica que o valor da "
-"propriedade de identificação deve ser utilizado)."
+"indica que uma instância foi instanciada recentemente (unsaved), "
+"distinguindo de instâncias desconectadas que foram salvas ou carregadas em "
+"sessões anteriores. (<literal>undefined</literal> especifica que o valor da "
+"propriedade de identificação deve ser utilizado). "
 
 #. Tag: para
-#: basic_mapping.xml:1193
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2474,31 +1996,26 @@
 "database. See the discussion of <link linkend=\"mapping-generated"
 "\">generated properties</link> for more information."
 msgstr ""
-"<literal>generated</literal> (optional - defaults to <literal>never</"
-"literal>): Specifies that this version property value is actually generated "
-"by the database. See the discussion of <xref linkend=\"mapping-generated"
-"\">generated properties</xref>. <literal>generated</literal> (opcional - "
-"valor default <literal>never</literal>): Especifica que valor para a "
-"propriedade versão é na verdade gerado pelo banco de dados. Veja a discussão "
-"da Seção <xref linkend=\"mapping-generated\">generated properties</xref>."
+"<literal>generated</literal> (opcional - valor padrão <literal>never</"
+"literal>): Especifica que este valor de propriedade da versão é na verdade "
+"gerado pelo banco de dados. Veja o <xref linkend=\"mapping-generated\"/> "
+"para maiores informações. "
 
 #. Tag: para
-#: basic_mapping.xml:1200
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>insert</literal> (optional - defaults to <literal>true</literal>): "
 "specifies whether the version column should be included in SQL insert "
 "statements. It can be set to <literal>false</literal> if the database column "
 "is defined with a default value of <literal>0</literal>."
 msgstr ""
-"<literal>insert</literal> (opcional - valor default para <literal>true</"
-"literal>): Especifica se a coluna de versão deve ser incluída no comando SQL "
-"de insert. Pode ser configurado como <literal>false</literal> se a coluna do "
-"banco de dados está definida com um valor default de <literal>0</literal>."
+"<literal>insert</literal> (opcional - padrão para <literal>true</literal>): "
+"Especifica se a coluna de versão deve ser incluída na instrução de inserção "
+"do SQL. Pode ser configurado como <literal>false</literal> se a coluna do "
+"banco de dados estiver definida com um valor padrão de <literal>0</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:1210
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Version numbers can be of Hibernate type <literal>long</literal>, "
 "<literal>integer</literal>, <literal>short</literal>, <literal>timestamp</"
@@ -2506,11 +2023,10 @@
 msgstr ""
 "Números de versão podem ser dos tipos Hibernate <literal>long</literal>, "
 "<literal>integer</literal>, <literal>short</literal>, <literal>timestamp</"
-"literal> ou <literal>calendar</literal>."
+"literal> ou <literal>calendar</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:1215
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A version or timestamp property should never be null for a detached "
 "instance. Hibernate will detect any instance with a null version or "
@@ -2520,24 +2036,22 @@
 "reattachment in Hibernate. It is especially useful for people using assigned "
 "identifiers or composite keys</emphasis>."
 msgstr ""
-"A versão de uma propriedade timestamp nunca deve ser nula para uma instancia "
-"desconectada, assim o Hibernate irá identificar qualquer instância com uma "
-"versão nula ou timestamp como transiente, não importando qual estratégia "
-"para foi especificada para <literal>unsaved-value</literal>. "
-"<emphasis>Declarando uma versão nula ou a propriedade timestamp é um caminho "
-"fácil para tratar problemas com reconexões transitivas no Hibernate, "
-"especialmente úteis para pessoas utilizando identificadores assinaldados ou "
-"chaves compostas!</emphasis>"
+"A versão ou timestamp de uma propriedade nunca deve ser nula para uma "
+"instância desconectada, assim o Hibernate irá identificar qualquer instância "
+"com uma versão nula ou timestamp como transiente, não importando qual outra "
+"estratégia <literal>unsaved-value</literal> tenha sido especificada. "
+"<emphasis>A declaração de uma versão nula ou a propriedade timestamp é um "
+"caminho fácil para tratar problemas com reconexões transitivas no Hibernate, "
+"especialmente úteis para pessoas utilizando identificadores atribuídos ou "
+"chaves compostas</emphasis>."
 
 #. Tag: title
-#: basic_mapping.xml:1226
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Timestamp (optional)"
-msgstr "timestamp (optional)"
+msgstr "Timestamp (opcional) "
 
 #. Tag: para
-#: basic_mapping.xml:1228
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The optional <literal>&lt;timestamp&gt;</literal> element indicates that the "
 "table contains timestamped data. This provides an alternative to versioning. "
@@ -2545,39 +2059,22 @@
 "sometimes the application might use the timestamps in other ways."
 msgstr ""
 "O elemento opcional <literal>&lt;timestamp&gt;</literal> indica que uma "
-"tabela contém dados timestamped. Isso tem por objetivo dar uma alternativa "
+"tabela contém dados em timestamp. Isso tem por objetivo dar uma alternativa "
 "para versionamento. Timestamps são por natureza uma implementação menos "
-"segura do locking otimista. Entretanto, algumas vezes a aplicação pode usar "
-"timestamps em outros caminhos."
+"segura do bloqueio otimista. Entretanto, algumas vezes a aplicação pode usar "
+"timestamps em outros caminhos. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1244
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<timestamp\n"
-"        column=\"timestamp_column\"\n"
-"        name=\"propertyName\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unsaved-value=\"null|undefined\"\n"
-"        source=\"vm|db\"\n"
-"        generated=\"never|always\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1247
-#, fuzzy, no-c-format
-msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of a column holding the timestamp."
 msgstr ""
-"<literal>column</literal> (opcional - valor default para a propriedade "
-"name): O nome da coluna que mantem o timestamp."
+"<literal>column</literal> (opcional - padrão para o nome da propriedade): O "
+"nome da coluna que mantém o timestamp."
 
 #. Tag: para
-#: basic_mapping.xml:1253
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal>: the name of a JavaBeans style property of Java type "
 "<literal>Date</literal> or <literal>Timestamp</literal> of the persistent "
@@ -2585,11 +2082,10 @@
 msgstr ""
 "<literal>name</literal>: O nome da propriedade no estilo JavaBeans do tipo "
 "<literal>Date</literal> ou <literal>Timestamp</literal> da classe "
-"persistente Java."
+"persistente."
 
 #. Tag: para
-#: basic_mapping.xml:1266
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to <literal>null</"
 "literal>): a version property value that indicates that an instance is newly "
@@ -2597,16 +2093,15 @@
 "saved or loaded in a previous session. <literal>Undefined</literal> "
 "specifies that the identifier property value should be used."
 msgstr ""
-"<literal>unsaved-value</literal> (opcional - valor default <literal>null</"
-"literal>): Uma propriedade para a versão de que indica que uma instância é "
-"uma nova instanciada (unsaved), distinguindo-a de instancias desconectadas "
-"que foram salvas ou carregadas em sessões previas. (<literal>undefined</"
-"literal> especifica que um valor de propriedade de identificação deve ser "
-"utilizado)"
+"<literal>unsaved-value</literal> (opcional - padrão para <literal>null</"
+"literal>): Um valor de propriedade da versão que indica que uma instância "
+"foi recentemente instanciada (unsaved), distinguindo-a de instâncias "
+"desconectadas que foram salvas ou carregadas em sessões prévias. "
+"<literal>Undefined</literal> especifica que um valor de propriedade de "
+"identificação deve ser utilizado."
 
 #. Tag: para
-#: basic_mapping.xml:1275
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>source</literal> (optional - defaults to <literal>vm</literal>): "
 "Where should Hibernate retrieve the timestamp value from? From the database, "
@@ -2617,18 +2112,17 @@
 "timestamp. Others may also be unsafe for usage in locking due to lack of "
 "precision (Oracle 8, for example)."
 msgstr ""
-"<literal>source</literal> (opcional - valor default para <literal>vm</"
-"literal>): De onde o Hibernate deve recuperar o valor timestamp? Do banco de "
-"dados ou da JVM corrente? Timestamps baseados em banco de dados levam a um "
-"overhead porque o Hibernate precisa acessar o banco de dados para determinar "
-"o \"próximo valor\", mas é mais seguro para uso em ambientes de \"cluster\". "
-"Observe também, que nem todos <literal>Dialect</literal>s suportam a "
-"recuperação do timestamp corrente do banco de dados, enquando outros podem "
-"não ser seguros para utilização em bloqueios pela falta de precisão (Oracle "
-"8 por exemplo)"
+"<literal>source</literal> (opcional - padrão para <literal>vm</literal>): De "
+"onde o Hibernate deve recuperar o valor timestamp? Do banco de dados ou da "
+"JVM atual? Timestamps baseados em banco de dados levam a um overhead porque "
+"o Hibernate precisa acessar o banco de dados para determinar o \"próximo "
+"valor\", mas é mais seguro para uso em ambientes de cluster. Observe também, "
+"que nem todos os <literal>Dialects</literal> suportam a recuperação do "
+"carimbo de data e hora atual do banco de dados, enquanto outros podem não "
+"ser seguros para utilização em bloqueios, pela falta de precisão (Oracle 8, "
+"por exemplo)."
 
 #. Tag: para
-#: basic_mapping.xml:1287
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2636,75 +2130,44 @@
 "generated by the database. See the discussion of <link linkend=\"mapping-"
 "generated\">generated properties</link> for more information."
 msgstr ""
-"<literal>generated</literal> (opcional - valor default <literal>never</"
+"<literal>generated</literal> (opcional - padrão para <literal>never</"
 "literal>): Especifica que o valor da propriedade timestamp é gerado pelo "
-"banco de dados. Veja a discussão <xref linkend=\"mapping-generated"
-"\">generated properties</xref>."
+"banco de dados. Veja a discussão do <xref linkend=\"mapping-generated\"/> "
+"para maiores informações. "
 
 #. Tag: title
-#: basic_mapping.xml:1298 basic_mapping.xml:2890
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Nota"
 
 #. Tag: para
-#: basic_mapping.xml:1299
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>&lt;Timestamp&gt;</literal> is equivalent to <literal>&lt;version "
 "type=\"timestamp\"&gt;</literal>. And <literal>&lt;timestamp source=\"db"
 "\"&gt;</literal> is equivalent to <literal>&lt;version type=\"dbtimestamp"
 "\"&gt;</literal>"
 msgstr ""
-"Observe que <literal>&lt;timestamp&gt;</literal> é equivalente a "
+"Observe que o <literal>&lt;timestamp&gt;</literal> é equivalente a "
 "<literal>&lt;version type=\"timestamp\"&gt;</literal>. E <literal>&lt;"
 "timestamp source=\"db\"&gt;</literal> é equivalente a <literal>&lt;version "
 "type=\"dbtimestamp\"&gt;</literal>."
 
 #. Tag: title
-#: basic_mapping.xml:1311
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Property"
-msgstr "property"
+msgstr "Propriedade "
 
 #. Tag: para
-#: basic_mapping.xml:1313
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;property&gt;</literal> element declares a persistent "
 "JavaBean style property of the class."
 msgstr ""
-"O elemento <literal>&lt;property&gt;</literal> declara uma propriedade "
-"persistente de uma classe, no estilo JavaBean."
+"O elemento <literal>&lt;property&gt;</literal> declara uma propriedade de "
+"estilo JavaBean de uma classe."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1335
-#, no-c-format
-msgid ""
-"<![CDATA[<property\n"
-"        name=\"propertyName\"\n"
-"        column=\"column_name\"\n"
-"        type=\"typename\"\n"
-"        update=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        formula=\"arbitrary SQL expression\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        lazy=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        not-null=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        generated=\"never|insert|always\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        index=\"index_name\"\n"
-"        unique_key=\"unique_key_id\"\n"
-"        length=\"L\"\n"
-"        precision=\"P\"\n"
-"        scale=\"S\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1338
 #, no-c-format
 msgid ""
 "<literal>name</literal>: the name of the property, with an initial lowercase "
@@ -2714,20 +2177,18 @@
 "minúscula."
 
 #. Tag: para
-#: basic_mapping.xml:1344
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of the mapped database table column. This can also be specified by "
 "nested <literal>&lt;column&gt;</literal> element(s)."
 msgstr ""
-"<literal>column</literal> (opcional - default para a propriedade name): o "
-"nome da coluna mapeada do banco de dados, Isto pode também ser especificado "
+"<literal>column</literal> (opcional - padrão para o nome da propriedade): O "
+"nome da coluna mapeada do banco de dados. Isto pode também ser especificado "
 "pelo(s) elemento(s) <literal>&lt;column&gt;</literal> aninhados."
 
 #. Tag: para
-#: basic_mapping.xml:1356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update, insert</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that the mapped columns should be included in SQL "
@@ -2736,76 +2197,70 @@
 "whose value is initialized from some other property that maps to the same "
 "column(s), or by a trigger or other application."
 msgstr ""
-"<literal>update, insert</literal> (opcional - valor default <literal>true</"
-"literal>): especifica que as colunas mapeadas devem ser incluidas nas "
-"instruções SQL de <literal>UPDATE</literal> e/ou <literal>INSERT</literal> . "
-"Setar ambas para to <literal>false</literal> permite uma propridade "
-"\"derivada\" pura cujo valor é inicializado de outra propriedade que mapeie "
-"a mesma coluna(s) ou por uma trigger ou outra aplicação."
+"<literal>update, insert</literal> (opcional - padrão para <literal>true</"
+"literal>): especifica que as colunas mapeadas devem ser incluídas nas "
+"instruções SQL de <literal>UPDATE</literal> e/ou <literal>INSERT</literal>. "
+"Ajustar ambas para <literal>false</literal> permite uma propridade \"derivada"
+"\" pura, cujo valor é inicializado de outra propriedade, que mapeie a mesma "
+"coluna(s) ou por uma disparo ou outra aplicação."
 
 #. Tag: para
-#: basic_mapping.xml:1365
 #, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an SQL expression that defines the "
 "value for a <emphasis>computed</emphasis> property. Computed properties do "
 "not have a column mapping of their own."
 msgstr ""
-"<literal>formula</literal> (opcional): uma expressão SQL que definie o valor "
+"<literal>formula</literal> (opcional): uma instrução SQL que definie o valor "
 "para uma propriedade <emphasis>calculada</emphasis>. Propriedades calculadas "
-"nao tem uma coluna de mapeamento para elas."
+"não possuem uma coluna de mapeamento para elas."
 
 #. Tag: para
-#: basic_mapping.xml:1378
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>false</literal>): "
 "specifies that this property should be fetched lazily when the instance "
 "variable is first accessed. It requires build-time bytecode instrumentation."
 msgstr ""
-"<literal>lazy</literal> (opcional - valor default para <literal>false</"
-"literal>): Especifica que esta propriedade deve ser trazida de forma \"lazy"
-"\" quando a instancia da variável é acessada pela primeira vez (requer "
-"instrumentação bytecode em tempo de criação)."
+"<literal>lazy</literal> (opcional - padrão para <literal>false</literal>): "
+"Especifica que esta propriedade deve ser atingida de forma lenta quando a "
+"instância da variável é acessada pela primeira vez. Isto requer "
+"instrumentação bytecode em tempo de criação."
 
 #. Tag: para
-#: basic_mapping.xml:1385
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): enables the DDL generation of a unique "
 "constraint for the columns. Also, allow this to be the target of a "
 "<literal>property-ref</literal>."
 msgstr ""
-"<literal>unique</literal> (opcional): Habilita a geração de DDL de uma unica "
-"constraint para as colunas. Assim, permite que isto seja o alvo de uma "
-"<literal>property-ref</literal>."
+"<literal>unique</literal> (opcional): Habilita a geração de DDL de uma única "
+"restrição para as colunas. Da mesma forma, permita que isto seja o alvo de "
+"uma <literal>property-ref</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:1392
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): enables the DDL generation of a "
 "nullability constraint for the columns."
 msgstr ""
 "<literal>not-null</literal> (opcional): Habilita a geração de DDL de uma "
-"constraint de nulidade para as colunas."
+"restrição de nulidade para as colunas. "
 
 #. Tag: para
-#: basic_mapping.xml:1398 basic_mapping.xml:1581
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to this property do or do not require "
 "acquisition of the optimistic lock. In other words, it determines if a "
 "version increment should occur when this property is dirty."
 msgstr ""
-"<literal>optimistic-lock</literal> (opcional - valor default <literal>true</"
+"<literal>optimistic-lock</literal> (opcional - padrão para <literal>true</"
 "literal>): Especifica se mudanças para esta propriedade requerem ou não "
 "bloqueio otimista. Em outras palavras, determina se um incremento de versão "
 "deve ocorrer quando esta propriedade está suja."
 
 #. Tag: para
-#: basic_mapping.xml:1406
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2813,60 +2268,52 @@
 "database. See the discussion of <link linkend=\"mapping-generated"
 "\">generated properties</link> for more information."
 msgstr ""
-"<literal>generated</literal> (opcional - valor default <literal>never</"
+"<literal>generated</literal> (opcional - padrão para <literal>never</"
 "literal>): Especifica que o valor da propriedade é na verdade gerado pelo "
-"banco de dados. Veja a discussão da seção <xref linkend=\"mapping-generated"
-"\">generated properties</xref>."
+"banco de dados. Veja a discussão do <xref linkend=\"mapping-generated\"/> "
+"para maiores informações. "
 
 #. Tag: para
-#: basic_mapping.xml:1415
 #, no-c-format
 msgid "<emphasis>typename</emphasis> could be:"
 msgstr "<emphasis>typename</emphasis> pode ser:"
 
 #. Tag: para
-#: basic_mapping.xml:1421
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The name of a Hibernate basic type: <literal>integer, string, character, "
 "date, timestamp, float, binary, serializable, object, blob</literal> etc."
 msgstr ""
-"The name of a Hibernate basic type (eg. <literal>integer, string, character, "
-"date, timestamp, float, binary, serializable, object, blob</literal>). O "
-"nome do tipo basico do Hibernate (ex., <literal>integer, string, character, "
-"date, timestamp, float, binary, serializable, object, blob</literal>)."
+"O nome de um tipo básico de Hibernate: <literal>integer, string, character, "
+"date, timestamp, float, binary, serializable, object, blob</literal>, etc. "
 
 #. Tag: para
-#: basic_mapping.xml:1427
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The name of a Java class with a default basic type: <literal>int, float, "
 "char, java.lang.String, java.util.Date, java.lang.Integer, java.sql.Clob</"
 "literal> etc."
 msgstr ""
-"O nome da classe Java com um tipo básico default (ex. <literal>int, float, "
-"char, java.lang.String, java.util.Date, java.lang.Integer, java.sql.Clob</"
-"literal>)."
+"O nome da classe Java com um tipo básico padrão: <literal>int, float, char, "
+"java.lang.String, java.util.Date, java.lang.Integer, java.sql.Clob</"
+"literal>, etc."
 
 #. Tag: para
-#: basic_mapping.xml:1433
 #, no-c-format
 msgid "The name of a serializable Java class."
-msgstr "O nome da classe Java serializable"
+msgstr "O nome da classe Java serializável"
 
 #. Tag: para
-#: basic_mapping.xml:1438
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The class name of a custom type: <literal>com.illflow.type.MyCustomType</"
 "literal> etc."
 msgstr ""
-"O nome da classe de um tipo customizado (ex. <literal>com.illflow.type."
-"MyCustomType</literal>)."
+"O nome da classe de um tipo customizado: <literal>com.illflow.type."
+"MyCustomType</literal>, etc."
 
 #. Tag: para
-#: basic_mapping.xml:1444
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you do not specify a type, Hibernate will use reflection upon the named "
 "property and guess the correct Hibernate type. Hibernate will attempt to "
@@ -2876,18 +2323,16 @@
 "DATE</literal> and <literal>Hibernate.TIMESTAMP</literal>, or to specify a "
 "custom type."
 msgstr ""
-"Se você não especificar um tipo, o Hibernate ira utilizar reflexão sobre a "
-"propriedade nomeada para ter uma idéia do tipo Hibernate correto. O "
-"Hibernate ira tentar interpretar o nome da classe retornada, usando as "
-"regras 2, 3 e 4 nesta ordem. Entretanto, isto não é sempre suficiente Em "
-"certos casos, você ainda irá necessitar do atributo <literal>type</literal>. "
-"(Por exemplo, para distinguir entre <literal>Hibernate.DATE</literal> ou "
-"<literal>Hibernate.TIMESTAMP</literal>, ou para espcificar uma tipo "
-"ciustomizado.)"
+"Se você não especificar um tipo, o Hibernate irá utilizar reflexão sobre a "
+"propriedade nomeada para ter uma idéia do tipo de Hibernate correto. O "
+"Hibernate tentará interpretar o nome da classe retornada, usando as regras "
+"2, 3 e 4 nesta ordem. Em certos casos, você ainda precisará do atributo "
+"<literal>type</literal>. Por exemplo, para distinguir entre "
+"<literal>Hibernate.DATE</literal> e <literal>Hibernate.TIMESTAMP</literal>, "
+"ou para especificar um tipo customizado."
 
 #. Tag: para
-#: basic_mapping.xml:1454
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>access</literal> attribute allows you to control how Hibernate "
 "accesses the property at runtime. By default, Hibernate will call the "
@@ -2897,18 +2342,17 @@
 "a class that implements the interface <literal>org.hibernate.property."
 "PropertyAccessor</literal>."
 msgstr ""
-"O atributo <literal>access</literal> permite voce controlar como o Hibernate "
-"irá acessar a propriedade em tempo de execução. Por default, o Hibernate irá "
-"chamar os métodos get/set da propriedades. Se voce especificar "
-"<literal>access=\"field\"</literal>, o Hibernate ira bipassar os metodos get/"
-"set, acessnado o campo diretamente, usando reflexão. Voc epode especificar "
+"A função <literal>access</literal> permite que você controle como o "
+"Hibernate irá acessar a propriedade em tempo de execução. Por padrão, o "
+"Hibernate irá chamar os métodos get/set da propriedades. Se você especificar "
+"<literal>access=\"field\"</literal>, o Hibernate irá bipassar os metodos get/"
+"set, acessando o campo diretamente, usando reflexão. Você pode especificar "
 "sua própria estratégia para acesso da propriedade criando uma classe que "
 "implemente a interface <literal>org.hibernate.property.PropertyAccessor</"
 "literal>."
 
 #. Tag: para
-#: basic_mapping.xml:1463
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A powerful feature is derived properties. These properties are by definition "
 "read-only. The property value is computed at load time. You declare the "
@@ -2916,48 +2360,32 @@
 "literal> clause subquery in the SQL query that loads an instance:"
 msgstr ""
 "Um recurso especialmente poderoso é o de propriedades derivadas. Estas "
-"propriedades são por definição read-only, e o valor da propriedade é "
-"calculado em tempo de execução. Você declara este calculo como uma expressão "
-"SQL, que traduz para clausula <literal>SELECT</literal> de uma subquery "
-"daquery SQL que carrega a instancia:"
+"propriedades são por definição somente leitura, e o valor da propriedade é "
+"calculado em tempo de execução. Você declara este cálculo como uma expressão "
+"SQL, que traduz para cláusula <literal>SELECT</literal> de uma subconsulta "
+"da consulta SQL que carrega a instância: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1470
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"<property name=\"totalPrice\"\n"
-"    formula=\"( SELECT SUM (li.quantity*p.price) FROM LineItem li, Product "
-"p\n"
-"                WHERE li.productId = p.productId\n"
-"                AND li.customerId = customerId\n"
-"                AND li.orderNumber = orderNumber )\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1472
-#, fuzzy, no-c-format
-msgid ""
 "You can reference the entity table by not declaring an alias on a particular "
 "column. This would be <literal>customerId</literal> in the given example. "
 "You can also use the nested <literal>&lt;formula&gt;</literal> mapping "
 "element if you do not want to use the attribute."
 msgstr ""
 "Observe que você pode referenciar as entidades da própria tabela, através da "
-"não declaração de um alias para uma coluna particular ( <literal>customerId</"
-"literal> no exemplo dado). Observe tambem que voce pode usar o mapeamento de "
-"elemento aninhado <literal>&lt;formula&gt;</literal>, se você não gostar de "
-"usar o atributo."
+"não declaração de um alias para uma coluna particular. Isto seria o "
+"<literal>customerId</literal> no exemplo dado. Observe também que você pode "
+"usar o mapeamento de elemento aninhado <literal>&lt;formula&gt;</literal>, "
+"se você não gostar de usar o atributo. "
 
 #. Tag: title
-#: basic_mapping.xml:1482
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Many-to-one"
-msgstr "many-to-one"
+msgstr "Muitos-para-um "
 
 #. Tag: para
-#: basic_mapping.xml:1484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An ordinary association to another persistent class is declared using a "
 "<literal>many-to-one</literal> element. The relational model is a many-to-"
@@ -2966,102 +2394,55 @@
 msgstr ""
 "Uma associação ordinária para outra classe persistente é declarada usando o "
 "elemento <literal>many-to-one</literal>. O modelo relacional é uma "
-"associação many-to-one: a uma chave estrangeira de uma tabela referenciando "
-"a chave primaria da tabela destino."
+"associação muitos para um: uma chave exterior de uma tabela referenciando as "
+"colunas da chave primária da tabela destino."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1512
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one\n"
-"        name=\"propertyName\"\n"
-"        column=\"column_name\"\n"
-"        class=\"ClassName\"\n"
-"        cascade=\"cascade_style\"\n"
-"        fetch=\"join|select\"\n"
-"        update=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unique=\"true|false\"\n"
-"        not-null=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        lazy=\"proxy|no-proxy|false\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        formula=\"arbitrary SQL expression\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        embed-xml=\"true|false\"\n"
-"        index=\"index_name\"\n"
-"        unique_key=\"unique_key_id\"\n"
-"        foreign-key=\"foreign_key_name\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1515 basic_mapping.xml:1696 basic_mapping.xml:1882
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>name</literal>: the name of the property."
-msgstr "<literal>name</literal>: O nome da propriedade."
+msgstr "<literal>name</literal>: O nome da propriedade. "
 
 #. Tag: para
-#: basic_mapping.xml:1520 basic_mapping.xml:2311
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>column</literal> (optional): the name of the foreign key column. "
 "This can also be specified by nested <literal>&lt;column&gt;</literal> "
 "element(s)."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>column</literal> (opcional): O nome da coluna foreign key. Isto "
-"pode também ser especificado através de elementos aninhados <literal>&lt;"
-"column&gt;</literal>.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-". <literal>column</literal> (opcional): O nome da coluna da chave "
-"estrangeira. Isto também pode ser especificado por aninhamento de elemento"
-"(s) <literal>&lt;column&gt;</literal>."
+"<literal>column</literal> (opcional): O nome da coluna da chave exterior. "
+"Isto pode também ser especificado através de elementos aninhados "
+"<literal>&lt;column&gt;</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:1527 basic_mapping.xml:1701
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
 "determined by reflection): the name of the associated class."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>class</literal> (opcional – default para o tipo de propriedade "
-"determinado pela reflexão). O nome da classe associada.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>class</literal> (opcional – default para o tipo da propriedade "
-"definido via reflection): O nome da classe associada."
+"<literal>class</literal> (opcional – padrão para o tipo de propriedade "
+"determinado pela reflexão): O nome da classe associada."
 
 #. Tag: para
-#: basic_mapping.xml:1533 basic_mapping.xml:1707
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional): specifies which operations should be "
 "cascaded from the parent object to the associated object."
 msgstr ""
-"<literal>cascade</literal> (opcional): Especifica qual operação deve ser "
-"cascateada do objeto pai para o objeto associado."
+"<literal>cascade</literal> (opcional): Especifica qual operação deve ser  "
+"cascateada do objeto pai para o objeto associado. "
 
 #. Tag: para
-#: basic_mapping.xml:1539 basic_mapping.xml:1722
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional - defaults to <literal>select</literal>): "
 "chooses between outer-join fetching or sequential select fetching."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>fetch</literal> (opcional - default para <literal>select</"
-"literal>): Escolhe entre recuperação outer-join ou recuperação seqüencial.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>fetch</literal> ((opcional – valor default <literal>select</"
-"literal>): Escolhe entre outer-join fetching ou sequential select fetching."
+"<literal>fetch</literal> (opcional - padrão para <literal>select</literal>): "
+"Escolhe entre recuperação da união exterior ou recuperação seqüencial de "
+"seleção."
 
 #. Tag: para
-#: basic_mapping.xml:1545
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update, insert</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that the mapped columns should be included in SQL "
@@ -3070,29 +2451,27 @@
 "association whose value is initialized from another property that maps to "
 "the same column(s), or by a trigger or other application."
 msgstr ""
-"<literal>update, insert</literal> (opcional - valor default <literal>true</"
-"literal>): especifica que as colunas mapeadas dever ser incluidas em "
+"<literal>update, insert</literal> (opcional - valor padrão <literal>true</"
+"literal>): especifica que as colunas mapeadas devem ser incluídas em "
 "instruções SQL de <literal>UPDATE</literal> e/ou <literal>INSERT</literal>. "
-"Setando ambas para <literal>false</literal> você permite uma associação "
-"\"derivada\" pura cujos valores são inicializados de algumas outras "
-"propriedades que mapeiam a mesma coluna ou por uma trigger ou outra "
-"aplicação."
+"Com o ajuste de ambas para <literal>false</literal> você permite uma "
+"associação \"derivada\" pura cujos valores são inicializados de algumas "
+"outras propriedades que mapeiam a(s) mesma(s) coluna(s) ou por um trigger ou "
+"outra aplicação. "
 
 #. Tag: para
-#: basic_mapping.xml:1554
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): the name of a property of the "
 "associated class that is joined to this foreign key. If not specified, the "
 "primary key of the associated class is used."
 msgstr ""
-"<literal>property-ref</literal>: (opcional) O nome da propriedade da classe "
-"associada que faz a junção desta foreign key. Se não especificada, a chave "
-"primaria da classe associada será utilizada."
+"<literal>property-ref</literal>: (opcional) O nome de uma propriedade da "
+"classe associada que esteja unida à esta chave exterior. Se não for "
+"especificada, a chave primária da classe associada será utilizada. "
 
 #. Tag: para
-#: basic_mapping.xml:1567
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): enables the DDL generation of a unique "
 "constraint for the foreign-key column. By allowing this to be the target of "
@@ -3100,23 +2479,21 @@
 "one-to-one."
 msgstr ""
 "<literal>unique</literal> (opcional): Habilita a geração DDL de uma "
-"constraint unique para a coluna foreign-key. Alem disso, permite ser o alvo "
-"de uma <literal>property-ref</literal>. Isso torna a associação multipla "
-"efetivamente um para um."
+"restrição única para a coluna da chave exterior. Além disso, permite ser o "
+"alvo de uma <literal>property-ref</literal>. Isso torna a multiplicidade  da "
+"associação efetivamente um para um. "
 
 #. Tag: para
-#: basic_mapping.xml:1575
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): enables the DDL generation of a "
 "nullability constraint for the foreign key columns."
 msgstr ""
-"<literal>not-null</literal> (opcional): Habilita a geração DDL de uma "
-"constraint de nulidade para as foreign keys."
+"<literal>not-null</literal> (opcional): Habilita a geração DDL de uma  "
+"restrição de nulidade para as colunas de chaves exteriores."
 
 #. Tag: para
-#: basic_mapping.xml:1589
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>proxy</literal>): "
 "by default, single point associations are proxied. <literal>lazy=\"no-proxy"
@@ -3125,51 +2502,47 @@
 "instrumentation. <literal>lazy=\"false\"</literal> specifies that the "
 "association will always be eagerly fetched."
 msgstr ""
-"<literal>lazy</literal>(opcional – valor default <literal>proxy</literal>): "
-"Por default, associações de ponto unico são envoltas em um proxie. "
+"<literal>lazy</literal>(opcional – padrão para <literal>proxy</literal>): "
+"Por padrão, associações de ponto único são envoltas em um proxie. "
 "<literal>lazy=\"no-proxy\"</literal> especifica que a propriedade deve ser "
-"trazida de forma tardia quando a instancia da variável é acessada pela "
-"primeira vez (requer instrumentação bytecode em tempo de criação) "
+"trazida de forma tardia quando a instância da variável é acessada pela "
+"primeira vez. Isto requer instrumentação bytecode em tempo de criação. O "
 "<literal>lazy=\"false\"</literal> especifica que a associação será sempre "
-"recuperada fortemente."
+"procurada."
 
 #. Tag: para
-#: basic_mapping.xml:1599
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-found</literal> (optional - defaults to <literal>exception</"
 "literal>): specifies how foreign keys that reference missing rows will be "
 "handled. <literal>ignore</literal> will treat a missing row as a null "
 "association."
 msgstr ""
-"<literal>not-found</literal> (opcional - valor default <literal>exception</"
-"literal>): Especifica como as foreign keys que referenciam linhas ausentes "
-"serão tratadas: <literal>ignore</literal> irá tratar a linha ausente como "
-"ama associaççao de null"
+"<literal>not-found</literal> (opcional - padrão para <literal>exception</"
+"literal>): Especifica como as chaves exteriores que informam que linhas que "
+"estejam faltando serão manuseadas. O <literal>ignore</literal> tratará a "
+"linha faltante como uma associação nula."
 
 #. Tag: para
-#: basic_mapping.xml:1606 basic_mapping.xml:1760
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>entity-name</literal> (optional): the entity name of the associated "
 "class."
 msgstr ""
 "<literal>entity-name</literal> (opcional): O nome da entidade da classe "
-"associada."
+"associada. "
 
 #. Tag: para
-#: basic_mapping.xml:1611
 #, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an SQL expression that defines the "
 "value for a <emphasis>computed</emphasis> foreign key."
 msgstr ""
-"<literal>formula</literal> (optional): Uma expressão SQL que define um valor "
-"para um foreign key <emphasis>computed</emphasis>."
+"<literal>formula</literal> (optional): Uma instrução SQL que define um valor "
+"para uma chave exterior <emphasis>computed</emphasis>."
 
 #. Tag: para
-#: basic_mapping.xml:1619
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Setting a value of the <literal>cascade</literal> attribute to any "
 "meaningful value other than <literal>none</literal> will propagate certain "
@@ -3179,42 +2552,34 @@
 "second, special values: <literal>delete-orphan</literal>; and third,"
 "<literal>all</literal> comma-separated combinations of operation names: "
 "<literal>cascade=\"persist,merge,evict\"</literal> or <literal>cascade=\"all,"
-"delete-orphan\"</literal>. See <xref linkend=\"objectstate-transitive\"/> "
+"delete-orphan\"</literal>. See <xref linkend=\"objectstate-transitive\" /> "
 "for a full explanation. Note that single valued, many-to-one and one-to-one, "
 "associations do not support orphan delete."
 msgstr ""
-"Setar o valor do atributo <literal>cascade</literal> para qualquer valor "
-"significativo diferente de <literal>none</literal> irá propagar certas "
-"operações ao objeto associado. Os valores significativos são os nomes das "
-"operações básicas do Hibernate, <literal>persist, merge, delete, save-"
-"update, evict, replicate, lock, refresh</literal>, assim como os valores "
-"especiais <literal>delete-orphan</literal> e <literal>all</literal> e "
-"combinações de nomes de operações separadas por vírgula, como por exemplo, "
-"<literal>cascade=\"persist,merge,evict\"</literal> ou <literal>cascade=\"all,"
-"delete-orphan\"</literal>. Veja a seção <xref linkend=\"objectstate-"
-"transitive\"/> para uma explicação completa. Note que associações valoradas "
-"simples (associações muitos-pra-um, e um-pra-um) não suportam orphan delete."
+"Ao ajustar o valor do atributo <literal>cascade</literal> para qualquer "
+"valor diferente de <literal>none</literal> irá propagar certas operações ao "
+"objeto associado. Os valores significativos são divididos em três "
+"categorias. A primeira, operações básicas, que inclui: <literal>persist, "
+"merge, delete, save-update, evict, replicate, lock and refresh</literal>. A "
+"segunda, valores especiais: <literal>delete-orphan</literal> e a terceira "
+"combinações de vírgula separada <literal>all</literal> dos nomes da "
+"operação: <literal>cascade=\"persist,merge,evict\"</literal> ou "
+"<literal>cascade=\"all,delete-orphan\"</literal>. Veja <xref linkend="
+"\"objectstate-transitive\"/> para uma completa explicação. Perceba que as "
+"associações de valores únicos, muitos-para-um e um-para-um, não suportam "
+"delete órfão: "
 
 #. Tag: para
-#: basic_mapping.xml:1632
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Here is an example of a typical <literal>many-to-one</literal> declaration:"
 msgstr ""
-"Uma típica declaração <literal>muitos-pra-um</literal> se parece com esta:"
+"Segue abaixo uma amostra de uma típica declaração <literal>many-to-one</"
+"literal>:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1636
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"product\" class=\"Product\" column=\"PRODUCT_ID"
-"\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1638
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>property-ref</literal> attribute should only be used for "
 "mapping legacy data where a foreign key refers to a unique key of the "
 "associated table other than the primary key. This is a complicated and "
@@ -3224,43 +2589,24 @@
 "the SchemaExport tool."
 msgstr ""
 "O atributo <literal>property-ref</literal> deve apenas ser usado para mapear "
-"dados legados onde uma chave estrangeira se referencia a uma chave exclusiva "
-"da tabela associada que não seja à chave primária. Este é um modelo "
-"relacional desagradável. Por exemplo, suponha que a classe <literal>Product</"
-"literal> tenha um número seqüencial exclusivo, que não é a chave primária. "
-"(O atributo <literal>unique</literal> controla a geração de DDL do Hibernate "
-"com a ferramenta SchemaExport.)"
+"dados legados onde uma chave exterior se refere à uma chave exclusiva da "
+"tabela associada que não seja a chave primária. Este é um modelo relacional "
+"desagradável. Por exemplo, suponha que a classe <literal>Product</literal> "
+"tenha um número seqüencial exclusivo, que não seja a chave primária. O "
+"atributo <literal>unique</literal> controla a geração de DDL do Hibernate "
+"com a ferramenta SchemaExport."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1647
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"serialNumber\" unique=\"true\" type=\"string\" "
-"column=\"SERIAL_NUMBER\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1649
 #, no-c-format
 msgid "Then the mapping for <literal>OrderItem</literal> might use:"
 msgstr "Então o mapeamento para <literal>OrderItem</literal> poderia usar:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1653
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"product\" property-ref=\"serialNumber\" column="
-"\"PRODUCT_SERIAL_NUMBER\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1655
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This is not encouraged, however."
-msgstr "Porém, isto obviamente não é indicado, nunca."
+msgstr "No entanto, isto não é recomendável."
 
 #. Tag: para
-#: basic_mapping.xml:1659
 #, no-c-format
 msgid ""
 "If the referenced unique key comprises multiple properties of the associated "
@@ -3272,31 +2618,20 @@
 "elemento chamado <literal>&lt;properties&gt;</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:1664
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the referenced unique key is the property of a component, you can specify "
 "a property path:"
 msgstr ""
 "Se a chave exclusiva referenciada é a propriedade de um componente, você "
-"pode especificar um caminho para a propriedade."
+"pode especificar um caminho para a propriedade:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1668
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"owner\" property-ref=\"identity.ssn\" column="
-"\"OWNER_SSN\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:1673
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "One-to-one"
-msgstr "one-to-one (um-pra-um)"
+msgstr "Um-para-um "
 
 #. Tag: para
-#: basic_mapping.xml:1675
 #, no-c-format
 msgid ""
 "A one-to-one association to another persistent class is declared using a "
@@ -3305,31 +2640,9 @@
 "Uma associação um-pra-um para outra classe persistente é declarada usando um "
 "elemento <literal>one-to-one </literal>."
 
-#. Tag: programlisting
-#: basic_mapping.xml:1693
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<one-to-one\n"
-"        name=\"propertyName\"\n"
-"        class=\"ClassName\"\n"
-"        cascade=\"cascade_style\"\n"
-"        constrained=\"true|false\"\n"
-"        fetch=\"join|select\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        formula=\"any SQL expression\"\n"
-"        lazy=\"proxy|no-proxy|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        embed-xml=\"true|false\"\n"
-"        foreign-key=\"foreign_key_name\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1713
-#, fuzzy, no-c-format
-msgid ""
 "<literal>constrained</literal> (optional): specifies that a foreign key "
 "constraint on the primary key of the mapped table and references the table "
 "of the associated class. This option affects the order in which <literal>save"
@@ -3337,28 +2650,25 @@
 "whether the association can be proxied. It is also used by the schema export "
 "tool."
 msgstr ""
-"<literal>constrained</literal> (opcional): Especifica que uma chave "
-"estrangeira constraint na chave primária da tabela mapeada referencia a "
-"tabela da classe associada, Esta opção afeta a ordem em queh <literal>save()"
-"</literal> e <literal>delete()</literal> são cascateadas, e determina se a "
-"associação pode ser substituída (isto também é usado pela ferramenta schema "
-"export)."
+"<literal>constrained</literal> (opcional): Especifica que uma restrição de "
+"chave exterior na chave primária da tabela mapeada referencia a tabela da "
+"classe associada. Esta opção afeta a ordem em que <literal>save()</literal> "
+"e <literal>delete()</literal> são cascateadas, e determina se a associação "
+"pode sofrer o proxie. Isto também é usado pela ferramenta schema export. "
 
 #. Tag: para
-#: basic_mapping.xml:1728
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): the name of a property of the "
 "associated class that is joined to the primary key of this class. If not "
 "specified, the primary key of the associated class is used."
 msgstr ""
 "<literal>property-ref</literal>(opcional): O nome da propriedade da classe "
-"associada que é ligada a chave primária desta classe. Se não for "
-"especificada, a chave primária da classe associada é utilizada."
+"associada que é ligada à chave primária desta classe. Se não for "
+"especificada, a chave primária da classe associada é utilizada. "
 
 #. Tag: para
-#: basic_mapping.xml:1741
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): almost all one-to-one associations "
 "map to the primary key of the owning entity. If this is not the case, you "
@@ -3367,14 +2677,13 @@
 "example."
 msgstr ""
 "<literal>formula</literal> (opcional): Quase todas associações um-pra-um "
-"mapeiam para a chave primária da entidade dona. No caso raro, que não é o "
-"caso, você pode especificar uma outra coluna, colunas ou expressões para "
-"juntar utilizando uma formula SQL. (Veja <literal>org.hibernate.test."
-"onetooneformula</literal> para exemplo)."
+"mapeiam para a chave primária da entidade dona. Caso este não seja o caso, "
+"você pode especificar uma outra coluna, colunas ou expressões para unir "
+"utilizando uma fórmula SQL. Veja <literal>org.hibernate.test."
+"onetooneformula</literal> para exemplo. "
 
 #. Tag: para
-#: basic_mapping.xml:1749
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>proxy</literal>): "
 "by default, single point associations are proxied. <literal>lazy=\"no-proxy"
@@ -3385,173 +2694,105 @@
 "<literal>constrained=\"false\"</literal>, proxying is impossible and "
 "Hibernate will eagerly fetch the association</emphasis>."
 msgstr ""
-"<literal>lazy</literal> (opcional – valor default <literal>proxy</literal>): "
-"Por default, associações single point são proxied. <literal>lazy=\"no-proxy"
-"\"</literal> especifica que a propriedade deve ser fetched lazily quando o "
-"atributo é acessado pela primeira vez (requer build-time bytecode "
-"instrumentation). <literal>lazy=\"false\"</literal> especifica que a "
-"associação vai sempre ser avidamente fetched. <emphasis>Note que se "
-"<literal>constrained=\"false\"</literal>, proxing é impossível e o Hibernate "
-"vai ávido fetch a associação!</emphasis>"
+"<literal>lazy</literal> (opcional – valor padrão <literal>proxy</literal>): "
+"Por padrão, as associações de ponto único estão em proxy. <literal>lazy=\"no-"
+"proxy\"</literal> especifica que a propriedade deve ser recuperada de forma "
+"preguiçosa quando a variável da instância for acessada pela primeira vez. "
+"Isto requer instrumentação de bytecode de tempo de construção. <literal>lazy="
+"\"false\"</literal> especifica que a associação terá sempre uma busca "
+"antecipada (eager fetched). <emphasis> Note que se <literal>constrained="
+"\"false\"</literal>, será impossível efetuar o proxing e o Hibernate irá "
+"realizar uma busca antecipada na associação</emphasis>."
 
 #. Tag: para
-#: basic_mapping.xml:1767
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "There are two varieties of one-to-one associations:"
-msgstr "Existem duas variedades de associações um-pra-um:"
+msgstr "Existem duas variedades de associações um-pra-um: "
 
 #. Tag: para
-#: basic_mapping.xml:1771
 #, no-c-format
 msgid "primary key associations"
-msgstr "associações de chave primária"
+msgstr "Associações de chave primária"
 
 #. Tag: para
-#: basic_mapping.xml:1774
 #, no-c-format
 msgid "unique foreign key associations"
-msgstr "associações de chave estrangeira exclusiva"
+msgstr "Associações de chave exterior exclusiva"
 
 #. Tag: para
-#: basic_mapping.xml:1779
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Primary key associations do not need an extra table column. If two rows are "
 "related by the association, then the two table rows share the same primary "
 "key value. To relate two objects by a primary key association, ensure that "
 "they are assigned the same identifier value."
 msgstr ""
-"Associações de chave primária não necessitam de uma coluna extra de tabela; "
-"se duas linhas são relacionadas pela associação então as duas linhas da "
-"tabela dividem a mesmo valor da chave primária. Assim, se você quer que dois "
-"objetos sejam relacionados por uma associação de chave primária, você deve "
-"ter certeza que eles são assinados com o mesmo valor identificador!"
+"Associações de chave primária não necessitam de uma coluna extra de tabela. "
+"Se duas linhas forem relacionadas pela associação, então as duas linhas da "
+"tabela dividem o mesmo valor da chave primária. Assim, se você quiser que "
+"dois objetos sejam relacionados por uma associação de chave primária, você "
+"deve ter certeza que foram atribuídos com o mesmo valor identificador."
 
 #. Tag: para
-#: basic_mapping.xml:1786
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For a primary key association, add the following mappings to "
 "<literal>Employee</literal> and <literal>Person</literal> respectively:"
 msgstr ""
 "Para uma associação de chave primária, adicione os seguintes mapeamentos em "
-"<literal>Employee</literal> e <literal>Person</literal>, respectivamente."
+"<literal>Employee</literal> e <literal>Person</literal>, respectivamente:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1791
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[<one-to-one name=\"person\" class=\"Person\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:1792
-#, no-c-format
 msgid ""
-"<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" constrained=\"true"
-"\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1794
-#, fuzzy, no-c-format
-msgid ""
 "Ensure that the primary keys of the related rows in the PERSON and EMPLOYEE "
 "tables are equal. You use a special Hibernate identifier generation strategy "
 "called <literal>foreign</literal>:"
 msgstr ""
-"Agora nós devemos assegurar que as chaves primárias de linhas relacionadas "
-"nas tabelas PERSON e EMPLOYEE são iguais. Nós usamos uma estratégia especial "
-"de geração de identificador do Hibernate chamada <literal>foreign</literal>:"
+"Agora devemos assegurar que as chaves primárias de linhas relacionadas nas "
+"tabelas PERSON e EMPLOYEE são iguais. Nós usamos uma estratégia especial de "
+"geração de identificador do Hibernate chamada <literal>foreign</literal>:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1800
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"person\" table=\"PERSON\">\n"
-"    <id name=\"id\" column=\"PERSON_ID\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">employee</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    ...\n"
-"    <one-to-one name=\"employee\"\n"
-"        class=\"Employee\"\n"
-"        constrained=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1802
-#, fuzzy, no-c-format
-msgid ""
 "A newly saved instance of <literal>Person</literal> is assigned the same "
 "primary key value as the <literal>Employee</literal> instance referred with "
 "the <literal>employee</literal> property of that <literal>Person</literal>."
 msgstr ""
-"Uma nova instância de <literal>Person</literal> salva recentemente é então "
-"assinada com o mesmo valor da chave primária da instância de "
-"<literal>employee</literal> referenciada com a propriedade "
-"<literal>employee</literal> daquela <literal>Person</literal>."
+"Uma nova instância de <literal>Person</literal> é atribuída com o mesmo "
+"valor da chave primária da instância de <literal>Employee</literal> "
+"referenciada com a propriedade <literal>employee</literal> daquela "
+"<literal>Person</literal>."
 
 #. Tag: para
-#: basic_mapping.xml:1808
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, a foreign key with a unique constraint, from "
 "<literal>Employee</literal> to <literal>Person</literal>, can be expressed "
 "as:"
 msgstr ""
-"Alternativamente, uma chave estrangeira com uma unique constraint, de "
+"Alternativamente, uma chave exterior com uma restrição única, de "
 "<literal>Employee</literal> para <literal>Person</literal>, pode ser "
-"expressa como:"
+"expressada como:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1813
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"person\" class=\"Person\" column=\"PERSON_ID\" "
-"unique=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1815
-#, fuzzy, no-c-format
-msgid ""
 "This association can be made bidirectional by adding the following to the "
 "<literal>Person</literal> mapping:"
 msgstr ""
-"E esta associação pode ser feita de forma bi-direcional adicionando o "
-"seguinte no mapeamento de <literal>Person</literal>:"
+"Esta associação pode ser feita de forma bi-direcional adicionando o seguinte "
+"no mapeamento de <literal>Person</literal>:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1820
-#, no-c-format
-msgid ""
-"<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" property-ref="
-"\"person\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:1825
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Natural-id"
-msgstr "natural-id"
+msgstr "Id Natural"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1827
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<natural-id mutable=\"true|false\"/>\n"
-"        <property ... />\n"
-"        <many-to-one ... />\n"
-"        ......\n"
-"</natural-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1829
-#, fuzzy, no-c-format
-msgid ""
 "Although we recommend the use of surrogate keys as primary keys, you should "
 "try to identify natural keys for all entities. A natural key is a property "
 "or combination of properties that is unique and non-null. It is also "
@@ -3560,166 +2801,127 @@
 "unique key and nullability constraints and, as a result, your mapping will "
 "be more self-documenting."
 msgstr ""
-"Embora nós recomendemos o uso de surrogate keys como chaves primárias, você "
+"Embora recomendemos o uso das chaves substitutas como chaves primárias, você "
 "deve ainda identificar chaves naturais para todas as entidades. Uma chave "
 "natural é uma propriedade ou combinação de propriedades que é exclusiva e "
-"não nula. Se não pude ser modificada, melhor ainda. Mapeie as propriedades "
-"da chave natural dentro do elemento <literal>&lt;natural-id&gt;</literal>. O "
-"Hibernate irá gerar a chave exclusiva necessária e as constraints de "
-"nullability , e seu mapeamento será apropriadamente auto documentado."
+"não nula. Mapeie as propriedades da chave natural dentro do elemento "
+"<literal>&lt;natural-id&gt;</literal>. O Hibernate irá gerar a chave "
+"exclusiva necessária e as restrições de anulabilidade, e seu mapeamento será "
+"apropriadamente auto documentado."
 
 #. Tag: para
-#: basic_mapping.xml:1838
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you implement <literal>equals()</literal> and "
 "<literal>hashCode()</literal> to compare the natural key properties of the "
 "entity."
 msgstr ""
-"Nós recomendamos com enfase que você implemente <literal>equals()</literal> "
+"Nós recomendamos com ênfase que você implemente <literal>equals()</literal> "
 "e <literal>hashCode()</literal> para comparar as propriedades da chave "
-"natural da entidade."
+"natural da entidade. "
 
 #. Tag: para
-#: basic_mapping.xml:1843
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This mapping is not intended for use with entities that have natural primary "
 "keys."
 msgstr ""
-"Este mapeamento não tem o objetivo de uso com entidades com natural chaves "
+"Este mapeamento não pretende ser utilizado com entidades com chaves naturais "
 "primárias."
 
 #. Tag: para
-#: basic_mapping.xml:1849
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>false</"
 "literal>): by default, natural identifier properties are assumed to be "
 "immutable (constant)."
 msgstr ""
-"<literal>mutable</literal> mutable (opcional, valor default<literal>false</"
-"literal>): Por default, propriedades naturais identificadoras são "
-"consideradas imutáveis (constante)."
+"<literal>mutable</literal> (opcional, padrão <literal>false</literal>): Por "
+"padrão, propriedades naturais identificadoras são consideradas imutáveis "
+"(constante)."
 
 #. Tag: title
-#: basic_mapping.xml:1859
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Component and dynamic-component"
-msgstr "componente, componente dinâmico"
+msgstr "Componente e componente dinâmico"
 
 #. Tag: para
-#: basic_mapping.xml:1861
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element maps properties of a child "
 "object to columns of the table of a parent class. Components can, in turn, "
 "declare their own properties, components or collections. See the \"Component"
 "\" examples below:"
 msgstr ""
-"O elemento<literal>&lt;component&gt;</literal> mapeia propriedades de um "
-"objeto filho para colunas da tabela de uma classe pai. Componentes podem, um "
-"após o outro, declarar suas próprias propriedades, componentes ou coleções. "
-"Veja \"Components\" abaixo."
+"O elemento <literal>&lt;component&gt;</literal> mapeia propriedades de um "
+"objeto filho para colunas da tabela de uma classe pai. Os componentes podem, "
+"um após o outro, declarar suas próprias propriedades, componentes ou "
+"coleções. Veja \"Components\" abaixo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1879
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<component\n"
-"        name=\"propertyName\"\n"
-"        class=\"className\"\n"
-"        insert=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        lazy=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        node=\"element-name|.\"\n"
-">\n"
-"\n"
-"        <property ...../>\n"
-"        <many-to-one .... />\n"
-"        ........\n"
-"</component>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1887
-#, fuzzy, no-c-format
-msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
 "determined by reflection): the name of the component (child) class."
 msgstr ""
-"<literal>class</literal> (opcional – valor default para o tipo de "
-"propriedade determinada por reflection): O nome da classe (filha) do "
-"componente."
+"<literal>class</literal> (opcional – padrão para o tipo de propriedade "
+"determinada por reflection): O nome da classe (filha) do componente."
 
 #. Tag: para
-#: basic_mapping.xml:1893 basic_mapping.xml:1982
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>insert</literal>: do the mapped columns appear in SQL "
 "<literal>INSERTs</literal>?"
 msgstr ""
 "<literal>insert</literal>: As colunas mapeadas aparecem nos SQL de "
-"<literal>INSERT</literal>s?"
+"<literal>INSERTs</literal>? "
 
 #. Tag: para
-#: basic_mapping.xml:1899 basic_mapping.xml:1988
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update</literal>: do the mapped columns appear in SQL "
 "<literal>UPDATEs</literal>?"
 msgstr ""
 "<literal>update</literal>: As colunas mapeadas aparecem nos SQL de "
-"<literal>UPDATE</literal>s?"
+"<literal>UPDATEs</literal>? "
 
 #. Tag: para
-#: basic_mapping.xml:1911
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>false</literal>): "
 "specifies that this component should be fetched lazily when the instance "
 "variable is first accessed. It requires build-time bytecode instrumentation."
 msgstr ""
-"<literal>lazy</literal> (opcional - valor default <literal>false</literal>): "
-"Especifica que este componente deve ser fetched lazily quando o atributo for "
-"acessado pela primeira vez (requer build-time bytecode instrumentation)."
+"<literal>lazy</literal> (opcional - padrão para <literal>false</literal>): "
+"Especifica que este componente deve ter uma busca lazy quando a função for "
+"acessada pela primeira vez. Isto requer instrumentação bytecode de tempo de "
+"construção."
 
 #. Tag: para
-#: basic_mapping.xml:1918
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to this component either do or do not "
 "require acquisition of the optimistic lock. It determines if a version "
 "increment should occur when this property is dirty."
 msgstr ""
-"<literal>optimistic-lock</literal> (opcional – valor default <literal>true</"
+"<literal>optimistic-lock</literal> (opcional – padrão para <literal>true</"
 "literal>): Especifica que atualizações para este componente requerem ou não "
-"aquisição de um lock otimista. Em outras palavras, determina se uma versão "
-"de incremento deve ocorrer quando esta propriedade estiver modificada."
+"aquisição de um bloqueio otimista. Em outras palavras, determina se uma "
+"versão de incremento deve ocorrer quando esta propriedade estiver suja."
 
 #. Tag: para
-#: basic_mapping.xml:1926 basic_mapping.xml:2002
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional - defaults to <literal>false</literal>): "
 "specifies that a unique constraint exists upon all mapped columns of the "
 "component."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>unique</literal> (opcional – valor default <literal>false</"
-"literal>): Especifica que existe uma unique constraint em todas as colunas "
-"mapeadas do componente.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>unique</literal> (opcional – valor defautl <literal>false</"
-"literal>): Especifica que uma unique constraint existe em todas as colunas "
-"mapeadas do componente."
+"<literal>unique</literal> (opcional – valor padrão <literal>false</"
+"literal>): Especifica que existe uma unique restrição em todas as colunas "
+"mapeadas do componente. "
 
 #. Tag: para
-#: basic_mapping.xml:1935
 #, no-c-format
 msgid ""
 "The child <literal>&lt;property&gt;</literal> tags map properties of the "
@@ -3729,7 +2931,6 @@
 "mapeamento da classe filha para colunas de uma tabela."
 
 #. Tag: para
-#: basic_mapping.xml:1940
 #, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element allows a <literal>&lt;"
@@ -3741,28 +2942,25 @@
 "componente como uma referencia de volta para a entidade que o contém."
 
 #. Tag: para
-#: basic_mapping.xml:1946
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;dynamic-component&gt;</literal> element allows a "
 "<literal>Map</literal> to be mapped as a component, where the property names "
-"refer to keys of the map. See <xref linkend=\"components-dynamic\"/> for "
+"refer to keys of the map. See <xref linkend=\"components-dynamic\" /> for "
 "more information."
 msgstr ""
 "O elemento <literal>&lt;dynamic-component&gt;</literal> permite que um "
 "<literal>Map</literal> possa ser mapeado como um componente onde os nomes "
-"das propriedades referem-se para as chaves no mapa, veja <xref linkend="
-"\"components-dynamic\"/>."
+"das propriedades referem-se para as chaves no mapa. Consulte <xref linkend="
+"\"components-dynamic\"/> para maiores informações."
 
 #. Tag: title
-#: basic_mapping.xml:1955
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Properties"
-msgstr "propriedades"
+msgstr "Propriedades"
 
 #. Tag: para
-#: basic_mapping.xml:1957
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;properties&gt;</literal> element allows the definition of a "
 "named, logical grouping of the properties of a class. The most important use "
@@ -3771,222 +2969,117 @@
 "define a multi-column unique constraint. For example:"
 msgstr ""
 "O elemento <literal>&lt;properties&gt;</literal> permite a definição de um "
-"grupo com nome, lógico de propriedades de uma classe. O uso mais importante "
-"do construtor é que este permite uma combinação de propriedades para ser o "
-"objetivo de uma <literal>property-ref</literal>. É também um modo "
-"conveninente para definir uma unique constraint de múltiplas colunas."
+"grupo com nome, lógico de propriedades de uma classe. A função mais "
+"importante do construtor é que ele permite que a combinação de propriedades "
+"seja o objetivo de uma <literal>property-ref</literal>. É também um modo "
+"conveninente para definir uma restrição única de múltiplas colunas. Por "
+"exemplo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1973
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<properties\n"
-"        name=\"logicalName\"\n"
-"        insert=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-">\n"
-"\n"
-"        <property ...../>\n"
-"        <many-to-one .... />\n"
-"        ........\n"
-"</properties>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1976
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal>: the logical name of the grouping. It is "
 "<emphasis>not</emphasis> an actual property name."
 msgstr ""
-"<literal>name</literal>:: O nome lógico do agrupamento – <emphasis>não </"
+"<literal>name</literal>: O nome lógico do agrupamento. Isto <emphasis>não</"
 "emphasis> é o nome atual de propriedade."
 
 #. Tag: para
-#: basic_mapping.xml:1994
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to these properties either do or do not "
 "require acquisition of the optimistic lock. It determines if a version "
 "increment should occur when these properties are dirty."
 msgstr ""
-"<literal>optimistic-lock</literal> (opcional – valor default <literal>true</"
+"<literal>optimistic-lock</literal> (opcional – padrão para <literal>true</"
 "literal>): Especifica que atualizações para estes componentes requerem ou "
-"não aquisição de um lock otimista. Em outras palavras, determina se uma "
-"versão de incremento deve ocorrer quando estas propriedades estiverem "
-"modificadas."
+"não aquisição de um bloqueio otimista. Em outras palavras, determina se uma "
+"versão de incremento deve ocorrer quando estas propriedades estiverem sujas."
 
 #. Tag: para
-#: basic_mapping.xml:2011
 #, no-c-format
 msgid ""
 "For example, if we have the following <literal>&lt;properties&gt;</literal> "
 "mapping:"
 msgstr ""
-"Por exemplo, se nós temos o seguinte mapeamento de <literal>&lt;"
-"properties&gt;</literal>:"
+"Por exemplo, se temos o seguinte mapeamento de <literal>&lt;properties&gt;</"
+"literal>:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2015
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"personNumber\"/>\n"
-"\n"
-"    ...\n"
-"    <properties name=\"name\"\n"
-"            unique=\"true\" update=\"false\">\n"
-"        <property name=\"firstName\"/>\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"lastName\"/>\n"
-"    </properties>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2017
-#, fuzzy, no-c-format
-msgid ""
 "You might have some legacy data association that refers to this unique key "
 "of the <literal>Person</literal> table, instead of to the primary key:"
 msgstr ""
-"Então nós podemos ter uma associação de dados herdados que referem a esta "
-"chave exclusiva da tabela <literal>Person</literal>, ao invés de se "
-"referirem a chave primária:"
+"Então podemos ter uma associação de dados legados que referem a esta chave "
+"exclusiva da tabela <literal>Person</literal>, ao invés de se referirem a "
+"chave primária:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2022
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"person\"\n"
-"         class=\"Person\" property-ref=\"name\">\n"
-"    <column name=\"firstName\"/>\n"
-"    <column name=\"initial\"/>\n"
-"    <column name=\"lastName\"/>\n"
-"</many-to-one>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2024
-#, fuzzy, no-c-format
-msgid ""
 "The use of this outside the context of mapping legacy data is not "
 "recommended."
 msgstr ""
 "Nós não recomendamos o uso deste tipo de coisa fora do contexto de "
-"mapeamento de dados herdados."
+"mapeamento de dados legados."
 
 #. Tag: title
-#: basic_mapping.xml:2032
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Subclass"
-msgstr "subclass (subclasse)"
+msgstr "Subclass"
 
 #. Tag: para
-#: basic_mapping.xml:2034
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Polymorphic persistence requires the declaration of each subclass of the "
 "root persistent class. For the table-per-class-hierarchy mapping strategy, "
 "the <literal>&lt;subclass&gt;</literal> declaration is used. For example:"
 msgstr ""
 "Finalmente, a persistência polimórfica requer a declaração de cada subclasse "
-"da classe de persistência raiz. Para a estratégia de mapeamento table-per-"
-"class-hierarchy, a declaração <literal>&lt;subclass&gt;</literal> deve ser "
-"usada."
+"da classe raíz de persistência. Para a estratégia de mapeamento tabela-por-"
+"hierarquia-de-classe, deve-se utilizar a declaração <literal>&lt;subclass&gt;"
+"</literal>. Por exemplo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2047
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<subclass\n"
-"        name=\"ClassName\"\n"
-"        discriminator-value=\"discriminator_value\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\"\n"
-"        extends=\"SuperclassName\">\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</subclass>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2050 basic_mapping.xml:2108 basic_mapping.xml:2171
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal>: the fully qualified class name of the subclass."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>name</literal>: O nome de classe completamente qualificada da "
-"subclasse.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>name</literal>: O nome da classe completamente qualificada da "
-"subclasse.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>name</literal>: O nome da subclasse completamente qualificada."
+"subclasse. "
 
 #. Tag: para
-#: basic_mapping.xml:2055
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>discriminator-value</literal> (optional - defaults to the class "
 "name): a value that distinguishes individual subclasses."
 msgstr ""
-"<literal>discriminator-value</literal> (opcional – valor default o nome da "
+"<literal>discriminator-value</literal> (opcional – padrão para o nome da "
 "classe): Um valor que distingue subclasses individuais."
 
 #. Tag: para
-#: basic_mapping.xml:2061
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies a class or interface used for "
 "lazy initializing proxies."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>proxy</literal> (opcional): Especifica a classe ou interface que "
-"usará os proxies de inicialização atrasada.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal> (opcional): Especifica a classe ou interface para "
-"usar os proxies de recuperação atrasada.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal> (optional): Specifies a class or interface to use "
-"for lazy initializing proxies. <literal>proxy</literal> (opcional): "
-"Especifica a classe ou interface para usar os proxies de recuperação "
-"atrasada."
+"usará os proxies de inicialização lazy."
 
 #. Tag: para
-#: basic_mapping.xml:2067
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>true</literal>): "
 "setting <literal>lazy=\"false\"</literal> disables the use of lazy fetching."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (opcional, valor default <literal>true</literal>): "
+"<literal>lazy</literal> (opcional, padrão para <literal>true</literal>): "
 "Configurar <literal>lazy=\"false\"</literal> desabilitará o uso de "
-"inicialização atrasada.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (opcional, valor default <literal>true</literal>): "
-"Fixanr <literal>lazy=\"false\"</literal> desabilita o uso recuperação "
-"atrasada.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (optional, defaults to <literal>true</literal>): "
-"Setting <literal>lazy=\"false\"</literal> disables the use of lazy fetching. "
-"<literal>lazy</literal> (opcional, valor default p<literal>true</literal>): "
-"Fixando <literal>lazy=\"false\"</literal> desabilita o uso da recuperação "
-"atrasada."
+"inicialização lazy."
 
 #. Tag: para
-#: basic_mapping.xml:2075
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Each subclass declares its own persistent properties and subclasses. "
 "<literal>&lt;version&gt;</literal> and <literal>&lt;id&gt;</literal> "
@@ -3996,182 +3089,82 @@
 msgstr ""
 "Cada subclasse deve declarar suas próprias propriedades persistentes e "
 "subclasses. As propriedades <literal>&lt;version&gt;</literal> e "
-"<literal>&lt;id&gt;</literal> são configuradas para serem herdades da classe "
-"raiz. Cada subclasse numa hierarquia deve definir um único "
-"<literal>discriminator-value</literal>. Se nenhum for especificado, o nome "
-"da classe Java completamente qualificada será usada."
+"<literal>&lt;id&gt;</literal> são configuradas para serem herdadas da classe "
+"raíz. Cada subclasse numa hierarquia deve definir um único "
+"<literal>discriminator-value</literal>. Se nenhum for especificado, será "
+"usado o nome da classe Java completamente qualificado."
 
 #. Tag: para
-#: basic_mapping.xml:2083 basic_mapping.xml:2141 basic_mapping.xml:2199
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"For information about inheritance mappings see <xref linkend=\"inheritance\"/"
-">."
+"For information about inheritance mappings see <xref linkend=\"inheritance"
+"\" />."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Para informações sobre mapeamento de heranças, veja o <xref linkend="
-"\"inheritance\"/>.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Para informações de mapeamentos de herança, veja <xref linkend=\"inheritance"
-"\"/>.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Para informações sobre mapeamentos de herança, veja <xref linkend="
-"\"inheritance\"/>."
+"Para informações sobre mapeamento de heranças. Consulte o <xref linkend="
+"\"inheritance\" />."
 
 #. Tag: title
-#: basic_mapping.xml:2090
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Joined-subclass"
-msgstr "joined-subclass"
+msgstr "Subclasses Unidas "
 
 #. Tag: para
-#: basic_mapping.xml:2092
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Each subclass can also be mapped to its own table. This is called the table-"
 "per-subclass mapping strategy. An inherited state is retrieved by joining "
 "with the table of the superclass. To do this you use the <literal>&lt;joined-"
 "subclass&gt;</literal> element. For example:"
 msgstr ""
-"Alternativamente, cada subclasse pode ser mapeada para sua própria tabela "
-"(Estratégia de mapeamento table-per-subclass). O estado herdado é devolvido "
-"por associação com a tabela da superclasse. Nós usamos o elemento "
-"<literal>&lt;joined-subclass&gt;</literal>."
+"Alternativamente, cada subclasse pode ser mapeada para sua própria tabela. "
+"Isto é chamado estratégia de mapeamento de tabela-por-subclasse. O estado "
+"herdado é devolvido por associação com a tabela da superclasse. Nós usamos o "
+"elemento <literal>&lt;joined-subclass&gt;</literal>. Por exemplo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2105
-#, no-c-format
-msgid ""
-"<![CDATA[<joined-subclass\n"
-"        name=\"ClassName\"\n"
-"        table=\"tablename\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        schema=\"schema\"\n"
-"        catalog=\"catalog\"\n"
-"        extends=\"SuperclassName\"\n"
-"        persister=\"ClassName\"\n"
-"        subselect=\"SQL expression\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\">\n"
-"\n"
-"        <key .... >\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</joined-subclass>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2113 basic_mapping.xml:2176
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>table</literal>: the name of the subclass table."
-msgstr "<literal>table</literal>: O nome da tabela da subclasse."
+msgstr "<literal>table</literal>: O nome da tabela da subclasse. "
 
 #. Tag: para
-#: basic_mapping.xml:2118 basic_mapping.xml:2181
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies a class or interface to use "
 "for lazy initializing proxies."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
 "<literal>proxy</literal> (opcional): Especifica a classe ou interface que "
-"usará os proxies de inicialização atrasada.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal> (opcional): Especifica a classe ou interface para "
-"usar os proxies de recuperação atrasada.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal> (optional): Specifies a class or interface to use "
-"for lazy initializing proxies. <literal>proxy</literal> (opcional): "
-"Especifica a classe ou interface para usar os proxies de recuperação "
-"atrasada."
+"usará os proxies de inicialização lazy. "
 
 #. Tag: para
-#: basic_mapping.xml:2124 basic_mapping.xml:2187
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional, defaults to <literal>true</literal>): "
 "setting <literal>lazy=\"false\"</literal> disables the use of lazy fetching."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (opcional, valor default <literal>true</literal>): "
+"<literal>lazy</literal> (opcional, padrão para <literal>true</literal>): "
 "Configurar <literal>lazy=\"false\"</literal> desabilitará o uso de "
-"inicialização atrasada.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (opcional, valor default <literal>true</literal>): "
-"Fixanr <literal>lazy=\"false\"</literal> desabilita o uso recuperação "
-"atrasada.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (optional, defaults to <literal>true</literal>): "
-"Setting <literal>lazy=\"false\"</literal> disables the use of lazy fetching. "
-"<literal>lazy</literal> (opcional, valor default p<literal>true</literal>): "
-"Fixando <literal>lazy=\"false\"</literal> desabilita o uso da recuperação "
-"atrasada."
+"inicialização lazy."
 
 #. Tag: para
-#: basic_mapping.xml:2132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A discriminator column is not required for this mapping strategy. Each "
 "subclass must, however, declare a table column holding the object identifier "
 "using the <literal>&lt;key&gt;</literal> element. The mapping at the start "
 "of the chapter would then be re-written as:"
 msgstr ""
-"A coluna discriminator requerida para esta estratégia de mapeamento. Porém, "
-"cada subclasse deve declarar uma coluna de tabela com o identificador do "
+"A coluna discriminadora não é requerida para esta estratégia de mapeamento. "
+"Cada subclasse deve declarar uma coluna de tabela com o identificador do "
 "objeto usando o elemento <literal>&lt;key&gt;</literal>. O mapeamento no "
-"início do capítulo poderia ser re-escrito assim:"
+"início do capítulo poderia ser re-escrito assim: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2139
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"        <class name=\"Cat\" table=\"CATS\">\n"
-"                <id name=\"id\" column=\"uid\" type=\"long\">\n"
-"                        <generator class=\"hilo\"/>\n"
-"                </id>\n"
-"                <property name=\"birthdate\" type=\"date\"/>\n"
-"                <property name=\"color\" not-null=\"true\"/>\n"
-"                <property name=\"sex\" not-null=\"true\"/>\n"
-"                <property name=\"weight\"/>\n"
-"                <many-to-one name=\"mate\"/>\n"
-"                <set name=\"kittens\">\n"
-"                        <key column=\"MOTHER\"/>\n"
-"                        <one-to-many class=\"Cat\"/>\n"
-"                </set>\n"
-"                <joined-subclass name=\"DomesticCat\" table=\"DOMESTIC_CATS"
-"\">\n"
-"                    <key column=\"CAT\"/>\n"
-"                    <property name=\"name\" type=\"string\"/>\n"
-"                </joined-subclass>\n"
-"        </class>\n"
-"\n"
-"        <class name=\"eg.Dog\">\n"
-"                <!-- mapping for Dog could go here -->\n"
-"        </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:2148
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Union-subclass"
-msgstr "union-subclass"
+msgstr "Subclasse de União"
 
 #. Tag: para
-#: basic_mapping.xml:2150
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A third option is to map only the concrete classes of an inheritance "
 "hierarchy to tables. This is called the table-per-concrete-class strategy. "
@@ -4183,94 +3176,46 @@
 "need to use the <literal>&lt;union-subclass&gt;</literal> mapping. For "
 "example:"
 msgstr ""
-"Uma terceira opção é mapear para tabelas apenas as classes concretas de uma "
-"hierarquia de heranças, (a estratégia table-per-concrete-class) onde cada "
-"tabela define todos os estados persistentes da classe, incluindo estados "
-"herdados. No Hibernate, não é absolutamente necessário mapear explicitamente "
-"como hierarquia de heranças. Você pode simplesmente mapear cada classe com "
-"uma declaração <literal>&lt;class&gt;</literal> separada. Porém, se você "
-"deseja usar associações polimórficas (por exemplo: uma associação para a "
-"superclasse de sua hierarquia), você precisa usar o mapeamento <literal>&lt;"
-"union-subclass&gt;</literal>."
+"Uma terceira opção é mapear apenas as classes concretas de uma hierarquia de "
+"heranças para tabelas. Isto é chamado estratégia table-per-concrete-class. "
+"Cada tabela define todos os estados persistentes da classe, incluindo "
+"estados herdados. No Hibernate, não é absolutamente necessário mapear "
+"explicitamente como hierarquia de heranças. Você pode simplesmente mapear "
+"cada classe com uma declaração <literal>&lt;class&gt;</literal> separada. "
+"Porém, se você deseja usar associações polimórficas (por exemplo: uma "
+"associação para a superclasse de sua hierarquia), você precisa usar o "
+"mapeamento <literal>&lt;union-subclass&gt;</literal>. Por exemplo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2168
-#, no-c-format
-msgid ""
-"<![CDATA[<union-subclass\n"
-"        name=\"ClassName\"\n"
-"        table=\"tablename\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        schema=\"schema\"\n"
-"        catalog=\"catalog\"\n"
-"        extends=\"SuperclassName\"\n"
-"        abstract=\"true|false\"\n"
-"        persister=\"ClassName\"\n"
-"        subselect=\"SQL expression\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\">\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</union-subclass>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2195
 #, no-c-format
 msgid ""
 "No discriminator column or key column is required for this mapping strategy."
 msgstr ""
-"A coluna discriminatõria não é requerida para esta estratégia de mapeamento."
+"A coluna discriminatória não é requerida para esta estratégia de mapeamento."
 
 #. Tag: title
-#: basic_mapping.xml:2206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Join"
-msgstr "join"
+msgstr "União "
 
 #. Tag: para
-#: basic_mapping.xml:2208
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Using the <literal>&lt;join&gt;</literal> element, it is possible to map "
 "properties of one class to several tables that have a one-to-one "
 "relationship. For example:"
 msgstr ""
 "Usando o elemento <literal>&lt;join&gt;</literal>&gt;, é possível mapear "
-"propriedades de uma classe para várias tabelas."
+"propriedades de uma classe para várias tabelas que possuem uma relação um "
+"por um. Por exemplo:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2222
-#, no-c-format
-msgid ""
-"<![CDATA[<join\n"
-"        table=\"tablename\"\n"
-"        schema=\"owner\"\n"
-"        catalog=\"catalog\"\n"
-"        fetch=\"join|select\"\n"
-"        inverse=\"true|false\"\n"
-"        optional=\"true|false\">\n"
-"\n"
-"        <key ... />\n"
-"\n"
-"        <property ... />\n"
-"        ...\n"
-"</join>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2226
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>table</literal>: the name of the joined table."
-msgstr "<literal>table</literal>: O nome da tabela associada."
+msgstr "<literal>table</literal>: O nome da tabela associada. "
 
 #. Tag: para
-#: basic_mapping.xml:2243
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional - defaults to <literal>join</literal>): "
 "if set to <literal>join</literal>, the default, Hibernate will use an inner "
@@ -4282,185 +3227,139 @@
 "instance of the subclass. Inner joins will still be used to retrieve a "
 "<literal>&lt;join&gt;</literal> defined by the class and its superclasses."
 msgstr ""
-"<literal>fetch</literal>(opcional – valor default <literal>join</literal>): "
-"Se setado para <literal>join</literal>, o padrão, o Hibernate irá usar um "
-"inner join para restaurar um <literal>join</literal> definido por uma classe "
-"ou suas subclasses e uma outer join para um <literal>join</literal> definido "
-"por uma subclasse. Se setado para <literal>select</literal>, então o "
-"Hibernate irá usar uma seleção seqüencial para um <literal>&lt;join&gt;</"
-"literal> definida numa subclasse, que irá ser emitido apenas se uma linha se "
-"concentrar para representar uma instância da subclasse. Inner joins irá "
-"ainda ser usado para restaurar um <literal>&lt;join&gt;</literal> definido "
-"pela classe e suas superclasses."
+"<literal>fetch</literal>(opcional – valor padrão <literal>join</literal>): "
+"Se ajustado para <literal>join</literal>, o padrão, o Hibernate irá usar uma "
+"união interna para restaurar um <literal>join</literal> definido por uma "
+"classe ou suas subclasses e uma união externa para um <literal>join</"
+"literal> definido por uma subclasse. Se ajustado para <literal>select</"
+"literal>, então o Hibernate irá usar uma seleção seqüencial para um "
+"<literal>&lt;join&gt;</literal> definida numa subclasse, que será emitido "
+"apenas se uma linha representar uma instância da subclasse. Uniões internas "
+"ainda serão utilizadas para restaurar um <literal>&lt;join&gt;</literal> "
+"definido pela classe e suas superclasses. "
 
 #. Tag: para
-#: basic_mapping.xml:2256
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>inverse</literal> (optional - defaults to <literal>false</"
 "literal>): if enabled, Hibernate will not insert or update the properties "
 "defined by this join."
 msgstr ""
-"<literal>inverse</literal> (opcional – valor default <literal>false</"
-"literal>): Se habilitado, o Hibernate não irá tentar inserir ou atualizar as "
-"propriedades definidas por este join."
+"<literal>inverse</literal> (opcional – padrão para <literal>false</"
+"literal>): Se habilitado, o Hibernate não tentará inserir ou atualizar as "
+"propriedades definidas por esta união."
 
 #. Tag: para
-#: basic_mapping.xml:2263
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optional</literal> (optional - defaults to <literal>false</"
 "literal>): if enabled, Hibernate will insert a row only if the properties "
 "defined by this join are non-null. It will always use an outer join to "
 "retrieve the properties."
 msgstr ""
-"<literal>optional</literal> (opcional – valor default <literal>false</"
+"<literal>optional</literal> (opcional – padrão para <literal>false</"
 "literal>): Se habilitado, o Hibernate irá inserir uma linha apenas se as "
-"propriedades definidas por esta junção não forem nulas e irá sempre usar uma "
-"outer join para recuperar as propriedades."
+"propriedades, definidas por esta junção, não forem nulas. Isto irá sempre "
+"usar uma união externa para recuperar as propriedades."
 
 #. Tag: para
-#: basic_mapping.xml:2272
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For example, address information for a person can be mapped to a separate "
 "table while preserving value type semantics for all properties:"
 msgstr ""
 "Por exemplo, a informação de endereço para uma pessoa pode ser mapeada para "
-"uma tabela separada (enquanto preservando o valor da semântica de tipos para "
-"todas as propriedades):"
+"uma tabela separada, enquanto preservando o valor da semântica de tipos para "
+"todas as propriedades:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2277
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\"\n"
-"    table=\"PERSON\">\n"
-"\n"
-"    <id name=\"id\" column=\"PERSON_ID\">...</id>\n"
-"\n"
-"    <join table=\"ADDRESS\">\n"
-"        <key column=\"ADDRESS_ID\"/>\n"
-"        <property name=\"address\"/>\n"
-"        <property name=\"zip\"/>\n"
-"        <property name=\"country\"/>\n"
-"    </join>\n"
-"    ...]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2279
-#, fuzzy, no-c-format
-msgid ""
 "This feature is often only useful for legacy data models. We recommend fewer "
 "tables than classes and a fine-grained domain model. However, it is useful "
 "for switching between inheritance mapping strategies in a single hierarchy, "
 "as explained later."
 msgstr ""
-"Esta característica é útil apenas para modelos de dados legados, nós "
-"recomendamos menos tabelas do que classes e um modelo de domínio bem "
-"granulado. Porém, é útil para ficar trocando entre estratégias de mapeamento "
-"de herança numa hierarquia simples, como explicado mais a frente."
+"Esta característica é útil apenas para modelos de dados legados. Nós "
+"recomendamos menos tabelas do que classes e um modelo de domínio fine-"
+"grained. Porém, é útil para ficar trocando entre estratégias de mapeamento "
+"de herança numa hierarquia simples, como explicaremos mais a frente."
 
 #. Tag: title
-#: basic_mapping.xml:2289
 #, no-c-format
-msgid "<title>Key</title>"
-msgstr ""
+msgid "Key"
+msgstr "Key"
 
 #. Tag: para
-#: basic_mapping.xml:2291
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;key&gt;</literal> element has featured a few times within "
 "this guide. It appears anywhere the parent mapping element defines a join to "
 "a new table that references the primary key of the original table. It also "
 "defines the foreign key in the joined table:"
 msgstr ""
-"Nós vimos que o elemento <literal>&lt;key&gt;</literal> surgiu algumas vezes "
-"até agora. Ele aparece em qualquer lugar que o elemento pai define uma "
-"junção para a nova tabela, e define a chave estrangeira para a tabela "
-"associada, que referencia a chave primária da tabela original."
+"Vimos que o elemento <literal>&lt;key&gt;</literal> (chave) surgiu algumas "
+"vezes até agora. Ele aparece em qualquer lugar que o elemento pai define uma "
+"junção para a nova tabela, e define a chave exterior para a tabela "
+"associada. Ele também referencia a chave primária da tabela original:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2307
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<key\n"
-"        column=\"columnname\"\n"
-"        on-delete=\"noaction|cascade\"\n"
-"        property-ref=\"propertyName\"\n"
-"        not-null=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2318
-#, fuzzy, no-c-format
-msgid ""
 "<literal>on-delete</literal> (optional - defaults to <literal>noaction</"
 "literal>): specifies whether the foreign key constraint has database-level "
 "cascade delete enabled."
 msgstr ""
-"<literal>on-delete</literal> (opcional, valor default <literal>noaction</"
-"literal>): Especifica se a constraint da chave estrangeira no banco de dados "
-"esta habilitada para cascade delete ."
+"<literal>on-delete</literal> (opcional, padrão para <literal>noaction</"
+"literal>): Especifica se a restrição da chave exterior no banco de dados "
+"está habilitada para o deletar cascade."
 
 #. Tag: para
-#: basic_mapping.xml:2325
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): specifies that the foreign key "
 "refers to columns that are not the primary key of the original table. It is "
 "provided for legacy data."
 msgstr ""
-"<literal>property-ref</literal> (opcional): Especifica que a chave "
-"estrangeira se refere a colunas que não são chave primária da tabela "
-"original. (Util para base de dados legadas.)"
+"<literal>property-ref</literal> (opcional): Especifica que a chave exterior "
+"se refere a colunas que não são chave primária da tabela original. Útil para "
+"os dados legados."
 
 #. Tag: para
-#: basic_mapping.xml:2332
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): specifies that the foreign key "
 "columns are not nullable. This is implied whenever the foreign key is also "
 "part of the primary key."
 msgstr ""
 "<literal>not-null</literal> (opcional): Especifica que a coluna da chave "
-"estrangeira não aceita valores nulos (isto é implícito em qualquer momento "
-"que a chave estrangeira também fizer parte da chave primária)."
+"exterior não aceita valores nulos. Isto é implícito em qualquer momento que "
+"a chave exterior também fizer parte da chave primária."
 
 #. Tag: para
-#: basic_mapping.xml:2339
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update</literal> (optional): specifies that the foreign key should "
 "never be updated. This is implied whenever the foreign key is also part of "
 "the primary key."
 msgstr ""
-"<literal>update</literal> (optional): Specifies that the foreign key should "
-"never be updated (this is implied whenever the foreign key is also part of "
-"the primary key). <literal>update</literal> (opcional): Especifica que a "
-"chave estrangeira nunca deve ser atualizada (isto é implícito em qualquer "
-"momento que a chave estrangeira também fizer parte da chave primária)."
+"<literal>update</literal> (opcional): Especifica que a chave exterior nunca "
+"deve ser atualizada. Isto está implícito em qualquer momento que a chave "
+"exterior também fizer parte da chave primária."
 
 #. Tag: para
-#: basic_mapping.xml:2346
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): specifies that the foreign key should "
 "have a unique constraint. This is implied whenever the foreign key is also "
 "the primary key."
 msgstr ""
-"<literal>unique</literal> (opcional): Especifica que a chave estrangeira "
-"deve ter uma constraint unique (sto é implícito em qualquer momento que a "
-"chave estrangeira também fizer parte da chave primária)."
+"<literal>unique</literal> (opcional): Especifica que a chave exterior deve "
+"ter uma restrição única. Isto é, implícito em qualquer momento que a chave "
+"exterior também fizer parte da chave primária."
 
 #. Tag: para
-#: basic_mapping.xml:2354
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For systems where delete performance is important, we recommend that all "
 "keys should be defined <literal>on-delete=\"cascade\"</literal>. Hibernate "
@@ -4469,17 +3368,15 @@
 "that this feature bypasses Hibernate's usual optimistic locking strategy for "
 "versioned data."
 msgstr ""
-"Nós recomendamos que para sistemas que a performance de delete seja "
-"importante, todas as chaves deve ser definida <literal>on-delete=\"cascade"
-"\"</literal>, e o Hibernate irá usar uma constraint a nível de banco de "
-"dados <literal>ON CASCADE DELETE</literal>, ao invés de muitas instruções "
+"Nós recomendamos que para sistemas que o desempenho deletar seja importante, "
+"todas as chaves devem ser definidas <literal>on-delete=\"cascade\"</"
+"literal>. O Hibernate irá usar uma restrição a nível de banco de dados "
+"<literal>ON CASCADE DELETE</literal>, ao invés de muitas instruções "
 "<literal>DELETE</literal>. Esteja ciente que esta característica é um atalho "
-"da estratégia usual de optimistic locking do Hibernate para dados "
-"versionados."
+"da estratégia usual de bloqueio otimista do Hibernate para dados versionados."
 
 #. Tag: para
-#: basic_mapping.xml:2362
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>not-null</literal> and <literal>update</literal> attributes are "
 "useful when mapping a unidirectional one-to-many association. If you map a "
@@ -4487,88 +3384,59 @@
 "<emphasis>must</emphasis> declare the key column using <literal>&lt;key not-"
 "null=\"true\"&gt;</literal>."
 msgstr ""
-"Os atributos <literal>not-null</literal> e <literal>update</literal> são "
-"úteis quando estamos mapeamos uma associação unidirecional um para muitos. "
-"Se você mapear uma asociação unidirecional um para muitos para uma chave "
-"estrangeira non-nullable, você <emphasis>deve</emphasis> declarar a coluna "
-"chave usando <literal>&lt;key not-null=\"true\"&gt;</literal>."
+"As funções <literal>not-null</literal> e <literal>update</literal> são úteis "
+"quando estamos mapeando uma associação unidirecional um para muitos. Se você "
+"mapear uma associação unidirecional um para muitos para uma chave exterior "
+"não-nula, você <emphasis>deve</emphasis> declarar a coluna chave usando "
+"<literal>&lt;key not-null=\"true\"&gt;</literal>."
 
 #. Tag: title
-#: basic_mapping.xml:2372
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Column and formula elements"
-msgstr "elementos column e formula"
+msgstr "Elementos coluna e fórmula "
 
 #. Tag: para
-#: basic_mapping.xml:2373
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Mapping elements which accept a <literal>column</literal> attribute will "
 "alternatively accept a <literal>&lt;column&gt;</literal> subelement. "
 "Likewise, <literal>&lt;formula&gt;</literal> is an alternative to the "
 "<literal>formula</literal> attribute. For example:"
 msgstr ""
-"Qualquer elemento de mapeamente que aceita um atributo <literal>column</"
-"literal> irá aceitar alternativamente um subelemento <literal>&lt;column&gt;"
-"</literal>. Da mesma forma, <literal>formula</literal> é uma alternativa "
-"para o atributo <literal>formula</literal>."
+"Qualquer elemento de mapeamento que aceita uma função <literal>column</"
+"literal> irá aceitar alternativamente um sub-elemento <literal>&lt;column&gt;"
+"</literal>. Da mesma forma, <literal>&lt;formula&gt;</literal> é uma "
+"alternativa para a função <literal>formula</literal>."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2379
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<column\n"
-"        name=\"column_name\"\n"
-"        length=\"N\"\n"
-"        precision=\"N\"\n"
-"        scale=\"N\"\n"
-"        not-null=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        unique-key=\"multicolumn_unique_key_name\"\n"
-"        index=\"index_name\"\n"
-"        sql-type=\"sql_type_name\"\n"
-"        check=\"SQL expression\"\n"
-"        default=\"SQL expression\"/>]]>"
+"Most of the attributes on <literal>column</literal> provide a means of "
+"tailoring the DDL during automatic schema generation. The <literal>read</"
+"literal> and <literal>write</literal> attributes allow you to specify custom "
+"SQL that Hibernate will use to access the column's value. For more on this, "
+"see the discussion of <link linkend=\"mapping-column-read-and-write\">column "
+"read and write expressions</link>."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2381
-#, no-c-format
-msgid "<![CDATA[<formula>SQL expression</formula>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2383
 #, fuzzy, no-c-format
 msgid ""
-"<literal>column</literal> and <literal>formula</literal> attributes can even "
-"be combined within the same property or association mapping to express, for "
-"example, exotic join conditions."
+"The <literal>column</literal> and <literal>formula</literal> elements can "
+"even be combined within the same property or association mapping to express, "
+"for example, exotic join conditions."
 msgstr ""
-"O atributo <literal>column</literal> e <literal>formula</literal> podem até "
+"As funções <literal>column</literal> e <literal>formula</literal> podem até "
 "ser combinados dentro da mesma propriedade ou associação mapeando para "
-"expressar, por exemplo, associações exóticas."
+"expressar, por exemplo, condições de associações exóticas."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2389
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"homeAddress\" class=\"Address\"\n"
-"        insert=\"false\" update=\"false\">\n"
-"    <column name=\"person_id\" not-null=\"true\" length=\"10\"/>\n"
-"    <formula>'MAILING'</formula>\n"
-"</many-to-one>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:2394
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Import"
-msgstr "import"
+msgstr "Importar "
 
 #. Tag: para
-#: basic_mapping.xml:2396
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your application has two persistent classes with the same name, and you "
 "do not want to specify the fully qualified package name in Hibernate "
@@ -4576,56 +3444,36 @@
 "<literal>auto-import=\"true\"</literal>. You can also import classes and "
 "interfaces that are not explicitly mapped:"
 msgstr ""
-"Suponha que a sua aplicação tem duas classes persistentes com o mesmo nome, "
-"e você não quer especificar o nome qualificado (do pacote) nas queries do "
-"Hibernate. As Classes devem ser \"importadas\" explicitamente, de "
+"Vamos supor que a sua aplicação tenha duas classes persistentes com o mesmo "
+"nome, e você não quer especificar o nome qualificado do pacote nas consultas "
+"do Hibernate. As Classes deverão ser \"importadas\" explicitamente, de "
 "preferência contando com <literal>auto-import=\"true\"</literal>. Você pode "
-"até importar classes e interfaces que não estão explicitamente mapeadas."
+"até importar classes e interfaces que não estão explicitamente mapeadas:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2403
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[<import class=\"java.lang.Object\" rename=\"Universe\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2410
-#, no-c-format
 msgid ""
-"<![CDATA[<import\n"
-"        class=\"ClassName\"\n"
-"        rename=\"ShortName\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2413
-#, fuzzy, no-c-format
-msgid ""
 "<literal>class</literal>: the fully qualified class name of any Java class."
 msgstr ""
-"<literal>class</literal>: O nome qualificado (do pacote) de qualquer classe "
+"<literal>class</literal>: O nome qualificado do pacote de qualquer classe "
 "Java."
 
 #. Tag: para
-#: basic_mapping.xml:2418
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>rename</literal> (optional - defaults to the unqualified class "
 "name): a name that can be used in the query language."
 msgstr ""
-"<literal>rename</literal> (opcional – valor default, o nome da classe não "
+"<literal>rename</literal> (opcional – padrão para o nome da classe não "
 "qualificada): Um nome que pode ser usado numa linguagem de consulta."
 
 #. Tag: title
-#: basic_mapping.xml:2429
 #, no-c-format
-msgid "<title>Any</title>"
-msgstr ""
+msgid "Any"
+msgstr "Any"
 
 #. Tag: para
-#: basic_mapping.xml:2431
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is one more type of property mapping. The <literal>&lt;any&gt;</"
 "literal> mapping element defines a polymorphic association to classes from "
@@ -4640,15 +3488,14 @@
 "<literal>&lt;any&gt;</literal> define uma associação polimórfica para "
 "classes de múltiplas tabelas. Este tipo de mapeamento sempre requer mais de "
 "uma coluna. A primeira coluna possui o tipo da entidade associada. A outra "
-"coluna que ficou possui o identificador. É impossível especificar uma "
-"restrição de chave estrangeira para este tipo de associação, assim isto "
-"claramente não é visto como um caminho usual para associações (polimórficas) "
+"coluna restante possui o identificador. É impossível especificar uma "
+"restrição de chave exterior para este tipo de associação, portanto isto "
+"certamente não é visto como um caminho usual para associações (polimórficas) "
 "de mapeamento. Você deve usar este mapeamento apenas em casos muito "
-"especiais (exemplo: audit logs, dados de sessão do usuário, etc)."
+"especiais. Por exemplo: audit logs, dados de sessão do usuário, etc. "
 
 #. Tag: para
-#: basic_mapping.xml:2441
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>meta-type</literal> attribute allows the application to specify "
 "a custom type that maps database column values to persistent classes that "
@@ -4656,115 +3503,74 @@
 "literal>. You must specify the mapping from values of the meta-type to class "
 "names."
 msgstr ""
-"O atributo <literal>meta-type</literal> permite a aplicação especificar um "
+"A função <literal>meta-type</literal> permite que a aplicação especifique um "
 "tipo adaptado que mapeia valores de colunas de banco de dados para classes "
-"persistentes que tem propriedades identificadoras do tipo especificado "
+"persistentes que possuem propriedades identificadoras do tipo especificado "
 "através do <literal>id-type</literal>. Você deve especificar o mapeamento de "
-"valores do meta-type para nome de classes."
+"valores do meta-type para nome de classes. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2448
-#, no-c-format
-msgid ""
-"<![CDATA[<any name=\"being\" id-type=\"long\" meta-type=\"string\">\n"
-"    <meta-value value=\"TBL_ANIMAL\" class=\"Animal\"/>\n"
-"    <meta-value value=\"TBL_HUMAN\" class=\"Human\"/>\n"
-"    <meta-value value=\"TBL_ALIEN\" class=\"Alien\"/>\n"
-"    <column name=\"table_name\"/>\n"
-"    <column name=\"id\"/>\n"
-"</any>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2459
-#, no-c-format
-msgid ""
-"<![CDATA[<any\n"
-"        name=\"propertyName\"\n"
-"        id-type=\"idtypename\"\n"
-"        meta-type=\"metatypename\"\n"
-"        cascade=\"cascade_style\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        optimistic-lock=\"true|false\"\n"
-">\n"
-"        <meta-value ... />\n"
-"        <meta-value ... />\n"
-"        .....\n"
-"        <column .... />\n"
-"        <column .... />\n"
-"        .....\n"
-"</any>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2462
 #, no-c-format
 msgid "<literal>name</literal>: the property name."
 msgstr "<literal>name</literal>: o nome da propriedade."
 
 #. Tag: para
-#: basic_mapping.xml:2467
 #, no-c-format
 msgid "<literal>id-type</literal>: the identifier type."
 msgstr "<literal>id-type</literal>: o tipo identificador."
 
 #. Tag: para
-#: basic_mapping.xml:2472
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>meta-type</literal> (optional - defaults to <literal>string</"
 "literal>): any type that is allowed for a discriminator mapping."
 msgstr ""
-"<literal>meta-type</literal> (opcional – valor default <literal>string</"
+"<literal>meta-type</literal> (opcional – padrão para <literal>string</"
 "literal>): Qualquer tipo que é permitido para um mapeamento discriminador."
 
 #. Tag: para
-#: basic_mapping.xml:2478
 #, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional- defaults to <literal>none</literal>): "
 "the cascade style."
 msgstr ""
-"<literal>cascade</literal> (opcional – valor default <literal>none</"
-"literal>): o estilo do cascade."
+"<literal>cascade</literal> (opcional – valor padrão <literal>none</"
+"literal>): o estilo cascata."
 
 #. Tag: para
-#: basic_mapping.xml:2490
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to this property either do or do not "
 "require acquisition of the optimistic lock. It defines whether a version "
 "increment should occur if this property is dirty."
 msgstr ""
-"<literal>optimistic-lock</literal> (opcional - valor default<literal>true</"
+"<literal>optimistic-lock</literal> (opcional - valor padrão<literal>true</"
 "literal>): Especifica que as atualizações para esta propriedade requerem ou "
-"não aquisição da trava otimista. Em outras palavras, define se uma versão de "
-"incremento deve ocorrer se esta propriedade está modificada."
+"não aquisição da bloqueio otimista. Em outras palavras, define se uma versão "
+"de incremento deve ocorrer se esta propriedade for suja."
 
 #. Tag: title
-#: basic_mapping.xml:2505
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Hibernate types"
-msgstr "Tipos do Hibernate"
+msgstr "Tipos do Hibernate "
 
 #. Tag: title
-#: basic_mapping.xml:2508
 #, no-c-format
 msgid "Entities and values"
 msgstr "Entidades e valores"
 
 #. Tag: para
-#: basic_mapping.xml:2510
 #, no-c-format
 msgid ""
 "In relation to the persistence service, Java language-level objects are "
 "classified into two groups:"
 msgstr ""
+"Os objetos de nível de linguagem Java são classificados em dois grupos, em "
+"relação ao serviço de persistência:"
 
 #. Tag: para
-#: basic_mapping.xml:2515
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An <emphasis>entity</emphasis> exists independently of any other objects "
 "holding references to the entity. Contrast this with the usual Java model, "
@@ -4776,20 +3582,19 @@
 "large systems. Entities support circular and shared references. They can "
 "also be versioned."
 msgstr ""
-"Uma <emphasis>entidade </emphasis> existe independentemente de qualquer "
-"outro objeto guardando referências para a entidade. Em contraste com o "
-"modelo usual de Java que um objeto não referenciado é coletado pelo garbage "
-"collector. Entidades devem ser explicitamente salvas ou deletada (exceto em "
+"Uma <emphasis>entidade</emphasis> existe independentemente de qualquer outro "
+"objeto guardando referências para a entidade. Em contraste com o modelo "
+"usual de Java que um objeto não referenciado é coletado pelo coletor de "
+"lixo. Entidades devem ser explicitamente salvas ou deletadas (exceto em "
 "operações de salvamento ou deleção que possam ser executada em "
 "<emphasis>cascata</emphasis> de uma entidade pai para seus filhos). Isto é "
-"diferente do modelo ODMG de persistência do objeto por acessibilidade – e "
-"corresponde quase a como objetos de aplicações são geralmente usados em "
+"diferente do modelo ODMG de persistência do objeto por acessibilidade e se "
+"refere mais à forma como os objetos de aplicações são geralmente usados em "
 "grandes sistemas. Entidades suportam referências circulares e comuns. Eles "
-"podem ser versionadas."
+"podem ser versionados."
 
 #. Tag: para
-#: basic_mapping.xml:2526
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An entity's persistent state consists of references to other entities and "
 "instances of <emphasis>value</emphasis> types. Values are primitives: "
@@ -4801,19 +3606,18 @@
 "no independent identity, so they cannot be shared by two entities or "
 "collections."
 msgstr ""
-"Uma entidade em estado persistente consiste de referências para outras "
+"O estado persistente da entidade consiste de referências para outras "
 "entidades e instâncias de tipos de <emphasis>valor</emphasis>. Valores são "
-"primitivos, coleções (não o que tem dentro de uma coleção), componentes e "
+"primitivos: coleções (não o que tem dentro de uma coleção), componentes e "
 "certos objetos imutáveis. Entidades distintas, valores (em coleções e "
-"componentes particulares) <emphasis>são </emphasis> persistidos e apagados "
-"por acessibilidade. Visto que objetos value (e primitivos) são persistidos e "
-"apagados junto com as entidades que os contém e não podem ser versionados "
-"independentemente. Valores têm identidade não independente, assim eles não "
-"podem ser comuns para duas entidades ou coleções."
+"componentes particulares) <emphasis>são</emphasis> persistidos e apagados "
+"por acessibilidade. Visto que objetos de valor (e primitivos) são "
+"persistidos e apagados junto com as entidades que os contém e não podem ser "
+"versionados independentemente. Valores têm identidade não independente, "
+"assim eles não podem ser comuns para duas entidades ou coleções."
 
 #. Tag: para
-#: basic_mapping.xml:2537
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Until now, we have been using the term \"persistent class\" to refer to "
 "entities. We will continue to do that. Not all user-defined classes with a "
@@ -4827,29 +3631,27 @@
 "single instance of that class, while composition or aggregation usually "
 "translates to a value type."
 msgstr ""
-"Até agora, nós estivemos usando o termo \"classe persistente\" para referir "
-"a entidades. Nós iremos continuar a fazer isto. Falando a rigor, porém, nem "
-"todas as classes definidas pelo usuário com estados persistentes são "
-"entidades. Um <emphasis>componente</emphasis> é uma classe de usuário "
-"definida com valores semânticos. Uma propriedade de Java de tipo "
-"<literal>java.lang.String</literal> também tem um valor semêntico. Dada esta "
-"definição, nós podemos dizer que todos os tipos (classes) fornecida pelo JDK "
-"tem tipo de valor semântico em Java, enquanto que tipos definidos pelo "
-"usuário pode ser mapeados com entidade ou valor de tipo semântico. Esta "
-"decisão pertence ao desenvolvedor da aplicação. Uma boa dica para uma classe "
-"entidade em um modelo de domínio são referências comuns para uma instância "
-"simples daquela classe, enquanto a composição ou agregação geralmente se "
-"traduz para um valor de tipo."
+"Até agora, estivemos usando o termo \"classe persistente\" para referir às "
+"entidades. Continuaremos a fazer isto. No entanto, nem todas as classes "
+"definidas pelo usuário com estados persistentes são entidades. Um "
+"<emphasis>componente</emphasis> é uma classe de usuário definida com valores "
+"semânticos. Uma propriedade de Java de tipo <literal>java.lang.String</"
+"literal> também tem um valor semântico. Dada esta definição, nós podemos "
+"dizer que todos os tipos (classes) fornecidos pelo JDK têm tipo de valor "
+"semântico em Java, enquanto que tipos definidos pelo usuário, podem ser "
+"mapeados com entidade ou valor de tipo semântico. Esta decisão pertence ao "
+"desenvolvedor da aplicação. Uma boa dica para uma classe de entidade em um "
+"modelo de domínio são referências comuns para uma instância simples daquela "
+"classe, enquanto a composição ou agregação geralmente se traduz para um tipo "
+"de valor."
 
 #. Tag: para
-#: basic_mapping.xml:2551
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "We will revisit both concepts throughout this reference guide."
-msgstr "Nós iremos rever ambos os conceitos durante toda a documentação."
+msgstr "Iremos rever ambos os conceitos durante todo o guia de referência."
 
 #. Tag: para
-#: basic_mapping.xml:2555
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The challenge is to map the Java type system, and the developers' definition "
 "of entities and value types, to the SQL/database type system. The bridge "
@@ -4862,57 +3664,51 @@
 "for standard JDK value types out of the box. You can write your own mapping "
 "types and implement your own custom conversion strategies."
 msgstr ""
-"O desafio pe mapear o sistema de tipo de Java (e a definição do "
-"desenvolvedor de entidades e tipos de valor) para o sistema de tipo SQL/"
-"banco de dados. A ponte entre ambos os sistemas é fornecido pelo Hibernate: "
-"para entidades que usam <literal>&lt;class&gt;</literal>, <literal>&lt;"
-"subclass&gt;</literal> e assim por diante. Para tipos de valores nós usamos "
-"<literal>&lt;property&gt;</literal>, <literal>&lt;component&gt;</literal>, "
-"etc, geralmente com um atributo <literal>type</literal>. O valor deste "
-"atributo é o nome de um <emphasis>tipo de mapeamento</emphasis> do "
-"Hibernate. O Hibernate fornece muitos mapeamentos (para tipos de valores do "
-"JDK padrão) ut of the box. Você pode escrever os seus próprios tipos de "
-"mapeamentos e implementar sua estratégia de conversão adaptada, como você "
-"verá adiante."
+"O desafio é mapear o sistema de tipo de Java e a definição do desenvolvedor "
+"de entidades e tipos de valor para o sistema de tipo SQL/banco de dados. A "
+"ponte entre ambos os sistemas é fornecida pelo Hibernate. Para entidades que "
+"usam <literal>&lt;class&gt;</literal>, <literal>&lt; subclass&gt;</literal> "
+"e assim por diante. Para tipos de valores nós usamos <literal>&lt;"
+"property&gt;</literal>, <literal>&lt;component&gt;</literal>, etc, "
+"geralmente com uma função <literal>type</literal>. O valor desta função é o "
+"nome de um <emphasis>tipo de mapeamento</emphasis> do Hibernate. O Hibernate "
+"fornece muitos mapeamentos imediatos para tipos de valores do JDK padrão. "
+"Você pode escrever os seus próprios tipos de mapeamentos e implementar sua "
+"estratégia de conversão adaptada, como você."
 
 #. Tag: para
-#: basic_mapping.xml:2568
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "With the exception of collections, all built-in Hibernate types support null "
 "semantics."
 msgstr ""
-"Todos os tipos internos do hibernate exceto coleções suportam semânticas "
-"nulas."
+"Todos os tipos internos do hibernate exceto coleções, suportam semânticas "
+"nulas com a exceção das coleções."
 
 #. Tag: title
-#: basic_mapping.xml:2575
 #, no-c-format
 msgid "Basic value types"
 msgstr "Valores de tipos básicos"
 
 #. Tag: para
-#: basic_mapping.xml:2577
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The built-in <emphasis>basic mapping types</emphasis> can be roughly "
 "categorized into the following:"
 msgstr ""
-"O tipos internos de mapeamentos básicos podem ser a grosso modo categorizado "
-"como: <placeholder-1/>"
+"Os <emphasis>tipos de mapeamento básicos</emphasis> fazem parte da "
+"categorização do seguinte:"
 
-#. Tag: literal
-#: basic_mapping.xml:2582
+#. Tag: term
 #, no-c-format
 msgid ""
-"integer, long, short, float, double, character, byte, boolean, yes_no, "
-"true_false"
+"<literal>integer, long, short, float, double, character, byte, boolean, "
+"yes_no, true_false</literal>"
 msgstr ""
-"integer, long, short, float, double, character, byte, boolean, yes_no, "
-"true_false"
+"<literal>integer, long, short, float, double, character, byte, boolean, "
+"yes_no, true_false</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2585
 #, no-c-format
 msgid ""
 "Type mappings from Java primitives or wrapper classes to appropriate (vendor-"
@@ -4920,19 +3716,17 @@
 "<literal>true_false</literal> are all alternative encodings for a Java "
 "<literal>boolean</literal> or <literal>java.lang.Boolean</literal>."
 msgstr ""
-"Tipos de mapeamentos de classes primitivas ou wrapper Java especificos "
+"Tipos de mapeamentos de classes primitivas ou wrapper Java específicos "
 "(vendor-specific) para tipos de coluna SQL. Boolean, <literal>boolean, "
 "yes_no</literal> são todas codificações alternativas para um "
 "<literal>boolean</literal> ou <literal>java.lang.Boolean</literal> do Java."
 
-#. Tag: literal
-#: basic_mapping.xml:2594
+#. Tag: term
 #, no-c-format
-msgid "string"
-msgstr "string"
+msgid "<literal>string</literal>"
+msgstr "<literal>string</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2596
 #, no-c-format
 msgid ""
 "A type mapping from <literal>java.lang.String</literal> to <literal>VARCHAR</"
@@ -4941,14 +3735,12 @@
 "Um tipo de mapeamento de <literal>java.lang.String</literal> para "
 "<literal>VARCHAR</literal> (ou <literal>VARCHAR2</literal> no Oracle)."
 
-#. Tag: literal
-#: basic_mapping.xml:2603
+#. Tag: term
 #, no-c-format
-msgid "date, time, timestamp"
-msgstr "date, time, timestamp"
+msgid "<literal>date, time, timestamp</literal>"
+msgstr "<literal>date, time, timestamp</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2605
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Date</literal> and its subclasses to "
@@ -4959,14 +3751,12 @@
 "para os tipos SQL <literal>DATE</literal>, <literal>TIME</literal> e "
 "<literal>TIMESTAMP</literal> (ou equivalente)."
 
-#. Tag: literal
-#: basic_mapping.xml:2613
+#. Tag: term
 #, no-c-format
-msgid "calendar, calendar_date"
-msgstr "calendar, calendar_date"
+msgid "<literal>calendar, calendar_date</literal>"
+msgstr "<literal>calendar, calendar_date</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2615
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Calendar</literal> to SQL types "
@@ -4975,14 +3765,12 @@
 "Tipo de mapeamento de <literal>java.util.Calendar</literal> para os tipos "
 "SQL <literal>TIMESTAMP</literal> e <literal>DATE</literal> (ou equivalente)."
 
-#. Tag: literal
-#: basic_mapping.xml:2623
+#. Tag: term
 #, no-c-format
-msgid "big_decimal, big_integer"
-msgstr "big_decimal, big_integer"
+msgid "<literal>big_decimal, big_integer</literal>"
+msgstr "<literal>big_decimal, big_integer</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2625
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.math.BigDecimal</literal> and <literal>java."
@@ -4993,14 +3781,12 @@
 "<literal>java.math.BigInteger</literal> para <literal>NUMERIC</literal> (ou "
 "<literal>NUMBER</literal> no Oracle)."
 
-#. Tag: literal
-#: basic_mapping.xml:2633
+#. Tag: term
 #, no-c-format
-msgid "locale, timezone, currency"
-msgstr "locale, timezone, currency"
+msgid "<literal>locale, timezone, currency</literal>"
+msgstr "<literal>locale, timezone, currency</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2635
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Locale</literal>, <literal>java.util."
@@ -5017,62 +3803,53 @@
 "mapeados para seus códigos ISO. Instâncias de <literal>TimeZone</literal> "
 "são mapeados para seu <literal>ID</literal>."
 
-#. Tag: literal
-#: basic_mapping.xml:2647
+#. Tag: term
 #, no-c-format
-msgid "class"
-msgstr "class"
+msgid "<literal>class</literal>"
+msgstr "<literal>class</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2649
 #, no-c-format
 msgid ""
 "A type mapping from <literal>java.lang.Class</literal> to <literal>VARCHAR</"
 "literal> (or Oracle <literal>VARCHAR2</literal>). A <literal>Class</literal> "
 "is mapped to its fully qualified name."
 msgstr ""
-"um tipo de mapeamento de <literal>java.lang.Class</literal> para "
+"Um tipo de mapeamento de <literal>java.lang.Class</literal> para "
 "<literal>VARCHAR</literal> (ou <literal>VARCHAR2</literal> no Oracle). Uma "
 "<literal>Class</literal> é mapeada pelo seu nome qualificado (completo)."
 
-#. Tag: literal
-#: basic_mapping.xml:2657
+#. Tag: term
 #, no-c-format
-msgid "binary"
-msgstr "binary"
+msgid "<literal>binary</literal>"
+msgstr "<literal>binary</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2659
 #, no-c-format
 msgid "Maps byte arrays to an appropriate SQL binary type."
-msgstr "Mapeia arrays de bytes para um tipo binário de SQL apropriado."
+msgstr "Mapeia matrizes de bytes para um tipo binário de SQL apropriado."
 
-#. Tag: literal
-#: basic_mapping.xml:2665
+#. Tag: term
 #, no-c-format
-msgid "text"
-msgstr "text"
+msgid "<literal>text</literal>"
+msgstr "<literal>text</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2667
 #, no-c-format
 msgid ""
 "Maps long Java strings to a SQL <literal>CLOB</literal> or <literal>TEXT</"
 "literal> type."
 msgstr ""
-"Maps long Java strings to a SQL <literal>CLOB</literal> or <literal>TEXT</"
-"literal> type. Mapeia strings longas de Java para um tipo SQL <literal>CLOB</"
-"literal> ou <literal>TEXT</literal>."
+"Mapeia strings de Java longos para um tipo SQL <literal>CLOB</literal> ou "
+"<literal>TEXT</literal>. "
 
-#. Tag: literal
-#: basic_mapping.xml:2674
+#. Tag: term
 #, no-c-format
-msgid "serializable"
-msgstr "serializable"
+msgid "<literal>serializable</literal>"
+msgstr "<literal>serializable</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2676
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Maps serializable Java types to an appropriate SQL binary type. You can also "
 "indicate the Hibernate type <literal>serializable</literal> with the name of "
@@ -5081,17 +3858,15 @@
 "Mapeia tipos Java serializáveis para um tipo binário SQL apropriado. Você "
 "pode também indicar o tipo <literal>serializable</literal> do Hibernate com "
 "o nome da classe ou interface Java serializável que não é padrão para um "
-"tipo básico."
+"tipo básico. "
 
-#. Tag: literal
-#: basic_mapping.xml:2685
+#. Tag: term
 #, no-c-format
-msgid "clob, blob"
-msgstr "clob, blob"
+msgid "<literal>clob, blob</literal>"
+msgstr "<literal>clob, blob</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2687
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Type mappings for the JDBC classes <literal>java.sql.Clob</literal> and "
 "<literal>java.sql.Blob</literal>. These types can be inconvenient for some "
@@ -5099,24 +3874,22 @@
 "transaction. Driver support is patchy and inconsistent."
 msgstr ""
 "Tipos de mapeamentos para as classes JDBC <literal>java.sql.Clob</literal> "
-"and <literal>java.sql.Blob</literal>. Estes tipos podem ser inconveniente "
-"para algumas aplicações, visto que o objeto blob ou clob pode não ser "
-"reusado fora de uma transação. (Além disso, o suporte de driver é imcompleto "
-"e inconsistente.)"
+"and <literal>java.sql.Blob</literal>. Estes tipos podem ser inconvenientes "
+"para algumas aplicações, visto que o objeto blob ou clob não pode ser "
+"reusado fora de uma transação. Além disso, o suporte de driver é imcompleto "
+"e inconsistente."
 
-#. Tag: literal
-#: basic_mapping.xml:2697
+#. Tag: term
 #, no-c-format
 msgid ""
-"imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
-"imm_serializable, imm_binary"
+"<literal>imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
+"imm_serializable, imm_binary</literal>"
 msgstr ""
-"imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
-"imm_serializable, imm_binary"
+"<literal>imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
+"imm_serializable, imm_binary</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2701
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Type mappings for what are considered mutable Java types. This is where "
 "Hibernate makes certain optimizations appropriate only for immutable Java "
@@ -5126,17 +3899,16 @@
 "have that change made persistent, the application must assign a new, "
 "nonidentical, object to the property."
 msgstr ""
-"Mapeando tipos para o que geralmente são consideradas tipos mutáveis de "
-"Java, onde o Hibernate faz determinadas otimizações apropriadas somente para "
-"tipos imutáveis de Java, e a aplicação trata o objeto como imutável. Por "
-"exemplo, você não deve chamar <literal>Date.setTime()</literal> para uma "
-"instância mapeada como <literal>imm_timestamp</literal>. Para mudar o valor "
-"da propriedade, e ter a mudança feita persistente, a aplicação deve atribuir "
-"um novo objeto (nonidentical) à propriedade."
+"Mapeamento de tipos para, os geralmente considerados, tipos mutáveis de "
+"Java. Isto é onde o Hibernate faz determinadas otimizações apropriadas "
+"somente para tipos imutáveis de Java, e a aplicação trata o objeto como "
+"imutável. Por exemplo, você não deve chamar <literal>Date.setTime()</"
+"literal> para uma instância mapeada como <literal>imm_timestamp</literal>. "
+"Para mudar o valor da propriedade, e ter a mudança feita persistente, a "
+"aplicação deve atribuir um novo objeto (nonidentical) à propriedade."
 
 #. Tag: para
-#: basic_mapping.xml:2716
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Unique identifiers of entities and collections can be of any basic type "
 "except <literal>binary</literal>, <literal>blob</literal> and <literal>clob</"
@@ -5145,11 +3917,10 @@
 msgstr ""
 "Identificadores únicos das entidades e coleções podem ser de qualquer tipo "
 "básico exceto <literal>binary</literal>, <literal>blob</literal> ou "
-"<literal>clob</literal>. (Identificadores compostos também são permitidos, "
-"veja abaixo.)"
+"<literal>clob</literal>. (Identificadores compostos também são permitidos. "
+"Leia abaixo para maiores informações."
 
 #. Tag: para
-#: basic_mapping.xml:2722
 #, no-c-format
 msgid ""
 "The basic value types have corresponding <literal>Type</literal> constants "
@@ -5163,14 +3934,12 @@
 "<literal>string</literal>."
 
 #. Tag: title
-#: basic_mapping.xml:2731
 #, no-c-format
 msgid "Custom value types"
 msgstr "Tipos de valores personalizados"
 
 #. Tag: para
-#: basic_mapping.xml:2733
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is relatively easy for developers to create their own value types. For "
 "example, you might want to persist properties of type <literal>java.lang."
@@ -5182,20 +3951,19 @@
 "that is persisted to the columns <literal>FIRST_NAME</literal>, "
 "<literal>INITIAL</literal>, <literal>SURNAME</literal>."
 msgstr ""
-"É relativamente fácil para desenvolvedores criar seus próprios tipos de "
-"valor. Por exemplo, você pode querer persistir propriedades do tipo "
+"É relativamente fácil para desenvolvedores criarem seus próprios tipos de "
+"valores. Por exemplo, você pode querer persistir propriedades do tipo "
 "<literal>java.lang.BigInteger</literal> para colunas <literal>VARCHAR</"
 "literal>. O Hibernate não fornece um tipo correspondente para isso. Mas os "
-"tipos adaptados não são limitados a mapeamento de uma propriedade (ou "
-"elemento de coleção) a uma única coluna da tabela. Assim, por exemplo, você "
-"pôde ter uma propriedade Java <literal>getName()</literal>/<literal>setName()"
+"tipos adaptados não são limitados a mapeamento de uma propriedade, ou "
+"elemento de coleção, a uma única coluna da tabela. Assim, por exemplo, você "
+"pode ter uma propriedade Java <literal>getName()</literal>/<literal>setName()"
 "</literal> do tipo <literal>java.lang.String</literal> que é persistido para "
 "colunas <literal>FIRST_NAME</literal>, <literal>INITIAL</literal>, "
-"<literal>SURNAME</literal>."
+"<literal>SURNAME</literal>. "
 
 #. Tag: para
-#: basic_mapping.xml:2744
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To implement a custom type, implement either <literal>org.hibernate."
 "UserType</literal> or <literal>org.hibernate.CompositeUserType</literal> and "
@@ -5204,24 +3972,12 @@
 "things that are possible."
 msgstr ""
 "Para implementar um tipo personalizado, implemente <literal>org.hibernate."
-"UserType</literal> or <literal>org.hibernate.CompositeUserType</literal> e "
+"UserType</literal> ou <literal>org.hibernate.CompositeUserType</literal> e "
 "declare propriedades usando o nome qualificado da classe do tipo. Veja "
-"<literal>org.hibernate.test.DoubleStringType</literal> para ver o tipo das "
-"coisas que são possíveis."
+"<literal>org.hibernate.test.DoubleStringType</literal> para outras "
+"funcionalidades. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2752
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"twoStrings\" type=\"org.hibernate.test."
-"DoubleStringType\">\n"
-"    <column name=\"first_string\"/>\n"
-"    <column name=\"second_string\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2754
 #, no-c-format
 msgid ""
 "Notice the use of <literal>&lt;column&gt;</literal> tags to map a property "
@@ -5231,7 +3987,6 @@
 "propriedade para colunas múltiplas."
 
 #. Tag: para
-#: basic_mapping.xml:2759
 #, no-c-format
 msgid ""
 "The <literal>CompositeUserType</literal>, <literal>EnhancedUserType</"
@@ -5245,8 +4000,7 @@
 "especializados."
 
 #. Tag: para
-#: basic_mapping.xml:2765
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can even supply parameters to a <literal>UserType</literal> in the "
 "mapping file. To do this, your <literal>UserType</literal> must implement "
@@ -5254,25 +4008,13 @@
 "To supply parameters to your custom type, you can use the <literal>&lt;"
 "type&gt;</literal> element in your mapping files."
 msgstr ""
-"Você pode mesmo fornecer parâmetros a um <literal>UserType</literal> no "
+"Você mesmo pode fornecer parâmetros a um <literal>UserType</literal> no "
 "arquivo de mapeamento. Para isto, seu <literal>UserType</literal> deve "
 "implementar a interface <literal>org.hibernate.usertype.ParameterizedType</"
 "literal>. Para fornecer parâmetros a seu tipo personalizado, você pode usar "
-"o elemento <literal>&lt;type&gt;</literal> em seus arquivos de mapeamento."
+"o elemento <literal>&lt;type&gt;</literal> em seus arquivos de mapeamento. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2773
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"priority\">\n"
-"    <type name=\"com.mycompany.usertypes.DefaultValueIntegerType\">\n"
-"        <param name=\"default\">0</param>\n"
-"    </type>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2775
 #, no-c-format
 msgid ""
 "The <literal>UserType</literal> can now retrieve the value for the parameter "
@@ -5280,12 +4022,11 @@
 "object passed to it."
 msgstr ""
 "O <literal>UserType</literal> pode agora recuperar o valor para o parâmetro "
-"chamado <literal>default</literal> da <literal>Propriedade</literal> do "
+"chamado <literal>padrão</literal> da <literal>Propriedade</literal> do "
 "passado a ele."
 
 #. Tag: para
-#: basic_mapping.xml:2780
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you regularly use a certain <literal>UserType</literal>, it is useful to "
 "define a shorter name for it. You can do this using the <literal>&lt;"
@@ -5296,38 +4037,21 @@
 "Se você usar freqüentemente um determinado <literal>UserType</literal>, pode "
 "ser útil definir um nome mais curto para ele. Você pode fazer isto usando o "
 "elemento <literal>&lt;typedef&gt;</literal>. Typedefs atribui um nome a um "
-"tipo personalizado, e pode também conter uma lista de valores default de "
-"parâmetro se o tipo for parametrizado."
+"tipo personalizado, e pode também conter uma lista de valores de parâmetro "
+"padrão se o tipo for parametrizado."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2787
-#, no-c-format
-msgid ""
-"<![CDATA[<typedef class=\"com.mycompany.usertypes.DefaultValueIntegerType\" "
-"name=\"default_zero\">\n"
-"    <param name=\"default\">0</param>\n"
-"</typedef>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2789
-#, no-c-format
-msgid "<![CDATA[<property name=\"priority\" type=\"default_zero\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2791
 #, no-c-format
 msgid ""
 "It is also possible to override the parameters supplied in a typedef on a "
 "case-by-case basis by using type parameters on the property mapping."
 msgstr ""
-"It is also possible to override the parameters supplied in a typedef on a "
-"case-by-case basis by using type parameters on the property mapping."
+"Também é possível substituir os parâmetros fornecidos em um tipo de "
+"definição em situações de caso a caso, utilizando tipos de parâmetros no "
+"mapeamento da propriedade."
 
 #. Tag: para
-#: basic_mapping.xml:2796
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Even though Hibernate's rich range of built-in types and support for "
 "components means you will rarely need to use a custom type, it is considered "
@@ -5338,25 +4062,23 @@
 "is abstraction. With a custom type, your mapping documents would be "
 "protected against changes to the way monetary values are represented."
 msgstr ""
-"Even though Hibernate's rich range of built-in types and support for "
-"components means you will very rarely <emphasis>need</emphasis> to use a "
-"custom type, it is nevertheless considered good form to use custom types for "
-"(non-entity) classes that occur frequently in your application. For example, "
-"a <literal>MonetaryAmount</literal> class is a good candidate for a "
-"<literal>CompositeUserType</literal>, even though it could easily be mapped "
-"as a component. One motivation for this is abstraction. With a custom type, "
-"your mapping documents would be future-proofed against possible changes in "
-"your way of representing monetary values."
+"Apesar da rica variedade, os tipos construídos do Hibernate e suporte para "
+"componentes raramente irão utilizar  um tipo de padrão, no entanto, é "
+"considerado uma boa idéia, utilizar tipos customizados para classes não "
+"entidade que ocorrem com freqüência em seu aplicativo. Por exemplo, uma "
+"classe <literal>MonetaryAmount</literal> é um bom candidato para um "
+"<literal>CompositeUserType</literal>, apesar de poder ter sido mapeado "
+"facilmente como um componente. Uma motivação para isto é a abstração. Com um "
+"tipo padronizado, seus documentos de mapeamento seriam colocados à prova "
+"contra mudanças possíveis na forma de representação de valores monetários. "
 
 #. Tag: title
-#: basic_mapping.xml:2812
 #, no-c-format
 msgid "Mapping a class more than once"
-msgstr "Mapping a class more than once"
+msgstr "Mapeando uma classe mais de uma vez"
 
 #. Tag: para
-#: basic_mapping.xml:2813
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to provide more than one mapping for a particular persistent "
 "class. In this case, you must specify an <emphasis>entity name</emphasis> to "
@@ -5365,55 +4087,30 @@
 "entity name when working with persistent objects, when writing queries, or "
 "when mapping associations to the named entity."
 msgstr ""
-"It is possible to provide more than one mapping for a particular persistent "
-"class. In this case you must specify an <emphasis>entity name</emphasis> do "
-"disambiguate between instances of the two mapped entities. (By default, the "
-"entity name is the same as the class name.) Hibernate lets you specify the "
-"entity name when working with persistent objects, when writing queries, or "
-"when mapping associations to the named entity."
+"É possível fornecer mais de um mapeamento para uma classe persistente em "
+"específico. Neste caso, você deve especificar um <emphasis>nome de entidade</"
+"emphasis> para as instâncias das duas entidades mapeadas não se tornarem "
+"ambíguas. Por padrão, o nome da entidade é o mesmo do nome da classe. O "
+"Hibernate o deixa especificar o nome de entidade quando estiver trabalhando "
+"com objetos persistentes, quando escrever consultas, ou ao mapear "
+"associações para a entidade nomeada. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2821
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Contract\" table=\"Contracts\"\n"
-"        entity-name=\"CurrentContract\">\n"
-"    ...\n"
-"    <set name=\"history\" inverse=\"true\"\n"
-"            order-by=\"effectiveEndDate desc\">\n"
-"        <key column=\"currentContractId\"/>\n"
-"        <one-to-many entity-name=\"HistoricalContract\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Contract\" table=\"ContractHistory\"\n"
-"        entity-name=\"HistoricalContract\">\n"
-"    ...\n"
-"    <many-to-one name=\"currentContract\"\n"
-"            column=\"currentContractId\"\n"
-"            entity-name=\"CurrentContract\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2823
-#, fuzzy, no-c-format
-msgid ""
 "Associations are now specified using <literal>entity-name</literal> instead "
 "of <literal>class</literal>."
 msgstr ""
-"Notice how associations are now specified using <literal>entity-name</"
-"literal> instead of <literal>class</literal>."
+"Note como as associações são agora especificadas utilizando o "
+"<literal>entity-name</literal> ao invés da <literal>class</literal>. "
 
 #. Tag: title
-#: basic_mapping.xml:2831
 #, no-c-format
 msgid "SQL quoted identifiers"
-msgstr "SQL quoted identifiers"
+msgstr "Identificadores quotados do SQL"
 
 #. Tag: para
-#: basic_mapping.xml:2832
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can force Hibernate to quote an identifier in the generated SQL by "
 "enclosing the table or column name in backticks in the mapping document. "
@@ -5421,49 +4118,33 @@
 "literal>. This is usually double quotes, but the SQL Server uses brackets "
 "and MySQL uses backticks."
 msgstr ""
-"You may force Hibernate to quote an identifier in the generated SQL by "
-"enclosing the table or column name in backticks in the mapping document. "
-"Hibernate will use the correct quotation style for the SQL <literal>Dialect</"
-"literal> (usually double quotes, but brackets for SQL Server and backticks "
-"for MySQL)."
+"Você poderá forçar o Hibernate a quotar um identificador no SQL gerado, "
+"anexando o nome da tabela ou coluna aos backticks no documento de "
+"mapeamento. O Hibernate usará o estilo de quotação correto para o SQL  "
+"<literal>Dialect</literal>. Geralmente são quotas dúplas, mas parênteses "
+"para o Servidor SQL e backticks para MeuSQL."
 
-#. Tag: programlisting
-#: basic_mapping.xml:2839
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"LineItem\" table=\"`Line Item`\">\n"
-"    <id name=\"id\" column=\"`Item Id`\"/><generator class=\"assigned\"/></"
-"id>\n"
-"    <property name=\"itemNumber\" column=\"`Item #`\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:2845
 #, no-c-format
 msgid "Metadata alternatives"
-msgstr "Metadata alternatives"
+msgstr "Alternativas de Metadados"
 
 #. Tag: para
-#: basic_mapping.xml:2847
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "XML does not suit all users so there are some alternative ways to define O/R "
 "mapping metadata in Hibernate."
 msgstr ""
-"XML isn't for everyone, and so there are some alternative ways to define O/R "
-"mapping metadata in Hibernate."
+"O XML não é para todos, e portanto existem algumas formas alternativas de "
+"defiinir o metadado de mapeamento no Hibernate. "
 
 #. Tag: title
-#: basic_mapping.xml:2852
 #, no-c-format
 msgid "Using XDoclet markup"
-msgstr "Using XDoclet markup"
+msgstr "Usando a marcação XDoclet."
 
 #. Tag: para
-#: basic_mapping.xml:2854
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Many Hibernate users prefer to embed mapping information directly in "
 "sourcecode using XDoclet <literal>@hibernate.tags</literal>. We do not cover "
@@ -5471,137 +4152,27 @@
 "XDoclet. However, we include the following example of the <literal>Cat</"
 "literal> class with XDoclet mappings:"
 msgstr ""
-"Many Hibernate users prefer to embed mapping information directly in "
-"sourcecode using XDoclet <literal>@hibernate.tags</literal>. We will not "
-"cover this approach in this document, since strictly it is considered part "
-"of XDoclet. However, we include the following example of the <literal>Cat</"
-"literal> class with XDoclet mappings."
+"Muitos usuários do Hibernate preferem encubar a informação de mapeamento "
+"diretamente no código de fonte utilizando o XDoclet <literal>@hibernate."
+"tags</literal>. Nós não falaremos sobre esta abordagem neste documento, uma "
+"vez que é estritamente considerado parte de um XDoclet. No entanto, "
+"incluímos os seguintes exemplos  da classe <literal>Cat</literal> com os "
+"mapeamentos de XDoclet:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2861
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"import java.util.Date;\n"
-"\n"
-"/**\n"
-" * @hibernate.class\n"
-" *  table=\"CATS\"\n"
-" */\n"
-"public class Cat {\n"
-"    private Long id; // identifier\n"
-"    private Date birthdate;\n"
-"    private Cat mother;\n"
-"    private Set kittens\n"
-"    private Color color;\n"
-"    private char sex;\n"
-"    private float weight;\n"
-"\n"
-"    /*\n"
-"     * @hibernate.id\n"
-"     *  generator-class=\"native\"\n"
-"     *  column=\"CAT_ID\"\n"
-"     */\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"    private void setId(Long id) {\n"
-"        this.id=id;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.many-to-one\n"
-"     *  column=\"PARENT_ID\"\n"
-"     */\n"
-"    public Cat getMother() {\n"
-"        return mother;\n"
-"    }\n"
-"    void setMother(Cat mother) {\n"
-"        this.mother = mother;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"BIRTH_DATE\"\n"
-"     */\n"
-"    public Date getBirthdate() {\n"
-"        return birthdate;\n"
-"    }\n"
-"    void setBirthdate(Date date) {\n"
-"        birthdate = date;\n"
-"    }\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"WEIGHT\"\n"
-"     */\n"
-"    public float getWeight() {\n"
-"        return weight;\n"
-"    }\n"
-"    void setWeight(float weight) {\n"
-"        this.weight = weight;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"COLOR\"\n"
-"     *  not-null=\"true\"\n"
-"     */\n"
-"    public Color getColor() {\n"
-"        return color;\n"
-"    }\n"
-"    void setColor(Color color) {\n"
-"        this.color = color;\n"
-"    }\n"
-"    /**\n"
-"     * @hibernate.set\n"
-"     *  inverse=\"true\"\n"
-"     *  order-by=\"BIRTH_DATE\"\n"
-"     * @hibernate.collection-key\n"
-"     *  column=\"PARENT_ID\"\n"
-"     * @hibernate.collection-one-to-many\n"
-"     */\n"
-"    public Set getKittens() {\n"
-"        return kittens;\n"
-"    }\n"
-"    void setKittens(Set kittens) {\n"
-"        this.kittens = kittens;\n"
-"    }\n"
-"    // addKitten not needed by Hibernate\n"
-"    public void addKitten(Cat kitten) {\n"
-"        kittens.add(kitten);\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"SEX\"\n"
-"     *  not-null=\"true\"\n"
-"     *  update=\"false\"\n"
-"     */\n"
-"    public char getSex() {\n"
-"        return sex;\n"
-"    }\n"
-"    void setSex(char sex) {\n"
-"        this.sex=sex;\n"
-"    }\n"
-"}]]>"
+msgid "See the Hibernate website for more examples of XDoclet and Hibernate."
 msgstr ""
+"Veja o web site do Hibernate para maiores detalhes sobre um XDoclet e "
+"Hibernate.  "
 
-#. Tag: para
-#: basic_mapping.xml:2863
-#, fuzzy, no-c-format
-msgid "See the Hibernate website for more examples of XDoclet and Hibernate."
-msgstr "See the Hibernate web site for more examples of XDoclet and Hibernate."
-
 #. Tag: title
-#: basic_mapping.xml:2870
 #, no-c-format
 msgid "Using JDK 5.0 Annotations"
-msgstr "Using JDK 5.0 Annotations"
+msgstr "Usando as anotações JDK 5.0"
 
 #. Tag: para
-#: basic_mapping.xml:2872
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "JDK 5.0 introduced XDoclet-style annotations at the language level that are "
 "type-safe and checked at compile time. This mechanism is more powerful than "
@@ -5614,72 +4185,41 @@
 "<emphasis>Hibernate Annotations</emphasis> package as a separate download. "
 "Both EJB3 (JSR-220) and Hibernate3 metadata is supported."
 msgstr ""
-"JDK 5.0 introduced XDoclet-style annotations at the language level, type-"
-"safe and checked at compile time. This mechnism is more powerful than "
-"XDoclet annotations and better supported by tools and IDEs. IntelliJ IDEA, "
-"for example, supports auto-completion and syntax highlighting of JDK 5.0 "
-"annotations. The new revision of the EJB specification (JSR-220) uses JDK "
-"5.0 annotations as the primary metadata mechanism for entity beans. "
-"Hibernate3 implements the <literal>EntityManager</literal> of JSR-220 (the "
-"persistence API), support for mapping metadata is available via the "
-"<emphasis>Hibernate Annotations</emphasis> package, as a separate download. "
-"Both EJB3 (JSR-220) and Hibernate3 metadata is supported."
+"O JDK 5.0 introduziu as anotações estilo XDoclet em nível de linguagem, tipo "
+"seguro e checado em tempo de compilação. Este mecanismo é mais potente do "
+"que as anotações XDoclet e melhor suportado pelas ferramentas e IDEs. O "
+"IntelliJ IDEA por exemplo, suporta a auto complexão e destaque da sintaxe "
+"das anotações JDK 5.0. A nova revisão da especificação EJB (JSR-220) usa as "
+"anotações JDK 5.0 como mecanismos de metadados para beans de entidade. O "
+"Hibernate3 implementa o <literal>EntityManager</literal> do JSR-220 (o API "
+"de persistência). O suporte para mapear metadados está disponível através do "
+"pacote <emphasis>Anotações do Hibernate</emphasis>, como um download "
+"separado. Ambos os EJB3 (JSR-220) e o metadado Hibernate3 são suportados. "
 
 #. Tag: para
-#: basic_mapping.xml:2883
 #, no-c-format
 msgid "This is an example of a POJO class annotated as an EJB entity bean:"
-msgstr "This is an example of a POJO class annotated as an EJB entity bean:"
-
-#. Tag: programlisting
-#: basic_mapping.xml:2887
-#, no-c-format
-msgid ""
-"<![CDATA[@Entity(access = AccessType.FIELD)\n"
-"public class Customer implements Serializable {\n"
-"\n"
-"    @Id;\n"
-"    Long id;\n"
-"\n"
-"    String firstName;\n"
-"    String lastName;\n"
-"    Date birthday;\n"
-"\n"
-"    @Transient\n"
-"    Integer age;\n"
-"\n"
-"    @Embedded\n"
-"    private Address homeAddress;\n"
-"\n"
-"    @OneToMany(cascade=CascadeType.ALL)\n"
-"    @JoinColumn(name=\"CUSTOMER_ID\")\n"
-"    Set<Order> orders;\n"
-"\n"
-"    // Getter/setter and business methods\n"
-"}]]>"
 msgstr ""
+"Este é um exemplo de uma classe POJO anotado como um bean de entidade EJB:"
 
 #. Tag: para
-#: basic_mapping.xml:2891
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Support for JDK 5.0 Annotations (and JSR-220) is currently under "
 "development. Please refer to the Hibernate Annotations module for more "
 "details."
 msgstr ""
-"Note that support for JDK 5.0 Annotations (and JSR-220) is still work in "
-"progress and not completed. Please refer to the Hibernate Annotations module "
-"for more details."
+"Note que o suporte para Anotações JDK 5.0 (e JSR-220) ainda está em "
+"construção. Consulte o módulo de Anotações do Hibernate para maiores "
+"detalhes.  "
 
 #. Tag: title
-#: basic_mapping.xml:2901
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Generated properties"
-msgstr "Generated Properties"
+msgstr "Propriedades geradas "
 
 #. Tag: para
-#: basic_mapping.xml:2902
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Generated properties are properties that have their values generated by the "
 "database. Typically, Hibernate applications needed to <literal>refresh</"
@@ -5689,17 +4229,16 @@
 "an SQL INSERT or UPDATE for an entity that has defined generated properties, "
 "it immediately issues a select afterwards to retrieve the generated values."
 msgstr ""
-"Generated properties are properties which have their values generated by the "
-"database. Typically, Hibernate applications needed to <literal>refresh</"
-"literal> objects which contain any properties for which the database was "
-"generating values. Marking properties as generated, however, lets the "
-"application delegate this responsibility to Hibernate. Essentially, whenever "
-"Hibernate issues an SQL INSERT or UPDATE for an entity which has defined "
-"generated properties, it immediately issues a select afterwards to retrieve "
-"the generated values."
+"Propriedades Geradas são propriedades que possuem seus valores gerados pelo "
+"banco de dados. Como sempre, os aplicativos do Hibernate precisavam "
+"<literal>renovar</literal> objetos que contenham qualquer propriedade para "
+"qual o banco de dados estivesse gerando valores. No entanto, vamos permitir "
+"que o aplicativo delegue esta responsabilidade ao Hibernate. Essencialmente, "
+"quando o Hibernate edita um SQL INSERT ou UPDATE para uma entidade que tem "
+"propriedades geradas definidas, ele edita imediatamente depois uma seleção "
+"para recuperar os valores gerados."
 
 #. Tag: para
-#: basic_mapping.xml:2911
 #, fuzzy, no-c-format
 msgid ""
 "Properties marked as generated must additionally be non-insertable and non-"
@@ -5708,24 +4247,21 @@
 "and <link linkend=\"mapping-declaration-property\">simple properties</link>, "
 "can be marked as generated."
 msgstr ""
-"Properties marked as generated must additionally be non-insertable and non-"
-"updateable. Only <xref linkend=\"mapping-declaration-version\">versions</"
-"xref>, <xref linkend=\"mapping-declaration-timestamp\">timestamps</xref>, "
-"and <xref linkend=\"mapping-declaration-property\">simple properties</xref> "
-"can be marked as generated."
+"As propriedades marcadas como geradas devem ser não-inseríveis e não-"
+"atualizáveis. Somente <xref linkend=\"mapping-declaration-version\" />, "
+"<xref linkend=\"mapping-declaration-timestamp\" /> e <xref linkend=\"mapping-"
+"declaration-property\"/> podem ser marcadas como geradas."
 
 #. Tag: para
-#: basic_mapping.xml:2918
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>never</literal> (the default): the given property value is not "
 "generated within the database."
 msgstr ""
-"<literal>never</literal> (the default) - means that the given property value "
-"is not generated within the database."
+"<literal>never</literal> (padrão) - significa que o valor de propriedade "
+"dado não é gerado dentro do banco de dados.  "
 
 #. Tag: para
-#: basic_mapping.xml:2922
 #, fuzzy, no-c-format
 msgid ""
 "<literal>insert</literal>: the given property value is generated on insert, "
@@ -5735,32 +4271,73 @@
 "\">timestamp</link> properties can be marked as generated, this option is "
 "not available."
 msgstr ""
-"<literal>insert</literal> - states that the given property value is "
-"generated on insert, but is not regenerated on subsequent updates. Things "
-"like created-date would fall into this category. Note that even thought "
-"<xref linkend=\"mapping-declaration-version\">version</xref> and <xref "
-"linkend=\"mapping-declaration-timestamp\">timestamp</xref> properties can be "
-"marked as generated, this option is not available there..."
+"<literal>insert</literal>: informa que o valor de propriedade dado é gerado "
+"ao inserir, mas não é novamente gerado nas próximas atualizações. "
+"Propriedades do tipo data criada, se encaixam nesta categoria. Note que "
+"embora as propriedades <xref linkend=\"mapping-declaration-version\"/> e "
+"<xref linkend=\"mapping-declaration-timestamp\"/> podem ser marcadas como "
+"geradas, esta opção não está disponível."
 
 #. Tag: para
-#: basic_mapping.xml:2930
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>always</literal>: the property value is generated both on insert "
 "and on update."
 msgstr ""
-"<literal>always</literal> - states that the property value is generated both "
-"on insert and on update."
+"<literal>always</literal> - informa que o valor da propriedade é gerado "
+"tanto ao inserir quanto ao atualizar. "
 
 #. Tag: title
-#: basic_mapping.xml:2937
-#, fuzzy, no-c-format
+#, no-c-format
+msgid "Column read and write expressions"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Hibernate allows you to customize the SQL it uses to read and write the "
+"values of columns mapped to <link linkend=\"mapping-declaration-property"
+"\">simple properties</link>. For example, if your database provides a set of "
+"data encryption functions, you can invoke them for individual columns like "
+"this: <programlisting role=\"XML\">&lt;property name=\"creditCardNumber"
+"\"&gt; &lt;column name=\"credit_card_num\" read=\"decrypt(credit_card_num)\" "
+"write=\"encrypt(?)\"/&gt; &lt;/property&gt;</programlisting>"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Hibernate applies the custom expressions automatically whenever the property "
+"is referenced in a query. This functionality is similar to a derived-"
+"property <literal>formula</literal> with two differences:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"The property is backed by one or more columns that are exported as part of "
+"automatic schema generation."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "The property is read-write, not read-only."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"The <literal>write</literal> expression, if specified, must contain exactly "
+"one '?' placeholder for the value."
+msgstr ""
+
+#. Tag: title
+#, no-c-format
 msgid "Auxiliary database objects"
-msgstr "Auxiliary Database Objects"
+msgstr "Objetos de Banco de Dados Auxiliares "
 
 #. Tag: para
-#: basic_mapping.xml:2938
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Auxiliary database objects allow for the CREATE and DROP of arbitrary "
 "database objects. In conjunction with Hibernate's schema evolution tools, "
@@ -5771,144 +4348,40 @@
 "example, ALTERs, INSERTS, etc.). There are essentially two modes for "
 "defining auxiliary database objects:"
 msgstr ""
-"Allows CREATE and DROP of arbitrary database objects, in conjunction with "
-"Hibernate's schema evolution tools, to provide the ability to fully define a "
-"user schema within the Hibernate mapping files. Although designed "
-"specifically for creating and dropping things like triggers or stored "
-"procedures, really any SQL command that can be run via a <literal>java.sql."
-"Statement.execute()</literal> method is valid here (ALTERs, INSERTS, etc). "
-"There are essentially two modes for defining auxiliary database objects..."
+"Permite o uso dos comandos CREATE e DROP para criar e remover os objetos de "
+"banco de dados arbitrários. Juntamente às ferramentas de evolução do esquema "
+"do Hibernate, eles possuem a habilidade de definir completamente um esquema "
+"de usuário dentro dos arquivos de mapeamento do Hibernate. Embora criado "
+"especificamente para criar e remover algo como trigger ou procedimento "
+"armazenado, qualquer comando SQL que pode rodar através de um método "
+"<literal>java.sql.Statement.execute()</literal> é válido. Existem dois "
+"módulos essenciais para definir objetos de banco de dados auxiliares:"
 
 #. Tag: para
-#: basic_mapping.xml:2947
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The first mode is to explicitly list the CREATE and DROP commands in the "
 "mapping file:"
 msgstr ""
-"The first mode is to explicitly list the CREATE and DROP commands out in the "
-"mapping file:"
+"O primeiro módulo é para listar explicitamente os comandos CREATE e DROP no "
+"arquivo de mapeamento: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2951
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <create>CREATE TRIGGER my_trigger ...</create>\n"
-"        <drop>DROP TRIGGER my_trigger</drop>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2952
-#, fuzzy, no-c-format
-msgid ""
 "The second mode is to supply a custom class that constructs the CREATE and "
 "DROP commands. This custom class must implement the <literal>org.hibernate."
 "mapping.AuxiliaryDatabaseObject</literal> interface."
 msgstr ""
-"The second mode is to supply a custom class which knows how to construct the "
-"CREATE and DROP commands. This custom class must implement the <literal>org."
-"hibernate.mapping.AuxiliaryDatabaseObject</literal> interface."
+"O segundo módulo é para fornecer uma classe padrão que sabe como construir "
+"os comandos CREATE e DROP. Esta classe padrão deve implementar a interface "
+"<literal>org.hibernate.mapping.AuxiliaryDatabaseObject</literal>. "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2957
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <definition class=\"MyTriggerDefinition\"/>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2958
-#, fuzzy, no-c-format
-msgid ""
 "Additionally, these database objects can be optionally scoped so that they "
 "only apply when certain dialects are used."
 msgstr ""
-"Additionally, these database objects can be optionally scoped such that they "
-"only apply when certain dialects are used."
-
-#. Tag: programlisting
-#: basic_mapping.xml:2962
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <definition class=\"MyTriggerDefinition\"/>\n"
-"        <dialect-scope name=\"org.hibernate.dialect.Oracle9iDialect\"/>\n"
-"        <dialect-scope name=\"org.hibernate.dialect.Oracle10gDialect\"/>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#~ msgid ""
-#~ "<literal>type</literal> (optional): A name that indicates the Hibernate "
-#~ "type."
-#~ msgstr ""
-#~ "<literal>type</literal> (opcional): Um nome que indica o tipo no "
-#~ "Hibernate."
-
-#~ msgid ""
-#~ "<literal>cascade</literal> (optional): Specifies which operations should "
-#~ "be cascaded from the parent object to the associated object."
-#~ msgstr ""
-#~ "<literal>cascade</literal> (opcional): Especifica quais operações dever "
-#~ "ser em cascata do objeto pai para o objeto associado."
-
-#~ msgid ""
-#~ "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
-#~ "literal>): Specifies that updates to this property do or do not require "
-#~ "acquisition of the optimistic lock. In other words, dertermines if a "
-#~ "version increment should occur when this property is dirty."
-#~ msgstr ""
-#~ "<literal>optimistic-lock</literal> (opcional - valor default "
-#~ "<literal>true</literal>): Especifica se mudanças desta propriedade "
-#~ "requerem ou não travamento otimista. Em outras palavras, determina se um "
-#~ "incremento de versão deve ocorrer quando esta propriedade está suja."
-
-#~ msgid ""
-#~ "To understand the behaviour of various Java language-level objects with "
-#~ "respect to the persistence service, we need to classify them into two "
-#~ "groups:"
-#~ msgstr ""
-#~ "Para entender o comportamento de vários objetos em nível de linguagem de "
-#~ "Java a respeito do serviço de persistência, nós precisamos classificá-los "
-#~ "em dois grupos."
-
-#, fuzzy
-#~ msgid "<literal>class</literal>"
-#~ msgstr "<literal>all</literal> cverifica todas as colunas"
-
-#~ msgid "id"
-#~ msgstr "id"
-
-#~ msgid ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal>none</"
-#~ "literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers"
-#~ "\"/>"
-#~ msgstr ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal>none</"
-#~ "literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers"
-#~ "\"/>"
-
-#~ msgid ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal/>): See "
-#~ "<xref linkend=\"mapping-declaration-id-enhanced-optimizers\"/>"
-#~ msgstr ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal/>): See "
-#~ "<xref linkend=\"mapping-declaration-id-enhanced-optimizers\"/>"
-
-#~ msgid "key"
-#~ msgstr "key"
-
-#~ msgid "any"
-#~ msgstr "any"
+"Além disso, estes objetos de banco de dados podem ter um escopo opcional que "
+"só será aplicado quando certos dialetos forem utilizados.  "

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/batch.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/batch.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/batch.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,126 +1,200 @@
+# translation of batch.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: batch\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-19 07:46+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: batch.xml:29
 #, no-c-format
 msgid "Batch processing"
-msgstr "Processamento de lotes"
+msgstr "Processamento em lotes"
 
 #. Tag: para
-#: batch.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A naive approach to inserting 100,000 rows in the database using Hibernate "
 "might look like this:"
 msgstr ""
 "Uma alternativa para inserir 100.000 linhas no banco de dados usando o "
-"Hibernate pode ser a seguinte:"
+"Hibernate pode ser a seguinte: "
 
-#. Tag: programlisting
-#: batch.xml:36
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"}\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:38
-#, fuzzy, no-c-format
-msgid ""
 "This would fall over with an <literal>OutOfMemoryException</literal> "
 "somewhere around the 50,000th row. That is because Hibernate caches all the "
 "newly inserted <literal>Customer</literal> instances in the session-level "
 "cache. In this chapter we will show you how to avoid this problem."
 msgstr ""
-"Isto irá falhar em algum lugar próximo a linha 50.000, lançando uma "
-"<literal>OutOfMemoryException</literal>. Isso ocorre devido ao fato do "
-"Hibernate fazer cache de todas as instâncias de <literal>Customer</literal> "
-"inseridas num cachê em nível de sessão."
+"Isto irá falhar com um <literal>OutOfMemoryException</literal> em algum "
+"lugar próximo a linha 50.000. Isso ocorre devido ao fato do Hibernate fazer "
+"cache de todas as instâncias de <literal>Customer</literal> inseridas num "
+"cachê em nível de sessão. Nós demonstraremos neste capitulo como evitar este "
+"problema."
 
 #. Tag: para
-#: batch.xml:45
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are undertaking batch processing you will need to enable the use of "
 "JDBC batching. This is absolutely essential if you want to achieve optimal "
 "performance. Set the JDBC batch size to a reasonable number (10-50, for "
 "example):"
 msgstr ""
-"Neste capítulo veremos como contornar esse problema. Entretanto, se você vai "
-"realizar processamento de lotes, é muito importante que você habilite o uso "
-"de lotes JDBC, se você pretende obter um desempenho razoável. Defina o "
-"tamanho do lote JDBC em um valor razoável (algo entre 10-50):"
+"Entretanto, se você vai realizar processamento em lotes, é muito importante "
+"que você habilite o uso de lotes JDBC, se você pretende obter um desempenho "
+"razoável. Defina o tamanho do lote JDBC em um valor razoável (algo entre 10-"
+"50, por exemplo):"
 
-#. Tag: programlisting
-#: batch.xml:52
-#, no-c-format
-msgid "<![CDATA[hibernate.jdbc.batch_size 20]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate disables insert batching at the JDBC level transparently if you "
 "use an <literal>identity</literal> identifier generator."
 msgstr ""
-"Você também pode querer rodar esse tipo de processamento de lotes com o "
-"cache secundário completamente desabilitado:"
+"Note que o Hibernate desabilita o loteamento de inserção no nível JDBC de "
+"forma transparente se você utilizar um gerador de identificador "
+"<literal>identiy</literal>. "
 
 #. Tag: para
-#: batch.xml:59
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also do this kind of work in a process where interaction with the "
 "second-level cache is completely disabled:"
 msgstr ""
-"Note that Hibernate disables insert batching at the JDBC level transparently "
-"if you use an <literal>identiy</literal> identifier generator."
+"Você também pode querer rodar esse tipo de processamento em lotes com o "
+"cache secundário completamente desabilitado: "
 
-#. Tag: programlisting
-#: batch.xml:64
-#, no-c-format
-msgid "<![CDATA[hibernate.cache.use_second_level_cache false]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:66
 #, no-c-format
 msgid ""
 "However, this is not absolutely necessary, since we can explicitly set the "
 "<literal>CacheMode</literal> to disable interaction with the second-level "
 "cache."
 msgstr ""
-"Mas isto não é absolutamente necessário, desde que nós possamos ajustar o "
+"Mas isto não é absolutamente necessário, desde que possamos ajustar o "
 "<literal>CacheMode</literal> para desabilitar a interação com o cache "
 "secundário."
 
 #. Tag: title
-#: batch.xml:72
 #, no-c-format
 msgid "Batch inserts"
-msgstr "Inserção de lotes"
+msgstr "Inserção em lotes"
 
 #. Tag: para
-#: batch.xml:74
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When making new objects persistent <literal>flush()</literal> and then "
 "<literal>clear()</literal> the session regularly in order to control the "
@@ -128,81 +202,31 @@
 msgstr ""
 "Quando você estiver inserindo novos objetos persistentes, vocês deve "
 "executar os métodos <literal>flush()</literal> e <literal>clear()</literal> "
-"regularmente na sessão, para controlar o tamanho do cache primário."
+"regularmente na sessão, para controlar o tamanho do cache primário. "
 
-#. Tag: programlisting
-#: batch.xml:80
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"    if ( i % 20 == 0 ) { //20, same as the JDBC batch size\n"
-"        //flush a batch of inserts and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: title
-#: batch.xml:85
 #, no-c-format
 msgid "Batch updates"
-msgstr "Batch updates"
+msgstr "Atualização em lotes"
 
 #. Tag: para
-#: batch.xml:87
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For retrieving and updating data, the same ideas apply. In addition, you "
 "need to use <literal>scroll()</literal> to take advantage of server-side "
 "cursors for queries that return many rows of data."
 msgstr ""
-"Para recuperar e atualizar informações a mesma idéia é válida. "
-"Adicionalmente, pode precisar usar o <literal>scroll()</literal> para usar "
-"recursos no lado do servidor em queries que retornam muita informação."
+"Para recuperar e atualizar informações a mesma idéia é válida. Além disso, "
+"pode precisará usar o <literal>scroll()</literal> para usar recursos no lado "
+"do servidor em consultas que retornem muita informação. "
 
-#. Tag: programlisting
-#: batch.xml:93
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-"    .setCacheMode(CacheMode.IGNORE)\n"
-"    .scroll(ScrollMode.FORWARD_ONLY);\n"
-"int count=0;\n"
-"while ( customers.next() ) {\n"
-"    Customer customer = (Customer) customers.get(0);\n"
-"    customer.updateStuff(...);\n"
-"    if ( ++count % 20 == 0 ) {\n"
-"        //flush a batch of updates and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: title
-#: batch.xml:98
 #, no-c-format
 msgid "The StatelessSession interface"
-msgstr "A interface StatelessSession"
+msgstr "A interface de Sessão sem Estado"
 
 #. Tag: para
-#: batch.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, Hibernate provides a command-oriented API that can be used "
 "for streaming data to and from the database in the form of detached objects. "
@@ -218,55 +242,34 @@
 "effects. A stateless session is a lower-level abstraction that is much "
 "closer to the underlying JDBC."
 msgstr ""
-"Alternativamente, o Hibernate provê uma API orientada à comandos, usada para "
-"transmitir um fluxo de dados de e para o banco de dados na forma de objetos "
-"soltos. Uma <literal>StatelessSession</literal> não tem um contexto "
-"persistente associado e não fornece muito das semânticas de alto nível para "
-"controle do ciclo de vida. Em especial, uma StatelessSession não implemente "
-"o cache primário e nem interage com o cache secundário ou query cache. Ele "
-"não implementa salvamento transacional automatico ou checagem automática de "
-"mudanças. Operação realizadas usando uma StatelessSession não fazem nenhum "
-"tipo de cascade com as instancias associadas. As coleções são ignoradas por "
-"uma StatelessSession. Operações realizadas com um StatelessSession ignoram a "
-"arquitetura de eventos e os interceptadores. StatelessSession são "
-"vulneráveis aos efeitos do aliasing dos dados, devido a falta do cache "
-"primário. Uma StatelessSession é uma abstração de baixo nível, muito mais "
-"próxima do JDBC."
+"Como forma alternativa, o Hibernate provê uma API orientada à comandos, que "
+"pode ser usada para transmitir um fluxo de dados de e para o banco de dados "
+"na forma de objetos desanexados. Um <literal>StatelessSession</literal> não "
+"tem um contexto persistente associado e não fornece muito das semânticas de "
+"alto nível para controle do ciclo de vida. Especialmente uma Sessão sem "
+"Estado não implementa um cachê primário e nem interage com o cache "
+"secundário ou cachê de consulta. Ela não implementa uma gravação temporária "
+"transacional ou checagem suja automática. Operações realizadas usando uma "
+"sessão sem estado não fazem nenhum tipo de cascata com as instâncias "
+"associadas. As coleções são ignoradas por uma Sessão sem Estado. Operações "
+"realizadas com uma Sessão sem Estado ignoram a arquitetura de eventos e os "
+"interceptadores. As sessões sem estado são vulneráveis aos efeitos do alias "
+"dos dados, devido à falta do cachê primário. Uma Sessão sem Estado é uma "
+"abstração de baixo nível, muito mais próxima do JDBC adjacente. "
 
-#. Tag: programlisting
-#: batch.xml:114
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[StatelessSession session = sessionFactory.openStatelessSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-"    .scroll(ScrollMode.FORWARD_ONLY);\n"
-"while ( customers.next() ) {\n"
-"    Customer customer = (Customer) customers.get(0);\n"
-"    customer.updateStuff(...);\n"
-"    session.update(customer);\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:116
-#, fuzzy, no-c-format
-msgid ""
 "In this code example, the <literal>Customer</literal> instances returned by "
 "the query are immediately detached. They are never associated with any "
 "persistence context."
 msgstr ""
-"Veja neste exempo, as instancias de <literal>Customer</literal> retornadas "
-"pela query são imediatamente desvinculadas. Elas nunca serão assossiadas à "
-"um contexto persistente."
+"Veja neste exempo, as instâncias de <literal>Customer</literal> retornadas "
+"pela consulta, são imediatamente desvinculadas. Elas nunca serão associadas "
+"à um contexto persistente. "
 
 #. Tag: para
-#: batch.xml:122
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>insert(), update()</literal> and <literal>delete()</literal> "
 "operations defined by the <literal>StatelessSession</literal> interface are "
@@ -277,22 +280,20 @@
 "operations defined by the <literal>Session</literal> interface."
 msgstr ""
 "As operações <literal>insert(), update()</literal> e <literal>delete()</"
-"literal> definidos pela interface <literal>StatelessSession</literal> são "
-"considerados operações diretas no banco de dados (row-level operations), "
-"isso resulta em uma execução imediata de comandos SQL <literal>INSERT, "
-"UPDATE</literal> ou <literal>DELETE</literal> respectivamente. Devido a "
-"isso, eles possuem uma semântica bem diferente das operações <literal>save"
-"(), saveOrUpdate()</literal> ou <literal>delete()</literal> definidas na "
-"interface <literal>Session</literal>."
+"literal> definidas pela interface <literal>StatelessSession</literal> são "
+"considerados operações diretas no banco de dados. Isto resulta em uma "
+"execução imediata de comandos SQL <literal>INSERT, UPDATE</literal> ou "
+"<literal>DELETE</literal> respectivamente. Dessa forma, eles possuem uma "
+"semântica bem diferente das operações <literal>save(), saveOrUpdate()</"
+"literal> ou <literal>delete()</literal> definidas na interface "
+"<literal>Session</literal>. "
 
 #. Tag: title
-#: batch.xml:135
 #, no-c-format
 msgid "DML-style operations"
 msgstr "Operações no estilo DML"
 
 #. Tag: para
-#: batch.xml:137
 #, fuzzy, no-c-format
 msgid ""
 "As already discussed, automatic and transparent object/relational mapping is "
@@ -305,76 +306,71 @@
 "is performed through the Hibernate Query Language (<link linkend=\"queryhql"
 "\">HQL</link>)."
 msgstr ""
-"Como já discutido, mapeamento objeto/relacional automático e transparente é "
-"conseguido com a gerência do estado do objeto. Com isto o estado daquele "
-"objeto fica disponível na memória, manipulando(usando as expressões SQL "
-"<literal>Data Manipulation Language</literal> (SQL-style DML): "
-"<literal>INSERT</literal>, <literal>UPDATE</literal>, <literal>DELETE</"
-"literal>) os dados diretamente no banco de dados não irá afetar o estado "
-"registrado em memória. Entretanto, o Hibernate provê métodos para executar "
-"queries SQL-style DML, que são totalmente executas com HQL (Hibernate Query "
-"Language) (<xref linkend=\"queryhql\">HQL</xref>)."
+"Como já discutido anteriormente, o mapeamento objeto/relacional automático e "
+"transparente é adquirido com a gerência do estado do objeto. Com isto o "
+"estado daquele objeto fica disponível na memória. Isto significa que a "
+"manipulação de dados (usando as instruções SQL <literal>Data Manipulation "
+"Language</literal> (SQL-style DML): <literal>INSERT</literal>, "
+"<literal>UPDATE</literal>, <literal>DELETE</literal>) diretamente no banco "
+"de dados não irá afetar o estado registrado em memória. Entretanto, o "
+"Hibernate provê métodos para executar instruções de volume de SQL-style DML, "
+"que são totalmente executados com HQL (Hibernate Query Language - Linguagem "
+"de Consulta Hibernate) (<xref linkend=\"queryhql\"/>). "
 
 #. Tag: para
-#: batch.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The pseudo-syntax for <literal>UPDATE</literal> and <literal>DELETE</"
 "literal> statements is: <literal>( UPDATE | DELETE ) FROM? EntityName (WHERE "
 "where_conditions)?</literal>."
 msgstr ""
-"A pseudo-sintaxe para expressões <literal>UPDATE</literal> e "
-"<literal>DELETE</literal> é: <literal>( UPDATE | DELETE ) FROM? NomeEntidade "
-"(WHERE condições_where)?</literal>. Algumas observações:"
+"A pseudo-sintaxe para instruções <literal>UPDATE</literal> e "
+"<literal>DELETE</literal> é: Algumas observações: <literal>( UPDATE | "
+"DELETE ) FROM? EntityName (WHERE where_conditions)?</literal>."
 
 #. Tag: para
-#: batch.xml:151
 #, no-c-format
 msgid "Some points to note:"
-msgstr ""
+msgstr "Alguns pontos a serem destacados:"
 
 #. Tag: para
-#: batch.xml:157
 #, no-c-format
 msgid "In the from-clause, the FROM keyword is optional"
-msgstr "Na clausula from, a palavra chave FROM é opcional;"
+msgstr "Na cláusula from, a palavra chave FROM é opcional;"
 
 #. Tag: para
-#: batch.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There can only be a single entity named in the from-clause. It can, however, "
 "be aliased. If the entity name is aliased, then any property references must "
 "be qualified using that alias. If the entity name is not aliased, then it is "
 "illegal for any property references to be qualified."
 msgstr ""
-"Somente uma entidade pode ser chamada na clausula from; opcionalmente pode "
-"ter um alias. Se o nome da entidade for possuir um alias, então qualquer "
-"propriedade referenciada deve usar esse alias qualificado; se o nome da "
-"entidade não possuir um alias, então nenhuma das propriedade precisa usar o "
-"acesso qualificado."
+"Somente uma entidade pode ser chamada na cláusula from. Isto pode, "
+"opcionalmente, ser um alias. Se o nome da entidade for um alias, então "
+"qualquer referência de propriedade deve ser qualificada usando esse alias. "
+"Caso o nome da entidade não for um alias, então será ilegal qualquer das "
+"referências de propriedade serem qualificadas."
 
 #. Tag: para
-#: batch.xml:170
 #, fuzzy, no-c-format
 msgid ""
 "No <link linkend=\"queryhql-joins-forms\">joins</link>, either implicit or "
 "explicit, can be specified in a bulk HQL query. Sub-queries can be used in "
 "the where-clause, where the subqueries themselves may contain joins."
 msgstr ""
-"Na <xref linkend=\"queryhql-joins-forms\">joins</xref> (ambas implícita ou "
-"explicita) pode ser especificada em um bulk HQL query. Sub-queries podem ser "
-"usadas na clausula where; as subqueries podem conter joins."
+"Nenhum <xref linkend=\"queryhql-joins-forms\" />, tanto implícito ou "
+"explícito, pode ser especificado em uma consulta de volume HQL. As Sub-"
+"consultas podem ser utilizadas na cláusula onde, em que as subconsultas "
+"podem conter uniões. "
 
 #. Tag: para
-#: batch.xml:177
 #, no-c-format
 msgid "The where-clause is also optional."
-msgstr "A clausula where também é opcional."
+msgstr "A clausula onde também é opcional."
 
 #. Tag: para
-#: batch.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As an example, to execute an HQL <literal>UPDATE</literal>, use the "
 "<literal>Query.executeUpdate()</literal> method. The method is named for "
@@ -382,31 +378,11 @@
 "literal>:"
 msgstr ""
 "Como exemplo para executar um HQL <literal>UPDATE</literal>, use o método "
-"<literal>Query.executeUpdate()</literal>(o método ganhou o nome devido a sua "
-"familiaridade com o do JDBC <literal>PreparedStatement.executeUpdate()</"
+"<literal>Query.executeUpdate()</literal>. O método ganhou o nome devido à "
+"sua familiaridade com o do JDBC <literal>PreparedStatement.executeUpdate()</"
 "literal>):"
 
-#. Tag: programlisting
-#: batch.xml:189
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlUpdate = \"update Customer c set c.name = :newName where c.name = :"
-"oldName\";\n"
-"// or String hqlUpdate = \"update Customer set name = :newName where name = :"
-"oldName\";\n"
-"int updatedEntities = s.createQuery( hqlUpdate )\n"
-"        .setString( \"newName\", newName )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:191
 #, fuzzy, no-c-format
 msgid ""
 "In keeping with the EJB3 specification, HQL <literal>UPDATE</literal> "
@@ -419,46 +395,27 @@
 "<literal>VERSIONED</literal> keyword after the <literal>UPDATE</literal> "
 "keyword."
 msgstr ""
-"HQL <literal>UPDATE</literal> statements, by default do not effect the <xref "
-"linkend=\"mapping-declaration-version\">version</xref> or the <xref linkend="
-"\"mapping-declaration-timestamp\">timestamp</xref> property values for the "
-"affected entities; this is in keeping with the EJB3 specification. However, "
-"you can force Hibernate to properly reset the <literal>version</literal> or "
-"<literal>timestamp</literal> property values through the use of a "
-"<literal>versioned update</literal>. This is achieved by adding the "
-"<literal>VERSIONED</literal> keyword after the <literal>UPDATE</literal> "
-"keyword."
+"As instruções do HQL <literal>UPDATE</literal> por padrão não afetam o <xref "
+"linkend=\"mapping-declaration-version\"/> ou os valores de propriedade <xref "
+"linkend=\"mapping-declaration-timestamp\"/> para as entidades afetadas, de "
+"acordo com a especificação EJB3. No entanto, você poderá forçar o Hibernate "
+"a redefinir corretamente os valores de propriedade <literal>version</"
+"literal> ou <literal>timestamp</literal> usando um <literal>versioned "
+"update</literal>. Para tal, adicione uma palavra chave <literal>VERSIONED</"
+"literal> após a palavra chave <literal>UPDATE</literal>. "
 
-#. Tag: programlisting
-#: batch.xml:201
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"String hqlVersionedUpdate = \"update versioned Customer set name = :newName "
-"where name = :oldName\";\n"
-"int updatedEntities = s.createQuery( hqlUpdate )\n"
-"        .setString( \"newName\", newName )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:203
-#, fuzzy, no-c-format
-msgid ""
 "Custom version types, <literal>org.hibernate.usertype.UserVersionType</"
 "literal>, are not allowed in conjunction with a <literal>update versioned</"
 "literal> statement."
 msgstr ""
-"Note that custom version types (<literal>org.hibernate.usertype."
-"UserVersionType</literal>) are not allowed in conjunction with a "
-"<literal>update versioned</literal> statement."
+"Note que os tipos de versões padronizadas, <literal>org.hibernate.usertype."
+"UserVersionType</literal>, não são permitidos junto às instruções "
+"<literal>update versioned</literal>."
 
 #. Tag: para
-#: batch.xml:208
 #, no-c-format
 msgid ""
 "To execute an HQL <literal>DELETE</literal>, use the same <literal>Query."
@@ -467,26 +424,9 @@
 "Para executar um HQL <literal>DELETE</literal>, use o mesmo método "
 "<literal>Query.executeUpdate()</literal>:"
 
-#. Tag: programlisting
-#: batch.xml:213
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlDelete = \"delete Customer c where c.name = :oldName\";\n"
-"// or String hqlDelete = \"delete Customer where name = :oldName\";\n"
-"int deletedEntities = s.createQuery( hqlDelete )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:215
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>int</literal> value returned by the <literal>Query.executeUpdate"
 "()</literal> method indicates the number of entities effected by the "
 "operation. This may or may not correlate to the number of rows effected in "
@@ -499,31 +439,29 @@
 "joined-subclass tables further down the inheritance hierarchy."
 msgstr ""
 "O valor <literal>int</literal> retornado pelo método <literal>Query."
-"executeUpdate()</literal> indica o numero de entidade afetadas pela "
+"executeUpdate()</literal> indica o número de entidade afetadas pela "
 "operação. Lembre-se que isso pode estar ou não relacionado ao número de "
-"linhas alteradas no banco de dados. Uma operação bulk HQL pode resultar em "
-"várias expressões SQL reais a serem executadas, por exemplo, no caso de "
-"joined-subclass. O número retornado indica a quantidade real de entidades "
-"afetadas pela expressão. Voltando ao exemplo da joined-subclass, a exclusão "
+"linhas alteradas no banco de dados. Uma operação de volume HQL pode resultar "
+"em várias instruções SQL atuais a serem executadas (por exemplo, no caso de "
+"subclasses unidas). O número retornado indica a quantidade real de entidades "
+"afetadas pela instrução. Voltando ao exemplo da subclasse unida, a exclusão "
 "de uma das subclasses pode resultar numa exclusão em outra tabelas, não "
 "apenas na tabela para qual a subclasses está mapeada, mas também tabela "
-"\"root\" e possivelmente nas tabelas joined-subclass num nível hierárquico "
-"imediatamente abaixo."
+"\"root\" e possivelmente nas tabelas de subclasses unidas num nível "
+"hierárquico imediatamente abaixo. "
 
 #. Tag: para
-#: batch.xml:226
 #, no-c-format
 msgid ""
 "The pseudo-syntax for <literal>INSERT</literal> statements is: "
 "<literal>INSERT INTO EntityName properties_list select_statement</literal>. "
 "Some points to note:"
 msgstr ""
-"A pseudo-sintaxe para o comando <literal>INSERT</literal> é: <literal>INSERT "
+"A pseudo-sintáxe para o comando <literal>INSERT</literal> é: <literal>INSERT "
 "INTO EntityName properties_list select_statement</literal>. Alguns pontos a "
 "observar:"
 
 #. Tag: para
-#: batch.xml:234
 #, no-c-format
 msgid ""
 "Only the INSERT INTO ... SELECT ... form is supported; not the INSERT "
@@ -533,8 +471,7 @@
 "VALUES ... não é suportada."
 
 #. Tag: para
-#: batch.xml:237
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The properties_list is analogous to the <literal>column specification</"
 "literal> in the SQL <literal>INSERT</literal> statement. For entities "
@@ -543,16 +480,15 @@
 "are not allowed and subclass properties do not make sense. In other words, "
 "<literal>INSERT</literal> statements are inherently non-polymorphic."
 msgstr ""
-"A lista de propriedade é análoga à <literal>especificação da coluna</"
-"literal> do comando SQL <literal>INSERT</literal>. Para entidades envolvidas "
-"em mapeamentos, apenas a propriedades definidas diretamente a nível da "
-"classe podem ser usandas na properties_list. Propriedades da superclass não "
-"são permitidas; e as propriedades da subclasse não faz sentido. Em outras "
-"palavras, os comandos <literal>INSERT</literal> não são polimorficos."
+"A lista de propriedade é análoga ao <literal>column specification</literal> "
+"do comando SQL <literal>INSERT</literal>. Para entidades envolvidas em "
+"mapeamentos, apenas as propriedades definidas diretamente em nível da classe "
+"podem ser usadas na properties_list. Propriedades da superclasse não são "
+"permitidas e as propriedades da subclasse não fazem sentido. Em outras "
+"palavras, os comandos <literal>INSERT</literal> não são polimórficos. "
 
 #. Tag: para
-#: batch.xml:247
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "select_statement can be any valid HQL select query, with the caveat that the "
 "return types must match the types expected by the insert. Currently, this is "
@@ -565,20 +501,20 @@
 "TimestampType</literal>, even though the database might not make a "
 "distinction or might be able to handle the conversion."
 msgstr ""
-"O camando select pode ser qualquer query HQL válida, que tenha um retorno "
-"compatível com o tipo com o esperado pela inclusão. Atualmente, isto é "
-"verificado durante a compilação da query, isto é melhor do que permitir que "
-"a verificação chegue ao banco de dados. Entretanto perceba que isso pode "
-"causar problemas entre os <literal>Tipo</literal> do Hibernate que são "
-"<emphasis>equivalentes</emphasis> em oposição a <emphasis>equal</emphasis>. "
-"Isso pode causar problemas nas combinações entre a propriedade definida como "
-"<literal>org.hibernate.type.DateType</literal>e um propriedade definida como "
-"<literal>org.hibernate.type.TimestampType</literal>, embora o banco de dados "
-"não possa fazer uma distinção ou possa ser capaz de manusear a conversão."
+"selecionar_instruções pode ser qualquer consulta de seleção HQL válida, "
+"desde que os tipos de retorno sejam compatíveis com os tipos esperados pela "
+"inserção. Atualmente, isto é verificado durante a compilação da consulta, ao "
+"invés de permitir que a verificação chegue ao banco de dados. Entretanto, "
+"perceba que isso pode causar problemas entre os <literal>Tipo</literal>s de "
+"Hibernate que são <emphasis>equivalentes</emphasis> e não <emphasis>iguais</"
+"emphasis>. Isso pode causar problemas nas combinações entre a propriedade "
+"definida como <literal>org.hibernate.type.DateType</literal>e uma "
+"propriedade definida como <literal>org.hibernate.type.TimestampType</"
+"literal>, embora o banco de dados não possa fazer uma distinção ou possa ser "
+"capaz de manusear a conversão."
 
 #. Tag: para
-#: batch.xml:259
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For the id property, the insert statement gives you two options. You can "
 "either explicitly specify the id property in the properties_list, in which "
@@ -594,23 +530,22 @@
 "TableHiLoGenerator</literal>, which cannot be used because it does not "
 "expose a selectable way to get its values."
 msgstr ""
-"Para a propriedade id, a expressão insert oferece duas opções. Você pode "
+"Para a propriedade id, a instrução insert oferece duas opções. Você pode "
 "especificar qualquer propriedade id explicitamente no properties_list (em "
-"alguns casos esse valor é obtido diretamente da expressão select) ou pode "
-"omitir do properties_list (nesse caso, um valor gerado é usado). Essa ultima "
+"alguns casos esse valor é obtido diretamente da instrução select) ou pode "
+"omitir do properties_list (nesse caso, um valor gerado é usado). Essa última "
 "opção só é válida quando são usados geradores de ids que operam no banco de "
 "dados; a tentativa de usar essa opção com geradores do tipo \"em memória\" "
-"vai causar um exceção durante a etapa de parser. Veja a finalidades desta "
-"discussão, os seguintes geradores operam com o banco de dados <literal>org."
-"hibernate.id.SequenceGenerator</literal> (e suas subclasses) e qualquer "
-"implementação de <literal>org.hibernate.id.PostInsertIdentifierGenerator</"
-"literal>. Aqui, a exceção mais notável é o <literal>org.hibernate.id."
-"TableHiLoGenerator</literal>, que não pode ser usado porque ele não dispõe "
-"de mecanismos para recuperar o seu valor."
+"irá causar um exceção durante a etapa de análise. Note que para a finalidade "
+"desta discussão, os seguintes geradores operam com o banco de dados "
+"<literal>org.hibernate.id.SequenceGenerator</literal> (e suas subclasses) e "
+"qualquer implementação de <literal>org.hibernate.id."
+"PostInsertIdentifierGenerator</literal>. Aqui, a exceção mais notável é o "
+"<literal>org.hibernate.id.TableHiLoGenerator</literal>, que não pode ser "
+"usado porque ele não dispõe de mecanismos para recuperar os seus valores."
 
 #. Tag: para
-#: batch.xml:274
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For properties mapped as either <literal>version</literal> or "
 "<literal>timestamp</literal>, the insert statement gives you two options. "
@@ -619,39 +554,18 @@
 "from the properties_list, in which case the <literal>seed value</literal> "
 "defined by the <literal>org.hibernate.type.VersionType</literal> is used."
 msgstr ""
-"For properties mapped as either <literal>version</literal> or "
-"<literal>timestamp</literal>, the insert statement gives you two options. "
-"You can either specify the property in the properties_list (in which case "
-"its value is taken from the corresponding select expressions) or omit it "
-"from the properties_list (in which case the <literal>seed value</literal> "
-"defined by the <literal>org.hibernate.type.VersionType</literal> is used). "
 "Para propriedades mapeadas como <literal>version</literal> ou "
-"<literal>timestamp</literal>, a expressão insert oferece a você duas opções. "
-"Você pode especificar a propriedade na properties_list (nesse caso o seu "
-"valor é obtido a partir da expressão select correspondente) ou ele pode ser "
-"omitido da properties_list (neste caso o usa o <literal>valor semente</"
+"<literal>timestamp</literal>, a instrução insert lhe oferece duas opções. "
+"Você pode especificar a propriedade na properties_list, nesse caso o seu "
+"valor é obtido a partir da instrução select correspondente, ou ele pode ser "
+"omitido da properties_list (neste caso utiliza-se o <literal>seed value</"
 "literal> definido pela classe <literal>org.hibernate.type.VersionType</"
 "literal>)."
 
 #. Tag: para
-#: batch.xml:284
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is an example of an HQL <literal>INSERT</literal> statement "
 "execution:"
-msgstr "Exemplo da execução de um HQL <literal>INSERT</literal>:"
-
-#. Tag: programlisting
-#: batch.xml:288
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlInsert = \"insert into DelinquentAccount (id, name) select c.id, c."
-"name from Customer c where ...\";\n"
-"int createdEntities = s.createQuery( hqlInsert )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
 msgstr ""
+"Segue abaixo o exemplo da execução de um HQL <literal>INSERT</literal>:"

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/best_practices.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/best_practices.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/best_practices.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,33 +1,137 @@
+# translation of best_practices.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: best_practices\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-10-22 15:53+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: best_practices.xml:29
 #, no-c-format
 msgid "Best Practices"
-msgstr "Boas práticas"
+msgstr "Melhores práticas"
 
 #. Tag: term
-#: best_practices.xml:33
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Write fine-grained classes and map them using <literal>&lt;component&gt;</"
 "literal>:"
 msgstr ""
 "Escreva classes compactas e mapeie-as usando <literal>&lt;component&gt;</"
-"literal>."
+"literal>:"
 
 #. Tag: para
-#: best_practices.xml:35
 #, no-c-format
 msgid ""
 "Use an <literal>Address</literal> class to encapsulate <literal>street</"
@@ -35,38 +139,33 @@
 "<literal>postcode</literal>. This encourages code reuse and simplifies "
 "refactoring."
 msgstr ""
-"Use uma classe <literal>Endereco</literal> para encapsular <literal>rua</"
+"Use uma classe <literal>Endereço</literal> para encapsular <literal>rua</"
 "literal>, <literal>bairro</literal>, <literal>estado</literal>, "
 "<literal>CEP</literal>. Isto promove a reutilização de código e simplifica o "
 "refactoring."
 
 #. Tag: term
-#: best_practices.xml:43
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Declare identifier properties on persistent classes:"
-msgstr "Declare propriedades identificadoras em classes persistentes."
+msgstr "Declare propriedades identificadoras em classes persistentes:"
 
 #. Tag: para
-#: best_practices.xml:45
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate makes identifier properties optional. There are a range of reasons "
 "why you should use them. We recommend that identifiers be 'synthetic', that "
 "is, generated with no business meaning."
 msgstr ""
-"O Hibernate constrói propriedades identificadoras opcionais. Existem todos "
-"os tipos de razões que explicam porquê você deveria utilizá-las. Nós "
-"recomendamos que os identificadores sejam 'sintéticos' (gerados, sem "
-"significado para o negocio)."
+"O Hibernate constrói propriedades identificadoras opcionais. Existem "
+"inúmeras razões para utilizá-las. Nós recomendamos que os identificadores "
+"sejam 'sintéticos', quer dizer, gerados sem significado para negócios. "
 
 #. Tag: term
-#: best_practices.xml:53
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Identify natural keys:"
-msgstr "Identifique chaves naturais."
+msgstr "Identifique chaves naturais:"
 
 #. Tag: para
-#: best_practices.xml:55
 #, no-c-format
 msgid ""
 "Identify natural keys for all entities, and map them using <literal>&lt;"
@@ -80,62 +179,54 @@
 "compõem a chave natural."
 
 #. Tag: term
-#: best_practices.xml:63
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Place each class mapping in its own file:"
-msgstr "Coloque cada classe de mapeamento em seu próprio arquivo."
+msgstr "Coloque cada classe de mapeamento em seu próprio arquivo:"
 
 #. Tag: para
-#: best_practices.xml:65
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not use a single monolithic mapping document. Map <literal>com.eg.Foo</"
 "literal> in the file <literal>com/eg/Foo.hbm.xml</literal>. This makes "
 "sense, particularly in a team environment."
 msgstr ""
 "Não use um único código de mapeamento monolítico. Mapeie <literal>com.eg."
-"Foo</literal> no arquivo <literal>com/eg/Foo.hbm.xml</literal>. Isto promove "
-"particularmente o bom senso no time de desenvolvimento."
+"Foo</literal> no arquivo <literal>com/eg/Foo.hbm.xml</literal>. Isto faz "
+"bastante sentido, especialmente em ambiente de equipe."
 
 #. Tag: term
-#: best_practices.xml:73
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Load mappings as resources:"
-msgstr "Carregue os mapeamentos como recursos."
+msgstr "Carregue os mapeamentos como recursos:"
 
 #. Tag: para
-#: best_practices.xml:75
 #, no-c-format
 msgid "Deploy the mappings along with the classes they map."
-msgstr "Faça o deploy dos mapeamentos junto com as classes que eles mapeiam."
+msgstr "Implemente os mapeamentos junto às classes que eles mapeiam."
 
 #. Tag: term
-#: best_practices.xml:81
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Consider externalizing query strings:"
-msgstr "Considere externalizar as strings de consultas."
+msgstr "Considere a possibilidade de externar as strings de consultas:"
 
 #. Tag: para
-#: best_practices.xml:83
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is recommended if your queries call non-ANSI-standard SQL functions. "
 "Externalizing the query strings to mapping files will make the application "
 "more portable."
 msgstr ""
 "Esta é uma boa prática se suas consultas chamam funções SQL que não sejam "
-"ANSI. Externalizar as strings de consultas para mapear arquivos irão tornar "
-"a aplicação mais portável."
+"ANSI. Externar as strings de consultas para mapear arquivos irá tornar a "
+"aplicação mais portável. "
 
 #. Tag: term
-#: best_practices.xml:91
 #, no-c-format
 msgid "Use bind variables."
-msgstr "Use bind variables."
+msgstr "Use variáveis de vínculo."
 
 #. Tag: para
-#: best_practices.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As in JDBC, always replace non-constant values by \"?\". Do not use string "
 "manipulation to bind a non-constant value in a query. You should also "
@@ -143,37 +234,34 @@
 msgstr ""
 "Assim como em JDBC, sempre substitua valores não constantes por \"?\". Nunca "
 "use a manipulação de strings para concatenar valores não constantes em uma "
-"consulta! Até melhor, considere usar parâmetros nomeados nas consultas."
+"consulta. Até melhor, considere a possibilidade de usar parâmetros nomeados "
+"nas consultas."
 
 #. Tag: term
-#: best_practices.xml:101
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Do not manage your own JDBC connections:"
-msgstr "Não gerencie suas conexões JDBC."
+msgstr "Não gerencie suas conexões JDBC:"
 
 #. Tag: para
-#: best_practices.xml:103
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate allows the application to manage JDBC connections, but his "
 "approach should be considered a last-resort. If you cannot use the built-in "
 "connection providers, consider providing your own implementation of "
 "<literal>org.hibernate.connection.ConnectionProvider</literal>."
 msgstr ""
-"O Hibernate permite que a aplicação gerencie conexões JDBC. Esta abordagem "
-"deve ser considerada um último recurso. Se você não pode usar os provedores "
-"de conexão embutidos, considere fazer sua implementação a partir de "
-"<literal>org.hibernate.connection.ConnectionProvider</literal>."
+"O Hibernate permite que a aplicação gerencie conexões JDBC, mas esta "
+"abordagem deve ser considerada um último recurso. Se você não pode usar os "
+"provedores de conexão embutidos, considere fazer sua implementação a partir "
+"de <literal>org.hibernate.connection.ConnectionProvider</literal>."
 
 #. Tag: term
-#: best_practices.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Consider using a custom type:"
-msgstr "Considere usar tipos customizados."
+msgstr "Considere a possibilidade de usar tipos customizados:"
 
 #. Tag: para
-#: best_practices.xml:113
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Suppose you have a Java type from a library that needs to be persisted but "
 "does not provide the accessors needed to map it as a component. You should "
@@ -182,46 +270,43 @@
 "from a Hibernate type."
 msgstr ""
 "Suponha que você tenha um tipo Java, de alguma biblioteca, que precisa ser "
-"persistido mas não provê os acessórios necessários para mapeá-lo como um "
+"persistido mas não provê de acessórios necessários para mapeá-lo como um "
 "componente. Você deve implementar <literal>org.hibernate.UserType</literal>. "
 "Esta abordagem livra o código da aplicação de implementar transformações de/"
-"para o tipo Hibernate."
+"para o tipo Hibernate. "
 
 #. Tag: term
-#: best_practices.xml:122
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Use hand-coded JDBC in bottlenecks:"
-msgstr "Use código manual JDBC nos gargalos."
+msgstr "Use código manual JDBC nos afunilamentos:"
 
 #. Tag: para
-#: best_practices.xml:124
 #, fuzzy, no-c-format
 msgid ""
 "In performance-critical areas of the system, some kinds of operations might "
 "benefit from direct JDBC. Do not assume, however, that JDBC is necessarily "
 "faster. Please wait until you <emphasis>know</emphasis> something is a "
 "bottleneck. If you need to use direct JDBC, you can open a Hibernate "
-"<literal>Session</literal> and usingfile:///usr/share/doc/HTML/en-US/index."
-"html that JDBC connection. This way you can still use the same transaction "
-"strategy and underlying connection provider."
+"<literal>Session</literal>, wrap your JDBC operation as a <literal>org."
+"hibernate.jdbc.Work</literal> object and using that JDBC connection. This "
+"way you can still use the same transaction strategy and underlying "
+"connection provider."
 msgstr ""
 "Nas áreas de desempenho crítico do sistema, alguns tipos de operações podem "
 "se beneficiar do uso direto do JDBC. Mas por favor, espere até você "
-"<emphasis>saber </emphasis> se é um gargalo. E não suponha que o uso direto "
-"do JDBC é necessariamente mais rápido. Se você precisar usar diretamente o "
-"JDBC, vale a pena abrir uma <literal>Session</literal> do Hibernate e usar "
-"uma conexão JDBC. De modo que você possa ainda usar a mesma estratégia de "
-"transação e ocultar o provedor a conexão"
+"<emphasis>saber</emphasis> se é um afunilamento. E não suponha que o uso "
+"direto do JDBC é necessariamente mais rápido. Se você precisar usar "
+"diretamente o JDBC, vale a pena abrir uma <literal>Session</literal> do "
+"Hibernate e usar uma conexão JDBC. De modo que você possa ainda usar a mesma "
+"estratégia de transação e ocultar o provedor a conexão."
 
 #. Tag: term
-#: best_practices.xml:134
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Understand <literal>Session</literal> flushing:"
-msgstr "Entenda o <literal>Session</literal> flushing."
+msgstr "Entenda o esvaziamento da <literal>Session</literal>:"
 
 #. Tag: para
-#: best_practices.xml:136
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes the Session synchronizes its persistent state with the database. "
 "Performance will be affected if this process occurs too often. You can "
@@ -231,20 +316,18 @@
 msgstr ""
 "De tempos em tempos a sessão sincroniza seu estado persistente com o banco "
 "de dados. O desempenho será afetado se este processo ocorrer frequentemente. "
-"Você pode algumas vezes minimizar o fluxo desnecessário desabilitando o "
-"fluxo automático ou até mesmo mudando a ordem das consultas e outras "
-"operações em uma transação particular."
+"Você pode algumas vezes minimizar a liberação desnecessária desabilitando a "
+"liberação automática ou até mesmo mudando a ordem das consultas e outras "
+"operações em uma transação particular. "
 
 #. Tag: term
-#: best_practices.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "In a three tiered architecture, consider using detached objects:"
 msgstr ""
-"Em uma arquitetura de três camadas, considere o uso de objetos separados."
+"Em uma arquitetura de três camadas, considere o uso de objetos separados:"
 
 #. Tag: para
-#: best_practices.xml:147
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When using a servlet/session bean architecture, you can pass persistent "
 "objects loaded in the session bean to and from the servlet/JSP layer. Use a "
@@ -252,22 +335,21 @@
 "or <literal>Session.saveOrUpdate()</literal> to synchronize objects with the "
 "database."
 msgstr ""
-"When using a servlet / session bean architecture, you could pass persistent "
-"objects loaded in the session bean to and from the servlet / JSP layer. Use "
-"a new session to service each request. Use <literal>Session.merge()</"
-"literal> or <literal>Session.saveOrUpdate()</literal> to synchronize objects "
-"with the database."
+"Ao usar a arquitetura do bean de sessão/servlet, você pode passar os objetos "
+"persistentes carregados no bean de sessão para e a partir da camada servlet/"
+"JSP. Use uma nova sessão para manipular cada solicitação. Use a "
+"<literal>Session.merge()</literal> ou a <literal>Session.saveOrUpdate()</"
+"literal> para sincronizar objetos com o banco de dados.  "
 
 #. Tag: term
-#: best_practices.xml:156
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "In a two tiered architecture, consider using long persistence contexts:"
 msgstr ""
-"In a two tiered architecture, consider using long persistence contexts."
+"Em uma arquitetura de duas camadas, considere o uso de contextos de longa "
+"persistência:"
 
 #. Tag: para
-#: best_practices.xml:158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Database Transactions have to be as short as possible for best scalability. "
 "However, it is often necessary to implement long running "
@@ -282,28 +364,26 @@
 "across more than one application transaction or you will be working with "
 "stale data."
 msgstr ""
-"Database Transactions have to be as short as possible for best scalability. "
-"However, it is often necessary to implement long running "
-"<emphasis>application transactions</emphasis>, a single unit-of-work from "
-"the point of view of a user. An application transaction might span several "
-"client request/response cycles. It is common to use detached objects to "
-"implement application transactions. An alternative, extremely appropriate in "
-"two tiered architecture, is to maintain a single open persistence contact "
-"(session) for the whole life cycle of the application transaction and simply "
-"disconnect from the JDBC connection at the end of each request and reconnect "
-"at the beginning of the subsequent request. Never share a single session "
-"across more than one application transaction, or you will be working with "
-"stale data."
+"As Transações do Banco de Dados precisam ser as mais curtas possíveis para "
+"uma melhor escalabilidade. No entanto, é geralmente necessário implementar "
+"<emphasis>transações de aplicações</emphasis> de longa duração, uma única "
+"unidade de trabalho a partir do ponto de vista de um usuário. Uma transação "
+"de aplicação pode transpor diversos ciclos de solicitação/resposta de "
+"cliente. É comum usar objetos desanexados para implementar as transações de "
+"aplicação. Uma outra alternativa, extremamente apropriada em uma arquitetura "
+"de duas camadas, é manter um único contato de persistência aberto (sessão) "
+"para todo o tempo de vida da transação de aplicação e simplesmente "
+"disconectá-lo do JDBC ao final de cada solicitação e reconectá-lo no início "
+"de uma solicitação subsequente. Nunca compartilhe uma sessão única com mais "
+"de uma transação de aplicação, ou você irá trabalhar com dados antigos."
 
 #. Tag: term
-#: best_practices.xml:172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Do not treat exceptions as recoverable:"
-msgstr "Don't treat exceptions as recoverable."
+msgstr "Não trate as exceções como recuperáveis:"
 
 #. Tag: para
-#: best_practices.xml:174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is more of a necessary practice than a \"best\" practice. When an "
 "exception occurs, roll back the <literal>Transaction</literal> and close the "
@@ -313,23 +393,22 @@
 "instance with the given identifier exists on the database; use "
 "<literal>Session.get()</literal> or a query instead."
 msgstr ""
-"This is more of a necessary practice than a \"best\" practice. When an "
-"exception occurs, roll back the <literal>Transaction</literal> and close the "
-"<literal>Session</literal>. If you don't, Hibernate can't guarantee that in-"
-"memory state accurately represents persistent state. As a special case of "
-"this, do not use <literal>Session.load()</literal> to determine if an "
-"instance with the given identifier exists on the database; use "
-"<literal>Session.get()</literal> or a query instead."
+"Isto é mais uma prática necessária do que uma \"melhor\" prática. Quando uma "
+"exceção ocorre, retorne à <literal>Transaction</literal> e feche a "
+"<literal>Sessão</literal>. Se não fizer isto, o Hibernate não poderá "
+"garantir que o estado em memória representará de forma precisa o estado "
+"persistente. Como este é um caso especial, não utilize a <literal>Session."
+"load()</literal> para determinar se uma instância com dado identificador "
+"existe em um banco de dados, use <literal>Session.get()</literal> ou então "
+"uma consulta. "
 
 #. Tag: term
-#: best_practices.xml:184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Prefer lazy fetching for associations:"
-msgstr "Prefer lazy fetching for associations."
+msgstr "Prefira a busca lazy para associações:"
 
 #. Tag: para
-#: best_practices.xml:186
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use eager fetching sparingly. Use proxies and lazy collections for most "
 "associations to classes that are not likely to be completely held in the "
@@ -339,27 +418,26 @@
 "to a particular use case, use a query with a <literal>left join fetch</"
 "literal>."
 msgstr ""
-"Use eager fetching sparingly. Use proxies and lazy collections for most "
-"associations to classes that are not likely to be completely held in the "
-"second-level cache. For associations to cached classes, where there is an a "
-"extremely high probability of a cache hit, explicitly disable eager fetching "
-"using <literal>lazy=\"false\"</literal>. When an join fetching is "
-"appropriate to a particular use case, use a query with a <literal>left join "
-"fetch</literal>."
+"Use a busca antecipada de forma moderada. Use as coleções proxy e lazy para "
+"a maioria das associações para classes que possam não ser completamente "
+"mantidas em cache de segundo nível. Para associações de classes em cache, "
+"onde existe uma enorme probabilidade de coincidir caches, desabilite "
+"explicitamente a busca antecipada usando <literal>lazy=\"false\"</literal>. "
+"Quando uma busca de união é apropriada para um caso específico, use a "
+"consulta com <literal>left join fetch</literal>."
 
 #. Tag: term
-#: best_practices.xml:196
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use the <emphasis>open session in view</emphasis> pattern, or a disciplined "
 "<emphasis>assembly phase</emphasis> to avoid problems with unfetched data:"
 msgstr ""
-"Use the <emphasis>open session in view</emphasis> pattern, or a disciplined "
-"<emphasis>assembly phase</emphasis> to avoid problems with unfetched data."
+"Use o modelo <emphasis>sessão aberta na visualização</emphasis>, ou uma "
+"<emphasis>fase de construção</emphasis> para evitar problemas com dados não "
+"encontrados."
 
 #. Tag: para
-#: best_practices.xml:201
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate frees the developer from writing tedious <emphasis>Data Transfer "
 "Objects</emphasis> (DTO). In a traditional EJB architecture, DTOs serve dual "
@@ -374,28 +452,28 @@
 "objects. This is not a limitation of Hibernate. It is a fundamental "
 "requirement of safe transactional data access."
 msgstr ""
-"Hibernate frees the developer from writing tedious <emphasis>Data Transfer "
-"Objects</emphasis> (DTO). In a traditional EJB architecture, DTOs serve dual "
-"purposes: first, they work around the problem that entity beans are not "
-"serializable; second, they implicitly define an assembly phase where all "
-"data to be used by the view is fetched and marshalled into the DTOs before "
-"returning control to the presentation tier. Hibernate eliminates the first "
-"purpose. However, you will still need an assembly phase (think of your "
-"business methods as having a strict contract with the presentation tier "
-"about what data is available in the detached objects) unless you are "
-"prepared to hold the persistence context (the session) open across the view "
-"rendering process. This is not a limitation of Hibernate! It is a "
-"fundamental requirement of safe transactional data access."
+"O Hibernate libera o desenvolvedor de escrever <emphasis>Objetos de "
+"Transferência de Dados</emphasis> (DTO). Em uma arquitetura tradicional EJB, "
+"os DTOs servem dois propósitos: primeiro, eles se deparam com o problema de "
+"que os beans de entidade não são serializáveis, depois, eles implicitamente "
+"definem uma fase de construção onde todos os dados a serem utilizados pelo "
+"view são buscados e conduzidos aos DTOs antes mesmo de retornar o controle à "
+"camada de apresentação. O Hibernate elimina o primeiro propósito. No "
+"entanto, você ainda precisará de uma fase de construção (pense em seus "
+"métodos de negócios como tendo um contrato estrito com a camada de "
+"apresentação sobre o quais dados estão disponíveis nos objetos desanexados) "
+"a não ser que você esteja preparado para manter o contexto de persistência "
+"(sessão) aberto no processo de renderização da visualização. Isto não é uma "
+"limitação do Hibernate. É uma solicitação fundamental para acesso a dados "
+"transacionais seguros."
 
 #. Tag: term
-#: best_practices.xml:215
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Consider abstracting your business logic from Hibernate:"
-msgstr "Consider abstracting your business logic from Hibernate."
+msgstr "Considere abstrair sua lógica comercial do Hibernate:"
 
 #. Tag: para
-#: best_practices.xml:217
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hide Hibernate data-access code behind an interface. Combine the "
 "<emphasis>DAO</emphasis> and <emphasis>Thread Local Session</emphasis> "
@@ -404,22 +482,20 @@
 "however, intended for \"sufficiently large\" applications. It is not "
 "appropriate for an application with five tables."
 msgstr ""
-"Hide (Hibernate) data-access code behind an interface. Combine the "
-"<emphasis>DAO</emphasis> and <emphasis>Thread Local Session</emphasis> "
-"patterns. You can even have some classes persisted by handcoded JDBC, "
-"associated to Hibernate via a <literal>UserType</literal>. (This advice is "
-"intended for \"sufficiently large\" applications; it is not appropriate for "
-"an application with five tables!)"
+"Oculte (Hibernate) o código de acesso a dados atrás de uma interface. "
+"Combine os modelos <emphasis>DAO</emphasis> e <emphasis>Sessão Local de "
+"Thread</emphasis>. Você pode também persistir algumas classes pelo JDBC "
+"handcoded, associado ao Hibernate via um  <literal>UserType</literal>. Este "
+"é um conselho para aplicações \"grandes o suficiente\", não é apropriado "
+"para uma aplicação com cinco tabelas."
 
 #. Tag: term
-#: best_practices.xml:227
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Do not use exotic association mappings:"
-msgstr "Don't use exotic association mappings."
+msgstr "Não use mapeamentos de associação exóticos:"
 
 #. Tag: para
-#: best_practices.xml:229
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Practical test cases for real many-to-many associations are rare. Most of "
 "the time you need additional information stored in the \"link table\". In "
@@ -428,27 +504,26 @@
 "to-one. For this reason, you should proceed cautiously when using any other "
 "association style."
 msgstr ""
-"Good usecases for a real many-to-many associations are rare. Most of the "
-"time you need additional information stored in the \"link table\". In this "
-"case, it is much better to use two one-to-many associations to an "
-"intermediate link class. In fact, we think that most associations are one-to-"
-"many and many-to-one, you should be careful when using any other association "
-"style and ask yourself if it is really neccessary."
+"Casos de testes práticos para associações muitos-para-muitos reais são "
+"raros. A maioria do tempo você precisa de informação adicional armazenada na "
+"\" tabela de link\". Neste caso, é muito melhor usar associações dois um-"
+"para-muitos para uma classe de link intermediário. Na verdade, acreditamos "
+"que a maioria das associações é um-para-muitos e muitos-para-um, você deve "
+"tomar cuidado ao utilizar qualquer outro tipo de associação e perguntar a "
+"você mesmo se é realmente necessário. "
 
 #. Tag: term
-#: best_practices.xml:239
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Prefer bidirectional associations:"
-msgstr "Prefer bidirectional associations."
+msgstr "Prefira associações bidirecionais:"
 
 #. Tag: para
-#: best_practices.xml:241
 #, no-c-format
 msgid ""
 "Unidirectional associations are more difficult to query. In a large "
 "application, almost all associations must be navigable in both directions in "
 "queries."
 msgstr ""
-"Unidirectional associations are more difficult to query. In a large "
-"application, almost all associations must be navigable in both directions in "
-"queries."
+"As associações unidirecionais são mais difíceis para pesquisar. Em "
+"aplicações grandes, quase todas as associações devem navegar nas duas "
+"direções em consultas. "

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/bibliography.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/bibliography.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/bibliography.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -5,7 +5,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: 2009-07-14 19:55+0000\n"
 "Last-Translator: Automatically generated\n"
 "Language-Team: none\n"
@@ -14,55 +14,36 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: bibliography.xml:27
 #, no-c-format
 msgid "References"
 msgstr ""
 
 #. Tag: title
-#: bibliography.xml:31
 #, no-c-format
 msgid "Patterns of Enterprise Application Architecture"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:34
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Martin</firstname> <surname>Fowler</surname>"
+msgid "Martin"
 msgstr ""
 
-#. Tag: holder
-#: bibliography.xml:41
-#, no-c-format
-msgid "Pearson Education, Inc."
-msgstr ""
-
 #. Tag: title
-#: bibliography.xml:50
 #, no-c-format
 msgid "Java Persistence with Hibernate"
 msgstr ""
 
 #. Tag: subtitle
-#: bibliography.xml:51
 #, no-c-format
 msgid "Second Edition of Hibernate in Action"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:57
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Christian</firstname> <surname>Bauer</surname>"
+msgid "Christian"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:61
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Gavin</firstname> <surname>King</surname>"
+msgid "Gavin"
 msgstr ""
-
-#. Tag: holder
-#: bibliography.xml:68
-#, no-c-format
-msgid "Manning Publications Co."
-msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/collection_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/collection_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/collection_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,56 +1,144 @@
+# translation of collection_mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: collection_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2009-12-19 08:32+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: collection_mapping.xml:29
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Collection mapping"
-msgstr "Collection mappings"
+msgstr "Mapeamento de coleção "
 
 #. Tag: title
-#: collection_mapping.xml:32
 #, no-c-format
 msgid "Persistent collections"
-msgstr "Persistent collections"
+msgstr "Coleções persistentes"
 
 #. Tag: para
-#: collection_mapping.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate requires that persistent collection-valued fields be declared as "
 "an interface type. For example:"
 msgstr ""
-"Hibernate requires that persistent collection-valued fields be declared as "
-"an interface type, for example:"
+"O Hibernate requer que os campos de coleções de valor persistente sejam "
+"declarados como um tipo de interface. Por exemplo:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:39
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[public class Product {\n"
-"    private String serialNumber;\n"
-"    private Set parts = new HashSet();\n"
-"    \n"
-"    public Set getParts() { return parts; }\n"
-"    void setParts(Set parts) { this.parts = parts; }\n"
-"    public String getSerialNumber() { return serialNumber; }\n"
-"    void setSerialNumber(String sn) { serialNumber = sn; }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:41
-#, fuzzy, no-c-format
-msgid ""
 "The actual interface might be <literal>java.util.Set</literal>, "
 "<literal>java.util.Collection</literal>, <literal>java.util.List</literal>, "
 "<literal>java.util.Map</literal>, <literal>java.util.SortedSet</literal>, "
@@ -58,16 +146,15 @@
 "like\" means you will have to write an implementation of <literal>org."
 "hibernate.usertype.UserCollectionType</literal>.)"
 msgstr ""
-"The actual interface might be <literal>java.util.Set</literal>, "
-"<literal>java.util.Collection</literal>, <literal>java.util.List</literal>, "
-"<literal>java.util.Map</literal>, <literal>java.util.SortedSet</literal>, "
-"<literal>java.util.SortedMap</literal> or ... anything you like! (Where "
-"\"anything you like\" means you will have to write an implementation of "
-"<literal>org.hibernate.usertype.UserCollectionType</literal>.)"
+"A interface atual pode ser <literal>java.util.Set</literal>, <literal>java."
+"util.Collection</literal>, <literal>java.util.List</literal>, <literal>java."
+"util.Map</literal>, <literal>java.util.SortedSet</literal>, <literal>java."
+"util.SortedMap</literal> ou o que desejar. (\"o que desejar\" significa que "
+"você terá que escrever uma implementação de <literal>org.hibernate.usertype."
+"UserCollectionType</literal>.)"
 
 #. Tag: para
-#: collection_mapping.xml:50
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Notice how the instance variable was initialized with an instance of "
 "<literal>HashSet</literal>. This is the best way to initialize collection "
@@ -77,46 +164,29 @@
 "an instance of Hibernate's own implementation of <literal>Set</literal>. Be "
 "aware of the following errors:"
 msgstr ""
-"Notice how we initialized the instance variable with an instance of "
-"<literal>HashSet</literal>. This is the best way to initialize collection "
-"valued properties of newly instantiated (non-persistent) instances. When you "
-"make the instance persistent - by calling <literal>persist()</literal>, for "
-"example - Hibernate will actually replace the <literal>HashSet</literal> "
-"with an instance of Hibernate's own implementation of <literal>Set</"
-"literal>. Watch out for errors like this:"
+"Observe como inicializamos a variável da instância com uma instância de "
+"<literal>HashSet</literal>. Esta é a melhor maneira de inicializar "
+"propriedades de coleções de valor de instâncias recentemente instanciadas "
+"(não persistentes). Quando você fizer uma instância persistente, chamando "
+"<literal>persist()</literal>, como por exemplo: o Hibernate substituirá o "
+"<literal>HashSet</literal> por uma instância da própria implementação do "
+"Hibernate do <literal>Set</literal>. Cuidado com erros como este:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:60
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Cat cat = new DomesticCat();\n"
-"Cat kitten = new DomesticCat();\n"
-"....\n"
-"Set kittens = new HashSet();\n"
-"kittens.add(kitten);\n"
-"cat.setKittens(kittens);\n"
-"session.persist(cat);\n"
-"kittens = cat.getKittens(); // Okay, kittens collection is a Set\n"
-"(HashSet) cat.getKittens(); // Error!]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:62
-#, fuzzy, no-c-format
-msgid ""
 "The persistent collections injected by Hibernate behave like "
 "<literal>HashMap</literal>, <literal>HashSet</literal>, <literal>TreeMap</"
 "literal>, <literal>TreeSet</literal> or <literal>ArrayList</literal>, "
 "depending on the interface type."
 msgstr ""
-"The persistent collections injected by Hibernate behave like "
+"As coleções persistentes injetadas pelo Hibernate, se comportam como "
 "<literal>HashMap</literal>, <literal>HashSet</literal>, <literal>TreeMap</"
-"literal>, <literal>TreeSet</literal> or <literal>ArrayList</literal>, "
-"depending upon the interface type."
+"literal>, <literal>TreeSet</literal> ou <literal>ArrayList</literal>, "
+"dependendo do tipo de interface."
 
 #. Tag: para
-#: collection_mapping.xml:69
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collections instances have the usual behavior of value types. They are "
 "automatically persisted when referenced by a persistent object and are "
@@ -127,74 +197,58 @@
 "properties do not support null value semantics. Hibernate does not "
 "distinguish between a null collection reference and an empty collection."
 msgstr ""
-"Collections instances have the usual behavior of value types. They are "
-"automatically persisted when referenced by a persistent object and "
-"automatically deleted when unreferenced. If a collection is passed from one "
-"persistent object to another, its elements might be moved from one table to "
-"another. Two entities may not share a reference to the same collection "
-"instance. Due to the underlying relational model, collection-valued "
-"properties do not support null value semantics; Hibernate does not "
-"distinguish between a null collection reference and an empty collection."
+"As instâncias de coleção têm o comportamento comum de tipos de valores. Eles "
+"são automaticamente persistidos quando referenciados por um objeto "
+"persistente e automaticamente deletados quando não referenciados. Se a "
+"coleção é passada de um objeto persistente para outro, seus elementos devem "
+"ser movidos de uma tabela para outra. Duas entidades não devem compartilhar "
+"uma referência com uma mesma instância de coleção. Devido ao modelo "
+"relacional adjacente, as propriedades de coleções válidas, não suportam "
+"semânticas de valores nulos. O Hibernate não distingue entre a referência da "
+"coleção nula e uma coleção vazia. "
 
 #. Tag: para
-#: collection_mapping.xml:80
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use persistent collections the same way you use ordinary Java collections. "
 "However, please ensure you understand the semantics of bidirectional "
 "associations (these are discussed later)."
 msgstr ""
-"You shouldn't have to worry much about any of this. Use persistent "
-"collections the same way you use ordinary Java collections. Just make sure "
-"you understand the semantics of bidirectional associations (discussed later)."
+"Use as coleções persistentes da mesma forma que usa coleções Java comuns. No "
+"entanto, somente tenha a certeza de entender as semânticas de associações "
+"bidirecionais (as quais serão discutidas mais tarde)."
 
 #. Tag: title
-#: collection_mapping.xml:89
 #, no-c-format
 msgid "Collection mappings"
-msgstr "Collection mappings"
+msgstr "Mapeamento de coleção"
 
 #. Tag: para
-#: collection_mapping.xml:92
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are quite a range of mappings that can be generated for collections "
 "that cover many common relational models. We suggest you experiment with the "
 "schema generation tool so that you understand how various mapping "
 "declarations translate to database tables."
 msgstr ""
-"There are quite a range of mappings that can be generated for collections, "
-"covering many common relational models. We suggest you experiment with the "
-"schema generation tool to get a feeling for how various mapping declarations "
-"translate to database tables."
+"Existem diversas variedades de mapeamento que podem ser gerados para as "
+"coleções, cobrindo muitos modelos relacionais comuns. Sugerimos que você "
+"faça o teste com a ferramenta de geração do esquema para obter uma idéia de "
+"como diversas declarações de mapeamento traduzem as tabelas de banco de "
+"dados. "
 
 #. Tag: para
-#: collection_mapping.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The Hibernate mapping element used for mapping a collection depends upon the "
 "type of interface. For example, a <literal>&lt;set&gt;</literal> element is "
 "used for mapping properties of type <literal>Set</literal>."
 msgstr ""
-"The Hibernate mapping element used for mapping a collection depends upon the "
-"type of the interface. For example, a <literal>&lt;set&gt;</literal> element "
-"is used for mapping properties of type <literal>Set</literal>."
+"O elemento do mapeamento do Hibernate, usado para mapear uma coleção, "
+"depende do tipo de interface. Por exemplo, um elemento <literal>&lt;set&gt;</"
+"literal> é usado para mapear propriedades do tipo <literal>Set</literal>. "
 
-#. Tag: programlisting
-#: collection_mapping.xml:105
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Product\">\n"
-"    <id name=\"serialNumber\" column=\"productSerialNumber\"/>\n"
-"    <set name=\"parts\">\n"
-"        <key column=\"productSerialNumber\" not-null=\"true\"/>\n"
-"        <one-to-many class=\"Part\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:107
 #, no-c-format
 msgid ""
 "Apart from <literal>&lt;set&gt;</literal>, there is also <literal>&lt;"
@@ -203,70 +257,37 @@
 "array&gt;</literal> mapping elements. The <literal>&lt;map&gt;</literal> "
 "element is representative:"
 msgstr ""
-"Apart from <literal>&lt;set&gt;</literal>, there is also <literal>&lt;"
-"list&gt;</literal>, <literal>&lt;map&gt;</literal>, <literal>&lt;bag&gt;</"
-"literal>, <literal>&lt;array&gt;</literal> and <literal>&lt;primitive-"
-"array&gt;</literal> mapping elements. The <literal>&lt;map&gt;</literal> "
-"element is representative:"
+"Além do <literal>&lt;set&gt;</literal>, existe também os elementos de "
+"mapeamento <literal>&lt;list&gt;</literal>, <literal>&lt;map&gt;</literal>, "
+"<literal>&lt;bag&gt;</literal>, <literal>&lt;array&gt;</literal> and "
+"<literal>&lt;primitive-array&gt;</literal>. O elemento <literal>&lt;map&gt;</"
+"literal> é de representação:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:132
-#, no-c-format
-msgid ""
-"<![CDATA[<map\n"
-"    name=\"propertyName\"\n"
-"    table=\"table_name\"\n"
-"    schema=\"schema_name\"\n"
-"    lazy=\"true|extra|false\"\n"
-"    inverse=\"true|false\"\n"
-"    cascade=\"all|none|save-update|delete|all-delete-orphan|delete-orphan\"\n"
-"    sort=\"unsorted|natural|comparatorClass\"\n"
-"    order-by=\"column_name asc|desc\"\n"
-"    where=\"arbitrary sql where condition\"\n"
-"    fetch=\"join|select|subselect\"\n"
-"    batch-size=\"N\"\n"
-"    access=\"field|property|ClassName\"\n"
-"    optimistic-lock=\"true|false\"\n"
-"    mutable=\"true|false\"\n"
-"    node=\"element-name|.\"\n"
-"    embed-xml=\"true|false\"\n"
-">\n"
-"\n"
-"    <key .... />\n"
-"    <map-key .... />\n"
-"    <element .... />\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:135
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>name</literal>: the collection property name"
-msgstr "<literal>name</literal> the collection property name"
+msgstr "<literal>name</literal>: o nome da propriedade da coleção"
 
 #. Tag: para
-#: collection_mapping.xml:140
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>table</literal> (optional - defaults to property name): the name of "
 "the collection table. It is not used for one-to-many associations."
 msgstr ""
-"<literal>table</literal> (optional - defaults to property name) the name of "
-"the collection table (not used for one-to-many associations)"
+"<literal>table</literal> (opcional - padrão para nome de propriedade): o "
+"nome da tabela de coleção. Isto não é usado para associações um-para-muitos."
 
 #. Tag: para
-#: collection_mapping.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>schema</literal> (optional): the name of a table schema to override "
 "the schema declared on the root element"
 msgstr ""
-"<literal>schema</literal> (optional) the name of a table schema to override "
-"the schema declared on the root element"
+"<literal>schema</literal> (opcional): o nome de um esquema de tabela para "
+"sobrescrever o esquema declarado no elemento raíz."
 
 #. Tag: para
-#: collection_mapping.xml:152
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>true</literal>): "
 "disables lazy fetching and specifies that the association is always eagerly "
@@ -274,139 +295,131 @@
 "operations do not initialize the collection. This is suitable for large "
 "collections."
 msgstr ""
-"<literal>lazy</literal> (optional - defaults to <literal>true</literal>) may "
-"be used to disable lazy fetching and specify that the association is always "
-"eagerly fetched, or to enable \"extra-lazy\" fetching where most operations "
-"do not initialize the collection (suitable for very large collections)"
+"<literal>lazy</literal> (opcional - padrão para <literal>true</literal>): "
+"pode ser utilizado para desabilitar a busca lazy e especificar que a "
+"associação é sempre buscada antecipadamente, ou para habilitar busca \"extra-"
+"lazy\" onde a maioria das operações não inicializa a coleção (apropriado "
+"para coleções bem grandes)."
 
 #. Tag: para
-#: collection_mapping.xml:161
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>inverse</literal> (optional - defaults to <literal>false</"
 "literal>): marks this collection as the \"inverse\" end of a bidirectional "
 "association."
 msgstr ""
-"<literal>inverse</literal> (optional - defaults to <literal>false</literal>) "
-"mark this collection as the \"inverse\" end of a bidirectional association"
+"<literal>inverse</literal> (opcional - padrão para <literal>false</"
+"literal>): marque esta coleção como o lado \"inverso\" de uma associação "
+"bidirecional."
 
 #. Tag: para
-#: collection_mapping.xml:167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional - defaults to <literal>none</literal>): "
 "enables operations to cascade to child entities."
 msgstr ""
-"<literal>cascade</literal> (optional - defaults to <literal>none</literal>) "
-"enable operations to cascade to child entities"
+"<literal>cascade</literal> (opcional - padrão para <literal>none</literal>): "
+"habilita operações para cascata para entidades filho."
 
 #. Tag: para
-#: collection_mapping.xml:173
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>sort</literal> (optional): specifies a sorted collection with "
 "<literal>natural</literal> sort order or a given comparator class."
 msgstr ""
-"<literal>sort</literal> (optional) specify a sorted collection with "
-"<literal>natural</literal> sort order, or a given comparator class"
+"<literal>sort</literal> (opcional): especifica uma coleção escolhida com "
+"ordem de escolha<literal>natural</literal> ou uma dada classe comparatória."
 
 #. Tag: para
-#: collection_mapping.xml:179
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>order-by</literal> (optional, JDK1.4 only): specifies a table "
 "column or columns that define the iteration order of the <literal>Map</"
 "literal>, <literal>Set</literal> or bag, together with an optional "
 "<literal>asc</literal> or <literal>desc</literal>."
 msgstr ""
-"<literal>order-by</literal> (optional, JDK1.4 only) specify a table column "
-"(or columns) that define the iteration order of the <literal>Map</literal>, "
-"<literal>Set</literal> or bag, together with an optional <literal>asc</"
-"literal> or <literal>desc</literal>"
+"<literal>order-by</literal> (opcional, somente JDK1.4): especifica uma "
+"coluna da tabela (ou colunas) que define a ordem de iteração do "
+"<literal>Map</literal>, <literal>Set</literal> ou bag, juntos com um "
+"<literal>asc</literal> ou <literal>desc</literal> opcional."
 
 #. Tag: para
-#: collection_mapping.xml:186
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>where</literal> (optional): specifies an arbitrary SQL "
 "<literal>WHERE</literal> condition that is used when retrieving or removing "
 "the collection. This is useful if the collection needs to contain only a "
 "subset of the available data."
 msgstr ""
-"<literal>where</literal> (optional) specify an arbitrary SQL <literal>WHERE</"
-"literal> condition to be used when retrieving or removing the collection "
-"(useful if the collection should contain only a subset of the available data)"
+"<literal>where</literal> (opcional): especifica uma condição SQL arbitrária "
+"<literal>WHERE</literal> a ser usada quando recuperar ou remover a coleção "
+"Isto é útil se a coleção tiver somente um subconjunto dos dados disponíveis."
 
 #. Tag: para
-#: collection_mapping.xml:193
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional, defaults to <literal>select</literal>): "
 "chooses between outer-join fetching, fetching by sequential select, and "
 "fetching by sequential subselect."
 msgstr ""
-"<literal>fetch</literal> (optional, defaults to <literal>select</literal>) "
-"Choose between outer-join fetching, fetching by sequential select, and "
-"fetching by sequential subselect."
+"<literal>fetch</literal> (opcional, padrão para <literal>select</literal>): "
+"escolha entre busca de união externa, busca por seleção sequencial e busca "
+"por subseleção sequencial."
 
 #. Tag: para
-#: collection_mapping.xml:200
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>batch-size</literal> (optional, defaults to <literal>1</literal>): "
 "specifies a \"batch size\" for lazily fetching instances of this collection."
 msgstr ""
-"<literal>batch-size</literal> (optional, defaults to <literal>1</literal>) "
-"specify a \"batch size\" for lazily fetching instances of this collection."
+"<literal>batch-size</literal> (opcional, padrão para <literal>1</literal>): "
+"especifica um \"tamanho de lote\" para instâncias de busca lazy desta "
+"coleção."
 
 #. Tag: para
-#: collection_mapping.xml:206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate uses for accessing the collection property "
 "value."
 msgstr ""
-"<literal>access</literal> (optional - defaults to <literal>property</"
-"literal>): The strategy Hibernate should use for accessing the collection "
-"property value."
+"<literal>access</literal> (opcional - padrão para <literal>property</"
+"literal>): A estratégia que o Hibernate deve usar para acessar a coleção de "
+"valor de propriedade. "
 
 #. Tag: para
-#: collection_mapping.xml:212
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that changes to the state of the collection results in "
 "increments of the owning entity's version. For one-to-many associations you "
 "may want to disable this setting."
 msgstr ""
-"<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
-"literal>): Species that changes to the state of the collection results in "
-"increment of the owning entity's version. (For one to many associations, it "
-"is often reasonable to disable this setting.)"
+"<literal>optimistic-lock</literal> (opcional - padrão para <literal>true</"
+"literal>): especifica que alterações para o estado da coleção, resulta no "
+"incremento da versão da própria entidade. Para associações um-para-muitos, é "
+"sempre bom desabilitar esta configuração."
 
 #. Tag: para
-#: collection_mapping.xml:220
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>true</literal>): "
 "a value of <literal>false</literal> specifies that the elements of the "
 "collection never change. This allows for minor performance optimization in "
 "some cases."
 msgstr ""
-"<literal>mutable</literal> (optional - defaults to <literal>true</literal>): "
-"A value of <literal>false</literal> specifies that the elements of the "
-"collection never change (a minor performance optimization in some cases)."
+"<literal>mutable</literal> (opcional - padrão para <literal>true</literal>): "
+"um valor de <literal>false</literal> especifica que os elementos  da coleção "
+"nunca mudam. Isto permite uma otimização mínima do desempenho em alguns "
+"casos."
 
 #. Tag: title
-#: collection_mapping.xml:230
 #, no-c-format
 msgid "Collection foreign keys"
-msgstr "Collection foreign keys"
+msgstr "Chaves Externas de Coleção"
 
 #. Tag: para
-#: collection_mapping.xml:232
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collection instances are distinguished in the database by the foreign key of "
 "the entity that owns the collection. This foreign key is referred to as the "
@@ -414,65 +427,48 @@
 "table. The collection key column is mapped by the <literal>&lt;key&gt;</"
 "literal> element."
 msgstr ""
-"Collection instances are distinguished in the database by the foreign key of "
-"the entity that owns the collection. This foreign key is referred to as the "
-"<emphasis>collection key column</emphasis> (or columns) of the collection "
-"table. The collection key column is mapped by the <literal>&lt;key&gt;</"
-"literal> element."
+"Instâncias de coleção são distinguidas no banco de dados pela chave exterior "
+"da entidade que possui a coleção. Esta chave exterior é referida como a "
+"<emphasis>coluna de chave de coleção</emphasis> (ou colunas) da tabela de "
+"coleção. A coluna de chave de coleção é mapeada pelo elemento <literal>&lt;"
+"key&gt;</literal>."
 
 #. Tag: para
-#: collection_mapping.xml:240
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There can be a nullability constraint on the foreign key column. For most "
 "collections, this is implied. For unidirectional one-to-many associations, "
 "the foreign key column is nullable by default, so you may need to specify "
 "<literal>not-null=\"true\"</literal>."
 msgstr ""
-"There may be a nullability constraint on the foreign key column. For most "
-"collections, this is implied. For unidirectional one to many associations, "
-"the foreign key column is nullable by default, so you might need to specify "
-"<literal>not-null=\"true\"</literal>."
+"Pode existir uma restrição de nulabilidade na coluna da chave exterior. Para "
+"a maioria das coleções, isto está implícito. Para associações unidirecionais "
+"um-para-muitos, a coluna de chave estrangeira é anulável por padrão, "
+"portanto você pode precisar especificar <literal>not-null=\"true\"</literal>."
 
-#. Tag: programlisting
-#: collection_mapping.xml:247
-#, no-c-format
-msgid "<![CDATA[<key column=\"productSerialNumber\" not-null=\"true\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:249
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The foreign key constraint can use <literal>ON DELETE CASCADE</literal>."
 msgstr ""
-"The foreign key constraint may use <literal>ON DELETE CASCADE</literal>."
+"A restrição da chave exterior pode usar <literal>ON DELETE CASCADE</literal>."
 
-#. Tag: programlisting
-#: collection_mapping.xml:253
-#, no-c-format
-msgid "<![CDATA[<key column=\"productSerialNumber\" on-delete=\"cascade\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:255
 #, no-c-format
 msgid ""
 "See the previous chapter for a full definition of the <literal>&lt;key&gt;</"
 "literal> element."
 msgstr ""
-"See the previous chapter for a full definition of the <literal>&lt;key&gt;</"
-"literal> element."
+"Veja nos capítulos anteriores para uma completa definição do "
+"elemento<literal>&lt;key&gt;</literal>."
 
 #. Tag: title
-#: collection_mapping.xml:263
 #, no-c-format
 msgid "Collection elements"
-msgstr "Collection elements"
+msgstr "Elementos de coleção"
 
 #. Tag: para
-#: collection_mapping.xml:265
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collections can contain almost any other Hibernate type, including: basic "
 "types, custom types, components and references to other entities. This is an "
@@ -482,16 +478,16 @@
 "latter case, only the \"link\" between the two objects is considered to be a "
 "state held by the collection."
 msgstr ""
-"Collections may contain almost any other Hibernate type, including all basic "
-"types, custom types, components, and of course, references to other "
-"entities. This is an important distinction: an object in a collection might "
-"be handled with \"value\" semantics (its life cycle fully depends on the "
-"collection owner) or it might be a reference to another entity, with its own "
-"life cycle. In the latter case, only the \"link\" between the two objects is "
-"considered to be state held by the collection."
+"As coleções podem conter quase qualquer outro tipo de Hibernate, incluindo "
+"todos os tipos básicos, tipos padronizados, e é claro, referências a outras "
+"entidades. Isto é uma distinção importante: um objeto em uma coleção pode "
+"ser manipulada com as semânticas \"valor\" (seu ciclo de vida depende "
+"totalmente do proprietário da coleção), ou ele pode ser uma referência à "
+"outra entidade, com seu próprio ciclo de vida. No último caso, somente o "
+"\"link\" entre os dois objetos é considerado como estado seguro pela "
+"coleção. "
 
 #. Tag: para
-#: collection_mapping.xml:274
 #, no-c-format
 msgid ""
 "The contained type is referred to as the <emphasis>collection element type</"
@@ -501,22 +497,21 @@
 "<literal>&lt;many-to-many&gt;</literal>. The first two map elements with "
 "value semantics, the next two are used to map entity associations."
 msgstr ""
-"The contained type is referred to as the <emphasis>collection element type</"
-"emphasis>. Collection elements are mapped by <literal>&lt;element&gt;</"
-"literal> or <literal>&lt;composite-element&gt;</literal>, or in the case of "
-"entity references, with <literal>&lt;one-to-many&gt;</literal> or "
-"<literal>&lt;many-to-many&gt;</literal>. The first two map elements with "
-"value semantics, the next two are used to map entity associations."
+"O tipo contido é referido como <emphasis>tipo de elemento de coleção</"
+"emphasis>. Os elementos de coleção são mapeados pelo <literal>&lt;element&gt;"
+"</literal> ou <literal>&lt;composite-element&gt;</literal>,ou no caso de "
+"referências de entidade, com <literal>&lt;one-to-many&gt;</literal> "
+"ou<literal>&lt;many-to-many&gt;</literal>. Os primeiros dois, mapeiam "
+"elementos com semânticas de valor, os dois outros são usados para mapear "
+"associações de entidade."
 
 #. Tag: title
-#: collection_mapping.xml:286
 #, no-c-format
 msgid "Indexed collections"
-msgstr "Indexed collections"
+msgstr "Coleções indexadas"
 
 #. Tag: para
-#: collection_mapping.xml:288
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All collection mappings, except those with set and bag semantics, need an "
 "<emphasis>index column</emphasis> in the collection table. An index column "
@@ -530,396 +525,358 @@
 "index&gt;</literal> element. The mapped column contains sequential integers "
 "that are numbered from zero by default."
 msgstr ""
-"All collection mappings, except those with set and bag semantics, need an "
-"<emphasis>index column</emphasis> in the collection table - a column that "
-"maps to an array index, or <literal>List</literal> index, or <literal>Map</"
-"literal> key. The index of a <literal>Map</literal> may be of any basic "
-"type, mapped with <literal>&lt;map-key&gt;</literal>, it may be an entity "
-"reference mapped with <literal>&lt;map-key-many-to-many&gt;</literal>, or it "
-"may be a composite type, mapped with <literal>&lt;composite-map-key&gt;</"
-"literal>. The index of an array or list is always of type <literal>integer</"
-"literal> and is mapped using the <literal>&lt;list-index&gt;</literal> "
-"element. The mapped column contains sequential integers (numbered from zero, "
-"by default)."
+"Todos os mapeamentos de coleção, exceto aqueles com semânticas de conjunto e "
+"bag, precisam de uma <emphasis>coluna índice</emphasis> na tabela de "
+"coleção, uma coluna que mapeia para um índice matriz ou índice "
+"<literal>List</literal> ou chave de <literal>Map</literal>. O índice de um "
+"<literal>Map</literal> pode ser de qualquer tipo, mapeado com <literal>&lt;"
+"map-key&gt;</literal>, pode ser uma referência de entidade mapeada com "
+"<literal>&lt;map-key-many-to-many&gt;</literal>, ou pode ser um tipo "
+"composto, mapeado com <literal>&lt;composite-map-key&gt;</literal>. O índice "
+"de uma matriz ou lista é sempre do tipo <literal>integer</literal> e é "
+"mapeado usando o elemento <literal>&lt;list-index&gt;</literal>. As colunas "
+"mapeadas contém inteiros sequenciais, dos quais são numerados a partir do "
+"zero, por padrão. "
 
-#. Tag: sect2
-#: collection_mapping.xml:299
+#. Tag: para
 #, no-c-format
 msgid ""
-"<programlistingco> <areaspec> <area id=\"index1\" coords=\"2 45\"/> <area id="
-"\"index2\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA[<list-"
-"index \n"
-"        column=\"column_name\"\n"
-"        base=\"0|1|...\"/>]]></programlisting> <calloutlist> <callout "
-"arearefs=\"index1\"> <para> <literal>column_name</literal> (required): the "
-"name of the column holding the collection index values. </para> </callout> "
-"<callout arearefs=\"index1\"> <para> <literal>base</literal> (optional - "
-"defaults to <literal>0</literal>): the value of the index column that "
-"corresponds to the first element of the list or array. </para> </callout> </"
-"calloutlist> </programlistingco> <programlistingco> <areaspec> <area id="
-"\"mapkey1\" coords=\"2 45\"/> <area id=\"mapkey2\" coords=\"3 45\"/> <area "
-"id=\"mapkey3\" coords=\"4 45\"/> </areaspec> <programlisting><![CDATA[<map-"
-"key \n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        type=\"type_name\"\n"
-"        node=\"@attribute-name\"\n"
-"        length=\"N\"/>]]></programlisting> <calloutlist> <callout arearefs="
-"\"mapkey1\"> <para> <literal>column</literal> (optional): the name of the "
-"column holding the collection index values. </para> </callout> <callout "
-"arearefs=\"mapkey2\"> <para> <literal>formula</literal> (optional): a SQL "
-"formula used to evaluate the key of the map. </para> </callout> <callout "
-"arearefs=\"mapkey3\"> <para> <literal>type</literal> (required): the type of "
-"the map keys. </para> </callout> </calloutlist> </programlistingco> "
-"<programlistingco> <areaspec> <area id=\"indexmanytomany1\" coords=\"2 45\"/"
-"> <area id=\"indexmanytomany2\" coords=\"3 45\"/> <area id=\"indexmanytomany3"
-"\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA[<map-key-many-to-"
-"many\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        class=\"ClassName\"\n"
-"/>]]></programlisting> <calloutlist> <callout arearefs=\"indexmanytomany1\"> "
-"<para> <literal>column</literal> (optional): the name of the foreign key "
-"column for the collection index values. </para> </callout> <callout arearefs="
-"\"indexmanytomany2\"> <para> <literal>formula</literal> (optional): a SQ "
-"formula used to evaluate the foreign key of the map key. </para> </callout> "
-"<callout arearefs=\"indexmanytomany3\"> <para> <literal>class</literal> "
-"(required): the entity class used as the map key. </para> </callout> </"
-"calloutlist> </programlistingco>"
+"<literal>column_name</literal> (required): the name of the column holding "
+"the collection index values."
 msgstr ""
+"<literal>column_name</literal> (requerido): O nome da coluna que mantém os "
+"valores do índice da coleção."
 
 #. Tag: para
-#: collection_mapping.xml:380
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
+"<literal>base</literal> (optional - defaults to <literal>0</literal>): the "
+"value of the index column that corresponds to the first element of the list "
+"or array."
+msgstr ""
+"<literal>base</literal> (opcional - padrão para <literal>0</literal>): o "
+"valor da coluna de índice que corresponde ao primeiro elemento da lista ou "
+"matriz."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>column</literal> (optional): the name of the column holding the "
+"collection index values."
+msgstr ""
+"<literal>column</literal>(opcional): o nome da coluna que mnatém os valores "
+"do índice de coleção."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>formula</literal> (optional): a SQL formula used to evaluate the "
+"key of the map."
+msgstr ""
+"<literal>formula</literal> (opcional): Uma fórmula SQL usada para avaliar a "
+"chave ou o mapa."
+
+#. Tag: para
+#, no-c-format
+msgid "<literal>type</literal> (required): the type of the map keys."
+msgstr "<literal>type</literal> (requerido): o tipo de chaves de mapa."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>column</literal> (optional): the name of the foreign key column for "
+"the collection index values."
+msgstr ""
+"<literal>column</literal> (opcional): o nome de uma coluna de chave exterior "
+"para os valores do índice de coleção."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>formula</literal> (optional): a SQ formula used to evaluate the "
+"foreign key of the map key."
+msgstr ""
+"<literal>formula</literal> (opcional): uma fórmula SQ usada para avaliar a "
+"chave exterior da chave do mapa."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>class</literal> (required): the entity class used as the map key."
+msgstr ""
+"<literal>class</literal> (requerido): a classe da entidade usada como chave "
+"do mapa."
+
+#. Tag: para
+#, no-c-format
+msgid ""
 "If your table does not have an index column, and you still wish to use "
 "<literal>List</literal> as the property type, you can map the property as a "
 "Hibernate <emphasis>&lt;bag&gt;</emphasis>. A bag does not retain its order "
 "when it is retrieved from the database, but it can be optionally sorted or "
 "ordered."
 msgstr ""
-"If your table doesn't have an index column, and you still wish to use "
-"<literal>List</literal> as the property type, you should map the property as "
-"a Hibernate <emphasis>&lt;bag&gt;</emphasis>. A bag does not retain its "
-"order when it is retrieved from the database, but it may be optionally "
-"sorted or ordered."
+"Se sua tabela não possui uma coluna de índice e você ainda quiser usar a "
+"<literal>Lista</literal> como tipo de propriedade, você deve mapeiar a "
+"propriedade como uma <emphasis>&lt;bag&gt;</emphasis> do Hibernate. Uma bag "
+"não mantém sua ordem quando é recuperadada do banco de dados, mas pode ser "
+"escolhida de forma opcional ou ordenada. "
 
 #. Tag: title
-#: collection_mapping.xml:390
 #, no-c-format
 msgid "Collections of values and many-to-many associations"
-msgstr "Collections of values and many-to-many associations"
+msgstr "Coleções de valores e associações muitos-para-muitos"
 
 #. Tag: para
-#: collection_mapping.xml:392
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Any collection of values or many-to-many associations requires a dedicated "
 "<emphasis>collection table</emphasis> with a foreign key column or columns, "
 "<emphasis>collection element column</emphasis> or columns, and possibly an "
 "index column or columns."
 msgstr ""
-"Any collection of values or many-to-many association requires a dedicated "
-"<emphasis>collection table</emphasis> with a foreign key column or columns, "
-"<emphasis>collection element column</emphasis> or columns and possibly an "
-"index column or columns."
+"Quaisquer valores de coleção ou associação muitos-para-muitos requerem uma "
+"<emphasis>tabela de coleção</emphasis> dedicada, com uma coluna de chave "
+"exterior ou colunas, <emphasis>collection element column</emphasis> ou "
+"colunas e possivelmente uma coluna de índice ou colunas."
 
 #. Tag: para
-#: collection_mapping.xml:399
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For a collection of values use the <literal>&lt;element&gt;</literal> tag. "
 "For example:"
 msgstr ""
-"For a collection of values, we use the <literal>&lt;element&gt;</literal> "
-"tag."
+"Para uma coleção com valores, utilizamos a tag <literal>&lt;element&gt;</"
+"literal>. Por exemplo:"
 
-#. Tag: sect2
-#: collection_mapping.xml:401
+#. Tag: para
 #, no-c-format
 msgid ""
-"<programlistingco> <areaspec> <area id=\"element1b\" coords=\"2 50\"/> <area "
-"id=\"element2b\" coords=\"3 50\"/> <area id=\"element3b\" coords=\"4 50\"/> "
-"</areaspec> <programlisting><![CDATA[<element\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        type=\"typename\"\n"
-"        length=\"L\"\n"
-"        precision=\"P\"\n"
-"        scale=\"S\"\n"
-"        not-null=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        node=\"element-name\"\n"
-"/>]]></programlisting> <calloutlist> <callout arearefs=\"element1b\"> <para> "
 "<literal>column</literal> (optional): the name of the column holding the "
-"collection element values. </para> </callout> <callout arearefs=\"element2b"
-"\"> <para> <literal>formula</literal> (optional): an SQL formula used to "
-"evaluate the element. </para> </callout> <callout arearefs=\"element3b\"> "
-"<para> <literal>type</literal> (required): the type of the collection "
-"element. </para> </callout> </calloutlist> </programlistingco> <para> A "
-"<emphasis>many-to-many association</emphasis> is specified using the "
-"<literal>&lt;many-to-many&gt;</literal> element. </para> <programlistingco> "
-"<areaspec> <area id=\"manytomany1\" coords=\"2 60\"/> <area id=\"manytomany2"
-"\" coords=\"3 60\"/> <area id=\"manytomany3\" coords=\"4 60\"/> <area id="
-"\"manytomany4\" coords=\"5 60\"/> <area id=\"manytomany5\" coords=\"6 60\"/> "
-"<area id=\"manytomany6\" coords=\"7 60\"/> <area id=\"manytomany7\" coords="
-"\"8 60\"/> <area id=\"manytomany8\" coords=\"9 60\"/> </areaspec> "
-"<programlisting><![CDATA[<many-to-many\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        class=\"ClassName\"\n"
-"        fetch=\"select|join\"\n"
-"        unique=\"true|false\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        node=\"element-name\"\n"
-"        embed-xml=\"true|false\"\n"
-"    />]]></programlisting> <calloutlist> <callout arearefs=\"manytomany1\"> "
-"<para> <literal>column</literal> (optional): the name of the element foreign "
-"key column. </para> </callout> <callout arearefs=\"manytomany2\"> <para> "
-"<literal>formula</literal> (optional): an SQL formula used to evaluate the "
-"element foreign key value. </para> </callout> <callout arearefs=\"manytomany3"
-"\"> <para> <literal>class</literal> (required): the name of the associated "
-"class. </para> </callout> <callout arearefs=\"manytomany4\"> <para> "
-"<literal>fetch</literal> (optional - defaults to <literal>join</literal>): "
-"enables outer-join or sequential select fetching for this association. This "
-"is a special case; for full eager fetching in a single <literal>SELECT</"
-"literal> of an entity and its many-to-many relationships to other entities, "
-"you would enable <literal>join</literal> fetching,not only of the collection "
-"itself, but also with this attribute on the <literal>&lt;many-to-many&gt;</"
-"literal> nested element. </para> </callout> <callout arearefs=\"manytomany5"
-"\"> <para> <literal>unique</literal> (optional): enables the DDL generation "
-"of a unique constraint for the foreign-key column. This makes the "
-"association multiplicity effectively one-to-many. </para> </callout> "
-"<callout arearefs=\"manytomany6\"> <para> <literal>not-found</literal> "
-"(optional - defaults to <literal>exception</literal>): specifies how foreign "
-"keys that reference missing rows will be handled: <literal>ignore</literal> "
-"will treat a missing row as a null association. </para> </callout> <callout "
-"arearefs=\"manytomany7\"> <para> <literal>entity-name</literal> (optional): "
-"the entity name of the associated class, as an alternative to "
-"<literal>class</literal>. </para> </callout> <callout arearefs=\"manytomany8"
-"\"> <para> <literal>property-ref</literal> (optional): the name of a "
-"property of the associated class that is joined to this foreign key. If not "
-"specified, the primary key of the associated class is used. </para> </"
-"callout> </calloutlist> </programlistingco>"
+"collection element values."
 msgstr ""
+"<literal>column</literal> (opcional): o nome da coluna que mantém os valores "
+"do elemento da coleção."
 
 #. Tag: para
-#: collection_mapping.xml:506
 #, no-c-format
-msgid "Here are some examples."
+msgid ""
+"<literal>formula</literal> (optional): an SQL formula used to evaluate the "
+"element."
 msgstr ""
+"<literal>formula</literal> (opcional): uma fórmula usada para avaliar o "
+"elemento."
 
 #. Tag: para
-#: collection_mapping.xml:509
 #, no-c-format
-msgid "A set of strings:"
+msgid "<literal>type</literal> (required): the type of the collection element."
+msgstr "<literal>type</literal> (requerido): o tipo do elemento de coleção."
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"A <emphasis>many-to-many association</emphasis> is specified using the "
+"<literal>&lt;many-to-many&gt;</literal> element."
 msgstr ""
+"A <emphasis>associação muitos-para-muitos</emphasis> é especificada usando o "
+"elemento <literal>&lt;many-to-many&gt;</literal>. "
 
-#. Tag: programlisting
-#: collection_mapping.xml:513
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"names\" table=\"person_names\">\n"
-"    <key column=\"person_id\"/>\n"
-"    <element column=\"person_name\" type=\"string\"/>\n"
-"</set>]]>"
+"<literal>column</literal> (optional): the name of the element foreign key "
+"column."
 msgstr ""
+"<literal>column</literal> (opcional): o nome da coluna da chave exterior do "
+"elemento."
 
 #. Tag: para
-#: collection_mapping.xml:515
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"A bag containing integers with an iteration order determined by the "
-"<literal>order-by</literal> attribute:"
+"<literal>formula</literal> (optional): an SQL formula used to evaluate the "
+"element foreign key value."
 msgstr ""
-"A bag containing integers (with an iteration order determined by the "
-"<literal>order-by</literal> attribute):"
+"<literal>formula</literal> (opcional): uma fórmula SQL usada para avaliar o "
+"valor da chave exterior do elemento."
 
-#. Tag: programlisting
-#: collection_mapping.xml:520
+#. Tag: para
 #, no-c-format
+msgid "<literal>class</literal> (required): the name of the associated class."
+msgstr "<literal>class</literal> (requerido): O nome da classe associada. "
+
+#. Tag: para
+#, no-c-format
 msgid ""
-"<![CDATA[<bag name=\"sizes\" \n"
-"        table=\"item_sizes\" \n"
-"        order-by=\"size asc\">\n"
-"    <key column=\"item_id\"/>\n"
-"    <element column=\"size\" type=\"integer\"/>\n"
-"</bag>]]>"
+"<literal>fetch</literal> (optional - defaults to <literal>join</literal>): "
+"enables outer-join or sequential select fetching for this association. This "
+"is a special case; for full eager fetching in a single <literal>SELECT</"
+"literal> of an entity and its many-to-many relationships to other entities, "
+"you would enable <literal>join</literal> fetching,not only of the collection "
+"itself, but also with this attribute on the <literal>&lt;many-to-many&gt;</"
+"literal> nested element."
 msgstr ""
+"<literal>fetch</literal> (opcional - padrão para <literal>join</literal>): "
+"ativa a busca de seleção seqüencial ou união exterior para esta associação. "
+"Isto é um caso especial; para uma busca completa num <literal>SELECT</"
+"literal> único de uma entidade e suas relações muitos-para-muitos com outras "
+"entidades, você deverá ativar a busca <literal>join</literal>, não apenas a "
+"própria coleção, mas também este atributo no elemento aninhado <literal>&lt;"
+"many-to-many&gt;</literal>."
 
 #. Tag: para
-#: collection_mapping.xml:522
-#, fuzzy, no-c-format
-msgid "An array of entities, in this case, a many-to-many association:"
-msgstr "An array of entities - in this case, a many to many association:"
+#, no-c-format
+msgid ""
+"<literal>unique</literal> (optional): enables the DDL generation of a unique "
+"constraint for the foreign-key column. This makes the association "
+"multiplicity effectively one-to-many."
+msgstr ""
+"<literal>unique</literal> (opcional): ativa a geração DDl de uma restrição "
+"única para a coluna de chave exterior. Isto realiza efetivamente a "
+"multiplicidade da associação um-para-muitos."
 
-#. Tag: programlisting
-#: collection_mapping.xml:526
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<array name=\"addresses\" \n"
-"        table=\"PersonAddress\" \n"
-"        cascade=\"persist\">\n"
-"    <key column=\"personId\"/>\n"
-"    <list-index column=\"sortOrder\"/>\n"
-"    <many-to-many column=\"addressId\" class=\"Address\"/>\n"
-"</array>]]>"
+"<literal>not-found</literal> (optional - defaults to <literal>exception</"
+"literal>): specifies how foreign keys that reference missing rows will be "
+"handled: <literal>ignore</literal> will treat a missing row as a null "
+"association."
 msgstr ""
+"<literal>not-found</literal> (opcional - padrão para <literal>exception</"
+"literal>): especifica como os identificadores em cache que referenciam as "
+"linhas faltantes serão tratadas: <literal>ignore</literal> tratará a linha "
+"faltante como uma associação nula. "
 
 #. Tag: para
-#: collection_mapping.xml:528
 #, no-c-format
-msgid "A map from string indices to dates:"
-msgstr "A map from string indices to dates:"
+msgid ""
+"<literal>entity-name</literal> (optional): the entity name of the associated "
+"class, as an alternative to <literal>class</literal>."
+msgstr ""
+"<literal>entity-name</literal> (opcional): O nome da entidade da classe "
+"associada, como uma alternativa para a <literal>class</literal>. "
 
-#. Tag: programlisting
-#: collection_mapping.xml:532
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<map name=\"holidays\" \n"
-"        table=\"holidays\" \n"
-"        schema=\"dbo\" \n"
-"        order-by=\"hol_name asc\">\n"
-"    <key column=\"id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date\" type=\"date\"/>\n"
-"</map>]]>"
+"<literal>property-ref</literal> (optional): the name of a property of the "
+"associated class that is joined to this foreign key. If not specified, the "
+"primary key of the associated class is used."
 msgstr ""
+"<literal>property-ref</literal> (opcional): o nome de uma propriedade de "
+"classe associada que é unida a esta chave exterior. caso não especificada, a "
+"chave primária da classe associada será usada."
 
 #. Tag: para
-#: collection_mapping.xml:534
-#, fuzzy, no-c-format
-msgid "A list of components (this is discussed in the next chapter):"
-msgstr "A list of components (discussed in the next chapter):"
+#, no-c-format
+msgid "Here are some examples."
+msgstr "Segue abaixo alguns exemplos."
 
-#. Tag: programlisting
-#: collection_mapping.xml:538
+#. Tag: para
 #, no-c-format
+msgid "A set of strings:"
+msgstr "Um conjunto de strings:"
+
+#. Tag: para
+#, no-c-format
 msgid ""
-"<![CDATA[<list name=\"carComponents\" \n"
-"        table=\"CarComponents\">\n"
-"    <key column=\"carId\"/>\n"
-"    <list-index column=\"sortOrder\"/>\n"
-"    <composite-element class=\"CarComponent\">\n"
-"        <property name=\"price\"/>\n"
-"        <property name=\"type\"/>\n"
-"        <property name=\"serialNumber\" column=\"serialNum\"/>\n"
-"    </composite-element>\n"
-"</list>]]>"
+"A bag containing integers with an iteration order determined by the "
+"<literal>order-by</literal> attribute:"
 msgstr ""
+"Uma bag contendo inteiros com uma ordem de iteração determinada pelo "
+"atributo <literal>order-by</literal>):"
 
+#. Tag: para
+#, no-c-format
+msgid "An array of entities, in this case, a many-to-many association:"
+msgstr ""
+"Uma matriz de entidades, neste caso, uma associação muitos-para-muitos: "
+
+#. Tag: para
+#, no-c-format
+msgid "A map from string indices to dates:"
+msgstr "Um mapa desde índices de strigs até datas:"
+
+#. Tag: para
+#, no-c-format
+msgid "A list of components (this is discussed in the next chapter):"
+msgstr "Uma lista de componentes (isto será discutido no próximo capítulo):"
+
 #. Tag: title
-#: collection_mapping.xml:543
 #, no-c-format
 msgid "One-to-many associations"
-msgstr "One-to-many associations"
+msgstr "Associações um-para-muitos"
 
 #. Tag: para
-#: collection_mapping.xml:545
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>one-to-many association</emphasis> links the tables of two "
 "classes via a foreign key with no intervening collection table. This mapping "
 "loses certain semantics of normal Java collections:"
 msgstr ""
-"A <emphasis>one to many association</emphasis> links the tables of two "
-"classes via a foreign key, with no intervening collection table. This "
-"mapping loses certain semantics of normal Java collections:"
+"Uma <emphasis>associação um para muitos</emphasis> liga as tabelas das duas "
+"classes através de uma chave exterior, sem a intervenção da tabela de "
+"coleção. Este mapeamento perde um pouco da semântica das coleções normais do "
+"Java: "
 
 #. Tag: para
-#: collection_mapping.xml:553
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of the contained entity class cannot belong to more than one "
 "instance of the collection."
 msgstr ""
-"An instance of the contained entity class may not belong to more than one "
-"instance of the collection"
+"Uma instância de classes entidades contidas, podem não pertencer à mais de "
+"uma instância da coleção. "
 
 #. Tag: para
-#: collection_mapping.xml:559
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of the contained entity class cannot appear at more than one "
 "value of the collection index."
 msgstr ""
-"An instance of the contained entity class may not appear at more than one "
-"value of the collection index"
+"Uma instância da classe de entidade contida pode não aparecer em mais de um "
+"valor do índice da coleção. "
 
 #. Tag: para
-#: collection_mapping.xml:566
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An association from <literal>Product</literal> to <literal>Part</literal> "
 "requires the existence of a foreign key column and possibly an index column "
 "to the <literal>Part</literal> table. A <literal>&lt;one-to-many&gt;</"
 "literal> tag indicates that this is a one-to-many association."
 msgstr ""
-"An association from <literal>Product</literal> to <literal>Part</literal> "
-"requires existence of a foreign key column and possibly an index column to "
-"the <literal>Part</literal> table. A <literal>&lt;one-to-many&gt;</literal> "
-"tag indicates that this is a one to many association."
+"Uma associação a partir do <literal>Produto</literal> até a <literal>Parte</"
+"literal> requer a existência de uma coluna de chave exterior e possivelmente "
+"uma coluna de índice para a tabela <literal>Part</literal> Uma tag "
+"<literal>&lt;one-to-many&gt;</literal> indica que esta é uma associação um "
+"para muitos."
 
-#. Tag: programlisting
-#: collection_mapping.xml:579
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<one-to-many \n"
-"        class=\"ClassName\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\"\n"
-"        embed-xml=\"true|false\"\n"
-"    />]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:582
-#, fuzzy, no-c-format
-msgid "<literal>class</literal> (required): the name of the associated class."
-msgstr "<literal>class</literal> (required): The name of the associated class."
-
-#. Tag: para
-#: collection_mapping.xml:587
-#, fuzzy, no-c-format
-msgid ""
 "<literal>not-found</literal> (optional - defaults to <literal>exception</"
 "literal>): specifies how cached identifiers that reference missing rows will "
 "be handled. <literal>ignore</literal> will treat a missing row as a null "
 "association."
 msgstr ""
-"<literal>not-found</literal> (optional - defaults to <literal>exception</"
-"literal>): Specifies how cached identifiers that reference missing rows will "
-"be handled: <literal>ignore</literal> will treat a missing row as a null "
-"association."
+"<literal>not-found</literal> (opcional - padrão para <literal>exception</"
+"literal>): Especifica como os identificadores em cache que referenciam as "
+"linhas faltantes serão tratadas: <literal>ignore</literal> tratará a linha "
+"faltante como uma associação nula. "
 
 #. Tag: para
-#: collection_mapping.xml:594
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"<literal>entity-name</literal> (optional): the entity name of the associated "
-"class, as an alternative to <literal>class</literal>."
-msgstr ""
-"<literal>entity-name</literal> (optional): The entity name of the associated "
-"class, as an alternative to <literal>class</literal>."
-
-#. Tag: para
-#: collection_mapping.xml:602
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>&lt;one-to-many&gt;</literal> element does not need to declare "
 "any columns. Nor is it necessary to specify the <literal>table</literal> "
 "name anywhere."
 msgstr ""
-"Notice that the <literal>&lt;one-to-many&gt;</literal> element does not need "
-"to declare any columns. Nor is it necessary to specify the <literal>table</"
-"literal> name anywhere."
+"Note que o elemento <literal>&lt;one-to-many&gt;</literal> não precisa "
+"declarar qualquer coluna. Nem é necessário especificar o nome da "
+"<literal>table</literal> em qualquer lugar. "
 
 #. Tag: para
-#: collection_mapping.xml:609
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the foreign key column of a <literal>&lt;one-to-many&gt;</literal> "
 "association is declared <literal>NOT NULL</literal>, you must declare the "
@@ -928,105 +885,67 @@
 "mapping marked <literal>inverse=\"true\"</literal>. See the discussion of "
 "bidirectional associations later in this chapter for more information."
 msgstr ""
-"<emphasis>Very important note:</emphasis> If the foreign key column of a "
-"<literal>&lt;one-to-many&gt;</literal> association is declared <literal>NOT "
-"NULL</literal>, you must declare the <literal>&lt;key&gt;</literal> mapping "
-"<literal>not-null=\"true\"</literal> or <emphasis>use a bidirectional "
-"association</emphasis> with the collection mapping marked <literal>inverse="
-"\"true\"</literal>. See the discussion of bidirectional associations later "
-"in this chapter."
+"Se a coluna da chave exterior de uma associação <literal>&lt;one-to-many&gt;"
+"</literal> for declarada como <literal>NOT NULL</literal>, você deve "
+"declarar a <literal>&lt;key&gt;</literal> mapeando <literal>not-null=\"true"
+"\"</literal> ou <emphasis>use uma associação bidirecional</emphasis> com o "
+"mapeamento da coleção marcado como <literal>inverse=\"true\"</literal>. Veja "
+"a discussão das associações bidirecionais mais tarde neste mesmo capítulo."
 
 #. Tag: para
-#: collection_mapping.xml:619
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following example shows a map of <literal>Part</literal> entities by "
 "name, where <literal>partName</literal> is a persistent property of "
 "<literal>Part</literal>. Notice the use of a formula-based index:"
 msgstr ""
-"This example shows a map of <literal>Part</literal> entities by name (where "
-"<literal>partName</literal> is a persistent property of <literal>Part</"
-"literal>). Notice the use of a formula-based index."
+"Este exemplo demonstra um mapa das entidades <literal>Part</literal> por "
+"nome, onde <literal>partName</literal> é uma propriedade persistente de "
+"<literal>Part</literal>. Note que o uso de um índice baseado em fórmula:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:625
-#, no-c-format
-msgid ""
-"<![CDATA[<map name=\"parts\"\n"
-"        cascade=\"all\">\n"
-"    <key column=\"productId\" not-null=\"true\"/>\n"
-"    <map-key formula=\"partName\"/>\n"
-"    <one-to-many class=\"Part\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:631
 #, no-c-format
 msgid "Advanced collection mappings"
-msgstr "Advanced collection mappings"
+msgstr "Mapeamentos de coleção avançados."
 
 #. Tag: title
-#: collection_mapping.xml:634
 #, no-c-format
 msgid "Sorted collections"
-msgstr "Sorted collections"
+msgstr "Coleções escolhidas"
 
 #. Tag: para
-#: collection_mapping.xml:636
 #, no-c-format
 msgid ""
 "Hibernate supports collections implementing <literal>java.util.SortedMap</"
 "literal> and <literal>java.util.SortedSet</literal>. You must specify a "
 "comparator in the mapping file:"
 msgstr ""
-"Hibernate supports collections implementing <literal>java.util.SortedMap</"
-"literal> and <literal>java.util.SortedSet</literal>. You must specify a "
-"comparator in the mapping file:"
+"O Hibernate suporta a implementação de coleções <literal>java.util."
+"SortedMap</literal> e <literal>java.util.SortedSet</literal>. Você deve "
+"especificar um comparador no arquivo de mapeamento:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:641
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"aliases\" \n"
-"            table=\"person_aliases\" \n"
-"            sort=\"natural\">\n"
-"    <key column=\"person\"/>\n"
-"    <element column=\"name\" type=\"string\"/>\n"
-"</set>\n"
-"\n"
-"<map name=\"holidays\" sort=\"my.custom.HolidayComparator\">\n"
-"    <key column=\"year_id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date\" type=\"date\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:643
 #, no-c-format
 msgid ""
 "Allowed values of the <literal>sort</literal> attribute are "
 "<literal>unsorted</literal>, <literal>natural</literal> and the name of a "
 "class implementing <literal>java.util.Comparator</literal>."
 msgstr ""
-"Allowed values of the <literal>sort</literal> attribute are "
-"<literal>unsorted</literal>, <literal>natural</literal> and the name of a "
-"class implementing <literal>java.util.Comparator</literal>."
+"Valores permitidos da função<literal>sort</literal> são<literal>unsorted</"
+"literal>, <literal>natural</literal> e o nome de uma classe implementando "
+"<literal>java.util.Comparator</literal>."
 
 #. Tag: para
-#: collection_mapping.xml:649
 #, no-c-format
 msgid ""
 "Sorted collections actually behave like <literal>java.util.TreeSet</literal> "
 "or <literal>java.util.TreeMap</literal>."
 msgstr ""
-"Sorted collections actually behave like <literal>java.util.TreeSet</literal> "
-"or <literal>java.util.TreeMap</literal>."
+"Coleções escolhidas, na verdade se comportam como <literal>java.util."
+"TreeSet</literal> ou <literal>java.util.TreeMap</literal>."
 
 #. Tag: para
-#: collection_mapping.xml:654
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want the database itself to order the collection elements, use the "
 "<literal>order-by</literal> attribute of <literal>set</literal>, "
@@ -1035,159 +954,98 @@
 "<literal>LinkedHashSet</literal> or <literal>LinkedHashMap</literal>. This "
 "performs the ordering in the SQL query and not in the memory."
 msgstr ""
-"If you want the database itself to order the collection elements use the "
-"<literal>order-by</literal> attribute of <literal>set</literal>, "
-"<literal>bag</literal> or <literal>map</literal> mappings. This solution is "
-"only available under JDK 1.4 or higher (it is implemented using "
-"<literal>LinkedHashSet</literal> or <literal>LinkedHashMap</literal>). This "
-"performs the ordering in the SQL query, not in memory."
+"Se você quiser que o próprio banco de dados ordene os elementos da coleção "
+"use a função <literal>order-by</literal> do <literal>set</literal>, "
+"<literal>bag</literal> ou mapeamentos <literal>map</literal>. Esta solução "
+"está disponível somente sob JDK 1.4 ou versões posteriores e é implementada "
+"usando <literal>LinkedHashSet</literal> ou <literal>LinkedHashMap</"
+"literal>). Este desempenha a ordenação na consulta SQL, não em memória."
 
-#. Tag: programlisting
-#: collection_mapping.xml:663
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"aliases\" table=\"person_aliases\" order-by=\"lower"
-"(name) asc\">\n"
-"    <key column=\"person\"/>\n"
-"    <element column=\"name\" type=\"string\"/>\n"
-"</set>\n"
-"\n"
-"<map name=\"holidays\" order-by=\"hol_date, hol_name\">\n"
-"    <key column=\"year_id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date type=\"date\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:666
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Nota"
 
 #. Tag: para
-#: collection_mapping.xml:667
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The value of the <literal>order-by</literal> attribute is an SQL ordering, "
 "not an HQL ordering."
 msgstr ""
-"Note that the value of the <literal>order-by</literal> attribute is an SQL "
-"ordering, not a HQL ordering!"
+"Note que o valor da função <literal>order-by</literal> é uma ordenação SQL e "
+"não uma ordenação."
 
 #. Tag: para
-#: collection_mapping.xml:673
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Associations can even be sorted by arbitrary criteria at runtime using a "
 "collection <literal>filter()</literal>:"
 msgstr ""
-"Associations may even be sorted by some arbitrary criteria at runtime using "
-"a collection <literal>filter()</literal>."
+"Associações podem também ser escolhidas por algum critério arbritrário em "
+"tempo de espera usando uma coleção <literal>filter()</literal>:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:678
-#, no-c-format
-msgid ""
-"<![CDATA[sortedUsers = s.createFilter( group.getUsers(), \"order by this.name"
-"\" ).list();]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:683
 #, no-c-format
 msgid "Bidirectional associations"
-msgstr "Bidirectional associations"
+msgstr "Associações Bidirecionais"
 
 #. Tag: para
-#: collection_mapping.xml:685
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional association</emphasis> allows navigation from both "
 "\"ends\" of the association. Two kinds of bidirectional association are "
 "supported:"
 msgstr ""
-"A <emphasis>bidirectional association</emphasis> allows navigation from both "
-"\"ends\" of the association. Two kinds of bidirectional association are "
-"supported: <placeholder-1/>"
+"Uma <emphasis>associação bidirecional</emphasis> permite a navegação de "
+"ambos os \"lados\" da associação. Dois dos casos de associação bidirecional, "
+"são suportados: "
 
 #. Tag: term
-#: collection_mapping.xml:692
 #, no-c-format
 msgid "one-to-many"
-msgstr "one-to-many"
+msgstr "Um-para-muitos"
 
 #. Tag: para
-#: collection_mapping.xml:694
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "set or bag valued at one end and single-valued at the other"
-msgstr "set or bag valued at one end, single-valued at the other"
+msgstr "conjunto ou bag de valor em um dos lados, valor único do outro "
 
 #. Tag: term
-#: collection_mapping.xml:700
 #, no-c-format
 msgid "many-to-many"
-msgstr "many-to-many"
+msgstr "Muitos-para-muitos"
 
 #. Tag: para
-#: collection_mapping.xml:702
 #, no-c-format
 msgid "set or bag valued at both ends"
-msgstr "set or bag valued at both ends"
+msgstr "Conjunto ou bag com valor em ambos os lados"
 
 #. Tag: para
-#: collection_mapping.xml:711
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can specify a bidirectional many-to-many association by mapping two many-"
 "to-many associations to the same database table and declaring one end as "
 "<emphasis>inverse</emphasis>. You cannot select an indexed collection."
 msgstr ""
-"You may specify a bidirectional many-to-many association simply by mapping "
-"two many-to-many associations to the same database table and declaring one "
-"end as <emphasis>inverse</emphasis> (which one is your choice, but it can "
-"not be an indexed collection)."
+"Você deve especificar uma associação muitos-para-muitos bidirecional, "
+"simplesmente mapeando as duas associações muitos-para-muitos para alguma "
+"tabela de banco de dados e declarando um dos lados como <emphasis>inverso</"
+"emphasis> Voce não poderá selecionar uma coleção indexada."
 
 #. Tag: para
-#: collection_mapping.xml:718
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Here is an example of a bidirectional many-to-many association that "
 "illustrates how each category can have many items and each item can be in "
 "many categories:"
 msgstr ""
-"Here's an example of a bidirectional many-to-many association; each category "
-"can have many items and each item can be in many categories:"
+"Segue aqui um exemplo de uma associação muitos-para-muitos bidirecional. "
+"Cada categoria pode ter muitos ítens e cada ítem pode estar em várias "
+"categorias: "
 
-#. Tag: programlisting
-#: collection_mapping.xml:723
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Category\">\n"
-"    <id name=\"id\" column=\"CATEGORY_ID\"/>\n"
-"    ...\n"
-"    <bag name=\"items\" table=\"CATEGORY_ITEM\">\n"
-"        <key column=\"CATEGORY_ID\"/>\n"
-"        <many-to-many class=\"Item\" column=\"ITEM_ID\"/>\n"
-"    </bag>\n"
-"</class>\n"
-"\n"
-"<class name=\"Item\">\n"
-"    <id name=\"id\" column=\"ITEM_ID\"/>\n"
-"    ...\n"
-"\n"
-"    <!-- inverse end -->\n"
-"    <bag name=\"categories\" table=\"CATEGORY_ITEM\" inverse=\"true\">\n"
-"        <key column=\"ITEM_ID\"/>\n"
-"        <many-to-many class=\"Category\" column=\"CATEGORY_ID\"/>\n"
-"    </bag>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:725
-#, fuzzy, no-c-format
-msgid ""
 "Changes made only to the inverse end of the association are <emphasis>not</"
 "emphasis> persisted. This means that Hibernate has two representations in "
 "memory for every bidirectional association: one link from A to B and another "
@@ -1198,36 +1056,19 @@
 "são persistidas. Isto significa que o Hibernate tem duas representações na "
 "memória para cada associação bidirecional, uma associação de A para B e uma "
 "outra associação de B para A. Isto é mais fácil de compreender se você pensa "
-"sobre o modelo do objetos do Java e como nós criamos um relacionamento "
-"muitos para muitos em Java:"
+"sobre o modelo de objetos do Java e como criamos um relacionamento muitos "
+"para muitos em Java:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:733
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"category.getItems().add(item);          // The category now \"knows\" about "
-"the relationship\n"
-"item.getCategories().add(category);     // The item now \"knows\" about the "
-"relationship\n"
-"\n"
-"session.persist(item);                   // The relationship won't be "
-"saved!\n"
-"session.persist(category);               // The relationship will be saved]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:735
 #, no-c-format
 msgid ""
 "The non-inverse side is used to save the in-memory representation to the "
 "database."
 msgstr ""
-"A outra ponta é usada salvar a representação em memória à base de dados."
+"A outra ponta é usada para salvar a representação em memória à base de dados."
 
 #. Tag: para
-#: collection_mapping.xml:739
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can define a bidirectional one-to-many association by mapping a one-to-"
 "many association to the same table column(s) as a many-to-one association "
@@ -1236,50 +1077,25 @@
 "Você pode definir uma associação bidirecional um para muitos através de uma "
 "associação um-para-muitos indicando as mesmas colunas da tabela que à "
 "associação muitos-para-um e declarando a propriedade <literal>inverse=\"true"
-"\"</literal>"
+"\"</literal>."
 
-#. Tag: programlisting
-#: collection_mapping.xml:745
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <set name=\"children\" inverse=\"true\">\n"
-"        <key column=\"parent_id\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:747
-#, fuzzy, no-c-format
-msgid ""
 "Mapping one end of an association with <literal>inverse=\"true\"</literal> "
 "does not affect the operation of cascades as these are orthogonal concepts."
 msgstr ""
 "Mapear apenas uma das pontas da associação com <literal>inverse=\"true\"</"
-"literal> não afeta as operações em cascata, isso é um conceito ortogonal."
+"literal> não afeta as operações em cascata, uma vez que isto é um conceito "
+"ortogonal."
 
 #. Tag: title
-#: collection_mapping.xml:755
 #, no-c-format
 msgid "Bidirectional associations with indexed collections"
 msgstr "Associações bidirecionais com coleções indexadas"
 
 #. Tag: para
-#: collection_mapping.xml:756
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A bidirectional association where one end is represented as a <literal>&lt;"
 "list&gt;</literal> or <literal>&lt;map&gt;</literal>, requires special "
@@ -1287,43 +1103,15 @@
 "index column you can use <literal>inverse=\"true\"</literal> on the "
 "collection mapping:"
 msgstr ""
-"Uma associação bidirecional onde uma dos lados e representa pôr uma "
+"Uma associação bidirecional onde um dos lados é representado por uma "
 "<literal>&lt;list&gt;</literal> ou <literal>&lt;map&gt;</literal> requer uma "
 "consideração especial. Se houver uma propriedade da classe filha que faça o "
-"mapeamento da coluna do índice, sem problema, pode-se continuar usando "
-"<literal>inverse=\"true\"</literal> no mapeamento da coleção."
+"mapeamento da coluna do índice sem problemas, pode-se continuar usando "
+"<literal>inverse=\"true\"</literal> no mapeamento da coleção:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:763
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <map name=\"children\" inverse=\"true\">\n"
-"        <key column=\"parent_id\"/>\n"
-"        <map-key column=\"name\" \n"
-"            type=\"string\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </map>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <property name=\"name\" \n"
-"        not-null=\"true\"/>\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:765
-#, fuzzy, no-c-format
-msgid ""
 "If there is no such property on the child class, the association cannot be "
 "considered truly bidirectional. That is, there is information available at "
 "one end of the association that is not available at the other end. In this "
@@ -1333,115 +1121,58 @@
 "Mas, se não houver nenhuma propriedade na classe filha, não podemos ver essa "
 "associação como verdadeiramente bidirecional (há uma informação disponível "
 "em um lado da associação que não está disponível no extremo oposto). Nesse "
-"caso, nos não podemos mapear a coleção usando <literal>inverse=\"true\"</"
-"literal>. Nos devemos usar o seguinte mapeamento:"
+"caso, nós não podemos mapear a coleção usando <literal>inverse=\"true\"</"
+"literal>. Devemos usar o seguinte mapeamento: "
 
-#. Tag: programlisting
-#: collection_mapping.xml:772
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <map name=\"children\">\n"
-"        <key column=\"parent_id\"\n"
-"            not-null=\"true\"/>\n"
-"        <map-key column=\"name\" \n"
-"            type=\"string\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </map>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        insert=\"false\"\n"
-"        update=\"false\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:774
 #, fuzzy, no-c-format
 msgid ""
 "Note that in this mapping, the collection-valued end of the association is "
 "responsible for updates to the foreign key."
 msgstr ""
-"Veja que neste mapeamento, que um dos lado da associação, a coleção, é "
-"responsável pela atualização da chave estrangeira. TODO: Isso realmente "
-"resulta em updates desnecessários ?."
+"Veja que neste mapeamento, o lado de coleção válida da associação é "
+"responsável pela atualização da chave exterior. <!-- TODO: Does this really "
+"result in some unnecessary update statements? -->"
 
 #. Tag: title
-#: collection_mapping.xml:782
 #, no-c-format
 msgid "Ternary associations"
 msgstr "Associações Ternárias"
 
 #. Tag: para
-#: collection_mapping.xml:784
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are three possible approaches to mapping a ternary association. One "
 "approach is to use a <literal>Map</literal> with an association as its index:"
 msgstr ""
 "Há três meios possíveis de se mapear uma associação ternária. Uma é usar um "
-"<literal>Map</literal> com uma associação como seu índice:"
+"<literal>Map</literal> com uma associação como seu índice: "
 
-#. Tag: programlisting
-#: collection_mapping.xml:789
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<map name=\"contracts\">\n"
-"    <key column=\"employer_id\" not-null=\"true\"/>\n"
-"    <map-key-many-to-many column=\"employee_id\" class=\"Employee\"/>\n"
-"    <one-to-many class=\"Contract\"/>\n"
-"</map>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: collection_mapping.xml:791
-#, no-c-format
-msgid ""
-"<![CDATA[<map name=\"connections\">\n"
-"    <key column=\"incoming_node_id\"/>\n"
-"    <map-key-many-to-many column=\"outgoing_node_id\" class=\"Node\"/>\n"
-"    <many-to-many column=\"connection_id\" class=\"Connection\"/>\n"
-"</map>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:793
-#, fuzzy, no-c-format
-msgid ""
 "A second approach is to remodel the association as an entity class. This is "
 "the most common approach."
 msgstr ""
 "A segunda maneira é simplesmente remodelar a associação das classes da "
-"entidade. Esta é a maneira que nós usamos de uma maneira geral."
+"entidade. Esta é a abordagem que utilizamos com mais freqüência. "
 
 #. Tag: para
-#: collection_mapping.xml:798
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A final alternative is to use composite elements, which will be discussed "
 "later."
 msgstr ""
 "Uma alternativa final é usar os elementos compostos, que nós discutiremos "
-"mais tarde."
+"mais tarde. "
 
-#. Tag: literal
-#: collection_mapping.xml:805
-#, no-c-format
-msgid "Using an &lt;idbag&gt;"
-msgstr "Usando o &lt;idbag&gt;"
+#. Tag: title
+#, fuzzy, no-c-format
+msgid "<literal>Using an &lt;idbag&gt;</literal>"
+msgstr "<literal>Using an &lt;idbag&gt;</literal>"
 
 #. Tag: para
-#: collection_mapping.xml:807
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The majority of the many-to-many associations and collections of values "
 "shown previously all map to tables with composite keys, even though it has "
@@ -1452,56 +1183,40 @@
 "feature that allows you to map many-to-many associations and collections of "
 "values to a table with a surrogate key."
 msgstr ""
-"Se você concorda com nossa visão que chaves compostas são uma coisa ruim e "
-"que as entidades devem ter identificadores sintéticos (surrogate keys), "
-"então você deve estar achando um pouco estranho que as associações muitos "
-"para muitos usando coleções de valores que nós mostramos estejam mapeadas "
-"com chaves compostas! Bem, este ponto é bastante discutível; um simples "
-"tabela de associação não parece se beneficiar muito de uma surrogate key "
-"(entretanto uma coleção de valores compostos <emphasis>sim</emphasis>). "
-"Opcionalmente, o Hibernate prove uma maneira de mapear uma associação muitos "
-"para muitos com uma coleção de valores para uma tabela com uma surrogate key."
+"A maioria das associações e coleções muitos para muitos de valores "
+"apresentados anteriormente mapeiam às tabelas com as chaves de composição, "
+"mesmo que foi sugerido que as entidades devem ser identificadores sintéticos "
+"(chaves substitutas). Uma tabela de associação pura não parece tirar muito "
+"proveito de uma chave substituta, mesmo que uma coleção de valores compostos "
+"<emphasis>usufruam disto</emphasis>. É por este motivo que o Hibernate provê "
+"uma maneira de mapear uma associação muitos para muitos com uma coleção de "
+"valores para uma tabela com uma chave substituta. "
 
 #. Tag: para
-#: collection_mapping.xml:817
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;idbag&gt;</literal> element lets you map a <literal>List</"
 "literal> (or <literal>Collection</literal>) with bag semantics. For example:"
 msgstr ""
 "O elemento <literal>&lt;idbag&gt;</literal> permite mapear um <literal>List</"
-"literal> (ou uma <literal>Collection</literal> com uma semântica de bag."
+"literal> (ou uma <literal>Collection</literal>) com uma semântica de bag. "
+"Por exemplo:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:822
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<idbag name=\"lovers\" table=\"LOVERS\">\n"
-"    <collection-id column=\"ID\" type=\"long\">\n"
-"        <generator class=\"sequence\"/>\n"
-"    </collection-id>\n"
-"    <key column=\"PERSON1\"/>\n"
-"    <many-to-many column=\"PERSON2\" class=\"Person\" fetch=\"join\"/>\n"
-"</idbag>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:824
-#, fuzzy, no-c-format
-msgid ""
 "An <literal>&lt;idbag&gt;</literal> has a synthetic id generator, just like "
 "an entity class. A different surrogate key is assigned to each collection "
 "row. Hibernate does not, however, provide any mechanism for discovering the "
 "surrogate key value of a particular row."
 msgstr ""
-"Como você pode ver, um <literal>&lt;idbag&gt;</literal> possui um gerador de "
-"id sintético, igual uma classe de entidade! Uma surrogate key diferente é "
-"associada para cada elemento de coleção. Porém, o Hibernate não prove nenhum "
-"mecanismo para descobrir qual a surrogate key de uma linha em particular."
+"O <literal>&lt;idbag&gt;</literal> possui um gerador de id sintético, igual "
+"a uma classe de entidade. Uma chave substituta diferente é associada para "
+"cada elemento de coleção. Porém, o Hibernate não provê de nenhum mecanismo "
+"para descobrir qual a chave substituta de uma linha em particular."
 
 #. Tag: para
-#: collection_mapping.xml:831
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The update performance of an <literal>&lt;idbag&gt;</literal> supersedes a "
 "regular <literal>&lt;bag&gt;</literal>. Hibernate can locate individual rows "
@@ -1509,12 +1224,11 @@
 "or set."
 msgstr ""
 "Note que o desempenho de atualização de um <literal>&lt;idbag&gt;</literal> "
-"é <emphasis>much</emphasis> melhor que um <literal>&lt;bag&gt;</literal> "
-"normal! O Hibernate pode localizar uma linha individual eficazmente e "
-"atualizar ou deletar individualmente, como um list, map ou set."
+"é melhor do que um <literal>&lt;bag&gt;</literal> normal. O Hibernate pode "
+"localizar uma linha individual eficazmente e atualizar ou deletar "
+"individualmente, como um list, map ou set."
 
 #. Tag: para
-#: collection_mapping.xml:837
 #, no-c-format
 msgid ""
 "In the current implementation, the <literal>native</literal> identifier "
@@ -1526,417 +1240,87 @@
 "usando o <literal>&lt;idbag&gt;</literal>."
 
 #. Tag: title
-#: collection_mapping.xml:861
 #, no-c-format
 msgid "Collection examples"
 msgstr "Exemplos de coleções"
 
 #. Tag: para
-#: collection_mapping.xml:863
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This section covers collection examples."
-msgstr "Exemplos de coleções"
+msgstr "Esta sessão cobre os exemplos de coleções."
 
 #. Tag: para
-#: collection_mapping.xml:867
 #, no-c-format
 msgid ""
 "The following class has a collection of <literal>Child</literal> instances:"
 msgstr ""
+"A seguinte classe possui uma coleção de instâncias <literal>Child</literal>:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:871
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"\n"
-"public class Parent {\n"
-"    private long id;\n"
-"    private Set children;\n"
-"\n"
-"    public long getId() { return id; }\n"
-"    private void setId(long id) { this.id=id; }\n"
-"\n"
-"    private Set getChildren() { return children; }\n"
-"    private void setChildren(Set children) { this.children=children; }\n"
-"\n"
-"    ....\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:873
-#, fuzzy, no-c-format
-msgid ""
 "If each child has, at most, one parent, the most natural mapping is a one-to-"
 "many association:"
 msgstr ""
-"tem uma coleção de instancias de <literal>Child</literal>. Se cada Child "
-"tiver no máximo um parent, o mapeamento natural é uma associação um para "
-"muitos:"
+"Se cada Filho tiver no máximo um Pai, o mapeamento natural é uma associação "
+"um para muitos:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:879
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:881
 #, no-c-format
 msgid "This maps to the following table definitions:"
 msgstr "Esse mapeamento gera a seguinte definição de tabelas"
 
-#. Tag: programlisting
-#: collection_mapping.xml:885
-#, no-c-format
-msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null primary key, name varchar(255), "
-"parent_id bigint )\n"
-"alter table child add constraint childfk0 (parent_id) references parent]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:887
 #, no-c-format
 msgid ""
 "If the parent is <emphasis>required</emphasis>, use a bidirectional one-to-"
 "many association:"
 msgstr ""
-"Se o parent for <emphasis>obrigatório</emphasis>, use uma associação "
+"Se o pai for <emphasis>obrigatório</emphasis>, use uma associação "
 "bidirecional um para muitos:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:892
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\" inverse=\"true\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"        <many-to-one name=\"parent\" class=\"Parent\" column=\"parent_id\" "
-"not-null=\"true\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:894
 #, no-c-format
 msgid "Notice the <literal>NOT NULL</literal> constraint:"
-msgstr "Repare na constraint <literal>NOT NULL</literal>:"
+msgstr "Repare na restrição <literal>NOT NULL</literal>:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:898
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null\n"
-"                     primary key,\n"
-"                     name varchar(255),\n"
-"                     parent_id bigint not null )\n"
-"alter table child add constraint childfk0 (parent_id) references parent]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:900
-#, fuzzy, no-c-format
-msgid ""
 "Alternatively, if this association must be unidirectional you can declare "
 "the <literal>NOT NULL</literal> constraint on the <literal>&lt;key&gt;</"
 "literal> mapping:"
 msgstr ""
-"Uma outra alternativa, no caso de você insistir que esta associação devea "
-"ser unidirecional, você pode declarar a constraint como <literal>NOT NULL</"
-"literal> na tag <literal>&lt;key&gt;</literal> do mapeamento:"
+"Uma outra alternativa, no caso de você insistir que esta associação deva ser "
+"unidirecional, você pode declarar a restrição como <literal>NOT NULL</"
+"literal> no mapeamento <literal>&lt;key&gt;</literal>:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:906
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\">\n"
-"            <key column=\"parent_id\" not-null=\"true\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:908
-#, fuzzy, no-c-format
-msgid ""
 "On the other hand, if a child has multiple parents, a many-to-many "
 "association is appropriate:"
 msgstr ""
-"Por outro lado, se uma child puder ter os múltiplos parents, a associação "
-"apropriada é muitos-para-muitos:"
+"Por outro lado, se um filho puder ter os múltiplos pais, a associação "
+"apropriada será muitos-para-muitos: "
 
-#. Tag: programlisting
-#: collection_mapping.xml:913
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\" table=\"childset\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <many-to-many class=\"Child\" column=\"child_id\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:915
 #, no-c-format
 msgid "Table definitions:"
 msgstr "Definições das tabelas:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:919
-#, no-c-format
-msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null primary key, name varchar(255) )\n"
-"create table childset ( parent_id bigint not null,\n"
-"                        child_id bigint not null,\n"
-"                        primary key ( parent_id, child_id ) )\n"
-"alter table childset add constraint childsetfk0 (parent_id) references "
-"parent\n"
-"alter table childset add constraint childsetfk1 (child_id) references child]]"
-">"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:921
 #, fuzzy, no-c-format
 msgid ""
 "For more examples and a complete explanation of a parent/child relationship "
-"mapping, see <xref linkend=\"example-parentchild\"/> for more information."
+"mapping, see <xref linkend=\"example-parentchild\" /> for more information."
 msgstr ""
-"For more examples and a complete walk-through a parent/child relationship "
-"mapping, see <xref linkend=\"example-parentchild\"/>. Para mais exemplos e "
-"um exemplo completo de mapeamento de relacionamento de mestre/detalhe, veja "
-"<xref linkend=\"example-parentchild\"/>."
+"Para mais exemplos e um exemplo completo de mapeamento de relacionamento de "
+"mestre/detalhe, consulte <xref linkend=\"example-parentchild\" />."
 
 #. Tag: para
-#: collection_mapping.xml:926
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Even more complex association mappings are covered in the next chapter."
 msgstr ""
-"Até mesmo o mapeamento de associações mais exóticas são possíveis, nós "
-"catalogaremos todas as possibilidades no próximo capítulo."
-
-#~ msgid "Collection Mapping"
-#~ msgstr "Mapeamento de Coleções"
-
-#~ msgid "Some examples, first, a set of strings:"
-#~ msgstr "Some examples, first, a set of strings:"
-
-#~ msgid ""
-#~ "The previous sections are pretty confusing. So lets look at an example. "
-#~ "This class:"
-#~ msgstr ""
-#~ "As seções anteriores são uma grande confusão. Assim sendo vejamos uma "
-#~ "exemplo. Essa classe:"
-
-#~ msgid ""
-#~ "<literal>column_name</literal> (required): The name of the column holding "
-#~ "the collection index values."
-#~ msgstr ""
-#~ "<literal>column_name</literal> (required): The name of the column holding "
-#~ "the collection index values."
-
-#~ msgid ""
-#~ "<literal>base</literal> (optional, defaults to <literal>0</literal>): The "
-#~ "value of the index column that corresponds to the first element of the "
-#~ "list or array."
-#~ msgstr ""
-#~ "<literal>base</literal> (optional, defaults to <literal>0</literal>): The "
-#~ "value of the index column that corresponds to the first element of the "
-#~ "list or array."
-
-#~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the column holding the "
-#~ "collection index values."
-#~ msgstr ""
-#~ "<literal>column</literal> (optional): The name of the column holding the "
-#~ "collection index values."
-
-#~ msgid ""
-#~ "<literal>formula</literal> (optional): A SQL formula used to evaluate the "
-#~ "key of the map."
-#~ msgstr ""
-#~ "<literal>formula</literal> (optional): A SQL formula used to evaluate the "
-#~ "key of the map."
-
-#~ msgid "<literal>type</literal> (reguired): The type of the map keys."
-#~ msgstr "<literal>type</literal> (reguired): The type of the map keys."
-
-#~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the foreign key column "
-#~ "for the collection index values."
-#~ msgstr ""
-#~ "<literal>column</literal> (optional): The name of the foreign key column "
-#~ "for the collection index values."
-
-#~ msgid ""
-#~ "<literal>formula</literal> (optional): A SQL formula used to evaluate the "
-#~ "foreign key of the map key."
-#~ msgstr ""
-#~ "<literal>formula</literal> (optional): A SQL formula used to evaluate the "
-#~ "foreign key of the map key."
-
-#~ msgid ""
-#~ "<literal>class</literal> (required): The entity class used as the map key."
-#~ msgstr ""
-#~ "<literal>class</literal> (required): The entity class used as the map key."
-
-#~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the column holding the "
-#~ "collection element values."
-#~ msgstr ""
-#~ "<literal>column</literal> (optional): The name of the column holding the "
-#~ "collection element values."
-
-#~ msgid ""
-#~ "<literal>formula</literal> (optional): An SQL formula used to evaluate "
-#~ "the element."
-#~ msgstr ""
-#~ "<literal>formula</literal> (optional): An SQL formula used to evaluate "
-#~ "the element."
-
-#~ msgid ""
-#~ "<literal>type</literal> (required): The type of the collection element."
-#~ msgstr ""
-#~ "<literal>type</literal> (required): The type of the collection element."
-
-#~ msgid ""
-#~ "A <emphasis>many-to-many association</emphasis> is specified using the "
-#~ "<literal>&lt;many-to-many&gt;</literal> element."
-#~ msgstr ""
-#~ "A <emphasis>many-to-many association</emphasis> is specified using the "
-#~ "<literal>&lt;many-to-many&gt;</literal> element."
-
-#~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the element foreign key "
-#~ "column."
-#~ msgstr ""
-#~ "<literal>column</literal> (optional): The name of the element foreign key "
-#~ "column."
-
-#~ msgid ""
-#~ "<literal>formula</literal> (optional): An SQL formula used to evaluate "
-#~ "the element foreign key value."
-#~ msgstr ""
-#~ "<literal>formula</literal> (optional): An SQL formula used to evaluate "
-#~ "the element foreign key value."
-
-#~ msgid ""
-#~ "<literal>fetch</literal> (optional - defaults to <literal>join</"
-#~ "literal>): enables outer-join or sequential select fetching for this "
-#~ "association. This is a special case; for full eager fetching (in a single "
-#~ "<literal>SELECT</literal>) of an entity and its many-to-many "
-#~ "relationships to other entities, you would enable <literal>join</literal> "
-#~ "fetching not only of the collection itself, but also with this attribute "
-#~ "on the <literal>&lt;many-to-many&gt;</literal> nested element."
-#~ msgstr ""
-#~ "<literal>fetch</literal> (optional - defaults to <literal>join</"
-#~ "literal>): enables outer-join or sequential select fetching for this "
-#~ "association. This is a special case; for full eager fetching (in a single "
-#~ "<literal>SELECT</literal>) of an entity and its many-to-many "
-#~ "relationships to other entities, you would enable <literal>join</literal> "
-#~ "fetching not only of the collection itself, but also with this attribute "
-#~ "on the <literal>&lt;many-to-many&gt;</literal> nested element."
-
-#~ msgid ""
-#~ "<literal>unique</literal> (optional): Enable the DDL generation of a "
-#~ "unique constraint for the foreign-key column. This makes the association "
-#~ "multiplicity effectively one to many."
-#~ msgstr ""
-#~ "<literal>unique</literal> (optional): Enable the DDL generation of a "
-#~ "unique constraint for the foreign-key column. This makes the association "
-#~ "multiplicity effectively one to many."
-
-#~ msgid ""
-#~ "<literal>not-found</literal> (optional - defaults to <literal>exception</"
-#~ "literal>): Specifies how foreign keys that reference missing rows will be "
-#~ "handled: <literal>ignore</literal> will treat a missing row as a null "
-#~ "association."
-#~ msgstr ""
-#~ "<literal>not-found</literal> (optional - defaults to <literal>exception</"
-#~ "literal>): Specifies how foreign keys that reference missing rows will be "
-#~ "handled: <literal>ignore</literal> will treat a missing row as a null "
-#~ "association."
-
-#~ msgid ""
-#~ "<literal>property-ref</literal>: (optional) The name of a property of the "
-#~ "associated class that is joined to this foreign key. If not specified, "
-#~ "the primary key of the associated class is used."
-#~ msgstr ""
-#~ "<literal>property-ref</literal>: (optional) The name of a property of the "
-#~ "associated class that is joined to this foreign key. If not specified, "
-#~ "the primary key of the associated class is used."
+"Até mesmo o mapeamento de associações mais complexos serão discutimos no "
+"próximo capítulo."

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/component_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/component_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/component_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,40 +1,143 @@
+# translation of component_mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: component_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-10-26 11:53+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: component_mapping.xml:29
 #, no-c-format
 msgid "Component Mapping"
 msgstr "Mapeamento de Componentes"
 
 #. Tag: para
-#: component_mapping.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The notion of a <emphasis>component</emphasis> is re-used in several "
 "different contexts and purposes throughout Hibernate."
 msgstr ""
-"A noção de <emphasis>componente</emphasis> é reusada em vários contextos "
-"diferentes, para propósitos diferentes, pelo Hibernate."
+"A noção de <emphasis>componente</emphasis> é re-utilizada em vários "
+"contextos diferentes, para propósitos diferentes, pelo Hibernate. "
 
 #. Tag: title
-#: component_mapping.xml:37
 #, no-c-format
 msgid "Dependent objects"
 msgstr "Objetos dependentes"
 
 #. Tag: para
-#: component_mapping.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A component is a contained object that is persisted as a value type and not "
 "an entity reference. The term \"component\" refers to the object-oriented "
@@ -43,73 +146,12 @@
 msgstr ""
 "Um componente é um objeto contido que é persistido como um tipo de valor, "
 "não uma referência de entidade. O termo \"componente\" refere-se à noção de "
-"composição da orientação a objetos (não a componentes no nível de "
-"arquitetura). Por exemplo, você pode modelar uma pessoa desta maneira:"
+"composição da orientação a objetos e não a componentes no nível de "
+"arquitetura. Por exemplo, você pode modelar uma pessoa desta maneira: "
 
-#. Tag: programlisting
-#: component_mapping.xml:45
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[public class Person {\n"
-"    private java.util.Date birthday;\n"
-"    private Name name;\n"
-"    private String key;\n"
-"    public String getKey() {\n"
-"        return key;\n"
-"    }\n"
-"    private void setKey(String key) {\n"
-"        this.key=key;\n"
-"    }\n"
-"    public java.util.Date getBirthday() {\n"
-"        return birthday;\n"
-"    }\n"
-"    public void setBirthday(java.util.Date birthday) {\n"
-"        this.birthday = birthday;\n"
-"    }\n"
-"    public Name getName() {\n"
-"        return name;\n"
-"    }\n"
-"    public void setName(Name name) {\n"
-"        this.name = name;\n"
-"    }\n"
-"    ......\n"
-"    ......\n"
-"}]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: component_mapping.xml:47
-#, no-c-format
-msgid ""
-"<![CDATA[public class Name {\n"
-"    char initial;\n"
-"    String first;\n"
-"    String last;\n"
-"    public String getFirst() {\n"
-"        return first;\n"
-"    }\n"
-"    void setFirst(String first) {\n"
-"        this.first = first;\n"
-"    }\n"
-"    public String getLast() {\n"
-"        return last;\n"
-"    }\n"
-"    void setLast(String last) {\n"
-"        this.last = last;\n"
-"    }\n"
-"    public char getInitial() {\n"
-"        return initial;\n"
-"    }\n"
-"    void setInitial(char initial) {\n"
-"        this.initial = initial;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:49
-#, fuzzy, no-c-format
-msgid ""
 "Now <literal>Name</literal> can be persisted as a component of "
 "<literal>Person</literal>. <literal>Name</literal> defines getter and setter "
 "methods for its persistent properties, but it does not need to declare any "
@@ -118,47 +160,26 @@
 "Agora <literal>Name</literal> pode ser persistido como um componente de "
 "<literal>Person</literal>. Note que <literal>Name</literal> define métodos "
 "getter e setter para suas propriedades persistentes, mas não necessita "
-"declarar nenhuma interface ou propriedades identificadoras."
+"declarar nenhuma interface ou propriedades identificadoras. "
 
 #. Tag: para
-#: component_mapping.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Our Hibernate mapping would look like this:"
-msgstr "Nosso mapeamento do Hibernate seria semelhante a isso"
+msgstr "Nosso mapeamento do Hibernate seria semelhante a este: "
 
-#. Tag: programlisting
-#: component_mapping.xml:60
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-"    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    <property name=\"birthday\" type=\"date\"/>\n"
-"    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
-"optional -->\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </component>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:62
 #, no-c-format
 msgid ""
 "The person table would have the columns <literal>pid</literal>, "
 "<literal>birthday</literal>, <literal>initial</literal>, <literal>first</"
 "literal> and <literal>last</literal>."
 msgstr ""
-"A tabela pessoa teria as seguintes colunas <literal>pid</literal>, "
+"A tabela person teria as seguintes colunas <literal>pid</literal>, "
 "<literal>birthday</literal>, <literal>initial</literal>, <literal>first</"
 "literal> and <literal>last</literal>."
 
 #. Tag: para
-#: component_mapping.xml:70
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Like value types, components do not support shared references. In other "
 "words, two persons could have the same name, but the two person objects "
@@ -168,18 +189,16 @@
 "if all component columns are null, then the entire component is null. This "
 "is suitable for most purposes."
 msgstr ""
-"Assim como todos tipos por valor, componentes não suportam referencias "
-"cruzadas. Em outras palavras, duas pessoas poderiam possuir o mesmo nome, "
-"mas os dois objetos pessoa poderiam conter dois objetos nome independentes, "
-"apenas com \"o mesmo\" por valor. A semântica dos valores null de um "
-"componente são <emphasis>ad hoc</emphasis>. No recarregameno do conteúdo do "
-"objeto, O Hibernate assumira que se todas as colunas do componente são null, "
-"então todo o componente é null. Isto seria o certo para a maioria dos "
-"propósitos."
+"Assim como todos tipos por valor, componentes não suportam referências "
+"cruzadas. Em outras palavras, duas persons podem ter o mesmo nome, mas os "
+"dois objetos person podem ter dois objetos de nome independentes, apenas \"o "
+"mesmo\" por valor. A semântica dos valores null de um componente são "
+"<emphasis>ad hoc</emphasis>. No recarregameno do conteúdo do objeto, o "
+"Hibernate entenderá que se todas as colunas do componente são null, então "
+"todo o componente é null. Isto seria o certo para a maioria dos propósitos."
 
 #. Tag: para
-#: component_mapping.xml:78
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The properties of a component can be of any Hibernate type (collections, "
 "many-to-one associations, other components, etc). Nested components should "
@@ -187,91 +206,53 @@
 "intended to support a fine-grained object model."
 msgstr ""
 "As propriedades de um componente podem ser de qualquer tipo do Hibernate"
-"(collections, associações muitos-para-um, outros componentes, etc). "
-"Componentes agrupados <emphasis>não </emphasis> devem ser consideros um uso "
-"exótico. O Hibernate tem a intenção de suportar um modelo de objetos muito "
-"bem granulado."
+"(coleções, associações muitos-para-um, outros componentes, etc). Componentes "
+"agrupados <emphasis>não</emphasis> devem ser considerados luxo. O Hibernate "
+"tem a intenção de suportar um modelo de objetos fine-grained (muito bem "
+"granulados)."
 
 #. Tag: para
-#: component_mapping.xml:85
 #, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element allows a <literal>&lt;"
 "parent&gt;</literal> subelement that maps a property of the component class "
 "as a reference back to the containing entity."
 msgstr ""
-"O elemento <literal>&lt;component&gt;</literal> permite um subelemento "
-"<literal>&lt;parent&gt;</literal> que mapeia uma propriedade da classe "
-"componente como uma referência de volta para a entidade que a contém."
+"O elemento <literal>&lt;component&gt;</literal> permite um sub-elemento "
+"<literal>&lt;parent&gt;</literal> mapeie uma propriedade da classe do "
+"componente como uma referencia de volta para a entidade que o contém."
 
-#. Tag: programlisting
-#: component_mapping.xml:91
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-"    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    <property name=\"birthday\" type=\"date\"/>\n"
-"    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
-"        <parent name=\"namedPerson\"/> <!-- reference back to the Person --"
-">\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </component>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: component_mapping.xml:96
 #, no-c-format
 msgid "Collections of dependent objects"
-msgstr "Collections de objetos dependentes"
+msgstr "Coleções de objetos dependentes"
 
 #. Tag: para
-#: component_mapping.xml:98
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collections of components are supported (e.g. an array of type "
 "<literal>Name</literal>). Declare your component collection by replacing the "
 "<literal>&lt;element&gt;</literal> tag with a <literal>&lt;composite-"
 "element&gt;</literal> tag:"
 msgstr ""
-"Collections de componentes são suportadadas(ex. uma array de tipo "
-"<literal>Name</literal>). Declare a sua collection de componentes "
-"substituindo a tag<literal>&lt;element&gt;</literal> pela tag <literal>&lt;"
-"composite-element&gt;</literal>."
+"Coleções de componentes são suportadas (ex.: uma matriz de tipo "
+"<literal>Name</literal>). Declare a sua coleção de componentes substituindo "
+"a tag<literal>&lt;element&gt;</literal> pela tag <literal>&lt;composite-"
+"element&gt;</literal>. "
 
-#. Tag: programlisting
-#: component_mapping.xml:105
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
-"    <key column=\"id\"/>\n"
-"    <composite-element class=\"eg.Name\"> <!-- class attribute required -->\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </composite-element>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:108
-#, fuzzy, no-c-format
-msgid ""
 "If you define a <literal>Set</literal> of composite elements, it is "
 "important to implement <literal>equals()</literal> and <literal>hashCode()</"
 "literal> correctly."
 msgstr ""
-"Nota: se você definir um <literal>Set</literal> de elementos compostos, é "
-"muito importante implementar <literal>equals()</literal> e <literal>hashCode"
-"()</literal> corretamente."
+"Se você definir um <literal>Set</literal> de elementos compostos, é muito "
+"importante implementar <literal>equals()</literal> e <literal>hashCode()</"
+"literal> corretamente. "
 
 #. Tag: para
-#: component_mapping.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Composite elements can contain components but not collections. If your "
 "composite element contains components, use the <literal>&lt;nested-composite-"
@@ -281,18 +262,17 @@
 "but be aware that even though the Java model is the same, the relational "
 "model and persistence semantics are still slightly different."
 msgstr ""
-"Elementos compostos podem conter componentes mas não collections. Se o seu "
-"elemento composto contiver componentes , use a tag <literal>&lt;nested-"
-"composite-element&gt;</literal> . Este é um caso bastante exótico – uma "
-"collections de componentes que por si própria possui componentes. Neste "
-"momento você deve estar se perguntando se uma associação de um-para-muitos "
-"seria mais apropriada. Tente remodelar o elemento composto como uma entidade "
-"– mas note que mesmo pensando que o modelo Java é o mesmo, o modelo "
-"relacional e a semântica de persistência ainda são diferentes."
+"Elementos compostos podem conter componentes mas não coleções. Se o seu "
+"elemento composto tiver componentes , use a tag <literal>&lt;nested-"
+"composite-element&gt;</literal>. Este é um caso bastante exótico – coleções "
+"de componentes que por si própria possui componentes. Neste momento você "
+"deve estar se perguntando se uma associação de um-para-muitos seria mais "
+"apropriada. Tente remodelar o elemento composto como uma entidade – mas note "
+"que mesmo pensando que o modelo Java é o mesmo, o modelo relacional e a "
+"semântica de persistência ainda são diferentes."
 
 #. Tag: para
-#: component_mapping.xml:127
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A composite element mapping does not support null-able properties if you are "
 "using a <literal>&lt;set&gt;</literal>. There is no separate primary key "
@@ -302,19 +282,17 @@
 "element or choose a <literal>&lt;list&gt;</literal>, <literal>&lt;map&gt;</"
 "literal>, <literal>&lt;bag&gt;</literal> or <literal>&lt;idbag&gt;</literal>."
 msgstr ""
-"Por favor, note que um mapeamento de elemento composto não suporta "
-"propriedades capazes de serem null se você estiver usando um <literal>&lt;"
-"set&gt;</literal>. O Hibernate tem que usar cada valor das colunas para "
-"identificar um registro quando estiver deletando objetos (não existe coluna "
-"chave primária separada na tabela de elemento composto), que não é possível "
-"com valores null. Você tem que usar um dos dois, ou apenas propriedades não "
-"null em um elemento composto ou escolher uma <literal>&lt;list&gt;</"
-"literal>, <literal>&lt;map&gt;</literal>, <literal>&lt;bag&gt;</literal> ou "
-"<literal>&lt;idbag&gt;</literal>."
+"Um mapeamento de elemento composto não suporta propriedades capazes de serem "
+"null se você estiver usando um <literal>&lt;set&gt;</literal>. Não existe "
+"coluna chave primária separada na tabela de elemento composto. O Hibernate "
+"tem que usar cada valor das colunas para identificar um registro quando "
+"estiver deletando objetos, que não é possível com valores null. Você tem que "
+"usar um dos dois, ou apenas propriedades não null em um elemento composto ou "
+"escolher uma <literal>&lt;list&gt;</literal>, <literal>&lt;map&gt;</"
+"literal>, <literal>&lt;bag&gt;</literal> ou <literal>&lt;idbag&gt;</literal>."
 
 #. Tag: para
-#: component_mapping.xml:138
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A special case of a composite element is a composite element with a nested "
 "<literal>&lt;many-to-one&gt;</literal> element. This mapping allows you to "
@@ -326,74 +304,35 @@
 msgstr ""
 "Um caso especial de elemento composto é um elemento composto com um elemento "
 "<literal>&lt;many-to-one&gt;</literal> aninhado. Um mapeamento como este "
-"permite você a mapear colunas extras de uma tabela de associação de muitos-"
+"permite que você mapeie colunas extras de uma tabela de associação de muitos-"
 "para-muitos para a classe de elemento composto. A seguinte associação de "
 "muitos-para-muitos de <literal>Order</literal> para um <literal>Item</"
 "literal> onde <literal>purchaseDate</literal>, <literal>price</literal> e "
 "<literal>quantity</literal> são propriedades da associação:"
 
-#. Tag: programlisting
-#: component_mapping.xml:148
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"eg.Order\" .... >\n"
-"    ....\n"
-"    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-"        <key column=\"order_id\">\n"
-"        <composite-element class=\"eg.Purchase\">\n"
-"            <property name=\"purchaseDate\"/>\n"
-"            <property name=\"price\"/>\n"
-"            <property name=\"quantity\"/>\n"
-"            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class "
-"attribute is optional -->\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:150
-#, fuzzy, no-c-format
-msgid ""
 "There cannot be a reference to the purchase on the other side for "
 "bidirectional association navigation. Components are value types and do not "
 "allow shared references. A single <literal>Purchase</literal> can be in the "
 "set of an <literal>Order</literal>, but it cannot be referenced by the "
 "<literal>Item</literal> at the same time."
 msgstr ""
-"Claro, que não pode ter uma referência para purchase no outro lado, para a "
-"navegação da associação bidirecional. Lembre-se que componentes são tipos "
-"por valor e não permitem referências compartilhadas. Uma classe "
-"<literal>Purchase</literal> simples pode estar no set de uma classe "
-"<literal>Order</literal>, mas ela não pode ser referenciada por "
-"<literal>Item</literal> no mesmo momento."
+"Não pode haver uma referência de compra no outro lado, para a navegação da "
+"associação bidirecional. Lembre-se que componentes são tipos por valor e não "
+"permitem referências compartilhadas. Uma classe <literal>Purchase</literal> "
+"simples pode estar no conjunto de uma classe <literal>Order</literal>, mas "
+"ela não pode ser referenciada por <literal>Item</literal> no mesmo momento."
 
 #. Tag: para
-#: component_mapping.xml:158
 #, no-c-format
 msgid "Even ternary (or quaternary, etc) associations are possible:"
 msgstr "Até mesmo associações ternárias (ou quaternária, etc) são possíveis:"
 
-#. Tag: programlisting
-#: component_mapping.xml:160
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"eg.Order\" .... >\n"
-"    ....\n"
-"    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-"        <key column=\"order_id\">\n"
-"        <composite-element class=\"eg.OrderLine\">\n"
-"            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
-"            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:162
-#, fuzzy, no-c-format
-msgid ""
 "Composite elements can appear in queries using the same syntax as "
 "associations to other entities."
 msgstr ""
@@ -401,14 +340,12 @@
 "como associações para outras entidades."
 
 #. Tag: title
-#: component_mapping.xml:170
 #, no-c-format
 msgid "Components as Map indices"
 msgstr "Componentes como índices de Map"
 
 #. Tag: para
-#: component_mapping.xml:172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;composite-map-key&gt;</literal> element allows you to map a "
 "component class as the key of a <literal>Map</literal>. Ensure that you "
@@ -418,71 +355,63 @@
 "O elemento <literal>&lt;composite-map-key&gt;</literal> permite você mapear "
 "uma classe componente como uma chave de um <literal>Map</literal>. Tenha "
 "certeza que você sobrescreveu <literal>hashCode()</literal> e <literal>equals"
-"()</literal> corretamente na classe componente."
+"()</literal> corretamente na classe componente. "
 
 #. Tag: title
-#: component_mapping.xml:181
 #, no-c-format
 msgid "Components as composite identifiers"
-msgstr ". Componentes como identificadores compostos"
+msgstr "Componentes como identificadores compostos"
 
 #. Tag: para
-#: component_mapping.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can use a component as an identifier of an entity class. Your component "
 "class must satisfy certain requirements:"
 msgstr ""
 "Você pode usar um componente como um identificador de uma classe entidade. "
-"Sua classe componente deve satisfazer certos requisitos:"
+"Sua classe componente deve satisfazer certos requisitos: "
 
 #. Tag: para
-#: component_mapping.xml:190
 #, no-c-format
 msgid "It must implement <literal>java.io.Serializable</literal>."
 msgstr "Ele deve implementar <literal>java.io.Serializable</literal>."
 
 #. Tag: para
-#: component_mapping.xml:195
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It must re-implement <literal>equals()</literal> and <literal>hashCode()</"
 "literal> consistently with the database's notion of composite key equality."
 msgstr ""
 "Ele deve re-implementar <literal>equals()</literal> e <literal>hashCode()</"
 "literal>, consistentemente com a noção de igualdade de chave composta do "
-"banco de dados."
+"banco de dados. "
 
 #. Tag: title
-#: component_mapping.xml:204
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Nota"
 
 #. Tag: para
-#: component_mapping.xml:205
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In Hibernate3, although the second requirement is not an absolutely hard "
 "requirement of Hibernate, it is recommended."
 msgstr ""
-"Nota: no Hibernate 3, o segundo requisito não é um requisito absolutamente "
+"No Hibernate 3, o segundo requisito não é um requisito absolutamente "
 "necessário. Mas atenda ele de qualquer forma."
 
 #. Tag: para
-#: component_mapping.xml:211
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You cannot use an <literal>IdentifierGenerator</literal> to generate "
 "composite keys. Instead the application must assign its own identifiers."
 msgstr ""
 "Você não pode usar um <literal>IdentifierGenerator</literal> para gerar "
-"chaves compostas. Ao invés disso o aplicativo deve gerenciar seus próprios "
+"chaves compostas. Ao invés disso, o aplicativo deve gerenciar seus próprios "
 "identificadores."
 
 #. Tag: para
-#: component_mapping.xml:216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use the <literal>&lt;composite-id&gt;</literal> tag, with nested "
 "<literal>&lt;key-property&gt;</literal> elements, in place of the usual "
@@ -490,73 +419,36 @@
 "<literal>OrderLine</literal> class has a primary key that depends upon the "
 "(composite) primary key of <literal>Order</literal>."
 msgstr ""
-"Use a tag <literal>&lt;composite-id&gt;</literal> (com elementos "
-"<literal>&lt;key-property&gt;</literal> aninhados) no lugar da declaração "
+"Use a tag <literal>&lt;composite-id&gt;</literal>, com elementos "
+"<literal>&lt;key-property&gt;</literal> aninhados, no lugar da declaração "
 "<literal>&lt;id&gt;</literal> de costume. Por exemplo, a classe "
 "<literal>OrderLine</literal> possui uma chave primária que depende da chave "
-"primária (composta) de <literal>Order</literal>."
+"primária (composta) de <literal>Order</literal>. "
 
-#. Tag: programlisting
-#: component_mapping.xml:224
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"OrderLine\">\n"
-"\n"
-"    <composite-id name=\"id\" class=\"OrderLineId\">\n"
-"        <key-property name=\"lineId\"/>\n"
-"        <key-property name=\"orderId\"/>\n"
-"        <key-property name=\"customerId\"/>\n"
-"    </composite-id>\n"
-"\n"
-"    <property name=\"name\"/>\n"
-"\n"
-"    <many-to-one name=\"order\" class=\"Order\"\n"
-"            insert=\"false\" update=\"false\">\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </many-to-one>\n"
-"    ....\n"
-"\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:226
-#, fuzzy, no-c-format
-msgid ""
 "Any foreign keys referencing the <literal>OrderLine</literal> table are now "
 "composite. Declare this in your mappings for other classes. An association "
 "to <literal>OrderLine</literal> is mapped like this:"
 msgstr ""
-"Agora, qualquer chave estrangeira referenciando a tabela <literal>OrderLine</"
-"literal> também serão compostas. Você deve declarar isto em seus mapeamentos "
+"Agora, qualquer chave exterior referenciando a tabela <literal>OrderLine</"
+"literal> também será composta. Você deve declarar isto em seus mapeamentos "
 "para outras classes. Uma associação para <literal>OrderLine</literal> seria "
 "mapeada dessa forma:"
 
-#. Tag: programlisting
-#: component_mapping.xml:232
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
-"<!-- the \"class\" attribute is optional, as usual -->\n"
-"    <column name=\"lineId\"/>\n"
-"    <column name=\"orderId\"/>\n"
-"    <column name=\"customerId\"/>\n"
-"</many-to-one>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:235
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The <literal>column</literal> element is an alternative to the "
 "<literal>column</literal> attribute everywhere. Using the <literal>column</"
 "literal> element just gives more declaration options, which are mostly "
 "useful when utilizing <literal>hbm2ddl</literal>"
 msgstr ""
+"A tag <literal>&lt;column&gt;</literal> é uma alternativa para a função "
+"<literal>column</literal> em todos os lugares."
 
 #. Tag: para
-#: component_mapping.xml:244
 #, no-c-format
 msgid ""
 "A <literal>many-to-many</literal> association to <literal>OrderLine</"
@@ -565,110 +457,43 @@
 "Uma associação <literal>many-to-many</literal> para <literal>many-to-many</"
 "literal> também usa a chave estrangeira composta:"
 
-#. Tag: programlisting
-#: component_mapping.xml:249
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"undeliveredOrderLines\">\n"
-"    <key column name=\"warehouseId\"/>\n"
-"    <many-to-many class=\"OrderLine\">\n"
-"        <column name=\"lineId\"/>\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </many-to-many>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:251
 #, no-c-format
 msgid ""
 "The collection of <literal>OrderLine</literal>s in <literal>Order</literal> "
 "would use:"
 msgstr ""
-"A collection de <literal>OrderLine</literal>s em <literal>Order</literal> "
-"usaria:"
+"A coleção de <literal>OrderLine</literal>s em <literal>Order</literal> "
+"usaria:  "
 
-#. Tag: programlisting
-#: component_mapping.xml:256
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
-"    <key>\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </key>\n"
-"    <one-to-many class=\"OrderLine\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:258
-#, fuzzy, no-c-format
 msgid "The <literal>&lt;one-to-many&gt;</literal> element declares no columns."
-msgstr ""
-"(O elemento <literal>&lt;one-to-many&gt;</literal>, como de costume, não "
-"declara colunas.)"
+msgstr "O elemento <literal>&lt;one-to-many&gt;</literal> não declara colunas."
 
 #. Tag: para
-#: component_mapping.xml:262
 #, no-c-format
 msgid ""
 "If <literal>OrderLine</literal> itself owns a collection, it also has a "
 "composite foreign key."
 msgstr ""
-"Se <literal>OrderLine</literal> possui uma collection, ela também tem uma "
-"chave estrangeira composta."
+"Se <literal>OrderLine</literal> possui uma coleção, ela também tem uma chave "
+"externa composta."
 
-#. Tag: programlisting
-#: component_mapping.xml:267
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"OrderLine\">\n"
-"    ....\n"
-"    ....\n"
-"    <list name=\"deliveryAttempts\">\n"
-"        <key>   <!-- a collection inherits the composite key type -->\n"
-"            <column name=\"lineId\"/>\n"
-"            <column name=\"orderId\"/>\n"
-"            <column name=\"customerId\"/>\n"
-"        </key>\n"
-"        <list-index column=\"attemptId\" base=\"1\"/>\n"
-"        <composite-element class=\"DeliveryAttempt\">\n"
-"            ...\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: component_mapping.xml:272
 #, no-c-format
 msgid "Dynamic components"
 msgstr "Componentes Dinâmicos"
 
 #. Tag: para
-#: component_mapping.xml:274
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can also map a property of type <literal>Map</literal>:"
 msgstr ""
-"Você pode até mesmo mapear uma propriedade do tipo <literal>Map</literal>:"
+"Você pode até mesmo mapear uma propriedade do tipo <literal>Map</literal>: "
 
-#. Tag: programlisting
-#: component_mapping.xml:278
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<dynamic-component name=\"userAttributes\">\n"
-"    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
-"    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
-"    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
-"</dynamic-component>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:280
-#, fuzzy, no-c-format
-msgid ""
 "The semantics of a <literal>&lt;dynamic-component&gt;</literal> mapping are "
 "identical to <literal>&lt;component&gt;</literal>. The advantage of this "
 "kind of mapping is the ability to determine the actual properties of the "
@@ -680,15 +505,375 @@
 "A semântica de um mapeamento <literal>&lt;dynamic-component&gt;</literal> é "
 "idêntica à <literal>&lt;component&gt;</literal>. A vantagem deste tipo de "
 "mapeamento é a habilidade de determinar as propriedades atuais do bean no "
-"momento de deploy, apenas editando o documento de mapeamento. A Manipulação "
-"em tempo de execução do documento de mapeamento também é possível, usando o "
-"parser DOM. Até melhor, você pode acessar (e mudar) o metamodelo "
-"configuration-time do Hibernate através do objeto <literal>Configuration</"
-"literal>."
+"momento da implementação, apenas editando o documento de mapeamento. A "
+"Manipulação em tempo de execução do documento de mapeamento também é "
+"possível, usando o parser DOM. Até melhor, você pode acessar,e mudar, o "
+"tempo de configuração do metamodelo do Hibernate através do objeto "
+"<literal>Configuration</literal>."
 
 #~ msgid ""
-#~ "(Note that the <literal>&lt;column&gt;</literal> tag is an alternative to "
-#~ "the <literal>column</literal> attribute everywhere.)"
+#~ "<![CDATA[public class Person {\n"
+#~ "    private java.util.Date birthday;\n"
+#~ "    private Name name;\n"
+#~ "    private String key;\n"
+#~ "    public String getKey() {\n"
+#~ "        return key;\n"
+#~ "    }\n"
+#~ "    private void setKey(String key) {\n"
+#~ "        this.key=key;\n"
+#~ "    }\n"
+#~ "    public java.util.Date getBirthday() {\n"
+#~ "        return birthday;\n"
+#~ "    }\n"
+#~ "    public void setBirthday(java.util.Date birthday) {\n"
+#~ "        this.birthday = birthday;\n"
+#~ "    }\n"
+#~ "    public Name getName() {\n"
+#~ "        return name;\n"
+#~ "    }\n"
+#~ "    public void setName(Name name) {\n"
+#~ "        this.name = name;\n"
+#~ "    }\n"
+#~ "    ......\n"
+#~ "    ......\n"
+#~ "}]]>"
 #~ msgstr ""
-#~ "(Note que a tag <literal>&lt;column&gt;</literal> é uma alternativa para "
-#~ "o atributo <literal>column</literal> por toda a parte.)"
+#~ "<![CDATA[public class Person {\n"
+#~ "    private java.util.Date birthday;\n"
+#~ "    private Name name;\n"
+#~ "    private String key;\n"
+#~ "    public String getKey() {\n"
+#~ "        return key;\n"
+#~ "    }\n"
+#~ "    private void setKey(String key) {\n"
+#~ "        this.key=key;\n"
+#~ "    }\n"
+#~ "    public java.util.Date getBirthday() {\n"
+#~ "        return birthday;\n"
+#~ "    }\n"
+#~ "    public void setBirthday(java.util.Date birthday) {\n"
+#~ "        this.birthday = birthday;\n"
+#~ "    }\n"
+#~ "    public Name getName() {\n"
+#~ "        return name;\n"
+#~ "    }\n"
+#~ "    public void setName(Name name) {\n"
+#~ "        this.name = name;\n"
+#~ "    }\n"
+#~ "    ......\n"
+#~ "    ......\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[public class Name {\n"
+#~ "    char initial;\n"
+#~ "    String first;\n"
+#~ "    String last;\n"
+#~ "    public String getFirst() {\n"
+#~ "        return first;\n"
+#~ "    }\n"
+#~ "    void setFirst(String first) {\n"
+#~ "        this.first = first;\n"
+#~ "    }\n"
+#~ "    public String getLast() {\n"
+#~ "        return last;\n"
+#~ "    }\n"
+#~ "    void setLast(String last) {\n"
+#~ "        this.last = last;\n"
+#~ "    }\n"
+#~ "    public char getInitial() {\n"
+#~ "        return initial;\n"
+#~ "    }\n"
+#~ "    void setInitial(char initial) {\n"
+#~ "        this.initial = initial;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[public class Name {\n"
+#~ "    char initial;\n"
+#~ "    String first;\n"
+#~ "    String last;\n"
+#~ "    public String getFirst() {\n"
+#~ "        return first;\n"
+#~ "    }\n"
+#~ "    void setFirst(String first) {\n"
+#~ "        this.first = first;\n"
+#~ "    }\n"
+#~ "    public String getLast() {\n"
+#~ "        return last;\n"
+#~ "    }\n"
+#~ "    void setLast(String last) {\n"
+#~ "        this.last = last;\n"
+#~ "    }\n"
+#~ "    public char getInitial() {\n"
+#~ "        return initial;\n"
+#~ "    }\n"
+#~ "    void setInitial(char initial) {\n"
+#~ "        this.initial = initial;\n"
+#~ "    }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
+#~ "optional -->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
+#~ "optional -->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
+#~ "        <parent name=\"namedPerson\"/> <!-- reference back to the Person "
+#~ "-->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
+#~ "        <parent name=\"namedPerson\"/> <!-- reference back to the Person "
+#~ "-->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
+#~ "    <key column=\"id\"/>\n"
+#~ "    <composite-element class=\"eg.Name\"> <!-- class attribute required --"
+#~ ">\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </composite-element>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
+#~ "    <key column=\"id\"/>\n"
+#~ "    <composite-element class=\"eg.Name\"> <!-- class attribute required --"
+#~ ">\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </composite-element>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.Purchase\">\n"
+#~ "            <property name=\"purchaseDate\"/>\n"
+#~ "            <property name=\"price\"/>\n"
+#~ "            <property name=\"quantity\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class "
+#~ "attribute is optional -->\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.Purchase\">\n"
+#~ "            <property name=\"purchaseDate\"/>\n"
+#~ "            <property name=\"price\"/>\n"
+#~ "            <property name=\"quantity\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class "
+#~ "attribute is optional -->\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.OrderLine\">\n"
+#~ "            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.OrderLine\">\n"
+#~ "            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" class=\"OrderLineId\">\n"
+#~ "        <key-property name=\"lineId\"/>\n"
+#~ "        <key-property name=\"orderId\"/>\n"
+#~ "        <key-property name=\"customerId\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\" class=\"Order\"\n"
+#~ "            insert=\"false\" update=\"false\">\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    ....\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" class=\"OrderLineId\">\n"
+#~ "        <key-property name=\"lineId\"/>\n"
+#~ "        <key-property name=\"orderId\"/>\n"
+#~ "        <key-property name=\"customerId\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\" class=\"Order\"\n"
+#~ "            insert=\"false\" update=\"false\">\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    ....\n"
+#~ "    \n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
+#~ "<!-- the \"class\" attribute is optional, as usual -->\n"
+#~ "    <column name=\"lineId\"/>\n"
+#~ "    <column name=\"orderId\"/>\n"
+#~ "    <column name=\"customerId\"/>\n"
+#~ "</many-to-one>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
+#~ "<!-- the \"class\" attribute is optional, as usual -->\n"
+#~ "    <column name=\"lineId\"/>\n"
+#~ "    <column name=\"orderId\"/>\n"
+#~ "    <column name=\"customerId\"/>\n"
+#~ "</many-to-one>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set name=\"undeliveredOrderLines\">\n"
+#~ "    <key column name=\"warehouseId\"/>\n"
+#~ "    <many-to-many class=\"OrderLine\">\n"
+#~ "        <column name=\"lineId\"/>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-many>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"undeliveredOrderLines\">\n"
+#~ "    <key column name=\"warehouseId\"/>\n"
+#~ "    <many-to-many class=\"OrderLine\">\n"
+#~ "        <column name=\"lineId\"/>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-many>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
+#~ "    <key>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </key>\n"
+#~ "    <one-to-many class=\"OrderLine\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
+#~ "    <key>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </key>\n"
+#~ "    <one-to-many class=\"OrderLine\"/>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    ....\n"
+#~ "    ....\n"
+#~ "    <list name=\"deliveryAttempts\">\n"
+#~ "        <key>   <!-- a collection inherits the composite key type -->\n"
+#~ "            <column name=\"lineId\"/>\n"
+#~ "            <column name=\"orderId\"/>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "        </key>\n"
+#~ "        <list-index column=\"attemptId\" base=\"1\"/>\n"
+#~ "        <composite-element class=\"DeliveryAttempt\">\n"
+#~ "            ...\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    ....\n"
+#~ "    ....\n"
+#~ "    <list name=\"deliveryAttempts\">\n"
+#~ "        <key>   <!-- a collection inherits the composite key type -->\n"
+#~ "            <column name=\"lineId\"/>\n"
+#~ "            <column name=\"orderId\"/>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "        </key>\n"
+#~ "        <list-index column=\"attemptId\" base=\"1\"/>\n"
+#~ "        <composite-element class=\"DeliveryAttempt\">\n"
+#~ "            ...\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<dynamic-component name=\"userAttributes\">\n"
+#~ "    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
+#~ "    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
+#~ "    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
+#~ "</dynamic-component>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<dynamic-component name=\"userAttributes\">\n"
+#~ "    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
+#~ "    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
+#~ "    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
+#~ "</dynamic-component>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/configuration.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/configuration.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/configuration.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,129 @@
+# translation of configuration.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: configuration\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-19 08:53+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: configuration.xml:29
 #, no-c-format
 msgid "Configuration"
-msgstr "Configuração"
+msgstr "Configuration"
 
 #. Tag: para
-#: configuration.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate is designed to operate in many different environments and, as "
 "such, there is a broad range of configuration parameters. Fortunately, most "
@@ -27,22 +132,20 @@
 "displays the various options. Simply put the example file in your classpath "
 "and customize it to suit your needs."
 msgstr ""
-"Devido ao fato de o Hibernate ser projetado para operar em vários ambientes "
+"Devido ao fato do Hibernate ser projetado para operar em vários ambientes "
 "diferentes, há um grande número de parâmetros de configuração. Felizmente, a "
-"maioria tem valores default lógicos e o Hibernate é distribuído com um "
-"arquivo <literal>hibernate.properties</literal> de exemplo no <literal>etc/</"
-"literal> que mostra várias opções. Apenas coloque o arquivo de exemplo no "
-"seu classpath e personalize-o."
+"maioria possui valores padrão consideráveis e o Hibernate é distribuído com "
+"um arquivo <literal>hibernate.properties</literal> de exemplo no "
+"<literal>etc/</literal> que mostra várias opções. Apenas coloque o arquivo "
+"de exemplo no seu classpath e personalize-o. "
 
 #. Tag: title
-#: configuration.xml:40
 #, no-c-format
 msgid "Programmatic configuration"
-msgstr "1.11 Configuração programática"
+msgstr "Configuração programática"
 
 #. Tag: para
-#: configuration.xml:42
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of <classname>org.hibernate.cfg.Configuration</classname> "
 "represents an entire set of mappings of an application's Java types to an "
@@ -51,122 +154,84 @@
 "interfacename>. The mappings are compiled from various XML mapping files."
 msgstr ""
 "Uma instância de <literal>org.hibernate.cfg.Configuration</literal> "
-"representa um conjunto inteiro de mapeamentos de tipos Java da aplicação "
-"para um banco de dados SQL. O <literal>Configuration</literal> é usado para "
-"construir uma <literal>SessionFactory</literal> (imutável). Os mapeamentos "
-"são compilados a partir de arquivos de mapeamento XML."
+"representa um conjunto inteiro de mapeamentos de tipos Java de aplicação "
+"para um banco de dados SQL. O <classname>org.hibernate.cfg.Configuration</"
+"classname> é usado para construir uma <literal>SessionFactory</literal> "
+"imutável. Os mapeamentos são compilados a partir de diversos arquivos de "
+"mapeamento XML. "
 
 #. Tag: para
-#: configuration.xml:49
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can obtain a <classname>org.hibernate.cfg.Configuration</classname> "
 "instance by instantiating it directly and specifying XML mapping documents. "
 "If the mapping files are in the classpath, use <literal>addResource()</"
 "literal>. For example:"
 msgstr ""
-"Você pode obter uma instância <literal>Configuration</literal> intanciando- "
-"o diretamente e especificando documentos de mapeamento XML. Se o arquivo de "
-"mapeamento estão no classpath, use use <literal>addResource()</literal>:"
+"Você pode obter uma instância <classname>org.hibernate.cfg.Configuration</"
+"classname> intanciando-a diretamente e especificando os documentos de "
+"mapeamento XML. Se os arquivos de mapeamento estiverem no classpath, use "
+"<literal>addResource()</literal>. Por exemplo:"
 
-#. Tag: programlisting
-#: configuration.xml:55
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addResource(\"Item.hbm.xml\")\n"
-"    .addResource(\"Bid.hbm.xml\");]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:57
-#, fuzzy, no-c-format
-msgid ""
 "An alternative way is to specify the mapped class and allow Hibernate to "
 "find the mapping document for you:"
 msgstr ""
-"Uma alternativa (às vezes melhor) é especificar a classe mapeada, e permitir "
-"que o Hibernate encontre o documento de mapeamento para você:"
+"Uma alternativa é especificar a classe mapeada e permitir que o Hibernate "
+"encontre o documento de mapeamento para você:"
 
-#. Tag: programlisting
-#: configuration.xml:62
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addClass(org.hibernate.auction.Item.class)\n"
-"    .addClass(org.hibernate.auction.Bid.class);]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:64
-#, fuzzy, no-c-format
-msgid ""
 "Hibernate will then search for mapping files named <filename>/org/hibernate/"
 "auction/Item.hbm.xml</filename> and <filename>/org/hibernate/auction/Bid.hbm."
 "xml</filename> in the classpath. This approach eliminates any hardcoded "
 "filenames."
 msgstr ""
-"Então o Hibernate procurará pelos arquivos de mapeamento chamados <literal>/"
-"org/hibernate/auction/Item.hbm.xml</literal> e <literal>/org/hibernate/"
-"auction/Bid.hbm.xml</literal> no classpath. Esta abordagem elimina qualquer "
-"nome de arquivo de difícil compreensão."
+"O Hibernate procurará pelos arquivos de mapeamento chamados <literal>/org/"
+"hibernate/auction/Item.hbm.xml</literal> e <literal>/org/hibernate/auction/"
+"Bid.hbm.xml</literal> no classpath. Esta abordagem elimina qualquer nome de "
+"arquivo de difícil compreensão."
 
 #. Tag: para
-#: configuration.xml:70
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <classname>org.hibernate.cfg.Configuration</classname> also allows you to "
 "specify configuration properties. For example:"
 msgstr ""
-"Uma <literal>Configuration</literal> também permite você especificar "
-"propriedades de configuração:"
+"Uma <literal>Configuration</literal> também permite que você especifique "
+"propriedades de configuração específica. Por exemplo:"
 
-#. Tag: programlisting
-#: configuration.xml:75
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addClass(org.hibernate.auction.Item.class)\n"
-"    .addClass(org.hibernate.auction.Bid.class)\n"
-"    .setProperty(\"hibernate.dialect\", \"org.hibernate.dialect."
-"MySQLInnoDBDialect\")\n"
-"    .setProperty(\"hibernate.connection.datasource\", \"java:comp/env/jdbc/"
-"test\")\n"
-"    .setProperty(\"hibernate.order_updates\", \"true\");]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:77
-#, fuzzy, no-c-format
-msgid ""
 "This is not the only way to pass configuration properties to Hibernate. Some "
 "alternative options include:"
 msgstr ""
-"Este não é o único caminho para passar as propriedades de configuração para "
-"o Hibernate. As várias opções incluem:"
+"Esta não é a única forma de passar as propriedades de configuração para o "
+"Hibernate. As várias opções incluem: "
 
 #. Tag: para
-#: configuration.xml:84
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Pass an instance of <classname>java.util.Properties</classname> to "
 "<literal>Configuration.setProperties()</literal>."
 msgstr ""
 "Passar uma instância de <literal>java.util.Properties</literal> para "
-"<literal>Configuration.setProperties()</literal>."
+"<literal>Configuration.setProperties()</literal>. "
 
 #. Tag: para
-#: configuration.xml:90
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Place a file named <filename>hibernate.properties</filename> in a root "
 "directory of the classpath."
 msgstr ""
-"Colocar <literal>hibernate.properties</literal> no diretório raiz do "
-"classpath."
+"Colocar <literal>hibernate.properties</literal> de arquivo nomeado no "
+"diretório raíz do classpath."
 
 #. Tag: para
-#: configuration.xml:95
 #, no-c-format
 msgid ""
 "Set <literal>System</literal> properties using <literal>java -"
@@ -176,44 +241,40 @@
 "-Dproperty=value</literal>."
 
 #. Tag: para
-#: configuration.xml:100
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Include <literal>&lt;property&gt;</literal> elements in <literal>hibernate."
 "cfg.xml</literal> (this is discussed later)."
 msgstr ""
-"Include <literal>&lt;property&gt;</literal> elements in <literal>hibernate."
-"cfg.xml</literal> (discussed later). Incluir elementos <literal>&lt;"
-"property&gt;</literal> no <literal>hibernate.cfg.xml</literal> (discutido "
-"mais tarde)."
+"Incluir elementos <literal>&lt;property&gt;</literal> no <literal>hibernate."
+"cfg.xml</literal> (discutido mais tarde). "
 
 #. Tag: para
-#: configuration.xml:107
 #, no-c-format
 msgid ""
 "If you want to get started quickly<filename>hibernate.properties</filename> "
 "is the easiest approach."
 msgstr ""
+"Caso você deseje inicializar rapidamente o <filename>hibernate.properties</"
+"filename> é a abordagem mais rápida."
 
 #. Tag: para
-#: configuration.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <classname>org.hibernate.cfg.Configuration</classname> is intended as a "
 "startup-time object that will be discarded once a <literal>SessionFactory</"
 "literal> is created."
 msgstr ""
-"O <literal>Configuration</literal> é entendido como um objeto startup-time, "
-"é descartado uma vez que a <literal>SessionFactory</literal> é criada."
+"O <classname>org.hibernate.cfg.Configuration</classname> é previsto como um "
+"objeto de tempo de inicialização, a ser descartado quando um "
+"<literal>SessionFactory</literal> for criado."
 
 #. Tag: title
-#: configuration.xml:119
 #, no-c-format
 msgid "Obtaining a SessionFactory"
 msgstr "Obtendo uma SessionFactory"
 
 #. Tag: para
-#: configuration.xml:121
 #, fuzzy, no-c-format
 msgid ""
 "When all mappings have been parsed by the <classname>org.hibernate.cfg."
@@ -221,68 +282,51 @@
 "<interfacename>org.hibernate.Session</interfacename> instances. This factory "
 "is intended to be shared by all application threads:"
 msgstr ""
-"Quando todos os mapeamentos têm sido analisados pelo <literal>Configuration</"
-"literal>, a aplicação deve obter uma factory para as instâncias da "
-"<literal>Session</literal>. O objetivo desta factory é ser compartilhado por "
-"todas as threads da aplicação:"
+"Quando todos os mapeamentos forem analisados pelo <classname>org.hibernate."
+"cfg.Configuration</classname>, a aplicação deve obter uma factory para as "
+"instâncias do <interfacename>org.hibernate.Session</interfacename>. O "
+"objetivo desta factory é ser compartilhado por todas as threads da aplicação:"
 
-#. Tag: programlisting
-#: configuration.xml:127
-#, no-c-format
-msgid "<![CDATA[SessionFactory sessions = cfg.buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:129
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate does allow your application to instantiate more than one "
 "<interfacename>org.hibernate.SessionFactory</interfacename>. This is useful "
 "if you are using more than one database."
 msgstr ""
-"Hibernate permite sua aplicação instanciar mais do que uma "
-"<literal>SessionFactory</literal>. Isto é útil se você está usando mais do "
-"que um banco de dados."
+"O Hibernate permite sua aplicação instanciar mais do que um "
+"<interfacename>org.hibernate.SessionFactory</interfacename>. Isto será útil "
+"se você estiver usando mais do que um banco de dados. "
 
 #. Tag: title
-#: configuration.xml:138
 #, no-c-format
 msgid "JDBC connections"
 msgstr "Conexões JDBC"
 
 #. Tag: para
-#: configuration.xml:140
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is advisable to have the <interfacename>org.hibernate.SessionFactory</"
 "interfacename> create and pool JDBC connections for you. If you take this "
 "approach, opening a <interfacename>org.hibernate.Session</interfacename> is "
 "as simple as:"
 msgstr ""
-"Normalmente, você quer mandar criar a <literal>SessionFactory</literal> "
-"criar um pool de conexões JDBC para você. Se você seguir essa abordagem, a "
-"abertura de uma <literal>Session</literal> é tão simples quanto:"
+"Normalmente, você deseja que o <interfacename>org.hibernate.SessionFactory</"
+"interfacename> crie e faça um um pool de conexões JDBC para você. Se você "
+"seguir essa abordagem, a abertura de um <interfacename>org.hibernate."
+"Session</interfacename> será tão simples quanto:"
 
-#. Tag: programlisting
-#: configuration.xml:146
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessions.openSession(); // open a new Session]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:148
-#, fuzzy, no-c-format
-msgid ""
 "Once you start a task that requires access to the database, a JDBC "
 "connection will be obtained from the pool."
 msgstr ""
-"Assim que você fizer algo que requer o acesso ao banco de dados, uma conexão "
-"JDBC será obtida do pool."
+"Assim que você fizer algo que requeira o acesso ao banco de dados, uma "
+"conexão JDBC será obtida a partir do pool."
 
 #. Tag: para
-#: configuration.xml:153
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Before you can do this, you first need to pass some JDBC connection "
 "properties to Hibernate. All Hibernate property names and semantics are "
@@ -290,106 +334,87 @@
 "The most important settings for JDBC connection configuration are outlined "
 "below."
 msgstr ""
-"Para esse trabalho, nós necessitamos passar algumas propriedades da conexão "
-"JDBC para o Hibernate. Todos os nomes de propriedades Hibernate e semânticas "
-"são definidas <literal>org.hibernate.cfg.Environment</literal>. Nós iremos "
-"descrever agora o mais importantes configurações de conexão JDBC."
+"Para esse trabalho, precisaremos passar algumas propriedades da conexão JDBC "
+"para o Hibernate. Todos os nomes de propriedades Hibernate e semânticas são "
+"definidas na classe <literal>org.hibernate.cfg.Environment</literal>. "
+"Descreveremos agora as configurações mais importantes para a conexão JDBC. "
 
 #. Tag: para
-#: configuration.xml:159
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will obtain and pool connections using <classname>java.sql."
 "DriverManager</classname> if you set the following properties:"
 msgstr ""
-"O Hibernate obterá conexões( e pool) usando <literal>java.sql.DriverManager</"
-"literal> se você determinar as seguintes propriedades:"
+"O Hibernate obterá conexões (e efetuará o pool) usando <literal>java.sql."
+"DriverManager</literal> se você determinar as seguintes propriedades: "
 
 #. Tag: title
-#: configuration.xml:165
 #, no-c-format
 msgid "Hibernate JDBC Properties"
 msgstr "Propriedades JDBC Hibernate"
 
 #. Tag: entry
-#: configuration.xml:171 configuration.xml:257 configuration.xml:353
-#: configuration.xml:548 configuration.xml:743 configuration.xml:850
-#: configuration.xml:938
 #, no-c-format
 msgid "Property name"
 msgstr "Nome da Propriedade"
 
 #. Tag: entry
-#: configuration.xml:172 configuration.xml:258 configuration.xml:354
-#: configuration.xml:549 configuration.xml:744 configuration.xml:851
-#: configuration.xml:939
 #, no-c-format
 msgid "Purpose"
 msgstr "Propósito"
 
-#. Tag: property
-#: configuration.xml:178
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.driver_class"
-msgstr "hibernate.connection.driver_class"
+msgid "<property>hibernate.connection.driver_class</property>"
+msgstr "<property>hibernate.connection.driver_class</property>"
 
-#. Tag: emphasis
-#: configuration.xml:181
+#. Tag: entry
 #, no-c-format
-msgid "JDBC driver class"
-msgstr "Classe driver jdbc"
+msgid "<emphasis>JDBC driver class</emphasis>"
+msgstr "<emphasis>JDBC driver class</emphasis>"
 
-#. Tag: property
-#: configuration.xml:186
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.url"
-msgstr "hibernate.connection.url"
+msgid "<property>hibernate.connection.url</property>"
+msgstr "<property>hibernate.connection.url</property>"
 
-#. Tag: emphasis
-#: configuration.xml:189
+#. Tag: entry
 #, no-c-format
-msgid "JDBC URL"
-msgstr "URL jdbc"
+msgid "<emphasis>JDBC URL</emphasis>"
+msgstr "<emphasis>JDBC URL</emphasis>"
 
-#. Tag: property
-#: configuration.xml:194 configuration.xml:288
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.username"
-msgstr "hibernate.connection.username"
+msgid "<property>hibernate.connection.username</property>"
+msgstr "<property>hibernate.connection.username</property>"
 
-#. Tag: emphasis
-#: configuration.xml:197
+#. Tag: entry
 #, no-c-format
-msgid "database user"
-msgstr "Usuário do banco de dados"
+msgid "<emphasis>database user</emphasis>"
+msgstr "<emphasis>usuário de banco de dados</emphasis> "
 
-#. Tag: property
-#: configuration.xml:202 configuration.xml:296
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.password"
-msgstr "hibernate.connection.password"
+msgid "<property>hibernate.connection.password</property>"
+msgstr "<property>hibernate.connection.password</property>"
 
-#. Tag: emphasis
-#: configuration.xml:205
+#. Tag: entry
 #, no-c-format
-msgid "database user password"
-msgstr "Senha do usuário do banco de dados"
+msgid "<emphasis>database user password</emphasis>"
+msgstr "<emphasis>senha de usuário de banco de dados</emphasis> "
 
-#. Tag: property
-#: configuration.xml:210
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.pool_size"
-msgstr "hibernate.connection.pool_size"
+msgid "<property>hibernate.connection.pool_size</property>"
+msgstr "<property>hibernate.connection.pool_size</property>"
 
-#. Tag: emphasis
-#: configuration.xml:213
+#. Tag: entry
 #, no-c-format
-msgid "maximum number of pooled connections"
-msgstr "Número máximo de connecxões no pool"
+msgid "<emphasis>maximum number of pooled connections</emphasis>"
+msgstr "<emphasis>número máximo de conexões em pool</emphasis>"
 
 #. Tag: para
-#: configuration.xml:220
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's own connection pooling algorithm is, however, quite rudimentary. "
 "It is intended to help you get started and is <emphasis>not intended for use "
@@ -399,18 +424,17 @@
 "with connection pool specific settings. This will turn off Hibernate's "
 "internal pool. For example, you might like to use c3p0."
 msgstr ""
-"O algoritmo de pool de conexões do próprio Hibernate entretanto é "
-"completamente rudimentar. A intenção dele e ajudar a iniciar e <emphasis>não "
-"para usar em um sistema de produção</emphasis> ou até para testar "
-"desempenho. Você deveria usar uma ferramente de pool de terceiros para "
-"conseguir melhor desempenho e estabilidade. Apenas especifique a propriedade "
-"<literal>hibernate.connection.pool_size</literal> com a definição do pool de "
-"conexões. Isto irá desligar o pool interno do Hibernate. Por exemplo, você "
-"pode gostar de usar C3P0."
+"No entanto, o algoritmo de pool de conexões do próprio Hibernate é um tanto "
+"rudimentar. A intenção dele é ajudar a iniciar e <emphasis>não para ser "
+"usado em um sistema de produção</emphasis> ou até para testar o desempenho. "
+"Você deve utilizar um pool de terceiros para conseguir um melhor desempenho "
+"e estabilidade. Apenas substitua a propriedade <literal>hibernate.connection."
+"pool_size</literal> pela configuração específica do pool de conexões. Isto "
+"irá desligar o pool interno do Hibernate. Por exemplo, você pode gostar de "
+"usar C3P0. "
 
 #. Tag: para
-#: configuration.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "C3P0 is an open source JDBC connection pool distributed along with Hibernate "
 "in the <filename>lib</filename> directory. Hibernate will use its "
@@ -421,157 +445,117 @@
 "more information."
 msgstr ""
 "O C3P0 é um pool conexão JDBC de código aberto distribuído junto com "
-"Hibernate no diretório <literal>lib</literal>. O Hibernate usará o "
-"<literal>C3P0ConnectionProvider</literal> para o pool de conexão se você "
-"configurar a propriedade <literal>hibernate.c3p0.*</literal>. Se você gostar "
-"de usar Proxool consulte ao pacote <literal>hibernate.properties</literal> e "
-"o web site do Hibernate para mais informações."
+"Hibernate no diretório <literal>lib</literal>. O Hibernate usará o próprio "
+"<classname>org.hibernate.connection.C3P0ConnectionProvider</classname> para "
+"o pool de conexão se você configurar a propriedade <literal>hibernate.c3p0."
+"*</literal>. Se você gostar de usar Proxool, consulte o pacote "
+"<literal>hibernate.properties</literal> e o web site do Hibernate para mais "
+"informações."
 
 #. Tag: para
-#: configuration.xml:238
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is an example <filename>hibernate.properties</filename> file "
 "for c3p0:"
 msgstr ""
-"Aqui é um exemplo de arquivo <literal>hibernate.properties</literal> para "
-"C3P0:"
+"Este é um exemplo de arquivo <literal>hibernate.properties</literal> para "
+"c3p0:"
 
-#. Tag: programlisting
-#: configuration.xml:242
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[hibernate.connection.driver_class = org.postgresql.Driver\n"
-"hibernate.connection.url = jdbc:postgresql://localhost/mydatabase\n"
-"hibernate.connection.username = myuser\n"
-"hibernate.connection.password = secret\n"
-"hibernate.c3p0.min_size=5\n"
-"hibernate.c3p0.max_size=20\n"
-"hibernate.c3p0.timeout=1800\n"
-"hibernate.c3p0.max_statements=50\n"
-"hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:244
-#, fuzzy, no-c-format
-msgid ""
 "For use inside an application server, you should almost always configure "
 "Hibernate to obtain connections from an application server "
 "<interfacename>javax.sql.Datasource</interfacename> registered in JNDI. You "
 "will need to set at least one of the following properties:"
 msgstr ""
 "Para usar dentro de um servidor de aplicação, você deve configurar o "
-"Hibernate para obter conexões de um application server <literal>Datasource</"
-"literal> registrado no JNDI. Você necessitará determinar pelo menos uma das "
-"seguintes propriedades:"
+"Hibernate para obter conexões de um servidor de aplicação "
+"<interfacename>javax.sql.Datasource</interfacename> registrado no JNDI. Você "
+"precisará determinar pelo menos uma das seguintes propriedades:"
 
 #. Tag: title
-#: configuration.xml:251
 #, no-c-format
 msgid "Hibernate Datasource Properties"
 msgstr "Propriedades do Datasource do Hibernate"
 
-#. Tag: property
-#: configuration.xml:264
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.datasource"
-msgstr "hibernate.connection.datasource"
+msgid "<property>hibernate.connection.datasource</property>"
+msgstr "<property>hibernate.connection.datasource</property>"
 
-#. Tag: emphasis
-#: configuration.xml:267
+#. Tag: entry
 #, no-c-format
-msgid "datasource JNDI name"
-msgstr "Nome datasource JNDI"
+msgid "<emphasis>datasource JNDI name</emphasis>"
+msgstr "<emphasis>nome JNDI de fonte de dados</emphasis>"
 
-#. Tag: property
-#: configuration.xml:272
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jndi.url"
-msgstr "hibernate.jndi.url"
+msgid "<property>hibernate.jndi.url</property>"
+msgstr "<property>hibernate.jndi.url</property>"
 
 #. Tag: entry
-#: configuration.xml:274
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis>URL of the JNDI provider</emphasis> (optional)"
-msgstr "URL do fornecedor JNDI"
+msgstr "<emphasis>URL do fornecedor JNDI</emphasis> (opcional)"
 
-#. Tag: property
-#: configuration.xml:280
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jndi.class"
-msgstr "hibernate.jndi.class"
+msgid "<property>hibernate.jndi.class</property>"
+msgstr "<property>hibernate.jndi.class</property>"
 
 #. Tag: entry
-#: configuration.xml:282
 #, no-c-format
 msgid ""
 "<emphasis>class of the JNDI <literal>InitialContextFactory</literal></"
 "emphasis> (optional)"
 msgstr ""
+"<emphasis>classe de JNDI <literal>InitialContextFactory</literal></emphasis> "
+"(opcional)"
 
 #. Tag: entry
-#: configuration.xml:290
 #, no-c-format
 msgid "<emphasis>database user</emphasis> (optional)"
-msgstr ""
+msgstr "<emphasis>usuário de banco de dados</emphasis> (opcional)"
 
 #. Tag: entry
-#: configuration.xml:298
 #, no-c-format
 msgid "<emphasis>database user password</emphasis> (optional)"
-msgstr ""
+msgstr "<emphasis>senha de usuário de banco de dados</emphasis> (opcional)"
 
 #. Tag: para
-#: configuration.xml:306
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Here is an example <filename>hibernate.properties</filename> file for an "
 "application server provided JNDI datasource:"
 msgstr ""
 "Eis um exemplo de arquivo <literal>hibernate.properties</literal> para um "
-"servidor de aplicação fornecedor de datasources JNDI:"
+"servidor de aplicação fornecedor de fontes de dados JNDI:"
 
-#. Tag: programlisting
-#: configuration.xml:311
-#, no-c-format
-msgid ""
-"<![CDATA[hibernate.connection.datasource = java:/comp/env/jdbc/test\n"
-"hibernate.transaction.factory_class = \\\n"
-"    org.hibernate.transaction.JTATransactionFactory\n"
-"hibernate.transaction.manager_lookup_class = \\\n"
-"    org.hibernate.transaction.JBossTransactionManagerLookup\n"
-"hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:313
 #, no-c-format
 msgid ""
 "JDBC connections obtained from a JNDI datasource will automatically "
 "participate in the container-managed transactions of the application server."
 msgstr ""
-"Conexões JDBC obtidas de um datasource JNDI irão automaticamente irão "
-"participar das transações gerenciadas pelo container no servidor de "
-"aplicação."
+"Conexões JDBC obtidas de um datasource JNDI irão automaticamente participar "
+"das transações gerenciadas pelo recipiente no servidor de aplicação."
 
 #. Tag: para
-#: configuration.xml:318
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Arbitrary connection properties can be given by prepending "
 "\"<literal>hibernate.connection</literal>\" to the connection property name. "
 "For example, you can specify a <property>charSet</property> connection "
 "property using <property>hibernate.connection.charSet</property>."
 msgstr ""
-"Arbitrariamente as propriedades de conexão podem ser acrescentandas ao "
+"As propriedades de conexão arbitrárias podem ser acrescentandas ao "
 "\"<literal>hibernate.connnection</literal>\" ao nome da propriedade. Por "
-"exemplo, você deve especificar o <literal>charSet</literal> usando "
-"<literal>hibernate.connection.charSet</literal>.t."
+"exemplo, você deve especificar a propriedade de conexão <literal>charSet</"
+"literal> usando <property>hibernate.connection.charSet</property>."
 
 #. Tag: para
-#: configuration.xml:324
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can define your own plugin strategy for obtaining JDBC connections by "
 "implementing the interface <interfacename>org.hibernate.connection."
@@ -581,28 +565,26 @@
 msgstr ""
 "Você pode definir sua própria estratégia de plugin para obter conexões JDBC "
 "implementando a interface <literal>org.hibernate.connection."
-"ConnectionProvider</literal>. Você pode escolher uma implementação "
-"customizada setando <literal>hibernate.connection.provider_class</literal>."
+"ConnectionProvider</literal> e especificando sua implementação customizada "
+"através da propriedade <literal>hibernate.connection.provider_class</"
+"literal>."
 
 #. Tag: title
-#: configuration.xml:333
 #, no-c-format
 msgid "Optional configuration properties"
 msgstr "Propriedades opcionais de configuração"
 
 #. Tag: para
-#: configuration.xml:335
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are a number of other properties that control the behavior of "
 "Hibernate at runtime. All are optional and have reasonable default values."
 msgstr ""
 "Há um grande número de outras propriedades que controlam o comportamento do "
-"Hibernate em tempo de execução. Todos são opcionais e tem valores default "
-"lógicos."
+"Hibernate em tempo de execução. Todos são opcionais e têm valores padrão "
+"lógicos. "
 
-#. Tag: warning
-#: configuration.xml:341
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Some of these properties are \"system-level\" only.</emphasis> "
@@ -610,428 +592,212 @@
 "literal> or <filename>hibernate.properties</filename>. They "
 "<emphasis>cannot</emphasis> be set by the other techniques described above."
 msgstr ""
-"<emphasis>Aviso: algumas destas propriedades são somente a \"nível de sistema"
-"\".</emphasis> Propriedades nível de sistema podem ser determinados somente "
-"via <literal>java -Dproperty=value</literal> ou <literal>hibernate."
-"properties</literal>. Elas <emphasis>não</emphasis>podem ser configuradas "
-"por outras técnicas descritas abaixo."
+"Algumas destas propriedades são somente em nível de sistema. As propriedades "
+"em nível de sistema podem ser determinadas somente via <literal>java -"
+"Dproperty=value</literal> ou <literal>hibernate.properties</literal>. Elas "
+"<emphasis>não podem</emphasis> ser configuradas por outras técnicas "
+"descritas abaixo."
 
 #. Tag: title
-#: configuration.xml:347
 #, no-c-format
 msgid "Hibernate Configuration Properties"
-msgstr "Hibernate Configuration Properties"
+msgstr "Propriedades de Configuração do Hibernate"
 
-#. Tag: property
-#: configuration.xml:360
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.dialect"
-msgstr "hibernate.dialect"
+msgid "<property>hibernate.dialect</property>"
+msgstr "<property>hibernate.dialect</property>"
 
 #. Tag: entry
-#: configuration.xml:362
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a Hibernate <classname>org.hibernate.dialect.Dialect</"
 "classname> which allows Hibernate to generate SQL optimized for a particular "
 "relational database."
 msgstr ""
-"O nome da classe de um <placeholder-1/> que permite o Hibernate gerar SQL "
-"otimizado para um banco de dados relacional em particular. <placeholder-2/>"
+"O nome da classe de um Hibernate <classname>org.hibernate.dialect.Dialect</"
+"classname> que permite o Hibernate gerar SQL otimizado para um banco de "
+"dados relacional em particular.  "
 
 #. Tag: para
-#: configuration.xml:365
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>full.classname.of."
 "Dialect</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>full.classname.of."
+"Dialect</literal>"
 
 #. Tag: para
-#: configuration.xml:369
 #, no-c-format
 msgid ""
 "In most cases Hibernate will actually be able to choose the correct "
 "<classname>org.hibernate.dialect.Dialect</classname> implementation based on "
 "the <literal>JDBC metadata</literal> returned by the JDBC driver."
 msgstr ""
+"Na maioria dos casos, o Hibernate irá atualmente estar apto a escolher a "
+"implementação <classname>org.hibernate.dialect.Dialect</classname> correta "
+"baseada no <literal>JDBC metadata</literal> retornado pelo JDBC driver."
 
-#. Tag: property
-#: configuration.xml:378
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.show_sql"
-msgstr "hibernate.show_sql"
+msgid "<property>hibernate.show_sql</property>"
+msgstr "<property>hibernate.show_sql</property>"
 
 #. Tag: entry
-#: configuration.xml:380
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Write all SQL statements to console. This is an alternative to setting the "
 "log category <literal>org.hibernate.SQL</literal> to <literal>debug</"
 "literal>."
 msgstr ""
-"Escreve todas as instruções SQL no console. Esta é uma alternativa a "
-"configurar a categoria de log <placeholder-1/> para <placeholder-2/>. "
-"<placeholder-3/>"
+"Escreve todas as instruções SQL no console. Esta é uma alternativa para "
+"configurar a categoria de log <literal>org.hibernate.SQL</literal> to "
+"<literal>debug</literal>."
 
 #. Tag: para
-#: configuration.xml:384 configuration.xml:396 configuration.xml:490
-#: configuration.xml:503 configuration.xml:516 configuration.xml:529
-#: configuration.xml:583 configuration.xml:610 configuration.xml:623
-#: configuration.xml:678 configuration.xml:906 configuration.xml:921
-#: configuration.xml:1011
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>true</literal> | "
 "<literal>false</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>true</literal> | "
 "<literal>false</literal>"
 
-#. Tag: property
-#: configuration.xml:392
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.format_sql"
-msgstr "hibernate.format_sql"
+msgid "<property>hibernate.format_sql</property>"
+msgstr "<property>hibernate.format_sql</property>"
 
 #. Tag: entry
-#: configuration.xml:394
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Pretty print the SQL in the log and console."
-msgstr "Imprime o SQL formatado no log e console. <placeholder-1/>"
+msgstr "Imprime o SQL formatado no log e recipiente. "
 
-#. Tag: property
-#: configuration.xml:404
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_schema"
-msgstr "hibernate.default_schema"
+msgid "<property>hibernate.default_schema</property>"
+msgstr "<property>hibernate.default_schema</property>"
 
 #. Tag: entry
-#: configuration.xml:406
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Qualify unqualified table names with the given schema/tablespace in "
 "generated SQL."
 msgstr ""
-"Qualifica no sql gerado, os nome das tabelas sem qualificar com schena/"
-"tablespace dado <placeholder-1/>"
+"Qualifica no SQL gerado, os nome das tabelas desqualificadas com o esquema/"
+"espaço da tabela dado."
 
 #. Tag: para
-#: configuration.xml:409
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>SCHEMA_NAME</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>SCHEMA_NAME</literal>"
 
-#. Tag: property
-#: configuration.xml:417
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_catalog"
-msgstr "hibernate.default_catalog"
+msgid "<property>hibernate.default_catalog</property>"
+msgstr "<property>hibernate.default_catalog</property>"
 
 #. Tag: entry
-#: configuration.xml:419
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Qualifies unqualified table names with the given catalog in generated SQL."
 msgstr ""
-"Qualifica no sql gerado, os nome das tabelas sem qualificar com catálogo "
-"dado <placeholder-1/>"
+"Qualifica no SQL gerado, os nome das tabelas desqualificadas com catálogo "
+"dado."
 
 #. Tag: para
-#: configuration.xml:422
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>CATALOG_NAME</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>CATALOG_NAME</literal>"
 
-#. Tag: property
-#: configuration.xml:430
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.session_factory_name"
-msgstr "hibernate.session_factory_name"
+msgid "<property>hibernate.session_factory_name</property>"
+msgstr "<property>hibernate.session_factory_name</property>"
 
 #. Tag: entry
-#: configuration.xml:432
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <interfacename>org.hibernate.SessionFactory</interfacename> will be "
 "automatically bound to this name in JNDI after it has been created."
 msgstr ""
-"O <placeholder-1/> irá automaticamente se ligar a este nome no JNDI depois "
-"de ter sido criado. <placeholder-2/>"
+"O <interfacename>org.hibernate.SessionFactory</interfacename> irá "
+"automaticamente se ligar a este nome no JNDI depois de ter sido criado. "
 
 #. Tag: para
-#: configuration.xml:435 configuration.xml:877
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>jndi/composite/name</"
 "literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">e.g.</emphasis> <literal>jndi/composite/name</"
+"literal>"
 
-#. Tag: property
-#: configuration.xml:443
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.max_fetch_depth"
-msgstr "hibernate.max_fetch_depth"
+msgid "<property>hibernate.max_fetch_depth</property>"
+msgstr "<property>hibernate.max_fetch_depth</property>"
 
 #. Tag: entry
-#: configuration.xml:445
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sets a maximum \"depth\" for the outer join fetch tree for single-ended "
 "associations (one-to-one, many-to-one). A <literal>0</literal> disables "
 "default outer join fetching."
 msgstr ""
-"Estabelece a \"profundidade\" máxima para árvore outer join fetch para "
-"associações finais únicas(one-to-one,many-to-one). Um <placeholder-1/> "
-"desativa por default a busca outer join. <placeholder-2/>"
+"Estabelece a \"profundidade\" máxima para árvore de busca de união externa "
+"para associações finais únicas (um para um, muitos para um). Um <literal>0</"
+"literal> desativa por padrão a busca de união externa.  "
 
 #. Tag: para
-#: configuration.xml:449
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values between "
 "<literal>0</literal> and <literal>3</literal>"
 msgstr ""
-"<emphasis role=\"strong\">eg.</emphasis> Valores recomendados "
+"<emphasis role=\"strong\">eg.</emphasis> valores recomendados "
 "entre<literal>0</literal> e <literal>3</literal>"
 
-#. Tag: property
-#: configuration.xml:458
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_batch_fetch_size"
-msgstr "hibernate.default_batch_fetch_size"
+msgid "<property>hibernate.default_batch_fetch_size</property>"
+msgstr "<property>hibernate.default_batch_fetch_size</property>"
 
 #. Tag: entry
-#: configuration.xml:460
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Sets a default size for Hibernate batch fetching of associations."
 msgstr ""
-"Determina um tamanho default para busca de associações em lotes do Hibernate "
-"<placeholder-1/>"
+"Determina um tamanho padrão para busca de associações em lotes do Hibernate."
 
 #. Tag: para
-#: configuration.xml:462
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values <literal>4</"
 "literal>, <literal>8</literal>, <literal>16</literal>"
 msgstr ""
-"<emphasis role=\"strong\">eg.</emphasis> Valores recomendados <literal>4</"
+"<emphasis role=\"strong\">eg.</emphasis> valores recomendados <literal>4</"
 "literal>, <literal>8</literal>, <literal>16</literal>"
 
-#. Tag: property
-#: configuration.xml:471
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_entity_mode"
-msgstr "hibernate.default_entity_mode"
+msgid "<property>hibernate.default_entity_mode</property>"
+msgstr "<property>hibernate.default_entity_mode</property>"
 
 #. Tag: entry
-#: configuration.xml:473
 #, fuzzy, no-c-format
 msgid ""
 "Sets a default mode for entity representation for all sessions opened from "
 "this <literal>SessionFactory</literal>"
 msgstr ""
-"Determina um modo default para representação de entidades para todas as "
-"sessões abertas desta <placeholder-1/><placeholder-2/>"
+"Determina um modo padrão para representação de entidades para todas as "
+"sessões abertas desta <literal>SessionFactory</literal> "
 
 #. Tag: para
-#: configuration.xml:476
 #, no-c-format
 msgid ""
 "<literal>dynamic-map</literal>, <literal>dom4j</literal>, <literal>pojo</"
@@ -1040,247 +806,183 @@
 "<literal>dynamic-map</literal>, <literal>dom4j</literal>, <literal>pojo</"
 "literal>"
 
-#. Tag: property
-#: configuration.xml:484
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.order_updates"
-msgstr "hibernate.order_updates"
+msgid "<property>hibernate.order_updates</property>"
+msgstr "<property>hibernate.order_updates</property>"
 
 #. Tag: entry
-#: configuration.xml:486
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Forces Hibernate to order SQL updates by the primary key value of the items "
 "being updated. This will result in fewer transaction deadlocks in highly "
 "concurrent systems."
 msgstr ""
 "Força o Hibernate a ordenar os updates SQL pelo valor da chave primária dos "
-"itens a serem atualizados. Isto resultará em menos deadlocks nas transações "
-"em sistemas altamente concorrente. <placeholder-1/>"
+"ítens a serem atualizados. Isto resultará em menos deadlocks nas transações "
+"em sistemas altamente concorrente. "
 
-#. Tag: property
-#: configuration.xml:498
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.generate_statistics"
-msgstr "hibernate.generate_statistics"
+msgid "<property>hibernate.generate_statistics</property>"
+msgstr "<property>hibernate.generate_statistics</property>"
 
 #. Tag: entry
-#: configuration.xml:500
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If enabled, Hibernate will collect statistics useful for performance tuning."
 msgstr ""
-"If enabled, Hibernate will collect statistics useful for performance tuning. "
-"Se habilitado, o Hibernate coletará estatísticas úties para performance "
-"tuning dos bancos. <placeholder-1/>"
+"Se habilitado, o Hibernate coletará estatísticas úteis para o ajuste do "
+"desempenho. "
 
-#. Tag: property
-#: configuration.xml:511
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.use_identifier_rollback"
-msgstr "hibernate.use_identifer_rollback"
+msgid "<property>hibernate.use_identifier_rollback</property>"
+msgstr "<property>hibernate.use_identifier_rollback</property>"
 
 #. Tag: entry
-#: configuration.xml:513
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If enabled, generated identifier properties will be reset to default values "
 "when objects are deleted."
 msgstr ""
 "Se habilitado, propriedades identificadoras geradas serão zeradas para os "
-"valores default quando os objetos forem apagados. <placeholder-1/>"
+"valores padrão quando os objetos forem apagados. "
 
-#. Tag: property
-#: configuration.xml:524
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.use_sql_comments"
-msgstr "hibernate.use_sql_comments"
+msgid "<property>hibernate.use_sql_comments</property>"
+msgstr "<property>hibernate.use_sql_comments</property>"
 
 #. Tag: entry
-#: configuration.xml:526
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If turned on, Hibernate will generate comments inside the SQL, for easier "
 "debugging, defaults to <literal>false</literal>."
 msgstr ""
-"Se ligado, o Hibernate irá gerar comentários dentro do SQL, para facilitar o "
-"debugging, o valor default é <placeholder-1/>. <placeholder-2/>"
+"Se ligado, o Hibernate irá gerar comentários dentro do SQL, para facilitar a "
+"depuração, o valor padrão é <literal>false</literal>"
 
 #. Tag: title
-#: configuration.xml:540
 #, no-c-format
 msgid "Hibernate JDBC and Connection Properties"
 msgstr "JDBC Hibernate e Propriedades de Conexão"
 
-#. Tag: property
-#: configuration.xml:555
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.fetch_size"
-msgstr "hibernate.jdbc.fetch_size"
+msgid "<property>hibernate.jdbc.fetch_size</property>"
+msgstr "<property>hibernate.jdbc.fetch_size</property>"
 
 #. Tag: entry
-#: configuration.xml:557
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A non-zero value determines the JDBC fetch size (calls <literal>Statement."
 "setFetchSize()</literal>)."
 msgstr ""
-"Um valor maior que zero determina o tamanho do fetch do JDBC( chamadas "
-"<placeholder-1/>)."
+"Um valor maior que zero determina o tamanho da buscado JDBC (chamadas "
+"<literal>Statement.setFetchSize()</literal>)."
 
-#. Tag: property
-#: configuration.xml:564
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.batch_size"
-msgstr "hibernate.jdbc.batch_size"
+msgid "<property>hibernate.jdbc.batch_size</property>"
+msgstr "<property>hibernate.jdbc.batch_size</property>"
 
 #. Tag: entry
-#: configuration.xml:566
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A non-zero value enables use of JDBC2 batch updates by Hibernate."
 msgstr ""
-"Um valor maior que zero habilita uso de batch updates JDBC2 pelo Hibernate. "
-"<placeholder-1/>"
+"Um valor maior que zero habilita o uso das atualizações em lotes JDBC2 pelo "
+"Hibernate.  "
 
 #. Tag: para
-#: configuration.xml:568
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values between "
 "<literal>5</literal> and <literal>30</literal>"
 msgstr ""
-"<emphasis role=\"strong\">Ex.</emphasis> valores recomentados entre "
+"<emphasis role=\"strong\">ex.</emphasis> valores recomentados entre "
 "<literal>5</literal> e <literal>30</literal>"
 
-#. Tag: property
-#: configuration.xml:576
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.batch_versioned_data"
-msgstr "hibernate.jdbc.batch_versioned_data"
+msgid "<property>hibernate.jdbc.batch_versioned_data</property>"
+msgstr "<property>hibernate.jdbc.batch_versioned_data</property>"
 
 #. Tag: entry
-#: configuration.xml:578
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Set this property to <literal>true</literal> if your JDBC driver returns "
 "correct row counts from <literal>executeBatch()</literal>. Iit is usually "
 "safe to turn this option on. Hibernate will then use batched DML for "
 "automatically versioned data. Defaults to <literal>false</literal>."
 msgstr ""
-"Sete esta propriedade como <placeholder-1/> se seu driver JDBC retorna o "
-"número correto de linhas no <placeholder-2/> ( É usualmente seguro tornar "
-"esta opção ligada). O Hibernate então irá usar betched DML para "
-"automaticamente versionar dados. <placeholder-3/> por default. <placeholder-"
-"4/>"
+"Configure esta propriedade como <literal>true</literal> se seu driver JDBC "
+"retornar o número correto de linhas no <literal>executeBatch()</literal>. "
+"Geralmente é seguro ligar opção. O Hibernate então usará o DML em lotes para "
+"dados automaticamente vertidos. Padronizar para <literal>false</literal>."
 
-#. Tag: property
-#: configuration.xml:591
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.factory_class"
-msgstr "hibernate.jdbc.factory_class"
+msgid "<property>hibernate.jdbc.factory_class</property>"
+msgstr "<property>hibernate.jdbc.factory_class</property>"
 
 #. Tag: entry
-#: configuration.xml:593
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Select a custom <interfacename>org.hibernate.jdbc.Batcher</interfacename>. "
 "Most applications will not need this configuration property."
 msgstr ""
-"Escolher um <placeholder-1/> customizado. Muitas aplicações não irão "
-"necessitar desta propriedade de configuração <placeholder-2/>"
+"Escolher um <interfacename>org.hibernate.jdbc.Batcher</interfacename>. "
+"Muitas aplicações não irão precisar desta propriedade de configuração."
 
 #. Tag: para
-#: configuration.xml:596
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "BatcherFactory</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">exemplo</emphasis> <literal>classname.of."
+"BatcherFactory</literal>"
 
-#. Tag: property
-#: configuration.xml:604
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_scrollable_resultset"
-msgstr "hibernate.jdbc.use_scrollable_resultset"
+msgid "<property>hibernate.jdbc.use_scrollable_resultset</property>"
+msgstr "<property>hibernate.jdbc.use_scrollable_resultset</property>"
 
 #. Tag: entry
-#: configuration.xml:606
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Enables use of JDBC2 scrollable resultsets by Hibernate. This property is "
 "only necessary when using user-supplied JDBC connections. Hibernate uses "
 "connection metadata otherwise."
 msgstr ""
-"Habilita o uso de JDBC2 scrollable resultsets pelo Hibernate. Essa "
-"propriedade somente é necessaria quando se usa Conexeções JDBC providas pelo "
-"usuário, caso contrário o Hibernate os os metadados da conexão. <placeholder-"
-"1/>"
+"Habilita o uso dos resultados de ajustes roláveis do JDBC2 pelo Hibernate. "
+"Essa propriedade somente é necessária quando se usa Conexões JDBC providas "
+"pelo usuário. Do contrário, o Hibernate os os metadados da conexão. "
 
-#. Tag: property
-#: configuration.xml:618
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_streams_for_binary"
-msgstr "hibernate.jdbc.use_streams_for_binary"
+msgid "<property>hibernate.jdbc.use_streams_for_binary</property>"
+msgstr "<property>hibernate.jdbc.use_streams_for_binary</property>"
 
 #. Tag: entry
-#: configuration.xml:620
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use streams when writing/reading <literal>binary</literal> or "
 "<literal>serializable</literal> types to/from JDBC. <emphasis>*system-level "
 "property*</emphasis>"
 msgstr ""
-"Use streams para escrever/ler tipos <placeholder-1/> ou <placeholder-2/> "
-"para/a o JDBC( propriedade a nível de sistema). <placeholder-3/>"
+"Utilize fluxos para escrever/ler tipos <literal>binary</literal> ou tipos "
+"<literal>serializable</literal> para/do JDBC. <emphasis>*system-level "
+"property*</emphasis>"
 
-#. Tag: property
-#: configuration.xml:631
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_get_generated_keys"
-msgstr "hibernate.jdbc.use_get_generated_keys"
+msgid "<property>hibernate.jdbc.use_get_generated_keys</property>"
+msgstr "<property>hibernate.jdbc.use_get_generated_keys</property>"
 
 #. Tag: entry
-#: configuration.xml:633
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Enables use of JDBC3 <literal>PreparedStatement.getGeneratedKeys()</literal> "
 "to retrieve natively generated keys after insert. Requires JDBC3+ driver and "
@@ -1288,131 +990,50 @@
 "identifier generators. By default, it tries to determine the driver "
 "capabilities using connection metadata."
 msgstr ""
-"Possibilita o uso <placeholder-1/> do JDBC3 para recuperar chaves geradas "
-"nativamente depois da inserçãp. Requer driver JDBC3+ e JRE1.4+, determine "
-"para false se seu driver tem problemas com gerador de indentificadores "
-"Hibernate. Por default, tente determinar o driver capaz de usar metadados da "
-"conexão. <placeholder-2/>"
+"Possibilita o uso do <literal>PreparedStatement.getGeneratedKeys()</literal> "
+"JDBC3 para recuperar chaves geradas de forma nativa depois da inserção. "
+"Requer driver JDBC3+ e JRE1.4+, ajuste para falso se seu driver tiver "
+"problemas com gerador de indentificadores Hibernate. Por padrão, tente "
+"determinar o driver capaz de usar metadados da conexão.  "
 
 #. Tag: para
-#: configuration.xml:639 configuration.xml:769 configuration.xml:781
-#: configuration.xml:795 configuration.xml:833
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>true|false</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">exemplo</emphasis> <literal>true|false</literal>  "
 
-#. Tag: property
-#: configuration.xml:647
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.provider_class"
-msgstr "hibernate.connection.provider_class"
+msgid "<property>hibernate.connection.provider_class</property>"
+msgstr "<property>hibernate.connection.provider_class</property>"
 
 #. Tag: entry
-#: configuration.xml:649
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a custom <interfacename>org.hibernate.connection."
 "ConnectionProvider</interfacename> which provides JDBC connections to "
 "Hibernate."
 msgstr ""
-"O nome da classe de um <placeholder-1/> personalizado o qual proverá "
-"conexões JDBC para o Hibernate. <placeholder-2/>"
+"O nome da classe de um <interfacename>org.hibernate.connection."
+"ConnectionProvider</interfacename>, do qual proverá conexões JDBC para o "
+"Hibernate. "
 
 #. Tag: para
-#: configuration.xml:652
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "ConnectionProvider</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">exemplo</emphasis><literal>classname.of."
+"ConnectionProvider</literal>  "
 
-#. Tag: property
-#: configuration.xml:660
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.isolation"
-msgstr "hibernate.connection.isolation"
+msgid "<property>hibernate.connection.isolation</property>"
+msgstr "<property>hibernate.connection.isolation</property>"
 
 #. Tag: entry
-#: configuration.xml:662
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sets the JDBC transaction isolation level. Check <interfacename>java.sql."
 "Connection</interfacename> for meaningful values, but note that most "
@@ -1420,77 +1041,33 @@
 "non-standard isolations."
 msgstr ""
 "Determina o nível de isolamento de uma transação JDBC. Verifique "
-"<placeholder-1/> para valores siginificativos mas note que a maior parte dos "
-"bancos de dados não suportam todos os níveis de isolamento. <placeholder-2/>"
+"<literal>java.sql.Connection</literal> para valores significativos mas note "
+"que a maior parte dos bancos de dados não suportam todos os isolamentos que "
+"não são padrões. "
 
 #. Tag: para
-#: configuration.xml:666
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>1, 2, 4, 8</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">exemplo</emphasis> <literal>1, 2, 4, 8</literal>"
 
-#. Tag: property
-#: configuration.xml:674
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.autocommit"
-msgstr "hibernate.connection.autocommit"
+msgid "<property>hibernate.connection.autocommit</property>"
+msgstr "<property>hibernate.connection.autocommit</property>"
 
 #. Tag: entry
-#: configuration.xml:676
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Enables autocommit for JDBC pooled connections (it is not recommended)."
-msgstr ""
-"Habilita autocommit para conexões no pool JDBC( não recomendado). "
-"<placeholder-1/>"
+msgstr "Habilita o auto-commit para conexões no pool JDBC (não recomendado). "
 
-#. Tag: property
-#: configuration.xml:686
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.release_mode"
-msgstr "hibernate.connection.release_mode"
+msgid "<property>hibernate.connection.release_mode</property>"
+msgstr "<property>hibernate.connection.release_mode</property>"
 
 #. Tag: entry
-#: configuration.xml:688
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Specifies when Hibernate should release JDBC connections. By default, a JDBC "
 "connection is held until the session is explicitly closed or disconnected. "
@@ -1502,711 +1079,441 @@
 "the JTA and CMT transaction strategies and <literal>after_transaction</"
 "literal> for the JDBC transaction strategy."
 msgstr ""
-"Especifica quando o Hibernate deve liberar conexões JDBC. Por default, uma "
-"conexão JDBC é retida até a sessão está explicitamente fechada ou "
-"desconectada. Para um datasource JTA do servidor de aplicação, você deve "
-"usar <placeholder-1/> para forçar s liberação da conexões depois de todas as "
-"chamadas JDBC. Para uma conexão não-JTA, freqüentemente faz sentido liberar "
-"a conexão ao fim de cada transação, usando <placeholder-2/>. <placeholder-3/"
-"> escolheremos <placeholder-4/> para as estratégias de transaçãoes JTA e CMT "
-"e <placeholder-5/> para as estratégias de transação JDBC <placeholder-6/"
-"><placeholder-7/>"
+"Especifica quando o Hibernate deve liberar conexões JDBC. Por padrão, uma "
+"conexão JDBC é retida até a sessão estar explicitamente fechada ou "
+"desconectada. Para uma fonte de dados JTA do servidor de aplicação, você "
+"deve usar <literal>after_statement</literal> para forçar a liberação da "
+"conexões depois de todas as chamadas JDBC. Para uma conexão não-JTA, "
+"freqüentemente faz sentido liberar a conexão ao fim de cada transação, "
+"usando <literal>after_transaction</literal>. O <literal>auto</literal> "
+"escolherá <literal>after_statement</literal> para as estratégias de "
+"transaçãoes JTA e CMT e <literal>after_transaction</literal> para as "
+"estratégias de transação JDBC."
 
 #. Tag: para
-#: configuration.xml:699
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>auto</literal> (default) "
 "| <literal>on_close</literal> | <literal>after_transaction</literal> | "
 "<literal>after_statement</literal>"
 msgstr ""
-"<emphasis role=\"strong\">Ex.</emphasis><literal>auto</literal> (default) | "
-"<literal>on_close</literal> | <literal>after_transaction</literal> | "
-"<literal>after_statement</literal>"
+"<emphasis role=\"strong\">exemplo</emphasis> <literal>auto</literal> "
+"(padrão) | <literal>on_close</literal> | <literal>after_transaction</"
+"literal> | <literal>after_statement</literal> "
 
 #. Tag: para
-#: configuration.xml:704
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This setting only affects <literal>Session</literal>s returned from "
 "<literal>SessionFactory.openSession</literal>. For <literal>Session</"
 "literal>s obtained through <literal>SessionFactory.getCurrentSession</"
 "literal>, the <literal>CurrentSessionContext</literal> implementation "
 "configured for use controls the connection release mode for those "
-"<literal>Session</literal>s. See"
-msgstr ""
-"Note that this setting only affects <literal>Session</literal>s returned "
-"from <literal>SessionFactory.openSession</literal>. For <literal>Session</"
-"literal>s obtained through <literal>SessionFactory.getCurrentSession</"
-"literal>, the <literal>CurrentSessionContext</literal> implementation "
-"configured for use controls the connection release mode for those "
 "<literal>Session</literal>s. See <xref linkend=\"architecture-current-session"
-"\"/>"
+"\" />"
+msgstr ""
+"Note que esta configuração somente afeta as <literal>Session</literal>s "
+"retornadas da <literal>SessionFactory.openSession</literal>. Para as "
+"<literal>Session</literal>s obtidas através da <literal>SessionFactory."
+"getCurrentSession</literal>, a implementação <literal>CurrentSessionContext</"
+"literal> configurada para uso, controla o modo de liberação de conexão para "
+"estas <literal>Session</literal>s. Consulte <xref linkend=\"architecture-"
+"current-session\" />"
 
 #. Tag: entry
-#: configuration.xml:715
 #, no-c-format
 msgid ""
 "<property>hibernate.connection.</property><emphasis>&lt;propertyName&gt;</"
 "emphasis>"
 msgstr ""
+"<property>hibernate.connection.</property><emphasis>&lt;propertyName&gt;</"
+"emphasis>"
 
 #. Tag: entry
-#: configuration.xml:718
 #, no-c-format
 msgid ""
 "Pass the JDBC property <emphasis>&lt;propertyName&gt;</emphasis> to "
 "<literal>DriverManager.getConnection()</literal>."
 msgstr ""
+"Passar a propriedade JDBC <emphasis>&lt;propertyName&gt;</emphasis> para "
+"<literal>DriverManager.getConnection()</literal>."
 
 #. Tag: entry
-#: configuration.xml:724
 #, no-c-format
 msgid ""
 "<property>hibernate.jndi.</property><emphasis>&lt;propertyName&gt;</emphasis>"
 msgstr ""
+"<property>hibernate.jndi.</property><emphasis>&lt;propertyName&gt;</emphasis>"
 
 #. Tag: entry
-#: configuration.xml:727
 #, no-c-format
 msgid ""
 "Pass the property <emphasis>&lt;propertyName&gt;</emphasis> to the JNDI "
 "<literal>InitialContextFactory</literal>."
 msgstr ""
+"Passar a propriedade <emphasis>&lt;propertyName&gt;</emphasis> para o JNDI "
+"<literal>InitialContextFactory</literal>."
 
 #. Tag: title
-#: configuration.xml:737
 #, no-c-format
 msgid "Hibernate Cache Properties"
 msgstr "Propriedades de Cachê do Hibernate"
 
-#. Tag: literal
-#: configuration.xml:750
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.provider_class"
-msgstr "hibernate.cache.provider_class"
+msgid "<literal>hibernate.cache.provider_class</literal>"
+msgstr "<literal>hibernate.cache.provider_class</literal>"
 
 #. Tag: entry
-#: configuration.xml:752
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The classname of a custom <literal>CacheProvider</literal>."
-msgstr "O nome da classe de um <placeholder-1/> customizado. <placeholder-2/>"
+msgstr ""
+"O nome da classe de um  <literal>CacheProvider</literal> personalizado."
 
 #. Tag: para
-#: configuration.xml:754
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "CacheProvider</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">exemplo</emphasis> <literal>classname.of."
+"CacheProvider</literal> "
 
-#. Tag: literal
-#: configuration.xml:762
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_minimal_puts"
-msgstr "hibernate.cache.use_minimal_puts"
+msgid "<literal>hibernate.cache.use_minimal_puts</literal>"
+msgstr "<literal>hibernate.cache.use_minimal_puts</literal>"
 
 #. Tag: entry
-#: configuration.xml:764
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Optimizes second-level cache operation to minimize writes, at the cost of "
 "more frequent reads. This setting is most useful for clustered caches and, "
 "in Hibernate3, is enabled by default for clustered cache implementations."
 msgstr ""
 "Otimizar operação de cachê de segundo nível para minimizar escritas, ao "
-"custo de leituras mais frequantes. Esta configuração é mais útil para cachês "
-"clusterizados e, no Hibernate3, é habilitado por default para implementações "
-"de cachê clusterizar. <placeholder-1/>"
+"custo de leituras mais freqüentes. Esta configuração é mais útil para cachês "
+"em cluster e, no Hibernate3, é habilitado por padrão para implementações de "
+"cache em cluster. "
 
-#. Tag: literal
-#: configuration.xml:777
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_query_cache"
-msgstr "hibernate.cache.use_query_cache"
+msgid "<literal>hibernate.cache.use_query_cache</literal>"
+msgstr "<literal>hibernate.cache.use_query_cache</literal>"
 
 #. Tag: entry
-#: configuration.xml:779
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Enables the query cache. Individual queries still have to be set cachable."
 msgstr ""
-"Habilita a cache de consultas, Mesmo assim, consultas individuais ainda tem "
-"que ser habilitadas para o cache. <placeholder-1/>"
+"Habilita a cache de consultas. Mesmo assim, consultas individuais ainda têm "
+"que ser habilitadas para o cache."
 
-#. Tag: literal
-#: configuration.xml:789
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_second_level_cache"
-msgstr "hibernate.cache.use_second_level_cache"
+msgid "<literal>hibernate.cache.use_second_level_cache</literal>"
+msgstr "<literal>hibernate.cache.use_second_level_cache</literal>"
 
 #. Tag: entry
-#: configuration.xml:791
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Can be used to completely disable the second level cache, which is enabled "
 "by default for classes which specify a <literal>&lt;cache&gt;</literal> "
 "mapping."
 msgstr ""
-"Pode ser usada para desabilitar completamente ocache de segundo nível, o "
-"qual está habilitado por default para classes que especificam um mapeamento "
-"<placeholder-1/>. <placeholder-2/>"
+"Pode ser utilizado para desabilitar completamente o cache de segundo nível, "
+"o qual é habilitado por padrão para as classes que especificam um mapeamento "
+"<literal>&lt;cache&gt;</literal>."
 
-#. Tag: literal
-#: configuration.xml:803
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.query_cache_factory"
-msgstr "hibernate.cache.query_cache_factory"
+msgid "<literal>hibernate.cache.query_cache_factory</literal>"
+msgstr "<literal>hibernate.cache.query_cache_factory</literal>"
 
 #. Tag: entry
-#: configuration.xml:805
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a custom <literal>QueryCache</literal> interface, defaults "
 "to the built-in <literal>StandardQueryCache</literal>."
 msgstr ""
-"O nome de uma classe que implementa a interface <placeholder-1/> "
-"personalizada, por default, um <placeholder-2/> criado automaticamente. "
-"<placeholder-3/>"
+"O nome de classe de uma interface personalizada <literal>QueryCache</"
+"literal>, padroniza para o <literal>StandardQueryCache</literal> criado "
+"automaticamente. "
 
 #. Tag: para
-#: configuration.xml:808
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of.QueryCache</"
 "literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">exemplo</emphasis> <literal>classname.of."
+"QueryCache</literal>"
 
-#. Tag: literal
-#: configuration.xml:816
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.region_prefix"
-msgstr "hibernate.cache.region_prefix"
+msgid "<literal>hibernate.cache.region_prefix</literal>"
+msgstr "<literal>hibernate.cache.region_prefix</literal>"
 
 #. Tag: entry
-#: configuration.xml:818
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A prefix to use for second-level cache region names."
-msgstr ""
-"Um prefixo para usar nos nomes da área especial do cachê de segundo nível. "
-"<placeholder-1/>"
+msgstr "Um prefixo para usar em nomes regionais de cachê de segundo nível"
 
 #. Tag: para
-#: configuration.xml:820
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>prefix</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">exemplo</emphasis> <literal>prefix</literal> "
 
-#. Tag: literal
-#: configuration.xml:828
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_structured_entries"
-msgstr "hibernate.cache.use_structured_entries"
+msgid "<literal>hibernate.cache.use_structured_entries</literal>"
+msgstr "<literal>hibernate.cache.use_structured_entries</literal>"
 
 #. Tag: entry
-#: configuration.xml:830
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Forces Hibernate to store data in the second-level cache in a more human-"
 "friendly format."
 msgstr ""
-"Forces Hibernate to store data in the second-level cache in a more human-"
-"friendly format. Força o Hibernate armazenar dados no cachê se segundo nível "
-"em um formato mais legivel. <placeholder-1/>"
+"Força o Hibernate a armazenar dados no cachê de segundo nível em um formato "
+"mais humanamente amigável."
 
 #. Tag: title
-#: configuration.xml:844
 #, no-c-format
 msgid "Hibernate Transaction Properties"
 msgstr "Propriedades de Transação do Hibernate"
 
-#. Tag: literal
-#: configuration.xml:857
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.transaction.factory_class"
-msgstr "hibernate.transaction.factory_class"
+msgid "<literal>hibernate.transaction.factory_class</literal>"
+msgstr "<literal>hibernate.transaction.factory_class</literal>"
 
 #. Tag: entry
-#: configuration.xml:859
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a <literal>TransactionFactory</literal> to use with "
 "Hibernate <literal>Transaction</literal> API (defaults to "
 "<literal>JDBCTransactionFactory</literal>)."
 msgstr ""
-"O nome da clase de um a <placeholder-1/> para usar com API <placeholder-2/> "
-"( por default <placeholder-3/>). <placeholder-4/>"
+"O nome da classe de uma <literal>TransactionFactory</literal>  para usar com "
+"API do Hibernate  <literal>Transaction</literal> ( por "
+"padrão<literal>JDBCTransactionFactory</literal> ). "
 
 #. Tag: para
-#: configuration.xml:863
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "TransactionFactory</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">exemplo</emphasis> <literal>classname.of."
+"TransactionFactory</literal>  "
 
-#. Tag: literal
-#: configuration.xml:871
+#. Tag: entry
 #, no-c-format
-msgid "jta.UserTransaction"
-msgstr "jta.UserTransaction"
+msgid "<literal>jta.UserTransaction</literal>"
+msgstr "<literal>jta.UserTransaction</literal>"
 
 #. Tag: entry
-#: configuration.xml:873
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A JNDI name used by <literal>JTATransactionFactory</literal> to obtain the "
 "JTA <literal>UserTransaction</literal> from the application server."
 msgstr ""
-"Um nome JNDI usado pelo <placeholder-1/> para obter uma <placeholder-2/> JTA "
-"a partir do servidor de aplicação. <placeholder-3/>"
+"Um nome JNDI usado pelo  <literal>JTATransactionFactory</literal>para obter "
+"uma  <literal>UserTransaction</literal> JTA a partir do servidor de "
+"aplicação. "
 
-#. Tag: literal
-#: configuration.xml:885
-#, no-c-format
-msgid "hibernate.transaction.manager_lookup_class"
-msgstr "hibernate.transaction.manager_lookup_class"
-
 #. Tag: entry
-#: configuration.xml:887
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.manager_lookup_class</literal>"
+msgstr "<literal>hibernate.transaction. manager_lookup_class</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "The classname of a <literal>TransactionManagerLookup</literal>. It is "
 "required when JVM-level caching is enabled or when using hilo generator in a "
 "JTA environment."
 msgstr ""
-"O nome da classe de um <placeholder-1/> – requerido quando caching a nível "
-"JVM esta habilitado ou quando estivermos usando um generator hilo em um "
-"ambiente JTA. <placeholder-2/>"
+"O nome da classe de um <literal>TransactionManagerLookup</literal>. Ele é "
+"requerido quando o caching a nível JVM estiver habilitado ou quando "
+"estivermos usando um gerador hilo em um ambiente JTA. "
 
 #. Tag: para
-#: configuration.xml:891
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "TransactionManagerLookup</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">exemplo</emphasis> <literal>classname.of."
+"TransactionManagerLookup</literal> "
 
-#. Tag: literal
-#: configuration.xml:899
-#, no-c-format
-msgid "hibernate.transaction.flush_before_completion"
-msgstr "hibernate.transaction.flush_before_completion"
-
 #. Tag: entry
-#: configuration.xml:901
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.flush_before_completion</literal>"
+msgstr "<literal>hibernate.transaction. flush_before_completion</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "If enabled, the session will be automatically flushed during the before "
 "completion phase of the transaction. Built-in and automatic session context "
-"management is preferred, see <xref linkend=\"architecture-current-session\"/"
+"management is preferred, see <xref linkend=\"architecture-current-session\" /"
 ">."
 msgstr ""
-"Se habilitado, a sessão será automaticamente limpa antes da fase de "
-"conclusão da transação. É preferivel a gerência interna e automática do "
-"contexto da sessão, veja <xref linkend=\"architecture-current-session\"/"
-"><placeholder-1/>"
+"Se habilitada, a sessão será automaticamente liberada antes da fase de "
+"conclusão da transação. Prefere-se o gerenciamento de contexto da sessão "
+"criada e automática, veja <xref linkend=\"architecture-current-session\" />."
 
-#. Tag: literal
-#: configuration.xml:914
-#, no-c-format
-msgid "hibernate.transaction.auto_close_session"
-msgstr "hibernate.transaction.auto_close_session"
-
 #. Tag: entry
-#: configuration.xml:916
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.auto_close_session</literal>"
+msgstr "<literal>hibernate.transaction. auto_close_session</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "If enabled, the session will be automatically closed during the after "
 "completion phase of the transaction. Built-in and automatic session context "
-"management is preferred, see <xref linkend=\"architecture-current-session\"/"
+"management is preferred, see <xref linkend=\"architecture-current-session\" /"
 ">."
 msgstr ""
-"Se habilitado, a sessão será automaticamente fechada após a fase de "
-"conclusão da transação. É preferivel a gerência interna e automática do "
-"contexto da sessão, veja <xref linkend=\"architecture-current-session\"/"
-"><placeholder-1/>"
+"Se habilitada, a sessão será automaticamente fechada após a fase de "
+"conclusão da transação. Prefere-se a gerência interna e automática do "
+"contexto da sessão, veja <xref linkend=\"architecture-current-session\" />."
 
 #. Tag: title
-#: configuration.xml:932
 #, no-c-format
 msgid "Miscellaneous Properties"
 msgstr "Propriedades Variadas"
 
-#. Tag: literal
-#: configuration.xml:945
-#, no-c-format
-msgid "hibernate.current_session_context_class"
-msgstr "hibernate.current_session_context_class"
-
 #. Tag: entry
-#: configuration.xml:947
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.current_session_context_class</literal>"
+msgstr "<literal>hibernate. current_session_context_class</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "Supply a custom strategy for the scoping of the \"current\" "
 "<literal>Session</literal>. See <xref linkend=\"architecture-current-session"
-"\"/> for more information about the built-in strategies."
+"\" /> for more information about the built-in strategies."
 msgstr ""
-"Forneçe uma estratégia (personalizada) para extensão da <placeholder-1/> "
-"\"corrente\". Veja <xref linkend=\"architecture-current-session\"/> para "
-"mais informação sobre estratégias internas. <placeholder-2/>"
+"Fornece uma estratégia personalizada para extensão da <literal>Session</"
+"literal>\"atual\". Veja <xref linkend=\"architecture-current-session\" /> "
+"para mais informação sobre estratégias internas. "
 
 #. Tag: para
-#: configuration.xml:952
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>jta</literal> | "
 "<literal>thread</literal> | <literal>managed</literal> | <literal>custom."
 "Class</literal>"
 msgstr ""
-"<emphasis role=\"strong\">Ex.</emphasis><literal>jta</literal> | "
+"<emphasis role=\"strong\">exemplo</emphasis> <literal>jta</literal> | "
 "<literal>thread</literal> | <literal>managed</literal> | <literal>custom."
 "Class</literal>"
 
-#. Tag: literal
-#: configuration.xml:961
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.query.factory_class"
-msgstr "hibernate.query.factory_class"
+msgid "<literal>hibernate.query.factory_class</literal>"
+msgstr "<literal>hibernate.query.factory_class</literal>"
 
 #. Tag: entry
-#: configuration.xml:963
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Chooses the HQL parser implementation."
-msgstr "Escolha a implementação de análise HQL. <placeholder-1/>"
+msgstr "Escolha a implementação de análise HQL. "
 
 #. Tag: para
-#: configuration.xml:965
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>org.hibernate.hql.ast."
 "ASTQueryTranslatorFactory</literal> or <literal>org.hibernate.hql.classic."
 "ClassicQueryTranslatorFactory</literal>"
 msgstr ""
-"<emphasis role=\"strong\">eg.</emphasis><literal>org.hibernate.hql.ast."
-"ASTQueryTranslatorFactory</literal> or <literal>org.hibernate.hql.classic."
+"<emphasis role=\"strong\">exemplo</emphasis> <literal>org.hibernate.hql.ast. "
+"ASTQueryTranslatorFactory</literal> ou <literal>org.hibernate.hql.classic. "
 "ClassicQueryTranslatorFactory</literal>"
 
-#. Tag: literal
-#: configuration.xml:974
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.query.substitutions"
-msgstr "hibernate.query.substitutions"
+msgid "<literal>hibernate.query.substitutions</literal>"
+msgstr "<literal>hibernate.query.substitutions</literal>"
 
 #. Tag: entry
-#: configuration.xml:976
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Is used to map from tokens in Hibernate queries to SQL tokens (tokens might "
 "be function or literal names, for example)."
 msgstr ""
-"Mapeamento a partir de símbolos em consultas HQL para símbolos SQL( símbolos "
-"devem ser funções ou nome literais , por exemplo). <placeholder-1/>"
+"Mapeamento a partir de símbolos em consultas do Hibernate para para símbolos "
+"SQL (símbolos devem ser por exemplo, funções ou nome literais).  "
 
 #. Tag: para
-#: configuration.xml:979
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>hqlLiteral=SQL_LITERAL, "
 "hqlFunction=SQLFUNC</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">Ex.</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">exemplo</emphasis> "
+"<literal>hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC</literal> "
 
-#. Tag: literal
-#: configuration.xml:987
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.hbm2ddl.auto"
-msgstr "hibernate.hbm2ddl.auto"
+msgid "<literal>hibernate.hbm2ddl.auto</literal>"
+msgstr "<literal>hibernate.hbm2ddl.auto</literal>"
 
 #. Tag: entry
-#: configuration.xml:989
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Automatically validates or exports schema DDL to the database when the "
 "<literal>SessionFactory</literal> is created. With <literal>create-drop</"
 "literal>, the database schema will be dropped when the "
 "<literal>SessionFactory</literal> is closed explicitly."
 msgstr ""
-"Automaticamente valida ou exporta schema DDL para o banco de dados quando o "
-"<placeholder-1/> é criads. Com <placeholder-2/>, o schema do banco de dados "
-"será excluido quando a <placeholder-3/> for fechada esplicitamente. "
-"<placeholder-4/>"
+"Automaticamente valida ou exporta DDL esquema para o banco de dados quando o "
+"<literal>SessionFactory</literal> é criado. Com <literal>create-drop</"
+"literal>, o esquema do banco de dados será excluido quando a "
+"<literal>SessionFactory</literal> for fechada explicitamente. "
 
 #. Tag: para
-#: configuration.xml:995
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>validate</literal> | "
 "<literal>update</literal> | <literal>create</literal> | <literal>create-"
 "drop</literal>"
 msgstr ""
-"<emphasis role=\"strong\">Ex.</emphasis><literal>validate</literal> | "
+"<emphasis role=\"strong\">exemplo</emphasis> <literal>validate</literal> | "
 "<literal>update</literal> | <literal>create</literal> | <literal>create-"
-"drop</literal>"
+"drop</literal>  "
 
-#. Tag: literal
-#: configuration.xml:1004
-#, no-c-format
-msgid "hibernate.cglib.use_reflection_optimizer"
-msgstr "hibernate.cglib.use_reflection_optimizer"
-
 #. Tag: entry
-#: configuration.xml:1006
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.cglib.use_reflection_optimizer</literal>"
+msgstr "<literal>hibernate.cglib. use_reflection_optimizer</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "Enables the use of CGLIB instead of runtime reflection (System-level "
 "property). Reflection can sometimes be useful when troubleshooting. "
 "Hibernate always requires CGLIB even if you turn off the optimizer. You "
 "cannot set this property in <literal>hibernate.cfg.xml</literal>."
 msgstr ""
-"Habilita o uso de CGLIB em vez de reflexão em tempo de execução "
-"( propriedade a nível de sistema). Reflexão pode algumas vezes ser ú til "
-"quando controlar erros, note que o Hibernate sempre irá requerer a CGLIB "
+"Habilita o uso de CGLIB ao invés de reflexão em tempo de execução "
+"(propriedade a nível de sistema). Reflexão pode algumas vezes ser útil "
+"quando controlar erros, note que o Hibernate sempre irá solicitar a CGLIB "
 "mesmo se você desligar o otimizador. Você não pode determinar esta "
-"propriedade no <placeholder-1/>. <placeholder-2/>"
+"propriedade no <literal>hibernate.cfg.xml</literal>."
 
 #. Tag: title
-#: configuration.xml:1022
 #, no-c-format
 msgid "SQL Dialects"
 msgstr "Dialetos SQL"
 
 #. Tag: para
-#: configuration.xml:1024
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Always set the <literal>hibernate.dialect</literal> property to the correct "
 "<literal>org.hibernate.dialect.Dialect</literal> subclass for your database. "
@@ -2216,317 +1523,262 @@
 msgstr ""
 "Você deve sempre determinar a propriedade <literal>hibernate.dialect</"
 "literal> para a subclasse de <literal>org.hibernate.dialect.Dialect</"
-"literal> correta de seu banco de dados. Se você especificar um dialeto, "
-"Hibernate usará defaults lógicos para qualquer um das outras propriedades "
+"literal> correta de seu banco de dados. Se você especificar um dialeto, o "
+"Hibernate usará padrões lógicos para qualquer um das outras propriedades "
 "listadas abaixo, reduzindo o esforço de especificá-los manualmente."
 
 #. Tag: title
-#: configuration.xml:1032
 #, no-c-format
 msgid "Hibernate SQL Dialects (<literal>hibernate.dialect</literal>)"
-msgstr "Hibernate SQL Dialects (<literal>hibernate.dialect</literal>)"
+msgstr "Dialetos SQL do Hibernate (<literal>hibernate.dialect</literal>)"
 
 #. Tag: entry
-#: configuration.xml:1040
 #, no-c-format
 msgid "RDBMS"
 msgstr "RDBMS"
 
 #. Tag: entry
-#: configuration.xml:1041
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Dialect"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Dialeto\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Dialect"
+msgstr "Dialeto"
 
 #. Tag: entry
-#: configuration.xml:1046
 #, no-c-format
-msgid "<entry>DB2</entry>"
-msgstr ""
+msgid "DB2"
+msgstr "DB2"
 
-#. Tag: literal
-#: configuration.xml:1046
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2Dialect"
-msgstr "org.hibernate.dialect.DB2Dialect"
+msgid "<literal>org.hibernate.dialect.DB2Dialect</literal>"
+msgstr "<literal>org.hibernate.dialect.DB2Dialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1049
 #, no-c-format
 msgid "DB2 AS/400"
 msgstr "DB2 AS/400"
 
-#. Tag: literal
-#: configuration.xml:1049
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2400Dialect"
-msgstr "org.hibernate.dialect.DB2400Dialect"
+msgid "<literal>org.hibernate.dialect.DB2400Dialect</literal>"
+msgstr "<literal>org.hibernate.dialect.DB2400Dialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1052
 #, no-c-format
 msgid "DB2 OS390"
 msgstr "DB2 OS390"
 
-#. Tag: literal
-#: configuration.xml:1052
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2390Dialect"
-msgstr "org.hibernate.dialect.DB2390Dialect"
+msgid "<literal>org.hibernate.dialect.DB2390Dialect</literal>"
+msgstr "<literal>org.hibernate.dialect.DB2390Dialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1055
 #, no-c-format
 msgid "PostgreSQL"
 msgstr "PostgreSQL"
 
-#. Tag: literal
-#: configuration.xml:1055
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.PostgreSQLDialect"
-msgstr "org.hibernate.dialect.PostgreSQLDialect"
+msgid "<literal>org.hibernate.dialect.PostgreSQLDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.PostgreSQLDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1058
 #, no-c-format
 msgid "MySQL"
-msgstr "MySQL"
+msgstr "Meu SQL"
 
-#. Tag: literal
-#: configuration.xml:1058
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLDialect"
-msgstr "org.hibernate.dialect.MySQLDialect"
+msgid "<literal>org.hibernate.dialect.MySQLDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MySQLDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1061
 #, no-c-format
 msgid "MySQL with InnoDB"
-msgstr "MySQL with InnoDB"
+msgstr "MeuSQL com InnoDB"
 
-#. Tag: literal
-#: configuration.xml:1061
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLInnoDBDialect"
-msgstr "org.hibernate.dialect.MySQLInnoDBDialect"
+msgid "<literal>org.hibernate.dialect.MySQLInnoDBDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MySQLInnoDBDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1064
 #, no-c-format
 msgid "MySQL with MyISAM"
-msgstr "MySQL with MyISAM"
+msgstr "Meu SQL com MeuISAM"
 
-#. Tag: literal
-#: configuration.xml:1064
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLMyISAMDialect"
-msgstr "org.hibernate.dialect.MySQLMyISAMDialect"
+msgid "<literal>org.hibernate.dialect.MySQLMyISAMDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MySQLMyISAMDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1067
 #, no-c-format
 msgid "Oracle (any version)"
-msgstr "Oracle (any version)"
+msgstr "Oracle (qualquer versão)"
 
-#. Tag: literal
-#: configuration.xml:1067
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.OracleDialect"
-msgstr "org.hibernate.dialect.OracleDialect"
+msgid "<literal>org.hibernate.dialect.OracleDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.OracleDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1070
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Oracle 9i"
-msgstr "Oracle 9i/10g"
+msgstr "Oracle 9i"
 
-#. Tag: literal
-#: configuration.xml:1070
-#, fuzzy, no-c-format
-msgid "org.hibernate.dialect.Oracle9iDialect"
-msgstr "org.hibernate.dialect.Oracle9Dialect"
+#. Tag: entry
+#, no-c-format
+msgid "<literal>org.hibernate.dialect.Oracle9iDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.Oracle9iDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1073
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Oracle 10g"
-msgstr "Oracle 9i/10g"
+msgstr "Oracle 10g"
 
-#. Tag: literal
-#: configuration.xml:1073
-#, fuzzy, no-c-format
-msgid "org.hibernate.dialect.Oracle10gDialect"
-msgstr "org.hibernate.dialect.OracleDialect"
+#. Tag: entry
+#, no-c-format
+msgid "<literal>org.hibernate.dialect.Oracle10gDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.Oracle10gDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1076
 #, no-c-format
 msgid "Sybase"
 msgstr "Sybase"
 
-#. Tag: literal
-#: configuration.xml:1076
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SybaseDialect"
-msgstr "org.hibernate.dialect.SybaseDialect"
+msgid "<literal>org.hibernate.dialect.SybaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SybaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1079
 #, no-c-format
 msgid "Sybase Anywhere"
-msgstr "Sybase Anywhere"
+msgstr "Sybase Qualquer lugar"
 
-#. Tag: literal
-#: configuration.xml:1079
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SybaseAnywhereDialect"
-msgstr "org.hibernate.dialect.SybaseAnywhereDialect"
+msgid "<literal>org.hibernate.dialect.SybaseAnywhereDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SybaseAnywhereDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1082
 #, no-c-format
 msgid "Microsoft SQL Server"
-msgstr "Microsoft SQL Server"
+msgstr "Servidor Microsoft SQL"
 
-#. Tag: literal
-#: configuration.xml:1082
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SQLServerDialect"
-msgstr "org.hibernate.dialect.SQLServerDialect"
+msgid "<literal>org.hibernate.dialect.SQLServerDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SQLServerDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1085
 #, no-c-format
 msgid "SAP DB"
 msgstr "SAP DB"
 
-#. Tag: literal
-#: configuration.xml:1085
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SAPDBDialect"
-msgstr "org.hibernate.dialect.SAPDBDialect"
+msgid "<literal>org.hibernate.dialect.SAPDBDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SAPDBDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1088
 #, no-c-format
 msgid "Informix"
 msgstr "Informix"
 
-#. Tag: literal
-#: configuration.xml:1088
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.InformixDialect"
-msgstr "org.hibernate.dialect.InformixDialect"
+msgid "<literal>org.hibernate.dialect.InformixDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.InformixDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1091
 #, no-c-format
 msgid "HypersonicSQL"
 msgstr "HypersonicSQL"
 
-#. Tag: literal
-#: configuration.xml:1091
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.HSQLDialect"
-msgstr "org.hibernate.dialect.HSQLDialect"
+msgid "<literal>org.hibernate.dialect.HSQLDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.HSQLDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1094
 #, no-c-format
 msgid "Ingres"
 msgstr "Ingres"
 
-#. Tag: literal
-#: configuration.xml:1094
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.IngresDialect"
-msgstr "org.hibernate.dialect.IngresDialect"
+msgid "<literal>org.hibernate.dialect.IngresDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.IngresDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1097
 #, no-c-format
 msgid "Progress"
-msgstr "Progress"
+msgstr "Progresso"
 
-#. Tag: literal
-#: configuration.xml:1097
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.ProgressDialect"
-msgstr "org.hibernate.dialect.ProgressDialect"
+msgid "<literal>org.hibernate.dialect.ProgressDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.ProgressDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1100
 #, no-c-format
 msgid "Mckoi SQL"
 msgstr "Mckoi SQL"
 
-#. Tag: literal
-#: configuration.xml:1100
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MckoiDialect"
-msgstr "org.hibernate.dialect.MckoiDialect"
+msgid "<literal>org.hibernate.dialect.MckoiDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MckoiDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1103
 #, no-c-format
 msgid "Interbase"
 msgstr "Interbase"
 
-#. Tag: literal
-#: configuration.xml:1103
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.InterbaseDialect"
-msgstr "org.hibernate.dialect.InterbaseDialect"
+msgid "<literal>org.hibernate.dialect.InterbaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.InterbaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1106
 #, no-c-format
 msgid "Pointbase"
-msgstr "Pointbase"
+msgstr "Base Ponto"
 
-#. Tag: literal
-#: configuration.xml:1106
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.PointbaseDialect"
-msgstr "org.hibernate.dialect.PointbaseDialect"
+msgid "<literal>org.hibernate.dialect.PointbaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.PointbaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1109
 #, no-c-format
 msgid "FrontBase"
-msgstr "FrontBase"
+msgstr "Base Frontal"
 
-#. Tag: literal
-#: configuration.xml:1109
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.FrontbaseDialect"
-msgstr "org.hibernate.dialect.FrontbaseDialect"
+msgid "<literal>org.hibernate.dialect.FrontbaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.FrontbaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1112
 #, no-c-format
 msgid "Firebird"
 msgstr "Firebird"
 
-#. Tag: literal
-#: configuration.xml:1112
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.FirebirdDialect"
-msgstr "org.hibernate.dialect.FirebirdDialect"
+msgid "<literal>org.hibernate.dialect.FirebirdDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.FirebirdDialect</literal>"
 
 #. Tag: title
-#: configuration.xml:1121
 #, no-c-format
 msgid "Outer Join Fetching"
-msgstr "Recuperação por união externa (Outer Join Fetching)"
+msgstr "Busca por união externa (Outer Join Fetching)"
 
 #. Tag: para
-#: configuration.xml:1123
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your database supports ANSI, Oracle or Sybase style outer joins, "
 "<emphasis>outer join fetching</emphasis> will often increase performance by "
@@ -2536,19 +1788,18 @@
 "one, one-to-many, many-to-many and one-to-one associations to be retrieved "
 "in a single SQL <literal>SELECT</literal>."
 msgstr ""
-"Se seu banco de dados suporta Recuperação por união externa (Outer Join "
-"Fetching) no estilo ANSI, Oracle ou Sybase, A recuperação por união externa "
-"(Outer Join Fetching) frequentemente aumentará o desempenho limitando o "
-"número de chamadas (round trips) ao banco de dados( ao custo de "
-"possivelmente mais trabalho desempenhado pelo próprio banco de dados). A "
-"recuperação por união externa (Outer Join Fetching)permite um gráfico "
-"completo de objetos conectados por muitos-para-um, um-para-muitos, muitos-"
-"para-muitos e associações um-para-um para ser recuperadas em um simples "
-"instrução SQL SELECT ."
+"Se seu banco de dados suporta união externa no estilo ANSI, Oracle ou "
+"Sybase, a <emphasis>outer join fetching</emphasis> freqüentemente aumentará "
+"o desempenho limitando o número de chamadas (round trips) para e a partir do "
+"banco de dados. No entanto, isto ao custo de possivelmente mais trabalho "
+"desempenhado pelo próprio banco de dados. A busca por união externa (outer "
+"join fetching) permite um gráfico completo de objetos conectados por "
+"associações muitos-para-um, um-para-muitos, muitos-para-muitos e um-para-um "
+"para serem recuperadas em uma simples instrução SQL <literal>SELECT</"
+"literal>."
 
 #. Tag: para
-#: configuration.xml:1132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Outer join fetching can be disabled <emphasis>globally</emphasis> by setting "
 "the property <literal>hibernate.max_fetch_depth</literal> to <literal>0</"
@@ -2556,27 +1807,24 @@
 "fetching for one-to-one and many-to-one associations that have been mapped "
 "with <literal>fetch=\"join\"</literal>."
 msgstr ""
-"A recuperação por união externa (Outer Join Fetching) pode ser desabilitado "
-"<emphasis>globalmente</emphasis> setando a propriedade <literal>hibernate."
-"max_fetch_depth</literal> para <literal>0</literal>. Uma valor 1 ou maior "
-"habilita o outer join fetching para associações um-para-um e muitos-para-"
-"umos cujos quais tem sido mapeado com <literal>fetch=\"join\"</literal>."
+"A busca por união externa pode ser desabilitada <emphasis>globalmente</"
+"emphasis> configurando a propriedade <literal>hibernate.max_fetch_depth</"
+"literal> para <literal>0</literal>. Um valor <literal>1</literal> ou maior "
+"habilita a busca por união externa para associações um-para-um e muitos-para-"
+"um, cujos quais têm sido mapeados com <literal>fetch=\"join\"</literal>."
 
 #. Tag: para
-#: configuration.xml:1140
 #, no-c-format
-msgid "See <xref linkend=\"performance-fetching\"/> for more information."
-msgstr "Veja <xref linkend=\"performance-fetching\"/> para mais informações."
+msgid "See <xref linkend=\"performance-fetching\" /> for more information."
+msgstr "Veja <xref linkend=\"performance-fetching\" /> para mais informações."
 
 #. Tag: title
-#: configuration.xml:1147
 #, no-c-format
 msgid "Binary Streams"
 msgstr "Fluxos Binários (Binary Streams)"
 
 #. Tag: para
-#: configuration.xml:1149
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Oracle limits the size of <literal>byte</literal> arrays that can be passed "
 "to and/or from its JDBC driver. If you wish to use large instances of "
@@ -2584,86 +1832,67 @@
 "should enable <literal>hibernate.jdbc.use_streams_for_binary</literal>. "
 "<emphasis>This is a system-level setting only.</emphasis>"
 msgstr ""
-"O Oracle limita o tamanho de arrays de <literal>byte</literal> que pode ser "
-"passado para/de o driver JDBC. Se você desejar usar grandes instâncias de "
+"O Oracle limita o tamanho de matrizes de <literal>byte</literal> que podem "
+"ser passadas para/do driver JDBC. Se você desejar usar grandes instâncias de "
 "tipos <literal>binary</literal> ou <literal>serializable</literal>, você "
 "deve habilitar <literal>hibernate.jdbc.use_streams_for_binary</literal>. "
-"<emphasis>Essa é uma configuração que só pode ser feita a nível de sistema.</"
-"emphasis>"
+"<emphasis>Essa é uma configuração que só pode ser feita em nível de sistema."
+"</emphasis> "
 
 #. Tag: title
-#: configuration.xml:1160
 #, no-c-format
 msgid "Second-level and query cache"
-msgstr "Cachê de segundo nível e query"
+msgstr "Cachê de segundo nível e consulta"
 
 #. Tag: para
-#: configuration.xml:1162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The properties prefixed by <literal>hibernate.cache</literal> allow you to "
 "use a process or cluster scoped second-level cache system with Hibernate. "
-"See the <xref linkend=\"performance-cache\"/> for more information."
+"See the <xref linkend=\"performance-cache\" /> for more information."
 msgstr ""
-"As propriedades prefixadas pelo <literal>hibernate.cache</literal> permite "
-"você usar um sistema de cachê de segundo nível em um processo executado em "
-"clustercom Hibernate. Veja <xref linkend=\"performance-cache\"/> para mais "
-"detalhes."
+"As propriedades pré-fixadas pelo <literal>hibernate.cache</literal> permitem "
+"que você use um sistema de cache de segundo nível em um processo executado "
+"ou em cluster com Hibernate. Veja <xref linkend=\"performance-cache\"/> para "
+"maiores detalhes. "
 
 #. Tag: title
-#: configuration.xml:1172
 #, no-c-format
 msgid "Query Language Substitution"
-msgstr "Substituições na Linguagem de Consulta"
+msgstr "Substituição na Linguagem de Consulta"
 
 #. Tag: para
-#: configuration.xml:1174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can define new Hibernate query tokens using <literal>hibernate.query."
 "substitutions</literal>. For example:"
 msgstr ""
 "Você pode definir novos símbolos de consulta Hibernate usando "
-"<literal>hibernate.query.substitutions</literal>. Por exemplo:"
+"<literal>hibernate.query.substitutions</literal>. Por exemplo: "
 
-#. Tag: programlisting
-#: configuration.xml:1179
-#, no-c-format
-msgid "hibernate.query.substitutions true=1, false=0"
-msgstr "hibernate.query.substitutions true=1, false=0"
-
 #. Tag: para
-#: configuration.xml:1181
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This would cause the tokens <literal>true</literal> and <literal>false</"
 "literal> to be translated to integer literals in the generated SQL."
 msgstr ""
-"Faria com que os símbolos <literal>true</literal> e <literal>false</literal> "
-"passasem a ser traduzidos para literais inteiro no SQL gerado."
+"Isto faria com que os símbolos <literal>true</literal> e <literal>false</"
+"literal> passasem a ser traduzidos para literais inteiros no SQL gerado."
 
-#. Tag: programlisting
-#: configuration.xml:1186
-#, no-c-format
-msgid "hibernate.query.substitutions toLowercase=LOWER"
-msgstr "hibernate.query.substitutions toLowercase=LOWER"
-
 #. Tag: para
-#: configuration.xml:1188
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This would allow you to rename the SQL <literal>LOWER</literal> function."
-msgstr "permitirá você renomear a função <literal>LOWER</literal> no SQL."
+msgstr ""
+"Isto permitirá que você renomeie a função <literal>LOWER</literal> no SQL."
 
 #. Tag: title
-#: configuration.xml:1195
 #, no-c-format
 msgid "Hibernate statistics"
 msgstr "Estatísticas do Hibernate"
 
 #. Tag: para
-#: configuration.xml:1197
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you enable <literal>hibernate.generate_statistics</literal>, Hibernate "
 "exposes a number of metrics that are useful when tuning a running system via "
@@ -2671,11 +1900,6 @@
 "configured to expose these statistics via JMX. Read the Javadoc of the "
 "interfaces in <literal>org.hibernate.stats</literal> for more information."
 msgstr ""
-"If you enable <literal>hibernate.generate_statistics</literal>, Hibernate "
-"will expose a number of metrics that are useful when tuning a running system "
-"via <literal>SessionFactory.getStatistics()</literal>. Hibernate can even be "
-"configured to expose these statistics via JMX. Read the Javadoc of the "
-"interfaces in <literal>org.hibernate.stats</literal> for more information. "
 "Se você habilitar <literal>hibernate.generate_statistics</literal>, o "
 "Hibernate exibirá um número de métricas bastante útil ao ajustar um sistema "
 "via <literal>SessionFactory.getStatistics()</literal>. O Hibernate pode até "
@@ -2683,13 +1907,11 @@
 "interface <literal>org.hibernate.stats</literal> para mais informações."
 
 #. Tag: title
-#: configuration.xml:1209
 #, no-c-format
 msgid "Logging"
 msgstr "Logging"
 
 #. Tag: para
-#: configuration.xml:1211
 #, no-c-format
 msgid ""
 "Hibernate utilizes <ulink url=\"http://www.slf4j.org/\">Simple Logging "
@@ -2705,10 +1927,22 @@
 "properties file is distributed with Hibernate in the <literal>src/</literal> "
 "directory."
 msgstr ""
+"O Hibernate utiliza o <ulink url=\"http://www.slf4j.org/\">Simple Logging "
+"Facade for Java</ulink> (SLF4J) com o objetivo de registrar os diversos "
+"eventos de sistema. O SLF4J pode direcionar a sua saída de logging a "
+"diversos frameworks de logging (NOP, Simple, log4j version 1.2, JDK 1.4 "
+"logging, JCL ou logback) dependendo de sua escolha de vinculação. Com o "
+"objetivo de determinar o seu logging, você precisará do <filename>slf4j-api."
+"jar</filename> em seu classpatch juntamente com o arquivo jar para a sua "
+"vinculação preferida - <filename>slf4j-log4j12.jar</filename> no caso do "
+"Log4J. Consulte o SLF4J <ulink url=\"http://www.slf4j.org/manual.html"
+"\">documentation</ulink> para maiores detalhes. Para usar o Log4j você "
+"precisará também colocar um arquivo <filename>log4j.properties</filename> em "
+"seu classpath. Um exemplo do arquivo de propriedades está distribuído com o "
+"Hibernate no diretório <literal>src/</literal>. "
 
 #. Tag: para
-#: configuration.xml:1222
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you familiarize yourself with Hibernate's log "
 "messages. A lot of work has been put into making the Hibernate log as "
@@ -2716,165 +1950,135 @@
 "troubleshooting device. The most interesting log categories are the "
 "following:"
 msgstr ""
-"We strongly recommend that you familiarize yourself with Hibernate's log "
-"messages. A lot of work has been put into making the Hibernate log as "
-"detailed as possible, without making it unreadable. It is an essential "
-"troubleshooting device. The most interesting log categories are the "
-"following: Nós recomendamos enfaticamente que você se familiarize-se com "
-"mensagens de log do Hibernate. Uma parte do trabalho tem sido posto em fazer "
-"o log Hibernate tão detalhado quanto possível, sem fazê-lo ilegível. É um "
-"essencial dispositivos de controle de erros. As categorias de log mais "
-"interessantes são as seguintes:"
+"Nós recomendamos que você se familiarize-se com mensagens de log do "
+"Hibernate. Tem sido um árduo trabalho fazer o log Hibernate tão detalhado "
+"quanto possível, sem fazê-lo ilegível. É um dispositivo de controle de erros "
+"essencial. As categorias de log mais interessantes são as seguintes:"
 
 #. Tag: title
-#: configuration.xml:1231
 #, no-c-format
 msgid "Hibernate Log Categories"
 msgstr "Categorias de Log do Hibernate"
 
 #. Tag: entry
-#: configuration.xml:1237
 #, no-c-format
 msgid "Category"
 msgstr "Categoria"
 
 #. Tag: entry
-#: configuration.xml:1238
 #, no-c-format
 msgid "Function"
 msgstr "Função"
 
-#. Tag: literal
-#: configuration.xml:1243
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.SQL"
-msgstr "org.hibernate.SQL"
+msgid "<literal>org.hibernate.SQL</literal>"
+msgstr "<literal>org.hibernate.SQL</literal>"
 
 #. Tag: entry
-#: configuration.xml:1244
 #, no-c-format
 msgid "Log all SQL DML statements as they are executed"
 msgstr "Registra todas as instruções SQL DML a medida que elas são executadas"
 
-#. Tag: literal
-#: configuration.xml:1247
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.type"
-msgstr "org.hibernate.type"
+msgid "<literal>org.hibernate.type</literal>"
+msgstr "<literal>org.hibernate.type</literal>"
 
 #. Tag: entry
-#: configuration.xml:1248
 #, no-c-format
 msgid "Log all JDBC parameters"
 msgstr "Registra todos os parâmetros JDBC"
 
-#. Tag: literal
-#: configuration.xml:1251
-#, no-c-format
-msgid "org.hibernate.tool.hbm2ddl"
-msgstr "org.hibernate.tool.hbm2ddl"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.tool.hbm2ddl</literal>"
+msgstr "<literal>org.hibernate.tool. hbm2ddl</literal>"
 
 #. Tag: entry
-#: configuration.xml:1252
 #, no-c-format
 msgid "Log all SQL DDL statements as they are executed"
 msgstr "Registra todas as instruções SQL DDL a medida que elas são executadas"
 
-#. Tag: literal
-#: configuration.xml:1255
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.pretty"
-msgstr "org.hibernate.pretty"
+msgid "<literal>org.hibernate.pretty</literal>"
+msgstr "<literal>org.hibernate.pretty</literal>"
 
 #. Tag: entry
-#: configuration.xml:1256
 #, no-c-format
 msgid ""
 "Log the state of all entities (max 20 entities) associated with the session "
 "at flush time"
 msgstr ""
-"Log the state of all entities (max 20 entities) associated with the session "
-"at flush time Registra o estado de todas as entidades (máximo 20 entidades) "
-"associadas a session no momento da limpeza (flush)."
+"Registra o estado de todas as entidades (máximo 20 entidades) associadas à "
+"sessão no momento da liberação (flush)."
 
-#. Tag: literal
-#: configuration.xml:1262
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.cache"
-msgstr "org.hibernate.cache"
+msgid "<literal>org.hibernate.cache</literal>"
+msgstr "<literal>org.hibernate.cache</literal>"
 
 #. Tag: entry
-#: configuration.xml:1263
 #, no-c-format
 msgid "Log all second-level cache activity"
 msgstr "Registra todas as atividades de cachê de segundo nível"
 
-#. Tag: literal
-#: configuration.xml:1266
-#, no-c-format
-msgid "org.hibernate.transaction"
-msgstr "org.hibernate.transaction"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.transaction</literal>"
+msgstr "<literal>org.hibernate. transaction</literal>"
 
 #. Tag: entry
-#: configuration.xml:1267
 #, no-c-format
 msgid "Log transaction related activity"
-msgstr "Registra atividades relacionada a transação"
+msgstr "Registra atividades relacionada à transação"
 
-#. Tag: literal
-#: configuration.xml:1270
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.jdbc"
-msgstr "org.hibernate.jdbc"
+msgid "<literal>org.hibernate.jdbc</literal>"
+msgstr "<literal>org.hibernate.jdbc</literal>"
 
 #. Tag: entry
-#: configuration.xml:1271
 #, no-c-format
 msgid "Log all JDBC resource acquisition"
 msgstr "Registra todas as requisições de recursos JDBC"
 
-#. Tag: literal
-#: configuration.xml:1274
-#, no-c-format
-msgid "org.hibernate.hql.ast.AST"
-msgstr "org.hibernate.hql.ast.AST"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.hql.ast.AST</literal>"
+msgstr "<literal>org.hibernate.hql. ast.AST</literal>"
 
 #. Tag: entry
-#: configuration.xml:1275
 #, no-c-format
 msgid "Log HQL and SQL ASTs during query parsing"
 msgstr "Registra instruções SQL e HQL durante a análise da consultas"
 
-#. Tag: literal
-#: configuration.xml:1280
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.secure"
-msgstr "org.hibernate.secure"
+msgid "<literal>org.hibernate.secure</literal>"
+msgstr "<literal>org.hibernate.secure</literal>"
 
 #. Tag: entry
-#: configuration.xml:1281
 #, no-c-format
 msgid "Log all JAAS authorization requests"
 msgstr "Registra todas as requisições de autorização JAAS"
 
-#. Tag: literal
-#: configuration.xml:1284
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate"
-msgstr "org.hibernate"
+msgid "<literal>org.hibernate</literal>"
+msgstr "<literal>org.hibernate</literal>"
 
 #. Tag: entry
-#: configuration.xml:1285
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Log everything. This is a lot of information but it is useful for "
 "troubleshooting"
 msgstr ""
-"Registra tudo ( uma parte das informações, mas muito útil para controle de "
-"erros )"
+"Registra tudo. Apesar de ter muita informação, é muito útil para o problema "
+"de inicialização."
 
 #. Tag: para
-#: configuration.xml:1294
 #, no-c-format
 msgid ""
 "When developing applications with Hibernate, you should almost always work "
@@ -2882,31 +2086,28 @@
 "hibernate.SQL</literal>, or, alternatively, the property <literal>hibernate."
 "show_sql</literal> enabled."
 msgstr ""
-"Quando desenvolver aplicações com Hibernate, você deve quase sempre "
-"trabalhar com debug <literal>debug</literal> para a categoria <literal>org."
-"hibernate.SQL</literal>, ou, alternativamente, a com a propriedade "
-"<literal>hibernate.show_sql</literal> habilitada."
+"Ao desenvolver aplicações com Hibernate, você deve quase sempre trabalhar "
+"com o depurador <literal>debug</literal> habilitado para a categoria "
+"<literal>org.hibernate.SQL</literal>, ou, alternativamente, com a "
+"propriedade <literal>hibernate.show_sql</literal> habilitada."
 
 #. Tag: title
-#: configuration.xml:1304
 #, no-c-format
 msgid "Implementing a <literal>NamingStrategy</literal>"
-msgstr "Implementado uma <literal>NamingStrategy</literal>"
+msgstr "Implementando um <literal>NamingStrategy</literal>"
 
 #. Tag: para
-#: configuration.xml:1306
 #, no-c-format
 msgid ""
 "The interface <literal>org.hibernate.cfg.NamingStrategy</literal> allows you "
 "to specify a \"naming standard\" for database objects and schema elements."
 msgstr ""
-"A interface <literal>org.hibernate.cfg.NamingStrategy</literal> permite você "
-"especificar um \"padrão de nomeação\" para objetos do banco de dados e "
-"elementos schema."
+"A interface <literal>org.hibernate.cfg.NamingStrategy</literal> permite que "
+"você especifique um \"padrão de nomeação\" para objetos do banco de dados e "
+"elementos de esquema."
 
 #. Tag: para
-#: configuration.xml:1311
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can provide rules for automatically generating database identifiers from "
 "Java identifiers or for processing \"logical\" column and table names given "
@@ -2917,52 +2118,37 @@
 msgstr ""
 "Você deve criar regras para a geração automaticamente de identificadores do "
 "banco de dados a partir de identificadores Java ou para processar colunas "
-"\"computadas\" e nomes de tabelas dado o arquivo de mapeamento para nomes "
-"\"físicos\" de tabelas e colunas. Esta característica ajuda a reduzir a "
-"verbosidade do documento de mapeamento, eliminando interferências repetitivas"
-"( <literal>TBL_</literal>prefixos, por exemplo). A estratégia default usada "
-"pelo Hibernate é completamente mínima."
+"\"lógicas\" e nomes de tabelas dado o arquivo de mapeamento para nomes "
+"\"físicos\" de tabelas e colunas. Este recurso ajuda a reduzir a verbosidade "
+"do documento de mapeamento, eliminando interferências repetitivas "
+"(<literal>TBL_</literal> prefixos, por exemplo). A estratégia padrão usada "
+"pelo Hibernate é bastante mínima. "
 
 #. Tag: para
-#: configuration.xml:1320
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can specify a different strategy by calling <literal>Configuration."
 "setNamingStrategy()</literal> before adding mappings:"
 msgstr ""
 "Você pode especificar uma estratégia diferente ao chamar "
 "<literal>Configuration.setNamingStrategy()</literal> antes de adicionar os "
-"mapeamentos:"
+"mapeamentos: "
 
-#. Tag: programlisting
-#: configuration.xml:1325
-#, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration()\n"
-"    .setNamingStrategy(ImprovedNamingStrategy.INSTANCE)\n"
-"    .addFile(\"Item.hbm.xml\")\n"
-"    .addFile(\"Bid.hbm.xml\")\n"
-"    .buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1327
 #, no-c-format
 msgid ""
 "<literal>org.hibernate.cfg.ImprovedNamingStrategy</literal> is a built-in "
 "strategy that might be a useful starting point for some applications."
 msgstr ""
 "<literal>org.hibernate.cfg.ImprovedNamingStrategy</literal> é uma estratégia "
-"interna que pode ser um ponto de começo útil para algumas aplicações."
+"interna que pode ser um ponto inicial útil para algumas aplicações."
 
 #. Tag: title
-#: configuration.xml:1335
 #, no-c-format
 msgid "XML configuration file"
 msgstr "Arquivo de configuração XML"
 
 #. Tag: para
-#: configuration.xml:1337
 #, no-c-format
 msgid ""
 "An alternative approach to configuration is to specify a full configuration "
@@ -2973,68 +2159,21 @@
 "Uma maneira alternativa de configuração é especificar uma configuração "
 "completa em um arquivo chamado <literal>hibernate.cfg.xml</literal>. Este "
 "arquivo pode ser usado como um substituto para o arquivo <literal>hibernate."
-"properties</literal> ou, se ambos estão presentes, sobrescrever propriedades."
+"properties</literal> ou, se ambos estiverem presentes, para substituir "
+"propriedades."
 
 #. Tag: para
-#: configuration.xml:1344
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The XML configuration file is by default expected to be in the root of your "
 "<literal>CLASSPATH</literal>. Here is an example:"
 msgstr ""
-"The XML configuration file is by default expected to be in the root o your "
-"<literal>CLASSPATH</literal>. Here is an example: O arquivo XML de "
-"configuração é por default esperado para estar na raiz do seu "
-"<literal>CLASSPATH</literal>. Veja um exemplo:"
+"O arquivo XML de configuração deve ser encontrado na raíz do seu "
+"<literal>CLASSPATH</literal>. Veja um exemplo: "
 
-#. Tag: programlisting
-#: configuration.xml:1349
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-"<!DOCTYPE hibernate-configuration PUBLIC\n"
-"    \"-//Hibernate/Hibernate Configuration DTD//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd\">\n"
-"\n"
-"<hibernate-configuration>\n"
-"\n"
-"    <!-- a SessionFactory instance listed as /jndi/name -->\n"
-"    <session-factory\n"
-"        name=\"java:hibernate/SessionFactory\">\n"
-"\n"
-"        <!-- properties -->\n"
-"        <property name=\"connection.datasource\">java:/comp/env/jdbc/MyDB</"
-"property>\n"
-"        <property name=\"dialect\">org.hibernate.dialect.MySQLDialect</"
-"property>\n"
-"        <property name=\"show_sql\">false</property>\n"
-"        <property name=\"transaction.factory_class\">\n"
-"            org.hibernate.transaction.JTATransactionFactory\n"
-"        </property>\n"
-"        <property name=\"jta.UserTransaction\">java:comp/UserTransaction</"
-"property>\n"
-"\n"
-"        <!-- mapping files -->\n"
-"        <mapping resource=\"org/hibernate/auction/Item.hbm.xml\"/>\n"
-"        <mapping resource=\"org/hibernate/auction/Bid.hbm.xml\"/>\n"
-"\n"
-"        <!-- cache settings -->\n"
-"        <class-cache class=\"org.hibernate.auction.Item\" usage=\"read-write"
-"\"/>\n"
-"        <class-cache class=\"org.hibernate.auction.Bid\" usage=\"read-only\"/"
-">\n"
-"        <collection-cache collection=\"org.hibernate.auction.Item.bids\" "
-"usage=\"read-write\"/>\n"
-"\n"
-"    </session-factory>\n"
-"\n"
-"</hibernate-configuration>]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:1351
-#, fuzzy, no-c-format
-msgid ""
 "The advantage of this approach is the externalization of the mapping file "
 "names to configuration. The <literal>hibernate.cfg.xml</literal> is also "
 "more convenient once you have to tune the Hibernate cache. It is your choice "
@@ -3046,56 +2185,35 @@
 "dos arquivos de mapeamento para configuração. O <literal>hibernate.cfg.xml</"
 "literal> também é mais conveniente caso você tenha que ajustar o cache do "
 "Hibernate. Note que a escolha é sua em usar <literal>hibernate.properties</"
-"literal> ou <literal>hibernate.cfg.xml</literal>, ambos são equivalente, à "
-"exceção dos benefícios acima mencionados de usar a sintaxe de XML."
+"literal> ou <literal>hibernate.cfg.xml</literal>, ambos são equivalentes, "
+"exceto os acima mencionados de usar a sintaxe de XML. "
 
 #. Tag: para
-#: configuration.xml:1360
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "With the XML configuration, starting Hibernate is then as simple as:"
 msgstr ""
-"Com a configuração do XML, iniciar o Hibernate é então tão simples como"
+"Com a configuração do XML, iniciar o Hibernate é então tão simples quanto: "
 
-#. Tag: programlisting
-#: configuration.xml:1364
-#, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration().configure()."
-"buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1366
-#, fuzzy, no-c-format
-msgid "You can select a different XML configuration file using:"
-msgstr "You can pick a different XML configuration file using"
-
-#. Tag: programlisting
-#: configuration.xml:1370
 #, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration()\n"
-"    .configure(\"catdb.cfg.xml\")\n"
-"    .buildSessionFactory();]]>"
+msgid "You can select a different XML configuration file using:"
 msgstr ""
+"Você poderá escolher um arquivo de configuração XML diferente, utilizando:"
 
 #. Tag: title
-#: configuration.xml:1375
 #, no-c-format
 msgid "J2EE Application Server integration"
 msgstr "Integração com servidores de aplicação J2EE"
 
 #. Tag: para
-#: configuration.xml:1377
 #, no-c-format
 msgid "Hibernate has the following integration points for J2EE infrastructure:"
 msgstr ""
-"O Hibernate tem os seguintes pontos da integração para o infraestrutura de "
+"O Hibernate tem os seguintes pontos da integração para a infraestrutura de "
 "J2EE:"
 
 #. Tag: para
-#: configuration.xml:1383
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Container-managed datasources</emphasis>: Hibernate can use JDBC "
 "connections managed by the container and provided through JNDI. Usually, a "
@@ -3110,25 +2228,24 @@
 "pode usar conexões JDBC gerenciadas pelo Container e fornecidas pela JNDI. "
 "Geralmente, um <literal>TransactionManager</literal> compatível com JTA e um "
 "<literal>ResourceManager</literal> cuidam do gerenciamento da transação "
-"( CMT ), especialmente em transações distribuídas manipuladas através de "
+"(CMT), especialmente em transações distribuídas,  manipuladas através de "
 "vários DataSources. Naturalmente, você também pode demarcar os limites das "
 "transações programaticamente (BMT) ou você poderia querer usar a API "
 "opcional do Hibernate <literal>Transaction</literal> para esta manter seu "
-"código portável."
+"código portável. "
 
 #. Tag: para
-#: configuration.xml:1398
 #, no-c-format
 msgid ""
 "<emphasis>Automatic JNDI binding</emphasis>: Hibernate can bind its "
 "<literal>SessionFactory</literal> to JNDI after startup."
 msgstr ""
-"<emphasis>Ligação (binding) automática a JNDI</emphasis>: O Hibernate pode "
-"associar sua <literal>SessionFactory</literal> a JNDI depois de iniciado."
+"<emphasis>Vinculação (binding) automática à JNDI</emphasis>: O Hibernate "
+"pode associar sua <literal>SessionFactory</literal> a JNDI depois de "
+"iniciado."
 
 #. Tag: para
-#: configuration.xml:1407
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>JTA Session binding:</emphasis> the Hibernate <literal>Session</"
 "literal> can be automatically bound to the scope of JTA transactions. Simply "
@@ -3138,17 +2255,17 @@
 "demarcation is either declarative (CMT) or programmatic (BMT/"
 "UserTransaction)."
 msgstr ""
-"<emphasis>Ligação (binding) Session na JTA:</emphasis> A <literal>Session</"
-"literal> do Hibernate pode automaticamente ser ligada ao escopo da "
-"transações JTA. Simplesmente localizando a <literal>SessionFactory</literal> "
-"da JNDI e obtendo a<literal>Session</literal> corrente. Deixe o Hibernate "
-"cuidar da limpeza e encerramento da <literal>Session</literal> quando as "
-"transações JTA terminarem. A Demarcação de transação pode ser declarativa "
-"(CMT) ou programática(BMT/Transação do usuário)."
+"<emphasis>Vinculação (binding) da Sessão na JTA:</emphasis> A "
+"<literal>Session</literal> do Hibernate pode automaticamente ser ligada ao "
+"escopo da transações JTA. Simplesmente localizando a "
+"<literal>SessionFactory</literal> da JNDI e obtendo a <literal>Session</"
+"literal> corrente. Deixe o Hibernate cuidar da liberação e encerramento da "
+"<literal>Session</literal> quando as transações JTA terminarem. A Demarcação "
+"de transação pode ser declarativa (CMT) ou programática (BMT/Transação do "
+"usuário)."
 
 #. Tag: para
-#: configuration.xml:1420
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>JMX deployment:</emphasis> if you have a JMX capable application "
 "server (e.g. JBoss AS), you can choose to deploy Hibernate as a managed "
@@ -3159,36 +2276,33 @@
 "Hibernate starts, etc)."
 msgstr ""
 "<emphasis>JMX deployment:</emphasis> Se você usa um JMX servidor de "
-"aplicações capaz (ex. Jboss AS), você pode fazer a instação do Hibernate "
-"como um Mbean controlado. Isto evita ter que iniciar uma linha de código "
+"aplicações capaz (ex. Jboss AS), você pode fazer a instalação do Hibernate "
+"como um MBean controlado. Isto evita ter que iniciar uma linha de código "
 "para construir sua <literal>SessionFactory</literal> de uma "
 "<literal>Configuration</literal>. O container iniciará seu "
-"<literal>HibernateService</literal>, e idealmente também cuidará das "
-"dependências de serviços (DataSources, têm que estar disponíveis antes do "
-"Hibernate iniciar, etc.)."
+"<literal>HibernateService</literal>, e também cuidará das dependências de "
+"serviços (DataSources, têm que estar disponíveis antes do Hibernate iniciar, "
+"etc.). "
 
 #. Tag: para
-#: configuration.xml:1431
 #, no-c-format
 msgid ""
 "Depending on your environment, you might have to set the configuration "
 "option <literal>hibernate.connection.aggressive_release</literal> to true if "
 "your application server shows \"connection containment\" exceptions."
 msgstr ""
-"Dependendo em seu ambiente, você poderia ter que ajustar a opção de "
+"Dependendo do seu ambiente, você pode ter que ajustar a opção de "
 "configuração <literal>hibernate.connection.aggressive_release</literal> para "
 "verdadeiro ( true ), se seu servidor de aplicações lançar exeções \"retenção "
-"de conecção\"."
+"de conexão\"."
 
 #. Tag: title
-#: configuration.xml:1438
 #, no-c-format
 msgid "Transaction strategy configuration"
 msgstr "Configuração de estratégia de transação"
 
 #. Tag: para
-#: configuration.xml:1440
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The Hibernate <literal>Session</literal> API is independent of any "
 "transaction demarcation system in your architecture. If you let Hibernate "
@@ -3203,10 +2317,9 @@
 "inicializar e encerrar suas transações chamando a API JDBC. Se você rodar em "
 "um servidor de aplicações J2EE, você poderá usar transações controladas por "
 "beans e chamar a API JTA e <literal>UserTransaction</literal> quando "
-"necessário."
+"necessário. "
 
 #. Tag: para
-#: configuration.xml:1448
 #, no-c-format
 msgid ""
 "To keep your code portable between these two (and other) environments we "
@@ -3216,73 +2329,66 @@
 "configuration property <literal>hibernate.transaction.factory_class</"
 "literal>."
 msgstr ""
-"Para manter seu código portável entre estes dois ( e outros ) ambientes, "
+"Para manter seu código portável entre estes dois (e outros) ambientes, "
 "recomendamos a API Hibernate <literal>Transaction</literal>, que envolve e "
-"esconde o sistema subjacente. Você tem que especificar um classe construtora "
-"para <literal>Transaction</literal> instanciar ajustando a propriedade de "
-"configuração do <literal>hibernate.transaction.factory_class</literal>."
+"esconde o sistema subjacente. Você tem que especificar uma classe "
+"construtora para instâncias <literal>Transaction</literal> ajustando a "
+"propriedade de configuração do <literal>hibernate.transaction.factory_class</"
+"literal>."
 
 #. Tag: para
-#: configuration.xml:1455
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "There are three standard, or built-in, choices:"
-msgstr "Existem três escolhas (internas) padrões:"
+msgstr "Existem três escolhas, ou internas, padrões: "
 
-#. Tag: literal
-#: configuration.xml:1461
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.JDBCTransactionFactory"
-msgstr "org.hibernate.transaction.JDBCTransactionFactory"
+msgid "<literal>org.hibernate.transaction.JDBCTransactionFactory</literal>"
+msgstr "<literal>org.hibernate.transaction.JDBCTransactionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1463
 #, no-c-format
 msgid "delegates to database (JDBC) transactions (default)"
-msgstr "delegada as transações (JDBC)a bases de dados (Padrão)"
+msgstr "delega as transações (JDBC) para bases de dados (Padrão)"
 
-#. Tag: literal
-#: configuration.xml:1467
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.JTATransactionFactory"
-msgstr "org.hibernate.transaction.JTATransactionFactory"
+msgid "<literal>org.hibernate.transaction.JTATransactionFactory</literal>"
+msgstr "<literal>org.hibernate.transaction.JTATransactionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1469
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "delegates to container-managed transactions if an existing transaction is "
 "underway in this context (for example, EJB session bean method). Otherwise, "
 "a new transaction is started and bean-managed transactions are used."
 msgstr ""
-"delegada a transação a um container gerenciador se a transação existente "
-"estiver de acordo neste contexto (ex: método bean sessão EJB), se não uma "
-"nova transação é iniciada e uma transação controlado por um bean é usada."
+"delega para uma transação à um container gerenciado se uma transação "
+"existente estiver de acordo neste contexto (ex: método bean de sessão EJB). "
+"No entanto, uma nova transação será iniciada e serão usadas transações "
+"controladas por um bean."
 
-#. Tag: literal
-#: configuration.xml:1477
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.CMTTransactionFactory"
-msgstr "org.hibernate.transaction.CMTTransactionFactory"
+msgid "<literal>org.hibernate.transaction.CMTTransactionFactory</literal>"
+msgstr "<literal>org.hibernate.transaction.CMTTransactionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1479
 #, no-c-format
 msgid "delegates to container-managed JTA transactions"
 msgstr "delega para um container gerenciador de transações JTA"
 
 #. Tag: para
-#: configuration.xml:1484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also define your own transaction strategies (for a CORBA transaction "
 "service, for example)."
 msgstr ""
-"Você também pode definir suas próprias estratégias de transação ( para um "
-"serviço de transação CORBA por exemplo)."
+"Você também pode definir suas próprias estratégias de transação (para um "
+"serviço de transação CORBA, por exemplo)."
 
 #. Tag: para
-#: configuration.xml:1489
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Some features in Hibernate (i.e., the second level cache, Contextual "
 "Sessions with JTA, etc.) require access to the JTA "
@@ -3296,169 +2402,168 @@
 "<literal>TransactionManager</literal> em um ambiente controlado. Em um "
 "servidor de aplicação você tem que especificar como o Hibernate pode obter "
 "uma referência para a <literal>TransactionManager</literal>, pois o J2EE não "
-"padronize um mecanismo simples :"
+"padroniza um mecanismo simples:"
 
 #. Tag: title
-#: configuration.xml:1497
 #, no-c-format
 msgid "JTA TransactionManagers"
 msgstr "Gerenciadores de transações JTA"
 
 #. Tag: entry
-#: configuration.xml:1503
 #, no-c-format
 msgid "Transaction Factory"
-msgstr "Transaction Factory"
+msgstr "Factory de Transação"
 
 #. Tag: entry
-#: configuration.xml:1504
 #, no-c-format
 msgid "Application Server"
-msgstr "Application Server"
+msgstr "Servidor de Aplicação"
 
-#. Tag: literal
-#: configuration.xml:1509
-#, no-c-format
-msgid "org.hibernate.transaction.JBossTransactionManagerLookup"
-msgstr "org.hibernate.transaction.JBossTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JBossTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JBossTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1510
 #, no-c-format
 msgid "JBoss"
 msgstr "JBoss"
 
-#. Tag: literal
-#: configuration.xml:1513
-#, no-c-format
-msgid "org.hibernate.transaction.WeblogicTransactionManagerLookup"
-msgstr "org.hibernate.transaction.WeblogicTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WeblogicTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. WeblogicTransactionManagerLookup</"
+"literal>"
 
 #. Tag: entry
-#: configuration.xml:1514
 #, no-c-format
 msgid "Weblogic"
 msgstr "Weblogic"
 
-#. Tag: literal
-#: configuration.xml:1517
-#, no-c-format
-msgid "org.hibernate.transaction.WebSphereTransactionManagerLookup"
-msgstr "org.hibernate.transaction.WebSphereTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WebSphereTransactionManagerLookup</"
+"literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. WebSphereTransactionManagerLookup</"
+"literal>"
 
 #. Tag: entry
-#: configuration.xml:1518
 #, no-c-format
 msgid "WebSphere"
 msgstr "WebSphere"
 
-#. Tag: literal
-#: configuration.xml:1521
-#, no-c-format
-msgid "org.hibernate.transaction.WebSphereExtendedJTATransactionLookup"
-msgstr "org.hibernate.transaction.WebSphereExtendedJTATransactionLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WebSphereExtendedJTATransactionLookup</"
+"literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. WebSphereExtendedJTATransactionLookup</"
+"literal>"
 
 #. Tag: entry
-#: configuration.xml:1522
 #, no-c-format
 msgid "WebSphere 6"
 msgstr "WebSphere 6"
 
-#. Tag: literal
-#: configuration.xml:1525
-#, no-c-format
-msgid "org.hibernate.transaction.OrionTransactionManagerLookup"
-msgstr "org.hibernate.transaction.OrionTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.OrionTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. OrionTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1526
 #, no-c-format
 msgid "Orion"
 msgstr "Orion"
 
-#. Tag: literal
-#: configuration.xml:1529
-#, no-c-format
-msgid "org.hibernate.transaction.ResinTransactionManagerLookup"
-msgstr "org.hibernate.transaction.ResinTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.ResinTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. ResinTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1530
 #, no-c-format
 msgid "Resin"
 msgstr "Resin"
 
-#. Tag: literal
-#: configuration.xml:1533
-#, no-c-format
-msgid "org.hibernate.transaction.JOTMTransactionManagerLookup"
-msgstr "org.hibernate.transaction.JOTMTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JOTMTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JOTMTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1534
 #, no-c-format
 msgid "JOTM"
 msgstr "JOTM"
 
-#. Tag: literal
-#: configuration.xml:1537
-#, no-c-format
-msgid "org.hibernate.transaction.JOnASTransactionManagerLookup"
-msgstr "org.hibernate.transaction.JOnASTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JOnASTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JOnASTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1538
 #, no-c-format
 msgid "JOnAS"
 msgstr "JOnAS"
 
-#. Tag: literal
-#: configuration.xml:1541
-#, no-c-format
-msgid "org.hibernate.transaction.JRun4TransactionManagerLookup"
-msgstr "org.hibernate.transaction.JRun4TransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JRun4TransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JRun4TransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1542
 #, no-c-format
 msgid "JRun4"
 msgstr "JRun4"
 
-#. Tag: literal
-#: configuration.xml:1545
-#, no-c-format
-msgid "org.hibernate.transaction.BESTransactionManagerLookup"
-msgstr "org.hibernate.transaction.BESTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.BESTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. BESTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1546
 #, no-c-format
 msgid "Borland ES"
 msgstr "Borland ES"
 
 #. Tag: title
-#: configuration.xml:1555
 #, no-c-format
 msgid "JNDI-bound <literal>SessionFactory</literal>"
-msgstr "<literal>SessionFactory</literal> ligada a JNDI"
+msgstr "<literal>SessionFactory</literal> vinculada à JNDI"
 
 #. Tag: para
-#: configuration.xml:1557
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A JNDI-bound Hibernate <literal>SessionFactory</literal> can simplify the "
 "lookup function of the factory and create new <literal>Session</literal>s. "
 "This is not, however, related to a JNDI bound <literal>Datasource</literal>; "
 "both simply use the same registry."
 msgstr ""
-"Uma <literal>SessionFactory</literal> de Hibernate ligada a JNDI pode "
-"simplificar a localização da fabrica e a criação de novas <literal>Session</"
-"literal>s. Observe que isto não relacionado a um <literal>Datasource</"
-"literal> ligado a JNDI, simplemente ambos usam o mesmo registro!"
+"Uma <literal>SessionFactory</literal> de Hibernate vinculada à JNDI pode "
+"simplificar a localização da fábrica e a criação de novas <literal>Session</"
+"literal>s. Observe que isto não está relacionado a um <literal>Datasource</"
+"literal> ligado a JNDI, simplesmente ambos usam o mesmo registro."
 
 #. Tag: para
-#: configuration.xml:1564
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you wish to have the <literal>SessionFactory</literal> bound to a JNDI "
 "namespace, specify a name (e.g. <literal>java:hibernate/SessionFactory</"
@@ -3467,15 +2572,15 @@
 "will not be bound to JNDI. This is especially useful in environments with a "
 "read-only JNDI default implementation (in Tomcat, for example)."
 msgstr ""
-"If you wish to have the <literal>SessionFactory</literal> bound to a JNDI "
-"namespace, specify a name (eg. <literal>java:hibernate/SessionFactory</"
-"literal>) using the property <literal>hibernate.session_factory_name</"
-"literal>. If this property is omitted, the <literal>SessionFactory</literal> "
-"will not be bound to JNDI. (This is especially useful in environments with a "
-"read-only JNDI default implementation, e.g. Tomcat.)"
+"Se você desejar ter uma <literal>SessionFactory</literal> limitada a um nome "
+"de espaço de JNDI, especifique um nome (ex.: <literal>java:hibernate/"
+"SessionFactory</literal>) usando a propriedade <literal>hibernate."
+"session_factory_name</literal>. Se esta propriedade for omitida, a "
+"<literal>SessionFactory</literal> não será limitada ao JNDI. Isto é muito "
+"útil em ambientes com uma implementação padrão JNDI de somente leitura (ex.: "
+"Tomcat)."
 
 #. Tag: para
-#: configuration.xml:1572
 #, no-c-format
 msgid ""
 "When binding the <literal>SessionFactory</literal> to JNDI, Hibernate will "
@@ -3483,14 +2588,14 @@
 "jndi.class</literal> to instantiate an initial context. If they are not "
 "specified, the default <literal>InitialContext</literal> will be used."
 msgstr ""
-"When binding the <literal>SessionFactory</literal> to JNDI, Hibernate will "
-"use the values of <literal>hibernate.jndi.url</literal>, <literal>hibernate."
-"jndi.class</literal> to instantiate an initial context. If they are not "
-"specified, the default <literal>InitialContext</literal> will be used."
+"Ao vincular a <literal>SessionFactory</literal> ao JNDI, o Hibernate irá "
+"utilizar os valores de <literal>hibernate.jndi.url</literal>, "
+"<literal>hibernate.jndi.class</literal> para instanciar um contexto inicial. "
+"Se eles não forem especificados, será usado o padrão "
+"<literal>InitialContext</literal>."
 
 #. Tag: para
-#: configuration.xml:1579
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will automatically place the <literal>SessionFactory</literal> in "
 "JNDI after you call <literal>cfg.buildSessionFactory()</literal>. This means "
@@ -3499,26 +2604,26 @@
 "<literal>HibernateService</literal> (this is discussed later in greater "
 "detail)."
 msgstr ""
-"Hibernate will automatically place the <literal>SessionFactory</literal> in "
-"JNDI after you call <literal>cfg.buildSessionFactory()</literal>. This means "
-"you will at least have this call in some startup code (or utility class) in "
-"your application, unless you use JMX deployment with the "
-"<literal>HibernateService</literal> (discussed later)."
+"O Hibernate colocará automaticamente a <literal>SessionFactory</literal> no "
+"JNDI depois que você chamar a <literal>cfg.buildSessionFactory()</literal>. "
+"Isto significa que você terá esta chamada em pelo menos algum código de "
+"inicialização (ou classe de utilidade) em seu aplicativo, a não ser que você "
+"use a implementação JMX com o <literal>HibernateService</literal> (discutido "
+"mais tarde). "
 
 #. Tag: para
-#: configuration.xml:1586
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you use a JNDI <literal>SessionFactory</literal>, an EJB or any other "
 "class, you can obtain the <literal>SessionFactory</literal> using a JNDI "
 "lookup."
 msgstr ""
-"If you use a JNDI <literal>SessionFactory</literal>, an EJB or any other "
-"class may obtain the <literal>SessionFactory</literal> using a JNDI lookup."
+"Se você usar um JNDI <literal>SessionFactory</literal>, o EJB ou qualquer "
+"outra classe obterá a <literal>SessionFactory</literal> utilizando um "
+"localizador JNDI."
 
 #. Tag: para
-#: configuration.xml:1591
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you bind the <literal>SessionFactory</literal> to "
 "JNDI in a managed environment and use a <literal>static</literal> singleton "
@@ -3528,32 +2633,30 @@
 "()</literal>. Note that such a class is also a convenient way to startup "
 "Hibernate&mdash;see chapter 1."
 msgstr ""
-"We recommend that you bind the <literal>SessionFactory</literal> to JNDI in "
-"a managend environment and use a <literal>static</literal> singleton "
-"otherwise. To shield your application code from these details, we also "
-"recommend to hide the actual lookup code for a <literal>SessionFactory</"
-"literal> in a helper class, such as <literal>HibernateUtil.getSessionFactory"
-"()</literal>. Note that such a class is also a convenient way to startup "
-"Hibernate&mdash;see chapter 1."
+"Recomendamos que você vincule a <literal>SessionFactory</literal> ao JNDI em "
+"um ambiente gerenciado e utilize um singleton <literal>static</literal>. "
+"Para proteger seu código de aplicativo destes detalhes, também recomendamos "
+"que esconda o código de localização atual para uma <literal>SessionFactory</"
+"literal> em uma classe de ajuda, assim como o <literal>HibernateUtil."
+"getSessionFactory()</literal>. Note que tal classe é também uma forma "
+"bastante conveniente de inicializar o Hibernate&mdash; veja o capítulo 1."
 
 #. Tag: title
-#: configuration.xml:1603
 #, no-c-format
 msgid "Current Session context management with JTA"
-msgstr "Current Session context management with JTA"
+msgstr "Gerenciamento de contexto de Sessão atual com JTA"
 
 #. Tag: para
-#: configuration.xml:1605
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The easiest way to handle <literal>Sessions</literal> and transactions is "
 "Hibernate's automatic \"current\" <literal>Session</literal> management. For "
-"a discussion of contextual sessions see <link linkend=\"architecture-current-"
-"session\"></link>. Using the <literal>\"jta\"</literal> session context, if "
-"there is no Hibernate <literal>Session</literal> associated with the current "
-"JTA transaction, one will be started and associated with that JTA "
-"transaction the first time you call <literal>sessionFactory.getCurrentSession"
-"()</literal>. The <literal>Session</literal>s retrieved via "
+"a discussion of contextual sessions see <xref linkend=\"architecture-current-"
+"session\" />. Using the <literal>\"jta\"</literal> session context, if there "
+"is no Hibernate <literal>Session</literal> associated with the current JTA "
+"transaction, one will be started and associated with that JTA transaction "
+"the first time you call <literal>sessionFactory.getCurrentSession()</"
+"literal>. The <literal>Session</literal>s retrieved via "
 "<literal>getCurrentSession()</literal> in the<literal>\"jta\"</literal> "
 "context are set to automatically flush before the transaction completes, "
 "close after the transaction completes, and aggressively release JDBC "
@@ -3566,34 +2669,33 @@
 "in an EJB container, declarative transaction demarcation with CMT is "
 "preferred."
 msgstr ""
-"The easiest way to handle <literal>Session</literal>s and transactions is "
-"Hibernates automatic \"current\" <literal>Session</literal> management. See "
-"the discussion of <xref linkend=\"architecture-current-session\">current "
-"sessions</xref>. Using the <literal>\"jta\"</literal> session context, if "
-"there is no Hibernate <literal>Session</literal> associated with the current "
-"JTA transaction, one will be started and associated with that JTA "
-"transaction the first time you call <literal>sessionFactory.getCurrentSession"
-"()</literal>. The <literal>Session</literal>s retrieved via "
-"<literal>getCurrentSession()</literal> in <literal>\"jta\"</literal> context "
-"will be set to automatically flush before the transaction completes, close "
-"after the transaction completes, and aggressively release JDBC connections "
-"after each statement. This allows the <literal>Session</literal>s to be "
-"managed by the life cycle of the JTA transaction to which it is associated, "
-"keeping user code clean of such management concerns. Your code can either "
-"use JTA programmatically through <literal>UserTransaction</literal>, or "
-"(recommended for portable code) use the Hibernate <literal>Transaction</"
-"literal> API to set transaction boundaries. If you run in an EJB container, "
-"declarative transaction demarcation with CMT is preferred."
+"A maneira mais fácil de manusear as <literal>Session</literal> e transações "
+"é com o gerenciamento automático do Hibernates \"atual\" <literal>Session</"
+"literal>. Veja a discussão do <xref linkend=\"architecture-current-session\"/"
+">. Utilizando o contexto da sessão <literal>\"jta\"</literal>, caso não haja "
+"uma <literal>Session</literal> do Hibernate associada com a transação atual "
+"do JTA, uma será iniciada e associada à transação JTA na primeira vez que "
+"você chamar a <literal>sessionFactory.getCurrentSession()</literal>. As "
+"<literal>Session</literal>s recuperadas através do contexto "
+"<literal>getCurrentSession()</literal> em <literal>\"jta\"</literal> serão "
+"ajustadas para liberar automaticamente antes que a transação se complete, e "
+"fechada após a transação se complete e liberar instantaneamente as conexões "
+"JDBC após cada instrução. Isto permitirá que as <literal>Session</literal>s "
+"sejam gerenciadas pelo ciclo de vida da transação JTA para as quais estão "
+"associadas, mantendo o código do usuário limpo de tais preocupações de "
+"gerenciamento. Seu código pode tanto utilizar um JTA programaticamente "
+"através do <literal>UserTransaction</literal>, ou (recomendado para códigos "
+"portáveis) use o API <literal>Transaction</literal> do Hibernate para "
+"ajustar as limitações das transações. Se você rodar em um recipiente EJB, "
+"prefira uma demarcação de transação declarativa com CMT. "
 
 #. Tag: title
-#: configuration.xml:1628
 #, no-c-format
 msgid "JMX deployment"
-msgstr "JMX deployment"
+msgstr "implementação JMX "
 
 #. Tag: para
-#: configuration.xml:1630
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The line <literal>cfg.buildSessionFactory()</literal> still has to be "
 "executed somewhere to get a <literal>SessionFactory</literal> into JNDI. You "
@@ -3601,81 +2703,30 @@
 "the one in <literal>HibernateUtil</literal>, or you can deploy Hibernate as "
 "a <emphasis>managed service</emphasis>."
 msgstr ""
-"The line <literal>cfg.buildSessionFactory()</literal> still has to be "
-"executed somewhere to get a <literal>SessionFactory</literal> into JNDI. You "
-"can do this either in a <literal>static</literal> initializer block (like "
-"the one in <literal>HibernateUtil</literal>) or you deploy Hibernate as a "
-"<emphasis>managed service</emphasis>."
+"A linha <literal>cfg.buildSessionFactory()</literal> ainda precisa ser "
+"executada em algum local para conseguir uma <literal>SessionFactory</"
+"literal> em JNDI. Você pode escolher fazer isto em um bloqueio de "
+"inicializador <literal>static</literal>, como aquele em "
+"<literal>HibernateUtil</literal>, ou implementar o Hibernate como "
+"<emphasis>serviço gerenciado</emphasis>."
 
 #. Tag: para
-#: configuration.xml:1638
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate is distributed with <literal>org.hibernate.jmx.HibernateService</"
 "literal> for deployment on an application server with JMX capabilities, such "
 "as JBoss AS. The actual deployment and configuration is vendor-specific. "
 "Here is an example <literal>jboss-service.xml</literal> for JBoss 4.0.x:"
 msgstr ""
-"Hibernate is distributed with <literal>org.hibernate.jmx.HibernateService</"
-"literal> for deployment on an application server with JMX capabilities, such "
-"as JBoss AS. The actual deployment and configuration is vendor specific. "
-"Here is an example <literal>jboss-service.xml</literal> for JBoss 4.0.x:"
+"O Hibernate é distribuído com o <literal>org.hibernate.jmx.HibernateService</"
+"literal> para implementação em um servidor de aplicativo com capacidades "
+"JMX, tal como o JBoss AS. A implementação atual e configuração é comercial. "
+"Segue aqui um exemplo do <literal>jboss-service.xml</literal> para o JBoss "
+"4.0.x:"
 
-#. Tag: programlisting
-#: configuration.xml:1645
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<server>\n"
-"\n"
-"<mbean code=\"org.hibernate.jmx.HibernateService\"\n"
-"    name=\"jboss.jca:service=HibernateFactory,name=HibernateFactory\">\n"
-"\n"
-"    <!-- Required services -->\n"
-"    <depends>jboss.jca:service=RARDeployer</depends>\n"
-"    <depends>jboss.jca:service=LocalTxCM,name=HsqlDS</depends>\n"
-"\n"
-"    <!-- Bind the Hibernate service to JNDI -->\n"
-"    <attribute name=\"JndiName\">java:/hibernate/SessionFactory</attribute>\n"
-"\n"
-"    <!-- Datasource settings -->\n"
-"    <attribute name=\"Datasource\">java:HsqlDS</attribute>\n"
-"    <attribute name=\"Dialect\">org.hibernate.dialect.HSQLDialect</"
-"attribute>\n"
-"\n"
-"    <!-- Transaction integration -->\n"
-"    <attribute name=\"TransactionStrategy\">\n"
-"        org.hibernate.transaction.JTATransactionFactory</attribute>\n"
-"    <attribute name=\"TransactionManagerLookupStrategy\">\n"
-"        org.hibernate.transaction.JBossTransactionManagerLookup</attribute>\n"
-"    <attribute name=\"FlushBeforeCompletionEnabled\">true</attribute>\n"
-"    <attribute name=\"AutoCloseSessionEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Fetching options -->\n"
-"    <attribute name=\"MaximumFetchDepth\">5</attribute>\n"
-"\n"
-"    <!-- Second-level caching -->\n"
-"    <attribute name=\"SecondLevelCacheEnabled\">true</attribute>\n"
-"    <attribute name=\"CacheProviderClass\">org.hibernate.cache."
-"EhCacheProvider</attribute>\n"
-"    <attribute name=\"QueryCacheEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Logging -->\n"
-"    <attribute name=\"ShowSqlEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Mapping files -->\n"
-"    <attribute name=\"MapResources\">auction/Item.hbm.xml,auction/Category."
-"hbm.xml</attribute>\n"
-"\n"
-"</mbean>\n"
-"\n"
-"</server>]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:1647
-#, fuzzy, no-c-format
-msgid ""
 "This file is deployed in a directory called <literal>META-INF</literal> and "
 "packaged in a JAR file with the extension <literal>.sar</literal> (service "
 "archive). You also need to package Hibernate, its required third-party "
@@ -3686,258 +2737,13 @@
 "JBoss AS documentation for more information about JMX service and EJB "
 "deployment."
 msgstr ""
-"This file is deployed in a directory called <literal>META-INF</literal> and "
-"packaged in a JAR file with the extension <literal>.sar</literal> (service "
-"archive). You also need to package Hibernate, its required third-party "
-"libraries, your compiled persistent classes, as well as your mapping files "
-"in the same archive. Your enterprise beans (usually session beans) may be "
-"kept in their own JAR file, but you may include this EJB JAR file in the "
-"main service archive to get a single (hot-)deployable unit. Consult the "
-"JBoss AS documentation for more information about JMX service and EJB "
-"deployment."
-
-#~ msgid ""
-#~ "<literal>hibernate.properties</literal> is the easiest approach if you "
-#~ "want to get started quickly."
-#~ msgstr ""
-#~ "<literal>hibernate.properties</literal> é o caminho mais facil se você "
-#~ "quer começar mais rápido."
-
-#~ msgid "Hibernate logs various events using Apache commons-logging."
-#~ msgstr "Hibernate registra vários eventos usando Apache commons-logging."
-
-#~ msgid ""
-#~ "The commons-logging service will direct output to either Apache Log4j (if "
-#~ "you include <literal>log4j.jar</literal> in your classpath) or JDK1.4 "
-#~ "logging (if running under JDK1.4 or above). You may download Log4j from "
-#~ "<literal>http://jakarta.apache.org</literal>. To use Log4j you will need "
-#~ "to place a <literal>log4j.properties</literal> file in your classpath, an "
-#~ "example properties file is distributed with Hibernate in the <literal>src/"
-#~ "</literal> directory."
-#~ msgstr ""
-#~ "O serviço commons-logging direcionará a saída para o Apache Log4j ( se "
-#~ "você incluir <literal>log4j.jar</literal>r no seu classpath) ou JDK1.4 "
-#~ "logging( se estiver em uso JDK1.4 ou maior). Você pode fazer o download "
-#~ "do Log4j a partir de <literal>http://jakarta.apache.org</literal>. Para "
-#~ "usar Log4j você necessitará colocar um arquivo <literal>log4j.properties</"
-#~ "literal> no seu classpath, um exemplo de arquivo de propriedades é "
-#~ "distribuído com o Hibernate no diretório <literal>src/</literal>."
-
-#~ msgid "<placeholder-1/> (optional)"
-#~ msgstr "<placeholder-1/> (opcional)"
-
-#~ msgid "InitialContextFactory"
-#~ msgstr "InitialContextFactory"
-
-#~ msgid "class of the JNDI <placeholder-1/>"
-#~ msgstr "Classe do JNDI <placeholder-1/>"
-
-#, fuzzy
-#~ msgid "eg."
-#~ msgstr ""
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "Ex.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "eg."
-
-#~ msgid "full.classname.of.Dialect"
-#~ msgstr "full.classname.of.Dialect"
-
-#~ msgid "debug"
-#~ msgstr "debug"
-
-#~ msgid "SCHEMA_NAME"
-#~ msgstr "SCHEMA_NAME"
-
-#~ msgid "CATALOG_NAME"
-#~ msgstr "CATALOG_NAME"
-
-#, fuzzy
-#~ msgid "SessionFactory"
-#~ msgstr ""
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "SessionFactory\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "SessionFactory\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "SessionFactory\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "create-drop"
-
-#~ msgid "jndi/composite/name"
-#~ msgstr "jndi/composite/name"
-
-#~ msgid "0"
-#~ msgstr "0"
-
-#~ msgid "false"
-#~ msgstr "false"
-
-#~ msgid "Statement.setFetchSize()"
-#~ msgstr "Statement.setFetchSize()"
-
-#~ msgid "true"
-#~ msgstr "true"
-
-#~ msgid "executeBatch()"
-#~ msgstr "executeBatch()"
-
-#~ msgid "Batcher"
-#~ msgstr "Batcher"
-
-#~ msgid "classname.of.BatcherFactory"
-#~ msgstr "classname.of.BatcherFactory"
-
-#~ msgid "binary"
-#~ msgstr "binary"
-
-#~ msgid "serializable"
-#~ msgstr "serializable"
-
-#~ msgid "PreparedStatement.getGeneratedKeys()"
-#~ msgstr "PreparedStatement.getGeneratedKeys()"
-
-#~ msgid "true|false"
-#~ msgstr "true|false"
-
-#~ msgid "ConnectionProvider"
-#~ msgstr "ConnectionProvider"
-
-#~ msgid "classname.of.ConnectionProvider"
-#~ msgstr "classname.of.ConnectionProvider"
-
-#~ msgid "java.sql.Connection"
-#~ msgstr "java.sql.Connection"
-
-#~ msgid "1, 2, 4, 8"
-#~ msgstr "1, 2, 4, 8"
-
-#~ msgid "after_statement"
-#~ msgstr "after_statement"
-
-#~ msgid "after_transaction"
-#~ msgstr "after_transaction"
-
-#~ msgid "auto"
-#~ msgstr "auto"
-
-#~ msgid "hibernate.connection."
-#~ msgstr "&lt;propertyName&gt;"
-
-#, fuzzy
-#~ msgid "&lt;propertyName&gt;"
-#~ msgstr ""
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "hibernate.connection.<placeholder-1/>\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "propertyName\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "hibernate.jndi.<placeholder-1/>\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "propertyName"
-
-#~ msgid "DriverManager.getConnection()"
-#~ msgstr "DriverManager.getConnection()"
-
-#~ msgid "Pass the JDBC property <placeholder-1/> to <placeholder-2/>."
-#~ msgstr "Passa a propriedade JDBC <placeholder-1/> para <placeholder-2/>."
-
-#~ msgid "hibernate.jndi."
-#~ msgstr "&lt;propertyName&gt;"
-
-#~ msgid "Pass the property <placeholder-1/> to the JNDI <placeholder-2/>."
-#~ msgstr "Passar a propriedade <placeholder-1/> para o <placeholder-2/> JNDI."
-
-#~ msgid "CacheProvider"
-#~ msgstr "CacheProvider"
-
-#~ msgid "classname.of.CacheProvider"
-#~ msgstr "classname.of.CacheProvider"
-
-#~ msgid "&lt;cache&gt;"
-#~ msgstr "&lt;cache&gt;"
-
-#~ msgid "QueryCache"
-#~ msgstr "QueryCache"
-
-#~ msgid "StandardQueryCache"
-#~ msgstr "StandardQueryCache"
-
-#~ msgid "classname.of.QueryCache"
-#~ msgstr "classname.of.QueryCache"
-
-#~ msgid "prefix"
-#~ msgstr "prefix"
-
-#~ msgid "TransactionFactory"
-#~ msgstr "TransactionFactory"
-
-#~ msgid "Transaction"
-#~ msgstr "Transaction"
-
-#~ msgid "JDBCTransactionFactory"
-#~ msgstr "JDBCTransactionFactory"
-
-#~ msgid "classname.of.TransactionFactory"
-#~ msgstr "classname.of.TransactionFactory"
-
-#~ msgid "JTATransactionFactory"
-#~ msgstr "JTATransactionFactory"
-
-#~ msgid "UserTransaction"
-#~ msgstr "UserTransaction"
-
-#~ msgid "TransactionManagerLookup"
-#~ msgstr "TransactionManagerLookup"
-
-#~ msgid "classname.of.TransactionManagerLookup"
-#~ msgstr "classname.of.TransactionManagerLookup"
-
-#~ msgid "Session"
-#~ msgstr "Session"
-
-#~ msgid "hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC"
-#~ msgstr "hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC"
-
-#~ msgid "create-drop"
-#~ msgstr "create-drop"
-
-#~ msgid "hibernate.cfg.xml"
-#~ msgstr "hibernate.cfg.xml"
-
-#~ msgid "DB2"
-#~ msgstr "DB2"
+"Este arquivo é implementado em um diretório chamado <literal>META-INF</"
+"literal> e envolto em um arquivo JAR com a extensão <literal>.sar</literal> "
+"(arquivo de serviço). Você também pode precisar envolver o Hibernate, suas "
+"bibliotecas de terceiros solicitadas, suas classes persistentes compiladas, "
+"assim como seus arquivos de mapeamento no mesmo arquivo. Seus beans de "
+"empresa (geralmente beans de sessão) podem ser mantidos em seus próprios "
+"arquivos JAR, mas você poderá incluir estes arquivos EJB JAR no arquivo de "
+"serviço principal para conseguir uma única unidade de (hot)-deployable. "
+"Consulte a documentação do JBoss AS para maiores informações sobre o serviço "
+"JMX e implementação EJB.  "

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/events.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/events.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/events.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,43 +1,145 @@
+# translation of events.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: events\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2009-10-28 16:51+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: events.xml:29
 #, no-c-format
 msgid "Interceptors and events"
 msgstr "Interceptadores e Eventos"
 
 #. Tag: para
-#: events.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is useful for the application to react to certain events that occur "
 "inside Hibernate. This allows for the implementation of generic "
 "functionality and the extension of Hibernate functionality."
 msgstr ""
-"É muito útil quando a aplicação precisa executar alguma \"coisa\" no momento "
-"em que o Hibernate executa uma de suas ações. Isso permite a implementação "
-"de certas funções genéricas, assim como permite estender as funcionalidades "
-"do Hibernate"
+"É muito útil quando a aplicação precisa reagir a certos eventos que ocorrem "
+"dentro do Hibernate. Isso permite a implementação de certas funções "
+"genéricas, assim como permite estender as funcionalidades do Hibernate."
 
 #. Tag: title
-#: events.xml:38
 #, no-c-format
 msgid "Interceptors"
 msgstr "Interceptadores"
 
 #. Tag: para
-#: events.xml:40
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>Interceptor</literal> interface provides callbacks from the "
 "session to the application, allowing the application to inspect and/or "
@@ -50,146 +152,46 @@
 "literal> is updated."
 msgstr ""
 "A interface <literal>Interceptor</literal> permite fornecer informações da "
-"session para o aplicativo, permitindo ao aplicativo inspecionar e/ou "
-"manipular as propriedades de um objeto persistente antes de ser salvo, "
-"atualizado, excluído ou salvo. Um dos possíveis usos é gerar informações de "
-"auditoria. Por exemplo, o seguinte <literal>Interceptor</literal> seta "
-"automaticamente o atributo <literal>createTimestamp</literal> quando um "
-"<literal>Auditable</literal> é criada e atualiza o atributo "
+"sessão para o aplicativo, permitindo que o aplicativo inspecione e/ou "
+"manipule as propriedades de um objeto persistente antes de ser salvo, "
+"atualizado, excluído ou salvo. Pode ser usado para gerar informações de "
+"auditoria. Por exemplo, o seguinte <literal>Interceptor</literal> ajusta a "
+"função automaticamente <literal>createTimestamp</literal> quando um "
+"<literal>Auditable</literal> é criado e atualiza a função "
 "<literal>lastUpdateTimestamp</literal> quando um <literal>Auditable</"
-"literal> é atualizado."
+"literal> é atualizado. "
 
 #. Tag: para
-#: events.xml:51
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can either implement <literal>Interceptor</literal> directly or extend "
 "<literal>EmptyInterceptor</literal>."
 msgstr ""
-"Você pode implementar <literal>Auditable</literal> diretamente ou pode "
-"estender <literal>EmptyInterceptor</literal>, sendo que a segunda é "
-"considerada a melhor opção."
+"Você pode implementar <literal>Interceptor</literal> diretamente ou pode "
+"estender <literal>EmptyInterceptor</literal>."
 
-#. Tag: programlisting
-#: events.xml:56
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[package org.hibernate.test;\n"
-"\n"
-"import java.io.Serializable;\n"
-"import java.util.Date;\n"
-"import java.util.Iterator;\n"
-"\n"
-"import org.hibernate.EmptyInterceptor;\n"
-"import org.hibernate.Transaction;\n"
-"import org.hibernate.type.Type;\n"
-"\n"
-"public class AuditInterceptor extends EmptyInterceptor {\n"
-"\n"
-"    private int updates;\n"
-"    private int creates;\n"
-"    private int loads;\n"
-"\n"
-"    public void onDelete(Object entity,\n"
-"                         Serializable id,\n"
-"                         Object[] state,\n"
-"                         String[] propertyNames,\n"
-"                         Type[] types) {\n"
-"        // do nothing\n"
-"    }\n"
-"\n"
-"    public boolean onFlushDirty(Object entity,\n"
-"                                Serializable id,\n"
-"                                Object[] currentState,\n"
-"                                Object[] previousState,\n"
-"                                String[] propertyNames,\n"
-"                                Type[] types) {\n"
-"\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            updates++;\n"
-"            for ( int i=0; i < propertyNames.length; i++ ) {\n"
-"                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) {\n"
-"                    currentState[i] = new Date();\n"
-"                    return true;\n"
-"                }\n"
-"            }\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public boolean onLoad(Object entity,\n"
-"                          Serializable id,\n"
-"                          Object[] state,\n"
-"                          String[] propertyNames,\n"
-"                          Type[] types) {\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            loads++;\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public boolean onSave(Object entity,\n"
-"                          Serializable id,\n"
-"                          Object[] state,\n"
-"                          String[] propertyNames,\n"
-"                          Type[] types) {\n"
-"\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            creates++;\n"
-"            for ( int i=0; i<propertyNames.length; i++ ) {\n"
-"                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
-"                    state[i] = new Date();\n"
-"                    return true;\n"
-"                }\n"
-"            }\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public void afterTransactionCompletion(Transaction tx) {\n"
-"        if ( tx.wasCommitted() ) {\n"
-"            System.out.println(\"Creations: \" + creates + \", Updates: \" + "
-"updates, \"Loads: \" + loads);\n"
-"        }\n"
-"        updates=0;\n"
-"        creates=0;\n"
-"        loads=0;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:58
-#, fuzzy, no-c-format
-msgid ""
 "There are two kinds of inteceptors: <literal>Session</literal>-scoped and "
 "<literal>SessionFactory</literal>-scoped."
 msgstr ""
-"Os interceptadores podem ser aplicados em dois diferentes escopos: No escopo "
-"da <literal>Session</literal> e no escopo <literal>SessionFactory</literal>."
+"Os interceptadores se apresentam de duas formas: <literal>Session</literal>-"
+"scoped e <literal>SessionFactory</literal>-scoped."
 
 #. Tag: para
-#: events.xml:63
 #, no-c-format
 msgid ""
 "A <literal>Session</literal>-scoped interceptor is specified when a session "
 "is opened using one of the overloaded SessionFactory.openSession() methods "
 "accepting an <literal>Interceptor</literal>."
 msgstr ""
-"Um interceptador no escopo da <literal>Session</literal> é definido quando "
+"Um interceptador delimitado da <literal>Session</literal>, é definido quando "
 "uma sessão é aberta usando o método sobrecarregado da SessionFactory."
 "openSession() que aceita um <literal>Interceptor</literal> como parâmetro."
 
-#. Tag: programlisting
-#: events.xml:69
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:71
-#, fuzzy, no-c-format
 msgid ""
 "A <literal>SessionFactory</literal>-scoped interceptor is registered with "
 "the <literal>Configuration</literal> object prior to building the "
@@ -200,46 +202,35 @@
 "Ensure that you do not store session-specific states, since multiple "
 "sessions will use this interceptor potentially concurrently."
 msgstr ""
-"Um interceptador no escopo da <literal>SessionFactory</literal> é definido "
-"no objeto <literal>Configuration</literal> antes da <literal>SessionFactory</"
+"Um interceptador da <literal>SessionFactory</literal>-scoped é definido no "
+"objeto <literal>Configuration</literal> antes da <literal>SessionFactory</"
 "literal> ser instanciada. Nesse caso, o interceptador fornecido será "
 "aplicado para todas as sessões abertas por aquela <literal>SessionFactory</"
 "literal>; Isso apenas não ocorrerá caso seja especificado um interceptador "
 "no momento em que a sessão for aberta. Um interceptador no escopo de "
-"<literal>SessionFactory</literal> deve ser thread safe, tomando-se o cuidado "
-"de não armazenar atributos de estado específicos da sessão, pois, "
-"provavelmente, múltiplas sessões irão utilizar esse interceptador "
-"simultaneamente."
+"<literal>SessionFactory</literal> deve ser thread safe. Cetifique-se de não "
+"armazenar funções de estado específicos da sessão, pois, provavelmente, "
+"múltiplas sessões irão utilizar esse interceptador simultaneamente."
 
-#. Tag: programlisting
-#: events.xml:80
-#, no-c-format
-msgid ""
-"<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
-msgstr ""
-
 #. Tag: title
-#: events.xml:85
 #, no-c-format
 msgid "Event system"
 msgstr "Sistema de Eventos"
 
 #. Tag: para
-#: events.xml:87
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you have to react to particular events in your persistence layer, you can "
 "also use the Hibernate3 <emphasis>event</emphasis> architecture. The event "
 "system can be used in addition, or as a replacement, for interceptors."
 msgstr ""
-"Se você precisa executar uma ação em determinados eventos da camada de "
+"Se você precisar executar uma ação em determinados eventos da camada de "
 "persistência, você também pode usar a arquitetura de <emphasis>event</"
 "emphasis> do Hibernate3. Um evento do sistema pode ser utilizado como "
-"complemento ou em substituição a um interceptador."
+"complemento ou em substituição a um interceptador. "
 
 #. Tag: para
-#: events.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All the methods of the <literal>Session</literal> interface correlate to an "
 "event. You have a <literal>LoadEvent</literal>, a <literal>FlushEvent</"
@@ -258,33 +249,31 @@
 msgstr ""
 "Essencialmente todos os métodos da interface <literal>Session</literal> "
 "possuem um evento correlacionado. Se você tiver um <literal>LoadEvent</"
-"literal>, um <literal>LoadEvent</literal>, etc (consulte o DTD do XML de "
-"configuração ou o pacote <literal>org.hibernate.event</literal> para a lista "
-"completa dos tipos de eventos). Quando uma requisição é feita em um desses "
-"métodos, a <literal>Session</literal> do hibernate gera um evento apropriado "
-"e o envia para o listener de evento correspondente àquele tipo de evento. "
-"Esses listeners implementam a mesma lógica que aqueles métodos, trazendo os "
-"mesmos resultados. Entretanto, você é livre para implementar uma "
-"customização de um desses listeners (isto é, o <literal>LoadEvent</literal> "
-"é processado pela implementação registrada da interface "
-"<literal>LoadEventListener</literal>), então sua implementação vai ficar "
-"responsável por processar qualquer requisição <literal>load()</literal> "
-"feita pela <literal>Session</literal>."
+"literal>, um <literal>LoadEvent</literal>, etc. Consulte o DTD do XML de "
+"arquivo deconfiguração ou o pacote <literal>org.hibernate.event</literal> "
+"para a lista completa dos tipos de eventos). Quando uma requisição é feita "
+"em um desses métodos, a <literal>Session</literal> do hibernate gera um "
+"evento apropriado e o envia para o listener de evento correspondente àquele "
+"tipo de evento. Esses listeners implementam a mesma lógica que aqueles "
+"métodos, trazendo os mesmos resultados. Entretanto, você é livre para "
+"implementar uma customização de um desses listeners (isto é, o "
+"<literal>LoadEvent</literal> é processado pela implementação registrada da "
+"interface <literal>LoadEventListener</literal>), então sua implementação vai "
+"ficar responsável por processar qualquer requisição <literal>load()</"
+"literal> feita pela <literal>Session</literal>."
 
 #. Tag: para
-#: events.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The listeners should be considered singletons. This means they are shared "
 "between requests, and should not save any state as instance variables."
 msgstr ""
-"Para todos os efeitos esses listeners deve ser considerados singletons; ou "
-"seja, eles são compartilhados entre as requisições, e assim sendo, não devem "
-"salvar nenhum estado das variáveis instanciadas."
+"Para todos os efeitos esses listeners devem ser considerados singletons. "
+"Isto significa que eles são compartilhados entre as requisições, e assim "
+"sendo, não devem salvar nenhum estado das variáveis instanciadas."
 
 #. Tag: para
-#: events.xml:113
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A custom listener implements the appropriate interface for the event it "
 "wants to process and/or extend one of the convenience base classes (or even "
@@ -296,33 +285,15 @@
 "example of a custom load event listener:"
 msgstr ""
 "Um listener personalizado deve implementar a interface referente ao evento a "
-"ser processado e/ou deve estender a classes base equivalente (ou mesmo os "
+"ser processado e/ou deve estender a classes base equivalentes (ou mesmo os "
 "listeners padrões usados pelo Hibernate, eles não são declarados como finais "
 "com esse objetivo). O listener personalizado pode ser registrado "
 "programaticamente no objeto <literal>Configuration</literal>, ou "
-"declarativamente no XML de configuração do Hibernate (o registro do listener "
-"no propertie de configuração não é suportado). Aqui temos um exemplo de como "
-"carregar um listener personalizado:"
+"declarativamente no XML de configuração do Hibernate especificado. A "
+"configuração declarativa através do arquivo de propriedades não é suportado. "
+"Aqui temos um exemplo de como carregar um listener personalizado:"
 
-#. Tag: programlisting
-#: events.xml:123
-#, no-c-format
-msgid ""
-"<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
-"    // this is the single method defined by the LoadEventListener interface\n"
-"    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
-"loadType)\n"
-"            throws HibernateException {\n"
-"        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
-"getEntityId() ) ) {\n"
-"            throw MySecurityException(\"Unauthorized access\");\n"
-"        }\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:125
 #, no-c-format
 msgid ""
 "You also need a configuration entry telling Hibernate to use the listener in "
@@ -332,58 +303,29 @@
 "Hibernate para registrar declarativamente qual listener deve se utilizado em "
 "conjunto com o listener padrão:"
 
-#. Tag: programlisting
-#: events.xml:130
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<hibernate-configuration>\n"
-"    <session-factory>\n"
-"        ...\n"
-"        <event type=\"load\">\n"
-"            <listener class=\"com.eg.MyLoadListener\"/>\n"
-"            <listener class=\"org.hibernate.event.def."
-"DefaultLoadEventListener\"/>\n"
-"        </event>\n"
-"    </session-factory>\n"
-"</hibernate-configuration>]]>"
-msgstr ""
+msgid "Instead, you can register it programmatically:"
+msgstr "Ou, você pode registrar o listener programaticamente:  "
 
 #. Tag: para
-#: events.xml:132
-#, fuzzy, no-c-format
-msgid "Instead, you can register it programmatically:"
-msgstr "Ou, você pode registrar o listener programaticamente:"
-
-#. Tag: programlisting
-#: events.xml:136
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration();\n"
-"LoadEventListener[] stack = { new MyLoadListener(), new "
-"DefaultLoadEventListener() };\n"
-"cfg.EventListeners().setLoadEventListeners(stack);]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:138
-#, fuzzy, no-c-format
-msgid ""
 "Listeners registered declaratively cannot share instances. If the same class "
 "name is used in multiple <literal>&lt;listener/&gt;</literal> elements, each "
 "reference will result in a separate instance of that class. If you need to "
 "share listener instances between listener types you must use the "
 "programmatic registration approach."
 msgstr ""
-"Listeners registrados declarativamente não compartilham da mesma instancia. "
-"Se o mesmo nome da classe é utilizado em vários elementos e <literal>&lt;"
-"listener/&gt;</literal>, cada um vai resultar em uma instancia separada "
-"dessa classe. Se você tem a necessidade de compartilhar uma instancia de um "
+"Listeners registrados declarativamente não compartilham da mesma instância. "
+"Se o mesmo nome da classe for utilizado em vários elementos <literal>&lt;"
+"listener/&gt;</literal>, cada um resultará em uma instância separada dessa "
+"classe. Se você tem a necessidade de compartilhar uma instância de um "
 "listener entre diversos tipos de listeners você deve registrar o listener "
-"programaticamente."
+"programaticamente. "
 
 #. Tag: para
-#: events.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Why implement an interface and define the specific type during "
 "configuration? A listener implementation could implement multiple event "
@@ -391,90 +333,331 @@
 "registration makes it easier to turn custom listeners on or off during "
 "configuration."
 msgstr ""
-"Mas porque implementar uma interface e definir o tipo específico durante a "
+"Mas, por quê implementar uma interface e definir o tipo específico durante a "
 "configuração? Bem, um listener pode implementar vários listeners de evento. "
 "Com o tipo sendo definido durante o registro, fica fácil ligar ou desligar "
-"listeners personalizados durante a configuração."
+"listeners personalizados durante a configuração. "
 
 #. Tag: title
-#: events.xml:156
 #, no-c-format
 msgid "Hibernate declarative security"
-msgstr "Hibernate declarative security"
+msgstr "Segurança declarativa do Hibernate"
 
 #. Tag: para
-#: events.xml:157
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Usually, declarative security in Hibernate applications is managed in a "
 "session facade layer. Hibernate3 allows certain actions to be permissioned "
 "via JACC, and authorized via JAAS. This is an optional functionality that is "
 "built on top of the event architecture."
 msgstr ""
-"Usually, declarative security in Hibernate applications is managed in a "
-"session facade layer. Now, Hibernate3 allows certain actions to be "
-"permissioned via JACC, and authorized via JAAS. This is optional "
-"functionality built on top of the event architecture."
+"Geralmente a segurança declarativa nos aplicativos do Hibernate é gerenciada "
+"em uma camada de fachada de sessão. Agora o Hibernate3 permite certas ações "
+"serem aceitas através do JACC e autorizadas através do JAAS. Esta é uma "
+"funcionalidade opcional construída em cima da arquitetura do evento. "
 
 #. Tag: para
-#: events.xml:163
 #, no-c-format
 msgid ""
 "First, you must configure the appropriate event listeners, to enable the use "
 "of JAAS authorization."
 msgstr ""
-"First, you must configure the appropriate event listeners, to enable the use "
-"of JAAS authorization."
+"Primeiro, você precisa configurar um evento listener apropriado, para "
+"possibilitar o uso da autorização JAAS."
 
-#. Tag: programlisting
-#: events.xml:168
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
-"JACCPreDeleteEventListener\"/>\n"
-"<listener type=\"pre-update\" class=\"org.hibernate.secure."
-"JACCPreUpdateEventListener\"/>\n"
-"<listener type=\"pre-insert\" class=\"org.hibernate.secure."
-"JACCPreInsertEventListener\"/>\n"
-"<listener type=\"pre-load\" class=\"org.hibernate.secure."
-"JACCPreLoadEventListener\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:170
-#, fuzzy, no-c-format
-msgid ""
 "Note that <literal>&lt;listener type=\"...\" class=\"...\"/&gt;</literal> is "
 "shorthand for <literal>&lt;event type=\"...\"&gt;&lt;listener class=\"...\"/"
 "&gt;&lt;/event&gt;</literal> when there is exactly one listener for a "
 "particular event type."
 msgstr ""
-"Note that <literal>&lt;listener type=\"...\" class=\"...\"/&gt;</literal> is "
-"just a shorthand for <literal>&lt;event type=\"...\"&gt;&lt;listener class="
-"\"...\"/&gt;&lt;/event&gt;</literal> when there is exactly one listener for "
-"a particular event type."
+"Note que <literal>&lt;listener type=\"...\" class=\"...\"/&gt;</literal> é "
+"somente um atalho para <literal>&lt;event type=\"...\"&gt;&lt;listener class="
+"\"...\"/&gt;&lt;/event&gt;</literal> quando existir somente um listener para "
+"um tipo de evento em particular."
 
 #. Tag: para
-#: events.xml:176
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next, while still in <literal>hibernate.cfg.xml</literal>, bind the "
 "permissions to roles:"
 msgstr ""
-"Next, still in <literal>hibernate.cfg.xml</literal>, bind the permissions to "
-"roles:"
+"Depois disso, ainda em <literal>hibernate.cfg.xml</literal>, vincule as "
+"permissões aos papéis:"
 
-#. Tag: programlisting
-#: events.xml:180
-#, no-c-format
-msgid ""
-"<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,update,"
-"read\"/>\n"
-"<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:182
 #, no-c-format
 msgid "The role names are the roles understood by your JACC provider."
-msgstr "The role names are the roles understood by your JACC provider."
+msgstr "Os nomes das funções são as funções conhecidas pelo seu provedor JACC."
+
+#~ msgid ""
+#~ "<![CDATA[package org.hibernate.test;\n"
+#~ "\n"
+#~ "import java.io.Serializable;\n"
+#~ "import java.util.Date;\n"
+#~ "import java.util.Iterator;\n"
+#~ "\n"
+#~ "import org.hibernate.EmptyInterceptor;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.type.Type;\n"
+#~ "\n"
+#~ "public class AuditInterceptor extends EmptyInterceptor {\n"
+#~ "\n"
+#~ "    private int updates;\n"
+#~ "    private int creates;\n"
+#~ "    private int loads;\n"
+#~ "\n"
+#~ "    public void onDelete(Object entity,\n"
+#~ "                         Serializable id,\n"
+#~ "                         Object[] state,\n"
+#~ "                         String[] propertyNames,\n"
+#~ "                         Type[] types) {\n"
+#~ "        // do nothing\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onFlushDirty(Object entity,\n"
+#~ "                                Serializable id,\n"
+#~ "                                Object[] currentState,\n"
+#~ "                                Object[] previousState,\n"
+#~ "                                String[] propertyNames,\n"
+#~ "                                Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            updates++;\n"
+#~ "            for ( int i=0; i < propertyNames.length; i++ ) {\n"
+#~ "                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) "
+#~ "{\n"
+#~ "                    currentState[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onLoad(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            loads++;\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onSave(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            creates++;\n"
+#~ "            for ( int i=0; i<propertyNames.length; i++ ) {\n"
+#~ "                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
+#~ "                    state[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void afterTransactionCompletion(Transaction tx) {\n"
+#~ "        if ( tx.wasCommitted() ) {\n"
+#~ "            System.out.println(\"Creations: \" + creates + \", Updates: "
+#~ "\" + updates, \"Loads: \" + loads);\n"
+#~ "        }\n"
+#~ "        updates=0;\n"
+#~ "        creates=0;\n"
+#~ "        loads=0;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package org.hibernate.test;\n"
+#~ "\n"
+#~ "import java.io.Serializable;\n"
+#~ "import java.util.Date;\n"
+#~ "import java.util.Iterator;\n"
+#~ "\n"
+#~ "import org.hibernate.EmptyInterceptor;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.type.Type;\n"
+#~ "\n"
+#~ "public class AuditInterceptor extends EmptyInterceptor {\n"
+#~ "\n"
+#~ "    private int updates;\n"
+#~ "    private int creates;\n"
+#~ "    private int loads;\n"
+#~ "\n"
+#~ "    public void onDelete(Object entity,\n"
+#~ "                         Serializable id,\n"
+#~ "                         Object[] state,\n"
+#~ "                         String[] propertyNames,\n"
+#~ "                         Type[] types) {\n"
+#~ "        // do nothing\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onFlushDirty(Object entity,\n"
+#~ "                                Serializable id,\n"
+#~ "                                Object[] currentState,\n"
+#~ "                                Object[] previousState,\n"
+#~ "                                String[] propertyNames,\n"
+#~ "                                Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            updates++;\n"
+#~ "            for ( int i=0; i < propertyNames.length; i++ ) {\n"
+#~ "                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) "
+#~ "{\n"
+#~ "                    currentState[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onLoad(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            loads++;\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onSave(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            creates++;\n"
+#~ "            for ( int i=0; i<propertyNames.length; i++ ) {\n"
+#~ "                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
+#~ "                    state[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void afterTransactionCompletion(Transaction tx) {\n"
+#~ "        if ( tx.wasCommitted() ) {\n"
+#~ "            System.out.println(\"Creations: \" + creates + \", Updates: "
+#~ "\" + updates, \"Loads: \" + loads);\n"
+#~ "        }\n"
+#~ "        updates=0;\n"
+#~ "        creates=0;\n"
+#~ "        loads=0;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
+
+#~ msgid ""
+#~ "<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
+#~ msgstr ""
+#~ "<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
+
+#~ msgid ""
+#~ "<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
+#~ "    // this is the single method defined by the LoadEventListener "
+#~ "interface\n"
+#~ "    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
+#~ "loadType)\n"
+#~ "            throws HibernateException {\n"
+#~ "        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
+#~ "getEntityId() ) ) {\n"
+#~ "            throw MySecurityException(\"Unauthorized access\");\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
+#~ "    // this is the single method defined by the LoadEventListener "
+#~ "interface\n"
+#~ "    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
+#~ "loadType)\n"
+#~ "            throws HibernateException {\n"
+#~ "        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
+#~ "getEntityId() ) ) {\n"
+#~ "            throw MySecurityException(\"Unauthorized access\");\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-configuration>\n"
+#~ "    <session-factory>\n"
+#~ "        ...\n"
+#~ "        <event type=\"load\">\n"
+#~ "            <listener class=\"com.eg.MyLoadListener\"/>\n"
+#~ "            <listener class=\"org.hibernate.event.def."
+#~ "DefaultLoadEventListener\"/>\n"
+#~ "        </event>\n"
+#~ "    </session-factory>\n"
+#~ "</hibernate-configuration>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-configuration>\n"
+#~ "    <session-factory>\n"
+#~ "        ...\n"
+#~ "        <event type=\"load\">\n"
+#~ "            <listener class=\"com.eg.MyLoadListener\"/>\n"
+#~ "            <listener class=\"org.hibernate.event.def."
+#~ "DefaultLoadEventListener\"/>\n"
+#~ "        </event>\n"
+#~ "    </session-factory>\n"
+#~ "</hibernate-configuration>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Configuration cfg = new Configuration();\n"
+#~ "LoadEventListener[] stack = { new MyLoadListener(), new "
+#~ "DefaultLoadEventListener() };\n"
+#~ "cfg.EventListeners().setLoadEventListeners(stack);]]>"
+#~ msgstr ""
+#~ "<![CDATA[Configuration cfg = new Configuration();\n"
+#~ "LoadEventListener[] stack = { new MyLoadListener(), new "
+#~ "DefaultLoadEventListener() };\n"
+#~ "cfg.EventListeners().setLoadEventListeners(stack);]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
+#~ "JACCPreDeleteEventListener\"/>\n"
+#~ "<listener type=\"pre-update\" class=\"org.hibernate.secure."
+#~ "JACCPreUpdateEventListener\"/>\n"
+#~ "<listener type=\"pre-insert\" class=\"org.hibernate.secure."
+#~ "JACCPreInsertEventListener\"/>\n"
+#~ "<listener type=\"pre-load\" class=\"org.hibernate.secure."
+#~ "JACCPreLoadEventListener\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
+#~ "JACCPreDeleteEventListener\"/>\n"
+#~ "<listener type=\"pre-update\" class=\"org.hibernate.secure."
+#~ "JACCPreUpdateEventListener\"/>\n"
+#~ "<listener type=\"pre-insert\" class=\"org.hibernate.secure."
+#~ "JACCPreInsertEventListener\"/>\n"
+#~ "<listener type=\"pre-load\" class=\"org.hibernate.secure."
+#~ "JACCPreLoadEventListener\"/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,"
+#~ "update,read\"/>\n"
+#~ "<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,"
+#~ "update,read\"/>\n"
+#~ "<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/example_mappings.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/example_mappings.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/example_mappings.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,36 +1,140 @@
+# translation of example_mappings.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: example_mappings\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-10-28 16:59+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: example_mappings.xml:29
 #, no-c-format
 msgid "Example: Various Mappings"
 msgstr "Exemplo: Vários Mapeamentos"
 
 #. Tag: para
-#: example_mappings.xml:32
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This chapters explores some more complex association mappings."
-msgstr "Este capitulo mostra algums mapeamentos de associações mais complexos."
+msgstr ""
+"Este capítulo mostra algums mapeamentos de associações mais complexos. "
 
 #. Tag: title
-#: example_mappings.xml:37
 #, no-c-format
 msgid "Employer/Employee"
-msgstr "Employer/Employee"
+msgstr "Empregador/Empregado"
 
 #. Tag: para
-#: example_mappings.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following model of the relationship between <literal>Employer</literal> "
 "and <literal>Employee</literal> uses an entity class (<literal>Employment</"
@@ -38,132 +142,32 @@
 "more than one period of employment for the same two parties. Components are "
 "used to model monetary values and employee names."
 msgstr ""
-"O modelo de seguinte relacionamento entre <literal>Employer</literal> e "
+"O modelo a seguir, do relacionamento entre <literal>Employer</literal> e "
 "<literal>Employee</literal> utiliza uma entidade de classe atual "
 "(<literal>Employment</literal>) para representar a associação. Isto é feito "
-"porque pode-ser ter mais do que um período de trabalho para as duas partes "
+"porque pode-se ter mais do que um período de trabalho para as duas partes "
 "envolvidas. Outros Componentes são usados para modelar valores monetários e "
-"os nomes do empregado."
+"os nomes do empregado. "
 
 #. Tag: para
-#: example_mappings.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is a possible mapping document:"
-msgstr "Abaixo o código de um possível mapeamento:"
+msgstr "Abaixo, segue o documento de um possível mapeamento: "
 
-#. Tag: programlisting
-#: example_mappings.xml:60
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"        \n"
-"    <class name=\"Employer\" table=\"employers\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employer_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Employment\" table=\"employment_periods\">\n"
-"\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employment_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"startDate\" column=\"start_date\"/>\n"
-"        <property name=\"endDate\" column=\"end_date\"/>\n"
-"\n"
-"        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
-"            <property name=\"amount\">\n"
-"                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/>\n"
-"            </property>\n"
-"            <property name=\"currency\" length=\"12\"/>\n"
-"        </component>\n"
-"\n"
-"        <many-to-one name=\"employer\" column=\"employer_id\" not-null=\"true"
-"\"/>\n"
-"        <many-to-one name=\"employee\" column=\"employee_id\" not-null=\"true"
-"\"/>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Employee\" table=\"employees\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employee_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"taxfileNumber\"/>\n"
-"        <component name=\"name\" class=\"Name\">\n"
-"            <property name=\"firstName\"/>\n"
-"            <property name=\"initial\"/>\n"
-"            <property name=\"lastName\"/>\n"
-"        </component>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: example_mappings.xml:62
-#, fuzzy, no-c-format
 msgid "Here is the table schema generated by <literal>SchemaExport</literal>."
 msgstr ""
-"E abaixo o esquema da tabela gerado pelo <literal>SchemaExport</literal>."
+"E abaixo, segue o esquema da tabela gerado pelo <literal>SchemaExport</"
+"literal>. "
 
-#. Tag: programlisting
-#: example_mappings.xml:66
-#, no-c-format
-msgid ""
-"<![CDATA[create table employers (\n"
-"    id BIGINT not null, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table employment_periods (\n"
-"    id BIGINT not null,\n"
-"    hourly_rate NUMERIC(12, 2),\n"
-"    currency VARCHAR(12), \n"
-"    employee_id BIGINT not null, \n"
-"    employer_id BIGINT not null, \n"
-"    end_date TIMESTAMP, \n"
-"    start_date TIMESTAMP, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table employees (\n"
-"    id BIGINT not null, \n"
-"    firstName VARCHAR(255), \n"
-"    initial CHAR(1), \n"
-"    lastName VARCHAR(255), \n"
-"    taxfileNumber VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table employment_periods \n"
-"    add constraint employment_periodsFK0 foreign key (employer_id) "
-"references employers\n"
-"alter table employment_periods \n"
-"    add constraint employment_periodsFK1 foreign key (employee_id) "
-"references employees\n"
-"create sequence employee_id_seq\n"
-"create sequence employment_id_seq\n"
-"create sequence employer_id_seq]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:71
 #, no-c-format
 msgid "Author/Work"
-msgstr "Author/Work"
+msgstr "Autor/Trabalho"
 
 #. Tag: para
-#: example_mappings.xml:73
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Consider the following model of the relationships between <literal>Work</"
 "literal>, <literal>Author</literal> and <literal>Person</literal>. In the "
@@ -179,10 +183,9 @@
 "como uma associação muitos-para-muitos. Nós escolhemos representar o "
 "relacionamento entre <literal>Author</literal> e <literal>Person</literal> "
 "como uma associação um-para-um. Outra possibilidade seria ter "
-"<literal>Author</literal> extendendo <literal>Person</literal>."
+"<literal>Author</literal> estendendo <literal>Person</literal>. "
 
 #. Tag: para
-#: example_mappings.xml:91
 #, no-c-format
 msgid ""
 "The following mapping document correctly represents these relationships:"
@@ -190,134 +193,28 @@
 "O mapeamento do código seguinte representa corretamente estes "
 "relacionamentos:"
 
-#. Tag: programlisting
-#: example_mappings.xml:95
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
-"\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <discriminator column=\"type\" type=\"character\"/>\n"
-"\n"
-"        <property name=\"title\"/>\n"
-"        <set name=\"authors\" table=\"author_work\">\n"
-"            <key column name=\"work_id\"/>\n"
-"            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
-"        </set>\n"
-"\n"
-"        <subclass name=\"Book\" discriminator-value=\"B\">\n"
-"            <property name=\"text\"/>\n"
-"        </subclass>\n"
-"\n"
-"        <subclass name=\"Song\" discriminator-value=\"S\">\n"
-"            <property name=\"tempo\"/>\n"
-"            <property name=\"genre\"/>\n"
-"        </subclass>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Author\" table=\"authors\">\n"
-"\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <!-- The Author must have the same identifier as the Person -->\n"
-"            <generator class=\"assigned\"/> \n"
-"        </id>\n"
-"\n"
-"        <property name=\"alias\"/>\n"
-"        <one-to-one name=\"person\" constrained=\"true\"/>\n"
-"\n"
-"        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
-"            <key column=\"author_id\"/>\n"
-"            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
-"        </set>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Person\" table=\"persons\">\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: example_mappings.xml:97
-#, fuzzy, no-c-format
-msgid ""
 "There are four tables in this mapping: <literal>works</literal>, "
 "<literal>authors</literal> and <literal>persons</literal> hold work, author "
 "and person data respectively. <literal>author_work</literal> is an "
 "association table linking authors to works. Here is the table schema, as "
 "generated by <literal>SchemaExport</literal>:"
 msgstr ""
-"There are four tables in this mapping. <literal>works</literal>, "
-"<literal>authors</literal> and <literal>persons</literal> hold work, author "
-"and person data respectively. <literal>author_work</literal> is an "
-"association table linking authors to works. Heres the table schema, as "
-"generated by <literal>SchemaExport</literal>. Existem quatro tabelas neste "
-"mapeamento. <literal>works</literal>, <literal>authors</literal> e "
-"<literal>persons</literal> recebem os dados de work, author e person, "
-"respectivamente. <literal>author_work</literal> é uma tabela de associação "
-"que liga authors à works. Abaixo o esquema das tabelas, gerados pelo "
-"<literal>SchemaExport</literal>."
+"Existem quatro tabelas neste mapeamento: <literal>works</literal>, "
+"<literal>authors</literal> e <literal>persons</literal> matém os dados de "
+"trabalho, autor e pessoa, respectivamente. O <literal>author_work</literal> "
+"é uma tabela de associação que liga autores à trabalhos. Abaixo, segue o "
+"esquema das tabelas, gerados pelo <literal>SchemaExport</literal>:"
 
-#. Tag: programlisting
-#: example_mappings.xml:105
-#, no-c-format
-msgid ""
-"<![CDATA[create table works (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    tempo FLOAT, \n"
-"    genre VARCHAR(255), \n"
-"    text INTEGER, \n"
-"    title VARCHAR(255), \n"
-"    type CHAR(1) not null, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table author_work (\n"
-"    author_id BIGINT not null, \n"
-"    work_id BIGINT not null, \n"
-"    primary key (work_id, author_id)\n"
-")\n"
-"\n"
-"create table authors (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    alias VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table persons (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table authors \n"
-"    add constraint authorsFK0 foreign key (id) references persons\n"
-"alter table author_work \n"
-"    add constraint author_workFK0 foreign key (author_id) references "
-"authors\n"
-"alter table author_work\n"
-"    add constraint author_workFK1 foreign key (work_id) references works]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:110
 #, no-c-format
 msgid "Customer/Order/Product"
-msgstr "Customer/Order/Product"
+msgstr "Cliente/Ordem/Produto"
 
 #. Tag: para
-#: example_mappings.xml:112
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In this section we consider a model of the relationships between "
 "<literal>Customer</literal>, <literal>Order</literal>, <literal>Line Item</"
@@ -334,62 +231,17 @@
 "<literal>Product</literal>. Existe uma associação um-para-muitos entre "
 "<literal>Customer</literal> e <literal>Order</literal>, mas como devemos "
 "representar <literal>Order</literal> / <literal>LineItem</literal> / "
-"<literal>Product</literal>? Eu escolhi mapear LineItem como uma classe de "
-"associação representando a associação muitos-para-muitos entre "
-"<literal>Order</literal> and <literal>Product</literal>. No Hibernate, isto "
-"é conhecido como um elemento composto."
+"<literal>Product</literal>? Neste exemplo, o LineItem é mapeado como uma "
+"classe de associação representando a associação muitos-para-muitos entre "
+"<literal>Order</literal> e <literal>Product</literal>. No Hibernate, isto é "
+"conhecido como um elemento composto."
 
 #. Tag: para
-#: example_mappings.xml:132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The mapping document will look like this:"
-msgstr "O código do mapeamento:"
+msgstr "O documento de mapeamento será parecido com:"
 
-#. Tag: programlisting
-#: example_mappings.xml:136
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Customer\" table=\"customers\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"        <set name=\"orders\" inverse=\"true\">\n"
-"            <key column=\"customer_id\"/>\n"
-"            <one-to-many class=\"Order\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Order\" table=\"orders\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"date\"/>\n"
-"        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
-"        <list name=\"lineItems\" table=\"line_items\">\n"
-"            <key column=\"order_id\"/>\n"
-"            <list-index column=\"line_number\"/>\n"
-"            <composite-element class=\"LineItem\">\n"
-"                <property name=\"quantity\"/>\n"
-"                <many-to-one name=\"product\" column=\"product_id\"/>\n"
-"            </composite-element>\n"
-"        </list>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Product\" table=\"products\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"serialNumber\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_mappings.xml:138
 #, no-c-format
 msgid ""
 "<literal>customers</literal>, <literal>orders</literal>, "
@@ -401,57 +253,15 @@
 "<literal>line_items</literal> e <literal>products</literal> recebem os dados "
 "de customer, order, line_item e product, respectivamente. "
 "<literal>line_items</literal> também atua como uma tabela de associação "
-"ligando orders com products."
+"ligando ordens a produtos."
 
-#. Tag: programlisting
-#: example_mappings.xml:145
-#, no-c-format
-msgid ""
-"<![CDATA[create table customers (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table orders (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    customer_id BIGINT, \n"
-"    date TIMESTAMP, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table line_items (\n"
-"    line_number INTEGER not null, \n"
-"    order_id BIGINT not null, \n"
-"    product_id BIGINT, \n"
-"    quantity INTEGER, \n"
-"    primary key (order_id, line_number)\n"
-")\n"
-"\n"
-"create table products (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    serialNumber VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table orders \n"
-"    add constraint ordersFK0 foreign key (customer_id) references customers\n"
-"alter table line_items\n"
-"    add constraint line_itemsFK0 foreign key (product_id) references "
-"products\n"
-"alter table line_items\n"
-"    add constraint line_itemsFK1 foreign key (order_id) references orders]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:150
 #, no-c-format
 msgid "Miscellaneous example mappings"
 msgstr "Exemplos variados de mapeamento"
 
 #. Tag: para
-#: example_mappings.xml:152
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These examples are available from the Hibernate test suite. You will find "
 "many other useful example mappings there by searching in the <literal>test</"
@@ -459,340 +269,1102 @@
 msgstr ""
 "Todos estes exemplos são retirados do conjunto de testes do Hibernate. Lá, "
 "você encontrará vários outros exemplos úteis de mapeamentos. Verifique o "
-"diretorio <literal>test</literal> da distribuição do Hibernate."
+"diretório <literal>test</literal> da distribuição do Hibernate. "
 
 #. Tag: title
-#: example_mappings.xml:161
 #, no-c-format
 msgid "\"Typed\" one-to-one association"
-msgstr "Associação um-para-um \"Tipadas\""
+msgstr "Associação um-para-um \"Typed\""
 
-#. Tag: programlisting
-#: example_mappings.xml:162
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"name\"/>\n"
-"    <one-to-one name=\"address\" \n"
-"            cascade=\"all\">\n"
-"        <formula>name</formula>\n"
-"        <formula>'HOME'</formula>\n"
-"    </one-to-one>\n"
-"    <one-to-one name=\"mailingAddress\" \n"
-"            cascade=\"all\">\n"
-"        <formula>name</formula>\n"
-"        <formula>'MAILING'</formula>\n"
-"    </one-to-one>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\" batch-size=\"2\" \n"
-"        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
-"    <composite-id>\n"
-"        <key-many-to-one name=\"person\" \n"
-"                column=\"personName\"/>\n"
-"        <key-property name=\"type\" \n"
-"                column=\"addressType\"/>\n"
-"    </composite-id>\n"
-"    <property name=\"street\" type=\"text\"/>\n"
-"    <property name=\"state\"/>\n"
-"    <property name=\"zip\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:166
 #, no-c-format
 msgid "Composite key example"
 msgstr "Exemplo de chave composta"
 
-#. Tag: programlisting
-#: example_mappings.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Customer\">\n"
-"\n"
-"    <id name=\"customerId\"\n"
-"        length=\"10\">\n"
-"        <generator class=\"assigned\"/>\n"
-"    </id>\n"
-"\n"
-"    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
-"    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
-"\n"
-"    <list name=\"orders\"\n"
-"            inverse=\"true\"\n"
-"            cascade=\"save-update\">\n"
-"        <key column=\"customerId\"/>\n"
-"        <index column=\"orderNumber\"/>\n"
-"        <one-to-many class=\"Order\"/>\n"
-"    </list>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
-"    <synchronize table=\"LineItem\"/>\n"
-"    <synchronize table=\"Product\"/>\n"
-"    \n"
-"    <composite-id name=\"id\" \n"
-"            class=\"Order$Id\">\n"
-"        <key-property name=\"customerId\" length=\"10\"/>\n"
-"        <key-property name=\"orderNumber\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"orderDate\" \n"
-"            type=\"calendar_date\"\n"
-"            not-null=\"true\"/>\n"
-"    \n"
-"    <property name=\"total\">\n"
-"        <formula>\n"
-"            ( select sum(li.quantity*p.price) \n"
-"            from LineItem li, Product p \n"
-"            where li.productId = p.productId \n"
-"                and li.customerId = customerId \n"
-"                and li.orderNumber = orderNumber )\n"
-"        </formula>\n"
-"    </property>\n"
-"    \n"
-"    <many-to-one name=\"customer\"\n"
-"            column=\"customerId\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\"/>\n"
-"        \n"
-"    <bag name=\"lineItems\"\n"
-"            fetch=\"join\" \n"
-"            inverse=\"true\"\n"
-"            cascade=\"save-update\">\n"
-"        <key>\n"
-"            <column name=\"customerId\"/>\n"
-"            <column name=\"orderNumber\"/>\n"
-"        </key>\n"
-"        <one-to-many class=\"LineItem\"/>\n"
-"    </bag>\n"
-"    \n"
-"</class>\n"
-"    \n"
-"<class name=\"LineItem\">\n"
-"    \n"
-"    <composite-id name=\"id\" \n"
-"            class=\"LineItem$Id\">\n"
-"        <key-property name=\"customerId\" length=\"10\"/>\n"
-"        <key-property name=\"orderNumber\"/>\n"
-"        <key-property name=\"productId\" length=\"10\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"quantity\"/>\n"
-"    \n"
-"    <many-to-one name=\"order\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\">\n"
-"        <column name=\"customerId\"/>\n"
-"        <column name=\"orderNumber\"/>\n"
-"    </many-to-one>\n"
-"    \n"
-"    <many-to-one name=\"product\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\"\n"
-"            column=\"productId\"/>\n"
-"        \n"
-"</class>\n"
-"\n"
-"<class name=\"Product\">\n"
-"    <synchronize table=\"LineItem\"/>\n"
-"\n"
-"    <id name=\"productId\"\n"
-"        length=\"10\">\n"
-"        <generator class=\"assigned\"/>\n"
-"    </id>\n"
-"    \n"
-"    <property name=\"description\" \n"
-"        not-null=\"true\" \n"
-"        length=\"200\"/>\n"
-"    <property name=\"price\" length=\"3\"/>\n"
-"    <property name=\"numberAvailable\"/>\n"
-"    \n"
-"    <property name=\"numberOrdered\">\n"
-"        <formula>\n"
-"            ( select sum(li.quantity) \n"
-"            from LineItem li \n"
-"            where li.productId = productId )\n"
-"        </formula>\n"
-"    </property>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:171
 #, no-c-format
 msgid "Many-to-many with shared composite key attribute"
-msgstr "Mmuitos-para-muitos com atributo de chave composta compartilhada"
+msgstr "Muitos-para-muitos com função de chave composta compartilhada"
 
-#. Tag: programlisting
-#: example_mappings.xml:172
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"User\" table=\"`User`\">\n"
-"    <composite-id>\n"
-"        <key-property name=\"name\"/>\n"
-"        <key-property name=\"org\"/>\n"
-"    </composite-id>\n"
-"    <set name=\"groups\" table=\"UserGroup\">\n"
-"        <key>\n"
-"            <column name=\"userName\"/>\n"
-"            <column name=\"org\"/>\n"
-"        </key>\n"
-"        <many-to-many class=\"Group\">\n"
-"            <column name=\"groupName\"/>\n"
-"            <formula>org</formula>\n"
-"        </many-to-many>\n"
-"    </set>\n"
-"</class>\n"
-"    \n"
-"<class name=\"Group\" table=\"`Group`\">\n"
-"    <composite-id>\n"
-"        <key-property name=\"name\"/>\n"
-"        <key-property name=\"org\"/>\n"
-"    </composite-id>\n"
-"    <property name=\"description\"/>\n"
-"    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
-"        <key>\n"
-"            <column name=\"groupName\"/>\n"
-"            <column name=\"org\"/>\n"
-"        </key>\n"
-"        <many-to-many class=\"User\">\n"
-"            <column name=\"userName\"/>\n"
-"            <formula>org</formula>\n"
-"        </many-to-many>\n"
-"    </set>\n"
-"</class>\n"
-"]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:176
 #, no-c-format
 msgid "Content based discrimination"
-msgstr "Conteúdo baseado em descriminação"
+msgstr "Conteúdo baseado em discriminação"
 
-#. Tag: programlisting
-#: example_mappings.xml:177
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\"\n"
-"    discriminator-value=\"P\">\n"
-"    \n"
-"    <id name=\"id\" \n"
-"        column=\"person_id\" \n"
-"        unsaved-value=\"0\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    \n"
-"            \n"
-"    <discriminator \n"
-"        type=\"character\">\n"
-"        <formula>\n"
-"            case \n"
-"                when title is not null then 'E' \n"
-"                when salesperson is not null then 'C' \n"
-"                else 'P' \n"
-"            end\n"
-"        </formula>\n"
-"    </discriminator>\n"
-"\n"
-"    <property name=\"name\" \n"
-"        not-null=\"true\"\n"
-"        length=\"80\"/>\n"
-"        \n"
-"    <property name=\"sex\" \n"
-"        not-null=\"true\"\n"
-"        update=\"false\"/>\n"
-"    \n"
-"    <component name=\"address\">\n"
-"        <property name=\"address\"/>\n"
-"        <property name=\"zip\"/>\n"
-"        <property name=\"country\"/>\n"
-"    </component>\n"
-"    \n"
-"    <subclass name=\"Employee\" \n"
-"        discriminator-value=\"E\">\n"
-"            <property name=\"title\"\n"
-"                length=\"20\"/>\n"
-"            <property name=\"salary\"/>\n"
-"            <many-to-one name=\"manager\"/>\n"
-"    </subclass>\n"
-"    \n"
-"    <subclass name=\"Customer\" \n"
-"        discriminator-value=\"C\">\n"
-"            <property name=\"comments\"/>\n"
-"            <many-to-one name=\"salesperson\"/>\n"
-"    </subclass>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:181
 #, no-c-format
 msgid "Associations on alternate keys"
 msgstr "Associações em chaves alternativas"
 
-#. Tag: programlisting
-#: example_mappings.xml:182
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    \n"
-"    <id name=\"id\">\n"
-"        <generator class=\"hilo\"/>\n"
-"    </id>\n"
-"    \n"
-"    <property name=\"name\" length=\"100\"/>\n"
-"    \n"
-"    <one-to-one name=\"address\" \n"
-"        property-ref=\"person\"\n"
-"        cascade=\"all\"\n"
-"        fetch=\"join\"/>\n"
-"    \n"
-"    <set name=\"accounts\" \n"
-"        inverse=\"true\">\n"
-"        <key column=\"userId\"\n"
-"            property-ref=\"userId\"/>\n"
-"        <one-to-many class=\"Account\"/>\n"
-"    </set>\n"
-"    \n"
-"    <property name=\"userId\" length=\"8\"/>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"hilo\"/>\n"
-"    </id>\n"
-"\n"
-"    <property name=\"address\" length=\"300\"/>\n"
-"    <property name=\"zip\" length=\"5\"/>\n"
-"    <property name=\"country\" length=\"25\"/>\n"
-"    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Account\">\n"
-"    <id name=\"accountId\" length=\"32\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    \n"
-"    <many-to-one name=\"user\"\n"
-"        column=\"userId\"\n"
-"        property-ref=\"userId\"/>\n"
-"    \n"
-"    <property name=\"type\" not-null=\"true\"/>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "        \n"
+#~ "    <class name=\"Employer\" table=\"employers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employer_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employment\" table=\"employment_periods\">\n"
+#~ "\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employment_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"startDate\" column=\"start_date\"/>\n"
+#~ "        <property name=\"endDate\" column=\"end_date\"/>\n"
+#~ "\n"
+#~ "        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
+#~ "            <property name=\"amount\">\n"
+#~ "                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/"
+#~ ">\n"
+#~ "            </property>\n"
+#~ "            <property name=\"currency\" length=\"12\"/>\n"
+#~ "        </component>\n"
+#~ "\n"
+#~ "        <many-to-one name=\"employer\" column=\"employer_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "        <many-to-one name=\"employee\" column=\"employee_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employee\" table=\"employees\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employee_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"taxfileNumber\"/>\n"
+#~ "        <component name=\"name\" class=\"Name\">\n"
+#~ "            <property name=\"firstName\"/>\n"
+#~ "            <property name=\"initial\"/>\n"
+#~ "            <property name=\"lastName\"/>\n"
+#~ "        </component>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "        \n"
+#~ "    <class name=\"Employer\" table=\"employers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employer_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employment\" table=\"employment_periods\">\n"
+#~ "\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employment_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"startDate\" column=\"start_date\"/>\n"
+#~ "        <property name=\"endDate\" column=\"end_date\"/>\n"
+#~ "\n"
+#~ "        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
+#~ "            <property name=\"amount\">\n"
+#~ "                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/"
+#~ ">\n"
+#~ "            </property>\n"
+#~ "            <property name=\"currency\" length=\"12\"/>\n"
+#~ "        </component>\n"
+#~ "\n"
+#~ "        <many-to-one name=\"employer\" column=\"employer_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "        <many-to-one name=\"employee\" column=\"employee_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employee\" table=\"employees\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employee_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"taxfileNumber\"/>\n"
+#~ "        <component name=\"name\" class=\"Name\">\n"
+#~ "            <property name=\"firstName\"/>\n"
+#~ "            <property name=\"initial\"/>\n"
+#~ "            <property name=\"lastName\"/>\n"
+#~ "        </component>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 
-#~ msgid "TODO: put words around this stuff"
-#~ msgstr "TODO: put words around this stuff"
+#~ msgid ""
+#~ "<![CDATA[create table employers (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employment_periods (\n"
+#~ "    id BIGINT not null,\n"
+#~ "    hourly_rate NUMERIC(12, 2),\n"
+#~ "    currency VARCHAR(12), \n"
+#~ "    employee_id BIGINT not null, \n"
+#~ "    employer_id BIGINT not null, \n"
+#~ "    end_date TIMESTAMP, \n"
+#~ "    start_date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employees (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    firstName VARCHAR(255), \n"
+#~ "    initial CHAR(1), \n"
+#~ "    lastName VARCHAR(255), \n"
+#~ "    taxfileNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK0 foreign key (employer_id) "
+#~ "references employers\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK1 foreign key (employee_id) "
+#~ "references employees\n"
+#~ "create sequence employee_id_seq\n"
+#~ "create sequence employment_id_seq\n"
+#~ "create sequence employer_id_seq]]>"
+#~ msgstr ""
+#~ "<![CDATA[create table employers (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employment_periods (\n"
+#~ "    id BIGINT not null,\n"
+#~ "    hourly_rate NUMERIC(12, 2),\n"
+#~ "    currency VARCHAR(12), \n"
+#~ "    employee_id BIGINT not null, \n"
+#~ "    employer_id BIGINT not null, \n"
+#~ "    end_date TIMESTAMP, \n"
+#~ "    start_date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employees (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    firstName VARCHAR(255), \n"
+#~ "    initial CHAR(1), \n"
+#~ "    lastName VARCHAR(255), \n"
+#~ "    taxfileNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK0 foreign key (employer_id) "
+#~ "references employers\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK1 foreign key (employee_id) "
+#~ "references employees\n"
+#~ "create sequence employee_id_seq\n"
+#~ "create sequence employment_id_seq\n"
+#~ "create sequence employer_id_seq]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <discriminator column=\"type\" type=\"character\"/>\n"
+#~ "\n"
+#~ "        <property name=\"title\"/>\n"
+#~ "        <set name=\"authors\" table=\"author_work\">\n"
+#~ "            <key column name=\"work_id\"/>\n"
+#~ "            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "        <subclass name=\"Book\" discriminator-value=\"B\">\n"
+#~ "            <property name=\"text\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "        <subclass name=\"Song\" discriminator-value=\"S\">\n"
+#~ "            <property name=\"tempo\"/>\n"
+#~ "            <property name=\"genre\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Author\" table=\"authors\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <!-- The Author must have the same identifier as the Person --"
+#~ ">\n"
+#~ "            <generator class=\"assigned\"/> \n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property name=\"alias\"/>\n"
+#~ "        <one-to-one name=\"person\" constrained=\"true\"/>\n"
+#~ "\n"
+#~ "        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
+#~ "            <key column=\"author_id\"/>\n"
+#~ "            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Person\" table=\"persons\">\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <discriminator column=\"type\" type=\"character\"/>\n"
+#~ "\n"
+#~ "        <property name=\"title\"/>\n"
+#~ "        <set name=\"authors\" table=\"author_work\">\n"
+#~ "            <key column name=\"work_id\"/>\n"
+#~ "            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "        <subclass name=\"Book\" discriminator-value=\"B\">\n"
+#~ "            <property name=\"text\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "        <subclass name=\"Song\" discriminator-value=\"S\">\n"
+#~ "            <property name=\"tempo\"/>\n"
+#~ "            <property name=\"genre\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Author\" table=\"authors\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <!-- The Author must have the same identifier as the Person --"
+#~ ">\n"
+#~ "            <generator class=\"assigned\"/> \n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property name=\"alias\"/>\n"
+#~ "        <one-to-one name=\"person\" constrained=\"true\"/>\n"
+#~ "\n"
+#~ "        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
+#~ "            <key column=\"author_id\"/>\n"
+#~ "            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Person\" table=\"persons\">\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[create table works (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    tempo FLOAT, \n"
+#~ "    genre VARCHAR(255), \n"
+#~ "    text INTEGER, \n"
+#~ "    title VARCHAR(255), \n"
+#~ "    type CHAR(1) not null, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table author_work (\n"
+#~ "    author_id BIGINT not null, \n"
+#~ "    work_id BIGINT not null, \n"
+#~ "    primary key (work_id, author_id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table authors (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    alias VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table persons (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table authors \n"
+#~ "    add constraint authorsFK0 foreign key (id) references persons\n"
+#~ "alter table author_work \n"
+#~ "    add constraint author_workFK0 foreign key (author_id) references "
+#~ "authors\n"
+#~ "alter table author_work\n"
+#~ "    add constraint author_workFK1 foreign key (work_id) references works]]"
+#~ ">"
+#~ msgstr ""
+#~ "<![CDATA[create table works (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    tempo FLOAT, \n"
+#~ "    genre VARCHAR(255), \n"
+#~ "    text INTEGER, \n"
+#~ "    title VARCHAR(255), \n"
+#~ "    type CHAR(1) not null, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table author_work (\n"
+#~ "    author_id BIGINT not null, \n"
+#~ "    work_id BIGINT not null, \n"
+#~ "    primary key (work_id, author_id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table authors (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    alias VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table persons (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table authors \n"
+#~ "    add constraint authorsFK0 foreign key (id) references persons\n"
+#~ "alter table author_work \n"
+#~ "    add constraint author_workFK0 foreign key (author_id) references "
+#~ "authors\n"
+#~ "alter table author_work\n"
+#~ "    add constraint author_workFK1 foreign key (work_id) references works]]"
+#~ ">"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Customer\" table=\"customers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "        <set name=\"orders\" inverse=\"true\">\n"
+#~ "            <key column=\"customer_id\"/>\n"
+#~ "            <one-to-many class=\"Order\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Order\" table=\"orders\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"date\"/>\n"
+#~ "        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
+#~ "        <list name=\"lineItems\" table=\"line_items\">\n"
+#~ "            <key column=\"order_id\"/>\n"
+#~ "            <list-index column=\"line_number\"/>\n"
+#~ "            <composite-element class=\"LineItem\">\n"
+#~ "                <property name=\"quantity\"/>\n"
+#~ "                <many-to-one name=\"product\" column=\"product_id\"/>\n"
+#~ "            </composite-element>\n"
+#~ "        </list>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Product\" table=\"products\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"serialNumber\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Customer\" table=\"customers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "        <set name=\"orders\" inverse=\"true\">\n"
+#~ "            <key column=\"customer_id\"/>\n"
+#~ "            <one-to-many class=\"Order\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Order\" table=\"orders\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"date\"/>\n"
+#~ "        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
+#~ "        <list name=\"lineItems\" table=\"line_items\">\n"
+#~ "            <key column=\"order_id\"/>\n"
+#~ "            <list-index column=\"line_number\"/>\n"
+#~ "            <composite-element class=\"LineItem\">\n"
+#~ "                <property name=\"quantity\"/>\n"
+#~ "                <many-to-one name=\"product\" column=\"product_id\"/>\n"
+#~ "            </composite-element>\n"
+#~ "        </list>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Product\" table=\"products\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"serialNumber\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[create table customers (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table orders (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    customer_id BIGINT, \n"
+#~ "    date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table line_items (\n"
+#~ "    line_number INTEGER not null, \n"
+#~ "    order_id BIGINT not null, \n"
+#~ "    product_id BIGINT, \n"
+#~ "    quantity INTEGER, \n"
+#~ "    primary key (order_id, line_number)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table products (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    serialNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table orders \n"
+#~ "    add constraint ordersFK0 foreign key (customer_id) references "
+#~ "customers\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK0 foreign key (product_id) references "
+#~ "products\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK1 foreign key (order_id) references "
+#~ "orders]]>"
+#~ msgstr ""
+#~ "<![CDATA[create table customers (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table orders (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    customer_id BIGINT, \n"
+#~ "    date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table line_items (\n"
+#~ "    line_number INTEGER not null, \n"
+#~ "    order_id BIGINT not null, \n"
+#~ "    product_id BIGINT, \n"
+#~ "    quantity INTEGER, \n"
+#~ "    primary key (order_id, line_number)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table products (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    serialNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table orders \n"
+#~ "    add constraint ordersFK0 foreign key (customer_id) references "
+#~ "customers\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK0 foreign key (product_id) references "
+#~ "products\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK1 foreign key (order_id) references "
+#~ "orders]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"name\"/>\n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'HOME'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "    <one-to-one name=\"mailingAddress\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'MAILING'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\" batch-size=\"2\" \n"
+#~ "        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-many-to-one name=\"person\" \n"
+#~ "                column=\"personName\"/>\n"
+#~ "        <key-property name=\"type\" \n"
+#~ "                column=\"addressType\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"street\" type=\"text\"/>\n"
+#~ "    <property name=\"state\"/>\n"
+#~ "    <property name=\"zip\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"name\"/>\n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'HOME'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "    <one-to-one name=\"mailingAddress\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'MAILING'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\" batch-size=\"2\" \n"
+#~ "        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-many-to-one name=\"person\" \n"
+#~ "                column=\"personName\"/>\n"
+#~ "        <key-property name=\"type\" \n"
+#~ "                column=\"addressType\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"street\" type=\"text\"/>\n"
+#~ "    <property name=\"state\"/>\n"
+#~ "    <property name=\"zip\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Customer\">\n"
+#~ "\n"
+#~ "    <id name=\"customerId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
+#~ "    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
+#~ "\n"
+#~ "    <list name=\"orders\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key column=\"customerId\"/>\n"
+#~ "        <index column=\"orderNumber\"/>\n"
+#~ "        <one-to-many class=\"Order\"/>\n"
+#~ "    </list>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "    <synchronize table=\"Product\"/>\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"Order$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"orderDate\" \n"
+#~ "            type=\"calendar_date\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"total\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity*p.price) \n"
+#~ "            from LineItem li, Product p \n"
+#~ "            where li.productId = p.productId \n"
+#~ "                and li.customerId = customerId \n"
+#~ "                and li.orderNumber = orderNumber )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"customer\"\n"
+#~ "            column=\"customerId\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        \n"
+#~ "    <bag name=\"lineItems\"\n"
+#~ "            fetch=\"join\" \n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "            <column name=\"orderNumber\"/>\n"
+#~ "        </key>\n"
+#~ "        <one-to-many class=\"LineItem\"/>\n"
+#~ "    </bag>\n"
+#~ "    \n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"LineItem\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"LineItem$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "        <key-property name=\"productId\" length=\"10\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"quantity\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\">\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "        <column name=\"orderNumber\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"product\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            column=\"productId\"/>\n"
+#~ "        \n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Product\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "\n"
+#~ "    <id name=\"productId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"description\" \n"
+#~ "        not-null=\"true\" \n"
+#~ "        length=\"200\"/>\n"
+#~ "    <property name=\"price\" length=\"3\"/>\n"
+#~ "    <property name=\"numberAvailable\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"numberOrdered\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity) \n"
+#~ "            from LineItem li \n"
+#~ "            where li.productId = productId )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Customer\">\n"
+#~ "\n"
+#~ "    <id name=\"customerId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
+#~ "    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
+#~ "\n"
+#~ "    <list name=\"orders\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key column=\"customerId\"/>\n"
+#~ "        <index column=\"orderNumber\"/>\n"
+#~ "        <one-to-many class=\"Order\"/>\n"
+#~ "    </list>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "    <synchronize table=\"Product\"/>\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"Order$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"orderDate\" \n"
+#~ "            type=\"calendar_date\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"total\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity*p.price) \n"
+#~ "            from LineItem li, Product p \n"
+#~ "            where li.productId = p.productId \n"
+#~ "                and li.customerId = customerId \n"
+#~ "                and li.orderNumber = orderNumber )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"customer\"\n"
+#~ "            column=\"customerId\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        \n"
+#~ "    <bag name=\"lineItems\"\n"
+#~ "            fetch=\"join\" \n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "            <column name=\"orderNumber\"/>\n"
+#~ "        </key>\n"
+#~ "        <one-to-many class=\"LineItem\"/>\n"
+#~ "    </bag>\n"
+#~ "    \n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"LineItem\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"LineItem$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "        <key-property name=\"productId\" length=\"10\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"quantity\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\">\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "        <column name=\"orderNumber\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"product\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            column=\"productId\"/>\n"
+#~ "        \n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Product\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "\n"
+#~ "    <id name=\"productId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"description\" \n"
+#~ "        not-null=\"true\" \n"
+#~ "        length=\"200\"/>\n"
+#~ "    <property name=\"price\" length=\"3\"/>\n"
+#~ "    <property name=\"numberAvailable\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"numberOrdered\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity) \n"
+#~ "            from LineItem li \n"
+#~ "            where li.productId = productId )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"User\" table=\"`User`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <set name=\"groups\" table=\"UserGroup\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"Group\">\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"Group\" table=\"`Group`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"description\"/>\n"
+#~ "    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"User\">\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"User\" table=\"`User`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <set name=\"groups\" table=\"UserGroup\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"Group\">\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"Group\" table=\"`Group`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"description\"/>\n"
+#~ "    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"User\">\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\"\n"
+#~ "    discriminator-value=\"P\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\" \n"
+#~ "        column=\"person_id\" \n"
+#~ "        unsaved-value=\"0\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "            \n"
+#~ "    <discriminator \n"
+#~ "        type=\"character\">\n"
+#~ "        <formula>\n"
+#~ "            case \n"
+#~ "                when title is not null then 'E' \n"
+#~ "                when salesperson is not null then 'C' \n"
+#~ "                else 'P' \n"
+#~ "            end\n"
+#~ "        </formula>\n"
+#~ "    </discriminator>\n"
+#~ "\n"
+#~ "    <property name=\"name\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        length=\"80\"/>\n"
+#~ "        \n"
+#~ "    <property name=\"sex\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        update=\"false\"/>\n"
+#~ "    \n"
+#~ "    <component name=\"address\">\n"
+#~ "        <property name=\"address\"/>\n"
+#~ "        <property name=\"zip\"/>\n"
+#~ "        <property name=\"country\"/>\n"
+#~ "    </component>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Employee\" \n"
+#~ "        discriminator-value=\"E\">\n"
+#~ "            <property name=\"title\"\n"
+#~ "                length=\"20\"/>\n"
+#~ "            <property name=\"salary\"/>\n"
+#~ "            <many-to-one name=\"manager\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Customer\" \n"
+#~ "        discriminator-value=\"C\">\n"
+#~ "            <property name=\"comments\"/>\n"
+#~ "            <many-to-one name=\"salesperson\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\"\n"
+#~ "    discriminator-value=\"P\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\" \n"
+#~ "        column=\"person_id\" \n"
+#~ "        unsaved-value=\"0\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "            \n"
+#~ "    <discriminator \n"
+#~ "        type=\"character\">\n"
+#~ "        <formula>\n"
+#~ "            case \n"
+#~ "                when title is not null then 'E' \n"
+#~ "                when salesperson is not null then 'C' \n"
+#~ "                else 'P' \n"
+#~ "            end\n"
+#~ "        </formula>\n"
+#~ "    </discriminator>\n"
+#~ "\n"
+#~ "    <property name=\"name\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        length=\"80\"/>\n"
+#~ "        \n"
+#~ "    <property name=\"sex\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        update=\"false\"/>\n"
+#~ "    \n"
+#~ "    <component name=\"address\">\n"
+#~ "        <property name=\"address\"/>\n"
+#~ "        <property name=\"zip\"/>\n"
+#~ "        <property name=\"country\"/>\n"
+#~ "    </component>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Employee\" \n"
+#~ "        discriminator-value=\"E\">\n"
+#~ "            <property name=\"title\"\n"
+#~ "                length=\"20\"/>\n"
+#~ "            <property name=\"salary\"/>\n"
+#~ "            <many-to-one name=\"manager\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Customer\" \n"
+#~ "        discriminator-value=\"C\">\n"
+#~ "            <property name=\"comments\"/>\n"
+#~ "            <many-to-one name=\"salesperson\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\" length=\"100\"/>\n"
+#~ "    \n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "        property-ref=\"person\"\n"
+#~ "        cascade=\"all\"\n"
+#~ "        fetch=\"join\"/>\n"
+#~ "    \n"
+#~ "    <set name=\"accounts\" \n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"userId\"\n"
+#~ "            property-ref=\"userId\"/>\n"
+#~ "        <one-to-many class=\"Account\"/>\n"
+#~ "    </set>\n"
+#~ "    \n"
+#~ "    <property name=\"userId\" length=\"8\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"address\" length=\"300\"/>\n"
+#~ "    <property name=\"zip\" length=\"5\"/>\n"
+#~ "    <property name=\"country\" length=\"25\"/>\n"
+#~ "    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Account\">\n"
+#~ "    <id name=\"accountId\" length=\"32\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"user\"\n"
+#~ "        column=\"userId\"\n"
+#~ "        property-ref=\"userId\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"type\" not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\" length=\"100\"/>\n"
+#~ "    \n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "        property-ref=\"person\"\n"
+#~ "        cascade=\"all\"\n"
+#~ "        fetch=\"join\"/>\n"
+#~ "    \n"
+#~ "    <set name=\"accounts\" \n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"userId\"\n"
+#~ "            property-ref=\"userId\"/>\n"
+#~ "        <one-to-many class=\"Account\"/>\n"
+#~ "    </set>\n"
+#~ "    \n"
+#~ "    <property name=\"userId\" length=\"8\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"address\" length=\"300\"/>\n"
+#~ "    <property name=\"zip\" length=\"5\"/>\n"
+#~ "    <property name=\"country\" length=\"25\"/>\n"
+#~ "    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Account\">\n"
+#~ "    <id name=\"accountId\" length=\"32\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"user\"\n"
+#~ "        column=\"userId\"\n"
+#~ "        property-ref=\"userId\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"type\" not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "</class>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/example_parentchild.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/example_parentchild.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/example_parentchild.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,129 @@
+# translation of example_parentchild.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: example_parentchild\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-08-17 20:22+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-12-19 08:56+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: example_parentchild.xml:29
 #, no-c-format
 msgid "Example: Parent/Child"
-msgstr "Example: Parent/Child"
+msgstr "Exemplo: Pai/Filho"
 
 #. Tag: para
-#: example_parentchild.xml:31
-#, fuzzy, no-c-format
+#, 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 "
@@ -34,52 +139,48 @@
 "cascades</emphasis> to model a parent/child relationship efficiently and "
 "elegantly."
 msgstr ""
-"One of the very first things that new users try to do with Hibernate is to "
-"model a parent / child type relationship. There are two different approaches "
-"to this. For various reasons the most convenient approach, especially for "
-"new users, is to model both <literal>Parent</literal> and <literal>Child</"
-"literal> as entity classes with a <literal>&lt;one-to-many&gt;</literal> "
-"association from <literal>Parent</literal> to <literal>Child</literal>. (The "
-"alternative approach is to declare the <literal>Child</literal> as a "
-"<literal>&lt;composite-element&gt;</literal>.) Now, it turns out that "
-"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. It's not at "
-"all difficult!"
+"Uma das primeiras coisas que um usuário tenta fazer com o Hibernate é "
+"modelar um tipo de relacionamento Pai/Filho. Existem duas abordagens "
+"diferentes para isto. Por diversas razões diferentes, a abordagem mais "
+"conveniente, especialmente para novos usuários, é modelar ambos os "
+"<literal>Parent</literal> e <literal>Child</literal> como classes de "
+"entidade com uma associação <literal>&lt;one-to-many&gt;</literal> a partir "
+"do <literal>Parent</literal> para o <literal>Child</literal>. A abordagem "
+"alternativa é declarar o <literal>Child</literal> como um <literal>&lt;"
+"composite-element&gt;</literal>. As semânticas padrões da associação um para "
+"muitos (no Hibernate), são muito menos parecidas com as semânticas comuns de "
+"um relacionamento pai/filho do que aqueles de um mapeamento de elemento de "
+"composição. Explicaremos como utilizar uma <emphasis>associação bidirecional "
+"um para muitos com cascatas</emphasis> para modelar um relacionamento pai/"
+"filho de forma eficiente e elegante."
 
 #. Tag: title
-#: example_parentchild.xml:45
 #, no-c-format
 msgid "A note about collections"
-msgstr "A note about collections"
+msgstr "Uma nota sobre as coleções"
 
 #. Tag: para
-#: example_parentchild.xml:47
-#, fuzzy, no-c-format
+#, 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 collections are considered to be a logical part of their owning "
-"entity; never of the contained entities. This is a crucial distinction! It "
-"has the following consequences:"
+"As coleções do Hibernate são consideradas uma parte lógica de suas próprias "
+"entidades, nunca das entidades contidas. Saiba que esta é uma distinção que "
+"possui as seguintes conseqüências:"
 
 #. Tag: para
-#: example_parentchild.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When you remove/add an object from/to a collection, the version number of "
 "the collection owner is incremented."
 msgstr ""
-"When we remove / add an object from / to a collection, the version number of "
-"the collection owner is incremented."
+"Quando removemos ou adicionamos um objeto da/na coleção, o número da versão "
+"do proprietário da coleção é incrementado. "
 
 #. Tag: para
-#: example_parentchild.xml:60
-#, fuzzy, no-c-format
+#, 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 "
@@ -87,15 +188,14 @@
 "value type instance to the collection will cause its state to be immediately "
 "persistent."
 msgstr ""
-"If an object that was removed from a collection is an instance of a value "
-"type (eg, 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."
+"Se um objeto removido de uma coleção for uma instância de um tipo de valor "
+"(ex.: um elemento de composição), este objeto irá parar de ser persistente e "
+"seu estado será completamente removido do banco de dados. Da mesma forma, ao "
+"adicionar uma instância de tipo de valor à coleção, causará ao estado uma "
+"persistência imediata. "
 
 #. Tag: para
-#: example_parentchild.xml:68
-#, fuzzy, no-c-format
+#, 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 "
@@ -103,16 +203,15 @@
 "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 ""
-"On the other hand, 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 "
-"behaviour 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."
+"Por outro lado, se uma entidade é removida de uma coleção (uma associação um-"
+"para-muitos ou muitos-para-muitos), ela não será deletada por padrão. Este "
+"comportamento é completamente consistente, uma mudança para o estado interno "
+"de uma outra entidade não deve fazer com que a entidade associada "
+"desapareça. Da mesma forma, ao adicionar uma entidade à coleção, não faz com "
+"que a entidade se torne persistente, por padrão. "
 
 #. Tag: para
-#: example_parentchild.xml:78
-#, fuzzy, no-c-format
+#, 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 "
@@ -120,112 +219,72 @@
 "case of a parent/child relationship. In this case, the life of the child is "
 "bound to the life cycle of the parent."
 msgstr ""
-"Instead, the default behaviour is that adding an entity to a collection "
-"merely creates a link between the two entities, while removing it removes "
-"the link. This is very appropriate for all sorts of cases. Where it is not "
-"appropriate at all is the case of a parent / child relationship, where the "
-"life of the child is bound to the life cycle of the parent."
+"A adição de uma entidade à coleção, por padrão, meramente cria um link entre "
+"as duas entidades. A remoção da entidade, removerá o link. Isto é muito "
+"apropriado para alguns tipos de casos. No entanto, não é apropriado o caso "
+"de um relacionamento pai/filho. Neste caso, a vida do filho está vinculada "
+"ao ciclo de vida do pai."
 
 #. Tag: title
-#: example_parentchild.xml:88
 #, no-c-format
 msgid "Bidirectional one-to-many"
-msgstr "Bidirectional one-to-many"
+msgstr "Bidirecional um-para-muitos"
 
 #. Tag: para
-#: example_parentchild.xml:90
 #, no-c-format
 msgid ""
 "Suppose we start with a simple <literal>&lt;one-to-many&gt;</literal> "
 "association from <literal>Parent</literal> to <literal>Child</literal>."
 msgstr ""
-"Suppose we start with a simple <literal>&lt;one-to-many&gt;</literal> "
-"association from <literal>Parent</literal> to <literal>Child</literal>."
+"Suponha que começamos uma associação <literal>&lt;one-to-many&gt;</literal> "
+"simples de <literal>Parent</literal> para <literal>Child</literal>."
 
-#. Tag: programlisting
-#: example_parentchild.xml:95
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:97
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "If we were to execute the following code:"
-msgstr "If we were to execute the following code"
+msgstr "Se fossemos executar o seguinte código:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:101
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = .....;\n"
-"Child c = new Child();\n"
-"p.getChildren().add(c);\n"
-"session.save(c);\n"
-"session.flush();]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:103
 #, no-c-format
 msgid "Hibernate would issue two SQL statements:"
-msgstr "Hibernate would issue two SQL statements:"
+msgstr "O Hibernate editaria duas instruções SQL"
 
 #. Tag: para
-#: example_parentchild.xml:109
 #, no-c-format
 msgid ""
 "an <literal>INSERT</literal> to create the record for <literal>c</literal>"
 msgstr ""
-"an <literal>INSERT</literal> to create the record for <literal>c</literal>"
+"um <literal>INSERT</literal> para criar um registro para <literal>c</literal>"
 
 #. Tag: para
-#: example_parentchild.xml:112
 #, no-c-format
 msgid ""
 "an <literal>UPDATE</literal> to create the link from <literal>p</literal> to "
 "<literal>c</literal>"
 msgstr ""
-"an <literal>UPDATE</literal> to create the link from <literal>p</literal> to "
+"um <literal>UPDATE</literal> para criar um link de <literal>p</literal> para "
 "<literal>c</literal>"
 
 #. Tag: para
-#: example_parentchild.xml:119
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is not only inefficient, but also violates any <literal>NOT NULL</"
 "literal> constraint on the <literal>parent_id</literal> column. You can fix "
 "the nullability constraint violation by specifying <literal>not-null=\"true"
 "\"</literal> in the collection mapping:"
 msgstr ""
-"This is not only inefficient, but also violates any <literal>NOT NULL</"
-"literal> constraint on the <literal>parent_id</literal> column. We can fix "
-"the nullability constraint violation by specifying <literal>not-null=\"true"
-"\"</literal> in the collection mapping:"
+"Isto não é somente ineficiente como também viola qualquer restrição "
+"<literal>NOT NULL</literal> na coluna <literal>parent_id</literal>. Nós "
+"podemos concertar a violação da restrição de nulabilidade, especificando um "
+"<literal>not-null=\"true\"</literal> no mapeamento da coleção:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:125
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\">\n"
-"    <key column=\"parent_id\" not-null=\"true\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:127
 #, no-c-format
 msgid "However, this is not the recommended solution."
-msgstr "However, this is not the recommended solution."
+msgstr "No entanto, esta não é uma solução recomendada."
 
 #. Tag: para
-#: example_parentchild.xml:130
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The underlying cause of this behavior is that the link (the foreign key "
 "<literal>parent_id</literal>) from <literal>p</literal> to <literal>c</"
@@ -233,267 +292,141 @@
 "object and is therefore not created in the <literal>INSERT</literal>. The "
 "solution is to make the link part of the <literal>Child</literal> mapping."
 msgstr ""
-"The underlying cause of this behaviour is that the link (the foreign key "
-"<literal>parent_id</literal>) from <literal>p</literal> to <literal>c</"
-"literal> is not considered part of the state of the <literal>Child</literal> "
-"object and is therefore not created in the <literal>INSERT</literal>. So the "
-"solution is to make the link part of the <literal>Child</literal> mapping."
+"As causas subjacentes deste comportamento é que o link (a chave exterior "
+"<literal>parent_id</literal>) de <literal>p</literal> para <literal>c</"
+"literal> não é considerada parte do estado do objeto <literal>Child</"
+"literal> e por isso não é criada no <literal>INSERT</literal>. Então a "
+"solução é fazer uma parte de link do mapeamento do <literal>Child</literal>."
 
-#. Tag: programlisting
-#: example_parentchild.xml:137
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"parent\" column=\"parent_id\" not-null=\"true\"/"
-">]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:139
-#, fuzzy, no-c-format
-msgid ""
 "You also need to add the <literal>parent</literal> property to the "
 "<literal>Child</literal> class."
 msgstr ""
-"(We also need to add the <literal>parent</literal> property to the "
-"<literal>Child</literal> class.)"
+"Nós também precisamos adicionar a propriedade <literal>parent</literal> à "
+"classe do <literal>Child</literal>."
 
 #. Tag: para
-#: example_parentchild.xml:143
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now that the <literal>Child</literal> entity is managing the state of the "
 "link, we tell the collection not to update the link. We use the "
 "<literal>inverse</literal> attribute to do this:"
 msgstr ""
-"Now that the <literal>Child</literal> entity is managing the state of the "
-"link, we tell the collection not to update the link. We use the "
-"<literal>inverse</literal> attribute."
+"Agora que a entidade <literal>Child</literal> está gerenciando o estado do "
+"link, informaremos à coleção para não atualizar o link. Utilizamos o "
+"atributo <literal>inverse</literal> para isto:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:148
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:150
-#, fuzzy, no-c-format
-msgid "The following code would be used to add a new <literal>Child</literal>:"
-msgstr "The following code would be used to add a new <literal>Child</literal>"
-
-#. Tag: programlisting
-#: example_parentchild.xml:154
 #, no-c-format
-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();]]>"
+msgid "The following code would be used to add a new <literal>Child</literal>:"
 msgstr ""
+"O seguinte código seria usado para adicionar um novo <literal>Child</"
+"literal>:"
 
 #. Tag: para
-#: example_parentchild.xml:156
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Only one SQL <literal>INSERT</literal> would now be issued."
-msgstr "And now, only one SQL <literal>INSERT</literal> would be issued!"
+msgstr "E agora, somente um SQL <literal>INSERT</literal> seria editado."
 
 #. Tag: para
-#: example_parentchild.xml:160
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You could also create an <literal>addChild()</literal> method of "
 "<literal>Parent</literal>."
 msgstr ""
-"To tighten things up a bit, we could create an <literal>addChild()</literal> "
-"method of <literal>Parent</literal>."
+"Para assegurar tudo isto, podemos criar um método de <literal>addChild()</"
+"literal> do <literal>Parent</literal>. "
 
-#. Tag: programlisting
-#: example_parentchild.xml:165
-#, no-c-format
-msgid ""
-"<![CDATA[public void addChild(Child c) {\n"
-"    c.setParent(this);\n"
-"    children.add(c);\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:167
-#, fuzzy, no-c-format
-msgid "The code to add a <literal>Child</literal> looks like this:"
-msgstr "Now, the code to add a <literal>Child</literal> looks like"
-
-#. Tag: programlisting
-#: example_parentchild.xml:171
 #, no-c-format
-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();]]>"
+msgid "The code to add a <literal>Child</literal> looks like this:"
 msgstr ""
+"Agora, o código que adiciona um <literal>Child</literal> se parece com este: "
 
 #. Tag: title
-#: example_parentchild.xml:176
 #, no-c-format
 msgid "Cascading life cycle"
-msgstr "Cascading life cycle"
+msgstr "Ciclo de vida em Cascata "
 
 #. Tag: para
-#: example_parentchild.xml:178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can address the frustrations of the explicit call to <literal>save()</"
 "literal> by using cascades."
 msgstr ""
-"The explicit call to <literal>save()</literal> is still annoying. We will "
-"address this by using cascades."
+"A chamada explícita para <literal>save()</literal> ainda é incômoda. Iremos "
+"nos referir a ela utilizando cascatas."
 
-#. Tag: programlisting
-#: example_parentchild.xml:183
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:185
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This simplifies the code above to:"
-msgstr "This simplifies the code above to"
+msgstr "Isto simplifica o código acima para:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:189
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-"Child c = new Child();\n"
-"p.addChild(c);\n"
-"session.flush();]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:191
-#, fuzzy, no-c-format
-msgid ""
 "Similarly, we do not need to iterate over the children when saving or "
 "deleting a <literal>Parent</literal>. The following removes <literal>p</"
 "literal> and all its children from the database."
 msgstr ""
-"Similarly, we don't need to iterate over the children when saving or "
-"deleting a <literal>Parent</literal>. The following removes <literal>p</"
-"literal> and all its children from the database."
+"Da mesma forma, não precisamos repetir este comando com os filhos ao salvar "
+"ou deletar um <literal>Parent</literal>. O comando seguinte irá remover o "
+"<literal>p</literal> e todos os seus filhos do banco de dados. "
 
-#. Tag: programlisting
-#: example_parentchild.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-"session.delete(p);\n"
-"session.flush();]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:198
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "However, the following code:"
-msgstr "However, this code"
+msgstr "No entanto, este código:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:202
+#. Tag: para
 #, no-c-format
 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 ""
-
-#. Tag: para
-#: example_parentchild.xml:204
-#, fuzzy, no-c-format
-msgid ""
 "will not remove <literal>c</literal> from the database. In this case, it "
 "will only remove the link to <literal>p</literal> and cause a <literal>NOT "
 "NULL</literal> constraint violation. You need to explicitly <literal>delete()"
 "</literal> the <literal>Child</literal>."
 msgstr ""
-"will not remove <literal>c</literal> from the database; it will ony remove "
-"the link to <literal>p</literal> (and cause a <literal>NOT NULL</literal> "
-"constraint violation, in this case). You need to explicitly <literal>delete()"
-"</literal> the <literal>Child</literal>."
+"não irá remover <literal>c</literal> do banco de dados. Neste caso, ele "
+"somente removerá o link para <literal>p</literal> e causará uma violação de "
+"restrição <literal>NOT NULL</literal>). Você precisará <literal>delete()</"
+"literal> de forma explícita o <literal>Child</literal>."
 
-#. Tag: programlisting
-#: example_parentchild.xml:210
+#. Tag: para
 #, no-c-format
 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 ""
-
-#. Tag: para
-#: example_parentchild.xml:212
-#, fuzzy, no-c-format
-msgid ""
 "In our case, a <literal>Child</literal> cannot exist without its parent. So "
 "if we remove a <literal>Child</literal> from the collection, we do want it "
 "to be deleted. To do this, we must use <literal>cascade=\"all-delete-orphan"
 "\"</literal>."
 msgstr ""
-"Now, in our case, a <literal>Child</literal> can't really exist without its "
-"parent. So if we remove a <literal>Child</literal> from the collection, we "
-"really do want it to be deleted. For this, we must use <literal>cascade="
-"\"all-delete-orphan\"</literal>."
+"Agora, no seu caso, um <literal>Child</literal> não pode existir sem seu "
+"pai. Então, se removermos um <literal>Child</literal> da coleção, não iremos "
+"mais querer que ele seja deletado. Devido a isto, devemos utilizar um "
+"<literal>cascade=\"all-delete-orphan\"</literal>."
 
-#. Tag: programlisting
-#: example_parentchild.xml:218
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all-delete-orphan"
-"\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:220
-#, fuzzy, no-c-format
-msgid ""
 "Even though the collection mapping specifies <literal>inverse=\"true\"</"
 "literal>, cascades are still processed by iterating the collection elements. "
 "If you need an object be saved, deleted or updated by cascade, you must add "
 "it to the collection. It is not enough to simply call <literal>setParent()</"
 "literal>."
 msgstr ""
-"Note: even though the collection mapping specifies <literal>inverse=\"true"
-"\"</literal>, cascades are still processed by iterating the collection "
-"elements. So if you require that an object be saved, deleted or updated by "
-"cascade, you must add it to the collection. It is not enough to simply call "
-"<literal>setParent()</literal>."
+"Apesar do mapeamento da coleção especificar <literal>inverse=\"true\"</"
+"literal>, as cascatas ainda são processadas por repetição dos elementos de "
+"coleção. Portanto, se você requiser que um objeto seja salvo, deletado ou "
+"atualizado por uma cascata, você deverá adicioná-lo à sua coleção. Chamar "
+"<literal>setParent()</literal> não é o bastante."
 
 #. Tag: title
-#: example_parentchild.xml:230
 #, no-c-format
 msgid "Cascades and <literal>unsaved-value</literal>"
-msgstr "Cascades and <literal>unsaved-value</literal>"
+msgstr "Cascatas e <literal>unsaved-value</literal>"
 
 #. Tag: para
-#: example_parentchild.xml:232
 #, fuzzy, no-c-format
 msgid ""
 "Suppose we loaded up a <literal>Parent</literal> in one <literal>Session</"
@@ -506,49 +439,36 @@
 "literal> have generated identifier properties of type <literal>Long</"
 "literal>. Hibernate will use the identifier and version/timestamp property "
 "value to determine which of the children are new. (See <xref linkend="
-"\"objectstate-saveorupdate\"/>.) <emphasis>In Hibernate3, it is no longer "
+"\"objectstate-saveorupdate\" />.) <emphasis>In Hibernate3, it is no longer "
 "necessary to specify an <literal>unsaved-value</literal> explicitly.</"
 "emphasis>"
 msgstr ""
-"Suppose we loaded up a <literal>Parent</literal> in one <literal>Session</"
-"literal>, made some changes in a UI action and wish to persist these changes "
-"in a new session by calling <literal>update()</literal>. The "
-"<literal>Parent</literal> will contain a collection of childen and, since "
-"cascading update is enabled, Hibernate needs to know which children are "
-"newly instantiated and which represent existing rows in the database. Lets "
-"assume that both <literal>Parent</literal> and <literal>Child</literal> have "
-"genenerated identifier properties of type <literal>Long</literal>. Hibernate "
-"will use the identifier and version/timestamp property value to determine "
-"which of the children are new. (See <xref linkend=\"objectstate-saveorupdate"
-"\"/>.) <emphasis>In Hibernate3, it is no longer necessary to specify an "
-"<literal>unsaved-value</literal> explicitly.</emphasis>"
+"Vamos supor que tenhamos carregado um <literal>Parent</literal> em uma  "
+"<literal>Session</literal>, fizemos algumas mudanças em uma ação UI e "
+"desejamos que persista estas mudanças em uma sessão nova, chamando um "
+"<literal>update()</literal>. O <literal>Parent</literal> irá conter uma "
+"coleção de filhos e uma vez que a atualização da cascata esteja habilitada, "
+"o Hibernate precisará saber qual filho foi instanciado mais recentemente e "
+"qual representa a linha existente no banco de dados. Vamos supor que ambos "
+"os <literal>Parent</literal> e <literal>Child</literal> tenham gerado "
+"propriedades de identificador do tipo <literal>Long</literal>. O Hibernate "
+"usará o identificador e o valor de propriedade da versão/carimbo de data e "
+"hora para determinar qual filho é novo. (Veja <xref linkend=\"objectstate-"
+"saveorupdate\"/>.) <emphasis>no Hibernate3, não é mais necessário "
+"especificar um <literal>unsaved-value</literal> explicitamente.</emphasis> "
 
 #. Tag: para
-#: example_parentchild.xml:244
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following code will update <literal>parent</literal> and <literal>child</"
 "literal> and insert <literal>newChild</literal>:"
 msgstr ""
-"The following code will update <literal>parent</literal> and <literal>child</"
-"literal> and insert <literal>newChild</literal>."
+"O seguinte código atualizará o <literal>parent</literal> e o <literal>child</"
+"literal> e inserirá um <literal>newChild</literal>:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:249
+#. Tag: para
 #, no-c-format
 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 ""
-
-#. Tag: para
-#: example_parentchild.xml:251
-#, fuzzy, 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 "
@@ -557,36 +477,34 @@
 "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 ""
-"Well, that's all very well for the case of a generated identifier, but what "
-"about assigned identifiers and composite identifiers? This is more "
-"difficult, since Hibernate can't 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."
+"Bem, isto cabe bem no caso de um identificador gerado, mas e os "
+"identificadores atribuídos e os identificadores de composição? Isto é mais "
+"difícil, pois uma vez que o Hibernate não pode utilizar a propriedade do "
+"identificador para distinguir entre um objeto instanciado recentemente, com "
+"um identificador atribuído pelo usuário, e um objeto carregado em uma sessão "
+"anterior. Neste caso, o Hibernate usará tanto um carimbo de data e hora "
+"(timestamp) ou uma propriedade de versão, ou irá na verdade consultar um "
+"cache de segundo nível, ou no pior dos casos, o banco de dados, para ver se "
+"a linha existe. "
 
 #. Tag: title
-#: example_parentchild.xml:263
 #, no-c-format
 msgid "Conclusion"
-msgstr "Conclusion"
+msgstr "Conclusão"
 
 #. Tag: para
-#: example_parentchild.xml:265
-#, fuzzy, no-c-format
+#, 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 ""
-"There is quite a bit to digest here and it might look confusing first time "
-"around. However, in practice, it all works out very nicely. Most Hibernate "
-"applications use the parent / child pattern in many places."
+"Há muito o que digerir aqui e pode parecer confuso na primeira vez. No "
+"entanto, na prática, funciona muito bem. A maioria dos aplicativos do "
+"Hibernate utiliza o modelo pai/filho em muitos lugares.  "
 
 #. Tag: para
-#: example_parentchild.xml:270
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We mentioned an alternative in the first paragraph. None of the above issues "
 "exist in the case of <literal>&lt;composite-element&gt;</literal> mappings, "
@@ -595,9 +513,9 @@
 "composite elements cannot own collections and they should not be the child "
 "of any entity other than the unique parent."
 msgstr ""
-"We mentioned an alternative in the first paragraph. None of the above issues "
-"exist in the case of <literal>&lt;composite-element&gt;</literal> mappings, "
-"which have exactly the semantics of a parent / child relationship. "
-"Unfortunately, there are two big limitations to composite element classes: "
-"composite elements may not own collections, and they should not be the child "
-"of any entity other than the unique parent."
+"Nós mencionamos uma alternativa neste primeiro parágrafo. Nenhum dos casos "
+"acima existem no caso de mapeamentos <literal>&lt;composite-element&gt;</"
+"literal>, que possuem exatamente a semântica do relacionamento pai/filho. "
+"Infelizmente, existem duas grandes limitações para elementos compostos: "
+"elementos compostos podem não possuir coleções e assim sendo podem não ser "
+"filhos de nenhuma outra entidade a não ser do pai único. "

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/example_weblog.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/example_weblog.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/example_weblog.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,484 +1,962 @@
+# translation of example_weblog.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: example_weblog\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-10-29 11:19+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: example_weblog.xml:29
 #, no-c-format
 msgid "Example: Weblog Application"
-msgstr "Example: Weblog Application"
+msgstr "Exemplo: Aplicativo Weblog"
 
 #. Tag: title
-#: example_weblog.xml:32
 #, no-c-format
 msgid "Persistent Classes"
-msgstr "Persistent Classes"
+msgstr "Classes Persistentes"
 
 #. Tag: para
-#: example_weblog.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The persistent classes here represent a weblog and an item posted in a "
 "weblog. They are to be modelled as a standard parent/child relationship, but "
 "we will use an ordered bag, instead of a set:"
 msgstr ""
-"The persistent classes represent a weblog, and an item posted in a weblog. "
-"They are to be modelled as a standard parent/child relationship, but we will "
-"use an ordered bag, instead of a set."
+"As classes persistentes representam um weblog, e um item postado em um "
+"weblog. Eles não devem ser modelados como um relacionamento padrão pai/"
+"filho, mas usaremos uma bolsa ordenada ao invés de um conjunto:"
 
-#. Tag: programlisting
-#: example_weblog.xml:40
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.util.List;\n"
-"\n"
-"public class Blog {\n"
-"    private Long _id;\n"
-"    private String _name;\n"
-"    private List _items;\n"
-"\n"
-"    public Long getId() {\n"
-"        return _id;\n"
-"    }\n"
-"    public List getItems() {\n"
-"        return _items;\n"
-"    }\n"
-"    public String getName() {\n"
-"        return _name;\n"
-"    }\n"
-"    public void setId(Long long1) {\n"
-"        _id = long1;\n"
-"    }\n"
-"    public void setItems(List list) {\n"
-"        _items = list;\n"
-"    }\n"
-"    public void setName(String string) {\n"
-"        _name = string;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: example_weblog.xml:42
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.text.DateFormat;\n"
-"import java.util.Calendar;\n"
-"\n"
-"public class BlogItem {\n"
-"    private Long _id;\n"
-"    private Calendar _datetime;\n"
-"    private String _text;\n"
-"    private String _title;\n"
-"    private Blog _blog;\n"
-"\n"
-"    public Blog getBlog() {\n"
-"        return _blog;\n"
-"    }\n"
-"    public Calendar getDatetime() {\n"
-"        return _datetime;\n"
-"    }\n"
-"    public Long getId() {\n"
-"        return _id;\n"
-"    }\n"
-"    public String getText() {\n"
-"        return _text;\n"
-"    }\n"
-"    public String getTitle() {\n"
-"        return _title;\n"
-"    }\n"
-"    public void setBlog(Blog blog) {\n"
-"        _blog = blog;\n"
-"    }\n"
-"    public void setDatetime(Calendar calendar) {\n"
-"        _datetime = calendar;\n"
-"    }\n"
-"    public void setId(Long long1) {\n"
-"        _id = long1;\n"
-"    }\n"
-"    public void setText(String string) {\n"
-"        _text = string;\n"
-"    }\n"
-"    public void setTitle(String string) {\n"
-"        _title = string;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: example_weblog.xml:47
 #, no-c-format
 msgid "Hibernate Mappings"
-msgstr "Hibernate Mappings"
+msgstr "Mapeamentos Hibernate"
 
 #. Tag: para
-#: example_weblog.xml:49
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The XML mappings are now straightforward. For example:"
-msgstr "The XML mappings should now be quite straightforward."
+msgstr "Os mapeamentos XML devem agora ser um tanto diretos. Por exemplo:"
 
-#. Tag: programlisting
-#: example_weblog.xml:53
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"    <class\n"
-"        name=\"Blog\"\n"
-"        table=\"BLOGS\">\n"
-"\n"
-"        <id\n"
-"            name=\"id\"\n"
-"            column=\"BLOG_ID\">\n"
-"\n"
-"            <generator class=\"native\"/>\n"
-"\n"
-"        </id>\n"
-"\n"
-"        <property\n"
-"            name=\"name\"\n"
-"            column=\"NAME\"\n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"\n"
-"        <bag\n"
-"            name=\"items\"\n"
-"            inverse=\"true\"\n"
-"            order-by=\"DATE_TIME\"\n"
-"            cascade=\"all\">\n"
-"\n"
-"            <key column=\"BLOG_ID\"/>\n"
-"            <one-to-many class=\"BlogItem\"/>\n"
-"\n"
-"        </bag>\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: example_weblog.xml:55
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"    <class\n"
-"        name=\"BlogItem\"\n"
-"        table=\"BLOG_ITEMS\"\n"
-"        dynamic-update=\"true\">\n"
-"\n"
-"        <id\n"
-"            name=\"id\"\n"
-"            column=\"BLOG_ITEM_ID\">\n"
-"\n"
-"            <generator class=\"native\"/>\n"
-"\n"
-"        </id>\n"
-"\n"
-"        <property\n"
-"            name=\"title\"\n"
-"            column=\"TITLE\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <property\n"
-"            name=\"text\"\n"
-"            column=\"TEXT\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <property\n"
-"            name=\"datetime\"\n"
-"            column=\"DATE_TIME\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <many-to-one\n"
-"            name=\"blog\"\n"
-"            column=\"BLOG_ID\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_weblog.xml:60
 #, no-c-format
 msgid "Hibernate Code"
-msgstr "Hibernate Code"
+msgstr "Código Hibernate "
 
 #. Tag: para
-#: example_weblog.xml:62
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following class demonstrates some of the kinds of things we can do with "
 "these classes using Hibernate:"
 msgstr ""
-"The following class demonstrates some of the kinds of things we can do with "
-"these classes, using Hibernate."
+"A seguinte classe demonstra algumas atividades que podemos realizar com "
+"estas classes, usando Hibernate:"
 
-#. Tag: programlisting
-#: example_weblog.xml:67
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.util.ArrayList;\n"
-"import java.util.Calendar;\n"
-"import java.util.Iterator;\n"
-"import java.util.List;\n"
-"\n"
-"import org.hibernate.HibernateException;\n"
-"import org.hibernate.Query;\n"
-"import org.hibernate.Session;\n"
-"import org.hibernate.SessionFactory;\n"
-"import org.hibernate.Transaction;\n"
-"import org.hibernate.cfg.Configuration;\n"
-"import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
-"\n"
-"public class BlogMain {\n"
-"    \n"
-"    private SessionFactory _sessions;\n"
-"    \n"
-"    public void configure() throws HibernateException {\n"
-"        _sessions = new Configuration()\n"
-"            .addClass(Blog.class)\n"
-"            .addClass(BlogItem.class)\n"
-"            .buildSessionFactory();\n"
-"    }\n"
-"    \n"
-"    public void exportTables() throws HibernateException {\n"
-"        Configuration cfg = new Configuration()\n"
-"            .addClass(Blog.class)\n"
-"            .addClass(BlogItem.class);\n"
-"        new SchemaExport(cfg).create(true, true);\n"
-"    }\n"
-"    \n"
-"    public Blog createBlog(String name) throws HibernateException {\n"
-"        \n"
-"        Blog blog = new Blog();\n"
-"        blog.setName(name);\n"
-"        blog.setItems( new ArrayList() );\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.persist(blog);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return blog;\n"
-"    }\n"
-"    \n"
-"    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
-"                        throws HibernateException {\n"
-"        \n"
-"        BlogItem item = new BlogItem();\n"
-"        item.setTitle(title);\n"
-"        item.setText(text);\n"
-"        item.setBlog(blog);\n"
-"        item.setDatetime( Calendar.getInstance() );\n"
-"        blog.getItems().add(item);\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.update(blog);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return item;\n"
-"    }\n"
-"    \n"
-"    public BlogItem createBlogItem(Long blogid, String title, String text)\n"
-"                        throws HibernateException {\n"
-"        \n"
-"        BlogItem item = new BlogItem();\n"
-"        item.setTitle(title);\n"
-"        item.setText(text);\n"
-"        item.setDatetime( Calendar.getInstance() );\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
-"            item.setBlog(blog);\n"
-"            blog.getItems().add(item);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return item;\n"
-"    }\n"
-"    \n"
-"    public void updateBlogItem(BlogItem item, String text)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        item.setText(text);\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.update(item);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"    }\n"
-"    \n"
-"    public void updateBlogItem(Long itemid, String text)\n"
-"                    throws HibernateException {\n"
-"    \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            BlogItem item = (BlogItem) session.load(BlogItem.class, "
-"itemid);\n"
-"            item.setText(text);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"    }\n"
-"    \n"
-"    public List listAllBlogNamesAndItemCounts(int max)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        List result = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"select blog.id, blog.name, count(blogItem) \" +\n"
-"                \"from Blog as blog \" +\n"
-"                \"left outer join blog.items as blogItem \" +\n"
-"                \"group by blog.name, blog.id \" +\n"
-"                \"order by max(blogItem.datetime)\"\n"
-"            );\n"
-"            q.setMaxResults(max);\n"
-"            result = q.list();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return result;\n"
-"    }\n"
-"    \n"
-"    public Blog getBlogAndAllItems(Long blogid)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        Blog blog = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"from Blog as blog \" +\n"
-"                \"left outer join fetch blog.items \" +\n"
-"                \"where blog.id = :blogid\"\n"
-"            );\n"
-"            q.setParameter(\"blogid\", blogid);\n"
-"            blog  = (Blog) q.uniqueResult();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return blog;\n"
-"    }\n"
-"    \n"
-"    public List listBlogsAndRecentItems() throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        List result = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"from Blog as blog \" +\n"
-"                \"inner join blog.items as blogItem \" +\n"
-"                \"where blogItem.datetime > :minDate\"\n"
-"            );\n"
-"\n"
-"            Calendar cal = Calendar.getInstance();\n"
-"            cal.roll(Calendar.MONTH, false);\n"
-"            q.setCalendar(\"minDate\", cal);\n"
-"            \n"
-"            result = q.list();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return result;\n"
-"    }\n"
-"}]]>"
-msgstr ""
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "public class Blog {\n"
+#~ "    private Long _id;\n"
+#~ "    private String _name;\n"
+#~ "    private List _items;\n"
+#~ "\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public List getItems() {\n"
+#~ "        return _items;\n"
+#~ "    }\n"
+#~ "    public String getName() {\n"
+#~ "        return _name;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setItems(List list) {\n"
+#~ "        _items = list;\n"
+#~ "    }\n"
+#~ "    public void setName(String string) {\n"
+#~ "        _name = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "public class Blog {\n"
+#~ "    private Long _id;\n"
+#~ "    private String _name;\n"
+#~ "    private List _items;\n"
+#~ "\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public List getItems() {\n"
+#~ "        return _items;\n"
+#~ "    }\n"
+#~ "    public String getName() {\n"
+#~ "        return _name;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setItems(List list) {\n"
+#~ "        _items = list;\n"
+#~ "    }\n"
+#~ "    public void setName(String string) {\n"
+#~ "        _name = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.text.DateFormat;\n"
+#~ "import java.util.Calendar;\n"
+#~ "\n"
+#~ "public class BlogItem {\n"
+#~ "    private Long _id;\n"
+#~ "    private Calendar _datetime;\n"
+#~ "    private String _text;\n"
+#~ "    private String _title;\n"
+#~ "    private Blog _blog;\n"
+#~ "\n"
+#~ "    public Blog getBlog() {\n"
+#~ "        return _blog;\n"
+#~ "    }\n"
+#~ "    public Calendar getDatetime() {\n"
+#~ "        return _datetime;\n"
+#~ "    }\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public String getText() {\n"
+#~ "        return _text;\n"
+#~ "    }\n"
+#~ "    public String getTitle() {\n"
+#~ "        return _title;\n"
+#~ "    }\n"
+#~ "    public void setBlog(Blog blog) {\n"
+#~ "        _blog = blog;\n"
+#~ "    }\n"
+#~ "    public void setDatetime(Calendar calendar) {\n"
+#~ "        _datetime = calendar;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setText(String string) {\n"
+#~ "        _text = string;\n"
+#~ "    }\n"
+#~ "    public void setTitle(String string) {\n"
+#~ "        _title = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.text.DateFormat;\n"
+#~ "import java.util.Calendar;\n"
+#~ "\n"
+#~ "public class BlogItem {\n"
+#~ "    private Long _id;\n"
+#~ "    private Calendar _datetime;\n"
+#~ "    private String _text;\n"
+#~ "    private String _title;\n"
+#~ "    private Blog _blog;\n"
+#~ "\n"
+#~ "    public Blog getBlog() {\n"
+#~ "        return _blog;\n"
+#~ "    }\n"
+#~ "    public Calendar getDatetime() {\n"
+#~ "        return _datetime;\n"
+#~ "    }\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public String getText() {\n"
+#~ "        return _text;\n"
+#~ "    }\n"
+#~ "    public String getTitle() {\n"
+#~ "        return _title;\n"
+#~ "    }\n"
+#~ "    public void setBlog(Blog blog) {\n"
+#~ "        _blog = blog;\n"
+#~ "    }\n"
+#~ "    public void setDatetime(Calendar calendar) {\n"
+#~ "        _datetime = calendar;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setText(String string) {\n"
+#~ "        _text = string;\n"
+#~ "    }\n"
+#~ "    public void setTitle(String string) {\n"
+#~ "        _title = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"Blog\"\n"
+#~ "        table=\"BLOGS\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"name\"\n"
+#~ "            column=\"NAME\"\n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "\n"
+#~ "        <bag\n"
+#~ "            name=\"items\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            order-by=\"DATE_TIME\"\n"
+#~ "            cascade=\"all\">\n"
+#~ "\n"
+#~ "            <key column=\"BLOG_ID\"/>\n"
+#~ "            <one-to-many class=\"BlogItem\"/>\n"
+#~ "\n"
+#~ "        </bag>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"Blog\"\n"
+#~ "        table=\"BLOGS\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"name\"\n"
+#~ "            column=\"NAME\"\n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "\n"
+#~ "        <bag\n"
+#~ "            name=\"items\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            order-by=\"DATE_TIME\"\n"
+#~ "            cascade=\"all\">\n"
+#~ "\n"
+#~ "            <key column=\"BLOG_ID\"/>\n"
+#~ "            <one-to-many class=\"BlogItem\"/>\n"
+#~ "\n"
+#~ "        </bag>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"BlogItem\"\n"
+#~ "        table=\"BLOG_ITEMS\"\n"
+#~ "        dynamic-update=\"true\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ITEM_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"title\"\n"
+#~ "            column=\"TITLE\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"text\"\n"
+#~ "            column=\"TEXT\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"datetime\"\n"
+#~ "            column=\"DATE_TIME\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <many-to-one\n"
+#~ "            name=\"blog\"\n"
+#~ "            column=\"BLOG_ID\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"BlogItem\"\n"
+#~ "        table=\"BLOG_ITEMS\"\n"
+#~ "        dynamic-update=\"true\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ITEM_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"title\"\n"
+#~ "            column=\"TITLE\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"text\"\n"
+#~ "            column=\"TEXT\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"datetime\"\n"
+#~ "            column=\"DATE_TIME\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <many-to-one\n"
+#~ "            name=\"blog\"\n"
+#~ "            column=\"BLOG_ID\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.ArrayList;\n"
+#~ "import java.util.Calendar;\n"
+#~ "import java.util.Iterator;\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "import org.hibernate.HibernateException;\n"
+#~ "import org.hibernate.Query;\n"
+#~ "import org.hibernate.Session;\n"
+#~ "import org.hibernate.SessionFactory;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.cfg.Configuration;\n"
+#~ "import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
+#~ "\n"
+#~ "public class BlogMain {\n"
+#~ "    \n"
+#~ "    private SessionFactory _sessions;\n"
+#~ "    \n"
+#~ "    public void configure() throws HibernateException {\n"
+#~ "        _sessions = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class)\n"
+#~ "            .buildSessionFactory();\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void exportTables() throws HibernateException {\n"
+#~ "        Configuration cfg = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class);\n"
+#~ "        new SchemaExport(cfg).create(true, true);\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog createBlog(String name) throws HibernateException {\n"
+#~ "        \n"
+#~ "        Blog blog = new Blog();\n"
+#~ "        blog.setName(name);\n"
+#~ "        blog.setItems( new ArrayList() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.persist(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setBlog(blog);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        blog.getItems().add(item);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Long blogid, String title, String "
+#~ "text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
+#~ "            item.setBlog(blog);\n"
+#~ "            blog.getItems().add(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(BlogItem item, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        item.setText(text);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(Long itemid, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "    \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            BlogItem item = (BlogItem) session.load(BlogItem.class, "
+#~ "itemid);\n"
+#~ "            item.setText(text);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listAllBlogNamesAndItemCounts(int max)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"select blog.id, blog.name, count(blogItem) \" +\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join blog.items as blogItem \" +\n"
+#~ "                \"group by blog.name, blog.id \" +\n"
+#~ "                \"order by max(blogItem.datetime)\"\n"
+#~ "            );\n"
+#~ "            q.setMaxResults(max);\n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog getBlogAndAllItems(Long blogid)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        Blog blog = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join fetch blog.items \" +\n"
+#~ "                \"where blog.id = :blogid\"\n"
+#~ "            );\n"
+#~ "            q.setParameter(\"blogid\", blogid);\n"
+#~ "            blog  = (Blog) q.uniqueResult();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listBlogsAndRecentItems() throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"inner join blog.items as blogItem \" +\n"
+#~ "                \"where blogItem.datetime > :minDate\"\n"
+#~ "            );\n"
+#~ "\n"
+#~ "            Calendar cal = Calendar.getInstance();\n"
+#~ "            cal.roll(Calendar.MONTH, false);\n"
+#~ "            q.setCalendar(\"minDate\", cal);\n"
+#~ "            \n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.ArrayList;\n"
+#~ "import java.util.Calendar;\n"
+#~ "import java.util.Iterator;\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "import org.hibernate.HibernateException;\n"
+#~ "import org.hibernate.Query;\n"
+#~ "import org.hibernate.Session;\n"
+#~ "import org.hibernate.SessionFactory;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.cfg.Configuration;\n"
+#~ "import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
+#~ "\n"
+#~ "public class BlogMain {\n"
+#~ "    \n"
+#~ "    private SessionFactory _sessions;\n"
+#~ "    \n"
+#~ "    public void configure() throws HibernateException {\n"
+#~ "        _sessions = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class)\n"
+#~ "            .buildSessionFactory();\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void exportTables() throws HibernateException {\n"
+#~ "        Configuration cfg = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class);\n"
+#~ "        new SchemaExport(cfg).create(true, true);\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog createBlog(String name) throws HibernateException {\n"
+#~ "        \n"
+#~ "        Blog blog = new Blog();\n"
+#~ "        blog.setName(name);\n"
+#~ "        blog.setItems( new ArrayList() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.persist(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setBlog(blog);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        blog.getItems().add(item);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Long blogid, String title, String "
+#~ "text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
+#~ "            item.setBlog(blog);\n"
+#~ "            blog.getItems().add(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(BlogItem item, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        item.setText(text);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(Long itemid, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "    \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            BlogItem item = (BlogItem) session.load(BlogItem.class, "
+#~ "itemid);\n"
+#~ "            item.setText(text);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listAllBlogNamesAndItemCounts(int max)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"select blog.id, blog.name, count(blogItem) \" +\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join blog.items as blogItem \" +\n"
+#~ "                \"group by blog.name, blog.id \" +\n"
+#~ "                \"order by max(blogItem.datetime)\"\n"
+#~ "            );\n"
+#~ "            q.setMaxResults(max);\n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog getBlogAndAllItems(Long blogid)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        Blog blog = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join fetch blog.items \" +\n"
+#~ "                \"where blog.id = :blogid\"\n"
+#~ "            );\n"
+#~ "            q.setParameter(\"blogid\", blogid);\n"
+#~ "            blog  = (Blog) q.uniqueResult();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listBlogsAndRecentItems() throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"inner join blog.items as blogItem \" +\n"
+#~ "                \"where blogItem.datetime > :minDate\"\n"
+#~ "            );\n"
+#~ "\n"
+#~ "            Calendar cal = Calendar.getInstance();\n"
+#~ "            cal.roll(Calendar.MONTH, false);\n"
+#~ "            q.setCalendar(\"minDate\", cal);\n"
+#~ "            \n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "}]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/filters.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/filters.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/filters.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,129 @@
+# translation of filters.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: filters\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-11-16 15:07+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: filters.xml:29
 #, no-c-format
 msgid "Filtering data"
 msgstr "Filtrando dados"
 
 #. Tag: para
-#: filters.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 provides an innovative new approach to handling data with "
 "\"visibility\" rules. A <emphasis>Hibernate filter</emphasis> is a global, "
@@ -27,18 +132,16 @@
 msgstr ""
 "O Hibernate3 provê um novo método inovador para manusear dados com regras de "
 "\"visibilidade\". Um <emphasis>Filtro do Hibernate</emphasis> é um filtro "
-"global, nomeado e parametrizado que pode se habilitado ou não dentro de um "
-"Session do Hibernate."
+"global, nomeado e parametrizado que pode ser habilitado ou não dentro de uma "
+"Sessão do Hibernate. "
 
 #. Tag: title
-#: filters.xml:38
 #, no-c-format
 msgid "Hibernate filters"
 msgstr "Filtros do Hibernate"
 
 #. Tag: para
-#: filters.xml:40
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 has the ability to pre-define filter criteria and attach those "
 "filters at both a class level and a collection level. A filter criteria "
@@ -49,18 +152,16 @@
 "parameter values should be. Filters can be used like database views, but "
 "they are parameterized inside the application."
 msgstr ""
-"O Hibernate tem a habilidade de pré definir os critérios do filtro e anexar "
+"O Hibernate3 tem a habilidade de pré-definir os critérios do filtro e anexar "
 "esses filtros no nível da classe e no nível da coleção. Um critério do "
-"filtro é a habilidade de definir uma cláusula restritiva muito semelhante ao "
-"atributo \"where\" disponível para a classe e várias coleções. A não ser que "
-"essas condições de filtros podem ser parametrizadas. A aplicação pode, "
-"então, fazer uma decisão em tempo de execução se os filtros definidos devem "
-"estar habilitados e quais valores seus parâmetros devem ter. Os filtros "
-"podem ser usados como Views de bancos de dados, mas com parametros internos "
-"à aplicação."
+"filtro é a habilidade de definir uma cláusula restritiva muito semelhante à "
+"função \"where\" disponível para a classe e várias coleções. A não ser que "
+"essas condições de filtros possam ser parametrizadas. A aplicação pode, "
+"então decidir, em tempo de execução, se os filtros definidos devem estar "
+"habilitados e quais valores seus parâmetros devem ter. Os filtros podem ser "
+"usados como Views de bancos de dados, mas com parâmetros dentro da aplicação."
 
 #. Tag: para
-#: filters.xml:50
 #, no-c-format
 msgid ""
 "In order to use filters, they must first be defined and then attached to the "
@@ -68,62 +169,28 @@
 "filter-def/&gt;</literal> element within a <literal>&lt;hibernate-mapping/"
 "&gt;</literal> element:"
 msgstr ""
-"Para usar esses filtros, eles primeiramente devem ser definidos e anexados "
+"Para usar esses filtros, eles devem inicialmente ser definidos e anexados "
 "aos elementos do mapeamento apropriados. Para definir um filtro, use o "
 "elemento <literal>&lt;filter-def/&gt;</literal> dentro do elemento "
 "<literal>&lt;hibernate-mapping/&gt;</literal>:"
 
-#. Tag: programlisting
-#: filters.xml:56
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<filter-def name=\"myFilter\">\n"
-"    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
-"</filter-def>]]>"
-msgstr ""
+msgid "This filter can then be attached to a class:"
+msgstr "Esse filtro pode ser acoplado à uma classe:"
 
 #. Tag: para
-#: filters.xml:58
-#, fuzzy, no-c-format
-msgid "This filter can then be attached to a class:"
-msgstr "Então esse filtro pode ser anexo à uma classe:"
-
-#. Tag: programlisting
-#: filters.xml:62
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"myClass\" ...>\n"
-"    ...\n"
-"    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN"
-"\"/>\n"
-"</class>]]>"
-msgstr ""
+msgid "Or, to a collection:"
+msgstr "Ou, à uma coleção:"
 
 #. Tag: para
-#: filters.xml:64
-#, fuzzy, no-c-format
-msgid "Or, to a collection:"
-msgstr "ou em uma coleção:"
-
-#. Tag: programlisting
-#: filters.xml:68
 #, no-c-format
-msgid ""
-"<![CDATA[<set ...>\n"
-"    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN"
-"\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:70
-#, fuzzy, no-c-format
 msgid "Or, to both or multiples of each at the same time."
-msgstr "ou mesmo para ambos (ou muitos de cada) ao mesmo tempo."
+msgstr "Ou, mesmo para ambos (ou muitos de cada) ao mesmo tempo."
 
 #. Tag: para
-#: filters.xml:74
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The methods on <literal>Session</literal> are: <literal>enableFilter(String "
 "filterName)</literal>, <literal>getEnabledFilter(String filterName)</"
@@ -136,151 +203,80 @@
 msgstr ""
 "Os métodos na <literal>Session</literal> são: <literal>enableFilter(String "
 "filterName)</literal>, <literal>getEnabledFilter(String filterName)</"
-"literal>, e <literal>disableFilter(String filterName)</literal>. Por padrão, "
-"os filtros não são habilitados dentro de qualquer session; Eles devem ser "
-"explicitamente habilitados usando o método <literal>Session.enableFilter()</"
-"literal>, que retorna uma instância da interface <literal>Filter</literal>. "
-"Usando o filtro simples definido acima, o código se pareceria com o seguinte:"
+"literal> e <literal>disableFilter(String filterName)</literal>. Por padrão, "
+"os filtros <emphasis>não</emphasis> são habilitados dentro de qualquer "
+"sessão. Eles devem ser explicitamente habilitados usando o método "
+"<literal>Session.enabledFilter()</literal>, que retorna uma instância da "
+"interface <literal>Filter</literal>. Usando o filtro simples definido acima, "
+"o código se pareceria com o seguinte: "
 
-#. Tag: programlisting
-#: filters.xml:83
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam\", "
-"\"some-value\");]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:85
-#, fuzzy, no-c-format
-msgid ""
 "Methods on the org.hibernate.Filter interface do allow the method-chaining "
 "common to much of Hibernate."
 msgstr ""
 "Veja que os métodos da interface org.hibernate.Filter permite o encadeamento "
-"de funções, comum à maioria das funções do Hibernate."
+"do método, comum à maioria das funções do Hibernate. "
 
 #. Tag: para
-#: filters.xml:89
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is a full example, using temporal data with an effective "
 "record date pattern:"
 msgstr ""
-"Um exemplo completo, usando dados temporais com um padrão efetivo de "
-"registro de datas:"
+"Um exemplo completo, usando dados temporais com um padrão de datas de "
+"registro efetivo:"
 
-#. Tag: programlisting
-#: filters.xml:93
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<filter-def name=\"effectiveDate\">\n"
-"    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
-"</filter-def>\n"
-"\n"
-"<class name=\"Employee\" ...>\n"
-"...\n"
-"    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department\"/"
-">\n"
-"    <property name=\"effectiveStartDate\" type=\"date\" column=\"eff_start_dt"
-"\"/>\n"
-"    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt\"/"
-">\n"
-"...\n"
-"    <!--\n"
-"        Note that this assumes non-terminal records have an eff_end_dt set "
-"to\n"
-"        a max db date for simplicity-sake\n"
-"    -->\n"
-"    <filter name=\"effectiveDate\"\n"
-"            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Department\" ...>\n"
-"...\n"
-"    <set name=\"employees\" lazy=\"true\">\n"
-"        <key column=\"dept_id\"/>\n"
-"        <one-to-many class=\"Employee\"/>\n"
-"        <filter name=\"effectiveDate\"\n"
-"                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
-">\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:95
-#, fuzzy, no-c-format
-msgid ""
 "In order to ensure that you are provided with currently effective records, "
 "enable the filter on the session prior to retrieving employee data:"
 msgstr ""
 "Para garantir que você sempre tenha registro efetivos, simplesmente habilite "
-"o filtro na session antes de recuperar os dados dos empregados:"
+"o filtro na sessão antes de recuperar os dados dos empregados: "
 
-#. Tag: programlisting
-#: filters.xml:100
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = ...;\n"
-"session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new Date"
-"());\n"
-"List results = session.createQuery(\"from Employee as e where e.salary > :"
-"targetSalary\")\n"
-"         .setLong(\"targetSalary\", new Long(1000000))\n"
-"         .list();\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:102
-#, fuzzy, no-c-format
-msgid ""
 "Even though a salary constraint was mentioned explicitly on the results in "
 "the above HQL, because of the enabled filter, the query will return only "
 "currently active employees who have a salary greater than one million "
 "dollars."
 msgstr ""
-"No HQL acima, mesmo que mencionamos apenas uma restrição de salário nos "
-"resultados, por causa do filtro habilitado, a consulta retornará apenas os "
-"funcionários ativos cujo salário é maior que um milhão de dólares."
+"No HQL acima, mesmo que tenhamos mencionado apenas uma restrição de salário "
+"nos resultados, por causa do filtro habilitado, a consulta retornará apenas "
+"os funcionários ativos cujo salário é maior que um milhão de dólares. "
 
 #. Tag: para
-#: filters.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want to use filters with outer joining, either through HQL or load "
 "fetching, be careful of the direction of the condition expression. It is "
 "safest to set this up for left outer joining. Place the parameter first "
 "followed by the column name(s) after the operator."
 msgstr ""
-"Nota: se você planeja usar filtros com outer join (por HQL ou por load "
-"fetching) seja cuidadoso na direção da expressão de condição. É mais seguro "
-"configura-lo com para um left outer join; geralmente, coloque o parâmetro "
-"primeiro seguido pelo nome da coluna após o operador."
+"Nota: se você planeja usar filtros com união externa (por HQL ou por busca "
+"de carga) seja cuidadoso quanto à direção da expressão de condição. É mais "
+"seguro configurá-lo para uma união externa esquerda. Coloque o parâmetro "
+"primeiro seguido pelo(s) nome(s) da coluna após o operador. "
 
 #. Tag: para
-#: filters.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "After being defined, a filter might be attached to multiple entities and/or "
 "collections each with its own condition. This can be problematic when the "
 "conditions are the same each time. Using <literal>&lt;filter-def/&gt;</"
 "literal> allows you to definine a default condition, either as an attribute "
 "or CDATA:"
-msgstr "translator-credits"
-
-#. Tag: programlisting
-#: filters.xml:122
-#, no-c-format
-msgid ""
-"<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</filter-"
-"def>\n"
-"<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"
 msgstr ""
+"Após ser definido, o filtro deve ser anexado às entidades múltiplas e/ou "
+"coleções, cada uma com sua própria condição. Isto pode ser tedioso quando as "
+"condições se repetem. Assim, usando o <literal>&lt;filter-def/&gt;</literal> "
+"permite denifir uma condição padrão, tanto como uma função quanto CDATA:"
 
 #. Tag: para
-#: filters.xml:124
 #, no-c-format
 msgid ""
 "This default condition will be used whenever the filter is attached to "
@@ -288,3 +284,144 @@
 "condition as part of the attachment of the filter that overrides the default "
 "condition in that particular case."
 msgstr ""
+"Esta condição padrão será utilizada todas as vezes que um filtro for anexado "
+"a algo sem uma condição específica. Note que isto significa que você pode "
+"dar uma condição específica como parte de um anexo de filtro que substitua a "
+"condição padrão neste caso em particular. "
+
+#~ msgid ""
+#~ "<![CDATA[<filter-def name=\"myFilter\">\n"
+#~ "    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
+#~ "</filter-def>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<filter-def name=\"myFilter\">\n"
+#~ "    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
+#~ "</filter-def>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"myClass\" ...>\n"
+#~ "    ...\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"myClass\" ...>\n"
+#~ "    ...\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set ...>\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set ...>\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam"
+#~ "\", \"some-value\");]]>"
+#~ msgstr ""
+#~ "<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam"
+#~ "\", \"some-value\");]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<filter-def name=\"effectiveDate\">\n"
+#~ "    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
+#~ "</filter-def>\n"
+#~ "\n"
+#~ "<class name=\"Employee\" ...>\n"
+#~ "...\n"
+#~ "    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department"
+#~ "\"/>\n"
+#~ "    <property name=\"effectiveStartDate\" type=\"date\" column="
+#~ "\"eff_start_dt\"/>\n"
+#~ "    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt"
+#~ "\"/>\n"
+#~ "...\n"
+#~ "    <!--\n"
+#~ "        Note that this assumes non-terminal records have an eff_end_dt "
+#~ "set to\n"
+#~ "        a max db date for simplicity-sake\n"
+#~ "    -->\n"
+#~ "    <filter name=\"effectiveDate\"\n"
+#~ "            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
+#~ ">\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Department\" ...>\n"
+#~ "...\n"
+#~ "    <set name=\"employees\" lazy=\"true\">\n"
+#~ "        <key column=\"dept_id\"/>\n"
+#~ "        <one-to-many class=\"Employee\"/>\n"
+#~ "        <filter name=\"effectiveDate\"\n"
+#~ "                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt"
+#~ "\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<filter-def name=\"effectiveDate\">\n"
+#~ "    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
+#~ "</filter-def>\n"
+#~ "\n"
+#~ "<class name=\"Employee\" ...>\n"
+#~ "...\n"
+#~ "    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department"
+#~ "\"/>\n"
+#~ "    <property name=\"effectiveStartDate\" type=\"date\" column="
+#~ "\"eff_start_dt\"/>\n"
+#~ "    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt"
+#~ "\"/>\n"
+#~ "...\n"
+#~ "    <!--\n"
+#~ "        Note that this assumes non-terminal records have an eff_end_dt "
+#~ "set to\n"
+#~ "        a max db date for simplicity-sake\n"
+#~ "    -->\n"
+#~ "    <filter name=\"effectiveDate\"\n"
+#~ "            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
+#~ ">\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Department\" ...>\n"
+#~ "...\n"
+#~ "    <set name=\"employees\" lazy=\"true\">\n"
+#~ "        <key column=\"dept_id\"/>\n"
+#~ "        <one-to-many class=\"Employee\"/>\n"
+#~ "        <filter name=\"effectiveDate\"\n"
+#~ "                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt"
+#~ "\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = ...;\n"
+#~ "session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new "
+#~ "Date());\n"
+#~ "List results = session.createQuery(\"from Employee as e where e.salary > :"
+#~ "targetSalary\")\n"
+#~ "         .setLong(\"targetSalary\", new Long(1000000))\n"
+#~ "         .list();\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = ...;\n"
+#~ "session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new "
+#~ "Date());\n"
+#~ "List results = session.createQuery(\"from Employee as e where e.salary > :"
+#~ "targetSalary\")\n"
+#~ "         .setLong(\"targetSalary\", new Long(1000000))\n"
+#~ "         .list();\n"
+#~ "]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</"
+#~ "filter-def>\n"
+#~ "<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</"
+#~ "filter-def>\n"
+#~ "<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/inheritance_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/inheritance_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/inheritance_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,75 +1,169 @@
+# translation of inheritance_mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: inheritance_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-19 17:16+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: inheritance_mapping.xml:29
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Inheritance mapping"
-msgstr "Mapeamento de Herança"
+msgstr "Mapeamento de Herança "
 
 #. Tag: title
-#: inheritance_mapping.xml:32
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The three strategies"
-msgstr "As três estratégias"
+msgstr "As três estratégias "
 
 #. Tag: para
-#: inheritance_mapping.xml:34
 #, no-c-format
 msgid "Hibernate supports the three basic inheritance mapping strategies:"
 msgstr ""
 "O Hibernate suporta as três estratégias básicas de mapeamento de herança:"
 
 #. Tag: para
-#: inheritance_mapping.xml:40
 #, no-c-format
 msgid "table per class hierarchy"
 msgstr "tabela por hierarquia de classes"
 
 #. Tag: para
-#: inheritance_mapping.xml:45
 #, fuzzy, no-c-format
-msgid "<para>table per subclass</para>"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"tabela por subclasse\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"table per subclass"
+msgid "table per subclass"
+msgstr "Tabela por subclasse"
 
 #. Tag: para
-#: inheritance_mapping.xml:50
 #, no-c-format
 msgid "table per concrete class"
 msgstr "tabela por classe concreta"
 
 #. Tag: para
-#: inheritance_mapping.xml:56
 #, no-c-format
 msgid ""
 "In addition, Hibernate supports a fourth, slightly different kind of "
 "polymorphism:"
 msgstr ""
-"Adicionalmente, o Hibernate suporta uma quarta, um tipo levemente diferente "
-"de polimorfismo:"
+"Além disso, o Hibernate suporta um quarto tipo de polimorfismo um pouco "
+"diferente:"
 
 #. Tag: para
-#: inheritance_mapping.xml:63
 #, no-c-format
 msgid "implicit polymorphism"
 msgstr "polimorfismo implícito"
 
 #. Tag: para
-#: inheritance_mapping.xml:69
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to use different mapping strategies for different branches of "
 "the same inheritance hierarchy. You can then make use of implicit "
@@ -83,20 +177,19 @@
 "<literal>&lt;join&gt;</literal> elements (see below for an example)."
 msgstr ""
 "É possível usar diferentes estratégias de mapeamento para diferentes "
-"ramificações da mesma hierarquia de herança, e então fazer uso do "
-"polimorfismo implícito para alcançar polimorfismo através da hierarquia "
-"completa. De qualquer forma, O Hibernate não suporta a mistura de "
-"mapeamentos <literal>&lt;subclass&gt;</literal>, and <literal>&lt;joined-"
-"subclass&gt;</literal> e <literal>&lt;union-subclass&gt;</literal> dentro do "
-"mesmo elemento raiz <literal>&lt;class&gt;</literal>. É possível usar junto "
-"às estratégias tabela por hierarquia e a tabela por subclasse, abaixo do "
+"ramificações da mesma hierarquia de herança. Você pode fazer uso do "
+"polimorfismo implícito para alcançá-lo através da hierarquia completa. De "
+"qualquer forma, o Hibernate não suporta a mistura de mapeamentos "
+"<literal>&lt;subclass&gt;</literal>, <literal>&lt;joined-subclass&gt;</"
+"literal> e <literal>&lt;union-subclass&gt;</literal> dentro do mesmo "
+"elemento raíz <literal>&lt;class&gt;</literal>. É possível usar, junto às "
+"estratégias, uma tabela por hierarquia e tabela por subclasse, abaixo do "
 "mesmo elemento <literal>&lt;class&gt;</literal>, combinando os elementos "
 "<literal>&lt;subclass&gt;</literal> e <literal>&lt;join&gt;</literal> (veja "
 "abaixo)."
 
 #. Tag: para
-#: inheritance_mapping.xml:83
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to define <literal>subclass</literal>, <literal>union-"
 "subclass</literal>, and <literal>joined-subclass</literal> mappings in "
@@ -110,146 +203,75 @@
 "defined as superclasses before subclasses."
 msgstr ""
 "É possível definir mapeamentos <literal>subclass</literal>, <literal>union-"
-"subclass</literal>, e <literal>joined-subclass</literal> em documentos de "
+"subclass</literal> e <literal>joined-subclass</literal> em documentos de "
 "mapeamento separados, diretamente abaixo de <literal>hibernate-mapping</"
-"literal>. Isso permite a você estender uma hierarquia de classes apenas "
-"adicionando um novo arquivo de mapeamento. Você deve especificar um atributo "
+"literal>. Isso permite que você estenda uma hierarquia de classes apenas "
+"adicionando um novo arquivo de mapeamento. Você deve especificar uma função "
 "<literal>extends</literal> no mapeamento da subclasse, nomeando uma "
-"superclasse previamente mapeada. Nota: Anteriormente esta característica "
-"fazia o ordenamento dos documentos de mapeamento importantes. Desde o "
-"Hibernate3, o ordenamento dos arquivos de mapeamento não importa quando "
-"usamos a palavra chave extends. O ordenamento dentro de um arquivo de "
-"mapeamento simples ainda necessita ser definido como superclasse antes de "
-"subclasse."
+"superclasse previamente mapeada. Anteriormente esta característica fazia o "
+"ordenamento dos documentos de mapeamento importantes. Desde o Hibernate3, o "
+"ordenamento dos arquivos de mapeamento não importa quando usamos a palavra "
+"chave extends. O ordenamento dentro de um arquivo de mapeamento simples "
+"ainda necessita ser definido como superclasse antes de subclasse."
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:94
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-" <hibernate-mapping>\n"
-"     <subclass name=\"DomesticCat\" extends=\"Cat\" discriminator-value=\"D"
-"\">\n"
-"          <property name=\"name\" type=\"string\"/>\n"
-"     </subclass>\n"
-" </hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:98
 #, no-c-format
 msgid "Table per class hierarchy"
 msgstr "Tabela por hierarquia de classes"
 
 #. Tag: para
-#: inheritance_mapping.xml:100
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Suppose we have an interface <literal>Payment</literal> with the "
 "implementors <literal>CreditCardPayment</literal>, <literal>CashPayment</"
 "literal>, and <literal>ChequePayment</literal>. The table per hierarchy "
 "mapping would display in the following way:"
 msgstr ""
-"Suponha que tenhamos uma interface <literal>Payment</literal>, com sua "
+"Vamos supor que temos uma interface <literal>Payment</literal>, com sua "
 "implementação <literal>CreditCardPayment</literal>, <literal>CashPayment</"
-"literal>, <literal>ChequePayment</literal>. O mapeamento da tabela por "
+"literal> e <literal>ChequePayment</literal>. O mapeamento da tabela por "
 "hierarquia seria parecido com:"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:107
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        ...\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: inheritance_mapping.xml:109
-#, fuzzy, no-c-format
-msgid ""
 "Exactly one table is required. There is a limitation of this mapping "
 "strategy: columns declared by the subclasses, such as <literal>CCTYPE</"
 "literal>, cannot have <literal>NOT NULL</literal> constraints."
 msgstr ""
-"Exactly one table is required. There is one big limitation of this mapping "
-"strategy: columns declared by the subclasses, such as <literal>CCTYPE</"
-"literal>, may not have <literal>NOT NULL</literal> constraints."
+"É requisitado exatamente uma tabela. Existe uma grande limitação desta "
+"estratégia de mapeamento: colunas declaradas por subclasses, tais como "
+"<literal>CCTYPE</literal>, podem não ter restrições <literal>NOT NULL</"
+"literal>. "
 
 #. Tag: title
-#: inheritance_mapping.xml:118
 #, no-c-format
 msgid "Table per subclass"
 msgstr "Tabela por subclasse"
 
 #. Tag: para
-#: inheritance_mapping.xml:120
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A table per subclass mapping looks like this:"
-msgstr "Um mapeamento de tabela por subclasse seria parecido com:"
+msgstr "Um mapeamento de tabela por subclasse seria parecido com: "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:124
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <joined-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: inheritance_mapping.xml:126
-#, fuzzy, no-c-format
-msgid ""
 "Four tables are required. The three subclass tables have primary key "
 "associations to the superclass table so the relational model is actually a "
 "one-to-one association."
 msgstr ""
-"Quatro tabelas são necessárias. As três tabelas subclasses possuem "
-"associação de chave primária para a tabela de superclasse (então o modelo "
-"relacional é atualmente uma associação de um-para-um)."
+"São necessárias quatro tabelas. As três tabelas subclasses possuem "
+"associação de chave primária para a tabela de superclasse, desta maneira o "
+"modelo relacional é atualmente uma associação de um-para-um."
 
 #. Tag: title
-#: inheritance_mapping.xml:135
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Table per subclass: using a discriminator"
-msgstr "Tabela por subclasse, usando um discriminador"
+msgstr "Tabela por subclasse: usando um discriminador"
 
 #. Tag: para
-#: inheritance_mapping.xml:137
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's implementation of table per subclass does not require a "
 "discriminator column. Other object/relational mappers use a different "
@@ -260,107 +282,41 @@
 "strategy, you can combine the use of <literal>&lt;subclass&gt;</literal> and "
 "<literal>&lt;join&gt;</literal>, as follows:"
 msgstr ""
-"Note que a implementação de tabela por subclasse do Hibernate não necessita "
-"de coluna de discriminador. Outro mapeador objeto/relacional usa uma "
-"implementação diferente de tabela por subclasse, que necessita uma coluna "
-"com o tipo discriminador na tabela da superclasse. A abordagem escolhida "
-"pelo Hibernate é muito mais difícil de implementar, porém de forma "
-"argumentável mais correto de um ponto de vista relacional. Se você deseja "
-"utilizar uma coluna discriminadora com a estratégia tabela por subclasse, "
-"você pode combinar o uso de <literal>&lt;subclass&gt;</literal> e "
-"<literal>&lt;join&gt;</literal>, dessa maneira:"
+"A implementação de tabela por subclasse do Hibernate não necessita de coluna "
+"de discriminador. Outro mapeador objeto/relacional usa uma implementação "
+"diferente de tabela por subclasse, que necessita uma coluna com o tipo "
+"discriminador na tabela da superclasse. A abordagem escolhida pelo Hibernate "
+"é muito mais difícil de implementar, porém mais correto de um ponto de vista "
+"relacional. Se você deseja utilizar uma coluna discriminadora com a "
+"estratégia tabela por subclasse, você poderá combinar o uso de <literal>&lt;"
+"subclass&gt;</literal> e <literal>&lt;join&gt;</literal>, dessa maneira:"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:149
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <join table=\"CREDIT_PAYMENT\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        <join table=\"CASH_PAYMENT\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        <join table=\"CHEQUE_PAYMENT\" fetch=\"select\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:151
 #, no-c-format
 msgid ""
 "The optional <literal>fetch=\"select\"</literal> declaration tells Hibernate "
 "not to fetch the <literal>ChequePayment</literal> subclass data using an "
 "outer join when querying the superclass."
 msgstr ""
-"The optional <literal>fetch=\"select\"</literal> declaration tells Hibernate "
-"not to fetch the <literal>ChequePayment</literal> subclass data using an "
-"outer join when querying the superclass. A declaração opcional "
-"fetch=”select” diz ao Hibernate para não buscar os dados da subclasse "
-"ChequePayment, quando usar um outer join pesquisando pela superclasse."
+"A declaração opcional <literal>fetch=\"select\"</literal> diz ao Hibernate "
+"para não buscar os dados da subclasse <literal>ChequePayment</literal>, "
+"quando usar uma união externa pesquisando a superclasse."
 
 #. Tag: title
-#: inheritance_mapping.xml:160
 #, no-c-format
 msgid "Mixing table per class hierarchy with table per subclass"
-msgstr ". Misturando tabela por hierarquia de classes com tabela por subclasse"
+msgstr "Mesclar tabela por hierarquia de classes com tabela por subclasse"
 
 #. Tag: para
-#: inheritance_mapping.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can even mix the table per hierarchy and table per subclass strategies "
 "using the following approach:"
 msgstr ""
-"Você pode até mesmo misturar a estratégia de tabela por hierarquia e tabela "
-"por subclasse usando esta abordagem:"
+"Você pode até mesmo mesclar a estratégia de tabela por hierarquia e tabela "
+"por subclasse usando esta abordagem:  "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <join table=\"CREDIT_PAYMENT\">\n"
-"            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        ...\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:169
 #, no-c-format
 msgid ""
 "For any of these mapping strategies, a polymorphic association to the root "
@@ -368,59 +324,25 @@
 "</literal>."
 msgstr ""
 "Para qualquer uma dessas estratégias de mapeamento, uma associação "
-"polimórfica para a classe raiz <literal>Payment</literal> deve ser mapeada "
+"polimórfica para a classe raíz <literal>Payment</literal> deve ser mapeada "
 "usando <literal>&lt;many-to-one&gt;</literal>."
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:175
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"payment\" column=\"PAYMENT_ID\" class=\"Payment"
-"\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:180
 #, no-c-format
 msgid "Table per concrete class"
 msgstr "Tabela por classe concreta"
 
 #. Tag: para
-#: inheritance_mapping.xml:182
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are two ways we can map the table per concrete class strategy. First, "
 "you can use <literal>&lt;union-subclass&gt;</literal>."
 msgstr ""
 "Existem duas formas que poderíamos usar a respeito da estratégia de "
 "mapeamento de tabela por classe concreta. A primeira é usar <literal>&lt;"
-"union-subclass&gt;</literal>.."
+"union-subclass&gt;</literal>. "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:187
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"sequence\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <union-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </union-subclass>\n"
-"    <union-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        ...\n"
-"    </union-subclass>\n"
-"    <union-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        ...\n"
-"    </union-subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:189
 #, no-c-format
 msgid ""
 "Three tables are involved for the subclasses. Each table defines columns for "
@@ -430,8 +352,7 @@
 "para todas as propriedades da classe, incluindo propriedades herdadas."
 
 #. Tag: para
-#: inheritance_mapping.xml:194
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The limitation of this approach is that if a property is mapped on the "
 "superclass, the column name must be the same on all subclass tables. The "
@@ -441,68 +362,34 @@
 msgstr ""
 "A limitação dessa abordagem é que se uma propriedade é mapeada na "
 "superclasse, o nome da coluna deve ser o mesmo em todas as tabelas das "
-"subclasses. (Nós devemos melhorar isto em um futuro release do Hibernate). A "
-"estratégia do gerador de identidade não é permitida em união de subclasses"
-"(union-subclass) herdadas, na verdade a fonte de chave primária deve ser "
-"compartilhada através de todas subclasses unidas da hierarquia."
+"subclasses. A estratégia do gerador identidade não é permitida na união da "
+"herança de sub-classe. A fonte de chave primária deve ser compartilhada "
+"através de todas subclasses unidas da hierarquia."
 
 #. Tag: para
-#: inheritance_mapping.xml:203
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your superclass is abstract, map it with <literal>abstract=\"true\"</"
 "literal>. If it is not abstract, an additional table (it defaults to "
 "<literal>PAYMENT</literal> in the example above), is needed to hold "
 "instances of the superclass."
 msgstr ""
-"Se sua superclasse é abstrata, mapeie ela com <literal>abstract=\"true\"</"
-"literal>. Claro, que se ela não for abstrata, uma tabela (padrão para "
-"<literal>PAYMENT</literal> no exemplo acima) adicional é necessária para "
+"Se sua superclasse é abstrata, mapeie-a com <literal>abstract=\"true\"</"
+"literal>. Claro, que se ela não for abstrata, uma tabela adicional (padrão "
+"para <literal>PAYMENT</literal> no exemplo acima), será necessária para "
 "segurar as instâncias da superclasse."
 
 #. Tag: title
-#: inheritance_mapping.xml:213
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Table per concrete class using implicit polymorphism"
-msgstr "Tabela por classe concreta, usando polimorfismo implícito"
+msgstr "Tabela por classe concreta usando polimorfismo implícito"
 
 #. Tag: para
-#: inheritance_mapping.xml:215
 #, no-c-format
 msgid "An alternative approach is to make use of implicit polymorphism:"
 msgstr "Uma abordagem alternativa é fazer uso de polimorfismo implícito:"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:219
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-"    ...\n"
-"</class>\n"
-"\n"
-"<class name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CASH_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-"    ...\n"
-"</class>\n"
-"\n"
-"<class name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CHEQUE_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:221
 #, fuzzy, no-c-format
 msgid ""
 "Notice that the <literal>Payment</literal> interface is not mentioned "
@@ -510,28 +397,26 @@
 "mapped in each of the subclasses. If you want to avoid duplication, consider "
 "using XML entities (for example, <literal>[ &lt;!ENTITY allproperties SYSTEM "
 "\"allproperties.xml\"&gt; ]</literal> in the <literal>DOCTYPE</literal> "
-"declaration and <literal>&amp;allproperties;</literal> in the mapping)."
+"declaration and <literal>&amp;allproperties&semi;</literal> in the mapping)."
 msgstr ""
 "Veja que em nenhum lugar mencionamos a interface <literal>Payment</literal> "
-"explicitamente. Também preste atenção que propriedades de <literal>Payment</"
-"literal> são mapeadas em cada uma das subclasses. Se você quer evitar "
-"duplicação, considere usar entidades de XML (ex. (e.g. <literal>[ &lt;!"
-"ENTITY allproperties SYSTEM \"allproperties.xml\"&gt; ]</literal> na "
-"declaração do <literal>DOCTYPE</literal> e <literal>&amp;allproperties;</"
-"literal> no mapeamento)."
+"explicitamente. Note também que propriedades de <literal>Payment</literal> "
+"são mapeadas em cada uma das subclasses. Se você quiser evitar duplicação, "
+"considere usar entidades de XML (ex. <literal>[ &lt;!ENTITY allproperties "
+"SYSTEM \"allproperties.xml\"&gt; ]</literal> na declaração do "
+"<literal>DOCTYPE</literal> e <literal>&amp; allproperties;</literal> no "
+"mapeamento).  "
 
 #. Tag: para
-#: inheritance_mapping.xml:231
 #, no-c-format
 msgid ""
 "The disadvantage of this approach is that Hibernate does not generate SQL "
 "<literal>UNION</literal>s when performing polymorphic queries."
 msgstr ""
 "A desvantagem dessa abordagem é que o Hibernate não gera <literal>UNION</"
-"literal>s SQL quando executa pesquisas polimórficas."
+"literal>s de SQL quando executa pesquisas polimórficas."
 
 #. Tag: para
-#: inheritance_mapping.xml:236
 #, no-c-format
 msgid ""
 "For this mapping strategy, a polymorphic association to <literal>Payment</"
@@ -540,28 +425,13 @@
 "Para essa estratégia, uma associação polimórfica para <literal>Payment</"
 "literal> geralmente é mapeada usando <literal>&lt;any&gt;</literal>."
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:241
-#, no-c-format
-msgid ""
-"<![CDATA[<any name=\"payment\" meta-type=\"string\" id-type=\"long\">\n"
-"    <meta-value value=\"CREDIT\" class=\"CreditCardPayment\"/>\n"
-"    <meta-value value=\"CASH\" class=\"CashPayment\"/>\n"
-"    <meta-value value=\"CHEQUE\" class=\"ChequePayment\"/>\n"
-"    <column name=\"PAYMENT_CLASS\"/>\n"
-"    <column name=\"PAYMENT_ID\"/>\n"
-"</any>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:246
 #, no-c-format
 msgid "Mixing implicit polymorphism with other inheritance mappings"
-msgstr "Misturando polimorfismo implícito com outros mapeamentos de herança"
+msgstr "Mesclando polimorfismo implícito com outros mapeamentos de herança"
 
 #. Tag: para
-#: inheritance_mapping.xml:248
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Since the subclasses are each mapped in their own <literal>&lt;class&gt;</"
 "literal> element, and since <literal>Payment</literal> is just an "
@@ -569,50 +439,16 @@
 "inheritance hierarchy. You can still use polymorphic queries against the "
 "<literal>Payment</literal> interface."
 msgstr ""
-"Ainda existe uma coisa para ser observada com respeito a este mapeamento. "
-"Desde que as subclasses sejam mapeadas em seu próprio elemento <literal>&lt;"
-"class&gt;</literal> (e desde que <literal>Payment</literal> seja apenas uma "
-"interface), cada uma das subclasses pode ser facilmente parte de uma outra "
-"hierarquia de herança! (E você ainda pode usar pesquisas polimórficas em "
-"cima da interface <literal>Payment</literal>.)"
+"Existe ainda um item a ser observado sobre este mapeamento. Como as "
+"subclasses são mapeadas em seu próprio elemento <literal>&lt;class&gt;</"
+"literal>, e como o <literal>Payment</literal> é apenas uma interface, cada "
+"uma das subclasses pode ser facilmente parte de uma outra hierarquia de "
+"herança! (E você ainda pode usar pesquisas polimórficas em cima da interface "
+"<literal>Payment</literal>.)"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:256
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"CREDIT_CARD\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"MasterCardPayment\" discriminator-value=\"MDC\"/>\n"
-"    <subclass name=\"VisaPayment\" discriminator-value=\"VISA\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"NonelectronicTransaction\" table=\"NONELECTRONIC_TXN\">\n"
-"    <id name=\"id\" type=\"long\" column=\"TXN_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    ...\n"
-"    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: inheritance_mapping.xml:258
-#, fuzzy, no-c-format
-msgid ""
 "Once again, <literal>Payment</literal> is not mentioned explicitly. If we "
 "execute a query against the <literal>Payment</literal> interface, for "
 "example <literal>from Payment</literal>, Hibernate automatically returns "
@@ -623,21 +459,19 @@
 msgstr ""
 "Mais uma vez, nós não mencionamos <literal>Payment</literal> explicitamente. "
 "Se nós executarmos uma pesquisa em cima da interface <literal>Payment</"
-"literal> – por exemplo, <literal>from Payment</literal> – o Hibernate "
-"retorna automaticamente instâncias de <literal>CreditCardPayment</literal> "
-"(e suas subclasses, desde que elas também implementem <literal>Payment</"
-"literal>), <literal>CashPayment</literal> e <literal>ChequePayment</literal> "
-"mas não as instâncias de <literal>NonelectronicTransaction</literal>."
+"literal>, por exemplo, <literal>from Payment</literal> – o Hibernate retorna "
+"automaticamente instâncias de <literal>CreditCardPayment</literal> (e suas "
+"subclasses, desde que elas também implementem <literal>Payment</literal>), "
+"<literal>CashPayment</literal> e <literal>ChequePayment</literal> mas não as "
+"instâncias de <literal>NonelectronicTransaction</literal>. "
 
 #. Tag: title
-#: inheritance_mapping.xml:273
 #, no-c-format
 msgid "Limitations"
 msgstr "Limitações"
 
 #. Tag: para
-#: inheritance_mapping.xml:275
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are limitations to the \"implicit polymorphism\" approach to the table "
 "per concrete-class mapping strategy. There are somewhat less restrictive "
@@ -646,204 +480,192 @@
 "Existem certas limitações para a abordagem do \"polimorfismo implícito\" "
 "comparada com a estratégia de mapeamento da tabela por classe concreta. "
 "Existe uma limitação um tanto menos restritiva para mapeamentos <literal>&lt;"
-"union-subclass&gt;</literal>."
+"union-subclass&gt;</literal>. "
 
 #. Tag: para
-#: inheritance_mapping.xml:282
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The following table shows the limitations of table per concrete-class "
 "mappings, and of implicit polymorphism, in Hibernate."
 msgstr ""
-"A tabela seguinte demonstra as limitações do mapeamento de tabela por classe "
+"A seguinte tabela demonstra as limitações do mapeamento de tabela por classe "
 "concreta e do polimorfismo implícito no Hibernate."
 
 #. Tag: title
-#: inheritance_mapping.xml:288
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Features of inheritance mappings"
-msgstr "Features of inheritance mappings"
+msgstr "Mapeamento de Herança "
 
 #. Tag: entry
-#: inheritance_mapping.xml:301
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Inheritance strategy"
-msgstr "Estratégia de Herança"
+msgstr "Mapeamento de Herança "
 
 #. Tag: entry
-#: inheritance_mapping.xml:302
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Polymorphic many-to-one"
-msgstr "muitos-para-um Polimórfico"
+msgstr "muitos-para-um Polimórfico: <code>&lt;any&gt;</code>"
 
 #. Tag: entry
-#: inheritance_mapping.xml:303
 #, no-c-format
 msgid "Polymorphic one-to-one"
-msgstr "um-para-um Polimórfico"
+msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:304
 #, no-c-format
 msgid "Polymorphic one-to-many"
-msgstr "um-para-muitos Polimórfico"
+msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:305
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Polymorphic many-to-many"
-msgstr "muitos-para-muitos Polimórfico"
+msgstr "muitos-para-um Polimórfico: <code>&lt;any&gt;</code>"
 
 #. Tag: entry
-#: inheritance_mapping.xml:306
 #, no-c-format
 msgid "Polymorphic <literal>load()/get()</literal>"
 msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:307
 #, no-c-format
 msgid "Polymorphic queries"
-msgstr "Pesquisas Polimórficas"
+msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:308
 #, no-c-format
 msgid "Polymorphic joins"
-msgstr "Joins polimórficos"
+msgstr ""
 
 #. Tag: entry
-#: inheritance_mapping.xml:309
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Outer join fetching"
-msgstr "Outer join fetching"
+msgstr "A busca por união externa é suportada."
 
 #. Tag: entry
-#: inheritance_mapping.xml:314
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "table per class-hierarchy"
-msgstr "table per class-hierarchy"
+msgstr "tabela por hierarquia de classes"
 
-#. Tag: literal
-#: inheritance_mapping.xml:315 inheritance_mapping.xml:326
-#: inheritance_mapping.xml:337
+#. Tag: entry
 #, no-c-format
-msgid "&lt;many-to-one&gt;"
-msgstr "&lt;many-to-one&gt;"
+msgid "<literal>&lt;many-to-one&gt;</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:316 inheritance_mapping.xml:327
-#: inheritance_mapping.xml:338
+#. Tag: entry
 #, no-c-format
-msgid "&lt;one-to-one&gt;"
-msgstr "&lt;one-to-one&gt;"
+msgid "<literal>&lt;one-to-one&gt;</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:317 inheritance_mapping.xml:328
+#. Tag: entry
 #, no-c-format
-msgid "&lt;one-to-many&gt;"
-msgstr "&lt;one-to-many&gt;"
+msgid "<literal>&lt;one-to-many&gt;</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:318 inheritance_mapping.xml:329
-#: inheritance_mapping.xml:340
+#. Tag: entry
 #, no-c-format
-msgid "&lt;many-to-many&gt;"
-msgstr "&lt;many-to-many&gt;"
+msgid "<literal>&lt;many-to-many&gt;</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:319 inheritance_mapping.xml:330
-#: inheritance_mapping.xml:341
+#. Tag: entry
 #, no-c-format
-msgid "s.get(Payment.class, id)"
-msgstr "s.get(Payment.class, id)"
+msgid "<literal>s.get(Payment.class, id)</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:320 inheritance_mapping.xml:331
-#: inheritance_mapping.xml:342 inheritance_mapping.xml:353
+#. Tag: entry
 #, no-c-format
-msgid "from Payment p"
-msgstr "from Payment p"
+msgid "<literal>from Payment p</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:321 inheritance_mapping.xml:332
-#: inheritance_mapping.xml:343
-#, no-c-format
-msgid "from Order o join o.payment p"
-msgstr "from Order o join o.payment p"
-
-#. Tag: emphasis
-#: inheritance_mapping.xml:322 inheritance_mapping.xml:333
-#: inheritance_mapping.xml:344
-#, no-c-format
-msgid "supported"
-msgstr "supported"
-
 #. Tag: entry
-#: inheritance_mapping.xml:325
 #, fuzzy, no-c-format
-msgid "<entry>table per subclass</entry>"
+msgid "<literal>from Order o join o.payment p</literal>"
+msgstr "Junções polimórficas: <code>from Order o join o.payment p</code>"
+
+#. Tag: entry
+#, no-c-format
+msgid "<emphasis>supported</emphasis>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"tabela por subclasse\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"table per subclass"
 
 #. Tag: entry
-#: inheritance_mapping.xml:336
 #, no-c-format
 msgid "table per concrete-class (union-subclass)"
-msgstr "table per concrete-class (union-subclass)"
+msgstr "tabela por classe concreta (subclasses de união)"
 
 #. Tag: entry
-#: inheritance_mapping.xml:339
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "<literal>&lt;one-to-many&gt;</literal> (for <literal>inverse=\"true\"</"
 "literal> only)"
 msgstr ""
+"Um-para-muito polimórfico: <literal>&lt;one-to-many&gt;</literal> (somente "
+"para <literal>inverse=\"true\"</literal>)"
 
 #. Tag: entry
-#: inheritance_mapping.xml:347
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "table per concrete class (implicit polymorphism)"
-msgstr "table per concrete class (implicit polymorphism)"
+msgstr "tabela por classe concreta (polimorfismo implícito) "
 
-#. Tag: literal
-#: inheritance_mapping.xml:348
+#. Tag: entry
 #, no-c-format
-msgid "&lt;any&gt;"
-msgstr "&lt;any&gt;"
+msgid "<literal>&lt;any&gt;</literal>"
+msgstr ""
 
-#. Tag: emphasis
-#: inheritance_mapping.xml:349 inheritance_mapping.xml:350
-#: inheritance_mapping.xml:354 inheritance_mapping.xml:355
+#. Tag: entry
 #, no-c-format
-msgid "not supported"
-msgstr "not supported"
+msgid "<emphasis>not supported</emphasis>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:351
+#. Tag: entry
 #, no-c-format
-msgid "&lt;many-to-any&gt;"
-msgstr "&lt;many-to-any&gt;"
+msgid "<literal>&lt;many-to-any&gt;</literal>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:352
-#, no-c-format
+#. Tag: entry
+#, fuzzy, no-c-format
 msgid ""
-"s.createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()"
+"<literal>s.createCriteria(Payment.class).add( Restrictions.idEq(id) )."
+"uniqueResult()</literal>"
 msgstr ""
-"s.createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()"
+"<literal>load()</literal> ou <literal>get()</literal> polimórfico: <code>s."
+"criarCritério(Payment.class).adicionar( Restrições.idEq(id) ).Resultado único"
+"()</code>"
 
-#~ msgid "load()/get()"
-#~ msgstr "load()/get()"
+#~ msgid "table per class-heirarchy"
+#~ msgstr "tabela por hierarquia de classe"
 
-#~ msgid "Polymorphic <placeholder-1/>"
-#~ msgstr "<placeholder-1/> Polimórfico"
+#~ msgid "Polymorphic many-to-one: <code>&lt;many-to-one&gt;</code>"
+#~ msgstr "Muitos-para-um polimórfico: <code>&lt;many-to-one&gt;</code>"
 
-#~ msgid "inverse=\"true\""
-#~ msgstr "inverse=\"true\""
+#~ msgid "Polymorphic one-to-one: <code>&lt;one-to-one&gt;</code>"
+#~ msgstr "Um-para-um polimórfico: <code>&lt;one-to-one&gt;</code>"
 
-#~ msgid "<placeholder-1/> (for <placeholder-2/> only)"
-#~ msgstr "<placeholder-1/> (for <placeholder-2/> only)"
+#~ msgid "Polymorphic one-to-many: <code>&lt;one-to-many&gt;</code>"
+#~ msgstr "Um-para-muitos polimórfico: <code>&lt;one-to-many&gt;</code>"
+
+#~ msgid "Polymorphic many-to-many: <code>&lt;many-to-many&gt;</code>"
+#~ msgstr "Muitos-para-muitos polimórfico: <code>&lt;many-to-many&gt;</code>"
+
+#~ msgid ""
+#~ "Polymorphic <literal>load()</literal> or <literal>get()</literal>: "
+#~ "<code>s.get(Payment.class, id)</code>"
+#~ msgstr ""
+#~ "<literal>load()</literal> ou <literal>get()</literal> polimórfico: "
+#~ "<code>s.get(Payment.class, id)</code>>"
+
+#~ msgid "Polymorphic queries: <code>from Payment p</code>"
+#~ msgstr "Consultas polimórficas: <code>from Payment p</code>"
+
+#~ msgid ""
+#~ "Polymorphic one-to-one, polymorphic one-to-many, polymorphic joins, and "
+#~ "outer join fetching are not supported."
+#~ msgstr ""
+#~ "Um-para-um polimórfico, um-para-muitos polimórfico, junções polimórficas "
+#~ "e a busca de união externa não são suportadas."
+
+#, fuzzy
+#~ msgid "<para>table per subclass</para>"
+#~ msgstr "tabela por subclasse"
+
+#, fuzzy
+#~ msgid "<term>table per subclass</term>"
+#~ msgstr "tabela por subclasse"

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/performance.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/performance.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/performance.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,51 +1,153 @@
+# translation of performance.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: performance\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-08-17 20:22+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-19 17:17+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: performance.xml:29
 #, no-c-format
 msgid "Improving performance"
-msgstr "Aumentando a performance"
+msgstr "Aumentando o desempenho"
 
 #. Tag: title
-#: performance.xml:32
 #, no-c-format
 msgid "Fetching strategies"
-msgstr "Estratégias de Fetching"
+msgstr "Estratégias de Busca "
 
 #. Tag: para
-#: performance.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate uses a <emphasis>fetching strategy</emphasis> to retrieve "
 "associated objects if the application needs to navigate the association. "
 "Fetch strategies can be declared in the O/R mapping metadata, or over-ridden "
 "by a particular HQL or <literal>Criteria</literal> query."
 msgstr ""
-"Uma <emphasis>estratégia de fetching</emphasis> é a estratégia que o "
-"Hibernate irá usar para buscar objetos associados se a aplicação precisar "
-"navegar pela associação. Estratégias de Fetch podem ser declaradas nos "
-"metadados de mapeamento O/R, ou sobrescritos por uma query HQL ou query com "
-"<literal>Criteria</literal>."
+"Uma <emphasis>estratégia de busca</emphasis> é a estratégia que o Hibernate "
+"irá usar para recuperar objetos associados se a aplicação precisar navegar "
+"pela associação. Estratégias de Busca podem ser declaradas nos metadados de "
+"mapeamento O/R, ou sobrescritos por uma consulta HQL ou consulta com "
+"<literal>Criteria</literal>. "
 
 #. Tag: para
-#: performance.xml:41
 #, no-c-format
 msgid "Hibernate3 defines the following fetching strategies:"
-msgstr "Hibernate3 define as seguintes estratégias de fetching:"
+msgstr "Hibernate3 define as seguintes estratégias de busca:"
 
 #. Tag: para
-#: performance.xml:47
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Join fetching</emphasis>: Hibernate retrieves the associated "
 "instance or collection in the same <literal>SELECT</literal>, using an "
@@ -53,11 +155,10 @@
 msgstr ""
 "<emphasis>Join fetching</emphasis> - o Hibernate busca o objeto ou coleção "
 "associada no mesmo <literal>SELECT</literal>, usando um <literal>OUTER JOIN</"
-"literal>."
+"literal>. "
 
 #. Tag: para
-#: performance.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Select fetching</emphasis>: a second <literal>SELECT</literal> is "
 "used to retrieve the associated entity or collection. Unless you explicitly "
@@ -66,12 +167,11 @@
 msgstr ""
 "<emphasis>Select fetching</emphasis> - um segundo <literal>SELECT</literal> "
 "é usado para buscar a entidade ou coleção associada. A menos que você "
-"desabilite lazy fetching especificando <literal>lazy=\"false\"</literal>, "
-"esse segundo SELECT será executado apenas quando você acessar a associação."
+"desabilite a busca lazy, especificando <literal>lazy=\"false\"</literal>, "
+"esse segundo SELECT será executado apenas quando você acessar a associação. "
 
 #. Tag: para
-#: performance.xml:63
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Subselect fetching</emphasis>: a second <literal>SELECT</literal> "
 "is used to retrieve the associated collections for all entities retrieved in "
@@ -80,60 +180,51 @@
 "be executed when you access the association."
 msgstr ""
 "<emphasis>Subselect fetching</emphasis> - um segundo <literal>SELECT</"
-"literal> será usado para buscar as coleções associadas de todas as entidades "
-"buscadas na query ou fetch anterior. A menos que você desabilite lazy "
-"fetching especificando <literal>lazy=\"false\"</literal>, esse segundo "
-"SELECT será executado apenas quando você acessar a associação."
+"literal> será usado para recuperar as coleções associadas de todas as "
+"entidades recuperadas em uma consulta ou busca anterior. A menos que você "
+"desabilite a busca lazy especificando <literal>lazy=\"false\"</literal>, "
+"esse segundo SELECT será executado apenas quando você acessar a associação.  "
 
 #. Tag: para
-#: performance.xml:72
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Batch fetching</emphasis>: an optimization strategy for select "
 "fetching. Hibernate retrieves a batch of entity instances or collections in "
 "a single <literal>SELECT</literal> by specifying a list of primary or "
 "foreign keys."
 msgstr ""
-"<emphasis>Batch fetching</emphasis> - uma opção de otimização para o Select "
-"Fetching – O Hibernate busca um lote de instâncias ou entidades usando um "
-"único <literal>SELECT</literal>, especificando uma lista de chaves primárias "
-"ou chaves estrangeiras."
+"<emphasis>Batch fetching</emphasis> - uma opção de otimização para "
+"selecionar a busca. O Hibernate recupera um lote de instâncias ou entidades "
+"usando um único <literal>SELECT</literal>, especificando uma lista de chaves "
+"primárias ou chaves externas."
 
 #. Tag: para
-#: performance.xml:81
 #, no-c-format
 msgid "Hibernate also distinguishes between:"
 msgstr "O Hibernate distingue também entre:"
 
 #. Tag: para
-#: performance.xml:87
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Immediate fetching</emphasis>: an association, collection or "
 "attribute is fetched immediately when the owner is loaded."
 msgstr ""
-"<emphasis>Immediate fetching</emphasis> - uma associação, coleção ou "
-"atributo é buscado como ela é carregada (Qual SQL é usado). Não se confuda "
-"com eles! Nós usamos fetch para melhorar a performance. Nós podemos usar "
-"lazy para definir um contrato para qual dado é sempre disponível em qualquer "
-"instância desanexada de uma classe qualquer. imediatamente, quando o pai é "
-"carregado."
+"<emphasis>Immediate fetching</emphasis> - uma associação, coleção ou função "
+"é imediatamente recuperada, quando o proprietário for carregado. "
 
 #. Tag: para
-#: performance.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Lazy collection fetching</emphasis>: a collection is fetched when "
 "the application invokes an operation upon that collection. This is the "
 "default for collections."
 msgstr ""
-"<emphasis>Lazy collection fetching</emphasis> - a coleção é buscada quando a "
-"aplicação invoca uma operação sobre aquela coleção (Esse é o padrão para "
-"coleções)"
+"<emphasis>Lazy collection fetching</emphasis> - a coleção é recuperada "
+"quando a aplicação invoca uma operação sobre aquela coleção. Esse é o padrão "
+"para coleções."
 
 #. Tag: para
-#: performance.xml:100
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>\"Extra-lazy\" collection fetching</emphasis>: individual elements "
 "of the collection are accessed from the database as needed. Hibernate tries "
@@ -141,25 +232,24 @@
 "is suitable for large collections."
 msgstr ""
 "<emphasis>\"Extra-lazy\" collection fetching</emphasis> - elementos "
-"individuais de uma coleção são acessados do banco de dados quando preciso. O "
-"Hibernate tenta não buscar a coleção inteira dentro da memória ao menos que "
-"seja absolutamente preciso. (indicado para coleções muito grandes)"
+"individuais de uma coleção são acessados a partir do banco de dados quando "
+"necessário. O Hibernate tenta não buscar a coleção inteira dentro da memória "
+"a menos que seja absolutamente necessário. Isto é indicado para coleções "
+"muito grandes."
 
 #. Tag: para
-#: performance.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Proxy fetching</emphasis>: a single-valued association is fetched "
 "when a method other than the identifier getter is invoked upon the "
 "associated object."
 msgstr ""
-"<emphasis>Proxy fetching</emphasis> - uma associação de um valor é carregada "
+"<emphasis>Proxy fetching</emphasis>: uma associação de um valor é carregada "
 "quando um método diferente do getter do identificador é invocado sobre o "
 "objeto associado."
 
 #. Tag: para
-#: performance.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>\"No-proxy\" fetching</emphasis>: a single-valued association is "
 "fetched when the instance variable is accessed. Compared to proxy fetching, "
@@ -168,28 +258,26 @@
 "visible to the application. This approach requires buildtime bytecode "
 "instrumentation and is rarely necessary."
 msgstr ""
-"<emphasis>\"No-proxy\" fetching</emphasis> - uma associação de um valor é "
-"carregada quando a variável da instância é carregada. Comparada com a proxy "
-"fetching, esse método é menos preguiçoso (lazy)(a associação é carregada "
-"somente quando o identificador é acessada) mas é mais transparente, já que "
-"não há proxies visíveis para a aplicação. Esse método requer instrumentação "
-"de bytecodes em build-time e é raramente necessário."
+"<emphasis>\"No-proxy\" fetching</emphasis> - uma associação de um único "
+"valor é recuperada quando a variável da instância é acessada. Comparada à "
+"busca proxy, esse método é menos preguiçoso (lazy); a associação é buscada "
+"até mesmo quando somente o identificador é acessado. Ela é mais "
+"transparente, já que não há proxies visíveis para a aplicação. Esse método "
+"requer instrumentação de bytecodes em build-time e é raramente necessário."
 
 #. Tag: para
-#: performance.xml:125
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Lazy attribute fetching</emphasis>: an attribute or single valued "
 "association is fetched when the instance variable is accessed. This approach "
 "requires buildtime bytecode instrumentation and is rarely necessary."
 msgstr ""
-"<emphasis>Lazy attribute fetching</emphasis> - um atributo ou associação de "
-"um valor é carregada quanto a varíavel da instância é acessada. Esse método "
+"<emphasis>Lazy attribute fetching</emphasis>: um atributo ou associação de "
+"um valor é buscado quanto a varíavel da instância é acessada. Esse método "
 "requer instrumentação de bytecodes em build-time e é raramente necessário."
 
 #. Tag: para
-#: performance.xml:134
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We have two orthogonal notions here: <emphasis>when</emphasis> is the "
 "association fetched and <emphasis>how</emphasis> is it fetched. It is "
@@ -199,21 +287,19 @@
 "class."
 msgstr ""
 "Nós temos aqui duas noções ortogonais: <emphasis>quando</emphasis> a "
-"associação é carregada e <emphasis>como </emphasis> ela é carregada (Qual "
-"SQL é usado). Não se confuda com eles! Nós usamos <literal>fetch</literal> "
-"para melhorar a performance. Nós podemos usar lazy para definir um contrato "
+"associação é buscada e <emphasis>como</emphasis> ela é buscada. É importante "
+"que você não os confuda. Nós usamos <literal>fetch</literal> para ajustar o "
+"desempenho. Podemos usar <literal>lazy</literal> para definir um contrato "
 "para qual dado é sempre disponível em qualquer instância desconectada de uma "
-"classe qualquer."
+"classe particular."
 
 #. Tag: title
-#: performance.xml:143
 #, no-c-format
 msgid "Working with lazy associations"
-msgstr "Inicializando coleções e proxies"
+msgstr "Trabalhando com associações preguiçosas (lazy)"
 
 #. Tag: para
-#: performance.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "By default, Hibernate3 uses lazy select fetching for collections and lazy "
 "proxy fetching for single-valued associations. These defaults make sense for "
@@ -221,53 +307,31 @@
 msgstr ""
 "Por padrão, o Hibernate3 usa busca preguiçosa para coleções e busca "
 "preguiçosa com proxy para associações de um valor. Esses padrões fazem "
-"sentido para quase todas as associações em quase todas a aplicações."
+"sentido para quase todas as associações em quase todas a aplicações. "
 
 #. Tag: para
-#: performance.xml:151
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you set <literal>hibernate.default_batch_fetch_size</literal>, Hibernate "
 "will use the batch fetch optimization for lazy fetching. This optimization "
 "can also be enabled at a more granular level."
 msgstr ""
-"<emphasis>Veja:</emphasis> se voce setar <literal>hibernate."
-"default_batch_fetch_size</literal>, O Hibernate irá usar otimização de "
-"carregamento em lote para o carregamento preguiçoso(Essa otimização pode ser "
-"também habilitada em um nível mais fino)."
+"Se você ajustar <literal>hibernate. default_batch_fetch_size</literal>, o "
+"Hibernate irá usar otimização de busca em lote para a busca preguiçosa. Essa "
+"otimização pode ser também habilitada em um nível mais fino."
 
 #. Tag: para
-#: performance.xml:158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please be aware that access to a lazy association outside of the context of "
 "an open Hibernate session will result in an exception. For example:"
 msgstr ""
-"Porém, a busca preguiçosa tem um problema que você precisar saber. Acesso a "
-"associações preguiçosas fora do contexto de uma sessão aberta do Hibernate "
-"irá resultar numa exceção. Por exemplo:"
+"Perceba que o acesso a associações preguiçosas fora do contexto de uma "
+"sessão aberta do Hibernate irá resultar numa exceção. Por exemplo:"
 
-#. Tag: programlisting
-#: performance.xml:164
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[s = sessions.openSession();\n"
-"Transaction tx = s.beginTransaction();\n"
-"            \n"
-"User u = (User) s.createQuery(\"from User u where u.name=:userName\")\n"
-"    .setString(\"userName\", userName).uniqueResult();\n"
-"Map permissions = u.getPermissions();\n"
-"\n"
-"tx.commit();\n"
-"s.close();\n"
-"\n"
-"Integer accessLevel = (Integer) permissions.get(\"accounts\");  // Error!]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:166
-#, fuzzy, no-c-format
-msgid ""
 "Since the permissions collection was not initialized when the "
 "<literal>Session</literal> was closed, the collection will not be able to "
 "load its state. <emphasis>Hibernate does not support lazy initialization for "
@@ -275,14 +339,13 @@
 "from the collection to just before the transaction is committed."
 msgstr ""
 "Como a coleção de permissões não foi inicializada quando a <literal>Session</"
-"literal> foi fechada, a coleção não poderá carregar o seu estado. O "
-"Hibernate não suporta inicialização preguiçosa para objetos desconectados. "
-"Para consertar isso, é necessário mover o código que carrega a coleção para "
-"antes da transação ser comitada."
+"literal> for fechada, a coleção não poderá carregar o seu estado. "
+"<emphasis>O Hibernate não suporta inicialização preguiçosa para objetos "
+"desconectados</emphasis>. Para consertar isso, é necessário mover o código "
+"que carrega a coleção para logo antes da transação ser submetida. "
 
 #. Tag: para
-#: performance.xml:174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, you can use a non-lazy collection or association, by "
 "specifying <literal>lazy=\"false\"</literal> for the association mapping. "
@@ -296,11 +359,10 @@
 "associação. Porém, é pretendido que a inicialização preguiçosa seja usada "
 "por quase todas as coleções e associações. Se você definir muitas "
 "associações não preguiçosas em seu modelo de objetos, o Hibernate irá "
-"precisar carregar o banco de dados inteiro na memória em cada transação!"
+"precisar buscar no banco de dados inteiro da memória em cada transação."
 
 #. Tag: para
-#: performance.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "On the other hand, you can use join fetching, which is non-lazy by nature, "
 "instead of select fetching in a particular transaction. We will now explain "
@@ -308,48 +370,27 @@
 "choosing a fetch strategy are identical for single-valued associations and "
 "collections."
 msgstr ""
-"Por outro lado, nós geralmente escolhemos join fetching (que é não "
-"preguiçosa por natureza) ao invés de select fetching em uma transação "
-"particular. Nós iremos ver como customizar a estratégoa de busca. No "
-"Hibernate3, os mecanismos para escolher a estratégia de fetching são "
-"identicos para as associações simples e para coleções."
+"Por outro lado, nós geralmente escolhemos a busca de união (que não é "
+"preguiçosa por natureza) ao invés do selecionar busca em uma transação "
+"particular. Nós agora veremos como customizar a estratégia de busca. No "
+"Hibernate3, os mecanismos para escolher a estratégia de busca são idênticos "
+"para as associações de valor único e para coleções."
 
 #. Tag: title
-#: performance.xml:194
 #, no-c-format
 msgid "Tuning fetch strategies"
 msgstr "Personalizando as estratégias de busca"
 
 #. Tag: para
-#: performance.xml:196
 #, no-c-format
 msgid ""
 "Select fetching (the default) is extremely vulnerable to N+1 selects "
 "problems, so we might want to enable join fetching in the mapping document:"
 msgstr ""
-"O select fetching (o padrão) é extremamente vunerável para N+1 problemas em "
-"select, então nós iremos querer habilitar o join fetching no documento de "
-"mapeamento:"
+"O padrão selecionar busca, é extremamente vunerável aos problemas de seleção "
+"N+1, então habilitaremos a busca de união no documento de mapeamento:"
 
-#. Tag: programlisting
-#: performance.xml:201
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"permissions\" \n"
-"            fetch=\"join\">\n"
-"    <key column=\"userId\"/>\n"
-"    <one-to-many class=\"Permission\"/>\n"
-"</set]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: performance.xml:203
-#, no-c-format
-msgid "<![CDATA[<many-to-one name=\"mother\" class=\"Cat\" fetch=\"join\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:205
 #, no-c-format
 msgid ""
 "The <literal>fetch</literal> strategy defined in the mapping document "
@@ -359,46 +400,40 @@
 "afeta:"
 
 #. Tag: para
-#: performance.xml:211
 #, no-c-format
 msgid "retrieval via <literal>get()</literal> or <literal>load()</literal>"
 msgstr "recupera via <literal>get()</literal> ou <literal>load()</literal>"
 
 #. Tag: para
-#: performance.xml:216
 #, no-c-format
 msgid "retrieval that happens implicitly when an association is navigated"
 msgstr ""
 "Recuperações que acontecem implicitamente quando navegamos por uma associação"
 
 #. Tag: para
-#: performance.xml:221
 #, no-c-format
 msgid "<literal>Criteria</literal> queries"
-msgstr "<literal>Criteria</literal> queries"
+msgstr "consultas por <literal>Criteria</literal> "
 
 #. Tag: para
-#: performance.xml:226
 #, no-c-format
 msgid "HQL queries if <literal>subselect</literal> fetching is used"
-msgstr "buscas por HQL se buscar por <literal>subselect</literal> for usado"
+msgstr "consultas HQL se a busca por <literal>subselect</literal> for usada"
 
 #. Tag: para
-#: performance.xml:232
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Irrespective of the fetching strategy you use, the defined non-lazy graph is "
 "guaranteed to be loaded into memory. This might, however, result in several "
 "immediate selects being used to execute a particular HQL query."
 msgstr ""
-"Independentemente da estratégia de busca que você usar, o grafo não "
-"preguiçoso definido será garantidamente carregado na memória. Note que isso "
-"irá resultar em diversos selects imediatos sendo usados em um HQL em "
-"particular."
+"Independentemente da estratégia de busca que você usar, o gráfico não "
+"preguiçoso definido será certamente carregado na memória. Note que isso irá "
+"resultar em diversas seleções imediatas sendo usadas para rodar uma consulta "
+"HQL em particular."
 
 #. Tag: para
-#: performance.xml:238
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Usually, the mapping document is not used to customize fetching. Instead, we "
 "keep the default behavior, and override it for a particular transaction, "
@@ -407,64 +442,49 @@
 "the <literal>Criteria</literal> query API, you would use "
 "<literal>setFetchMode(FetchMode.JOIN)</literal>."
 msgstr ""
-"Usualmente não usamos documentos de mapeamento para customizar as buscas. Ao "
-"invés disso, nós deixamos o comportamento padrão e sobrescrevemos isso em "
+"Geralmente, não usamos documentos de mapeamento para customizar as buscas. "
+"Ao invés disso, nós deixamos o comportamento padrão e sobrescrevemos isso em "
 "uma transação em particular, usando <literal>left join fetch</literal> no "
 "HQL. Isso diz ao Hibernate para buscar a associação inteira no primeiro "
-"select, usando um outer join. Na API de busca <literal>Criteria</literal>, "
-"você irá usar <literal>setFetchMode(FetchMode.JOIN)</literal>."
+"select, usando uma união externa. Na API de busca <literal>Criteria</"
+"literal>, você irá usar <literal>setFetchMode(FetchMode.JOIN)</literal>."
 
 #. Tag: para
-#: performance.xml:247
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want to change the fetching strategy used by <literal>get()</literal> "
 "or <literal>load()</literal>, you can use a <literal>Criteria</literal> "
 "query. For example:"
 msgstr ""
 "Se você quiser mudar a estratégia de busca usada pelo <literal>get()</"
-"literal> ou <literal>load()</literal>, simplesmente use uma query "
-"<literal>Criteria</literal>, por exemplo:"
+"literal> ou <literal>load()</literal>, simplesmente use uma consulta por "
+"<literal>Criteria</literal>, por exemplo: "
 
-#. Tag: programlisting
-#: performance.xml:253
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[User user = (User) session.createCriteria(User.class)\n"
-"                .setFetchMode(\"permissions\", FetchMode.JOIN)\n"
-"                .add( Restrictions.idEq(userId) )\n"
-"                .uniqueResult();]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:255
-#, fuzzy, no-c-format
-msgid ""
 "This is Hibernate's equivalent of what some ORM solutions call a \"fetch plan"
 "\"."
 msgstr ""
-"(Isto é o equivalente do Hibernate para o que algumas soluções ORM chamam de "
-"\"plano de busca\")"
+"Isto é o equivalente do Hibernate para o que algumas soluções ORM chamam de "
+"\"plano de busca\"."
 
 #. Tag: para
-#: performance.xml:259
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A completely different approach to problems with N+1 selects is to use the "
 "second-level cache."
 msgstr ""
 "Um meio totalmente diferente de evitar problemas com selects N+1 é usar um "
-"cache de segundo nível."
+"cache de segundo nível. "
 
 #. Tag: title
-#: performance.xml:267
 #, no-c-format
 msgid "Single-ended association proxies"
-msgstr "Proxies de associação single-ended"
+msgstr "Proxies de associação final único"
 
 #. Tag: para
-#: performance.xml:269
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Lazy fetching for collections is implemented using Hibernate's own "
 "implementation of persistent collections. However, a different mechanism is "
@@ -474,28 +494,26 @@
 "accessed via the CGLIB library."
 msgstr ""
 "A recuperação preguiçosa para coleções é implementada usando uma "
-"implementação própria do Hibernate para coleções persistentes. Porém, um "
-"mecanismo diferente é necessário para comportamento preguiçoso para "
-"associações de um lado só. A entidade alvo da associação precisa usar um "
+"implementação própria do Hibernate para coleções persistentes. Porém, é "
+"necessário um mecanismo diferente para comportamento preguiçoso em "
+"associações de final único. A entidade alvo da associação precisa usar um "
 "proxy. O Hibernate implementa proxies para inicialização preguiçosa em "
-"objetos persistentes usando manipulação de bytecode (via a excelente "
-"biblioteca CGLIB)."
+"objetos persistentes usando manipulação de bytecode, através da excelente "
+"biblioteca CGLIB. "
 
 #. Tag: para
-#: performance.xml:277
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "At startup, Hibernate3 generates proxies by default for all persistent "
 "classes and uses them to enable lazy fetching of <literal>many-to-one</"
 "literal> and <literal>one-to-one</literal> associations."
 msgstr ""
 "Por padrão, o Hibernate3 gera proxies (na inicialização) para todas as "
-"classes persistentes que usem eles para habilitar recuperaçãopreguiçosa de "
-"associações <literal>many-to-one</literal> e <literal>one-to-one</literal>."
+"classes persistentes que os usem para habilitar recuperação preguiçosa de "
+"associações <literal>many-to-one</literal> e <literal>one-to-one</literal>. "
 
 #. Tag: para
-#: performance.xml:283
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The mapping file may declare an interface to use as the proxy interface for "
 "that class, with the <literal>proxy</literal> attribute. By default, "
@@ -503,80 +521,39 @@
 "implement a default constructor with at least package visibility. This "
 "constructor is recommended for all persistent classes</emphasis>."
 msgstr ""
-"O arquivo de mapeamento deve declaram uma interface para usar como interface "
-"de proxy para aquela classe, com o atributo <literal>proxy</literal>. Por "
+"O arquivo de mapeamento deve declarar uma interface para usar como interface "
+"de proxy para aquela classe, com a função <literal>proxy</literal>. Por "
 "padrão, o Hibernate usa uma subclasse dessa classe. <emphasis>Note que a "
 "classe a ser usada via proxy precisa implementar o construtor padrão com "
 "pelo menos visibilidade de package. Nós recomendamos esse construtor para "
-"todas as classes persistentes!</emphasis>"
+"todas as classes persistentes</emphasis>."
 
 #. Tag: para
-#: performance.xml:290
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are potential problems to note when extending this approach to "
 "polymorphic classes.For example:"
 msgstr ""
-"Existe alguns truques que você deve saber quando extender esse comportamento "
-"para classes polimórficas, dessa maneira:"
+"Existe alguns truques que você deve saber quando estender esse comportamento "
+"para classes polimórficas. Por exemplo:"
 
-#. Tag: programlisting
-#: performance.xml:294
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Cat\" proxy=\"Cat\">\n"
-"    ......\n"
-"    <subclass name=\"DomesticCat\">\n"
-"        .....\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:296
 #, no-c-format
 msgid ""
 "Firstly, instances of <literal>Cat</literal> will never be castable to "
 "<literal>DomesticCat</literal>, even if the underlying instance is an "
 "instance of <literal>DomesticCat</literal>:"
 msgstr ""
-"Primeiramente, instâncias de <literal>Cat</literal> nunca seráo convertidas "
+"Primeiramente, instâncias de <literal>Cat</literal> nunca serão convertidas "
 "para <literal>DomesticCat</literal>, mesmo que a instância em questão seja "
-"uma estância de <literal>DomesticCat</literal>:"
+"uma instância de <literal>DomesticCat</literal>:"
 
-#. Tag: programlisting
-#: performance.xml:302
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);  // instantiate a "
-"proxy (does not hit the db)\n"
-"if ( cat.isDomesticCat() ) {                  // hit the db to initialize "
-"the proxy\n"
-"    DomesticCat dc = (DomesticCat) cat;       // Error!\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:304
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Secondly, it is possible to break proxy <literal>==</literal>:"
-msgstr "É possível quebrar o proxy <literal>==</literal>."
+msgstr "E, segundo, é possível quebrar o proxy <literal>==</literal>:"
 
-#. Tag: programlisting
-#: performance.xml:308
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);            // "
-"instantiate a Cat proxy\n"
-"DomesticCat dc = \n"
-"        (DomesticCat) session.load(DomesticCat.class, id);  // acquire new "
-"DomesticCat proxy!\n"
-"System.out.println(cat==dc);                            // false]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:310
 #, no-c-format
 msgid ""
 "However, the situation is not quite as bad as it looks. Even though we now "
@@ -584,44 +561,33 @@
 "still be the same object:"
 msgstr ""
 "Porém a situação não é tão ruim como parece. Mesmo quando temos duas "
-"referências para objetos proxies diferentes, a instância deles será o mesmo "
-"objeto"
+"referências para objetos proxies diferentes, a instância adjacente será do "
+"mesmo objeto:"
 
-#. Tag: programlisting
-#: performance.xml:315
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[cat.setWeight(11.0);  // hit the db to initialize the proxy\n"
-"System.out.println( dc.getWeight() );  // 11.0]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:317
-#, fuzzy, no-c-format
-msgid ""
 "Third, you cannot use a CGLIB proxy for a <literal>final</literal> class or "
 "a class with any <literal>final</literal> methods."
 msgstr ""
-"Terceiro, Você não pode usar um proxy CGLIB em uma classe <literal>final</"
-"literal> ou com qualquer método <literal>final</literal>."
+"E por terceiro, você não pode usar um proxy CGLIB em uma classe "
+"<literal>final</literal> ou com quaisquer métodos <literal>final</literal>."
 
 #. Tag: para
-#: performance.xml:322
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, if your persistent object acquires any resources upon instantiation "
 "(e.g. in initializers or default constructor), then those resources will "
 "also be acquired by the proxy. The proxy class is an actual subclass of the "
 "persistent class."
 msgstr ""
-"Finalmente, se o seu objeto persistente adquirir qualquer recursto durante a "
-"instanciação (em inicializadores ou construtor padrão), então esses recursos "
-"serão adquiridos pelo proxy também. A classe de proxy é uma subclasse da "
-"classe persistente."
+"Finalmente, se o seu objeto persistente adquirir qualquer recurso durante a "
+"instanciação (ex. em inicializadores ou construtor padrão), então esses "
+"recursos serão adquiridos pelo proxy também. A classe de proxy é uma "
+"subclasse da classe persistente. "
 
 #. Tag: para
-#: performance.xml:328
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These problems are all due to fundamental limitations in Java's single "
 "inheritance model. To avoid these problems your persistent classes must each "
@@ -631,106 +597,77 @@
 "<literal>DomesticCatImpl</literal> implements the interface "
 "<literal>DomesticCat</literal>. For example:"
 msgstr ""
-"Esses problemas são todos devido a limitação fundamental do modelo de "
-"herança simples do Java. Se você quiser evitar esse problemas em suas "
-"classes persistentes você deve imeplementar uma interface que declare seus "
-"métodos de negócio. Você deve especificar essas interfaces no arquivo de "
-"mapeamento. Ex:"
+"Esses problemas se dão devido à limitação originária do modelo de herança "
+"simples do Java. Se você quiser evitar esses problemas em suas classes "
+"persistentes você deve implementar uma interface que declare seus métodos "
+"comerciais. Você deve especificar essas interfaces no arquivo de mapeamento "
+"onde <literal>CatImpl</literal> implementa a interface <literal>Cat</"
+"literal> e <literal>DomesticCatImpl</literal> implementa a interface "
+"<literal>DomesticCat</literal>. Por exemplo: "
 
-#. Tag: programlisting
-#: performance.xml:336
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"CatImpl\" proxy=\"Cat\">\n"
-"    ......\n"
-"    <subclass name=\"DomesticCatImpl\" proxy=\"DomesticCat\">\n"
-"        .....\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:338
-#, fuzzy, no-c-format
-msgid ""
 "Then proxies for instances of <literal>Cat</literal> and "
 "<literal>DomesticCat</literal> can be returned by <literal>load()</literal> "
 "or <literal>iterate()</literal>."
 msgstr ""
-"Primeiramente, instâncias de <literal>Cat</literal> nunca seráo convertidas "
-"para <literal>DomesticCat</literal>, mesmo que a instância em questão seja "
-"uma estância de <literal>DomesticCat</literal>:"
+"Então, os proxies para instâncias de <literal>Cat</literal> e  "
+"<literal>DomesticCat</literal> podem ser retornadas pelo <literal>load()</"
+"literal> ou <literal>iterate()</literal>."
 
-#. Tag: programlisting
-#: performance.xml:343
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(CatImpl.class, catid);\n"
-"Iterator iter = session.createQuery(\"from CatImpl as cat where cat."
-"name='fritz'\").iterate();\n"
-"Cat fritz = (Cat) iter.next();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:346
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Nota"
 
 #. Tag: para
-#: performance.xml:347
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>list()</literal> does not usually return proxies."
-msgstr "<literal>Criteria</literal> queries"
+msgstr "<literal>list()</literal> normalmente retorna proxies."
 
 #. Tag: para
-#: performance.xml:352
 #, no-c-format
 msgid ""
 "Relationships are also lazily initialized. This means you must declare any "
 "properties to be of type <literal>Cat</literal>, not <literal>CatImpl</"
 "literal>."
 msgstr ""
-"Relacionamentos são também carregados preguiçosamente. Isso significa que "
-"você precisa declarar qualquer propriedade como sendo do tipo <literal>Cat</"
-"literal>, e não <literal>CatImpl</literal>."
+"Relacionamentos são também inicializados de forma preguiçosa. Isso significa "
+"que você precisa declarar qualquer propriedade como sendo do tipo "
+"<literal>Cat</literal>, e não <literal>CatImpl</literal>."
 
 #. Tag: para
-#: performance.xml:357
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Certain operations do <emphasis>not</emphasis> require proxy initialization:"
 msgstr ""
-"Algumas operações <emphasis>não</emphasis> requerem inicialização por proxy:"
+"Algumas operações <emphasis>não</emphasis> requerem inicialização por proxy: "
 
 #. Tag: para
-#: performance.xml:363
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>equals()</literal>: if the persistent class does not override "
 "<literal>equals()</literal>"
 msgstr ""
-"<literal>equals()</literal>, se a classe persistente não sobrescrever "
+"<literal>equals()</literal>: se a classe persistente não sobrescrever "
 "<literal>equals()</literal>"
 
 #. Tag: para
-#: performance.xml:369
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>hashCode()</literal>: if the persistent class does not override "
 "<literal>hashCode()</literal>"
 msgstr ""
-"<literal>hashCode()</literal>, se a classe persistente não sobrescrever "
+"<literal>hashCode()</literal>: se a classe persistente não sobrescrever "
 "<literal>hashCode()</literal>"
 
 #. Tag: para
-#: performance.xml:375
 #, no-c-format
 msgid "The identifier getter method"
 msgstr "O método getter do identificador"
 
 #. Tag: para
-#: performance.xml:381
 #, no-c-format
 msgid ""
 "Hibernate will detect persistent classes that override <literal>equals()</"
@@ -740,8 +677,7 @@
 "<literal>equals()</literal> ou <literal>hashCode()</literal>."
 
 #. Tag: para
-#: performance.xml:386
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "By choosing <literal>lazy=\"no-proxy\"</literal> instead of the default "
 "<literal>lazy=\"proxy\"</literal>, you can avoid problems associated with "
@@ -751,18 +687,16 @@
 "Escolhendo <literal>lazy=\"no-proxy\"</literal> ao invés do padrão "
 "<literal>lazy=\"proxy\"</literal>, podemos evitar problemas associados com "
 "typecasting. Porém, iremos precisar de instrumentação de bytecode em tempo "
-"de compilação e todas as operações irão resultar em iniciazações de proxy "
-"imediatas."
+"de compilação e todas as operações irão resultar em inicializações de proxy "
+"imediatas. "
 
 #. Tag: title
-#: performance.xml:396
 #, no-c-format
 msgid "Initializing collections and proxies"
 msgstr "Inicializando coleções e proxies"
 
 #. Tag: para
-#: performance.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>LazyInitializationException</literal> will be thrown by Hibernate "
 "if an uninitialized collection or proxy is accessed outside of the scope of "
@@ -770,13 +704,12 @@
 "or having the reference to the proxy is in the detached state."
 msgstr ""
 "Será lançada uma <literal>LazyInitializationException</literal> se uma "
-"coleção não inicializada ou proxy é acessado fora do escopo da "
+"coleção não inicializada ou proxy for acessado fora do escopo da "
 "<literal>Session</literal>, isto é, quando a entidade que contém a coleção "
-"ou tem a referência ao proxy estiver no estado destachado."
+"ou que possua a referência ao proxy estiver no estado desanexado. "
 
 #. Tag: para
-#: performance.xml:404
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes a proxy or collection needs to be initialized before closing the "
 "<literal>Session</literal>. You can force initialization by calling "
@@ -784,15 +717,14 @@
 "literal>, for example. However, this can be confusing to readers of the code "
 "and it is not convenient for generic code."
 msgstr ""
-"Algumas vezes precisamos garantir qie o proxy ou coleção é inicializado "
-"antes de se fechar a <literal>Session</literal>. Claro que sempre podemos "
+"Algumas vezes precisamos garantir que o proxy ou coleção é inicializado "
+"antes de fechar a <literal>Session</literal>. Claro que sempre podemos "
 "forçar a inicialização chamando <literal>cat.getSex()</literal> ou "
 "<literal>cat.getKittens().size()</literal>, por exemplo. Mas isto parece "
-"confuso para quem lê o código e não é conveniente para códigos genéricos."
+"confuso para quem lê o código e não é conveniente para códigos genéricos. "
 
 #. Tag: para
-#: performance.xml:411
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The static methods <literal>Hibernate.initialize()</literal> and "
 "<literal>Hibernate.isInitialized()</literal>, provide the application with a "
@@ -803,17 +735,15 @@
 "literal> has a similar effect for the collection of kittens."
 msgstr ""
 "Os métodos estáticos <literal>Hibernate.initialize()</literal> e "
-"<literal>Hibernate.isInitialized()</literal> possibilitam a aplicação uma "
-"maneira conveniente de trabalhar com coleções inicializadas preguiçosamente "
-"e proxies. <literal>Hibernate.initialize(cat)</literal> irá forçar a "
-"inicialização de um proxy, <literal>cat</literal>, contanto que a "
-"<literal>Session</literal> esteja ainda aberta. <literal>Hibernate.initialize"
-"( cat.getKittens() )</literal> tem um efeito similar para a coleção de "
-"kittens."
+"<literal>Hibernate.isInitialized()</literal> favorecem a aplicação para "
+"trabalhar com coleções ou proxies inicializados de forma preguiçosa. O "
+"<literal>Hibernate.initialize(cat)</literal> irá forçar a inicialização de "
+"um proxy, <literal>cat</literal>, contanto que a <literal>Session</literal> "
+"esteja ainda aberta. <literal>Hibernate.initialize (cat.getKittens() )</"
+"literal> tem um efeito similar para a coleção de kittens. "
 
 #. Tag: para
-#: performance.xml:420
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Another option is to keep the <literal>Session</literal> open until all "
 "required collections and proxies have been loaded. In some application "
@@ -823,17 +753,17 @@
 "<literal>Session</literal> is open when a collection is initialized. There "
 "are two basic ways to deal with this issue:"
 msgstr ""
-"Outra opção é manter a <literal>Session</literal> aberta até que todas as "
-"coleções e proxies necessários sejam carregados. Em algumas arquiteturas de "
-"aplicações, particularmente onde o código que acessa os dados usando "
-"Hibernate e o código que usa os dados estão em diferentes camadas da "
-"aplicação ou diferentes processos físicos, será um problema garantir que a "
-"<literal>Session</literal> esteja aberta quando uma coleção for "
-"inicializada. Existem dois caminhos básicos para lidar com esse problema:"
+"Uma outra opção é manter a <literal>Session</literal> aberta até que todas "
+"as coleções e os proxies necessários sejam carregados. Em algumas "
+"arquiteturas de aplicações, particularmente onde o código que acessa os "
+"dados usando Hibernate e o código que os usa, se encontram em diferentes "
+"camadas da aplicação ou diferentes processos físicos, será um problema "
+"garantir que a <literal>Session</literal> esteja aberta quando uma coleção "
+"for inicializada. Existem dois caminhos básicos para lidar com esse "
+"problema: "
 
 #. Tag: para
-#: performance.xml:431
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In a web-based application, a servlet filter can be used to close the "
 "<literal>Session</literal> only at the end of a user request, once the "
@@ -845,19 +775,18 @@
 "rendering of the view. See the Hibernate Wiki for examples of this \"Open "
 "Session in View\" pattern."
 msgstr ""
-"Em aplicações web, um filtro servlet pode ser usado para fechar a "
-"<literal>Session</literal> somente no final da requisição do usuário, já que "
-"a renderização da visão estará completa (o pattern <emphasis>Open Session In "
-"View</emphasis>). Claro, que isto cria a necessidade de um correto manuseio "
-"de exceções na infraestrutura de sua aplicação. É vitalmente importante que "
-"a <literal>Session</literal> esteja fechada e a transação terminada antes de "
+"Em uma aplicações web, um filtro servlet pode ser usado para fechar a "
+"<literal>Session</literal> somente no final da requisição do usuário, quando "
+"a renderização da view estiver completa (o modelo <emphasis>Abrir Sessão em "
+"View</emphasis>). Claro, que isto demanda uma exatidão no manuseio de "
+"exceções na infraestrutura de sua aplicação. É extremamente importante que a "
+"<literal>Session</literal> seja fechada e a transação terminada antes de "
 "retornar para o usuário, mesmo que uma exceção ocorra durante a renderização "
-"da view. Veja o Wiki do Hibernate para exemplos do pattern \"Open Session In "
-"View\""
+"da view. Veja o Wiki do Hibernate para exemplos do pattern \"Abrir Sessão em "
+"View\"."
 
 #. Tag: para
-#: performance.xml:444
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In an application with a separate business tier, the business logic must "
 "\"prepare\" all collections that the web tier needs before returning. This "
@@ -874,18 +803,18 @@
 "Em uma aplicação com uma camada de negócios separada, a lógica de negócios "
 "deve \"preparar\" todas as coleções que serão usadas pela camada web antes "
 "de retornar. Isto sgnifica que a camada de negócios deve carregar todos os "
-"dados e retorná-los já inicializados para a camada de apresentação. "
-"Usualmente a aplicação chama <literal>Hibernate.initialize()</literal> para "
-"cada coleção que será usada pela camada web (essa chamada de método deve "
-"ocorrer antes da sessão ser fechada ou retornar a coleção usando uma "
-"consulta Hibernate com uma cláusula <literal>FETCH</literal> ou um "
-"<literal>FetchMode.JOIN</literal> na <literal>Criteria</literal>. Fica muito "
-"mais fácil se você adotar o pattern <emphasis>Command</emphasis> ao invés do "
-"<emphasis>Session Facade</emphasis>."
+"dados e retorná-los já inicializados para a camada de apresentação que é "
+"representada para um caso de uso particular. Geralmente, a aplicação chama "
+"<literal>Hibernate.initialize()</literal> para cada coleção que será usada "
+"pela camada web (essa chamada deve ocorrer antes da sessão ser fechada) ou "
+"retorna a coleção usando uma consulta Hibernate com uma cláusula "
+"<literal>FETCH</literal> ou um <literal>FetchMode.JOIN</literal> na "
+"<literal>Criteria</literal>. Fica muito mais fácil se você adotar o modelo "
+"<emphasis>Command</emphasis> ao invés do <emphasis>Session Facade</"
+"emphasis>. "
 
 #. Tag: para
-#: performance.xml:459
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also attach a previously loaded object to a new <literal>Session</"
 "literal> with <literal>merge()</literal> or <literal>lock()</literal> before "
@@ -893,42 +822,31 @@
 "and certainly <emphasis>should</emphasis> not, do this automatically since "
 "it would introduce impromptu transaction semantics."
 msgstr ""
-"Você também pode anexar um objeto prevaimente carregado em uma nova "
-"<literal>Session</literal><literal>merge()</literal> or <literal>lock()</"
+"Você também pode anexar um objeto previamente carregado em uma nova "
+"<literal>Session</literal><literal>merge()</literal> ou <literal>lock()</"
 "literal> antes de acessar coleções não inicializadas (ou outros proxies). O "
-"Hibernate não faz e certamente <literal>não deve</literal> isso "
-"automaticamente pois isso introduziria semantica em transações ad hoc."
+"Hibernate não faz e certamente <literal>não deve</literal> fazer isso "
+"automaticamente, pois isso introduziria semântica em transações  impromptu."
 
 #. Tag: para
-#: performance.xml:469
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes you do not want to initialize a large collection, but still need "
 "some information about it, like its size, for example, or a subset of the "
 "data."
 msgstr ""
-"As vezes você não quer inicializar uma coleção muito grande, mas precisa de "
-"algumas informações (como o tamanho) ou alguns de seus dados."
+"Às vezes você não quer inicializar uma coleção muito grande, mas precisa de "
+"algumas informações, como o mesmo tamanho, ou um subconjunto de seus dados."
 
 #. Tag: para
-#: performance.xml:474
 #, no-c-format
 msgid ""
 "You can use a collection filter to get the size of a collection without "
 "initializing it:"
 msgstr ""
-"Você pode usar um filtro de coleção para saber seu tamanho sem a inicializar:"
+"Você pode usar um filtro de coleção para saber seu tamanho sem inicializá-la:"
 
-#. Tag: programlisting
-#: performance.xml:478
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) s.createFilter( collection, \"select count(*)\" ).list"
-"().get(0) ).intValue()]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:480
 #, no-c-format
 msgid ""
 "The <literal>createFilter()</literal> method is also used to efficiently "
@@ -939,38 +857,27 @@
 "algus dados de uma coleção eficientemente sem precisar inicializar a coleção "
 "inteira:"
 
-#. Tag: programlisting
-#: performance.xml:485
-#, no-c-format
-msgid ""
-"<![CDATA[s.createFilter( lazyCollection, \"\").setFirstResult(0)."
-"setMaxResults(10).list();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:490
 #, no-c-format
 msgid "Using batch fetching"
 msgstr "Usando busca em lote"
 
 #. Tag: para
-#: performance.xml:492
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Using batch fetching, Hibernate can load several uninitialized proxies if "
 "one proxy is accessed. Batch fetching is an optimization of the lazy select "
 "fetching strategy. There are two ways you can configure batch fetching: on "
 "the class level and the collection level."
 msgstr ""
-"O Hibernate pode fazer uso eficiente de busca em lote, isto é, o Hibernate "
-"pode carregar diversos proxies não inicializados se um proxy é acessado (ou "
-"coleções. A busca em lote é uma otimização da estratégia de select "
-"fetching). Existe duas maneiras em que você pode usar busca em lote: no "
-"nível da classe ou no nível da coleção."
+"O Hibernate pode fazer uso eficiente de busca em lote, ou seja o Hibernate "
+"pode carregar diversos proxies não inicializados, se um proxy for acessado "
+"(ou coleções). A busca em lote é uma otimização da estratégia da busca de "
+"seleção lazy. Existem duas maneiras para você usar a busca em lote: no nível "
+"da classe ou no nível da coleção."
 
 #. Tag: para
-#: performance.xml:498
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Batch fetching for classes/entities is easier to understand. Consider the "
 "following example: at runtime you have 25 <literal>Cat</literal> instances "
@@ -984,35 +891,26 @@
 "mapping of <literal>Person</literal>:"
 msgstr ""
 "A recuperação em lote para classes/entidades é mais fácil de entender. "
-"Imagine que você tem a seguinte situação em tempo de execução: Você tem 25 "
+"Imagine que você tem a seguinte situação em tempo de execução: você tem 25 "
 "instâncias de <literal>Cat</literal> carregadas em uma <literal>Session</"
-"literal>, cada <literal>Cat</literal> tem uma referência ao seu "
+"literal>, cada <literal>Cat</literal> possui uma referência ao seu "
 "<literal>owner</literal>, que é da classe <literal>Person</literal>. A "
 "classe <literal>Person</literal> é mapeada com um proxy, <literal>lazy=\"true"
-"\"</literal>. Se você iterar sobre todos os Cat's e chamar <literal>getOwner"
+"\"</literal>. Se você interar sobre todos os Cat's e chamar <literal>getOwner"
 "()</literal> em cada, o Hibernate irá por padrão executar 25 comandos "
 "<literal>SELECT()</literal>, para buscar os proxies de owners. Você pode "
 "melhorar esse comportamento especificando um <literal>batch-size</literal> "
-"no mapeamento da classe <literal>Person</literal>:"
+"no mapeamento da classe <literal>Person</literal>: "
 
-#. Tag: programlisting
-#: performance.xml:508
-#, no-c-format
-msgid "<![CDATA[<class name=\"Person\" batch-size=\"10\">...</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:510
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will now execute only three queries: the pattern is 10, 10, 5."
 msgstr ""
-"O Hibernate irá executar agora apenas três consultas, buscando por vez, 10, "
-"10 e 5 Person."
+"O Hibernate irá executar agora apenas três consultas; o padrão é 10, 10, 5."
 
 #. Tag: para
-#: performance.xml:514
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also enable batch fetching of collections. For example, if each "
 "<literal>Person</literal> has a lazy collection of <literal>Cat</literal>s, "
@@ -1024,26 +922,14 @@
 msgstr ""
 "Você também pode habilitar busca em lote de uma coleção. Por exemplo, se "
 "cada <literal>Person</literal> tem uma coleção preguiçosa de <literal>Cat</"
-"literal>s, e 10 pessoas estão já carregados em uma <literal>Sesssion</"
-"literal>, serão gerados 10 <literal>SELECT</literal>s ao se iterar todas as "
-"pessoas, um para cada chamada de <literal>getCats()</literal>.. Se você "
+"literal>s e 10 persons estão já carregadas em uma <literal>Session</"
+"literal>, serão gerados 10 <literal>SELECT</literal>s ao se interar todas as "
+"persons, um para cada chamada de <literal>getCats()</literal>. Se você "
 "habilitar busca em lote para a coleção de <literal>cats</literal> no "
 "mapeamento da classe <literal>Person</literal>, o Hibernate pode fazer uma "
 "pré carga das coleções:"
 
-#. Tag: programlisting
-#: performance.xml:523
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <set name=\"cats\" batch-size=\"3\">\n"
-"        ...\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:525
 #, no-c-format
 msgid ""
 "With a <literal>batch-size</literal> of 3, Hibernate will load 3, 3, 3, 1 "
@@ -1052,13 +938,12 @@
 "particular <literal>Session</literal>."
 msgstr ""
 "Com um <literal>batch-size</literal> de 3, o Hibernate irá carregar 3, 3, 3, "
-"1 coleções em 4 <literal>SELECT</literal>s. Novamente, o valor do atributo "
-"depende do número esperado de coleções não inicialiadas em determinada "
+"1 coleções em 4 <literal>SELECT</literal>s. Novamente, o valor da função "
+"depende do número esperado de coleções não inicializadas em determinada "
 "<literal>Session</literal>."
 
 #. Tag: para
-#: performance.xml:531
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Batch fetching of collections is particularly useful if you have a nested "
 "tree of items, i.e. the typical bill-of-materials pattern. However, a "
@@ -1066,38 +951,92 @@
 "might be a better option for read-mostly trees."
 msgstr ""
 "A busca em lote de coleções é particularmente útil quando você tem uma "
-"árvore encadeada de items, ex. o típico padrão bill-of-materials (Se bem que "
-"um <emphasis>conjunto encadeado</emphasis> ou <emphasis>caminho "
-"materializado </emphasis> pode ser uma opção melhor para árvores com mais "
-"leitura)"
+"árvore encadeada de ítens, ex.: o típico padrão bill-of-materials (Se bem "
+"que um <emphasis>conjunto encadeado</emphasis> ou <emphasis>caminho "
+"materializado</emphasis> pode ser uma opção melhor para árvores com mais "
+"leitura."
 
 #. Tag: title
-#: performance.xml:540
 #, no-c-format
 msgid "Using subselect fetching"
-msgstr "Usando subselect fetching"
+msgstr "Usando busca de subseleção"
 
 #. Tag: para
-#: performance.xml:542
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If one lazy collection or single-valued proxy has to be fetched, Hibernate "
 "will load all of them, re-running the original query in a subselect. This "
 "works in the same way as batch-fetching but without the piecemeal loading."
 msgstr ""
 "Se uma coleção ou proxy simples precisa ser recuperado, o Hibernate carrega "
-"todos eles rodando novamente a query original em um subselect. Isso funciona "
-"da mesma maneira que busca em lote, sem carregar tanto."
+"todos eles rodando novamente a consulta original em uma subseleção. Isso "
+"funciona da mesma maneira que busca em lote, sem carregar tanto."
 
 #. Tag: title
-#: performance.xml:553
+#, fuzzy, no-c-format
+msgid "Fetch profiles"
+msgstr "Estratégias de Busca "
+
+#. Tag: para
 #, no-c-format
+msgid ""
+"Another way to affect the fetching strategy for loading associated objects "
+"is through something called a fetch profile, which is a named configuration "
+"associated with the <interfacename>org.hibernate.SessionFactory</"
+"interfacename> but enabled, by name, on the <interfacename>org.hibernate."
+"Session</interfacename>. Once enabled on a <interfacename>org.hibernate."
+"Session</interfacename>, the fetch profile wull be in affect for that "
+"<interfacename>org.hibernate.Session</interfacename> until it is explicitly "
+"disabled."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"So what does that mean? Well lets explain that by way of an example. Say we "
+"have the following mappings:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Now normally when you get a reference to a particular customer, that "
+"customer's set of orders will be lazy meaning we will not yet have loaded "
+"those orders from the database. Normally this is a good thing. Now lets say "
+"that you have a certain use case where it is more efficient to load the "
+"customer and their orders together. One way certainly is to use \"dynamic "
+"fetching\" strategies via an HQL or criteria queries. But another option is "
+"to use a fetch profile to achieve that. Just add the following to your "
+"mapping:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "or even:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Now the following code will actually load both the customer <emphasis>and "
+"their orders</emphasis>:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Currently only join style fetch profiles are supported, but they plan is to "
+"support additional styles. See <ulink url=\"http://opensource.atlassian.com/"
+"projects/hibernate/browse/HHH-3414\">HHH-3414</ulink> for details."
+msgstr ""
+
+#. Tag: title
+#, no-c-format
 msgid "Using lazy property fetching"
 msgstr "Usando busca preguiçosa de propriedade"
 
 #. Tag: para
-#: performance.xml:555
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 supports the lazy fetching of individual properties. This "
 "optimization technique is also known as <emphasis>fetch groups</emphasis>. "
@@ -1107,111 +1046,68 @@
 "when legacy tables have hundreds of columns and the data model cannot be "
 "improved."
 msgstr ""
-"O Hibernate3 suporta a carga posterior de propriedades individuais. Essa "
-"técnica de otimização também conhecida como <emphasis>fetch groups</"
-"emphasis>. Veja que isso é mais uma funcionalidade de marketing já que na "
-"prática, é mais importante otimização nas leituras dos registros do que na "
-"leitura das colunas. Porém, carregar apenas algumas propriedades de uma "
-"classe pode ser útil em casos extremos, onde tabelas legadas podem ter "
-"centenas de colunas e o modelo de dados não pode ser melhorado."
+"O Hibernate3 suporta a busca lazy de propriedades individuais. Essa técnica "
+"de otimização é também conhecida como <emphasis>grupos de busca</emphasis>. "
+"Veja que esta é mais uma característica de marketing já que na prática, é "
+"mais importante a otimização nas leituras dos registros do que na leitura "
+"das colunas. Porém, carregar apenas algumas propriedades de uma classe pode "
+"ser útil em casos extremos, onde tabelas legadas podem ter centenas de "
+"colunas e o modelo de dados não pode ser melhorado."
 
 #. Tag: para
-#: performance.xml:564
 #, no-c-format
 msgid ""
 "To enable lazy property loading, set the <literal>lazy</literal> attribute "
 "on your particular property mappings:"
 msgstr ""
-"Para habilitar a carga posterior de propriedade, é preciso setar o atributo "
+"Para habilitar a carga de propriedade lazy, é preciso ajustar a função "
 "<literal>lazy</literal> no seu mapeamento de propriedade:"
 
-#. Tag: programlisting
-#: performance.xml:569
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Document\">\n"
-"       <id name=\"id\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\" length=\"50\"/>\n"
-"    <property name=\"summary\" not-null=\"true\" length=\"200\" lazy=\"true"
-"\"/>\n"
-"    <property name=\"text\" not-null=\"true\" length=\"2000\" lazy=\"true\"/"
-">\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:571
-#, fuzzy, no-c-format
-msgid ""
 "Lazy property loading requires buildtime bytecode instrumentation. If your "
 "persistent classes are not enhanced, Hibernate will ignore lazy property "
 "settings and return to immediate fetching."
 msgstr ""
-"A carga posterior de propriedades requer instrumentação de bytecode! Se suas "
+"A carga de propriedades lazy requer instrumentação de bytecode. Se suas "
 "classes persistentes não forem melhoradas, o Hibernate irá ignorar "
-"silenciosamente essa configuração e usará busca imediatamente."
+"silenciosamente essa configuração e usará a busca imediata."
 
 #. Tag: para
-#: performance.xml:577
 #, no-c-format
 msgid "For bytecode instrumentation, use the following Ant task:"
 msgstr "Para instrumentação de bytecode, use a seguinte tarefa do Ant:"
 
-#. Tag: programlisting
-#: performance.xml:581
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<target name=\"instrument\" depends=\"compile\">\n"
-"    <taskdef name=\"instrument\" classname=\"org.hibernate.tool.instrument."
-"InstrumentTask\">\n"
-"        <classpath path=\"${jar.path}\"/>\n"
-"        <classpath path=\"${classes.dir}\"/>\n"
-"        <classpath refid=\"lib.class.path\"/>\n"
-"    </taskdef>\n"
-"\n"
-"    <instrument verbose=\"true\">\n"
-"        <fileset dir=\"${testclasses.dir}/org/hibernate/auction/model\">\n"
-"            <include name=\"*.class\"/>\n"
-"        </fileset>\n"
-"    </instrument>\n"
-"</target>]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:583
-#, fuzzy, no-c-format
-msgid ""
 "A different way of avoiding unnecessary column reads, at least for read-only "
 "transactions, is to use the projection features of HQL or Criteria queries. "
 "This avoids the need for buildtime bytecode processing and is certainly a "
 "preferred solution."
 msgstr ""
-"A different (better?) way to avoid unnecessary column reads, at least for "
-"read-only transactions is to use the projection features of HQL or Criteria "
-"queries. This avoids the need for buildtime bytecode processing and is "
-"certainly a prefered solution."
+"Uma forma diferente de evitar leitura de coluna desnecessária, ao menos para "
+"transações de somente leitura, deve-se usar os recursos de projeção do HQL "
+"ou consultas por Critério. Isto evita a necessidade de processamento de "
+"bytecode em build-time e é certamente uma melhor solução."
 
 #. Tag: para
-#: performance.xml:590
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can force the usual eager fetching of properties using <literal>fetch "
 "all properties</literal> in HQL."
 msgstr ""
-"You may force the usual eager fetching of properties using <literal>fetch "
-"all properties</literal> in HQL."
+"Você pode forçar a busca antecipada comum de propriedades usando "
+"<literal>buscar todas as propriedades</literal> no HQL."
 
 #. Tag: title
-#: performance.xml:600
 #, no-c-format
 msgid "The Second Level Cache"
-msgstr "The Second Level Cache"
+msgstr "O Cachê de Segundo Nível"
 
 #. Tag: para
-#: performance.xml:602
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A Hibernate <literal>Session</literal> is a transaction-level cache of "
 "persistent data. It is possible to configure a cluster or JVM-level "
@@ -1221,17 +1117,16 @@
 "another application. They can, however, be configured to regularly expire "
 "cached data."
 msgstr ""
-"A Hibernate <literal>Session</literal> is a transaction-level cache of "
-"persistent data. It is possible to configure a cluster or JVM-level "
-"(<literal>SessionFactory</literal>-level) cache on a class-by-class and "
-"collection-by-collection basis. You may even plug in a clustered cache. Be "
-"careful. Caches are never aware of changes made to the persistent store by "
-"another application (though they may be configured to regularly expire "
-"cached data)."
+"Uma <literal>Session</literal> do Hibernate é um cache de nível transacional "
+"de dados persistentes. É possível configurar um cluster ou um cache de nível "
+"JVM (nível <literal>SessionFactory</literal>) em uma estrutura classe por "
+"classe e coleção por coleção. Você pode até mesmo plugar em um cache em "
+"cluster. Tenha cuidado, pois os caches nunca sabem das mudanças feitas em "
+"armazenamento persistente por um outro aplicativo. No entanto, eles podem "
+"ser configurados para dados em cache vencido regularmente."
 
 #. Tag: para
-#: performance.xml:610
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You have the option to tell Hibernate which caching implementation to use by "
 "specifying the name of a class that implements <literal>org.hibernate.cache."
@@ -1241,306 +1136,243 @@
 "can also implement your own and plug it in as outlined above. Note that "
 "versions prior to 3.2 use EhCache as the default cache provider."
 msgstr ""
-"You have the option to tell Hibernate which caching implementation to use by "
-"specifying the name of a class that implements <literal>org.hibernate.cache."
-"CacheProvider</literal> using the property <literal>hibernate.cache."
-"provider_class</literal>. Hibernate comes bundled with a number of built-in "
-"integrations with open-source cache providers (listed below); additionally, "
-"you could implement your own and plug it in as outlined above. Note that "
-"versions prior to 3.2 defaulted to use EhCache as the default cache "
-"provider; that is no longer the case as of 3.2."
+"Você tem a opção de informar o Hibernate sobre qual implementação de cache "
+"utilizar, especificando o nome de uma classe que implementa <literal>org."
+"hibernate.cache.CacheProvider</literal> usando a propriedade "
+"<literal>hibernate.cache.provider_class</literal>. O Hibernate vem envolvido "
+"com um número de integrações construídas com provedores de cache de fonte "
+"aberta (listados abaixo). Além disso, você pode implementar seu próprio e "
+"plugá-lo como mencionado acima. Note que as versões anteriores ao padrão 3.2 "
+"utilizam EhCache como provedor de cache padrão. "
 
 #. Tag: title
-#: performance.xml:621
 #, no-c-format
 msgid "Cache Providers"
-msgstr "Cache Providers"
+msgstr "Provedores de Cache "
 
 #. Tag: entry
-#: performance.xml:630 performance.xml:818
 #, no-c-format
 msgid "Cache"
 msgstr "Cache"
 
 #. Tag: entry
-#: performance.xml:631
 #, no-c-format
 msgid "Provider class"
-msgstr "Provider class"
+msgstr "Classe de provedor"
 
 #. Tag: entry
-#: performance.xml:632
 #, no-c-format
 msgid "Type"
-msgstr "Type"
+msgstr "Tipo"
 
 #. Tag: entry
-#: performance.xml:633
 #, no-c-format
 msgid "Cluster Safe"
-msgstr "Cluster Safe"
+msgstr "Segurança de Cluster"
 
 #. Tag: entry
-#: performance.xml:634
 #, no-c-format
 msgid "Query Cache Supported"
-msgstr "Query Cache Supported"
+msgstr "Cache de Consulta Suportado"
 
 #. Tag: entry
-#: performance.xml:639 performance.xml:827
 #, no-c-format
 msgid "Hashtable (not intended for production use)"
-msgstr "Hashtable (not intended for production use)"
+msgstr "Hashtable (não recomendado para uso de produção)"
 
-#. Tag: literal
-#: performance.xml:640
-#, no-c-format
-msgid "org.hibernate.cache.HashtableCacheProvider"
-msgstr "org.hibernate.cache.HashtableCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.HashtableCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.HashtableCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:641
 #, no-c-format
 msgid "memory"
-msgstr "memory"
+msgstr "memória"
 
 #. Tag: entry
-#: performance.xml:643 performance.xml:650 performance.xml:657
-#: performance.xml:828 performance.xml:829 performance.xml:830
-#: performance.xml:835 performance.xml:836 performance.xml:837
-#: performance.xml:842 performance.xml:843 performance.xml:844
-#: performance.xml:849 performance.xml:850 performance.xml:856
-#: performance.xml:859 performance.xml:863 performance.xml:866
 #, no-c-format
-msgid "<entry>yes</entry>"
-msgstr ""
+msgid "yes"
+msgstr "sim"
 
 #. Tag: entry
-#: performance.xml:646 performance.xml:834
 #, no-c-format
 msgid "EHCache"
 msgstr "EHCache"
 
-#. Tag: literal
-#: performance.xml:647
-#, no-c-format
-msgid "org.hibernate.cache.EhCacheProvider"
-msgstr "org.hibernate.cache.EhCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.EhCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.EhCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:648 performance.xml:655
 #, no-c-format
 msgid "memory, disk"
-msgstr "memory, disk"
+msgstr "memória, disco"
 
 #. Tag: entry
-#: performance.xml:653 performance.xml:841
 #, no-c-format
 msgid "OSCache"
 msgstr "OSCache"
 
-#. Tag: literal
-#: performance.xml:654
-#, no-c-format
-msgid "org.hibernate.cache.OSCacheProvider"
-msgstr "org.hibernate.cache.OSCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.OSCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.OSCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:660 performance.xml:848
 #, no-c-format
 msgid "SwarmCache"
 msgstr "SwarmCache"
 
-#. Tag: literal
-#: performance.xml:661
-#, no-c-format
-msgid "org.hibernate.cache.SwarmCacheProvider"
-msgstr "org.hibernate.cache.SwarmCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.SwarmCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.SwarmCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:662
 #, no-c-format
 msgid "clustered (ip multicast)"
 msgstr "clustered (ip multicast)"
 
 #. Tag: entry
-#: performance.xml:663
 #, no-c-format
 msgid "yes (clustered invalidation)"
-msgstr "yes (clustered invalidation)"
+msgstr "sim (invalidação em cluster)"
 
 #. Tag: entry
-#: performance.xml:667 performance.xml:855
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "JBoss Cache 1.x"
-msgstr "JBoss TreeCache"
+msgstr "JBoss Cache 1.x"
 
-#. Tag: literal
-#: performance.xml:668
-#, no-c-format
-msgid "org.hibernate.cache.TreeCacheProvider"
-msgstr "org.hibernate.cache.TreeCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.TreeCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.TreeCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:669 performance.xml:676
 #, no-c-format
 msgid "clustered (ip multicast), transactional"
-msgstr "clustered (ip multicast), transactional"
+msgstr "(ip multicast) em cluster, transacional"
 
 #. Tag: entry
-#: performance.xml:670
 #, no-c-format
 msgid "yes (replication)"
-msgstr "yes (replication)"
+msgstr "sim (replicação)"
 
 #. Tag: entry
-#: performance.xml:671 performance.xml:678
 #, no-c-format
 msgid "yes (clock sync req.)"
-msgstr "yes (clock sync req.)"
+msgstr "sim (solicitação de sync. de relógio)"
 
 #. Tag: entry
-#: performance.xml:674 performance.xml:862
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "JBoss Cache 2"
-msgstr "JBoss TreeCache"
+msgstr "JBoss Cache 2"
 
-#. Tag: literal
-#: performance.xml:675
+#. Tag: entry
 #, fuzzy, no-c-format
-msgid "org.hibernate.cache.jbc.JBossCacheRegionFactory"
-msgstr "org.hibernate.cache.EhCacheProvider"
+msgid "<literal>org.hibernate.cache.jbc.JBossCacheRegionFactory</literal>"
+msgstr "<literal>org.hibernate.cache.jbc2.JBossCacheRegionFactory</literal>"
 
 #. Tag: entry
-#: performance.xml:677
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "yes (replication or invalidation)"
-msgstr "yes (clustered invalidation)"
+msgstr "sim (invalidação ou replicação)"
 
 #. Tag: title
-#: performance.xml:685
 #, no-c-format
 msgid "Cache mappings"
-msgstr "Cache mappings"
+msgstr "Mapeamento de Cache"
 
 #. Tag: para
-#: performance.xml:687
 #, no-c-format
 msgid ""
 "The <literal>&lt;cache&gt;</literal> element of a class or collection "
 "mapping has the following form:"
 msgstr ""
-"The <literal>&lt;cache&gt;</literal> element of a class or collection "
-"mapping has the following form:"
+"O elemento <literal>&lt;cache&gt;</literal> de uma classe ou mapeamento de "
+"coleção possui a seguinte forma:"
 
-#. Tag: programlisting
-#: performance.xml:698
-#, no-c-format
-msgid ""
-"<![CDATA[<cache \n"
-"    usage=\"transactional|read-write|nonstrict-read-write|read-only\"\n"
-"    region=\"RegionName\"\n"
-"    include=\"all|non-lazy\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:701
 #, no-c-format
 msgid ""
 "<literal>usage</literal> (required) specifies the caching strategy: "
 "<literal>transactional</literal>, <literal>read-write</literal>, "
 "<literal>nonstrict-read-write</literal> or <literal>read-only</literal>"
 msgstr ""
-"<literal>usage</literal> (required) specifies the caching strategy: "
-"<literal>transactional</literal>, <literal>read-write</literal>, "
-"<literal>nonstrict-read-write</literal> or <literal>read-only</literal>"
+"<literal>uso</literal> (solicitado) especifica a estratégia de cache: "
+"<literal>transacional</literal>, <literal>leitura-escrita</literal>, "
+"<literal>leitura-escrita não estrito</literal> ou <literal>somente leitura</"
+"literal>"
 
 #. Tag: para
-#: performance.xml:710
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>region</literal> (optional: defaults to the class or collection "
 "role name): specifies the name of the second level cache region"
 msgstr ""
-"<literal>region</literal> (optional, defaults to the class or collection "
-"role name) specifies the name of the second level cache region"
+"<literal>region</literal> (opcional: padrão à classe ou nome papel da "
+"coleção): especifica o nome da região do cache de segundo nível"
 
 #. Tag: para
-#: performance.xml:717
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>include</literal> (optional: defaults to <literal>all</literal>) "
 "<literal>non-lazy</literal>: specifies that properties of the entity mapped "
 "with <literal>lazy=\"true\"</literal> cannot be cached when attribute-level "
 "lazy fetching is enabled"
 msgstr ""
-"<literal>include</literal> (optional, defaults to <literal>all</literal>) "
-"<literal>non-lazy</literal> specifies that properties of the entity mapped "
-"with <literal>lazy=\"true\"</literal> may not be cached when attribute-level "
-"lazy fetching is enabled"
+"<literal>include</literal> (opcional: padrão para <literal>all</literal>) "
+"<literal>non-lazy</literal>: especifica que a propriedade da entidade "
+"mapeada com <literal>lazy=\"true\"</literal> pode não estar em cache quando "
+"o nível da função busca lazy for habilitada"
 
 #. Tag: para
-#: performance.xml:727
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, you can specify <literal>&lt;class-cache&gt;</literal> and "
 "<literal>&lt;collection-cache&gt;</literal> elements in <literal>hibernate."
 "cfg.xml</literal>."
 msgstr ""
-"Alternatively (preferrably?), you may specify <literal>&lt;class-cache&gt;</"
-"literal> and <literal>&lt;collection-cache&gt;</literal> elements in "
+"De forma alternativa, você poderá especificar os elementos <literal>&lt;"
+"class-cache&gt;</literal> e <literal>&lt;collection-cache&gt;</literal> em "
 "<literal>hibernate.cfg.xml</literal>."
 
 #. Tag: para
-#: performance.xml:732
 #, no-c-format
 msgid ""
 "The <literal>usage</literal> attribute specifies a <emphasis>cache "
 "concurrency strategy</emphasis>."
 msgstr ""
-"The <literal>usage</literal> attribute specifies a <emphasis>cache "
-"concurrency strategy</emphasis>."
+"A função <literal>uso </literal> especifica uma <emphasis>estratégia de "
+"concorrência de cache</emphasis>."
 
 #. Tag: title
-#: performance.xml:739
 #, no-c-format
 msgid "Strategy: read only"
-msgstr "Strategy: read only"
+msgstr "Estratégia: somente leitura"
 
 #. Tag: para
-#: performance.xml:741
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your application needs to read, but not modify, instances of a persistent "
 "class, a <literal>read-only</literal> cache can be used. This is the "
 "simplest and optimal performing strategy. It is even safe for use in a "
 "cluster."
 msgstr ""
-"If your application needs to read but never modify instances of a persistent "
-"class, a <literal>read-only</literal> cache may be used. This is the "
-"simplest and best performing strategy. It's even perfectly safe for use in a "
-"cluster."
+"Se sua aplicação precisar ler mas nunca modificar instâncias de uma classe "
+"persistente, pode-se utilizar um cache de <literal>read-only</literal>. Esta "
+"é a estratégia de desempenho mais simples e melhor. É também perfeitamente "
+"seguro para uso em um cluster."
 
-#. Tag: programlisting
-#: performance.xml:747
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Immutable\" mutable=\"false\">\n"
-"    <cache usage=\"read-only\"/>\n"
-"    ....\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:753
 #, no-c-format
 msgid "Strategy: read/write"
-msgstr "Strategy: read/write"
+msgstr "Estratégia: leitura/escrita"
 
 #. Tag: para
-#: performance.xml:755
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the application needs to update data, a <literal>read-write</literal> "
 "cache might be appropriate. This cache strategy should never be used if "
@@ -1554,41 +1386,26 @@
 "should ensure that the underlying cache implementation supports locking. The "
 "built-in cache providers <emphasis>do not</emphasis> support locking."
 msgstr ""
-"If the application needs to update data, a <literal>read-write</literal> "
-"cache might be appropriate. This cache strategy should never be used if "
-"serializable transaction isolation level is required. If the cache is used "
-"in a JTA environment, you must specify the property <literal>hibernate."
-"transaction.manager_lookup_class</literal>, naming a strategy for obtaining "
-"the JTA <literal>TransactionManager</literal>. In other environments, you "
-"should ensure that the transaction is completed when <literal>Session.close()"
-"</literal> or <literal>Session.disconnect()</literal> is called. If you wish "
-"to use this strategy in a cluster, you should ensure that the underlying "
-"cache implementation supports locking. The built-in cache providers do "
-"<emphasis>not</emphasis>."
+"Se a aplicação precisar atualizar dados, um cache de <literal>read-write</"
+"literal> pode ser mais apropriado. Esta estratégia de cache nunca deve ser "
+"usada se solicitado um nível de isolação de transação serializável. Se o "
+"cache for usado em um ambiente JTA, você deve especificar a propriedade "
+"<literal>hibernate.transaction.manager_lookup_class</literal>, nomeando uma "
+"estratégia por obter o <literal>TransactionManager</literal> JTA. Em outros "
+"ambientes, você deve assegurar que a transação está completa quando a "
+"<literal>Session.close()</literal> ou <literal>Session.disconnect()</"
+"literal> for chamada. Se desejar utilizar esta estratégia em um cluster, "
+"você deve assegurar que a implementação de cache adjacente suporta o "
+"bloqueio. Os provedores de cache built-in <emphasis>não</emphasis> suportam "
+"o bloqueamento."
 
-#. Tag: programlisting
-#: performance.xml:766
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Cat\" .... >\n"
-"    <cache usage=\"read-write\"/>\n"
-"    ....\n"
-"    <set name=\"kittens\" ... >\n"
-"        <cache usage=\"read-write\"/>\n"
-"        ....\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:771
 #, no-c-format
 msgid "Strategy: nonstrict read/write"
-msgstr "Strategy: nonstrict read/write"
+msgstr "Estratégia: leitura/escrita não estrita"
 
 #. Tag: para
-#: performance.xml:773
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the application only occasionally needs to update data (i.e. if it is "
 "extremely unlikely that two transactions would try to update the same item "
@@ -1599,101 +1416,88 @@
 "should ensure that the transaction is completed when <literal>Session.close()"
 "</literal> or <literal>Session.disconnect()</literal> is called."
 msgstr ""
-"If the application only occasionally needs to update data (ie. if it is "
-"extremely unlikely that two transactions would try to update the same item "
-"simultaneously) and strict transaction isolation is not required, a "
-"<literal>nonstrict-read-write</literal> cache might be appropriate. If the "
-"cache is used in a JTA environment, you must specify <literal>hibernate."
-"transaction.manager_lookup_class</literal>. In other environments, you "
-"should ensure that the transaction is completed when <literal>Session.close()"
-"</literal> or <literal>Session.disconnect()</literal> is called."
+"Se a aplicação somente precisa atualizar dados ocasionalmente (ou seja, se "
+"for extremamente improvável que as duas transações tentem atualizar o mesmo "
+"ítem simultaneamente) e não for requerido uma isolação de transação estrita, "
+"o uso deum cache de <literal>nonstrict-read-write</literal> pode ser mais "
+"apropriado. Se um cache é usado em ambiente JTA, você deverá especificar o "
+"<literal>hibernate.transaction.manager_lookup_class</literal>. Em outros "
+"ambientes, você deve assegurar que a transação está completa quando a "
+"<literal>Session.close()</literal> ou <literal>Session.disconnect()</"
+"literal> for chamada."
 
 #. Tag: title
-#: performance.xml:785
 #, no-c-format
 msgid "Strategy: transactional"
-msgstr "Strategy: transactional"
+msgstr "Estratégia: transacional"
 
 #. Tag: para
-#: performance.xml:787
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>transactional</literal> cache strategy provides support for "
 "fully transactional cache providers such as JBoss TreeCache. Such a cache "
 "can only be used in a JTA environment and you must specify "
 "<literal>hibernate.transaction.manager_lookup_class</literal>."
 msgstr ""
-"The <literal>transactional</literal> cache strategy provides support for "
-"fully transactional cache providers such as JBoss TreeCache. Such a cache "
-"may only be used in a JTA environment and you must specify "
+"A estratégia de cache <literal>transactional</literal> provê suporte para "
+"provedores de cache transacional completo como o JBoss TreeCache. Tal cache, "
+"deve ser usado somente em um ambiente JTA e você deverá especificar o "
 "<literal>hibernate.transaction.manager_lookup_class</literal>."
 
 #. Tag: title
-#: performance.xml:796
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Cache-provider/concurrency-strategy compatibility"
-msgstr "Cache Concurrency Strategy Support"
+msgstr "Compatibilidade de Estratégia de Concorrência de Cache Provedor"
 
 #. Tag: para
-#: performance.xml:799
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "None of the cache providers support all of the cache concurrency strategies."
 msgstr ""
-"None of the cache providers support all of the cache concurrency strategies. "
-"The following table shows which providers are compatible with which "
-"concurrency strategies."
+"Nenhum provedor de cache suporta todas as estratégias de concorrência de "
+"cache. "
 
 #. Tag: para
-#: performance.xml:804
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table shows which providers are compatible with which "
 "concurrency strategies."
 msgstr ""
-"None of the cache providers support all of the cache concurrency strategies. "
-"The following table shows which providers are compatible with which "
-"concurrency strategies."
+"A seguinte tabela mostra qual provedor é compatível com qual estratégia de "
+"concorrência. "
 
 #. Tag: title
-#: performance.xml:809
 #, no-c-format
 msgid "Cache Concurrency Strategy Support"
-msgstr "Cache Concurrency Strategy Support"
+msgstr "Suporte de Estratégia de Concorrência de Cache"
 
 #. Tag: entry
-#: performance.xml:819
 #, no-c-format
 msgid "read-only"
-msgstr "read-only"
+msgstr "somente leitura"
 
 #. Tag: entry
-#: performance.xml:820
 #, no-c-format
 msgid "nonstrict-read-write"
-msgstr "nonstrict-read-write"
+msgstr "leitura-escrita não estrita"
 
 #. Tag: entry
-#: performance.xml:821
 #, no-c-format
 msgid "read-write"
-msgstr "read-write"
+msgstr "leitura-escrita"
 
 #. Tag: entry
-#: performance.xml:822
 #, no-c-format
 msgid "transactional"
-msgstr "transactional"
+msgstr "transacional"
 
 #. Tag: title
-#: performance.xml:877
 #, no-c-format
 msgid "Managing the caches"
-msgstr "Managing the caches"
+msgstr "Gerenciando os caches"
 
 #. Tag: para
-#: performance.xml:879
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Whenever you pass an object to <literal>save()</literal>, <literal>update()</"
 "literal> or <literal>saveOrUpdate()</literal>, and whenever you retrieve an "
@@ -1702,16 +1506,14 @@
 "</literal>, that object is added to the internal cache of the "
 "<literal>Session</literal>."
 msgstr ""
-"Whenever you pass an object to <literal>save()</literal>, <literal>update()</"
-"literal> or <literal>saveOrUpdate()</literal> and whenever you retrieve an "
-"object using <literal>load()</literal>, <literal>get()</literal>, "
-"<literal>list()</literal>, <literal>iterate()</literal> or <literal>scroll()"
-"</literal>, that object is added to the internal cache of the "
-"<literal>Session</literal>."
+"Quando passar um objeto para <literal>save()</literal>, <literal>update()</"
+"literal> ou <literal>saveOrUpdate()</literal> e quando recuperar um objeto "
+"usando um <literal>load()</literal>, <literal>get()</literal>, <literal>list"
+"()</literal>, <literal>iterate()</literal> ou <literal>scroll()</literal>, "
+"este objeto será adicionado ao cache interno da <literal>Session</literal>."
 
 #. Tag: para
-#: performance.xml:886
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When <literal>flush()</literal> is subsequently called, the state of that "
 "object will be synchronized with the database. If you do not want this "
@@ -1720,312 +1522,281 @@
 "can be used to remove the object and its collections from the first-level "
 "cache."
 msgstr ""
-"When <literal>flush()</literal> is subsequently called, the state of that "
-"object will be synchronized with the database. If you do not want this "
-"synchronization to occur or if you are processing a huge number of objects "
-"and need to manage memory efficiently, the <literal>evict()</literal> method "
-"may be used to remove the object and its collections from the first-level "
-"cache."
+"Quando o <literal>flush()</literal> for subsequentemente chamado, o estado "
+"deste objeto será sincronizado com o banco de dados. Se você não desejar que "
+"esta sincronização aconteça ou se você estiver processando uma grande "
+"quantidade de objetos e precisar gerenciar a memória de forma eficiente, o "
+"método <literal>evict()</literal> pode ser usado para remover o objeto de "
+"suas coleções de cache de primeiro nível."
 
-#. Tag: programlisting
-#: performance.xml:894
-#, no-c-format
-msgid ""
-"<![CDATA[ScrollableResult cats = sess.createQuery(\"from Cat as cat\").scroll"
-"(); //a huge result set\n"
-"while ( cats.next() ) {\n"
-"    Cat cat = (Cat) cats.get(0);\n"
-"    doSomethingWithACat(cat);\n"
-"    sess.evict(cat);\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:896
 #, no-c-format
 msgid ""
 "The <literal>Session</literal> also provides a <literal>contains()</literal> "
 "method to determine if an instance belongs to the session cache."
 msgstr ""
-"The <literal>Session</literal> also provides a <literal>contains()</literal> "
-"method to determine if an instance belongs to the session cache."
+"A <literal>Session</literal> também oferece um método<literal>contains()</"
+"literal> para determinar se uma instância pertence ao cache de sessão."
 
 #. Tag: para
-#: performance.xml:901
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To evict all objects from the session cache, call <literal>Session.clear()</"
 "literal>"
 msgstr ""
-"To completely evict all objects from the session cache, call "
+"Para despejar completamente todos os objetos do cache de Sessão, chame "
 "<literal>Session.clear()</literal>"
 
 #. Tag: para
-#: performance.xml:905
 #, no-c-format
 msgid ""
 "For the second-level cache, there are methods defined on "
 "<literal>SessionFactory</literal> for evicting the cached state of an "
 "instance, entire class, collection instance or entire collection role."
 msgstr ""
-"For the second-level cache, there are methods defined on "
-"<literal>SessionFactory</literal> for evicting the cached state of an "
-"instance, entire class, collection instance or entire collection role."
+"Para o cache de segundo nível, existem métodos definidos na "
+"<literal>SessionFactory</literal> para despejar o estado de cache de uma "
+"instância, classe inteira, instância de coleção ou papel de coleção inteiro."
 
-#. Tag: programlisting
-#: performance.xml:911
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sessionFactory.evict(Cat.class, catId); //evict a particular Cat\n"
-"sessionFactory.evict(Cat.class);  //evict all Cats\n"
-"sessionFactory.evictCollection(\"Cat.kittens\", catId); //evict a particular "
-"collection of kittens\n"
-"sessionFactory.evictCollection(\"Cat.kittens\"); //evict all kitten "
-"collections]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:913
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>CacheMode</literal> controls how a particular session interacts "
 "with the second-level cache:"
 msgstr ""
-"The <literal>CacheMode</literal> controls how a particular session interacts "
-"with the second-level cache."
+"O <literal>CacheMode</literal> controla como uma sessão em particular "
+"interage com o cache de segundo nível:"
 
 #. Tag: para
-#: performance.xml:920
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.NORMAL</literal>: will read items from and write items to "
 "the second-level cache"
 msgstr ""
-"<literal>CacheMode.NORMAL</literal> - read items from and write items to the "
-"second-level cache"
+"<literal>CacheMode.NORMAL</literal> - lê e escreve itens ao cache de segundo "
+"nível."
 
 #. Tag: para
-#: performance.xml:925
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.GET</literal>: will read items from the second-level "
 "cache. Do not write to the second-level cache except when updating data"
 msgstr ""
-"<literal>CacheMode.GET</literal> - read items from the second-level cache, "
-"but don't write to the second-level cache except when updating data"
+"<literal>CacheMode.GET</literal>: itens de leitura do cache de segundo "
+"nível. Não escreve ao cache de segundo nível, exceto quando atualizar dados."
 
 #. Tag: para
-#: performance.xml:931
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.PUT</literal>: will write items to the second-level "
 "cache. Do not read from the second-level cache"
 msgstr ""
-"<literal>CacheMode.PUT</literal> - write items to the second-level cache, "
-"but don't read from the second-level cache"
+"<literal>CacheMode.PUT</literal>: escreve itens ao cache de segundo nível. "
+"Não lê a partir do cache de segundo nível."
 
 #. Tag: para
-#: performance.xml:937
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.REFRESH</literal>: will write items to the second-level "
 "cache. Do not read from the second-level cache. Bypass the effect of "
 "<literal>hibernate.cache.use_minimal_puts</literal> forcing a refresh of the "
 "second-level cache for all items read from the database"
 msgstr ""
-"<literal>CacheMode.REFRESH</literal> - write items to the second-level "
-"cache, but don't read from the second-level cache, bypass the effect of "
-"<literal>hibernate.cache.use_minimal_puts</literal>, forcing a refresh of "
-"the second-level cache for all items read from the database"
+"<literal>CacheMode.REFRESH</literal>: escreve itens ao cache de segundo "
+"nível, mas não lê a partir do cache de segundo nível. Passa o efeito de "
+"<literal>hibernate.cache.use_minimal_puts</literal>, forçando uma "
+"atualização do cache de segundo nível para que todos os itens leiam a partir "
+"do banco de dados. "
 
 #. Tag: para
-#: performance.xml:945
 #, no-c-format
 msgid ""
 "To browse the contents of a second-level or query cache region, use the "
 "<literal>Statistics</literal> API:"
 msgstr ""
-"To browse the contents of a second-level or query cache region, use the "
-"<literal>Statistics</literal> API:"
+"Para navegar o conteúdo do segundo nível ou região de cache de consulta, use "
+"o<literal>Statistics</literal> API:"
 
-#. Tag: programlisting
-#: performance.xml:950
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Map cacheEntries = sessionFactory.getStatistics()\n"
-"        .getSecondLevelCacheStatistics(regionName)\n"
-"        .getEntries();]]>"
+"You will need to enable statistics and, optionally, force Hibernate to keep "
+"the cache entries in a more readable format:"
 msgstr ""
+"Você precisará habilitar estatísticas e, opcionalmente, forçar o Hibernate a "
+"manter as entradas de cache em um formato mais compreensível: "
 
+#. Tag: title
+#, no-c-format
+msgid "The Query Cache"
+msgstr "O Cache de Consulta"
+
 #. Tag: para
-#: performance.xml:952
 #, fuzzy, no-c-format
 msgid ""
-"You will need to enable statistics and, optionally, force Hibernate to keep "
-"the cache entries in a more readable format:"
+"Query result sets can also be cached. This is only useful for queries that "
+"are run frequently with the same parameters."
 msgstr ""
-"You'll need to enable statistics, and, optionally, force Hibernate to keep "
-"the cache entries in a more human-understandable format:"
+"O conjunto de resultado de consulta pode também estar em cache. Isto é útil, "
+"somente para consultas que são rodadas freqüentemente com os mesmos "
+"parâmetros. Para usar o cache de consulta você deve habilitá-lo primeiro: "
 
-#. Tag: programlisting
-#: performance.xml:957
+#. Tag: title
 #, no-c-format
+msgid "Enabling query caching"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
 msgid ""
-"<![CDATA[hibernate.generate_statistics true\n"
-"hibernate.cache.use_structured_entries true]]>"
+"Caching of query results introduces some overhead in terms of your "
+"applications normal transactional processing. For example, if you cache "
+"results of a query against Person Hibernate will need to keep track of when "
+"those results should be invalidated because changes have been committed "
+"against Person. That, coupled with the fact that most applications simply "
+"gain no benefit from caching query results, leads Hibernate to disable "
+"caching of query results by default. To use query caching, you will first "
+"need to enable the query cache:"
 msgstr ""
 
-#. Tag: title
-#: performance.xml:962
+#. Tag: para
 #, no-c-format
-msgid "The Query Cache"
-msgstr "The Query Cache"
+msgid "This setting creates two new cache regions:"
+msgstr ""
 
 #. Tag: para
-#: performance.xml:964
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"Query result sets can also be cached. This is only useful for queries that "
-"are run frequently with the same parameters. You will first need to enable "
-"the query cache:"
+"<classname>org.hibernate.cache.StandardQueryCache</classname>, holding the "
+"cached query results"
 msgstr ""
-"Query result sets may also be cached. This is only useful for queries that "
-"are run frequently with the same parameters. To use the query cache you must "
-"first enable it:"
 
-#. Tag: programlisting
-#: performance.xml:969
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[hibernate.cache.use_query_cache true]]>"
+msgid ""
+"<classname>org.hibernate.cache.UpdateTimestampsCache</classname>, holding "
+"timestamps of the most recent updates to queryable tables. These are used to "
+"validate the results as they are served from the query cache."
 msgstr ""
 
 #. Tag: para
-#: performance.xml:971
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"This setting creates two new cache regions: one holding cached query result "
-"sets (<literal>org.hibernate.cache.StandardQueryCache</literal>), the other "
-"holding timestamps of the most recent updates to queryable tables "
-"(<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). Note that "
-"the query cache does not cache the state of the actual entities in the "
-"result set; it caches only identifier values and results of value type. The "
-"query cache should always be used in conjunction with the second-level cache."
+"If you configure your underlying cache implementation to use expiry or "
+"timeouts is is very important that the cache timeout of the underlying cache "
+"region for the UpdateTimestampsCache be set to a higher value than the "
+"timeouts of any of the query caches. In fact, we recommend that the the "
+"UpdateTimestampsCache region not be configured for expiry at all. Note, in "
+"particular, that an LRU cache expiry policy is never appropriate."
 msgstr ""
-"This setting causes the creation of two new cache regions - one holding "
-"cached query result sets (<literal>org.hibernate.cache.StandardQueryCache</"
-"literal>), the other holding timestamps of the most recent updates to "
-"queryable tables (<literal>org.hibernate.cache.UpdateTimestampsCache</"
-"literal>). Note that the query cache does not cache the state of the actual "
-"entities in the result set; it caches only identifier values and results of "
-"value type. So the query cache should always be used in conjunction with the "
-"second-level cache."
 
 #. Tag: para
-#: performance.xml:981
 #, fuzzy, no-c-format
 msgid ""
-"Most queries do not benefit from caching, so by default, queries are not "
-"cached. To enable caching, call <literal>Query.setCacheable(true)</literal>. "
-"This call allows the query to look for existing cache results or add its "
-"results to the cache when it is executed."
+"As mentioned above, most queries do not benefit from caching or their "
+"results. So by default, individual queries are not cached even after "
+"enabling query caching. To enable results caching for a particular query, "
+"call <literal>org.hibernate.Query.setCacheable(true)</literal>. This call "
+"allows the query to look for existing cache results or add its results to "
+"the cache when it is executed."
 msgstr ""
-"Most queries do not benefit from caching, so by default queries are not "
-"cached. To enable caching, call <literal>Query.setCacheable(true)</literal>. "
-"This call allows the query to look for existing cache results or add its "
-"results to the cache when it is executed."
+"A maioria das consultas não se beneficiam do cache, portanto por padrão, "
+"eles não estão em cache. Para habilitar o caching, chame <literal>Query."
+"setCacheable(true)</literal>. Esta chamada permite que a consulta procure "
+"por resultados de caches existentes ou adicione seus resultados ao cache "
+"quando for executado.  "
 
 #. Tag: para
-#: performance.xml:988
+#, no-c-format
+msgid ""
+"The query cache does not cache the state of the actual entities in the "
+"cache; it caches only identifier values and results of value type. For this "
+"reaso, the query cache should always be used in conjunction with the second-"
+"level cache for those entities expected to be cached as part of a query "
+"result cache (just as with collection caching)."
+msgstr ""
+
+#. Tag: title
 #, fuzzy, no-c-format
+msgid "Query cache regions"
+msgstr "Cache de Consulta Suportado"
+
+#. Tag: para
+#, no-c-format
 msgid ""
 "If you require fine-grained control over query cache expiration policies, "
 "you can specify a named cache region for a particular query by calling "
 "<literal>Query.setCacheRegion()</literal>."
 msgstr ""
-"If you require fine-grained control over query cache expiration policies, "
-"you may specify a named cache region for a particular query by calling "
-"<literal>Query.setCacheRegion()</literal>."
+"Se você solicitar um controle de granulado fino com políticas de validade do "
+"cache de consulta, você poderá especificar uma região de cache nomeada para "
+"uma consulta em particular, chamando <literal>Query.setCacheRegion()</"
+"literal>."
 
-#. Tag: programlisting
-#: performance.xml:994
-#, no-c-format
-msgid ""
-"<![CDATA[List blogs = sess.createQuery(\"from Blog blog where blog.blogger "
-"= :blogger\")\n"
-"    .setEntity(\"blogger\", blogger)\n"
-"    .setMaxResults(15)\n"
-"    .setCacheable(true)\n"
-"    .setCacheRegion(\"frontpages\")\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:996
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"If the query should force a refresh of its query cache region, you should "
-"call <literal>Query.setCacheMode(CacheMode.REFRESH)</literal>. This is "
-"particularly useful in cases where underlying data may have been updated via "
-"a separate process (i.e., not modified through Hibernate) and allows the "
-"application to selectively refresh particular query result sets. This is a "
-"more efficient alternative to eviction of a query cache region via "
-"<literal>SessionFactory.evictQueries()</literal>."
+"If you want to force the query cache to refresh one of its regions "
+"(disregard any cached results it finds there) you can use <literal>org."
+"hibernate.Query.setCacheMode(CacheMode.REFRESH)</literal>. In conjunction "
+"with the region you have defined for the given query, Hibernate will "
+"selectively force the results cached in that particular region to be "
+"refreshed. This is particularly useful in cases where underlying data may "
+"have been updated via a separate process and is a far more efficient "
+"alternative to bulk eviction of the region via <literal>org.hibernate."
+"SessionFactory.evictQueries()</literal>."
 msgstr ""
-"If the query should force a refresh of its query cache region, you should "
-"call <literal>Query.setCacheMode(CacheMode.REFRESH)</literal>. This is "
-"particularly useful in cases where underlying data may have been updated via "
-"a separate process (i.e., not modified through Hibernate) and allows the "
-"application to selectively refresh particular query result sets. This is a "
-"more efficient alternative to eviction of a query cache region via "
-"<literal>SessionFactory.evictQueries()</literal>."
+"Se a consulta forçar uma atualização de sua região de cache de consulta, "
+"você deve chamar <literal>Query.setCacheMode(CacheMode.REFRESH)</literal>. "
+"Isto é particularmente útil em casos onde dados adjacentes podem ter sido "
+"atualizados através de um processo em separado (ou seja, não modificado "
+"através do Hibernate) e permite que a aplicação atualize de forma seletiva "
+"um conjunto particular de resultado de consulta. Esta alternativa é mais "
+"eficiente se aplicada ao despejo de uma região de cache de consulta através "
+"de <literal>SessionFactory.evictQueries()</literal>."
 
 #. Tag: title
-#: performance.xml:1008
 #, no-c-format
 msgid "Understanding Collection performance"
-msgstr "Understanding Collection performance"
+msgstr "Entendendo o desempenho da Coleção"
 
 #. Tag: para
-#: performance.xml:1010
 #, no-c-format
 msgid ""
 "In the previous sections we have covered collections and their applications. "
 "In this section we explore some more issues in relation to collections at "
 "runtime."
 msgstr ""
+"Nas seções anteriores nós descrevemos as coleções e seus aplicativos. Nesta "
+"seção nós exploraremos mais problemas em relação às coleções no período de "
+"execução."
 
 #. Tag: title
-#: performance.xml:1017
 #, no-c-format
 msgid "Taxonomy"
-msgstr "Taxonomy"
+msgstr "Taxonomia"
 
 #. Tag: para
-#: performance.xml:1019
 #, no-c-format
 msgid "Hibernate defines three basic kinds of collections:"
-msgstr "Hibernate defines three basic kinds of collections:"
+msgstr "O Hibernate define três tipos básicos de coleções:"
 
 #. Tag: para
-#: performance.xml:1023
 #, no-c-format
 msgid "collections of values"
-msgstr "collections of values"
+msgstr "Coleções de valores"
 
 #. Tag: para
-#: performance.xml:1026
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "one-to-many associations"
-msgstr "one to many associations"
+msgstr "Associações um-para-muitos "
 
 #. Tag: para
-#: performance.xml:1029
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "many-to-many associations"
-msgstr "many to many associations"
+msgstr "Associações muitos-para-muitos "
 
 #. Tag: para
-#: performance.xml:1033
 #, no-c-format
 msgid ""
 "This classification distinguishes the various table and foreign key "
@@ -2035,34 +1806,30 @@
 "primary key that is used by Hibernate to update or delete collection rows. "
 "This suggests the following classification:"
 msgstr ""
-"This classification distinguishes the various table and foreign key "
-"relationships but does not tell us quite everything we need to know about "
-"the relational model. To fully understand the relational structure and "
-"performance characteristics, we must also consider the structure of the "
-"primary key that is used by Hibernate to update or delete collection rows. "
-"This suggests the following classification:"
+"A classificação distingue as diversas tabelas e relacionamento de chave "
+"externa, mas não nos diz tudo que precisamos saber sobre o modelo "
+"relacional. Para entender completamente a estrutura relacional e as "
+"características de desempenho, devemos também considerar a estrutura da "
+"chave primária que é usada pelo Hibernate para atualizar ou deletar linhas "
+"de coleções. Isto sugere a seguinte classificação:"
 
 #. Tag: para
-#: performance.xml:1044
 #, no-c-format
 msgid "indexed collections"
-msgstr "indexed collections"
+msgstr "Coleções indexadas"
 
 #. Tag: para
-#: performance.xml:1047
 #, no-c-format
 msgid "sets"
-msgstr "sets"
+msgstr "conjuntos"
 
 #. Tag: para
-#: performance.xml:1050
 #, no-c-format
 msgid "bags"
-msgstr "bags"
+msgstr "Bags"
 
 #. Tag: para
-#: performance.xml:1054
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All indexed collections (maps, lists, and arrays) have a primary key "
 "consisting of the <literal>&lt;key&gt;</literal> and <literal>&lt;index&gt;</"
@@ -2070,15 +1837,15 @@
 "The primary key can be efficiently indexed and a particular row can be "
 "efficiently located when Hibernate tries to update or delete it."
 msgstr ""
-"All indexed collections (maps, lists, arrays) have a primary key consisting "
-"of the <literal>&lt;key&gt;</literal> and <literal>&lt;index&gt;</literal> "
-"columns. In this case collection updates are usually extremely efficient - "
-"the primary key may be efficiently indexed and a particular row may be "
-"efficiently located when Hibernate tries to update or delete it."
+"Todas as coleções indexadas (mapas, listas, matrizes) possuem uma chave "
+"primária, que consiste em colunas <literal>&lt;key&gt;</literal> e "
+"<literal>&lt;index&gt;</literal>. Neste caso, as atualizações de coleção são "
+"geralmente muito eficientes. A chave primária pode ser indexada de forma "
+"eficiente e uma linha em particular pode ser localizada de forma eficiente "
+"quando o Hibernate tentar atualizar ou deletá-la. "
 
 #. Tag: para
-#: performance.xml:1062
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sets have a primary key consisting of <literal>&lt;key&gt;</literal> and "
 "element columns. This can be less efficient for some types of collection "
@@ -2090,29 +1857,29 @@
 "<literal>&lt;set&gt;</literal>, you must declare all columns as <literal>not-"
 "null=\"true\"</literal>."
 msgstr ""
-"Sets have a primary key consisting of <literal>&lt;key&gt;</literal> and "
-"element columns. This may be less efficient for some types of collection "
-"element, particularly composite elements or large text or binary fields; the "
-"database may not be able to index a complex primary key as efficently. On "
-"the other hand, for one to many or many to many associations, particularly "
-"in the case of synthetic identifiers, it is likely to be just as efficient. "
-"(Side-note: if you want <literal>SchemaExport</literal> to actually create "
-"the primary key of a <literal>&lt;set&gt;</literal> for you, you must "
-"declare all columns as <literal>not-null=\"true\"</literal>.)"
+"Os conjuntos possuem uma chave primária que consiste em <literal>&lt;key&gt;"
+"</literal> e colunas de elemento. Isto pode ser menos eficiente para alguns "
+"tipos de elementos de coleções, especialmente elementos compostos ou textos "
+"grandes ou ainda campos binários. O banco de dados pode não ser capaz de "
+"indexar uma chave primária complexa de forma tão eficiente. Por um outro "
+"lado, para associações um-para-muitos ou muitos-para-muitos, especialmente "
+"no caso de identificadores sintáticos, é bem provável que seja tão eficiente "
+"quanto. Se você quiser que o <literal>SchemaExport</literal> crie para você "
+"uma chave primária de um <literal>&lt;set&gt;</literal> você deverá declarar "
+"todas as colunas como <literal>not-null=\"true\"</literal>."
 
 #. Tag: para
-#: performance.xml:1073
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>&lt;idbag&gt;</literal> mappings define a surrogate key, so they "
 "are efficient to update. In fact, they are the best case."
 msgstr ""
-"<literal>&lt;idbag&gt;</literal> mappings define a surrogate key, so they "
-"are always very efficient to update. In fact, they are the best case."
+"Os mapeamentos <literal>&lt;idbag&gt;</literal> definem uma chave "
+"substituta, para que elas sejam sempre muito eficientes ao atualizar. Na "
+"verdade, este é o melhor caso. "
 
 #. Tag: para
-#: performance.xml:1078
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Bags are the worst case since they permit duplicate element values and, as "
 "they have no index column, no primary key can be defined. Hibernate has no "
@@ -2120,49 +1887,47 @@
 "problem by completely removing in a single <literal>DELETE</literal> and "
 "recreating the collection whenever it changes. This can be inefficient."
 msgstr ""
-"Bags are the worst case. Since a bag permits duplicate element values and "
-"has no index column, no primary key may be defined. Hibernate has no way of "
-"distinguishing between duplicate rows. Hibernate resolves this problem by "
-"completely removing (in a single <literal>DELETE</literal>) and recreating "
-"the collection whenever it changes. This might be very inefficient."
+"As Bags são os piores casos. Como uma bag permite duplicar valores de "
+"elementos e não possui coluna de índice, não se deve definir nenhuma chave "
+"primária. O Hibernate não tem como distinguir entre linhas duplicadas. O "
+"Hibernate resolve este problema, removendo completamente em um único "
+"<literal>DELETE</literal> e recria a coleção quando mudar. Isto pode ser "
+"bastante ineficiente."
 
 #. Tag: para
-#: performance.xml:1086
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For a one-to-many association, the \"primary key\" may not be the physical "
 "primary key of the database table. Even in this case, the above "
 "classification is still useful. It reflects how Hibernate \"locates\" "
 "individual rows of the collection."
 msgstr ""
-"Note that for a one-to-many association, the \"primary key\" may not be the "
-"physical primary key of the database table - but even in this case, the "
-"above classification is still useful. (It still reflects how Hibernate "
-"\"locates\" individual rows of the collection.)"
+"Note que para uma associação um-para-muitos, a chave primária pode não ser a "
+"chave primária física da tabela do banco de dados, mas mesmo neste caso, a "
+"classificação acima é ainda útil. Isto reflete como o Hibernate \"localiza\" "
+"linhas individuais da coleção."
 
 #. Tag: title
-#: performance.xml:1096
 #, no-c-format
 msgid ""
 "Lists, maps, idbags and sets are the most efficient collections to update"
 msgstr ""
-"Lists, maps, idbags and sets are the most efficient collections to update"
+"Listas, mapas, bags de id e conjuntos são coleções mais eficientes para "
+"atualizar"
 
 #. Tag: para
-#: performance.xml:1098
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "From the discussion above, it should be clear that indexed collections and "
 "sets allow the most efficient operation in terms of adding, removing and "
 "updating elements."
 msgstr ""
-"From the discussion above, it should be clear that indexed collections and "
-"(usually) sets allow the most efficient operation in terms of adding, "
-"removing and updating elements."
+"A partir da discussão acima, deve ficar claro que as coleções indexadas e "
+"conjuntos (geralmente) permitem uma operação mais eficente em termos de "
+"adição, remoção e atualização de elementos.  "
 
 #. Tag: para
-#: performance.xml:1104
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is, arguably, one more advantage that indexed collections have over "
 "sets for many-to-many associations or collections of values. Because of the "
@@ -2172,17 +1937,16 @@
 "literal> of individual rows. Once again, this consideration does not apply "
 "to one-to-many associations."
 msgstr ""
-"There is, arguably, one more advantage that indexed collections have over "
-"sets for many to many associations or collections of values. Because of the "
-"structure of a <literal>Set</literal>, Hibernate doesn't ever "
-"<literal>UPDATE</literal> a row when an element is \"changed\". Changes to a "
-"<literal>Set</literal> always work via <literal>INSERT</literal> and "
-"<literal>DELETE</literal> (of individual rows). Once again, this "
-"consideration does not apply to one to many associations."
+"Existe ainda, mais uma vantagem, das coleções indexadas sob conjuntos para "
+"associações muitos-para-muitos. Por causa da estrutura de um <literal>Set</"
+"literal>, o Hibernate nunca utiliza o comando <literal>UPDATE</literal> em "
+"uma linha quando um elemento é \"modificado\". As mudanças para o <literal> "
+"Conjunto</literal> funcionam sempre através do comando <literal>INSERT</"
+"literal> e <literal>DELETE</literal> de linhas individuais. Novamente, esta "
+"consideração não se aplica às associações um para muitos. "
 
 #. Tag: para
-#: performance.xml:1113
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "After observing that arrays cannot be lazy, you can conclude that lists, "
 "maps and idbags are the most performant (non-inverse) collection types, with "
@@ -2190,15 +1954,14 @@
 "collection in Hibernate applications. This is because the \"set\" semantics "
 "are most natural in the relational model."
 msgstr ""
-"After observing that arrays cannot be lazy, we would conclude that lists, "
-"maps and idbags are the most performant (non-inverse) collection types, with "
-"sets not far behind. Sets are expected to be the most common kind of "
-"collection in Hibernate applications. This is because the \"set\" semantics "
-"are most natural in the relational model."
+"Após observar que as matrizes não podem ser preguiçosas, nós concluimos que "
+"as listas, mapas e bags de id são tipos de coleções com maior desempenho "
+"(não inverso), com conjuntos que não ficam atrás. Espera-se que os conjuntos "
+"sejam um tipo mais comum de coleção nas aplicações Hibernate. Isto porque as "
+"semânticas \"conjunto\" são mais naturais em modelos relacionais. "
 
 #. Tag: para
-#: performance.xml:1121
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, in well-designed Hibernate domain models, most collections are in "
 "fact one-to-many associations with <literal>inverse=\"true\"</literal>. For "
@@ -2206,21 +1969,20 @@
 "association, and so considerations of collection update performance simply "
 "do not apply."
 msgstr ""
-"However, in well-designed Hibernate domain models, we usually see that most "
-"collections are in fact one-to-many associations with <literal>inverse=\"true"
-"\"</literal>. For these associations, the update is handled by the many-to-"
-"one end of the association, and so considerations of collection update "
-"performance simply do not apply."
+"No entanto, em modelos de domínio de Hibernate bem criados, geralmente vemos "
+"que a maioria das coleções são de fato, associações um-para-muitos com "
+"<literal>inverse=\"true\"</literal>. Para estas associações, a atualização é "
+"manipulada pelo lado muitos-para-um de uma associação e portanto "
+"considerações de desempenho de atualização de coleção simplesmente não se "
+"aplicam a este caso.  "
 
 #. Tag: title
-#: performance.xml:1131
 #, no-c-format
 msgid "Bags and lists are the most efficient inverse collections"
-msgstr "Bags and lists are the most efficient inverse collections"
+msgstr "As Bags e listas são as coleções de inversão mais eficientes."
 
 #. Tag: para
-#: performance.xml:1133
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is a particular case, however, in which bags, and also lists, are much "
 "more performant than sets. For a collection with <literal>inverse=\"true\"</"
@@ -2231,131 +1993,110 @@
 "literal> must always return true for a bag or <literal>List</literal>. This "
 "can make the following common code much faster:"
 msgstr ""
-"Just before you ditch bags forever, there is a particular case in which bags "
-"(and also lists) are much more performant than sets. For a collection with "
-"<literal>inverse=\"true\"</literal> (the standard bidirectional one-to-many "
-"relationship idiom, for example) we can add elements to a bag or list "
-"without needing to initialize (fetch) the bag elements! This is because "
-"<literal>Collection.add()</literal> or <literal>Collection.addAll()</"
-"literal> must always return true for a bag or <literal>List</literal> "
-"(unlike a <literal>Set</literal>). This can make the following common code "
-"much faster."
+"Existe um caso em particular no qual as bags (e também as listas) possuem um "
+"desempenho muito maior do que conjuntos. Para uma coleção com "
+"<literal>inverse=\"true\"</literal>, o idioma de relacionamento um-para-um "
+"bidirecional padrão, por exemplo, podemos adicionar elementos a uma bag ou "
+"uma lista sem precisar inicializar (buscar) os elementos da bag. Isto "
+"acontece porque a <literal>Collection.add()</literal> ou <literal>Collection."
+"addAll()</literal> deve sempre retornar verdadeira para uma bag ou "
+"<literal>List</literal>. Isto pode fazer que o código comum seguinte seja "
+"muito mais rápido:"
 
-#. Tag: programlisting
-#: performance.xml:1143
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = (Parent) sess.load(Parent.class, id);\n"
-"Child c = new Child();\n"
-"c.setParent(p);\n"
-"p.getChildren().add(c);  //no need to fetch the collection!\n"
-"sess.flush();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:1148
 #, no-c-format
 msgid "One shot delete"
-msgstr "One shot delete"
+msgstr "Deletar uma vez"
 
 #. Tag: para
-#: performance.xml:1150
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Deleting collection elements one by one can sometimes be extremely "
 "inefficient. Hibernate knows not to do that in the case of an newly-empty "
 "collection (if you called <literal>list.clear()</literal>, for example). In "
 "this case, Hibernate will issue a single <literal>DELETE</literal>."
 msgstr ""
-"Occasionally, deleting collection elements one by one can be extremely "
-"inefficient. Hibernate isn't completely stupid, so it knows not to do that "
-"in the case of an newly-empty collection (if you called <literal>list.clear()"
-"</literal>, for example). In this case, Hibernate will issue a single "
-"<literal>DELETE</literal> and we are done!"
+"Às vezes, deletar elementos de coleção um por um pode ser extremamente "
+"ineficiente. O Hibernate não é completamente burro, portanto ele sabe que "
+"não deve fazer isso no caso de uma coleção que tenha sido esvaziada "
+"recentemente (se você chamou <literal>list.clear()</literal>, por exemplo). "
+"Neste caso, o Hibernate irá editar um único <literal>DELETE</literal>."
 
 #. Tag: para
-#: performance.xml:1157
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Suppose you added a single element to a collection of size twenty and then "
 "remove two elements. Hibernate will issue one <literal>INSERT</literal> "
 "statement and two <literal>DELETE</literal> statements, unless the "
 "collection is a bag. This is certainly desirable."
 msgstr ""
-"Suppose we add a single element to a collection of size twenty and then "
-"remove two elements. Hibernate will issue one <literal>INSERT</literal> "
-"statement and two <literal>DELETE</literal> statements (unless the "
-"collection is a bag). This is certainly desirable."
+"Vamos supor que tenha adicionado um elemento único à uma coleção de tamanho "
+"vinte e então remove dois elementos. O Hibernate irá editar uma instrução "
+"<literal>INSERT</literal> e duas instruções <literal>DELETE</literal>, a não "
+"ser que a coleção seja uma bag. Isto é certamente desejável."
 
 #. Tag: para
-#: performance.xml:1163
 #, no-c-format
 msgid ""
 "However, suppose that we remove eighteen elements, leaving two and then add "
 "thee new elements. There are two possible ways to proceed"
 msgstr ""
-"However, suppose that we remove eighteen elements, leaving two and then add "
-"thee new elements. There are two possible ways to proceed"
+"No entanto, suponha que removamos dezoito elementos, deixando dois e então "
+"adicionando três novos elementos. Existem duas formas possíveis de se "
+"proceder:"
 
 #. Tag: para
-#: performance.xml:1170
 #, no-c-format
 msgid "delete eighteen rows one by one and then insert three rows"
-msgstr "delete eighteen rows one by one and then insert three rows"
+msgstr "delete dezoito linhas uma por uma e então insira três linhas"
 
 #. Tag: para
-#: performance.xml:1173
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "remove the whole collection in one SQL <literal>DELETE</literal> and insert "
 "all five current elements one by one"
 msgstr ""
-"remove the whole collection (in one SQL <literal>DELETE</literal>) and "
-"insert all five current elements (one by one)"
+"remova toda a coleção em um SQL <literal>DELETE</literal> e insira todos os "
+"cinco elementos atuais, um por um"
 
 #. Tag: para
-#: performance.xml:1178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate cannot know that the second option is probably quicker. It would "
 "probably be undesirable for Hibernate to be that intuitive as such behavior "
 "might confuse database triggers, etc."
 msgstr ""
-"Hibernate isn't smart enough to know that the second option is probably "
-"quicker in this case. (And it would probably be undesirable for Hibernate to "
-"be that smart; such behaviour might confuse database triggers, etc.)"
+"O Hibernate não sabe que a segunda opção é provavelmente mais rápida neste "
+"caso. O Hibernate não deseha saber a opção, uma vez que tal comportamento "
+"deve confundir os triggers do banco de dados, etc."
 
 #. Tag: para
-#: performance.xml:1184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Fortunately, you can force this behavior (i.e. the second strategy) at any "
 "time by discarding (i.e. dereferencing) the original collection and "
 "returning a newly instantiated collection with all the current elements."
 msgstr ""
-"Fortunately, you can force this behaviour (ie. the second strategy) at any "
-"time by discarding (ie. dereferencing) the original collection and returning "
-"a newly instantiated collection with all the current elements. This can be "
-"very useful and powerful from time to time."
+"Felizmente, você pode forçar este comportamento (ou seja, uma segunda "
+"estratégia) a qualquer momento, descartando (ou seja, desreferenciando) a "
+"coleção original e retornando uma coleção recentemente instanciada com todos "
+"os elementos atuais. "
 
 #. Tag: para
-#: performance.xml:1190
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "One-shot-delete does not apply to collections mapped <literal>inverse=\"true"
 "\"</literal>."
 msgstr ""
-"Of course, one-shot-delete does not apply to collections mapped "
+"É claro que, deletar somente uma vez, não se aplica às coleções mapeadas "
 "<literal>inverse=\"true\"</literal>."
 
 #. Tag: title
-#: performance.xml:1199
 #, no-c-format
 msgid "Monitoring performance"
-msgstr "Monitoring performance"
+msgstr "Monitorando desempenho"
 
 #. Tag: para
-#: performance.xml:1201
 #, no-c-format
 msgid ""
 "Optimization is not much use without monitoring and access to performance "
@@ -2363,167 +2104,126 @@
 "operations. Statistics in Hibernate are available per "
 "<literal>SessionFactory</literal>."
 msgstr ""
-"Optimization is not much use without monitoring and access to performance "
-"numbers. Hibernate provides a full range of figures about its internal "
-"operations. Statistics in Hibernate are available per "
+"A otimização não é muito usada sem o monitoramento e acesso ao número de "
+"desempenho. O Hibernate oferece uma grande variedade de números sobre suas "
+"operações internas. Estatísticas em Hibernate estão disponíveis através do "
 "<literal>SessionFactory</literal>."
 
 #. Tag: title
-#: performance.xml:1208
 #, no-c-format
 msgid "Monitoring a SessionFactory"
-msgstr "Monitoring a SessionFactory"
+msgstr "Monitorando uma SessionFactory"
 
 #. Tag: para
-#: performance.xml:1210
 #, no-c-format
 msgid ""
 "You can access <literal>SessionFactory</literal> metrics in two ways. Your "
 "first option is to call <literal>sessionFactory.getStatistics()</literal> "
 "and read or display the <literal>Statistics</literal> yourself."
 msgstr ""
-"You can access <literal>SessionFactory</literal> metrics in two ways. Your "
-"first option is to call <literal>sessionFactory.getStatistics()</literal> "
-"and read or display the <literal>Statistics</literal> yourself."
+"Você poderá acessar as métricas da <literal>SessionFactory</literal> de duas "
+"formas. Sua primeira opção é chamar a <literal>sessionFactory.getStatistics()"
+"</literal> e ler ou dispôr as <literal>Estatísticas</literal> você mesmo."
 
 #. Tag: para
-#: performance.xml:1216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate can also use JMX to publish metrics if you enable the "
 "<literal>StatisticsService</literal> MBean. You can enable a single MBean "
 "for all your <literal>SessionFactory</literal> or one per factory. See the "
 "following code for minimalistic configuration examples:"
 msgstr ""
-"Hibernate can also use JMX to publish metrics if you enable the "
-"<literal>StatisticsService</literal> MBean. You may enable a single MBean "
-"for all your <literal>SessionFactory</literal> or one per factory. See the "
-"following code for minimalistic configuration examples:"
+"O Hibernate também usa o JMX para publicar métricas se você habilitar o "
+"MBean de <literal>StatisticsService</literal>. Você deve habiliar um MBean "
+"único para todas as suas <literal>SessionFactory</literal> ou uma por "
+"factory. Veja o seguinte código para exemplos de configurações "
+"minimalísticos: "
 
-#. Tag: programlisting
-#: performance.xml:1223
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// MBean service registration for a specific SessionFactory\n"
-"Hashtable tb = new Hashtable();\n"
-"tb.put(\"type\", \"statistics\");\n"
-"tb.put(\"sessionFactory\", \"myFinancialApp\");\n"
-"ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-"\n"
-"StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-"stats.setSessionFactory(sessionFactory); // Bind the stats to a "
-"SessionFactory\n"
-"server.registerMBean(stats, on); // Register the Mbean on the server]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: performance.xml:1226
-#, no-c-format
-msgid ""
-"<![CDATA[// MBean service registration for all SessionFactory's\n"
-"Hashtable tb = new Hashtable();\n"
-"tb.put(\"type\", \"statistics\");\n"
-"tb.put(\"sessionFactory\", \"all\");\n"
-"ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-"\n"
-"StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-"server.registerMBean(stats, on); // Register the MBean on the server]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:1228
-#, fuzzy, no-c-format
-msgid ""
 "You can activate and deactivate the monitoring for a "
 "<literal>SessionFactory</literal>:"
 msgstr ""
-"You can (de)activate the monitoring for a <literal>SessionFactory</literal>"
+"Você pode (des)ativar o monitoramento para uma <literal>SessionFactory</"
+"literal>:"
 
 #. Tag: para
-#: performance.xml:1233
 #, no-c-format
 msgid ""
 "at configuration time, set <literal>hibernate.generate_statistics</literal> "
 "to <literal>false</literal>"
 msgstr ""
-"at configuration time, set <literal>hibernate.generate_statistics</literal> "
-"to <literal>false</literal>"
+"no tempo de configuração, ajuste <literal>hibernate.generate_statistics</"
+"literal> para <literal>falso</literal>"
 
 #. Tag: para
-#: performance.xml:1240
 #, no-c-format
 msgid ""
 "at runtime: <literal>sf.getStatistics().setStatisticsEnabled(true)</literal> "
 "or <literal>hibernateStatsBean.setStatisticsEnabled(true)</literal>"
 msgstr ""
-"at runtime: <literal>sf.getStatistics().setStatisticsEnabled(true)</literal> "
-"or <literal>hibernateStatsBean.setStatisticsEnabled(true)</literal>"
+"em tempo de espera: <literal>sf.getStatistics().setStatisticsEnabled(true)</"
+"literal> ou <literal>hibernateStatsBean.setStatisticsEnabled(true)</literal>"
 
 #. Tag: para
-#: performance.xml:1247
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Statistics can be reset programmatically using the <literal>clear()</"
 "literal> method. A summary can be sent to a logger (info level) using the "
 "<literal>logSummary()</literal> method."
 msgstr ""
-"Statistics can be reset programatically using the <literal>clear()</literal> "
-"method. A summary can be sent to a logger (info level) using the "
-"<literal>logSummary()</literal> method."
+"As estatísticas podem ser reajsutadas de forma programática, usando o método "
+"<literal>clear()</literal>. Um resumo pode ser enviado para o usuário (nível "
+"de info) usando o método <literal>logSummary()</literal>. "
 
 #. Tag: title
-#: performance.xml:1256
 #, no-c-format
 msgid "Metrics"
-msgstr "Metrics"
+msgstr "Métricas"
 
 #. Tag: para
-#: performance.xml:1258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate provides a number of metrics, from basic information to more "
 "specialized information that is only relevant in certain scenarios. All "
 "available counters are described in the <literal>Statistics</literal> "
 "interface API, in three categories:"
 msgstr ""
-"Hibernate provides a number of metrics, from very basic to the specialized "
-"information only relevant in certain scenarios. All available counters are "
-"described in the <literal>Statistics</literal> interface API, in three "
-"categories:"
+"O Hibernate oferece um número de métricas, desde informações bem básicas até "
+"especializadas, somente relevantes a certos cenários. Todos os contadores "
+"disponíveis estão descritos na API da interface <literal>Statistics</"
+"literal>, em três categorias: "
 
 #. Tag: para
-#: performance.xml:1265
 #, no-c-format
 msgid ""
 "Metrics related to the general <literal>Session</literal> usage, such as "
 "number of open sessions, retrieved JDBC connections, etc."
 msgstr ""
-"Metrics related to the general <literal>Session</literal> usage, such as "
-"number of open sessions, retrieved JDBC connections, etc."
+"As métricas relacionadas ao uso da <literal>Sessão</literal>, tal como um "
+"número de sessões em aberto, conexões JDBC recuperadas, etc."
 
 #. Tag: para
-#: performance.xml:1271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Metrics related to the entities, collections, queries, and caches as a whole "
 "(aka global metrics)."
 msgstr ""
-"Metrics related to he entities, collections, queries, and caches as a whole "
-"(aka global metrics),"
+"As métricas relacionadas às entidades, coleções, consultas e caches como um "
+"todo (mais conhecido como métricas globais). "
 
 #. Tag: para
-#: performance.xml:1277
 #, no-c-format
 msgid ""
 "Detailed metrics related to a particular entity, collection, query or cache "
 "region."
 msgstr ""
-"Detailed metrics related to a particular entity, collection, query or cache "
-"region."
+"Métricas detalhadas relacionadas à uma entidade em particular, coleção, "
+"consulta ou região de cache."
 
 #. Tag: para
-#: performance.xml:1284
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For example, you can check the cache hit, miss, and put ratio of entities, "
 "collections and queries, and the average time a query needs. Be aware that "
@@ -2531,15 +2231,14 @@
 "tied to the JVM precision and on some platforms this might only be accurate "
 "to 10 seconds."
 msgstr ""
-"For exampl,e you can check the cache hit, miss, and put ratio of entities, "
-"collections and queries, and the average time a query needs. Beware that the "
-"number of milliseconds is subject to approximation in Java. Hibernate is "
-"tied to the JVM precision, on some platforms this might even only be "
-"accurate to 10 seconds."
+"Por exemplo, você pode verificar a coincidência de um cache, perder e "
+"colocar a relação entre as entidades, colações e consultas e tempo médio que "
+"uma consulta precisa. Esteja ciente de que o número de milisegundos é "
+"sujeito a aproximação em Java. O Hibernate é preso à precisão do JVM, em "
+"algumas plataformas a precisão chega a ser de 10 segundos. "
 
 #. Tag: para
-#: performance.xml:1291
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Simple getters are used to access the global metrics (i.e. not tied to a "
 "particular entity, collection, cache region, etc.). You can access the "
@@ -2551,90 +2250,48 @@
 "literal> API Javadoc for more information. The following code is a simple "
 "example:"
 msgstr ""
-"Simple getters are used to access the global metrics (i.e. not tied to a "
-"particular entity, collection, cache region, etc.). You can access the "
-"metrics of a particular entity, collection or cache region through its name, "
-"and through its HQL or SQL representation for queries. Please refer to the "
-"<literal>Statistics</literal>, <literal>EntityStatistics</literal>, "
-"<literal>CollectionStatistics</literal>, "
-"<literal>SecondLevelCacheStatistics</literal>, and <literal>QueryStatistics</"
-"literal> API Javadoc for more information. The following code shows a simple "
-"example:"
+"Os Getters simples são usados para acessar métricas globais (ou seja, não "
+"presos à uma entidade em particular, coleção, região de cache, etc.) Você "
+"pode acessar as métricas de uma entidade em particular, coleção ou região de "
+"cache através de seu nome e através de sua representação de HQL ou SQL para "
+"consultas. Por favor consulte a Javadoc API <literal>Statistics</literal>, "
+"<literal>EntityStatistics</literal>, <literal>CollectionStatistics</"
+"literal>, <literal>SecondLevelCacheStatistics</literal>, e "
+"<literal>QueryStatistics</literal> para maiores informações. O seguinte "
+"código mostra um exemplo simples:  "
 
-#. Tag: programlisting
-#: performance.xml:1301
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Statistics stats = HibernateUtil.sessionFactory.getStatistics();\n"
-"\n"
-"double queryCacheHitCount  = stats.getQueryCacheHitCount();\n"
-"double queryCacheMissCount = stats.getQueryCacheMissCount();\n"
-"double queryCacheHitRatio =\n"
-"  queryCacheHitCount / (queryCacheHitCount + queryCacheMissCount);\n"
-"\n"
-"log.info(\"Query Hit ratio:\" + queryCacheHitRatio);\n"
-"\n"
-"EntityStatistics entityStats =\n"
-"  stats.getEntityStatistics( Cat.class.getName() );\n"
-"long changes =\n"
-"        entityStats.getInsertCount()\n"
-"        + entityStats.getUpdateCount()\n"
-"        + entityStats.getDeleteCount();\n"
-"log.info(Cat.class.getName() + \" changed \" + changes + \"times\"  );]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:1303
-#, fuzzy, no-c-format
-msgid ""
 "You can work on all entities, collections, queries and region caches, by "
 "retrieving the list of names of entities, collections, queries and region "
 "caches using the following methods: <literal>getQueries()</literal>, "
 "<literal>getEntityNames()</literal>, <literal>getCollectionRoleNames()</"
 "literal>, and <literal>getSecondLevelCacheRegionNames()</literal>."
 msgstr ""
-"To work on all entities, collections, queries and region caches, you can "
-"retrieve the list of names of entities, collections, queries and region "
-"caches with the following methods: <literal>getQueries()</literal>, "
-"<literal>getEntityNames()</literal>, <literal>getCollectionRoleNames()</"
-"literal>, and <literal>getSecondLevelCacheRegionNames()</literal>."
+"Para trabalhar em todas as entidades, coleções, consultas e caches "
+"regionais, você poderá recuperar os nomes de lista de entidades, coleções, "
+"consultas e caches regionais com os seguintes métodos: <literal>getQueries()"
+"</literal>, <literal>getEntityNames()</literal>, "
+"<literal>getCollectionRoleNames()</literal>, e "
+"<literal>getSecondLevelCacheRegionNames()</literal>. "
 
 #~ msgid ""
-#~ "where <literal>CatImpl</literal> implements the interface <literal>Cat</"
-#~ "literal> and <literal>DomesticCatImpl</literal> implements the interface "
-#~ "<literal>DomesticCat</literal>. Then proxies for instances of "
-#~ "<literal>Cat</literal> and <literal>DomesticCat</literal> may be returned "
-#~ "by <literal>load()</literal> or <literal>iterate()</literal>. (Note that "
-#~ "<literal>list()</literal> does not usually return proxies.)"
+#~ "This setting creates two new cache regions: one holding cached query "
+#~ "result sets (<literal>org.hibernate.cache.StandardQueryCache</literal>), "
+#~ "the other holding timestamps of the most recent updates to queryable "
+#~ "tables (<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). "
+#~ "Note that the query cache does not cache the state of the actual entities "
+#~ "in the result set; it caches only identifier values and results of value "
+#~ "type. The query cache should always be used in conjunction with the "
+#~ "second-level cache."
 #~ msgstr ""
-#~ "onde <literal>CatImpl</literal> implementa a interface <literal>Cat</"
-#~ "literal> e <literal>DomesticCatImpl</literal> implementa a interface "
-#~ "<literal>DomesticCat</literal>. Então proxies para instâncias de "
-#~ "<literal>Cat</literal> e <literal>DomesticCat</literal> serão retornadas "
-#~ "por <literal>load()</literal> ou <literal>iterate()</literal>. (Note que "
-#~ "<literal>list()</literal> geralmente não retorna proxies)."
-
-#~ msgid ""
-#~ "We've already spent quite some time talking about collections. In this "
-#~ "section we will highlight a couple more issues about how collections "
-#~ "behave at runtime."
-#~ msgstr ""
-#~ "We've already spent quite some time talking about collections. In this "
-#~ "section we will highlight a couple more issues about how collections "
-#~ "behave at runtime."
-
-#~ msgid ""
-#~ "TODO: This doesn't make sense: In the first case, we retrieve and use the "
-#~ "MBean directly. In the second one, we must give the JNDI name in which "
-#~ "the session factory is held before using it. Use "
-#~ "<literal>hibernateStatsBean.setSessionFactoryJNDIName(\"my/JNDI/Name\")</"
-#~ "literal>"
-#~ msgstr ""
-#~ "TODO: This doesn't make sense: In the first case, we retrieve and use the "
-#~ "MBean directly. In the second one, we must give the JNDI name in which "
-#~ "the session factory is held before using it. Use "
-#~ "<literal>hibernateStatsBean.setSessionFactoryJNDIName(\"my/JNDI/Name\")</"
-#~ "literal>"
-
-#~ msgid "yes"
-#~ msgstr "yes"
+#~ "Esta configuração cria duas novas regiões de cache, um conjunto de "
+#~ "resultado de consulta em cache de retenção (<literal>org.hibernate.cache."
+#~ "StandardQueryCache</literal>), os outros carimbos de data e hora "
+#~ "timestamps de retenção das atualizações recentes de tabelas consultáveis "
+#~ "(<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). Note que "
+#~ "o cache de consulta não efetua o cache no estado das entidades atuais no "
+#~ "conjunto de resultados. Ele somente efetua o cache de valores de "
+#~ "identificadores e resulta em tipo de valor. Portanto, o cache de consulta "
+#~ "deve sempre ser usado junto ao cache de segundo nível. "

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/persistent_classes.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/persistent_classes.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/persistent_classes.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,129 @@
+# translation of persistent_classes.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: persistent_classes\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-19 17:20+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: persistent_classes.xml:29
 #, no-c-format
 msgid "Persistent Classes"
-msgstr "Persistent Classes"
+msgstr "Classes Persistentes"
 
 #. Tag: para
-#: persistent_classes.xml:31
-#, fuzzy, no-c-format
+#, 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 "
@@ -26,14 +131,14 @@
 "in the persistent state. For example, an instance can instead be transient "
 "or detached."
 msgstr ""
-"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 - an instance may instead be transient or detached."
+"As classes persistentes são classes dentro de um aplicativo que implementa "
+"as entidades de problemas de negócios (ex.: Cliente e Pedido em um "
+"aplicativo e-commerce). Nem todas as instâncias de uma classe persistente "
+"estão em estado persistente, uma instância pode, ao invés disso, ser "
+"transiente ou desanexada. "
 
 #. Tag: para
-#: persistent_classes.xml:38
-#, fuzzy, no-c-format
+#, 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 "
@@ -41,128 +146,43 @@
 "about the nature of your persistent objects. You can express a domain model "
 "in other ways (using trees of <literal>Map</literal> instances, for example)."
 msgstr ""
-"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 may express a domain model "
-"in other ways: using trees of <literal>Map</literal> instances, for example."
+"O Hibernate trabalha melhor se estas classes seguirem uma regra simples, "
+"também conhecida como modelo de programação Objeto de Java Antigo Simples "
+"(POJO). No entanto, nenhuma destas regras são difíceis solicitações. "
+"Certamente, o Hibernate3 considera muito pouco da natureza de seus objetos "
+"persistentes. Você pode expressar um modelo de domínio de outras formas (por "
+"exemplo: utilizando árvores de instâncias <literal>Map</literal>)."
 
 #. Tag: title
-#: persistent_classes.xml:47
 #, no-c-format
 msgid "A simple POJO example"
-msgstr "A simple POJO example"
+msgstr "Um exemplo simples de POJO"
 
 #. Tag: para
-#: persistent_classes.xml:49
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Most Java applications require a persistent class representing felines. For "
 "example:"
 msgstr ""
-"Most Java applications require a persistent class representing felines."
+"A maior parte dos aplicativos Java requerem uma classe persistente que "
+"representa os felinos. Por exemplo:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:53
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"import java.util.Date;\n"
-"\n"
-"public class Cat {\n"
-"    private Long id; // identifier\n"
-"\n"
-"    private Date birthdate;\n"
-"    private Color color;\n"
-"    private char sex;\n"
-"    private float weight;\n"
-"    private int litterId;\n"
-"\n"
-"    private Cat mother;\n"
-"    private Set kittens = new HashSet();\n"
-"\n"
-"    private void setId(Long id) {\n"
-"        this.id=id;\n"
-"    }\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"\n"
-"    void setBirthdate(Date date) {\n"
-"        birthdate = date;\n"
-"    }\n"
-"    public Date getBirthdate() {\n"
-"        return birthdate;\n"
-"    }\n"
-"\n"
-"    void setWeight(float weight) {\n"
-"        this.weight = weight;\n"
-"    }\n"
-"    public float getWeight() {\n"
-"        return weight;\n"
-"    }\n"
-"\n"
-"    public Color getColor() {\n"
-"        return color;\n"
-"    }\n"
-"    void setColor(Color color) {\n"
-"        this.color = color;\n"
-"    }\n"
-"\n"
-"    void setSex(char sex) {\n"
-"        this.sex=sex;\n"
-"    }\n"
-"    public char getSex() {\n"
-"        return sex;\n"
-"    }\n"
-"\n"
-"    void setLitterId(int id) {\n"
-"        this.litterId = id;\n"
-"    }\n"
-"    public int getLitterId() {\n"
-"        return litterId;\n"
-"    }\n"
-"\n"
-"    void setMother(Cat mother) {\n"
-"        this.mother = mother;\n"
-"    }\n"
-"    public Cat getMother() {\n"
-"        return mother;\n"
-"    }\n"
-"    void setKittens(Set kittens) {\n"
-"        this.kittens = kittens;\n"
-"    }\n"
-"    public Set getKittens() {\n"
-"        return kittens;\n"
-"    }\n"
-"    \n"
-"    // addKitten not needed by Hibernate\n"
-"    public void addKitten(Cat kitten) {\n"
-"            kitten.setMother(this);\n"
-"        kitten.setLitterId( kittens.size() ); \n"
-"        kittens.add(kitten);\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:55
 #, no-c-format
 msgid ""
 "The four main rules of persistent classes are explored in more detail in the "
 "following sections."
 msgstr ""
+"As quatro regras principais das classes persistentes são descritas em "
+"maiores detalhes nas seguintes seções."
 
 #. Tag: title
-#: persistent_classes.xml:61
 #, no-c-format
 msgid "Implement a no-argument constructor"
-msgstr "Implement a no-argument constructor"
+msgstr "Implemente um construtor de não argumento"
 
 #. Tag: para
-#: persistent_classes.xml:63
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Cat</literal> has a no-argument constructor. All persistent classes "
 "must have a default constructor (which can be non-public) so that Hibernate "
@@ -171,22 +191,20 @@
 "<emphasis>package</emphasis> visibility for runtime proxy generation in "
 "Hibernate."
 msgstr ""
-"<literal>Cat</literal> has a no-argument constructor. All persistent classes "
-"must have a default constructor (which may be non-public) so that Hibernate "
-"can instantiate them using <literal>Constructor.newInstance()</literal>. We "
-"strongly recommend having a default constructor with at least "
-"<emphasis>package</emphasis> visibility for runtime proxy generation in "
-"Hibernate."
+"<literal>Cat</literal> possui um construtor de não argumento. Todas as "
+"classes persistentes devem ter um construtor padrão (que não pode ser "
+"público), para que o Hibernate possa instanciá-lo utilizando um "
+"<literal>Constructor.newInstance()</literal>. Nós recomendamos enfaticamente "
+"ter um construtor padrão com ao menos uma visibilidade <emphasis>package</"
+"emphasis> para a geração de um proxy de tempo de espera no Hibernate. "
 
 #. Tag: title
-#: persistent_classes.xml:73
 #, no-c-format
 msgid "Provide an identifier property (optional)"
-msgstr "Provide an identifier property (optional)"
+msgstr "Providencie uma propriedade de identificador (opcional)"
 
 #. Tag: para
-#: persistent_classes.xml:75
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Cat</literal> has a property called <literal>id</literal>. This "
 "property maps to the primary key column of a database table. The property "
@@ -196,102 +214,93 @@
 "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</literal> has a property called <literal>id</literal>. 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</literal> or "
-"<literal>java.util.Date</literal>. (If your legacy database table has "
-"composite keys, you can even use a user-defined class with properties of "
-"these types - see the section on composite identifiers later.)"
+"<literal>Cat</literal> possui uma propriedade chamada <literal>id</literal>. "
+"Esta propriedade mapeia para a coluna de chave primária de uma tabela de "
+"banco de dados. A propriedade pode ter sido chamada por qualquer nome e seu "
+"tipo pode ter sido qualquer um primitivo, ou qualquer tipo \"wrapper\", "
+"<literal>java.lang.String</literal> ou <literal>java.util.Date</literal>. Se "
+"sua tabela de banco de dados de legacia possuir chaves compostas, você "
+"também poderá usar uma classe de usuário definido, com propriedades destes "
+"tipos (veja a seção de identificadores compostos mais adiante.)"
 
 #. Tag: para
-#: persistent_classes.xml:84
 #, 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 ""
-"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."
+"A propriedade de identificador é estritamente opcional. Você pode deixá-los "
+"desligados e deixar que o Hibernate encontre os identificadores de objeto "
+"internamente. No entanto, não recomendamos que faça isto."
 
 #. Tag: para
-#: persistent_classes.xml:89
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In fact, some functionality is available only to classes that declare an "
 "identifier property:"
 msgstr ""
-"In fact, some functionality is available only to classes which declare an "
-"identifier property:"
+"Na verdade, algumas funcionalidades estão disponíveis somente para classes "
+"que declaram uma propriedade de identificador:"
 
 #. Tag: para
-#: persistent_classes.xml:96
 #, fuzzy, no-c-format
 msgid ""
 "Transitive reattachment for detached objects (cascade update or cascade "
-"merge) - see"
+"merge) - see <xref linkend=\"objectstate-transitive\" />"
 msgstr ""
-"Transitive reattachment for detached objects (cascade update or cascade "
-"merge) - see <xref linkend=\"objectstate-transitive\"/>"
+"Reconexão transitiva para objetos desanexados (atualização de cascata ou "
+"mesclagem de cascata) - veja <xref linkend=\"objectstate-transitive\" />"
 
-#. Tag: literal
-#: persistent_classes.xml:103
-#, no-c-format
-msgid "Session.saveOrUpdate()"
-msgstr "Session.saveOrUpdate()"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>Session.saveOrUpdate()</literal>"
+msgstr "<literal>Session.saveOrUpdate()</literal>"
 
-#. Tag: literal
-#: persistent_classes.xml:108
-#, no-c-format
-msgid "Session.merge()"
-msgstr "Session.merge()"
-
 #. Tag: para
-#: persistent_classes.xml:113
 #, fuzzy, no-c-format
+msgid "<literal>Session.merge()</literal>"
+msgstr "<literal>Session.merge()</literal>"
+
+#. Tag: para
+#, 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 ""
-"We recommend you declare consistently-named identifier properties on "
-"persistent classes. We further recommend that you use a nullable (ie. non-"
-"primitive) type."
+"Recomendamos que você declare propriedades de identificador nomeados de "
+"forma consistente nas classes persistentes e que você use um tipo anulável "
+"(ou seja, não primitivo)."
 
 #. Tag: title
-#: persistent_classes.xml:120
 #, no-c-format
 msgid "Prefer non-final classes (optional)"
-msgstr "Prefer non-final classes (optional)"
+msgstr "Prefira classes não finais (opcional)"
 
 #. Tag: para
-#: persistent_classes.xml:121
 #, no-c-format
 msgid ""
 "A central feature of Hibernate, <emphasis>proxies</emphasis>, depends upon "
 "the persistent class being either non-final, or the implementation of an "
 "interface that declares all public methods."
 msgstr ""
-"A central feature of Hibernate, <emphasis>proxies</emphasis>, depends upon "
-"the persistent class being either non-final, or the implementation of an "
-"interface that declares all public methods."
+"Um recurso central do Hibernate, <emphasis>proxies</emphasis>, depende da "
+"classe persistente ser tanto não final como uma implementação de uma "
+"interface que declare todos os métodos públicos."
 
 #. Tag: para
-#: persistent_classes.xml:126
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can persist <literal>final</literal> 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 ""
-"You can persist <literal>final</literal> classes that do not implement an "
-"interface with Hibernate, but you won't be able to use proxies for lazy "
-"association fetching - which will limit your options for performance tuning."
+"Você pode persistir as classes <literal>final</literal> que não implementam "
+"uma interface com o Hibernate, mas não poderá usar os proxies para busca por "
+"associação lazy, que irá limitar suas opções para ajuste de desempenho. "
 
 #. Tag: para
-#: persistent_classes.xml:131
 #, no-c-format
 msgid ""
 "You should also avoid declaring <literal>public final</literal> methods on "
@@ -299,20 +308,18 @@
 "final</literal> method, you must explicitly disable proxying by setting "
 "<literal>lazy=\"false\"</literal>."
 msgstr ""
-"You should also avoid declaring <literal>public final</literal> methods on "
-"the non-final classes. If you want to use a class with a <literal>public "
-"final</literal> method, you must explicitly disable proying by setting "
-"<literal>lazy=\"false\"</literal>."
+"Você deve evitar declarar métodos <literal>public final</literal> em classes "
+"não finais. Se você desejar usar uma classe com um método <literal>public "
+"final</literal> você deve desabilitar o proxy explicitamente, ajustando "
+"<literal>lazy=\"false\"</literal>. "
 
 #. Tag: title
-#: persistent_classes.xml:139
 #, no-c-format
 msgid "Declare accessors and mutators for persistent fields (optional)"
-msgstr "Declare accessors and mutators for persistent fields (optional)"
+msgstr "Declare acessores e mutadores para campos persistentes (opcional)"
 
 #. Tag: para
-#: persistent_classes.xml:141
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Cat</literal> declares accessor methods for all its persistent "
 "fields. Many other ORM tools directly persist instance variables. It is "
@@ -322,100 +329,75 @@
 "literal>, <literal>isFoo</literal> and <literal>setFoo</literal>. If "
 "required, you can switch to direct field access for particular properties."
 msgstr ""
-"<literal>Cat</literal> declares accessor methods for all its persistent "
-"fields. Many other ORM tools directly persist instance variables. We believe "
-"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>getFoo</literal>, <literal>isFoo</literal> and <literal>setFoo</"
-"literal>. You may switch to direct field access for particular properties, "
-"if needed."
+"<literal>Cat</literal> declara os métodos assessores para todos os seus "
+"campos persistentes. Muitas ferramentas ORM persistem diretamente variáveis "
+"de instâncias. Acreditamos ser melhor prover uma indireção entre o esquema "
+"relacional e as estruturas de dados internos da classe. Por padrão, o "
+"Hibernate persiste as propriedades de estilo JavaBeans, e reconhece nomes de "
+"métodos da forma <literal>getFoo</literal>, <literal>isFoo</literal> e "
+"<literal>setFoo</literal>. Caso solicitado, você pode mudar para direcionar "
+"acesso ao campo para certas propriedades, caso seja necessário. "
 
 #. Tag: para
-#: persistent_classes.xml:151
 #, no-c-format
 msgid ""
 "Properties need <emphasis>not</emphasis> be declared public - Hibernate can "
 "persist a property with a default, <literal>protected</literal> or "
 "<literal>private</literal> get / set pair."
 msgstr ""
-"Properties need <emphasis>not</emphasis> be declared public - Hibernate can "
-"persist a property with a default, <literal>protected</literal> or "
-"<literal>private</literal> get / set pair."
+"As propriedades precisam <emphasis>not</emphasis> ser declaradas como "
+"públicas. O Hibernate pode persistir uma propriedade com um par get/set "
+"padrão <literal>protegido</literal> ou <literal>privado</literal>."
 
 #. Tag: title
-#: persistent_classes.xml:162
 #, no-c-format
 msgid "Implementing inheritance"
-msgstr "Implementing inheritance"
+msgstr "Implementando herança"
 
 #. Tag: para
-#: persistent_classes.xml:164
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A subclass must also observe the first and second rules. It inherits its "
 "identifier property from the superclass, <literal>Cat</literal>. For example:"
 msgstr ""
-"A subclass must also observe the first and second rules. It inherits its "
-"identifier property from the superclass, <literal>Cat</literal>."
+"Uma subclasse também deve observar as primeiras e segundas regras. Ela herda "
+"sua propriedade de identificador a partir das superclasses, <literal>Cat</"
+"literal>. Por exemplo:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:169
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"public class DomesticCat extends Cat {\n"
-"        private String name;\n"
-"\n"
-"        public String getName() {\n"
-"                return name;\n"
-"        }\n"
-"        protected void setName(String name) {\n"
-"                this.name=name;\n"
-"        }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: persistent_classes.xml:173
 #, no-c-format
 msgid ""
 "Implementing <literal>equals()</literal> and <literal>hashCode()</literal>"
 msgstr ""
-"Implementing <literal>equals()</literal> and <literal>hashCode()</literal>"
+"Implementando <literal>equals()</literal> e <literal>hashCode()</literal> "
 
 #. Tag: para
-#: persistent_classes.xml:175
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You have to override the <literal>equals()</literal> and <literal>hashCode()"
 "</literal> methods if you:"
 msgstr ""
-"You have to override the <literal>equals()</literal> and <literal>hashCode()"
-"</literal> methods if you"
+"Você precisa substituir os métodos <literal>equals()</literal> e "
+"<literal>hashCode()</literal> se você:"
 
 #. Tag: para
-#: persistent_classes.xml:181
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "intend to put instances of persistent classes in a <literal>Set</literal> "
 "(the recommended way to represent many-valued associations); <emphasis>and</"
 "emphasis>"
 msgstr ""
-"intend to put instances of persistent classes in a <literal>Set</literal> "
-"(the recommended way to represent many-valued associations) <emphasis>and</"
-"emphasis>"
+"pretender inserir instâncias de classes persistentes em um <literal>Set</"
+"literal> (a forma mais recomendada é representar associações de muitos "
+"valores), <emphasis>e</emphasis>"
 
 #. Tag: para
-#: persistent_classes.xml:188
 #, no-c-format
 msgid "intend to use reattachment of detached instances"
-msgstr "intend to use reattachment of detached instances"
+msgstr "pretender usar reconexão de instâncias desanexadas"
 
 #. Tag: para
-#: persistent_classes.xml:194
-#, fuzzy, no-c-format
+#, 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 "
@@ -423,15 +405,15 @@
 "literal> and <literal>hashCode()</literal> if you wish to have meaningful "
 "semantics for <literal>Set</literal>s."
 msgstr ""
-"Hibernate guarantees equivalence of persistent identity (database row) and "
-"Java identity only inside a particular session scope. So as soon as we mix "
-"instances retrieved in different sessions, we must implement <literal>equals"
-"()</literal> and <literal>hashCode()</literal> if we wish to have meaningful "
-"semantics for <literal>Set</literal>s."
+"O Hibernate garante a equivalência de identidades persistentes (linha de "
+"base de dados) e identidade Java somente dentro de um certo escopo de "
+"sessão. Dessa forma, assim que misturarmos instâncias recuperadas em sessões "
+"diferentes, devemos implementar <literal>equals()</literal> e "
+"<literal>hashCode()</literal> se quisermos ter semânticas significativas "
+"para os <literal>Set</literal>s.  "
 
 #. Tag: para
-#: persistent_classes.xml:202
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The most obvious way is to implement <literal>equals()</literal>/"
 "<literal>hashCode()</literal> by comparing the identifier value of both "
@@ -448,25 +430,25 @@
 "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 ""
-"The most obvious way is to implement <literal>equals()</literal>/"
-"<literal>hashCode()</literal> by comparing the identifier value of both "
-"objects. If the value is the same, both must be the same database row, they "
-"are therefore equal (if both are added to a <literal>Set</literal>, we will "
-"only have one element in the <literal>Set</literal>). Unfortunately, we "
-"can't 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</literal>, saving it will assign an "
-"identifier value to the object. If <literal>equals()</literal> and "
-"<literal>hashCode()</literal> are based on the identifier value, the hash "
-"code would change, breaking the contract of the <literal>Set</literal>. See "
-"the Hibernate website for a full discussion of this problem. Note that this "
-"is not a Hibernate issue, but normal Java semantics of object identity and "
-"equality."
+"A forma mais óbvia é implementar <literal>equals()</literal>/"
+"<literal>hashCode()</literal> comparando o valor do identificador de ambos "
+"objetos. Caso o valor seja o mesmo, ambos devem ter a mesma linha de base de "
+"dados, assim eles serão iguais (se ambos forem adicionados a um "
+"<literal>Set</literal>, nós só teremos um elemento no <literal>Set</"
+"literal>). Infelizmente, não podemos usar esta abordagem com os "
+"identificadores gerados. O Hibernate atribuirá somente os valores de "
+"identificadores aos objetos que forem persistentes, uma instância "
+"recentemente criada não terá nenhum valor de identificador. Além disso, se "
+"uma instância não for salva e estiver em um <literal>Set</literal>, salvá-la "
+"atribuirá um valor de identificador ao objeto. Se <literal>equals()</"
+"literal> e <literal>hashCode()</literal> fossem baseados em um valor "
+"identificador, o código hash teria mudado, quebrando o contrato do "
+"<literal>Set</literal>. Consulte o website do Hibernate para acessar uma "
+"discussão completa sobre este problema. Note que esta não é uma edição do "
+"Hibernate, e sim semânticas naturais do Java de igualdade e identidade."
 
 #. Tag: para
-#: persistent_classes.xml:216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you implement <literal>equals()</literal> and "
 "<literal>hashCode()</literal> using <emphasis>Business key equality</"
@@ -475,79 +457,46 @@
 "that would identify our instance in the real world (a <emphasis>natural</"
 "emphasis> candidate key):"
 msgstr ""
-"We recommend implementing <literal>equals()</literal> and <literal>hashCode()"
-"</literal> using <emphasis>Business key equality</emphasis>. Business key "
-"equality means that the <literal>equals()</literal> method compares only the "
-"properties that form the business key, a key that would identify our "
-"instance in the real world (a <emphasis>natural</emphasis> candidate key):"
+"Recomendamos implementar <literal>equals()</literal> e <literal>hashCode()</"
+"literal> usando <emphasis>Business key equality</emphasis>. A chave de "
+"negócios significa que o método <literal>equals()</literal> compara somente "
+"a propriedade que formar uma chave de negócios, uma chave que identificaria "
+"nossa instância na realidade (uma chave de candidato <emphasis>natural</"
+"emphasis>): "
 
-#. Tag: programlisting
-#: persistent_classes.xml:224
-#, no-c-format
-msgid ""
-"<![CDATA[public class Cat {\n"
-"\n"
-"    ...\n"
-"    public boolean equals(Object other) {\n"
-"        if (this == other) return true;\n"
-"        if ( !(other instanceof Cat) ) return false;\n"
-"\n"
-"        final Cat cat = (Cat) other;\n"
-"\n"
-"        if ( !cat.getLitterId().equals( getLitterId() ) ) return false;\n"
-"        if ( !cat.getMother().equals( getMother() ) ) return false;\n"
-"\n"
-"        return true;\n"
-"    }\n"
-"\n"
-"    public int hashCode() {\n"
-"        int result;\n"
-"        result = getMother().hashCode();\n"
-"        result = 29 * result + getLitterId();\n"
-"        return result;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:226
 #, 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 "
+"candidate (see <xref linkend=\"transactions-basics-identity\" />). Immutable "
 "or unique properties are usually good candidates for a business key."
 msgstr ""
-"Note that 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."
+"Note que uma chave de negócios não tem que ser tão sólida quanto um "
+"candidato de chave primária de base de dados (veja <xref linkend="
+"\"transactions-basics-identity\"/>). Propriedades imutáveis ou únicas são "
+"bons candidatos para uma chave de negócios. "
 
 #. Tag: title
-#: persistent_classes.xml:236
 #, no-c-format
 msgid "Dynamic models"
-msgstr "Dynamic models"
+msgstr "Modelos dinâmicos"
 
 #. Tag: title
-#: persistent_classes.xml:239
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Nota"
 
-#. Tag: emphasis
-#: persistent_classes.xml:241
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
-"The following features are currently considered experimental and may change "
-"in the near future."
+"<emphasis>The following features are currently considered experimental and "
+"may change in the near future.</emphasis>"
 msgstr ""
-"Note that the following features are currently considered experimental and "
-"may change in the near future."
+"<emphasis>Os recursos seguintes são considerados experimentais no momento e "
+"podem mudar no futuro.</emphasis>"
 
 #. Tag: para
-#: persistent_classes.xml:246
-#, fuzzy, no-c-format
+#, 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 "
@@ -555,131 +504,62 @@
 "and the representation of entities as DOM4J trees. With this approach, you "
 "do not write persistent classes, only mapping files."
 msgstr ""
-"Persistent entities don't necessarily have to be represented as POJO classes "
-"or as JavaBean objects at runtime. Hibernate also supports dynamic models "
-"(using <literal>Map</literal>s of <literal>Map</literal>s at runtime) and "
-"the representation of entities as DOM4J trees. With this approach, you don't "
-"write persistent classes, only mapping files."
+"Entidades persistentes não precisam ser representadas como classes POJO ou "
+"como objetos JavaBeans em tempo de espera. O Hibernate também suporta "
+"modelos dinâmicos (usando <literal>Map</literal>s de <literal>Map</literal>s "
+"em tempo de execução) e a representação de entidades como árvores DOM4J. Com "
+"esta abordagem, você não escreve classes persistes, somente arquivos de "
+"mapeamentos. "
 
 #. Tag: para
-#: persistent_classes.xml:254
 #, 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>SessionFactory</"
 "literal> using the <literal>default_entity_mode</literal> configuration "
-"option (see <xref linkend=\"configuration-optional-properties\"/>)."
+"option (see <xref linkend=\"configuration-optional-properties\" />)."
 msgstr ""
-"By default, Hibernate works in normal POJO mode. You may set a default "
-"entity representation mode for a particular <literal>SessionFactory</"
-"literal> using the <literal>default_entity_mode</literal> configuration "
-"option (see <xref linkend=\"configuration-optional-properties\"/>."
+"Por padrão, o Hibernate funciona em modo POJO normal. Você deve ajustar um "
+"modo de representação de entidade por padrão para uma certa "
+"<literal>SessionFactory</literal> usando a opção de configuração "
+"<literal>default_entity_mode</literal> (veja <xref linkend=\"configuration-"
+"optional-properties\"/>). "
 
 #. Tag: para
-#: persistent_classes.xml:261
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following examples demonstrate the representation using <literal>Map</"
 "literal>s. First, in the mapping file an <literal>entity-name</literal> has "
 "to be declared instead of, or in addition to, a class name:"
 msgstr ""
-"The following examples demonstrates the representation using <literal>Map</"
-"literal>s. First, in the mapping file, an <literal>entity-name</literal> has "
-"to be declared instead of (or in addition to) a class name:"
+"Os seguintes exemplos demonstram a representação usando <literal>Map</"
+"literal>s. Primeiro, no arquivo de mapeamento, um <literal>entity-name</"
+"literal> precisa ser declarado ao invés de (ou além de) um nome de classe:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:267
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class entity-name=\"Customer\">\n"
-"\n"
-"        <id name=\"id\"\n"
-"            type=\"long\"\n"
-"            column=\"ID\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"\n"
-"        <property name=\"name\"\n"
-"            column=\"NAME\"\n"
-"            type=\"string\"/>\n"
-"\n"
-"        <property name=\"address\"\n"
-"            column=\"ADDRESS\"\n"
-"            type=\"string\"/>\n"
-"\n"
-"        <many-to-one name=\"organization\"\n"
-"            column=\"ORGANIZATION_ID\"\n"
-"            class=\"Organization\"/>\n"
-"\n"
-"        <bag name=\"orders\"\n"
-"            inverse=\"true\"\n"
-"            lazy=\"false\"\n"
-"            cascade=\"all\">\n"
-"            <key column=\"CUSTOMER_ID\"/>\n"
-"            <one-to-many class=\"Order\"/>\n"
-"        </bag>\n"
-"\n"
-"    </class>\n"
-"    \n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: persistent_classes.xml:269
-#, 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 ""
-"Note that even though associations are declared using target class names, "
-"the target type of an associations may also be a dynamic entity instead of a "
-"POJO."
+"Note que embora as associações sejam declaradas utilizando nomes de classe, "
+"o tipo alvo de uma associação pode também ser uma entidade dinâmica, ao "
+"invés de um POJO. "
 
 #. Tag: para
-#: persistent_classes.xml:276
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "After setting the default entity mode to <literal>dynamic-map</literal> for "
 "the <literal>SessionFactory</literal>, you can, at runtime, work with "
 "<literal>Map</literal>s of <literal>Map</literal>s:"
 msgstr ""
-"After setting the default entity mode to <literal>dynamic-map</literal> for "
-"the <literal>SessionFactory</literal>, we can at runtime work with "
-"<literal>Map</literal>s of <literal>Map</literal>s:"
+"Após ajustar o modo de entidade padrão para <literal>dynamic-map</literal> "
+"para a <literal>SessionFactory</literal>, você poderá trabalhar com "
+"<literal>Map</literal>s de <literal>Map</literal>s no período de execução: "
 
-#. Tag: programlisting
-#: persistent_classes.xml:282
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session s = openSession();\n"
-"Transaction tx = s.beginTransaction();\n"
-"Session s = openSession();\n"
-"\n"
-"// Create a customer\n"
-"Map david = new HashMap();\n"
-"david.put(\"name\", \"David\");\n"
-"\n"
-"// Create an organization\n"
-"Map foobar = new HashMap();\n"
-"foobar.put(\"name\", \"Foobar Inc.\");\n"
-"\n"
-"// Link both\n"
-"david.put(\"organization\", foobar);\n"
-"\n"
-"// Save both\n"
-"s.save(\"Customer\", david);\n"
-"s.save(\"Organization\", foobar);\n"
-"\n"
-"tx.commit();\n"
-"s.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: persistent_classes.xml:284
-#, 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 "
@@ -687,45 +567,26 @@
 "easily be normalized and sound, allowing to add a proper domain model "
 "implementation on top later on."
 msgstr ""
-"The advantages of a dynamic mapping are quick turnaround time for "
-"prototyping without the need for entity class implementation. However, you "
-"lose compile-time type checking and will very likely deal with many "
-"exceptions at runtime. Thanks to the Hibernate mapping, the database schema "
-"can easily be normalized and sound, allowing to add a proper domain model "
-"implementation on top later on."
+"As vantagens de um mapeamento dinâmico são o tempo de retorno rápido para "
+"realizar o protótipo sem a necessidade de implementar uma classe de "
+"entidade. No entanto, você perde o tipo de tempo de compilação, verificando "
+"e muito provavelmente terá que lidar com muitas exceções de tempo de espera. "
+"Graças ao mapeamento do Hibernate, o esquema do banco de dados pode ser "
+"facilmente normalizado e seguro, permitindo adicionar uma implementação "
+"modelo de domínio apropriado na camada do topo num futuro próximo. "
 
 #. Tag: para
-#: persistent_classes.xml:292
 #, no-c-format
 msgid ""
 "Entity representation modes can also be set on a per <literal>Session</"
 "literal> basis:"
 msgstr ""
-"Entity representation modes can also be set on a per <literal>Session</"
-"literal> basis:"
+"Modos de representação de entidade podem ser também ajustados para base por "
+"<literal>Session</literal>:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:297
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session dynamicSession = pojoSession.getSession(EntityMode.MAP);\n"
-"\n"
-"// Create a customer\n"
-"Map david = new HashMap();\n"
-"david.put(\"name\", \"David\");\n"
-"dynamicSession.save(\"Customer\", david);\n"
-"...\n"
-"dynamicSession.flush();\n"
-"dynamicSession.close()\n"
-"...\n"
-"// Continue on pojoSession\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: persistent_classes.xml:300
-#, fuzzy, no-c-format
-msgid ""
 "Please note that the call to <literal>getSession()</literal> using an "
 "<literal>EntityMode</literal> is on the <literal>Session</literal> API, not "
 "the <literal>SessionFactory</literal>. That way, the new <literal>Session</"
@@ -735,34 +596,31 @@
 "literal>, and also leave the transaction and connection handling to the "
 "primary unit of work."
 msgstr ""
-"Please note that the call to <literal>getSession()</literal> using an "
-"<literal>EntityMode</literal> is on the <literal>Session</literal> API, not "
-"the <literal>SessionFactory</literal>. That way, the new <literal>Session</"
-"literal> shares the underlying JDBC connection, transaction, and other "
-"context information. This means you don't have tocall <literal>flush()</"
-"literal> and <literal>close()</literal> on the secondary <literal>Session</"
-"literal>, and also leave the transaction and connection handling to the "
-"primary unit of work."
+"Por favor, note que a chamada para a <literal>getSession()</literal> usando "
+"um <literal>EntityMode</literal> está na API de <literal>Session</literal> e "
+"não na <literal>SessionFactory</literal>. Dessa forma, a nova "
+"<literal>Session</literal> compartilha a conexão, transação e outra "
+"informação de contexto JDBC adjacente. Isto significa que você não precisará "
+"chamar <literal>flush()</literal> e <literal>close()</literal> na "
+"<literal>Session</literal> secundária, e também deixar a transação e o "
+"manuseio da conexão para a unidade primária do trabalho. "
 
 #. Tag: para
-#: persistent_classes.xml:310
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "More information about the XML representation capabilities can be found in "
-"<xref linkend=\"xml\"/>."
+"<xref linkend=\"xml\" />."
 msgstr ""
-"More information about the XML representation capabilities can be found in "
-"<xref linkend=\"xml\"/>."
+"Você poderá encontrar maiores informações sobre as atividades de "
+"representação XML em <xref linkend=\"xml\" />."
 
 #. Tag: title
-#: persistent_classes.xml:318
 #, no-c-format
 msgid "Tuplizers"
-msgstr "Tuplizers"
+msgstr "Tuplizadores"
 
 #. Tag: para
-#: persistent_classes.xml:320
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.tuple.Tuplizer</literal>, and its sub-interfaces, are "
 "responsible for managing a particular representation of a piece of data "
@@ -774,23 +632,17 @@
 "through its constructor. It also knows how to access the POJO properties "
 "using the defined property accessors."
 msgstr ""
-"<literal>org.hibernate.tuple.Tuplizer</literal>, and its sub-interfaces, are "
-"responsible for managing a particular representation of a piece of data, "
-"given that representation's <literal>org.hibernate.EntityMode</literal>. If "
-"a given piece of data is thought of as a data structure, then a tuplizer is "
-"the thing which 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 correpsonding tuplizer knows how create the POJO "
-"through its constructor and how to access the POJO properties using the "
-"defined property accessors. There are two high-level types of Tuplizers, "
-"represented by the <literal>org.hibernate.tuple.EntityTuplizer</literal> and "
-"<literal>org.hibernate.tuple.ComponentTuplizer</literal> interfaces. "
-"<literal>EntityTuplizer</literal>s are responsible for managing the above "
-"mentioned contracts in regards to entities, while "
-"<literal>ComponentTuplizer</literal>s do the same for components."
+"<literal>org.hibernate.tuple.Tuplizer</literal>, e suas sub-interfaces, são "
+"responsáveis por gerenciar uma certa representação de uma parte de dado, "
+"dada a <literal>org.hibernate.EntityMode</literal> da representação. Se uma "
+"parte de dado é tida como uma estrutura de dado, então o tuplizador se "
+"encarrega de criar tal estrutura de dado e como extrair e injetar valores de "
+"e em tal estrutura de dados. Por exemplo, para um modo POJO, o tuplizador "
+"correspondente sabe como criar um POJO através de seu construtor. Além "
+"disso, ele sabe como acessar propriedades de POJO usando assessores de "
+"propriedades definidas. "
 
 #. Tag: para
-#: persistent_classes.xml:330
 #, no-c-format
 msgid ""
 "There are two high-level types of Tuplizers, represented by the <literal>org."
@@ -800,10 +652,15 @@
 "mentioned contracts in regards to entities, while "
 "<literal>ComponentTuplizer</literal>s do the same for components."
 msgstr ""
+"Existem dois tipos de alto nível de Tuplizadores, representados pelas "
+"interfaces <literal>org.hibernate.tuple.entity.EntityTuplizer</literal> e "
+"<literal>org.hibernate.tuple.component.ComponentTuplizer</literal>. Os "
+"<literal>EntityTuplizer</literal>s são responsáveis pelo gerenciamento dos "
+"contratos mencionados acima em relação às entidades, enquanto os "
+"<literal>ComponentTuplizer</literal>s realizam o mesmo para os componentes."
 
 #. Tag: para
-#: persistent_classes.xml:338
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Users can also plug in their own tuplizers. Perhaps you require that a "
 "<literal>java.util.Map</literal> implementation other than <literal>java."
@@ -814,64 +671,22 @@
 "mapping they are meant to manage. Going back to the example of our customer "
 "entity:"
 msgstr ""
-"Users may also plug in their own tuplizers. Perhaps you require that a "
-"<literal>java.util.Map</literal> implementation other than <literal>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. Tuplizers definitions are attached to the entity or "
-"component mapping they are meant to manage. Going back to the example of our "
-"customer entity:"
+"Os usuários podem também plugar seu próprio tuplizador. Talvez você queira "
+"usar uma implementação <literal>java.util.Map</literal> ao invés de uma "
+"<literal>java.util.HashMap</literal> enquanto estiver no modo de entidade "
+"mapa dinâmico, ou talvez você precise definir uma estratégia de geração de "
+"proxy diferente, ao invés de uma utilizada por padrão. Ambas seriam "
+"alcançadas definindo uma implementação de tuplizador personalizada. As "
+"definições do tuplizador estão anexadas à entidade ou ao mapeamento de "
+"componente que tiverem que gerenciar. Retornando ao exemplo da entidade do "
+"nosso cliente:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:347
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    <class entity-name=\"Customer\">\n"
-"        <!--\n"
-"            Override the dynamic-map entity-mode\n"
-"            tuplizer for the customer entity\n"
-"        -->\n"
-"        <tuplizer entity-mode=\"dynamic-map\"\n"
-"                class=\"CustomMapTuplizerImpl\"/>\n"
-"\n"
-"        <id name=\"id\" type=\"long\" column=\"ID\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"\n"
-"        <!-- other properties -->\n"
-"        ...\n"
-"    </class>\n"
-"</hibernate-mapping>\n"
-"\n"
-"\n"
-"public class CustomMapTuplizerImpl\n"
-"        extends org.hibernate.tuple.entity.DynamicMapEntityTuplizer {\n"
-"    // override the buildInstantiator() method to plug in our custom map...\n"
-"    protected final Instantiator buildInstantiator(\n"
-"            org.hibernate.mapping.PersistentClass mappingInfo) {\n"
-"        return new CustomMapInstantiator( mappingInfo );\n"
-"    }\n"
-"\n"
-"    private static final class CustomMapInstantiator\n"
-"            extends org.hibernate.tuple.DynamicMapInstantitor {\n"
-"        // override the generateMap() method to return our custom map...\n"
-"            protected final Map generateMap() {\n"
-"                    return new CustomMap();\n"
-"            }\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: persistent_classes.xml:354
 #, no-c-format
 msgid "EntityNameResolvers"
-msgstr ""
+msgstr "EntityNameResolvers"
 
 #. Tag: para
-#: persistent_classes.xml:356
 #, no-c-format
 msgid ""
 "The <interfacename>org.hibernate.EntityNameResolver</interfacename> "
@@ -888,158 +703,41 @@
 "dynamicentity.tuplizer2</package>. Here is some of the code from that "
 "package for illustration."
 msgstr ""
+"A interface <interfacename>org.hibernate.EntityNameResolver</interfacename> "
+"é um contrato para resolver o nome da entidade de uma instância de entidade "
+"dada. A interface define um <methodname>resolveEntityName</methodname> de "
+"método único que é passado à instância de entidade e é esperado a retornar "
+"ao nome de entidade apropriado (nulo é permitido e indicaria que o "
+"solucionador não saiba como resolver o nome de entidade da instância de "
+"entidade dada). Normalmente, um <interfacename>org.hibernate."
+"EntityNameResolver</interfacename> será mais útil no caso de modelos "
+"dinâmicos. Um exemplo poderá ser usado nas interfaces com proxie no caso dos "
+"modelos dinâmicos. O hibernate test suite possui um exemplo deste estilo "
+"exato de uso sob o <package>org.hibernate.test.dynamicentity.tuplizer2</"
+"package>. Segue abaixo parte do código a partir daquele pacote para "
+"ilustração."
 
-#. Tag: programlisting
-#: persistent_classes.xml:368
-#, no-c-format
-msgid ""
-"/**\n"
-" * A very trivial JDK Proxy InvocationHandler implementation where we proxy "
-"an interface as\n"
-" * the domain model and simply store persistent state in an internal Map.  "
-"This is an extremely\n"
-" * trivial example meant only for illustration.\n"
-" */\n"
-"public final class DataProxyHandler implements InvocationHandler {\n"
-"        private String entityName;\n"
-"        private HashMap data = new HashMap();\n"
-"\n"
-"        public DataProxyHandler(String entityName, Serializable id) {\n"
-"                this.entityName = entityName;\n"
-"                data.put( \"Id\", id );\n"
-"        }\n"
-"\n"
-"        public Object invoke(Object proxy, Method method, Object[] args) "
-"throws Throwable {\n"
-"                String methodName = method.getName();\n"
-"                if ( methodName.startsWith( \"set\" ) ) {\n"
-"                        String propertyName = methodName.substring( 3 );\n"
-"                        data.put( propertyName, args[0] );\n"
-"                }\n"
-"                else if ( methodName.startsWith( \"get\" ) ) {\n"
-"                        String propertyName = methodName.substring( 3 );\n"
-"                        return data.get( propertyName );\n"
-"                }\n"
-"                else if ( \"toString\".equals( methodName ) ) {\n"
-"                        return entityName + \"#\" + data.get( \"Id\" );\n"
-"                }\n"
-"                else if ( \"hashCode\".equals( methodName ) ) {\n"
-"                        return new Integer( this.hashCode() );\n"
-"                }\n"
-"                return null;\n"
-"        }\n"
-"\n"
-"        public String getEntityName() {\n"
-"                return entityName;\n"
-"        }\n"
-"\n"
-"        public HashMap getData() {\n"
-"                return data;\n"
-"        }\n"
-"}\n"
-"\n"
-"/**\n"
-" *\n"
-" */\n"
-"public class ProxyHelper {\n"
-"    public static String extractEntityName(Object object) {\n"
-"        // Our custom java.lang.reflect.Proxy instances actually bundle\n"
-"        // their appropriate entity name, so we simply extract it from "
-"there\n"
-"        // if this represents one of our proxies; otherwise, we return null\n"
-"        if ( Proxy.isProxyClass( object.getClass() ) ) {\n"
-"            InvocationHandler handler = Proxy.getInvocationHandler"
-"( object );\n"
-"            if ( DataProxyHandler.class.isAssignableFrom( handler.getClass"
-"() ) ) {\n"
-"                DataProxyHandler myHandler = ( DataProxyHandler ) handler;\n"
-"                return myHandler.getEntityName();\n"
-"            }\n"
-"        }\n"
-"        return null;\n"
-"    }\n"
-"\n"
-"    // various other utility methods ....\n"
-"\n"
-"}\n"
-"\n"
-"/**\n"
-" * The EntityNameResolver implementation.\n"
-" * IMPL NOTE : An EntityNameResolver really defines a strategy for how "
-"entity names should be\n"
-" * resolved.  Since this particular impl can handle resolution for all of "
-"our entities we want to\n"
-" * take advantage of the fact that SessionFactoryImpl keeps these in a Set "
-"so that we only ever\n"
-" * have one instance registered.  Why?  Well, when it comes time to resolve "
-"an entity name,\n"
-" * Hibernate must iterate over all the registered resolvers.  So keeping "
-"that number down\n"
-" * helps that process be as speedy as possible.  Hence the equals and "
-"hashCode impls\n"
-" */\n"
-"public class MyEntityNameResolver implements EntityNameResolver {\n"
-"    public static final MyEntityNameResolver INSTANCE = new "
-"MyEntityNameResolver();\n"
-"\n"
-"    public String resolveEntityName(Object entity) {\n"
-"        return ProxyHelper.extractEntityName( entity );\n"
-"    }\n"
-"\n"
-"    public boolean equals(Object obj) {\n"
-"        return getClass().equals( obj.getClass() );\n"
-"    }\n"
-"\n"
-"    public int hashCode() {\n"
-"        return getClass().hashCode();\n"
-"    }\n"
-"}\n"
-"\n"
-"public class MyEntityTuplizer extends PojoEntityTuplizer {\n"
-"        public MyEntityTuplizer(EntityMetamodel entityMetamodel, "
-"PersistentClass mappedEntity) {\n"
-"                super( entityMetamodel, mappedEntity );\n"
-"        }\n"
-"\n"
-"        public EntityNameResolver[] getEntityNameResolvers() {\n"
-"                return new EntityNameResolver[] { MyEntityNameResolver."
-"INSTANCE };\n"
-"        }\n"
-"\n"
-"    public String determineConcreteSubclassEntityName(Object entityInstance, "
-"SessionFactoryImplementor factory) {\n"
-"        String entityName = ProxyHelper.extractEntityName"
-"( entityInstance );\n"
-"        if ( entityName == null ) {\n"
-"            entityName = super.determineConcreteSubclassEntityName"
-"( entityInstance, factory );\n"
-"        }\n"
-"        return entityName;\n"
-"    }\n"
-"\n"
-"    ...\n"
-"}"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:370
 #, no-c-format
 msgid ""
 "In order to register an <interfacename>org.hibernate.EntityNameResolver</"
 "interfacename> users must either:"
 msgstr ""
+"Com o objetivo de registrar um <interfacename>org.hibernate."
+"EntityNameResolver</interfacename>, os usuários devem tanto:"
 
 #. Tag: para
-#: persistent_classes.xml:374
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Implement a custom <link linkend=\"persistent-classes-tuplizers\">Tuplizer</"
 "link>, implementing the <methodname>getEntityNameResolvers</methodname> "
 "method."
 msgstr ""
+"Implementar um <xref linkend=\"persistent-classes-tuplizers\"/> "
+"personalizado, implementando o método <methodname>getEntityNameResolvers</"
+"methodname>. "
 
 #. Tag: para
-#: persistent_classes.xml:380
 #, no-c-format
 msgid ""
 "Register it with the <classname>org.hibernate.impl.SessionFactoryImpl</"
@@ -1047,11 +745,7 @@
 "hibernate.SessionFactory</interfacename>) using the "
 "<methodname>registerEntityNameResolver</methodname> method."
 msgstr ""
-
-#~ msgid "There are four main rules to follow here:"
-#~ msgstr "There are four main rules to follow here:"
-
-#~ msgid ""
-#~ "TODO: Document user-extension framework in the property and proxy packages"
-#~ msgstr ""
-#~ "TODO: Document user-extension framework in the property and proxy packages"
+"Registrá-lo com o <classname>org.hibernate.impl.SessionFactoryImpl</"
+"classname> (que é a classe de implementação para <interfacename>org."
+"hibernate.SessionFactory</interfacename>) usando o método "
+"<methodname>registerEntityNameResolver</methodname>."

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/portability.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/portability.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/portability.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,32 +1,133 @@
-# Language pt-BR translations for PACKAGE package.
-# Automatically generated, 2009.
-#
+# translation of portability.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: portability\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: 2009-07-14 19:56+0000\n"
-"Last-Translator: Automatically generated\n"
-"Language-Team: none\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-19 18:37+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: portability.xml:26
 #, no-c-format
 msgid "Database Portability Considerations"
-msgstr ""
+msgstr "Considerações da Portabilidade do Banco de Dados"
 
 #. Tag: title
-#: portability.xml:29
 #, no-c-format
 msgid "Portability Basics"
-msgstr ""
+msgstr "Fundamentos da Portabilidade"
 
 #. Tag: para
-#: portability.xml:31
 #, no-c-format
 msgid ""
 "One of the selling points of Hibernate (and really Object/Relational Mapping "
@@ -38,15 +139,23 @@
 "run against any number of databases without changes to your code, and "
 "ideally without any changes to the mapping metadata."
 msgstr ""
+"Um dos pontos de venda do Hibernate (e realmente Mapeamento do Objeto/"
+"Relacional como um conjunto) é a noção da portabilidade do banco de dados. "
+"Isto pode significar um usuário de TI interno migrando a partir de um "
+"fornecedor de banco de dados a outro, ou isto pode significar que um "
+"framework ou aplicativo implementável consumindo o Hibernate para produtos "
+"de banco de dados múltiplos de destinação simultaneamente pelos usuários. "
+"Independente do cenário exato, a idéia básica é que você queira que o "
+"Hibernate o ajude a rodar em referência a qualquer número de banco de dados "
+"sem as alterações a seu código e preferencialmente sem quaisquer alterações "
+"ao metadados de mapeamento."
 
 #. Tag: title
-#: portability.xml:42
 #, no-c-format
 msgid "Dialect"
-msgstr ""
+msgstr "Dialeto"
 
 #. Tag: para
-#: portability.xml:44
 #, no-c-format
 msgid ""
 "The first line of portability for Hibernate is the dialect, which is a "
@@ -58,15 +167,21 @@
 "your particular database is not among them, it is not terribly difficult to "
 "write your own."
 msgstr ""
+"A primeira linha de portabilidade para o Hibernate é o dialeto, que trata-se "
+"de uma especialização de um contrato <classname>org.hibernate.dialect."
+"Dialect</classname>. Um dialeto encapsula todas as diferenças em como o "
+"Hibernate deve comunicar-se com um banco de dados particular para completar "
+"algumas tarefas como obter um valor de seqüência ou estruturar uma consulta "
+"SELECT. O Hibernate vincula uma variedade de dialetos para muitos dos bancos "
+"de dados mais populares. Se você achar que seu banco de dados particular não "
+"está seguindo os mesmos, não será difícil escrever o seu próprio."
 
 #. Tag: title
-#: portability.xml:55
 #, no-c-format
 msgid "Dialect resolution"
-msgstr ""
+msgstr "Resolução do Dialeto"
 
 #. Tag: para
-#: portability.xml:57
 #, no-c-format
 msgid ""
 "Originally, Hibernate would always require that users specify which dialect "
@@ -75,9 +190,14 @@
 "their users to configure the Hibernate dialect or defining their own method "
 "of setting that value."
 msgstr ""
+"Originalmente, o Hibernate sempre solicita que os usuários especifiquem qual "
+"dialeto a ser usado. No caso dos usuários buscarem banco de dados múltiplos "
+"de destinação simultaneamente com as próprias construções que eram "
+"problemáticas. Normalmente, isto solicita que seus próprios usuários "
+"configurem o dialeto do Hibernate ou definam o próprio método de "
+"determinação do valor."
 
 #. Tag: para
-#: portability.xml:64
 #, no-c-format
 msgid ""
 "Starting with version 3.2, Hibernate introduced the notion of automatically "
@@ -87,17 +207,22 @@
 "that this resolution was limited to databases Hibernate know about ahead of "
 "time and was in no way configurable or overrideable."
 msgstr ""
+"Inicializando com a versão 3.2, o Hibernate introduziu a noção de detecção "
+"automática do dialeto para uso baseado no <interfacename>java.sql."
+"DatabaseMetaData</interfacename> obtido a partir de um <interfacename>java."
+"sql.Connection</interfacename> para aquele banco de dados. Era muito melhor, "
+"esperar que esta resolução limitada aos bancos de dados Hibernate soubesse "
+"com antecedência e que em ocasião alguma era configurável ou substituível."
 
 #. Tag: para
-#: portability.xml:72
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Starting with version 3.3, Hibernate has a fare more powerful way to "
 "automatically determine which dialect to should be used by relying on a "
 "series of delegates which implement the <interfacename>org.hibernate.dialect."
 "resolver.DialectResolver</interfacename> which defines only a single method:"
-"<programlisting><![CDATA[public Dialect resolveDialect(DatabaseMetaData "
-"metaData) throws JDBCConnectionException]]></programlisting>. The basic "
+"<programlisting role=\"JAVA\">public Dialect resolveDialect(DatabaseMetaData "
+"metaData) throws JDBCConnectionException</programlisting>. The basic "
 "contract here is that if the resolver 'understands' the given database "
 "metadata then it returns the corresponding Dialect; if not it returns null "
 "and the process continues to the next resolver. The signature also "
@@ -108,9 +233,25 @@
 "All other exceptions result in a warning and continuing on to the next "
 "resolver."
 msgstr ""
+"Inicializando com a versão 3.3, o Hibernate possui uma maneira muito mais "
+"potente para determinar automaticamente qual dialeto deve ser usado baseando-"
+"se numa série de delegações que determinam qual implementação deve ser usada "
+"baseando-se numa série de delegações que implementam o <interfacename>org."
+"hibernate.dialect.resolver.DialectResolver</interfacename> que define apenas "
+"um método único: <programlisting><![CDATA[public Dialect resolveDialect"
+"(DatabaseMetaData metaData) throws JDBCConnectionException]]></"
+"programlisting>. Este contrato básico é que se o solucionador 'entender' o "
+"metadados do banco de dados dado, ele retornará o Dialeto correspondente. "
+"Caso contrário, ele retornará nulo e o processo continuará ao próximo "
+"solucionador. A assinatura também identifica o <exceptionname>org.hibernate."
+"exception.JDBCConnectionException</exceptionname> como possivelmente "
+"lançado. Neste caso, o JDBCConnectionException é interpretado para implicar "
+"um problema de conexão (também conhecida com não-recuperável) \"não "
+"transiente\" e é usado para indicar uma parada imediata de tentativas de "
+"resolução. Todas as demais exceções resultam num aviso e dão continuidade ao "
+"próximo solucionador. "
 
 #. Tag: para
-#: portability.xml:85
 #, no-c-format
 msgid ""
 "The cool part about these resolvers is that users can also register their "
@@ -124,16 +265,25 @@
 "<constant>DIALECT_RESOLVERS</constant> constant on <classname>org.hibernate."
 "cfg.Environment</classname>)."
 msgstr ""
+"A melhor parte destes solucionadores é que os usuários também podem "
+"registrar os seus próprios solucionadores personalizados dos quais serão "
+"processados antes dos Hibernates internos. Isto poderá ser útil em um número "
+"diferente de situações: permite uma integração fácil de auto-detecção de "
+"dialetos além daqueles lançados com o próprio Hibernate. Além disto, permite "
+"que você especifique o uso de um dialeto personalizado quando um banco de "
+"dados particular é reconhecido, etc. Para registrar um ou mais "
+"solucionadores, apenas especifique-os (separados por vírgula, tabs ou "
+"espaços) usando o conjunto de configuração 'hibernate."
+"dialect_resolvers' (consulte a constante <constant>DIALECT_RESOLVERS</"
+"constant> no <classname>org.hibernate.cfg.Environment</classname>)."
 
 #. Tag: title
-#: portability.xml:98
 #, no-c-format
 msgid "Identifier generation"
-msgstr ""
+msgstr "Geração do identificador"
 
 #. Tag: para
-#: portability.xml:100
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "When considering portability between databases, another important decision "
 "is selecting the identifier generation stratagy you want to use. Originally "
@@ -151,38 +301,94 @@
 "reference entities within a persistence context it must then issue the "
 "insert immediately when the users requests the entitiy be associated with "
 "the session (like via save() e.g.) regardless of current transactional "
-"semantics. <note> <para> Hibernate was changed slightly once the implication "
-"of this was better understood so that the insert is delayed in cases where "
-"that is feasible. </para> </note> The underlying issue is that the actual "
-"semanctics of the application itself changes in these cases."
+"semantics."
 msgstr ""
+"Quando considerando a portabilidade entre os bancos de dados, outra "
+"importante decisão é selecionar a estratégia de geração do identificador que "
+"você deseja usar. Originalmente, o Hibernate fornecia o gerador "
+"<emphasis>nativo</emphasis> para este propósito, que intencionava selecionar "
+"entre uma estratégia de <emphasis>seqüência</emphasis>, "
+"<emphasis>identidade</emphasis> ou <emphasis>tabela</emphasis> dependendo da "
+"capacidade do banco de dados adjacente. No entanto, uma implicação insidiosa "
+"desta abordagem vêem quando destinando alguns bancos de dados que suportam a "
+"geração de identidade e outros que não suportam. A geração "
+"<emphasis>identidade</emphasis> baseia-se na definição de uma coluna (ou "
+"auto-incremento) IDENTITY para gerenciar o valor identificador. Isto é "
+"conhecido como estratégia de geração pós-inserção devido à inserção ter que "
+"ocorrer antes que nós possamos conhecer o valor identificador. Devido ao "
+"Hibernate depender neste valor identificador para unicamente referenciar "
+"entidades com um contexto persistente, ele deverá imprimir a inserção "
+"imediatamente quando as solicitações dos usuários de entidade estiverem "
+"associados com a sessão (como através save() e.g.) independente das "
+"semânticas de transação atual. O problema adjacente é que as semânticas do "
+"próprio aplicativo alteram nestes casos."
 
 #. Tag: para
-#: portability.xml:125
+#, fuzzy, no-c-format
+msgid ""
+"Hibernate was changed slightly once the implication of this was better "
+"understood so that the insert is delayed in cases where that is feasible."
+msgstr ""
+"O Hibernate foi atualizado para que a inserção seja lenta em casos em que "
+"isto é possível. "
+
+#. Tag: note
 #, no-c-format
 msgid ""
+"The underlying issue is that the actual semanctics of the application itself "
+"changes in these cases."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
 "Starting with version 3.2.3, Hibernate comes with a set of <ulink url="
 "\"http://in.relation.to/2082.lace\">enhanced</ulink> identifier generators "
-"targetting portability in a much different way. <note> <para> There are "
-"specifically 2 bundled <emphasis>enhanced</emphasis>generators: "
-"<itemizedlist> <listitem> <para> <classname>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</classname> </para> </listitem> <listitem> <para> "
-"<classname>org.hibernate.id.enhanced.TableGenerator</classname> </para> </"
-"listitem> </itemizedlist> </para> </note> The idea behind these generators "
-"is to port the actual semantics of the identifer value generation to the "
-"different databases. For example, the <classname>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</classname> mimics the behavior of a sequence on "
-"databases which do not support sequences by using a table."
+"targetting portability in a much different way."
 msgstr ""
+"Starting with version 3.2.3, Hibernate comes with a set of <ulink url="
+"\"http://in.relation.to/2082.lace\">enhanced</ulink> identifier generators "
+"targetting portability in a much different way."
 
+#. Tag: para
+#, no-c-format
+msgid ""
+"There are specifically 2 bundled <emphasis>enhanced</emphasis>generators:"
+msgstr ""
+"There are specifically 2 bundled <emphasis>enhanced</emphasis>generators:"
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname>"
+msgstr ""
+"<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname>"
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<classname>org.hibernate.id.enhanced.TableGenerator</classname>"
+msgstr "<classname>org.hibernate.id.enhanced.TableGenerator</classname>"
+
+#. Tag: note
+#, no-c-format
+msgid ""
+"The idea behind these generators is to port the actual semantics of the "
+"identifer value generation to the different databases. For example, the "
+"<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname> "
+"mimics the behavior of a sequence on databases which do not support "
+"sequences by using a table."
+msgstr ""
+"The idea behind these generators is to port the actual semantics of the "
+"identifer value generation to the different databases. For example, the "
+"<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname> "
+"mimics the behavior of a sequence on databases which do not support "
+"sequences by using a table."
+
 #. Tag: title
-#: portability.xml:154
 #, no-c-format
 msgid "Database functions"
-msgstr ""
+msgstr "Funções do banco de dados"
 
 #. Tag: para
-#: portability.xml:157
 #, no-c-format
 msgid ""
 "This is an area in Hibernate in need of improvement. In terms of portability "
@@ -191,7 +397,6 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:164
 #, no-c-format
 msgid ""
 "SQL functions can be referenced in many ways by users. However, not all "
@@ -200,9 +405,13 @@
 "knows how to render that particular function, perhaps even using a totally "
 "different physical function call."
 msgstr ""
+"SQL functions can be referenced in many ways by users. However, not all "
+"databases support the same set of functions. Hibernate, provides a means of "
+"mapping a <emphasis>logical</emphasis> function name to a a delegate which "
+"knows how to render that particular function, perhaps even using a totally "
+"different physical function call."
 
 #. Tag: para
-#: portability.xml:170
 #, no-c-format
 msgid ""
 "Technically this function registration is handled through the <classname>org."
@@ -211,24 +420,36 @@
 "having to provide a custom dialect. This specific behavior is not fully "
 "completed as of yet."
 msgstr ""
+"Technically this function registration is handled through the <classname>org."
+"hibernate.dialect.function.SQLFunctionRegistry</classname> class which is "
+"intended to allow users to provide custom function definitions without "
+"having to provide a custom dialect. This specific behavior is not fully "
+"completed as of yet."
 
 #. Tag: para
-#: portability.xml:177
 #, no-c-format
 msgid ""
 "It is sort of implemented such that users can programatically register "
 "functions with the <classname>org.hibernate.cfg.Configuration</classname> "
 "and those functions will be recognized for HQL."
 msgstr ""
+"It is sort of implemented such that users can programatically register "
+"functions with the <classname>org.hibernate.cfg.Configuration</classname> "
+"and those functions will be recognized for HQL."
 
 #. Tag: title
-#: portability.xml:187
 #, no-c-format
 msgid "Type mappings"
 msgstr ""
 
 #. Tag: para
-#: portability.xml:189
 #, no-c-format
 msgid "This section scheduled for completion at a later date..."
 msgstr ""
+
+#~ msgid ""
+#~ "This is a new area in Hibernate and as such it is not as mature as the "
+#~ "overall Hibernate experience."
+#~ msgstr ""
+#~ "This is a new area in Hibernate and as such it is not as mature as the "
+#~ "overall Hibernate experience."

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/preface.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/preface.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/preface.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,23 +1,129 @@
+# translation of Preface.po to
+# translation of preface.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Preface\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-19 18:38+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: preface.xml:29
 #, no-c-format
 msgid "Preface"
 msgstr "Prefácio"
 
 #. Tag: para
-#: preface.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "Working with object-oriented software and a relational database can be "
@@ -27,31 +133,29 @@
 "representation from an object model to a relational data model with a SQL-"
 "based schema."
 msgstr ""
-"Trabalhando com software orientado a objetos e banco de dados relacional, "
-"podemos ter alguns incômodos hoje em dia em ambientes empresariais. "
-"Hibernate é uma ferramenta que mapeia o objeto/relacional para o ambiente "
-"Java. O termo de mapeamento de objeto/relacional (ou ORM – Object/Relational "
-"Mapping) se refere a técnica de mapear uma representação de dados de um "
-"modelo de objeto para dados de modelo relacional com o esquema baseado em SQL"
+"O trabalho com o software objeto relacional e banco de dados relacionais, "
+"pode ser incômodo e desgastante atualmente num meio empresarial. Hibernate é "
+"um objeto/relacional de mapeamento de ferramentas nos meios Java. O termo "
+"objeto/relacional de mapeamento ( ORM ) refere-se à técnica de mapeamento de "
+"dados, representada desde o objeto modelo aos dados relacionais modelo com "
+"um esquema baseado na SQL. "
 
 #. Tag: para
-#: preface.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate not only takes care of the mapping from Java classes to database "
 "tables (and from Java data types to SQL data types), but also provides data "
 "query and retrieval facilities. It can also significantly reduce development "
 "time otherwise spent with manual data handling in SQL and JDBC."
 msgstr ""
-"O Hibernate não somente cuida do mapeamento de classes em Java para tabelas "
-"de banco de dados (e de tipos de dados em Java para tipos de dados em SQL), "
-"como também fornece facilidade de consultas e recuperação de dados, podendo "
-"também reduzir significantemente o tempo de desenvolvimento gasto com a "
-"manipulação manual de dados no SQL e JDBC."
+"O Hibernate não cuida apenas do mapeamento desde às classes de Java até as "
+"mesas de banco de dados (e de tipos de dados Java até tipos de dados da "
+"SQL), mas também proporciona a consulta de dados e facildades de recuperação "
+"que pode significativamente reduzir o tempo de desenvolvimento. Do "
+"contrário, consumido com o manual de dados executados em SQL e JDBC. "
 
 #. Tag: para
-#: preface.xml:46
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's goal is to relieve the developer from 95 percent of common data "
 "persistence related programming tasks. Hibernate may not be the best "
@@ -62,52 +166,48 @@
 "specific SQL code and will help with the common task of result set "
 "translation from a tabular representation to a graph of objects."
 msgstr ""
-"O objetivo do Hibernate é de aliviar o desenvolvedor de 95 por cento das "
-"tarefas de programação relacionadas aos dados comuns de persistência. O "
-"Hibernate talvez não seja a melhor solução para aplicações de dados-data-"
-"centric que somente usa stored-procedures para implementar a lógica de "
-"negócio no banco de dados, isto é muito utilizado com o domínio de modelos "
-"orientado a objetos e lógicas de negócio em camadas do meio (middle-tier) "
-"baseadas em Java. Porém, o Hibernate poderá certamente ajuda-lo a remover ou "
-"encapsular o código SQL de um vendedor específico, ajudando também com a "
-"tarefa comum da tradução do resultado ajustado de uma representação para um "
+"A meta de Hibernate é aliviar o desenvolvedor em 95% de dados comuns de "
+"persistência relacionados as tarefas de programação. O Hibernate talvez não "
+"seja a melhor solução para as aplicações centradas em dados, das quais "
+"apenas usam procedimentos armazenados para a implementação das lógicas "
+"comerciais no banco de dados. Isto é mais utilizado orientando o objeto aos "
+"modelos de domínio e lógicas comerciais na camada intermediária baseada em "
+"Java. No entanto, o Hibernate pode certamente ajudá-lo a remover ou "
+"condensar o específico código fornecedor SQL, e ajudará com a tarefa comum "
+"de resultado estabelecido pela tradução desde a representação tabular até um "
 "gráfico de objetos."
 
 #. Tag: para
-#: preface.xml:56
 #, no-c-format
 msgid ""
 "If you are new to Hibernate and Object/Relational Mapping or even Java, "
 "please follow these steps:"
 msgstr ""
-"Se você for novo no Hibernate e no mapeamento Objeto/Relacional, ou até "
-"mesmo em Java, por favor, siga os seguintes passos."
+"Por favor siga  os seguintes passos, caso você seja inexperiente com o "
+"Hibernate, Mapeamento Objeto/Relacional ou mesmo Java:"
 
 #. Tag: para
-#: preface.xml:63
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"Read <xref linkend=\"tutorial\"/> for a tutorial with step-by-step "
+"Read <xref linkend=\"tutorial\" /> for a tutorial with step-by-step "
 "instructions. The source code for the tutorial is included in the "
 "distribution in the <literal>doc/reference/tutorial/</literal> directory."
 msgstr ""
-"Leia <xref linkend=\"tutorial\"/> para um tutorial com instruções passo-a-"
-"passo. O código fonte para do tutorial está incluído na distribuição no "
-"diretório <literal>doc/reference/tutorial/</literal>."
+"Leia <xref linkend=\"tutorial\"/> com passo-a-passo de instruções tutoriais. "
+"O código de origem tutorial está incluído no diretório de distribuição "
+"<literal>doc/reference/tutorial/</literal>. "
 
 #. Tag: para
-#: preface.xml:71
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"Read <xref linkend=\"architecture\"/> to understand the environments where "
+"Read <xref linkend=\"architecture\" /> to understand the environments where "
 "Hibernate can be used."
 msgstr ""
-"Leia o <xref linkend=\"architecture\"/> para entender o ambiente onde o "
-"Hibernate pode ser utilizado."
+"Leia <xref linkend=\"architecture\"/> para melhor entendimento dos meios "
+"onde Hibernate pode ser utilizado.  "
 
 #. Tag: para
-#: preface.xml:77
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "View the <literal>eg/</literal> directory in the Hibernate distribution. It "
 "contains a simple standalone application. Copy your JDBC driver to the "
@@ -116,64 +216,58 @@
 "command prompt in the distribution directory, type <literal>ant eg</literal> "
 "(using Ant), or under Windows, type <literal>build eg</literal>."
 msgstr ""
-"Dê uma olhada no diretório de exemplo <literal>eg/</literal> da distribuição "
-"do Hibernate, ele contém uma simples aplicação standalone. Copie seu driver "
-"JDBC para o diretório <literal>lib/</literal> e edite o arquivo <literal>etc/"
-"hibernate.properties</literal>, especificando corretamente os valores para "
-"seu banco de dados. Usando o prompt de commando no diretorio de "
-"distribuicao, digite <literal>ant eg</literal> (usando Ant), ou no Windows, "
-"digite <literal>build eg</literal>."
+"Verifique no diretório <literal>eg/</literal> em sua distribuição de "
+"Hibernate, do qual possui uma simples aplicação autônoma. Copie seu driver "
+"JDBC para o diretório <literal>lib/</literal> e edite <literal>eg/hibernate."
+"properties</literal>, especificando valores corretos para o seu banco de "
+"dados. No diretório de distribuição sob o comando aviso, digite <literal>ant "
+"eg</literal> (usando Ant), ou sob Windows, digite <literal>build eg</"
+"literal>. "
 
 #. Tag: para
-#: preface.xml:88
 #, fuzzy, no-c-format
 msgid ""
 "Use this reference documentation as your primary source of information. "
 "Consider reading <biblioref linkend=\"biblio-JPwH\"></biblioref> if you need "
 "more help with application design, or if you prefer a step-by-step tutorial. "
-"Also visit <ulink url=\"http://caveatemptor.hibernate.org\"></ulink> and "
-"download the example application from <biblioref linkend=\"biblio-JPwH\"></"
-"biblioref>."
+"Also visit <ulink url=\"http://caveatemptor.hibernate.org\" /> and download "
+"the example application from <biblioref linkend=\"biblio-JPwH\"></biblioref>."
 msgstr ""
-"Use esta documentação de referencia como sua fonte primaria de informação. "
-"Considere ler também o livro <emphasis>Java Persistence with Hibernate</"
-"emphasis> (http://www.manning.com/bauer2) caso você precise de mais ajuda "
-"com o desenvolvimento de aplicações ou caso prefira um tutorial passo-a-"
-"passo. Também visite o site http://caveatemptor.hibernate.org e faça o "
-"download da aplicação de exemplo do Java Persistence with Hibernate."
+"Utilize esta documentação de referência como a sua primeira fonte de "
+"informação. Considere a leitura <emphasis> Persistência Java com Hibernate </"
+"emphasis> (http://www.manning.com/bauer2), caso você precise de auxílio com "
+"a aplicação de design, ou tutorial com passo-a-passo, caso seja desejado. "
+"Você pode também visitar http://caveatemptor.hibernate.org e fazer o "
+"download do exemplo de aplicação da Persistência Java com Hibernate."
 
 #. Tag: para
-#: preface.xml:98
 #, no-c-format
 msgid "FAQs are answered on the Hibernate website."
 msgstr ""
-"FAQs (perguntas feitas com mais freqüência) estão respondidas no site do "
-"Hibernate"
+"As respostas das perguntas mais freqüentes podem ser encontradas no website "
+"Hibernate. "
 
 #. Tag: para
-#: preface.xml:103
 #, fuzzy, no-c-format
 msgid ""
 "Links to third party demos, examples, and tutorials are maintained on the "
 "Hibernate website."
 msgstr ""
-"Demonstrações, exemplos e tutorials estão disponíveis no site do Hibernate."
+"A terceira parte de demonstração, exemplos e tutoriais estão vinculadas no "
+"website Hibernate. "
 
 #. Tag: para
-#: preface.xml:109
 #, no-c-format
 msgid ""
 "The Community Area on the Hibernate website is a good resource for design "
 "patterns and various integration solutions (Tomcat, JBoss AS, Struts, EJB, "
 "etc.)."
 msgstr ""
-"A Área da comunidade no site do Hibernate é uma boa fonte de recursos para "
-"padrões de projeto e várias soluções de integração (Tomcat, JBoss AS, "
-"Struts, EJB, etc.)."
+"A Área de Comunidade no website Hibernate é um bom recurso para parceiros de "
+"design e várias soluções integradas. ( Tomcat, JBoss AS, Struts, EJB, etc. )"
 
 #. Tag: para
-#: preface.xml:117
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you have questions, use the user forum linked on the Hibernate website. "
 "We also provide a JIRA issue tracking system for bug reports and feature "
@@ -181,14 +275,15 @@
 "developer mailing list. If you are interested in translating this "
 "documentation into your language, contact us on the developer mailing list."
 msgstr ""
-"Caso você tenha dúvidas, use o fórum dos usuários encontrado no site do "
-"Hibernate. Nós também fornecemos um sistema para controle de bug’s (JIRA) "
-"para relatórios de erros e requisições de features. Se você está interessado "
-"no desenvolvimento do Hibernate, junte-se a lista de e-mail dos "
-"desenvolvedores."
+"Em caso de dúvidas, utilize o fórum do usuário encontrado no website "
+"Hibernate. Nós também provemos o JIRA sistema de questão de rastreamento "
+"para os relatórios de erros de programação e recursos solicitados. Se você "
+"tem interesse no desenvolvimento do Hibernate, participe da lista de correio "
+"eletrônico do desenvolvedor. Caso você tenha interesse em traduzir este "
+"documento na sua própria língua, por favor entre em contato conosco através "
+"da lista de correio eletrônico do desenvolvedor.  "
 
 #. Tag: para
-#: preface.xml:125
 #, no-c-format
 msgid ""
 "Commercial development support, production support, and training for "
@@ -197,8 +292,8 @@
 "critical component of the JBoss Enterprise Middleware System (JEMS) suite of "
 "products."
 msgstr ""
-"Suporte comercial de desenvolvimento, suporte de produção e treinamento para "
-"o Hibernate está disponível através do JBoss Inc. (veja http://www.hibernate."
-"org/SupportTraining). O Hibernate é um Projeto Profissional de Código Aberto "
-"e um componente crítico da suíte de produtos JBoss Enterprise Middleware "
-"System (JEMS)."
+"O suporte do desenvolvimento comercial, suporte de produção e treinamento de "
+"Hibernate está disponível através do JBoss Inc. ( see http://www.hibernate."
+"org/SupportTraining/ ). Hibernate é um projeto de Fonte Aberta Profissional "
+"e componente crítico do Sistema Jboss de Empreendimento e Middleware "
+"( JEMS ) suíte de produtos. "

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/query_criteria.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/query_criteria.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/query_criteria.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,62 +1,155 @@
+# translation of query_criteria.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: query_criteria\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-19 18:39+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: query_criteria.xml:29
 #, no-c-format
 msgid "Criteria Queries"
 msgstr "Consultas por critérios"
 
 #. Tag: para
-#: query_criteria.xml:31
 #, no-c-format
 msgid "Hibernate features an intuitive, extensible criteria query API."
-msgstr "O Hibernate provê uma intuitiva e extensível API de critério de query."
+msgstr ""
+"O Hibernate provê uma API de consulta por critério intuitiva e extensível."
 
 #. Tag: title
-#: query_criteria.xml:36
 #, no-c-format
 msgid "Creating a <literal>Criteria</literal> instance"
-msgstr "Criando uma instancia <literal>Criteria</literal>"
+msgstr "Criando uma instância <literal>Criteria</literal>"
 
 #. Tag: para
-#: query_criteria.xml:38
 #, no-c-format
 msgid ""
 "The interface <literal>org.hibernate.Criteria</literal> represents a query "
 "against a particular persistent class. The <literal>Session</literal> is a "
 "factory for <literal>Criteria</literal> instances."
 msgstr ""
-"A interface <literal>org.hibernate.Criteria</literal> representa a query ao "
-"invés de uma classe persistente particular. A sessão é uma fábrica para "
-"intancias de <literal>Criteria</literal> ."
+"A interface <literal>org.hibernate.Criteria</literal> representa a consulta "
+"ao invés de uma classe persistente particular. A sessão é uma fábrica para "
+"instâncias de <literal>Criteria</literal> ."
 
-#. Tag: programlisting
-#: query_criteria.xml:44
-#, no-c-format
-msgid ""
-"<![CDATA[Criteria crit = sess.createCriteria(Cat.class);\n"
-"crit.setMaxResults(50);\n"
-"List cats = crit.list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:49
 #, no-c-format
 msgid "Narrowing the result set"
-msgstr "Limitando o result set"
+msgstr "Limitando o conjunto de resultados"
 
 #. Tag: para
-#: query_criteria.xml:51
 #, no-c-format
 msgid ""
 "An individual query criterion is an instance of the interface <literal>org."
@@ -64,458 +157,250 @@
 "criterion.Restrictions</literal> defines factory methods for obtaining "
 "certain built-in <literal>Criterion</literal> types."
 msgstr ""
-"Um critério individual de query é uma instancia da interface <literal>org."
+"Um critério individual de consulta é uma instância da interface <literal>org."
 "hibernate.criterion.Criterion</literal>. A classe <literal>org.hibernate."
 "criterion.Restrictions</literal> define os métodos da fábrica para obter "
-"certos tipos pré fabricados de <literal>Criterion</literal>."
+"certos tipos de <literal>Criterion</literal> pré fabricados."
 
-#. Tag: programlisting
-#: query_criteria.xml:59
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .add( Restrictions.between(\"weight\", minWeight, maxWeight) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Restrictions can be grouped logically."
-msgstr "Restrições podem ser logicamente agrupadas."
+msgstr "Restrições podem ser logicamente agrupadas. "
 
-#. Tag: programlisting
-#: query_criteria.xml:65
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .add( Restrictions.or(\n"
-"        Restrictions.eq( \"age\", new Integer(0) ),\n"
-"        Restrictions.isNull(\"age\")\n"
-"    ) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:67
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.in( \"name\", new String[] { \"Fritz\", \"Izi\", \"Pk"
-"\" } ) )\n"
-"    .add( Restrictions.disjunction()\n"
-"        .add( Restrictions.isNull(\"age\") )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(0) ) )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(1) ) )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(2) ) )\n"
-"    ) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:69
-#, fuzzy, no-c-format
-msgid ""
 "There are a range of built-in criterion types (<literal>Restrictions</"
 "literal> subclasses). One of the most useful allows you to specify SQL "
 "directly."
 msgstr ""
-"Existe um grande número de critérios pré fabricados (subclasses de "
-"<literal>Restrictions</literal>), mas um é especialmente útil pois permite "
-"especificar o SQL diretamente."
+"Existe um grande número de critérios pré-fabricados (subclasses de "
+"<literal>Restrictions</literal>). Um dos mais úteis permite especificar o "
+"SQL diretamente."
 
-#. Tag: programlisting
-#: query_criteria.xml:74
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.sqlRestriction(\"lower({alias}.name) like lower(?)\", "
-"\"Fritz%\", Hibernate.STRING) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:76
 #, no-c-format
 msgid ""
 "The <literal>{alias}</literal> placeholder with be replaced by the row alias "
 "of the queried entity."
 msgstr ""
-"O parametro <literal>{alias}</literal> será substituido pelo alias da "
+"O parâmetro <literal>{alias}</literal> será substituido pelo alias da "
 "entidade procurada."
 
 #. Tag: para
-#: query_criteria.xml:81
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also obtain a criterion from a <literal>Property</literal> instance. "
 "You can create a <literal>Property</literal> by calling <literal>Property."
 "forName()</literal>:"
 msgstr ""
-"Uma maneira alternativa de obter um critério é pegá-lo de uma instancia de "
+"Uma maneira alternativa de obter um critério é apartir de uma instância "
 "<literal>Property</literal>. Você pode criar uma <literal>Property</literal> "
-"chamando <literal>Property.forName()</literal>."
+"chamando <literal>Property.forName()</literal>:"
 
-#. Tag: programlisting
-#: query_criteria.xml:87
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"Property age = Property.forName(\"age\");\n"
-"List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.disjunction()\n"
-"        .add( age.isNull() )\n"
-"        .add( age.eq( new Integer(0) ) )\n"
-"        .add( age.eq( new Integer(1) ) )\n"
-"        .add( age.eq( new Integer(2) ) )\n"
-"    ) )\n"
-"    .add( Property.forName(\"name\").in( new String[] { \"Fritz\", \"Izi\", "
-"\"Pk\" } ) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:92
 #, no-c-format
 msgid "Ordering the results"
-msgstr "Ordering the results"
+msgstr "Ordenando resultados"
 
 #. Tag: para
-#: query_criteria.xml:94
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can order the results using <literal>org.hibernate.criterion.Order</"
 "literal>."
 msgstr ""
-"You may order the results using <literal>org.hibernate.criterion.Order</"
-"literal>."
+"Você poderá ordenar os resultados usando <literal>org.hibernate.criterion."
+"Order</literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:98
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"F%\")\n"
-"    .addOrder( Order.asc(\"name\") )\n"
-"    .addOrder( Order.desc(\"age\") )\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:100
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Property.forName(\"name\").like(\"F%\") )\n"
-"    .addOrder( Property.forName(\"name\").asc() )\n"
-"    .addOrder( Property.forName(\"age\").desc() )\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:105
 #, no-c-format
 msgid "Associations"
-msgstr "Associations"
+msgstr "Associações"
 
 #. Tag: para
-#: query_criteria.xml:107
 #, no-c-format
 msgid ""
 "By navigating associations using <literal>createCriteria()</literal> you can "
 "specify constraints upon related entities:"
 msgstr ""
+"Através da navegação de associações usando <literal>createCriteria()</"
+"literal>, você pode especificar restrições por entidades relacionadas:"
 
-#. Tag: programlisting
-#: query_criteria.xml:112
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"F%\") )\n"
-"    .createCriteria(\"kittens\")\n"
-"        .add( Restrictions.like(\"name\", \"F%\") )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:114
-#, fuzzy, no-c-format
-msgid ""
 "The second <literal>createCriteria()</literal> returns a new instance of "
 "<literal>Criteria</literal> that refers to the elements of the "
 "<literal>kittens</literal> collection."
 msgstr ""
-"note that the second <literal>createCriteria()</literal> returns a new "
-"instance of <literal>Criteria</literal>, which refers to the elements of the "
-"<literal>kittens</literal> collection."
+"Note que o segundo <literal>createCriteria()</literal> retorna uma nova "
+"instância de <literal>Criteria</literal>, que refere aos elementos da "
+"coleção <literal>kittens</literal>."
 
 #. Tag: para
-#: query_criteria.xml:120
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is also an alternate form that is useful in certain circumstances:"
-msgstr "The following, alternate form is useful in certain circumstances."
+msgstr "A seguinte forma alternada é útil em certas circunstâncias:"
 
-#. Tag: programlisting
-#: query_criteria.xml:124
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .createAlias(\"kittens\", \"kt\")\n"
-"    .createAlias(\"mate\", \"mt\")\n"
-"    .add( Restrictions.eqProperty(\"kt.name\", \"mt.name\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:126
 #, no-c-format
 msgid ""
 "(<literal>createAlias()</literal> does not create a new instance of "
 "<literal>Criteria</literal>.)"
 msgstr ""
-"(<literal>createAlias()</literal> does not create a new instance of "
+"(<literal>createAlias()</literal> não cria uma nova instância de "
 "<literal>Criteria</literal>.)"
 
 #. Tag: para
-#: query_criteria.xml:131
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The kittens collections held by the <literal>Cat</literal> instances "
 "returned by the previous two queries are <emphasis>not</emphasis> pre-"
 "filtered by the criteria. If you want to retrieve just the kittens that "
 "match the criteria, you must use a <literal>ResultTransformer</literal>."
 msgstr ""
-"Note that the kittens collections held by the <literal>Cat</literal> "
-"instances returned by the previous two queries are <emphasis>not</emphasis> "
-"pre-filtered by the criteria! If you wish to retrieve just the kittens that "
-"match the criteria, you must use a <literal>ResultTransformer</literal>."
+"Note que as coleções de kittens mantidas pelas instâncias <literal>Cat</"
+"literal>, retornadas pelas duas consultas anteriores <emphasis>não</"
+"emphasis> são pré-filtradas pelo critério. Se você desejar recuperar somente "
+"os kittens que se encaixarem ao critérios, você deverá usar um  "
+"<literal>ResultTransformer</literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:138
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .createCriteria(\"kittens\", \"kt\")\n"
-"        .add( Restrictions.eq(\"name\", \"F%\") )\n"
-"    .setResultTransformer(Criteria.ALIAS_TO_ENTITY_MAP)\n"
-"    .list();\n"
-"Iterator iter = cats.iterator();\n"
-"while ( iter.hasNext() ) {\n"
-"    Map map = (Map) iter.next();\n"
-"    Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);\n"
-"    Cat kitten = (Cat) map.get(\"kt\");\n"
-"}]]>"
+msgid "Additionally you may manipulate the result set using a left outer join:"
 msgstr ""
 
-#. Tag: title
-#: query_criteria.xml:143
+#. Tag: para
 #, no-c-format
-msgid "Dynamic association fetching"
-msgstr "Dynamic association fetching"
+msgid ""
+"This will return all of the <literal>Cat</literal>s with a mate whose name "
+"starts with \"good\" ordered by their mate's age, and all cats who do not "
+"have a mate. This is useful when there is a need to order or limit in the "
+"database prior to returning complex/large result sets, and removes many "
+"instances where multiple queries would have to be performed and the results "
+"unioned by java in memory."
+msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"You can specify association fetching semantics at runtime using "
-"<literal>setFetchMode()</literal>."
+"Without this feature, first all of the cats without a mate would need to be "
+"loaded in one query."
 msgstr ""
-"You may specify association fetching semantics at runtime using "
-"<literal>setFetchMode()</literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:150
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .setFetchMode(\"mate\", FetchMode.EAGER)\n"
-"    .setFetchMode(\"kittens\", FetchMode.EAGER)\n"
-"    .list();]]>"
+"A second query would need to retreive the cats with mates who's name started "
+"with \"good\" sorted by the mates age."
 msgstr ""
 
 #. Tag: para
-#: query_criteria.xml:152
 #, no-c-format
+msgid "Thirdly, in memory; the lists would need to be joined manually."
+msgstr ""
+
+#. Tag: title
+#, no-c-format
+msgid "Dynamic association fetching"
+msgstr "Busca de associação dinâmica"
+
+#. Tag: para
+#, no-c-format
 msgid ""
-"This query will fetch both <literal>mate</literal> and <literal>kittens</"
-"literal> by outer join. See <xref linkend=\"performance-fetching\"/> for "
-"more information."
+"You can specify association fetching semantics at runtime using "
+"<literal>setFetchMode()</literal>."
 msgstr ""
+"Você deve especificar as semânticas de busca de associação em tempo de "
+"execução usando <literal>setFetchMode()</literal>. "
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
 "This query will fetch both <literal>mate</literal> and <literal>kittens</"
-"literal> by outer join. See <xref linkend=\"performance-fetching\"/> for "
+"literal> by outer join. See <xref linkend=\"performance-fetching\" /> for "
 "more information."
+msgstr ""
+"Esta consulta fará a busca tanto de <literal>mate</literal> quanto de "
+"<literal>kittens</literal> por uma união externa. Para maiores informações, "
+"veja <xref linkend=\"performance-fetching\"/>. "
 
 #. Tag: title
-#: query_criteria.xml:160
 #, no-c-format
 msgid "Example queries"
-msgstr "Example queries"
+msgstr "Exemplos de consultas"
 
 #. Tag: para
-#: query_criteria.xml:162
 #, no-c-format
 msgid ""
 "The class <literal>org.hibernate.criterion.Example</literal> allows you to "
 "construct a query criterion from a given instance."
 msgstr ""
-"The class <literal>org.hibernate.criterion.Example</literal> allows you to "
-"construct a query criterion from a given instance."
+"A classe <literal>org.hibernate.criterion.Example</literal> permite que você "
+"construa um critério de consulta a partir de uma dada instância."
 
-#. Tag: programlisting
-#: query_criteria.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = new Cat();\n"
-"cat.setSex('F');\n"
-"cat.setColor(Color.BLACK);\n"
-"List results = session.createCriteria(Cat.class)\n"
-"    .add( Example.create(cat) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:169
 #, no-c-format
 msgid ""
 "Version properties, identifiers and associations are ignored. By default, "
 "null valued properties are excluded."
 msgstr ""
-"Version properties, identifiers and associations are ignored. By default, "
-"null valued properties are excluded."
+"Propriedades de versão, identificadores e associações são ignoradas. Por "
+"padrão, as propriedades de valor null são excluídas."
 
 #. Tag: para
-#: query_criteria.xml:174
 #, no-c-format
 msgid "You can adjust how the <literal>Example</literal> is applied."
-msgstr "You can adjust how the <literal>Example</literal> is applied."
+msgstr "Você pode ajustar como o  <literal>Exemplo</literal> é aplicado."
 
-#. Tag: programlisting
-#: query_criteria.xml:178
-#, no-c-format
-msgid ""
-"<![CDATA[Example example = Example.create(cat)\n"
-"    .excludeZeroes()           //exclude zero valued properties\n"
-"    .excludeProperty(\"color\")  //exclude the property named \"color\"\n"
-"    .ignoreCase()              //perform case insensitive string "
-"comparisons\n"
-"    .enableLike();             //use like for string comparisons\n"
-"List results = session.createCriteria(Cat.class)\n"
-"    .add(example)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:180
 #, no-c-format
 msgid "You can even use examples to place criteria upon associated objects."
-msgstr "You can even use examples to place criteria upon associated objects."
-
-#. Tag: programlisting
-#: query_criteria.xml:184
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .add( Example.create(cat) )\n"
-"    .createCriteria(\"mate\")\n"
-"        .add( Example.create( cat.getMate() ) )\n"
-"    .list();]]>"
 msgstr ""
+"Você pode até usar os exemplos para colocar os critérios em objetos "
+"associados."
 
 #. Tag: title
-#: query_criteria.xml:189
 #, no-c-format
 msgid "Projections, aggregation and grouping"
-msgstr "Projections, aggregation and grouping"
+msgstr "Projeções, agregações e agrupamento."
 
 #. Tag: para
-#: query_criteria.xml:190
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The class <literal>org.hibernate.criterion.Projections</literal> is a "
 "factory for <literal>Projection</literal> instances. You can apply a "
 "projection to a query by calling <literal>setProjection()</literal>."
 msgstr ""
-"The class <literal>org.hibernate.criterion.Projections</literal> is a "
-"factory for <literal>Projection</literal> instances. We apply a projection "
-"to a query by calling <literal>setProjection()</literal>."
+"A classe <literal>org.hibernate.criterion.Projections</literal> é uma "
+"fábrica para instâncias de <literal>Projection</literal>. Você pode aplicar "
+"uma projeção à uma consulta, chamando o <literal>setProjection()</literal>."
 
-#. Tag: programlisting
-#: query_criteria.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.rowCount() )\n"
-"    .add( Restrictions.eq(\"color\", Color.BLACK) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:198
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount() )\n"
-"        .add( Projections.avg(\"weight\") )\n"
-"        .add( Projections.max(\"weight\") )\n"
-"        .add( Projections.groupProperty(\"color\") )\n"
-"    )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:200
 #, no-c-format
 msgid ""
 "There is no explicit \"group by\" necessary in a criteria query. Certain "
 "projection types are defined to be <emphasis>grouping projections</"
 "emphasis>, which also appear in the SQL <literal>group by</literal> clause."
 msgstr ""
-"There is no explicit \"group by\" necessary in a criteria query. Certain "
-"projection types are defined to be <emphasis>grouping projections</"
-"emphasis>, which also appear in the SQL <literal>group by</literal> clause."
+"Não há necessidade de um \"agrupamento por\" explícito em uma consulta por "
+"critério. Certos tipos de projeção são definidos para serem "
+"<emphasis>projeções de agrupamento</emphasis>, que também aparecem em uma "
+"cláusula <literal>agrupamento por</literal>SQL."
 
 #. Tag: para
-#: query_criteria.xml:206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An alias can be assigned to a projection so that the projected value can be "
 "referred to in restrictions or orderings. Here are two different ways to do "
 "this:"
 msgstr ""
-"An alias may optionally be assigned to a projection, so that the projected "
-"value may be referred to in restrictions or orderings. Here are two "
-"different ways to do this:"
+"Um alias pode ser atribuído de forma opcional à uma projeção, assim o valor "
+"projetado pode ser referenciado em restrições ou ordenações. Aqui seguem "
+"duas formas diferentes para fazer isto:  "
 
-#. Tag: programlisting
-#: query_criteria.xml:212
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.alias( Projections.groupProperty(\"color\"), "
-"\"colr\" ) )\n"
-"    .addOrder( Order.asc(\"colr\") )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:214
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.groupProperty(\"color\").as(\"colr\") )\n"
-"    .addOrder( Order.asc(\"colr\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:216
 #, no-c-format
 msgid ""
 "The <literal>alias()</literal> and <literal>as()</literal> methods simply "
@@ -523,173 +408,60 @@
 "<literal>Projection</literal>. As a shortcut, you can assign an alias when "
 "you add the projection to a projection list:"
 msgstr ""
-"The <literal>alias()</literal> and <literal>as()</literal> methods simply "
-"wrap a projection instance in another, aliased, instance of "
-"<literal>Projection</literal>. As a shortcut, you can assign an alias when "
-"you add the projection to a projection list:"
+"Os métodos <literal>alias()</literal> e <literal>as()</literal> simplesmente "
+"envolvem uma instância de projeção à outra instância de <literal>Projeção</"
+"literal> em alias. Como um atalho, você poderá atribuir um alias quando "
+"adicionar a projeção à uma lista de projeção:"
 
-#. Tag: programlisting
-#: query_criteria.xml:223
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount(), \"catCountByColor\" )\n"
-"        .add( Projections.avg(\"weight\"), \"avgWeight\" )\n"
-"        .add( Projections.max(\"weight\"), \"maxWeight\" )\n"
-"        .add( Projections.groupProperty(\"color\"), \"color\" )\n"
-"    )\n"
-"    .addOrder( Order.desc(\"catCountByColor\") )\n"
-"    .addOrder( Order.desc(\"avgWeight\") )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:225
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Domestic.class, \"cat\")\n"
-"    .createAlias(\"kittens\", \"kit\")\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.property(\"cat.name\"), \"catName\" )\n"
-"        .add( Projections.property(\"kit.name\"), \"kitName\" )\n"
-"    )\n"
-"    .addOrder( Order.asc(\"catName\") )\n"
-"    .addOrder( Order.asc(\"kitName\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:227
 #, no-c-format
 msgid ""
 "You can also use <literal>Property.forName()</literal> to express "
 "projections:"
 msgstr ""
-"You can also use <literal>Property.forName()</literal> to express "
-"projections:"
+"Você também pode usar um <literal>Property.forName()</literal> para "
+"expressar projeções:"
 
-#. Tag: programlisting
-#: query_criteria.xml:231
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Property.forName(\"name\") )\n"
-"    .add( Property.forName(\"color\").eq(Color.BLACK) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:233
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount().as(\"catCountByColor\") )\n"
-"        .add( Property.forName(\"weight\").avg().as(\"avgWeight\") )\n"
-"        .add( Property.forName(\"weight\").max().as(\"maxWeight\") )\n"
-"        .add( Property.forName(\"color\").group().as(\"color\" )\n"
-"    )\n"
-"    .addOrder( Order.desc(\"catCountByColor\") )\n"
-"    .addOrder( Order.desc(\"avgWeight\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:238
 #, no-c-format
 msgid "Detached queries and subqueries"
-msgstr "Detached queries and subqueries"
+msgstr "Consultas e subconsultas desanexadas."
 
 #. Tag: para
-#: query_criteria.xml:239
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>DetachedCriteria</literal> class allows you to create a query "
 "outside the scope of a session and then execute it using an arbitrary "
 "<literal>Session</literal>."
 msgstr ""
-"The <literal>DetachedCriteria</literal> class lets you create a query "
-"outside the scope of a session, and then later execute it using some "
-"arbitrary <literal>Session</literal>."
+"A classe <literal>DetachedCriteria</literal> deixa você criar uma consulta "
+"fora do escopo de uma sessão, e depois executá-la usando alguma "
+"<literal>Session</literal> arbitrária. "
 
-#. Tag: programlisting
-#: query_criteria.xml:244
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DetachedCriteria query = DetachedCriteria.forClass(Cat.class)\n"
-"    .add( Property.forName(\"sex\").eq('F') );\n"
-"    \n"
-"Session session = ....;\n"
-"Transaction txn = session.beginTransaction();\n"
-"List results = query.getExecutableCriteria(session).setMaxResults(100).list"
-"();\n"
-"txn.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:246
-#, fuzzy, no-c-format
-msgid ""
 "A <literal>DetachedCriteria</literal> can also be used to express a "
 "subquery. Criterion instances involving subqueries can be obtained via "
 "<literal>Subqueries</literal> or <literal>Property</literal>."
 msgstr ""
-"A <literal>DetachedCriteria</literal> may also be used to express a "
-"subquery. Criterion instances involving subqueries may be obtained via "
-"<literal>Subqueries</literal> or <literal>Property</literal>."
+"Um <literal>DetachedCriteria</literal> também pode ser usado para expressar "
+"uma subconsulta. As instâncias de critérios, que envolvem subconsultas, "
+"podem ser obtidas através das <literal>Subqueries</literal> ou "
+"<literal>Property</literal>. "
 
-#. Tag: programlisting
-#: query_criteria.xml:252
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria avgWeight = DetachedCriteria.forClass(Cat.class)\n"
-"    .setProjection( Property.forName(\"weight\").avg() );\n"
-"session.createCriteria(Cat.class)\n"
-"    .add( Property.forName(\"weight\").gt(avgWeight) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:254
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria weights = DetachedCriteria.forClass(Cat.class)\n"
-"    .setProjection( Property.forName(\"weight\") );\n"
-"session.createCriteria(Cat.class)\n"
-"    .add( Subqueries.geAll(\"weight\", weights) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:256
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Correlated subqueries are also possible:"
-msgstr "Even correlated subqueries are possible:"
+msgstr "Até mesmo as subconsultas correlacionadas são possíveis: "
 
-#. Tag: programlisting
-#: query_criteria.xml:260
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria avgWeightForSex = DetachedCriteria.forClass(Cat."
-"class, \"cat2\")\n"
-"    .setProjection( Property.forName(\"weight\").avg() )\n"
-"    .add( Property.forName(\"cat2.sex\").eqProperty(\"cat.sex\") );\n"
-"session.createCriteria(Cat.class, \"cat\")\n"
-"    .add( Property.forName(\"weight\").gt(avgWeightForSex) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:269
 #, no-c-format
 msgid "Queries by natural identifier"
-msgstr "Queries by natural identifier"
+msgstr "Consultas por um identificador natural"
 
 #. Tag: para
-#: query_criteria.xml:271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For most queries, including criteria queries, the query cache is not "
 "efficient because query cache invalidation occurs too frequently. However, "
@@ -698,79 +470,40 @@
 "applications, this kind of query occurs frequently. The criteria API "
 "provides special provision for this use case."
 msgstr ""
-"For most queries, including criteria queries, the query cache is not very "
-"efficient, because query cache invalidation occurs too frequently. However, "
-"there is one special kind of query where we can optimize the cache "
-"invalidation algorithm: lookups by a constant natural key. In some "
-"applications, this kind of query occurs frequently. The criteria API "
-"provides special provision for this use case."
+"Para a maioria das consultas, incluindo consultas de critérios, o cache de "
+"consulta não é muito eficiente, pois a invalidação do cache de consulta "
+"ocorre com muita frequência. No entanto, não há um tipo de consulta especial "
+"onde possamos otimizar um algoritmo de invalidação de cache: consultas "
+"realizadas por chaves naturais constantes. Em algumas aplicações, este tipo "
+"de consulta ocorre com freqüência. O API de critério provê provisão especial "
+"para este caso de uso.  "
 
 #. Tag: para
-#: query_criteria.xml:279
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, map the natural key of your entity using <literal>&lt;natural-id&gt;</"
 "literal> and enable use of the second-level cache."
 msgstr ""
-"First, you should map the natural key of your entity using <literal>&lt;"
-"natural-id&gt;</literal>, and enable use of the second-level cache."
+"Primeiro, você deve mapear a chave natural de sua entidade usando um "
+"<literal>&lt;natural-id&gt;</literal> e habilitar o uso de um cache de "
+"segundo nível."
 
-#. Tag: programlisting
-#: query_criteria.xml:284
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"User\">\n"
-"    <cache usage=\"read-write\"/>\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <natural-id>\n"
-"        <property name=\"name\"/>\n"
-"        <property name=\"org\"/>\n"
-"    </natural-id>\n"
-"    <property name=\"password\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:286
-#, fuzzy, no-c-format
-msgid ""
 "This functionality is not intended for use with entities with "
 "<emphasis>mutable</emphasis> natural keys."
 msgstr ""
-"Note that this functionality is not intended for use with entities with "
-"<emphasis>mutable</emphasis> natural keys."
+"Note que esta funcionalidade não é proposta para o uso com entidades com "
+"chaves naturais <emphasis>mutáveis</emphasis>. "
 
 #. Tag: para
-#: query_criteria.xml:291
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Once you have enabled the Hibernate query cache, the <literal>Restrictions."
 "naturalId()</literal> allows you to make use of the more efficient cache "
 "algorithm."
 msgstr ""
-"Now, <literal>Restrictions.naturalId()</literal> allows us to make use of "
-"the more efficient cache algorithm."
-
-#. Tag: programlisting
-#: query_criteria.xml:297
-#, no-c-format
-msgid ""
-"<![CDATA[session.createCriteria(User.class)\n"
-"    .add( Restrictions.naturalId()\n"
-"        .set(\"name\", \"gavin\")\n"
-"        .set(\"org\", \"hb\") \n"
-"    ).setCacheable(true)\n"
-"    .uniqueResult();]]>"
-msgstr ""
-
-#~ msgid ""
-#~ "You may easily specify constraints upon related entities by navigating "
-#~ "associations using <literal>createCriteria()</literal>."
-#~ msgstr ""
-#~ "You may easily specify constraints upon related entities by navigating "
-#~ "associations using <literal>createCriteria()</literal>."
-
-#~ msgid "Next, enable the Hibernate query cache."
-#~ msgstr "Next, enable the Hibernate query cache."
+"Uma vez que você tenha ativado o cache de consulta Hibernate, o "
+"<literal>Restrictions.naturalId()</literal> nos permite que utilizemos um "
+"algoritmo de cache mais eficiente."

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/query_hql.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/query_hql.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/query_hql.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,43 +1,146 @@
+# translation of query_hql.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: query_hql\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-19 18:42+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: query_hql.xml:29
 #, no-c-format
 msgid "HQL: The Hibernate Query Language"
-msgstr "HQL: A linguagem de Queries do Hibernate"
+msgstr "HQL: A Linguagem de Consultas do Hibernate"
 
 #. Tag: para
-#: query_hql.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate uses a powerful query language (HQL) that is similar in appearance "
 "to SQL. Compared with SQL, however, HQL is fully object-oriented and "
 "understands notions like inheritance, polymorphism and association."
 msgstr ""
-"O Hibernate vem com uma poderosa linguagem que é (intencionalmente) muito "
-"parecida com o SQL. Mas não seja enganado pela sintaxe; a HQL é totalmente "
-"orientada à objetos, requer conhecimentos de herança, polimorfismo e "
+"O Hibernate vem com uma poderosa linguagem de consulta (HQL) que é muito "
+"parecida com o SQL. No entanto, comparado com o SQL o HQL é totalmente "
+"orientado à objetos, e compreende noções de herança, polimorfismo e "
 "associações."
 
 #. Tag: title
-#: query_hql.xml:38
 #, no-c-format
 msgid "Case Sensitivity"
-msgstr "Case Sensitíve"
+msgstr "Diferenciação de maiúscula e minúscula"
 
 #. Tag: para
-#: query_hql.xml:40
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "With the exception of names of Java classes and properties, queries are case-"
 "insensitive. So <literal>SeLeCT</literal> is the same as <literal>sELEct</"
@@ -45,266 +148,164 @@
 "hibernate.eg.FOO</literal> is not <literal>org.hibernate.eg.Foo</literal>, "
 "and <literal>foo.barSet</literal> is not <literal>foo.BARSET</literal>."
 msgstr ""
-"As Queries não são case-sensitive, exceto pelo nomes das classes e "
-"propriedades Java. <literal>sELEct</literal> e o mesmo que <literal>SELECT</"
-"literal> mas <literal>org.hibernate.eg.FOO</literal> não é <literal>org."
-"hibernate.eg.Foo</literal> e <literal>foo.barSet</literal> não é "
-"<literal>foo.BARSET</literal>."
+"As Consultas não diferenciam maiúscula de minúscula, exceto pelo nomes das "
+"classes e propriedades Java. Portanto, <literal>SeLeCT</literal> é o mesmo "
+"que <literal>sELEct</literal> que é o mesmo que <literal>SELECT</literal>, "
+"mas <literal>org.hibernate.eg.FOO</literal> não é <literal>org.hibernate.eg."
+"Foo</literal> e <literal>foo.barSet</literal> não é <literal>foo.BARSET</"
+"literal>."
 
 #. Tag: para
-#: query_hql.xml:51
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This manual uses lowercase HQL keywords. Some users find queries with "
 "uppercase keywords more readable, but this convention is unsuitable for "
 "queries embedded in Java code."
 msgstr ""
 "Esse manual usa as palavras chave HQL em letras minúsculas. Alguns usuários "
-"acham que com letras maiúsculas as queries ficam mais legíveis, mas nós "
-"achamos essa convenção feia dentro do código Java."
+"acreditam que com letras maiúsculas as consultas ficam mais legíveis, mas "
+"nós acreditamos que este formato não é apropriado para o código Java. "
 
 #. Tag: title
-#: query_hql.xml:59
 #, no-c-format
 msgid "The from clause"
-msgstr "A clausula from"
+msgstr "A cláusula from"
 
 #. Tag: para
-#: query_hql.xml:61
 #, no-c-format
 msgid "The simplest possible Hibernate query is of the form:"
-msgstr "A mais simples query possível do Hibernate é a assim:"
+msgstr "A consulta mais simples possível do Hibernate é a seguinte:"
 
-#. Tag: programlisting
-#: query_hql.xml:65
-#, no-c-format
-msgid "<![CDATA[from eg.Cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:67
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This returns all instances of the class <literal>eg.Cat</literal>. You do "
 "not usually need to qualify the class name, since <literal>auto-import</"
 "literal> is the default. For example:"
 msgstr ""
-"Ela irá retornar todas as instancias da classe <literal>eg.Cat</literal>. "
-"Necessariamente não precisamos qualificar o nome da classe, pois é realizado "
-"<literal>auto-import</literal> por padrão. Por isso na maior parte do tempos "
-"nós simplesmente escrevemos:"
+"Isto simplesmente retornará todas as instâncias da classe <literal>eg.Cat</"
+"literal>. Geralmente não precisamos qualificar o nome da classe, uma vez que "
+"o <literal>auto-import</literal> é o padrão. Por exemplo:"
 
-#. Tag: programlisting
-#: query_hql.xml:73
-#, no-c-format
-msgid "<![CDATA[from Cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:75
 #, no-c-format
 msgid ""
 "In order to refer to the <literal>Cat</literal> in other parts of the query, "
 "you will need to assign an <emphasis>alias</emphasis>. For example:"
 msgstr ""
+"Com o objetivo de referir-se ao <literal>Cat</literal> em outras partes da "
+"consulta, você precisará determinar um <emphasis>alias</emphasis>. Por "
+"exemplo:"
 
-#. Tag: programlisting
-#: query_hql.xml:81 query_hql.xml:396
-#, no-c-format
-msgid "<![CDATA[from Cat as cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:83
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This query assigns the alias <literal>cat</literal> to <literal>Cat</"
 "literal> instances, so you can use that alias later in the query. The "
 "<literal>as</literal> keyword is optional. You could also write:"
 msgstr ""
-"Essa query atribui um alias a <literal>cat</literal> para as instancias de "
-"<literal>Cat</literal>, então nós podemos usar esse alias depois na query. A "
-"palavra chave as é opcional; poderíamos escrever assim:"
+"Essa consulta atribui um alias a <literal>cat</literal> para as instâncias "
+"de <literal>Cat</literal>, portanto poderemos usar esse alias mais tarde na "
+"consulta. A palavra chave <literal>as</literal> é opcional. Você também pode "
+"escrever assim:"
 
-#. Tag: programlisting
-#: query_hql.xml:89
-#, no-c-format
-msgid "<![CDATA[from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:91
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Multiple classes can appear, resulting in a cartesian product or \"cross\" "
 "join."
 msgstr ""
-"Múltiplas classes pode ser envolvidas, resultando em um produto cartesiano "
-"ou \"cross\" join."
+"Classes múltiplas podem ser envolvidas, resultando em um produto cartesiano "
+"ou união \"cruzada\". "
 
-#. Tag: programlisting
-#: query_hql.xml:95
-#, no-c-format
-msgid "<![CDATA[from Formula, Parameter]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:96
-#, no-c-format
-msgid "<![CDATA[from Formula as form, Parameter as param]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:98
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is good practice to name query aliases using an initial lowercase as this "
 "is consistent with Java naming standards for local variables (e.g. "
 "<literal>domesticCat</literal>)."
 msgstr ""
-"É considerada uma boa prática os nomes dos aliases começarem com letra "
-"minúscula, aderente com os padrões Java para variáveis locais (ex: "
-"<literal>domesticCat</literal>)."
+"É considerada uma boa prática nomear alias de consulta, utilizando uma letra "
+"minúscula inicial, consistente com os padrões de nomeação Java para "
+"variáveis locais (ex.: <literal>domesticCat</literal>). "
 
 #. Tag: title
-#: query_hql.xml:107
 #, no-c-format
 msgid "Associations and joins"
-msgstr "Associações e joins"
+msgstr "Associações e uniões"
 
 #. Tag: para
-#: query_hql.xml:109
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also assign aliases to associated entities or to elements of a "
 "collection of values using a <literal>join</literal>. For example:"
 msgstr ""
-"Nós também podemos querer atribuir aliases em uma entidade associada, ou "
-"mesmo em elementos de uma coleção de valores, usando um <literal>join</"
-"literal>."
+"Podemos também atribuir aliases em uma entidade associada, ou mesmo em "
+"elementos de uma coleção de valores, usando uma <literal>join</literal>. Por "
+"exemplo:"
 
-#. Tag: programlisting
-#: query_hql.xml:114
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join cat.mate as mate\n"
-"    left outer join cat.kittens as kitten]]>"
-msgstr ""
+msgid "The supported join types are borrowed from ANSI SQL:"
+msgstr "Os tipos de uniões suportados foram inspirados no ANSI SQL:"
 
-#. Tag: programlisting
-#: query_hql.xml:116
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from Cat as cat left join cat.mate.kittens as kittens]]>"
-msgstr ""
+msgid "<literal>inner join</literal>"
+msgstr "<literal>inner join</literal>"
 
-#. Tag: programlisting
-#: query_hql.xml:118
-#, no-c-format
-msgid "<![CDATA[from Formula form full join form.parameter param]]>"
-msgstr ""
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>left outer join</literal>"
+msgstr "<literal>inner join</literal>"
 
 #. Tag: para
-#: query_hql.xml:120
 #, fuzzy, no-c-format
-msgid "The supported join types are borrowed from ANSI SQL:"
-msgstr "Os tipos de joins suportados foram inspirados no SQL ANSI:"
+msgid "<literal>right outer join</literal>"
+msgstr "<literal>inner join</literal>"
 
-#. Tag: literal
-#: query_hql.xml:127
-#, no-c-format
-msgid "inner join"
-msgstr "inner join"
-
-#. Tag: literal
-#: query_hql.xml:132
-#, no-c-format
-msgid "left outer join"
-msgstr "left outer join"
-
-#. Tag: literal
-#: query_hql.xml:137
-#, no-c-format
-msgid "right outer join"
-msgstr "right outer join"
-
 #. Tag: para
-#: query_hql.xml:141
 #, no-c-format
 msgid "<literal>full join</literal> (not usually useful)"
-msgstr "<literal>full join</literal> (geralmente não é útil)"
+msgstr "<literal>união completa</literal> (geralmente não é útil)"
 
 #. Tag: para
-#: query_hql.xml:147
 #, no-c-format
 msgid ""
 "The <literal>inner join</literal>, <literal>left outer join</literal> and "
 "<literal>right outer join</literal> constructs may be abbreviated."
 msgstr ""
-"The <literal>inner join</literal>, <literal>left outer join</literal> and "
-"<literal>right outer join</literal> constructs may be abbreviated. As "
-"construções <literal>inner join</literal>, <literal>left outer join</"
-"literal> e <literal>right outer join</literal> podem ser abreviadas."
+"As construções <literal>inteiro</literal>, <literal>união esquerda externa</"
+"literal> e <literal>união direita externa</literal> podem ser abreviadas."
 
-#. Tag: programlisting
-#: query_hql.xml:152
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    join cat.mate as mate\n"
-"    left join cat.kittens as kitten]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:154
 #, no-c-format
 msgid ""
 "You may supply extra join conditions using the HQL <literal>with</literal> "
 "keyword."
 msgstr ""
-"Você pode fornecer condições extras de join usando a palavra chave do HQL "
+"Você pode fornecer condições extras de união usando a palavra chave do HQL "
 "<literal>with</literal>."
 
-#. Tag: programlisting
-#: query_hql.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    left join cat.kittens as kitten\n"
-"        with kitten.bodyWeight > 10.0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:161
 #, fuzzy, no-c-format
 msgid ""
 "A \"fetch\" join allows associations or collections of values to be "
 "initialized along with their parent objects using a single select. This is "
 "particularly useful in the case of a collection. It effectively overrides "
 "the outer join and lazy declarations of the mapping file for associations "
-"and collections. See <xref linkend=\"performance-fetching\"/> for more "
+"and collections. See <xref linkend=\"performance-fetching\" /> for more "
 "information."
 msgstr ""
-"Adicionalmente, um \"fetch\" join permite que associações ou coleções de "
-"valores sejam inicializadas junto com o objeto pai, usando apenas um select. "
-"Isso é muito útil no caso das coleções. Isso efetivamente sobre escreve as "
-"declarações outer join e lazy do arquivo mapeamento para associações e "
-"coleções. Veja a seção <xref linkend=\"performance-fetching\"/> para mais "
-"informações."
+"A união de \"busca\" permite que associações ou coleções de valores sejam "
+"inicializadas junto com o objeto pai, usando apenas um select. Isso é muito "
+"útil no caso das coleções. Isso efetivamente substitui as declarações união "
+"externa e lazy do arquivo de mapeamento para associações e coleções. Veja a "
+"seção <xref linkend=\"performance-fetching\"/> para mais informações."
 
-#. Tag: programlisting
-#: query_hql.xml:169
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join fetch cat.mate\n"
-"    left join fetch cat.kittens]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:171
-#, fuzzy, no-c-format
-msgid ""
 "A fetch join does not usually need to assign an alias, because the "
 "associated objects should not be used in the <literal>where</literal> clause "
 "(or any other clause). The associated objects are also not returned directly "
@@ -312,28 +313,17 @@
 "The only reason you might need an alias is if you are recursively join "
 "fetching a further collection:"
 msgstr ""
-"Usualmente, um <literal>fetch</literal>join não precisa atribuir um alias, "
-"pois o objeto associado não deve ser usado na clausula <literal>where</"
-"literal> (ou em qualquer outra clausula). Também, os objetos associados não "
-"são retornados diretamente nos resultados da query. Ao invés disso, eles "
-"devem ser acessados usando o objeto pai. A única razão que nós podemos "
-"necessitar de um alias é quando fazemos um fech join recursivamente em uma "
-"coleção adicional:"
+"Geralmente, uma união de busca não precisa atribuir um alias, pois o objeto "
+"associado não deve ser usado na cláusula <literal>where</literal> (ou em "
+"qualquer outra cláusula). Também, os objetos associados não são retornados "
+"diretamente nos resultados da consulta. Ao invés disso, eles devem ser "
+"acessados usando o objeto pai. A única razão pela qual precisariamos de um "
+"alias é quando fazemos uma união de busca recursivamente em uma coleção "
+"adicional: "
 
-#. Tag: programlisting
-#: query_hql.xml:179
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join fetch cat.mate\n"
-"    left join fetch cat.kittens child\n"
-"    left join fetch child.kittens]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:181
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>fetch</literal> construct cannot be used in queries called "
 "using <literal>iterate()</literal> (though <literal>scroll()</literal> can "
 "be used). <literal>Fetch</literal> should be used together with "
@@ -349,80 +339,61 @@
 "<literal>full join fetch</literal> and <literal>right join fetch</literal> "
 "are not meaningful."
 msgstr ""
-"Observe que a construção <literal>fetch</literal> não deve ser usada em "
-"queries invocadas usando <literal>iterate()</literal> (embora possa ser "
-"usado com <literal>scroll()</literal>). O <literal>fetch</literal> também "
+"Observe que a construção <literal>busca</literal> não deve ser usada em "
+"consultas invocadas usando <literal>iterate()</literal> (embora possa ser "
+"usado com <literal>scroll()</literal>). O <literal>Fetch</literal> também "
 "não deve ser usado junto com o <literal>setMaxResults()</literal> ou "
 "<literal>setFirstResult()</literal> pois essas operações são baseadas nas "
-"linhas retornadas, que normalmente contem duplicidade devido ao fetching das "
-"coleções, então o número de linhas pode não ser o que você espera. O "
-"<literal>fetch</literal> não deve ser usado junto com uma condição "
-"<literal>with</literal> em uma condição <literal>with</literal> ad hoc. É "
-"possível que seja criado um produto cartesiano pelo join fetching em mais do "
-"que uma coleção em uma query, então tome cuidado nesses casos. Um join "
-"fetching em varias coleções pode trazer resultados inesperados para "
-"mapeamentos do tipo bag, tome cuidado na hora de formular queries como "
-"essas. Finalmente, observe o seguinte, o <literal>full join fetch</literal> "
-"e <literal>right join fetch</literal> não são significativos."
+"linhas retornadas, que normalmente contém duplicidade devido à busca das "
+"coleções, então o número de linhas pode não ser o que você espera. A "
+"<literal>Fetch</literal> não deve ser usada junto com uma condição "
+"<literal>with</literal>. É possível que seja criado um produto cartesiano "
+"pela busca de união em mais do que uma coleção em uma consulta, então tome "
+"cuidado nesses casos. Uma busca de união em várias coleções pode trazer "
+"resultados inesperados para mapeamentos do tipo bag, tome cuidado na hora de "
+"formular consultas como essas. Finalmente, observe o seguinte, a "
+"<literal>busca de união completa</literal> e <literal>busca de união "
+"direita</literal> não são importantes."
 
 #. Tag: para
-#: query_hql.xml:196
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are using property-level lazy fetching (with bytecode "
 "instrumentation), it is possible to force Hibernate to fetch the lazy "
 "properties in the first query immediately using <literal>fetch all "
 "properties</literal>."
 msgstr ""
-"Se está usando o nível de propriedade lazy (<literal>com</literal> "
-"instrumentação de bytecode), é possível forçar o Hibernate a "
-"<literal>buscar</literal> as propriedades lazy imediatamente (na primeira "
-"query), usando <literal>fetch all properties </literal>."
+"Se estiver usando o nível de propriedade busca lazy (com instrumentação de "
+"bytecode), é possível forçar o Hibernate a buscar as propriedades lazy "
+"imediatamente na primeira consulta, usando <literal>buscar todas as "
+"propriedades </literal>. "
 
-#. Tag: programlisting
-#: query_hql.xml:202
-#, no-c-format
-msgid "<![CDATA[from Document fetch all properties order by name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:203
-#, no-c-format
-msgid ""
-"<![CDATA[from Document doc fetch all properties where lower(doc.name) like '%"
-"cats%']]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:208
 #, no-c-format
 msgid "Forms of join syntax"
-msgstr "Formas e sintaxe de joins"
+msgstr "Formas de sintáxe de uniões"
 
 #. Tag: para
-#: query_hql.xml:210
 #, no-c-format
 msgid ""
 "HQL supports two forms of association joining: <literal>implicit</literal> "
 "and <literal>explicit</literal>."
 msgstr ""
 "O HQL suporta duas formas de associação para união: <literal>implícita</"
-"literal> e <literal>explicita</literal>."
+"literal> e <literal>explícita</literal>."
 
 #. Tag: para
-#: query_hql.xml:214
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The queries shown in the previous section all use the <literal>explicit</"
 "literal> form, that is, where the join keyword is explicitly used in the "
 "from clause. This is the recommended form."
 msgstr ""
-"As queries apresentadas na seção anterior usam a forma <literal>explicita</"
-"literal>, onde a palavra chave \"join\" é explicitamente usada na clausula "
-"\"from\". Essa é a forma recomendada."
+"As consultas apresentadas na seção anterior usam a forma <literal>explícita</"
+"literal>, onde a palavra chave união é explicitamente usada na cláusula "
+"from. Essa é a forma recomendada."
 
 #. Tag: para
-#: query_hql.xml:219
 #, no-c-format
 msgid ""
 "The <literal>implicit</literal> form does not use the join keyword. Instead, "
@@ -430,57 +401,47 @@
 "literal> joins can appear in any of the HQL clauses. <literal>implicit</"
 "literal> join result in inner joins in the resulting SQL statement."
 msgstr ""
-"A forma <literal>implícita</literal> não usa a palavra chave \"join\". "
-"Entretanto, as associações são diferenciadas usando pontuação (\".\" - "
-"dotnation). Uniões implícitas podem aparecer em qualquer das clausulas HQL. "
-"A união <literal>implícita</literal> resulta em declarações SQL que contem "
-"inner joins."
+"A forma <literal>implícita</literal> não usa a palavra chave \"união\". "
+"Entretanto, as associações são \"diferenciadas\" usando pontuação (\".\" - "
+"dot-notation). Uniões<literal>implícitas</literal> podem aparecer em "
+"qualquer uma das cláusulas HQL. A união <literal>implícita</literal> resulta "
+"em declarações SQL que contém uniões inteiras."
 
-#. Tag: programlisting
-#: query_hql.xml:226
-#, no-c-format
-msgid "<![CDATA[from Cat as cat where cat.mate.name like '%s%']]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Referring to identifier property"
-msgstr "Refering to identifier property"
+msgstr "Referência à propriedade do identificador "
 
 #. Tag: para
-#: query_hql.xml:232
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "There are 2 ways to refer to an entity's identifier property:"
 msgstr ""
-"There are, generally speaking, 2 ways to refer to an entity's identifier "
-"property:"
+"Geralmente, existem duas formas para se referir à propriedade do "
+"indentificador de uma entidade: "
 
 #. Tag: para
-#: query_hql.xml:237
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The special property (lowercase) <literal>id</literal> may be used to "
 "reference the identifier property of an entity <emphasis>provided that the "
 "entity does not define a non-identifier property named id</emphasis>."
 msgstr ""
-"The special property (lowercase) <literal>id</literal> may be used to "
-"reference the identifier property of an entity <emphasis>provided that "
-"entity does not define a non-identifier property named id</emphasis>."
+"A propriedade especial (em letra minúscula) <literal>id</literal> pode ser "
+"usada para se referir à propriedade do identificador de uma entidade "
+"<emphasis>considerando que a entidade não define uma propriedade não "
+"identificadora chamada id</emphasis>."
 
 #. Tag: para
-#: query_hql.xml:244
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the entity defines a named identifier property, you can use that property "
 "name."
 msgstr ""
-"If the entity defines a named identifier property, you may use that property "
-"name."
+"Se a entidade definir a propriedade do identificador nomeada, você poderá "
+"usar este nome de propriedade. "
 
 #. Tag: para
-#: query_hql.xml:250
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "References to composite identifier properties follow the same naming rules. "
 "If the entity has a non-identifier property named id, the composite "
@@ -488,15 +449,15 @@
 "the special <literal>id</literal> property can be used to reference the "
 "identifier property."
 msgstr ""
-"References to composite identifier properties follow the same naming rules. "
-"If the entity has a non-identifier property named id, the composite "
-"identifier property can only be referenced by its defined named; otherwise, "
-"the special <literal>id</literal> property can be used to rerference the "
-"identifier property."
+"As referências à composição das propriedades do identificador seguem as "
+"mesmas regras de nomeação. Se a entidade tiver uma propriedade de não "
+"identificador chamada id, a composição da propriedade do identificador pode "
+"somente ser referenciada pelo seu nome definido. Do contrário, uma "
+"propriedade especial <literal>id</literal> poderá ser usada para referenciar "
+"a propriedade do identificador. "
 
 #. Tag: para
-#: query_hql.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please note that, starting in version 3.2.2, this has changed significantly. "
 "In previous versions, <literal>id</literal> <emphasis>always</emphasis> "
@@ -504,289 +465,157 @@
 "ramification of that decision was that non-identifier properties named "
 "<literal>id</literal> could never be referenced in Hibernate queries."
 msgstr ""
-"Note: this has changed significantly starting in version 3.2.2. In previous "
-"versions, <literal>id</literal><emphasis>always</emphasis> referred to the "
-"identifier property no matter what its actual name. A ramification of that "
-"decision was that non-identifier properties named <literal>id</literal> "
-"could never be referenced in Hibernate queries."
+"Observe: esta ação mudou completamente na versão 3.2.2. Nas versões "
+"anteriores o <literal>id</literal> <emphasis>sempre</emphasis> referia-se à "
+"propriedade do identificador não importando seu nome atual. Uma ramificação "
+"desta decisão era que as propriedades do não identificador de chamadas "
+"<literal>id</literal> nunca poderiam ser referenciadas nas consultas do "
+"Hibernate. "
 
 #. Tag: title
-#: query_hql.xml:269
 #, no-c-format
 msgid "The select clause"
-msgstr "Clausula select"
+msgstr "A cláusula select"
 
 #. Tag: para
-#: query_hql.xml:271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>select</literal> clause picks which objects and properties to "
 "return in the query result set. Consider the following:"
 msgstr ""
-"A clausula <literal>select</literal> seleciona quais obetos e propriedades "
-"retornam no resultado da query. Considere:"
+"A cláusula <literal>select</literal> seleciona quais objetos e propriedades "
+"retornam no resultado da consulta. Considere: "
 
-#. Tag: programlisting
-#: query_hql.xml:276
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select mate\n"
-"from Cat as cat\n"
-"    inner join cat.mate as mate]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:278
-#, fuzzy, no-c-format
-msgid ""
 "The query will select <literal>mate</literal>s of other <literal>Cat</"
 "literal>s. You can express this query more compactly as:"
 msgstr ""
-"A query selecionará <literal>mate</literal>s (companheiros), de outros "
-"<literal>Cat</literal>s. Atualmente, podemos expressar a query de forma mais "
-"compacta como:"
+"A consulta selecionará <literal>mate</literal>s (parceiros), de outros "
+"<literal>Cat</literal>s. Atualmente, podemos expressar a consulta de forma "
+"mais compacta como: "
 
-#. Tag: programlisting
-#: query_hql.xml:283
-#, no-c-format
-msgid "<![CDATA[select cat.mate from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:285
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Queries can return properties of any value type including properties of "
 "component type:"
 msgstr ""
-"Queries podem retornar propriedades de qualquer tipo de valor, incluindo "
-"propriedades de tipo de componente:"
+"As consultas podem retornar propriedades de qualquer tipo de valor, "
+"incluindo propriedades de tipo de componente: "
 
-#. Tag: programlisting
-#: query_hql.xml:289
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat.name from DomesticCat cat\n"
-"where cat.name like 'fri%']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:291
-#, no-c-format
-msgid "<![CDATA[select cust.name.firstName from Customer as cust]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:293
-#, fuzzy, no-c-format
-msgid ""
 "Queries can return multiple objects and/or properties as an array of type "
 "<literal>Object[]</literal>:"
 msgstr ""
-"Queries podem retornar múltiplos objetos e/ou propriedades como um array do "
-"tipo Object[],"
+"As consultas podem retornar múltiplos objetos e/ou propriedades como uma "
+"matriz do tipo <literal>Object[]</literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:298
-#, no-c-format
-msgid ""
-"<![CDATA[select mother, offspr, mate.name\n"
-"from DomesticCat as mother\n"
-"    inner join mother.mate as mate\n"
-"    left outer join mother.kittens as offspr]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:300
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Or as a <literal>List</literal>:"
-msgstr "ou como um <literal>List</literal>,"
+msgstr "Ou como um <literal>List</literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:304
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select new list(mother, offspr, mate.name)\n"
-"from DomesticCat as mother\n"
-"    inner join mother.mate as mate\n"
-"    left outer join mother.kittens as offspr]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:306
-#, fuzzy, no-c-format
-msgid ""
 "Or - assuming that the class <literal>Family</literal> has an appropriate "
 "constructor - as an actual typesafe Java object:"
 msgstr ""
-"assumindo que a classe <literal>Family</literal> tenha um construtor "
-"apropriado."
+"Ou - considerando que a classe <literal>Family</literal> tenha um construtor "
+"apropriado - como um objeto Java typesafe atual:"
 
-#. Tag: programlisting
-#: query_hql.xml:310
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select new Family(mother, mate, offspr)\n"
-"from DomesticCat as mother\n"
-"    join mother.mate as mate\n"
-"    left join mother.kittens as offspr]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:313
-#, fuzzy, no-c-format
-msgid ""
 "You can assign aliases to selected expressions using <literal>as</literal>:"
 msgstr ""
-"Pode-se designar referencias a expressões selecionadas, <literal>as</"
+"Pode-se designar alias à expressões selecionadas usando <literal>as</"
 "literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:317
-#, no-c-format
-msgid ""
-"<![CDATA[select max(bodyWeight) as max, min(bodyWeight) as min, count(*) as "
-"n\n"
-"from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:319
 #, no-c-format
 msgid ""
 "This is most useful when used together with <literal>select new map</"
 "literal>:"
 msgstr ""
 "Isto é bem mais útil quando usado junto <literal>com</"
-"literal><literal>select new map</literal>:"
+"literal><literal>selecione novo mapa</literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:323
-#, no-c-format
-msgid ""
-"<![CDATA[select new map( max(bodyWeight) as max, min(bodyWeight) as min, "
-"count(*) as n )\n"
-"from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:325
 #, no-c-format
 msgid ""
 "This query returns a <literal>Map</literal> from aliases to selected values."
 msgstr ""
-"Esta query retorna um <literal>Map</literal> de referencias para valores "
+"Esta consulta retorna um <literal>Mapa</literal> de referências para valores "
 "selecionados."
 
 #. Tag: title
-#: query_hql.xml:332
 #, no-c-format
 msgid "Aggregate functions"
 msgstr "Funções de agregação"
 
 #. Tag: para
-#: query_hql.xml:334
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL queries can even return the results of aggregate functions on properties:"
 msgstr ""
-"As queries HQL podem retornar o resultado de funções agregadas nas "
-"propriedades."
+"As consultas HQL podem retornar o resultado de funções agregadas nas "
+"propriedades:"
 
-#. Tag: programlisting
-#: query_hql.xml:338
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[select avg(cat.weight), sum(cat.weight), max(cat.weight), count"
-"(cat)\n"
-"from Cat cat]]>"
-msgstr ""
+msgid "The supported aggregate functions are:"
+msgstr "As funções agregadas suportadas são: "
 
 #. Tag: para
-#: query_hql.xml:349
 #, fuzzy, no-c-format
-msgid "The supported aggregate functions are:"
-msgstr "As funções agregadas suportadas são:"
+msgid "<literal>avg(...), sum(...), min(...), max(...)</literal>"
+msgstr "<literal>avg(...), sum(...), min(...), max(...)</literal>"
 
-#. Tag: literal
-#: query_hql.xml:356
+#. Tag: para
 #, no-c-format
-msgid "avg(...), sum(...), min(...), max(...)"
-msgstr "avg(...), sum(...), min(...), max(...)"
+msgid "<literal>count(*)</literal>"
+msgstr "<literal>count(*)</literal>"
 
-#. Tag: literal
-#: query_hql.xml:361
-#, no-c-format
-msgid "count(*)"
-msgstr "count(*)"
-
-#. Tag: literal
-#: query_hql.xml:366
-#, no-c-format
-msgid "count(...), count(distinct ...), count(all...)"
-msgstr "count(...), count(distinct ...), count(all...)"
-
 #. Tag: para
-#: query_hql.xml:371
 #, fuzzy, no-c-format
+msgid "<literal>count(...), count(distinct ...), count(all...)</literal>"
+msgstr "<literal>count(...), count(distinct ...), count(all...)</literal>"
+
+#. Tag: para
+#, no-c-format
 msgid ""
 "You can use arithmetic operators, concatenation, and recognized SQL "
 "functions in the select clause:"
 msgstr ""
-"Pode-se usar operadores aritiméticos, concatenação e funções SQL "
-"reconhecidas na clausula select:"
+"Pode-se usar operadores aritméticos, concatenação e funções SQL reconhecidas "
+"na cláusula select: "
 
-#. Tag: programlisting
-#: query_hql.xml:376
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat.weight + sum(kitten.weight)\n"
-"from Cat cat\n"
-"    join cat.kittens kitten\n"
-"group by cat.id, cat.weight]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:378
-#, no-c-format
-msgid ""
-"<![CDATA[select firstName||' '||initial||' '||upper(lastName) from Person]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:380
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>distinct</literal> and <literal>all</literal> keywords can be "
 "used and have the same semantics as in SQL."
 msgstr ""
 "As palavras <literal>distinct</literal> e <literal>all</literal> podem ser "
-"usadas e têm a mesma semântica como no SQL."
+"usadas e têm a mesma semântica que no SQL. "
 
-#. Tag: programlisting
-#: query_hql.xml:385
-#, no-c-format
-msgid ""
-"<![CDATA[select distinct cat.name from Cat cat\n"
-"\n"
-"select count(distinct cat.name), count(cat) from Cat cat]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:390
 #, no-c-format
 msgid "Polymorphic queries"
-msgstr "Queries polimórficas"
+msgstr "Pesquisas Polimórficas"
 
 #. Tag: para
-#: query_hql.xml:392
 #, no-c-format
 msgid "A query like:"
-msgstr "A query:"
+msgstr "A consulta:"
 
 #. Tag: para
-#: query_hql.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "returns instances not only of <literal>Cat</literal>, but also of subclasses "
 "like <literal>DomesticCat</literal>. Hibernate queries can name "
@@ -795,21 +624,14 @@
 "that extend that class or implement the interface. The following query would "
 "return all persistent objects:"
 msgstr ""
-"retorna instancias não só de <literal>Cat</literal>, mas também de "
-"subclasses como <literal>DomesticCat</literal>. As queries do Hibernate "
-"podem nomear qualquer classe Java ou interface na clausula <literal>from</"
-"literal>. A query retornará instancias de toda classe persistente que "
-"extenda a determinada classe ou implemente a determinada interface. A "
-"query , a seguir, pode retornar todo objeto persistente:"
+"retorna instâncias não só de <literal>Cat</literal>, mas também de "
+"subclasses como <literal>DomesticCat</literal>. As consultas do Hibernate "
+"podem nomear qualquer classe Java ou interface na cláusula <literal>from</"
+"literal>. A consulta retornará instâncias de todas as classes persistentes "
+"que extendam a determinada classe ou implemente a determinada interface. A "
+"consulta a seguir, poderia retornar todos os objetos persistentes: "
 
-#. Tag: programlisting
-#: query_hql.xml:406
-#, no-c-format
-msgid "<![CDATA[from java.lang.Object o]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:408
 #, no-c-format
 msgid ""
 "The interface <literal>Named</literal> might be implemented by various "
@@ -818,340 +640,217 @@
 "A interface <literal>Named</literal> pode ser implementada por várias "
 "classes persistentes:"
 
-#. Tag: programlisting
-#: query_hql.xml:413
-#, no-c-format
-msgid "<![CDATA[from Named n, Named m where n.name = m.name]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:415
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These last two queries will require more than one SQL <literal>SELECT</"
 "literal>. This means that the <literal>order by</literal> clause does not "
 "correctly order the whole result set. It also means you cannot call these "
 "queries using <literal>Query.scroll()</literal>."
 msgstr ""
-"Note que as duas últimas queries requerem mais de um SQL SELECT . Isto "
-"significa que a clausula <literal>order by</literal> não ordena corretamente "
-"todo o resultado. (Isso também significa que você não pode chamar essas "
-"queries usando <literal>Query.scroll()</literal>.)"
+"Note que as duas últimas consultas requerem mais de um SQL <literal>SELECT</"
+"literal>. Isto significa que a cláusula <literal>order by</literal> não "
+"ordena corretamente todo o resultado. Isso também significa que você não "
+"pode chamar essas consultas usando <literal>consulta.scroll()</literal>."
 
 #. Tag: title
-#: query_hql.xml:424
 #, no-c-format
 msgid "The where clause"
-msgstr "A clausula where"
+msgstr "A cláusula where"
 
 #. Tag: para
-#: query_hql.xml:426
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>where</literal> clause allows you to refine the list of "
 "instances returned. If no alias exists, you can refer to properties by name:"
 msgstr ""
-"A clausula <literal>where</literal> permite estreitar a lista de instancias "
-"retornada. Se não houver referencia alguma, pode-se referir a propriedades "
-"pelo nome:"
+"A cláusula <literal>where</literal> permite estreitar a lista de instâncias "
+"retornadas. Se não houver referência alguma, pode-se referir à propriedades "
+"pelo nome: "
 
-#. Tag: programlisting
-#: query_hql.xml:431
-#, no-c-format
-msgid "<![CDATA[from Cat where name='Fritz']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:433
 #, no-c-format
 msgid "If there is an alias, use a qualified property name:"
 msgstr "Se houver uma referência, use o nome da propriedade qualificada:"
 
-#. Tag: programlisting
-#: query_hql.xml:437
-#, no-c-format
-msgid "<![CDATA[from Cat as cat where cat.name='Fritz']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:439
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This returns instances of <literal>Cat</literal> named 'Fritz'."
-msgstr "retorna instancias de <literal>Cat</literal> com nome ‘Fritz’."
+msgstr "Isto retorna instâncias de <literal>Cat</literal> com nome ‘Fritz’."
 
 #. Tag: para
-#: query_hql.xml:443
 #, no-c-format
 msgid "The following query:"
-msgstr ""
+msgstr "A seguinte consulta:"
 
-#. Tag: programlisting
-#: query_hql.xml:446
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select foo\n"
-"from Foo foo, Bar bar\n"
-"where foo.startDate = bar.date]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:448
-#, fuzzy, no-c-format
-msgid ""
 "returns all instances of <literal>Foo</literal> with an instance of "
 "<literal>bar</literal> with a <literal>date</literal> property equal to the "
 "<literal>startDate</literal> property of the <literal>Foo</literal>. "
 "Compound path expressions make the <literal>where</literal> clause extremely "
 "powerful. Consider the following:"
 msgstr ""
-"retornará todas as instancias de <literal>Foo</literal>, para cada um que "
-"tiver uma instancia de <literal>bar</literal> com a propriedade "
+"retornará todas as instâncias de <literal>Foo</literal>, para cada um que "
+"tiver uma instância de <literal>bar</literal> com a propriedade "
 "<literal>date</literal> igual a propriedade <literal>startDate</literal> de "
-"<literal>Foo</literal>. Expressões de filtro compostas fazem da clausula "
-"<literal>where</literal>, extremamente poderosa. Consideremos:"
+"<literal>Foo</literal>. Expressões de caminho compostas fazem da cláusula "
+"<literal>where</literal>, extremamente poderosa. Consideremos: "
 
-#. Tag: programlisting
-#: query_hql.xml:457
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.mate.name is not null]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:459
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This query translates to an SQL query with a table (inner) join. For example:"
 msgstr ""
-"Esta query traduzida para uma query SQL <literal>com</literal> uma tabela "
-"(inner) join. Se fosse escrever algo como:"
+"Esta consulta traduz para uma consulta SQL com uma tabela (inner) união. Por "
+"exemplo:"
 
-#. Tag: programlisting
-#: query_hql.xml:464
-#, no-c-format
-msgid ""
-"<![CDATA[from Foo foo\n"
-"where foo.bar.baz.customer.address.city is not null]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:466
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "would result in a query that would require four table joins in SQL."
 msgstr ""
-"Poderia-se terminar <literal>com</literal> uma query que necessitasse de "
-"join de quatro tabelas, no SQL."
+"resultaria numa consulta que necessitasse de união de quatro tabelas, no SQL."
 
 #. Tag: para
-#: query_hql.xml:470
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>=</literal> operator can be used to compare not only "
 "properties, but also instances:"
 msgstr ""
-"O operador <literal>=</literal> pode ser uasdo para comparar não apenas "
-"propriedades, mas também instancias:"
+"O operador <literal>=</literal> pode ser usado para comparar não apenas "
+"propriedades, mas também instâncias: "
 
-#. Tag: programlisting
-#: query_hql.xml:475
-#, no-c-format
-msgid "<![CDATA[from Cat cat, Cat rival where cat.mate = rival.mate]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:477
-#, no-c-format
-msgid ""
-"<![CDATA[select cat, mate\n"
-"from Cat cat, Cat mate\n"
-"where cat.mate = mate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:479
 #, fuzzy, no-c-format
 msgid ""
 "The special property (lowercase) <literal>id</literal> can be used to "
 "reference the unique identifier of an object. See <xref linkend=\"queryhql-"
-"identifier-property\"/> for more information."
+"identifier-property\" /> for more information."
 msgstr ""
-"A propriedade especial (lowercase) <literal>id</literal> pode ser usada para "
-"referenciar o identificador único de um objeto. (Pode-se usar também o nome "
-"de sua propriedade)"
+"A propriedade especial (letra minúscula) <literal>id</literal> pode ser "
+"usada para referenciar o identificador único de um objeto. Para maiores "
+"informações consulte a <xref linkend=\"queryhql-identifier-property\"/>.  "
 
-#. Tag: programlisting
-#: query_hql.xml:485
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat where cat.id = 123\n"
-"\n"
-"from Cat as cat where cat.mate.id = 69]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:487
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The second query is efficient and does not require a table join."
-msgstr "A Segunda query é eficiente. Nenhuma união de tabelas é necessária!"
+msgstr "A segunda consulta é eficiente e não requer nenhuma união de tabelas."
 
 #. Tag: para
-#: query_hql.xml:491
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Properties of composite identifiers can also be used. Consider the following "
 "example where <literal>Person</literal> has composite identifiers consisting "
 "of <literal>country</literal> and <literal>medicareNumber</literal>:"
 msgstr ""
 "As propriedades de identificadores compostas também podem ser usadas. "
-"Suponha que <literal>Person</literal> tenha um identificador composto que "
-"consiste de <literal>country</literal> e <literal>medicareNumber</literal>."
+"Considere o seguinte exemplo onde <literal>Person</literal> possui "
+"identificadores compostos que consistem de <literal>country</literal> e "
+"<literal>medicareNumber</literal>: "
 
-#. Tag: programlisting
-#: query_hql.xml:497
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[from bank.Person person\n"
-"where person.id.country = 'AU'\n"
-"    and person.id.medicareNumber = 123456]]>"
+msgid "Once again, the second query does not require a table join."
 msgstr ""
+"Mais uma vez, a segunda consulta não precisa de nenhuma união de tabela."
 
-#. Tag: programlisting
-#: query_hql.xml:499
-#, no-c-format
-msgid ""
-"<![CDATA[from bank.Account account\n"
-"where account.owner.id.country = 'AU'\n"
-"    and account.owner.id.medicareNumber = 123456]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:501
 #, fuzzy, no-c-format
-msgid "Once again, the second query does not require a table join."
-msgstr "Mais uma vez, a Segunda query não precisa de nenhum join de tabela."
-
-#. Tag: para
-#: query_hql.xml:505
-#, no-c-format
 msgid ""
-"See <xref linkend=\"queryhql-identifier-property\"/> for more information "
+"See <xref linkend=\"queryhql-identifier-property\" /> for more information "
 "regarding referencing identifier properties)"
 msgstr ""
+"Veja <xref linkend=\"queryhql-identifier-property\"/> para maiores "
+"informações a respeito das propriedades do identificador referenciado) "
 
 #. Tag: para
-#: query_hql.xml:510
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The special property <literal>class</literal> accesses the discriminator "
 "value of an instance in the case of polymorphic persistence. A Java class "
 "name embedded in the where clause will be translated to its discriminator "
 "value."
 msgstr ""
-"Assim mesmo, a propriedade especial <literal>class</literal> acessa o valor "
-"discriminador da instancia, no caso de persistência polimórfica. O nome de "
-"uma classe Java inclusa em uma clausula \"where\", será traduzida para seu "
-"valor descriminante."
+"Da mesma forma, a propriedade especial <literal>class</literal> acessa o "
+"valor discriminador da instância, no caso de persistência polimórfica. O "
+"nome de uma classe Java inclusa em uma cláusula where, será traduzida para "
+"seu valor discriminante."
 
-#. Tag: programlisting
-#: query_hql.xml:516
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.class = DomesticCat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:518
 #, fuzzy, no-c-format
 msgid ""
 "You can also use components or composite user types, or properties of said "
-"component types. See <xref linkend=\"queryhql-components\"/> for more "
+"component types. See <xref linkend=\"queryhql-components\" /> for more "
 "information."
 msgstr ""
-"Pode-se também especificar as propriedades dos components ou tipos de "
-"usuário composto (e de componentes de componentes). Nunca tente usar uma "
-"expressão de filtro que termine na propriedade de um tipo de componente (ao "
-"contrário de uma propriedade de um componente). Por exemplo, se store.owner "
-"é uma entidade <literal>com</literal> um componente <literal>address</"
-"literal>."
+"Pode-se também utilizar componentes ou tipos de usuários de composição, ou "
+"propriedades dos tipos de componentes mencionados. Veja <xref linkend="
+"\"queryhql-components\"/> para maiores informações."
 
 #. Tag: para
-#: query_hql.xml:523
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An \"any\" type has the special properties <literal>id</literal> and "
 "<literal>class</literal> that allows you to express a join in the following "
 "way (where <literal>AuditLog.item</literal> is a property mapped with "
 "<literal>&lt;any&gt;</literal>):"
 msgstr ""
-"Um tipo \"any\" tem as propriedades <literal>id</literal> e <literal>class</"
-"literal> especiais, nôs permitindo expressar um join da seguinte forma (onde "
-"<literal>AuditLog.item</literal> é uma propriedade mapeada <literal>com</"
-"literal><literal>&lt;any&gt;</literal>)"
+"Um tipo \"any\" possui as propriedades <literal>id</literal> e "
+"<literal>class</literal> especiais, nos permitindo expressar uma união da "
+"seguinte forma (onde <literal>AuditLog.item</literal> é uma propriedade "
+"mapeada <literal>com</literal><literal>&lt;any&gt;</literal>):"
 
-#. Tag: programlisting
-#: query_hql.xml:529
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from AuditLog log, Payment payment\n"
-"where log.item.class = 'Payment' and log.item.id = payment.id]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:531
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>log.item.class</literal> and <literal>payment.class</literal> "
 "would refer to the values of completely different database columns in the "
 "above query."
 msgstr ""
 "Veja que <literal>log.item.class</literal> e <literal>payment.class</"
-"literal> podem referir-se a valores de colunas de banco de dados "
-"completamente diferentes, na query acima."
+"literal> podem referir-se à valores de colunas de banco de dados "
+"completamente diferentes, na consulta acima. "
 
 #. Tag: title
-#: query_hql.xml:539
 #, no-c-format
 msgid "Expressions"
 msgstr "Expressões"
 
 #. Tag: para
-#: query_hql.xml:541
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Expressions used in the <literal>where</literal> clause include the "
 "following:"
 msgstr ""
-"As expressões permitidas na cláusula <literal>where</literal> inclui a "
-"maioria das coisas que você poderia escrever no SQL:"
+"As expressões permitidas na cláusula <literal>where</literal> incluem o "
+"seguinte:"
 
 #. Tag: para
-#: query_hql.xml:548
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "mathematical operators: <literal>+, -, *, /</literal>"
-msgstr "operadores matemáticos <literal>+, -, *, /</literal>"
+msgstr "operadores matemáticos: <literal>+, -, *, /</literal>"
 
 #. Tag: para
-#: query_hql.xml:553
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "binary comparison operators: <literal>=, &gt;=, &lt;=, &lt;&gt;, !=, like</"
 "literal>"
 msgstr ""
-"operadores de comparação binários <literal>=, &gt;=, &lt;=, &lt;&gt;, !=, "
+"operadores de comparação binários: <literal>=, &gt;=, &lt;=, &lt;&gt;, !=, "
 "like</literal>"
 
 #. Tag: para
-#: query_hql.xml:558
 #, no-c-format
 msgid "logical operations <literal>and, or, not</literal>"
 msgstr "operadores lógicos <literal>and, or, not</literal>"
 
 #. Tag: para
-#: query_hql.xml:563
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Parentheses <literal>( )</literal> that indicates grouping"
-msgstr "parenteses <literal>( )</literal>, indicating grouping"
+msgstr "Parênteses <literal>( )</literal> que indica o agrupamento"
 
 #. Tag: para
-#: query_hql.xml:568
 #, no-c-format
 msgid ""
 "<literal>in</literal>, <literal>not in</literal>, <literal>between</"
@@ -1165,7 +864,6 @@
 "<literal>member of</literal> and <literal>not member of</literal>"
 
 #. Tag: para
-#: query_hql.xml:581
 #, no-c-format
 msgid ""
 "\"Simple\" case, <literal>case ... when ... then ... else ... end</literal>, "
@@ -1176,7 +874,6 @@
 "end</literal>"
 
 #. Tag: para
-#: query_hql.xml:587
 #, no-c-format
 msgid ""
 "string concatenation <literal>...||...</literal> or <literal>concat(...,...)"
@@ -1186,57 +883,51 @@
 "(...,...)</literal>"
 
 #. Tag: para
-#: query_hql.xml:592
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>current_date()</literal>, <literal>current_time()</literal>, and "
 "<literal>current_timestamp()</literal>"
 msgstr ""
-"<literal>current_date()</literal>, <literal>current_time()</literal>, "
-"<literal>current_timestamp()</literal>"
+"<literal>current_date()</literal>, <literal>current_time()</literal> e "
+"<literal>current_timestamp()</literal> "
 
 #. Tag: para
-#: query_hql.xml:598
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>second(...)</literal>, <literal>minute(...)</literal>, <literal>hour"
 "(...)</literal>, <literal>day(...)</literal>, <literal>month(...)</literal>, "
 "and <literal>year(...)</literal>"
 msgstr ""
 "<literal>second(...)</literal>, <literal>minute(...)</literal>, <literal>hour"
-"(...)</literal>, <literal>day(...)</literal>, <literal>month(...)</literal>, "
-"<literal>year(...)</literal>,"
+"(...)</literal>, <literal>day(...)</literal>, <literal>month(...)</literal> "
+"e <literal>year(...)</literal>"
 
 #. Tag: para
-#: query_hql.xml:605
 #, no-c-format
 msgid ""
 "Any function or operator defined by EJB-QL 3.0: <literal>substring(), trim"
 "(), lower(), upper(), length(), locate(), abs(), sqrt(), bit_length(), mod()"
 "</literal>"
 msgstr ""
-"qualquer funcao ou operador definida pela EJB-QL 3.0: <literal>substring(), "
+"qualquer função ou operador definidos pela EJB-QL 3.0: <literal>substring(), "
 "trim(), lower(), upper(), length(), locate(), abs(), sqrt(), bit_length(), "
 "mod()</literal>"
 
 #. Tag: para
-#: query_hql.xml:611
 #, no-c-format
 msgid "<literal>coalesce()</literal> and <literal>nullif()</literal>"
 msgstr "<literal>coalesce()</literal> and <literal>nullif()</literal>"
 
 #. Tag: para
-#: query_hql.xml:616
 #, no-c-format
 msgid ""
 "<literal>str()</literal> for converting numeric or temporal values to a "
 "readable string"
 msgstr ""
-"<literal>str()</literal> para converter valores numericos ou temporais para "
-"string"
+"<literal>str()</literal> para converter valores numéricos ou temporais para "
+"uma string de leitura"
 
 #. Tag: para
-#: query_hql.xml:622
 #, no-c-format
 msgid ""
 "<literal>cast(... as ...)</literal>, where the second argument is the name "
@@ -1246,22 +937,20 @@
 msgstr ""
 "<literal>cast(... as ...)</literal>, onde o segundo argumento é o nome do "
 "tipo hibernate, e<literal>extract(... from ...)</literal> se ANSI "
-"<literal>cast()</literal> e <literal>extract()</literal> é suportado pele "
-"banco de dados usado"
+"<literal>cast()</literal> e <literal>extract()</literal> é suportado pelo "
+"banco de dados adjacente"
 
 #. Tag: para
-#: query_hql.xml:630
 #, no-c-format
 msgid ""
 "the HQL <literal>index()</literal> function, that applies to aliases of a "
 "joined indexed collection"
 msgstr ""
-"A função HQL <literal>index()</literal> , que se aplicam a referencias de "
+"A função HQL <literal>index()</literal> , que se aplicam às referências de "
 "coleçôes associadas e indexadas"
 
 #. Tag: para
-#: query_hql.xml:636
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL functions that take collection-valued path expressions: <literal>size(), "
 "minelement(), maxelement(), minindex(), maxindex()</literal>, along with the "
@@ -1269,42 +958,38 @@
 "functions that can be quantified using <literal>some, all, exists, any, in</"
 "literal>."
 msgstr ""
-"As funções hql que retornam expressões de coleções de valores: <literal>size"
-"(), minelement(), maxelement(), minindex(), maxindex()</literal>, "
-"<literal>junto</literal> com o elemento especial, <literal>elements()</"
-"literal>, e funções de <literal>índice</literal> que podem ser quantificadas "
-"usando <literal>some, all, exists, any, in</literal>."
+"As funções HQL que retornam expressões de coleções de valores: <literal>size"
+"(), minelement(), maxelement(), minindex(), maxindex()</literal>, junto com "
+"o elemento especial, <literal>elements()</literal> e funções de "
+"<literal>índices</literal> que podem ser quantificadas usando <literal>some, "
+"all, exists, any, in</literal>."
 
 #. Tag: para
-#: query_hql.xml:644
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Any database-supported SQL scalar function like <literal>sign()</literal>, "
 "<literal>trunc()</literal>, <literal>rtrim()</literal>, and <literal>sin()</"
 "literal>"
 msgstr ""
-"Qualquer funçâo escalar pelo bando de dados como <literal>sign()</literal>, "
-"<literal>trunc()</literal>, <literal>rtrim()</literal>, <literal>sin()</"
-"literal>"
+"Qualquer função escalar suportada pelo banco de dados como <literal>sign()</"
+"literal>, <literal>trunc()</literal>, <literal>rtrim()</literal> e "
+"<literal>sin()</literal>"
 
 #. Tag: para
-#: query_hql.xml:650
 #, no-c-format
 msgid "JDBC-style positional parameters <literal>?</literal>"
-msgstr "Parametros posicionais ao estilo JDBC <literal>?</literal>"
+msgstr "Parâmetros posicionais ao estilo JDBC <literal>?</literal>"
 
 #. Tag: para
-#: query_hql.xml:655
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "named parameters <literal>:name</literal>, <literal>:start_date</literal>, "
 "and <literal>:x1</literal>"
 msgstr ""
-"Parametros nomeados <literal>:name</literal>, <literal>:start_date</"
-"literal>, <literal>:x1</literal>"
+"Parâmetros nomeados <literal>:name</literal>, <literal>:start_date</literal> "
+"e <literal>:x1</literal>"
 
 #. Tag: para
-#: query_hql.xml:660
 #, no-c-format
 msgid ""
 "SQL literals <literal>'foo'</literal>, <literal>69</literal>, <literal>6.66E"
@@ -1314,88 +999,46 @@
 "+2</literal>, <literal>'1970-01-01 10:00:01.0'</literal>"
 
 #. Tag: para
-#: query_hql.xml:666
 #, no-c-format
 msgid ""
 "Java <literal>public static final</literal> constants <literal>eg.Color."
 "TABBY</literal>"
 msgstr ""
-"Constantes Java <literal>public static final</literal><literal>ex: Color."
+"Constantes Java <literal>final estático público</literal><literal>ex: Color."
 "TABBY</literal>"
 
 #. Tag: para
-#: query_hql.xml:672
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>in</literal> and <literal>between</literal> can be used as follows:"
 msgstr ""
 "<literal>in</literal> e <literal>between</literal> podem ser usadas da "
-"seguinte maneira:"
+"seguinte maneira: "
 
-#. Tag: programlisting
-#: query_hql.xml:676
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name between 'A' and 'B']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:678
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat cat where cat.name in ( 'Foo', 'Bar', 'Baz' )]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:680
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The negated forms can be written as follows:"
-msgstr "e as formas negativas podem ser escritas"
+msgstr "As formas negativas podem ser escritas conforme segue abaixo:"
 
-#. Tag: programlisting
-#: query_hql.xml:684
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name not between 'A' and 'B']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:686
-#, no-c-format
 msgid ""
-"<![CDATA[from DomesticCat cat where cat.name not in ( 'Foo', 'Bar', 'Baz' )]]"
-">"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:688
-#, fuzzy, no-c-format
-msgid ""
 "Similarly, <literal>is null</literal> and <literal>is not null</literal> can "
 "be used to test for null values."
 msgstr ""
-"Likewise, <literal>is null</literal> and <literal>is not null</literal> may "
-"be used to test for null values. Assim mesmo, , <literal>is null</literal> e "
-"<literal>is not null</literal> podem ser usados para testar valores nulos."
+"Da mesma forma, <literal>is null</literal> e <literal>is not null</literal> "
+"podem ser usados para testar valores nulos."
 
 #. Tag: para
-#: query_hql.xml:693
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Booleans can be easily used in expressions by declaring HQL query "
 "substitutions in Hibernate configuration:"
 msgstr ""
 "Booleanos podem ser facilmente usados em expressões, declarando as "
-"substituições da HQL query, na configuração do Hibernate"
+"substituições da consulta HQL, na configuração do Hibernate:"
 
-#. Tag: programlisting
-#: query_hql.xml:698
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"hibernate.query.substitutions\">true 1, false 0</"
-"property>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:700
 #, no-c-format
 msgid ""
 "This will replace the keywords <literal>true</literal> and <literal>false</"
@@ -1406,38 +1049,17 @@
 "<literal>false</literal><literal>pelos</literal> literais <literal>1</"
 "literal> e <literal>0</literal> na tradução do HQL para SQL."
 
-#. Tag: programlisting
-#: query_hql.xml:705
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.alive = true]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:707
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can test the size of a collection with the special property "
 "<literal>size</literal> or the special <literal>size()</literal> function."
 msgstr ""
-"Pode-se testar o tamanho de uma coleção <literal>com</literal> a propriedade "
-"especial <literal>size</literal>, ou a função especial <literal>size()</"
-"literal>."
+"Pode-se testar o tamanho de uma coleção com a propriedade especial "
+"<literal>size</literal> ou a função especial <literal>size()</literal>."
 
-#. Tag: programlisting
-#: query_hql.xml:712
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.kittens.size > 0]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:714
-#, no-c-format
-msgid "<![CDATA[from Cat cat where size(cat.kittens) > 0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:716
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For indexed collections, you can refer to the minimum and maximum indices "
 "using <literal>minindex</literal> and <literal>maxindex</literal> functions. "
@@ -1447,33 +1069,13 @@
 msgstr ""
 "Para coleções indexadas, você pode se referir aos índices máximo e mínimo, "
 "usando as funções <literal>minindex</literal> e <literal>maxindex</literal>. "
-"Similarmente, pode-se referir aos elementos máximo e mínimo de uma coleção "
-"de tipos básicos usando as funções <literal>minelement</literal> e "
-"<literal>maxelement</literal>."
+"Igualmente, pode-se referir aos elementos máximo e mínimo de uma coleção de "
+"tipos básicos usando as funções <literal>minelement</literal> e "
+"<literal>maxelement</literal>. Por exemplo:"
 
-#. Tag: programlisting
-#: query_hql.xml:724
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Calendar cal where maxelement(cal.holidays) > current_date]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:726
-#, no-c-format
-msgid "<![CDATA[from Order order where maxindex(order.items) > 100]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:728
-#, no-c-format
-msgid "<![CDATA[from Order order where minelement(order.items) > 10000]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:730
-#, fuzzy, no-c-format
-msgid ""
 "The SQL functions <literal>any, some, all, exists, in</literal> are "
 "supported when passed the element or index set of a collection "
 "(<literal>elements</literal> and <literal>indices</literal> functions) or "
@@ -1481,229 +1083,87 @@
 msgstr ""
 "As funções SQL <literal>any, some, all, exists, in</literal> são suportadas "
 "quando passado o elemento ou o conjunto de índices de uma coleção "
-"(<literal>elements</literal> e <literal>indices</literal> de funções), ou o "
-"resultado de uma subquery (veja abaixo)."
+"(<literal>elements</literal> e <literal>índices</literal> de funções) ou o "
+"resultado de uma subconsulta (veja abaixo):"
 
-#. Tag: programlisting
-#: query_hql.xml:736
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select mother from Cat as mother, Cat as kit\n"
-"where kit in elements(foo.kittens)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:738
-#, no-c-format
-msgid ""
-"<![CDATA[select p from NameList list, Person p\n"
-"where p.name = some elements(list.names)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:740
-#, no-c-format
-msgid "<![CDATA[from Cat cat where exists elements(cat.kittens)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:742
-#, no-c-format
-msgid "<![CDATA[from Player p where 3 > all elements(p.scores)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:744
-#, no-c-format
-msgid "<![CDATA[from Show show where 'fizard' in indices(show.acts)]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:746
-#, fuzzy, no-c-format
-msgid ""
 "Note that these constructs - <literal>size</literal>, <literal>elements</"
 "literal>, <literal>indices</literal>, <literal>minindex</literal>, "
 "<literal>maxindex</literal>, <literal>minelement</literal>, "
 "<literal>maxelement</literal> - can only be used in the where clause in "
 "Hibernate3."
 msgstr ""
-"Note que essas construções - <literal>size</literal>, <literal>elements</"
-"literal>, <literal>indices</literal>, <literal>minindex</literal>, "
+"Note que essas construções - <literal>tamanho</literal>, <literal>elementos</"
+"literal>, <literal>índices</literal>, <literal>minindex</literal>, "
 "<literal>maxindex</literal>, <literal>minelement</literal>, "
-"<literal>maxelement</literal>– só podem ser usados na clausula where do "
+"<literal>maxelement</literal> – só podem ser usados na cláusula where do "
 "Hibernate3."
 
 #. Tag: para
-#: query_hql.xml:753
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Elements of indexed collections (arrays, lists, and maps) can be referred to "
 "by index in a where clause only:"
 msgstr ""
-"Elementos de coleções com índice (arrays, lists, maps), podem ser "
-"referenciadas pelo índice (apenas na clausula where):"
+"Elementos de coleções com índice (matriz, listas, mapas) podem ser "
+"referenciadas pelo índice (apenas na cláusula where):"
 
-#. Tag: programlisting
-#: query_hql.xml:758
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from Order order where order.items[0].id = 1234]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:760
-#, no-c-format
 msgid ""
-"<![CDATA[select person from Person person, Calendar calendar\n"
-"where calendar.holidays['national day'] = person.birthDay\n"
-"    and person.nationality.calendar = calendar]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:762
-#, no-c-format
-msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ order.deliveredItemIndices[0] ] = item and order.id = 11]]"
-">"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:764
-#, no-c-format
-msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ maxindex(order.items) ] = item and order.id = 11]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:766
-#, fuzzy, no-c-format
-msgid ""
 "The expression inside <literal>[]</literal> can even be an arithmetic "
 "expression:"
 msgstr ""
-"A expressão entre colchetes <literal>[]</literal>, pode ser até uma "
-"expressão aritimética."
+"A expressão entre colchetes <literal>[]</literal> pode ser até uma expressão "
+"aritimética:"
 
-#. Tag: programlisting
-#: query_hql.xml:770
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ size(order.items) - 1 ] = item]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:772
-#, fuzzy, no-c-format
-msgid ""
 "HQL also provides the built-in <literal>index()</literal> function for "
 "elements of a one-to-many association or collection of values."
 msgstr ""
-"O HQL também provê a função interna <literal>index()</literal>, para "
-"elementos de associação um-pra-muitos ou coleção de valores."
+"O HQL também provê a função interna <literal>index()</literal> para "
+"elementos de associação um-para-muitos ou coleção de valores."
 
-#. Tag: programlisting
-#: query_hql.xml:777
-#, no-c-format
-msgid ""
-"<![CDATA[select item, index(item) from Order order\n"
-"    join order.items item\n"
-"where index(item) < 5]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:779
-#, fuzzy, no-c-format
-msgid "Scalar SQL functions supported by the underlying database can be used:"
-msgstr "Funções escalares SQL, suportadas pelo banco de dados subjacente."
-
-#. Tag: programlisting
-#: query_hql.xml:783
 #, no-c-format
-msgid "<![CDATA[from DomesticCat cat where upper(cat.name) like 'FRI%']]>"
+msgid "Scalar SQL functions supported by the underlying database can be used:"
 msgstr ""
+"Funções escalares SQL, suportadas pelo banco de dados subjacente podem ser "
+"usadas:"
 
 #. Tag: para
-#: query_hql.xml:785
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Consider how much longer and less readable the following query would be in "
 "SQL:"
 msgstr ""
-"Se ainda ainda não está totalmente convencido, pense o quão maior e menos "
-"legível poderia ser a query a seguir, em SQL:"
+"Se ainda não estiver totalmente convencido, pense o quão maior e menos "
+"legível poderia ser a consulta a seguir, em SQL: "
 
-#. Tag: programlisting
-#: query_hql.xml:790
-#, no-c-format
-msgid ""
-"<![CDATA[select cust\n"
-"from Product prod,\n"
-"    Store store\n"
-"    inner join store.customers cust\n"
-"where prod.name = 'widget'\n"
-"    and store.location.name in ( 'Melbourne', 'Sydney' )\n"
-"    and prod = all elements(cust.currentOrder.lineItems)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:792
 #, no-c-format
 msgid "<emphasis>Hint:</emphasis> something like"
-msgstr "<emphasis>Hint:</emphasis> something like"
+msgstr "<emphasis>Hint:</emphasis> algo como:"
 
-#. Tag: programlisting
-#: query_hql.xml:796
-#, no-c-format
-msgid ""
-"<![CDATA[SELECT cust.name, cust.address, cust.phone, cust.id, cust."
-"current_order\n"
-"FROM customers cust,\n"
-"    stores store,\n"
-"    locations loc,\n"
-"    store_customers sc,\n"
-"    product prod\n"
-"WHERE prod.name = 'widget'\n"
-"    AND store.loc_id = loc.id\n"
-"    AND loc.name IN ( 'Melbourne', 'Sydney' )\n"
-"    AND sc.store_id = store.id\n"
-"    AND sc.cust_id = cust.id\n"
-"    AND prod.id = ALL(\n"
-"        SELECT item.prod_id\n"
-"        FROM line_items item, orders o\n"
-"        WHERE item.order_id = o.id\n"
-"            AND cust.current_order = o.id\n"
-"    )]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:801
 #, no-c-format
 msgid "The order by clause"
-msgstr "A clausula order by"
+msgstr "A cláusula ordenar por"
 
 #. Tag: para
-#: query_hql.xml:803
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The list returned by a query can be ordered by any property of a returned "
 "class or components:"
 msgstr ""
-"A lista retornada pela query pode ser ordenada por qualquer propriedade da "
-"classe ou componente retornado:"
+"A lista retornada pela consulta pode ser ordenada por qualquer propriedade "
+"da classe ou componentes retornados:"
 
-#. Tag: programlisting
-#: query_hql.xml:807
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat cat\n"
-"order by cat.name asc, cat.weight desc, cat.birthdate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:809
 #, no-c-format
 msgid ""
 "The optional <literal>asc</literal> or <literal>desc</literal> indicate "
@@ -1713,100 +1173,57 @@
 "crescente ou decrescente, respectivamente."
 
 #. Tag: title
-#: query_hql.xml:816
 #, no-c-format
 msgid "The group by clause"
-msgstr "A clausula group by"
+msgstr "A cláusula agrupar por"
 
 #. Tag: para
-#: query_hql.xml:818
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A query that returns aggregate values can be grouped by any property of a "
 "returned class or components:"
 msgstr ""
-"Uma query que retorne valores agregados, podem ser agrupados por qualquer "
-"propriedade de uma classe ou componente retornado:"
+"Uma consulta que retorne valores agregados, podem ser agrupados por qualquer "
+"propriedade de uma classe ou componentes retornados:"
 
-#. Tag: programlisting
-#: query_hql.xml:822
-#, no-c-format
-msgid ""
-"<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
-"from Cat cat\n"
-"group by cat.color]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:824
-#, no-c-format
-msgid ""
-"<![CDATA[select foo.id, avg(name), max(name)\n"
-"from Foo foo join foo.names name\n"
-"group by foo.id]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:826
 #, no-c-format
 msgid "A <literal>having</literal> clause is also allowed."
-msgstr "Uma clausula <literal>having</literal> também é permitida."
+msgstr "Uma cláusula <literal>having</literal> também é permitida."
 
-#. Tag: programlisting
-#: query_hql.xml:830
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
-"from Cat cat\n"
-"group by cat.color\n"
-"having cat.color in (eg.Color.TABBY, eg.Color.BLACK)]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:832
-#, fuzzy, no-c-format
-msgid ""
 "SQL functions and aggregate functions are allowed in the <literal>having</"
 "literal> and <literal>order by</literal> clauses if they are supported by "
 "the underlying database (i.e., not in MySQL)."
 msgstr ""
-"Funções SQL e funções agregadas são permitidas nas clausulas "
+"Funções SQL e funções agregadas são permitidas nas cláusulas "
 "<literal>having</literal> e <literal>order by</literal>, se suportadas pelo "
-"banco de dados subjacente (ex: não no MySQL)."
+"banco de dados subjacentes (ex: não no MeuSQL). "
 
-#. Tag: programlisting
-#: query_hql.xml:838
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat\n"
-"from Cat cat\n"
-"    join cat.kittens kitten\n"
-"group by cat.id, cat.name, cat.other, cat.properties\n"
-"having avg(kitten.weight) > 100\n"
-"order by count(kitten) asc, sum(kitten.weight) desc]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:840
-#, fuzzy, no-c-format
-msgid ""
 "Neither the <literal>group by</literal> clause nor the <literal>order by</"
 "literal> clause can contain arithmetic expressions. Hibernate also does not "
 "currently expand a grouped entity, so you cannot write <literal>group by "
 "cat</literal> if all properties of <literal>cat</literal> are non-"
 "aggregated. You have to list all non-aggregated properties explicitly."
 msgstr ""
-"Note que, nem a clausula <literal>group by</literal> ou <literal>order by</"
-"literal>, podem conter expressões aritiméticas."
+"Note que, nem a cláusula <literal>group by</literal> ou <literal>order by</"
+"literal> podem conter expressões aritméticas. O Hibernate também não expande "
+"atualmente uma entidade agrupada, portanto você não pode escrever "
+"<literal>group by cat</literal> caso todas as propriedades do <literal>cat</"
+"literal> não estiverem agregadas. Você precisa listar claramente todas as "
+"propriedades não-agregadas. "
 
 #. Tag: title
-#: query_hql.xml:852
 #, no-c-format
 msgid "Subqueries"
-msgstr "Subqueries"
+msgstr "Subconsultas"
 
 #. Tag: para
-#: query_hql.xml:854
 #, no-c-format
 msgid ""
 "For databases that support subselects, Hibernate supports subqueries within "
@@ -1814,86 +1231,37 @@
 "aggregate function call). Even correlated subqueries (subqueries that refer "
 "to an alias in the outer query) are allowed."
 msgstr ""
-"Para bancos de dados que suportem subselects, o Hibernate suporta subqueries "
-"dentro de queries. Uma subquery precisa estar entre parênteses (normalmente "
-"uma chamada de função agregada SQL). Mesmo subqueries co-relacionadas "
-"(subqueries que fazem referência à alias de outras queries), são aceitas."
+"Para bancos de dados que suportam subseleções, o Hibernate suporta "
+"subconsultas dentro de consultas. Uma subconsulta precisa estar entre "
+"parênteses (normalmente uma chamada de função agregada SQL). Mesmo "
+"subconsultas co-relacionadas (subconsultas que fazem referência à alias de "
+"outras consultas), são aceitas."
 
-#. Tag: programlisting
-#: query_hql.xml:860
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as fatcat\n"
-"where fatcat.weight > (\n"
-"    select avg(cat.weight) from DomesticCat cat\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:862
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat as cat\n"
-"where cat.name = some (\n"
-"    select name.nickName from Name as name\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:864
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"where not exists (\n"
-"    from Cat as mate where mate.mate = cat\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:866
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat as cat\n"
-"where cat.name not in (\n"
-"    select name.nickName from Name as name\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:868
-#, no-c-format
-msgid ""
-"<![CDATA[select cat.id, (select max(kit.weight) from cat.kitten kit)\n"
-"from Cat as cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:870
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Note that HQL subqueries can occur only in the select or where clauses."
 msgstr ""
-"Note que HQL subqueries podem aparecer apenas dentro de clausulas select ou "
-"where."
+"Note que HQL subconsultas podem aparecer apenas dentro de cláusulas select "
+"ou where. "
 
 #. Tag: para
-#: query_hql.xml:874
 #, fuzzy, no-c-format
 msgid ""
 "Note that subqueries can also utilize <literal>row value constructor</"
-"literal> syntax. See <xref linkend=\"queryhql-tuple\"/> for more information."
+"literal> syntax. See <xref linkend=\"queryhql-tuple\" /> for more "
+"information."
 msgstr ""
-"Note that subqueries can also utilize <literal>row value constructor</"
-"literal> syntax. See <xref linkend=\"queryhql-tuple\"/> for more details."
+"Note que as subconsultas também podem utilizar a sintáxe <literal>row value "
+"constructor</literal>. Veja <xref linkend=\"queryhql-tuple\"/> para maiores "
+"detalhes. "
 
 #. Tag: title
-#: query_hql.xml:882
 #, no-c-format
 msgid "HQL examples"
 msgstr "Exemplos de HQL"
 
 #. Tag: para
-#: query_hql.xml:884
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate queries can be quite powerful and complex. In fact, the power of "
 "the query language is one of Hibernate's main strengths. The following "
@@ -1901,15 +1269,14 @@
 "projects. Please note that most queries you will write will be much simpler "
 "than the following examples."
 msgstr ""
-"As queries do Hibernate, podem ser muito poderosas e complexas. De fato, o "
-"poder da linguagem de querie é um dos pontos principais na distribuição do "
-"Hibernate. Aqui temos algumas queries de exemplo, muito similares a queries "
-"que usei em um projeto recente. Note que a maioria das queries que você irá "
-"escrever, são mais simples que estas."
+"As consultas do Hibernate, podem ser muito poderosas e complexas. De fato, o "
+"poder da linguagem de consulta é um dos pontos principais na distribuição do "
+"Hibernate. Aqui temos algumas consultas de exemplo, muito similares a "
+"consultas usadas em um projeto recente. Note que a maioria das consultas que "
+"você irá escrever, são mais simples que estas."
 
 #. Tag: para
-#: query_hql.xml:890
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following query returns the order id, number of items, the given minimum "
 "total value and the total value of the order for all unpaid orders for a "
@@ -1919,69 +1286,25 @@
 "<literal>PRODUCT</literal>, <literal>CATALOG</literal> and <literal>PRICE</"
 "literal> tables has four inner joins and an (uncorrelated) subselect."
 msgstr ""
-"A query a seguir retorna o id de order, numero de itens e o valor total do "
-"order para todos os orders não pagos para um freguês particular e valor "
-"total mínimo dado, ordenando os resultados por valor total. Ao determinar os "
-"preços, é usado o catalogo corrente. A query SQL resultante, usando tabelas "
-"<literal>ORDER</literal>, <literal>ORDER_LINE</literal>, <literal>PRODUCT</"
-"literal>, <literal>CATALOG</literal> e <literal>PRICE</literal>, tem quatro "
-"inner joins e um (não correlacionado) subselect."
+"A consulta a seguir retorna o id de ordenar, número de ítens e o valor total "
+"do ordenar para todos os ordenar não pagos para um cliente particular e "
+"valor total mínimo dado, ordenando os resultados por valor total. Para "
+"determinar os preços, utiliza-se o catálogo atual. A consulta SQL "
+"resultante, usando tabelas <literal>ORDER</literal>, <literal>ORDER_LINE</"
+"literal>, <literal>PRODUCT</literal>, <literal>CATALOG</literal> e "
+"<literal>PRICE</literal>, têm quatro uniões inteiras e uma subseleção (não "
+"correlacionada)."
 
-#. Tag: programlisting
-#: query_hql.xml:899
-#, no-c-format
-msgid ""
-"<![CDATA[select order.id, sum(price.amount), count(item)\n"
-"from Order as order\n"
-"    join order.lineItems as item\n"
-"    join item.product as product,\n"
-"    Catalog as catalog\n"
-"    join catalog.prices as price\n"
-"where order.paid = false\n"
-"    and order.customer = :customer\n"
-"    and price.product = product\n"
-"    and catalog.effectiveDate < sysdate\n"
-"    and catalog.effectiveDate >= all (\n"
-"        select cat.effectiveDate\n"
-"        from Catalog as cat\n"
-"        where cat.effectiveDate < sysdate\n"
-"    )\n"
-"group by order\n"
-"having sum(price.amount) > :minAmount\n"
-"order by sum(price.amount) desc]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:901
 #, no-c-format
 msgid ""
 "What a monster! Actually, in real life, I'm not very keen on subqueries, so "
 "my query was really more like this:"
 msgstr ""
-"Que monstro! Atualmente, na vida real, eu não sou muito afeiçoado a "
-"subqueries, então minha query seria mais parecida com isto:"
+"Que monstro! Na verdade, na vida real, eu não sou muito afeiçoado à "
+"subconsultas, então minha consulta seria mais parecida com isto:"
 
-#. Tag: programlisting
-#: query_hql.xml:906
-#, no-c-format
-msgid ""
-"<![CDATA[select order.id, sum(price.amount), count(item)\n"
-"from Order as order\n"
-"    join order.lineItems as item\n"
-"    join item.product as product,\n"
-"    Catalog as catalog\n"
-"    join catalog.prices as price\n"
-"where order.paid = false\n"
-"    and order.customer = :customer\n"
-"    and price.product = product\n"
-"    and catalog = :currentCatalog\n"
-"group by order\n"
-"having sum(price.amount) > :minAmount\n"
-"order by sum(price.amount) desc]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:908
 #, no-c-format
 msgid ""
 "The next query counts the number of payments in each status, excluding all "
@@ -1991,61 +1314,25 @@
 "<literal>PAYMENT</literal>, <literal>PAYMENT_STATUS</literal> and "
 "<literal>PAYMENT_STATUS_CHANGE</literal> tables."
 msgstr ""
-"A próxima query conta o número de pagamentos em cada status, tirando todos "
-"os pagamentos com status <literal>AWAITING_APPROVAL</literal>, onde a mais "
-"recente mudança de status foi feita pelo usuário corrente. Traduz-se para "
-"uma query SQL <literal>com</literal> dois inner joins e um subselect "
-"correlacionado, nas tabelas <literal>PAYMENT</literal>, "
+"A próxima consulta conta o número de pagamentos em cada status, excluindo "
+"todos os pagamentos no status <literal>AWAITING_APPROVAL</literal>, onde a "
+"mais recente mudança de status foi feita pelo usuário atual. Traduz-se para "
+"uma consulta SQL <literal>com</literal> duas uniões inteiras e uma "
+"subseleção correlacionada, nas tabelas <literal>PAYMENT</literal>, "
 "<literal>PAYMENT_STATUS</literal> e <literal>PAYMENT_STATUS_CHANGE</"
 "literal> ."
 
-#. Tag: programlisting
-#: query_hql.xml:916
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select count(payment), status.name\n"
-"from Payment as payment\n"
-"    join payment.currentStatus as status\n"
-"    join payment.statusChanges as statusChange\n"
-"where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-"    or (\n"
-"        statusChange.timeStamp = (\n"
-"            select max(change.timeStamp)\n"
-"            from PaymentStatusChange change\n"
-"            where change.payment = payment\n"
-"        )\n"
-"        and statusChange.user <> :currentUser\n"
-"    )\n"
-"group by status.name, status.sortOrder\n"
-"order by status.sortOrder]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:918
-#, fuzzy, no-c-format
-msgid ""
 "If the <literal>statusChanges</literal> collection was mapped as a list, "
 "instead of a set, the query would have been much simpler to write."
 msgstr ""
-"Se eu tivesse mapeado a Collection <literal>statusChanges</literal> como um "
-"List, ao invés de um Set, a query teria sido muito mais simples de escrever."
+"Se eu tivesse mapeado a coleção <literal>statusChanges</literal> como um "
+"List, ao invés de um Set, a consulta teria sido muito mais simples de "
+"escrever. "
 
-#. Tag: programlisting
-#: query_hql.xml:923
-#, no-c-format
-msgid ""
-"<![CDATA[select count(payment), status.name\n"
-"from Payment as payment\n"
-"    join payment.currentStatus as status\n"
-"where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-"    or payment.statusChanges[ maxIndex(payment.statusChanges) ].user <> :"
-"currentUser\n"
-"group by status.name, status.sortOrder\n"
-"order by status.sortOrder]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:925
 #, no-c-format
 msgid ""
 "The next query uses the MS SQL Server <literal>isNull()</literal> function "
@@ -2056,315 +1343,155 @@
 "<literal>ACCOUNT_TYPE</literal>, <literal>ORGANIZATION</literal> and "
 "<literal>ORG_USER</literal> tables."
 msgstr ""
-"A próxima query usa a função <literal>isNull()</literal> do MS SQL Server, "
-"para retornar todas as contas e pagamentos não pagos para a organização, "
-"para cada usuário corrente pertencente. Traduz-se para uma query SQL "
-"<literal>com</literal> três inner joins, um outer join e um subselect nas "
-"tabelas <literal>ACCOUNT</literal>, <literal>PAYMENT</literal>, "
-"<literal>PAYMENT_STATUS</literal>,<literal>ACCOUNT_TYPE</literal>, "
-"<literal>ORGANIZATION</literal> e <literal>ORG_USER</literal> ."
+"A próxima consulta usa a função <literal>isNull()</literal> do Servidor MS "
+"SQL, para retornar todas as contas e pagamentos não efetuados para a "
+"organização, para aquele que o usuário atual pertencer. Traduz-se para uma "
+"consulta SQL <literal>com</literal> três uniões inteiras, uma união externa "
+"e uma subseleção nas tabelas <literal>ACCOUNT</literal>, <literal>PAYMENT</"
+"literal>, <literal>PAYMENT_STATUS</literal>, <literal>ACCOUNT_TYPE</"
+"literal>, <literal>ORGANIZATION</literal> e <literal>ORG_USER</literal> ."
 
-#. Tag: programlisting
-#: query_hql.xml:934
-#, no-c-format
-msgid ""
-"<![CDATA[select account, payment\n"
-"from Account as account\n"
-"    left outer join account.payments as payment\n"
-"where :currentUser in elements(account.holder.users)\n"
-"    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
-"PaymentStatus.UNPAID)\n"
-"order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:936
 #, no-c-format
 msgid ""
 "For some databases, we would need to do away with the (correlated) subselect."
 msgstr ""
-"Para alguns bancos de dados, precisaremos eleminar o subselect "
-"(correlacionado)."
+"Para alguns bancos de dados, precisaremos eliminar a subseleção "
+"(correlacionada)."
 
-#. Tag: programlisting
-#: query_hql.xml:940
-#, no-c-format
-msgid ""
-"<![CDATA[select account, payment\n"
-"from Account as account\n"
-"    join account.holder.users as user\n"
-"    left outer join account.payments as payment\n"
-"where :currentUser = user\n"
-"    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
-"PaymentStatus.UNPAID)\n"
-"order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:945
 #, no-c-format
 msgid "Bulk update and delete"
-msgstr "update e delete em lote"
+msgstr "Atualização e correção em lote"
 
 #. Tag: para
-#: query_hql.xml:947
 #, fuzzy, no-c-format
 msgid ""
 "HQL now supports <literal>update</literal>, <literal>delete</literal> and "
 "<literal>insert ... select ...</literal> statements. See <xref linkend="
-"\"batch-direct\"/> for more information."
+"\"batch-direct\" /> for more information."
 msgstr ""
 "Agora o HQL suporta declarações, <literal>update</literal>, <literal>delete</"
-"literal> e <literal>insert ... select ...</literal> Veja <xref linkend="
-"\"batch-direct\"/>, para mais detalhes."
+"literal> e <literal>insert ... select ...</literal>. Veja <xref linkend="
+"\"batch-direct\"/> para mais detalhes. "
 
 #. Tag: title
-#: query_hql.xml:955
 #, no-c-format
 msgid "Tips &amp; Tricks"
 msgstr "Dicas e Truques"
 
 #. Tag: para
-#: query_hql.xml:957
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can count the number of query results without returning them:"
 msgstr ""
-"Pode-se contar o número de resultados da query, sem realmente retorna-los."
+"Pode-se contar o número de resultados da consulta, sem realmente retorná-los:"
 
-#. Tag: programlisting
-#: query_hql.xml:961
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
-"iterate().next() ).intValue()]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:963
 #, no-c-format
 msgid "To order a result by the size of a collection, use the following query:"
 msgstr ""
-"Para ordenar um resultado pelo tamanho de uma Collection, use a query a "
+"Para ordenar um resultado pelo tamanho de uma coleção, use a consulta a "
 "seguir."
 
-#. Tag: programlisting
-#: query_hql.xml:967
-#, no-c-format
-msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User as usr\n"
-"    left join usr.messages as msg\n"
-"group by usr.id, usr.name\n"
-"order by count(msg)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:969
 #, no-c-format
 msgid ""
 "If your database supports subselects, you can place a condition upon "
 "selection size in the where clause of your query:"
 msgstr ""
-"Se seu banco de dados suporta subselects, pode-se colocar uma condição sobre "
-"tamanho de seleção na cláusula where da sua query:"
+"Se seu banco de dados suporta subseleções, pode-se colocar uma condição "
+"sobre tamanho de seleção na cláusula where da sua consulta:"
 
-#. Tag: programlisting
-#: query_hql.xml:974
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from User usr where size(usr.messages) >= 1]]>"
+msgid "If your database does not support subselects, use the following query:"
 msgstr ""
+"Se seu banco de dados não suporta subseleções, use a consulta a seguir: "
 
 #. Tag: para
-#: query_hql.xml:976
-#, fuzzy, no-c-format
-msgid "If your database does not support subselects, use the following query:"
-msgstr "Se seu banco de dados não suporta subselects, use a query a seguir:"
-
-#. Tag: programlisting
-#: query_hql.xml:980
 #, no-c-format
 msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User usr.name\n"
-"    join usr.messages msg\n"
-"group by usr.id, usr.name\n"
-"having count(msg) >= 1]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:983
-#, fuzzy, no-c-format
-msgid ""
 "As this solution cannot return a <literal>User</literal> with zero messages "
 "because of the inner join, the following form is also useful:"
 msgstr ""
-"Com essa solução não se pode retornar um <literal>User</"
-"literal><literal>com</literal> sem nenhuma menssagem, por causa do \"inner "
-"join\", a forma a seguir também é útil."
+"Com essa solução não se pode retornar um <literal>User</literal> sem nenhuma "
+"menssagem, por causa da união inteira, a forma a seguir também é útil:"
 
-#. Tag: programlisting
-#: query_hql.xml:988
-#, no-c-format
-msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User as usr\n"
-"    left join usr.messages as msg\n"
-"group by usr.id, usr.name\n"
-"having count(msg) = 0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:990
 #, no-c-format
 msgid "Properties of a JavaBean can be bound to named query parameters:"
 msgstr ""
 "As propriedades de um JavaBean podem ser limitadas à parâmetros nomeados da "
-"query:"
+"consulta:"
 
-#. Tag: programlisting
-#: query_hql.xml:994
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = s.createQuery(\"from foo Foo as foo where foo.name=:name "
-"and foo.size=:size\");\n"
-"q.setProperties(fooBean); // fooBean has getName() and getSize()\n"
-"List foos = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:996
 #, no-c-format
 msgid ""
 "Collections are pageable by using the <literal>Query</literal> interface "
 "with a filter:"
 msgstr ""
-"As Collections são paginaveis, usando a interface <literal>Query</"
-"literal><literal>com</literal> um filtro:"
+"As coleções são pagináveis, usando a interface <literal>Query</literal> com "
+"um filtro:"
 
-#. Tag: programlisting
-#: query_hql.xml:1000
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = s.createFilter( collection, \"\" ); // the trivial "
-"filter\n"
-"q.setMaxResults(PAGE_SIZE);\n"
-"q.setFirstResult(PAGE_SIZE * pageNumber);\n"
-"List page = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1002
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Collection elements can be ordered or grouped using a query filter:"
 msgstr ""
-"Os elementos da Collection podem ser ordenados ou agrupados usando um filtro "
-"de query:"
+"Os elementos da coleção podem ser ordenados ou agrupados usando um filtro de "
+"consulta: "
 
-#. Tag: programlisting
-#: query_hql.xml:1006
-#, no-c-format
-msgid ""
-"<![CDATA[Collection orderedCollection = s.filter( collection, \"order by "
-"this.amount\" );\n"
-"Collection counts = s.filter( collection, \"select this.type, count(this) "
-"group by this.type\" );]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1008
 #, no-c-format
 msgid "You can find the size of a collection without initializing it:"
-msgstr "Pode-se achar o tamanho de uma Collection sem inicializa-la:"
+msgstr "Pode-se achar o tamanho de uma coleção sem inicializá-la:"
 
-#. Tag: programlisting
-#: query_hql.xml:1012
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
-"iterate().next() ).intValue();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:1017
 #, no-c-format
 msgid "Components"
-msgstr "translator-credits"
+msgstr "Componentes"
 
 #. Tag: para
-#: query_hql.xml:1019
 #, no-c-format
 msgid ""
 "Components can be used similarly to the simple value types that are used in "
 "HQL queries. They can appear in the <literal>select</literal> clause as "
 "follows:"
 msgstr ""
+"Os componentes podem ser usados de quase todas as formas que os tipos de "
+"valores simples são usados nas consultas HQL. Eles podem aparecer na "
+"cláusula <literal>select</literal>: "
 
-#. Tag: programlisting
-#: query_hql.xml:1024 query_hql.xml:1070
-#, no-c-format
-msgid "<![CDATA[select p.name from Person p]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1025
-#, no-c-format
-msgid "<![CDATA[select p.name.first from Person p]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1027
 #, no-c-format
 msgid ""
 "where the Person's name property is a component. Components can also be used "
 "in the <literal>where</literal> clause:"
 msgstr ""
+"onde a propriedade do nome da Person é um componente. Os componentes também "
+"podem ser utilizados na cláusula <literal>where</literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:1032
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name = :name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1033
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name.first = :firstName]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1035
 #, no-c-format
 msgid "Components can also be used in the <literal>order by</literal> clause:"
 msgstr ""
+"Os componentes também podem ser usados na cláusula <literal>order by</"
+"literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:1039
-#, no-c-format
-msgid "<![CDATA[from Person p order by p.name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1040
-#, no-c-format
-msgid "<![CDATA[from Person p order by p.name.first]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1042
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Another common use of components is in <link linkend=\"queryhql-tuple\">row "
 "value constructors</link>."
 msgstr ""
+"Outro uso comum dos componentes é nos construtores de valores em <xref "
+"linkend=\"queryhql-tuple\" />."
 
 #. Tag: title
-#: query_hql.xml:1048
 #, no-c-format
 msgid "Row value constructor syntax"
-msgstr ""
+msgstr "Sintáxe do construtor de valores de linha"
 
 #. Tag: para
-#: query_hql.xml:1050
 #, no-c-format
 msgid ""
 "HQL supports the use of ANSI SQL <literal>row value constructor</literal> "
@@ -2373,72 +1500,56 @@
 "generally referring to multi-valued comparisons, typically associated with "
 "components. Consider an entity Person which defines a name component:"
 msgstr ""
+"O HQL suporta o uso da sintáxe ANSI SQL <literal>row value constructor</"
+"literal>, algumas vezes chamado de sintáxe <literal>tupla</literal>, embora "
+"o banco de dados adjacente possa não suportar esta noção. Aqui nós "
+"geralmente nos referimos às comparações de valores múltiplos, tipicamente "
+"associada aos componentes. Considere uma entidade Person que define um "
+"componente de nome:"
 
-#. Tag: programlisting
-#: query_hql.xml:1057
-#, no-c-format
-msgid ""
-"<![CDATA[from Person p where p.name.first='John' and p.name."
-"last='Jingleheimer-Schmidt']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1059
 #, no-c-format
 msgid ""
 "That is valid syntax although it is a little verbose. You can make this more "
 "concise by using <literal>row value constructor</literal> syntax:"
 msgstr ""
+"Esta é uma sintáxe válida, embora um pouco verbosa. Seria ótimo tornar essa "
+"sintáxe um pouco mais concisa e utilizar a sintáxe <literal>row value "
+"constructor</literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:1064
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name=('John', 'Jingleheimer-Schmidt')]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1066
 #, no-c-format
 msgid ""
 "It can also be useful to specify this in the <literal>select</literal> "
 "clause:"
 msgstr ""
+"Pode também ser útil especificar isto na cláusula <literal>select</literal>:"
 
 #. Tag: para
-#: query_hql.xml:1072
 #, no-c-format
 msgid ""
 "Using <literal>row value constructor</literal> syntax can also be beneficial "
 "when using subqueries that need to compare against multiple values:"
 msgstr ""
+"Com o uso da sintáxe <literal>row value constructor</literal>, e que pode "
+"ser de benéfico, seria quando utilizar as subconsultas que precisem comparar "
+"com os valores múltiplos:"
 
-#. Tag: programlisting
-#: query_hql.xml:1077
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"where not ( cat.name, cat.color ) in (\n"
-"    select cat.name, cat.color from DomesticCat cat\n"
-")]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1079
 #, no-c-format
 msgid ""
 "One thing to consider when deciding if you want to use this syntax, is that "
 "the query will be dependent upon the ordering of the component sub-"
 "properties in the metadata."
 msgstr ""
+"Ao decidir se você quer usar esta sintáxe ou não, deve-se considerar o fato "
+"de que a consulta será dependente da ordenação das sub-propriedades do "
+"componente no metadados. "
 
-#~ msgid ""
-#~ "Most of the time, you will need to assign an <emphasis>alias</emphasis>, "
-#~ "since you will want to refer to the <literal>Cat</literal> in other parts "
-#~ "of the query."
-#~ msgstr ""
-#~ "Na maior parte do tempo, você precisará atribuir um <emphasis>alias</"
-#~ "emphasis>, desde que você queira se referia ao <literal>Cat</literal> em "
-#~ "outras partes da query."
+#, fuzzy
+#~ msgid "left outer join"
+#~ msgstr "<literal>left outer join</literal>"
 
-#~ msgid "or as an actual typesafe Java object,"
-#~ msgstr "ou como um objeto Java typesafe,"
+#, fuzzy
+#~ msgid "right outer join"
+#~ msgstr "<literal>right outer join</literal>"

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/query_sql.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/query_sql.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/query_sql.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,129 @@
+# translation of query_sql.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: query_sql\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-19 18:44+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: query_sql.xml:29
 #, no-c-format
 msgid "Native SQL"
-msgstr "Native SQL"
+msgstr "SQL Nativo"
 
 #. Tag: para
-#: query_sql.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also express queries in the native SQL dialect of your database. "
 "This is useful if you want to utilize database-specific features such as "
@@ -26,119 +131,90 @@
 "provides a clean migration path from a direct SQL/JDBC based application to "
 "Hibernate."
 msgstr ""
-"You may also express queries in the native SQL dialect of your database. "
-"This is useful if you want to utilize database specific features such as "
-"query hints or the <literal>CONNECT</literal> keyword in Oracle. It also "
-"provides a clean migration path from a direct SQL/JDBC based application to "
-"Hibernate."
+"Você também pode expressar consultas no dialeto SQL nativo de seu banco de "
+"dados. Isto é bastante útil para usar recursos específicos do banco de "
+"dados, assim como dicas de consultas ou a palavra chave em Oracle "
+"<literal>CONNECT</literal>. Ele também oferece um caminho de migração limpo "
+"de uma aplicação baseada em SQL/JDBC direta até o Hibernate. "
 
 #. Tag: para
-#: query_sql.xml:37
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 allows you to specify handwritten SQL, including stored "
 "procedures, for all create, update, delete, and load operations."
 msgstr ""
-"Hibernate3 allows you to specify handwritten SQL (including stored "
-"procedures) for all create, update, delete, and load operations."
+"O Hibernate3 permite que você especifique o SQL escrito à mão, incluindo "
+"procedimentos armazenados, para todas as operações de criar, atualizar, "
+"deletar e carregar."
 
 #. Tag: title
-#: query_sql.xml:41
 #, no-c-format
 msgid "Using a <literal>SQLQuery</literal>"
-msgstr "Using a <literal>SQLQuery</literal>"
+msgstr "Usando um <literal>SQLQuery</literal>"
 
 #. Tag: para
-#: query_sql.xml:43
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Execution of native SQL queries is controlled via the <literal>SQLQuery</"
 "literal> interface, which is obtained by calling <literal>Session."
 "createSQLQuery()</literal>. The following sections describe how to use this "
 "API for querying."
 msgstr ""
-"Execution of native SQL queries is controlled via the <literal>SQLQuery</"
-"literal> interface, which is obtained by calling <literal>Session."
-"createSQLQuery()</literal>. The following describes how to use this API for "
-"querying."
+"A execução de consultas SQL nativa é controlada através da interface "
+"<literal>SQLQuery</literal> que é obtido, chamando a <literal>Session."
+"createSQLQuery()</literal>. As seções abaixo descrevem como usar este API "
+"para consultas."
 
 #. Tag: title
-#: query_sql.xml:49
 #, no-c-format
 msgid "Scalar queries"
-msgstr "Scalar queries"
+msgstr "Consultas Escalares"
 
 #. Tag: para
-#: query_sql.xml:51
 #, no-c-format
 msgid "The most basic SQL query is to get a list of scalars (values)."
-msgstr "The most basic SQL query is to get a list of scalars (values)."
+msgstr "A consulta SQL mais básica é obter uma lista dos escalares (valores)."
 
-#. Tag: programlisting
-#: query_sql.xml:54
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").list();\n"
-"sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").list();\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:56
-#, fuzzy, no-c-format
-msgid ""
 "These will return a List of Object arrays (Object[]) with scalar values for "
 "each column in the CATS table. Hibernate will use ResultSetMetadata to "
 "deduce the actual order and types of the returned scalar values."
 msgstr ""
-"These will both return a List of Object arrays (Object[]) with scalar values "
-"for each column in the CATS table. Hibernate will use ResultSetMetadata to "
-"deduce the actual order and types of the returned scalar values."
+"Eles irão retornar uma matriz de Lista de Objeto (Object[]) com valores "
+"escalares para cada coluna na tabela CATS. O Hibernate usará o "
+"ResultSetMetadata para deduzir a ordem atual e tipos de valores escalares "
+"retornados."
 
 #. Tag: para
-#: query_sql.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To avoid the overhead of using <literal>ResultSetMetadata</literal>, or "
 "simply to be more explicit in what is returned, one can use "
 "<literal>addScalar()</literal>:"
 msgstr ""
-"To avoid the overhead of using <literal>ResultSetMetadata</literal> or "
-"simply to be more explicit in what is returned one can use <literal>addScalar"
-"()</literal>."
+"Para evitar o uso do <literal>ResultSetMetadata</literal> ou simplesmente "
+"para ser mais explícito em o quê é retornado, você poderá usar o "
+"<literal>addScalar()</literal>:"
 
-#. Tag: programlisting
-#: query_sql.xml:65
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-" .addScalar(\"ID\", Hibernate.LONG)\n"
-" .addScalar(\"NAME\", Hibernate.STRING)\n"
-" .addScalar(\"BIRTHDATE\", Hibernate.DATE)\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:67 query_sql.xml:113 query_sql.xml:198 query_sql.xml:349
 #, no-c-format
 msgid "This query specified:"
-msgstr "This query specified:"
+msgstr "Esta consulta especificou:"
 
 #. Tag: para
-#: query_sql.xml:71 query_sql.xml:117 query_sql.xml:353
 #, no-c-format
 msgid "the SQL query string"
-msgstr "the SQL query string"
+msgstr "A string da consulta SQL"
 
 #. Tag: para
-#: query_sql.xml:75
 #, no-c-format
 msgid "the columns and types to return"
-msgstr "the columns and types to return"
+msgstr "as colunas e tipos para retornar"
 
 #. Tag: para
-#: query_sql.xml:79
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This will return Object arrays, but now it will not use "
 "<literal>ResultSetMetadata</literal> but will instead explicitly get the ID, "
@@ -147,68 +223,53 @@
 "be returned, even though the query is using <literal>*</literal> and could "
 "return more than the three listed columns."
 msgstr ""
-"This will still return Object arrays, but now it will not use "
-"<literal>ResultSetMetdata</literal> but will instead explicitly get the ID, "
-"NAME and BIRTHDATE column as respectively a Long, String and a Short from "
-"the underlying resultset. This also means that only these three columns will "
-"be returned, even though the query is using <literal>*</literal> and could "
-"return more than the three listed columns."
+"Este ainda irá retornar as matrizes de Objeto, mas desta vez ele não usará o "
+"<literal>ResultSetMetdata</literal>, ao invés disso, obterá explicitamente a "
+"coluna de ID, NOME e DATA DE NASCIMENTO como respectivamente uma Longa, "
+"String e Curta a partir do conjunto de resultados adjacentes. Isto também "
+"significa que somente estas três colunas irão retornar, embora a consulta "
+"esteja utilizando <literal>*</literal> e possa retornar mais do que três "
+"colunas listadas. "
 
 #. Tag: para
-#: query_sql.xml:87
 #, no-c-format
 msgid ""
 "It is possible to leave out the type information for all or some of the "
 "scalars."
 msgstr ""
-"It is possible to leave out the type information for all or some of the "
-"scalars."
+"É possível deixar de fora o tipo de informação para todos ou alguns dos "
+"escalares."
 
-#. Tag: programlisting
-#: query_sql.xml:90
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-" .addScalar(\"ID\", Hibernate.LONG)\n"
-" .addScalar(\"NAME\")\n"
-" .addScalar(\"BIRTHDATE\")\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:92
-#, fuzzy, no-c-format
-msgid ""
 "This is essentially the same query as before, but now "
 "<literal>ResultSetMetaData</literal> is used to determine the type of NAME "
 "and BIRTHDATE, where as the type of ID is explicitly specified."
 msgstr ""
-"This is essentially the same query as before, but now "
-"<literal>ResultSetMetaData</literal> is used to decide the type of NAME and "
-"BIRTHDATE where as the type of ID is explicitly specified."
+"Esta é a mesma consulta de antes, mas desta vez, o "
+"<literal>ResultSetMetaData</literal> é utilizado para decidir o tipo de NOME "
+"e DATA DE NASCIMENTO onde o tipo de ID é explicitamente especificado. "
 
 #. Tag: para
-#: query_sql.xml:96
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "How the java.sql.Types returned from ResultSetMetaData is mapped to "
 "Hibernate types is controlled by the Dialect. If a specific type is not "
 "mapped, or does not result in the expected type, it is possible to customize "
 "it via calls to <literal>registerHibernateType</literal> in the Dialect."
 msgstr ""
-"How the java.sql.Types returned from ResultSetMetaData is mapped to "
-"Hibernate types is controlled by the Dialect. If a specific type is not "
-"mapped or does not result in the expected type it is possible to customize "
-"it via calls to <literal>registerHibernateType</literal> in the Dialect."
+"Como o java.sql.Types retornados do ResultSetMetadata é mapeado para os "
+"tipos Hibernate, ele é controlado pelo Dialeto. Se um tipo específico não é "
+"mapeado ou não resulta no tipo esperado, é possível padronizá-lo através de "
+"chamadas para <literal>registerHibernateType</literal> no Dialeto. "
 
 #. Tag: title
-#: query_sql.xml:104
 #, no-c-format
 msgid "Entity queries"
-msgstr "Entity queries"
+msgstr "Consultas de Entidade"
 
 #. Tag: para
-#: query_sql.xml:106
 #, no-c-format
 msgid ""
 "The above queries were all about returning scalar values, basically "
@@ -216,41 +277,28 @@
 "get entity objects from a native sql query via <literal>addEntity()</"
 "literal>."
 msgstr ""
-"The above queries were all about returning scalar values, basically "
-"returning the \"raw\" values from the resultset. The following shows how to "
-"get entity objects from a native sql query via <literal>addEntity()</"
-"literal>."
+"As consultas acima foram todas sobre o retorno de valores escalares, "
+"basicamente retornando os valores \"não processados\" do conjunto de "
+"resultados. A seguir, mostramos como obter objetos de entidade da consulta "
+"sql nativa através do <literal>addEntity()</literal>."
 
-#. Tag: programlisting
-#: query_sql.xml:111
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").addEntity(Cat.class);\n"
-"sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").addEntity(Cat."
-"class);\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:121
 #, no-c-format
 msgid "the entity returned by the query"
-msgstr "the entity returned by the query"
+msgstr "A entidade retornada por uma consulta"
 
 #. Tag: para
-#: query_sql.xml:125
 #, no-c-format
 msgid ""
 "Assuming that Cat is mapped as a class with the columns ID, NAME and "
 "BIRTHDATE the above queries will both return a List where each element is a "
 "Cat entity."
 msgstr ""
-"Assuming that Cat is mapped as a class with the columns ID, NAME and "
-"BIRTHDATE the above queries will both return a List where each element is a "
-"Cat entity."
+"Considerando que o Cat esteja mapeado como uma classe com colunas ID,NOME e "
+"DATA DE NASCIMENTO, as consultas acima irão devolver uma Lista onde cada "
+"elemento é uma entidade de Cat."
 
 #. Tag: para
-#: query_sql.xml:129
 #, no-c-format
 msgid ""
 "If the entity is mapped with a <literal>many-to-one</literal> to another "
@@ -260,36 +308,24 @@
 "but we prefer to be explicit as in the following example for a <literal>many-"
 "to-one</literal> to a <literal>Dog</literal>:"
 msgstr ""
-"If the entity is mapped with a <literal>many-to-one</literal> to another "
-"entity it is required to also return this when performing the native query, "
-"otherwise a database specific \"column not found\" error will occur. The "
-"additional columns will automatically be returned when using the * notation, "
-"but we prefer to be explicit as in the following example for a <literal>many-"
-"to-one</literal> to a <literal>Dog</literal>:"
+"Se a entidade estiver mapeada com um <literal>muitos-para-um</literal> para "
+"outra entidade, requer-se que devolva também este ao desempenhar a consulta "
+"nativa, senão ocorrerá um erro de banco de dados específico \"coluna não "
+"encontrada\". As colunas adicionais serão automaticamente retornadas ao usar "
+"a anotação, mas preferimos ser explícitos como no seguinte exemplo para "
+"uma<literal>muitos-para-um</literal> para um <literal>Dog</literal>:"
 
-#. Tag: programlisting
-#: query_sql.xml:137
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, DOG_ID FROM CATS"
-"\").addEntity(Cat.class);\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:139
 #, no-c-format
 msgid "This will allow cat.getDog() to function properly."
-msgstr "This will allow cat.getDog() to function properly."
+msgstr "Isto irá permitir que o cat.getDog() funcione de forma apropriada"
 
 #. Tag: title
-#: query_sql.xml:143
 #, no-c-format
 msgid "Handling associations and collections"
-msgstr "Handling associations and collections"
+msgstr "Manuseio de associações e coleções"
 
 #. Tag: para
-#: query_sql.xml:145
 #, no-c-format
 msgid ""
 "It is possible to eagerly join in the <literal>Dog</literal> to avoid the "
@@ -297,26 +333,14 @@
 "<literal>addJoin()</literal> method, which allows you to join in an "
 "association or collection."
 msgstr ""
-"It is possible to eagerly join in the <literal>Dog</literal> to avoid the "
-"possible extra roundtrip for initializing the proxy. This is done via the "
-"<literal>addJoin()</literal> method, which allows you to join in an "
-"association or collection."
+"É possível realizar a recuperação adiantada no <literal>Dog</literal> para "
+"evitar uma viagem extra por inicializar o proxy. Isto é feito através do "
+"método <literal>addJoin()</literal>que permite que você se una à associação "
+"ou coleção."
 
-#. Tag: programlisting
-#: query_sql.xml:150
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT c.ID, NAME, BIRTHDATE, DOG_ID, D_ID, "
-"D_NAME FROM CATS c, DOGS d WHERE c.DOG_ID = d.D_ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addJoin(\"cat.dog\");\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:152
-#, fuzzy, no-c-format
-msgid ""
 "In this example, the returned <literal>Cat</literal>'s will have their "
 "<literal>dog</literal> property fully initialized without any extra "
 "roundtrip to the database. Notice that you added an alias name (\"cat\") to "
@@ -324,83 +348,58 @@
 "do the same eager joining for collections, e.g. if the <literal>Cat</"
 "literal> had a one-to-many to <literal>Dog</literal> instead."
 msgstr ""
-"In this example the returned <literal>Cat</literal>'s will have their "
-"<literal>dog</literal> property fully initialized without any extra "
-"roundtrip to the database. Notice that we added a alias name (\"cat\") to be "
-"able to specify the target property path of the join. It is possible to do "
-"the same eager joining for collections, e.g. if the <literal>Cat</literal> "
-"had a one-to-many to <literal>Dog</literal> instead."
+"Neste exemplo, a devolução do <literal>Cat</literal> terá sua propriedade "
+"<literal>dog</literal> totalmente inicializada sem nenhuma viagem extra ao "
+"banco de dados. Note que adicionamos um nome alias (\"cat\") para poder "
+"especificar o caminho da propriedade alvo na união. É possível fazer a mesma "
+"união para coleções, ex.: se ao invés disso, o <literal>Cat</literal> "
+"tivesse um-para-muitos para <literal>Dog</literal>."
 
-#. Tag: programlisting
-#: query_sql.xml:160
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, D_ID, D_NAME, "
-"CAT_ID FROM CATS c, DOGS d WHERE c.ID = d.CAT_ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addJoin(\"cat.dogs\");\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:162
-#, fuzzy, no-c-format
-msgid ""
 "At this stage you are reaching the limits of what is possible with native "
 "queries, without starting to enhance the sql queries to make them usable in "
 "Hibernate. Problems can arise when returning multiple entities of the same "
 "type or when the default alias/column names are not enough."
 msgstr ""
-"At this stage we are reaching the limits of what is possible with native "
-"queries without starting to enhance the sql queries to make them usable in "
-"Hibernate; the problems starts to arise when returning multiple entities of "
-"the same type or when the default alias/column names are not enough."
+"Neste estágio, estamos chegando no limite do que é possível fazer com as "
+"consultas nativas sem começar a destacar as colunas sql para torná-las útil "
+"no Hibernate. Os problemas começam a surgir quando se retorna entidades "
+"múltiplas do mesmo tipo ou quando o padrão de nomes de alias/coluna não são "
+"suficientes. "
 
 #. Tag: title
-#: query_sql.xml:170
 #, no-c-format
 msgid "Returning multiple entities"
-msgstr "Returning multiple entities"
+msgstr "Retorno de entidades múltiplas"
 
 #. Tag: para
-#: query_sql.xml:172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Until now, the result set column names are assumed to be the same as the "
 "column names specified in the mapping document. This can be problematic for "
 "SQL queries that join multiple tables, since the same column names can "
 "appear in more than one table."
 msgstr ""
-"Until now the result set column names are assumed to be the same as the "
-"column names specified in the mapping document. This can be problematic for "
-"SQL queries which join multiple tables, since the same column names may "
-"appear in more than one table."
+"Até aqui, os nomes de colunas do conjunto de resultados são considerados "
+"como sendo os mesmos que os nomes de colunas especificados no documento de "
+"mapeamento. Isto pode ser problemático para as consultas SQL, que une "
+"tabelas múltiplas, uma vez que os mesmos nomes de colunas podem aparecer em "
+"mais de uma tabela. "
 
 #. Tag: para
-#: query_sql.xml:177
 #, no-c-format
 msgid ""
 "Column alias injection is needed in the following query (which most likely "
 "will fail):"
 msgstr ""
-"Column alias injection is needed in the following query (which most likely "
-"will fail):"
+"É necessário uma injeção de alias de coluna na seguinte consulta (a qual é "
+"bem provável que falhe):"
 
-#. Tag: programlisting
-#: query_sql.xml:180
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT c.*, m.*  FROM CATS c, CATS m WHERE c."
-"MOTHER_ID = c.ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addEntity(\"mother\", Cat.class)\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:184
-#, fuzzy, no-c-format
-msgid ""
 "The query was intended to return two Cat instances per row: a cat and its "
 "mother. The query will, however, fail because there is a conflict of names; "
 "the instances are mapped to the same column names. Also, on some databases "
@@ -408,49 +407,34 @@
 "NAME\", etc. which are not equal to the columns specified in the mappings "
 "(\"ID\" and \"NAME\")."
 msgstr ""
-"The intention for this query is to return two Cat instances per row, a cat "
-"and its mother. This will fail since there is a conflict of names since they "
-"are mapped to the same column names and on some databases the returned "
-"column aliases will most likely be on the form \"c.ID\", \"c.NAME\", etc. "
-"which are not equal to the columns specificed in the mappings (\"ID\" and "
-"\"NAME\")."
+"A intenção para esta consulta é retornar duas instâncias Cat por linha: um "
+"cat e sua mãe. Isto irá falhar pois existe um conflito de nomes, são "
+"mapeados aos mesmos nomes de colunas e em alguns bancos de dados os aliases "
+"de colunas retornadas estarão, muito provavelmente, na forma de \"c.ID\", "
+"\"c.NOME\", etc., os quais não são iguais às colunas especificadas no "
+"mapeamento (\"ID\" e \"NOME\"). "
 
 #. Tag: para
-#: query_sql.xml:193
 #, no-c-format
 msgid "The following form is not vulnerable to column name duplication:"
-msgstr "The following form is not vulnerable to column name duplication:"
+msgstr "A seguinte forma não é vulnerável à duplicação do nome de coluna:"
 
-#. Tag: programlisting
-#: query_sql.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT {cat.*}, {mother.*}  FROM CATS c, CATS "
-"m WHERE c.MOTHER_ID = c.ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addEntity(\"mother\", Cat.class)\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:202
 #, no-c-format
 msgid ""
 "the SQL query string, with placeholders for Hibernate to inject column "
 "aliases"
 msgstr ""
-"the SQL query string, with placeholders for Hibernate to inject column "
-"aliases"
+"a string da consulta SQL, com espaço reservado para Hibernate para injetar "
+"aliases de coluna."
 
 #. Tag: para
-#: query_sql.xml:207
 #, no-c-format
 msgid "the entities returned by the query"
-msgstr "the entities returned by the query"
+msgstr "as entidades retornadas pela consulta"
 
 #. Tag: para
-#: query_sql.xml:211
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The {cat.*} and {mother.*} notation used above is a shorthand for \"all "
 "properties\". Alternatively, you can list the columns explicitly, but even "
@@ -460,605 +444,394 @@
 "from a different table (cat_log) to the one declared in the mapping "
 "metadata. You can even use the property aliases in the where clause."
 msgstr ""
-"The {cat.*} and {mother.*} notation used above is a shorthand for \"all "
-"properties\". Alternatively, you may list the columns explicity, but even in "
-"this case we let Hibernate inject the SQL column aliases for each property. "
-"The placeholder for a column alias is just the property name qualified by "
-"the table alias. In the following example, we retrieve Cats and their "
-"mothers from a different table (cat_log) to the one declared in the mapping "
-"metadata. Notice that we may even use the property aliases in the where "
-"clause if we like."
+"A anotação {cat.*} e {mãe.*} usada acima, é um atalho para \"todas as "
+"propriedades\". De forma alternativa, você pode listar as colunas "
+"explicitamente, mas até neste caso nós deixamos o Hibernate injetar os "
+"aliases de coluna SQL para cada propriedade. O espaço reservado para um "
+"alias de coluna é simplesmente o nome de propriedade qualificado pelo alias "
+"de tabela. No seguinte exemplo, recuperamos os Cats e suas mães de uma "
+"tabela diferente (cat_log) para aquele declarado no metadado de mapeamentos. "
+"Note que podemos até usar os aliases de propriedade na cláusula where se "
+"quisermos."
 
-#. Tag: programlisting
-#: query_sql.xml:220
-#, no-c-format
-msgid ""
-"<![CDATA[String sql = \"SELECT ID as {c.id}, NAME as {c.name}, \" + \n"
-"         \"BIRTHDATE as {c.birthDate}, MOTHER_ID as {c.mother}, {mother.*} "
-"\" +\n"
-"         \"FROM CAT_LOG c, CAT_LOG m WHERE {c.mother} = c.ID\";\n"
-"\n"
-"List loggedCats = sess.createSQLQuery(sql)\n"
-"        .addEntity(\"cat\", Cat.class)\n"
-"        .addEntity(\"mother\", Cat.class).list()\n"
-"]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:223
 #, no-c-format
 msgid "Alias and property references"
-msgstr "Alias and property references"
+msgstr "Alias e referências de propriedades"
 
 #. Tag: para
-#: query_sql.xml:225
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In most cases the above alias injection is needed. For queries relating to "
 "more complex mappings, like composite properties, inheritance "
 "discriminators, collections etc., you can use specific aliases that allow "
 "Hibernate to inject the proper aliases."
 msgstr ""
-"For most cases the above alias injection is needed, but for queries relating "
-"to more complex mappings like composite properties, inheritance "
-"discriminators, collections etc. there are some specific aliases to use to "
-"allow Hibernate to inject the proper aliases."
+"Para a maioria dos casos, necessita-se da injeção de alias acima. Para "
+"consultas relatadas aos mapeamentos mais complexos, como as propriedades "
+"compostas, discriminadores de herança, coleções, etc., você pode usar "
+"aliases específicos que permitem o Hibernate injetar os aliases apropriados."
 
 #. Tag: para
-#: query_sql.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table shows the different ways you can use the alias "
 "injection. Please note that the alias names in the result are simply "
 "examples; each alias will have a unique and probably different name when "
 "used."
 msgstr ""
-"The following table shows the different possibilities of using the alias "
-"injection. Note: the alias names in the result are examples, each alias will "
-"have a unique and probably different name when used."
+"As seguintes tabelas mostram as diferentes formas de usar uma injeção de "
+"alias. Por favor note que os nomes de alias no resultado são exemplos, cada "
+"alias terá um nome único e provavelmente diferente quando usado."
 
 #. Tag: title
-#: query_sql.xml:236
 #, no-c-format
 msgid "Alias injection names"
-msgstr "Alias injection names"
+msgstr "Nomes de injeção de alias"
 
 #. Tag: entry
-#: query_sql.xml:247
 #, no-c-format
 msgid "Description"
-msgstr "Description"
+msgstr "Descrição"
 
 #. Tag: entry
-#: query_sql.xml:249
 #, no-c-format
 msgid "Syntax"
-msgstr "Syntax"
+msgstr "Sintáxe"
 
 #. Tag: entry
-#: query_sql.xml:251
 #, no-c-format
 msgid "Example"
-msgstr "Example"
+msgstr "Exemplo"
 
 #. Tag: entry
-#: query_sql.xml:257
 #, no-c-format
 msgid "A simple property"
-msgstr "A simple property"
+msgstr "Uma propriedade simples"
 
-#. Tag: literal
-#: query_sql.xml:259
-#, no-c-format
-msgid "{[aliasname].[propertyname]"
-msgstr "{[aliasname].[propertyname]"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].[propertyname]</literal>"
+msgstr "<literal>{[aliasname].[propertyname]</literal>"
 
-#. Tag: literal
-#: query_sql.xml:261
-#, no-c-format
-msgid "A_NAME as {item.name}"
-msgstr "A_NAME as {item.name}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>A_NAME as {item.name}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:265
 #, no-c-format
 msgid "A composite property"
-msgstr "A composite property"
+msgstr "Uma propriedade composta"
 
-#. Tag: literal
-#: query_sql.xml:267
-#, no-c-format
-msgid "{[aliasname].[componentname].[propertyname]}"
-msgstr "{[aliasname].[componentname].[propertyname]}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].[componentname].[propertyname]}</literal>"
+msgstr "<literal>{[aliasname].[componentname].[propertyname]}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:269
-#, no-c-format
-msgid "CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}"
-msgstr "CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}</"
+"literal>"
+msgstr ""
+"<literal>CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}</"
+"literal>"
 
 #. Tag: entry
-#: query_sql.xml:274
 #, no-c-format
 msgid "Discriminator of an entity"
-msgstr "Discriminator of an entity"
+msgstr "Discriminador de uma entidade"
 
-#. Tag: literal
-#: query_sql.xml:276
-#, no-c-format
-msgid "{[aliasname].class}"
-msgstr "{[aliasname].class}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].class}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:278
-#, no-c-format
-msgid "DISC as {item.class}"
-msgstr "DISC as {item.class}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>DISC as {item.class}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:282
 #, no-c-format
 msgid "All properties of an entity"
-msgstr "All properties of an entity"
+msgstr "Todas as propriedades de uma entidade"
 
-#. Tag: literal
-#: query_sql.xml:284 query_sql.xml:332
-#, no-c-format
-msgid "{[aliasname].*}"
-msgstr "{[aliasname].*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].*}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:286
+#. Tag: entry
 #, no-c-format
-msgid "{item.*}"
-msgstr "{item.*}"
+msgid "<literal>{item.*}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:290
 #, no-c-format
 msgid "A collection key"
-msgstr "A collection key"
+msgstr "Uma chave de coleção"
 
-#. Tag: literal
-#: query_sql.xml:292
-#, no-c-format
-msgid "{[aliasname].key}"
-msgstr "{[aliasname].key}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].key}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:294
-#, no-c-format
-msgid "ORGID as {coll.key}"
-msgstr "ORGID as {coll.key}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>ORGID as {coll.key}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:298
 #, no-c-format
 msgid "The id of an collection"
-msgstr "The id of an collection"
+msgstr "O id de uma coleção"
 
-#. Tag: literal
-#: query_sql.xml:300
-#, no-c-format
-msgid "{[aliasname].id}"
-msgstr "{[aliasname].id}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].id}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:302
-#, no-c-format
-msgid "EMPID as {coll.id}"
-msgstr "EMPID as {coll.id}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>EMPID as {coll.id}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:306
 #, no-c-format
 msgid "The element of an collection"
-msgstr "The element of an collection"
+msgstr "O elemento de uma coleção"
 
-#. Tag: literal
-#: query_sql.xml:308
-#, no-c-format
-msgid "{[aliasname].element}"
-msgstr "{[aliasname].element}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:310
-#, no-c-format
-msgid "XID as {coll.element}"
-msgstr "XID as {coll.element}"
-
 #. Tag: entry
-#: query_sql.xml:314
 #, fuzzy, no-c-format
-msgid "property of the element in the collection"
-msgstr "roperty of the element in the collection"
+msgid "<literal>XID as {coll.element}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:316
+#. Tag: entry
 #, no-c-format
-msgid "{[aliasname].element.[propertyname]}"
-msgstr "{[aliasname].element.[propertyname]}"
+msgid "property of the element in the collection"
+msgstr "propriedade de elemento na coleção "
 
-#. Tag: literal
-#: query_sql.xml:318
-#, no-c-format
-msgid "NAME as {coll.element.name}"
-msgstr "NAME as {coll.element.name}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element.[propertyname]}</literal>"
+msgstr "<literal>{[aliasname].element.[propertyname]}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:322
+#, fuzzy, no-c-format
+msgid "<literal>NAME as {coll.element.name}</literal>"
+msgstr "<literal>NAME as {coll.element.name}</literal>"
+
+#. Tag: entry
 #, no-c-format
 msgid "All properties of the element in the collection"
-msgstr "All properties of the element in the collection"
+msgstr "Todas as propriedades de elemento na coleção"
 
-#. Tag: literal
-#: query_sql.xml:324
-#, no-c-format
-msgid "{[aliasname].element.*}"
-msgstr "{[aliasname].element.*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element.*}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:326
-#, no-c-format
-msgid "{coll.element.*}"
-msgstr "{coll.element.*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{coll.element.*}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:330
 #, no-c-format
 msgid "All properties of the the collection"
-msgstr "All properties of the the collection"
+msgstr "Todas as propriedades da coleção"
 
-#. Tag: literal
-#: query_sql.xml:334
+#. Tag: entry
 #, no-c-format
-msgid "{coll.*}"
-msgstr "{coll.*}"
+msgid "<literal>{coll.*}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: title
-#: query_sql.xml:343
 #, no-c-format
 msgid "Returning non-managed entities"
-msgstr "Returning non-managed entities"
+msgstr "Retorno de entidades não gerenciadas"
 
 #. Tag: para
-#: query_sql.xml:345
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to apply a ResultTransformer to native SQL queries, allowing "
 "it to return non-managed entities."
 msgstr ""
-"It is possible to apply a ResultTransformer to native sql queries. Allowing "
-"it to e.g. return non-managed entities."
+"É possível aplicar um ResultTransformer para consultas sql nativas, "
+"permitindo que o retorno de entidades não gerenciadas."
 
-#. Tag: programlisting
-#: query_sql.xml:347
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT NAME, BIRTHDATE FROM CATS\")\n"
-"        .setResultTransformer(Transformers.aliasToBean(CatDTO.class))]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:357
 #, no-c-format
 msgid "a result transformer"
-msgstr "a result transformer"
+msgstr "um transformador de resultado"
 
 #. Tag: para
-#: query_sql.xml:361
 #, no-c-format
 msgid ""
 "The above query will return a list of <literal>CatDTO</literal> which has "
 "been instantiated and injected the values of NAME and BIRTHNAME into its "
 "corresponding properties or fields."
 msgstr ""
-"The above query will return a list of <literal>CatDTO</literal> which has "
-"been instantiated and injected the values of NAME and BIRTHNAME into its "
-"corresponding properties or fields."
+"A consulta acima irá devolver uma lista de <literal>CatDTO</literal> que foi "
+"instanciada e injetada com valores dos comandos NAME e BIRTHDATE em suas "
+"propriedades correspondentes ou campos."
 
 #. Tag: title
-#: query_sql.xml:368
 #, no-c-format
 msgid "Handling inheritance"
-msgstr "Handling inheritance"
+msgstr "Manuseio de herança"
 
 #. Tag: para
-#: query_sql.xml:370
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Native SQL queries which query for entities that are mapped as part of an "
 "inheritance must include all properties for the baseclass and all its "
 "subclasses."
 msgstr ""
-"Native sql queries which query for entities that is mapped as part of an "
-"inheritance must include all properties for the baseclass and all it "
-"subclasses."
+"As consultas sql nativas, as quais consultam entidades mapeadas como parte "
+"de uma herança, devem incluir todas as propriedades na classe base e todas "
+"as suas subclasses. "
 
 #. Tag: title
-#: query_sql.xml:376
 #, no-c-format
 msgid "Parameters"
-msgstr "Parameters"
+msgstr "Parâmetros"
 
 #. Tag: para
-#: query_sql.xml:378
-#, fuzzy, no-c-format
-msgid "Native SQL queries support positional as well as named parameters:"
-msgstr "Native sql queries support positional as well as named parameters:"
-
-#. Tag: programlisting
-#: query_sql.xml:381
 #, no-c-format
-msgid ""
-"<![CDATA[Query query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME "
-"like ?\").addEntity(Cat.class);\n"
-"List pusList = query.setString(0, \"Pus%\").list();\n"
-"     \n"
-"query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME like :name\")."
-"addEntity(Cat.class);\n"
-"List pusList = query.setString(\"name\", \"Pus%\").list();          ]]>"
+msgid "Native SQL queries support positional as well as named parameters:"
 msgstr ""
+"Consultas sql Nativas suportam parâmetros posicionais assim como parâmetros "
+"nomeados:"
 
 #. Tag: title
-#: query_sql.xml:389
 #, no-c-format
 msgid "Named SQL queries"
-msgstr "Named SQL queries"
+msgstr "Consultas SQL Nomeadas"
 
 #. Tag: para
-#: query_sql.xml:391
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Named SQL queries can be defined in the mapping document and called in "
 "exactly the same way as a named HQL query. In this case, you do "
 "<emphasis>not</emphasis> need to call <literal>addEntity()</literal>."
 msgstr ""
-"Named SQL queries may be defined in the mapping document and called in "
-"exactly the same way as a named HQL query. In this case, we do "
-"<emphasis>not</emphasis> need to call <literal>addEntity()</literal>."
+"Consultas SQL Nomeadas podem ser definidas no documento de mapeamento e "
+"chamadas exatamente da mesma forma que uma consulta HQL nomeada. Neste caso "
+"nós <emphasis>não</emphasis> precisamos chamar o <literal>addEntity()</"
+"literal>."
 
-#. Tag: programlisting
-#: query_sql.xml:396
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"persons\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex}\n"
-"    FROM PERSON person\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_sql.xml:398
-#, no-c-format
-msgid ""
-"<![CDATA[List people = sess.getNamedQuery(\"persons\")\n"
-"    .setString(\"namePattern\", namePattern)\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:400
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>&lt;return-join&gt;</literal> element is use to join "
 "associations and the <literal>&lt;load-collection&gt;</literal> element is "
 "used to define queries which initialize collections,"
 msgstr ""
-"The <literal>&lt;return-join&gt;</literal> and <literal>&lt;load-"
-"collection&gt;</literal> elements are used to join associations and define "
-"queries which initialize collections, respectively."
+"Os elementos <literal>&lt;return-join&gt;</literal> e <literal>&lt;load-"
+"collection&gt;</literal> são usados para unir associações e definir "
+"consultas que inicializam coleções, "
 
-#. Tag: programlisting
-#: query_sql.xml:404
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"personsWith\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex},\n"
-"           address.STREET AS {address.street},\n"
-"           address.CITY AS {address.city},\n"
-"           address.STATE AS {address.state},\n"
-"           address.ZIP AS {address.zip}\n"
-"    FROM PERSON person\n"
-"    JOIN ADDRESS address\n"
-"        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:406
 #, no-c-format
 msgid ""
 "A named SQL query may return a scalar value. You must declare the column "
 "alias and Hibernate type using the <literal>&lt;return-scalar&gt;</literal> "
 "element:"
 msgstr ""
-"A named SQL query may return a scalar value. You must declare the column "
-"alias and Hibernate type using the <literal>&lt;return-scalar&gt;</literal> "
-"element:"
+"Uma consulta SQL nomeada pode devolver um valor escalar. Você deve declarar "
+"um alias de coluna e um tipo Hibernate usando o elemento <literal>&lt;return-"
+"scalar&gt;</literal>:"
 
-#. Tag: programlisting
-#: query_sql.xml:410
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-"    <return-scalar column=\"name\" type=\"string\"/>\n"
-"    <return-scalar column=\"age\" type=\"long\"/>\n"
-"    SELECT p.NAME AS name,\n"
-"           p.AGE AS age,\n"
-"    FROM PERSON p WHERE p.NAME LIKE 'Hiber%'\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:412
-#, fuzzy, no-c-format
-msgid ""
 "You can externalize the resultset mapping information in a <literal>&lt;"
 "resultset&gt;</literal> element which will allow you to either reuse them "
 "across several named queries or through the <literal>setResultSetMapping()</"
 "literal> API."
 msgstr ""
-"You can externalize the resultset mapping informations in a <literal>&lt;"
-"resultset&gt;</literal> element to either reuse them accross several named "
-"queries or through the <literal>setResultSetMapping()</literal> API."
+"Você pode externar as informações de mapeamento de conjunto de resultado em "
+"um elemento <literal>&lt;resultset&gt;</literal> tanto para reusá-los em "
+"diversas consultas nomeadas quanto através da API "
+"<literal>setResultSetMapping()</literal>."
 
-#. Tag: programlisting
-#: query_sql.xml:417
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<resultset name=\"personAddress\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
-"</resultset>\n"
-"\n"
-"<sql-query name=\"personsWith\" resultset-ref=\"personAddress\">\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex},\n"
-"           address.STREET AS {address.street},\n"
-"           address.CITY AS {address.city},\n"
-"           address.STATE AS {address.state},\n"
-"           address.ZIP AS {address.zip}\n"
-"    FROM PERSON person\n"
-"    JOIN ADDRESS address\n"
-"        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:419
-#, fuzzy, no-c-format
-msgid ""
 "You can, alternatively, use the resultset mapping information in your hbm "
 "files directly in java code."
 msgstr ""
-"You can alternatively use the resultset mapping information in your hbm "
-"files directly in java code."
+"Você pode também, como forma alternativa, usar a informação de mapeamento de "
+"conjunto de resultado em seus arquivos hbm em código de java. "
 
-#. Tag: programlisting
-#: query_sql.xml:422
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createSQLQuery(\n"
-"        \"select {cat.*}, {kitten.*} from cats cat, cats kitten where kitten."
-"mother = cat.id\"\n"
-"    )\n"
-"    .setResultSetMapping(\"catAndKitten\")\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:425
 #, no-c-format
 msgid "Using return-property to explicitly specify column/alias names"
-msgstr "Using return-property to explicitly specify column/alias names"
+msgstr ""
+"Utilizando a propriedade retorno para especificar explicitamente os nomes de "
+"colunas/alias"
 
 #. Tag: para
-#: query_sql.xml:428
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can explicitly tell Hibernate what column aliases to use with "
 "<literal>&lt;return-property&gt;</literal>, instead of using the <literal>{}"
 "</literal>-syntax to let Hibernate inject its own aliases.For example:"
 msgstr ""
-"With <literal>&lt;return-property&gt;</literal> you can explicitly tell "
-"Hibernate what column aliases to use, instead of using the <literal>{}</"
-"literal>-syntax to let Hibernate inject its own aliases."
+"Com a <literal>&lt;return-property&gt;</literal> você pode informar "
+"explicitamente, quais aliases de coluna utilizar, ao invés de usar a sintáxe "
+"<literal>{}</literal> para deixar o Hibernate injetar seus próprios aliases. "
+"Por exemplo:"
 
-#. Tag: programlisting
-#: query_sql.xml:433
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-"    <return alias=\"person\" class=\"eg.Person\">\n"
-"        <return-property name=\"name\" column=\"myName\"/>\n"
-"        <return-property name=\"age\" column=\"myAge\"/>\n"
-"        <return-property name=\"sex\" column=\"mySex\"/>\n"
-"    </return>\n"
-"    SELECT person.NAME AS myName,\n"
-"           person.AGE AS myAge,\n"
-"           person.SEX AS mySex,\n"
-"    FROM PERSON person WHERE person.NAME LIKE :name\n"
-"</sql-query>\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:435
-#, fuzzy, no-c-format
-msgid ""
 "<literal>&lt;return-property&gt;</literal> also works with multiple columns. "
 "This solves a limitation with the <literal>{}</literal>-syntax which cannot "
 "allow fine grained control of multi-column properties."
 msgstr ""
-"<literal>&lt;return-property&gt;</literal> also works with multiple columns. "
-"This solves a limitation with the <literal>{}</literal>-syntax which can not "
-"allow fine grained control of multi-column properties."
+"<literal>&lt;return-property&gt;</literal> também funciona com colunas "
+"múltiplas. Isto resolve a limitação com a sintáxe <literal>{}</literal> que "
+"não pode permitir controle granulado fino de muitas propriedades de colunas "
+"múltiplas. "
 
-#. Tag: programlisting
-#: query_sql.xml:440
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"organizationCurrentEmployments\">\n"
-"    <return alias=\"emp\" class=\"Employment\">\n"
-"        <return-property name=\"salary\">\n"
-"            <return-column name=\"VALUE\"/>\n"
-"            <return-column name=\"CURRENCY\"/>\n"
-"        </return-property>\n"
-"        <return-property name=\"endDate\" column=\"myEndDate\"/>\n"
-"    </return>\n"
-"        SELECT EMPLOYEE AS {emp.employee}, EMPLOYER AS {emp.employer},\n"
-"        STARTDATE AS {emp.startDate}, ENDDATE AS {emp.endDate},\n"
-"        REGIONCODE as {emp.regionCode}, EID AS {emp.id}, VALUE, CURRENCY\n"
-"        FROM EMPLOYMENT\n"
-"        WHERE EMPLOYER = :id AND ENDDATE IS NULL\n"
-"        ORDER BY STARTDATE ASC\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:442
-#, fuzzy, no-c-format
-msgid ""
 "In this example <literal>&lt;return-property&gt;</literal> was used in "
 "combination with the <literal>{}</literal>-syntax for injection. This allows "
 "users to choose how they want to refer column and properties."
 msgstr ""
-"Notice that in this example we used <literal>&lt;return-property&gt;</"
-"literal> in combination with the <literal>{}</literal>-syntax for injection. "
-"Allowing users to choose how they want to refer column and properties."
+"Observe que neste exemplo nós usamos <literal>&lt;return-property&gt;</"
+"literal> combinado à síntáxe <literal>{}</literal> para injeção. Permite que "
+"os usuários escolham como eles querem se referir à coluna e às "
+"propriedades.  "
 
 #. Tag: para
-#: query_sql.xml:447
 #, no-c-format
 msgid ""
 "If your mapping has a discriminator you must use <literal>&lt;return-"
 "discriminator&gt;</literal> to specify the discriminator column."
 msgstr ""
-"If your mapping has a discriminator you must use <literal>&lt;return-"
-"discriminator&gt;</literal> to specify the discriminator column."
+"Se seu mapeamento possuir um discriminador, você deve usar <literal>&lt;"
+"return-discriminator&gt;</literal> para especificar a coluna do "
+"discriminador."
 
 #. Tag: title
-#: query_sql.xml:453
 #, no-c-format
 msgid "Using stored procedures for querying"
-msgstr "Using stored procedures for querying"
+msgstr "Usando procedimentos de armazenamento para consultas"
 
 #. Tag: para
-#: query_sql.xml:455
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 provides support for queries via stored procedures and functions. "
 "Most of the following documentation is equivalent for both. The stored "
@@ -1066,78 +839,38 @@
 "able to work with Hibernate. An example of such a stored function in Oracle "
 "9 and higher is as follows:"
 msgstr ""
-"Hibernate 3 introduces support for queries via stored procedures and "
-"functions. Most of the following documentation is equivalent for both. The "
-"stored procedure/function must return a resultset as the first out-parameter "
-"to be able to work with Hibernate. An example of such a stored function in "
-"Oracle 9 and higher is as follows:"
+"O Hibernate 3 apresenta o suporte para consultas através de procedimentos e "
+"funções armazenadas. A maior parte da documentação a seguir, é equivalente "
+"para ambos. Os procedimentos e funções armazenados devem devolver um "
+"conjunto de resultados como primeiros parâmetros externos para poder "
+"trabalhar com o Hibernate. Um exemplo disto é a função armazenada em Oracle "
+"9 e versões posteriores como se segue: "
 
-#. Tag: programlisting
-#: query_sql.xml:461
-#, no-c-format
-msgid ""
-"<![CDATA[CREATE OR REPLACE FUNCTION selectAllEmployments\n"
-"    RETURN SYS_REFCURSOR\n"
-"AS\n"
-"    st_cursor SYS_REFCURSOR;\n"
-"BEGIN\n"
-"    OPEN st_cursor FOR\n"
-" SELECT EMPLOYEE, EMPLOYER,\n"
-" STARTDATE, ENDDATE,\n"
-" REGIONCODE, EID, VALUE, CURRENCY\n"
-" FROM EMPLOYMENT;\n"
-"      RETURN  st_cursor;\n"
-" END;]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:463
 #, no-c-format
 msgid "To use this query in Hibernate you need to map it via a named query."
-msgstr "To use this query in Hibernate you need to map it via a named query."
-
-#. Tag: programlisting
-#: query_sql.xml:466
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"selectAllEmployees_SP\" callable=\"true\">\n"
-"    <return alias=\"emp\" class=\"Employment\">\n"
-"        <return-property name=\"employee\" column=\"EMPLOYEE\"/>\n"
-"        <return-property name=\"employer\" column=\"EMPLOYER\"/>\n"
-"        <return-property name=\"startDate\" column=\"STARTDATE\"/>\n"
-"        <return-property name=\"endDate\" column=\"ENDDATE\"/>\n"
-"        <return-property name=\"regionCode\" column=\"REGIONCODE\"/>\n"
-"        <return-property name=\"id\" column=\"EID\"/>\n"
-"        <return-property name=\"salary\">\n"
-"            <return-column name=\"VALUE\"/>\n"
-"            <return-column name=\"CURRENCY\"/>\n"
-"        </return-property>\n"
-"    </return>\n"
-"    { ? = call selectAllEmployments() }\n"
-"</sql-query>]]>"
 msgstr ""
+"Para usar esta consulta no Hibernate você vai precisar mapeá-lo através de "
+"uma consulta nomeada"
 
 #. Tag: para
-#: query_sql.xml:468
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Stored procedures currently only return scalars and entities. <literal>&lt;"
 "return-join&gt;</literal> and <literal>&lt;load-collection&gt;</literal> are "
 "not supported."
 msgstr ""
-"Notice stored procedures currently only return scalars and entities. "
-"<literal>&lt;return-join&gt;</literal> and <literal>&lt;load-collection&gt;</"
-"literal> are not supported."
+"Observe que os procedimentos armazenados somente devolvem escalares e "
+"entidades. O <literal>&lt;return-join&gt;</literal> e <literal>&lt;load-"
+"collection&gt;</literal> não são suportados."
 
 #. Tag: title
-#: query_sql.xml:473
 #, no-c-format
 msgid "Rules/limitations for using stored procedures"
-msgstr "Rules/limitations for using stored procedures"
+msgstr "Regras e limitações para utilizar procedimentos armazenados."
 
 #. Tag: para
-#: query_sql.xml:475
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You cannot use stored procedures with Hibernate unless you follow some "
 "procedure/function rules. If they do not follow those rules they are not "
@@ -1146,44 +879,41 @@
 "different for each database, since database vendors have different stored "
 "procedure semantics/syntax."
 msgstr ""
-"To use stored procedures with Hibernate the procedures/functions have to "
-"follow some rules. If they do not follow those rules they are not usable "
-"with Hibernate. If you still want to use these procedures you have to "
-"execute them via <literal>session.connection()</literal>. The rules are "
-"different for each database, since database vendors have different stored "
-"procedure semantics/syntax."
+"Para usar procedimentos armazenados com Hibernate, os procedimentos e "
+"funções precisam seguir a mesma regra. Caso não sigam estas regras, não "
+"poderão ser usados com o Hibernate. Se você ainda desejar usar estes "
+"procedimentos, terá que executá-los através da <literal>session.connection()"
+"</literal>. As regras são diferentes para cada banco de dados, uma vez que "
+"os fabricantes possuem procedimentos de semânticas/sintáxe armazenados.  "
 
 #. Tag: para
-#: query_sql.xml:482
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Stored procedure queries cannot be paged with <literal>setFirstResult()/"
 "setMaxResults()</literal>."
 msgstr ""
-"Stored procedure queries can't be paged with <literal>setFirstResult()/"
-"setMaxResults()</literal>."
+"Consultas de procedimento armazenado não podem ser paginados com o "
+"<literal>setFirstResult()/setMaxResults()</literal>. "
 
 #. Tag: para
-#: query_sql.xml:485
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The recommended call form is standard SQL92: <literal>{ ? = call functionName"
 "(&lt;parameters&gt;) }</literal> or <literal>{ ? = call procedureName(&lt;"
 "parameters&gt;}</literal>. Native call syntax is not supported."
 msgstr ""
-"Recommended call form is standard SQL92: <literal>{ ? = call functionName"
-"(&lt;parameters&gt;) }</literal> or <literal>{ ? = call procedureName(&lt;"
-"parameters&gt;}</literal>. Native call syntax is not supported."
+"O formulário de chamada recomedado é o padrão SQL92: <literal>{ ? = call "
+"functionName(&lt;parameters&gt;) }</literal> or <literal>{ ? = call "
+"procedureName(&lt;parameters&gt;}</literal>. A sintáxe de chamada nativa não "
+"é suportada."
 
 #. Tag: para
-#: query_sql.xml:490
 #, no-c-format
 msgid "For Oracle the following rules apply:"
-msgstr "For Oracle the following rules apply:"
+msgstr "As seguintes regras se aplicam para Oracle:"
 
 #. Tag: para
-#: query_sql.xml:494
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A function must return a result set. The first parameter of a procedure must "
 "be an <literal>OUT</literal> that returns a result set. This is done by "
@@ -1191,138 +921,101 @@
 "you need to define a <literal>REF CURSOR</literal> type. See Oracle "
 "literature for further information."
 msgstr ""
-"A funçãp deve retornar um result set. O primeiro parâmetro da procedure "
-"dever ser uma <literal>SAÍDA</literal> que retorne um result set. Isto é "
-"feito usando o tipo a <literal>SYS_REFCURSOR</literal> no Oracle 9 ou 10. No "
-"Oracle é necessário definir o tipo <literal>REF CURSOR</literal>, veja a "
-"documentação do Oracle."
+"A função deve retornar um conjunto de resultado. O primeiro parâmetro do "
+"procedimento deve ser um <literal>OUT</literal> que retorne um conjunto de "
+"resultado. Isto é feito usando o tipo <literal>SYS_REFCURSOR</literal> no "
+"Oracle 9 ou 10. No Oracle é necessário definir o tipo de <literal>REF "
+"CURSOR</literal>, veja a documentação do Oracle. "
 
 #. Tag: para
-#: query_sql.xml:503
 #, no-c-format
 msgid "For Sybase or MS SQL server the following rules apply:"
-msgstr "For Sybase or MS SQL server the following rules apply:"
+msgstr "Para servidores Sybase ou MS SQL aplicam-se as seguintes regras:"
 
 #. Tag: para
-#: query_sql.xml:507
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The procedure must return a result set. Note that since these servers can "
 "return multiple result sets and update counts, Hibernate will iterate the "
 "results and take the first result that is a result set as its return value. "
 "Everything else will be discarded."
 msgstr ""
-"A procedure deve retornar um result set. Veja que este servidor pode "
-"retornar múltiplos result sets e update counts. O Hibernate ira iterar os "
-"resultados e pegar o primeiro resultado que é o valor de retorno do result "
-"set. O resto será descartado."
+"O procedimento deve retornar um conjunto de resultados. Observe que, como "
+"este servidor pode retornar múltiplos conjuntos de resultados e contas "
+"atualizadas, o Hibernate irá inteirar os resultados e pegar o primeiro "
+"resultado, o qual é o valor de retorno do conjunto de resultados. O resto "
+"será descartado."
 
 #. Tag: para
-#: query_sql.xml:515
 #, no-c-format
 msgid ""
 "If you can enable <literal>SET NOCOUNT ON</literal> in your procedure it "
 "will probably be more efficient, but this is not a requirement."
 msgstr ""
-"Se você habilitar <literal>SET NOCOUNT ON</literal> na sua procedure, ela "
+"Se você habilitar <literal>SET NOCOUNT ON</literal> no seu procedimento, ele "
 "provavelmente será mais eficiente. Mas, isto não é obrigatório"
 
 #. Tag: title
-#: query_sql.xml:525
 #, no-c-format
 msgid "Custom SQL for create, update and delete"
-msgstr "SQL customizado para create, update e delete"
+msgstr "SQL padronizado para criar, atualizar e deletar"
 
 #. Tag: para
-#: query_sql.xml:527
 #, no-c-format
 msgid ""
-"Hibernate3 can use custom SQL statements for create, update, and delete "
-"operations. The class and collection persisters in Hibernate already contain "
-"a set of configuration time generated strings (insertsql, deletesql, "
-"updatesql etc.). The mapping tags <literal>&lt;sql-insert&gt;</literal>, "
-"<literal>&lt;sql-delete&gt;</literal>, and <literal>&lt;sql-update&gt;</"
-"literal> override these strings:"
+"Hibernate3 can use custom SQL for create, update, and delete operations. The "
+"SQL can be overridden at the statement level or inidividual column level. "
+"This section describes statement overrides. For columns, see <xref linkend="
+"\"mapping-column-read-and-write\" />."
 msgstr ""
-"Hibernate3 can use custom SQL statements for create, update, and delete "
-"operations. The class and collection persisters in Hibernate already contain "
-"a set of configuration time generated strings (insertsql, deletesql, "
-"updatesql etc.). The mapping tags <literal>&lt;sql-insert&gt;</literal>, "
-"<literal>&lt;sql-delete&gt;</literal>, and <literal>&lt;sql-update&gt;</"
-"literal> override these strings: Hibernate3 pode usar SQL customizado para "
-"operações de create, update e delete. A persistência de classe e collection "
-"no hibernate já contem alguma strings de configurações (insertsql, "
-"deletesql, updatesql etc.). O mapaemento das tags <literal>&lt;sql-insert&gt;"
-"</literal>, <literal>&lt;sql-delete&gt;</literal>, e <literal>&lt;sql-"
-"update&gt;</literal> sobreecreve essas strings:"
 
-#. Tag: programlisting
-#: query_sql.xml:535
-#, no-c-format
+#. Tag: para
+#, fuzzy, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <sql-insert>INSERT INTO PERSON (NAME, ID) VALUES ( UPPER(?), ? )</sql-"
-"insert>\n"
-"    <sql-update>UPDATE PERSON SET NAME=UPPER(?) WHERE ID=?</sql-update>\n"
-"    <sql-delete>DELETE FROM PERSON WHERE ID=?</sql-delete>\n"
-"</class>]]>"
+"The class and collection persisters in Hibernate already contain a set of "
+"configuration time generated strings (insertsql, deletesql, updatesql etc.). "
+"The mapping tags <literal>&lt;sql-insert&gt;</literal>, <literal>&lt;sql-"
+"delete&gt;</literal>, and <literal>&lt;sql-update&gt;</literal> override "
+"these strings:"
 msgstr ""
+"O Hibernate3 pode usar SQL padronizado para operações criar, atualizar e "
+"deletar. A persistência de classe e coleção no Hibernate já contém um "
+"conjunto de strings gerados por tempo de configuração (insertsql, deletesql, "
+"updatesql etc.). O mapeamento das tags <literal>&lt;sql-insert&gt;</"
+"literal>, <literal>&lt;sql-delete&gt;</literal>, e <literal>&lt;sql-"
+"update&gt;</literal> sobrescreve essas strings:"
 
 #. Tag: para
-#: query_sql.xml:537
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The SQL is directly executed in your database, so you can use any dialect "
 "you like. This will reduce the portability of your mapping if you use "
 "database specific SQL."
 msgstr ""
 "O SQL é executado diretamente no seu banco de dados, então você pode usar "
-"qualquer linguagem que quiser. Isto com certeza reduzira a portabilidade do "
-"seu mapeamento se você utilizar um SQL para um banco de dados especifico."
+"qualquer linguagem que quiser. Isto com certeza reduzirá a portabilidade do "
+"seu mapeamento se você utilizar um SQL para um banco de dados específico."
 
 #. Tag: para
-#: query_sql.xml:541
 #, no-c-format
 msgid ""
 "Stored procedures are supported if the <literal>callable</literal> attribute "
 "is set:"
 msgstr ""
-"Stored Procedures são suportadas se o atributo the <literal>callable</"
-"literal> estiver ativado:"
+"Os procedimentos armazenados são suportados se a função <literal>callable</"
+"literal> estiver ativada:"
 
-#. Tag: programlisting
-#: query_sql.xml:544
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <sql-insert callable=\"true\">{call createPerson (?, ?)}</sql-insert>\n"
-"    <sql-delete callable=\"true\">{? = call deletePerson (?)}</sql-delete>\n"
-"    <sql-update callable=\"true\">{? = call updatePerson (?, ?)}</sql-"
-"update>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:546
-#, fuzzy, no-c-format
-msgid ""
 "The order of the positional parameters is vital, as they must be in the same "
 "sequence as Hibernate expects them."
 msgstr ""
 "A ordem de posições dos parâmetros são vitais, pois eles devem estar na "
-"mesma seqüência esperada pelo Hibernate."
+"mesma seqüência esperada pelo Hibernate. "
 
 #. Tag: para
-#: query_sql.xml:549
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can view the expected order by enabling debug logging for the "
 "<literal>org.hibernate.persister.entity</literal> level. With this level "
@@ -1331,155 +1024,121 @@
 "your custom SQL in the mapping files, as this will override the Hibernate "
 "generated static SQL."
 msgstr ""
-"Você pode ver a ordem esperada ativando o debug logging no nível "
-"<literal>org.hibernate.persister.entity</literal>. Com este nível ativado, o "
-"Hibernate irá imprimir o SQL estático que foi usado para create, update, "
-"delete, etc. Entidades. (Para ver a seqüência esperada, lembre-se de não "
-"incluir seu SQL customizado no arquivo de mapeamento, pois ele irá "
-"sobreecreve o SQL estático gerado pelo Hibernate)."
+"Você pode ver a ordem esperada ativando o debug logging no ní­vel "
+"<literal>org.hibernate.persister.entity</literal>. Com este ní­vel ativado, "
+"o Hibernate irá imprimir o SQL estático que foi usado para criar, atualizar, "
+"deletar, etc., entidades. Para ver a seqüência esperada, lembre-se de não "
+"incluir seu SQL padronizado no arquivo de mapeamento, pois ele irá "
+"sobrescrever o SQL estático gerado pelo Hibernate."
 
 #. Tag: para
-#: query_sql.xml:556
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The stored procedures are in most cases required to return the number of "
 "rows inserted, updated and deleted, as Hibernate has some runtime checks for "
 "the success of the statement. Hibernate always registers the first statement "
 "parameter as a numeric output parameter for the CUD operations:"
 msgstr ""
-"As stored procedures são na maioria dos casos (leia: melhor não fazer) "
-"requeridas para retornar o numero de linhas inseridas/atualizadas/deletadas. "
-"O hibernate tem algumas verificações em tempo de execução para o sucesso da "
-"declaração. Hibernate sempre registra o primeiro parâmetro da declaração "
-"como uma saída numérica para operações CRUD."
+"Os procedimentos armazenados são na maioria dos casos requeridos para "
+"retornar o número de linhas inseridas/atualizadas/deletadas, uma vez que o "
+"Hibernate possui algumas verificações em tempo de espera para o sucesso das "
+"instruções. O Hibernate sempre registra o primeiro parâmetro da instrução "
+"como um parâmetro de saída numérica para as operações CUD:"
 
-#. Tag: programlisting
-#: query_sql.xml:562
-#, no-c-format
-msgid ""
-"<![CDATA[CREATE OR REPLACE FUNCTION updatePerson (uid IN NUMBER, uname IN "
-"VARCHAR2)\n"
-"    RETURN NUMBER IS\n"
-"BEGIN\n"
-"\n"
-"    update PERSON\n"
-"    set\n"
-"        NAME = uname,\n"
-"    where\n"
-"        ID = uid;\n"
-"\n"
-"    return SQL%ROWCOUNT;\n"
-"\n"
-"END updatePerson;]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:566
 #, no-c-format
 msgid "Custom SQL for loading"
-msgstr "SQL customizado para carga"
+msgstr "SQL padronizado para carga"
 
 #. Tag: para
-#: query_sql.xml:568
-#, fuzzy, no-c-format
-msgid "You can also declare your own SQL (or HQL) queries for entity loading:"
-msgstr ""
-"Você pode declarar sua própria query SQL (ou HQL) para iniciar entidades:"
-
-#. Tag: programlisting
-#: query_sql.xml:571
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"person\">\n"
-"    <return alias=\"pers\" class=\"Person\" lock-mode=\"upgrade\"/>\n"
-"    SELECT NAME AS {pers.name}, ID AS {pers.id}\n"
-"    FROM PERSON\n"
-"    WHERE ID=?\n"
-"    FOR UPDATE\n"
-"</sql-query>]]>"
+"You can also declare your own SQL (or HQL) queries for entity loading. As "
+"with inserts, updates, and deletes, this can be done at the individual "
+"column level as described in <xref linkend=\"mapping-column-read-and-write"
+"\" /> or at the statement level. Here is an example of a statement level "
+"override:"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:573
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is just a named query declaration, as discussed earlier. You can "
 "reference this named query in a class mapping:"
 msgstr ""
-"Este é apenas uma declaração de query com nome, como discutido "
-"anteriormente. Você pode referenciar esta query com nome em um mapeamento de "
-"classe:"
+"Este é apenas uma instrução de consulta nomeada, como discutido "
+"anteriormente. Você pode referenciar esta consulta nomeada em um mapeamento "
+"de classe:"
 
-#. Tag: programlisting
-#: query_sql.xml:576
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <loader query-ref=\"person\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:578
 #, no-c-format
 msgid "This even works with stored procedures."
-msgstr "Isto também funciona com stored procedures."
+msgstr "Este também funciona com procedimentos armazenados."
 
 #. Tag: para
-#: query_sql.xml:580
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can even define a query for collection loading:"
-msgstr "Você pode tembém definir uma query para iniciar collection:"
+msgstr "Você pode também definir uma consulta para carregar uma coleção: "
 
-#. Tag: programlisting
-#: query_sql.xml:582
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"employments\" inverse=\"true\">\n"
-"    <key/>\n"
-"    <one-to-many class=\"Employment\"/>\n"
-"    <loader query-ref=\"employments\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_sql.xml:584
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"employments\">\n"
-"    <load-collection alias=\"emp\" role=\"Person.employments\"/>\n"
-"    SELECT {emp.*}\n"
-"    FROM EMPLOYMENT emp\n"
-"    WHERE EMPLOYER = :id\n"
-"    ORDER BY STARTDATE ASC, EMPLOYEE ASC\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:586
-#, fuzzy, no-c-format
-msgid ""
 "You can also define an entity loader that loads a collection by join "
 "fetching:"
 msgstr ""
-"You could even define an entity loader that loads a collection by join "
-"fetching:"
+"Você pode até definir um carregador de entidade que carregue uma coleção por "
+"busca de união: "
 
-#. Tag: programlisting
-#: query_sql.xml:589
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"person\">\n"
-"    <return alias=\"pers\" class=\"Person\"/>\n"
-"    <return-join alias=\"emp\" property=\"pers.employments\"/>\n"
-"    SELECT NAME AS {pers.*}, {emp.*}\n"
-"    FROM PERSON pers\n"
-"    LEFT OUTER JOIN EMPLOYMENT emp\n"
-"        ON pers.ID = emp.PERSON_ID\n"
-"    WHERE ID=?\n"
-"</sql-query>]]>"
-msgstr ""
+#~ msgid ""
+#~ "You can also declare your own SQL (or HQL) queries for entity loading:"
+#~ msgstr ""
+#~ "Você pode declarar sua própria consulta SQL (ou HQL) para o carregamento "
+#~ "da entidade: "
+
+#, fuzzy
+#~ msgid "A_NAME as {item.name}"
+#~ msgstr "<literal>A_NAME as {item.name}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].class}"
+#~ msgstr "<literal>{[aliasname].class}</literal>"
+
+#, fuzzy
+#~ msgid "DISC as {item.class}"
+#~ msgstr "<literal>DISC as {item.class}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].*}"
+#~ msgstr "<literal>{[aliasname].*}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].key}"
+#~ msgstr "<literal>{[aliasname].key}</literal>"
+
+#, fuzzy
+#~ msgid "ORGID as {coll.key}"
+#~ msgstr "<literal>ORGID as {coll.key}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].id}"
+#~ msgstr "<literal>{[aliasname].id}</literal>"
+
+#, fuzzy
+#~ msgid "EMPID as {coll.id}"
+#~ msgstr "<literal>EMPID as {coll.id}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].element}"
+#~ msgstr "<literal>{[aliasname].element}</literal>"
+
+#, fuzzy
+#~ msgid "XID as {coll.element}"
+#~ msgstr "<literal>XID as {coll.element}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].element.*}"
+#~ msgstr "<literal>{[aliasname].element.*}</literal>"
+
+#, fuzzy
+#~ msgid "{coll.element.*}"
+#~ msgstr "<literal>{coll.element.*}</literal>"

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/session_api.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/session_api.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/session_api.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,129 @@
+# translation of session_api.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: session_api\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-12-21 07:37+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: session_api.xml:29
 #, no-c-format
 msgid "Working with objects"
 msgstr "Trabalhando com objetos"
 
 #. Tag: para
-#: session_api.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate is a full object/relational mapping solution that not only shields "
 "the developer from the details of the underlying database management system, "
@@ -29,14 +134,13 @@
 msgstr ""
 "O Hibernate é uma solução completa de mapeamento objeto/relacional que não "
 "apenas poupa o desenvolvedor dos detalhes de baixo nível do sistema de "
-"gerenciamento do banco de dados, mas também oferece um "
-"<emphasis>gerenciamento de estado </emphasis> para objetos. Isto é, ao "
-"contrário do gerenciamento de <literal>instruções </literal> SQL em camadas "
+"gerenciamento do banco de dados, como também oferece um "
+"<emphasis>gerenciamento de estado</emphasis> para objetos. Isto é, ao "
+"contrário do gerenciamento de <literal>instruções</literal> SQL em camadas "
 "de persistência JDBC/SQL comuns, uma visão natural da persistência orientada "
-"a objetos em aplicações Java."
+"a objetos em aplicações Java. "
 
 #. Tag: para
-#: session_api.xml:40
 #, no-c-format
 msgid ""
 "In other words, Hibernate application developers should always think about "
@@ -46,26 +150,23 @@
 "of the system."
 msgstr ""
 "Em outras palavras, desenvolvedores de aplicações Hibernate podem sempre "
-"pensar em relação ao <emphasis>estado</emphasis> de seus objetos, e não "
-"necessariamente em relação a execução de instruções SQL. Este parte é "
-"responsabilidade do Hibernate e é relevante aos desenvolvedores de "
-"aplicações apenas quando estão ajustando a performance do sistema."
+"considerar o <emphasis>estado</emphasis> de seus objetos, e não "
+"necessariamente a execução de instruções SQL. O Hibernate é responsável por "
+"esta parte e é relevante aos desenvolvedores de aplicações apenas quando "
+"estão ajustando o desempenho do sistema."
 
 #. Tag: title
-#: session_api.xml:48
 #, no-c-format
 msgid "Hibernate object states"
 msgstr "Estado dos objetos no Hibernate"
 
 #. Tag: para
-#: session_api.xml:50
 #, no-c-format
 msgid "Hibernate defines and supports the following object states:"
-msgstr "O Hibernate define e suporta os seguintes estados de um objetos:"
+msgstr "O Hibernate define e suporta os seguintes estados de objetos:"
 
 #. Tag: para
-#: session_api.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Transient</emphasis> - an object is transient if it has just been "
 "instantiated using the <literal>new</literal> operator, and it is not "
@@ -78,18 +179,17 @@
 "transition)."
 msgstr ""
 "<emphasis>Transient</emphasis> - um objeto é transiente se ele foi "
-"instanciando usando apenas o operador <literal>new</literal>, e não foi "
-"associado com uma <literal>Session</literal> do Hibernate. Ele não terá uma "
-"representação persistente no banco de dados e nenhum identificador será "
-"atribuído para ele. Instâncias transientes serão destruídas pelo coletor de "
-"lixo se a aplicação não manter sua referência. Use uma <literal>Session</"
-"literal> do Hibernate para tornar o objeto persistente ( e deixe o Hibernate "
+"instanciando usando apenas o operador <literal>new</literal> e não foi "
+"associado a uma <literal>Session</literal> do Hibernate. Ele não possui uma "
+"representação persistente no banco de dados e não lhe foi atribuído nenhum "
+"identificador. Instâncias transientes serão destruídas pelo coletor de lixo "
+"se a aplicação não mantiver sua referência. Use uma <literal>Session</"
+"literal> do Hibernate para tornar o objeto persistente (e deixe o Hibernate "
 "gerenciar as instruções SQL que serão necessárias para executar esta "
 "transição)."
 
 #. Tag: para
-#: session_api.xml:68
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Persistent</emphasis> - a persistent instance has a representation "
 "in the database and an identifier value. It might just have been saved or "
@@ -100,18 +200,17 @@
 "statements, or <literal>DELETE</literal> statements when an object should be "
 "made transient."
 msgstr ""
-"<emphasis>Persistent</emphasis> -– uma instância persistente possui uma "
-"representação no banco de dados e um identificador. Ele pode ter sido salvo "
-"ou carregado, assim, ele está por definição no escopo de uma "
-"<literal>Session</literal>. O Hibernate irá detectar qualquer mudança feita "
-"a um objeto persistente e sincronizar o seu estado com o banco de dados "
-"quando completar a unidade de trabalho. Desenvolvedores não executam "
-"instruções manuais de <literal>UPDATE</literal>, ou instruções de "
-"<literal>DELETE</literal> quando o objeto deve ser passado para transiente."
+"<emphasis>Persistent</emphasis> - uma instância persistente possui uma "
+"representação no banco de dados e um identificador. Ela pode ter sido salva "
+"ou carregada, portanto ela se encontra no escopo de uma <literal>Session</"
+"literal>. O Hibernate irá detectar qualquer mudança feita a um objeto "
+"persistente e sincronizar o seu estado com o banco de dados quando completar "
+"a unidade de trabalho. Desenvolvedores não executam instruções manuais de "
+"<literal>UPDATE</literal>, ou instruções de <literal>DELETE</literal> quando "
+"o objeto se tornar transiente. "
 
 #. Tag: para
-#: session_api.xml:79
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Detached</emphasis> - a detached instance is an object that has "
 "been persistent, but its <literal>Session</literal> has been closed. The "
@@ -123,60 +222,45 @@
 "them <emphasis>application transactions</emphasis>, i.e., a unit of work "
 "from the point of view of the user."
 msgstr ""
-"<emphasis>Detached</emphasis> – uma instância desaclopada é um objeto que "
-"foi persistido, mas sua <literal>Session</literal> foi fechada. A referência "
-"ao objeto continua válida, é claro, e a instância destacada desaclopada pode "
-"ser acoplada a uma nova <literal>Session</literal> no futuro, fazendo-o ( e "
-"todas as modificações sofridas) persistente novamente. Essa característica "
-"possibilita um modelo de programação para unidades de trabalho que rodam "
-"durante muito tempo que requer um pensamento por tempo do usuário. Podemos "
-"chamar-las de <emphasis>transações da aplicação</emphasis>, i.e. uma unidade "
-"de trabalho do ponto de vista do usuário."
+"<emphasis>Detached</emphasis> – uma instância desanexada é um objeto que foi "
+"persistido, mas sua <literal>Session</literal> foi fechada. A referência ao "
+"objeto continua válida, é claro, e a instância desanexada pode ser acoplada "
+"a uma nova <literal>Session</literal> no futuro, tornando-o novamente "
+"persistente (e todas as modificações sofridas). Essa característica habilita "
+"um modelo de programação para unidades de trabalho de longa execução, que "
+"requeira um tempo de espera do usuário. Podemos chamá-las de "
+"<emphasis>transações da aplicação</emphasis>, ou seja, uma unidade de "
+"trabalho do ponto de vista do usuário."
 
 #. Tag: para
-#: session_api.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will now discuss the states and state transitions (and the Hibernate "
 "methods that trigger a transition) in more detail."
 msgstr ""
-"Agora iremos discutir os estados e suas transições ( e os métodos do "
+"Agora iremos discutir os estados e suas transições (e os métodos do "
 "Hibernate que disparam uma transição) em mais detalhes."
 
 #. Tag: title
-#: session_api.xml:101
 #, no-c-format
 msgid "Making objects persistent"
 msgstr "Tornando os objetos persistentes"
 
 #. Tag: para
-#: session_api.xml:103
 #, no-c-format
 msgid ""
 "Newly instantiated instances of a a persistent class are considered "
 "<emphasis>transient</emphasis> by Hibernate. We can make a transient "
 "instance <emphasis>persistent</emphasis> by associating it with a session:"
 msgstr ""
-"Instâncias recentemente instanciadas de uma classe persistente são "
+"As instâncias recentemente instanciadas de uma classe persistente são "
 "consideradas <emphasis>transientes </emphasis> pelo Hibernate. Podemos "
-"tornar uma instância transiente em <emphasis>persistente</emphasis> "
+"transformar uma instância transiente em <emphasis>persistente</emphasis> "
 "associando-a a uma sessão:"
 
-#. Tag: programlisting
-#: session_api.xml:110
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DomesticCat fritz = new DomesticCat();\n"
-"fritz.setColor(Color.GINGER);\n"
-"fritz.setSex('M');\n"
-"fritz.setName(\"Fritz\");\n"
-"Long generatedId = (Long) sess.save(fritz);]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:112
-#, fuzzy, no-c-format
-msgid ""
 "If <literal>Cat</literal> has a generated identifier, the identifier is "
 "generated and assigned to the <literal>cat</literal> when <literal>save()</"
 "literal> is called. If <literal>Cat</literal> has an <literal>assigned</"
@@ -187,17 +271,16 @@
 "draft."
 msgstr ""
 "Se <literal>Cat</literal> possui um identificador gerado, o identificador é "
-"gerado e atribuído a <literal>cat</literal> quando <literal>save()</literal> "
-"for chamada. Se <literal>Cat</literal> possuir um identificador "
-"<literal>Associado</literal>, ou uma chave composta, o identificador deve "
+"gerado e atribuído à <literal>cat</literal> quando <literal>save()</literal> "
+"for chamado. Se <literal>Cat</literal> possuir um identificador "
+"<literal>Associado</literal>, ou uma chave composta, o identificador deverá "
 "ser atribuído à instância de <literal>cat</literal> antes que <literal>save()"
 "</literal> seja chamado. Pode-se usar também <literal>persist()</literal> ao "
-"invés de <literal>save()</literal>, com a semântica definada no novo esboço "
-"do EJB3."
+"invés de <literal>save()</literal>, com a semântica definida no novo esboço "
+"do EJB3. "
 
 #. Tag: para
-#: session_api.xml:124
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>persist()</literal> makes a transient instance persistent. However, "
 "it does not guarantee that the identifier value will be assigned to the "
@@ -207,16 +290,15 @@
 "boundaries. This is useful in long-running conversations with an extended "
 "Session/persistence context."
 msgstr ""
-"<literal>persist()</literal> makes a transient instance persistent. However, "
-"it doesn't guarantee that the identifier value will be assigned to the "
-"persistent instance immediately, the assignment might happen at flush time. "
-"<literal>persist()</literal> also guarantees that it will not execute an "
-"<literal>INSERT</literal> statement if it is called outside of transaction "
-"boundaries. This is useful in long-running conversations with an extended "
-"Session/persistence context."
+"<literal>persist()</literal> faz uma instância transciente persistente. No "
+"entanto, isto não garante que o valor do identificador será determinado à "
+"instância persistente imediatamente, pois a determinação pode acontecer no "
+"período de limpeza. O <literal>persist()</literal> também garante que isto "
+"não executará uma declaração <literal>INSERT</literal> caso esta seja "
+"chamada fora dos limites da transação. Isto é útil em transações de longa-"
+"execução com um contexto de Sessão/persistência estendido."
 
 #. Tag: para
-#: session_api.xml:135
 #, no-c-format
 msgid ""
 "<literal>save()</literal> does guarantee to return an identifier. If an "
@@ -225,39 +307,24 @@
 "you are inside or outside of a transaction. This is problematic in a long-"
 "running conversation with an extended Session/persistence context."
 msgstr ""
-"<literal>save()</literal> does guarantee to return an identifier. If an "
-"INSERT has to be executed to get the identifier ( e.g. \"identity\" "
-"generator, not \"sequence\"), this INSERT happens immediately, no matter if "
-"you are inside or outside of a transaction. This is problematic in a long-"
-"running conversation with an extended Session/persistence context."
+"<literal>save()</literal> garante retornar um identificador. Caso um INSERT "
+"necessita ser executado para obter o identificador (ex.: gerador \"identidade"
+"\" e não \"seqüência\"), este INSERT acontece imediatamente, independente de "
+"você estar dentro ou fora da transação. Isto é problemático numa conversação "
+"de longa execução com um contexto de Sessão/persistência estendido."
 
 #. Tag: para
-#: session_api.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, you can assign the identifier using an overloaded version of "
 "<literal>save()</literal>."
 msgstr ""
 "Alternativamente, pode-se atribuir o identificador usando uma versão "
-"sobrecarregada de <literal>save()</literal>."
+"sobrecarregada de <literal>save()</literal>. "
 
-#. Tag: programlisting
-#: session_api.xml:150
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DomesticCat pk = new DomesticCat();\n"
-"pk.setColor(Color.TABBY);\n"
-"pk.setSex('F');\n"
-"pk.setName(\"PK\");\n"
-"pk.setKittens( new HashSet() );\n"
-"pk.addKitten(fritz);\n"
-"sess.save( pk, new Long(1234) );]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:152
-#, fuzzy, no-c-format
-msgid ""
 "If the object you make persistent has associated objects (e.g. the "
 "<literal>kittens</literal> collection in the previous example), these "
 "objects can be made persistent in any order you like unless you have a "
@@ -266,17 +333,16 @@
 "violate a <literal>NOT NULL</literal> constraint if you <literal>save()</"
 "literal> the objects in the wrong order."
 msgstr ""
-"Se o objeto persistido possuir objetos associados (e.g. a coleção "
-"<literal>kittens</literal> no exemplo anterior), esses objetos podem ser "
-"tornar persistente em qualquer ordem que se queira ao menos que se tenha uma "
-"restrição <literal>NOT NULL</literal> em uma coluna de chave estrangeira. "
-"Nunca há risco de violação de restrições de chave estrangeira. Assim, pode-"
-"se violar uma restrição <literal>NOT NULL</literal> se <literal>save()</"
-"literal> for usada nos objetos em uma ordem errada."
+"Se o objeto persistido tiver associado objetos (ex.: a coleção "
+"<literal>kittens</literal> no exemplo anterior), esses objetos podem se "
+"tornar persistentes em qualquer ordem que se queira, a não ser que se tenha "
+"uma restrição <literal>NOT NULL</literal> em uma coluna de chave "
+"estrangeira. Nunca há risco de violação de restrições de chave estrangeira. "
+"Assim, pode-se violar uma restrição <literal>NOT NULL</literal> se "
+"<literal>save()</literal> for usado nos objetos em uma ordem errada. "
 
 #. Tag: para
-#: session_api.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Usually you do not bother with this detail, as you will normally use "
 "Hibernate's <emphasis>transitive persistence</emphasis> feature to save the "
@@ -284,72 +350,40 @@
 "constraint violations do not occur - Hibernate will take care of everything. "
 "Transitive persistence is discussed later in this chapter."
 msgstr ""
-"Geralmente você não deve se importar com esses detalhes, muito provavelmente "
-"se usará a característica de <emphasis>persistência transitiva </emphasis> "
-"do Hibernate para salvar os objetos associados automaticamente. Então, "
-"enquanto uma restrição <literal>NOT NULL</literal> não ocorrer – Hibernate "
-"tomará conta de tudo. Persistência transitiva será discutida futuramente "
-"nesse capítulo."
+"Geralmente você não precisa se preocupar com esses detalhes, pois muito "
+"provavelmente usará a característica de <emphasis>persistência transitiva </"
+"emphasis> do Hibernate para salvar os objetos associados automaticamente. "
+"Assim, enquanto uma restrição <literal>NOT NULL</literal> não ocorrer, o "
+"Hibernate tomará conta de tudo. Persistência transitiva será discutida mais "
+"adiante nesse mesmo capítulo. "
 
 #. Tag: title
-#: session_api.xml:173
 #, no-c-format
 msgid "Loading an object"
-msgstr "Carregando o objetos"
+msgstr "Carregando o objeto"
 
 #. Tag: para
-#: session_api.xml:175
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>load()</literal> methods of <literal>Session</literal> provide "
 "a way of retrieving a persistent instance if you know its identifier. "
 "<literal>load()</literal> takes a class object and loads the state into a "
 "newly instantiated instance of that class in a persistent state."
 msgstr ""
-"O método <literal>load()</literal> de uma <literal> Session</literal> nos "
-"fornece um meio para recuperar uma instância persistente se o identificador "
-"for conhecido. <literal>load()</literal> recebe uma classe do objeto e "
-"carregará o estado em uma instância mais recente dessa classe, no estado "
-"persistente."
+"O método <literal>load()</literal> de uma <literal> Session</literal> "
+"oferece uma maneira de recuperar uma instância persistente se o "
+"identificador for conhecido. O <literal>load()</literal> escolhe uma classe "
+"do objeto e carregará o estado em uma instância mais recente dessa classe, "
+"em estado persistente."
 
-#. Tag: programlisting
-#: session_api.xml:182
-#, no-c-format
-msgid "<![CDATA[Cat fritz = (Cat) sess.load(Cat.class, generatedId);]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:184
-#, no-c-format
-msgid ""
-"<![CDATA[// you need to wrap primitive identifiers\n"
-"long id = 1234;\n"
-"DomesticCat pk = (DomesticCat) sess.load( DomesticCat.class, new Long"
-"(id) );]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:186
 #, no-c-format
 msgid "Alternatively, you can load state into a given instance:"
-msgstr ""
-"Alternatively, you can load state into a given instance: Alternativamente, "
-"pode-se carregar um estado em uma instância dada:"
+msgstr "Alternativamente, pode-se carregar um estado em uma instância dada:"
 
-#. Tag: programlisting
-#: session_api.xml:190
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Cat cat = new DomesticCat();\n"
-"// load pk's state into cat\n"
-"sess.load( cat, new Long(pkId) );\n"
-"Set kittens = cat.getKittens();]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:192
-#, fuzzy, no-c-format
-msgid ""
 "Be aware that <literal>load()</literal> will throw an unrecoverable "
 "exception if there is no matching database row. If the class is mapped with "
 "a proxy, <literal>load()</literal> just returns an uninitialized proxy and "
@@ -363,112 +397,79 @@
 "não houver na tabela no banco de dados um registro que combine. Se a classe "
 "for mapeada com um proxy, <literal>load()</literal> simplesmente retorna um "
 "proxy não inicializado e realmente não chamará o banco de dados até que um "
-"método do proxy seja invocado. Esse comportamento é muito útil se deseja-se "
-"criar uma associação com um objeto sem que realmente o carregue do bando de "
-"dados. Isto também permite que sejam carregadas múltiplas instâncias como um "
-"grupo se <literal>batch-size</literal> estiver para o mapeamento da classe."
+"método do proxy seja invocado. Esse comportamento é muito útil para criar "
+"uma associação com um objeto sem que realmente o carregue do bando de dados. "
+"Isto também permite que sejam carregadas múltiplas instâncias como um grupo "
+"se o <literal>batch-size</literal> estiver definido para o mapeamento da "
+"classe. "
 
 #. Tag: para
-#: session_api.xml:203
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are not certain that a matching row exists, you should use the "
 "<literal>get()</literal> method which hits the database immediately and "
 "returns null if there is no matching row."
 msgstr ""
-"Se você não tiver certeza da existencia do registro no banco, você deve usar "
-"o metodo <literal>get()</literal>, que consulta o banco imediantamente e "
-"retorna um null se não existir o registro."
+"Se você não tiver certeza da existência do registro no banco, você deve usar "
+"o método <literal>get()</literal>, que consulta o banco imediatamente e "
+"retorna um null se não existir o registro. "
 
-#. Tag: programlisting
-#: session_api.xml:209
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id);\n"
-"if (cat==null) {\n"
-"    cat = new Cat();\n"
-"    sess.save(cat, id);\n"
-"}\n"
-"return cat;]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:211
-#, fuzzy, no-c-format
-msgid ""
 "You can even load an object using an SQL <literal>SELECT ... FOR UPDATE</"
 "literal>, using a <literal>LockMode</literal>. See the API documentation for "
 "more information."
 msgstr ""
 "Também pode-se carregar um objeto usando <literal>SELECT ... FOR UPDATE</"
 "literal>, usando um <literal>LockMode</literal>. Veja a documentação da API "
-"para maiores informações."
+"para maiores informações. "
 
-#. Tag: programlisting
-#: session_api.xml:216
-#, no-c-format
-msgid "<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id, LockMode.UPGRADE);]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:218
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Any associated instances or contained collections will <emphasis>not</"
 "emphasis> be selected <literal>FOR UPDATE</literal>, unless you decide to "
 "specify <literal>lock</literal> or <literal>all</literal> as a cascade style "
 "for the association."
 msgstr ""
-"Note that any associated instances or contained collections are "
-"<emphasis>not</emphasis> selected <literal>FOR UPDATE</literal>, unless you "
-"decide to specify <literal>lock</literal> or <literal>all</literal> as a "
-"cascade style for the association."
+"Note que quaisquer instâncias associadas ou que contenham coleções, "
+"<emphasis>não</emphasis> são selecionados <literal>FOR UPDATE</literal>, a "
+"não ser que você decida especificar um <literal>lock</literal> ou "
+"<literal>all</literal> como um estilo cascata para a associação. "
 
 #. Tag: para
-#: session_api.xml:225
 #, no-c-format
 msgid ""
 "It is possible to re-load an object and all its collections at any time, "
 "using the <literal>refresh()</literal> method. This is useful when database "
 "triggers are used to initialize some of the properties of the object."
 msgstr ""
-"O recarregamento de um objeto e todas as suas coleções é possível a qualquer "
-"momento, usando o método <literal>refresh()</literal>. Util quando as "
-"triggers do banco de dados são usados para inicializar algumas propriedades "
-"do objeto."
+"É possível realizar o recarregamento de um objeto e todas as suas coleções a "
+"qualquer momento, usando o método <literal>refresh()</literal>.É útil quando "
+"os disparos do banco de dados são usados para inicializar algumas "
+"propriedades do objeto."
 
-#. Tag: programlisting
-#: session_api.xml:231
-#, no-c-format
-msgid ""
-"<![CDATA[sess.save(cat);\n"
-"sess.flush(); //force the SQL INSERT\n"
-"sess.refresh(cat); //re-read the state (after the trigger executes)]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:233
 #, fuzzy, no-c-format
 msgid ""
 "How much does Hibernate load from the database and how many SQL "
 "<literal>SELECT</literal>s will it use? This depends on the "
 "<emphasis>fetching strategy</emphasis>. This is explained in <xref linkend="
-"\"performance-fetching\"/>."
+"\"performance-fetching\" />."
 msgstr ""
-"Uma importante questão geralmente aparece neste ponto: O quanto Hibernate "
-"carrega do banco de dados e quantos SQL <literal>SELECT</literal> ele irá "
-"usar? Isto depende da estratégia de <emphasis>recuperação</emphasis>usada e "
-"explicada na <xref linkend=\"performance-fetching\"/>."
+"O quanto Hibernate carrega do banco de dados e quantos SQL <literal>SELECT</"
+"literal> ele irá usar? Isto depende da estratégia de <emphasis>estratégia de "
+"busca</emphasis> usada e explicada na <xref linkend=\"performance-fetching\"/"
+">."
 
 #. Tag: title
-#: session_api.xml:243
 #, no-c-format
 msgid "Querying"
 msgstr "Consultando"
 
 #. Tag: para
-#: session_api.xml:245
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you do not know the identifiers of the objects you are looking for, you "
 "need a query. Hibernate supports an easy-to-use but powerful object oriented "
@@ -477,22 +478,20 @@
 "express your query in the native SQL of your database, with optional support "
 "from Hibernate for result set conversion into objects."
 msgstr ""
-"Se o identificador do objeto que se está buscando não for conhecido, uma "
-"consulta será necessária. O Hibernate suporta uma linguagem de consulta "
-"(HQL) orientada a objetos fácil mas poderosa. Para criação via programação "
-"de consultas, o Hibernate suporta características sofisticadas de consulta "
-"por Critério e Exemplo (QBCe QBE). Pode-se também expressar a consulta por "
-"meio de SQL nativa do banco de dados, com suporte opcional do Hibernate para "
-"conversão do conjunto de reultados em objetos."
+"Se o identificador do objeto que se está buscando não for conhecido, será "
+"necessário realizar uma consulta. O Hibernate suporta uma linguagem de "
+"consulta (HQL) orientada a objetos fáceis de usar, porém poderosos. Para "
+"criação via programação de consultas, o Hibernate suporta características "
+"sofisticadas de consulta por Critério e Exemplo (QBCe QBE). Pode-se também "
+"expressar a consulta por meio de SQL nativa do banco de dados, com suporte "
+"opcional do Hibernate para conversão do conjunto de resultados em objetos. "
 
 #. Tag: title
-#: session_api.xml:255
 #, no-c-format
 msgid "Executing queries"
 msgstr "Executando consultas"
 
 #. Tag: para
-#: session_api.xml:257
 #, no-c-format
 msgid ""
 "HQL and native SQL queries are represented with an instance of <literal>org."
@@ -501,46 +500,15 @@
 "always obtain a <literal>Query</literal> using the current <literal>Session</"
 "literal>:"
 msgstr ""
-"Consultas HQL e SQL nativa são representadas por uma instância de "
+"Consultas HQL e SQL nativas são representadas por uma instância de "
 "<literal>org.hibernate.Query</literal>. Esta interface oferece métodos para "
-"associação de parâmetros, tratamento de conjunto de resultados, e para a "
+"associação de parâmetros, tratamento de conjunto de resultados e para a "
 "execução de consultas reais. Você pode obter uma <literal>Query</literal> "
 "usando a <literal>Session</literal> atual:"
 
-#. Tag: programlisting
-#: session_api.xml:264
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = session.createQuery(\n"
-"    \"from Cat as cat where cat.birthdate < ?\")\n"
-"    .setDate(0, date)\n"
-"    .list();\n"
-"\n"
-"List mothers = session.createQuery(\n"
-"    \"select mother from Cat as cat join cat.mother as mother where cat.name "
-"= ?\")\n"
-"    .setString(0, name)\n"
-"    .list();\n"
-"\n"
-"List kittens = session.createQuery(\n"
-"    \"from Cat as cat where cat.mother = ?\")\n"
-"    .setEntity(0, pk)\n"
-"    .list();\n"
-"\n"
-"Cat mother = (Cat) session.createQuery(\n"
-"    \"select cat.mother from Cat as cat where cat = ?\")\n"
-"    .setEntity(0, izi)\n"
-"    .uniqueResult();]]\n"
-"\n"
-"Query mothersWithKittens = (Cat) session.createQuery(\n"
-"    \"select mother from Cat as mother left join fetch mother.kittens\");\n"
-"Set uniqueMothers = new HashSet(mothersWithKittens.list());]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:266
-#, fuzzy, no-c-format
-msgid ""
 "A query is usually executed by invoking <literal>list()</literal>. The "
 "result of the query will be loaded completely into a collection in memory. "
 "Entity instances retrieved by a query are in a persistent state. The "
@@ -550,25 +518,23 @@
 "with their collections initialized. You can filter these duplicates through "
 "a <literal>Set</literal>."
 msgstr ""
-"Geralmente uma consulta é executada ao invocar <literal>list()</literal>, o "
+"Geralmente uma consulta é executada ao invocar <literal>list()</literal>.O "
 "resultado da consulta será carregado completamente em uma coleção na "
 "memória. Instâncias de entidades recuperadas por uma consulta estão no "
 "estado persistente. O <literal>uniqueResult()</literal> oferece um atalho se "
-"você souber de previamente que a consulta retornará apenas um único objeto. "
-"Repare que consultas que fazem uso de buscas de coleções de forma ansiosa "
-"(eager) geralmente retornam duplicatas dos objetos raiz ( mas com suas "
-"coleções inicializadas ). Pode-se filtrar estas duplicatas através de um "
+"você souber previamente, que a consulta retornará apenas um único objeto. "
+"Repare que consultas que fazem uso da busca antecipada (eager fetching) de "
+"coleções, geralmente retornam duplicatas dos objetos raiz, mas com suas "
+"coleções inicializadas. Pode-se filtrar estas duplicatas através de um "
 "simples <literal>Set</literal>."
 
 #. Tag: title
-#: session_api.xml:278
 #, no-c-format
 msgid "Iterating results"
 msgstr "Interagindo com resultados"
 
 #. Tag: para
-#: session_api.xml:280
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Occasionally, you might be able to achieve better performance by executing "
 "the query using the <literal>iterate()</literal> method. This will usually "
@@ -580,118 +546,55 @@
 "returns identifiers, and <emphasis>n</emphasis> additional selects to "
 "initialize the actual instances."
 msgstr ""
-"Ocasionalmente, deves-se ser capaz de atingir performances melhores com a "
-"execução de consultas usando o método <literal>iterate()</literal>. "
-"Geralmente isso será o caso esperado apenas se as instâncias dos entidades "
-"reais retornadas pela consulta já estiverem na sessão ou no caché de segundo "
-"nível. Caso elas ainda não tenham sido armazenadas, <literal>iterate()</"
-"literal> será mais devagar do que <literal>list()</literal> e pode ser "
-"necessário vários acessos ao banco de dados para um simples consulta, "
-"geralmente <emphasis>1</emphasis> para a seleção inicial que retorna apenas "
-"identificadores, e <emphasis>n</emphasis> consultas adicionais para "
-"inicializar as instâncias reais."
+"Ocasionalmente, pode-se obter um melhor desempenho com a execução de "
+"consultas, usando o método <literal>iterate()</literal>. Geralmente isso "
+"acontece apenas se as instâncias das entidades reais retornadas pela "
+"consulta já estiverem na sessão ou no cachê de segundo nível. Caso elas "
+"ainda não tenham sido armazenadas, <literal>iterate()</literal> será mais "
+"devagar do que <literal>list()</literal> e podem ser necessários vários "
+"acessos ao banco de dados para uma simples consulta, geralmente <emphasis>1</"
+"emphasis> para a seleção inicial que retorna apenas identificadores, e "
+"<emphasis>n</emphasis> consultas adicionais para inicializar as instâncias "
+"reais. "
 
-#. Tag: programlisting
-#: session_api.xml:292
-#, no-c-format
-msgid ""
-"<![CDATA[// fetch ids\n"
-"Iterator iter = sess.createQuery(\"from eg.Qux q order by q.likeliness\")."
-"iterate();\n"
-"while ( iter.hasNext() ) {\n"
-"    Qux qux = (Qux) iter.next();  // fetch the object\n"
-"    // something we couldnt express in the query\n"
-"    if ( qux.calculateComplicatedAlgorithm() ) {\n"
-"        // delete the current instance\n"
-"        iter.remove();\n"
-"        // dont need to process the rest\n"
-"        break;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:296
 #, no-c-format
 msgid "Queries that return tuples"
 msgstr "Consultas que retornam tuplas"
 
 #. Tag: para
-#: session_api.xml:298
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate queries sometimes return tuples of objects. Each tuple is returned "
 "as an array:"
 msgstr ""
-"Algumas vezes as consultas do Hibernate retornam tuplas de objetos, nesse "
-"caso cada tupla é retornada como um array:"
+"Algumas vezes as consultas do Hibernate retornam tuplas de objetos. Cada "
+"tupla é retornada como uma matriz:"
 
-#. Tag: programlisting
-#: session_api.xml:303
-#, no-c-format
-msgid ""
-"<![CDATA[Iterator kittensAndMothers = sess.createQuery(\n"
-"            \"select kitten, mother from Cat kitten join kitten.mother mother"
-"\")\n"
-"            .list()\n"
-"            .iterator();\n"
-"\n"
-"while ( kittensAndMothers.hasNext() ) {\n"
-"    Object[] tuple = (Object[]) kittensAndMothers.next();\n"
-"    Cat kitten = (Cat) tuple[0];\n"
-"    Cat mother = (Cat) tuple[1];\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:308
 #, no-c-format
 msgid "Scalar results"
 msgstr "Resultados escalares"
 
 #. Tag: para
-#: session_api.xml:310
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Queries can specify a property of a class in the <literal>select</literal> "
 "clause. They can even call SQL aggregate functions. Properties or aggregates "
 "are considered \"scalar\" results and not entities in persistent state."
 msgstr ""
-"Consultas devem especificar uma propriedade da classe na clausula "
+"As consultas devem especificar uma propriedade da classe na cláusula "
 "<literal>select</literal>. Elas também podem chamar funções SQL de "
-"agregaçãos. Propriedades ou agregações são considerados resultados agregados "
-"( e não entidades no estado persistente)."
+"agregações. Propriedades ou agregações são consideradas resultados agregados "
+"e não entidades no estado persistente. "
 
-#. Tag: programlisting
-#: session_api.xml:316
-#, no-c-format
-msgid ""
-"<![CDATA[Iterator results = sess.createQuery(\n"
-"        \"select cat.color, min(cat.birthdate), count(cat) from Cat cat \" "
-"+\n"
-"        \"group by cat.color\")\n"
-"        .list()\n"
-"        .iterator();\n"
-"\n"
-"while ( results.hasNext() ) {\n"
-"    Object[] row = (Object[]) results.next();\n"
-"    Color type = (Color) row[0];\n"
-"    Date oldest = (Date) row[1];\n"
-"    Integer count = (Integer) row[2];\n"
-"    .....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:321
 #, no-c-format
 msgid "Bind parameters"
-msgstr "Bind parameters"
+msgstr "Parâmetros de vínculo"
 
 #. Tag: para
-#: session_api.xml:323
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Methods on <literal>Query</literal> are provided for binding values to named "
 "parameters or JDBC-style <literal>?</literal> parameters. <emphasis>Contrary "
@@ -699,227 +602,120 @@
 "are identifiers of the form <literal>:name</literal> in the query string. "
 "The advantages of named parameters are as follows:"
 msgstr ""
-"Methods on <literal>Query</literal> are provided for binding values to named "
-"parameters or JDBC-style <literal>?</literal> parameters. <emphasis>Contrary "
-"to JDBC, Hibernate numbers parameters from zero.</emphasis> Named parameters "
-"are identifiers of the form <literal>:name</literal> in the query string. "
-"The advantages of named parameters are:"
+"Métodos em <literal>Consulta</literal> são oferecidos para valores de "
+"vínculo para parâmetros nomeados ou de estilo JDBC <literal>?</literal>. "
+"<emphasis>Ao contrário do JDBC, o Hibernate numera parâmetros a partir de "
+"zero.</emphasis> Parâmetros nomeados são identificadores da forma<literal>:"
+"name</literal> na faixa de consulta. As vantagens de parâmetros nomeados "
+"são: "
 
 #. Tag: para
-#: session_api.xml:333
 #, no-c-format
 msgid ""
 "named parameters are insensitive to the order they occur in the query string"
 msgstr ""
-"named parameters are insensitive to the order they occur in the query string"
+"Parâmetros nomeados são insensíveis à ordem que eles ocorrem na faixa de "
+"consulta"
 
 #. Tag: para
-#: session_api.xml:339
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "they can occur multiple times in the same query"
-msgstr "they may occur multiple times in the same query"
+msgstr "eles podem ocorrer em tempos múltiplos na mesma consulta "
 
 #. Tag: para
-#: session_api.xml:344
 #, no-c-format
 msgid "they are self-documenting"
-msgstr "they are self-documenting"
+msgstr "eles são auto documentáveis"
 
-#. Tag: programlisting
-#: session_api.xml:350
-#, no-c-format
-msgid ""
-"<![CDATA[//named parameter (preferred)\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name = :name"
-"\");\n"
-"q.setString(\"name\", \"Fritz\");\n"
-"Iterator cats = q.iterate();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:352
-#, no-c-format
-msgid ""
-"<![CDATA[//positional parameter\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name = ?\");\n"
-"q.setString(0, \"Izi\");\n"
-"Iterator cats = q.iterate();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:354
-#, no-c-format
-msgid ""
-"<![CDATA[//named parameter list\n"
-"List names = new ArrayList();\n"
-"names.add(\"Izi\");\n"
-"names.add(\"Fritz\");\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name in (:"
-"namesList)\");\n"
-"q.setParameterList(\"namesList\", names);\n"
-"List cats = q.list();]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:359
 #, no-c-format
 msgid "Pagination"
-msgstr "Pagination"
+msgstr "Paginação"
 
 #. Tag: para
-#: session_api.xml:361
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you need to specify bounds upon your result set, that is, the maximum "
 "number of rows you want to retrieve and/or the first row you want to "
 "retrieve, you can use methods of the <literal>Query</literal> interface:"
 msgstr ""
-"If you need to specify bounds upon your result set (the maximum number of "
-"rows you want to retrieve and / or the first row you want to retrieve) you "
-"should use methods of the <literal>Query</literal> interface:"
+"Se você precisar especificar vínculos do conjunto de resultados, o máximo de "
+"números por linha que quiser recuperar e/ou a primeira linha que quiser "
+"recuperar, você deve usar métodos de interface <literal>Consulta</literal>:"
 
-#. Tag: programlisting
-#: session_api.xml:367
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = sess.createQuery(\"from DomesticCat cat\");\n"
-"q.setFirstResult(20);\n"
-"q.setMaxResults(10);\n"
-"List cats = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:369
 #, no-c-format
 msgid ""
 "Hibernate knows how to translate this limit query into the native SQL of "
 "your DBMS."
 msgstr ""
-"Hibernate knows how to translate this limit query into the native SQL of "
-"your DBMS."
+"O Hibernate sabe como traduzir esta consulta de limite para a SQL nativa de "
+"seu DBMS"
 
 #. Tag: title
-#: session_api.xml:377
 #, no-c-format
 msgid "Scrollable iteration"
-msgstr "Scrollable iteration"
+msgstr "Iteração rolável"
 
 #. Tag: para
-#: session_api.xml:379
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your JDBC driver supports scrollable <literal>ResultSet</literal>s, the "
 "<literal>Query</literal> interface can be used to obtain a "
 "<literal>ScrollableResults</literal> object that allows flexible navigation "
 "of the query results."
 msgstr ""
-"If your JDBC driver supports scrollable <literal>ResultSet</literal>s, the "
-"<literal>Query</literal> interface may be used to obtain a "
-"<literal>ScrollableResults</literal> object, which allows flexible "
-"navigation of the query results."
+"Se seu driver JDBC driver suportar <literal>ResultSet</literal>s roláveis, a "
+"interface da <literal>Consulta</literal> poderá ser usada para obter um "
+"objeto de <literal>ScrollableResults</literal>, que permite uma navegação "
+"flexível dos resultados de consulta.  "
 
-#. Tag: programlisting
-#: session_api.xml:386
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Query q = sess.createQuery(\"select cat.name, cat from DomesticCat "
-"cat \" +\n"
-"                            \"order by cat.name\");\n"
-"ScrollableResults cats = q.scroll();\n"
-"if ( cats.first() ) {\n"
-"\n"
-"    // find the first name on each page of an alphabetical list of cats by "
-"name\n"
-"    firstNamesOfPages = new ArrayList();\n"
-"    do {\n"
-"        String name = cats.getString(0);\n"
-"        firstNamesOfPages.add(name);\n"
-"    }\n"
-"    while ( cats.scroll(PAGE_SIZE) );\n"
-"\n"
-"    // Now get the first page of cats\n"
-"    pageOfCats = new ArrayList();\n"
-"    cats.beforeFirst();\n"
-"    int i=0;\n"
-"    while( ( PAGE_SIZE > i++ ) && cats.next() ) pageOfCats.add( cats.get"
-"(1) );\n"
-"\n"
-"}\n"
-"cats.close()]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:388
-#, fuzzy, no-c-format
-msgid ""
 "Note that an open database connection and cursor is required for this "
 "functionality. Use <literal>setMaxResult()</literal>/<literal>setFirstResult"
 "()</literal> if you need offline pagination functionality."
 msgstr ""
-"Note that an open database connection (and cursor) is required for this "
-"functionality, use <literal>setMaxResult()</literal>/<literal>setFirstResult"
-"()</literal> if you need offline pagination functionality."
+"Note que uma conexão aberta de banco de dados (e cursor) é requerida para "
+"esta função, use <literal>setMaxResult()</literal>/<literal>setFirstResult()"
+"</literal> se precisar da função de paginação offline. "
 
 #. Tag: title
-#: session_api.xml:397
 #, no-c-format
 msgid "Externalizing named queries"
-msgstr "Externalizing named queries"
+msgstr "Externando consultas nomeadas"
 
 #. Tag: para
-#: session_api.xml:399
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also define named queries in the mapping document. Remember to use a "
 "<literal>CDATA</literal> section if your query contains characters that "
 "could be interpreted as markup."
 msgstr ""
-"You may also define named queries in the mapping document. (Remember to use "
-"a <literal>CDATA</literal> section if your query contains characters that "
-"could be interpreted as markup.)"
+"Você pode também definir consultas nomeadas no documento de mapeamento. "
+"Lembre-se de usar uma seção <literal>CDATA</literal> se sua consulta "
+"contiver caracteres que possam ser interpretados como marcação."
 
-#. Tag: programlisting
-#: session_api.xml:405
-#, no-c-format
-msgid ""
-"<![CDATA[<query name=\"ByNameAndMaximumWeight\"><![CDATA[\n"
-"    from eg.DomesticCat as cat\n"
-"        where cat.name = ?\n"
-"        and cat.weight > ?\n"
-"] ]></query>]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:407
 #, no-c-format
 msgid "Parameter binding and executing is done programatically:"
-msgstr "Parameter binding and executing is done programatically:"
+msgstr "O vínculo e execução de parâmetro são feitos programaticamente :"
 
-#. Tag: programlisting
-#: session_api.xml:411
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Query q = sess.getNamedQuery(\"ByNameAndMaximumWeight\");\n"
-"q.setString(0, name);\n"
-"q.setInt(1, minWeight);\n"
-"List cats = q.list();]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:413
-#, fuzzy, no-c-format
-msgid ""
 "The actual program code is independent of the query language that is used. "
 "You can also define native SQL queries in metadata, or migrate existing "
 "queries to Hibernate by placing them in mapping files."
 msgstr ""
-"Note that the actual program code is independent of the query language that "
-"is used, you may also define native SQL queries in metadata, or migrate "
-"existing queries to Hibernate by placing them in mapping files."
+"Note que o código de programa atual é independente da linguagem de consulta "
+"que é utilizada, você também pode definir as consultas SQL nativas no "
+"metadado, ou migrar consultas existentes para o Hibernate, colocando-os em "
+"arquivos de mapeamento. "
 
 #. Tag: para
-#: session_api.xml:419
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Also note that a query declaration inside a <literal>&lt;hibernate-"
 "mapping&gt;</literal> element requires a global unique name for the query, "
@@ -927,147 +723,96 @@
 "is made unique automatically by prepending the fully qualified name of the "
 "class. For example <literal>eg.Cat.ByNameAndMaximumWeight</literal>."
 msgstr ""
-"Also note that a query declaration inside a <literal>&lt;hibernate-"
-"mapping&gt;</literal> element requires a global unique name for the query, "
-"while a query declaration inside a <literal>&lt;class&gt;</literal> element "
-"is made unique automatically by prepending the fully qualified name of the "
-"class, for example <literal>eg.Cat.ByNameAndMaximumWeight</literal>."
+"Observe também que uma declaração de consulta dentro de um elemento "
+"<literal>&lt;hibernate-mapping&gt;</literal> requer um nome único global "
+"para a consulta, enquanto uma declaração de consulta dentro de um elemento "
+"de <literal>&lt;classe&gt;</literal> torna-se único automaticamente, "
+"aguardando o nome completo da classe qualificada, por exemplo: <literal>eg."
+"Cat.ByNameAndMaximumWeight</literal>. "
 
 #. Tag: title
-#: session_api.xml:432
 #, no-c-format
 msgid "Filtering collections"
-msgstr "Filtering collections"
+msgstr "Filtrando coleções"
 
 #. Tag: para
-#: session_api.xml:433
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A collection <emphasis>filter</emphasis> is a special type of query that can "
 "be applied to a persistent collection or array. The query string can refer "
 "to <literal>this</literal>, meaning the current collection element."
 msgstr ""
-"A collection <emphasis>filter</emphasis> is a special type of query that may "
-"be applied to a persistent collection or array. The query string may refer "
-"to <literal>this</literal>, meaning the current collection element."
+"Uma coleção <emphasis>filter</emphasis> é um tipo especial de consulta que "
+"pode ser aplicado a uma coleção persistente ou a uma matriz. A faixa de "
+"consulta pode referir-se ao <literal>this</literal>, significando o elemento "
+"de coleção atual. "
 
-#. Tag: programlisting
-#: session_api.xml:439
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Collection blackKittens = session.createFilter(\n"
-"    pk.getKittens(), \n"
-"    \"where this.color = ?\")\n"
-"    .setParameter( Color.BLACK, Hibernate.custom(ColorUserType.class) )\n"
-"    .list()\n"
-");]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:441
-#, fuzzy, no-c-format
-msgid ""
 "The returned collection is considered a bag that is a copy of the given "
 "collection. The original collection is not modified. This is contrary to the "
 "implication of the name \"filter\", but consistent with expected behavior."
 msgstr ""
-"The returned collection is considered a bag, and it's a copy of the given "
-"collection. The original collection is not modified (this is contrary to the "
-"implication of the name \"filter\", but consistent with expected behavior)."
+"A coleção retornada é considerada uma bolsa, e é a cópia da coleção dada. A "
+"coleção original não é modificada. Ela é oposta à implicação do nome \"filtro"
+"\", mas é consistente com o comportamento esperado."
 
 #. Tag: para
-#: session_api.xml:447
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Observe that filters do not require a <literal>from</literal> clause, "
 "although they can have one if required. Filters are not limited to returning "
 "the collection elements themselves."
 msgstr ""
-"Observe that filters do not require a <literal>from</literal> clause (though "
-"they may have one if required). Filters are not limited to returning the "
-"collection elements themselves."
+"Observe que os filtros não requerem uma cláusula <literal>from</literal> "
+"embora possam ter um, se requerido. Os filtros não são limitados a retornar "
+"aos elementos de coleção. "
 
-#. Tag: programlisting
-#: session_api.xml:452
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Collection blackKittenMates = session.createFilter(\n"
-"    pk.getKittens(), \n"
-"    \"select this.mate where this.color = eg.Color.BLACK.intValue\")\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:454
-#, fuzzy, no-c-format
-msgid ""
 "Even an empty filter query is useful, e.g. to load a subset of elements in a "
 "large collection:"
 msgstr ""
-"Even an empty filter query is useful, e.g. to load a subset of elements in a "
-"huge collection:"
+"Até mesmo um filtro vazio é útil, ex.: para carregar um subconjunto em uma "
+"coleção enorme:"
 
-#. Tag: programlisting
-#: session_api.xml:459
-#, no-c-format
-msgid ""
-"<![CDATA[Collection tenKittens = session.createFilter(\n"
-"    mother.getKittens(), \"\")\n"
-"    .setFirstResult(0).setMaxResults(10)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:464
 #, no-c-format
 msgid "Criteria queries"
-msgstr "Criteria queries"
+msgstr "Consulta por critério"
 
 #. Tag: para
-#: session_api.xml:466
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL is extremely powerful, but some developers prefer to build queries "
 "dynamically using an object-oriented API, rather than building query "
 "strings. Hibernate provides an intuitive <literal>Criteria</literal> query "
 "API for these cases:"
 msgstr ""
-"HQL is extremely powerful but some developers prefer to build queries "
-"dynamically, using an object-oriented API, rather than building query "
-"strings. Hibernate provides an intuitive <literal>Criteria</literal> query "
-"API for these cases:"
+"O HQL é extremamente potente mas alguns desenvolvedores preferem construir "
+"consultas de forma dinâmica, utilizando um API de objeto, ao invés de "
+"construir faixas de consultas. O Hibernate oferece uma API de consulta de "
+"<literal>Critério</literal> intuitiva para estes casos: "
 
-#. Tag: programlisting
-#: session_api.xml:472
-#, no-c-format
-msgid ""
-"<![CDATA[Criteria crit = session.createCriteria(Cat.class);\n"
-"crit.add( Restrictions.eq( \"color\", eg.Color.BLACK ) );\n"
-"crit.setMaxResults(10);\n"
-"List cats = crit.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:474
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The <literal>Criteria</literal> and the associated <literal>Example</"
-"literal> API are discussed in more detail in <xref linkend=\"querycriteria\"/"
-">."
+"literal> API are discussed in more detail in <xref linkend=\"querycriteria"
+"\" />."
 msgstr ""
-"The <literal>Criteria</literal> and the associated <literal>Example</"
-"literal> API are discussed in more detail in <xref linkend=\"querycriteria\"/"
-">."
+"Um <literal>Criteria</literal> e API associado <literal>Example</literal> "
+"serão discutidos em mais detalhes em <xref linkend=\"querycriteria\"/>. "
 
 #. Tag: title
-#: session_api.xml:482
 #, no-c-format
 msgid "Queries in native SQL"
-msgstr "Queries in native SQL"
+msgstr "Consultas em SQL nativa"
 
 #. Tag: para
-#: session_api.xml:484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can express a query in SQL, using <literal>createSQLQuery()</literal> "
 "and let Hibernate manage the mapping from result sets to objects. You can at "
@@ -1075,56 +820,31 @@
 "<literal>Connection</literal> directly. If you choose to use the Hibernate "
 "API, you must enclose SQL aliases in braces:"
 msgstr ""
-"You may express a query in SQL, using <literal>createSQLQuery()</literal> "
-"and let Hibernate take care of the mapping from result sets to objects. Note "
-"that you may at any time call <literal>session.connection()</literal> and "
-"use the JDBC <literal>Connection</literal> directly. If you chose to use the "
-"Hibernate API, you must enclose SQL aliases in braces:"
+"Você pode expressar uma consulta em SQL utilizando <literal>createSQLQuery()"
+"</literal> e deixar o Hibernate tomar conta do mapeamento desde conjuntos de "
+"resultados até objetos. Note que você pode chamar uma <literal>session."
+"connection()</literal> a qualquer momento e usar a <literal>Connection</"
+"literal> JDBC diretamente. Se você escolher utilizar a API Hibernate, você "
+"deve incluir as aliases SQL dentro de chaves: "
 
-#. Tag: programlisting
-#: session_api.xml:492
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = session.createSQLQuery(\"SELECT {cat.*} FROM CAT {cat} "
-"WHERE ROWNUM<10\")\n"
-"    .addEntity(\"cat\", Cat.class)\n"
-".list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:494
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = session.createSQLQuery(\n"
-"    \"SELECT {cat}.ID AS {cat.id}, {cat}.SEX AS {cat.sex}, \" +\n"
-"           \"{cat}.MATE AS {cat.mate}, {cat}.SUBCLASS AS {cat.class}, ... \" "
-"+\n"
-"    \"FROM CAT {cat} WHERE ROWNUM<10\")\n"
-"    .addEntity(\"cat\", Cat.class)\n"
-".list()]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:496
 #, fuzzy, no-c-format
 msgid ""
 "SQL queries can contain named and positional parameters, just like Hibernate "
 "queries. More information about native SQL queries in Hibernate can be found "
-"in <xref linkend=\"querysql\"/>."
+"in <xref linkend=\"querysql\" />."
 msgstr ""
-"SQL queries may contain named and positional parameters, just like Hibernate "
-"queries. More information about native SQL queries in Hibernate can be found "
-"in <xref linkend=\"querysql\"/>."
+"As consultas SQL podem conter parâmetros nomeados e posicionais, assim como "
+"as consultas Hibernate. Maiores informações sobre as consultas nativas SQL "
+"no Hibernate poderão ser encontradas em <xref linkend=\"querysql\" />."
 
 #. Tag: title
-#: session_api.xml:507
 #, no-c-format
 msgid "Modifying persistent objects"
-msgstr "Modifying persistent objects"
+msgstr "Modificando objetos persistentes"
 
 #. Tag: para
-#: session_api.xml:509
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Transactional persistent instances</emphasis> (i.e. objects "
 "loaded, saved, created or queried by the <literal>Session</literal>) can be "
@@ -1136,43 +856,32 @@
 "to update the state of an object is to <literal>load()</literal> it and then "
 "manipulate it directly while the <literal>Session</literal> is open:"
 msgstr ""
-"<emphasis>Transactional persistent instances</emphasis> (ie. objects loaded, "
-"saved, created or queried by the <literal>Session</literal>) may be "
-"manipulated by the application and any changes to persistent state will be "
-"persisted when the <literal>Session</literal> is <emphasis>flushed</"
-"emphasis> (discussed later in this chapter). There is no need to call a "
-"particular method (like <literal>update()</literal>, which has a different "
-"purpose) to make your modifications persistent. So the most straightforward "
-"way to update the state of an object is to <literal>load()</literal> it, and "
-"then manipulate it directly, while the <literal>Session</literal> is open:"
+"<emphasis>Instâncias persistentes transacionais</emphasis> (ou seja, objetos "
+"carregados, salvos, criados ou consultados pela <literal>Session</literal>) "
+"podem ser manipuladas pela aplicação e qualquer mudança para estado "
+"persistente será persistida quando a <literal>Sessão</literal> for "
+"<emphasis>limpa</emphasis>. Isto será discutido mais adiante neste capítulo. "
+"Não há necessidade de chamar um método em particular (como <literal>update()"
+"</literal>, que possui um propósito diferente) para fazer modificações "
+"persistentes. Portanto, a forma mais direta de atualizar o estado de um "
+"objeto é <literal>carregá-lo()</literal> e depois manipulá-lo diretamente, "
+"enquanto a <literal>Sessão</literal> estiver aberta:"
 
-#. Tag: programlisting
-#: session_api.xml:520
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DomesticCat cat = (DomesticCat) sess.load( Cat.class, new Long"
-"(69) );\n"
-"cat.setName(\"PK\");\n"
-"sess.flush();  // changes to cat are automatically detected and persisted]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:522
-#, fuzzy, no-c-format
-msgid ""
 "Sometimes this programming model is inefficient, as it requires in the same "
 "session both an SQL <literal>SELECT</literal> to load an object and an SQL "
 "<literal>UPDATE</literal> to persist its updated state. Hibernate offers an "
 "alternate approach by using detached instances."
 msgstr ""
-"Sometimes this programming model is inefficient since it would require both "
-"an SQL <literal>SELECT</literal> (to load an object) and an SQL "
-"<literal>UPDATE</literal> (to persist its updated state) in the same "
-"session. Therefore Hibernate offers an alternate approach, using detached "
-"instances."
+"Algumas vezes, este modelo de programação é ineficiente, uma vez que ele "
+"requer ambos SQL <literal>SELECT</literal> (para carregar um objeto) e um "
+"SQL<literal>UPDATE</literal> (para persistir seu estado atualizado) na mesma "
+"sessão. Por isso, o Hibernate oferece uma abordagem alternativa, usando "
+"instâncias desanexadas."
 
 #. Tag: para
-#: session_api.xml:529
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate does not offer its own API for direct execution of "
@@ -1184,26 +893,26 @@
 "the notion of mass operations conflicts with object/relational mapping for "
 "online transaction processing-oriented applications. Future versions of "
 "Hibernate can, however, provide special mass operation functions. See <xref "
-"linkend=\"batch\"/> for some possible batch operation tricks."
+"linkend=\"batch\" /> for some possible batch operation tricks."
 msgstr ""
-"Note that Hibernate does not offer its own API for direct execution of "
-"<placeholder-1/> or <placeholder-2/> statements. Hibernate is a <placeholder-"
-"3/> service, you don't have to think in <placeholder-4/> to use it. JDBC is "
-"a perfect API for executing SQL statements, you can get a JDBC <placeholder-"
-"5/> at any time by calling <placeholder-6/>. Furthermore, the notion of mass "
-"operations conflicts with object/relational mapping for online transaction "
-"processing-oriented applications. Future versions of Hibernate may however "
-"provide special mass operation functions. See <xref linkend=\"batch\"/> for "
-"some possible batch operation tricks."
+"Note que o Hibernate não oferece seu próprio API para execução direta de "
+"instruções <literal>UPDATE</literal> ou <literal>DELETE</literal>. O "
+"Hibernate é um serviço de <emphasis>gerenciamento de estado</emphasis> que "
+"você nem precisa se preocupar com <emphasis>instruções</emphasis> para "
+"utilizá-lo. O JDBC é um API perfeito para executar instruções SQL, você pode "
+"ter uma <literal>Connection</literal> JDBC a qualquer momento, chamando "
+"<literal>session.connection()</literal>. Além disso, a noção de operações em "
+"massa conflitua com o mapeamento de objeto/relacional para aplicativos de "
+"transações online com processamento. No entanto, versões futuras do "
+"Hibernate poderão oferecer funções especiais de operação em massa. Veja "
+"<xref linkend=\"batch\"/> para alguns possíveis truques de operação em lote. "
 
 #. Tag: title
-#: session_api.xml:546
 #, no-c-format
 msgid "Modifying detached objects"
-msgstr "Modifying detached objects"
+msgstr "Modificando objetos desacoplados"
 
 #. Tag: para
-#: session_api.xml:548
 #, no-c-format
 msgid ""
 "Many applications need to retrieve an object in one transaction, send it to "
@@ -1212,56 +921,36 @@
 "environment usually use versioned data to ensure isolation for the \"long\" "
 "unit of work."
 msgstr ""
-"Many applications need to retrieve an object in one transaction, send it to "
-"the UI layer for manipulation, then save the changes in a new transaction. "
-"Applications that use this kind of approach in a high-concurrency "
-"environment usually use versioned data to ensure isolation for the \"long\" "
-"unit of work."
+"Muitas aplicações precisam recuperar um objeto em uma transação, enviá-lo "
+"para a camada UI para manipulação e somente então salvar as mudanças em uma "
+"nova transação. As aplicações que usam este tipo de abordagem em ambiente de "
+"alta concorrência, geralmente usam dados versionados para assegurar isolação "
+"durante a \"longa\" unidade de trabalho."
 
 #. Tag: para
-#: session_api.xml:555
 #, no-c-format
 msgid ""
 "Hibernate supports this model by providing for reattachment of detached "
 "instances using the <literal>Session.update()</literal> or <literal>Session."
 "merge()</literal> methods:"
 msgstr ""
-"Hibernate supports this model by providing for reattachment of detached "
-"instances using the <literal>Session.update()</literal> or <literal>Session."
-"merge()</literal> methods:"
+"O Hibernate suporta este modelo, oferecendo re-acoplamentos das instâncias "
+"usando os métodos <literal>Session.update()</literal> ou<literal>Session."
+"merge()</literal>:"
 
-#. Tag: programlisting
-#: session_api.xml:561
-#, no-c-format
-msgid ""
-"<![CDATA[// in the first session\n"
-"Cat cat = (Cat) firstSession.load(Cat.class, catId);\n"
-"Cat potentialMate = new Cat();\n"
-"firstSession.save(potentialMate);\n"
-"\n"
-"// in a higher layer of the application\n"
-"cat.setMate(potentialMate);\n"
-"\n"
-"// later, in a new session\n"
-"secondSession.update(cat);  // update cat\n"
-"secondSession.update(mate); // update mate]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:563
 #, no-c-format
 msgid ""
 "If the <literal>Cat</literal> with identifier <literal>catId</literal> had "
 "already been loaded by <literal>secondSession</literal> when the application "
 "tried to reattach it, an exception would have been thrown."
 msgstr ""
-"If the <literal>Cat</literal> with identifier <literal>catId</literal> had "
-"already been loaded by <literal>secondSession</literal> when the application "
-"tried to reattach it, an exception would have been thrown."
+"Se o <literal>Cat</literal> com identificador <literal>catId</literal> já "
+"tivesse sido carregado pela<literal>segundaSessão</literal> quando a "
+"aplicação tentou re-acoplá-lo, teria surgido uma exceção."
 
 #. Tag: para
-#: session_api.xml:569
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use <literal>update()</literal> if you are certain that the session does not "
 "contain an already persistent instance with the same identifier. Use "
@@ -1271,86 +960,69 @@
 "fresh session, ensuring that the reattachment of your detached instances is "
 "the first operation that is executed."
 msgstr ""
-"Use <literal>update()</literal> if you are sure that the session does not "
-"contain an already persistent instance with the same identifier, and "
-"<literal>merge()</literal> if you want to merge your modifications at any "
-"time without consideration of the state of the session. In other words, "
-"<literal>update()</literal> is usually the first method you would call in a "
-"fresh session, ensuring that reattachment of your detached instances is the "
-"first operation that is executed."
+"Use <literal>update()</literal> se você tiver certeza de que a sessão já não "
+"contém uma instância persistente com o mesmo identificador, e <literal>merge"
+"()</literal> se você quiser mesclar suas modificações a qualquer momento sem "
+"considerar o estado da sessão. Em outras palavras, <literal>update()</"
+"literal> é geralmente o primeiro método que você chama em uma nova sessão, "
+"assegurando que o re-acoplamento de suas instâncias seja a primeira operação "
+"executada. "
 
 #. Tag: para
-#: session_api.xml:578
 #, fuzzy, no-c-format
 msgid ""
 "The application should individually <literal>update()</literal> detached "
 "instances that are reachable from the given detached instance "
 "<emphasis>only</emphasis> if it wants their state to be updated. This can be "
 "automated using <emphasis>transitive persistence</emphasis>. See <xref "
-"linkend=\"objectstate-transitive\"/> for more information."
+"linkend=\"objectstate-transitive\" /> for more information."
 msgstr ""
-"The application should individually <literal>update()</literal> detached "
-"instances reachable from the given detached instance if and <emphasis>only</"
-"emphasis> if it wants their state also updated. This can be automated of "
-"course, using <emphasis>transitive persistence</emphasis>, see <xref linkend="
-"\"objectstate-transitive\"/>."
+"A aplicação deve <literal>update()</literal> instâncias desanexadas "
+"individualmente, ao alcance da atual instância desanexada, se e "
+"<emphasis>somente</emphasis> se, esta requerer uma atualização também de seu "
+"estado. Esta ação pode ser automatizada, é claro, utilizando "
+"<emphasis>persistência transitiva</emphasis>, veja <xref linkend="
+"\"objectstate-transitive\"/> para maiores informações. "
 
 #. Tag: para
-#: session_api.xml:585
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>lock()</literal> method also allows an application to "
 "reassociate an object with a new session. However, the detached instance has "
 "to be unmodified."
 msgstr ""
-"The <literal>lock()</literal> method also allows an application to "
-"reassociate an object with a new session. However, the detached instance has "
-"to be unmodified!"
+"O método <literal>lock()</literal> também permite que um aplicativo re-"
+"associe um objeto com uma nova sessão. No entanto, a instância desanexada "
+"não pode ser modificada."
 
-#. Tag: programlisting
-#: session_api.xml:590
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[//just reassociate:\n"
-"sess.lock(fritz, LockMode.NONE);\n"
-"//do a version check, then reassociate:\n"
-"sess.lock(izi, LockMode.READ);\n"
-"//do a version check, using SELECT ... FOR UPDATE, then reassociate:\n"
-"sess.lock(pk, LockMode.UPGRADE);]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:592
-#, fuzzy, no-c-format
-msgid ""
 "Note that <literal>lock()</literal> can be used with various "
 "<literal>LockMode</literal>s. See the API documentation and the chapter on "
 "transaction handling for more information. Reattachment is not the only "
 "usecase for <literal>lock()</literal>."
 msgstr ""
-"Note that <literal>lock()</literal> can be used with various "
-"<literal>LockMode</literal>s, see the API documentation and the chapter on "
-"transaction handling for more information. Reattachment is not the only "
-"usecase for <literal>lock()</literal>."
+"Note que <literal>lock()</literal> pode ser usado com diversos "
+"<literal>LockMode</literal>s, veja a documentação API e o capítulo sobre "
+"manuseio de transações para maiores informações. Re-acoplamento não é o "
+"único caso de uso para <literal>lock()</literal>.  "
 
 #. Tag: para
-#: session_api.xml:599
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Other models for long units of work are discussed in <xref linkend="
-"\"transactions-optimistic\"/>."
+"\"transactions-optimistic\" />."
 msgstr ""
-"Other models for long units of work are discussed in <xref linkend="
-"\"transactions-optimistic\"/>."
+"Outros modelos para unidades longas de trabalho serão discutidas em <xref "
+"linkend=\"transactions-optimistic\"/>. "
 
 #. Tag: title
-#: session_api.xml:606
 #, no-c-format
 msgid "Automatic state detection"
-msgstr "Automatic state detection"
+msgstr "Detecção automática de estado"
 
 #. Tag: para
-#: session_api.xml:608
 #, no-c-format
 msgid ""
 "Hibernate users have requested a general purpose method that either saves a "
@@ -1358,31 +1030,12 @@
 "detached instances associated with its current identifier. The "
 "<literal>saveOrUpdate()</literal> method implements this functionality."
 msgstr ""
-"Hibernate users have requested a general purpose method that either saves a "
-"transient instance by generating a new identifier or updates/reattaches the "
-"detached instances associated with its current identifier. The "
-"<literal>saveOrUpdate()</literal> method implements this functionality."
+"Os usuários de Hibernate solicitaram um método geral, tanto para salvar uma "
+"instância transiente, gerando um novo identificador, quanto para atualizar/ "
+"re-acoplar as instâncias desanexadas associadas ao seu identificador atual. "
+"O método <literal>saveOrUpdate()</literal> implementa esta funcionalidade."
 
-#. Tag: programlisting
-#: session_api.xml:615
-#, no-c-format
-msgid ""
-"<![CDATA[// in the first session\n"
-"Cat cat = (Cat) firstSession.load(Cat.class, catID);\n"
-"\n"
-"// in a higher tier of the application\n"
-"Cat mate = new Cat();\n"
-"cat.setMate(mate);\n"
-"\n"
-"// later, in a new session\n"
-"secondSession.saveOrUpdate(cat);   // update existing state (cat has a non-"
-"null id)\n"
-"secondSession.saveOrUpdate(mate);  // save the new instance (mate has a null "
-"id)]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:617
 #, no-c-format
 msgid ""
 "The usage and semantics of <literal>saveOrUpdate()</literal> seems to be "
@@ -1392,290 +1045,240 @@
 "<literal>merge()</literal>. Some whole applications will never use either of "
 "these methods."
 msgstr ""
-"The usage and semantics of <literal>saveOrUpdate()</literal> seems to be "
-"confusing for new users. Firstly, so long as you are not trying to use "
-"instances from one session in another new session, you should not need to "
-"use <literal>update()</literal>, <literal>saveOrUpdate()</literal>, or "
-"<literal>merge()</literal>. Some whole applications will never use either of "
-"these methods."
+"O uso e semântica do <literal>saveOrUpdate()</literal> parecem ser confusos "
+"para novos usuários. A princípio, enquanto você não tentar usar instâncias "
+"de uma sessão em outra nova sessão, não precisará utilizar <literal>update()"
+"</literal>, <literal>saveOrUpdate()</literal>, ou <literal>merge()</"
+"literal>. Algumas aplicações inteiras nunca precisarão utilizar estes "
+"métodos."
 
 #. Tag: para
-#: session_api.xml:625
 #, no-c-format
 msgid ""
 "Usually <literal>update()</literal> or <literal>saveOrUpdate()</literal> are "
 "used in the following scenario:"
 msgstr ""
-"Usually <literal>update()</literal> or <literal>saveOrUpdate()</literal> are "
-"used in the following scenario:"
+"Geralmente, <literal>update()</literal> ou <literal>saveOrUpdate()</"
+"literal>são utilizados nos seguintes cenários:"
 
 #. Tag: para
-#: session_api.xml:632
 #, no-c-format
 msgid "the application loads an object in the first session"
-msgstr "the application loads an object in the first session"
+msgstr "a aplicação carrega um objeto na primeira sessão"
 
 #. Tag: para
-#: session_api.xml:637
 #, no-c-format
 msgid "the object is passed up to the UI tier"
-msgstr "the object is passed up to the UI tier"
+msgstr "o objeto é passado para a camada UI"
 
 #. Tag: para
-#: session_api.xml:642
 #, no-c-format
 msgid "some modifications are made to the object"
-msgstr "some modifications are made to the object"
+msgstr "algumas modificações são feitas ao objeto"
 
 #. Tag: para
-#: session_api.xml:647
 #, no-c-format
 msgid "the object is passed back down to the business logic tier"
-msgstr "the object is passed back down to the business logic tier"
+msgstr "o objeto é retornado à camada lógica de negócios"
 
 #. Tag: para
-#: session_api.xml:652
 #, no-c-format
 msgid ""
 "the application persists these modifications by calling <literal>update()</"
 "literal> in a second session"
 msgstr ""
-"the application persists these modifications by calling <literal>update()</"
-"literal> in a second session"
+"a aplicação persiste estas modificações, chamando <literal>update()</"
+"literal> em uma segunda sessão."
 
 #. Tag: para
-#: session_api.xml:659
 #, no-c-format
 msgid "<literal>saveOrUpdate()</literal> does the following:"
-msgstr "<literal>saveOrUpdate()</literal> does the following:"
+msgstr "<literal>saveOrUpdate()</literal> faz o seguinte:"
 
 #. Tag: para
-#: session_api.xml:665
 #, no-c-format
 msgid "if the object is already persistent in this session, do nothing"
-msgstr "if the object is already persistent in this session, do nothing"
+msgstr "se o objeto já estiver persistente nesta sessão, não faça nada"
 
 #. Tag: para
-#: session_api.xml:670
 #, no-c-format
 msgid ""
 "if another object associated with the session has the same identifier, throw "
 "an exception"
 msgstr ""
-"if another object associated with the session has the same identifier, throw "
-"an exception"
+"se outro objeto associado com a sessão possuir o mesmo identificador, jogue "
+"uma exceção"
 
 #. Tag: para
-#: session_api.xml:676
 #, no-c-format
 msgid "if the object has no identifier property, <literal>save()</literal> it"
-msgstr "if the object has no identifier property, <literal>save()</literal> it"
+msgstr ""
+"se o objeto não tiver uma propriedade de identificador <literal>salve-o()</"
+"literal> "
 
 #. Tag: para
-#: session_api.xml:681
 #, no-c-format
 msgid ""
 "if the object's identifier has the value assigned to a newly instantiated "
 "object, <literal>save()</literal> it"
 msgstr ""
-"if the object's identifier has the value assigned to a newly instantiated "
-"object, <literal>save()</literal> it"
+"se o identificador do objeto possuir o valor atribuído ao objeto "
+"recentemente instanciado, <literal>salve-o()</literal> "
 
 #. Tag: para
-#: session_api.xml:687
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "if the object is versioned by a <literal>&lt;version&gt;</literal> or "
 "<literal>&lt;timestamp&gt;</literal>, and the version property value is the "
 "same value assigned to a newly instantiated object, <literal>save()</"
 "literal> it"
 msgstr ""
-"if the object is versioned (by a <literal>&lt;version&gt;</literal> or "
-"<literal>&lt;timestamp&gt;</literal>), and the version property value is the "
-"same value assigned to a newly instantiated object, <literal>save()</"
-"literal> it"
+"se o objeto for versionado por um <literal>&lt;version&gt;</literal> ou "
+"<literal>&lt;timestamp&gt;</literal>, e o valor da propriedade da versão for "
+"o mesmo valor atribuído ao objeto recentemente instanciado, <literal>salve()"
+"</literal> o mesmo"
 
 #. Tag: para
-#: session_api.xml:695
 #, no-c-format
 msgid "otherwise <literal>update()</literal> the object"
-msgstr "otherwise <literal>update()</literal> the object"
+msgstr "do contrário <literal>atualize()</literal> o objeto"
 
 #. Tag: para
-#: session_api.xml:701
 #, no-c-format
 msgid "and <literal>merge()</literal> is very different:"
-msgstr "and <literal>merge()</literal> is very different:"
+msgstr "e a <literal>mesclagem()</literal> é bastante diferente:"
 
 #. Tag: para
-#: session_api.xml:707
 #, no-c-format
 msgid ""
 "if there is a persistent instance with the same identifier currently "
 "associated with the session, copy the state of the given object onto the "
 "persistent instance"
 msgstr ""
-"if there is a persistent instance with the same identifier currently "
-"associated with the session, copy the state of the given object onto the "
-"persistent instance"
+"se existir uma instância persistente com um mesmo identificador associado "
+"atualmente com a sessão, copie o estado do objeto dado para a instância "
+"persistente."
 
 #. Tag: para
-#: session_api.xml:714
 #, no-c-format
 msgid ""
 "if there is no persistent instance currently associated with the session, "
 "try to load it from the database, or create a new persistent instance"
 msgstr ""
-"if there is no persistent instance currently associated with the session, "
-"try to load it from the database, or create a new persistent instance"
+"se não existir uma instância persistente atualmente associada com a sessão, "
+"tente carregá-la a partir do banco de dados, ou crie uma nova instância "
+"persistente"
 
 #. Tag: para
-#: session_api.xml:720
 #, no-c-format
 msgid "the persistent instance is returned"
-msgstr "the persistent instance is returned"
+msgstr "a instância persistente é retornada"
 
 #. Tag: para
-#: session_api.xml:725
 #, no-c-format
 msgid ""
 "the given instance does not become associated with the session, it remains "
 "detached"
 msgstr ""
-"the given instance does not become associated with the session, it remains "
-"detached"
+"a instância dada não se torna associada com a sessão, ela permanece "
+"desanexada"
 
 #. Tag: title
-#: session_api.xml:735
 #, no-c-format
 msgid "Deleting persistent objects"
-msgstr "Deleting persistent objects"
+msgstr "Apagando objetos persistentes"
 
 #. Tag: para
-#: session_api.xml:737
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Session.delete()</literal> will remove an object's state from the "
 "database. Your application, however, can still hold a reference to a deleted "
 "object. It is best to think of <literal>delete()</literal> as making a "
 "persistent instance, transient."
 msgstr ""
-"<literal>Session.delete()</literal> will remove an object's state from the "
-"database. Of course, your application might still hold a reference to a "
-"deleted object. It's best to think of <literal>delete()</literal> as making "
-"a persistent instance transient."
+"A <literal>Session.delete()</literal> removerá um estado de objeto do banco "
+"de dados. É claro que seu aplicativo pode ainda reter uma referência à um "
+"objeto apagado. É melhor pensar em <literal>delete()</literal> como fazer "
+"uma instância persistente se tornar transiente.  "
 
-#. Tag: programlisting
-#: session_api.xml:744
-#, no-c-format
-msgid "<![CDATA[sess.delete(cat);]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:746
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can delete objects in any order, without risk of foreign key constraint "
 "violations. It is still possible to violate a <literal>NOT NULL</literal> "
 "constraint on a foreign key column by deleting objects in the wrong order, e."
 "g. if you delete the parent, but forget to delete the children."
 msgstr ""
-"You may delete objects in any order you like, without risk of foreign key "
-"constraint violations. It is still possible to violate a <literal>NOT NULL</"
-"literal> constraint on a foreign key column by deleting objects in the wrong "
-"order, e.g. if you delete the parent, but forget to delete the children."
+"Você poderá deletar objetos na ordem que desejar, sem risco de violação de "
+"restrição da chave estrangeira.  É possível violar uma restrição "
+"<literal>NOT NULL</literal> em uma coluna de chave estrangeira, apagando "
+"objetos na ordem inversa, ex.: se apagar o pai, mas esquecer de apagar o "
+"filho.  "
 
 #. Tag: title
-#: session_api.xml:757
 #, no-c-format
 msgid "Replicating object between two different datastores"
-msgstr "Replicating object between two different datastores"
+msgstr "Replicando objeto entre dois armazenamentos de dados diferentes."
 
 #. Tag: para
-#: session_api.xml:759
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is sometimes useful to be able to take a graph of persistent instances "
 "and make them persistent in a different datastore, without regenerating "
 "identifier values."
 msgstr ""
-"It is occasionally useful to be able to take a graph of persistent instances "
-"and make them persistent in a different datastore, without regenerating "
-"identifier values."
+"Algumas vezes é útil poder tirar um gráfico de instâncias persistentes e "
+"fazê-los persistentes em um armazenamento de dados diferente, sem gerar "
+"novamente valores de identificador. "
 
-#. Tag: programlisting
-#: session_api.xml:765
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[//retrieve a cat from one database\n"
-"Session session1 = factory1.openSession();\n"
-"Transaction tx1 = session1.beginTransaction();\n"
-"Cat cat = session1.get(Cat.class, catId);\n"
-"tx1.commit();\n"
-"session1.close();\n"
-"\n"
-"//reconcile with a second database\n"
-"Session session2 = factory2.openSession();\n"
-"Transaction tx2 = session2.beginTransaction();\n"
-"session2.replicate(cat, ReplicationMode.LATEST_VERSION);\n"
-"tx2.commit();\n"
-"session2.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:767
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>ReplicationMode</literal> determines how <literal>replicate()</"
 "literal> will deal with conflicts with existing rows in the database:"
 msgstr ""
-"The <literal>ReplicationMode</literal> determines how <literal>replicate()</"
-"literal> will deal with conflicts with existing rows in the database."
+"O <literal>ReplicationMode</literal> determina como o <literal>replicate()</"
+"literal> irá lidar com conflitos em linhas existentes no banco de dados: "
 
 #. Tag: para
-#: session_api.xml:774
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.IGNORE</literal>: ignores the object when there is "
 "an existing database row with the same identifier"
 msgstr ""
-"<literal>ReplicationMode.IGNORE</literal> - ignore the object when there is "
-"an existing database row with the same identifier"
+"<literal>ReplicationMode.IGNORE</literal>: ignore o objeto quando houver uma "
+"linha de banco de dados existente com o mesmo identificador."
 
 #. Tag: para
-#: session_api.xml:780
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.OVERWRITE</literal>: overwrites any existing "
 "database row with the same identifier"
 msgstr ""
-"<literal>ReplicationMode.OVERWRITE</literal> - overwrite any existing "
-"database row with the same identifier"
+"<literal>ReplicationMode.OVERWRITE</literal>: subscreva uma linha de banco "
+"de dados existente com um mesmo identificador."
 
 #. Tag: para
-#: session_api.xml:786
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.EXCEPTION</literal>: throws an exception if there "
 "is an existing database row with the same identifier"
 msgstr ""
-"<literal>ReplicationMode.EXCEPTION</literal> - throw an exception if there "
-"is an existing database row with the same identifier"
+"<literal>ReplicationMode.EXCEPTION</literal>: jogue uma exceção se houver "
+"uma linha de banco de dados existente com o mesmo identificador. "
 
 #. Tag: para
-#: session_api.xml:792
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.LATEST_VERSION</literal>: overwrites the row if its "
 "version number is earlier than the version number of the object, or ignore "
 "the object otherwise"
 msgstr ""
-"<literal>ReplicationMode.LATEST_VERSION</literal> - overwrite the row if its "
-"version number is earlier than the version number of the object, or ignore "
-"the object otherwise"
+"<literal>ReplicationMode.LATEST_VERSION</literal>: subscreva a linha se seu "
+"número de versão for anterior ao número de versão do objeto, caso contrário, "
+"ignore o objeto."
 
 #. Tag: para
-#: session_api.xml:800
 #, no-c-format
 msgid ""
 "Usecases for this feature include reconciling data entered into different "
@@ -1683,112 +1286,98 @@
 "product upgrades, rolling back changes made during non-ACID transactions and "
 "more."
 msgstr ""
-"Usecases for this feature include reconciling data entered into different "
-"database instances, upgrading system configuration information during "
-"product upgrades, rolling back changes made during non-ACID transactions and "
-"more."
+"O caso de uso para este recurso inclui dados de reconciliação em instâncias "
+"de banco de dados diferentes, atualizando informações da configuração do "
+"sistema durante a atualização do produto, retornando mudanças realizadas "
+"durante transações não ACID entre outras funções."
 
 #. Tag: title
-#: session_api.xml:809
 #, no-c-format
 msgid "Flushing the Session"
-msgstr "Flushing the Session"
+msgstr "Limpando a Sessão"
 
 #. Tag: para
-#: session_api.xml:811
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes the <literal>Session</literal> will execute the SQL statements "
 "needed to synchronize the JDBC connection's state with the state of objects "
 "held in memory. This process, called <emphasis>flush</emphasis>, occurs by "
 "default at the following points:"
 msgstr ""
-"From time to time the <literal>Session</literal> will execute the SQL "
-"statements needed to synchronize the JDBC connection's state with the state "
-"of objects held in memory. This process, <emphasis>flush</emphasis>, occurs "
-"by default at the following points"
+"De vez em quando, a <literal>Session</literal> irá executar as instruções "
+"SQL, necessárias para sincronizar o estado de conexão JDBC com o estado de "
+"objetos mantidos na memória. Este processo de <emphasis>flush</emphasis>, "
+"ocorre por padrão nos seguintes pontos: "
 
 #. Tag: para
-#: session_api.xml:820
 #, no-c-format
 msgid "before some query executions"
-msgstr "before some query executions"
+msgstr "antes de algumas execuções de consultas"
 
 #. Tag: para
-#: session_api.xml:825
 #, no-c-format
 msgid "from <literal>org.hibernate.Transaction.commit()</literal>"
-msgstr "from <literal>org.hibernate.Transaction.commit()</literal>"
+msgstr "a partir de<literal>org.hibernate.Transaction.commit()</literal>"
 
 #. Tag: para
-#: session_api.xml:830
 #, no-c-format
 msgid "from <literal>Session.flush()</literal>"
-msgstr "from <literal>Session.flush()</literal>"
+msgstr "a partir de <literal>Session.flush()</literal>"
 
 #. Tag: para
-#: session_api.xml:836
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The SQL statements are issued in the following order:"
-msgstr "The SQL statements are issued in the following order"
+msgstr "As instruções SQL são editadas na seguinte ordem:"
 
 #. Tag: para
-#: session_api.xml:842
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "all entity insertions in the same order the corresponding objects were saved "
 "using <literal>Session.save()</literal>"
 msgstr ""
-"all entity insertions, in the same order the corresponding objects were "
-"saved using <literal>Session.save()</literal>"
+"todas as inserções de entidade, na mesma ordem que os objetos "
+"correspondentes foram salvos usando <literal>Session.save()</literal> "
 
 #. Tag: para
-#: session_api.xml:848
 #, no-c-format
 msgid "all entity updates"
-msgstr "all entity updates"
+msgstr "todas as atualizações de entidades"
 
 #. Tag: para
-#: session_api.xml:853
 #, no-c-format
 msgid "all collection deletions"
-msgstr "all collection deletions"
+msgstr "todas as deleções de coleções"
 
 #. Tag: para
-#: session_api.xml:858
 #, no-c-format
 msgid "all collection element deletions, updates and insertions"
-msgstr "all collection element deletions, updates and insertions"
+msgstr "todas as deleções, atualizações e inserções de elementos de coleção."
 
 #. Tag: para
-#: session_api.xml:863
 #, no-c-format
 msgid "all collection insertions"
-msgstr "all collection insertions"
+msgstr "todas as inserções de coleção"
 
 #. Tag: para
-#: session_api.xml:868
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "all entity deletions in the same order the corresponding objects were "
 "deleted using <literal>Session.delete()</literal>"
 msgstr ""
-"all entity deletions, in the same order the corresponding objects were "
-"deleted using <literal>Session.delete()</literal>"
+"todas as deleções de entidade, na mesma ordem que os objetos correspondentes "
+"foram deletados usando <literal>Session.delete()</literal> "
 
 #. Tag: para
-#: session_api.xml:875
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An exception is that objects using <literal>native</literal> ID generation "
 "are inserted when they are saved."
 msgstr ""
-"(An exception is that objects using <literal>native</literal> ID generation "
-"are inserted when they are saved.)"
+"Uma exceção é que o objeto que utiliza a geração de ID <literal>native</"
+"literal> é inserido quando salvo."
 
 #. Tag: para
-#: session_api.xml:880
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Except when you explicitly <literal>flush()</literal>, there are absolutely "
 "no guarantees about <emphasis>when</emphasis> the <literal>Session</literal> "
@@ -1796,15 +1385,14 @@
 "are executed. However, Hibernate does guarantee that the <literal>Query.list"
 "(..)</literal> will never return stale or incorrect data."
 msgstr ""
-"Except when you explicity <literal>flush()</literal>, there are absolutely "
-"no guarantees about <emphasis>when</emphasis> the <literal>Session</literal> "
-"executes the JDBC calls, only the <emphasis>order</emphasis> in which they "
-"are executed. However, Hibernate does guarantee that the <literal>Query.list"
-"(..)</literal> will never return stale data; nor will they return the wrong "
-"data."
+"Exceto quando você explicitamente <literal>limpar()</literal>, não há "
+"nenhuma garantia sobre <emphasis>quando</emphasis> a <literal>Sessão</"
+"literal> executará as chamadas de JDBC, somente se sabe a <emphasis>ordem</"
+"emphasis> na qual elas são executadas. No entanto, o Hibernate garante que a "
+"<literal>Query.list(..)</literal> nunca retornará dados antigos, nem "
+"retornará dados errados. "
 
 #. Tag: para
-#: session_api.xml:888
 #, fuzzy, no-c-format
 msgid ""
 "It is possible to change the default behavior so that flush occurs less "
@@ -1814,72 +1402,49 @@
 "never flush unless <literal>flush()</literal> is called explicitly. The last "
 "mode is useful for long running units of work, where a <literal>Session</"
 "literal> is kept open and disconnected for a long time (see <xref linkend="
-"\"transactions-optimistic-longsession\"/>)."
+"\"transactions-optimistic-longsession\" />)."
 msgstr ""
-"It is possible to change the default behavior so that flush occurs less "
-"frequently. The <literal>FlushMode</literal> class defines three different "
-"modes: only flush at commit time (and only when the Hibernate "
-"<literal>Transaction</literal> API is used), flush automatically using the "
-"explained routine, or never flush unless <literal>flush()</literal> is "
-"called explicitly. The last mode is useful for long running units of work, "
-"where a <literal>Session</literal> is kept open and disconnected for a long "
-"time (see <xref linkend=\"transactions-optimistic-longsession\"/>)."
+"É possível mudar o comportamento padrão para que a limpeza ocorra com menos "
+"freqüência. A classe <literal>FlushMode</literal> define três modos "
+"diferentes: somente limpe em um tempo submetido: somente quando a API da "
+"<literal>Transaction</literal> do Hibernate for usada, limpe automaticamente "
+"usando uma rotina explicada, ou nunca limpe a menos que o <literal>flush()</"
+"literal> seja chamado explicitamente. O último modo é útil para execução de "
+"unidades de trabalho longas, onde uma <literal>Session</literal> é mantida "
+"aberta e disconectada por um longo tempo (veja <xref linkend=\"transactions-"
+"optimistic-longsession\"/>)."
 
-#. Tag: programlisting
-#: session_api.xml:898
-#, no-c-format
-msgid ""
-"<![CDATA[sess = sf.openSession();\n"
-"Transaction tx = sess.beginTransaction();\n"
-"sess.setFlushMode(FlushMode.COMMIT); // allow queries to return stale state\n"
-"\n"
-"Cat izi = (Cat) sess.load(Cat.class, id);\n"
-"izi.setName(iznizi);\n"
-"\n"
-"// might return stale data\n"
-"sess.find(\"from Cat as cat left outer join cat.kittens kitten\");\n"
-"\n"
-"// change to izi is not flushed!\n"
-"...\n"
-"tx.commit(); // flush occurs\n"
-"sess.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:900
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "During flush, an exception might occur (e.g. if a DML operation violates a "
 "constraint). Since handling exceptions involves some understanding of "
 "Hibernate's transactional behavior, we discuss it in <xref linkend="
-"\"transactions\"/>."
+"\"transactions\" />."
 msgstr ""
-"During flush, an exception might occur (e.g. if a DML operation violates a "
-"constraint). Since handling exceptions involves some understanding of "
-"Hibernate's transactional behavior, we discuss it in <xref linkend="
-"\"transactions\"/>."
+"Durante uma limpeza, pode ocorrer uma exceção (ex.: se uma operação DML "
+"violar uma restrição). Como o manuseio de exceções envolve algum "
+"entendimento do comportamento transacional do Hibernate, discutiremos sobre "
+"isso em <xref linkend=\"transactions\"/>. "
 
 #. Tag: title
-#: session_api.xml:909
 #, no-c-format
 msgid "Transitive persistence"
-msgstr "Transitive persistence"
+msgstr "Persistência Transitiva"
 
 #. Tag: para
-#: session_api.xml:911
 #, no-c-format
 msgid ""
 "It is quite cumbersome to save, delete, or reattach individual objects, "
 "especially if you deal with a graph of associated objects. A common case is "
 "a parent/child relationship. Consider the following example:"
 msgstr ""
-"It is quite cumbersome to save, delete, or reattach individual objects, "
-"especially if you deal with a graph of associated objects. A common case is "
-"a parent/child relationship. Consider the following example:"
+"É um tanto incômodo salvar, deletar ou reanexar objetos individuais, "
+"especialmente ao lidar com um grafo de objetos associados. Um caso comum é "
+"um relacionamento pai/filho. Considere o seguinte exemplo: "
 
 #. Tag: para
-#: session_api.xml:917
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the children in a parent/child relationship would be value typed (e.g. a "
 "collection of addresses or strings), their life cycle would depend on the "
@@ -1890,18 +1455,17 @@
 "collection. Since value-typed objects cannot have shared references, "
 "Hibernate will detect this and delete the child from the database."
 msgstr ""
-"If the children in a parent/child relationship would be value typed (e.g. a "
-"collection of addresses or strings), their life cycle would depend on the "
-"parent and no further action would be required for convenient \"cascading\" "
-"of state changes. When the parent is saved, the value-typed child objects "
-"are saved as well, when the parent is deleted, the children will be deleted, "
-"etc. This even works for operations such as the removal of a child from the "
-"collection; Hibernate will detect this and, since value-typed objects can't "
-"have shared references, delete the child from the database."
+"Se os filhos em um relacionamento pai/filho fossem do tipo valor (ex.: "
+"coleção de endereços ou strings), seus ciclos de vida dependeriam do pai e "
+"nenhuma ação seria requerida para \"cascateamento\" de mudança de estado. "
+"Quando o pai é salvo, os objetos filho de valor são salvos também, quando o "
+"pai é deletado, os filhos também serão deletados, etc. Isto funciona até "
+"para operações como remoção de filho da coleção. O Hibernate irá detectar "
+"isto e como objetos de valor não podem ter referências compartilhadas, irá "
+"deletar o filho do banco de dados.  "
 
 #. Tag: para
-#: session_api.xml:928
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now consider the same scenario with parent and child objects being entities, "
 "not value-types (e.g. categories and items, or parent and child cats). "
@@ -1911,16 +1475,15 @@
 "entities. Hibernate does not implement <emphasis>persistence by "
 "reachability</emphasis> by default."
 msgstr ""
-"Now consider the same scenario with parent and child objects being entities, "
-"not value-types (e.g. categories and items, or parent and child cats). "
-"Entities have their own life cycle, support shared references (so removing "
-"an entity from the collection does not mean it can be deleted), and there is "
-"by default no cascading of state from one entity to any other associated "
-"entities. Hibernate does not implement <emphasis>persistence by "
-"reachability</emphasis> by default."
+"Agora considere o mesmo cenário com objeto pai e filho sendo entidades, e "
+"não de valores (ex.: categorias e ítens, ou cats pai e filho). As entidades "
+"possuem seus próprios ciclos de vida, suportam referências compartilhadas "
+"(portanto, remover uma entidade da coleção não significa que possa ter sido "
+"deletada), e não existe efeito cascata de estado, por padrão, a partir de "
+"uma entidade para outras entidades associadas. O Hibernate não implementa "
+"<emphasis>persistência por alcance</emphasis> por padrão. "
 
 #. Tag: para
-#: session_api.xml:937
 #, no-c-format
 msgid ""
 "For each basic operation of the Hibernate session - including "
@@ -1931,49 +1494,33 @@
 "operation to be cascaded along an association, you must indicate that in the "
 "mapping document. For example:"
 msgstr ""
-"For each basic operation of the Hibernate session - including "
-"<literal>persist(), merge(), saveOrUpdate(), delete(), lock(), refresh(), "
-"evict(), replicate()</literal> - there is a corresponding cascade style. "
-"Respectively, the cascade styles are named <literal>create, merge, save-"
-"update, delete, lock, refresh, evict, replicate</literal>. If you want an "
-"operation to be cascaded along an association, you must indicate that in the "
-"mapping document. For example:"
+"Para cada operação básica da sessão do Hibernate, incluindo<literal>persistir"
+"(), mesclar(), salvarOuAtualizar(), deletar(), bloquear(), atualizar(), "
+"despejar(), replicar()</literal>, existe um estilo cascata correspondente. "
+"Respectivamente, os estilos cascatas são nomeados <literal>criar, mesclar, "
+"salvar-atualizar, deletar, bloquiar, atualizar, despejar, replicar</"
+"literal>. Se desejar uma operação em cascata junto a associação, você deverá "
+"indicar isto no documento de mapeamento. Por exemplo:"
 
-#. Tag: programlisting
-#: session_api.xml:946
-#, no-c-format
-msgid "<![CDATA[<one-to-one name=\"person\" cascade=\"persist\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:948
 #, no-c-format
 msgid "Cascade styles my be combined:"
-msgstr "Cascade styles my be combined:"
+msgstr "Estilo cascata pode ser combinado:"
 
-#. Tag: programlisting
-#: session_api.xml:952
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<one-to-one name=\"person\" cascade=\"persist,delete,lock\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:954
-#, fuzzy, no-c-format
-msgid ""
 "You can even use <literal>cascade=\"all\"</literal> to specify that "
 "<emphasis>all</emphasis> operations should be cascaded along the "
 "association. The default <literal>cascade=\"none\"</literal> specifies that "
 "no operations are to be cascaded."
 msgstr ""
-"You may even use <literal>cascade=\"all\"</literal> to specify that "
-"<emphasis>all</emphasis> operations should be cascaded along the "
-"association. The default <literal>cascade=\"none\"</literal> specifies that "
-"no operations are to be cascaded."
+"Você pode até utilizar <literal>cascade=\"all\"</literal> para especificar "
+"que <emphasis>todas</emphasis> as operações devem estar em cascata junto à "
+"associação. O padrão <literal>cascade=\"none\"</literal> especifica que "
+"nenhuma operação deve estar em cascata. "
 
 #. Tag: para
-#: session_api.xml:960
 #, no-c-format
 msgid ""
 "A special cascade style, <literal>delete-orphan</literal>, applies only to "
@@ -1981,45 +1528,41 @@
 "operation should be applied to any child object that is removed from the "
 "association."
 msgstr ""
-"A special cascade style, <literal>delete-orphan</literal>, applies only to "
-"one-to-many associations, and indicates that the <literal>delete()</literal> "
-"operation should be applied to any child object that is removed from the "
-"association."
+"Um estilo especial em cascata, <literal>delete-orphan</literal>, aplica "
+"somente associações um-para-um, e indica que a operação <literal>delete()</"
+"literal> deve ser aplicada em qualquer objeto filho que seja removido da "
+"associação."
 
 #. Tag: para
-#: session_api.xml:967
 #, no-c-format
 msgid "Recommendations:"
-msgstr "Recommendations:"
+msgstr "Recomendações:"
 
 #. Tag: para
-#: session_api.xml:973
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It does not usually make sense to enable cascade on a <literal>&lt;many-to-"
 "one&gt;</literal> or <literal>&lt;many-to-many&gt;</literal> association. "
 "Cascade is often useful for <literal>&lt;one-to-one&gt;</literal> and "
 "<literal>&lt;one-to-many&gt;</literal> associations."
 msgstr ""
-"It doesn't usually make sense to enable cascade on a <literal>&lt;many-to-"
-"one&gt;</literal> or <literal>&lt;many-to-many&gt;</literal> association. "
-"Cascade is often useful for <literal>&lt;one-to-one&gt;</literal> and "
-"<literal>&lt;one-to-many&gt;</literal> associations."
+"Não faz sentido habilitar a cascata em uma associação. <literal>&lt;many-to-"
+"one&gt;</literal> ou <literal>&lt;many-to-many&gt;</literal> A Cascata é "
+"geralmente útil para associações <literal>&lt;one-to-one&gt;</literal> e "
+"<literal>&lt;one-to-many&gt;</literal>."
 
 #. Tag: para
-#: session_api.xml:981
 #, no-c-format
 msgid ""
 "If the child object's lifespan is bounded by the lifespan of the parent "
 "object, make it a <emphasis>life cycle object</emphasis> by specifying "
 "<literal>cascade=\"all,delete-orphan\"</literal>."
 msgstr ""
-"If the child object's lifespan is bounded by the lifespan of the parent "
-"object, make it a <emphasis>life cycle object</emphasis> by specifying "
-"<literal>cascade=\"all,delete-orphan\"</literal>."
+"Se o tempo de vida do objeto filho estiver vinculado ao tempo de vida do "
+"objeto pai, faça disto um <emphasis>objeto de ciclo de vida</emphasis> "
+"especificando um <literal>cascade=\"all,delete-orphan\"</literal>."
 
 #. Tag: para
-#: session_api.xml:988
 #, no-c-format
 msgid ""
 "Otherwise, you might not need cascade at all. But if you think that you will "
@@ -2027,13 +1570,12 @@
 "transaction, and you want to save yourself some typing, consider using "
 "<literal>cascade=\"persist,merge,save-update\"</literal>."
 msgstr ""
-"Otherwise, you might not need cascade at all. But if you think that you will "
-"often be working with the parent and children together in the same "
-"transaction, and you want to save yourself some typing, consider using "
-"<literal>cascade=\"persist,merge,save-update\"</literal>."
+"Caso contrário, você pode não precisar realizar a cascata. Mas se você achar "
+"que irá trabalhar com o pai e filho juntos com freqüência, na mesma "
+"transação, e quiser salvar você mesmo, considere o uso do <literal>cascata="
+"\"persistir,mesclar,salvar-atualizar\"</literal>."
 
 #. Tag: para
-#: session_api.xml:996
 #, no-c-format
 msgid ""
 "Mapping an association (either a single valued association, or a collection) "
@@ -2041,14 +1583,14 @@
 "<emphasis>parent/child</emphasis> style relationship where save/update/"
 "delete of the parent results in save/update/delete of the child or children."
 msgstr ""
-"Mapping an association (either a single valued association, or a collection) "
-"with <literal>cascade=\"all\"</literal> marks the association as a "
-"<emphasis>parent/child</emphasis> style relationship where save/update/"
-"delete of the parent results in save/update/delete of the child or children."
+"Ao mapear uma associação (tanto uma associação de valor único como uma "
+"coleção) com  <literal>casca de=\"all\"</literal>, a associação é demarcada  "
+"como um relacionamento de estilo <emphasis>parent/child</emphasis> onde "
+"salvar/atualizar/deletar do pai, resulta em salvar/atualizar/deletar do(s) "
+"filho(s)."
 
 #. Tag: para
-#: session_api.xml:1002
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Furthermore, a mere reference to a child from a persistent parent will "
 "result in save/update of the child. This metaphor is incomplete, however. A "
@@ -2058,68 +1600,62 @@
 "literal>. The precise semantics of cascading operations for a parent/child "
 "relationship are as follows:"
 msgstr ""
-"Futhermore, a mere reference to a child from a persistent parent will result "
-"in save/update of the child. This metaphor is incomplete, however. A child "
-"which becomes unreferenced by its parent is <emphasis>not</emphasis> "
-"automatically deleted, except in the case of a <literal>&lt;one-to-many&gt;</"
-"literal> association mapped with <literal>cascade=\"delete-orphan\"</"
-"literal>. The precise semantics of cascading operations for a parent/child "
-"relationship are as follows:"
+"Além disso, uma mera referência ao filho de um pai persistente irá resultar "
+"em salvar/atualizar/ o filho. Entretanto, esta metáfora está incompleta. Um "
+"filho, que não é referenciado por seu pai <emphasis>não</emphasis> é "
+"deletado automaticamente, exceto no caso de uma associação <literal>&lt;one-"
+"to-many&gt;</literal> mapeada com <literal>casca de=\"delete-orphan\"</"
+"literal>. A semântica exata, de operações em cascata para o relacionamento "
+"pai/filho, são como as que se seguem: "
 
 #. Tag: para
-#: session_api.xml:1013
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>persist()</literal>, all children are "
 "passed to <literal>persist()</literal>"
 msgstr ""
-"If a parent is passed to <literal>persist()</literal>, all children are "
-"passed to <literal>persist()</literal>"
+"Se um pai é passado para <literal>persist()</literal>, todos os filhos são "
+"passados para <literal>persist()</literal>"
 
 #. Tag: para
-#: session_api.xml:1019
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>merge()</literal>, all children are passed "
 "to <literal>merge()</literal>"
 msgstr ""
-"If a parent is passed to <literal>merge()</literal>, all children are passed "
-"to <literal>merge()</literal>"
+"Se um pai é passado para <literal>merge()</literal>, todos os filhos são "
+"passados para  <literal>merge()</literal>"
 
 #. Tag: para
-#: session_api.xml:1025
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>save()</literal>, <literal>update()</"
 "literal> or <literal>saveOrUpdate()</literal>, all children are passed to "
 "<literal>saveOrUpdate()</literal>"
 msgstr ""
-"If a parent is passed to <literal>save()</literal>, <literal>update()</"
-"literal> or <literal>saveOrUpdate()</literal>, all children are passed to "
+"Se um pai for passado para <literal>save()</literal>, <literal>update()</"
+"literal> ou <literal>saveOrUpdate()</literal>, todos os filhos passarão para "
 "<literal>saveOrUpdate()</literal>"
 
 #. Tag: para
-#: session_api.xml:1031
 #, no-c-format
 msgid ""
 "If a transient or detached child becomes referenced by a persistent parent, "
 "it is passed to <literal>saveOrUpdate()</literal>"
 msgstr ""
-"If a transient or detached child becomes referenced by a persistent parent, "
-"it is passed to <literal>saveOrUpdate()</literal>"
+"Se um filho transiente ou desanexado se tornar referenciado pelo pai "
+"persistente, ele será passado para <literal>saveOrUpdate()</literal>"
 
 #. Tag: para
-#: session_api.xml:1037
 #, no-c-format
 msgid ""
 "If a parent is deleted, all children are passed to <literal>delete()</"
 "literal>"
 msgstr ""
-"If a parent is deleted, all children are passed to <literal>delete()</"
-"literal>"
+"Se um pai for deletado, todos os filhos serão passados para <literal>delete()"
+"</literal>"
 
 #. Tag: para
-#: session_api.xml:1042
 #, no-c-format
 msgid ""
 "If a child is dereferenced by a persistent parent, <emphasis>nothing special "
@@ -2127,14 +1663,13 @@
 "necessary - unless <literal>cascade=\"delete-orphan\"</literal>, in which "
 "case the \"orphaned\" child is deleted."
 msgstr ""
-"If a child is dereferenced by a persistent parent, <emphasis>nothing special "
-"happens</emphasis> - the application should explicitly delete the child if "
-"necessary - unless <literal>cascade=\"delete-orphan\"</literal>, in which "
-"case the \"orphaned\" child is deleted."
+"Se um filho for diferenciado pelo pai persistente, <emphasis>nada de "
+"especial acontece</emphasis> - a aplicação deve explicitamente deletar o "
+"filho se necessário, a não ser que <literal>casca de=\"delete-orphan\"</"
+"literal>, nos quais casos o filho \"órfão\" é deletado."
 
 #. Tag: para
-#: session_api.xml:1051
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, note that cascading of operations can be applied to an object graph "
 "at <emphasis>call time</emphasis> or at <emphasis>flush time</emphasis>. All "
@@ -2143,22 +1678,21 @@
 "<literal>delete-orphan</literal> are transitive for all associated entities "
 "reachable during flush of the <literal>Session</literal>."
 msgstr ""
-"Finally, note that cascading of operations can be applied to an object graph "
-"at <emphasis>call time</emphasis> or at <emphasis>flush time</emphasis>. All "
-"operations, if enabled, are cascaded to associated entities reachable when "
-"the operation is executed. However, <literal>save-upate</literal> and "
-"<literal>delete-orphan</literal> are transitive for all associated entities "
-"reachable during flush of the <literal>Session</literal>."
+"Finalmente, note que o cascateamento das operações podem ser aplicados a um "
+"grafo de objeto em <emphasis>tempo de chamada</emphasis> ou em "
+"<emphasis>tempo de limpeza</emphasis>. Todas as operações, se habilitadas, "
+"são colocadas em cascata para entidades associadas atingíveis quando a "
+"operação for executada. No entanto, <literal>save-upate</literal> e "
+"<literal>delete-orphan</literal> são transitivas para todas as entidades "
+"associadas atingíveis durante a limpeza da <literal>Sessão</literal>. "
 
 #. Tag: title
-#: session_api.xml:1063
 #, no-c-format
 msgid "Using metadata"
 msgstr "Usando metadados"
 
 #. Tag: para
-#: session_api.xml:1065
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate requires a rich meta-level model of all entity and value types. "
 "This model can be useful to the application itself. For example, the "
@@ -2167,63 +1701,23 @@
 "value types) and which objects that should not (e.g. immutable value types "
 "and, possibly, associated entities)."
 msgstr ""
-"O Hibernate requer um modelo muito rico a nível de metadados de todas as "
+"O Hibernate requer um modelo muito rico, em nível de metadados, de todas as "
 "entidades e tipos de valores. De tempos em tempos, este modelo é muito útil "
-"à própria aplicação. Por exemplo, a aplicação pode usar o metadados do "
-"Hibernate que executa um algoritmo \"inteligente\" que compreende quais "
+"à própria aplicação. Por exemplo, a aplicação pode usar os metadados do "
+"Hibernate, que executa um algoritmo \"inteligente\", que compreende quais "
 "objetos podem ser copiados (por exemplo, tipos de valores mutáveis) ou não "
 "(por exemplo, tipos de valores imutáveis e, possivelmente, entidades "
-"associadas)."
+"associadas). "
 
 #. Tag: para
-#: session_api.xml:1072
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate exposes metadata via the <literal>ClassMetadata</literal> and "
 "<literal>CollectionMetadata</literal> interfaces and the <literal>Type</"
 "literal> hierarchy. Instances of the metadata interfaces can be obtained "
 "from the <literal>SessionFactory</literal>."
 msgstr ""
-"O Hibernate expõe o metadados via interfaces <literal>ClassMetadata</"
+"O Hibernate expõe os metadados via interfaces <literal>ClassMetadata</"
 "literal> e <literal>CollectionMetadata</literal> e pela hierarquia "
 "<literal>Type</literal>. Instâncias das interfaces de metadados podem ser "
-"obtidas a partir do <literal>SessionFactory</literal>."
-
-#. Tag: programlisting
-#: session_api.xml:1079
-#, no-c-format
-msgid ""
-"<![CDATA[Cat fritz = ......;\n"
-"ClassMetadata catMeta = sessionfactory.getClassMetadata(Cat.class);\n"
-"\n"
-"Object[] propertyValues = catMeta.getPropertyValues(fritz);\n"
-"String[] propertyNames = catMeta.getPropertyNames();\n"
-"Type[] propertyTypes = catMeta.getPropertyTypes();\n"
-"\n"
-"// get a Map of all properties which are not collections or associations\n"
-"Map namedValues = new HashMap();\n"
-"for ( int i=0; i<propertyNames.length; i++ ) {\n"
-"    if ( !propertyTypes[i].isEntityType() && !propertyTypes[i]."
-"isCollectionType() ) {\n"
-"        namedValues.put( propertyNames[i], propertyValues[i] );\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#~ msgid "UPDATE"
-#~ msgstr "UPDATE"
-
-#~ msgid "DELETE"
-#~ msgstr "DELETE"
-
-#~ msgid "state management"
-#~ msgstr "state management"
-
-#~ msgid "statements"
-#~ msgstr "statements"
-
-#~ msgid "Connection"
-#~ msgstr "Connection"
-
-#~ msgid "session.connection()"
-#~ msgstr "session.connection()"
+"obtidas a partir do <literal>SessionFactory</literal>. "

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/toolset_guide.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/toolset_guide.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/toolset_guide.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,60 +1,164 @@
+# translation of toolset_guide.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: toolset_guide\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2009-12-21 07:41+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: toolset_guide.xml:29
 #, no-c-format
 msgid "Toolset Guide"
-msgstr "Toolset Guide"
+msgstr "Guia de Toolset"
 
 #. Tag: para
-#: toolset_guide.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Roundtrip engineering with Hibernate is possible using a set of Eclipse "
 "plugins, commandline tools, and Ant tasks."
 msgstr ""
-"Roundtrip engineering with Hibernate is possible using a set of Eclipse "
-"plugins, commandline tools, as well as Ant tasks."
+"É possível realizar uma engenharia de roundtrip com o Hibernate, usando um "
+"conjunto de plug-ins de Eclipse, ferramentas de linha de comando, assim como "
+"tarefas Ant."
 
 #. Tag: para
-#: toolset_guide.xml:36
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Hibernate Tools</emphasis> currently include plugins for the "
 "Eclipse IDE as well as Ant tasks for reverse engineering of existing "
 "databases:"
 msgstr ""
-"The <emphasis>Hibernate Tools</emphasis> currently include plugins for the "
-"Eclipse IDE as well as Ant tasks for reverse engineering of existing "
-"databases:"
+"As <emphasis>Ferramentas do Hibernate</emphasis> atualmente incluem os plug-"
+"ins para o IDE de Eclipse assim como as tarefas para reverter a engenharia "
+"dos bancos de dados existentes:"
 
 #. Tag: para
-#: toolset_guide.xml:42
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Mapping Editor:</emphasis> an editor for Hibernate XML mapping "
 "files that supports auto-completion and syntax highlighting. It also "
 "supports semantic auto-completion for class names and property/field names, "
 "making it more versatile than a normal XML editor."
 msgstr ""
-"<emphasis>Mapping Editor:</emphasis> An editor for Hibernate XML mapping "
-"files, supporting auto-completion and syntax highlighting. It also supports "
-"semantic auto-completion for class names and property/field names, making it "
-"much more versatile than a normal XML editor."
+"<emphasis>Editor de Mapeamento:</emphasis> um editor para mapeamento de "
+"arquivos XML do Hibernate, suportando a auto complexão e destaque de "
+"sintáxe. Ele também suporta a auto complexão da semântica para nomes de "
+"classes e nomes de propriedade/campo, fazendo com que ele seja mais versátil "
+"do que um editor XML normal. "
 
 #. Tag: para
-#: toolset_guide.xml:47
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Console:</emphasis> the console is a new view in Eclipse. In "
 "addition to a tree overview of your console configurations, you are also "
@@ -62,15 +166,14 @@
 "relationships. The console allows you to execute HQL queries against your "
 "database and browse the result directly in Eclipse."
 msgstr ""
-"<emphasis>Console:</emphasis> The console is a new view in Eclipse. In "
-"addition to a tree overview of your console configurations, you also get an "
-"interactive view of your persistent classes and their relationships. The "
-"console allows you to execute HQL queries against your database and browse "
-"the result directly in Eclipse."
+"<emphasis>Console:</emphasis> o console é uma nova visão em Eclipse. Além "
+"disso, para uma visão geral de árvore de suas configurações de console, você "
+"também pode obter uma visão interativa de suas classes persistentes e seus "
+"relacionamentos. O console permite que você execute as consultas HQL junto "
+"ao banco de dados e navegue o resultado diretamente em Eclipse. "
 
 #. Tag: para
-#: toolset_guide.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Development Wizards:</emphasis> several wizards are provided with "
 "the Hibernate Eclipse tools. You can use a wizard to quickly generate "
@@ -78,453 +181,306 @@
 "database schema into POJO source files and Hibernate mapping files. The "
 "reverse engineering wizard supports customizable templates."
 msgstr ""
-"<emphasis>Development Wizards:</emphasis> Several wizards are provided with "
-"the Hibernate Eclipse tools; you can use a wizard to quickly generate "
-"Hibernate configuration (cfg.xml) files, or you may even completely reverse "
-"engineer an existing database schema into POJO source files and Hibernate "
-"mapping files. The reverse engineering wizard supports customizable "
-"templates."
+"<emphasis>Assistentes de Desenvolvimento:</emphasis> são oferecidos diversos "
+"assistentes com as ferramentas de Eclipse do Hibernate. Você pode usar o "
+"assistente para gerar rapidamente arquivos de configuração do Hibernate (cfg."
+"xml), ou você pode também reverter completamente o engenheiro, um esquema de "
+"banco de dados existente, para arquivos de fonte POJO e arquivos de "
+"mapeamento do Hibernate. O assistente de engenharia reversa suporta modelos "
+"padronizáveis."
 
 #. Tag: para
-#: toolset_guide.xml:67
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please refer to the <emphasis>Hibernate Tools</emphasis> package "
 "documentation for more information."
 msgstr ""
-"Please refer to the <emphasis>Hibernate Tools</emphasis> package and it's "
-"documentation for more information."
+"Por favor, consulte o pacote <emphasis>Ferramentas do Hibernate</emphasis> e "
+"suas documentações para maiores informações."
 
 #. Tag: para
-#: toolset_guide.xml:72
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, the Hibernate main package comes bundled with an integrated tool : "
 "<emphasis>SchemaExport</emphasis> aka <literal>hbm2ddl</literal>.It can even "
 "be used from \"inside\" Hibernate."
 msgstr ""
-"However, the Hibernate main package comes bundled with an integrated tool "
-"(it can even be used from \"inside\" Hibernate on-the-fly): "
-"<emphasis>SchemaExport</emphasis> aka <literal>hbm2ddl</literal>."
+"No entanto, o pacote principal do Hibernate vem em lote com uma ferramenta "
+"integrada: <emphasis>SchemaExport</emphasis> aka <literal>hbm2ddl</literal>. "
+"Ele pode também ser usado dentro do Hibernate."
 
 #. Tag: title
-#: toolset_guide.xml:79
 #, no-c-format
 msgid "Automatic schema generation"
-msgstr "Automatic schema generation"
+msgstr "Geração de esquema automático"
 
 #. Tag: para
-#: toolset_guide.xml:81
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "DDL can be generated from your mapping files by a Hibernate utility. The "
 "generated schema includes referential integrity constraints, primary and "
 "foreign keys, for entity and collection tables. Tables and sequences are "
 "also created for mapped identifier generators."
 msgstr ""
-"DDL may be generated from your mapping files by a Hibernate utility. The "
-"generated schema includes referential integrity constraints (primary and "
-"foreign keys) for entity and collection tables. Tables and sequences are "
-"also created for mapped identifier generators."
+"O DDL pode ser gerado a partir dos arquivos de mapeamento através dos "
+"utilitários do Hibernate. O esquema gerado inclui as restrições de "
+"integridade referencial, primária e chave estrangeira, para entidade e "
+"tabela de coleção. Tabelas e seqüência são também criadas por geradores de "
+"identificador mapeado."
 
 #. Tag: para
-#: toolset_guide.xml:88
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You <emphasis>must</emphasis> specify a SQL <literal>Dialect</literal> via "
 "the <literal>hibernate.dialect</literal> property when using this tool, as "
 "DDL is highly vendor-specific."
 msgstr ""
-"You <emphasis>must</emphasis> specify a SQL <literal>Dialect</literal> via "
-"the <literal>hibernate.dialect</literal> property when using this tool, as "
-"DDL is highly vendor specific."
+"Você <emphasis>deve</emphasis> especificar um SQL <literal>Dialect</literal> "
+"através da propriedade <literal>hibernate.dialect</literal> ao usar esta "
+"ferramenta, uma vez que o DDL é um fabricante bastante específico."
 
 #. Tag: para
-#: toolset_guide.xml:94
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, you must customize your mapping files to improve the generated "
 "schema. The next section covers schema customization."
-msgstr "First, customize your mapping files to improve the generated schema."
+msgstr ""
+"Primeiro, padronize seus arquivos de mapeamento para melhorar o esquema "
+"gerado. A próxima seção cobrirá a personalização do esquema."
 
 #. Tag: title
-#: toolset_guide.xml:99
 #, no-c-format
 msgid "Customizing the schema"
-msgstr "Customizing the schema"
+msgstr "Padronizando o esquema"
 
 #. Tag: para
-#: toolset_guide.xml:101
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Many Hibernate mapping elements define optional attributes named "
 "<literal>length</literal>, <literal>precision</literal> and <literal>scale</"
 "literal>. You can set the length, precision and scale of a column with this "
 "attribute."
 msgstr ""
-"Many Hibernate mapping elements define optional attributes named "
-"<literal>length</literal>, <literal>precision</literal> and <literal>scale</"
-"literal>. You may set the length, precision and scale of a column with this "
-"attribute."
+"Muitos elementos de mapeamento do Hibernate definem funções opcionais "
+"nomeadas <literal>length</literal>, <literal>precision</literal> e "
+"<literal>scale</literal>. Você deve ajustar o length, precision e scale de "
+"uma coluna com esta função."
 
-#. Tag: programlisting
-#: toolset_guide.xml:108
-#, no-c-format
-msgid "<![CDATA[<property name=\"zip\" length=\"5\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:109
-#, no-c-format
-msgid "<![CDATA[<property name=\"balance\" precision=\"12\" scale=\"2\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Some tags also accept a <literal>not-null</literal> attribute for generating "
 "a <literal>NOT NULL</literal> constraint on table columns, and a "
 "<literal>unique</literal> attribute for generating <literal>UNIQUE</literal> "
 "constraint on table columns."
 msgstr ""
-"Some tags also accept a <literal>not-null</literal> attribute (for "
-"generating a <literal>NOT NULL</literal> constraint on table columns) and a "
-"<literal>unique</literal> attribute (for generating <literal>UNIQUE</"
-"literal> constraint on table columns)."
+"Algumas tags aceitam uma função <literal>not-null</literal> para gerar uma "
+"restrição <literal>NOT NULL</literal>nas colunas de tabela e uma função "
+"<literal>unique</literal> para gerar uma restrição <literal>UNIQUE</literal> "
+"em colunas de tabela."
 
-#. Tag: programlisting
-#: toolset_guide.xml:117
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"bar\" column=\"barId\" not-null=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:119
-#, no-c-format
-msgid ""
-"<![CDATA[<element column=\"serialNumber\" type=\"long\" not-null=\"true\" "
-"unique=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:121
-#, fuzzy, no-c-format
-msgid ""
 "A <literal>unique-key</literal> attribute can be used to group columns in a "
 "single, unique key constraint. Currently, the specified value of the "
 "<literal>unique-key</literal> attribute is <emphasis>not</emphasis> used to "
 "name the constraint in the generated DDL. It is only used to group the "
 "columns in the mapping file."
 msgstr ""
-"A <literal>unique-key</literal> attribute may be used to group columns in a "
-"single unique key constraint. Currently, the specified value of the "
-"<literal>unique-key</literal> attribute is <emphasis>not</emphasis> used to "
-"name the constraint in the generated DDL, only to group the columns in the "
-"mapping file."
+"Uma função <literal>unique-key</literal> pode ser usada para agrupar colunas "
+"em uma restrição de chave única. Atualmente, o valor específico da função "
+"<literal>unique-key</literal> <emphasis>não é</emphasis> usada para nomear a "
+"restrição no DDL gerado, somente para agrupar as colunas no arquivo de "
+"mapeamento. "
 
-#. Tag: programlisting
-#: toolset_guide.xml:129
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"org\" column=\"orgId\" unique-key="
-"\"OrgEmployeeId\"/>\n"
-"<property name=\"employeeId\" unique-key=\"OrgEmployee\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:131
-#, fuzzy, no-c-format
-msgid ""
 "An <literal>index</literal> attribute specifies the name of an index that "
 "will be created using the mapped column or columns. Multiple columns can be "
 "grouped into the same index by simply specifying the same index name."
 msgstr ""
-"An <literal>index</literal> attribute specifies the name of an index that "
-"will be created using the mapped column or columns. Multiple columns may be "
-"grouped into the same index, simply by specifying the same index name."
+"Uma função <literal>index</literal> especifica o nome de um indexe que será "
+"criado, usando a coluna ou colunas mapeada(s). As colunas múltiplas podem "
+"ser agrupadas no mesmo indexe, simplesmente especificando o mesmo nome de "
+"índice. "
 
-#. Tag: programlisting
-#: toolset_guide.xml:137
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<property name=\"lastName\" index=\"CustName\"/>\n"
-"<property name=\"firstName\" index=\"CustName\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:139
-#, fuzzy, no-c-format
-msgid ""
 "A <literal>foreign-key</literal> attribute can be used to override the name "
 "of any generated foreign key constraint."
 msgstr ""
-"A <literal>foreign-key</literal> attribute may be used to override the name "
-"of any generated foreign key constraint."
+"Uma função <literal>foreign-key</literal> pode ser usada para sobrescrever o "
+"nome de qualquer restrição de chave exterior gerada. "
 
-#. Tag: programlisting
-#: toolset_guide.xml:144
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"bar\" column=\"barId\" foreign-key=\"FKFooBar\"/"
-">]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:146
 #, no-c-format
 msgid ""
 "Many mapping elements also accept a child <literal>&lt;column&gt;</literal> "
 "element. This is particularly useful for mapping multi-column types:"
 msgstr ""
-"Many mapping elements also accept a child <literal>&lt;column&gt;</literal> "
-"element. This is particularly useful for mapping multi-column types:"
+"Muitos elementos de mapeamento também aceitam um elemento filho <literal>&lt;"
+"column&gt;</literal>. Isto é particularmente útil para mapeamento de tipos "
+"multi-colunas:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:151
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<property name=\"name\" type=\"my.customtypes.Name\"/>\n"
-"    <column name=\"last\" not-null=\"true\" index=\"bar_idx\" length=\"30\"/"
-">\n"
-"    <column name=\"first\" not-null=\"true\" index=\"bar_idx\" length=\"20\"/"
-">\n"
-"    <column name=\"initial\"/>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:153
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>default</literal> attribute allows you to specify a default "
 "value for a column.You should assign the same value to the mapped property "
 "before saving a new instance of the mapped class."
 msgstr ""
-"The <literal>default</literal> attribute lets you specify a default value "
-"for a column (you should assign the same value to the mapped property before "
-"saving a new instance of the mapped class)."
+"A função <literal>default</literal> deixa você especificar um valor padrão "
+"para uma coluna. Você deve atribuir o mesmo valor à propriedade mapeada "
+"antes de salvar uma nova instância da classe mapeada."
 
-#. Tag: programlisting
-#: toolset_guide.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"credits\" type=\"integer\" insert=\"false\">\n"
-"    <column name=\"credits\" default=\"10\"/>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:161
-#, no-c-format
-msgid ""
-"<![CDATA[<version name=\"version\" type=\"integer\" insert=\"false\">\n"
-"    <column name=\"version\" default=\"0\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:163
 #, no-c-format
 msgid ""
 "The <literal>sql-type</literal> attribute allows the user to override the "
 "default mapping of a Hibernate type to SQL datatype."
 msgstr ""
-"The <literal>sql-type</literal> attribute allows the user to override the "
-"default mapping of a Hibernate type to SQL datatype."
+"A função <literal>sql-type</literal> permite que o usuário sobrescreva o "
+"mapeamento padrão de um tipo de Hibernate para um tipo de dados SQL."
 
-#. Tag: programlisting
-#: toolset_guide.xml:168
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"balance\" type=\"float\">\n"
-"    <column name=\"balance\" sql-type=\"decimal(13,3)\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:170
 #, no-c-format
 msgid ""
 "The <literal>check</literal> attribute allows you to specify a check "
 "constraint."
 msgstr ""
-"The <literal>check</literal> attribute allows you to specify a check "
-"constraint."
+"A função <literal>check</literal> permite que você especifique uma restrição "
+"de verificação."
 
-#. Tag: programlisting
-#: toolset_guide.xml:174
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"foo\" type=\"integer\">\n"
-"    <column name=\"foo\" check=\"foo > 10\"/>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:176
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Foo\" table=\"foos\" check=\"bar < 100.0\">\n"
-"    ...\n"
-"    <property name=\"bar\" type=\"float\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:179
 #, no-c-format
 msgid "The following table summarizes these optional attributes."
-msgstr ""
+msgstr "A seguinte tabela resume estes atributos opcionais."
 
 #. Tag: title
-#: toolset_guide.xml:182
 #, no-c-format
 msgid "Summary"
-msgstr "Summary"
+msgstr "Sumário"
 
 #. Tag: entry
-#: toolset_guide.xml:189
 #, no-c-format
 msgid "Attribute"
-msgstr "Attribute"
+msgstr "Função"
 
 #. Tag: entry
-#: toolset_guide.xml:190
 #, no-c-format
 msgid "Values"
-msgstr "Values"
+msgstr "Valores"
 
 #. Tag: entry
-#: toolset_guide.xml:191
 #, no-c-format
 msgid "Interpretation"
-msgstr "Interpretation"
+msgstr "Interpretação"
 
-#. Tag: literal
-#: toolset_guide.xml:196
+#. Tag: entry
 #, no-c-format
-msgid "length"
-msgstr "length"
+msgid "<literal>length</literal>"
+msgstr "<literal>length</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:197 toolset_guide.xml:202 toolset_guide.xml:207
 #, no-c-format
 msgid "number"
-msgstr "number"
+msgstr "número"
 
 #. Tag: entry
-#: toolset_guide.xml:198
 #, no-c-format
 msgid "column length"
-msgstr "column length"
+msgstr "comprimento da coluna"
 
-#. Tag: literal
-#: toolset_guide.xml:201
+#. Tag: entry
 #, no-c-format
-msgid "precision"
-msgstr "precision"
+msgid "<literal>precision</literal>"
+msgstr "<literal>precision</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:203
 #, no-c-format
 msgid "column decimal precision"
-msgstr "column decimal precision"
+msgstr "precisão da coluna decimal"
 
-#. Tag: literal
-#: toolset_guide.xml:206
+#. Tag: entry
 #, no-c-format
-msgid "scale"
-msgstr "scale"
+msgid "<literal>scale</literal>"
+msgstr "<literal>scale</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:208
 #, no-c-format
 msgid "column decimal scale"
-msgstr "column decimal scale"
+msgstr "escaça de coluna decimal"
 
-#. Tag: literal
-#: toolset_guide.xml:211
+#. Tag: entry
 #, no-c-format
-msgid "not-null"
-msgstr "not-null"
+msgid "<literal>not-null</literal>"
+msgstr "<literal>not-null</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:212 toolset_guide.xml:217
+#. Tag: entry
 #, no-c-format
-msgid "true|false"
-msgstr "true|false"
+msgid "<literal>true|false</literal>"
+msgstr "<literal>true|false</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:213
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "specifies that the column should be non-nullable"
-msgstr "specfies that the column should be non-nullable"
+msgstr "especifica que a coluna deveria ser não anulável "
 
-#. Tag: literal
-#: toolset_guide.xml:216
+#. Tag: entry
 #, no-c-format
-msgid "unique"
-msgstr "unique"
+msgid "<literal>unique</literal>"
+msgstr "<literal>unique</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:218
 #, no-c-format
 msgid "specifies that the column should have a unique constraint"
-msgstr "specifies that the column should have a unique constraint"
+msgstr "especifica que a coluna deveria ter uma restrição única"
 
-#. Tag: literal
-#: toolset_guide.xml:221
+#. Tag: entry
 #, no-c-format
-msgid "index"
-msgstr "index"
+msgid "<literal>index</literal>"
+msgstr "<literal>index</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:222
+#. Tag: entry
 #, no-c-format
-msgid "index_name"
-msgstr "index_name"
+msgid "<literal>index_name</literal>"
+msgstr "<literal>index_name</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:223
 #, no-c-format
 msgid "specifies the name of a (multi-column) index"
-msgstr "specifies the name of a (multi-column) index"
+msgstr "especifica o nome de um índice (multi-coluna)"
 
-#. Tag: literal
-#: toolset_guide.xml:226
+#. Tag: entry
 #, no-c-format
-msgid "unique-key"
-msgstr "unique-key"
+msgid "<literal>unique-key</literal>"
+msgstr "<literal>unique-key</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:227
-#, no-c-format
-msgid "unique_key_name"
-msgstr "unique_key_name"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>unique_key_name</literal>"
+msgstr "<literal>unique-key</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:228
 #, no-c-format
 msgid "specifies the name of a multi-column unique constraint"
-msgstr "specifies the name of a multi-column unique constraint"
+msgstr "especifica o nome de uma restrição única de coluna múltipla"
 
-#. Tag: literal
-#: toolset_guide.xml:231
+#. Tag: entry
 #, no-c-format
-msgid "foreign-key"
-msgstr "foreign-key"
+msgid "<literal>foreign-key</literal>"
+msgstr "<literal>foreign-key</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:232
-#, no-c-format
-msgid "foreign_key_name"
-msgstr "foreign_key_name"
-
 #. Tag: entry
-#: toolset_guide.xml:233
 #, fuzzy, no-c-format
+msgid "<literal>foreign_key_name</literal>"
+msgstr "<literal>foreign-key</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "specifies the name of the foreign key constraint generated for an "
 "association, for a <literal>&lt;one-to-one&gt;</literal>, <literal>&lt;many-"
@@ -532,540 +488,407 @@
 "to-many&gt;</literal> mapping element. Note that <literal>inverse=\"true\"</"
 "literal> sides will not be considered by <literal>SchemaExport</literal>."
 msgstr ""
-"specifies the name of the foreign key constraint generated for an "
-"association, for a <placeholder-1/>, <placeholder-2/>, <placeholder-3/>, or "
-"<placeholder-4/> mapping element. Note that <placeholder-5/> sides will not "
-"be considered by <placeholder-6/>."
+"especifica o nome da restrição de chave estrangeira gerada para uma "
+"associação, por um elemento de mapeamento <literal>&lt;one-to-one&gt;</"
+"literal>, <literal>&lt;many-to-one&gt;</literal>, <literal>&lt;key&gt;</"
+"literal>, ou <literal>&lt;many-to-many&gt;</literal>. Note que os lados "
+"<literal>inverse=\"true\"</literal> não serão considerados pelo "
+"<literal>SchemaExport</literal>."
 
-#. Tag: literal
-#: toolset_guide.xml:243
+#. Tag: entry
 #, no-c-format
-msgid "sql-type"
-msgstr "sql-type"
+msgid "<literal>sql-type</literal>"
+msgstr "<literal>sql-type</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:244
-#, no-c-format
-msgid "SQL column type"
-msgstr "SQL column type"
-
 #. Tag: entry
-#: toolset_guide.xml:245
 #, fuzzy, no-c-format
+msgid "<literal>SQL column type</literal>"
+msgstr "<literal>sql-type</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "overrides the default column type (attribute of <literal>&lt;column&gt;</"
 "literal> element only)"
 msgstr ""
-"overrides the default column type (attribute of <placeholder-1/> element "
-"only)"
+"sobrescreve o tipo de coluna padrão (função do elemento <literal>&lt;"
+"column&gt;</literal>somente)"
 
-#. Tag: literal
-#: toolset_guide.xml:251
+#. Tag: entry
 #, no-c-format
-msgid "default"
-msgstr "default"
+msgid "<literal>default</literal>"
+msgstr "<literal>default</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:252 toolset_guide.xml:259
 #, no-c-format
 msgid "SQL expression"
-msgstr "SQL expression"
+msgstr "Expressão SQL "
 
 #. Tag: entry
-#: toolset_guide.xml:253
 #, no-c-format
 msgid "specify a default value for the column"
-msgstr "specify a default value for the column"
+msgstr "especifica um valor padrão para a coluna"
 
-#. Tag: literal
-#: toolset_guide.xml:258
+#. Tag: entry
 #, no-c-format
-msgid "check"
-msgstr "check"
+msgid "<literal>check</literal>"
+msgstr "<literal>check</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:260
 #, no-c-format
 msgid "create an SQL check constraint on either column or table"
-msgstr "create an SQL check constraint on either column or table"
+msgstr ""
+"cria uma restrição de verificação de SQL tanto na coluna quanto na tabela"
 
 #. Tag: para
-#: toolset_guide.xml:268
 #, no-c-format
 msgid ""
 "The <literal>&lt;comment&gt;</literal> element allows you to specify "
 "comments for the generated schema."
 msgstr ""
-"The <literal>&lt;comment&gt;</literal> element allows you to specify "
-"comments for the generated schema."
+"O elemento <literal>&lt;comment&gt;</literal> permite que você especifique "
+"comentários para esquema gerado."
 
-#. Tag: programlisting
-#: toolset_guide.xml:273
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Customer\" table=\"CurCust\">\n"
-"    <comment>Current customers only</comment>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:275
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"balance\">\n"
-"    <column name=\"bal\">\n"
-"        <comment>Balance in USD</comment>\n"
-"    </column>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:277
-#, fuzzy, no-c-format
-msgid ""
 "This results in a <literal>comment on table</literal> or <literal>comment on "
 "column</literal> statement in the generated DDL where supported."
 msgstr ""
-"This results in a <literal>comment on table</literal> or <literal>comment on "
-"column</literal> statement in the generated DDL (where supported)."
+"Isto resulta em uma instrução <literal>comment on table</literal> ou "
+"<literal>comment on column</literal> no DDL gerado, onde é suportado."
 
 #. Tag: title
-#: toolset_guide.xml:286
 #, no-c-format
 msgid "Running the tool"
-msgstr "Running the tool"
+msgstr "Executando a ferramenta"
 
 #. Tag: para
-#: toolset_guide.xml:288
 #, no-c-format
 msgid ""
 "The <literal>SchemaExport</literal> tool writes a DDL script to standard out "
 "and/or executes the DDL statements."
 msgstr ""
-"The <literal>SchemaExport</literal> tool writes a DDL script to standard out "
-"and/or executes the DDL statements."
+"A ferramenta <literal>SchemaExport</literal> escreve um script DDL para "
+"padronizar e/ou para executar as instruções DDL."
 
 #. Tag: para
-#: toolset_guide.xml:293
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table displays the <literal>SchemaExport</literal> command "
 "line options"
-msgstr "<literal>SchemaExport</literal> Command Line Options"
+msgstr ""
+"A seguinte tabela exibe as opções de linha de comando do "
+"<literal>SchemaExport</literal>"
 
 #. Tag: para
-#: toolset_guide.xml:295
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
 "<literal>org.hibernate.tool.hbm2ddl.SchemaExport</literal> <emphasis>options "
 "mapping_files</emphasis>"
 msgstr ""
+"<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
+"<literal>org.hibernate.tool.hbm2ddl.SchemaExport</literal> <emphasis>options "
+"mapping_files</emphasis>"
 
 #. Tag: title
-#: toolset_guide.xml:301
 #, no-c-format
 msgid "<literal>SchemaExport</literal> Command Line Options"
-msgstr "<literal>SchemaExport</literal> Command Line Options"
+msgstr "<literal>SchemaExport</literal> Opções de Linha de Comando"
 
 #. Tag: entry
-#: toolset_guide.xml:307 toolset_guide.xml:457 toolset_guide.xml:527
 #, no-c-format
 msgid "Option"
-msgstr "Option"
+msgstr "Opção"
 
 #. Tag: entry
-#: toolset_guide.xml:308 toolset_guide.xml:395 toolset_guide.xml:458
-#: toolset_guide.xml:528
 #, no-c-format
 msgid "Description"
-msgstr "Description"
+msgstr "Descrição"
 
-#. Tag: literal
-#: toolset_guide.xml:313 toolset_guide.xml:463
+#. Tag: entry
 #, no-c-format
-msgid "--quiet"
-msgstr "--quiet"
+msgid "<literal>--quiet</literal>"
+msgstr "<literal>--quiet</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:314 toolset_guide.xml:464
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "do not output the script to stdout"
-msgstr "don't output the script to stdout"
+msgstr "não saia do script para stdout "
 
-#. Tag: literal
-#: toolset_guide.xml:317
+#. Tag: entry
 #, no-c-format
-msgid "--drop"
-msgstr "--drop"
+msgid "<literal>--drop</literal>"
+msgstr "<literal>--drop</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:318
 #, no-c-format
 msgid "only drop the tables"
-msgstr "only drop the tables"
+msgstr "somente suspenda as tabelas"
 
-#. Tag: literal
-#: toolset_guide.xml:321
+#. Tag: entry
 #, no-c-format
-msgid "--create"
-msgstr "--create"
+msgid "<literal>--create</literal>"
+msgstr "<literal>--create</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:322
 #, no-c-format
 msgid "only create the tables"
-msgstr "only create the tables"
+msgstr "somente crie tabelas"
 
-#. Tag: literal
-#: toolset_guide.xml:325 toolset_guide.xml:467
+#. Tag: entry
 #, no-c-format
-msgid "--text"
-msgstr "--text"
+msgid "<literal>--text</literal>"
+msgstr "<literal>--text</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:326
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "do not export to the database"
-msgstr "don't export to the database"
+msgstr "não exporte para o banco de dados "
 
-#. Tag: literal
-#: toolset_guide.xml:329
-#, no-c-format
-msgid "--output=my_schema.ddl"
-msgstr "--output=my_schema.ddl"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--output=my_schema.ddl</literal>"
+msgstr "<literal>scale</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:330
 #, no-c-format
 msgid "output the ddl script to a file"
-msgstr "output the ddl script to a file"
+msgstr "saia do script ddl para um arquivo"
 
-#. Tag: literal
-#: toolset_guide.xml:333 toolset_guide.xml:471 toolset_guide.xml:533
-#, no-c-format
-msgid "--naming=eg.MyNamingStrategy"
-msgstr "--naming=eg.MyNamingStrategy"
-
 #. Tag: entry
-#: toolset_guide.xml:334 toolset_guide.xml:472 toolset_guide.xml:534
 #, fuzzy, no-c-format
-msgid "select a <literal>NamingStrategy</literal>"
-msgstr "in <literal>hibernate.properties</literal>"
+msgid "<literal>--naming=eg.MyNamingStrategy</literal>"
+msgstr "<literal>--naming=eg.MyNamingStrategy</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:337 toolset_guide.xml:479 toolset_guide.xml:541
+#. Tag: entry
 #, no-c-format
-msgid "--config=hibernate.cfg.xml"
-msgstr "--config=hibernate.cfg.xml"
+msgid "select a <literal>NamingStrategy</literal>"
+msgstr "seleciona um <literal>NamingStrategy</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:338
+#, fuzzy, no-c-format
+msgid "<literal>--config=hibernate.cfg.xml</literal>"
+msgstr "<literal>--config=hibernate.cfg.xml</literal>"
+
+#. Tag: entry
 #, no-c-format
 msgid "read Hibernate configuration from an XML file"
-msgstr "read Hibernate configuration from an XML file"
+msgstr "leia a configuração do Hibernate a partir do arquivo XML"
 
-#. Tag: literal
-#: toolset_guide.xml:341 toolset_guide.xml:475 toolset_guide.xml:537
-#, no-c-format
-msgid "--properties=hibernate.properties"
-msgstr "--properties=hibernate.properties"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--properties=hibernate.properties</literal>"
+msgstr "em <literal>hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:342 toolset_guide.xml:476 toolset_guide.xml:538
 #, no-c-format
 msgid "read database properties from a file"
-msgstr "read database properties from a file"
+msgstr "leia propriedades de banco de dados a partir dos arquivos"
 
-#. Tag: literal
-#: toolset_guide.xml:345
+#. Tag: entry
 #, no-c-format
-msgid "--format"
-msgstr "--format"
+msgid "<literal>--format</literal>"
+msgstr "<literal>--format</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:346
 #, no-c-format
 msgid "format the generated SQL nicely in the script"
-msgstr "format the generated SQL nicely in the script"
+msgstr "formatar bem o SQL gerado no script"
 
-#. Tag: literal
-#: toolset_guide.xml:349
+#. Tag: entry
 #, no-c-format
-msgid "--delimiter=;"
-msgstr "--delimiter=;"
+msgid "<literal>--delimiter=;</literal>"
+msgstr "<literal>--delimiter=;</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:350
 #, no-c-format
 msgid "set an end of line delimiter for the script"
-msgstr "set an end of line delimiter for the script"
+msgstr "ajustar e finalizar o delimitador de linha para o script"
 
 #. Tag: para
-#: toolset_guide.xml:356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can even embed <literal>SchemaExport</literal> in your application:"
 msgstr ""
-"You may even embed <literal>SchemaExport</literal> in your application:"
+"Você pode até mesmo incorporar o <literal>SchemaExport</literal> em sua "
+"aplicação: "
 
-#. Tag: programlisting
-#: toolset_guide.xml:360
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaExport(cfg).create(false, true);]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:365
 #, no-c-format
 msgid "Properties"
-msgstr "Properties"
+msgstr "Propriedades"
 
 #. Tag: para
-#: toolset_guide.xml:367
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Database properties can be specified:"
-msgstr "Database properties may be specified"
+msgstr "As Propriedades do Banco de Daods podem ser especificadas:"
 
 #. Tag: para
-#: toolset_guide.xml:373
 #, no-c-format
 msgid ""
 "as system properties with <literal>-D</literal><emphasis>&lt;property&gt;</"
 "emphasis>"
 msgstr ""
-"as system properties with <literal>-D</literal><emphasis>&lt;property&gt;</"
-"emphasis>"
+"Como Propriedades de sistema com <literal>-D</literal><emphasis>&lt;"
+"property&gt;</emphasis>"
 
 #. Tag: para
-#: toolset_guide.xml:376
 #, no-c-format
 msgid "in <literal>hibernate.properties</literal>"
-msgstr "in <literal>hibernate.properties</literal>"
+msgstr "em <literal>hibernate.properties</literal>"
 
 #. Tag: para
-#: toolset_guide.xml:379
 #, no-c-format
 msgid "in a named properties file with <literal>--properties</literal>"
-msgstr "in a named properties file with <literal>--properties</literal>"
+msgstr ""
+"em um arquivo de propriedades nomeadas com <literal>--properties</literal>"
 
 #. Tag: para
-#: toolset_guide.xml:383
 #, no-c-format
 msgid "The needed properties are:"
-msgstr "The needed properties are:"
+msgstr "As propriedades necessárias são:"
 
 #. Tag: title
-#: toolset_guide.xml:388
 #, no-c-format
 msgid "SchemaExport Connection Properties"
 msgstr "SchemaExport Connection Properties"
 
 #. Tag: entry
-#: toolset_guide.xml:394
 #, no-c-format
 msgid "Property Name"
-msgstr "Property Name"
+msgstr "Nome de Propriedade"
 
-#. Tag: literal
-#: toolset_guide.xml:400
-#, no-c-format
-msgid "hibernate.connection.driver_class"
-msgstr "hibernate.connection.driver_class"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.driver_class</literal>"
+msgstr "<literal>hibernate.connection.driver_class</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:401
 #, no-c-format
 msgid "jdbc driver class"
-msgstr "jdbc driver class"
+msgstr "classe de driver jdbc"
 
-#. Tag: literal
-#: toolset_guide.xml:404
-#, no-c-format
-msgid "hibernate.connection.url"
-msgstr "hibernate.connection.url"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.url</literal>"
+msgstr "em <literal>hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:405
 #, no-c-format
 msgid "jdbc url"
 msgstr "jdbc url"
 
-#. Tag: literal
-#: toolset_guide.xml:408
-#, no-c-format
-msgid "hibernate.connection.username"
-msgstr "hibernate.connection.username"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.username</literal>"
+msgstr "em <literal>hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:409
 #, no-c-format
 msgid "database user"
-msgstr "database user"
+msgstr "usuário de banco de dados"
 
-#. Tag: literal
-#: toolset_guide.xml:412
-#, no-c-format
-msgid "hibernate.connection.password"
-msgstr "hibernate.connection.password"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.connection.password</literal>"
+msgstr "em <literal>hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:413
 #, no-c-format
 msgid "user password"
-msgstr "user password"
+msgstr "senha do usuário"
 
-#. Tag: literal
-#: toolset_guide.xml:416
-#, no-c-format
-msgid "hibernate.dialect"
-msgstr "hibernate.dialect"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>hibernate.dialect</literal>"
+msgstr "em <literal>hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:417
 #, no-c-format
 msgid "dialect"
-msgstr "dialect"
+msgstr "dialeto"
 
 #. Tag: title
-#: toolset_guide.xml:426
 #, no-c-format
 msgid "Using Ant"
-msgstr "Using Ant"
+msgstr "Usando o Ant"
 
 #. Tag: para
-#: toolset_guide.xml:428
 #, no-c-format
 msgid ""
 "You can call <literal>SchemaExport</literal> from your Ant build script:"
 msgstr ""
-"You can call <literal>SchemaExport</literal> from your Ant build script:"
+"Você pode chamar o <literal>SchemaExport</literal> a partir de seu script de "
+"construção do Ant:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:432
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemaexport\">\n"
-"    <taskdef name=\"schemaexport\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaExportTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemaexport\n"
-"        properties=\"hibernate.properties\"\n"
-"        quiet=\"no\"\n"
-"        text=\"no\"\n"
-"        drop=\"no\"\n"
-"        delimiter=\";\"\n"
-"        output=\"schema-export.sql\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemaexport>\n"
-"</target>]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:437
 #, no-c-format
 msgid "Incremental schema updates"
-msgstr "Incremental schema updates"
+msgstr "Atualizações de esquema incremental"
 
 #. Tag: para
-#: toolset_guide.xml:439
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>SchemaUpdate</literal> tool will update an existing schema with "
 "\"incremental\" changes. The <literal>SchemaUpdate</literal> depends upon "
 "the JDBC metadata API and, as such, will not work with all JDBC drivers."
 msgstr ""
-"The <literal>SchemaUpdate</literal> tool will update an existing schema with "
-"\"incremental\" changes. Note that <literal>SchemaUpdate</literal> depends "
-"heavily upon the JDBC metadata API, so it will not work with all JDBC "
-"drivers."
+"A ferramenta <literal>SchemaUpdate</literal> irá atualizar um esquema "
+"existente com mudanças \"incrementais\". Observe que <literal>SchemaUpdate</"
+"literal> depende totalmente da API de metadados JDBC, portanto não irá "
+"funcionar com todos os driver JDBC. "
 
 #. Tag: para
-#: toolset_guide.xml:445
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
 "<literal>org.hibernate.tool.hbm2ddl.SchemaUpdate</literal> <emphasis>options "
 "mapping_files</emphasis>"
 msgstr ""
+"<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
+"<literal>org.hibernate.tool.hbm2ddl.SchemaUpdate</literal> <emphasis>options "
+"mapping_files</emphasis>"
 
 #. Tag: title
-#: toolset_guide.xml:451
 #, no-c-format
 msgid "<literal>SchemaUpdate</literal> Command Line Options"
-msgstr "<literal>SchemaUpdate</literal> Command Line Options"
+msgstr "<literal>SchemaUpdate</literal>Opções de Linha de Comando"
 
 #. Tag: entry
-#: toolset_guide.xml:468
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "do not export the script to the database"
-msgstr "don't export the script to the database"
+msgstr "não exporte o script ao banco de dados "
 
 #. Tag: entry
-#: toolset_guide.xml:480 toolset_guide.xml:542
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "specify a <literal>.cfg.xml</literal> file"
-msgstr "specify a <placeholder-1/> file"
+msgstr "especifique um arquivo <literal>.cfg.xml</literal>"
 
 #. Tag: para
-#: toolset_guide.xml:486
-#, fuzzy, no-c-format
-msgid "You can embed <literal>SchemaUpdate</literal> in your application:"
-msgstr "You may embed <literal>SchemaUpdate</literal> in your application:"
-
-#. Tag: programlisting
-#: toolset_guide.xml:490
 #, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaUpdate(cfg).execute(false);]]>"
+msgid "You can embed <literal>SchemaUpdate</literal> in your application:"
 msgstr ""
+"Você pode incorporar o <literal>SchemaUpdate</literal> em sua aplicação: "
 
 #. Tag: title
-#: toolset_guide.xml:495
 #, no-c-format
 msgid "Using Ant for incremental schema updates"
-msgstr "Using Ant for incremental schema updates"
+msgstr "Utilizando Ant para atualizações de esquema incremental"
 
 #. Tag: para
-#: toolset_guide.xml:497
 #, no-c-format
 msgid "You can call <literal>SchemaUpdate</literal> from the Ant script:"
-msgstr "You can call <literal>SchemaUpdate</literal> from the Ant script:"
-
-#. Tag: programlisting
-#: toolset_guide.xml:501
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemaupdate\">\n"
-"    <taskdef name=\"schemaupdate\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaUpdateTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemaupdate\n"
-"        properties=\"hibernate.properties\"\n"
-"        quiet=\"no\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemaupdate>\n"
-"</target>]]>"
 msgstr ""
+"Você pode chamar <literal>SchemaUpdate</literal> a partir do script Ant:"
 
 #. Tag: title
-#: toolset_guide.xml:506
 #, no-c-format
 msgid "Schema validation"
-msgstr "Schema validation"
+msgstr "Validação de esquema"
 
 #. Tag: para
-#: toolset_guide.xml:508
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>SchemaValidator</literal> tool will validate that the existing "
 "database schema \"matches\" your mapping documents. The "
@@ -1073,126 +896,97 @@
 "API and, as such, will not work with all JDBC drivers. This tool is "
 "extremely useful for testing."
 msgstr ""
-"The <literal>SchemaValidator</literal> tool will validate that the existing "
-"database schema \"matches\" your mapping documents. Note that "
-"<literal>SchemaValidator</literal> depends heavily upon the JDBC metadata "
-"API, so it will not work with all JDBC drivers. This tool is extremely "
-"useful for testing."
+"A ferramenta <literal>SchemaValidator</literal> irá confirmar que o esquema "
+"de banco de dados existente \"combina\" com seus documentos de mapeamento. "
+"Observe que o <literal>SchemaValidator</literal> depende totalmente da API "
+"de metadados JDBC, portanto ele não funcionará com todos os drivers JDBC. "
+"Esta ferramenta é extremamente útil para teste. "
 
 #. Tag: para
-#: toolset_guide.xml:514
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
 "<literal>org.hibernate.tool.hbm2ddl.SchemaValidator</literal> "
 "<emphasis>options mapping_files</emphasis>"
 msgstr ""
+"<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
+"<literal>org.hibernate.tool.hbm2ddl.SchemaValidator</literal> "
+"<emphasis>options mapping_files</emphasis>"
 
 #. Tag: para
-#: toolset_guide.xml:518
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table displays the <literal>SchemaValidator</literal> command "
 "line options:"
-msgstr "<literal>SchemaValidator</literal> Command Line Options"
+msgstr ""
+"A seguinte tabela exibe as opções de linha de comando do "
+"<literal>SchemaValidator</literal>:"
 
 #. Tag: title
-#: toolset_guide.xml:521
 #, no-c-format
 msgid "<literal>SchemaValidator</literal> Command Line Options"
-msgstr "<literal>SchemaValidator</literal> Command Line Options"
+msgstr "<literal>SchemaValidator</literal> Opções de Linha de Comando"
 
 #. Tag: para
-#: toolset_guide.xml:548
-#, fuzzy, no-c-format
-msgid "You can embed <literal>SchemaValidator</literal> in your application:"
-msgstr "You may embed <literal>SchemaValidator</literal> in your application:"
-
-#. Tag: programlisting
-#: toolset_guide.xml:552
 #, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaValidator(cfg).validate();]]>"
+msgid "You can embed <literal>SchemaValidator</literal> in your application:"
 msgstr ""
+"Você pode incorporar o <literal>SchemaValidator</literal> em sua aplicação:"
 
 #. Tag: title
-#: toolset_guide.xml:557
 #, no-c-format
 msgid "Using Ant for schema validation"
-msgstr "Using Ant for schema validation"
+msgstr "Utilizando Ant para validação de esquema"
 
 #. Tag: para
-#: toolset_guide.xml:559
 #, no-c-format
 msgid "You can call <literal>SchemaValidator</literal> from the Ant script:"
-msgstr "You can call <literal>SchemaValidator</literal> from the Ant script:"
-
-#. Tag: programlisting
-#: toolset_guide.xml:563
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemavalidate\">\n"
-"    <taskdef name=\"schemavalidator\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaValidatorTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemavalidator\n"
-"        properties=\"hibernate.properties\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemavalidator>\n"
-"</target>]]>"
 msgstr ""
+"Você pode chamar o <literal>SchemaValidator</literal> a partir do script Ant:"
 
-#~ msgid "Ant Tasks:"
-#~ msgstr "Ant Tasks:"
+#, fuzzy
+#~ msgid "length"
+#~ msgstr "comprimento da coluna"
 
-#~ msgid "&lt;one-to-one&gt;"
-#~ msgstr "&lt;one-to-one&gt;"
+#, fuzzy
+#~ msgid "precision"
+#~ msgstr "Expressão SQL "
 
-#~ msgid "&lt;many-to-one&gt;"
-#~ msgstr "&lt;many-to-one&gt;"
+#, fuzzy
+#~ msgid "unique_key_name"
+#~ msgstr "<literal>unique_key_name</literal>"
 
-#~ msgid "&lt;key&gt;"
-#~ msgstr "&lt;key&gt;"
+#, fuzzy
+#~ msgid "foreign_key_name"
+#~ msgstr "<literal>foreign_key_name</literal>"
 
-#~ msgid "&lt;many-to-many&gt;"
-#~ msgstr "&lt;many-to-many&gt;"
+#, fuzzy
+#~ msgid "SQL column type"
+#~ msgstr "<literal>SQL column type</literal>"
 
-#~ msgid "inverse=\"true\""
-#~ msgstr "inverse=\"true\""
+#, fuzzy
+#~ msgid "--output=my_schema.ddl"
+#~ msgstr "<literal>--output=my_schema.ddl</literal>"
 
-#~ msgid "SchemaExport"
-#~ msgstr "SchemaExport"
+#, fuzzy
+#~ msgid "--properties=hibernate.properties"
+#~ msgstr "<literal>--properties=hibernate.properties</literal>"
 
-#~ msgid "&lt;column&gt;"
-#~ msgstr "&lt;column&gt;"
+#, fuzzy
+#~ msgid "hibernate.connection.url"
+#~ msgstr "<literal>hibernate.connection.url</literal>"
 
-#~ msgid "java -cp"
-#~ msgstr "java -cp"
+#, fuzzy
+#~ msgid "hibernate.connection.username"
+#~ msgstr "<literal>hibernate.connection.username</literal>"
 
-#~ msgid "hibernate_classpaths"
-#~ msgstr "hibernate_classpaths"
+#, fuzzy
+#~ msgid "hibernate.connection.password"
+#~ msgstr "<literal>hibernate.connection.password</literal>"
 
-#~ msgid "org.hibernate.tool.hbm2ddl.SchemaExport"
-#~ msgstr "org.hibernate.tool.hbm2ddl.SchemaExport"
+#, fuzzy
+#~ msgid "hibernate.dialect"
+#~ msgstr "<literal>hibernate.dialect</literal>"
 
-#~ msgid "options mapping_files"
-#~ msgstr "options mapping_files"
-
-#~ msgid "NamingStrategy"
-#~ msgstr "NamingStrategy"
-
-#~ msgid "select a <placeholder-1/>"
-#~ msgstr "select a <placeholder-1/>"
-
-#~ msgid "org.hibernate.tool.hbm2ddl.SchemaUpdate"
-#~ msgstr "org.hibernate.tool.hbm2ddl.SchemaUpdate"
-
-#~ msgid ".cfg.xml"
-#~ msgstr ".cfg.xml"
-
-#~ msgid "org.hibernate.tool.hbm2ddl.SchemaValidator"
-#~ msgstr "org.hibernate.tool.hbm2ddl.SchemaValidator"
+#~ msgid "<!-- <emphasis>Ant Tasks:</emphasis> -->"
+#~ msgstr "<!-- <emphasis>Tarefas Ant:</emphasis> -->"

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/transactions.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/transactions.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/transactions.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,129 @@
+# translation of transactions.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: transactions\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2009-12-21 07:53+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: transactions.xml:29
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Transactions and Concurrency"
-msgstr "Transações e Concorrência"
+msgstr "Transações e Concorrência "
 
 #. Tag: para
-#: transactions.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The most important point about Hibernate and concurrency control is that it "
 "is easy to understand. Hibernate directly uses JDBC connections and JTA "
@@ -26,16 +131,15 @@
 "that you spend some time with the JDBC, ANSI, and transaction isolation "
 "specification of your database management system."
 msgstr ""
-"O ponto o mais importante sobre o Hibernate e o controle de concorrência é "
-"que é muito fácil de ser compreendido. O Hibernate usa diretamente conexões "
-"de JDBC e recursos de JTA sem adicionar nenhum comportamento de bloqueio a "
-"mais. Nós altamente recomendamos que você gaste algum tempo com o JDBC, o "
-"ANSI e a especificação de isolamento de transação de seu sistema de gerência "
-"da base de dados."
+"O fator mais importante sobre o Hibernate e o controle de concorrência é que "
+"é muito fácil de ser compreendido. O Hibernate usa diretamente conexões de "
+"JDBC e recursos de JTA sem adicionar nenhum comportamento de bloqueio a "
+"mais. Recomendamos que você gaste algum tempo com o JDBC, o ANSI e a "
+"especificação de isolamento de transação de seu sistema de gerência da base "
+"de dados. "
 
 #. Tag: para
-#: transactions.xml:38
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate does not lock objects in memory. Your application can expect the "
 "behavior as defined by the isolation level of your database transactions. "
@@ -44,15 +148,14 @@
 "entity queries and not reporting queries that return scalar values."
 msgstr ""
 "O Hibernate não bloqueia objetos na memória. Sua aplicação pode esperar o "
-"comportamento tal qual definido pelo nível de isolamento de suas transações "
-"de banco de dados. Note que graças ao <literal>Session</literal>, que também "
-"é um cache de escopo de transação, o Hibernate fornece leituras repetíveis "
-"para procurar por identificadores e consultas de entidade (não pesquisas de "
-"relatórios que retornam valores escalares)."
+"comportamento tal qual definido de acordo com o nível de isolamento de suas "
+"transações de banco de dados. Note que graças ao <literal>Session</literal>, "
+"que também é um cache de escopo de transação, o Hibernate procura "
+"repetidamente por identificadores e consultas de entidade não consultas de "
+"relatórios que retornam valores escalares. "
 
 #. Tag: para
-#: transactions.xml:46
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In addition to versioning for automatic optimistic concurrency control, "
 "Hibernate also offers, using the <literal>SELECT FOR UPDATE</literal> "
@@ -61,12 +164,11 @@
 msgstr ""
 "Além do versionamento para o controle automático de concorrência otimista, o "
 "Hibernate oferece também uma API (menor) para bloqueio pessimista de linhas "
-"usando a sintaxe <literal>SELECT FOR UPDATE</literal>. O controle de "
-"concorrência otimista e esta API são discutidos mais tarde neste capítulo."
+"usando a sintáxe <literal>SELECT FOR UPDATE</literal>. O controle de "
+"concorrência otimista e esta API são discutidos mais tarde neste capítulo. "
 
 #. Tag: para
-#: transactions.xml:53
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The discussion of concurrency control in Hibernate begins with the "
 "granularity of <literal>Configuration</literal>, <literal>SessionFactory</"
@@ -75,32 +177,29 @@
 msgstr ""
 "Nós começamos a discussão do controle de concorrência no Hibernate com a "
 "granularidade do <literal>Configuration</literal>, <literal>SessionFactory</"
-"literal>, e <literal>Session</literal>, além de transações de base de dados "
-"e conversações longas."
+"literal> e <literal>Session</literal>, além de transações de base de dados e "
+"conversações longas. "
 
 #. Tag: title
-#: transactions.xml:60
 #, no-c-format
 msgid "Session and transaction scopes"
-msgstr "Session e escopos de transações"
+msgstr "Sessão e escopos de transações"
 
 #. Tag: para
-#: transactions.xml:62
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>SessionFactory</literal> is an expensive-to-create, threadsafe "
 "object, intended to be shared by all application threads. It is created "
 "once, usually on application startup, from a <literal>Configuration</"
 "literal> instance."
 msgstr ""
-"Um <literal>SessionFactory</literal> é objeto threadsafe compartilhado por "
-"todas as threads da aplicação que consome muitos recursos na sua criação. É "
-"criado uma unica vez no inicio da execução da aplicação a partir da "
-"instância de uma <literal>Configuration</literal>."
+"Um <literal>SessionFactory</literal> é objeto threadsafe com um custo alto "
+"de criação, compartilhado por todas as threads da aplicação. É criado uma "
+"única vez, no início da execução da aplicação, a partir da instância de uma "
+"<literal>Configuration</literal>. "
 
 #. Tag: para
-#: transactions.xml:68
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>Session</literal> is an inexpensive, non-threadsafe object that "
 "should be used once and then discarded for: a single request, a conversation "
@@ -111,13 +210,12 @@
 "Uma <literal>Session</literal> é um objeto de baixo custo de criação, não é "
 "threadsafe, deve ser usado uma vez, para uma única requisição, uma "
 "conversação, uma única unidade do trabalho e então deve ser descartado. Um "
-"<literal>Session</literal> não obterá um JDBC <literal>Connection</literal> "
-"(ou um <literal>Datasource</literal>) a menos que necessite, "
-"conseqüentemente não consome nenhum recurso até ser usado."
+"<literal>Session</literal> não obterá um JDBC <literal>Connection</literal>, "
+"ou um <literal>Datasource</literal>, a menos que necessite. Isto não consome "
+"nenhum recurso até ser usado."
 
 #. Tag: para
-#: transactions.xml:76
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In order to reduce lock contention in the database, a database transaction "
 "has to be as short as possible. Long database transactions will prevent your "
@@ -125,16 +223,14 @@
 "that you hold a database transaction open during user think time until the "
 "unit of work is complete."
 msgstr ""
-"Para completar, você também tem que pensar sobre as transações de base de "
-"dados. Uma transação tem que ser tão curta quanto possível, para reduzir a "
-"disputa pelo bloqueio na base de dados. Transações longas impedirão que sua "
-"aplicação escale a carga altamente concorrente. Por isso, em um projeto "
-"raramente é para manter uma transação de base de dados aberta durante o "
-"tempo que o usuário pensa, até que a unidade do trabalho esteja completa."
+"Uma transação precisa ser o mais curta possível, para reduzir a disputa pelo "
+"bloqueio na base de dados. Transações longas impedirão que sua aplicação "
+"escale a carga altamente concorrente. Por isso, não é bom manter uma "
+"transação de base de dados aberta durante o tempo que o usuário pensa, até "
+"que a unidade do trabalho esteja completa."
 
 #. Tag: para
-#: transactions.xml:84
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What is the scope of a unit of work? Can a single Hibernate "
 "<literal>Session</literal> span several database transactions, or is this a "
@@ -142,21 +238,19 @@
 "<literal>Session</literal> and how do you demarcate the database transaction "
 "boundaries? These questions are addressed in the following sections."
 msgstr ""
-"Qual é o escopo de uma unidade de trabalho? Pode uma únicoa "
-"<literal>Session</literal> do Hibernate gerenciar diversas transações ou é "
-"esta um o relacionamento um-para-um dos escopos? Quando deve você abrir e "
-"fechar uma <literal>Session</literal> e como você demarca os limites da "
-"transação?"
+"Qual é o escopo de uma unidade de trabalho? Pode uma única <literal>Session</"
+"literal> do Hibernate gerenciar diversas transações ou este é um o "
+"relacionamento um-para-um dos escopos? Quando você deve abrir e fechar uma "
+"<literal>Session</literal> e como você demarca os limites da transação? "
+"Estas questões estão endereçadas nas seguintes seções."
 
 #. Tag: title
-#: transactions.xml:92
 #, no-c-format
 msgid "Unit of work"
 msgstr "Unidade de trabalho"
 
 #. Tag: para
-#: transactions.xml:94
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "First, let's define a unit of work. A unit of work is a design pattern "
 "described by Martin Fowler as <quote> [maintaining] a list of objects "
@@ -165,14 +259,24 @@
 "citation> In other words, its a series of operations we wish to carry out "
 "against the database together. Basically, it is a transaction, though "
 "fulfilling a unit of work will often span multiple physical database "
-"transactions (see <xref linkend=\"transactions-basics-apptx\"/>). So really "
+"transactions (see <xref linkend=\"transactions-basics-apptx\" />). So really "
 "we are talking about a more abstract notion of a transaction. The term "
 "\"business transaction\" is also sometimes used in lieu of unit of work."
 msgstr ""
+"Primeiro, vamos definir uma unidade de trabalho. Uma unidade de trabalho é "
+"um padrão de design descrito por Martin Fowler como <quote> [maintaining] a "
+"list of objects affected by a business transaction and coordinates the "
+"writing out of changes and the resolution of concurrency problems. </"
+"quote><citation>PoEAA</citation> Em outras palavras, é uma série de "
+"operações que desejamos cuidar junto ao banco de dados. Basicamente, é uma "
+"transação, que apesar de completar uma unidade de trabalho, sempre "
+"distribuirá transações de banco de dados físico múltiplos (consulte <xref "
+"linkend=\"transactions-basics-apptx\"/>). Portanto, estamos conversando "
+"sobre uma noção mais abstrata da transação. O termo \"transação comercial\" "
+"é também usada em acúmulo na unidade de trabalho. "
 
 #. Tag: para
-#: transactions.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not use the <emphasis>session-per-operation</emphasis> antipattern: do "
 "not open and close a <literal>Session</literal> for every simple database "
@@ -188,26 +292,25 @@
 "clearly defined unit of work. The latter is also more maintainable and "
 "extensible."
 msgstr ""
-"Primeiro, não use o antipattern <emphasis>sessão-por-operação</emphasis>, "
-"isto é, não abra e não feche uma <literal>Session</literal> para cada "
-"simples chamada ao banco de de dados em uma única thread! Naturalmente, o "
-"mesmo é verdadeiro para transações. As chamadas a banco de dados em uma "
+"Primeiro, não use o antipattern <emphasis>sessão-por-operação</emphasis>: "
+"isto é, não abra e feche uma <literal>Session</literal> para cada simples "
+"chamada ao banco de dados em uma única thread. Naturalmente, o mesmo se "
+"aplica às transações do banco de dados. As chamadas ao banco de dados em uma "
 "aplicação são feitas usando uma seqüência planejada, elas são agrupadas em "
-"unidades de trabalho atômicas. (Veja que isso também significa que um auto-"
-"commit depois de cada sentença SQL é inútil em uma aplicação, esta "
+"unidades de trabalho atômicas. Veja que isso também significa que realizar "
+"um auto-commit depois de cada instrução SQL é inútil em uma aplicação, esta "
 "modalidade é ideal para o trabalho ad hoc do console do SQL. O Hibernate "
-"impede, ou espera que o servidor de aplicação impessa isso, o uso da "
-"modalidade de auto-commit.) As transações nunca são opcionais, toda a "
-"comunicação com um banco de dados tem que ocorrer dentro de uma transação, "
-"não importa se você vai ler ou escrever dados. Como explicado, o "
-"comportamento auto-commit para leitura de dados deve ser evitado, como "
-"muitas transações pequenas são improváveis de executar melhor do que uma "
-"unidade claramente definida do trabalho. A última opção também muito mais "
-"manutenível e extensível."
+"impede, ou espera que o servidor de aplicação impessa isso, aplique a "
+"modalidade auto-commit imediatamente. As transações de banco de dados nunca "
+"são opcionais, toda a comunicação com um banco de dados tem que ocorrer "
+"dentro de uma transação, não importa se você vai ler ou escrever dados. Como "
+"explicado, o comportamento auto-commit para leitura de dados deve ser "
+"evitado, uma vez que muitas transações pequenas são improváveis de executar "
+"melhor do que uma unidade de trabalho claramente definida. A última opção é "
+"também muito mais sustentável e expandida."
 
 #. Tag: para
-#: transactions.xml:126
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The most common pattern in a multi-user client/server application is "
 "<emphasis>session-per-request</emphasis>. In this model, a request from the "
@@ -220,21 +323,20 @@
 "literal>. The relationship between the two is one-to-one and this model is a "
 "perfect fit for many applications."
 msgstr ""
-"O pattern mais comum em uma aplicação multi-usuário cliente/servidor é "
+"O modelo mais comum em uma aplicação de cliente/servidor multi-usuário  é "
 "<emphasis>sessão-por-requisição</emphasis>. Neste modelo, uma requisição do "
-"cliente é enviada ao servidor (onde a camada de persistência do Hibernate "
-"roda), uma <literal>Session</literal> nova do Hibernate é aberta, e todas as "
-"operações da base de dados são executadas nesta unidade do trabalho. Logo "
-"que o trabalho for completado (e a resposta para o cliente for preparada), a "
-"sessão é descarregad e fechada. Você usaria também uma única transação de "
-"base de dados para servir às requisições dos clientes, começando e "
-"commitando-o quando você abre e fecha a <literal>Session</literal>. O "
+"cliente é enviada ao servidor, onde a camada de persistência do Hibernate é "
+"executada, uma <literal>Session</literal> nova do Hibernate é aberta, e "
+"todas as operações da base de dados são executadas nesta unidade do "
+"trabalho. Logo que o trabalho for completado, e a resposta para o cliente "
+"for preparada, a sessão é descarregada e fechada. Você usaria também uma "
+"única transação de base de dados para servir às requisições dos clientes, "
+"iniciando e submetendo-o ao abrir e fechar da <literal>Session</literal>. O "
 "relacionamento entre os dois é um-para-um e este modelo é um ajuste perfeito "
 "para muitas aplicações."
 
 #. Tag: para
-#: transactions.xml:138
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The challenge lies in the implementation. Hibernate provides built-in "
 "management of the \"current session\" to simplify this pattern. Start a "
@@ -248,40 +350,38 @@
 "use the Hibernate <literal>Transaction</literal> API shown later in this "
 "chapter."
 msgstr ""
-"O desafio encontra-se na implementação. O Hibernate fornece gerência "
-"integrada da \"sessão atual\" para simplificar este pattern. Tudo que você "
-"tem que fazer é iniciar uma transação quando uma requisição tem que ser "
-"processada e termina a transação antes que a resposta seja enviada ao "
+"O desafio encontra-se na implementação. O Hibernate fornece gerenciamento "
+"integrado da \"sessão atual\" para simplificar este modelo. Tudo que você "
+"tem a fazer é iniciar uma transação quando uma requisição precisa ser "
+"processada e terminar a transação antes que a resposta seja enviada ao "
 "cliente. Você pode fazer onde quiser, soluções comuns são "
 "<literal>ServletFilter</literal>, interceptador AOP com um pointcut (ponto "
-"de corte) nos métodos de serviço ou em um container de proxy/interceptação. "
-"Um container de EJB é uma maneira padronizada para implementar aspectos "
-"cross-cutting tais como a demarcação da transação em EJB session beans, "
+"de corte) nos métodos de serviço ou em um recipiente de proxy/interceptação. "
+"Um recipiente de EJB é uma maneira padronizada de implementar aspectos cross-"
+"cutting, tais como a demarcação da transação em beans de sessão EJB, "
 "declarativamente com CMT. Se você se decidir usar demarcação programática de "
-"transação, de preferencia a API <literal>Transaction</literal> do Hibernate "
-"mostrada mais adiante neste capítulo, para fácilidade no uso e portabilidade "
-"de código."
+"transação, dê preferência à API <literal>Transaction</literal> do Hibernate "
+"mostrada mais adiante neste capítulo, para facilidade no uso e portabilidade "
+"de código. "
 
 #. Tag: para
-#: transactions.xml:150
 #, fuzzy, no-c-format
 msgid ""
 "Your application code can access a \"current session\" to process the "
 "request by calling <literal>sessionFactory.getCurrentSession()</literal>. "
 "You will always get a <literal>Session</literal> scoped to the current "
 "database transaction. This has to be configured for either resource-local or "
-"JTA environments, see <xref linkend=\"architecture-current-session\"/>."
+"JTA environments, see <xref linkend=\"architecture-current-session\" />."
 msgstr ""
 "Seu código de aplicação pode acessar a \"sessão atual\" para processar a "
 "requisição fazendo uma chamada simples a <literal>sessionFactory."
-"getCurrentSession()</literal> em qualquer lugar e com a frequencia "
+"getCurrentSession()</literal> em qualquer lugar e com a freqüência "
 "necessária. Você sempre conseguirá uma <literal>Session</literal> limitada a "
-"transação atual. Isto tem que ser configurado para recurso local ou os "
-"ambientes JTA. Veja <xref linkend=\"architecture-current-session\"/>."
+"transação atual. Isto tem que ser configurado para recurso local ou para "
+"ambientes JTA. Veja <xref linkend=\"architecture-current-session\"/>. "
 
 #. Tag: para
-#: transactions.xml:158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can extend the scope of a <literal>Session</literal> and database "
 "transaction until the \"view has been rendered\". This is especially useful "
@@ -293,27 +393,25 @@
 "of any view can start. See the Hibernate website and forum for tips and "
 "examples relating to this <emphasis>Open Session in View</emphasis> pattern."
 msgstr ""
-"Às vezes é conveniente estender o escopo de uma <literal>Session</literal> e "
-"de uma transação do banco de dados até que a \"visão esteja renderizada\". É "
-"especialmente útil em aplicações servlet que utilizam uma fase de "
-"rendenderização separada depois que a requisição ter sido processada. "
-"Estendendo a transação até que renderização da visão esteja completa é fácil "
-"de fazer se você implementar seu próprio interceptador. Entretanto, não se "
-"pode fazer facilmente se você confiar em EJBs com transações gerenciadas por "
-"contêiner, porque uma transação será terminada quando um método de EJB "
-"retornar, antes da renderização de toda visão puder começar. Veja o website "
-"e o fórum do Hibernate para dicas e exemplos em torno deste pattern "
-"<emphasis>Open Session in View</emphasis>."
+"Ás vezes, é conveniente estender o escopo de uma <literal>Session</literal> "
+"e de uma transação do banco de dados até que a \"visão esteja renderizada\". "
+"É especialmente útil em aplicações servlet que utilizam uma fase de "
+"renderização separada depois da requisição ter sido processada. Estender a "
+"transação até que a renderização da visão esteja completa é fácil de fazer "
+"se você implementar seu próprio interceptador. Entretanto, não será fácil se "
+"você confiar em EJBs com transações gerenciadas por recipiente, porque uma "
+"transação será terminada quando um método de EJB retornar, antes que a "
+"renderização de toda visão possa começar. Veja o website e o fórum do "
+"Hibernate para dicas e exemplos em torno deste modelo de <emphasis>Sessão "
+"Aberta na Visualização</emphasis>."
 
 #. Tag: title
-#: transactions.xml:173
 #, no-c-format
 msgid "Long conversations"
 msgstr "Longas conversações"
 
 #. Tag: para
-#: transactions.xml:175
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The session-per-request pattern is not the only way of designing units of "
 "work. Many business processes require a whole series of interactions with "
@@ -321,53 +419,49 @@
 "applications, it is not acceptable for a database transaction to span a user "
 "interaction. Consider the following example:"
 msgstr ""
-"O pattern sessão-por-requisição não é o único conceito útil que você pode "
+"O modelo sessão-por-requisição não é o único conceito útil que você pode "
 "usar ao projetar unidades de trabalho. Muitos processos de negócio requerem "
-"uma totalidade de séries de interações com o usuário intercaladas com "
-"acessos a uma base de dados. Em aplicações web e corporativas não é "
-"aceitável para uma transação atrapalhe uma interação do usuário. Considere o "
+"uma totalidade de séries de interações com o usuário, intercaladas com "
+"acessos a uma base de dados. Em aplicações da web e corporativas não é "
+"aceitável que uma transação atrapalhe uma interação do usuário. Considere o "
 "seguinte exemplo:"
 
 #. Tag: para
-#: transactions.xml:185
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The first screen of a dialog opens. The data seen by the user has been "
 "loaded in a particular <literal>Session</literal> and database transaction. "
 "The user is free to modify the objects."
 msgstr ""
-"A primeira tela de um diálogo abre os dados carregado pelo usuário em "
-"através de <literal>Session</literal> e transação particulares. O usuário "
-"está livre modificar os objetos."
+"A primeira tela de um diálogo se abre e os dados vistos pelo usuário são "
+"carregados em uma <literal>Session</literal> e transação de banco de dados "
+"particulares. O usuário está livre para modificar os objetos. "
 
 #. Tag: para
-#: transactions.xml:192
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The user clicks \"Save\" after 5 minutes and expects their modifications to "
 "be made persistent. The user also expects that they were the only person "
 "editing this information and that no conflicting modification has occurred."
 msgstr ""
 "O usuário clica em \"Salvar\" após 5 minutos e espera suas modificações "
-"serem persistidas; espera também que ele era a única pessoa que edita esta "
-"informação e que nenhuma modificação conflitante possa ocorrer."
+"serem persistidas. O usuário também espera que ele seja a única pessoa que "
+"edita esta informação e que nenhuma modificação conflitante possa ocorrer."
 
 #. Tag: para
-#: transactions.xml:200
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "From the point of view of the user, we call this unit of work a long-running "
 "<emphasis>conversation</emphasis> or <emphasis>application transaction</"
 "emphasis>. There are many ways to implement this in your application."
 msgstr ""
-"Nós chamamos esta unidade de trabalho, do ponto da visão do usuário, "
-"executando uma longa <emphasis>conversação</emphasis> (ou "
-"<emphasis>transação da aplicação</emphasis>). Há muitas maneiras de você "
-"pode implementar em sua aplicação."
+"Nós chamamos esta unidade de trabalho, do ponto da visão do usuário, uma "
+"<emphasis>conversação</emphasis> de longa duração (ou <emphasis>transação da "
+"aplicação</emphasis>). Há muitas maneiras de você implementar em sua "
+"aplicação. "
 
 #. Tag: para
-#: transactions.xml:206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A first naive implementation might keep the <literal>Session</literal> and "
 "database transaction open during user think time, with locks held in the "
@@ -375,16 +469,15 @@
 "atomicity. This is an anti-pattern, since lock contention would not allow "
 "the application to scale with the number of concurrent users."
 msgstr ""
-"Uma primeira implementação simples pode manter a<literal>Session</literal> e "
-"a transação aberta durante o tempo de interação do usuário, com bloqueios na "
-"base de dados para impedir a modificação concorrente e para garantir o "
-"isolamento e a atomicidade. Esse é naturalmente um anti-pattern, desde que a "
-"disputa do bloqueio não permitiria o escalonameneto da aplicação com o "
+"Uma primeira implementação simples pode manter a <literal>Session</literal> "
+"e a transação aberta durante o tempo de interação do usuário, com bloqueios "
+"na base de dados para impedir a modificação concorrente e para garantir o "
+"isolamento e a atomicidade. Esse é naturalmente um anti-pattern, uma vez que "
+"a disputa do bloqueio não permitiria o escalonameneto da aplicação com o "
 "número de usuários concorrentes."
 
 #. Tag: para
-#: transactions.xml:214
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You have to use several database transactions to implement the conversation. "
 "In this case, maintaining isolation of business processes becomes the "
@@ -395,34 +488,32 @@
 "several request/response cycles). This is easier to implement than it might "
 "sound, especially if you utilize some of Hibernate's features:"
 msgstr ""
-"Claramente, nós temos que usar diversas transações para implementar a "
-"conversação. Neste caso, Manter o isolamento dos processos de negócio torna-"
+"Claramente, temos que usar diversas transações para implementar a "
+"conversação. Neste caso, manter o isolamento dos processos de negócio, torna-"
 "se responsabilidade parcial da camada da aplicação. Uma única conversação "
 "geralmente usa diversas transações. Ela será atômica se somente uma destas "
 "transações (a última) armazenar os dados atualizados, todas as outras "
 "simplesmente leram os dados (por exemplo em um diálogo do estilo wizard que "
 "mede diversos ciclos de requisição/resposta). Isto é mais fácil de "
-"implementar do que pode parecer, especialmente se você usar as "
-"características do Hibernate:"
+"implementar do parece, especialmente se você usar as características do "
+"Hibernate: "
 
 #. Tag: para
-#: transactions.xml:227
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Automatic Versioning</emphasis>: Hibernate can perform automatic "
 "optimistic concurrency control for you. It can automatically detect if a "
 "concurrent modification occurred during user think time. Check for this at "
 "the end of the conversation."
 msgstr ""
-"<emphasis>Versionamento automático</emphasis> - O Hibernate pode fazer o "
+"<emphasis>Versionamento automático</emphasis>: o Hibernate pode fazer o "
 "controle automático de concorrência otimista para você, ele pode "
 "automaticamente detectar se uma modificação concorrente ocorreu durante o "
 "tempo de interação do usuário. Geralmente nós verificamos somente no fim da "
-"conversação."
+"conversação. "
 
 #. Tag: para
-#: transactions.xml:235
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Detached Objects</emphasis>: if you decide to use the "
 "<emphasis>session-per-request</emphasis> pattern, all loaded instances will "
@@ -431,17 +522,16 @@
 "<emphasis>session-per-request-with-detached-objects</emphasis>. Automatic "
 "versioning is used to isolate concurrent modifications."
 msgstr ""
-"<emphasis>Detached Objects</emphasis>- se você se decidir usar o já "
-"discutido pattern <emphasis>session-per-request</emphasis>, todas as "
+"<emphasis>Objetos Desanexados</emphasis>: se você se decidir usar o já "
+"discutido pattern <emphasis>sessão-por-solicitação</emphasis>, todas as "
 "instâncias carregadas estarão no estado destacado durante o tempo em que o "
-"usuário estiver pensando. O Hibernate permite que você reatache os objetos e "
-"persita as modificações, esse pattern é chamado <emphasis>session-per-"
-"request-with-detached-objects</emphasis>. É usado versionamento automatico "
-"para isolar as modificações concorrentes."
+"usuário estiver pensando. O Hibernate permite que você re-anexe os objetos e "
+"persista as modificações, esse pattern é chamado <emphasis>sessão-por-"
+"solicitação-com-objetos-desanexados</emphasis>. Utiliza-se versionamento "
+"automático para isolar as modificações concorrentes."
 
 #. Tag: para
-#: transactions.xml:245
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Extended (or Long) Session</emphasis>: the Hibernate "
 "<literal>Session</literal> can be disconnected from the underlying JDBC "
@@ -452,38 +542,35 @@
 "<literal>Session</literal> will not be allowed to be flushed automatically, "
 "but explicitly."
 msgstr ""
-"<emphasis>Extended (or Long) Session</emphasis> A <literal>Session</literal> "
-"do Hibernate pode ser desligada da conexão básica do JDBC depois que a "
-"transação foi commitada e ser reconectado quando uma nova requisição do "
-"cliente ocorrer. Este pattern é conhecido como <emphasis>session-per-"
-"conversation</emphasis> e faz o reatamento uniforme desnecessário. "
+"<emphasis>Sessão Estendida (ou Longa)</emphasis> A <literal>Session</"
+"literal> do Hibernate pode ser desligada da conexão adjacente do JDBC depois "
+"que a transação foi submetida, e ser reconectada quando uma nova requisição "
+"do cliente ocorrer. Este pattern é conhecido como <emphasis>sessão-por-"
+"conversação</emphasis> e faz o reatamento uniforme desnecessário. "
 "Versionamento automático é usado para isolar modificações concorrentes e a "
-"<emphasis>session-per-conversation</emphasis> usualmente não é permitido "
-"para ser nivelado automaticamente, e sim explicitamente."
+"<emphasis>sessão-por-conversação</emphasis> geralmente pode ser nivelada "
+"automaticamente, e sim explicitamente. "
 
 #. Tag: para
-#: transactions.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Both <emphasis>session-per-request-with-detached-objects</emphasis> and "
 "<emphasis>session-per-conversation</emphasis> have advantages and "
 "disadvantages. These disadvantages are discussed later in this chapter in "
 "the context of optimistic concurrency control."
 msgstr ""
-"Ambos <emphasis>session-per-request-with-detached-objects</emphasis> e "
-"<emphasis>session-per-conversation</emphasis> possuem vantagens e "
-"desvantagens, nos discutiremos mais tarde neste capítulo no contexto do "
-"controle de concorrência otimista."
+"Tanto a <emphasis>sessão-por-solicitação-com-objetos-desanexados</emphasis> "
+"quanto a <emphasis>sessão-por-conversação</emphasis> possuem vantagens e "
+"desvantagens. Estas desvantagens serão discutidas mais tarde neste capítulo "
+"no contexto do controle de concorrência otimista. "
 
 #. Tag: title
-#: transactions.xml:267
 #, no-c-format
 msgid "Considering object identity"
 msgstr "Considerando a identidade do objeto"
 
 #. Tag: para
-#: transactions.xml:269
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An application can concurrently access the same persistent state in two "
 "different <literal>Session</literal>s. However, an instance of a persistent "
@@ -493,36 +580,31 @@
 "Uma aplicação pode acessar concorrentemente o mesmo estado persistente em "
 "duas <literal>Session</literal>s diferentes. Entretanto, uma instância de "
 "uma classe persistente nunca é compartilhada entre duas instâncias "
-"<literal>Session</literal>. Por tanto, há duas noções diferentes da "
-"identidade:"
+"<literal>Session</literal>. Portanto, há duas noções diferentes da "
+"identidade:  "
 
 #. Tag: term
-#: transactions.xml:278
 #, no-c-format
 msgid "Database Identity"
 msgstr "Identidade da base de dados"
 
-#. Tag: literal
-#: transactions.xml:281
-#, no-c-format
-msgid "foo.getId().equals( bar.getId() )"
-msgstr "foo.getId().equals( bar.getId() )"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>foo.getId().equals( bar.getId() )</literal>"
+msgstr "<literal>foo.getId().equals( bar.getId() )</literal>"
 
 #. Tag: term
-#: transactions.xml:286
 #, no-c-format
 msgid "JVM Identity"
 msgstr "Identidade da JVM"
 
-#. Tag: literal
-#: transactions.xml:289
+#. Tag: para
 #, no-c-format
-msgid "foo==bar"
-msgstr "foo==bar"
+msgid "<literal>foo==bar</literal>"
+msgstr "<literal>foo==bar</literal>"
 
 #. Tag: para
-#: transactions.xml:295
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For objects attached to a <emphasis>particular</emphasis> <literal>Session</"
 "literal> (i.e., in the scope of a <literal>Session</literal>), the two "
@@ -533,19 +615,18 @@
 "resolved using an optimistic approach and automatic versioning at flush/"
 "commit time."
 msgstr ""
-"Então para os objetos acoplados a um <literal>Session</literal> em "
-"<literal>particular </literal> (isto é no escopo de um <literal>Session</"
-"literal>), as duas noções são equivalentes e a identidade da JVM para a "
-"identidade da base de dados é garantida pelo Hibernate. Entretanto, quando a "
-"aplicação pode acessar concorrentemente o \"mesmo\" objeto do negócio "
-"(identidade persistente) em duas sessões diferentes, as duas instâncias "
-"serão realmente \"diferentes\" (identidade de JVM). Os conflitos são "
-"resolvidos usando (versionamento automático) no flush/commit, usando "
-"abordagem otimista."
+"Então para os objetos acoplados a uma <literal>Session</literal> "
+"<emphasis>específica</emphasis> (ex.: isto está no escopo de uma "
+"<literal>Session</literal>), as duas noções são equivalentes e a identidade "
+"da JVM para a identidade da base de dados é garantida pelo Hibernate. "
+"Entretanto, embora a aplicação possa acessar concorrentemente o \"mesmo\" "
+"objeto do negócio (identidade persistente) em duas sessões diferentes, as "
+"duas instâncias serão realmente \"diferentes\" (identidade de JVM). Os "
+"conflitos são resolvidos usando (versionamento automático) no flush/commit, "
+"usando uma abordagem otimista."
 
 #. Tag: para
-#: transactions.xml:304
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This approach leaves Hibernate and the database to worry about concurrency. "
 "It also provides the best scalability, since guaranteeing identity in single-"
@@ -555,18 +636,17 @@
 "<literal>Session</literal>. Within a <literal>Session</literal> the "
 "application can safely use <literal>==</literal> to compare objects."
 msgstr ""
-"Este caminho deixa o Hibernate e o banco dedados se preocuparem com a "
-"concorrência; também fornece uma escalabilidade melhor, garantindo que a "
-"identidade em unidades de trabalho único-encadeadas não necessite de "
-"bloqueio dispendioso ou de outros meios de sincronização. A aplicação nunca "
-"necessita sincronizar qualquer objeto de negócio tão longo que transpasse "
-"uma única thread por <literal>Session</literal>. Dentro de uma "
-"<literal>Session</literal> a aplicação pode usar com segurança o "
-"<literal>==</literal> para comparar objetos."
+"Este caminho deixa o Hibernate e o banco de dados se preocuparem com a "
+"concorrência. Ele também fornece uma escalabilidade melhor, garantindo que a "
+"identidade em unidades de trabalho single-threaded não necessite de bloqueio "
+"dispendioso ou de outros meios de sincronização. A aplicação nunca necessita "
+"sincronizar qualquer objeto de negócio tão longo que transpasse uma única "
+"thread por <literal>Session</literal>. Dentro de uma <literal>Session</"
+"literal> a aplicação pode usar com segurança o <literal>==</literal> para "
+"comparar objetos. "
 
 #. Tag: para
-#: transactions.xml:313
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, an application that uses <literal>==</literal> outside of a "
 "<literal>Session</literal> might produce unexpected results. This might "
@@ -589,37 +669,36 @@
 "that this is not a Hibernate issue, but simply how Java object identity and "
 "equality has to be implemented."
 msgstr ""
-"Com tudo, uma aplicação que usa <literal>==</literal> fora de uma "
+"No entanto, uma aplicação que usa <literal>==</literal> fora de uma "
 "<literal>Session</literal>, pode ver resultados inesperados. Isto pode "
 "ocorrer mesmo em alguns lugares inesperados, por exemplo, se você colocar "
-"duas instâncias desacopladas em um mesmo <literal>Set</literal>. Ambos podem "
-"ter a mesma identidade na base de dados (isto é eles representam a mesma "
-"linha em uma tabela), mas a identidade da JVM pela definição não garantida "
-"para instâncias em estado desacoplado. O desenvolvedor tem que sobrescrever "
-"os métodos <literal>equals()</literal> e <literal>hashCode()</literal> em "
+"duas instâncias desacopladas em um mesmo <literal>Set</literal>. Ambas podem "
+"ter a mesma identidade na base de dados (ex.: elas representam a mesma "
+"linha), mas a identidade da JVM não é, por definição, garantida para "
+"instâncias em estado desacoplado. O desenvolvedor tem que substituir os "
+"métodos <literal>equals()</literal> e <literal>hashCode()</literal> em "
 "classes persistentes e implementar sua própria noção da igualdade do objeto. "
 "Advertência: nunca use o identificador da base de dados para implementar a "
 "igualdade, use atributos de negócio, uma combinação única, geralmente "
 "imutável. O identificador da base de dados mudará se um objeto transiente "
 "passar para o estado persistente. Se a instância transiente (geralmente "
 "junto com instâncias desacopladas) for inserida em um <literal>Set</"
-"literal>, mudar o hashcode quebra o contrato do <literal>Set</literal>. "
-"Atributos para chaves de negócio não têm que ser tão estável quanto às "
-"chaves primárias da base de dados, você somente tem que garantir a "
-"estabilidade durante o tempo que os objetos estiverem no mesmo Set. Veja o "
-"website do Hibernate para uma discussão mais completa sobre o assunto. Note "
-"também que esta não é uma caracteristica do Hibernate, mas simplesmente como "
-"a identidade e a igualdade do objeto de Java têm que ser implementadas."
+"literal>, a mudança do hashcode quebrará o contrato do <literal>Set</"
+"literal>. As funções para chaves de negócio não têm que ser tão estável "
+"quanto às chaves primárias da base de dados, você somente tem que garantir a "
+"estabilidade durante o tempo que os objetos estiverem no mesmo <literal>Set</"
+"literal>. Veja o website do Hibernate para uma discussão mais completa sobre "
+"o assunto. Note também que esta não é uma característica do Hibernate, mas "
+"simplesmente a maneira como a identidade e a igualdade do objeto de Java têm "
+"que ser implementadas. "
 
 #. Tag: title
-#: transactions.xml:334
 #, no-c-format
 msgid "Common issues"
 msgstr "Edições comuns"
 
 #. Tag: para
-#: transactions.xml:336
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not use the anti-patterns <emphasis>session-per-user-session</emphasis> "
 "or <emphasis>session-per-application</emphasis> (there are, however, rare "
@@ -627,15 +706,14 @@
 "within the recommended patterns, so ensure that you understand the "
 "implications before making a design decision:"
 msgstr ""
-"Nunca use o anti-patterns <emphasis>session-per-user-session</emphasis> ou "
-"<emphasis>session-per-application</emphasis> (naturalmente, há umas exceções "
-"raras a essa regra). Note que algumas das seguintes edições podem também "
-"aparecer com patterns recomendados, certifique-se que tenha compreendido as "
-"implicações antes de fazer uma decisão de projeto:"
+"Nunca use o anti-patterns <emphasis>sessão-por-usuário-sessão</emphasis> ou "
+"<emphasis>sessão-por-aplicação</emphasis> (naturalmente, existem exceções "
+"raras para essa regra). Note que algumas das seguintes edições podem também "
+"aparecer com modelos recomendados, certifique-se que tenha compreendido as "
+"implicações antes de fazer uma decisão de projeto: "
 
 #. Tag: para
-#: transactions.xml:345
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>Session</literal> is not thread-safe. Things that work "
 "concurrently, like HTTP requests, session beans, or Swing workers, will "
@@ -647,18 +725,16 @@
 "in two concurrently running threads."
 msgstr ""
 "Uma <literal>Session</literal> não é threadsafe. As coisas que são supostas "
-"para trabalhar concorrentemente, como requisições HTTP, session beans, ou "
+"para trabalhar concorrentemente, como requisições HTTP, beans de sessão, ou "
 "Swing, causarão condições de disputa se uma instância <literal>Session</"
 "literal> for compartilhada. Se você mantiver sua <literal>Session</literal> "
 "do Hibernate em seu <literal>HttpSession</literal> (discutido mais tarde), "
-"você deve considerar sincronizar o acesso a sua sessão do HTTP. Caso "
-"contrário, um usuário que clica em reload várias muito rapidamente pode usar "
-"o mesmo <literal>Session</literal> em duas threads executando "
-"concorrentemente."
+"você deverá considerar sincronizar o acesso a sua sessão do HTTP. Caso "
+"contrário, um usuário que clica em recarga rápido demais, pode usar o mesmo "
+"<literal>Session</literal> em duas threads executando simultaneamente. "
 
 #. Tag: para
-#: transactions.xml:356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An exception thrown by Hibernate means you have to rollback your database "
 "transaction and close the <literal>Session</literal> immediately (this is "
@@ -673,15 +749,14 @@
 "Uma exceção lançada pelo Hibernate significa que você tem que dar rollback "
 "na sua transação no banco de dados e fechar a <literal>Session</literal> "
 "imediatamente (discutido mais tarde em maiores detalhes). Se sua "
-"<literal>Session</literal> é limitado pela aplicação, você tem que parar a "
-"aplicação. Dando rollback na transação no banco de dados não põe seus "
-"objetos do negócio em um estado anterior que estavam no início da transação. "
-"Isto significa que o estado da base de dados e os objetos de negócio perdem "
-"a sincronização. Geralmente não é um problema porque as exceções não são "
-"recuperáveis e você tem que iniciar após o rollback de qualquer maneira."
+"<literal>Session</literal> é limitada pela aplicação, você tem que parar a "
+"aplicação. Fazer o rollback na transação no banco de dados não retorna seus "
+"objetos do negócio ao estado que estavam no início da transação. Isto "
+"significa que o estado da base de dados e os objetos de negócio perdem a "
+"sincronização. Geralmente, não é um problema porque as exceções não são "
+"recuperáveis e você tem que iniciar após o rollback de qualquer maneira. "
 
 #. Tag: para
-#: transactions.xml:368
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>Session</literal> caches every object that is in a persistent "
@@ -690,31 +765,29 @@
 "until you get an OutOfMemoryException. One solution is to call <literal>clear"
 "()</literal> and <literal>evict()</literal> to manage the <literal>Session</"
 "literal> cache, but you should consider a Stored Procedure if you need mass "
-"data operations. Some solutions are shown in <xref linkend=\"batch\"/>. "
+"data operations. Some solutions are shown in <xref linkend=\"batch\" />. "
 "Keeping a <literal>Session</literal> open for the duration of a user session "
 "also means a higher probability of stale data."
 msgstr ""
-"O <literal>Session</literal> guarda em cache cada objeto que está no estado "
-"persistente (guardado e checado para estado \"sujo\" pelo Hibernate). Isto "
-"significa que ele cresce infinitamente até que você obtenha uma "
-"OutOfMemoryException, se você o mantiver aberto por muito tempo ou "
-"simplesmente carregar dados demais. Uma solução é chamar <literal>clear()</"
-"literal> e <literal>evict()</literal> para controlar o cache da "
-"<literal>Session</literal>, mas você deve considerar uma Store Procedure se "
-"precisar de operações que envolvam grande volume de dados. Algumas soluções "
-"são mostradas no <xref linkend=\"batch\"/>. Manter uma <literal>Session</"
-"literal> aberta durante uma sessão do usuário significa também uma "
-"probabilidade elevada de se acabar com dados velhos."
+"A <literal>Session</literal> obtém cada objeto que se encontra o estado "
+"persistente (assistido e checado para o estado dirty do Hibernate). Isto "
+"significa o crescimento contínuo até chegar a um OutOfMemoryException, caso "
+"você mantenha isto aberto por um longo período ou simplesmente carregue "
+"muitos dados. Para resolver este problema, chame <literal>clear()</literal> "
+"e <literal>evict()</literal> para gerenciar o cache da <literal>Session</"
+"literal>, mas você ainda deve considerar a possibilidade de um Procedimento "
+"Armazenado, caso precise de operações de dados em massa. Algumas soluções "
+"poderão ser encontradas em <xref linkend=\"batch\"/>. Se você mantiver uma "
+"<literal>Session</literal> aberta durante todo o tempo da sessão do usuário, "
+"terá maior probabilidade de obter dados danificados. "
 
 #. Tag: title
-#: transactions.xml:386
 #, no-c-format
 msgid "Database transaction demarcation"
 msgstr "Demarcação de transações de bancos de dados"
 
 #. Tag: para
-#: transactions.xml:388
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Database, or system, transaction boundaries are always necessary. No "
 "communication with the database can occur outside of a database transaction "
@@ -725,20 +798,19 @@
 "transactions explicitly. Certainly, a single database transaction is going "
 "to perform better than many small transactions, even for reading data."
 msgstr ""
-"Os limites de uma transação de banco de dados (ou sistema) são sempre "
+"Os limites de uma transação de banco de dados, ou sistema, são sempre "
 "necessários. Nenhuma comunicação com o banco de dados pode ocorrer fora de "
 "uma transação de banco de dados (isto parece confundir muitos "
-"desenvolvedores que estão usados modo auto-commit). Sempre use os limites "
-"desobstruídos da transação, até mesmo para operações somente leitura. "
-"Dependendo de seu nível de isolamento e capacidade da base de dados isto "
-"pode não ser requerido, mas não há nenhum aspecto negativo se você demarca "
-"sempre transações explicitamente. Certamente, uma única transação será "
-"melhor executada do que muitas transações pequenas, até mesmo para dados de "
-"leitura."
+"desenvolvedores que estão acostumados ao modo auto-commit). Sempre use os "
+"limites desobstruídos da transação, até mesmo para operações somente "
+"leitura. Dependendo de seu nível de isolamento e capacidade da base de dados "
+"isto pode não ser requerido, mas não há nenhum aspecto negativo se você "
+"sempre demarcar transações explicitamente. Certamente, uma única transação "
+"será melhor executada do que muitas transações pequenas, até mesmo para "
+"dados de leitura. "
 
 #. Tag: para
-#: transactions.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A Hibernate application can run in non-managed (i.e., standalone, simple "
 "Web- or Swing applications) and managed J2EE environments. In a non-managed "
@@ -751,19 +823,17 @@
 "demarcation is then no longer necessary."
 msgstr ""
 "Uma aplicação do Hibernate pode funcionar em ambientes não gerenciados (isto "
-"é aplicações standalone, Web simples ou Swing) e ambientes gerenciados J2EE. "
-"Em um ambiente não gerenciado, o Hibernate é geralmente responsável pelo seu "
-"próprio pool de conexões. O desenvolvedor tem que manualmente ajustar "
-"limites das transaçãos, ou seja, começar, commitar, ou dar rollback nas "
-"transações ele mesmo. Um ambiente gerenciado fornece transações gerenciadas "
-"por contêiner (CMT - container-managed transactions), com um conjunto da "
-"transações definido declarativamente em descritores de deployment de EJB "
-"session beans, por exemplo. A demarcação programática é então já não é "
-"necessário."
+"é, aplicações standalone, Web simples ou Swing) e ambientes gerenciados "
+"J2EE. Em um ambiente não gerenciado, o Hibernate é geralmente responsável "
+"pelo seu próprio pool de conexões. O desenvolvedor, precisa ajustar "
+"manualmente os limites das transaçãos, ou seja, começar, submeter ou efetar "
+"rollback nas transações ele mesmo. Um ambiente gerenciado fornece transações "
+"gerenciadas por recipiente (CMT), com um conjunto da transações definido "
+"declarativamente em descritores de implementação de beans de sessão EJB, por "
+"exemplo. A demarcação programática é portanto, não mais necessária."
 
 #. Tag: para
-#: transactions.xml:408
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, it is often desirable to keep your persistence layer portable "
 "between non-managed resource-local environments, and systems that can rely "
@@ -775,66 +845,59 @@
 msgstr ""
 "Entretanto, é freqüentemente desejável manter sua camada de persistência "
 "portável entre ambientes de recurso locais não gerenciados e sistemas que "
-"podem confiar em JTA, mas usar BMT em vez de CMT. Em ambos os casos você "
+"podem confiar em JTA, mas use BMT ao invés de CMT. Em ambos os casos você "
 "usaria demarcação de transação programática. O Hibernate oferece uma API "
 "chamada Transaction que traduz dentro do sistema de transação nativa de seu "
-"ambiente de deployment. Esta API é realmente opcional, mas nós encorajamos "
-"fortemente seu uso a menos que você estiver em um CMT session bean."
+"ambiente de implementação. Esta API é realmente opcional, mas nós "
+"encorajamos fortemente seu uso a menos que você esteja em um bean de sessão "
+"CMT.  "
 
 #. Tag: para
-#: transactions.xml:417
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Ending a <literal>Session</literal> usually involves four distinct phases:"
 msgstr ""
-"Geralmente, finalizar um <literal>Session</literal>envolve quatro fases "
+"Geralmente, finalizar uma <literal>Session</literal> envolve quatro fases "
 "distintas:"
 
 #. Tag: para
-#: transactions.xml:423
 #, no-c-format
 msgid "flush the session"
-msgstr "flush da sessão"
+msgstr "liberar a sessão"
 
 #. Tag: para
-#: transactions.xml:428
 #, no-c-format
 msgid "commit the transaction"
-msgstr "commitar a transação"
+msgstr "submeter a transação"
 
 #. Tag: para
-#: transactions.xml:433
 #, no-c-format
 msgid "close the session"
 msgstr "fechar a sessão"
 
 #. Tag: para
-#: transactions.xml:438
 #, no-c-format
 msgid "handle exceptions"
 msgstr "tratar as exceções"
 
 #. Tag: para
-#: transactions.xml:444
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We discussed Flushing the session earlier, so we will now have a closer look "
 "at transaction demarcation and exception handling in both managed and non-"
 "managed environments."
 msgstr ""
-"A limpeza da sessão já foi bem discutida, agora nós daremos uma olhada na "
+"A liberação da sessão já foi bem discutida, agora nós daremos uma olhada na "
 "demarcação da transação e na manipulação de exceção em ambientes controlados "
-"e não controlados."
+"e não controlados. "
 
 #. Tag: title
-#: transactions.xml:451
 #, no-c-format
 msgid "Non-managed environment"
 msgstr "Ambiente não gerenciado"
 
 #. Tag: para
-#: transactions.xml:453
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If a Hibernate persistence layer runs in a non-managed environment, database "
 "connections are usually handled by simple (i.e., non-DataSource) connection "
@@ -843,36 +906,11 @@
 msgstr ""
 "Se uma camada de persistência do Hibernate roda em um ambiente não "
 "gerenciado, as conexões do banco de dados são geralmente tratadas pelos "
-"pools de conexões simples (isto é, não baseados em DataSource) dos quais o "
-"Hibernate obtém as conexões assim que necessita. A maneira de se manipular "
-"uma sessão/transação é mais ou menos assim:"
+"pools de conexões simples (ex.: não DataSource) dos quais o Hibernate obtém "
+"as conexões assim que necessitar. A maneira de se manipular uma sessão/"
+"transação é mais ou menos assim:"
 
-#. Tag: programlisting
-#: transactions.xml:460
-#, no-c-format
-msgid ""
-"<![CDATA[// Non-managed environment idiom\n"
-"Session sess = factory.openSession();\n"
-"Transaction tx = null;\n"
-"try {\n"
-"    tx = sess.beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    if (tx != null) tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:462
 #, fuzzy, no-c-format
 msgid ""
 "You do not have to <literal>flush()</literal> the <literal>Session</literal> "
@@ -883,47 +921,26 @@
 "literal> is that the JDBC connection will be relinquished by the session. "
 "This Java code is portable and runs in both non-managed and JTA environments."
 msgstr ""
-"Você não pode chamar <literal>flush()</literal> do <literal>Session()</"
-"literal> explicitamente - a chamada ao <literal>commit()</literal> dispara "
-"automaticamente a sincronização para a sessão (dependendo do <xref linkend="
-"\"objectstate-flushing\"> FlushMode</xref>). Uma chamada ao <literal>close()"
-"</literal> marca o fim de uma sessão. A principal implicação do "
-"<literal>close()</literal> é que a conexão JDBC será abandonada pela sessão. "
-"Este código Java é portável e funciona em ambientes não gerenciado e de JTA."
+"Você não pode chamar <literal>flush()</literal> da <literal>Session()</"
+"literal> explicitamente. A chamada ao <literal>commit()</literal> dispara "
+"automaticamente a sincronização para a sessão, dependendo do <xref linkend="
+"\"objectstate-flushing\"/>. Uma chamada ao <literal>close()</literal> marca "
+"o fim de uma sessão. A principal implicação do <literal>close()</literal> é "
+"que a conexão JDBC será abandonada pela sessão. Este código Java é portável "
+"e funciona em ambientes não gerenciados e de JTA. "
 
 #. Tag: para
-#: transactions.xml:471
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As outlined earlier, a much more flexible solution is Hibernate's built-in "
 "\"current session\" context management:"
 msgstr ""
-"Uma solução muito mais flexível é gerência integrada de contexto da \"sessão "
-"atual\" do Hibernate, como descrito anteriormente:"
+"Uma solução muito mais flexível é o gerenciamento de contexto \"sessão atual"
+"\" da construção interna do Hibernate, como descrito anteriormente: "
 
-#. Tag: programlisting
-#: transactions.xml:476
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// Non-managed environment idiom with getCurrentSession()\n"
-"try {\n"
-"    factory.getCurrentSession().beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    factory.getCurrentSession().getTransaction().commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    factory.getCurrentSession().getTransaction().rollback();\n"
-"    throw e; // or display error message\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:478
-#, fuzzy, no-c-format
-msgid ""
 "You will not see these code snippets in a regular application; fatal "
 "(system) exceptions should always be caught at the \"top\". In other words, "
 "the code that executes Hibernate calls in the persistence layer, and the "
@@ -935,17 +952,16 @@
 msgstr ""
 "Você muito provavelmente nunca verá estes fragmentos de código em uma "
 "aplicação regular; as exceções fatais (do sistema) devem sempre ser pegas no "
-"\"alto\". Ou seja, o código que executa chamadas do Hibernate (na camada de "
+"\"topo\". Ou seja, o código que executa chamadas do Hibernate (na camada de "
 "persistência) e o código que trata <literal>RuntimeException</literal> (e "
 "geralmente pode somente limpar acima e na saída) estão em camadas "
 "diferentes. O gerenciamento do contexto atual feito pelo Hibernate pode "
 "significativamente simplificar este projeto, como tudo que você necessita é "
 "do acesso a um <literal>SessionFactory</literal>. A manipulação de exceção é "
-"discutida mais tarde neste capítulo."
+"discutida mais tarde neste capítulo. "
 
 #. Tag: para
-#: transactions.xml:488
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You should select <literal>org.hibernate.transaction.JDBCTransactionFactory</"
 "literal>, which is the default, and for the second example select <literal>"
@@ -953,19 +969,17 @@
 "current_session_context_class</literal>."
 msgstr ""
 "Note que você deve selecionar <literal>org.hibernate.transaction."
-"JDBCTransactionFactory</literal> (que é o padrão) e para o segundo exemplo "
+"JDBCTransactionFactory</literal>, que é o padrão, e para o segundo exemplo "
 "<literal>\"thread\"</literal> como seu <literal>hibernate."
 "current_session_context_class</literal>."
 
 #. Tag: title
-#: transactions.xml:497
 #, no-c-format
 msgid "Using JTA"
 msgstr "Usando JTA"
 
 #. Tag: para
-#: transactions.xml:499
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your persistence layer runs in an application server (for example, behind "
 "EJB session beans), every datasource connection obtained by Hibernate will "
@@ -974,112 +988,49 @@
 "strategies for JTA integration."
 msgstr ""
 "Se sua camada de persistência funcionar em um servidor de aplicação (por "
-"exemplo, dentro dos EJB session beans), cada conexão do datasource obtida "
-"pelo Hibernate automaticamente fará parte da transação global de JTA. Você "
-"pode também instalar uma implementação standalone de JTA e usá-la sem EJB. O "
-"Hibernate oferece duas estratégias para a integração de JTA."
+"exemplo, dentro dos beans de sessão EJB), cada conexão da fonte de dados "
+"obtida pelo Hibernate automaticamente fará parte da transação global de JTA. "
+"Você pode também instalar uma implementação standalone de JTA e usá-la sem "
+"EJB. O Hibernate oferece duas estratégias para a integração de JTA. "
 
 #. Tag: para
-#: transactions.xml:506
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you use bean-managed transactions (BMT), Hibernate will tell the "
 "application server to start and end a BMT transaction if you use the "
 "<literal>Transaction</literal> API. The transaction management code is "
 "identical to the non-managed environment."
 msgstr ""
-"Se você usar bean-managed transactions (BMT - transações gerenciadas por "
-"bean) o Hibernate dirá ao servidor de aplicação para começar e para terminar "
-"uma transação de BMT se você usar a API Transaction. Assim, o código de "
-"gerência de transação é idêntico ao ambiente não gerenciado."
+"Se você usar transações de bean gerenciado (BMT) o Hibernate dirá ao "
+"servidor de aplicação para começar e para terminar uma transação de BMT se "
+"você usar a <literal>Transaction</literal> API. Assim, o código de gerência "
+"de transação é idêntico ao ambiente não gerenciado."
 
-#. Tag: programlisting
-#: transactions.xml:512
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// BMT idiom\n"
-"Session sess = factory.openSession();\n"
-"Transaction tx = null;\n"
-"try {\n"
-"    tx = sess.beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    if (tx != null) tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:514
-#, fuzzy, no-c-format
-msgid ""
 "If you want to use a transaction-bound <literal>Session</literal>, that is, "
 "the <literal>getCurrentSession()</literal> functionality for easy context "
 "propagation, use the JTA <literal>UserTransaction</literal> API directly:"
 msgstr ""
-"Se você quiser usar um <literal>Session</literal> limitada por transação, "
+"Se você quiser usar uma <literal>Session</literal> limitada por transação, "
 "isto é, a funcionalidade do <literal>getCurrentSession()</literal> para a "
 "propagação fácil do contexto, você terá que usar diretamente a API JTA "
-"<literal>UserTransaction</literal>:"
+"<literal>UserTransaction</literal>: "
 
-#. Tag: programlisting
-#: transactions.xml:520
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// BMT idiom with getCurrentSession()\n"
-"try {\n"
-"    UserTransaction tx = (UserTransaction)new InitialContext()\n"
-"                            .lookup(\"java:comp/UserTransaction\");\n"
-"\n"
-"    tx.begin();\n"
-"\n"
-"    // Do some work on Session bound to transaction\n"
-"    factory.getCurrentSession().load(...);\n"
-"    factory.getCurrentSession().persist(...);\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:522
-#, fuzzy, no-c-format
-msgid ""
 "With CMT, transaction demarcation is completed in session bean deployment "
 "descriptors, not programmatically. The code is reduced to:"
 msgstr ""
-"Com CMT, a demarcação da transação é feita em descritores de deployment do "
-"session beans, não programaticamente, conseqüentemente, o código é reduzido "
-"a:"
+"Com CMT, a demarcação da transação é feita em descritores de implementação "
+"de beans de sessão, não programaticamente, conseqüentemente, o código é "
+"reduzido a: "
 
-#. Tag: programlisting
-#: transactions.xml:527
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// CMT idiom\n"
-" Session sess = factory.getCurrentSession();\n"
-"\n"
-" // do some work\n"
-" ...\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:529
-#, fuzzy, no-c-format
-msgid ""
 "In a CMT/EJB, even rollback happens automatically. An unhandled "
 "<literal>RuntimeException</literal> thrown by a session bean method tells "
 "the container to set the global transaction to rollback. <emphasis>You do "
@@ -1087,17 +1038,16 @@
 "BMT or CMT, and you get automatic propagation of the \"current\" Session "
 "bound to the transaction.</emphasis>"
 msgstr ""
-"Em um CMT/EJB mesmo um rollback acontece automaticamente, desde que uma "
-"exeção <literal>RuntimeException</literal> não tratável seja lançada por um "
-"método de um session bean que informa ao contêiner ajustar a transação "
-"global ao rollback. <emphasis>Isto significa que você não necessita usar a "
-"API <literal>Transaction</literal> do Hibernate em tudo com BMT ou CMT e "
-"você obtém a propagação automática do Session \"atual\" limitada à transação."
-"</emphasis>"
+"Em um CMT/EJB, até mesmo um rollback acontece automaticamente, desde que uma "
+"exceção <literal>RuntimeException</literal> não tratável seja lançada por um "
+"método de um bean de sessão que informa ao recipiente ajustar a transação "
+"global ao rollback. <emphasis>Isto significa que você não precisa mesmo usar "
+"a API <literal>Transaction</literal> do Hibernate com BMT ou CMT e você "
+"obterá a propagação automática da Sessão \"atual\" limitada à transação.</"
+"emphasis> "
 
 #. Tag: para
-#: transactions.xml:537
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When configuring Hibernate's transaction factory, choose <literal>org."
 "hibernate.transaction.JTATransactionFactory</literal> if you use JTA "
@@ -1109,17 +1059,16 @@
 msgstr ""
 "Veja que você deverá escolher <literal>org.hibernate.transaction."
 "JTATransactionFactory</literal> se você usar o JTA diretamente (BMT) e "
-"<literal>org.hibernate.transaction.CMTTransactionFactory</literal> em um CMT "
-"session bean, quando você configura a fábrica de transação do Hibernate. "
-"Lembre-se também de configurar o <literal>hibernate.transaction."
+"<literal>org.hibernate.transaction.CMTTransactionFactory</literal> em um "
+"bean de sessão CMT, quando você configura a fábrica de transação do "
+"Hibernate. Lembre-se também de configurar o <literal>hibernate.transaction."
 "manager_lookup_class</literal>. Além disso, certifique-se que seu "
 "<literal>hibernate.current_session_context_class</literal> ou não é "
-"configurado (compatibilidade com o legado) ou é definido para <literal>\"jta"
-"\"</literal>."
+"configurado (compatibilidade com o legado) ou está definido para <literal>"
+"\"jta\"</literal>. "
 
 #. Tag: para
-#: transactions.xml:546
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>getCurrentSession()</literal> operation has one downside in a "
 "JTA environment. There is one caveat to the use of <literal>after_statement</"
@@ -1144,19 +1093,17 @@
 "Você <emphasis>deve</emphasis> liberar o cursor subjacente da base de dados "
 "chamando <literal>ScrollableResults.close()</literal> ou <literal>Hibernate."
 "close(Iterator)</literal> explicitamente de um bloco <literal>finally</"
-"literal>. (Claro que a maioria de aplicações podem facilmente evitar o uso "
+"literal>. Claro que a maioria das aplicações podem facilmente evitar o uso "
 "do <literal>scroll()</literal> ou do <literal>iterate()</literal> em todo "
-"código provindo do JTA ou do CMT.)"
+"código provindo do JTA ou do CMT."
 
 #. Tag: title
-#: transactions.xml:562
 #, no-c-format
 msgid "Exception handling"
 msgstr "Tratamento de Exceção"
 
 #. Tag: para
-#: transactions.xml:564
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the <literal>Session</literal> throws an exception, including any "
 "<literal>SQLException</literal>, immediately rollback the database "
@@ -1167,18 +1114,17 @@
 "Ensure that the <literal>Session</literal> will be closed by calling "
 "<literal>close()</literal> in a <literal>finally</literal> block."
 msgstr ""
-"Se a <literal>Session</literal> levantar uma exceção (incluindo qualquer "
-"<literal>SQLException</literal>), você deve imediatamente dar um rollback na "
-"transação do banco, chamando <literal>Session.close()</literal> e "
+"Se a <literal>Session</literal> levantar uma exceção, incluindo qualquer "
+"<literal>SQLException</literal>, você deverá imediatamente dar um rollback "
+"na transação do banco, chamando <literal>Session.close()</literal> e "
 "descartando a instância da <literal>Session</literal>. Certos métodos da "
 "<literal>Session</literal><literal>não</literal> deixarão a sessão em um "
 "estado inconsistente. Nenhuma exceção lançada pelo Hibernate pode ser "
 "recuperada. Certifique-se que a <literal>Session</literal> será fechada "
-"chamando <literal>close()</literal> no bloco <literal>finally</literal>."
+"chamando <literal>close()</literal> no bloco <literal>finally</literal>. "
 
 #. Tag: para
-#: transactions.xml:575
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>HibernateException</literal>, which wraps most of the errors "
 "that can occur in a Hibernate persistence layer, is an unchecked exception. "
@@ -1193,19 +1139,18 @@
 msgstr ""
 "A exceção <literal>HibernateException</literal>, a qual envolve a maioria "
 "dos erros que podem ocorrer em uma camada de persistência do Hibernate, é "
-"uma exceção unchecked ( não estava em umas versões mais antigas de "
-"Hibernate). Em nossa opinião, nós não devemos forçar o desenvolvedor a "
-"tratar uma exceção irrecuperável em uma camada mais baixa. Na maioria dos "
-"sistemas, as exceções unchecked e fatais são tratadas em um dos primeiros "
-"frames da pilha da chamada do método (isto é, em umas camadas mais elevadas) "
-"e uma mensagem de erro é apresentada ao usuário da aplicação (ou a alguma "
-"outra ação apropriada é feita). Note que Hibernate pode também lançar outras "
-"exceções unchecked que não são um <literal>HibernateException</literal>. "
-"Estas, também são, irrecuperáveis e uma ação apropriada deve ser tomada."
+"uma exceção não verificada. Ela não constava em versões mais antigas de "
+"Hibernate. Em nossa opinião, nós não devemos forçar o desenvolvedor a tratar "
+"uma exceção irrecuperável em uma camada mais baixa. Na maioria dos sistemas, "
+"as exceções não verificadas e fatais são tratadas em um dos primeiros frames "
+"da pilha da chamada do método (isto é, em umas camadas mais elevadas) e uma "
+"mensagem de erro é apresentada ao usuário da aplicação (ou alguma outra ação "
+"apropriada é feita). Note que Hibernate pode também lançar outras exceções "
+"não verificadas que não sejam um <literal>HibernateException</literal>. "
+"Estas, também são, irrecuperáveis e uma ação apropriada deve ser tomada. "
 
 #. Tag: para
-#: transactions.xml:587
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate wraps <literal>SQLException</literal>s thrown while interacting "
 "with the database in a <literal>JDBCException</literal>. In fact, Hibernate "
@@ -1224,77 +1169,71 @@
 msgstr ""
 "O Hibernate envolve <literal>SQLException</literal>s lançadas ao interagir "
 "com a base de dados em um <literal>JDBCException</literal>. Na realidade, o "
-"Hibernate tentará converter a exceção em em uma sub classe mais "
-"significativa da <literal>JDBCException</literal>. A <literal>SQLException</"
-"literal> subjacente está sempre disponível através de <literal>JDBCException."
-"getCause()</literal>. O Hibernate converte a <literal>SQLException</literal> "
-"em uma sub classe <literal>JDBCException</literal> apropriada usando "
-"<literal>SQLExceptionConverter</literal> associado ao SessionFactory. Por "
-"padrão, o <literal>SQLExceptionConverter</literal> é definido pelo dialeto "
-"configurado; entretanto, é também possível conectar em uma implementação "
-"customizada (veja o javadoc para mais detalhes da classe "
-"<literal>SQLExceptionConverterFactory</literal>). Os subtipos padrão de "
-"<literal>JDBCException</literal> são:"
+"Hibernate tentará converter a exceção em uma subclasse mais significativa da "
+"<literal>JDBCException</literal>. A <literal>SQLException</literal> "
+"subjacente está sempre disponível através de <literal>JDBCException.getCause"
+"()</literal>. O Hibernate converte a <literal>SQLException</literal> em uma "
+"subclasse <literal>JDBCException</literal> apropriada usando "
+"<literal>SQLExceptionConverter</literal> associado ao "
+"<literal>SessionFactory</literal>. Por padrão, o "
+"<literal>SQLExceptionConverter</literal> é definido pelo dialeto "
+"configurado. Entretanto, é também possível conectar em uma implementação "
+"customizada. Veja o javadoc para mais detalhes da classe "
+"<literal>SQLExceptionConverterFactory</literal>. Os subtipos padrão de "
+"<literal>JDBCException</literal> são: "
 
 #. Tag: para
-#: transactions.xml:603
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>JDBCConnectionException</literal>: indicates an error with the "
 "underlying JDBC communication."
 msgstr ""
-"<literal>JDBCConnectionException</literal> - indica um erro com a "
-"comunicação subjacente de JDBC."
+"<literal>JDBCConnectionException</literal>: indica um erro com a comunicação "
+"subjacente de JDBC."
 
 #. Tag: para
-#: transactions.xml:609
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>SQLGrammarException</literal>: indicates a grammar or syntax "
 "problem with the issued SQL."
 msgstr ""
-"<literal>SQLGrammarException</literal> - indica um problema da gramática ou "
-"da sintaxe com o SQL emitido."
+"<literal>SQLGrammarException</literal>: indica um problema da gramática ou "
+"da sintáxe com o SQL emitido."
 
 #. Tag: para
-#: transactions.xml:615
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ConstraintViolationException</literal>: indicates some form of "
 "integrity constraint violation."
 msgstr ""
-"<literal>ConstraintViolationException</literal> - indica algum forma de "
+"<literal>ConstraintViolationException</literal>: indica algum forma de "
 "violação de confinamento de integridade."
 
 #. Tag: para
-#: transactions.xml:621
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockAcquisitionException</literal>: indicates an error acquiring a "
 "lock level necessary to perform the requested operation."
 msgstr ""
-"<literal>LockAcquisitionException</literal> - indica um erro ao adquirir um "
+"<literal>LockAcquisitionException</literal>: indica um erro ao adquirir um "
 "nível de bloqueio necessário para realizar a operação de requisição."
 
 #. Tag: para
-#: transactions.xml:627
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>GenericJDBCException</literal>: a generic exception which did not "
 "fall into any of the other categories."
 msgstr ""
-"<literal>GenericJDBCException</literal> - uma exceção genérica que não cai "
-"em algumas das outras categorias."
+"<literal>GenericJDBCException</literal>: uma exceção genérica que não está "
+"inclusa em nenhuma das outras categorias."
 
 #. Tag: title
-#: transactions.xml:637
 #, no-c-format
 msgid "Transaction timeout"
-msgstr "Timeout de Transação"
+msgstr "Tempo de espera de Transação"
 
 #. Tag: para
-#: transactions.xml:639
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An important feature provided by a managed environment like EJB, that is "
 "never provided for non-managed code, is transaction timeout. Transaction "
@@ -1307,62 +1246,35 @@
 "transaction timeout to JTA. This functionality is abstracted by the "
 "Hibernate <literal>Transaction</literal> object."
 msgstr ""
-"Uma característica extremamente importante fornecida por um ambiente "
-"gerenciado como EJB e que nunca é fornecido pelo código não gerenciado é o "
-"timeout de transação. Timeouts de transação asseguram que nenhuma transação "
-"possa reter indefinidamente recursos enquanto não retorna nenhuma resposta "
-"ao usuário. Fora de um ambiente controlado (JTA), o Hibernate não pode "
-"fornecer inteiramente esta funcionalidade. Entretanto, o Hibernate pode "
-"afinal controlar as operações do acesso a dados, assegurando que o nível de "
-"deadlocks e queries do banco de dados com imensos resultados definidos sejam "
-"limitados pelo timeout. Em um ambiente gerenciado, o Hibernate pode delegar "
-"o timeout da transação ao JTA. Esta funcionalidade é abstraída pelo objeto "
-"<literal>Transaction</literal> do Hibernate."
+"O tempo de espera de transação é uma característica extremamente importante "
+"fornecida por um ambiente gerenciado como EJB e que nunca é fornecido pelo "
+"código não gerenciado. Os tempos de espera de transação asseguram que "
+"nenhuma transação retenha indefinidamente recursos enquanto não retornar "
+"nenhuma resposta ao usuário. Fora de um ambiente controlado (JTA), o "
+"Hibernate não pode fornecer inteiramente esta funcionalidade. Entretanto, o "
+"Hibernate pode afinal controlar as operações do acesso a dados, assegurando "
+"que o nível de deadlocks e consultas do banco de dados com imensos "
+"resultados definidos sejam limitados pelo tempo de espera. Em um ambiente "
+"gerenciado, o Hibernate pode delegar o tempo de espera da transação ao JTA. "
+"Esta funcionalidade é abstraída pelo objeto <literal>Transaction</literal> "
+"do Hibernate. "
 
-#. Tag: programlisting
-#: transactions.xml:652
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"Session sess = factory.openSession();\n"
-"try {\n"
-"    //set transaction timeout to 3 seconds\n"
-"    sess.getTransaction().setTimeout(3);\n"
-"    sess.getTransaction().begin();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    sess.getTransaction().commit()\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    sess.getTransaction().rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:654
-#, fuzzy, no-c-format
-msgid ""
 "<literal>setTimeout()</literal> cannot be called in a CMT bean, where "
 "transaction timeouts must be defined declaratively."
 msgstr ""
-"Veja que <literal>setTimeout()</literal> não pode ser chamado em um CMT "
-"bean, onde os timeouts das transações devem ser definidos declarativamente."
+"Veja que <literal>setTimeout()</literal> não pode ser chamado em um bean "
+"CMT, onde o tempo de espera das transações deve ser definido declaradamente. "
 
 #. Tag: title
-#: transactions.xml:664
 #, no-c-format
 msgid "Optimistic concurrency control"
 msgstr "Controle de concorrência otimista"
 
 #. Tag: para
-#: transactions.xml:666
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The only approach that is consistent with high concurrency and high "
 "scalability, is optimistic concurrency control with versioning. Version "
@@ -1373,23 +1285,21 @@
 "has the benefit of preventing lost updates in single database transactions."
 msgstr ""
 "O único caminho que é consistente com a elevada concorrência e "
-"escalabilidade é controle de concorrência otimista com versionamento. "
-"Checagem de versão usa número de versão, ou timestamps, para detectar "
-"conflitos de atualizações (e para impedir atualizações perdidas). O "
-"Hibernate fornece três caminhos possíveis para escrever aplicações que usam "
-"concorrência otimista. Os casos de uso que nós mostramos estão no contexto "
-"de conversações longas, mas a checagem de versão também tem o benefício de "
-"impedir atualizações perdidas em únicas transações."
+"escalabilidade é o controle de concorrência otimista com versionamento. A "
+"checagem de versão usa número de versão, ou carimbo de hora (timestamp), "
+"para detectar conflitos de atualizações (e para impedir atualizações "
+"perdidas). O Hibernate fornece três caminhos possíveis para escrever "
+"aplicações que usam concorrência otimista. Os casos de uso que nós mostramos "
+"estão no contexto de conversações longas, mas a checagem de versão também "
+"tem o benefício de impedir atualizações perdidas em únicas transações. "
 
 #. Tag: title
-#: transactions.xml:677
 #, no-c-format
 msgid "Application version checking"
 msgstr "Checagem de versão da aplicação"
 
 #. Tag: para
-#: transactions.xml:679
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In an implementation without much help from Hibernate, each interaction with "
 "the database occurs in a new <literal>Session</literal> and the developer is "
@@ -1401,32 +1311,13 @@
 msgstr ""
 "Em uma implementação sem muita ajuda do Hibernate, cada interação com o "
 "banco de dados ocorre em uma nova <literal>Session</literal> e o "
-"desenvolvedor é responsável para recarregar todas as instâncias persistentes "
+"desenvolvedor é responsável por recarregar todas as instâncias persistentes "
 "da base de dados antes de manipulá-las. Este caminho força a aplicação a "
 "realizar sua própria checagem de versão para assegurar a conversação do "
 "isolamento da transação. Este caminho é menos eficiente em termos de acesso "
-"ao banco de dados. É a caminho mais similar a EJBs entity."
+"ao banco de dados. É o caminho mais similar à entidade EJBs."
 
-#. Tag: programlisting
-#: transactions.xml:688
-#, no-c-format
-msgid ""
-"<![CDATA[// foo is an instance loaded by a previous Session\n"
-"session = factory.openSession();\n"
-"Transaction t = session.beginTransaction();\n"
-"\n"
-"int oldVersion = foo.getVersion();\n"
-"session.load( foo, foo.getKey() ); // load the current state\n"
-"if ( oldVersion != foo.getVersion() ) throw new StaleObjectStateException"
-"();\n"
-"foo.setProperty(\"bar\");\n"
-"\n"
-"t.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:690
 #, no-c-format
 msgid ""
 "The <literal>version</literal> property is mapped using <literal>&lt;"
@@ -1434,12 +1325,11 @@
 "flush if the entity is dirty."
 msgstr ""
 "A propriedade <literal>version</literal> é mapeada usando <literal>&lt;"
-"version&gt;</literal>, e o Hibernate vai incrementá-lo-á automaticamente "
-"durante o flush se a entidade estiver alterada."
+"version&gt;</literal>, e o Hibernate vai incrementá-lá automaticamente "
+"durante a liberação se a entidade estiver alterada."
 
 #. Tag: para
-#: transactions.xml:696
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are operating in a low-data-concurrency environment, and do not "
 "require version checking, you can use this approach and skip the version "
@@ -1448,17 +1338,16 @@
 "of the application, as they might experience lost updates without error "
 "messages or a chance to merge conflicting changes."
 msgstr ""
-"Claro, se você se estiver operando em um ambiente de baixa concorrência de "
-"dados e não requerer a checagem de versão, você pode usar este caminho e "
-"apenas saltar a checagem de versão. Nesse caso, o <emphasis>ultimo commit "
-"realizdo </emphasis> é a estratégia padrão para suas conversações longas. "
-"Mantenha em mente que isto pode confundir os usuários da aplicação, assim "
-"como eles podem experimentar atualizações perdidas sem mensagens de erro ou "
-"uma possibilidade ajustar mudanças de conflito."
+"Claro, se você estiver operando em um ambiente de baixa concorrência de "
+"dados e não precisar da checagem de versão, você pode usar este caminho e "
+"apenas pular a checagem de versão. Nesse caso, o <emphasis>último commit "
+"realizado</emphasis> é a estratégia padrão para suas conversações longas. "
+"Tenha em mente que isto pode confundir os usuários da aplicação, como também "
+"poderão ter atualizações perdidas sem mensagens de erro ou uma possibilidade "
+"de ajustar mudanças conflitantes."
 
 #. Tag: para
-#: transactions.xml:705
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Manual version checking is only feasible in trivial circumstances and not "
 "practical for most applications. Often not only single instances, but "
@@ -1466,22 +1355,20 @@
 "automatic version checking with either an extended <literal>Session</"
 "literal> or detached instances as the design paradigm."
 msgstr ""
-"Claro que, checagem manual da versão é somente praticável em circunstâncias "
-"triviais e não para a maioria de aplicações. Freqüentemente, os grafos "
-"completos de objetos modificados têm que ser verificados, não somente únicas "
-"instâncias. O Hibernate oferece checagem de versão automática com uma "
-"<literal>Session</literal> estendida ou instâncias desatachadas como o "
-"paradigma do projeto."
+"Claro que, a checagem manual da versão é somente possível em circunstâncias "
+"triviais e não para a maioria de aplicações. Freqüentemente, os "
+"gráficoscompletos de objetos modificados têm que ser verificados, não "
+"somente únicas instâncias. O Hibernate oferece checagem de versão automática "
+"com uma <literal>Session</literal> estendida ou instâncias desatachadas como "
+"o paradigma do projeto. "
 
 #. Tag: title
-#: transactions.xml:716
 #, no-c-format
 msgid "Extended session and automatic versioning"
 msgstr "Sessão estendida e versionamento automático"
 
 #. Tag: para
-#: transactions.xml:718
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A single <literal>Session</literal> instance and its persistent instances "
 "that are used for the whole conversation are known as <emphasis>session-per-"
@@ -1493,15 +1380,14 @@
 msgstr ""
 "Uma única instância de <literal>Session</literal> e suas instâncias "
 "persistentes são usadas para a conversação inteira, isto é conhecido como "
-"<emphasis>session-per-conversation</emphasis>. O Hibernate verifica versões "
-"da instância no momento dio flush, lançando uma exceção se a modificação "
-"concorrente for detectada. Até o desenvolvedor pegar e tratar essa exceção "
-"(as opções comuns são a oportunidade para que o usuário intercale as "
-"mudanças ou reinicie a conversação do negócio com dados não antigos)."
+"<emphasis>sessão-por-conversação</emphasis>. O Hibernate verifica versões da "
+"instância no momento da liberação, lançando uma exceção se a modificação "
+"concorrente for detectada. Até o desenvolvedor pegar e tratar essa exceção. "
+"As opções comuns são a oportunidade para que o usuário intercale as mudanças "
+"ou reinicie a conversação do negócio com dados não antigos."
 
 #. Tag: para
-#: transactions.xml:727
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>Session</literal> is disconnected from any underlying JDBC "
 "connection when waiting for user interaction. This approach is the most "
@@ -1509,36 +1395,15 @@
 "check or reattach detached instances, nor does it have to reload instances "
 "in every database transaction."
 msgstr ""
-"The <literal>Session</literal> is disconnected from any underlying JDBC "
-"connection when waiting for user interaction. This approach is the most "
-"efficient in terms of database access. The application need not concern "
-"itself with version checking or with reattaching detached instances, nor "
-"does it have to reload instances in every database transaction. A "
-"<literal>Session</literal> é desconectada de toda a conexão JDBC subjacente "
-"enquanto espera a interação do usuário. Este caminho é a mais eficiente em "
-"termos de acesso a bancos de dados. A aplicação não necessita concernir-se "
-"com a checagem de versão ou com as instâncias destacadas reatadas, nem tem "
-"que recarregar instâncias em cada transação."
+"A <literal>Session</literal> é desconectada de toda a conexão JDBC adjacente "
+"enquanto espera a interação do usuário. Este caminho é o mais eficiente em "
+"termos de acesso a bancos de dados. A aplicação não precisa se preocupar com "
+"a checagem de versão ou com as instâncias destacadas reatadas, nem precisa "
+"recarregar instâncias a cada transação."
 
-#. Tag: programlisting
-#: transactions.xml:735
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// foo is an instance loaded earlier by the old session\n"
-"Transaction t = session.beginTransaction(); // Obtain a new JDBC connection, "
-"start transaction\n"
-"\n"
-"foo.setProperty(\"bar\");\n"
-"\n"
-"session.flush();    // Only for last transaction in conversation\n"
-"t.commit();         // Also return JDBC connection\n"
-"session.close();    // Only for last transaction in conversation]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:736
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>foo</literal> object knows which <literal>Session</literal> it "
 "was loaded in. Beginning a new database transaction on an old session "
 "obtains a new connection and resumes the session. Committing a database "
@@ -1554,24 +1419,24 @@
 "will include the <literal>flush()</literal> operation, and then "
 "<literal>close()</literal> the session to end the conversation."
 msgstr ""
-"O objeto <literal>foo</literal> sabe que <literal>Session</literal> já foi "
-"carregada. Começando uma nova transação em uma sessão velha obtém uma "
-"conexão nova e recomeça a sessão. Commitando uma transação desconecta uma "
-"sessão da conexão JDBC e retorna a conexão ao pool. Após a reconexão, forçar "
-"uma checagem de versão em dados que você não está atualizando, você pode "
-"chamar <literal>Session.lock()</literal> com o <literal>LockMode.READ</"
-"literal> em todos os objetos que possam ter sido atualizados por uma outra "
-"transação. Você não necessita bloquear nenhum dado para atualizar. "
-"Geralmente você configuraria <literal>FlushMode.MANUAL</literal> em uma "
-"<literal>Session</literal> estendida, de modo que somente o último ciclo da "
-"transação tenha permissão de persistir todas as modificações feitas nesta "
-"conversação. Disso, somente esta última transação incluiria a operação "
-"<literal>flush()</literal> e então chamar também <literal>close()</literal> "
-"da sessão para terminar a conversação."
+"O objeto <literal>foo</literal> sabe que a <literal>Session</literal> já foi "
+"carregada. Ao começar uma nova transação ou uma sessão velha, você obterá "
+"uma conexão nova e reiniciará a sessão. Submeter uma transação implica em "
+"desconectar uma sessão da conexão JDBC e retornar à conexão ao pool. Após a "
+"reconexão, para forçar uma checagem de versão em dados que você não esteja "
+"atualizando, você poderá chamar <literal>Session.lock()</literal> com o "
+"<literal>LockMode.READ</literal> em todos os objetos que possam ter sido "
+"atualizados por uma outra transação. Você não precisa bloquear nenhum dado "
+"que você <emphasis>está</emphasis> atualizando. Geralmente, você "
+"configuraria <literal>FlushMode.NEVER</literal> em uma <literal>Session</"
+"literal> estendida, de modo que somente o último ciclo da transação tenha "
+"permissão de persistir todas as modificações feitas nesta conversação. Por "
+"isso, somente esta última transação incluiria a operação <literal>flush()</"
+"literal> e então também iria <literal>close()</literal> a sessão para "
+"terminar a conversação. "
 
 #. Tag: para
-#: transactions.xml:751
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This pattern is problematic if the <literal>Session</literal> is too big to "
 "be stored during user think time (for example, an <literal>HttpSession</"
@@ -1581,36 +1446,33 @@
 "<literal>Session</literal> only for a single conversation as it will soon "
 "have stale data."
 msgstr ""
-"Este pattern é problemático se a <literal>Session</literal> for "
-"demasiadamente grande para ser armazenado durante o tempo que usuário "
-"pensar, por exemplo um <literal>HttpSession</literal> estiver mantido tão "
-"pequeno quanto possível. Como o <literal>Session</literal> é também cache de "
+"Este modelo é problemático se a <literal>Session</literal> for "
+"demasiadamente grande para ser armazenada durante o tempo de espera do "
+"usuário (por exemplo uma <literal>HttpSession</literal> deve ser mantida o "
+"menor possível). Como a <literal>Session</literal> é também cache de "
 "primeiro nível (imperativo) e contém todos os objetos carregados, nós "
 "podemos provavelmente usar esta estratégia somente para alguns ciclos de "
 "requisição/resposta. Você deve usar a <literal>Session</literal> somente "
-"para uma única conversação, porque ela logo também estará com dados velhos."
+"para uma única conversação, porque ela logo também estará com dados velhos. "
 
 #. Tag: title
-#: transactions.xml:762
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "Nota"
 
 #. Tag: para
-#: transactions.xml:763
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Earlier versions of Hibernate required explicit disconnection and "
 "reconnection of a <literal>Session</literal>. These methods are deprecated, "
 "as beginning and ending a transaction has the same effect."
 msgstr ""
-"(Note que versões mais atuais de Hibernate requerem a desconexão e o "
-"reconexão explícitas de uma <literal>Session</literal>. Estes métodos são "
-"desatualizados, como o início e término de uma transação tem o mesmo efeito.)"
+"Note que versões mais atuais de Hibernate requerem a desconexão e reconexão "
+"explícitas de uma <literal>Session</literal>. Estes métodos são "
+"desatualizados, pois o início e término de uma transação têm o mesmo efeito."
 
 #. Tag: para
-#: transactions.xml:769
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Keep the disconnected <literal>Session</literal> close to the persistence "
 "layer. Use an EJB stateful session bean to hold the <literal>Session</"
@@ -1618,15 +1480,14 @@
 "or even serialize it to a separate tier, to store it in the "
 "<literal>HttpSession</literal>."
 msgstr ""
-"Note também que você deve manter a <literal>Session</literal> desconectada "
-"fechada para a camada de persistência. Ou seja, use um EJB stateful session "
-"bean para prender a <literal>Session</literal> em um ambiente do três "
-"camadas e não o transferir à camada web (ou até serializá-lo para uma camada "
-"separada) para armazená-lo no <literal>HttpSession</literal>."
+"Note também que você deve manter a <literal>Session</literal> desconectada, "
+"fechada para a camada de persistência. Ou seja, use um bean de sessão com "
+"estado EJB para prender a <literal>Session</literal> em um ambiente de três "
+"camadas. Não transfira à camada web, ou até serializá-lo para uma camada "
+"separada, para armazená-lo no <literal>HttpSession</literal>."
 
 #. Tag: para
-#: transactions.xml:777
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The extended session pattern, or <emphasis>session-per-conversation</"
 "emphasis>, is more difficult to implement with automatic current session "
@@ -1634,20 +1495,18 @@
 "<literal>CurrentSessionContext</literal> for this. See the Hibernate Wiki "
 "for examples."
 msgstr ""
-"O pattern sessão estendida, ou <emphasis>session-per-conversation</"
+"O modelo da sessão estendida, ou <emphasis>sessão-por-conversação</"
 "emphasis>, é mais difícil de implementar com gerenciamento automático de "
 "sessão atual. Você precisa fornecer sua própria implementação do "
-"<literal>CurrentSessionContext</literal> para isto (veja o Hibernate Wiki "
-"para exemplos)."
+"<literal>CurrentSessionContext</literal> para isto. Veja o Hibernate Wiki "
+"para exemplos."
 
 #. Tag: title
-#: transactions.xml:787
 #, no-c-format
 msgid "Detached objects and automatic versioning"
 msgstr "Objetos destacados e versionamento automático"
 
 #. Tag: para
-#: transactions.xml:789
 #, no-c-format
 msgid ""
 "Each interaction with the persistent store occurs in a new <literal>Session</"
@@ -1662,37 +1521,21 @@
 "<literal>Session</literal> nova. Entretanto, as mesmas instâncias "
 "persistentes são reusadas para cada interação com o banco de dados. A "
 "aplicação manipula o estado das instâncias desatachadas originalmente "
-"carregadas em um outro <literal>Session</literal> e reata-os então usando "
+"carregadas em uma outra <literal>Session</literal> e as reata então usando "
 "<literal>Session.update()</literal>, <literal>Session.saveOrUpdate()</"
 "literal> ou <literal>Session.merge()</literal>."
 
-#. Tag: programlisting
-#: transactions.xml:797
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// foo is an instance loaded by a previous Session\n"
-"foo.setProperty(\"bar\");\n"
-"session = factory.openSession();\n"
-"Transaction t = session.beginTransaction();\n"
-"session.saveOrUpdate(foo); // Use merge() if \"foo\" might have been loaded "
-"already\n"
-"t.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:799
-#, fuzzy, no-c-format
-msgid ""
 "Again, Hibernate will check instance versions during flush, throwing an "
 "exception if conflicting updates occurred."
 msgstr ""
-"Outra vez, o Hibernate verificará versões da instância durante o flush, "
-"lançando uma exceção se ocorrer conflitos de atualizações."
+"Outra vez, o Hibernate verificará versões da instância durante a liberação, "
+"lançando uma exceção se ocorrer conflitos de atualizações. "
 
 #. Tag: para
-#: transactions.xml:804
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also call <literal>lock()</literal> instead of <literal>update()</"
 "literal>, and use <literal>LockMode.READ</literal> (performing a version "
@@ -1702,17 +1545,15 @@
 "Você pode também chamar o <literal>lock()</literal> em vez de <literal>update"
 "()</literal> e usar <literal>LockMode.READ</literal> (executando uma "
 "checagem de versão, ignorando todos os caches) se você estiver certo de que "
-"o objeto não foi modificado."
+"o objeto não foi modificado. "
 
 #. Tag: title
-#: transactions.xml:813
 #, no-c-format
 msgid "Customizing automatic versioning"
 msgstr "Versionamento automático customizado"
 
 #. Tag: para
-#: transactions.xml:815
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can disable Hibernate's automatic version increment for particular "
 "properties and collections by setting the <literal>optimistic-lock</literal> "
@@ -1720,13 +1561,13 @@
 "increment versions if the property is dirty."
 msgstr ""
 "Você pode desabilitar o incremento da versão automática de Hibernate para "
-"propriedades e coleções particulares configurando o mapeamento do atributo "
-"<literal>optimistic-lock</literal> para false. O Hibernate então não irá "
-"incrementa versões se a propriedade estiver modificada."
+"propriedades e coleções particulares, configurando a função de mapeamento "
+"<literal>optimistic-lock</literal> para <literal>false</literal>. O "
+"Hibernate então, não incrementará mais versões se a propriedade estiver "
+"modificada. "
 
 #. Tag: para
-#: transactions.xml:822
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Legacy database schemas are often static and cannot be modified. Or, other "
 "applications might access the same database and will not know how to handle "
@@ -1739,36 +1580,33 @@
 "long <literal>Session</literal> and not session-per-request-with-detached-"
 "objects)."
 msgstr ""
-"Os esquemas da base de dados legada são freqüentemente estáticos e não podem "
-"ser modificados. Ou outras aplicações puderam também acessar a mesma base de "
-"dados e não sabem tratar a versão dos números ou timestamps. Em ambos os "
-"casos, o versionamento não pode confiar em uma coluna particular em uma "
-"tabela. Para forçar uma checagem de versão sem uma versão ou mapeamento da "
-"propriedade do timestamp com uma comparação do estado de todos os campos em "
-"uma linha, configure <literal>optimistic-lock=\"all\"</literal> no "
-"mapeamento <literal>&lt;class&gt;</literal>. Note que isto conceitualmente é "
-"somente feito em trabalhos se Hibernate puder comparar o estado velho e "
-"novo, isto é, se você usa um único <literal>Session</literal> longo e não "
-"session-per-request-with-detached-objects."
+"Os esquemas da base de dados legado são freqüentemente estáticos e não podem "
+"ser modificados. Ou então, outras aplicações puderam também acessar a mesma "
+"base de dados e não sabem tratar a versão dos números ou carimbos de hora. "
+"Em ambos os casos, o versionamento não pode confiar em uma coluna particular "
+"em uma tabela. Para forçar uma checagem de versão sem uma versão ou "
+"mapeamento da propriedade do carimbo de hora com uma comparação do estado de "
+"todos os campos em uma linha, configure <literal>optimistic-lock=\"all\"</"
+"literal> no mapeamento <literal>&lt;class&gt;</literal>. Note que isto "
+"conceitualmente é somente feito em trabalhos se o Hibernate puder comparar o "
+"estado velho e novo (ex.: se você usar uma única <literal>Session</literal> "
+"longa e não uma sessão-por-solicitação-com-objetos-desanexados)."
 
 #. Tag: para
-#: transactions.xml:834
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Concurrent modification can be permitted in instances where the changes that "
 "have been made do not overlap. If you set <literal>optimistic-lock=\"dirty"
 "\"</literal> when mapping the <literal>&lt;class&gt;</literal>, Hibernate "
 "will only compare dirty fields during flush."
 msgstr ""
-"Às vezes a modificação concorrente pode ser permitida tão longa quanto às "
-"mudanças que tiveram sido feitas que não sobrepuseram. Se você configurar "
-"<literal>optimistic-lock=\"dirty\"</literal> ao mapear o <literal>&lt;"
-"class&gt;</literal>, o Hibernate comparará somente campos modificados "
-"durante o flush."
+"Às vezes a modificação concorrente pode ser permitida, desde que as mudanças "
+"realizadas não se sobreponham. Se você configurar <literal>optimistic-lock="
+"\"dirty\"</literal> ao mapear o <literal>&lt;class&gt;</literal>, o "
+"Hibernate comparará somente campos modificados durante a liberação. "
 
 #. Tag: para
-#: transactions.xml:840
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In both cases, with dedicated version/timestamp columns or with a full/dirty "
 "field comparison, Hibernate uses a single <literal>UPDATE</literal> "
@@ -1783,29 +1621,28 @@
 "to <literal>SELECT</literal> the instance to ensure that changes did occur "
 "before updating the row."
 msgstr ""
-"Em ambos os casos, com as colunas dedicadas da versão/timestamp ou com "
-"comparação do campo cheio/modificados, o Hibernate usa uma única declaração "
-"UPDATE (com uma cláusula WHERE apropriada ) por entidade para executar a "
-"checagem da versão e atualizar a informação. Se você usa a persistência "
-"transitiva para cascatear o reatamento das entidades associadas, o Hibernate "
-"pode executar atualizações desnecessárias. Isso não é geralmente um "
-"problema, mas triggers <emphasis>on update</emphasis> em um banco de dados "
-"podem ser executados mesmo quando nenhuma mudança foi feita nas instâncias "
-"destacadas. Você pode customizar este comportamento configurando "
-"<literal>select-before-update=\"true\"</literal> no mapeamento <literal>&lt;"
-"class&gt;</literal>, forçando o Hibernate a dá um SELECT nas instâncias para "
-"assegurar-se esse as mudanças ocorreram realmente, antes de atualizar a "
-"linha."
+"Em ambos os casos, com as colunas de versão/carimbo de hora dedicados com "
+"comparação de campo cheio/sujo, o Hibernate usa uma única instrução "
+"<literal>UPDATE</literal>, com uma cláusula <literal>WHERE</literal> "
+"apropriada, por entidade para executar a checagem da versão e atualizar a "
+"informação. Se você usar a persistência transitiva para cascatear o "
+"reatamento das entidades associadas, o Hibernate pode executar atualizações "
+"desnecessárias. Isso não é geralmente um problema, mas os triggers "
+"<emphasis>em atualizações</emphasis> num banco de dados pode ser executado "
+"mesmo quando nenhuma mudança foi feita nas instâncias desanexadas. Você pode "
+"customizar este comportamento configurando <literal>selecionar-antes-de "
+"atualizar=\"verdadeiro\"</literal> no mapeamento <literal>&lt;class&gt;</"
+"literal>, forçando o Hibernate a fazer um <literal>SELECT</literal> nas "
+"instâncias para assegurar-se de que as mudanças realmente aconteceram, antes "
+"de atualizar a linha. "
 
 #. Tag: title
-#: transactions.xml:858
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Pessimistic locking"
-msgstr "Locking pessimista"
+msgstr "Bloqueio Pessimista "
 
 #. Tag: para
-#: transactions.xml:860
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is not intended that users spend much time worrying about locking "
 "strategies. It is usually enough to specify an isolation level for the JDBC "
@@ -1813,35 +1650,33 @@
 "advanced users may wish to obtain exclusive pessimistic locks or re-obtain "
 "locks at the start of a new transaction."
 msgstr ""
-"Não se pretende que os usuários gastam muitas horas se preocupando com suas "
-"estratégias de locking. Geralmente é o bastante para especificar um nível de "
-"isolamento para as conexões JDBC e então deixar simplesmente o banco de "
+"Não ha intenção alguma que usuários gastem muitas horas se preocupando com "
+"suas estratégias de bloqueio. Geralmente, é o bastante especificar um nível "
+"de isolamento para as conexões JDBC e então deixar simplesmente o banco de "
 "dados fazer todo o trabalho. Entretanto, os usuários avançados podem às "
-"vezes desejar obter locks pessimistas exclusivos, ou re-obter locks no "
-"início de uma nova transação."
+"vezes desejar obter bloqueios pessimistas exclusivos, ou re-obter bloqueios "
+"no início de uma nova transação. "
 
 #. Tag: para
-#: transactions.xml:867
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will always use the locking mechanism of the database; it never "
 "lock objects in memory."
 msgstr ""
-"O Hibernate usará sempre o mecanismo de lock da base de dados, nunca trava "
-"objetos na memória!"
+"O Hibernate usará sempre o mecanismo de bloqueio da base de dados, nunca "
+"bloquiar objetos na memória."
 
 #. Tag: para
-#: transactions.xml:872
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>LockMode</literal> class defines the different lock levels that "
 "can be acquired by Hibernate. A lock is obtained by the following mechanisms:"
 msgstr ""
-"A classe <literal>LockMode</literal> define os diferentes níveis de lock que "
-"o Hibernate pode adquirir. Um lock é obtido pelos seguintes mecanismos:"
+"A classe <literal>LockMode</literal> define os diferentes níveis de bloqueio "
+"que o Hibernate pode adquirir. Um bloqueio é obtido pelos seguintes "
+"mecanismos: "
 
 #. Tag: para
-#: transactions.xml:879
 #, no-c-format
 msgid ""
 "<literal>LockMode.WRITE</literal> is acquired automatically when Hibernate "
@@ -1851,8 +1686,7 @@
 "Hibernate atualiza ou insere uma linha."
 
 #. Tag: para
-#: transactions.xml:885
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockMode.UPGRADE</literal> can be acquired upon explicit user "
 "request using <literal>SELECT ... FOR UPDATE</literal> on databases which "
@@ -1860,11 +1694,10 @@
 msgstr ""
 "<literal>LockMode.UPGRADE</literal> pode ser adquirido explicitamente pelo "
 "usuário usando <literal>SELECT ... FOR UPDATE</literal> em um banco de dados "
-"que suporte esse sintaxe."
+"que suporte essa sintáxe. "
 
 #. Tag: para
-#: transactions.xml:891
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockMode.UPGRADE_NOWAIT</literal> can be acquired upon explicit "
 "user request using a <literal>SELECT ... FOR UPDATE NOWAIT</literal> under "
@@ -1872,22 +1705,20 @@
 msgstr ""
 "<literal>LockMode.UPGRADE_NOWAIT</literal> pode ser adquirido explicitamente "
 "pelo usuário usando <literal>SELECT ... FOR UPDATE NOWAIT</literal> no "
-"Oracle."
+"Oracle. "
 
 #. Tag: para
-#: transactions.xml:897
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockMode.READ</literal> is acquired automatically when Hibernate "
 "reads data under Repeatable Read or Serializable isolation level. It can be "
 "re-acquired by explicit user request."
 msgstr ""
 "<literal>LockMode.READ</literal> é adquirido automaticamente quando o "
-"Hibernate lê dados em um nível Repeatable Read ou Serializable isolation. "
-"Pode ser readquirido explicitamente pelo usuário."
+"Hibernate lê dados em um nível de Leitura Repetida ou isolamento "
+"Serializável. Pode ser readquirido explicitamente pelo usuário. "
 
 #. Tag: para
-#: transactions.xml:904
 #, no-c-format
 msgid ""
 "<literal>LockMode.NONE</literal> represents the absence of a lock. All "
@@ -1896,23 +1727,20 @@
 "</literal> or <literal>saveOrUpdate()</literal> also start out in this lock "
 "mode."
 msgstr ""
-"<literal>LockMode.NONE</literal> representa a ausência do lock. Todos os "
-"objetos mudam para esse estado de lock no final da <literal>Transaction</"
+"<literal>LockMode.NONE</literal> representa a ausência do bloqueio. Todos os "
+"objetos mudam para esse estado de bloqueio no final da <literal>Transaction</"
 "literal>. Objetos associados com a sessão através do método <literal>update()"
 "</literal> ou <literal>saveOrUpdate()</literal> também são inicializados com "
-"esse lock mode."
+"esse modo de bloqueio."
 
 #. Tag: para
-#: transactions.xml:913
 #, no-c-format
 msgid ""
 "The \"explicit user request\" is expressed in one of the following ways:"
 msgstr ""
-"O lock obtido \"explicitamente pelo usuário\" se dá em uma das seguintes "
-"maneiras:"
+"O bloqueio obtido \"explicitamente pelo usuário\" se dá nas seguintes formas:"
 
 #. Tag: para
-#: transactions.xml:919
 #, no-c-format
 msgid ""
 "A call to <literal>Session.load()</literal>, specifying a <literal>LockMode</"
@@ -1922,19 +1750,16 @@
 "<literal>LockMode</literal>."
 
 #. Tag: para
-#: transactions.xml:924
 #, no-c-format
 msgid "A call to <literal>Session.lock()</literal>."
-msgstr "Uma chamada a <literal>Session.lock()</literal>."
+msgstr "Uma chamada à <literal>Session.lock()</literal>."
 
 #. Tag: para
-#: transactions.xml:929
 #, no-c-format
 msgid "A call to <literal>Query.setLockMode()</literal>."
-msgstr "Uma chamada a <literal>Query.setLockMode()</literal>."
+msgstr "Uma chamada à <literal>Query.setLockMode()</literal>."
 
 #. Tag: para
-#: transactions.xml:935
 #, no-c-format
 msgid ""
 "If <literal>Session.load()</literal> is called with <literal>UPGRADE</"
@@ -1949,13 +1774,12 @@
 "literal> ou <literal>UPGRADE_NOWAIT</literal>, e o objeto requisitado ainda "
 "não foi carregado pela sessão, o objeto é carregado usando "
 "<literal>SELECT ... FOR UPDATE</literal>. Se <literal>load()</literal> for "
-"chamado para um objeto que já foi carregado com um lock menos restritivo que "
-"o novo lock solicitado, o Hibernate invoca o método <literal>lock()</"
+"chamado para um objeto que já foi carregado com um bloqueio menos restritivo "
+"que o novo bloqueio solicitado, o Hibernate invoca o método <literal>lock()</"
 "literal> para aquele objeto."
 
 #. Tag: para
-#: transactions.xml:944
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Session.lock()</literal> performs a version number check if the "
 "specified lock mode is <literal>READ</literal>, <literal>UPGRADE</literal> "
@@ -1963,33 +1787,30 @@
 "literal> or <literal>UPGRADE_NOWAIT</literal>, <literal>SELECT ... FOR "
 "UPDATE</literal> is used."
 msgstr ""
-"O método <literal>Session.lock()</literal> executa uma verificação no número "
-"da versão se o modo de lock especificado for <literal>READ</literal>, "
-"<literal>UPGRADE</literal> ou <literal>UPGRADE_NOWAIT</literal>.. (No caso "
-"do <literal>UPGRADE</literal> ou <literal>UPGRADE_NOWAIT</literal>, é usado "
-"<literal>SELECT ... FOR UPDATE</literal>.)"
+"O <literal>Session.lock()</literal> executa uma verificação no número da "
+"versão se o modo de bloqueio especificado for <literal>READ</literal>, "
+"<literal>UPGRADE</literal> ou <literal>UPGRADE_NOWAIT</literal>. No caso do "
+"<literal>UPGRADE</literal> ou <literal>UPGRADE_NOWAIT</literal>, é usado "
+"<literal>SELECT ... FOR UPDATE</literal>."
 
 #. Tag: para
-#: transactions.xml:951
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the requested lock mode is not supported by the database, Hibernate uses "
 "an appropriate alternate mode instead of throwing an exception. This ensures "
 "that applications are portable."
 msgstr ""
-"Se o banco de dados não suportar o lock mode solicitado, o Hibernate vai "
-"usar um modo alternativo apropriado (ao invés de lançar uma exceção). Isso "
-"garante que a aplicação vai ser portável."
+"Se o banco de dados não suportar o modo de bloqueio solicitado, o Hibernate "
+"usará um modo alternativo apropriado, ao invés de lançar uma exceção. Isso "
+"garante que a aplicação seja portátil. "
 
 #. Tag: title
-#: transactions.xml:960
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Connection release modes"
-msgstr "Modos de liberar a Connection"
+msgstr "Modos para liberar a conexão"
 
 #. Tag: para
-#: transactions.xml:962
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "One of the legacies of Hibernate 2.x JDBC connection management meant that a "
 "<literal>Session</literal> would obtain a connection when it was first "
@@ -2002,43 +1823,40 @@
 "by the enumerated values of <literal>org.hibernate.ConnectionReleaseMode</"
 "literal>:"
 msgstr ""
-"O comportamento legado do Hibernate (2.x) em consideração ao gerenciamento "
-"da conexão via JDBC fez com que a <literal>Session</literal> precisasse "
-"obter uma conexão quando ela precisasse pela primeira vez e depois manter a "
-"conexão enquanto a sessão não fosse fechada. O Hibernate 3.x introduz a "
-"idéia de modos de liberar a sessão, para informar a sessão a forma como deve "
+"O comportamento legado do Hibernate 2.x referente ao gerenciamento da "
+"conexão via JDBC era que a <literal>Session</literal> precisaria obter uma "
+"conexão quando ela precisasse pela primeira vez e depois manteria a conexão "
+"enquanto a sessão não fosse fechada. O Hibernate 3.x introduz a idéia de "
+"modos para liberar a sessão, para informar a sessão a forma como deve "
 "manusear a sua conexão JDBC. Veja que essa discussão só é pertinente para "
 "conexões fornecidas com um <literal>ConnectionProvider</literal> "
-"configurado; conexões fornecidas pelo usuário estão fora do escopo dessa "
+"configurado. As conexões fornecidas pelo usuário estão fora do escopo dessa "
 "discussão. Os diferentes modos de liberação estão definidos pelos valores da "
 "enumeração <literal>org.hibernate.ConnectionReleaseMode</literal>:"
 
 #. Tag: para
-#: transactions.xml:976
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ON_CLOSE</literal>: is the legacy behavior described above. The "
 "Hibernate session obtains a connection when it first needs to perform some "
 "JDBC access and maintains that connection until the session is closed."
 msgstr ""
-"<literal>ON_CLOSE</literal> - essencialmente é o modo legado descrito acima. "
-"A sessão do Hibernate obtêm a conexão quando precisar executar alguma "
-"operação JDBC pela primeira vez e mantem enquanto a conexão não for fechada."
+"<literal>ON_CLOSE</literal>: é o modo legado descrito acima. A sessão do "
+"Hibernate obtém a conexão quando precisar executar alguma operação JDBC pela "
+"primeira vez e mantém enquanto a conexão não for fechada."
 
 #. Tag: para
-#: transactions.xml:983
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>AFTER_TRANSACTION</literal>: releases connections after a "
 "<literal>org.hibernate.Transaction</literal> has been completed."
 msgstr ""
-"<literal>AFTER_TRANSACTION</literal> – informa que a conexão deve ser "
+"<literal>AFTER_TRANSACTION</literal>: informa que a conexão deve ser "
 "liberada após a conclusão de uma <literal>org.hibernate.Transaction</"
-"literal>."
+"literal>. "
 
 #. Tag: para
-#: transactions.xml:989
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>AFTER_STATEMENT</literal> (also referred to as aggressive release): "
 "releases connections after every statement execution. This aggressive "
@@ -2046,16 +1864,15 @@
 "the given session. Currently the only situation where this occurs is through "
 "the use of <literal>org.hibernate.ScrollableResults</literal>."
 msgstr ""
-"<literal>AFTER_STATEMENT</literal> (também conhecida com liberação "
-"agressiva) – informa que a conexão deve ser liberada após a execução de cada "
-"statement. A liberação agressiva não ocorre se o statement deixa pra trás "
-"algum recurso aberto associado com a sessão obtida; atualmente, a única "
-"situação em que isso é possível é com o uso de <literal>org.hibernate."
-"ScrollableResults</literal>."
+"<literal>AFTER_STATEMENT</literal> (também conhecida como liberação "
+"agressiva): informa que a conexão deve ser liberada após a execução de cada "
+"instrução. A liberação agressiva não ocorre se a instrução deixa pra trás "
+"algum recurso aberto associado com a sessão obtida. Atualmente, a única "
+"situação em que isto ocorre é com o uso de <literal>org.hibernate."
+"ScrollableResults</literal>. "
 
 #. Tag: para
-#: transactions.xml:999
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The configuration parameter <literal>hibernate.connection.release_mode</"
 "literal> is used to specify which release mode to use. The possible values "
@@ -2063,11 +1880,10 @@
 msgstr ""
 "O parâmetro de configuração <literal>hibernate.connection.release_mode</"
 "literal> é usado para especificar qual modo de liberação deve ser usado. "
-"Opções disponíveis:"
+"Segue abaixo os valores possíveis:"
 
 #. Tag: para
-#: transactions.xml:1006
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>auto</literal> (the default): this choice delegates to the release "
 "mode returned by the <literal>org.hibernate.transaction.TransactionFactory."
@@ -2077,28 +1893,26 @@
 "default behavior as failures due to the value of this setting tend to "
 "indicate bugs and/or invalid assumptions in user code."
 msgstr ""
-"<literal>auto</literal> (padrão) – essa opção delega ao modo de liberação "
+"<literal>auto</literal> (padrão): essa opção delega ao modo de liberação "
 "retornado pelo método <literal>org.hibernate.transaction.TransactionFactory."
 "getDefaultReleaseMode()</literal>. Para JTATransactionFactory, ele retorna "
 "ConnectionReleaseMode.AFTER_STATEMENT; para JDBCTransactionFactory, ele "
-"retorna ConnectionReleaseMode.AFTER_TRANSACTION. Raramente é uma boa idéia "
-"alterar padrão, como frequencia ao se fazer isso temos falhas que parecem "
-"bugs e/ou suposições inválidas no código do usuário."
+"retorna ConnectionReleaseMode.AFTER_TRANSACTION. Raramente, é uma boa idéia "
+"alterar padrão, pois ao se fazer isso temos falhas que parecem bugs e/ou "
+"suposições inválidas no código do usuário. "
 
 #. Tag: para
-#: transactions.xml:1016
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>on_close</literal>: uses ConnectionReleaseMode.ON_CLOSE. This "
 "setting is left for backwards compatibility, but its use is discouraged."
 msgstr ""
-"<literal>on_close</literal> - indica o uso da ConnectionReleaseMode."
-"ON_CLOSE. Essa opção foi deixada para manter a compatibilidade, mas seu uso "
-"é fortemente desencorajado."
+"<literal>on_close</literal>: indica o uso da ConnectionReleaseMode.ON_CLOSE. "
+"Essa opção foi deixada para manter a compatibilidade, mas seu uso é "
+"fortemente desencorajado. "
 
 #. Tag: para
-#: transactions.xml:1022
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>after_transaction</literal>: uses ConnectionReleaseMode."
 "AFTER_TRANSACTION. This setting should not be used in JTA environments. Also "
@@ -2106,15 +1920,14 @@
 "considered to be in auto-commit mode, connections will be released as if the "
 "release mode were AFTER_STATEMENT."
 msgstr ""
-"<literal>after_transaction</literal> – indica o uso da ConnectionReleaseMode."
-"AFTER_TRANSACTION. Essa opção nada deve ser usada com ambientes JTA. Também "
+"<literal>after_transaction</literal>: indica o uso da ConnectionReleaseMode."
+"AFTER_TRANSACTION. Essa opção não deve ser usada com ambientes JTA. Também "
 "note que no caso da ConnectionReleaseMode.AFTER_TRANSACTION, se a sessão foi "
 "colocada no modo auto-commit a conexão vai ser liberada de forma similar ao "
-"modo AFTER_STATEMENT."
+"modo AFTER_STATEMENT. "
 
 #. Tag: para
-#: transactions.xml:1030
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>after_statement</literal>: uses ConnectionReleaseMode."
 "AFTER_STATEMENT. Additionally, the configured <literal>ConnectionProvider</"
@@ -2126,12 +1939,12 @@
 "getConnection()</literal> or in auto-commit environments where it does not "
 "matter if we re-establish the same connection."
 msgstr ""
-"<literal>after_statement</literal> – indica o uso ConnectionReleaseMode."
-"AFTER_STATEMENT. Adicionalmente, o <literal>ConnectionProvider</literal> "
+"<literal>after_statement</literal>: indica o uso ConnectionReleaseMode."
+"AFTER_STATEMENT. Além disso, o <literal>ConnectionProvider</literal> "
 "configurado é consultado para verificar se suporta essa configuração "
-"((<literal>supportsAggressiveRelease()</literal>). Se não suportar, o modo "
-"de liberação é redefinido como ConnectionRelease-Mode.AFTER_TRANSACTION. "
-"Essa configuração só é segura em ambientes onde podemos readquirir a mesma "
-"conexão JDBC toda vez que o método <literal>ConnectionProvider.getConnection"
-"()</literal> for chamado ou em um ambiente auto-commit onde não importa se "
-"nós recuperamos a mesma conexão."
+"(<literal>supportsAggressiveRelease()</literal>). Se não suportar, o modo de "
+"liberação é redefinido como ConnectionRelease-Mode.AFTER_TRANSACTION. Essa "
+"configuração só é segura em ambientes onde podemos tanto readquirir a mesma "
+"conexão JDBC adjacente todas as vezes que chamarmos "
+"<literal>ConnectionProvider.getConnection()</literal> quanto em um ambiente "
+"auto-commit, onde não importa se voltamos para a mesma conexão. "

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/tutorial.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/tutorial.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/tutorial.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,23 +1,128 @@
+# translation of tutorial.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: tutorial\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2009-12-21 07:55+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: tutorial.xml:31
 #, no-c-format
 msgid "Tutorial"
-msgstr ""
+msgstr "Tutorial"
 
 #. Tag: para
-#: tutorial.xml:33
 #, no-c-format
 msgid ""
 "Intended for new users, this chapter provides an step-by-step introduction "
@@ -26,43 +131,49 @@
 "Gloegl. All code is contained in the <filename>tutorials/web</filename> "
 "directory of the project source."
 msgstr ""
+"Intencionado para novos usuários, este capítulo fornece uma introdução "
+"detalhada do Hibernate, começando com um aplicativo simples usando um banco "
+"de dados em memória. O tutorial é baseado num tutorial anterior desenvolvido "
+"por Michael Gloegl. Todo o código está contido no diretório "
+"<filename>tutorials/web</filename> da fonte do projeto."
 
 #. Tag: para
-#: tutorial.xml:42
 #, no-c-format
 msgid ""
 "This tutorial expects the user have knowledge of both Java and SQL. If you "
 "have a limited knowledge of JAVA or SQL, it is advised that you start with a "
 "good introduction to that technology prior to attempting to learn Hibernate."
 msgstr ""
+"Este tutorial espera que o usuário tenha conhecimento de ambos Java e SQL. "
+"Caso você tenha um conhecimento limitado do JAVA ou SQL, é recomendado que "
+"você inicie com uma boa introdução àquela tecnologia, antes de tentar "
+"entender o Hibernate."
 
 #. Tag: para
-#: tutorial.xml:51
 #, no-c-format
 msgid ""
 "The distribution contains another example application under the "
 "<filename>tutorial/eg</filename> project source directory."
 msgstr ""
+"Esta distribuição contém outro aplicativo de amostra sob o diretório de "
+"fonte do projeto <filename>tutorial/eg</filename>."
 
 #. Tag: title
-#: tutorial.xml:59
 #, no-c-format
 msgid "Part 1 - The first Hibernate Application"
 msgstr "Parte 1 – A primeira aplicação Hibernate"
 
 #. Tag: para
-#: tutorial.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For this example, we will set up a small database application that can store "
 "events we want to attend and information about the host(s) of these events."
 msgstr ""
 "Vamos supor que precisemos de uma aplicação com um banco de dados pequeno "
-"que possa armazenar e atender os eventos que queremos, e as informaççes "
-"sobre os hosts destes eventos."
+"que possa armazenar e atender os eventos que queremos, além das informações "
+"sobre os hosts destes eventos. "
 
 #. Tag: para
-#: tutorial.xml:67
 #, no-c-format
 msgid ""
 "Although you can use whatever database you feel comfortable using, we will "
@@ -70,15 +181,17 @@
 "database) to avoid describing installation/setup of any particular database "
 "servers."
 msgstr ""
+"Mesmo que usando qualquer banco de dados do qual você se sinta confortável, "
+"nós usaremos <ulink url=\"http://hsqldb.org/\">HSQLDB</ulink> (o em memória, "
+"banco de dados Java) para evitar a descrição de instalação/configuração de "
+"quaisquer servidores do banco de dados."
 
 #. Tag: title
-#: tutorial.xml:76
 #, no-c-format
 msgid "Setup"
-msgstr ""
+msgstr "Configuração"
 
 #. Tag: para
-#: tutorial.xml:78
 #, no-c-format
 msgid ""
 "The first thing we need to do is to set up the development environment. We "
@@ -90,72 +203,29 @@
 "making use of <filename>src/main/java</filename>, <filename>src/main/"
 "resources</filename> and <filename>src/main/webapp</filename> directories."
 msgstr ""
+"O primeiro passo em que precisamos tomar é configurar o ambiente de "
+"desenvolvimento. Nós usaremos o \"layout padrão\" suportado por muitas "
+"ferramentas de construção, tais como <ulink url=\"http://maven.org\">Maven</"
+"ulink>. Maven, em particular, possui um excelente recurso de descrição disto "
+"<ulink url=\"http://maven.apache.org/guides/introduction/introduction-to-the-"
+"standard-directory-layout.html\">layout</ulink>. Assim como este tutorial "
+"deve ser um aplicativo da web, nós criaremos e faremos uso dos diretórios "
+"<filename>src/main/java</filename>, <filename>src/main/resources</filename> "
+"e <filename>src/main/webapp</filename>."
 
 #. Tag: para
-#: tutorial.xml:88
 #, no-c-format
 msgid ""
 "We will be using Maven in this tutorial, taking advantage of its transitive "
 "dependency management capabilities as well as the ability of many IDEs to "
 "automatically set up a project for us based on the maven descriptor."
 msgstr ""
+"Nós usaremos Maven neste tutorial, tirando vantagem destas capacidades de "
+"dependência transitiva assim como a habilidade de muitos IDEs de configurar "
+"automaticamente um projeto baseado no descritor maven."
 
-#. Tag: programlisting
-#: tutorial.xml:94
-#, no-c-format
-msgid ""
-"<![CDATA[<project xmlns=\"http://maven.apache.org/POM/4.0.0\"\n"
-"         xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
-"         xsi:schemaLocation=\"http://maven.apache.org/POM/4.0.0 http://maven."
-"apache.org/xsd/maven-4.0.0.xsd\">\n"
-"\n"
-"    <modelVersion>4.0.0</modelVersion>\n"
-"\n"
-"    <groupId>org.hibernate.tutorials</groupId>\n"
-"    <artifactId>hibernate-tutorial</artifactId>\n"
-"    <version>1.0.0-SNAPSHOT</version>\n"
-"    <name>First Hibernate Tutorial</name>\n"
-"\n"
-"    <build>\n"
-"         <!-- we dont want the version to be part of the generated war file "
-"name -->\n"
-"         <finalName>${artifactId}</finalName>\n"
-"    </build>\n"
-"\n"
-"    <dependencies>\n"
-"        <dependency>\n"
-"            <groupId>org.hibernate</groupId>\n"
-"            <artifactId>hibernate-core</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Because this is a web app, we also have a dependency on the "
-"servlet api. -->\n"
-"        <dependency>\n"
-"            <groupId>javax.servlet</groupId>\n"
-"            <artifactId>servlet-api</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Hibernate uses slf4j for logging, for our purposes here use the "
-"simple backend -->\n"
-"        <dependency>\n"
-"            <groupId>org.slf4j</groupId>\n"
-"            <artifactId>slf4j-simple</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Hibernate gives you a choice of bytecode providers between "
-"cglib and javassist -->\n"
-"        <dependency>\n"
-"            <groupId>javassist</groupId>\n"
-"            <artifactId>javassist</artifactId>\n"
-"        </dependency>\n"
-"    </dependencies>\n"
-"\n"
-"</project>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:97
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "It is not a requirement to use Maven. If you wish to use something else to "
 "build this tutoial (such as Ant), the layout will remain the same. The only "
@@ -171,93 +241,61 @@
 "javassist</filename> directory; additionally you will need both the servlet-"
 "api jar and one of the slf4j logging backends."
 msgstr ""
+"O uso do Maven não é obrigatório. Caso você deseje usar outra tecnologia "
+"para construir este tutorial (tal como Ant), o layout continuará o mesmo. A "
+"única mudança é que você precisará contar manualmente para todas as "
+"dependências necessárias. Caso você utilize <ulink url=\"http://ant.apache."
+"org/ivy/\">Ivy</ulink> para fornecer um gerenciamento de dependência "
+"transitiva, você continuará a usar as dependências mencionadas abaixo. Do "
+"contrário, você precisará encontrar todas as dependências, ambas explícitas "
+"e transitivas, além de adicioná-las às classpath de projetos. Caso "
+"trabalhando da vinculação de distribuição Hibernate, quer dizer "
+"<filename>hibernate3.jar</filename>, todos os artefatos no diretório "
+"<filename>lib/required</filename> e todos os arquivos a partir do diretório "
+"<filename>lib/bytecode/cglib</filename> ou <filename>lib/bytecode/javassist</"
+"filename>. Adicionalmente, você precisará de ambos servlet-api jar e um dos "
+"slf4j logging backends."
 
 #. Tag: para
-#: tutorial.xml:114
 #, no-c-format
 msgid ""
 "Save this file as <filename>pom.xml</filename> in the project root directory."
 msgstr ""
+"Salve este arquivo como <filename>pom.xml</filename> no diretório raiz do "
+"projeto."
 
 #. Tag: title
-#: tutorial.xml:121
 #, no-c-format
 msgid "The first class"
 msgstr "A primeira Classe"
 
 #. Tag: para
-#: tutorial.xml:123
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next, we create a class that represents the event we want to store in the "
 "database; it is a simple JavaBean class with some properties:"
 msgstr ""
 "Agora, iremos criar uma classe que representa o evento que queremos "
-"armazenar na base de dados.."
+"armazenar na base de dados. Isto é uma classe JavaBean simples com algumas "
+"propriedades:"
 
-#. Tag: programlisting
-#: tutorial.xml:128
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[package org.hibernate.tutorial.domain;\n"
-"\n"
-"import java.util.Date;\n"
-"\n"
-"public class Event {\n"
-"    private Long id;\n"
-"\n"
-"    private String title;\n"
-"    private Date date;\n"
-"\n"
-"    public Event() {}\n"
-"\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"\n"
-"    private void setId(Long id) {\n"
-"        this.id = id;\n"
-"    }\n"
-"\n"
-"    public Date getDate() {\n"
-"        return date;\n"
-"    }\n"
-"\n"
-"    public void setDate(Date date) {\n"
-"        this.date = date;\n"
-"    }\n"
-"\n"
-"    public String getTitle() {\n"
-"        return title;\n"
-"    }\n"
-"\n"
-"    public void setTitle(String title) {\n"
-"        this.title = title;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:130
-#, fuzzy, no-c-format
-msgid ""
 "This class uses standard JavaBean naming conventions for property getter and "
 "setter methods, as well as private visibility for the fields. Although this "
 "is the recommended design, it is not required. Hibernate can also access "
 "fields directly, the benefit of accessor methods is robustness for "
 "refactoring."
 msgstr ""
-"Você pode ver que esta classe usa o padrão JavaBean para o nomeamento "
-"convencional da propriedade getter e dos métodos setter, como também a "
-"visibilidade private dos campos. Este é um padrão de projeto recomendado, "
-"mas não requerido. O Hibernate pode também acessar campos diretamente, o "
-"benefício para os métodos de acesso é a robustez para o Refactoring. O "
-"construtor sem argumento é requerido para instanciar um objeto desta classe "
-"com a reflexão."
+"Você pode ver que esta classe usa o padrão JavaBean para o nome convencional "
+"dos métodos de propriedade getter e setter, como também a visibilidade "
+"privada dos campos. Este é um padrão de projeto recomendado, mas não "
+"requerido. O Hibernate pode também acessar campos diretamente, o benefício "
+"para os métodos de acesso é a robustez para o refactoring. "
 
 #. Tag: para
-#: tutorial.xml:138
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>id</literal> property holds a unique identifier value for a "
 "particular event. All persistent entity classes (there are less important "
@@ -275,19 +313,18 @@
 "para um evento particular. Todas as classes persistentes da entidade (bem "
 "como aquelas classes dependentes de menos importância) precisam de uma "
 "propriedade de identificação, caso nós queiramos usar o conjunto completo de "
-"características do Hibernate. De fato, a maioria das aplicações (esp. "
-"aplicações web) precisam destinguir os objetos pelo identificador, então "
-"você deverá considerar esta, uma característica em lugar de uma limitação. "
-"Porém, nós normalmente não manipulamos a identidade de um objeto, "
-"consequentemente o método setter deverá ser privado. O Hibernate somente "
-"nomeará os identificadores quando um objeto for salvo. Você pode ver como o "
+"características do Hibernate. De fato, a maioria das aplicações, "
+"especialmente. aplicações web, precisam distinguir os objetos pelo "
+"identificador. Portanto, você deverá considerar esta, uma característica ao "
+"invés de uma limitação. Porém, nós normalmente não manipulamos a identidade "
+"de um objeto, conseqüentemente o método setter deverá ser privado. O "
+"Hibernate somente nomeará os identificadores quando um objeto for salvo. O "
 "Hibernate pode acessar métodos públicos, privados, e protegidos, como também "
-"campos (públicos, privados, protegidos) diretamente. A escolha está até "
-"você, e você pode combinar isso para adaptar seu projeto de aplicação"
+"campos públicos, privados, protegidos diretamente. A escolha é sua e você "
+"pode adaptar seu projeto de aplicação."
 
 #. Tag: para
-#: tutorial.xml:153
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The no-argument constructor is a requirement for all persistent classes; "
 "Hibernate has to create objects for you, using Java Reflection. The "
@@ -296,27 +333,26 @@
 "instrumentation."
 msgstr ""
 "O construtor sem argumentos é um requerimento para todas as classes "
-"persistentes; O Hibernate tem que criar para você os objetos usando Java "
+"persistentes; O Hibernate precisa criar para você os objetos usando Java "
 "Reflection. O construtor pode ser privado, porém, a visibilidade do pacote é "
 "requerida para a procuração da geração em tempo de execução e recuperação "
-"eficiente dos dados sem a instrumentação de bytecode"
+"eficiente dos dados sem a instrumentação de bytecode."
 
 #. Tag: para
-#: tutorial.xml:161
 #, no-c-format
 msgid ""
 "Save this file to the <filename>src/main/java/org/hibernate/tutorial/domain</"
 "filename> directory."
 msgstr ""
+"Salve este arquivo no diretório <filename>src/main/java/org/hibernate/"
+"tutorial/domain</filename>."
 
 #. Tag: title
-#: tutorial.xml:168
 #, no-c-format
 msgid "The mapping file"
 msgstr "O mapeamento do arquivo"
 
 #. Tag: para
-#: tutorial.xml:170
 #, no-c-format
 msgid ""
 "Hibernate needs to know how to load and store objects of the persistent "
@@ -325,34 +361,18 @@
 "columns in that table it should use."
 msgstr ""
 "O Hibernate precisa saber como carregar e armazenar objetos da classe de "
-"persistência. Isto será onde o mapeamento do arquivo do Hibernate entrará em "
+"persistência. É aqui que o mapeamento do arquivo do Hibernate entrará em "
 "jogo. O arquivo mapeado informa ao Hibernate, qual tabela no banco de dados "
 "ele deverá acessar, e quais as colunas na tabela ele deverá usar."
 
 #. Tag: para
-#: tutorial.xml:178
 #, no-c-format
 msgid "The basic structure of a mapping file looks like this:"
 msgstr "A estrutura básica de um arquivo de mapeamento é parecida com:"
 
-#. Tag: programlisting
-#: tutorial.xml:182
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"[...]\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:184
-#, fuzzy, no-c-format
-msgid ""
 "Hibernate DTD is sophisticated. You can use it for auto-completion of XML "
 "mapping elements and attributes in your editor or IDE. Opening up the DTD "
 "file in your text editor is the easiest way to get an overview of all "
@@ -363,56 +383,41 @@
 "<filename>hibernate3.jar</filename>, if using the distribution bundle)."
 msgstr ""
 "Note que o Hibernate DTD é muito sofisticado. Você pode usar isso para auto-"
-"conclusão no mapeamento XML dos elementos e atributos no seu editor ou IDE. "
-"Você também pode abrir o arquivo DTD no seu editor – é a maneira mais fácil "
-"de ter uma visão geral de todos os elementos e atributos e dos padrões, como "
-"também alguns comentários. Note que o Hibernate não irá carregar o arquivo "
-"DTD da web, e sim do diretório da aplicação (classpath). O arquivo DTD está "
-"incluído no <literal>hibernate3.jar</literal> como também no diretório "
-"<literal>src/</literal> da distribuição do Hibernate."
+"conclusão no mapeamento XML dos elementos e funções no seu editor ou IDE. "
+"Você também pode abrir o arquivo DTD no seu editor. Esta é a maneira mais "
+"fácil de ter uma visão geral de todos os elementos e funções e dos padrões, "
+"como também alguns comentários. Note que o Hibernate não irá carregar o "
+"arquivo DTD da web, e sim da classpath da aplicação. O arquivo DTD está "
+"incluído no <filename>hibernate-core.jar</filename> (como também no "
+"<filename>hibernate3.jar</filename>, caso usando a vinculação de "
+"distribuição."
 
 #. Tag: para
-#: tutorial.xml:197
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will omit the DTD declaration in future examples to shorten the code. It "
 "is, of course, not optional."
 msgstr ""
 "Nós omitiremos a declaração do DTD nos exemplos futuros para encurtar o "
-"código. Isto, é claro, não é opcional."
+"código. Isto, é claro, não é opcional. "
 
 #. Tag: para
-#: tutorial.xml:203
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Between the two <literal>hibernate-mapping</literal> tags, include a "
 "<literal>class</literal> element. All persistent entity classes (again, "
 "there might be dependent classes later on, which are not first-class "
 "entities) need a mapping to a table in the SQL database:"
 msgstr ""
-"Entre os dois tags <literal>hibernate-mapping</literal>, inclua um elemento "
+"Entre as duas tags <literal>hibernate-mapping</literal>, inclua um elemento "
 "<literal>class</literal>. Todas as classes persistentes da entidade "
 "(novamente, poderá haver mais tarde, dependências sobre as classes que não "
 "são classes-primárias de entidades) necessitam do tal mapeamento, para uma "
-"tabela na base de dados SQL"
+"tabela na base de dados SQL:"
 
-#. Tag: programlisting
-#: tutorial.xml:210
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:212
-#, fuzzy, no-c-format
-msgid ""
 "So far we have told Hibernate how to persist and load object of class "
 "<literal>Event</literal> to the table <literal>EVENTS</literal>. Each "
 "instance is now represented by a row in that table. Now we can continue by "
@@ -420,31 +425,15 @@
 "not want to care about handling this identifier, we configure Hibernate's "
 "identifier generation strategy for a surrogate primary key column:"
 msgstr ""
-"Mais adiante iremos dizer ao Hibernate como fazer para persistir e carregar "
+"Até agora, informamos o Hibernate sobre como fazer para persistir e carregar "
 "objetos da classe <literal>Event</literal> da tabela <literal>EVENTS</"
-"literal>, cada instancia representada por uma coluna na tabela. Agora, "
+"literal>, cada instância representada por uma coluna na tabela. Agora, "
 "continuaremos com o mapeamento de uma única propriedade identificadora para "
-"as chaves primárias da tabela. Além disso, nós não iremos se importar com "
-"esta propriedade identificadora, nós iremos configurar uma estratégia de "
-"geração de id’s para uma chave primária de uma surrogate key:"
+"as chaves primárias da tabela. Além disso, como não precisamos nos preocupar "
+"em manipular este identificador, iremos configurar uma estratégia de geração "
+"de id’s do Hibernate para uma coluna de chave primária substituta: "
 
-#. Tag: programlisting
-#: tutorial.xml:222
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"        <id name=\"id\" column=\"EVENT_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:224
 #, no-c-format
 msgid ""
 "The <literal>id</literal> element is the declaration of the identifier "
@@ -454,9 +443,14 @@
 "The column attribute tells Hibernate which column of the <literal>EVENTS</"
 "literal> table holds the primary key value."
 msgstr ""
+"O elemento <literal>id</literal> é a declaração de uma propriedade do "
+"identificador. O atributo do mapeamento <literal>name=\"id\"</literal> "
+"declara que o nome da propriedade JavaBeans e informa o Hibernate a utilizar "
+"os métodos <literal>getId()</literal> and <literal>setId()</literal> para "
+"acessar a propriedade. A atributo da coluna informa o Hibernate qual coluna "
+"da tabela <literal>EVENTS</literal> mantém o valor de chave primária."
 
 #. Tag: para
-#: tutorial.xml:234
 #, no-c-format
 msgid ""
 "The nested <literal>generator</literal> element specifies the identifier "
@@ -467,63 +461,53 @@
 "Identifier value generation is also one of Hibernate's many extension points "
 "and you can plugin in your own strategy."
 msgstr ""
+"O elemento <literal>generator</literal> aninhado especifica a estratégia da "
+"geração do identificador (como os valores do identificador são gerados?). "
+"Neste caso, nós escolhemos <literal>native</literal>, do qual oferece um "
+"nível de portabilidade dependendo no dialeto do banco de dados configurado. "
+"O Hibernate suporta o banco de dados gerado, globalmente único, assim como a "
+"aplicação determinada, identificadores. A geração do valor do identificador "
+"é também um dos muitos pontos de extensão do Hibernate e você pode realizar "
+"o plugin na sua própria estratégia."
 
 #. Tag: para
-#: tutorial.xml:246
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "<literal>native</literal> is no longer consider the best strategy in terms "
-"of portability. for further discussion, see"
+"of portability. for further discussion, see <xref linkend=\"portability-idgen"
+"\" />"
 msgstr ""
+"<literal>native</literal> não é mais considerada a melhor estratégia em "
+"termos de portabilidade. Para maiores informações consulte <xref linkend="
+"\"portability-idgen\" />"
 
 #. Tag: para
-#: tutorial.xml:252
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Lastly, we need to tell Hibernate about the remaining entity class "
 "properties. By default, no properties of the class are considered persistent:"
 msgstr ""
-"Finalmente incluiremos as declarações para as propriedades persistentes da "
-"classe no arquivo mapeado. Por default, nenhuma das propriedades da classe é "
+"Finalmente, incluiremos as declarações para as propriedades persistentes da "
+"classe no arquivo mapeado. Por padrão, nenhuma das propriedades da classe é "
 "considerada persistente:"
 
-#. Tag: programlisting
-#: tutorial.xml:258
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"        <id name=\"id\" column=\"EVENT_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"date\" type=\"timestamp\" column=\"EVENT_DATE\"/>\n"
-"        <property name=\"title\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:260
-#, fuzzy, no-c-format
-msgid ""
 "Similar to the <literal>id</literal> element, the <literal>name</literal> "
 "attribute of the <literal>property</literal> element tells Hibernate which "
 "getter and setter methods to use. In this case, Hibernate will search for "
 "<literal>getDate()</literal>, <literal>setDate()</literal>, <literal>getTitle"
 "()</literal> and <literal>setTitle()</literal> methods."
 msgstr ""
-"Da mesma maneira que com o elemento <literal>id</literal>, o atributo "
-"<literal>name</literal> do elemento <literal>property</literal> informa ao "
-"Hibernate qual método getter e setter deverá usar. Assim, neste caso, o "
-"Hibernate irá procurar pelo <literal>getDate()/setDate()</literal>, como "
-"também pelo <literal>getTitle()/setTitle()</literal>."
+"Assim como com o elemento <literal>id</literal>, a função <literal>name</"
+"literal> do elemento <literal>property</literal> informa ao Hibernate qual "
+"método getter e setter deverá usar. Assim, neste caso, o Hibernate irá "
+"procurar pelos métodos <literal>getDate()</literal>, <literal>setDate()</"
+"literal>, <literal>getTitle()</literal> e <literal>setTitle()</literal>."
 
 #. Tag: para
-#: tutorial.xml:271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Why does the <literal>date</literal> property mapping include the "
 "<literal>column</literal> attribute, but the <literal>title</literal> does "
@@ -532,17 +516,16 @@
 "literal>, however, <literal>date</literal> is a reserved keyword in most "
 "databases so you will need to map it to a different name."
 msgstr ""
-"Porque fazer o mapeamento da propriedade <literal>date</literal> incluído no "
-"atributo <literal>column</literal>, e no title não fazer? Sem o atributo "
-"<literal>column</literal> o Hibernate por padrão usa o nome da propriedade "
-"como o nome da coluna. Isto trabalha muito bem para o <literal>title</"
-"literal>. Entretanto o <literal>date</literal> é uma palavra-chave reservada "
-"na maioria dos bancos de dados, assim nós melhoramos o mapeamentos disto com "
-"um nome diferente."
+"Porque fazer o mapeamento da propriedade <literal>date</literal> incluído na "
+"função <literal>column</literal>, e no <literal>title</literal> não fazer? "
+"Sem a função <literal>column</literal> o Hibernate, por padrão, utiliza o "
+"nome da propriedade como o nome da coluna. Isto funciona bem para o "
+"<literal>title</literal>. Entretanto, o <literal>date</literal> é uma "
+"palavra-chave reservada na maioria dos bancos de dados, por isso seria "
+"melhor mapeá-lo com um nome diferente. "
 
 #. Tag: para
-#: tutorial.xml:281
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>title</literal> mapping also lacks a <literal>type</literal> "
 "attribute. The types declared and used in the mapping files are not Java "
@@ -559,26 +542,24 @@
 "literal> column. Full date and time information is preserved by mapping the "
 "property with a <literal>timestamp</literal> converter."
 msgstr ""
-"A próxima coisa interessante é que mapemanto do <literal>title</literal> "
-"também falta o atributo <literal>type</literal>. O tipo que declaramos e o "
-"uso nos arquivos mapeados, não são como você pôde esperar, atributos de "
-"dados Java. Eles não são como os tipos de base de dados SQL. Esses tipos "
-"podem ser chamados de <emphasis>Tipos de mapeamento Hibernate</emphasis>, "
-"que são conversores que podem traduzir tipos de dados do Java para os tipos "
-"de dados SQL e vice-versa. Novamente, o Hibernate irá tentar determinar a "
-"conversão correta e mapeará o <literal>type</literal> próprio, caso o tipo "
-"do atributo não estiver presente no mapeamento. Em alguns casos, esta "
-"detecção automática (que usa Reflection sobre as classes Java) poderá não "
-"ter padrão que você espera ou necessita. Este é o caso com a propriedade "
-"<literal>date</literal>. O Hibernate não pode saber se a propriedade (que é "
-"do <literal>java.util.Date</literal>) pode mapear para uma coluna do tipo "
-"<literal>date</literal> do SQL, <literal>timestamp</literal>, ou "
-"<literal>time</literal> . Nós preservamos a informação cheia de datas e "
-"horas pelo mapeamento da propriedade com um conversor <literal>timestamp</"
-"literal>."
+"O mapeamento do <literal>title</literal> também não possui a função "
+"<literal>type</literal>. O tipo que declaramos e utilizamos nos arquivos "
+"mapeados, não são como você esperava, ou seja, funções de dados Java. Eles "
+"também não são como os tipos de base de dados SQL. Esses tipos podem ser "
+"chamados de <emphasis>Tipos de mapeamento Hibernate</emphasis>, que são "
+"conversores que podem traduzir tipos de dados do Java para os tipos de dados "
+"SQL e vice-versa. Novamente, o Hibernate irá tentar determinar a conversão "
+"correta e mapeará o <literal>type</literal> próprio, caso o tipo da função "
+"não estiver presente no mapeamento. Em alguns casos, esta detecção "
+"automática (que usa Reflection sobre as classes Java) poderá não ter o "
+"padrão que você espera ou necessita. Este é o caso com a propriedade "
+"<literal>date</literal>. O Hibernate não sabe se a propriedade, que é do "
+"<literal>java.util.Date</literal>, pode mapear para uma coluna do tipo "
+"<literal>date</literal> do SQL, <literal>timestamp</literal> ou "
+"<literal>time</literal>. Nós preservamos as informações sobre datas e horas "
+"pelo mapeamento da propriedade com um conversor <literal>timestamp</literal>."
 
 #. Tag: para
-#: tutorial.xml:297
 #, no-c-format
 msgid ""
 "Hibernate makes this mapping type determination using reflection when the "
@@ -586,39 +567,44 @@
 "performance is important you should consider explicitly defining the type to "
 "use."
 msgstr ""
+"O Hibernate realiza esta determinação de tipo de mapeamento usando a "
+"reflexão quando os arquivos de mapeamentos são processados. Isto pode levar "
+"tempo e recursos, portanto se você inicializar o desempenho, será importante "
+"que você considere claramente a definição do tipo para uso."
 
 #. Tag: para
-#: tutorial.xml:304
 #, no-c-format
 msgid ""
 "Save this mapping file as <filename>src/main/resources/org/hibernate/"
 "tutorial/domain/Event.hbm.xml</filename>."
 msgstr ""
+"Salve este arquivo de mapeamento como <filename>src/main/resources/org/"
+"hibernate/tutorial/domain/Event.hbm.xml</filename>."
 
 #. Tag: title
-#: tutorial.xml:312
 #, no-c-format
 msgid "Hibernate configuration"
 msgstr "Configuração do Hibernate"
 
 #. Tag: para
-#: tutorial.xml:314
 #, no-c-format
 msgid ""
 "At this point, you should have the persistent class and its mapping file in "
 "place. It is now time to configure Hibernate. First let's set up HSQLDB to "
 "run in \"server mode\""
 msgstr ""
+"Nestas alturas, você deve possuir a classe persistente e seu arquivo de "
+"mapeamento prontos. É o momento de configurar o Hibernate. Primeiro, vamos "
+"configurar o HSQLDB para rodar no \"modo do servidor\"."
 
 #. Tag: para
-#: tutorial.xml:321
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "We do this do that the data remains between runs."
 msgstr ""
+"Nós realizamos isto para que aqueles dados permaneçam entre as execuções."
 
 #. Tag: para
-#: tutorial.xml:326
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will utilize the Maven exec plugin to launch the HSQLDB server by "
 "running: <command> mvn exec:java -Dexec.mainClass=\"org.hsqldb.Server\" -"
@@ -628,18 +614,15 @@
 "tutorial, shutdown HSQLDB, delete all files in the <filename>target/data</"
 "filename> directory, and start HSQLDB again."
 msgstr ""
-"Crie um diretório chamado <literal>data</literal> no diretório root de "
-"desenvolvimento – Isto será onde o HSQL DB irá armazenar arquivos de dados. "
-"Agora iremos iniciar o banco de dados executando <literal>java -classpath ../"
-"lib/hsqldb.jar org.hsqldb.Server</literal> neste diretório de dados. Você "
-"pode ver ele iniciando e conectando ao socket TCP/IP, isto será onde nossa "
+"Nós utilizaremos o Maven exec plugin para lançar o servidor HSQLDB pela "
+"execução: <command> mvn exec:java -Dexec.mainClass=\"org.hsqldb.Server\" -"
+"Dexec.args=\"-database.0 file:target/data/tutorial\"</command>. Você pode "
+"ver ele iniciando e vinculando ao soquete TCP/IP, aqui será onde nossa "
 "aplicação irá se conectar depois. Se você deseja iniciar uma nova base de "
-"dados durante este tutorial, finalize o HSQL DB(pressionando o <literal>CTRL "
-"+ C</literal> na janela), delete todos os arquivos no diretório "
-"<literal>data/</literal>, e inicie o HSQL BD novamente."
+"dados durante este tutorial, finalize o HSQLDB, delete todos os arquivos no "
+"diretório <filename>target/data</filename>, e inicie o HSQLBD novamente."
 
 #. Tag: para
-#: tutorial.xml:337
 #, no-c-format
 msgid ""
 "Hibernate will be connecting to the database on behalf of your application, "
@@ -651,18 +634,26 @@
 "net/\">proxool</ulink>. However, we will be using the Hibernate built-in "
 "connection pool for this tutorial."
 msgstr ""
+"O Hibernate conectará ao banco de dados no lugar de sua aplicação, portanto "
+"ele precisará saber como obter as conexões. Para este tutorial nós usaremos "
+"um pool de conexão autônomo (ao invés de <interfacename>javax.sql."
+"DataSource</interfacename>). O Hibernate vem com o suporte para dois terços "
+"dos pools de conexão JDBC de código aberto: <ulink url=\"https://sourceforge."
+"net/projects/c3p0\">c3p0</ulink> e <ulink url=\"http://proxool.sourceforge."
+"net/\">proxool</ulink>. No entanto, nós usaremos o pool de conexão interna "
+"do Hibernate para este tutorial."
 
 #. Tag: para
-#: tutorial.xml:348
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The built-in Hibernate connection pool is in no way intended for production "
 "use. It lacks several features found on any decent connection pool."
 msgstr ""
+"O pool de conexão interna do Hibernate não é recomendado para uso de "
+"produção."
 
 #. Tag: para
-#: tutorial.xml:354
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For Hibernate's configuration, we can use a simple <literal>hibernate."
 "properties</literal> file, a more sophisticated <literal>hibernate.cfg.xml</"
@@ -670,102 +661,54 @@
 "XML configuration file:"
 msgstr ""
 "Para as configurações do Hibernate, nós podemos usar um arquivo simples "
-"<literal>hibernate.properties</literal>, um arquivo mais ligeiramente "
-"sofisticado <literal>hibernate.cfg.xml</literal> ou até mesmo uma instalação "
-"programática completa. A maioria dos usuários preferem utilizar o arquivo de "
-"configuração XML"
+"<literal>hibernate.properties</literal>, um arquivo mais sofisticado "
+"<literal>hibernate.cfg.xml</literal> ou até mesmo uma instalação "
+"programática completa. A maioria dos usuários prefere utilizar o arquivo de "
+"configuração XML:"
 
-#. Tag: programlisting
-#: tutorial.xml:360
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-"<!DOCTYPE hibernate-configuration PUBLIC\n"
-"        \"-//Hibernate/Hibernate Configuration DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
-"\">\n"
-"\n"
-"<hibernate-configuration>\n"
-"\n"
-"    <session-factory>\n"
-"\n"
-"        <!-- Database connection settings -->\n"
-"        <property name=\"connection.driver_class\">org.hsqldb.jdbcDriver</"
-"property>\n"
-"        <property name=\"connection.url\">jdbc:hsqldb:hsql://localhost</"
-"property>\n"
-"        <property name=\"connection.username\">sa</property>\n"
-"        <property name=\"connection.password\"></property>\n"
-"\n"
-"        <!-- JDBC connection pool (use the built-in) -->\n"
-"        <property name=\"connection.pool_size\">1</property>\n"
-"\n"
-"        <!-- SQL dialect -->\n"
-"        <property name=\"dialect\">org.hibernate.dialect.HSQLDialect</"
-"property>\n"
-"\n"
-"        <!-- Enable Hibernate's automatic session context management -->\n"
-"        <property name=\"current_session_context_class\">thread</property>\n"
-"\n"
-"        <!-- Disable the second-level cache  -->\n"
-"        <property name=\"cache.provider_class\">org.hibernate.cache."
-"NoCacheProvider</property>\n"
-"\n"
-"        <!-- Echo all executed SQL to stdout -->\n"
-"        <property name=\"show_sql\">true</property>\n"
-"\n"
-"        <!-- Drop and re-create the database schema on startup -->\n"
-"        <property name=\"hbm2ddl.auto\">update</property>\n"
-"\n"
-"        <mapping resource=\"org/hibernate/tutorial/domain/Event.hbm.xml\"/>\n"
-"\n"
-"    </session-factory>\n"
-"\n"
-"</hibernate-configuration>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:363
 #, no-c-format
 msgid "Notice that this configuration file specifies a different DTD"
-msgstr ""
+msgstr "Perceba que este arquivo de configuração especifica um DTD diferente"
 
 #. Tag: para
-#: tutorial.xml:366
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You configure Hibernate's <literal>SessionFactory</literal>. SessionFactory "
 "is a global factory responsible for a particular database. If you have "
 "several databases, for easier startup you should use several <literal>&lt;"
 "session-factory&gt;</literal> configurations in several configuration files."
 msgstr ""
-"Note que esta configuração XML usa um diferente DTD. Nós configuraremos as "
-"<literal>SessionFactory</literal> do Hibernate – uma factory global "
-"responsável por uma base de dedados particular. Se você tiver diversas bases "
-"de dados, use diversas configurações <literal>&lt;session-factory&gt;</"
-"literal>, geralmente em diversos arquivos de configuração (para uma partida "
-"mais fácil)."
+"Configure a <literal>SessionFactory</literal> do Hibernate. A SessionFactory "
+"é uma fábrica global responsável por uma base de dados particular. Se você "
+"tiver diversas bases de dados, use diversas configurações <literal>&lt;"
+"session-factory&gt;</literal>, geralmente em diversos arquivos de "
+"configuração, para uma inicialização mais fácil. "
 
 #. Tag: para
-#: tutorial.xml:373
 #, no-c-format
 msgid ""
 "The first four <literal>property</literal> elements contain the necessary "
 "configuration for the JDBC connection. The dialect <literal>property</"
 "literal> element specifies the particular SQL variant Hibernate generates."
 msgstr ""
+"Os primeiros quatro elementos <literal>property</literal> contêm a "
+"configuração necessária para a conexão JBDC. O elemento <literal>property</"
+"literal> do dialeto especifica a variante do SQL particular que o Hibernate "
+"gera."
 
 #. Tag: para
-#: tutorial.xml:380
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "In most cases, Hibernate is able to properly determine which dialect to use. "
-"See <xref linkend=\"portability-dialectresolver\"/> for more information."
+"See <xref linkend=\"portability-dialectresolver\" /> for more information."
 msgstr ""
+"Na maioria dos casos, o Hibernate está apto a determinar corretamente qual "
+"dialeto em uso. Consulte <xref linkend=\"portability-dialectresolver\"/> "
+"para maiores informações. "
 
 #. Tag: para
-#: tutorial.xml:386
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's automatic session management for persistence contexts is "
 "particularly useful in this context. The <literal>hbm2ddl.auto</literal> "
@@ -775,34 +718,30 @@
 "Ant task. Finally, add the mapping file(s) for persistent classes to the "
 "configuration."
 msgstr ""
-"As primeiras quatro <literal>propriedades</literal> do elemento contém a "
-"configuração necessária para a conexão ao JDBC. A propriedade "
-"<literal>propriedade</literal> dialect do elemento especifica a variante "
-"particular do SQL que o Hibernate gera. O gerenciamento automático de sessão "
-"do Hibernate para contextos de persistência estará disponível em breve. A "
-"opção <literal>hbm2ddl.auto</literal> habilita a geração automática de "
-"schemas da base de dados – diretamente na base de dados. Isto também pode "
-"ser naturalmente desligado (removendo a opção de configuração) ou "
-"redirecionando para um arquivo com ajuda do <literal>SchemaExport</literal> "
-"nas tarefas do Ant. Finalmente, iremos adicionar os arquivos das classes de "
-"persistência mapeadas na configuração."
+"O gerenciamento automático de sessão do Hibernate para contextos de "
+"persistência é bastante útil neste contexto. A opção <literal>hbm2ddl.auto</"
+"literal> habilita a geração automática de esquemas da base de dados, "
+"diretamente na base de dados. Isto também pode ser naturalmente desligado "
+"apenas removendo a opção de configuração ou redirecionado para um arquivo "
+"com ajuda do <literal>SchemaExport</literal> na tarefa do Ant. Finalmente, "
+"iremos adicionar os arquivos das classes de persistência mapeadas na "
+"configuração."
 
 #. Tag: para
-#: tutorial.xml:395
 #, no-c-format
 msgid ""
 "Save this file as <filename>hibernate.cfg.xml</filename> into the "
 "<filename>src/main/resources</filename> directory."
 msgstr ""
+"Salve este arquivo como <filename>hibernate.cfg.xml</filename> no diretório "
+"<filename>src/main/resources</filename>."
 
 #. Tag: title
-#: tutorial.xml:403
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Building with Maven"
-msgstr "Construindo com o Ant"
+msgstr "Construindo com o Maven"
 
 #. Tag: para
-#: tutorial.xml:405
 #, no-c-format
 msgid ""
 "We will now build the tutorial with Maven. You will need to have Maven "
@@ -812,45 +751,21 @@
 "basic project tasks. First, lets run the <literal>compile</literal> goal to "
 "make sure we can compile everything so far:"
 msgstr ""
+"Nós iremos construir agora o tutorial com Maven. Você necessitará que o "
+"Maven esteja instalado; ele está disponível a partir do <ulink url=\"http://"
+"maven.apache.org/download.html\">Maven download page</ulink>. O Maven "
+"gravará o arquivo <filename>/pom.xml</filename> que criamos anteriormente, "
+"além de saber como executar algumas tarefas do projeto básico. Primeiro, "
+"vamos rodar o objetivo <literal>compile</literal> para nos certificarmos de "
+"que tudo foi compilado até agora:"
 
-#. Tag: programlisting
-#: tutorial.xml:415
-#, no-c-format
-msgid ""
-"<![CDATA[[hibernateTutorial]$ mvn compile\n"
-"[INFO] Scanning for projects...\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] Building First Hibernate Tutorial\n"
-"[INFO]    task-segment: [compile]\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] [resources:resources]\n"
-"[INFO] Using default encoding to copy filtered resources.\n"
-"[INFO] [compiler:compile]\n"
-"[INFO] Compiling 1 source file to /home/steve/projects/sandbox/"
-"hibernateTutorial/target/classes\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] BUILD SUCCESSFUL\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] Total time: 2 seconds\n"
-"[INFO] Finished at: Tue Jun 09 12:25:25 CDT 2009\n"
-"[INFO] Final Memory: 5M/547M\n"
-"[INFO] "
-"------------------------------------------------------------------------]]>"
-msgstr ""
-
 #. Tag: title
-#: tutorial.xml:420
 #, no-c-format
 msgid "Startup and helpers"
-msgstr "Startup and helpers"
+msgstr "Inicialização e Auxiliares "
 
 #. Tag: para
-#: tutorial.xml:422
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is time to load and store some <literal>Event</literal> objects, but "
 "first you have to complete the setup with some infrastructure code. You have "
@@ -863,72 +778,40 @@
 "<interfacename>org.hibernate.SessionFactory</interfacename> is a thread-safe "
 "global object that is instantiated once."
 msgstr ""
-"É hora de carregar e arquivar alguns objetos <literal>Event</literal>, mas "
-"primeiro nós temos de completar o setup com algum código de infraestrutura. "
-"Este startup inclui a construção de um objeto <literal>SessionFactory</"
-"literal> global e armazenar isto em algum lugar de fácil acesso para o "
-"código da aplicação. Uma <literal>SessionFactory</literal> pode abrir novas "
-"<literal>Session</literal>'s. Uma <literal>Session</literal> representa uma "
-"unidade single-theaded do trabalho, a <literal>SessionFactory</literal> é um "
-"objeto global thread-safe, instanciado uma vez."
+"É hora de carregar e armazenar alguns objetos <literal>Event</literal>, mas "
+"primeiro nós temos de completar a instalação com algum código de "
+"infraestrutura. Você precisa inicializar o Hibernate pela construção de um "
+"objeto <interfacename>org.hibernate.SessionFactory</interfacename> global e "
+"o armazenamento dele em algum lugar de fácil acesso para o código da "
+"aplicação. O <interfacename>org.hibernate.SessionFactory</interfacename> é "
+"usado para obter instâncias <interfacename>org.hibernate.Session</"
+"interfacename>. O <interfacename>org.hibernate.Session</interfacename> "
+"representa uma unidade de single-threaded de trabalho. O <interfacename>org."
+"hibernate.SessionFactory</interfacename> é um objeto global thread-safe, "
+"instanciado uma vez. "
 
 #. Tag: para
-#: tutorial.xml:436
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will create a <literal>HibernateUtil</literal> helper class that takes "
 "care of startup and makes accessing the <interfacename>org.hibernate."
 "SessionFactory</interfacename> more convenient."
 msgstr ""
-"Nos iremos criar uma classe de ajuda <literal>HibernateUtil</literal>, que "
-"toma conta do startup e faz acesso a uma <literal>SessionFactory</literal> "
-"conveniente. Vamos dar uma olhada na implementação:"
+"Criaremos uma classe de ajuda <literal>HibernateUtil</literal>, que cuida da "
+"inicialização e faz acesso a uma <interfacename>org.hibernate."
+"SessionFactory</interfacename> mais conveniente. "
 
-#. Tag: programlisting
-#: tutorial.xml:442
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.util;\n"
-"\n"
-"import org.hibernate.SessionFactory;\n"
-"import org.hibernate.cfg.Configuration;\n"
-"\n"
-"public class HibernateUtil {\n"
-"\n"
-"    private static final SessionFactory sessionFactory = buildSessionFactory"
-"();\n"
-"\n"
-"    private static SessionFactory buildSessionFactory() {\n"
-"        try {\n"
-"            // Create the SessionFactory from hibernate.cfg.xml\n"
-"            return new Configuration().configure().buildSessionFactory();\n"
-"        }\n"
-"        catch (Throwable ex) {\n"
-"            // Make sure you log the exception, as it might be swallowed\n"
-"            System.err.println(\"Initial SessionFactory creation failed.\" + "
-"ex);\n"
-"            throw new ExceptionInInitializerError(ex);\n"
-"        }\n"
-"    }\n"
-"\n"
-"    public static SessionFactory getSessionFactory() {\n"
-"        return sessionFactory;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:444
 #, no-c-format
 msgid ""
 "Save this code as <filename>src/main/java/org/hibernate/tutorial/util/"
 "HibernateUtil.java</filename>"
 msgstr ""
+"Salve este código como <filename>src/main/java/org/hibernate/tutorial/util/"
+"HibernateUtil.java</filename>"
 
 #. Tag: para
-#: tutorial.xml:449
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This class not only produces the global <interfacename>org.hibernate."
 "SessionFactory</interfacename> reference in its static initializer; it also "
@@ -937,15 +820,15 @@
 "reference from JNDI in an application server or any other location for that "
 "matter."
 msgstr ""
-"Esta classe não só produz a global <literal>SessionFactory</literal> no seu "
-"static initializer (chamado uma vez pela JVM quando a classe é carregada), "
-"mas também esconde o fato de que isto usa um static singleton. Ela pode "
-"muito bem, enxergar a <literal>SessionFactory</literal> do JNDI em um "
-"application server."
+"Esta classe não só produz uma referência <interfacename>org.hibernate."
+"SessionFactory</interfacename> global em seu inicializador estático, mas "
+"também esconde o fato de que utiliza um autônomo estático. Nós poderemos "
+"buscar pela referência <interfacename>org.hibernate.SessionFactory</"
+"interfacename> a partir do JNDI no servidor da aplicação ou qualquer outra "
+"localização para este assunto."
 
 #. Tag: para
-#: tutorial.xml:458
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you give the <interfacename>org.hibernate.SessionFactory</interfacename> "
 "a name in your configuration, Hibernate will try to bind it to JNDI under "
@@ -954,16 +837,16 @@
 "<literal>HibernateService</literal> to JNDI. Such advanced options are "
 "discussed later."
 msgstr ""
-"Se você der à <literal>SessionFactory</literal> um nome, no seu arquivo de "
-"configuração. O Hibernate irá, de fato, tentar uni-lo ao JNDI depois que "
-"estiver construído. Para evitar este completamente este código, você também "
-"poderia usar JMX deployment e deixar o contêiner JMX capaz, instanciar e "
-"unir um <literal>HibernateService</literal> no JNDI. Essas opções avançadas "
-"são discutidas no documento de referência do Hibernate."
+"Se você der um nome à <literal>SessionFactory</literal> em seu arquivo de "
+"configuração, o Hibernate irá, de fato, tentar vinculá-lo ao JNDI sob aquele "
+"nome, depois que estiver construído. Outra opção melhor seria usar a "
+"implementação JMX e deixar o recipiente JMX capaz, instanciar e vincular um "
+"<literal>HibernateService</literal> ao JNDI. Essas opções avançadas são "
+"discutidas no documento de referência do Hibernate. Tais opções avançadas "
+"serão discutidas mais tarde."
 
 #. Tag: para
-#: tutorial.xml:467
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You now need to configure a logging system. Hibernate uses commons logging "
 "and provides two choices: Log4j and JDK 1.4 logging. Most developers prefer "
@@ -974,103 +857,55 @@
 "configuration, you can change the settings. By default, only the Hibernate "
 "startup message is shown on stdout."
 msgstr ""
-"Novamente, isto deve compilar sem problemas. Finalmente, nós precisamos "
-"configurar um sistema de logging – o Hibernate usa commons logging e deixa "
-"você escolher entre o Log4j e o logging do JDK 1.4 . A maioria dos "
-"desenvolvedores preferem o Log4j: copie <literal>log4j.properties</literal> "
-"da distribuição do Hibernate (está no diretório <literal>etc/</literal>), "
-"para seu diretório <literal>src</literal>, depois vá em hibernate.cfg.xml. "
-"Dê uma olhada no exemplo de configuração e mude as configurações se você "
-"quizer ter uma saída mais detalhada. Por default, apenas as mensagems de "
-"startup e shwwn do Hibernate é mostrada no stdout."
+"Você precisará agora configurar um sistema de logging. O Hibernate usa "
+"logging comuns e lhe oferece a escolha entre o Log4j e o logging do JDK "
+"1.4 . A maioria dos desenvolvedores prefere o Log4j: copie <literal>log4j."
+"properties</literal> da distribuição do Hibernate no diretório <literal>etc/"
+"</literal>, para seu diretório <literal>src</literal>, depois vá em "
+"<literal>hibernate.cfg.xml</literal>. Dê uma olhada no exemplo de "
+"configuração e mude as configurações se você quiser ter uma saída mais "
+"detalhada. Por padrão, apenas as mensagens de inicialização do Hibernate são "
+"mostradas no stdout."
 
 #. Tag: para
-#: tutorial.xml:477
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The tutorial infrastructure is complete and you are now ready to do some "
 "real work with Hibernate."
 msgstr ""
-"O tutorial de infra-estrutura está completo - e nós já estamos preparados "
-"para algum trabalho de verdade com o Hibernate."
+"O tutorial de infra-estrutura está completo e nós já estamos preparados para "
+"algum trabalho de verdade com o Hibernate. "
 
 #. Tag: title
-#: tutorial.xml:485
 #, no-c-format
 msgid "Loading and storing objects"
 msgstr "Carregando e salvando objetos"
 
 #. Tag: para
-#: tutorial.xml:487
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We are now ready to start doing some real worjk with Hibernate. Let's start "
 "by writing an <literal>EventManager</literal> class with a <literal>main()</"
 "literal> method:"
 msgstr ""
-"Finalmente, nós podemos usar o Hibernate para carregar e armazenar objetos. "
-"Nós escrevemos uma classe <literal>EventManager</literal> com um método main"
-"():"
+"Agora estamos prontos a começar a trabalhar de verdade com o Hibernate. "
+"Vamos começar escrevendo uma classe <literal>EventManager</literal> com um "
+"método <literal>main()</literal>:"
 
-#. Tag: programlisting
-#: tutorial.xml:493
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[package org.hibernate.tutorial;\n"
-"\n"
-"import org.hibernate.Session;\n"
-"\n"
-"import java.util.*;\n"
-"\n"
-"import org.hibernate.tutorial.domain.Event;\n"
-"import org.hibernate.tutorial.util.HibernateUtil;\n"
-"\n"
-"public class EventManager {\n"
-"\n"
-"    public static void main(String[] args) {\n"
-"        EventManager mgr = new EventManager();\n"
-"\n"
-"        if (args[0].equals(\"store\")) {\n"
-"            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-"        }\n"
-"\n"
-"        HibernateUtil.getSessionFactory().close();\n"
-"    }\n"
-"\n"
-"    private void createAndStoreEvent(String title, Date theDate) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Event theEvent = new Event();\n"
-"        theEvent.setTitle(title);\n"
-"        theEvent.setDate(theDate);\n"
-"        session.save(theEvent);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:495
-#, fuzzy, no-c-format
-msgid ""
 "In <literal>createAndStoreEvent()</literal> we created a new <literal>Event</"
 "literal> object and handed it over to Hibernate. At that point, Hibernate "
 "takes care of the SQL and executes an <literal>INSERT</literal> on the "
 "database."
 msgstr ""
-"Nós criamos um novo objeto <literal>Event</literal>, e passamos para o "
-"Hibernate. O Hibernate sabe como tomar conta do SQL e executa "
-"<literal>INSERT</literal>s no banco de dados. Vamos dar uma olhada na "
-"<literal>Session</literal> e no código <literal>Transaction</literal>-"
-"handling antes de executarmos."
+"Em <literal>createAndStoreEvent()</literal>, criamos um novo objeto de "
+"<literal>Event</literal>, e passamos para o Hibernate. O Hibernate sabe como "
+"tomar conta do SQL e executa <literal>INSERT</literal>s no banco de dados. "
 
 #. Tag: para
-#: tutorial.xml:502
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <interface>org.hibernate.Session</interface> is designed to represent a "
 "single unit of work (a single atmoic piece of work to be performed). For now "
@@ -1081,17 +916,18 @@
 "interfacename> API. In this particular case we are using JDBC-based "
 "transactional semantics, but it could also run with JTA."
 msgstr ""
-"Um <literal>Session</literal> é uma unidade simples de trabalho. Por agora "
-"nós iremos pegar coisas simples e assumir uma granularidade de um-pra-um "
-"entre uma <literal>Session</literal> do Hibernate e uma transação de banco "
-"de dados. Para proteger nosso código de um atual sistema subjacente de "
-"transação (nesse caso puro JDBC, mas também poderia rodar com JTA), nos "
-"usamos a API <literal>Transaction</literal>, que está disponível na "
-"<literal>Session</literal> do Hibernate."
+"O <interface>org.hibernate.Session</interface> é designado a representar uma "
+"unidade simples de trabalho (um pedaço atômico simples de trabalho a ser "
+"executado). Nesta fase manteremos tudo muito simples e consideraremos uma "
+"granularidade de um-para-um entre um <interface>org.hibernate.Session</"
+"interface> do Hibernate e uma transação de banco de dados. Para proteger "
+"nosso código do sistema subjacente de transação, usamos o Hibernate "
+"<interfacename>org.hibernate.Transaction</interfacename> API. Neste caso em "
+"particular, nós estamos usando as semânticas transacionais baseadas o JDBC, "
+"mas isto pode rodar também com o JTA."
 
 #. Tag: para
-#: tutorial.xml:515
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What does <literal>sessionFactory.getCurrentSession()</literal> do? First, "
 "you can call it as many times and anywhere you like once you get hold of "
@@ -1103,17 +939,16 @@
 "is bound to the current Java thread that executes the application."
 msgstr ""
 "O que a <literal>sessionFactory.getCurrentSession()</literal> faz? Primeiro, "
-"você pode chamar quantas vezes e de onde quiser, uma vez você recebe sua "
-"<literal>SessionFactory</literal> (fácil graças ao <literal>HibernateUtil</"
-"literal>). O método <literal>getCurrentSession()</literal> sempre retorna a "
-"unidade de trabalho \"corrente\". Lembra de que nós mudamos a opção de "
-"configuração desse mecanismo para thread no <literal>hibernate.cfg.xml</"
-"literal>? Daqui em diante, o escopo da unidade de trabalho corrente é a "
-"thread Java corrente que executa nossa aplicação. Entretanto, esta não é "
-"toda a verdade. Uma"
+"você pode chamar quantas vezes e de onde quiser, assim que você receber sua "
+"<interfacename>org.hibernate.SessionFactory</interfacename>. O método "
+"<literal>getCurrentSession()</literal> sempre retorna à unidade de trabalho "
+"\"atual\". Você se lembra que nós mudamos a opção de configuração desse "
+"mecanismo para \"thread\" em nosso <filename>src/main/resources/hibernate."
+"cfg.xml</filename>? Devido a esta configuração, o contexto de uma unidade de "
+"trabalho atual estará vinculada à thread Java atual que executa nossa "
+"aplicação. "
 
 #. Tag: para
-#: tutorial.xml:529
 #, no-c-format
 msgid ""
 "Hibernate offers three methods of current session tracking. The \"thread\" "
@@ -1121,10 +956,13 @@
 "prototyping and tutorials such as this one. Current session tracking is "
 "discussed in more detail later on."
 msgstr ""
+"O Hibernate oferece três métodos da sessão atual. O método \"thread\" "
+"baseado não possui por interesse o uso de produção; ele é basicamente útil "
+"para prototyping e tutoriais tais como este. A sessão atual será discutida "
+"em mais detalhes mais tarde."
 
 #. Tag: para
-#: tutorial.xml:538
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <interface>org.hibernate.Session</interface> begins when the first call to "
 "<literal>getCurrentSession()</literal> is made for the current thread. It is "
@@ -1135,19 +973,17 @@
 "new <interface>org.hibernate.Session</interface> and can start a new unit of "
 "work."
 msgstr ""
-"<literal>Session</literal> começa quando é primeiramente necessária, quando "
-"é feita a primeira chamada à <literal>getCurrentSession()</literal>. É então "
-"limitado pelo Hibernate para thread corrente. Quando a transação termina, "
-"tanto com commit quanto rollback, o Hibernate também desune a "
-"<literal>Session</literal> da thread e fecha isso pra você. Se você chamar "
-"<literal>getCurrentSession()</literal> novamente, você receberá uma nova "
-"<literal>Session</literal> e pode começar uma nova unidade de trabalho. Esse "
-"modelo de programação de limite de thread <emphasis>thread-bound</emphasis>, "
-"é o modo mais popular de se usar o Hibernate."
+"Um <interface>org.hibernate.Session</interface> começa quando for "
+"necessária, quando é feita a primeira chamada à <literal>getCurrentSession()"
+"</literal>. É então limitada pelo Hibernate para a thread atual. Quando a "
+"transação termina, tanto com commit quanto rollback, o Hibernate também "
+"desvincula a <literal>Session</literal> da thread e fecha isso pra você. Se "
+"você chamar <literal>getCurrentSession()</literal> novamente, você receberá "
+"uma nova <literal>Session</literal> e poderá começar uma nova unidade de "
+"trabalho. "
 
 #. Tag: para
-#: tutorial.xml:551
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Related to the unit of work scope, should the Hibernate <interface>org."
 "hibernate.Session</interface> be used to execute one or several database "
@@ -1161,149 +997,110 @@
 "<emphasis>session-per-operation</emphasis> an anti-pattern. A real web "
 "application is shown later in the tutorial which will help illustrate this."
 msgstr ""
-"Related to the unit of work scope, should the Hibernate <literal>Session</"
-"literal> be used to execute one or several database operations? The above "
-"example uses one <literal>Session</literal> for one operation. This is pure "
-"coincidence, the example is just not complex enough to show any other "
-"approach. The scope of a Hibernate <literal>Session</literal> is flexible "
-"but you should never design your application to use a new Hibernate "
-"<literal>Session</literal> for <emphasis>every</emphasis> database "
-"operation. So even if you see it a few more times in the following (very "
-"trivial) examples, consider <emphasis>session-per-operation</emphasis> an "
-"anti-pattern. A real (web) application is shown later in this tutorial."
+"Em relação ao escopo da unidade de trabalho, o Hibernate <interface>org."
+"hibernate.Session</interface> deve ser utilizado para executar uma ou mais "
+"operações do banco de dados? O exemplo acima utiliza uma <literal>Session</"
+"literal> para cada operação. Isto é pura coincidência, o exemplo "
+"simplesmente não é complexo o bastante para mostrar qualquer outra "
+"abordagem. O escopo de um Hibernate <interface>org.hibernate.Session</"
+"interface> é flexível, mas você nunca deve configurar seu aplicativo para "
+"utilizar um novo Hibernate <interface>org.hibernate.Session</interface> para "
+"aoperação de banco de dados <emphasis>every</emphasis>. Portanto, mesmo que "
+"você o veja algumas vezes mais nos seguintes exemplos, considere "
+"<emphasis>session-per-operation</emphasis> como um anti-modelo. Um "
+"aplicativo  da web real será demonstrado mais adiante neste tutorial."
 
 #. Tag: para
-#: tutorial.xml:568
 #, fuzzy, no-c-format
 msgid ""
-"See <xref linkend=\"transactions\"/> for more information about transaction "
+"See <xref linkend=\"transactions\" /> for more information about transaction "
 "handling and demarcation. The previous example also skipped any error "
 "handling and rollback."
 msgstr ""
 "Dê uma olhada no <xref linkend=\"transactions\"/> para mais informações a "
 "respeito de manipulação de transação e demarcação. Nós também pulamos "
-"qualquer manipulação de erro e rollback no exemplo anterior."
+"qualquer manipulação de erro e rollback no exemplo anterior. "
 
 #. Tag: para
-#: tutorial.xml:574
 #, no-c-format
 msgid ""
 "To run this, we will make use of the Maven exec plugin to call our class "
 "with the necessary classpath setup: <command>mvn exec:java -Dexec.mainClass="
 "\"org.hibernate.tutorial.EventManager\" -Dexec.args=\"store\"</command>"
 msgstr ""
+"Para rodar isto, nós faremos uso do Maven exec plugin para chamar nossa "
+"classe com a instalação do classpath necessária: <command>mvn exec:java -"
+"Dexec.mainClass=\"org.hibernate.tutorial.EventManager\" -Dexec.args=\"store"
+"\"</command>"
 
 #. Tag: para
-#: tutorial.xml:581
 #, no-c-format
 msgid "You may need to perform <command>mvn compile</command> first."
-msgstr ""
+msgstr "Você precisa executar o <command>mvn compile</command> primeiramente."
 
 #. Tag: para
-#: tutorial.xml:586
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You should see Hibernate starting up and, depending on your configuration, "
 "lots of log output. Towards the end, the following line will be displayed:"
 msgstr ""
-"Você deverá ver, após a compilação, o startup do Hibernate e, dependendo da "
-"sua configuração, muito log de saída. No final você verá a seguinte linha:"
+"Você deverá ver, após a compilação, a inicialização do Hibernate e, "
+"dependendo da sua configuração, muito log de saída. No final, você verá a "
+"seguinte linha: "
 
-#. Tag: programlisting
-#: tutorial.xml:591
-#, no-c-format
-msgid ""
-"<![CDATA[[java] Hibernate: insert into EVENTS (EVENT_DATE, title, EVENT_ID) "
-"values (?, ?, ?)]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:593
 #, no-c-format
 msgid "This is the <literal>INSERT</literal> executed by Hibernate."
-msgstr ""
+msgstr "Este é o <literal>INSERT</literal> executado pelo Hibernate."
 
 #. Tag: para
-#: tutorial.xml:597
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "To list stored events an option is added to the main method:"
 msgstr ""
-"Agora nós gostaríamos de listar os eventos arquivados, então nós adicionamos "
-"uma opção para o método main:"
+"Adicionamos uma opção para o método principal com o objetivo de listar os "
+"eventos arquivados: "
 
-#. Tag: programlisting
-#: tutorial.xml:601
-#, no-c-format
-msgid ""
-"<![CDATA[        if (args[0].equals(\"store\")) {\n"
-"            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-"        }\n"
-"        else if (args[0].equals(\"list\")) {\n"
-"            List events = mgr.listEvents();\n"
-"            for (int i = 0; i < events.size(); i++) {\n"
-"                Event theEvent = (Event) events.get(i);\n"
-"                System.out.println(\n"
-"                        \"Event: \" + theEvent.getTitle() + \" Time: \" + "
-"theEvent.getDate()\n"
-"                );\n"
-"            }\n"
-"        }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:603
-#, fuzzy, no-c-format
-msgid "A new <literal>listEvents() method is also added</literal>:"
-msgstr "Nos também adicionamos um novo <literal>método listEvents()</literal>:"
-
-#. Tag: programlisting
-#: tutorial.xml:607
 #, no-c-format
-msgid ""
-"<![CDATA[    private List listEvents() {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"        List result = session.createQuery(\"from Event\").list();\n"
-"        session.getTransaction().commit();\n"
-"        return result;\n"
-"    }]]>"
+msgid "A new <literal>listEvents() method is also added</literal>:"
 msgstr ""
+"Nos também adicionamos um novo <literal>listEvents() method is also added</"
+"literal>: "
 
 #. Tag: para
-#: tutorial.xml:609
 #, fuzzy, no-c-format
 msgid ""
 "Here, we are using a Hibernate Query Language (HQL) query to load all "
 "existing <literal>Event</literal> objects from the database. Hibernate will "
 "generate the appropriate SQL, send it to the database and populate "
 "<literal>Event</literal> objects with the data. You can create more complex "
-"queries with HQL. See <xref linkend=\"queryhql\"/> for more information."
+"queries with HQL. See <xref linkend=\"queryhql\" /> for more information."
 msgstr ""
-"O que nós fazemos aqui, é usar uma query HQL (Hibernate Query Language), "
-"para carregar todos os objetos <literal>Event</literal> exitentes no banco "
-"de dados. O Hibernate irá gerar o SQL apropriado, enviar para o banco de "
-"dados e popular objetos <literal>Event</literal> com os dados. Você pode "
-"criar queries mais complexas com HQL, claro."
+"Neste caso, nós usamos uma consulta Hibernate Query LanguageHQL (HQL), para "
+"carregar todos os objetos <literal>Event</literal> existentes no banco de "
+"dados. O Hibernate irá gerar o SQL apropriado, enviar para o banco de dados "
+"e popular objetos <literal>Event</literal> com os dados. Você pode criar "
+"consultas mais complexas com HQL. Consulte <xref linkend=\"queryhql\"/> para "
+"maiores informações. "
 
 #. Tag: para
-#: tutorial.xml:617
 #, no-c-format
 msgid ""
 "Now we can call our new functionality, again using the Maven exec plugin: "
 "<command>mvn exec:java -Dexec.mainClass=\"org.hibernate.tutorial.EventManager"
 "\" -Dexec.args=\"list\"</command>"
 msgstr ""
+"Agora podemos chamar nossa nova funcionalidade usando, novamente, o Maven "
+"exec plugin: <command>mvn exec:java -Dexec.mainClass=\"org.hibernate."
+"tutorial.EventManager\" -Dexec.args=\"list\"</command>"
 
 #. Tag: title
-#: tutorial.xml:627
 #, no-c-format
 msgid "Part 2 - Mapping associations"
-msgstr "Part 2 - Mapeando associações"
+msgstr "Parte 2 - Mapeando associações "
 
 #. Tag: para
-#: tutorial.xml:629
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "So far we have mapped a single persistent entity class to a table in "
 "isolation. Let's expand on that a bit and add some class associations. We "
@@ -1311,112 +1108,63 @@
 "participate."
 msgstr ""
 "Nós mapeamos uma classe de entidade de persistência para uma tabela. Agora "
-"vamos continuar e adicionar algumas associações de classe. Primeiro nos "
-"iremos adicionar pessoas a nossa aplicação, e armazenar os eventos de que "
-"elas participam."
+"vamos continuar e adicionar algumas associações de classe. Primeiro iremos "
+"adicionar pessoas à nossa aplicação e armazenar os eventos em que elas "
+"participam. "
 
 #. Tag: title
-#: tutorial.xml:637
 #, no-c-format
 msgid "Mapping the Person class"
-msgstr "Mapeando a classe Person"
+msgstr "Mapeando a classe Person "
 
 #. Tag: para
-#: tutorial.xml:639
-#, fuzzy, no-c-format
-msgid "The first cut of the <literal>Person</literal> class looks like this:"
-msgstr "O primeiro código da classe <literal>Person</literal> é simples:"
-
-#. Tag: programlisting
-#: tutorial.xml:643
 #, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.domain;\n"
-"\n"
-"public class Person {\n"
-"\n"
-"    private Long id;\n"
-"    private int age;\n"
-"    private String firstname;\n"
-"    private String lastname;\n"
-"\n"
-"    public Person() {}\n"
-"\n"
-"    // Accessor methods for all properties, private setter for 'id'\n"
-"\n"
-"}]]>"
+msgid "The first cut of the <literal>Person</literal> class looks like this:"
 msgstr ""
+"O primeira parte da classe <literal>Person</literal> parece-se com isto: "
 
 #. Tag: para
-#: tutorial.xml:645
 #, no-c-format
 msgid ""
 "Save this to a file named <filename>src/main/java/org/hibernate/tutorial/"
 "domain/Person.java</filename>"
 msgstr ""
+"Salve isto ao arquivo nomeado <filename>src/main/java/org/hibernate/tutorial/"
+"domain/Person.java</filename>"
 
 #. Tag: para
-#: tutorial.xml:650
 #, no-c-format
 msgid ""
 "Next, create the new mapping file as <filename>src/main/resources/org/"
 "hibernate/tutorial/domain/Person.hbm.xml</filename>"
 msgstr ""
+"Após isto, crie um novo arquivo de mapeamento como <filename>src/main/"
+"resources/org/hibernate/tutorial/domain/Person.hbm.xml</filename>"
 
-#. Tag: programlisting
-#: tutorial.xml:655
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Person\" table=\"PERSON\">\n"
-"        <id name=\"id\" column=\"PERSON_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"age\"/>\n"
-"        <property name=\"firstname\"/>\n"
-"        <property name=\"lastname\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:657
 #, no-c-format
 msgid "Finally, add the new mapping to Hibernate's configuration:"
-msgstr "Finalmente, adicione o novo mapeamento a configuração do Hibernate:"
+msgstr "Finalmente, adicione o novo mapeamento à configuração do Hibernate: "
 
-#. Tag: programlisting
-#: tutorial.xml:661
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<mapping resource=\"events/Event.hbm.xml\"/>\n"
-"<mapping resource=\"events/Person.hbm.xml\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:663
-#, fuzzy, no-c-format
-msgid ""
 "Create an association between these two entities. Persons can participate in "
 "events, and events have participants. The design questions you have to deal "
 "with are: directionality, multiplicity, and collection behavior."
 msgstr ""
-"Nos iremos agora criar uma associação entre estas duas entidades. "
-"Obviamente, pessoas (Person) podem participar de eventos, e eventos possuem "
-"participantes. As questões de design com que teremos de lidar são: "
-"direcionalidade, multiplicidade e comportamento de coleção."
+"Crie agora uma associação entre estas duas entidades. As pessoas (Person) "
+"podem participar de eventos, e eventos possuem participantes. As questões de "
+"design com que teremos de lidar são: direcionalidade, multiplicidade e "
+"comportamento de coleção. "
 
 #. Tag: title
-#: tutorial.xml:673
 #, no-c-format
 msgid "A unidirectional Set-based association"
-msgstr "Uma associação Set-based unidirectional"
+msgstr "Uma associação unidirecional baseada em Configuração"
 
 #. Tag: para
-#: tutorial.xml:675
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "By adding a collection of events to the <literal>Person</literal> class, you "
 "can easily navigate to the events for a particular person, without executing "
@@ -1426,35 +1174,18 @@
 "Set</interfacename> because the collection will not contain duplicate "
 "elements and the ordering is not relevant to our examples:"
 msgstr ""
-"Nos iremos adicionar uma coleção de eventos na classe <literal>Person</"
-"literal>. Desse jeito poderemos navegar pelos eventos de uma pessoa em "
-"particular, sem executar uma query explicitamente – apenas chamando "
-"<literal>aPerson.getEvents()</literal>. Nos usaremos uma coleção Java, um "
-"<literal>Set</literal>, porquê a coleção não conterá elementos duplicados e "
-"a ordem não é relevante para nós."
+"Iremos adicionar uma coleção de eventos na classe <literal>Person</literal>. "
+"Dessa forma, poderemos navegar pelos eventos de uma pessoa em particular, "
+"sem executar uma consulta explicitamente, apenas chamando "
+"<literal>Person#getEvents</literal>. As associações de valores múltiplos são "
+"representadas no Hibernate por um dos contratos do Java Collection "
+"Framework; aqui nós escolhemos um <interfacename>java.util.Set</"
+"interfacename>, uma vez que a coleção não conterá elementos duplicados e a "
+"ordem não é relevante em nossos exemplos:"
 
-#. Tag: programlisting
-#: tutorial.xml:686
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[public class Person {\n"
-"\n"
-"    private Set events = new HashSet();\n"
-"\n"
-"    public Set getEvents() {\n"
-"        return events;\n"
-"    }\n"
-"\n"
-"    public void setEvents(Set events) {\n"
-"        this.events = events;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:688
-#, fuzzy, no-c-format
-msgid ""
 "Before mapping this association, let's consider the other side. We could "
 "just keep this unidirectional or create another collection on the "
 "<literal>Event</literal>, if we wanted to be able to navigate it from both "
@@ -1467,40 +1198,18 @@
 msgstr ""
 "Antes de mapearmos esta associação, pense no outro lado. Claramente, "
 "poderíamos apenas fazer isto de forma unidirecional. Ou poderíamos criar "
-"outra coleção no <literal>Event</literal>, se quisermos ser capaz de navegar "
-"bidirecionalmente, i.e. um - <literal>anEvent.getParticipants()</literal>. "
-"Isto não é necessário, de perspectiva funcional. Você poderia sempre "
-"executar uma query explicita que retornasse os participantes de um evento em "
-"particular. Esta é uma escolha de design que cabe a você, mas o que é claro "
-"nessa discussão é a multiplicidade da associação: \"muitos\" valores em "
-"ambos os lados, nós chamamos isto uma associação <emphasis>muitos-para-"
-"muitos</emphasis>. Daqui pra frente, nos usaremos o mapeamento muitos-para-"
-"muitos do Hibernate:"
+"outra coleção no <literal>Event</literal>, se quisermos navegar de ambas "
+"direções. Isto não é necessário, de uma perspectiva funcional. Você poderá "
+"sempre executar uma consulta explícita para recuperar os participantes de um "
+"evento em particular. Esta é uma escolha de design que cabe a você, mas o "
+"que é claro nessa discussão é a multiplicidade da associação: \"muitos\" "
+"válidos em ambos os lados, nós chamamos isto de uma associação "
+"<emphasis>muitos-para-muitos</emphasis>. Daqui pra frente, usaremos o "
+"mapeamento muitos-para-muitos do Hibernate: "
 
-#. Tag: programlisting
-#: tutorial.xml:701
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\" table=\"PERSON\">\n"
-"    <id name=\"id\" column=\"PERSON_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"age\"/>\n"
-"    <property name=\"firstname\"/>\n"
-"    <property name=\"lastname\"/>\n"
-"\n"
-"    <set name=\"events\" table=\"PERSON_EVENT\">\n"
-"        <key column=\"PERSON_ID\"/>\n"
-"        <many-to-many column=\"EVENT_ID\" class=\"Event\"/>\n"
-"    </set>\n"
-"\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:703
-#, fuzzy, no-c-format
-msgid ""
 "Hibernate supports a broad range of collection mappings, a <literal>set</"
 "literal> being most common. For a many-to-many association, or <emphasis>n:"
 "m</emphasis> entity relationship, an association table is required. Each row "
@@ -1513,81 +1222,40 @@
 "tell Hibernate the class of the objects in your collection (the class on the "
 "other side of the collection of references)."
 msgstr ""
-"O Hibernate suporta todo tipo de mapeamento de coleção , sendo um "
-"<literal>&lt;set&gt;</literal> mais comum. Para uma associação muitos-para-"
-"muitos (ou relacionamento de entidade <emphasis>n:m</emphasis> ), uma tabela "
-"de associação é necessária. Cada linha nessa tabela representa um link entre "
-"uma pessoa e um evento. O nome da tabela é configurado com o atributo "
-"<literal>table</literal> do elemento <literal>set</literal>. O nome da "
-"coluna identificadora na associção, peloo lado da pessoa, é definido com o "
-"elemento <literal>&lt;key&gt;</literal> , o nome da coluna pelo lado dos "
-"eventos, e definido com o atributo <literal>column</literal> do <literal>&lt;"
-"many-to-many&gt;</literal>. Você também precisa dizer para o Hibernate a "
-"classe dos objetos na sua coleção (a classe do outro lado das coleções de "
-"referência)."
+"O Hibernate suporta todo tipo de mapeamento de coleção, sendo um "
+"<literal>set</literal> mais comum. Para uma associação muitos-para-muitos ou "
+"relacionamento de entidade <emphasis>n:m</emphasis>, é necessária uma tabela "
+"de associação. Cada linha nessa tabela representa um link entre uma pessoa e "
+"um evento. O nome da tabela é configurado com a função <literal>table</"
+"literal> do elemento <literal>set</literal>. O nome da coluna identificadora "
+"na associação, pelo lado da pessoa, é definido com o elemento <literal>key</"
+"literal>, o nome da coluna pelo lado dos eventos, é definido com a função "
+"<literal>column</literal> do <literal>many-to-many</literal>. Você também "
+"precisa dizer para o Hibernate a classe dos objetos na sua coleção (a classe "
+"do outro lado das coleções de referência)."
 
 #. Tag: para
-#: tutorial.xml:719
 #, no-c-format
 msgid "The database schema for this mapping is therefore:"
-msgstr "O esquema de mapeamento para o banco de dados está a seguir:"
+msgstr "O esquema de mapeamento para o banco de dados está a seguir: "
 
-#. Tag: programlisting
-#: tutorial.xml:723
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"    _____________        __________________\n"
-"   |             |      |                  |       _____________\n"
-"   |   EVENTS    |      |   PERSON_EVENT   |      |             |\n"
-"   |_____________|      |__________________|      |    PERSON   |\n"
-"   |             |      |                  |      |_____________|\n"
-"   | *EVENT_ID   | <--> | *EVENT_ID        |      |             |\n"
-"   |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  |\n"
-"   |  TITLE      |      |__________________|      |  AGE        |\n"
-"   |_____________|                                |  FIRSTNAME  |\n"
-"                                                  |  LASTNAME   |\n"
-"                                                  |_____________|\n"
-" ]]>"
-msgstr ""
-
 #. Tag: title
-#: tutorial.xml:728
 #, no-c-format
 msgid "Working the association"
-msgstr "Trabalhando a associação"
+msgstr "Trabalhando a associação "
 
 #. Tag: para
-#: tutorial.xml:730
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now we will bring some people and events together in a new method in "
 "<literal>EventManager</literal>:"
 msgstr ""
-"Vamos trazer juntos algumas pessoas e eventos em um novo método na classe "
-"<literal>EventManager</literal>::"
+"Vamos reunir algumas pessoas e eventos em um novo método na classe "
+"<literal>EventManager</literal>:"
 
-#. Tag: programlisting
-#: tutorial.xml:734
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session.load(Person.class, personId);\n"
-"        Event anEvent = (Event) session.load(Event.class, eventId);\n"
-"        aPerson.getEvents().add(anEvent);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:736
-#, fuzzy, no-c-format
-msgid ""
 "After loading a <literal>Person</literal> and an <literal>Event</literal>, "
 "simply modify the collection using the normal collection methods. There is "
 "no explicit call to <literal>update()</literal> or <literal>save()</"
@@ -1605,24 +1273,21 @@
 "Após carregar um <literal>Person</literal> e um <literal>Event</literal>, "
 "simplesmente modifique a coleção usando os métodos normais de uma coleção. "
 "Como você pode ver, não há chamada explícita para <literal>update()</"
-"literal> ou <literal>save()</literal>, o Hibernate detecta automaticamente "
-"que a coleção foi modificada e necessita ser atualizada. Isso é chamado de "
-"<emphasis>checagem suja automática</emphasis>, e você também pode usá-la "
-"modificando o nome ou a data de qualquer um dos seus objetos. Assim que eles "
-"estiverem no estado <emphasis>persistent</emphasis>, ou seja, limitado por "
-"uma <literal>Session</literal> do Hibernate em particular (i.e. eles foram "
-"carregados ou salvos dentro de uma unidade de trabalho), o Hibernate "
-"monitora qualquer alteração e executa o SQL em modo de escrita em segundo "
-"plano. O processo de sincronização do estado da memória com o banco de "
-"dados, geralmente apenas no final de uma unidade de trabalho, é chamado de "
-"<emphasis>flushing</emphasis>. No nosso código, a unidade de trabalho "
-"termina com o commit da transação do banco de dados – como definido pela "
-"opção de configuração da <literal>thread</literal> da classe "
-"<literal>CurrentSessionContext</literal>."
+"literal> ou <literal>save()</literal>; o Hibernate detecta automaticamente "
+"que a coleção foi modificada e que necessita ser atualizada. Isso é chamado "
+"de <emphasis>checagem suja automática</emphasis>, e você também pode usá-la "
+"modificando o nome ou a data de qualquer um dos seus objetos. Desde que eles "
+"estejam no estado <emphasis>persistent</emphasis>, ou seja, limitado por uma "
+"<literal>Session</literal> do Hibernate em particular, o Hibernate monitora "
+"qualquer alteração e executa o SQL em modo de gravação temporária. O "
+"processo de sincronização do estado da memória com o banco de dados, "
+"geralmente apenas no final de uma unidade de trabalho, normalmente apenas no "
+"final da unidade de trabalho, é chamado de <emphasis>flushing</emphasis>. No "
+"nosso código, a unidade de trabalho termina com o commit , ou rollback, da "
+"transação do banco de dados. "
 
 #. Tag: para
-#: tutorial.xml:755
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can load person and event in different units of work. Or you can modify "
 "an object outside of a <interfacename>org.hibernate.Session</interfacename>, "
@@ -1631,67 +1296,30 @@
 "when it is detached:"
 msgstr ""
 "Você pode também querer carregar pessoas e eventos em diferentes unidades de "
-"trabalho. Ou você modifica um objeto fora de uma <literal>Session</literal>, "
-"quando não se encontra no estado persistent (se já esteve neste estado "
-"anteriormente, chamamos esse estado de <emphasis>detached</emphasis>). Você "
-"pode até mesmo modificar uma coleção quando esta se encontrar no estado "
-"detached."
+"trabalho. Ou você modifica um objeto fora de um <interfacename>org.hibernate."
+"Session</interfacename>, quando não se encontra no estado persistente (se já "
+"esteve neste estado anteriormente, chamamos esse estado de "
+"<emphasis>detached</emphasis>). Você pode até mesmo modificar uma coleção "
+"quando esta se encontrar no estado detached:"
 
-#. Tag: programlisting
-#: tutorial.xml:764
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session\n"
-"                .createQuery(\"select p from Person p left join fetch p."
-"events where p.id = :pid\")\n"
-"                .setParameter(\"pid\", personId)\n"
-"                .uniqueResult(); // Eager fetch the collection so we can use "
-"it detached\n"
-"        Event anEvent = (Event) session.load(Event.class, eventId);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"\n"
-"        // End of first unit of work\n"
-"\n"
-"        aPerson.getEvents().add(anEvent); // aPerson (and its collection) is "
-"detached\n"
-"\n"
-"        // Begin second unit of work\n"
-"\n"
-"        Session session2 = HibernateUtil.getSessionFactory()."
-"getCurrentSession();\n"
-"        session2.beginTransaction();\n"
-"        session2.update(aPerson); // Reattachment of aPerson\n"
-"\n"
-"        session2.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:766
-#, fuzzy, no-c-format
-msgid ""
 "The call to <literal>update</literal> makes a detached object persistent "
 "again by binding it to a new unit of work, so any modifications you made to "
 "it while detached can be saved to the database. This includes any "
 "modifications (additions/deletions) you made to a collection of that entity "
 "object."
 msgstr ""
-"A chamada <literal>update</literal> cria um objeto persistent novamente, "
-"você poderia dizer que ele liga o objeto a uma nova unidade de trabalho, "
-"assim qualquer modificação que você faça neste objeto enquanto estiver no "
-"estado detached pode ser salvo no banco de dados. Isso inclui qualquer "
+"A chamada <literal>update</literal> cria um objeto persistente novamente, "
+"pode-se dizer que ele liga o objeto a uma nova unidade de trabalho, assim "
+"qualquer modificação que você faça neste objeto enquanto estiver no estado "
+"desanexado pode ser salvo no banco de dados. Isso inclui qualquer "
 "modificação (adição/exclusão) que você faça em uma coleção da entidade deste "
-"objeto."
+"objeto.  "
 
 #. Tag: para
-#: tutorial.xml:775
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is not much use in our example, but it is an important concept you can "
 "incorporate into your own application. Complete this exercise by adding a "
@@ -1700,32 +1328,17 @@
 "an event - the <literal>save()</literal> method returns it (you might have "
 "to modify some of the previous methods to return that identifier):"
 msgstr ""
-"Bom, isso não foi muito usado na nossa situação, porém, é um importante "
-"conceito que você pode aplicar em seus aplicativos. Agora, complete este "
-"exercício adicionando uma nova ação ao método main( ) da classe "
-"<literal>EventManager</literal> e chame-o pela linha de comando. Se você "
-"precisar dos identificadores de uma pessoa ou evento – o método <literal>save"
-"()</literal> retorna estes identificadores (você poderá modificar alguns dos "
-"métodos anteriores para retornar aquele identificador):"
+"Bem, isso não é de grande utilidade na nossa situação atual, porém, é um "
+"importante conceito que você pode criar em seu próprio aplicativo. No "
+"momento, complete este exercício adicionando uma ação ao método principal da "
+"classe <literal>EventManager</literal> e chame-o pela linha de comando. Se "
+"você precisar dos identificadores de uma pessoa ou evento - o método "
+"<literal>save()</literal> retornará estes identificadores (você poderá "
+"modificar alguns dos métodos anteriores para retornar aquele identificador): "
 
-#. Tag: programlisting
-#: tutorial.xml:783
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[        else if (args[0].equals(\"addpersontoevent\")) {\n"
-"            Long eventId = mgr.createAndStoreEvent(\"My Event\", new Date"
-"());\n"
-"            Long personId = mgr.createAndStorePerson(\"Foo\", \"Bar\");\n"
-"            mgr.addPersonToEvent(personId, eventId);\n"
-"            System.out.println(\"Added person \" + personId + \" to event \" "
-"+ eventId);\n"
-"        }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:785
-#, fuzzy, no-c-format
-msgid ""
 "This is an example of an association between two equally important classes : "
 "two entities. As mentioned earlier, there are other classes and types in a "
 "typical model, usually \"less important\". Some you have already seen, like "
@@ -1740,82 +1353,55 @@
 "fact, in a Hibernate application all JDK classes are considered value types."
 msgstr ""
 "Este foi um exemplo de uma associação entre duas classes igualmente "
-"importantes, duas entidades. Como mencionado anteriormente, há outras "
+"importantes: duas entidades. Como mencionado anteriormente, há outras "
 "classes e tipos dentro de um modelo típico, geralmente \"menos importante\". "
 "Alguns você já viu, como um <literal>int</literal> ou uma <literal>String</"
-"literal>. Nós chamamos essas classes de <emphasis>value types</emphasis>, e "
-"suas instâncias <emphasis>depend</emphasis> de uma entidade particular. As "
-"instâncias desses tipos não possuem sua própria identidade, nem são "
-"compartilhados entre entidades (duas pessoas não referenciam o mesmo objeto "
-"<literal>firstname</literal> mesmo se elas tiverem o mesmo objeto "
-"firstname). Naturalmente, os value types não são apenas encontrados dentro "
-"da JDK (de fato, em um aplicativo Hibernate todas as classes JDK são "
-"consideradas como value types), mas você pode também criar suas classes "
-"como, por exemplo, <literal>Address</literal> ou <literal>MonetaryAmount</"
-"literal>."
+"literal>. Nós chamamos essas classes de <emphasis>tipos de valores</"
+"emphasis>, e suas instâncias <emphasis>dependem</emphasis> de uma entidade "
+"particular. As instâncias desses tipos não possuem sua própria identidade, "
+"nem são compartilhados entre entidades. Duas pessoas não referenciam o mesmo "
+"objeto <literal>firstname</literal> mesmo se elas tiverem o mesmo objeto "
+"firstname. Naturalmente, os tipos de valores não são apenas encontrados "
+"dentro da JDK, mas você pode também criar suas classes como, por exemplo, "
+"<literal>Address</literal> ou <literal>MonetaryAmount</literal>. De fato, no "
+"aplicativo Hibernate todas as classes JDK são consideradas tipos de valores."
 
 #. Tag: para
-#: tutorial.xml:803
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also design a collection of value types. This is conceptually "
 "different from a collection of references to other entities, but looks "
 "almost the same in Java."
 msgstr ""
-"Você também pode criar uma coleção de value types. Isso é conceitualmente "
-"muito diferente de uma coleção de referências para outras entidades, mas em "
-"Java parece ser quase a mesma coisa."
+"Você também pode criar uma coleção de tipo de valores. Isso é "
+"conceitualmente muito diferente de uma coleção de referências para outras "
+"entidades, mas em Java parece ser quase a mesma coisa.  "
 
 #. Tag: title
-#: tutorial.xml:812
 #, no-c-format
 msgid "Collection of values"
-msgstr "Coleção de valores"
+msgstr "Coleção de valores "
 
 #. Tag: para
-#: tutorial.xml:814
 #, no-c-format
 msgid ""
 "Let's add a collection of email addresses to the <literal>Person</literal> "
 "entity. This will be represented as a <interfacename>java.util.Set</"
 "interfacename> of <classname>java.lang.String</classname> instances:"
 msgstr ""
+"Vamos adicionar uma coleção de endereços de e-mail à entidade "
+"<literal>Person</literal>. Isto será representado como um "
+"<interfacename>java.util.Set</interfacename> das instâncias <classname>java."
+"lang.String</classname>:"
 
-#. Tag: programlisting
-#: tutorial.xml:820
-#, no-c-format
-msgid ""
-"<![CDATA[    private Set emailAddresses = new HashSet();\n"
-"\n"
-"    public Set getEmailAddresses() {\n"
-"        return emailAddresses;\n"
-"    }\n"
-"\n"
-"    public void setEmailAddresses(Set emailAddresses) {\n"
-"        this.emailAddresses = emailAddresses;\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:822
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The mapping of this <literal>Set</literal> is as follows:"
-msgstr "O mapeamento deste <literal>Set</literal>:"
+msgstr "Segue abaixo o mapeamento deste <literal>Set</literal>: "
 
-#. Tag: programlisting
-#: tutorial.xml:826
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[        <set name=\"emailAddresses\" table=\"PERSON_EMAIL_ADDR\">\n"
-"            <key column=\"PERSON_ID\"/>\n"
-"            <element type=\"string\" column=\"EMAIL_ADDR\"/>\n"
-"        </set>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:828
-#, fuzzy, no-c-format
-msgid ""
 "The difference compared with the earlier mapping is the use of the "
 "<literal>element</literal> part which tells Hibernate that the collection "
 "does not contain references to another entity, but is rather a collection "
@@ -1829,184 +1415,102 @@
 "address values will actually be stored."
 msgstr ""
 "A diferença comparada com o mapeamento anterior se encontra na parte "
-"<literal>element</literal>, que indica ao Hibernate que a coleção não contém "
-"referências à outra entidade, mas uma coleção de elementos do tipo "
-"<literal>String</literal> (a tag name em miniscula indica que se trata de um "
-"mapeamento do Hibernate para conversão de tipos). Mais uma vez, o atributo "
+"<literal>element</literal>, que informa ao Hibernate que a coleção não "
+"contém referências à outra entidade, mas uma coleção de elementos do tipo "
+"<literal>String</literal>. O nome da tag em minúsculo indica que se trata de "
+"um tipo/conversor de mapeamento do Hibernate. Mais uma vez, a função "
 "<literal>table</literal> do elemento <literal>set</literal> determina o nome "
 "da tabela para a coleção. O elemento <literal>key</literal> define o nome da "
-"coluna de chave estrangeira na tabela de coleção. O atributo "
-"<literal>column</literal> dentro do elemento <literal>element</literal> "
-"define o nome da coluna onde os valores da <literal>String</literal> serão "
-"armazenados."
+"coluna de chave estrangeira na tabela de coleção. A função <literal>column</"
+"literal> dentro do elemento <literal>element</literal> define o nome da "
+"coluna onde os valores da <literal>String</literal> serão armazenados.  "
 
 #. Tag: para
-#: tutorial.xml:844
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is the updated schema:"
-msgstr "Dê uma olhada no esquema atualizado:"
+msgstr "Segue abaixo o esquema atualizado:  "
 
-#. Tag: programlisting
-#: tutorial.xml:848
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"  _____________        __________________\n"
-" |             |      |                  |       _____________\n"
-" |   EVENTS    |      |   PERSON_EVENT   |      |             |       "
-"___________________\n"
-" |_____________|      |__________________|      |    PERSON   |      "
-"|                   |\n"
-" |             |      |                  |      |_____________|      | "
-"PERSON_EMAIL_ADDR |\n"
-" | *EVENT_ID   | <--> | *EVENT_ID        |      |             |      |"
-"___________________|\n"
-" |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  | <--> |  "
-"*PERSON_ID       |\n"
-" |  TITLE      |      |__________________|      |  AGE        |      |  "
-"*EMAIL_ADDR      |\n"
-" |_____________|                                |  FIRSTNAME  |      |"
-"___________________|\n"
-"                                                |  LASTNAME   |\n"
-"                                                |_____________|\n"
-" ]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:850
-#, fuzzy, no-c-format
-msgid ""
 "You can see that the primary key of the collection table is in fact a "
 "composite key that uses both columns. This also implies that there cannot be "
 "duplicate email addresses per person, which is exactly the semantics we need "
 "for a set in Java."
 msgstr ""
-"Você pode observar que a chave primária da tabela da coleção é de na verdade "
-"uma chave composta, usando ambas colunas. Isso também implica que cada "
+"Você pode observar que a chave primária da tabela da coleção é na verdade "
+"uma chave composta, usando as duas colunas. Isso também implica que cada "
 "pessoa não pode ter endereços de e-mail duplicados, o que é exatamente a "
-"semântica que precisamos para um set em Java."
+"semântica que precisamos para um set em Java.  "
 
 #. Tag: para
-#: tutorial.xml:856
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can now try to add elements to this collection, just like we did before "
 "by linking persons and events. It is the same code in Java:"
 msgstr ""
-"Você pode agora tentar adicionar elementos a essa coleção, do mesmo modo que "
-"fizemos anteriormente ligando pessoas e eventos. È o mesmo código em Java:"
+"Você pode agora tentar adicionar elementos à essa coleção, do mesmo modo que "
+"fizemos anteriormente ligando pessoas e eventos. É o mesmo código em Java:  "
 
-#. Tag: programlisting
-#: tutorial.xml:861
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    private void addEmailToPerson(Long personId, String "
-"emailAddress) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session.load(Person.class, personId);\n"
-"        // adding to the emailAddress collection might trigger a lazy load "
-"of the collection\n"
-"        aPerson.getEmailAddresses().add(emailAddress);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:863
-#, fuzzy, no-c-format
-msgid ""
 "This time we did not use a <emphasis>fetch</emphasis> query to initialize "
 "the collection. Monitor the SQL log and try to optimize this with an eager "
 "fetch."
 msgstr ""
-"This time we didnt' use a <emphasis>fetch</emphasis> query to initialize the "
-"collection. Hence, the call to its getter method will trigger an additional "
-"select to initialize it, so we can add an element to it. Monitor the SQL log "
-"and try to optimize this with an eager fetch."
+"Desta vez não utilizamos uma consulta <emphasis>fetch</emphasis> (busca) "
+"para inicializar a coleção. Monitore o log SQL e tente otimizá-lo com árdua "
+"busca. "
 
 #. Tag: title
-#: tutorial.xml:872
 #, no-c-format
 msgid "Bi-directional associations"
-msgstr "Associações bidirecionais"
+msgstr "Associações bidirecionais "
 
 #. Tag: para
-#: tutorial.xml:874
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next you will map a bi-directional association. You will make the "
 "association between person and event work from both sides in Java. The "
 "database schema does not change, so you will still have many-to-many "
 "multiplicity."
 msgstr ""
-"Agora iremos mapear uma associação bidirecional – fazendo a associação entre "
-"pessoas e eventos, de ambos os lados, em Java. Logicamente, o esquema do "
-"banco de dados não muda, nós continuamos tendo multiplicidades muitos-para-"
-"muitos. Um banco de dados é mais flexível do que uma linguagem de "
-"programação para redes, ele não precisa de nenhuma direção de navegação – os "
-"dados podem ser acessados em qualquer caminho possível."
+"Agora iremos mapear uma associação bidirecional. Você fará uma associação "
+"entre o trabalho person e event de ambos os lados em Java. O esquema do "
+"banco de dados acima não muda, de forma que você continua possuir a "
+"multiplicidade muitos-para-muitos. "
 
 #. Tag: para
-#: tutorial.xml:882
 #, no-c-format
 msgid ""
 "A relational database is more flexible than a network programming language, "
 "in that it does not need a navigation direction; data can be viewed and "
 "retrieved in any possible way."
 msgstr ""
+"Um banco de dados relacional é mais flexível que um linguagem de programação "
+"da rede, de maneira que ele não precisa de uma direção de navegação; os "
+"dados podem ser visualizados e restaurados de qualquer maneira."
 
 #. Tag: para
-#: tutorial.xml:890
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, add a collection of participants to the <literal>Event</literal> "
 "class:"
 msgstr ""
 "Primeiramente, adicione uma coleção de participantes à classe "
-"<literal>Event</literal>:"
+"<literal>Event</literal>:  "
 
-#. Tag: programlisting
-#: tutorial.xml:895
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    private Set participants = new HashSet();\n"
-"\n"
-"    public Set getParticipants() {\n"
-"        return participants;\n"
-"    }\n"
-"\n"
-"    public void setParticipants(Set participants) {\n"
-"        this.participants = participants;\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:897
-#, fuzzy, no-c-format
-msgid ""
 "Now map this side of the association in <literal>Event.hbm.xml</literal>."
 msgstr ""
-"Agora mapeie este lado da associação em <literal>Event.hbm.xml</literal>."
+"Agora mapeie este lado da associação em <literal>Event.hbm.xml</literal>. "
 
-#. Tag: programlisting
-#: tutorial.xml:901
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[        <set name=\"participants\" table=\"PERSON_EVENT\" inverse="
-"\"true\">\n"
-"            <key column=\"EVENT_ID\"/>\n"
-"            <many-to-many column=\"PERSON_ID\" class=\"events.Person\"/>\n"
-"        </set>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:903
-#, fuzzy, no-c-format
-msgid ""
 "These are normal <literal>set</literal> mappings in both mapping documents. "
 "Notice that the column names in <literal>key</literal> and <literal>many-to-"
 "many</literal> swap in both mapping documents. The most important addition "
@@ -2014,37 +1518,34 @@
 "<literal>set</literal> element of the <literal>Event</literal>'s collection "
 "mapping."
 msgstr ""
-"Como você pode ver, esses é uma mapeamento normal usando <literal>set</"
-"literal> em ambos documenentos de mapeamento. Observe que o nome das colunas "
-"em <literal>key</literal> e <literal>many-to-many</literal> estão trocados "
-"em ambos os documentos de mapeamento. A adição mais importante feita está no "
-"atributo <literal>inverse=\"true\"</literal> no elemento set do mapeamento "
-"da coleção da classe <literal>Event</literal>."
+"Como você pode ver, esses são mapeamentos <literal>set</literal> normais em "
+"ambos documentos de mapeamento. Observe que os nomes das colunas em "
+"<literal>key</literal> e <literal>many-to-many</literal> estão trocados em "
+"ambos os documentos de mapeamento. A adição mais importante feita está na "
+"função <literal>inverse=\"true\"</literal> no elemento <literal>set</"
+"literal> da coleção da classe <literal>Event</literal>. "
 
 #. Tag: para
-#: tutorial.xml:911
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What this means is that Hibernate should take the other side, the "
 "<literal>Person</literal> class, when it needs to find out information about "
 "the link between the two. This will be a lot easier to understand once you "
 "see how the bi-directional link between our two entities is created."
 msgstr ""
-"Isso significa que o Hibernate deve pegar o outro lado – a classe "
-"<literal>Person</literal> – quando necessitar encontrar informação sobre a "
-"relação entre as duas entidades. Isso será muito mais facilmente "
-"compreendido quando você analisar como a relação bidirecional entre as "
-"entidades é criada."
+"Isso significa que o Hibernate deve pegar o outro lado, a classe "
+"<literal>Person</literal>, quando precisar encontrar informação sobre a "
+"relação entre as duas entidades. Isso será muito mais fácil de entender "
+"quando você analisar como a relação bidirecional entre as entidades é "
+"criada. "
 
 #. Tag: title
-#: tutorial.xml:920
 #, no-c-format
 msgid "Working bi-directional links"
-msgstr "Trabalhando com links bidirecionais"
+msgstr "Trabalhando com links bidirecionais "
 
 #. Tag: para
-#: tutorial.xml:922
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, keep in mind that Hibernate does not affect normal Java semantics. "
 "How did we create a link between a <literal>Person</literal> and an "
@@ -2056,68 +1557,41 @@
 "literal>. This process of \"setting the link on both sides\" is absolutely "
 "necessary with bi-directional links."
 msgstr ""
-"Primeiro tenha em mente que o Hibernate não afeta a semântica normal do "
-"Java. Como nós criamos um link entre uma <literal>Person</literal> e um "
-"<literal>Event</literal> no exemplo unidirecional? Nós adicionamos uma "
-"instância de <literal>Event</literal>, da coleção de referências de eventos, "
-"a uma instância de <literal>Person</literal>. Então, obviamente, se nós "
-"queremos que este link funcione bidirecionalmente, nós devemos fazer a mesma "
-"coisa para o outro lado – adicionando uma referência de <literal>Person</"
-"literal> na coleção de um <literal>Event</literal>. Esse acerto de link de "
-"ambos os lados é absolutamente necessário e você nunca deve esquecer de faze-"
-"lo."
+"Primeiro, tenha em mente que o Hibernate não afeta a semântica normal do "
+"Java. Como foi que criamos um link entre uma <literal>Person</literal> e um "
+"<literal>Event</literal> no exemplo unidirecional? Adicionamos uma instância "
+"de <literal>Event</literal>, da coleção de referências de eventos, à uma "
+"instância de <literal>Person</literal>. Então, obviamente, se quisermos que "
+"este link funcione bidirecionalmente, devemos fazer a mesma coisa para o "
+"outro lado, adicionando uma referência de <literal>Person</literal> na "
+"coleção de um <literal>Event</literal>. Essa \"configuração de link de ambos "
+"os lados\" é absolutamente necessária e você nunca deve esquecer de fazê-la. "
 
 #. Tag: para
-#: tutorial.xml:932
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Many developers program defensively and create link management methods to "
 "correctly set both sides (for example, in <literal>Person</literal>):"
 msgstr ""
-"Muitos desenvolvedores programam de maneira defensiva e criam métodos "
-"gerenciador de associações que ajusta corretamente ambos os lados:"
+"Muitos desenvolvedores programam de maneira defensiva e criam métodos de "
+"gerenciamento de um link que ajustam-se corretamente em ambos os lados (como "
+"por exemplo, em <literal>Person</literal>): "
 
-#. Tag: programlisting
-#: tutorial.xml:937
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    protected Set getEvents() {\n"
-"        return events;\n"
-"    }\n"
-"\n"
-"    protected void setEvents(Set events) {\n"
-"        this.events = events;\n"
-"    }\n"
-"\n"
-"    public void addToEvent(Event event) {\n"
-"        this.getEvents().add(event);\n"
-"        event.getParticipants().add(this);\n"
-"    }\n"
-"\n"
-"    public void removeFromEvent(Event event) {\n"
-"        this.getEvents().remove(event);\n"
-"        event.getParticipants().remove(this);\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:939
-#, fuzzy, no-c-format
-msgid ""
 "The get and set methods for the collection are now protected. This allows "
 "classes in the same package and subclasses to still access the methods, but "
 "prevents everybody else from altering the collections directly. Repeat the "
 "steps for the collection on the other side."
 msgstr ""
-"Observe que os métodos set e get da a coleção estão protegidos – isso "
-"permite que classes e subclasses do mesmo pacote continuem acessando os "
-"métodos, mas previne que qualquer outra classe, que não esteja no mesmo "
-"pacote, acesse a coleção diretamente. Você provavelmente deve fazer a mesma "
-"coisa para a coleção do outro lado."
+"Observe que os métodos set e get da coleção estão protegidos. Isso permite "
+"que classes e subclasses do mesmo pacote continuem acessando os métodos, mas "
+"evita que qualquer outra classe, que não esteja no mesmo pacote, acesse a "
+"coleção diretamente. Repita os passos para a coleção do outro lado.  "
 
 #. Tag: para
-#: tutorial.xml:946
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What about the <literal>inverse</literal> mapping attribute? For you, and "
 "for Java, a bi-directional link is simply a matter of setting the references "
@@ -2132,32 +1606,30 @@
 "as <literal>inverse</literal>. In a one-to-many association it has to be the "
 "many-side, and in many-to-many association you can select either side."
 msgstr ""
-"E sobre o mapeamento do atributo <literal>inverse</literal>? Pra você, e "
-"para o Java, um link bidirecional é simplesmente o fato de ajustar "
-"corretamente as referências de ambos os lados. O Hibernate, entretanto não "
-"possui informação necessária para corretamente adaptar os estados "
-"<literal>INSERT</literal> e <literal>UPDATE</literal> do SQL, e precisa de "
-"ajuda para manipular as propriedades das associações bidirecionais. Fazer um "
-"lado da associação com o atributo <literal>inverse</literal> instrui o "
-"Hibernate para basicamente ignora-lo, considerando-o uma <emphasis>cópia</"
-"emphasis> do outro lado. Isso é todo o necessário para o Hibernate trabalhar "
-"com todas as possibilidades quando transformando um modelo de navegação "
-"bidirecional em esquema de banco de dados do SQL. As regras que você possui "
-"para lembrar são diretas: Todas associações bidirecionais necessitam que um "
-"lado possua o atributo inverse. Em uma associação de um-para-muitos, o lado "
-"de \"muitos\" deve conter o atributo <literal>inverse</literal>, já em uma "
-"associação de muitos-para-muitos você pode pegar qualquer lado, não há "
-"diferença."
+"E sobre o mapeamento da função <literal>inverse</literal>? Para você, e para "
+"o Java, um link bidirecional é simplesmente uma questão de configurar "
+"corretamente as referências de ambos os lados. O Hibernate, entretanto, não "
+"possui informação necessária para ajustar corretamente as instruções "
+"<literal>INSERT</literal> e <literal>UPDATE</literal> do SQL (para evitar "
+"violações de restrição) e precisa de ajuda para manipular as associações "
+"bidirecionais de forma apropriada. Ao fazer um lado da associação com a "
+"função <literal>inverse</literal>, você instrui o Hibernate para basicamente "
+"ignorá-lo, considerando-o uma <emphasis>cópia</emphasis> do outro lado. Isso "
+"é o necessário para o Hibernate compreender todas as possibilidades quando "
+"transformar um modelo de navegação bidirecional em esquema de banco de dados "
+"do SQL. As regras que você precisa lembrar são diretas: todas as associações "
+"bidirecionais necessitam que um lado possua a função <literal>inverse</"
+"literal>. Em uma associação de um-para-muitos, precisará ser o lado de "
+"\"muitos\", já em uma associação de muitos-para-muitos você poderá "
+"selecionar qualquer lado. "
 
 #. Tag: title
-#: tutorial.xml:962
 #, no-c-format
 msgid "Part 3 - The EventManager web application"
-msgstr "EventManager um aplicativo para internet"
+msgstr "EventManager um aplicativo da web"
 
 #. Tag: para
-#: tutorial.xml:964
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A Hibernate web application uses <literal>Session</literal> and "
 "<literal>Transaction</literal> almost like a standalone application. "
@@ -2165,85 +1637,40 @@
 "<literal>EventManagerServlet</literal>. This servlet can list all events "
 "stored in the database, and it provides an HTML form to enter new events."
 msgstr ""
-"Um aplicativo para internet do Hibernate usa uma <literal>Session</literal> "
-"e uma <literal>Transaction</literal> quase do mesmo modo que um aplicativo "
-"standalone. Entretanto, alguns patterns comuns são úteis. Nós agora "
-"criaremos um <literal>EventManagerServlet</literal>. Esse servlet lista "
-"todos os eventos salvos no banco de dados, e cria um formulário HTML para "
-"entrada de novos eventos."
+"Um aplicativo de web do Hibernate utiliza uma <literal>Session</literal> e "
+"uma <literal>Transaction</literal> quase do mesmo modo que um aplicativo "
+"autônomo. Entretanto, alguns modelos comuns são úteis. Nós agora criaremos "
+"um <literal>EventManagerServlet</literal>. Esse servlet lista todos os "
+"eventos salvos no banco de dados, e cria um formulário HTML para entrada de "
+"novos eventos. "
 
 #. Tag: title
-#: tutorial.xml:972
 #, no-c-format
 msgid "Writing the basic servlet"
-msgstr "Criando um servlet básico"
+msgstr "Criando um servlet básico "
 
 #. Tag: para
-#: tutorial.xml:974
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First we need create our basic processing servlet. Since our servlet only "
 "handles HTTP <literal>GET</literal> requests, we will only implement the "
 "<literal>doGet()</literal> method:"
 msgstr ""
-"O servlet manuseia somente requisições <literal>GET</literal> do HTTP, "
-"portanto o método que iremos implementar é <literal>doGet()</literal>:"
+"Nós deveremos criar o nosso servket de processamento básico primeiramente. "
+"Uma vez que o servlet manuseia somente requisições <literal>GET</literal> do "
+"HTTP, o método que iremos implementar é <literal>doGet()</literal>: "
 
-#. Tag: programlisting
-#: tutorial.xml:980
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.web;\n"
-"\n"
-"// Imports\n"
-"\n"
-"public class EventManagerServlet extends HttpServlet {\n"
-"\n"
-"    protected void doGet(\n"
-"            HttpServletRequest request,\n"
-"            HttpServletResponse response) throws ServletException, "
-"IOException {\n"
-"\n"
-"        SimpleDateFormat dateFormatter = new SimpleDateFormat( \"dd.MM.yyyy"
-"\" );\n"
-"\n"
-"        try {\n"
-"            // Begin unit of work\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"beginTransaction();\n"
-"\n"
-"            // Process request and render page...\n"
-"\n"
-"            // End unit of work\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"getTransaction().commit();\n"
-"        }\n"
-"        catch (Exception ex) {\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"getTransaction().rollback();\n"
-"            if ( ServletException.class.isInstance( ex ) ) {\n"
-"                throw ( ServletException ) ex;\n"
-"            }\n"
-"            else {\n"
-"                throw new ServletException( ex );\n"
-"            }\n"
-"        }\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:982
 #, no-c-format
 msgid ""
 "Save this servlet as <filename>src/main/java/org/hibernate/tutorial/web/"
 "EventManagerServlet.java</filename>"
 msgstr ""
+"Salve esse servlet como <filename>src/main/java/org/hibernate/tutorial/web/"
+"EventManagerServlet.java</filename>"
 
 #. Tag: para
-#: tutorial.xml:987
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The pattern applied here is called <emphasis>session-per-request</emphasis>. "
 "When a request hits the servlet, a new Hibernate <literal>Session</literal> "
@@ -2252,16 +1679,15 @@
 "started. All data access occurs inside a transaction irrespective of whether "
 "the data is read or written. Do not use the auto-commit mode in applications."
 msgstr ""
-"O pattern que estamos aplicando neste código é chamado <emphasis>session-per-"
-"request</emphasis>. Quando uma requisição chega ao servlet, uma nova "
+"O modelo que estamos aplicando neste código é chamado <emphasis>session-per-"
+"request</emphasis>. Quando uma solicitação chega ao servlet, uma nova "
 "<literal>Session</literal> do Hibernate é aberta através da primeira chamada "
 "para <literal>getCurrentSession()</literal> em <literal>SessionFactory</"
-"literal>. Então uma transação do banco de dados é inicializada - todo acesso "
+"literal>. Então uma transação do banco de dados é inicializada e todo acesso "
 "a dados deve ocorrer dentro de uma transação, não importando se o dado é de "
-"leitura ou escrita. (nós não devemos usar o modo auto-commit em aplicações)."
+"leitura ou escrita. Não se deve utilizar o modo auto-commit em aplicações. "
 
 #. Tag: para
-#: tutorial.xml:996
 #, no-c-format
 msgid ""
 "Do <emphasis>not</emphasis> use a new Hibernate <literal>Session</literal> "
@@ -2269,24 +1695,23 @@
 "that is scoped to the whole request. Use <literal>getCurrentSession()</"
 "literal>, so that it is automatically bound to the current Java thread."
 msgstr ""
-"Do <emphasis>not</emphasis> use a new Hibernate <literal>Session</literal> "
-"for every database operation. Use one Hibernate <literal>Session</literal> "
-"that is scoped to the whole request. Use <literal>getCurrentSession()</"
-"literal>, so that it is automatically bound to the current Java thread."
+"<emphasis>Nunca</emphasis> utilize uma nova <literal>Session</literal> do "
+"Hibernate para todas as operações de banco de dados. Utilize uma "
+"<literal>Session</literal> do Hibernate que seja de interesse à todas as "
+"solicitações. Utilize <literal>getCurrentSession()</literal>, para que seja "
+"vinculado automaticamente à thread atual de Java.  "
 
 #. Tag: para
-#: tutorial.xml:1003
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next, the possible actions of the request are processed and the response "
 "HTML is rendered. We will get to that part soon."
 msgstr ""
-"Agora, as possibilidades de ações de uma requisição serão processadas e uma "
-"resposta HTML será renderizada. Nós já iremos chegar nesta parte."
+"Agora, as possíveis ações de uma solicitação serão processadas e uma "
+"resposta HTML será renderizada. Já chegaremos nesta parte.  "
 
 #. Tag: para
-#: tutorial.xml:1008
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, the unit of work ends when processing and rendering are complete. "
 "If any problems occurred during processing or rendering, an exception will "
@@ -2298,70 +1723,31 @@
 "as you consider rendering your view in JSP, not in a servlet."
 msgstr ""
 "Finalmente, a unidade de trabalho termina quando o processamento e a "
-"restituição são completados. Se ocorrer algum erro durante o processamento "
-"ou a restituição, uma exceção será lançada e a transação do banco de dados "
-"encerrada. Isso completa o pattern <literal>session-per-request</literal>. "
-"Em vez de usar código de demarcação de transação em todo servlet você pode "
-"também criar um filtro servlet. Dê uma olhada no site do Hibernate e do Wiki "
-"para maiores informações sobre esse pattern, chamado <emphasis>Open Session "
-"in View</emphasis>."
+"renderização são completados. Se ocorrer algum erro durante o processamento "
+"ou a renderização, uma exceção será lançada e a transação do banco de dados "
+"revertida. Isso completa o modelo <literal>session-per-request</literal>. Em "
+"vez de usar código de demarcação de transação em todo servlet você pode "
+"também criar um filtro servlet. Dê uma olhada no website do Hibernate e do "
+"Wiki para maiores informações sobre esse modelo, chamado <emphasis>Sessão "
+"Aberta na Visualização</emphasis>. Você precisará disto assim que você "
+"considerar renderizar sua visualização no JSP, não apenas num servlet. "
 
 #. Tag: title
-#: tutorial.xml:1022
 #, no-c-format
 msgid "Processing and rendering"
 msgstr "Processando e renderizando"
 
 #. Tag: para
-#: tutorial.xml:1024
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now you can implement the processing of the request and the rendering of the "
 "page."
 msgstr ""
-"Vamos implementar o processamento da requisição e a restituição da página "
-"HTML."
+"Vamos implementar o processamento da solicitação e renderização da página. "
 
-#. Tag: programlisting
-#: tutorial.xml:1028
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[        // Write HTML header\n"
-"        PrintWriter out = response.getWriter();\n"
-"        out.println(\"<html><head><title>Event Manager</title></head><body>"
-"\");\n"
-"\n"
-"        // Handle actions\n"
-"        if ( \"store\".equals(request.getParameter(\"action\")) ) {\n"
-"\n"
-"            String eventTitle = request.getParameter(\"eventTitle\");\n"
-"            String eventDate = request.getParameter(\"eventDate\");\n"
-"\n"
-"            if ( \"\".equals(eventTitle) || \"\".equals(eventDate) ) {\n"
-"                out.println(\"<b><i>Please enter event title and date.</i></"
-"b>\");\n"
-"            }\n"
-"            else {\n"
-"                createAndStoreEvent(eventTitle, dateFormatter.parse"
-"(eventDate));\n"
-"                out.println(\"<b><i>Added event.</i></b>\");\n"
-"            }\n"
-"        }\n"
-"\n"
-"        // Print page\n"
-"       printEventForm(out);\n"
-"       listEvents(out, dateFormatter);\n"
-"\n"
-"       // Write HTML footer\n"
-"       out.println(\"</body></html>\");\n"
-"       out.flush();\n"
-"       out.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:1030
-#, fuzzy, no-c-format
-msgid ""
 "This coding style, with a mix of Java and HTML, would not scale in a more "
 "complex application&mdash;keep in mind that we are only illustrating basic "
 "Hibernate concepts in this tutorial. The code prints an HTML header and a "
@@ -2369,102 +1755,36 @@
 "events in the database are printed. The first method is trivial and only "
 "outputs HTML:"
 msgstr ""
-"O estilo de código acima, misturando linguagem HTML e Java não será "
-"funcional em um aplicativo mais complexo&mdash;tenha em mente que neste "
-"manual nós estamos apenas ilustrando conceitos básicos do Hibernate. O "
-"código imprime um cabeçalho HTML e um rodapé. Dentro desta página, é "
-"mostrado um formulário em HTML, para entrada de novos eventos, e uma lista "
-"de todos os eventos contidos no banco de dados. O primeiro método é trivial "
-"e apenas imprime uma página HTML:"
+"O estilo deste código misturado com o Java e HTML, não escalariam em um "
+"aplicativo mais complexo, tenha em mente que estamos somente ilustrando os "
+"conceitos básicos do Hibernate neste tutorial. O código imprime um cabeçalho "
+"e nota de rodapé em HTML. Dentro desta página, são impressos um formulário "
+"para entrada de evento em HTML e uma lista de todos os evento no banco de "
+"dados. O primeiro método é trivial e somente produz um HTML:"
 
-#. Tag: programlisting
-#: tutorial.xml:1039
-#, no-c-format
-msgid ""
-"<![CDATA[    private void printEventForm(PrintWriter out) {\n"
-"        out.println(\"<h2>Add new event:</h2>\");\n"
-"        out.println(\"<form>\");\n"
-"        out.println(\"Title: <input name='eventTitle' length='50'/><br/>"
-"\");\n"
-"        out.println(\"Date (e.g. 24.12.2009): <input name='eventDate' "
-"length='10'/><br/>\");\n"
-"        out.println(\"<input type='submit' name='action' value='store'/>"
-"\");\n"
-"        out.println(\"</form>\");\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1041
 #, no-c-format
 msgid ""
 "The <literal>listEvents()</literal> method uses the Hibernate "
 "<literal>Session</literal> bound to the current thread to execute a query:"
 msgstr ""
-"O método <literal>listEvents()</literal> usa a <literal>Session</literal> do "
-"Hibernate associada a thread atual para executar um query:"
+"O método <literal>listEvents()</literal> utiliza a <literal>Session</"
+"literal> do Hibernate, limitado ao thread atual para executar uma consulta: "
 
-#. Tag: programlisting
-#: tutorial.xml:1047
-#, no-c-format
-msgid ""
-"<![CDATA[    private void listEvents(PrintWriter out, SimpleDateFormat "
-"dateFormatter) {\n"
-"\n"
-"        List result = HibernateUtil.getSessionFactory()\n"
-"                .getCurrentSession().createCriteria(Event.class).list();\n"
-"        if (result.size() > 0) {\n"
-"            out.println(\"<h2>Events in database:</h2>\");\n"
-"            out.println(\"<table border='1'>\");\n"
-"            out.println(\"<tr>\");\n"
-"            out.println(\"<th>Event title</th>\");\n"
-"            out.println(\"<th>Event date</th>\");\n"
-"            out.println(\"</tr>\");\n"
-"            Iterator it = result.iterator();\n"
-"            while (it.hasNext()) {\n"
-"                Event event = (Event) it.next();\n"
-"                out.println(\"<tr>\");\n"
-"                out.println(\"<td>\" + event.getTitle() + \"</td>\");\n"
-"                out.println(\"<td>\" + dateFormatter.format(event.getDate()) "
-"+ \"</td>\");\n"
-"                out.println(\"</tr>\");\n"
-"            }\n"
-"            out.println(\"</table>\");\n"
-"        }\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1049
 #, no-c-format
 msgid ""
 "Finally, the <literal>store</literal> action is dispatched to the "
 "<literal>createAndStoreEvent()</literal> method, which also uses the "
 "<literal>Session</literal> of the current thread:"
 msgstr ""
-"Finalmente, a action <literal>store</literal> é passada pra o método "
-"<literal>createAndStoreEvent()</literal>, que também usa a <literal>Session</"
-"literal> da thread atual:"
+"Finalmente, a ação <literal>store</literal>, é despachada ao método "
+"<literal>createAndStoreEvent()</literal>, que também utiliza a "
+"<literal>Session</literal> da thread atual:"
 
-#. Tag: programlisting
-#: tutorial.xml:1055
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    protected void createAndStoreEvent(String title, Date theDate) "
-"{\n"
-"        Event theEvent = new Event();\n"
-"        theEvent.setTitle(title);\n"
-"        theEvent.setDate(theDate);\n"
-"\n"
-"        HibernateUtil.getSessionFactory()\n"
-"                .getCurrentSession().save(theEvent);\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:1057
-#, fuzzy, no-c-format
-msgid ""
 "The servlet is now complete. A request to the servlet will be processed in a "
 "single <literal>Session</literal> and <literal>Transaction</literal>. As "
 "earlier in the standalone application, Hibernate can automatically bind "
@@ -2474,80 +1794,54 @@
 "data access code into data access objects (the DAO pattern). See the "
 "Hibernate Wiki for more examples."
 msgstr ""
-"Pronto, o servlet está completo. Uma requisição para o servlet será "
-"processada em uma <literal>Session</literal> e uma <literal>Transaction</"
-"literal> simples. Como anteriormente, no aplicativo standalone, o Hibernate "
-"pode automaticamente associar esses objetos a thread atual em execução. Isso "
-"possibilita a liberdade de você modelar seu código e acessar o método "
-"<literal>SessionFactory</literal> do jeito que achar melhor. Geralmente você "
-"irá usar um design mais sofisticado e mover o código de acesso a dados para "
-"dentro de objetos de acesso a dados (o patter DAO). Leia o Hibernate Wiki "
-"para maiores exemplos."
+"O servlet está completo agora. Uma solicitação ao servlet será processada "
+"com uma única <literal>Session</literal> e <literal>Transaction</literal>. "
+"Quanto antes estiver no aplicativo autônomo, maior a chance do Hibernate "
+"vincular automaticamente estes objetos à thread atual de execução. Isto lhe "
+"dá a liberdade para inserir seu código e acessar a <literal>SessionFactory</"
+"literal> como desejar. Geralmente, usaríamos um diagrama mais sofisticado e "
+"moveríamos o código de acesso de dados para os objetos de acesso dos dados "
+"(o modelo DAO). Veja o Hibernate Wiki para mais exemplos. "
 
 #. Tag: title
-#: tutorial.xml:1071
 #, no-c-format
 msgid "Deploying and testing"
-msgstr "Instalando e testando"
+msgstr "Implementando e testando"
 
 #. Tag: para
-#: tutorial.xml:1073
 #, no-c-format
 msgid ""
 "To deploy this application for testing we must create a Web ARchive (WAR). "
 "First we must define the WAR descriptor as <filename>src/main/webapp/WEB-INF/"
 "web.xml</filename>"
 msgstr ""
+"Para implementar este aplicativo em testes, nós devemos criar um Arquivo da "
+"Web (WAR). Primeiro, nós devemos definir o descritor WAR como <filename>src/"
+"main/webapp/WEB-INF/web.xml</filename>"
 
-#. Tag: programlisting
-#: tutorial.xml:1079
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
-"<web-app version=\"2.4\"\n"
-"    xmlns=\"http://java.sun.com/xml/ns/j2ee\"\n"
-"    xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
-"    xsi:schemaLocation=\"http://java.sun.com/xml/ns/j2ee http://java.sun.com/"
-"xml/ns/j2ee/web-app_2_4.xsd\">\n"
-"\n"
-"    <servlet>\n"
-"        <servlet-name>Event Manager</servlet-name>\n"
-"        <servlet-class>org.hibernate.tutorial.web.EventManagerServlet</"
-"servlet-class>\n"
-"    </servlet>\n"
-"\n"
-"    <servlet-mapping>\n"
-"        <servlet-name>Event Manager</servlet-name>\n"
-"        <url-pattern>/eventmanager</url-pattern>\n"
-"    </servlet-mapping>\n"
-"</web-app>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:1081
-#, fuzzy, no-c-format
-msgid ""
 "To build and deploy call <literal>mvn package</literal> in your project "
 "directory and copy the <filename>hibernate-tutorial.war</filename> file into "
 "your Tomcat <filename>webapps</filename> directory."
 msgstr ""
-"Para compilar e instalar execute <literal>ant war</literal> no seu diretório "
-"do projeto e copie o arquivo <literal>hibernate-tutorial.war</literal> para "
-"o diretório <literal>webapp</literal> do Tomcat. Se você não possui o Tomcat "
-"instalado faça o download e siga as instruções de instalação. Você não "
-"precisa modificar nenhuma configuração do Tomcat para rodar este aplicativo."
+"Para construir e implementar, chame seu diretório de projeto <literal>ant "
+"war</literal> e copie o arquivo <literal>hibernate-tutorial.war</literal> "
+"para seu diretório Tomcat <literal>webapp</literal>. "
 
 #. Tag: para
-#: tutorial.xml:1088
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "If you do not have Tomcat installed, download it from <ulink url=\"http://"
-"tomcat.apache.org/\"></ulink> and follow the installation instructions. Our "
+"tomcat.apache.org/\" /> and follow the installation instructions. Our "
 "application requires no changes to the standard Tomcat configuration."
 msgstr ""
+"Caso você não possua o Tomcat instalado, baixe isto do <ulink url=\"http://"
+"tomcat.apache.org/\"></ulink> e siga as instruções de instalação. Nosso "
+"aplicativo não solicita alterações à configuração Tomcat padrão."
 
 #. Tag: para
-#: tutorial.xml:1096
 #, no-c-format
 msgid ""
 "Once deployed and Tomcat is running, access the application at "
@@ -2557,422 +1851,26 @@
 "<literal>HibernateUtil</literal> is called) and to get the detailed output "
 "if any exceptions occurs."
 msgstr ""
-"Uma vez feito o deploy e com Tomcat rodando, acesse o aplicativo em "
+"Uma vez implementado e com o Tomcat rodando, acesse o aplicativo em "
 "<literal>http://localhost:8080/hibernate-tutorial/eventmanager</literal>. "
-"Veja o log do Tomcat para observar a inicialização do Hibernate quando a "
-"primeira requisição chega ao servlet (o inicializador estático dentro de "
-"<literal>HibernateUtil</literal> é chamado) e para ter uma depuração "
-"detalhada se ocorrer alguma exceção."
+"Tenha a certeza de observar o log do Tomcat para ver o Hibernate inicializar "
+"quando a primeira solicitação chegar em seu servlet (o inicializador "
+"estático no <literal>HibernateUtil</literal> é chamado) e para obter o "
+"resultado detalhado caso exceções aconteçam. "
 
 #. Tag: title
-#: tutorial.xml:1109
 #, no-c-format
 msgid "Summary"
 msgstr "Sumário"
 
 #. Tag: para
-#: tutorial.xml:1111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This tutorial covered the basics of writing a simple standalone Hibernate "
 "application and a small web application. More tutorials are available from "
 "the Hibernate <ulink url=\"http://hibernate.org\">website</ulink>."
 msgstr ""
-"Este manual cobriu os princípios básicos para criação de uma aplicação "
-"simples do Hibernate e uma pequena aplicação web."
-
-#~ msgid "Introduction to Hibernate"
-#~ msgstr "Introdução ao Hibernate"
-
-#~ msgid "Preface"
-#~ msgstr "Prefácio"
-
-#~ msgid ""
-#~ "This chapter is an introductory tutorial for new users of Hibernate. We "
-#~ "start with a simple command line application using an in-memory database "
-#~ "and develop it in easy to understand steps."
-#~ msgstr ""
-#~ "Este capítulo é um tutorial introdutório para novos usuários do "
-#~ "Hibernate. Nós iniciaremos com uma simples linha de comando em uma "
-#~ "aplicação usando uma base de dados em memória tornando isto um passo de "
-#~ "fácil de compreender."
-
-#~ msgid ""
-#~ "This tutorial is intended for new users of Hibernate but requires Java "
-#~ "and SQL knowledge. It is based on a tutorial by Michael Gloegl, the third-"
-#~ "party libraries we name are for JDK 1.4 and 5.0. You might need others "
-#~ "for JDK 1.3."
-#~ msgstr ""
-#~ "Este tutorial é voltado para novos usuários do Hibernate, mas requer um "
-#~ "conhecimento de Java e SQL. Este tutorial é baseado no tutorial de "
-#~ "Michael Gloegl, as bibliotecas Third Party foram nomeadas para JDK 1.4 e "
-#~ "5.0. Você pode precisar de outras bibliotecas para JDK 1.3."
-
-#~ msgid ""
-#~ "The source code for the tutorial is included in the distribution in the "
-#~ "<literal>doc/reference/tutorial/</literal> directory."
-#~ msgstr ""
-#~ "O código fonte para o tutorial está incluído no diretório da distribuição "
-#~ "<literal>doc/reference/tutorial/</literal>."
-
-#~ msgid ""
-#~ "First, we'll create a simple console-based Hibernate application. We use "
-#~ "an Java database (HSQL DB), so we do not have to install any database "
-#~ "server."
-#~ msgstr ""
-#~ "Primeiro, iremos criar uma simples aplicação Hibernate baseada em "
-#~ "console. Usaremos uma base de dados Java (HSQL DB), então não teremos que "
-#~ "instalar nenhum servidor de base de dados."
-
-#~ msgid ""
-#~ "The first thing we do, is set up our development directory and put all "
-#~ "the Java libraries we need into it. Download the Hibernate distribution "
-#~ "from the Hibernate website. Extract the package and place all required "
-#~ "libraries found in <literal>/lib</literal> into into the <literal>/lib</"
-#~ "literal> directory of your new development working directory. It should "
-#~ "look like this:"
-#~ msgstr ""
-#~ "A primeira coisa que devemos fazer é configurar nosso diretório de "
-#~ "desenvolvimento, e colocar todas as bibliotecas Java que precisamos "
-#~ "dentro dele. Faça o download da distribuição do Hibernate no site do "
-#~ "Hibernate. Descompacte o pacote e coloque todas as bibliotecas "
-#~ "necessárias encontradas no diretório <literal>/lib</literal>, dentro do "
-#~ "diretório <literal>/lib</literal> do seu novo projeto. Você deverá ter "
-#~ "algo parecido com isso:"
-
-#~ msgid ""
-#~ "This is the minimum set of required libraries (note that we also copied "
-#~ "hibernate3.jar, the main archive) for Hibernate <emphasis>at the time of "
-#~ "writing</emphasis>. The Hibernate release you are using might require "
-#~ "more or less libraries. See the <literal>README.txt</literal> file in the "
-#~ "<literal>lib/</literal> directory of the Hibernate distribution for more "
-#~ "information about required and optional third-party libraries. (Actually, "
-#~ "Log4j is not required but preferred by many developers.)"
-#~ msgstr ""
-#~ "Esta é a configuração mínima requerida das bibliotecas (observe que "
-#~ "também foi copiado o hibernate3.jar da pasta principal do Hibernate) para "
-#~ "o Hibernate <emphasis>na hora do desenvolvimento</emphasis>. O Hibernate "
-#~ "permite que você utilize mais ou menos bibliotecas. Veja o arquivo "
-#~ "<literal>README.txt</literal> no diretório <literal>lib/</literal> da "
-#~ "distribuição do Hibernate para maiores informaççes sobre bibliotecas "
-#~ "requeridas e opcionais. (Atualmente, a biblioteca Log4j não é requerida, "
-#~ "mas é preferida por muitos desenvolvedores.)"
-
-#~ msgid ""
-#~ "Our first persistent class is a simple JavaBean class with some "
-#~ "properties:"
-#~ msgstr ""
-#~ "Nossa primeira classe de persistência é uma simples classe JavaBean com "
-#~ "algumas propriedades:"
-
-#~ msgid ""
-#~ "Place this Java source file in a directory called <literal>src</literal> "
-#~ "in the development folder, and in its correct package. The directory "
-#~ "should now look like this:"
-#~ msgstr ""
-#~ "Coloque este fonte Java no diretório chamado <literal>src</literal> na "
-#~ "pasta de desenvolvimento, e em seu pacote correto. O diretório deverá ser "
-#~ "parecido como este:"
-
-#~ msgid "In the next step, we tell Hibernate about this persistent class."
-#~ msgstr ""
-#~ "No próximo passo, iremos falar sobre as classes de persistência do "
-#~ "Hibernate.."
-
-#~ msgid ""
-#~ "The <literal>id</literal> element is the declaration of the identifer "
-#~ "property, <literal>name=\"id\"</literal> declares the name of the Java "
-#~ "property - Hibernate will use the getter and setter methods to access the "
-#~ "property. The column attribute tells Hibernate which column of the "
-#~ "<literal>EVENTS</literal> table we use for this primary key. The nested "
-#~ "<literal>generator</literal> element specifies the identifier generation "
-#~ "strategy, in this case we used <literal>native</literal>, which picks the "
-#~ "best strategy depending on the configured database (dialect). Hibernate "
-#~ "supports database generated, globally unique, as well as application "
-#~ "assigned identifiers (or any strategy you have written an extension for)."
-#~ msgstr ""
-#~ "O elemento <literal>id</literal> é a declaração da propriedade "
-#~ "identificadora, o <literal>name=\"id\"</literal> declara o nome da "
-#~ "propriedade Java – o Hibernate irá usar os métodos getter e setter para "
-#~ "acessar a propriedade. O atributo da coluna informa ao Hibernate qual "
-#~ "coluna da tabela <literal>EVENTS</literal> nós iremos usar como chave "
-#~ "primária. O elemento <literal>generator</literal> especifica a estratégia "
-#~ "de geração do identificador, neste caso usaremos <literal>native</"
-#~ "literal>, que escolhe a melhor estratégia dependendo da base de dados "
-#~ "(dialeto) configurada. O Hibernate suporta a base de dados gerada, "
-#~ "globalmente única, bem como a atribuição aos identificadores da aplicação "
-#~ "(ou toda estratégia escrita para uma extensão)."
-
-#~ msgid ""
-#~ "This mapping file should be saved as <literal>Event.hbm.xml</literal>, "
-#~ "right in the directory next to the <literal>Event</literal> Java class "
-#~ "source file. The naming of mapping files can be arbitrary, however the "
-#~ "<literal>hbm.xml</literal> suffix is a convention in the Hibernate "
-#~ "developer community. The directory structure should now look like this:"
-#~ msgstr ""
-#~ "Este arquivo de mapeamento deve ser salvo como <literal>Event.hbm.xml</"
-#~ "literal>, corretamente no diretório próximo ao arquivo fonte da Classe "
-#~ "Java <literal>Event</literal>. O nomeamento dos arquivos de mapeamento "
-#~ "podem ser arbitrários, porém o sufixo <literal>hbm.xml</literal> é uma "
-#~ "convenção da comunidade dos desenvolvedores do Hibernate. Esta estrutura "
-#~ "do diretório deve agora se parecer com isso:"
-
-#~ msgid "We continue with the main configuration of Hibernate."
-#~ msgstr "Nós iremos continuar com a configuração principal do Hibernate."
-
-#~ msgid ""
-#~ "We now have a persistent class and its mapping file in place. It is time "
-#~ "to configure Hibernate. Before we do this, we will need a database. HSQL "
-#~ "DB, a java-based SQL DBMS, can be downloaded from the HSQL DB website"
-#~ "(http://hsqldb.org/). Actually, you only need the <literal>hsqldb.jar</"
-#~ "literal> from this download. Place this file in the <literal>lib/</"
-#~ "literal> directory of the development folder."
-#~ msgstr ""
-#~ "Agora nós temos uma classe persistente e este arquivo de mapeamento no "
-#~ "lugar. Está na hora de configurar o Hibernate. Antes de fazermos isso, "
-#~ "iremos precisar de uma base de dados. O HSQL DB, um SQL DBMS feito em "
-#~ "java, pode ser baixado através do site do HSQL DB(http://hsqldb.org/). "
-#~ "Atualmente, você só precisa baixar o <literal>hsqldb.jar</literal>. "
-#~ "Coloque este arquivo no diretório da pasta de desenvolvimento "
-#~ "<literal>lib/</literal>."
-
-#~ msgid ""
-#~ "Hibernate is the layer in your application which connects to this "
-#~ "database, so it needs connection information. The connections are made "
-#~ "through a JDBC connection pool, which we also have to configure. The "
-#~ "Hibernate distribution contains several open source JDBC connection "
-#~ "pooling tools, but will use the Hibernate built-in connection pool for "
-#~ "this tutorial. Note that you have to copy the required library into your "
-#~ "classpath and use different connection pooling settings if you want to "
-#~ "use a production-quality third party JDBC pooling software."
-#~ msgstr ""
-#~ "O Hibernate é uma camada na sua aplicação na qual se conecta com a base "
-#~ "de dados, para isso necessita de informação da conexão. As conexões são "
-#~ "feitas através de um pool de conexão JDBC, na qual teremos que "
-#~ "configurar. A distribuição do Hibernate contém diversas ferramentas de "
-#~ "pooling da conexão JDBC de fonte aberta, mas iremos usar o pool de "
-#~ "conexão interna para este tutorial. Note que você tem que copiar a "
-#~ "biblioteca necessária em seu classpath e use configurações diferentes "
-#~ "para pooling de conexão caso você deseje utilizar um software de pooling "
-#~ "JDBC terceirizado para qualidade de produção."
-
-#~ msgid ""
-#~ "Copy this file into the source directory, so it will end up in the root "
-#~ "of the classpath. Hibernate automatically looks for a file called "
-#~ "<literal>hibernate.cfg.xml</literal> in the root of the classpath, on "
-#~ "startup."
-#~ msgstr ""
-#~ "Copie este arquivo no diretório fonte, assim isto irá terminar na raiz "
-#~ "(root) do classpath. O Hibernate automaticamente procura por um arquivo "
-#~ "chamado <literal>hibernate.cfg.xml</literal> na raiz do classpath, no "
-#~ "startup."
-
-#~ msgid ""
-#~ "We'll now build the tutorial with Ant. You will need to have Ant "
-#~ "installed - get it from the <ulink url=\"http://ant.apache.org/"
-#~ "bindownload.cgi\">Ant download page</ulink>. How to install Ant will not "
-#~ "be covered here. Please refer to the <ulink url=\"http://ant.apache.org/"
-#~ "manual/index.html\">Ant manual</ulink>. After you have installed Ant, we "
-#~ "can start to create the buildfile. It will be called <literal>build.xml</"
-#~ "literal> and placed directly in the development directory."
-#~ msgstr ""
-#~ "Nos iremos, agora, construir o tutorial com Ant. Você ira precisar o Ant "
-#~ "instalado – se encontra disponível <ulink url=\"http://ant.apache.org/"
-#~ "bindownload.cgi\">na página de download do Ant</ulink>. Como instalar o "
-#~ "Ant, não será abordado aqui. Caso tenha alguma dúvida, por favor, vá ao "
-#~ "<ulink url=\"http://ant.apache.org/manual/index.html\">Ant manual</"
-#~ "ulink>. Depois que tiver instalado o Ant, podemos começar a criar o "
-#~ "arquivo de construção <literal>build.xml</literal>. Este arquivo será "
-#~ "chamado de <literal>build.xml</literal> e posto diretamente no diretório "
-#~ "de desenvolvimento."
-
-#~ msgid "A basic build file looks like this:"
-#~ msgstr "Um arquivo básico de build, se parece com isto:"
-
-#~ msgid ""
-#~ "This will tell Ant to add all files in the lib directory ending with "
-#~ "<literal>.jar</literal> to the classpath used for compilation. It will "
-#~ "also copy all non-Java source files to the target directory, e.g. "
-#~ "configuration and Hibernate mapping files. If you now run Ant, you should "
-#~ "get this output:"
-#~ msgstr ""
-#~ "Isto irá avisar ao Ant para adicionar todos os arquivos no diretório lib "
-#~ "terminando com <literal>.jar</literal>, para o classpath usado para "
-#~ "compilação. Irá também copiar todos os arquivos não-java para o diretório "
-#~ "alvo (arquivos de configuração, mapeamento). Se você rodar o ant agora, "
-#~ "deverá ter esta saída."
-
-#~ msgid ""
-#~ "Place <literal>HibernateUtil.java</literal> in the development source "
-#~ "directory, in a package next to <literal>events</literal>:"
-#~ msgstr ""
-#~ "Coloque o <literal>HibernateUtil.java</literal> no diretório de arquivos "
-#~ "de desenvolvimento(source), em um pacote após o <literal>events</literal>:"
-
-#~ msgid ""
-#~ "To run this first routine we have to add a callable target to the Ant "
-#~ "build file:"
-#~ msgstr ""
-#~ "Para executar esta primeira rotina, nos teremos que adicionar um ponto de "
-#~ "chamada para o arquivo de build do Ant:"
-
-#~ msgid ""
-#~ "The value of the <literal>action</literal> argument is set on the command "
-#~ "line when calling the target:"
-#~ msgstr ""
-#~ "O valor do argumento <literal>action</literal>, é setado na linha de "
-#~ "comando quando chamando esse ponto:"
-
-#~ msgid ""
-#~ "This is the <literal>INSERT</literal> executed by Hibernate, the question "
-#~ "marks represent JDBC bind parameters. To see the values bound as "
-#~ "arguments, or to reduce the verbosity of the log, check your "
-#~ "<literal>log4j.properties</literal>."
-#~ msgstr ""
-#~ "Este é o <literal>INSERT</literal> executado pelo Hibernate, os pontos de "
-#~ "interrogação representam parêmetros de união do JDBC. Para ver os valores "
-#~ "substituídos, ou para diminuir a verbalidade do log, check seu "
-#~ "l<literal>log4j.properties</literal>."
-
-#~ msgid "Now, to execute and test all of this, follow these steps:"
-#~ msgstr "Agora, para executar e testar tudo isso, siga os passos a seguir:"
-
-#~ msgid ""
-#~ "Run <literal>ant run -Daction=store</literal> to store something into the "
-#~ "database and, of course, to generate the database schema before through "
-#~ "hbm2ddl."
-#~ msgstr ""
-#~ "Execute <literal>ant run -Daction=store</literal> para armazenar algo no "
-#~ "banco de dados e, claro, gerar o esquema do banco de dados antes pelo "
-#~ "hbm2ddl."
-
-#~ msgid ""
-#~ "Now disable hbm2ddl by commenting out the property in your "
-#~ "<literal>hibernate.cfg.xml</literal> file. Usually you only leave it "
-#~ "turned on in continous unit testing, but another run of hbm2ddl would "
-#~ "<emphasis>drop</emphasis> everything you have stored - the "
-#~ "<literal>create</literal> configuration setting actually translates into "
-#~ "\"drop all tables from the schema, then re-create all tables, when the "
-#~ "SessionFactory is build\"."
-#~ msgstr ""
-#~ "Agora desabilite hbm2ddl comentando a propriedade no seu arquivo "
-#~ "<literal>hibernate.cfg.xml</literal>. Normalmente só se deixa habilitado "
-#~ "em teste unitários contínuos, mas outra carga de hbm2ddl pode "
-#~ "<emphasis>remover</emphasis> tudo que você já tenha arquivado. Sa "
-#~ "configuração <literal>create</literal>, atualmente são traduzidas para "
-#~ "\"apague todas as tabelas do esquema, então recrie todas quando a "
-#~ "SessionFactory estiver pronta\"."
-
-#~ msgid ""
-#~ "If you now call Ant with <literal>-Daction=list</literal>, you should see "
-#~ "the events you have stored so far. You can of course also call the "
-#~ "<literal>store</literal> action a few times more."
-#~ msgstr ""
-#~ "Se você agora chamar o Ant com <literal>-Daction=list</literal>, você "
-#~ "deverá ver os eventos que você acabou de criar. Você pode também chamar a "
-#~ "ação <literal>store</literal> mais algumas vezes."
-
-#~ msgid ""
-#~ "Note: Most new Hibernate users fail at this point and we see questions "
-#~ "about <emphasis>Table not found</emphasis> error messages regularly. "
-#~ "However, if you follow the steps outlined above you will not have this "
-#~ "problem, as hbm2ddl creates the database schema on the first run, and "
-#~ "subsequent application restarts will use this schema. If you change the "
-#~ "mapping and/or database schema, you have to re-enable hbm2ddl once again."
-#~ msgstr ""
-#~ "Nota: A maioria dos novos usuários do Hibernate falha nesse ponto e nós "
-#~ "regularmente, vemos questões sobre mensagens de erro de <emphasis>tabela "
-#~ "não encontrada </emphasis> . Entretanto, se você seguir os passos "
-#~ "marcados acima, você não terá esse problema, com o hbm2ddl criando o "
-#~ "esquema do banco de dados na primeira execução, e restarts subsequentes "
-#~ "da aplicação irão usar este esquema. Se você mudar o mapeamento e/ou o "
-#~ "esquema do banco de dados, terá de re-habilitar o hbm2ddl mais uma vez."
-
-#~ msgid ""
-#~ "Create a new mapping file called <literal>Person.hbm.xml</literal> (don't "
-#~ "forget the DTD reference at the top):"
-#~ msgstr ""
-#~ "Crie um novo arquivo de mapeamento, chamado <literal>Person.hbm.xml</"
-#~ "literal> (não esqueça a referencia ao DTD no topo)"
-
-#~ msgid ""
-#~ "We need a unidirectional, many-valued associations, implemented with a "
-#~ "<literal>Set</literal>. Let's write the code for this in the Java classes "
-#~ "and then map it:"
-#~ msgstr "Vamos escrever o código para isto nas classes Java e então mapear:"
-
-#~ msgid ""
-#~ "We add a collection of value typed objects to the <literal>Person</"
-#~ "literal> entity. We want to store email addresses, so the type we use is "
-#~ "<literal>String</literal>, and the collection is again a <literal>Set</"
-#~ "literal>:"
-#~ msgstr ""
-#~ "Nós adicionamos uma coleção de objetos de tipo de valores à entidade "
-#~ "<literal>Person</literal>. Nós querermos armazenar endereços de e-mail, "
-#~ "para isso utilizamos o tipo <literal>String</literal>, e a coleção "
-#~ "novamente será um <literal>Set</literal>:"
-
-#~ msgid "Let's turn this into a small web application."
-#~ msgstr ""
-#~ "Agora, vamos portar este exemplo para um pequeno aplicativo para internet."
-
-#~ msgid ""
-#~ "Create a new class in your source directory, in the <literal>events</"
-#~ "literal> package:"
-#~ msgstr ""
-#~ "Crie uma nova classe no seu diretório fonte, no pacote <literal>events</"
-#~ "literal>:"
-
-#~ msgid ""
-#~ "To deploy this application you have to create a web archive, a WAR. Add "
-#~ "the following Ant target to your <literal>build.xml</literal>:"
-#~ msgstr ""
-#~ "Para fazer o deploy desta aplicação você tem que criar um arquivo para "
-#~ "web, um WAR. Adicione o alvo Ant abaixo em seu <literal>build.xml</"
-#~ "literal>:"
-
-#~ msgid ""
-#~ "This target creates a file called <literal>hibernate-tutorial.war</"
-#~ "literal> in your project directory. It packages all libraries and the "
-#~ "<literal>web.xml</literal> descriptor, which is expected in the base "
-#~ "directory of your project:"
-#~ msgstr ""
-#~ "Esta target cria um arquivo chamado <literal>hibernate-tutorial.war</"
-#~ "literal> no diretório do seu projeto. Ele empacota todas as bibliotecas e "
-#~ "o arquivo de descrição <literal>web.xml</literal>, o qual é esperado no "
-#~ "diretório base do seu projeto:"
-
-#~ msgid ""
-#~ "Before you compile and deploy the web application, note that an "
-#~ "additional library is required: <literal>jsdk.jar</literal>. This is the "
-#~ "Java servlet development kit, if you don't have this library already, get "
-#~ "it from the Sun website and copy it to your library directory. However, "
-#~ "it will be only used for compliation and excluded from the WAR package."
-#~ msgstr ""
-#~ "Antes de você compilar e fazer o deploy desta aplicação web, note que uma "
-#~ "biblioteca adicional é requerida: <literal>jsdk.jar</literal>. Esse é o "
-#~ "Java servlet development kit, se você não possui esta biblioteca, faça "
-#~ "seu download na página da Sun e copie-a para seu diretório de "
-#~ "bibliotecas. Entretanto, será usado somente para a compilação e excluído "
-#~ "do pacote WAR."
-
-#~ msgid ""
-#~ "If you already feel confident with Hibernate, continue browsing through "
-#~ "the reference documentation table of contents for topics you find "
-#~ "interesting - most asked are transactional processing (<xref linkend="
-#~ "\"transactions\"/>), fetch performance (<xref linkend=\"performance\"/>), "
-#~ "or the usage of the API (<xref linkend=\"objectstate\"/>) and the query "
-#~ "features (<xref linkend=\"objectstate-querying\"/>)."
-#~ msgstr ""
-#~ "Se você já se sente seguro com o Hibernate, continue navegando na "
-#~ "documentação de referência por tópicos que você acha interessante – os "
-#~ "tópicos mais questionados são: processo de transação (<xref linkend="
-#~ "\"transactions\"/>), uso da API (<xref linkend=\"objectstate\"/>) e "
-#~ "características de consulta (<xref linkend=\"objectstate-querying\"/>)."
-
-#~ msgid ""
-#~ "Don't forget to check the Hibernate website for more (specialized) "
-#~ "tutorials."
-#~ msgstr ""
-#~ "Não esqueça de visitar o site do Hibernate para obter mais tutoriais "
-#~ "especializados."
+"Este tutorial cobriu itens básicos de como escrever um aplicativo Hibernate "
+"autônomo simples e um aplicativo da web pequeno. A partir do Hibernate "
+"<ulink url=\"http://hibernate.org\">website</ulink> você poderá encontrar "
+"mais tutoriais disponíveis."

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/content/xml.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/content/xml.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/content/xml.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,41 +1,143 @@
+# translation of xml.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# translation of Collection_Mapping.po to
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2006.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# , 2007.
+# Michael H. Smith <mhideo at redhat.com>, 2007.
+# Glaucia Cintra <gcintra at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: xml\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-12-21 07:56+1000\n"
+"Last-Translator: \n"
+"Language-Team:  <en at 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
-#: xml.xml:29
 #, no-c-format
 msgid "XML Mapping"
 msgstr "Mapeamento XML"
 
-#. Tag: emphasis
-#: xml.xml:31
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
-"XML Mapping is an experimental feature in Hibernate 3.0 and is currently "
-"under active development."
+"<emphasis> XML Mapping is an experimental feature in Hibernate 3.0 and is "
+"currently under active development. </emphasis>"
 msgstr ""
-"Note that this is an experimental feature in Hibernate 3.0 and is under "
-"extremely active development. Veja que essa é uma feature experimental no "
-"Hibernate 3.0 e o desenvolvimento esta bastante ativo."
+"<emphasis> O Mapeamento XML é um recurso experimental no Hibernate 3.0 e "
+"está sob constante desenvolvimento. </emphasis>"
 
 #. Tag: title
-#: xml.xml:37
 #, no-c-format
 msgid "Working with XML data"
 msgstr "Trabalhando com dados em XML"
 
 #. Tag: para
-#: xml.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate allows you to work with persistent XML data in much the same way "
 "you work with persistent POJOs. A parsed XML tree can be thought of as "
@@ -43,12 +145,11 @@
 "of POJOs."
 msgstr ""
 "O Hibernate permite que se trabalhe com dados persistentes em XML quase da "
-"mesma maneira como você trabalhar com POJOs persistentes. Uma árvore XML "
-"parseada, pode ser imaginada como apenas uma maneira de representar os dados "
-"relacionais como objetos, ao invés dos POJOs."
+"mesma maneira como você trabalha com POJOs persistentes. Uma árvore XML "
+"analisada, pode ser considerada como apenas uma maneira de representar os "
+"dados relacionais como objetos, ao invés dos POJOs. "
 
 #. Tag: para
-#: xml.xml:46
 #, no-c-format
 msgid ""
 "Hibernate supports dom4j as API for manipulating XML trees. You can write "
@@ -62,13 +163,12 @@
 "O Hibernate suporta a API dom4j para manipular árvores XML. Você pode "
 "escrever queries que retornem árvores dom4j do banco de dados e "
 "automaticamente sincronizar com o banco de dados qualquer modificação feita "
-"nessas árvores. Você pode até mesmo pegar um documento XML, parsear usando o "
-"dom4j, e escrever as alterações no banco de dados usando quaisquer operações "
-"básicas do Hibernate: <literal>persist(), saveOrUpdate(),merge(), delete(), "
-"replicate()</literal> (merging ainda não é suportado)"
+"nessas árvores. Você pode até mesmo pegar um documento XML, analisá-lo "
+"usando o dom4j, e escrever as alterações no banco de dados usando quaisquer "
+"operações básicas do Hibernate: <literal>persist(), saveOrUpdate(),merge(), "
+"delete(), replicate()</literal> (a mesclagem ainda não é suportada)"
 
 #. Tag: para
-#: xml.xml:56
 #, no-c-format
 msgid ""
 "This feature has many applications including data import/export, "
@@ -79,8 +179,7 @@
 "usando XSLT."
 
 #. Tag: para
-#: xml.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A single mapping can be used to simultaneously map properties of a class and "
 "nodes of an XML document to the database, or, if there is no class to map, "
@@ -89,156 +188,88 @@
 "Um mapeamento simples pode ser usado para simultaneamente mapear "
 "propriedades da classe e nós de um documento XML para um banco de dados ou, "
 "se não houver classe para mapear, pode ser usado simplesmente para mapear o "
-"XML."
+"XML. "
 
 #. Tag: title
-#: xml.xml:68
 #, no-c-format
 msgid "Specifying XML and class mapping together"
 msgstr ""
-"Especificando o mapeamento de uma classe e de um arquivo XML simultaneamente"
+"Especificando o mapeamento de uma classe e de um arquivo XML simultaneamente "
 
 #. Tag: para
-#: xml.xml:70
 #, no-c-format
 msgid "Here is an example of mapping a POJO and XML simultaneously:"
 msgstr "Segue um exemplo de como mapear um POJO e um XML ao mesmo tempo:"
 
-#. Tag: programlisting
-#: xml.xml:74
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Account\" \n"
-"        table=\"ACCOUNTS\" \n"
-"        node=\"account\">\n"
-"        \n"
-"    <id name=\"accountId\" \n"
-"            column=\"ACCOUNT_ID\" \n"
-"            node=\"@id\"/>\n"
-"            \n"
-"    <many-to-one name=\"customer\" \n"
-"            column=\"CUSTOMER_ID\" \n"
-"            node=\"customer/@id\" \n"
-"            embed-xml=\"false\"/>\n"
-"            \n"
-"    <property name=\"balance\" \n"
-"            column=\"BALANCE\" \n"
-"            node=\"balance\"/>\n"
-"            \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: xml.xml:78
 #, no-c-format
 msgid "Specifying only an XML mapping"
 msgstr "Especificando somente um mapeamento XML"
 
 #. Tag: para
-#: xml.xml:80
 #, no-c-format
 msgid "Here is an example where there is no POJO class:"
 msgstr "Segue um exemplo que não contém uma classe POJO:"
 
-#. Tag: programlisting
-#: xml.xml:84
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class entity-name=\"Account\" \n"
-"        table=\"ACCOUNTS\" \n"
-"        node=\"account\">\n"
-"        \n"
-"    <id name=\"id\" \n"
-"            column=\"ACCOUNT_ID\" \n"
-"            node=\"@id\" \n"
-"            type=\"string\"/>\n"
-"            \n"
-"    <many-to-one name=\"customerId\" \n"
-"            column=\"CUSTOMER_ID\" \n"
-"            node=\"customer/@id\" \n"
-"            embed-xml=\"false\" \n"
-"            entity-name=\"Customer\"/>\n"
-"            \n"
-"    <property name=\"balance\" \n"
-"            column=\"BALANCE\" \n"
-"            node=\"balance\" \n"
-"            type=\"big_decimal\"/>\n"
-"            \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: xml.xml:86
-#, fuzzy, no-c-format
-msgid ""
 "This mapping allows you to access the data as a dom4j tree, or as a graph of "
 "property name/value pairs or java <literal>Map</literal>s. The property "
 "names are purely logical constructs that can be referred to in HQL queries."
 msgstr ""
 "Esse mapeamento permite que você acesse os dados como uma árvore dom4j ou um "
-"grafo de de pares nome de propriedade/valor (<literal>Map</literal>s do "
-"Java). Os nomes de propriedades são somente construções lógicas que podem "
-"ser referenciadas em consultas HQL."
+"gráfico de pares de nome/valor de propriedade  ou <literal>Map</literal>s do "
+"Java. Os nomes de propriedades são somente construções lógicas que podem ser "
+"referenciadas em consultas HQL. "
 
 #. Tag: title
-#: xml.xml:97
 #, no-c-format
 msgid "XML mapping metadata"
 msgstr "Mapeando metadados com XML"
 
 #. Tag: para
-#: xml.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A range of Hibernate mapping elements accept the <literal>node</literal> "
 "attribute. This lets you specify the name of an XML attribute or element "
 "that holds the property or entity data. The format of the <literal>node</"
 "literal> attribute must be one of the following:"
 msgstr ""
-"Muitos elementos do mapeamento do Hibernate aceitam o atributo "
-"<literal>node</literal>. Por meio dele, você pode especificar o nome de um "
-"atributo ou elemento XML que contém a propriedade ou os dados da entidade. O "
-"formato do atributo <literal>node</literal> deve ser o seguinte:"
+"Muitos elementos do mapeamento do Hibernate aceitam a função <literal>node</"
+"literal>. Através dele, você pode especificar o nome de uma função ou "
+"elemento XML que contenha a propriedade ou os dados da entidade. O formato "
+"da função <literal>node</literal> deve ser o seguinte: "
 
 #. Tag: para
-#: xml.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>\"element-name\"</literal>: map to the named XML element"
 msgstr ""
-"<literal>\"element-name\"</literal> - mapeia para o elemento XML com "
-"determinado nome"
+"<literal>\"element-name\"</literal>: mapeia para o elemento XML nomeado"
 
 #. Tag: para
-#: xml.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>\"@attribute-name\"</literal>: map to the named XML attribute"
 msgstr ""
-"<literal>\"@attribute-name\"</literal> - mapeia para o atributo XML com "
+"<literal>\"@attribute-name\"</literal>: mapeia para a função XML com "
 "determinado nome"
 
 #. Tag: para
-#: xml.xml:114
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>\".\"</literal>: map to the parent element"
-msgstr "<literal>\".\"</literal> - mapeia para o elemento pai"
+msgstr "<literal>\".\"</literal>: mapeia para o elemento pai"
 
 #. Tag: para
-#: xml.xml:117
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>\"element-name/@attribute-name\"</literal>: map to the named "
 "attribute of the named element"
 msgstr ""
-"<literal>\"element-name/@attribute-name\"</literal> - mapeia para para o "
-"atributo com determinado nome do elemento com determinado nome"
+"<literal>\"element-name/@attribute-name\"</literal>: mapeia para a função "
+"nomeada com o elemento nomeado"
 
 #. Tag: para
-#: xml.xml:124
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For collections and single valued associations, there is an additional "
 "<literal>embed-xml</literal> attribute. If <literal>embed-xml=\"true\"</"
@@ -248,208 +279,69 @@
 "then only the referenced identifier value will appear in the XML for single "
 "point associations and collections will not appear at all."
 msgstr ""
-"Para coleções e associações simples, existe o atributo adicional "
-"<literal>embed-xml</literal>. Se o atributo <literal>embed-xml=\"true\"</"
+"Para coleções e associações de valores simples, existe uma função adicional "
+"<literal>embed-xml</literal>. Se a função <literal>embed-xml=\"true\"</"
 "literal>, que é o valor padrão, a árvore XML para a entidade associada (ou "
 "coleção de determinado tipo de valor) será embutida diretamente na árvore "
 "XML que contém a associação. Por outro lado, se <literal>embed-xml=\"false"
 "\"</literal>, então apenas o valor do identificador referenciado irá "
-"aparecer no XML para associações simples e coleções simplesmentenão irão "
-"aparecer."
+"aparecer no XML para associações simples e as coleções simplesmente não irão "
+"aparecer. "
 
 #. Tag: para
-#: xml.xml:134
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not leave <literal>embed-xml=\"true\"</literal> for too many "
 "associations, since XML does not deal well with circularity."
 msgstr ""
-"Você precisa tomar cuidado em não deixar o<literal>embed-xml=\"true\"</"
+"Você precisa tomar cuidado para não deixar o <literal>embed-xml=\"true\"</"
 "literal> para muitas associações, pois o XML não suporta bem referências "
-"circulares."
+"circulares. "
 
-#. Tag: programlisting
-#: xml.xml:139
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Customer\" \n"
-"        table=\"CUSTOMER\" \n"
-"        node=\"customer\">\n"
-"        \n"
-"    <id name=\"id\" \n"
-"            column=\"CUST_ID\" \n"
-"            node=\"@id\"/>\n"
-"            \n"
-"    <map name=\"accounts\" \n"
-"            node=\".\" \n"
-"            embed-xml=\"true\">\n"
-"        <key column=\"CUSTOMER_ID\" \n"
-"                not-null=\"true\"/>\n"
-"        <map-key column=\"SHORT_DESC\" \n"
-"                node=\"@short-desc\" \n"
-"                type=\"string\"/>\n"
-"        <one-to-many entity-name=\"Account\"\n"
-"                embed-xml=\"false\" \n"
-"                node=\"account\"/>\n"
-"    </map>\n"
-"    \n"
-"    <component name=\"name\" \n"
-"            node=\"name\">\n"
-"        <property name=\"firstName\" \n"
-"                node=\"first-name\"/>\n"
-"        <property name=\"initial\" \n"
-"                node=\"initial\"/>\n"
-"        <property name=\"lastName\" \n"
-"                node=\"last-name\"/>\n"
-"    </component>\n"
-"    \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: xml.xml:141
-#, fuzzy, no-c-format
-msgid ""
 "In this case, the collection of account ids is embedded, but not the actual "
 "account data. The following HQL query:"
 msgstr ""
-"Nesse caso, decidimos embutir a colenção de account ids, e não os dados de "
-"accounts. A query HQL a seguir:"
+"Nesse caso, decidimos incorporar a coleção de ids de contas, e não os dados "
+"de contas. Segue a abaixo a consulta HQL:"
 
-#. Tag: programlisting
-#: xml.xml:146
-#, no-c-format
-msgid ""
-"<![CDATA[from Customer c left join fetch c.accounts where c.lastName like :"
-"lastName]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:148
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "would return datasets such as this:"
-msgstr "Retornaria um conjunto de dados como esse:"
+msgstr "Retornaria um conjunto de dados como esse: "
 
-#. Tag: programlisting
-#: xml.xml:152
-#, no-c-format
-msgid ""
-"<![CDATA[<customer id=\"123456789\">\n"
-"    <account short-desc=\"Savings\">987632567</account>\n"
-"    <account short-desc=\"Credit Card\">985612323</account>\n"
-"    <name>\n"
-"        <first-name>Gavin</first-name>\n"
-"        <initial>A</initial>\n"
-"        <last-name>King</last-name>\n"
-"    </name>\n"
-"    ...\n"
-"</customer>]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:154
 #, no-c-format
 msgid ""
 "If you set <literal>embed-xml=\"true\"</literal> on the <literal>&lt;one-to-"
 "many&gt;</literal> mapping, the data might look more like this:"
 msgstr ""
-"Se você setar <literal>embed-xml=\"true\"</literal> em um mapeamento "
+"Se você ajustar <literal>embed-xml=\"true\"</literal> em um mapeamento "
 "<literal>&lt;one-to-many&gt;</literal>, os dados se pareceriam com o "
 "seguinte:"
 
-#. Tag: programlisting
-#: xml.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[<customer id=\"123456789\">\n"
-"    <account id=\"987632567\" short-desc=\"Savings\">\n"
-"        <customer id=\"123456789\"/>\n"
-"        <balance>100.29</balance>\n"
-"    </account>\n"
-"    <account id=\"985612323\" short-desc=\"Credit Card\">\n"
-"        <customer id=\"123456789\"/>\n"
-"        <balance>-2370.34</balance>\n"
-"    </account>\n"
-"    <name>\n"
-"        <first-name>Gavin</first-name>\n"
-"        <initial>A</initial>\n"
-"        <last-name>King</last-name>\n"
-"    </name>\n"
-"    ...\n"
-"</customer>]]>"
-msgstr ""
-
 #. Tag: title
-#: xml.xml:165
 #, no-c-format
 msgid "Manipulating XML data"
 msgstr "Manipulando dados em XML"
 
 #. Tag: para
-#: xml.xml:167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also re-read and update XML documents in the application. You can do "
 "this by obtaining a dom4j session:"
 msgstr ""
 "Vamos reler e atualizar documentos em XML em nossa aplicação. Nós fazemos "
-"isso obtendo uma session do dom4j:"
+"isso obtendo uma sessão do dom4j: "
 
-#. Tag: programlisting
-#: xml.xml:172
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Document doc = ....;\n"
-"       \n"
-"Session session = factory.openSession();\n"
-"Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"List results = dom4jSession\n"
-"    .createQuery(\"from Customer c left join fetch c.accounts where c."
-"lastName like :lastName\")\n"
-"    .list();\n"
-"for ( int i=0; i<results.size(); i++ ) {\n"
-"    //add the customer data to the XML document\n"
-"    Element customer = (Element) results.get(i);\n"
-"    doc.add(customer);\n"
-"}\n"
-"\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: xml.xml:174
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = factory.openSession();\n"
-"Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"Element cust = (Element) dom4jSession.get(\"Customer\", customerId);\n"
-"for ( int i=0; i<results.size(); i++ ) {\n"
-"    Element customer = (Element) results.get(i);\n"
-"    //change the customer name in the XML and database\n"
-"    Element name = customer.element(\"name\");\n"
-"    name.element(\"first-name\").setText(firstName);\n"
-"    name.element(\"initial\").setText(initial);\n"
-"    name.element(\"last-name\").setText(lastName);\n"
-"}\n"
-"\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: xml.xml:176
-#, fuzzy, no-c-format
-msgid ""
 "When implementing XML-based data import/export, it is useful to combine this "
 "feature with Hibernate's <literal>replicate()</literal> operation."
 msgstr ""
 "É extremamente útil combinar essa funcionalidade com a operação "
 "<literal>replicate()</literal> do Hibernate para implementar importação/"
-"exportação baseadas em XML."
+"exportação de dados baseados em XML."

Modified: core/trunk/documentation/manual/src/main/docbook/pt-BR/legal_notice.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/pt-BR/legal_notice.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/pt-BR/legal_notice.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,35 +2,33 @@
 msgid ""
 msgstr ""
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:23\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
 "Content-Type: text/plain; charset=UTF-8\n"
 
 #. Tag: title
-#: legal_notice.xml:28
 #, no-c-format
 msgid "Legal Notice"
 msgstr "Legal Notice"
 
-#. Tag: address
-#: legal_notice.xml:30
-#, no-c-format
+#. Tag: para
+#, fuzzy, no-c-format
 msgid ""
-"<street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
-"state><postcode>27606-2072</postcode><country>USA</country> <phone>Phone: +1 "
-"919 754 3700</phone> <phone>Phone: 888 733 4281</phone> <fax>Fax: +1 919 754 "
-"3701</fax> <pob>PO Box 13588</pob><city>Research Triangle Park</city>, "
-"<state>NC</state><postcode>27709</postcode><country>USA</country>"
+"<address> <street>1801 Varsity Drive</street> <city>Raleigh</city>, "
+"<state>NC</state><postcode>27606-2072</postcode><country>USA</country> "
+"<phone>Phone: +1 919 754 3700</phone> <phone>Phone: 888 733 4281</phone> "
+"<fax>Fax: +1 919 754 3701</fax> <pob>PO Box 13588</pob><city>Research "
+"Triangle Park</city>, <state>NC</state><postcode>27709</"
+"postcode><country>USA</country> </address>"
 msgstr ""
-"<street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
+"<address> <street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
 "state><postcode>27606-2072</postcode><country>USA</country> <phone>Phone: +1 "
 "919 754 3700</phone> <phone>Phone: 888 733 4281</phone> <fax>Fax: +1 919 754 "
 "3701</fax> <pob>PO Box 13588</pob><city>Research Triangle Park</city>, "
-"<state>NC</state><postcode>27709</postcode><country>USA</country>"
+"<state>NC</state><postcode>27709</postcode><country>USA</country> </address>"
 
 #. Tag: para
-#: legal_notice.xml:39
 #, fuzzy, no-c-format
 msgid ""
 "Copyright <trademark class=\"copyright\"></trademark> 2007 by Red Hat, Inc. "
@@ -46,7 +44,6 @@
 "Public License</ulink>, as published by the Free Software Foundation."
 
 #. Tag: para
-#: legal_notice.xml:45
 #, no-c-format
 msgid ""
 "Red Hat and the Red Hat \"Shadow Man\" logo are registered trademarks of Red "
@@ -56,7 +53,6 @@
 "Hat, Inc. in the United States and other countries."
 
 #. Tag: para
-#: legal_notice.xml:48
 #, no-c-format
 msgid ""
 "All other trademarks referenced herein are the property of their respective "
@@ -66,13 +62,11 @@
 "owners."
 
 #. Tag: para
-#: legal_notice.xml:51
 #, no-c-format
 msgid "The GPG fingerprint of the security at redhat.com key is:"
 msgstr "The GPG fingerprint of the security at redhat.com key is:"
 
 #. Tag: para
-#: legal_notice.xml:54
 #, no-c-format
 msgid "CA 20 86 86 2B D6 9D FC 65 F6 EC C4 21 91 80 CD DB 42 A6 0E"
 msgstr "CA 20 86 86 2B D6 9D FC 65 F6 EC C4 21 91 80 CD DB 42 A6 0E"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/Hibernate_Reference.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/Hibernate_Reference.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/Hibernate_Reference.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,32 +1,30 @@
+# SOME DESCRIPTIVE TITLE.
+# FIRST AUTHOR <EMAIL at ADDRESS>, YEAR.
+#
 #, fuzzy
 msgid ""
 msgstr ""
+"Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-11T05:38:14\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Content-Type: text/plain; charset=UTF-8\n"
+"Language-Team: LANGUAGE <kde-i18n-doc at kde.org>\n"
+"MIME-Version: 1.0\n"
+"Content-Type: application/x-xml2pot; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: Hibernate_Reference.xml:35
 #, no-c-format
 msgid "HIBERNATE - Relational Persistence for Idiomatic Java"
-msgstr "HIBERNATE - 符合Java习惯的关系数据库持久化"
+msgstr ""
 
 #. Tag: subtitle
-#: Hibernate_Reference.xml:36
 #, no-c-format
 msgid "Hibernate Reference Documentation"
-msgstr "Hibernate参考文档"
+msgstr ""
 
-#. Tag: holder
-#: Hibernate_Reference.xml:51
+#. Tag: releaseinfo
 #, no-c-format
-msgid "&copyrightHolder;"
-msgstr "&copyrightHolder;"
-
-#~ msgid "ROLES_OF_TRANSLATORS"
-#~ msgstr "<!--TRANS:ROLES_OF_TRANSLATORS-->"
-
-#~ msgid "CREDIT_FOR_TRANSLATORS"
-#~ msgstr "<!--TRANS:CREDIT_FOR_TRANSLATORS-->"
+msgid "&versionNumber;"
+msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/author_group.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/author_group.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/author_group.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -5,7 +5,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: 2009-07-14 19:55+0000\n"
 "Last-Translator: Automatically generated\n"
 "Language-Team: none\n"
@@ -13,209 +13,137 @@
 "Content-Type: text/plain; charset=UTF-8\n"
 "Content-Transfer-Encoding: 8bit\n"
 
-#. Tag: author
-#: author_group.xml:27
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Gavin</firstname> <surname>King</surname>"
+msgid "Gavin"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:31
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Christian</firstname> <surname>Bauer</surname>"
+msgid "Christian"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:35
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Max</firstname> <othername>Rydahl</othername> <surname>Andersen</"
-"surname>"
+msgid "Max"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:40
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<author><firstname>Emmanuel</firstname> <surname>Bernard</surname></author>"
+msgid "Emmanuel"
 msgstr ""
 
-#. Tag: author
-#: author_group.xml:44
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Steve</firstname> <surname>Ebersole</surname>"
+msgid "Steve"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:49
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>James</firstname> <surname>Cobb</surname>"
+msgid "James"
 msgstr ""
 
-#. Tag: shortaffil
-#: author_group.xml:53 author_group.xml:60
+#. Tag: firstname
 #, no-c-format
-msgid "Graphic Design"
+msgid "Cheyenne"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:56
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Cheyenne</firstname> <surname>Weaver</surname>"
+msgid "Vincent"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:69
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<othername><![CDATA[Bernardo Antonio Buffa Colom&#x00e9]]></othername> "
-"<email>kreimer at bbs.frc.utn.edu.ar</email>"
+msgid "Sebastien"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:79
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Vincent</firstname> <surname>Ricard</surname>"
+msgid "Michael"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:83
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Sebastien</firstname> <surname>Cesbron</surname>"
+msgid "Baptiste"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:87
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Michael</firstname> <surname>Courcy</surname>"
+msgid "Anthony"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:91
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Vincent</firstname> <surname>Giguère</surname>"
+msgid "Alvaro"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:95
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Baptiste</firstname> <surname>Mathus</surname>"
+msgid "Anderson"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:99
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<othercredit><firstname>Emmanuel</firstname> <surname>Bernard</surname></"
-"othercredit>"
+msgid "Daniel Vieira"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:103
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Anthony</firstname> <surname>Patricio</surname>"
+msgid "Francisco"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:113
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Alvaro</firstname> <surname>Netto</surname> "
-"<email>alvaronetto at cetip.com.br</email>"
+msgid "Gamarra"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:118
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Anderson</firstname> <surname>Braulio</surname> "
-"<email>andersonbraulio at gmail.com</email>"
+msgid "Luiz Carlos"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:123
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Daniel Vieira</firstname> <surname>Costa</surname> "
-"<email>danielvc at gmail.com</email>"
+msgid "Marcel"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:128
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Francisco</firstname> <surname>gamarra</surname> <email>francisco."
-"gamarra at gmail.com</email>"
+msgid "Paulo"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:133
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Gamarra</firstname> <email>mauricio.gamarra at gmail.com</email>"
+msgid "Pablo L."
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:137
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Luiz Carlos</firstname> <surname>Rodrigues</surname> "
-"<email>luizcarlos_rodrigues at yahoo.com.br</email>"
+msgid "Renato"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:142
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Marcel</firstname> <surname>Castelo</surname> <email>marcel."
-"castelo at gmail.com</email>"
+msgid "Rogério"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:147
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Paulo</firstname> <surname>César</surname> <email>paulocol at gmail."
-"com</email>"
+msgid "Wanderson"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:152
+#. Tag: firstname
 #, no-c-format
-msgid ""
-"<firstname>Pablo L.</firstname> <surname>de Miranda</surname> "
-"<email>pablolmiranda at gmail.com</email>"
+msgid "Cao"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:157
+#. Tag: orgname
 #, no-c-format
-msgid ""
-"<firstname>Renato</firstname> <surname>Deggau</surname> <email>rdeggau at gmail."
-"com</email>"
+msgid "RedSaga"
 msgstr ""
 
-#. Tag: othercredit
-#: author_group.xml:162
+#. Tag: contrib
 #, no-c-format
-msgid ""
-"<firstname>Rogério</firstname> <surname>Araújo</surname> "
-"<email>rgildoaraujo at yahoo.com.br</email>"
+msgid "Translation Lead"
 msgstr ""
-
-#. Tag: othercredit
-#: author_group.xml:167
-#, no-c-format
-msgid ""
-"<firstname>Wanderson</firstname> <surname>Siqueira</surname> "
-"<email>wandersonxs at gmail.com</email>"
-msgstr ""
-
-#. Tag: othercredit
-#: author_group.xml:178
-#, no-c-format
-msgid ""
-"<firstname>Cao</firstname> <surname>Xiaogang</surname> <affiliation> "
-"<orgname>RedSaga</orgname> </affiliation> <contrib>Translation Lead</"
-"contrib> <email>caoxg at yahoo.com</email>"
-msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/architecture.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/architecture.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/architecture.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,97 +1,88 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2010-01-11 10:12+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: architecture.xml:30
 #, no-c-format
 msgid "Architecture"
-msgstr "体系结构(Architecture)"
+msgstr "体系结构(Architecture)"
 
 #. Tag: title
-#: architecture.xml:33
 #, no-c-format
 msgid "Overview"
-msgstr "概况(Overview)"
+msgstr "概况(Overview)"
 
 #. Tag: para
-#: architecture.xml:35
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The diagram below provides a high-level view of the Hibernate architecture:"
-msgstr "一个非常简要的Hibernate体系结构的概要图:"
+msgstr "下面的图表提供了 Hibernate 体系结构的高层视图:"
 
 #. Tag: para
-#: architecture.xml:48
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We do not have the scope in this document to provide a more detailed view of "
 "all the runtime architectures available; Hibernate is flexible and supports "
 "several different approaches. We will, however, show the two extremes: "
 "\"minimal\" architecture and \"comprehensive\" architecture."
 msgstr ""
-"我们来更详细地看一下Hibernate运行时体系结构。由于Hibernate非常灵活,且支持多"
-"种应用方案, 所以我们这只描述一下两种极端的情况。“轻型”的体系结构方案,要求应"
-"用程序提供自己的JDBC 连接并管理自己的事务。这种方案使用了Hibernate API的最小"
-"子集:"
+"提供 Hibernate 所有运行时体系结构的更多细节不是本文档的范畴。由于 Hibernate "
+"非常灵活,且支持多种应用方案, 所以我们这只描述一下两种极端的情况:“最"
+"小”和“全面解决”的体系结构方案。"
 
 #. Tag: para
-#: architecture.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This next diagram illustrates how Hibernate utilizes database and "
 "configuration data to provide persistence services, and persistent objects, "
 "to the application."
 msgstr ""
-"从这个图可以看出,Hibernate使用数据库和配置信息来为应用程序提供持久化服务(以"
-"及持久的对象)。"
+"下图演示了 Hibernate 如何使用数据库和配置信息来为应用程序提供持久化服务(以及"
+"持久的对象)。"
 
 #. Tag: para
-#: architecture.xml:59
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The \"minimal\" architecture has the application provide its own JDBC "
 "connections and manage its own transactions. This approach uses a minimal "
 "subset of Hibernate's APIs:"
 msgstr ""
-"我们来更详细地看一下Hibernate运行时体系结构。由于Hibernate非常灵活,且支持多"
-"种应用方案, 所以我们这只描述一下两种极端的情况。“轻型”的体系结构方案,要求应"
-"用程序提供自己的JDBC 连接并管理自己的事务。这种方案使用了Hibernate API的最小"
-"子集:"
+"“最小”的体系结构方案,要求应用程序提供自己的 JDBC 连接并管理自己的事务。这种"
+"方案使用了Hibernate API 的最小子集:"
 
 #. Tag: para
-#: architecture.xml:74
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The \"comprehensive\" architecture abstracts the application away from the "
 "underlying JDBC/JTA APIs and allows Hibernate to manage the details."
 msgstr ""
-"“全面解决”的体系结构方案,将应用层从底层的JDBC/JTA API中抽象出来,而让"
-"Hibernate来处理这些细节。"
+"“全面解决”的体系结构方案,将应用层从底层的 JDBC/JTA API 中抽象出来,而让 "
+"Hibernate 来处理这些细节。"
 
 #. Tag: para
-#: architecture.xml:88
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here are some definitions of the objects depicted in the diagrams:"
-msgstr "图中各个对象的定义如下: <placeholder-1/>"
+msgstr "图中各个对象的定义如下: "
 
 #. Tag: term
-#: architecture.xml:93
 #, no-c-format
 msgid "SessionFactory (<literal>org.hibernate.SessionFactory</literal>)"
 msgstr "SessionFactory (<literal>org.hibernate.SessionFactory</literal>)"
 
 #. Tag: para
-#: architecture.xml:95
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A threadsafe, immutable cache of compiled mappings for a single database. A "
 "factory for <literal>Session</literal> and a client of "
@@ -99,20 +90,18 @@
 "hold an optional (second-level) cache of data that is reusable between "
 "transactions at a process, or cluster, level."
 msgstr ""
-"针对单个数据库映射关系经过编译后的内存镜像,是线程安全的(不可变)。 它是生成"
-"<literal>Session</literal>的工厂,本身要用到<literal>ConnectionProvider</"
-"literal>。 该对象可以在进程或集群的级别上,为那些事务之间可以重用的数据提供可"
-"选的二级缓存。"
+"针对单个数据库映射关系经过编译后的内存镜像,是线程安全的(不可变)。 作为 "
+"<literal>Session</literal> 的工厂和 <literal>ConnectionProvider</literal> 的"
+"客户。<literal>SessionFactory</literal> 可以在进程或集群的级别上,为那些事务"
+"之间可以重用的数据提供可选的二级缓存。"
 
 #. Tag: term
-#: architecture.xml:105
 #, no-c-format
 msgid "Session (<literal>org.hibernate.Session</literal>)"
 msgstr "Session (<literal>org.hibernate.Session</literal>)"
 
 #. Tag: para
-#: architecture.xml:107
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A single-threaded, short-lived object representing a conversation between "
 "the application and the persistent store. It wraps a JDBC connection and is "
@@ -120,19 +109,18 @@
 "holds a mandatory first-level cache of persistent objects that are used when "
 "navigating the object graph or looking up objects by identifier."
 msgstr ""
-"表示应用程序与持久储存层之间交互操作的一个单线程对象,此对象生存期很短。 其隐"
-"藏了JDBC连接,也是<literal>Transaction</literal>的工厂。 其会持有一个针对持久"
-"化对象的必选(第一级)缓存,在遍历对象图或者根据持久化标识查找对象时会用到。"
+"表示应用程序与持久储存层之间交互操作的一个单线程对象,此对象生存期很短。其隐"
+"藏了 JDBC 连接,也是 <literal>Transaction</literal> 的工厂。它会持有一个针对"
+"持久化对象的必选(第一级)缓存,在遍历对象图或者根据持久化标识查找对象时会用"
+"到。"
 
 #. Tag: term
-#: architecture.xml:117
 #, no-c-format
 msgid "Persistent objects and collections"
 msgstr "持久的对象及其集合"
 
 #. Tag: para
-#: architecture.xml:119
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Short-lived, single threaded objects containing persistent state and "
 "business function. These can be ordinary JavaBeans/POJOs. They are "
@@ -141,40 +129,36 @@
 "in any application layer (for example, directly as data transfer objects to "
 "and from presentation)."
 msgstr ""
-"带有持久化状态的、具有业务功能的单线程对象,此对象生存期很短。 这些对象可能是"
+"带有持久化状态的、具有业务功能的单线程对象,此对象生存期很短。这些对象可能是"
 "普通的JavaBeans/POJO,唯一特殊的是他们正与(仅仅一个)<literal>Session</"
-"literal>相关联。 一旦这个<literal>Session</literal>被关闭,这些对象就会脱离持"
-"久化状态,这样就可被应用程序的任何层自由使用。 (例如,用作跟表示层打交道的数"
-"据传输对象。)"
+"literal> 相关联。一旦这个 <literal>Session</literal> 被关闭,这些对象就会脱离"
+"持久化状态,这样就可被应用程序的任何层自由使用(例如,用作跟表示层打交道的数"
+"据传输对象)。"
 
 #. Tag: term
-#: architecture.xml:129
 #, no-c-format
 msgid "Transient and detached objects and collections"
-msgstr "瞬态(transient)和脱管(detached)的对象及其集合"
+msgstr "瞬态(transient)和脱管(detached)的对象及其集合"
 
 #. Tag: para
-#: architecture.xml:131
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Instances of persistent classes that are not currently associated with a "
 "<literal>Session</literal>. They may have been instantiated by the "
 "application and not yet persisted, or they may have been instantiated by a "
 "closed <literal>Session</literal>."
 msgstr ""
-"那些目前没有与session关联的持久化类实例。 他们可能是在被应用程序实例化后,尚"
-"未进行持久化的对象。 也可能是因为实例化他们的<literal>Session</literal>已经被"
-"关闭而脱离持久化的对象。"
+"那些目前没有与 <literal>Session</literal>关联的持久化类实例。他们可能是在被应"
+"用程序实例化后,尚未进行持久化的对象。也可能是因为实例化他们的 "
+"<literal>Session</literal> 已经被关闭而脱离持久化的对象。"
 
 #. Tag: term
-#: architecture.xml:140
 #, no-c-format
 msgid "Transaction (<literal>org.hibernate.Transaction</literal>)"
-msgstr "事务Transaction (<literal>org.hibernate.Transaction</literal>)"
+msgstr "事务 Transaction (<literal>org.hibernate.Transaction</literal>)"
 
 #. Tag: para
-#: architecture.xml:142
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "(Optional) A single-threaded, short-lived object used by the application to "
 "specify atomic units of work. It abstracts the application from the "
@@ -184,13 +168,12 @@
 "<literal>Transaction</literal>, is never optional."
 msgstr ""
 "(可选的)应用程序用来指定原子操作单元范围的对象,它是单线程的,生命周期很"
-"短。 它通过抽象将应用从底层具体的JDBC、JTA以及CORBA事务隔离开。 某些情况下,"
-"一个<literal>Session</literal>之内可能包含多个<literal>Transaction</literal>"
-"对象。 尽管是否使用该对象是可选的,但无论是使用底层的API还是使用"
-"<literal>Transaction</literal>对象,事务边界的开启与关闭是必不可少的。"
+"短。它通过抽象将应用从底层具体的 JDBC、JTA 以及 CORBA 事务隔离开。某些情况"
+"下,一个 <literal>Session</literal> 之内可能包含多个 <literal>Transaction</"
+"literal> 对象。尽管是否使用该对象是可选的,但无论是使用底层的 API 还是使用 "
+"<literal>Transaction</literal> 对象,事务边界的开启与关闭是必需的。 "
 
 #. Tag: term
-#: architecture.xml:153
 #, no-c-format
 msgid ""
 "ConnectionProvider (<literal>org.hibernate.connection.ConnectionProvider</"
@@ -200,20 +183,18 @@
 "literal>)"
 
 #. Tag: para
-#: architecture.xml:155
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "(Optional) A factory for, and pool of, JDBC connections. It abstracts the "
 "application from underlying <literal>Datasource</literal> or "
 "<literal>DriverManager</literal>. It is not exposed to application, but it "
 "can be extended and/or implemented by the developer."
 msgstr ""
-"(可选的)生成JDBC连接的工厂(同时也起到连接池的作用)。 它通过抽象将应用从底"
-"层的<literal>Datasource</literal>或<literal>DriverManager</literal>隔离开。 "
-"仅供开发者扩展/实现用,并不暴露给应用程序使用。"
+"(可选的)生成 JDBC 连接的工厂(同时也起到连接池的作用)。它通过抽象将应用从"
+"底层的 <literal>Datasource</literal> 或 <literal>DriverManager</literal> 隔离"
+"开。仅供开发者扩展/实现用,并不开放给应用程序使用。"
 
 #. Tag: term
-#: architecture.xml:163
 #, no-c-format
 msgid ""
 "TransactionFactory (<literal>org.hibernate.TransactionFactory</literal>)"
@@ -221,88 +202,80 @@
 "TransactionFactory (<literal>org.hibernate.TransactionFactory</literal>)"
 
 #. Tag: para
-#: architecture.xml:165
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "(Optional) A factory for <literal>Transaction</literal> instances. It is not "
 "exposed to the application, but it can be extended and/or implemented by the "
 "developer."
 msgstr ""
-"(可选的)生成<literal>Transaction</literal>对象实例的工厂。 仅供开发者扩展/"
-"实现用,并不暴露给应用程序使用。"
+"(可选的)生成 <literal>Transaction</literal> 对象实例的工厂。仅供开发者扩展/"
+"实现用,并不开发能够给应用程序使用。"
 
-#. Tag: emphasis
-#: architecture.xml:172
-#, no-c-format
-msgid "Extension Interfaces"
-msgstr "扩展接口"
+#. Tag: term
+#, fuzzy, no-c-format
+msgid "<emphasis>Extension Interfaces</emphasis>"
+msgstr "<emphasis>扩展接口</emphasis>"
 
 #. Tag: para
-#: architecture.xml:174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate offers a range of optional extension interfaces you can implement "
 "to customize the behavior of your persistence layer. See the API "
 "documentation for details."
 msgstr ""
-"Hibernate提供了很多可选的扩展接口,你可以通过实现它们来定制你的持久层的行"
-"为。 具体请参考API文档。"
+"Hibernate 提供了很多可选的扩展接口,你可以通过实现它们来定制你的持久层的行"
+"为。具体请参考 API 文档。"
 
 #. Tag: para
-#: architecture.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Given a \"minimal\" architecture, the application bypasses the "
 "<literal>Transaction</literal>/<literal>TransactionFactory</literal> and/or "
 "<literal>ConnectionProvider</literal> APIs to communicate with JTA or JDBC "
 "directly."
 msgstr ""
-"在特定“轻型”的体系结构中,应用程序可能绕过 <literal>Transaction</literal>/"
+"在特定“最小”的体系结构中,应用程序可能绕过  <literal>Transaction</literal>/"
 "<literal>TransactionFactory</literal> 以及 <literal>ConnectionProvider</"
-"literal> 等API直接跟JTA或JDBC打交道。"
+"literal> 等 API 直接跟 JTA 或 JDBC 打交道。"
 
 #. Tag: title
-#: architecture.xml:191
 #, no-c-format
 msgid "Instance states"
 msgstr "实例状态"
 
 #. Tag: para
-#: architecture.xml:192
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of a persistent class can be in one of three different states. "
 "These states are defined in relation to a <emphasis>persistence context</"
 "emphasis>. The Hibernate <literal>Session</literal> object is the "
 "persistence context. The three different states are as follows:"
 msgstr ""
-"一个持久化类的实例可能处于三种不同状态中的某一种。 这三种状态的定义则与所谓的"
-"<emphasis>持久化上下文(persistence context)</emphasis>有关。 Hibernate的"
-"<literal>Session</literal>对象就是这个所谓的持久化上下文:"
+"一个持久化类的实例可能处于三种不同状态中的某一种。这三种状态的定义则与所谓的"
+"<emphasis>持久化上下文(persistence context)</emphasis>有关。Hibernate 的 "
+"<literal>Session</literal> 对象就是这个所谓的持久化上下文。这三种不同的状态如"
+"下:"
 
 #. Tag: term
-#: architecture.xml:200
 #, no-c-format
 msgid "transient"
 msgstr "瞬态(transient)"
 
 #. Tag: para
-#: architecture.xml:202
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The instance is not associated with any persistence context. It has no "
 "persistent identity or primary key value."
-msgstr "该实例从未与任何持久化上下文关联过。它没有持久化标识(相当于主键值)。"
+msgstr ""
+"该实例从未与任何持久化上下文关联过。它没有持久化标识(相当于主键值)。 "
 
 #. Tag: term
-#: architecture.xml:210
 #, no-c-format
 msgid "persistent"
-msgstr "持久化(persistent)"
+msgstr "持久化(persistent)"
 
 #. Tag: para
-#: architecture.xml:212
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The instance is currently associated with a persistence context. It has a "
 "persistent identity (primary key value) and can have a corresponding row in "
@@ -310,19 +283,17 @@
 "<emphasis>guarantees</emphasis> that persistent identity is equivalent to "
 "Java identity in relation to the in-memory location of the object."
 msgstr ""
-"实例目前与某个持久化上下文有关联。 它拥有持久化标识(相当于主键值),并且可能"
-"在数据库中有一个对应的行。 对于某一个特定的持久化上下文,Hibernate<emphasis>"
-"保证</emphasis>持久化标识与Java标识(其值代表对象在内存中的位置)等价。"
+"实例目前与某个持久化上下文有关联。它拥有持久化标识(相当于主键值),并且可能"
+"在数据库中有一个对应的行。对于某一个特定的持久化上下文,Hibernate <emphasis>"
+"保证</emphasis> 持久化标识与 Java 标识(其值代表对象在内存中的位置)等价。 "
 
 #. Tag: term
-#: architecture.xml:224
 #, no-c-format
 msgid "detached"
-msgstr "脱管(detached)"
+msgstr "脱管(detached)"
 
 #. Tag: para
-#: architecture.xml:226
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The instance was once associated with a persistence context, but that "
 "context was closed, or the instance was serialized to another process. It "
@@ -330,45 +301,41 @@
 "For detached instances, Hibernate does not guarantee the relationship "
 "between persistent identity and Java identity."
 msgstr ""
-"实例曾经与某个持久化上下文发生过关联,不过那个上下文被关闭了, 或者这个实例是"
-"被序列化(serialize)到另外的进程。 它拥有持久化标识,并且在数据库中可能存在一"
-"个对应的行。 对于脱管状态的实例,Hibernate不保证任何持久化标识和Java标识的关"
-"系。"
+"实例曾经与某个持久化上下文发生过关联,不过那个上下文被关闭了,或者这个实例是"
+"被序列化(serialize)到另外的进程。它拥有持久化标识,并且在数据库中可能存在一"
+"个对应的行。对于脱管状态的实例,Hibernate 不保证任何持久化标识和 Java 标识的"
+"关系。 "
 
 #. Tag: title
-#: architecture.xml:241
 #, no-c-format
 msgid "JMX Integration"
-msgstr "JMX整合"
+msgstr "JMX 整合"
 
 #. Tag: para
-#: architecture.xml:243
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "JMX is the J2EE standard for the management of Java components. Hibernate "
 "can be managed via a JMX standard service. AN MBean implementation is "
 "provided in the distribution: <literal>org.hibernate.jmx.HibernateService</"
 "literal>."
 msgstr ""
-"JMX是管理Java组件(Java components)的J2EE标准。 Hibernate 可以通过一个JMX标准"
-"服务来管理。 在这个发行版本中,我们提供了一个MBean接口的实现,即 <literal>org."
-"hibernate.jmx.HibernateService</literal>。"
+"JMX 是管理 Java 组件的 J2EE 标准。Hibernate 可以通过一个 JMX 标准服务来管理。"
+"在这个发行版本中,我们提供了一个 MBean 接口的实现,即 <literal>org.hibernate."
+"jmx.HibernateService</literal>。 "
 
 #. Tag: para
-#: architecture.xml:249
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For an example of how to deploy Hibernate as a JMX service on the JBoss "
 "Application Server, please see the JBoss User Guide. JBoss AS also provides "
 "these benefits if you deploy using JMX:"
 msgstr ""
-"想要看如何在JBoss应用服务器上将Hibernate部署为一个JMX服务的例子,您可以参考"
-"JBoss用户指南。 我们现在说一下在Jboss应用服务器上,使用JMX来部署Hibernate的好"
-"处:"
+"想要看如何在 JBoss 应用服务器上将 Hibernate 部署为一个 JMX 服务的例子,您可以"
+"参考《JBoss 用户指南》。如果你使用 JMX 来部署 Hibernate,JBoss AS 也提供如下"
+"好处:"
 
 #. Tag: para
-#: architecture.xml:257
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Session Management</emphasis>: the Hibernate <literal>Session</"
 "literal>'s life cycle can be automatically bound to the scope of a JTA "
@@ -380,16 +347,15 @@
 "the <literal>HibernateContext</literal> to access a <literal>Session</"
 "literal>."
 msgstr ""
-"<emphasis>Session管理:</emphasis> Hibernate的<literal>Session</literal>对象"
-"的生命周期可以 自动跟一个JTA事务边界绑定。这意味着你无需手工开关"
-"<literal>Session</literal>了, 这项 工作会由JBoss EJB 拦截器来完成。你再也不用"
-"担心你的代码中的事务边界了(除非你想利用Hibernate提供可选 的"
-"<literal>Transaction</literal> API来自己写一个便于移植的的持久层)。 你通过调"
-"用<literal>HibernateContext</literal>来访问<literal>Session</literal>。"
+"<emphasis>会话管理:</emphasis> Hibernate 的 <literal>Session</literal> 对象"
+"的生命周期可以 自动跟一个 JTA 事务边界绑定。这意味着你无需手工开关 "
+"<literal>Session</literal> 了, 这项工作会由 JBoss EJB 拦截器来完成。你再也不"
+"用担心你的代码中的事务边界了(除非你想利用 Hibernate 提供可选的 "
+"<literal>Transaction</literal> API 来自己写一个便于移植的的持久层)。你通过调"
+"用 <literal>HibernateContext</literal> 来访问 <literal>Session</literal>。"
 
 #. Tag: para
-#: architecture.xml:269
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>HAR deployment</emphasis>: the Hibernate JMX service is deployed "
 "using a JBoss service deployment descriptor in an EAR and/or SAR file, as it "
@@ -399,56 +365,50 @@
 "deployment, JBoss will automatically detect all mapping files in your HAR "
 "file."
 msgstr ""
-"<emphasis>HAR 部署:</emphasis> 通常情况下,你会使用JBoss的服务部署描述符(在"
-"EAR或/和SAR文件中)来部署Hibernate JMX服务。 这种部署方式支持所有常见的"
-"Hibernate <literal>SessionFactory</literal>的配置选项。 不过,你仍需在部署描"
-"述符中,列出你所有的映射文件的名字。如果你使用HAR部署方式, JBoss 会自动探测出"
-"你的HAR文件中所有的映射文件。"
+"<emphasis>HAR 部署:</emphasis> 通常情况下,你会使用 JBoss 的服务部署描述符"
+"(在 EAR 或/和 SAR 文件中)来部署 Hibernate JMX 服务。这种部署方式支持所有常"
+"见的 Hibernate <literal>SessionFactory</literal> 的配置选项。不过,你仍需在部"
+"署描述符中,列出你所有的映射文的名字。如果你使用 HAR 部署方式, JBoss 会自动探"
+"测出你的 HAR 文件中所有的映射文件。"
 
 #. Tag: para
-#: architecture.xml:280
 #, no-c-format
 msgid ""
 "Consult the JBoss AS user guide for more information about these options."
-msgstr "这些选项更多的描述,请参考JBoss 应用程序用户指南。"
+msgstr "这些选项更多的描述,请参考 JBoss 应用程序用户指南。"
 
 #. Tag: para
-#: architecture.xml:284
 #, fuzzy, no-c-format
 msgid ""
 "Another feature available as a JMX service is runtime Hibernate statistics. "
-"See <xref linkend=\"configuration-optional-statistics\"/> for more "
+"See <xref linkend=\"configuration-optional-statistics\" /> for more "
 "information."
 msgstr ""
-"将Hibernate以部署为JMX服务的另一个好处,是可以查看Hibernate的运行时统计信息。"
-"参看 <xref linkend=\"configuration-optional-statistics\"/>."
+"将 Hibernate 以部署为 JMX 服务的另一个好处是可以查看 Hibernate 的运行时统计信"
+"息。参看 <xref linkend=\"configuration-optional-statistics\"/>。"
 
 #. Tag: title
-#: architecture.xml:291
 #, no-c-format
 msgid "JCA Support"
-msgstr "对JCA的支持"
+msgstr "对 JCA 的支持"
 
 #. Tag: para
-#: architecture.xml:292
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate can also be configured as a JCA connector. Please see the website "
 "for more information. Please note, however, that at this stage Hibernate JCA "
 "support is under development."
 msgstr ""
-"Hibernate也可以被配置为一个JCA连接器(JCA connector)。更多信息请参看网站。 "
-"请注意,Hibernate对JCA的支持,仍处于实验性阶段。"
+"Hibernate 也可以被配置为一个 JCA 连接器(JCA connector)。更多信息请参看网"
+"站。请注意,Hibernate 对 JCA 的支持,仍处于实验性阶段。"
 
 #. Tag: title
-#: architecture.xml:299
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Contextual sessions"
-msgstr "上下文相关的(Contextual)Session"
+msgstr "上下文相关的会话(Contextual Session)"
 
 #. Tag: para
-#: architecture.xml:300
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Most applications using Hibernate need some form of \"contextual\" session, "
 "where a given session is in effect throughout the scope of a given context. "
@@ -460,18 +420,17 @@
 "utilized third-party frameworks, such as Spring or Pico, which provided "
 "proxy/interception-based contextual sessions."
 msgstr ""
-"使用Hibernate的大多数应用程序需要某种形式的“上下文相关的” session,特定的"
-"session在整个特定的上下文范围内始终有效。然而,对不同类型的应用程序而言,要为"
-"什么是组成这种“上下文”下一个定义通常是困难的;不同的上下文对“当前”这个概念定"
-"义了不同的范围。在3.0版本之前,使用Hibernate的程序要么采用自行编写的基于"
-"<literal>ThreadLocal</literal>的上下文session,要么采用"
-"<literal>HibernateUtil</literal>这样的辅助类,要么采用第三方框架(比如Spring"
-"或Pico),它们提供了基于代理(proxy)或者基于拦截器(interception)的上下文相关"
-"session。"
+"使用 Hibernate 的大多数应用程序需要某种形式的“上下文相关的”会话,特定的会话在"
+"整个特定的上下文范围内始终有效。然而,对不同类型的应用程序而言,要为什么是组"
+"成这种“上下文”下一个定义通常是困难的;不同的上下文对“当前”这个概念定义了不同"
+"的范围。在 3.0 版本之前,使用 Hibernate 的程序要么采用自行编写的基于 "
+"<literal>ThreadLocal</literal> 的上下文会话,要么采用 "
+"<literal>HibernateUtil</literal> 这样的辅助类,要么采用第三方框架(比如 "
+"Spring 或 Pico),它们提供了基于代理(proxy)或者基于拦截器(interception)的"
+"上下文相关的会话。"
 
 #. Tag: para
-#: architecture.xml:309
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Starting with version 3.0.1, Hibernate added the <literal>SessionFactory."
 "getCurrentSession()</literal> method. Initially, this assumed usage of "
@@ -483,17 +442,16 @@
 "deployed into a <literal>J2EE</literal> container. Based on that, the "
 "<literal>JTA</literal>-based contextual sessions are all you need to use."
 msgstr ""
-"从3.0.1版本开始,Hibernate增加了<literal>SessionFactory.getCurrentSession()</"
-"literal>方法。一开始,它假定了采用<literal>JTA</literal>事务,<literal>JTA</"
-"literal>事务定义了当前session的范围和上下文(scope and context)。Hibernate开发"
-"团队坚信,因为有好几个独立的<literal>JTA TransactionManager</literal>实现稳定"
-"可用,不论是否被部署到一个<literal>J2EE</literal>容器中,大多数(假若不是所有"
-"的)应用程序都应该采用<literal>JTA</literal>事务管理。基于这一点,采用"
-"<literal>JTA</literal>的上下文相关session可以满足你一切需要。"
+"从 3.0.1 版本开始,Hibernate 增加了 <literal>SessionFactory.getCurrentSession"
+"()</literal> 方法。一开始,它假定了采用 <literal>JTA</literal> 事务,"
+"<literal>JTA</literal> 事务定义了当前 session 的范围和上下文(scope 和 "
+"context)。因为有好几个独立的 <literal>JTA TransactionManager</literal> 实现"
+"稳定可用,不论是否被部署到一个 <literal>J2EE</literal> 容器中,大多数(假若不"
+"是所有的)应用程序都应该采用 <literal>JTA</literal> 事务管理。基于这一点,采"
+"用 <literal>JTA</literal> 的上下文相关的会话可以满足你一切需要。"
 
 #. Tag: para
-#: architecture.xml:319
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, as of version 3.1, the processing behind <literal>SessionFactory."
 "getCurrentSession()</literal> is now pluggable. To that end, a new extension "
@@ -502,15 +460,14 @@
 "current_session_context_class</literal>, have been added to allow "
 "pluggability of the scope and context of defining current sessions."
 msgstr ""
-"更好的是,从3.1开始,<literal>SessionFactory.getCurrentSession()</literal>的"
-"后台实现是可拔插的。因此,我们引入了新的扩展接口(<literal>org.hibernate."
-"context.CurrentSessionContext</literal>)和新的配置参数(<literal>hibernate."
-"current_session_context_class</literal>),以便对什么是“当前session”的范围和上"
-"下文(scope and context)的定义进行拔插。"
+"更好的是,从 3.1 开始,<literal>SessionFactory.getCurrentSession()</literal> "
+"的后台实现是可拔插的。因此,我们引入了新的扩展接口(<literal>org.hibernate."
+"context.CurrentSessionContext</literal>)和新的配置参数(<literal>hibernate."
+"current_session_context_class</literal>),以便对什么是当前会话的范围"
+"(scope)和上下文(context)的定义进行拔插。"
 
 #. Tag: para
-#: architecture.xml:326
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "See the Javadocs for the <literal>org.hibernate.context."
 "CurrentSessionContext</literal> interface for a detailed discussion of its "
@@ -519,50 +476,46 @@
 "contextual session. Out-of-the-box, Hibernate comes with three "
 "implementations of this interface:"
 msgstr ""
-"请参阅<literal>org.hibernate.context.CurrentSessionContext</literal>接口的"
-"Javadoc,那里有关于它的契约的详细讨论。它定义了单一的方法,"
-"<literal>currentSession()</literal>,特定的实现用它来负责跟踪当前的上下文"
-"session。Hibernate内置了此接口的三种实现。"
+"请参阅 <literal>org.hibernate.context.CurrentSessionContext</literal> 接口的 "
+"Javadoc,那里有关于它的契约的详细讨论。它定义了单一的方法,"
+"<literal>currentSession()</literal>,特定的实现用它来负责跟踪当前的上下文相关"
+"的会话。Hibernate 内置了此接口的三种实现:"
 
 #. Tag: para
-#: architecture.xml:336
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.context.JTASessionContext</literal>: current sessions "
 "are tracked and scoped by a <literal>JTA</literal> transaction. The "
 "processing here is exactly the same as in the older JTA-only approach. See "
 "the Javadocs for details."
 msgstr ""
-"<literal>org.hibernate.context.JTASessionContext</literal> - 当前session根据"
-"<literal>JTA</literal>来跟踪和界定。这和以前的仅支持JTA的方法是完全一样的。详"
-"情请参阅Javadoc。"
+"<literal>org.hibernate.context.JTASessionContext</literal>:当前会话根据 "
+"<literal>JTA</literal> 来跟踪和界定。这和以前的仅支持 JTA 的方法是完全一样"
+"的。详情请参阅 Javadoc。"
 
 #. Tag: para
-#: architecture.xml:344
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.context.ThreadLocalSessionContext</literal>:current "
 "sessions are tracked by thread of execution. See the Javadocs for details."
 msgstr ""
-"<literal>org.hibernate.context.ThreadLocalSessionContext</literal> - 当前"
-"session通过当前执行的线程来跟踪和界定。详情也请参阅Javadoc。"
+"<literal>org.hibernate.context.ThreadLocalSessionContext</literal>:当前会话"
+"通过当前执行的线程来跟踪和界定。详情也请参阅 Javadoc。"
 
 #. Tag: para
-#: architecture.xml:350
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.context.ManagedSessionContext</literal>: current "
 "sessions are tracked by thread of execution. However, you are responsible to "
 "bind and unbind a <literal>Session</literal> instance with static methods on "
 "this class: it does not open, flush, or close a <literal>Session</literal>."
 msgstr ""
-"<literal>org.hibernate.context.ManagedSessionContext</literal> - 当前session"
-"通过当前执行的线程来跟踪和界定。但是,你需要负责使用这个类的静态方法将"
-"<literal>Session</literal>实例绑定、或者取消绑定,它并不会打开(open)、flush或"
-"者关闭(close)任何<literal>Session</literal>。"
+"<literal>org.hibernate.context.ManagedSessionContext</literal>:当前会话通过"
+"当前执行的线程来跟踪和界定。但是,你需要负责使用这个类的静态方法将 "
+"<literal>Session</literal> 实例绑定、或者取消绑定,它并不会打开(open)、"
+"flush 或者关闭(close)任何 <literal>Session</literal>。"
 
 #. Tag: para
-#: architecture.xml:359
 #, fuzzy, no-c-format
 msgid ""
 "The first two implementations provide a \"one session - one database "
@@ -575,21 +528,20 @@
 "utilize the JTA interfaces to demarcate transactions. If you execute in an "
 "EJB container that supports CMT, transaction boundaries are defined "
 "declaratively and you do not need any transaction or session demarcation "
-"operations in your code. Refer to <xref linkend=\"transactions\"/> for more "
+"operations in your code. Refer to <xref linkend=\"transactions\" /> for more "
 "information and code examples."
 msgstr ""
-"前两种实现都提供了“每数据库事务对应一个session”的编程模型,也称作<emphasis>每"
-"次请求一个session</emphasis>。Hibernate session的起始和终结由数据库事务的生存"
-"来控制。假若你在纯粹的 Java SE之上采用自行编写代码来管理事务,而不使用JTA,建"
-"议你使用Hibernate <literal>Transaction</literal> API来把底层事务实现从你的代"
-"码中隐藏掉。如果你使用JTA,请使用JTA借口来管理Transaction。如果你在支持CMT的"
-"EJB容器中执行代码,事务边界是声明式定义的,你不需要在代码中进行任何事务或"
-"session管理操作。请参阅<xref linkend=\"transactions\"/>一节来阅读更多的内容和"
-"示例代码。"
+"前两种实现都提供了“one session - one database transaction”的编程模型,也称作 "
+"<emphasis>session-per-request</emphasis>。Hibernate session 的起始和终结由数"
+"据库事务的生存来控制。假若你在纯粹的 Java SE 之上采用自行编写代码来管理事务,"
+"而不使用 JTA,建议你使用 Hibernate <literal>Transaction</literal> API 来把底"
+"层事务实现从你的代码中隐藏掉。如果你使用 JTA,请使用 JTA 接口来对事务限界。如"
+"果你在支持 CMT 的 EJB 容器中执行代码,事务边界是声明式定义的,你不需要在代码"
+"中进行任何事务或会话管理操作。请参阅 <xref linkend=\"transactions\"/> 一节来"
+"阅读更多的内容和示例代码。"
 
 #. Tag: para
-#: architecture.xml:371
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>hibernate.current_session_context_class</literal> configuration "
 "parameter defines which <literal>org.hibernate.context."
@@ -602,10 +554,10 @@
 "however, there are three corresponding short names: \"jta\", \"thread\", and "
 "\"managed\"."
 msgstr ""
-"<literal>hibernate.current_session_context_class</literal>配置参数定义了应该"
-"采用哪个<literal>org.hibernate.context.CurrentSessionContext</literal>实现。"
-"注意,为了向下兼容,如果未配置此参数,但是存在<literal>org.hibernate."
-"transaction.TransactionManagerLookup</literal>的配置,Hibernate会采用"
+"<literal>hibernate.current_session_context_class</literal> 配置参数定义了应该"
+"采用哪个 <literal>org.hibernate.context.CurrentSessionContext</literal> 实"
+"现。注意,为了向下兼容,如果未配置此参数,但是存在 <literal>org.hibernate."
+"transaction.TransactionManagerLookup</literal> 的配置,Hibernate 会采用"
 "<literal>org.hibernate.context.JTASessionContext</literal>。一般而言,此参数"
-"的值指明了要使用的实现类的全名,但那三种内置的实现可以使用简写,即\"jta\"、"
-"\"thread\"和\"managed\"。"
+"的值指明了要使用的实现类的全名,但那三种内置的实现可以使用简写,即 \"jta\"、"
+"\"thread\" 和 \"managed\"。 "

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/association_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/association_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/association_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,30 +1,32 @@
+# translation of association_mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007, 2009.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: association_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.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 at redhat.com>\n"
+"Language-Team:  <en at 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
-#: association_mapping.xml:30
 #, no-c-format
 msgid "Association Mappings"
 msgstr "关联关系映射"
 
 #. Tag: title
-#: association_mapping.xml:33
 #, no-c-format
 msgid "Introduction"
 msgstr "介绍"
 
 #. Tag: para
-#: association_mapping.xml:35
-#, fuzzy, no-c-format
+#, 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, "
@@ -33,94 +35,52 @@
 "examples."
 msgstr ""
 "关联关系映射通常情况是最难配置正确的。在这个部分中,我们从单向关系映射开始,"
-"然后考虑双向关系映射,由浅至深讲述一遍典型的案例。在所有的例子中,我们都使用 "
-"<literal>Person</literal>和<literal>Address</literal>。"
+"然后考虑双向关系映射,逐步讲解典型的案例。在所有的例子中,我们都使将用 "
+"<literal>Person</literal> 和 <literal>Address</literal>。"
 
 #. Tag: para
-#: association_mapping.xml:43
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Associations will be classified by multiplicity and whether or not they map "
 "to an intervening join table."
-msgstr "我们根据映射关系是否涉及连接表以及多样性来划分关联类型。"
+msgstr ""
+"我们根据映射关系是否涉及连接表以及多样性(multiplicity)来划分关联类型。 "
 
 #. Tag: para
-#: association_mapping.xml:48
-#, fuzzy, no-c-format
+#, 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映射一样可以工作的很好。"
+"在传统的数据建模中,允许为 Null 值的外键被认为是一种不好的实践,因此我们所有"
+"的例子中都使用不允许为 Null 的外键。这并不是 Hibernate的 要求,即使你删除掉不"
+"允许为 Null 的约束,Hibernate 映射一样可以工作的很好。 "
 
 #. Tag: title
-#: association_mapping.xml:58
 #, no-c-format
 msgid "Unidirectional associations"
 msgstr "单向关联(Unidirectional associations)"
 
 #. Tag: title
-#: association_mapping.xml:61 association_mapping.xml:132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Many-to-one"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"多对一(many to one)\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"多对一(many to one)"
+msgstr "多对一(many-to-one) "
 
 #. Tag: para
-#: association_mapping.xml:63
 #, no-c-format
 msgid ""
 "A <emphasis>unidirectional many-to-one association</emphasis> is the most "
 "common kind of unidirectional association."
-msgstr "<emphasis>单向many-to-one关联</emphasis>是最常见的单向关联关系。"
+msgstr "<emphasis>单向 many-to-one 关联</emphasis>是最常见的单向关联关系。"
 
-#. Tag: programlisting
-#: association_mapping.xml:68
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:69 association_mapping.xml:185
-#, no-c-format
-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 ""
-
-#. Tag: title
-#: association_mapping.xml:74 association_mapping.xml:145
-#: association_mapping.xml:210
-#, fuzzy, no-c-format
 msgid "One-to-one"
-msgstr "一对一(one to one)"
+msgstr "一对一(One-to-one)"
 
 #. Tag: para
-#: association_mapping.xml:76
 #, no-c-format
 msgid ""
 "A <emphasis>unidirectional one-to-one association on a foreign key</"
@@ -131,147 +91,42 @@
 "emphasis>几乎是一样的。唯一的不同就是单向一对一关联中的外键字段具有唯一性约"
 "束。"
 
-#. Tag: programlisting
-#: association_mapping.xml:81
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:82 association_mapping.xml:218
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:84
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>unidirectional one-to-one association on a primary key</"
 "emphasis> usually uses a special id generator In this example, however, we "
 "have reversed the direction of the association:"
 msgstr ""
-"<emphasis>基于主键关联的单向一对一关联</emphasis>通常使用一个特定的id生成器。"
-"(请注意,在这个例子中我们掉换了关联的方向。)"
+"<emphasis>基于主键关联的单向一对一关联</emphasis>通常使用一个特定的 id 生成"
+"器,然而在这个例子中我们掉换了关联的方向:"
 
-#. Tag: programlisting
-#: association_mapping.xml:90
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" constrained=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:91 association_mapping.xml:226
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"create table Person ( personId bigint not null primary key )\n"
-"create table Address ( personId bigint not null primary key )\n"
-"        ]]>"
-msgstr ""
-
-#. Tag: title
-#: association_mapping.xml:96 association_mapping.xml:118
-#, fuzzy, no-c-format
 msgid "One-to-many"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"一对多(one to many)\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"一对多(one to many)"
+msgstr "一对多(one-to-many) "
 
 #. Tag: para
-#: association_mapping.xml:98
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>unidirectional one-to-many association on a foreign key</"
 "emphasis> is an unusual case, and is not recommended."
 msgstr ""
-"<emphasis>基于外键关联的单向一对多关联</emphasis>是一种很少见的情况,并不推荐"
-"使用。"
+"<emphasis>基于外键关联的单向一对多关联</emphasis>是一种很少见的情况,我们不推"
+"荐使用它。"
 
-#. Tag: programlisting
-#: association_mapping.xml:103
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\">\n"
-"        <key column=\"personId\" \n"
-"            not-null=\"true\"/>\n"
-"        <one-to-many class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:104
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:106
-#, fuzzy, no-c-format
 msgid "You should instead use a join table for this kind of association."
-msgstr "我们认为对于这种关联关系最好使用连接表。"
+msgstr "我们认为对于这种关联关系最好使用连接表。 "
 
 #. Tag: title
-#: association_mapping.xml:115
 #, no-c-format
 msgid "Unidirectional associations with join tables"
 msgstr "使用连接表的单向关联(Unidirectional associations with join tables)"
 
 #. Tag: para
-#: association_mapping.xml:120
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>unidirectional one-to-many association on a join table</"
 "emphasis> is the preferred option. Specifying <literal>unique=\"true\"</"
@@ -281,237 +136,58 @@
 "指定<literal>unique=\"true\"</literal>,我们可以把多样性从多对多改变为一对"
 "多。"
 
-#. Tag: programlisting
-#: association_mapping.xml:126
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:127
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:134
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>unidirectional many-to-one association on a join table</"
 "emphasis> is common when the association is optional. For example:"
 msgstr ""
 "<emphasis>基于连接表的单向多对一关联</emphasis>在关联关系可选的情况下应用也很"
-"普遍。"
+"普遍。例如:"
 
-#. Tag: programlisting
-#: association_mapping.xml:139
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:140
-#, no-c-format
-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 ""
-
-#. Tag: para
-#: association_mapping.xml:147
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>unidirectional one-to-one association on a join table</emphasis> "
 "is possible, but extremely unusual."
 msgstr ""
-"<emphasis>基于连接表的单向一对一关联</emphasis>非常少见,但也是可行的。"
+"<emphasis>基于连接表的单向一对一关联</emphasis>也是可行的,但非常少见。"
 
-#. Tag: programlisting
-#: association_mapping.xml:152
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:153 association_mapping.xml:258
-#, no-c-format
-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 ""
-
-#. Tag: title
-#: association_mapping.xml:158 association_mapping.xml:263
-#, fuzzy, no-c-format
 msgid "Many-to-many"
-msgstr "多对多(many to many)"
+msgstr "多对多(many-to-many) "
 
 #. Tag: para
-#: association_mapping.xml:160
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, here is an example of a <emphasis>unidirectional many-to-many "
 "association</emphasis>."
-msgstr "最后,还有 <emphasis>单向多对多关联</emphasis>."
+msgstr "最后,这里是一个<emphasis>单向多对多关联</emphasis>的例子。"
 
-#. Tag: programlisting
-#: association_mapping.xml:164
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:165 association_mapping.xml:271
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: association_mapping.xml:172
 #, no-c-format
 msgid "Bidirectional associations"
 msgstr "双向关联(Bidirectional associations)"
 
 #. Tag: title
-#: association_mapping.xml:175 association_mapping.xml:236
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "one-to-many / many-to-one"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"一对多(one to many) / 多对一(many to one)\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"一对多(one to many) /多对一( many to one)"
+msgstr "一对多(one to many)/多对一(many to one) "
 
 #. Tag: para
-#: association_mapping.xml:177
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional many-to-one association</emphasis> is the most "
 "common kind of association. The following example illustrates the standard "
 "parent/child relationship."
 msgstr ""
-"<emphasis>双向多对一关联</emphasis> 是最常见的关联关系。(这也是标准的父/子关"
-"联关系。)"
+"<emphasis>双向多对一关联</emphasis> 是最常见的关联关系。下面的例子解释了这种"
+"标准的父/子关联关系。"
 
-#. Tag: programlisting
-#: association_mapping.xml:183
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <one-to-many class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:187
-#, fuzzy, no-c-format
-msgid ""
 "If you use a <literal>List</literal>, or other indexed collection, set the "
 "<literal>key</literal> column of the foreign key to <literal>not null</"
 "literal>. Hibernate will manage the association from the collections side to "
@@ -519,40 +195,14 @@
 "by setting <literal>update=\"false\"</literal> and <literal>insert=\"false"
 "\"</literal>:"
 msgstr ""
-"如果你使用<literal>List</literal>(或者其他有序集合类),你需要设置外键对应的"
-"<literal>key</literal>列为 <literal>not null</literal>,让Hibernate来从集合端"
-"管理关联,维护每个元素的索引(通过设置<literal>update=\"false\"</literal> "
-"and <literal>insert=\"false\"</literal>来对另一端反向操作)。"
+"如果你使用 <literal>List</literal>(或者其他有序集合类),你需要设置外键对应"
+"的 <literal>key</literal> 列为 <literal>not null</literal>。Hibernate 将从集"
+"合端管理关联,维护每个元素的索引,并通过设置 <literal>update=\"false\"</"
+"literal> 和 <literal>insert=\"false\"</literal> 来对另一端反向操作。"
 
-#. Tag: programlisting
-#: association_mapping.xml:195
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"   <id name=\"id\"/>\n"
-"   ...\n"
-"   <many-to-one name=\"address\"\n"
-"      column=\"addressId\"\n"
-"      not-null=\"true\"\n"
-"      insert=\"false\"\n"
-"      update=\"false\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"   <id name=\"id\"/>\n"
-"   ...\n"
-"   <list name=\"people\">\n"
-"      <key column=\"addressId\" not-null=\"true\"/>\n"
-"      <list-index column=\"peopleIdx\"/>\n"
-"      <one-to-many class=\"Person\"/>\n"
-"   </list>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:197
-#, fuzzy, no-c-format
-msgid ""
 "If the underlying foreign key column is <literal>NOT NULL</literal>, it is "
 "important that you define <literal>not-null=\"true\"</literal> on the "
 "<literal>&lt;key&gt;</literal> element of the collection mapping. Do not "
@@ -560,230 +210,71 @@
 "<literal>&lt;column&gt;</literal> element, but on the <literal>&lt;key&gt;</"
 "literal> element."
 msgstr ""
-"假若集合映射的<literal>&lt;key&gt;</literal>元素对应的底层外键字段是"
-"<literal>NOT NULL</literal>的,那么为这一key元素定义<literal>not-null=\"true"
-"\"</literal>是很重要的。不要仅仅为可能的嵌套<literal>&lt;column&gt;</literal>"
-"元素定义<literal>not-null=\"true\"</literal>,<literal>&lt;key&gt;</literal>"
-"元素也是需要的。"
+"假若集合映射的 <literal>&lt;key&gt;</literal> 元素对应的底层外键字段是 "
+"<literal>NOT NULL</literal> 的,那么为这一 key 元素定义 <literal>not-null="
+"\"true\"</literal> 是很重要的。不要仅仅为可能的嵌套 <literal>&lt;column&gt;</"
+"literal>元素定义 <literal>not-null=\"true\"</literal>,<literal>&lt;key&gt;</"
+"literal> 元素也是需要的。 "
 
 #. Tag: para
-#: association_mapping.xml:212
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional one-to-one association on a foreign key</emphasis> "
 "is common:"
-msgstr "<emphasis>基于外键关联的双向一对一关联</emphasis>也很常见。"
+msgstr "<emphasis>基于外键关联的双向一对一关联</emphasis>也很常见。 "
 
-#. Tag: programlisting
-#: association_mapping.xml:217
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <many-to-one name=\"address\" \n"
-"        column=\"addressId\" \n"
-"        unique=\"true\"\n"
-"        not-null=\"true\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"   <one-to-one name=\"person\" \n"
-"        property-ref=\"address\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:220
-#, fuzzy, no-c-format
-msgid ""
 "A <emphasis>bidirectional one-to-one association on a primary key</emphasis> "
 "uses the special id generator:"
-msgstr "<emphasis>基于主键关联的一对一关联</emphasis>需要使用特定的id生成器。"
-
-#. Tag: programlisting
-#: association_mapping.xml:225
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <one-to-one name=\"address\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">person</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    <one-to-one name=\"person\" \n"
-"        constrained=\"true\"/>\n"
-"</class>]]>"
 msgstr ""
+"<emphasis>基于主键关联的一对一关联</emphasis>需要使用特定的 id 生成器:"
 
 #. Tag: title
-#: association_mapping.xml:233
 #, no-c-format
 msgid "Bidirectional associations with join tables"
 msgstr "使用连接表的双向关联(Bidirectional associations with join tables)"
 
 #. Tag: para
-#: association_mapping.xml:238
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is an example of a <emphasis>bidirectional one-to-many "
 "association on a join table</emphasis>. The <literal>inverse=\"true\"</"
 "literal> can go on either end of the association, on the collection, or on "
 "the join."
 msgstr ""
-"<emphasis>基于连接表的双向一对多关联</emphasis>。注意<literal>inverse=\"true"
-"\"</literal>可以出现在关联的任意一端,即collection端或者join端。"
+"下面是一个<emphasis>基于连接表的双向一对多关联</emphasis>的例子。注意 "
+"<literal>inverse=\"true\"</literal> 可以出现在关联的任意一端,即 collection "
+"端或者 join 端。"
 
-#. Tag: programlisting
-#: association_mapping.xml:244
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" \n"
-"        table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            unique=\"true\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        inverse=\"true\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-one name=\"person\"\n"
-"            column=\"personId\"\n"
-"            not-null=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: association_mapping.xml:245
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: association_mapping.xml:250
 #, no-c-format
 msgid "one to one"
 msgstr "一对一(one to one)"
 
 #. Tag: para
-#: association_mapping.xml:252
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional one-to-one association on a join table</emphasis> "
 "is possible, but extremely unusual."
 msgstr ""
-"<emphasis>基于连接表的双向一对一关联</emphasis>极为罕见,但也是可行的。"
+"<emphasis>基于连接表的双向一对一关联</emphasis>也是可行的,但极为罕见。"
 
-#. Tag: programlisting
-#: association_mapping.xml:257
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\">\n"
-"        <key column=\"personId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"address\"\n"
-"            column=\"addressId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <join table=\"PersonAddress\" \n"
-"        optional=\"true\"\n"
-"        inverse=\"true\">\n"
-"        <key column=\"addressId\" \n"
-"            unique=\"true\"/>\n"
-"        <many-to-one name=\"person\"\n"
-"            column=\"personId\" \n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"    </join>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:265
-#, fuzzy, no-c-format
-msgid ""
 "Here is an example of a <emphasis>bidirectional many-to-many association</"
 "emphasis>."
-msgstr "最后,还有 <emphasis>双向多对多关联</emphasis>."
+msgstr "下面是一个<emphasis>双向多对多关联</emphasis>的例子。"
 
-#. Tag: programlisting
-#: association_mapping.xml:269
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\" column=\"personId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"addresses\" table=\"PersonAddress\">\n"
-"        <key column=\"personId\"/>\n"
-"        <many-to-many column=\"addressId\"\n"
-"            class=\"Address\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"    <id name=\"id\" column=\"addressId\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
-"        <key column=\"addressId\"/>\n"
-"        <many-to-many column=\"personId\"\n"
-"            class=\"Person\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: association_mapping.xml:278
 #, no-c-format
 msgid "More complex association mappings"
 msgstr "更复杂的关联映射"
 
 #. Tag: para
-#: association_mapping.xml:280
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "More complex association joins are <emphasis>extremely</emphasis> rare. "
 "Hibernate handles more complex situations by using SQL fragments embedded in "
@@ -792,52 +283,23 @@
 "<literal>effectiveEndDate</literal> and <literal>effectiveStartDate</"
 "literal>columns, it would be mapped as follows:"
 msgstr ""
-"更复杂的关联连接<emphasis>极为</emphasis>罕见。 通过在映射文档中嵌入SQL片断,"
-"Hibernate也可以处理更为复杂的情况。比如,假若包含历史帐户数据的表定义了"
-"<literal>accountNumber</literal>, <literal>effectiveEndDate</literal> 和"
-"<literal>effectiveStartDate</literal>字段,按照下面映射:"
+"更复杂的关联连接<emphasis>极为</emphasis>罕见。通过在映射文档中嵌入 SQL 片"
+"断,Hibernate 也可以处理更为复杂的情况。比如,假若包含历史帐户数据的表定义了 "
+"<literal>accountNumber</literal>、<literal>effectiveEndDate</literal> 和 "
+"<literal>effectiveStartDate</literal> 字段,按照下面映射:"
 
-#. Tag: programlisting
-#: association_mapping.xml:289
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<properties name=\"currentAccountKey\">\n"
-"    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
-"    <property name=\"currentAccount\" type=\"boolean\">\n"
-"        <formula>case when effectiveEndDate is null then 1 else 0 end</"
-"formula>\n"
-"    </property>\n"
-"</properties>\n"
-"<property name=\"effectiveEndDate\" type=\"date\"/>\n"
-"<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:291
-#, fuzzy, no-c-format
-msgid ""
 "You can then map an association to the <emphasis>current</emphasis> "
 "instance, the one with null <literal>effectiveEndDate</literal>, by using:"
 msgstr ""
-"那么我们可以对<emphasis>目前(current)</emphasis>实例(其"
-"<literal>effectiveEndDate</literal>为null)使用这样的关联映射:"
+"那么我们可以对<emphasis>目前(current)</emphasis>实例(其 "
+"<literal>effectiveEndDate</literal> 为 null)使用这样的关联映射: "
 
-#. Tag: programlisting
-#: association_mapping.xml:296
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
-"        property-ref=\"currentAccountKey\"\n"
-"        class=\"AccountInfo\">\n"
-"    <column name=\"accountNumber\"/>\n"
-"    <formula>'1'</formula>\n"
-"</many-to-one>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:298
-#, fuzzy, no-c-format
-msgid ""
 "In a more complex example, imagine that the association between "
 "<literal>Employee</literal> and <literal>Organization</literal> is "
 "maintained in an <literal>Employment</literal> table full of historical "
@@ -845,34 +307,804 @@
 "emphasis> employer, the one with the most recent <literal>startDate</"
 "literal>, could be mapped in the following way:"
 msgstr ""
-"更复杂的例子,假想<literal>Employee</literal>和<literal>Organization</literal>"
-"之间的关联是通过一个<literal>Employment</literal>中间表维护的,而中间表中填充"
-"了很多历史雇员数据。那“雇员的<emphasis>最新</emphasis>雇主”这个关联(最新雇主"
-"就是<literal>startDate</literal>最后的那个)可以这样映射:"
+"在更复杂的例子中,假想 <literal>Employee</literal> 和 <literal>Organization</"
+"literal> 之间的关联是通过一个 <literal>Employment</literal> 中间表维护的,而"
+"中间表中填充了很多历史雇员数据。那“雇员的<emphasis>最新</emphasis>雇主”这个关"
+"联(最新雇主就是具有最新的 <literal>startDate</literal> 的那个)可以这样映"
+"射:"
 
-#. Tag: programlisting
-#: association_mapping.xml:306
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<join>\n"
-"    <key column=\"employeeId\"/>\n"
-"    <subselect>\n"
-"        select employeeId, orgId \n"
-"        from Employments \n"
-"        group by orgId \n"
-"        having startDate = max(startDate)\n"
-"    </subselect>\n"
-"    <many-to-one name=\"mostRecentEmployer\" \n"
-"            class=\"Organization\" \n"
-"            column=\"orgId\"/>\n"
-"</join>]]>"
-msgstr ""
-
-#. Tag: para
-#: association_mapping.xml:308
-#, fuzzy, 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或条件查询来处理这些情形。"
+"使用这一功能时可以充满创意和灵活性,但通常更加实用的是用 HQL 或条件查询来处理"
+"这些情况。"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" constrained=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        <one-to-many class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        <one-to-many class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <one-to-many class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <one-to-many class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <many-to-one name=\"address\"\n"
+#~ "      column=\"addressId\"\n"
+#~ "      not-null=\"true\"\n"
+#~ "      insert=\"false\"\n"
+#~ "      update=\"false\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <list name=\"people\">\n"
+#~ "      <key column=\"addressId\" not-null=\"true\"/>\n"
+#~ "      <list-index column=\"peopleIdx\"/>\n"
+#~ "      <one-to-many class=\"Person\"/>\n"
+#~ "   </list>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <many-to-one name=\"address\"\n"
+#~ "      column=\"addressId\"\n"
+#~ "      not-null=\"true\"\n"
+#~ "      insert=\"false\"\n"
+#~ "      update=\"false\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "   <id name=\"id\"/>\n"
+#~ "   ...\n"
+#~ "   <list name=\"people\">\n"
+#~ "      <key column=\"addressId\" not-null=\"true\"/>\n"
+#~ "      <list-index column=\"peopleIdx\"/>\n"
+#~ "      <one-to-many class=\"Person\"/>\n"
+#~ "   </list>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "   <one-to-one name=\"person\" \n"
+#~ "        property-ref=\"address\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <many-to-one name=\"address\" \n"
+#~ "        column=\"addressId\" \n"
+#~ "        unique=\"true\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "   <one-to-one name=\"person\" \n"
+#~ "        property-ref=\"address\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"address\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" \n"
+#~ "        constrained=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"address\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">person</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    <one-to-one name=\"person\" \n"
+#~ "        constrained=\"true\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        inverse=\"true\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            unique=\"true\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        inverse=\"true\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+
+#~ 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[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\"\n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"addressId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\">\n"
+#~ "        <key column=\"personId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"address\"\n"
+#~ "            column=\"addressId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <join table=\"PersonAddress\" \n"
+#~ "        optional=\"true\"\n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"addressId\" \n"
+#~ "            unique=\"true\"/>\n"
+#~ "        <many-to-one name=\"person\"\n"
+#~ "            column=\"personId\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "    </join>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-many column=\"personId\"\n"
+#~ "            class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\" column=\"personId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"addresses\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"personId\"/>\n"
+#~ "        <many-to-many column=\"addressId\"\n"
+#~ "            class=\"Address\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "    <id name=\"id\" column=\"addressId\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <set name=\"people\" inverse=\"true\" table=\"PersonAddress\">\n"
+#~ "        <key column=\"addressId\"/>\n"
+#~ "        <many-to-many column=\"personId\"\n"
+#~ "            class=\"Person\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<properties name=\"currentAccountKey\">\n"
+#~ "    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
+#~ "    <property name=\"currentAccount\" type=\"boolean\">\n"
+#~ "        <formula>case when effectiveEndDate is null then 1 else 0 end</"
+#~ "formula>\n"
+#~ "    </property>\n"
+#~ "</properties>\n"
+#~ "<property name=\"effectiveEndDate\" type=\"date\"/>\n"
+#~ "<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<properties name=\"currentAccountKey\">\n"
+#~ "    <property name=\"accountNumber\" type=\"string\" not-null=\"true\"/>\n"
+#~ "    <property name=\"currentAccount\" type=\"boolean\">\n"
+#~ "        <formula>case when effectiveEndDate is null then 1 else 0 end</"
+#~ "formula>\n"
+#~ "    </property>\n"
+#~ "</properties>\n"
+#~ "<property name=\"effectiveEndDate\" type=\"date\"/>\n"
+#~ "<property name=\"effectiveStateDate\" type=\"date\" not-null=\"true\"/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
+#~ "        property-ref=\"currentAccountKey\"\n"
+#~ "        class=\"AccountInfo\">\n"
+#~ "    <column name=\"accountNumber\"/>\n"
+#~ "    <formula>'1'</formula>\n"
+#~ "</many-to-one>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<many-to-one name=\"currentAccountInfo\" \n"
+#~ "        property-ref=\"currentAccountKey\"\n"
+#~ "        class=\"AccountInfo\">\n"
+#~ "    <column name=\"accountNumber\"/>\n"
+#~ "    <formula>'1'</formula>\n"
+#~ "</many-to-one>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<join>\n"
+#~ "    <key column=\"employeeId\"/>\n"
+#~ "    <subselect>\n"
+#~ "        select employeeId, orgId \n"
+#~ "        from Employments \n"
+#~ "        group by orgId \n"
+#~ "        having startDate = max(startDate)\n"
+#~ "    </subselect>\n"
+#~ "    <many-to-one name=\"mostRecentEmployer\" \n"
+#~ "            class=\"Organization\" \n"
+#~ "            column=\"orgId\"/>\n"
+#~ "</join>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<join>\n"
+#~ "    <key column=\"employeeId\"/>\n"
+#~ "    <subselect>\n"
+#~ "        select employeeId, orgId \n"
+#~ "        from Employments \n"
+#~ "        group by orgId \n"
+#~ "        having startDate = max(startDate)\n"
+#~ "    </subselect>\n"
+#~ "    <many-to-one name=\"mostRecentEmployer\" \n"
+#~ "            class=\"Organization\" \n"
+#~ "            column=\"orgId\"/>\n"
+#~ "</join>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/basic_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/basic_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/basic_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,150 +1,77 @@
+# translation of basic_mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007, 2009.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: basic_mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-11 10:32+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: basic_mapping.xml:29
 #, no-c-format
 msgid "Basic O/R Mapping"
-msgstr "对象/关系数据库映射基础(Basic O/R Mapping)"
+msgstr "对象/关系数据库映射基础(Basic O/R Mapping)"
 
 #. Tag: title
-#: basic_mapping.xml:32
 #, no-c-format
 msgid "Mapping declaration"
 msgstr "映射定义(Mapping declaration)"
 
 #. Tag: para
-#: basic_mapping.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Object/relational mappings are usually defined in an XML document. The "
 "mapping document is designed to be readable and hand-editable. The mapping "
 "language is Java-centric, meaning that mappings are constructed around "
 "persistent class declarations and not table declarations."
 msgstr ""
-"对象和关系数据库之间的映射通常是用一个XML文档(XML document)来定义的。这个映射"
-"文档被设计为易读的, 并且可以手工修改。映射语言是以Java为中心,这意味着映射文"
-"档是按照持久化类的定义来创建的, 而非表的定义。"
+"对象和关系数据库之间的映射通常是用一个 XML 文档来定义的。这个映射文档被设计为"
+"易读的,并且可以手工修改。映射语言是以 Java 为中心,这意味着映射文档是按照持"
+"久化类的定义来创建的,而非表的定义。 "
 
 #. Tag: para
-#: basic_mapping.xml:41
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please note that even though many Hibernate users choose to write the XML by "
 "hand, a number of tools exist to generate the mapping document. These "
 "include XDoclet, Middlegen and AndroMDA."
 msgstr ""
-"请注意,虽然很多Hibernate用户选择手写XML映射文档,但也有一些工具可以用来生成"
-"映射文档, 包括XDoclet,Middlegen和AndroMDA。"
+"请注意,虽然很多 Hibernate 用户选择手写 XML 映射文档,但也有一些工具可以用来"
+"生成映射文档,包括 XDoclet、Middlegen 和 AndroMDA。"
 
 #. Tag: para
-#: basic_mapping.xml:47
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is an example mapping:"
-msgstr "让我们从一个映射的例子开始:"
+msgstr "下面是一个映射的例子:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:51
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"      \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"          \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"        <class name=\"Cat\"\n"
-"            table=\"cats\"\n"
-"            discriminator-value=\"C\">\n"
-"\n"
-"                <id name=\"id\">\n"
-"                        <generator class=\"native\"/>\n"
-"                </id>\n"
-"\n"
-"                <discriminator column=\"subclass\"\n"
-"                     type=\"character\"/>\n"
-"\n"
-"                <property name=\"weight\"/>\n"
-"\n"
-"                <property name=\"birthdate\"\n"
-"                    type=\"date\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"color\"\n"
-"                    type=\"eg.types.ColorUserType\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"sex\"\n"
-"                    not-null=\"true\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <property name=\"litterId\"\n"
-"                    column=\"litterId\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <many-to-one name=\"mother\"\n"
-"                    column=\"mother_id\"\n"
-"                    update=\"false\"/>\n"
-"\n"
-"                <set name=\"kittens\"\n"
-"                    inverse=\"true\"\n"
-"                    order-by=\"litter_id\">\n"
-"                        <key column=\"mother_id\"/>\n"
-"                        <one-to-many class=\"Cat\"/>\n"
-"                </set>\n"
-"\n"
-"                <subclass name=\"DomesticCat\"\n"
-"                    discriminator-value=\"D\">\n"
-"\n"
-"                        <property name=\"name\"\n"
-"                            type=\"string\"/>\n"
-"\n"
-"                </subclass>\n"
-"\n"
-"        </class>\n"
-"\n"
-"        <class name=\"Dog\">\n"
-"                <!-- mapping for Dog could go here -->\n"
-"        </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:53
-#, fuzzy, no-c-format
-msgid ""
 "We will now discuss the content of the mapping document. We will only "
 "describe, however, the document elements and attributes that are used by "
 "Hibernate at runtime. The mapping document also contains some extra optional "
 "attributes and elements that affect the database schemas exported by the "
 "schema export tool (for example, the <literal> not-null</literal> attribute)."
 msgstr ""
-"我们现在开始讨论映射文档的内容。我们只描述Hibernate在运行时用到的文档元素和属"
-"性。 映射文档还包括一些额外的可选属性和元素,它们在使用schema导出工具的时候会"
-"影响导出的数据库schema结果。 (比如,<literal> not-null</literal> 属性。)"
+"我们现在开始讨论映射文档的内容。我们只描述 Hibernate 在运行时用到的文档元素和"
+"属性。映射文档还包括一些额外的可选属性和元素,它们在使用 schema 导出工具的时"
+"候会影响导出的数据库 schema 结果(比如,<literal>not-null</literal> 属性)。"
 
 #. Tag: title
-#: basic_mapping.xml:64
 #, no-c-format
 msgid "Doctype"
 msgstr "Doctype"
 
 #. Tag: para
-#: basic_mapping.xml:66
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All XML mappings should declare the doctype shown. The actual DTD can be "
 "found at the URL above, in the directory <literal>hibernate-x.x.x/src/org/"
@@ -153,21 +80,19 @@
 "lookups of the DTD using an Internet connection, check the DTD declaration "
 "against the contents of your classpath."
 msgstr ""
-"所有的XML映射都需要定义如上所示的doctype。DTD可以从上述URL中获取, 也可以从"
-"<literal>hibernate-x.x.x/src/net/sf/hibernate</literal>目录中、 或"
-"<literal>hibernate.jar</literal>文件中找到。Hibernate总是会首先在它的"
-"classptah中搜索DTD文件。 如果你发现它是通过连接Internet查找DTD文件,就对照你"
-"的classpath目录检查XML文件里的DTD声明。"
+"所有的 XML 映射都需要定义如上所示的 doctype。DTD 可以从上述 URL 中获取,也可"
+"以从 <literal>hibernate-x.x.x/src/org/hibernate </literal> 目录中、或 "
+"<literal>hibernate.jar</literal> 文件中找到。Hibernate 总是会首先在它的 "
+"classptah 中搜索 DTD 文件。如果你发现它是通过连接 Internet 查找 DTD 文件,就"
+"对照你的 classpath 目录检查 XML 文件里的 DTD 声明。"
 
 #. Tag: title
-#: basic_mapping.xml:76
 #, no-c-format
 msgid "EntityResolver"
 msgstr "EntityResolver"
 
 #. Tag: para
-#: basic_mapping.xml:77
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will first attempt to resolve DTDs in its classpath. It does this "
 "is by registering a custom <literal>org.xml.sax.EntityResolver</literal> "
@@ -175,32 +100,26 @@
 "custom <literal>EntityResolver</literal> recognizes two different systemId "
 "namespaces:"
 msgstr ""
-"As mentioned previously, Hibernate will first attempt to resolve DTDs in its "
-"classpath. The manner in which it does this is by registering a custom "
-"<literal>org.xml.sax.EntityResolver</literal> implementation with the "
-"SAXReader it uses to read in the xml files. This custom "
-"<literal>EntityResolver</literal> recognizes two different systemId "
-"namespaces. 如前所述,Hibernate首先在其classpath中查找DTD。其行为是依靠在系统"
-"中注册的<literal>org.xml.sax.EntityResolver</literal>的一个具体实现,"
-"SAXReader依靠它来读取xml文件。这一 <literal>EntityResolver</literal> 实现能辨"
-"认两种不同的 systenId命名空间。"
+"Hibernate 首先试图在其 classpath 中解析 DTD。这是依靠在系统中注册的 "
+"<literal>org.xml.sax.EntityResolver</literal> 的一个具体实现,SAXReader 依靠"
+"它来读取 xml 文件。这个自定义的 <literal>EntityResolver</literal> 能辨认两种"
+"不同的 systenId 命名空间:"
 
 #. Tag: para
-#: basic_mapping.xml:85
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "a <literal>hibernate namespace</literal> is recognized whenever the resolver "
 "encounters a systemId starting with <literal>http://hibernate.sourceforge."
 "net/</literal>. The resolver attempts to resolve these entities via the "
 "classloader which loaded the Hibernate classes."
 msgstr ""
-"若resolver遇到了一个以<literal>http://hibernate.sourceforge.net/</literal>为"
-"开头的systemId,它会辨认出是<literal>hibernate namespace</literal>,resolver"
-"就试图通过加载Hibernate类的classloader来查找这些实体。"
+"若 resolver 遇到了一个以 <literal>http://hibernate.sourceforge.net/</"
+"literal> 为开头的 systemId,它会辨认出是 <literal>hibernate namespace</"
+"literal>,resolver 就试图通过加载 Hibernate 类的 classloader 来查找这些实"
+"体。 "
 
 #. Tag: para
-#: basic_mapping.xml:94
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "a <literal>user namespace</literal> is recognized whenever the resolver "
 "encounters a systemId using a <literal>classpath://</literal> URL protocol. "
@@ -208,57 +127,33 @@
 "thread context classloader and (2) the classloader which loaded the "
 "Hibernate classes."
 msgstr ""
-"若resolver遇到了一个使用<literal>classpath://</literal>URL协议的systemId,它"
-"会辨认出这是<literal>user namespace</literal>,resolver试图通过(1)当前线程上下"
-"文的classloader和(2)加载Hibernate class的classloader来查找这些实体。"
+"若 resolver 遇到了一个使用 <literal>classpath://</literal> URL 协议的 "
+"systemId,它会辨认出这是 <literal>user namespace</literal>,resolver 试图通过"
+"(1) 当前线程上下文的 classloader 和(2) 加载 Hibernate class 的 classloader "
+"来查找这些实体。"
 
 #. Tag: para
-#: basic_mapping.xml:103
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The following is an example of utilizing user namespacing:"
-msgstr "使用user namespace(用户命名空间)的例子:"
+msgstr "下面是一个使用用户命名空间(user namespace)的例子:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:106
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\" [\n"
-"    <!ENTITY types SYSTEM \"classpath://your/domain/types.xml\">\n"
-"]>\n"
-"\n"
-"<hibernate-mapping package=\"your.domain\">\n"
-"    <class name=\"MyEntity\">\n"
-"        <id name=\"id\" type=\"my-custom-id-type\">\n"
-"            ...\n"
-"        </id>\n"
-"    <class>\n"
-"    &types;\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:107
 #, fuzzy, no-c-format
 msgid ""
 "Where <literal>types.xml</literal> is a resource in the <literal>your."
 "domain</literal> package and contains a custom <link linkend=\"mapping-types-"
 "custom\">typedef</link>."
 msgstr ""
-"<literal>types.xml</literal>是<literal>your.domain</literal>包中的一个资源,"
-"它包含了一个定制的<xref linkend=\"mapping-types-custom\">typedef</xref>。"
+"这里的 <literal>types.xml</literal> 是 <literal>your.domain</literal> 包中的"
+"一个资源,它包含了一个自定义的 <xref linkend=\"mapping-types-custom\"/>。 "
 
 #. Tag: title
-#: basic_mapping.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Hibernate-mapping"
-msgstr "hibernate-mapping"
+msgstr "Hibernate-mapping"
 
 #. Tag: para
-#: basic_mapping.xml:117
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This element has several optional attributes. The <literal>schema</literal> "
 "and <literal>catalog</literal> attributes specify that tables referred to in "
@@ -271,111 +166,87 @@
 "literal> attribute allows you to use unqualified class names in the query "
 "language."
 msgstr ""
-"这个元素包括一些可选的属性。<literal>schema</literal>和<literal>catalog</"
-"literal>属性, 指明了这个映射所连接(refer)的表所在的schema和/或catalog名"
-"称。 假若指定了这个属性,表名会加上所指定的schema和catalog的名字扩展为全限定"
-"名。假若没有指定,表名就不会使用全限定名。 <literal>default-cascade</literal>"
-"指定了未明确注明<literal>cascade</literal>属性的Java属性和 集合类Hibernate会"
-"采取什么样的默认级联风格。<literal>auto-import</literal>属性默认让我们在查询"
-"语言中可以使用 非全限定名的类名。"
+"这个元素包括一些可选的属性。<literal>schema</literal> 和 <literal>catalog</"
+"literal> 属性, 指明了这个映射所连接(refer)的表所在的 schema 和/或 catalog "
+"名称。假若指定了这个属性,表名会加上所指定的 schema 和 catalog 的名字扩展为全"
+"限定名。假若没有指定,表名就不会使用全限定名。<literal>default-cascade</"
+"literal> 指定了未明确注明 <literal>cascade</literal> 属性的 Java 属性和 集合"
+"类 Hibernate 会采取什么样的默认级联风格。<literal>auto-import</literal> 属性"
+"默认让我们在查询语言中可以使用非全限定名的类名。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:138
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping\n"
-"         schema=\"schemaName\"\n"
-"         catalog=\"catalogName\"\n"
-"         default-cascade=\"cascade_style\"\n"
-"         default-access=\"field|property|ClassName\"\n"
-"         default-lazy=\"true|false\"\n"
-"         auto-import=\"true|false\"\n"
-"         package=\"package.name\"\n"
-" />]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:141
-#, fuzzy, no-c-format
 msgid "<literal>schema</literal> (optional): the name of a database schema."
-msgstr "<literal>schema</literal> (可选): 数据库schema的名称。"
+msgstr "<literal>schema</literal>(可选):数据库 schema 的名称。"
 
 #. Tag: para
-#: basic_mapping.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>catalog</literal> (optional): the name of a database catalog."
-msgstr "<literal>catalog</literal> (可选): 数据库catalog的名称。"
+msgstr "<literal>catalog</literal>(可选):数据库 catalog 的名称。 "
 
 #. Tag: para
-#: basic_mapping.xml:151
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>default-cascade</literal> (optional - defaults to <literal>none</"
 "literal>): a default cascade style."
 msgstr ""
-"<literal>default-cascade</literal> (可选 - 默认为 <literal>none</literal>): "
-"默认的级联风格。"
+"<literal>default-cascade</literal>(可选 — 默认为 <literal>none</literal>):"
+"默认的级联风格。 "
 
 #. Tag: para
-#: basic_mapping.xml:157
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>default-access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate should use for accessing all properties. "
 "It can be a custom implementation of <literal>PropertyAccessor</literal>."
 msgstr ""
-"<literal>default-access</literal> (可选 - 默认为 <literal>property</"
-"literal>): Hibernate用来访问所有属性的策略。可以通过实现"
-"<literal>PropertyAccessor</literal>接口 自定义。"
+"<literal>default-access</literal>(可选 — 默认为 <literal>property</"
+"literal>):Hibernate 用来访问所有属性的策略。可以通过实现 "
+"<literal>PropertyAccessor</literal> 接口自定义。 "
 
 #. Tag: para
-#: basic_mapping.xml:164
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>default-lazy</literal> (optional - defaults to <literal>true</"
 "literal>): the default value for unspecified <literal>lazy</literal> "
 "attributes of class and collection mappings."
 msgstr ""
-"<literal>default-lazy</literal> (可选 - 默认为 <literal>true</literal>): 指定"
-"了未明确注明<literal>lazy</literal>属性的Java属性和集合类, Hibernate会采取什"
-"么样的默认加载风格。"
+"<literal>default-lazy</literal>(可选 — 默认为 <literal>true</literal>):指"
+"定了未明确注明 <literal>lazy</literal> 属性的 Java 属性和集合类,Hibernate 会"
+"采取什么样的默认加载风格。 "
 
 #. Tag: para
-#: basic_mapping.xml:171
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>auto-import</literal> (optional - defaults to <literal>true</"
 "literal>): specifies whether we can use unqualified class names of classes "
 "in this mapping in the query language."
 msgstr ""
-"<literal>auto-import</literal> (可选 - 默认为 <literal>true</literal>): 指定"
-"我们是否可以在查询语言中使用非全限定的类名(仅限于本映射文件中的类)。"
+"<literal>auto-import</literal>(可选 — 默认为 <literal>true</literal>):指定"
+"我们是否可以在查询语言中使用非全限定的类名(仅限于本映射文件中的类)。 "
 
 #. Tag: para
-#: basic_mapping.xml:178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>package</literal> (optional): specifies a package prefix to use for "
 "unqualified class names in the mapping document."
 msgstr ""
-"<literal>package</literal> (可选): 指定一个包前缀,如果在映射文档中没有指定全"
-"限定的类名, 就使用这个作为包名。"
+"<literal>package</literal>(可选):指定一个包前缀,如果在映射文档中没有指定"
+"全限定的类名,就使用这个作为包名。 "
 
 #. Tag: para
-#: basic_mapping.xml:186
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you have two persistent classes with the same unqualified name, you "
 "should set <literal>auto-import=\"false\"</literal>. An exception will "
 "result if you attempt to assign two classes to the same \"imported\" name."
 msgstr ""
 "假若你有两个持久化类,它们的非全限定名是一样的(就是两个类的名字一样,所在的"
-"包不一样--译者注), 你应该设置<literal>auto-import=\"false\"</literal>。如果"
-"你把一个“import过”的名字同时对应两个类, Hibernate会抛出一个异常。"
+"包不一样 — 译者注),你应该设置 <literal>auto-import=\"false\"</literal>。如"
+"果你把一个“导入过”的名字同时对应两个类,Hibernate 会抛出一个异常。"
 
 #. Tag: para
-#: basic_mapping.xml:192
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>hibernate-mapping</literal> element allows you to nest several "
 "persistent <literal>&lt;class&gt;</literal> mappings, as shown above. It is, "
@@ -385,164 +256,114 @@
 "literal>, <literal>Dog.hbm.xml</literal>, or if using inheritance, "
 "<literal>Animal.hbm.xml</literal>."
 msgstr ""
-"注意<literal>hibernate-mapping</literal> 元素允许你嵌套多个如上所示的 "
-"<literal>&lt;class&gt;</literal>映射。但是最好的做法(也许一些工具需要的)是"
-"一个 持久化类(或一个类的继承层次)对应一个映射文件,并以持久化的超类名称命"
-"名,例如: <literal>Cat.hbm.xml</literal>, <literal>Dog.hbm.xml</literal>,"
-"或者如果使用继承,<literal>Animal.hbm.xml</literal>。"
+"注意 <literal>hibernate-mapping</literal> 元素允许你嵌套多个如上所示的 "
+"<literal>&lt;class&gt;</literal> 映射。但是最好的做法(也许一些工具需要的)是"
+"一个持久化类(或一个类的继承层次)对应一个映射文件,并以持久化的超类名称命"
+"名,例如:<literal>Cat.hbm.xml</literal>、<literal>Dog.hbm.xml</literal>,或"
+"者如果使用继承,<literal>Animal.hbm.xml</literal>。"
 
 #. Tag: title
-#: basic_mapping.xml:205
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Class"
-msgstr "class"
+msgstr "ç±»"
 
 #. Tag: para
-#: basic_mapping.xml:207
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can declare a persistent class using the <literal>class</literal> "
 "element. For example:"
-msgstr "你可以使用<literal>class</literal>元素来定义一个持久化类:"
+msgstr "你可以使用 <literal>class</literal> 元素来定义一个持久化类。例如:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:235
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class\n"
-"        name=\"ClassName\"\n"
-"        table=\"tableName\"\n"
-"        discriminator-value=\"discriminator_value\"\n"
-"        mutable=\"true|false\"\n"
-"        schema=\"owner\"\n"
-"        catalog=\"catalog\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        select-before-update=\"true|false\"\n"
-"        polymorphism=\"implicit|explicit\"\n"
-"        where=\"arbitrary sql where condition\"\n"
-"        persister=\"PersisterClass\"\n"
-"        batch-size=\"N\"\n"
-"        optimistic-lock=\"none|version|dirty|all\"\n"
-"        lazy=\"true|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        check=\"arbitrary sql check condition\"\n"
-"        rowid=\"rowid\"\n"
-"        subselect=\"SQL expression\"\n"
-"        abstract=\"true|false\"\n"
-"        node=\"element-name\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:238
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal> (optional): the fully qualified Java class name of "
 "the persistent class or interface. If this attribute is missing, it is "
 "assumed that the mapping is for a non-POJO entity."
 msgstr ""
-"<literal>name</literal> (可选): 持久化类(或者接口)的Java全限定名。 如果这个"
-"属性不存在,Hibernate将假定这是一个非POJO的实体映射。"
+"<literal>name</literal>(可选):持久化类(或者接口)的 Java 全限定名。 如果"
+"这个属性不存在,Hibernate 将假定这是一个非 POJO 的实体映射。 "
 
 #. Tag: para
-#: basic_mapping.xml:245
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>table</literal> (optional - defaults to the unqualified class "
 "name): the name of its database table."
 msgstr ""
-"<literal>table</literal> (可选 - 默认是类的非全限定名): 对应的数据库表名。"
+"<literal>table</literal>(可选 — 默认是类的非全限定名):对应的数据库表名。 "
 
 #. Tag: para
-#: basic_mapping.xml:251
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>discriminator-value</literal> (optional - defaults to the class "
 "name): a value that distinguishes individual subclasses that is used for "
 "polymorphic behavior. Acceptable values include <literal>null</literal> and "
 "<literal>not null</literal>."
 msgstr ""
-"<literal>discriminator-value</literal> (可选 - 默认和类名一样): 一个用于区分"
+"<literal>discriminator-value</literal>(可选 — 默认和类名一样):一个用于区分"
 "不同的子类的值,在多态行为时使用。它可以接受的值包括 <literal>null</literal> "
-"和 <literal>not null</literal>。"
+"和 <literal>not null</literal>。 "
 
 #. Tag: para
-#: basic_mapping.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>true</literal>): "
 "specifies that instances of the class are (not) mutable."
 msgstr ""
-"<literal>mutable</literal> (可选,默认值为<literal>true</literal>): 表明该类"
-"的实例是可变的或者不可变的。"
+"<literal>mutable</literal>(可选,默认值为 <literal>true</literal>):表明该"
+"类的实例是可变的或者不可变的。 "
 
 #. Tag: para
-#: basic_mapping.xml:264 basic_mapping.xml:2231
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>schema</literal> (optional): overrides the schema name specified by "
 "the root <literal>&lt;hibernate-mapping&gt;</literal> element."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>schema</literal> (可选): 覆盖在根<literal>&lt;hibernate-mapping&gt;"
-"</literal>元素中指定的schema名字。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>schema</literal> (可选):覆盖由根<literal>&lt;hibernate-mapping&gt;</"
-"literal>元素指定的模式名称。"
+"<literal>schema</literal>(可选):覆盖在根 <literal>&lt;hibernate-"
+"mapping&gt;</literal> 元素中指定的 schema 名字。 "
 
 #. Tag: para
-#: basic_mapping.xml:270 basic_mapping.xml:2237
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>catalog</literal> (optional): overrides the catalog name specified "
 "by the root <literal>&lt;hibernate-mapping&gt;</literal> element."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>catalog</literal> (可选): 覆盖在根<literal>&lt;hibernate-mapping&gt;"
-"</literal>元素中指定的catalog名字。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>catalog</literal> (可选): 覆盖由根 <literal>&lt;hibernate-"
-"mapping&gt;</literal>元素指定的目录名称。"
+"<literal>catalog</literal>(可选):覆盖在根 <literal>&lt;hibernate-"
+"mapping&gt;</literal> 元素中指定的 catalog 名字。 "
 
 #. Tag: para
-#: basic_mapping.xml:276
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies an interface to use for lazy "
 "initializing proxies. You can specify the name of the class itself."
 msgstr ""
-"<literal>proxy</literal> (可选): 指定一个接口,在延迟装载时作为代理使用。 你"
-"可以在这里使用该类自己的名字。"
+"<literal>proxy</literal>(可选):指定一个接口,在延迟装载时作为代理使用。你"
+"可以在这里使用该类自己的名字。 "
 
 #. Tag: para
-#: basic_mapping.xml:282
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>dynamic-update</literal> (optional - defaults to <literal>false</"
 "literal>): specifies that <literal>UPDATE</literal> SQL should be generated "
 "at runtime and can contain only those columns whose values have changed."
 msgstr ""
-"<literal>dynamic-update</literal> (可选, 默认为 <literal>false</literal>): 指"
-"定用于<literal>UPDATE</literal> 的SQL将会在运行时动态生成,并且只更新那些改变"
-"过的字段。"
+"<literal>dynamic-update</literal>(可选,默认为 <literal>false</literal>):"
+"指定用于 <literal>UPDATE</literal> 的 SQL 将会在运行时动态生成,并且只更新那"
+"些改变过的字段。 "
 
 #. Tag: para
-#: basic_mapping.xml:289
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>dynamic-insert</literal> (optional - defaults to <literal>false</"
 "literal>): specifies that <literal>INSERT</literal> SQL should be generated "
 "at runtime and contain only the columns whose values are not null."
 msgstr ""
-"<literal>dynamic-insert</literal> (可选, 默认为 <literal>false</literal>): 指"
-"定用于<literal>INSERT</literal>的 SQL 将会在运行时动态生成,并且只包含那些非"
-"空值字段。"
+"<literal>dynamic-insert</literal>(可选,默认为 <literal>false</literal>):"
+"指定用于 <literal>INSERT</literal> 的 SQL 将会在运行时动态生成,并且只包含那"
+"些非空值字段。 "
 
 #. Tag: para
-#: basic_mapping.xml:296
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>select-before-update</literal> (optional - defaults to "
 "<literal>false</literal>): specifies that Hibernate should <emphasis>never</"
@@ -552,108 +373,99 @@
 "Hibernate perform an extra SQL <literal>SELECT</literal> to determine if an "
 "<literal>UPDATE</literal> is actually required."
 msgstr ""
-"<literal>select-before-update</literal> (可选, 默认为 <literal>false</"
-"literal>): 指定Hibernate除非确定对象真正被修改了(如果该值为true-译注),否"
-"则<emphasis>不会</emphasis>执行SQL <literal>UPDATE</literal>操作。在特定场合"
-"(实际上,它只在一个瞬时对象(transient object)关联到一个 新的session中时执"
-"行的update()中生效),这说明Hibernate会在<literal>UPDATE</literal> 之前执行一"
-"次额外的SQL <literal>SELECT</literal>操作,来决定是否应该执行 "
-"<literal>UPDATE</literal>。"
+"<literal>select-before-update</literal>(可选,默认为 <literal>false</"
+"literal>):指定 Hibernate 除非确定对象真正被修改了(如果该值为 true — 译"
+"注),否则<emphasis>不会</emphasis>执行 SQL <literal>UPDATE</literal> 操作。"
+"在特定场合(实际上,它只在一个瞬时对象(transient object)关联到一个新的 "
+"session 中时执行的 update() 中生效),这说明 Hibernate 会在 <literal>UPDATE</"
+"literal> 之前执行一次额外的 SQL <literal>SELECT</literal> 操作来决定是否确实"
+"需要执行 <literal>UPDATE</literal>。"
 
 #. Tag: para
-#: basic_mapping.xml:306
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>polymorphism</literal> (optional - defaults to <literal>implicit</"
 "literal>): determines whether implicit or explicit query polymorphism is "
 "used."
 msgstr ""
-"<literal>polymorphism(多态)</literal> (可选, 默认值为 <literal>implicit (隐"
-"式) </literal>): 界定是隐式还是显式的使用多态查询(这只在Hibernate的具体表继"
-"承策略中用到-译注)。"
+"<literal>polymorphism(多态)</literal>(可选,默认值为 <literal>implicit "
+"(隐式)</literal>):界定是隐式还是显式的使用多态查询(这只在 Hibernate 的具"
+"体表继承策略中用到 — 译注)。 "
 
 #. Tag: para
-#: basic_mapping.xml:312
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>where</literal> (optional): specifies an arbitrary SQL "
 "<literal>WHERE</literal> condition to be used when retrieving objects of "
 "this class."
 msgstr ""
-"<literal>where</literal> (可选) 指定一个附加的SQL<literal>WHERE</literal> 条"
-"件, 在抓取这个类的对象时会一直增加这个条件。"
+"<literal>where</literal>(可选)指定一个附加的 SQL <literal>WHERE</literal> "
+"条件,在抓取这个类的对象时会一直增加这个条件。 "
 
 #. Tag: para
-#: basic_mapping.xml:318
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>persister</literal> (optional): specifies a custom "
 "<literal>ClassPersister</literal>."
 msgstr ""
-"<literal>persister</literal> (可选): 指定一个定制的<literal>ClassPersister</"
-"literal>。"
+"<literal>persister</literal>(可选):指定一个定制的 "
+"<literal>ClassPersister</literal>。 "
 
 #. Tag: para
-#: basic_mapping.xml:323
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>batch-size</literal> (optional - defaults to <literal>1</literal>): "
 "specifies a \"batch size\" for fetching instances of this class by "
 "identifier."
 msgstr ""
-"<literal>batch-size</literal> (可选,默认是<literal>1</literal>) 指定一个用于 "
-"根据标识符(identifier)抓取实例时使用的\"batch size\"(批次抓取数量)。"
+"<literal>batch-size</literal>(可选,默认是 <literal>1</literal>)指定一个用"
+"于 根据标识符(identifier)抓取实例时使用的 \"batch size\"(批次抓取数量)。 "
 
 #. Tag: para
-#: basic_mapping.xml:329
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>version</"
 "literal>): determines the optimistic locking strategy."
 msgstr ""
-"<literal>optimistic-lock(乐观锁定)</literal> (可选,默认是"
-"<literal>version</literal>): 决定乐观锁定的策略。"
+"<literal>optimistic-lock(乐观锁定)</literal>(可选,默认是 "
+"<literal>version</literal>):决定乐观锁定的策略。 "
 
 #. Tag: para
-#: basic_mapping.xml:335
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional): lazy fetching can be disabled by setting "
 "<literal>lazy=\"false\"</literal>."
 msgstr ""
-"<literal>lazy</literal> (可选): 通过设置<literal>lazy=\"false\"</literal>, "
+"<literal>lazy</literal>(可选):通过设置 <literal>lazy=\"false\"</literal>,"
 "所有的延迟加载(Lazy fetching)功能将被全部禁用(disabled)。"
 
 #. Tag: para
-#: basic_mapping.xml:341
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>entity-name</literal> (optional - defaults to the class name): "
 "Hibernate3 allows a class to be mapped multiple times, potentially to "
 "different tables. It also allows entity mappings that are represented by "
 "Maps or XML at the Java level. In these cases, you should provide an "
 "explicit arbitrary name for the entity. See <xref linkend=\"persistent-"
-"classes-dynamicmodels\"/> and <xref linkend=\"xml\"/> for more information."
+"classes-dynamicmodels\" /> and <xref linkend=\"xml\" /> for more information."
 msgstr ""
-"<literal>entity-name</literal> (可选,默认为类名): Hibernate3允许一个类进行多"
-"次映射( 前提是映射到不同的表),并且允许使用Maps或XML代替Java层次的实体映射 "
-"(也就是实现动态领域模型,不用写持久化类-译注)。 更多信息请看<xref linkend="
-"\"persistent-classes-dynamicmodels\"/> and <xref linkend=\"xml\"/>。"
+"<literal>entity-name</literal>(可选,默认为类名):Hibernate3 允许一个类进行"
+"多次映射(前提是映射到不同的表),并且允许使用 Maps 或 XML 代替 Java 层次的实"
+"体映射(也就是实现动态领域模型,不用写持久化类-译注)。更多信息请看 <xref "
+"linkend=\"persistent-classes-dynamicmodels\"/> 和 <xref linkend=\"xml\"/>。 "
 
 #. Tag: para
-#: basic_mapping.xml:351
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>check</literal> (optional): an SQL expression used to generate a "
 "multi-row <emphasis>check</emphasis> constraint for automatic schema "
 "generation."
 msgstr ""
-"<literal>check</literal> (可选): 这是一个SQL表达式, 用于为自动生成的schema添"
-"加多行(multi-row)约束<emphasis>检查</emphasis>。"
+"<literal>check</literal>(可选):这是一个 SQL 表达式, 用于为自动生成的 "
+"schema 添加多行(multi-row)约束<emphasis>检查</emphasis>。 "
 
 #. Tag: para
-#: basic_mapping.xml:357
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>rowid</literal> (optional): Hibernate can use ROWIDs on databases. "
 "On Oracle, for example, Hibernate can use the <literal>rowid</literal> extra "
@@ -661,36 +473,33 @@
 "literal>. A ROWID is an implementation detail and represents the physical "
 "location of a stored tuple."
 msgstr ""
-"<literal>rowid</literal> (可选): Hibernate可以使用数据库支持的所谓的ROWIDs,"
-"例如: Oracle数据库,如果你设置这个可选的<literal>rowid</literal>, Hibernate"
-"可以使用额外的字段<literal>rowid</literal>实现快速更新。ROWID是这个功能实现的"
-"重点, 它代表了一个存储元组(tuple)的物理位置。"
+"<literal>rowid</literal>(可选):Hibernate 可以使用数据库支持的所谓的 "
+"ROWIDs,例如:Oracle 数据库,如果你设置这个可选的 <literal>rowid</literal>,"
+"Hibernate 可以使用额外的字段 <literal>rowid</literal> 实现快速更新。ROWID 是"
+"这个功能实现的重点,它代表了一个存储元组(tuple)的物理位置。 "
 
 #. Tag: para
-#: basic_mapping.xml:364
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>subselect</literal> (optional): maps an immutable and read-only "
 "entity to a database subselect. This is useful if you want to have a view "
 "instead of a base table. See below for more information."
 msgstr ""
-"<literal>subselect</literal> (可选): 它将一个不可变(immutable)并且只读的实"
-"体映射到一个数据库的 子查询中。当你想用视图代替一张基本表的时候,这是有用的,"
-"但最好不要这样做。更多的介绍请看下面内容。"
+"<literal>subselect</literal>(可选):它将一个不可变(immutable)并且只读的实"
+"体映射到一个数据库的子查询中。当你想用视图代替一张基本表的时候,这是有用的,"
+"但最好不要这样做。更多的介绍请看下面内容。 "
 
 #. Tag: para
-#: basic_mapping.xml:371
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>abstract</literal> (optional): is used to mark abstract "
 "superclasses in <literal>&lt;union-subclass&gt;</literal> hierarchies."
 msgstr ""
-"<literal>abstract</literal> (可选): 用于在<literal>&lt;union-subclass&gt;</"
-"literal>的继承结构 (hierarchies)中标识抽象超类。"
+"<literal>abstract</literal>(可选):用于在 <literal>&lt;union-subclass&gt;</"
+"literal> 的层次结构(hierarchies)中标识抽象超类。"
 
 #. Tag: para
-#: basic_mapping.xml:379
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is acceptable for the named persistent class to be an interface. You can "
 "declare implementing classes of that interface using the <literal>&lt;"
@@ -698,25 +507,23 @@
 "emphasis> inner class. Specify the class name using the standard form i.e. "
 "<literal>e.g.Foo$Bar</literal>."
 msgstr ""
-"若指明的持久化类实际上是一个接口,这也是完全可以接受的。 之后你可以用元素"
-"<literal>&lt;subclass&gt;</literal>来指定该接口的实际实现类。 你可以持久化任"
-"何<emphasis>static</emphasis>(静态的)内部类。 你应该使用标准的类名格式来指"
-"定类名,<literal>比如:Foo$Bar</literal>。"
+"若指明的持久化类实际上是一个接口,这也是完全可以接受的。之后你可以用元素 "
+"<literal>&lt;subclass&gt;</literal> 来指定该接口的实际实现类。你可以持久化任"
+"何 <emphasis>static</emphasis>(静态的)内部类。你应该使用标准的类名格式来指"
+"定类名,比如:<literal>Foo$Bar</literal>。"
 
 #. Tag: para
-#: basic_mapping.xml:386
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Immutable classes, <literal>mutable=\"false\"</literal>, cannot be updated "
 "or deleted by the application. This allows Hibernate to make some minor "
 "performance optimizations."
 msgstr ""
-"不可变类,<literal>mutable=\"false\"</literal>不可以被应用程序更新或者删除。 "
-"这可以让Hibernate做一些小小的性能优化。"
+"不可变类,<literal>mutable=\"false\"</literal> 不可以被应用程序更新或者删除。"
+"这允许 Hibernate 实现一些小小的性能优化。"
 
 #. Tag: para
-#: basic_mapping.xml:391
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The optional <literal>proxy</literal> attribute enables lazy initialization "
 "of persistent instances of the class. Hibernate will initially return CGLIB "
@@ -724,13 +531,12 @@
 "when a method of the proxy is invoked. See \"Initializing collections and "
 "proxies\" below."
 msgstr ""
-"可选的<literal>proxy</literal>属性允许延迟加载类的持久化实例。 Hibernate开始"
-"会返回实现了这个命名接口的CGLIB代理。当代理的某个方法被实际调用的时候, 真实"
-"的持久化对象才会被装载。参见下面的“用于延迟装载的代理”。"
+"可选的 <literal>proxy</literal> 属性允许延迟加载类的持久化实例。Hibernate 开"
+"始会返回实现了这个命名接口的 CGLIB 代理。当代理的某个方法被实际调用的时候,真"
+"实的持久化对象才会被装载。参见下面的“用于延迟装载的代理”。 "
 
 #. Tag: para
-#: basic_mapping.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Implicit</emphasis> polymorphism means that instances of the class "
 "will be returned by a query that names any superclass or implemented "
@@ -746,19 +552,18 @@
 "table This allows a \"lightweight\" class that contains a subset of the "
 "table columns."
 msgstr ""
-"<emphasis>Implicit</emphasis> (隐式)的多态是指,如果查询时给出的是任何超类、"
-"该类实现的接口或者该类的 名字,都会返回这个类的实例;如果查询中给出的是子类的"
-"名字,则会返回子类的实例。 <emphasis>Explicit</emphasis> (显式)的多态是指,"
-"只有在查询时给出明确的该类名字时才会返回这个类的实例; 同时只有在这个"
-"<literal>&lt;class&gt;</literal>的定义中作为<literal>&lt;subclass&gt;</"
-"literal> 或者<literal>&lt;joined-subclass&gt;</literal>出现的子类,才会可能返"
-"回。 在大多数情况下,默认的<literal>polymorphism=\"implicit\"</literal>都是合"
-"适的。 显式的多态在有两个不同的类映射到同一个表的时候很有用。(允许一个“轻"
-"型”的类,只包含部分表字段)。"
+"<emphasis>Implicit</emphasis>(隐式)的多态是指,如果查询时给出的是任何超类、"
+"该类实现的接口或者该类的名字,都会返回这个类的实例;如果查询中给出的是子类的"
+"名字,则会返回子类的实例。<emphasis>Explicit</emphasis>(显式)的多态是指,只"
+"有在查询时给出明确的该类名字时才会返回这个类的实例; 同时只有在这个 "
+"<literal>&lt;class&gt;</literal> 的定义中作为 <literal>&lt;subclass&gt;</"
+"literal> 或者 <literal>&lt;joined-subclass&gt;</literal> 出现的子类,才会可能"
+"返回。在大多数情况下,默认的 <literal>polymorphism=\"implicit\"</literal> 都"
+"是合适的。显式的多态在有两个不同的类映射到同一个表的时候很有用。(允许一个“轻"
+"量级”的类,只包含部分表字段)。 "
 
 #. Tag: para
-#: basic_mapping.xml:410
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>persister</literal> attribute lets you customize the "
 "persistence strategy used for the class. You can, for example, specify your "
@@ -769,16 +574,15 @@
 "files or LDAP. See <literal>org.hibernate.test.CustomPersister</literal> for "
 "a simple example of \"persistence\" to a <literal>Hashtable</literal>."
 msgstr ""
-"<literal>persister</literal>属性可以让你定制这个类使用的持久化策略。 你可以指"
-"定你自己实现 <literal>org.hibernate.persister.EntityPersister</literal>的子"
+"<literal>persister</literal> 属性可以让你定制这个类使用的持久化策略。你可以指"
+"定你自己实现 <literal>org.hibernate.persister.EntityPersister</literal> 的子"
 "类,你甚至可以完全从头开始编写一个 <literal>org.hibernate.persister."
-"ClassPersister</literal>接口的实现, 比如是用储存过程调用、序列化到文件或者"
-"LDAP数据库来实现。 参阅<literal>org.hibernate.test.CustomPersister</"
-"literal>,这是一个简单的例子 (“持久化”到一个<literal>Hashtable</literal>)。"
+"ClassPersister</literal> 接口的实现,比如是用储存过程调用、序列化到文件或者 "
+"LDAP 数据库来实现。参阅 <literal>org.hibernate.test.CustomPersister</"
+"literal>,这是持久化到 <literal>Hashtable</literal> 的一个简单例子。 "
 
 #. Tag: para
-#: basic_mapping.xml:421
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>dynamic-update</literal> and <literal>dynamic-insert</literal> "
 "settings are not inherited by subclasses, so they can also be specified on "
@@ -786,26 +590,24 @@
 "literal> elements. Although these settings can increase performance in some "
 "cases, they can actually decrease performance in others."
 msgstr ""
-"请注意<literal>dynamic-update</literal>和<literal>dynamic-insert</literal>的"
-"设置并不会继承到子类, 所以在<literal>&lt;subclass&gt;</literal>或者"
-"<literal>&lt;joined-subclass&gt;</literal>元素中可能 需要再次设置。这些设置是"
-"否能够提高效率要视情形而定。请用你的智慧决定是否使用。"
+"请注意 <literal>dynamic-update</literal> 和 <literal>dynamic-insert</"
+"literal> 的设置并不会继承到子类,所以在 <literal>&lt;subclass&gt;</literal> "
+"或者 <literal>&lt;joined-subclass&gt;</literal> 元素中可能需要再次设置。这些"
+"设置在某些情况下能够提高效率,而其他情况下则反而可能降低性能。"
 
 #. Tag: para
-#: basic_mapping.xml:429
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use of <literal>select-before-update</literal> will usually decrease "
 "performance. It is useful to prevent a database update trigger being called "
 "unnecessarily if you reattach a graph of detached instances to a "
 "<literal>Session</literal>."
 msgstr ""
-"使用<literal>select-before-update</literal>通常会降低性能。如果你重新连接一个"
-"脱管(detache)对象实例 到一个<literal>Session</literal>中时,它可以防止数据"
-"库不必要的触发update。 这就很有用了。"
+"使用 <literal>select-before-update</literal> 通常会降低性能。如果你重新连接一"
+"个脱管(detached)对象实例 到一个 <literal>Session</literal> 中时,它可以防止"
+"数据库不必要的触发 update。这就很有用了。"
 
 #. Tag: para
-#: basic_mapping.xml:435
 #, no-c-format
 msgid ""
 "If you enable <literal>dynamic-update</literal>, you will have a choice of "
@@ -814,47 +616,42 @@
 "如果你打开了<literal>dynamic-update</literal>,你可以选择几种乐观锁定的策略:"
 
 #. Tag: para
-#: basic_mapping.xml:441
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>version</literal>: check the version/timestamp columns"
-msgstr "<literal>version(版本检查)</literal> 检查version/timestamp字段"
+msgstr "<literal>version(版本检查)</literal>:检查 version/timestamp 字段"
 
 #. Tag: para
-#: basic_mapping.xml:446
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>all</literal>: check all columns"
-msgstr "<literal>all(全部)</literal> 检查全部字段"
+msgstr "<literal>all(全部)</literal>:检查全部字段"
 
 #. Tag: para
-#: basic_mapping.xml:451
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>dirty</literal>: check the changed columns, allowing some "
 "concurrent updates"
-msgstr "<literal>dirty(脏检查)</literal>只检察修改过的字段"
+msgstr ""
+"<literal>dirty(脏检查)</literal>:只检察修改过的字段,允许某些并行更新"
 
 #. Tag: para
-#: basic_mapping.xml:456
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>none</literal>: do not use optimistic locking"
-msgstr "<literal>none(不检查)</literal>不使用乐观锁定"
+msgstr "<literal>none(不检查)</literal>:不使用乐观锁定"
 
 #. Tag: para
-#: basic_mapping.xml:461
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is <emphasis>strongly</emphasis> recommended that you use version/"
 "timestamp columns for optimistic locking with Hibernate. This strategy "
 "optimizes performance and correctly handles modifications made to detached "
 "instances (i.e. when <literal>Session.merge()</literal> is used)."
 msgstr ""
-"我们<emphasis>非常</emphasis>强烈建议你在Hibernate中使用version/timestamp字段"
-"来进行乐观锁定。 对性能来说,这是最好的选择,并且这也是唯一能够处理在session"
-"外进行操作的策略(例如: 在使用<literal>Session.merge()</literal>的时候)。"
+"我们<emphasis>强烈</emphasis>建议你在 Hibernate 中使用 version/timestamp 字段"
+"来进行乐观锁定。这个选择可以优化性能,且能够处理对脱管实例的修改(例如:在使"
+"用 <literal>Session.merge()</literal> 的时候)。"
 
 #. Tag: para
-#: basic_mapping.xml:468
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is no difference between a view and a base table for a Hibernate "
 "mapping. This is transparent at the database level, although some DBMS do "
@@ -863,50 +660,29 @@
 "schema). In this case, you can map an immutable and read-only entity to a "
 "given SQL subselect expression:"
 msgstr ""
-"对Hibernate映射来说视图和表是没有区别的,这是因为它们在数据层都是透明的( 注"
-"意:一些数据库不支持视图属性,特别是更新的时候)。有时你想使用视图,但却不能"
-"在数据库 中创建它(例如:在遗留的schema中)。这样的话,你可以映射一个不可变的"
-"(immutable)并且是 只读的实体到一个给定的SQL子查询表达式:"
+"对 Hibernate 映射来说视图和表是没有区别的,这是因为它们在数据层都是透明的"
+"( 注意:一些数据库不支持视图属性,特别是更新的时候)。有时你想使用视图,但却"
+"不能在数据库中创建它(例如:在遗留的 schema 中)。这样的话,你可以映射一个不"
+"可变的(immutable)并且是 只读的实体到一个给定的 SQL 子查询表达式: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:476
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Summary\">\n"
-"    <subselect>\n"
-"        select item.name, max(bid.amount), count(*)\n"
-"        from item\n"
-"        join bid on bid.item_id = item.id\n"
-"        group by item.name\n"
-"    </subselect>\n"
-"    <synchronize table=\"item\"/>\n"
-"    <synchronize table=\"bid\"/>\n"
-"    <id name=\"name\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:478
-#, fuzzy, no-c-format
-msgid ""
 "Declare the tables to synchronize this entity with, ensuring that auto-flush "
 "happens correctly and that queries against the derived entity do not return "
 "stale data. The <literal>&lt;subselect&gt;</literal> is available both as an "
 "attribute and a nested mapping element."
 msgstr ""
 "定义这个实体用到的表为同步(synchronize),确保自动刷新(auto-flush)正确执"
-"行, 并且依赖原实体的查询不会返回过期数据。<literal>&lt;subselect&gt;</"
-"literal>在属性元素 和一个嵌套映射元素中都可见。"
+"行,并且依赖原实体的查询不会返回过期数据。在属性元素和嵌套映射元素中都可使用 "
+"<literal>&lt;subselect&gt;</literal>。"
 
 #. Tag: title
-#: basic_mapping.xml:488
 #, no-c-format
-msgid "<title>id</title>"
-msgstr ""
+msgid "id"
+msgstr "id"
 
 #. Tag: para
-#: basic_mapping.xml:490
 #, no-c-format
 msgid ""
 "Mapped classes <emphasis>must</emphasis> declare the primary key column of "
@@ -915,133 +691,82 @@
 "literal> element defines the mapping from that property to the primary key "
 "column."
 msgstr ""
-"被映射的类<emphasis>必须</emphasis>定义对应数据库表主键字段。大多数类有一个"
-"JavaBeans风格的属性, 为每一个实例包含唯一的标识。<literal>&lt;id&gt;</"
+"被映射的类<emphasis>必须</emphasis>定义对应数据库表主键字段。大多数类有一个 "
+"JavaBeans 风格的属性, 为每一个实例包含唯一的标识。<literal>&lt;id&gt;</"
 "literal> 元素定义了该属性到数据库表主键字段的映射。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:505
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id\n"
-"        name=\"propertyName\"\n"
-"        type=\"typename\"\n"
-"        column=\"column_name\"\n"
-"        unsaved-value=\"null|any|none|undefined|id_value\"\n"
-"        access=\"field|property|ClassName\">\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"\n"
-"        <generator class=\"generatorClass\"/>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:508
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal> (optional): the name of the identifier property."
-msgstr "<literal>name</literal> (可选): 标识属性的名字。"
+msgstr "<literal>name</literal>(可选):标识属性的名字。 "
 
 #. Tag: para
-#: basic_mapping.xml:513 basic_mapping.xml:1351
 #, no-c-format
 msgid ""
 "<literal>type</literal> (optional): a name that indicates the Hibernate type."
-msgstr "<literal>type</literal> (可选): 一个Hibernate类型的名字。"
+msgstr "<literal>type</literal>(可选):一个 Hibernate 类型的名字。"
 
 #. Tag: para
-#: basic_mapping.xml:518
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of the primary key column."
-msgstr "<literal>column</literal> (可选 - 默认为属性名): 主键字段的名字。"
+msgstr "<literal>column</literal>(可选 — 默认为属性名):主键字段的名字。 "
 
 #. Tag: para
-#: basic_mapping.xml:524
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to a \"sensible\" "
 "value): an identifier property value that indicates an instance is newly "
 "instantiated (unsaved), distinguishing it from detached instances that were "
 "saved or loaded in a previous session."
 msgstr ""
-"<literal>unsaved-value</literal> (可选 - 默认为一个切合实际(sensible)的"
-"值): 一个特定的标识属性值,用来标志该实例是刚刚创建的,尚未保存。 这可以把这"
-"种实例和从以前的session中装载过(可能又做过修改--译者注) 但未再次持久化的实"
-"例区分开来。"
+"<literal>unsaved-value</literal>(可选 — 默认为一个切合实际(sensible)的"
+"值):一个特定的标识属性值,用来标志该实例是刚刚创建的,尚未保存。这可以把这"
+"种实例和从以前的 session 中装载过(可能又做过修改--译者注)但未再次持久化的实"
+"例区分开来。 "
 
 #. Tag: para
-#: basic_mapping.xml:532
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate should use for accessing the property "
 "value."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认为<literal>property</literal>): "
-"Hibernate用来访问属性值的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认为<literal>property</literal>): "
-"Hibernate应该使用的访问此属性值的策略\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认是 <literal>property</literal>): "
-"Hibernate用于访问属性值的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认是 <literal>property</literal>): "
-"Hibernate用于访问属性值的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认值为 <literal>property</literal>): "
-"Hibernate用来访问属性值的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认是 <literal>property</literal>): "
-"Hibernate用来访问属性的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认是 <literal>property</literal>): "
-"Hibernate用来访问属性的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认是 <literal>property</literal>): "
-"Hibernate用来访问属性的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 -默认是 <literal>property</literal>): "
-"Hibernate 用来访问属性值的策略。"
+"<literal>access</literal>(可选 — 默认为 <literal>property</literal>):"
+"Hibernate 用来访问属性值的策略。 "
 
 #. Tag: para
-#: basic_mapping.xml:540
 #, no-c-format
 msgid ""
 "If the <literal>name</literal> attribute is missing, it is assumed that the "
 "class has no identifier property."
-msgstr "如果 <literal>name</literal>属性不存在,会认为这个类没有标识属性。"
+msgstr "如果 <literal>name</literal> 属性不存在,会认为这个类没有标识属性。"
 
 #. Tag: para
-#: basic_mapping.xml:545
 #, no-c-format
 msgid ""
 "The <literal>unsaved-value</literal> attribute is almost never needed in "
 "Hibernate3."
-msgstr "<literal>unsaved-value</literal> 属性在Hibernate3中几乎不再需要。"
+msgstr "<literal>unsaved-value</literal> 属性在 Hibernate3 中几乎不再需要。"
 
 #. Tag: para
-#: basic_mapping.xml:549
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is an alternative <literal>&lt;composite-id&gt;</literal> declaration "
 "that allows access to legacy data with composite keys. Its use is strongly "
 "discouraged for anything else."
 msgstr ""
-"还有一个另外的<literal>&lt;composite-id&gt;</literal>定义可以访问旧式的多主键"
-"数据。 我们强烈不建议使用这种方式。"
+"还有一个另外的 <literal>&lt;composite-id&gt;</literal> 定义可以访问旧式的多主"
+"键数据。我们非常不鼓励使用这种方式。"
 
 #. Tag: title
-#: basic_mapping.xml:555
 #, no-c-format
 msgid "Generator"
 msgstr "Generator"
 
 #. Tag: para
-#: basic_mapping.xml:557
 #, no-c-format
 msgid ""
 "The optional <literal>&lt;generator&gt;</literal> child element names a Java "
@@ -1050,45 +775,29 @@
 "generator instance, they are passed using the <literal>&lt;param&gt;</"
 "literal> element."
 msgstr ""
-"可选的<literal>&lt;generator&gt;</literal>子元素是一个Java类的名字, 用来为该"
-"持久化类的实例生成唯一的标识。如果这个生成器实例需要某些配置值或者初始化参"
-"数, 用<literal>&lt;param&gt;</literal>元素来传递。"
+"可选的 <literal>&lt;generator&gt;</literal> 子元素是一个 Java 类的名字,用来"
+"为该持久化类的实例生成唯一的标识。如果这个生成器实例需要某些配置值或者初始化"
+"参数,用 <literal>&lt;param&gt;</literal> 元素来传递。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:564
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"org.hibernate.id.TableHiLoGenerator\">\n"
-"                <param name=\"table\">uid_table</param>\n"
-"                <param name=\"column\">next_hi_value_column</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:566
-#, fuzzy, no-c-format
-msgid ""
 "All generators implement the interface <literal>org.hibernate.id."
 "IdentifierGenerator</literal>. This is a very simple interface. Some "
 "applications can choose to provide their own specialized implementations, "
 "however, Hibernate provides a range of built-in implementations. The "
 "shortcut names for the built-in generators are as follows:"
 msgstr ""
-"所有的生成器都实现<literal>org.hibernate.id.IdentifierGenerator</literal>接"
-"口。 这是一个非常简单的接口;某些应用程序可以选择提供他们自己特定的实现。当"
-"然, Hibernate提供了很多内置的实现。下面是一些内置生成器的快捷名字: "
-"<placeholder-1/>"
+"所有的生成器都实现 <literal>org.hibernate.id.IdentifierGenerator</literal> 接"
+"口。这是一个非常简单的接口;某些应用程序可以选择提供他们自己特定的实现。当"
+"然,Hibernate 提供了很多内置的实现。下面是一些内置生成器的快捷名字:  "
 
-#. Tag: literal
-#: basic_mapping.xml:574
+#. Tag: term
 #, no-c-format
-msgid "increment"
-msgstr "increment"
+msgid "<literal>increment</literal>"
+msgstr "<literal>increment</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:576
 #, no-c-format
 msgid ""
 "generates identifiers of type <literal>long</literal>, <literal>short</"
@@ -1096,54 +805,48 @@
 "process is inserting data into the same table. <emphasis>Do not use in a "
 "cluster.</emphasis>"
 msgstr ""
-"用于为<literal>long</literal>, <literal>short</literal>或者<literal>int</"
-"literal>类型生成 唯一标识。只有在没有其他进程往同一张表中插入数据时才能使"
-"用。 <emphasis>在集群下不要使用。</emphasis>"
+"用于为 <literal>long</literal>, <literal>short</literal> 或者 <literal>int</"
+"literal> 类型生成 唯一标识。只有在没有其他进程往同一张表中插入数据时才能使"
+"用。<emphasis>在集群下不要使用。</emphasis>"
 
-#. Tag: literal
-#: basic_mapping.xml:585
+#. Tag: term
 #, no-c-format
-msgid "identity"
-msgstr "identity"
+msgid "<literal>identity</literal>"
+msgstr "<literal>identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:587
 #, no-c-format
 msgid ""
 "supports identity columns in DB2, MySQL, MS SQL Server, Sybase and "
 "HypersonicSQL. The returned identifier is of type <literal>long</literal>, "
 "<literal>short</literal> or <literal>int</literal>."
 msgstr ""
-"对DB2,MySQL, MS SQL Server, Sybase和HypersonicSQL的内置标识字段提供支持。 返"
-"回的标识符是<literal>long</literal>, <literal>short</literal> 或者"
-"<literal>int</literal>类型的。"
+"对 DB2,MySQL,MS SQL Server,Sybase 和 HypersonicSQL 的内置标识字段提供支"
+"持。返回的标识符是 <literal>long</literal>,<literal>short</literal> 或者 "
+"<literal>int</literal> 类型的。"
 
-#. Tag: literal
-#: basic_mapping.xml:595
+#. Tag: term
 #, no-c-format
-msgid "sequence"
-msgstr "sequence"
+msgid "<literal>sequence</literal>"
+msgstr "<literal>sequence</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:597
 #, no-c-format
 msgid ""
 "uses a sequence in DB2, PostgreSQL, Oracle, SAP DB, McKoi or a generator in "
 "Interbase. The returned identifier is of type <literal>long</literal>, "
 "<literal>short</literal> or <literal>int</literal>"
 msgstr ""
-"在DB2,PostgreSQL, Oracle, SAP DB, McKoi中使用序列(sequence), 而在Interbase"
-"中使用生成器(generator)。返回的标识符是<literal>long</literal>, "
-"<literal>short</literal>或者 <literal>int</literal>类型的。"
+"在 DB2,PostgreSQL,Oracle,SAP DB,McKoi 中使用序列(sequence), 而在 "
+"Interbase 中使用生成器(generator)。返回的标识符是 <literal>long</literal>,"
+"<literal>short</literal> 或者 <literal>int</literal> 类型的。"
 
-#. Tag: literal
-#: basic_mapping.xml:605
+#. Tag: term
 #, no-c-format
-msgid "hilo"
-msgstr "hilo"
+msgid "<literal>hilo</literal>"
+msgstr "<literal>hilo</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:607
 #, no-c-format
 msgid ""
 "uses a hi/lo algorithm to efficiently generate identifiers of type "
@@ -1153,132 +856,116 @@
 "hi/lo algorithm generates identifiers that are unique only for a particular "
 "database."
 msgstr ""
-"使用一个高/低位算法高效的生成<literal>long</literal>, <literal>short</"
-"literal> 或者 <literal>int</literal>类型的标识符。给定一个表和字段(默认分别"
-"是 <literal>hibernate_unique_key</literal> 和<literal>next_hi</literal>)作为"
-"高位值的来源。 高/低位算法生成的标识符只在一个特定的数据库中是唯一的。"
+"使用一个高/低位算法高效的生成 <literal>long</literal>,<literal>short</"
+"literal> 或者 <literal>int</literal> 类型的标识符。给定一个表和字段(默认分别"
+"是 <literal>hibernate_unique_key</literal> 和 <literal>next_hi</literal>)作"
+"为高位值的来源。高/低位算法生成的标识符只在一个特定的数据库中是唯一的。"
 
-#. Tag: literal
-#: basic_mapping.xml:617
+#. Tag: term
 #, no-c-format
-msgid "seqhilo"
-msgstr "seqhilo"
+msgid "<literal>seqhilo</literal>"
+msgstr "<literal>seqhilo</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:619
 #, no-c-format
 msgid ""
 "uses a hi/lo algorithm to efficiently generate identifiers of type "
 "<literal>long</literal>, <literal>short</literal> or <literal>int</literal>, "
 "given a named database sequence."
 msgstr ""
-"使用一个高/低位算法来高效的生成<literal>long</literal>, <literal>short</"
-"literal> 或者 <literal>int</literal>类型的标识符,给定一个数据库序列"
+"使用一个高/低位算法来高效的生成 <literal>long</literal>,<literal>short</"
+"literal> 或者 <literal>int</literal> 类型的标识符,给定一个数据库序列"
 "(sequence)的名字。"
 
-#. Tag: literal
-#: basic_mapping.xml:627
+#. Tag: term
 #, no-c-format
-msgid "uuid"
-msgstr "uuid"
+msgid "<literal>uuid</literal>"
+msgstr "<literal>uuid</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:629
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "uses a 128-bit UUID algorithm to generate identifiers of type string that "
 "are unique within a network (the IP address is used). The UUID is encoded as "
 "a string of 32 hexadecimal digits in length."
 msgstr ""
-"用一个128-bit的UUID算法生成字符串类型的标识符, 这在一个网络中是唯一的(使用"
-"了IP地址)。UUID被编码为一个32位16进制数字的字符串。"
+"用一个 128-bit 的 UUID 算法生成字符串类型的标识符,这在一个网络中是唯一的(使"
+"用了 IP 地址)。UUID 被编码为一个 32 位 16 进制数字的字符串。 "
 
-#. Tag: literal
-#: basic_mapping.xml:637
+#. Tag: term
 #, no-c-format
-msgid "guid"
-msgstr "guid"
+msgid "<literal>guid</literal>"
+msgstr "<literal>guid</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:639
 #, no-c-format
 msgid "uses a database-generated GUID string on MS SQL Server and MySQL."
-msgstr "在MS SQL Server 和 MySQL 中使用数据库生成的GUID字符串。"
+msgstr "在 MS SQL Server 和 MySQL 中使用数据库生成的 GUID 字符串。"
 
-#. Tag: literal
-#: basic_mapping.xml:645
+#. Tag: term
 #, no-c-format
-msgid "native"
-msgstr "native"
+msgid "<literal>native</literal>"
+msgstr "<literal>native</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:647
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "selects <literal>identity</literal>, <literal>sequence</literal> or "
 "<literal>hilo</literal> depending upon the capabilities of the underlying "
 "database."
 msgstr ""
-"根据底层数据库的能力选择<literal>identity</literal>, <literal>sequence</"
-"literal> 或者<literal>hilo</literal>中的一个。"
+"根据底层数据库的能力选择 <literal>identity</literal>、<literal>sequence</"
+"literal> 或者 <literal>hilo</literal> 中的一个。"
 
-#. Tag: literal
-#: basic_mapping.xml:655
+#. Tag: term
 #, no-c-format
-msgid "assigned"
-msgstr "assigned"
+msgid "<literal>assigned</literal>"
+msgstr "<literal>assigned</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:657
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "lets the application assign an identifier to the object before <literal>save"
 "()</literal> is called. This is the default strategy if no <literal>&lt;"
 "generator&gt;</literal> element is specified."
 msgstr ""
-"让应用程序在<literal>save()</literal>之前为对象分配一个标示符。这是 "
-"<literal>&lt;generator&gt;</literal>元素没有指定时的默认生成策略。"
+"让应用程序在调用 <literal>save()</literal> 之前为对象分配一个标识符。这是 "
+"<literal>&lt;generator&gt;</literal> 元素没有指定时的默认生成策略。"
 
-#. Tag: literal
-#: basic_mapping.xml:665
+#. Tag: term
 #, no-c-format
-msgid "select"
-msgstr "select"
+msgid "<literal>select</literal>"
+msgstr "<literal>select</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:667
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "retrieves a primary key, assigned by a database trigger, by selecting the "
 "row by some unique key and retrieving the primary key value."
-msgstr "通过数据库触发器选择一些唯一主键的行并返回主键值来分配一个主键。"
+msgstr "通过数据库触发器选择一些唯一主键的行并返回主键值来分配一个主键。 "
 
-#. Tag: literal
-#: basic_mapping.xml:674
+#. Tag: term
 #, no-c-format
-msgid "foreign"
-msgstr "foreign"
+msgid "<literal>foreign</literal>"
+msgstr "<literal>foreign</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:676
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "uses the identifier of another associated object. It is usually used in "
 "conjunction with a <literal>&lt;one-to-one&gt;</literal> primary key "
 "association."
 msgstr ""
-"使用另外一个相关联的对象的标识符。通常和<literal>&lt;one-to-one&gt;</literal>"
-"联合起来使用。"
+"使用另外一个相关联的对象的标识符。它通常和 <literal>&lt;one-to-one&gt;</"
+"literal> 联合起来使用。"
 
-#. Tag: literal
-#: basic_mapping.xml:683
+#. Tag: term
 #, no-c-format
-msgid "sequence-identity"
-msgstr "sequence-identity"
+msgid "<literal>sequence-identity</literal>"
+msgstr "<literal>sequence-identity</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:685
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "a specialized sequence generation strategy that utilizes a database sequence "
 "for the actual value generation, but combines this with JDBC3 "
@@ -1287,21 +974,18 @@
 "drivers targeted for JDK 1.4. Comments on these insert statements are "
 "disabled due to a bug in the Oracle drivers."
 msgstr ""
-"一种特别的序列生成策略,使用数据库序列来生成实际值,但将它和JDBC3的"
-"getGeneratedKeys结合在一起,使得在插入语句执行的时候就返回生成的值。目前为止只"
-"有面向JDK 1.4的Oracle 10g驱动支持这一策略。注意,因为Oracle驱动程序的一个"
-"bug,这些插入语句的注释被关闭了。(原文:Note comments on these insert "
-"statements are disabled due to a bug in the Oracle drivers.)"
+"一种特别的序列生成策略,它使用数据库序列来生成实际值,但将它和 JDBC3 的 "
+"getGeneratedKeys 结合在一起,使得在插入语句执行的时候就返回生成的值。目前为止"
+"只有面向 JDK 1.4 的 Oracle 10g 驱动支持这一策略。由于 Oracle 驱动程序的一个 "
+"bug,这些插入语句的注释被关闭了。"
 
 #. Tag: title
-#: basic_mapping.xml:702
 #, no-c-format
 msgid "Hi/lo algorithm"
 msgstr "高/低位算法(Hi/Lo Algorithm)"
 
 #. Tag: para
-#: basic_mapping.xml:703
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>hilo</literal> and <literal>seqhilo</literal> generators "
 "provide two alternate implementations of the hi/lo algorithm. The first "
@@ -1309,78 +993,49 @@
 "available \"hi\" value. Where supported, the second uses an Oracle-style "
 "sequence."
 msgstr ""
-"<literal>hilo</literal> 和 <literal>seqhilo</literal>生成器给出了两种hi/lo算"
-"法的实现, 这是一种很令人满意的标识符生成算法。第一种实现需要一个“特殊”的数据"
-"库表来保存下一个可用的“hi”值。 第二种实现使用一个Oracle风格的序列(在被支持的"
-"情况下)。"
+"<literal>hilo</literal> 和 <literal>seqhilo</literal> 生成器给出了两种 hi/lo "
+"算法的实现, 这是一种很令人满意的标识符生成算法。第一种实现需要一个“特殊”的数"
+"据库表来保存下一个可用的“hi”值。 第二种实现使用一个 Oracle 风格的序列(在被支"
+"持的情况下)。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:710
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"hilo\">\n"
-"                <param name=\"table\">hi_value</param>\n"
-"                <param name=\"column\">next_value</param>\n"
-"                <param name=\"max_lo\">100</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:712
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
-"        <generator class=\"seqhilo\">\n"
-"                <param name=\"sequence\">hi_value</param>\n"
-"                <param name=\"max_lo\">100</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:714
-#, fuzzy, no-c-format
-msgid ""
 "Unfortunately, you cannot use <literal>hilo</literal> when supplying your "
 "own <literal>Connection</literal> to Hibernate. When Hibernate uses an "
 "application server datasource to obtain connections enlisted with JTA, you "
 "must configure the <literal>hibernate.transaction.manager_lookup_class</"
 "literal>."
 msgstr ""
-"很不幸,你在为Hibernate自行提供<literal>Connection</literal>时无法使用"
-"<literal>hilo</literal>。 当Hibernate使用JTA获取应用服务器的数据源连接时,你必"
-"须正确地配置 <literal>hibernate.transaction.manager_lookup_class</literal>。"
+"可惜的是,你在为 Hibernate 自行提供 <literal>Connection</literal> 时无法使用 "
+"<literal>hilo</literal>。 当 Hibernate 使用 JTA 获取应用服务器的数据源连接"
+"时,你必须正确地配置 <literal>hibernate.transaction.manager_lookup_class</"
+"literal>。"
 
 #. Tag: title
-#: basic_mapping.xml:723
 #, no-c-format
 msgid "UUID algorithm"
-msgstr "UUID算法(UUID Algorithm )"
+msgstr "UUID 算法(UUID Algorithm )"
 
 #. Tag: para
-#: basic_mapping.xml:724
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The UUID contains: IP address, startup time of the JVM that is accurate to a "
 "quarter second, system time and a counter value that is unique within the "
 "JVM. It is not possible to obtain a MAC address or memory address from Java "
 "code, so this is the best option without using JNI."
 msgstr ""
-"UUID包含:IP地址,JVM的启动时间(精确到1/4秒),系统时间和一个计数器值(在JVM"
-"中唯一)。 在Java代码中不可能获得MAC地址或者内存地址,所以这已经是我们在不使"
-"用JNI的前提下的能做的最好实现了。"
+"UUID 包含:IP 地址、JVM 的启动时间(精确到 1/4 秒)、系统时间和一个计数器值"
+"(在 JVM 中唯一)。 在 Java 代码中不可能获得 MAC 地址或者内存地址,所以这已经"
+"是我们在不使用 JNI 的前提下的能做的最好实现了。"
 
 #. Tag: title
-#: basic_mapping.xml:733
 #, no-c-format
 msgid "Identity columns and sequences"
 msgstr "标识字段和序列(Identity columns and Sequences)"
 
 #. Tag: para
-#: basic_mapping.xml:734
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For databases that support identity columns (DB2, MySQL, Sybase, MS SQL), "
 "you can use <literal>identity</literal> key generation. For databases that "
@@ -1388,54 +1043,31 @@
 "can use <literal>sequence</literal> style key generation. Both of these "
 "strategies require two SQL queries to insert a new object. For example:"
 msgstr ""
-"对于内部支持标识字段的数据库(DB2,MySQL,Sybase,MS SQL),你可以使用"
-"<literal>identity</literal>关键字生成。 对于内部支持序列的数据库(DB2,"
-"Oracle, PostgreSQL, Interbase, McKoi,SAP DB), 你可以使用<literal>sequence</"
-"literal>风格的关键字生成。 这两种方式对于插入一个新的对象都需要两次SQL查询。"
+"对于内部支持标识字段的数据库(DB2、MySQL、Sybase 和 MS SQL),你可以使用 "
+"<literal>identity</literal> 关键字生成。对于内部支持序列的数据库(DB2、"
+"Oracle、PostgreSQL、Interbase、McKoi 和 SAP DB),你可以使用 "
+"<literal>sequence</literal> 风格的关键字生成。这两种方式对于插入一个新的对象"
+"都需要两次 SQL 查询。例如:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:742
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-"        <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">person_id_sequence</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:744
-#, no-c-format
-msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\" unsaved-value=\"0"
-"\">\n"
-"        <generator class=\"identity\"/>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:746
-#, fuzzy, no-c-format
-msgid ""
 "For cross-platform development, the <literal>native</literal> strategy will, "
 "depending on the capabilities of the underlying database, choose from the "
 "<literal>identity</literal>, <literal>sequence</literal> and <literal>hilo</"
 "literal> strategies."
 msgstr ""
-"对于跨平台开发,<literal>native</literal>策略会从<literal>identity</"
-"literal>, <literal>sequence</literal> 和<literal>hilo</literal>中进行选择,选"
-"择哪一个,这取决于底层数据库的支持能力。"
+"对于跨平台开发,<literal>native</literal> 策略会从 <literal>identity</"
+"literal>、<literal>sequence</literal> 和 <literal>hilo</literal> 中进行选择,"
+"选择哪一个,这取决于底层数据库的支持能力。"
 
 #. Tag: title
-#: basic_mapping.xml:754
 #, no-c-format
 msgid "Assigned identifiers"
 msgstr "程序分配的标识符(Assigned Identifiers)"
 
 #. Tag: para
-#: basic_mapping.xml:755
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want the application to assign identifiers, as opposed to having "
 "Hibernate generate them, you can use the <literal>assigned</literal> "
@@ -1445,15 +1077,14 @@
 "behavior if you do not specify a <literal>&lt;generator&gt;</literal> "
 "element."
 msgstr ""
-"如果你需要应用程序分配一个标示符(而非Hibernate来生成),你可以使用"
+"如果你需要应用程序分配一个标示符(而非 Hibernate 来生成),你可以使用 "
 "<literal>assigned</literal> 生成器。这种特殊的生成器会使用已经分配给对象的标"
 "识符属性的标识符值。 这个生成器使用一个自然键(natural key,有商业意义的列-"
 "译注)作为主键,而不是使用一个代理键( surrogate key,没有商业意义的列-译"
-"注)。这是没有指定<literal>&lt;generator&gt;</literal>元素时的默认行为"
+"注)。这是没有指定 <literal>&lt;generator&gt;</literal> 元素时的默认行为。"
 
 #. Tag: para
-#: basic_mapping.xml:764
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>assigned</literal> generator makes Hibernate use "
 "<literal>unsaved-value=\"undefined\"</literal>. This forces Hibernate to go "
@@ -1461,57 +1092,42 @@
 "there is a version or timestamp property, or you define <literal>Interceptor."
 "isUnsaved()</literal>."
 msgstr ""
-"当选择<literal>assigned</literal>生成器时,除非有一个version或timestamp属性,"
-"或者你定义了 <literal>Interceptor.isUnsaved()</literal>,否则需要让Hiberante"
-"使用 <literal>unsaved-value=\"undefined\"</literal>,强制Hibernatet查询数据库"
-"来确定一个实例是瞬时的(transient) 还是脱管的(detached)。"
+"当选择 <literal>assigned</literal> 生成器时,除非有一个 version 或 timestamp "
+"属性,或者你定义了 <literal>Interceptor.isUnsaved()</literal>,否则需要让 "
+"Hiberante 使用 <literal>unsaved-value=\"undefined\"</literal>,强制 "
+"Hibernatet 查询数据库来确定一个实例是瞬时的(transient) 还是脱管的"
+"(detached)。"
 
 #. Tag: title
-#: basic_mapping.xml:774
 #, no-c-format
 msgid "Primary keys assigned by triggers"
 msgstr "触发器实现的主键生成器(Primary keys assigned by triggers)"
 
 #. Tag: para
-#: basic_mapping.xml:775
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate does not generate DDL with triggers. It is for legacy schemas only."
-msgstr "仅仅用于遗留的schema中 (Hibernate不能使用触发器生成DDL)。"
+msgstr "仅仅用于遗留的 schema 中(Hibernate 不能用触发器生成 DDL)。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:779
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
-"        <generator class=\"select\">\n"
-"                <param name=\"key\">socialSecurityNumber</param>\n"
-"        </generator>\n"
-"</id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:781
-#, fuzzy, no-c-format
-msgid ""
 "In the above example, there is a unique valued property named "
 "<literal>socialSecurityNumber</literal>. It is defined by the class, as a "
 "natural key and a surrogate key named <literal>person_id</literal>, whose "
 "value is generated by a trigger."
 msgstr ""
-"在上面的例子中,类定义了一个命名为<literal>socialSecurityNumber</literal>的唯"
-"一值属性, 它是一个自然键(natural key),命名为<literal>person_id</literal>"
-"的代理键(surrogate key) 的值由触发器生成。"
+"在上面的例子中,类定义了一个命名为 <literal>socialSecurityNumber</literal> 的"
+"具有唯一值的属性,它是一个自然键(natural key),命名为 <literal>person_id</"
+"literal> 的代理键(surrogate key)的值由触发器生成。"
 
 #. Tag: title
-#: basic_mapping.xml:793
 #, no-c-format
 msgid "Enhanced identifier generators"
-msgstr "Enhanced identifier generators"
+msgstr "增强的标识符生成器"
 
 #. Tag: para
-#: basic_mapping.xml:795
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Starting with release 3.2.3, there are 2 new generators which represent a re-"
 "thinking of 2 different aspects of identifier generation. The first aspect "
@@ -1521,17 +1137,13 @@
 "the named generators described above, starting in 3.3.x. However, they are "
 "included in the current releases and can be referenced by FQN."
 msgstr ""
-"Starting with release 3.2.3, there are 2 new generators which represent a re-"
-"thinking of 2 different aspects of identifier generation. The first aspect "
-"is database portability; the second is optimization (not having to query the "
-"database for every request for a new identifier value). These two new "
-"generators are intended to take the place of some of the named generators "
-"described above (starting in 3.3.x); however, they are included in the "
-"current releases and can be referenced by FQN."
+"从 3.2.3 版本开始,有两个代表不同标识符生成概念的新的生成器。第一个概念是数据"
+"库移植性;第二个是优化。优化表示你不需对每个新标识符的请求都查询数据库。从 "
+"3.3.x 开始,这两个新的生成器都是用来取代上面所述的生成器的。然而,它们也包括"
+"在当前版本里且可以由 FQN 进行引用。"
 
 #. Tag: para
-#: basic_mapping.xml:803
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The first of these new generators is <literal>org.hibernate.id.enhanced."
 "SequenceStyleGenerator</literal> which is intended, firstly, as a "
@@ -1550,99 +1162,81 @@
 "with its table-based generators. This generator has a number of "
 "configuration parameters:"
 msgstr ""
-"The first of these new generators is <literal>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</literal> which is intended firstly as a replacement "
-"for the <literal>sequence</literal> generator and secondly as a better "
-"portability generator than <literal>native</literal> (because "
-"<literal>native</literal> (generally) chooses between <literal>identity</"
-"literal> and <literal>sequence</literal> which have largely different "
-"semantics which can cause subtle isssues in applications eyeing "
-"portability). <literal>org.hibernate.id.enhanced.SequenceStyleGenerator</"
-"literal> however achieves portability in a different manner. It chooses "
-"between using a table or a sequence in the database to store its "
-"incrementing values depending on the capabilities of the dialect being used. "
-"The difference between this and <literal>native</literal> is that table-"
-"based and sequence-based storage have the same exact semantic (in fact "
-"sequences are exactly what Hibernate tries to emmulate with its table-based "
-"generators). This generator has a number of configuration parameters: "
-"<placeholder-1/>"
+"这些生成器的第一个是 <literal>org.hibernate.id.enhanced."
+"SequenceStyleGenerator</literal>,首先,它是作为 <literal>sequence</literal> "
+"生成器的替代物,其次,它是比 <literal>native</literal> 具有更好移植性的生成"
+"器。这是因为 <literal>native</literal> 通常在 <literal>identity</literal> 和 "
+"<literal>sequence</literal> 之间选择,它有差别很大的 semantic,在移植时会导致"
+"潜在的问题。然而,<literal>org.hibernate.id.enhanced.SequenceStyleGenerator</"
+"literal> 以不同的方式实现移植性。它根据所使用的方言的能力,在数据库表或序列之"
+"间选择以存储其增量。这和 <literal>native</literal> 的区别是基于表或序列的存储"
+"具有恰好相同的 semantic。实际上,序列就是 Hibernate 试图用基于表的生成器来模"
+"拟的。这个生成器有如下的配置参数:"
 
 #. Tag: para
-#: basic_mapping.xml:817
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>sequence_name</literal> (optional, defaults to "
 "<literal>hibernate_sequence</literal>): the name of the sequence or table to "
 "be used."
 msgstr ""
-"<literal>sequence_name</literal> (optional, defaults to "
-"<literal>hibernate_sequence</literal>): The name of the sequence (or table) "
-"to be used."
+"<literal>sequence_name</literal>(可选 — 默认为 <literal>hibernate_sequence</"
+"literal>):序列或表的名字"
 
 #. Tag: para
-#: basic_mapping.xml:823
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>initial_value</literal> (optional, defaults to <literal>1</"
 "literal>): the initial value to be retrieved from the sequence/table. In "
 "sequence creation terms, this is analogous to the clause typically named "
 "\"STARTS WITH\"."
 msgstr ""
-"<literal>initial_value</literal> (optional, defaults to <literal>1</"
-"literal>): The initial value to be retrieved from the sequence/table. In "
-"sequence creation terms, this is analogous to the clause typical named "
-"\"STARTS WITH\"."
+"<literal>initial_value</literal>(可选,默认为 <literal>1</literal>):从序"
+"列/表里获取的初始值。按照序列创建的术语,这等同于子句 \"STARTS WITH\"。"
 
 #. Tag: para
-#: basic_mapping.xml:830
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>increment_size</literal> (optional - defaults to <literal>1</"
 "literal>): the value by which subsequent calls to the sequence/table should "
 "differ. In sequence creation terms, this is analogous to the clause "
 "typically named \"INCREMENT BY\"."
 msgstr ""
-"<literal>increment_size</literal> (optional, defaults to <literal>1</"
-"literal>): The value by which subsequent calls to the sequence/table should "
-"differ. In sequence creation terms, this is analogous to the clause typical "
-"named \"INCREMENT BY\"."
+"<literal>increment_size</literal>(可选 - 缺省为 <literal>1</literal>):对序"
+"列/表的调用应该区分的值。按照序列创建的术语,这等同于子句 \"INCREMENT BY\"。"
 
 #. Tag: para
-#: basic_mapping.xml:837
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>force_table_use</literal> (optional - defaults to <literal>false</"
 "literal>): should we force the use of a table as the backing structure even "
 "though the dialect might support sequence?"
 msgstr ""
-"<literal>force_table_use</literal> (optional, defaults to <literal>false</"
-"literal>): Should we force the use of a table as the backing structure even "
-"though the dialect might support sequence?"
+"<literal>force_table_use</literal>(可选 - 缺省为 <literal>false</"
+"literal>):即使方言可能支持序列,是否也应该强制把表用作后台结构。"
 
 #. Tag: para
-#: basic_mapping.xml:844
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>value_column</literal> (optional - defaults to <literal>next_val</"
 "literal>): only relevant for table structures, it is the name of the column "
 "on the table which is used to hold the value."
 msgstr ""
-"<literal>value_column</literal> (optional, defaults to <literal>next_val</"
-"literal>): Only relevant for table structures! The name of the column on the "
-"table which is used to hold the value."
+"<literal>value_column</literal>(可选 - 缺省为 <literal>next_val</"
+"literal>):只和表结构相关,它是用于保存值的字段的名称。"
 
 #. Tag: para
-#: basic_mapping.xml:851
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimizer</literal> (optional - defaults to <literal>none</"
-"literal>): See"
+"literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\" /"
+">"
 msgstr ""
-"<literal>cascade</literal> (可选 -默认是<literal>none</literal>): 级联的类型"
+"<literal>optimizer</literal>(可选 — 默认是<literal>none</literal>):请参考 "
+"<xref linkend=\"mapping-declaration-id-enhanced-optimizers\" />。"
 
 #. Tag: para
-#: basic_mapping.xml:858
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The second of these new generators is <literal>org.hibernate.id.enhanced."
 "TableGenerator</literal>, which is intended, firstly, as a replacement for "
@@ -1655,147 +1249,125 @@
 "multiple distinctly keyed rows. This generator has a number of configuration "
 "parameters:"
 msgstr ""
-"The second of these new generators is <literal>org.hibernate.id.enhanced."
-"TableGenerator</literal> which is intended firstly as a replacement for the "
-"<literal>table</literal> generator (although it actually functions much more "
-"like <literal>org.hibernate.id.MultipleHiLoPerTableGenerator</literal>) and "
-"secondly as a re-implementation of <literal>org.hibernate.id."
-"MultipleHiLoPerTableGenerator</literal> utilizing the notion of pluggable "
-"optimiziers. Essentially this generator defines a table capable of holding a "
-"number of different increment values simultaneously by using multiple "
-"distinctly keyed rows. This generator has a number of configuration "
-"parameters: <placeholder-1/>"
+"新生成器的第二个是 <literal>org.hibernate.id.enhanced.TableGenerator</"
+"literal>,它的目的首先是替代 <literal>table</literal> 生成器,即使它实际上比 "
+"<literal>org.hibernate.id.MultipleHiLoPerTableGenerator</literal> 功能要强得"
+"多;其次,作为利用可插拔 optimizer 的 <literal>org.hibernate.id."
+"MultipleHiLoPerTableGenerator</literal> 的替代品。基本上这个生成器定义了一个"
+"可以利用多个不同的键值记录存储大量不同增量值的表。这个生成器有如下的配置参"
+"数:"
 
 #. Tag: para
-#: basic_mapping.xml:868
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>table_name</literal> (optional - defaults to "
 "<literal>hibernate_sequences</literal>): the name of the table to be used."
 msgstr ""
-"<literal>table_name</literal> (optional, defaults to "
-"<literal>hibernate_sequences</literal>): The name of the table to be used."
+"<literal>table_name</literal>(可选 — 默认是 <literal>hibernate_sequences</"
+"literal>):所用的表的名称。"
 
 #. Tag: para
-#: basic_mapping.xml:874
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>value_column_name</literal> (optional - defaults to "
 "<literal>next_val</literal>): the name of the column on the table that is "
 "used to hold the value."
 msgstr ""
-"<literal>value_column_name</literal> (optional, defaults to "
-"<literal>next_val</literal>): The name of the column on the table which is "
-"used to hold the value."
+"<literal>value_column_name</literal>(可选 — 默认为 <literal>next_val</"
+"literal>):用于存储这些值的表的字段的名字。"
 
 #. Tag: para
-#: basic_mapping.xml:880
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>segment_column_name</literal> (optional - defaults to "
 "<literal>sequence_name</literal>): the name of the column on the table that "
 "is used to hold the \"segment key\". This is the value which identifies "
 "which increment value to use."
 msgstr ""
-"<literal>segment_column_name</literal> (optional, defaults to "
-"<literal>sequence_name</literal>): The name of the column on the table which "
-"is used to hold the \"segement key\". This is the value which distinctly "
-"identifies which increment value to use."
+"<literal>segment_column_name</literal>(可选,默认为 <literal>sequence_name</"
+"literal>):用于保存 \"segment key\" 的字段的名称。这是标识使用哪个增量值的"
+"值。"
 
 #. Tag: para
-#: basic_mapping.xml:887
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>segment_value</literal> (optional - defaults to <literal>default</"
 "literal>): The \"segment key\" value for the segment from which we want to "
 "pull increment values for this generator."
 msgstr ""
-"<literal>segment_value</literal> (optional, defaults to <literal>default</"
-"literal>): The \"segment key\" value for the segment from which we want to "
-"pull increment values for this generator."
+"<literal>segment_value</literal>(可选,默认为 <literal>default</literal>):"
+"我们为这个生成器获取增量值的 segment 的 \"segment key\"。"
 
 #. Tag: para
-#: basic_mapping.xml:894
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>segment_value_length</literal> (optional - defaults to "
 "<literal>255</literal>): Used for schema generation; the column size to "
 "create this segment key column."
 msgstr ""
-"<literal>segment_value_length</literal> (optional, defaults to <literal>255</"
-"literal>): Used for schema generation; the column size to create this "
-"segment key column."
+"<literal>segment_value_length</literal>(可选 — 默认为 <literal>255</"
+"literal>):用于 schema 生成;创建 Segment Key 字段的字段大小。"
 
 #. Tag: para
-#: basic_mapping.xml:900
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>initial_value</literal> (optional - defaults to <literal>1</"
 "literal>): The initial value to be retrieved from the table."
 msgstr ""
-"<literal>initial_value</literal> (optional, defaults to <literal>1</"
-"literal>): The initial value to be retrieved from the table."
+"<literal>initial_value</literal>(可选 — 默认是 <literal>1</literal>):从表"
+"里获取的初始值。"
 
 #. Tag: para
-#: basic_mapping.xml:906
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>increment_size</literal> (optional - defaults to <literal>1</"
 "literal>): The value by which subsequent calls to the table should differ."
 msgstr ""
-"<literal>increment_size</literal> (optional, defaults to <literal>1</"
-"literal>): The value by which subsequent calls to the table should differ."
+"<literal>increment_size</literal>(可选 — 默认是 <literal>1</literal>):对表"
+"随后的调用应该区分的值。"
 
 #. Tag: para
-#: basic_mapping.xml:912
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimizer</literal> (optional - defaults to <literal></literal>): "
-"See"
+"See <xref linkend=\"mapping-declaration-id-enhanced-optimizers\" />"
 msgstr ""
-"<literal>cascade</literal> (可选 -默认是<literal>none</literal>): 级联的类型"
+"<literal>optimizer</literal>(可选 — 默认是 <literal> </literal>):请参考 "
+"<xref linkend=\"mapping-declaration-id-enhanced-optimizers\" />。"
 
 #. Tag: title
-#: basic_mapping.xml:922
 #, no-c-format
 msgid "Identifier generator optimization"
-msgstr "Identifier generator optimization"
+msgstr "标识符生成器的优化"
 
 #. Tag: para
-#: basic_mapping.xml:923
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For identifier generators that store values in the database, it is "
 "inefficient for them to hit the database on each and every call to generate "
 "a new identifier value. Instead, you can group a bunch of them in memory and "
 "only hit the database when you have exhausted your in-memory value group. "
 "This is the role of the pluggable optimizers. Currently only the two "
-"enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced\"/> "
+"enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced\" /> "
 "support this operation."
 msgstr ""
-"For identifier generators which store values in the database, it is "
-"inefficient for them to hit the database on each and every call to generate "
-"a new identifier value. Instead, you'd ideally want to group a bunch of them "
-"in memory and only hit the database when you have exhausted your in-memory "
-"value group. This is the role of the pluggable optimizers. Currently only "
-"the two enhanced generators (<xref linkend=\"mapping-declaration-id-enhanced"
-"\"/> support this notion. <placeholder-1/>"
+"对于在数据库里存储值的标识符生成器,生成新标识符时的每次调用都访问数据库是低"
+"效的。因此,你可以把它们在内存里分组并只有在快用光内存时才访问数据库。这是可"
+"插拔 optimizer 的任务。目前只有两个增强型的生成器支持这个操作(<xref linkend="
+"\"mapping-declaration-id-enhanced\"/>)。 "
 
 #. Tag: para
-#: basic_mapping.xml:931
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>none</literal> (generally this is the default if no optimizer was "
 "specified): this will not perform any optimizations and hit the database for "
 "each and every request."
 msgstr ""
-"<literal>none</literal> (generally this is the default if no optimizer was "
-"specified): This says to not perform any optimizations, and hit the database "
-"each and every request."
+"<literal>none</literal>(如果没有指定 optimizer,通常这是缺省配置):这不会执"
+"行任何优化,在每次请求时都访问数据库。"
 
 #. Tag: para
-#: basic_mapping.xml:937
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>hilo</literal>: applies a hi/lo algorithm around the database "
 "retrieved values. The values from the database for this optimizer are "
@@ -1804,16 +1376,12 @@
 "<literal>increment_size</literal> is multiplied by that value in memory to "
 "define a group \"hi value\"."
 msgstr ""
-"<literal>hilo</literal>: applies a hi/lo algorithm around the database "
-"retrieved values. The values from the database for this optimizer are "
-"expected to be sequential. The values retrieved from the database structure "
-"for this optimizer indicates the \"group number\"; the "
-"<literal>increment_size</literal> is multiplied by that value in memory to "
-"define a group \"hi value\"."
+"<literal>hilo</literal>:对从数据库获取的值应用 hi/lo 算法。用于这个 "
+"optimizer 的从数据库获取的值应该是有序的。它们表明“组编号”。"
+"<literal>increment_size</literal> 将乘以内存里的值来定义组的“hi 值”。"
 
 #. Tag: para
-#: basic_mapping.xml:946
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>pooled</literal>: as with the case of <literal>hilo</literal>, this "
 "optimizer attempts to minimize the number of hits to the database. Here, "
@@ -1822,76 +1390,41 @@
 "memory grouping algorithm. Here, <literal>increment_size</literal> refers to "
 "the values coming from the database."
 msgstr ""
-"<literal>pooled</literal>: like was discussed for <literal>hilo</literal>, "
-"this optimizers attempts to minimize the number of hits to the database. "
-"Here, however, we simply store the starting value for the \"next group\" "
-"into the database structure rather than a sequential value in combination "
-"with an in-memory grouping algorithm. <literal>increment_size</literal> here "
-"refers to the values coming from the database."
+"<literal>pooled</literal>:和 <literal>hilo</literal> 一样,这个 optimizer 试"
+"图最小化对数据库的访问。然而,我们只是简单地把“下一组”的起始值而不是把序列值"
+"和分组算法的组合存入到数据库结构里。在这里,<literal>increment_size</"
+"literal> 表示数据库里的值。"
 
 #. Tag: title
-#: basic_mapping.xml:959
 #, no-c-format
 msgid "composite-id"
 msgstr "composite-id"
 
-#. Tag: programlisting
-#: basic_mapping.xml:961
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<composite-id\n"
-"        name=\"propertyName\"\n"
-"        class=\"ClassName\"\n"
-"        mapped=\"true|false\"\n"
-"        access=\"field|property|ClassName\">\n"
-"        node=\"element-name|.\"\n"
-"\n"
-"        <key-property name=\"propertyName\" type=\"typename\" column="
-"\"column_name\"/>\n"
-"        <key-many-to-one name=\"propertyName class=\"ClassName\" column="
-"\"column_name\"/>\n"
-"        ......\n"
-"</composite-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:963
-#, fuzzy, no-c-format
-msgid ""
 "A table with a composite key can be mapped with multiple properties of the "
 "class as identifier properties. The <literal>&lt;composite-id&gt;</literal> "
 "element accepts <literal>&lt;key-property&gt;</literal> property mappings "
 "and <literal>&lt;key-many-to-one&gt;</literal> mappings as child elements."
 msgstr ""
-"如果表使用联合主键,你可以映射类的多个属性为标识符属性。 <literal>&lt;"
-"composite-id&gt;</literal>元素接受<literal>&lt;key-property&gt;</literal> 属"
-"性映射和<literal>&lt;key-many-to-one&gt;</literal>属性映射作为子元素。"
+"如果表使用联合主键,你可以映射类的多个属性为标识符属性。<literal>&lt;"
+"composite-id&gt;</literal> 元素接受 <literal>&lt;key-property&gt;</literal> "
+"属性映射和 <literal>&lt;key-many-to-one&gt;</literal> 属性映射作为子元素。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:970
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<composite-id>\n"
-"        <key-property name=\"medicareNumber\"/>\n"
-"        <key-property name=\"dependent\"/>\n"
-"</composite-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:972
-#, fuzzy, no-c-format
-msgid ""
 "The persistent class <emphasis>must</emphasis> override <literal>equals()</"
 "literal> and <literal>hashCode()</literal> to implement composite identifier "
 "equality. It must also implement <literal>Serializable</literal>."
 msgstr ""
-"你的持久化类<emphasis>必须</emphasis>重载<literal>equals()</literal>和 "
-"<literal>hashCode()</literal>方法,来实现组合的标识符的相等判断。 实现"
-"<literal>Serializable</literal>接口也是必须的。"
+"你的持久化类<emphasis>必须</emphasis>覆盖 <literal>equals()</literal> 和 "
+"<literal>hashCode()</literal> 方法,来实现组合的标识符的相等判断。实现 "
+"<literal>Serializable</literal> 接口也是必须的。"
 
 #. Tag: para
-#: basic_mapping.xml:978
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Unfortunately, this approach means that a persistent object is its own "
 "identifier. There is no convenient \"handle\" other than the object itself. "
@@ -1902,13 +1435,12 @@
 "serious applications."
 msgstr ""
 "不幸的是,这种组合关键字的方法意味着一个持久化类是它自己的标识。除了对象自己"
-"之外, 没有什么方便的“把手”可用。你必须初始化持久化类的实例,填充它的标识符属"
-"性,再<literal>load()</literal> 组合关键字关联的持久状态。我们把这种方法称为"
-"<emphasis>embedded(嵌入式)</emphasis>的组合标识符,在重要的应用中不鼓励使用"
-"这种用法。"
+"之外,没有什么方便的“把手”可用。你必须初始化持久化类的实例,填充它的标识符属"
+"性,再 <literal>load()</literal> 组合关键字关联的持久状态。我们把这种方法称"
+"为 <emphasis>embedded(嵌入式)</emphasis>的组合标识符,在重要的应用中不鼓励"
+"使用这种用法。 "
 
 #. Tag: para
-#: basic_mapping.xml:987
 #, no-c-format
 msgid ""
 "A second approach is what we call a <emphasis>mapped</emphasis> composite "
@@ -1916,24 +1448,13 @@
 "composite-id&gt;</literal> element are duplicated on both the persistent "
 "class and a separate identifier class."
 msgstr ""
-"第二种方法我们称为<emphasis>mapped(映射式)</emphasis>组合标识符 (mapped "
-"composite identifier),<literal>&lt;composite-id&gt;</literal>元素中列出的标识"
-"属性不但在持久化类出现,还形成一个独立的标识符类。"
+"第二种方法我们称为 <emphasis>mapped(映射式)</emphasis>组合标识符(mapped "
+"composite identifier),<literal>&lt;composite-id&gt;</literal> 元素中列出的"
+"标识属性不但在持久化类出现,还形成一个独立的标识符类。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:993
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<composite-id class=\"MedicareId\" mapped=\"true\">\n"
-"        <key-property name=\"medicareNumber\"/>\n"
-"        <key-property name=\"dependent\"/>\n"
-"</composite-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:995
-#, fuzzy, no-c-format
-msgid ""
 "In this example, both the composite identifier class, <literal>MedicareId</"
 "literal>, and the entity class itself have properties named "
 "<literal>medicareNumber</literal> and <literal>dependent</literal>. The "
@@ -1941,131 +1462,95 @@
 "<literal>hashCode()</literal> and implement <literal>Serializable</literal>. "
 "The main disadvantage of this approach is code duplication."
 msgstr ""
-"在这个例子中,组合标识符类<literal>MedicareId</literal>和实体类都含有"
-"<literal>medicareNumber</literal>和<literal>dependent</literal>属性。标识符类"
-"必须重载<literal>equals()</literal>和<literal>hashCode()</literal>并且实现"
-"<literal>Serializable</literal>接口。这种方法的缺点是出现了明显的代码重复。"
+"在这个例子中,组合标识符类 <literal>MedicareId</literal> 和实体类都含有 "
+"<literal>medicareNumber</literal> 和 <literal>dependent</literal> 属性。标识"
+"符类必须重载 <literal>equals()</literal> 和 <literal>hashCode()</literal> 并"
+"且实现 <literal>Serializable</literal> 接口。这种方法的缺点是出现了明显的代码"
+"重复。"
 
 #. Tag: para
-#: basic_mapping.xml:1004
 #, no-c-format
 msgid ""
 "The following attributes are used to specify a mapped composite identifier:"
 msgstr "下面列出的属性是用来指定一个映射式组合标识符的:"
 
 #. Tag: para
-#: basic_mapping.xml:1010
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mapped</literal> (optional - defaults to <literal>false</literal>): "
 "indicates that a mapped composite identifier is used, and that the contained "
 "property mappings refer to both the entity class and the composite "
 "identifier class."
 msgstr ""
-"<literal>mapped</literal> (可选, 默认为<literal>false</literal>): 指明使用一"
-"个映射式组合标识符,其包含的属性映射同时在实体类和组合标识符类中出现。"
+"<literal>mapped</literal>(可选,默认为 <literal>false</literal>):指明使用"
+"一个映射式组合标识符,其包含的属性映射同时在实体类和组合标识符类中出现。 "
 
 #. Tag: para
-#: basic_mapping.xml:1018
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - but required for a mapped composite "
 "identifier): the class used as a composite identifier."
 msgstr ""
-"<literal>class</literal> (可选,但对映射式组合标识符必须指定): 作为组合标识符"
-"类使用的类名."
+"<literal>class</literal>(可选,但对映射式组合标识符必须指定):作为组合标识符"
+"类使用的类名。"
 
 #. Tag: para
-#: basic_mapping.xml:1025
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will describe a third, even more convenient approach, where the composite "
 "identifier is implemented as a component class in <xref linkend=\"components-"
-"compositeid\"/>. The attributes described below apply only to this "
+"compositeid\" />. The attributes described below apply only to this "
 "alternative approach:"
 msgstr ""
-"在<xref linkend=\"components-compositeid\"/>一节中,我们会描述第三种方式,那就"
-"是把组合标识符实现为一个组件(component)类,这是更方便的方法。下面的属性仅对第"
-"三种方法有效:"
+"在 <xref linkend=\"components-compositeid\"/> 一节中,我们会描述第三种方式,那"
+"就是把组合标识符实现为一个组件(component)类,这是更方便的方法。下面的属性仅"
+"对第三种方法有效: "
 
 #. Tag: para
-#: basic_mapping.xml:1033
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal> (optional - required for this approach): a property "
 "of component type that holds the composite identifier. Please see chapter 9 "
 "for more information."
 msgstr ""
-"<literal>name</literal> (可选,但对这种方法而言必须): 包含此组件标识符的组件类"
-"型的名字 (参阅第9章)."
+"<literal>name</literal>(可选,但对这种方法而言必须):包含此组件标识符的组件"
+"类型的名字(参阅第 9 章)。"
 
 #. Tag: para
-#: basic_mapping.xml:1039 basic_mapping.xml:1260 basic_mapping.xml:1372
-#: basic_mapping.xml:1561 basic_mapping.xml:1735 basic_mapping.xml:1905
-#: basic_mapping.xml:2484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate uses for accessing the property value."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认为<literal>property</literal>): "
-"Hibernate用来访问属性值的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认为<literal>property</literal>): "
-"Hibernate应该使用的访问此属性值的策略\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认是 <literal>property</literal>): "
-"Hibernate用于访问属性值的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认是 <literal>property</literal>): "
-"Hibernate用于访问属性值的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认值为 <literal>property</literal>): "
-"Hibernate用来访问属性值的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认是 <literal>property</literal>): "
-"Hibernate用来访问属性的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认是 <literal>property</literal>): "
-"Hibernate用来访问属性的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认是 <literal>property</literal>): "
-"Hibernate用来访问属性的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 -默认是 <literal>property</literal>): "
-"Hibernate 用来访问属性值的策略。"
+"<literal>access</literal>(可选 — 默认为 <literal>property</literal>):"
+"Hibernate 用来访问属性值的策略。 "
 
 #. Tag: para
-#: basic_mapping.xml:1045
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
 "determined by reflection): the component class used as a composite "
 "identifier. Please see the next section for more information."
 msgstr ""
-"<literal>class</literal> (可选 - 默认会用反射来自动判定属性类型 ): 用来作为组"
-"合标识符的组件类的类名(参阅下一节)"
+"<literal>class</literal>(可选 — 默认会用反射来自动判定属性类型 ):用来作为"
+"组合标识符的组件类的类名(参阅下一节)。 "
 
 #. Tag: para
-#: basic_mapping.xml:1052
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The third approach, an <emphasis>identifier component</emphasis>, is "
 "recommended for almost all applications."
 msgstr ""
-"第三种方式,被称为<emphasis>identifier component(标识符组件)</emphasis>是我们"
-"对几乎所有应用都推荐使用的方式。"
+"第三种方式,被称为 <emphasis>identifier component(标识符组件)</emphasis>是"
+"我们对几乎所有应用都推荐使用的方式。 "
 
 #. Tag: title
-#: basic_mapping.xml:1060
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Discriminator"
-msgstr "鉴别器(discriminator)"
+msgstr "鉴别器(discriminator) "
 
 #. Tag: para
-#: basic_mapping.xml:1062
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;discriminator&gt;</literal> element is required for "
 "polymorphic persistence using the table-per-class-hierarchy mapping "
@@ -2077,224 +1562,146 @@
 "<literal>boolean</literal>, <literal>yes_no</literal>, <literal>true_false</"
 "literal>."
 msgstr ""
-"在\"一棵对象继承树对应一个表\"的策略中,<literal>&lt;discriminator&gt;</"
-"literal>元素是必需的, 它定义了表的鉴别器字段。鉴别器字段包含标志值,用于告知"
-"持久化层应该为某个特定的行创建哪一个子类的实例。 如下这些受到限制的类型可以使"
-"用: <literal>string</literal>, <literal>character</literal>, "
-"<literal>integer</literal>, <literal>byte</literal>, <literal>short</"
-"literal>, <literal>boolean</literal>, <literal>yes_no</literal>, "
-"<literal>true_false</literal>."
+"在\"一棵对象继承树对应一个表\"的策略中,<literal>&lt;discriminator&gt;</"
+"literal> 元素是必需的,它定义了表的鉴别器字段。鉴别器字段包含标志值,用于告知"
+"持久化层应该为某个特定的行创建哪一个子类的实例。如下这些受到限制的类型可以使"
+"用:<literal>string</literal>、<literal>character</literal>、"
+"<literal>integer</literal>、<literal>byte</literal>、<literal>short</"
+"literal>、<literal>boolean</literal>、<literal>yes_no</literal>、"
+"<literal>true_false</literal>。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1080
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<discriminator\n"
-"        column=\"discriminator_column\"\n"
-"        type=\"discriminator_type\"\n"
-"        force=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        formula=\"arbitrary sql expression\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1083
-#, fuzzy, no-c-format
-msgid ""
 "<literal>column</literal> (optional - defaults to <literal>class</literal>): "
 "the name of the discriminator column."
 msgstr ""
-"<literal>column</literal> (可选 - 默认为 <literal>class</literal>) 鉴别器字段"
-"的名字"
+"<literal>column</literal>(可选 — 默认为 <literal>class</literal>)"
+"discriminator 器字段的名字。"
 
 #. Tag: para
-#: basic_mapping.xml:1089
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>type</literal> (optional - defaults to <literal>string</literal>): "
 "a name that indicates the Hibernate type"
 msgstr ""
-"<literal>type</literal> (可选 - 默认为 <literal>string</literal>) 一个"
-"Hibernate字段类型的名字"
+"<literal>type</literal>(可选 — 默认为 <literal>string</literal>)一个 "
+"Hibernate 字段类型的名字 "
 
 #. Tag: para
-#: basic_mapping.xml:1095
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>force</literal> (optional - defaults to <literal>false</literal>): "
 "\"forces\" Hibernate to specify the allowed discriminator values, even when "
 "retrieving all instances of the root class."
 msgstr ""
-"<literal>force(强制)</literal> (可选 - 默认为 <literal>false</literal>) \"强"
-"制\"Hibernate指定允许的鉴别器值,即使当取得的所有实例都是根类的。"
+"<literal>force(强制)</literal>(可选 — 默认为 <literal>false</literal>)\"强"
+"制\" Hibernate 指定允许的鉴别器值,即使当取得的所有实例都是根类的。 "
 
 #. Tag: para
-#: basic_mapping.xml:1102
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>insert</literal> (optional - defaults to <literal>true</literal>): "
 "set this to <literal>false</literal> if your discriminator column is also "
 "part of a mapped composite identifier. It tells Hibernate not to include the "
 "column in SQL <literal>INSERTs</literal>."
 msgstr ""
-"<literal>insert</literal> (可选 - 默认为<literal>true</literal>) 如果你的鉴别"
-"器字段也是映射为复合标识(composite identifier)的一部分,则需将 这个值设为"
-"<literal>false</literal>。(告诉Hibernate在做SQL <literal>INSERT</literal> 时"
-"不包含该列)"
+"<literal>insert</literal>(可选 - 默认为<literal>true</literal>)如果你的鉴别"
+"器字段也是映射为复合标识(composite identifier)的一部分,则需将这个值设为 "
+"<literal>false</literal>。(告诉 Hibernate 在做 SQL <literal>INSERT</"
+"literal> 时不包含该列) "
 
 #. Tag: para
-#: basic_mapping.xml:1110
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an arbitrary SQL expression that is "
 "executed when a type has to be evaluated. It allows content-based "
 "discrimination."
 msgstr ""
-"<literal>formula</literal> (可选) 一个SQL表达式,在类型判断(判断是父类还是具"
-"体子类-译注)时执行。可用于基于内容的鉴别器。"
+"<literal>formula</literal>(可选)一个 SQL 表达式,在类型判断(判断是父类还是"
+"具体子类 — 译注)时执行。可用于基于内容的鉴别器。 "
 
 #. Tag: para
-#: basic_mapping.xml:1118
 #, no-c-format
 msgid ""
 "Actual values of the discriminator column are specified by the "
 "<literal>discriminator-value</literal> attribute of the <literal>&lt;"
 "class&gt;</literal> and <literal>&lt;subclass&gt;</literal> elements."
 msgstr ""
-"鉴别器字段的实际值是根据<literal>&lt;class&gt;</literal>和<literal>&lt;"
-"subclass&gt;</literal>元素中 的<literal>discriminator-value</literal>属性得来"
-"的。"
+"鉴别器字段的实际值是根据 <literal>&lt;class&gt;</literal> 和 <literal>&lt;"
+"subclass&gt;</literal> 元素中的 <literal>discriminator-value</literal> 属性得"
+"来的。"
 
 #. Tag: para
-#: basic_mapping.xml:1124
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>force</literal> attribute is only useful if the table contains "
 "rows with \"extra\" discriminator values that are not mapped to a persistent "
 "class. This will not usually be the case."
 msgstr ""
-"<literal>force</literal>属性仅仅在这种情况下有用的:表中包含没有被映射到持久"
-"化类的附加辨别器值。 这种情况不会经常遇到。"
+"<literal>force</literal> 属性仅仅在这种情况下有用的:表中包含没有被映射到持久"
+"化类的附加辨别器值。这种情况不会经常遇到。 "
 
 #. Tag: para
-#: basic_mapping.xml:1130
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>formula</literal> attribute allows you to declare an arbitrary "
 "SQL expression that will be used to evaluate the type of a row. For example:"
 msgstr ""
-"使用<literal>formula</literal>属性你可以定义一个SQL表达式,用来判断一个行数据"
-"的类型。"
+"使用 <literal>formula</literal> 属性你可以定义一个 SQL 表达式,用来判断一行数"
+"据的类型。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1135
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<discriminator\n"
-"    formula=\"case when CLASS_TYPE in ('a', 'b', 'c') then 0 else 1 end\"\n"
-"    type=\"integer\"/>]]>"
-msgstr ""
-
-#. Tag: title
-#: basic_mapping.xml:1140
-#, fuzzy, no-c-format
 msgid "Version (optional)"
-msgstr "版本(version)(可选)"
+msgstr "版本(version)(可选) "
 
 #. Tag: para
-#: basic_mapping.xml:1142
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;version&gt;</literal> element is optional and indicates "
 "that the table contains versioned data. This is particularly useful if you "
 "plan to use <emphasis>long transactions</emphasis>. See below for more "
 "information:"
 msgstr ""
-"<literal>&lt;version&gt;</literal>元素是可选的,表明表中包含附带版本信息的数"
-"据。 这在你准备使用<emphasis> 长事务(long transactions)</emphasis>的时候特"
-"别有用。(见后)"
+"<literal>&lt;version&gt;</literal> 元素是可选的,表明表中包含附带版本信息的数"
+"据。这在你准备使用<emphasis> 长事务(long transactions)</emphasis>的时候特别"
+"有用。下面是更多信息:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1158
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<version\n"
-"        column=\"version_column\"\n"
-"        name=\"propertyName\"\n"
-"        type=\"typename\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unsaved-value=\"null|negative|undefined\"\n"
-"        generated=\"never|always\"\n"
-"        insert=\"true|false\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1161
-#, fuzzy, no-c-format
-msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of the column holding the version number."
 msgstr ""
-"<literal>column</literal> (可选 - 默认为属性名): 指定持有版本号的字段名。"
+"<literal>column</literal>(可选 — 默认为属性名):指定持有版本号的字段名。 "
 
 #. Tag: para
-#: basic_mapping.xml:1167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal>: the name of a property of the persistent class."
-msgstr "<literal>name</literal>: 持久化类的属性名。"
+msgstr "<literal>name</literal>:持久化类的属性名。 "
 
 #. Tag: para
-#: basic_mapping.xml:1172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>type</literal> (optional - defaults to <literal>integer</literal>): "
 "the type of the version number."
 msgstr ""
-"<literal>type</literal> (可选 - 默认是 <literal>integer</literal>): 版本号的"
-"类型。"
+"<literal>type</literal>(可选 — 默认是 <literal>integer</literal>):版本号的"
+"类型。 "
 
 #. Tag: para
-#: basic_mapping.xml:1178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate uses to access the property value."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认为<literal>property</literal>): "
-"Hibernate用来访问属性值的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认为<literal>property</literal>): "
-"Hibernate应该使用的访问此属性值的策略\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认是 <literal>property</literal>): "
-"Hibernate用于访问属性值的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认是 <literal>property</literal>): "
-"Hibernate用于访问属性值的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认值为 <literal>property</literal>): "
-"Hibernate用来访问属性值的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认是 <literal>property</literal>): "
-"Hibernate用来访问属性的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认是 <literal>property</literal>): "
-"Hibernate用来访问属性的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 - 默认是 <literal>property</literal>): "
-"Hibernate用来访问属性的策略。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>access</literal> (可选 -默认是 <literal>property</literal>): "
-"Hibernate 用来访问属性值的策略。"
+"<literal>access</literal>(可选 — 默认为 <literal>property</literal>):"
+"Hibernate 用来访问属性值的策略。 "
 
 #. Tag: para
-#: basic_mapping.xml:1184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to <literal>undefined</"
 "literal>): a version property value that indicates that an instance is newly "
@@ -2302,13 +1709,12 @@
 "saved or loaded in a previous session. <literal>Undefined</literal> "
 "specifies that the identifier property value should be used."
 msgstr ""
-"<literal>unsaved-value</literal> (可选 - 默认是<literal>undefined</"
-"literal>): 用于标明某个实例时刚刚被实例化的(尚未保存)版本属性值,依靠这个值"
-"就可以把这种情况 和已经在先前的session中保存或装载的脱管(detached)实例区分"
-"开来。 (<literal>undefined</literal>指明应被使用的标识属性值。)"
+"<literal>unsaved-value</literal>(可选 — 默认是 <literal>undefined</"
+"literal>):用于标明某个实例时刚刚被实例化的(尚未保存)版本属性值,依靠这个"
+"值就可以把这种情况 和已经在先前的 session 中保存或装载的脱管(detached)实例"
+"区分开来。(<literal>undefined</literal> 指明应被使用的标识属性值。) "
 
 #. Tag: para
-#: basic_mapping.xml:1193
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2316,38 +1722,35 @@
 "database. See the discussion of <link linkend=\"mapping-generated"
 "\">generated properties</link> for more information."
 msgstr ""
-"<literal>generated</literal> (可选 - 默认是 <literal>never</literal>): 表明此"
-"版本属性值是否实际上是由数据库生成的。请参阅<xref linkend=\"mapping-generated"
-"\">generated properties</xref>部分的讨论。"
+"<literal>generated</literal>(可选 — 默认是 <literal>never</literal>):表明"
+"此版本属性值是否实际上是由数据库生成的。请参阅 <xref linkend=\"mapping-"
+"generated\"/> 部分的讨论。 "
 
 #. Tag: para
-#: basic_mapping.xml:1200
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>insert</literal> (optional - defaults to <literal>true</literal>): "
 "specifies whether the version column should be included in SQL insert "
 "statements. It can be set to <literal>false</literal> if the database column "
 "is defined with a default value of <literal>0</literal>."
 msgstr ""
-"<literal>insert</literal> (可选 - 默认是 <literal>true</literal>): 表明此版本"
-"列应该包含在SQL插入语句中。只有当数据库字段有默认值<literal>0</literal>的时"
-"候,才可以设置为<literal>false</literal>。"
+"<literal>insert</literal>(可选 — 默认是 <literal>true</literal>):表明此版"
+"本列应该包含在 SQL 插入语句中。只有当数据库字段有默认值 <literal>0</literal> "
+"的时候,才可以设置为 <literal>false</literal>。 "
 
 #. Tag: para
-#: basic_mapping.xml:1210
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Version numbers can be of Hibernate type <literal>long</literal>, "
 "<literal>integer</literal>, <literal>short</literal>, <literal>timestamp</"
 "literal> or <literal>calendar</literal>."
 msgstr ""
-"版本号必须是以下类型:<literal>long</literal>, <literal>integer</literal>, "
-"<literal>short</literal>, <literal>timestamp</literal>或者<literal>calendar</"
-"literal>。"
+"版本号必须是以下类型:<literal>long</literal>、<literal>integer</literal>、"
+"<literal>short</literal>、<literal>timestamp</literal> 或者 "
+"<literal>calendar</literal>。"
 
 #. Tag: para
-#: basic_mapping.xml:1215
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A version or timestamp property should never be null for a detached "
 "instance. Hibernate will detect any instance with a null version or "
@@ -2357,69 +1760,50 @@
 "reattachment in Hibernate. It is especially useful for people using assigned "
 "identifiers or composite keys</emphasis>."
 msgstr ""
-"一个脱管(detached)实例的version或timestamp属性不能为空(null),因为"
-"Hibernate不管 <literal>unsaved-value</literal>被指定为何种策略,它将任何属性"
-"为空的version或timestamp 实例看作为瞬时(transient)实例。 <emphasis>避免"
-"Hibernate中的传递重附(transitive reattachment)问题的一个简单方法是 定义一个"
-"不能为空的version或timestamp属性,特别是在人们使用程序分配的标识符(assigned "
-"identifiers) 或复合主键时非常有用!</emphasis>"
+"一个脱管(detached)实例的 version 或 timestamp 属性不能为空(null),因为 "
+"Hibernate 不管  <literal>unsaved-value</literal> 被指定为何种策略,它将任何属"
+"性为空的 version 或 timestamp 实例看作为瞬时(transient)实例。 <emphasis>避"
+"免 Hibernate 中的传递重附(transitive reattachment)问题的一个简单方法是 定义"
+"一个不能为空的 version 或 timestamp 属性,特别是在人们使用程序分配的标识符"
+"(assigned identifiers) 或复合主键时非常有用</emphasis>。"
 
 #. Tag: title
-#: basic_mapping.xml:1226
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Timestamp (optional)"
-msgstr "timestamp (可选)"
+msgstr "timestamp(可选) "
 
 #. Tag: para
-#: basic_mapping.xml:1228
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The optional <literal>&lt;timestamp&gt;</literal> element indicates that the "
 "table contains timestamped data. This provides an alternative to versioning. "
 "Timestamps are a less safe implementation of optimistic locking. However, "
 "sometimes the application might use the timestamps in other ways."
 msgstr ""
-"可选的<literal>&lt;timestamp&gt;</literal>元素指明了表中包含时间戳数据。 这用"
-"来作为版本的替代。时间戳本质上是一种对乐观锁定的一种不是特别安全的实现。当"
-"然, 有时候应用程序可能在其他方面使用时间戳。"
+"可选的 <literal>&lt;timestamp&gt;</literal> 元素指明了表中包含时间戳数据。这"
+"用来作为版本的替代。时间戳本质上是一种对乐观锁定的一种不是特别安全的实现。当"
+"然,有时候应用程序可能在其他方面使用时间戳。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1244
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<timestamp\n"
-"        column=\"timestamp_column\"\n"
-"        name=\"propertyName\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unsaved-value=\"null|undefined\"\n"
-"        source=\"vm|db\"\n"
-"        generated=\"never|always\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1247
-#, fuzzy, no-c-format
-msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of a column holding the timestamp."
-msgstr "<literal>column</literal> (可选 - 默认为属性名): 持有时间戳的字段名。"
+msgstr ""
+"<literal>column</literal>(可选 — 默认为属性名):存有时间戳的字段名。 "
 
 #. Tag: para
-#: basic_mapping.xml:1253
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>name</literal>: the name of a JavaBeans style property of Java type "
 "<literal>Date</literal> or <literal>Timestamp</literal> of the persistent "
 "class."
 msgstr ""
-"<literal>name</literal>: 在持久化类中的JavaBeans风格的属性名, 其Java类型是 "
-"<literal>Date</literal> 或者 <literal>Timestamp</literal>的。"
+"<literal>name</literal>:在持久化类中的 JavaBeans 风格的属性名,其 Java 类型"
+"是 <literal>Date</literal> 或者 <literal>Timestamp</literal> 的。 "
 
 #. Tag: para
-#: basic_mapping.xml:1266
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unsaved-value</literal> (optional - defaults to <literal>null</"
 "literal>): a version property value that indicates that an instance is newly "
@@ -2427,14 +1811,13 @@
 "saved or loaded in a previous session. <literal>Undefined</literal> "
 "specifies that the identifier property value should be used."
 msgstr ""
-"<literal>unsaved-value</literal> (可选 - 默认是<literal>null</literal>): 用于"
-"标明某个实例时刚刚被实例化的(尚未保存)版本属性值,依靠这个值就可以把这种情"
-"况和 已经在先前的session中保存或装载的脱管(detached)实例区分开来。"
-"(<literal>undefined</literal> 指明使用标识属性值进行这种判断。)"
+"<literal>unsaved-value</literal>(可选 — 默认是 <literal>null</literal>):用"
+"于标明某个实例时刚刚被实例化的(尚未保存)版本属性值,依靠这个值就可以把这种"
+"情况和已经在先前的 session 中保存或装载的脱管(detached)实例区分开来。"
+"(<literal>undefined</literal> 指明使用标识属性值进行这种判断。) "
 
 #. Tag: para
-#: basic_mapping.xml:1275
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>source</literal> (optional - defaults to <literal>vm</literal>): "
 "Where should Hibernate retrieve the timestamp value from? From the database, "
@@ -2445,15 +1828,14 @@
 "timestamp. Others may also be unsafe for usage in locking due to lack of "
 "precision (Oracle 8, for example)."
 msgstr ""
-"<literal>source</literal> (可选 - 默认是 <literal>vm</literal>): Hibernate如"
-"何才能获取到时间戳的值呢?从数据库,还是当前JVM?从数据库获取会带来一些负担,"
-"因为Hibernate必须访问数据库来获得“下一个值”,但是在集群环境中会更安全些。还要"
-"注意,并不是所有的<literal>Dialect(方言)</literal>都支持获得数据库的当前时"
-"间戳的,而支持的数据库中又有一部分因为精度不足,用于锁定是不安全的(例如"
-"Oracle 8)。"
+"<literal>source</literal>(可选 — 默认是 <literal>vm</literal>):Hibernate "
+"如何才能获取到时间戳的值呢?从数据库,还是当前 JVM?从数据库获取会带来一些负"
+"担,因为 Hibernate 必须访问数据库来获得“下一个值”,但是在集群环境中会更安全"
+"些。还要注意,并不是所有的 <literal>Dialect(方言)</literal>都支持获得数据库"
+"的当前时间戳的,而支持的数据库中又有一部分因为精度不足,用于锁定是不安全的"
+"(例如 Oracle 8)。 "
 
 #. Tag: para
-#: basic_mapping.xml:1287
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2461,94 +1843,61 @@
 "generated by the database. See the discussion of <link linkend=\"mapping-"
 "generated\">generated properties</link> for more information."
 msgstr ""
-"<literal>generated</literal> (可选 - 默认是 <literal>never</literal>): 指出时"
-"间戳值是否实际上是由数据库生成的.请参阅<xref linkend=\"mapping-generated"
-"\">generated properties</xref>的讨论。"
+"<literal>generated</literal>(可选 - 默认是 <literal>never</literal>):指出"
+"时间戳值是否实际上是由数据库生成的。请参阅 <xref linkend=\"mapping-generated"
+"\"/> 的讨论。 "
 
 #. Tag: title
-#: basic_mapping.xml:1298 basic_mapping.xml:2890
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "注意"
 
 #. Tag: para
-#: basic_mapping.xml:1299
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>&lt;Timestamp&gt;</literal> is equivalent to <literal>&lt;version "
 "type=\"timestamp\"&gt;</literal>. And <literal>&lt;timestamp source=\"db"
 "\"&gt;</literal> is equivalent to <literal>&lt;version type=\"dbtimestamp"
 "\"&gt;</literal>"
 msgstr ""
-"注意,<literal>&lt;timestamp&gt;</literal> 和<literal>&lt;version type="
-"\"timestamp\"&gt;</literal>是等价的。并且<literal>&lt;timestamp source=\"db"
-"\"&gt;</literal>和<literal>&lt;version type=\"dbtimestamp\"&gt;</literal>是等"
-"价的。"
+"注意,<literal>&lt;timestamp&gt;</literal> 和 <literal>&lt;version type="
+"\"timestamp\"&gt;</literal> 是等价的。并且 <literal>&lt;timestamp source=\"db"
+"\"&gt;</literal> 和 <literal>&lt;version type=\"dbtimestamp\"&gt;</literal> "
+"是等价的。 "
 
 #. Tag: title
-#: basic_mapping.xml:1311
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Property"
-msgstr "property"
+msgstr "Property"
 
 #. Tag: para
-#: basic_mapping.xml:1313
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;property&gt;</literal> element declares a persistent "
 "JavaBean style property of the class."
 msgstr ""
-"<literal>&lt;property&gt;</literal>元素为类定义了一个持久化的,JavaBean风格的"
-"属性。"
+"<literal>&lt;property&gt;</literal> 元素为类定义了一个持久化的、JavaBean 风格"
+"的属性。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1335
-#, no-c-format
-msgid ""
-"<![CDATA[<property\n"
-"        name=\"propertyName\"\n"
-"        column=\"column_name\"\n"
-"        type=\"typename\"\n"
-"        update=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        formula=\"arbitrary SQL expression\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        lazy=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        not-null=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        generated=\"never|insert|always\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        index=\"index_name\"\n"
-"        unique_key=\"unique_key_id\"\n"
-"        length=\"L\"\n"
-"        precision=\"P\"\n"
-"        scale=\"S\"\n"
-"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1338
 #, no-c-format
 msgid ""
 "<literal>name</literal>: the name of the property, with an initial lowercase "
 "letter."
-msgstr "<literal>name</literal>: 属性的名字,以小写字母开头。"
+msgstr "<literal>name</literal>:属性的名字,以小写字母开头。"
 
 #. Tag: para
-#: basic_mapping.xml:1344
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>column</literal> (optional - defaults to the property name): the "
 "name of the mapped database table column. This can also be specified by "
 "nested <literal>&lt;column&gt;</literal> element(s)."
 msgstr ""
-"<literal>column</literal> (可选 - 默认为属性名字): 对应的数据库字段名。 也可"
-"以通过嵌套的<literal>&lt;column&gt;</literal>元素指定。"
+"<literal>column</literal>(可选 — 默认为属性名字):对应的数据库字段名。 也可"
+"以通过嵌套的 <literal>&lt;column&gt;</literal> 元素指定。 "
 
 #. Tag: para
-#: basic_mapping.xml:1356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update, insert</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that the mapped columns should be included in SQL "
@@ -2557,71 +1906,65 @@
 "whose value is initialized from some other property that maps to the same "
 "column(s), or by a trigger or other application."
 msgstr ""
-"<literal>update, insert</literal> (可选 - 默认为 <literal>true</literal>) : "
-"表明用于<literal>UPDATE</literal> 和/或 <literal>INSERT</literal> 的SQL语句中"
-"是否包含这个被映射了的字段。这二者如果都设置为<literal>false</literal> 则表明"
-"这是一个“外源性(derived)”的属性,它的值来源于映射到同一个(或多个) 字段的"
-"某些其他属性,或者通过一个trigger(触发器)或其他程序生成。"
+"<literal>update, insert</literal>(可选 — 默认为 <literal>true</literal>): "
+"表明用于 <literal>UPDATE</literal> 和/或 <literal>INSERT</literal> 的 SQL 语"
+"句中是否包含这个被映射了的字段。这二者如果都设置为 <literal>false</literal> "
+"则表明这是一个“外源性(derived)”的属性,它的值来源于映射到同一个(或多个) "
+"字段的某些其他属性,或者通过一个 trigger(触发器)或其他程序生成。 "
 
 #. Tag: para
-#: basic_mapping.xml:1365
 #, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an SQL expression that defines the "
 "value for a <emphasis>computed</emphasis> property. Computed properties do "
 "not have a column mapping of their own."
 msgstr ""
-"<literal>formula</literal> (可选): 一个SQL表达式,定义了这个<emphasis>计算 "
-"(computed)</emphasis> 属性的值。计算属性没有和它对应的数据库字段。"
+"<literal>formula</literal>(可选):一个 SQL 表达式,定义了这个<emphasis>计"
+"算 (computed)</emphasis> 属性的值。计算属性没有和它对应的数据库字段。"
 
 #. Tag: para
-#: basic_mapping.xml:1378
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>false</literal>): "
 "specifies that this property should be fetched lazily when the instance "
 "variable is first accessed. It requires build-time bytecode instrumentation."
 msgstr ""
-"<literal>lazy</literal> (可选 - 默认为 <literal>false</literal>): 指定 指定实"
-"例变量第一次被访问时,这个属性是否延迟抓取(fetched lazily)( 需要运行时字节"
-"码增强)。"
+"<literal>lazy</literal>(可选 — 默认为 <literal>false</literal>):指定 指定"
+"实例变量第一次被访问时,这个属性是否延迟抓取(fetched lazily)( 需要运行时字"
+"节码增强)。 "
 
 #. Tag: para
-#: basic_mapping.xml:1385
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): enables the DDL generation of a unique "
 "constraint for the columns. Also, allow this to be the target of a "
 "<literal>property-ref</literal>."
 msgstr ""
-"<literal>unique</literal> (可选): 使用DDL为该字段添加唯一的约束。 同样,允许"
-"它作为<literal>property-ref</literal>引用的目标。"
+"<literal>unique</literal>(可选):使用 DDL 为该字段添加唯一的约束。同样,允"
+"许它作为 <literal>property-ref</literal> 引用的目标。 "
 
 #. Tag: para
-#: basic_mapping.xml:1392
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): enables the DDL generation of a "
 "nullability constraint for the columns."
 msgstr ""
-"<literal>not-null</literal> (可选): 使用DDL为该字段添加可否为空"
-"(nullability)的约束。"
+"<literal>not-null</literal>(可选):使用 DDL 为该字段添加可否为空"
+"(nullability)的约束。 "
 
 #. Tag: para
-#: basic_mapping.xml:1398 basic_mapping.xml:1581
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to this property do or do not require "
 "acquisition of the optimistic lock. In other words, it determines if a "
 "version increment should occur when this property is dirty."
 msgstr ""
-"<literal>optimistic-lock</literal> (可选 - 默认为 <literal>true</literal>): "
-"指定这个属性在做更新时是否需要获得乐观锁定(optimistic lock)。 换句话说,它"
-"决定这个属性发生脏数据时版本(version)的值是否增长。"
+"<literal>optimistic-lock</literal>(可选 — 默认为 <literal>true</literal>):"
+"指定这个属性在做更新时是否需要获得乐观锁定(optimistic lock)。换句话说,它决"
+"定这个属性发生脏数据时版本(version)的值是否增长。 "
 
 #. Tag: para
-#: basic_mapping.xml:1406
 #, fuzzy, no-c-format
 msgid ""
 "<literal>generated</literal> (optional - defaults to <literal>never</"
@@ -2629,57 +1972,51 @@
 "database. See the discussion of <link linkend=\"mapping-generated"
 "\">generated properties</link> for more information."
 msgstr ""
-"<literal>generated</literal> (可选 - 默认为 <literal>never</literal>): 表明此"
-"属性值是否实际上是由数据库生成的。请参阅<xref linkend=\"mapping-generated"
-"\">generated properties</xref>的讨论。"
+"<literal>generated</literal>(可选 — 默认为 <literal>never</literal>):表明"
+"此属性值是否实际上是由数据库生成的。请参阅 <xref linkend=\"mapping-generated"
+"\"/> 的讨论。 "
 
 #. Tag: para
-#: basic_mapping.xml:1415
 #, no-c-format
 msgid "<emphasis>typename</emphasis> could be:"
-msgstr "<emphasis>typename</emphasis>可以是如下几种:"
+msgstr "<emphasis>typename</emphasis> 可以是如下几种:"
 
 #. Tag: para
-#: basic_mapping.xml:1421
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The name of a Hibernate basic type: <literal>integer, string, character, "
 "date, timestamp, float, binary, serializable, object, blob</literal> etc."
 msgstr ""
-"Hibernate基本类型名(比如:<literal>integer, string, character,date, "
-"timestamp, float, binary, serializable, object, blob</literal>)。"
+"Hibernate 基本类型名(比如:<literal>integer, string, character,date, "
+"timestamp, float, binary, serializable, object, blob</literal>)。 "
 
 #. Tag: para
-#: basic_mapping.xml:1427
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The name of a Java class with a default basic type: <literal>int, float, "
 "char, java.lang.String, java.util.Date, java.lang.Integer, java.sql.Clob</"
 "literal> etc."
 msgstr ""
-"一个Java类的名字,这个类属于一种默认基础类型 (比如: <literal>int, float,"
+"一个 Java 类的名字,这个类属于一种默认基础类型(比如:<literal>int, float,"
 "char, java.lang.String, java.util.Date, java.lang.Integer, java.sql.Clob</"
-"literal>)。"
+"literal>)。 "
 
 #. Tag: para
-#: basic_mapping.xml:1433
 #, no-c-format
 msgid "The name of a serializable Java class."
-msgstr "一个可以序列化的Java类的名字。"
+msgstr "一个可以序列化的 Java 类的名字。"
 
 #. Tag: para
-#: basic_mapping.xml:1438
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The class name of a custom type: <literal>com.illflow.type.MyCustomType</"
 "literal> etc."
 msgstr ""
-"一个自定义类型的类的名字。(比如: <literal>com.illflow.type.MyCustomType</"
-"literal>)。"
+"一个自定义类型的类的名字。(比如:<literal>com.illflow.type.MyCustomType</"
+"literal>)。 "
 
 #. Tag: para
-#: basic_mapping.xml:1444
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you do not specify a type, Hibernate will use reflection upon the named "
 "property and guess the correct Hibernate type. Hibernate will attempt to "
@@ -2689,15 +2026,14 @@
 "DATE</literal> and <literal>Hibernate.TIMESTAMP</literal>, or to specify a "
 "custom type."
 msgstr ""
-"如果你没有指定类型,Hibernarte会使用反射来得到这个名字的属性,以此来猜测正确"
-"的Hibernate类型。 Hibernate会按照规则2,3,4的顺序对属性读取器(getter方法)的返"
-"回类进行解释。然而,这还不够。 在某些情况下你仍然需要<literal>type</literal>"
-"属性。(比如,为了区别<literal>Hibernate.DATE</literal> 和<literal>Hibernate."
-"TIMESTAMP</literal>,或者为了指定一个自定义类型。)"
+"如果你没有指定类型,Hibernarte 会使用反射来得到这个名字的属性,以此来猜测正确"
+"的 Hibernate 类型。Hibernate 会按照规则 2,3,4 的顺序对属性读取器(getter方"
+"法)的返回类进行解释。然而,这还不够。 在某些情况下你仍然需要 <literal>type</"
+"literal> 属性。(比如,为了区别<literal>Hibernate.DATE</literal> 和"
+"<literal>Hibernate.TIMESTAMP</literal>,或者为了指定一个自定义类型。) "
 
 #. Tag: para
-#: basic_mapping.xml:1454
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>access</literal> attribute allows you to control how Hibernate "
 "accesses the property at runtime. By default, Hibernate will call the "
@@ -2707,16 +2043,15 @@
 "a class that implements the interface <literal>org.hibernate.property."
 "PropertyAccessor</literal>."
 msgstr ""
-"<literal>access</literal>属性用来让你控制Hibernate如何在运行时访问属性。在默"
-"认情况下, Hibernate会使用属性的get/set方法对(pair)。如果你指明"
-"<literal>access=\"field\"</literal>, Hibernate会忽略get/set方法对,直接使用反"
-"射来访问成员变量。你也可以指定你自己的策略, 这就需要你自己实现<literal>org."
-"hibernate.property.PropertyAccessor</literal>接口, 再在access中设置你自定义"
-"策略类的名字。"
+"<literal>access</literal> 属性用来让你控制 Hibernate 如何在运行时访问属性。在"
+"默认情况下,Hibernate 会使用属性的 get/set 方法对(pair)。如果你指明 "
+"<literal>access=\"field\"</literal>,Hibernate 会忽略 get/set 方法对,直接使"
+"用反射来访问成员变量。你也可以指定你自己的策略,这就需要你自己实现 "
+"<literal>org.hibernate.property.PropertyAccessor</literal> 接口,再在 access "
+"中设置你自定义策略类的名字。 "
 
 #. Tag: para
-#: basic_mapping.xml:1463
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A powerful feature is derived properties. These properties are by definition "
 "read-only. The property value is computed at load time. You declare the "
@@ -2724,152 +2059,83 @@
 "literal> clause subquery in the SQL query that loads an instance:"
 msgstr ""
 "衍生属性(derive propertie)是一个特别强大的特征。这些属性应该定义为只读,属"
-"性值在装载时计算生成。 你用一个SQL表达式生成计算的结果,它会在这个实例转载时"
-"翻译成一个SQL查询的<literal>SELECT</literal> 子查询语句。"
+"性值在装载时计算生成。 你用一个 SQL 表达式生成计算的结果,它会在这个实例转载"
+"时翻译成一个 SQL 查询的 <literal>SELECT</literal> 子查询语句。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1470
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"<property name=\"totalPrice\"\n"
-"    formula=\"( SELECT SUM (li.quantity*p.price) FROM LineItem li, Product "
-"p\n"
-"                WHERE li.productId = p.productId\n"
-"                AND li.customerId = customerId\n"
-"                AND li.orderNumber = orderNumber )\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1472
-#, fuzzy, no-c-format
-msgid ""
 "You can reference the entity table by not declaring an alias on a particular "
 "column. This would be <literal>customerId</literal> in the given example. "
 "You can also use the nested <literal>&lt;formula&gt;</literal> mapping "
 "element if you do not want to use the attribute."
 msgstr ""
-"注意,你可以使用实体自己的表,而不用为这个特别的列定义别名( 上面例子中的"
+"注意,你可以使用实体自己的表,而不用为这个特别的列定义别名(上面例子中的 "
 "<literal>customerId</literal>)。同时注意,如果你不喜欢使用属性, 你可以使用"
-"嵌套的<literal>&lt;formula&gt;</literal>映射元素。"
+"嵌套的 <literal>&lt;formula&gt;</literal> 映射元素。 "
 
 #. Tag: title
-#: basic_mapping.xml:1482
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Many-to-one"
-msgstr "多对一(many-to-one)"
+msgstr "多对一(many-to-one) "
 
 #. Tag: para
-#: basic_mapping.xml:1484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An ordinary association to another persistent class is declared using a "
 "<literal>many-to-one</literal> element. The relational model is a many-to-"
 "one association; a foreign key in one table is referencing the primary key "
 "column(s) of the target table."
 msgstr ""
-"通过<literal>many-to-one</literal>元素,可以定义一种常见的与另一个持久化类的关"
-"联。 这种关系模型是多对一关联(实际上是一个对象引用-译注):这个表的一个外键"
-"引用目标表的 主键字段。"
+"通过 <literal>many-to-one</literal> 元素,可以定义一种常见的与另一个持久化类的"
+"关联。这种关系模型是多对一关联(实际上是一个对象引用-译注):这个表的一个外"
+"键引用目标表的主键字段。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1512
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<many-to-one\n"
-"        name=\"propertyName\"\n"
-"        column=\"column_name\"\n"
-"        class=\"ClassName\"\n"
-"        cascade=\"cascade_style\"\n"
-"        fetch=\"join|select\"\n"
-"        update=\"true|false\"\n"
-"        insert=\"true|false\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        unique=\"true|false\"\n"
-"        not-null=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        lazy=\"proxy|no-proxy|false\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        formula=\"arbitrary SQL expression\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        embed-xml=\"true|false\"\n"
-"        index=\"index_name\"\n"
-"        unique_key=\"unique_key_id\"\n"
-"        foreign-key=\"foreign_key_name\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1515 basic_mapping.xml:1696 basic_mapping.xml:1882
-#, fuzzy, no-c-format
 msgid "<literal>name</literal>: the name of the property."
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>name</literal>: 属性名。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>name</literal>: 属性的名字。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>name</literal>: 属性名"
+msgstr "<literal>name</literal>:属性名。"
 
 #. Tag: para
-#: basic_mapping.xml:1520 basic_mapping.xml:2311
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>column</literal> (optional): the name of the foreign key column. "
 "This can also be specified by nested <literal>&lt;column&gt;</literal> "
 "element(s)."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>column</literal> (可选): 外间字段名。它也可以通过嵌套的 "
-"<literal>&lt;column&gt;</literal>元素指定。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>column</literal> (可选): 外键字段的名称。也可以通过嵌套的 "
-"<literal>&lt;column&gt;</literal>指定。"
+"<literal>column</literal>(可选):外键字段的名称。也可以通过嵌套的  "
+"<literal>&lt;column&gt;</literal> 指定。 "
 
 #. Tag: para
-#: basic_mapping.xml:1527 basic_mapping.xml:1701
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
 "determined by reflection): the name of the associated class."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>class</literal> (可选 - 默认是通过反射得到属性类型): 关联的类的名"
-"字。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>class</literal> (可选 - 默认是通过反射得到的属性类型):被关联的类的"
-"名字。"
+"<literal>class</literal>(可选 — 默认是通过反射得到的属性类型):被关联的类的"
+"名字。  "
 
 #. Tag: para
-#: basic_mapping.xml:1533 basic_mapping.xml:1707
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional): specifies which operations should be "
 "cascaded from the parent object to the associated object."
 msgstr ""
-"<literal>cascade(级联)</literal> (可选) 表明操作是否从父对象级联到被关联的对"
-"象。"
+"<literal>cascade(级联)</literal>(可选)表明操作是否从父对象级联到被关联的"
+"对象。 "
 
 #. Tag: para
-#: basic_mapping.xml:1539 basic_mapping.xml:1722
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional - defaults to <literal>select</literal>): "
 "chooses between outer-join fetching or sequential select fetching."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>fetch</literal> (可选 - 默认为 <literal>select</literal>): 在外连接"
+"<literal>fetch</literal>(可选 — 默认为 <literal>select</literal>):在外连接"
 "抓取(outer-join fetching)和序列选择抓取(sequential select fetching)两者中"
-"选择其一。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>fetch</literal> (可选 - 默认设置为<literal>选择</literal>): 在外连接"
-"抓取或者序列选择抓取选择其一."
+"选择其一。 "
 
 #. Tag: para
-#: basic_mapping.xml:1545
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update, insert</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that the mapped columns should be included in SQL "
@@ -2878,48 +2144,44 @@
 "association whose value is initialized from another property that maps to "
 "the same column(s), or by a trigger or other application."
 msgstr ""
-"<literal>update, insert</literal> (可选 - 默认为 <literal>true</literal>) 指"
-"定对应的字段是否包含在用于<literal>UPDATE</literal> 和/或 <literal>INSERT</"
-"literal> 的SQL语句中。如果二者都是<literal>false</literal>,则这是一个纯粹的 "
-"“外源性(derived)”关联,它的值是通过映射到同一个(或多个)字段的某些其他属性"
-"得到 或者通过trigger(触发器)、或其他程序生成。"
+"<literal>update, insert</literal>(可选 — 默认为 <literal>true</literal>)指"
+"定对应的字段是否包含在用于 <literal>UPDATE</literal> 和/或 <literal>INSERT</"
+"literal> 的 SQL 语句中。如果二者都是<literal>false</literal>,则这是一个纯粹"
+"的 “外源性(derived)”关联,它的值是通过映射到同一个(或多个)字段的某些其他"
+"属性得到 或者通过 trigger(触发器)、或其他程序生成。 "
 
 #. Tag: para
-#: basic_mapping.xml:1554
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): the name of a property of the "
 "associated class that is joined to this foreign key. If not specified, the "
 "primary key of the associated class is used."
 msgstr ""
-"<literal>property-ref</literal>: (可选) 指定关联类的一个属性,这个属性将会和"
-"本外键相对应。 如果没有指定,会使用对方关联类的主键。"
+"<literal>property-ref</literal>:(可选)被关联到此外键的类中的对应属性的名"
+"字。如果没有指定,被关联类的主键将被使用。 "
 
 #. Tag: para
-#: basic_mapping.xml:1567
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): enables the DDL generation of a unique "
 "constraint for the foreign-key column. By allowing this to be the target of "
 "a <literal>property-ref</literal>, you can make the association multiplicity "
 "one-to-one."
 msgstr ""
-"<literal>unique</literal> (可选): 使用DDL为外键字段生成一个唯一约束。此外, "
-"这也可以用作<literal>property-ref</literal>的目标属性。这使关联同时具有 一对"
-"一的效果。"
+"<literal>unique</literal>(可选):使用 DDL 为外键字段生成一个唯一约束。此"
+"外, 这也可以用作 <literal>property-ref</literal> 的目标属性。这使关联同时具"
+"有一对一的效果。 "
 
 #. Tag: para
-#: basic_mapping.xml:1575
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): enables the DDL generation of a "
 "nullability constraint for the foreign key columns."
 msgstr ""
-"<literal>not-null</literal> (可选): 使用DDL为外键字段生成一个非空约束。"
+"<literal>not-null</literal>(可选):使用 DDL 为外键字段生成一个非空约束。 "
 
 #. Tag: para
-#: basic_mapping.xml:1589
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>proxy</literal>): "
 "by default, single point associations are proxied. <literal>lazy=\"no-proxy"
@@ -2928,45 +2190,41 @@
 "instrumentation. <literal>lazy=\"false\"</literal> specifies that the "
 "association will always be eagerly fetched."
 msgstr ""
-"<literal>lazy</literal> (可选 - 默认为 <literal>proxy</literal>): 默认情况"
-"下,单点关联是经过代理的。<literal>lazy=\"no-proxy\"</literal>指定此属性应该"
+"<literal>lazy</literal>(可选 — 默认为 <literal>proxy</literal>):默认情况"
+"下,单点关联是经过代理的。<literal>lazy=\"no-proxy\"</literal> 指定此属性应该"
 "在实例变量第一次被访问时应该延迟抓取(fetche lazily)(需要运行时字节码的增"
-"强)。 <literal>lazy=\"false\"</literal>指定此关联总是被预先抓取。"
+"强)。<literal>lazy=\"false\"</literal> 指定此关联总是被预先抓取。 "
 
 #. Tag: para
-#: basic_mapping.xml:1599
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-found</literal> (optional - defaults to <literal>exception</"
 "literal>): specifies how foreign keys that reference missing rows will be "
 "handled. <literal>ignore</literal> will treat a missing row as a null "
 "association."
 msgstr ""
-"<literal>not-found</literal> (可选 - 默认为 <literal>exception</literal>): 指"
-"定外键引用的数据不存在时如何处理: <literal>ignore</literal>会将行数据不存在"
-"视为一个空(null)关联。"
+"<literal>not-found</literal>(可选 - 默认为<literal>exception</literal>):指"
+"定如何处理引用缺失行的外键:<literal>ignore</literal> 会把缺失的行作为一个空"
+"关联处理。 "
 
 #. Tag: para
-#: basic_mapping.xml:1606 basic_mapping.xml:1760
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>entity-name</literal> (optional): the entity name of the associated "
 "class."
-msgstr "<literal>entity-name</literal> (可选): 被关联的类的实体名。"
+msgstr "<literal>entity-name</literal>(可选):被关联的类的实体名。 "
 
 #. Tag: para
-#: basic_mapping.xml:1611
 #, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): an SQL expression that defines the "
 "value for a <emphasis>computed</emphasis> foreign key."
 msgstr ""
-"<literal>formula</literal> (可选): SQL表达式,用于定义<emphasis>computed(计"
-"算出的)</emphasis>外键值。"
+"<literal>formula</literal>(可选):SQL 表达式,用于定义 <emphasis>computed"
+"(计算出的)</emphasis>外键值。"
 
 #. Tag: para
-#: basic_mapping.xml:1619
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Setting a value of the <literal>cascade</literal> attribute to any "
 "meaningful value other than <literal>none</literal> will propagate certain "
@@ -2976,39 +2234,29 @@
 "second, special values: <literal>delete-orphan</literal>; and third,"
 "<literal>all</literal> comma-separated combinations of operation names: "
 "<literal>cascade=\"persist,merge,evict\"</literal> or <literal>cascade=\"all,"
-"delete-orphan\"</literal>. See <xref linkend=\"objectstate-transitive\"/> "
+"delete-orphan\"</literal>. See <xref linkend=\"objectstate-transitive\" /> "
 "for a full explanation. Note that single valued, many-to-one and one-to-one, "
 "associations do not support orphan delete."
 msgstr ""
-"<literal>cascade</literal>属性设置为除了<literal>none</literal>以外任何有意义"
-"的值, 它将把特定的操作传递到关联对象中。这个值就代表着Hibernate基本操作的名"
-"称, <literal>persist, merge, delete, save-update, evict, replicate, lock, "
-"refresh</literal>, 以及特别的值<literal>delete-orphan</literal>和"
-"<literal>all</literal>,并且可以用逗号分隔符 来组合这些操作,例如,"
-"<literal>cascade=\"persist,merge,evict\"</literal>或 <literal>cascade=\"all,"
-"delete-orphan\"</literal>。更全面的解释请参考<xref linkend=\"objectstate-"
-"transitive\"/>. 注意,单值关联 (many-to-one 和 one-to-one 关联) 不支持删除孤"
-"儿(orphan delete,删除不再被引用的值)."
+"<literal>cascade</literal> 属性设置为除了<literal>none</literal> 以外任何有意"
+"义的值,它将把特定的操作传递到关联对象中。这个值就代表着 Hibernate 基本操作的"
+"名称,<literal>persist, merge, delete, save-update, evict, replicate, lock, "
+"refresh</literal>,以及特别的值 <literal>delete-orphan</literal> 和 "
+"<literal>all</literal>,并且可以用逗号分隔符来组合这些操作,例如,"
+"<literal>cascade=\"persist,merge,evict\"</literal> 或  <literal>cascade="
+"\"all,delete-orphan\"</literal>。更全面的解释请参考 <xref linkend="
+"\"objectstate-transitive\"/>。注意,单值关联(many-to-one 和 one-to-one 关"
+"联)不支持删除孤儿(orphan delete,删除不再被引用的值)。 "
 
 #. Tag: para
-#: basic_mapping.xml:1632
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Here is an example of a typical <literal>many-to-one</literal> declaration:"
-msgstr "一个典型的简单<literal>many-to-one</literal>定义例子:"
+msgstr "一个典型的简单 <literal>many-to-one</literal> 定义例子: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1636
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"product\" class=\"Product\" column=\"PRODUCT_ID"
-"\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1638
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>property-ref</literal> attribute should only be used for "
 "mapping legacy data where a foreign key refers to a unique key of the "
 "associated table other than the primary key. This is a complicated and "
@@ -3017,107 +2265,56 @@
 "<literal>unique</literal> attribute controls Hibernate's DDL generation with "
 "the SchemaExport tool."
 msgstr ""
-"<literal>property-ref</literal>属性只应该用来对付遗留下来的数据库系统, 可能"
-"有外键指向对方关联表的是个非主键字段(但是应该是一个惟一关键字)的情况下。 这"
-"是一种十分丑陋的关系模型。比如说,假设<literal>Product</literal>类有一个惟一"
-"的序列号, 它并不是主键。(<literal>unique</literal>属性控制Hibernate通过"
-"SchemaExport工具进行的DDL生成。)"
+"<literal>property-ref</literal> 属性只应该用来对付遗留下来的数据库系统,可能"
+"有外键指向对方关联表的是个非主键字段(但是应该是一个惟一关键字)的情况下。这"
+"是一种十分丑陋的关系模型。比如说,假设 <literal>Product</literal> 类有一个惟"
+"一的序列号,它并不是主键。(<literal>unique</literal> 属性控制 Hibernate 通"
+"过 SchemaExport 工具进行的 DDL 生成。) "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1647
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"serialNumber\" unique=\"true\" type=\"string\" "
-"column=\"SERIAL_NUMBER\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:1649
 #, no-c-format
 msgid "Then the mapping for <literal>OrderItem</literal> might use:"
-msgstr "那么关于<literal>OrderItem</literal> 的映射可能是:"
+msgstr "那么关于 <literal>OrderItem</literal> 的映射可能是:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1653
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"product\" property-ref=\"serialNumber\" column="
-"\"PRODUCT_SERIAL_NUMBER\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1655
-#, fuzzy, no-c-format
 msgid "This is not encouraged, however."
-msgstr "当然,我们决不鼓励这种用法。"
+msgstr "当然,我们决不鼓励这种用法。 "
 
 #. Tag: para
-#: basic_mapping.xml:1659
 #, no-c-format
 msgid ""
 "If the referenced unique key comprises multiple properties of the associated "
 "entity, you should map the referenced properties inside a named <literal>&lt;"
 "properties&gt;</literal> element."
 msgstr ""
-"如果被引用的唯一主键由关联实体的多个属性组成,你应该在名称为<literal>&lt;"
-"properties&gt;</literal>的元素 里面映射所有关联的属性。"
+"如果被引用的唯一主键由关联实体的多个属性组成,你应该在名称为 <literal>&lt;"
+"properties&gt;</literal> 的元素 里面映射所有关联的属性。"
 
 #. Tag: para
-#: basic_mapping.xml:1664
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the referenced unique key is the property of a component, you can specify "
 "a property path:"
-msgstr "假若被引用的唯一主键是组件的属性,你可以指定属性路径:"
+msgstr "假若被引用的唯一主键是组件的属性,你可以指定属性路径: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1668
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"owner\" property-ref=\"identity.ssn\" column="
-"\"OWNER_SSN\"/>]]>"
-msgstr ""
-
-#. Tag: title
-#: basic_mapping.xml:1673
-#, fuzzy, no-c-format
 msgid "One-to-one"
-msgstr "一对一"
+msgstr "一对一 "
 
 #. Tag: para
-#: basic_mapping.xml:1675
 #, no-c-format
 msgid ""
 "A one-to-one association to another persistent class is declared using a "
 "<literal>one-to-one</literal> element."
 msgstr ""
-"持久化对象之间一对一的关联关系是通过<literal>one-to-one</literal>元素定义的。"
+"持久化对象之间一对一的关联关系是通过 <literal>one-to-one</literal> 元素定义"
+"的。"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1693
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<one-to-one\n"
-"        name=\"propertyName\"\n"
-"        class=\"ClassName\"\n"
-"        cascade=\"cascade_style\"\n"
-"        constrained=\"true|false\"\n"
-"        fetch=\"join|select\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        formula=\"any SQL expression\"\n"
-"        lazy=\"proxy|no-proxy|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
-"        embed-xml=\"true|false\"\n"
-"        foreign-key=\"foreign_key_name\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1713
-#, fuzzy, no-c-format
-msgid ""
 "<literal>constrained</literal> (optional): specifies that a foreign key "
 "constraint on the primary key of the mapped table and references the table "
 "of the associated class. This option affects the order in which <literal>save"
@@ -3125,25 +2322,23 @@
 "whether the association can be proxied. It is also used by the schema export "
 "tool."
 msgstr ""
-"<literal>constrained(约束)</literal> (可选) 表明该类对应的表对应的数据库表,"
-"和被关联的对象所对应的数据库表之间,通过一个外键引用对主键进行约束。 这个选项"
-"影响<literal>save()</literal>和<literal>delete()</literal>在级联执行时的先后"
-"顺序以及 决定该关联能否被委托(也在schema export tool中被使用)."
+"<literal>constrained(约束)</literal>(可选)表明该类对应的表对应的数据库"
+"表,和被关联的对象所对应的数据库表之间,通过一个外键引用对主键进行约束。这个"
+"选项影响 <literal>save()</literal> 和 <literal>delete()</literal> 在级联执行"
+"时的先后顺序以及决定该关联能否被委托(也在 schema export tool 中被使用)。 "
 
 #. Tag: para
-#: basic_mapping.xml:1728
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): the name of a property of the "
 "associated class that is joined to the primary key of this class. If not "
 "specified, the primary key of the associated class is used."
 msgstr ""
-"<literal>property-ref</literal>: (可选) 指定关联类的属性名,这个属性将会和本"
-"类的主键相对应。如果没有指定,会使用对方关联类的主键。"
+"<literal>property-ref</literal>:(可选)指定关联类的属性名,这个属性将会和本"
+"类的主键相对应。如果没有指定,会使用对方关联类的主键。 "
 
 #. Tag: para
-#: basic_mapping.xml:1741
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>formula</literal> (optional): almost all one-to-one associations "
 "map to the primary key of the owning entity. If this is not the case, you "
@@ -3151,14 +2346,13 @@
 "formula. See <literal>org.hibernate.test.onetooneformula</literal> for an "
 "example."
 msgstr ""
-"<literal>formula </literal> (可选):绝大多数一对一的关联都指向其实体的主键。在"
-"一些少见的情况中, 你可能会指向其他的一个或多个字段,或者是一个表达式,这些情"
-"况下,你可以用一个SQL公式来表示。 (可以在org.hibernate.test.onetooneformula"
-"找到例子)"
+"<literal>formula </literal>(可选):绝大多数一对一的关联都指向其实体的主键。"
+"在一些少见的情况中,你可能会指向其他的一个或多个字段,或者是一个表达式,这些"
+"情况下,你可以用一个 SQL 公式来表示。(可以在 org.hibernate.test."
+"onetooneformula 找到例子) "
 
 #. Tag: para
-#: basic_mapping.xml:1749
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>proxy</literal>): "
 "by default, single point associations are proxied. <literal>lazy=\"no-proxy"
@@ -3169,34 +2363,30 @@
 "<literal>constrained=\"false\"</literal>, proxying is impossible and "
 "Hibernate will eagerly fetch the association</emphasis>."
 msgstr ""
-"<literal>lazy</literal> (可选 - 默认为 <literal>proxy</literal>): 默认情况"
+"<literal>lazy</literal>(可选 — 默认为 <literal>proxy</literal>):默认情况"
 "下,单点关联是经过代理的。<literal>lazy=\"no-proxy\"</literal>指定此属性应该"
 "在实例变量第一次被访问时应该延迟抓取(fetche lazily)(需要运行时字节码的增"
 "强)。 <literal>lazy=\"false\"</literal>指定此关联总是被预先抓取。<emphasis>"
 "注意,如果<literal>constrained=\"false\"</literal>, 不可能使用代理,Hibernate"
-"会采取预先抓取!</emphasis>"
+"会采取预先抓取</emphasis>。"
 
 #. Tag: para
-#: basic_mapping.xml:1767
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "There are two varieties of one-to-one associations:"
-msgstr "有两种不同的一对一关联:"
+msgstr "有两种不同的一对一关联: "
 
 #. Tag: para
-#: basic_mapping.xml:1771
 #, no-c-format
 msgid "primary key associations"
 msgstr "主键关联"
 
 #. Tag: para
-#: basic_mapping.xml:1774
 #, no-c-format
 msgid "unique foreign key associations"
 msgstr "惟一外键关联"
 
 #. Tag: para
-#: basic_mapping.xml:1779
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Primary key associations do not need an extra table column. If two rows are "
 "related by the association, then the two table rows share the same primary "
@@ -3205,129 +2395,64 @@
 msgstr ""
 "主键关联不需要额外的表字段;如果两行是通过这种一对一关系相关联的,那么这两行"
 "就共享同样的主关键字值。所以如果你希望两个对象通过主键一对一关联,你必须确认"
-"它们被赋予同样的标识值!"
+"它们被赋予同样的标识值。"
 
 #. Tag: para
-#: basic_mapping.xml:1786
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For a primary key association, add the following mappings to "
 "<literal>Employee</literal> and <literal>Person</literal> respectively:"
 msgstr ""
-"比如说,对下面的<literal>Employee</literal>和<literal>Person</literal>进行主"
-"键一对一关联:"
+"比如说,对下面的 <literal>Employee</literal> 和 <literal>Person</literal> 进"
+"行主键一对一关联:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1791
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[<one-to-one name=\"person\" class=\"Person\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:1792
-#, no-c-format
 msgid ""
-"<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" constrained=\"true"
-"\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1794
-#, fuzzy, no-c-format
-msgid ""
 "Ensure that the primary keys of the related rows in the PERSON and EMPLOYEE "
 "tables are equal. You use a special Hibernate identifier generation strategy "
 "called <literal>foreign</literal>:"
 msgstr ""
-"现在我们必须确保PERSON和EMPLOYEE中相关的字段是相等的。我们使用一个被成为"
-"<literal>foreign</literal>的特殊的hibernate标识符生成策略:"
+"现在我们必须确保 PERSON 和 EMPLOYEE 中相关的字段是相等的。我们使用一个被成为 "
+"<literal>foreign</literal> 的特殊的 hibernate 标识符生成策略: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1800
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"person\" table=\"PERSON\">\n"
-"    <id name=\"id\" column=\"PERSON_ID\">\n"
-"        <generator class=\"foreign\">\n"
-"            <param name=\"property\">employee</param>\n"
-"        </generator>\n"
-"    </id>\n"
-"    ...\n"
-"    <one-to-one name=\"employee\"\n"
-"        class=\"Employee\"\n"
-"        constrained=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1802
-#, fuzzy, no-c-format
-msgid ""
 "A newly saved instance of <literal>Person</literal> is assigned the same "
 "primary key value as the <literal>Employee</literal> instance referred with "
 "the <literal>employee</literal> property of that <literal>Person</literal>."
 msgstr ""
-"一个刚刚保存的<literal>Person</literal>实例被赋予和该<literal>Person</"
-"literal>的<literal>employee</literal>属性所指向的<literal>Employee</literal>"
-"实例同样的关键字值。"
+"一个刚刚保存的 <literal>Person</literal> 实例被赋予和该 <literal>Person</"
+"literal> 的 <literal>employee</literal> 属性所指向的 <literal>Employee</"
+"literal> 实例同样的关键字值。 "
 
 #. Tag: para
-#: basic_mapping.xml:1808
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, a foreign key with a unique constraint, from "
 "<literal>Employee</literal> to <literal>Person</literal>, can be expressed "
 "as:"
 msgstr ""
-"另一种方式是一个外键和一个惟一关键字对应,上面的<literal>Employee</literal>和"
-"<literal>Person</literal>的例子,如果使用这种关联方式,可以表达成:"
+"另一种方式是一个外键和一个惟一关键字对应,上面的 <literal>Employee</literal> "
+"和  <literal>Person</literal> 的例子,如果使用这种关联方式,可以表达成: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1813
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"person\" class=\"Person\" column=\"PERSON_ID\" "
-"unique=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1815
-#, fuzzy, no-c-format
-msgid ""
 "This association can be made bidirectional by adding the following to the "
 "<literal>Person</literal> mapping:"
 msgstr ""
-"如果在<literal>Person</literal>的映射加入下面几句,这种关联就是双向的:"
+"如果在 <literal>Person</literal> 的映射加入下面几句,这种关联就是双向的: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1820
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" property-ref="
-"\"person\"/>]]>"
-msgstr ""
-
-#. Tag: title
-#: basic_mapping.xml:1825
-#, fuzzy, no-c-format
 msgid "Natural-id"
-msgstr "自然ID(natural-id)"
+msgstr "自然 ID(natural-id) "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1827
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<natural-id mutable=\"true|false\"/>\n"
-"        <property ... />\n"
-"        <many-to-one ... />\n"
-"        ......\n"
-"</natural-id>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1829
-#, fuzzy, no-c-format
-msgid ""
 "Although we recommend the use of surrogate keys as primary keys, you should "
 "try to identify natural keys for all entities. A natural key is a property "
 "or combination of properties that is unique and non-null. It is also "
@@ -3338,198 +2463,152 @@
 msgstr ""
 "我们建议使用代用键(键值不具备实际意义)作为主键,我们仍然应该尝试为所有的实"
 "体采用自然的键值作为(附加——译者注)标示。自然键(natural key)是单个或组合属"
-"性,他们必须唯一且非空。如果它还是不可变的那就更理想了。在<literal>&lt;"
-"natural-id&gt;</literal>元素中列出自然键的属性。Hibernate会帮你生成必须的唯一"
-"键值和非空约束,你的映射会更加的明显易懂(原文是self-documenting,自我注"
-"解)。"
+"性,他们必须唯一且非空。如果它还是不可变的那就更理想了。在 <literal>&lt;"
+"natural-id&gt;</literal> 元素中列出自然键的属性。Hibernate 会帮你生成必须的唯"
+"一键值和非空约束,你的映射会更加的明显易懂(原文是 self-documenting,自我注"
+"解)。 "
 
 #. Tag: para
-#: basic_mapping.xml:1838
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you implement <literal>equals()</literal> and "
 "<literal>hashCode()</literal> to compare the natural key properties of the "
 "entity."
 msgstr ""
-"我们强烈建议你实现<literal>equals()</literal> 和<literal>hashCode()</literal>"
-"方法,来比较实体的自然键属性。"
+"我们强烈建议你实现 <literal>equals()</literal> 和 <literal>hashCode()</"
+"literal> 方法,来比较实体的自然键属性。 "
 
 #. Tag: para
-#: basic_mapping.xml:1843
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This mapping is not intended for use with entities that have natural primary "
 "keys."
-msgstr "这一映射不是为了把自然键作为主键而准备的。"
+msgstr "这一映射不是为了把自然键作为主键而准备的。 "
 
 #. Tag: para
-#: basic_mapping.xml:1849
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>false</"
 "literal>): by default, natural identifier properties are assumed to be "
 "immutable (constant)."
 msgstr ""
-"<literal>mutable</literal> (可选, 默认为<literal>false</literal>): 默认情况"
-"下,自然标识属性被假定为不可变的(常量)。"
+"<literal>mutable</literal>(可选,默认为 <literal>false</literal>):默认情况"
+"下,自然标识属性被假定为不可变的(常量)。 "
 
 #. Tag: title
-#: basic_mapping.xml:1859
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Component and dynamic-component"
-msgstr "组件(component), 动态组件(dynamic-component)"
+msgstr "组件(component)和动态组件(dynamic-component) "
 
 #. Tag: para
-#: basic_mapping.xml:1861
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element maps properties of a child "
 "object to columns of the table of a parent class. Components can, in turn, "
 "declare their own properties, components or collections. See the \"Component"
 "\" examples below:"
 msgstr ""
-"<literal>&lt;component&gt;</literal>元素把子对象的一些元素与父类对应的表的一"
-"些字段映射起来。 然后组件可以定义它们自己的属性、组件或者集合。参见后面"
-"的“Components”一章。"
+"<literal>&lt;component&gt;</literal> 元素把子对象的一些元素与父类对应的表的一"
+"些字段映射起来。然后组件可以定义它们自己的属性、组件或者集合。参见后面"
+"的“Components”一章。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:1879
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<component\n"
-"        name=\"propertyName\"\n"
-"        class=\"className\"\n"
-"        insert=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        lazy=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        node=\"element-name|.\"\n"
-">\n"
-"\n"
-"        <property ...../>\n"
-"        <many-to-one .... />\n"
-"        ........\n"
-"</component>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1887
-#, fuzzy, no-c-format
-msgid ""
 "<literal>class</literal> (optional - defaults to the property type "
 "determined by reflection): the name of the component (child) class."
 msgstr ""
-"<literal>class</literal> (可选 - 默认为通过反射得到的属性类型):组件(子)类的名"
-"字。"
+"<literal>class</literal>(可选 — 默认为通过反射得到的属性类型):组件(子)类"
+"的名字。 "
 
 #. Tag: para
-#: basic_mapping.xml:1893 basic_mapping.xml:1982
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>insert</literal>: do the mapped columns appear in SQL "
 "<literal>INSERTs</literal>?"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>insert</literal>: 被映射的字段是否出现在SQL的<literal>INSERT</"
-"literal>语句中?\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>insert</literal>: 被映射的字段是否出现在SQL的 <literal>INSERT</"
-"literal>语句中?"
+"<literal>insert</literal>:被映射的字段是否出现在 SQL 的 <literal>INSERT</"
+"literal> 语句中? "
 
 #. Tag: para
-#: basic_mapping.xml:1899 basic_mapping.xml:1988
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update</literal>: do the mapped columns appear in SQL "
 "<literal>UPDATEs</literal>?"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>update</literal>: 被映射的字段是否出现在SQL的<literal>UPDATE</"
-"literal>语句中?\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>update</literal>: 被映射的字段是否出现在SQL的 <literal>UPDATE</"
-"literal>语句中?"
+"<literal>update</literal>:被映射的字段是否出现在 SQL 的 <literal>UPDATE</"
+"literal> 语句中? "
 
 #. Tag: para
-#: basic_mapping.xml:1911
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>false</literal>): "
 "specifies that this component should be fetched lazily when the instance "
 "variable is first accessed. It requires build-time bytecode instrumentation."
 msgstr ""
-"<literal>lazy</literal> (可选 - 默认是 <literal>false</literal>): 表明此组件"
-"应在实例变量第一次被访问的时候延迟加载(需要编译时字节码装置器)"
+"<literal>lazy</literal>(可选 — 默认是 <literal>false</literal>):表明此组件"
+"应在实例变量第一次被访问的时候延迟加载(需要编译时字节码装置器)。"
 
 #. Tag: para
-#: basic_mapping.xml:1918
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to this component either do or do not "
 "require acquisition of the optimistic lock. It determines if a version "
 "increment should occur when this property is dirty."
 msgstr ""
-"<literal>optimistic-lock</literal> (可选 - 默认是 <literal>true</literal>):表"
-"明更新此组件是否需要获取乐观锁。换句话说,当这个属性变脏时,是否增加版本号"
-"(Version)"
+"<literal>optimistic-lock</literal>(可选 — 默认是 <literal>true</literal>):"
+"表明更新此组件是否需要获取乐观锁。换句话说,当这个属性变脏时,是否增加版本号"
+"(Version)。"
 
 #. Tag: para
-#: basic_mapping.xml:1926 basic_mapping.xml:2002
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional - defaults to <literal>false</literal>): "
 "specifies that a unique constraint exists upon all mapped columns of the "
 "component."
 msgstr ""
-"<literal>unique</literal> (可选 - 默认是 <literal>false</literal>):表明组件映"
-"射的所有字段上都有唯一性约束"
+"<literal>unique</literal>(可选 — 默认是 <literal>false</literal>):表明组件"
+"映射的所有字段上都有唯一性约束。"
 
 #. Tag: para
-#: basic_mapping.xml:1935
 #, no-c-format
 msgid ""
 "The child <literal>&lt;property&gt;</literal> tags map properties of the "
 "child class to table columns."
 msgstr ""
-"其<literal>&lt;property&gt;</literal>子标签为子类的一些属性与表字段之间建立映"
-"射。"
+"其 <literal>&lt;property&gt;</literal> 子标签为子类的一些属性与表字段之间建立"
+"映射。"
 
 #. Tag: para
-#: basic_mapping.xml:1940
 #, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element allows a <literal>&lt;"
 "parent&gt;</literal> subelement that maps a property of the component class "
 "as a reference back to the containing entity."
 msgstr ""
-"<literal>&lt;component&gt;</literal>元素允许加入一个<literal>&lt;parent&gt;</"
-"literal>子元素,在组件类内部就可以有一个指向其容器的实体的反向引用。"
+"<literal>&lt;component&gt;</literal> 元素允许加入一个 <literal>&lt;parent&gt;"
+"</literal> 子元素,在组件类内部就可以有一个指向其容器的实体的反向引用。"
 
 #. Tag: para
-#: basic_mapping.xml:1946
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;dynamic-component&gt;</literal> element allows a "
 "<literal>Map</literal> to be mapped as a component, where the property names "
-"refer to keys of the map. See <xref linkend=\"components-dynamic\"/> for "
+"refer to keys of the map. See <xref linkend=\"components-dynamic\" /> for "
 "more information."
 msgstr ""
-"<literal>&lt;dynamic-component&gt;</literal>元素允许把一个<literal>Map</"
-"literal>映射为组件,其属性名对应map的键值。 参见<xref linkend=\"components-"
-"dynamic\"/>."
+"<literal>&lt;dynamic-component&gt;</literal> 元素允许把一个 <literal>Map</"
+"literal> 映射为组件,其属性名对应 map 的键值。参见 <xref linkend="
+"\"components-dynamic\"/>。 "
 
 #. Tag: title
-#: basic_mapping.xml:1955
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Properties"
-msgstr "properties"
+msgstr "属性(Properties)"
 
 #. Tag: para
-#: basic_mapping.xml:1957
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;properties&gt;</literal> element allows the definition of a "
 "named, logical grouping of the properties of a class. The most important use "
@@ -3538,197 +2617,104 @@
 "define a multi-column unique constraint. For example:"
 msgstr ""
 "<literal>&lt;properties&gt;</literal> 元素允许定义一个命名的逻辑分组"
-"(grouping)包含一个类中的多个属性。 这个元素最重要的用处是允许多个属性的组合作"
-"为<literal>property-ref</literal>的目标(target)。 这也是定义多字段唯一约束的"
-"一种方便途径。"
+"(grouping)包含一个类中的多个属性。这个元素最重要的用处是允许多个属性的组合"
+"作为 <literal>property-ref</literal> 的目标(target)。这也是定义多字段唯一约"
+"束的一种方便途径。例如:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:1973
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<properties\n"
-"        name=\"logicalName\"\n"
-"        insert=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        optimistic-lock=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-">\n"
-"\n"
-"        <property ...../>\n"
-"        <many-to-one .... />\n"
-"        ........\n"
-"</properties>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:1976
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal>: the logical name of the grouping. It is "
 "<emphasis>not</emphasis> an actual property name."
 msgstr ""
-"<literal>name</literal>: 分组的逻辑名称 - <emphasis>不是</emphasis> 实际属性"
-"的名称."
+"<literal>name</literal>:分组的逻辑名称 — <emphasis>不是</emphasis> 实际属性"
+"的名称。 "
 
 #. Tag: para
-#: basic_mapping.xml:1994
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to these properties either do or do not "
 "require acquisition of the optimistic lock. It determines if a version "
 "increment should occur when these properties are dirty."
 msgstr ""
-"<literal>optimistic-lock</literal> (可选 - 默认是 <literal>true</literal>):表"
-"明更新此组件是否需要获取乐观锁。换句话说,当这个属性变脏时,是否增加版本号"
-"(Version)"
+"<literal>optimistic-lock</literal>(可选 — 默认是 <literal>true</literal>):"
+"表明更新此组件是否需要获取乐观锁。换句话说,当这个属性变脏时,是否增加版本号"
+"(Version)。"
 
 #. Tag: para
-#: basic_mapping.xml:2011
 #, no-c-format
 msgid ""
 "For example, if we have the following <literal>&lt;properties&gt;</literal> "
 "mapping:"
-msgstr "例如,如果我们有如下的<literal>&lt;properties&gt;</literal>映射:"
+msgstr "例如,如果我们有如下的 <literal>&lt;properties&gt;</literal> 映射:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2015
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"personNumber\"/>\n"
-"\n"
-"    ...\n"
-"    <properties name=\"name\"\n"
-"            unique=\"true\" update=\"false\">\n"
-"        <property name=\"firstName\"/>\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"lastName\"/>\n"
-"    </properties>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2017
-#, fuzzy, no-c-format
-msgid ""
 "You might have some legacy data association that refers to this unique key "
 "of the <literal>Person</literal> table, instead of to the primary key:"
 msgstr ""
-"然后,我们可能有一些遗留的数据关联,引用 <literal>Person</literal>表的这个唯"
-"一键,而不是主键。"
+"然后,我们可能有一些遗留的数据关联,引用 <literal>Person</literal> 表的这个唯"
+"一键,而不是主键:"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2022
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"person\"\n"
-"         class=\"Person\" property-ref=\"name\">\n"
-"    <column name=\"firstName\"/>\n"
-"    <column name=\"initial\"/>\n"
-"    <column name=\"lastName\"/>\n"
-"</many-to-one>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2024
-#, fuzzy, no-c-format
-msgid ""
 "The use of this outside the context of mapping legacy data is not "
 "recommended."
-msgstr "我们并不推荐这样使用,除非在映射遗留数据的情况下。"
+msgstr "我们并不推荐这样使用,除非在映射遗留数据的情况下。 "
 
 #. Tag: title
-#: basic_mapping.xml:2032
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Subclass"
-msgstr "子类(subclass)"
+msgstr "子类(subclass) "
 
 #. Tag: para
-#: basic_mapping.xml:2034
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Polymorphic persistence requires the declaration of each subclass of the "
 "root persistent class. For the table-per-class-hierarchy mapping strategy, "
 "the <literal>&lt;subclass&gt;</literal> declaration is used. For example:"
 msgstr ""
 "最后,多态持久化需要为父类的每个子类都进行定义。对于“每一棵类继承树对应一个"
-"表”的策略来说,就需要使用<literal>&lt;subclass&gt;</literal>定义。"
+"表”的策略来说,就需要使用 <literal>&lt;subclass&gt;</literal> 定义。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2047
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<subclass\n"
-"        name=\"ClassName\"\n"
-"        discriminator-value=\"discriminator_value\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\"\n"
-"        extends=\"SuperclassName\">\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</subclass>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2050 basic_mapping.xml:2108 basic_mapping.xml:2171
-#, fuzzy, no-c-format
-msgid ""
 "<literal>name</literal>: the fully qualified class name of the subclass."
-msgstr "<literal>name</literal>: 子类的全限定名。"
+msgstr "<literal>name</literal>:子类的全限定名。 "
 
 #. Tag: para
-#: basic_mapping.xml:2055
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>discriminator-value</literal> (optional - defaults to the class "
 "name): a value that distinguishes individual subclasses."
 msgstr ""
-"<literal>discriminator-value(辨别标志)</literal> (可选 - 默认为类名):一个用于"
-"区分每个独立的子类的值。"
+"<literal>discriminator-value(辨别标志)</literal>(可选 — 默认为类名):一个"
+"用于区分每个独立的子类的值。 "
 
 #. Tag: para
-#: basic_mapping.xml:2061
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies a class or interface used for "
 "lazy initializing proxies."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy(代理)</literal> (可选): 指定一个类或者接口,在延迟装载时作为代"
-"理使用。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal> (可选): 指定一个类或者接口,在延迟装载时作为代理使"
-"用。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal> (可选): 指定一个类或者接口,在延迟装载时作为代理使"
-"用。"
+"<literal>proxy</literal>(可选):指定一个类或者接口,在延迟装载时作为代理使"
+"用。 "
 
 #. Tag: para
-#: basic_mapping.xml:2067
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>true</literal>): "
 "setting <literal>lazy=\"false\"</literal> disables the use of lazy fetching."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (可选, 默认是<literal>true</literal>): 设置为 "
-"<literal>lazy=\"false\"</literal> 禁止使用延迟抓取\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (可选, 默认是 <literal>true</literal>): 设置为 "
-"<literal>lazy=\"false\"</literal> 禁止使用延迟装载。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (可选, 默认是 <literal>true</literal>): 设置为 "
-"<literal>lazy=\"false\"</literal> 禁止使用延迟装载。"
+"<literal>lazy</literal>(可选,默认是 <literal>true</literal>):设置为 "
+"<literal>lazy=\"false\"</literal> 禁止使用延迟装载。 "
 
 #. Tag: para
-#: basic_mapping.xml:2075
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Each subclass declares its own persistent properties and subclasses. "
 "<literal>&lt;version&gt;</literal> and <literal>&lt;id&gt;</literal> "
@@ -3736,174 +2722,77 @@
 "a hierarchy must define a unique <literal>discriminator-value</literal>. If "
 "this is not specified, the fully qualified Java class name is used."
 msgstr ""
-"每个子类都应该定义它自己的持久化属性和子类。 <literal>&lt;version&gt;</"
-"literal> 和<literal>&lt;id&gt;</literal> 属性可以从根父类继承下来。在一棵继承"
-"树上的每个子类都必须定义一个唯一的<literal>discriminator-value</literal>。如"
-"果没有指定,就会使用Java类的全限定名。"
+"每个子类都应该定义它自己的持久化属性和子类。<literal>&lt;version&gt;</"
+"literal> 和 <literal>&lt;id&gt;</literal> 属性可以从根父类继承下来。在一棵继"
+"承树上的每个子类都必须定义一个唯一的 <literal>discriminator-value</literal>。"
+"如果没有指定,就会使用 Java 类的全限定名。 "
 
 #. Tag: para
-#: basic_mapping.xml:2083 basic_mapping.xml:2141 basic_mapping.xml:2199
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"For information about inheritance mappings see <xref linkend=\"inheritance\"/"
-">."
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"更多关于继承映射的信息, 参考 <xref linkend=\"inheritance\"/>章节.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"更多关于继承映射的信息,参考<xref linkend=\"inheritance\"/>。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"更多关于继承映射的信息,参考<xref linkend=\"inheritance\"/>。"
+"For information about inheritance mappings see <xref linkend=\"inheritance"
+"\" />."
+msgstr "更多关于继承映射的信息,参考 <xref linkend=\"inheritance\"/>。 "
 
 #. Tag: title
-#: basic_mapping.xml:2090
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Joined-subclass"
-msgstr "连接的子类(joined-subclass)"
+msgstr "连接的子类(joined-subclass) "
 
 #. Tag: para
-#: basic_mapping.xml:2092
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Each subclass can also be mapped to its own table. This is called the table-"
 "per-subclass mapping strategy. An inherited state is retrieved by joining "
 "with the table of the superclass. To do this you use the <literal>&lt;joined-"
 "subclass&gt;</literal> element. For example:"
 msgstr ""
-"此外,每个子类可能被映射到他自己的表中(每个子类一个表的策略)。被继承的状态通"
-"过和超类的表关联得到。我们使用<literal>&lt;joined-subclass&gt;</literal>元"
-"素。"
+"此外,每个子类可能被映射到他自己的表中(每个子类一个表的策略)。被继承的状态"
+"通过和超类的表关联得到。我们使用 <literal>&lt;joined-subclass&gt;</literal> "
+"元素。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2105
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<joined-subclass\n"
-"        name=\"ClassName\"\n"
-"        table=\"tablename\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        schema=\"schema\"\n"
-"        catalog=\"catalog\"\n"
-"        extends=\"SuperclassName\"\n"
-"        persister=\"ClassName\"\n"
-"        subselect=\"SQL expression\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\">\n"
-"\n"
-"        <key .... >\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</joined-subclass>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2113 basic_mapping.xml:2176
-#, fuzzy, no-c-format
 msgid "<literal>table</literal>: the name of the subclass table."
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>table</literal>: 子类的表名.\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>table</literal>: 子类的表名"
+msgstr "<literal>table</literal>:子类的表名。"
 
 #. Tag: para
-#: basic_mapping.xml:2118 basic_mapping.xml:2181
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>proxy</literal> (optional): specifies a class or interface to use "
 "for lazy initializing proxies."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy(代理)</literal> (可选): 指定一个类或者接口,在延迟装载时作为代"
-"理使用。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal> (可选): 指定一个类或者接口,在延迟装载时作为代理使"
-"用。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>proxy</literal> (可选): 指定一个类或者接口,在延迟装载时作为代理使"
-"用。"
+"<literal>proxy</literal>(可选):指定一个类或者接口,在延迟装载时作为代理使"
+"用。 "
 
 #. Tag: para
-#: basic_mapping.xml:2124 basic_mapping.xml:2187
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional, defaults to <literal>true</literal>): "
 "setting <literal>lazy=\"false\"</literal> disables the use of lazy fetching."
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (可选, 默认是<literal>true</literal>): 设置为 "
-"<literal>lazy=\"false\"</literal> 禁止使用延迟抓取\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (可选, 默认是 <literal>true</literal>): 设置为 "
-"<literal>lazy=\"false\"</literal> 禁止使用延迟装载。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>lazy</literal> (可选, 默认是 <literal>true</literal>): 设置为 "
-"<literal>lazy=\"false\"</literal> 禁止使用延迟装载。"
+"<literal>lazy</literal>(可选,默认是 <literal>true</literal>):设置为 "
+"<literal>lazy=\"false\"</literal> 禁止使用延迟装载。 "
 
 #. Tag: para
-#: basic_mapping.xml:2132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A discriminator column is not required for this mapping strategy. Each "
 "subclass must, however, declare a table column holding the object identifier "
 "using the <literal>&lt;key&gt;</literal> element. The mapping at the start "
 "of the chapter would then be re-written as:"
 msgstr ""
-"这种映射策略不需要指定辨别标志(discriminator)字段。但是,每一个子类都必须使用"
-"<literal>&lt;key&gt;</literal>元素指定一个表字段来持有对象的标识符。本章开始"
-"的映射可以被用如下方式重写:"
+"这种映射策略不需要指定辨别标志(discriminator)字段。但是,每一个子类都必须使"
+"用 <literal>&lt;key&gt;</literal> 元素指定一个表字段来持有对象的标识符。本章"
+"开始的映射可以被用如下方式重写: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2139
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"        <class name=\"Cat\" table=\"CATS\">\n"
-"                <id name=\"id\" column=\"uid\" type=\"long\">\n"
-"                        <generator class=\"hilo\"/>\n"
-"                </id>\n"
-"                <property name=\"birthdate\" type=\"date\"/>\n"
-"                <property name=\"color\" not-null=\"true\"/>\n"
-"                <property name=\"sex\" not-null=\"true\"/>\n"
-"                <property name=\"weight\"/>\n"
-"                <many-to-one name=\"mate\"/>\n"
-"                <set name=\"kittens\">\n"
-"                        <key column=\"MOTHER\"/>\n"
-"                        <one-to-many class=\"Cat\"/>\n"
-"                </set>\n"
-"                <joined-subclass name=\"DomesticCat\" table=\"DOMESTIC_CATS"
-"\">\n"
-"                    <key column=\"CAT\"/>\n"
-"                    <property name=\"name\" type=\"string\"/>\n"
-"                </joined-subclass>\n"
-"        </class>\n"
-"\n"
-"        <class name=\"eg.Dog\">\n"
-"                <!-- mapping for Dog could go here -->\n"
-"        </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: title
-#: basic_mapping.xml:2148
-#, fuzzy, no-c-format
 msgid "Union-subclass"
-msgstr "联合子类(union-subclass)"
+msgstr "联合子类(union-subclass) "
 
 #. Tag: para
-#: basic_mapping.xml:2150
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A third option is to map only the concrete classes of an inheritance "
 "hierarchy to tables. This is called the table-per-concrete-class strategy. "
@@ -3915,89 +2804,40 @@
 "need to use the <literal>&lt;union-subclass&gt;</literal> mapping. For "
 "example:"
 msgstr ""
-"第三种选择是仅仅映射类继承树中具体类部分到表中(每个具体类一张表的策略)。其"
+"第三种选择是仅仅映射类继承树中具体类部分到表中(每个具体类一张表的策略)。其"
 "中,每张表定义了类的所有持久化状态,包括继承的状态。在 Hibernate 中,并不需要"
-"完全显式地映射这样的继承树。你可以简单地使用单独的<literal>&lt;class&gt;</"
-"literal>定义映射每个类。然而,如果你想使用多态关联(例如,一个对类继承树中超类"
-"的关联),你需要使用<literal>&lt;union-subclass&gt;</literal>映射。"
+"完全显式地映射这样的继承树。你可以简单地使用单独的 <literal>&lt;class&gt;</"
+"literal> 定义映射每个类。然而,如果你想使用多态关联(例如,一个对类继承树中超"
+"类的关联),你需要使用 <literal>&lt;union-subclass&gt;</literal> 映射。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2168
-#, no-c-format
-msgid ""
-"<![CDATA[<union-subclass\n"
-"        name=\"ClassName\"\n"
-"        table=\"tablename\"\n"
-"        proxy=\"ProxyInterface\"\n"
-"        lazy=\"true|false\"\n"
-"        dynamic-update=\"true|false\"\n"
-"        dynamic-insert=\"true|false\"\n"
-"        schema=\"schema\"\n"
-"        catalog=\"catalog\"\n"
-"        extends=\"SuperclassName\"\n"
-"        abstract=\"true|false\"\n"
-"        persister=\"ClassName\"\n"
-"        subselect=\"SQL expression\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\">\n"
-"\n"
-"        <property .... />\n"
-"        .....\n"
-"</union-subclass>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2195
 #, no-c-format
 msgid ""
 "No discriminator column or key column is required for this mapping strategy."
-msgstr "这种映射策略不需要指定辨别标志(discriminator)字段。"
+msgstr "这种映射策略不需要指定辨别标志(discriminator)字段。"
 
 #. Tag: title
-#: basic_mapping.xml:2206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Join"
-msgstr "连接(join)"
+msgstr "连接(join) "
 
 #. Tag: para
-#: basic_mapping.xml:2208
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Using the <literal>&lt;join&gt;</literal> element, it is possible to map "
 "properties of one class to several tables that have a one-to-one "
 "relationship. For example:"
 msgstr ""
 "使用 <literal>&lt;join&gt;</literal> 元素,假若在表之间存在一对一关联,可以将"
-"一个类的属性映射到多张表中。"
+"一个类的属性映射到多张表中。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2222
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<join\n"
-"        table=\"tablename\"\n"
-"        schema=\"owner\"\n"
-"        catalog=\"catalog\"\n"
-"        fetch=\"join|select\"\n"
-"        inverse=\"true|false\"\n"
-"        optional=\"true|false\">\n"
-"\n"
-"        <key ... />\n"
-"\n"
-"        <property ... />\n"
-"        ...\n"
-"</join>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2226
-#, fuzzy, no-c-format
 msgid "<literal>table</literal>: the name of the joined table."
-msgstr "<literal>table</literal>: 被连接表的名称。"
+msgstr "<literal>table</literal>:被连接表的名称。 "
 
 #. Tag: para
-#: basic_mapping.xml:2243
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional - defaults to <literal>join</literal>): "
 "if set to <literal>join</literal>, the default, Hibernate will use an inner "
@@ -4009,169 +2849,125 @@
 "instance of the subclass. Inner joins will still be used to retrieve a "
 "<literal>&lt;join&gt;</literal> defined by the class and its superclasses."
 msgstr ""
-"<literal>fetch</literal> (可选 - 默认是 <literal>join</literal>): 如果设置为"
-"默认值<literal>join</literal>, Hibernate 将使用一个内连接来得到这个类或其超"
-"类定义的<literal>&lt;join&gt;</literal>,而使用一个外连接来得到其子类定义的"
-"<literal>&lt;join&gt;</literal>。如果设置为<literal>select</literal>,则 "
-"Hibernate 将为子类定义的 <literal>&lt;join&gt;</literal>使用顺序选择。这仅在"
-"一行数据表示一个子类的对象的时候才会发生。对这个类和其超类定义的<literal>&lt;"
-"join&gt;</literal>,依然会使用内连接得到。"
+"<literal>fetch</literal>(可选 — 默认是 <literal>join</literal>):如果设置为"
+"默认值 <literal>join</literal>,Hibernate 将使用一个内连接来得到这个类或其超"
+"类定义的 <literal>&lt;join&gt;</literal>,而使用一个外连接来得到其子类定义的 "
+"<literal>&lt;join&gt;</literal>。如果设置为 <literal>select</literal>,则 "
+"Hibernate 将为子类定义的 <literal>&lt;join&gt;</literal> 使用顺序选择。这仅在"
+"一行数据表示一个子类的对象的时候才会发生。对这个类和其超类定义的 "
+"<literal>&lt;join&gt;</literal>,依然会使用内连接得到。 "
 
 #. Tag: para
-#: basic_mapping.xml:2256
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>inverse</literal> (optional - defaults to <literal>false</"
 "literal>): if enabled, Hibernate will not insert or update the properties "
 "defined by this join."
 msgstr ""
-"<literal>inverse</literal> (可选 - 默认是 <literal>false</literal>): 如果打"
-"开,Hibernate 不会插入或者更新此连接定义的属性。"
+"<literal>inverse</literal>(可选 — 默认是 <literal>false</literal>):如果打"
+"开,Hibernate 不会插入或者更新此连接定义的属性。 "
 
 #. Tag: para
-#: basic_mapping.xml:2263
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optional</literal> (optional - defaults to <literal>false</"
 "literal>): if enabled, Hibernate will insert a row only if the properties "
 "defined by this join are non-null. It will always use an outer join to "
 "retrieve the properties."
 msgstr ""
-"<literal>optional</literal> (可选 - 默认是 <literal>false</literal>): 如果打"
+"<literal>optional</literal>(可选 — 默认是 <literal>false</literal>):如果打"
 "开,Hibernate 只会在此连接定义的属性非空时插入一行数据,并且总是使用一个外连"
-"接来得到这些属性。"
+"接来得到这些属性。 "
 
 #. Tag: para
-#: basic_mapping.xml:2272
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For example, address information for a person can be mapped to a separate "
 "table while preserving value type semantics for all properties:"
 msgstr ""
-"例如,一个人(person)的地址(address)信息可以被映射到单独的表中(并保留所有属性"
-"的值类型语义):"
+"例如,一个人(person)的地址(address)信息可以被映射到单独的表中(并保留所有"
+"属性的值类型语义): "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2277
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\"\n"
-"    table=\"PERSON\">\n"
-"\n"
-"    <id name=\"id\" column=\"PERSON_ID\">...</id>\n"
-"\n"
-"    <join table=\"ADDRESS\">\n"
-"        <key column=\"ADDRESS_ID\"/>\n"
-"        <property name=\"address\"/>\n"
-"        <property name=\"zip\"/>\n"
-"        <property name=\"country\"/>\n"
-"    </join>\n"
-"    ...]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2279
-#, fuzzy, no-c-format
-msgid ""
 "This feature is often only useful for legacy data models. We recommend fewer "
 "tables than classes and a fine-grained domain model. However, it is useful "
 "for switching between inheritance mapping strategies in a single hierarchy, "
 "as explained later."
 msgstr ""
 "此特性常常对遗留数据模型有用,我们推荐表个数比类个数少,以及细粒度的领域模"
-"型。然而,在单独的继承树上切换继承映射策略是有用的,后面会解释这点。"
+"型。然而,在单独的继承树上切换继承映射策略是有用的,后面会解释这点。 "
 
 #. Tag: title
-#: basic_mapping.xml:2289
 #, no-c-format
-msgid "<title>Key</title>"
-msgstr ""
+msgid "Key"
+msgstr "Key"
 
 #. Tag: para
-#: basic_mapping.xml:2291
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;key&gt;</literal> element has featured a few times within "
 "this guide. It appears anywhere the parent mapping element defines a join to "
 "a new table that references the primary key of the original table. It also "
 "defines the foreign key in the joined table:"
 msgstr ""
-"我们目前已经见到过<literal>&lt;key&gt;</literal>元素多次了。 这个元素在父映射"
-"元素定义了对新表的连接,并且在被连接表中定义了一个外键引用原表的主键的情况下"
-"经常使用。"
+"我们目前已经见到过 <literal>&lt;key&gt;</literal> 元素多次了。这个元素在父映"
+"射元素定义了对新表的连接,并且在被连接表中定义了一个外键引用原表的主键的情况"
+"下经常使用。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2307
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<key\n"
-"        column=\"columnname\"\n"
-"        on-delete=\"noaction|cascade\"\n"
-"        property-ref=\"propertyName\"\n"
-"        not-null=\"true|false\"\n"
-"        update=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2318
-#, fuzzy, no-c-format
-msgid ""
 "<literal>on-delete</literal> (optional - defaults to <literal>noaction</"
 "literal>): specifies whether the foreign key constraint has database-level "
 "cascade delete enabled."
 msgstr ""
-"<literal>on-delete</literal> (可选, 默认是 <literal>noaction</literal>): 表明"
-"外键关联是否打开数据库级别的级联删除。"
+"<literal>on-delete</literal>(可选,默认是 <literal>noaction</literal>):表"
+"明外键关联是否打开数据库级别的级联删除。 "
 
 #. Tag: para
-#: basic_mapping.xml:2325
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>property-ref</literal> (optional): specifies that the foreign key "
 "refers to columns that are not the primary key of the original table. It is "
 "provided for legacy data."
 msgstr ""
-"<literal>property-ref</literal> (可选): 表明外键引用的字段不是原表的主键(提供"
-"给遗留数据)。"
+"<literal>property-ref</literal>(可选):表明外键引用的字段不是原表的主键(提"
+"供给遗留数据)。 "
 
 #. Tag: para
-#: basic_mapping.xml:2332
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-null</literal> (optional): specifies that the foreign key "
 "columns are not nullable. This is implied whenever the foreign key is also "
 "part of the primary key."
 msgstr ""
-"<literal>not-null</literal> (可选): 表明外键的字段不可为空(这意味着无论何时外"
-"键都是主键的一部分)。"
+"<literal>not-null</literal>(可选):表明外键的字段不可为空(这意味着无论何时"
+"外键都是主键的一部分)。 "
 
 #. Tag: para
-#: basic_mapping.xml:2339
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>update</literal> (optional): specifies that the foreign key should "
 "never be updated. This is implied whenever the foreign key is also part of "
 "the primary key."
 msgstr ""
-"<literal>update</literal> (可选): 表明外键决不应该被更新(这意味着无论何时外键"
-"都是主键的一部分)。"
+"<literal>update</literal>(可选):表明外键决不应该被更新(这意味着无论何时外"
+"键都是主键的一部分)。 "
 
 #. Tag: para
-#: basic_mapping.xml:2346
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>unique</literal> (optional): specifies that the foreign key should "
 "have a unique constraint. This is implied whenever the foreign key is also "
 "the primary key."
 msgstr ""
-"<literal>unique</literal> (可选): 表明外键应有唯一性约束 (这意味着无论何时外"
-"键都是主键的一部分)。"
+"<literal>unique</literal>(可选):表明外键应有唯一性约束(这意味着无论何时外"
+"键都是主键的一部分)。 "
 
 #. Tag: para
-#: basic_mapping.xml:2354
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For systems where delete performance is important, we recommend that all "
 "keys should be defined <literal>on-delete=\"cascade\"</literal>. Hibernate "
@@ -4180,14 +2976,13 @@
 "that this feature bypasses Hibernate's usual optimistic locking strategy for "
 "versioned data."
 msgstr ""
-"对那些看重删除性能的系统,我们推荐所有的键都应该定义为<literal>on-delete="
-"\"cascade\"</literal>,这样 Hibernate 将使用数据库级的<literal>ON CASCADE "
-"DELETE</literal>约束,而不是多个<literal>DELETE</literal>语句。 注意,这个特"
-"性会绕过 Hibernate 通常对版本数据(versioned data)采用的乐观锁策略。"
+"对那些看重删除性能的系统,我们推荐所有的键都应该定义为 <literal>on-delete="
+"\"cascade\"</literal>,这样 Hibernate 将使用数据库级的 <literal>ON CASCADE "
+"DELETE</literal> 约束,而不是多个 <literal>DELETE</literal> 语句。注意,这个"
+"特性会绕过 Hibernate 通常对版本数据(versioned data)采用的乐观锁策略。 "
 
 #. Tag: para
-#: basic_mapping.xml:2362
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>not-null</literal> and <literal>update</literal> attributes are "
 "useful when mapping a unidirectional one-to-many association. If you map a "
@@ -4196,84 +2991,55 @@
 "null=\"true\"&gt;</literal>."
 msgstr ""
 "<literal>not-null</literal> 和 <literal>update</literal> 属性在映射单向一对多"
-"关联的时候有用。如果你映射一个单向一对多关联到非空的(non-nullable)外键,你"
-"<emphasis>必须</emphasis> 用<literal>&lt;key not-null=\"true\"&gt;</literal>"
-"定义此键字段。"
+"关联的时候有用。如果你映射一个单向一对多关联到非空的(non-nullable)外键,你"
+"<emphasis>必须</emphasis> 用 <literal>&lt;key not-null=\"true\"&gt;</"
+"literal> 定义此键字段。 "
 
 #. Tag: title
-#: basic_mapping.xml:2372
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Column and formula elements"
-msgstr "字段和规则元素(column and formula elements)"
+msgstr "字段和规则元素(column and formula elements) "
 
 #. Tag: para
-#: basic_mapping.xml:2373
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Mapping elements which accept a <literal>column</literal> attribute will "
 "alternatively accept a <literal>&lt;column&gt;</literal> subelement. "
 "Likewise, <literal>&lt;formula&gt;</literal> is an alternative to the "
 "<literal>formula</literal> attribute. For example:"
 msgstr ""
-"任何接受<literal>column</literal>属性的映射元素都可以选择接受<literal>&lt;"
-"column&gt;</literal> 子元素。同样的,<literal>formula</literal>子元素也可以替"
-"换<literal>&lt;formula&gt;</literal>属性。"
+"任何接受 <literal>column</literal> 属性的映射元素都可以选择接受 <literal>&lt;"
+"column&gt;</literal> 子元素。同样的,<literal>formula</literal> 子元素也可以"
+"替换 <literal>&lt;formula&gt;</literal> 属性。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2379
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<column\n"
-"        name=\"column_name\"\n"
-"        length=\"N\"\n"
-"        precision=\"N\"\n"
-"        scale=\"N\"\n"
-"        not-null=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        unique-key=\"multicolumn_unique_key_name\"\n"
-"        index=\"index_name\"\n"
-"        sql-type=\"sql_type_name\"\n"
-"        check=\"SQL expression\"\n"
-"        default=\"SQL expression\"/>]]>"
+"Most of the attributes on <literal>column</literal> provide a means of "
+"tailoring the DDL during automatic schema generation. The <literal>read</"
+"literal> and <literal>write</literal> attributes allow you to specify custom "
+"SQL that Hibernate will use to access the column's value. For more on this, "
+"see the discussion of <link linkend=\"mapping-column-read-and-write\">column "
+"read and write expressions</link>."
 msgstr ""
 
-#. Tag: programlisting
-#: basic_mapping.xml:2381
-#, no-c-format
-msgid "<![CDATA[<formula>SQL expression</formula>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2383
 #, fuzzy, no-c-format
 msgid ""
-"<literal>column</literal> and <literal>formula</literal> attributes can even "
-"be combined within the same property or association mapping to express, for "
-"example, exotic join conditions."
+"The <literal>column</literal> and <literal>formula</literal> elements can "
+"even be combined within the same property or association mapping to express, "
+"for example, exotic join conditions."
 msgstr ""
 "<literal>column</literal> 和 <literal>formula</literal> 属性甚至可以在同一个"
-"属性或关联映射中被合并来表达,例如,一些奇异的连接条件。"
+"属性或关联映射中被合并来表达,例如,一些奇异的连接条件。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2389
+#. Tag: title
 #, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"homeAddress\" class=\"Address\"\n"
-"        insert=\"false\" update=\"false\">\n"
-"    <column name=\"person_id\" not-null=\"true\" length=\"10\"/>\n"
-"    <formula>'MAILING'</formula>\n"
-"</many-to-one>]]>"
-msgstr ""
-
-#. Tag: title
-#: basic_mapping.xml:2394
-#, fuzzy, no-c-format
 msgid "Import"
-msgstr "引用(import)"
+msgstr "引用(import) "
 
 #. Tag: para
-#: basic_mapping.xml:2396
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your application has two persistent classes with the same name, and you "
 "do not want to specify the fully qualified package name in Hibernate "
@@ -4281,52 +3047,32 @@
 "<literal>auto-import=\"true\"</literal>. You can also import classes and "
 "interfaces that are not explicitly mapped:"
 msgstr ""
-"假设你的应用程序有两个同样名字的持久化类,但是你不想在Hibernate查询中使用他们"
-"的全限定名。除了依赖<literal>auto-import=\"true\"</literal>以外,类也可以被显"
-"式地“import(引用)”。你甚至可以引用没有被明确映射的类和接口。"
+"假设你的应用程序有两个同样名字的持久化类,但是你不想在 Hibernate 查询中使用他"
+"们的全限定名。除了依赖 <literal>auto-import=\"true\"</literal> 以外,类也可以"
+"被显式地“import(引用)”。你甚至可以引用没有被明确映射的类和接口。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2403
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[<import class=\"java.lang.Object\" rename=\"Universe\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2410
-#, no-c-format
 msgid ""
-"<![CDATA[<import\n"
-"        class=\"ClassName\"\n"
-"        rename=\"ShortName\"\n"
-"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2413
-#, fuzzy, no-c-format
-msgid ""
 "<literal>class</literal>: the fully qualified class name of any Java class."
-msgstr "<literal>class</literal>: 任何Java类的全限定名。"
+msgstr "<literal>class</literal>:任何 Java 类的全限定名。 "
 
 #. Tag: para
-#: basic_mapping.xml:2418
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>rename</literal> (optional - defaults to the unqualified class "
 "name): a name that can be used in the query language."
 msgstr ""
-"<literal>rename</literal> (可选 - 默认为类的全限定名): 在查询语句中可以使用的"
-"名字。"
+"<literal>rename</literal>(可选 — 默认为类的全限定名):在查询语句中可以使用"
+"的名字。 "
 
 #. Tag: title
-#: basic_mapping.xml:2429
 #, no-c-format
-msgid "<title>Any</title>"
-msgstr ""
+msgid "Any"
+msgstr "Any"
 
 #. Tag: para
-#: basic_mapping.xml:2431
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is one more type of property mapping. The <literal>&lt;any&gt;</"
 "literal> mapping element defines a polymorphic association to classes from "
@@ -4340,12 +3086,11 @@
 "这是属性映射的又一种类型。<literal>&lt;any&gt;</literal> 映射元素定义了一种从"
 "多个表到类的多态关联。这种类型的映射常常需要多于一个字段。第一个字段持有被关"
 "联实体的类型,其他的字段持有标识符。对这种类型的关联来说,不可能指定一个外键"
-"约束,所以这当然不是映射(多态)关联的通常的方式。你只应该在非常特殊的情况下使"
-"用它(比如,审计log,用户会话数据等等)。"
+"约束,所以这当然不是映射(多态)关联的通常的方式。你只应该在非常特殊的情况下"
+"使用它(比如,审计 log,用户会话数据等等)。 "
 
 #. Tag: para
-#: basic_mapping.xml:2441
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>meta-type</literal> attribute allows the application to specify "
 "a custom type that maps database column values to persistent classes that "
@@ -4354,110 +3099,68 @@
 "names."
 msgstr ""
 "<literal>meta-type</literal> 属性使得应用程序能指定一个将数据库字段的值映射到"
-"持久化类的自定义类型。这个持久化类包含有用<literal>id-type</literal>指定的标"
-"识符属性。 你必须指定从meta-type的值到类名的映射。"
+"持久化类的自定义类型。这个持久化类包含有用 <literal>id-type</literal> 指定的"
+"标识符属性。你必须指定从 meta-type 的值到类名的映射。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2448
-#, no-c-format
-msgid ""
-"<![CDATA[<any name=\"being\" id-type=\"long\" meta-type=\"string\">\n"
-"    <meta-value value=\"TBL_ANIMAL\" class=\"Animal\"/>\n"
-"    <meta-value value=\"TBL_HUMAN\" class=\"Human\"/>\n"
-"    <meta-value value=\"TBL_ALIEN\" class=\"Alien\"/>\n"
-"    <column name=\"table_name\"/>\n"
-"    <column name=\"id\"/>\n"
-"</any>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2459
-#, no-c-format
-msgid ""
-"<![CDATA[<any\n"
-"        name=\"propertyName\"\n"
-"        id-type=\"idtypename\"\n"
-"        meta-type=\"metatypename\"\n"
-"        cascade=\"cascade_style\"\n"
-"        access=\"field|property|ClassName\"\n"
-"        optimistic-lock=\"true|false\"\n"
-">\n"
-"        <meta-value ... />\n"
-"        <meta-value ... />\n"
-"        .....\n"
-"        <column .... />\n"
-"        <column .... />\n"
-"        .....\n"
-"</any>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2462
 #, no-c-format
 msgid "<literal>name</literal>: the property name."
-msgstr "<literal>name</literal>: 属性名"
+msgstr "<literal>name</literal>:属性名"
 
 #. Tag: para
-#: basic_mapping.xml:2467
 #, no-c-format
 msgid "<literal>id-type</literal>: the identifier type."
-msgstr "<literal>id-type</literal>: 标识符类型"
+msgstr "<literal>id-type</literal>:标识符类型"
 
 #. Tag: para
-#: basic_mapping.xml:2472
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>meta-type</literal> (optional - defaults to <literal>string</"
 "literal>): any type that is allowed for a discriminator mapping."
 msgstr ""
-"<literal>meta-type</literal> (可选 -默认是 <literal>string</literal>): 允许辨"
-"别标志(discriminator)映射的任何类型"
+"<literal>meta-type</literal>(可选 -默认是 <literal>string</literal>):允许"
+"辨别标志(discriminator)映射的任何类型。 "
 
 #. Tag: para
-#: basic_mapping.xml:2478
 #, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional- defaults to <literal>none</literal>): "
 "the cascade style."
 msgstr ""
-"<literal>cascade</literal> (可选 -默认是<literal>none</literal>): 级联的类型"
+"<literal>cascade</literal>(可选 — 默认是<literal>none</literal>):级联的类"
+"型。"
 
 #. Tag: para
-#: basic_mapping.xml:2490
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that updates to this property either do or do not "
 "require acquisition of the optimistic lock. It defines whether a version "
 "increment should occur if this property is dirty."
 msgstr ""
-"<literal>optimistic-lock</literal> (可选 -默认是 <literal>true</literal>): 表"
-"明更新此组件是否需要获取乐观锁。换句话说,当这个属性变脏时,是否增加版本号"
-"(Version)"
+"<literal>optimistic-lock</literal>(可选 — 默认是 <literal>true</literal>):"
+"表明更新此组件是否需要获取乐观锁。换句话说,当这个属性变脏时,是否增加版本号"
+"(Version)。"
 
 #. Tag: title
-#: basic_mapping.xml:2505
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Hibernate types"
-msgstr "Hibernate 的类型"
+msgstr "Hibernate 的类型 "
 
 #. Tag: title
-#: basic_mapping.xml:2508
 #, no-c-format
 msgid "Entities and values"
-msgstr "实体(Entities)和值(values)"
+msgstr "实体(Entities)和值(values)"
 
 #. Tag: para
-#: basic_mapping.xml:2510
 #, no-c-format
 msgid ""
 "In relation to the persistence service, Java language-level objects are "
 "classified into two groups:"
-msgstr ""
+msgstr "和持久化服务相比,Java 级别的对象分为两个组别:"
 
 #. Tag: para
-#: basic_mapping.xml:2515
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An <emphasis>entity</emphasis> exists independently of any other objects "
 "holding references to the entity. Contrast this with the usual Java model, "
@@ -4469,15 +3172,15 @@
 "large systems. Entities support circular and shared references. They can "
 "also be versioned."
 msgstr ""
-"<emphasis>实体entity</emphasis> 独立于任何持有实体引用的对象。与通常的Java模"
-"型相比,不再被引用的对象会被当作垃圾收集掉。实体必须被显式的保存和删除(除非保"
-"存和删除是从父实体向子实体引发的<emphasis>级联</emphasis>)。这和ODMG模型中关"
-"于对象通过可触及保持持久性有一些不同——比较起来更加接近应用程序对象通常在一个"
-"大系统中的使用方法。实体支持循环引用和交叉引用,它们也可以加上版本信息。"
+"<emphasis>实体entity</emphasis> 独立于任何持有实体引用的对象。与通常的 Java "
+"模型相比,不再被引用的对象会被当作垃圾收集掉。实体必须被显式的保存和删除(除"
+"非保存和删除是从父实体向子实体引发的<emphasis>级联</emphasis>)。这和 ODMG 模"
+"型中关于对象通过可触及保持持久性有一些不同 — 比较起来更加接近应用程序对象通常"
+"在一个大系统中的使用方法。实体支持循环引用和交叉引用,它们也可以加上版本信"
+"息。 "
 
 #. Tag: para
-#: basic_mapping.xml:2526
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An entity's persistent state consists of references to other entities and "
 "instances of <emphasis>value</emphasis> types. Values are primitives: "
@@ -4490,14 +3193,13 @@
 "collections."
 msgstr ""
 "一个实体的持久状态包含指向其他实体和<emphasis>值</emphasis>类型实例的引用。值"
-"可以是原始类型,集合(不是集合中的对象),组件或者特定的不可变对象。与实体不"
-"同,值(特别是集合和组件)是通过可触及性来进行持久化和删除的。因为值对象(和原始"
-"类型数据)是随着包含他们的实体而被持久化和删除的,他们不能被独立的加上版本信"
-"息。值没有独立的标识,所以他们不能被两个实体或者集合共享。"
+"可以是原始类型,集合(不是集合中的对象),组件或者特定的不可变对象。与实体不"
+"同,值(特别是集合和组件)是通过可触及性来进行持久化和删除的。因为值对象(和"
+"原始类型数据)是随着包含他们的实体而被持久化和删除的,他们不能被独立的加上版"
+"本信息。值没有独立的标识,所以他们不能被两个实体或者集合共享。 "
 
 #. Tag: para
-#: basic_mapping.xml:2537
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Until now, we have been using the term \"persistent class\" to refer to "
 "entities. We will continue to do that. Not all user-defined classes with a "
@@ -4511,23 +3213,21 @@
 "single instance of that class, while composition or aggregation usually "
 "translates to a value type."
 msgstr ""
-"直到现在,我们都一直使用术语“持久类”(persistent class)来代表实体。我们仍然会"
-"这么做。 然而严格说来,不是所有的用户自定义的,带有持久化状态的类都是实体。"
+"直到现在,我们都一直使用术语“持久类”(persistent class)来代表实体。我们仍然"
+"会这么做。然而严格说来,不是所有的用户自定义的,带有持久化状态的类都是实体。"
 "<emphasis>组件</emphasis>就是用户自定义类,却是值语义的。<literal>java.lang."
-"String</literal>类型的java属性也是值语义的。给了这个定义以后,我们可以说所有"
-"JDK提供的类型(类)都是值类型的语义,而用于自定义类型可能被映射为实体类型或值类"
-"型语义。采用哪种类型的语义取决于开发人员。在领域模型中,寻找实体类的一个好线"
-"索是共享引用指向这个类的单一实例,而组合或聚合通常被转化为值类型。"
+"String</literal> 类型的 java 属性也是值语义的。给了这个定义以后,我们可以说所"
+"有 JDK 提供的类型(类)都是值类型的语义,而用于自定义类型可能被映射为实体类型"
+"或值类型语义。采用哪种类型的语义取决于开发人员。在领域模型中,寻找实体类的一"
+"个好线索是共享引用指向这个类的单一实例,而组合或聚合通常被转化为值类型。 "
 
 #. Tag: para
-#: basic_mapping.xml:2551
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "We will revisit both concepts throughout this reference guide."
-msgstr "我们会在本文档中重复碰到这两个概念。"
+msgstr "我们会在本文档中重复碰到这两个概念。 "
 
 #. Tag: para
-#: basic_mapping.xml:2555
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The challenge is to map the Java type system, and the developers' definition "
 "of entities and value types, to the SQL/database type system. The bridge "
@@ -4540,49 +3240,45 @@
 "for standard JDK value types out of the box. You can write your own mapping "
 "types and implement your own custom conversion strategies."
 msgstr ""
-"挑战在于将java类型系统(和开发者定义的实体和值类型)映射到 SQL/数据库类型系统。"
-"Hibernate提供了连接两个系统之间的桥梁:对于实体类型,我们使用<literal>&lt;"
-"class&gt;</literal>, <literal>&lt;subclass&gt;</literal> 等等。对于值类型,我"
-"们使用 <literal>&lt;property&gt;</literal>, <literal>&lt;component&gt;</"
-"literal> 及其他,通常跟随着<literal>type</literal>属性。这个属性的值是"
-"Hibernate 的<emphasis>映射类型</emphasis>的名字。Hibernate提供了许多现成的映"
-"射(标准的JDK值类型)。你也可以编写自己的映射类型并实现自定义的变换策略,随后我"
-"们会看到这点。"
+"挑战在于将 java 类型系统(和开发者定义的实体和值类型)映射到 SQL/数据库类型系"
+"统。Hibernate 提供了连接两个系统之间的桥梁:对于实体类型,我们使用 "
+"<literal>&lt;class&gt;</literal>,<literal>&lt;subclass&gt;</literal> 等等。"
+"对于值类型,我们使用 <literal>&lt;property&gt;</literal>,<literal>&lt;"
+"component&gt;</literal> 及其他,通常跟随着 <literal>type</literal> 属性。这个"
+"属性的值是Hibernate 的<emphasis>映射类型</emphasis>的名字。Hibernate 提供了许"
+"多现成的映射(标准的 JDK 值类型)。你也可以编写自己的映射类型并实现自定义的变"
+"换策略,随后我们会看到这点。 "
 
 #. Tag: para
-#: basic_mapping.xml:2568
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "With the exception of collections, all built-in Hibernate types support null "
 "semantics."
-msgstr "所有的Hibernate内建类型,除了collections以外,都支持空(null)语义。"
+msgstr ""
+"所有的 Hibernate 内建类型,除了 collections 以外,都支持空(null)语义。 "
 
 #. Tag: title
-#: basic_mapping.xml:2575
 #, no-c-format
 msgid "Basic value types"
 msgstr "基本值类型"
 
 #. Tag: para
-#: basic_mapping.xml:2577
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The built-in <emphasis>basic mapping types</emphasis> can be roughly "
 "categorized into the following:"
-msgstr "内建的 <emphasis>基本映射类型</emphasis>可以大致分为 <placeholder-1/>"
+msgstr "内置的 <emphasis>basic mapping types</emphasis> 可以大致地分类为:"
 
-#. Tag: literal
-#: basic_mapping.xml:2582
+#. Tag: term
 #, no-c-format
 msgid ""
-"integer, long, short, float, double, character, byte, boolean, yes_no, "
-"true_false"
+"<literal>integer, long, short, float, double, character, byte, boolean, "
+"yes_no, true_false</literal>"
 msgstr ""
-"integer, long, short, float, double, character, byte, boolean, yes_no, "
-"true_false"
+"<literal>integer, long, short, float, double, character, byte, boolean, "
+"yes_no, true_false</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2585
 #, no-c-format
 msgid ""
 "Type mappings from Java primitives or wrapper classes to appropriate (vendor-"
@@ -4590,86 +3286,77 @@
 "<literal>true_false</literal> are all alternative encodings for a Java "
 "<literal>boolean</literal> or <literal>java.lang.Boolean</literal>."
 msgstr ""
-"这些类型都对应Java的原始类型或者其封装类,来符合(特定厂商的)SQL 字段类型。"
-"<literal>boolean, yes_no</literal> 和 <literal>true_false</literal>都是Java "
-"中<literal>boolean</literal> 或者<literal>java.lang.Boolean</literal>的另外说"
-"法。"
+"这些类型都对应 Java 的原始类型或者其封装类,来符合(特定厂商的)SQL 字段类"
+"型。<literal>boolean, yes_no</literal> 和 <literal>true_false</literal> 都是 "
+"Java 中 <literal>boolean</literal> 或者 <literal>java.lang.Boolean</literal> "
+"的另外说法。"
 
-#. Tag: literal
-#: basic_mapping.xml:2594
+#. Tag: term
 #, no-c-format
-msgid "string"
-msgstr "string"
+msgid "<literal>string</literal>"
+msgstr "<literal>string</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2596
 #, no-c-format
 msgid ""
 "A type mapping from <literal>java.lang.String</literal> to <literal>VARCHAR</"
 "literal> (or Oracle <literal>VARCHAR2</literal>)."
 msgstr ""
-"从<literal>java.lang.String</literal> 到 <literal>VARCHAR</literal> (或者 "
-"Oracle的 <literal>VARCHAR2</literal>)的映射。"
+"从 <literal>java.lang.String</literal> 到 <literal>VARCHAR</literal>(或者 "
+"Oracle 的 <literal>VARCHAR2</literal>)的映射。"
 
-#. Tag: literal
-#: basic_mapping.xml:2603
+#. Tag: term
 #, no-c-format
-msgid "date, time, timestamp"
-msgstr "date, time, timestamp"
+msgid "<literal>date, time, timestamp</literal>"
+msgstr "<literal>date, time, timestamp</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2605
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Date</literal> and its subclasses to "
 "SQL types <literal>DATE</literal>, <literal>TIME</literal> and "
 "<literal>TIMESTAMP</literal> (or equivalent)."
 msgstr ""
-"从<literal>java.util.Date</literal>和其子类到SQL类型<literal>DATE</literal>, "
-"<literal>TIME</literal> 和<literal>TIMESTAMP</literal> (或等价类型)的映射。"
+"从 <literal>java.util.Date</literal> 和其子类到 SQL 类型 <literal>DATE</"
+"literal>,<literal>TIME</literal> 和 <literal>TIMESTAMP</literal>(或等价类"
+"型)的映射。"
 
-#. Tag: literal
-#: basic_mapping.xml:2613
+#. Tag: term
 #, no-c-format
-msgid "calendar, calendar_date"
-msgstr "calendar, calendar_date"
+msgid "<literal>calendar, calendar_date</literal>"
+msgstr "<literal>calendar, calendar_date</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2615
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Calendar</literal> to SQL types "
 "<literal>TIMESTAMP</literal> and <literal>DATE</literal> (or equivalent)."
 msgstr ""
-"从<literal>java.util.Calendar</literal> 到SQL 类型<literal>TIMESTAMP</"
-"literal>和 <literal>DATE</literal>(或等价类型)的映射。"
+"从 <literal>java.util.Calendar</literal> 到 SQL 类型 <literal>TIMESTAMP</"
+"literal> 和 <literal>DATE</literal>(或等价类型)的映射。"
 
-#. Tag: literal
-#: basic_mapping.xml:2623
+#. Tag: term
 #, no-c-format
-msgid "big_decimal, big_integer"
-msgstr "big_decimal, big_integer"
+msgid "<literal>big_decimal, big_integer</literal>"
+msgstr "<literal>big_decimal, big_integer</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2625
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.math.BigDecimal</literal> and <literal>java."
 "math.BigInteger</literal> to <literal>NUMERIC</literal> (or Oracle "
 "<literal>NUMBER</literal>)."
 msgstr ""
-"从<literal>java.math.BigDecimal</literal>和<literal>java.math.BigInteger</"
-"literal>到<literal>NUMERIC</literal> (或者 Oracle 的<literal>NUMBER</literal>"
-"类型)的映射。"
+"从 <literal>java.math.BigDecimal</literal> 和 <literal>java.math.BigInteger</"
+"literal> 到 <literal>NUMERIC</literal>(或者 Oracle 的 <literal>NUMBER</"
+"literal>类型)的映射。"
 
-#. Tag: literal
-#: basic_mapping.xml:2633
+#. Tag: term
 #, no-c-format
-msgid "locale, timezone, currency"
-msgstr "locale, timezone, currency"
+msgid "<literal>locale, timezone, currency</literal>"
+msgstr "<literal>locale, timezone, currency</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2635
 #, no-c-format
 msgid ""
 "Type mappings from <literal>java.util.Locale</literal>, <literal>java.util."
@@ -4679,84 +3366,76 @@
 "mapped to their ISO codes. Instances of <literal>TimeZone</literal> are "
 "mapped to their <literal>ID</literal>."
 msgstr ""
-"从<literal>java.util.Locale</literal>, <literal>java.util.TimeZone</literal> "
-"和<literal>java.util.Currency</literal> 到<literal>VARCHAR</literal> (或者 "
-"Oracle 的<literal>VARCHAR2</literal>类型)的映射. <literal>Locale</literal>和 "
-"<literal>Currency</literal> 的实例被映射为它们的ISO代码。<literal>TimeZone</"
-"literal>的实例被影射为它的<literal>ID</literal>。"
+"从 <literal>java.util.Locale</literal>,<literal>java.util.TimeZone</"
+"literal>  和 <literal>java.util.Currency</literal> 到 <literal>VARCHAR</"
+"literal>(或者 Oracle 的 <literal>VARCHAR2</literal> 类型)的映射。"
+"<literal>Locale</literal> 和 <literal>Currency</literal> 的实例被映射为它们"
+"的 ISO 代码。<literal>TimeZone</literal> 的实例被影射为它的 <literal>ID</"
+"literal>。"
 
-#. Tag: literal
-#: basic_mapping.xml:2647
+#. Tag: term
 #, no-c-format
-msgid "class"
-msgstr "class"
+msgid "<literal>class</literal>"
+msgstr "<literal>class</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2649
 #, no-c-format
 msgid ""
 "A type mapping from <literal>java.lang.Class</literal> to <literal>VARCHAR</"
 "literal> (or Oracle <literal>VARCHAR2</literal>). A <literal>Class</literal> "
 "is mapped to its fully qualified name."
 msgstr ""
-"从<literal>java.lang.Class</literal> 到 <literal>VARCHAR</literal> (或者 "
-"Oracle 的<literal>VARCHAR2</literal>类型)的映射。<literal>Class</literal>被映"
-"射为它的全限定名。"
+"从 <literal>java.lang.Class</literal> 到 <literal>VARCHAR</literal>(或者 "
+"Oracle 的 <literal>VARCHAR2</literal> 类型)的映射。<literal>Class</literal> "
+"被映射为它的全限定名。"
 
-#. Tag: literal
-#: basic_mapping.xml:2657
+#. Tag: term
 #, no-c-format
-msgid "binary"
-msgstr "binary"
+msgid "<literal>binary</literal>"
+msgstr "<literal>binary</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2659
 #, no-c-format
 msgid "Maps byte arrays to an appropriate SQL binary type."
-msgstr "把字节数组(byte arrays)映射为对应的 SQL二进制类型。"
+msgstr "把字节数组(byte arrays)映射为对应的 SQL 二进制类型。"
 
-#. Tag: literal
-#: basic_mapping.xml:2665
+#. Tag: term
 #, no-c-format
-msgid "text"
-msgstr "text"
+msgid "<literal>text</literal>"
+msgstr "<literal>text</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2667
 #, no-c-format
 msgid ""
 "Maps long Java strings to a SQL <literal>CLOB</literal> or <literal>TEXT</"
 "literal> type."
 msgstr ""
-"把长Java字符串映射为SQL的<literal>CLOB</literal>或者<literal>TEXT</literal>类"
-"型。"
+"把长 Java 字符串映射为 SQL 的 <literal>CLOB</literal> 或者 <literal>TEXT</"
+"literal> 类型。"
 
-#. Tag: literal
-#: basic_mapping.xml:2674
+#. Tag: term
 #, no-c-format
-msgid "serializable"
-msgstr "serializable"
+msgid "<literal>serializable</literal>"
+msgstr "<literal>serializable</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2676
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Maps serializable Java types to an appropriate SQL binary type. You can also "
 "indicate the Hibernate type <literal>serializable</literal> with the name of "
 "a serializable Java class or interface that does not default to a basic type."
 msgstr ""
-"把可序列化的Java类型映射到对应的SQL二进制类型。你也可以为一个并非默认为基本类"
-"型的可序列化Java类或者接口指定Hibernate类型<literal>serializable</literal>。"
+"把可序列化的 Java 类型映射到对应的 SQL 二进制类型。你也可以为一个并非默认为基"
+"本类型的可序列化 Java 类或者接口指定 Hibernate 类型 <literal>serializable</"
+"literal>。 "
 
-#. Tag: literal
-#: basic_mapping.xml:2685
+#. Tag: term
 #, no-c-format
-msgid "clob, blob"
-msgstr "clob, blob"
+msgid "<literal>clob, blob</literal>"
+msgstr "<literal>clob, blob</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2687
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Type mappings for the JDBC classes <literal>java.sql.Clob</literal> and "
 "<literal>java.sql.Blob</literal>. These types can be inconvenient for some "
@@ -4764,22 +3443,20 @@
 "transaction. Driver support is patchy and inconsistent."
 msgstr ""
 "JDBC 类 <literal>java.sql.Clob</literal> 和 <literal>java.sql.Blob</literal>"
-"的映射。某些程序可能不适合使用这个类型,因为blob和clob对象可能在一个事务之外"
-"是无法重用的。(而且, 驱动程序对这种类型的支持充满着补丁和前后矛盾。)"
+"的映射。某些程序可能不适合使用这个类型,因为 blob 和 clob 对象可能在一个事务"
+"之外是无法重用的。(而且, 驱动程序对这种类型的支持充满着补丁和前后矛盾。) "
 
-#. Tag: literal
-#: basic_mapping.xml:2697
+#. Tag: term
 #, no-c-format
 msgid ""
-"imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
-"imm_serializable, imm_binary"
+"<literal>imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
+"imm_serializable, imm_binary</literal>"
 msgstr ""
-"imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
-"imm_serializable, imm_binary"
+"<literal>imm_date, imm_time, imm_timestamp, imm_calendar, imm_calendar_date, "
+"imm_serializable, imm_binary</literal>"
 
 #. Tag: para
-#: basic_mapping.xml:2701
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Type mappings for what are considered mutable Java types. This is where "
 "Hibernate makes certain optimizations appropriate only for immutable Java "
@@ -4789,27 +3466,25 @@
 "have that change made persistent, the application must assign a new, "
 "nonidentical, object to the property."
 msgstr ""
-"一般来说,映射类型被假定为是可变的Java类型,只有对不可变Java类型,Hibernate会"
-"采取特定的优化措施,应用程序会把这些对象作为不可变对象处理。比如,你不应该对"
-"作为<literal>imm_timestamp</literal>映射的Date执行<literal>Date.setTime()</"
-"literal>。要改变属性的值,并且保存这一改变,应用程序必须对这一属性重新设置一"
-"个新的(不一样的)对象。"
+"一般来说,映射类型被假定为是可变的 Java 类型,只有对不可变 Java 类型,"
+"Hibernate 会采取特定的优化措施,应用程序会把这些对象作为不可变对象处理。比"
+"如,你不应该对作为 <literal>imm_timestamp</literal> 映射的 Date 执行 "
+"<literal>Date.setTime()</literal>。要改变属性的值,并且保存这一改变,应用程序"
+"必须对这一属性重新设置一个新的(不一样的)对象。 "
 
 #. Tag: para
-#: basic_mapping.xml:2716
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Unique identifiers of entities and collections can be of any basic type "
 "except <literal>binary</literal>, <literal>blob</literal> and <literal>clob</"
 "literal>. Composite identifiers are also allowed. See below for more "
 "information."
 msgstr ""
-"实体及其集合的唯一标识可以是除了<literal>binary</literal>、 <literal>blob</"
-"literal> 和 <literal>clob</literal>之外的任何基础类型。(联合标识也是允许的,"
-"后面会说到。)"
+"实体及其集合的唯一标识可以是除了 <literal>binary</literal>、 <literal>blob</"
+"literal> 和 <literal>clob</literal> 之外的任何基础类型。(联合标识也是允许"
+"的,后面会说到。)"
 
 #. Tag: para
-#: basic_mapping.xml:2722
 #, no-c-format
 msgid ""
 "The basic value types have corresponding <literal>Type</literal> constants "
@@ -4817,19 +3492,17 @@
 "<literal>Hibernate.STRING</literal> represents the <literal>string</literal> "
 "type."
 msgstr ""
-"在<literal>org.hibernate.Hibernate</literal>中,定义了基础类型对应的"
-"<literal>Type</literal>常量。比如,<literal>Hibernate.STRING</literal>代表"
+"在 <literal>org.hibernate.Hibernate</literal> 中,定义了基础类型对应的 "
+"<literal>Type</literal> 常量。比如,<literal>Hibernate.STRING</literal> 代表 "
 "<literal>string</literal> 类型。"
 
 #. Tag: title
-#: basic_mapping.xml:2731
 #, no-c-format
 msgid "Custom value types"
 msgstr "自定义值类型"
 
 #. Tag: para
-#: basic_mapping.xml:2733
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is relatively easy for developers to create their own value types. For "
 "example, you might want to persist properties of type <literal>java.lang."
@@ -4841,18 +3514,17 @@
 "that is persisted to the columns <literal>FIRST_NAME</literal>, "
 "<literal>INITIAL</literal>, <literal>SURNAME</literal>."
 msgstr ""
-"开发者创建属于他们自己的值类型也是很容易的。比如说,你可能希望持久化"
-"<literal>java.lang.BigInteger</literal>类型的属性,持久化成为"
-"<literal>VARCHAR</literal>字段。Hibernate没有内置这样一种类型。自定义类型能够"
-"映射一个属性(或集合元素)到不止一个数据库表字段。比如说,你可能有这样的Java属"
-"性:<literal>getName()</literal>/<literal>setName()</literal>,这是"
-"<literal>java.lang.String</literal>类型的,对应的持久化到三个字段:"
-"<literal>FIRST_NAME</literal>, <literal>INITIAL</literal>, <literal>SURNAME</"
-"literal>。"
+"开发者创建属于他们自己的值类型也是很容易的。比如说,你可能希望持久化 "
+"<literal>java.lang.BigInteger</literal> 类型的属性,持久化成为 "
+"<literal>VARCHAR</literal> 字段。Hibernate没有内置这样一种类型。自定义类型能"
+"够映射一个属性(或集合元素)到不止一个数据库表字段。比如说,你可能有这样的 "
+"Java 属性:<literal>getName()</literal>/<literal>setName()</literal>,这是 "
+"<literal>java.lang.String</literal> 类型的,对应的持久化到三个字段:"
+"<literal>FIRST_NAME</literal>,<literal>INITIAL</literal>,<literal>SURNAME</"
+"literal>。 "
 
 #. Tag: para
-#: basic_mapping.xml:2744
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To implement a custom type, implement either <literal>org.hibernate."
 "UserType</literal> or <literal>org.hibernate.CompositeUserType</literal> and "
@@ -4860,34 +3532,21 @@
 "<literal>org.hibernate.test.DoubleStringType</literal> to see the kind of "
 "things that are possible."
 msgstr ""
-"要实现一个自定义类型,可以实现<literal>org.hibernate.UserType</literal>或"
-"<literal>org.hibernate.CompositeUserType</literal>中的任一个,并且使用类型的"
-"Java全限定类名来定义属性。请查看<literal>org.hibernate.test."
-"DoubleStringType</literal>这个例子,看看它是怎么做的。"
+"要实现一个自定义类型,可以实现 <literal>org.hibernate.UserType</literal> 或 "
+"<literal>org.hibernate.CompositeUserType</literal> 中的任一个,并且使用类型"
+"的 Java 全限定类名来定义属性。请查看 <literal>org.hibernate.test."
+"DoubleStringType</literal> 这个例子,看看它是怎么做的。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2752
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"twoStrings\" type=\"org.hibernate.test."
-"DoubleStringType\">\n"
-"    <column name=\"first_string\"/>\n"
-"    <column name=\"second_string\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2754
 #, no-c-format
 msgid ""
 "Notice the use of <literal>&lt;column&gt;</literal> tags to map a property "
 "to multiple columns."
 msgstr ""
-"注意使用<literal>&lt;column&gt;</literal>标签来把一个属性映射到多个字段的做"
+"注意使用 <literal>&lt;column&gt;</literal> 标签来把一个属性映射到多个字段的做"
 "法。"
 
 #. Tag: para
-#: basic_mapping.xml:2759
 #, no-c-format
 msgid ""
 "The <literal>CompositeUserType</literal>, <literal>EnhancedUserType</"
@@ -4895,13 +3554,12 @@
 "<literal>UserVersionType</literal> interfaces provide support for more "
 "specialized uses."
 msgstr ""
-"<literal>CompositeUserType</literal>, <literal>EnhancedUserType</literal>, "
-"<literal>UserCollectionType</literal>, 和 <literal>UserVersionType</literal> "
+"<literal>CompositeUserType</literal>,<literal>EnhancedUserType</literal>,"
+"<literal>UserCollectionType</literal> 和 <literal>UserVersionType</literal> "
 "接口为更特殊的使用方式提供支持。"
 
 #. Tag: para
-#: basic_mapping.xml:2765
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can even supply parameters to a <literal>UserType</literal> in the "
 "mapping file. To do this, your <literal>UserType</literal> must implement "
@@ -4909,36 +3567,23 @@
 "To supply parameters to your custom type, you can use the <literal>&lt;"
 "type&gt;</literal> element in your mapping files."
 msgstr ""
-"你甚至可以在一个映射文件中提供参数给一个<literal>UserType</literal>。 为了这"
-"样做,你的<literal>UserType</literal>必须实现<literal>org.hibernate.usertype."
-"ParameterizedType</literal>接口。为了给自定义类型提供参数,你可以在映射文件中"
-"使用<literal>&lt;type&gt;</literal>元素。"
+"你甚至可以在一个映射文件中提供参数给一个 <literal>UserType</literal>。 为了这"
+"样做,你的 <literal>UserType</literal> 必须实现 <literal>org.hibernate."
+"usertype.ParameterizedType</literal> 接口。为了给自定义类型提供参数,你可以在"
+"映射文件中使用 <literal>&lt;type&gt;</literal> 元素。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2773
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"priority\">\n"
-"    <type name=\"com.mycompany.usertypes.DefaultValueIntegerType\">\n"
-"        <param name=\"default\">0</param>\n"
-"    </type>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2775
 #, no-c-format
 msgid ""
 "The <literal>UserType</literal> can now retrieve the value for the parameter "
 "named <literal>default</literal> from the <literal>Properties</literal> "
 "object passed to it."
 msgstr ""
-"现在,<literal>UserType</literal> 可以从传入的<literal>Properties</literal>对"
-"象中得到<literal>default</literal> 参数的值。"
+"现在,<literal>UserType</literal> 可以从传入的 <literal>Properties</literal> "
+"对象中得到 <literal>default</literal> 参数的值。"
 
 #. Tag: para
-#: basic_mapping.xml:2780
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you regularly use a certain <literal>UserType</literal>, it is useful to "
 "define a shorter name for it. You can do this using the <literal>&lt;"
@@ -4946,37 +3591,21 @@
 "can also contain a list of default parameter values if the type is "
 "parameterized."
 msgstr ""
-"如果你非常频繁地使用某一<literal>UserType</literal>,可以为他定义一个简称。这"
-"可以通过使用 <literal>&lt;typedef&gt;</literal>元素来实现。Typedefs为一自定义"
-"类型赋予一个名称,并且如果此类型是参数化的,还可以包含一系列默认的参数值。"
+"如果你非常频繁地使用某一 <literal>UserType</literal>,可以为他定义一个简称。"
+"这可以通过使用 <literal>&lt;typedef&gt;</literal> 元素来实现。Typedefs 为一自"
+"定义类型赋予一个名称,并且如果此类型是参数化的,还可以包含一系列默认的参数"
+"值。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2787
-#, no-c-format
-msgid ""
-"<![CDATA[<typedef class=\"com.mycompany.usertypes.DefaultValueIntegerType\" "
-"name=\"default_zero\">\n"
-"    <param name=\"default\">0</param>\n"
-"</typedef>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: basic_mapping.xml:2789
-#, no-c-format
-msgid "<![CDATA[<property name=\"priority\" type=\"default_zero\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: basic_mapping.xml:2791
 #, no-c-format
 msgid ""
 "It is also possible to override the parameters supplied in a typedef on a "
 "case-by-case basis by using type parameters on the property mapping."
-msgstr "也可以根据具体案例通过属性映射中的类型参数覆盖在typedef中提供的参数。"
+msgstr ""
+"也可以根据具体案例通过属性映射中的类型参数覆盖在 typedef 中提供的参数。"
 
 #. Tag: para
-#: basic_mapping.xml:2796
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Even though Hibernate's rich range of built-in types and support for "
 "components means you will rarely need to use a custom type, it is considered "
@@ -4989,20 +3618,18 @@
 msgstr ""
 "尽管 Hibernate 内建的丰富的类型和对组件的支持意味着你可能很少 <emphasis>需要"
 "</emphasis>使用自定义类型。不过,为那些在你的应用中经常出现的(非实体)类使用自"
-"定义类型也是一个好方法。例如,一个<literal>MonetaryAmount</literal>类使用"
-"<literal>CompositeUserType</literal>来映射是不错的选择,虽然他可以很容易地被"
+"定义类型也是一个好方法。例如,一个 <literal>MonetaryAmount</literal> 类使用 "
+"<literal>CompositeUserType</literal> 来映射是不错的选择,虽然他可以很容易地被"
 "映射成组件。这样做的动机之一是抽象。使用自定义类型,以后假若你改变表示金额的"
-"方法时,它可以保证映射文件不需要修改。"
+"方法时,它可以保证映射文件不需要修改。 "
 
 #. Tag: title
-#: basic_mapping.xml:2812
 #, no-c-format
 msgid "Mapping a class more than once"
 msgstr "多次映射同一个类"
 
 #. Tag: para
-#: basic_mapping.xml:2813
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to provide more than one mapping for a particular persistent "
 "class. In this case, you must specify an <emphasis>entity name</emphasis> to "
@@ -5011,53 +3638,27 @@
 "entity name when working with persistent objects, when writing queries, or "
 "when mapping associations to the named entity."
 msgstr ""
-"对特定的持久化类,映射多次是允许的。这种情形下,你必须指定<emphasis>entity "
-"name</emphasis>来区别不同映射实体的对象实例。(默认情况下,实体名字和类名是相"
-"同的。) Hibernate在操作持久化对象、编写查询条件,或者把关联映射到指定实体"
-"时,允许你指定这个entity name(实体名字)。"
+"对特定的持久化类,映射多次是允许的。这种情形下,你必须指定 <emphasis>entity "
+"name</emphasis> 来区别不同映射实体的对象实例。(默认情况下,实体名字和类名是"
+"相同的。) Hibernate 在操作持久化对象、编写查询条件,或者把关联映射到指定实体"
+"时,允许你指定这个 entity name(实体名字)。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2821
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Contract\" table=\"Contracts\"\n"
-"        entity-name=\"CurrentContract\">\n"
-"    ...\n"
-"    <set name=\"history\" inverse=\"true\"\n"
-"            order-by=\"effectiveEndDate desc\">\n"
-"        <key column=\"currentContractId\"/>\n"
-"        <one-to-many entity-name=\"HistoricalContract\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Contract\" table=\"ContractHistory\"\n"
-"        entity-name=\"HistoricalContract\">\n"
-"    ...\n"
-"    <many-to-one name=\"currentContract\"\n"
-"            column=\"currentContractId\"\n"
-"            entity-name=\"CurrentContract\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2823
-#, fuzzy, no-c-format
-msgid ""
 "Associations are now specified using <literal>entity-name</literal> instead "
 "of <literal>class</literal>."
 msgstr ""
-"注意这里关联是如何用<literal>entity-name</literal>来代替<literal>class</"
-"literal>的。"
+"注意这里关联是如何用 <literal>entity-name</literal> 来代替 <literal>class</"
+"literal> 的。 "
 
 #. Tag: title
-#: basic_mapping.xml:2831
 #, no-c-format
 msgid "SQL quoted identifiers"
-msgstr "SQL中引号包围的标识符"
+msgstr "SQL 中引号包围的标识符"
 
 #. Tag: para
-#: basic_mapping.xml:2832
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can force Hibernate to quote an identifier in the generated SQL by "
 "enclosing the table or column name in backticks in the mapping document. "
@@ -5065,48 +3666,32 @@
 "literal>. This is usually double quotes, but the SQL Server uses brackets "
 "and MySQL uses backticks."
 msgstr ""
-"你可通过在映射文档中使用反向引号(`)把表名或者字段名包围起来,以强制Hibernate"
-"在生成的SQL中把标识符用引号包围起来。Hibernate会使用相应的"
-"SQL<literal>Dialect</literal>(方言)来使用正确的引号风格(通常是双引号,但是在"
-"SQL Server中是括号,MySQL中是反向引号)。"
+"你可通过在映射文档中使用反向引号(`)把表名或者字段名包围起来,以强制 "
+"Hibernate 在生成的 SQL 中把标识符用引号包围起来。Hibernate 会使用相应的 "
+"SQL<literal>Dialect</literal>(方言)来使用正确的引号风格(通常是双引号,但是"
+"在 SQL Server 中是括号,MySQL 中是反向引号)。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2839
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"LineItem\" table=\"`Line Item`\">\n"
-"    <id name=\"id\" column=\"`Item Id`\"/><generator class=\"assigned\"/></"
-"id>\n"
-"    <property name=\"itemNumber\" column=\"`Item #`\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: basic_mapping.xml:2845
 #, no-c-format
 msgid "Metadata alternatives"
-msgstr "其他元数据(Metadata)"
+msgstr "其他元数据(Metadata)"
 
 #. Tag: para
-#: basic_mapping.xml:2847
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "XML does not suit all users so there are some alternative ways to define O/R "
 "mapping metadata in Hibernate."
 msgstr ""
-"XML 并不适用于所有人, 因此有其他定义Hibernate O/R 映射元数据(metadata)的方"
-"法。"
+"XML 并不适用于所有人, 因此有其他定义 Hibernate O/R 映射元数据(metadata)的方"
+"法。 "
 
 #. Tag: title
-#: basic_mapping.xml:2852
 #, no-c-format
 msgid "Using XDoclet markup"
 msgstr "使用 XDoclet 标记"
 
 #. Tag: para
-#: basic_mapping.xml:2854
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Many Hibernate users prefer to embed mapping information directly in "
 "sourcecode using XDoclet <literal>@hibernate.tags</literal>. We do not cover "
@@ -5114,136 +3699,23 @@
 "XDoclet. However, we include the following example of the <literal>Cat</"
 "literal> class with XDoclet mappings:"
 msgstr ""
-"很多Hibernate使用者更喜欢使用XDoclet<literal>@hibernate.tags</literal>将映射"
-"信息直接嵌入到源代码中。我们不会在本文档中涉及这个方法,因为严格说来,这属于"
-"XDoclet的一部分。然而,我们包含了如下使用XDoclet映射的<literal>Cat</literal>"
-"类的例子。"
+"很多 Hibernate 使用者更喜欢使用 XDoclet<literal>@hibernate.tags</literal> 将"
+"映射信息直接嵌入到源代码中。我们不会在本文档中涉及这个方法,因为严格说来,这"
+"属于 XDoclet 的一部分。然而,我们包含了如下使用 XDoclet 映射的 <literal>Cat</"
+"literal> 类的例子。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2861
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"import java.util.Date;\n"
-"\n"
-"/**\n"
-" * @hibernate.class\n"
-" *  table=\"CATS\"\n"
-" */\n"
-"public class Cat {\n"
-"    private Long id; // identifier\n"
-"    private Date birthdate;\n"
-"    private Cat mother;\n"
-"    private Set kittens\n"
-"    private Color color;\n"
-"    private char sex;\n"
-"    private float weight;\n"
-"\n"
-"    /*\n"
-"     * @hibernate.id\n"
-"     *  generator-class=\"native\"\n"
-"     *  column=\"CAT_ID\"\n"
-"     */\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"    private void setId(Long id) {\n"
-"        this.id=id;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.many-to-one\n"
-"     *  column=\"PARENT_ID\"\n"
-"     */\n"
-"    public Cat getMother() {\n"
-"        return mother;\n"
-"    }\n"
-"    void setMother(Cat mother) {\n"
-"        this.mother = mother;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"BIRTH_DATE\"\n"
-"     */\n"
-"    public Date getBirthdate() {\n"
-"        return birthdate;\n"
-"    }\n"
-"    void setBirthdate(Date date) {\n"
-"        birthdate = date;\n"
-"    }\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"WEIGHT\"\n"
-"     */\n"
-"    public float getWeight() {\n"
-"        return weight;\n"
-"    }\n"
-"    void setWeight(float weight) {\n"
-"        this.weight = weight;\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"COLOR\"\n"
-"     *  not-null=\"true\"\n"
-"     */\n"
-"    public Color getColor() {\n"
-"        return color;\n"
-"    }\n"
-"    void setColor(Color color) {\n"
-"        this.color = color;\n"
-"    }\n"
-"    /**\n"
-"     * @hibernate.set\n"
-"     *  inverse=\"true\"\n"
-"     *  order-by=\"BIRTH_DATE\"\n"
-"     * @hibernate.collection-key\n"
-"     *  column=\"PARENT_ID\"\n"
-"     * @hibernate.collection-one-to-many\n"
-"     */\n"
-"    public Set getKittens() {\n"
-"        return kittens;\n"
-"    }\n"
-"    void setKittens(Set kittens) {\n"
-"        this.kittens = kittens;\n"
-"    }\n"
-"    // addKitten not needed by Hibernate\n"
-"    public void addKitten(Cat kitten) {\n"
-"        kittens.add(kitten);\n"
-"    }\n"
-"\n"
-"    /**\n"
-"     * @hibernate.property\n"
-"     *  column=\"SEX\"\n"
-"     *  not-null=\"true\"\n"
-"     *  update=\"false\"\n"
-"     */\n"
-"    public char getSex() {\n"
-"        return sex;\n"
-"    }\n"
-"    void setSex(char sex) {\n"
-"        this.sex=sex;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2863
-#, fuzzy, no-c-format
 msgid "See the Hibernate website for more examples of XDoclet and Hibernate."
-msgstr "参考Hibernate网站更多的Xdoclet和Hibernate的例子"
+msgstr "参考 Hibernate 网站更多的 Xdoclet 和 Hibernate 的例子。"
 
 #. Tag: title
-#: basic_mapping.xml:2870
 #, no-c-format
 msgid "Using JDK 5.0 Annotations"
-msgstr "使用 JDK 5.0 的注解(Annotation)"
+msgstr "使用 JDK 5.0 的注解(Annotation)"
 
 #. Tag: para
-#: basic_mapping.xml:2872
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "JDK 5.0 introduced XDoclet-style annotations at the language level that are "
 "type-safe and checked at compile time. This mechanism is more powerful than "
@@ -5257,67 +3729,35 @@
 "Both EJB3 (JSR-220) and Hibernate3 metadata is supported."
 msgstr ""
 "JDK 5.0 在语言级别引入了 XDoclet 风格的标注,并且是类型安全的,在编译期进行检"
-"查。这一机制比XDoclet的注解更为强大,有更好的工具和IDE支持。例如, IntelliJ "
-"IDEA,支持JDK 5.0注解的自动完成和语法高亮 。EJB规范的新修订版(JSR-220)使用 "
-"JDK 5.0的注解作为entity beans的主要元数据(metadata)机制。Hibernate 3 实现了"
-"JSR-220 (the persistence API)的<literal>EntityManager</literal>,支持通过"
-"<emphasis>Hibernate Annotations</emphasis>包定义映射元数据。这个包作为单独的"
-"部分下载,支持EJB3 (JSR-220)和Hibernate3的元数据。"
+"查。这一机制比 XDoclet 的注解更为强大,有更好的工具和 IDE 支持。例如,"
+"IntelliJ IDEA,支持 JDK 5.0 注解的自动完成和语法高亮 。EJB 规范的新修订版 "
+"(JSR-220) 使用 JDK 5.0 的注解作为entity beans的主要元数据(metadata)机制。"
+"Hibernate 3 实现了JSR-220(the persistence API) 的 <literal>EntityManager</"
+"literal>,支持通过 <emphasis>Hibernate Annotations</emphasis> 包定义映射元数"
+"据。这个包作为单独的部分下载,支持 EJB3(JSR-220) 和 Hibernate3 的元数据。 "
 
 #. Tag: para
-#: basic_mapping.xml:2883
 #, no-c-format
 msgid "This is an example of a POJO class annotated as an EJB entity bean:"
-msgstr "这是一个被注解为EJB entity bean 的POJO类的例子"
+msgstr "这是一个被注解为 EJB entity bean 的 POJO 类的例子"
 
-#. Tag: programlisting
-#: basic_mapping.xml:2887
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[@Entity(access = AccessType.FIELD)\n"
-"public class Customer implements Serializable {\n"
-"\n"
-"    @Id;\n"
-"    Long id;\n"
-"\n"
-"    String firstName;\n"
-"    String lastName;\n"
-"    Date birthday;\n"
-"\n"
-"    @Transient\n"
-"    Integer age;\n"
-"\n"
-"    @Embedded\n"
-"    private Address homeAddress;\n"
-"\n"
-"    @OneToMany(cascade=CascadeType.ALL)\n"
-"    @JoinColumn(name=\"CUSTOMER_ID\")\n"
-"    Set<Order> orders;\n"
-"\n"
-"    // Getter/setter and business methods\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2891
-#, fuzzy, no-c-format
-msgid ""
 "Support for JDK 5.0 Annotations (and JSR-220) is currently under "
 "development. Please refer to the Hibernate Annotations module for more "
 "details."
 msgstr ""
-"注意:对 JDK 5.0 注解 (和 JSR-220)支持的工作仍然在进行中,并未完成。更多细节请"
-"参阅Hibernate Annotations 模块。"
+"注意:对 JDK 5.0 注解(和 JSR-220)支持的工作仍然在进行中,并未完成。更多细节请"
+"参阅 Hibernate Annotations 模块。 "
 
 #. Tag: title
-#: basic_mapping.xml:2901
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Generated properties"
-msgstr "数据库生成属性(Generated Properties)"
+msgstr "数据库生成属性(Generated Properties) "
 
 #. Tag: para
-#: basic_mapping.xml:2902
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Generated properties are properties that have their values generated by the "
 "database. Typically, Hibernate applications needed to <literal>refresh</"
@@ -5327,14 +3767,13 @@
 "an SQL INSERT or UPDATE for an entity that has defined generated properties, "
 "it immediately issues a select afterwards to retrieve the generated values."
 msgstr ""
-"Generated properties指的是其值由数据库生成的属性。一般来说,如果对象有任何属"
-"性由数据库生成值,Hibernate应用程序需要进行<literal>刷新(refresh)</literal>。"
-"但如果把属性标明为generated,就可以转由Hibernate来负责这个动作。实际上。对定"
-"义了generated properties的实体,每当Hibernate执行一条SQL INSERT或者UPDATE语"
-"句,会立刻执行一条select来获得生成的值。"
+"Generated properties 指的是其值由数据库生成的属性。一般来说,如果对象有任何属"
+"性由数据库生成值,Hibernate 应用程序需要进行<literal>刷新(refresh)</"
+"literal>。但如果把属性标明为 generated,就可以转由 Hibernate 来负责这个动作。"
+"实际上。对定义了 generated properties 的实体,每当 Hibernate 执行一条 SQL "
+"INSERT 或者 UPDATE 语句,会立刻执行一条 select 来获得生成的值。 "
 
 #. Tag: para
-#: basic_mapping.xml:2911
 #, fuzzy, no-c-format
 msgid ""
 "Properties marked as generated must additionally be non-insertable and non-"
@@ -5343,22 +3782,20 @@
 "and <link linkend=\"mapping-declaration-property\">simple properties</link>, "
 "can be marked as generated."
 msgstr ""
-"被标明为generated的属性还必须是 non-insertable和 non-updateable的。只有<xref "
-"linkend=\"mapping-declaration-version\">versions</xref>,<xref linkend="
-"\"mapping-declaration-timestamp\">timestamps</xref>和<xref linkend=\"mapping-"
-"declaration-property\">简单属性(simple properties)</xref>可以被标明为"
-"generated。"
+"被标明为 generated 的属性还必须是 non-insertable 和 non-updateable 的。只有 "
+"<xref linkend=\"mapping-declaration-version\"/> versions、<xref linkend="
+"\"mapping-declaration-timestamp\"/> timestamp 和 <xref linkend=\"mapping-"
+"declaration-property\"/> 简单属性(simple properties)可以被标明为 "
+"generated。 "
 
 #. Tag: para
-#: basic_mapping.xml:2918
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>never</literal> (the default): the given property value is not "
 "generated within the database."
-msgstr "<literal>never</literal> (默认) 标明此属性值不是从数据库中生成。"
+msgstr "<literal>never</literal>(默认)标明此属性值不是从数据库中生成。 "
 
 #. Tag: para
-#: basic_mapping.xml:2922
 #, fuzzy, no-c-format
 msgid ""
 "<literal>insert</literal>: the given property value is generated on insert, "
@@ -5368,29 +3805,71 @@
 "\">timestamp</link> properties can be marked as generated, this option is "
 "not available."
 msgstr ""
-"<literal>insert</literal> - 标明此属性值在insert的时候生成,但是不会在随后的"
-"update时重新生成。比如说创建日期就归属于这类。注意虽然<xref linkend="
-"\"mapping-declaration-version\">version</xref>和<xref linkend=\"mapping-"
-"declaration-timestamp\">timestamp</xref>属性可以被标注为generated,但是不适用"
-"这个选项..."
+"<literal>insert</literal> — 标明此属性值在 insert 的时候生成,但是不会在随后"
+"的 update 时重新生成。比如说创建日期就归属于这类。注意虽然 <xref linkend="
+"\"mapping-declaration-version\"/> version 和 <xref linkend=\"mapping-"
+"declaration-timestamp\"/> timestamp 属性可以被标注为 generated,但是不适用这"
+"个选项... "
 
 #. Tag: para
-#: basic_mapping.xml:2930
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>always</literal>: the property value is generated both on insert "
 "and on update."
-msgstr "<literal>always</literal> - 标明此属性值在insert和update时都会被生成。"
+msgstr ""
+"<literal>always</literal> — 标明此属性值在 insert 和 update 时都会被生成。 "
 
 #. Tag: title
-#: basic_mapping.xml:2937
-#, fuzzy, no-c-format
+#, no-c-format
+msgid "Column read and write expressions"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Hibernate allows you to customize the SQL it uses to read and write the "
+"values of columns mapped to <link linkend=\"mapping-declaration-property"
+"\">simple properties</link>. For example, if your database provides a set of "
+"data encryption functions, you can invoke them for individual columns like "
+"this: <programlisting role=\"XML\">&lt;property name=\"creditCardNumber"
+"\"&gt; &lt;column name=\"credit_card_num\" read=\"decrypt(credit_card_num)\" "
+"write=\"encrypt(?)\"/&gt; &lt;/property&gt;</programlisting>"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Hibernate applies the custom expressions automatically whenever the property "
+"is referenced in a query. This functionality is similar to a derived-"
+"property <literal>formula</literal> with two differences:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"The property is backed by one or more columns that are exported as part of "
+"automatic schema generation."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "The property is read-write, not read-only."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"The <literal>write</literal> expression, if specified, must contain exactly "
+"one '?' placeholder for the value."
+msgstr ""
+
+#. Tag: title
+#, no-c-format
 msgid "Auxiliary database objects"
-msgstr "辅助数据库对象(Auxiliary Database Objects)"
+msgstr "辅助数据库对象(Auxiliary Database Objects) "
 
 #. Tag: para
-#: basic_mapping.xml:2938
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Auxiliary database objects allow for the CREATE and DROP of arbitrary "
 "database objects. In conjunction with Hibernate's schema evolution tools, "
@@ -5401,140 +3880,1729 @@
 "example, ALTERs, INSERTS, etc.). There are essentially two modes for "
 "defining auxiliary database objects:"
 msgstr ""
-"Allows CREATE and DROP of arbitrary database objects, in conjunction with "
-"Hibernate's schema evolution tools, to provide the ability to fully define a "
-"user schema within the Hibernate mapping files. Although designed "
-"specifically for creating and dropping things like triggers or stored "
-"procedures, really any SQL command that can be run via a <literal>java.sql."
-"Statement.execute()</literal> method is valid here (ALTERs, INSERTS, etc). "
-"There are essentially two modes for defining auxiliary database objects... 帮"
-"助CREATE和DROP任意数据库对象,与Hibernate的schema交互工具组合起来,可以提供在"
-"Hibernate映射文件中完全定义用户schema的能力。虽然这是为创建和销毁trigger(触发"
-"器)或stored procedure(存储过程)等特别设计的,实际上任何可以在<literal>java."
-"sql.Statement.execute()</literal>方法中执行的SQL命令都可以在此使用(比如"
-"ALTER, INSERT,等等)。本质上有两种模式来定义辅助数据库对象..."
+"允许 CREATE 和 DROP 任意数据库对象,与 Hibernate 的 schema 交互工具组合起来,"
+"可以提供在 Hibernate 映射文件中完全定义用户 schema 的能力。虽然这是为创建和销"
+"毁 trigger(触发器)或stored procedure(存储过程)等特别设计的,实际上任何可"
+"以在 <literal>java.sql.Statement.execute()</literal> 方法中执行的 SQL 命令都"
+"可以在此使用(比如ALTER, INSERT,等等)。本质上有两种模式来定义辅助数据库对"
+"象... "
 
 #. Tag: para
-#: basic_mapping.xml:2947
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The first mode is to explicitly list the CREATE and DROP commands in the "
 "mapping file:"
-msgstr "第一种模式是在映射文件中显式声明CREATE和DROP命令:"
+msgstr "第一种模式是在映射文件中显式声明 CREATE 和 DROP 命令: "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2951
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <create>CREATE TRIGGER my_trigger ...</create>\n"
-"        <drop>DROP TRIGGER my_trigger</drop>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2952
-#, fuzzy, no-c-format
-msgid ""
 "The second mode is to supply a custom class that constructs the CREATE and "
 "DROP commands. This custom class must implement the <literal>org.hibernate."
 "mapping.AuxiliaryDatabaseObject</literal> interface."
 msgstr ""
-"第二种模式是提供一个类,这个类知道如何组织CREATE和DROP命令。这个特别类必须实"
-"现<literal>org.hibernate.mapping.AuxiliaryDatabaseObject</literal>接口。"
+"第二种模式是提供一个类,这个类知道如何组织 CREATE 和 DROP 命令。这个特别类必"
+"须实现 <literal>org.hibernate.mapping.AuxiliaryDatabaseObject</literal> 接"
+"口。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2957
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <definition class=\"MyTriggerDefinition\"/>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: basic_mapping.xml:2958
-#, fuzzy, no-c-format
-msgid ""
 "Additionally, these database objects can be optionally scoped so that they "
 "only apply when certain dialects are used."
-msgstr "还有,这些数据库对象可以特别指定为仅在特定的方言中才使用。"
+msgstr "还有,这些数据库对象可以特别指定为仅在特定的方言中才使用。 "
 
-#. Tag: programlisting
-#: basic_mapping.xml:2962
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    ...\n"
-"    <database-object>\n"
-"        <definition class=\"MyTriggerDefinition\"/>\n"
-"        <dialect-scope name=\"org.hibernate.dialect.Oracle9iDialect\"/>\n"
-"        <dialect-scope name=\"org.hibernate.dialect.Oracle10gDialect\"/>\n"
-"    </database-object>\n"
-"</hibernate-mapping>]]>"
-msgstr ""
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "      \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "          \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"
+#~ "\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "        <class name=\"Cat\"\n"
+#~ "            table=\"cats\"\n"
+#~ "            discriminator-value=\"C\">\n"
+#~ "\n"
+#~ "                <id name=\"id\">\n"
+#~ "                        <generator class=\"native\"/>\n"
+#~ "                </id>\n"
+#~ "\n"
+#~ "                <discriminator column=\"subclass\"\n"
+#~ "                     type=\"character\"/>\n"
+#~ "\n"
+#~ "                <property name=\"weight\"/>\n"
+#~ "\n"
+#~ "                <property name=\"birthdate\"\n"
+#~ "                    type=\"date\"\n"
+#~ "                    not-null=\"true\"\n"
+#~ "                    update=\"false\"/>\n"
+#~ "\n"
+#~ "                <property name=\"color\"\n"
+#~ "                    type=\"eg.types.ColorUserType\"\n"
+#~ "                    not-null=\"true\"\n"
+#~ "                    update=\"false\"/>\n"
+#~ "\n"
+#~ "                <property name=\"sex\"\n"
+#~ "                    not-null=\"true\"\n"
+#~ "                    update=\"false\"/>\n"
+#~ "\n"
+#~ "                <property name=\"litterId\"\n"
+#~ "                    column=\"litterId\"\n"
+#~ "                    update=\"false\"/>\n"
+#~ "\n"
+#~ "                <many-to-one name=\"mother\"\n"
+#~ "                    column=\"mother_id\"\n"
+#~ "                    update=\"false\"/>\n"
+#~ "\n"
+#~ "                <set name=\"kittens\"\n"
+#~ "                    inverse=\"true\"\n"
+#~ "                    order-by=\"litter_id\">\n"
+#~ "                        <key column=\"mother_id\"/>\n"
+#~ "                        <one-to-many class=\"Cat\"/>\n"
+#~ "                </set>\n"
+#~ "\n"
+#~ "                <subclass name=\"DomesticCat\"\n"
+#~ "                    discriminator-value=\"D\">\n"
+#~ "\n"
+#~ "                        <property name=\"name\"\n"
+#~ "                            type=\"string\"/>\n"
+#~ "\n"
+#~ "                </subclass>\n"
+#~ "\n"
+#~ "        </class>\n"
+#~ "\n"
+#~ "        <class name=\"Dog\">\n"
+#~ "                <!-- mapping for Dog could go here -->\n"
+#~ "        </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "      \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "          \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"
+#~ "\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "        <class name=\"Cat\"\n"
+#~ "            table=\"cats\"\n"
+#~ "            discriminator-value=\"C\">\n"
+#~ "\n"
+#~ "                <id name=\"id\">\n"
+#~ "                        <generator class=\"native\"/>\n"
+#~ "                </id>\n"
+#~ "\n"
+#~ "                <discriminator column=\"subclass\"\n"
+#~ "                     type=\"character\"/>\n"
+#~ "\n"
+#~ "                <property name=\"weight\"/>\n"
+#~ "\n"
+#~ "                <property name=\"birthdate\"\n"
+#~ "                    type=\"date\"\n"
+#~ "                    not-null=\"true\"\n"
+#~ "                    update=\"false\"/>\n"
+#~ "\n"
+#~ "                <property name=\"color\"\n"
+#~ "                    type=\"eg.types.ColorUserType\"\n"
+#~ "                    not-null=\"true\"\n"
+#~ "                    update=\"false\"/>\n"
+#~ "\n"
+#~ "                <property name=\"sex\"\n"
+#~ "                    not-null=\"true\"\n"
+#~ "                    update=\"false\"/>\n"
+#~ "\n"
+#~ "                <property name=\"litterId\"\n"
+#~ "                    column=\"litterId\"\n"
+#~ "                    update=\"false\"/>\n"
+#~ "\n"
+#~ "                <many-to-one name=\"mother\"\n"
+#~ "                    column=\"mother_id\"\n"
+#~ "                    update=\"false\"/>\n"
+#~ "\n"
+#~ "                <set name=\"kittens\"\n"
+#~ "                    inverse=\"true\"\n"
+#~ "                    order-by=\"litter_id\">\n"
+#~ "                        <key column=\"mother_id\"/>\n"
+#~ "                        <one-to-many class=\"Cat\"/>\n"
+#~ "                </set>\n"
+#~ "\n"
+#~ "                <subclass name=\"DomesticCat\"\n"
+#~ "                    discriminator-value=\"D\">\n"
+#~ "\n"
+#~ "                        <property name=\"name\"\n"
+#~ "                            type=\"string\"/>\n"
+#~ "\n"
+#~ "                </subclass>\n"
+#~ "\n"
+#~ "        </class>\n"
+#~ "\n"
+#~ "        <class name=\"Dog\">\n"
+#~ "                <!-- mapping for Dog could go here -->\n"
+#~ "        </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 
 #~ msgid ""
-#~ "<literal>type</literal> (optional): A name that indicates the Hibernate "
-#~ "type."
-#~ msgstr "<literal>type</literal> (可选): 标识Hibernate类型的名字。"
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\" [\n"
+#~ "    <!ENTITY types SYSTEM \"classpath://your/domain/types.xml\">\n"
+#~ "]>\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"your.domain\">\n"
+#~ "    <class name=\"MyEntity\">\n"
+#~ "        <id name=\"id\" type=\"my-custom-id-type\">\n"
+#~ "            ...\n"
+#~ "        </id>\n"
+#~ "    <class>\n"
+#~ "    &types;\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\" [\n"
+#~ "    <!ENTITY types SYSTEM \"classpath://your/domain/types.xml\">\n"
+#~ "]>\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"your.domain\">\n"
+#~ "    <class name=\"MyEntity\">\n"
+#~ "        <id name=\"id\" type=\"my-custom-id-type\">\n"
+#~ "            ...\n"
+#~ "        </id>\n"
+#~ "    <class>\n"
+#~ "    &types;\n"
+#~ "</hibernate-mapping>]]>"
 
 #~ msgid ""
-#~ "<literal>cascade</literal> (optional): Specifies which operations should "
-#~ "be cascaded from the parent object to the associated object."
+#~ "<![CDATA[<hibernate-mapping\n"
+#~ "         schema=\"schemaName\"\n"
+#~ "         catalog=\"catalogName\"\n"
+#~ "         default-cascade=\"cascade_style\"\n"
+#~ "         default-access=\"field|property|ClassName\"\n"
+#~ "         default-lazy=\"true|false\"\n"
+#~ "         auto-import=\"true|false\"\n"
+#~ "         package=\"package.name\"\n"
+#~ " />]]>"
 #~ msgstr ""
-#~ "<literal>cascade(级联)</literal> (可选): 指明哪些操作会从父对象级联到关"
-#~ "联的对象。"
+#~ "<![CDATA[<hibernate-mapping\n"
+#~ "         schema=\"schemaName\"\n"
+#~ "         catalog=\"catalogName\"\n"
+#~ "         default-cascade=\"cascade_style\"\n"
+#~ "         default-access=\"field|property|ClassName\"\n"
+#~ "         default-lazy=\"true|false\"\n"
+#~ "         auto-import=\"true|false\"\n"
+#~ "         package=\"package.name\"\n"
+#~ " />]]>"
 
 #~ msgid ""
-#~ "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
-#~ "literal>): Specifies that updates to this property do or do not require "
-#~ "acquisition of the optimistic lock. In other words, dertermines if a "
-#~ "version increment should occur when this property is dirty."
+#~ "<![CDATA[<class\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        table=\"tableName\"\n"
+#~ "        discriminator-value=\"discriminator_value\"\n"
+#~ "        mutable=\"true|false\"\n"
+#~ "        schema=\"owner\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        select-before-update=\"true|false\"\n"
+#~ "        polymorphism=\"implicit|explicit\"\n"
+#~ "        where=\"arbitrary sql where condition\"\n"
+#~ "        persister=\"PersisterClass\"\n"
+#~ "        batch-size=\"N\"\n"
+#~ "        optimistic-lock=\"none|version|dirty|all\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        check=\"arbitrary sql check condition\"\n"
+#~ "        rowid=\"rowid\"\n"
+#~ "        subselect=\"SQL expression\"\n"
+#~ "        abstract=\"true|false\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "/>]]>"
 #~ msgstr ""
-#~ "<literal>optimistic-lock</literal> (可选 - 默认为 <literal>true</"
-#~ "literal>): 指定这个属性在做更新时是否需要获得乐观锁定(optimistic "
-#~ "lock)。 换句话说,它决定这个属性发生脏数据时版本(version)的值是否增长。"
+#~ "<![CDATA[<class\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        table=\"tableName\"\n"
+#~ "        discriminator-value=\"discriminator_value\"\n"
+#~ "        mutable=\"true|false\"\n"
+#~ "        schema=\"owner\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        select-before-update=\"true|false\"\n"
+#~ "        polymorphism=\"implicit|explicit\"\n"
+#~ "        where=\"arbitrary sql where condition\"\n"
+#~ "        persister=\"PersisterClass\"\n"
+#~ "        batch-size=\"N\"\n"
+#~ "        optimistic-lock=\"none|version|dirty|all\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        check=\"arbitrary sql check condition\"\n"
+#~ "        rowid=\"rowid\"\n"
+#~ "        subselect=\"SQL expression\"\n"
+#~ "        abstract=\"true|false\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "/>]]>"
 
 #~ msgid ""
-#~ "To understand the behaviour of various Java language-level objects with "
-#~ "respect to the persistence service, we need to classify them into two "
-#~ "groups:"
+#~ "<![CDATA[<class name=\"Summary\">\n"
+#~ "    <subselect>\n"
+#~ "        select item.name, max(bid.amount), count(*)\n"
+#~ "        from item\n"
+#~ "        join bid on bid.item_id = item.id\n"
+#~ "        group by item.name\n"
+#~ "    </subselect>\n"
+#~ "    <synchronize table=\"item\"/>\n"
+#~ "    <synchronize table=\"bid\"/>\n"
+#~ "    <id name=\"name\"/>\n"
+#~ "    ...\n"
+#~ "</class>]]>"
 #~ msgstr ""
-#~ "为了理解很多与持久化服务相关的Java语言级对象的行为,我们需要把它们分为两"
-#~ "类:"
+#~ "<![CDATA[<class name=\"Summary\">\n"
+#~ "    <subselect>\n"
+#~ "        select item.name, max(bid.amount), count(*)\n"
+#~ "        from item\n"
+#~ "        join bid on bid.item_id = item.id\n"
+#~ "        group by item.name\n"
+#~ "    </subselect>\n"
+#~ "    <synchronize table=\"item\"/>\n"
+#~ "    <synchronize table=\"bid\"/>\n"
+#~ "    <id name=\"name\"/>\n"
+#~ "    ...\n"
+#~ "</class>]]>"
 
+#~ msgid ""
+#~ "<![CDATA[<id\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        type=\"typename\"\n"
+#~ "        column=\"column_name\"\n"
+#~ "        unsaved-value=\"null|any|none|undefined|id_value\"\n"
+#~ "        access=\"field|property|ClassName\">\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "\n"
+#~ "        <generator class=\"generatorClass\"/>\n"
+#~ "</id>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<id\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        type=\"typename\"\n"
+#~ "        column=\"column_name\"\n"
+#~ "        unsaved-value=\"null|any|none|undefined|id_value\"\n"
+#~ "        access=\"field|property|ClassName\">\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "\n"
+#~ "        <generator class=\"generatorClass\"/>\n"
+#~ "</id>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
+#~ "        <generator class=\"org.hibernate.id.TableHiLoGenerator\">\n"
+#~ "                <param name=\"table\">uid_table</param>\n"
+#~ "                <param name=\"column\">next_hi_value_column</param>\n"
+#~ "        </generator>\n"
+#~ "</id>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
+#~ "        <generator class=\"org.hibernate.id.TableHiLoGenerator\">\n"
+#~ "                <param name=\"table\">uid_table</param>\n"
+#~ "                <param name=\"column\">next_hi_value_column</param>\n"
+#~ "        </generator>\n"
+#~ "</id>]]>"
+
+#~ msgid "increment"
+#~ msgstr "increment"
+
+#~ msgid "identity"
+#~ msgstr "identity"
+
+#~ msgid "sequence"
+#~ msgstr "sequence"
+
+#~ msgid "hilo"
+#~ msgstr "hilo"
+
+#~ msgid "seqhilo"
+#~ msgstr "seqhilo"
+
+#~ msgid "guid"
+#~ msgstr "guid"
+
+#~ msgid "native"
+#~ msgstr "native"
+
+#~ msgid "assigned"
+#~ msgstr "assigned"
+
+#~ msgid "select"
+#~ msgstr "select"
+
+#~ msgid "foreign"
+#~ msgstr "foreign"
+
+#~ msgid ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
+#~ "        <generator class=\"hilo\">\n"
+#~ "                <param name=\"table\">hi_value</param>\n"
+#~ "                <param name=\"column\">next_value</param>\n"
+#~ "                <param name=\"max_lo\">100</param>\n"
+#~ "        </generator>\n"
+#~ "</id>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
+#~ "        <generator class=\"hilo\">\n"
+#~ "                <param name=\"table\">hi_value</param>\n"
+#~ "                <param name=\"column\">next_value</param>\n"
+#~ "                <param name=\"max_lo\">100</param>\n"
+#~ "        </generator>\n"
+#~ "</id>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
+#~ "        <generator class=\"seqhilo\">\n"
+#~ "                <param name=\"sequence\">hi_value</param>\n"
+#~ "                <param name=\"max_lo\">100</param>\n"
+#~ "        </generator>\n"
+#~ "</id>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"cat_id\">\n"
+#~ "        <generator class=\"seqhilo\">\n"
+#~ "                <param name=\"sequence\">hi_value</param>\n"
+#~ "                <param name=\"max_lo\">100</param>\n"
+#~ "        </generator>\n"
+#~ "</id>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
+#~ "        <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">person_id_sequence</param>\n"
+#~ "        </generator>\n"
+#~ "</id>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
+#~ "        <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">person_id_sequence</param>\n"
+#~ "        </generator>\n"
+#~ "</id>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\" unsaved-value="
+#~ "\"0\">\n"
+#~ "        <generator class=\"identity\"/>\n"
+#~ "</id>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\" unsaved-value="
+#~ "\"0\">\n"
+#~ "        <generator class=\"identity\"/>\n"
+#~ "</id>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
+#~ "        <generator class=\"select\">\n"
+#~ "                <param name=\"key\">socialSecurityNumber</param>\n"
+#~ "        </generator>\n"
+#~ "</id>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<id name=\"id\" type=\"long\" column=\"person_id\">\n"
+#~ "        <generator class=\"select\">\n"
+#~ "                <param name=\"key\">socialSecurityNumber</param>\n"
+#~ "        </generator>\n"
+#~ "</id>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<composite-id\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        mapped=\"true|false\"\n"
+#~ "        access=\"field|property|ClassName\">\n"
+#~ "        node=\"element-name|.\"\n"
+#~ "\n"
+#~ "        <key-property name=\"propertyName\" type=\"typename\" column="
+#~ "\"column_name\"/>\n"
+#~ "        <key-many-to-one name=\"propertyName class=\"ClassName\" column="
+#~ "\"column_name\"/>\n"
+#~ "        ......\n"
+#~ "</composite-id>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<composite-id\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        mapped=\"true|false\"\n"
+#~ "        access=\"field|property|ClassName\">\n"
+#~ "        node=\"element-name|.\"\n"
+#~ "\n"
+#~ "        <key-property name=\"propertyName\" type=\"typename\" column="
+#~ "\"column_name\"/>\n"
+#~ "        <key-many-to-one name=\"propertyName class=\"ClassName\" column="
+#~ "\"column_name\"/>\n"
+#~ "        ......\n"
+#~ "</composite-id>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<composite-id>\n"
+#~ "        <key-property name=\"medicareNumber\"/>\n"
+#~ "        <key-property name=\"dependent\"/>\n"
+#~ "</composite-id>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<composite-id>\n"
+#~ "        <key-property name=\"medicareNumber\"/>\n"
+#~ "        <key-property name=\"dependent\"/>\n"
+#~ "</composite-id>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<composite-id class=\"MedicareId\" mapped=\"true\">\n"
+#~ "        <key-property name=\"medicareNumber\"/>\n"
+#~ "        <key-property name=\"dependent\"/>\n"
+#~ "</composite-id>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<composite-id class=\"MedicareId\" mapped=\"true\">\n"
+#~ "        <key-property name=\"medicareNumber\"/>\n"
+#~ "        <key-property name=\"dependent\"/>\n"
+#~ "</composite-id>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<discriminator\n"
+#~ "        column=\"discriminator_column\"\n"
+#~ "        type=\"discriminator_type\"\n"
+#~ "        force=\"true|false\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        formula=\"arbitrary sql expression\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<discriminator\n"
+#~ "        column=\"discriminator_column\"\n"
+#~ "        type=\"discriminator_type\"\n"
+#~ "        force=\"true|false\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        formula=\"arbitrary sql expression\"\n"
+#~ "/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<discriminator\n"
+#~ "    formula=\"case when CLASS_TYPE in ('a', 'b', 'c') then 0 else 1 end"
+#~ "\"\n"
+#~ "    type=\"integer\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<discriminator\n"
+#~ "    formula=\"case when CLASS_TYPE in ('a', 'b', 'c') then 0 else 1 end"
+#~ "\"\n"
+#~ "    type=\"integer\"/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<version\n"
+#~ "        column=\"version_column\"\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        type=\"typename\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        unsaved-value=\"null|negative|undefined\"\n"
+#~ "        generated=\"never|always\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<version\n"
+#~ "        column=\"version_column\"\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        type=\"typename\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        unsaved-value=\"null|negative|undefined\"\n"
+#~ "        generated=\"never|always\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<timestamp\n"
+#~ "        column=\"timestamp_column\"\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        unsaved-value=\"null|undefined\"\n"
+#~ "        source=\"vm|db\"\n"
+#~ "        generated=\"never|always\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<timestamp\n"
+#~ "        column=\"timestamp_column\"\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        unsaved-value=\"null|undefined\"\n"
+#~ "        source=\"vm|db\"\n"
+#~ "        generated=\"never|always\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<property\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        column=\"column_name\"\n"
+#~ "        type=\"typename\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        formula=\"arbitrary SQL expression\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        generated=\"never|insert|always\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "        index=\"index_name\"\n"
+#~ "        unique_key=\"unique_key_id\"\n"
+#~ "        length=\"L\"\n"
+#~ "        precision=\"P\"\n"
+#~ "        scale=\"S\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<property\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        column=\"column_name\"\n"
+#~ "        type=\"typename\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        formula=\"arbitrary SQL expression\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        generated=\"never|insert|always\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "        index=\"index_name\"\n"
+#~ "        unique_key=\"unique_key_id\"\n"
+#~ "        length=\"L\"\n"
+#~ "        precision=\"P\"\n"
+#~ "        scale=\"S\"\n"
+#~ "/>]]>"
+
 #, fuzzy
-#~ msgid "<literal>class</literal>"
-#~ msgstr "<literal>all(全部)</literal> 检查全部字段"
+#~ msgid ""
+#~ "<![CDATA[\n"
+#~ "<property name=\"totalPrice\"\n"
+#~ "    formula=\"( SELECT SUM (li.quantity*p.price) FROM LineItem li, "
+#~ "Product p\n"
+#~ "                WHERE li.productId = p.productId\n"
+#~ "                AND li.customerId = customerId\n"
+#~ "                AND li.orderNumber = orderNumber )\"/>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"totalPrice\"\n"
+#~ "    formula=\"( SELECT SUM (li.quantity*p.price) FROM LineItem li, "
+#~ "Product p\n"
+#~ "                WHERE li.productId = p.productId\n"
+#~ "                AND li.customerId = customerId\n"
+#~ "                AND li.orderNumber = orderNumber )\"/&gt;"
 
-#~ msgid "id"
-#~ msgstr "id"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        column=\"column_name\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        cascade=\"cascade_style\"\n"
+#~ "        fetch=\"join|select\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        property-ref=\"propertyNameFromAssociatedClass\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        lazy=\"proxy|no-proxy|false\"\n"
+#~ "        not-found=\"ignore|exception\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        formula=\"arbitrary SQL expression\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "        embed-xml=\"true|false\"\n"
+#~ "        index=\"index_name\"\n"
+#~ "        unique_key=\"unique_key_id\"\n"
+#~ "        foreign-key=\"foreign_key_name\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        column=\"column_name\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        cascade=\"cascade_style\"\n"
+#~ "        fetch=\"join|select\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        property-ref=\"propertyNameFromAssociatedClass\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        lazy=\"proxy|no-proxy|false\"\n"
+#~ "        not-found=\"ignore|exception\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        formula=\"arbitrary SQL expression\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "        embed-xml=\"true|false\"\n"
+#~ "        index=\"index_name\"\n"
+#~ "        unique_key=\"unique_key_id\"\n"
+#~ "        foreign-key=\"foreign_key_name\"\n"
+#~ "/&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal>none</"
-#~ "literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers"
-#~ "\"/>"
+#~ "<![CDATA[<many-to-one name=\"product\" class=\"Product\" column="
+#~ "\"PRODUCT_ID\"/>]]>"
 #~ msgstr ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal>none</"
-#~ "literal>): See <xref linkend=\"mapping-declaration-id-enhanced-optimizers"
-#~ "\"/>"
+#~ "&lt;many-to-one name=\"product\" class=\"Product\" column=\"PRODUCT_ID\"/"
+#~ "&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal/>): See "
-#~ "<xref linkend=\"mapping-declaration-id-enhanced-optimizers\"/>"
+#~ "<![CDATA[<property name=\"serialNumber\" unique=\"true\" type=\"string\" "
+#~ "column=\"SERIAL_NUMBER\"/>]]>"
 #~ msgstr ""
-#~ "<literal>optimizer</literal> (optional, defaults to <literal/>): See "
-#~ "<xref linkend=\"mapping-declaration-id-enhanced-optimizers\"/>"
+#~ "&lt;property name=\"serialNumber\" unique=\"true\" type=\"string\" column="
+#~ "\"SERIAL_NUMBER\"/&gt;"
 
-#~ msgid "key"
-#~ msgstr "é”®(key)"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"product\" property-ref=\"serialNumber\" "
+#~ "column=\"PRODUCT_SERIAL_NUMBER\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"product\" property-ref=\"serialNumber\" column="
+#~ "\"PRODUCT_SERIAL_NUMBER\"/&gt;"
 
-#~ msgid "any"
-#~ msgstr "any"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"owner\" property-ref=\"identity.ssn\" column="
+#~ "\"OWNER_SSN\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"owner\" property-ref=\"identity.ssn\" column="
+#~ "\"OWNER_SSN\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<one-to-one\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        cascade=\"cascade_style\"\n"
+#~ "        constrained=\"true|false\"\n"
+#~ "        fetch=\"join|select\"\n"
+#~ "        property-ref=\"propertyNameFromAssociatedClass\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        formula=\"any SQL expression\"\n"
+#~ "        lazy=\"proxy|no-proxy|false\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "        embed-xml=\"true|false\"\n"
+#~ "        foreign-key=\"foreign_key_name\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "&lt;one-to-one\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        cascade=\"cascade_style\"\n"
+#~ "        constrained=\"true|false\"\n"
+#~ "        fetch=\"join|select\"\n"
+#~ "        property-ref=\"propertyNameFromAssociatedClass\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        formula=\"any SQL expression\"\n"
+#~ "        lazy=\"proxy|no-proxy|false\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name|@attribute-name|element/@attribute|.\"\n"
+#~ "        embed-xml=\"true|false\"\n"
+#~ "        foreign-key=\"foreign_key_name\"\n"
+#~ "/&gt;"
+
+#, fuzzy
+#~ msgid "<![CDATA[<one-to-one name=\"person\" class=\"Person\"/>]]>"
+#~ msgstr "&lt;one-to-one name=\"person\" class=\"Person\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" constrained="
+#~ "\"true\"/>]]>"
+#~ msgstr ""
+#~ "&lt;one-to-one name=\"employee\" class=\"Employee\" constrained=\"true\"/"
+#~ "&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"person\" table=\"PERSON\">\n"
+#~ "    <id name=\"id\" column=\"PERSON_ID\">\n"
+#~ "        <generator class=\"foreign\">\n"
+#~ "            <param name=\"property\">employee</param>\n"
+#~ "        </generator>\n"
+#~ "    </id>\n"
+#~ "    ...\n"
+#~ "    <one-to-one name=\"employee\"\n"
+#~ "        class=\"Employee\"\n"
+#~ "        constrained=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"person\" table=\"PERSON\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"PERSON_ID\"&gt;\n"
+#~ "        &lt;generator class=\"foreign\"&gt;\n"
+#~ "            &lt;param name=\"property\"&gt;employee&lt;/param&gt;\n"
+#~ "        &lt;/generator&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;one-to-one name=\"employee\"\n"
+#~ "        class=\"Employee\"\n"
+#~ "        constrained=\"true\"/&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"person\" class=\"Person\" column=\"PERSON_ID"
+#~ "\" unique=\"true\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"person\" class=\"Person\" column=\"PERSON_ID\" "
+#~ "unique=\"true\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<one-to-one name=\"employee\" class=\"Employee\" property-ref="
+#~ "\"person\"/>]]>"
+#~ msgstr ""
+#~ "&lt;one-to-one name\"employee\" class=\"Employee\" property-ref=\"person"
+#~ "\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<natural-id mutable=\"true|false\"/>\n"
+#~ "        <property ... />\n"
+#~ "        <many-to-one ... />\n"
+#~ "        ......\n"
+#~ "</natural-id>]]>"
+#~ msgstr ""
+#~ "&lt;natural-id mutable=\"true|false\"/&gt;\n"
+#~ "        &lt;property ... /&gt;\n"
+#~ "        &lt;many-to-one ... /&gt;\n"
+#~ "        ......\n"
+#~ "&lt;/natural-id&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<component\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        class=\"className\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        node=\"element-name|.\"\n"
+#~ ">\n"
+#~ "\n"
+#~ "        <property ...../>\n"
+#~ "        <many-to-one .... />\n"
+#~ "        ........\n"
+#~ "</component>]]>"
+#~ msgstr ""
+#~ "&lt;component \n"
+#~ "        name=\"propertyName\" \n"
+#~ "        class=\"className\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        node=\"element-name|.\"\n"
+#~ "&gt;\n"
+#~ "        \n"
+#~ "        &lt;property ...../&gt;\n"
+#~ "        &lt;many-to-one .... /&gt;\n"
+#~ "        ........\n"
+#~ "&lt;/component&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<properties\n"
+#~ "        name=\"logicalName\"\n"
+#~ "        insert=\"true|false\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ ">\n"
+#~ "\n"
+#~ "        <property ...../>\n"
+#~ "        <many-to-one .... />\n"
+#~ "        ........\n"
+#~ "</properties>]]>"
+#~ msgstr ""
+#~ "&lt;properties \n"
+#~ "        name=\"logicalName\" \n"
+#~ "        insert=\"true|false\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "&gt;\n"
+#~ "        \n"
+#~ "        &lt;property ...../&gt;\n"
+#~ "        &lt;many-to-one .... /&gt;\n"
+#~ "        ........\n"
+#~ "&lt;/properties&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"personNumber\"/>\n"
+#~ "\n"
+#~ "    ...\n"
+#~ "    <properties name=\"name\"\n"
+#~ "            unique=\"true\" update=\"false\">\n"
+#~ "        <property name=\"firstName\"/>\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"lastName\"/>\n"
+#~ "    </properties>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"personNumber\"/&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;properties name=\"name\" \n"
+#~ "            unique=\"true\" update=\"false\"&gt;\n"
+#~ "        &lt;property name=\"firstName\"/&gt;\n"
+#~ "        &lt;property name=\"initial\"/&gt;\n"
+#~ "        &lt;property name=\"lastName\"/&gt;\n"
+#~ "    &lt;/properties&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"person\"\n"
+#~ "         class=\"Person\" property-ref=\"name\">\n"
+#~ "    <column name=\"firstName\"/>\n"
+#~ "    <column name=\"initial\"/>\n"
+#~ "    <column name=\"lastName\"/>\n"
+#~ "</many-to-one>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"person\" \n"
+#~ "         class=\"Person\" property-ref=\"name\"&gt;\n"
+#~ "    &lt;column name=\"firstName\"/&gt;\n"
+#~ "    &lt;column name=\"initial\"/&gt;\n"
+#~ "    &lt;column name=\"lastName\"/&gt;\n"
+#~ "&lt;/many-to-one&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<subclass\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        discriminator-value=\"discriminator_value\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "        extends=\"SuperclassName\">\n"
+#~ "\n"
+#~ "        <property .... />\n"
+#~ "        .....\n"
+#~ "</subclass>]]>"
+#~ msgstr ""
+#~ "&lt;subclass\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        discriminator-value=\"discriminator_value\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "        extends=\"SuperclassName\"&gt;\n"
+#~ "\n"
+#~ "        &lt;property .... /&gt;\n"
+#~ "        .....\n"
+#~ "&lt;/subclass&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<joined-subclass\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        table=\"tablename\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        schema=\"schema\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        extends=\"SuperclassName\"\n"
+#~ "        persister=\"ClassName\"\n"
+#~ "        subselect=\"SQL expression\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\">\n"
+#~ "\n"
+#~ "        <key .... >\n"
+#~ "\n"
+#~ "        <property .... />\n"
+#~ "        .....\n"
+#~ "</joined-subclass>]]>"
+#~ msgstr ""
+#~ "&lt;joined-subclass\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        table=\"tablename\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        schema=\"schema\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        extends=\"SuperclassName\"\n"
+#~ "        persister=\"ClassName\"\n"
+#~ "        subselect=\"SQL expression\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\"&gt;\n"
+#~ "\n"
+#~ "        &lt;key .... &gt;\n"
+#~ "\n"
+#~ "        &lt;property .... /&gt;\n"
+#~ "        .....\n"
+#~ "&lt;/joined-subclass&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Mapping DTD//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "        <class name=\"Cat\" table=\"CATS\">\n"
+#~ "                <id name=\"id\" column=\"uid\" type=\"long\">\n"
+#~ "                        <generator class=\"hilo\"/>\n"
+#~ "                </id>\n"
+#~ "                <property name=\"birthdate\" type=\"date\"/>\n"
+#~ "                <property name=\"color\" not-null=\"true\"/>\n"
+#~ "                <property name=\"sex\" not-null=\"true\"/>\n"
+#~ "                <property name=\"weight\"/>\n"
+#~ "                <many-to-one name=\"mate\"/>\n"
+#~ "                <set name=\"kittens\">\n"
+#~ "                        <key column=\"MOTHER\"/>\n"
+#~ "                        <one-to-many class=\"Cat\"/>\n"
+#~ "                </set>\n"
+#~ "                <joined-subclass name=\"DomesticCat\" table="
+#~ "\"DOMESTIC_CATS\">\n"
+#~ "                    <key column=\"CAT\"/>\n"
+#~ "                    <property name=\"name\" type=\"string\"/>\n"
+#~ "                </joined-subclass>\n"
+#~ "        </class>\n"
+#~ "\n"
+#~ "        <class name=\"eg.Dog\">\n"
+#~ "                <!-- mapping for Dog could go here -->\n"
+#~ "        </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;?xml version=\"1.0\"?&gt;\n"
+#~ "&lt;!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Mapping DTD//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd"
+#~ "\"&gt;\n"
+#~ "\n"
+#~ "&lt;hibernate-mapping package=\"eg\"&gt;\n"
+#~ "\n"
+#~ "        &lt;class name=\"Cat\" table=\"CATS\"&gt;\n"
+#~ "                &lt;id name=\"id\" column=\"uid\" type=\"long\"&gt;\n"
+#~ "                        &lt;generator class=\"hilo\"/&gt;\n"
+#~ "                &lt;/id&gt;\n"
+#~ "                &lt;property name=\"birthdate\" type=\"date\"/&gt;\n"
+#~ "                &lt;property name=\"color\" not-null=\"true\"/&gt;\n"
+#~ "                &lt;property name=\"sex\" not-null=\"true\"/&gt;\n"
+#~ "                &lt;property name=\"weight\"/&gt;\n"
+#~ "                &lt;many-to-one name=\"mate\"/&gt;\n"
+#~ "                &lt;set name=\"kittens\"&gt;\n"
+#~ "                        &lt;key column=\"MOTHER\"/&gt;\n"
+#~ "                        &lt;one-to-many class=\"Cat\"/&gt;\n"
+#~ "                &lt;/set&gt;\n"
+#~ "                &lt;joined-subclass name=\"DomesticCat\" table="
+#~ "\"DOMESTIC_CATS\"&gt;\n"
+#~ "                    &lt;key column=\"CAT\"/&gt;\n"
+#~ "                    &lt;property name=\"name\" type=\"string\"/&gt;\n"
+#~ "                &lt;/joined-subclass&gt;\n"
+#~ "        &lt;/class&gt;\n"
+#~ "\n"
+#~ "        &lt;class name=\"eg.Dog\"&gt;\n"
+#~ "                &lt;!-- mapping for Dog could go here --&gt;\n"
+#~ "        &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<union-subclass\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        table=\"tablename\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        schema=\"schema\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        extends=\"SuperclassName\"\n"
+#~ "        abstract=\"true|false\"\n"
+#~ "        persister=\"ClassName\"\n"
+#~ "        subselect=\"SQL expression\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\">\n"
+#~ "\n"
+#~ "        <property .... />\n"
+#~ "        .....\n"
+#~ "</union-subclass>]]>"
+#~ msgstr ""
+#~ "&lt;union-subclass\n"
+#~ "        name=\"ClassName\"\n"
+#~ "        table=\"tablename\"\n"
+#~ "        proxy=\"ProxyInterface\"\n"
+#~ "        lazy=\"true|false\"\n"
+#~ "        dynamic-update=\"true|false\"\n"
+#~ "        dynamic-insert=\"true|false\"\n"
+#~ "        schema=\"schema\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        extends=\"SuperclassName\"\n"
+#~ "        abstract=\"true|false\"\n"
+#~ "        persister=\"ClassName\"\n"
+#~ "        subselect=\"SQL expression\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\"&gt;\n"
+#~ "\n"
+#~ "        &lt;property .... /&gt;\n"
+#~ "        .....\n"
+#~ "&lt;/union-subclass&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<join\n"
+#~ "        table=\"tablename\"\n"
+#~ "        schema=\"owner\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        fetch=\"join|select\"\n"
+#~ "        inverse=\"true|false\"\n"
+#~ "        optional=\"true|false\">\n"
+#~ "\n"
+#~ "        <key ... />\n"
+#~ "\n"
+#~ "        <property ... />\n"
+#~ "        ...\n"
+#~ "</join>]]>"
+#~ msgstr ""
+#~ "&lt;join\n"
+#~ "        table=\"tablename\"\n"
+#~ "        schema=\"owner\"\n"
+#~ "        catalog=\"catalog\"\n"
+#~ "        fetch=\"join|select\"\n"
+#~ "        inverse=\"true|false\"\n"
+#~ "        optional=\"true|false\"&gt;\n"
+#~ "        \n"
+#~ "        &lt;key ... /&gt;\n"
+#~ "        \n"
+#~ "        &lt;property ... /&gt;\n"
+#~ "        ...\n"
+#~ "&lt;/join&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\"\n"
+#~ "    table=\"PERSON\">\n"
+#~ "\n"
+#~ "    <id name=\"id\" column=\"PERSON_ID\">...</id>\n"
+#~ "\n"
+#~ "    <join table=\"ADDRESS\">\n"
+#~ "        <key column=\"ADDRESS_ID\"/>\n"
+#~ "        <property name=\"address\"/>\n"
+#~ "        <property name=\"zip\"/>\n"
+#~ "        <property name=\"country\"/>\n"
+#~ "    </join>\n"
+#~ "    ...]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"\n"
+#~ "    table=\"PERSON\"&gt;\n"
+#~ "\n"
+#~ "    &lt;id name=\"id\" column=\"PERSON_ID\"&gt;...&lt;/id&gt;\n"
+#~ "\n"
+#~ "    &lt;join table=\"ADDRESS\"&gt;\n"
+#~ "        &lt;key column=\"ADDRESS_ID\"/&gt;\n"
+#~ "        &lt;property name=\"address\"/&gt;\n"
+#~ "        &lt;property name=\"zip\"/&gt;\n"
+#~ "        &lt;property name=\"country\"/&gt;\n"
+#~ "    &lt;/join&gt;\n"
+#~ "    ..."
+
+#, fuzzy
+#~ msgid "<title>Key</title>"
+#~ msgstr "<title>键(key)</title>"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<key\n"
+#~ "        column=\"columnname\"\n"
+#~ "        on-delete=\"noaction|cascade\"\n"
+#~ "        property-ref=\"propertyName\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "&lt;key\n"
+#~ "        column=\"columnname\"\n"
+#~ "        on-delete=\"noaction|cascade\"\n"
+#~ "        property-ref=\"propertyName\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        update=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<column\n"
+#~ "        name=\"column_name\"\n"
+#~ "        length=\"N\"\n"
+#~ "        precision=\"N\"\n"
+#~ "        scale=\"N\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        unique-key=\"multicolumn_unique_key_name\"\n"
+#~ "        index=\"index_name\"\n"
+#~ "        sql-type=\"sql_type_name\"\n"
+#~ "        check=\"SQL expression\"\n"
+#~ "        default=\"SQL expression\"/>]]>"
+#~ msgstr ""
+#~ "&lt;column\n"
+#~ "        name=\"column_name\"\n"
+#~ "        length=\"N\"\n"
+#~ "        precision=\"N\"\n"
+#~ "        scale=\"N\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        unique-key=\"multicolumn_unique_key_name\"\n"
+#~ "        index=\"index_name\"\n"
+#~ "        sql-type=\"sql_type_name\"\n"
+#~ "        check=\"SQL expression\"\n"
+#~ "        default=\"SQL expression\"/&gt;"
+
+#, fuzzy
+#~ msgid "<![CDATA[<formula>SQL expression</formula>]]>"
+#~ msgstr "&lt;formula&gt;SQL expression&lt;/formula&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"homeAddress\" class=\"Address\"\n"
+#~ "        insert=\"false\" update=\"false\">\n"
+#~ "    <column name=\"person_id\" not-null=\"true\" length=\"10\"/>\n"
+#~ "    <formula>'MAILING'</formula>\n"
+#~ "</many-to-one>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"homeAddress\" class=\"Address\"\n"
+#~ "        insert=\"false\" update=\"false\"&gt;\n"
+#~ "    &lt;column name=\"person_id\" not-null=\"true\" length=\"10\"/&gt;\n"
+#~ "    &lt;formula&gt;'MAILING'&lt;/formula&gt;\n"
+#~ "&lt;/many-to-one&gt;"
+
+#, fuzzy
+#~ msgid "<![CDATA[<import class=\"java.lang.Object\" rename=\"Universe\"/>]]>"
+#~ msgstr "&lt;import class=\"java.lang.Object\" rename=\"Universe\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<import\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        rename=\"ShortName\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "&lt;import\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        rename=\"ShortName\"\n"
+#~ "/&gt;"
+
+#, fuzzy
+#~ msgid "<title>Any</title>"
+#~ msgstr "<title>any</title>"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<any name=\"being\" id-type=\"long\" meta-type=\"string\">\n"
+#~ "    <meta-value value=\"TBL_ANIMAL\" class=\"Animal\"/>\n"
+#~ "    <meta-value value=\"TBL_HUMAN\" class=\"Human\"/>\n"
+#~ "    <meta-value value=\"TBL_ALIEN\" class=\"Alien\"/>\n"
+#~ "    <column name=\"table_name\"/>\n"
+#~ "    <column name=\"id\"/>\n"
+#~ "</any>]]>"
+#~ msgstr ""
+#~ "&lt;any name=\"being\" id-type=\"long\" meta-type=\"string\"&gt;\n"
+#~ "    &lt;meta-value value=\"TBL_ANIMAL\" class=\"Animal\"/&gt;\n"
+#~ "    &lt;meta-value value=\"TBL_HUMAN\" class=\"Human\"/&gt;\n"
+#~ "    &lt;meta-value value=\"TBL_ALIEN\" class=\"Alien\"/&gt;\n"
+#~ "    &lt;column name=\"table_name\"/&gt;\n"
+#~ "    &lt;column name=\"id\"/&gt;\n"
+#~ "&lt;/any&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<any\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        id-type=\"idtypename\"\n"
+#~ "        meta-type=\"metatypename\"\n"
+#~ "        cascade=\"cascade_style\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ ">\n"
+#~ "        <meta-value ... />\n"
+#~ "        <meta-value ... />\n"
+#~ "        .....\n"
+#~ "        <column .... />\n"
+#~ "        <column .... />\n"
+#~ "        .....\n"
+#~ "</any>]]>"
+#~ msgstr ""
+#~ "&lt;any\n"
+#~ "        name=\"propertyName\"\n"
+#~ "        id-type=\"idtypename\"\n"
+#~ "        meta-type=\"metatypename\"\n"
+#~ "        cascade=\"cascade_style\"\n"
+#~ "        access=\"field|property|ClassName\"\n"
+#~ "        optimistic-lock=\"true|false\"\n"
+#~ "&gt;\n"
+#~ "        &lt;meta-value ... /&gt;\n"
+#~ "        &lt;meta-value ... /&gt;\n"
+#~ "        .....\n"
+#~ "        &lt;column .... /&gt;\n"
+#~ "        &lt;column .... /&gt;\n"
+#~ "        .....\n"
+#~ "&lt;/any&gt;"
+
+#~ msgid "string"
+#~ msgstr "string"
+
+#, fuzzy
+#~ msgid "class"
+#~ msgstr "子类(subclass)"
+
+#~ msgid "binary"
+#~ msgstr "binary"
+
+#~ msgid "text"
+#~ msgstr "text"
+
+#~ msgid "serializable"
+#~ msgstr "serializable"
+
+#~ msgid "clob, blob"
+#~ msgstr "clob, blob"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"twoStrings\" type=\"org.hibernate.test."
+#~ "DoubleStringType\">\n"
+#~ "    <column name=\"first_string\"/>\n"
+#~ "    <column name=\"second_string\"/>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"twoStrings\" type=\"org.hibernate.test."
+#~ "DoubleStringType\"&gt;\n"
+#~ "    &lt;column name=\"first_string\"/&gt;\n"
+#~ "    &lt;column name=\"second_string\"/&gt;\n"
+#~ "&lt;/property&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"priority\">\n"
+#~ "    <type name=\"com.mycompany.usertypes.DefaultValueIntegerType\">\n"
+#~ "        <param name=\"default\">0</param>\n"
+#~ "    </type>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"priority\"&gt;\n"
+#~ "    &lt;type name=\"com.mycompany.usertypes.DefaultValueIntegerType"
+#~ "\"&gt;\n"
+#~ "        &lt;param name=\"default\"&gt;0&lt;/param&gt;\n"
+#~ "    &lt;/type&gt;\n"
+#~ "&lt;/property&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<typedef class=\"com.mycompany.usertypes.DefaultValueIntegerType"
+#~ "\" name=\"default_zero\">\n"
+#~ "    <param name=\"default\">0</param>\n"
+#~ "</typedef>]]>"
+#~ msgstr ""
+#~ "&lt;typedef class=\"com.mycompany.usertypes.DefaultValueIntegerType\" "
+#~ "name=\"default_zero\"&gt;\n"
+#~ "    &lt;param name=\"default\"&gt;0&lt;/param&gt;\n"
+#~ "&lt;/typedef&gt;"
+
+#, fuzzy
+#~ msgid "<![CDATA[<property name=\"priority\" type=\"default_zero\"/>]]>"
+#~ msgstr "&lt;property name=\"priority\" type=\"default_zero\"/&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Contract\" table=\"Contracts\"\n"
+#~ "        entity-name=\"CurrentContract\">\n"
+#~ "    ...\n"
+#~ "    <set name=\"history\" inverse=\"true\"\n"
+#~ "            order-by=\"effectiveEndDate desc\">\n"
+#~ "        <key column=\"currentContractId\"/>\n"
+#~ "        <one-to-many entity-name=\"HistoricalContract\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Contract\" table=\"ContractHistory\"\n"
+#~ "        entity-name=\"HistoricalContract\">\n"
+#~ "    ...\n"
+#~ "    <many-to-one name=\"currentContract\"\n"
+#~ "            column=\"currentContractId\"\n"
+#~ "            entity-name=\"CurrentContract\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Contract\" table=\"Contracts\" \n"
+#~ "        entity-name=\"CurrentContract\"&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;set name=\"history\" inverse=\"true\" \n"
+#~ "            order-by=\"effectiveEndDate desc\"&gt;\n"
+#~ "        &lt;key column=\"currentContractId\"/&gt;\n"
+#~ "        &lt;one-to-many entity-name=\"HistoricalContract\"/&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"Contract\" table=\"ContractHistory\" \n"
+#~ "        entity-name=\"HistoricalContract\"&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;many-to-one name=\"currentContract\" \n"
+#~ "            column=\"currentContractId\" \n"
+#~ "            entity-name=\"CurrentContract\"/&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"LineItem\" table=\"`Line Item`\">\n"
+#~ "    <id name=\"id\" column=\"`Item Id`\"/><generator class=\"assigned\"/"
+#~ "></id>\n"
+#~ "    <property name=\"itemNumber\" column=\"`Item #`\"/>\n"
+#~ "    ...\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"LineItem\" table=\"`Line Item`\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"`Item Id`\"/&gt;&lt;generator class="
+#~ "\"assigned\"/&gt;&lt;/id&gt;\n"
+#~ "    &lt;property name=\"itemNumber\" column=\"`Item #`\"/&gt;\n"
+#~ "    ...\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "import java.util.Set;\n"
+#~ "import java.util.Date;\n"
+#~ "\n"
+#~ "/**\n"
+#~ " * @hibernate.class\n"
+#~ " *  table=\"CATS\"\n"
+#~ " */\n"
+#~ "public class Cat {\n"
+#~ "    private Long id; // identifier\n"
+#~ "    private Date birthdate;\n"
+#~ "    private Cat mother;\n"
+#~ "    private Set kittens\n"
+#~ "    private Color color;\n"
+#~ "    private char sex;\n"
+#~ "    private float weight;\n"
+#~ "\n"
+#~ "    /*\n"
+#~ "     * @hibernate.id\n"
+#~ "     *  generator-class=\"native\"\n"
+#~ "     *  column=\"CAT_ID\"\n"
+#~ "     */\n"
+#~ "    public Long getId() {\n"
+#~ "        return id;\n"
+#~ "    }\n"
+#~ "    private void setId(Long id) {\n"
+#~ "        this.id=id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.many-to-one\n"
+#~ "     *  column=\"PARENT_ID\"\n"
+#~ "     */\n"
+#~ "    public Cat getMother() {\n"
+#~ "        return mother;\n"
+#~ "    }\n"
+#~ "    void setMother(Cat mother) {\n"
+#~ "        this.mother = mother;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"BIRTH_DATE\"\n"
+#~ "     */\n"
+#~ "    public Date getBirthdate() {\n"
+#~ "        return birthdate;\n"
+#~ "    }\n"
+#~ "    void setBirthdate(Date date) {\n"
+#~ "        birthdate = date;\n"
+#~ "    }\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"WEIGHT\"\n"
+#~ "     */\n"
+#~ "    public float getWeight() {\n"
+#~ "        return weight;\n"
+#~ "    }\n"
+#~ "    void setWeight(float weight) {\n"
+#~ "        this.weight = weight;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"COLOR\"\n"
+#~ "     *  not-null=\"true\"\n"
+#~ "     */\n"
+#~ "    public Color getColor() {\n"
+#~ "        return color;\n"
+#~ "    }\n"
+#~ "    void setColor(Color color) {\n"
+#~ "        this.color = color;\n"
+#~ "    }\n"
+#~ "    /**\n"
+#~ "     * @hibernate.set\n"
+#~ "     *  inverse=\"true\"\n"
+#~ "     *  order-by=\"BIRTH_DATE\"\n"
+#~ "     * @hibernate.collection-key\n"
+#~ "     *  column=\"PARENT_ID\"\n"
+#~ "     * @hibernate.collection-one-to-many\n"
+#~ "     */\n"
+#~ "    public Set getKittens() {\n"
+#~ "        return kittens;\n"
+#~ "    }\n"
+#~ "    void setKittens(Set kittens) {\n"
+#~ "        this.kittens = kittens;\n"
+#~ "    }\n"
+#~ "    // addKitten not needed by Hibernate\n"
+#~ "    public void addKitten(Cat kitten) {\n"
+#~ "        kittens.add(kitten);\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"SEX\"\n"
+#~ "     *  not-null=\"true\"\n"
+#~ "     *  update=\"false\"\n"
+#~ "     */\n"
+#~ "    public char getSex() {\n"
+#~ "        return sex;\n"
+#~ "    }\n"
+#~ "    void setSex(char sex) {\n"
+#~ "        this.sex=sex;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "package eg;\n"
+#~ "import java.util.Set;\n"
+#~ "import java.util.Date;\n"
+#~ "\n"
+#~ "/**\n"
+#~ " * @hibernate.class\n"
+#~ " *  table=\"CATS\"\n"
+#~ " */\n"
+#~ "public class Cat {\n"
+#~ "    private Long id; // identifier\n"
+#~ "    private Date birthdate;\n"
+#~ "    private Cat mother;\n"
+#~ "    private Set kittens\n"
+#~ "    private Color color;\n"
+#~ "    private char sex;\n"
+#~ "    private float weight;\n"
+#~ "\n"
+#~ "    /*\n"
+#~ "     * @hibernate.id\n"
+#~ "     *  generator-class=\"native\"\n"
+#~ "     *  column=\"CAT_ID\"\n"
+#~ "     */\n"
+#~ "    public Long getId() {\n"
+#~ "        return id;\n"
+#~ "    }\n"
+#~ "    private void setId(Long id) {\n"
+#~ "        this.id=id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.many-to-one\n"
+#~ "     *  column=\"PARENT_ID\"\n"
+#~ "     */\n"
+#~ "    public Cat getMother() {\n"
+#~ "        return mother;\n"
+#~ "    }\n"
+#~ "    void setMother(Cat mother) {\n"
+#~ "        this.mother = mother;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"BIRTH_DATE\"\n"
+#~ "     */\n"
+#~ "    public Date getBirthdate() {\n"
+#~ "        return birthdate;\n"
+#~ "    }\n"
+#~ "    void setBirthdate(Date date) {\n"
+#~ "        birthdate = date;\n"
+#~ "    }\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"WEIGHT\"\n"
+#~ "     */\n"
+#~ "    public float getWeight() {\n"
+#~ "        return weight;\n"
+#~ "    }\n"
+#~ "    void setWeight(float weight) {\n"
+#~ "        this.weight = weight;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"COLOR\"\n"
+#~ "     *  not-null=\"true\"\n"
+#~ "     */\n"
+#~ "    public Color getColor() {\n"
+#~ "        return color;\n"
+#~ "    }\n"
+#~ "    void setColor(Color color) {\n"
+#~ "        this.color = color;\n"
+#~ "    }\n"
+#~ "    /**\n"
+#~ "     * @hibernate.set\n"
+#~ "     *  inverse=\"true\"\n"
+#~ "     *  order-by=\"BIRTH_DATE\"\n"
+#~ "     * @hibernate.collection-key\n"
+#~ "     *  column=\"PARENT_ID\"\n"
+#~ "     * @hibernate.collection-one-to-many\n"
+#~ "     */\n"
+#~ "    public Set getKittens() {\n"
+#~ "        return kittens;\n"
+#~ "    }\n"
+#~ "    void setKittens(Set kittens) {\n"
+#~ "        this.kittens = kittens;\n"
+#~ "    }\n"
+#~ "    // addKitten not needed by Hibernate\n"
+#~ "    public void addKitten(Cat kitten) {\n"
+#~ "        kittens.add(kitten);\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    /**\n"
+#~ "     * @hibernate.property\n"
+#~ "     *  column=\"SEX\"\n"
+#~ "     *  not-null=\"true\"\n"
+#~ "     *  update=\"false\"\n"
+#~ "     */\n"
+#~ "    public char getSex() {\n"
+#~ "        return sex;\n"
+#~ "    }\n"
+#~ "    void setSex(char sex) {\n"
+#~ "        this.sex=sex;\n"
+#~ "    }\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[@Entity(access = AccessType.FIELD)\n"
+#~ "public class Customer implements Serializable {\n"
+#~ "\n"
+#~ "    @Id;\n"
+#~ "    Long id;\n"
+#~ "\n"
+#~ "    String firstName;\n"
+#~ "    String lastName;\n"
+#~ "    Date birthday;\n"
+#~ "\n"
+#~ "    @Transient\n"
+#~ "    Integer age;\n"
+#~ "\n"
+#~ "    @Embedded\n"
+#~ "    private Address homeAddress;\n"
+#~ "\n"
+#~ "    @OneToMany(cascade=CascadeType.ALL)\n"
+#~ "    @JoinColumn(name=\"CUSTOMER_ID\")\n"
+#~ "    Set<Order> orders;\n"
+#~ "\n"
+#~ "    // Getter/setter and business methods\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "@Entity(access = AccessType.FIELD)\n"
+#~ "public class Customer implements Serializable {\n"
+#~ "\n"
+#~ "    @Id;\n"
+#~ "    Long id;\n"
+#~ "\n"
+#~ "    String firstName;\n"
+#~ "    String lastName;\n"
+#~ "    Date birthday;\n"
+#~ "\n"
+#~ "    @Transient\n"
+#~ "    Integer age;\n"
+#~ "\n"
+#~ "    @Embedded\n"
+#~ "    private Address homeAddress;\n"
+#~ "\n"
+#~ "    @OneToMany(cascade=CascadeType.ALL)\n"
+#~ "    @JoinColumn(name=\"CUSTOMER_ID\")\n"
+#~ "    Set&lt;Order&gt; orders;\n"
+#~ "\n"
+#~ "    // Getter/setter and business methods\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "    ...\n"
+#~ "    <database-object>\n"
+#~ "        <create>CREATE TRIGGER my_trigger ...</create>\n"
+#~ "        <drop>DROP TRIGGER my_trigger</drop>\n"
+#~ "    </database-object>\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;database-object&gt;\n"
+#~ "        &lt;create&gt;CREATE TRIGGER my_trigger ...&lt;/create&gt;\n"
+#~ "        &lt;drop&gt;DROP TRIGGER my_trigger&lt;/drop&gt;\n"
+#~ "    &lt;/database-object&gt;\n"
+#~ "&lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "    ...\n"
+#~ "    <database-object>\n"
+#~ "        <definition class=\"MyTriggerDefinition\"/>\n"
+#~ "    </database-object>\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;database-object&gt;\n"
+#~ "        &lt;definition class=\"MyTriggerDefinition\"/&gt;\n"
+#~ "    &lt;/database-object&gt;\n"
+#~ "&lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "    ...\n"
+#~ "    <database-object>\n"
+#~ "        <definition class=\"MyTriggerDefinition\"/>\n"
+#~ "        <dialect-scope name=\"org.hibernate.dialect.Oracle9iDialect\"/>\n"
+#~ "        <dialect-scope name=\"org.hibernate.dialect.Oracle10gDialect\"/>\n"
+#~ "    </database-object>\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;database-object&gt;\n"
+#~ "        &lt;definition class=\"MyTriggerDefinition\"/&gt;\n"
+#~ "        &lt;dialect-scope name=\"org.hibernate.dialect.Oracle9Dialect\"/"
+#~ "&gt;\n"
+#~ "        &lt;dialect-scope name=\"org.hibernate.dialect.OracleDialect\"/"
+#~ "&gt;\n"
+#~ "    &lt;/database-object&gt;\n"
+#~ "&lt;/hibernate-mapping&gt;"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/batch.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/batch.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/batch.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,61 +1,47 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-11 10:33+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: batch.xml:29
 #, no-c-format
 msgid "Batch processing"
 msgstr "批量处理(Batch processing)"
 
 #. Tag: para
-#: batch.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A naive approach to inserting 100,000 rows in the database using Hibernate "
 "might look like this:"
 msgstr ""
-"使用Hibernate将 100 000 条记录插入到数据库的一个很自然的做法可能是这样的"
+"使用 Hibernate 将 100,000 条记录插入到数据库的一个很天真的做法可能是这样的:"
 
-#. Tag: programlisting
-#: batch.xml:36
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"}\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:38
-#, fuzzy, no-c-format
-msgid ""
 "This would fall over with an <literal>OutOfMemoryException</literal> "
 "somewhere around the 50,000th row. That is because Hibernate caches all the "
 "newly inserted <literal>Customer</literal> instances in the session-level "
 "cache. In this chapter we will show you how to avoid this problem."
 msgstr ""
-"这段程序大概运行到 50 000 条记录左右会失败并抛出 <literal>内存溢出异常"
-"(OutOfMemoryException)</literal> 。 这是因为 Hibernate 把所有新插入的 "
-"<literal>客户(Customer)</literal>实例在 session级别的缓存区进行了缓存的缘"
-"故。"
+"这段程序大概运行到 50,000 条记录左右会失败并抛出<literal>内存溢出异常"
+"(OutOfMemoryException)</literal> 。这是因为 Hibernate 把所有新插入的"
+"<literal>客户(Customer)</literal>实例在 session 级别的缓存区进行了缓存的缘"
+"故。 "
 
 #. Tag: para
-#: batch.xml:45
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are undertaking batch processing you will need to enable the use of "
 "JDBC batching. This is absolutely essential if you want to achieve optimal "
@@ -63,139 +49,72 @@
 "example):"
 msgstr ""
 "我们会在本章告诉你如何避免此类问题。首先,如果你要执行批量处理并且想要达到一"
-"个理想的性能, 那么使用JDBC的批量(batching)功能是至关重要。将JDBC的批量抓取"
-"数量(batch size)参数设置到一个合适值 (比如,10-50之间):"
+"个理想的性能,那么使用 JDBC 的批量(batching)功能是至关重要。将 JDBC 的批量"
+"抓取数量(batch size)参数设置到一个合适值(比如,10 - 50 之间):"
 
-#. Tag: programlisting
-#: batch.xml:52
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[hibernate.jdbc.batch_size 20]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:54
-#, fuzzy, no-c-format
 msgid ""
 "Hibernate disables insert batching at the JDBC level transparently if you "
 "use an <literal>identity</literal> identifier generator."
 msgstr ""
-"注意,假若你使用了<literal>identiy</literal>标识符生成器,Hibernate在JDBC级别透"
-"明的关闭插入语句的批量执行。"
+"注意,假若你使用了 <literal>identiy</literal> 标识符生成器,Hibernate 在 "
+"JDBC 级别透明的关闭插入语句的批量执行。 "
 
 #. Tag: para
-#: batch.xml:59
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also do this kind of work in a process where interaction with the "
 "second-level cache is completely disabled:"
-msgstr "你也可能想在执行批量处理时关闭二级缓存:"
+msgstr "你也可能想在执行批量处理时完全关闭二级缓存:"
 
-#. Tag: programlisting
-#: batch.xml:64
-#, no-c-format
-msgid "<![CDATA[hibernate.cache.use_second_level_cache false]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:66
 #, no-c-format
 msgid ""
 "However, this is not absolutely necessary, since we can explicitly set the "
 "<literal>CacheMode</literal> to disable interaction with the second-level "
 "cache."
 msgstr ""
-"但是,这不是绝对必须的,因为我们可以显式设置<literal>CacheMode</literal>来关"
-"闭与二级缓存的交互。"
+"但是,这不是绝对必须的,因为我们可以显式设置 <literal>CacheMode</literal> 来"
+"关闭与二级缓存的交互。"
 
 #. Tag: title
-#: batch.xml:72
 #, no-c-format
 msgid "Batch inserts"
 msgstr "批量插入(Batch inserts)"
 
 #. Tag: para
-#: batch.xml:74
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When making new objects persistent <literal>flush()</literal> and then "
 "<literal>clear()</literal> the session regularly in order to control the "
 "size of the first-level cache."
 msgstr ""
 "如果要将很多对象持久化,你必须通过经常的调用 <literal>flush()</literal> 以及"
-"稍后调用 <literal>clear()</literal> 来控制第一级缓存的大小。"
+"稍后调用  <literal>clear()</literal> 来控制第一级缓存的大小。 "
 
-#. Tag: programlisting
-#: batch.xml:80
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"for ( int i=0; i<100000; i++ ) {\n"
-"    Customer customer = new Customer(.....);\n"
-"    session.save(customer);\n"
-"    if ( i % 20 == 0 ) { //20, same as the JDBC batch size\n"
-"        //flush a batch of inserts and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: title
-#: batch.xml:85
 #, no-c-format
 msgid "Batch updates"
 msgstr "批量更新(Batch updates)"
 
 #. Tag: para
-#: batch.xml:87
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For retrieving and updating data, the same ideas apply. In addition, you "
 "need to use <literal>scroll()</literal> to take advantage of server-side "
 "cursors for queries that return many rows of data."
 msgstr ""
-"此方法同样适用于检索和更新数据。此外,在进行会返回很多行数据的查询时, 你需要"
-"使用 <literal>scroll()</literal> 方法以便充分利用服务器端游标所带来的好处。"
+"此方法同样适用于检索和更新数据。此外,在进行会返回很多行数据的查询时,你需要"
+"使用 <literal>scroll()</literal> 方法以便充分利用服务器端游标所带来的好处。 "
 
-#. Tag: programlisting
-#: batch.xml:93
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-"    .setCacheMode(CacheMode.IGNORE)\n"
-"    .scroll(ScrollMode.FORWARD_ONLY);\n"
-"int count=0;\n"
-"while ( customers.next() ) {\n"
-"    Customer customer = (Customer) customers.get(0);\n"
-"    customer.updateStuff(...);\n"
-"    if ( ++count % 20 == 0 ) {\n"
-"        //flush a batch of updates and release memory:\n"
-"        session.flush();\n"
-"        session.clear();\n"
-"    }\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: title
-#: batch.xml:98
 #, no-c-format
 msgid "The StatelessSession interface"
-msgstr "StatelessSession (无状态session)接口"
+msgstr "StatelessSession(无状态 session)接口"
 
 #. Tag: para
-#: batch.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, Hibernate provides a command-oriented API that can be used "
 "for streaming data to and from the database in the form of detached objects. "
@@ -211,48 +130,27 @@
 "effects. A stateless session is a lower-level abstraction that is much "
 "closer to the underlying JDBC."
 msgstr ""
-"作为选择,Hibernate提供了基于命令的API,可以用detached object的形式把数据以流"
-"的方法加入到数据库,或从数据库输出。<literal>StatelessSession</literal>没有持"
-"久化上下文,也不提供多少高层的生命周期语义。特别是,无状态session不实现第一级"
-"cache,也不和第二级缓存,或者查询缓存交互。它不实现事务化写,也不实现脏数据检"
-"查。用stateless session进行的操作甚至不级联到关联实例。stateless session忽略"
-"集合类(Collections)。通过stateless session进行的操作不触发Hibernate的事件模型"
-"和拦截器。无状态session对数据的混淆现象免疫,因为它没有第一级缓存。无状态"
-"session是低层的抽象,和低层JDBC相当接近。"
+"作为选择,Hibernate 提供了基于命令的 API,可以用 detached object 的形式把数据"
+"以流的方法加入到数据库,或从数据库输出。<literal>StatelessSession</literal> "
+"没有持久化上下文,也不提供多少高层的生命周期语义。特别是,无状态 session 不实"
+"现第一级 cache,也不和第二级缓存,或者查询缓存交互。它不实现事务化写,也不实"
+"现脏数据检查。用 stateless session 进行的操作甚至不级联到关联实例。stateless "
+"session 忽略集合类(Collections)。通过 stateless session 进行的操作不触发 "
+"Hibernate 的事件模型和拦截器。无状态 session 对数据的混淆现象免疫,因为它没有"
+"第一级缓存。无状态 session 是低层的抽象,和低层 JDBC 相当接近。 "
 
-#. Tag: programlisting
-#: batch.xml:114
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[StatelessSession session = sessionFactory.openStatelessSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"   \n"
-"ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
-"    .scroll(ScrollMode.FORWARD_ONLY);\n"
-"while ( customers.next() ) {\n"
-"    Customer customer = (Customer) customers.get(0);\n"
-"    customer.updateStuff(...);\n"
-"    session.update(customer);\n"
-"}\n"
-"   \n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:116
-#, fuzzy, no-c-format
-msgid ""
 "In this code example, the <literal>Customer</literal> instances returned by "
 "the query are immediately detached. They are never associated with any "
 "persistence context."
 msgstr ""
-"注意在上面的例子中,查询返回的<literal>Customer</literal>实例立即被脱管"
-"(detach)。它们与任何持久化上下文都没有关系。"
+"注意在上面的例子中,查询返回的 <literal>Customer</literal> 实例立即被脱管"
+"(detach)。它们与任何持久化上下文都没有关系。 "
 
 #. Tag: para
-#: batch.xml:122
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>insert(), update()</literal> and <literal>delete()</literal> "
 "operations defined by the <literal>StatelessSession</literal> interface are "
@@ -262,20 +160,19 @@
 "<literal>save(), saveOrUpdate()</literal> and <literal>delete()</literal> "
 "operations defined by the <literal>Session</literal> interface."
 msgstr ""
-"<literal>StatelessSession</literal> 接口定义的<literal>insert(), update()</"
-"literal> 和 <literal>delete()</literal>操作是直接的数据库行级别操作,其结果是"
-"立刻执行一条<literal>INSERT, UPDATE</literal> 或 <literal>DELETE</literal> 语"
-"句。因此,它们的语义和<literal>Session</literal> 接口定义的<literal>save(), "
-"saveOrUpdate()</literal> 和<literal>delete()</literal> 操作有很大的不同。"
+"<literal>StatelessSession</literal> 接口定义的 <literal>insert(), update()</"
+"literal> 和 <literal>delete()</literal> 操作是直接的数据库行级别操作,其结果"
+"是立刻执行一条 <literal>INSERT, UPDATE</literal> 或 <literal>DELETE</"
+"literal> 语句。因此,它们的语义和 <literal>Session</literal> 接口定义的 "
+"<literal>save(), saveOrUpdate()</literal> 和<literal>delete()</literal> 操作"
+"有很大的不同。 "
 
 #. Tag: title
-#: batch.xml:135
 #, no-c-format
 msgid "DML-style operations"
-msgstr "DML(数据操作语言)风格的操作(DML-style operations)"
+msgstr "DML(数据操作语言)风格的操作(DML-style operations)"
 
 #. Tag: para
-#: batch.xml:137
 #, fuzzy, no-c-format
 msgid ""
 "As already discussed, automatic and transparent object/relational mapping is "
@@ -288,109 +185,76 @@
 "is performed through the Hibernate Query Language (<link linkend=\"queryhql"
 "\">HQL</link>)."
 msgstr ""
-"hence manipulating (using the SQL <literal>Data Manipulation Language</"
-"literal> (DML) statements: <literal>INSERT</literal>, <literal>UPDATE</"
-"literal>, <literal>DELETE</literal>) data directly in the database will not "
-"affect in-memory state. However, Hibernate provides methods for bulk SQL-"
-"style DML statement execution which are performed through the Hibernate "
-"Query Language (<xref linkend=\"queryhql\">HQL</xref>). 就像已经讨论的那样,"
-"自动和透明的 对象/关系 映射(object/relational mapping)关注于管理对象的状"
-"态。 这就意味着对象的状态存在于内存,因此直接操作 (使用 SQL <literal>Data "
-"Manipulation Language</literal>(DML,数据操作语言)语句 :<literal>INSERT</"
-"literal> ,<literal>UPDATE</literal> 和 <literal>DELETE</literal>) 数据库中的"
-"数据将不会影响内存中的对象状态和对象数据。 不过,Hibernate提供通过Hibernate查"
-"询语言(<xref linkend=\"queryhql\">HQL</xref>)来执行大批 量SQL风格的DML语句"
-"的方法。"
+"就像已经讨论的那样,自动和透明的对象/关系映射(object/relational mapping)关"
+"注于管理对象的状态。这就意味着对象的状态存在于内存,因此直接操作(使用 SQL "
+"<literal>Data Manipulation Language</literal>(DML,数据操作语言)语句 :"
+"<literal>INSERT</literal> ,<literal>UPDATE</literal> 和 <literal>DELETE</"
+"literal>) 数据库中的数据将不会影响内存中的对象状态和对象数据。不过,"
+"Hibernate 提供通过 Hibernate 查询语言(<xref linkend=\"queryhql\"/>)来执行大"
+"批量 SQL 风格的 DML 语句的方法。 "
 
 #. Tag: para
-#: batch.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The pseudo-syntax for <literal>UPDATE</literal> and <literal>DELETE</"
 "literal> statements is: <literal>( UPDATE | DELETE ) FROM? EntityName (WHERE "
 "where_conditions)?</literal>."
 msgstr ""
-"<literal>UPDATE</literal> 和 <literal>DELETE</literal>语句的语法为: "
+"<literal>UPDATE</literal> 和 <literal>DELETE</literal> 语句的伪语法为:"
 "<literal>( UPDATE | DELETE ) FROM? EntityName (WHERE where_conditions)?</"
-"literal> 有几点说明:"
+"literal>。"
 
 #. Tag: para
-#: batch.xml:151
 #, no-c-format
 msgid "Some points to note:"
-msgstr ""
+msgstr "要注意的事项:"
 
 #. Tag: para
-#: batch.xml:157
 #, no-c-format
 msgid "In the from-clause, the FROM keyword is optional"
-msgstr "在FROM子句(from-clause)中,FROM关键字是可选的"
+msgstr "在 FROM 子句(from-clause)中,FROM 关键字是可选的"
 
 #. Tag: para
-#: batch.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There can only be a single entity named in the from-clause. It can, however, "
 "be aliased. If the entity name is aliased, then any property references must "
 "be qualified using that alias. If the entity name is not aliased, then it is "
 "illegal for any property references to be qualified."
 msgstr ""
-"在FROM子句(from-clause)中只能有一个实体名,它可以是别名。如果实体名是别名,"
-"那么任何被引用的属性都必须加上此别名的前缀;如果不是别名,那么任何有前缀的属"
-"性引用都是非法的。"
+"在 FROM 子句(from-clause)中只能有一个实体名,它可以是别名。如果实体名是别"
+"名,那么任何被引用的属性都必须加上此别名的前缀;如果不是别名,那么任何有前缀"
+"的属性引用都是非法的。 "
 
 #. Tag: para
-#: batch.xml:170
 #, fuzzy, no-c-format
 msgid ""
 "No <link linkend=\"queryhql-joins-forms\">joins</link>, either implicit or "
 "explicit, can be specified in a bulk HQL query. Sub-queries can be used in "
 "the where-clause, where the subqueries themselves may contain joins."
 msgstr ""
-"不能在大批量HQL语句中使用<xref linkend=\"queryhql-joins-forms\">连接(join)</"
-"xref>(显式或者隐式的都不行)。不过在WHERE子句中可以使用子查询。可以在where子"
-"句中使用子查询,子查询本身可以包含join。"
+"不能在大批量 HQL 语句中使用 <xref linkend=\"queryhql-joins-forms\"/> 连接(显"
+"式或者隐式的都不行)。不过在 WHERE 子句中可以使用子查询。可以在 where 子句中"
+"使用子查询,子查询本身可以包含 join。 "
 
 #. Tag: para
-#: batch.xml:177
 #, no-c-format
 msgid "The where-clause is also optional."
-msgstr "整个WHERE子句是可选的。"
+msgstr "整个 WHERE 子句是可选的。"
 
 #. Tag: para
-#: batch.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As an example, to execute an HQL <literal>UPDATE</literal>, use the "
 "<literal>Query.executeUpdate()</literal> method. The method is named for "
 "those familiar with JDBC's <literal>PreparedStatement.executeUpdate()</"
 "literal>:"
 msgstr ""
-"举个例子,使用<literal>Query.executeUpdate()</literal>方法执行一个HQL "
-"<literal>UPDATE</literal>语句(: (方法命名是来源于JDBC's "
-"<literal>PreparedStatement.executeUpdate()</literal>):"
+"举个例子,使用 <literal>Query.executeUpdate()</literal> 方法执行一个 HQL "
+"<literal>UPDATE</literal>语句(方法命名是来源于 JDBC 的 "
+"<literal>PreparedStatement.executeUpdate()</literal>): "
 
-#. Tag: programlisting
-#: batch.xml:189
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlUpdate = \"update Customer c set c.name = :newName where c.name = :"
-"oldName\";\n"
-"// or String hqlUpdate = \"update Customer set name = :newName where name = :"
-"oldName\";\n"
-"int updatedEntities = s.createQuery( hqlUpdate )\n"
-"        .setString( \"newName\", newName )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: batch.xml:191
 #, fuzzy, no-c-format
 msgid ""
 "In keeping with the EJB3 specification, HQL <literal>UPDATE</literal> "
@@ -403,71 +267,36 @@
 "<literal>VERSIONED</literal> keyword after the <literal>UPDATE</literal> "
 "keyword."
 msgstr ""
-"HQL <literal>UPDATE</literal>语句,默认不会影响更新实体的<xref linkend="
-"\"mapping-declaration-version\">version</xref>或者<xref linkend=\"mapping-"
-"declaration-timestamp\">timestamp</xref>属性值。这和EJB3规范是一致的。但是,"
-"通过使用<literal>versioned update</literal>,你可以强制Hibernate正确的重置"
-"<literal>version</literal>或者<literal>timestamp</literal>属性值。这通过在"
-"<literal>UPDATE</literal>关键字后面增加<literal>VERSIONED</literal>关键字来实"
-"现的。"
+"HQL <literal>UPDATE</literal> 语句,默认不会影响更新实体的 <xref linkend="
+"\"mapping-declaration-version\"/> 或者 <xref linkend=\"mapping-declaration-"
+"timestamp\"/> 属性值。这和 EJB3 规范是一致的。但是,通过使用 "
+"<literal>versioned update</literal>,你可以强制 Hibernate 正确的重置"
+"<literal>version</literal> 或者 <literal>timestamp</literal> 属性值。这通过"
+"在 <literal>UPDATE</literal> 关键字后面增加 <literal>VERSIONED</literal> 关键"
+"字来实现的。 "
 
-#. Tag: programlisting
-#: batch.xml:201
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"String hqlVersionedUpdate = \"update versioned Customer set name = :newName "
-"where name = :oldName\";\n"
-"int updatedEntities = s.createQuery( hqlUpdate )\n"
-"        .setString( \"newName\", newName )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:203
-#, fuzzy, no-c-format
-msgid ""
 "Custom version types, <literal>org.hibernate.usertype.UserVersionType</"
 "literal>, are not allowed in conjunction with a <literal>update versioned</"
 "literal> statement."
 msgstr ""
-"注意,自定义的版本类型(<literal>org.hibernate.usertype.UserVersionType</"
-"literal>)不允许和<literal>update versioned</literal>语句联用。"
+"注意,自定义的版本类型(<literal>org.hibernate.usertype.UserVersionType</"
+"literal>)不允许和 <literal>update versioned</literal> 语句联用。 "
 
 #. Tag: para
-#: batch.xml:208
 #, no-c-format
 msgid ""
 "To execute an HQL <literal>DELETE</literal>, use the same <literal>Query."
 "executeUpdate()</literal> method:"
 msgstr ""
-"执行一个HQL <literal>DELETE</literal>,同样使用 <literal>Query.executeUpdate"
-"()</literal> 方法:"
+"执行一个 HQL <literal>DELETE</literal>,同样使用 <literal>Query.executeUpdate"
+"()</literal> 方法:"
 
-#. Tag: programlisting
-#: batch.xml:213
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlDelete = \"delete Customer c where c.name = :oldName\";\n"
-"// or String hqlDelete = \"delete Customer where name = :oldName\";\n"
-"int deletedEntities = s.createQuery( hqlDelete )\n"
-"        .setString( \"oldName\", oldName )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: batch.xml:215
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>int</literal> value returned by the <literal>Query.executeUpdate"
 "()</literal> method indicates the number of entities effected by the "
 "operation. This may or may not correlate to the number of rows effected in "
@@ -479,37 +308,35 @@
 "which that subclass is mapped, but also the \"root\" table and potentially "
 "joined-subclass tables further down the inheritance hierarchy."
 msgstr ""
-"由<literal>Query.executeUpdate()</literal>方法返回的<literal>整型</literal>值"
-"表明了受此操作影响的记录数量。 注意这个数值可能与数据库中被(最后一条SQL语"
-"句)影响了的“行”数有关,也可能没有。一个大批量HQL操作可能导致多条实际的SQL语"
-"句被执行, 举个例子,对joined-subclass映射方式的类进行的此类操作。这个返回值"
-"代表了实际被语句影响了的记录数量。在那个joined-subclass的例子中, 对一个子类"
-"的删除实际上可能不仅仅会删除子类映射到的表而且会影响“根”表,还有可能影响与之"
-"有继承关系的joined-subclass映射方式的子类的表。"
+"由 <literal>Query.executeUpdate()</literal> 方法返回的<literal>整型</literal>"
+"值表明了受此操作影响的记录数量。注意这个数值可能与数据库中被(最后一条 SQL 语"
+"句)影响了的“行”数有关,也可能没有。一个大批量 HQL 操作可能导致多条实际的SQL"
+"语句被执行,举个例子,对 joined-subclass 映射方式的类进行的此类操作。这个返回"
+"值代表了实际被语句影响了的记录数量。在那个 joined-subclass 的例子中, 对一个"
+"子类的删除实际上可能不仅仅会删除子类映射到的表而且会影响“根”表,还有可能影响"
+"与之有继承关系的 joined-subclass 映射方式的子类的表。 "
 
 #. Tag: para
-#: batch.xml:226
 #, no-c-format
 msgid ""
 "The pseudo-syntax for <literal>INSERT</literal> statements is: "
 "<literal>INSERT INTO EntityName properties_list select_statement</literal>. "
 "Some points to note:"
 msgstr ""
-"<literal>INSERT</literal>语句的伪码是: <literal>INSERT INTO EntityName "
-"properties_list select_statement</literal>. 要注意的是:"
+"<literal>INSERT</literal> 语句的伪码是:<literal>INSERT INTO EntityName "
+"properties_list select_statement</literal>。要注意的是:"
 
 #. Tag: para
-#: batch.xml:234
 #, no-c-format
 msgid ""
 "Only the INSERT INTO ... SELECT ... form is supported; not the INSERT "
 "INTO ... VALUES ... form."
 msgstr ""
-"只支持INSERT INTO ... SELECT ...形式,不支持INSERT INTO ... VALUES ...形式."
+"只支持 INSERT INTO ... SELECT ... 形式,不支持 INSERT INTO ... VALUES ... 形"
+"式。"
 
 #. Tag: para
-#: batch.xml:237
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The properties_list is analogous to the <literal>column specification</"
 "literal> in the SQL <literal>INSERT</literal> statement. For entities "
@@ -518,14 +345,13 @@
 "are not allowed and subclass properties do not make sense. In other words, "
 "<literal>INSERT</literal> statements are inherently non-polymorphic."
 msgstr ""
-"properties_list和SQL <literal>INSERT</literal>语句中的<literal>字段定义"
-"(column speficiation)</literal>类似。对参与继承树映射的实体而言,只有直接定义"
-"在给定的类级别的属性才能直接在properties_list中使用。超类的属性不被支持;子类"
-"的属性无意义。换句话说,<literal>INSERT</literal>天生不支持多态。"
+"properties_list 和 SQL <literal>INSERT</literal> 语句中的<literal>字段定义"
+"(column speficiation)</literal>类似。对参与继承树映射的实体而言,只有直接定"
+"义在给定的类级别的属性才能直接在 properties_list 中使用。超类的属性不被支持;"
+"子类的属性无意义。换句话说,<literal>INSERT</literal> 天生不支持多态性。"
 
 #. Tag: para
-#: batch.xml:247
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "select_statement can be any valid HQL select query, with the caveat that the "
 "return types must match the types expected by the insert. Currently, this is "
@@ -538,17 +364,16 @@
 "TimestampType</literal>, even though the database might not make a "
 "distinction or might be able to handle the conversion."
 msgstr ""
-"select_statement可以是任何合法的HQL选择查询,不过要保证返回类型必须和要插入的"
-"类型完全匹配。目前,这一检查是在查询编译的时候进行的,而不是把它交给数据库。"
-"注意,在Hibernate<literal>Type</literal>间如果只是<emphasis>等价"
-"(equivalent)</emphasis>而非<emphasis>相等(equal)</emphasis>,会导致问题。定"
-"义为<literal>org.hibernate.type.DateType</literal>和<literal>org.hibernate."
-"type.TimestampType</literal>的两个属性可能会产生类型不匹配错误,虽然数据库级"
-"可能不加区分或者可以处理这种转换。"
+"select_statement 可以是任何合法的 HQL 选择查询,不过要保证返回类型必须和要插"
+"入的类型完全匹配。目前,这一检查是在查询编译的时候进行的,而不是把它交给数据"
+"库。注意,在Hibernate<literal>Type</literal> 间如果只是<emphasis>等价"
+"(equivalent)</emphasis>而非<emphasis>相等(equal)</emphasis>,会导致问题。"
+"定义为 <literal>org.hibernate.type.DateType</literal> 和 <literal>org."
+"hibernate.type.TimestampType</literal> 的两个属性可能会产生类型不匹配错误,虽"
+"然数据库级可能不加区分或者可以处理这种转换。 "
 
 #. Tag: para
-#: batch.xml:259
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For the id property, the insert statement gives you two options. You can "
 "either explicitly specify the id property in the properties_list, in which "
@@ -564,19 +389,18 @@
 "TableHiLoGenerator</literal>, which cannot be used because it does not "
 "expose a selectable way to get its values."
 msgstr ""
-"对id属性来说,insert语句给你两个选择。你可以明确地在properties_list表中指定id"
-"属性(这样它的值是从对应的select表达式中获得),或者在properties_list中省略它"
-"(此时使用生成指)。后一种选择只有当使用在数据库中生成值的id产生器时才能使"
-"用;如果是“内存”中计算的类型生成器,在解析时会抛出一个异常。注意,为了说明这"
-"一问题,数据库产生值的生成器是<literal>org.hibernate.id.SequenceGenerator</"
-"literal>(和它的子类),以及任何<literal>org.hibernate.id."
-"PostInsertIdentifierGenerator</literal>接口的实现。这儿最值得注意的意外是"
-"<literal>org.hibernate.id.TableHiLoGenerator</literal>,它不能在此使用,因为"
-"它没有得到其值的途径。"
+"对 id 属性来说,insert 语句给你两个选择。你可以明确地在 properties_list 表中"
+"指定 id 属性(这样它的值是从对应的 select 表达式中获得),或者在 "
+"properties_list 中省略它(此时使用生成指)。后一种选择只有当使用在数据库中生"
+"成值的 id 产生器时才能使用;如果是“内存”中计算的类型生成器,在解析时会抛出一"
+"个异常。注意,为了说明这一问题,数据库产生值的生成器是 <literal>org."
+"hibernate.id.SequenceGenerator</literal>(和它的子类),以及任何 "
+"<literal>org.hibernate.id.PostInsertIdentifierGenerator</literal> 接口的实"
+"现。这儿最值得注意的意外是 <literal>org.hibernate.id.TableHiLoGenerator</"
+"literal>,它不能在此使用,因为它没有得到其值的途径。 "
 
 #. Tag: para
-#: batch.xml:274
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For properties mapped as either <literal>version</literal> or "
 "<literal>timestamp</literal>, the insert statement gives you two options. "
@@ -585,31 +409,241 @@
 "from the properties_list, in which case the <literal>seed value</literal> "
 "defined by the <literal>org.hibernate.type.VersionType</literal> is used."
 msgstr ""
-"对映射为<literal>version</literal> 或 <literal>timestamp</literal>的属性来"
-"说,insert语句也给你两个选择,你可以在properties_list表中指定(此时其值从对应"
-"的select表达式中获得),或者在properties_list中省略它(此时,使用在"
-"<literal>org.hibernate.type.VersionType</literal> 中定义的<literal>seed value"
-"(种子值)</literal>)。"
+"对映射为 <literal>version</literal> 或 <literal>timestamp</literal> 的属性来"
+"说,insert 语句也给你两个选择,你可以在 properties_list 表中指定(此时其值从"
+"对应的 select 表达式中获得),或者在 properties_list 中省略它(此时,使用在 "
+"<literal>org.hibernate.type.VersionType</literal> 中定义的 <literal>seed "
+"value(种子值)</literal>)。"
 
 #. Tag: para
-#: batch.xml:284
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is an example of an HQL <literal>INSERT</literal> statement "
 "execution:"
-msgstr "执行HQL <literal>INSERT</literal>语句的例子如下:"
+msgstr "下面是一个执行 HQL <literal>INSERT</literal> 语句的例子:"
 
-#. Tag: programlisting
-#: batch.xml:288
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = sessionFactory.openSession();\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"String hqlInsert = \"insert into DelinquentAccount (id, name) select c.id, c."
-"name from Customer c where ...\";\n"
-"int createdEntities = s.createQuery( hqlInsert )\n"
-"        .executeUpdate();\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "for ( int i=0; i<100000; i++ ) {\n"
+#~ "    Customer customer = new Customer(.....);\n"
+#~ "    session.save(customer);\n"
+#~ "}\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "for ( int i=0; i<100000; i++ ) {\n"
+#~ "    Customer customer = new Customer(.....);\n"
+#~ "    session.save(customer);\n"
+#~ "}\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+
+#~ msgid "<![CDATA[hibernate.jdbc.batch_size 20]]>"
+#~ msgstr "<![CDATA[hibernate.jdbc.batch_size 20]]>"
+
+#~ msgid "<![CDATA[hibernate.cache.use_second_level_cache false]]>"
+#~ msgstr "<![CDATA[hibernate.cache.use_second_level_cache false]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "for ( int i=0; i<100000; i++ ) {\n"
+#~ "    Customer customer = new Customer(.....);\n"
+#~ "    session.save(customer);\n"
+#~ "    if ( i % 20 == 0 ) { //20, same as the JDBC batch size\n"
+#~ "        //flush a batch of inserts and release memory:\n"
+#~ "        session.flush();\n"
+#~ "        session.clear();\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "for ( int i=0; i<100000; i++ ) {\n"
+#~ "    Customer customer = new Customer(.....);\n"
+#~ "    session.save(customer);\n"
+#~ "    if ( i % 20 == 0 ) { //20, same as the JDBC batch size\n"
+#~ "        //flush a batch of inserts and release memory:\n"
+#~ "        session.flush();\n"
+#~ "        session.clear();\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
+#~ "    .setCacheMode(CacheMode.IGNORE)\n"
+#~ "    .scroll(ScrollMode.FORWARD_ONLY);\n"
+#~ "int count=0;\n"
+#~ "while ( customers.next() ) {\n"
+#~ "    Customer customer = (Customer) customers.get(0);\n"
+#~ "    customer.updateStuff(...);\n"
+#~ "    if ( ++count % 20 == 0 ) {\n"
+#~ "        //flush a batch of updates and release memory:\n"
+#~ "        session.flush();\n"
+#~ "        session.clear();\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
+#~ "    .setCacheMode(CacheMode.IGNORE)\n"
+#~ "    .scroll(ScrollMode.FORWARD_ONLY);\n"
+#~ "int count=0;\n"
+#~ "while ( customers.next() ) {\n"
+#~ "    Customer customer = (Customer) customers.get(0);\n"
+#~ "    customer.updateStuff(...);\n"
+#~ "    if ( ++count % 20 == 0 ) {\n"
+#~ "        //flush a batch of updates and release memory:\n"
+#~ "        session.flush();\n"
+#~ "        session.clear();\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[StatelessSession session = sessionFactory.openStatelessSession"
+#~ "();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
+#~ "    .scroll(ScrollMode.FORWARD_ONLY);\n"
+#~ "while ( customers.next() ) {\n"
+#~ "    Customer customer = (Customer) customers.get(0);\n"
+#~ "    customer.updateStuff(...);\n"
+#~ "    session.update(customer);\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[StatelessSession session = sessionFactory.openStatelessSession"
+#~ "();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "   \n"
+#~ "ScrollableResults customers = session.getNamedQuery(\"GetCustomers\")\n"
+#~ "    .scroll(ScrollMode.FORWARD_ONLY);\n"
+#~ "while ( customers.next() ) {\n"
+#~ "    Customer customer = (Customer) customers.get(0);\n"
+#~ "    customer.updateStuff(...);\n"
+#~ "    session.update(customer);\n"
+#~ "}\n"
+#~ "   \n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlUpdate = \"update Customer c set c.name = :newName where c.name "
+#~ "= :oldName\";\n"
+#~ "// or String hqlUpdate = \"update Customer set name = :newName where name "
+#~ "= :oldName\";\n"
+#~ "int updatedEntities = s.createQuery( hqlUpdate )\n"
+#~ "        .setString( \"newName\", newName )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlUpdate = \"update Customer c set c.name = :newName where c.name "
+#~ "= :oldName\";\n"
+#~ "// or String hqlUpdate = \"update Customer set name = :newName where name "
+#~ "= :oldName\";\n"
+#~ "int updatedEntities = s.createQuery( hqlUpdate )\n"
+#~ "        .setString( \"newName\", newName )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "String hqlVersionedUpdate = \"update versioned Customer set name = :"
+#~ "newName where name = :oldName\";\n"
+#~ "int updatedEntities = s.createQuery( hqlUpdate )\n"
+#~ "        .setString( \"newName\", newName )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "String hqlVersionedUpdate = \"update versioned Customer set name = :"
+#~ "newName where name = :oldName\";\n"
+#~ "int updatedEntities = s.createQuery( hqlUpdate )\n"
+#~ "        .setString( \"newName\", newName )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlDelete = \"delete Customer c where c.name = :oldName\";\n"
+#~ "// or String hqlDelete = \"delete Customer where name = :oldName\";\n"
+#~ "int deletedEntities = s.createQuery( hqlDelete )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlDelete = \"delete Customer c where c.name = :oldName\";\n"
+#~ "// or String hqlDelete = \"delete Customer where name = :oldName\";\n"
+#~ "int deletedEntities = s.createQuery( hqlDelete )\n"
+#~ "        .setString( \"oldName\", oldName )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlInsert = \"insert into DelinquentAccount (id, name) select c."
+#~ "id, c.name from Customer c where ...\";\n"
+#~ "int createdEntities = s.createQuery( hqlInsert )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sessionFactory.openSession();\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "String hqlInsert = \"insert into DelinquentAccount (id, name) select c."
+#~ "id, c.name from Customer c where ...\";\n"
+#~ "int createdEntities = s.createQuery( hqlInsert )\n"
+#~ "        .executeUpdate();\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/best_practices.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/best_practices.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/best_practices.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,32 +1,34 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-11-06 10:05+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: best_practices.xml:29
 #, no-c-format
 msgid "Best Practices"
-msgstr "最佳实践(Best Practices)"
+msgstr "最佳实践(Best Practices)"
 
 #. Tag: term
-#: best_practices.xml:33
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Write fine-grained classes and map them using <literal>&lt;component&gt;</"
 "literal>:"
 msgstr ""
-"设计细颗粒度的持久类并且使用<literal>&lt;component&gt;</literal>来实现映射。"
+"设计细颗粒度的持久类并且使用 <literal>&lt;component&gt;</literal> 来实现映"
+"射:"
 
 #. Tag: para
-#: best_practices.xml:35
 #, no-c-format
 msgid ""
 "Use an <literal>Address</literal> class to encapsulate <literal>street</"
@@ -34,35 +36,31 @@
 "<literal>postcode</literal>. This encourages code reuse and simplifies "
 "refactoring."
 msgstr ""
-"使用一个<literal>Address</literal>持久类来封装 <literal>street</literal>, "
-"<literal>suburb</literal>, <literal>state</literal>, <literal>postcode</"
-"literal>. 这将有利于代码重用和简化代码重构(refactoring)的工作。"
+"使用一个 <literal>Address</literal> 持久类来封装 <literal>street</literal>,"
+"<literal>suburb</literal>,<literal>state</literal>,<literal>postcode</"
+"literal>。 这将有利于代码重用和简化代码重构(refactoring)的工作。"
 
 #. Tag: term
-#: best_practices.xml:43
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Declare identifier properties on persistent classes:"
-msgstr "对持久类声明标识符属性( identifier properties)。"
+msgstr "对持久类声明标识符属性(identifier properties):"
 
 #. Tag: para
-#: best_practices.xml:45
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate makes identifier properties optional. There are a range of reasons "
 "why you should use them. We recommend that identifiers be 'synthetic', that "
 "is, generated with no business meaning."
 msgstr ""
-"Hibernate中标识符属性是可选的,不过有很多原因来说明你应该使用标识符属性。我们"
-"建议标识符应该是“人造”的(自动生成,不涉及业务含义)。"
+"Hibernate 中标识符属性是可选的,不过有很多原因来说明你应该使用标识符属性。我"
+"们建议标识符应该是“人造”的(自动生成,不涉及业务含义)。 "
 
 #. Tag: term
-#: best_practices.xml:53
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Identify natural keys:"
-msgstr "使用自然键(natural keys)标识"
+msgstr "使用自然键(natural keys)标识:"
 
 #. Tag: para
-#: best_practices.xml:55
 #, no-c-format
 msgid ""
 "Identify natural keys for all entities, and map them using <literal>&lt;"
@@ -70,102 +68,90 @@
 "<literal>hashCode()</literal> to compare the properties that make up the "
 "natural key."
 msgstr ""
-"对所有的实体都标识出自然键,用<literal>&lt;natural-id&gt;</literal>进行映射。"
-"实现<literal>equals()</literal>和<literal>hashCode()</literal>,在其中用组成"
-"自然键的属性进行比较。"
+"对所有的实体都标识出自然键,用 <literal>&lt;natural-id&gt;</literal> 进行映"
+"射。实现 <literal>equals()</literal> 和 <literal>hashCode()</literal>,在其中"
+"用组成自然键的属性进行比较。"
 
 #. Tag: term
-#: best_practices.xml:63
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Place each class mapping in its own file:"
-msgstr "为每个持久类写一个映射文件"
+msgstr "为每个持久类写一个映射文件:"
 
 #. Tag: para
-#: best_practices.xml:65
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not use a single monolithic mapping document. Map <literal>com.eg.Foo</"
 "literal> in the file <literal>com/eg/Foo.hbm.xml</literal>. This makes "
 "sense, particularly in a team environment."
 msgstr ""
 "不要把所有的持久类映射都写到一个大文件中。把 <literal>com.eg.Foo</literal> 映"
-"射到<literal>com/eg/Foo.hbm.xml</literal>中, 在团队开发环境中,这一点显得特"
-"别有意义。"
+"射到 <literal>com/eg/Foo.hbm.xml</literal> 中。在团队开发环境中,这一点尤其重"
+"要。"
 
 #. Tag: term
-#: best_practices.xml:73
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Load mappings as resources:"
-msgstr "把映射文件作为资源加载"
+msgstr "把映射文件作为资源加载:"
 
 #. Tag: para
-#: best_practices.xml:75
 #, no-c-format
 msgid "Deploy the mappings along with the classes they map."
 msgstr "把映射文件和他们的映射类放在一起进行部署。"
 
 #. Tag: term
-#: best_practices.xml:81
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Consider externalizing query strings:"
-msgstr "考虑把查询字符串放在程序外面"
+msgstr "考虑把查询字符串放在程序外面:"
 
 #. Tag: para
-#: best_practices.xml:83
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is recommended if your queries call non-ANSI-standard SQL functions. "
 "Externalizing the query strings to mapping files will make the application "
 "more portable."
 msgstr ""
-"如果你的查询中调用了非ANSI标准的SQL函数,那么这条实践经验对你适用。把查询字符"
-"串放在映射文件中可以让程序具有更好的可移植性。"
+"如果你的查询中调用了非 ANSI 标准的 SQL 函数,那么这条实践经验对你适用。把查询"
+"字符串放在映射文件中可以让程序具有更好的可移植性。 "
 
 #. Tag: term
-#: best_practices.xml:91
 #, no-c-format
 msgid "Use bind variables."
 msgstr "使用绑定变量"
 
 #. Tag: para
-#: best_practices.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As in JDBC, always replace non-constant values by \"?\". Do not use string "
 "manipulation to bind a non-constant value in a query. You should also "
 "consider using named parameters in queries."
 msgstr ""
-"就像在JDBC编程中一样,应该总是用占位符\"?\"来替换非常量值,不要在查询中用字符"
-"串值来构造非常量值!更好的办法是在查询中使用命名参数。"
+"就像在 JDBC 编程中一样,应该总是用占位符 \"?\" 来替换非常量值,不要在查询中用"
+"字符串值来构造非常量值。你也应该考虑在查询中使用命名参数。"
 
 #. Tag: term
-#: best_practices.xml:101
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Do not manage your own JDBC connections:"
-msgstr "不要自己来管理JDBC connections"
+msgstr "不要自己来管理 JDBC 连接:"
 
 #. Tag: para
-#: best_practices.xml:103
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate allows the application to manage JDBC connections, but his "
 "approach should be considered a last-resort. If you cannot use the built-in "
 "connection providers, consider providing your own implementation of "
 "<literal>org.hibernate.connection.ConnectionProvider</literal>."
 msgstr ""
-"Hibernate允许应用程序自己来管理JDBC connections,但是应该作为最后没有办法的办"
-"法。如果你不能使用Hibernate内建的connections providers,那么考虑实现自己来实"
-"现<literal>org.hibernate.connection.ConnectionProvider</literal>"
+"Hibernate 允许应用程序自己来管理 JDBC 连接,但是应该作为最后没有办法的办法。"
+"如果你不能使用 Hibernate 内建的 connections providers,那么考虑实现自己来实"
+"现 <literal>org.hibernate.connection.ConnectionProvider</literal>。"
 
 #. Tag: term
-#: best_practices.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Consider using a custom type:"
-msgstr "考虑使用用户自定义类型(custom type)"
+msgstr "考虑使用用户自定义类型(custom type):"
 
 #. Tag: para
-#: best_practices.xml:113
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Suppose you have a Java type from a library that needs to be persisted but "
 "does not provide the accessors needed to map it as a component. You should "
@@ -173,51 +159,41 @@
 "approach frees the application code from implementing transformations to/"
 "from a Hibernate type."
 msgstr ""
-"假设你有一个Java类型,来自某些类库,需要被持久化,但是该类没有提供映射操作需"
-"要的存取方法。那么你应该考虑实现<literal>org.hibernate.UserType</literal>接"
-"口。这种办法使程序代码写起来更加自如,不再需要考虑类与Hibernate type之间的相"
-"互转换。"
+"假设你有一个 Java 类型,来自某些类库,需要被持久化,但是该类没有提供映射操作"
+"需要的存取方法。那么你应该考虑实现 <literal>org.hibernate.UserType</literal> "
+"接口。这种办法使程序代码写起来更加自如,不再需要考虑类与 Hibernate type 之间"
+"的相互转换。 "
 
 #. Tag: term
-#: best_practices.xml:122
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Use hand-coded JDBC in bottlenecks:"
-msgstr "在性能瓶颈的地方使用硬编码的JDBC"
+msgstr "在性能瓶颈的地方使用硬编码的 JDBC:"
 
 #. Tag: para
-#: best_practices.xml:124
 #, fuzzy, no-c-format
 msgid ""
 "In performance-critical areas of the system, some kinds of operations might "
 "benefit from direct JDBC. Do not assume, however, that JDBC is necessarily "
 "faster. Please wait until you <emphasis>know</emphasis> something is a "
 "bottleneck. If you need to use direct JDBC, you can open a Hibernate "
-"<literal>Session</literal> and usingfile:///usr/share/doc/HTML/en-US/index."
-"html that JDBC connection. This way you can still use the same transaction "
-"strategy and underlying connection provider."
+"<literal>Session</literal>, wrap your JDBC operation as a <literal>org."
+"hibernate.jdbc.Work</literal> object and using that JDBC connection. This "
+"way you can still use the same transaction strategy and underlying "
+"connection provider."
 msgstr ""
-"In performance-critical areas of the system, some kinds of operations might "
-"benefit from direct JDBC. But please, wait until you <emphasis>know</"
-"emphasis> something is a bottleneck. And don't assume that direct JDBC is "
-"necessarily faster. If you need to use direct JDBC, it might be worth "
-"opening a Hibernate <literal>Session</literal> and using that JDBC "
-"connection. That way you can still use the same transaction strategy and "
-"underlying connection provider. 在系统中对性能要求很严格的一些部分,某些操作"
-"也许直接使用JDBC会更好。但是请先<emphasis>确认</emphasis>这的确是一个瓶颈,并"
-"且不要想当然认为JDBC一定会更快。如果确实需要直接使用JDBC,那么最好打开一个 "
-"Hibernate <literal>Session</literal> 然后从 <literal>Session</literal>获得"
-"connection,按照这种办法你仍然可以使用同样的transaction策略和底层的"
-"connection provider。"
+"在系统中对性能要求很严格的一些部分,某些操作也许直接使用 JDBC 会更好。但是请"
+"先<emphasis>确认</emphasis>这的确是一个瓶颈,并且不要想当然认为 JDBC 一定会更"
+"快。如果确实需要直接使用 JDBC,那么最好打开一个 Hibernate <literal>Session</"
+"literal> 然后从 <literal>Session</literal> 获得 connection,按照这种办法你仍"
+"然可以使用同样的 transaction 策略和底层的 connection provider。 "
 
 #. Tag: term
-#: best_practices.xml:134
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Understand <literal>Session</literal> flushing:"
-msgstr "理解<literal>Session</literal>清洗( flushing)"
+msgstr "理解 <literal>Session</literal> 冲刷(flushing):"
 
 #. Tag: para
-#: best_practices.xml:136
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes the Session synchronizes its persistent state with the database. "
 "Performance will be affected if this process occurs too often. You can "
@@ -225,19 +201,17 @@
 "even by changing the order of queries and other operations within a "
 "particular transaction."
 msgstr ""
-"Session会不时的向数据库同步持久化状态,如果这种操作进行的过于频繁,性能会受到"
-"一定的影响。有时候你可以通过禁止自动flushing,尽量最小化非必要的flushing操"
-"作,或者更进一步,在一个特定的transaction中改变查询和其它操作的顺序。"
+"Session 会不时的向数据库同步持久化状态,如果这种操作进行的过于频繁,性能会受"
+"到一定的影响。有时候你可以通过禁止自动 flushing,尽量最小化非必要的 flushing "
+"操作,或者更进一步,在一个特定的 transaction 中改变查询和其它操作的顺序。 "
 
 #. Tag: term
-#: best_practices.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "In a three tiered architecture, consider using detached objects:"
-msgstr "在三层结构中,考虑使用托管对象(detached object)"
+msgstr "在三层结构中,考虑使用脱管对象(detached object):"
 
 #. Tag: para
-#: best_practices.xml:147
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When using a servlet/session bean architecture, you can pass persistent "
 "objects loaded in the session bean to and from the servlet/JSP layer. Use a "
@@ -245,20 +219,18 @@
 "or <literal>Session.saveOrUpdate()</literal> to synchronize objects with the "
 "database."
 msgstr ""
-"当使用一个servlet / session bean 类型的架构的时候, 你可以把已加载的持久对象在"
-"session bean层和servlet / JSP 层之间来回传递。使用新的session来为每个请求服"
-"务,使用 <literal>Session.merge()</literal> 或者<literal>Session.saveOrUpdate"
-"()</literal>来与数据库同步。"
+"当使用一个 servlet / session bean 类型的架构的时候, 你可以把已加载的持久对象"
+"在 session bean 层和 servlet / JSP 层之间来回传递。使用新的 session 来为每个"
+"请求服务,使用 <literal>Session.merge()</literal> 或者 <literal>Session."
+"saveOrUpdate()</literal> 来与数据库同步。 "
 
 #. Tag: term
-#: best_practices.xml:156
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "In a two tiered architecture, consider using long persistence contexts:"
-msgstr "在两层结构中,考虑使用长持久上下文(long persistence contexts)."
+msgstr "在两层结构中,考虑使用长持久上下文(long persistence contexts):"
 
 #. Tag: para
-#: best_practices.xml:158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Database Transactions have to be as short as possible for best scalability. "
 "However, it is often necessary to implement long running "
@@ -273,23 +245,21 @@
 "across more than one application transaction or you will be working with "
 "stale data."
 msgstr ""
-"为了得到最佳的可伸缩性,数据库事务(Database Transaction)应该尽可能的短。但"
-"是,程序常常需要实现长时间运行的<emphasis>“应用程序事务(Application "
-"Transaction)”</emphasis>,包含一个从用户的观点来看的原子操作。这个应用程序事"
-"务可能跨越多次从用户请求到得到反馈的循环。用脱管对象(与session脱离的对象)来实"
-"现应用程序事务是常见的。或者,尤其在两层结构中,把Hibernate Session从JDBC连接"
-"中脱离开,下次需要用的时候再连接上。绝不要把一个Session用在多个应用程序事务"
-"(Application Transaction)中,否则你的数据可能会过期失效。"
+"为了得到最佳的可伸缩性,数据库事务(Database Transaction)应该尽可能的短。但"
+"是,程序常常需要实现长时间运行的<emphasis>“应用程序事务(Application "
+"Transaction)”</emphasis>,包含一个从用户的观点来看的原子操作。这个应用程序事"
+"务可能跨越多次从用户请求到得到反馈的循环。用脱管对象(与 session 脱离的对象)"
+"来实现应用程序事务是常见的。或者,尤其在两层结构中,把 Hibernate Session 从 "
+"JDBC 连接中脱离开,下次需要用的时候再连接上。绝不要把一个 Session 用在多个应"
+"用程序事务(Application Transaction)中,否则你的数据可能会过期失效。"
 
 #. Tag: term
-#: best_practices.xml:172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Do not treat exceptions as recoverable:"
-msgstr "不要把异常看成可恢复的"
+msgstr "不要把异常看成可恢复的:"
 
 #. Tag: para
-#: best_practices.xml:174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is more of a necessary practice than a \"best\" practice. When an "
 "exception occurs, roll back the <literal>Transaction</literal> and close the "
@@ -300,20 +270,18 @@
 "<literal>Session.get()</literal> or a query instead."
 msgstr ""
 "这一点甚至比“最佳实践”还要重要,这是“必备常识”。当异常发生的时候,必须要回滚 "
-"<literal>Transaction</literal> ,关闭<literal>Session</literal>。如果你不这样"
-"做的话,Hibernate无法保证内存状态精确的反应持久状态。尤其不要使用"
-"<literal>Session.load()</literal>来判断一个给定标识符的对象实例在数据库中是否"
-"存在,应该使用<literal>Session.get()</literal>或者进行一次查询."
+"<literal>Transaction</literal> ,关闭 <literal>Session</literal>。如果你不这"
+"样做的话,Hibernate 无法保证内存状态精确的反应持久状态。尤其不要使用 "
+"<literal>Session.load()</literal> 来判断一个给定标识符的对象实例在数据库中是"
+"否存在,应该使用 <literal>Session.get()</literal> 或者进行一次查询。"
 
 #. Tag: term
-#: best_practices.xml:184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Prefer lazy fetching for associations:"
-msgstr "对于关联优先考虑lazy fetching"
+msgstr "对于关联优先考虑 lazy fetching:"
 
 #. Tag: para
-#: best_practices.xml:186
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use eager fetching sparingly. Use proxies and lazy collections for most "
 "associations to classes that are not likely to be completely held in the "
@@ -323,26 +291,24 @@
 "to a particular use case, use a query with a <literal>left join fetch</"
 "literal>."
 msgstr ""
-"谨慎的使用主动抓取(eager fetching)。对于关联来说,若其目标是无法在第二级缓存"
-"中完全缓存所有实例的类,应该使用代理(proxies)与/或具有延迟加载属性的集合"
-"(lazy collections)。若目标是可以被缓存的,尤其是缓存的命中率非常高的情况下,"
-"应该使用<literal>lazy=\"false\"</literal>,明确的禁止掉eager fetching。如果那"
-"些特殊的确实适合使用join fetch 的场合,请在查询中使用<literal>left join "
-"fetch</literal>。"
+"谨慎的使用主动抓取(eager fetching)。对于关联来说,若其目标是无法在第二级缓"
+"存中完全缓存所有实例的类,应该使用代理(proxies)与/或具有延迟加载属性的集合"
+"(lazy collections)。若目标是可以被缓存的,尤其是缓存的命中率非常高的情况"
+"下,应该使用 <literal>lazy=\"false\"</literal>,明确的禁止掉 eager fetching。"
+"如果那些特殊的确实适合使用 join fetch 的场合,请在查询中使用 <literal>left "
+"join fetch</literal>。 "
 
 #. Tag: term
-#: best_practices.xml:196
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use the <emphasis>open session in view</emphasis> pattern, or a disciplined "
 "<emphasis>assembly phase</emphasis> to avoid problems with unfetched data:"
 msgstr ""
-"使用<emphasis>open session in view</emphasis>模式,或者执行严格的<emphasis>装"
-"配期(assembly phase)</emphasis>策略来避免再次抓取数据带来的问题"
+"使用 <emphasis>open session in view</emphasis> 模式,或者执行严格的<emphasis>"
+"装配期(assembly phase)</emphasis>策略来避免再次抓取数据带来的问题:"
 
 #. Tag: para
-#: best_practices.xml:201
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate frees the developer from writing tedious <emphasis>Data Transfer "
 "Objects</emphasis> (DTO). In a traditional EJB architecture, DTOs serve dual "
@@ -357,24 +323,22 @@
 "objects. This is not a limitation of Hibernate. It is a fundamental "
 "requirement of safe transactional data access."
 msgstr ""
-"Hibernate让开发者们摆脱了繁琐的<emphasis>Data Transfer Objects</emphasis> "
-"(DTO)。在传统的EJB结构中,DTO有双重作用:首先,他们解决了entity bean无法序列"
-"化的问题;其次,他们隐含地定义了一个装配期,在此期间,所有在view层需要用到的"
-"数据,都被抓取、集中到了DTO中,然后控制才被装到表示层。Hibernate终结了第一个"
-"作用。然而,除非你做好了在整个渲染过程中都维护一个打开的持久化上下文(session)"
-"的准备,你仍然需要一个装配期(想象一下,你的业务方法与你的表示层有严格的契"
-"约,数据总是被放置到托管对象中)。这并非是Hibernate的限制!这是实现安全的事务"
-"化数据访问的基本需求。"
+"Hibernate 让开发者们摆脱了繁琐的 <emphasis>Data Transfer Objects</emphasis>"
+"(DTO)。在传统的 EJB 结构中,DTO 有双重作用:首先,他们解决了 entity bean 无"
+"法序列化的问题;其次,他们隐含地定义了一个装配期,在此期间,所有在 view 层需"
+"要用到的数据,都被抓取、集中到了 DTO 中,然后控制才被装到表示层。Hibernate 终"
+"结了第一个作用。然而,除非你做好了在整个渲染过程中都维护一个打开的持久化上下"
+"文(session)的准备,你仍然需要一个装配期(想象一下,你的业务方法与你的表示层"
+"有严格的契约,数据总是被放置到脱管对象中)。这并非是 Hibernate 的限制,这是实"
+"现安全的事务化数据访问的基本需求。"
 
 #. Tag: term
-#: best_practices.xml:215
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Consider abstracting your business logic from Hibernate:"
-msgstr "考虑把Hibernate代码从业务逻辑代码中抽象出来"
+msgstr "考虑把 Hibernate 代码从业务逻辑代码中抽象出来:"
 
 #. Tag: para
-#: best_practices.xml:217
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hide Hibernate data-access code behind an interface. Combine the "
 "<emphasis>DAO</emphasis> and <emphasis>Thread Local Session</emphasis> "
@@ -383,21 +347,19 @@
 "however, intended for \"sufficiently large\" applications. It is not "
 "appropriate for an application with five tables."
 msgstr ""
-"把Hibernate的数据存取代码隐藏到接口(interface)的后面,组合使用<emphasis>DAO</"
-"emphasis>和<emphasis>Thread Local Session</emphasis>模式。通过Hibernate的"
-"<literal>UserType</literal>,你甚至可以用硬编码的JDBC来持久化那些本该被"
-"Hibernate持久化的类。 (该建议更适用于规模足够大应用软件中,对于那些只有5张表"
-"的应用程序并不适合。)"
+"把 Hibernate 的数据存取代码隐藏到接口(interface)的后面,组合使用 "
+"<emphasis>DAO</emphasis> 和 <emphasis>Thread Local Session</emphasis> 模式。"
+"通过 Hibernate 的<literal>UserType</literal>,你甚至可以用硬编码的 JDBC 来持"
+"久化那些本该被 Hibernate 持久化的类。然而,该建议更适用于规模足够大应用软件"
+"中,对于那些只有 5 张表的应用程序并不适合。"
 
 #. Tag: term
-#: best_practices.xml:227
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Do not use exotic association mappings:"
-msgstr "不要用怪异的连接映射"
+msgstr "不要用怪异的连接映射:"
 
 #. Tag: para
-#: best_practices.xml:229
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Practical test cases for real many-to-many associations are rare. Most of "
 "the time you need additional information stored in the \"link table\". In "
@@ -408,17 +370,14 @@
 msgstr ""
 "多对多连接用得好的例子实际上相当少见。大多数时候你在“连接表”中需要保存额外的"
 "信息。这种情况下,用两个指向中介类的一对多的连接比较好。实际上,我们认为绝大"
-"多数的连接是一对多和多对一的,你应该谨慎使用其它连接风格,用之前问自己一句,"
-"是否真的必须这么做。"
+"多数的连接是一对多和多对一的。i因此,你应该谨慎使用其它连接风格。"
 
 #. Tag: term
-#: best_practices.xml:239
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Prefer bidirectional associations:"
-msgstr "偏爱双向关联"
+msgstr "偏爱双向关联:"
 
 #. Tag: para
-#: best_practices.xml:241
 #, no-c-format
 msgid ""
 "Unidirectional associations are more difficult to query. In a large "

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/bibliography.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/bibliography.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/bibliography.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -5,7 +5,7 @@
 msgstr ""
 "Project-Id-Version: PACKAGE VERSION\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:21\n"
 "PO-Revision-Date: 2009-07-14 19:55+0000\n"
 "Last-Translator: Automatically generated\n"
 "Language-Team: none\n"
@@ -14,55 +14,36 @@
 "Content-Transfer-Encoding: 8bit\n"
 
 #. Tag: title
-#: bibliography.xml:27
 #, no-c-format
 msgid "References"
 msgstr ""
 
 #. Tag: title
-#: bibliography.xml:31
 #, no-c-format
 msgid "Patterns of Enterprise Application Architecture"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:34
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Martin</firstname> <surname>Fowler</surname>"
+msgid "Martin"
 msgstr ""
 
-#. Tag: holder
-#: bibliography.xml:41
-#, no-c-format
-msgid "Pearson Education, Inc."
-msgstr ""
-
 #. Tag: title
-#: bibliography.xml:50
 #, no-c-format
 msgid "Java Persistence with Hibernate"
 msgstr ""
 
 #. Tag: subtitle
-#: bibliography.xml:51
 #, no-c-format
 msgid "Second Edition of Hibernate in Action"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:57
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Christian</firstname> <surname>Bauer</surname>"
+msgid "Christian"
 msgstr ""
 
-#. Tag: author
-#: bibliography.xml:61
+#. Tag: firstname
 #, no-c-format
-msgid "<firstname>Gavin</firstname> <surname>King</surname>"
+msgid "Gavin"
 msgstr ""
-
-#. Tag: holder
-#: bibliography.xml:68
-#, no-c-format
-msgid "Manning Publications Co."
-msgstr ""

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/collection_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/collection_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/collection_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,65 +1,50 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2009-12-09 12:11+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: collection_mapping.xml:29
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Collection mapping"
-msgstr "集合映射( Collection mappings )"
+msgstr "集合映射(Collection mappings)"
 
 #. Tag: title
-#: collection_mapping.xml:32
 #, no-c-format
 msgid "Persistent collections"
-msgstr "持久化集合类(Persistent collections)"
+msgstr "持久化集合类(Persistent collections)"
 
 #. Tag: para
-#: collection_mapping.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate requires that persistent collection-valued fields be declared as "
 "an interface type. For example:"
 msgstr ""
-"Hibernate要求持久化集合值字段必须声明为接口,比如:(译者注:在阅读本章的时"
-"候,以后整个手册的阅读过程中,我们都会面临一个名词方面的问题,那就是“集合”。"
-"\"Collections\"和\"Set\"在中文里对应都被翻译为“集合”,但是他们的含义很不一"
-"样。Collections是一个超集,Set是其中的一种。大部分情况下,本译稿中泛指的未加"
-"英文注明的“集合”,都应当理解为“Collections”。在有些二者同时出现,可能造成混淆"
-"的地方,我们用“集合类”来特指“Collecions”,“集合(Set)”来指\"Set\",一般都会在后"
-"面的括号中给出英文。希望大家在阅读时联系上下文理解,不要造成误解。 与此同"
-"时,“元素”一词对应的英文“element”,也有两个不同的含义。其一为集合的元素,是内"
-"存中的一个变量;另一含义则是XML文档中的一个标签所代表的元素。也请注意区别。 "
-"本章中,特别是后半部分是需要反复阅读才能理解清楚的。如果遇到任何疑问,请记住,英"
-"文版本的reference是惟一标准的参考资料。)"
+"(译者注:在阅读本章的时候,以后整个手册的阅读过程中,我们都会面临一个名词方"
+"面的问题,那就是“集合”。\"Collections\" 和 \"Set\" 在中文里对应都被翻译为“集"
+"合”,但是他们的含义很不一样。Collections 是一个超集,Set 是其中的一种。大部分"
+"情况下,本译稿中泛指的未加英文注明的“集合”,都应当理解为“Collections”。在有些"
+"二者同时出现,可能造成混淆的地方,我们用“集合类”来特指“Collecions”,“集合"
+"(Set)”来指 \"Set\",一般都会在后面的括号中给出英文。希望大家在阅读时联系上"
+"下文理解,不要造成误解。 与此同时,“元素”一词对应的英文“element”,也有两个不"
+"同的含义。其一为集合的元素,是内存中的一个变量;另一含义则是 XML 文档中的一个"
+"标签所代表的元素。也请注意区别。本章中,特别是后半部分是需要反复阅读才能理解"
+"清楚的。如果遇到任何疑问,请记住,英文版本的 reference 是惟一标准的参考资"
+"料。) Hibernate 要求持久化集合值字段必须声明为接口,例如:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:39
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[public class Product {\n"
-"    private String serialNumber;\n"
-"    private Set parts = new HashSet();\n"
-"    \n"
-"    public Set getParts() { return parts; }\n"
-"    void setParts(Set parts) { this.parts = parts; }\n"
-"    public String getSerialNumber() { return serialNumber; }\n"
-"    void setSerialNumber(String sn) { serialNumber = sn; }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:41
-#, fuzzy, no-c-format
-msgid ""
 "The actual interface might be <literal>java.util.Set</literal>, "
 "<literal>java.util.Collection</literal>, <literal>java.util.List</literal>, "
 "<literal>java.util.Map</literal>, <literal>java.util.SortedSet</literal>, "
@@ -67,15 +52,14 @@
 "like\" means you will have to write an implementation of <literal>org."
 "hibernate.usertype.UserCollectionType</literal>.)"
 msgstr ""
-"实际的接口可能是<literal>java.util.Set</literal>, <literal>java.util."
-"Collection</literal>, <literal>java.util.List</literal>, <literal>java.util."
-"Map</literal>, <literal>java.util.SortedSet</literal>, <literal>java.util."
-"SortedMap</literal> 或者...任何你喜欢的类型!(\"任何你喜欢的类型\" 代表你需要"
-"编写 <literal>org.hibernate.usertype.UserCollectionType</literal>的实现.)"
+"实际的接口可能是 <literal>java.util.Set</literal>、<literal>java.util."
+"Collection</literal>、<literal>java.util.List</literal>、<literal>java.util."
+"Map</literal>、<literal>java.util.SortedSet</literal>、<literal>java.util."
+"SortedMap</literal> 或者任何你喜欢的类型(\"任何你喜欢的类型\" 代表你需要编"
+"写 <literal>org.hibernate.usertype.UserCollectionType</literal> 的实现)。"
 
 #. Tag: para
-#: collection_mapping.xml:50
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Notice how the instance variable was initialized with an instance of "
 "<literal>HashSet</literal>. This is the best way to initialize collection "
@@ -85,43 +69,26 @@
 "an instance of Hibernate's own implementation of <literal>Set</literal>. Be "
 "aware of the following errors:"
 msgstr ""
-"注意我们是如何用一个<literal>HashSet</literal>实例来初始化实例变量的.这是用于"
-"初始化新创建(尚未持久化)的类实例中集合值属性的最佳方法。当你持久化这个实例时"
-"——比如通过调用<literal>persist()</literal>——Hibernate 会自动把"
-"<literal>HashSet</literal>替换为Hibernate自己的<literal>Set</literal>实现。观"
-"察下面的错误:"
+"注意我们是如何用一个 <literal>HashSet</literal> 实例来初始化实例变量的。这是"
+"用于初始化新创建(尚未持久化)的类实例中集合值属性的最佳方法。当你持久化这个"
+"实例时 — 比如通过调用 <literal>persist()</literal> — Hibernate 会自动把 "
+"<literal>HashSet</literal> 替换为 Hibernate 自己的 <literal>Set</literal> 实"
+"现。注意下面的错误:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:60
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Cat cat = new DomesticCat();\n"
-"Cat kitten = new DomesticCat();\n"
-"....\n"
-"Set kittens = new HashSet();\n"
-"kittens.add(kitten);\n"
-"cat.setKittens(kittens);\n"
-"session.persist(cat);\n"
-"kittens = cat.getKittens(); // Okay, kittens collection is a Set\n"
-"(HashSet) cat.getKittens(); // Error!]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:62
-#, fuzzy, no-c-format
-msgid ""
 "The persistent collections injected by Hibernate behave like "
 "<literal>HashMap</literal>, <literal>HashSet</literal>, <literal>TreeMap</"
 "literal>, <literal>TreeSet</literal> or <literal>ArrayList</literal>, "
 "depending on the interface type."
 msgstr ""
-"根据不同的接口类型,被Hibernate注射的持久化集合类的表现类似<literal>HashMap</"
-"literal>, <literal>HashSet</literal>, <literal>TreeMap</literal>, "
-"<literal>TreeSet</literal> or <literal>ArrayList</literal>。"
+"根据不同的接口类型,被 Hibernate 注射的持久化集合类的表现类似 "
+"<literal>HashMap</literal>、<literal>HashSet</literal>、<literal>TreeMap</"
+"literal>、<literal>TreeSet</literal> 或 <literal>ArrayList</literal>。"
 
 #. Tag: para
-#: collection_mapping.xml:69
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collections instances have the usual behavior of value types. They are "
 "automatically persisted when referenced by a persistent object and are "
@@ -135,65 +102,46 @@
 "集合类实例具有值类型的通常行为。当被持久化对象引用后,他们会自动被持久化,当"
 "不再被引用后,自动被删除。假若实例被从一个持久化对象传递到另一个,它的元素可"
 "能从一个表转移到另一个表。两个实体不能共享同一个集合类实例的引用。因为底层关"
-"系数据库模型的原因,集合值属性无法支持空值语义;Hibernate对空的集合引用和空集"
-"合不加区别。"
+"系数据库模型的原因,集合值属性无法支持空值语义;Hibernate 对空的集合引用和空"
+"集合不加区别。 "
 
 #. Tag: para
-#: collection_mapping.xml:80
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use persistent collections the same way you use ordinary Java collections. "
 "However, please ensure you understand the semantics of bidirectional "
 "associations (these are discussed later)."
 msgstr ""
-"你不需要过多的为此担心。就如同你平时使用普通的Java集合类一样来使用持久化集合"
-"类。只是要确认你理解了双向关联的语义(后文讨论)。"
+"你不需要过多的为此担心。就如同你平时使用普通的 Java 集合类一样来使用持久化集"
+"合类。只是要确认你理解了双向关联的语义(后文将进行讨论)。"
 
 #. Tag: title
-#: collection_mapping.xml:89
 #, no-c-format
 msgid "Collection mappings"
 msgstr "集合映射( Collection mappings )"
 
 #. Tag: para
-#: collection_mapping.xml:92
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are quite a range of mappings that can be generated for collections "
 "that cover many common relational models. We suggest you experiment with the "
 "schema generation tool so that you understand how various mapping "
 "declarations translate to database tables."
 msgstr ""
-"任何值集合或者多对多关联需要专用的具有一个或多个外键字段的"
-"<emphasis>collection table</emphasis>、一个或多个<emphasis>collection "
-"element column</emphasis>,以及还可能有一个或多个索引字段。"
+"从集合类可以产生很大一部分映射,覆盖了很多常见的关系模型。我们建议你试验 "
+"schema 生成工具,来体会一下不同的映射声明是如何被翻译为数据库表的。 "
 
 #. Tag: para
-#: collection_mapping.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The Hibernate mapping element used for mapping a collection depends upon the "
 "type of interface. For example, a <literal>&lt;set&gt;</literal> element is "
 "used for mapping properties of type <literal>Set</literal>."
 msgstr ""
-"用于映射集合类的Hibernate映射元素取决于接口的类型。比如, <literal>&lt;"
-"set&gt;</literal> 元素用来映射<literal>Set</literal>类型的属性。"
+"用于映射集合类的 Hibernate 映射元素取决于接口的类型。比如,<literal>&lt;"
+"set&gt;</literal> 元素用来映射 <literal>Set</literal> 类型的属性。 "
 
-#. Tag: programlisting
-#: collection_mapping.xml:105
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Product\">\n"
-"    <id name=\"serialNumber\" column=\"productSerialNumber\"/>\n"
-"    <set name=\"parts\">\n"
-"        <key column=\"productSerialNumber\" not-null=\"true\"/>\n"
-"        <one-to-many class=\"Part\"/>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:107
 #, no-c-format
 msgid ""
 "Apart from <literal>&lt;set&gt;</literal>, there is also <literal>&lt;"
@@ -202,69 +150,36 @@
 "array&gt;</literal> mapping elements. The <literal>&lt;map&gt;</literal> "
 "element is representative:"
 msgstr ""
-"除了<literal>&lt;set&gt;</literal>,还有<literal>&lt;list&gt;</literal>, "
-"<literal>&lt;map&gt;</literal>, <literal>&lt;bag&gt;</literal>, <literal>&lt;"
+"除了 <literal>&lt;set&gt;</literal>,还有<literal>&lt;list&gt;</literal>,"
+"<literal>&lt;map&gt;</literal>,<literal>&lt;bag&gt;</literal>,<literal>&lt;"
 "array&gt;</literal> 和 <literal>&lt;primitive-array&gt;</literal> 映射元素。"
-"<literal>&lt;map&gt;</literal>具有代表性:"
+"<literal>&lt;map&gt;</literal> 具有代表性:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:132
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<map\n"
-"    name=\"propertyName\"\n"
-"    table=\"table_name\"\n"
-"    schema=\"schema_name\"\n"
-"    lazy=\"true|extra|false\"\n"
-"    inverse=\"true|false\"\n"
-"    cascade=\"all|none|save-update|delete|all-delete-orphan|delete-orphan\"\n"
-"    sort=\"unsorted|natural|comparatorClass\"\n"
-"    order-by=\"column_name asc|desc\"\n"
-"    where=\"arbitrary sql where condition\"\n"
-"    fetch=\"join|select|subselect\"\n"
-"    batch-size=\"N\"\n"
-"    access=\"field|property|ClassName\"\n"
-"    optimistic-lock=\"true|false\"\n"
-"    mutable=\"true|false\"\n"
-"    node=\"element-name|.\"\n"
-"    embed-xml=\"true|false\"\n"
-">\n"
-"\n"
-"    <key .... />\n"
-"    <map-key .... />\n"
-"    <element .... />\n"
-"</map>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:135
-#, fuzzy, no-c-format
 msgid "<literal>name</literal>: the collection property name"
-msgstr "<literal>name</literal> 集合属性的名称"
+msgstr "<literal>name</literal>:集合属性的名称"
 
 #. Tag: para
-#: collection_mapping.xml:140
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>table</literal> (optional - defaults to property name): the name of "
 "the collection table. It is not used for one-to-many associations."
 msgstr ""
-"<literal>table</literal> (可选——默认为属性的名称)这个集合表的名称(不能在一"
-"对多的关联关系中使用)"
+"<literal>table</literal>(可选——默认为属性的名称)这个集合表的名称(不能在一"
+"对多的关联关系中使用)。"
 
 #. Tag: para
-#: collection_mapping.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>schema</literal> (optional): the name of a table schema to override "
 "the schema declared on the root element"
 msgstr ""
-"<literal>schema</literal> (可选) 表的schema的名称, 他将覆盖在根元素中定义的"
-"schema"
+"<literal>schema</literal>(可选):表的 schema 的名称,他将覆盖在根元素中定义"
+"çš„ schema"
 
 #. Tag: para
-#: collection_mapping.xml:152
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>lazy</literal> (optional - defaults to <literal>true</literal>): "
 "disables lazy fetching and specifies that the association is always eagerly "
@@ -272,133 +187,121 @@
 "operations do not initialize the collection. This is suitable for large "
 "collections."
 msgstr ""
-"<literal>lazy</literal> (可选--默认为true) 可以用来关闭延迟加载(false),指定"
-"一直使用预先抓取,或者打开\"extra-lazy\" 抓取,此时大多数操作不会初始化集合类"
-"(适用于非常大的集合)"
+"<literal>lazy</literal>(可选--默认为 true)可以用来关闭延迟加载(false):指"
+"定一直使用预先抓取,或者打开 \"extra-lazy\" 抓取,此时大多数操作不会初始化集"
+"合类(适用于非常大的集合)。"
 
 #. Tag: para
-#: collection_mapping.xml:161
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>inverse</literal> (optional - defaults to <literal>false</"
 "literal>): marks this collection as the \"inverse\" end of a bidirectional "
 "association."
 msgstr ""
-"<literal>inverse</literal> (可选——默认为<literal>false</literal>) 标记这个集"
-"合作为双向关联关系中的方向一端。"
+"<literal>inverse</literal>(可选 — 默认为 <literal>false</literal>)标记这个"
+"集合作为双向关联关系中的方向一端。 "
 
 #. Tag: para
-#: collection_mapping.xml:167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>cascade</literal> (optional - defaults to <literal>none</literal>): "
 "enables operations to cascade to child entities."
 msgstr ""
-"<literal>cascade</literal> (可选——默认为<literal>none</literal>) 让操作级联到"
-"子实体"
+"<literal>cascade</literal>(可选 — 默认为 <literal>none</literal>)让操作级联"
+"到子实体。"
 
 #. Tag: para
-#: collection_mapping.xml:173
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>sort</literal> (optional): specifies a sorted collection with "
 "<literal>natural</literal> sort order or a given comparator class."
 msgstr ""
-"<literal>sort</literal>(可选)指定集合的排序顺序, 其可以为自然的"
-"(<literal>natural</literal>)或者给定一个用来比较的类。"
+"<literal>sort</literal>(可选)指定集合的排序顺序,其可以为自然的"
+"(<literal>natural</literal>)或者给定一个用来比较的类。 "
 
 #. Tag: para
-#: collection_mapping.xml:179
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>order-by</literal> (optional, JDK1.4 only): specifies a table "
 "column or columns that define the iteration order of the <literal>Map</"
 "literal>, <literal>Set</literal> or bag, together with an optional "
 "<literal>asc</literal> or <literal>desc</literal>."
 msgstr ""
-"<literal>order-by</literal> (可选, 仅用于jdk1.4) 指定表的字段(一个或几个)再加"
-"上asc或者desc(可选), 定义Map,Set和Bag的迭代顺序"
+"<literal>order-by</literal>(可选,仅用于 jdk1.4):指定表的字段(一个或几"
+"个)再加上 asc 或者 desc(可选),定义 Map、Set 和 Bag 的迭代顺序。"
 
 #. Tag: para
-#: collection_mapping.xml:186
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>where</literal> (optional): specifies an arbitrary SQL "
 "<literal>WHERE</literal> condition that is used when retrieving or removing "
 "the collection. This is useful if the collection needs to contain only a "
 "subset of the available data."
 msgstr ""
-"<literal>where</literal> (可选) 指定任意的SQL where条件, 该条件将在重新载入或"
-"者删除这个集合时使用(当集合中的数据仅仅是所有可用数据的一个子集时这个条件非常"
-"有用)"
+"<literal>where</literal>(可选):指定任意的 SQL where 条件,该条件将在重新载"
+"入或者删除这个集合时使用(当集合中的数据仅仅是所有可用数据的一个子集时这个条"
+"件非常有用)。"
 
 #. Tag: para
-#: collection_mapping.xml:193
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>fetch</literal> (optional, defaults to <literal>select</literal>): "
 "chooses between outer-join fetching, fetching by sequential select, and "
 "fetching by sequential subselect."
 msgstr ""
-"<literal>fetch</literal> (可选, 默认为<literal>select</literal>) 用于在外连接"
-"抓取、通过后续select抓取和通过后续subselect抓取之间选择。"
+"<literal>fetch</literal>(可选,默认为 <literal>select</literal>):用于在外"
+"连接抓取、通过后续 select 抓取和通过后续 subselect 抓取之间选择。"
 
 #. Tag: para
-#: collection_mapping.xml:200
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>batch-size</literal> (optional, defaults to <literal>1</literal>): "
 "specifies a \"batch size\" for lazily fetching instances of this collection."
 msgstr ""
-"<literal>batch-size</literal> (可选, 默认为<literal>1</literal>) 指定通过延迟"
-"加载取得集合实例的批处理块大小(\"batch size\")。"
+"<literal>batch-size</literal>(可选,默认为 <literal>1</literal>):指定通过"
+"延迟加载取得集合实例的批处理块大小(\"batch size\")。"
 
 #. Tag: para
-#: collection_mapping.xml:206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>access</literal> (optional - defaults to <literal>property</"
 "literal>): the strategy Hibernate uses for accessing the collection property "
 "value."
 msgstr ""
-"<literal>access</literal>(可选-默认为属性property):Hibernate取得集合属性值时"
-"使用的策略"
+"<literal>access</literal>(可选-默认为属性 property):Hibernate 取得集合属性"
+"值时使用的策略。"
 
 #. Tag: para
-#: collection_mapping.xml:212
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>optimistic-lock</literal> (optional - defaults to <literal>true</"
 "literal>): specifies that changes to the state of the collection results in "
 "increments of the owning entity's version. For one-to-many associations you "
 "may want to disable this setting."
 msgstr ""
-"<literal>乐观锁</literal> (可选 - 默认为 <literal>true</literal>): 对集合的状"
-"态的改变会是否导致其所属的实体的版本增长。 (对一对多关联来说,关闭这个属性常"
-"常是有理的)"
+"<literal>乐观锁</literal>(可选 - 默认为 <literal>true</literal>):对集合的"
+"状态的改变会是否导致其所属的实体的版本增长(对一对多关联来说,关闭这个属性常"
+"常是有理的)。"
 
 #. Tag: para
-#: collection_mapping.xml:220
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>mutable</literal> (optional - defaults to <literal>true</literal>): "
 "a value of <literal>false</literal> specifies that the elements of the "
 "collection never change. This allows for minor performance optimization in "
 "some cases."
 msgstr ""
-"<literal>mutable(可变)</literal> (可选 - 默认为<literal>true</literal>): 若"
-"值为<literal>false</literal>,表明集合中的元素不会改变(在某些情况下可以进行一"
-"些小的性能优化)。"
+"<literal>mutable(可变)</literal>(可选 — 默认为 <literal>true</literal>):"
+"若值为 <literal>false</literal>,表明集合中的元素不会改变(在某些情况下可以进"
+"行一些小的性能优化)。 "
 
 #. Tag: title
-#: collection_mapping.xml:230
 #, no-c-format
 msgid "Collection foreign keys"
-msgstr "集合外键(Collection foreign keys)"
+msgstr "集合外键(Collection foreign keys)"
 
 #. Tag: para
-#: collection_mapping.xml:232
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collection instances are distinguished in the database by the foreign key of "
 "the entity that owns the collection. This foreign key is referred to as the "
@@ -408,11 +311,10 @@
 msgstr ""
 "集合实例在数据库中依靠持有集合的实体的外键加以辨别。此外键作为<emphasis>集合"
 "关键字段(collection key column)</emphasis>(或多个字段)加以引用。集合关键"
-"字段通过<literal>&lt;key&gt;</literal> 元素映射。"
+"字段通过 <literal>&lt;key&gt;</literal> 元素映射。 "
 
 #. Tag: para
-#: collection_mapping.xml:240
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There can be a nullability constraint on the foreign key column. For most "
 "collections, this is implied. For unidirectional one-to-many associations, "
@@ -421,44 +323,28 @@
 msgstr ""
 "在外键字段上可能具有非空约束。对于大多数集合来说,这是隐含的。对单向一对多关"
 "联来说,外键字段默认是可以为空的,因此你可能需要指明 <literal>not-null=\"true"
-"\"</literal>。"
+"\"</literal>。 "
 
-#. Tag: programlisting
-#: collection_mapping.xml:247
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[<key column=\"productSerialNumber\" not-null=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:249
-#, fuzzy, no-c-format
 msgid ""
 "The foreign key constraint can use <literal>ON DELETE CASCADE</literal>."
-msgstr "外键约束可以使用<literal>ON DELETE CASCADE</literal>。"
+msgstr "外键约束可以使用 <literal>ON DELETE CASCADE</literal>。 "
 
-#. Tag: programlisting
-#: collection_mapping.xml:253
-#, no-c-format
-msgid "<![CDATA[<key column=\"productSerialNumber\" on-delete=\"cascade\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:255
 #, no-c-format
 msgid ""
 "See the previous chapter for a full definition of the <literal>&lt;key&gt;</"
 "literal> element."
-msgstr "对<literal>&lt;key&gt;</literal> 元素的完整定义,请参阅前面的章节。"
+msgstr "对 <literal>&lt;key&gt;</literal> 元素的完整定义,请参阅前面的章节。"
 
 #. Tag: title
-#: collection_mapping.xml:263
 #, no-c-format
 msgid "Collection elements"
 msgstr "集合元素(Collection elements)"
 
 #. Tag: para
-#: collection_mapping.xml:265
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Collections can contain almost any other Hibernate type, including: basic "
 "types, custom types, components and references to other entities. This is an "
@@ -468,14 +354,13 @@
 "latter case, only the \"link\" between the two objects is considered to be a "
 "state held by the collection."
 msgstr ""
-"集合几乎可以包含任何其他的Hibernate类型,包括所有的基本类型、自定义类型、组"
+"集合几乎可以包含任何其他的 Hibernate 类型,包括所有的基本类型、自定义类型、组"
 "件,当然还有对其他实体的引用。存在一个重要的区别:位于集合中的对象可能是根"
 "据“值”语义来操作(其声明周期完全依赖于集合持有者),或者它可能是指向另一个实"
 "体的引用,具有其自己的生命周期。在后者的情况下,被作为集合持有的状态考虑的,"
-"只有两个对象之间的“连接”。"
+"只有两个对象之间的“连接”。 "
 
 #. Tag: para
-#: collection_mapping.xml:274
 #, no-c-format
 msgid ""
 "The contained type is referred to as the <emphasis>collection element type</"
@@ -486,20 +371,18 @@
 "value semantics, the next two are used to map entity associations."
 msgstr ""
 "被包容的类型被称为<emphasis>集合元素类型(collection element type)</"
-"emphasis>。集合元素通过<literal>&lt;element&gt;</literal>或<literal>&lt;"
-"composite-element&gt;</literal>映射,或在其是实体引用的时候,通过"
-"<literal>&lt;one-to-many&gt;</literal> 或<literal>&lt;many-to-many&gt;</"
-"literal>映射。前两种用于使用值语义映射元素,后两种用于映射实体关联。"
+"emphasis>。集合元素通过 <literal>&lt;element&gt;</literal> 或 <literal>&lt;"
+"composite-element&gt;</literal> 映射,或在其是实体引用的时候,通过  "
+"<literal>&lt;one-to-many&gt;</literal> 或 <literal>&lt;many-to-many&gt;</"
+"literal> 映射。前两种用于使用值语义映射元素,后两种用于映射实体关联。"
 
 #. Tag: title
-#: collection_mapping.xml:286
 #, no-c-format
 msgid "Indexed collections"
-msgstr "索引集合类(Indexed collections)"
+msgstr "索引集合类(Indexed collections)"
 
 #. Tag: para
-#: collection_mapping.xml:288
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All collection mappings, except those with set and bag semantics, need an "
 "<emphasis>index column</emphasis> in the collection table. An index column "
@@ -513,387 +396,318 @@
 "index&gt;</literal> element. The mapped column contains sequential integers "
 "that are numbered from zero by default."
 msgstr ""
-"所有的集合映射,除了set和bag语义的以外,都需要指定一个集合表的<emphasis>索引"
-"字段(index column)</emphasis>——用于对应到数组索引,或者<literal>List</"
-"literal>的索引,或者<literal>Map</literal>的关键字。通过<literal>&lt;map-"
-"key&gt;</literal>,<literal>Map</literal> 的索引可以是任何基础类型;若通过"
-"<literal>&lt;map-key-many-to-many&gt;</literal>,它也可以是一个实体引用;若通"
-"过<literal>&lt;composite-map-key&gt;</literal>,它还可以是一个组合类型。数组"
-"或列表的索引必须是<literal>integer</literal>类型,并且使用 <literal>&lt;list-"
-"index&gt;</literal>元素定义映射。被映射的字段包含有顺序排列的整数(默认从0开"
-"始)。"
+"所有的集合映射,除了 set 和 bag 语义的以外,都需要指定一个集合表的<emphasis>"
+"索引字段(index column)</emphasis> — 用于对应到数组索引,或者 "
+"<literal>List</literal> 的索引,或者 <literal>Map</literal> 的关键字。通过 "
+"<literal>&lt;map-key&gt;</literal>,<literal>Map</literal> 的索引可以是任何基"
+"础类型;若通过 <literal>&lt;map-key-many-to-many&gt;</literal>,它也可以是一"
+"个实体引用;若通过 <literal>&lt;composite-map-key&gt;</literal>,它还可以是一"
+"个组合类型。数组或列表的索引必须是 <literal>integer</literal> 类型,并且使用 "
+"<literal>&lt;list-index&gt;</literal> 元素定义映射。被映射的字段包含有顺序排"
+"列的整数(默认从 0 开始)。 "
 
-#. Tag: sect2
-#: collection_mapping.xml:299
+#. Tag: para
 #, no-c-format
 msgid ""
-"<programlistingco> <areaspec> <area id=\"index1\" coords=\"2 45\"/> <area id="
-"\"index2\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA[<list-"
-"index \n"
-"        column=\"column_name\"\n"
-"        base=\"0|1|...\"/>]]></programlisting> <calloutlist> <callout "
-"arearefs=\"index1\"> <para> <literal>column_name</literal> (required): the "
-"name of the column holding the collection index values. </para> </callout> "
-"<callout arearefs=\"index1\"> <para> <literal>base</literal> (optional - "
-"defaults to <literal>0</literal>): the value of the index column that "
-"corresponds to the first element of the list or array. </para> </callout> </"
-"calloutlist> </programlistingco> <programlistingco> <areaspec> <area id="
-"\"mapkey1\" coords=\"2 45\"/> <area id=\"mapkey2\" coords=\"3 45\"/> <area "
-"id=\"mapkey3\" coords=\"4 45\"/> </areaspec> <programlisting><![CDATA[<map-"
-"key \n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        type=\"type_name\"\n"
-"        node=\"@attribute-name\"\n"
-"        length=\"N\"/>]]></programlisting> <calloutlist> <callout arearefs="
-"\"mapkey1\"> <para> <literal>column</literal> (optional): the name of the "
-"column holding the collection index values. </para> </callout> <callout "
-"arearefs=\"mapkey2\"> <para> <literal>formula</literal> (optional): a SQL "
-"formula used to evaluate the key of the map. </para> </callout> <callout "
-"arearefs=\"mapkey3\"> <para> <literal>type</literal> (required): the type of "
-"the map keys. </para> </callout> </calloutlist> </programlistingco> "
-"<programlistingco> <areaspec> <area id=\"indexmanytomany1\" coords=\"2 45\"/"
-"> <area id=\"indexmanytomany2\" coords=\"3 45\"/> <area id=\"indexmanytomany3"
-"\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA[<map-key-many-to-"
-"many\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        class=\"ClassName\"\n"
-"/>]]></programlisting> <calloutlist> <callout arearefs=\"indexmanytomany1\"> "
-"<para> <literal>column</literal> (optional): the name of the foreign key "
-"column for the collection index values. </para> </callout> <callout arearefs="
-"\"indexmanytomany2\"> <para> <literal>formula</literal> (optional): a SQ "
-"formula used to evaluate the foreign key of the map key. </para> </callout> "
-"<callout arearefs=\"indexmanytomany3\"> <para> <literal>class</literal> "
-"(required): the entity class used as the map key. </para> </callout> </"
-"calloutlist> </programlistingco>"
+"<literal>column_name</literal> (required): the name of the column holding "
+"the collection index values."
+msgstr "<literal>column_name</literal>(必需):持有集合索引值的字段的名称。 "
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>base</literal> (optional - defaults to <literal>0</literal>): the "
+"value of the index column that corresponds to the first element of the list "
+"or array."
 msgstr ""
+"<literal>base</literal>(可选 — 默认为 <literal>0</literal>)对应列表或队列的"
+"第一个元素的索引字段的值。"
 
 #. Tag: para
-#: collection_mapping.xml:380
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
+"<literal>column</literal> (optional): the name of the column holding the "
+"collection index values."
+msgstr "<literal>column</literal>(可选):持有集合索引值的字段的名称。"
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>formula</literal> (optional): a SQL formula used to evaluate the "
+"key of the map."
+msgstr "<literal>formula</literal>(可选):用于对表键求值的 SQL 公式。"
+
+#. Tag: para
+#, no-c-format
+msgid "<literal>type</literal> (required): the type of the map keys."
+msgstr "<literal>type</literal>(必需):映射键的类型。 "
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>column</literal> (optional): the name of the foreign key column for "
+"the collection index values."
+msgstr "<literal>column</literal>(可选):用于集合索引值的外键字段的名称。"
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>formula</literal> (optional): a SQ formula used to evaluate the "
+"foreign key of the map key."
+msgstr ""
+"<literal>formula</literal>(可选):用于对映射键的外键求值的 SQL 公式。"
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>class</literal> (required): the entity class used as the map key."
+msgstr "<literal>class</literal>(必需):用作映射键的实体类的名称。 "
+
+#. Tag: para
+#, no-c-format
+msgid ""
 "If your table does not have an index column, and you still wish to use "
 "<literal>List</literal> as the property type, you can map the property as a "
 "Hibernate <emphasis>&lt;bag&gt;</emphasis>. A bag does not retain its order "
 "when it is retrieved from the database, but it can be optionally sorted or "
 "ordered."
 msgstr ""
-"值集合于多对多关联(Collections of values and many-to-many associations)"
+"假若你的表没有一个索引字段,当你仍然希望使用 <literal>List</literal> 作为属性"
+"类型,你应该把此属性映射为 Hibernate <emphasis>&lt;bag&gt;</emphasis>。从数据"
+"库中获取的时候,bag 不维护其顺序,但也可选择性的进行排序。 "
 
 #. Tag: title
-#: collection_mapping.xml:390
 #, no-c-format
 msgid "Collections of values and many-to-many associations"
-msgstr "对于一个值集合, 我们使用<literal>&lt;element&gt;</literal>标签。"
+msgstr ""
+"值集合于多对多关联(Collections of values and many-to-many associations)"
 
 #. Tag: para
-#: collection_mapping.xml:392
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Any collection of values or many-to-many associations requires a dedicated "
 "<emphasis>collection table</emphasis> with a foreign key column or columns, "
 "<emphasis>collection element column</emphasis> or columns, and possibly an "
 "index column or columns."
-msgstr "<literal>column</literal>(可选):保存集合元素值的字段名。"
+msgstr ""
+"任何值集合或者多对多关联需要专用的具有一个或多个外键字段的 "
+"<emphasis>collection table</emphasis>、一个或多个 <emphasis>collection "
+"element column</emphasis>,以及还可能有一个或多个索引字段。 "
 
 #. Tag: para
-#: collection_mapping.xml:399
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For a collection of values use the <literal>&lt;element&gt;</literal> tag. "
 "For example:"
-msgstr "<literal>formula</literal> (可选): 用于计算元素的SQL公式"
+msgstr ""
+"对于一个值集合,我们使用 <literal>&lt;element&gt;</literal> 标签。例如:"
 
-#. Tag: sect2
-#: collection_mapping.xml:401
+#. Tag: para
 #, no-c-format
 msgid ""
-"<programlistingco> <areaspec> <area id=\"element1b\" coords=\"2 50\"/> <area "
-"id=\"element2b\" coords=\"3 50\"/> <area id=\"element3b\" coords=\"4 50\"/> "
-"</areaspec> <programlisting><![CDATA[<element\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        type=\"typename\"\n"
-"        length=\"L\"\n"
-"        precision=\"P\"\n"
-"        scale=\"S\"\n"
-"        not-null=\"true|false\"\n"
-"        unique=\"true|false\"\n"
-"        node=\"element-name\"\n"
-"/>]]></programlisting> <calloutlist> <callout arearefs=\"element1b\"> <para> "
 "<literal>column</literal> (optional): the name of the column holding the "
-"collection element values. </para> </callout> <callout arearefs=\"element2b"
-"\"> <para> <literal>formula</literal> (optional): an SQL formula used to "
-"evaluate the element. </para> </callout> <callout arearefs=\"element3b\"> "
-"<para> <literal>type</literal> (required): the type of the collection "
-"element. </para> </callout> </calloutlist> </programlistingco> <para> A "
-"<emphasis>many-to-many association</emphasis> is specified using the "
-"<literal>&lt;many-to-many&gt;</literal> element. </para> <programlistingco> "
-"<areaspec> <area id=\"manytomany1\" coords=\"2 60\"/> <area id=\"manytomany2"
-"\" coords=\"3 60\"/> <area id=\"manytomany3\" coords=\"4 60\"/> <area id="
-"\"manytomany4\" coords=\"5 60\"/> <area id=\"manytomany5\" coords=\"6 60\"/> "
-"<area id=\"manytomany6\" coords=\"7 60\"/> <area id=\"manytomany7\" coords="
-"\"8 60\"/> <area id=\"manytomany8\" coords=\"9 60\"/> </areaspec> "
-"<programlisting><![CDATA[<many-to-many\n"
-"        column=\"column_name\"\n"
-"        formula=\"any SQL expression\"\n"
-"        class=\"ClassName\"\n"
-"        fetch=\"select|join\"\n"
-"        unique=\"true|false\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        property-ref=\"propertyNameFromAssociatedClass\"\n"
-"        node=\"element-name\"\n"
-"        embed-xml=\"true|false\"\n"
-"    />]]></programlisting> <calloutlist> <callout arearefs=\"manytomany1\"> "
-"<para> <literal>column</literal> (optional): the name of the element foreign "
-"key column. </para> </callout> <callout arearefs=\"manytomany2\"> <para> "
+"collection element values."
+msgstr "<literal>column</literal>(可选):持有集合元素值的字段的名称。"
+
+#. Tag: para
+#, no-c-format
+msgid ""
 "<literal>formula</literal> (optional): an SQL formula used to evaluate the "
-"element foreign key value. </para> </callout> <callout arearefs=\"manytomany3"
-"\"> <para> <literal>class</literal> (required): the name of the associated "
-"class. </para> </callout> <callout arearefs=\"manytomany4\"> <para> "
+"element."
+msgstr "<literal>formula</literal>(可选):用于对元素求值的 SQL 公式。"
+
+#. Tag: para
+#, no-c-format
+msgid "<literal>type</literal> (required): the type of the collection element."
+msgstr "<literal>type</literal>(必需):集合元素的类型。 "
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"A <emphasis>many-to-many association</emphasis> is specified using the "
+"<literal>&lt;many-to-many&gt;</literal> element."
+msgstr ""
+"用 <literal>&lt;many-to-many&gt;</literal> 元素指定 <emphasis>many-to-many "
+"association</emphasis>。"
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>column</literal> (optional): the name of the element foreign key "
+"column."
+msgstr "<literal>column</literal>(必需):元素外键字段的名称。 "
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"<literal>formula</literal> (optional): an SQL formula used to evaluate the "
+"element foreign key value."
+msgstr "<literal>formula</literal>(可选):用于对元素外键值求值的 SQL 公式。"
+
+#. Tag: para
+#, no-c-format
+msgid "<literal>class</literal> (required): the name of the associated class."
+msgstr "<literal>class</literal>(必需):被关联类的名称。 "
+
+#. Tag: para
+#, no-c-format
+msgid ""
 "<literal>fetch</literal> (optional - defaults to <literal>join</literal>): "
 "enables outer-join or sequential select fetching for this association. This "
 "is a special case; for full eager fetching in a single <literal>SELECT</"
 "literal> of an entity and its many-to-many relationships to other entities, "
 "you would enable <literal>join</literal> fetching,not only of the collection "
 "itself, but also with this attribute on the <literal>&lt;many-to-many&gt;</"
-"literal> nested element. </para> </callout> <callout arearefs=\"manytomany5"
-"\"> <para> <literal>unique</literal> (optional): enables the DDL generation "
-"of a unique constraint for the foreign-key column. This makes the "
-"association multiplicity effectively one-to-many. </para> </callout> "
-"<callout arearefs=\"manytomany6\"> <para> <literal>not-found</literal> "
-"(optional - defaults to <literal>exception</literal>): specifies how foreign "
-"keys that reference missing rows will be handled: <literal>ignore</literal> "
-"will treat a missing row as a null association. </para> </callout> <callout "
-"arearefs=\"manytomany7\"> <para> <literal>entity-name</literal> (optional): "
-"the entity name of the associated class, as an alternative to "
-"<literal>class</literal>. </para> </callout> <callout arearefs=\"manytomany8"
-"\"> <para> <literal>property-ref</literal> (optional): the name of a "
-"property of the associated class that is joined to this foreign key. If not "
-"specified, the primary key of the associated class is used. </para> </"
-"callout> </calloutlist> </programlistingco>"
+"literal> nested element."
 msgstr ""
+"<literal>fetch</literal>(可选 - 缺省为 <literal>join</literal>): 为这个关"
+"联启用外连接或序列性选择抓取。这是一个特例。对于在单个 <literal>SELECT</"
+"literal> 里进行完全的 eager fetching 以及使 <literal>&lt;many-to-many&gt;</"
+"literal> n用多对多关联,你可以启用 <literal>join</literal> fetching,这不仅是"
+"对于集合本身,也对 <literal>&lt;many-to-many&gt;</literal> 嵌套元素的属性。"
 
 #. Tag: para
-#: collection_mapping.xml:506
 #, no-c-format
-msgid "Here are some examples."
+msgid ""
+"<literal>unique</literal> (optional): enables the DDL generation of a unique "
+"constraint for the foreign-key column. This makes the association "
+"multiplicity effectively one-to-many."
 msgstr ""
+"<literal>unique</literal>(可选):未外键字段启用唯一约束的 DDL 生成。这使得"
+"关联一对多的多样性更为有效。"
 
 #. Tag: para
-#: collection_mapping.xml:509
 #, no-c-format
-msgid "A set of strings:"
+msgid ""
+"<literal>not-found</literal> (optional - defaults to <literal>exception</"
+"literal>): specifies how foreign keys that reference missing rows will be "
+"handled: <literal>ignore</literal> will treat a missing row as a null "
+"association."
 msgstr ""
+"<literal>not-found</literal>(可选 - 默认为 <literal>exception</literal>):"
+"指明若缓存的标示值关联的行缺失,该如何处理:<literal>ignore</literal> 会把缺"
+"失的行作为一个空关联处理。 "
 
-#. Tag: programlisting
-#: collection_mapping.xml:513
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"names\" table=\"person_names\">\n"
-"    <key column=\"person_id\"/>\n"
-"    <element column=\"person_name\" type=\"string\"/>\n"
-"</set>]]>"
+"<literal>entity-name</literal> (optional): the entity name of the associated "
+"class, as an alternative to <literal>class</literal>."
 msgstr ""
+"<literal>entity-name</literal>(可选):被关联的类的实体名,作为 "
+"<literal>class</literal> 的替代。 "
 
 #. Tag: para
-#: collection_mapping.xml:515
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"A bag containing integers with an iteration order determined by the "
-"<literal>order-by</literal> attribute:"
+"<literal>property-ref</literal> (optional): the name of a property of the "
+"associated class that is joined to this foreign key. If not specified, the "
+"primary key of the associated class is used."
 msgstr ""
-"一个实体数组,在这个案例中是一个多对多的关联(注意这里的实体是自动管理生命周期"
-"的对象(life cycle objects),<literal>cascade=\"all\"</literal>):"
+"<literal>property-ref</literal>(可选):连接至这个外键的关联类的属性名称。如"
+"果未指定,关联类的主键将被使用。"
 
-#. Tag: programlisting
-#: collection_mapping.xml:520
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<bag name=\"sizes\" \n"
-"        table=\"item_sizes\" \n"
-"        order-by=\"size asc\">\n"
-"    <key column=\"item_id\"/>\n"
-"    <element column=\"size\" type=\"integer\"/>\n"
-"</bag>]]>"
-msgstr ""
+msgid "Here are some examples."
+msgstr "下面是一些例子:"
 
 #. Tag: para
-#: collection_mapping.xml:522
-#, fuzzy, no-c-format
-msgid "An array of entities, in this case, a many-to-many association:"
-msgstr "一个map,通过字符串的索引来指明日期:"
+#, no-c-format
+msgid "A set of strings:"
+msgstr "一系列字符串:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:526
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<array name=\"addresses\" \n"
-"        table=\"PersonAddress\" \n"
-"        cascade=\"persist\">\n"
-"    <key column=\"personId\"/>\n"
-"    <list-index column=\"sortOrder\"/>\n"
-"    <many-to-many column=\"addressId\" class=\"Address\"/>\n"
-"</array>]]>"
+"A bag containing integers with an iteration order determined by the "
+"<literal>order-by</literal> attribute:"
 msgstr ""
+"包含一组整数的 bag(还设置了 <literal>order-by</literal> 参数指定了迭代的顺"
+"序): "
 
 #. Tag: para
-#: collection_mapping.xml:528
 #, no-c-format
-msgid "A map from string indices to dates:"
-msgstr "一个组件的列表:(下一章讨论)"
+msgid "An array of entities, in this case, a many-to-many association:"
+msgstr ""
+"一个实体数组,在这个案例中是一个多对多的关联(注意这里的实体是自动管理生命周"
+"期的对象(lifecycle objects),<literal>cascade=\"all\"</literal>): "
 
-#. Tag: programlisting
-#: collection_mapping.xml:532
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<map name=\"holidays\" \n"
-"        table=\"holidays\" \n"
-"        schema=\"dbo\" \n"
-"        order-by=\"hol_name asc\">\n"
-"    <key column=\"id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date\" type=\"date\"/>\n"
-"</map>]]>"
-msgstr ""
+msgid "A map from string indices to dates:"
+msgstr "一个 map,通过字符串的索引来指明日期:"
 
 #. Tag: para
-#: collection_mapping.xml:534
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A list of components (this is discussed in the next chapter):"
-msgstr "一对多关联(One-to-many Associations)"
+msgstr "一个组件的列表:(将在下一章讨论)"
 
-#. Tag: programlisting
-#: collection_mapping.xml:538
-#, no-c-format
-msgid ""
-"<![CDATA[<list name=\"carComponents\" \n"
-"        table=\"CarComponents\">\n"
-"    <key column=\"carId\"/>\n"
-"    <list-index column=\"sortOrder\"/>\n"
-"    <composite-element class=\"CarComponent\">\n"
-"        <property name=\"price\"/>\n"
-"        <property name=\"type\"/>\n"
-"        <property name=\"serialNumber\" column=\"serialNum\"/>\n"
-"    </composite-element>\n"
-"</list>]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:543
 #, no-c-format
 msgid "One-to-many associations"
-msgstr ""
-"<emphasis>一对多关联</emphasis><emphasis>通过外键</emphasis>连接两个类对应的"
-"表,而没有中间集合表。 这个关系模型失去了一些Java集合的语义:"
+msgstr "一对多关联(One-to-many Associations)"
 
 #. Tag: para
-#: collection_mapping.xml:545
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>one-to-many association</emphasis> links the tables of two "
 "classes via a foreign key with no intervening collection table. This mapping "
 "loses certain semantics of normal Java collections:"
-msgstr "一个被包含的实体的实例只能被包含在一个集合的实例中"
+msgstr ""
+"<emphasis>一对多关联</emphasis><emphasis>通过外键</emphasis>连接两个类对应的"
+"表,而没有中间集合表。 这个关系模型失去了一些 Java 集合的语义:"
 
 #. Tag: para
-#: collection_mapping.xml:553
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of the contained entity class cannot belong to more than one "
 "instance of the collection."
-msgstr "一个被包含的实体的实例只能对应于集合索引的一个值中"
+msgstr "一个被包含的实体的实例只能被包含在一个集合的实例中。"
 
 #. Tag: para
-#: collection_mapping.xml:559
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of the contained entity class cannot appear at more than one "
 "value of the collection index."
-msgstr ""
-"一个从<literal>Product</literal>到<literal>Part</literal>的关联需要关键字字"
-"段,可能还有一个索引字段指向<literal>Part</literal>所对应的表。 <literal>&lt;"
-"one-to-many&gt;</literal>标记指明了一个一对多的关联。"
+msgstr "一个被包含的实体的实例只能对应于集合索引的一个值中。"
 
 #. Tag: para
-#: collection_mapping.xml:566
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An association from <literal>Product</literal> to <literal>Part</literal> "
 "requires the existence of a foreign key column and possibly an index column "
 "to the <literal>Part</literal> table. A <literal>&lt;one-to-many&gt;</"
 "literal> tag indicates that this is a one-to-many association."
-msgstr "<literal>class</literal>(必须):被关联类的名称。"
-
-#. Tag: programlisting
-#: collection_mapping.xml:579
-#, no-c-format
-msgid ""
-"<![CDATA[<one-to-many \n"
-"        class=\"ClassName\"\n"
-"        not-found=\"ignore|exception\"\n"
-"        entity-name=\"EntityName\"\n"
-"        node=\"element-name\"\n"
-"        embed-xml=\"true|false\"\n"
-"    />]]>"
 msgstr ""
+"一个从 <literal>Product</literal> 到 <literal>Part</literal> 的关联需要关键字"
+"字段,可能还有一个索引字段指向 <literal>Part</literal> 所对应的表。"
+"<literal>&lt;one-to-many&gt;</literal> 标记指明了一个一对多的关联。 "
 
 #. Tag: para
-#: collection_mapping.xml:582
-#, fuzzy, no-c-format
-msgid "<literal>class</literal> (required): the name of the associated class."
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"为此关联打开外连接抓取或者后续select抓取。这是特殊情况;对于一个实体及其指向"
-"其他实体的多对多关联进全预先抓取(使用一条单独的<literal>SELECT</literal>),"
-"你不仅需要对集合自身打开<literal>join</literal>,也需要对<literal>&lt;many-"
-"to-many&gt;</literal>这个内嵌元素打开此属性。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>not-found</literal> (可选 - 默认为<literal>exception</literal>): 指"
-"明若缓存的标示值关联的行缺失,该如何处理: <literal>ignore</literal> 会把缺失的"
-"行作为一个空关联处理。"
-
-#. Tag: para
-#: collection_mapping.xml:587
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>not-found</literal> (optional - defaults to <literal>exception</"
 "literal>): specifies how cached identifiers that reference missing rows will "
 "be handled. <literal>ignore</literal> will treat a missing row as a null "
 "association."
 msgstr ""
-"<literal>entity-name</literal> (可选): 被关联的类的实体名,作为"
-"<literal>class</literal>的替代。"
+"<literal>not-found</literal>(可选 - 默认为<literal>exception</literal>):指"
+"明若缓存的标示值关联的行缺失,该如何处理:<literal>ignore</literal> 会把缺失"
+"的行作为一个空关联处理。 "
 
 #. Tag: para
-#: collection_mapping.xml:594
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"<literal>entity-name</literal> (optional): the entity name of the associated "
-"class, as an alternative to <literal>class</literal>."
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<literal>property-ref</literal>: (可选) 被关联到此外键(foreign key)的类中的对"
-"应属性的名字。若未指定,使用被关联类的主键。\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"例子"
-
-#. Tag: para
-#: collection_mapping.xml:602
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>&lt;one-to-many&gt;</literal> element does not need to declare "
 "any columns. Nor is it necessary to specify the <literal>table</literal> "
 "name anywhere."
 msgstr ""
-"注意:<literal>&lt;one-to-many&gt;</literal>元素不需要定义任何字段。 也不需要"
-"指定表名。"
+"注意:<literal>&lt;one-to-many&gt;</literal> 元素不需要定义任何字段。也不需要"
+"指定表名。 "
 
 #. Tag: para
-#: collection_mapping.xml:609
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the foreign key column of a <literal>&lt;one-to-many&gt;</literal> "
 "association is declared <literal>NOT NULL</literal>, you must declare the "
@@ -902,102 +716,65 @@
 "mapping marked <literal>inverse=\"true\"</literal>. See the discussion of "
 "bidirectional associations later in this chapter for more information."
 msgstr ""
-"<emphasis>重要提示</emphasis>:如果<literal>一对多</literal>关联中的外键字段定"
-"义成<literal>NOT NULL</literal>,你必须把<literal>&lt;key&gt;</literal>映射声"
-"明为<literal>not-null=\"true\"</literal>,或者使用<emphasis>双向关联</"
-"emphasis>,并且标明<literal>inverse=\"true\"</literal>。参阅本章后面关于双向"
-"关联的讨论。"
+"<emphasis>重要提示</emphasis>:如果<literal>一对多</literal>关联中的外键字段"
+"定义成 <literal>NOT NULL</literal>,你必须把 <literal>&lt;key&gt;</literal> "
+"映射声明为 <literal>not-null=\"true\"</literal>,或者使用<emphasis>双向关联</"
+"emphasis>,并且标明 <literal>inverse=\"true\"</literal>。参阅本章后面关于双向"
+"关联的讨论。 "
 
 #. Tag: para
-#: collection_mapping.xml:619
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following example shows a map of <literal>Part</literal> entities by "
 "name, where <literal>partName</literal> is a persistent property of "
 "<literal>Part</literal>. Notice the use of a formula-based index:"
 msgstr ""
-"下面的例子展示一个<literal>Part</literal>实体的map,把name作为关键字。"
-"( <literal>partName</literal> 是<literal>Part</literal>的持久化属性)。注意其"
-"中的基于公式的索引的用法。"
+"下面的例子展示一个 <literal>Part</literal> 实体的 map,把 name 作为关键字。"
+"( <literal>partName</literal> 是 <literal>Part</literal> 的持久化属性)。注"
+"意其中的基于公式的索引的用法。 "
 
-#. Tag: programlisting
-#: collection_mapping.xml:625
-#, no-c-format
-msgid ""
-"<![CDATA[<map name=\"parts\"\n"
-"        cascade=\"all\">\n"
-"    <key column=\"productId\" not-null=\"true\"/>\n"
-"    <map-key formula=\"partName\"/>\n"
-"    <one-to-many class=\"Part\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:631
 #, no-c-format
 msgid "Advanced collection mappings"
 msgstr "高级集合映射(Advanced collection mappings)"
 
 #. Tag: title
-#: collection_mapping.xml:634
 #, no-c-format
 msgid "Sorted collections"
 msgstr "有序集合(Sorted collections)"
 
 #. Tag: para
-#: collection_mapping.xml:636
 #, no-c-format
 msgid ""
 "Hibernate supports collections implementing <literal>java.util.SortedMap</"
 "literal> and <literal>java.util.SortedSet</literal>. You must specify a "
 "comparator in the mapping file:"
 msgstr ""
-"Hibernate支持实现<literal>java.util.SortedMap</literal>和<literal>java.util."
-"SortedSet</literal>的集合。 你必须在映射文件中指定一个比较器:"
+"Hibernate 支持实现 <literal>java.util.SortedMap</literal> 和 <literal>java."
+"util.SortedSet</literal> 的集合。你必须在映射文件中指定一个比较器:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:641
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"aliases\" \n"
-"            table=\"person_aliases\" \n"
-"            sort=\"natural\">\n"
-"    <key column=\"person\"/>\n"
-"    <element column=\"name\" type=\"string\"/>\n"
-"</set>\n"
-"\n"
-"<map name=\"holidays\" sort=\"my.custom.HolidayComparator\">\n"
-"    <key column=\"year_id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date\" type=\"date\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:643
 #, no-c-format
 msgid ""
 "Allowed values of the <literal>sort</literal> attribute are "
 "<literal>unsorted</literal>, <literal>natural</literal> and the name of a "
 "class implementing <literal>java.util.Comparator</literal>."
 msgstr ""
-"<literal>sort</literal>属性中允许的值包括<literal>unsorted</literal>,"
-"<literal>natural</literal>和某个实现了<literal>java.util.Comparator</literal>"
-"的类的名称。"
+"<literal>sort</literal> 属性中允许的值包括 <literal>unsorted</literal>,"
+"<literal>natural</literal> 和某个实现了 <literal>java.util.Comparator</"
+"literal> 的类的名称。"
 
 #. Tag: para
-#: collection_mapping.xml:649
 #, no-c-format
 msgid ""
 "Sorted collections actually behave like <literal>java.util.TreeSet</literal> "
 "or <literal>java.util.TreeMap</literal>."
 msgstr ""
-"分类集合的行为事实上象<literal>java.util.TreeSet</literal>或者<literal>java."
-"util.TreeMap</literal>。"
+"分类集合的行为事实上象 <literal>java.util.TreeSet</literal> 或者 "
+"<literal>java.util.TreeMap</literal>。"
 
 #. Tag: para
-#: collection_mapping.xml:654
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want the database itself to order the collection elements, use the "
 "<literal>order-by</literal> attribute of <literal>set</literal>, "
@@ -1006,154 +783,93 @@
 "<literal>LinkedHashSet</literal> or <literal>LinkedHashMap</literal>. This "
 "performs the ordering in the SQL query and not in the memory."
 msgstr ""
-"如果你希望数据库自己对集合元素排序,可以利用<literal>set</literal>,"
-"<literal>bag</literal>或者<literal>map</literal>映射中的<literal>order-by</"
-"literal>属性。这个解决方案只能在jdk1.4或者更高的jdk版本中才可以实现(通过"
-"LinkedHashSet或者 LinkedHashMap实现)。 它是在SQL查询中完成排序,而不是在内存"
-"中。"
+"如果你希望数据库自己对集合元素排序,可以利用 <literal>set</literal>,"
+"<literal>bag</literal> 或者 <literal>map</literal> 映射中的 <literal>order-"
+"by</literal> 属性。这个解决方案只能在 jdk1.4 或者更高的 jdk 版本中才可以实现"
+"(通过 LinkedHashSet 或者 LinkedHashMap 实现)。它是在 SQL 查询中完成排序,而"
+"不是在内存中。 "
 
-#. Tag: programlisting
-#: collection_mapping.xml:663
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"aliases\" table=\"person_aliases\" order-by=\"lower"
-"(name) asc\">\n"
-"    <key column=\"person\"/>\n"
-"    <element column=\"name\" type=\"string\"/>\n"
-"</set>\n"
-"\n"
-"<map name=\"holidays\" order-by=\"hol_date, hol_name\">\n"
-"    <key column=\"year_id\"/>\n"
-"    <map-key column=\"hol_name\" type=\"string\"/>\n"
-"    <element column=\"hol_date type=\"date\"/>\n"
-"</map>]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:666
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "注意"
 
 #. Tag: para
-#: collection_mapping.xml:667
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The value of the <literal>order-by</literal> attribute is an SQL ordering, "
 "not an HQL ordering."
 msgstr ""
-"注意: 这个<literal>order-by</literal>属性的值是一个SQL排序子句而不是HQL的!"
+"注意:这个 <literal>order-by</literal> 属性的值是一个 SQL 排序子句而不是 HQL "
+"的。"
 
 #. Tag: para
-#: collection_mapping.xml:673
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Associations can even be sorted by arbitrary criteria at runtime using a "
 "collection <literal>filter()</literal>:"
 msgstr ""
-"关联还可以在运行时使用集合<literal>filter()</literal>根据任意的条件来排序。"
+"关联还可以在运行时使用集合 <literal>filter()</literal> 根据任意的条件来排序:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:678
-#, no-c-format
-msgid ""
-"<![CDATA[sortedUsers = s.createFilter( group.getUsers(), \"order by this.name"
-"\" ).list();]]>"
-msgstr ""
-
 #. Tag: title
-#: collection_mapping.xml:683
 #, no-c-format
 msgid "Bidirectional associations"
 msgstr "双向关联(Bidirectional associations)"
 
 #. Tag: para
-#: collection_mapping.xml:685
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <emphasis>bidirectional association</emphasis> allows navigation from both "
 "\"ends\" of the association. Two kinds of bidirectional association are "
 "supported:"
 msgstr ""
-"<emphasis>双向关联</emphasis>允许通过关联的任一端访问另外一端。在Hibernate"
-"中, 支持两种类型的双向关联: <placeholder-1/>"
+"<emphasis>双向关联</emphasis>允许通过关联的任一端访问另外一端。在 Hibernate "
+"中,支持两种类型的双向关联: "
 
 #. Tag: term
-#: collection_mapping.xml:692
 #, no-c-format
 msgid "one-to-many"
 msgstr "一对多(one-to-many)"
 
 #. Tag: para
-#: collection_mapping.xml:694
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "set or bag valued at one end and single-valued at the other"
-msgstr "Set或者bag值在一端, 单独值(非集合)在另外一端"
+msgstr "Set 或者 bag 值在一端,单独值(非集合)在另外一端 "
 
 #. Tag: term
-#: collection_mapping.xml:700
 #, no-c-format
 msgid "many-to-many"
 msgstr "多对多(many-to-many)"
 
 #. Tag: para
-#: collection_mapping.xml:702
 #, no-c-format
 msgid "set or bag valued at both ends"
-msgstr "两端都是set或bag值"
+msgstr "两端都是 set 或 bag 值"
 
 #. Tag: para
-#: collection_mapping.xml:711
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can specify a bidirectional many-to-many association by mapping two many-"
 "to-many associations to the same database table and declaring one end as "
 "<emphasis>inverse</emphasis>. You cannot select an indexed collection."
 msgstr ""
-"要建立一个双向的多对多关联,只需要映射两个many-to-many关联到同一个数据库表"
-"中,并再定义其中的一端为<emphasis>inverse</emphasis>(使用哪一端要根据你的选"
-"择,但它不能是一个索引集合)。"
+"要建立一个双向的多对多关联,只需要映射两个 many-to-many 关联到同一个数据库表"
+"中,并再定义其中的一端为 <emphasis>inverse</emphasis>(使用哪一端要根据你的选"
+"择,但它不能是一个索引集合)。 "
 
 #. Tag: para
-#: collection_mapping.xml:718
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Here is an example of a bidirectional many-to-many association that "
 "illustrates how each category can have many items and each item can be in "
 "many categories:"
 msgstr ""
-"这里有一个many-to-many的双向关联的例子;每一个category都可以有很多items,每一个"
-"items可以属于很多categories:"
+"这里有一个 many-to-many 的双向关联的例子;每一个 category 都可以有很多 items,"
+"每一个 items 可以属于很多 categories: "
 
-#. Tag: programlisting
-#: collection_mapping.xml:723
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Category\">\n"
-"    <id name=\"id\" column=\"CATEGORY_ID\"/>\n"
-"    ...\n"
-"    <bag name=\"items\" table=\"CATEGORY_ITEM\">\n"
-"        <key column=\"CATEGORY_ID\"/>\n"
-"        <many-to-many class=\"Item\" column=\"ITEM_ID\"/>\n"
-"    </bag>\n"
-"</class>\n"
-"\n"
-"<class name=\"Item\">\n"
-"    <id name=\"id\" column=\"ITEM_ID\"/>\n"
-"    ...\n"
-"\n"
-"    <!-- inverse end -->\n"
-"    <bag name=\"categories\" table=\"CATEGORY_ITEM\" inverse=\"true\">\n"
-"        <key column=\"ITEM_ID\"/>\n"
-"        <many-to-many class=\"Category\" column=\"CATEGORY_ID\"/>\n"
-"    </bag>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:725
-#, fuzzy, no-c-format
-msgid ""
 "Changes made only to the inverse end of the association are <emphasis>not</"
 "emphasis> persisted. This means that Hibernate has two representations in "
 "memory for every bidirectional association: one link from A to B and another "
@@ -1161,27 +877,11 @@
 "object model and how a many-to-many relationship in Javais created:"
 msgstr ""
 "如果只对关联的反向端进行了改变,这个改变<emphasis>不会</emphasis>被持久化。 "
-"这表示Hibernate为每个双向关联在内存中存在两次表现,一个从A连接到B,另一个从B连"
-"接到A。如果你回想一下Java对象模型,我们是如何在Java中创建多对多关系的,这可以"
-"让你更容易理解:"
+"这表示 Hibernate 为每个双向关联在内存中存在两次表现,一个从 A 连接到 B,另一"
+"个从 B 连接到 A。如果你回想一下 Java 对象模型,我们是如何在 Java 中创建多对多"
+"关系的,这可以让你更容易理解: "
 
-#. Tag: programlisting
-#: collection_mapping.xml:733
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"category.getItems().add(item);          // The category now \"knows\" about "
-"the relationship\n"
-"item.getCategories().add(category);     // The item now \"knows\" about the "
-"relationship\n"
-"\n"
-"session.persist(item);                   // The relationship won't be "
-"saved!\n"
-"session.persist(category);               // The relationship will be saved]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:735
 #, no-c-format
 msgid ""
 "The non-inverse side is used to save the in-memory representation to the "
@@ -1189,59 +889,32 @@
 msgstr "非反向端用于把内存中的表示保存到数据库中。"
 
 #. Tag: para
-#: collection_mapping.xml:739
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can define a bidirectional one-to-many association by mapping a one-to-"
 "many association to the same table column(s) as a many-to-one association "
 "and declaring the many-valued end <literal>inverse=\"true\"</literal>."
 msgstr ""
 "要建立一个一对多的双向关联,你可以通过把一个一对多关联,作为一个多对一关联映"
-"射到到同一张表的字段上,并且在\"多\"的那一端定义<literal>inverse=\"true\"</"
-"literal>。"
+"射到到同一张表的字段上,并且在\"多\"的那一端定义 <literal>inverse=\"true\"</"
+"literal>。 "
 
-#. Tag: programlisting
-#: collection_mapping.xml:745
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <set name=\"children\" inverse=\"true\">\n"
-"        <key column=\"parent_id\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </set>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:747
-#, fuzzy, no-c-format
-msgid ""
 "Mapping one end of an association with <literal>inverse=\"true\"</literal> "
 "does not affect the operation of cascades as these are orthogonal concepts."
 msgstr ""
-"在“一”这一端定义<literal>inverse=\"true\"</literal>不会影响级联操作,二者是正"
-"交的概念!"
+"在“一”这一端定义 <literal>inverse=\"true\"</literal> 不会影响级联操作,二者是"
+"正交的概念。"
 
 #. Tag: title
-#: collection_mapping.xml:755
 #, no-c-format
 msgid "Bidirectional associations with indexed collections"
 msgstr "双向关联,涉及有序集合类"
 
 #. Tag: para
-#: collection_mapping.xml:756
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A bidirectional association where one end is represented as a <literal>&lt;"
 "list&gt;</literal> or <literal>&lt;map&gt;</literal>, requires special "
@@ -1249,41 +922,13 @@
 "index column you can use <literal>inverse=\"true\"</literal> on the "
 "collection mapping:"
 msgstr ""
-"对于有一端是<literal>&lt;list&gt;</literal>或者<literal>&lt;map&gt;</literal>"
-"的双向关联,需要加以特别考虑。假若子类中的一个属性映射到索引字段,没问题,我"
-"们仍然可以在集合类映射上使用<literal>inverse=\"true\"</literal>:"
+"对于有一端是 <literal>&lt;list&gt;</literal> 或者 <literal>&lt;map&gt;</"
+"literal> 的双向关联,需要加以特别考虑。假若子类中的一个属性映射到索引字段,没"
+"问题,我们仍然可以在集合类映射上使用 <literal>inverse=\"true\"</literal>: "
 
-#. Tag: programlisting
-#: collection_mapping.xml:763
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <map name=\"children\" inverse=\"true\">\n"
-"        <key column=\"parent_id\"/>\n"
-"        <map-key column=\"name\" \n"
-"            type=\"string\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </map>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <property name=\"name\" \n"
-"        not-null=\"true\"/>\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:765
-#, fuzzy, no-c-format
-msgid ""
 "If there is no such property on the child class, the association cannot be "
 "considered truly bidirectional. That is, there is information available at "
 "one end of the association that is not available at the other end. In this "
@@ -1291,111 +936,52 @@
 "Instead, you could use the following mapping:"
 msgstr ""
 "但是,假若子类中没有这样的属性存在,我们不能认为这个关联是真正的双向关联(信"
-"息不对称,在关联的一端有一些另外一端没有的信息)。在这种情况下,我们不能使用"
-"<literal>inverse=\"true\"</literal>。我们需要这样用:"
+"息不对称,在关联的一端有一些另外一端没有的信息)。在这种情况下,我们不能使用 "
+"<literal>inverse=\"true\"</literal>。我们需要这样用: "
 
-#. Tag: programlisting
-#: collection_mapping.xml:772
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Parent\">\n"
-"    <id name=\"id\" column=\"parent_id\"/>\n"
-"    ....\n"
-"    <map name=\"children\">\n"
-"        <key column=\"parent_id\"\n"
-"            not-null=\"true\"/>\n"
-"        <map-key column=\"name\" \n"
-"            type=\"string\"/>\n"
-"        <one-to-many class=\"Child\"/>\n"
-"    </map>\n"
-"</class>\n"
-"\n"
-"<class name=\"Child\">\n"
-"    <id name=\"id\" column=\"child_id\"/>\n"
-"    ....\n"
-"    <many-to-one name=\"parent\" \n"
-"        class=\"Parent\" \n"
-"        column=\"parent_id\"\n"
-"        insert=\"false\"\n"
-"        update=\"false\"\n"
-"        not-null=\"true\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:774
 #, fuzzy, no-c-format
 msgid ""
 "Note that in this mapping, the collection-valued end of the association is "
 "responsible for updates to the foreign key."
-msgstr ""
-"注意在这个映射中,关联中集合类\"值\"一端负责来更新外键.TODO: Does this "
-"really result in some unnecessary update statements?"
+msgstr "注意在这个映射中,关联中集合类\"值\"一端负责来更新外键。  "
 
 #. Tag: title
-#: collection_mapping.xml:782
 #, no-c-format
 msgid "Ternary associations"
 msgstr "三重关联(Ternary associations)"
 
 #. Tag: para
-#: collection_mapping.xml:784
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are three possible approaches to mapping a ternary association. One "
 "approach is to use a <literal>Map</literal> with an association as its index:"
 msgstr ""
-"有三种可能的途径来映射一个三重关联。第一种是使用一个<literal>Map</literal>,"
-"把一个关联作为其索引:"
+"有三种可能的途径来映射一个三重关联。第一种是使用一个 <literal>Map</literal>,"
+"把一个关联作为其索引: "
 
-#. Tag: programlisting
-#: collection_mapping.xml:789
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<map name=\"contracts\">\n"
-"    <key column=\"employer_id\" not-null=\"true\"/>\n"
-"    <map-key-many-to-many column=\"employee_id\" class=\"Employee\"/>\n"
-"    <one-to-many class=\"Contract\"/>\n"
-"</map>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: collection_mapping.xml:791
-#, no-c-format
-msgid ""
-"<![CDATA[<map name=\"connections\">\n"
-"    <key column=\"incoming_node_id\"/>\n"
-"    <map-key-many-to-many column=\"outgoing_node_id\" class=\"Node\"/>\n"
-"    <many-to-many column=\"connection_id\" class=\"Connection\"/>\n"
-"</map>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:793
-#, fuzzy, no-c-format
-msgid ""
 "A second approach is to remodel the association as an entity class. This is "
 "the most common approach."
 msgstr ""
-"第二种方法是简单的把关联重新建模为一个实体类。这使我们最经常使用的方法。"
+"第二种方法是简单的把关联重新建模为一个实体类。这使我们最经常使用的方法。 "
 
 #. Tag: para
-#: collection_mapping.xml:798
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A final alternative is to use composite elements, which will be discussed "
 "later."
-msgstr "最后一种选择是使用复合元素,我们会在后面讨论"
+msgstr "最后一种选择是使用复合元素,我们会在后面讨论。"
 
-#. Tag: literal
-#: collection_mapping.xml:805
-#, no-c-format
-msgid "Using an &lt;idbag&gt;"
-msgstr "使用&lt;idbag&gt;"
+#. Tag: title
+#, fuzzy, no-c-format
+msgid "<literal>Using an &lt;idbag&gt;</literal>"
+msgstr "<literal>使用 an &lt;idbag&gt;</literal>"
 
 #. Tag: para
-#: collection_mapping.xml:807
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The majority of the many-to-many associations and collections of values "
 "shown previously all map to tables with composite keys, even though it has "
@@ -1411,450 +997,1136 @@
 "怪,我们目前为止展示的多对多关联和值集合都是映射成为带有联合主键的表的!现"
 "在,这一点非常值得争辩;看上去一个单纯的关联表并不能从代用标识符中获得什么好"
 "处(虽然使用组合值的集合<emphasis>可能</emphasis>会获得一点好处)。不过,"
-"Hibernate提供了一个(一点点试验性质的)功能,让你把多对多关联和值集合应得到一"
-"个使用代用标识符的表去。"
+"Hibernate 提供了一个(一点点试验性质的)功能,让你把多对多关联和值集合应得到"
+"一个使用代用标识符的表去。 "
 
 #. Tag: para
-#: collection_mapping.xml:817
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;idbag&gt;</literal> element lets you map a <literal>List</"
 "literal> (or <literal>Collection</literal>) with bag semantics. For example:"
 msgstr ""
-"<literal>&lt;idbag&gt;</literal> 属性让你使用bag语义来映射一个<literal>List</"
-"literal> (或<literal>Collection</literal>)。"
+"<literal>&lt;idbag&gt;</literal> 属性让你使用 bag 语义来映射一个 "
+"<literal>List</literal> (或 <literal>Collection</literal>)。 "
 
-#. Tag: programlisting
-#: collection_mapping.xml:822
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<idbag name=\"lovers\" table=\"LOVERS\">\n"
-"    <collection-id column=\"ID\" type=\"long\">\n"
-"        <generator class=\"sequence\"/>\n"
-"    </collection-id>\n"
-"    <key column=\"PERSON1\"/>\n"
-"    <many-to-many column=\"PERSON2\" class=\"Person\" fetch=\"join\"/>\n"
-"</idbag>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:824
-#, fuzzy, no-c-format
-msgid ""
 "An <literal>&lt;idbag&gt;</literal> has a synthetic id generator, just like "
 "an entity class. A different surrogate key is assigned to each collection "
 "row. Hibernate does not, however, provide any mechanism for discovering the "
 "surrogate key value of a particular row."
 msgstr ""
-"你可以理解,<literal>&lt;idbag&gt;</literal>人工的id生成器,就好像是实体类一"
-"样!集合的每一行都有一个不同的人造关键字。但是,Hibernate没有提供任何机制来让"
-"你取得某个特定行的人造关键字。"
+"你可以理解,<literal>&lt;idbag&gt;</literal> 人工的 id 生成器,就好像是实体类"
+"一样!集合的每一行都有一个不同的人造关键字。但是,Hibernate 没有提供任何机制"
+"来让你取得某个特定行的人造关键字。 "
 
 #. Tag: para
-#: collection_mapping.xml:831
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The update performance of an <literal>&lt;idbag&gt;</literal> supersedes a "
 "regular <literal>&lt;bag&gt;</literal>. Hibernate can locate individual rows "
 "efficiently and update or delete them individually, similar to a list, map "
 "or set."
 msgstr ""
-"注意<literal>&lt;idbag&gt;</literal>的更新性能要比普通的<literal>&lt;bag&gt;"
-"</literal>高得多!Hibernate可以有效的定位到不同的行,分别进行更新或删除工作,"
-"就如同处理一个list, map或者set一样。"
+"注意 <literal>&lt;idbag&gt;</literal> 的更新性能要比普通的 <literal>&lt;"
+"bag&gt;</literal> 高得多!Hibernate 可以有效的定位到不同的行,分别进行更新或"
+"删除工作,就如同处理一个 list,map 或者 set 一样。 "
 
 #. Tag: para
-#: collection_mapping.xml:837
 #, no-c-format
 msgid ""
 "In the current implementation, the <literal>native</literal> identifier "
 "generation strategy is not supported for <literal>&lt;idbag&gt;</literal> "
 "collection identifiers."
 msgstr ""
-"在目前的实现中,还不支持使用<literal>identity</literal>标识符生成器策略来生成"
-"<literal>&lt;idbag&gt;</literal>集合的标识符。"
+"在目前的实现中,还不支持使用 <literal>identity</literal> 标识符生成器策略来生"
+"成 <literal>&lt;idbag&gt;</literal> 集合的标识符。"
 
 #. Tag: title
-#: collection_mapping.xml:861
 #, no-c-format
 msgid "Collection examples"
 msgstr "集合例子(Collection example)"
 
 #. Tag: para
-#: collection_mapping.xml:863
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This section covers collection examples."
-msgstr "集合例子(Collection example)"
+msgstr "集合例子(Collection example)。"
 
 #. Tag: para
-#: collection_mapping.xml:867
 #, no-c-format
 msgid ""
 "The following class has a collection of <literal>Child</literal> instances:"
-msgstr ""
+msgstr "下面的代码是用来添加一个新的 <literal>Child</literal>:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:871
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"\n"
-"public class Parent {\n"
-"    private long id;\n"
-"    private Set children;\n"
-"\n"
-"    public long getId() { return id; }\n"
-"    private void setId(long id) { this.id=id; }\n"
-"\n"
-"    private Set getChildren() { return children; }\n"
-"    private void setChildren(Set children) { this.children=children; }\n"
-"\n"
-"    ....\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:873
-#, fuzzy, no-c-format
-msgid ""
 "If each child has, at most, one parent, the most natural mapping is a one-to-"
 "many association:"
 msgstr ""
-"这个类有一个<literal>Child</literal>的实例集合。如果每一个子实例至多有一个父"
-"实例, 那么最自然的映射是一个one-to-many的关联关系:"
+"这个类有一个 <literal>Child</literal> 的实例集合。如果每一个子实例至多有一个"
+"父实例,那么最自然的映射是一个 one-to-many 的关联关系: "
 
-#. Tag: programlisting
-#: collection_mapping.xml:879
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:881
 #, no-c-format
 msgid "This maps to the following table definitions:"
 msgstr "在以下的表定义中反应了这个映射关系:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:885
-#, no-c-format
-msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null primary key, name varchar(255), "
-"parent_id bigint )\n"
-"alter table child add constraint childfk0 (parent_id) references parent]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:887
 #, no-c-format
 msgid ""
 "If the parent is <emphasis>required</emphasis>, use a bidirectional one-to-"
 "many association:"
 msgstr ""
-"如果父亲是<emphasis>必须</emphasis>的, 那么就可以使用双向one-to-many的关联"
+"如果父亲是<emphasis>必须</emphasis>的,那么就可以使用双向 one-to-many 的关联"
 "了:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:892
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\" inverse=\"true\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"        <many-to-one name=\"parent\" class=\"Parent\" column=\"parent_id\" "
-"not-null=\"true\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:894
 #, no-c-format
 msgid "Notice the <literal>NOT NULL</literal> constraint:"
-msgstr "请注意<literal>NOT NULL</literal>的约束:"
+msgstr "请注意 <literal>NOT NULL</literal> 的约束:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:898
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null\n"
-"                     primary key,\n"
-"                     name varchar(255),\n"
-"                     parent_id bigint not null )\n"
-"alter table child add constraint childfk0 (parent_id) references parent]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:900
-#, fuzzy, no-c-format
-msgid ""
 "Alternatively, if this association must be unidirectional you can declare "
 "the <literal>NOT NULL</literal> constraint on the <literal>&lt;key&gt;</"
 "literal> mapping:"
 msgstr ""
-"另外,如果你绝对坚持这个关联应该是单向的,你可以对<literal>&lt;key&gt;</"
-"literal>映射声明<literal>NOT NULL</literal>约束:"
+"另外,如果你绝对坚持这个关联应该是单向的,你可以对 <literal>&lt;key&gt;</"
+"literal> 映射声明 <literal>NOT NULL</literal> 约束: "
 
-#. Tag: programlisting
-#: collection_mapping.xml:906
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\">\n"
-"            <key column=\"parent_id\" not-null=\"true\"/>\n"
-"            <one-to-many class=\"Child\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: collection_mapping.xml:908
-#, fuzzy, no-c-format
-msgid ""
 "On the other hand, if a child has multiple parents, a many-to-many "
 "association is appropriate:"
 msgstr ""
-"另外一方面,如果一个子实例可能有多个父实例, 那么就应该使用many-to-many关联:"
+"另外一方面,如果一个子实例可能有多个父实例,那么就应该使用 many-to-many 关"
+"联: "
 
-#. Tag: programlisting
-#: collection_mapping.xml:913
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Parent\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <set name=\"children\" table=\"childset\">\n"
-"            <key column=\"parent_id\"/>\n"
-"            <many-to-many class=\"Child\" column=\"child_id\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Child\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:915
 #, no-c-format
 msgid "Table definitions:"
 msgstr "表定义:"
 
-#. Tag: programlisting
-#: collection_mapping.xml:919
-#, no-c-format
-msgid ""
-"<![CDATA[create table parent ( id bigint not null primary key )\n"
-"create table child ( id bigint not null primary key, name varchar(255) )\n"
-"create table childset ( parent_id bigint not null,\n"
-"                        child_id bigint not null,\n"
-"                        primary key ( parent_id, child_id ) )\n"
-"alter table childset add constraint childsetfk0 (parent_id) references "
-"parent\n"
-"alter table childset add constraint childsetfk1 (child_id) references child]]"
-">"
-msgstr ""
-
 #. Tag: para
-#: collection_mapping.xml:921
 #, fuzzy, no-c-format
 msgid ""
 "For more examples and a complete explanation of a parent/child relationship "
-"mapping, see <xref linkend=\"example-parentchild\"/> for more information."
+"mapping, see <xref linkend=\"example-parentchild\" /> for more information."
 msgstr ""
-"更多的例子,以及一个完整的父/子关系映射的排练,请参阅<xref linkend=\"example-"
-"parentchild\"/>."
+"更多的例子,以及一个完整的父/子关系映射的排练,请参阅 <xref linkend="
+"\"example-parentchild\"/>。  "
 
 #. Tag: para
-#: collection_mapping.xml:926
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Even more complex association mappings are covered in the next chapter."
-msgstr "甚至可能出现更加复杂的关联映射,我们会在下一章中列出所有可能性。"
+msgstr "甚至可能出现更加复杂的关联映射,我们会在下一章中列出所有可能性。 "
 
-#~ msgid "Collection Mapping"
-#~ msgstr "集合类(Collections)映射"
+#~ msgid ""
+#~ "<![CDATA[public class Product {\n"
+#~ "    private String serialNumber;\n"
+#~ "    private Set parts = new HashSet();\n"
+#~ "    \n"
+#~ "    public Set getParts() { return parts; }\n"
+#~ "    void setParts(Set parts) { this.parts = parts; }\n"
+#~ "    public String getSerialNumber() { return serialNumber; }\n"
+#~ "    void setSerialNumber(String sn) { serialNumber = sn; }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[public class Product {\n"
+#~ "    private String serialNumber;\n"
+#~ "    private Set parts = new HashSet();\n"
+#~ "    \n"
+#~ "    public Set getParts() { return parts; }\n"
+#~ "    void setParts(Set parts) { this.parts = parts; }\n"
+#~ "    public String getSerialNumber() { return serialNumber; }\n"
+#~ "    void setSerialNumber(String sn) { serialNumber = sn; }\n"
+#~ "}]]>"
 
-#~ msgid "Some examples, first, a set of strings:"
+#~ msgid ""
+#~ "<![CDATA[Cat cat = new DomesticCat();\n"
+#~ "Cat kitten = new DomesticCat();\n"
+#~ "....\n"
+#~ "Set kittens = new HashSet();\n"
+#~ "kittens.add(kitten);\n"
+#~ "cat.setKittens(kittens);\n"
+#~ "session.persist(cat);\n"
+#~ "kittens = cat.getKittens(); // Okay, kittens collection is a Set\n"
+#~ "(HashSet) cat.getKittens(); // Error!]]>"
 #~ msgstr ""
-#~ "包含一组整数的bag(还设置了<literal>order-by</literal>参数指定了迭代的顺"
-#~ "序):"
+#~ "<![CDATA[Cat cat = new DomesticCat();\n"
+#~ "Cat kitten = new DomesticCat();\n"
+#~ "....\n"
+#~ "Set kittens = new HashSet();\n"
+#~ "kittens.add(kitten);\n"
+#~ "cat.setKittens(kittens);\n"
+#~ "session.persist(cat);\n"
+#~ "kittens = cat.getKittens(); // Okay, kittens collection is a Set\n"
+#~ "(HashSet) cat.getKittens(); // Error!]]>"
 
 #~ msgid ""
-#~ "The previous sections are pretty confusing. So lets look at an example. "
-#~ "This class:"
-#~ msgstr "在前面的几个章节的确非常令人迷惑。 因此让我们来看一个例子。这个类:"
+#~ "<![CDATA[<class name=\"Product\">\n"
+#~ "    <id name=\"serialNumber\" column=\"productSerialNumber\"/>\n"
+#~ "    <set name=\"parts\">\n"
+#~ "        <key column=\"productSerialNumber\" not-null=\"true\"/>\n"
+#~ "        <one-to-many class=\"Part\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Product\">\n"
+#~ "    <id name=\"serialNumber\" column=\"productSerialNumber\"/>\n"
+#~ "    <set name=\"parts\">\n"
+#~ "        <key column=\"productSerialNumber\" not-null=\"true\"/>\n"
+#~ "        <one-to-many class=\"Part\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
 
 #~ msgid ""
-#~ "<literal>column_name</literal> (required): The name of the column holding "
-#~ "the collection index values."
-#~ msgstr "<literal>column</literal>(可选):保存集合索引值的字段名。"
+#~ "<![CDATA[<map\n"
+#~ "    name=\"propertyName\"\n"
+#~ "    table=\"table_name\"\n"
+#~ "    schema=\"schema_name\"\n"
+#~ "    lazy=\"true|extra|false\"\n"
+#~ "    inverse=\"true|false\"\n"
+#~ "    cascade=\"all|none|save-update|delete|all-delete-orphan|delete-orphan"
+#~ "\"\n"
+#~ "    sort=\"unsorted|natural|comparatorClass\"\n"
+#~ "    order-by=\"column_name asc|desc\"\n"
+#~ "    where=\"arbitrary sql where condition\"\n"
+#~ "    fetch=\"join|select|subselect\"\n"
+#~ "    batch-size=\"N\"\n"
+#~ "    access=\"field|property|ClassName\"\n"
+#~ "    optimistic-lock=\"true|false\"\n"
+#~ "    mutable=\"true|false\"\n"
+#~ "    node=\"element-name|.\"\n"
+#~ "    embed-xml=\"true|false\"\n"
+#~ ">\n"
+#~ "\n"
+#~ "    <key .... />\n"
+#~ "    <map-key .... />\n"
+#~ "    <element .... />\n"
+#~ "</map>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<map\n"
+#~ "    name=\"propertyName\"\n"
+#~ "    table=\"table_name\"\n"
+#~ "    schema=\"schema_name\"\n"
+#~ "    lazy=\"true|extra|false\"\n"
+#~ "    inverse=\"true|false\"\n"
+#~ "    cascade=\"all|none|save-update|delete|all-delete-orphan|delete-orphan"
+#~ "\"\n"
+#~ "    sort=\"unsorted|natural|comparatorClass\"\n"
+#~ "    order-by=\"column_name asc|desc\"\n"
+#~ "    where=\"arbitrary sql where condition\"\n"
+#~ "    fetch=\"join|select|subselect\"\n"
+#~ "    batch-size=\"N\"\n"
+#~ "    access=\"field|property|ClassName\"\n"
+#~ "    optimistic-lock=\"true|false\"\n"
+#~ "    mutable=\"true|false\"\n"
+#~ "    node=\"element-name|.\"\n"
+#~ "    embed-xml=\"true|false\"\n"
+#~ ">\n"
+#~ "\n"
+#~ "    <key .... />\n"
+#~ "    <map-key .... />\n"
+#~ "    <element .... />\n"
+#~ "</map>]]>"
 
+#~ msgid "<![CDATA[<key column=\"productSerialNumber\" not-null=\"true\"/>]]>"
+#~ msgstr "<![CDATA[<key column=\"productSerialNumber\" not-null=\"true\"/>]]>"
+
 #~ msgid ""
-#~ "<literal>base</literal> (optional, defaults to <literal>0</literal>): The "
-#~ "value of the index column that corresponds to the first element of the "
-#~ "list or array."
-#~ msgstr "<literal>formula</literal> (可选): 用于计算map关键字的SQL公式"
+#~ "<![CDATA[<key column=\"productSerialNumber\" on-delete=\"cascade\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<key column=\"productSerialNumber\" on-delete=\"cascade\"/>]]>"
 
 #~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the column holding the "
-#~ "collection index values."
-#~ msgstr "<literal>type</literal> (必须):映射键(map key)的类型。"
+#~ "<programlistingco> <areaspec> <area id=\"index1\" coords=\"2 45\"/> <area "
+#~ "id=\"index2\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA"
+#~ "[<list-index \n"
+#~ "        column=\"column_name\"\n"
+#~ "        base=\"0|1|...\"/>]]></programlisting> <calloutlist> <callout "
+#~ "arearefs=\"index1\"> <para> <literal>column_name</literal> (required): "
+#~ "the name of the column holding the collection index values. </para> </"
+#~ "callout> <callout arearefs=\"index1\"> <para> <literal>base</literal> "
+#~ "(optional - defaults to <literal>0</literal>): the value of the index "
+#~ "column that corresponds to the first element of the list or array. </"
+#~ "para> </callout> </calloutlist> </programlistingco> <programlistingco> "
+#~ "<areaspec> <area id=\"mapkey1\" coords=\"2 45\"/> <area id=\"mapkey2\" "
+#~ "coords=\"3 45\"/> <area id=\"mapkey3\" coords=\"4 45\"/> </areaspec> "
+#~ "<programlisting><![CDATA[<map-key \n"
+#~ "        column=\"column_name\"\n"
+#~ "        formula=\"any SQL expression\"\n"
+#~ "        type=\"type_name\"\n"
+#~ "        node=\"@attribute-name\"\n"
+#~ "        length=\"N\"/>]]></programlisting> <calloutlist> <callout "
+#~ "arearefs=\"mapkey1\"> <para> <literal>column</literal> (optional): the "
+#~ "name of the column holding the collection index values. </para> </"
+#~ "callout> <callout arearefs=\"mapkey2\"> <para> <literal>formula</literal> "
+#~ "(optional): a SQL formula used to evaluate the key of the map. </para> </"
+#~ "callout> <callout arearefs=\"mapkey3\"> <para> <literal>type</literal> "
+#~ "(required): the type of the map keys. </para> </callout> </calloutlist> </"
+#~ "programlistingco> <programlistingco> <areaspec> <area id="
+#~ "\"indexmanytomany1\" coords=\"2 45\"/> <area id=\"indexmanytomany2\" "
+#~ "coords=\"3 45\"/> <area id=\"indexmanytomany3\" coords=\"3 45\"/> </"
+#~ "areaspec> <programlisting><![CDATA[<map-key-many-to-many\n"
+#~ "        column=\"column_name\"\n"
+#~ "        formula=\"any SQL expression\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "/>]]></programlisting> <calloutlist> <callout arearefs=\"indexmanytomany1"
+#~ "\"> <para> <literal>column</literal> (optional): the name of the foreign "
+#~ "key column for the collection index values. </para> </callout> <callout "
+#~ "arearefs=\"indexmanytomany2\"> <para> <literal>formula</literal> "
+#~ "(optional): a SQ formula used to evaluate the foreign key of the map key. "
+#~ "</para> </callout> <callout arearefs=\"indexmanytomany3\"> <para> "
+#~ "<literal>class</literal> (required): the entity class used as the map "
+#~ "key. </para> </callout> </calloutlist> </programlistingco>"
+#~ msgstr ""
+#~ "<programlistingco> <areaspec> <area id=\"index1\" coords=\"2 45\"/> <area "
+#~ "id=\"index2\" coords=\"3 45\"/> </areaspec> <programlisting><![CDATA"
+#~ "[<list-index \n"
+#~ "        column=\"column_name\"\n"
+#~ "        base=\"0|1|...\"/>]]></programlisting> <calloutlist> <callout "
+#~ "arearefs=\"index1\"> <para> <literal>column_name</literal> (required): "
+#~ "the name of the column holding the collection index values. </para> </"
+#~ "callout> <callout arearefs=\"index1\"> <para> <literal>base</literal> "
+#~ "(optional - defaults to <literal>0</literal>): the value of the index "
+#~ "column that corresponds to the first element of the list or array. </"
+#~ "para> </callout> </calloutlist> </programlistingco> <programlistingco> "
+#~ "<areaspec> <area id=\"mapkey1\" coords=\"2 45\"/> <area id=\"mapkey2\" "
+#~ "coords=\"3 45\"/> <area id=\"mapkey3\" coords=\"4 45\"/> </areaspec> "
+#~ "<programlisting><![CDATA[<map-key \n"
+#~ "        column=\"column_name\"\n"
+#~ "        formula=\"any SQL expression\"\n"
+#~ "        type=\"type_name\"\n"
+#~ "        node=\"@attribute-name\"\n"
+#~ "        length=\"N\"/>]]></programlisting> <calloutlist> <callout "
+#~ "arearefs=\"mapkey1\"> <para> <literal>column</literal> (optional): the "
+#~ "name of the column holding the collection index values. </para> </"
+#~ "callout> <callout arearefs=\"mapkey2\"> <para> <literal>formula</literal> "
+#~ "(optional): a SQL formula used to evaluate the key of the map. </para> </"
+#~ "callout> <callout arearefs=\"mapkey3\"> <para> <literal>type</literal> "
+#~ "(required): the type of the map keys. </para> </callout> </calloutlist> </"
+#~ "programlistingco> <programlistingco> <areaspec> <area id="
+#~ "\"indexmanytomany1\" coords=\"2 45\"/> <area id=\"indexmanytomany2\" "
+#~ "coords=\"3 45\"/> <area id=\"indexmanytomany3\" coords=\"3 45\"/> </"
+#~ "areaspec> <programlisting><![CDATA[<map-key-many-to-many\n"
+#~ "        column=\"column_name\"\n"
+#~ "        formula=\"any SQL expression\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "/>]]></programlisting> <calloutlist> <callout arearefs=\"indexmanytomany1"
+#~ "\"> <para> <literal>column</literal> (optional): the name of the foreign "
+#~ "key column for the collection index values. </para> </callout> <callout "
+#~ "arearefs=\"indexmanytomany2\"> <para> <literal>formula</literal> "
+#~ "(optional): a SQ formula used to evaluate the foreign key of the map key. "
+#~ "</para> </callout> <callout arearefs=\"indexmanytomany3\"> <para> "
+#~ "<literal>class</literal> (required): the entity class used as the map "
+#~ "key. </para> </callout> </calloutlist> </programlistingco>"
 
 #~ msgid ""
-#~ "<literal>formula</literal> (optional): A SQL formula used to evaluate the "
-#~ "key of the map."
-#~ msgstr "<literal>column</literal>(可选):集合索引值中外键字段的名称"
+#~ "<programlistingco> <areaspec> <area id=\"element1b\" coords=\"2 50\"/> "
+#~ "<area id=\"element2b\" coords=\"3 50\"/> <area id=\"element3b\" coords="
+#~ "\"4 50\"/> </areaspec> <programlisting><![CDATA[<element\n"
+#~ "        column=\"column_name\"\n"
+#~ "        formula=\"any SQL expression\"\n"
+#~ "        type=\"typename\"\n"
+#~ "        length=\"L\"\n"
+#~ "        precision=\"P\"\n"
+#~ "        scale=\"S\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "/>]]></programlisting> <calloutlist> <callout arearefs=\"element1b\"> "
+#~ "<para> <literal>column</literal> (optional): the name of the column "
+#~ "holding the collection element values. </para> </callout> <callout "
+#~ "arearefs=\"element2b\"> <para> <literal>formula</literal> (optional): an "
+#~ "SQL formula used to evaluate the element. </para> </callout> <callout "
+#~ "arearefs=\"element3b\"> <para> <literal>type</literal> (required): the "
+#~ "type of the collection element. </para> </callout> </calloutlist> </"
+#~ "programlistingco> <para> A <emphasis>many-to-many association</emphasis> "
+#~ "is specified using the <literal>&lt;many-to-many&gt;</literal> element. </"
+#~ "para> <programlistingco> <areaspec> <area id=\"manytomany1\" coords=\"2 60"
+#~ "\"/> <area id=\"manytomany2\" coords=\"3 60\"/> <area id=\"manytomany3\" "
+#~ "coords=\"4 60\"/> <area id=\"manytomany4\" coords=\"5 60\"/> <area id="
+#~ "\"manytomany5\" coords=\"6 60\"/> <area id=\"manytomany6\" coords=\"7 60"
+#~ "\"/> <area id=\"manytomany7\" coords=\"8 60\"/> <area id=\"manytomany8\" "
+#~ "coords=\"9 60\"/> </areaspec> <programlisting><![CDATA[<many-to-many\n"
+#~ "        column=\"column_name\"\n"
+#~ "        formula=\"any SQL expression\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        fetch=\"select|join\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        not-found=\"ignore|exception\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        property-ref=\"propertyNameFromAssociatedClass\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "        embed-xml=\"true|false\"\n"
+#~ "    />]]></programlisting> <calloutlist> <callout arearefs=\"manytomany1"
+#~ "\"> <para> <literal>column</literal> (optional): the name of the element "
+#~ "foreign key column. </para> </callout> <callout arearefs=\"manytomany2\"> "
+#~ "<para> <literal>formula</literal> (optional): an SQL formula used to "
+#~ "evaluate the element foreign key value. </para> </callout> <callout "
+#~ "arearefs=\"manytomany3\"> <para> <literal>class</literal> (required): the "
+#~ "name of the associated class. </para> </callout> <callout arearefs="
+#~ "\"manytomany4\"> <para> <literal>fetch</literal> (optional - defaults to "
+#~ "<literal>join</literal>): enables outer-join or sequential select "
+#~ "fetching for this association. This is a special case; for full eager "
+#~ "fetching in a single <literal>SELECT</literal> of an entity and its many-"
+#~ "to-many relationships to other entities, you would enable <literal>join</"
+#~ "literal> fetching,not only of the collection itself, but also with this "
+#~ "attribute on the <literal>&lt;many-to-many&gt;</literal> nested element. "
+#~ "</para> </callout> <callout arearefs=\"manytomany5\"> <para> "
+#~ "<literal>unique</literal> (optional): enables the DDL generation of a "
+#~ "unique constraint for the foreign-key column. This makes the association "
+#~ "multiplicity effectively one-to-many. </para> </callout> <callout "
+#~ "arearefs=\"manytomany6\"> <para> <literal>not-found</literal> (optional - "
+#~ "defaults to <literal>exception</literal>): specifies how foreign keys "
+#~ "that reference missing rows will be handled: <literal>ignore</literal> "
+#~ "will treat a missing row as a null association. </para> </callout> "
+#~ "<callout arearefs=\"manytomany7\"> <para> <literal>entity-name</literal> "
+#~ "(optional): the entity name of the associated class, as an alternative to "
+#~ "<literal>class</literal>. </para> </callout> <callout arearefs="
+#~ "\"manytomany8\"> <para> <literal>property-ref</literal> (optional): the "
+#~ "name of a property of the associated class that is joined to this foreign "
+#~ "key. If not specified, the primary key of the associated class is used. </"
+#~ "para> </callout> </calloutlist> </programlistingco>"
+#~ msgstr ""
+#~ "<programlistingco> <areaspec> <area id=\"element1b\" coords=\"2 50\"/> "
+#~ "<area id=\"element2b\" coords=\"3 50\"/> <area id=\"element3b\" coords="
+#~ "\"4 50\"/> </areaspec> <programlisting><![CDATA[<element\n"
+#~ "        column=\"column_name\"\n"
+#~ "        formula=\"any SQL expression\"\n"
+#~ "        type=\"typename\"\n"
+#~ "        length=\"L\"\n"
+#~ "        precision=\"P\"\n"
+#~ "        scale=\"S\"\n"
+#~ "        not-null=\"true|false\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "/>]]></programlisting> <calloutlist> <callout arearefs=\"element1b\"> "
+#~ "<para> <literal>column</literal> (optional): the name of the column "
+#~ "holding the collection element values. </para> </callout> <callout "
+#~ "arearefs=\"element2b\"> <para> <literal>formula</literal> (optional): an "
+#~ "SQL formula used to evaluate the element. </para> </callout> <callout "
+#~ "arearefs=\"element3b\"> <para> <literal>type</literal> (required): the "
+#~ "type of the collection element. </para> </callout> </calloutlist> </"
+#~ "programlistingco> <para> A <emphasis>many-to-many association</emphasis> "
+#~ "is specified using the <literal>&lt;many-to-many&gt;</literal> element. </"
+#~ "para> <programlistingco> <areaspec> <area id=\"manytomany1\" coords=\"2 60"
+#~ "\"/> <area id=\"manytomany2\" coords=\"3 60\"/> <area id=\"manytomany3\" "
+#~ "coords=\"4 60\"/> <area id=\"manytomany4\" coords=\"5 60\"/> <area id="
+#~ "\"manytomany5\" coords=\"6 60\"/> <area id=\"manytomany6\" coords=\"7 60"
+#~ "\"/> <area id=\"manytomany7\" coords=\"8 60\"/> <area id=\"manytomany8\" "
+#~ "coords=\"9 60\"/> </areaspec> <programlisting><![CDATA[<many-to-many\n"
+#~ "        column=\"column_name\"\n"
+#~ "        formula=\"any SQL expression\"\n"
+#~ "        class=\"ClassName\"\n"
+#~ "        fetch=\"select|join\"\n"
+#~ "        unique=\"true|false\"\n"
+#~ "        not-found=\"ignore|exception\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        property-ref=\"propertyNameFromAssociatedClass\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "        embed-xml=\"true|false\"\n"
+#~ "    />]]></programlisting> <calloutlist> <callout arearefs=\"manytomany1"
+#~ "\"> <para> <literal>column</literal> (optional): the name of the element "
+#~ "foreign key column. </para> </callout> <callout arearefs=\"manytomany2\"> "
+#~ "<para> <literal>formula</literal> (optional): an SQL formula used to "
+#~ "evaluate the element foreign key value. </para> </callout> <callout "
+#~ "arearefs=\"manytomany3\"> <para> <literal>class</literal> (required): the "
+#~ "name of the associated class. </para> </callout> <callout arearefs="
+#~ "\"manytomany4\"> <para> <literal>fetch</literal> (optional - defaults to "
+#~ "<literal>join</literal>): enables outer-join or sequential select "
+#~ "fetching for this association. This is a special case; for full eager "
+#~ "fetching in a single <literal>SELECT</literal> of an entity and its many-"
+#~ "to-many relationships to other entities, you would enable <literal>join</"
+#~ "literal> fetching,not only of the collection itself, but also with this "
+#~ "attribute on the <literal>&lt;many-to-many&gt;</literal> nested element. "
+#~ "</para> </callout> <callout arearefs=\"manytomany5\"> <para> "
+#~ "<literal>unique</literal> (optional): enables the DDL generation of a "
+#~ "unique constraint for the foreign-key column. This makes the association "
+#~ "multiplicity effectively one-to-many. </para> </callout> <callout "
+#~ "arearefs=\"manytomany6\"> <para> <literal>not-found</literal> (optional - "
+#~ "defaults to <literal>exception</literal>): specifies how foreign keys "
+#~ "that reference missing rows will be handled: <literal>ignore</literal> "
+#~ "will treat a missing row as a null association. </para> </callout> "
+#~ "<callout arearefs=\"manytomany7\"> <para> <literal>entity-name</literal> "
+#~ "(optional): the entity name of the associated class, as an alternative to "
+#~ "<literal>class</literal>. </para> </callout> <callout arearefs="
+#~ "\"manytomany8\"> <para> <literal>property-ref</literal> (optional): the "
+#~ "name of a property of the associated class that is joined to this foreign "
+#~ "key. If not specified, the primary key of the associated class is used. </"
+#~ "para> </callout> </calloutlist> </programlistingco>"
 
-#~ msgid "<literal>type</literal> (reguired): The type of the map keys."
-#~ msgstr "<literal>formula</literal> (可选): 用于计算map关键字的外键的SQL公式"
+#~ msgid ""
+#~ "<![CDATA[<set name=\"names\" table=\"person_names\">\n"
+#~ "    <key column=\"person_id\"/>\n"
+#~ "    <element column=\"person_name\" type=\"string\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"names\" table=\"person_names\">\n"
+#~ "    <key column=\"person_id\"/>\n"
+#~ "    <element column=\"person_name\" type=\"string\"/>\n"
+#~ "</set>]]>"
 
 #~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the foreign key column "
-#~ "for the collection index values."
-#~ msgstr "<literal>class</literal> (必需):映射的键(map key)使用的实体类。"
+#~ "<![CDATA[<bag name=\"sizes\" \n"
+#~ "        table=\"item_sizes\" \n"
+#~ "        order-by=\"size asc\">\n"
+#~ "    <key column=\"item_id\"/>\n"
+#~ "    <element column=\"size\" type=\"integer\"/>\n"
+#~ "</bag>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<bag name=\"sizes\" \n"
+#~ "        table=\"item_sizes\" \n"
+#~ "        order-by=\"size asc\">\n"
+#~ "    <key column=\"item_id\"/>\n"
+#~ "    <element column=\"size\" type=\"integer\"/>\n"
+#~ "</bag>]]>"
 
 #~ msgid ""
-#~ "<literal>formula</literal> (optional): A SQL formula used to evaluate the "
-#~ "foreign key of the map key."
+#~ "<![CDATA[<array name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\" \n"
+#~ "        cascade=\"persist\">\n"
+#~ "    <key column=\"personId\"/>\n"
+#~ "    <list-index column=\"sortOrder\"/>\n"
+#~ "    <many-to-many column=\"addressId\" class=\"Address\"/>\n"
+#~ "</array>]]>"
 #~ msgstr ""
-#~ "假若你的表没有一个索引字段,当你仍然希望使用<literal>List</literal>作为属性"
-#~ "类型,你应该把此属性映射为Hibernate <emphasis>&lt;bag&gt;</emphasis>。从数"
-#~ "据库中获取的时候,bag不维护其顺序,但也可选择性的进行排序。"
+#~ "<![CDATA[<array name=\"addresses\" \n"
+#~ "        table=\"PersonAddress\" \n"
+#~ "        cascade=\"persist\">\n"
+#~ "    <key column=\"personId\"/>\n"
+#~ "    <list-index column=\"sortOrder\"/>\n"
+#~ "    <many-to-many column=\"addressId\" class=\"Address\"/>\n"
+#~ "</array>]]>"
 
 #~ msgid ""
-#~ "<literal>class</literal> (required): The entity class used as the map key."
+#~ "<![CDATA[<map name=\"holidays\" \n"
+#~ "        table=\"holidays\" \n"
+#~ "        schema=\"dbo\" \n"
+#~ "        order-by=\"hol_name asc\">\n"
+#~ "    <key column=\"id\"/>\n"
+#~ "    <map-key column=\"hol_name\" type=\"string\"/>\n"
+#~ "    <element column=\"hol_date\" type=\"date\"/>\n"
+#~ "</map>]]>"
 #~ msgstr ""
-#~ "从集合类可以产生很大一部分映射,覆盖了很多常见的关系模型。我们建议你试验"
-#~ "schema生成工具,来体会一下不同的映射声明是如何被翻译为数据库表的。"
+#~ "<![CDATA[<map name=\"holidays\" \n"
+#~ "        table=\"holidays\" \n"
+#~ "        schema=\"dbo\" \n"
+#~ "        order-by=\"hol_name asc\">\n"
+#~ "    <key column=\"id\"/>\n"
+#~ "    <map-key column=\"hol_name\" type=\"string\"/>\n"
+#~ "    <element column=\"hol_date\" type=\"date\"/>\n"
+#~ "</map>]]>"
 
 #~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the column holding the "
-#~ "collection element values."
-#~ msgstr "<literal>type</literal> (必需):集合元素的类型"
+#~ "<![CDATA[<list name=\"carComponents\" \n"
+#~ "        table=\"CarComponents\">\n"
+#~ "    <key column=\"carId\"/>\n"
+#~ "    <list-index column=\"sortOrder\"/>\n"
+#~ "    <composite-element class=\"CarComponent\">\n"
+#~ "        <property name=\"price\"/>\n"
+#~ "        <property name=\"type\"/>\n"
+#~ "        <property name=\"serialNumber\" column=\"serialNum\"/>\n"
+#~ "    </composite-element>\n"
+#~ "</list>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<list name=\"carComponents\" \n"
+#~ "        table=\"CarComponents\">\n"
+#~ "    <key column=\"carId\"/>\n"
+#~ "    <list-index column=\"sortOrder\"/>\n"
+#~ "    <composite-element class=\"CarComponent\">\n"
+#~ "        <property name=\"price\"/>\n"
+#~ "        <property name=\"type\"/>\n"
+#~ "        <property name=\"serialNumber\" column=\"serialNum\"/>\n"
+#~ "    </composite-element>\n"
+#~ "</list>]]>"
 
 #~ msgid ""
-#~ "<literal>formula</literal> (optional): An SQL formula used to evaluate "
-#~ "the element."
+#~ "<![CDATA[<one-to-many \n"
+#~ "        class=\"ClassName\"\n"
+#~ "        not-found=\"ignore|exception\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "        embed-xml=\"true|false\"\n"
+#~ "    />]]>"
 #~ msgstr ""
-#~ "<emphasis>多对多关联(many-to-many association)</emphasis> 使用 "
-#~ "<literal>&lt;many-to-many&gt;</literal>元素定义."
+#~ "<![CDATA[<one-to-many \n"
+#~ "        class=\"ClassName\"\n"
+#~ "        not-found=\"ignore|exception\"\n"
+#~ "        entity-name=\"EntityName\"\n"
+#~ "        node=\"element-name\"\n"
+#~ "        embed-xml=\"true|false\"\n"
+#~ "    />]]>"
 
 #~ msgid ""
-#~ "<literal>type</literal> (required): The type of the collection element."
-#~ msgstr "<literal>column</literal>(可选): 这个元素的外键关键字段名"
+#~ "<![CDATA[<map name=\"parts\"\n"
+#~ "        cascade=\"all\">\n"
+#~ "    <key column=\"productId\" not-null=\"true\"/>\n"
+#~ "    <map-key formula=\"partName\"/>\n"
+#~ "    <one-to-many class=\"Part\"/>\n"
+#~ "</map>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<map name=\"parts\"\n"
+#~ "        cascade=\"all\">\n"
+#~ "    <key column=\"productId\" not-null=\"true\"/>\n"
+#~ "    <map-key formula=\"partName\"/>\n"
+#~ "    <one-to-many class=\"Part\"/>\n"
+#~ "</map>]]>"
 
 #~ msgid ""
-#~ "A <emphasis>many-to-many association</emphasis> is specified using the "
-#~ "<literal>&lt;many-to-many&gt;</literal> element."
-#~ msgstr "<literal>formula</literal> (可选): 用于计算元素外键值的SQL公式."
+#~ "<![CDATA[<set name=\"aliases\" \n"
+#~ "            table=\"person_aliases\" \n"
+#~ "            sort=\"natural\">\n"
+#~ "    <key column=\"person\"/>\n"
+#~ "    <element column=\"name\" type=\"string\"/>\n"
+#~ "</set>\n"
+#~ "\n"
+#~ "<map name=\"holidays\" sort=\"my.custom.HolidayComparator\">\n"
+#~ "    <key column=\"year_id\"/>\n"
+#~ "    <map-key column=\"hol_name\" type=\"string\"/>\n"
+#~ "    <element column=\"hol_date\" type=\"date\"/>\n"
+#~ "</map>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"aliases\" \n"
+#~ "            table=\"person_aliases\" \n"
+#~ "            sort=\"natural\">\n"
+#~ "    <key column=\"person\"/>\n"
+#~ "    <element column=\"name\" type=\"string\"/>\n"
+#~ "</set>\n"
+#~ "\n"
+#~ "<map name=\"holidays\" sort=\"my.custom.HolidayComparator\">\n"
+#~ "    <key column=\"year_id\"/>\n"
+#~ "    <map-key column=\"hol_name\" type=\"string\"/>\n"
+#~ "    <element column=\"hol_date\" type=\"date\"/>\n"
+#~ "</map>]]>"
 
 #~ msgid ""
-#~ "<literal>column</literal> (optional): The name of the element foreign key "
-#~ "column."
-#~ msgstr "<literal>class</literal> (必需): 关联类的名称"
+#~ "<![CDATA[<set name=\"aliases\" table=\"person_aliases\" order-by=\"lower"
+#~ "(name) asc\">\n"
+#~ "    <key column=\"person\"/>\n"
+#~ "    <element column=\"name\" type=\"string\"/>\n"
+#~ "</set>\n"
+#~ "\n"
+#~ "<map name=\"holidays\" order-by=\"hol_date, hol_name\">\n"
+#~ "    <key column=\"year_id\"/>\n"
+#~ "    <map-key column=\"hol_name\" type=\"string\"/>\n"
+#~ "    <element column=\"hol_date type=\"date\"/>\n"
+#~ "</map>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"aliases\" table=\"person_aliases\" order-by=\"lower"
+#~ "(name) asc\">\n"
+#~ "    <key column=\"person\"/>\n"
+#~ "    <element column=\"name\" type=\"string\"/>\n"
+#~ "</set>\n"
+#~ "\n"
+#~ "<map name=\"holidays\" order-by=\"hol_date, hol_name\">\n"
+#~ "    <key column=\"year_id\"/>\n"
+#~ "    <map-key column=\"hol_name\" type=\"string\"/>\n"
+#~ "    <element column=\"hol_date type=\"date\"/>\n"
+#~ "</map>]]>"
 
 #~ msgid ""
-#~ "<literal>formula</literal> (optional): An SQL formula used to evaluate "
-#~ "the element foreign key value."
+#~ "<![CDATA[sortedUsers = s.createFilter( group.getUsers(), \"order by this."
+#~ "name\" ).list();]]>"
 #~ msgstr ""
-#~ "<literal>outer-join</literal> (可选 - 默认为<literal>auto</literal>): 在"
-#~ "Hibernate系统参数中<literal>hibernate.use_outer_join</literal>被打开的情况"
-#~ "下,该参数用来允许使用outer join来载入此集合的数据。"
+#~ "<![CDATA[sortedUsers = s.createFilter( group.getUsers(), \"order by this."
+#~ "name\" ).list();]]>"
 
 #~ msgid ""
-#~ "<literal>fetch</literal> (optional - defaults to <literal>join</"
-#~ "literal>): enables outer-join or sequential select fetching for this "
-#~ "association. This is a special case; for full eager fetching (in a single "
-#~ "<literal>SELECT</literal>) of an entity and its many-to-many "
-#~ "relationships to other entities, you would enable <literal>join</literal> "
-#~ "fetching not only of the collection itself, but also with this attribute "
-#~ "on the <literal>&lt;many-to-many&gt;</literal> nested element."
+#~ "<![CDATA[<class name=\"Category\">\n"
+#~ "    <id name=\"id\" column=\"CATEGORY_ID\"/>\n"
+#~ "    ...\n"
+#~ "    <bag name=\"items\" table=\"CATEGORY_ITEM\">\n"
+#~ "        <key column=\"CATEGORY_ID\"/>\n"
+#~ "        <many-to-many class=\"Item\" column=\"ITEM_ID\"/>\n"
+#~ "    </bag>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Item\">\n"
+#~ "    <id name=\"id\" column=\"ITEM_ID\"/>\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    <!-- inverse end -->\n"
+#~ "    <bag name=\"categories\" table=\"CATEGORY_ITEM\" inverse=\"true\">\n"
+#~ "        <key column=\"ITEM_ID\"/>\n"
+#~ "        <many-to-many class=\"Category\" column=\"CATEGORY_ID\"/>\n"
+#~ "    </bag>\n"
+#~ "</class>]]>"
 #~ msgstr ""
-#~ "对外键字段允许DDL生成的时候生成一个惟一约束。这使关联变成了一个高效的一对"
-#~ "多关联。(此句存疑:原文为This makes the association multiplicity "
-#~ "effectively one to many.)"
+#~ "<![CDATA[<class name=\"Category\">\n"
+#~ "    <id name=\"id\" column=\"CATEGORY_ID\"/>\n"
+#~ "    ...\n"
+#~ "    <bag name=\"items\" table=\"CATEGORY_ITEM\">\n"
+#~ "        <key column=\"CATEGORY_ID\"/>\n"
+#~ "        <many-to-many class=\"Item\" column=\"ITEM_ID\"/>\n"
+#~ "    </bag>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Item\">\n"
+#~ "    <id name=\"id\" column=\"ITEM_ID\"/>\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    <!-- inverse end -->\n"
+#~ "    <bag name=\"categories\" table=\"CATEGORY_ITEM\" inverse=\"true\">\n"
+#~ "        <key column=\"ITEM_ID\"/>\n"
+#~ "        <many-to-many class=\"Category\" column=\"CATEGORY_ID\"/>\n"
+#~ "    </bag>\n"
+#~ "</class>]]>"
 
 #~ msgid ""
-#~ "<literal>unique</literal> (optional): Enable the DDL generation of a "
-#~ "unique constraint for the foreign-key column. This makes the association "
-#~ "multiplicity effectively one to many."
+#~ "<![CDATA[\n"
+#~ "category.getItems().add(item);          // The category now \"knows\" "
+#~ "about the relationship\n"
+#~ "item.getCategories().add(category);     // The item now \"knows\" about "
+#~ "the relationship\n"
+#~ "\n"
+#~ "session.persist(item);                   // The relationship won't be "
+#~ "saved!\n"
+#~ "session.persist(category);               // The relationship will be "
+#~ "saved]]>"
 #~ msgstr ""
-#~ "<literal>not-found</literal> (可选 - 默认为 <literal>exception</"
-#~ "literal>): 指明引用的外键中缺少某些行该如何处理: <literal>ignore</"
-#~ "literal> 会把缺失的行作为一个空引用处理。"
+#~ "<![CDATA[\n"
+#~ "category.getItems().add(item);          // The category now \"knows\" "
+#~ "about the relationship\n"
+#~ "item.getCategories().add(category);     // The item now \"knows\" about "
+#~ "the relationship\n"
+#~ "\n"
+#~ "session.persist(item);                   // The relationship won't be "
+#~ "saved!\n"
+#~ "session.persist(category);               // The relationship will be "
+#~ "saved]]>"
 
 #~ msgid ""
-#~ "<literal>not-found</literal> (optional - defaults to <literal>exception</"
-#~ "literal>): Specifies how foreign keys that reference missing rows will be "
-#~ "handled: <literal>ignore</literal> will treat a missing row as a null "
-#~ "association."
+#~ "<![CDATA[<class name=\"Parent\">\n"
+#~ "    <id name=\"id\" column=\"parent_id\"/>\n"
+#~ "    ....\n"
+#~ "    <set name=\"children\" inverse=\"true\">\n"
+#~ "        <key column=\"parent_id\"/>\n"
+#~ "        <one-to-many class=\"Child\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Child\">\n"
+#~ "    <id name=\"id\" column=\"child_id\"/>\n"
+#~ "    ....\n"
+#~ "    <many-to-one name=\"parent\" \n"
+#~ "        class=\"Parent\" \n"
+#~ "        column=\"parent_id\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>]]>"
 #~ msgstr ""
-#~ "<literal>entity-name</literal> (可选): 被关联的类的实体名,作为"
-#~ "<literal>class</literal>的替代。"
+#~ "<![CDATA[<class name=\"Parent\">\n"
+#~ "    <id name=\"id\" column=\"parent_id\"/>\n"
+#~ "    ....\n"
+#~ "    <set name=\"children\" inverse=\"true\">\n"
+#~ "        <key column=\"parent_id\"/>\n"
+#~ "        <one-to-many class=\"Child\"/>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Child\">\n"
+#~ "    <id name=\"id\" column=\"child_id\"/>\n"
+#~ "    ....\n"
+#~ "    <many-to-one name=\"parent\" \n"
+#~ "        class=\"Parent\" \n"
+#~ "        column=\"parent_id\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>]]>"
 
 #~ msgid ""
-#~ "<literal>property-ref</literal>: (optional) The name of a property of the "
-#~ "associated class that is joined to this foreign key. If not specified, "
-#~ "the primary key of the associated class is used."
-#~ msgstr "例子:首先, 一组字符串:"
+#~ "<![CDATA[<class name=\"Parent\">\n"
+#~ "    <id name=\"id\" column=\"parent_id\"/>\n"
+#~ "    ....\n"
+#~ "    <map name=\"children\" inverse=\"true\">\n"
+#~ "        <key column=\"parent_id\"/>\n"
+#~ "        <map-key column=\"name\" \n"
+#~ "            type=\"string\"/>\n"
+#~ "        <one-to-many class=\"Child\"/>\n"
+#~ "    </map>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Child\">\n"
+#~ "    <id name=\"id\" column=\"child_id\"/>\n"
+#~ "    ....\n"
+#~ "    <property name=\"name\" \n"
+#~ "        not-null=\"true\"/>\n"
+#~ "    <many-to-one name=\"parent\" \n"
+#~ "        class=\"Parent\" \n"
+#~ "        column=\"parent_id\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Parent\">\n"
+#~ "    <id name=\"id\" column=\"parent_id\"/>\n"
+#~ "    ....\n"
+#~ "    <map name=\"children\" inverse=\"true\">\n"
+#~ "        <key column=\"parent_id\"/>\n"
+#~ "        <map-key column=\"name\" \n"
+#~ "            type=\"string\"/>\n"
+#~ "        <one-to-many class=\"Child\"/>\n"
+#~ "    </map>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Child\">\n"
+#~ "    <id name=\"id\" column=\"child_id\"/>\n"
+#~ "    ....\n"
+#~ "    <property name=\"name\" \n"
+#~ "        not-null=\"true\"/>\n"
+#~ "    <many-to-one name=\"parent\" \n"
+#~ "        class=\"Parent\" \n"
+#~ "        column=\"parent_id\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Parent\">\n"
+#~ "    <id name=\"id\" column=\"parent_id\"/>\n"
+#~ "    ....\n"
+#~ "    <map name=\"children\">\n"
+#~ "        <key column=\"parent_id\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        <map-key column=\"name\" \n"
+#~ "            type=\"string\"/>\n"
+#~ "        <one-to-many class=\"Child\"/>\n"
+#~ "    </map>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Child\">\n"
+#~ "    <id name=\"id\" column=\"child_id\"/>\n"
+#~ "    ....\n"
+#~ "    <many-to-one name=\"parent\" \n"
+#~ "        class=\"Parent\" \n"
+#~ "        column=\"parent_id\"\n"
+#~ "        insert=\"false\"\n"
+#~ "        update=\"false\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Parent\">\n"
+#~ "    <id name=\"id\" column=\"parent_id\"/>\n"
+#~ "    ....\n"
+#~ "    <map name=\"children\">\n"
+#~ "        <key column=\"parent_id\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        <map-key column=\"name\" \n"
+#~ "            type=\"string\"/>\n"
+#~ "        <one-to-many class=\"Child\"/>\n"
+#~ "    </map>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Child\">\n"
+#~ "    <id name=\"id\" column=\"child_id\"/>\n"
+#~ "    ....\n"
+#~ "    <many-to-one name=\"parent\" \n"
+#~ "        class=\"Parent\" \n"
+#~ "        column=\"parent_id\"\n"
+#~ "        insert=\"false\"\n"
+#~ "        update=\"false\"\n"
+#~ "        not-null=\"true\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<map name=\"contracts\">\n"
+#~ "    <key column=\"employer_id\" not-null=\"true\"/>\n"
+#~ "    <map-key-many-to-many column=\"employee_id\" class=\"Employee\"/>\n"
+#~ "    <one-to-many class=\"Contract\"/>\n"
+#~ "</map>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<map name=\"contracts\">\n"
+#~ "    <key column=\"employer_id\" not-null=\"true\"/>\n"
+#~ "    <map-key-many-to-many column=\"employee_id\" class=\"Employee\"/>\n"
+#~ "    <one-to-many class=\"Contract\"/>\n"
+#~ "</map>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<map name=\"connections\">\n"
+#~ "    <key column=\"incoming_node_id\"/>\n"
+#~ "    <map-key-many-to-many column=\"outgoing_node_id\" class=\"Node\"/>\n"
+#~ "    <many-to-many column=\"connection_id\" class=\"Connection\"/>\n"
+#~ "</map>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<map name=\"connections\">\n"
+#~ "    <key column=\"incoming_node_id\"/>\n"
+#~ "    <map-key-many-to-many column=\"outgoing_node_id\" class=\"Node\"/>\n"
+#~ "    <many-to-many column=\"connection_id\" class=\"Connection\"/>\n"
+#~ "</map>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<idbag name=\"lovers\" table=\"LOVERS\">\n"
+#~ "    <collection-id column=\"ID\" type=\"long\">\n"
+#~ "        <generator class=\"sequence\"/>\n"
+#~ "    </collection-id>\n"
+#~ "    <key column=\"PERSON1\"/>\n"
+#~ "    <many-to-many column=\"PERSON2\" class=\"Person\" fetch=\"join\"/>\n"
+#~ "</idbag>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<idbag name=\"lovers\" table=\"LOVERS\">\n"
+#~ "    <collection-id column=\"ID\" type=\"long\">\n"
+#~ "        <generator class=\"sequence\"/>\n"
+#~ "    </collection-id>\n"
+#~ "    <key column=\"PERSON1\"/>\n"
+#~ "    <many-to-many column=\"PERSON2\" class=\"Person\" fetch=\"join\"/>\n"
+#~ "</idbag>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "import java.util.Set;\n"
+#~ "\n"
+#~ "public class Parent {\n"
+#~ "    private long id;\n"
+#~ "    private Set children;\n"
+#~ "\n"
+#~ "    public long getId() { return id; }\n"
+#~ "    private void setId(long id) { this.id=id; }\n"
+#~ "\n"
+#~ "    private Set getChildren() { return children; }\n"
+#~ "    private void setChildren(Set children) { this.children=children; }\n"
+#~ "\n"
+#~ "    ....\n"
+#~ "    ....\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package eg;\n"
+#~ "import java.util.Set;\n"
+#~ "\n"
+#~ "public class Parent {\n"
+#~ "    private long id;\n"
+#~ "    private Set children;\n"
+#~ "\n"
+#~ "    public long getId() { return id; }\n"
+#~ "    private void setId(long id) { this.id=id; }\n"
+#~ "\n"
+#~ "    private Set getChildren() { return children; }\n"
+#~ "    private void setChildren(Set children) { this.children=children; }\n"
+#~ "\n"
+#~ "    ....\n"
+#~ "    ....\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Parent\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <set name=\"children\">\n"
+#~ "            <key column=\"parent_id\"/>\n"
+#~ "            <one-to-many class=\"Child\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Child\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Parent\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <set name=\"children\">\n"
+#~ "            <key column=\"parent_id\"/>\n"
+#~ "            <one-to-many class=\"Child\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Child\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[create table parent ( id bigint not null primary key )\n"
+#~ "create table child ( id bigint not null primary key, name varchar(255), "
+#~ "parent_id bigint )\n"
+#~ "alter table child add constraint childfk0 (parent_id) references parent]]>"
+#~ msgstr ""
+#~ "<![CDATA[create table parent ( id bigint not null primary key )\n"
+#~ "create table child ( id bigint not null primary key, name varchar(255), "
+#~ "parent_id bigint )\n"
+#~ "alter table child add constraint childfk0 (parent_id) references parent]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Parent\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <set name=\"children\" inverse=\"true\">\n"
+#~ "            <key column=\"parent_id\"/>\n"
+#~ "            <one-to-many class=\"Child\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Child\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "        <many-to-one name=\"parent\" class=\"Parent\" column=\"parent_id"
+#~ "\" not-null=\"true\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Parent\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <set name=\"children\" inverse=\"true\">\n"
+#~ "            <key column=\"parent_id\"/>\n"
+#~ "            <one-to-many class=\"Child\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Child\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "        <many-to-one name=\"parent\" class=\"Parent\" column=\"parent_id"
+#~ "\" not-null=\"true\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[create table parent ( id bigint not null primary key )\n"
+#~ "create table child ( id bigint not null\n"
+#~ "                     primary key,\n"
+#~ "                     name varchar(255),\n"
+#~ "                     parent_id bigint not null )\n"
+#~ "alter table child add constraint childfk0 (parent_id) references parent]]>"
+#~ msgstr ""
+#~ "<![CDATA[create table parent ( id bigint not null primary key )\n"
+#~ "create table child ( id bigint not null\n"
+#~ "                     primary key,\n"
+#~ "                     name varchar(255),\n"
+#~ "                     parent_id bigint not null )\n"
+#~ "alter table child add constraint childfk0 (parent_id) references parent]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Parent\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <set name=\"children\">\n"
+#~ "            <key column=\"parent_id\" not-null=\"true\"/>\n"
+#~ "            <one-to-many class=\"Child\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Child\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Parent\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <set name=\"children\">\n"
+#~ "            <key column=\"parent_id\" not-null=\"true\"/>\n"
+#~ "            <one-to-many class=\"Child\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Child\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Parent\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <set name=\"children\" table=\"childset\">\n"
+#~ "            <key column=\"parent_id\"/>\n"
+#~ "            <many-to-many class=\"Child\" column=\"child_id\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Child\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Parent\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <set name=\"children\" table=\"childset\">\n"
+#~ "            <key column=\"parent_id\"/>\n"
+#~ "            <many-to-many class=\"Child\" column=\"child_id\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Child\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[create table parent ( id bigint not null primary key )\n"
+#~ "create table child ( id bigint not null primary key, name varchar(255) )\n"
+#~ "create table childset ( parent_id bigint not null,\n"
+#~ "                        child_id bigint not null,\n"
+#~ "                        primary key ( parent_id, child_id ) )\n"
+#~ "alter table childset add constraint childsetfk0 (parent_id) references "
+#~ "parent\n"
+#~ "alter table childset add constraint childsetfk1 (child_id) references "
+#~ "child]]>"
+#~ msgstr ""
+#~ "<![CDATA[create table parent ( id bigint not null primary key )\n"
+#~ "create table child ( id bigint not null primary key, name varchar(255) )\n"
+#~ "create table childset ( parent_id bigint not null,\n"
+#~ "                        child_id bigint not null,\n"
+#~ "                        primary key ( parent_id, child_id ) )\n"
+#~ "alter table childset add constraint childsetfk0 (parent_id) references "
+#~ "parent\n"
+#~ "alter table childset add constraint childsetfk1 (child_id) references "
+#~ "child]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/component_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/component_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/component_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,163 +1,82 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-11 10:36+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: component_mapping.xml:29
 #, no-c-format
 msgid "Component Mapping"
 msgstr "组件(Component)映射"
 
 #. Tag: para
-#: component_mapping.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The notion of a <emphasis>component</emphasis> is re-used in several "
 "different contexts and purposes throughout Hibernate."
 msgstr ""
-"<emphasis>组件</emphasis>(Component)这个概念在Hibernate中几处不同的地方为了不"
-"同的目的被重复使用."
+"<emphasis>组件(Component)</emphasis>这个概念在 Hibernate 中几处不同的地方为"
+"了不同的目的被重复使用。"
 
 #. Tag: title
-#: component_mapping.xml:37
 #, no-c-format
 msgid "Dependent objects"
 msgstr "依赖对象(Dependent objects)"
 
 #. Tag: para
-#: component_mapping.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A component is a contained object that is persisted as a value type and not "
 "an entity reference. The term \"component\" refers to the object-oriented "
 "notion of composition and not to architecture-level components. For example, "
 "you can model a person like this:"
 msgstr ""
-"组件(Component)是一个被包含的对象,在持久化的过程中,它被当作值类型,而并非一"
-"个实体的引用。在这篇文档中,组件这一术语指的是面向对象的合成概念(而并不是系"
-"统构架层次上的组件的概念)。举个例子, 你对人(Person)这个概念可以像下面这样来"
-"建模:"
+"组件(Component)是一个被包含的对象,在持久化的过程中,它被当作值类型,而并非"
+"一个实体的引用。在这篇文档中,组件这一术语指的是面向对象的合成概念(而并不是"
+"系统构架层次上的组件的概念)。举个例子,你对人(Person)这个概念可以像下面这"
+"样来建模: "
 
-#. Tag: programlisting
-#: component_mapping.xml:45
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[public class Person {\n"
-"    private java.util.Date birthday;\n"
-"    private Name name;\n"
-"    private String key;\n"
-"    public String getKey() {\n"
-"        return key;\n"
-"    }\n"
-"    private void setKey(String key) {\n"
-"        this.key=key;\n"
-"    }\n"
-"    public java.util.Date getBirthday() {\n"
-"        return birthday;\n"
-"    }\n"
-"    public void setBirthday(java.util.Date birthday) {\n"
-"        this.birthday = birthday;\n"
-"    }\n"
-"    public Name getName() {\n"
-"        return name;\n"
-"    }\n"
-"    public void setName(Name name) {\n"
-"        this.name = name;\n"
-"    }\n"
-"    ......\n"
-"    ......\n"
-"}]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: component_mapping.xml:47
-#, no-c-format
-msgid ""
-"<![CDATA[public class Name {\n"
-"    char initial;\n"
-"    String first;\n"
-"    String last;\n"
-"    public String getFirst() {\n"
-"        return first;\n"
-"    }\n"
-"    void setFirst(String first) {\n"
-"        this.first = first;\n"
-"    }\n"
-"    public String getLast() {\n"
-"        return last;\n"
-"    }\n"
-"    void setLast(String last) {\n"
-"        this.last = last;\n"
-"    }\n"
-"    public char getInitial() {\n"
-"        return initial;\n"
-"    }\n"
-"    void setInitial(char initial) {\n"
-"        this.initial = initial;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:49
-#, fuzzy, no-c-format
-msgid ""
 "Now <literal>Name</literal> can be persisted as a component of "
 "<literal>Person</literal>. <literal>Name</literal> defines getter and setter "
 "methods for its persistent properties, but it does not need to declare any "
 "interfaces or identifier properties."
 msgstr ""
-"在持久化的过程中,<literal>姓名(Name)</literal>可以作为<literal>人(Person)</"
-"literal>的一个组件。需要注意的是:你应该为<literal>姓名</literal>的持久化属性"
-"定义getter和setter方法,但是你不需要实现任何的接口或申明标识符字段。"
+"在持久化的过程中,<literal>姓名(Name)</literal>可以作为<literal>人"
+"(Person)</literal>的一个组件。需要注意的是:你应该为<literal>姓名</literal>"
+"的持久化属性定义 getter 和 setter 方法,但是你不需要实现任何的接口或申明标识"
+"符字段。  "
 
 #. Tag: para
-#: component_mapping.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Our Hibernate mapping would look like this:"
-msgstr "以下是这个例子的Hibernate映射文件:"
+msgstr "以下是这个例子的 Hibernate 映射文件: "
 
-#. Tag: programlisting
-#: component_mapping.xml:60
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-"    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    <property name=\"birthday\" type=\"date\"/>\n"
-"    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
-"optional -->\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </component>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:62
 #, no-c-format
 msgid ""
 "The person table would have the columns <literal>pid</literal>, "
 "<literal>birthday</literal>, <literal>initial</literal>, <literal>first</"
 "literal> and <literal>last</literal>."
 msgstr ""
-"人员(Person)表中将包括<literal>pid</literal>, <literal>birthday</literal>, "
-"<literal>initial</literal>, <literal>first</literal>和 <literal>last</"
-"literal>等字段。"
+"人员(Person)表中将包括 <literal>pid</literal>,<literal>birthday</"
+"literal>,<literal>initial</literal>,<literal>first</literal>和 "
+"<literal>last</literal> 等字段。"
 
 #. Tag: para
-#: component_mapping.xml:70
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Like value types, components do not support shared references. In other "
 "words, two persons could have the same name, but the two person objects "
@@ -167,64 +86,41 @@
 "if all component columns are null, then the entire component is null. This "
 "is suitable for most purposes."
 msgstr ""
-"就像所有的值类型一样, 组件不支持共享引用。 换句话说,两个人可能重名,但是两个"
-"Person对象应该包含两个独立的Name对象,只不过这两个Name对象具有“同样”的值。 组"
-"件的值可以为空,其定义如下。 每当Hibernate重新加载一个包含组件的对象,如果该组"
-"件的所有字段为空,Hibernate将假定整个组件为空。 在大多数情况下,这样假定应该是"
-"没有问题的。"
+"就像所有的值类型一样,组件不支持共享引用。换句话说,两个人可能重名,但是两个 "
+"Person 对象应该包含两个独立的 Name 对象,只不过这两个 Name 对象具有“同样”的"
+"值。组件的值可以为空,其定义如下。 每当 Hibernate 重新加载一个包含组件的对"
+"象,如果该组件的所有字段为空,Hibernate 将假定整个组件为空。在大多数情况下,"
+"这样假定应该是没有问题的。"
 
 #. Tag: para
-#: component_mapping.xml:78
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The properties of a component can be of any Hibernate type (collections, "
 "many-to-one associations, other components, etc). Nested components should "
 "<emphasis>not</emphasis> be considered an exotic usage. Hibernate is "
 "intended to support a fine-grained object model."
 msgstr ""
-"组件的属性可以是任意一种Hibernate类型(包括集合, 多对多关联, 以及其它组件等"
-"等)。嵌套组件不应该被当作一种特殊的应用(Nested components should not be "
-"considered an exotic usage)。 Hibernate倾向于支持细致的(fine-grained)对象模"
-"型。"
+"组件的属性可以是任意一种 Hibernate 类型(包括集合,多对多关联,以及其它组件等"
+"等)。嵌套组件不应该被当作一种特殊的应用(Nested components should not be "
+"considered an exotic usage)。Hibernate 倾向于支持细颗粒度的(fine-grained)"
+"对象模型。"
 
 #. Tag: para
-#: component_mapping.xml:85
 #, no-c-format
 msgid ""
 "The <literal>&lt;component&gt;</literal> element allows a <literal>&lt;"
 "parent&gt;</literal> subelement that maps a property of the component class "
 "as a reference back to the containing entity."
 msgstr ""
-"<literal>&lt;component&gt;</literal> 元素还允许有 <literal>&lt;parent&gt;</"
-"literal>子元素,用来表明component类中的一个属性是指向包含它的实体的引用。"
+"<literal>&lt;component&gt;</literal> 元素允许加入一个 <literal>&lt;parent&gt;"
+"</literal> 子元素,在组件类内部就可以有一个指向其容器的实体的反向引用。"
 
-#. Tag: programlisting
-#: component_mapping.xml:91
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
-"    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    <property name=\"birthday\" type=\"date\"/>\n"
-"    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
-"        <parent name=\"namedPerson\"/> <!-- reference back to the Person --"
-">\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </component>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: component_mapping.xml:96
 #, no-c-format
 msgid "Collections of dependent objects"
-msgstr "在集合中出现的依赖对象 (Collections of dependent objects)"
+msgstr "在集合中出现的依赖对象(Collections of dependent objects)"
 
 #. Tag: para
-#: component_mapping.xml:98
 #, fuzzy, no-c-format
 msgid ""
 "Collections of components are supported (e.g. an array of type "
@@ -232,38 +128,22 @@
 "<literal>&lt;element&gt;</literal> tag with a <literal>&lt;composite-"
 "element&gt;</literal> tag:"
 msgstr ""
-"Hibernate支持组件的集合(例如: 一个元素是姓名(Name)这种类型的数组)。 你可以使"
-"用<literal>&lt;composite-element&gt;</literal>标签替代<literal>&lt;"
-"element&gt;</literal>标签来定义你的组件集合。"
+"Hibernate 支持组件的集合(例如:一个元素是姓名(Name)这种类型的数组)。你可"
+"以使用 <literal>&lt;composite-element&gt;</literal> 标签替代 <literal>&lt;"
+"element&gt;</literal> 标签来定义你的组件集合。"
 
-#. Tag: programlisting
-#: component_mapping.xml:105
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
-"    <key column=\"id\"/>\n"
-"    <composite-element class=\"eg.Name\"> <!-- class attribute required -->\n"
-"        <property name=\"initial\"/>\n"
-"        <property name=\"first\"/>\n"
-"        <property name=\"last\"/>\n"
-"    </composite-element>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:108
-#, fuzzy, no-c-format
-msgid ""
 "If you define a <literal>Set</literal> of composite elements, it is "
 "important to implement <literal>equals()</literal> and <literal>hashCode()</"
 "literal> correctly."
 msgstr ""
-"注意,如果你定义的Set包含组合元素(composite-element),正确地实现"
-"<literal>equals()</literal>和<literal>hashCode()</literal>是非常重要的。"
+"注意,如果你定义的 Set 包含组合元素(composite-element),正确地实现 "
+"<literal>equals()</literal> 和 <literal>hashCode()</literal> 是非常重要的。 "
 
 #. Tag: para
-#: component_mapping.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Composite elements can contain components but not collections. If your "
 "composite element contains components, use the <literal>&lt;nested-composite-"
@@ -273,16 +153,15 @@
 "but be aware that even though the Java model is the same, the relational "
 "model and persistence semantics are still slightly different."
 msgstr ""
-"组合元素可以包含组件,但是不能包含集合。如果你的组合元素自身包含组件, 你必须"
-"使用<literal>&lt;nested-composite-element&gt;</literal>标签。这是一个相当特殊"
-"的案例 - 在一个组件的集合里,那些组件本身又可以包含其他的组件。这个时候你就应"
-"该考虑一下使用one-to-many关联是否会更恰当。 尝试对这个组合元素重新建模为一个"
-"实体-但是需要注意的是,虽然Java模型和重新建模前是一样的,关系模型和持久性语"
-"义会有细微的变化。"
+"组合元素可以包含组件,但是不能包含集合。如果你的组合元素自身包含组件,你必须"
+"使用 <literal>&lt;nested-composite-element&gt;</literal> 标签。这是一个相当特"
+"殊的案例 — 在一个组件的集合里,那些组件本身又可以包含其他的组件。这个时候你就"
+"应该考虑一下使用 one-to-many 关联是否会更恰当。尝试对这个组合元素重新建模为一"
+"个实体 — 但是需要注意的是,虽然 Java 模型和重新建模前是一样的,关系模型和持久"
+"性语义会有细微的变化。 "
 
 #. Tag: para
-#: component_mapping.xml:127
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A composite element mapping does not support null-able properties if you are "
 "using a <literal>&lt;set&gt;</literal>. There is no separate primary key "
@@ -292,17 +171,16 @@
 "element or choose a <literal>&lt;list&gt;</literal>, <literal>&lt;map&gt;</"
 "literal>, <literal>&lt;bag&gt;</literal> or <literal>&lt;idbag&gt;</literal>."
 msgstr ""
-"请注意如果你使用<literal>&lt;set&gt;</literal>标签,一个组合元素的映射不支持可"
-"能为空的属性. 当删除对象时, Hibernate必须使用每一个字段的值来确定一条记录(在"
-"组合元素表中,没有单独的关键字段), 如果有为null的字段,这样做就不可能了。你"
-"必须作出一个选择,要么在组合元素中使用不能为空的属性,要么选择使用"
-"<literal>&lt;list&gt;</literal>,<literal>&lt;map&gt;</literal>,<literal>&lt;"
-"bag&gt;</literal> 或者 <literal>&lt;idbag&gt;</literal>而不是 <literal>&lt;"
-"set&gt;</literal>。"
+"请注意如果你使用 <literal>&lt;set&gt;</literal> 标签,一个组合元素的映射不支"
+"持可能为空的属性. 当删除对象时,Hibernate 必须使用每一个字段的值来确定一条记"
+"录(在组合元素表中,没有单独的关键字段),如果有为 null 的字段,这样做就不可"
+"能了。你必须作出一个选择,要么在组合元素中使用不能为空的属性,要么选择使用 "
+"<literal>&lt;list&gt;</literal>,<literal>&lt;map&gt;</literal>,"
+"<literal>&lt;bag&gt;</literal> 或者 <literal>&lt;idbag&gt;</literal> 而不是 "
+"<literal>&lt;set&gt;</literal>。 "
 
 #. Tag: para
-#: component_mapping.xml:138
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A special case of a composite element is a composite element with a nested "
 "<literal>&lt;many-to-one&gt;</literal> element. This mapping allows you to "
@@ -313,155 +191,106 @@
 "<literal>quantity</literal> are properties of the association:"
 msgstr ""
 "组合元素有个特别的用法是它可以包含一个<literal>&lt;many-to-one&gt;</literal>"
-"元素。类似这样的映射允许你将一个many-to-many关联表映射为组合元素的集合。(A "
-"mapping like this allows you to map extra columns of a many-to-many "
-"association table to the composite element class.) 接下来的的例子是从"
-"<literal>Order</literal>到<literal>Item</literal>的一个多对多的关联关系, 关联"
-"属性是 <literal>purchaseDate</literal>, <literal>price</literal> 和 "
-"<literal>quantity</literal> 。"
+"元素。类似这样的映射允许你将一个 many-to-many 关联表的额外字段映射为组合元素"
+"类。接下来的的例子是从 <literal>Order</literal> 到 <literal>Item</literal> 的"
+"一个多对多的关联关系,关联属性是 <literal>purchaseDate</literal>,"
+"<literal>price</literal> 和 <literal>quantity</literal> 。 "
 
-#. Tag: programlisting
-#: component_mapping.xml:148
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"eg.Order\" .... >\n"
-"    ....\n"
-"    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-"        <key column=\"order_id\">\n"
-"        <composite-element class=\"eg.Purchase\">\n"
-"            <property name=\"purchaseDate\"/>\n"
-"            <property name=\"price\"/>\n"
-"            <property name=\"quantity\"/>\n"
-"            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class "
-"attribute is optional -->\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:150
-#, fuzzy, no-c-format
-msgid ""
 "There cannot be a reference to the purchase on the other side for "
 "bidirectional association navigation. Components are value types and do not "
 "allow shared references. A single <literal>Purchase</literal> can be in the "
 "set of an <literal>Order</literal>, but it cannot be referenced by the "
 "<literal>Item</literal> at the same time."
 msgstr ""
-"当然,当你定义Item时,你无法引用这些purchase,因此你无法实现双向关联查询。记"
-"住组件是值类型,并且不允许共享引用。某一个特定的<literal>Purchase</literal> "
-"可以放在<literal>Order</literal>的集合中,但它不能同时被<literal>Item</"
-"literal>所引用。"
+"当然,当你定义 Item 时,你无法引用这些 purchase,因此你无法实现双向关联查询。"
+"记住组件是值类型,并且不允许共享引用。某一个特定的 <literal>Purchase</"
+"literal> 可以放在 <literal>Order</literal> 的集合中,但它不能同时被 "
+"<literal>Item</literal> 所引用。 "
 
 #. Tag: para
-#: component_mapping.xml:158
 #, no-c-format
 msgid "Even ternary (or quaternary, etc) associations are possible:"
 msgstr "其实组合元素的这个用法可以扩展到三重或多重关联:"
 
-#. Tag: programlisting
-#: component_mapping.xml:160
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"eg.Order\" .... >\n"
-"    ....\n"
-"    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
-"        <key column=\"order_id\">\n"
-"        <composite-element class=\"eg.OrderLine\">\n"
-"            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
-"            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:162
-#, fuzzy, no-c-format
-msgid ""
 "Composite elements can appear in queries using the same syntax as "
 "associations to other entities."
-msgstr "在查询中,表达组合元素的语法和关联到其他实体的语法是一样的。"
+msgstr "在查询中,表达组合元素的语法和关联到其他实体的语法是一样的。 "
 
 #. Tag: title
-#: component_mapping.xml:170
 #, no-c-format
 msgid "Components as Map indices"
-msgstr "组件作为Map的索引(Components as Map indices )"
+msgstr "组件作为 Map 的索引(Components as Map indices )"
 
 #. Tag: para
-#: component_mapping.xml:172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>&lt;composite-map-key&gt;</literal> element allows you to map a "
 "component class as the key of a <literal>Map</literal>. Ensure that you "
 "override <literal>hashCode()</literal> and <literal>equals()</literal> "
 "correctly on the component class."
 msgstr ""
-"<literal>&lt;composite-map-key&gt;</literal>元素允许你映射一个组件类作为一个"
-"<literal>Map</literal>的key,前提是你必须正确的在这个类中重写了"
-"<literal>hashCode()</literal> 和 <literal>equals()</literal>方法。"
+"<literal>&lt;composite-map-key&gt;</literal> 元素允许你映射一个组件类作为一"
+"个 <literal>Map</literal> 的 key,前提是你必须正确的在这个类中重写了 "
+"<literal>hashCode()</literal> 和 <literal>equals()</literal> 方法。 "
 
 #. Tag: title
-#: component_mapping.xml:181
 #, no-c-format
 msgid "Components as composite identifiers"
-msgstr "组件作为联合标识符(Components as composite identifiers)"
+msgstr "组件作为联合标识符(Components as composite identifiers)"
 
 #. Tag: para
-#: component_mapping.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can use a component as an identifier of an entity class. Your component "
 "class must satisfy certain requirements:"
 msgstr ""
-"你可以使用一个组件作为一个实体类的标识符。 你的组件类必须满足以下要求:"
+"你可以使用一个组件作为一个实体类的标识符。你的组件类必须满足以下要求: "
 
 #. Tag: para
-#: component_mapping.xml:190
 #, no-c-format
 msgid "It must implement <literal>java.io.Serializable</literal>."
-msgstr "它必须实现<literal>java.io.Serializable</literal>接口"
+msgstr "它必须实现 <literal>java.io.Serializable</literal> 接口"
 
 #. Tag: para
-#: component_mapping.xml:195
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It must re-implement <literal>equals()</literal> and <literal>hashCode()</"
 "literal> consistently with the database's notion of composite key equality."
 msgstr ""
-"它必须重新实现<literal>equals()</literal>和<literal>hashCode()</literal>方"
-"法, 始终和组合关键字在数据库中的概念保持一致"
+"它必须重新实现 <literal>equals()</literal> 和 <literal>hashCode()</literal> "
+"方法,始终和组合关键字在数据库中的概念保持一致 "
 
 #. Tag: title
-#: component_mapping.xml:204
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "注意"
 
 #. Tag: para
-#: component_mapping.xml:205
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In Hibernate3, although the second requirement is not an absolutely hard "
 "requirement of Hibernate, it is recommended."
 msgstr ""
-"注意:在Hibernate3中,第二个要求并非是Hibernate强制必须的。但最好这样做。"
+"注意:在 Hibernate3 中,第二个要求并非是 Hibernate 强制必须的。但最好这样"
+"做。 "
 
 #. Tag: para
-#: component_mapping.xml:211
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You cannot use an <literal>IdentifierGenerator</literal> to generate "
 "composite keys. Instead the application must assign its own identifiers."
 msgstr ""
-"你不能使用一个<literal>IdentifierGenerator</literal>产生组合关键字。一个应用"
-"程序必须分配它自己的标识符。"
+"你不能使用一个 <literal>IdentifierGenerator</literal> 产生组合关键字。一个应"
+"用程序必须分配它自己的标识符。 "
 
 #. Tag: para
-#: component_mapping.xml:216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use the <literal>&lt;composite-id&gt;</literal> tag, with nested "
 "<literal>&lt;key-property&gt;</literal> elements, in place of the usual "
@@ -469,177 +298,76 @@
 "<literal>OrderLine</literal> class has a primary key that depends upon the "
 "(composite) primary key of <literal>Order</literal>."
 msgstr ""
-"使用<literal>&lt;composite-id&gt;</literal> 标签(并且内嵌<literal>&lt;key-"
-"property&gt;</literal>元素)代替通常的<literal>&lt;id&gt;</literal>标签。比如,"
-"<literal>OrderLine</literal>类具有一个主键,这个主键依赖于<literal>Order</"
-"literal>的(联合)主键。"
+"使用 <literal>&lt;composite-id&gt;</literal> 标签(并且内嵌 <literal>&lt;key-"
+"property&gt;</literal> 元素)代替通常的 <literal>&lt;id&gt;</literal> 标签。"
+"比如,<literal>OrderLine</literal> 类具有一个主键,这个主键依赖于 "
+"<literal>Order</literal> 的(联合)主键。 "
 
-#. Tag: programlisting
-#: component_mapping.xml:224
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"OrderLine\">\n"
-"\n"
-"    <composite-id name=\"id\" class=\"OrderLineId\">\n"
-"        <key-property name=\"lineId\"/>\n"
-"        <key-property name=\"orderId\"/>\n"
-"        <key-property name=\"customerId\"/>\n"
-"    </composite-id>\n"
-"\n"
-"    <property name=\"name\"/>\n"
-"\n"
-"    <many-to-one name=\"order\" class=\"Order\"\n"
-"            insert=\"false\" update=\"false\">\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </many-to-one>\n"
-"    ....\n"
-"\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:226
-#, fuzzy, no-c-format
-msgid ""
 "Any foreign keys referencing the <literal>OrderLine</literal> table are now "
 "composite. Declare this in your mappings for other classes. An association "
 "to <literal>OrderLine</literal> is mapped like this:"
 msgstr ""
-"现在,任何指向<literal>OrderLine</literal>的外键都是复合的。在你的映射文件"
-"中,必须为其他类也这样声明。例如,一个指向<literal>OrderLine</literal>的关联"
-"可能被这样映射:"
+"现在,任何指向 <literal>OrderLine</literal> 的外键都是复合的。在你的映射文件"
+"中,必须为其他类也这样声明。例如,一个指向 <literal>OrderLine</literal> 的关"
+"联可能被这样映射: "
 
-#. Tag: programlisting
-#: component_mapping.xml:232
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
-"<!-- the \"class\" attribute is optional, as usual -->\n"
-"    <column name=\"lineId\"/>\n"
-"    <column name=\"orderId\"/>\n"
-"    <column name=\"customerId\"/>\n"
-"</many-to-one>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:235
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The <literal>column</literal> element is an alternative to the "
 "<literal>column</literal> attribute everywhere. Using the <literal>column</"
 "literal> element just gives more declaration options, which are mostly "
 "useful when utilizing <literal>hbm2ddl</literal>"
 msgstr ""
+"(注意在各个地方 <literal>&lt;column&gt;</literal> 标签都是 <literal>column</"
+"literal> 属性的替代写法。) "
 
 #. Tag: para
-#: component_mapping.xml:244
 #, no-c-format
 msgid ""
 "A <literal>many-to-many</literal> association to <literal>OrderLine</"
 "literal> also uses the composite foreign key:"
 msgstr ""
-"指向<literal>OrderLine</literal>的<literal>多对多</literal>关联也使用联合外"
-"é”®:"
+"指向 <literal>OrderLine</literal> 的<literal>多对多</literal>关联也使用联合外"
+"键:"
 
-#. Tag: programlisting
-#: component_mapping.xml:249
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"undeliveredOrderLines\">\n"
-"    <key column name=\"warehouseId\"/>\n"
-"    <many-to-many class=\"OrderLine\">\n"
-"        <column name=\"lineId\"/>\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </many-to-many>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: component_mapping.xml:251
 #, no-c-format
 msgid ""
 "The collection of <literal>OrderLine</literal>s in <literal>Order</literal> "
 "would use:"
 msgstr ""
-"在<literal>Order</literal>中,<literal>OrderLine</literal>的集合则是这样:"
+"在 <literal>Order</literal> 中,<literal>OrderLine</literal> 的集合则是这"
+"样: "
 
-#. Tag: programlisting
-#: component_mapping.xml:256
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
-"    <key>\n"
-"        <column name=\"orderId\"/>\n"
-"        <column name=\"customerId\"/>\n"
-"    </key>\n"
-"    <one-to-many class=\"OrderLine\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:258
-#, fuzzy, no-c-format
 msgid "The <literal>&lt;one-to-many&gt;</literal> element declares no columns."
-msgstr "(与通常一样,<literal>&lt;one-to-many&gt;</literal>元素不声明任何列.)"
+msgstr "与通常一样,<literal>&lt;one-to-many&gt;</literal> 元素不声明任何列。"
 
 #. Tag: para
-#: component_mapping.xml:262
 #, no-c-format
 msgid ""
 "If <literal>OrderLine</literal> itself owns a collection, it also has a "
 "composite foreign key."
-msgstr "假若<literal>OrderLine</literal>本身拥有一个集合,它也具有组合外键。"
+msgstr "假若 <literal>OrderLine</literal> 本身拥有一个集合,它也具有组合外键。"
 
-#. Tag: programlisting
-#: component_mapping.xml:267
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"OrderLine\">\n"
-"    ....\n"
-"    ....\n"
-"    <list name=\"deliveryAttempts\">\n"
-"        <key>   <!-- a collection inherits the composite key type -->\n"
-"            <column name=\"lineId\"/>\n"
-"            <column name=\"orderId\"/>\n"
-"            <column name=\"customerId\"/>\n"
-"        </key>\n"
-"        <list-index column=\"attemptId\" base=\"1\"/>\n"
-"        <composite-element class=\"DeliveryAttempt\">\n"
-"            ...\n"
-"        </composite-element>\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: component_mapping.xml:272
 #, no-c-format
 msgid "Dynamic components"
-msgstr "动态组件 (Dynamic components)"
+msgstr "动态组件(Dynamic components)"
 
 #. Tag: para
-#: component_mapping.xml:274
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can also map a property of type <literal>Map</literal>:"
-msgstr "你甚至可以映射<literal>Map</literal>类型的属性:"
+msgstr "你甚至可以映射 <literal>Map</literal> 类型的属性: "
 
-#. Tag: programlisting
-#: component_mapping.xml:278
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<dynamic-component name=\"userAttributes\">\n"
-"    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
-"    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
-"    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
-"</dynamic-component>]]>"
-msgstr ""
-
-#. Tag: para
-#: component_mapping.xml:280
-#, fuzzy, no-c-format
-msgid ""
 "The semantics of a <literal>&lt;dynamic-component&gt;</literal> mapping are "
 "identical to <literal>&lt;component&gt;</literal>. The advantage of this "
 "kind of mapping is the ability to determine the actual properties of the "
@@ -648,15 +376,387 @@
 "You can also access, and change, Hibernate's configuration-time metamodel "
 "via the <literal>Configuration</literal> object."
 msgstr ""
-"从<literal>&lt;dynamic-component&gt;</literal>映射的语义上来讲,它和"
-"<literal>&lt;component&gt;</literal>是相同的。 这种映射类型的优点在于通过修改"
-"映射文件,就可以具有在部署时检测真实属性的能力。利用一个DOM解析器,也可以在程"
-"序运行时操作映射文件。 更好的是,你可以通过<literal>Configuration</literal>对"
-"象来访问(或者修改)Hibernate的运行时元模型。"
+"从 <literal>&lt;dynamic-component&gt;</literal> 映射的语义上来讲,它和 "
+"<literal>&lt;component&gt;</literal> 是相同的。这种映射类型的优点在于通过修改"
+"映射文件,就可以具有在部署时检测真实属性的能力。利用一个 DOM 解析器,也可以在"
+"程序运行时操作映射文件。更好的是,你可以通过 <literal>Configuration</"
+"literal> 对象来访问(或者修改)Hibernate 的运行时元模型。 "
 
 #~ msgid ""
-#~ "(Note that the <literal>&lt;column&gt;</literal> tag is an alternative to "
-#~ "the <literal>column</literal> attribute everywhere.)"
+#~ "<![CDATA[public class Person {\n"
+#~ "    private java.util.Date birthday;\n"
+#~ "    private Name name;\n"
+#~ "    private String key;\n"
+#~ "    public String getKey() {\n"
+#~ "        return key;\n"
+#~ "    }\n"
+#~ "    private void setKey(String key) {\n"
+#~ "        this.key=key;\n"
+#~ "    }\n"
+#~ "    public java.util.Date getBirthday() {\n"
+#~ "        return birthday;\n"
+#~ "    }\n"
+#~ "    public void setBirthday(java.util.Date birthday) {\n"
+#~ "        this.birthday = birthday;\n"
+#~ "    }\n"
+#~ "    public Name getName() {\n"
+#~ "        return name;\n"
+#~ "    }\n"
+#~ "    public void setName(Name name) {\n"
+#~ "        this.name = name;\n"
+#~ "    }\n"
+#~ "    ......\n"
+#~ "    ......\n"
+#~ "}]]>"
 #~ msgstr ""
-#~ "(注意在各个地方<literal>&lt;column&gt;</literal>标签都是<literal>column</"
-#~ "literal>属性的替代写法。)"
+#~ "<![CDATA[public class Person {\n"
+#~ "    private java.util.Date birthday;\n"
+#~ "    private Name name;\n"
+#~ "    private String key;\n"
+#~ "    public String getKey() {\n"
+#~ "        return key;\n"
+#~ "    }\n"
+#~ "    private void setKey(String key) {\n"
+#~ "        this.key=key;\n"
+#~ "    }\n"
+#~ "    public java.util.Date getBirthday() {\n"
+#~ "        return birthday;\n"
+#~ "    }\n"
+#~ "    public void setBirthday(java.util.Date birthday) {\n"
+#~ "        this.birthday = birthday;\n"
+#~ "    }\n"
+#~ "    public Name getName() {\n"
+#~ "        return name;\n"
+#~ "    }\n"
+#~ "    public void setName(Name name) {\n"
+#~ "        this.name = name;\n"
+#~ "    }\n"
+#~ "    ......\n"
+#~ "    ......\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[public class Name {\n"
+#~ "    char initial;\n"
+#~ "    String first;\n"
+#~ "    String last;\n"
+#~ "    public String getFirst() {\n"
+#~ "        return first;\n"
+#~ "    }\n"
+#~ "    void setFirst(String first) {\n"
+#~ "        this.first = first;\n"
+#~ "    }\n"
+#~ "    public String getLast() {\n"
+#~ "        return last;\n"
+#~ "    }\n"
+#~ "    void setLast(String last) {\n"
+#~ "        this.last = last;\n"
+#~ "    }\n"
+#~ "    public char getInitial() {\n"
+#~ "        return initial;\n"
+#~ "    }\n"
+#~ "    void setInitial(char initial) {\n"
+#~ "        this.initial = initial;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[public class Name {\n"
+#~ "    char initial;\n"
+#~ "    String first;\n"
+#~ "    String last;\n"
+#~ "    public String getFirst() {\n"
+#~ "        return first;\n"
+#~ "    }\n"
+#~ "    void setFirst(String first) {\n"
+#~ "        this.first = first;\n"
+#~ "    }\n"
+#~ "    public String getLast() {\n"
+#~ "        return last;\n"
+#~ "    }\n"
+#~ "    void setLast(String last) {\n"
+#~ "        this.last = last;\n"
+#~ "    }\n"
+#~ "    public char getInitial() {\n"
+#~ "        return initial;\n"
+#~ "    }\n"
+#~ "    void setInitial(char initial) {\n"
+#~ "        this.initial = initial;\n"
+#~ "    }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
+#~ "optional -->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\"> <!-- class attribute "
+#~ "optional -->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
+#~ "        <parent name=\"namedPerson\"/> <!-- reference back to the Person "
+#~ "-->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Person\" table=\"person\">\n"
+#~ "    <id name=\"Key\" column=\"pid\" type=\"string\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"birthday\" type=\"date\"/>\n"
+#~ "    <component name=\"Name\" class=\"eg.Name\" unique=\"true\">\n"
+#~ "        <parent name=\"namedPerson\"/> <!-- reference back to the Person "
+#~ "-->\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </component>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
+#~ "    <key column=\"id\"/>\n"
+#~ "    <composite-element class=\"eg.Name\"> <!-- class attribute required --"
+#~ ">\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </composite-element>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"someNames\" table=\"some_names\" lazy=\"true\">\n"
+#~ "    <key column=\"id\"/>\n"
+#~ "    <composite-element class=\"eg.Name\"> <!-- class attribute required --"
+#~ ">\n"
+#~ "        <property name=\"initial\"/>\n"
+#~ "        <property name=\"first\"/>\n"
+#~ "        <property name=\"last\"/>\n"
+#~ "    </composite-element>\n"
+#~ "</set>]]>"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.Purchase\">\n"
+#~ "            <property name=\"purchaseDate\"/>\n"
+#~ "            <property name=\"price\"/>\n"
+#~ "            <property name=\"quantity\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/> <!-- class "
+#~ "attribute is optional -->\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"eg.Order\" .... &gt;\n"
+#~ "    ....\n"
+#~ "    &lt;set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true"
+#~ "\"&gt;\n"
+#~ "        &lt;key column=\"order_id\"&gt;\n"
+#~ "        &lt;composite-element class=\"eg.Purchase\"&gt;\n"
+#~ "            &lt;property name=\"purchaseDate\"/&gt;\n"
+#~ "            &lt;property name=\"price\"/&gt;\n"
+#~ "            &lt;property name=\"quantity\"/&gt;\n"
+#~ "            &lt;many-to-one name=\"item\" class=\"eg.Item\"/&gt; &lt;!-- "
+#~ "class attribute is optional --&gt;\n"
+#~ "        &lt;/composite-element&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Order\" .... >\n"
+#~ "    ....\n"
+#~ "    <set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true\">\n"
+#~ "        <key column=\"order_id\">\n"
+#~ "        <composite-element class=\"eg.OrderLine\">\n"
+#~ "            <many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/>\n"
+#~ "            <many-to-one name=\"item\" class=\"eg.Item\"/>\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"eg.Order\" .... &gt;\n"
+#~ "    ....\n"
+#~ "    &lt;set name=\"purchasedItems\" table=\"purchase_items\" lazy=\"true"
+#~ "\"&gt;\n"
+#~ "        &lt;key column=\"order_id\"&gt;\n"
+#~ "        &lt;composite-element class=\"eg.OrderLine\"&gt;\n"
+#~ "            &lt;many-to-one name=\"purchaseDetails class=\"eg.Purchase\"/"
+#~ "&gt;\n"
+#~ "            &lt;many-to-one name=\"item\" class=\"eg.Item\"/&gt;\n"
+#~ "        &lt;/composite-element&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" class=\"OrderLineId\">\n"
+#~ "        <key-property name=\"lineId\"/>\n"
+#~ "        <key-property name=\"orderId\"/>\n"
+#~ "        <key-property name=\"customerId\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\" class=\"Order\"\n"
+#~ "            insert=\"false\" update=\"false\">\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    ....\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"OrderLine\"&gt;\n"
+#~ "    \n"
+#~ "    &lt;composite-id name=\"id\" class=\"OrderLineId\"&gt;\n"
+#~ "        &lt;key-property name=\"lineId\"/&gt;\n"
+#~ "        &lt;key-property name=\"orderId\"/&gt;\n"
+#~ "        &lt;key-property name=\"customerId\"/&gt;\n"
+#~ "    &lt;/composite-id&gt;\n"
+#~ "    \n"
+#~ "    &lt;property name=\"name\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;many-to-one name=\"order\" class=\"Order\"\n"
+#~ "            insert=\"false\" update=\"false\"&gt;\n"
+#~ "        &lt;column name=\"orderId\"/&gt;\n"
+#~ "        &lt;column name=\"customerId\"/&gt;\n"
+#~ "    &lt;/many-to-one&gt;\n"
+#~ "    ....\n"
+#~ "    \n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"orderLine\" class=\"OrderLine\">\n"
+#~ "<!-- the \"class\" attribute is optional, as usual -->\n"
+#~ "    <column name=\"lineId\"/>\n"
+#~ "    <column name=\"orderId\"/>\n"
+#~ "    <column name=\"customerId\"/>\n"
+#~ "</many-to-one>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"orderLine\" class=\"OrderLine\"&gt;\n"
+#~ "&lt;!-- the \"class\" attribute is optional, as usual --&gt;\n"
+#~ "    &lt;column name=\"lineId\"/&gt;\n"
+#~ "    &lt;column name=\"orderId\"/&gt;\n"
+#~ "    &lt;column name=\"customerId\"/&gt;\n"
+#~ "&lt;/many-to-one&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<set name=\"undeliveredOrderLines\">\n"
+#~ "    <key column name=\"warehouseId\"/>\n"
+#~ "    <many-to-many class=\"OrderLine\">\n"
+#~ "        <column name=\"lineId\"/>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </many-to-many>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "&lt;set name=\"undeliveredOrderLines\"&gt;\n"
+#~ "    &lt;key column name=\"warehouseId\"/&gt;\n"
+#~ "    &lt;many-to-many class=\"OrderLine\"&gt;\n"
+#~ "        &lt;column name=\"lineId\"/&gt;\n"
+#~ "        &lt;column name=\"orderId\"/&gt;\n"
+#~ "        &lt;column name=\"customerId\"/&gt;\n"
+#~ "    &lt;/many-to-many&gt;\n"
+#~ "&lt;/set&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<set name=\"orderLines\" inverse=\"true\">\n"
+#~ "    <key>\n"
+#~ "        <column name=\"orderId\"/>\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "    </key>\n"
+#~ "    <one-to-many class=\"OrderLine\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "&lt;set name=\"orderLines\" inverse=\"true\"&gt;\n"
+#~ "    &lt;key&gt;\n"
+#~ "        &lt;column name=\"orderId\"/&gt;\n"
+#~ "        &lt;column name=\"customerId\"/&gt;\n"
+#~ "    &lt;/key&gt;\n"
+#~ "    &lt;one-to-many class=\"OrderLine\"/&gt;\n"
+#~ "&lt;/set&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"OrderLine\">\n"
+#~ "    ....\n"
+#~ "    ....\n"
+#~ "    <list name=\"deliveryAttempts\">\n"
+#~ "        <key>   <!-- a collection inherits the composite key type -->\n"
+#~ "            <column name=\"lineId\"/>\n"
+#~ "            <column name=\"orderId\"/>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "        </key>\n"
+#~ "        <list-index column=\"attemptId\" base=\"1\"/>\n"
+#~ "        <composite-element class=\"DeliveryAttempt\">\n"
+#~ "            ...\n"
+#~ "        </composite-element>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"OrderLine\"&gt;\n"
+#~ "    ....\n"
+#~ "    ....\n"
+#~ "    &lt;list name=\"deliveryAttempts\"&gt;\n"
+#~ "        &lt;key&gt;   &lt;!-- a collection inherits the composite key "
+#~ "type --&gt;\n"
+#~ "            &lt;column name=\"lineId\"/&gt;\n"
+#~ "            &lt;column name=\"orderId\"/&gt;\n"
+#~ "            &lt;column name=\"customerId\"/&gt;\n"
+#~ "        &lt;/key&gt;\n"
+#~ "        &lt;list-index column=\"attemptId\" base=\"1\"/&gt;\n"
+#~ "        &lt;composite-element class=\"DeliveryAttempt\"&gt;\n"
+#~ "            ...\n"
+#~ "        &lt;/composite-element&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<dynamic-component name=\"userAttributes\">\n"
+#~ "    <property name=\"foo\" column=\"FOO\" type=\"string\"/>\n"
+#~ "    <property name=\"bar\" column=\"BAR\" type=\"integer\"/>\n"
+#~ "    <many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/>\n"
+#~ "</dynamic-component>]]>"
+#~ msgstr ""
+#~ "&lt;dynamic-component name=\"userAttributes\"&gt;\n"
+#~ "    &lt;property name=\"foo\" column=\"FOO\" type=\"string\"/&gt;\n"
+#~ "    &lt;property name=\"bar\" column=\"BAR\" type=\"integer\"/&gt;\n"
+#~ "    &lt;many-to-one name=\"baz\" class=\"Baz\" column=\"BAZ_ID\"/&gt;\n"
+#~ "&lt;/dynamic-component&gt;"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/configuration.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/configuration.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/configuration.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,26 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-11 10:39+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: configuration.xml:29
 #, no-c-format
 msgid "Configuration"
 msgstr "配置"
 
 #. Tag: para
-#: configuration.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate is designed to operate in many different environments and, as "
 "such, there is a broad range of configuration parameters. Fortunately, most "
@@ -27,21 +29,19 @@
 "displays the various options. Simply put the example file in your classpath "
 "and customize it to suit your needs."
 msgstr ""
-"由于Hibernate是为了能在各种不同环境下工作而设计的, 因此存在着大量的配置参数. "
-"幸运的是多数配置参数都 有比较直观的默认值, 并有随Hibernate一同分发的配置样例"
-"<literal>hibernate.properties</literal> (位于<literal>etc/</literal>)来展示各"
-"种配置选项. 所需做的仅仅是将这个样例文件复制到类路径 (classpath)下并做一些自"
-"定义的修改."
+"由于 Hibernate 是为了能在各种不同环境下工作而设计的,因此存在着大量的配置参"
+"数。幸运的是多数配置参数都有比较直观的默认值,并有随 Hibernate 一同分发的配置"
+"样例 <literal>hibernate.properties</literal>(位于 <literal>etc/</literal>)"
+"来展示各种配置选项。所需做的仅仅是将这个样例文件复制到类路径(classpath)下并"
+"进行定制。"
 
 #. Tag: title
-#: configuration.xml:40
 #, no-c-format
 msgid "Programmatic configuration"
 msgstr "可编程的配置方式"
 
 #. Tag: para
-#: configuration.xml:42
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An instance of <classname>org.hibernate.cfg.Configuration</classname> "
 "represents an entire set of mappings of an application's Java types to an "
@@ -49,162 +49,124 @@
 "used to build an immutable <interfacename>org.hibernate.SessionFactory</"
 "interfacename>. The mappings are compiled from various XML mapping files."
 msgstr ""
-"一个<literal>org.hibernate.cfg.Configuration</literal>实例代表了一个应用程序"
-"中Java类型 到SQL数据库映射的完整集合. <literal>Configuration</literal>被用来"
-"构建一个(不可变的 (immutable))<literal>SessionFactory</literal>. 映射定义则由"
-"不同的XML映射定义文件编译而来."
+"<literal>org.hibernate.cfg.Configuration</literal> 实例代表了一个应用程序中 "
+"Java 类型到SQL数据库映射的完整集合。<classname>org.hibernate.cfg."
+"Configuration</classname> 被用来构建一个(不可变的(immutable))"
+"<interfacename>org.hibernate.SessionFactory</interfacename>。映射定义则由不同"
+"的 XML 映射定义文件编译而来。"
 
 #. Tag: para
-#: configuration.xml:49
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can obtain a <classname>org.hibernate.cfg.Configuration</classname> "
 "instance by instantiating it directly and specifying XML mapping documents. "
 "If the mapping files are in the classpath, use <literal>addResource()</"
 "literal>. For example:"
 msgstr ""
-"你可以直接实例化<literal>Configuration</literal>来获取一个实例,并为它指定XML"
-"映射定义 文件. 如果映射定 义文件在类路径(classpath)中, 请使用"
-"<literal>addResource()</literal>:"
+"你可以直接实例化 <classname>org.hibernate.cfg.Configuration</classname> 来获"
+"取一个实例,并为它指定 XML 映射定义文件。如果映射定义文件在类路径"
+"(classpath)中,请使用 <literal>addResource()</literal>。例如:"
 
-#. Tag: programlisting
-#: configuration.xml:55
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addResource(\"Item.hbm.xml\")\n"
-"    .addResource(\"Bid.hbm.xml\");]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:57
-#, fuzzy, no-c-format
-msgid ""
 "An alternative way is to specify the mapped class and allow Hibernate to "
 "find the mapping document for you:"
 msgstr ""
-"一个替代方法(有时是更好的选择)是,指定被映射的类,让Hibernate帮你寻找映射定"
-"义文件:"
+"一个替代方法(有时是更好的选择)是,指定被映射的类,让 Hibernate 帮你寻找映射"
+"定义文件: "
 
-#. Tag: programlisting
-#: configuration.xml:62
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addClass(org.hibernate.auction.Item.class)\n"
-"    .addClass(org.hibernate.auction.Bid.class);]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:64
-#, fuzzy, no-c-format
-msgid ""
 "Hibernate will then search for mapping files named <filename>/org/hibernate/"
 "auction/Item.hbm.xml</filename> and <filename>/org/hibernate/auction/Bid.hbm."
 "xml</filename> in the classpath. This approach eliminates any hardcoded "
 "filenames."
 msgstr ""
-"Hibernate将会在类路径(classpath)中寻找名字为 <literal>/org/hibernate/auction/"
-"Item.hbm.xml</literal>和 <literal>/org/hibernate/auction/Bid.hbm.xml</"
-"literal>映射定义文件. 这种方式消除了任何对文件名的硬编码(hardcoded)."
+"Hibernate 将会在类路径(classpath)中寻找名字为 <filename>/org/hibernate/"
+"auction/Item.hbm.xml</filename> 和 <filename>/org/hibernate/auction/Bid.hbm."
+"xml</filename> 映射定义文件。这种方式消除了任何对文件名的硬编码"
+"(hardcoded)。"
 
 #. Tag: para
-#: configuration.xml:70
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <classname>org.hibernate.cfg.Configuration</classname> also allows you to "
 "specify configuration properties. For example:"
-msgstr "<literal>Configuration</literal>也允许你指定配置属性:"
-
-#. Tag: programlisting
-#: configuration.xml:75
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = new Configuration()\n"
-"    .addClass(org.hibernate.auction.Item.class)\n"
-"    .addClass(org.hibernate.auction.Bid.class)\n"
-"    .setProperty(\"hibernate.dialect\", \"org.hibernate.dialect."
-"MySQLInnoDBDialect\")\n"
-"    .setProperty(\"hibernate.connection.datasource\", \"java:comp/env/jdbc/"
-"test\")\n"
-"    .setProperty(\"hibernate.order_updates\", \"true\");]]>"
 msgstr ""
+"<classname>org.hibernate.cfg.Configuration</classname>> 也允许你指定配置属"
+"性。例如:"
 
 #. Tag: para
-#: configuration.xml:77
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is not the only way to pass configuration properties to Hibernate. Some "
 "alternative options include:"
-msgstr "当然这不是唯一的传递Hibernate配置属性的方式, 其他可选方式还包括:"
+msgstr "当然这不是唯一的传递 Hibernate 配置属性的方式,其他可选方式还包括: "
 
 #. Tag: para
-#: configuration.xml:84
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Pass an instance of <classname>java.util.Properties</classname> to "
 "<literal>Configuration.setProperties()</literal>."
 msgstr ""
-"传一个<literal>java.util.Properties</literal>实例给 <literal>Configuration."
-"setProperties()</literal>."
+"传一个 <classname>java.util.Properties</classname> 实例给 "
+"<literal>Configuration.setProperties()</literal>。"
 
 #. Tag: para
-#: configuration.xml:90
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Place a file named <filename>hibernate.properties</filename> in a root "
 "directory of the classpath."
 msgstr ""
-"将<literal>hibernate.properties</literal>放置在类路径(classpath)的根目录下 "
-"(root directory)."
+"将 <filename>hibernate.properties</filename> 放置在类路径(classpath)的根目"
+"录下(root directory)。"
 
 #. Tag: para
-#: configuration.xml:95
 #, no-c-format
 msgid ""
 "Set <literal>System</literal> properties using <literal>java -"
 "Dproperty=value</literal>."
 msgstr ""
-"通过<literal>java -Dproperty=value</literal>来设置系统 (<literal>System</"
-"literal>)属性."
+"通过 <literal>java -Dproperty=value</literal> 来设置系统(<literal>System</"
+"literal>)属性。"
 
 #. Tag: para
-#: configuration.xml:100
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Include <literal>&lt;property&gt;</literal> elements in <literal>hibernate."
 "cfg.xml</literal> (this is discussed later)."
 msgstr ""
-"在<literal>hibernate.cfg.xml</literal>中加入元素 <literal>&lt;property&gt;</"
-"literal> (稍后讨论)."
+"在 <literal>hibernate.cfg.xml</literal> 中加入元素 <literal>&lt;property&gt;"
+"</literal>(稍后讨论)。 "
 
 #. Tag: para
-#: configuration.xml:107
 #, no-c-format
 msgid ""
 "If you want to get started quickly<filename>hibernate.properties</filename> "
 "is the easiest approach."
 msgstr ""
+"如果你想快速上路,<filename>hibernate.properties</filename> 就是最容易的途"
+"径。"
 
 #. Tag: para
-#: configuration.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <classname>org.hibernate.cfg.Configuration</classname> is intended as a "
 "startup-time object that will be discarded once a <literal>SessionFactory</"
 "literal> is created."
 msgstr ""
-"<literal>Configuration</literal>实例被设计成启动期间(startup-time)对象, 一"
-"旦<literal>SessionFactory</literal>创建完成它就被丢弃了."
+"<classname>org.hibernate.cfg.Configuration</classname> 实例被设计成启动期间"
+"(startup-time)对象,一旦 <literal>SessionFactory</literal> 创建完成它就被丢"
+"弃了。"
 
 #. Tag: title
-#: configuration.xml:119
 #, no-c-format
 msgid "Obtaining a SessionFactory"
-msgstr "获得SessionFactory"
+msgstr "获得 SessionFactory"
 
 #. Tag: para
-#: configuration.xml:121
 #, fuzzy, no-c-format
 msgid ""
 "When all mappings have been parsed by the <classname>org.hibernate.cfg."
@@ -212,64 +174,48 @@
 "<interfacename>org.hibernate.Session</interfacename> instances. This factory "
 "is intended to be shared by all application threads:"
 msgstr ""
-"当所有映射定义被<literal>Configuration</literal>解析后, 应用程序必须获得一个"
-"用于构造<literal>Session</literal>实例的工厂. 这个工厂将被应用程序的所有线程"
-"共享:"
+"当所有映射定义被 <classname>org.hibernate.cfg.Configuration</classname> 解析"
+"后,应用程序必须获得一个用于构造 <interfacename>org.hibernate.Session</"
+"interfacename> 实例的工厂。这个工厂将被应用程序的所有线程共享: "
 
-#. Tag: programlisting
-#: configuration.xml:127
-#, no-c-format
-msgid "<![CDATA[SessionFactory sessions = cfg.buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:129
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate does allow your application to instantiate more than one "
 "<interfacename>org.hibernate.SessionFactory</interfacename>. This is useful "
 "if you are using more than one database."
 msgstr ""
-"Hibernate允许你的应用程序创建多个<literal>SessionFactory</literal>实例. 这对 "
-"使用多个数据库的应用来说很有用."
+"Hibernate 允许你的应用程序创建多个 <interfacename>org.hibernate."
+"SessionFactory</interfacename> 实例。这对 使用多个数据库的应用来说很有用。 "
 
 #. Tag: title
-#: configuration.xml:138
 #, no-c-format
 msgid "JDBC connections"
-msgstr "JDBC连接"
+msgstr "JDBC 连接"
 
 #. Tag: para
-#: configuration.xml:140
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is advisable to have the <interfacename>org.hibernate.SessionFactory</"
 "interfacename> create and pool JDBC connections for you. If you take this "
 "approach, opening a <interfacename>org.hibernate.Session</interfacename> is "
 "as simple as:"
 msgstr ""
-"通常你希望<literal>SessionFactory</literal>来为你创建和缓存(pool)JDBC连接. 如"
-"果你采用这种方式, 只需要如下例所示那样,打开一个<literal>Session</literal>:"
+"通常你希望  <interfacename>org.hibernate.SessionFactory</interfacename> 来为"
+"你创建和缓存(pool)JDBC 连接。如果你采用这种方式,只需要如下例所示那样,打开"
+"一个 <interfacename>org.hibernate.Session</interfacename>:"
 
-#. Tag: programlisting
-#: configuration.xml:146
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = sessions.openSession(); // open a new Session]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:148
-#, fuzzy, no-c-format
-msgid ""
 "Once you start a task that requires access to the database, a JDBC "
 "connection will be obtained from the pool."
 msgstr ""
-"一旦你需要进行数据访问时, 就会从连接池(connection pool)获得一个JDBC连接."
+"一旦你需要进行数据访问时,就会从连接池(connection pool)获得一个 JDBC 连"
+"接。 "
 
 #. Tag: para
-#: configuration.xml:153
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Before you can do this, you first need to pass some JDBC connection "
 "properties to Hibernate. All Hibernate property names and semantics are "
@@ -277,105 +223,86 @@
 "The most important settings for JDBC connection configuration are outlined "
 "below."
 msgstr ""
-"为了使这种方式工作起来, 我们需要向Hibernate传递一些JDBC连接的属性. 所有"
-"Hibernate属性的名字和语义都在<literal>org.hibernate.cfg.Environment</literal>"
-"中定义. 我们现在将描述JDBC连接配置中最重要的设置."
+"为了使这种方式工作起来,我们需要向 Hibernate 传递一些 JDBC 连接的属性。所有 "
+"Hibernate 属性的名字和语义都在 <classname>org.hibernate.cfg.Environment</"
+"classname> 中定义。我们现在将描述 JDBC 连接配置中最重要的设置。"
 
 #. Tag: para
-#: configuration.xml:159
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will obtain and pool connections using <classname>java.sql."
 "DriverManager</classname> if you set the following properties:"
 msgstr ""
-"如果你设置如下属性,Hibernate将使用<literal>java.sql.DriverManager</literal>"
-"来获得(和缓存)JDBC连接 :"
+"如果你设置如下属性,Hibernate 将使用 <classname>java.sql.DriverManager</"
+"classname> 来获得(和缓存)JDBC 连接:"
 
 #. Tag: title
-#: configuration.xml:165
 #, no-c-format
 msgid "Hibernate JDBC Properties"
-msgstr "Hibernate JDBC属性"
+msgstr "Hibernate JDBC 属性"
 
 #. Tag: entry
-#: configuration.xml:171 configuration.xml:257 configuration.xml:353
-#: configuration.xml:548 configuration.xml:743 configuration.xml:850
-#: configuration.xml:938
 #, no-c-format
 msgid "Property name"
 msgstr "属性名"
 
 #. Tag: entry
-#: configuration.xml:172 configuration.xml:258 configuration.xml:354
-#: configuration.xml:549 configuration.xml:744 configuration.xml:851
-#: configuration.xml:939
 #, no-c-format
 msgid "Purpose"
 msgstr "用途"
 
-#. Tag: property
-#: configuration.xml:178
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.driver_class"
-msgstr "hibernate.connection.driver_class"
+msgid "<property>hibernate.connection.driver_class</property>"
+msgstr "<property>hibernate.connection.driver_class</property>"
 
-#. Tag: emphasis
-#: configuration.xml:181
+#. Tag: entry
 #, no-c-format
-msgid "JDBC driver class"
-msgstr "jdbc驱动类"
+msgid "<emphasis>JDBC driver class</emphasis>"
+msgstr "<emphasis>JDBC 驱动类</emphasis>"
 
-#. Tag: property
-#: configuration.xml:186
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.url"
-msgstr "hibernate.connection.url"
+msgid "<property>hibernate.connection.url</property>"
+msgstr "<property>hibernate.connection.url</property>"
 
-#. Tag: emphasis
-#: configuration.xml:189
+#. Tag: entry
 #, no-c-format
-msgid "JDBC URL"
-msgstr "jdbc URL"
+msgid "<emphasis>JDBC URL</emphasis>"
+msgstr "<emphasis>JDBC URL</emphasis>"
 
-#. Tag: property
-#: configuration.xml:194 configuration.xml:288
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.username"
-msgstr "hibernate.connection.username"
+msgid "<property>hibernate.connection.username</property>"
+msgstr "<property>hibernate.connection.username</property>"
 
-#. Tag: emphasis
-#: configuration.xml:197
+#. Tag: entry
 #, no-c-format
-msgid "database user"
-msgstr "数据库用户"
+msgid "<emphasis>database user</emphasis>"
+msgstr "<emphasis>数据库用户</emphasis>(可选) "
 
-#. Tag: property
-#: configuration.xml:202 configuration.xml:296
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.password"
-msgstr "hibernate.connection.password"
+msgid "<property>hibernate.connection.password</property>"
+msgstr "<property>hibernate.connection.password</property>"
 
-#. Tag: emphasis
-#: configuration.xml:205
+#. Tag: entry
 #, no-c-format
-msgid "database user password"
-msgstr "数据库用户密码"
+msgid "<emphasis>database user password</emphasis>"
+msgstr "<emphasis>数据库密码</emphasis>(可选) "
 
-#. Tag: property
-#: configuration.xml:210
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.pool_size"
-msgstr "hibernate.connection.pool_size"
+msgid "<property>hibernate.connection.pool_size</property>"
+msgstr "<property>hibernate.connection.pool_size</property>"
 
-#. Tag: emphasis
-#: configuration.xml:213
+#. Tag: entry
 #, no-c-format
-msgid "maximum number of pooled connections"
-msgstr "连接池容量上限数目"
+msgid "<emphasis>maximum number of pooled connections</emphasis>"
+msgstr "<emphasis>连接池容量上限数目</emphasis>"
 
 #. Tag: para
-#: configuration.xml:220
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's own connection pooling algorithm is, however, quite rudimentary. "
 "It is intended to help you get started and is <emphasis>not intended for use "
@@ -385,15 +312,14 @@
 "with connection pool specific settings. This will turn off Hibernate's "
 "internal pool. For example, you might like to use c3p0."
 msgstr ""
-"但Hibernate自带的连接池算法相当不成熟. 它只是为了让你快些上手<emphasis>,并不"
-"适合用于产品系统</emphasis>或性能测试中。 出于最佳性能和稳定性考虑你应该使用"
-"第三方的连接池。只需要用特定连接池的设置替换 <literal>hibernate.connection."
-"pool_size</literal>即可。这将关闭Hibernate自带的连接池. 例如, 你可能会想用"
-"C3P0."
+"但 Hibernate 自带的连接池算法相当不成熟。它只是为了让你快些上手<emphasis>,并"
+"不适合用于产品系统</emphasis>或性能测试中。 出于最佳性能和稳定性考虑你应该使"
+"用第三方的连接池。只需要用特定连接池的设置替换 <literal>hibernate.connection."
+"pool_size</literal> 即可。这将关闭 Hibernate 自带的连接池。例如,你可能会想"
+"用 C3P0。  "
 
 #. Tag: para
-#: configuration.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "C3P0 is an open source JDBC connection pool distributed along with Hibernate "
 "in the <filename>lib</filename> directory. Hibernate will use its "
@@ -403,152 +329,112 @@
 "<filename>hibernate.properties</filename> and the Hibernate web site for "
 "more information."
 msgstr ""
-"C3P0是一个随Hibernate一同分发的开源的JDBC连接池, 它位于<literal>lib</literal>"
-"目录下。 如果你设置了<literal>hibernate.c3p0.*</literal>相关的属性, Hibernate"
-"将使用 <literal>C3P0ConnectionProvider</literal>来缓存JDBC连接. 如果你更原意"
-"使用Proxool, 请参考发 行包中的<literal>hibernate.properties</literal>并到"
-"Hibernate网站获取更多的信息."
+"C3P0 是一个随 Hibernate 一同分发的开源的 JDBC 连接池,它位于 <literal>lib</"
+"literal>目录下。 如果你设置了 <literal>hibernate.c3p0.*</literal> 相关的属"
+"性,Hibernate将使用 <literal>C3P0ConnectionProvider</literal> 来缓存 JDBC 连"
+"接。如果你更原意使用 Proxool,请参考发行包中的 <literal>hibernate."
+"properties</literal> 并到 Hibernate 网站获取更多的信息。 "
 
 #. Tag: para
-#: configuration.xml:238
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is an example <filename>hibernate.properties</filename> file "
 "for c3p0:"
-msgstr "这是一个使用C3P0的<literal>hibernate.properties</literal>样例文件:"
-
-#. Tag: programlisting
-#: configuration.xml:242
-#, no-c-format
-msgid ""
-"<![CDATA[hibernate.connection.driver_class = org.postgresql.Driver\n"
-"hibernate.connection.url = jdbc:postgresql://localhost/mydatabase\n"
-"hibernate.connection.username = myuser\n"
-"hibernate.connection.password = secret\n"
-"hibernate.c3p0.min_size=5\n"
-"hibernate.c3p0.max_size=20\n"
-"hibernate.c3p0.timeout=1800\n"
-"hibernate.c3p0.max_statements=50\n"
-"hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
 msgstr ""
+"这是一个使用 C3P0 的 <literal>hibernate.properties</literal> 样例文件: "
 
 #. Tag: para
-#: configuration.xml:244
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For use inside an application server, you should almost always configure "
 "Hibernate to obtain connections from an application server "
 "<interfacename>javax.sql.Datasource</interfacename> registered in JNDI. You "
 "will need to set at least one of the following properties:"
 msgstr ""
-"为了能在应用程序服务器(application server)中使用Hibernate, 应当总是将"
-"Hibernate 配置成从注册在JNDI中的<literal>Datasource</literal>处获得连接,你至"
-"少需要设置下列属性中的一个:"
+"为了能在应用程序服务器(application server)中使用 Hibernate,应当总是将 "
+"Hibernate 配置成从注册在 JNDI 中的 <literal>Datasource</literal> 处获得连接,"
+"你至少需要设置下列属性中的一个: "
 
 #. Tag: title
-#: configuration.xml:251
 #, no-c-format
 msgid "Hibernate Datasource Properties"
-msgstr "Hibernate数据源属性"
+msgstr "Hibernate 数据源属性"
 
-#. Tag: property
-#: configuration.xml:264
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.datasource"
-msgstr "hibernate.connection.datasource"
+msgid "<property>hibernate.connection.datasource</property>"
+msgstr "<property>hibernate.connection.datasource</property>"
 
-#. Tag: emphasis
-#: configuration.xml:267
+#. Tag: entry
 #, no-c-format
-msgid "datasource JNDI name"
-msgstr "数据源JNDI名字"
+msgid "<emphasis>datasource JNDI name</emphasis>"
+msgstr "<emphasis>数据库用户</emphasis>(可选) "
 
-#. Tag: property
-#: configuration.xml:272
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jndi.url"
-msgstr "hibernate.jndi.url"
+msgid "<property>hibernate.jndi.url</property>"
+msgstr "<property>hibernate.jndi.url</property>"
 
 #. Tag: entry
-#: configuration.xml:274
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis>URL of the JNDI provider</emphasis> (optional)"
-msgstr "JNDI提供者的URL"
+msgstr "<emphasis>JNDI 提供者的 URL</emphasis>(可选)"
 
-#. Tag: property
-#: configuration.xml:280
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jndi.class"
-msgstr "hibernate.jndi.class"
+msgid "<property>hibernate.jndi.class</property>"
+msgstr "<property>hibernate.jndi.class</property>"
 
 #. Tag: entry
-#: configuration.xml:282
 #, no-c-format
 msgid ""
 "<emphasis>class of the JNDI <literal>InitialContextFactory</literal></"
 "emphasis> (optional)"
 msgstr ""
+"<emphasis>JNDI <literal>InitialContextFactory</literal> 类</emphasis>(可选)"
 
 #. Tag: entry
-#: configuration.xml:290
 #, no-c-format
 msgid "<emphasis>database user</emphasis> (optional)"
-msgstr ""
+msgstr "<emphasis>数据库用户</emphasis>(可选)"
 
 #. Tag: entry
-#: configuration.xml:298
 #, no-c-format
 msgid "<emphasis>database user password</emphasis> (optional)"
-msgstr ""
+msgstr "<emphasis>数据库密码</emphasis>(可选)"
 
 #. Tag: para
-#: configuration.xml:306
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Here is an example <filename>hibernate.properties</filename> file for an "
 "application server provided JNDI datasource:"
 msgstr ""
-"这是一个使用应用程序服务器提供的JNDI数据源的<literal>hibernate.properties</"
-"literal>样例文件:"
+"这是一个使用应用程序服务器提供的 JNDI 数据源的 <literal>hibernate."
+"properties</literal> 样例文件: "
 
-#. Tag: programlisting
-#: configuration.xml:311
-#, no-c-format
-msgid ""
-"<![CDATA[hibernate.connection.datasource = java:/comp/env/jdbc/test\n"
-"hibernate.transaction.factory_class = \\\n"
-"    org.hibernate.transaction.JTATransactionFactory\n"
-"hibernate.transaction.manager_lookup_class = \\\n"
-"    org.hibernate.transaction.JBossTransactionManagerLookup\n"
-"hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:313
 #, no-c-format
 msgid ""
 "JDBC connections obtained from a JNDI datasource will automatically "
 "participate in the container-managed transactions of the application server."
 msgstr ""
-"从JNDI数据源获得的JDBC连接将自动参与到应用程序服务器中容器管理的事务"
-"(container-managed transactions)中去."
+"从 JNDI 数据源获得的 JDBC 连接将自动参与到应用程序服务器中容器管理的事务"
+"(container-managed transactions)中去。"
 
 #. Tag: para
-#: configuration.xml:318
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Arbitrary connection properties can be given by prepending "
 "\"<literal>hibernate.connection</literal>\" to the connection property name. "
 "For example, you can specify a <property>charSet</property> connection "
 "property using <property>hibernate.connection.charSet</property>."
 msgstr ""
-"任何连接(connection)属性的属性名都要以\"<literal>hibernate.connnection</"
-"literal>\"开头. 例如, 你可能会使用<literal>hibernate.connection.charSet</"
-"literal>来指定字符集<literal>charSet</literal>."
+"任何连接(connection)属性的属性名都要以 \"<literal>hibernate.connnection</"
+"literal>\" 开头。例如,你可能会使用 <literal>hibernate.connection.charSet</"
+"literal> 来指定 <property>charSet</property> 连接属性。 "
 
 #. Tag: para
-#: configuration.xml:324
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can define your own plugin strategy for obtaining JDBC connections by "
 "implementing the interface <interfacename>org.hibernate.connection."
@@ -556,28 +442,25 @@
 "implementation via the <property>hibernate.connection.provider_class</"
 "property> property."
 msgstr ""
-"通过实现<literal>org.hibernate.connection.ConnectionProvider</literal>接口,"
-"你可以定义属于 你自己的获得JDBC连接的插件策略。通过设置<literal>hibernate."
-"connection.provider_class</literal>, 你可以选择一个自定义的实现."
+"通过实现 <literal>org.hibernate.connection.ConnectionProvider</literal> 接"
+"口,你可以定义属于你自己的获得JDBC连接的插件策略。通过设置<literal>hibernate."
+"connection.provider_class</literal>,你可以选择一个自定义的实现。 "
 
 #. Tag: title
-#: configuration.xml:333
 #, no-c-format
 msgid "Optional configuration properties"
 msgstr "可选的配置属性"
 
 #. Tag: para
-#: configuration.xml:335
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are a number of other properties that control the behavior of "
 "Hibernate at runtime. All are optional and have reasonable default values."
 msgstr ""
-"有大量属性能用来控制Hibernate在运行期的行为. 它们都是可选的, 并拥有适当的默认"
-"值."
+"有大量属性能用来控制 Hibernate 在运行期的行为。它们都是可选的,并拥有适当的默"
+"认值。 "
 
-#. Tag: warning
-#: configuration.xml:341
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
 "<emphasis>Some of these properties are \"system-level\" only.</emphasis> "
@@ -585,657 +468,379 @@
 "literal> or <filename>hibernate.properties</filename>. They "
 "<emphasis>cannot</emphasis> be set by the other techniques described above."
 msgstr ""
-"<emphasis>警告: 其中一些属性是\"系统级(system-level)的\".</emphasis> 系统级属"
-"性只能通过<literal>java -Dproperty=value</literal>或 <literal>hibernate."
-"properties</literal>来设置, 而<emphasis>不能</emphasis>用上面描述的其他方法来"
-"设置."
+"警告: 其中一些属性是\"系统级(system-level)的\"。系统级属性只能通过"
+"<literal>java -Dproperty=value</literal> 或 <literal>hibernate.properties</"
+"literal> 来设置,而<emphasis>不能</emphasis>用上面描述的其他方法来设置。 "
 
 #. Tag: title
-#: configuration.xml:347
 #, no-c-format
 msgid "Hibernate Configuration Properties"
-msgstr "Hibernate配置属性"
+msgstr "Hibernate 配置属性"
 
-#. Tag: property
-#: configuration.xml:360
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.dialect"
-msgstr "hibernate.dialect"
+msgid "<property>hibernate.dialect</property>"
+msgstr "<property>hibernate.dialect</property>"
 
 #. Tag: entry
-#: configuration.xml:362
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a Hibernate <classname>org.hibernate.dialect.Dialect</"
 "classname> which allows Hibernate to generate SQL optimized for a particular "
 "relational database."
 msgstr ""
-"一个Hibernate <placeholder-1/>类名允许Hibernate针对特定的关系数据库生成优化的"
-"SQL. <placeholder-2/>"
+"允许 Hibernate 针对特定的关系数据库生成优化的 SQL 的 <classname>org."
+"hibernate.dialect.Dialect</classname> 的类名。"
 
 #. Tag: para
-#: configuration.xml:365
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>full.classname.of."
 "Dialect</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例如:</emphasis><literal>full.classname.of."
+"Dialect</literal> "
 
 #. Tag: para
-#: configuration.xml:369
 #, no-c-format
 msgid ""
 "In most cases Hibernate will actually be able to choose the correct "
 "<classname>org.hibernate.dialect.Dialect</classname> implementation based on "
 "the <literal>JDBC metadata</literal> returned by the JDBC driver."
 msgstr ""
+"在大多数情况下,Hibernate 可以根据 JDBC 驱动返回的 <literal>JDBC metadata</"
+"literal> 选择正确的 <classname>org.hibernate.dialect.Dialect</classname> 实"
+"现。"
 
-#. Tag: property
-#: configuration.xml:378
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.show_sql"
-msgstr "hibernate.show_sql"
+msgid "<property>hibernate.show_sql</property>"
+msgstr "<property>hibernate.show_sql</property>"
 
 #. Tag: entry
-#: configuration.xml:380
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Write all SQL statements to console. This is an alternative to setting the "
 "log category <literal>org.hibernate.SQL</literal> to <literal>debug</"
 "literal>."
 msgstr ""
-"输出所有SQL语句到控制台. 有一个另外的选择是把<placeholder-1/>这个log category"
-"设为<placeholder-2/>。 <placeholder-3/>"
+"输出所有 SQL 语句到控制台。有一个另外的选择是把 <literal>org.hibernate.SQL</"
+"literal> 这个 log category设为 <literal>debug</literal>。"
 
 #. Tag: para
-#: configuration.xml:384 configuration.xml:396 configuration.xml:490
-#: configuration.xml:503 configuration.xml:516 configuration.xml:529
-#: configuration.xml:583 configuration.xml:610 configuration.xml:623
-#: configuration.xml:678 configuration.xml:906 configuration.xml:921
-#: configuration.xml:1011
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>true</literal> | "
 "<literal>false</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例如:</emphasis><literal>true</literal> | "
+"<literal>false</literal> "
 
-#. Tag: property
-#: configuration.xml:392
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.format_sql"
-msgstr "hibernate.format_sql"
+msgid "<property>hibernate.format_sql</property>"
+msgstr "<property>hibernate.format_sql</property>"
 
 #. Tag: entry
-#: configuration.xml:394
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Pretty print the SQL in the log and console."
-msgstr "在log和console中打印出更漂亮的SQL。 <placeholder-1/>"
+msgstr "在 log 和 console 中打印出更漂亮的 SQL。"
 
-#. Tag: property
-#: configuration.xml:404
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_schema"
-msgstr "hibernate.default_schema"
+msgid "<property>hibernate.default_schema</property>"
+msgstr "<property>hibernate.default_schema</property>"
 
 #. Tag: entry
-#: configuration.xml:406
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Qualify unqualified table names with the given schema/tablespace in "
 "generated SQL."
 msgstr ""
-"在生成的SQL中, 将给定的schema/tablespace附加于非全限定名的表名上. "
-"<placeholder-1/>"
+"在生成的 SQL 中,将给定的 schema/tablespace 附加于非全限定名的表名上。 "
 
 #. Tag: para
-#: configuration.xml:409
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>SCHEMA_NAME</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例如:</emphasis><literal>SCHEMA_NAME</literal> "
 
-#. Tag: property
-#: configuration.xml:417
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_catalog"
-msgstr "hibernate.default_catalog"
+msgid "<property>hibernate.default_catalog</property>"
+msgstr "<property>hibernate.default_catalog</property>"
 
 #. Tag: entry
-#: configuration.xml:419
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Qualifies unqualified table names with the given catalog in generated SQL."
-msgstr ""
-"在生成的SQL中, 将给定的catalog附加于非全限定名的表名上. <placeholder-1/>"
+msgstr "在生成的 SQL 中,将给定的 catalog 附加于非全限定名的表名上。 "
 
 #. Tag: para
-#: configuration.xml:422
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>CATALOG_NAME</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例如:</emphasis><literal>CATALOG_NAME</literal> "
 
-#. Tag: property
-#: configuration.xml:430
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.session_factory_name"
-msgstr "hibernate.session_factory_name"
+msgid "<property>hibernate.session_factory_name</property>"
+msgstr "<property>hibernate.session_factory_name</property>"
 
 #. Tag: entry
-#: configuration.xml:432
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <interfacename>org.hibernate.SessionFactory</interfacename> will be "
 "automatically bound to this name in JNDI after it has been created."
 msgstr ""
-"<placeholder-1/>创建后,将自动使用这个名字绑定到JNDI中. <placeholder-2/>"
+"<interfacename>org.hibernate.SessionFactory</interfacename> 创建后,将自动使"
+"用这个名字绑定到 JNDI 中。"
 
 #. Tag: para
-#: configuration.xml:435 configuration.xml:877
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>jndi/composite/name</"
 "literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例如:</emphasis><literal>jndi/composite/name</"
+"literal> "
 
-#. Tag: property
-#: configuration.xml:443
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.max_fetch_depth"
-msgstr "hibernate.max_fetch_depth"
+msgid "<property>hibernate.max_fetch_depth</property>"
+msgstr "<property>hibernate.max_fetch_depth</property>"
 
 #. Tag: entry
-#: configuration.xml:445
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sets a maximum \"depth\" for the outer join fetch tree for single-ended "
 "associations (one-to-one, many-to-one). A <literal>0</literal> disables "
 "default outer join fetching."
 msgstr ""
-"为单向关联(一对一, 多对一)的外连接抓取(outer join fetch)树设置最大深度. 值"
-"为<placeholder-1/>意味着将关闭默认的外连接抓取. <placeholder-2/>"
+"为单向关联(一对一,多对一)的外连接抓取(outer join fetch)树设置最大深度。"
+"值为 <literal>0</literal> 意味着将关闭默认的外连接抓取。 "
 
 #. Tag: para
-#: configuration.xml:449
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values between "
 "<literal>0</literal> and <literal>3</literal>"
 msgstr ""
-"<emphasis role=\"strong\">取值</emphasis> 建议在<literal>0</literal>到"
-"<literal>3</literal>之间取值"
+"<emphasis role=\"strong\">例如:</emphasis> 建议在 <literal>0</literal> 到 "
+"<literal>3</literal> 之间取值 "
 
-#. Tag: property
-#: configuration.xml:458
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_batch_fetch_size"
-msgstr "hibernate.default_batch_fetch_size"
+msgid "<property>hibernate.default_batch_fetch_size</property>"
+msgstr "<property>hibernate.default_batch_fetch_size</property>"
 
 #. Tag: entry
-#: configuration.xml:460
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Sets a default size for Hibernate batch fetching of associations."
-msgstr "为Hibernate关联的批量抓取设置默认数量. <placeholder-1/>"
+msgstr "为 Hibernate 关联的批量抓取设置默认数量。 "
 
 #. Tag: para
-#: configuration.xml:462
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values <literal>4</"
 "literal>, <literal>8</literal>, <literal>16</literal>"
 msgstr ""
-"<emphasis role=\"strong\">取值</emphasis> 建议的取值为<literal>4</literal>, "
-"<literal>8</literal>, 和<literal>16</literal>"
+"<emphasis role=\"strong\">例如:</emphasis>建议的取值为 <literal>4</"
+"literal>,<literal>8</literal>,和 <literal>16</literal> "
 
-#. Tag: property
-#: configuration.xml:471
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.default_entity_mode"
-msgstr "hibernate.default_entity_mode"
+msgid "<property>hibernate.default_entity_mode</property>"
+msgstr "<property>hibernate.default_entity_mode</property>"
 
 #. Tag: entry
-#: configuration.xml:473
 #, fuzzy, no-c-format
 msgid ""
 "Sets a default mode for entity representation for all sessions opened from "
 "this <literal>SessionFactory</literal>"
 msgstr ""
-"为由这个<placeholder-1/>打开的所有Session指定默认的实体表现模式. "
-"<placeholder-2/>"
+"为由这个 <literal>SessionFactory</literal> 打开的所有 Session 指定默认的实体"
+"表现模式。  "
 
 #. Tag: para
-#: configuration.xml:476
 #, no-c-format
 msgid ""
 "<literal>dynamic-map</literal>, <literal>dom4j</literal>, <literal>pojo</"
 "literal>"
 msgstr ""
-"<emphasis role=\"strong\">取值</emphasis><literal>dynamic-map</literal>, "
-"<literal>dom4j</literal>, <literal>pojo</literal>"
+"<emphasis role=\"strong\">取值</emphasis><literal>dynamic-map</literal>,"
+"<literal>dom4j</literal>,<literal>pojo</literal>"
 
-#. Tag: property
-#: configuration.xml:484
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.order_updates"
-msgstr "hibernate.order_updates"
+msgid "<property>hibernate.order_updates</property>"
+msgstr "<property>hibernate.order_updates</property>"
 
 #. Tag: entry
-#: configuration.xml:486
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Forces Hibernate to order SQL updates by the primary key value of the items "
 "being updated. This will result in fewer transaction deadlocks in highly "
 "concurrent systems."
 msgstr ""
-"强制Hibernate按照被更新数据的主键,为SQL更新排序。这么做将减少在高并发系统中"
-"事务的死锁。 <placeholder-1/>"
+"强制 Hibernate 按照被更新数据的主键,为 SQL 更新排序。这么做将减少在高并发系"
+"统中事务的死锁。"
 
-#. Tag: property
-#: configuration.xml:498
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.generate_statistics"
-msgstr "hibernate.generate_statistics"
+msgid "<property>hibernate.generate_statistics</property>"
+msgstr "<property>hibernate.generate_statistics</property>"
 
 #. Tag: entry
-#: configuration.xml:500
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If enabled, Hibernate will collect statistics useful for performance tuning."
-msgstr "如果开启, Hibernate将收集有助于性能调节的统计数据. <placeholder-1/>"
+msgstr "如果开启,Hibernate 将收集有助于性能调节的统计数据。"
 
-#. Tag: property
-#: configuration.xml:511
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.use_identifier_rollback"
-msgstr "hibernate.use_identifer_rollback"
+msgid "<property>hibernate.use_identifier_rollback</property>"
+msgstr "<property>hibernate.use_identifier_rollback</property>"
 
 #. Tag: entry
-#: configuration.xml:513
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If enabled, generated identifier properties will be reset to default values "
 "when objects are deleted."
-msgstr ""
-"如果开启, 在对象被删除时生成的标识属性将被重设为默认值. <placeholder-1/>"
+msgstr "如果开启,在对象被删除时生成的标识属性将被重设为默认值。"
 
-#. Tag: property
-#: configuration.xml:524
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.use_sql_comments"
-msgstr "hibernate.use_sql_comments"
+msgid "<property>hibernate.use_sql_comments</property>"
+msgstr "<property>hibernate.use_sql_comments</property>"
 
 #. Tag: entry
-#: configuration.xml:526
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If turned on, Hibernate will generate comments inside the SQL, for easier "
 "debugging, defaults to <literal>false</literal>."
 msgstr ""
-"如果开启, Hibernate将在SQL中生成有助于调试的注释信息, 默认值为<placeholder-1/"
-">. <placeholder-2/>"
+"如果开启,Hibernate 将在 SQL 中生成有助于调试的注释信息,默认值为 "
+"<literal>false</literal>。"
 
 #. Tag: title
-#: configuration.xml:540
 #, no-c-format
 msgid "Hibernate JDBC and Connection Properties"
-msgstr "Hibernate JDBC和连接(connection)属性"
+msgstr "Hibernate JDBC 和连接(connection)属性"
 
-#. Tag: property
-#: configuration.xml:555
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.fetch_size"
-msgstr "hibernate.jdbc.fetch_size"
+msgid "<property>hibernate.jdbc.fetch_size</property>"
+msgstr "<property>hibernate.jdbc.fetch_size</property>"
 
 #. Tag: entry
-#: configuration.xml:557
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A non-zero value determines the JDBC fetch size (calls <literal>Statement."
 "setFetchSize()</literal>)."
-msgstr "非零值,指定JDBC抓取数量的大小 (调用<placeholder-1/>)."
+msgstr ""
+"非零值,指定 JDBC 抓取数量的大小(调用 <literal>Statement.setFetchSize()</"
+"literal>)。"
 
-#. Tag: property
-#: configuration.xml:564
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.batch_size"
-msgstr "hibernate.jdbc.batch_size"
+msgid "<property>hibernate.jdbc.batch_size</property>"
+msgstr "<property>hibernate.jdbc.batch_size</property>"
 
 #. Tag: entry
-#: configuration.xml:566
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A non-zero value enables use of JDBC2 batch updates by Hibernate."
-msgstr "非零值,允许Hibernate使用JDBC2的批量更新. <placeholder-1/>"
+msgstr "非零值,允许 Hibernate 使用 JDBC2 的批量更新。"
 
 #. Tag: para
-#: configuration.xml:568
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> recommended values between "
 "<literal>5</literal> and <literal>30</literal>"
 msgstr ""
-"<emphasis role=\"strong\">取值</emphasis> 建议取<literal>5</literal>到"
-"<literal>30</literal>之间的值"
+"<emphasis role=\"strong\">例如:</emphasis>建议取 <literal>5</literal> 到 "
+"<literal>30</literal> 之间的值 "
 
-#. Tag: property
-#: configuration.xml:576
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.batch_versioned_data"
-msgstr "hibernate.jdbc.batch_versioned_data"
+msgid "<property>hibernate.jdbc.batch_versioned_data</property>"
+msgstr "<property>hibernate.jdbc.batch_versioned_data</property>"
 
 #. Tag: entry
-#: configuration.xml:578
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Set this property to <literal>true</literal> if your JDBC driver returns "
 "correct row counts from <literal>executeBatch()</literal>. Iit is usually "
 "safe to turn this option on. Hibernate will then use batched DML for "
 "automatically versioned data. Defaults to <literal>false</literal>."
 msgstr ""
-"如果你想让你的JDBC驱动从<placeholder-1/>返回正确的行计数 , 那么将此属性设为"
-"<placeholder-2/>(开启这个选项通常是安全的). 同时,Hibernate将为自动版本化的数"
-"据使用批量DML. 默认值为<placeholder-3/>. <placeholder-4/>"
+"如果你想让你的 JDBC 驱动从 <literal>true</literal> 返回正确的行计数 ,那么将"
+"此属性设为 <literal>executeBatch()</literal>(开启这个选项通常是安全的)。同"
+"时,Hibernate 将为自动版本化的数据使用批量 DML。默认值为 <literal>false</"
+"literal>。 "
 
-#. Tag: property
-#: configuration.xml:591
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.factory_class"
-msgstr "hibernate.jdbc.factory_class"
+msgid "<property>hibernate.jdbc.factory_class</property>"
+msgstr "<property>hibernate.jdbc.factory_class</property>"
 
 #. Tag: entry
-#: configuration.xml:593
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Select a custom <interfacename>org.hibernate.jdbc.Batcher</interfacename>. "
 "Most applications will not need this configuration property."
 msgstr ""
-"选择一个自定义的<placeholder-1/>. 多数应用程序不需要这个配置属性. "
-"<placeholder-2/>"
+"选择一个自定义的 <literal>Batcher</literal>。多数应用程序不需要这个配置属"
+"性。 "
 
 #. Tag: para
-#: configuration.xml:596
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "BatcherFactory</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例如:</emphasis><literal>classname.of.Batcher</"
+"literal> "
 
-#. Tag: property
-#: configuration.xml:604
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_scrollable_resultset"
-msgstr "hibernate.jdbc.use_scrollable_resultset"
+msgid "<property>hibernate.jdbc.use_scrollable_resultset</property>"
+msgstr "<property>hibernate.jdbc.use_scrollable_resultset</property>"
 
 #. Tag: entry
-#: configuration.xml:606
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Enables use of JDBC2 scrollable resultsets by Hibernate. This property is "
 "only necessary when using user-supplied JDBC connections. Hibernate uses "
 "connection metadata otherwise."
 msgstr ""
-"允许Hibernate使用JDBC2的可滚动结果集. 只有在使用用户提供的JDBC连接时,这个选"
-"项才是必要的, 否则Hibernate会使用连接的元数据. <placeholder-1/>"
+"允许 Hibernate 使用 JDBC2 的可滚动结果集。只有在使用用户提供的 JDBC 连接时,"
+"这个选项才是必要的,否则 Hibernate 会使用连接的元数据。 "
 
-#. Tag: property
-#: configuration.xml:618
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_streams_for_binary"
-msgstr "hibernate.jdbc.use_streams_for_binary"
+msgid "<property>hibernate.jdbc.use_streams_for_binary</property>"
+msgstr "<property>hibernate.jdbc.use_streams_for_binary</property>"
 
 #. Tag: entry
-#: configuration.xml:620
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use streams when writing/reading <literal>binary</literal> or "
 "<literal>serializable</literal> types to/from JDBC. <emphasis>*system-level "
 "property*</emphasis>"
 msgstr ""
-"在JDBC读写<placeholder-1/>或<placeholder-2/> 的类型时使用流(stream)(系统级属"
-"性). <placeholder-3/>"
+"在 JDBC 读写 <literal>binary</literal> 或 <literal>serializable</literal> 的"
+"类型时使用流(stream)(系统级属性)。 "
 
-#. Tag: property
-#: configuration.xml:631
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.jdbc.use_get_generated_keys"
-msgstr "hibernate.jdbc.use_get_generated_keys"
+msgid "<property>hibernate.jdbc.use_get_generated_keys</property>"
+msgstr "<property>hibernate.jdbc.use_get_generated_keys</property>"
 
 #. Tag: entry
-#: configuration.xml:633
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Enables use of JDBC3 <literal>PreparedStatement.getGeneratedKeys()</literal> "
 "to retrieve natively generated keys after insert. Requires JDBC3+ driver and "
@@ -1243,206 +848,80 @@
 "identifier generators. By default, it tries to determine the driver "
 "capabilities using connection metadata."
 msgstr ""
-"在数据插入数据库之后,允许使用JDBC3 <placeholder-1/> 来获取数据库生成的key"
-"(键)。需要JDBC3+驱动和JRE1.4+, 如果你的数据库驱动在使用Hibernate的标 识生成器"
-"时遇到问题,请将此值设为false. 默认情况下将使用连接的元数据来判定驱动的能力. "
-"<placeholder-2/>"
+"在数据插入数据库之后,允许使用 JDBC3 <literal>PreparedStatement."
+"getGeneratedKeys()</literal> 来获取数据库生成的 key(键)。需要 JDBC3+ 驱动"
+"和 JRE1.4+,如果你的数据库驱动在使用 Hibernate 的标识生成器时遇到问题,请将此"
+"值设为 false。默认情况下将使用连接的元数据来判定驱动的能力。 "
 
 #. Tag: para
-#: configuration.xml:639 configuration.xml:769 configuration.xml:781
-#: configuration.xml:795 configuration.xml:833
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>true|false</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例如:</emphasis><literal>true | false</literal> "
 
-#. Tag: property
-#: configuration.xml:647
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.provider_class"
-msgstr "hibernate.connection.provider_class"
+msgid "<property>hibernate.connection.provider_class</property>"
+msgstr "<property>hibernate.connection.provider_class</property>"
 
 #. Tag: entry
-#: configuration.xml:649
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a custom <interfacename>org.hibernate.connection."
 "ConnectionProvider</interfacename> which provides JDBC connections to "
 "Hibernate."
 msgstr ""
-"自定义<placeholder-1/>的类名, 此类用来向Hibernate提供JDBC连接. <placeholder-"
-"2/>"
+"自定义 <literal>ConnectionProvider</literal> 的类名,此类用来向 Hibernate 提"
+"供 JDBC 连接。 "
 
 #. Tag: para
-#: configuration.xml:652
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "ConnectionProvider</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例如:</emphasis><literal>classname.of."
+"ConnectionProvider</literal> "
 
-#. Tag: property
-#: configuration.xml:660
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.isolation"
-msgstr "hibernate.connection.isolation"
+msgid "<property>hibernate.connection.isolation</property>"
+msgstr "<property>hibernate.connection.isolation</property>"
 
 #. Tag: entry
-#: configuration.xml:662
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sets the JDBC transaction isolation level. Check <interfacename>java.sql."
 "Connection</interfacename> for meaningful values, but note that most "
 "databases do not support all isolation levels and some define additional, "
 "non-standard isolations."
 msgstr ""
-"设置JDBC事务隔离级别. 查看<placeholder-1/>来了解各个值的具体意义, 但请注意多"
-"数数据库都不支持所有的隔离级别. <placeholder-2/>"
+"设置 JDBC 事务隔离级别。查看 <literal>java.sql.Connection</literal> 来了解各"
+"个值的具体意义,但请注意多数数据库都不支持所有的隔离级别。 "
 
 #. Tag: para
-#: configuration.xml:666
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>1, 2, 4, 8</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例如:</emphasis><literal>1, 2, 4, 8</literal> "
 
-#. Tag: property
-#: configuration.xml:674
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.autocommit"
-msgstr "hibernate.connection.autocommit"
+msgid "<property>hibernate.connection.autocommit</property>"
+msgstr "<property>hibernate.connection.autocommit</property>"
 
 #. Tag: entry
-#: configuration.xml:676
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Enables autocommit for JDBC pooled connections (it is not recommended)."
-msgstr ""
-"允许被缓存的JDBC连接开启自动提交(autocommit) (不建议). <placeholder-1/>"
+msgstr "允许被缓存的 JDBC 连接开启自动提交(autocommit)(不推荐)。"
 
-#. Tag: property
-#: configuration.xml:686
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.release_mode"
-msgstr "hibernate.connection.release_mode"
+msgid "<property>hibernate.connection.release_mode</property>"
+msgstr "<property>hibernate.connection.release_mode</property>"
 
 #. Tag: entry
-#: configuration.xml:688
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Specifies when Hibernate should release JDBC connections. By default, a JDBC "
 "connection is held until the session is explicitly closed or disconnected. "
@@ -1454,693 +933,421 @@
 "the JTA and CMT transaction strategies and <literal>after_transaction</"
 "literal> for the JDBC transaction strategy."
 msgstr ""
-"指定Hibernate在何时释放JDBC连接. 默认情况下,直到Session被显式关闭或被断开连接"
-"时,才会释放JDBC连接. 对于应用程序服务器的JTA数据源, 你应当使用<placeholder-1/"
-">, 这样在每次JDBC调用后,都会主动的释放连接. 对于非JTA的连接, 使用"
-"<placeholder-2/>在每个事务结束时释放连接是合理的. <placeholder-3/>将为JTA和"
-"CMT事务策略选择<placeholder-4/>, 为JDBC事务策略选择<placeholder-5/>. "
-"<placeholder-6/><placeholder-7/>"
+"指定 Hibernate 在何时释放 JDBC 连接。默认情况下,直到 Session 被显式关闭或被断"
+"开连接时,才会释放 JDBC 连接。对于应用程序服务器的 JTA 数据源,你应当使用  "
+"<literal>after_statement</literal>,这样在每次 JDBC 调用后,都会主动的释放连"
+"接。对于非 JTA 的连接,使用 <literal>after_transaction</literal> 在每个事务结"
+"束时释放连接是合理的。<literal>auto</literal> 将为 JTA 和 CMT 事务策略选择 "
+"<literal>after_statement</literal>,为JDBC事务策略选择 "
+"<literal>after_transaction</literal>。"
 
 #. Tag: para
-#: configuration.xml:699
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>auto</literal> (default) "
 "| <literal>on_close</literal> | <literal>after_transaction</literal> | "
 "<literal>after_statement</literal>"
 msgstr ""
-"<emphasis role=\"strong\">取值</emphasis><literal>auto</literal> (默认) | "
+"<emphasis role=\"strong\">例如:</emphasis><literal>auto</literal> (默认) | "
 "<literal>on_close</literal> | <literal>after_transaction</literal> | "
-"<literal>after_statement</literal>"
+"<literal>after_statement</literal> "
 
 #. Tag: para
-#: configuration.xml:704
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This setting only affects <literal>Session</literal>s returned from "
 "<literal>SessionFactory.openSession</literal>. For <literal>Session</"
 "literal>s obtained through <literal>SessionFactory.getCurrentSession</"
 "literal>, the <literal>CurrentSessionContext</literal> implementation "
 "configured for use controls the connection release mode for those "
-"<literal>Session</literal>s. See"
+"<literal>Session</literal>s. See <xref linkend=\"architecture-current-session"
+"\" />"
 msgstr ""
-"注意,这些设置仅对通过<literal>SessionFactory.openSession</literal>得到的"
-"<literal>Session</literal>起作用。对于通过<literal>SessionFactory."
-"getCurrentSession</literal>得到的<literal>Session</literal>,所配置的"
-"<literal>CurrentSessionContext</literal>实现控制这些<literal>Session</"
-"literal>的连接释放模式。请参阅<xref linkend=\"architecture-current-session\"/"
-">。"
+"注意,这些设置仅对通过 <literal>SessionFactory.openSession</literal> 得到的 "
+"<literal>Session</literal> 起作用。对于通过 <literal>SessionFactory."
+"getCurrentSession</literal> 得到的 <literal>Session</literal>,所配置的 "
+"<literal>CurrentSessionContext</literal> 实现控制这些 <literal>Session</"
+"literal> 的连接释放模式。请参阅 <xref linkend=\"architecture-current-session"
+"\" />。"
 
 #. Tag: entry
-#: configuration.xml:715
 #, no-c-format
 msgid ""
 "<property>hibernate.connection.</property><emphasis>&lt;propertyName&gt;</"
 "emphasis>"
 msgstr ""
+"<property>hibernate.connection.</property><emphasis>&lt;propertyName&gt;</"
+"emphasis>"
 
 #. Tag: entry
-#: configuration.xml:718
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Pass the JDBC property <emphasis>&lt;propertyName&gt;</emphasis> to "
 "<literal>DriverManager.getConnection()</literal>."
 msgstr ""
-"传一个<literal>java.util.Properties</literal>实例给 <literal>Configuration."
-"setProperties()</literal>."
+"把 JDBC 属性 <emphasis>&lt;propertyName&gt;</emphasis> 传递给 "
+"<literal>DriverManager.getConnection()</literal>。"
 
 #. Tag: entry
-#: configuration.xml:724
 #, no-c-format
 msgid ""
 "<property>hibernate.jndi.</property><emphasis>&lt;propertyName&gt;</emphasis>"
 msgstr ""
+"<property>hibernate.jndi.</property><emphasis>&lt;propertyName&gt;</emphasis>"
 
 #. Tag: entry
-#: configuration.xml:727
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Pass the property <emphasis>&lt;propertyName&gt;</emphasis> to the JNDI "
 "<literal>InitialContextFactory</literal>."
 msgstr ""
-"传一个<literal>java.util.Properties</literal>实例给 <literal>Configuration."
-"setProperties()</literal>."
+"把 <emphasis>&lt;propertyName&gt;</emphasis> 属性传递给 JNDI "
+"<literal>InitialContextFactory</literal>。"
 
 #. Tag: title
-#: configuration.xml:737
 #, no-c-format
 msgid "Hibernate Cache Properties"
-msgstr "Hibernate缓存属性"
+msgstr "Hibernate 缓存属性"
 
-#. Tag: literal
-#: configuration.xml:750
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.provider_class"
-msgstr "hibernate.cache.provider_class"
+msgid "<literal>hibernate.cache.provider_class</literal>"
+msgstr "<literal>hibernate.cache.provider_class</literal>"
 
 #. Tag: entry
-#: configuration.xml:752
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The classname of a custom <literal>CacheProvider</literal>."
-msgstr "自定义的<placeholder-1/>的类名. <placeholder-2/>"
+msgstr "自定义的 <literal>CacheProvider</literal> 的类名。"
 
 #. Tag: para
-#: configuration.xml:754
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "CacheProvider</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例如:</emphasis><literal>classname.of."
+"CacheProvider</literal> "
 
-#. Tag: literal
-#: configuration.xml:762
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_minimal_puts"
-msgstr "hibernate.cache.use_minimal_puts"
+msgid "<literal>hibernate.cache.use_minimal_puts</literal>"
+msgstr "<literal>hibernate.cache.use_minimal_puts</literal>"
 
 #. Tag: entry
-#: configuration.xml:764
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Optimizes second-level cache operation to minimize writes, at the cost of "
 "more frequent reads. This setting is most useful for clustered caches and, "
 "in Hibernate3, is enabled by default for clustered cache implementations."
 msgstr ""
-"以频繁的读操作为代价, 优化二级缓存来最小化写操作. 在Hibernate3中,这个设置对"
-"的集群缓存非常有用, 对集群缓存的实现而言,默认是开启的. <placeholder-1/>"
+"以频繁的读操作为代价,优化二级缓存来最小化写操作。在 Hibernate3 中,这个设置"
+"对的集群缓存非常有用,对集群缓存的实现而言,默认是开启的。 "
 
-#. Tag: literal
-#: configuration.xml:777
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_query_cache"
-msgstr "hibernate.cache.use_query_cache"
+msgid "<literal>hibernate.cache.use_query_cache</literal>"
+msgstr "<literal>hibernate.cache.use_query_cache</literal>"
 
 #. Tag: entry
-#: configuration.xml:779
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Enables the query cache. Individual queries still have to be set cachable."
-msgstr "允许查询缓存, 个别查询仍然需要被设置为可缓存的. <placeholder-1/>"
+msgstr "允许查询缓存,个别查询仍然需要被设置为可缓存的。 "
 
-#. Tag: literal
-#: configuration.xml:789
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_second_level_cache"
-msgstr "hibernate.cache.use_second_level_cache"
+msgid "<literal>hibernate.cache.use_second_level_cache</literal>"
+msgstr "<literal>hibernate.cache.use_second_level_cache</literal>"
 
 #. Tag: entry
-#: configuration.xml:791
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Can be used to completely disable the second level cache, which is enabled "
 "by default for classes which specify a <literal>&lt;cache&gt;</literal> "
 "mapping."
 msgstr ""
-"能用来完全禁止使用二级缓存. 对那些在类的映射定义中指定<placeholder-1/>的类,"
-"会默认开启二级缓存. <placeholder-2/>"
+"能用来完全禁止使用二级缓存。对那些在类的映射定义中指定 <literal>&lt;cache&gt;"
+"</literal> 的类,会默认开启二级缓存。 "
 
-#. Tag: literal
-#: configuration.xml:803
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.query_cache_factory"
-msgstr "hibernate.cache.query_cache_factory"
+msgid "<literal>hibernate.cache.query_cache_factory</literal>"
+msgstr "<literal>hibernate.cache.query_cache_factory</literal>"
 
 #. Tag: entry
-#: configuration.xml:805
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a custom <literal>QueryCache</literal> interface, defaults "
 "to the built-in <literal>StandardQueryCache</literal>."
 msgstr ""
-"自定义实现<placeholder-1/>接口的类名, 默认为内建的<placeholder-2/>. "
-"<placeholder-3/>"
+"自定义实现 <literal>QueryCache</literal> 接口的类名,默认为内建的 "
+"<literal>StandardQueryCache</literal>。"
 
 #. Tag: para
-#: configuration.xml:808
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of.QueryCache</"
 "literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例如:</emphasis><literal>classname.of.QueryCache</"
+"literal> "
 
-#. Tag: literal
-#: configuration.xml:816
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.region_prefix"
-msgstr "hibernate.cache.region_prefix"
+msgid "<literal>hibernate.cache.region_prefix</literal>"
+msgstr "<literal>hibernate.cache.region_prefix</literal>"
 
 #. Tag: entry
-#: configuration.xml:818
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A prefix to use for second-level cache region names."
-msgstr "二级缓存区域名的前缀. <placeholder-1/>"
+msgstr "二级缓存区域名的前缀。"
 
 #. Tag: para
-#: configuration.xml:820
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<emphasis role=\"strong\">e.g.</emphasis> <literal>prefix</literal>"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+msgstr "<emphasis role=\"strong\">例如:</emphasis><literal>prefix</literal> "
 
-#. Tag: literal
-#: configuration.xml:828
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.cache.use_structured_entries"
-msgstr "hibernate.cache.use_structured_entries"
+msgid "<literal>hibernate.cache.use_structured_entries</literal>"
+msgstr "<literal>hibernate.cache.use_structured_entries</literal>"
 
 #. Tag: entry
-#: configuration.xml:830
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Forces Hibernate to store data in the second-level cache in a more human-"
 "friendly format."
-msgstr "强制Hibernate以更人性化的格式将数据存入二级缓存. <placeholder-1/>"
+msgstr "强制 Hibernate 以更人性化的格式将数据存入二级缓存。"
 
 #. Tag: title
-#: configuration.xml:844
 #, no-c-format
 msgid "Hibernate Transaction Properties"
-msgstr "Hibernate事务属性"
+msgstr "Hibernate 事务属性"
 
-#. Tag: literal
-#: configuration.xml:857
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.transaction.factory_class"
-msgstr "hibernate.transaction.factory_class"
+msgid "<literal>hibernate.transaction.factory_class</literal>"
+msgstr "<literal>hibernate.transaction.factory_class</literal>"
 
 #. Tag: entry
-#: configuration.xml:859
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The classname of a <literal>TransactionFactory</literal> to use with "
 "Hibernate <literal>Transaction</literal> API (defaults to "
 "<literal>JDBCTransactionFactory</literal>)."
 msgstr ""
-"一个<placeholder-1/>的类名, 用于Hibernate <placeholder-2/> API (默认为"
-"<placeholder-3/>). <placeholder-4/>"
+"一个 <literal>TransactionFactory</literal> 的类名,用于 Hibernate "
+"<literal>Transaction</literal> API(默认为 <literal>JDBCTransactionFactory</"
+"literal>)。"
 
 #. Tag: para
-#: configuration.xml:863
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "TransactionFactory</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例如:</emphasis><literal>classname.of."
+"TransactionFactory</literal> "
 
-#. Tag: literal
-#: configuration.xml:871
+#. Tag: entry
 #, no-c-format
-msgid "jta.UserTransaction"
-msgstr "jta.UserTransaction"
+msgid "<literal>jta.UserTransaction</literal>"
+msgstr "<literal>jta.UserTransaction</literal>"
 
 #. Tag: entry
-#: configuration.xml:873
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A JNDI name used by <literal>JTATransactionFactory</literal> to obtain the "
 "JTA <literal>UserTransaction</literal> from the application server."
 msgstr ""
-"一个JNDI名字,被<placeholder-1/>用来从应用服务器获取JTA <placeholder-2/>. "
-"<placeholder-3/>"
+"一个 JNDI 名字,被 <literal>JTATransactionFactory</literal> 用来从应用服务器"
+"获取 JTA   <literal>UserTransaction</literal>。"
 
-#. Tag: literal
-#: configuration.xml:885
-#, no-c-format
-msgid "hibernate.transaction.manager_lookup_class"
-msgstr "hibernate.transaction.manager_lookup_class"
-
 #. Tag: entry
-#: configuration.xml:887
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.manager_lookup_class</literal>"
+msgstr "<literal>hibernate.transaction. manager_lookup_class</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "The classname of a <literal>TransactionManagerLookup</literal>. It is "
 "required when JVM-level caching is enabled or when using hilo generator in a "
 "JTA environment."
 msgstr ""
-"一个<placeholder-1/>的类名 - 当使用JVM级缓存,或在JTA环境中使用hilo生成器的时"
-"候需要该类. <placeholder-2/>"
+"一个 <literal>TransactionManagerLookup</literal> 的类名 — 当使用 JVM 级缓存,"
+"或在 JTA 环境中使用 hilo 生成器的时候需要该类。 "
 
 #. Tag: para
-#: configuration.xml:891
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>classname.of."
 "TransactionManagerLookup</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例如:</emphasis><literal>classname.of."
+"TransactionManagerLookup</literal> "
 
-#. Tag: literal
-#: configuration.xml:899
-#, no-c-format
-msgid "hibernate.transaction.flush_before_completion"
-msgstr "hibernate.transaction.flush_before_completion"
-
 #. Tag: entry
-#: configuration.xml:901
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.flush_before_completion</literal>"
+msgstr "<literal>hibernate.transaction. flush_before_completion</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "If enabled, the session will be automatically flushed during the before "
 "completion phase of the transaction. Built-in and automatic session context "
-"management is preferred, see <xref linkend=\"architecture-current-session\"/"
+"management is preferred, see <xref linkend=\"architecture-current-session\" /"
 ">."
 msgstr ""
-"如果开启, session在事务完成后将被自动清洗(flush)。 现在更好的方法是使用自动"
-"session上下文管理。请参见<xref linkend=\"architecture-current-session\"/>。 "
-"<placeholder-1/>"
+"如果开启,session 在事务完成后将被自动清洗(flush)。现在更好的方法是使用自"
+"动 session 上下文管理。请参见 <xref linkend=\"architecture-current-session\"/"
+">。 "
 
-#. Tag: literal
-#: configuration.xml:914
-#, no-c-format
-msgid "hibernate.transaction.auto_close_session"
-msgstr "hibernate.transaction.auto_close_session"
-
 #. Tag: entry
-#: configuration.xml:916
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.transaction.auto_close_session</literal>"
+msgstr "<literal>hibernate.transaction. auto_close_session</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "If enabled, the session will be automatically closed during the after "
 "completion phase of the transaction. Built-in and automatic session context "
-"management is preferred, see <xref linkend=\"architecture-current-session\"/"
+"management is preferred, see <xref linkend=\"architecture-current-session\" /"
 ">."
 msgstr ""
-"如果开启, session在事务完成后将被自动关闭。 现在更好的方法是使用自动session上"
-"下文管理。请参见<xref linkend=\"architecture-current-session\"/>。 "
-"<placeholder-1/>"
+"如果开启,session 在事务完成后将被自动关闭。 现在更好的方法是使用自动 "
+"session 上下文管理。请参见 <xref linkend=\"architecture-current-session\"/"
+">。  "
 
 #. Tag: title
-#: configuration.xml:932
 #, no-c-format
 msgid "Miscellaneous Properties"
 msgstr "其他属性"
 
-#. Tag: literal
-#: configuration.xml:945
-#, no-c-format
-msgid "hibernate.current_session_context_class"
-msgstr "hibernate.current_session_context_class"
-
 #. Tag: entry
-#: configuration.xml:947
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.current_session_context_class</literal>"
+msgstr "<literal>hibernate. current_session_context_class</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "Supply a custom strategy for the scoping of the \"current\" "
 "<literal>Session</literal>. See <xref linkend=\"architecture-current-session"
-"\"/> for more information about the built-in strategies."
+"\" /> for more information about the built-in strategies."
 msgstr ""
-"为\"当前\" <placeholder-1/>指定一个(自定义的)策略。关于内置策略的详情,请参见"
-"<xref linkend=\"architecture-current-session\"/> 。 <placeholder-2/>"
+"为\"当前\" <literal>Session</literal> 指定一个(自定义的)策略。关于内置策略"
+"的详情,请参见 <xref linkend=\"architecture-current-session\"/>。 "
 
 #. Tag: para
-#: configuration.xml:952
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>jta</literal> | "
 "<literal>thread</literal> | <literal>managed</literal> | <literal>custom."
 "Class</literal>"
 msgstr ""
-"<emphasis role=\"strong\">eg.</emphasis><literal>jta</literal> | "
+"<emphasis role=\"strong\">例如:</emphasis><literal>jta</literal> | "
 "<literal>thread</literal> | <literal>managed</literal> | <literal>custom."
-"Class</literal>"
+"Class</literal> "
 
-#. Tag: literal
-#: configuration.xml:961
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.query.factory_class"
-msgstr "hibernate.query.factory_class"
+msgid "<literal>hibernate.query.factory_class</literal>"
+msgstr "<literal>hibernate.query.factory_class</literal>"
 
 #. Tag: entry
-#: configuration.xml:963
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Chooses the HQL parser implementation."
-msgstr "选择HQL解析器的实现. <placeholder-1/>"
+msgstr "选择 HQL 解析器的实现。"
 
 #. Tag: para
-#: configuration.xml:965
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>org.hibernate.hql.ast."
 "ASTQueryTranslatorFactory</literal> or <literal>org.hibernate.hql.classic."
 "ClassicQueryTranslatorFactory</literal>"
 msgstr ""
-"<emphasis role=\"strong\">取值</emphasis><literal>org.hibernate.hql.ast."
-"ASTQueryTranslatorFactory</literal> or <literal>org.hibernate.hql.classic."
-"ClassicQueryTranslatorFactory</literal>"
+"<emphasis role=\"strong\">例如:</emphasis><literal>org.hibernate.hql.ast."
+"ASTQueryTranslatorFactory</literal> 或 <literal>org.hibernate.hql.classic."
+"ClassicQueryTranslatorFactory</literal> "
 
-#. Tag: literal
-#: configuration.xml:974
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.query.substitutions"
-msgstr "hibernate.query.substitutions"
+msgid "<literal>hibernate.query.substitutions</literal>"
+msgstr "<literal>hibernate.query.substitutions</literal>"
 
 #. Tag: entry
-#: configuration.xml:976
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Is used to map from tokens in Hibernate queries to SQL tokens (tokens might "
 "be function or literal names, for example)."
 msgstr ""
-"将Hibernate查询中的符号映射到SQL查询中的符号 (符号可能是函数名或常量名字). "
-"<placeholder-1/>"
+"将 Hibernate 查询中的符号映射到 SQL 查询中的符号(符号可能是函数名或常量名"
+"字)。  "
 
 #. Tag: para
-#: configuration.xml:979
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>hqlLiteral=SQL_LITERAL, "
 "hqlFunction=SQLFUNC</literal>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">eg.</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"<emphasis role=\"strong\">取值</emphasis><literal>true</literal> | "
-"<literal>false</literal>"
+"<emphasis role=\"strong\">例如:</emphasis><literal>hqlLiteral=SQL_LITERAL, "
+"hqlFunction=SQLFUNC</literal> "
 
-#. Tag: literal
-#: configuration.xml:987
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.hbm2ddl.auto"
-msgstr "hibernate.hbm2ddl.auto"
+msgid "<literal>hibernate.hbm2ddl.auto</literal>"
+msgstr "<literal>hibernate.hbm2ddl.auto</literal>"
 
 #. Tag: entry
-#: configuration.xml:989
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Automatically validates or exports schema DDL to the database when the "
 "<literal>SessionFactory</literal> is created. With <literal>create-drop</"
 "literal>, the database schema will be dropped when the "
 "<literal>SessionFactory</literal> is closed explicitly."
 msgstr ""
-"在<placeholder-1/>创建时,自动检查数据库结构,或者将数据库schema的DDL导出到数"
-"据库. 使用 <placeholder-2/>时,在显式关闭<placeholder-3/>时,将drop掉数据库"
-"schema. <placeholder-4/>"
+"在 <literal>SessionFactory</literal> 创建时,自动检查数据库结构,或者将数据"
+"库 schema 的 DDL 导出到数据库。使用 <literal>create-drop</literal> 时,在显式"
+"关闭 <literal>SessionFactory</literal> 时,将删除掉数据库 schema。 "
 
 #. Tag: para
-#: configuration.xml:995
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis role=\"strong\">e.g.</emphasis> <literal>validate</literal> | "
 "<literal>update</literal> | <literal>create</literal> | <literal>create-"
 "drop</literal>"
 msgstr ""
-"<emphasis role=\"strong\">取值</emphasis><literal>validate</literal> | "
+"<emphasis role=\"strong\">例如:</emphasis><literal>validate</literal> | "
 "<literal>update</literal> | <literal>create</literal> | <literal>create-"
-"drop</literal>"
+"drop</literal> "
 
-#. Tag: literal
-#: configuration.xml:1004
-#, no-c-format
-msgid "hibernate.cglib.use_reflection_optimizer"
-msgstr "hibernate.cglib.use_reflection_optimizer"
-
 #. Tag: entry
-#: configuration.xml:1006
 #, fuzzy, no-c-format
+msgid "<literal>hibernate.cglib.use_reflection_optimizer</literal>"
+msgstr "<literal>hibernate.cglib. use_reflection_optimizer</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "Enables the use of CGLIB instead of runtime reflection (System-level "
 "property). Reflection can sometimes be useful when troubleshooting. "
 "Hibernate always requires CGLIB even if you turn off the optimizer. You "
 "cannot set this property in <literal>hibernate.cfg.xml</literal>."
 msgstr ""
-"开启CGLIB来替代运行时反射机制(系统级属性). 反射机制有时在除错时比较有用. 注意"
-"即使关闭这个优化, Hibernate还是需要CGLIB. 你不能在<placeholder-1/>中设置此属"
-"性. <placeholder-2/>"
+"开启 CGLIB 来替代运行时反射机制(系统级属性)。反射机制有时在除错时比较有用。"
+"注意即使关闭这个优化,Hibernate 还是需要 CGLIB。你不能在 <literal>hibernate."
+"cfg.xml</literal> 中设置此属性。 "
 
 #. Tag: title
-#: configuration.xml:1022
 #, no-c-format
 msgid "SQL Dialects"
-msgstr "SQL方言"
+msgstr "SQL 方言"
 
 #. Tag: para
-#: configuration.xml:1024
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Always set the <literal>hibernate.dialect</literal> property to the correct "
 "<literal>org.hibernate.dialect.Dialect</literal> subclass for your database. "
@@ -2148,318 +1355,263 @@
 "the other properties listed above. This means that you will not have to "
 "specify them manually."
 msgstr ""
-"你应当总是为你的数据库将<literal>hibernate.dialect</literal>属性设置成正确的 "
-"<literal>org.hibernate.dialect.Dialect</literal>子类. 如果你指定一种方言, "
-"Hibernate将为上面列出的一些属性使用合理的默认值, 为你省去了手工指定它们的功"
-"夫."
+"你应当总是为你的数据库将 <literal>hibernate.dialect</literal> 属性设置成正确"
+"的  <literal>org.hibernate.dialect.Dialect</literal> 子类。如果你指定一种方"
+"言,Hibernate 将为上面列出的一些属性使用合理的默认值,这样你就不用手工指定它"
+"们。"
 
 #. Tag: title
-#: configuration.xml:1032
 #, no-c-format
 msgid "Hibernate SQL Dialects (<literal>hibernate.dialect</literal>)"
-msgstr "Hibernate SQL方言 (<literal>hibernate.dialect</literal>)"
+msgstr "Hibernate SQL 方言(<literal>hibernate.dialect</literal>)"
 
 #. Tag: entry
-#: configuration.xml:1040
 #, no-c-format
 msgid "RDBMS"
 msgstr "RDBMS"
 
 #. Tag: entry
-#: configuration.xml:1041
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Dialect"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"Dialect\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"方言"
+msgstr "Dialect"
 
 #. Tag: entry
-#: configuration.xml:1046
 #, no-c-format
-msgid "<entry>DB2</entry>"
-msgstr ""
+msgid "DB2"
+msgstr "DB2"
 
-#. Tag: literal
-#: configuration.xml:1046
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2Dialect"
-msgstr "org.hibernate.dialect.DB2Dialect"
+msgid "<literal>org.hibernate.dialect.DB2Dialect</literal>"
+msgstr "<literal>org.hibernate.dialect.DB2Dialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1049
 #, no-c-format
 msgid "DB2 AS/400"
 msgstr "DB2 AS/400"
 
-#. Tag: literal
-#: configuration.xml:1049
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2400Dialect"
-msgstr "org.hibernate.dialect.DB2400Dialect"
+msgid "<literal>org.hibernate.dialect.DB2400Dialect</literal>"
+msgstr "<literal>org.hibernate.dialect.DB2400Dialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1052
 #, no-c-format
 msgid "DB2 OS390"
 msgstr "DB2 OS390"
 
-#. Tag: literal
-#: configuration.xml:1052
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.DB2390Dialect"
-msgstr "org.hibernate.dialect.DB2390Dialect"
+msgid "<literal>org.hibernate.dialect.DB2390Dialect</literal>"
+msgstr "<literal>org.hibernate.dialect.DB2390Dialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1055
 #, no-c-format
 msgid "PostgreSQL"
 msgstr "PostgreSQL"
 
-#. Tag: literal
-#: configuration.xml:1055
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.PostgreSQLDialect"
-msgstr "org.hibernate.dialect.PostgreSQLDialect"
+msgid "<literal>org.hibernate.dialect.PostgreSQLDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.PostgreSQLDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1058
 #, no-c-format
 msgid "MySQL"
 msgstr "MySQL"
 
-#. Tag: literal
-#: configuration.xml:1058
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLDialect"
-msgstr "org.hibernate.dialect.MySQLDialect"
+msgid "<literal>org.hibernate.dialect.MySQLDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MySQLDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1061
 #, no-c-format
 msgid "MySQL with InnoDB"
 msgstr "MySQL with InnoDB"
 
-#. Tag: literal
-#: configuration.xml:1061
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLInnoDBDialect"
-msgstr "org.hibernate.dialect.MySQLInnoDBDialect"
+msgid "<literal>org.hibernate.dialect.MySQLInnoDBDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MySQLInnoDBDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1064
 #, no-c-format
 msgid "MySQL with MyISAM"
 msgstr "MySQL with MyISAM"
 
-#. Tag: literal
-#: configuration.xml:1064
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MySQLMyISAMDialect"
-msgstr "org.hibernate.dialect.MySQLMyISAMDialect"
+msgid "<literal>org.hibernate.dialect.MySQLMyISAMDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MySQLMyISAMDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1067
 #, no-c-format
 msgid "Oracle (any version)"
-msgstr "Oracle (any version)"
+msgstr "Oracle(any version)"
 
-#. Tag: literal
-#: configuration.xml:1067
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.OracleDialect"
-msgstr "org.hibernate.dialect.OracleDialect"
+msgid "<literal>org.hibernate.dialect.OracleDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.OracleDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1070
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Oracle 9i"
-msgstr "Oracle 9i/10g"
+msgstr "Oracle 9i"
 
-#. Tag: literal
-#: configuration.xml:1070
-#, fuzzy, no-c-format
-msgid "org.hibernate.dialect.Oracle9iDialect"
-msgstr "org.hibernate.dialect.Oracle9Dialect"
+#. Tag: entry
+#, no-c-format
+msgid "<literal>org.hibernate.dialect.Oracle9iDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.Oracle9iDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1073
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Oracle 10g"
-msgstr "Oracle 9i/10g"
+msgstr "Oracle 10g"
 
-#. Tag: literal
-#: configuration.xml:1073
-#, fuzzy, no-c-format
-msgid "org.hibernate.dialect.Oracle10gDialect"
-msgstr "org.hibernate.dialect.OracleDialect"
+#. Tag: entry
+#, no-c-format
+msgid "<literal>org.hibernate.dialect.Oracle10gDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.Oracle10gDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1076
 #, no-c-format
 msgid "Sybase"
 msgstr "Sybase"
 
-#. Tag: literal
-#: configuration.xml:1076
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SybaseDialect"
-msgstr "org.hibernate.dialect.SybaseDialect"
+msgid "<literal>org.hibernate.dialect.SybaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SybaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1079
 #, no-c-format
 msgid "Sybase Anywhere"
 msgstr "Sybase Anywhere"
 
-#. Tag: literal
-#: configuration.xml:1079
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SybaseAnywhereDialect"
-msgstr "org.hibernate.dialect.SybaseAnywhereDialect"
+msgid "<literal>org.hibernate.dialect.SybaseAnywhereDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SybaseAnywhereDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1082
 #, no-c-format
 msgid "Microsoft SQL Server"
 msgstr "Microsoft SQL Server"
 
-#. Tag: literal
-#: configuration.xml:1082
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SQLServerDialect"
-msgstr "org.hibernate.dialect.SQLServerDialect"
+msgid "<literal>org.hibernate.dialect.SQLServerDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SQLServerDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1085
 #, no-c-format
 msgid "SAP DB"
 msgstr "SAP DB"
 
-#. Tag: literal
-#: configuration.xml:1085
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.SAPDBDialect"
-msgstr "org.hibernate.dialect.SAPDBDialect"
+msgid "<literal>org.hibernate.dialect.SAPDBDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.SAPDBDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1088
 #, no-c-format
 msgid "Informix"
 msgstr "Informix"
 
-#. Tag: literal
-#: configuration.xml:1088
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.InformixDialect"
-msgstr "org.hibernate.dialect.InformixDialect"
+msgid "<literal>org.hibernate.dialect.InformixDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.InformixDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1091
 #, no-c-format
 msgid "HypersonicSQL"
 msgstr "HypersonicSQL"
 
-#. Tag: literal
-#: configuration.xml:1091
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.HSQLDialect"
-msgstr "org.hibernate.dialect.HSQLDialect"
+msgid "<literal>org.hibernate.dialect.HSQLDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.HSQLDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1094
 #, no-c-format
 msgid "Ingres"
 msgstr "Ingres"
 
-#. Tag: literal
-#: configuration.xml:1094
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.IngresDialect"
-msgstr "org.hibernate.dialect.IngresDialect"
+msgid "<literal>org.hibernate.dialect.IngresDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.IngresDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1097
 #, no-c-format
 msgid "Progress"
 msgstr "Progress"
 
-#. Tag: literal
-#: configuration.xml:1097
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.ProgressDialect"
-msgstr "org.hibernate.dialect.ProgressDialect"
+msgid "<literal>org.hibernate.dialect.ProgressDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.ProgressDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1100
 #, no-c-format
 msgid "Mckoi SQL"
 msgstr "Mckoi SQL"
 
-#. Tag: literal
-#: configuration.xml:1100
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.MckoiDialect"
-msgstr "org.hibernate.dialect.MckoiDialect"
+msgid "<literal>org.hibernate.dialect.MckoiDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.MckoiDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1103
 #, no-c-format
 msgid "Interbase"
 msgstr "Interbase"
 
-#. Tag: literal
-#: configuration.xml:1103
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.InterbaseDialect"
-msgstr "org.hibernate.dialect.InterbaseDialect"
+msgid "<literal>org.hibernate.dialect.InterbaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.InterbaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1106
 #, no-c-format
 msgid "Pointbase"
 msgstr "Pointbase"
 
-#. Tag: literal
-#: configuration.xml:1106
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.PointbaseDialect"
-msgstr "org.hibernate.dialect.PointbaseDialect"
+msgid "<literal>org.hibernate.dialect.PointbaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.PointbaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1109
 #, no-c-format
 msgid "FrontBase"
 msgstr "FrontBase"
 
-#. Tag: literal
-#: configuration.xml:1109
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.FrontbaseDialect"
-msgstr "org.hibernate.dialect.FrontbaseDialect"
+msgid "<literal>org.hibernate.dialect.FrontbaseDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.FrontbaseDialect</literal>"
 
 #. Tag: entry
-#: configuration.xml:1112
 #, no-c-format
 msgid "Firebird"
 msgstr "Firebird"
 
-#. Tag: literal
-#: configuration.xml:1112
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.dialect.FirebirdDialect"
-msgstr "org.hibernate.dialect.FirebirdDialect"
+msgid "<literal>org.hibernate.dialect.FirebirdDialect</literal>"
+msgstr "<literal>org.hibernate.dialect.FirebirdDialect</literal>"
 
 #. Tag: title
-#: configuration.xml:1121
 #, no-c-format
 msgid "Outer Join Fetching"
-msgstr "外连接抓取(Outer Join Fetching)"
+msgstr "外连接抓取(Outer Join Fetching)"
 
 #. Tag: para
-#: configuration.xml:1123
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your database supports ANSI, Oracle or Sybase style outer joins, "
 "<emphasis>outer join fetching</emphasis> will often increase performance by "
@@ -2469,14 +1621,14 @@
 "one, one-to-many, many-to-many and one-to-one associations to be retrieved "
 "in a single SQL <literal>SELECT</literal>."
 msgstr ""
-"如果你的数据库支持ANSI, Oracle或Sybase风格的外连接, <emphasis>外连接抓取</"
-"emphasis>通常能通过限制往返数据库次数 (更多的工作交由数据库自己来完成)来提高"
-"效率. 外连接抓取允许在单个<literal>SELECT</literal>SQL语句中, 通过many-to-"
-"one, one-to-many, many-to-many和one-to-one关联获取连接对象的整个对象图."
+"如果你的数据库支持 ANSI、Oracle 或 Sybase 风格的外连接,<emphasis>外连接抓取"
+"</emphasis>通常能通过限制往返数据库次数(更多的工作交由数据库自己来完成)来提"
+"高效率。外连接抓取允许在单个 <literal>SELECT</literal> SQL 语句中, 通过 "
+"many-to-one、one-to-many、many-to-many 和 one-to-one 关联获取连接对象的整个对"
+"象图。"
 
 #. Tag: para
-#: configuration.xml:1132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Outer join fetching can be disabled <emphasis>globally</emphasis> by setting "
 "the property <literal>hibernate.max_fetch_depth</literal> to <literal>0</"
@@ -2484,26 +1636,23 @@
 "fetching for one-to-one and many-to-one associations that have been mapped "
 "with <literal>fetch=\"join\"</literal>."
 msgstr ""
-"将<literal>hibernate.max_fetch_depth</literal>设为<literal>0</literal>能在"
-"<emphasis>全局</emphasis> 范围内禁止外连接抓取. 设为<literal>1</literal>或更"
-"高值能启用one-to-one和many-to-oneouter关联的外连接抓取, 它们通过 "
-"<literal>fetch=\"join\"</literal>来映射."
+"将 <literal>hibernate.max_fetch_depth</literal> 设为 <literal>0</literal> 能"
+"在<emphasis>全局</emphasis> 范围内禁止外连接抓取。设为 <literal>1</literal> "
+"或更高值能启用 one-to-one 和 many-to-oneouter 关联的外连接抓取,它们通过 "
+"<literal>fetch=\"join\"</literal> 来映射。 "
 
 #. Tag: para
-#: configuration.xml:1140
 #, no-c-format
-msgid "See <xref linkend=\"performance-fetching\"/> for more information."
-msgstr "参见<xref linkend=\"performance-fetching\"/>获得更多信息."
+msgid "See <xref linkend=\"performance-fetching\" /> for more information."
+msgstr "参见 <xref linkend=\"performance-fetching\"/> 获得更多信息。 "
 
 #. Tag: title
-#: configuration.xml:1147
 #, no-c-format
 msgid "Binary Streams"
-msgstr "二进制流 (Binary Streams)"
+msgstr "二进制流(Binary Streams)"
 
 #. Tag: para
-#: configuration.xml:1149
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Oracle limits the size of <literal>byte</literal> arrays that can be passed "
 "to and/or from its JDBC driver. If you wish to use large instances of "
@@ -2511,83 +1660,63 @@
 "should enable <literal>hibernate.jdbc.use_streams_for_binary</literal>. "
 "<emphasis>This is a system-level setting only.</emphasis>"
 msgstr ""
-"Oracle限制那些通过JDBC驱动传输的<literal>字节</literal>数组的数目. 如果你希望"
-"使用<literal>二进值 (binary)</literal>或 <literal>可序列化的 (serializable)</"
-"literal>类型的大对象, 你应该开启 <literal>hibernate.jdbc."
-"use_streams_for_binary</literal>属性. <emphasis>这是系统级属性.</emphasis>"
+"Oracle 限制那些通过 JDBC 驱动传输的<literal>字节</literal>数组的数目。如果你"
+"希望使用<literal>二进值(binary)</literal>或 <literal>可序列化的"
+"(serializable)</literal>类型的大对象,你应该开启 <literal>hibernate.jdbc."
+"use_streams_for_binary</literal> 属性。<emphasis>这是系统级属性。</emphasis> "
 
 #. Tag: title
-#: configuration.xml:1160
 #, no-c-format
 msgid "Second-level and query cache"
 msgstr "二级缓存与查询缓存"
 
 #. Tag: para
-#: configuration.xml:1162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The properties prefixed by <literal>hibernate.cache</literal> allow you to "
 "use a process or cluster scoped second-level cache system with Hibernate. "
-"See the <xref linkend=\"performance-cache\"/> for more information."
+"See the <xref linkend=\"performance-cache\" /> for more information."
 msgstr ""
-"以<literal>hibernate.cache</literal>为前缀的属性允许你在Hibernate中,使用进程"
-"或群集范围内的二级缓存系统. 参见<xref linkend=\"performance-cache\"/>获取更多"
-"的详情."
+"以 <literal>hibernate.cache</literal> 为前缀的属性允许你在 Hibernate 中,使用"
+"进程或群集范围内的二级缓存系统。参见 <xref linkend=\"performance-cache\"/> 获"
+"取更多的详情。"
 
 #. Tag: title
-#: configuration.xml:1172
 #, no-c-format
 msgid "Query Language Substitution"
 msgstr "查询语言中的替换"
 
 #. Tag: para
-#: configuration.xml:1174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can define new Hibernate query tokens using <literal>hibernate.query."
 "substitutions</literal>. For example:"
 msgstr ""
-"你可以使用<literal>hibernate.query.substitutions</literal>在Hibernate中定义新"
-"的查询符号. 例如:"
+"你可以使用 <literal>hibernate.query.substitutions</literal> 在 Hibernate 中定"
+"义新的查询符号。例如: "
 
-#. Tag: programlisting
-#: configuration.xml:1179
-#, no-c-format
-msgid "hibernate.query.substitutions true=1, false=0"
-msgstr "hibernate.query.substitutions true=1, false=0"
-
 #. Tag: para
-#: configuration.xml:1181
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This would cause the tokens <literal>true</literal> and <literal>false</"
 "literal> to be translated to integer literals in the generated SQL."
 msgstr ""
-"将导致符号<literal>true</literal>和<literal>false</literal>在生成的SQL中被翻"
-"译成整数常量."
+"将导致符号 <literal>true</literal> 和 <literal>false</literal> 在生成的 SQL "
+"中被翻译成整数常量。"
 
-#. Tag: programlisting
-#: configuration.xml:1186
-#, no-c-format
-msgid "hibernate.query.substitutions toLowercase=LOWER"
-msgstr "hibernate.query.substitutions toLowercase=LOWER"
-
 #. Tag: para
-#: configuration.xml:1188
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This would allow you to rename the SQL <literal>LOWER</literal> function."
-msgstr "将允许你重命名SQL中的<literal>LOWER</literal>函数."
+msgstr "将允许你重命名 SQL 中的 <literal>LOWER</literal> 函数。"
 
 #. Tag: title
-#: configuration.xml:1195
 #, no-c-format
 msgid "Hibernate statistics"
-msgstr "Hibernate的统计(statistics)机制"
+msgstr "Hibernate 的统计(statistics)机制"
 
 #. Tag: para
-#: configuration.xml:1197
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you enable <literal>hibernate.generate_statistics</literal>, Hibernate "
 "exposes a number of metrics that are useful when tuning a running system via "
@@ -2595,20 +1724,18 @@
 "configured to expose these statistics via JMX. Read the Javadoc of the "
 "interfaces in <literal>org.hibernate.stats</literal> for more information."
 msgstr ""
-"如果你开启<literal>hibernate.generate_statistics</literal>, 那么当你通过 "
-"<literal>SessionFactory.getStatistics()</literal>调整正在运行的系统时,"
-"Hibernate将导出大量有用的数据. Hibernate甚至能被配置成通过JMX导出这些统计信"
-"息. 参考<literal>org.hibernate.stats</literal>中接口的Javadoc,以获得更多信"
-"息."
+"如果你开启 <literal>hibernate.generate_statistics</literal>,那么当你通过  "
+"<literal>SessionFactory.getStatistics()</literal> 调整正在运行的系统时,"
+"Hibernate 将导出大量有用的数据。Hibernate 甚至能被配置成通过 JMX 导出这些统计"
+"信息。参考 <literal>org.hibernate.stats</literal> 中接口的 Javadoc,以获得更"
+"多信息。 "
 
 #. Tag: title
-#: configuration.xml:1209
 #, no-c-format
 msgid "Logging"
 msgstr "日志"
 
 #. Tag: para
-#: configuration.xml:1211
 #, no-c-format
 msgid ""
 "Hibernate utilizes <ulink url=\"http://www.slf4j.org/\">Simple Logging "
@@ -2624,10 +1751,18 @@
 "properties file is distributed with Hibernate in the <literal>src/</literal> "
 "directory."
 msgstr ""
+"Hibernate 利用 <ulink url=\"http://www.slf4j.org/\">Simple Logging Facade "
+"for Java</ulink> (SLF4J) 来记录不同系统事件的日志。SLF4J 可以根据你选择的绑定"
+"把日志输出到几个日志框架(NOP、Simple、log4j version 1.2、JDK 1.4 logging、"
+"JCL 或 logback)上。为了设置日志,你需要在 classpath 里加入 <filename>slf4j-"
+"api.jar</filename> 和你选择的绑定的 JAR 文件(使用 Log4J 时加入 "
+"<filename>slf4j-log4j12.jar</filename>)。更多的细节请参考 SLF4J <ulink url="
+"\"http://www.slf4j.org/manual.html\">文档</ulink>。要使用 Log4j,你也需要在 "
+"classpath 里加入 <filename>log4j.properties</filename> 文件。Hibernate 里的 "
+"<literal>src/</literal> 目录里带有一个属性文件的例子。"
 
 #. Tag: para
-#: configuration.xml:1222
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you familiarize yourself with Hibernate's log "
 "messages. A lot of work has been put into making the Hibernate log as "
@@ -2635,154 +1770,131 @@
 "troubleshooting device. The most interesting log categories are the "
 "following:"
 msgstr ""
-"我们强烈建议你熟悉一下Hibernate的日志消息. 在不失可读性的前提下, 我们做了很"
-"多工作,使Hibernate的日志可能地详细. 这是必要的查错利器. 最令人感兴趣的日志分"
-"类有如下这些:"
+"我们强烈建议你熟悉一下 Hibernate 的日志消息。在不失可读性的前提下,我们做了很"
+"多工作,使 Hibernate 的日志可能地详细。这是必要的查错利器。最令人感兴趣的日志"
+"分类有如下这些:"
 
 #. Tag: title
-#: configuration.xml:1231
 #, no-c-format
 msgid "Hibernate Log Categories"
-msgstr "Hibernate日志类别"
+msgstr "Hibernate 日志类别"
 
 #. Tag: entry
-#: configuration.xml:1237
 #, no-c-format
 msgid "Category"
 msgstr "类别"
 
 #. Tag: entry
-#: configuration.xml:1238
 #, no-c-format
 msgid "Function"
 msgstr "功能"
 
-#. Tag: literal
-#: configuration.xml:1243
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.SQL"
-msgstr "org.hibernate.SQL"
+msgid "<literal>org.hibernate.SQL</literal>"
+msgstr "<literal>org.hibernate.SQL</literal>"
 
 #. Tag: entry
-#: configuration.xml:1244
 #, no-c-format
 msgid "Log all SQL DML statements as they are executed"
-msgstr "在所有SQL DML语句被执行时为它们记录日志"
+msgstr "在所有 SQL DML 语句被执行时为它们记录日志"
 
-#. Tag: literal
-#: configuration.xml:1247
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.type"
-msgstr "org.hibernate.type"
+msgid "<literal>org.hibernate.type</literal>"
+msgstr "<literal>org.hibernate.type</literal>"
 
 #. Tag: entry
-#: configuration.xml:1248
 #, no-c-format
 msgid "Log all JDBC parameters"
-msgstr "为所有JDBC参数记录日志"
+msgstr "为所有 JDBC 参数记录日志"
 
-#. Tag: literal
-#: configuration.xml:1251
-#, no-c-format
-msgid "org.hibernate.tool.hbm2ddl"
-msgstr "org.hibernate.tool.hbm2ddl"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.tool.hbm2ddl</literal>"
+msgstr "<literal>org.hibernate.tool. hbm2ddl</literal>"
 
 #. Tag: entry
-#: configuration.xml:1252
 #, no-c-format
 msgid "Log all SQL DDL statements as they are executed"
-msgstr "在所有SQL DDL语句执行时为它们记录日志"
+msgstr "在所有 SQL DDL 语句执行时为它们记录日志"
 
-#. Tag: literal
-#: configuration.xml:1255
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.pretty"
-msgstr "org.hibernate.pretty"
+msgid "<literal>org.hibernate.pretty</literal>"
+msgstr "<literal>org.hibernate.pretty</literal>"
 
 #. Tag: entry
-#: configuration.xml:1256
 #, no-c-format
 msgid ""
 "Log the state of all entities (max 20 entities) associated with the session "
 "at flush time"
-msgstr "在session清洗(flush)时,为所有与其关联的实体(最多20个)的状态记录日志"
+msgstr ""
+"在 session 清洗(flush)时,为所有与其关联的实体(最多 20 个)的状态记录日志"
 
-#. Tag: literal
-#: configuration.xml:1262
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.cache"
-msgstr "org.hibernate.cache"
+msgid "<literal>org.hibernate.cache</literal>"
+msgstr "<literal>org.hibernate.cache</literal>"
 
 #. Tag: entry
-#: configuration.xml:1263
 #, no-c-format
 msgid "Log all second-level cache activity"
 msgstr "为所有二级缓存的活动记录日志"
 
-#. Tag: literal
-#: configuration.xml:1266
-#, no-c-format
-msgid "org.hibernate.transaction"
-msgstr "org.hibernate.transaction"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.transaction</literal>"
+msgstr "<literal>org.hibernate. transaction</literal>"
 
 #. Tag: entry
-#: configuration.xml:1267
 #, no-c-format
 msgid "Log transaction related activity"
 msgstr "为事务相关的活动记录日志"
 
-#. Tag: literal
-#: configuration.xml:1270
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.jdbc"
-msgstr "org.hibernate.jdbc"
+msgid "<literal>org.hibernate.jdbc</literal>"
+msgstr "<literal>org.hibernate.jdbc</literal>"
 
 #. Tag: entry
-#: configuration.xml:1271
 #, no-c-format
 msgid "Log all JDBC resource acquisition"
-msgstr "为所有JDBC资源的获取记录日志"
+msgstr "为所有 JDBC 资源的获取记录日志"
 
-#. Tag: literal
-#: configuration.xml:1274
-#, no-c-format
-msgid "org.hibernate.hql.ast.AST"
-msgstr "org.hibernate.hql.AST"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.hql.ast.AST</literal>"
+msgstr "<literal>org.hibernate.hql. ast.AST</literal>"
 
 #. Tag: entry
-#: configuration.xml:1275
 #, no-c-format
 msgid "Log HQL and SQL ASTs during query parsing"
-msgstr "在解析查询的时候,记录HQL和SQL的AST分析日志"
+msgstr "在解析查询的时候,记录 HQL 和 SQL 的 AST 分析日志"
 
-#. Tag: literal
-#: configuration.xml:1280
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate.secure"
-msgstr "org.hibernate.secure"
+msgid "<literal>org.hibernate.secure</literal>"
+msgstr "<literal>org.hibernate.secure</literal>"
 
 #. Tag: entry
-#: configuration.xml:1281
 #, no-c-format
 msgid "Log all JAAS authorization requests"
-msgstr "为JAAS认证请求做日志"
+msgstr "为 JAAS 认证请求做日志"
 
-#. Tag: literal
-#: configuration.xml:1284
+#. Tag: entry
 #, no-c-format
-msgid "org.hibernate"
-msgstr "org.hibernate"
+msgid "<literal>org.hibernate</literal>"
+msgstr "<literal>org.hibernate</literal>"
 
 #. Tag: entry
-#: configuration.xml:1285
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Log everything. This is a lot of information but it is useful for "
 "troubleshooting"
-msgstr "为任何Hibernate相关信息做日志 (信息量较大, 但对查错非常有帮助)"
+msgstr "为任何 Hibernate 相关信息记录日志(信息量较大,但对查错非常有帮助)"
 
 #. Tag: para
-#: configuration.xml:1294
 #, no-c-format
 msgid ""
 "When developing applications with Hibernate, you should almost always work "
@@ -2790,29 +1902,26 @@
 "hibernate.SQL</literal>, or, alternatively, the property <literal>hibernate."
 "show_sql</literal> enabled."
 msgstr ""
-"在使用Hibernate开发应用程序时, 你应当总是为<literal>org.hibernate.SQL</"
-"literal> 开启<literal>debug</literal>级别的日志记录,或者开启"
-"<literal>hibernate.show_sql</literal>属性。"
+"在使用 Hibernate 开发应用程序时,你应当总是为 <literal>org.hibernate.SQL</"
+"literal> 开启 <literal>debug</literal> 级别的日志记录,或者开启 "
+"<literal>hibernate.show_sql</literal> 属性。"
 
 #. Tag: title
-#: configuration.xml:1304
 #, no-c-format
 msgid "Implementing a <literal>NamingStrategy</literal>"
-msgstr "实现<literal>NamingStrategy</literal>"
+msgstr "实现 <literal>NamingStrategy</literal>"
 
 #. Tag: para
-#: configuration.xml:1306
 #, no-c-format
 msgid ""
 "The interface <literal>org.hibernate.cfg.NamingStrategy</literal> allows you "
 "to specify a \"naming standard\" for database objects and schema elements."
 msgstr ""
-"<literal>org.hibernate.cfg.NamingStrategy</literal>接口允许你为数据库中的对象"
-"和schema 元素指定一个“命名标准”."
+"<literal>org.hibernate.cfg.NamingStrategy</literal> 接口允许你为数据库中的对"
+"象和 schema 元素指定一个“命名标准”。"
 
 #. Tag: para
-#: configuration.xml:1311
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can provide rules for automatically generating database identifiers from "
 "Java identifiers or for processing \"logical\" column and table names given "
@@ -2821,48 +1930,34 @@
 "noise (<literal>TBL_</literal> prefixes, for example). The default strategy "
 "used by Hibernate is quite minimal."
 msgstr ""
-"你可能会提供一些通过Java标识生成数据库标识或将映射定义文件中\"逻辑\"表/列名处"
-"理成\"物理\"表/列名的规则. 这个特性有助于减少冗长的映射定义文件."
+"你可能会提供一些通过 Java 标识生成数据库标识或将映射定义文件中\"逻辑\"表/列名"
+"处理成\"物理\"表/列名的规则。这个特性有助于减少冗长的映射定义文件,消除重复内"
+"容(如 <literal>TBL_</literal> 前缀)。Hibernate 使用的缺省策略是相当精简的。"
 
 #. Tag: para
-#: configuration.xml:1320
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can specify a different strategy by calling <literal>Configuration."
 "setNamingStrategy()</literal> before adding mappings:"
 msgstr ""
 "在加入映射定义前,你可以调用 <literal>Configuration.setNamingStrategy()</"
-"literal>指定一个不同的命名策略:"
+"literal> 指定一个不同的命名策略: "
 
-#. Tag: programlisting
-#: configuration.xml:1325
-#, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration()\n"
-"    .setNamingStrategy(ImprovedNamingStrategy.INSTANCE)\n"
-"    .addFile(\"Item.hbm.xml\")\n"
-"    .addFile(\"Bid.hbm.xml\")\n"
-"    .buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1327
 #, no-c-format
 msgid ""
 "<literal>org.hibernate.cfg.ImprovedNamingStrategy</literal> is a built-in "
 "strategy that might be a useful starting point for some applications."
 msgstr ""
-"<literal>org.hibernate.cfg.ImprovedNamingStrategy</literal>是一个内建的命名策"
-"略, 对 一些应用程序而言,可能是非常有用的起点."
+"<literal>org.hibernate.cfg.ImprovedNamingStrategy</literal> 是一个内建的命名"
+"策略,对一些应用程序而言,可能是非常有用的起点。"
 
 #. Tag: title
-#: configuration.xml:1335
 #, no-c-format
 msgid "XML configuration file"
-msgstr "XML配置文件"
+msgstr "XML 配置文件"
 
 #. Tag: para
-#: configuration.xml:1337
 #, no-c-format
 msgid ""
 "An alternative approach to configuration is to specify a full configuration "
@@ -2870,67 +1965,22 @@
 "as a replacement for the <literal>hibernate.properties</literal> file or, if "
 "both are present, to override properties."
 msgstr ""
-"另一个配置方法是在<literal>hibernate.cfg.xml</literal>文件中指定一套完整的配"
-"置. 这个文件可以当成<literal>hibernate.properties</literal>的替代。 若两个文"
-"件同时存在,它将覆盖前者的属性."
+"另一个配置方法是在 <literal>hibernate.cfg.xml</literal> 文件中指定一套完整的"
+"配置。这个文件可以当成 <literal>hibernate.properties</literal> 的替代。若两个"
+"文件同时存在,它将覆盖前者的属性。"
 
 #. Tag: para
-#: configuration.xml:1344
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The XML configuration file is by default expected to be in the root of your "
 "<literal>CLASSPATH</literal>. Here is an example:"
 msgstr ""
-"XML配置文件被默认是放在<literal>CLASSPATH</literal>的根目录下. 这是一个例子:"
+"XML 配置文件被默认是放在 <literal>CLASSPATH</literal> 的根目录下。下面是一个"
+"例子: "
 
-#. Tag: programlisting
-#: configuration.xml:1349
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-"<!DOCTYPE hibernate-configuration PUBLIC\n"
-"    \"-//Hibernate/Hibernate Configuration DTD//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd\">\n"
-"\n"
-"<hibernate-configuration>\n"
-"\n"
-"    <!-- a SessionFactory instance listed as /jndi/name -->\n"
-"    <session-factory\n"
-"        name=\"java:hibernate/SessionFactory\">\n"
-"\n"
-"        <!-- properties -->\n"
-"        <property name=\"connection.datasource\">java:/comp/env/jdbc/MyDB</"
-"property>\n"
-"        <property name=\"dialect\">org.hibernate.dialect.MySQLDialect</"
-"property>\n"
-"        <property name=\"show_sql\">false</property>\n"
-"        <property name=\"transaction.factory_class\">\n"
-"            org.hibernate.transaction.JTATransactionFactory\n"
-"        </property>\n"
-"        <property name=\"jta.UserTransaction\">java:comp/UserTransaction</"
-"property>\n"
-"\n"
-"        <!-- mapping files -->\n"
-"        <mapping resource=\"org/hibernate/auction/Item.hbm.xml\"/>\n"
-"        <mapping resource=\"org/hibernate/auction/Bid.hbm.xml\"/>\n"
-"\n"
-"        <!-- cache settings -->\n"
-"        <class-cache class=\"org.hibernate.auction.Item\" usage=\"read-write"
-"\"/>\n"
-"        <class-cache class=\"org.hibernate.auction.Bid\" usage=\"read-only\"/"
-">\n"
-"        <collection-cache collection=\"org.hibernate.auction.Item.bids\" "
-"usage=\"read-write\"/>\n"
-"\n"
-"    </session-factory>\n"
-"\n"
-"</hibernate-configuration>]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:1351
-#, fuzzy, no-c-format
-msgid ""
 "The advantage of this approach is the externalization of the mapping file "
 "names to configuration. The <literal>hibernate.cfg.xml</literal> is also "
 "more convenient once you have to tune the Hibernate cache. It is your choice "
@@ -2938,56 +1988,34 @@
 "cfg.xml</literal>. Both are equivalent, except for the above mentioned "
 "benefits of using the XML syntax."
 msgstr ""
-"如你所见, 这个方法优势在于,在配置文件中指出了映射定义文件的名字. 一旦你需要"
-"调整Hibernate的缓存, <literal>hibernate.cfg.xml</literal>也是更方便. 注意,"
-"使用<literal>hibernate.properties</literal>还是 <literal>hibernate.cfg.xml</"
-"literal>完全是由你来决定, 除了上面提到的XML语法的优势之外, 两者是等价的."
+"如你所见,这个方法优势在于,在配置文件中指出了映射定义文件的名字。一旦你需要"
+"调整 Hibernate 的缓存,<literal>hibernate.cfg.xml</literal> 也是更方便。注"
+"意,使用 <literal>hibernate.properties</literal> 还是 <literal>hibernate.cfg."
+"xml</literal> 完全是由你来决定,除了上面提到的 XML 语法的优势之外,两者是等价"
+"的。 "
 
 #. Tag: para
-#: configuration.xml:1360
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "With the XML configuration, starting Hibernate is then as simple as:"
-msgstr ""
-"使用XML配置,使得启动Hibernate变的异常简单, 如下所示,一行代码就可以搞定:"
+msgstr "使用 XML 配置,使得启动 Hibernate 变的异常简单:"
 
-#. Tag: programlisting
-#: configuration.xml:1364
-#, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration().configure()."
-"buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: para
-#: configuration.xml:1366
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can select a different XML configuration file using:"
-msgstr "你可以使用如下代码来添加一个不同的XML配置文件"
+msgstr "你可以使用如下代码来添加一个不同的 XML 配置文件:"
 
-#. Tag: programlisting
-#: configuration.xml:1370
-#, no-c-format
-msgid ""
-"<![CDATA[SessionFactory sf = new Configuration()\n"
-"    .configure(\"catdb.cfg.xml\")\n"
-"    .buildSessionFactory();]]>"
-msgstr ""
-
 #. Tag: title
-#: configuration.xml:1375
 #, no-c-format
 msgid "J2EE Application Server integration"
-msgstr "J2EE应用程序服务器的集成"
+msgstr "J2EE 应用程序服务器的集成"
 
 #. Tag: para
-#: configuration.xml:1377
 #, no-c-format
 msgid "Hibernate has the following integration points for J2EE infrastructure:"
-msgstr "针对J2EE体系,Hibernate有如下几个集成的方面:"
+msgstr "针对 J2EE 体系,Hibernate 有如下几个集成的方面:"
 
 #. Tag: para
-#: configuration.xml:1383
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Container-managed datasources</emphasis>: Hibernate can use JDBC "
 "connections managed by the container and provided through JNDI. Usually, a "
@@ -2998,27 +2026,25 @@
 "(BMT), or you might want to use the optional Hibernate <literal>Transaction</"
 "literal> API for this to keep your code portable."
 msgstr ""
-"<emphasis>容器管理的数据源(Container-managed datasources)</emphasis>: "
-"Hibernate能使用通过容器管理,并由JNDI提供的JDBC连接. 通常, 特别是当处理多个数"
-"据源的分布式事务的时候, 由一个JTA兼容的<literal>TransactionManager</literal>"
-"和一个 <literal>ResourceManager</literal>来处理事务管理(CMT, 容器管理的事"
-"务). 当然你可以通过 编程方式来划分事务边界(BMT, Bean管理的事务). 或者为了代码"
-"的可移植性,你也也许会想使用可选的 Hibernate <literal>Transaction</literal> "
-"API."
+"<emphasis>容器管理的数据源(Container-managed datasources)</emphasis>: "
+"Hibernate 能使用通过容器管理,并由 JNDI 提供的 JDBC 连接。通常,特别是当处理"
+"多个数据源的分布式事务的时候,由一个 JTA 兼容的 <literal>TransactionManager</"
+"literal> 和一个 <literal>ResourceManager</literal> 来处理事务管理(CMT,容器"
+"管理的事务)。当然你可以通过 编程方式来划分事务边界(BMT,Bean 管理的事务)。"
+"或者为了代码的可移植性,你也也许会想使用可选的 Hibernate "
+"<literal>Transaction</literal> API。 "
 
 #. Tag: para
-#: configuration.xml:1398
 #, no-c-format
 msgid ""
 "<emphasis>Automatic JNDI binding</emphasis>: Hibernate can bind its "
 "<literal>SessionFactory</literal> to JNDI after startup."
 msgstr ""
-"<emphasis>自动JNDI绑定</emphasis>: Hibernate可以在启动后将 "
-"<literal>SessionFactory</literal>绑定到JNDI."
+"<emphasis>自动 JNDI 绑定</emphasis>:Hibernate 可以在启动后将 "
+"<literal>SessionFactory</literal> 绑定到 JNDI。"
 
 #. Tag: para
-#: configuration.xml:1407
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>JTA Session binding:</emphasis> the Hibernate <literal>Session</"
 "literal> can be automatically bound to the scope of JTA transactions. Simply "
@@ -3028,15 +2054,15 @@
 "demarcation is either declarative (CMT) or programmatic (BMT/"
 "UserTransaction)."
 msgstr ""
-"<emphasis>JTA Session绑定:</emphasis> Hibernate <literal>Session</literal> 可"
-"以自动绑定到JTA事务作用的范围. 只需简单地从JNDI查找<literal>SessionFactory</"
-"literal>并获得当前的 <literal>Session</literal>. 当JTA事务完成时, 让Hibernate"
-"来处理 <literal>Session</literal>的清洗(flush)与关闭. 事务的划分可以是声明式"
-"的(CMT),也可以是编程式的(BMT/UserTransaction)."
+"<emphasis>JTA Session 绑定:</emphasis> Hibernate <literal>Session</literal> "
+"可以自动绑定到 JTA 事务作用的范围。只需简单地从 JNDI 查找 "
+"<literal>SessionFactory</literal> 并获得当前的 <literal>Session</literal>。"
+"当 JTA 事务完成时,让 Hibernate来处理 <literal>Session</literal> 的清洗"
+"(flush)与关闭。事务的划分可以是声明式的(CMT),也可以是编程式的(BMT/"
+"UserTransaction)。 "
 
 #. Tag: para
-#: configuration.xml:1420
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>JMX deployment:</emphasis> if you have a JMX capable application "
 "server (e.g. JBoss AS), you can choose to deploy Hibernate as a managed "
@@ -3046,33 +2072,30 @@
 "take care of service dependencies (datasource has to be available before "
 "Hibernate starts, etc)."
 msgstr ""
-"<emphasis>JMX部署:</emphasis> 如果你使用支持JMX应用程序服务器(如, JBoss AS), "
-"那么你可以选择将Hibernate部署成托管MBean. 这将为你省去一行从"
-"<literal>Configuration</literal>构建<literal>SessionFactory</literal>的启动代"
-"码. 容器将启动你的<literal>HibernateService</literal>, 并完美地处理好服务间的"
-"依赖关系 (在Hibernate启动前,数据源必须是可用的,等等)."
+"<emphasis>JMX 部署:</emphasis> 如果你使用支持 JMX 应用程序服务器(如,JBoss "
+"AS),那么你可以选择将 Hibernate 部署成托管 MBean。这将为你省去一行从"
+"<literal>Configuration</literal> 构建 <literal>SessionFactory</literal> 的启"
+"动代码。容器将启动你的 <literal>HibernateService</literal>,并完美地处理好服"
+"务间的依赖关系(在 Hibernate 启动前,数据源必须是可用的,等等)。 "
 
 #. Tag: para
-#: configuration.xml:1431
 #, no-c-format
 msgid ""
 "Depending on your environment, you might have to set the configuration "
 "option <literal>hibernate.connection.aggressive_release</literal> to true if "
 "your application server shows \"connection containment\" exceptions."
 msgstr ""
-"如果应用程序服务器抛出\"connection containment\"异常, 根据你的环境,也许该将"
-"配置属性 <literal>hibernate.connection.release_mode</literal>设为"
-"<literal>after_statement</literal>."
+"如果应用程序服务器抛出 \"connection containment\" 异常,根据你的环境,也许该"
+"将配置属性 <literal>hibernate.connection.release_mode</literal> 设为 "
+"<literal>after_statement</literal>。"
 
 #. Tag: title
-#: configuration.xml:1438
 #, no-c-format
 msgid "Transaction strategy configuration"
 msgstr "事务策略配置"
 
 #. Tag: para
-#: configuration.xml:1440
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The Hibernate <literal>Session</literal> API is independent of any "
 "transaction demarcation system in your architecture. If you let Hibernate "
@@ -3081,13 +2104,12 @@
 "server, you might want to use bean-managed transactions and call the JTA API "
 "and <literal>UserTransaction</literal> when needed."
 msgstr ""
-"在你的架构中,Hibernate的<literal>Session</literal> API是独立于任何事务分界系"
-"统的. 如果你让Hibernate通过连接池直接使用JDBC, 你需要调用JDBC API来打开和关闭"
-"你的事务. 如果你运行在J2EE应用程序服务器中, 你也许想用Bean管理的事务并在需要"
-"的时候调用JTA API和<literal>UserTransaction</literal>."
+"在你的架构中,Hibernate 的 <literal>Session</literal> API 是独立于任何事务分"
+"界系统的。如果你让 Hibernate 通过连接池直接使用 JDBC,你需要调用 JDBC API 来"
+"打开和关闭你的事务。如果你运行在 J2EE 应用程序服务器中,你也许想用 Bean 管理"
+"的事务并在需要的时候调用 JTA API 和 <literal>UserTransaction</literal>。 "
 
 #. Tag: para
-#: configuration.xml:1448
 #, no-c-format
 msgid ""
 "To keep your code portable between these two (and other) environments we "
@@ -3097,69 +2119,60 @@
 "configuration property <literal>hibernate.transaction.factory_class</"
 "literal>."
 msgstr ""
-"为了让你的代码在两种(或其他)环境中可以移植,我们建议使用可选的Hibernate "
-"<literal>Transaction</literal> API, 它包装并隐藏了底层系统. 你必须通过设置"
-"Hibernate配置属性<literal>hibernate.transaction.factory_class</literal>来指"
-"定 一个<literal>Transaction</literal>实例的工厂类."
+"为了让你的代码在两种(或其他)环境中可以移植,我们建议使用可选的 Hibernate "
+"<literal>Transaction</literal> API,它包装并隐藏了底层系统。你必须通过设置 "
+"Hibernate 配置属性 <literal>hibernate.transaction.factory_class</literal> 来"
+"指定一个 <literal>Transaction</literal> 实例的工厂类。"
 
 #. Tag: para
-#: configuration.xml:1455
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "There are three standard, or built-in, choices:"
-msgstr "有三个标准(内建)的选择:"
+msgstr "有三个标准(内建)的选择: "
 
-#. Tag: literal
-#: configuration.xml:1461
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.JDBCTransactionFactory"
-msgstr "org.hibernate.transaction.JDBCTransactionFactory"
+msgid "<literal>org.hibernate.transaction.JDBCTransactionFactory</literal>"
+msgstr "<literal>org.hibernate.transaction.JDBCTransactionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1463
 #, no-c-format
 msgid "delegates to database (JDBC) transactions (default)"
-msgstr "委托给数据库(JDBC)事务(默认)"
+msgstr "委托给数据库(JDBC)事务(默认)"
 
-#. Tag: literal
-#: configuration.xml:1467
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.JTATransactionFactory"
-msgstr "org.hibernate.transaction.JTATransactionFactory"
+msgid "<literal>org.hibernate.transaction.JTATransactionFactory</literal>"
+msgstr "<literal>org.hibernate.transaction.JTATransactionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1469
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "delegates to container-managed transactions if an existing transaction is "
 "underway in this context (for example, EJB session bean method). Otherwise, "
 "a new transaction is started and bean-managed transactions are used."
 msgstr ""
-"如果在上下文环境中存在运行着的事务(如, EJB会话Bean的方法), 则委托给容器管 理"
-"的事务, 否则,将启动一个新的事务,并使用Bean管理的事务."
+"如果在上下文环境中存在运行着的事务(如,EJB 会话 Bean 的方法),则委托给容器"
+"管理的事务。否则,将启动一个新的事务,并使用 Bean 管理的事务。"
 
-#. Tag: literal
-#: configuration.xml:1477
+#. Tag: term
 #, no-c-format
-msgid "org.hibernate.transaction.CMTTransactionFactory"
-msgstr "org.hibernate.transaction.CMTTransactionFactory"
+msgid "<literal>org.hibernate.transaction.CMTTransactionFactory</literal>"
+msgstr "<literal>org.hibernate.transaction.CMTTransactionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1479
 #, no-c-format
 msgid "delegates to container-managed JTA transactions"
-msgstr "委托给容器管理的JTA事务"
+msgstr "委托给容器管理的 JTA 事务"
 
 #. Tag: para
-#: configuration.xml:1484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also define your own transaction strategies (for a CORBA transaction "
 "service, for example)."
-msgstr "你也可以定义属于你自己的事务策略 (如, 针对CORBA的事务服务)"
+msgstr "你也可以定义属于你自己的事务策略(如,针对 CORBA 的事务服务)。"
 
 #. Tag: para
-#: configuration.xml:1489
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Some features in Hibernate (i.e., the second level cache, Contextual "
 "Sessions with JTA, etc.) require access to the JTA "
@@ -3168,171 +2181,170 @@
 "have to specify how Hibernate should obtain a reference to the "
 "<literal>TransactionManager</literal>:"
 msgstr ""
-"Hibernate的一些特性 (比如二级缓存, Contextual Sessions with JTA等等)需要访问"
-"在托管环境中的JTA <literal>TransactionManager</literal>. 由于J2EE没有标准化一"
-"个单一的机制,Hibernate在应用程序服务器中,你必须指定Hibernate如何获得"
-"<literal>TransactionManager</literal>的引用:"
+"Hibernate 的一些特性(比如二级缓存,Contextual Sessions with JTA 等等)需要访"
+"问在托管环境中的 JTA <literal>TransactionManager</literal>。由于 J2EE 没有标"
+"准化一个单一的机制,Hibernate 在应用程序服务器中,你必须指定 Hibernate 如何获"
+"得 <literal>TransactionManager</literal> 的引用: "
 
 #. Tag: title
-#: configuration.xml:1497
 #, no-c-format
 msgid "JTA TransactionManagers"
 msgstr "JTA TransactionManagers"
 
 #. Tag: entry
-#: configuration.xml:1503
 #, no-c-format
 msgid "Transaction Factory"
-msgstr "Transaction工厂类"
+msgstr "Transaction 工厂类"
 
 #. Tag: entry
-#: configuration.xml:1504
 #, no-c-format
 msgid "Application Server"
 msgstr "应用程序服务器"
 
-#. Tag: literal
-#: configuration.xml:1509
-#, no-c-format
-msgid "org.hibernate.transaction.JBossTransactionManagerLookup"
-msgstr "org.hibernate.transaction.JBossTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JBossTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JBossTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1510
 #, no-c-format
 msgid "JBoss"
 msgstr "JBoss"
 
-#. Tag: literal
-#: configuration.xml:1513
-#, no-c-format
-msgid "org.hibernate.transaction.WeblogicTransactionManagerLookup"
-msgstr "org.hibernate.transaction.WeblogicTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WeblogicTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. WeblogicTransactionManagerLookup</"
+"literal>"
 
 #. Tag: entry
-#: configuration.xml:1514
 #, no-c-format
 msgid "Weblogic"
 msgstr "Weblogic"
 
-#. Tag: literal
-#: configuration.xml:1517
-#, no-c-format
-msgid "org.hibernate.transaction.WebSphereTransactionManagerLookup"
-msgstr "org.hibernate.transaction.WebSphereTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WebSphereTransactionManagerLookup</"
+"literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. WebSphereTransactionManagerLookup</"
+"literal>"
 
 #. Tag: entry
-#: configuration.xml:1518
 #, no-c-format
 msgid "WebSphere"
 msgstr "WebSphere"
 
-#. Tag: literal
-#: configuration.xml:1521
-#, no-c-format
-msgid "org.hibernate.transaction.WebSphereExtendedJTATransactionLookup"
-msgstr "org.hibernate.transaction.WebSphereExtendedJTATransactionLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.WebSphereExtendedJTATransactionLookup</"
+"literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. WebSphereExtendedJTATransactionLookup</"
+"literal>"
 
 #. Tag: entry
-#: configuration.xml:1522
 #, no-c-format
 msgid "WebSphere 6"
 msgstr "WebSphere 6"
 
-#. Tag: literal
-#: configuration.xml:1525
-#, no-c-format
-msgid "org.hibernate.transaction.OrionTransactionManagerLookup"
-msgstr "org.hibernate.transaction.OrionTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.OrionTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. OrionTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1526
 #, no-c-format
 msgid "Orion"
 msgstr "Orion"
 
-#. Tag: literal
-#: configuration.xml:1529
-#, no-c-format
-msgid "org.hibernate.transaction.ResinTransactionManagerLookup"
-msgstr "org.hibernate.transaction.ResinTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.ResinTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. ResinTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1530
 #, no-c-format
 msgid "Resin"
 msgstr "Resin"
 
-#. Tag: literal
-#: configuration.xml:1533
-#, no-c-format
-msgid "org.hibernate.transaction.JOTMTransactionManagerLookup"
-msgstr "org.hibernate.transaction.JOTMTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JOTMTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JOTMTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1534
 #, no-c-format
 msgid "JOTM"
 msgstr "JOTM"
 
-#. Tag: literal
-#: configuration.xml:1537
-#, no-c-format
-msgid "org.hibernate.transaction.JOnASTransactionManagerLookup"
-msgstr "org.hibernate.transaction.JOnASTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JOnASTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JOnASTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1538
 #, no-c-format
 msgid "JOnAS"
 msgstr "JOnAS"
 
-#. Tag: literal
-#: configuration.xml:1541
-#, no-c-format
-msgid "org.hibernate.transaction.JRun4TransactionManagerLookup"
-msgstr "org.hibernate.transaction.JRun4TransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.JRun4TransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. JRun4TransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1542
 #, no-c-format
 msgid "JRun4"
 msgstr "JRun4"
 
-#. Tag: literal
-#: configuration.xml:1545
-#, no-c-format
-msgid "org.hibernate.transaction.BESTransactionManagerLookup"
-msgstr "org.hibernate.transaction.BESTransactionManagerLookup"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>org.hibernate.transaction.BESTransactionManagerLookup</literal>"
+msgstr ""
+"<literal>org.hibernate.transaction. BESTransactionManagerLookup</literal>"
 
 #. Tag: entry
-#: configuration.xml:1546
 #, no-c-format
 msgid "Borland ES"
 msgstr "Borland ES"
 
 #. Tag: title
-#: configuration.xml:1555
 #, no-c-format
 msgid "JNDI-bound <literal>SessionFactory</literal>"
-msgstr "JNDI绑定的<literal>SessionFactory</literal>"
+msgstr "JNDI 绑定的 <literal>SessionFactory</literal>"
 
 #. Tag: para
-#: configuration.xml:1557
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A JNDI-bound Hibernate <literal>SessionFactory</literal> can simplify the "
 "lookup function of the factory and create new <literal>Session</literal>s. "
 "This is not, however, related to a JNDI bound <literal>Datasource</literal>; "
 "both simply use the same registry."
 msgstr ""
-"与JNDI绑定的Hibernate的<literal>SessionFactory</literal>能简化工厂的查询,简"
-"化创建新的<literal>Session</literal>. 需要注意的是这与JNDI绑定"
-"<literal>Datasource</literal>没有关系, 它们只是恰巧用了相同的注册表!"
+"与 JNDI 绑定的 Hibernate 的 <literal>SessionFactory</literal> 能简化工厂的查"
+"询,简化创建新的 <literal>Session</literal>。需要注意的是这与 JNDI 绑定 "
+"<literal>Datasource</literal> 没有关系,它们只是恰巧用了相同的注册表。"
 
 #. Tag: para
-#: configuration.xml:1564
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you wish to have the <literal>SessionFactory</literal> bound to a JNDI "
 "namespace, specify a name (e.g. <literal>java:hibernate/SessionFactory</"
@@ -3341,14 +2353,13 @@
 "will not be bound to JNDI. This is especially useful in environments with a "
 "read-only JNDI default implementation (in Tomcat, for example)."
 msgstr ""
-"如果你希望将<literal>SessionFactory</literal>绑定到一个JNDI的名字空间, 用属性"
-"<literal>hibernate.session_factory_name</literal>指定一个名字(如, "
-"<literal>java:hibernate/SessionFactory</literal>). 如果不设置这个属性, "
-"<literal>SessionFactory</literal>将不会被绑定到JNDI中. (在以只读JNDI为默认实"
-"现的环境中,这个设置尤其有用, 如Tomcat.)"
+"如果你希望将 <literal>SessionFactory</literal> 绑定到一个 JNDI 的名字空间,用"
+"属性 <literal>hibernate.session_factory_name</literal> 指定一个名字(如,"
+"<literal>java:hibernate/SessionFactory</literal>)。如果不设置这个属性,"
+"<literal>SessionFactory</literal> 将不会被绑定到 JNDI 中(在以只读 JNDI 为默"
+"认实现的环境中,这个设置尤其有用,如 Tomcat)。"
 
 #. Tag: para
-#: configuration.xml:1572
 #, no-c-format
 msgid ""
 "When binding the <literal>SessionFactory</literal> to JNDI, Hibernate will "
@@ -3356,14 +2367,13 @@
 "jndi.class</literal> to instantiate an initial context. If they are not "
 "specified, the default <literal>InitialContext</literal> will be used."
 msgstr ""
-"在将<literal>SessionFactory</literal>绑定至JNDI时, Hibernate将使用"
-"<literal>hibernate.jndi.url</literal>, 和<literal>hibernate.jndi.class</"
-"literal>的值来实例化初始环境(initial context). 如果它们没有被指定, 将使用默认"
-"çš„<literal>InitialContext</literal>."
+"在将 <literal>SessionFactory</literal> 绑定至 JNDI 时,Hibernate 将使用 "
+"<literal>hibernate.jndi.url</literal>,和 <literal>hibernate.jndi.class</"
+"literal> 的值来实例化初始环境(initial context)。如果它们没有被指定,将使用"
+"默认的 <literal>InitialContext</literal>。"
 
 #. Tag: para
-#: configuration.xml:1579
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will automatically place the <literal>SessionFactory</literal> in "
 "JNDI after you call <literal>cfg.buildSessionFactory()</literal>. This means "
@@ -3372,25 +2382,23 @@
 "<literal>HibernateService</literal> (this is discussed later in greater "
 "detail)."
 msgstr ""
-"在你调用<literal>cfg.buildSessionFactory()</literal>后, Hibernate会自动将"
-"<literal>SessionFactory</literal>注册到JNDI. 这意味这你至少需要在你应用程序的"
-"启动代码(或工具类)中完成这个调用, 除非你使用<literal>HibernateService</"
-"literal>来做JMX部署 (见后面讨论)."
+"在你调用 <literal>cfg.buildSessionFactory()</literal>后,Hibernate 会自动将 "
+"<literal>SessionFactory</literal> 注册到 JNDI。这意味这你至少需要在你应用程序"
+"的启动代码(或工具类)中完成这个调用,除非你使用 <literal>HibernateService</"
+"literal> 来做 JMX 部署(见后面讨论)。"
 
 #. Tag: para
-#: configuration.xml:1586
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you use a JNDI <literal>SessionFactory</literal>, an EJB or any other "
 "class, you can obtain the <literal>SessionFactory</literal> using a JNDI "
 "lookup."
 msgstr ""
-"假若你使用JNDI <literal>SessionFactory</literal>,EJB或者任何其它类都可以从"
-"JNDI中找到此<literal>SessionFactory</literal>。"
+"假若你使用 JNDI <literal>SessionFactory</literal>,EJB 或者任何其它类都可以"
+"从 JNDI 中找到此 <literal>SessionFactory</literal>。 "
 
 #. Tag: para
-#: configuration.xml:1591
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you bind the <literal>SessionFactory</literal> to "
 "JNDI in a managed environment and use a <literal>static</literal> singleton "
@@ -3400,31 +2408,29 @@
 "()</literal>. Note that such a class is also a convenient way to startup "
 "Hibernate&mdash;see chapter 1."
 msgstr ""
-"我们建议,在受管理的环境中,把<literal>SessionFactory</literal>绑定到JNDI,在"
-"其它情况下,使用一个<literal>static(静态的)</literal>singleton。为了在你的应"
-"用程序代码中隐藏这些细节,我们还建议你用一个helper类把实际查找"
-"<literal>SessionFactory</literal>的代码隐藏起来,比如<literal>HibernateUtil."
-"getSessionFactory()</literal>。注意,这个类也就可以方便地启动Hibernate,参见"
-"第一章。"
+"我们建议,在受管理的环境中,把 <literal>SessionFactory</literal> 绑定到 "
+"JNDI,在其它情况下,使用一个 <literal>static(静态的)</literal>singleton。为"
+"了在你的应用程序代码中隐藏这些细节,我们还建议你用一个 helper 类把实际查找 "
+"<literal>SessionFactory</literal> 的代码隐藏起来,比如 "
+"<literal>HibernateUtil.getSessionFactory()</literal>。注意,这个类也就可以方"
+"便地启动 Hibernate,参见第一章。 "
 
 #. Tag: title
-#: configuration.xml:1603
 #, no-c-format
 msgid "Current Session context management with JTA"
-msgstr "在JTA环境下使用Current Session context (当前session上下文)管理"
+msgstr "在 JTA 环境下使用 Current Session context(当前 session 上下文)管理"
 
 #. Tag: para
-#: configuration.xml:1605
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The easiest way to handle <literal>Sessions</literal> and transactions is "
 "Hibernate's automatic \"current\" <literal>Session</literal> management. For "
-"a discussion of contextual sessions see <link linkend=\"architecture-current-"
-"session\"></link>. Using the <literal>\"jta\"</literal> session context, if "
-"there is no Hibernate <literal>Session</literal> associated with the current "
-"JTA transaction, one will be started and associated with that JTA "
-"transaction the first time you call <literal>sessionFactory.getCurrentSession"
-"()</literal>. The <literal>Session</literal>s retrieved via "
+"a discussion of contextual sessions see <xref linkend=\"architecture-current-"
+"session\" />. Using the <literal>\"jta\"</literal> session context, if there "
+"is no Hibernate <literal>Session</literal> associated with the current JTA "
+"transaction, one will be started and associated with that JTA transaction "
+"the first time you call <literal>sessionFactory.getCurrentSession()</"
+"literal>. The <literal>Session</literal>s retrieved via "
 "<literal>getCurrentSession()</literal> in the<literal>\"jta\"</literal> "
 "context are set to automatically flush before the transaction completes, "
 "close after the transaction completes, and aggressively release JDBC "
@@ -3437,30 +2443,29 @@
 "in an EJB container, declarative transaction demarcation with CMT is "
 "preferred."
 msgstr ""
-"在Hibernate中,管理<literal>Session</literal>和transaction最好的方法是自动的"
-"\"当前\"<literal>Session</literal>管理。请参见<xref linkend=\"architecture-"
-"current-session\">contextual sessions</xref>一节的讨论。使用<literal>\"jta"
-"\"</literal>session上下文,假若在当前JTA事务中还没有"
-"Hibernate<literal>Session</literal>关联,第一次<literal>sessionFactory."
-"getCurrentSession()</literal>调用会启动一个Session,并关联到当前的JTA事务。在"
-"<literal>\"jta\"</literal>上下文中调用<literal>getCurrentSession()</literal>"
-"获得的<literal>Session</literal>,会被设置为在transaction关闭的时候自动flush"
-"(清洗)、在transaction关闭之后自动关闭,每句语句之后主动释放JDBC连接。这就可"
-"以根据JTA事务的生命周期来管理与之关联的<literal>Session</literal>,用户代码中"
-"就可以不再考虑这些管理。你的代码也可以通过<literal>UserTransaction</literal>"
-"用编程方式使用JTA,或者(我们建议,为了便于移植代码)使用Hibernate的"
-"<literal>Transaction</literal> API来设置transaction边界。如果你的代码运行在"
-"EJB容器中,建议对CMT使用声明式事务声明。"
+"在 Hibernate 中,管理 <literal>Session</literal> 和 transaction 最好的方法是"
+"自动的\"当前\"<literal>Session</literal> 管理。请参见 <xref linkend="
+"\"architecture-current-session\" /> 一节的讨论。使用 <literal>\"jta\"</"
+"literal> session 上下文,假若在当前 JTA 事务中还没有 "
+"Hibernate<literal>Session</literal> 关联,第一次 <literal>sessionFactory."
+"getCurrentSession()</literal> 调用会启动一个 Session,并关联到当前的 JTA 事"
+"务。在 <literal>\"jta\"</literal> 上下文中调用 <literal>getCurrentSession()</"
+"literal> 获得的 <literal>Session</literal>,会被设置为在 transaction 关闭的时"
+"候自动 flush(清洗)、在 transaction 关闭之后自动关闭,每句语句之后主动释放 "
+"JDBC 连接。这就可以根据 JTA 事务的生命周期来管理与之关联的 <literal>Session</"
+"literal>,用户代码中就可以不再考虑这些管理。你的代码也可以通过 "
+"<literal>UserTransaction</literal>用编程方式使用 JTA,或者(我们建议,为了便"
+"于移植代码)使用 Hibernate 的 <literal>Transaction</literal> API 来设置 "
+"transaction 边界。如果你的代码运行在 EJB 容器中,我们建议对 CMT 使用声明式事"
+"务声明。 "
 
 #. Tag: title
-#: configuration.xml:1628
 #, no-c-format
 msgid "JMX deployment"
-msgstr "JMX部署"
+msgstr "JMX 部署"
 
 #. Tag: para
-#: configuration.xml:1630
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The line <literal>cfg.buildSessionFactory()</literal> still has to be "
 "executed somewhere to get a <literal>SessionFactory</literal> into JNDI. You "
@@ -3468,80 +2473,27 @@
 "the one in <literal>HibernateUtil</literal>, or you can deploy Hibernate as "
 "a <emphasis>managed service</emphasis>."
 msgstr ""
-"为了将<literal>SessionFactory</literal>注册到JNDI中,<literal>cfg."
-"buildSessionFactory()</literal>这行代码仍需在某处被执行. 你可在一个"
-"<literal>static</literal>初始化块(像<literal>HibernateUtil</literal>中的那样)"
-"中执行它或将Hibernate部署为一个<emphasis>托管的服务</emphasis>."
+"为了将 <literal>SessionFactory</literal> 注册到 JNDI 中,<literal>cfg."
+"buildSessionFactory()</literal> 这行代码仍需在某处被执行。你可在一个 "
+"<literal>static</literal> 初始化块(像 <literal>HibernateUtil</literal> 中的"
+"那样)中执行它或将 Hibernate 部署为一个<emphasis>托管的服务</emphasis>。  "
 
 #. Tag: para
-#: configuration.xml:1638
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate is distributed with <literal>org.hibernate.jmx.HibernateService</"
 "literal> for deployment on an application server with JMX capabilities, such "
 "as JBoss AS. The actual deployment and configuration is vendor-specific. "
 "Here is an example <literal>jboss-service.xml</literal> for JBoss 4.0.x:"
 msgstr ""
-"为了部署在一个支持JMX的应用程序服务器上,Hibernate和 <literal>org.hibernate."
-"jmx.HibernateService</literal>一同分发,如Jboss AS。 实际的部署和配置是由应用"
-"程序服务器提供者指定的. 这里是JBoss 4.0.x的<literal>jboss-service.xml</"
-"literal>样例:"
+"为了部署在一个支持 JMX 的应用程序服务器上,Hibernate 和 <literal>org."
+"hibernate.jmx.HibernateService</literal> 一同分发,如 Jboss AS。 实际的部署和"
+"配置是由应用程序服务器提供者指定的。这里是 JBoss 4.0.x 的 <literal>jboss-"
+"service.xml</literal> 样例: "
 
-#. Tag: programlisting
-#: configuration.xml:1645
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<server>\n"
-"\n"
-"<mbean code=\"org.hibernate.jmx.HibernateService\"\n"
-"    name=\"jboss.jca:service=HibernateFactory,name=HibernateFactory\">\n"
-"\n"
-"    <!-- Required services -->\n"
-"    <depends>jboss.jca:service=RARDeployer</depends>\n"
-"    <depends>jboss.jca:service=LocalTxCM,name=HsqlDS</depends>\n"
-"\n"
-"    <!-- Bind the Hibernate service to JNDI -->\n"
-"    <attribute name=\"JndiName\">java:/hibernate/SessionFactory</attribute>\n"
-"\n"
-"    <!-- Datasource settings -->\n"
-"    <attribute name=\"Datasource\">java:HsqlDS</attribute>\n"
-"    <attribute name=\"Dialect\">org.hibernate.dialect.HSQLDialect</"
-"attribute>\n"
-"\n"
-"    <!-- Transaction integration -->\n"
-"    <attribute name=\"TransactionStrategy\">\n"
-"        org.hibernate.transaction.JTATransactionFactory</attribute>\n"
-"    <attribute name=\"TransactionManagerLookupStrategy\">\n"
-"        org.hibernate.transaction.JBossTransactionManagerLookup</attribute>\n"
-"    <attribute name=\"FlushBeforeCompletionEnabled\">true</attribute>\n"
-"    <attribute name=\"AutoCloseSessionEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Fetching options -->\n"
-"    <attribute name=\"MaximumFetchDepth\">5</attribute>\n"
-"\n"
-"    <!-- Second-level caching -->\n"
-"    <attribute name=\"SecondLevelCacheEnabled\">true</attribute>\n"
-"    <attribute name=\"CacheProviderClass\">org.hibernate.cache."
-"EhCacheProvider</attribute>\n"
-"    <attribute name=\"QueryCacheEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Logging -->\n"
-"    <attribute name=\"ShowSqlEnabled\">true</attribute>\n"
-"\n"
-"    <!-- Mapping files -->\n"
-"    <attribute name=\"MapResources\">auction/Item.hbm.xml,auction/Category."
-"hbm.xml</attribute>\n"
-"\n"
-"</mbean>\n"
-"\n"
-"</server>]]>"
-msgstr ""
-
-#. Tag: para
-#: configuration.xml:1647
-#, fuzzy, no-c-format
-msgid ""
 "This file is deployed in a directory called <literal>META-INF</literal> and "
 "packaged in a JAR file with the extension <literal>.sar</literal> (service "
 "archive). You also need to package Hibernate, its required third-party "
@@ -3552,238 +2504,323 @@
 "JBoss AS documentation for more information about JMX service and EJB "
 "deployment."
 msgstr ""
-"这个文件是部署在<literal>META-INF</literal>目录下的, 并会被打包到以<literal>."
-"sar</literal> (service archive)为扩展名的JAR文件中. 同时,你需要将Hibernate、"
-"它所需要的第三方库、你编译好的持久化类以及你的映射定义文件打包进同一个文档. "
-"你的企业Bean(一般为会话Bean)可能会被打包成它们自己的JAR文件, 但你也许会将EJB "
-"JAR文件一同包含进能独立(热)部署的主服务文档. 参考JBoss AS文档以了解更多的JMX"
-"服务与EJB部署的信息."
+"这个文件是部署在 <literal>META-INF</literal> 目录下的,并会被打包到以 "
+"<literal>.sar</literal>(service archive)为扩展名的 JAR 文件中。同时,你需要"
+"将 Hibernate、它所需要的第三方库、你编译好的持久化类以及你的映射定义文件打包"
+"进同一个文档。你的企业 Bean(一般为会话 Bean)可能会被打包成它们自己的 JAR 文"
+"件,但你也许会将 EJB JAR 文件一同包含进能独立(热)部署的主服务文档。参考 "
+"JBoss AS 文档以了解更多的 JMX服务与 EJB 部署的信息。 "
 
 #~ msgid ""
-#~ "<literal>hibernate.properties</literal> is the easiest approach if you "
-#~ "want to get started quickly."
+#~ "<![CDATA[Configuration cfg = new Configuration()\n"
+#~ "    .addResource(\"Item.hbm.xml\")\n"
+#~ "    .addResource(\"Bid.hbm.xml\");]]>"
 #~ msgstr ""
-#~ "如果想尽快体验Hibernate, <literal>hibernate.properties</literal>是最简单的"
-#~ "方式."
+#~ "<![CDATA[Configuration cfg = new Configuration()\n"
+#~ "    .addResource(\"Item.hbm.xml\")\n"
+#~ "    .addResource(\"Bid.hbm.xml\");]]>"
 
-#~ msgid "Hibernate logs various events using Apache commons-logging."
-#~ msgstr "Hibernate使用Apache commons-logging来为各种事件记录日志."
+#~ msgid ""
+#~ "<![CDATA[Configuration cfg = new Configuration()\n"
+#~ "    .addClass(org.hibernate.auction.Item.class)\n"
+#~ "    .addClass(org.hibernate.auction.Bid.class);]]>"
+#~ msgstr ""
+#~ "<![CDATA[Configuration cfg = new Configuration()\n"
+#~ "    .addClass(org.hibernate.auction.Item.class)\n"
+#~ "    .addClass(org.hibernate.auction.Bid.class);]]>"
 
 #~ msgid ""
-#~ "The commons-logging service will direct output to either Apache Log4j (if "
-#~ "you include <literal>log4j.jar</literal> in your classpath) or JDK1.4 "
-#~ "logging (if running under JDK1.4 or above). You may download Log4j from "
-#~ "<literal>http://jakarta.apache.org</literal>. To use Log4j you will need "
-#~ "to place a <literal>log4j.properties</literal> file in your classpath, an "
-#~ "example properties file is distributed with Hibernate in the <literal>src/"
-#~ "</literal> directory."
+#~ "<![CDATA[Configuration cfg = new Configuration()\n"
+#~ "    .addClass(org.hibernate.auction.Item.class)\n"
+#~ "    .addClass(org.hibernate.auction.Bid.class)\n"
+#~ "    .setProperty(\"hibernate.dialect\", \"org.hibernate.dialect."
+#~ "MySQLInnoDBDialect\")\n"
+#~ "    .setProperty(\"hibernate.connection.datasource\", \"java:comp/env/"
+#~ "jdbc/test\")\n"
+#~ "    .setProperty(\"hibernate.order_updates\", \"true\");]]>"
 #~ msgstr ""
-#~ "commons-logging将直接输出到Apache Log4j(如果在类路径中包括<literal>log4j."
-#~ "jar</literal>)或 JDK1.4 logging (如果运行在JDK1.4或以上的环境下). 你可以从"
-#~ "<literal>http://jakarta.apache.org</literal> 下载Log4j. 要使用Log4j,你需"
-#~ "要将<literal>log4j.properties</literal>文件放置在类路径下, 随Hibernate 一"
-#~ "同分发的样例属性文件在<literal>src/</literal>目录下."
+#~ "<![CDATA[Configuration cfg = new Configuration()\n"
+#~ "    .addClass(org.hibernate.auction.Item.class)\n"
+#~ "    .addClass(org.hibernate.auction.Bid.class)\n"
+#~ "    .setProperty(\"hibernate.dialect\", \"org.hibernate.dialect."
+#~ "MySQLInnoDBDialect\")\n"
+#~ "    .setProperty(\"hibernate.connection.datasource\", \"java:comp/env/"
+#~ "jdbc/test\")\n"
+#~ "    .setProperty(\"hibernate.order_updates\", \"true\");]]>"
 
-#~ msgid "<placeholder-1/> (optional)"
-#~ msgstr "<placeholder-1/> (可选)"
+#~ msgid "<![CDATA[SessionFactory sessions = cfg.buildSessionFactory();]]>"
+#~ msgstr "<![CDATA[SessionFactory sessions = cfg.buildSessionFactory();]]>"
 
-#~ msgid "InitialContextFactory"
-#~ msgstr "InitialContextFactory"
-
-#~ msgid "class of the JNDI <placeholder-1/>"
-#~ msgstr "JNDI <placeholder-1/>ç±»"
-
-#, fuzzy
-#~ msgid "eg."
+#~ msgid ""
+#~ "<![CDATA[Session session = sessions.openSession(); // open a new Session]]"
+#~ ">"
 #~ msgstr ""
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "eg.\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "取值"
+#~ "<![CDATA[Session session = sessions.openSession(); // open a new Session]]"
+#~ ">"
 
-#~ msgid "full.classname.of.Dialect"
-#~ msgstr "full.classname.of.Dialect"
+#~ msgid "JDBC URL"
+#~ msgstr "JDBC URL"
 
-#~ msgid "debug"
-#~ msgstr "debug"
+#~ msgid "database user"
+#~ msgstr "database user"
 
-#~ msgid "SCHEMA_NAME"
-#~ msgstr "SCHEMA_NAME"
+#~ msgid "database user password"
+#~ msgstr "数据库用户密码"
 
-#~ msgid "CATALOG_NAME"
-#~ msgstr "CATALOG_NAME"
+#~ msgid ""
+#~ "<![CDATA[hibernate.connection.driver_class = org.postgresql.Driver\n"
+#~ "hibernate.connection.url = jdbc:postgresql://localhost/mydatabase\n"
+#~ "hibernate.connection.username = myuser\n"
+#~ "hibernate.connection.password = secret\n"
+#~ "hibernate.c3p0.min_size=5\n"
+#~ "hibernate.c3p0.max_size=20\n"
+#~ "hibernate.c3p0.timeout=1800\n"
+#~ "hibernate.c3p0.max_statements=50\n"
+#~ "hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
+#~ msgstr ""
+#~ "<![CDATA[hibernate.connection.driver_class = org.postgresql.Driver\n"
+#~ "hibernate.connection.url = jdbc:postgresql://localhost/mydatabase\n"
+#~ "hibernate.connection.username = myuser\n"
+#~ "hibernate.connection.password = secret\n"
+#~ "hibernate.c3p0.min_size=5\n"
+#~ "hibernate.c3p0.max_size=20\n"
+#~ "hibernate.c3p0.timeout=1800\n"
+#~ "hibernate.c3p0.max_statements=50\n"
+#~ "hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
 
-#~ msgid "SessionFactory"
-#~ msgstr "SessionFactory"
+#~ msgid "datasource JNDI name"
+#~ msgstr "数据源 JNDI 名字"
 
-#~ msgid "jndi/composite/name"
-#~ msgstr "jndi/composite/name"
+#~ msgid ""
+#~ "<![CDATA[hibernate.connection.datasource = java:/comp/env/jdbc/test\n"
+#~ "hibernate.transaction.factory_class = \\\n"
+#~ "    org.hibernate.transaction.JTATransactionFactory\n"
+#~ "hibernate.transaction.manager_lookup_class = \\\n"
+#~ "    org.hibernate.transaction.JBossTransactionManagerLookup\n"
+#~ "hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
+#~ msgstr ""
+#~ "<![CDATA[hibernate.connection.datasource = java:/comp/env/jdbc/test\n"
+#~ "hibernate.transaction.factory_class = \\\n"
+#~ "    org.hibernate.transaction.JTATransactionFactory\n"
+#~ "hibernate.transaction.manager_lookup_class = \\\n"
+#~ "    org.hibernate.transaction.JBossTransactionManagerLookup\n"
+#~ "hibernate.dialect = org.hibernate.dialect.PostgreSQLDialect]]>"
 
-#~ msgid "0"
-#~ msgstr "0"
+#~ msgid "<entry>DB2</entry>"
+#~ msgstr "<entry>DB2</entry>"
 
-#~ msgid "false"
-#~ msgstr "false"
+#~ msgid "hibernate.query.substitutions true=1, false=0"
+#~ msgstr "hibernate.query.substitutions true=1,false=0"
 
-#~ msgid "Statement.setFetchSize()"
-#~ msgstr "Statement.setFetchSize()"
+#~ msgid "hibernate.query.substitutions toLowercase=LOWER"
+#~ msgstr "hibernate.query.substitutions toLowercase=LOWER"
 
-#~ msgid "true"
-#~ msgstr "executeBatch()"
+#~ msgid "org.hibernate"
+#~ msgstr "org.hibernate"
 
-#~ msgid "executeBatch()"
-#~ msgstr "true"
+#~ msgid ""
+#~ "<![CDATA[SessionFactory sf = new Configuration()\n"
+#~ "    .setNamingStrategy(ImprovedNamingStrategy.INSTANCE)\n"
+#~ "    .addFile(\"Item.hbm.xml\")\n"
+#~ "    .addFile(\"Bid.hbm.xml\")\n"
+#~ "    .buildSessionFactory();]]>"
+#~ msgstr ""
+#~ "<![CDATA[SessionFactory sf = new Configuration()\n"
+#~ "    .setNamingStrategy(ImprovedNamingStrategy.INSTANCE)\n"
+#~ "    .addFile(\"Item.hbm.xml\")\n"
+#~ "    .addFile(\"Bid.hbm.xml\")\n"
+#~ "    .buildSessionFactory();]]>"
 
-#~ msgid "Batcher"
-#~ msgstr "Batcher"
+#~ msgid ""
+#~ "<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
+#~ "<!DOCTYPE hibernate-configuration PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Configuration DTD//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
+#~ "\">\n"
+#~ "\n"
+#~ "<hibernate-configuration>\n"
+#~ "\n"
+#~ "    <!-- a SessionFactory instance listed as /jndi/name -->\n"
+#~ "    <session-factory\n"
+#~ "        name=\"java:hibernate/SessionFactory\">\n"
+#~ "\n"
+#~ "        <!-- properties -->\n"
+#~ "        <property name=\"connection.datasource\">java:/comp/env/jdbc/"
+#~ "MyDB</property>\n"
+#~ "        <property name=\"dialect\">org.hibernate.dialect.MySQLDialect</"
+#~ "property>\n"
+#~ "        <property name=\"show_sql\">false</property>\n"
+#~ "        <property name=\"transaction.factory_class\">\n"
+#~ "            org.hibernate.transaction.JTATransactionFactory\n"
+#~ "        </property>\n"
+#~ "        <property name=\"jta.UserTransaction\">java:comp/UserTransaction</"
+#~ "property>\n"
+#~ "\n"
+#~ "        <!-- mapping files -->\n"
+#~ "        <mapping resource=\"org/hibernate/auction/Item.hbm.xml\"/>\n"
+#~ "        <mapping resource=\"org/hibernate/auction/Bid.hbm.xml\"/>\n"
+#~ "\n"
+#~ "        <!-- cache settings -->\n"
+#~ "        <class-cache class=\"org.hibernate.auction.Item\" usage=\"read-"
+#~ "write\"/>\n"
+#~ "        <class-cache class=\"org.hibernate.auction.Bid\" usage=\"read-only"
+#~ "\"/>\n"
+#~ "        <collection-cache collection=\"org.hibernate.auction.Item.bids\" "
+#~ "usage=\"read-write\"/>\n"
+#~ "\n"
+#~ "    </session-factory>\n"
+#~ "\n"
+#~ "</hibernate-configuration>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
+#~ "<!DOCTYPE hibernate-configuration PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Configuration DTD//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
+#~ "\">\n"
+#~ "\n"
+#~ "<hibernate-configuration>\n"
+#~ "\n"
+#~ "    <!-- a SessionFactory instance listed as /jndi/name -->\n"
+#~ "    <session-factory\n"
+#~ "        name=\"java:hibernate/SessionFactory\">\n"
+#~ "\n"
+#~ "        <!-- properties -->\n"
+#~ "        <property name=\"connection.datasource\">java:/comp/env/jdbc/"
+#~ "MyDB</property>\n"
+#~ "        <property name=\"dialect\">org.hibernate.dialect.MySQLDialect</"
+#~ "property>\n"
+#~ "        <property name=\"show_sql\">false</property>\n"
+#~ "        <property name=\"transaction.factory_class\">\n"
+#~ "            org.hibernate.transaction.JTATransactionFactory\n"
+#~ "        </property>\n"
+#~ "        <property name=\"jta.UserTransaction\">java:comp/UserTransaction</"
+#~ "property>\n"
+#~ "\n"
+#~ "        <!-- mapping files -->\n"
+#~ "        <mapping resource=\"org/hibernate/auction/Item.hbm.xml\"/>\n"
+#~ "        <mapping resource=\"org/hibernate/auction/Bid.hbm.xml\"/>\n"
+#~ "\n"
+#~ "        <!-- cache settings -->\n"
+#~ "        <class-cache class=\"org.hibernate.auction.Item\" usage=\"read-"
+#~ "write\"/>\n"
+#~ "        <class-cache class=\"org.hibernate.auction.Bid\" usage=\"read-only"
+#~ "\"/>\n"
+#~ "        <collection-cache collection=\"org.hibernate.auction.Item.bids\" "
+#~ "usage=\"read-write\"/>\n"
+#~ "\n"
+#~ "    </session-factory>\n"
+#~ "\n"
+#~ "</hibernate-configuration>]]>"
 
-#~ msgid "classname.of.BatcherFactory"
-#~ msgstr "classname.of.BatcherFactory"
+#~ msgid ""
+#~ "<![CDATA[SessionFactory sf = new Configuration().configure()."
+#~ "buildSessionFactory();]]>"
+#~ msgstr ""
+#~ "<![CDATA[SessionFactory sf = new Configuration().configure()."
+#~ "buildSessionFactory();]]>"
 
-#~ msgid "binary"
-#~ msgstr "binary (二进制)"
+#~ msgid ""
+#~ "<![CDATA[SessionFactory sf = new Configuration()\n"
+#~ "    .configure(\"catdb.cfg.xml\")\n"
+#~ "    .buildSessionFactory();]]>"
+#~ msgstr ""
+#~ "<![CDATA[SessionFactory sf = new Configuration()\n"
+#~ "    .configure(\"catdb.cfg.xml\")\n"
+#~ "    .buildSessionFactory();]]>"
 
-#~ msgid "serializable"
-#~ msgstr "serializable (可序列化)"
-
-#~ msgid "PreparedStatement.getGeneratedKeys()"
-#~ msgstr "PreparedStatement.getGeneratedKeys()"
-
-#~ msgid "true|false"
-#~ msgstr "true|false"
-
-#~ msgid "ConnectionProvider"
-#~ msgstr "ConnectionProvider"
-
-#~ msgid "classname.of.ConnectionProvider"
-#~ msgstr "classname.of.ConnectionProvider"
-
-#~ msgid "java.sql.Connection"
-#~ msgstr "java.sql.Connection"
-
-#~ msgid "1, 2, 4, 8"
-#~ msgstr "1, 2, 4, 8"
-
-#~ msgid "after_statement"
-#~ msgstr "after_statement"
-
-#~ msgid "after_transaction"
-#~ msgstr "after_transaction"
-
-#~ msgid "auto"
-#~ msgstr "auto"
-
-#~ msgid "&lt;propertyName&gt;"
-#~ msgstr "&lt;propertyName&gt;"
-
-#~ msgid "hibernate.connection.<placeholder-1/>"
-#~ msgstr "hibernate.connection.<placeholder-1/>"
-
-#~ msgid "propertyName"
-#~ msgstr "propertyName"
-
-#~ msgid "DriverManager.getConnection()"
-#~ msgstr "DriverManager.getConnection()"
-
-#~ msgid "Pass the JDBC property <placeholder-1/> to <placeholder-2/>."
-#~ msgstr "将JDBC属性<placeholder-1/>传递到<placeholder-2/>中去."
-
-#~ msgid "hibernate.jndi.<placeholder-1/>"
-#~ msgstr "hibernate.jndi.<placeholder-1/>"
-
-#~ msgid "Pass the property <placeholder-1/> to the JNDI <placeholder-2/>."
-#~ msgstr "将属性<placeholder-1/>传递到JNDI <placeholder-2/>中去."
-
-#~ msgid "CacheProvider"
-#~ msgstr "CacheProvider"
-
-#~ msgid "classname.of.CacheProvider"
-#~ msgstr "classname.of.CacheProvider"
-
-#~ msgid "&lt;cache&gt;"
-#~ msgstr "&lt;cache&gt;"
-
-#~ msgid "QueryCache"
-#~ msgstr "QueryCache"
-
-#~ msgid "StandardQueryCache"
-#~ msgstr "StandardQueryCache"
-
-#~ msgid "classname.of.QueryCache"
-#~ msgstr "classname.of.QueryCache"
-
-#~ msgid "prefix"
-#~ msgstr "prefix"
-
-#~ msgid "TransactionFactory"
-#~ msgstr "TransactionFactory"
-
-#~ msgid "Transaction"
-#~ msgstr "Transaction"
-
-#~ msgid "JDBCTransactionFactory"
-#~ msgstr "JDBCTransactionFactory"
-
-#~ msgid "classname.of.TransactionFactory"
-#~ msgstr "classname.of.TransactionFactory"
-
-#~ msgid "JTATransactionFactory"
-#~ msgstr "JTATransactionFactory"
-
-#~ msgid "UserTransaction"
-#~ msgstr "UserTransaction"
-
-#~ msgid "TransactionManagerLookup"
-#~ msgstr "TransactionManagerLookup"
-
-#~ msgid "classname.of.TransactionManagerLookup"
-#~ msgstr "classname.of.TransactionManagerLookup"
-
-#~ msgid "Session"
-#~ msgstr "Session"
-
-#~ msgid "hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC"
-#~ msgstr "hqlLiteral=SQL_LITERAL, hqlFunction=SQLFUNC"
-
-#~ msgid "create-drop"
-#~ msgstr "create-drop"
-
-#~ msgid "hibernate.cfg.xml"
-#~ msgstr "hibernate.cfg.xml"
-
-#~ msgid "DB2"
-#~ msgstr "DB2"
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<server>\n"
+#~ "\n"
+#~ "<mbean code=\"org.hibernate.jmx.HibernateService\"\n"
+#~ "    name=\"jboss.jca:service=HibernateFactory,name=HibernateFactory\">\n"
+#~ "\n"
+#~ "    <!-- Required services -->\n"
+#~ "    <depends>jboss.jca:service=RARDeployer</depends>\n"
+#~ "    <depends>jboss.jca:service=LocalTxCM,name=HsqlDS</depends>\n"
+#~ "\n"
+#~ "    <!-- Bind the Hibernate service to JNDI -->\n"
+#~ "    <attribute name=\"JndiName\">java:/hibernate/SessionFactory</"
+#~ "attribute>\n"
+#~ "\n"
+#~ "    <!-- Datasource settings -->\n"
+#~ "    <attribute name=\"Datasource\">java:HsqlDS</attribute>\n"
+#~ "    <attribute name=\"Dialect\">org.hibernate.dialect.HSQLDialect</"
+#~ "attribute>\n"
+#~ "\n"
+#~ "    <!-- Transaction integration -->\n"
+#~ "    <attribute name=\"TransactionStrategy\">\n"
+#~ "        org.hibernate.transaction.JTATransactionFactory</attribute>\n"
+#~ "    <attribute name=\"TransactionManagerLookupStrategy\">\n"
+#~ "        org.hibernate.transaction.JBossTransactionManagerLookup</"
+#~ "attribute>\n"
+#~ "    <attribute name=\"FlushBeforeCompletionEnabled\">true</attribute>\n"
+#~ "    <attribute name=\"AutoCloseSessionEnabled\">true</attribute>\n"
+#~ "\n"
+#~ "    <!-- Fetching options -->\n"
+#~ "    <attribute name=\"MaximumFetchDepth\">5</attribute>\n"
+#~ "\n"
+#~ "    <!-- Second-level caching -->\n"
+#~ "    <attribute name=\"SecondLevelCacheEnabled\">true</attribute>\n"
+#~ "    <attribute name=\"CacheProviderClass\">org.hibernate.cache."
+#~ "EhCacheProvider</attribute>\n"
+#~ "    <attribute name=\"QueryCacheEnabled\">true</attribute>\n"
+#~ "\n"
+#~ "    <!-- Logging -->\n"
+#~ "    <attribute name=\"ShowSqlEnabled\">true</attribute>\n"
+#~ "\n"
+#~ "    <!-- Mapping files -->\n"
+#~ "    <attribute name=\"MapResources\">auction/Item.hbm.xml,auction/"
+#~ "Category.hbm.xml</attribute>\n"
+#~ "\n"
+#~ "</mbean>\n"
+#~ "\n"
+#~ "</server>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<server>\n"
+#~ "\n"
+#~ "<mbean code=\"org.hibernate.jmx.HibernateService\"\n"
+#~ "    name=\"jboss.jca:service=HibernateFactory,name=HibernateFactory\">\n"
+#~ "\n"
+#~ "    <!-- Required services -->\n"
+#~ "    <depends>jboss.jca:service=RARDeployer</depends>\n"
+#~ "    <depends>jboss.jca:service=LocalTxCM,name=HsqlDS</depends>\n"
+#~ "\n"
+#~ "    <!-- Bind the Hibernate service to JNDI -->\n"
+#~ "    <attribute name=\"JndiName\">java:/hibernate/SessionFactory</"
+#~ "attribute>\n"
+#~ "\n"
+#~ "    <!-- Datasource settings -->\n"
+#~ "    <attribute name=\"Datasource\">java:HsqlDS</attribute>\n"
+#~ "    <attribute name=\"Dialect\">org.hibernate.dialect.HSQLDialect</"
+#~ "attribute>\n"
+#~ "\n"
+#~ "    <!-- Transaction integration -->\n"
+#~ "    <attribute name=\"TransactionStrategy\">\n"
+#~ "        org.hibernate.transaction.JTATransactionFactory</attribute>\n"
+#~ "    <attribute name=\"TransactionManagerLookupStrategy\">\n"
+#~ "        org.hibernate.transaction.JBossTransactionManagerLookup</"
+#~ "attribute>\n"
+#~ "    <attribute name=\"FlushBeforeCompletionEnabled\">true</attribute>\n"
+#~ "    <attribute name=\"AutoCloseSessionEnabled\">true</attribute>\n"
+#~ "\n"
+#~ "    <!-- Fetching options -->\n"
+#~ "    <attribute name=\"MaximumFetchDepth\">5</attribute>\n"
+#~ "\n"
+#~ "    <!-- Second-level caching -->\n"
+#~ "    <attribute name=\"SecondLevelCacheEnabled\">true</attribute>\n"
+#~ "    <attribute name=\"CacheProviderClass\">org.hibernate.cache."
+#~ "EhCacheProvider</attribute>\n"
+#~ "    <attribute name=\"QueryCacheEnabled\">true</attribute>\n"
+#~ "\n"
+#~ "    <!-- Logging -->\n"
+#~ "    <attribute name=\"ShowSqlEnabled\">true</attribute>\n"
+#~ "\n"
+#~ "    <!-- Mapping files -->\n"
+#~ "    <attribute name=\"MapResources\">auction/Item.hbm.xml,auction/"
+#~ "Category.hbm.xml</attribute>\n"
+#~ "\n"
+#~ "</mbean>\n"
+#~ "\n"
+#~ "</server>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/events.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/events.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/events.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,41 +1,41 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:34\n"
+"PO-Revision-Date: 2009-11-23 09:36+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: events.xml:29
 #, no-c-format
 msgid "Interceptors and events"
-msgstr "拦截器与事件(Interceptors and events)"
+msgstr "拦截器与事件(Interceptors and events)"
 
 #. Tag: para
-#: events.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is useful for the application to react to certain events that occur "
 "inside Hibernate. This allows for the implementation of generic "
 "functionality and the extension of Hibernate functionality."
 msgstr ""
-"应用程序能够响应Hibernate内部产生的特定事件是非常有用的。这样就允许实现某些通"
-"用的功能 以及允许对Hibernate功能进行扩展。"
+"应用程序能够响应 Hibernate 内部产生的特定事件是非常有用的。这样就允许实现某些"
+"通用的功能以及允许对 Hibernate 功能进行扩展。"
 
 #. Tag: title
-#: events.xml:38
 #, no-c-format
 msgid "Interceptors"
-msgstr "拦截器(Interceptors)"
+msgstr "拦截器(Interceptors)"
 
 #. Tag: para
-#: events.xml:40
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>Interceptor</literal> interface provides callbacks from the "
 "session to the application, allowing the application to inspect and/or "
@@ -47,145 +47,46 @@
 "<literal>lastUpdateTimestamp</literal> property when an <literal>Auditable</"
 "literal> is updated."
 msgstr ""
-"<literal>Interceptor</literal>接口提供了从会话(session)回调(callback)应用程序"
-"(application)的机制, 这种回调机制可以允许应用程序在持久化对象被保存、更新、"
-"删除或是加载之前,检查并(或)修改其 属性。一个可能的用途,就是用来跟踪审核"
-"(auditing)信息。例如:下面的这个<literal>拦截器</literal>,会在一个实现了 "
-"<literal>Auditable</literal>接口的对象被创建时自动地设置"
-"<literal>createTimestamp</literal>属性,并在实现了 <literal>Auditable</"
-"literal>接口的对象被更新时,同步更新<literal>lastUpdateTimestamp</literal>属"
-"性。"
+"<literal>Interceptor</literal> 接口提供了从会话(session)回调(callback)应"
+"用程序(application)的机制, 这种回调机制可以允许应用程序在持久化对象被保"
+"存、更新、删除或是加载之前,检查并(或)修改其 属性。一个可能的用途,就是用来"
+"跟踪审核(auditing)信息。例如:下面的这个<literal>拦截器</literal>,会在一个"
+"实现了 <literal>Auditable</literal> 接口的对象被创建时自动地设置 "
+"<literal>createTimestamp</literal> 属性,并在实现了 <literal>Auditable</"
+"literal> 接口的对象被更新时,同步更新 <literal>lastUpdateTimestamp</literal> "
+"属性。 "
 
 #. Tag: para
-#: events.xml:51
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can either implement <literal>Interceptor</literal> directly or extend "
 "<literal>EmptyInterceptor</literal>."
 msgstr ""
-"你可以直接实现<literal>Interceptor</literal>接口,也可以(最好)继承自"
-"<literal>EmptyInterceptor</literal>。"
+"你可以直接实现 <literal>Interceptor</literal> 接口,也可以(最好)继承自 "
+"<literal>EmptyInterceptor</literal>。 "
 
-#. Tag: programlisting
-#: events.xml:56
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[package org.hibernate.test;\n"
-"\n"
-"import java.io.Serializable;\n"
-"import java.util.Date;\n"
-"import java.util.Iterator;\n"
-"\n"
-"import org.hibernate.EmptyInterceptor;\n"
-"import org.hibernate.Transaction;\n"
-"import org.hibernate.type.Type;\n"
-"\n"
-"public class AuditInterceptor extends EmptyInterceptor {\n"
-"\n"
-"    private int updates;\n"
-"    private int creates;\n"
-"    private int loads;\n"
-"\n"
-"    public void onDelete(Object entity,\n"
-"                         Serializable id,\n"
-"                         Object[] state,\n"
-"                         String[] propertyNames,\n"
-"                         Type[] types) {\n"
-"        // do nothing\n"
-"    }\n"
-"\n"
-"    public boolean onFlushDirty(Object entity,\n"
-"                                Serializable id,\n"
-"                                Object[] currentState,\n"
-"                                Object[] previousState,\n"
-"                                String[] propertyNames,\n"
-"                                Type[] types) {\n"
-"\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            updates++;\n"
-"            for ( int i=0; i < propertyNames.length; i++ ) {\n"
-"                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) {\n"
-"                    currentState[i] = new Date();\n"
-"                    return true;\n"
-"                }\n"
-"            }\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public boolean onLoad(Object entity,\n"
-"                          Serializable id,\n"
-"                          Object[] state,\n"
-"                          String[] propertyNames,\n"
-"                          Type[] types) {\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            loads++;\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public boolean onSave(Object entity,\n"
-"                          Serializable id,\n"
-"                          Object[] state,\n"
-"                          String[] propertyNames,\n"
-"                          Type[] types) {\n"
-"\n"
-"        if ( entity instanceof Auditable ) {\n"
-"            creates++;\n"
-"            for ( int i=0; i<propertyNames.length; i++ ) {\n"
-"                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
-"                    state[i] = new Date();\n"
-"                    return true;\n"
-"                }\n"
-"            }\n"
-"        }\n"
-"        return false;\n"
-"    }\n"
-"\n"
-"    public void afterTransactionCompletion(Transaction tx) {\n"
-"        if ( tx.wasCommitted() ) {\n"
-"            System.out.println(\"Creations: \" + creates + \", Updates: \" + "
-"updates, \"Loads: \" + loads);\n"
-"        }\n"
-"        updates=0;\n"
-"        creates=0;\n"
-"        loads=0;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:58
-#, fuzzy, no-c-format
-msgid ""
 "There are two kinds of inteceptors: <literal>Session</literal>-scoped and "
 "<literal>SessionFactory</literal>-scoped."
 msgstr ""
-"拦截器可以有两种:<literal>Session</literal>范围内的,和"
-"<literal>SessionFactory</literal>范围内的。"
+"拦截器可以有两种:<literal>Session</literal> 范围内的和 "
+"<literal>SessionFactory</literal> 范围内的。"
 
 #. Tag: para
-#: events.xml:63
 #, no-c-format
 msgid ""
 "A <literal>Session</literal>-scoped interceptor is specified when a session "
 "is opened using one of the overloaded SessionFactory.openSession() methods "
 "accepting an <literal>Interceptor</literal>."
 msgstr ""
-"当使用某个重载的SessionFactory.openSession()使用<literal>Interceptor</"
-"literal>作为参数调用打开一个session的时候,就指定了<literal>Session</literal>"
-"范围内的拦截器。"
+"当使用某个重载的 SessionFactory.openSession() 使用 <literal>Interceptor</"
+"literal> 作为参数调用打开一个 session 的时候,就指定了 <literal>Session</"
+"literal> 范围内的拦截器。"
 
-#. Tag: programlisting
-#: events.xml:69
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:71
-#, fuzzy, no-c-format
 msgid ""
 "A <literal>SessionFactory</literal>-scoped interceptor is registered with "
 "the <literal>Configuration</literal> object prior to building the "
@@ -196,40 +97,31 @@
 "Ensure that you do not store session-specific states, since multiple "
 "sessions will use this interceptor potentially concurrently."
 msgstr ""
-"<literal>SessionFactory</literal>范围内的拦截器要通过<literal>Configuration</"
-"literal>中注册,而这必须在创建<literal>SessionFactory</literal>之前。在这种情"
-"况下,给出的拦截器会被这个<literal>SessionFactory</literal>所打开的所有"
-"session使用了;除非session打开时明确指明了使用的拦截器。"
-"<literal>SessionFactory</literal>范围内的拦截器,必须是线程安全的,因为多个"
-"session可能并发使用这个拦截器,要因此小心不要保存与session相关的状态。"
+"<literal>SessionFactory</literal> 范围内的拦截器要通过 "
+"<literal>Configuration</literal> 中注册,而这必须在创建 "
+"<literal>SessionFactory</literal> 之前。在这种情况下,给出的拦截器会被这个 "
+"<literal>SessionFactory</literal> 所打开的所有 session 使用了;除非 session "
+"打开时明确指明了使用的拦截器。<literal>SessionFactory</literal> 范围内的拦截"
+"器,必须是线程安全的。确保你没有保存 session 专有的状态,因为多个 session 可"
+"能并发使用这个拦截器。"
 
-#. Tag: programlisting
-#: events.xml:80
-#, no-c-format
-msgid ""
-"<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
-msgstr ""
-
 #. Tag: title
-#: events.xml:85
 #, no-c-format
 msgid "Event system"
-msgstr "事件系统(Event system)"
+msgstr "事件系统(Event system)"
 
 #. Tag: para
-#: events.xml:87
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you have to react to particular events in your persistence layer, you can "
 "also use the Hibernate3 <emphasis>event</emphasis> architecture. The event "
 "system can be used in addition, or as a replacement, for interceptors."
 msgstr ""
-"如果需要响应持久层的某些特殊事件,你也可以使用Hibernate3的事件框架。 该事件系"
-"统可以用来替代拦截器,也可以作为拦截器的补充来使用。"
+"如果需要响应持久层的某些特殊事件,你也可以使用 Hibernate3 的事件框架。该事件"
+"系统可以用来替代拦截器,也可以作为拦截器的补充来使用。 "
 
 #. Tag: para
-#: events.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All the methods of the <literal>Session</literal> interface correlate to an "
 "event. You have a <literal>LoadEvent</literal>, a <literal>FlushEvent</"
@@ -246,30 +138,28 @@
 "processing any <literal>load()</literal> requests made of the "
 "<literal>Session</literal>."
 msgstr ""
-"基本上,<literal>Session</literal>接口的每个方法都有相对应的事件。比如 "
-"<literal>LoadEvent</literal>,<literal>FlushEvent</literal>,等等(查阅XML配"
-"置文件 的DTD,以及<literal>org.hibernate.event</literal>包来获得所有已定义的"
-"事件的列表)。当某个方 法被调用时,Hibernate <literal>Session</literal>会生成"
-"一个相对应的事件并激活所 有配置好的事件监听器。系统预设的监听器实现的处理过程"
-"就是被监听的方法要做的(被监听的方法所做的其实仅仅是激活监听器, “实际”的工作"
-"是由监听器完成的)。不过,你可以自由地选择实现 一个自己定制的监听器(比如,实"
-"现并注册用来处理处理<literal>LoadEvent</literal>的"
-"<literal>LoadEventListener</literal>接口), 来负责处理所有的调用"
-"<literal>Session</literal>的<literal>load()</literal>方法的请求。"
+"基本上,<literal>Session</literal> 接口的每个方法都有相对应的事件。比如 "
+"<literal>LoadEvent</literal>,<literal>FlushEvent</literal>,等等(查阅 XML "
+"配置文件的 DTD,以及 <literal>org.hibernate.event</literal> 包来获得所有已定"
+"义的事件的列表)。当某个方 法被调用时,Hibernate <literal>Session</literal>会"
+"生成一个相对应的事件并激活所 有配置好的事件监听器。系统预设的监听器实现的处理"
+"过程就是被监听的方法要做的(被监听的方法所做的其实仅仅是激活监听器,“实际”的"
+"工作是由监听器完成的)。不过,你可以自由地选择实现 一个自己定制的监听器(比"
+"如,实现并注册用来处理处理 <literal>LoadEvent</literal> 的 "
+"<literal>LoadEventListener</literal> 接口), 来负责处理所有的调用 "
+"<literal>Session</literal> 的 <literal>load()</literal> 方法的请求。"
 
 #. Tag: para
-#: events.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The listeners should be considered singletons. This means they are shared "
 "between requests, and should not save any state as instance variables."
 msgstr ""
-"监听器应该被看作是单例(singleton)对象,也就是说,所有同类型的事件的处理共享同"
-"一个监听器实例,因此监听器 不应该保存任何状态(也就是不应该使用成员变量)。"
+"监听器应该被看作是单例(singleton)对象,也就是说,所有同类型的事件的处理共享"
+"同一个监听器实例,因此监听器不应该保存任何状态(也就是不应该使用成员变量)。"
 
 #. Tag: para
-#: events.xml:113
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A custom listener implements the appropriate interface for the event it "
 "wants to process and/or extend one of the convenience base classes (or even "
@@ -281,89 +171,42 @@
 "example of a custom load event listener:"
 msgstr ""
 "用户定制的监听器应该实现与所要处理的事件相对应的接口,或者从一个合适的基类继"
-"承(甚至是从Hibernate自带的默认事件监听器类继承, 为了方便你这样做,这些类都"
-"被声明成non-final的了)。用户定制的监听器可以通过编程使用"
-"<literal>Configuration</literal>对象 来注册,也可以在Hibernate的XML格式的配置"
-"文件中进行声明(不支持在Properties格式的配置文件声明监听器)。 下面是一个用户"
-"定制的加载事件(load event)的监听器:"
+"承(甚至是从 Hibernate 自带的默认事件监听器类继承,为了方便你这样做,这些类都"
+"被声明成 non-final 的了)。用户定制的监听器可以通过编程使用 "
+"<literal>Configuration</literal> 对象 来注册,也可以在Hibernate的 XML 格式的"
+"配置文件中进行声明(不支持在 Properties 格式的配置文件声明监听器)。下面是一"
+"个用户定制的加载事件(load event)的监听器:"
 
-#. Tag: programlisting
-#: events.xml:123
-#, no-c-format
-msgid ""
-"<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
-"    // this is the single method defined by the LoadEventListener interface\n"
-"    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
-"loadType)\n"
-"            throws HibernateException {\n"
-"        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
-"getEntityId() ) ) {\n"
-"            throw MySecurityException(\"Unauthorized access\");\n"
-"        }\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:125
 #, no-c-format
 msgid ""
 "You also need a configuration entry telling Hibernate to use the listener in "
 "addition to the default listener:"
 msgstr ""
-"你还需要修改一处配置,来告诉Hibernate,除了默认的监听器,还要附加选定的监听"
+"你还需要修改一处配置,来告诉 Hibernate,除了默认的监听器,还要附加选定的监听"
 "器。"
 
-#. Tag: programlisting
-#: events.xml:130
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<hibernate-configuration>\n"
-"    <session-factory>\n"
-"        ...\n"
-"        <event type=\"load\">\n"
-"            <listener class=\"com.eg.MyLoadListener\"/>\n"
-"            <listener class=\"org.hibernate.event.def."
-"DefaultLoadEventListener\"/>\n"
-"        </event>\n"
-"    </session-factory>\n"
-"</hibernate-configuration>]]>"
-msgstr ""
+msgid "Instead, you can register it programmatically:"
+msgstr "或者,你可以通过编程的方式来注册它:"
 
 #. Tag: para
-#: events.xml:132
-#, fuzzy, no-c-format
-msgid "Instead, you can register it programmatically:"
-msgstr "看看用另一种方式,通过编程的方式来注册它。"
-
-#. Tag: programlisting
-#: events.xml:136
 #, no-c-format
 msgid ""
-"<![CDATA[Configuration cfg = new Configuration();\n"
-"LoadEventListener[] stack = { new MyLoadListener(), new "
-"DefaultLoadEventListener() };\n"
-"cfg.EventListeners().setLoadEventListeners(stack);]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:138
-#, fuzzy, no-c-format
-msgid ""
 "Listeners registered declaratively cannot share instances. If the same class "
 "name is used in multiple <literal>&lt;listener/&gt;</literal> elements, each "
 "reference will result in a separate instance of that class. If you need to "
 "share listener instances between listener types you must use the "
 "programmatic registration approach."
 msgstr ""
-"通过在XML配置文件声明而注册的监听器不能共享实例。如果在多个<literal>&lt;"
-"listener/&gt;</literal>节点中使用 了相同的类的名字,则每一个引用都将会产生一"
+"通过在XML配置文件声明而注册的监听器不能共享实例。如果在多个 <literal>&lt;"
+"listener/&gt;</literal> 节点中使用 了相同的类的名字,则每一个引用都将会产生一"
 "个独立的实例。如果你需要在多个监听器类型之间共享 监听器的实例,则你必须使用编"
-"程的方式来进行注册。"
+"程的方式来进行注册。 "
 
 #. Tag: para
-#: events.xml:146
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Why implement an interface and define the specific type during "
 "configuration? A listener implementation could implement multiple event "
@@ -373,84 +216,326 @@
 msgstr ""
 "为什么我们实现了特定监听器的接口,在注册的时候还要明确指出我们要注册哪个事件"
 "的监听器呢? 这是因为一个类可能实现多个监听器的接口。在注册的时候明确指定要监"
-"听的事件,可以让启用或者禁用对某个事件的监听的配置工作简单些。"
+"听的事件,可以让启用或者禁用对某个事件的监听的配置工作简单些。 "
 
 #. Tag: title
-#: events.xml:156
 #, no-c-format
 msgid "Hibernate declarative security"
-msgstr "Hibernate的声明式安全机制"
+msgstr "Hibernate 的声明式安全机制"
 
 #. Tag: para
-#: events.xml:157
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Usually, declarative security in Hibernate applications is managed in a "
 "session facade layer. Hibernate3 allows certain actions to be permissioned "
 "via JACC, and authorized via JAAS. This is an optional functionality that is "
 "built on top of the event architecture."
 msgstr ""
-"通常,Hibernate应用程序的声明式安全机制由会话外观层(session facade)所管理。 "
-"现在,Hibernate3允许某些特定的行为由JACC进行许可管理,由JAAS进行授权管理。 本"
-"功能是一个建立在事件框架之上的可选的功能。"
+"通常,Hibernate 应用程序的声明式安全机制由会话外观层(session facade)所管"
+"理。现在,Hibernate3允许某些特定的行为由 JACC 进行许可管理,由 JAAS 进行授权"
+"管理。本功能是一个建立在事件框架之上的可选的功能。 "
 
 #. Tag: para
-#: events.xml:163
 #, no-c-format
 msgid ""
 "First, you must configure the appropriate event listeners, to enable the use "
 "of JAAS authorization."
 msgstr ""
-"首先,你必须要配置适当的事件监听器(event listener),来激活使用JAAS管理授权"
-"的功能。"
+"首先,你必须要配置适当的事件监听器(event listener),来激活使用 JAAS 管理授"
+"权的功能。"
 
-#. Tag: programlisting
-#: events.xml:168
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
-"JACCPreDeleteEventListener\"/>\n"
-"<listener type=\"pre-update\" class=\"org.hibernate.secure."
-"JACCPreUpdateEventListener\"/>\n"
-"<listener type=\"pre-insert\" class=\"org.hibernate.secure."
-"JACCPreInsertEventListener\"/>\n"
-"<listener type=\"pre-load\" class=\"org.hibernate.secure."
-"JACCPreLoadEventListener\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: events.xml:170
-#, fuzzy, no-c-format
-msgid ""
 "Note that <literal>&lt;listener type=\"...\" class=\"...\"/&gt;</literal> is "
 "shorthand for <literal>&lt;event type=\"...\"&gt;&lt;listener class=\"...\"/"
 "&gt;&lt;/event&gt;</literal> when there is exactly one listener for a "
 "particular event type."
 msgstr ""
-"注意,<literal>&lt;listener type=\"...\" class=\"...\"/&gt;</literal>只是"
+"注意,<literal>&lt;listener type=\"...\" class=\"...\"/&gt;</literal> 只是 "
 "<literal>&lt;event type=\"...\"&gt;&lt;listener class=\"...\"/&gt;&lt;/"
-"event&gt;</literal>的简写,对每一个事件类型都必须严格的有一个监听器与之对应。"
+"event&gt;</literal> 的简写,对每一个事件类型都必须严格的有一个监听器与之对"
+"应。 "
 
 #. Tag: para
-#: events.xml:176
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next, while still in <literal>hibernate.cfg.xml</literal>, bind the "
 "permissions to roles:"
 msgstr ""
-"接下来,仍然在<literal>hibernate.cfg.xml</literal>文件中,绑定角色的权限:"
+"接下来,仍然在 <literal>hibernate.cfg.xml</literal> 文件中,绑定角色的权限: "
 
-#. Tag: programlisting
-#: events.xml:180
-#, no-c-format
-msgid ""
-"<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,update,"
-"read\"/>\n"
-"<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: events.xml:182
 #, no-c-format
 msgid "The role names are the roles understood by your JACC provider."
-msgstr "这些角色的名字就是你的JACC provider所定义的角色的名字。"
+msgstr "这些角色的名字就是你的 JACC provider 所定义的角色的名字。"
+
+#~ msgid ""
+#~ "<![CDATA[package org.hibernate.test;\n"
+#~ "\n"
+#~ "import java.io.Serializable;\n"
+#~ "import java.util.Date;\n"
+#~ "import java.util.Iterator;\n"
+#~ "\n"
+#~ "import org.hibernate.EmptyInterceptor;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.type.Type;\n"
+#~ "\n"
+#~ "public class AuditInterceptor extends EmptyInterceptor {\n"
+#~ "\n"
+#~ "    private int updates;\n"
+#~ "    private int creates;\n"
+#~ "    private int loads;\n"
+#~ "\n"
+#~ "    public void onDelete(Object entity,\n"
+#~ "                         Serializable id,\n"
+#~ "                         Object[] state,\n"
+#~ "                         String[] propertyNames,\n"
+#~ "                         Type[] types) {\n"
+#~ "        // do nothing\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onFlushDirty(Object entity,\n"
+#~ "                                Serializable id,\n"
+#~ "                                Object[] currentState,\n"
+#~ "                                Object[] previousState,\n"
+#~ "                                String[] propertyNames,\n"
+#~ "                                Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            updates++;\n"
+#~ "            for ( int i=0; i < propertyNames.length; i++ ) {\n"
+#~ "                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) "
+#~ "{\n"
+#~ "                    currentState[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onLoad(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            loads++;\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onSave(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            creates++;\n"
+#~ "            for ( int i=0; i<propertyNames.length; i++ ) {\n"
+#~ "                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
+#~ "                    state[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void afterTransactionCompletion(Transaction tx) {\n"
+#~ "        if ( tx.wasCommitted() ) {\n"
+#~ "            System.out.println(\"Creations: \" + creates + \", Updates: "
+#~ "\" + updates, \"Loads: \" + loads);\n"
+#~ "        }\n"
+#~ "        updates=0;\n"
+#~ "        creates=0;\n"
+#~ "        loads=0;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package org.hibernate.test;\n"
+#~ "\n"
+#~ "import java.io.Serializable;\n"
+#~ "import java.util.Date;\n"
+#~ "import java.util.Iterator;\n"
+#~ "\n"
+#~ "import org.hibernate.EmptyInterceptor;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.type.Type;\n"
+#~ "\n"
+#~ "public class AuditInterceptor extends EmptyInterceptor {\n"
+#~ "\n"
+#~ "    private int updates;\n"
+#~ "    private int creates;\n"
+#~ "    private int loads;\n"
+#~ "\n"
+#~ "    public void onDelete(Object entity,\n"
+#~ "                         Serializable id,\n"
+#~ "                         Object[] state,\n"
+#~ "                         String[] propertyNames,\n"
+#~ "                         Type[] types) {\n"
+#~ "        // do nothing\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onFlushDirty(Object entity,\n"
+#~ "                                Serializable id,\n"
+#~ "                                Object[] currentState,\n"
+#~ "                                Object[] previousState,\n"
+#~ "                                String[] propertyNames,\n"
+#~ "                                Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            updates++;\n"
+#~ "            for ( int i=0; i < propertyNames.length; i++ ) {\n"
+#~ "                if ( \"lastUpdateTimestamp\".equals( propertyNames[i] ) ) "
+#~ "{\n"
+#~ "                    currentState[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onLoad(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            loads++;\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean onSave(Object entity,\n"
+#~ "                          Serializable id,\n"
+#~ "                          Object[] state,\n"
+#~ "                          String[] propertyNames,\n"
+#~ "                          Type[] types) {\n"
+#~ "\n"
+#~ "        if ( entity instanceof Auditable ) {\n"
+#~ "            creates++;\n"
+#~ "            for ( int i=0; i<propertyNames.length; i++ ) {\n"
+#~ "                if ( \"createTimestamp\".equals( propertyNames[i] ) ) {\n"
+#~ "                    state[i] = new Date();\n"
+#~ "                    return true;\n"
+#~ "                }\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return false;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void afterTransactionCompletion(Transaction tx) {\n"
+#~ "        if ( tx.wasCommitted() ) {\n"
+#~ "            System.out.println(\"Creations: \" + creates + \", Updates: "
+#~ "\" + updates, \"Loads: \" + loads);\n"
+#~ "        }\n"
+#~ "        updates=0;\n"
+#~ "        creates=0;\n"
+#~ "        loads=0;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = sf.openSession( new AuditInterceptor() );]]>"
+
+#~ msgid ""
+#~ "<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
+#~ msgstr ""
+#~ "<![CDATA[new Configuration().setInterceptor( new AuditInterceptor() );]]>"
+
+#~ msgid ""
+#~ "<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
+#~ "    // this is the single method defined by the LoadEventListener "
+#~ "interface\n"
+#~ "    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
+#~ "loadType)\n"
+#~ "            throws HibernateException {\n"
+#~ "        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
+#~ "getEntityId() ) ) {\n"
+#~ "            throw MySecurityException(\"Unauthorized access\");\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[public class MyLoadListener implements LoadEventListener {\n"
+#~ "    // this is the single method defined by the LoadEventListener "
+#~ "interface\n"
+#~ "    public void onLoad(LoadEvent event, LoadEventListener.LoadType "
+#~ "loadType)\n"
+#~ "            throws HibernateException {\n"
+#~ "        if ( !MySecurity.isAuthorized( event.getEntityClassName(), event."
+#~ "getEntityId() ) ) {\n"
+#~ "            throw MySecurityException(\"Unauthorized access\");\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-configuration>\n"
+#~ "    <session-factory>\n"
+#~ "        ...\n"
+#~ "        <event type=\"load\">\n"
+#~ "            <listener class=\"com.eg.MyLoadListener\"/>\n"
+#~ "            <listener class=\"org.hibernate.event.def."
+#~ "DefaultLoadEventListener\"/>\n"
+#~ "        </event>\n"
+#~ "    </session-factory>\n"
+#~ "</hibernate-configuration>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-configuration>\n"
+#~ "    <session-factory>\n"
+#~ "        ...\n"
+#~ "        <event type=\"load\">\n"
+#~ "            <listener class=\"com.eg.MyLoadListener\"/>\n"
+#~ "            <listener class=\"org.hibernate.event.def."
+#~ "DefaultLoadEventListener\"/>\n"
+#~ "        </event>\n"
+#~ "    </session-factory>\n"
+#~ "</hibernate-configuration>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Configuration cfg = new Configuration();\n"
+#~ "LoadEventListener[] stack = { new MyLoadListener(), new "
+#~ "DefaultLoadEventListener() };\n"
+#~ "cfg.EventListeners().setLoadEventListeners(stack);]]>"
+#~ msgstr ""
+#~ "<![CDATA[Configuration cfg = new Configuration();\n"
+#~ "LoadEventListener[] stack = { new MyLoadListener(), new "
+#~ "DefaultLoadEventListener() };\n"
+#~ "cfg.EventListeners().setLoadEventListeners(stack);]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
+#~ "JACCPreDeleteEventListener\"/>\n"
+#~ "<listener type=\"pre-update\" class=\"org.hibernate.secure."
+#~ "JACCPreUpdateEventListener\"/>\n"
+#~ "<listener type=\"pre-insert\" class=\"org.hibernate.secure."
+#~ "JACCPreInsertEventListener\"/>\n"
+#~ "<listener type=\"pre-load\" class=\"org.hibernate.secure."
+#~ "JACCPreLoadEventListener\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<listener type=\"pre-delete\" class=\"org.hibernate.secure."
+#~ "JACCPreDeleteEventListener\"/>\n"
+#~ "<listener type=\"pre-update\" class=\"org.hibernate.secure."
+#~ "JACCPreUpdateEventListener\"/>\n"
+#~ "<listener type=\"pre-insert\" class=\"org.hibernate.secure."
+#~ "JACCPreInsertEventListener\"/>\n"
+#~ "<listener type=\"pre-load\" class=\"org.hibernate.secure."
+#~ "JACCPreLoadEventListener\"/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,"
+#~ "update,read\"/>\n"
+#~ "<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<grant role=\"admin\" entity-name=\"User\" actions=\"insert,"
+#~ "update,read\"/>\n"
+#~ "<grant role=\"su\" entity-name=\"User\" actions=\"*\"/>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/example_mappings.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/example_mappings.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/example_mappings.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,36 +1,36 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:55+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-11-20 18:36+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: example_mappings.xml:29
 #, no-c-format
 msgid "Example: Various Mappings"
 msgstr "示例:复杂映射实例"
 
 #. Tag: para
-#: example_mappings.xml:32
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This chapters explores some more complex association mappings."
-msgstr "本章展示了一些较为复杂的关系映射。"
+msgstr "本章展示了一些较为复杂的关系映射。 "
 
 #. Tag: title
-#: example_mappings.xml:37
 #, no-c-format
 msgid "Employer/Employee"
-msgstr "Employer(雇主)/Employee(雇员)"
+msgstr "Employer(雇主)/Employee(雇员)"
 
 #. Tag: para
-#: example_mappings.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following model of the relationship between <literal>Employer</literal> "
 "and <literal>Employee</literal> uses an entity class (<literal>Employment</"
@@ -38,128 +38,28 @@
 "more than one period of employment for the same two parties. Components are "
 "used to model monetary values and employee names."
 msgstr ""
-"下面关于<literal>Employer</literal> 和 <literal>Employee</literal>的关系模型"
-"使用了一个真实的实体类 (<literal>Employment</literal>)来表述,这是因为对于相"
-"同的雇员和雇主可能会有多个雇佣时间段。 对于金额和雇员姓名,用Components建模。"
+"下面关于 <literal>Employer</literal> 和 <literal>Employee</literal> 的关系模"
+"型使用了一个真实的实体类(<literal>Employment</literal>)来表述,这是因为对于"
+"相同的雇员和雇主可能会有多个雇佣时间段。对于金额和雇员姓名,用 Components 建"
+"模。 "
 
 #. Tag: para
-#: example_mappings.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is a possible mapping document:"
-msgstr "映射文件可能是这样:"
+msgstr "映射文件可能是这样: "
 
-#. Tag: programlisting
-#: example_mappings.xml:60
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"        \n"
-"    <class name=\"Employer\" table=\"employers\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employer_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Employment\" table=\"employment_periods\">\n"
-"\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employment_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"startDate\" column=\"start_date\"/>\n"
-"        <property name=\"endDate\" column=\"end_date\"/>\n"
-"\n"
-"        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
-"            <property name=\"amount\">\n"
-"                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/>\n"
-"            </property>\n"
-"            <property name=\"currency\" length=\"12\"/>\n"
-"        </component>\n"
-"\n"
-"        <many-to-one name=\"employer\" column=\"employer_id\" not-null=\"true"
-"\"/>\n"
-"        <many-to-one name=\"employee\" column=\"employee_id\" not-null=\"true"
-"\"/>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Employee\" table=\"employees\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"sequence\">\n"
-"                <param name=\"sequence\">employee_id_seq</param>\n"
-"            </generator>\n"
-"        </id>\n"
-"        <property name=\"taxfileNumber\"/>\n"
-"        <component name=\"name\" class=\"Name\">\n"
-"            <property name=\"firstName\"/>\n"
-"            <property name=\"initial\"/>\n"
-"            <property name=\"lastName\"/>\n"
-"        </component>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: example_mappings.xml:62
-#, fuzzy, no-c-format
 msgid "Here is the table schema generated by <literal>SchemaExport</literal>."
-msgstr "用<literal>SchemaExport</literal>生成表结构。"
+msgstr "用 <literal>SchemaExport</literal> 生成表结构。 "
 
-#. Tag: programlisting
-#: example_mappings.xml:66
-#, no-c-format
-msgid ""
-"<![CDATA[create table employers (\n"
-"    id BIGINT not null, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table employment_periods (\n"
-"    id BIGINT not null,\n"
-"    hourly_rate NUMERIC(12, 2),\n"
-"    currency VARCHAR(12), \n"
-"    employee_id BIGINT not null, \n"
-"    employer_id BIGINT not null, \n"
-"    end_date TIMESTAMP, \n"
-"    start_date TIMESTAMP, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table employees (\n"
-"    id BIGINT not null, \n"
-"    firstName VARCHAR(255), \n"
-"    initial CHAR(1), \n"
-"    lastName VARCHAR(255), \n"
-"    taxfileNumber VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table employment_periods \n"
-"    add constraint employment_periodsFK0 foreign key (employer_id) "
-"references employers\n"
-"alter table employment_periods \n"
-"    add constraint employment_periodsFK1 foreign key (employee_id) "
-"references employees\n"
-"create sequence employee_id_seq\n"
-"create sequence employment_id_seq\n"
-"create sequence employer_id_seq]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:71
 #, no-c-format
 msgid "Author/Work"
-msgstr "Author(作家)/Work(作品)"
+msgstr "Author(作家)/Work(作品)"
 
 #. Tag: para
-#: example_mappings.xml:73
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Consider the following model of the relationships between <literal>Work</"
 "literal>, <literal>Author</literal> and <literal>Person</literal>. In the "
@@ -169,141 +69,39 @@
 "literal> is represented as one-to-one association. Another possibility would "
 "be to have <literal>Author</literal> extend <literal>Person</literal>."
 msgstr ""
-"考虑下面的<literal>Work</literal>,<literal>Author</literal> 和 "
-"<literal>Person</literal>模型的关系。 我们用多对多关系来描述<literal>Work</"
-"literal> 和 <literal>Author</literal>, 用一对一关系来描述<literal>Author</"
-"literal> 和 <literal>Person</literal>, 另一种可能性是<literal>Author</"
-"literal>继承<literal>Person</literal>。"
+"考虑下面的 <literal>Work</literal>,<literal>Author</literal> 和 "
+"<literal>Person</literal> 模型的关系。我们用多对多关系来描述 <literal>Work</"
+"literal> 和 <literal>Author</literal>,用一对一关系来描述 <literal>Author</"
+"literal> 和 <literal>Person</literal>,另一种可能性是 <literal>Author</"
+"literal> 继承 <literal>Person</literal>。 "
 
 #. Tag: para
-#: example_mappings.xml:91
 #, no-c-format
 msgid ""
 "The following mapping document correctly represents these relationships:"
 msgstr "下面的映射文件正确的描述了这些关系:"
 
-#. Tag: programlisting
-#: example_mappings.xml:95
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
-"\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <discriminator column=\"type\" type=\"character\"/>\n"
-"\n"
-"        <property name=\"title\"/>\n"
-"        <set name=\"authors\" table=\"author_work\">\n"
-"            <key column name=\"work_id\"/>\n"
-"            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
-"        </set>\n"
-"\n"
-"        <subclass name=\"Book\" discriminator-value=\"B\">\n"
-"            <property name=\"text\"/>\n"
-"        </subclass>\n"
-"\n"
-"        <subclass name=\"Song\" discriminator-value=\"S\">\n"
-"            <property name=\"tempo\"/>\n"
-"            <property name=\"genre\"/>\n"
-"        </subclass>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Author\" table=\"authors\">\n"
-"\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <!-- The Author must have the same identifier as the Person -->\n"
-"            <generator class=\"assigned\"/> \n"
-"        </id>\n"
-"\n"
-"        <property name=\"alias\"/>\n"
-"        <one-to-one name=\"person\" constrained=\"true\"/>\n"
-"\n"
-"        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
-"            <key column=\"author_id\"/>\n"
-"            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
-"        </set>\n"
-"\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Person\" table=\"persons\">\n"
-"        <id name=\"id\" column=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: example_mappings.xml:97
-#, fuzzy, no-c-format
-msgid ""
 "There are four tables in this mapping: <literal>works</literal>, "
 "<literal>authors</literal> and <literal>persons</literal> hold work, author "
 "and person data respectively. <literal>author_work</literal> is an "
 "association table linking authors to works. Here is the table schema, as "
 "generated by <literal>SchemaExport</literal>:"
 msgstr ""
-"映射中有4个表。<literal>works</literal>, <literal>authors</literal> 和 "
-"<literal>persons</literal> 分别保存着work,author和person的数据。"
-"<literal>author_work</literal>是authors和works的关联表。 表结构是由"
-"<literal>SchemaExport</literal>生成的。"
+"映射中有 4 个表。<literal>works</literal>,<literal>authors</literal> 和 "
+"<literal>persons</literal> 分别保存着 work,author 和 person 的数据。"
+"<literal>author_work</literal> 是 authors 和 works 的关联表。表结构是由 "
+"<literal>SchemaExport</literal> 生成的:"
 
-#. Tag: programlisting
-#: example_mappings.xml:105
-#, no-c-format
-msgid ""
-"<![CDATA[create table works (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    tempo FLOAT, \n"
-"    genre VARCHAR(255), \n"
-"    text INTEGER, \n"
-"    title VARCHAR(255), \n"
-"    type CHAR(1) not null, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table author_work (\n"
-"    author_id BIGINT not null, \n"
-"    work_id BIGINT not null, \n"
-"    primary key (work_id, author_id)\n"
-")\n"
-"\n"
-"create table authors (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    alias VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table persons (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table authors \n"
-"    add constraint authorsFK0 foreign key (id) references persons\n"
-"alter table author_work \n"
-"    add constraint author_workFK0 foreign key (author_id) references "
-"authors\n"
-"alter table author_work\n"
-"    add constraint author_workFK1 foreign key (work_id) references works]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:110
 #, no-c-format
 msgid "Customer/Order/Product"
-msgstr "Customer(客户)/Order(订单)/Product(产品)"
+msgstr "Customer(客户)/Order(订单)/Product(产品)"
 
 #. Tag: para
-#: example_mappings.xml:112
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In this section we consider a model of the relationships between "
 "<literal>Customer</literal>, <literal>Order</literal>, <literal>Line Item</"
@@ -315,65 +113,20 @@
 "between <literal>Order</literal> and <literal>Product</literal>. In "
 "Hibernate this is called a composite element."
 msgstr ""
-"现在来考虑<literal>Customer</literal>,<literal>Order</literal> , "
-"<literal>LineItem</literal> 和 <literal>Product</literal>关系的模型。"
-"<literal>Customer</literal> 和 <literal>Order</literal>之间 是一对多的关系,"
-"但是我们怎么来描述<literal>Order</literal> / <literal>LineItem</literal> / "
-"<literal>Product</literal>呢? 我可以把<literal>LineItem</literal>作为描述"
-"<literal>Order</literal> 和 <literal>Product</literal> 多对多关系的关联类,在"
-"Hibernate,这叫做组合元素。"
+"现在来考虑 <literal>Customer</literal>,<literal>Order</literal>, "
+"<literal>LineItem</literal> 和 <literal>Product</literal> 关系的模型。"
+"<literal>Customer</literal> 和 <literal>Order</literal> 之间 是一对多的关系,"
+"但是我们怎么来描述 <literal>Order</literal> / <literal>LineItem</literal> / "
+"<literal>Product</literal>呢? 我可以把 <literal>LineItem</literal> 作为描述 "
+"<literal>Order</literal> 和  <literal>Product</literal> 多对多关系的关联类,"
+"在 Hibernate,这叫做组合元素。 "
 
 #. Tag: para
-#: example_mappings.xml:132
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The mapping document will look like this:"
-msgstr "映射文件如下:"
+msgstr "映射文件如下: "
 
-#. Tag: programlisting
-#: example_mappings.xml:136
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class name=\"Customer\" table=\"customers\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"name\"/>\n"
-"        <set name=\"orders\" inverse=\"true\">\n"
-"            <key column=\"customer_id\"/>\n"
-"            <one-to-many class=\"Order\"/>\n"
-"        </set>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Order\" table=\"orders\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"date\"/>\n"
-"        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
-"        <list name=\"lineItems\" table=\"line_items\">\n"
-"            <key column=\"order_id\"/>\n"
-"            <list-index column=\"line_number\"/>\n"
-"            <composite-element class=\"LineItem\">\n"
-"                <property name=\"quantity\"/>\n"
-"                <many-to-one name=\"product\" column=\"product_id\"/>\n"
-"            </composite-element>\n"
-"        </list>\n"
-"    </class>\n"
-"\n"
-"    <class name=\"Product\" table=\"products\">\n"
-"        <id name=\"id\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"serialNumber\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_mappings.xml:138
 #, no-c-format
 msgid ""
 "<literal>customers</literal>, <literal>orders</literal>, "
@@ -381,401 +134,1121 @@
 "order, order line item and product data respectively. <literal>line_items</"
 "literal> also acts as an association table linking orders with products."
 msgstr ""
-"<literal>customers</literal>, <literal>orders</literal>, "
-"<literal>line_items</literal> 和 <literal>products</literal> 分别保存着"
-"customer, order, order line item 和 product的数据。 <literal>line_items</"
-"literal>也作为连接orders 和 products的关联表。"
+"<literal>customers</literal>,<literal>orders</literal>,"
+"<literal>line_items</literal> 和  <literal>products</literal> 分别保存着 "
+"customer,order,order line item 和 product 的数据。 <literal>line_items</"
+"literal> 也作为连接 orders 和 products 的关联表。"
 
-#. Tag: programlisting
-#: example_mappings.xml:145
-#, no-c-format
-msgid ""
-"<![CDATA[create table customers (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    name VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table orders (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    customer_id BIGINT, \n"
-"    date TIMESTAMP, \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"create table line_items (\n"
-"    line_number INTEGER not null, \n"
-"    order_id BIGINT not null, \n"
-"    product_id BIGINT, \n"
-"    quantity INTEGER, \n"
-"    primary key (order_id, line_number)\n"
-")\n"
-"\n"
-"create table products (\n"
-"    id BIGINT not null generated by default as identity, \n"
-"    serialNumber VARCHAR(255), \n"
-"    primary key (id)\n"
-")\n"
-"\n"
-"alter table orders \n"
-"    add constraint ordersFK0 foreign key (customer_id) references customers\n"
-"alter table line_items\n"
-"    add constraint line_itemsFK0 foreign key (product_id) references "
-"products\n"
-"alter table line_items\n"
-"    add constraint line_itemsFK1 foreign key (order_id) references orders]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:150
 #, no-c-format
 msgid "Miscellaneous example mappings"
 msgstr "杂例"
 
 #. Tag: para
-#: example_mappings.xml:152
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These examples are available from the Hibernate test suite. You will find "
 "many other useful example mappings there by searching in the <literal>test</"
 "literal> folder of the Hibernate distribution."
 msgstr ""
-"这些例子全部来自于Hibernate的test suite,同时你也可以找到其他有用的例子。 可"
-"以参考Hibernate的<literal>test</literal>目录。"
+"这些例子全部来自于 Hibernate 的 test suite,同时你也可以找到其他有用的例子。"
+"可以参考 Hibernate 的 <literal>test</literal> 目录。 "
 
 #. Tag: title
-#: example_mappings.xml:161
 #, no-c-format
 msgid "\"Typed\" one-to-one association"
-msgstr "\"Typed\" one-to-one association"
+msgstr "\"Typed\" 一对一关联"
 
-#. Tag: programlisting
-#: example_mappings.xml:162
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"name\"/>\n"
-"    <one-to-one name=\"address\" \n"
-"            cascade=\"all\">\n"
-"        <formula>name</formula>\n"
-"        <formula>'HOME'</formula>\n"
-"    </one-to-one>\n"
-"    <one-to-one name=\"mailingAddress\" \n"
-"            cascade=\"all\">\n"
-"        <formula>name</formula>\n"
-"        <formula>'MAILING'</formula>\n"
-"    </one-to-one>\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\" batch-size=\"2\" \n"
-"        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
-"    <composite-id>\n"
-"        <key-many-to-one name=\"person\" \n"
-"                column=\"personName\"/>\n"
-"        <key-property name=\"type\" \n"
-"                column=\"addressType\"/>\n"
-"    </composite-id>\n"
-"    <property name=\"street\" type=\"text\"/>\n"
-"    <property name=\"state\"/>\n"
-"    <property name=\"zip\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:166
 #, no-c-format
 msgid "Composite key example"
-msgstr "Composite key example"
+msgstr "组合键示例"
 
-#. Tag: programlisting
-#: example_mappings.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Customer\">\n"
-"\n"
-"    <id name=\"customerId\"\n"
-"        length=\"10\">\n"
-"        <generator class=\"assigned\"/>\n"
-"    </id>\n"
-"\n"
-"    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
-"    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
-"\n"
-"    <list name=\"orders\"\n"
-"            inverse=\"true\"\n"
-"            cascade=\"save-update\">\n"
-"        <key column=\"customerId\"/>\n"
-"        <index column=\"orderNumber\"/>\n"
-"        <one-to-many class=\"Order\"/>\n"
-"    </list>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
-"    <synchronize table=\"LineItem\"/>\n"
-"    <synchronize table=\"Product\"/>\n"
-"    \n"
-"    <composite-id name=\"id\" \n"
-"            class=\"Order$Id\">\n"
-"        <key-property name=\"customerId\" length=\"10\"/>\n"
-"        <key-property name=\"orderNumber\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"orderDate\" \n"
-"            type=\"calendar_date\"\n"
-"            not-null=\"true\"/>\n"
-"    \n"
-"    <property name=\"total\">\n"
-"        <formula>\n"
-"            ( select sum(li.quantity*p.price) \n"
-"            from LineItem li, Product p \n"
-"            where li.productId = p.productId \n"
-"                and li.customerId = customerId \n"
-"                and li.orderNumber = orderNumber )\n"
-"        </formula>\n"
-"    </property>\n"
-"    \n"
-"    <many-to-one name=\"customer\"\n"
-"            column=\"customerId\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\"/>\n"
-"        \n"
-"    <bag name=\"lineItems\"\n"
-"            fetch=\"join\" \n"
-"            inverse=\"true\"\n"
-"            cascade=\"save-update\">\n"
-"        <key>\n"
-"            <column name=\"customerId\"/>\n"
-"            <column name=\"orderNumber\"/>\n"
-"        </key>\n"
-"        <one-to-many class=\"LineItem\"/>\n"
-"    </bag>\n"
-"    \n"
-"</class>\n"
-"    \n"
-"<class name=\"LineItem\">\n"
-"    \n"
-"    <composite-id name=\"id\" \n"
-"            class=\"LineItem$Id\">\n"
-"        <key-property name=\"customerId\" length=\"10\"/>\n"
-"        <key-property name=\"orderNumber\"/>\n"
-"        <key-property name=\"productId\" length=\"10\"/>\n"
-"    </composite-id>\n"
-"    \n"
-"    <property name=\"quantity\"/>\n"
-"    \n"
-"    <many-to-one name=\"order\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\">\n"
-"        <column name=\"customerId\"/>\n"
-"        <column name=\"orderNumber\"/>\n"
-"    </many-to-one>\n"
-"    \n"
-"    <many-to-one name=\"product\"\n"
-"            insert=\"false\"\n"
-"            update=\"false\" \n"
-"            not-null=\"true\"\n"
-"            column=\"productId\"/>\n"
-"        \n"
-"</class>\n"
-"\n"
-"<class name=\"Product\">\n"
-"    <synchronize table=\"LineItem\"/>\n"
-"\n"
-"    <id name=\"productId\"\n"
-"        length=\"10\">\n"
-"        <generator class=\"assigned\"/>\n"
-"    </id>\n"
-"    \n"
-"    <property name=\"description\" \n"
-"        not-null=\"true\" \n"
-"        length=\"200\"/>\n"
-"    <property name=\"price\" length=\"3\"/>\n"
-"    <property name=\"numberAvailable\"/>\n"
-"    \n"
-"    <property name=\"numberOrdered\">\n"
-"        <formula>\n"
-"            ( select sum(li.quantity) \n"
-"            from LineItem li \n"
-"            where li.productId = productId )\n"
-"        </formula>\n"
-"    </property>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:171
 #, no-c-format
 msgid "Many-to-many with shared composite key attribute"
 msgstr ""
-"共有组合键属性的多对多(Many-to-many with shared composite key attribute)"
+"共有组合键属性的多对多(Many-to-many with shared composite key attribute)"
 
-#. Tag: programlisting
-#: example_mappings.xml:172
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"User\" table=\"`User`\">\n"
-"    <composite-id>\n"
-"        <key-property name=\"name\"/>\n"
-"        <key-property name=\"org\"/>\n"
-"    </composite-id>\n"
-"    <set name=\"groups\" table=\"UserGroup\">\n"
-"        <key>\n"
-"            <column name=\"userName\"/>\n"
-"            <column name=\"org\"/>\n"
-"        </key>\n"
-"        <many-to-many class=\"Group\">\n"
-"            <column name=\"groupName\"/>\n"
-"            <formula>org</formula>\n"
-"        </many-to-many>\n"
-"    </set>\n"
-"</class>\n"
-"    \n"
-"<class name=\"Group\" table=\"`Group`\">\n"
-"    <composite-id>\n"
-"        <key-property name=\"name\"/>\n"
-"        <key-property name=\"org\"/>\n"
-"    </composite-id>\n"
-"    <property name=\"description\"/>\n"
-"    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
-"        <key>\n"
-"            <column name=\"groupName\"/>\n"
-"            <column name=\"org\"/>\n"
-"        </key>\n"
-"        <many-to-many class=\"User\">\n"
-"            <column name=\"userName\"/>\n"
-"            <formula>org</formula>\n"
-"        </many-to-many>\n"
-"    </set>\n"
-"</class>\n"
-"]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:176
 #, no-c-format
 msgid "Content based discrimination"
-msgstr "Content based discrimination"
+msgstr "基于内容的识别"
 
-#. Tag: programlisting
-#: example_mappings.xml:177
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\"\n"
-"    discriminator-value=\"P\">\n"
-"    \n"
-"    <id name=\"id\" \n"
-"        column=\"person_id\" \n"
-"        unsaved-value=\"0\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    \n"
-"            \n"
-"    <discriminator \n"
-"        type=\"character\">\n"
-"        <formula>\n"
-"            case \n"
-"                when title is not null then 'E' \n"
-"                when salesperson is not null then 'C' \n"
-"                else 'P' \n"
-"            end\n"
-"        </formula>\n"
-"    </discriminator>\n"
-"\n"
-"    <property name=\"name\" \n"
-"        not-null=\"true\"\n"
-"        length=\"80\"/>\n"
-"        \n"
-"    <property name=\"sex\" \n"
-"        not-null=\"true\"\n"
-"        update=\"false\"/>\n"
-"    \n"
-"    <component name=\"address\">\n"
-"        <property name=\"address\"/>\n"
-"        <property name=\"zip\"/>\n"
-"        <property name=\"country\"/>\n"
-"    </component>\n"
-"    \n"
-"    <subclass name=\"Employee\" \n"
-"        discriminator-value=\"E\">\n"
-"            <property name=\"title\"\n"
-"                length=\"20\"/>\n"
-"            <property name=\"salary\"/>\n"
-"            <many-to-one name=\"manager\"/>\n"
-"    </subclass>\n"
-"    \n"
-"    <subclass name=\"Customer\" \n"
-"        discriminator-value=\"C\">\n"
-"            <property name=\"comments\"/>\n"
-"            <many-to-one name=\"salesperson\"/>\n"
-"    </subclass>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_mappings.xml:181
 #, no-c-format
 msgid "Associations on alternate keys"
-msgstr "Associations on alternate keys"
+msgstr "备用键的联合"
 
-#. Tag: programlisting
-#: example_mappings.xml:182
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    \n"
-"    <id name=\"id\">\n"
-"        <generator class=\"hilo\"/>\n"
-"    </id>\n"
-"    \n"
-"    <property name=\"name\" length=\"100\"/>\n"
-"    \n"
-"    <one-to-one name=\"address\" \n"
-"        property-ref=\"person\"\n"
-"        cascade=\"all\"\n"
-"        fetch=\"join\"/>\n"
-"    \n"
-"    <set name=\"accounts\" \n"
-"        inverse=\"true\">\n"
-"        <key column=\"userId\"\n"
-"            property-ref=\"userId\"/>\n"
-"        <one-to-many class=\"Account\"/>\n"
-"    </set>\n"
-"    \n"
-"    <property name=\"userId\" length=\"8\"/>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Address\">\n"
-"\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"hilo\"/>\n"
-"    </id>\n"
-"\n"
-"    <property name=\"address\" length=\"300\"/>\n"
-"    <property name=\"zip\" length=\"5\"/>\n"
-"    <property name=\"country\" length=\"25\"/>\n"
-"    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
-"\n"
-"</class>\n"
-"\n"
-"<class name=\"Account\">\n"
-"    <id name=\"accountId\" length=\"32\">\n"
-"        <generator class=\"uuid\"/>\n"
-"    </id>\n"
-"    \n"
-"    <many-to-one name=\"user\"\n"
-"        column=\"userId\"\n"
-"        property-ref=\"userId\"/>\n"
-"    \n"
-"    <property name=\"type\" not-null=\"true\"/>\n"
-"    \n"
-"</class>]]>"
-msgstr ""
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "        \n"
+#~ "    <class name=\"Employer\" table=\"employers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employer_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employment\" table=\"employment_periods\">\n"
+#~ "\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employment_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"startDate\" column=\"start_date\"/>\n"
+#~ "        <property name=\"endDate\" column=\"end_date\"/>\n"
+#~ "\n"
+#~ "        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
+#~ "            <property name=\"amount\">\n"
+#~ "                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/"
+#~ ">\n"
+#~ "            </property>\n"
+#~ "            <property name=\"currency\" length=\"12\"/>\n"
+#~ "        </component>\n"
+#~ "\n"
+#~ "        <many-to-one name=\"employer\" column=\"employer_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "        <many-to-one name=\"employee\" column=\"employee_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employee\" table=\"employees\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employee_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"taxfileNumber\"/>\n"
+#~ "        <component name=\"name\" class=\"Name\">\n"
+#~ "            <property name=\"firstName\"/>\n"
+#~ "            <property name=\"initial\"/>\n"
+#~ "            <property name=\"lastName\"/>\n"
+#~ "        </component>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "        \n"
+#~ "    <class name=\"Employer\" table=\"employers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employer_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employment\" table=\"employment_periods\">\n"
+#~ "\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employment_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"startDate\" column=\"start_date\"/>\n"
+#~ "        <property name=\"endDate\" column=\"end_date\"/>\n"
+#~ "\n"
+#~ "        <component name=\"hourlyRate\" class=\"MonetaryAmount\">\n"
+#~ "            <property name=\"amount\">\n"
+#~ "                <column name=\"hourly_rate\" sql-type=\"NUMERIC(12, 2)\"/"
+#~ ">\n"
+#~ "            </property>\n"
+#~ "            <property name=\"currency\" length=\"12\"/>\n"
+#~ "        </component>\n"
+#~ "\n"
+#~ "        <many-to-one name=\"employer\" column=\"employer_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "        <many-to-one name=\"employee\" column=\"employee_id\" not-null="
+#~ "\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Employee\" table=\"employees\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"sequence\">\n"
+#~ "                <param name=\"sequence\">employee_id_seq</param>\n"
+#~ "            </generator>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"taxfileNumber\"/>\n"
+#~ "        <component name=\"name\" class=\"Name\">\n"
+#~ "            <property name=\"firstName\"/>\n"
+#~ "            <property name=\"initial\"/>\n"
+#~ "            <property name=\"lastName\"/>\n"
+#~ "        </component>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 
-#~ msgid "TODO: put words around this stuff"
-#~ msgstr "TODO: put words around this stuff"
+#~ msgid ""
+#~ "<![CDATA[create table employers (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employment_periods (\n"
+#~ "    id BIGINT not null,\n"
+#~ "    hourly_rate NUMERIC(12, 2),\n"
+#~ "    currency VARCHAR(12), \n"
+#~ "    employee_id BIGINT not null, \n"
+#~ "    employer_id BIGINT not null, \n"
+#~ "    end_date TIMESTAMP, \n"
+#~ "    start_date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employees (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    firstName VARCHAR(255), \n"
+#~ "    initial CHAR(1), \n"
+#~ "    lastName VARCHAR(255), \n"
+#~ "    taxfileNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK0 foreign key (employer_id) "
+#~ "references employers\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK1 foreign key (employee_id) "
+#~ "references employees\n"
+#~ "create sequence employee_id_seq\n"
+#~ "create sequence employment_id_seq\n"
+#~ "create sequence employer_id_seq]]>"
+#~ msgstr ""
+#~ "<![CDATA[create table employers (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employment_periods (\n"
+#~ "    id BIGINT not null,\n"
+#~ "    hourly_rate NUMERIC(12, 2),\n"
+#~ "    currency VARCHAR(12), \n"
+#~ "    employee_id BIGINT not null, \n"
+#~ "    employer_id BIGINT not null, \n"
+#~ "    end_date TIMESTAMP, \n"
+#~ "    start_date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table employees (\n"
+#~ "    id BIGINT not null, \n"
+#~ "    firstName VARCHAR(255), \n"
+#~ "    initial CHAR(1), \n"
+#~ "    lastName VARCHAR(255), \n"
+#~ "    taxfileNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK0 foreign key (employer_id) "
+#~ "references employers\n"
+#~ "alter table employment_periods \n"
+#~ "    add constraint employment_periodsFK1 foreign key (employee_id) "
+#~ "references employees\n"
+#~ "create sequence employee_id_seq\n"
+#~ "create sequence employment_id_seq\n"
+#~ "create sequence employer_id_seq]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <discriminator column=\"type\" type=\"character\"/>\n"
+#~ "\n"
+#~ "        <property name=\"title\"/>\n"
+#~ "        <set name=\"authors\" table=\"author_work\">\n"
+#~ "            <key column name=\"work_id\"/>\n"
+#~ "            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "        <subclass name=\"Book\" discriminator-value=\"B\">\n"
+#~ "            <property name=\"text\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "        <subclass name=\"Song\" discriminator-value=\"S\">\n"
+#~ "            <property name=\"tempo\"/>\n"
+#~ "            <property name=\"genre\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Author\" table=\"authors\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <!-- The Author must have the same identifier as the Person --"
+#~ ">\n"
+#~ "            <generator class=\"assigned\"/> \n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property name=\"alias\"/>\n"
+#~ "        <one-to-one name=\"person\" constrained=\"true\"/>\n"
+#~ "\n"
+#~ "        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
+#~ "            <key column=\"author_id\"/>\n"
+#~ "            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Person\" table=\"persons\">\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Work\" table=\"works\" discriminator-value=\"W\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <discriminator column=\"type\" type=\"character\"/>\n"
+#~ "\n"
+#~ "        <property name=\"title\"/>\n"
+#~ "        <set name=\"authors\" table=\"author_work\">\n"
+#~ "            <key column name=\"work_id\"/>\n"
+#~ "            <many-to-many class=\"Author\" column name=\"author_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "        <subclass name=\"Book\" discriminator-value=\"B\">\n"
+#~ "            <property name=\"text\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "        <subclass name=\"Song\" discriminator-value=\"S\">\n"
+#~ "            <property name=\"tempo\"/>\n"
+#~ "            <property name=\"genre\"/>\n"
+#~ "        </subclass>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Author\" table=\"authors\">\n"
+#~ "\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <!-- The Author must have the same identifier as the Person --"
+#~ ">\n"
+#~ "            <generator class=\"assigned\"/> \n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property name=\"alias\"/>\n"
+#~ "        <one-to-one name=\"person\" constrained=\"true\"/>\n"
+#~ "\n"
+#~ "        <set name=\"works\" table=\"author_work\" inverse=\"true\">\n"
+#~ "            <key column=\"author_id\"/>\n"
+#~ "            <many-to-many class=\"Work\" column=\"work_id\"/>\n"
+#~ "        </set>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Person\" table=\"persons\">\n"
+#~ "        <id name=\"id\" column=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[create table works (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    tempo FLOAT, \n"
+#~ "    genre VARCHAR(255), \n"
+#~ "    text INTEGER, \n"
+#~ "    title VARCHAR(255), \n"
+#~ "    type CHAR(1) not null, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table author_work (\n"
+#~ "    author_id BIGINT not null, \n"
+#~ "    work_id BIGINT not null, \n"
+#~ "    primary key (work_id, author_id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table authors (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    alias VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table persons (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table authors \n"
+#~ "    add constraint authorsFK0 foreign key (id) references persons\n"
+#~ "alter table author_work \n"
+#~ "    add constraint author_workFK0 foreign key (author_id) references "
+#~ "authors\n"
+#~ "alter table author_work\n"
+#~ "    add constraint author_workFK1 foreign key (work_id) references works]]"
+#~ ">"
+#~ msgstr ""
+#~ "<![CDATA[create table works (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    tempo FLOAT, \n"
+#~ "    genre VARCHAR(255), \n"
+#~ "    text INTEGER, \n"
+#~ "    title VARCHAR(255), \n"
+#~ "    type CHAR(1) not null, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table author_work (\n"
+#~ "    author_id BIGINT not null, \n"
+#~ "    work_id BIGINT not null, \n"
+#~ "    primary key (work_id, author_id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table authors (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    alias VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table persons (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table authors \n"
+#~ "    add constraint authorsFK0 foreign key (id) references persons\n"
+#~ "alter table author_work \n"
+#~ "    add constraint author_workFK0 foreign key (author_id) references "
+#~ "authors\n"
+#~ "alter table author_work\n"
+#~ "    add constraint author_workFK1 foreign key (work_id) references works]]"
+#~ ">"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Customer\" table=\"customers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "        <set name=\"orders\" inverse=\"true\">\n"
+#~ "            <key column=\"customer_id\"/>\n"
+#~ "            <one-to-many class=\"Order\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Order\" table=\"orders\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"date\"/>\n"
+#~ "        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
+#~ "        <list name=\"lineItems\" table=\"line_items\">\n"
+#~ "            <key column=\"order_id\"/>\n"
+#~ "            <list-index column=\"line_number\"/>\n"
+#~ "            <composite-element class=\"LineItem\">\n"
+#~ "                <property name=\"quantity\"/>\n"
+#~ "                <many-to-one name=\"product\" column=\"product_id\"/>\n"
+#~ "            </composite-element>\n"
+#~ "        </list>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Product\" table=\"products\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"serialNumber\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class name=\"Customer\" table=\"customers\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "        <set name=\"orders\" inverse=\"true\">\n"
+#~ "            <key column=\"customer_id\"/>\n"
+#~ "            <one-to-many class=\"Order\"/>\n"
+#~ "        </set>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Order\" table=\"orders\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"date\"/>\n"
+#~ "        <many-to-one name=\"customer\" column=\"customer_id\"/>\n"
+#~ "        <list name=\"lineItems\" table=\"line_items\">\n"
+#~ "            <key column=\"order_id\"/>\n"
+#~ "            <list-index column=\"line_number\"/>\n"
+#~ "            <composite-element class=\"LineItem\">\n"
+#~ "                <property name=\"quantity\"/>\n"
+#~ "                <many-to-one name=\"product\" column=\"product_id\"/>\n"
+#~ "            </composite-element>\n"
+#~ "        </list>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "    <class name=\"Product\" table=\"products\">\n"
+#~ "        <id name=\"id\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"serialNumber\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[create table customers (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table orders (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    customer_id BIGINT, \n"
+#~ "    date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table line_items (\n"
+#~ "    line_number INTEGER not null, \n"
+#~ "    order_id BIGINT not null, \n"
+#~ "    product_id BIGINT, \n"
+#~ "    quantity INTEGER, \n"
+#~ "    primary key (order_id, line_number)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table products (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    serialNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table orders \n"
+#~ "    add constraint ordersFK0 foreign key (customer_id) references "
+#~ "customers\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK0 foreign key (product_id) references "
+#~ "products\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK1 foreign key (order_id) references "
+#~ "orders]]>"
+#~ msgstr ""
+#~ "<![CDATA[create table customers (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    name VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table orders (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    customer_id BIGINT, \n"
+#~ "    date TIMESTAMP, \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table line_items (\n"
+#~ "    line_number INTEGER not null, \n"
+#~ "    order_id BIGINT not null, \n"
+#~ "    product_id BIGINT, \n"
+#~ "    quantity INTEGER, \n"
+#~ "    primary key (order_id, line_number)\n"
+#~ ")\n"
+#~ "\n"
+#~ "create table products (\n"
+#~ "    id BIGINT not null generated by default as identity, \n"
+#~ "    serialNumber VARCHAR(255), \n"
+#~ "    primary key (id)\n"
+#~ ")\n"
+#~ "\n"
+#~ "alter table orders \n"
+#~ "    add constraint ordersFK0 foreign key (customer_id) references "
+#~ "customers\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK0 foreign key (product_id) references "
+#~ "products\n"
+#~ "alter table line_items\n"
+#~ "    add constraint line_itemsFK1 foreign key (order_id) references "
+#~ "orders]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"name\"/>\n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'HOME'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "    <one-to-one name=\"mailingAddress\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'MAILING'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\" batch-size=\"2\" \n"
+#~ "        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-many-to-one name=\"person\" \n"
+#~ "                column=\"personName\"/>\n"
+#~ "        <key-property name=\"type\" \n"
+#~ "                column=\"addressType\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"street\" type=\"text\"/>\n"
+#~ "    <property name=\"state\"/>\n"
+#~ "    <property name=\"zip\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"name\"/>\n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'HOME'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "    <one-to-one name=\"mailingAddress\" \n"
+#~ "            cascade=\"all\">\n"
+#~ "        <formula>name</formula>\n"
+#~ "        <formula>'MAILING'</formula>\n"
+#~ "    </one-to-one>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\" batch-size=\"2\" \n"
+#~ "        check=\"addressType in ('MAILING', 'HOME', 'BUSINESS')\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-many-to-one name=\"person\" \n"
+#~ "                column=\"personName\"/>\n"
+#~ "        <key-property name=\"type\" \n"
+#~ "                column=\"addressType\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"street\" type=\"text\"/>\n"
+#~ "    <property name=\"state\"/>\n"
+#~ "    <property name=\"zip\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Customer\">\n"
+#~ "\n"
+#~ "    <id name=\"customerId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
+#~ "    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
+#~ "\n"
+#~ "    <list name=\"orders\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key column=\"customerId\"/>\n"
+#~ "        <index column=\"orderNumber\"/>\n"
+#~ "        <one-to-many class=\"Order\"/>\n"
+#~ "    </list>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "    <synchronize table=\"Product\"/>\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"Order$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"orderDate\" \n"
+#~ "            type=\"calendar_date\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"total\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity*p.price) \n"
+#~ "            from LineItem li, Product p \n"
+#~ "            where li.productId = p.productId \n"
+#~ "                and li.customerId = customerId \n"
+#~ "                and li.orderNumber = orderNumber )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"customer\"\n"
+#~ "            column=\"customerId\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        \n"
+#~ "    <bag name=\"lineItems\"\n"
+#~ "            fetch=\"join\" \n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "            <column name=\"orderNumber\"/>\n"
+#~ "        </key>\n"
+#~ "        <one-to-many class=\"LineItem\"/>\n"
+#~ "    </bag>\n"
+#~ "    \n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"LineItem\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"LineItem$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "        <key-property name=\"productId\" length=\"10\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"quantity\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\">\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "        <column name=\"orderNumber\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"product\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            column=\"productId\"/>\n"
+#~ "        \n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Product\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "\n"
+#~ "    <id name=\"productId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"description\" \n"
+#~ "        not-null=\"true\" \n"
+#~ "        length=\"200\"/>\n"
+#~ "    <property name=\"price\" length=\"3\"/>\n"
+#~ "    <property name=\"numberAvailable\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"numberOrdered\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity) \n"
+#~ "            from LineItem li \n"
+#~ "            where li.productId = productId )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Customer\">\n"
+#~ "\n"
+#~ "    <id name=\"customerId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"name\" not-null=\"true\" length=\"100\"/>\n"
+#~ "    <property name=\"address\" not-null=\"true\" length=\"200\"/>\n"
+#~ "\n"
+#~ "    <list name=\"orders\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key column=\"customerId\"/>\n"
+#~ "        <index column=\"orderNumber\"/>\n"
+#~ "        <one-to-many class=\"Order\"/>\n"
+#~ "    </list>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Order\" table=\"CustomerOrder\" lazy=\"true\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "    <synchronize table=\"Product\"/>\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"Order$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"orderDate\" \n"
+#~ "            type=\"calendar_date\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"total\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity*p.price) \n"
+#~ "            from LineItem li, Product p \n"
+#~ "            where li.productId = p.productId \n"
+#~ "                and li.customerId = customerId \n"
+#~ "                and li.orderNumber = orderNumber )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"customer\"\n"
+#~ "            column=\"customerId\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"/>\n"
+#~ "        \n"
+#~ "    <bag name=\"lineItems\"\n"
+#~ "            fetch=\"join\" \n"
+#~ "            inverse=\"true\"\n"
+#~ "            cascade=\"save-update\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"customerId\"/>\n"
+#~ "            <column name=\"orderNumber\"/>\n"
+#~ "        </key>\n"
+#~ "        <one-to-many class=\"LineItem\"/>\n"
+#~ "    </bag>\n"
+#~ "    \n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"LineItem\">\n"
+#~ "    \n"
+#~ "    <composite-id name=\"id\" \n"
+#~ "            class=\"LineItem$Id\">\n"
+#~ "        <key-property name=\"customerId\" length=\"10\"/>\n"
+#~ "        <key-property name=\"orderNumber\"/>\n"
+#~ "        <key-property name=\"productId\" length=\"10\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    \n"
+#~ "    <property name=\"quantity\"/>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"order\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\">\n"
+#~ "        <column name=\"customerId\"/>\n"
+#~ "        <column name=\"orderNumber\"/>\n"
+#~ "    </many-to-one>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"product\"\n"
+#~ "            insert=\"false\"\n"
+#~ "            update=\"false\" \n"
+#~ "            not-null=\"true\"\n"
+#~ "            column=\"productId\"/>\n"
+#~ "        \n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Product\">\n"
+#~ "    <synchronize table=\"LineItem\"/>\n"
+#~ "\n"
+#~ "    <id name=\"productId\"\n"
+#~ "        length=\"10\">\n"
+#~ "        <generator class=\"assigned\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"description\" \n"
+#~ "        not-null=\"true\" \n"
+#~ "        length=\"200\"/>\n"
+#~ "    <property name=\"price\" length=\"3\"/>\n"
+#~ "    <property name=\"numberAvailable\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"numberOrdered\">\n"
+#~ "        <formula>\n"
+#~ "            ( select sum(li.quantity) \n"
+#~ "            from LineItem li \n"
+#~ "            where li.productId = productId )\n"
+#~ "        </formula>\n"
+#~ "    </property>\n"
+#~ "    \n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"User\" table=\"`User`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <set name=\"groups\" table=\"UserGroup\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"Group\">\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"Group\" table=\"`Group`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"description\"/>\n"
+#~ "    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"User\">\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"User\" table=\"`User`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <set name=\"groups\" table=\"UserGroup\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"Group\">\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "    \n"
+#~ "<class name=\"Group\" table=\"`Group`\">\n"
+#~ "    <composite-id>\n"
+#~ "        <key-property name=\"name\"/>\n"
+#~ "        <key-property name=\"org\"/>\n"
+#~ "    </composite-id>\n"
+#~ "    <property name=\"description\"/>\n"
+#~ "    <set name=\"users\" table=\"UserGroup\" inverse=\"true\">\n"
+#~ "        <key>\n"
+#~ "            <column name=\"groupName\"/>\n"
+#~ "            <column name=\"org\"/>\n"
+#~ "        </key>\n"
+#~ "        <many-to-many class=\"User\">\n"
+#~ "            <column name=\"userName\"/>\n"
+#~ "            <formula>org</formula>\n"
+#~ "        </many-to-many>\n"
+#~ "    </set>\n"
+#~ "</class>\n"
+#~ "]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\"\n"
+#~ "    discriminator-value=\"P\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\" \n"
+#~ "        column=\"person_id\" \n"
+#~ "        unsaved-value=\"0\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "            \n"
+#~ "    <discriminator \n"
+#~ "        type=\"character\">\n"
+#~ "        <formula>\n"
+#~ "            case \n"
+#~ "                when title is not null then 'E' \n"
+#~ "                when salesperson is not null then 'C' \n"
+#~ "                else 'P' \n"
+#~ "            end\n"
+#~ "        </formula>\n"
+#~ "    </discriminator>\n"
+#~ "\n"
+#~ "    <property name=\"name\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        length=\"80\"/>\n"
+#~ "        \n"
+#~ "    <property name=\"sex\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        update=\"false\"/>\n"
+#~ "    \n"
+#~ "    <component name=\"address\">\n"
+#~ "        <property name=\"address\"/>\n"
+#~ "        <property name=\"zip\"/>\n"
+#~ "        <property name=\"country\"/>\n"
+#~ "    </component>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Employee\" \n"
+#~ "        discriminator-value=\"E\">\n"
+#~ "            <property name=\"title\"\n"
+#~ "                length=\"20\"/>\n"
+#~ "            <property name=\"salary\"/>\n"
+#~ "            <many-to-one name=\"manager\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Customer\" \n"
+#~ "        discriminator-value=\"C\">\n"
+#~ "            <property name=\"comments\"/>\n"
+#~ "            <many-to-one name=\"salesperson\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\"\n"
+#~ "    discriminator-value=\"P\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\" \n"
+#~ "        column=\"person_id\" \n"
+#~ "        unsaved-value=\"0\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "            \n"
+#~ "    <discriminator \n"
+#~ "        type=\"character\">\n"
+#~ "        <formula>\n"
+#~ "            case \n"
+#~ "                when title is not null then 'E' \n"
+#~ "                when salesperson is not null then 'C' \n"
+#~ "                else 'P' \n"
+#~ "            end\n"
+#~ "        </formula>\n"
+#~ "    </discriminator>\n"
+#~ "\n"
+#~ "    <property name=\"name\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        length=\"80\"/>\n"
+#~ "        \n"
+#~ "    <property name=\"sex\" \n"
+#~ "        not-null=\"true\"\n"
+#~ "        update=\"false\"/>\n"
+#~ "    \n"
+#~ "    <component name=\"address\">\n"
+#~ "        <property name=\"address\"/>\n"
+#~ "        <property name=\"zip\"/>\n"
+#~ "        <property name=\"country\"/>\n"
+#~ "    </component>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Employee\" \n"
+#~ "        discriminator-value=\"E\">\n"
+#~ "            <property name=\"title\"\n"
+#~ "                length=\"20\"/>\n"
+#~ "            <property name=\"salary\"/>\n"
+#~ "            <many-to-one name=\"manager\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "    <subclass name=\"Customer\" \n"
+#~ "        discriminator-value=\"C\">\n"
+#~ "            <property name=\"comments\"/>\n"
+#~ "            <many-to-one name=\"salesperson\"/>\n"
+#~ "    </subclass>\n"
+#~ "    \n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\" length=\"100\"/>\n"
+#~ "    \n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "        property-ref=\"person\"\n"
+#~ "        cascade=\"all\"\n"
+#~ "        fetch=\"join\"/>\n"
+#~ "    \n"
+#~ "    <set name=\"accounts\" \n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"userId\"\n"
+#~ "            property-ref=\"userId\"/>\n"
+#~ "        <one-to-many class=\"Account\"/>\n"
+#~ "    </set>\n"
+#~ "    \n"
+#~ "    <property name=\"userId\" length=\"8\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"address\" length=\"300\"/>\n"
+#~ "    <property name=\"zip\" length=\"5\"/>\n"
+#~ "    <property name=\"country\" length=\"25\"/>\n"
+#~ "    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Account\">\n"
+#~ "    <id name=\"accountId\" length=\"32\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"user\"\n"
+#~ "        column=\"userId\"\n"
+#~ "        property-ref=\"userId\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"type\" not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    \n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <property name=\"name\" length=\"100\"/>\n"
+#~ "    \n"
+#~ "    <one-to-one name=\"address\" \n"
+#~ "        property-ref=\"person\"\n"
+#~ "        cascade=\"all\"\n"
+#~ "        fetch=\"join\"/>\n"
+#~ "    \n"
+#~ "    <set name=\"accounts\" \n"
+#~ "        inverse=\"true\">\n"
+#~ "        <key column=\"userId\"\n"
+#~ "            property-ref=\"userId\"/>\n"
+#~ "        <one-to-many class=\"Account\"/>\n"
+#~ "    </set>\n"
+#~ "    \n"
+#~ "    <property name=\"userId\" length=\"8\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Address\">\n"
+#~ "\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"hilo\"/>\n"
+#~ "    </id>\n"
+#~ "\n"
+#~ "    <property name=\"address\" length=\"300\"/>\n"
+#~ "    <property name=\"zip\" length=\"5\"/>\n"
+#~ "    <property name=\"country\" length=\"25\"/>\n"
+#~ "    <many-to-one name=\"person\" unique=\"true\" not-null=\"true\"/>\n"
+#~ "\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Account\">\n"
+#~ "    <id name=\"accountId\" length=\"32\">\n"
+#~ "        <generator class=\"uuid\"/>\n"
+#~ "    </id>\n"
+#~ "    \n"
+#~ "    <many-to-one name=\"user\"\n"
+#~ "        column=\"userId\"\n"
+#~ "        property-ref=\"userId\"/>\n"
+#~ "    \n"
+#~ "    <property name=\"type\" not-null=\"true\"/>\n"
+#~ "    \n"
+#~ "</class>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/example_parentchild.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/example_parentchild.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/example_parentchild.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,26 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-08-17 20:22+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-11-27 13:54+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: example_parentchild.xml:29
 #, no-c-format
 msgid "Example: Parent/Child"
-msgstr "示例:父子关系(Parent Child Relationships)"
+msgstr "示例:父子关系(Parent/Child)"
 
 #. Tag: para
-#: example_parentchild.xml:31
-#, fuzzy, no-c-format
+#, 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 "
@@ -34,45 +36,42 @@
 "cascades</emphasis> to model a parent/child relationship efficiently and "
 "elegantly."
 msgstr ""
-"刚刚接触Hibernate的人大多是从父子关系(parent / child type relationship)的建"
-"模入手的。父子关系的建模有两种方法。由于种种原因,最方便的方法是把"
-"<literal>Parent</literal>和<literal>Child</literal>都建模成实体类,并创建一个"
-"从<literal>Parent</literal>指向<literal>Child</literal>的&lt;one-to-many&gt;"
-"关联,对新手来说尤其如此。还有一种方法,就是将<literal>Child</literal>声明为"
-"一个<literal>&lt;composite-element&gt;</literal>(组合元素)。 事实上在"
-"Hibernate中one to many关联的默认语义远没有composite element贴近parent / child"
-"关系的通常语义。下面我们会阐述如何使用<emphasis>带有级联的双向一对多关联"
-"(bidirectional one to many association with cascades)</emphasis>去建立有效、"
-"优美的parent / child关系。这一点也不难!"
+"刚刚接触 Hibernate 的人大多是从父子关系(parent / child type relationship)的"
+"建模入手的。父子关系的建模有两种方法。由于种种原因,最方便的方法是把 "
+"<literal>Parent</literal> 和 <literal>Child</literal> 都建模成实体类,并创建"
+"一个从 <literal>Parent</literal> 指向 <literal>Child</literal> 的 &lt;one-to-"
+"many&gt; 关联,对新手来说尤其如此。还有一种方法,就是将 <literal>Child</"
+"literal> 声明为一个 <literal>&lt;composite-element&gt;</literal>(组合元"
+"素)。 事实上在 Hibernate 中 one to many 关联的默认语义远没有 composite "
+"element 贴近 parent / child 关系的通常语义。下面我们会阐述如何使用<emphasis>"
+"带有级联的双向一对多关联(idirectional one to many association with "
+"cascades)</emphasis>去建立有效、优美的 parent / child 关系。"
 
 #. Tag: title
-#: example_parentchild.xml:45
 #, no-c-format
 msgid "A note about collections"
-msgstr "关于collections需要注意的一点"
+msgstr "关于 collections 需要注意的一点"
 
 #. Tag: para
-#: example_parentchild.xml:47
-#, fuzzy, no-c-format
+#, 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 collections被当作其所属实体而不是其包含实体的一个逻辑部分。这非常重"
-"要!它主要体现为以下几点:"
+"Hibernate collections 被当作其所属实体而不是其包含实体的一个逻辑部分。这非常"
+"重要,它主要体现为以下几点:"
 
 #. Tag: para
-#: example_parentchild.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When you remove/add an object from/to a collection, the version number of "
 "the collection owner is incremented."
-msgstr "当删除或增加collection中对象的时候,collection所属者的版本值会递增。"
+msgstr ""
+"当删除或增加 collection 中对象的时候,collection 所属者的版本值会递增。 "
 
 #. Tag: para
-#: example_parentchild.xml:60
-#, fuzzy, no-c-format
+#, 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 "
@@ -80,13 +79,13 @@
 "value type instance to the collection will cause its state to be immediately "
 "persistent."
 msgstr ""
-"如果一个从collection中移除的对象是一个值类型(value type)的实例,比如"
+"如果一个从 collection 中移除的对象是一个值类型(value type)的实例,比如 "
 "composite element,那么这个对象的持久化状态将会终止,其在数据库中对应的记录会"
-"被删除。同样的,向collection增加一个value type的实例将会使之立即被持久化。"
+"被删除。同样的,向 collection 增加一个 value type 的实例将会使之立即被持久"
+"化。 "
 
 #. Tag: para
-#: example_parentchild.xml:68
-#, fuzzy, no-c-format
+#, 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 "
@@ -94,13 +93,13 @@
 "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 ""
-"另一方面,如果从一对多或多对多关联的collection中移除一个实体,在缺省情况下这"
-"个对象并不会被删除。这个行为是完全合乎逻辑的--改变一个实体的内部状态不应该"
-"使与它关联的实体消失掉!同样的,向collection增加一个实体不会使之被持久化。"
+"另一方面,如果从一对多或多对多关联的 collection 中移除一个实体,在缺省情况下"
+"这个对象并不会被删除。这个行为是完全合乎逻辑的--改变一个实体的内部状态不应"
+"该使与它关联的实体消失掉。同样的,向 collection 增加一个实体不会使之被持久"
+"化。 "
 
 #. Tag: para
-#: example_parentchild.xml:78
-#, fuzzy, no-c-format
+#, 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 "
@@ -108,106 +107,68 @@
 "case of a parent/child relationship. In this case, the life of the child is "
 "bound to the life cycle of the parent."
 msgstr ""
-"实际上,向Collection增加一个实体的缺省动作只是在两个实体之间创建一个连接而"
+"实际上,向 Collection 增加一个实体的缺省动作只是在两个实体之间创建一个连接而"
 "已,同样移除的时候也只是删除连接。这种处理对于所有的情况都是合适的。对于父子"
-"关系则是完全不适合的,在这种关系下,子对象的生存绑定于父对象的生存周期。"
+"关系则是完全不适合的,在这种关系下,子对象的生存绑定于父对象的生存周期。 "
 
 #. Tag: title
-#: example_parentchild.xml:88
 #, no-c-format
 msgid "Bidirectional one-to-many"
-msgstr "双向的一对多关系(Bidirectional one-to-many)"
+msgstr "双向的一对多关系(Bidirectional one-to-many)"
 
 #. Tag: para
-#: example_parentchild.xml:90
 #, no-c-format
 msgid ""
 "Suppose we start with a simple <literal>&lt;one-to-many&gt;</literal> "
 "association from <literal>Parent</literal> to <literal>Child</literal>."
-msgstr "假设我们要实现一个简单的从Parent到Child的&lt;one-to-many&gt;关联。"
-
-#. Tag: programlisting
-#: example_parentchild.xml:95
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
 msgstr ""
+"假设我们要实现一个简单的从 Parent 到 Child 的 &lt;one-to-many&gt; 关联。"
 
 #. Tag: para
-#: example_parentchild.xml:97
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "If we were to execute the following code:"
-msgstr "如果我们运行下面的代码"
+msgstr "如果我们运行下面的代码:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:101
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = .....;\n"
-"Child c = new Child();\n"
-"p.getChildren().add(c);\n"
-"session.save(c);\n"
-"session.flush();]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:103
 #, no-c-format
 msgid "Hibernate would issue two SQL statements:"
-msgstr "Hibernate会产生两条SQL语句:"
+msgstr "Hibernate 会产生两条 SQL 语句:"
 
 #. Tag: para
-#: example_parentchild.xml:109
 #, no-c-format
 msgid ""
 "an <literal>INSERT</literal> to create the record for <literal>c</literal>"
-msgstr "一条<literal>INSERT</literal>语句,为<literal>c</literal>创建一条记录"
+msgstr ""
+"一条 <literal>INSERT</literal> 语句,为 <literal>c</literal> 创建一条记录"
 
 #. Tag: para
-#: example_parentchild.xml:112
 #, no-c-format
 msgid ""
 "an <literal>UPDATE</literal> to create the link from <literal>p</literal> to "
 "<literal>c</literal>"
 msgstr ""
-"一条<literal>UPDATE</literal>语句,创建从<literal>p</literal>到<literal>c</"
-"literal>的连接"
+"一条 <literal>UPDATE</literal> 语句,创建从 <literal>p</literal> 到 "
+"<literal>c</literal> 的连接"
 
 #. Tag: para
-#: example_parentchild.xml:119
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is not only inefficient, but also violates any <literal>NOT NULL</"
 "literal> constraint on the <literal>parent_id</literal> column. You can fix "
 "the nullability constraint violation by specifying <literal>not-null=\"true"
 "\"</literal> in the collection mapping:"
 msgstr ""
-"这样做不仅效率低,而且违反了列<literal>parent_id</literal>非空的限制。我们可"
-"以通过在集合类映射上指定<literal>not-null=\"true\"</literal>来解决违反非空约"
-"束的问题:"
+"这样做不仅效率低,而且违反了 <literal>parent_id</literal> 列 "
+"<literal>parent_id</literal> 非空的限制。我们可以通过在集合类映射上指定 "
+"<literal>not-null=\"true\"</literal> 来解决违反非空约束的问题:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:125
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\">\n"
-"    <key column=\"parent_id\" not-null=\"true\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:127
 #, no-c-format
 msgid "However, this is not the recommended solution."
 msgstr "然而,这并非是推荐的解决方法。"
 
 #. Tag: para
-#: example_parentchild.xml:130
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The underlying cause of this behavior is that the link (the foreign key "
 "<literal>parent_id</literal>) from <literal>p</literal> to <literal>c</"
@@ -215,261 +176,131 @@
 "object and is therefore not created in the <literal>INSERT</literal>. The "
 "solution is to make the link part of the <literal>Child</literal> mapping."
 msgstr ""
-"这种现象的根本原因是从<literal>p</literal>到<literal>c</literal>的连接(外键"
-"parent_id)没有被当作<literal>Child</literal>对象状态的一部分,因而没有在"
-"INSERT语句中被创建。因此解决的办法就是把这个连接添加到Child的映射中。"
+"这种现象的根本原因是从 <literal>p</literal> 到 <literal>c</literal> 的连接"
+"(外键 parent_id)没有被当作 <literal>Child</literal> 对象状态的一部分,因而"
+"没有在 <literal>INSERT</literal> 语句中被创建。因此解决的办法就是把这个连接添"
+"加到 <literal>Child</literal> 的映射中。"
 
-#. Tag: programlisting
-#: example_parentchild.xml:137
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"parent\" column=\"parent_id\" not-null=\"true\"/"
-">]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:139
-#, fuzzy, no-c-format
-msgid ""
 "You also need to add the <literal>parent</literal> property to the "
 "<literal>Child</literal> class."
 msgstr ""
-"(我们还需要为类<literal>Child</literal>添加<literal>parent</literal>属性)"
+"你还需要为类 <literal>Child</literal> 添加 <literal>parent</literal> 属性。"
 
 #. Tag: para
-#: example_parentchild.xml:143
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now that the <literal>Child</literal> entity is managing the state of the "
 "link, we tell the collection not to update the link. We use the "
 "<literal>inverse</literal> attribute to do this:"
 msgstr ""
-"现在实体<literal>Child</literal>在管理连接的状态,为了使collection不更新连"
-"接,我们使用<literal>inverse</literal>属性。"
+"现在实体 <literal>Child</literal> 在管理连接的状态,为了使 collection 不更新"
+"连接,我们使用 <literal>inverse</literal> 属性:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:148
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:150
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The following code would be used to add a new <literal>Child</literal>:"
-msgstr "下面的代码是用来添加一个新的<literal>Child</literal>"
+msgstr "下面的代码是用来添加一个新的 <literal>Child</literal>:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:154
-#, no-c-format
-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 ""
-
 #. Tag: para
-#: example_parentchild.xml:156
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Only one SQL <literal>INSERT</literal> would now be issued."
-msgstr "现在,只会有一条<literal>INSERT</literal>语句被执行!"
+msgstr "现在,只会有一条 <literal>INSERT</literal> 语句被执行。"
 
 #. Tag: para
-#: example_parentchild.xml:160
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You could also create an <literal>addChild()</literal> method of "
 "<literal>Parent</literal>."
 msgstr ""
-"为了让事情变得井井有条,可以为<literal>Parent</literal>加一个"
-"<literal>addChild()</literal>方法。"
+"为了让事情变得井井有条,可以为 <literal>Parent</literal> 加一个 "
+"<literal>addChild()</literal> 方法。"
 
-#. Tag: programlisting
-#: example_parentchild.xml:165
-#, no-c-format
-msgid ""
-"<![CDATA[public void addChild(Child c) {\n"
-"    c.setParent(this);\n"
-"    children.add(c);\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The code to add a <literal>Child</literal> looks like this:"
-msgstr "现在,添加<literal>Child</literal>的代码就是这样"
+msgstr "现在,添加 <literal>Child</literal> 的代码就是这样:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:171
-#, no-c-format
-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 ""
-
 #. Tag: title
-#: example_parentchild.xml:176
 #, no-c-format
 msgid "Cascading life cycle"
-msgstr "级联生命周期(Cascading life cycle)"
+msgstr "级联生命周期(Cascading lifecycle) "
 
 #. Tag: para
-#: example_parentchild.xml:178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can address the frustrations of the explicit call to <literal>save()</"
 "literal> by using cascades."
 msgstr ""
-"需要显式调用<literal>save()</literal>仍然很麻烦,我们可以用级联来解决这个问"
-"题。"
+"需要显式调用 <literal>save()</literal> 仍然很麻烦,我们可以用级联来解决这个问"
+"题。 "
 
-#. Tag: programlisting
-#: example_parentchild.xml:183
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:185
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "This simplifies the code above to:"
-msgstr "这样上面的代码可以简化为:"
+msgstr "这样上面的代码可以简化为: "
 
-#. Tag: programlisting
-#: example_parentchild.xml:189
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-"Child c = new Child();\n"
-"p.addChild(c);\n"
-"session.flush();]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:191
-#, fuzzy, no-c-format
-msgid ""
 "Similarly, we do not need to iterate over the children when saving or "
 "deleting a <literal>Parent</literal>. The following removes <literal>p</"
 "literal> and all its children from the database."
 msgstr ""
-"同样的,保存或删除<literal>Parent</literal>对象的时候并不需要遍历其子对象。 "
-"下面的代码会删除对象<literal>p</literal>及其所有子对象对应的数据库记录。"
+"同样的,保存或删除 <literal>Parent</literal> 对象的时候并不需要遍历其子对象。"
+"下面的代码会删除对象 <literal>p</literal> 及其所有子对象对应的数据库记录。 "
 
-#. Tag: programlisting
-#: example_parentchild.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
-"session.delete(p);\n"
-"session.flush();]]>"
-msgstr ""
-
 #. Tag: para
-#: example_parentchild.xml:198
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "However, the following code:"
-msgstr "然而,这段代码"
+msgstr "然而,这段代码:"
 
-#. Tag: programlisting
-#: example_parentchild.xml:202
+#. Tag: para
 #, no-c-format
 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 ""
-
-#. Tag: para
-#: example_parentchild.xml:204
-#, fuzzy, no-c-format
-msgid ""
 "will not remove <literal>c</literal> from the database. In this case, it "
 "will only remove the link to <literal>p</literal> and cause a <literal>NOT "
 "NULL</literal> constraint violation. You need to explicitly <literal>delete()"
 "</literal> the <literal>Child</literal>."
 msgstr ""
-"不会从数据库删除<literal>c</literal>;它只会删除与<literal>p</literal>之间的"
-"连接(并且会导致违反<literal>NOT NULL</literal>约束,在这个例子中)。你需要显"
-"式调用<literal>delete()</literal>来删除<literal>Child</literal>。"
+"不会从数据库删除<literal>c</literal>;它只会删除与 <literal>p</literal> 之间"
+"的连接(并且会导致违反 <literal>NOT NULL</literal> 约束,在这个例子中)。你需"
+"要显式调用 <literal>delete()</literal> 来删除 <literal>Child</literal>。 "
 
-#. Tag: programlisting
-#: example_parentchild.xml:210
+#. Tag: para
 #, no-c-format
 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 ""
-
-#. Tag: para
-#: example_parentchild.xml:212
-#, fuzzy, no-c-format
-msgid ""
 "In our case, a <literal>Child</literal> cannot exist without its parent. So "
 "if we remove a <literal>Child</literal> from the collection, we do want it "
 "to be deleted. To do this, we must use <literal>cascade=\"all-delete-orphan"
 "\"</literal>."
 msgstr ""
-"在我们的例子中,如果没有父对象,子对象就不应该存在,如果将子对象从collection"
-"中移除,实际上我们是想删除它。要实现这种要求,就必须使用<literal>cascade="
-"\"all-delete-orphan\"</literal>。"
+"在我们的例子中,如果没有父对象,子对象就不应该存在,如果将子对象从 "
+"collection 中移除,实际上我们是想删除它。要实现这种要求,就必须使用 "
+"<literal>cascade=\"all-delete-orphan\"</literal>。 "
 
-#. Tag: programlisting
-#: example_parentchild.xml:218
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all-delete-orphan"
-"\">\n"
-"    <key column=\"parent_id\"/>\n"
-"    <one-to-many class=\"Child\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: example_parentchild.xml:220
-#, fuzzy, no-c-format
-msgid ""
 "Even though the collection mapping specifies <literal>inverse=\"true\"</"
 "literal>, cascades are still processed by iterating the collection elements. "
 "If you need an object be saved, deleted or updated by cascade, you must add "
 "it to the collection. It is not enough to simply call <literal>setParent()</"
 "literal>."
 msgstr ""
-"注意:即使在collection一方的映射中指定<literal>inverse=\"true\"</literal>,级"
-"联仍然是通过遍历collection中的元素来处理的。如果你想要通过级联进行子对象的插"
-"入、删除、更新操作,就必须把它加到collection中,只调用<literal>setParent()</"
-"literal>是不够的。"
+"注意:即使在 collection 一方的映射中指定 <literal>inverse=\"true\"</"
+"literal>,级联仍然是通过遍历 collection 中的元素来处理的。如果你想要通过级联"
+"进行子对象的插入、删除、更新操作,就必须把它加到 collection 中,只调用 "
+"<literal>setParent()</literal> 是不够的。 "
 
 #. Tag: title
-#: example_parentchild.xml:230
 #, no-c-format
 msgid "Cascades and <literal>unsaved-value</literal>"
-msgstr ""
-"级联与<literal>未保存值</literal>(Cascades and <literal>unsaved-value</"
-"literal>)"
+msgstr "级联与未保存值(<literal>unsaved-value</literal>)"
 
 #. Tag: para
-#: example_parentchild.xml:232
 #, fuzzy, no-c-format
 msgid ""
 "Suppose we loaded up a <literal>Parent</literal> in one <literal>Session</"
@@ -482,47 +313,33 @@
 "literal> have generated identifier properties of type <literal>Long</"
 "literal>. Hibernate will use the identifier and version/timestamp property "
 "value to determine which of the children are new. (See <xref linkend="
-"\"objectstate-saveorupdate\"/>.) <emphasis>In Hibernate3, it is no longer "
+"\"objectstate-saveorupdate\" />.) <emphasis>In Hibernate3, it is no longer "
 "necessary to specify an <literal>unsaved-value</literal> explicitly.</"
 "emphasis>"
 msgstr ""
-"假设我们从<literal>Session</literal>中装入了一个<literal>Parent</literal>对"
-"象,用户界面对其进行了修改,然后希望在一个新的Session里面调用<literal>update"
-"()</literal>来保存这些修改。对象<literal>Parent</literal>包含了子对象的集合,"
-"由于打开了级联更新,Hibernate需要知道哪些Child对象是新实例化的,哪些代表数据"
-"库中已经存在的记录。我们假设<literal>Parent</literal>和<literal>Child</"
-"literal>对象的标识属性都是自动生成的,类型为<literal>java.lang.Long</"
-"literal>。Hibernate会使用标识属性的值,和version 或 timestamp 属性,来判断哪"
-"些子对象是新的。(参见<xref linkend=\"objectstate-saveorupdate\"/>.) "
-"<emphasis>在 Hibernate3 中,显式指定<literal>unsaved-value</literal>不再是必须"
-"的了。</emphasis>"
+"假设我们从 <literal>Session</literal> 中装入了一个 <literal>Parent</literal> "
+"对象,用户界面对其进行了修改,然后希望在一个新的 Session 里面调用 "
+"<literal>update()</literal> 来保存这些修改。对象 <literal>Parent</literal> 包"
+"含了子对象的集合,由于打开了级联更新,Hibernate 需要知道哪些 Child 对象是新实"
+"例化的,哪些代表数据库中已经存在的记录。我们假设 <literal>Parent</literal> "
+"和 <literal>Child</literal> 对象的标识属性都是自动生成的,类型为 "
+"<literal>java.lang.Long</literal>。Hibernate 会使用标识属性的值,和 version "
+"或 timestamp 属性,来判断哪些子对象是新的。(参见 <xref linkend="
+"\"objectstate-saveorupdate\"/>)<emphasis>在 Hibernate3 中,显式指定 "
+"<literal>unsaved-value</literal> 不再是必须的了。</emphasis>"
 
 #. Tag: para
-#: example_parentchild.xml:244
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following code will update <literal>parent</literal> and <literal>child</"
 "literal> and insert <literal>newChild</literal>:"
 msgstr ""
-"下面的代码会更新<literal>parent</literal>和<literal>child</literal>对象,并且"
-"插入<literal>newChild</literal>对象。"
+"下面的代码会更新 <literal>parent</literal> 和 <literal>child</literal> 对象,"
+"并且插入 <literal>newChild</literal> 对象。 "
 
-#. Tag: programlisting
-#: example_parentchild.xml:249
+#. Tag: para
 #, no-c-format
 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 ""
-
-#. Tag: para
-#: example_parentchild.xml:251
-#, fuzzy, 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 "
@@ -532,30 +349,27 @@
 "cache or, worst case, the database, to see if the row exists."
 msgstr ""
 "这对于自动生成标识的情况是非常好的,但是自分配的标识和复合标识怎么办呢?这是"
-"有点麻烦,因为Hibernate没有办法区分新实例化的对象(标识被用户指定了)和前一个"
-"Session装入的对象。在这种情况下,Hibernate会使用timestamp或version属性,或者"
-"查询第二级缓存,或者最坏的情况,查询数据库,来确认是否此行存在。"
+"有点麻烦,因为 Hibernate 没有办法区分新实例化的对象(标识被用户指定了)和前一"
+"个 Session 装入的对象。在这种情况下,Hibernate 会使用 timestamp 或 version 属"
+"性,或者查询第二级缓存,或者最坏的情况,查询数据库,来确认是否此行存在。 "
 
 #. Tag: title
-#: example_parentchild.xml:263
 #, no-c-format
 msgid "Conclusion"
 msgstr "结论"
 
 #. Tag: para
-#: example_parentchild.xml:265
-#, fuzzy, no-c-format
+#, 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应用程序都会经常用到父子对象模式。"
+"常好。大部分 Hibernate 应用程序都会经常用到父子对象模式。 "
 
 #. Tag: para
-#: example_parentchild.xml:270
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We mentioned an alternative in the first paragraph. None of the above issues "
 "exist in the case of <literal>&lt;composite-element&gt;</literal> mappings, "
@@ -564,7 +378,184 @@
 "composite elements cannot own collections and they should not be the child "
 "of any entity other than the unique parent."
 msgstr ""
-"在第一段中我们曾经提到另一个方案。上面的这些问题都不会出现在<literal>&lt;"
-"composite-element&gt;</literal>映射中,它准确地表达了父子关系的语义。很不幸复"
-"合元素还有两个重大限制:复合元素不能拥有collections,并且,除了用于惟一的父对"
-"象外,它们不能再作为其它任何实体的子对象。"
+"在第一段中我们曾经提到另一个方案。上面的这些问题都不会出现在 <literal>&lt;"
+"composite-element&gt;</literal> 映射中,它准确地表达了父子关系的语义。很不幸"
+"复合元素还有两个重大限制:复合元素不能拥有 collections,并且,除了用于惟一的"
+"父对象外,它们不能再作为其它任何实体的子对象。 "
+
+#~ msgid ""
+#~ "<![CDATA[<set name=\"children\">\n"
+#~ "    <key column=\"parent_id\"/>\n"
+#~ "    <one-to-many class=\"Child\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"children\">\n"
+#~ "    <key column=\"parent_id\"/>\n"
+#~ "    <one-to-many class=\"Child\"/>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Parent p = .....;\n"
+#~ "Child c = new Child();\n"
+#~ "p.getChildren().add(c);\n"
+#~ "session.save(c);\n"
+#~ "session.flush();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Parent p = .....;\n"
+#~ "Child c = new Child();\n"
+#~ "p.getChildren().add(c);\n"
+#~ "session.save(c);\n"
+#~ "session.flush();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set name=\"children\">\n"
+#~ "    <key column=\"parent_id\" not-null=\"true\"/>\n"
+#~ "    <one-to-many class=\"Child\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"children\">\n"
+#~ "    <key column=\"parent_id\" not-null=\"true\"/>\n"
+#~ "    <one-to-many class=\"Child\"/>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"parent\" column=\"parent_id\" not-null=\"true"
+#~ "\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<many-to-one name=\"parent\" column=\"parent_id\" not-null=\"true"
+#~ "\"/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set name=\"children\" inverse=\"true\">\n"
+#~ "    <key column=\"parent_id\"/>\n"
+#~ "    <one-to-many class=\"Child\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"children\" inverse=\"true\">\n"
+#~ "    <key column=\"parent_id\"/>\n"
+#~ "    <one-to-many class=\"Child\"/>\n"
+#~ "</set>]]>"
+
+#~ 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 ""
+#~ "<![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();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[public void addChild(Child c) {\n"
+#~ "    c.setParent(this);\n"
+#~ "    children.add(c);\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[public void addChild(Child c) {\n"
+#~ "    c.setParent(this);\n"
+#~ "    children.add(c);\n"
+#~ "}]]>"
+
+#~ 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 ""
+#~ "<![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();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all\">\n"
+#~ "    <key column=\"parent_id\"/>\n"
+#~ "    <one-to-many class=\"Child\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all\">\n"
+#~ "    <key column=\"parent_id\"/>\n"
+#~ "    <one-to-many class=\"Child\"/>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
+#~ "Child c = new Child();\n"
+#~ "p.addChild(c);\n"
+#~ "session.flush();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
+#~ "Child c = new Child();\n"
+#~ "p.addChild(c);\n"
+#~ "session.flush();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
+#~ "session.delete(p);\n"
+#~ "session.flush();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Parent p = (Parent) session.load(Parent.class, pid);\n"
+#~ "session.delete(p);\n"
+#~ "session.flush();]]>"
+
+#~ 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 ""
+#~ "<![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();]]>"
+
+#~ 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 ""
+#~ "<![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();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all-delete-"
+#~ "orphan\">\n"
+#~ "    <key column=\"parent_id\"/>\n"
+#~ "    <one-to-many class=\"Child\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set name=\"children\" inverse=\"true\" cascade=\"all-delete-"
+#~ "orphan\">\n"
+#~ "    <key column=\"parent_id\"/>\n"
+#~ "    <one-to-many class=\"Child\"/>\n"
+#~ "</set>]]>"
+
+#~ 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 ""
+#~ "<![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();]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/example_weblog.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/example_weblog.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/example_weblog.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,481 +1,856 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-11-27 13:54+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: example_weblog.xml:29
 #, no-c-format
 msgid "Example: Weblog Application"
-msgstr "示例:Weblog 应用程序"
+msgstr "示例:Weblog 应用程序 "
 
 #. Tag: title
-#: example_weblog.xml:32
 #, no-c-format
 msgid "Persistent Classes"
-msgstr "持久化类"
+msgstr "持久化类(Persistent Classes)"
 
 #. Tag: para
-#: example_weblog.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The persistent classes here represent a weblog and an item posted in a "
 "weblog. They are to be modelled as a standard parent/child relationship, but "
 "we will use an ordered bag, instead of a set:"
 msgstr ""
-"下面的持久化类表示一个weblog和在其中张贴的一个贴子。他们是标准的父/子关系模"
-"型,但是我们会用一个有序包(ordered bag)而非集合(set)。"
+"下面的持久化类表示一个 weblog 和在其中张贴的一个贴子。他们是标准的父/子关系模"
+"型,但是我们会用一个有序包(ordered bag)而非集合(set)。 "
 
-#. Tag: programlisting
-#: example_weblog.xml:40
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.util.List;\n"
-"\n"
-"public class Blog {\n"
-"    private Long _id;\n"
-"    private String _name;\n"
-"    private List _items;\n"
-"\n"
-"    public Long getId() {\n"
-"        return _id;\n"
-"    }\n"
-"    public List getItems() {\n"
-"        return _items;\n"
-"    }\n"
-"    public String getName() {\n"
-"        return _name;\n"
-"    }\n"
-"    public void setId(Long long1) {\n"
-"        _id = long1;\n"
-"    }\n"
-"    public void setItems(List list) {\n"
-"        _items = list;\n"
-"    }\n"
-"    public void setName(String string) {\n"
-"        _name = string;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: example_weblog.xml:42
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.text.DateFormat;\n"
-"import java.util.Calendar;\n"
-"\n"
-"public class BlogItem {\n"
-"    private Long _id;\n"
-"    private Calendar _datetime;\n"
-"    private String _text;\n"
-"    private String _title;\n"
-"    private Blog _blog;\n"
-"\n"
-"    public Blog getBlog() {\n"
-"        return _blog;\n"
-"    }\n"
-"    public Calendar getDatetime() {\n"
-"        return _datetime;\n"
-"    }\n"
-"    public Long getId() {\n"
-"        return _id;\n"
-"    }\n"
-"    public String getText() {\n"
-"        return _text;\n"
-"    }\n"
-"    public String getTitle() {\n"
-"        return _title;\n"
-"    }\n"
-"    public void setBlog(Blog blog) {\n"
-"        _blog = blog;\n"
-"    }\n"
-"    public void setDatetime(Calendar calendar) {\n"
-"        _datetime = calendar;\n"
-"    }\n"
-"    public void setId(Long long1) {\n"
-"        _id = long1;\n"
-"    }\n"
-"    public void setText(String string) {\n"
-"        _text = string;\n"
-"    }\n"
-"    public void setTitle(String string) {\n"
-"        _title = string;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: example_weblog.xml:47
 #, no-c-format
 msgid "Hibernate Mappings"
 msgstr "Hibernate 映射"
 
 #. Tag: para
-#: example_weblog.xml:49
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The XML mappings are now straightforward. For example:"
-msgstr "下列的XML映射应该是很直白的。"
+msgstr "下列的 XML 映射应该是很直白的。例如:"
 
-#. Tag: programlisting
-#: example_weblog.xml:53
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"    <class\n"
-"        name=\"Blog\"\n"
-"        table=\"BLOGS\">\n"
-"\n"
-"        <id\n"
-"            name=\"id\"\n"
-"            column=\"BLOG_ID\">\n"
-"\n"
-"            <generator class=\"native\"/>\n"
-"\n"
-"        </id>\n"
-"\n"
-"        <property\n"
-"            name=\"name\"\n"
-"            column=\"NAME\"\n"
-"            not-null=\"true\"\n"
-"            unique=\"true\"/>\n"
-"\n"
-"        <bag\n"
-"            name=\"items\"\n"
-"            inverse=\"true\"\n"
-"            order-by=\"DATE_TIME\"\n"
-"            cascade=\"all\">\n"
-"\n"
-"            <key column=\"BLOG_ID\"/>\n"
-"            <one-to-many class=\"BlogItem\"/>\n"
-"\n"
-"        </bag>\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: example_weblog.xml:55
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"eg\">\n"
-"\n"
-"    <class\n"
-"        name=\"BlogItem\"\n"
-"        table=\"BLOG_ITEMS\"\n"
-"        dynamic-update=\"true\">\n"
-"\n"
-"        <id\n"
-"            name=\"id\"\n"
-"            column=\"BLOG_ITEM_ID\">\n"
-"\n"
-"            <generator class=\"native\"/>\n"
-"\n"
-"        </id>\n"
-"\n"
-"        <property\n"
-"            name=\"title\"\n"
-"            column=\"TITLE\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <property\n"
-"            name=\"text\"\n"
-"            column=\"TEXT\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <property\n"
-"            name=\"datetime\"\n"
-"            column=\"DATE_TIME\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"        <many-to-one\n"
-"            name=\"blog\"\n"
-"            column=\"BLOG_ID\"\n"
-"            not-null=\"true\"/>\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: example_weblog.xml:60
 #, no-c-format
 msgid "Hibernate Code"
 msgstr "Hibernate 代码"
 
 #. Tag: para
-#: example_weblog.xml:62
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following class demonstrates some of the kinds of things we can do with "
 "these classes using Hibernate:"
-msgstr "下面的类演示了我们可以使用Hibernate对这些类进行的一些操作。"
+msgstr "下面的类演示了我们可以使用 Hibernate 对这些类进行的一些操作:"
 
-#. Tag: programlisting
-#: example_weblog.xml:67
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"import java.util.ArrayList;\n"
-"import java.util.Calendar;\n"
-"import java.util.Iterator;\n"
-"import java.util.List;\n"
-"\n"
-"import org.hibernate.HibernateException;\n"
-"import org.hibernate.Query;\n"
-"import org.hibernate.Session;\n"
-"import org.hibernate.SessionFactory;\n"
-"import org.hibernate.Transaction;\n"
-"import org.hibernate.cfg.Configuration;\n"
-"import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
-"\n"
-"public class BlogMain {\n"
-"    \n"
-"    private SessionFactory _sessions;\n"
-"    \n"
-"    public void configure() throws HibernateException {\n"
-"        _sessions = new Configuration()\n"
-"            .addClass(Blog.class)\n"
-"            .addClass(BlogItem.class)\n"
-"            .buildSessionFactory();\n"
-"    }\n"
-"    \n"
-"    public void exportTables() throws HibernateException {\n"
-"        Configuration cfg = new Configuration()\n"
-"            .addClass(Blog.class)\n"
-"            .addClass(BlogItem.class);\n"
-"        new SchemaExport(cfg).create(true, true);\n"
-"    }\n"
-"    \n"
-"    public Blog createBlog(String name) throws HibernateException {\n"
-"        \n"
-"        Blog blog = new Blog();\n"
-"        blog.setName(name);\n"
-"        blog.setItems( new ArrayList() );\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.persist(blog);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return blog;\n"
-"    }\n"
-"    \n"
-"    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
-"                        throws HibernateException {\n"
-"        \n"
-"        BlogItem item = new BlogItem();\n"
-"        item.setTitle(title);\n"
-"        item.setText(text);\n"
-"        item.setBlog(blog);\n"
-"        item.setDatetime( Calendar.getInstance() );\n"
-"        blog.getItems().add(item);\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.update(blog);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return item;\n"
-"    }\n"
-"    \n"
-"    public BlogItem createBlogItem(Long blogid, String title, String text)\n"
-"                        throws HibernateException {\n"
-"        \n"
-"        BlogItem item = new BlogItem();\n"
-"        item.setTitle(title);\n"
-"        item.setText(text);\n"
-"        item.setDatetime( Calendar.getInstance() );\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
-"            item.setBlog(blog);\n"
-"            blog.getItems().add(item);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return item;\n"
-"    }\n"
-"    \n"
-"    public void updateBlogItem(BlogItem item, String text)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        item.setText(text);\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            session.update(item);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"    }\n"
-"    \n"
-"    public void updateBlogItem(Long itemid, String text)\n"
-"                    throws HibernateException {\n"
-"    \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            BlogItem item = (BlogItem) session.load(BlogItem.class, "
-"itemid);\n"
-"            item.setText(text);\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"    }\n"
-"    \n"
-"    public List listAllBlogNamesAndItemCounts(int max)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        List result = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"select blog.id, blog.name, count(blogItem) \" +\n"
-"                \"from Blog as blog \" +\n"
-"                \"left outer join blog.items as blogItem \" +\n"
-"                \"group by blog.name, blog.id \" +\n"
-"                \"order by max(blogItem.datetime)\"\n"
-"            );\n"
-"            q.setMaxResults(max);\n"
-"            result = q.list();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return result;\n"
-"    }\n"
-"    \n"
-"    public Blog getBlogAndAllItems(Long blogid)\n"
-"                    throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        Blog blog = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"from Blog as blog \" +\n"
-"                \"left outer join fetch blog.items \" +\n"
-"                \"where blog.id = :blogid\"\n"
-"            );\n"
-"            q.setParameter(\"blogid\", blogid);\n"
-"            blog  = (Blog) q.uniqueResult();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return blog;\n"
-"    }\n"
-"    \n"
-"    public List listBlogsAndRecentItems() throws HibernateException {\n"
-"        \n"
-"        Session session = _sessions.openSession();\n"
-"        Transaction tx = null;\n"
-"        List result = null;\n"
-"        try {\n"
-"            tx = session.beginTransaction();\n"
-"            Query q = session.createQuery(\n"
-"                \"from Blog as blog \" +\n"
-"                \"inner join blog.items as blogItem \" +\n"
-"                \"where blogItem.datetime > :minDate\"\n"
-"            );\n"
-"\n"
-"            Calendar cal = Calendar.getInstance();\n"
-"            cal.roll(Calendar.MONTH, false);\n"
-"            q.setCalendar(\"minDate\", cal);\n"
-"            \n"
-"            result = q.list();\n"
-"            tx.commit();\n"
-"        }\n"
-"        catch (HibernateException he) {\n"
-"            if (tx!=null) tx.rollback();\n"
-"            throw he;\n"
-"        }\n"
-"        finally {\n"
-"            session.close();\n"
-"        }\n"
-"        return result;\n"
-"    }\n"
-"}]]>"
-msgstr ""
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "public class Blog {\n"
+#~ "    private Long _id;\n"
+#~ "    private String _name;\n"
+#~ "    private List _items;\n"
+#~ "\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public List getItems() {\n"
+#~ "        return _items;\n"
+#~ "    }\n"
+#~ "    public String getName() {\n"
+#~ "        return _name;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setItems(List list) {\n"
+#~ "        _items = list;\n"
+#~ "    }\n"
+#~ "    public void setName(String string) {\n"
+#~ "        _name = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "public class Blog {\n"
+#~ "    private Long _id;\n"
+#~ "    private String _name;\n"
+#~ "    private List _items;\n"
+#~ "\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public List getItems() {\n"
+#~ "        return _items;\n"
+#~ "    }\n"
+#~ "    public String getName() {\n"
+#~ "        return _name;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setItems(List list) {\n"
+#~ "        _items = list;\n"
+#~ "    }\n"
+#~ "    public void setName(String string) {\n"
+#~ "        _name = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.text.DateFormat;\n"
+#~ "import java.util.Calendar;\n"
+#~ "\n"
+#~ "public class BlogItem {\n"
+#~ "    private Long _id;\n"
+#~ "    private Calendar _datetime;\n"
+#~ "    private String _text;\n"
+#~ "    private String _title;\n"
+#~ "    private Blog _blog;\n"
+#~ "\n"
+#~ "    public Blog getBlog() {\n"
+#~ "        return _blog;\n"
+#~ "    }\n"
+#~ "    public Calendar getDatetime() {\n"
+#~ "        return _datetime;\n"
+#~ "    }\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public String getText() {\n"
+#~ "        return _text;\n"
+#~ "    }\n"
+#~ "    public String getTitle() {\n"
+#~ "        return _title;\n"
+#~ "    }\n"
+#~ "    public void setBlog(Blog blog) {\n"
+#~ "        _blog = blog;\n"
+#~ "    }\n"
+#~ "    public void setDatetime(Calendar calendar) {\n"
+#~ "        _datetime = calendar;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setText(String string) {\n"
+#~ "        _text = string;\n"
+#~ "    }\n"
+#~ "    public void setTitle(String string) {\n"
+#~ "        _title = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.text.DateFormat;\n"
+#~ "import java.util.Calendar;\n"
+#~ "\n"
+#~ "public class BlogItem {\n"
+#~ "    private Long _id;\n"
+#~ "    private Calendar _datetime;\n"
+#~ "    private String _text;\n"
+#~ "    private String _title;\n"
+#~ "    private Blog _blog;\n"
+#~ "\n"
+#~ "    public Blog getBlog() {\n"
+#~ "        return _blog;\n"
+#~ "    }\n"
+#~ "    public Calendar getDatetime() {\n"
+#~ "        return _datetime;\n"
+#~ "    }\n"
+#~ "    public Long getId() {\n"
+#~ "        return _id;\n"
+#~ "    }\n"
+#~ "    public String getText() {\n"
+#~ "        return _text;\n"
+#~ "    }\n"
+#~ "    public String getTitle() {\n"
+#~ "        return _title;\n"
+#~ "    }\n"
+#~ "    public void setBlog(Blog blog) {\n"
+#~ "        _blog = blog;\n"
+#~ "    }\n"
+#~ "    public void setDatetime(Calendar calendar) {\n"
+#~ "        _datetime = calendar;\n"
+#~ "    }\n"
+#~ "    public void setId(Long long1) {\n"
+#~ "        _id = long1;\n"
+#~ "    }\n"
+#~ "    public void setText(String string) {\n"
+#~ "        _text = string;\n"
+#~ "    }\n"
+#~ "    public void setTitle(String string) {\n"
+#~ "        _title = string;\n"
+#~ "    }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"Blog\"\n"
+#~ "        table=\"BLOGS\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"name\"\n"
+#~ "            column=\"NAME\"\n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "\n"
+#~ "        <bag\n"
+#~ "            name=\"items\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            order-by=\"DATE_TIME\"\n"
+#~ "            cascade=\"all\">\n"
+#~ "\n"
+#~ "            <key column=\"BLOG_ID\"/>\n"
+#~ "            <one-to-many class=\"BlogItem\"/>\n"
+#~ "\n"
+#~ "        </bag>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"Blog\"\n"
+#~ "        table=\"BLOGS\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"name\"\n"
+#~ "            column=\"NAME\"\n"
+#~ "            not-null=\"true\"\n"
+#~ "            unique=\"true\"/>\n"
+#~ "\n"
+#~ "        <bag\n"
+#~ "            name=\"items\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            order-by=\"DATE_TIME\"\n"
+#~ "            cascade=\"all\">\n"
+#~ "\n"
+#~ "            <key column=\"BLOG_ID\"/>\n"
+#~ "            <one-to-many class=\"BlogItem\"/>\n"
+#~ "\n"
+#~ "        </bag>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"BlogItem\"\n"
+#~ "        table=\"BLOG_ITEMS\"\n"
+#~ "        dynamic-update=\"true\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ITEM_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"title\"\n"
+#~ "            column=\"TITLE\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"text\"\n"
+#~ "            column=\"TEXT\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"datetime\"\n"
+#~ "            column=\"DATE_TIME\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <many-to-one\n"
+#~ "            name=\"blog\"\n"
+#~ "            column=\"BLOG_ID\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "    \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "    \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"eg\">\n"
+#~ "\n"
+#~ "    <class\n"
+#~ "        name=\"BlogItem\"\n"
+#~ "        table=\"BLOG_ITEMS\"\n"
+#~ "        dynamic-update=\"true\">\n"
+#~ "\n"
+#~ "        <id\n"
+#~ "            name=\"id\"\n"
+#~ "            column=\"BLOG_ITEM_ID\">\n"
+#~ "\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"title\"\n"
+#~ "            column=\"TITLE\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"text\"\n"
+#~ "            column=\"TEXT\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <property\n"
+#~ "            name=\"datetime\"\n"
+#~ "            column=\"DATE_TIME\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "        <many-to-one\n"
+#~ "            name=\"blog\"\n"
+#~ "            column=\"BLOG_ID\"\n"
+#~ "            not-null=\"true\"/>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.ArrayList;\n"
+#~ "import java.util.Calendar;\n"
+#~ "import java.util.Iterator;\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "import org.hibernate.HibernateException;\n"
+#~ "import org.hibernate.Query;\n"
+#~ "import org.hibernate.Session;\n"
+#~ "import org.hibernate.SessionFactory;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.cfg.Configuration;\n"
+#~ "import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
+#~ "\n"
+#~ "public class BlogMain {\n"
+#~ "    \n"
+#~ "    private SessionFactory _sessions;\n"
+#~ "    \n"
+#~ "    public void configure() throws HibernateException {\n"
+#~ "        _sessions = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class)\n"
+#~ "            .buildSessionFactory();\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void exportTables() throws HibernateException {\n"
+#~ "        Configuration cfg = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class);\n"
+#~ "        new SchemaExport(cfg).create(true, true);\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog createBlog(String name) throws HibernateException {\n"
+#~ "        \n"
+#~ "        Blog blog = new Blog();\n"
+#~ "        blog.setName(name);\n"
+#~ "        blog.setItems( new ArrayList() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.persist(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setBlog(blog);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        blog.getItems().add(item);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Long blogid, String title, String "
+#~ "text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
+#~ "            item.setBlog(blog);\n"
+#~ "            blog.getItems().add(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(BlogItem item, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        item.setText(text);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(Long itemid, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "    \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            BlogItem item = (BlogItem) session.load(BlogItem.class, "
+#~ "itemid);\n"
+#~ "            item.setText(text);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listAllBlogNamesAndItemCounts(int max)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"select blog.id, blog.name, count(blogItem) \" +\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join blog.items as blogItem \" +\n"
+#~ "                \"group by blog.name, blog.id \" +\n"
+#~ "                \"order by max(blogItem.datetime)\"\n"
+#~ "            );\n"
+#~ "            q.setMaxResults(max);\n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog getBlogAndAllItems(Long blogid)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        Blog blog = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join fetch blog.items \" +\n"
+#~ "                \"where blog.id = :blogid\"\n"
+#~ "            );\n"
+#~ "            q.setParameter(\"blogid\", blogid);\n"
+#~ "            blog  = (Blog) q.uniqueResult();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listBlogsAndRecentItems() throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"inner join blog.items as blogItem \" +\n"
+#~ "                \"where blogItem.datetime > :minDate\"\n"
+#~ "            );\n"
+#~ "\n"
+#~ "            Calendar cal = Calendar.getInstance();\n"
+#~ "            cal.roll(Calendar.MONTH, false);\n"
+#~ "            q.setCalendar(\"minDate\", cal);\n"
+#~ "            \n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "import java.util.ArrayList;\n"
+#~ "import java.util.Calendar;\n"
+#~ "import java.util.Iterator;\n"
+#~ "import java.util.List;\n"
+#~ "\n"
+#~ "import org.hibernate.HibernateException;\n"
+#~ "import org.hibernate.Query;\n"
+#~ "import org.hibernate.Session;\n"
+#~ "import org.hibernate.SessionFactory;\n"
+#~ "import org.hibernate.Transaction;\n"
+#~ "import org.hibernate.cfg.Configuration;\n"
+#~ "import org.hibernate.tool.hbm2ddl.SchemaExport;\n"
+#~ "\n"
+#~ "public class BlogMain {\n"
+#~ "    \n"
+#~ "    private SessionFactory _sessions;\n"
+#~ "    \n"
+#~ "    public void configure() throws HibernateException {\n"
+#~ "        _sessions = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class)\n"
+#~ "            .buildSessionFactory();\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void exportTables() throws HibernateException {\n"
+#~ "        Configuration cfg = new Configuration()\n"
+#~ "            .addClass(Blog.class)\n"
+#~ "            .addClass(BlogItem.class);\n"
+#~ "        new SchemaExport(cfg).create(true, true);\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog createBlog(String name) throws HibernateException {\n"
+#~ "        \n"
+#~ "        Blog blog = new Blog();\n"
+#~ "        blog.setName(name);\n"
+#~ "        blog.setItems( new ArrayList() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.persist(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Blog blog, String title, String text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setBlog(blog);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        blog.getItems().add(item);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(blog);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public BlogItem createBlogItem(Long blogid, String title, String "
+#~ "text)\n"
+#~ "                        throws HibernateException {\n"
+#~ "        \n"
+#~ "        BlogItem item = new BlogItem();\n"
+#~ "        item.setTitle(title);\n"
+#~ "        item.setText(text);\n"
+#~ "        item.setDatetime( Calendar.getInstance() );\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Blog blog = (Blog) session.load(Blog.class, blogid);\n"
+#~ "            item.setBlog(blog);\n"
+#~ "            blog.getItems().add(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return item;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(BlogItem item, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        item.setText(text);\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            session.update(item);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public void updateBlogItem(Long itemid, String text)\n"
+#~ "                    throws HibernateException {\n"
+#~ "    \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            BlogItem item = (BlogItem) session.load(BlogItem.class, "
+#~ "itemid);\n"
+#~ "            item.setText(text);\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listAllBlogNamesAndItemCounts(int max)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"select blog.id, blog.name, count(blogItem) \" +\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join blog.items as blogItem \" +\n"
+#~ "                \"group by blog.name, blog.id \" +\n"
+#~ "                \"order by max(blogItem.datetime)\"\n"
+#~ "            );\n"
+#~ "            q.setMaxResults(max);\n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public Blog getBlogAndAllItems(Long blogid)\n"
+#~ "                    throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        Blog blog = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"left outer join fetch blog.items \" +\n"
+#~ "                \"where blog.id = :blogid\"\n"
+#~ "            );\n"
+#~ "            q.setParameter(\"blogid\", blogid);\n"
+#~ "            blog  = (Blog) q.uniqueResult();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return blog;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    public List listBlogsAndRecentItems() throws HibernateException {\n"
+#~ "        \n"
+#~ "        Session session = _sessions.openSession();\n"
+#~ "        Transaction tx = null;\n"
+#~ "        List result = null;\n"
+#~ "        try {\n"
+#~ "            tx = session.beginTransaction();\n"
+#~ "            Query q = session.createQuery(\n"
+#~ "                \"from Blog as blog \" +\n"
+#~ "                \"inner join blog.items as blogItem \" +\n"
+#~ "                \"where blogItem.datetime > :minDate\"\n"
+#~ "            );\n"
+#~ "\n"
+#~ "            Calendar cal = Calendar.getInstance();\n"
+#~ "            cal.roll(Calendar.MONTH, false);\n"
+#~ "            q.setCalendar(\"minDate\", cal);\n"
+#~ "            \n"
+#~ "            result = q.list();\n"
+#~ "            tx.commit();\n"
+#~ "        }\n"
+#~ "        catch (HibernateException he) {\n"
+#~ "            if (tx!=null) tx.rollback();\n"
+#~ "            throw he;\n"
+#~ "        }\n"
+#~ "        finally {\n"
+#~ "            session.close();\n"
+#~ "        }\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "}]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/filters.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/filters.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/filters.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,44 +1,44 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-11-27 13:53+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: filters.xml:29
 #, no-c-format
 msgid "Filtering data"
 msgstr "过滤数据"
 
 #. Tag: para
-#: filters.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 provides an innovative new approach to handling data with "
 "\"visibility\" rules. A <emphasis>Hibernate filter</emphasis> is a global, "
 "named, parameterized filter that can be enabled or disabled for a particular "
 "Hibernate session."
 msgstr ""
-"Hibernate3 提供了一种创新的方式来处理具有“显性(visibility)”规则的数据,那就是"
-"使用<emphasis>Hibernate filter</emphasis>。 <emphasis>Hibernate filter</"
-"emphasis>是全局有效的、具有名字、可以带参数的过滤器, 对于某个特定的"
-"Hibernate session您可以选择是否启用(或禁用)某个过滤器。"
+"Hibernate3 提供了一种创新的方式来处理具有“显性(visibility)”规则的数据,那就"
+"是使用<emphasis>Hibernate 过滤器</emphasis>。<emphasis>Hibernate 过滤器</"
+"emphasis>是全局有效的、具有名字、可以带参数的过滤器,对于某个特定的 "
+"Hibernate session 您可以选择是否启用(或禁用)某个过滤器。"
 
 #. Tag: title
-#: filters.xml:38
 #, no-c-format
 msgid "Hibernate filters"
-msgstr "Hibernate 过滤器(filters)"
+msgstr "Hibernate 过滤器(filters)"
 
 #. Tag: para
-#: filters.xml:40
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 has the ability to pre-define filter criteria and attach those "
 "filters at both a class level and a collection level. A filter criteria "
@@ -49,14 +49,13 @@
 "parameter values should be. Filters can be used like database views, but "
 "they are parameterized inside the application."
 msgstr ""
-"Hibernate3新增了对某个类或者集合使用预先定义的过滤器条件(filter criteria)的功"
-"能。过滤器条件相当于定义一个 非常类似于类和各种集合上的“where”属性的约束子"
-"句,但是过滤器条件可以带参数。 应用程序可以在运行时决定是否启用给定的过滤器,"
-"以及使用什么样的参数值。 过滤器的用法很像数据库视图,只不过是在应用程序中确定"
-"使用什么样的参数的。"
+"Hibernate3 新增了对某个类或者集合使用预先定义的过滤器条件(filter criteria)"
+"的功能。过滤器条件相当于定义一个 非常类似于类和各种集合上的“where”属性的约束"
+"子句,但是过滤器条件可以带参数。 应用程序可以在运行时决定是否启用给定的过滤"
+"器,以及使用什么样的参数值。过滤器的用法很像数据库视图,只不过是在应用程序中"
+"确定使用什么样的参数的。 "
 
 #. Tag: para
-#: filters.xml:50
 #, no-c-format
 msgid ""
 "In order to use filters, they must first be defined and then attached to the "
@@ -64,62 +63,27 @@
 "filter-def/&gt;</literal> element within a <literal>&lt;hibernate-mapping/"
 "&gt;</literal> element:"
 msgstr ""
-"要使用过滤器,必须首先在相应的映射节点中定义。而定义一个过滤器,要用到位于"
-"<literal>&lt;hibernate-mapping/&gt;</literal> 节点之内的<literal>&lt;filter-"
-"def/&gt;</literal>节点:"
+"要使用过滤器,必须首先在相应的映射节点中定义。而定义一个过滤器,要用到位于 "
+"<literal>&lt;hibernate-mapping/&gt;</literal> 节点之内的 <literal>&lt;filter-"
+"def/&gt;</literal> 节点:"
 
-#. Tag: programlisting
-#: filters.xml:56
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[<filter-def name=\"myFilter\">\n"
-"    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
-"</filter-def>]]>"
-msgstr ""
+msgid "This filter can then be attached to a class:"
+msgstr "定义好之后,就可以在某个类中使用这个过滤器: "
 
 #. Tag: para
-#: filters.xml:58
-#, fuzzy, no-c-format
-msgid "This filter can then be attached to a class:"
-msgstr "定义好之后,就可以在某个类中使用这个过滤器:"
-
-#. Tag: programlisting
-#: filters.xml:62
 #, no-c-format
-msgid ""
-"<![CDATA[<class name=\"myClass\" ...>\n"
-"    ...\n"
-"    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN"
-"\"/>\n"
-"</class>]]>"
-msgstr ""
+msgid "Or, to a collection:"
+msgstr "或者也可以在某个集合使用它:"
 
 #. Tag: para
-#: filters.xml:64
-#, fuzzy, no-c-format
-msgid "Or, to a collection:"
-msgstr "也可以在某个集合使用它:"
-
-#. Tag: programlisting
-#: filters.xml:68
 #, no-c-format
-msgid ""
-"<![CDATA[<set ...>\n"
-"    <filter name=\"myFilter\" condition=\":myFilterParam = MY_FILTERED_COLUMN"
-"\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:70
-#, fuzzy, no-c-format
 msgid "Or, to both or multiples of each at the same time."
-msgstr ""
-"可以在多个类或集合中使用某个过滤器;某个类或者集合中也可以使用多个过滤器。"
+msgstr "或者在同时可以使用多个过滤器。"
 
 #. Tag: para
-#: filters.xml:74
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The methods on <literal>Session</literal> are: <literal>enableFilter(String "
 "filterName)</literal>, <literal>getEnabledFilter(String filterName)</"
@@ -130,129 +94,64 @@
 "interface. If you used the simple filter defined above, it would look like "
 "this:"
 msgstr ""
-"<literal>Session</literal>对象中会用到的方法有:<literal>enableFilter(String "
-"filterName)</literal>, <literal>getEnabledFilter(String filterName)</"
-"literal>, 和 <literal>disableFilter(String filterName)</literal>. Session中默"
-"认是<emphasis>不</emphasis>启用过滤器的,必须通过<literal>Session."
-"enabledFilter()</literal>方法显式的启用。 该方法返回被启用的<literal>Filter</"
-"literal>的实例。以上文定义的过滤器为例:"
+"<literal>Session</literal> 对象中会用到的方法有:<literal>enableFilter"
+"(String filterName)</literal>,<literal>getEnabledFilter(String filterName)</"
+"literal>,和 <literal>disableFilter(String filterName)</literal>。Session 中"
+"默认是<emphasis>不</emphasis>启用过滤器的,必须通过 <literal>Session."
+"enabledFilter()</literal> 方法显式的启用。该方法返回被启用的 "
+"<literal>Filter</literal> 的实例。以上文定义的过滤器为例:"
 
-#. Tag: programlisting
-#: filters.xml:83
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam\", "
-"\"some-value\");]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:85
-#, fuzzy, no-c-format
-msgid ""
 "Methods on the org.hibernate.Filter interface do allow the method-chaining "
 "common to much of Hibernate."
 msgstr ""
-"注意,org.hibernate.Filter的方法允许链式方法调用。(类似上面例子中启用Filter"
-"之后设定Filter参数这个“方法链”) Hibernate的其他部分也大多有这个特性。"
+"注意,org.hibernate.Filter 的方法允许链式方法调用。(类似上面例子中启用 "
+"Filter 之后设定 Filter 参数这个“方法链”) Hibernate 的其他部分也大多有这个特"
+"性。 "
 
 #. Tag: para
-#: filters.xml:89
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following is a full example, using temporal data with an effective "
 "record date pattern:"
-msgstr "下面是一个比较完整的例子,使用了记录生效日期模式过滤有时效的数据:"
+msgstr "下面是一个比较完整的例子,使用了记录生效日期模式过滤有时效的数据: "
 
-#. Tag: programlisting
-#: filters.xml:93
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<filter-def name=\"effectiveDate\">\n"
-"    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
-"</filter-def>\n"
-"\n"
-"<class name=\"Employee\" ...>\n"
-"...\n"
-"    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department\"/"
-">\n"
-"    <property name=\"effectiveStartDate\" type=\"date\" column=\"eff_start_dt"
-"\"/>\n"
-"    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt\"/"
-">\n"
-"...\n"
-"    <!--\n"
-"        Note that this assumes non-terminal records have an eff_end_dt set "
-"to\n"
-"        a max db date for simplicity-sake\n"
-"    -->\n"
-"    <filter name=\"effectiveDate\"\n"
-"            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"Department\" ...>\n"
-"...\n"
-"    <set name=\"employees\" lazy=\"true\">\n"
-"        <key column=\"dept_id\"/>\n"
-"        <one-to-many class=\"Employee\"/>\n"
-"        <filter name=\"effectiveDate\"\n"
-"                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
-">\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:95
-#, fuzzy, no-c-format
-msgid ""
 "In order to ensure that you are provided with currently effective records, "
 "enable the filter on the session prior to retrieving employee data:"
 msgstr ""
 "定义好后,如果想要保证取回的都是目前处于生效期的记录,只需在获取雇员数据的操"
-"作之前先开启过滤器即可:"
+"作之前先开启过滤器即可: "
 
-#. Tag: programlisting
-#: filters.xml:100
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session session = ...;\n"
-"session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new Date"
-"());\n"
-"List results = session.createQuery(\"from Employee as e where e.salary > :"
-"targetSalary\")\n"
-"         .setLong(\"targetSalary\", new Long(1000000))\n"
-"         .list();\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:102
-#, fuzzy, no-c-format
-msgid ""
 "Even though a salary constraint was mentioned explicitly on the results in "
 "the above HQL, because of the enabled filter, the query will return only "
 "currently active employees who have a salary greater than one million "
 "dollars."
 msgstr ""
-"在上面的HQL中,虽然我们仅仅显式的使用了一个薪水条件,但因为启用了过滤器,查询"
-"将仅返回那些目前雇用 关系处于生效期的,并且薪水高于一百万美刀的雇员的数据。"
+"在上面的 HQL 中,虽然我们仅仅显式的使用了一个薪水条件,但因为启用了过滤器,查"
+"询将仅返回那些目前雇用关系处于生效期的,并且薪水高于一百万美元的雇员的数据。 "
 
 #. Tag: para
-#: filters.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want to use filters with outer joining, either through HQL or load "
 "fetching, be careful of the direction of the condition expression. It is "
 "safest to set this up for left outer joining. Place the parameter first "
 "followed by the column name(s) after the operator."
 msgstr ""
-"注意:如果你打算在使用外连接(或者通过HQL或load fetching)的同时使用过滤器,"
-"要注意条件表达式的方向(左还是右)。 最安全的方式是使用左外连接(left outer "
-"joining)。并且通常来说,先写参数, 然后是操作符,最后写数据库字段名。"
+"注意:如果你打算在使用外连接(或者通过 HQL 或 load fetching)的同时使用过滤"
+"器,要注意条件表达式的方向(左还是右)。最安全的方式是使用左外连接(left "
+"outer joining)。并且通常来说,先写参数,然后是操作符,最后写数据库字段名。"
 
 #. Tag: para
-#: filters.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "After being defined, a filter might be attached to multiple entities and/or "
 "collections each with its own condition. This can be problematic when the "
@@ -260,27 +159,154 @@
 "literal> allows you to definine a default condition, either as an attribute "
 "or CDATA:"
 msgstr ""
-"在Filter定义之后,它可能被附加到多个实体和/或集合类,每个都有自己的条件。假若这"
-"些条件都是一样的,每次都要定义就显得很繁琐。因此,<literal>&lt;filter-def/"
-"&gt;</literal>被用来定义一个默认条件,它可能作为属性或者CDATA出现:"
+"在 Filter 定义之后,它可能被附加到多个实体和/或集合类,每个都有自己的条件。假若"
+"这些条件都是一样的,每次都要定义就显得很繁琐。因此,<literal>&lt;filter-def/"
+"&gt;</literal> 被用来定义一个默认条件,它可能作为属性或者 CDATA 出现: "
 
-#. Tag: programlisting
-#: filters.xml:122
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</filter-"
-"def>\n"
-"<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"
-msgstr ""
-
-#. Tag: para
-#: filters.xml:124
-#, fuzzy, no-c-format
-msgid ""
 "This default condition will be used whenever the filter is attached to "
 "something without specifying a condition. This means you can give a specific "
 "condition as part of the attachment of the filter that overrides the default "
 "condition in that particular case."
 msgstr ""
-"当这个filter被附加到任何目的地,而又没有指明条件时,这个条件就会被使用。注"
-"意,换句话说,你可以通过给filter附加特别的条件来重载默认条件。"
+"当这个 filter 被附加到任何目的地,而又没有指明条件时,这个缺省条件就会被使"
+"用。注意,换句话说,你可以通过给 filter 附加特别的条件来重载默认条件。"
+
+#~ msgid ""
+#~ "<![CDATA[<filter-def name=\"myFilter\">\n"
+#~ "    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
+#~ "</filter-def>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<filter-def name=\"myFilter\">\n"
+#~ "    <filter-param name=\"myFilterParam\" type=\"string\"/>\n"
+#~ "</filter-def>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"myClass\" ...>\n"
+#~ "    ...\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"myClass\" ...>\n"
+#~ "    ...\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<set ...>\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<set ...>\n"
+#~ "    <filter name=\"myFilter\" condition=\":myFilterParam = "
+#~ "MY_FILTERED_COLUMN\"/>\n"
+#~ "</set>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam"
+#~ "\", \"some-value\");]]>"
+#~ msgstr ""
+#~ "<![CDATA[session.enableFilter(\"myFilter\").setParameter(\"myFilterParam"
+#~ "\", \"some-value\");]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<filter-def name=\"effectiveDate\">\n"
+#~ "    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
+#~ "</filter-def>\n"
+#~ "\n"
+#~ "<class name=\"Employee\" ...>\n"
+#~ "...\n"
+#~ "    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department"
+#~ "\"/>\n"
+#~ "    <property name=\"effectiveStartDate\" type=\"date\" column="
+#~ "\"eff_start_dt\"/>\n"
+#~ "    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt"
+#~ "\"/>\n"
+#~ "...\n"
+#~ "    <!--\n"
+#~ "        Note that this assumes non-terminal records have an eff_end_dt "
+#~ "set to\n"
+#~ "        a max db date for simplicity-sake\n"
+#~ "    -->\n"
+#~ "    <filter name=\"effectiveDate\"\n"
+#~ "            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
+#~ ">\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Department\" ...>\n"
+#~ "...\n"
+#~ "    <set name=\"employees\" lazy=\"true\">\n"
+#~ "        <key column=\"dept_id\"/>\n"
+#~ "        <one-to-many class=\"Employee\"/>\n"
+#~ "        <filter name=\"effectiveDate\"\n"
+#~ "                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt"
+#~ "\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<filter-def name=\"effectiveDate\">\n"
+#~ "    <filter-param name=\"asOfDate\" type=\"date\"/>\n"
+#~ "</filter-def>\n"
+#~ "\n"
+#~ "<class name=\"Employee\" ...>\n"
+#~ "...\n"
+#~ "    <many-to-one name=\"department\" column=\"dept_id\" class=\"Department"
+#~ "\"/>\n"
+#~ "    <property name=\"effectiveStartDate\" type=\"date\" column="
+#~ "\"eff_start_dt\"/>\n"
+#~ "    <property name=\"effectiveEndDate\" type=\"date\" column=\"eff_end_dt"
+#~ "\"/>\n"
+#~ "...\n"
+#~ "    <!--\n"
+#~ "        Note that this assumes non-terminal records have an eff_end_dt "
+#~ "set to\n"
+#~ "        a max db date for simplicity-sake\n"
+#~ "    -->\n"
+#~ "    <filter name=\"effectiveDate\"\n"
+#~ "            condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt\"/"
+#~ ">\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"Department\" ...>\n"
+#~ "...\n"
+#~ "    <set name=\"employees\" lazy=\"true\">\n"
+#~ "        <key column=\"dept_id\"/>\n"
+#~ "        <one-to-many class=\"Employee\"/>\n"
+#~ "        <filter name=\"effectiveDate\"\n"
+#~ "                condition=\":asOfDate BETWEEN eff_start_dt and eff_end_dt"
+#~ "\"/>\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = ...;\n"
+#~ "session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new "
+#~ "Date());\n"
+#~ "List results = session.createQuery(\"from Employee as e where e.salary > :"
+#~ "targetSalary\")\n"
+#~ "         .setLong(\"targetSalary\", new Long(1000000))\n"
+#~ "         .list();\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = ...;\n"
+#~ "session.enableFilter(\"effectiveDate\").setParameter(\"asOfDate\", new "
+#~ "Date());\n"
+#~ "List results = session.createQuery(\"from Employee as e where e.salary > :"
+#~ "targetSalary\")\n"
+#~ "         .setLong(\"targetSalary\", new Long(1000000))\n"
+#~ "         .list();\n"
+#~ "]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</"
+#~ "filter-def>\n"
+#~ "<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<filter-def name=\"myFilter\" condition=\"abc > xyz\">...</"
+#~ "filter-def>\n"
+#~ "<filter-def name=\"myOtherFilter\">abc=xyz</filter-def>]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/inheritance_mapping.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/inheritance_mapping.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/inheritance_mapping.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,72 +1,63 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-07 09:35+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: inheritance_mapping.xml:29
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Inheritance mapping"
-msgstr "继承映射(Inheritance Mappings)"
+msgstr "继承映射(Inheritance Mapping) "
 
 #. Tag: title
-#: inheritance_mapping.xml:32
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The three strategies"
-msgstr "三种策略"
+msgstr "三种策略 "
 
 #. Tag: para
-#: inheritance_mapping.xml:34
 #, no-c-format
 msgid "Hibernate supports the three basic inheritance mapping strategies:"
-msgstr "Hibernate支持三种基本的继承映射策略:"
+msgstr "Hibernate 支持三种基本的继承映射策略:"
 
 #. Tag: para
-#: inheritance_mapping.xml:40
 #, no-c-format
 msgid "table per class hierarchy"
-msgstr "每个类分层结构一张表(table per class hierarchy)"
+msgstr "每个类分层结构一张表(table per class hierarchy)"
 
 #. Tag: para
-#: inheritance_mapping.xml:45
-#, fuzzy, no-c-format
-msgid "<para>table per subclass</para>"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"每个子类一张表(table per subclass)\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"每个子类一张表"
+#, no-c-format
+msgid "table per subclass"
+msgstr "每个子类一张表(Table per subclass) "
 
 #. Tag: para
-#: inheritance_mapping.xml:50
 #, no-c-format
 msgid "table per concrete class"
-msgstr "每个具体类一张表(table per concrete class)"
+msgstr "每个具体类一张表(table per concrete class)"
 
 #. Tag: para
-#: inheritance_mapping.xml:56
 #, no-c-format
 msgid ""
 "In addition, Hibernate supports a fourth, slightly different kind of "
 "polymorphism:"
-msgstr "此外,Hibernate还支持第四种稍有不同的多态映射策略:"
+msgstr "此外,Hibernate 还支持第四种稍有不同的多态映射策略:"
 
 #. Tag: para
-#: inheritance_mapping.xml:63
 #, no-c-format
 msgid "implicit polymorphism"
-msgstr "隐式多态(implicit polymorphism)"
+msgstr "隐式多态(implicit polymorphism)"
 
 #. Tag: para
-#: inheritance_mapping.xml:69
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to use different mapping strategies for different branches of "
 "the same inheritance hierarchy. You can then make use of implicit "
@@ -80,17 +71,16 @@
 "<literal>&lt;join&gt;</literal> elements (see below for an example)."
 msgstr ""
 "对于同一个继承层次内的不同分支,可以采用不同的映射策略,然后用隐式多 态来完成"
-"跨越整个层次的多态。但是在同一个<literal>&lt;class&gt;</literal>根元素 下,"
-"Hibernate不支持混合了元素<literal>&lt;subclass&gt;</literal>、 <literal>&lt;"
-"joined-subclass&gt;</literal>和<literal>&lt;union-subclass&gt;</literal> 的映"
-"射。在同一个<literal>&lt;class&gt;</literal>元素下,可以混合使用 “每个类分层"
-"结构一张表”(table per hierarchy) 和“每个子类一张表”(table per subclass) "
-"这两种映射策略,这是通过结合元素<literal>&lt;subclass&gt;</literal>和 "
-"<literal>&lt;join&gt;</literal>来实现的(见后)。"
+"跨越整个层次的多态。但是在同一个 <literal>&lt;class&gt;</literal> 根元素下,"
+"Hibernate 不支持混合了元素 <literal>&lt;subclass&gt;</literal>、<literal>&lt;"
+"joined-subclass&gt;</literal> 和 <literal>&lt;union-subclass&gt;</literal> 的"
+"映射。在同一个 <literal>&lt;class&gt;</literal> 元素下,可以混合使用“每个类分"
+"层结构一张表”(table per hierarchy)和“每个子类一张表”(table per subclass) "
+"这两种映射策略,这是通过结合元素 <literal>&lt;subclass&gt;</literal> 和 "
+"<literal>&lt;join&gt;</literal> 来实现的(见后)。 "
 
 #. Tag: para
-#: inheritance_mapping.xml:83
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to define <literal>subclass</literal>, <literal>union-"
 "subclass</literal>, and <literal>joined-subclass</literal> mappings in "
@@ -103,36 +93,21 @@
 "extends keyword. The ordering inside a single mapping file still needs to be "
 "defined as superclasses before subclasses."
 msgstr ""
-"在多个映射文件中,可以直接在<literal>hibernate-mapping</literal>根下定义"
-"<literal>subclass</literal>,<literal>union-subclass</literal>和"
+"在多个映射文件中,可以直接在 <literal>hibernate-mapping</literal> 根下定义 "
+"<literal>subclass</literal>,<literal>union-subclass</literal> 和  "
 "<literal>joined-subclass</literal>。也就是说,你可以仅加入一个新的映射文件来"
-"扩展类层次。你必须在subclass的映射中指明<literal>extends</literal>属性,给出"
-"一个之前定义的超类的名字。注意,在以前,这一功能对映射文件的顺序有严格的要"
-"求,从Hibernate 3开始,使用extends关键字的时侯,对映射文件的顺序不再有要求;"
-"但在每个映射文件里,超类必须在子类之前定义。"
+"扩展类层次。你必须在 subclass 的映射中指明 <literal>extends</literal> 属性,"
+"给出一个之前定义的超类的名字。注意,在以前,这一功能对映射文件的顺序有严格的"
+"要求,从 Hibernate 3 开始,使用 extends 关键字的时侯,对映射文件的顺序不再有"
+"要求;但在每个映射文件里,超类必须在子类之前定义。 "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:94
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-" <hibernate-mapping>\n"
-"     <subclass name=\"DomesticCat\" extends=\"Cat\" discriminator-value=\"D"
-"\">\n"
-"          <property name=\"name\" type=\"string\"/>\n"
-"     </subclass>\n"
-" </hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:98
 #, no-c-format
 msgid "Table per class hierarchy"
-msgstr "每个类分层结构一张表(Table per class hierarchy)"
+msgstr "每个类分层结构一张表(Table per class hierarchy)"
 
 #. Tag: para
-#: inheritance_mapping.xml:100
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Suppose we have an interface <literal>Payment</literal> with the "
 "implementors <literal>CreditCardPayment</literal>, <literal>CashPayment</"
@@ -140,102 +115,49 @@
 "mapping would display in the following way:"
 msgstr ""
 "假设我们有接口<literal>Payment</literal>和它的几个实现类: "
-"<literal>CreditCardPayment</literal>, <literal>CashPayment</literal>, 和"
-"<literal>ChequePayment</literal>。则“每个类分层结构一张表”(Table per class "
-"hierarchy)的映射代码如下所示:"
+"<literal>CreditCardPayment</literal>, <literal>CashPayment</literal> 和"
+"<literal>ChequePayment</literal>。则“每个类分层结构一张表”(Table per class "
+"hierarchy)的映射代码如下所示: "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:107
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        ...\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: inheritance_mapping.xml:109
-#, fuzzy, no-c-format
-msgid ""
 "Exactly one table is required. There is a limitation of this mapping "
 "strategy: columns declared by the subclasses, such as <literal>CCTYPE</"
 "literal>, cannot have <literal>NOT NULL</literal> constraints."
 msgstr ""
 "采用这种策略只需要一张表即可。它有一个很大的限制:要求那些由子类定义的字段, "
-"如<literal>CCTYPE</literal>,不能有<literal>非空(NOT NULL)</literal>约束。"
+"如 <literal>CCTYPE</literal>,不能有<literal>非空(NOT NULL)</literal>约"
+"束。 "
 
 #. Tag: title
-#: inheritance_mapping.xml:118
 #, no-c-format
 msgid "Table per subclass"
-msgstr "每个子类一张表(Table per subclass)"
+msgstr "每个子类一张表(Table per subclass)"
 
 #. Tag: para
-#: inheritance_mapping.xml:120
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "A table per subclass mapping looks like this:"
-msgstr "对于上例中的几个类而言,采用“每个子类一张表”的映射策略,代码如下所示:"
-
-#. Tag: programlisting
-#: inheritance_mapping.xml:124
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <joined-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"</class>]]>"
 msgstr ""
+" 对于上例中的几个类而言,采用“每个子类一张表”的映射策略,代码如下所示:"
 
 #. Tag: para
-#: inheritance_mapping.xml:126
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Four tables are required. The three subclass tables have primary key "
 "associations to the superclass table so the relational model is actually a "
 "one-to-one association."
 msgstr ""
-"需要四张表。三个子类表通过主键关联到超类表(因而关系模型实际上是一对一关联)。"
+"需要四张表。三个子类表通过主键关联到超类表(因而关系模型实际上是一对一关"
+"联)。 "
 
 #. Tag: title
-#: inheritance_mapping.xml:135
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Table per subclass: using a discriminator"
-msgstr "每个子类一张表(Table per subclass),使用辨别标志(Discriminator)"
+msgstr "每个子类一张表(Table per subclass),使用辨别标志(Discriminator)  "
 
 #. Tag: para
-#: inheritance_mapping.xml:137
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's implementation of table per subclass does not require a "
 "discriminator column. Other object/relational mappers use a different "
@@ -246,160 +168,63 @@
 "strategy, you can combine the use of <literal>&lt;subclass&gt;</literal> and "
 "<literal>&lt;join&gt;</literal>, as follows:"
 msgstr ""
-"注意,对“每个子类一张表”的映射策略,Hibernate的实现不需要辨别字段,而其他 的"
-"对象/关系映射工具使用了一种不同于Hibernate的实现方法,该方法要求在超类 表中有"
-"一个类型辨别字段(type discriminator column)。Hibernate采用的方法更 难实现,但"
-"从关系(数据库)的角度来看,按理说它更正确。若你愿意使用带有辨别字 段的“每个"
-"子类一张表”的策略,你可以结合使用<literal>&lt;subclass&gt;</literal> 与"
-"<literal>&lt;join&gt;</literal>,如下所示:"
+"注意,对“每个子类一张表”的映射策略,Hibernate 的实现不需要辨别字段,而其他的"
+"对象/关系映射工具使用了一种不同于Hibernate的实现方法,该方法要求在超类表中有"
+"一个类型辨别字段(type discriminator column)。Hibernate 采用的方法更难实现,"
+"但从关系(数据库)的角度来看,按理说它更正确。若你愿意使用带有辨别字段的“每个"
+"子类一张表”的策略,你可以结合使用 <literal>&lt;subclass&gt;</literal> 与"
+"<literal>&lt;join&gt;</literal>,如下所示: "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:149
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <join table=\"CREDIT_PAYMENT\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        <join table=\"CASH_PAYMENT\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        <join table=\"CHEQUE_PAYMENT\" fetch=\"select\">\n"
-"            <key column=\"PAYMENT_ID\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:151
 #, no-c-format
 msgid ""
 "The optional <literal>fetch=\"select\"</literal> declaration tells Hibernate "
 "not to fetch the <literal>ChequePayment</literal> subclass data using an "
 "outer join when querying the superclass."
 msgstr ""
-"可选的声明<literal>fetch=\"select\"</literal>,是用来告诉Hibernate,在查询超"
-"类时, 不要使用外部连接(outer join)来抓取子类<literal>ChequePayment</literal>"
-"的数据。"
+"可选的声明 <literal>fetch=\"select\"</literal>,是用来告诉 Hibernate,在查询"
+"超类时,不要使用外部连接(outer join)来抓取子类 <literal>ChequePayment</"
+"literal> 的数据。"
 
 #. Tag: title
-#: inheritance_mapping.xml:160
 #, no-c-format
 msgid "Mixing table per class hierarchy with table per subclass"
 msgstr "混合使用“每个类分层结构一张表”和“每个子类一张表”"
 
 #. Tag: para
-#: inheritance_mapping.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can even mix the table per hierarchy and table per subclass strategies "
 "using the following approach:"
 msgstr ""
 "你甚至可以采取如下方法混和使用“每个类分层结构一张表”和“每个子类一张表”这两种"
-"策略:"
+"策略: "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
-"        <join table=\"CREDIT_PAYMENT\">\n"
-"            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"            ...\n"
-"        </join>\n"
-"    </subclass>\n"
-"    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
-"        ...\n"
-"    </subclass>\n"
-"    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
-"        ...\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:169
 #, no-c-format
 msgid ""
 "For any of these mapping strategies, a polymorphic association to the root "
 "<literal>Payment</literal> class is mapped using <literal>&lt;many-to-one&gt;"
 "</literal>."
 msgstr ""
-"对上述任何一种映射策略而言,指向根类<literal>Payment</literal>的 关联是使用"
-"<literal>&lt;many-to-one&gt;</literal>进行映射的。"
+"对上述任何一种映射策略而言,指向根类 <literal>Payment</literal> 的关联是使用 "
+"<literal>&lt;many-to-one&gt;</literal> 进行映射的。"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:175
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"payment\" column=\"PAYMENT_ID\" class=\"Payment"
-"\"/>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:180
 #, no-c-format
 msgid "Table per concrete class"
-msgstr "每个具体类一张表(Table per concrete class)"
+msgstr "每个具体类一张表(Table per concrete class)"
 
 #. Tag: para
-#: inheritance_mapping.xml:182
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are two ways we can map the table per concrete class strategy. First, "
 "you can use <literal>&lt;union-subclass&gt;</literal>."
 msgstr ""
-"对于“每个具体类一张表”的映射策略,可以采用两种方法。第一种方法是使用 "
-"<literal>&lt;union-subclass&gt;</literal>。"
+"对于“每个具体类一张表”的映射策略,可以采用两种方法。第一种方法是使用  "
+"<literal>&lt;union-subclass&gt;</literal>。 "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:187
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Payment\">\n"
-"    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
-"        <generator class=\"sequence\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"AMOUNT\"/>\n"
-"    ...\n"
-"    <union-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
-"        ...\n"
-"    </union-subclass>\n"
-"    <union-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        ...\n"
-"    </union-subclass>\n"
-"    <union-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        ...\n"
-"    </union-subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:189
 #, no-c-format
 msgid ""
 "Three tables are involved for the subclasses. Each table defines columns for "
@@ -409,8 +234,7 @@
 "定义相应字段。"
 
 #. Tag: para
-#: inheritance_mapping.xml:194
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The limitation of this approach is that if a property is mapped on the "
 "superclass, the column name must be the same on all subclass tables. The "
@@ -418,68 +242,35 @@
 "The primary key seed has to be shared across all unioned subclasses of a "
 "hierarchy."
 msgstr ""
-"这种方式的局限在于,如果一个属性在超类中做了映射,其字段名必须与所有子类 表中"
-"定义的相同。(我们可能会在Hibernate的后续发布版本中放宽此限制。) 不允许在联合"
-"子类(union subclass)的继承层次中使用标识生成器策略(identity generator "
-"strategy), 实际上, 主键的种子(primary key seed)不得不为同一继承层次中的全部被"
-"联合子类所共用."
+"这种方式的局限在于,如果一个属性在超类中做了映射,其字段名必须与所有子类表中"
+"定义的相同。(我们可能会在 Hibernate 的后续发布版本中放宽此限制。)不允许在联"
+"合子类(union subclass)的继承层次中使用标识生成器策略(identity generator "
+"strategy),实际上,主键的种子(primary key seed)不得不为同一继承层次中的全"
+"部被联合子类所共用。 "
 
 #. Tag: para
-#: inheritance_mapping.xml:203
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your superclass is abstract, map it with <literal>abstract=\"true\"</"
 "literal>. If it is not abstract, an additional table (it defaults to "
 "<literal>PAYMENT</literal> in the example above), is needed to hold "
 "instances of the superclass."
 msgstr ""
-"假若超类是抽象类,请使用<literal>abstract=\"true\"</literal>。当然,假若它不"
-"是抽象的,需要一个额外的表(上面的例子中,默认是<literal>PAYMENT</"
-"literal>),来保存超类的实例。"
+"假若超类是抽象类,请使用 <literal>abstract=\"true\"</literal>。当然,假若它不"
+"是抽象的,需要一个额外的表(上面的例子中,默认是 <literal>PAYMENT</"
+"literal>),来保存超类的实例。 "
 
 #. Tag: title
-#: inheritance_mapping.xml:213
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Table per concrete class using implicit polymorphism"
-msgstr "每个具体类一张表,使用隐式多态"
+msgstr "每个具体类一张表,使用隐式多态 "
 
 #. Tag: para
-#: inheritance_mapping.xml:215
 #, no-c-format
 msgid "An alternative approach is to make use of implicit polymorphism:"
 msgstr "另一种可供选择的方法是采用隐式多态:"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:219
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-"    ...\n"
-"</class>\n"
-"\n"
-"<class name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CASH_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-"    ...\n"
-"</class>\n"
-"\n"
-"<class name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CHEQUE_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: inheritance_mapping.xml:221
 #, fuzzy, no-c-format
 msgid ""
 "Notice that the <literal>Payment</literal> interface is not mentioned "
@@ -487,56 +278,39 @@
 "mapped in each of the subclasses. If you want to avoid duplication, consider "
 "using XML entities (for example, <literal>[ &lt;!ENTITY allproperties SYSTEM "
 "\"allproperties.xml\"&gt; ]</literal> in the <literal>DOCTYPE</literal> "
-"declaration and <literal>&amp;allproperties;</literal> in the mapping)."
+"declaration and <literal>&amp;allproperties&semi;</literal> in the mapping)."
 msgstr ""
-"注意,我们没有在任何地方明确的提及接口<literal>Payment</literal>。同时注意 "
-"<literal>Payment</literal>的属性在每个子类中都进行了映射。如果你想避免重复, "
-"可以考虑使用XML实体(例如:位于<literal>DOCTYPE</literal>声明内的 <literal>"
-"[ &lt;!ENTITY allproperties SYSTEM \"allproperties.xml\"&gt; ]</literal> 和映"
-"射中的<literal>&amp;allproperties;</literal>)。"
+"请注意这里没有显性地提及 <literal>Payment</literal> 接口。<literal>Payment</"
+"literal> 的属性映射到每个子类。如果你想避免重复,请考虑使用 XML 实体(如:"
+"<literal>DOCTYPE</literal> 声明里的  <literal>[ &lt;!ENTITY allproperties "
+"SYSTEM \"allproperties.xml\"&gt; ]</literal> 和映射里的 <literal>&amp;"
+"allproperties&semi;</literal>)。"
 
 #. Tag: para
-#: inheritance_mapping.xml:231
 #, no-c-format
 msgid ""
 "The disadvantage of this approach is that Hibernate does not generate SQL "
 "<literal>UNION</literal>s when performing polymorphic queries."
 msgstr ""
-"这种方法的缺陷在于,在Hibernate执行多态查询时(polymorphic queries)无法生成带 "
-"<literal>UNION</literal>的SQL语句。"
+"这种方法的缺陷在于,在 Hibernate 执行多态查询时(polymorphic queries)无法生"
+"成带 <literal>UNION</literal> 的 SQL 语句。 "
 
 #. Tag: para
-#: inheritance_mapping.xml:236
 #, no-c-format
 msgid ""
 "For this mapping strategy, a polymorphic association to <literal>Payment</"
 "literal> is usually mapped using <literal>&lt;any&gt;</literal>."
 msgstr ""
-"对于这种映射策略而言,通常用<literal>&lt;any&gt;</literal>来实现到 "
-"<literal>Payment</literal>的多态关联映射。"
+"对于这种映射策略而言,通常用 <literal>&lt;any&gt;</literal> 来实现到  "
+"<literal>Payment</literal> 的多态关联映射。"
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:241
-#, no-c-format
-msgid ""
-"<![CDATA[<any name=\"payment\" meta-type=\"string\" id-type=\"long\">\n"
-"    <meta-value value=\"CREDIT\" class=\"CreditCardPayment\"/>\n"
-"    <meta-value value=\"CASH\" class=\"CashPayment\"/>\n"
-"    <meta-value value=\"CHEQUE\" class=\"ChequePayment\"/>\n"
-"    <column name=\"PAYMENT_CLASS\"/>\n"
-"    <column name=\"PAYMENT_ID\"/>\n"
-"</any>]]>"
-msgstr ""
-
 #. Tag: title
-#: inheritance_mapping.xml:246
 #, no-c-format
 msgid "Mixing implicit polymorphism with other inheritance mappings"
 msgstr "隐式多态和其他继承映射混合使用"
 
 #. Tag: para
-#: inheritance_mapping.xml:248
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Since the subclasses are each mapped in their own <literal>&lt;class&gt;</"
 "literal> element, and since <literal>Payment</literal> is just an "
@@ -544,48 +318,14 @@
 "inheritance hierarchy. You can still use polymorphic queries against the "
 "<literal>Payment</literal> interface."
 msgstr ""
-"对这一映射还有一点需要注意。因为每个子类都在各自独立的元素<literal>&lt;"
-"class&gt;</literal> 中映射(并且<literal>Payment</literal>只是一个接口),每个"
-"子类可以很容易的成为另一 个继承体系中的一部分!(你仍然可以对接口"
-"<literal>Payment</literal>使用多态查询。)"
+"对这一映射还有一点需要注意。因为每个子类都在各自独立的元素 <literal>&lt;"
+"class&gt;</literal> 中映射(并且 <literal>Payment</literal> 只是一个接口),"
+"每个子类可以很容易的成为另一个继承体系中的一部分!(你仍然可以对接口 "
+"<literal>Payment</literal> 使用多态查询。) "
 
-#. Tag: programlisting
-#: inheritance_mapping.xml:256
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
-"    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <discriminator column=\"CREDIT_CARD\" type=\"string\"/>\n"
-"    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
-"    ...\n"
-"    <subclass name=\"MasterCardPayment\" discriminator-value=\"MDC\"/>\n"
-"    <subclass name=\"VisaPayment\" discriminator-value=\"VISA\"/>\n"
-"</class>\n"
-"\n"
-"<class name=\"NonelectronicTransaction\" table=\"NONELECTRONIC_TXN\">\n"
-"    <id name=\"id\" type=\"long\" column=\"TXN_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    ...\n"
-"    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
-"        <key column=\"PAYMENT_ID\"/>\n"
-"        <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
-"        ...\n"
-"    </joined-subclass>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: inheritance_mapping.xml:258
-#, fuzzy, no-c-format
-msgid ""
 "Once again, <literal>Payment</literal> is not mentioned explicitly. If we "
 "execute a query against the <literal>Payment</literal> interface, for "
 "example <literal>from Payment</literal>, Hibernate automatically returns "
@@ -594,225 +334,614 @@
 "literal> and <literal>ChequePayment</literal>, but not instances of "
 "<literal>NonelectronicTransaction</literal>."
 msgstr ""
-"我们还是没有明确的提到<literal>Payment</literal>。 如果我们针对接口"
-"<literal>Payment</literal>执行查询 ——如<literal>from Payment</literal>—— "
-"Hibernate 自动返回<literal>CreditCardPayment</literal>(和它的子类,因为 它们"
-"也实现了接口<literal>Payment</literal>)、 <literal>CashPayment</literal>和"
-"<literal>Chequepayment</literal>的实例, 但不返回"
-"<literal>NonelectronicTransaction</literal>的实例。"
+"我们还是没有明确的提到 <literal>Payment</literal>。如果我们针对接口 "
+"<literal>Payment</literal> 执行查询 — 如 <literal>from Payment</literal> — "
+"Hibernate 自动返回 <literal>CreditCardPayment</literal>(和它的子类,因为 它"
+"们也实现了接口 <literal>Payment</literal>)、<literal>CashPayment</literal> "
+"和 <literal>Chequepayment</literal> 的实例,但不返回 "
+"<literal>NonelectronicTransaction</literal> 的实例。 "
 
 #. Tag: title
-#: inheritance_mapping.xml:273
 #, no-c-format
 msgid "Limitations"
 msgstr "限制"
 
 #. Tag: para
-#: inheritance_mapping.xml:275
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are limitations to the \"implicit polymorphism\" approach to the table "
 "per concrete-class mapping strategy. There are somewhat less restrictive "
 "limitations to <literal>&lt;union-subclass&gt;</literal> mappings."
 msgstr ""
 "对“每个具体类映射一张表”(table per concrete-class)的映射策略而言,隐式多态"
-"的 方式有一定的限制。而<literal>&lt;union-subclass&gt;</literal>映射的限制则"
-"没有那 么严格。"
+"的方式有一定的限制。而 <literal>&lt;union-subclass&gt;</literal> 映射的限制则"
+"没有那么严格。 "
 
 #. Tag: para
-#: inheritance_mapping.xml:282
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The following table shows the limitations of table per concrete-class "
 "mappings, and of implicit polymorphism, in Hibernate."
-msgstr "下面表格中列出了在Hibernte中“每个具体类一张表”的策略和隐式多态的限制。"
+msgstr ""
+"下面表格中列出了在 Hibernte 中“每个具体类一张表”的策略和隐式多态的限制。 "
 
 #. Tag: title
-#: inheritance_mapping.xml:288
 #, no-c-format
 msgid "Features of inheritance mappings"
-msgstr "继承映射特性(Features of inheritance mappings)"
+msgstr "继承映射特性(Features of inheritance mappings)"
 
 #. Tag: entry
-#: inheritance_mapping.xml:301
 #, no-c-format
 msgid "Inheritance strategy"
-msgstr "继承策略(Inheritance strategy)"
+msgstr "继承策略(Inheritance strategy)"
 
 #. Tag: entry
-#: inheritance_mapping.xml:302
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Polymorphic many-to-one"
-msgstr "多态多对一"
+msgstr "多态多对多"
 
 #. Tag: entry
-#: inheritance_mapping.xml:303
 #, no-c-format
 msgid "Polymorphic one-to-one"
 msgstr "多态一对一"
 
 #. Tag: entry
-#: inheritance_mapping.xml:304
 #, no-c-format
 msgid "Polymorphic one-to-many"
 msgstr "多态一对多"
 
 #. Tag: entry
-#: inheritance_mapping.xml:305
 #, no-c-format
 msgid "Polymorphic many-to-many"
 msgstr "多态多对多"
 
 #. Tag: entry
-#: inheritance_mapping.xml:306
 #, no-c-format
 msgid "Polymorphic <literal>load()/get()</literal>"
-msgstr ""
+msgstr "Polymorphic <literal>load()/get()</literal>"
 
 #. Tag: entry
-#: inheritance_mapping.xml:307
 #, no-c-format
 msgid "Polymorphic queries"
 msgstr "多态查询"
 
 #. Tag: entry
-#: inheritance_mapping.xml:308
 #, no-c-format
 msgid "Polymorphic joins"
-msgstr "多态连接(join)"
+msgstr "多态连接(join)"
 
 #. Tag: entry
-#: inheritance_mapping.xml:309
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "Outer join fetching"
-msgstr "外连接(Outer join)读取"
+msgstr "支持外连接(Outer join)读取。"
 
 #. Tag: entry
-#: inheritance_mapping.xml:314
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "table per class-hierarchy"
-msgstr "每个类分层结构一张表"
+msgstr "每个类分层结构一张表(table per class hierarchy)"
 
-#. Tag: literal
-#: inheritance_mapping.xml:315 inheritance_mapping.xml:326
-#: inheritance_mapping.xml:337
-#, no-c-format
-msgid "&lt;many-to-one&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;many-to-one&gt;</literal>"
 msgstr "&lt;many-to-one&gt;"
 
-#. Tag: literal
-#: inheritance_mapping.xml:316 inheritance_mapping.xml:327
-#: inheritance_mapping.xml:338
-#, no-c-format
-msgid "&lt;one-to-one&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;one-to-one&gt;</literal>"
 msgstr "&lt;one-to-one&gt;"
 
-#. Tag: literal
-#: inheritance_mapping.xml:317 inheritance_mapping.xml:328
-#, no-c-format
-msgid "&lt;one-to-many&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;one-to-many&gt;</literal>"
 msgstr "&lt;one-to-many&gt;"
 
-#. Tag: literal
-#: inheritance_mapping.xml:318 inheritance_mapping.xml:329
-#: inheritance_mapping.xml:340
-#, no-c-format
-msgid "&lt;many-to-many&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;many-to-many&gt;</literal>"
 msgstr "&lt;many-to-many&gt;"
 
-#. Tag: literal
-#: inheritance_mapping.xml:319 inheritance_mapping.xml:330
-#: inheritance_mapping.xml:341
-#, no-c-format
-msgid "s.get(Payment.class, id)"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>s.get(Payment.class, id)</literal>"
 msgstr "s.get(Payment.class, id)"
 
-#. Tag: literal
-#: inheritance_mapping.xml:320 inheritance_mapping.xml:331
-#: inheritance_mapping.xml:342 inheritance_mapping.xml:353
-#, no-c-format
-msgid "from Payment p"
-msgstr "from Payment p"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>from Payment p</literal>"
+msgstr "Polymorphic <literal>load()/get()</literal>"
 
-#. Tag: literal
-#: inheritance_mapping.xml:321 inheritance_mapping.xml:332
-#: inheritance_mapping.xml:343
-#, no-c-format
-msgid "from Order o join o.payment p"
-msgstr "from Order o join o.payment p"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>from Order o join o.payment p</literal>"
+msgstr "多态性 join:<code>from Order o join o.payment p</code>"
 
-#. Tag: emphasis
-#: inheritance_mapping.xml:322 inheritance_mapping.xml:333
-#: inheritance_mapping.xml:344
+#. Tag: entry
 #, no-c-format
-msgid "supported"
-msgstr "支持"
-
-#. Tag: entry
-#: inheritance_mapping.xml:325
-#, fuzzy, no-c-format
-msgid "<entry>table per subclass</entry>"
+msgid "<emphasis>supported</emphasis>"
 msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"每个子类一张表(table per subclass)\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"每个子类一张表"
 
 #. Tag: entry
-#: inheritance_mapping.xml:336
 #, no-c-format
 msgid "table per concrete-class (union-subclass)"
-msgstr "每个具体类一张表(union-subclass)"
+msgstr "每个具体类一张表(union-subclass)"
 
 #. Tag: entry
-#: inheritance_mapping.xml:339
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "<literal>&lt;one-to-many&gt;</literal> (for <literal>inverse=\"true\"</"
 "literal> only)"
 msgstr ""
+"多态性一对多:<literal>&lt;one-to-many&gt;</literal> (仅适用于 "
+"<literal>inverse=\"true\"</literal>)"
 
 #. Tag: entry
-#: inheritance_mapping.xml:347
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "table per concrete class (implicit polymorphism)"
-msgstr "每个具体类一张表(隐式多态)"
+msgstr "每个具体类一张表(隐式多态) "
 
-#. Tag: literal
-#: inheritance_mapping.xml:348
-#, no-c-format
-msgid "&lt;any&gt;"
-msgstr "&lt;any&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;any&gt;</literal>"
+msgstr "Polymorphic <literal>load()/get()</literal>"
 
-#. Tag: emphasis
-#: inheritance_mapping.xml:349 inheritance_mapping.xml:350
-#: inheritance_mapping.xml:354 inheritance_mapping.xml:355
+#. Tag: entry
 #, no-c-format
-msgid "not supported"
-msgstr "不支持"
+msgid "<emphasis>not supported</emphasis>"
+msgstr ""
 
-#. Tag: literal
-#: inheritance_mapping.xml:351
-#, no-c-format
-msgid "&lt;many-to-any&gt;"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>&lt;many-to-any&gt;</literal>"
 msgstr "&lt;many-to-any&gt;"
 
-#. Tag: literal
-#: inheritance_mapping.xml:352
-#, no-c-format
+#. Tag: entry
+#, fuzzy, no-c-format
 msgid ""
-"s.createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()"
+"<literal>s.createCriteria(Payment.class).add( Restrictions.idEq(id) )."
+"uniqueResult()</literal>"
 msgstr ""
-"s.createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()"
+"多态性 <literal>load()</literal> 或 <literal>get()</literal>:<code>s."
+"createCriteria(Payment.class).add( Restrictions.idEq(id) ).uniqueResult()</"
+"code>"
 
-#~ msgid "load()/get()"
-#~ msgstr "load()/get()"
+#~ msgid "table per class-heirarchy"
+#~ msgstr "每个类分层结构一张表 "
 
-#~ msgid "Polymorphic <placeholder-1/>"
-#~ msgstr "多态 <placeholder-1/>"
+#~ msgid "Polymorphic many-to-one: <code>&lt;many-to-one&gt;</code>"
+#~ msgstr "多态性多对一:<code>&lt;many-to-one&gt;</code>"
 
-#~ msgid "inverse=\"true\""
-#~ msgstr "inverse=\"true\""
+#~ msgid "Polymorphic one-to-one: <code>&lt;one-to-one&gt;</code>"
+#~ msgstr "多态性一对一:<code>&lt;one-to-one&gt;</code>"
 
-#~ msgid "<placeholder-1/> (for <placeholder-2/> only)"
-#~ msgstr "<placeholder-1/> (仅对于<placeholder-2/>的情况)"
+#~ msgid "Polymorphic one-to-many: <code>&lt;one-to-many&gt;</code>"
+#~ msgstr "多态性一对多:<code>&lt;one-to-many&gt;</code>"
+
+#~ msgid "Polymorphic many-to-many: <code>&lt;many-to-many&gt;</code>"
+#~ msgstr "多态性多对多:<code>&lt;many-to-many&gt;</code>"
+
+#~ msgid ""
+#~ "Polymorphic <literal>load()</literal> or <literal>get()</literal>: "
+#~ "<code>s.get(Payment.class, id)</code>"
+#~ msgstr ""
+#~ "多态性 <literal>load()</literal> 或 <literal>get()</literal>:<code>s.get"
+#~ "(Payment.class, id)</code>"
+
+#~ msgid "Polymorphic queries: <code>from Payment p</code>"
+#~ msgstr "多态性查询:<code>from Payment p</code>"
+
+#~ msgid "Polymorphic many-to-one: <code>&lt;any&gt;</code>"
+#~ msgstr "多态多对一:<code>&lt;any&gt;</code>"
+
+#~ msgid ""
+#~ "Polymorphic one-to-one, polymorphic one-to-many, polymorphic joins, and "
+#~ "outer join fetching are not supported."
+#~ msgstr ""
+#~ "多态性一对一、多态性一对多,不支持多态性 join 和 outer join fetching。"
+
+#~ msgid "<para>table per subclass</para>"
+#~ msgstr "<para>每个子类一张表</para>"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[\n"
+#~ " <hibernate-mapping>\n"
+#~ "     <subclass name=\"DomesticCat\" extends=\"Cat\" discriminator-value="
+#~ "\"D\">\n"
+#~ "          <property name=\"name\" type=\"string\"/>\n"
+#~ "     </subclass>\n"
+#~ " </hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "     &lt;subclass name=\"DomesticCat\" extends=\"Cat\" discriminator-"
+#~ "value=\"D\"&gt;\n"
+#~ "          &lt;property name=\"name\" type=\"string\"/&gt;\n"
+#~ "     &lt;/subclass&gt;\n"
+#~ " &lt;/hibernate-mapping&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
+#~ "    <property name=\"amount\" column=\"AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
+#~ "        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
+#~ "        ...\n"
+#~ "    </subclass>\n"
+#~ "    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
+#~ "        ...\n"
+#~ "    </subclass>\n"
+#~ "    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
+#~ "        ...\n"
+#~ "    </subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Payment\" table=\"PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;discriminator column=\"PAYMENT_TYPE\" type=\"string\"/&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT"
+#~ "\"&gt;\n"
+#~ "        &lt;property name=\"creditCardType\" column=\"CCTYPE\"/&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "    &lt;subclass name=\"CashPayment\" discriminator-value=\"CASH\"&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "    &lt;subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE"
+#~ "\"&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"amount\" column=\"AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "    <joined-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT"
+#~ "\">\n"
+#~ "        <key column=\"PAYMENT_ID\"/>\n"
+#~ "        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
+#~ "        ...\n"
+#~ "    </joined-subclass>\n"
+#~ "    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
+#~ "        <key column=\"PAYMENT_ID\"/>\n"
+#~ "        ...\n"
+#~ "    </joined-subclass>\n"
+#~ "    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
+#~ "        <key column=\"PAYMENT_ID\"/>\n"
+#~ "        ...\n"
+#~ "    </joined-subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Payment\" table=\"PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;joined-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT"
+#~ "\"&gt;\n"
+#~ "        &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "        &lt;property name=\"creditCardType\" column=\"CCTYPE\"/&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/joined-subclass&gt;\n"
+#~ "    &lt;joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\"&gt;\n"
+#~ "        &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/joined-subclass&gt;\n"
+#~ "    &lt;joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT"
+#~ "\"&gt;\n"
+#~ "        &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/joined-subclass&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
+#~ "    <property name=\"amount\" column=\"AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
+#~ "        <join table=\"CREDIT_PAYMENT\">\n"
+#~ "            <key column=\"PAYMENT_ID\"/>\n"
+#~ "            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
+#~ "            ...\n"
+#~ "        </join>\n"
+#~ "    </subclass>\n"
+#~ "    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
+#~ "        <join table=\"CASH_PAYMENT\">\n"
+#~ "            <key column=\"PAYMENT_ID\"/>\n"
+#~ "            ...\n"
+#~ "        </join>\n"
+#~ "    </subclass>\n"
+#~ "    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
+#~ "        <join table=\"CHEQUE_PAYMENT\" fetch=\"select\">\n"
+#~ "            <key column=\"PAYMENT_ID\"/>\n"
+#~ "            ...\n"
+#~ "        </join>\n"
+#~ "    </subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Payment\" table=\"PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;discriminator column=\"PAYMENT_TYPE\" type=\"string\"/&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT"
+#~ "\"&gt;\n"
+#~ "        &lt;join table=\"CREDIT_PAYMENT\"&gt;\n"
+#~ "            &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "            &lt;property name=\"creditCardType\" column=\"CCTYPE\"/&gt;\n"
+#~ "            ...\n"
+#~ "        &lt;/join&gt;\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "    &lt;subclass name=\"CashPayment\" discriminator-value=\"CASH\"&gt;\n"
+#~ "        &lt;join table=\"CASH_PAYMENT\"&gt;\n"
+#~ "            &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "            ...\n"
+#~ "        &lt;/join&gt;\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "    &lt;subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE"
+#~ "\"&gt;\n"
+#~ "        &lt;join table=\"CHEQUE_PAYMENT\" fetch=\"select\"&gt;\n"
+#~ "            &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "            ...\n"
+#~ "        &lt;/join&gt;\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Payment\" table=\"PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <discriminator column=\"PAYMENT_TYPE\" type=\"string\"/>\n"
+#~ "    <property name=\"amount\" column=\"AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "    <subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT\">\n"
+#~ "        <join table=\"CREDIT_PAYMENT\">\n"
+#~ "            <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
+#~ "            ...\n"
+#~ "        </join>\n"
+#~ "    </subclass>\n"
+#~ "    <subclass name=\"CashPayment\" discriminator-value=\"CASH\">\n"
+#~ "        ...\n"
+#~ "    </subclass>\n"
+#~ "    <subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE\">\n"
+#~ "        ...\n"
+#~ "    </subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Payment\" table=\"PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;discriminator column=\"PAYMENT_TYPE\" type=\"string\"/&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;subclass name=\"CreditCardPayment\" discriminator-value=\"CREDIT"
+#~ "\"&gt;\n"
+#~ "        &lt;join table=\"CREDIT_PAYMENT\"&gt;\n"
+#~ "            &lt;property name=\"creditCardType\" column=\"CCTYPE\"/&gt;\n"
+#~ "            ...\n"
+#~ "        &lt;/join&gt;\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "    &lt;subclass name=\"CashPayment\" discriminator-value=\"CASH\"&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "    &lt;subclass name=\"ChequePayment\" discriminator-value=\"CHEQUE"
+#~ "\"&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/subclass&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"payment\" column=\"PAYMENT_ID\" class="
+#~ "\"Payment\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"payment\" column=\"PAYMENT_ID\" class=\"Payment\"/"
+#~ "&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Payment\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"PAYMENT_ID\">\n"
+#~ "        <generator class=\"sequence\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"amount\" column=\"AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "    <union-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
+#~ "        <property name=\"creditCardType\" column=\"CCTYPE\"/>\n"
+#~ "        ...\n"
+#~ "    </union-subclass>\n"
+#~ "    <union-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
+#~ "        ...\n"
+#~ "    </union-subclass>\n"
+#~ "    <union-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
+#~ "        ...\n"
+#~ "    </union-subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Payment\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"sequence\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;union-subclass name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT"
+#~ "\"&gt;\n"
+#~ "        &lt;property name=\"creditCardType\" column=\"CCTYPE\"/&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/union-subclass&gt;\n"
+#~ "    &lt;union-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\"&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/union-subclass&gt;\n"
+#~ "    &lt;union-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT"
+#~ "\"&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/union-subclass&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"CASH_PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"CHEQUE_PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"CREDIT_AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"CashPayment\" table=\"CASH_PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"CASH_PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"CASH_AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"CHEQUE_PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"CHEQUE_AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<any name=\"payment\" meta-type=\"string\" id-type=\"long\">\n"
+#~ "    <meta-value value=\"CREDIT\" class=\"CreditCardPayment\"/>\n"
+#~ "    <meta-value value=\"CASH\" class=\"CashPayment\"/>\n"
+#~ "    <meta-value value=\"CHEQUE\" class=\"ChequePayment\"/>\n"
+#~ "    <column name=\"PAYMENT_CLASS\"/>\n"
+#~ "    <column name=\"PAYMENT_ID\"/>\n"
+#~ "</any>]]>"
+#~ msgstr ""
+#~ "&lt;any name=\"payment\" meta-type=\"string\" id-type=\"long\"&gt;\n"
+#~ "    &lt;meta-value value=\"CREDIT\" class=\"CreditCardPayment\"/&gt;\n"
+#~ "    &lt;meta-value value=\"CASH\" class=\"CashPayment\"/&gt;\n"
+#~ "    &lt;meta-value value=\"CHEQUE\" class=\"ChequePayment\"/&gt;\n"
+#~ "    &lt;column name=\"PAYMENT_CLASS\"/&gt;\n"
+#~ "    &lt;column name=\"PAYMENT_ID\"/&gt;\n"
+#~ "&lt;/any&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <discriminator column=\"CREDIT_CARD\" type=\"string\"/>\n"
+#~ "    <property name=\"amount\" column=\"CREDIT_AMOUNT\"/>\n"
+#~ "    ...\n"
+#~ "    <subclass name=\"MasterCardPayment\" discriminator-value=\"MDC\"/>\n"
+#~ "    <subclass name=\"VisaPayment\" discriminator-value=\"VISA\"/>\n"
+#~ "</class>\n"
+#~ "\n"
+#~ "<class name=\"NonelectronicTransaction\" table=\"NONELECTRONIC_TXN\">\n"
+#~ "    <id name=\"id\" type=\"long\" column=\"TXN_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    ...\n"
+#~ "    <joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\">\n"
+#~ "        <key column=\"PAYMENT_ID\"/>\n"
+#~ "        <property name=\"amount\" column=\"CASH_AMOUNT\"/>\n"
+#~ "        ...\n"
+#~ "    </joined-subclass>\n"
+#~ "    <joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT\">\n"
+#~ "        <key column=\"PAYMENT_ID\"/>\n"
+#~ "        <property name=\"amount\" column=\"CHEQUE_AMOUNT\"/>\n"
+#~ "        ...\n"
+#~ "    </joined-subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"CreditCardPayment\" table=\"CREDIT_PAYMENT\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"CREDIT_PAYMENT_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;discriminator column=\"CREDIT_CARD\" type=\"string\"/&gt;\n"
+#~ "    &lt;property name=\"amount\" column=\"CREDIT_AMOUNT\"/&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;subclass name=\"MasterCardPayment\" discriminator-value=\"MDC\"/"
+#~ "&gt;\n"
+#~ "    &lt;subclass name=\"VisaPayment\" discriminator-value=\"VISA\"/&gt;\n"
+#~ "&lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;class name=\"NonelectronicTransaction\" table=\"NONELECTRONIC_TXN"
+#~ "\"&gt;\n"
+#~ "    &lt;id name=\"id\" type=\"long\" column=\"TXN_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;joined-subclass name=\"CashPayment\" table=\"CASH_PAYMENT\"&gt;\n"
+#~ "        &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "        &lt;property name=\"amount\" column=\"CASH_AMOUNT\"/&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/joined-subclass&gt;\n"
+#~ "    &lt;joined-subclass name=\"ChequePayment\" table=\"CHEQUE_PAYMENT"
+#~ "\"&gt;\n"
+#~ "        &lt;key column=\"PAYMENT_ID\"/&gt;\n"
+#~ "        &lt;property name=\"amount\" column=\"CHEQUE_AMOUNT\"/&gt;\n"
+#~ "        ...\n"
+#~ "    &lt;/joined-subclass&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid "<term>table per subclass</term>"
+#~ msgstr "<entry>每个子类一张表</entry>"
+
+#~ msgid "from Payment p"
+#~ msgstr "from Payment p"
+
+#~ msgid "supported"
+#~ msgstr "支持"
+
+#~ msgid "&lt;any&gt;"
+#~ msgstr "&lt;any&gt;"
+
+#~ msgid "not supported"
+#~ msgstr "不支持"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/performance.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/performance.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/performance.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,76 +1,74 @@
+# translation of performance.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007, 2009.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: performance\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-08-17 20:22+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-07 09:35+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: performance.xml:29
 #, no-c-format
 msgid "Improving performance"
 msgstr "提升性能"
 
 #. Tag: title
-#: performance.xml:32
 #, no-c-format
 msgid "Fetching strategies"
-msgstr "抓取策略(Fetching strategies)"
+msgstr "抓取策略(Fetching strategies)"
 
 #. Tag: para
-#: performance.xml:34
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate uses a <emphasis>fetching strategy</emphasis> to retrieve "
 "associated objects if the application needs to navigate the association. "
 "Fetch strategies can be declared in the O/R mapping metadata, or over-ridden "
 "by a particular HQL or <literal>Criteria</literal> query."
 msgstr ""
-"<emphasis>抓取策略(fetching strategy)</emphasis> 是指:当应用程序需要在"
-"(Hibernate实体对象图的)关联关系间进行导航的时候, Hibernate如何获取关联对象"
-"的策略。抓取策略可以在O/R映射的元数据中声明,也可以在特定的HQL 或<literal>条"
-"件查询(Criteria Query)</literal>中重载声明。"
+"当应用程序需要在(Hibernate实体对象图的)关联关系间进行导航的时候,Hibernate "
+"使用 <emphasis>抓取策略(fetching strategy)</emphasis> 获取关联对象。抓取策"
+"略可以在 O/R 映射的元数据中声明,也可以在特定的 HQL 或<literal>条件查询"
+"(Criteria Query)</literal>中重载声明。"
 
 #. Tag: para
-#: performance.xml:41
 #, no-c-format
 msgid "Hibernate3 defines the following fetching strategies:"
 msgstr "Hibernate3 定义了如下几种抓取策略:"
 
 #. Tag: para
-#: performance.xml:47
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Join fetching</emphasis>: Hibernate retrieves the associated "
 "instance or collection in the same <literal>SELECT</literal>, using an "
 "<literal>OUTER JOIN</literal>."
 msgstr ""
-"<emphasis>连接抓取(Join fetching)</emphasis> - Hibernate通过 在"
-"<literal>SELECT</literal>语句使用<literal>OUTER JOIN</literal>(外连接)来 获"
-"得对象的关联实例或者关联集合。"
+"<emphasis>连接抓取(Join fetching)</emphasis>:Hibernate 通过在 "
+"<literal>SELECT</literal>  语句使用 <literal>OUTER JOIN</literal>(外连接)来"
+"获得对象的关联实例或者关联集合。 "
 
 #. Tag: para
-#: performance.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Select fetching</emphasis>: a second <literal>SELECT</literal> is "
 "used to retrieve the associated entity or collection. Unless you explicitly "
 "disable lazy fetching by specifying <literal>lazy=\"false\"</literal>, this "
 "second select will only be executed when you access the association."
 msgstr ""
-"<emphasis>查询抓取(Select fetching)</emphasis> - 另外发送一条 "
-"<literal>SELECT</literal> 语句抓取当前对象的关联实体或集合。除非你显式的指定"
-"<literal>lazy=\"false\"</literal>禁止 延迟抓取(lazy fetching),否则只有当你"
-"真正访问关联关系的时候,才会执行第二条select语句。"
+"<emphasis>查询抓取(Select fetching)</emphasis>:另外发送一条 "
+"<literal>SELECT</literal> 语句抓取当前对象的关联实体或集合。除非你显式的指定 "
+"<literal>lazy=\"false\"</literal> 禁止 延迟抓取(lazy fetching),否则只有当"
+"你真正访问关联关系的时候,才会执行第二条 select 语句。"
 
 #. Tag: para
-#: performance.xml:63
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Subselect fetching</emphasis>: a second <literal>SELECT</literal> "
 "is used to retrieve the associated collections for all entities retrieved in "
@@ -78,79 +76,72 @@
 "specifying <literal>lazy=\"false\"</literal>, this second select will only "
 "be executed when you access the association."
 msgstr ""
-"<emphasis>子查询抓取(Subselect fetching)</emphasis> - 另外发送一条"
+"<emphasis>子查询抓取(Subselect fetching)</emphasis>:另外发送一条  "
 "<literal>SELECT</literal> 语句抓取在前面查询到(或者抓取到)的所有实体对象的"
-"关联集合。除非你显式的指定<literal>lazy=\"false\"</literal> 禁止延迟抓取"
-"(lazy fetching),否则只有当你真正访问关联关系的时候,才会执行第二条select语"
-"句。"
+"关联集合。除非你显式的指定 <literal>lazy=\"false\"</literal> 禁止延迟抓取"
+"(lazy fetching),否则只有当你真正访问关联关系的时候,才会执行第二条 select "
+"语句。"
 
 #. Tag: para
-#: performance.xml:72
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Batch fetching</emphasis>: an optimization strategy for select "
 "fetching. Hibernate retrieves a batch of entity instances or collections in "
 "a single <literal>SELECT</literal> by specifying a list of primary or "
 "foreign keys."
 msgstr ""
-"<emphasis>批量抓取(Batch fetching)</emphasis> - 对查询抓取的优化方案, 通过"
-"指定一个主键或外键列表,Hibernate使用单条<literal>SELECT</literal>语句获取一"
+"<emphasis>批量抓取(Batch fetching)</emphasis>:对查询抓取的优化方案,通过指"
+"定一个主键或外键列表,Hibernate 使用单条 <literal>SELECT</literal> 语句获取一"
 "批对象实例或集合。"
 
 #. Tag: para
-#: performance.xml:81
 #, no-c-format
 msgid "Hibernate also distinguishes between:"
-msgstr "Hibernate会区分下列各种情况:"
+msgstr "Hibernate 会区分下列各种情况:"
 
 #. Tag: para
-#: performance.xml:87
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Immediate fetching</emphasis>: an association, collection or "
 "attribute is fetched immediately when the owner is loaded."
 msgstr ""
-"<emphasis>Immediate fetching,立即抓取</emphasis> - 当宿主被加载时,关联、集"
-"合或属性被立即抓取。"
+"<emphasis>Immediate fetching,立即抓取</emphasis>:当宿主被加载时,关联、集合"
+"或属性被立即抓取。"
 
 #. Tag: para
-#: performance.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Lazy collection fetching</emphasis>: a collection is fetched when "
 "the application invokes an operation upon that collection. This is the "
 "default for collections."
 msgstr ""
-"<emphasis>Lazy collection fetching,延迟集合抓取</emphasis>- 直到应用程序对集"
-"合进行了一次操作时,集合才被抓取。(对集合而言这是默认行为。)"
+"<emphasis>Lazy collection fetching,延迟集合抓取</emphasis>:直到应用程序对集"
+"合进行了一次操作时,集合才被抓取(对集合而言这是默认行为)。"
 
 #. Tag: para
-#: performance.xml:100
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>\"Extra-lazy\" collection fetching</emphasis>: individual elements "
 "of the collection are accessed from the database as needed. Hibernate tries "
 "not to fetch the whole collection into memory unless absolutely needed. It "
 "is suitable for large collections."
 msgstr ""
-"<emphasis>\"Extra-lazy\" collection fetching,\"Extra-lazy\"集合抓取</"
-"emphasis> -对集合类中的每个元素而言,都是直到需要时才去访问数据库。除非绝对必"
-"要,Hibernate不会试图去把整个集合都抓取到内存里来(适用于非常大的集合)。"
+"<emphasis>\"Extra-lazy\" collection fetching,\"Extra-lazy\" 集合抓取</"
+"emphasis>:对集合类中的每个元素而言,都是直到需要时才去访问数据库。除非绝对必"
+"要,Hibernate 不会试图去把整个集合都抓取到内存里来(适用于非常大的集合)。"
 
 #. Tag: para
-#: performance.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Proxy fetching</emphasis>: a single-valued association is fetched "
 "when a method other than the identifier getter is invoked upon the "
 "associated object."
 msgstr ""
-"<emphasis>Proxy fetching,代理抓取</emphasis> - 对返回单值的关联而言,当其某"
-"个方法被调用,而非对其关键字进行get操作时才抓取。"
+"<emphasis>Proxy fetching,代理抓取</emphasis>:对返回单值的关联而言,当其某个"
+"方法被调用,而非对其关键字进行 get 操作时才抓取。"
 
 #. Tag: para
-#: performance.xml:115
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>\"No-proxy\" fetching</emphasis>: a single-valued association is "
 "fetched when the instance variable is accessed. Compared to proxy fetching, "
@@ -159,27 +150,25 @@
 "visible to the application. This approach requires buildtime bytecode "
 "instrumentation and is rarely necessary."
 msgstr ""
-"<emphasis>\"No-proxy\" fetching,非代理抓取</emphasis> - 对返回单值的关联而"
+"<emphasis>\"No-proxy\" fetching,非代理抓取</emphasis>:对返回单值的关联而"
 "言,当实例变量被访问的时候进行抓取。与上面的代理抓取相比,这种方法没有那么“延"
-"迟”得厉害(就算只访问标识符,也会导致关联抓取)但是更加透明,因为对应用程序来"
-"说,不再看到proxy。这种方法需要在编译期间进行字节码增强操作,因此很少需要用"
+"迟”得厉害(就算只访问标识符,也会导致关联抓取)但是更加透明,因为对应用程序来"
+"说,不再看到 proxy。这种方法需要在编译期间进行字节码增强操作,因此很少需要用"
 "到。"
 
 #. Tag: para
-#: performance.xml:125
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Lazy attribute fetching</emphasis>: an attribute or single valued "
 "association is fetched when the instance variable is accessed. This approach "
 "requires buildtime bytecode instrumentation and is rarely necessary."
 msgstr ""
-"<emphasis>Lazy attribute fetching,属性延迟加载</emphasis> - 对属性或返回单值"
+"<emphasis>Lazy attribute fetching,属性延迟加载</emphasis>:对属性或返回单值"
 "的关联而言,当其实例变量被访问的时候进行抓取。需要编译期字节码强化,因此这一"
 "方法很少是必要的。"
 
 #. Tag: para
-#: performance.xml:134
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We have two orthogonal notions here: <emphasis>when</emphasis> is the "
 "association fetched and <emphasis>how</emphasis> is it fetched. It is "
@@ -189,84 +178,60 @@
 "class."
 msgstr ""
 "这里有两个正交的概念:关联<emphasis>何时</emphasis>被抓取,以及被<emphasis>如"
-"何</emphasis>抓取(会采用什么样的SQL语句)。不要混淆它们!我们使用<literal>抓"
-"取</literal>来改善性能。我们使用<literal>延迟</literal>来定义一些契约,对某特"
-"定类的某个脱管的实例,知道有哪些数据是可以使用的。"
+"何</emphasis>抓取(会采用什么样的 SQL 语句)。注意不要混淆它们。我们使用"
+"<literal>抓取</literal>来改善性能。我们使用<literal>延迟</literal>来定义一些"
+"契约,对某特定类的某个脱管的实例,知道有哪些数据是可以使用的。"
 
 #. Tag: title
-#: performance.xml:143
 #, no-c-format
 msgid "Working with lazy associations"
 msgstr "操作延迟加载的关联"
 
 #. Tag: para
-#: performance.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "By default, Hibernate3 uses lazy select fetching for collections and lazy "
 "proxy fetching for single-valued associations. These defaults make sense for "
 "most associations in the majority of applications."
 msgstr ""
-"默认情况下,Hibernate 3对集合使用延迟select抓取,对返回单值的关联使用延迟代理"
-"抓取。对几乎是所有的应用而言,其绝大多数的关联,这种策略都是有效的。"
+"默认情况下,Hibernate 3 对集合使用延迟 select 抓取,对返回单值的关联使用延迟"
+"代理抓取。对几乎是所有的应用而言,其绝大多数的关联,这种策略都是有效的。"
 
 #. Tag: para
-#: performance.xml:151
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you set <literal>hibernate.default_batch_fetch_size</literal>, Hibernate "
 "will use the batch fetch optimization for lazy fetching. This optimization "
 "can also be enabled at a more granular level."
 msgstr ""
-"<emphasis>注意:</emphasis>假若你设置了<literal>hibernate."
-"default_batch_fetch_size</literal>,Hibernate会对延迟加载采取批量抓取优化措施"
-"(这种优化也可能会在更细化的级别打开)。"
+"假若你设置了 <literal>hibernate.default_batch_fetch_size</literal>,"
+"Hibernate 会对延迟加载采取批量抓取优化措施(这种优化也可能会在更细化的级别打"
+"开)。"
 
 #. Tag: para
-#: performance.xml:158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please be aware that access to a lazy association outside of the context of "
 "an open Hibernate session will result in an exception. For example:"
 msgstr ""
-"然而,你必须了解延迟抓取带来的一个问题。在一个打开的Hibernate session上下文之"
-"外调用延迟集合会导致一次意外。比如:"
+"然而,你必须了解延迟抓取带来的一个问题。在一个打开的 Hibernate session 上下文"
+"之外调用延迟集合会导致一次意外。比如: "
 
-#. Tag: programlisting
-#: performance.xml:164
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[s = sessions.openSession();\n"
-"Transaction tx = s.beginTransaction();\n"
-"            \n"
-"User u = (User) s.createQuery(\"from User u where u.name=:userName\")\n"
-"    .setString(\"userName\", userName).uniqueResult();\n"
-"Map permissions = u.getPermissions();\n"
-"\n"
-"tx.commit();\n"
-"s.close();\n"
-"\n"
-"Integer accessLevel = (Integer) permissions.get(\"accounts\");  // Error!]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:166
-#, fuzzy, no-c-format
-msgid ""
 "Since the permissions collection was not initialized when the "
 "<literal>Session</literal> was closed, the collection will not be able to "
 "load its state. <emphasis>Hibernate does not support lazy initialization for "
 "detached objects</emphasis>. This can be fixed by moving the code that reads "
 "from the collection to just before the transaction is committed."
 msgstr ""
-"在<literal>Session</literal>关闭后,permessions集合将是未实例化的、不再可用,"
-"因此无法正常载入其状态。 <emphasis>Hibernate对脱管对象不支持延迟实例化</"
-"emphasis>. 这里的修改方法是:将permissions读取数据的代码 移到tx.commit()之"
-"前。"
+"在 <literal>Session</literal> 关闭后,permessions 集合将是未实例化的、不再可"
+"用,因此无法正常载入其状态。 <emphasis>Hibernate 对脱管对象不支持延迟实例化</"
+"emphasis>。这里的修改方法是将 permissions 读取数据的代码移到事务提交之前。"
 
 #. Tag: para
-#: performance.xml:174
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, you can use a non-lazy collection or association, by "
 "specifying <literal>lazy=\"false\"</literal> for the association mapping. "
@@ -275,14 +240,13 @@
 "in your object model, Hibernate will fetch the entire database into memory "
 "in every transaction."
 msgstr ""
-"除此之外,通过对关联映射指定<literal>lazy=\"false\"</literal>,我们也可以使用"
-"非延迟的集合或关联。但是, 对绝大部分集合来说,更推荐使用延迟方式抓取数据。如"
-"果在你的对象模型中定义了太多的非延迟关联,Hibernate最终几乎需要在每个事务中载"
-"入整个数据库到内存中!"
+"除此之外,通过对关联映射指定 <literal>lazy=\"false\"</literal>,我们也可以使"
+"用非延迟的集合或关联。但是,对绝大部分集合来说,更推荐使用延迟方式抓取数据。"
+"如果在你的对象模型中定义了太多的非延迟关联,Hibernate 最终几乎需要在每个事务"
+"中载入整个数据库到内存中。"
 
 #. Tag: para
-#: performance.xml:183
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "On the other hand, you can use join fetching, which is non-lazy by nature, "
 "instead of select fetching in a particular transaction. We will now explain "
@@ -291,45 +255,25 @@
 "collections."
 msgstr ""
 "但是,另一方面,在一些特殊的事务中,我们也经常需要使用到连接抓取(它本身上就"
-"是非延迟的),以代替查询抓取。 下面我们将会很快明白如何具体的定制Hibernate中"
-"的抓取策略。在Hibernate3中,具体选择哪种抓取策略的机制是和选择 单值关联或集合"
-"关联相一致的。"
+"是非延迟的),以代替查询抓取。 下面我们将会很快明白如何具体的定制 Hibernate "
+"中的抓取策略。在 Hibernate3 中,具体选择哪种抓取策略的机制是和选择 单值关联或"
+"集合关联相一致的。 "
 
 #. Tag: title
-#: performance.xml:194
 #, no-c-format
 msgid "Tuning fetch strategies"
 msgstr "调整抓取策略(Tuning fetch strategies)"
 
 #. Tag: para
-#: performance.xml:196
 #, no-c-format
 msgid ""
 "Select fetching (the default) is extremely vulnerable to N+1 selects "
 "problems, so we might want to enable join fetching in the mapping document:"
 msgstr ""
-"查询抓取(默认的)在N+1查询的情况下是极其脆弱的,因此我们可能会要求在映射文档"
-"中定义使用连接抓取:"
+"查询抓取(默认的)在 N+1 查询的情况下是极其脆弱的,因此我们可能会要求在映射文"
+"档中定义使用连接抓取:"
 
-#. Tag: programlisting
-#: performance.xml:201
-#, no-c-format
-msgid ""
-"<![CDATA[<set name=\"permissions\" \n"
-"            fetch=\"join\">\n"
-"    <key column=\"userId\"/>\n"
-"    <one-to-many class=\"Permission\"/>\n"
-"</set]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: performance.xml:203
-#, no-c-format
-msgid "<![CDATA[<many-to-one name=\"mother\" class=\"Cat\" fetch=\"join\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:205
 #, no-c-format
 msgid ""
 "The <literal>fetch</literal> strategy defined in the mapping document "
@@ -338,43 +282,38 @@
 "在映射文档中定义的<literal>抓取</literal>策略将会对以下列表条目产生影响:"
 
 #. Tag: para
-#: performance.xml:211
 #, no-c-format
 msgid "retrieval via <literal>get()</literal> or <literal>load()</literal>"
-msgstr "通过<literal>get()</literal>或<literal>load()</literal>方法取得数据。"
+msgstr ""
+"通过 <literal>get()</literal> 或 <literal>load()</literal> 方法取得数据。"
 
 #. Tag: para
-#: performance.xml:216
 #, no-c-format
 msgid "retrieval that happens implicitly when an association is navigated"
 msgstr "只有在关联之间进行导航时,才会隐式的取得数据。"
 
 #. Tag: para
-#: performance.xml:221
 #, no-c-format
 msgid "<literal>Criteria</literal> queries"
 msgstr "条件查询"
 
 #. Tag: para
-#: performance.xml:226
 #, no-c-format
 msgid "HQL queries if <literal>subselect</literal> fetching is used"
-msgstr "使用了<literal>subselect</literal>抓取的HQL查询"
+msgstr "使用了 <literal>subselect</literal> 抓取的 HQL 查询"
 
 #. Tag: para
-#: performance.xml:232
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Irrespective of the fetching strategy you use, the defined non-lazy graph is "
 "guaranteed to be loaded into memory. This might, however, result in several "
 "immediate selects being used to execute a particular HQL query."
 msgstr ""
 "不管你使用哪种抓取策略,定义为非延迟的类图会被保证一定装载入内存。注意这可能"
-"意味着在一条HQL查询后紧跟着一系列的查询。"
+"意味着在一条 HQL 查询后紧跟着一系列的查询。 "
 
 #. Tag: para
-#: performance.xml:238
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Usually, the mapping document is not used to customize fetching. Instead, we "
 "keep the default behavior, and override it for a particular transaction, "
@@ -384,58 +323,43 @@
 "<literal>setFetchMode(FetchMode.JOIN)</literal>."
 msgstr ""
 "通常情况下,我们并不使用映射文档进行抓取策略的定制。更多的是,保持其默认值,"
-"然后在特定的事务中, 使用HQL的<literal>左连接抓取(left join fetch)</"
+"然后在特定的事务中, 使用 HQL 的<literal>左连接抓取(left join fetch)</"
 "literal> 对其进行重载。这将通知 Hibernate在第一次查询中使用外部关联(outer "
-"join),直接得到其关联数据。 在<literal>条件查询</literal> API中,应该调用 "
-"<literal>setFetchMode(FetchMode.JOIN)</literal>语句。"
+"join),直接得到其关联数据。在<literal>条件查询</literal> API 中,应该调用 "
+"<literal>setFetchMode(FetchMode.JOIN)</literal>语句。 "
 
 #. Tag: para
-#: performance.xml:247
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you want to change the fetching strategy used by <literal>get()</literal> "
 "or <literal>load()</literal>, you can use a <literal>Criteria</literal> "
 "query. For example:"
 msgstr ""
-"也许你喜欢仅仅通过条件查询,就可以改变<literal>get()</literal> 或 "
-"<literal>load()</literal>语句中的数据抓取策略。例如:"
+"也许你喜欢仅仅通过条件查询,就可以改变 <literal>get()</literal> 或 "
+"<literal>load()</literal> 语句中的数据抓取策略。例如: "
 
-#. Tag: programlisting
-#: performance.xml:253
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[User user = (User) session.createCriteria(User.class)\n"
-"                .setFetchMode(\"permissions\", FetchMode.JOIN)\n"
-"                .add( Restrictions.idEq(userId) )\n"
-"                .uniqueResult();]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:255
-#, fuzzy, no-c-format
-msgid ""
 "This is Hibernate's equivalent of what some ORM solutions call a \"fetch plan"
 "\"."
 msgstr ""
-"(这就是其他ORM解决方案的“抓取计划(fetch plan)”在Hibernate中的等价物。)"
+"这就是其他 ORM 解决方案的“抓取计划(fetch plan)”在 Hibernate 中的等价物。"
 
 #. Tag: para
-#: performance.xml:259
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A completely different approach to problems with N+1 selects is to use the "
 "second-level cache."
-msgstr "截然不同的一种避免N+1次查询的方法是,使用二级缓存。"
+msgstr "截然不同的一种避免 N+1 次查询的方法是,使用二级缓存。 "
 
 #. Tag: title
-#: performance.xml:267
 #, no-c-format
 msgid "Single-ended association proxies"
 msgstr "单端关联代理(Single-ended association proxies)"
 
 #. Tag: para
-#: performance.xml:269
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Lazy fetching for collections is implemented using Hibernate's own "
 "implementation of persistent collections. However, a different mechanism is "
@@ -444,25 +368,24 @@
 "proxies for persistent objects using runtime bytecode enhancement which is "
 "accessed via the CGLIB library."
 msgstr ""
-"在Hinerbate中,对集合的延迟抓取的采用了自己的实现方法。但是,对于单端关联的延"
-"迟抓取,则需要采用 其他不同的机制。单端关联的目标实体必须使用代理,Hihernate"
-"在运行期二进制级(通过优异的CGLIB库), 为持久对象实现了延迟载入代理。"
+"在 Hinerbate 中,对集合的延迟抓取的采用了自己的实现方法。但是,对于单端关联的"
+"延迟抓取,则需要采用 其他不同的机制。单端关联的目标实体必须使用代理,"
+"Hihernate 在运行期二进制级(通过优异的 CGLIB 库), 为持久对象实现了延迟载入"
+"代理。 "
 
 #. Tag: para
-#: performance.xml:277
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "At startup, Hibernate3 generates proxies by default for all persistent "
 "classes and uses them to enable lazy fetching of <literal>many-to-one</"
 "literal> and <literal>one-to-one</literal> associations."
 msgstr ""
-"默认的,Hibernate3将会为所有的持久对象产生代理(在启动阶段),然后使用他们实"
+"默认的,Hibernate3 将会为所有的持久对象产生代理(在启动阶段),然后使用他们实"
 "现 <literal>多对一(many-to-one)</literal>关联和<literal>一对一(one-to-"
-"one)</literal> 关联的延迟抓取。"
+"one)</literal> 关联的延迟抓取。 "
 
 #. Tag: para
-#: performance.xml:283
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The mapping file may declare an interface to use as the proxy interface for "
 "that class, with the <literal>proxy</literal> attribute. By default, "
@@ -470,75 +393,35 @@
 "implement a default constructor with at least package visibility. This "
 "constructor is recommended for all persistent classes</emphasis>."
 msgstr ""
-"在映射文件中,可以通过设置<literal>proxy</literal>属性为目标class声明一个接口"
-"供代理接口使用。 默认的,Hibernate将会使用该类的一个子类。 <emphasis>注意:被"
-"代理的类必须实现一个至少包可见的默认构造函数,我们建议所有的持久类都应拥有这"
-"样的构造函数</emphasis>"
+"在映射文件中,可以通过设置 <literal>proxy</literal> 属性为目标 class 声明一个"
+"接口供代理接口使用。 默认的,Hibernate 将会使用该类的一个子类。<emphasis>注"
+"意:被代理的类必须实现一个至少包可见的默认构造函数,我们建议所有的持久类都应"
+"拥有这样的构造函数。</emphasis>"
 
 #. Tag: para
-#: performance.xml:290
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There are potential problems to note when extending this approach to "
 "polymorphic classes.For example:"
-msgstr "在如此方式定义一个多态类的时候,有许多值得注意的常见性的问题,例如:"
+msgstr "在如此方式定义一个多态类的时候,有许多值得注意的常见性的问题,例如: "
 
-#. Tag: programlisting
-#: performance.xml:294
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Cat\" proxy=\"Cat\">\n"
-"    ......\n"
-"    <subclass name=\"DomesticCat\">\n"
-"        .....\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:296
 #, no-c-format
 msgid ""
 "Firstly, instances of <literal>Cat</literal> will never be castable to "
 "<literal>DomesticCat</literal>, even if the underlying instance is an "
 "instance of <literal>DomesticCat</literal>:"
 msgstr ""
-"首先,<literal>Cat</literal>实例永远不可以被强制转换为<literal>DomesticCat</"
-"literal>, 即使它本身就是<literal>DomesticCat</literal>实例。"
+"首先,<literal>Cat</literal> 实例永远不可以被强制转换为 "
+"<literal>DomesticCat</literal>,即使它本身就是 <literal>DomesticCat</"
+"literal> 实例。"
 
-#. Tag: programlisting
-#: performance.xml:302
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);  // instantiate a "
-"proxy (does not hit the db)\n"
-"if ( cat.isDomesticCat() ) {                  // hit the db to initialize "
-"the proxy\n"
-"    DomesticCat dc = (DomesticCat) cat;       // Error!\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:304
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Secondly, it is possible to break proxy <literal>==</literal>:"
-msgstr "其次,代理的“<literal>==</literal>”可能不再成立。"
+msgstr "其次,代理的“<literal>==</literal>”可能不再成立。 "
 
-#. Tag: programlisting
-#: performance.xml:308
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);            // "
-"instantiate a Cat proxy\n"
-"DomesticCat dc = \n"
-"        (DomesticCat) session.load(DomesticCat.class, id);  // acquire new "
-"DomesticCat proxy!\n"
-"System.out.println(cat==dc);                            // false]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:310
 #, no-c-format
 msgid ""
 "However, the situation is not quite as bad as it looks. Even though we now "
@@ -546,27 +429,19 @@
 "still be the same object:"
 msgstr ""
 "虽然如此,但实际情况并没有看上去那么糟糕。虽然我们现在有两个不同的引用,分别"
-"指向这两个不同的代理对象, 但实际上,其底层应该是同一个实例对象:"
+"指向这两个不同的代理对象,但实际上,其底层应该是同一个实例对象:"
 
-#. Tag: programlisting
-#: performance.xml:315
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[cat.setWeight(11.0);  // hit the db to initialize the proxy\n"
-"System.out.println( dc.getWeight() );  // 11.0]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:317
-#, fuzzy, no-c-format
-msgid ""
 "Third, you cannot use a CGLIB proxy for a <literal>final</literal> class or "
 "a class with any <literal>final</literal> methods."
-msgstr "第三,你不能对“final类”或“具有final方法的类”使用CGLIB代理。"
+msgstr ""
+"第三,你不能对 <literal>final</literal> 类或具有 <literal>final</literal> 方"
+"法的类使用 CGLIB 代理。"
 
 #. Tag: para
-#: performance.xml:322
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, if your persistent object acquires any resources upon instantiation "
 "(e.g. in initializers or default constructor), then those resources will "
@@ -574,12 +449,11 @@
 "persistent class."
 msgstr ""
 "最后,如果你的持久化对象在实例化时需要某些资源(例如,在实例化方法、默认构造"
-"方法中), 那么代理对象也同样需要使用这些资源。实际上,代理类是持久化类的子"
+"方法中),那么代理对象也同样需要使用这些资源。实际上,代理类是持久化类的子"
 "类。"
 
 #. Tag: para
-#: performance.xml:328
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These problems are all due to fundamental limitations in Java's single "
 "inheritance model. To avoid these problems your persistent classes must each "
@@ -589,144 +463,111 @@
 "<literal>DomesticCatImpl</literal> implements the interface "
 "<literal>DomesticCat</literal>. For example:"
 msgstr ""
-"这些问题都源于Java的单根继承模型的天生限制。如果你希望避免这些问题,那么你的"
-"每个持久化类必须实现一个接口, 在此接口中已经声明了其业务方法。然后,你需要在"
-"映射文档中再指定这些接口。例如:"
+"这些问题都源于 Java 的单根继承模型的天生限制。如果你希望避免这些问题,那么你"
+"的每个持久化类必须实现一个接口, 在此接口中已经声明了其业务方法。然后,你需要"
+"在映射文档中再指定这些接口,如 <literal>CatImpl</literal> 实现 <literal>Cat</"
+"literal> 而 <literal>DomesticCatImpl</literal> 实现 <literal>DomesticCat</"
+"literal> 接口。例如:"
 
-#. Tag: programlisting
-#: performance.xml:336
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"CatImpl\" proxy=\"Cat\">\n"
-"    ......\n"
-"    <subclass name=\"DomesticCatImpl\" proxy=\"DomesticCat\">\n"
-"        .....\n"
-"    </subclass>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:338
-#, fuzzy, no-c-format
-msgid ""
 "Then proxies for instances of <literal>Cat</literal> and "
 "<literal>DomesticCat</literal> can be returned by <literal>load()</literal> "
 "or <literal>iterate()</literal>."
 msgstr ""
-"首先,<literal>Cat</literal>实例永远不可以被强制转换为<literal>DomesticCat</"
-"literal>, 即使它本身就是<literal>DomesticCat</literal>实例。"
+"然后,<literal>load()</literal> 和 <literal>iterate()</literal> 永远也不会返"
+"回 <literal>Cat</literal> 和 <literal>DomesticCat</literal> 实例的代理。"
 
-#. Tag: programlisting
-#: performance.xml:343
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = (Cat) session.load(CatImpl.class, catid);\n"
-"Iterator iter = session.createQuery(\"from CatImpl as cat where cat."
-"name='fritz'\").iterate();\n"
-"Cat fritz = (Cat) iter.next();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:346
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "注意"
 
 #. Tag: para
-#: performance.xml:347
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>list()</literal> does not usually return proxies."
-msgstr "条件查询"
+msgstr "<literal>list()</literal> 通常不返回代理。"
 
 #. Tag: para
-#: performance.xml:352
 #, no-c-format
 msgid ""
 "Relationships are also lazily initialized. This means you must declare any "
 "properties to be of type <literal>Cat</literal>, not <literal>CatImpl</"
 "literal>."
 msgstr ""
-"这里,对象之间的关系也将被延迟载入。这就意味着,你应该将属性声明为"
-"<literal>Cat</literal>,而不是<literal>CatImpl</literal>。"
+"这里,对象之间的关系也将被延迟载入。这就意味着,你应该将属性声明为 "
+"<literal>Cat</literal>,而不是 <literal>CatImpl</literal>。"
 
 #. Tag: para
-#: performance.xml:357
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Certain operations do <emphasis>not</emphasis> require proxy initialization:"
-msgstr "但是,在有些方法中是<emphasis>不需要</emphasis>使用代理的。例如:"
+msgstr "有些方法中是<emphasis>不</emphasis>需要代理初始化的:"
 
 #. Tag: para
-#: performance.xml:363
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>equals()</literal>: if the persistent class does not override "
 "<literal>equals()</literal>"
 msgstr ""
-"<literal>equals()</literal>方法,如果持久类没有重载<literal>equals()</"
-"literal>方法。"
+"<literal>equals()</literal> 方法,如果持久类没有重载 <literal>equals()</"
+"literal> 方法。"
 
 #. Tag: para
-#: performance.xml:369
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>hashCode()</literal>: if the persistent class does not override "
 "<literal>hashCode()</literal>"
 msgstr ""
-"<literal>hashCode()</literal>方法,如果持久类没有重载<literal>hashCode()</"
-"literal>方法。"
+"<literal>hashCode()</literal>:如果持久类没有重载 <literal>hashCode()</"
+"literal> 方法。"
 
 #. Tag: para
-#: performance.xml:375
 #, no-c-format
 msgid "The identifier getter method"
-msgstr "标志符的getter方法。"
+msgstr "标志符的 getter 方法。"
 
 #. Tag: para
-#: performance.xml:381
 #, no-c-format
 msgid ""
 "Hibernate will detect persistent classes that override <literal>equals()</"
 "literal> or <literal>hashCode()</literal>."
 msgstr ""
-"Hibernate将会识别出那些重载了<literal>equals()</literal>、或<literal>hashCode"
-"()</literal>方法的持久化类。"
+"Hibernate 将会识别出那些重载了 <literal>equals()</literal>、或 "
+"<literal>hashCode()</literal> 方法的持久化类。"
 
 #. Tag: para
-#: performance.xml:386
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "By choosing <literal>lazy=\"no-proxy\"</literal> instead of the default "
 "<literal>lazy=\"proxy\"</literal>, you can avoid problems associated with "
 "typecasting. However, buildtime bytecode instrumentation is required, and "
 "all operations will result in immediate proxy initialization."
 msgstr ""
-"若选择<literal>lazy=\"no-proxy\"</literal>而非默认的<literal>lazy=\"proxy\"</"
-"literal>,我们可以避免类型转换带来的问题。然而,这样我们就需要编译期字节码增"
-"强,并且所有的操作都会导致立刻进行代理初始化。"
+"若选择 <literal>lazy=\"no-proxy\"</literal> 而非默认的 <literal>lazy=\"proxy"
+"\"</literal>,我们可以避免类型转换带来的问题。然而,这样我们就需要编译期字节"
+"码增强,并且所有的操作都会导致立刻进行代理初始化。 "
 
 #. Tag: title
-#: performance.xml:396
 #, no-c-format
 msgid "Initializing collections and proxies"
 msgstr "实例化集合和代理(Initializing collections and proxies)"
 
 #. Tag: para
-#: performance.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>LazyInitializationException</literal> will be thrown by Hibernate "
 "if an uninitialized collection or proxy is accessed outside of the scope of "
 "the <literal>Session</literal>, i.e., when the entity owning the collection "
 "or having the reference to the proxy is in the detached state."
 msgstr ""
-"在<literal>Session</literal>范围之外访问未初始化的集合或代理,Hibernate将会抛"
-"出<literal>LazyInitializationException</literal>异常。 也就是说,在分离状态"
-"下,访问一个实体所拥有的集合,或者访问其指向代理的属性时,会引发此异常。"
+"在 <literal>Session</literal> 范围之外访问未初始化的集合或代理,Hibernate 将"
+"会抛出 <literal>LazyInitializationException</literal> 异常。也就是说,在分离"
+"状态下,访问一个实体所拥有的集合,或者访问其指向代理的属性时,会引发此异常。 "
 
 #. Tag: para
-#: performance.xml:404
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes a proxy or collection needs to be initialized before closing the "
 "<literal>Session</literal>. You can force initialization by calling "
@@ -734,14 +575,13 @@
 "literal>, for example. However, this can be confusing to readers of the code "
 "and it is not convenient for generic code."
 msgstr ""
-"有时候我们需要保证某个代理或者集合在Session关闭前就已经被初始化了。 当然,我"
-"们可以通过强行调用<literal>cat.getSex()</literal>或者<literal>cat.getKittens"
-"().size()</literal>之类的方法来确保这一点。 但是这样的程序会造成读者的疑惑,"
-"也不符合通常的代码规范。"
+"有时候我们需要保证某个代理或者集合在 Session 关闭前就已经被初始化了。当然,我"
+"们可以通过强行调用 <literal>cat.getSex()</literal> 或者 <literal>cat."
+"getKittens().size()</literal> 之类的方法来确保这一点。 但是这样的程序会造成读"
+"者的疑惑,也不符合通常的代码规范。 "
 
 #. Tag: para
-#: performance.xml:411
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The static methods <literal>Hibernate.initialize()</literal> and "
 "<literal>Hibernate.isInitialized()</literal>, provide the application with a "
@@ -751,15 +591,14 @@
 "literal> is still open. <literal>Hibernate.initialize( cat.getKittens() )</"
 "literal> has a similar effect for the collection of kittens."
 msgstr ""
-"静态方法<literal>Hibernate.initialized()</literal> 为你的应用程序提供了一个便"
-"捷的途径来延迟加载集合或代理。 只要它的Session处于open状态,"
-"<literal>Hibernate.initialize(cat)</literal> 将会为cat强制对代理实例化。 同"
-"样,<literal>Hibernate.initialize( cat.getKittens() )</literal> 对kittens的集"
-"合具有同样的功能。"
+"静态方法 <literal>Hibernate.initialized()</literal> 为你的应用程序提供了一个"
+"便捷的途径来延迟加载集合或代理。 只要它的 Session 处于 open 状态,"
+"<literal>Hibernate.initialize(cat)</literal> 将会为 cat 强制对代理实例化。同"
+"样,<literal>Hibernate.initialize(cat.getKittens())</literal> 对 kittens 的集"
+"合具有同样的功能。 "
 
 #. Tag: para
-#: performance.xml:420
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Another option is to keep the <literal>Session</literal> open until all "
 "required collections and proxies have been loaded. In some application "
@@ -769,15 +608,14 @@
 "<literal>Session</literal> is open when a collection is initialized. There "
 "are two basic ways to deal with this issue:"
 msgstr ""
-"还有另外一种选择,就是保持<literal>Session</literal>一直处于open状态,直到所"
-"有需要的集合或代理都被载入。 在某些应用架构中,特别是对于那些使用Hibernate进"
-"行数据访问的代码,以及那些在不同应用层和不同物理进程中使用Hibernate的代码。 "
-"在集合实例化时,如何保证<literal>Session</literal>处于open状态经常会是一个问"
-"题。有两种方法可以解决此问题:"
+"还有另外一种选择,就是保持 <literal>Session</literal> 一直处于 open 状态,直"
+"到所有需要的集合或代理都被载入。 在某些应用架构中,特别是对于那些使用 "
+"Hibernate 进行数据访问的代码,以及那些在不同应用层和不同物理进程中使用 "
+"Hibernate 的代码。 在集合实例化时,如何保证 <literal>Session</literal> 处于 "
+"open 状态经常会是一个问题。有两种方法可以解决此问题: "
 
 #. Tag: para
-#: performance.xml:431
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In a web-based application, a servlet filter can be used to close the "
 "<literal>Session</literal> only at the end of a user request, once the "
@@ -789,16 +627,16 @@
 "rendering of the view. See the Hibernate Wiki for examples of this \"Open "
 "Session in View\" pattern."
 msgstr ""
-"在一个基于Web的应用中,可以利用servlet过滤器(filter),在用户请求(request)"
-"结束、页面生成 结束时关闭<literal>Session</literal>(这里使用了<emphasis>在展"
-"示层保持打开Session模式(Open Session in View)</emphasis>), 当然,这将依赖"
-"于应用框架中异常需要被正确的处理。在返回界面给用户之前,乃至在生成界面过程中"
-"发生异常的情况下, 正确关闭<literal>Session</literal>和结束事务将是非常重要"
-"的, 请参见Hibernate wiki上的\"Open Session in View\"模式,你可以找到示例。"
+"在一个基于 Web 的应用中,可以利用 servlet 过滤器(filter),在用户请求"
+"(request)结束、页面生成 结束时关闭 <literal>Session</literal>(这里使用了"
+"<emphasis>在展示层保持打开 Session 模式(Open Session in View)</"
+"emphasis>),当然,这将依赖于应用框架中异常需要被正确的处理。在返回界面给用户"
+"之前,乃至在生成界面过程中发生异常的情况下,正确关闭 <literal>Session</"
+"literal> 和结束事务将是非常重要的, 请参见 Hibernate wiki 上的 \"Open "
+"Session in View\" 模式,你可以找到示例。 "
 
 #. Tag: para
-#: performance.xml:444
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In an application with a separate business tier, the business logic must "
 "\"prepare\" all collections that the web tier needs before returning. This "
@@ -812,18 +650,17 @@
 "literal>. This is usually easier if you adopt the <emphasis>Command</"
 "emphasis> pattern instead of a <emphasis>Session Facade</emphasis>."
 msgstr ""
-"在一个拥有单独业务层的应用中,业务层必须在返回之前,为web层“准备”好其所需的数"
-"据集合。这就意味着 业务层应该载入所有表现层/web层所需的数据,并将这些已实例化"
-"完毕的数据返回。通常,应用程序应该 为web层所需的每个集合调用"
-"<literal>Hibernate.initialize()</literal>(这个调用必须发生咱session关闭之"
-"前); 或者使用带有<literal>FETCH</literal>从句,或<literal>FetchMode.JOIN</"
-"literal>的Hibernate查询, 事先取得所有的数据集合。如果你在应用中使用了"
-"<emphasis>Command</emphasis>模式,代替<emphasis>Session Facade</emphasis> , "
-"那么这项任务将会变得简单的多。"
+"在一个拥有单独业务层的应用中,业务层必须在返回之前,为 web 层“准备”好其所需的"
+"数据集合。这就意味着 业务层应该载入所有表现层/web 层所需的数据,并将这些已实"
+"例化完毕的数据返回。通常,应用程序应该为 web 层所需的每个集合调用 "
+"<literal>Hibernate.initialize()</literal>(这个调用必须发生咱 session 关闭之"
+"前);或者使用带有 <literal>FETCH</literal> 从句,或 <literal>FetchMode."
+"JOIN</literal> 的 Hibernate 查询,事先取得所有的数据集合。如果你在应用中使用"
+"了 <emphasis>Command</emphasis> 模式,代替 <emphasis>Session Facade</"
+"emphasis>,那么这项任务将会变得简单的多。 "
 
 #. Tag: para
-#: performance.xml:459
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also attach a previously loaded object to a new <literal>Session</"
 "literal> with <literal>merge()</literal> or <literal>lock()</literal> before "
@@ -831,79 +668,57 @@
 "and certainly <emphasis>should</emphasis> not, do this automatically since "
 "it would introduce impromptu transaction semantics."
 msgstr ""
-"你也可以通过<literal>merge()</literal>或<literal>lock()</literal>方法,在访问"
-"未实例化的集合(或代理)之前, 为先前载入的对象绑定一个新的<literal>Session</"
-"literal>。 显然,Hibernate将不会,也不<emphasis>应该</emphasis>自动完成这些任"
-"务,因为这将引入一个特殊的事务语义。"
+"你也可以通过 <literal>merge()</literal> 或 <literal>lock()</literal> 方法,在"
+"访问未实例化的集合(或代理)之前,为先前载入的对象绑定一个新的 "
+"<literal>Session</literal>。显然,Hibernate 将不会,也不<emphasis>应该</"
+"emphasis>自动完成这些任务,因为这将引入一个特殊的事务语义。 "
 
 #. Tag: para
-#: performance.xml:469
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes you do not want to initialize a large collection, but still need "
 "some information about it, like its size, for example, or a subset of the "
 "data."
 msgstr ""
 "有时候,你并不需要完全实例化整个大的集合,仅需要了解它的部分信息(例如其大"
-"小)、或者集合的部分内容。"
+"小)、或者集合的部分内容。 "
 
 #. Tag: para
-#: performance.xml:474
 #, no-c-format
 msgid ""
 "You can use a collection filter to get the size of a collection without "
 "initializing it:"
 msgstr "你可以使用集合过滤器得到其集合的大小,而不必实例化整个集合:"
 
-#. Tag: programlisting
-#: performance.xml:478
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) s.createFilter( collection, \"select count(*)\" ).list"
-"().get(0) ).intValue()]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:480
 #, no-c-format
 msgid ""
 "The <literal>createFilter()</literal> method is also used to efficiently "
 "retrieve subsets of a collection without needing to initialize the whole "
 "collection:"
 msgstr ""
-"这里的<literal>createFilter()</literal>方法也可以被用来有效的抓取集合的部分内"
-"容,而无需实例化整个集合:"
+"这里的 <literal>createFilter()</literal> 方法也可以被用来有效的抓取集合的部分"
+"内容,而无需实例化整个集合:"
 
-#. Tag: programlisting
-#: performance.xml:485
-#, no-c-format
-msgid ""
-"<![CDATA[s.createFilter( lazyCollection, \"\").setFirstResult(0)."
-"setMaxResults(10).list();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:490
 #, no-c-format
 msgid "Using batch fetching"
 msgstr "使用批量抓取(Using batch fetching)"
 
 #. Tag: para
-#: performance.xml:492
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Using batch fetching, Hibernate can load several uninitialized proxies if "
 "one proxy is accessed. Batch fetching is an optimization of the lazy select "
 "fetching strategy. There are two ways you can configure batch fetching: on "
 "the class level and the collection level."
 msgstr ""
-"Hibernate可以充分有效的使用批量抓取,也就是说,如果仅一个访问代理(或集合),"
-"那么Hibernate将不载入其他未实例化的代理。 批量抓取是延迟查询抓取的优化方案,"
-"你可以在两种批量抓取方案之间进行选择:在类级别和集合级别。"
+"Hibernate 可以充分有效的使用批量抓取,也就是说,如果仅一个访问代理(或集"
+"合),那么 Hibernate 将不载入其他未实例化的代理。批量抓取是延迟查询抓取的优化"
+"方案,你可以在两种批量抓取方案之间进行选择:在类级别和集合级别。 "
 
 #. Tag: para
-#: performance.xml:498
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Batch fetching for classes/entities is easier to understand. Consider the "
 "following example: at runtime you have 25 <literal>Cat</literal> instances "
@@ -916,32 +731,24 @@
 "can tune this behavior by specifying a <literal>batch-size</literal> in the "
 "mapping of <literal>Person</literal>:"
 msgstr ""
-"类/实体级别的批量抓取很容易理解。假设你在运行时将需要面对下面的问题:你在一个"
-"<literal>Session</literal>中载入了25个 <literal>Cat</literal>实例,每个"
-"<literal>Cat</literal>实例都拥有一个引用成员<literal>owner</literal>, 其指向"
-"<literal>Person</literal>,而<literal>Person</literal>类是代理,同时"
-"<literal>lazy=\"true\"</literal>。 如果你必须遍历整个cats集合,对每个元素调用"
-"<literal>getOwner()</literal>方法,Hibernate将会默认的执行25次"
-"<literal>SELECT</literal>查询, 得到其owner的代理对象。这时,你可以通过在映射"
-"文件的<literal>Person</literal>属性,显式声明<literal>batch-size</literal>,"
-"改变其行为:"
+"类/实体级别的批量抓取很容易理解。假设你在运行时将需要面对下面的问题:你在一"
+"个 <literal>Session</literal> 中载入了 25 个 <literal>Cat</literal> 实例,每"
+"个 <literal>Cat</literal> 实例都拥有一个引用成员 <literal>owner</literal>,其"
+"指向 <literal>Person</literal>,而 <literal>Person</literal> 类是代理,同时 "
+"<literal>lazy=\"true\"</literal>。如果你必须遍历整个 cats 集合,对每个元素调"
+"用 <literal>getOwner()</literal> 方法,Hibernate 将会默认的执行 25 次 "
+"<literal>SELECT</literal> 查询, 得到其 owner 的代理对象。这时,你可以通过在"
+"映射文件的 <literal>Person</literal> 属性,显式声明 <literal>batch-size</"
+"literal>,改变其行为: "
 
-#. Tag: programlisting
-#: performance.xml:508
-#, no-c-format
-msgid "<![CDATA[<class name=\"Person\" batch-size=\"10\">...</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:510
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will now execute only three queries: the pattern is 10, 10, 5."
-msgstr "随之,Hibernate将只需要执行三次查询,分别为10、10、 5。"
+msgstr "随之,Hibernate 将只需要执行三次查询,分别为 10、10、 5。 "
 
 #. Tag: para
-#: performance.xml:514
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also enable batch fetching of collections. For example, if each "
 "<literal>Person</literal> has a lazy collection of <literal>Cat</literal>s, "
@@ -951,26 +758,15 @@
 "fetching for the <literal>cats</literal> collection in the mapping of "
 "<literal>Person</literal>, Hibernate can pre-fetch collections:"
 msgstr ""
-"你也可以在集合级别定义批量抓取。例如,如果每个<literal>Person</literal>都拥有"
-"一个延迟载入的<literal>Cats</literal>集合, 现在,<literal>Sesssion</literal>"
-"中载入了10个person对象,遍历person集合将会引起10次<literal>SELECT</literal>查"
-"询, 每次查询都会调用<literal>getCats()</literal>方法。如果你在"
-"<literal>Person</literal>的映射定义部分,允许对<literal>cats</literal>批量抓"
-"取, 那么,Hibernate将可以预先抓取整个集合。请看例子:"
+"你也可以在集合级别定义批量抓取。例如,如果每个 <literal>Person</literal> 都拥"
+"有一个延迟载入的 <literal>Cats</literal> 集合, 现在,<literal>Sesssion</"
+"literal> 中载入了 10 个 person 对象,遍历 person 集合将会引起 10 次 "
+"<literal>SELECT</literal> 查询,每次查询都会调用 <literal>getCats()</"
+"literal> 方法。如果你在 <literal>Person</literal> 的映射定义部分,允许对 "
+"<literal>cats</literal> 批量抓取,那么,Hibernate 将可以预先抓取整个集合。请"
+"看例子: "
 
-#. Tag: programlisting
-#: performance.xml:523
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <set name=\"cats\" batch-size=\"3\">\n"
-"        ...\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:525
 #, no-c-format
 msgid ""
 "With a <literal>batch-size</literal> of 3, Hibernate will load 3, 3, 3, 1 "
@@ -978,14 +774,13 @@
 "attribute depends on the expected number of uninitialized collections in a "
 "particular <literal>Session</literal>."
 msgstr ""
-"如果整个的<literal>batch-size</literal>是3(笔误?),那么Hibernate将会分四次"
-"执行<literal>SELECT</literal>查询, 按照3、3、3、1的大小分别载入数据。这里的"
-"每次载入的数据量还具体依赖于当前<literal>Session</literal>中未实例化集合的个"
-"数。"
+"如果整个的 <literal>batch-size</literal> 是 3,那么 Hibernate 将会分四次执行 "
+"<literal>SELECT</literal> 查询, 按照 3、3、3、1 的大小分别载入数据。这里的每"
+"次载入的数据量还具体依赖于当前 <literal>Session</literal> 中未实例化集合的个"
+"数。 "
 
 #. Tag: para
-#: performance.xml:531
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Batch fetching of collections is particularly useful if you have a nested "
 "tree of items, i.e. the typical bill-of-materials pattern. However, a "
@@ -993,37 +788,91 @@
 "might be a better option for read-mostly trees."
 msgstr ""
 "如果你的模型中有嵌套的树状结构,例如典型的帐单-原料结构(bill-of-materials "
-"pattern),集合的批量抓取是非常有用的。 (尽管在更多情况下对树进行读取时,"
-"<emphasis>嵌套集合(nested set)</emphasis>或<emphasis>原料路径(materialized "
-"path)</emphasis>(××) 是更好的解决方法。)"
+"pattern),集合的批量抓取是非常有用的。(尽管在更多情况下对树进行读取时,"
+"<emphasis>嵌套集合(nested set)</emphasis>或<emphasis>原料路径"
+"(materialized path)</emphasis>可能是更好的解决方法。)"
 
 #. Tag: title
-#: performance.xml:540
 #, no-c-format
 msgid "Using subselect fetching"
 msgstr "使用子查询抓取(Using subselect fetching)"
 
 #. Tag: para
-#: performance.xml:542
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If one lazy collection or single-valued proxy has to be fetched, Hibernate "
 "will load all of them, re-running the original query in a subselect. This "
 "works in the same way as batch-fetching but without the piecemeal loading."
 msgstr ""
-"假若一个延迟集合或单值代理需要抓取,Hibernate会使用一个subselect重新运行原来"
-"的查询,一次性读入所有的实例。这和批量抓取的实现方法是一样的,不会有破碎的加"
-"载。"
+"假若一个延迟集合或单值代理需要抓取,Hibernate 会使用一个 subselect 重新运行原"
+"来的查询,一次性读入所有的实例。这和批量抓取的实现方法是一样的,不会有破碎的"
+"加载。 "
 
 #. Tag: title
-#: performance.xml:553
+#, fuzzy, no-c-format
+msgid "Fetch profiles"
+msgstr "抓取策略(Fetching strategies)"
+
+#. Tag: para
 #, no-c-format
+msgid ""
+"Another way to affect the fetching strategy for loading associated objects "
+"is through something called a fetch profile, which is a named configuration "
+"associated with the <interfacename>org.hibernate.SessionFactory</"
+"interfacename> but enabled, by name, on the <interfacename>org.hibernate."
+"Session</interfacename>. Once enabled on a <interfacename>org.hibernate."
+"Session</interfacename>, the fetch profile wull be in affect for that "
+"<interfacename>org.hibernate.Session</interfacename> until it is explicitly "
+"disabled."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"So what does that mean? Well lets explain that by way of an example. Say we "
+"have the following mappings:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Now normally when you get a reference to a particular customer, that "
+"customer's set of orders will be lazy meaning we will not yet have loaded "
+"those orders from the database. Normally this is a good thing. Now lets say "
+"that you have a certain use case where it is more efficient to load the "
+"customer and their orders together. One way certainly is to use \"dynamic "
+"fetching\" strategies via an HQL or criteria queries. But another option is "
+"to use a fetch profile to achieve that. Just add the following to your "
+"mapping:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "or even:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Now the following code will actually load both the customer <emphasis>and "
+"their orders</emphasis>:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"Currently only join style fetch profiles are supported, but they plan is to "
+"support additional styles. See <ulink url=\"http://opensource.atlassian.com/"
+"projects/hibernate/browse/HHH-3414\">HHH-3414</ulink> for details."
+msgstr ""
+
+#. Tag: title
+#, no-c-format
 msgid "Using lazy property fetching"
 msgstr "使用延迟属性抓取(Using lazy property fetching)"
 
 #. Tag: para
-#: performance.xml:555
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 supports the lazy fetching of individual properties. This "
 "optimization technique is also known as <emphasis>fetch groups</emphasis>. "
@@ -1033,106 +882,63 @@
 "when legacy tables have hundreds of columns and the data model cannot be "
 "improved."
 msgstr ""
-"Hibernate3对单独的属性支持延迟抓取,这项优化技术也被称为<emphasis>组抓取"
+"Hibernate3 对单独的属性支持延迟抓取,这项优化技术也被称为<emphasis>组抓取"
 "(fetch groups)</emphasis>。 请注意,该技术更多的属于市场特性。在实际应用"
 "中,优化行读取比优化列读取更重要。但是,仅载入类的部分属性在某些特定情况下会"
-"有用,例如在原有表中拥有几百列数据、数据模型无法改动的情况下。"
+"有用,例如在原有表中拥有几百列数据、数据模型无法改动的情况下。 "
 
 #. Tag: para
-#: performance.xml:564
 #, no-c-format
 msgid ""
 "To enable lazy property loading, set the <literal>lazy</literal> attribute "
 "on your particular property mappings:"
 msgstr ""
-"可以在映射文件中对特定的属性设置<literal>lazy</literal>,定义该属性为延迟载"
+"可以在映射文件中对特定的属性设置 <literal>lazy</literal>,定义该属性为延迟载"
 "入。"
 
-#. Tag: programlisting
-#: performance.xml:569
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Document\">\n"
-"       <id name=\"id\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\" length=\"50\"/>\n"
-"    <property name=\"summary\" not-null=\"true\" length=\"200\" lazy=\"true"
-"\"/>\n"
-"    <property name=\"text\" not-null=\"true\" length=\"2000\" lazy=\"true\"/"
-">\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:571
-#, fuzzy, no-c-format
-msgid ""
 "Lazy property loading requires buildtime bytecode instrumentation. If your "
 "persistent classes are not enhanced, Hibernate will ignore lazy property "
 "settings and return to immediate fetching."
 msgstr ""
 "属性的延迟载入要求在其代码构建时加入二进制指示指令(bytecode "
-"instrumentation),如果你的持久类代码中未含有这些指令, Hibernate将会忽略这些"
-"属性的延迟设置,仍然将其直接载入。"
+"instrumentation),如果你的持久类代码中未含有这些指令, Hibernate 将会忽略这"
+"些属性的延迟设置,仍然将其直接载入。 "
 
 #. Tag: para
-#: performance.xml:577
 #, no-c-format
 msgid "For bytecode instrumentation, use the following Ant task:"
-msgstr "你可以在Ant的Task中,进行如下定义,对持久类代码加入“二进制指令。”"
+msgstr "你可以在 Ant 的 Task 中,进行如下定义,对持久类代码加入“二进制指令。”"
 
-#. Tag: programlisting
-#: performance.xml:581
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<target name=\"instrument\" depends=\"compile\">\n"
-"    <taskdef name=\"instrument\" classname=\"org.hibernate.tool.instrument."
-"InstrumentTask\">\n"
-"        <classpath path=\"${jar.path}\"/>\n"
-"        <classpath path=\"${classes.dir}\"/>\n"
-"        <classpath refid=\"lib.class.path\"/>\n"
-"    </taskdef>\n"
-"\n"
-"    <instrument verbose=\"true\">\n"
-"        <fileset dir=\"${testclasses.dir}/org/hibernate/auction/model\">\n"
-"            <include name=\"*.class\"/>\n"
-"        </fileset>\n"
-"    </instrument>\n"
-"</target>]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:583
-#, fuzzy, no-c-format
-msgid ""
 "A different way of avoiding unnecessary column reads, at least for read-only "
 "transactions, is to use the projection features of HQL or Criteria queries. "
 "This avoids the need for buildtime bytecode processing and is certainly a "
 "preferred solution."
 msgstr ""
-"还有一种可以优化的方法,它使用HQL或条件查询的投影(projection)特性,可以避免"
-"读取非必要的列, 这一点至少对只读事务是非常有用的。它无需在代码构建时“二进制"
-"指令”处理,因此是一个更加值得选择的解决方法。"
+"还有一种可以优化的方法,它使用 HQL 或条件查询的投影(projection)特性,可以避"
+"免读取非必要的列, 这一点至少对只读事务是非常有用的。它无需在代码构建时“二进"
+"制指令”处理,因此是一个更加值得选择的解决方法。 "
 
 #. Tag: para
-#: performance.xml:590
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can force the usual eager fetching of properties using <literal>fetch "
 "all properties</literal> in HQL."
 msgstr ""
-"有时你需要在HQL中通过<literal>抓取所有属性</literal>,强行抓取所有内容。"
+"有时你需要在 HQL 中通过<literal>抓取所有属性</literal>,强行抓取所有内容。 "
 
 #. Tag: title
-#: performance.xml:600
 #, no-c-format
 msgid "The Second Level Cache"
 msgstr "二级缓存(The Second Level Cache)"
 
 #. Tag: para
-#: performance.xml:602
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A Hibernate <literal>Session</literal> is a transaction-level cache of "
 "persistent data. It is possible to configure a cluster or JVM-level "
@@ -1142,15 +948,14 @@
 "another application. They can, however, be configured to regularly expire "
 "cached data."
 msgstr ""
-"Hibernate的<literal>Session</literal>在事务级别进行持久化数据的缓存操作。 当"
-"然,也有可能分别为每个类(或集合),配置集群、或JVM级别"
-"(<literal>SessionFactory级别</literal>)的缓存。 你甚至可以为之插入一个集群的"
-"缓存。注意,缓存永远不知道其他应用程序对持久化仓库(数据库)可能进行的修改 "
-"(即使可以将缓存数据设定为定期失效)。"
+"Hibernate 的 <literal>Session</literal> 在事务级别进行持久化数据的缓存操作。 "
+"当然,也有可能分别为每个类(或集合),配置集群、或 JVM 级别"
+"(<literal>SessionFactory 级别</literal>)的缓存。你甚至可以为之插入一个集群"
+"的缓存。注意,缓存永远不知道其他应用程序对持久化仓库(数据库)可能进行的修改 "
+"(即使可以将缓存数据设定为定期失效)。 "
 
 #. Tag: para
-#: performance.xml:610
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You have the option to tell Hibernate which caching implementation to use by "
 "specifying the name of a class that implements <literal>org.hibernate.cache."
@@ -1160,269 +965,221 @@
 "can also implement your own and plug it in as outlined above. Note that "
 "versions prior to 3.2 use EhCache as the default cache provider."
 msgstr ""
-"通过在<literal>hibernate.cache.provider_class</literal>属性中指定"
-"<literal>org.hibernate.cache.CacheProvider</literal>的某个实现的类名,你可以选"
-"择让Hibernate使用哪个缓存实现。Hibernate打包一些开源缓存实现,提供对它们的内"
-"置支持(见下表)。除此之外,你也可以实现你自己的实现,将它们插入到系统中。注"
-"意,在3.2版本之前,默认使用EhCache 作为缓存实现,但从3.2起就不再这样了。"
+"通过在 <literal>hibernate.cache.provider_class</literal> 属性中指定  "
+"<literal>org.hibernate.cache.CacheProvider</literal> 的某个实现的类名,你可以"
+"选择让 Hibernate 使用哪个缓存实现。Hibernate 打包一些开源缓存实现,提供对它们"
+"的内置支持(见下表)。除此之外,你也可以实现你自己的实现,将它们插入到系统"
+"中。注意,在 3.2 版本之前,默认使用 EhCache 作为缓存实现,但从 3.2 起就不再这"
+"样了。 "
 
 #. Tag: title
-#: performance.xml:621
 #, no-c-format
 msgid "Cache Providers"
 msgstr "缓存策略提供商(Cache Providers)"
 
 #. Tag: entry
-#: performance.xml:630 performance.xml:818
 #, no-c-format
 msgid "Cache"
 msgstr "Cache"
 
 #. Tag: entry
-#: performance.xml:631
 #, no-c-format
 msgid "Provider class"
 msgstr "Provider class"
 
 #. Tag: entry
-#: performance.xml:632
 #, no-c-format
 msgid "Type"
 msgstr "Type"
 
 #. Tag: entry
-#: performance.xml:633
 #, no-c-format
 msgid "Cluster Safe"
 msgstr "Cluster Safe"
 
 #. Tag: entry
-#: performance.xml:634
 #, no-c-format
 msgid "Query Cache Supported"
 msgstr "Query Cache Supported"
 
 #. Tag: entry
-#: performance.xml:639 performance.xml:827
 #, no-c-format
 msgid "Hashtable (not intended for production use)"
-msgstr "Hashtable (not intended for production use)"
+msgstr "Hashtable (not intended for production use)"
 
-#. Tag: literal
-#: performance.xml:640
-#, no-c-format
-msgid "org.hibernate.cache.HashtableCacheProvider"
-msgstr "org.hibernate.cache.HashtableCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.HashtableCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.HashtableCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:641
 #, no-c-format
 msgid "memory"
 msgstr "memory"
 
 #. Tag: entry
-#: performance.xml:643 performance.xml:650 performance.xml:657
-#: performance.xml:828 performance.xml:829 performance.xml:830
-#: performance.xml:835 performance.xml:836 performance.xml:837
-#: performance.xml:842 performance.xml:843 performance.xml:844
-#: performance.xml:849 performance.xml:850 performance.xml:856
-#: performance.xml:859 performance.xml:863 performance.xml:866
 #, no-c-format
-msgid "<entry>yes</entry>"
-msgstr ""
+msgid "yes"
+msgstr "yes"
 
 #. Tag: entry
-#: performance.xml:646 performance.xml:834
 #, no-c-format
 msgid "EHCache"
 msgstr "EHCache"
 
-#. Tag: literal
-#: performance.xml:647
-#, no-c-format
-msgid "org.hibernate.cache.EhCacheProvider"
-msgstr "org.hibernate.cache.EhCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.EhCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.EhCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:648 performance.xml:655
 #, no-c-format
 msgid "memory, disk"
-msgstr "memory, disk"
+msgstr "memory,disk"
 
 #. Tag: entry
-#: performance.xml:653 performance.xml:841
 #, no-c-format
 msgid "OSCache"
 msgstr "OSCache"
 
-#. Tag: literal
-#: performance.xml:654
-#, no-c-format
-msgid "org.hibernate.cache.OSCacheProvider"
-msgstr "org.hibernate.cache.OSCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.OSCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.OSCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:660 performance.xml:848
 #, no-c-format
 msgid "SwarmCache"
 msgstr "SwarmCache"
 
-#. Tag: literal
-#: performance.xml:661
-#, no-c-format
-msgid "org.hibernate.cache.SwarmCacheProvider"
-msgstr "org.hibernate.cache.SwarmCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.SwarmCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.SwarmCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:662
 #, no-c-format
 msgid "clustered (ip multicast)"
 msgstr "clustered (ip multicast)"
 
 #. Tag: entry
-#: performance.xml:663
 #, no-c-format
 msgid "yes (clustered invalidation)"
 msgstr "yes (clustered invalidation)"
 
 #. Tag: entry
-#: performance.xml:667 performance.xml:855
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "JBoss Cache 1.x"
-msgstr "JBoss TreeCache"
+msgstr "JBoss Cache 1.x"
 
-#. Tag: literal
-#: performance.xml:668
-#, no-c-format
-msgid "org.hibernate.cache.TreeCacheProvider"
-msgstr "org.hibernate.cache.TreeCacheProvider"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>org.hibernate.cache.TreeCacheProvider</literal>"
+msgstr "<literal>org.hibernate.cache.TreeCacheProvider</literal>"
 
 #. Tag: entry
-#: performance.xml:669 performance.xml:676
 #, no-c-format
 msgid "clustered (ip multicast), transactional"
 msgstr "clustered (ip multicast), transactional"
 
 #. Tag: entry
-#: performance.xml:670
 #, no-c-format
 msgid "yes (replication)"
 msgstr "yes (replication)"
 
 #. Tag: entry
-#: performance.xml:671 performance.xml:678
 #, no-c-format
 msgid "yes (clock sync req.)"
 msgstr "yes (clock sync req.)"
 
 #. Tag: entry
-#: performance.xml:674 performance.xml:862
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "JBoss Cache 2"
-msgstr "JBoss TreeCache"
+msgstr "JBoss Cache 2"
 
-#. Tag: literal
-#: performance.xml:675
+#. Tag: entry
 #, fuzzy, no-c-format
-msgid "org.hibernate.cache.jbc.JBossCacheRegionFactory"
-msgstr "org.hibernate.cache.EhCacheProvider"
+msgid "<literal>org.hibernate.cache.jbc.JBossCacheRegionFactory</literal>"
+msgstr "<literal>org.hibernate.cache.jbc2.JBossCacheRegionFactory</literal>"
 
 #. Tag: entry
-#: performance.xml:677
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "yes (replication or invalidation)"
-msgstr "yes (clustered invalidation)"
+msgstr "yes (replication or invalidation)"
 
 #. Tag: title
-#: performance.xml:685
 #, no-c-format
 msgid "Cache mappings"
 msgstr "缓存映射(Cache mappings)"
 
 #. Tag: para
-#: performance.xml:687
 #, no-c-format
 msgid ""
 "The <literal>&lt;cache&gt;</literal> element of a class or collection "
 "mapping has the following form:"
-msgstr "类或者集合映射的“<literal>&lt;cache&gt;</literal>元素”可以有下列形式:"
-
-#. Tag: programlisting
-#: performance.xml:698
-#, no-c-format
-msgid ""
-"<![CDATA[<cache \n"
-"    usage=\"transactional|read-write|nonstrict-read-write|read-only\"\n"
-"    region=\"RegionName\"\n"
-"    include=\"all|non-lazy\"\n"
-"/>]]>"
 msgstr ""
+"类或者集合映射的“<literal>&lt;cache&gt;</literal> 元素”可以有下列形式:"
 
 #. Tag: para
-#: performance.xml:701
 #, no-c-format
 msgid ""
 "<literal>usage</literal> (required) specifies the caching strategy: "
 "<literal>transactional</literal>, <literal>read-write</literal>, "
 "<literal>nonstrict-read-write</literal> or <literal>read-only</literal>"
 msgstr ""
-"<literal>usage</literal>(必须)说明了缓存的策略: <literal>transactional</"
-"literal>、 <literal>read-write</literal>、 <literal>nonstrict-read-write</"
-"literal>或 <literal>read-only</literal>。"
+"<literal>usage</literal>(必须)说明了缓存的策略:<literal>transactional</"
+"literal>、 <literal>read-write</literal>、<literal>nonstrict-read-write</"
+"literal> 或 <literal>read-only</literal>。"
 
 #. Tag: para
-#: performance.xml:710
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>region</literal> (optional: defaults to the class or collection "
 "role name): specifies the name of the second level cache region"
 msgstr ""
-"<literal>region</literal> (可选, 默认为类或者集合的名字(class or collection "
-"role name)) 指定第二级缓存的区域名(name of the second level cache region)"
+"<literal>region</literal> (可选,默认为类或者集合的名字(class or "
+"collection role name)) 指定第二级缓存的区域名(name of the second level "
+"cache region) "
 
 #. Tag: para
-#: performance.xml:717
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>include</literal> (optional: defaults to <literal>all</literal>) "
 "<literal>non-lazy</literal>: specifies that properties of the entity mapped "
 "with <literal>lazy=\"true\"</literal> cannot be cached when attribute-level "
 "lazy fetching is enabled"
 msgstr ""
-"<literal>include</literal> (可选,默认为 <literal>all</literal>) <literal>non-"
-"lazy</literal> 当属性级延迟抓取打开时, 标记为<literal>lazy=\"true\"</literal>"
-"的实体的属性可能无法被缓存"
+"<literal>include</literal>(可选,默认为 <literal>all</literal>) "
+"<literal>non-lazy</literal> 当属性级延迟抓取打开时,标记为 <literal>lazy="
+"\"true\"</literal> 的实体的属性可能无法被缓存 "
 
 #. Tag: para
-#: performance.xml:727
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, you can specify <literal>&lt;class-cache&gt;</literal> and "
 "<literal>&lt;collection-cache&gt;</literal> elements in <literal>hibernate."
 "cfg.xml</literal>."
 msgstr ""
-"另外(首选?), 你可以在hibernate.cfg.xml中指定<literal>&lt;class-cache&gt;</"
-"literal>和 <literal>&lt;collection-cache&gt;</literal> 元素。"
+"另外(首选?),你可以在<literal>hibernate.cfg.xml</literal> 中指定 "
+"<literal>&lt;class-cache&gt;</literal> 和 <literal>&lt;collection-cache&gt;</"
+"literal> 元素。"
 
 #. Tag: para
-#: performance.xml:732
 #, no-c-format
 msgid ""
 "The <literal>usage</literal> attribute specifies a <emphasis>cache "
 "concurrency strategy</emphasis>."
 msgstr ""
-"这里的<literal>usage</literal> 属性指明了<emphasis>缓存并发策略(cache "
+"这里的 <literal>usage</literal> 属性指明了<emphasis>缓存并发策略(cache "
 "concurrency strategy)</emphasis>。"
 
 #. Tag: title
-#: performance.xml:739
 #, no-c-format
 msgid "Strategy: read only"
-msgstr "策略:只读缓存(Strategy: read only)"
+msgstr "策略:只读缓存(Strategy:read only)"
 
 #. Tag: para
-#: performance.xml:741
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your application needs to read, but not modify, instances of a persistent "
 "class, a <literal>read-only</literal> cache can be used. This is the "
@@ -1431,27 +1188,15 @@
 msgstr ""
 "如果你的应用程序只需读取一个持久化类的实例,而无需对其修改, 那么就可以对其进"
 "行<literal>只读</literal> 缓存。这是最简单,也是实用性最好的方法。甚至在集群"
-"中,它也能完美地运作。"
+"中,它也能完美地运作。 "
 
-#. Tag: programlisting
-#: performance.xml:747
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Immutable\" mutable=\"false\">\n"
-"    <cache usage=\"read-only\"/>\n"
-"    ....\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:753
 #, no-c-format
 msgid "Strategy: read/write"
-msgstr "策略:读/写缓存(Strategy: read/write)"
+msgstr "策略:读写/缓存(Strategy:read/write)"
 
 #. Tag: para
-#: performance.xml:755
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the application needs to update data, a <literal>read-write</literal> "
 "cache might be appropriate. This cache strategy should never be used if "
@@ -1467,37 +1212,21 @@
 msgstr ""
 "如果应用程序需要更新数据,那么使用<literal>读/写缓存</literal> 比较合适。 如"
 "果应用程序要求“序列化事务”的隔离级别(serializable transaction isolation "
-"level),那么就决不能使用这种缓存策略。 如果在JTA环境中使用缓存,你必须指定"
-"<literal>hibernate.transaction.manager_lookup_class</literal>属性的值, 通过"
-"它,Hibernate才能知道该应用程序中JTA的<literal>TransactionManager</literal>的"
-"具体策略。 在其它环境中,你必须保证在<literal>Session.close()</literal>、或"
-"<literal>Session.disconnect()</literal>调用前, 整个事务已经结束。 如果你想在"
-"集群环境中使用此策略,你必须保证底层的缓存实现支持锁定(locking)。Hibernate内"
-"置的缓存策略并不支持锁定功能。"
+"level),那么就决不能使用这种缓存策略。 如果在 JTA 环境中使用缓存,你必须指"
+"定 <literal>hibernate.transaction.manager_lookup_class</literal> 属性的值, "
+"通过它,Hibernate 才能知道该应用程序中 JTA 的<literal>TransactionManager</"
+"literal>的具体策略。 在其它环境中,你必须保证在 <literal>Session.close()</"
+"literal>、或 <literal>Session.disconnect()</literal> 调用前, 整个事务已经结"
+"束。 如果你想在集群环境中使用此策略,你必须保证底层的缓存实现支持锁定"
+"(locking)。Hibernate 内置的缓存策略并不支持锁定功能。 "
 
-#. Tag: programlisting
-#: performance.xml:766
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"eg.Cat\" .... >\n"
-"    <cache usage=\"read-write\"/>\n"
-"    ....\n"
-"    <set name=\"kittens\" ... >\n"
-"        <cache usage=\"read-write\"/>\n"
-"        ....\n"
-"    </set>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:771
 #, no-c-format
 msgid "Strategy: nonstrict read/write"
-msgstr "策略:非严格读/写缓存(Strategy: nonstrict read/write)"
+msgstr "策略:非严格读/写缓存(Strategy:nonstrict read/write)"
 
 #. Tag: para
-#: performance.xml:773
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the application only occasionally needs to update data (i.e. if it is "
 "extremely unlikely that two transactions would try to update the same item "
@@ -1509,97 +1238,84 @@
 "</literal> or <literal>Session.disconnect()</literal> is called."
 msgstr ""
 "如果应用程序只偶尔需要更新数据(也就是说,两个事务同时更新同一记录的情况很不"
-"常见),也不需要十分严格的事务隔离, 那么比较适合使用<literal>非严格读/写缓存"
-"</literal>策略。如果在JTA环境中使用该策略, 你必须为其指定<literal>hibernate."
-"transaction.manager_lookup_class</literal>属性的值, 在其它环境中,你必须保证"
-"在<literal>Session.close()</literal>、或<literal>Session.disconnect()</"
-"literal>调用前, 整个事务已经结束。"
+"常见),也不需要十分严格的事务隔离,那么比较适合使用<literal>非严格读/写缓存"
+"</literal>策略。如果在 JTA 环境中使用该策略,你必须为其指定 "
+"<literal>hibernate.transaction.manager_lookup_class</literal> 属性的值,在其"
+"它环境中,你必须保证在<literal>Session.close()</literal>、或 "
+"<literal>Session.disconnect()</literal> 调用前,整个事务已经结束。 "
 
 #. Tag: title
-#: performance.xml:785
 #, no-c-format
 msgid "Strategy: transactional"
-msgstr "策略:事务缓存(transactional)"
+msgstr "策略:事务缓存(transactional)"
 
 #. Tag: para
-#: performance.xml:787
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>transactional</literal> cache strategy provides support for "
 "fully transactional cache providers such as JBoss TreeCache. Such a cache "
 "can only be used in a JTA environment and you must specify "
 "<literal>hibernate.transaction.manager_lookup_class</literal>."
 msgstr ""
-"Hibernate的<literal>事务缓存</literal>策略提供了全事务的缓存支持, 例如对"
-"JBoss TreeCache的支持。这样的缓存只能用于JTA环境中,你必须指定 为其"
-"<literal>hibernate.transaction.manager_lookup_class</literal>属性。"
+"Hibernate 的<literal>事务缓存</literal>策略提供了全事务的缓存支持,例如对 "
+"JBoss TreeCache 的支持。这样的缓存只能用于 JTA 环境中,你必须指定为其  "
+"<literal>hibernate.transaction.manager_lookup_class</literal> 属性。 "
 
 #. Tag: title
-#: performance.xml:796
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Cache-provider/concurrency-strategy compatibility"
-msgstr ""
-"各种缓存提供商对缓存并发策略的支持情况(Cache Concurrency Strategy Support)"
+msgstr "各种缓存提供商/缓存并发策略的兼容性"
 
 #. Tag: para
-#: performance.xml:799
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "None of the cache providers support all of the cache concurrency strategies."
 msgstr ""
 "没有一种缓存提供商能够支持上列的所有缓存并发策略。下表中列出了各种提供器、及"
-"其各自适用的并发策略。"
+"其各自适用的并发策略。 "
 
 #. Tag: para
-#: performance.xml:804
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table shows which providers are compatible with which "
 "concurrency strategies."
 msgstr ""
 "没有一种缓存提供商能够支持上列的所有缓存并发策略。下表中列出了各种提供器、及"
-"其各自适用的并发策略。"
+"其各自适用的并发策略。 "
 
 #. Tag: title
-#: performance.xml:809
 #, no-c-format
 msgid "Cache Concurrency Strategy Support"
 msgstr ""
 "各种缓存提供商对缓存并发策略的支持情况(Cache Concurrency Strategy Support)"
 
 #. Tag: entry
-#: performance.xml:819
 #, no-c-format
 msgid "read-only"
 msgstr "read-only"
 
 #. Tag: entry
-#: performance.xml:820
 #, no-c-format
 msgid "nonstrict-read-write"
 msgstr "nonstrict-read-write"
 
 #. Tag: entry
-#: performance.xml:821
 #, no-c-format
 msgid "read-write"
 msgstr "read-write"
 
 #. Tag: entry
-#: performance.xml:822
 #, no-c-format
 msgid "transactional"
 msgstr "transactional"
 
 #. Tag: title
-#: performance.xml:877
 #, no-c-format
 msgid "Managing the caches"
 msgstr "管理缓存(Managing the caches)"
 
 #. Tag: para
-#: performance.xml:879
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Whenever you pass an object to <literal>save()</literal>, <literal>update()</"
 "literal> or <literal>saveOrUpdate()</literal>, and whenever you retrieve an "
@@ -1608,15 +1324,14 @@
 "</literal>, that object is added to the internal cache of the "
 "<literal>Session</literal>."
 msgstr ""
-"无论何时,当你给<literal>save()</literal>、<literal>update()</literal>或 "
-"<literal>saveOrUpdate()</literal>方法传递一个对象时,或使用<literal>load()</"
-"literal>、 <literal>get()</literal>、<literal>list()</literal>、"
-"<literal>iterate()</literal> 或<literal>scroll()</literal>方法获得一个对象"
-"时, 该对象都将被加入到<literal>Session</literal>的内部缓存中。"
+"无论何时,当你给 <literal>save()</literal>、<literal>update()</literal> 或  "
+"<literal>saveOrUpdate()</literal> 方法传递一个对象时,或使用 <literal>load()"
+"</literal>、<literal>get()</literal>、<literal>list()</literal>、"
+"<literal>iterate()</literal> 或 <literal>scroll()</literal> 方法获得一个对象"
+"时,该对象都将被加入到 <literal>Session</literal> 的内部缓存中。 "
 
 #. Tag: para
-#: performance.xml:886
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When <literal>flush()</literal> is subsequently called, the state of that "
 "object will be synchronized with the database. If you do not want this "
@@ -1625,118 +1340,85 @@
 "can be used to remove the object and its collections from the first-level "
 "cache."
 msgstr ""
-"当随后flush()方法被调用时,对象的状态会和数据库取得同步。 如果你不希望此同步"
-"操作发生,或者你正处理大量对象、需要对有效管理内存时,你可以调用"
-"<literal>evict()</literal> 方法,从一级缓存中去掉这些对象及其集合。"
+"当随后 flush() 方法被调用时,对象的状态会和数据库取得同步。如果你不希望此同步"
+"操作发生,或者你正处理大量对象、需要对有效管理内存时,你可以调用 "
+"<literal>evict()</literal> 方法,从一级缓存中去掉这些对象及其集合。 "
 
-#. Tag: programlisting
-#: performance.xml:894
-#, no-c-format
-msgid ""
-"<![CDATA[ScrollableResult cats = sess.createQuery(\"from Cat as cat\").scroll"
-"(); //a huge result set\n"
-"while ( cats.next() ) {\n"
-"    Cat cat = (Cat) cats.get(0);\n"
-"    doSomethingWithACat(cat);\n"
-"    sess.evict(cat);\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: performance.xml:896
 #, no-c-format
 msgid ""
 "The <literal>Session</literal> also provides a <literal>contains()</literal> "
 "method to determine if an instance belongs to the session cache."
 msgstr ""
-"Session还提供了一个<literal>contains()</literal>方法,用来判断某个实例是否处"
-"于当前session的缓存中。"
+"Session 还提供了一个 <literal>contains()</literal> 方法,用来判断某个实例是否"
+"处于当前 session 的缓存中。"
 
 #. Tag: para
-#: performance.xml:901
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To evict all objects from the session cache, call <literal>Session.clear()</"
 "literal>"
 msgstr ""
-"如若要把所有的对象从session缓存中彻底清除,则需要调用<literal>Session.clear()"
-"</literal>。"
+"如若要把所有的对象从 session 缓存中彻底清除,则需要调用 <literal>Session."
+"clear()</literal>。 "
 
 #. Tag: para
-#: performance.xml:905
 #, no-c-format
 msgid ""
 "For the second-level cache, there are methods defined on "
 "<literal>SessionFactory</literal> for evicting the cached state of an "
 "instance, entire class, collection instance or entire collection role."
 msgstr ""
-"对于二级缓存来说,在<literal>SessionFactory</literal>中定义了许多方法, 清除"
+"对于二级缓存来说,在 <literal>SessionFactory</literal> 中定义了许多方法,清除"
 "缓存中实例、整个类、集合实例或者整个集合。"
 
-#. Tag: programlisting
-#: performance.xml:911
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sessionFactory.evict(Cat.class, catId); //evict a particular Cat\n"
-"sessionFactory.evict(Cat.class);  //evict all Cats\n"
-"sessionFactory.evictCollection(\"Cat.kittens\", catId); //evict a particular "
-"collection of kittens\n"
-"sessionFactory.evictCollection(\"Cat.kittens\"); //evict all kitten "
-"collections]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:913
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>CacheMode</literal> controls how a particular session interacts "
 "with the second-level cache:"
 msgstr ""
-"<literal>CacheMode</literal>参数用于控制具体的Session如何与二级缓存进行交互。"
+"<literal>CacheMode</literal> 参数用于控制具体的 Session 如何与二级缓存进行交"
+"互。 "
 
 #. Tag: para
-#: performance.xml:920
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.NORMAL</literal>: will read items from and write items to "
 "the second-level cache"
-msgstr "<literal>CacheMode.NORMAL</literal> - 从二级缓存中读、写数据。"
+msgstr "<literal>CacheMode.NORMAL</literal>:从二级缓存中读、写数据。"
 
 #. Tag: para
-#: performance.xml:925
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.GET</literal>: will read items from the second-level "
 "cache. Do not write to the second-level cache except when updating data"
 msgstr ""
-"<literal>CacheMode.GET</literal> - 从二级缓存中读取数据,仅在数据更新时对二级"
+"<literal>CacheMode.GET</literal>:从二级缓存中读取数据,仅在数据更新时对二级"
 "缓存写数据。"
 
 #. Tag: para
-#: performance.xml:931
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.PUT</literal>: will write items to the second-level "
 "cache. Do not read from the second-level cache"
 msgstr ""
-"<literal>CacheMode.PUT</literal> - 仅向二级缓存写数据,但不从二级缓存中读数"
+"<literal>CacheMode.PUT</literal>:仅向二级缓存写数据,但不从二级缓存中读数"
 "据。"
 
 #. Tag: para
-#: performance.xml:937
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>CacheMode.REFRESH</literal>: will write items to the second-level "
 "cache. Do not read from the second-level cache. Bypass the effect of "
 "<literal>hibernate.cache.use_minimal_puts</literal> forcing a refresh of the "
 "second-level cache for all items read from the database"
 msgstr ""
-"<literal>CacheMode.REFRESH</literal> - 仅向二级缓存写数据,但不从二级缓存中读"
-"数据。通过 <literal>hibernate.cache.use_minimal_puts</literal>的设置,强制二"
+"<literal>CacheMode.REFRESH</literal>:仅向二级缓存写数据,但不从二级缓存中读"
+"数据。通过 <literal>hibernate.cache.use_minimal_puts</literal> 的设置,强制二"
 "级缓存从数据库中读取数据,刷新缓存内容。"
 
 #. Tag: para
-#: performance.xml:945
 #, no-c-format
 msgid ""
 "To browse the contents of a second-level or query cache region, use the "
@@ -1745,176 +1427,178 @@
 "如若需要查看二级缓存或查询缓存区域的内容,你可以使用<literal>统计"
 "(Statistics)</literal> API。"
 
-#. Tag: programlisting
-#: performance.xml:950
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Map cacheEntries = sessionFactory.getStatistics()\n"
-"        .getSecondLevelCacheStatistics(regionName)\n"
-"        .getEntries();]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:952
-#, fuzzy, no-c-format
-msgid ""
 "You will need to enable statistics and, optionally, force Hibernate to keep "
 "the cache entries in a more readable format:"
 msgstr ""
-"此时,你必须手工打开统计选项。可选的,你可以让Hibernate更人工可读的方式维护缓"
-"存内容。"
+"此时,你必须手工打开统计选项。可选的,你可以让 Hibernate 更人工可读的方式维护"
+"缓存内容。 "
 
-#. Tag: programlisting
-#: performance.xml:957
-#, no-c-format
-msgid ""
-"<![CDATA[hibernate.generate_statistics true\n"
-"hibernate.cache.use_structured_entries true]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:962
 #, no-c-format
 msgid "The Query Cache"
 msgstr "查询缓存(The Query Cache)"
 
 #. Tag: para
-#: performance.xml:964
 #, fuzzy, no-c-format
 msgid ""
 "Query result sets can also be cached. This is only useful for queries that "
-"are run frequently with the same parameters. You will first need to enable "
-"the query cache:"
+"are run frequently with the same parameters."
 msgstr ""
 "查询的结果集也可以被缓存。只有当经常使用同样的参数进行查询时,这才会有些用"
-"处。 要使用查询缓存,首先你必须打开它:"
+"处。要使用查询缓存,首先你必须打开它: "
 
-#. Tag: programlisting
-#: performance.xml:969
+#. Tag: title
 #, no-c-format
-msgid "<![CDATA[hibernate.cache.use_query_cache true]]>"
+msgid "Enabling query caching"
 msgstr ""
 
 #. Tag: para
-#: performance.xml:971
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
-"This setting creates two new cache regions: one holding cached query result "
-"sets (<literal>org.hibernate.cache.StandardQueryCache</literal>), the other "
-"holding timestamps of the most recent updates to queryable tables "
-"(<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). Note that "
-"the query cache does not cache the state of the actual entities in the "
-"result set; it caches only identifier values and results of value type. The "
-"query cache should always be used in conjunction with the second-level cache."
+"Caching of query results introduces some overhead in terms of your "
+"applications normal transactional processing. For example, if you cache "
+"results of a query against Person Hibernate will need to keep track of when "
+"those results should be invalidated because changes have been committed "
+"against Person. That, coupled with the fact that most applications simply "
+"gain no benefit from caching query results, leads Hibernate to disable "
+"caching of query results by default. To use query caching, you will first "
+"need to enable the query cache:"
 msgstr ""
-"该设置将会创建两个缓存区域 - 一个用于保存查询结果集(<literal>org.hibernate."
-"cache.StandardQueryCache</literal>); 另一个则用于保存最近查询的一系列表的时"
-"间戳(<literal>org.hibernate.cache.UpdateTimestampsCache</literal>)。 请注意:"
-"在查询缓存中,它并不缓存结果集中所包含的实体的确切状态;它只缓存这些实体的标"
-"识符属性的值、以及各值类型的结果。 所以查询缓存通常会和二级缓存一起使用。"
 
 #. Tag: para
-#: performance.xml:981
-#, fuzzy, no-c-format
+#, no-c-format
+msgid "This setting creates two new cache regions:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
 msgid ""
-"Most queries do not benefit from caching, so by default, queries are not "
-"cached. To enable caching, call <literal>Query.setCacheable(true)</literal>. "
-"This call allows the query to look for existing cache results or add its "
-"results to the cache when it is executed."
+"<classname>org.hibernate.cache.StandardQueryCache</classname>, holding the "
+"cached query results"
 msgstr ""
-"绝大多数的查询并不能从查询缓存中受益,所以Hibernate默认是不进行查询缓存的。如"
-"若需要进行缓存,请调用 <literal>Query.setCacheable(true)</literal>方法。这个"
-"调用会让查询在执行过程中时先从缓存中查找结果, 并将自己的结果集放到缓存中去。"
 
 #. Tag: para
-#: performance.xml:988
+#, no-c-format
+msgid ""
+"<classname>org.hibernate.cache.UpdateTimestampsCache</classname>, holding "
+"timestamps of the most recent updates to queryable tables. These are used to "
+"validate the results as they are served from the query cache."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"If you configure your underlying cache implementation to use expiry or "
+"timeouts is is very important that the cache timeout of the underlying cache "
+"region for the UpdateTimestampsCache be set to a higher value than the "
+"timeouts of any of the query caches. In fact, we recommend that the the "
+"UpdateTimestampsCache region not be configured for expiry at all. Note, in "
+"particular, that an LRU cache expiry policy is never appropriate."
+msgstr ""
+
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
-"If you require fine-grained control over query cache expiration policies, "
-"you can specify a named cache region for a particular query by calling "
-"<literal>Query.setCacheRegion()</literal>."
+"As mentioned above, most queries do not benefit from caching or their "
+"results. So by default, individual queries are not cached even after "
+"enabling query caching. To enable results caching for a particular query, "
+"call <literal>org.hibernate.Query.setCacheable(true)</literal>. This call "
+"allows the query to look for existing cache results or add its results to "
+"the cache when it is executed."
 msgstr ""
-"如果你要对查询缓存的失效政策进行精确的控制,你必须调用<literal>Query."
-"setCacheRegion()</literal>方法, 为每个查询指定其命名的缓存区域。"
+"绝大多数的查询并不能从查询缓存中受益,所以 Hibernate 默认是不进行查询缓存的。"
+"如若需要进行缓存,请调用 <literal>Query.setCacheable(true)</literal>方法。"
+"这个调用会让查询在执行过程中时先从缓存中查找结果,并将自己的结果集放到缓存中"
+"去。 "
 
-#. Tag: programlisting
-#: performance.xml:994
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List blogs = sess.createQuery(\"from Blog blog where blog.blogger "
-"= :blogger\")\n"
-"    .setEntity(\"blogger\", blogger)\n"
-"    .setMaxResults(15)\n"
-"    .setCacheable(true)\n"
-"    .setCacheRegion(\"frontpages\")\n"
-"    .list();]]>"
+"The query cache does not cache the state of the actual entities in the "
+"cache; it caches only identifier values and results of value type. For this "
+"reaso, the query cache should always be used in conjunction with the second-"
+"level cache for those entities expected to be cached as part of a query "
+"result cache (just as with collection caching)."
 msgstr ""
 
+#. Tag: title
+#, fuzzy, no-c-format
+msgid "Query cache regions"
+msgstr "Query Cache Supported"
+
 #. Tag: para
-#: performance.xml:996
 #, no-c-format
 msgid ""
-"If the query should force a refresh of its query cache region, you should "
-"call <literal>Query.setCacheMode(CacheMode.REFRESH)</literal>. This is "
-"particularly useful in cases where underlying data may have been updated via "
-"a separate process (i.e., not modified through Hibernate) and allows the "
-"application to selectively refresh particular query result sets. This is a "
-"more efficient alternative to eviction of a query cache region via "
-"<literal>SessionFactory.evictQueries()</literal>."
+"If you require fine-grained control over query cache expiration policies, "
+"you can specify a named cache region for a particular query by calling "
+"<literal>Query.setCacheRegion()</literal>."
 msgstr ""
-"如果查询需要强行刷新其查询缓存区域,那么你应该调用<literal>Query.setCacheMode"
-"(CacheMode.REFRESH)</literal>方法。 这对在其他进程中修改底层数据(例如,不通"
-"过Hibernate修改数据),或对那些需要选择性更新特定查询结果集的情况特别有用。 "
-"这是对<literal>SessionFactory.evictQueries()</literal>的更为有效的替代方案,"
-"同样可以清除查询缓存区域。"
+"如果你要对查询缓存的失效政策进行精确的控制,你必须调用 <literal>Query."
+"setCacheRegion()</literal> 方法,为每个查询指定其命名的缓存区域。 "
 
+#. Tag: para
+#, fuzzy, no-c-format
+msgid ""
+"If you want to force the query cache to refresh one of its regions "
+"(disregard any cached results it finds there) you can use <literal>org."
+"hibernate.Query.setCacheMode(CacheMode.REFRESH)</literal>. In conjunction "
+"with the region you have defined for the given query, Hibernate will "
+"selectively force the results cached in that particular region to be "
+"refreshed. This is particularly useful in cases where underlying data may "
+"have been updated via a separate process and is a far more efficient "
+"alternative to bulk eviction of the region via <literal>org.hibernate."
+"SessionFactory.evictQueries()</literal>."
+msgstr ""
+"如果查询需要强行刷新其查询缓存区域,那么你应该调用 <literal>Query."
+"setCacheMode(CacheMode.REFRESH)</literal>方法。 这对在其他进程中修改底层数"
+"据(例如,不通过Hibernate修改数据),或对那些需要选择性更新特定查询结果集的情"
+"况特别有用。 这是对 <literal>SessionFactory.evictQueries()</literal> 的更为有"
+"效的替代方案,同样可以清除查询缓存区域。"
+
 #. Tag: title
-#: performance.xml:1008
 #, no-c-format
 msgid "Understanding Collection performance"
 msgstr "理解集合性能(Understanding Collection performance)"
 
 #. Tag: para
-#: performance.xml:1010
 #, no-c-format
 msgid ""
 "In the previous sections we have covered collections and their applications. "
 "In this section we explore some more issues in relation to collections at "
 "runtime."
 msgstr ""
+"在前面的章节里我们已经讨论了集合和相关应用程序。在本节我么将探索运行时集合的"
+"更多问题。"
 
 #. Tag: title
-#: performance.xml:1017
 #, no-c-format
 msgid "Taxonomy"
 msgstr "分类(Taxonomy)"
 
 #. Tag: para
-#: performance.xml:1019
 #, no-c-format
 msgid "Hibernate defines three basic kinds of collections:"
-msgstr "Hibernate定义了三种基本类型的集合:"
+msgstr "Hibernate 定义了三种基本类型的集合:"
 
 #. Tag: para
-#: performance.xml:1023
 #, no-c-format
 msgid "collections of values"
 msgstr "值数据集合"
 
 #. Tag: para
-#: performance.xml:1026
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "one-to-many associations"
-msgstr "一对多关联"
+msgstr "一对多关联(One-to-many Associations) "
 
 #. Tag: para
-#: performance.xml:1029
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "many-to-many associations"
-msgstr "多对多关联"
+msgstr "多对多关联 "
 
 #. Tag: para
-#: performance.xml:1033
 #, no-c-format
 msgid ""
 "This classification distinguishes the various table and foreign key "
@@ -1925,30 +1609,26 @@
 "This suggests the following classification:"
 msgstr ""
 "这个分类是区分了不同的表和外键关系类型,但是它没有告诉我们关系模型的所有内"
-"容。 要完全理解他们的关系结构和性能特点,我们必须同时考虑“用于Hibernate更新或"
-"删除集合行数据的主键的结构”。 因此得到了如下的分类:"
+"容。 要完全理解他们的关系结构和性能特点,我们必须同时考虑“用于 Hibernate 更新"
+"或删除集合行数据的主键的结构”。因此得到了如下的分类:"
 
 #. Tag: para
-#: performance.xml:1044
 #, no-c-format
 msgid "indexed collections"
 msgstr "有序集合类"
 
 #. Tag: para
-#: performance.xml:1047
 #, no-c-format
 msgid "sets"
 msgstr "集合(sets)"
 
 #. Tag: para
-#: performance.xml:1050
 #, no-c-format
 msgid "bags"
-msgstr "包(bags)"
+msgstr "包(bags)"
 
 #. Tag: para
-#: performance.xml:1054
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "All indexed collections (maps, lists, and arrays) have a primary key "
 "consisting of the <literal>&lt;key&gt;</literal> and <literal>&lt;index&gt;</"
@@ -1956,14 +1636,13 @@
 "The primary key can be efficiently indexed and a particular row can be "
 "efficiently located when Hibernate tries to update or delete it."
 msgstr ""
-"所有的有序集合类(maps, lists, arrays)都拥有一个由<literal>&lt;key&gt;</"
-"literal>和 <literal>&lt;index&gt;</literal>组成的主键。 这种情况下集合类的更"
-"新是非常高效的——主键已经被有效的索引,因此当Hibernate试图更新或删除一行时,可"
-"以迅速找到该行数据。"
+"所有的有序集合类(maps,lists,arrays)都拥有一个由 <literal>&lt;key&gt;</"
+"literal> 和 <literal>&lt;index&gt;</literal> 组成的主键。这种情况下集合类的更"
+"新是非常高效的 — 主键已经被有效的索引,因此当 Hibernate 试图更新或删除一行"
+"时,可以迅速找到该行数据。 "
 
 #. Tag: para
-#: performance.xml:1062
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sets have a primary key consisting of <literal>&lt;key&gt;</literal> and "
 "element columns. This can be less efficient for some types of collection "
@@ -1975,26 +1654,24 @@
 "<literal>&lt;set&gt;</literal>, you must declare all columns as <literal>not-"
 "null=\"true\"</literal>."
 msgstr ""
-"集合(sets)的主键由<literal>&lt;key&gt;</literal>和其他元素字段构成。 对于有些"
-"元素类型来说,这很低效,特别是组合元素或者大文本、大二进制字段; 数据库可能无"
-"法有效的对复杂的主键进行索引。 另一方面,对于一对多、多对多关联,特别是合成的"
-"标识符来说,集合也可以达到同样的高效性能。( 附注:如果你希望"
-"<literal>SchemaExport</literal>为你的<literal>&lt;set&gt;</literal>创建主"
-"键, 你必须把所有的字段都声明为<literal>not-null=\"true\"</literal>。)"
+"集合(sets)的主键由 <literal>&lt;key&gt;</literal> 和其他元素字段构成。对于"
+"有些元素类型来说,这很低效,特别是组合元素或者大文本、大二进制字段;数据库可"
+"能无法有效的对复杂的主键进行索引。另一方面,对于一对多、多对多关联,特别是合"
+"成的标识符来说,集合也可以达到同样的高效性能。( 附注:如果你希望 "
+"<literal>SchemaExport</literal> 为你的 <literal>&lt;set&gt;</literal> 创建主"
+"键,你必须把所有的字段都声明为 <literal>not-null=\"true\"</literal>。) "
 
 #. Tag: para
-#: performance.xml:1073
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>&lt;idbag&gt;</literal> mappings define a surrogate key, so they "
 "are efficient to update. In fact, they are the best case."
 msgstr ""
-"<literal>&lt;idbag&gt;</literal>映射定义了代理键,因此它总是可以很高效的被更"
-"新。事实上, <literal>&lt;idbag&gt;</literal>拥有着最好的性能表现。"
+"<literal>&lt;idbag&gt;</literal> 映射定义了代理键,因此它总是可以很高效的被更"
+"新。事实上,<literal>&lt;idbag&gt;</literal> 拥有着最好的性能表现。 "
 
 #. Tag: para
-#: performance.xml:1078
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Bags are the worst case since they permit duplicate element values and, as "
 "they have no index column, no primary key can be defined. Hibernate has no "
@@ -2002,45 +1679,41 @@
 "problem by completely removing in a single <literal>DELETE</literal> and "
 "recreating the collection whenever it changes. This can be inefficient."
 msgstr ""
-"Bag是最差的。因为bag允许重复的元素值,也没有索引字段,因此不可能定义主键。 "
-"Hibernate无法判断出重复的行。当这种集合被更改时,Hibernate将会先完整地移除 "
-"(通过一个(in a single <literal>DELETE</literal>))整个集合,然后再重新创建整"
-"个集合。 因此Bag是非常低效的。"
+"Bag 是最差的。因为 bag 允许重复的元素值,也没有索引字段,因此不可能定义主"
+"键。 Hibernate 无法判断出重复的行。当这种集合被更改时,Hibernate 将会先完整地"
+"移除 (通过一个(in a single <literal>DELETE</literal>))整个集合,然后再重"
+"新创建整个集合。因此 Bag 是非常低效的。 "
 
 #. Tag: para
-#: performance.xml:1086
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For a one-to-many association, the \"primary key\" may not be the physical "
 "primary key of the database table. Even in this case, the above "
 "classification is still useful. It reflects how Hibernate \"locates\" "
 "individual rows of the collection."
 msgstr ""
-"请注意:对于一对多关联来说,“主键”很可能并不是数据库表的物理主键。 但就算在此"
-"情况下,上面的分类仍然是有用的。(它仍然反映了Hibernate在集合的各数据行中是如"
-"何进行“定位”的。)"
+"请注意:对于一对多关联来说,“主键”很可能并不是数据库表的物理主键。但就算在此"
+"情况下,上面的分类仍然是有用的。(它仍然反映了 Hibernate 在集合的各数据行中是"
+"如何进行“定位”的。) "
 
 #. Tag: title
-#: performance.xml:1096
 #, no-c-format
 msgid ""
 "Lists, maps, idbags and sets are the most efficient collections to update"
-msgstr "Lists, maps 和sets用于更新效率最高"
+msgstr "Lists,maps 和 sets 用于更新效率最高"
 
 #. Tag: para
-#: performance.xml:1098
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "From the discussion above, it should be clear that indexed collections and "
 "sets allow the most efficient operation in terms of adding, removing and "
 "updating elements."
 msgstr ""
-"根据我们上面的讨论,显然有序集合类型和大多数set都可以在增加、删除、修改元素中"
-"拥有最好的性能。"
+"根据我们上面的讨论,显然有序集合类型和大多数 set 都可以在增加、删除、修改元素"
+"中拥有最好的性能。 "
 
 #. Tag: para
-#: performance.xml:1104
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is, arguably, one more advantage that indexed collections have over "
 "sets for many-to-many associations or collections of values. Because of the "
@@ -2050,15 +1723,14 @@
 "literal> of individual rows. Once again, this consideration does not apply "
 "to one-to-many associations."
 msgstr ""
-"可论证的是对于多对多关联、值数据集合而言,有序集合类比集合(set)有一个好处。因"
-"为<literal>Set</literal>的内在结构, 如果“改变”了一个元素,Hibernate并不会"
-"<literal>更新(UPDATE)</literal>这一行。 对于<literal>Set</literal>来说,只"
-"有在<literal>插入(INSERT)</literal>和<literal>删除(DELETE)</literal> 操作"
-"时“改变”才有效。再次强调:这段讨论对“一对多关联”并不适用。"
+"可论证的是对于多对多关联、值数据集合而言,有序集合类比集合(set)有一个好处。"
+"因为 <literal>Set</literal> 的内在结构, 如果“改变”了一个元素,Hibernate 并不"
+"会<literal>更新(UPDATE)</literal>这一行。对于 <literal>Set</literal> 来说,"
+"只有在<literal>插入(INSERT)</literal>和<literal>删除(DELETE)</literal> 操"
+"作时“改变”才有效。再次强调:这段讨论对“一对多关联”并不适用。 "
 
 #. Tag: para
-#: performance.xml:1113
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "After observing that arrays cannot be lazy, you can conclude that lists, "
 "maps and idbags are the most performant (non-inverse) collection types, with "
@@ -2066,13 +1738,12 @@
 "collection in Hibernate applications. This is because the \"set\" semantics "
 "are most natural in the relational model."
 msgstr ""
-"注意到数组无法延迟载入,我们可以得出结论,list, map和idbags是最高效的(非反"
-"向)集合类型,set则紧随其后。 在Hibernate中,set应该时最通用的集合类型,这时"
-"因为“set”的语义在关系模型中是最自然的。"
+"注意到数组无法延迟载入,我们可以得出结论,list,map 和 idbags 是最高效的(非"
+"反向)集合类型,set 则紧随其后。 在 Hibernate 中,set 应该时最通用的集合类"
+"型,这时因为“set”的语义在关系模型中是最自然的。 "
 
 #. Tag: para
-#: performance.xml:1121
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, in well-designed Hibernate domain models, most collections are in "
 "fact one-to-many associations with <literal>inverse=\"true\"</literal>. For "
@@ -2080,19 +1751,17 @@
 "association, and so considerations of collection update performance simply "
 "do not apply."
 msgstr ""
-"但是,在设计良好的Hibernate领域模型中,我们通常可以看到更多的集合事实上是带有"
-"<literal>inverse=\"true\"</literal> 的一对多的关联。对于这些关联,更新操作将"
-"会在多对一的这一端进行处理。因此对于此类情况,无需考虑其集合的更新性能。"
+"但是,在设计良好的 Hibernate 领域模型中,我们通常可以看到更多的集合事实上是带"
+"有  <literal>inverse=\"true\"</literal> 的一对多的关联。对于这些关联,更新操"
+"作将会在多对一的这一端进行处理。因此对于此类情况,无需考虑其集合的更新性能。 "
 
 #. Tag: title
-#: performance.xml:1131
 #, no-c-format
 msgid "Bags and lists are the most efficient inverse collections"
-msgstr "Bag和list是反向集合类中效率最高的"
+msgstr "Bag 和 list 是反向集合类中效率最高的"
 
 #. Tag: para
-#: performance.xml:1133
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is a particular case, however, in which bags, and also lists, are much "
 "more performant than sets. For a collection with <literal>inverse=\"true\"</"
@@ -2103,119 +1772,99 @@
 "literal> must always return true for a bag or <literal>List</literal>. This "
 "can make the following common code much faster:"
 msgstr ""
-"在把bag扔进水沟之前,你必须了解,在一种情况下,bag的性能(包括list)要比set高得"
-"多: 对于指明了<literal>inverse=\"true\"</literal>的集合类(比如说,标准的双"
-"向的一对多关联), 我们可以在未初始化(fetch)包元素的情况下直接向bag或list添加"
-"新元素! 这是因为<literal>Collection.add()</literal>)或者<literal>Collection."
-"addAll()</literal> 方法 对bag或者List总是返回true(这点与与Set不同)。因此对"
-"于下面的相同代码来说,速度会快得多。"
+"在把 bag 扔进水沟之前,你必须了解,在一种情况下,bag 的性能(包括list)要比 "
+"set 高得多:对于指明了 <literal>inverse=\"true\"</literal> 的集合类(比如说,"
+"标准的双向的一对多关联),我们可以在未初始化(fetch)包元素的情况下直接向 "
+"bag 或 list 添加新元素! 这是因为 <literal>Collection.add()</literal>)或者 "
+"<literal>Collection.addAll()</literal> 方法对 bag 或者 List 总是返回 true(这"
+"点与与 Set 不同)。因此对于下面的相同代码来说,速度会快得多。 "
 
-#. Tag: programlisting
-#: performance.xml:1143
-#, no-c-format
-msgid ""
-"<![CDATA[Parent p = (Parent) sess.load(Parent.class, id);\n"
-"Child c = new Child();\n"
-"c.setParent(p);\n"
-"p.getChildren().add(c);  //no need to fetch the collection!\n"
-"sess.flush();]]>"
-msgstr ""
-
 #. Tag: title
-#: performance.xml:1148
 #, no-c-format
 msgid "One shot delete"
 msgstr "一次性删除(One shot delete)"
 
 #. Tag: para
-#: performance.xml:1150
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Deleting collection elements one by one can sometimes be extremely "
 "inefficient. Hibernate knows not to do that in the case of an newly-empty "
 "collection (if you called <literal>list.clear()</literal>, for example). In "
 "this case, Hibernate will issue a single <literal>DELETE</literal>."
 msgstr ""
-"偶尔的,逐个删除集合类中的元素是相当低效的。Hibernate并没那么笨, 如果你想要"
-"把整个集合都删除(比如说调用list.clear()),Hibernate只需要一个DELETE就搞定"
-"了。"
+"偶尔的,逐个删除集合类中的元素是相当低效的。Hibernate 并没那么笨,如果你想要"
+"把整个集合都删除(比如说调用 list.clear()),Hibernate 只需要一个 DELETE 就搞"
+"定了。 "
 
 #. Tag: para
-#: performance.xml:1157
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Suppose you added a single element to a collection of size twenty and then "
 "remove two elements. Hibernate will issue one <literal>INSERT</literal> "
 "statement and two <literal>DELETE</literal> statements, unless the "
 "collection is a bag. This is certainly desirable."
 msgstr ""
-"假设我们在一个长度为20的集合类中新增加了一个元素,然后再删除两个。 Hibernate"
-"会安排一条<literal>INSERT</literal>语句和两条<literal>DELETE</literal>语句"
-"(除非集合类是一个bag)。 这当然是显而易见的。"
+"假设我们在一个长度为20的集合类中新增加了一个元素,然后再删除两个。Hibernate "
+"会安排一条 <literal>INSERT</literal> 语句和两条 <literal>DELETE</literal> 语"
+"句(除非集合类是一个 bag)。这当然是令人满意的。 "
 
 #. Tag: para
-#: performance.xml:1163
 #, no-c-format
 msgid ""
 "However, suppose that we remove eighteen elements, leaving two and then add "
 "thee new elements. There are two possible ways to proceed"
 msgstr ""
-"但是,假设我们删除了18个数据,只剩下2个,然后新增3个。则有两种处理方式:"
+"但是,假设我们删除了 18 个数据,只剩下 2 个,然后新增 3 个。则有两种处理方"
+"式:"
 
 #. Tag: para
-#: performance.xml:1170
 #, no-c-format
 msgid "delete eighteen rows one by one and then insert three rows"
-msgstr "逐一的删除这18个数据,再新增三个;"
+msgstr "逐一的删除这 18 个数据,再新增三个;"
 
 #. Tag: para
-#: performance.xml:1173
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "remove the whole collection in one SQL <literal>DELETE</literal> and insert "
 "all five current elements one by one"
-msgstr "删除整个集合类(只用一句DELETE语句),然后增加5个数据。"
+msgstr "删除整个集合类(只用一句 DELETE 语句),然后逐一添加 5 个数据。"
 
 #. Tag: para
-#: performance.xml:1178
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate cannot know that the second option is probably quicker. It would "
 "probably be undesirable for Hibernate to be that intuitive as such behavior "
 "might confuse database triggers, etc."
 msgstr ""
-"Hibernate还没那么聪明,知道第二种选择可能会比较快。 (也许让Hibernate不这么聪"
-"明也是好事,否则可能会引发意外的“数据库触发器”之类的问题。)"
+"Hibernate 还没那么聪明,知道第二种选择可能会比较快。(也许让 Hibernate 不这么"
+"聪明也是好事,否则可能会引发意外的“数据库触发器”之类的问题。)"
 
 #. Tag: para
-#: performance.xml:1184
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Fortunately, you can force this behavior (i.e. the second strategy) at any "
 "time by discarding (i.e. dereferencing) the original collection and "
 "returning a newly instantiated collection with all the current elements."
 msgstr ""
 "幸运的是,你可以强制使用第二种策略。你需要取消原来的整个集合类(解除其引"
-"用), 然后再返回一个新的实例化的集合类,只包含需要的元素。有些时候这是非常有"
-"用的。"
+"用),然后再返回一个新的实例化的集合类,只包含需要的元素。有些时候这是非常有"
+"用的。 "
 
 #. Tag: para
-#: performance.xml:1190
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "One-shot-delete does not apply to collections mapped <literal>inverse=\"true"
 "\"</literal>."
 msgstr ""
-"显然,一次性删除并不适用于被映射为<literal>inverse=\"true\"</literal>的集合。"
+"显然,一次性删除并不适用于被映射为 <literal>inverse=\"true\"</literal> 的集"
+"合。 "
 
 #. Tag: title
-#: performance.xml:1199
 #, no-c-format
 msgid "Monitoring performance"
 msgstr "监测性能(Monitoring performance)"
 
 #. Tag: para
-#: performance.xml:1201
 #, no-c-format
 msgid ""
 "Optimization is not much use without monitoring and access to performance "
@@ -2223,151 +1872,109 @@
 "operations. Statistics in Hibernate are available per "
 "<literal>SessionFactory</literal>."
 msgstr ""
-"没有监测和性能参数而进行优化是毫无意义的。Hibernate为其内部操作提供了一系列的"
-"示意图,因此可以从 每个<literal>SessionFactory</literal>抓取其统计数据。"
+"没有监测和性能参数而进行优化是毫无意义的。Hibernate 为其内部操作提供了一系列"
+"的示意图,因此可以从 每个 <literal>SessionFactory</literal> 抓取其统计数据。"
 
 #. Tag: title
-#: performance.xml:1208
 #, no-c-format
 msgid "Monitoring a SessionFactory"
-msgstr "监测SessionFactory"
+msgstr "监测 SessionFactory"
 
 #. Tag: para
-#: performance.xml:1210
 #, no-c-format
 msgid ""
 "You can access <literal>SessionFactory</literal> metrics in two ways. Your "
 "first option is to call <literal>sessionFactory.getStatistics()</literal> "
 "and read or display the <literal>Statistics</literal> yourself."
 msgstr ""
-"你可以有两种方式访问<literal>SessionFactory</literal>的数据记录,第一种就是自"
-"己直接调用 <literal>sessionFactory.getStatistics()</literal>方法读取、显示"
+"你可以有两种方式访问 <literal>SessionFactory</literal> 的数据记录,第一种就是"
+"自己直接调用 <literal>sessionFactory.getStatistics()</literal> 方法读取、显示"
 "<literal>统计</literal>数据。"
 
 #. Tag: para
-#: performance.xml:1216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate can also use JMX to publish metrics if you enable the "
 "<literal>StatisticsService</literal> MBean. You can enable a single MBean "
 "for all your <literal>SessionFactory</literal> or one per factory. See the "
 "following code for minimalistic configuration examples:"
 msgstr ""
-"此外,如果你打开<literal>StatisticsService</literal> MBean选项,那么Hibernate"
-"则可以使用JMX技术 发布其数据记录。你可以让应用中所有的"
-"<literal>SessionFactory</literal>同时共享一个MBean,也可以每个 SessionFactory"
-"分配一个MBean。下面的代码即是其演示代码:"
+"此外,如果你打开 <literal>StatisticsService</literal> MBean 选项,那么 "
+"Hibernate 则可以使用 JMX 技术 发布其数据记录。你可以让应用中所有的 "
+"<literal>SessionFactory</literal> 同时共享一个 MBean,也可以每个 "
+"SessionFactory 分配一个 MBean。下面的代码即是其演示代码: "
 
-#. Tag: programlisting
-#: performance.xml:1223
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// MBean service registration for a specific SessionFactory\n"
-"Hashtable tb = new Hashtable();\n"
-"tb.put(\"type\", \"statistics\");\n"
-"tb.put(\"sessionFactory\", \"myFinancialApp\");\n"
-"ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-"\n"
-"StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-"stats.setSessionFactory(sessionFactory); // Bind the stats to a "
-"SessionFactory\n"
-"server.registerMBean(stats, on); // Register the Mbean on the server]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: performance.xml:1226
-#, no-c-format
-msgid ""
-"<![CDATA[// MBean service registration for all SessionFactory's\n"
-"Hashtable tb = new Hashtable();\n"
-"tb.put(\"type\", \"statistics\");\n"
-"tb.put(\"sessionFactory\", \"all\");\n"
-"ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
-"\n"
-"StatisticsService stats = new StatisticsService(); // MBean implementation\n"
-"server.registerMBean(stats, on); // Register the MBean on the server]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:1228
-#, fuzzy, no-c-format
-msgid ""
 "You can activate and deactivate the monitoring for a "
 "<literal>SessionFactory</literal>:"
 msgstr ""
-"你可以通过以下方法打开或关闭<literal>SessionFactory</literal>的监测功能:"
+"你可以通过以下方法打开或关闭 <literal>SessionFactory</literal> 的监测功能: "
 
 #. Tag: para
-#: performance.xml:1233
 #, no-c-format
 msgid ""
 "at configuration time, set <literal>hibernate.generate_statistics</literal> "
 "to <literal>false</literal>"
 msgstr ""
-"在配置期间,将<literal>hibernate.generate_statistics</literal>设置为"
-"<literal>true</literal>或<literal>false</literal>;"
+"在配置期间,将 <literal>hibernate.generate_statistics</literal> 设置为 "
+"<literal>true</literal> 或 <literal>false</literal>;"
 
 #. Tag: para
-#: performance.xml:1240
 #, no-c-format
 msgid ""
 "at runtime: <literal>sf.getStatistics().setStatisticsEnabled(true)</literal> "
 "or <literal>hibernateStatsBean.setStatisticsEnabled(true)</literal>"
 msgstr ""
-"在运行期间,则可以可以通过<literal>sf.getStatistics().setStatisticsEnabled"
-"(true)</literal> 或<literal>hibernateStatsBean.setStatisticsEnabled(true)</"
+"在运行期间,则可以可以通过 <literal>sf.getStatistics().setStatisticsEnabled"
+"(true)</literal> 或 <literal>hibernateStatsBean.setStatisticsEnabled(true)</"
 "literal>"
 
 #. Tag: para
-#: performance.xml:1247
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Statistics can be reset programmatically using the <literal>clear()</"
 "literal> method. A summary can be sent to a logger (info level) using the "
 "<literal>logSummary()</literal> method."
 msgstr ""
-"你也可以在程序中调用<literal>clear()</literal>方法重置统计数据,调用"
-"<literal>logSummary()</literal> 在日志中记录(info级别)其总结。"
+"你也可以在程序中调用 <literal>clear()</literal> 方法重置统计数据,调用 "
+"<literal>logSummary()</literal> 在日志中记录(info 级别)其总结。 "
 
 #. Tag: title
-#: performance.xml:1256
 #, no-c-format
 msgid "Metrics"
 msgstr "数据记录(Metrics)"
 
 #. Tag: para
-#: performance.xml:1258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate provides a number of metrics, from basic information to more "
 "specialized information that is only relevant in certain scenarios. All "
 "available counters are described in the <literal>Statistics</literal> "
 "interface API, in three categories:"
 msgstr ""
-"Hibernate提供了一系列数据记录,其记录的内容包括从最基本的信息到与具体场景的特"
-"殊信息。所有的测量值都可以由 <literal>Statistics</literal>接口进行访问,主要"
-"分为三类:"
+"Hibernate 提供了一系列数据记录,其记录的内容包括从最基本的信息到与具体场景的"
+"特殊信息。所有的测量值都可以由 <literal>Statistics</literal> 接口 API 进行访"
+"问,主要分为三类:"
 
 #. Tag: para
-#: performance.xml:1265
 #, no-c-format
 msgid ""
 "Metrics related to the general <literal>Session</literal> usage, such as "
 "number of open sessions, retrieved JDBC connections, etc."
 msgstr ""
-"使用<literal>Session</literal>的普通数据记录,例如打开的Session的个数、取得的"
-"JDBC的连接数等;"
+"使用 <literal>Session</literal> 的普通数据记录,例如打开的 Session 的个数、取"
+"得的 JDBC 的连接数等;"
 
 #. Tag: para
-#: performance.xml:1271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Metrics related to the entities, collections, queries, and caches as a whole "
 "(aka global metrics)."
-msgstr "实体、集合、查询、缓存等内容的统一数据记录"
+msgstr "实体、集合、查询、缓存等内容的统一数据记录。"
 
 #. Tag: para
-#: performance.xml:1277
 #, no-c-format
 msgid ""
 "Detailed metrics related to a particular entity, collection, query or cache "
@@ -2375,8 +1982,7 @@
 msgstr "和具体实体、集合、查询、缓存相关的详细数据记录"
 
 #. Tag: para
-#: performance.xml:1284
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For example, you can check the cache hit, miss, and put ratio of entities, "
 "collections and queries, and the average time a query needs. Be aware that "
@@ -2385,12 +1991,11 @@
 "to 10 seconds."
 msgstr ""
 "例如:你可以检查缓存的命中成功次数,缓存的命中失败次数,实体、集合和查询的使"
-"用概率,查询的平均时间等。请注意 Java中时间的近似精度是毫秒。Hibernate的数据"
-"精度和具体的JVM有关,在有些平台上其精度甚至只能精确到10秒。"
+"用概率,查询的平均时间等。请注意 Java 中时间的近似精度是毫秒。Hibernate 的数"
+"据精度和具体的 JVM 有关,在有些平台上其精度甚至只能精确到 10 秒。 "
 
 #. Tag: para
-#: performance.xml:1291
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Simple getters are used to access the global metrics (i.e. not tied to a "
 "particular entity, collection, cache region, etc.). You can access the "
@@ -2402,39 +2007,16 @@
 "literal> API Javadoc for more information. The following code is a simple "
 "example:"
 msgstr ""
-"你可以直接使用getter方法得到全局数据记录(例如,和具体的实体、集合、缓存区无"
-"关的数据),你也可以在具体查询中通过标记实体名、 或HQL、SQL语句得到某实体的数"
-"据记录。请参考<literal>Statistics</literal>、<literal>EntityStatistics</"
-"literal>、 <literal>CollectionStatistics</literal>、"
-"<literal>SecondLevelCacheStatistics</literal>、 和<literal>QueryStatistics</"
-"literal>的API文档以抓取更多信息。下面的代码则是个简单的例子:"
+"你可以直接使用 getter 方法得到全局数据记录(例如,和具体的实体、集合、缓存区"
+"无关的数据),你也可以在具体查询中通过标记实体名、 或 HQL、SQL 语句得到某实体"
+"的数据记录。请参考 <literal>Statistics</literal>、<literal>EntityStatistics</"
+"literal>、<literal>CollectionStatistics</literal>、"
+"<literal>SecondLevelCacheStatistics</literal> 和 <literal>QueryStatistics</"
+"literal> 的 API 文档以抓取更多信息。下面的代码则是个简单的例子: "
 
-#. Tag: programlisting
-#: performance.xml:1301
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Statistics stats = HibernateUtil.sessionFactory.getStatistics();\n"
-"\n"
-"double queryCacheHitCount  = stats.getQueryCacheHitCount();\n"
-"double queryCacheMissCount = stats.getQueryCacheMissCount();\n"
-"double queryCacheHitRatio =\n"
-"  queryCacheHitCount / (queryCacheHitCount + queryCacheMissCount);\n"
-"\n"
-"log.info(\"Query Hit ratio:\" + queryCacheHitRatio);\n"
-"\n"
-"EntityStatistics entityStats =\n"
-"  stats.getEntityStatistics( Cat.class.getName() );\n"
-"long changes =\n"
-"        entityStats.getInsertCount()\n"
-"        + entityStats.getUpdateCount()\n"
-"        + entityStats.getDeleteCount();\n"
-"log.info(Cat.class.getName() + \" changed \" + changes + \"times\"  );]]>"
-msgstr ""
-
-#. Tag: para
-#: performance.xml:1303
-#, fuzzy, no-c-format
-msgid ""
 "You can work on all entities, collections, queries and region caches, by "
 "retrieving the list of names of entities, collections, queries and region "
 "caches using the following methods: <literal>getQueries()</literal>, "
@@ -2442,43 +2024,455 @@
 "literal>, and <literal>getSecondLevelCacheRegionNames()</literal>."
 msgstr ""
 "如果你想得到所有实体、集合、查询和缓存区的数据,你可以通过以下方法获得实体、"
-"集合、查询和缓存区列表: <literal>getQueries()</literal>、"
-"<literal>getEntityNames()</literal>、 <literal>getCollectionRoleNames()</"
-"literal>和 <literal>getSecondLevelCacheRegionNames()</literal>。"
+"集合、查询和缓存区列表:<literal>getQueries()</literal>、"
+"<literal>getEntityNames()</literal>、<literal>getCollectionRoleNames()</"
+"literal> 和 <literal>getSecondLevelCacheRegionNames()</literal>。"
 
 #~ msgid ""
-#~ "where <literal>CatImpl</literal> implements the interface <literal>Cat</"
-#~ "literal> and <literal>DomesticCatImpl</literal> implements the interface "
-#~ "<literal>DomesticCat</literal>. Then proxies for instances of "
-#~ "<literal>Cat</literal> and <literal>DomesticCat</literal> may be returned "
-#~ "by <literal>load()</literal> or <literal>iterate()</literal>. (Note that "
-#~ "<literal>list()</literal> does not usually return proxies.)"
+#~ "This setting creates two new cache regions: one holding cached query "
+#~ "result sets (<literal>org.hibernate.cache.StandardQueryCache</literal>), "
+#~ "the other holding timestamps of the most recent updates to queryable "
+#~ "tables (<literal>org.hibernate.cache.UpdateTimestampsCache</literal>). "
+#~ "Note that the query cache does not cache the state of the actual entities "
+#~ "in the result set; it caches only identifier values and results of value "
+#~ "type. The query cache should always be used in conjunction with the "
+#~ "second-level cache."
 #~ msgstr ""
-#~ "这里<literal>CatImpl</literal>实现了<literal>Cat</literal>接口, "
-#~ "<literal>DomesticCatImpl</literal>实现<literal>DomesticCat</literal>接"
-#~ "口。 在<literal>load()</literal>、<literal>iterate()</literal>方法中就会返"
-#~ "回 <literal>Cat</literal>和<literal>DomesticCat</literal>的代理对象。 (注"
-#~ "意<literal>list()</literal>并不会返回代理对象。)"
+#~ "该设置将会创建两个缓存区域 — 一个用于保存查询结果集(<literal>org."
+#~ "hibernate.cache.StandardQueryCache</literal>); 另一个则用于保存最近查询"
+#~ "的一系列表的时间戳(<literal>org.hibernate.cache.UpdateTimestampsCache</"
+#~ "literal>)。请注意:在查询缓存中,它并不缓存结果集中所包含的实体的确切状"
+#~ "态;它只缓存这些实体的标识符属性的值、以及各值类型的结果。所以查询缓存通常"
+#~ "会和二级缓存一起使用。 "
 
 #~ msgid ""
-#~ "We've already spent quite some time talking about collections. In this "
-#~ "section we will highlight a couple more issues about how collections "
-#~ "behave at runtime."
+#~ "<![CDATA[s = sessions.openSession();\n"
+#~ "Transaction tx = s.beginTransaction();\n"
+#~ "            \n"
+#~ "User u = (User) s.createQuery(\"from User u where u.name=:userName\")\n"
+#~ "    .setString(\"userName\", userName).uniqueResult();\n"
+#~ "Map permissions = u.getPermissions();\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "s.close();\n"
+#~ "\n"
+#~ "Integer accessLevel = (Integer) permissions.get(\"accounts\");  // "
+#~ "Error!]]>"
 #~ msgstr ""
-#~ "前面我们已经对集合进行了足够的讨论。本段中,我们将着重讲述集合在运行时的事"
-#~ "宜。"
+#~ "<![CDATA[s = sessions.openSession();\n"
+#~ "Transaction tx = s.beginTransaction();\n"
+#~ "            \n"
+#~ "User u = (User) s.createQuery(\"from User u where u.name=:userName\")\n"
+#~ "    .setString(\"userName\", userName).uniqueResult();\n"
+#~ "Map permissions = u.getPermissions();\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "s.close();\n"
+#~ "\n"
+#~ "Integer accessLevel = (Integer) permissions.get(\"accounts\");  // "
+#~ "Error!]]>"
 
 #~ msgid ""
-#~ "TODO: This doesn't make sense: In the first case, we retrieve and use the "
-#~ "MBean directly. In the second one, we must give the JNDI name in which "
-#~ "the session factory is held before using it. Use "
-#~ "<literal>hibernateStatsBean.setSessionFactoryJNDIName(\"my/JNDI/Name\")</"
-#~ "literal>"
+#~ "<![CDATA[<set name=\"permissions\" \n"
+#~ "            fetch=\"join\">\n"
+#~ "    <key column=\"userId\"/>\n"
+#~ "    <one-to-many class=\"Permission\"/>\n"
+#~ "</set]]>"
 #~ msgstr ""
-#~ "TODO:仍需要说明的是:在第一个例子中,我们直接得到和使用MBean;而在第二个"
-#~ "例子中,在使用MBean之前 我们则需要给出SessionFactory的JNDI名,使用"
-#~ "<literal>hibernateStatsBean.setSessionFactoryJNDIName(\"my/JNDI/Name\")</"
-#~ "literal> 得到SessionFactory,然后将MBean保存于其中。"
+#~ "<![CDATA[<set name=\"permissions\" \n"
+#~ "            fetch=\"join\">\n"
+#~ "    <key column=\"userId\"/>\n"
+#~ "    <one-to-many class=\"Permission\"/>\n"
+#~ "</set]]>"
 
-#~ msgid "yes"
-#~ msgstr "yes"
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"mother\" class=\"Cat\" fetch=\"join\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<many-to-one name=\"mother\" class=\"Cat\" fetch=\"join\"/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[User user = (User) session.createCriteria(User.class)\n"
+#~ "                .setFetchMode(\"permissions\", FetchMode.JOIN)\n"
+#~ "                .add( Restrictions.idEq(userId) )\n"
+#~ "                .uniqueResult();]]>"
+#~ msgstr ""
+#~ "<![CDATA[User user = (User) session.createCriteria(User.class)\n"
+#~ "                .setFetchMode(\"permissions\", FetchMode.JOIN)\n"
+#~ "                .add( Restrictions.idEq(userId) )\n"
+#~ "                .uniqueResult();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Cat\" proxy=\"Cat\">\n"
+#~ "    ......\n"
+#~ "    <subclass name=\"DomesticCat\">\n"
+#~ "        .....\n"
+#~ "    </subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Cat\" proxy=\"Cat\">\n"
+#~ "    ......\n"
+#~ "    <subclass name=\"DomesticCat\">\n"
+#~ "        .....\n"
+#~ "    </subclass>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);  // instantiate a "
+#~ "proxy (does not hit the db)\n"
+#~ "if ( cat.isDomesticCat() ) {                  // hit the db to initialize "
+#~ "the proxy\n"
+#~ "    DomesticCat dc = (DomesticCat) cat;       // Error!\n"
+#~ "    ....\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);  // instantiate a "
+#~ "proxy (does not hit the db)\n"
+#~ "if ( cat.isDomesticCat() ) {                  // hit the db to initialize "
+#~ "the proxy\n"
+#~ "    DomesticCat dc = (DomesticCat) cat;       // Error!\n"
+#~ "    ....\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);            // "
+#~ "instantiate a Cat proxy\n"
+#~ "DomesticCat dc = \n"
+#~ "        (DomesticCat) session.load(DomesticCat.class, id);  // acquire "
+#~ "new DomesticCat proxy!\n"
+#~ "System.out.println(cat==dc);                            // false]]>"
+#~ msgstr ""
+#~ "<![CDATA[Cat cat = (Cat) session.load(Cat.class, id);            // "
+#~ "instantiate a Cat proxy\n"
+#~ "DomesticCat dc = \n"
+#~ "        (DomesticCat) session.load(DomesticCat.class, id);  // acquire "
+#~ "new DomesticCat proxy!\n"
+#~ "System.out.println(cat==dc);                            // false]]>"
+
+#~ msgid ""
+#~ "<![CDATA[cat.setWeight(11.0);  // hit the db to initialize the proxy\n"
+#~ "System.out.println( dc.getWeight() );  // 11.0]]>"
+#~ msgstr ""
+#~ "<![CDATA[cat.setWeight(11.0);  // hit the db to initialize the proxy\n"
+#~ "System.out.println( dc.getWeight() );  // 11.0]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"CatImpl\" proxy=\"Cat\">\n"
+#~ "    ......\n"
+#~ "    <subclass name=\"DomesticCatImpl\" proxy=\"DomesticCat\">\n"
+#~ "        .....\n"
+#~ "    </subclass>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"CatImpl\" proxy=\"Cat\">\n"
+#~ "    ......\n"
+#~ "    <subclass name=\"DomesticCatImpl\" proxy=\"DomesticCat\">\n"
+#~ "        .....\n"
+#~ "    </subclass>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Cat cat = (Cat) session.load(CatImpl.class, catid);\n"
+#~ "Iterator iter = session.createQuery(\"from CatImpl as cat where cat."
+#~ "name='fritz'\").iterate();\n"
+#~ "Cat fritz = (Cat) iter.next();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Cat cat = (Cat) session.load(CatImpl.class, catid);\n"
+#~ "Iterator iter = session.createQuery(\"from CatImpl as cat where cat."
+#~ "name='fritz'\").iterate();\n"
+#~ "Cat fritz = (Cat) iter.next();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[( (Integer) s.createFilter( collection, \"select count(*)\" )."
+#~ "list().get(0) ).intValue()]]>"
+#~ msgstr ""
+#~ "<![CDATA[( (Integer) s.createFilter( collection, \"select count(*)\" )."
+#~ "list().get(0) ).intValue()]]>"
+
+#~ msgid ""
+#~ "<![CDATA[s.createFilter( lazyCollection, \"\").setFirstResult(0)."
+#~ "setMaxResults(10).list();]]>"
+#~ msgstr ""
+#~ "<![CDATA[s.createFilter( lazyCollection, \"\").setFirstResult(0)."
+#~ "setMaxResults(10).list();]]>"
+
+#~ msgid "<![CDATA[<class name=\"Person\" batch-size=\"10\">...</class>]]>"
+#~ msgstr "<![CDATA[<class name=\"Person\" batch-size=\"10\">...</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <set name=\"cats\" batch-size=\"3\">\n"
+#~ "        ...\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <set name=\"cats\" batch-size=\"3\">\n"
+#~ "        ...\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Document\">\n"
+#~ "       <id name=\"id\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"name\" not-null=\"true\" length=\"50\"/>\n"
+#~ "    <property name=\"summary\" not-null=\"true\" length=\"200\" lazy="
+#~ "\"true\"/>\n"
+#~ "    <property name=\"text\" not-null=\"true\" length=\"2000\" lazy=\"true"
+#~ "\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Document\">\n"
+#~ "       <id name=\"id\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"name\" not-null=\"true\" length=\"50\"/>\n"
+#~ "    <property name=\"summary\" not-null=\"true\" length=\"200\" lazy="
+#~ "\"true\"/>\n"
+#~ "    <property name=\"text\" not-null=\"true\" length=\"2000\" lazy=\"true"
+#~ "\"/>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<target name=\"instrument\" depends=\"compile\">\n"
+#~ "    <taskdef name=\"instrument\" classname=\"org.hibernate.tool."
+#~ "instrument.InstrumentTask\">\n"
+#~ "        <classpath path=\"${jar.path}\"/>\n"
+#~ "        <classpath path=\"${classes.dir}\"/>\n"
+#~ "        <classpath refid=\"lib.class.path\"/>\n"
+#~ "    </taskdef>\n"
+#~ "\n"
+#~ "    <instrument verbose=\"true\">\n"
+#~ "        <fileset dir=\"${testclasses.dir}/org/hibernate/auction/model\">\n"
+#~ "            <include name=\"*.class\"/>\n"
+#~ "        </fileset>\n"
+#~ "    </instrument>\n"
+#~ "</target>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<target name=\"instrument\" depends=\"compile\">\n"
+#~ "    <taskdef name=\"instrument\" classname=\"org.hibernate.tool."
+#~ "instrument.InstrumentTask\">\n"
+#~ "        <classpath path=\"${jar.path}\"/>\n"
+#~ "        <classpath path=\"${classes.dir}\"/>\n"
+#~ "        <classpath refid=\"lib.class.path\"/>\n"
+#~ "    </taskdef>\n"
+#~ "\n"
+#~ "    <instrument verbose=\"true\">\n"
+#~ "        <fileset dir=\"${testclasses.dir}/org/hibernate/auction/model\">\n"
+#~ "            <include name=\"*.class\"/>\n"
+#~ "        </fileset>\n"
+#~ "    </instrument>\n"
+#~ "</target>]]>"
+
+#~ msgid "<entry>yes</entry>"
+#~ msgstr "<entry>yes</entry>"
+
+#~ msgid ""
+#~ "<![CDATA[<cache \n"
+#~ "    usage=\"transactional|read-write|nonstrict-read-write|read-only\"\n"
+#~ "    region=\"RegionName\"\n"
+#~ "    include=\"all|non-lazy\"\n"
+#~ "/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<cache \n"
+#~ "    usage=\"transactional|read-write|nonstrict-read-write|read-only\"\n"
+#~ "    region=\"RegionName\"\n"
+#~ "    include=\"all|non-lazy\"\n"
+#~ "/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Immutable\" mutable=\"false\">\n"
+#~ "    <cache usage=\"read-only\"/>\n"
+#~ "    ....\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Immutable\" mutable=\"false\">\n"
+#~ "    <cache usage=\"read-only\"/>\n"
+#~ "    ....\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"eg.Cat\" .... >\n"
+#~ "    <cache usage=\"read-write\"/>\n"
+#~ "    ....\n"
+#~ "    <set name=\"kittens\" ... >\n"
+#~ "        <cache usage=\"read-write\"/>\n"
+#~ "        ....\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"eg.Cat\" .... >\n"
+#~ "    <cache usage=\"read-write\"/>\n"
+#~ "    ....\n"
+#~ "    <set name=\"kittens\" ... >\n"
+#~ "        <cache usage=\"read-write\"/>\n"
+#~ "        ....\n"
+#~ "    </set>\n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[ScrollableResult cats = sess.createQuery(\"from Cat as cat\")."
+#~ "scroll(); //a huge result set\n"
+#~ "while ( cats.next() ) {\n"
+#~ "    Cat cat = (Cat) cats.get(0);\n"
+#~ "    doSomethingWithACat(cat);\n"
+#~ "    sess.evict(cat);\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[ScrollableResult cats = sess.createQuery(\"from Cat as cat\")."
+#~ "scroll(); //a huge result set\n"
+#~ "while ( cats.next() ) {\n"
+#~ "    Cat cat = (Cat) cats.get(0);\n"
+#~ "    doSomethingWithACat(cat);\n"
+#~ "    sess.evict(cat);\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[sessionFactory.evict(Cat.class, catId); //evict a particular "
+#~ "Cat\n"
+#~ "sessionFactory.evict(Cat.class);  //evict all Cats\n"
+#~ "sessionFactory.evictCollection(\"Cat.kittens\", catId); //evict a "
+#~ "particular collection of kittens\n"
+#~ "sessionFactory.evictCollection(\"Cat.kittens\"); //evict all kitten "
+#~ "collections]]>"
+#~ msgstr ""
+#~ "<![CDATA[sessionFactory.evict(Cat.class, catId); //evict a particular "
+#~ "Cat\n"
+#~ "sessionFactory.evict(Cat.class);  //evict all Cats\n"
+#~ "sessionFactory.evictCollection(\"Cat.kittens\", catId); //evict a "
+#~ "particular collection of kittens\n"
+#~ "sessionFactory.evictCollection(\"Cat.kittens\"); //evict all kitten "
+#~ "collections]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Map cacheEntries = sessionFactory.getStatistics()\n"
+#~ "        .getSecondLevelCacheStatistics(regionName)\n"
+#~ "        .getEntries();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Map cacheEntries = sessionFactory.getStatistics()\n"
+#~ "        .getSecondLevelCacheStatistics(regionName)\n"
+#~ "        .getEntries();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[hibernate.generate_statistics true\n"
+#~ "hibernate.cache.use_structured_entries true]]>"
+#~ msgstr ""
+#~ "<![CDATA[hibernate.generate_statistics true\n"
+#~ "hibernate.cache.use_structured_entries true]]>"
+
+#~ msgid "<![CDATA[hibernate.cache.use_query_cache true]]>"
+#~ msgstr "<![CDATA[hibernate.cache.use_query_cache true]]>"
+
+#~ msgid ""
+#~ "<![CDATA[List blogs = sess.createQuery(\"from Blog blog where blog."
+#~ "blogger = :blogger\")\n"
+#~ "    .setEntity(\"blogger\", blogger)\n"
+#~ "    .setMaxResults(15)\n"
+#~ "    .setCacheable(true)\n"
+#~ "    .setCacheRegion(\"frontpages\")\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "<![CDATA[List blogs = sess.createQuery(\"from Blog blog where blog."
+#~ "blogger = :blogger\")\n"
+#~ "    .setEntity(\"blogger\", blogger)\n"
+#~ "    .setMaxResults(15)\n"
+#~ "    .setCacheable(true)\n"
+#~ "    .setCacheRegion(\"frontpages\")\n"
+#~ "    .list();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Parent p = (Parent) sess.load(Parent.class, id);\n"
+#~ "Child c = new Child();\n"
+#~ "c.setParent(p);\n"
+#~ "p.getChildren().add(c);  //no need to fetch the collection!\n"
+#~ "sess.flush();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Parent p = (Parent) sess.load(Parent.class, id);\n"
+#~ "Child c = new Child();\n"
+#~ "c.setParent(p);\n"
+#~ "p.getChildren().add(c);  //no need to fetch the collection!\n"
+#~ "sess.flush();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[// MBean service registration for a specific SessionFactory\n"
+#~ "Hashtable tb = new Hashtable();\n"
+#~ "tb.put(\"type\", \"statistics\");\n"
+#~ "tb.put(\"sessionFactory\", \"myFinancialApp\");\n"
+#~ "ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
+#~ "\n"
+#~ "StatisticsService stats = new StatisticsService(); // MBean "
+#~ "implementation\n"
+#~ "stats.setSessionFactory(sessionFactory); // Bind the stats to a "
+#~ "SessionFactory\n"
+#~ "server.registerMBean(stats, on); // Register the Mbean on the server]]>"
+#~ msgstr ""
+#~ "<![CDATA[// MBean service registration for a specific SessionFactory\n"
+#~ "Hashtable tb = new Hashtable();\n"
+#~ "tb.put(\"type\", \"statistics\");\n"
+#~ "tb.put(\"sessionFactory\", \"myFinancialApp\");\n"
+#~ "ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
+#~ "\n"
+#~ "StatisticsService stats = new StatisticsService(); // MBean "
+#~ "implementation\n"
+#~ "stats.setSessionFactory(sessionFactory); // Bind the stats to a "
+#~ "SessionFactory\n"
+#~ "server.registerMBean(stats, on); // Register the Mbean on the server]]>"
+
+#~ msgid ""
+#~ "<![CDATA[// MBean service registration for all SessionFactory's\n"
+#~ "Hashtable tb = new Hashtable();\n"
+#~ "tb.put(\"type\", \"statistics\");\n"
+#~ "tb.put(\"sessionFactory\", \"all\");\n"
+#~ "ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
+#~ "\n"
+#~ "StatisticsService stats = new StatisticsService(); // MBean "
+#~ "implementation\n"
+#~ "server.registerMBean(stats, on); // Register the MBean on the server]]>"
+#~ msgstr ""
+#~ "<![CDATA[// MBean service registration for all SessionFactory's\n"
+#~ "Hashtable tb = new Hashtable();\n"
+#~ "tb.put(\"type\", \"statistics\");\n"
+#~ "tb.put(\"sessionFactory\", \"all\");\n"
+#~ "ObjectName on = new ObjectName(\"hibernate\", tb); // MBean object name\n"
+#~ "\n"
+#~ "StatisticsService stats = new StatisticsService(); // MBean "
+#~ "implementation\n"
+#~ "server.registerMBean(stats, on); // Register the MBean on the server]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Statistics stats = HibernateUtil.sessionFactory.getStatistics"
+#~ "();\n"
+#~ "\n"
+#~ "double queryCacheHitCount  = stats.getQueryCacheHitCount();\n"
+#~ "double queryCacheMissCount = stats.getQueryCacheMissCount();\n"
+#~ "double queryCacheHitRatio =\n"
+#~ "  queryCacheHitCount / (queryCacheHitCount + queryCacheMissCount);\n"
+#~ "\n"
+#~ "log.info(\"Query Hit ratio:\" + queryCacheHitRatio);\n"
+#~ "\n"
+#~ "EntityStatistics entityStats =\n"
+#~ "  stats.getEntityStatistics( Cat.class.getName() );\n"
+#~ "long changes =\n"
+#~ "        entityStats.getInsertCount()\n"
+#~ "        + entityStats.getUpdateCount()\n"
+#~ "        + entityStats.getDeleteCount();\n"
+#~ "log.info(Cat.class.getName() + \" changed \" + changes + \"times\"  );]]>"
+#~ msgstr ""
+#~ "<![CDATA[Statistics stats = HibernateUtil.sessionFactory.getStatistics"
+#~ "();\n"
+#~ "\n"
+#~ "double queryCacheHitCount  = stats.getQueryCacheHitCount();\n"
+#~ "double queryCacheMissCount = stats.getQueryCacheMissCount();\n"
+#~ "double queryCacheHitRatio =\n"
+#~ "  queryCacheHitCount / (queryCacheHitCount + queryCacheMissCount);\n"
+#~ "\n"
+#~ "log.info(\"Query Hit ratio:\" + queryCacheHitRatio);\n"
+#~ "\n"
+#~ "EntityStatistics entityStats =\n"
+#~ "  stats.getEntityStatistics( Cat.class.getName() );\n"
+#~ "long changes =\n"
+#~ "        entityStats.getInsertCount()\n"
+#~ "        + entityStats.getUpdateCount()\n"
+#~ "        + entityStats.getDeleteCount();\n"
+#~ "log.info(Cat.class.getName() + \" changed \" + changes + \"times\"  );]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/persistent_classes.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/persistent_classes.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/persistent_classes.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,27 @@
+# translation of persistent_classes.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007, 2009.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: persistent_classes\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-07 09:36+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: persistent_classes.xml:29
 #, no-c-format
 msgid "Persistent Classes"
-msgstr "持久化类(Persistent Classes)"
+msgstr "持久化类(Persistent Classes)"
 
 #. Tag: para
-#: persistent_classes.xml:31
-#, fuzzy, no-c-format
+#, 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 "
@@ -26,13 +29,12 @@
 "in the persistent state. For example, an instance can instead be transient "
 "or detached."
 msgstr ""
-"在应用程序中,用来实现业务问题实体的(如,在电子商务应用程序中的Customer和"
-"Order) 类就是持久化类。不能认为所有的持久化类的实例都是持久的状态——一个实例"
-"的状态也可能 是瞬时的或脱管的。"
+"在应用程序中,用来实现业务问题实体的(如,在电子商务应用程序中的 Customer 和 "
+"Order)类就是持久化类。不能认为所有的持久化类的实例都是持久的状态 - 一个实例"
+"的状态也可能是瞬时的或脱管的。"
 
 #. Tag: para
-#: persistent_classes.xml:38
-#, fuzzy, no-c-format
+#, 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 "
@@ -40,126 +42,37 @@
 "about the nature of your persistent objects. You can express a domain model "
 "in other ways (using trees of <literal>Map</literal> instances, for example)."
 msgstr ""
-"如果这些持久化类遵循一些简单的规则,Hibernate能够工作得更好,这些规则也被称"
-"作 简单传统Java对象(POJO:Plain Old Java Object)编程模型。但是这些规则并不是必"
-"需的。 实际上,Hibernate3对于你的持久化类几乎不做任何设想。你可以用其他的方法"
-"来表达领域模型: 比如,使用<literal>Map</literal>实例的树型结构。"
+"如果这些持久化类遵循一些简单的规则,Hibernate 能够工作得更好,这些规则也被称"
+"作简单传统 Java 对象(POJO:Plain Old Java Object)编程模型。但是这些规则并不"
+"是必需的。 实际上,Hibernate3 对于你的持久化类几乎不做任何设想。你可以用其他"
+"的方法来表达领域模型:比如,使用 <literal>Map</literal> 实例的树型结构。"
 
 #. Tag: title
-#: persistent_classes.xml:47
 #, no-c-format
 msgid "A simple POJO example"
-msgstr "一个简单的POJO例子"
+msgstr "一个简单的 POJO 例子"
 
 #. Tag: para
-#: persistent_classes.xml:49
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Most Java applications require a persistent class representing felines. For "
 "example:"
-msgstr "大多数Java程序需要用一个持久化类来表示猫科动物。"
+msgstr "大多数 Java 程序需要用一个持久化类来表示猫科动物。例如:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:53
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"import java.util.Set;\n"
-"import java.util.Date;\n"
-"\n"
-"public class Cat {\n"
-"    private Long id; // identifier\n"
-"\n"
-"    private Date birthdate;\n"
-"    private Color color;\n"
-"    private char sex;\n"
-"    private float weight;\n"
-"    private int litterId;\n"
-"\n"
-"    private Cat mother;\n"
-"    private Set kittens = new HashSet();\n"
-"\n"
-"    private void setId(Long id) {\n"
-"        this.id=id;\n"
-"    }\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"\n"
-"    void setBirthdate(Date date) {\n"
-"        birthdate = date;\n"
-"    }\n"
-"    public Date getBirthdate() {\n"
-"        return birthdate;\n"
-"    }\n"
-"\n"
-"    void setWeight(float weight) {\n"
-"        this.weight = weight;\n"
-"    }\n"
-"    public float getWeight() {\n"
-"        return weight;\n"
-"    }\n"
-"\n"
-"    public Color getColor() {\n"
-"        return color;\n"
-"    }\n"
-"    void setColor(Color color) {\n"
-"        this.color = color;\n"
-"    }\n"
-"\n"
-"    void setSex(char sex) {\n"
-"        this.sex=sex;\n"
-"    }\n"
-"    public char getSex() {\n"
-"        return sex;\n"
-"    }\n"
-"\n"
-"    void setLitterId(int id) {\n"
-"        this.litterId = id;\n"
-"    }\n"
-"    public int getLitterId() {\n"
-"        return litterId;\n"
-"    }\n"
-"\n"
-"    void setMother(Cat mother) {\n"
-"        this.mother = mother;\n"
-"    }\n"
-"    public Cat getMother() {\n"
-"        return mother;\n"
-"    }\n"
-"    void setKittens(Set kittens) {\n"
-"        this.kittens = kittens;\n"
-"    }\n"
-"    public Set getKittens() {\n"
-"        return kittens;\n"
-"    }\n"
-"    \n"
-"    // addKitten not needed by Hibernate\n"
-"    public void addKitten(Cat kitten) {\n"
-"            kitten.setMother(this);\n"
-"        kitten.setLitterId( kittens.size() ); \n"
-"        kittens.add(kitten);\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:55
 #, no-c-format
 msgid ""
 "The four main rules of persistent classes are explored in more detail in the "
 "following sections."
-msgstr ""
+msgstr "在后续的章节里我们将介绍持久性类的 4 个主要规则的更多细节。"
 
 #. Tag: title
-#: persistent_classes.xml:61
 #, no-c-format
 msgid "Implement a no-argument constructor"
 msgstr "实现一个默认的(即无参数的)构造方法(constructor)"
 
 #. Tag: para
-#: persistent_classes.xml:63
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Cat</literal> has a no-argument constructor. All persistent classes "
 "must have a default constructor (which can be non-public) so that Hibernate "
@@ -168,21 +81,19 @@
 "<emphasis>package</emphasis> visibility for runtime proxy generation in "
 "Hibernate."
 msgstr ""
-"<literal>Cat</literal>有一个无参数的构造方法。所有的持久化类都必须有一个 默认"
-"的构造方法(可以不是public的),这样的话Hibernate就可以使用 "
-"<literal>Constructor.newInstance()</literal>来实例化它们。 我们强烈建议,在"
-"Hibernate中,为了运行期代理的生成,构造方法至少是 <emphasis>包(package)</"
+"<literal>Cat</literal> 有一个无参数的构造方法。所有的持久化类都必须有一个默认"
+"的构造方法(可以不是 public 的),这样的话 Hibernate 就可以使用 "
+"<literal>Constructor.newInstance()</literal>来实例化它们。 我们强烈建议,在 "
+"Hibernate 中,为了运行期代理的生成,构造方法至少是<emphasis>包(package)</"
 "emphasis>内可见的。"
 
 #. Tag: title
-#: persistent_classes.xml:73
 #, no-c-format
 msgid "Provide an identifier property (optional)"
 msgstr "提供一个标识属性(identifier property)(可选)"
 
 #. Tag: para
-#: persistent_classes.xml:75
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Cat</literal> has a property called <literal>id</literal>. This "
 "property maps to the primary key column of a database table. The property "
@@ -192,94 +103,85 @@
 "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</literal>有一个属性叫做<literal>id</literal>。这个属性映射数据库"
-"表的主 键字段。这个属性可以叫任何名字,其类型可以是任何的原始类型、原始类型的"
-"包装类型、 <literal>java.lang.String</literal> 或者是 <literal>java.util."
-"Date</literal>。 (如果你的遗留数据库表有联合主键,你甚至可以用一个用户自定义"
-"的类,该类拥有这些类型 的属性。参见后面的关于联合标识符的章节。)"
+"<literal>Cat</literal> 有一个属性叫做 <literal>id</literal>。这个属性映射数据"
+"库表的主 键字段。这个属性可以叫任何名字,其类型可以是任何的原始类型、原始类型"
+"的包装类型、 <literal>java.lang.String</literal> 或者是 <literal>java.util."
+"Date</literal>。(如果你的遗留数据库表有联合主键,你甚至可以用一个用户自定义"
+"的类,该类拥有这些类型的属性。参见后面的关于联合标识符的章节。)"
 
 #. Tag: para
-#: persistent_classes.xml:84
 #, 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 ""
-"标识符属性是可选的。可以不用管它,让Hibernate内部来追踪对象的识别。 但是我们"
-"并不推荐这样做。"
+"标识符属性是可选的。可以不用管它,让 Hibernate 内部来追踪对象的识别。 但是我"
+"们并不推荐这样做。"
 
 #. Tag: para
-#: persistent_classes.xml:89
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In fact, some functionality is available only to classes that declare an "
 "identifier property:"
-msgstr "实际上,一些功能只对那些声明了标识符属性的类起作用:"
+msgstr "实际上,一些功能只对那些声明了标识符属性的类起作用: "
 
 #. Tag: para
-#: persistent_classes.xml:96
 #, fuzzy, no-c-format
 msgid ""
 "Transitive reattachment for detached objects (cascade update or cascade "
-"merge) - see"
+"merge) - see <xref linkend=\"objectstate-transitive\" />"
 msgstr ""
-"托管对象的传播性再连接(级联更新或级联合并) ——参阅 <xref linkend="
+"托管对象的传播性再连接(级联更新或级联合并) — 参阅 <xref linkend="
 "\"objectstate-transitive\"/>"
 
-#. Tag: literal
-#: persistent_classes.xml:103
-#, no-c-format
-msgid "Session.saveOrUpdate()"
-msgstr "Session.saveOrUpdate()"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>Session.saveOrUpdate()</literal>"
+msgstr "<literal>Session.saveOrUpdate()</literal>"
 
-#. Tag: literal
-#: persistent_classes.xml:108
-#, no-c-format
-msgid "Session.merge()"
-msgstr "Session.merge()"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>Session.merge()</literal>"
+msgstr "<literal>Session.merge()</literal>"
 
 #. Tag: para
-#: persistent_classes.xml:113
-#, fuzzy, no-c-format
+#, 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 ""
-"我们建议你对持久化类声明命名一致的标识属性。我们还建议你使用一 个可以为空(也"
-"就是说,不是原始类型)的类型。"
+"我们建议你对持久化类声明命名一致的标识属性。我们还建议你使用一个可以为空(也"
+"就是说,不是原始类型)的类型。 "
 
 #. Tag: title
-#: persistent_classes.xml:120
 #, no-c-format
 msgid "Prefer non-final classes (optional)"
-msgstr "使用非final的类 (可选)"
+msgstr "使用非final的类(可选)"
 
 #. Tag: para
-#: persistent_classes.xml:121
 #, no-c-format
 msgid ""
 "A central feature of Hibernate, <emphasis>proxies</emphasis>, depends upon "
 "the persistent class being either non-final, or the implementation of an "
 "interface that declares all public methods."
 msgstr ""
-"<emphasis>代理(proxies)</emphasis>是Hibernate的一个重要的功能,它依赖的条件"
-"是,持久 化类或者是非final的,或者是实现了一个所有方法都声明为public的接口。"
+"<emphasis>代理(proxies)</emphasis>是 Hibernate 的一个重要的功能,它依赖的条"
+"件是,持久化类或者是非 final 的,或者是实现了一个所有方法都声明为 public 的接"
+"口。"
 
 #. Tag: para
-#: persistent_classes.xml:126
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can persist <literal>final</literal> 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</literal>类,但是"
-"你 不能使用代理来延迟关联加载,这会限制你进行性能优化的选择。"
+"你可以用 Hibernate 持久化一个没有实现任何接口的 <literal>final</literal> 类,"
+"但是你不能使用代理来延迟关联加载,这会限制你进行性能优化的选择。 "
 
 #. Tag: para
-#: persistent_classes.xml:131
 #, no-c-format
 msgid ""
 "You should also avoid declaring <literal>public final</literal> methods on "
@@ -287,19 +189,18 @@
 "final</literal> method, you must explicitly disable proxying by setting "
 "<literal>lazy=\"false\"</literal>."
 msgstr ""
-"你也应该避免在非final类中声明 <literal>public final</literal>的方法。如果你想"
-"使用一 个有<literal>public final</literal>方法的类,你必须通过设置"
-"<literal>lazy=\"false\"</literal> 来明确地禁用代理。"
+"你也应该避免在非 final 类中声明 <literal>public final</literal> 的方法。如果"
+"你想使用一个有 <literal>public final</literal> 方法的类,你必须通过设置 "
+"<literal>lazy=\"false\"</literal> 来明确地禁用代理。 "
 
 #. Tag: title
-#: persistent_classes.xml:139
 #, no-c-format
 msgid "Declare accessors and mutators for persistent fields (optional)"
-msgstr "为持久化字段声明访问器(accessors)和是否可变的标志(mutators)(可选)"
+msgstr ""
+"为持久化字段声明访问器(accessors)和是否可变的标志(mutators)(可选)"
 
 #. Tag: para
-#: persistent_classes.xml:141
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Cat</literal> declares accessor methods for all its persistent "
 "fields. Many other ORM tools directly persist instance variables. It is "
@@ -309,95 +210,71 @@
 "literal>, <literal>isFoo</literal> and <literal>setFoo</literal>. If "
 "required, you can switch to direct field access for particular properties."
 msgstr ""
-"<literal>Cat</literal>为它的所有持久化字段声明了访问方法。很多其他ORM工具直接"
-"对 实例变量进行持久化。我们相信,在关系数据库schema和类的内部数据结构之间引入"
-"间接层(原文为\"非直接\",indirection)会好一些。默认情况下Hibernate持久化"
-"JavaBeans风格的属性,认可 <literal>getFoo</literal>,<literal>isFoo</"
-"literal> 和 <literal>setFoo</literal>这种形式的方法名。 如果需要,你可以对某"
-"些特定属性实行直接字段访问。"
+"<literal>Cat</literal> 为它的所有持久化字段声明了访问方法。很多其他 ORM 工具"
+"直接对实例变量进行持久化。我们相信,在关系数据库 schema 和类的内部数据结构之"
+"间引入间接层(原文为\"非直接\",indirection)会好一些。默认情况下 Hibernate "
+"持久化 JavaBeans 风格的属性,认可  <literal>getFoo</literal>,"
+"<literal>isFoo</literal> 和 <literal>setFoo</literal> 这种形式的方法名。如果"
+"需要,你可以对某些特定属性实行直接字段访问。 "
 
 #. Tag: para
-#: persistent_classes.xml:151
 #, no-c-format
 msgid ""
 "Properties need <emphasis>not</emphasis> be declared public - Hibernate can "
 "persist a property with a default, <literal>protected</literal> or "
 "<literal>private</literal> get / set pair."
 msgstr ""
-"属性<emphasis>不需要</emphasis>要声明为public的。Hibernate可以持久化一个有 "
-"<literal>default</literal>、<literal>protected</literal>或<literal>private</"
-"literal>的get/set方法对 的属性进行持久化。"
+"属性<emphasis>不需要</emphasis>要声明为 public 的。Hibernate 可以持久化一个"
+"有 <literal>default</literal>、<literal>protected</literal> 或 "
+"<literal>private</literal> 的 get/set 方法对的属性进行持久化。"
 
 #. Tag: title
-#: persistent_classes.xml:162
 #, no-c-format
 msgid "Implementing inheritance"
 msgstr "实现继承(Inheritance)"
 
 #. Tag: para
-#: persistent_classes.xml:164
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A subclass must also observe the first and second rules. It inherits its "
 "identifier property from the superclass, <literal>Cat</literal>. For example:"
 msgstr ""
-"子类也必须遵守第一条和第二条规则。它从超类<literal>Cat</literal>继承了标识属"
-"性。"
+"子类也必须遵守第一条和第二条规则。它从超类 <literal>Cat</literal> 继承了标识"
+"属性。例如:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:169
-#, no-c-format
-msgid ""
-"<![CDATA[package eg;\n"
-"\n"
-"public class DomesticCat extends Cat {\n"
-"        private String name;\n"
-"\n"
-"        public String getName() {\n"
-"                return name;\n"
-"        }\n"
-"        protected void setName(String name) {\n"
-"                this.name=name;\n"
-"        }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: persistent_classes.xml:173
 #, no-c-format
 msgid ""
 "Implementing <literal>equals()</literal> and <literal>hashCode()</literal>"
-msgstr "实现<literal>equals()</literal>和<literal>hashCode()</literal>"
+msgstr ""
+"实现 <literal>equals()</literal> 和 <literal>hashCode()</literal> 方法:"
 
 #. Tag: para
-#: persistent_classes.xml:175
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You have to override the <literal>equals()</literal> and <literal>hashCode()"
 "</literal> methods if you:"
 msgstr ""
 "如果你有如下需求,你必须重载 <literal>equals()</literal> 和 <literal>hashCode"
-"()</literal>方法:"
+"()</literal> 方法: "
 
 #. Tag: para
-#: persistent_classes.xml:181
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "intend to put instances of persistent classes in a <literal>Set</literal> "
 "(the recommended way to represent many-valued associations); <emphasis>and</"
 "emphasis>"
 msgstr ""
-"想把持久类的实例放入<literal>Set</literal>中(当表示多值关联时,推荐这么做)"
+"想把持久类的实例放入 <literal>Set</literal> 中(当表示多值关联时,推荐这么"
+"做),<emphasis>而且</emphasis>"
 
 #. Tag: para
-#: persistent_classes.xml:188
 #, no-c-format
 msgid "intend to use reattachment of detached instances"
 msgstr "想重用脱管实例"
 
 #. Tag: para
-#: persistent_classes.xml:194
-#, fuzzy, no-c-format
+#, 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 "
@@ -405,14 +282,13 @@
 "literal> and <literal>hashCode()</literal> if you wish to have meaningful "
 "semantics for <literal>Set</literal>s."
 msgstr ""
-"Hibernate保证,仅在特定会话范围内,持久化标识(数据库的行)和Java标识是等价"
-"的。因此,一旦 我们混合了从不同会话中获取的实例,如果希望<literal>Set</"
-"literal>有明确的语义,就必 须实现<literal>equals()</literal> 和"
-"<literal>hashCode()</literal>。"
+"Hibernate 保证,仅在特定会话范围内,持久化标识(数据库的行)和 Java 标识是等"
+"价的。因此,一旦我们混合了从不同会话中获取的实例,如果希望 <literal>Set</"
+"literal> 有明确的语义,就必须实现 <literal>equals()</literal> 和  "
+"<literal>hashCode()</literal>。 "
 
 #. Tag: para
-#: persistent_classes.xml:202
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The most obvious way is to implement <literal>equals()</literal>/"
 "<literal>hashCode()</literal> by comparing the identifier value of both "
@@ -429,20 +305,20 @@
 "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 ""
-"实现<literal>equals()</literal>/<literal>hashCode()</literal>最显而易见的方法"
-"是比较两个对象 标识符的值。如果值相同,则两个对象对应于数据库的同一行,因此它"
-"们是相等的(如果都被添加到 <literal>Set</literal>,则在<literal>Set</literal>"
-"中只有一个元素)。不幸的是,对生成的标识不能 使用这种方法。Hibernate仅对那些"
-"持久化对象赋标识值,一个新创建的实例将不会有任何标识值。此外, 如果一个实例没"
-"有被保存(unsaved),并且它当前正在一个<literal>Set</literal>中,保存它将会给这"
-"个对象 赋一个标识值。如果<literal>equals()</literal> 和 <literal>hashCode()</"
-"literal>是基于标识值 实现的,则其哈希码将会改变,这违反了<literal>Set</"
-"literal>的契约。建议去Hibernate的站点阅读关于这个 问题的全部讨论。注意,这不"
-"是Hibernate的问题,而是一般的Java对象标识和Java对象等价的语义问题。"
+"实现 <literal>equals()</literal>/<literal>hashCode()</literal> 最显而易见的方"
+"法是比较两个对象 标识符的值。如果值相同,则两个对象对应于数据库的同一行,因此"
+"它们是相等的(如果都被添加到 <literal>Set</literal>,则在 <literal>Set</"
+"literal> 中只有一个元素)。不幸的是,对生成的标识不能 使用这种方法。"
+"Hibernate 仅对那些持久化对象赋标识值,一个新创建的实例将不会有任何标识值。此"
+"外, 如果一个实例没有被保存(unsaved),并且它当前正在一个 <literal>Set</"
+"literal> 中,保存它将会给这个对象赋一个标识值。如果 <literal>equals()</"
+"literal> 和 <literal>hashCode()</literal> 是基于标识值 实现的,则其哈希码将会"
+"改变,这违反了 <literal>Set</literal> 的契约。建议去 Hibernate 的站点阅读关于"
+"这个问题的全部讨论。注意,这不是 Hibernate 的问题,而是一般的 Java 对象标识"
+"和 Java 对象等价的语义问题。 "
 
 #. Tag: para
-#: persistent_classes.xml:216
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is recommended that you implement <literal>equals()</literal> and "
 "<literal>hashCode()</literal> using <emphasis>Business key equality</"
@@ -451,74 +327,42 @@
 "that would identify our instance in the real world (a <emphasis>natural</"
 "emphasis> candidate key):"
 msgstr ""
-"我们建议使用<emphasis>业务键值相等(Business key equality)</emphasis>来实现"
+"我们建议使用<emphasis>业务键值相等(Business key equality)</emphasis>来实现 "
 "<literal>equals()</literal> 和 <literal>hashCode()</literal>。业务键值相等的"
-"意思是,<literal>equals()</literal>方法 仅仅比较形成业务键的属性,它能在现实"
+"意思是,<literal>equals()</literal> 方法仅仅比较形成业务键的属性,它能在现实"
 "世界里标识我们的实例(是一个<emphasis>自然的</emphasis>候选码)。"
 
-#. Tag: programlisting
-#: persistent_classes.xml:224
-#, no-c-format
-msgid ""
-"<![CDATA[public class Cat {\n"
-"\n"
-"    ...\n"
-"    public boolean equals(Object other) {\n"
-"        if (this == other) return true;\n"
-"        if ( !(other instanceof Cat) ) return false;\n"
-"\n"
-"        final Cat cat = (Cat) other;\n"
-"\n"
-"        if ( !cat.getLitterId().equals( getLitterId() ) ) return false;\n"
-"        if ( !cat.getMother().equals( getMother() ) ) return false;\n"
-"\n"
-"        return true;\n"
-"    }\n"
-"\n"
-"    public int hashCode() {\n"
-"        int result;\n"
-"        result = getMother().hashCode();\n"
-"        result = 29 * result + getLitterId();\n"
-"        return result;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:226
 #, 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 "
+"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\"/>)。 对业务键而言,不可变或唯一的属性是不错的选择。"
+"注意,业务键不必像数据库的主键那样固定不变(参见 <xref linkend="
+"\"transactions-basics-identity\"/>)。对业务键而言,不可变或唯一的属性是不错"
+"的选择。 "
 
 #. Tag: title
-#: persistent_classes.xml:236
 #, no-c-format
 msgid "Dynamic models"
-msgstr "动态模型(Dynamic models)"
+msgstr "动态模型(Dynamic models)"
 
 #. Tag: title
-#: persistent_classes.xml:239
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "注意"
 
-#. Tag: emphasis
-#: persistent_classes.xml:241
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
-"The following features are currently considered experimental and may change "
-"in the near future."
-msgstr "注意,以下特性在当前处于试验阶段,将来可能会有变化。"
+"<emphasis>The following features are currently considered experimental and "
+"may change in the near future.</emphasis>"
+msgstr ""
+"<emphasis>注意,以下特性在当前处于试验阶段,将来可能会有变化。</emphasis>"
 
 #. Tag: para
-#: persistent_classes.xml:246
-#, fuzzy, no-c-format
+#, 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 "
@@ -526,128 +370,57 @@
 "and the representation of entities as DOM4J trees. With this approach, you "
 "do not write persistent classes, only mapping files."
 msgstr ""
-"运行期的持久化实体没有必要一定表示为像POJO类或JavaBean对象那样的形式。"
-"Hibernate也支持动态模型 (在运行期使用<literal>Map</literal>的<literal>Map</"
-"literal>)和象DOM4J的树模型那 样的实体表示。使用这种方法,你不用写持久化类,"
-"只写映射文件就行了。"
+"运行期的持久化实体没有必要一定表示为像 POJO 类或 JavaBean 对象那样的形式。"
+"Hibernate 也支持动态模型 (在运行期使用 <literal>Map</literal> 的 "
+"<literal>Map</literal>)和象 DOM4J 的树模型那样的实体表示。使用这种方法,你不"
+"用写持久化类,只写映射文件就行了。 "
 
 #. Tag: para
-#: persistent_classes.xml:254
 #, 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>SessionFactory</"
 "literal> using the <literal>default_entity_mode</literal> configuration "
-"option (see <xref linkend=\"configuration-optional-properties\"/>)."
+"option (see <xref linkend=\"configuration-optional-properties\" />)."
 msgstr ""
-"Hibernate默认工作在普通POJO模式。你可以使用配置选项"
-"<literal>default_entity_mode</literal>, 对特定的<literal>SessionFactory</"
-"literal>,设置一个默认的实体表示模式。 (参见<xref linkend=\"configuration-"
-"optional-properties\"/>。)"
+"Hibernate 默认工作在普通 POJO 模式。你可以使用配置选项 "
+"<literal>default_entity_mode</literal>, 对特定的 <literal>SessionFactory</"
+"literal>,设置一个默认的实体表示模式。(参见 <xref linkend=\"configuration-"
+"optional-properties\"/>) "
 
 #. Tag: para
-#: persistent_classes.xml:261
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following examples demonstrate the representation using <literal>Map</"
 "literal>s. First, in the mapping file an <literal>entity-name</literal> has "
 "to be declared instead of, or in addition to, a class name:"
 msgstr ""
-"下面是用<literal>Map</literal>来表示的例子。首先,在映射文件中,要声明 "
-"<literal>entity-name</literal>来代替一个类名(或作为一种附属)。"
+"下面是用 <literal>Map</literal> 来表示的例子。首先,在映射文件中,要声明  "
+"<literal>entity-name</literal> 来代替一个类名(或作为一种附属)。 "
 
-#. Tag: programlisting
-#: persistent_classes.xml:267
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"\n"
-"    <class entity-name=\"Customer\">\n"
-"\n"
-"        <id name=\"id\"\n"
-"            type=\"long\"\n"
-"            column=\"ID\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"\n"
-"        <property name=\"name\"\n"
-"            column=\"NAME\"\n"
-"            type=\"string\"/>\n"
-"\n"
-"        <property name=\"address\"\n"
-"            column=\"ADDRESS\"\n"
-"            type=\"string\"/>\n"
-"\n"
-"        <many-to-one name=\"organization\"\n"
-"            column=\"ORGANIZATION_ID\"\n"
-"            class=\"Organization\"/>\n"
-"\n"
-"        <bag name=\"orders\"\n"
-"            inverse=\"true\"\n"
-"            lazy=\"false\"\n"
-"            cascade=\"all\">\n"
-"            <key column=\"CUSTOMER_ID\"/>\n"
-"            <one-to-many class=\"Order\"/>\n"
-"        </bag>\n"
-"\n"
-"    </class>\n"
-"    \n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: persistent_classes.xml:269
-#, 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 ""
-"注意,虽然是用目标类名来声明关联的,但是关联的目标类型除了是POJO之外,也可以 "
-"是一个动态的实体。"
+"注意,虽然是用目标类名来声明关联的,但是关联的目标类型除了是 POJO 之外,也可"
+"以是一个动态的实体。 "
 
 #. Tag: para
-#: persistent_classes.xml:276
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "After setting the default entity mode to <literal>dynamic-map</literal> for "
 "the <literal>SessionFactory</literal>, you can, at runtime, work with "
 "<literal>Map</literal>s of <literal>Map</literal>s:"
 msgstr ""
-"在使用<literal>dynamic-map</literal>为<literal>SessionFactory</literal> 设置"
-"了默认的实体模式之后,可以在运行期使用<literal>Map</literal>的 <literal>Map</"
-"literal>。"
+"在使用 <literal>dynamic-map</literal> 为 <literal>SessionFactory</literal> 设"
+"置了默认的实体模式之后,可以在运行期使用 <literal>Map</literal> 的 "
+"<literal>Map</literal>:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:282
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session s = openSession();\n"
-"Transaction tx = s.beginTransaction();\n"
-"Session s = openSession();\n"
-"\n"
-"// Create a customer\n"
-"Map david = new HashMap();\n"
-"david.put(\"name\", \"David\");\n"
-"\n"
-"// Create an organization\n"
-"Map foobar = new HashMap();\n"
-"foobar.put(\"name\", \"Foobar Inc.\");\n"
-"\n"
-"// Link both\n"
-"david.put(\"organization\", foobar);\n"
-"\n"
-"// Save both\n"
-"s.save(\"Customer\", david);\n"
-"s.save(\"Organization\", foobar);\n"
-"\n"
-"tx.commit();\n"
-"s.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: persistent_classes.xml:284
-#, 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 "
@@ -656,40 +429,20 @@
 "implementation on top later on."
 msgstr ""
 "动态映射的好处是,变化所需要的时间少了,因为原型不需要实现实体类。然而,你无"
-"法进行 编译期的类型检查,并可能由此会处理很多的运行期异常。幸亏有了Hibernate"
-"映射,它使得数 据库的schema能容易的规格化和合理化,并允许稍后在此之上添加合适"
-"的领域模型实现。"
+"法进行编译期的类型检查,并可能由此会处理很多的运行期异常。幸亏有了 Hibernate "
+"映射,它使得数据库的 schema 能容易的规格化和合理化,并允许稍后在此之上添加合"
+"适的领域模型实现。 "
 
 #. Tag: para
-#: persistent_classes.xml:292
 #, no-c-format
 msgid ""
 "Entity representation modes can also be set on a per <literal>Session</"
 "literal> basis:"
-msgstr "实体表示模式也能在每个<literal>Session</literal>的基础上设置:"
+msgstr "实体表示模式也能在每个 <literal>Session</literal> 的基础上设置:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:297
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Session dynamicSession = pojoSession.getSession(EntityMode.MAP);\n"
-"\n"
-"// Create a customer\n"
-"Map david = new HashMap();\n"
-"david.put(\"name\", \"David\");\n"
-"dynamicSession.save(\"Customer\", david);\n"
-"...\n"
-"dynamicSession.flush();\n"
-"dynamicSession.close()\n"
-"...\n"
-"// Continue on pojoSession\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: persistent_classes.xml:300
-#, fuzzy, no-c-format
-msgid ""
 "Please note that the call to <literal>getSession()</literal> using an "
 "<literal>EntityMode</literal> is on the <literal>Session</literal> API, not "
 "the <literal>SessionFactory</literal>. That way, the new <literal>Session</"
@@ -699,30 +452,27 @@
 "literal>, and also leave the transaction and connection handling to the "
 "primary unit of work."
 msgstr ""
-"请注意,用<literal>EntityMode</literal>调用<literal>getSession()</literal>是"
-"在 <literal>Session</literal>的API中,而不是<literal>SessionFactory</"
-"literal>。 这样,新的<literal>Session</literal>共享底层的JDBC连接,事务,和其"
-"他的上下文信 息。这意味着,你不需要在第二个<literal>Session</literal>中调用 "
-"<literal>flush()</literal>和<literal>close()</literal>,同样的,把事务和连接"
-"的处理 交给原来的工作单元。"
+"请注意,用 <literal>EntityMode</literal> 调用 <literal>getSession()</"
+"literal> 是在 <literal>Session</literal> 的 API 中,而不是 "
+"<literal>SessionFactory</literal>。 这样,新的 <literal>Session</literal> 共"
+"享底层的 JDBC 连接,事务,和其他的上下文信息。这意味着,你不需要在第二个 "
+"<literal>Session</literal> 中调用 <literal>flush()</literal> 和 "
+"<literal>close()</literal>,同样的,把事务和连接的处理交给原来的工作单元。 "
 
 #. Tag: para
-#: persistent_classes.xml:310
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "More information about the XML representation capabilities can be found in "
-"<xref linkend=\"xml\"/>."
-msgstr "关于XML表示能力的更多信息可以在<xref linkend=\"xml\"/>中找到。"
+"<xref linkend=\"xml\" />."
+msgstr "关于 XML 表示能力的更多信息可以在 <xref linkend=\"xml\"/> 中找到。 "
 
 #. Tag: title
-#: persistent_classes.xml:318
 #, no-c-format
 msgid "Tuplizers"
-msgstr "元组片断映射(Tuplizers)"
+msgstr "元组片断映射(Tuplizers)"
 
 #. Tag: para
-#: persistent_classes.xml:320
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>org.hibernate.tuple.Tuplizer</literal>, and its sub-interfaces, are "
 "responsible for managing a particular representation of a piece of data "
@@ -736,16 +486,16 @@
 msgstr ""
 "<literal>org.hibernate.tuple.Tuplizer</literal>,以及其子接口,负责根据给定的"
 "<literal>org.hibernate.EntityMode</literal>,来复现片断数据。如果给定的片断数"
-"据被认为其是一种数据结构,\"tuplizer\"就是一个知道如何创建这样的数据结构,以"
-"及如何给这个数据结构赋值的东西。比如说,对于POJO这种Entity Mode,对应的"
-"tuplizer知道通过其构造方法来创建一个POJO,再通过其属性访问器来访问POJO属性。"
-"有两大类高层Tuplizer,分别是<literal>org.hibernate.tuple.entity."
-"EntityTuplizer</literal> 和<literal>org.hibernate.tuple.entity."
-"ComponentTuplizer</literal>接口。<literal>EntityTuplizer</literal>负责管理上"
-"面提到的实体的契约,而<literal>ComponentTuplizer</literal>则是针对组件的。"
+"据被认为其是一种数据结构,\"tuplizer\" 就是一个知道如何创建这样的数据结构,以"
+"及如何给这个数据结构赋值的东西。比如说,对于 POJO 这种 Entity Mode,对应的 "
+"tuplizer 知道通过其构造方法来创建一个 POJO,再通过其属性访问器来访问 POJO 属"
+"性。有两大类高层 Tuplizer,分别是<literal>org.hibernate.tuple.entity."
+"EntityTuplizer</literal> 和 <literal>org.hibernate.tuple.entity."
+"ComponentTuplizer</literal> 接口。<literal>EntityTuplizer</literal> 负责管理"
+"上面提到的实体的契约,而 <literal>ComponentTuplizer</literal> 则是针对组件"
+"的。 "
 
 #. Tag: para
-#: persistent_classes.xml:330
 #, no-c-format
 msgid ""
 "There are two high-level types of Tuplizers, represented by the <literal>org."
@@ -755,10 +505,13 @@
 "mentioned contracts in regards to entities, while "
 "<literal>ComponentTuplizer</literal>s do the same for components."
 msgstr ""
+"有两种高层类型的 Tuplizer,分别由 <literal>org.hibernate.tuple.entity."
+"EntityTuplizer</literal> 和 <literal>org.hibernate.tuple.component."
+"ComponentTuplizer</literal> 接口代表。<literal>EntityTuplizer</literal> 负责"
+"管理和实体相关的上述合约,而<literal>ComponentTuplizer</literal> 则负责组件。"
 
 #. Tag: para
-#: persistent_classes.xml:338
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Users can also plug in their own tuplizers. Perhaps you require that a "
 "<literal>java.util.Map</literal> implementation other than <literal>java."
@@ -769,61 +522,19 @@
 "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>的<literal>java.util.Map</"
-"literal>实现;或许您需要与默认策略不同的代理生成策略(proxy generation "
-"strategy)。通过自定义tuplizer实现,这两个目标您都可以达到。Tuplizer定义被附加"
-"到它们期望管理的entity或者component映射中。回到我们的customer entity例子:"
+"用户也可以插入其自定义的 tuplizer。或许您需要一种不同于 dynamic-map entity-"
+"mode 中使用的 <literal>java.util.HashMap</literal> 的 <literal>java.util."
+"Map</literal> 实现;或许您需要与默认策略不同的代理生成策略(proxy generation "
+"strategy)。通过自定义 tuplizer 实现,这两个目标您都可以达到。Tuplizer 定义被"
+"附加到它们期望管理的 entity 或者 component 映射中。回到我们的 customer "
+"entity 例子: "
 
-#. Tag: programlisting
-#: persistent_classes.xml:347
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping>\n"
-"    <class entity-name=\"Customer\">\n"
-"        <!--\n"
-"            Override the dynamic-map entity-mode\n"
-"            tuplizer for the customer entity\n"
-"        -->\n"
-"        <tuplizer entity-mode=\"dynamic-map\"\n"
-"                class=\"CustomMapTuplizerImpl\"/>\n"
-"\n"
-"        <id name=\"id\" type=\"long\" column=\"ID\">\n"
-"            <generator class=\"sequence\"/>\n"
-"        </id>\n"
-"\n"
-"        <!-- other properties -->\n"
-"        ...\n"
-"    </class>\n"
-"</hibernate-mapping>\n"
-"\n"
-"\n"
-"public class CustomMapTuplizerImpl\n"
-"        extends org.hibernate.tuple.entity.DynamicMapEntityTuplizer {\n"
-"    // override the buildInstantiator() method to plug in our custom map...\n"
-"    protected final Instantiator buildInstantiator(\n"
-"            org.hibernate.mapping.PersistentClass mappingInfo) {\n"
-"        return new CustomMapInstantiator( mappingInfo );\n"
-"    }\n"
-"\n"
-"    private static final class CustomMapInstantiator\n"
-"            extends org.hibernate.tuple.DynamicMapInstantitor {\n"
-"        // override the generateMap() method to return our custom map...\n"
-"            protected final Map generateMap() {\n"
-"                    return new CustomMap();\n"
-"            }\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: persistent_classes.xml:354
 #, no-c-format
 msgid "EntityNameResolvers"
-msgstr ""
+msgstr "EntityNameResolvers"
 
 #. Tag: para
-#: persistent_classes.xml:356
 #, no-c-format
 msgid ""
 "The <interfacename>org.hibernate.EntityNameResolver</interfacename> "
@@ -840,158 +551,35 @@
 "dynamicentity.tuplizer2</package>. Here is some of the code from that "
 "package for illustration."
 msgstr ""
+"<interfacename>org.hibernate.EntityNameResolver</interfacename> 接口是一个解"
+"析给定实体实例的实体名称的合约。这个接口定义了一个单一的方法 "
+"<methodname>resolveEntityName</methodname>,它传递实体实例并预期返回合适的实"
+"体名称(null 指明解析器不知道如何解析给定实体实例的实体名称)。一般说来,"
+"<interfacename>org.hibernate.EntityNameResolver</interfacename> 在动态模型里"
+"最为有用。其中的例子是把代理接口用作你的域模型。Hibernate Test Suite 在 "
+"<package>org.hibernate.test.dynamicentity.tuplizer2</package> 下有具有完全相"
+"同风格的例子。下面是该包里的一些代码:"
 
-#. Tag: programlisting
-#: persistent_classes.xml:368
-#, no-c-format
-msgid ""
-"/**\n"
-" * A very trivial JDK Proxy InvocationHandler implementation where we proxy "
-"an interface as\n"
-" * the domain model and simply store persistent state in an internal Map.  "
-"This is an extremely\n"
-" * trivial example meant only for illustration.\n"
-" */\n"
-"public final class DataProxyHandler implements InvocationHandler {\n"
-"        private String entityName;\n"
-"        private HashMap data = new HashMap();\n"
-"\n"
-"        public DataProxyHandler(String entityName, Serializable id) {\n"
-"                this.entityName = entityName;\n"
-"                data.put( \"Id\", id );\n"
-"        }\n"
-"\n"
-"        public Object invoke(Object proxy, Method method, Object[] args) "
-"throws Throwable {\n"
-"                String methodName = method.getName();\n"
-"                if ( methodName.startsWith( \"set\" ) ) {\n"
-"                        String propertyName = methodName.substring( 3 );\n"
-"                        data.put( propertyName, args[0] );\n"
-"                }\n"
-"                else if ( methodName.startsWith( \"get\" ) ) {\n"
-"                        String propertyName = methodName.substring( 3 );\n"
-"                        return data.get( propertyName );\n"
-"                }\n"
-"                else if ( \"toString\".equals( methodName ) ) {\n"
-"                        return entityName + \"#\" + data.get( \"Id\" );\n"
-"                }\n"
-"                else if ( \"hashCode\".equals( methodName ) ) {\n"
-"                        return new Integer( this.hashCode() );\n"
-"                }\n"
-"                return null;\n"
-"        }\n"
-"\n"
-"        public String getEntityName() {\n"
-"                return entityName;\n"
-"        }\n"
-"\n"
-"        public HashMap getData() {\n"
-"                return data;\n"
-"        }\n"
-"}\n"
-"\n"
-"/**\n"
-" *\n"
-" */\n"
-"public class ProxyHelper {\n"
-"    public static String extractEntityName(Object object) {\n"
-"        // Our custom java.lang.reflect.Proxy instances actually bundle\n"
-"        // their appropriate entity name, so we simply extract it from "
-"there\n"
-"        // if this represents one of our proxies; otherwise, we return null\n"
-"        if ( Proxy.isProxyClass( object.getClass() ) ) {\n"
-"            InvocationHandler handler = Proxy.getInvocationHandler"
-"( object );\n"
-"            if ( DataProxyHandler.class.isAssignableFrom( handler.getClass"
-"() ) ) {\n"
-"                DataProxyHandler myHandler = ( DataProxyHandler ) handler;\n"
-"                return myHandler.getEntityName();\n"
-"            }\n"
-"        }\n"
-"        return null;\n"
-"    }\n"
-"\n"
-"    // various other utility methods ....\n"
-"\n"
-"}\n"
-"\n"
-"/**\n"
-" * The EntityNameResolver implementation.\n"
-" * IMPL NOTE : An EntityNameResolver really defines a strategy for how "
-"entity names should be\n"
-" * resolved.  Since this particular impl can handle resolution for all of "
-"our entities we want to\n"
-" * take advantage of the fact that SessionFactoryImpl keeps these in a Set "
-"so that we only ever\n"
-" * have one instance registered.  Why?  Well, when it comes time to resolve "
-"an entity name,\n"
-" * Hibernate must iterate over all the registered resolvers.  So keeping "
-"that number down\n"
-" * helps that process be as speedy as possible.  Hence the equals and "
-"hashCode impls\n"
-" */\n"
-"public class MyEntityNameResolver implements EntityNameResolver {\n"
-"    public static final MyEntityNameResolver INSTANCE = new "
-"MyEntityNameResolver();\n"
-"\n"
-"    public String resolveEntityName(Object entity) {\n"
-"        return ProxyHelper.extractEntityName( entity );\n"
-"    }\n"
-"\n"
-"    public boolean equals(Object obj) {\n"
-"        return getClass().equals( obj.getClass() );\n"
-"    }\n"
-"\n"
-"    public int hashCode() {\n"
-"        return getClass().hashCode();\n"
-"    }\n"
-"}\n"
-"\n"
-"public class MyEntityTuplizer extends PojoEntityTuplizer {\n"
-"        public MyEntityTuplizer(EntityMetamodel entityMetamodel, "
-"PersistentClass mappedEntity) {\n"
-"                super( entityMetamodel, mappedEntity );\n"
-"        }\n"
-"\n"
-"        public EntityNameResolver[] getEntityNameResolvers() {\n"
-"                return new EntityNameResolver[] { MyEntityNameResolver."
-"INSTANCE };\n"
-"        }\n"
-"\n"
-"    public String determineConcreteSubclassEntityName(Object entityInstance, "
-"SessionFactoryImplementor factory) {\n"
-"        String entityName = ProxyHelper.extractEntityName"
-"( entityInstance );\n"
-"        if ( entityName == null ) {\n"
-"            entityName = super.determineConcreteSubclassEntityName"
-"( entityInstance, factory );\n"
-"        }\n"
-"        return entityName;\n"
-"    }\n"
-"\n"
-"    ...\n"
-"}"
-msgstr ""
-
 #. Tag: para
-#: persistent_classes.xml:370
 #, no-c-format
 msgid ""
 "In order to register an <interfacename>org.hibernate.EntityNameResolver</"
 "interfacename> users must either:"
 msgstr ""
+"为了注册 <interfacename>org.hibernate.EntityNameResolver</interfacename>,用"
+"户必须:"
 
 #. Tag: para
-#: persistent_classes.xml:374
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Implement a custom <link linkend=\"persistent-classes-tuplizers\">Tuplizer</"
 "link>, implementing the <methodname>getEntityNameResolvers</methodname> "
 "method."
 msgstr ""
+"实现自定义的 <xref linkend=\"persistent-classes-tuplizers\"/> 并实现 "
+"<methodname>getEntityNameResolvers</methodname> 方法。 "
 
 #. Tag: para
-#: persistent_classes.xml:380
 #, no-c-format
 msgid ""
 "Register it with the <classname>org.hibernate.impl.SessionFactoryImpl</"
@@ -999,10 +587,718 @@
 "hibernate.SessionFactory</interfacename>) using the "
 "<methodname>registerEntityNameResolver</methodname> method."
 msgstr ""
+"用 <methodname>registerEntityNameResolver</methodname> 方法注册到 "
+"<classname>org.hibernate.impl.SessionFactoryImpl</classname>(它是 "
+"<interfacename>org.hibernate.SessionFactory</interfacename> 的实现类)。"
 
-#~ msgid "There are four main rules to follow here:"
-#~ msgstr "这里要遵循四条主要的规则:"
+#~ msgid ""
+#~ "<![CDATA[package eg;\n"
+#~ "import java.util.Set;\n"
+#~ "import java.util.Date;\n"
+#~ "\n"
+#~ "public class Cat {\n"
+#~ "    private Long id; // identifier\n"
+#~ "\n"
+#~ "    private Date birthdate;\n"
+#~ "    private Color color;\n"
+#~ "    private char sex;\n"
+#~ "    private float weight;\n"
+#~ "    private int litterId;\n"
+#~ "\n"
+#~ "    private Cat mother;\n"
+#~ "    private Set kittens = new HashSet();\n"
+#~ "\n"
+#~ "    private void setId(Long id) {\n"
+#~ "        this.id=id;\n"
+#~ "    }\n"
+#~ "    public Long getId() {\n"
+#~ "        return id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setBirthdate(Date date) {\n"
+#~ "        birthdate = date;\n"
+#~ "    }\n"
+#~ "    public Date getBirthdate() {\n"
+#~ "        return birthdate;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setWeight(float weight) {\n"
+#~ "        this.weight = weight;\n"
+#~ "    }\n"
+#~ "    public float getWeight() {\n"
+#~ "        return weight;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public Color getColor() {\n"
+#~ "        return color;\n"
+#~ "    }\n"
+#~ "    void setColor(Color color) {\n"
+#~ "        this.color = color;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setSex(char sex) {\n"
+#~ "        this.sex=sex;\n"
+#~ "    }\n"
+#~ "    public char getSex() {\n"
+#~ "        return sex;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setLitterId(int id) {\n"
+#~ "        this.litterId = id;\n"
+#~ "    }\n"
+#~ "    public int getLitterId() {\n"
+#~ "        return litterId;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setMother(Cat mother) {\n"
+#~ "        this.mother = mother;\n"
+#~ "    }\n"
+#~ "    public Cat getMother() {\n"
+#~ "        return mother;\n"
+#~ "    }\n"
+#~ "    void setKittens(Set kittens) {\n"
+#~ "        this.kittens = kittens;\n"
+#~ "    }\n"
+#~ "    public Set getKittens() {\n"
+#~ "        return kittens;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    // addKitten not needed by Hibernate\n"
+#~ "    public void addKitten(Cat kitten) {\n"
+#~ "            kitten.setMother(this);\n"
+#~ "        kitten.setLitterId( kittens.size() ); \n"
+#~ "        kittens.add(kitten);\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package eg;\n"
+#~ "import java.util.Set;\n"
+#~ "import java.util.Date;\n"
+#~ "\n"
+#~ "public class Cat {\n"
+#~ "    private Long id; // identifier\n"
+#~ "\n"
+#~ "    private Date birthdate;\n"
+#~ "    private Color color;\n"
+#~ "    private char sex;\n"
+#~ "    private float weight;\n"
+#~ "    private int litterId;\n"
+#~ "\n"
+#~ "    private Cat mother;\n"
+#~ "    private Set kittens = new HashSet();\n"
+#~ "\n"
+#~ "    private void setId(Long id) {\n"
+#~ "        this.id=id;\n"
+#~ "    }\n"
+#~ "    public Long getId() {\n"
+#~ "        return id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setBirthdate(Date date) {\n"
+#~ "        birthdate = date;\n"
+#~ "    }\n"
+#~ "    public Date getBirthdate() {\n"
+#~ "        return birthdate;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setWeight(float weight) {\n"
+#~ "        this.weight = weight;\n"
+#~ "    }\n"
+#~ "    public float getWeight() {\n"
+#~ "        return weight;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public Color getColor() {\n"
+#~ "        return color;\n"
+#~ "    }\n"
+#~ "    void setColor(Color color) {\n"
+#~ "        this.color = color;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setSex(char sex) {\n"
+#~ "        this.sex=sex;\n"
+#~ "    }\n"
+#~ "    public char getSex() {\n"
+#~ "        return sex;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setLitterId(int id) {\n"
+#~ "        this.litterId = id;\n"
+#~ "    }\n"
+#~ "    public int getLitterId() {\n"
+#~ "        return litterId;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    void setMother(Cat mother) {\n"
+#~ "        this.mother = mother;\n"
+#~ "    }\n"
+#~ "    public Cat getMother() {\n"
+#~ "        return mother;\n"
+#~ "    }\n"
+#~ "    void setKittens(Set kittens) {\n"
+#~ "        this.kittens = kittens;\n"
+#~ "    }\n"
+#~ "    public Set getKittens() {\n"
+#~ "        return kittens;\n"
+#~ "    }\n"
+#~ "    \n"
+#~ "    // addKitten not needed by Hibernate\n"
+#~ "    public void addKitten(Cat kitten) {\n"
+#~ "            kitten.setMother(this);\n"
+#~ "        kitten.setLitterId( kittens.size() ); \n"
+#~ "        kittens.add(kitten);\n"
+#~ "    }\n"
+#~ "}]]>"
 
 #~ msgid ""
-#~ "TODO: Document user-extension framework in the property and proxy packages"
-#~ msgstr "TODO:property和proxy包里的用户扩展框架文档。"
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "public class DomesticCat extends Cat {\n"
+#~ "        private String name;\n"
+#~ "\n"
+#~ "        public String getName() {\n"
+#~ "                return name;\n"
+#~ "        }\n"
+#~ "        protected void setName(String name) {\n"
+#~ "                this.name=name;\n"
+#~ "        }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package eg;\n"
+#~ "\n"
+#~ "public class DomesticCat extends Cat {\n"
+#~ "        private String name;\n"
+#~ "\n"
+#~ "        public String getName() {\n"
+#~ "                return name;\n"
+#~ "        }\n"
+#~ "        protected void setName(String name) {\n"
+#~ "                this.name=name;\n"
+#~ "        }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[public class Cat {\n"
+#~ "\n"
+#~ "    ...\n"
+#~ "    public boolean equals(Object other) {\n"
+#~ "        if (this == other) return true;\n"
+#~ "        if ( !(other instanceof Cat) ) return false;\n"
+#~ "\n"
+#~ "        final Cat cat = (Cat) other;\n"
+#~ "\n"
+#~ "        if ( !cat.getLitterId().equals( getLitterId() ) ) return false;\n"
+#~ "        if ( !cat.getMother().equals( getMother() ) ) return false;\n"
+#~ "\n"
+#~ "        return true;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public int hashCode() {\n"
+#~ "        int result;\n"
+#~ "        result = getMother().hashCode();\n"
+#~ "        result = 29 * result + getLitterId();\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[public class Cat {\n"
+#~ "\n"
+#~ "    ...\n"
+#~ "    public boolean equals(Object other) {\n"
+#~ "        if (this == other) return true;\n"
+#~ "        if ( !(other instanceof Cat) ) return false;\n"
+#~ "\n"
+#~ "        final Cat cat = (Cat) other;\n"
+#~ "\n"
+#~ "        if ( !cat.getLitterId().equals( getLitterId() ) ) return false;\n"
+#~ "        if ( !cat.getMother().equals( getMother() ) ) return false;\n"
+#~ "\n"
+#~ "        return true;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public int hashCode() {\n"
+#~ "        int result;\n"
+#~ "        result = getMother().hashCode();\n"
+#~ "        result = 29 * result + getLitterId();\n"
+#~ "        return result;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class entity-name=\"Customer\">\n"
+#~ "\n"
+#~ "        <id name=\"id\"\n"
+#~ "            type=\"long\"\n"
+#~ "            column=\"ID\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property name=\"name\"\n"
+#~ "            column=\"NAME\"\n"
+#~ "            type=\"string\"/>\n"
+#~ "\n"
+#~ "        <property name=\"address\"\n"
+#~ "            column=\"ADDRESS\"\n"
+#~ "            type=\"string\"/>\n"
+#~ "\n"
+#~ "        <many-to-one name=\"organization\"\n"
+#~ "            column=\"ORGANIZATION_ID\"\n"
+#~ "            class=\"Organization\"/>\n"
+#~ "\n"
+#~ "        <bag name=\"orders\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            lazy=\"false\"\n"
+#~ "            cascade=\"all\">\n"
+#~ "            <key column=\"CUSTOMER_ID\"/>\n"
+#~ "            <one-to-many class=\"Order\"/>\n"
+#~ "        </bag>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "    \n"
+#~ "</hibernate-mapping>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "\n"
+#~ "    <class entity-name=\"Customer\">\n"
+#~ "\n"
+#~ "        <id name=\"id\"\n"
+#~ "            type=\"long\"\n"
+#~ "            column=\"ID\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <property name=\"name\"\n"
+#~ "            column=\"NAME\"\n"
+#~ "            type=\"string\"/>\n"
+#~ "\n"
+#~ "        <property name=\"address\"\n"
+#~ "            column=\"ADDRESS\"\n"
+#~ "            type=\"string\"/>\n"
+#~ "\n"
+#~ "        <many-to-one name=\"organization\"\n"
+#~ "            column=\"ORGANIZATION_ID\"\n"
+#~ "            class=\"Organization\"/>\n"
+#~ "\n"
+#~ "        <bag name=\"orders\"\n"
+#~ "            inverse=\"true\"\n"
+#~ "            lazy=\"false\"\n"
+#~ "            cascade=\"all\">\n"
+#~ "            <key column=\"CUSTOMER_ID\"/>\n"
+#~ "            <one-to-many class=\"Order\"/>\n"
+#~ "        </bag>\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "    \n"
+#~ "</hibernate-mapping>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session s = openSession();\n"
+#~ "Transaction tx = s.beginTransaction();\n"
+#~ "Session s = openSession();\n"
+#~ "\n"
+#~ "// Create a customer\n"
+#~ "Map david = new HashMap();\n"
+#~ "david.put(\"name\", \"David\");\n"
+#~ "\n"
+#~ "// Create an organization\n"
+#~ "Map foobar = new HashMap();\n"
+#~ "foobar.put(\"name\", \"Foobar Inc.\");\n"
+#~ "\n"
+#~ "// Link both\n"
+#~ "david.put(\"organization\", foobar);\n"
+#~ "\n"
+#~ "// Save both\n"
+#~ "s.save(\"Customer\", david);\n"
+#~ "s.save(\"Organization\", foobar);\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "s.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session s = openSession();\n"
+#~ "Transaction tx = s.beginTransaction();\n"
+#~ "Session s = openSession();\n"
+#~ "\n"
+#~ "// Create a customer\n"
+#~ "Map david = new HashMap();\n"
+#~ "david.put(\"name\", \"David\");\n"
+#~ "\n"
+#~ "// Create an organization\n"
+#~ "Map foobar = new HashMap();\n"
+#~ "foobar.put(\"name\", \"Foobar Inc.\");\n"
+#~ "\n"
+#~ "// Link both\n"
+#~ "david.put(\"organization\", foobar);\n"
+#~ "\n"
+#~ "// Save both\n"
+#~ "s.save(\"Customer\", david);\n"
+#~ "s.save(\"Organization\", foobar);\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "s.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session dynamicSession = pojoSession.getSession(EntityMode."
+#~ "MAP);\n"
+#~ "\n"
+#~ "// Create a customer\n"
+#~ "Map david = new HashMap();\n"
+#~ "david.put(\"name\", \"David\");\n"
+#~ "dynamicSession.save(\"Customer\", david);\n"
+#~ "...\n"
+#~ "dynamicSession.flush();\n"
+#~ "dynamicSession.close()\n"
+#~ "...\n"
+#~ "// Continue on pojoSession\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session dynamicSession = pojoSession.getSession(EntityMode."
+#~ "MAP);\n"
+#~ "\n"
+#~ "// Create a customer\n"
+#~ "Map david = new HashMap();\n"
+#~ "david.put(\"name\", \"David\");\n"
+#~ "dynamicSession.save(\"Customer\", david);\n"
+#~ "...\n"
+#~ "dynamicSession.flush();\n"
+#~ "dynamicSession.close()\n"
+#~ "...\n"
+#~ "// Continue on pojoSession\n"
+#~ "]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "    <class entity-name=\"Customer\">\n"
+#~ "        <!--\n"
+#~ "            Override the dynamic-map entity-mode\n"
+#~ "            tuplizer for the customer entity\n"
+#~ "        -->\n"
+#~ "        <tuplizer entity-mode=\"dynamic-map\"\n"
+#~ "                class=\"CustomMapTuplizerImpl\"/>\n"
+#~ "\n"
+#~ "        <id name=\"id\" type=\"long\" column=\"ID\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <!-- other properties -->\n"
+#~ "        ...\n"
+#~ "    </class>\n"
+#~ "</hibernate-mapping>\n"
+#~ "\n"
+#~ "\n"
+#~ "public class CustomMapTuplizerImpl\n"
+#~ "        extends org.hibernate.tuple.entity.DynamicMapEntityTuplizer {\n"
+#~ "    // override the buildInstantiator() method to plug in our custom "
+#~ "map...\n"
+#~ "    protected final Instantiator buildInstantiator(\n"
+#~ "            org.hibernate.mapping.PersistentClass mappingInfo) {\n"
+#~ "        return new CustomMapInstantiator( mappingInfo );\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    private static final class CustomMapInstantiator\n"
+#~ "            extends org.hibernate.tuple.DynamicMapInstantitor {\n"
+#~ "        // override the generateMap() method to return our custom map...\n"
+#~ "            protected final Map generateMap() {\n"
+#~ "                    return new CustomMap();\n"
+#~ "            }\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[<hibernate-mapping>\n"
+#~ "    <class entity-name=\"Customer\">\n"
+#~ "        <!--\n"
+#~ "            Override the dynamic-map entity-mode\n"
+#~ "            tuplizer for the customer entity\n"
+#~ "        -->\n"
+#~ "        <tuplizer entity-mode=\"dynamic-map\"\n"
+#~ "                class=\"CustomMapTuplizerImpl\"/>\n"
+#~ "\n"
+#~ "        <id name=\"id\" type=\"long\" column=\"ID\">\n"
+#~ "            <generator class=\"sequence\"/>\n"
+#~ "        </id>\n"
+#~ "\n"
+#~ "        <!-- other properties -->\n"
+#~ "        ...\n"
+#~ "    </class>\n"
+#~ "</hibernate-mapping>\n"
+#~ "\n"
+#~ "\n"
+#~ "public class CustomMapTuplizerImpl\n"
+#~ "        extends org.hibernate.tuple.entity.DynamicMapEntityTuplizer {\n"
+#~ "    // override the buildInstantiator() method to plug in our custom "
+#~ "map...\n"
+#~ "    protected final Instantiator buildInstantiator(\n"
+#~ "            org.hibernate.mapping.PersistentClass mappingInfo) {\n"
+#~ "        return new CustomMapInstantiator( mappingInfo );\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    private static final class CustomMapInstantiator\n"
+#~ "            extends org.hibernate.tuple.DynamicMapInstantitor {\n"
+#~ "        // override the generateMap() method to return our custom map...\n"
+#~ "            protected final Map generateMap() {\n"
+#~ "                    return new CustomMap();\n"
+#~ "            }\n"
+#~ "    }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "/**\n"
+#~ " * A very trivial JDK Proxy InvocationHandler implementation where we "
+#~ "proxy an interface as\n"
+#~ " * the domain model and simply store persistent state in an internal "
+#~ "Map.  This is an extremely\n"
+#~ " * trivial example meant only for illustration.\n"
+#~ " */\n"
+#~ "public final class DataProxyHandler implements InvocationHandler {\n"
+#~ "        private String entityName;\n"
+#~ "        private HashMap data = new HashMap();\n"
+#~ "\n"
+#~ "        public DataProxyHandler(String entityName, Serializable id) {\n"
+#~ "                this.entityName = entityName;\n"
+#~ "                data.put( \"Id\", id );\n"
+#~ "        }\n"
+#~ "\n"
+#~ "        public Object invoke(Object proxy, Method method, Object[] args) "
+#~ "throws Throwable {\n"
+#~ "                String methodName = method.getName();\n"
+#~ "                if ( methodName.startsWith( \"set\" ) ) {\n"
+#~ "                        String propertyName = methodName.substring( 3 );\n"
+#~ "                        data.put( propertyName, args[0] );\n"
+#~ "                }\n"
+#~ "                else if ( methodName.startsWith( \"get\" ) ) {\n"
+#~ "                        String propertyName = methodName.substring( 3 );\n"
+#~ "                        return data.get( propertyName );\n"
+#~ "                }\n"
+#~ "                else if ( \"toString\".equals( methodName ) ) {\n"
+#~ "                        return entityName + \"#\" + data.get( \"Id\" );\n"
+#~ "                }\n"
+#~ "                else if ( \"hashCode\".equals( methodName ) ) {\n"
+#~ "                        return new Integer( this.hashCode() );\n"
+#~ "                }\n"
+#~ "                return null;\n"
+#~ "        }\n"
+#~ "\n"
+#~ "        public String getEntityName() {\n"
+#~ "                return entityName;\n"
+#~ "        }\n"
+#~ "\n"
+#~ "        public HashMap getData() {\n"
+#~ "                return data;\n"
+#~ "        }\n"
+#~ "}\n"
+#~ "\n"
+#~ "/**\n"
+#~ " *\n"
+#~ " */\n"
+#~ "public class ProxyHelper {\n"
+#~ "    public static String extractEntityName(Object object) {\n"
+#~ "        // Our custom java.lang.reflect.Proxy instances actually bundle\n"
+#~ "        // their appropriate entity name, so we simply extract it from "
+#~ "there\n"
+#~ "        // if this represents one of our proxies; otherwise, we return "
+#~ "null\n"
+#~ "        if ( Proxy.isProxyClass( object.getClass() ) ) {\n"
+#~ "            InvocationHandler handler = Proxy.getInvocationHandler"
+#~ "( object );\n"
+#~ "            if ( DataProxyHandler.class.isAssignableFrom( handler.getClass"
+#~ "() ) ) {\n"
+#~ "                DataProxyHandler myHandler = ( DataProxyHandler ) "
+#~ "handler;\n"
+#~ "                return myHandler.getEntityName();\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return null;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    // various other utility methods ....\n"
+#~ "\n"
+#~ "}\n"
+#~ "\n"
+#~ "/**\n"
+#~ " * The EntityNameResolver implementation.\n"
+#~ " * IMPL NOTE : An EntityNameResolver really defines a strategy for how "
+#~ "entity names should be\n"
+#~ " * resolved.  Since this particular impl can handle resolution for all of "
+#~ "our entities we want to\n"
+#~ " * take advantage of the fact that SessionFactoryImpl keeps these in a "
+#~ "Set so that we only ever\n"
+#~ " * have one instance registered.  Why?  Well, when it comes time to "
+#~ "resolve an entity name,\n"
+#~ " * Hibernate must iterate over all the registered resolvers.  So keeping "
+#~ "that number down\n"
+#~ " * helps that process be as speedy as possible.  Hence the equals and "
+#~ "hashCode impls\n"
+#~ " */\n"
+#~ "public class MyEntityNameResolver implements EntityNameResolver {\n"
+#~ "    public static final MyEntityNameResolver INSTANCE = new "
+#~ "MyEntityNameResolver();\n"
+#~ "\n"
+#~ "    public String resolveEntityName(Object entity) {\n"
+#~ "        return ProxyHelper.extractEntityName( entity );\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean equals(Object obj) {\n"
+#~ "        return getClass().equals( obj.getClass() );\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public int hashCode() {\n"
+#~ "        return getClass().hashCode();\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "\n"
+#~ "public class MyEntityTuplizer extends PojoEntityTuplizer {\n"
+#~ "        public MyEntityTuplizer(EntityMetamodel entityMetamodel, "
+#~ "PersistentClass mappedEntity) {\n"
+#~ "                super( entityMetamodel, mappedEntity );\n"
+#~ "        }\n"
+#~ "\n"
+#~ "        public EntityNameResolver[] getEntityNameResolvers() {\n"
+#~ "                return new EntityNameResolver[] { MyEntityNameResolver."
+#~ "INSTANCE };\n"
+#~ "        }\n"
+#~ "\n"
+#~ "    public String determineConcreteSubclassEntityName(Object "
+#~ "entityInstance, SessionFactoryImplementor factory) {\n"
+#~ "        String entityName = ProxyHelper.extractEntityName"
+#~ "( entityInstance );\n"
+#~ "        if ( entityName == null ) {\n"
+#~ "            entityName = super.determineConcreteSubclassEntityName"
+#~ "( entityInstance, factory );\n"
+#~ "        }\n"
+#~ "        return entityName;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    ...\n"
+#~ "}"
+#~ msgstr ""
+#~ "/**\n"
+#~ " * A very trivial JDK Proxy InvocationHandler implementation where we "
+#~ "proxy an interface as\n"
+#~ " * the domain model and simply store persistent state in an internal "
+#~ "Map.  This is an extremely\n"
+#~ " * trivial example meant only for illustration.\n"
+#~ " */\n"
+#~ "public final class DataProxyHandler implements InvocationHandler {\n"
+#~ "        private String entityName;\n"
+#~ "        private HashMap data = new HashMap();\n"
+#~ "\n"
+#~ "        public DataProxyHandler(String entityName, Serializable id) {\n"
+#~ "                this.entityName = entityName;\n"
+#~ "                data.put( \"Id\", id );\n"
+#~ "        }\n"
+#~ "\n"
+#~ "        public Object invoke(Object proxy, Method method, Object[] args) "
+#~ "throws Throwable {\n"
+#~ "                String methodName = method.getName();\n"
+#~ "                if ( methodName.startsWith( \"set\" ) ) {\n"
+#~ "                        String propertyName = methodName.substring( 3 );\n"
+#~ "                        data.put( propertyName, args[0] );\n"
+#~ "                }\n"
+#~ "                else if ( methodName.startsWith( \"get\" ) ) {\n"
+#~ "                        String propertyName = methodName.substring( 3 );\n"
+#~ "                        return data.get( propertyName );\n"
+#~ "                }\n"
+#~ "                else if ( \"toString\".equals( methodName ) ) {\n"
+#~ "                        return entityName + \"#\" + data.get( \"Id\" );\n"
+#~ "                }\n"
+#~ "                else if ( \"hashCode\".equals( methodName ) ) {\n"
+#~ "                        return new Integer( this.hashCode() );\n"
+#~ "                }\n"
+#~ "                return null;\n"
+#~ "        }\n"
+#~ "\n"
+#~ "        public String getEntityName() {\n"
+#~ "                return entityName;\n"
+#~ "        }\n"
+#~ "\n"
+#~ "        public HashMap getData() {\n"
+#~ "                return data;\n"
+#~ "        }\n"
+#~ "}\n"
+#~ "\n"
+#~ "/**\n"
+#~ " *\n"
+#~ " */\n"
+#~ "public class ProxyHelper {\n"
+#~ "    public static String extractEntityName(Object object) {\n"
+#~ "        // Our custom java.lang.reflect.Proxy instances actually bundle\n"
+#~ "        // their appropriate entity name, so we simply extract it from "
+#~ "there\n"
+#~ "        // if this represents one of our proxies; otherwise, we return "
+#~ "null\n"
+#~ "        if ( Proxy.isProxyClass( object.getClass() ) ) {\n"
+#~ "            InvocationHandler handler = Proxy.getInvocationHandler"
+#~ "( object );\n"
+#~ "            if ( DataProxyHandler.class.isAssignableFrom( handler.getClass"
+#~ "() ) ) {\n"
+#~ "                DataProxyHandler myHandler = ( DataProxyHandler ) "
+#~ "handler;\n"
+#~ "                return myHandler.getEntityName();\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "        return null;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    // various other utility methods ....\n"
+#~ "\n"
+#~ "}\n"
+#~ "\n"
+#~ "/**\n"
+#~ " * The EntityNameResolver implementation.\n"
+#~ " * IMPL NOTE : An EntityNameResolver really defines a strategy for how "
+#~ "entity names should be\n"
+#~ " * resolved.  Since this particular impl can handle resolution for all of "
+#~ "our entities we want to\n"
+#~ " * take advantage of the fact that SessionFactoryImpl keeps these in a "
+#~ "Set so that we only ever\n"
+#~ " * have one instance registered.  Why?  Well, when it comes time to "
+#~ "resolve an entity name,\n"
+#~ " * Hibernate must iterate over all the registered resolvers.  So keeping "
+#~ "that number down\n"
+#~ " * helps that process be as speedy as possible.  Hence the equals and "
+#~ "hashCode impls\n"
+#~ " */\n"
+#~ "public class MyEntityNameResolver implements EntityNameResolver {\n"
+#~ "    public static final MyEntityNameResolver INSTANCE = new "
+#~ "MyEntityNameResolver();\n"
+#~ "\n"
+#~ "    public String resolveEntityName(Object entity) {\n"
+#~ "        return ProxyHelper.extractEntityName( entity );\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public boolean equals(Object obj) {\n"
+#~ "        return getClass().equals( obj.getClass() );\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public int hashCode() {\n"
+#~ "        return getClass().hashCode();\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "\n"
+#~ "public class MyEntityTuplizer extends PojoEntityTuplizer {\n"
+#~ "        public MyEntityTuplizer(EntityMetamodel entityMetamodel, "
+#~ "PersistentClass mappedEntity) {\n"
+#~ "                super( entityMetamodel, mappedEntity );\n"
+#~ "        }\n"
+#~ "\n"
+#~ "        public EntityNameResolver[] getEntityNameResolvers() {\n"
+#~ "                return new EntityNameResolver[] { MyEntityNameResolver."
+#~ "INSTANCE };\n"
+#~ "        }\n"
+#~ "\n"
+#~ "    public String determineConcreteSubclassEntityName(Object "
+#~ "entityInstance, SessionFactoryImplementor factory) {\n"
+#~ "        String entityName = ProxyHelper.extractEntityName"
+#~ "( entityInstance );\n"
+#~ "        if ( entityName == null ) {\n"
+#~ "            entityName = super.determineConcreteSubclassEntityName"
+#~ "( entityInstance, factory );\n"
+#~ "        }\n"
+#~ "        return entityName;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    ...\n"
+#~ "}"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/portability.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/portability.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/portability.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,32 +1,30 @@
-# Language zh-CN translations for PACKAGE package.
-# Automatically generated, 2009.
-#
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: 2009-07-14 19:56+0000\n"
-"Last-Translator: Automatically generated\n"
-"Language-Team: none\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-11 10:57+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: portability.xml:26
 #, no-c-format
 msgid "Database Portability Considerations"
-msgstr ""
+msgstr "数据库移植性考量"
 
 #. Tag: title
-#: portability.xml:29
 #, no-c-format
 msgid "Portability Basics"
-msgstr ""
+msgstr "移植性基础"
 
 #. Tag: para
-#: portability.xml:31
 #, no-c-format
 msgid ""
 "One of the selling points of Hibernate (and really Object/Relational Mapping "
@@ -38,15 +36,18 @@
 "run against any number of databases without changes to your code, and "
 "ideally without any changes to the mapping metadata."
 msgstr ""
+"Hibernate(实际上是整个 Object/Relational Mapping)的一个卖点是数据库的移植"
+"性。这意味着内部的 IT 用户可以改变数据库供应商,或者可部署的应用程序/框架使"
+"用 Hibernate 来同时使用多个数据库产品。不考虑具体的应用情景,这里的基本概念"
+"是 Hibernate 可帮助你运行多种数据库而无需修改你的代码,理想情况下甚至不用修改"
+"映射元数据。"
 
 #. Tag: title
-#: portability.xml:42
 #, no-c-format
 msgid "Dialect"
-msgstr ""
+msgstr "Dialect"
 
 #. Tag: para
-#: portability.xml:44
 #, no-c-format
 msgid ""
 "The first line of portability for Hibernate is the dialect, which is a "
@@ -58,15 +59,18 @@
 "your particular database is not among them, it is not terribly difficult to "
 "write your own."
 msgstr ""
+"Hibernate 的移植性的首要问题是方言(dialect),也就是 <classname>org."
+"hibernate.dialect.Dialect</classname> 合约的具体实例。方言封装了 Hibernate 和"
+"特定数据库通讯以完成某些任务如获取序列值或构建 SELECT 查询等的所有差异。"
+"Hibernate 捆绑了用于许多最常用的数据库的方言。如果你发现自己使用的数据库不在"
+"其中,编写自定义的方言也不是很困难的事情。"
 
 #. Tag: title
-#: portability.xml:55
 #, no-c-format
 msgid "Dialect resolution"
-msgstr ""
+msgstr "方言的使用"
 
 #. Tag: para
-#: portability.xml:57
 #, no-c-format
 msgid ""
 "Originally, Hibernate would always require that users specify which dialect "
@@ -75,9 +79,11 @@
 "their users to configure the Hibernate dialect or defining their own method "
 "of setting that value."
 msgstr ""
+"最开始,Hibernate 总是要求用户指定所使用的方言(dialect)。在用户希望同时使用"
+"多个数据库时就会出现问题。通常这要求用户配置 Hibernate 方言或者定义自己设置这"
+"个值的方法。"
 
 #. Tag: para
-#: portability.xml:64
 #, no-c-format
 msgid ""
 "Starting with version 3.2, Hibernate introduced the notion of automatically "
@@ -87,17 +93,20 @@
 "that this resolution was limited to databases Hibernate know about ahead of "
 "time and was in no way configurable or overrideable."
 msgstr ""
+"从版本 3.2 开始,Hibernate 引入了方言的自动检测,它基于从该数据库的 "
+"<interfacename>java.sql.Connection</interfacename> 上获得的 "
+"<interfacename>java.sql.DatabaseMetaData</interfacename>。这是一个更好的方"
+"案,但它局限于 Hibernate 已知的数据库且无法进行配置和覆盖。"
 
 #. Tag: para
-#: portability.xml:72
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Starting with version 3.3, Hibernate has a fare more powerful way to "
 "automatically determine which dialect to should be used by relying on a "
 "series of delegates which implement the <interfacename>org.hibernate.dialect."
 "resolver.DialectResolver</interfacename> which defines only a single method:"
-"<programlisting><![CDATA[public Dialect resolveDialect(DatabaseMetaData "
-"metaData) throws JDBCConnectionException]]></programlisting>. The basic "
+"<programlisting role=\"JAVA\">public Dialect resolveDialect(DatabaseMetaData "
+"metaData) throws JDBCConnectionException</programlisting>. The basic "
 "contract here is that if the resolver 'understands' the given database "
 "metadata then it returns the corresponding Dialect; if not it returns null "
 "and the process continues to the next resolver. The signature also "
@@ -108,9 +117,18 @@
 "All other exceptions result in a warning and continuing on to the next "
 "resolver."
 msgstr ""
+"从版本 3.3 开始,Hibernate 有了更为强大的自动决定应该使用哪个方言的方法,这根"
+"据一系列实现 <interfacename>org.hibernate.dialect.resolver.DialectResolver</"
+"interfacename> 接口的代理,它们只定义一个方法:<programlisting>public "
+"Dialect resolveDialect(DatabaseMetaData metaData) throws "
+"JDBCConnectionException</programlisting>。这里的基本合约是如果解析者"
+"(resolver)“理解”给点数据库的元数据并返回对应的方言;否则返回 null 并使用下"
+"一个解析者。这个签名也指定可能抛出的异常 <exceptionname>org.hibernate."
+"exception.JDBCConnectionException</exceptionname>。这里的 "
+"JDBCConnectionException 被认为是“非瞬时的”(也就是不可恢复的)连接问题且指示"
+"立即终止解析。所有其他的异常都导致警告发出并使用下一个解析者。\""
 
 #. Tag: para
-#: portability.xml:85
 #, no-c-format
 msgid ""
 "The cool part about these resolvers is that users can also register their "
@@ -124,16 +142,20 @@
 "<constant>DIALECT_RESOLVERS</constant> constant on <classname>org.hibernate."
 "cfg.Environment</classname>)."
 msgstr ""
+"这些解析者最棒的功能是用户也可以注册自定义的解析者,它们将在内置的解析者之前"
+"被调用。在许多情况下这可能很有用:它可以轻易地集成内置方言之外的方言的自动检"
+"测;它让你可以使用自定义的方言等。要注册一个或多个解析者,只要用 'hibernate."
+"dialect_resolvers' 配置设置指定它们(由逗号、制表符或空格隔开)就可以了(请参"
+"考 <classname>org.hibernate.cfg.Environment</classname> 上的 "
+"<constant>DIALECT_RESOLVERS</constant>)。"
 
 #. Tag: title
-#: portability.xml:98
 #, no-c-format
 msgid "Identifier generation"
-msgstr ""
+msgstr "标识符的生成"
 
 #. Tag: para
-#: portability.xml:100
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "When considering portability between databases, another important decision "
 "is selecting the identifier generation stratagy you want to use. Originally "
@@ -151,38 +173,80 @@
 "reference entities within a persistence context it must then issue the "
 "insert immediately when the users requests the entitiy be associated with "
 "the session (like via save() e.g.) regardless of current transactional "
-"semantics. <note> <para> Hibernate was changed slightly once the implication "
-"of this was better understood so that the insert is delayed in cases where "
-"that is feasible. </para> </note> The underlying issue is that the actual "
-"semanctics of the application itself changes in these cases."
+"semantics."
 msgstr ""
+"当考虑数据库的移植性时,另外一个重要的考量是选择标识符生成策略。Hibernate 原"
+"先提供的 <emphasis>native</emphasis> 生成器的目的是根据底层数据库的能力在 "
+"<emphasis>sequence</emphasis>、<emphasis>identity</emphasis> 或 "
+"<emphasis>table</emphasis> 策略间进行选择。然而,这个方法一个潜在的问题是有些"
+"数据库支持<emphasis>标识符(identity)</emphasis>生成而有些则不支持。"
+"<emphasis>标识符(identity)</emphasis> 生成依赖于管理标识符值的 IDENTITY"
+"(或 auto-increment)字段的 SQL 定义。它也成为 post-insert 生成策略,因为 "
+"insert 必须在知道标识符值后才能实际发生。因为 Hibernate 依赖于这个标识符值来"
+"唯一地引用持久性上下文里的实体,当用户请求和会话相关联的实体时,它必须立即执"
+"行 insert  语句而不管当前的事务性语义。底层的问题是应用程序的语义在这些情况下"
+"自身也会发生改变。"
 
 #. Tag: para
-#: portability.xml:125
+#, fuzzy, no-c-format
+msgid ""
+"Hibernate was changed slightly once the implication of this was better "
+"understood so that the insert is delayed in cases where that is feasible."
+msgstr "Hibernate 已经进行了改进,所以在可行时这种插入会被延迟。"
+
+#. Tag: note
 #, no-c-format
 msgid ""
+"The underlying issue is that the actual semanctics of the application itself "
+"changes in these cases."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
 "Starting with version 3.2.3, Hibernate comes with a set of <ulink url="
 "\"http://in.relation.to/2082.lace\">enhanced</ulink> identifier generators "
-"targetting portability in a much different way. <note> <para> There are "
-"specifically 2 bundled <emphasis>enhanced</emphasis>generators: "
-"<itemizedlist> <listitem> <para> <classname>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</classname> </para> </listitem> <listitem> <para> "
-"<classname>org.hibernate.id.enhanced.TableGenerator</classname> </para> </"
-"listitem> </itemizedlist> </para> </note> The idea behind these generators "
-"is to port the actual semantics of the identifer value generation to the "
-"different databases. For example, the <classname>org.hibernate.id.enhanced."
-"SequenceStyleGenerator</classname> mimics the behavior of a sequence on "
-"databases which do not support sequences by using a table."
+"targetting portability in a much different way."
 msgstr ""
+"从 3.2.3 版本开始,Hibernate 带有一套 <ulink url=\"http://in.relation."
+"to/2082.lace\">enhanced</ulink> 标识符生成器,它以很不同的方式实现移植性。"
 
+#. Tag: para
+#, no-c-format
+msgid ""
+"There are specifically 2 bundled <emphasis>enhanced</emphasis>generators:"
+msgstr "特别是两个捆绑的 <emphasis>enhanced</emphasis> 生成器:"
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname>"
+msgstr ""
+"<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname>"
+
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<classname>org.hibernate.id.enhanced.TableGenerator</classname>"
+msgstr "<classname>org.hibernate.id.enhanced.TableGenerator</classname>"
+
+#. Tag: note
+#, no-c-format
+msgid ""
+"The idea behind these generators is to port the actual semantics of the "
+"identifer value generation to the different databases. For example, the "
+"<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname> "
+"mimics the behavior of a sequence on databases which do not support "
+"sequences by using a table."
+msgstr ""
+"这些生成器背后的概念是把标识符值生成的实际情景移植到不同的数据库里。例如,"
+"<classname>org.hibernate.id.enhanced.SequenceStyleGenerator</classname> 通过"
+"使用表来模拟不支持序列(sequences)的数据库上的序列行为。"
+
 #. Tag: title
-#: portability.xml:154
 #, no-c-format
 msgid "Database functions"
-msgstr ""
+msgstr "数据库函数"
 
 #. Tag: para
-#: portability.xml:157
 #, no-c-format
 msgid ""
 "This is an area in Hibernate in need of improvement. In terms of portability "
@@ -191,7 +255,6 @@
 msgstr ""
 
 #. Tag: para
-#: portability.xml:164
 #, no-c-format
 msgid ""
 "SQL functions can be referenced in many ways by users. However, not all "
@@ -200,9 +263,11 @@
 "knows how to render that particular function, perhaps even using a totally "
 "different physical function call."
 msgstr ""
+"用户可以以多种方式引用 SQL 函数。然而,不是所有的数据库都支持相同的函数集。"
+"Hibernate 提供了一种映射<emphasis>逻辑</emphasis>函数名到代理的方法,这个代理"
+"知道如何解析特定的函数,甚至可能使用完全不同的物理函数调用。"
 
 #. Tag: para
-#: portability.xml:170
 #, no-c-format
 msgid ""
 "Technically this function registration is handled through the <classname>org."
@@ -211,24 +276,31 @@
 "having to provide a custom dialect. This specific behavior is not fully "
 "completed as of yet."
 msgstr ""
+"从技术上来讲,这个函数注册是通过 <classname>org.hibernate.dialect.function."
+"SQLFunctionRegistry</classname> 类进行处理的,它的目的是允许用户提供自定义的"
+"函数定义而无需提供自定义的方言。这种特殊的行为目前还未全部开发完毕。"
 
 #. Tag: para
-#: portability.xml:177
 #, no-c-format
 msgid ""
 "It is sort of implemented such that users can programatically register "
 "functions with the <classname>org.hibernate.cfg.Configuration</classname> "
 "and those functions will be recognized for HQL."
 msgstr ""
+"其中一些功能已经实现,如用户可以在程序里用 <classname>org.hibernate.cfg."
+"Configuration</classname> 注册函数且这些函数可被 HQL 识别。"
 
 #. Tag: title
-#: portability.xml:187
 #, no-c-format
 msgid "Type mappings"
-msgstr ""
+msgstr "类型映射"
 
 #. Tag: para
-#: portability.xml:189
 #, no-c-format
 msgid "This section scheduled for completion at a later date..."
-msgstr ""
+msgstr "本节内容仍未完成..."
+
+#~ msgid ""
+#~ "This is a new area in Hibernate and as such it is not as mature as the "
+#~ "overall Hibernate experience."
+#~ msgstr "这是 Hibernate 的一个新的领域,暂时还不如 Hibernate 总体那么成熟。"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/preface.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/preface.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/preface.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,23 +1,25 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-11 10:44+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: preface.xml:29
 #, no-c-format
 msgid "Preface"
 msgstr "前言"
 
 #. Tag: para
-#: preface.xml:31
 #, fuzzy, no-c-format
 msgid ""
 "Working with object-oriented software and a relational database can be "
@@ -27,27 +29,25 @@
 "representation from an object model to a relational data model with a SQL-"
 "based schema."
 msgstr ""
-"在今日的企业环境中,把面向对象的软件和关系数据库一起使用可能是相当麻烦、浪费"
-"时间的。Hibernate是一个面向Java环境的对象/关系数据库映射工具。对象/关系数据库"
-"映射(object/relational mapping (ORM))这个术语表示一种技术,用来把对象模型表示"
-"的对象映射到基于SQL的关系模型数据结构中去。"
+"在今日的企业环境中,把面向对象的软件和关系型数据库一起使用可能是相当麻烦和浪"
+"费时间的。Hibernate 是一个面向 Java 环境的对象/关系型数据库映射工具。对象/关"
+"系型数据库映射(object/relational mapping,ORM)这个术语表示一种技术,用来把"
+"对象模型表示的对象映射到基于 SQL 的关系模型数据结构中去。"
 
 #. Tag: para
-#: preface.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate not only takes care of the mapping from Java classes to database "
 "tables (and from Java data types to SQL data types), but also provides data "
 "query and retrieval facilities. It can also significantly reduce development "
 "time otherwise spent with manual data handling in SQL and JDBC."
 msgstr ""
-"Hibernate不仅仅管理Java类到数据库表的映射(包括Java数据类型到SQL数据类型的映"
-"射),还提供数据查询和获取数据的方法,可以大幅度减少开发时人工使用SQL和JDBC处"
-"理数据的时间。"
+"Hibernate 不仅管理 Java 类到数据库表的映射(包括 Java 数据类型到 SQL 数据类型"
+"的映射),还提供数据查询和获取数据的方法,可以大幅度减少开发时对人工使用 SQL "
+"和 JDBC 处理数据的时间。 "
 
 #. Tag: para
-#: preface.xml:46
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's goal is to relieve the developer from 95 percent of common data "
 "persistence related programming tasks. Hibernate may not be the best "
@@ -58,46 +58,43 @@
 "specific SQL code and will help with the common task of result set "
 "translation from a tabular representation to a graph of objects."
 msgstr ""
-"Hibernate的目标是对于开发者通常的数据持久化相关的编程任务,解放其中的95%。对"
-"于以数据为中心的程序来说,它们往往只在数据库中使用存储过程来实现商业逻辑,"
-"Hibernate可能不是最好的解决方案;对于那些在基于Java的中间层应用中,它们实现面"
-"向对象的业务模型和商业逻辑的应用,Hibernate是最有用的。不管怎样,Hibernate一"
-"定可以帮助你消除或者包装那些针对特定厂商的SQL代码,并且帮你把结果集从表格式的"
-"表示形式转换到一系列的对象去。"
+"Hibernate 的目标是对于开发者通常的数据持久化相关的编程任务,解放其中的 95%。"
+"对于以数据为中心的程序来说,它们往往只在数据库中使用存储过程来实现商业逻辑,"
+"Hibernate 可能不是最好的解决方案;对于那些在基于 Java 的中间层应用中,它们实"
+"现面向对象的业务模型和商业逻辑的应用,Hibernate 是最有用的。不管怎样,"
+"Hibernate 一定可以帮助你消除或者包装那些针对特定厂商的 SQL 代码,而且帮助你结"
+"果集从表格式的表示形式转换到一系列的对象中去。 "
 
 #. Tag: para
-#: preface.xml:56
 #, no-c-format
 msgid ""
 "If you are new to Hibernate and Object/Relational Mapping or even Java, "
 "please follow these steps:"
 msgstr ""
-"如果你对Hibernate和对象/关系数据库映射还是个新手,或者甚至对Java也不熟悉,请"
-"按照下面的步骤来学习。"
+"如果你对 Hibernate 和对象/关系型数据库映射还是个新手,甚至对 Java 也不熟悉,"
+"请按照下面的步骤来学习。"
 
 #. Tag: para
-#: preface.xml:63
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"Read <xref linkend=\"tutorial\"/> for a tutorial with step-by-step "
+"Read <xref linkend=\"tutorial\" /> for a tutorial with step-by-step "
 "instructions. The source code for the tutorial is included in the "
 "distribution in the <literal>doc/reference/tutorial/</literal> directory."
 msgstr ""
-"阅读<xref linkend=\"tutorial\"/>,这是一篇包含详细的逐步指导的指南。本指南的"
-"源代码包含在发行包中,你可以在<literal>doc/reference/tutorial/</literal>目录"
-"下找到。"
+"阅读 <xref linkend=\"tutorial\"/>,这是一篇包含详细的逐步知道的指南。本指南的"
+"源代码包含在发行包里,你可以在 <literal>doc/reference/tutorial/</literal> 目"
+"录下找到。 "
 
 #. Tag: para
-#: preface.xml:71
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"Read <xref linkend=\"architecture\"/> to understand the environments where "
+"Read <xref linkend=\"architecture\" /> to understand the environments where "
 "Hibernate can be used."
-msgstr "阅读<xref linkend=\"architecture\"/>来理解Hibernate可以使用的环境。"
+msgstr ""
+"阅读 <xref linkend=\"architecture\"/> 来理解 Hibernate 可以使用的环境。 "
 
 #. Tag: para
-#: preface.xml:77
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "View the <literal>eg/</literal> directory in the Hibernate distribution. It "
 "contains a simple standalone application. Copy your JDBC driver to the "
@@ -106,52 +103,50 @@
 "command prompt in the distribution directory, type <literal>ant eg</literal> "
 "(using Ant), or under Windows, type <literal>build eg</literal>."
 msgstr ""
-"查看Hibernate发行包中的<literal>eg/</literal>目录,里面有一个简单的独立运行的"
-"程序。把你的JDBC驱动拷贝到<literal>lib/</literal>目录下,修改一下"
-"<literal>src/hibernate.properties</literal>,指定其中你的数据库的信息。进入命"
-"令行,切换到你的发行包的目录,输入<literal>ant eg</literal>(使用了Ant),或者"
-"在Windows操作系统中使用<literal>build eg</literal>。"
+"查看 Hibernate 发行包中的 <literal>eg/</literal> 目录,里面有个一简单的独立运"
+"行的程序。把你的 JDBC 驱动复制到 <literal>lib/</literal> 目录并修改一下 "
+"<literal>etc/hibernate.properties</literal>,指定数据库的信息。然后进入命令"
+"行,切换到发行包的目录,输入 <literal>ant eg</literal>(使用 Ant),或者在 "
+"Windows 系统下使用 <literal>build eg</literal>。 "
 
 #. Tag: para
-#: preface.xml:88
 #, fuzzy, no-c-format
 msgid ""
 "Use this reference documentation as your primary source of information. "
 "Consider reading <biblioref linkend=\"biblio-JPwH\"></biblioref> if you need "
 "more help with application design, or if you prefer a step-by-step tutorial. "
-"Also visit <ulink url=\"http://caveatemptor.hibernate.org\"></ulink> and "
-"download the example application from <biblioref linkend=\"biblio-JPwH\"></"
-"biblioref>."
-msgstr "把这份参考文档作为你学习的主要信息来源。"
+"Also visit <ulink url=\"http://caveatemptor.hibernate.org\" /> and download "
+"the example application from <biblioref linkend=\"biblio-JPwH\"></biblioref>."
+msgstr ""
+"把这份文档作为你学习的主要信息来源。如果你需要应用程序设计方面的帮助或者你希"
+"望有一个按部就班的指南,你可以考虑阅读 <emphasis>Hibernate in Action</"
+"emphasis>(http://www.manning.com/bauer)。你也可以访问http://caveatemptor."
+"hibernate.org 并下载 Hibernate 的示例程序。 "
 
 #. Tag: para
-#: preface.xml:98
 #, no-c-format
 msgid "FAQs are answered on the Hibernate website."
-msgstr "在Hibernate 的网站上可以找到经常提问的问题与解答(FAQ)。"
+msgstr "在 Hibernate 网站上可以找到问题和解答(FAQ)。"
 
 #. Tag: para
-#: preface.xml:103
 #, fuzzy, no-c-format
 msgid ""
 "Links to third party demos, examples, and tutorials are maintained on the "
 "Hibernate website."
-msgstr "在Hibernate网站上还有第三方的演示、示例和教程的链接。"
+msgstr "在 Hibernate 网站上还有第三方的演示、示例和教程的链接。"
 
 #. Tag: para
-#: preface.xml:109
 #, no-c-format
 msgid ""
 "The Community Area on the Hibernate website is a good resource for design "
 "patterns and various integration solutions (Tomcat, JBoss AS, Struts, EJB, "
 "etc.)."
 msgstr ""
-"Hibernate网站的“社区(Community Area)”是讨论关于设计模式以及很多整合方案"
-"(Tomcat, JBoss AS, Struts, EJB,等等)的好地方。"
+"Hibernate 网站的社区是讨论关于设计模式以及很多整合方案(Tomcat、JBoss AS、"
+"Struts、EJB 等)的好地方。"
 
 #. Tag: para
-#: preface.xml:117
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you have questions, use the user forum linked on the Hibernate website. "
 "We also provide a JIRA issue tracking system for bug reports and feature "
@@ -159,13 +154,12 @@
 "developer mailing list. If you are interested in translating this "
 "documentation into your language, contact us on the developer mailing list."
 msgstr ""
-"如果你有问题,请使用Hibernate网站上链接的用户论坛。我们也提供一个JIRA问题追踪"
-"系统,来搜集bug报告和新功能请求。如果你对开发Hibernate有兴趣,请加入开发者的"
-"邮件列表。(Hibernate网站上的用户论坛有一个中文版面,JavaEye也有Hibernate中文"
-"版面,您可以在那里交流问题与经验。)"
+"如果你有任何问题,请使用 Hibernate 网站上链接的用户论坛。我们也提供一个 JIRA "
+"问题追踪系统,来搜集 bug 报告和新的功能请求。如果对开发 Hibernate 有兴趣,请"
+"加入开发者的邮件列表。如果你对翻译本文档感兴趣,请通过开发者的邮件列表来联系"
+"我们。 "
 
 #. Tag: para
-#: preface.xml:125
 #, no-c-format
 msgid ""
 "Commercial development support, production support, and training for "
@@ -174,7 +168,18 @@
 "critical component of the JBoss Enterprise Middleware System (JEMS) suite of "
 "products."
 msgstr ""
-"商业开发、产品支持和Hibernate培训可以通过JBoss Inc.获得。(请查阅:http://"
-"www.hibernate.org/SupportTraining/)。 Hibernate是一个专业的开放源代码项目"
-"(Professional Open Source project),也是JBoss Enterprise Middleware System"
-"(JEMS),JBoss企业级中间件系统的一个核心组件。"
+"商业开发、产品支持和 Hibernate 培训可以通过 JBoss Inc. 获得(请查阅: http://"
+"www.hibernate.org/SupportTraining/)。Hibernate 是一个专业的开源项目,也是 "
+"JBoss 企业级中间件系统(JBoss Enterprise Middleware System,JEMS)里的一个核"
+"心组件。  "
+
+#~ msgid "Feedback"
+#~ msgstr "反馈"
+
+#~ msgid ""
+#~ "Use <ulink url=\"http://opensource.atlassian.com/projects/hibernate"
+#~ "\">Hibernate JIRA</ulink> to report errors or request enhacements to this "
+#~ "documentation."
+#~ msgstr ""
+#~ "用 <ulink url=\"http://opensource.atlassian.com/projects/hibernate"
+#~ "\">Hibernate JIRA</ulink> 来报告错误或改进本文档。"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/query_criteria.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/query_criteria.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/query_criteria.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,61 +1,50 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-07 20:31+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: query_criteria.xml:29
 #, no-c-format
 msgid "Criteria Queries"
-msgstr "条件查询(Criteria Queries)"
+msgstr "条件查询(Criteria Queries)"
 
 #. Tag: para
-#: query_criteria.xml:31
 #, no-c-format
 msgid "Hibernate features an intuitive, extensible criteria query API."
-msgstr "具有一个直观的、可扩展的条件查询API是Hibernate的特色。"
+msgstr "具有一个直观的、可扩展的条件查询 API 是 Hibernate 的特色。"
 
 #. Tag: title
-#: query_criteria.xml:36
 #, no-c-format
 msgid "Creating a <literal>Criteria</literal> instance"
-msgstr "创建一个<literal>Criteria</literal> 实例"
+msgstr "创建一个 <literal>Criteria</literal> 实例"
 
 #. Tag: para
-#: query_criteria.xml:38
 #, no-c-format
 msgid ""
 "The interface <literal>org.hibernate.Criteria</literal> represents a query "
 "against a particular persistent class. The <literal>Session</literal> is a "
 "factory for <literal>Criteria</literal> instances."
 msgstr ""
-"<literal>org.hibernate.Criteria</literal>接口表示特定持久类的一个查询。"
-"<literal>Session</literal>是 <literal>Criteria</literal>实例的工厂。"
+"<literal>org.hibernate.Criteria</literal >接口表示特定持久类的一个查询。"
+"<literal>Session</literal> 是 <literal>Criteria</literal> 实例的工厂。"
 
-#. Tag: programlisting
-#: query_criteria.xml:44
-#, no-c-format
-msgid ""
-"<![CDATA[Criteria crit = sess.createCriteria(Cat.class);\n"
-"crit.setMaxResults(50);\n"
-"List cats = crit.list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:49
 #, no-c-format
 msgid "Narrowing the result set"
 msgstr "限制结果集内容"
 
 #. Tag: para
-#: query_criteria.xml:51
 #, no-c-format
 msgid ""
 "An individual query criterion is an instance of the interface <literal>org."
@@ -63,402 +52,215 @@
 "criterion.Restrictions</literal> defines factory methods for obtaining "
 "certain built-in <literal>Criterion</literal> types."
 msgstr ""
-"一个单独的查询条件是<literal>org.hibernate.criterion.Criterion</literal> 接口"
-"的一个实例。<literal>org.hibernate.criterion.Restrictions</literal>类 定义了"
-"获得某些内置<literal>Criterion</literal>类型的工厂方法。"
+"一个单独的查询条件是 <literal>org.hibernate.criterion.Criterion</literal> 接"
+"口的一个实例。<literal>org.hibernate.criterion.Restrictions</literal> 类定义"
+"了获得某些内置 <literal>Criterion</literal> 类型的工厂方法。"
 
-#. Tag: programlisting
-#: query_criteria.xml:59
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .add( Restrictions.between(\"weight\", minWeight, maxWeight) )\n"
-"    .list();]]>"
-msgstr ""
+msgid "Restrictions can be grouped logically."
+msgstr "约束可以按逻辑分组。 "
 
 #. Tag: para
-#: query_criteria.xml:61
-#, fuzzy, no-c-format
-msgid "Restrictions can be grouped logically."
-msgstr "约束可以按逻辑分组。"
-
-#. Tag: programlisting
-#: query_criteria.xml:65
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .add( Restrictions.or(\n"
-"        Restrictions.eq( \"age\", new Integer(0) ),\n"
-"        Restrictions.isNull(\"age\")\n"
-"    ) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:67
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.in( \"name\", new String[] { \"Fritz\", \"Izi\", \"Pk"
-"\" } ) )\n"
-"    .add( Restrictions.disjunction()\n"
-"        .add( Restrictions.isNull(\"age\") )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(0) ) )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(1) ) )\n"
-"        .add( Restrictions.eq(\"age\", new Integer(2) ) )\n"
-"    ) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:69
-#, fuzzy, no-c-format
-msgid ""
 "There are a range of built-in criterion types (<literal>Restrictions</"
 "literal> subclasses). One of the most useful allows you to specify SQL "
 "directly."
 msgstr ""
-"Hibernate提供了相当多的内置criterion类型(<literal>Restrictions</literal> 子"
-"类), 但是尤其有用的是可以允许你直接使用SQL。"
+"Hibernate 提供了相当多的内置 criterion 类型(<literal>Restrictions</literal> "
+"子类),但是尤其有用的是可以允许你直接使用 SQL。 "
 
-#. Tag: programlisting
-#: query_criteria.xml:74
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.sqlRestriction(\"lower({alias}.name) like lower(?)\", "
-"\"Fritz%\", Hibernate.STRING) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:76
 #, no-c-format
 msgid ""
 "The <literal>{alias}</literal> placeholder with be replaced by the row alias "
 "of the queried entity."
-msgstr "<literal>{alias}</literal>占位符应当被替换为被查询实体的列别名。"
+msgstr "<literal>{alias}</literal> 占位符应当被替换为被查询实体的列别名。"
 
 #. Tag: para
-#: query_criteria.xml:81
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also obtain a criterion from a <literal>Property</literal> instance. "
 "You can create a <literal>Property</literal> by calling <literal>Property."
 "forName()</literal>:"
 msgstr ""
-"<literal>Property</literal>实例是获得一个条件的另外一种途径。你可以通过调用"
-"<literal>Property.forName()</literal> 创建一个<literal>Property</literal>。"
+"<literal>Property</literal> 实例是获得一个条件的另外一种途径。你可以通过调用 "
+"<literal>Property.forName()</literal> 创建一个 <literal>Property</literal>:"
 
-#. Tag: programlisting
-#: query_criteria.xml:87
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"Property age = Property.forName(\"age\");\n"
-"List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.disjunction()\n"
-"        .add( age.isNull() )\n"
-"        .add( age.eq( new Integer(0) ) )\n"
-"        .add( age.eq( new Integer(1) ) )\n"
-"        .add( age.eq( new Integer(2) ) )\n"
-"    ) )\n"
-"    .add( Property.forName(\"name\").in( new String[] { \"Fritz\", \"Izi\", "
-"\"Pk\" } ) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:92
 #, no-c-format
 msgid "Ordering the results"
 msgstr "结果集排序"
 
 #. Tag: para
-#: query_criteria.xml:94
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can order the results using <literal>org.hibernate.criterion.Order</"
 "literal>."
 msgstr ""
-"你可以使用<literal>org.hibernate.criterion.Order</literal>来为查询结果排序。"
+"你可以使用 <literal>org.hibernate.criterion.Order</literal> 来为查询结果排"
+"序。 "
 
-#. Tag: programlisting
-#: query_criteria.xml:98
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"F%\")\n"
-"    .addOrder( Order.asc(\"name\") )\n"
-"    .addOrder( Order.desc(\"age\") )\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:100
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Property.forName(\"name\").like(\"F%\") )\n"
-"    .addOrder( Property.forName(\"name\").asc() )\n"
-"    .addOrder( Property.forName(\"age\").desc() )\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:105
 #, no-c-format
 msgid "Associations"
 msgstr "关联"
 
 #. Tag: para
-#: query_criteria.xml:107
 #, no-c-format
 msgid ""
 "By navigating associations using <literal>createCriteria()</literal> you can "
 "specify constraints upon related entities:"
 msgstr ""
+"通过使用 <literal>createCriteria()</literal> 对关联进行导航,你可以指定相关实"
+"体的约束。"
 
-#. Tag: programlisting
-#: query_criteria.xml:112
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"F%\") )\n"
-"    .createCriteria(\"kittens\")\n"
-"        .add( Restrictions.like(\"name\", \"F%\") )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:114
-#, fuzzy, no-c-format
-msgid ""
 "The second <literal>createCriteria()</literal> returns a new instance of "
 "<literal>Criteria</literal> that refers to the elements of the "
 "<literal>kittens</literal> collection."
 msgstr ""
-"注意第二个 <literal>createCriteria()</literal>返回一个新的 "
-"<literal>Criteria</literal>实例,该实例引用<literal>kittens</literal> 集合中"
-"的元素。"
+"注意第二个 <literal>createCriteria()</literal> 返回一个新的 "
+"<literal>Criteria</literal> 实例,该实例引用 <literal>kittens</literal> 集合"
+"中的元素。 "
 
 #. Tag: para
-#: query_criteria.xml:120
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "There is also an alternate form that is useful in certain circumstances:"
-msgstr "接下来,替换形态在某些情况下也是很有用的。"
+msgstr "接下来,替换形态在某些情况下也是很有用的。 "
 
-#. Tag: programlisting
-#: query_criteria.xml:124
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .createAlias(\"kittens\", \"kt\")\n"
-"    .createAlias(\"mate\", \"mt\")\n"
-"    .add( Restrictions.eqProperty(\"kt.name\", \"mt.name\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:126
 #, no-c-format
 msgid ""
 "(<literal>createAlias()</literal> does not create a new instance of "
 "<literal>Criteria</literal>.)"
 msgstr ""
-"(<literal>createAlias()</literal>并不创建一个新的 <literal>Criteria</literal>"
-"实例。)"
+"(<literal>createAlias()</literal> 并不创建一个新的 <literal>Criteria</"
+"literal> 实例。)"
 
 #. Tag: para
-#: query_criteria.xml:131
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The kittens collections held by the <literal>Cat</literal> instances "
 "returned by the previous two queries are <emphasis>not</emphasis> pre-"
 "filtered by the criteria. If you want to retrieve just the kittens that "
 "match the criteria, you must use a <literal>ResultTransformer</literal>."
 msgstr ""
-"<literal>Cat</literal>实例所保存的之前两次查询所返回的kittens集合是 "
-"<emphasis>没有</emphasis>被条件预过滤的。如果你希望只获得符合条件的kittens, "
-"你必须使用<literal>ResultTransformer</literal>。"
+"<literal>Cat</literal> 实例所保存的之前两次查询所返回的 kittens 集合是 "
+"<emphasis>没有</emphasis>被条件预过滤的。如果你希望只获得符合条件的 kittens,"
+"你必须使用 <literal>ResultTransformer</literal>。 "
 
-#. Tag: programlisting
-#: query_criteria.xml:138
+#. Tag: para
 #, no-c-format
+msgid "Additionally you may manipulate the result set using a left outer join:"
+msgstr ""
+
+#. Tag: para
+#, no-c-format
 msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .createCriteria(\"kittens\", \"kt\")\n"
-"        .add( Restrictions.eq(\"name\", \"F%\") )\n"
-"    .setResultTransformer(Criteria.ALIAS_TO_ENTITY_MAP)\n"
-"    .list();\n"
-"Iterator iter = cats.iterator();\n"
-"while ( iter.hasNext() ) {\n"
-"    Map map = (Map) iter.next();\n"
-"    Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);\n"
-"    Cat kitten = (Cat) map.get(\"kt\");\n"
-"}]]>"
+"This will return all of the <literal>Cat</literal>s with a mate whose name "
+"starts with \"good\" ordered by their mate's age, and all cats who do not "
+"have a mate. This is useful when there is a need to order or limit in the "
+"database prior to returning complex/large result sets, and removes many "
+"instances where multiple queries would have to be performed and the results "
+"unioned by java in memory."
 msgstr ""
 
+#. Tag: para
+#, no-c-format
+msgid ""
+"Without this feature, first all of the cats without a mate would need to be "
+"loaded in one query."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid ""
+"A second query would need to retreive the cats with mates who's name started "
+"with \"good\" sorted by the mates age."
+msgstr ""
+
+#. Tag: para
+#, no-c-format
+msgid "Thirdly, in memory; the lists would need to be joined manually."
+msgstr ""
+
 #. Tag: title
-#: query_criteria.xml:143
 #, no-c-format
 msgid "Dynamic association fetching"
 msgstr "动态关联抓取"
 
 #. Tag: para
-#: query_criteria.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can specify association fetching semantics at runtime using "
 "<literal>setFetchMode()</literal>."
 msgstr ""
-"你可以使用<literal>setFetchMode()</literal>在运行时定义动态关联抓取的语义。"
+"你可以使用 <literal>setFetchMode()</literal> 在运行时定义动态关联抓取的语"
+"义。 "
 
-#. Tag: programlisting
-#: query_criteria.xml:150
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
-"    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
-"    .setFetchMode(\"mate\", FetchMode.EAGER)\n"
-"    .setFetchMode(\"kittens\", FetchMode.EAGER)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:152
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "This query will fetch both <literal>mate</literal> and <literal>kittens</"
-"literal> by outer join. See <xref linkend=\"performance-fetching\"/> for "
+"literal> by outer join. See <xref linkend=\"performance-fetching\" /> for "
 "more information."
 msgstr ""
-"这个查询可以通过外连接抓取<literal>mate</literal>和<literal>kittens</"
-"literal>。 查看<xref linkend=\"performance-fetching\"/>可以获得更多信息。"
+"这个查询可以通过外连接抓取 <literal>mate</literal> 和 <literal>kittens</"
+"literal>。查看 <xref linkend=\"performance-fetching\" /> 可以获得更多信息。"
 
 #. Tag: title
-#: query_criteria.xml:160
 #, no-c-format
 msgid "Example queries"
 msgstr "查询示例"
 
 #. Tag: para
-#: query_criteria.xml:162
 #, no-c-format
 msgid ""
 "The class <literal>org.hibernate.criterion.Example</literal> allows you to "
 "construct a query criterion from a given instance."
 msgstr ""
-"<literal>org.hibernate.criterion.Example</literal>类允许你通过一个给定实例 构"
+"<literal>org.hibernate.criterion.Example</literal> 类允许你通过一个给定实例构"
 "建一个条件查询。"
 
-#. Tag: programlisting
-#: query_criteria.xml:167
-#, no-c-format
-msgid ""
-"<![CDATA[Cat cat = new Cat();\n"
-"cat.setSex('F');\n"
-"cat.setColor(Color.BLACK);\n"
-"List results = session.createCriteria(Cat.class)\n"
-"    .add( Example.create(cat) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:169
 #, no-c-format
 msgid ""
 "Version properties, identifiers and associations are ignored. By default, "
 "null valued properties are excluded."
-msgstr "版本属性、标识符和关联被忽略。默认情况下值为null的属性将被排除。"
+msgstr "版本属性、标识符和关联被忽略。默认情况下值为 null 的属性将被排除。"
 
 #. Tag: para
-#: query_criteria.xml:174
 #, no-c-format
 msgid "You can adjust how the <literal>Example</literal> is applied."
-msgstr "你可以自行调整<literal>Example</literal>使之更实用。"
+msgstr "你可以自行调整 <literal>Example</literal> 使之更实用。"
 
-#. Tag: programlisting
-#: query_criteria.xml:178
-#, no-c-format
-msgid ""
-"<![CDATA[Example example = Example.create(cat)\n"
-"    .excludeZeroes()           //exclude zero valued properties\n"
-"    .excludeProperty(\"color\")  //exclude the property named \"color\"\n"
-"    .ignoreCase()              //perform case insensitive string "
-"comparisons\n"
-"    .enableLike();             //use like for string comparisons\n"
-"List results = session.createCriteria(Cat.class)\n"
-"    .add(example)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:180
 #, no-c-format
 msgid "You can even use examples to place criteria upon associated objects."
-msgstr "你甚至可以使用examples在关联对象上放置条件。"
+msgstr "你甚至可以使用 examples 在关联对象上放置条件。"
 
-#. Tag: programlisting
-#: query_criteria.xml:184
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .add( Example.create(cat) )\n"
-"    .createCriteria(\"mate\")\n"
-"        .add( Example.create( cat.getMate() ) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:189
 #, no-c-format
 msgid "Projections, aggregation and grouping"
-msgstr "投影(Projections)、聚合(aggregation)和分组(grouping)"
+msgstr "投影(Projections)、聚合(aggregation)和分组(grouping)"
 
 #. Tag: para
-#: query_criteria.xml:190
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The class <literal>org.hibernate.criterion.Projections</literal> is a "
 "factory for <literal>Projection</literal> instances. You can apply a "
 "projection to a query by calling <literal>setProjection()</literal>."
 msgstr ""
-"<literal>org.hibernate.criterion.Projections</literal>是 "
+"<literal>org.hibernate.criterion.Projections</literal> 是 "
 "<literal>Projection</literal> 的实例工厂。我们通过调用 <literal>setProjection"
-"()</literal>应用投影到一个查询。"
+"()</literal> 应用投影到一个查询。 "
 
-#. Tag: programlisting
-#: query_criteria.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.rowCount() )\n"
-"    .add( Restrictions.eq(\"color\", Color.BLACK) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:198
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount() )\n"
-"        .add( Projections.avg(\"weight\") )\n"
-"        .add( Projections.max(\"weight\") )\n"
-"        .add( Projections.groupProperty(\"color\") )\n"
-"    )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:200
 #, no-c-format
 msgid ""
 "There is no explicit \"group by\" necessary in a criteria query. Certain "
@@ -466,43 +268,20 @@
 "emphasis>, which also appear in the SQL <literal>group by</literal> clause."
 msgstr ""
 "在一个条件查询中没有必要显式的使用 \"group by\" 。某些投影类型就是被定义为"
-"<emphasis> 分组投影</emphasis>,他们也出现在SQL的<literal>group by</literal>"
-"子句中。"
+"<emphasis>分组投影</emphasis>,他们也出现在 SQL 的 <literal>group by</"
+"literal> 子句中。"
 
 #. Tag: para
-#: query_criteria.xml:206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An alias can be assigned to a projection so that the projected value can be "
 "referred to in restrictions or orderings. Here are two different ways to do "
 "this:"
 msgstr ""
 "你可以选择把一个别名指派给一个投影,这样可以使投影值被约束或排序所引用。下面"
-"是两种不同的实现方式:"
+"是两种不同的实现方式: "
 
-#. Tag: programlisting
-#: query_criteria.xml:212
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.alias( Projections.groupProperty(\"color\"), "
-"\"colr\" ) )\n"
-"    .addOrder( Order.asc(\"colr\") )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:214
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.groupProperty(\"color\").as(\"colr\") )\n"
-"    .addOrder( Order.asc(\"colr\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:216
 #, no-c-format
 msgid ""
 "The <literal>alias()</literal> and <literal>as()</literal> methods simply "
@@ -510,168 +289,55 @@
 "<literal>Projection</literal>. As a shortcut, you can assign an alias when "
 "you add the projection to a projection list:"
 msgstr ""
-"<literal>alias()</literal>和<literal>as()</literal>方法简便的将一个投影实例包"
-"装到另外一个 别名的<literal>Projection</literal>实例中。简而言之,当你添加一"
-"个投影到一个投影列表中时 你可以为它指定一个别名:"
+"<literal>alias()</literal> 和 <literal>as()</literal> 方法简便的将一个投影实"
+"例包装到另外一个 别名的 <literal>Projection</literal> 实例中。简而言之,当你"
+"添加一个投影到一个投影列表中时你可以为它指定一个别名:"
 
-#. Tag: programlisting
-#: query_criteria.xml:223
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount(), \"catCountByColor\" )\n"
-"        .add( Projections.avg(\"weight\"), \"avgWeight\" )\n"
-"        .add( Projections.max(\"weight\"), \"maxWeight\" )\n"
-"        .add( Projections.groupProperty(\"color\"), \"color\" )\n"
-"    )\n"
-"    .addOrder( Order.desc(\"catCountByColor\") )\n"
-"    .addOrder( Order.desc(\"avgWeight\") )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:225
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Domestic.class, \"cat\")\n"
-"    .createAlias(\"kittens\", \"kit\")\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.property(\"cat.name\"), \"catName\" )\n"
-"        .add( Projections.property(\"kit.name\"), \"kitName\" )\n"
-"    )\n"
-"    .addOrder( Order.asc(\"catName\") )\n"
-"    .addOrder( Order.asc(\"kitName\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_criteria.xml:227
 #, no-c-format
 msgid ""
 "You can also use <literal>Property.forName()</literal> to express "
 "projections:"
-msgstr "你也可以使用<literal>Property.forName()</literal>来表示投影:"
+msgstr "你也可以使用 <literal>Property.forName()</literal> 来表示投影:"
 
-#. Tag: programlisting
-#: query_criteria.xml:231
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Property.forName(\"name\") )\n"
-"    .add( Property.forName(\"color\").eq(Color.BLACK) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:233
-#, no-c-format
-msgid ""
-"<![CDATA[List results = session.createCriteria(Cat.class)\n"
-"    .setProjection( Projections.projectionList()\n"
-"        .add( Projections.rowCount().as(\"catCountByColor\") )\n"
-"        .add( Property.forName(\"weight\").avg().as(\"avgWeight\") )\n"
-"        .add( Property.forName(\"weight\").max().as(\"maxWeight\") )\n"
-"        .add( Property.forName(\"color\").group().as(\"color\" )\n"
-"    )\n"
-"    .addOrder( Order.desc(\"catCountByColor\") )\n"
-"    .addOrder( Order.desc(\"avgWeight\") )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:238
 #, no-c-format
 msgid "Detached queries and subqueries"
-msgstr "离线(detached)查询和子查询"
+msgstr "离线(detached)查询和子查询"
 
 #. Tag: para
-#: query_criteria.xml:239
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>DetachedCriteria</literal> class allows you to create a query "
 "outside the scope of a session and then execute it using an arbitrary "
 "<literal>Session</literal>."
 msgstr ""
-"<literal>DetachedCriteria</literal>类使你在一个session范围之外创建一个查询,"
-"并且可以使用任意的 <literal>Session</literal>来执行它。"
+"<literal>DetachedCriteria</literal> 类使你在一个 session 范围之外创建一个查"
+"询,并且可以使用任意的 <literal>Session</literal> 来执行它。 "
 
-#. Tag: programlisting
-#: query_criteria.xml:244
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DetachedCriteria query = DetachedCriteria.forClass(Cat.class)\n"
-"    .add( Property.forName(\"sex\").eq('F') );\n"
-"    \n"
-"Session session = ....;\n"
-"Transaction txn = session.beginTransaction();\n"
-"List results = query.getExecutableCriteria(session).setMaxResults(100).list"
-"();\n"
-"txn.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:246
-#, fuzzy, no-c-format
-msgid ""
 "A <literal>DetachedCriteria</literal> can also be used to express a "
 "subquery. Criterion instances involving subqueries can be obtained via "
 "<literal>Subqueries</literal> or <literal>Property</literal>."
 msgstr ""
-"<literal>DetachedCriteria</literal>也可以用以表示子查询。条件实例包含子查询可"
-"以通过 <literal>Subqueries</literal>或者<literal>Property</literal>获得。"
+"<literal>DetachedCriteria</literal> 也可以用以表示子查询。条件实例包含子查询"
+"可以通过  <literal>Subqueries</literal> 或者 <literal>Property</literal> 获"
+"得。 "
 
-#. Tag: programlisting
-#: query_criteria.xml:252
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria avgWeight = DetachedCriteria.forClass(Cat.class)\n"
-"    .setProjection( Property.forName(\"weight\").avg() );\n"
-"session.createCriteria(Cat.class)\n"
-"    .add( Property.forName(\"weight\").gt(avgWeight) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_criteria.xml:254
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria weights = DetachedCriteria.forClass(Cat.class)\n"
-"    .setProjection( Property.forName(\"weight\") );\n"
-"session.createCriteria(Cat.class)\n"
-"    .add( Subqueries.geAll(\"weight\", weights) )\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:256
-#, fuzzy, no-c-format
 msgid "Correlated subqueries are also possible:"
-msgstr "甚至相互关联的子查询也是有可能的:"
+msgstr "甚至相互关联的子查询也是有可能的: "
 
-#. Tag: programlisting
-#: query_criteria.xml:260
-#, no-c-format
-msgid ""
-"<![CDATA[DetachedCriteria avgWeightForSex = DetachedCriteria.forClass(Cat."
-"class, \"cat2\")\n"
-"    .setProjection( Property.forName(\"weight\").avg() )\n"
-"    .add( Property.forName(\"cat2.sex\").eqProperty(\"cat.sex\") );\n"
-"session.createCriteria(Cat.class, \"cat\")\n"
-"    .add( Property.forName(\"weight\").gt(avgWeightForSex) )\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_criteria.xml:269
 #, no-c-format
 msgid "Queries by natural identifier"
-msgstr "根据自然标识查询(Queries by natural identifier)"
+msgstr "根据自然标识查询(Queries by natural identifier)"
 
 #. Tag: para
-#: query_criteria.xml:271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For most queries, including criteria queries, the query cache is not "
 "efficient because query cache invalidation occurs too frequently. However, "
@@ -680,75 +346,541 @@
 "applications, this kind of query occurs frequently. The criteria API "
 "provides special provision for this use case."
 msgstr ""
-"对大多数查询,包括条件查询而言,因为查询缓存的失效(invalidation)发生得太频"
+"对大多数查询,包括条件查询而言,因为查询缓存的失效(invalidation)发生得太频"
 "繁,查询缓存不是非常高效。然而,有一种特别的查询,可以通过不变的自然键优化缓"
-"存的失效算法。在某些应用中,这种类型的查询比较常见。条件查询API对这种用例提供"
-"了特别规约。"
+"存的失效算法。在某些应用中,这种类型的查询比较常见。条件查询 API 对这种用例提"
+"供了特别规约。 "
 
 #. Tag: para
-#: query_criteria.xml:279
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, map the natural key of your entity using <literal>&lt;natural-id&gt;</"
 "literal> and enable use of the second-level cache."
 msgstr ""
-"首先,你应该对你的entity使用<literal>&lt;natural-id&gt;</literal>来映射自然"
-"键,然后打开第二级缓存。"
+"首先,你应该对你的 entity 使用 <literal>&lt;natural-id&gt;</literal> 来映射自"
+"然键,然后打开第二级缓存。 "
 
-#. Tag: programlisting
-#: query_criteria.xml:284
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"User\">\n"
-"    <cache usage=\"read-write\"/>\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <natural-id>\n"
-"        <property name=\"name\"/>\n"
-"        <property name=\"org\"/>\n"
-"    </natural-id>\n"
-"    <property name=\"password\"/>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_criteria.xml:286
-#, fuzzy, no-c-format
-msgid ""
 "This functionality is not intended for use with entities with "
 "<emphasis>mutable</emphasis> natural keys."
-msgstr "注意,此功能对具有<emphasis>mutable</emphasis>自然键的entity并不适用。"
+msgstr ""
+"注意,此功能对具有<emphasis>mutable</emphasis>自然键的 entity 并不适用。 "
 
 #. Tag: para
-#: query_criteria.xml:291
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Once you have enabled the Hibernate query cache, the <literal>Restrictions."
 "naturalId()</literal> allows you to make use of the more efficient cache "
 "algorithm."
 msgstr ""
-"现在,我们可以用<literal>Restrictions.naturalId()</literal>来使用更加高效的缓"
-"存算法。"
+"现在,我们可以用 <literal>Restrictions.naturalId()</literal> 来使用更加高效的"
+"缓存算法。 "
 
-#. Tag: programlisting
-#: query_criteria.xml:297
-#, no-c-format
-msgid ""
-"<![CDATA[session.createCriteria(User.class)\n"
-"    .add( Restrictions.naturalId()\n"
-"        .set(\"name\", \"gavin\")\n"
-"        .set(\"org\", \"hb\") \n"
-"    ).setCacheable(true)\n"
-"    .uniqueResult();]]>"
-msgstr ""
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Criteria crit = sess.createCriteria(Cat.class);\n"
+#~ "crit.setMaxResults(50);\n"
+#~ "List cats = crit.list();]]>"
+#~ msgstr ""
+#~ "Criteria crit = sess.createCriteria(Cat.class);\n"
+#~ "crit.setMaxResults(50);\n"
+#~ "List cats = crit.list();"
 
+#, fuzzy
 #~ msgid ""
-#~ "You may easily specify constraints upon related entities by navigating "
-#~ "associations using <literal>createCriteria()</literal>."
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
+#~ "    .add( Restrictions.between(\"weight\", minWeight, maxWeight) )\n"
+#~ "    .list();]]>"
 #~ msgstr ""
-#~ "你可以使用<literal>createCriteria()</literal>非常容易的在互相关联的实体间"
-#~ "建立 约束。"
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"Fritz&#37;\") )\n"
+#~ "    .add( Restrictions.between(\"weight\", minWeight, maxWeight) )\n"
+#~ "    .list();"
 
-#~ msgid "Next, enable the Hibernate query cache."
-#~ msgstr "然后,打开Hibernate 查询缓存。"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
+#~ "    .add( Restrictions.or(\n"
+#~ "        Restrictions.eq( \"age\", new Integer(0) ),\n"
+#~ "        Restrictions.isNull(\"age\")\n"
+#~ "    ) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"Fritz&#37;\") )\n"
+#~ "    .add( Restrictions.or(\n"
+#~ "        Restrictions.eq( \"age\", new Integer(0) ),\n"
+#~ "        Restrictions.isNull(\"age\")\n"
+#~ "    ) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.in( \"name\", new String[] { \"Fritz\", \"Izi\", "
+#~ "\"Pk\" } ) )\n"
+#~ "    .add( Restrictions.disjunction()\n"
+#~ "        .add( Restrictions.isNull(\"age\") )\n"
+#~ "        .add( Restrictions.eq(\"age\", new Integer(0) ) )\n"
+#~ "        .add( Restrictions.eq(\"age\", new Integer(1) ) )\n"
+#~ "        .add( Restrictions.eq(\"age\", new Integer(2) ) )\n"
+#~ "    ) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.in( \"name\", new String[] { \"Fritz\", \"Izi\", "
+#~ "\"Pk\" } ) )\n"
+#~ "    .add( Restrictions.disjunction()\n"
+#~ "        .add( Restrictions.isNull(\"age\") )\n"
+#~ "        .add( Restrictions.eq(\"age\", new Integer(0) ) )\n"
+#~ "        .add( Restrictions.eq(\"age\", new Integer(1) ) )\n"
+#~ "        .add( Restrictions.eq(\"age\", new Integer(2) ) )\n"
+#~ "    ) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.sqlRestriction(\"lower({alias}.name) like lower(?)"
+#~ "\", \"Fritz%\", Hibernate.STRING) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.sqlRestriction(\"lower({alias}.name) like lower(?)"
+#~ "\", \"Fritz&#37;\", \n"
+#~ "        Hibernate.STRING) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[\n"
+#~ "Property age = Property.forName(\"age\");\n"
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.disjunction()\n"
+#~ "        .add( age.isNull() )\n"
+#~ "        .add( age.eq( new Integer(0) ) )\n"
+#~ "        .add( age.eq( new Integer(1) ) )\n"
+#~ "        .add( age.eq( new Integer(2) ) )\n"
+#~ "    ) )\n"
+#~ "    .add( Property.forName(\"name\").in( new String[] { \"Fritz\", \"Izi"
+#~ "\", \"Pk\" } ) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "Property age = Property.forName(\"age\");\n"
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.disjunction()\n"
+#~ "        .add( age.isNull() )\n"
+#~ "        .add( age.eq( new Integer(0) ) )\n"
+#~ "        .add( age.eq( new Integer(1) ) )\n"
+#~ "        .add( age.eq( new Integer(2) ) )\n"
+#~ "    ) )\n"
+#~ "    .add( Property.forName(\"name\").in( new String[] { \"Fritz\", \"Izi"
+#~ "\", \"Pk\" } ) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"F%\")\n"
+#~ "    .addOrder( Order.asc(\"name\") )\n"
+#~ "    .addOrder( Order.desc(\"age\") )\n"
+#~ "    .setMaxResults(50)\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"F&#37;\")\n"
+#~ "    .addOrder( Order.asc(\"name\") )\n"
+#~ "    .addOrder( Order.desc(\"age\") )\n"
+#~ "    .setMaxResults(50)\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Property.forName(\"name\").like(\"F%\") )\n"
+#~ "    .addOrder( Property.forName(\"name\").asc() )\n"
+#~ "    .addOrder( Property.forName(\"age\").desc() )\n"
+#~ "    .setMaxResults(50)\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Property.forName(\"name\").like(\"F&#37;\") )\n"
+#~ "    .addOrder( Property.forName(\"name\").asc() )\n"
+#~ "    .addOrder( Property.forName(\"age\").desc() )\n"
+#~ "    .setMaxResults(50)\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"F%\") )\n"
+#~ "    .createCriteria(\"kittens\")\n"
+#~ "        .add( Restrictions.like(\"name\", \"F%\") )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"F&#37;\") )\n"
+#~ "    .createCriteria(\"kittens\")\n"
+#~ "        .add( Restrictions.like(\"name\", \"F&#37;\") )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .createAlias(\"kittens\", \"kt\")\n"
+#~ "    .createAlias(\"mate\", \"mt\")\n"
+#~ "    .add( Restrictions.eqProperty(\"kt.name\", \"mt.name\") )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .createAlias(\"kittens\", \"kt\")\n"
+#~ "    .createAlias(\"mate\", \"mt\")\n"
+#~ "    .add( Restrictions.eqProperty(\"kt.name\", \"mt.name\") )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .createCriteria(\"kittens\", \"kt\")\n"
+#~ "        .add( Restrictions.eq(\"name\", \"F%\") )\n"
+#~ "    .setResultTransformer(Criteria.ALIAS_TO_ENTITY_MAP)\n"
+#~ "    .list();\n"
+#~ "Iterator iter = cats.iterator();\n"
+#~ "while ( iter.hasNext() ) {\n"
+#~ "    Map map = (Map) iter.next();\n"
+#~ "    Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);\n"
+#~ "    Cat kitten = (Cat) map.get(\"kt\");\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .createCriteria(\"kittens\", \"kt\")\n"
+#~ "        .add( Restrictions.eq(\"name\", \"F&#37;\") )\n"
+#~ "    .setResultTransformer(Criteria.ALIAS_TO_ENTITY_MAP)\n"
+#~ "    .list();\n"
+#~ "Iterator iter = cats.iterator();\n"
+#~ "while ( iter.hasNext() ) {\n"
+#~ "    Map map = (Map) iter.next();\n"
+#~ "    Cat cat = (Cat) map.get(Criteria.ROOT_ALIAS);\n"
+#~ "    Cat kitten = (Cat) map.get(\"kt\");\n"
+#~ "}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"Fritz%\") )\n"
+#~ "    .setFetchMode(\"mate\", FetchMode.EAGER)\n"
+#~ "    .setFetchMode(\"kittens\", FetchMode.EAGER)\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createCriteria(Cat.class)\n"
+#~ "    .add( Restrictions.like(\"name\", \"Fritz&#37;\") )\n"
+#~ "    .setFetchMode(\"mate\", FetchMode.EAGER)\n"
+#~ "    .setFetchMode(\"kittens\", FetchMode.EAGER)\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Cat cat = new Cat();\n"
+#~ "cat.setSex('F');\n"
+#~ "cat.setColor(Color.BLACK);\n"
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .add( Example.create(cat) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "Cat cat = new Cat();\n"
+#~ "cat.setSex('F');\n"
+#~ "cat.setColor(Color.BLACK);\n"
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .add( Example.create(cat) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Example example = Example.create(cat)\n"
+#~ "    .excludeZeroes()           //exclude zero valued properties\n"
+#~ "    .excludeProperty(\"color\")  //exclude the property named \"color\"\n"
+#~ "    .ignoreCase()              //perform case insensitive string "
+#~ "comparisons\n"
+#~ "    .enableLike();             //use like for string comparisons\n"
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .add(example)\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "Example example = Example.create(cat)\n"
+#~ "    .excludeZeroes()           //exclude zero valued properties\n"
+#~ "    .excludeProperty(\"color\")  //exclude the property named \"color\"\n"
+#~ "    .ignoreCase()              //perform case insensitive string "
+#~ "comparisons\n"
+#~ "    .enableLike();             //use like for string comparisons\n"
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .add(example)\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .add( Example.create(cat) )\n"
+#~ "    .createCriteria(\"mate\")\n"
+#~ "        .add( Example.create( cat.getMate() ) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .add( Example.create(cat) )\n"
+#~ "    .createCriteria(\"mate\")\n"
+#~ "        .add( Example.create( cat.getMate() ) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.rowCount() )\n"
+#~ "    .add( Restrictions.eq(\"color\", Color.BLACK) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.rowCount() )\n"
+#~ "    .add( Restrictions.eq(\"color\", Color.BLACK) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.rowCount() )\n"
+#~ "        .add( Projections.avg(\"weight\") )\n"
+#~ "        .add( Projections.max(\"weight\") )\n"
+#~ "        .add( Projections.groupProperty(\"color\") )\n"
+#~ "    )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.rowCount() )\n"
+#~ "        .add( Projections.avg(\"weight\") )\n"
+#~ "        .add( Projections.max(\"weight\") )\n"
+#~ "        .add( Projections.groupProperty(\"color\") )\n"
+#~ "    )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.alias( Projections.groupProperty(\"color"
+#~ "\"), \"colr\" ) )\n"
+#~ "    .addOrder( Order.asc(\"colr\") )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.alias( Projections.groupProperty(\"color"
+#~ "\"), \"colr\" ) )\n"
+#~ "    .addOrder( Order.asc(\"colr\") )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.groupProperty(\"color\").as(\"colr\") )\n"
+#~ "    .addOrder( Order.asc(\"colr\") )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.groupProperty(\"color\").as(\"colr\") )\n"
+#~ "    .addOrder( Order.asc(\"colr\") )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.rowCount(), \"catCountByColor\" )\n"
+#~ "        .add( Projections.avg(\"weight\"), \"avgWeight\" )\n"
+#~ "        .add( Projections.max(\"weight\"), \"maxWeight\" )\n"
+#~ "        .add( Projections.groupProperty(\"color\"), \"color\" )\n"
+#~ "    )\n"
+#~ "    .addOrder( Order.desc(\"catCountByColor\") )\n"
+#~ "    .addOrder( Order.desc(\"avgWeight\") )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.rowCount(), \"catCountByColor\" )\n"
+#~ "        .add( Projections.avg(\"weight\"), \"avgWeight\" )\n"
+#~ "        .add( Projections.max(\"weight\"), \"maxWeight\" )\n"
+#~ "        .add( Projections.groupProperty(\"color\"), \"color\" )\n"
+#~ "    )\n"
+#~ "    .addOrder( Order.desc(\"catCountByColor\") )\n"
+#~ "    .addOrder( Order.desc(\"avgWeight\") )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Domestic.class, \"cat\")\n"
+#~ "    .createAlias(\"kittens\", \"kit\")\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.property(\"cat.name\"), \"catName\" )\n"
+#~ "        .add( Projections.property(\"kit.name\"), \"kitName\" )\n"
+#~ "    )\n"
+#~ "    .addOrder( Order.asc(\"catName\") )\n"
+#~ "    .addOrder( Order.asc(\"kitName\") )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Domestic.class, \"cat\")\n"
+#~ "    .createAlias(\"kittens\", \"kit\")\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.property(\"cat.name\"), \"catName\" )\n"
+#~ "        .add( Projections.property(\"kit.name\"), \"kitName\" )\n"
+#~ "    )\n"
+#~ "    .addOrder( Order.asc(\"catName\") )\n"
+#~ "    .addOrder( Order.asc(\"kitName\") )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Property.forName(\"name\") )\n"
+#~ "    .add( Property.forName(\"color\").eq(Color.BLACK) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Property.forName(\"name\") )\n"
+#~ "    .add( Property.forName(\"color\").eq(Color.BLACK) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.rowCount().as(\"catCountByColor\") )\n"
+#~ "        .add( Property.forName(\"weight\").avg().as(\"avgWeight\") )\n"
+#~ "        .add( Property.forName(\"weight\").max().as(\"maxWeight\") )\n"
+#~ "        .add( Property.forName(\"color\").group().as(\"color\" )\n"
+#~ "    )\n"
+#~ "    .addOrder( Order.desc(\"catCountByColor\") )\n"
+#~ "    .addOrder( Order.desc(\"avgWeight\") )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List results = session.createCriteria(Cat.class)\n"
+#~ "    .setProjection( Projections.projectionList()\n"
+#~ "        .add( Projections.rowCount().as(\"catCountByColor\") )\n"
+#~ "        .add( Property.forName(\"weight\").avg().as(\"avgWeight\") )\n"
+#~ "        .add( Property.forName(\"weight\").max().as(\"maxWeight\") )\n"
+#~ "        .add( Property.forName(\"color\").group().as(\"color\" )\n"
+#~ "    )\n"
+#~ "    .addOrder( Order.desc(\"catCountByColor\") )\n"
+#~ "    .addOrder( Order.desc(\"avgWeight\") )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[DetachedCriteria query = DetachedCriteria.forClass(Cat.class)\n"
+#~ "    .add( Property.forName(\"sex\").eq('F') );\n"
+#~ "    \n"
+#~ "Session session = ....;\n"
+#~ "Transaction txn = session.beginTransaction();\n"
+#~ "List results = query.getExecutableCriteria(session).setMaxResults(100)."
+#~ "list();\n"
+#~ "txn.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "DetachedCriteria query = DetachedCriteria.forClass(Cat.class)\n"
+#~ "    .add( Property.forName(\"sex\").eq('F') );\n"
+#~ "    \n"
+#~ "Session session = ....;\n"
+#~ "Transaction txn = session.beginTransaction();\n"
+#~ "List results = query.getExecutableCriteria(session).setMaxResults(100)."
+#~ "list();\n"
+#~ "txn.commit();\n"
+#~ "session.close();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[DetachedCriteria avgWeight = DetachedCriteria.forClass(Cat."
+#~ "class)\n"
+#~ "    .setProjection( Property.forName(\"weight\").avg() );\n"
+#~ "session.createCriteria(Cat.class)\n"
+#~ "    .add( Property.forName(\"weight\").gt(avgWeight) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "DetachedCriteria avgWeight = DetachedCriteria.forClass(Cat.class)\n"
+#~ "    .setProjection( Property.forName(\"weight\").avg() );\n"
+#~ "session.createCriteria(Cat.class)\n"
+#~ "    .add( Property.forName(\"weight).gt(avgWeight) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[DetachedCriteria weights = DetachedCriteria.forClass(Cat.class)\n"
+#~ "    .setProjection( Property.forName(\"weight\") );\n"
+#~ "session.createCriteria(Cat.class)\n"
+#~ "    .add( Subqueries.geAll(\"weight\", weights) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "DetachedCriteria weights = DetachedCriteria.forClass(Cat.class)\n"
+#~ "    .setProjection( Property.forName(\"weight\") );\n"
+#~ "session.createCriteria(Cat.class)\n"
+#~ "    .add( Subqueries.geAll(\"weight\", weights) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[DetachedCriteria avgWeightForSex = DetachedCriteria.forClass(Cat."
+#~ "class, \"cat2\")\n"
+#~ "    .setProjection( Property.forName(\"weight\").avg() )\n"
+#~ "    .add( Property.forName(\"cat2.sex\").eqProperty(\"cat.sex\") );\n"
+#~ "session.createCriteria(Cat.class, \"cat\")\n"
+#~ "    .add( Property.forName(\"weight\").gt(avgWeightForSex) )\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "DetachedCriteria avgWeightForSex = DetachedCriteria.forClass(Cat.class, "
+#~ "\"cat2\")\n"
+#~ "    .setProjection( Property.forName(\"weight\").avg() )\n"
+#~ "    .add( Property.forName(\"cat2.sex\").eqProperty(\"cat.sex\") );\n"
+#~ "session.createCriteria(Cat.class, \"cat\")\n"
+#~ "    .add( Property.forName(\"weight).gt(avgWeightForSex) )\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"User\">\n"
+#~ "    <cache usage=\"read-write\"/>\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"increment\"/>\n"
+#~ "    </id>\n"
+#~ "    <natural-id>\n"
+#~ "        <property name=\"name\"/>\n"
+#~ "        <property name=\"org\"/>\n"
+#~ "    </natural-id>\n"
+#~ "    <property name=\"password\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"User\"&gt;\n"
+#~ "    &lt;cache usage=\"read-write\"/&gt;\n"
+#~ "    &lt;id name=\"id\"&gt;\n"
+#~ "        &lt;generator class=\"increment\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;natural-id&gt;\n"
+#~ "        &lt;property name=\"name\"/&gt;\n"
+#~ "        &lt;property name=\"org\"/&gt;\n"
+#~ "    &lt;/natural-id&gt;\n"
+#~ "    &lt;property name=\"password\"/&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[session.createCriteria(User.class)\n"
+#~ "    .add( Restrictions.naturalId()\n"
+#~ "        .set(\"name\", \"gavin\")\n"
+#~ "        .set(\"org\", \"hb\") \n"
+#~ "    ).setCacheable(true)\n"
+#~ "    .uniqueResult();]]>"
+#~ msgstr ""
+#~ "session.createCriteria(User.class)\n"
+#~ "    .add( Restrictions.naturalId()\n"
+#~ "        .set(\"name\", \"gavin\")\n"
+#~ "        .set(\"org\", \"hb\") \n"
+#~ "    ).setCacheable(true)\n"
+#~ "    .uniqueResult();"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/query_hql.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/query_hql.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/query_hql.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,42 +1,42 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2009-12-07 21:13+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: query_hql.xml:29
 #, no-c-format
 msgid "HQL: The Hibernate Query Language"
-msgstr "HQL: Hibernate查询语言"
+msgstr "HQL: Hibernate 查询语言"
 
 #. Tag: para
-#: query_hql.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate uses a powerful query language (HQL) that is similar in appearance "
 "to SQL. Compared with SQL, however, HQL is fully object-oriented and "
 "understands notions like inheritance, polymorphism and association."
 msgstr ""
-"Hibernate配备了一种非常强大的查询语言,这种语言看上去很像SQL。但是不要被语法"
-"结构 上的相似所迷惑,HQL是非常有意识的被设计为完全面向对象的查询,它可以理解"
-"如继承、多态 和关联之类的概念。"
+"Hibernate 配备了一种非常强大的查询语言,这种语言看上去很像 SQL。但是不要被语"
+"法结构上的相似所迷惑,HQL 是非常有意识的被设计为完全面向对象的查询,它可以理"
+"解如继承、多态和关联之类的概念。 "
 
 #. Tag: title
-#: query_hql.xml:38
 #, no-c-format
 msgid "Case Sensitivity"
 msgstr "大小写敏感性问题"
 
 #. Tag: para
-#: query_hql.xml:40
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "With the exception of names of Java classes and properties, queries are case-"
 "insensitive. So <literal>SeLeCT</literal> is the same as <literal>sELEct</"
@@ -44,257 +44,157 @@
 "hibernate.eg.FOO</literal> is not <literal>org.hibernate.eg.Foo</literal>, "
 "and <literal>foo.barSet</literal> is not <literal>foo.BARSET</literal>."
 msgstr ""
-"除了Java类与属性的名称外,查询语句对大小写并不敏感。 所以 <literal>SeLeCT</"
+"除了 Java 类与属性的名称外,查询语句对大小写并不敏感。 所以 <literal>SeLeCT</"
 "literal> 与 <literal>sELEct</literal> 以及 <literal>SELECT</literal> 是相同"
 "的,但是 <literal>org.hibernate.eg.FOO</literal> 并不等价于 <literal>org."
 "hibernate.eg.Foo</literal> 并且 <literal>foo.barSet</literal> 也不等价于 "
-"<literal>foo.BARSET</literal>。"
+"<literal>foo.BARSET</literal>。 "
 
 #. Tag: para
-#: query_hql.xml:51
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This manual uses lowercase HQL keywords. Some users find queries with "
 "uppercase keywords more readable, but this convention is unsuitable for "
 "queries embedded in Java code."
 msgstr ""
-"本手册中的HQL关键字将使用小写字母. 很多用户发现使用完全大写的关键字会使查询语"
-"句 的可读性更强, 但我们发现,当把查询语句嵌入到Java语句中的时候使用大写关键字"
-"比较难看。"
+"本手册中的 HQL 关键字将使用小写字母。很多用户发现使用完全大写的关键字会使查询"
+"语句的可读性更强,但我们发现,当把查询语句嵌入到 Java 语句中的时候使用大写关"
+"键字比较难看。"
 
 #. Tag: title
-#: query_hql.xml:59
 #, no-c-format
 msgid "The from clause"
-msgstr "from子句"
+msgstr "from 子句"
 
 #. Tag: para
-#: query_hql.xml:61
 #, no-c-format
 msgid "The simplest possible Hibernate query is of the form:"
-msgstr "Hibernate中最简单的查询语句的形式如下:"
+msgstr "Hibernate 中最简单的查询语句的形式如下:"
 
-#. Tag: programlisting
-#: query_hql.xml:65
-#, no-c-format
-msgid "<![CDATA[from eg.Cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:67
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This returns all instances of the class <literal>eg.Cat</literal>. You do "
 "not usually need to qualify the class name, since <literal>auto-import</"
 "literal> is the default. For example:"
 msgstr ""
-"该子句简单的返回<literal>eg.Cat</literal>类的所有实例。 通常我们不需要使用类"
-"的全限定名, 因为 <literal>auto-import</literal>(自动引入) 是缺省的情况。 所"
-"以我们几乎只使用如下的简单写法:"
+"该子句简单的返回 <literal>eg.Cat</literal> 类的所有实例。通常我们不需要使用类"
+"的全限定名,因为  <literal>auto-import</literal>(自动引入)是缺省的情况。所"
+"以我们几乎只使用如下的简单写法: "
 
-#. Tag: programlisting
-#: query_hql.xml:73
-#, no-c-format
-msgid "<![CDATA[from Cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:75
 #, no-c-format
 msgid ""
 "In order to refer to the <literal>Cat</literal> in other parts of the query, "
 "you will need to assign an <emphasis>alias</emphasis>. For example:"
 msgstr ""
+"为了在这个查询的其他部分里引用 <literal>Cat</literal>,你将需要分配一个"
+"<emphasis>别名</emphasis>。例如:"
 
-#. Tag: programlisting
-#: query_hql.xml:81 query_hql.xml:396
-#, no-c-format
-msgid "<![CDATA[from Cat as cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:83
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This query assigns the alias <literal>cat</literal> to <literal>Cat</"
 "literal> instances, so you can use that alias later in the query. The "
 "<literal>as</literal> keyword is optional. You could also write:"
 msgstr ""
-"这个语句把别名<literal>cat</literal>指定给类<literal>Cat</literal> 的实例, 这"
-"样我们就可以在随后的查询中使用此别名了。 关键字<literal>as</literal> 是可选"
-"的,我们也可以这样写:"
+"这个语句把别名 <literal>cat</literal> 指定给类<literal>Cat</literal> 的实例,"
+"这样我们就可以在随后的查询中使用此别名了。关键字 <literal>as</literal> 是可选"
+"的,我们也可以这样写: "
 
-#. Tag: programlisting
-#: query_hql.xml:89
-#, no-c-format
-msgid "<![CDATA[from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:91
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Multiple classes can appear, resulting in a cartesian product or \"cross\" "
 "join."
 msgstr ""
-"子句中可以同时出现多个类, 其查询结果是产生一个笛卡儿积或产生跨表的连接。"
+"子句中可以同时出现多个类,其查询结果是产生一个笛卡儿积或产生跨表的连接。 "
 
-#. Tag: programlisting
-#: query_hql.xml:95
-#, no-c-format
-msgid "<![CDATA[from Formula, Parameter]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:96
-#, no-c-format
-msgid "<![CDATA[from Formula as form, Parameter as param]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:98
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is good practice to name query aliases using an initial lowercase as this "
 "is consistent with Java naming standards for local variables (e.g. "
 "<literal>domesticCat</literal>)."
 msgstr ""
-"查询语句中别名的开头部分小写被认为是实践中的好习惯, 这样做与Java变量的命名标"
-"准保持了一致 (比如,<literal>domesticCat</literal>)。"
+"查询语句中别名的开头部分小写被认为是实践中的好习惯,这样做与 Java 变量的命名"
+"标准保持了一致(比如,<literal>domesticCat</literal>)。 "
 
 #. Tag: title
-#: query_hql.xml:107
 #, no-c-format
 msgid "Associations and joins"
-msgstr "关联(Association)与连接(Join)"
+msgstr "关联(Association)与连接(Join)"
 
 #. Tag: para
-#: query_hql.xml:109
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also assign aliases to associated entities or to elements of a "
 "collection of values using a <literal>join</literal>. For example:"
 msgstr ""
-"我们也可以为相关联的实体甚至是对一个集合中的全部元素指定一个别名, 这时要使用"
-"关键字<literal>join</literal>。"
+"我们也可以为相关联的实体甚至是对一个集合中的全部元素指定一个别名,这时要使用"
+"关键字 <literal>join</literal>。 "
 
-#. Tag: programlisting
-#: query_hql.xml:114
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join cat.mate as mate\n"
-"    left outer join cat.kittens as kitten]]>"
-msgstr ""
+msgid "The supported join types are borrowed from ANSI SQL:"
+msgstr "受支持的连接类型是从 ANSI SQL 中借鉴来的:"
 
-#. Tag: programlisting
-#: query_hql.xml:116
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from Cat as cat left join cat.mate.kittens as kittens]]>"
-msgstr ""
+msgid "<literal>inner join</literal>"
+msgstr "<literal>inner join</literal>"
 
-#. Tag: programlisting
-#: query_hql.xml:118
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from Formula form full join form.parameter param]]>"
-msgstr ""
+msgid "<literal>left outer join</literal>"
+msgstr "<literal>left outer join</literal>"
 
 #. Tag: para
-#: query_hql.xml:120
-#, fuzzy, no-c-format
-msgid "The supported join types are borrowed from ANSI SQL:"
-msgstr "受支持的连接类型是从ANSI SQL中借鉴来的。"
-
-#. Tag: literal
-#: query_hql.xml:127
 #, no-c-format
-msgid "inner join"
-msgstr "<literal>inner join</literal>(内连接)"
+msgid "<literal>right outer join</literal>"
+msgstr "<literal>right outer join</literal>"
 
-#. Tag: literal
-#: query_hql.xml:132
-#, no-c-format
-msgid "left outer join"
-msgstr "<literal>left outer join</literal>(左外连接)"
-
-#. Tag: literal
-#: query_hql.xml:137
-#, no-c-format
-msgid "right outer join"
-msgstr "<literal>right outer join</literal>(右外连接)"
-
 #. Tag: para
-#: query_hql.xml:141
 #, no-c-format
 msgid "<literal>full join</literal> (not usually useful)"
-msgstr "<literal>full join</literal> (全连接,并不常用)"
+msgstr "<literal>full join</literal>(全连接,并不常用)"
 
 #. Tag: para
-#: query_hql.xml:147
 #, no-c-format
 msgid ""
 "The <literal>inner join</literal>, <literal>left outer join</literal> and "
 "<literal>right outer join</literal> constructs may be abbreviated."
 msgstr ""
-"语句<literal>inner join</literal>, <literal>left outer join</literal> 以及 "
+"语句 <literal>inner join</literal>,<literal>left outer join</literal> 以及 "
 "<literal>right outer join</literal> 可以简写。"
 
-#. Tag: programlisting
-#: query_hql.xml:152
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    join cat.mate as mate\n"
-"    left join cat.kittens as kitten]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:154
 #, no-c-format
 msgid ""
 "You may supply extra join conditions using the HQL <literal>with</literal> "
 "keyword."
-msgstr "通过HQL的<literal>with</literal>关键字,你可以提供额外的join条件。"
-
-#. Tag: programlisting
-#: query_hql.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"    left join cat.kittens as kitten\n"
-"        with kitten.bodyWeight > 10.0]]>"
 msgstr ""
+"通过 HQL 的 <literal>with</literal> 关键字,你可以提供额外的 join 条件。"
 
 #. Tag: para
-#: query_hql.xml:161
 #, fuzzy, no-c-format
 msgid ""
 "A \"fetch\" join allows associations or collections of values to be "
 "initialized along with their parent objects using a single select. This is "
 "particularly useful in the case of a collection. It effectively overrides "
 "the outer join and lazy declarations of the mapping file for associations "
-"and collections. See <xref linkend=\"performance-fetching\"/> for more "
+"and collections. See <xref linkend=\"performance-fetching\" /> for more "
 "information."
 msgstr ""
-"还有,一个\"fetch\"连接允许仅仅使用一个选择语句就将相关联的对象或一组值的集合"
-"随着他们的父对象的初始化而被初始化,这种方法在使用到集合的情况下尤其有用,对"
-"于关联和集合来说,它有效的代替了映射文件中的外联接 与延迟声明(lazy "
-"declarations). 查看 <xref linkend=\"performance-fetching\"/> 以获得等多的信"
+"还有,一个 \"fetch\" 连接允许仅仅使用一个选择语句就将相关联的对象或一组值的集"
+"合随着他们的父对象的初始化而被初始化,这种方法在使用到集合的情况下尤其有用,"
+"对于关联和集合来说,它有效的代替了映射文件中的外联接与延迟声明(lazy "
+"declarations)。查看 <xref linkend=\"performance-fetching\" /> 以获得等多的信"
 "息。"
 
-#. Tag: programlisting
-#: query_hql.xml:169
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join fetch cat.mate\n"
-"    left join fetch cat.kittens]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:171
-#, fuzzy, no-c-format
-msgid ""
 "A fetch join does not usually need to assign an alias, because the "
 "associated objects should not be used in the <literal>where</literal> clause "
 "(or any other clause). The associated objects are also not returned directly "
@@ -302,24 +202,13 @@
 "The only reason you might need an alias is if you are recursively join "
 "fetching a further collection:"
 msgstr ""
-"一个fetch连接通常不需要被指定别名, 因为相关联的对象不应当被用在 "
-"<literal>where</literal> 子句 (或其它任何子句)中。同时,相关联的对象 并不在查"
-"询的结果中直接返回,但可以通过他们的父对象来访问到他们。"
+"一个 fetch 连接通常不需要被指定别名,因为相关联的对象不应当被用在 "
+"<literal>where</literal> 子句(或其它任何子句)中。同时,相关联的对象并不在查"
+"询的结果中直接返回,但可以通过他们的父对象来访问到他们。 "
 
-#. Tag: programlisting
-#: query_hql.xml:179
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Cat as cat\n"
-"    inner join fetch cat.mate\n"
-"    left join fetch cat.kittens child\n"
-"    left join fetch child.kittens]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:181
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>fetch</literal> construct cannot be used in queries called "
 "using <literal>iterate()</literal> (though <literal>scroll()</literal> can "
 "be used). <literal>Fetch</literal> should be used together with "
@@ -335,20 +224,19 @@
 "<literal>full join fetch</literal> and <literal>right join fetch</literal> "
 "are not meaningful."
 msgstr ""
-"假若使用<literal>iterate()</literal>来调用查询,请注意<literal>fetch</"
-"literal>构造是不能使用的(<literal>scroll()</literal> 可以使用)。"
-"<literal>fetch</literal>也不应该与<literal>setMaxResults()</literal> 或"
-"<literal>setFirstResult()</literal>共用,这是因为这些操作是基于结果集的,而在"
-"预先抓取集合类时可能包含重复的数据,也就是说无法预先知道精确的行数。"
-"<literal>fetch</literal>还不能与独立的 <literal>with</literal>条件一起使用。"
-"通过在一次查询中fetch多个集合,可以制造出笛卡尔积,因此请多加注意。对bag映射"
-"来说,同时join fetch多个集合角色可能在某些情况下给出并非预期的结果,也请小"
-"心。最后注意,使用<literal>full join fetch</literal> 与 <literal>right join "
-"fetch</literal>是没有意义的。"
+"假若使用 <literal>iterate()</literal> 来调用查询,请注意 <literal>fetch</"
+"literal> 构造是不能使用的(<literal>scroll()</literal> 可以使用)。"
+"<literal>fetch</literal> 也不应该与 <literal>setMaxResults()</literal> 或 "
+"<literal>setFirstResult()</literal> 共用,这是因为这些操作是基于结果集的,而"
+"在预先抓取集合类时可能包含重复的数据,也就是说无法预先知道精确的行数。"
+"<literal>fetch</literal> 还不能与独立的 <literal>with</literal> 条件一起使"
+"用。通过在一次查询中 fetch 多个集合,可以制造出笛卡尔积,因此请多加注意。对 "
+"bag 映射来说,同时 join fetch 多个集合角色可能在某些情况下给出并非预期的结"
+"果,也请小心。最后注意,使用 <literal>full join fetch</literal> 与 "
+"<literal>right join fetch</literal> 是没有意义的。 "
 
 #. Tag: para
-#: query_hql.xml:196
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are using property-level lazy fetching (with bytecode "
 "instrumentation), it is possible to force Hibernate to fetch the lazy "
@@ -356,52 +244,34 @@
 "properties</literal>."
 msgstr ""
 "如果你使用属性级别的延迟获取(lazy fetching)(这是通过重新编写字节码实现"
-"的),可以使用 <literal>fetch all properties</literal> 来强制Hibernate立即取"
-"得那些原本需要延迟加载的属性(在第一个查询中)。"
+"的),可以使用  <literal>fetch all properties</literal> 来强制 Hibernate 立即"
+"取得那些原本需要延迟加载的属性(在第一个查询中)。 "
 
-#. Tag: programlisting
-#: query_hql.xml:202
-#, no-c-format
-msgid "<![CDATA[from Document fetch all properties order by name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:203
-#, no-c-format
-msgid ""
-"<![CDATA[from Document doc fetch all properties where lower(doc.name) like '%"
-"cats%']]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:208
 #, no-c-format
 msgid "Forms of join syntax"
 msgstr "join 语法的形式"
 
 #. Tag: para
-#: query_hql.xml:210
 #, no-c-format
 msgid ""
 "HQL supports two forms of association joining: <literal>implicit</literal> "
 "and <literal>explicit</literal>."
 msgstr ""
-"HQL支持两种关联join的形式:<literal>implicit(隐式)</literal> 与"
+"HQL 支持两种关联 join 的形式:<literal>implicit(隐式)</literal> 与 "
 "<literal>explicit(显式)</literal>。"
 
 #. Tag: para
-#: query_hql.xml:214
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The queries shown in the previous section all use the <literal>explicit</"
 "literal> form, that is, where the join keyword is explicitly used in the "
 "from clause. This is the recommended form."
 msgstr ""
-"上一节中给出的查询都是使用<literal>explicit(显式)</literal>形式的,其中form子"
-"句中明确给出了join关键字。这是建议使用的方式。"
+"上一节中给出的查询都是使用 <literal>explicit(显式)</literal>形式的,其中 "
+"form 子句中明确给出了 join 关键字。这是建议使用的方式。 "
 
 #. Tag: para
-#: query_hql.xml:219
 #, no-c-format
 msgid ""
 "The <literal>implicit</literal> form does not use the join keyword. Instead, "
@@ -409,55 +279,41 @@
 "literal> joins can appear in any of the HQL clauses. <literal>implicit</"
 "literal> join result in inner joins in the resulting SQL statement."
 msgstr ""
-"<literal>implicit(隐式)</literal>形式不使用join关键字。关联使用\"点号\"来进"
-"行“引用”。<literal>implicit</literal> join可以在任何HQL子句中出现."
-"<literal>implicit</literal> join在最终的SQL语句中以inner join的方式出现。"
+"<literal>implicit(隐式)</literal>形式不使用 join 关键字。关联使用\"点号\"来"
+"进行“引用”。<literal>implicit</literal> join 可以在任何 HQL 子句中出现。"
+"<literal>implicit</literal> join 在最终的 SQL 语句中以 inner join 的方式出"
+"现。"
 
-#. Tag: programlisting
-#: query_hql.xml:226
-#, no-c-format
-msgid "<![CDATA[from Cat as cat where cat.mate.name like '%s%']]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Referring to identifier property"
-msgstr "Refering to identifier property"
+msgstr "引用 identifier 属性 "
 
 #. Tag: para
-#: query_hql.xml:232
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "There are 2 ways to refer to an entity's identifier property:"
-msgstr ""
-"There are, generally speaking, 2 ways to refer to an entity's identifier "
-"property:"
+msgstr "通常有两种方法来引用实体的 identifier 属性: "
 
 #. Tag: para
-#: query_hql.xml:237
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The special property (lowercase) <literal>id</literal> may be used to "
 "reference the identifier property of an entity <emphasis>provided that the "
 "entity does not define a non-identifier property named id</emphasis>."
 msgstr ""
-"The special property (lowercase) <literal>id</literal> may be used to "
-"reference the identifier property of an entity <emphasis>provided that "
-"entity does not define a non-identifier property named id</emphasis>."
+"特殊属性(lowercase)<literal>id</literal> 可以用来引用实体的 identifier 属"
+"性 <emphasis>假设这个实体没有定义用 non-identifier 属性命名的 id</"
+"emphasis>。 "
 
 #. Tag: para
-#: query_hql.xml:244
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the entity defines a named identifier property, you can use that property "
 "name."
-msgstr ""
-"If the entity defines a named identifier property, you may use that property "
-"name."
+msgstr "如果这个实体定义了 identifier 属性,你可以使用属性名。 "
 
 #. Tag: para
-#: query_hql.xml:250
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "References to composite identifier properties follow the same naming rules. "
 "If the entity has a non-identifier property named id, the composite "
@@ -465,15 +321,12 @@
 "the special <literal>id</literal> property can be used to reference the "
 "identifier property."
 msgstr ""
-"References to composite identifier properties follow the same naming rules. "
-"If the entity has a non-identifier property named id, the composite "
-"identifier property can only be referenced by its defined named; otherwise, "
-"the special <literal>id</literal> property can be used to rerference the "
-"identifier property."
+"对组合 identifier 属性的引用遵循相同的命名规则。如果实体有一个 non-"
+"identifier 属性命名的 id,这个组合 identifier 属性只能用自己定义的名字来引"
+"用;否则,特殊 <literal>id</literal> 属性可以用来引用 identifier 属性。 "
 
 #. Tag: para
-#: query_hql.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please note that, starting in version 3.2.2, this has changed significantly. "
 "In previous versions, <literal>id</literal> <emphasis>always</emphasis> "
@@ -481,277 +334,146 @@
 "ramification of that decision was that non-identifier properties named "
 "<literal>id</literal> could never be referenced in Hibernate queries."
 msgstr ""
-"Note: this has changed significantly starting in version 3.2.2. In previous "
-"versions, <literal>id</literal><emphasis>always</emphasis> referred to the "
-"identifier property no matter what its actual name. A ramification of that "
-"decision was that non-identifier properties named <literal>id</literal> "
-"could never be referenced in Hibernate queries."
+"注意:从 3.2.2 版本开始,这已经改变了很多。在前面的版本里,不管实际的名字,"
+"<literal>id</literal> <emphasis>总是</emphasis>指向 identifier 属性;而用 "
+"non-identifier 属性命名的 <literal>id</literal> 就从来不在 Hibernate 查询里引"
+"用。  "
 
 #. Tag: title
-#: query_hql.xml:269
 #, no-c-format
 msgid "The select clause"
-msgstr "select子句"
+msgstr "select 子句"
 
 #. Tag: para
-#: query_hql.xml:271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>select</literal> clause picks which objects and properties to "
 "return in the query result set. Consider the following:"
 msgstr ""
-"<literal>select</literal> 子句选择将哪些对象与属性返 回到查询结果集中. 考虑如"
-"下情况:"
+"<literal>select</literal> 子句选择将哪些对象与属性返回到查询结果集中。考虑如"
+"下情况:"
 
-#. Tag: programlisting
-#: query_hql.xml:276
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select mate\n"
-"from Cat as cat\n"
-"    inner join cat.mate as mate]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:278
-#, fuzzy, no-c-format
-msgid ""
 "The query will select <literal>mate</literal>s of other <literal>Cat</"
 "literal>s. You can express this query more compactly as:"
 msgstr ""
-"该语句将选择<literal>mate</literal>s of other <literal>Cat</literal>s。(其他"
-"猫的配偶) 实际上, 你可以更简洁的用以下的查询语句表达相同的含义:"
+"该语句将选择其它 <literal>Cat</literal> 的 <literal>mate</literal>(其他猫的"
+"配偶)。实际上,你可以更简洁的用以下的查询语句表达相同的含义: "
 
-#. Tag: programlisting
-#: query_hql.xml:283
-#, no-c-format
-msgid "<![CDATA[select cat.mate from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:285
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Queries can return properties of any value type including properties of "
 "component type:"
 msgstr ""
-"查询语句可以返回值为任何类型的属性,包括返回类型为某种组件(Component)的属性:"
+"查询语句可以返回值为任何类型的属性,包括返回类型为某种组件(Component)的属"
+"性: "
 
-#. Tag: programlisting
-#: query_hql.xml:289
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat.name from DomesticCat cat\n"
-"where cat.name like 'fri%']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:291
-#, no-c-format
-msgid "<![CDATA[select cust.name.firstName from Customer as cust]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:293
-#, fuzzy, no-c-format
-msgid ""
 "Queries can return multiple objects and/or properties as an array of type "
 "<literal>Object[]</literal>:"
 msgstr ""
-"查询语句可以返回多个对象和(或)属性,存放在 <literal>Object[]</literal>队列"
-"中,"
+"查询语句可以返回多个对象和(或)属性,存放在 <literal>Object[]</literal> 队列"
+"中, "
 
-#. Tag: programlisting
-#: query_hql.xml:298
-#, no-c-format
-msgid ""
-"<![CDATA[select mother, offspr, mate.name\n"
-"from DomesticCat as mother\n"
-"    inner join mother.mate as mate\n"
-"    left outer join mother.kittens as offspr]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:300
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Or as a <literal>List</literal>:"
-msgstr "或存放在一个<literal>List</literal>对象中,"
+msgstr "或存放在一个 <literal>List</literal> 对象中:"
 
-#. Tag: programlisting
-#: query_hql.xml:304
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select new list(mother, offspr, mate.name)\n"
-"from DomesticCat as mother\n"
-"    inner join mother.mate as mate\n"
-"    left outer join mother.kittens as offspr]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:306
-#, fuzzy, no-c-format
-msgid ""
 "Or - assuming that the class <literal>Family</literal> has an appropriate "
 "constructor - as an actual typesafe Java object:"
-msgstr "假设类<literal>Family</literal>有一个合适的构造函数."
-
-#. Tag: programlisting
-#: query_hql.xml:310
-#, no-c-format
-msgid ""
-"<![CDATA[select new Family(mother, mate, offspr)\n"
-"from DomesticCat as mother\n"
-"    join mother.mate as mate\n"
-"    left join mother.kittens as offspr]]>"
 msgstr ""
+"假设类 <literal>Family</literal> 有一个合适的构造函数 - 作为实际的类型安全的 "
+"Java 对象:"
 
 #. Tag: para
-#: query_hql.xml:313
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can assign aliases to selected expressions using <literal>as</literal>:"
-msgstr "你可以使用关键字<literal>as</literal>给“被选择了的表达式”指派别名:"
+msgstr "你可以使用关键字 <literal>as</literal> 给“被选择了的表达式”指派别名: "
 
-#. Tag: programlisting
-#: query_hql.xml:317
-#, no-c-format
-msgid ""
-"<![CDATA[select max(bodyWeight) as max, min(bodyWeight) as min, count(*) as "
-"n\n"
-"from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:319
 #, no-c-format
 msgid ""
 "This is most useful when used together with <literal>select new map</"
 "literal>:"
-msgstr "这种做法在与子句<literal>select new map</literal>一起使用时最有用:"
+msgstr "这种做法在与子句 <literal>select new map</literal> 一起使用时最有用:"
 
-#. Tag: programlisting
-#: query_hql.xml:323
-#, no-c-format
-msgid ""
-"<![CDATA[select new map( max(bodyWeight) as max, min(bodyWeight) as min, "
-"count(*) as n )\n"
-"from Cat cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:325
 #, no-c-format
 msgid ""
 "This query returns a <literal>Map</literal> from aliases to selected values."
 msgstr ""
-"该查询返回了一个<literal>Map</literal>的对象,内容是别名与被选择的值组成的名-"
-"值映射。"
+"该查询返回了一个 <literal>Map</literal> 的对象,内容是别名与被选择的值组成的"
+"名-值映射。"
 
 #. Tag: title
-#: query_hql.xml:332
 #, no-c-format
 msgid "Aggregate functions"
 msgstr "聚集函数"
 
 #. Tag: para
-#: query_hql.xml:334
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL queries can even return the results of aggregate functions on properties:"
-msgstr "HQL查询甚至可以返回作用于属性之上的聚集函数的计算结果:"
+msgstr "HQL 查询甚至可以返回作用于属性之上的聚集函数的计算结果: "
 
-#. Tag: programlisting
-#: query_hql.xml:338
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[select avg(cat.weight), sum(cat.weight), max(cat.weight), count"
-"(cat)\n"
-"from Cat cat]]>"
-msgstr ""
+msgid "The supported aggregate functions are:"
+msgstr "受支持的聚集函数如下: "
 
 #. Tag: para
-#: query_hql.xml:349
 #, fuzzy, no-c-format
-msgid "The supported aggregate functions are:"
-msgstr "受支持的聚集函数如下:"
+msgid "<literal>avg(...), sum(...), min(...), max(...)</literal>"
+msgstr "<literal>avg(...), sum(...), min(...), max(...)</literal>"
 
-#. Tag: literal
-#: query_hql.xml:356
+#. Tag: para
 #, no-c-format
-msgid "avg(...), sum(...), min(...), max(...)"
-msgstr "avg(...), sum(...), min(...), max(...)"
+msgid "<literal>count(*)</literal>"
+msgstr "<literal>count(*)</literal>"
 
-#. Tag: literal
-#: query_hql.xml:361
-#, no-c-format
-msgid "count(*)"
-msgstr "count(*)"
-
-#. Tag: literal
-#: query_hql.xml:366
-#, no-c-format
-msgid "count(...), count(distinct ...), count(all...)"
-msgstr "count(...), count(distinct ...), count(all...)"
-
 #. Tag: para
-#: query_hql.xml:371
 #, fuzzy, no-c-format
+msgid "<literal>count(...), count(distinct ...), count(all...)</literal>"
+msgstr "<literal>count(...), count(distinct ...), count(all...)</literal>"
+
+#. Tag: para
+#, no-c-format
 msgid ""
 "You can use arithmetic operators, concatenation, and recognized SQL "
 "functions in the select clause:"
-msgstr "你可以在选择子句中使用数学操作符、连接以及经过验证的SQL函数:"
+msgstr "你可以在选择子句中使用数学操作符、连接以及经过验证的 SQL 函数: "
 
-#. Tag: programlisting
-#: query_hql.xml:376
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat.weight + sum(kitten.weight)\n"
-"from Cat cat\n"
-"    join cat.kittens kitten\n"
-"group by cat.id, cat.weight]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:378
-#, no-c-format
-msgid ""
-"<![CDATA[select firstName||' '||initial||' '||upper(lastName) from Person]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:380
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>distinct</literal> and <literal>all</literal> keywords can be "
 "used and have the same semantics as in SQL."
 msgstr ""
-"关键字<literal>distinct</literal>与<literal>all</literal> 也可以使用,它们具"
-"有与SQL相同的语义."
+"关键字 <literal>distinct</literal> 与 <literal>all</literal> 也可以使用,它们"
+"具有与 SQL 相同的语义。 "
 
-#. Tag: programlisting
-#: query_hql.xml:385
-#, no-c-format
-msgid ""
-"<![CDATA[select distinct cat.name from Cat cat\n"
-"\n"
-"select count(distinct cat.name), count(cat) from Cat cat]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:390
 #, no-c-format
 msgid "Polymorphic queries"
 msgstr "多态查询"
 
 #. Tag: para
-#: query_hql.xml:392
 #, no-c-format
 msgid "A query like:"
-msgstr "一个如下的查询语句:"
+msgstr "一个如下的查询语句:"
 
 #. Tag: para
-#: query_hql.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "returns instances not only of <literal>Cat</literal>, but also of subclasses "
 "like <literal>DomesticCat</literal>. Hibernate queries can name "
@@ -760,294 +482,173 @@
 "that extend that class or implement the interface. The following query would "
 "return all persistent objects:"
 msgstr ""
-"不仅返回<literal>Cat</literal>类的实例, 也同时返回子类 <literal>DomesticCat</"
-"literal>的实例. Hibernate 可以在<literal>from</literal>子句中指定<emphasis>任"
-"何</emphasis> Java 类或接口. 查询会返回继承了该类的所有持久化子类 的实例或返"
-"回声明了该接口的所有持久化类的实例。下面的查询语句返回所有的被持久化的对象:"
+"不仅返回 <literal>Cat</literal> 类的实例,也同时返回子类 "
+"<literal>DomesticCat</literal> 的实例。Hibernate 可以在 <literal>from</"
+"literal> 子句中指定<emphasis>任何</emphasis> Java 类或接口。查询会返回继承了"
+"该类的所有持久化子类的实例或返回声明了该接口的所有持久化类的实例。下面的查询"
+"语句返回所有的被持久化的对象: "
 
-#. Tag: programlisting
-#: query_hql.xml:406
-#, no-c-format
-msgid "<![CDATA[from java.lang.Object o]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:408
 #, no-c-format
 msgid ""
 "The interface <literal>Named</literal> might be implemented by various "
 "persistent classes:"
-msgstr "接口<literal>Named</literal> 可能被各种各样的持久化类声明:"
+msgstr "接口 <literal>Named</literal> 可能被各种各样的持久化类声明:"
 
-#. Tag: programlisting
-#: query_hql.xml:413
-#, no-c-format
-msgid "<![CDATA[from Named n, Named m where n.name = m.name]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:415
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "These last two queries will require more than one SQL <literal>SELECT</"
 "literal>. This means that the <literal>order by</literal> clause does not "
 "correctly order the whole result set. It also means you cannot call these "
 "queries using <literal>Query.scroll()</literal>."
 msgstr ""
-"注意,最后的两个查询将需要超过一个的SQL <literal>SELECT</literal>.这表明"
-"<literal>order by</literal>子句 没有对整个结果集进行正确的排序. (这也说明你不"
-"能对这样的查询使用<literal>Query.scroll()</literal>方法.)"
+"注意,最后的两个查询将需要超过一个的 SQL <literal>SELECT</literal>。这表明 "
+"<literal>order by</literal> 子句没有对整个结果集进行正确的排序。(这也说明你"
+"不能对这样的查询使用 <literal>Query.scroll()</literal> 方法。)"
 
 #. Tag: title
-#: query_hql.xml:424
 #, no-c-format
 msgid "The where clause"
-msgstr "where子句"
+msgstr "where 子句"
 
 #. Tag: para
-#: query_hql.xml:426
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>where</literal> clause allows you to refine the list of "
 "instances returned. If no alias exists, you can refer to properties by name:"
 msgstr ""
-"<literal>where</literal>子句允许你将返回的实例列表的范围缩小. 如果没有指定别"
-"名,你可以使用属性名来直接引用属性:"
+"<literal>where</literal> 子句允许你将返回的实例列表的范围缩小。如果没有指定别"
+"名,你可以使用属性名来直接引用属性: "
 
-#. Tag: programlisting
-#: query_hql.xml:431
-#, no-c-format
-msgid "<![CDATA[from Cat where name='Fritz']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:433
 #, no-c-format
 msgid "If there is an alias, use a qualified property name:"
-msgstr "如果指派了别名,需要使用完整的属性名:"
+msgstr "如果指派了别名,需要使用完整的属性名:"
 
-#. Tag: programlisting
-#: query_hql.xml:437
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from Cat as cat where cat.name='Fritz']]>"
+msgid "This returns instances of <literal>Cat</literal> named 'Fritz'."
 msgstr ""
+"返回名为(属性 name 等于)'Fritz' 的 <literal>Cat</literal> 类的实例。 "
 
 #. Tag: para
-#: query_hql.xml:439
-#, fuzzy, no-c-format
-msgid "This returns instances of <literal>Cat</literal> named 'Fritz'."
-msgstr "返回名为(属性name等于)'Fritz'的<literal>Cat</literal>类的实例。"
-
-#. Tag: para
-#: query_hql.xml:443
 #, no-c-format
 msgid "The following query:"
-msgstr ""
+msgstr "下面的查询:"
 
-#. Tag: programlisting
-#: query_hql.xml:446
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select foo\n"
-"from Foo foo, Bar bar\n"
-"where foo.startDate = bar.date]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:448
-#, fuzzy, no-c-format
-msgid ""
 "returns all instances of <literal>Foo</literal> with an instance of "
 "<literal>bar</literal> with a <literal>date</literal> property equal to the "
 "<literal>startDate</literal> property of the <literal>Foo</literal>. "
 "Compound path expressions make the <literal>where</literal> clause extremely "
 "powerful. Consider the following:"
 msgstr ""
-"将返回所有满足下面条件的<literal>Foo</literal>类的实例: 存在如下的"
-"<literal>bar</literal>的一个实例,其<literal>date</literal>属性等于 "
-"<literal>Foo</literal>的<literal>startDate</literal>属性。 复合路径表达式使得"
-"<literal>where</literal>子句非常的强大,考虑如下情况:"
+"将返回所有满足下面条件的 <literal>Foo</literal> 类的实例: 存在如下的 "
+"<literal>bar</literal> 的一个实例,其 <literal>date</literal> 属性等于 "
+"<literal>Foo</literal> 的 <literal>startDate</literal> 属性。复合路径表达式使"
+"得 <literal>where</literal> 子句非常的强大,考虑如下情况: "
 
-#. Tag: programlisting
-#: query_hql.xml:457
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.mate.name is not null]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:459
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This query translates to an SQL query with a table (inner) join. For example:"
 msgstr ""
-"该查询将被翻译成为一个含有表连接(内连接)的SQL查询。如果你打算写像这样的查询"
-"语句"
+"该查询将被翻译成为一个含有表连接(内连接)的 SQL 查询。如果你打算写像这样的查"
+"询语句:"
 
-#. Tag: programlisting
-#: query_hql.xml:464
-#, no-c-format
-msgid ""
-"<![CDATA[from Foo foo\n"
-"where foo.bar.baz.customer.address.city is not null]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:466
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "would result in a query that would require four table joins in SQL."
-msgstr "在SQL中,你为达此目的将需要进行一个四表连接的查询。"
+msgstr "在 SQL 中,你为达此目的将需要进行一个四表连接的查询。 "
 
 #. Tag: para
-#: query_hql.xml:470
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>=</literal> operator can be used to compare not only "
 "properties, but also instances:"
 msgstr ""
-"<literal>=</literal>运算符不仅可以被用来比较属性的值,也可以用来比较实例:"
+"<literal>=</literal> 运算符不仅可以被用来比较属性的值,也可以用来比较实例: "
 
-#. Tag: programlisting
-#: query_hql.xml:475
-#, no-c-format
-msgid "<![CDATA[from Cat cat, Cat rival where cat.mate = rival.mate]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:477
-#, no-c-format
-msgid ""
-"<![CDATA[select cat, mate\n"
-"from Cat cat, Cat mate\n"
-"where cat.mate = mate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:479
 #, fuzzy, no-c-format
 msgid ""
 "The special property (lowercase) <literal>id</literal> can be used to "
 "reference the unique identifier of an object. See <xref linkend=\"queryhql-"
-"identifier-property\"/> for more information."
+"identifier-property\" /> for more information."
 msgstr ""
-"特殊属性(小写)<literal>id</literal>可以用来表示一个对象的唯一的标识符。(你"
-"也可以使用该对象的属性名。)"
+"特殊属性(小写)<literal>id</literal> 可以用来表示一个对象的唯一的标识符。详"
+"情请参考 <xref linkend=\"queryhql-identifier-property\" />。"
 
-#. Tag: programlisting
-#: query_hql.xml:485
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat where cat.id = 123\n"
-"\n"
-"from Cat as cat where cat.mate.id = 69]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:487
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The second query is efficient and does not require a table join."
-msgstr "第二个查询是有效的。此时不需要进行表连接!"
+msgstr "第二个查询是有效的。此时不需要进行表连接。"
 
 #. Tag: para
-#: query_hql.xml:491
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Properties of composite identifiers can also be used. Consider the following "
 "example where <literal>Person</literal> has composite identifiers consisting "
 "of <literal>country</literal> and <literal>medicareNumber</literal>:"
 msgstr ""
-"同样也可以使用复合标识符。比如<literal>Person</literal>类有一个复合标识符,它"
-"由<literal>country</literal>属性 与<literal>medicareNumber</literal>属性组"
-"成。"
+"同样也可以使用复合标识符。比如 <literal>Person</literal> 类有一个复合标识符,"
+"它由 <literal>country</literal> 属性与 <literal>medicareNumber</literal> 属性"
+"组成:"
 
-#. Tag: programlisting
-#: query_hql.xml:497
-#, no-c-format
-msgid ""
-"<![CDATA[from bank.Person person\n"
-"where person.id.country = 'AU'\n"
-"    and person.id.medicareNumber = 123456]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:499
-#, no-c-format
-msgid ""
-"<![CDATA[from bank.Account account\n"
-"where account.owner.id.country = 'AU'\n"
-"    and account.owner.id.medicareNumber = 123456]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:501
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Once again, the second query does not require a table join."
-msgstr "第二个查询也不需要进行表连接。"
+msgstr "第二个查询也不需要进行表连接。 "
 
 #. Tag: para
-#: query_hql.xml:505
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
-"See <xref linkend=\"queryhql-identifier-property\"/> for more information "
+"See <xref linkend=\"queryhql-identifier-property\" /> for more information "
 "regarding referencing identifier properties)"
 msgstr ""
+"关于引用标识符属性的更多信息,请参考 <xref linkend=\"queryhql-identifier-"
+"property\" />。"
 
 #. Tag: para
-#: query_hql.xml:510
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The special property <literal>class</literal> accesses the discriminator "
 "value of an instance in the case of polymorphic persistence. A Java class "
 "name embedded in the where clause will be translated to its discriminator "
 "value."
 msgstr ""
-"同样的,特殊属性<literal>class</literal>在进行多态持久化的情况下被用来存取一"
-"个实例的鉴别值(discriminator value)。 一个嵌入到where子句中的Java类的名字将"
-"被转换为该类的鉴别值。"
+"同样的,特殊属性 <literal>class</literal> 在进行多态持久化的情况下被用来存取"
+"一个实例的鉴别值(discriminator value)。一个嵌入到 where 子句中的 Java 类的"
+"名字将被转换为该类的鉴别值。 "
 
-#. Tag: programlisting
-#: query_hql.xml:516
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.class = DomesticCat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:518
 #, fuzzy, no-c-format
 msgid ""
 "You can also use components or composite user types, or properties of said "
-"component types. See <xref linkend=\"queryhql-components\"/> for more "
+"component types. See <xref linkend=\"queryhql-components\" /> for more "
 "information."
 msgstr ""
-"你也可以声明一个属性的类型是组件或者复合用户类型(以及由组件构成的组件等"
-"等)。永远不要尝试使用以组件类型来结尾的路径表达式(path-expression) (与此"
-"相反,你应当使用组件的一个属性来结尾)。 举例来说,如果<literal>store.owner</"
-"literal>含有一个包含了组件的实体<literal>address</literal>"
+"你也可以使用组件或者复合用户类型,以及组件类型的属性。详情请参考 <xref "
+"linkend=\"queryhql-components\" />。"
 
 #. Tag: para
-#: query_hql.xml:523
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An \"any\" type has the special properties <literal>id</literal> and "
 "<literal>class</literal> that allows you to express a join in the following "
 "way (where <literal>AuditLog.item</literal> is a property mapped with "
 "<literal>&lt;any&gt;</literal>):"
 msgstr ""
-"一个“任意”类型有两个特殊的属性<literal>id</literal>和<literal>class</"
-"literal>, 来允许我们按照下面的方式表达一个连接(<literal>AuditLog.item</"
-"literal> 是一个属性,该属性被映射为<literal>&lt;any&gt;</literal>)。"
+"一个“任意”类型有两个特殊的属性 <literal>id</literal> 和 <literal>class</"
+"literal>,来允许我们按照下面的方式表达一个连接(<literal>AuditLog.item</"
+"literal> 是一个属性,该属性被映射为 <literal>&lt;any&gt;</literal>)。 "
 
-#. Tag: programlisting
-#: query_hql.xml:529
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from AuditLog log, Payment payment\n"
-"where log.item.class = 'Payment' and log.item.id = payment.id]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:531
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>log.item.class</literal> and <literal>payment.class</literal> "
 "would refer to the values of completely different database columns in the "
 "above query."
@@ -1056,49 +657,43 @@
 "<literal>payment.class</literal> 将涉及到完全不同的数据库中的列。"
 
 #. Tag: title
-#: query_hql.xml:539
 #, no-c-format
 msgid "Expressions"
 msgstr "表达式"
 
 #. Tag: para
-#: query_hql.xml:541
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Expressions used in the <literal>where</literal> clause include the "
 "following:"
 msgstr ""
-"在<literal>where</literal>子句中允许使用的表达式包括 大多数你可以在SQL使用的"
-"表达式种类:"
+"在 <literal>where</literal> 子句中允许使用的表达式包括 大多数你可以在 SQL 使"
+"用的表达式种类: "
 
 #. Tag: para
-#: query_hql.xml:548
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "mathematical operators: <literal>+, -, *, /</literal>"
-msgstr "数学运算符<literal>+, -, *, /</literal>"
+msgstr "数学运算符 <literal>+,-,*,/</literal> "
 
 #. Tag: para
-#: query_hql.xml:553
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "binary comparison operators: <literal>=, &gt;=, &lt;=, &lt;&gt;, !=, like</"
 "literal>"
-msgstr "二进制比较运算符<literal>=, &gt;=, &lt;=, &lt;&gt;, !=, like</literal>"
+msgstr ""
+"二进制比较运算符 <literal>=, &gt;=, &lt;=, &lt;&gt;, !=, like</literal> "
 
 #. Tag: para
-#: query_hql.xml:558
 #, no-c-format
 msgid "logical operations <literal>and, or, not</literal>"
-msgstr "逻辑运算符<literal>and, or, not</literal>"
+msgstr "逻辑运算符 <literal>and,or,not</literal>"
 
 #. Tag: para
-#: query_hql.xml:563
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Parentheses <literal>( )</literal> that indicates grouping"
-msgstr "Parentheses <literal>( )</literal>, indicating grouping"
+msgstr "括号 <literal>( )</literal>,表示分组 "
 
 #. Tag: para
-#: query_hql.xml:568
 #, no-c-format
 msgid ""
 "<literal>in</literal>, <literal>not in</literal>, <literal>between</"
@@ -1112,65 +707,59 @@
 "<literal>member of</literal> and <literal>not member of</literal>"
 
 #. Tag: para
-#: query_hql.xml:581
 #, no-c-format
 msgid ""
 "\"Simple\" case, <literal>case ... when ... then ... else ... end</literal>, "
 "and \"searched\" case, <literal>case when ... then ... else ... end</literal>"
 msgstr ""
-"\"简单的\" case, <literal>case ... when ... then ... else ... end</literal>,"
-"和 \"搜索\" case, <literal>case when ... then ... else ... end</literal>"
+"\"Simple\" case, <literal>case ... when ... then ... else ... end</literal>, "
+"and \"searched\" case, <literal>case when ... then ... else ... end</literal>"
 
 #. Tag: para
-#: query_hql.xml:587
 #, no-c-format
 msgid ""
 "string concatenation <literal>...||...</literal> or <literal>concat(...,...)"
 "</literal>"
 msgstr ""
-"字符串连接符<literal>...||...</literal> or <literal>concat(...,...)</literal>"
+"字符串连接符 <literal>...||...</literal> or <literal>concat(...,...)</"
+"literal>"
 
 #. Tag: para
-#: query_hql.xml:592
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>current_date()</literal>, <literal>current_time()</literal>, and "
 "<literal>current_timestamp()</literal>"
 msgstr ""
-"<literal>current_date()</literal>, <literal>current_time()</literal>, "
+"<literal>current_date()</literal>, <literal>current_time()</literal>, and "
 "<literal>current_timestamp()</literal>"
 
 #. Tag: para
-#: query_hql.xml:598
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>second(...)</literal>, <literal>minute(...)</literal>, <literal>hour"
 "(...)</literal>, <literal>day(...)</literal>, <literal>month(...)</literal>, "
 "and <literal>year(...)</literal>"
 msgstr ""
-"<literal>second(...)</literal>, <literal>minute(...)</literal>, <literal>hour"
-"(...)</literal>, <literal>day(...)</literal>, <literal>month(...)</literal>, "
-"<literal>year(...)</literal>,"
+"<literal>second(...)</literal>、<literal>minute(...)</literal>、<literal>hour"
+"(...)</literal>、<literal>day(...)</literal>、<literal>month(...)</literal> "
+"和 <literal>year(...)</literal>"
 
 #. Tag: para
-#: query_hql.xml:605
 #, no-c-format
 msgid ""
 "Any function or operator defined by EJB-QL 3.0: <literal>substring(), trim"
 "(), lower(), upper(), length(), locate(), abs(), sqrt(), bit_length(), mod()"
 "</literal>"
 msgstr ""
-"EJB-QL 3.0定义的任何函数或操作:<literal>substring(), trim(), lower(), upper"
-"(), length(), locate(), abs(), sqrt(), bit_length(), mod()</literal>"
+"EJB-QL 3.0 定义的任何功能或操作符:<literal>substring(), trim(), lower(), "
+"upper(), length(), locate(), abs(), sqrt(), bit_length(), mod()</literal>"
 
 #. Tag: para
-#: query_hql.xml:611
 #, no-c-format
 msgid "<literal>coalesce()</literal> and <literal>nullif()</literal>"
 msgstr "<literal>coalesce()</literal> 和 <literal>nullif()</literal>"
 
 #. Tag: para
-#: query_hql.xml:616
 #, no-c-format
 msgid ""
 "<literal>str()</literal> for converting numeric or temporal values to a "
@@ -1178,7 +767,6 @@
 msgstr "<literal>str()</literal> 把数字或者时间值转换为可读的字符串"
 
 #. Tag: para
-#: query_hql.xml:622
 #, no-c-format
 msgid ""
 "<literal>cast(... as ...)</literal>, where the second argument is the name "
@@ -1186,21 +774,19 @@
 "<literal>cast()</literal> and <literal>extract()</literal> is supported by "
 "the underlying database"
 msgstr ""
-"<literal>cast(... as ...)</literal>, 其第二个参数是某Hibernate类型的名字,以"
-"及<literal>extract(... from ...)</literal>,只要ANSI <literal>cast()</"
-"literal> 和 <literal>extract()</literal> 被底层数据库支持"
+"<literal>cast(... as ...)</literal>,其第二个参数是某 Hibernate 类型的名字,"
+"以及 <literal>extract(... from ...)</literal>,只要 ANSI <literal>cast()</"
+"literal> 和  <literal>extract()</literal> 被底层数据库支持"
 
 #. Tag: para
-#: query_hql.xml:630
 #, no-c-format
 msgid ""
 "the HQL <literal>index()</literal> function, that applies to aliases of a "
 "joined indexed collection"
-msgstr "HQL <literal>index()</literal> 函数,作用于join的有序集合的别名。"
+msgstr "HQL <literal>index()</literal> 函数,作用于 join 的有序集合的别名。"
 
 #. Tag: para
-#: query_hql.xml:636
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL functions that take collection-valued path expressions: <literal>size(), "
 "minelement(), maxelement(), minindex(), maxindex()</literal>, along with the "
@@ -1208,40 +794,36 @@
 "functions that can be quantified using <literal>some, all, exists, any, in</"
 "literal>."
 msgstr ""
-"HQL函数,把集合作为参数:<literal>size(), minelement(), maxelement(), minindex"
-"(), maxindex()</literal>,还有特别的<literal>elements()</literal> 和"
-"<literal>indices</literal>函数,可以与数量词加以限定:<literal>some, all, "
-"exists, any, in</literal>。"
+"HQL 函数,把集合作为参数:<literal>size(), minelement(), maxelement(), "
+"minindex(), maxindex()</literal>,还有特别的 <literal>elements()</literal> "
+"和 <literal>indices</literal> 函数,可以与数量词加以限定:<literal>some, "
+"all, exists, any, in</literal>。 "
 
 #. Tag: para
-#: query_hql.xml:644
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Any database-supported SQL scalar function like <literal>sign()</literal>, "
 "<literal>trunc()</literal>, <literal>rtrim()</literal>, and <literal>sin()</"
 "literal>"
 msgstr ""
-"任何数据库支持的SQL标量函数,比如<literal>sign()</literal>, <literal>trunc()"
-"</literal>, <literal>rtrim()</literal>, <literal>sin()</literal>"
+"任何数据库支持的 SQL 标量函数,比如 <literal>sign()</literal>, <literal>trunc"
+"()</literal>, <literal>rtrim()</literal>, <literal>sin()</literal> "
 
 #. Tag: para
-#: query_hql.xml:650
 #, no-c-format
 msgid "JDBC-style positional parameters <literal>?</literal>"
-msgstr "JDBC风格的参数传入 <literal>?</literal>"
+msgstr "JDBC 风格的参数传入 <literal>?</literal>"
 
 #. Tag: para
-#: query_hql.xml:655
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "named parameters <literal>:name</literal>, <literal>:start_date</literal>, "
 "and <literal>:x1</literal>"
 msgstr ""
-"命名参数<literal>:name</literal>, <literal>:start_date</literal>, <literal>:"
-"x1</literal>"
+"命名参数 <literal>:name</literal>,<literal>:start_date</literal>,<literal>:"
+"x1</literal> "
 
 #. Tag: para
-#: query_hql.xml:660
 #, no-c-format
 msgid ""
 "SQL literals <literal>'foo'</literal>, <literal>69</literal>, <literal>6.66E"
@@ -1251,7 +833,6 @@
 "+2</literal>, <literal>'1970-01-01 10:00:01.0'</literal>"
 
 #. Tag: para
-#: query_hql.xml:666
 #, no-c-format
 msgid ""
 "Java <literal>public static final</literal> constants <literal>eg.Color."
@@ -1261,117 +842,58 @@
 "TABBY</literal>"
 
 #. Tag: para
-#: query_hql.xml:672
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>in</literal> and <literal>between</literal> can be used as follows:"
 msgstr ""
-"关键字<literal>in</literal>与<literal>between</literal>可按如下方法使用:"
+"关键字 <literal>in</literal> 与 <literal>between</literal> 可按如下方法使"
+"用: "
 
-#. Tag: programlisting
-#: query_hql.xml:676
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name between 'A' and 'B']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:678
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat cat where cat.name in ( 'Foo', 'Bar', 'Baz' )]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:680
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The negated forms can be written as follows:"
-msgstr "而且否定的格式也可以如下书写:"
+msgstr "而且否定的格式也可以如下书写: "
 
-#. Tag: programlisting
-#: query_hql.xml:684
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from DomesticCat cat where cat.name not between 'A' and 'B']]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:686
-#, no-c-format
 msgid ""
-"<![CDATA[from DomesticCat cat where cat.name not in ( 'Foo', 'Bar', 'Baz' )]]"
-">"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:688
-#, fuzzy, no-c-format
-msgid ""
 "Similarly, <literal>is null</literal> and <literal>is not null</literal> can "
 "be used to test for null values."
 msgstr ""
-"同样, 子句<literal>is null</literal>与<literal>is not null</literal>可以被用"
-"来测试空值(null)."
+"同样,子句 <literal>is null</literal> 与 <literal>is not null</literal> 可以"
+"被用来测试空值(null)。 "
 
 #. Tag: para
-#: query_hql.xml:693
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Booleans can be easily used in expressions by declaring HQL query "
 "substitutions in Hibernate configuration:"
 msgstr ""
-"在Hibernate配置文件中声明HQL“查询替代(query substitutions)”之后, 布尔表达"
-"式(Booleans)可以在其他表达式中轻松的使用:"
+"在 Hibernate 配置文件中声明 HQL“查询替代(query substitutions)”之后,布尔表"
+"达式(Booleans)可以在其他表达式中轻松的使用: "
 
-#. Tag: programlisting
-#: query_hql.xml:698
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"hibernate.query.substitutions\">true 1, false 0</"
-"property>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:700
 #, no-c-format
 msgid ""
 "This will replace the keywords <literal>true</literal> and <literal>false</"
 "literal> with the literals <literal>1</literal> and <literal>0</literal> in "
 "the translated SQL from this HQL:"
 msgstr ""
-"系统将该HQL转换为SQL语句时,该设置表明将用字符 <literal>1</literal> 和 "
-"<literal>0</literal> 来 取代关键字<literal>true</literal> 和 <literal>false</"
-"literal>:"
+"系统将该 HQL 转换为 SQL 语句时,该设置表明将用字符 <literal>1</literal> 和  "
+"<literal>0</literal> 来取代关键字 <literal>true</literal> 和 <literal>false</"
+"literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:705
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.alive = true]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:707
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can test the size of a collection with the special property "
 "<literal>size</literal> or the special <literal>size()</literal> function."
 msgstr ""
-"你可以用特殊属性<literal>size</literal>, 或是特殊函数<literal>size()</"
-"literal>测试一个集合的大小。"
+"你可以用特殊属性 <literal>size</literal>,或是特殊函数 <literal>size()</"
+"literal> 测试一个集合的大小。 "
 
-#. Tag: programlisting
-#: query_hql.xml:712
-#, no-c-format
-msgid "<![CDATA[from Cat cat where cat.kittens.size > 0]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:714
-#, no-c-format
-msgid "<![CDATA[from Cat cat where size(cat.kittens) > 0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:716
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For indexed collections, you can refer to the minimum and maximum indices "
 "using <literal>minindex</literal> and <literal>maxindex</literal> functions. "
@@ -1379,364 +901,155 @@
 "of basic type using the <literal>minelement</literal> and "
 "<literal>maxelement</literal> functions. For example:"
 msgstr ""
-"对于索引了(有序)的集合,你可以使用<literal>minindex</literal> 与 "
-"<literal>maxindex</literal>函数来引用到最小与最大的索引序数。 同理,你可以使"
-"用<literal>minelement</literal> 与 <literal>maxelement</literal>函数来 引用到"
-"一个基本数据类型的集合中最小与最大的元素。"
+"对于索引了(有序)的集合,你可以使用 <literal>minindex</literal> 与  "
+"<literal>maxindex</literal> 函数来引用到最小与最大的索引序数。同理,你可以使"
+"用 <literal>minelement</literal> 与 <literal>maxelement</literal> 函数来引用"
+"到一个基本数据类型的集合中最小与最大的元素。例如:"
 
-#. Tag: programlisting
-#: query_hql.xml:724
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[from Calendar cal where maxelement(cal.holidays) > current_date]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:726
-#, no-c-format
-msgid "<![CDATA[from Order order where maxindex(order.items) > 100]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:728
-#, no-c-format
-msgid "<![CDATA[from Order order where minelement(order.items) > 10000]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:730
-#, fuzzy, no-c-format
-msgid ""
 "The SQL functions <literal>any, some, all, exists, in</literal> are "
 "supported when passed the element or index set of a collection "
 "(<literal>elements</literal> and <literal>indices</literal> functions) or "
 "the result of a subquery (see below):"
 msgstr ""
-"在传递一个集合的索引集或者是元素集(<literal>elements</literal>与"
-"<literal>indices</literal> 函数) 或者传递一个子查询的结果的时候,可以使用SQL"
-"函数<literal>any, some, all, exists, in</literal>"
+"在传递一个集合的索引集或者是元素集(<literal>elements</literal> 与 "
+"<literal>indices</literal> 函数)或者传递一个子查询的结果的时候,可以使用 "
+"SQL 函数 <literal>any, some,all, exists, in</literal>:"
 
-#. Tag: programlisting
-#: query_hql.xml:736
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select mother from Cat as mother, Cat as kit\n"
-"where kit in elements(foo.kittens)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:738
-#, no-c-format
-msgid ""
-"<![CDATA[select p from NameList list, Person p\n"
-"where p.name = some elements(list.names)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:740
-#, no-c-format
-msgid "<![CDATA[from Cat cat where exists elements(cat.kittens)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:742
-#, no-c-format
-msgid "<![CDATA[from Player p where 3 > all elements(p.scores)]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:744
-#, no-c-format
-msgid "<![CDATA[from Show show where 'fizard' in indices(show.acts)]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:746
-#, fuzzy, no-c-format
-msgid ""
 "Note that these constructs - <literal>size</literal>, <literal>elements</"
 "literal>, <literal>indices</literal>, <literal>minindex</literal>, "
 "<literal>maxindex</literal>, <literal>minelement</literal>, "
 "<literal>maxelement</literal> - can only be used in the where clause in "
 "Hibernate3."
 msgstr ""
-"注意,在Hibernate3种,这些结构变量- <literal>size</literal>, "
-"<literal>elements</literal>, <literal>indices</literal>, <literal>minindex</"
-"literal>, <literal>maxindex</literal>, <literal>minelement</literal>, "
-"<literal>maxelement</literal> - 只能在where子句中使用。"
+"注意,在 Hibernate3 中,这些结构变量 —  <literal>size</literal>,"
+"<literal>elements</literal>,<literal>indices</literal>,<literal>minindex</"
+"literal>,<literal>maxindex</literal>,<literal>minelement</literal>,"
+"<literal>maxelement</literal> — 只能在 where 子句中使用。 "
 
 #. Tag: para
-#: query_hql.xml:753
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Elements of indexed collections (arrays, lists, and maps) can be referred to "
 "by index in a where clause only:"
 msgstr ""
-"一个被索引过的(有序的)集合的元素(arrays, lists, maps)可以在其他索引中被引用"
-"(只能在where子句中):"
+"一个被索引过的(有序的)集合的元素(arrays,lists,maps)可以在其他索引中被引"
+"用(只能在 where 子句中): "
 
-#. Tag: programlisting
-#: query_hql.xml:758
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[from Order order where order.items[0].id = 1234]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:760
-#, no-c-format
 msgid ""
-"<![CDATA[select person from Person person, Calendar calendar\n"
-"where calendar.holidays['national day'] = person.birthDay\n"
-"    and person.nationality.calendar = calendar]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:762
-#, no-c-format
-msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ order.deliveredItemIndices[0] ] = item and order.id = 11]]"
-">"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:764
-#, no-c-format
-msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ maxindex(order.items) ] = item and order.id = 11]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:766
-#, fuzzy, no-c-format
-msgid ""
 "The expression inside <literal>[]</literal> can even be an arithmetic "
 "expression:"
-msgstr "在<literal>[]</literal>中的表达式甚至可以是一个算数表达式。"
+msgstr "在 <literal>[]</literal> 中的表达式甚至可以是一个算数表达式:"
 
-#. Tag: programlisting
-#: query_hql.xml:770
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select item from Item item, Order order\n"
-"where order.items[ size(order.items) - 1 ] = item]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:772
-#, fuzzy, no-c-format
-msgid ""
 "HQL also provides the built-in <literal>index()</literal> function for "
 "elements of a one-to-many association or collection of values."
 msgstr ""
-"对于一个一对多的关联(one-to-many association)或是值的集合中的元素, HQL也提"
-"供内建的<literal>index()</literal>函数,"
+"对于一个一对多的关联(one-to-many association)或是值的集合中的元素,HQL 也提"
+"供内建的 <literal>index()</literal> 函数。"
 
-#. Tag: programlisting
-#: query_hql.xml:777
-#, no-c-format
-msgid ""
-"<![CDATA[select item, index(item) from Order order\n"
-"    join order.items item\n"
-"where index(item) < 5]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:779
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Scalar SQL functions supported by the underlying database can be used:"
-msgstr "如果底层数据库支持标量的SQL函数,它们也可以被使用"
+msgstr "如果底层数据库支持标量的 SQL 函数,它们也可以被使用:"
 
-#. Tag: programlisting
-#: query_hql.xml:783
-#, no-c-format
-msgid "<![CDATA[from DomesticCat cat where upper(cat.name) like 'FRI%']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:785
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Consider how much longer and less readable the following query would be in "
 "SQL:"
 msgstr ""
-"如果你还不能对所有的这些深信不疑,想想下面的查询。如果使用SQL,语句长度会增长"
-"多少,可读性会下降多少:"
+"如果你还不能对所有的这些深信不疑,想想下面的查询。如果使用 SQL,语句长度会增"
+"长多少,可读性会下降多少: "
 
-#. Tag: programlisting
-#: query_hql.xml:790
-#, no-c-format
-msgid ""
-"<![CDATA[select cust\n"
-"from Product prod,\n"
-"    Store store\n"
-"    inner join store.customers cust\n"
-"where prod.name = 'widget'\n"
-"    and store.location.name in ( 'Melbourne', 'Sydney' )\n"
-"    and prod = all elements(cust.currentOrder.lineItems)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:792
 #, no-c-format
 msgid "<emphasis>Hint:</emphasis> something like"
-msgstr "<emphasis>提示:</emphasis> 会像如下的语句"
+msgstr "<emphasis>提示:</emphasis> 会像如下的语句"
 
-#. Tag: programlisting
-#: query_hql.xml:796
-#, no-c-format
-msgid ""
-"<![CDATA[SELECT cust.name, cust.address, cust.phone, cust.id, cust."
-"current_order\n"
-"FROM customers cust,\n"
-"    stores store,\n"
-"    locations loc,\n"
-"    store_customers sc,\n"
-"    product prod\n"
-"WHERE prod.name = 'widget'\n"
-"    AND store.loc_id = loc.id\n"
-"    AND loc.name IN ( 'Melbourne', 'Sydney' )\n"
-"    AND sc.store_id = store.id\n"
-"    AND sc.cust_id = cust.id\n"
-"    AND prod.id = ALL(\n"
-"        SELECT item.prod_id\n"
-"        FROM line_items item, orders o\n"
-"        WHERE item.order_id = o.id\n"
-"            AND cust.current_order = o.id\n"
-"    )]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:801
 #, no-c-format
 msgid "The order by clause"
-msgstr "order by子句"
+msgstr "order by 子句"
 
 #. Tag: para
-#: query_hql.xml:803
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The list returned by a query can be ordered by any property of a returned "
 "class or components:"
 msgstr ""
-"查询返回的列表(list)可以按照一个返回的类或组件(components)中的任何属性"
-"(property)进行排序:"
+"查询返回的列表(list)可以按照一个返回的类或组件(components)中的任何属性"
+"(property)进行排序: "
 
-#. Tag: programlisting
-#: query_hql.xml:807
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat cat\n"
-"order by cat.name asc, cat.weight desc, cat.birthdate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:809
 #, no-c-format
 msgid ""
 "The optional <literal>asc</literal> or <literal>desc</literal> indicate "
 "ascending or descending order respectively."
 msgstr ""
-"可选的<literal>asc</literal>或<literal>desc</literal>关键字指明了按照升序或降"
-"序进行排序."
+"可选的 <literal>asc</literal> 或 <literal>desc</literal> 关键字指明了按照升序"
+"或降序进行排序。"
 
 #. Tag: title
-#: query_hql.xml:816
 #, no-c-format
 msgid "The group by clause"
-msgstr "group by子句"
+msgstr "group by 子句"
 
 #. Tag: para
-#: query_hql.xml:818
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A query that returns aggregate values can be grouped by any property of a "
 "returned class or components:"
 msgstr ""
-"一个返回聚集值(aggregate values)的查询可以按照一个返回的类或组件(components)"
-"中的任何属性(property)进行分组:"
+"一个返回聚集值(aggregate values)的查询可以按照一个返回的类或组件"
+"(components)中的任何属性(property)进行分组: "
 
-#. Tag: programlisting
-#: query_hql.xml:822
-#, no-c-format
-msgid ""
-"<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
-"from Cat cat\n"
-"group by cat.color]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:824
-#, no-c-format
-msgid ""
-"<![CDATA[select foo.id, avg(name), max(name)\n"
-"from Foo foo join foo.names name\n"
-"group by foo.id]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:826
 #, no-c-format
 msgid "A <literal>having</literal> clause is also allowed."
-msgstr "<literal>having</literal>子句在这里也允许使用."
+msgstr "<literal>having</literal> 子句在这里也允许使用。"
 
-#. Tag: programlisting
-#: query_hql.xml:830
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
-"from Cat cat\n"
-"group by cat.color\n"
-"having cat.color in (eg.Color.TABBY, eg.Color.BLACK)]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:832
-#, fuzzy, no-c-format
-msgid ""
 "SQL functions and aggregate functions are allowed in the <literal>having</"
 "literal> and <literal>order by</literal> clauses if they are supported by "
 "the underlying database (i.e., not in MySQL)."
 msgstr ""
-"如果底层的数据库支持的话(例如不能在MySQL中使用),SQL的一般函数与聚集函数也可"
-"以出现 在<literal>having</literal>与<literal>order by</literal> 子句中。"
+"如果底层的数据库支持的话(例如不能在 MySQL 中使用),SQL 的一般函数与聚集函数"
+"也可以出现在 <literal>having</literal> 与 <literal>order by</literal> 子句"
+"中。 "
 
-#. Tag: programlisting
-#: query_hql.xml:838
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select cat\n"
-"from Cat cat\n"
-"    join cat.kittens kitten\n"
-"group by cat.id, cat.name, cat.other, cat.properties\n"
-"having avg(kitten.weight) > 100\n"
-"order by count(kitten) asc, sum(kitten.weight) desc]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:840
-#, fuzzy, no-c-format
-msgid ""
 "Neither the <literal>group by</literal> clause nor the <literal>order by</"
 "literal> clause can contain arithmetic expressions. Hibernate also does not "
 "currently expand a grouped entity, so you cannot write <literal>group by "
 "cat</literal> if all properties of <literal>cat</literal> are non-"
 "aggregated. You have to list all non-aggregated properties explicitly."
 msgstr ""
-"注意<literal>group by</literal>子句与 <literal>order by</literal>子句中都不能"
-"包含算术表达式(arithmetic expressions). 也要注意Hibernate目前不会扩展group"
-"的实体,因此你不能写<literal>group by cat</literal>,除非<literal>cat</literal>"
-"的所有属性都不是聚集的(non-aggregated)。你必须明确的列出所有的非聚集属性。"
+"注意 <literal>group by</literal> 子句与 <literal>order by</literal> 子句中都"
+"不能包含算术表达式(arithmetic expressions)。也要注意 Hibernate 目前不会扩"
+"展 group 的实体,因此你不能写 <literal>group by cat</literal>,除非 "
+"<literal>cat</literal> 的所有属性都不是聚集的(non-aggregated)。你必须明确的"
+"列出所有的非聚集属性。 "
 
 #. Tag: title
-#: query_hql.xml:852
 #, no-c-format
 msgid "Subqueries"
 msgstr "子查询"
 
 #. Tag: para
-#: query_hql.xml:854
 #, no-c-format
 msgid ""
 "For databases that support subselects, Hibernate supports subqueries within "
@@ -1744,83 +1057,32 @@
 "aggregate function call). Even correlated subqueries (subqueries that refer "
 "to an alias in the outer query) are allowed."
 msgstr ""
-"对于支持子查询的数据库,Hibernate支持在查询中使用子查询。一个子查询必须被圆括"
-"号包围起来(经常是SQL聚集函数的圆括号)。 甚至相互关联的子查询(引用到外部查"
-"询中的别名的子查询)也是允许的。"
+"对于支持子查询的数据库,Hibernate 支持在查询中使用子查询。一个子查询必须被圆"
+"括号包围起来(经常是 SQL 聚集函数的圆括号)。甚至相互关联的子查询(引用到外部"
+"查询中的别名的子查询)也是允许的。"
 
-#. Tag: programlisting
-#: query_hql.xml:860
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as fatcat\n"
-"where fatcat.weight > (\n"
-"    select avg(cat.weight) from DomesticCat cat\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:862
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat as cat\n"
-"where cat.name = some (\n"
-"    select name.nickName from Name as name\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:864
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"where not exists (\n"
-"    from Cat as mate where mate.mate = cat\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:866
-#, no-c-format
-msgid ""
-"<![CDATA[from DomesticCat as cat\n"
-"where cat.name not in (\n"
-"    select name.nickName from Name as name\n"
-")]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:868
-#, no-c-format
-msgid ""
-"<![CDATA[select cat.id, (select max(kit.weight) from cat.kitten kit)\n"
-"from Cat as cat]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:870
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Note that HQL subqueries can occur only in the select or where clauses."
-msgstr "注意,HQL自查询只可以在select或者where子句中出现。"
+msgstr "注意,HQL 自查询只可以在 select 或者 where 子句中出现。 "
 
 #. Tag: para
-#: query_hql.xml:874
 #, fuzzy, no-c-format
 msgid ""
 "Note that subqueries can also utilize <literal>row value constructor</"
-"literal> syntax. See <xref linkend=\"queryhql-tuple\"/> for more information."
+"literal> syntax. See <xref linkend=\"queryhql-tuple\" /> for more "
+"information."
 msgstr ""
-"Note that subqueries can also utilize <literal>row value constructor</"
-"literal> syntax. See <xref linkend=\"queryhql-tuple\"/> for more details."
+"注意子查询也可以利用 <literal>row value constructor</literal> 语法。请参考 "
+"<xref linkend=\"queryhql-tuple\" /> 来获得详情。 "
 
 #. Tag: title
-#: query_hql.xml:882
 #, no-c-format
 msgid "HQL examples"
-msgstr "HQL示例"
+msgstr "HQL 示例 "
 
 #. Tag: para
-#: query_hql.xml:884
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate queries can be quite powerful and complex. In fact, the power of "
 "the query language is one of Hibernate's main strengths. The following "
@@ -1828,13 +1090,12 @@
 "projects. Please note that most queries you will write will be much simpler "
 "than the following examples."
 msgstr ""
-"Hibernate查询可以非常的强大与复杂。实际上,Hibernate的一个主要卖点就是查询语"
-"句的威力。这里有一些例子,它们与我在最近的 一个项目中使用的查询非常相似。注意"
-"你能用到的大多数查询比这些要简单的多!"
+"Hibernate 查询可以非常的强大与复杂。实际上,Hibernate 的一个主要卖点就是查询"
+"语句的威力。这里有一些例子,它们与我在最近的一个项目中使用的查询非常相似。注"
+"意你能用到的大多数查询比这些要简单的多。"
 
 #. Tag: para
-#: query_hql.xml:890
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following query returns the order id, number of items, the given minimum "
 "total value and the total value of the order for all unpaid orders for a "
@@ -1845,37 +1106,12 @@
 "literal> tables has four inner joins and an (uncorrelated) subselect."
 msgstr ""
 "下面的查询对于某个特定的客户的所有未支付的账单,在给定给最小总价值的情况下,"
-"返回订单的id,条目的数量和总价值, 返回值按照总价值的结果进行排序。为了决定价"
-"格,查询使用了当前目录。作为转换结果的SQL查询,使用了<literal>ORDER</"
-"literal>, <literal>ORDER_LINE</literal>, <literal>PRODUCT</literal>, "
-"<literal>CATALOG</literal> 和<literal>PRICE</literal> 库表。"
+"返回订单的 id,条目的数量和总价值,返回值按照总价值的结果进行排序。为了决定价"
+"格,查询使用了当前目录。作为转换结果的 SQL 查询,使用了<literal>ORDER</"
+"literal>,<literal>ORDER_LINE</literal>,<literal>PRODUCT</literal>,"
+"<literal>CATALOG</literal> 和 <literal>PRICE</literal> 库表。"
 
-#. Tag: programlisting
-#: query_hql.xml:899
-#, no-c-format
-msgid ""
-"<![CDATA[select order.id, sum(price.amount), count(item)\n"
-"from Order as order\n"
-"    join order.lineItems as item\n"
-"    join item.product as product,\n"
-"    Catalog as catalog\n"
-"    join catalog.prices as price\n"
-"where order.paid = false\n"
-"    and order.customer = :customer\n"
-"    and price.product = product\n"
-"    and catalog.effectiveDate < sysdate\n"
-"    and catalog.effectiveDate >= all (\n"
-"        select cat.effectiveDate\n"
-"        from Catalog as cat\n"
-"        where cat.effectiveDate < sysdate\n"
-"    )\n"
-"group by order\n"
-"having sum(price.amount) > :minAmount\n"
-"order by sum(price.amount) desc]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:901
 #, no-c-format
 msgid ""
 "What a monster! Actually, in real life, I'm not very keen on subqueries, so "
@@ -1884,27 +1120,7 @@
 "这简直是一个怪物!实际上,在现实生活中,我并不热衷于子查询,所以我的查询语句"
 "看起来更像这个:"
 
-#. Tag: programlisting
-#: query_hql.xml:906
-#, no-c-format
-msgid ""
-"<![CDATA[select order.id, sum(price.amount), count(item)\n"
-"from Order as order\n"
-"    join order.lineItems as item\n"
-"    join item.product as product,\n"
-"    Catalog as catalog\n"
-"    join catalog.prices as price\n"
-"where order.paid = false\n"
-"    and order.customer = :customer\n"
-"    and price.product = product\n"
-"    and catalog = :currentCatalog\n"
-"group by order\n"
-"having sum(price.amount) > :minAmount\n"
-"order by sum(price.amount) desc]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:908
 #, no-c-format
 msgid ""
 "The next query counts the number of payments in each status, excluding all "
@@ -1914,59 +1130,22 @@
 "<literal>PAYMENT</literal>, <literal>PAYMENT_STATUS</literal> and "
 "<literal>PAYMENT_STATUS_CHANGE</literal> tables."
 msgstr ""
-"下面一个查询计算每一种状态下的支付的数目,除去所有处于"
-"<literal>AWAITING_APPROVAL</literal>状态的支付,因为在该状态下 当前的用户作出"
-"了状态的最新改变。该查询被转换成含有两个内连接以及一个相关联的子选择的SQL查"
-"询,该查询使用了表 <literal>PAYMENT</literal>, <literal>PAYMENT_STATUS</"
-"literal> 以及 <literal>PAYMENT_STATUS_CHANGE</literal>。"
+"下面一个查询计算每一种状态下的支付的数目,除去所有处于 "
+"<literal>AWAITING_APPROVAL</literal> 状态的支付,因为在该状态下 当前的用户作"
+"出了状态的最新改变。该查询被转换成含有两个内连接以及一个相关联的子选择的 SQL "
+"查询,该查询使用了表 <literal>PAYMENT</literal>,<literal>PAYMENT_STATUS</"
+"literal> 以及  <literal>PAYMENT_STATUS_CHANGE</literal>。"
 
-#. Tag: programlisting
-#: query_hql.xml:916
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select count(payment), status.name\n"
-"from Payment as payment\n"
-"    join payment.currentStatus as status\n"
-"    join payment.statusChanges as statusChange\n"
-"where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-"    or (\n"
-"        statusChange.timeStamp = (\n"
-"            select max(change.timeStamp)\n"
-"            from PaymentStatusChange change\n"
-"            where change.payment = payment\n"
-"        )\n"
-"        and statusChange.user <> :currentUser\n"
-"    )\n"
-"group by status.name, status.sortOrder\n"
-"order by status.sortOrder]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:918
-#, fuzzy, no-c-format
-msgid ""
 "If the <literal>statusChanges</literal> collection was mapped as a list, "
 "instead of a set, the query would have been much simpler to write."
 msgstr ""
-"如果我把<literal>statusChanges</literal>实例集映射为一个列表(list)而不是一"
-"个集合(set), 书写查询语句将更加简单."
+"如果我把 <literal>statusChanges</literal> 实例集映射为一个列表(list)而不是"
+"一个集合(set),书写查询语句将更加简单。 "
 
-#. Tag: programlisting
-#: query_hql.xml:923
-#, no-c-format
-msgid ""
-"<![CDATA[select count(payment), status.name\n"
-"from Payment as payment\n"
-"    join payment.currentStatus as status\n"
-"where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
-"    or payment.statusChanges[ maxIndex(payment.statusChanges) ].user <> :"
-"currentUser\n"
-"group by status.name, status.sortOrder\n"
-"order by status.sortOrder]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:925
 #, no-c-format
 msgid ""
 "The next query uses the MS SQL Server <literal>isNull()</literal> function "
@@ -1977,305 +1156,142 @@
 "<literal>ACCOUNT_TYPE</literal>, <literal>ORGANIZATION</literal> and "
 "<literal>ORG_USER</literal> tables."
 msgstr ""
-"下面一个查询使用了MS SQL Server的 <literal>isNull()</literal>函数用以返回当前"
-"用户所属组织的组织帐号及组织未支付的账。 它被转换成一个对表<literal>ACCOUNT</"
-"literal>, <literal>PAYMENT</literal>, <literal>PAYMENT_STATUS</literal>, "
-"<literal>ACCOUNT_TYPE</literal>, <literal>ORGANIZATION</literal> 以及 "
-"<literal>ORG_USER</literal>进行的三个内连接, 一个外连接和一个子选择的SQL查"
-"询。"
+"下面一个查询使用了 MS SQL Server 的 <literal>isNull()</literal> 函数用以返回"
+"当前用户所属组织的组织帐号及组织未支付的账。它被转换成一个对表 "
+"<literal>ACCOUNT</literal>,<literal>PAYMENT</literal>,"
+"<literal>PAYMENT_STATUS</literal>,<literal>ACCOUNT_TYPE</literal>,"
+"<literal>ORGANIZATION</literal>  以及 <literal>ORG_USER</literal> 进行的三个"
+"内连接,一个外连接和一个子选择的 SQL 查询。"
 
-#. Tag: programlisting
-#: query_hql.xml:934
-#, no-c-format
-msgid ""
-"<![CDATA[select account, payment\n"
-"from Account as account\n"
-"    left outer join account.payments as payment\n"
-"where :currentUser in elements(account.holder.users)\n"
-"    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
-"PaymentStatus.UNPAID)\n"
-"order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:936
 #, no-c-format
 msgid ""
 "For some databases, we would need to do away with the (correlated) subselect."
 msgstr "对于一些数据库,我们需要弃用(相关的)子选择。"
 
-#. Tag: programlisting
-#: query_hql.xml:940
-#, no-c-format
-msgid ""
-"<![CDATA[select account, payment\n"
-"from Account as account\n"
-"    join account.holder.users as user\n"
-"    left outer join account.payments as payment\n"
-"where :currentUser = user\n"
-"    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
-"PaymentStatus.UNPAID)\n"
-"order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:945
 #, no-c-format
 msgid "Bulk update and delete"
-msgstr "批量的UPDATE和DELETE"
+msgstr "批量的 UPDATE 和 DELETE"
 
 #. Tag: para
-#: query_hql.xml:947
 #, fuzzy, no-c-format
 msgid ""
 "HQL now supports <literal>update</literal>, <literal>delete</literal> and "
 "<literal>insert ... select ...</literal> statements. See <xref linkend="
-"\"batch-direct\"/> for more information."
+"\"batch-direct\" /> for more information."
 msgstr ""
-"HQL现在支持 <literal>update</literal>, <literal>delete</literal> 和 "
-"<literal>insert ... select ...</literal>语句. 查阅 <xref linkend=\"batch-"
-"direct\"/> 以获得更多信息。"
+"HQL 现在支持 <literal>update</literal>,<literal>delete</literal> 和 "
+"<literal>insert ... select ...</literal>语句。查阅 <xref linkend=\"batch-"
+"direct\" /> 以获得更多信息。"
 
 #. Tag: title
-#: query_hql.xml:955
 #, no-c-format
 msgid "Tips &amp; Tricks"
 msgstr "小技巧 &amp; 小窍门"
 
 #. Tag: para
-#: query_hql.xml:957
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can count the number of query results without returning them:"
-msgstr "你可以统计查询结果的数目而不必实际的返回他们:"
+msgstr "你可以统计查询结果的数目而不必实际的返回他们: "
 
-#. Tag: programlisting
-#: query_hql.xml:961
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
-"iterate().next() ).intValue()]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:963
 #, no-c-format
 msgid "To order a result by the size of a collection, use the following query:"
 msgstr "若想根据一个集合的大小来进行排序,可以使用如下的语句:"
 
-#. Tag: programlisting
-#: query_hql.xml:967
-#, no-c-format
-msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User as usr\n"
-"    left join usr.messages as msg\n"
-"group by usr.id, usr.name\n"
-"order by count(msg)]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:969
 #, no-c-format
 msgid ""
 "If your database supports subselects, you can place a condition upon "
 "selection size in the where clause of your query:"
 msgstr ""
-"如果你的数据库支持子选择,你可以在你的查询的where子句中为选择的大小"
-"(selection size)指定一个条件:"
+"如果你的数据库支持子选择,你可以在你的查询的 where 子句中为选择的大小"
+"(selection size)指定一个条件:"
 
-#. Tag: programlisting
-#: query_hql.xml:974
-#, no-c-format
-msgid "<![CDATA[from User usr where size(usr.messages) >= 1]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:976
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "If your database does not support subselects, use the following query:"
-msgstr "如果你的数据库不支持子选择语句,使用下面的查询:"
+msgstr "如果你的数据库不支持子选择语句,使用下面的查询: "
 
-#. Tag: programlisting
-#: query_hql.xml:980
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User usr.name\n"
-"    join usr.messages msg\n"
-"group by usr.id, usr.name\n"
-"having count(msg) >= 1]]>"
-msgstr ""
-
-#. Tag: para
-#: query_hql.xml:983
-#, fuzzy, no-c-format
-msgid ""
 "As this solution cannot return a <literal>User</literal> with zero messages "
 "because of the inner join, the following form is also useful:"
 msgstr ""
-"因为内连接(inner join)的原因,这个解决方案不能返回含有零个信息的"
-"<literal>User</literal> 类的实例, 所以这种情况下使用下面的格式将是有帮助的:"
+"因为内连接(inner join)的原因,这个解决方案不能返回含有零个信息的 "
+"<literal>User</literal> 类的实例,所以这种情况下使用下面的格式将是有帮助的: "
 
-#. Tag: programlisting
-#: query_hql.xml:988
-#, no-c-format
-msgid ""
-"<![CDATA[select usr.id, usr.name\n"
-"from User as usr\n"
-"    left join usr.messages as msg\n"
-"group by usr.id, usr.name\n"
-"having count(msg) = 0]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:990
 #, no-c-format
 msgid "Properties of a JavaBean can be bound to named query parameters:"
-msgstr "JavaBean的属性可以被绑定到一个命名查询(named query)的参数上:"
+msgstr "JavaBean 的属性可以被绑定到一个命名查询(named query)的参数上:"
 
-#. Tag: programlisting
-#: query_hql.xml:994
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = s.createQuery(\"from foo Foo as foo where foo.name=:name "
-"and foo.size=:size\");\n"
-"q.setProperties(fooBean); // fooBean has getName() and getSize()\n"
-"List foos = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:996
 #, no-c-format
 msgid ""
 "Collections are pageable by using the <literal>Query</literal> interface "
 "with a filter:"
 msgstr ""
-"通过将接口<literal>Query</literal>与一个过滤器(filter)一起使用,集合"
+"通过将接口 <literal>Query</literal> 与一个过滤器(filter)一起使用,集合"
 "(Collections)是可以分页的:"
 
-#. Tag: programlisting
-#: query_hql.xml:1000
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = s.createFilter( collection, \"\" ); // the trivial "
-"filter\n"
-"q.setMaxResults(PAGE_SIZE);\n"
-"q.setFirstResult(PAGE_SIZE * pageNumber);\n"
-"List page = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1002
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Collection elements can be ordered or grouped using a query filter:"
 msgstr ""
-"通过使用查询过滤器(query filter)可以将集合(Collection)的原素分组或排序:"
+"通过使用查询过滤器(query filter)可以将集合(Collection)的元素分组或排序: "
 
-#. Tag: programlisting
-#: query_hql.xml:1006
-#, no-c-format
-msgid ""
-"<![CDATA[Collection orderedCollection = s.filter( collection, \"order by "
-"this.amount\" );\n"
-"Collection counts = s.filter( collection, \"select this.type, count(this) "
-"group by this.type\" );]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1008
 #, no-c-format
 msgid "You can find the size of a collection without initializing it:"
 msgstr "不用通过初始化,你就可以知道一个集合(Collection)的大小:"
 
-#. Tag: programlisting
-#: query_hql.xml:1012
-#, no-c-format
-msgid ""
-"<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
-"iterate().next() ).intValue();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_hql.xml:1017
 #, no-c-format
 msgid "Components"
-msgstr "translator-credits"
+msgstr "组件"
 
 #. Tag: para
-#: query_hql.xml:1019
 #, no-c-format
 msgid ""
 "Components can be used similarly to the simple value types that are used in "
 "HQL queries. They can appear in the <literal>select</literal> clause as "
 "follows:"
 msgstr ""
+"在 HQL 查询里,组件可以和简单值类型一样使用。它们可以出现在 <literal>select</"
+"literal> 子句里: "
 
-#. Tag: programlisting
-#: query_hql.xml:1024 query_hql.xml:1070
-#, no-c-format
-msgid "<![CDATA[select p.name from Person p]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1025
-#, no-c-format
-msgid "<![CDATA[select p.name.first from Person p]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1027
 #, no-c-format
 msgid ""
 "where the Person's name property is a component. Components can also be used "
 "in the <literal>where</literal> clause:"
 msgstr ""
+"在这里,Person 的 name 属性是一个组件。组件也可以用在 <literal>where</"
+"literal> 子句里:"
 
-#. Tag: programlisting
-#: query_hql.xml:1032
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name = :name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1033
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name.first = :firstName]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1035
 #, no-c-format
 msgid "Components can also be used in the <literal>order by</literal> clause:"
-msgstr ""
+msgstr "组件也可以用在 <literal>order by</literal> 子句里:"
 
-#. Tag: programlisting
-#: query_hql.xml:1039
-#, no-c-format
-msgid "<![CDATA[from Person p order by p.name]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_hql.xml:1040
-#, no-c-format
-msgid "<![CDATA[from Person p order by p.name.first]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1042
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Another common use of components is in <link linkend=\"queryhql-tuple\">row "
 "value constructors</link>."
 msgstr ""
+"组件的另外一个常见用法是在 <xref linkend=\"queryhql-tuple\" /> 行值(row "
+"value)构造函数里。"
 
 #. Tag: title
-#: query_hql.xml:1048
 #, no-c-format
 msgid "Row value constructor syntax"
-msgstr ""
+msgstr "Row value 构造函数语法"
 
 #. Tag: para
-#: query_hql.xml:1050
 #, no-c-format
 msgid ""
 "HQL supports the use of ANSI SQL <literal>row value constructor</literal> "
@@ -2284,71 +1300,982 @@
 "generally referring to multi-valued comparisons, typically associated with "
 "components. Consider an entity Person which defines a name component:"
 msgstr ""
+"HQL 支持 ANSI SQL <literal>row value constructor</literal> 语法(有时也叫作 "
+"<literal>tuple</literal> 语法),即使底层数据库可能不支持这个概念。在这里我们"
+"通常指的是多值(multi-valued)的比较,典型地是和组件相关联。来看看一个定义了 "
+"name 组件的实体 Person:"
 
-#. Tag: programlisting
-#: query_hql.xml:1057
-#, no-c-format
-msgid ""
-"<![CDATA[from Person p where p.name.first='John' and p.name."
-"last='Jingleheimer-Schmidt']]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1059
 #, no-c-format
 msgid ""
 "That is valid syntax although it is a little verbose. You can make this more "
 "concise by using <literal>row value constructor</literal> syntax:"
 msgstr ""
+"那是有效的语法,虽然有点冗长。我们可以使它更加简洁一点,并使用 <literal>row "
+"value constructor</literal> 语法: "
 
-#. Tag: programlisting
-#: query_hql.xml:1064
-#, no-c-format
-msgid "<![CDATA[from Person p where p.name=('John', 'Jingleheimer-Schmidt')]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1066
 #, no-c-format
 msgid ""
 "It can also be useful to specify this in the <literal>select</literal> "
 "clause:"
-msgstr ""
+msgstr "在 <literal>select</literal> 子句里指定这个也是很有用的:"
 
 #. Tag: para
-#: query_hql.xml:1072
 #, no-c-format
 msgid ""
 "Using <literal>row value constructor</literal> syntax can also be beneficial "
 "when using subqueries that need to compare against multiple values:"
 msgstr ""
+"当使用需要比较多个值的子查询时,采用 <literal>row value constructor</"
+"literal> 语法也很有用处: "
 
-#. Tag: programlisting
-#: query_hql.xml:1077
-#, no-c-format
-msgid ""
-"<![CDATA[from Cat as cat\n"
-"where not ( cat.name, cat.color ) in (\n"
-"    select cat.name, cat.color from DomesticCat cat\n"
-")]]>"
-msgstr ""
-
 #. Tag: para
-#: query_hql.xml:1079
 #, no-c-format
 msgid ""
 "One thing to consider when deciding if you want to use this syntax, is that "
 "the query will be dependent upon the ordering of the component sub-"
 "properties in the metadata."
 msgstr ""
+"决定是否使用这个语法的一件因素就是:这个查询将依赖于元数据里的组件子属性"
+"(sub-properties)的顺序。 "
 
+#, fuzzy
+#~ msgid "<![CDATA[from eg.Cat]]>"
+#~ msgstr "from eg.Cat"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat]]>"
+#~ msgstr "from eg.Cat"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat as cat]]>"
+#~ msgstr "from Cat as cat"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat]]>"
+#~ msgstr "from Cat cat"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Formula, Parameter]]>"
+#~ msgstr "from Formula, Parameter"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Formula as form, Parameter as param]]>"
+#~ msgstr "from Formula as form, Parameter as param"
+
+#, fuzzy
 #~ msgid ""
-#~ "Most of the time, you will need to assign an <emphasis>alias</emphasis>, "
-#~ "since you will want to refer to the <literal>Cat</literal> in other parts "
-#~ "of the query."
+#~ "<![CDATA[from Cat as cat\n"
+#~ "    inner join cat.mate as mate\n"
+#~ "    left outer join cat.kittens as kitten]]>"
 #~ msgstr ""
-#~ "大多数情况下, 你需要指定一个<emphasis>别名</emphasis>, 原因是你可能需要 在"
-#~ "查询语句的其它部分引用到<literal>Cat</literal>"
+#~ "from Cat as cat\n"
+#~ "    inner join cat.mate as mate\n"
+#~ "    left outer join cat.kittens as kitten"
 
-#~ msgid "or as an actual typesafe Java object,"
-#~ msgstr "也可能直接返回一个实际的类型安全的Java对象,"
+#, fuzzy
+#~ msgid "<![CDATA[from Cat as cat left join cat.mate.kittens as kittens]]>"
+#~ msgstr "from Cat as cat left join cat.mate.kittens as kittens"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Formula form full join form.parameter param]]>"
+#~ msgstr "from Formula form full join form.parameter param"
+
+#~ msgid "inner join"
+#~ msgstr "<literal>inner join</literal>(内连接)"
+
+#~ msgid "left outer join"
+#~ msgstr "<literal>left outer join</literal>(左外连接)"
+
+#, fuzzy
+#~ msgid "right outer join"
+#~ msgstr "<literal>left outer join</literal>(左外连接)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as cat\n"
+#~ "    join cat.mate as mate\n"
+#~ "    left join cat.kittens as kitten]]>"
+#~ msgstr ""
+#~ "from Cat as cat\n"
+#~ "    join cat.mate as mate\n"
+#~ "    left join cat.kittens as kitten"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as cat\n"
+#~ "    left join cat.kittens as kitten\n"
+#~ "        with kitten.bodyWeight > 10.0]]>"
+#~ msgstr ""
+#~ "from Cat as cat\n"
+#~ "    left join cat.kittens as kitten\n"
+#~ "        with kitten.bodyWeight &gt; 10.0"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as cat\n"
+#~ "    inner join fetch cat.mate\n"
+#~ "    left join fetch cat.kittens]]>"
+#~ msgstr ""
+#~ "from Cat as cat\n"
+#~ "    inner join fetch cat.mate\n"
+#~ "    left join fetch cat.kittens"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as cat\n"
+#~ "    inner join fetch cat.mate\n"
+#~ "    left join fetch cat.kittens child\n"
+#~ "    left join fetch child.kittens]]>"
+#~ msgstr ""
+#~ "from Cat as cat\n"
+#~ "    inner join fetch cat.mate\n"
+#~ "    left join fetch cat.kittens child\n"
+#~ "    left join fetch child.kittens"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Document fetch all properties order by name]]>"
+#~ msgstr "from Document fetch all properties order by name"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Document doc fetch all properties where lower(doc.name) "
+#~ "like '%cats%']]>"
+#~ msgstr ""
+#~ "from Document doc fetch all properties where lower(doc.name) like '&#37;"
+#~ "cats&#37;'"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat as cat where cat.mate.name like '%s%']]>"
+#~ msgstr "from Cat as cat where cat.mate.name like '&#37;s&#37;'"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select mate\n"
+#~ "from Cat as cat\n"
+#~ "    inner join cat.mate as mate]]>"
+#~ msgstr ""
+#~ "select mate\n"
+#~ "from Cat as cat\n"
+#~ "    inner join cat.mate as mate"
+
+#, fuzzy
+#~ msgid "<![CDATA[select cat.mate from Cat cat]]>"
+#~ msgstr "select cat.mate from Cat cat"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cat.name from DomesticCat cat\n"
+#~ "where cat.name like 'fri%']]>"
+#~ msgstr ""
+#~ "select cat.name from DomesticCat cat\n"
+#~ "where cat.name like 'fri&#37;'"
+
+#, fuzzy
+#~ msgid "<![CDATA[select cust.name.firstName from Customer as cust]]>"
+#~ msgstr "select cust.name.firstName from Customer as cust"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select mother, offspr, mate.name\n"
+#~ "from DomesticCat as mother\n"
+#~ "    inner join mother.mate as mate\n"
+#~ "    left outer join mother.kittens as offspr]]>"
+#~ msgstr ""
+#~ "select mother, offspr, mate.name\n"
+#~ "from DomesticCat as mother\n"
+#~ "    inner join mother.mate as mate\n"
+#~ "    left outer join mother.kittens as offspr"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select new list(mother, offspr, mate.name)\n"
+#~ "from DomesticCat as mother\n"
+#~ "    inner join mother.mate as mate\n"
+#~ "    left outer join mother.kittens as offspr]]>"
+#~ msgstr ""
+#~ "select new list(mother, offspr, mate.name)\n"
+#~ "from DomesticCat as mother\n"
+#~ "    inner join mother.mate as mate\n"
+#~ "    left outer join mother.kittens as offspr"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select new Family(mother, mate, offspr)\n"
+#~ "from DomesticCat as mother\n"
+#~ "    join mother.mate as mate\n"
+#~ "    left join mother.kittens as offspr]]>"
+#~ msgstr ""
+#~ "select new Family(mother, mate, offspr)\n"
+#~ "from DomesticCat as mother\n"
+#~ "    join mother.mate as mate\n"
+#~ "    left join mother.kittens as offspr"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select max(bodyWeight) as max, min(bodyWeight) as min, count(*) "
+#~ "as n\n"
+#~ "from Cat cat]]>"
+#~ msgstr ""
+#~ "select max(bodyWeight) as max, min(bodyWeight) as min, count(*) as n\n"
+#~ "from Cat cat"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select new map( max(bodyWeight) as max, min(bodyWeight) as min, "
+#~ "count(*) as n )\n"
+#~ "from Cat cat]]>"
+#~ msgstr ""
+#~ "select new map( max(bodyWeight) as max, min(bodyWeight) as min, count(*) "
+#~ "as n )\n"
+#~ "from Cat cat"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select avg(cat.weight), sum(cat.weight), max(cat.weight), count"
+#~ "(cat)\n"
+#~ "from Cat cat]]>"
+#~ msgstr ""
+#~ "select avg(cat.weight), sum(cat.weight), max(cat.weight), count(cat)\n"
+#~ "from Cat cat"
+
+#~ msgid "count(*)"
+#~ msgstr "count(*)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cat.weight + sum(kitten.weight)\n"
+#~ "from Cat cat\n"
+#~ "    join cat.kittens kitten\n"
+#~ "group by cat.id, cat.weight]]>"
+#~ msgstr ""
+#~ "select cat.weight + sum(kitten.weight)\n"
+#~ "from Cat cat\n"
+#~ "    join cat.kittens kitten\n"
+#~ "group by cat.id, cat.weight"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select firstName||' '||initial||' '||upper(lastName) from "
+#~ "Person]]>"
+#~ msgstr "select firstName||' '||initial||' '||upper(lastName) from Person"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select distinct cat.name from Cat cat\n"
+#~ "\n"
+#~ "select count(distinct cat.name), count(cat) from Cat cat]]>"
+#~ msgstr ""
+#~ "select distinct cat.name from Cat cat\n"
+#~ "\n"
+#~ "select count(distinct cat.name), count(cat) from Cat cat"
+
+#, fuzzy
+#~ msgid "<![CDATA[from java.lang.Object o]]>"
+#~ msgstr "from java.lang.Object o"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Named n, Named m where n.name = m.name]]>"
+#~ msgstr "from Named n, Named m where n.name = m.name"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat where name='Fritz']]>"
+#~ msgstr "from Cat where name='Fritz'"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat as cat where cat.name='Fritz']]>"
+#~ msgstr "from Cat as cat where cat.name='Fritz'"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select foo\n"
+#~ "from Foo foo, Bar bar\n"
+#~ "where foo.startDate = bar.date]]>"
+#~ msgstr ""
+#~ "select foo\n"
+#~ "from Foo foo, Bar bar\n"
+#~ "where foo.startDate = bar.date"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat where cat.mate.name is not null]]>"
+#~ msgstr "from Cat cat where cat.mate.name is not null"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Foo foo\n"
+#~ "where foo.bar.baz.customer.address.city is not null]]>"
+#~ msgstr ""
+#~ "from Foo foo\n"
+#~ "where foo.bar.baz.customer.address.city is not null"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat, Cat rival where cat.mate = rival.mate]]>"
+#~ msgstr "from Cat cat, Cat rival where cat.mate = rival.mate"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cat, mate\n"
+#~ "from Cat cat, Cat mate\n"
+#~ "where cat.mate = mate]]>"
+#~ msgstr ""
+#~ "select cat, mate\n"
+#~ "from Cat cat, Cat mate\n"
+#~ "where cat.mate = mate"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as cat where cat.id = 123\n"
+#~ "\n"
+#~ "from Cat as cat where cat.mate.id = 69]]>"
+#~ msgstr ""
+#~ "from Cat as cat where cat.id = 123\n"
+#~ "\n"
+#~ "from Cat as cat where cat.mate.id = 69"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from bank.Person person\n"
+#~ "where person.id.country = 'AU'\n"
+#~ "    and person.id.medicareNumber = 123456]]>"
+#~ msgstr ""
+#~ "from bank.Person person\n"
+#~ "where person.id.country = 'AU'\n"
+#~ "    and person.id.medicareNumber = 123456"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from bank.Account account\n"
+#~ "where account.owner.id.country = 'AU'\n"
+#~ "    and account.owner.id.medicareNumber = 123456]]>"
+#~ msgstr ""
+#~ "from bank.Account account\n"
+#~ "where account.owner.id.country = 'AU'\n"
+#~ "    and account.owner.id.medicareNumber = 123456"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat where cat.class = DomesticCat]]>"
+#~ msgstr "from Cat cat where cat.class = DomesticCat"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from AuditLog log, Payment payment\n"
+#~ "where log.item.class = 'Payment' and log.item.id = payment.id]]>"
+#~ msgstr ""
+#~ "from AuditLog log, Payment payment\n"
+#~ "where log.item.class = 'Payment' and log.item.id = payment.id"
+
+#, fuzzy
+#~ msgid "<![CDATA[from DomesticCat cat where cat.name between 'A' and 'B']]>"
+#~ msgstr "from DomesticCat cat where cat.name between 'A' and 'B'"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from DomesticCat cat where cat.name in ( 'Foo', 'Bar', 'Baz' )]]>"
+#~ msgstr "from DomesticCat cat where cat.name in ( 'Foo', 'Bar', 'Baz' )"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from DomesticCat cat where cat.name not between 'A' and 'B']]>"
+#~ msgstr "from DomesticCat cat where cat.name not between 'A' and 'B'"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from DomesticCat cat where cat.name not in ( 'Foo', 'Bar', "
+#~ "'Baz' )]]>"
+#~ msgstr "from DomesticCat cat where cat.name not in ( 'Foo', 'Bar', 'Baz' )"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"hibernate.query.substitutions\">true 1, false "
+#~ "0</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"hibernate.query.substitutions\"&gt;true 1, false "
+#~ "0&lt;/property&gt;"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat where cat.alive = true]]>"
+#~ msgstr "from Cat cat where cat.alive = true"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat where cat.kittens.size > 0]]>"
+#~ msgstr "from Cat cat where cat.kittens.size &gt; 0"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat where size(cat.kittens) > 0]]>"
+#~ msgstr "from Cat cat where size(cat.kittens) &gt; 0"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Calendar cal where maxelement(cal.holidays) > current_date]]"
+#~ ">"
+#~ msgstr "from Calendar cal where maxelement(cal.holidays) &gt; current_date"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Order order where maxindex(order.items) > 100]]>"
+#~ msgstr "from Order order where maxindex(order.items) &gt; 100"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Order order where minelement(order.items) > 10000]]>"
+#~ msgstr "from Order order where minelement(order.items) &gt; 10000"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select mother from Cat as mother, Cat as kit\n"
+#~ "where kit in elements(foo.kittens)]]>"
+#~ msgstr ""
+#~ "select mother from Cat as mother, Cat as kit\n"
+#~ "where kit in elements(foo.kittens)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select p from NameList list, Person p\n"
+#~ "where p.name = some elements(list.names)]]>"
+#~ msgstr ""
+#~ "select p from NameList list, Person p\n"
+#~ "where p.name = some elements(list.names)"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Cat cat where exists elements(cat.kittens)]]>"
+#~ msgstr "from Cat cat where exists elements(cat.kittens)"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Player p where 3 > all elements(p.scores)]]>"
+#~ msgstr "from Player p where 3 &gt; all elements(p.scores)"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Show show where 'fizard' in indices(show.acts)]]>"
+#~ msgstr "from Show show where 'fizard' in indices(show.acts)"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Order order where order.items[0].id = 1234]]>"
+#~ msgstr "from Order order where order.items[0].id = 1234"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select person from Person person, Calendar calendar\n"
+#~ "where calendar.holidays['national day'] = person.birthDay\n"
+#~ "    and person.nationality.calendar = calendar]]>"
+#~ msgstr ""
+#~ "select person from Person person, Calendar calendar\n"
+#~ "where calendar.holidays['national day'] = person.birthDay\n"
+#~ "    and person.nationality.calendar = calendar"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select item from Item item, Order order\n"
+#~ "where order.items[ order.deliveredItemIndices[0] ] = item and order.id = "
+#~ "11]]>"
+#~ msgstr ""
+#~ "select item from Item item, Order order\n"
+#~ "where order.items[ order.deliveredItemIndices[0] ] = item and order.id = "
+#~ "11"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select item from Item item, Order order\n"
+#~ "where order.items[ maxindex(order.items) ] = item and order.id = 11]]>"
+#~ msgstr ""
+#~ "select item from Item item, Order order\n"
+#~ "where order.items[ maxindex(order.items) ] = item and order.id = 11"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select item from Item item, Order order\n"
+#~ "where order.items[ size(order.items) - 1 ] = item]]>"
+#~ msgstr ""
+#~ "select item from Item item, Order order\n"
+#~ "where order.items[ size(order.items) - 1 ] = item"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select item, index(item) from Order order\n"
+#~ "    join order.items item\n"
+#~ "where index(item) < 5]]>"
+#~ msgstr ""
+#~ "select item, index(item) from Order order\n"
+#~ "    join order.items item\n"
+#~ "where index(item) &lt; 5"
+
+#, fuzzy
+#~ msgid "<![CDATA[from DomesticCat cat where upper(cat.name) like 'FRI%']]>"
+#~ msgstr "from DomesticCat cat where upper(cat.name) like 'FRI&#37;'"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cust\n"
+#~ "from Product prod,\n"
+#~ "    Store store\n"
+#~ "    inner join store.customers cust\n"
+#~ "where prod.name = 'widget'\n"
+#~ "    and store.location.name in ( 'Melbourne', 'Sydney' )\n"
+#~ "    and prod = all elements(cust.currentOrder.lineItems)]]>"
+#~ msgstr ""
+#~ "select cust\n"
+#~ "from Product prod,\n"
+#~ "    Store store\n"
+#~ "    inner join store.customers cust\n"
+#~ "where prod.name = 'widget'\n"
+#~ "    and store.location.name in ( 'Melbourne', 'Sydney' )\n"
+#~ "    and prod = all elements(cust.currentOrder.lineItems)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[SELECT cust.name, cust.address, cust.phone, cust.id, cust."
+#~ "current_order\n"
+#~ "FROM customers cust,\n"
+#~ "    stores store,\n"
+#~ "    locations loc,\n"
+#~ "    store_customers sc,\n"
+#~ "    product prod\n"
+#~ "WHERE prod.name = 'widget'\n"
+#~ "    AND store.loc_id = loc.id\n"
+#~ "    AND loc.name IN ( 'Melbourne', 'Sydney' )\n"
+#~ "    AND sc.store_id = store.id\n"
+#~ "    AND sc.cust_id = cust.id\n"
+#~ "    AND prod.id = ALL(\n"
+#~ "        SELECT item.prod_id\n"
+#~ "        FROM line_items item, orders o\n"
+#~ "        WHERE item.order_id = o.id\n"
+#~ "            AND cust.current_order = o.id\n"
+#~ "    )]]>"
+#~ msgstr ""
+#~ "SELECT cust.name, cust.address, cust.phone, cust.id, cust.current_order\n"
+#~ "FROM customers cust,\n"
+#~ "    stores store,\n"
+#~ "    locations loc,\n"
+#~ "    store_customers sc,\n"
+#~ "    product prod\n"
+#~ "WHERE prod.name = 'widget'\n"
+#~ "    AND store.loc_id = loc.id\n"
+#~ "    AND loc.name IN ( 'Melbourne', 'Sydney' )\n"
+#~ "    AND sc.store_id = store.id\n"
+#~ "    AND sc.cust_id = cust.id\n"
+#~ "    AND prod.id = ALL(\n"
+#~ "        SELECT item.prod_id\n"
+#~ "        FROM line_items item, orders o\n"
+#~ "        WHERE item.order_id = o.id\n"
+#~ "            AND cust.current_order = o.id\n"
+#~ "    )"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from DomesticCat cat\n"
+#~ "order by cat.name asc, cat.weight desc, cat.birthdate]]>"
+#~ msgstr ""
+#~ "from DomesticCat cat\n"
+#~ "order by cat.name asc, cat.weight desc, cat.birthdate"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
+#~ "from Cat cat\n"
+#~ "group by cat.color]]>"
+#~ msgstr ""
+#~ "select cat.color, sum(cat.weight), count(cat)\n"
+#~ "from Cat cat\n"
+#~ "group by cat.color"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select foo.id, avg(name), max(name)\n"
+#~ "from Foo foo join foo.names name\n"
+#~ "group by foo.id]]>"
+#~ msgstr ""
+#~ "select foo.id, avg(name), max(name)\n"
+#~ "from Foo foo join foo.names name\n"
+#~ "group by foo.id"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cat.color, sum(cat.weight), count(cat)\n"
+#~ "from Cat cat\n"
+#~ "group by cat.color\n"
+#~ "having cat.color in (eg.Color.TABBY, eg.Color.BLACK)]]>"
+#~ msgstr ""
+#~ "select cat.color, sum(cat.weight), count(cat)\n"
+#~ "from Cat cat\n"
+#~ "group by cat.color\n"
+#~ "having cat.color in (eg.Color.TABBY, eg.Color.BLACK)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cat\n"
+#~ "from Cat cat\n"
+#~ "    join cat.kittens kitten\n"
+#~ "group by cat.id, cat.name, cat.other, cat.properties\n"
+#~ "having avg(kitten.weight) > 100\n"
+#~ "order by count(kitten) asc, sum(kitten.weight) desc]]>"
+#~ msgstr ""
+#~ "select cat\n"
+#~ "from Cat cat\n"
+#~ "    join cat.kittens kitten\n"
+#~ "group by cat.id, cat.name, cat.other, cat.properties\n"
+#~ "having avg(kitten.weight) &gt; 100\n"
+#~ "order by count(kitten) asc, sum(kitten.weight) desc"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as fatcat\n"
+#~ "where fatcat.weight > (\n"
+#~ "    select avg(cat.weight) from DomesticCat cat\n"
+#~ ")]]>"
+#~ msgstr ""
+#~ "from Cat as fatcat\n"
+#~ "where fatcat.weight &gt; (\n"
+#~ "    select avg(cat.weight) from DomesticCat cat\n"
+#~ ")"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from DomesticCat as cat\n"
+#~ "where cat.name = some (\n"
+#~ "    select name.nickName from Name as name\n"
+#~ ")]]>"
+#~ msgstr ""
+#~ "from DomesticCat as cat\n"
+#~ "where cat.name = some (\n"
+#~ "    select name.nickName from Name as name\n"
+#~ ")"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as cat\n"
+#~ "where not exists (\n"
+#~ "    from Cat as mate where mate.mate = cat\n"
+#~ ")]]>"
+#~ msgstr ""
+#~ "from Cat as cat\n"
+#~ "where not exists (\n"
+#~ "    from Cat as mate where mate.mate = cat\n"
+#~ ")"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from DomesticCat as cat\n"
+#~ "where cat.name not in (\n"
+#~ "    select name.nickName from Name as name\n"
+#~ ")]]>"
+#~ msgstr ""
+#~ "from DomesticCat as cat\n"
+#~ "where cat.name not in (\n"
+#~ "    select name.nickName from Name as name\n"
+#~ ")"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select cat.id, (select max(kit.weight) from cat.kitten kit)\n"
+#~ "from Cat as cat]]>"
+#~ msgstr ""
+#~ "select cat.id, (select max(kit.weight) from cat.kitten kit)\n"
+#~ "from Cat as cat"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select order.id, sum(price.amount), count(item)\n"
+#~ "from Order as order\n"
+#~ "    join order.lineItems as item\n"
+#~ "    join item.product as product,\n"
+#~ "    Catalog as catalog\n"
+#~ "    join catalog.prices as price\n"
+#~ "where order.paid = false\n"
+#~ "    and order.customer = :customer\n"
+#~ "    and price.product = product\n"
+#~ "    and catalog.effectiveDate < sysdate\n"
+#~ "    and catalog.effectiveDate >= all (\n"
+#~ "        select cat.effectiveDate\n"
+#~ "        from Catalog as cat\n"
+#~ "        where cat.effectiveDate < sysdate\n"
+#~ "    )\n"
+#~ "group by order\n"
+#~ "having sum(price.amount) > :minAmount\n"
+#~ "order by sum(price.amount) desc]]>"
+#~ msgstr ""
+#~ "select order.id, sum(price.amount), count(item)\n"
+#~ "from Order as order\n"
+#~ "    join order.lineItems as item\n"
+#~ "    join item.product as product,\n"
+#~ "    Catalog as catalog\n"
+#~ "    join catalog.prices as price\n"
+#~ "where order.paid = false\n"
+#~ "    and order.customer = :customer\n"
+#~ "    and price.product = product\n"
+#~ "    and catalog.effectiveDate &lt; sysdate\n"
+#~ "    and catalog.effectiveDate &gt;= all (\n"
+#~ "        select cat.effectiveDate\n"
+#~ "        from Catalog as cat\n"
+#~ "        where cat.effectiveDate &lt; sysdate\n"
+#~ "    )\n"
+#~ "group by order\n"
+#~ "having sum(price.amount) &gt; :minAmount\n"
+#~ "order by sum(price.amount) desc"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select order.id, sum(price.amount), count(item)\n"
+#~ "from Order as order\n"
+#~ "    join order.lineItems as item\n"
+#~ "    join item.product as product,\n"
+#~ "    Catalog as catalog\n"
+#~ "    join catalog.prices as price\n"
+#~ "where order.paid = false\n"
+#~ "    and order.customer = :customer\n"
+#~ "    and price.product = product\n"
+#~ "    and catalog = :currentCatalog\n"
+#~ "group by order\n"
+#~ "having sum(price.amount) > :minAmount\n"
+#~ "order by sum(price.amount) desc]]>"
+#~ msgstr ""
+#~ "select order.id, sum(price.amount), count(item)\n"
+#~ "from Order as order\n"
+#~ "    join order.lineItems as item\n"
+#~ "    join item.product as product,\n"
+#~ "    Catalog as catalog\n"
+#~ "    join catalog.prices as price\n"
+#~ "where order.paid = false\n"
+#~ "    and order.customer = :customer\n"
+#~ "    and price.product = product\n"
+#~ "    and catalog = :currentCatalog\n"
+#~ "group by order\n"
+#~ "having sum(price.amount) &gt; :minAmount\n"
+#~ "order by sum(price.amount) desc"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select count(payment), status.name\n"
+#~ "from Payment as payment\n"
+#~ "    join payment.currentStatus as status\n"
+#~ "    join payment.statusChanges as statusChange\n"
+#~ "where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
+#~ "    or (\n"
+#~ "        statusChange.timeStamp = (\n"
+#~ "            select max(change.timeStamp)\n"
+#~ "            from PaymentStatusChange change\n"
+#~ "            where change.payment = payment\n"
+#~ "        )\n"
+#~ "        and statusChange.user <> :currentUser\n"
+#~ "    )\n"
+#~ "group by status.name, status.sortOrder\n"
+#~ "order by status.sortOrder]]>"
+#~ msgstr ""
+#~ "select count(payment), status.name\n"
+#~ "from Payment as payment\n"
+#~ "    join payment.currentStatus as status\n"
+#~ "    join payment.statusChanges as statusChange\n"
+#~ "where payment.status.name &lt;&gt; PaymentStatus.AWAITING_APPROVAL\n"
+#~ "    or (\n"
+#~ "        statusChange.timeStamp = (\n"
+#~ "            select max(change.timeStamp)\n"
+#~ "            from PaymentStatusChange change\n"
+#~ "            where change.payment = payment\n"
+#~ "        )\n"
+#~ "        and statusChange.user &lt;&gt; :currentUser\n"
+#~ "    )\n"
+#~ "group by status.name, status.sortOrder\n"
+#~ "order by status.sortOrder"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select count(payment), status.name\n"
+#~ "from Payment as payment\n"
+#~ "    join payment.currentStatus as status\n"
+#~ "where payment.status.name <> PaymentStatus.AWAITING_APPROVAL\n"
+#~ "    or payment.statusChanges[ maxIndex(payment.statusChanges) ].user <> :"
+#~ "currentUser\n"
+#~ "group by status.name, status.sortOrder\n"
+#~ "order by status.sortOrder]]>"
+#~ msgstr ""
+#~ "select count(payment), status.name\n"
+#~ "from Payment as payment\n"
+#~ "    join payment.currentStatus as status\n"
+#~ "where payment.status.name &lt;&gt; PaymentStatus.AWAITING_APPROVAL\n"
+#~ "    or payment.statusChanges[ maxIndex(payment.statusChanges) ].user &lt;"
+#~ "&gt; :currentUser\n"
+#~ "group by status.name, status.sortOrder\n"
+#~ "order by status.sortOrder"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select account, payment\n"
+#~ "from Account as account\n"
+#~ "    left outer join account.payments as payment\n"
+#~ "where :currentUser in elements(account.holder.users)\n"
+#~ "    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
+#~ "PaymentStatus.UNPAID)\n"
+#~ "order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
+#~ msgstr ""
+#~ "select account, payment\n"
+#~ "from Account as account\n"
+#~ "    left outer join account.payments as payment\n"
+#~ "where :currentUser in elements(account.holder.users)\n"
+#~ "    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
+#~ "PaymentStatus.UNPAID)\n"
+#~ "order by account.type.sortOrder, account.accountNumber, payment.dueDate"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select account, payment\n"
+#~ "from Account as account\n"
+#~ "    join account.holder.users as user\n"
+#~ "    left outer join account.payments as payment\n"
+#~ "where :currentUser = user\n"
+#~ "    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
+#~ "PaymentStatus.UNPAID)\n"
+#~ "order by account.type.sortOrder, account.accountNumber, payment.dueDate]]>"
+#~ msgstr ""
+#~ "select account, payment\n"
+#~ "from Account as account\n"
+#~ "    join account.holder.users as user\n"
+#~ "    left outer join account.payments as payment\n"
+#~ "where :currentUser = user\n"
+#~ "    and PaymentStatus.UNPAID = isNull(payment.currentStatus.name, "
+#~ "PaymentStatus.UNPAID)\n"
+#~ "order by account.type.sortOrder, account.accountNumber, payment.dueDate"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
+#~ "iterate().next() ).intValue()]]>"
+#~ msgstr ""
+#~ "( (Integer) session.iterate(\"select count(*) from ....\").next() )."
+#~ "intValue()"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select usr.id, usr.name\n"
+#~ "from User as usr\n"
+#~ "    left join usr.messages as msg\n"
+#~ "group by usr.id, usr.name\n"
+#~ "order by count(msg)]]>"
+#~ msgstr ""
+#~ "select usr.id, usr.name\n"
+#~ "from User as usr\n"
+#~ "    left join usr.messages as msg\n"
+#~ "group by usr.id, usr.name\n"
+#~ "order by count(msg)"
+
+#, fuzzy
+#~ msgid "<![CDATA[from User usr where size(usr.messages) >= 1]]>"
+#~ msgstr "from User usr where size(usr.messages) &gt;= 1"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select usr.id, usr.name\n"
+#~ "from User usr.name\n"
+#~ "    join usr.messages msg\n"
+#~ "group by usr.id, usr.name\n"
+#~ "having count(msg) >= 1]]>"
+#~ msgstr ""
+#~ "select usr.id, usr.name\n"
+#~ "from User usr.name\n"
+#~ "    join usr.messages msg\n"
+#~ "group by usr.id, usr.name\n"
+#~ "having count(msg) &gt;= 1"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[select usr.id, usr.name\n"
+#~ "from User as usr\n"
+#~ "    left join usr.messages as msg\n"
+#~ "group by usr.id, usr.name\n"
+#~ "having count(msg) = 0]]>"
+#~ msgstr ""
+#~ "select usr.id, usr.name\n"
+#~ "from User as usr\n"
+#~ "    left join usr.messages as msg\n"
+#~ "group by usr.id, usr.name\n"
+#~ "having count(msg) = 0"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Query q = s.createQuery(\"from foo Foo as foo where foo.name=:"
+#~ "name and foo.size=:size\");\n"
+#~ "q.setProperties(fooBean); // fooBean has getName() and getSize()\n"
+#~ "List foos = q.list();]]>"
+#~ msgstr ""
+#~ "Query q = s.createQuery(\"from foo Foo as foo where foo.name=:name and "
+#~ "foo.size=:size\");\n"
+#~ "q.setProperties(fooBean); // fooBean has getName() and getSize()\n"
+#~ "List foos = q.list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Query q = s.createFilter( collection, \"\" ); // the trivial "
+#~ "filter\n"
+#~ "q.setMaxResults(PAGE_SIZE);\n"
+#~ "q.setFirstResult(PAGE_SIZE * pageNumber);\n"
+#~ "List page = q.list();]]>"
+#~ msgstr ""
+#~ "Query q = s.createFilter( collection, \"\" ); // the trivial filter\n"
+#~ "q.setMaxResults(PAGE_SIZE);\n"
+#~ "q.setFirstResult(PAGE_SIZE * pageNumber);\n"
+#~ "List page = q.list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Collection orderedCollection = s.filter( collection, \"order by "
+#~ "this.amount\" );\n"
+#~ "Collection counts = s.filter( collection, \"select this.type, count(this) "
+#~ "group by this.type\" );]]>"
+#~ msgstr ""
+#~ "Collection orderedCollection = s.filter( collection, \"order by this."
+#~ "amount\" );\n"
+#~ "Collection counts = s.filter( collection, \"select this.type, count(this) "
+#~ "group by this.type\" );"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[( (Integer) session.createQuery(\"select count(*) from ....\")."
+#~ "iterate().next() ).intValue();]]>"
+#~ msgstr ""
+#~ "( (Integer) session.iterate(\"select count(*) from ....\").next() )."
+#~ "intValue();"
+
+#, fuzzy
+#~ msgid "<![CDATA[select p.name from Person p]]>"
+#~ msgstr "select p.name from from Person p"
+
+#, fuzzy
+#~ msgid "<![CDATA[select p.name.first from Person p]]>"
+#~ msgstr "select p.name.first from from Person p"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Person p where p.name = :name]]>"
+#~ msgstr "from from Person p where p.name = :name"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Person p where p.name.first = :firstName]]>"
+#~ msgstr "from from Person p where p.name.first = :firstName"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Person p order by p.name]]>"
+#~ msgstr "from from Person p order by p.name"
+
+#, fuzzy
+#~ msgid "<![CDATA[from Person p order by p.name.first]]>"
+#~ msgstr "from from Person p order by p.name.first"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Person p where p.name.first='John' and p.name."
+#~ "last='Jingleheimer-Schmidt']]>"
+#~ msgstr ""
+#~ "from Person p where p.name.first='John' and p.name.last='Jingleheimer-"
+#~ "Schmidt'"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Person p where p.name=('John', 'Jingleheimer-Schmidt')]]>"
+#~ msgstr "from Person p where p.name=('John', 'Jingleheimer-Schmidt')"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[from Cat as cat\n"
+#~ "where not ( cat.name, cat.color ) in (\n"
+#~ "    select cat.name, cat.color from DomesticCat cat\n"
+#~ ")]]>"
+#~ msgstr ""
+#~ "from Cat as cat\n"
+#~ "where not ( cat.name, cat.color ) in (\n"
+#~ "    select cat.name, cat.color from DomesticCat cat\n"
+#~ ")"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/query_sql.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/query_sql.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/query_sql.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,26 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:15\n"
+"PO-Revision-Date: 2010-01-11 10:42+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: query_sql.xml:29
 #, no-c-format
 msgid "Native SQL"
-msgstr "Native SQL查询"
+msgstr "Native SQL 查询"
 
 #. Tag: para
-#: query_sql.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also express queries in the native SQL dialect of your database. "
 "This is useful if you want to utilize database-specific features such as "
@@ -26,123 +28,85 @@
 "provides a clean migration path from a direct SQL/JDBC based application to "
 "Hibernate."
 msgstr ""
-"你也可以使用你的数据库的Native SQL语言来查询数据。这对你在要使用数据库的某些"
-"特性的时候(比如说在查询提示或者Oracle中的 <literal>CONNECT</literal>关键字),"
-"这是非常有用的。这就能够扫清你把原来直接使用SQL/JDBC 的程序迁移到基于 "
-"Hibernate应用的道路上的障碍。"
+"你也可以使用你的数据库的 Native SQL 语言来查询数据。这对你在要使用数据库的某"
+"些特性的时候(比如说在查询提示或者 Oracle 中的 <literal>CONNECT</literal> 关"
+"键字),这是非常有用的。这就能够扫清你把原来直接使用 SQL/JDBC 的程序迁移到基"
+"于 Hibernate 应用的道路上的障碍。 "
 
 #. Tag: para
-#: query_sql.xml:37
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 allows you to specify handwritten SQL, including stored "
 "procedures, for all create, update, delete, and load operations."
 msgstr ""
-"Hibernate3允许你使用手写的sql来完成所有的create,update,delete,和load操作(包"
-"括存储过程)"
+"Hibernate3 允许你使用手写的 sql 来完成所有的 create、update、delete 和 load "
+"操作(包括存储过程) "
 
 #. Tag: title
-#: query_sql.xml:41
 #, no-c-format
 msgid "Using a <literal>SQLQuery</literal>"
-msgstr "使用<literal>SQLQuery</literal>"
+msgstr "使用 <literal>SQLQuery</literal>"
 
 #. Tag: para
-#: query_sql.xml:43
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Execution of native SQL queries is controlled via the <literal>SQLQuery</"
 "literal> interface, which is obtained by calling <literal>Session."
 "createSQLQuery()</literal>. The following sections describe how to use this "
 "API for querying."
 msgstr ""
-"对原生SQL查询执行的控制是通过<literal>SQLQuery</literal>接口进行的,通过执行"
-"<literal>Session.createSQLQuery()</literal>获取这个接口。下面来描述如何使用这"
-"个API进行查询。"
+"对原生 SQL 查询执行的控制是通过 <literal>SQLQuery</literal> 接口进行的,通过"
+"执行<literal>Session.createSQLQuery()</literal>获取这个接口。下面来描述如何使"
+"用这个 API 进行查询。 "
 
 #. Tag: title
-#: query_sql.xml:49
 #, no-c-format
 msgid "Scalar queries"
 msgstr "标量查询(Scalar queries)"
 
 #. Tag: para
-#: query_sql.xml:51
 #, no-c-format
 msgid "The most basic SQL query is to get a list of scalars (values)."
-msgstr "最基本的SQL查询就是获得一个标量(数值)的列表。"
+msgstr "最基本的 SQL 查询就是获得一个标量(数值)的列表。"
 
-#. Tag: programlisting
-#: query_sql.xml:54
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").list();\n"
-"sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").list();\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:56
-#, fuzzy, no-c-format
-msgid ""
 "These will return a List of Object arrays (Object[]) with scalar values for "
 "each column in the CATS table. Hibernate will use ResultSetMetadata to "
 "deduce the actual order and types of the returned scalar values."
 msgstr ""
-"它们都将返回一个Object数组(Object[])组成的List,数组每个元素都是CATS表的一个"
-"字段值。Hibernate会使用ResultSetMetadata来判定返回的标量值的实际顺序和类型。"
+"它们都将返回一个 Object 数组(Object[])组成的 List,数组每个元素都是 CATS 表"
+"的一个字段值。Hibernate 会使用 ResultSetMetadata 来判定返回的标量值的实际顺序"
+"和类型。 "
 
 #. Tag: para
-#: query_sql.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "To avoid the overhead of using <literal>ResultSetMetadata</literal>, or "
 "simply to be more explicit in what is returned, one can use "
 "<literal>addScalar()</literal>:"
 msgstr ""
-"如果要避免过多的使用<literal>ResultSetMetadata</literal>,或者只是为了更加明确"
-"的指名返回值,可以使用<literal>addScalar()</literal>。"
+"如果要避免过多的使用 <literal>ResultSetMetadata</literal>,或者只是为了更加明"
+"确的指名返回值,可以使用 <literal>addScalar()</literal>: "
 
-#. Tag: programlisting
-#: query_sql.xml:65
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-" .addScalar(\"ID\", Hibernate.LONG)\n"
-" .addScalar(\"NAME\", Hibernate.STRING)\n"
-" .addScalar(\"BIRTHDATE\", Hibernate.DATE)\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:67 query_sql.xml:113 query_sql.xml:198 query_sql.xml:349
-#, fuzzy, no-c-format
 msgid "This query specified:"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"这个查询指定了:\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"这个查询指定:\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"这个查询指明:\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"这个查询指定:"
+msgstr "这个查询指定:"
 
 #. Tag: para
-#: query_sql.xml:71 query_sql.xml:117 query_sql.xml:353
 #, no-c-format
 msgid "the SQL query string"
-msgstr "SQL查询字符串"
+msgstr "SQL 查询字符串"
 
 #. Tag: para
-#: query_sql.xml:75
 #, no-c-format
 msgid "the columns and types to return"
 msgstr "要返回的字段和类型"
 
 #. Tag: para
-#: query_sql.xml:79
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This will return Object arrays, but now it will not use "
 "<literal>ResultSetMetadata</literal> but will instead explicitly get the ID, "
@@ -151,62 +115,47 @@
 "be returned, even though the query is using <literal>*</literal> and could "
 "return more than the three listed columns."
 msgstr ""
-"它仍然会返回Object数组,但是此时不再使用<literal>ResultSetMetdata</literal>,而"
-"是明确的将ID,NAME和BIRTHDATE按照Long,String和Short类型从resultset中取出。同"
-"时,也指明了就算query是使用<literal>*</literal>来查询的,可能获得超过列出的这"
-"三个字段,也仅仅会返回这三个字段。"
+"它仍然会返回 Object 数组,但是此时不再使用 <literal>ResultSetMetdata</"
+"literal>,而是明确的将 ID,NAME 和 BIRTHDATE 按照 Long,String 和 Short 类型"
+"从 resultset 中取出。同时,也指明了就算 query 是使用 <literal>*</literal> 来"
+"查询的,可能获得超过列出的这三个字段,也仅仅会返回这三个字段。 "
 
 #. Tag: para
-#: query_sql.xml:87
 #, no-c-format
 msgid ""
 "It is possible to leave out the type information for all or some of the "
 "scalars."
 msgstr "对全部或者部分的标量值不设置类型信息也是可以的。"
 
-#. Tag: programlisting
-#: query_sql.xml:90
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
-" .addScalar(\"ID\", Hibernate.LONG)\n"
-" .addScalar(\"NAME\")\n"
-" .addScalar(\"BIRTHDATE\")\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:92
-#, fuzzy, no-c-format
-msgid ""
 "This is essentially the same query as before, but now "
 "<literal>ResultSetMetaData</literal> is used to determine the type of NAME "
 "and BIRTHDATE, where as the type of ID is explicitly specified."
 msgstr ""
-"基本上这和前面一个查询相同,只是此时使用<literal>ResultSetMetaData</literal>来"
-"决定NAME和BIRTHDATE的类型,而ID的类型是明确指出的。"
+"基本上这和前面一个查询相同,只是此时使用 <literal>ResultSetMetaData</literal> "
+"来决定 NAME 和 BIRTHDATE 的类型,而 ID 的类型是明确指出的。 "
 
 #. Tag: para
-#: query_sql.xml:96
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "How the java.sql.Types returned from ResultSetMetaData is mapped to "
 "Hibernate types is controlled by the Dialect. If a specific type is not "
 "mapped, or does not result in the expected type, it is possible to customize "
 "it via calls to <literal>registerHibernateType</literal> in the Dialect."
 msgstr ""
-"关于从ResultSetMetaData返回的java.sql.Types是如何映射到Hibernate类型,是由方"
-"言(Dialect)控制的。假若某个指定的类型没有被映射,或者不是你所预期的类型,你可"
-"以通过Dialet的<literal>registerHibernateType</literal>调用自行定义。"
+"关于从 ResultSetMetaData 返回的 java.sql.Types 是如何映射到 Hibernate 类型,"
+"是由方言(Dialect)控制的。假若某个指定的类型没有被映射,或者不是你所预期的类"
+"型,你可以通过 Dialet 的 <literal>registerHibernateType</literal> 调用自行定"
+"义。 "
 
 #. Tag: title
-#: query_sql.xml:104
 #, no-c-format
 msgid "Entity queries"
-msgstr "实体查询(Entity queries)"
+msgstr "实体查询(Entity queries)"
 
 #. Tag: para
-#: query_sql.xml:106
 #, no-c-format
 msgid ""
 "The above queries were all about returning scalar values, basically "
@@ -214,38 +163,25 @@
 "get entity objects from a native sql query via <literal>addEntity()</"
 "literal>."
 msgstr ""
-"上面的查询都是返回标量值的,也就是从resultset中返回的“裸”数据。下面展示如何通"
-"过<literal>addEntity()</literal>让原生查询返回实体对象。"
+"上面的查询都是返回标量值的,也就是从 resultset 中返回的“裸”数据。下面展示如何"
+"通过 <literal>addEntity()</literal> 让原生查询返回实体对象。"
 
-#. Tag: programlisting
-#: query_sql.xml:111
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").addEntity(Cat.class);\n"
-"sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").addEntity(Cat."
-"class);\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:121
 #, no-c-format
 msgid "the entity returned by the query"
 msgstr "要返回的实体"
 
 #. Tag: para
-#: query_sql.xml:125
 #, no-c-format
 msgid ""
 "Assuming that Cat is mapped as a class with the columns ID, NAME and "
 "BIRTHDATE the above queries will both return a List where each element is a "
 "Cat entity."
 msgstr ""
-"假设Cat被映射为拥有ID,NAME和BIRTHDATE三个字段的类,以上的两个查询都返回一个"
-"List,每个元素都是一个Cat实体。"
+"假设 Cat 被映射为拥有 ID,NAME 和 BIRTHDATE 三个字段的类,以上的两个查询都返"
+"回一个 List,每个元素都是一个 Cat 实体。"
 
 #. Tag: para
-#: query_sql.xml:129
 #, no-c-format
 msgid ""
 "If the entity is mapped with a <literal>many-to-one</literal> to another "
@@ -255,34 +191,23 @@
 "but we prefer to be explicit as in the following example for a <literal>many-"
 "to-one</literal> to a <literal>Dog</literal>:"
 msgstr ""
-"假若实体在映射时有一个<literal>many-to-one</literal>的关联指向另外一个实体,"
-"在查询时必须也返回那个实体,否则会导致发生一个\"column not found\"的数据库错"
-"误。这些附加的字段可以使用*标注来自动返回,但我们希望还是明确指明,看下面这个"
-"具有指向<literal>Dog</literal>的<literal>many-to-one</literal>的例子:"
+"假若实体在映射时有一个 <literal>many-to-one</literal> 的关联指向另外一个实"
+"体,在查询时必须也返回那个实体,否则会导致发生一个 \"column not found\" 的数"
+"据库错误。这些附加的字段可以使用 * 标注来自动返回,但我们希望还是明确指明,看"
+"下面这个具有指向 <literal>Dog</literal> 的 <literal>many-to-one</literal> 的"
+"例子:"
 
-#. Tag: programlisting
-#: query_sql.xml:137
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, DOG_ID FROM CATS"
-"\").addEntity(Cat.class);\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:139
 #, no-c-format
 msgid "This will allow cat.getDog() to function properly."
-msgstr "这样cat.getDog()就能正常运作。"
+msgstr "这样 cat.getDog() 就能正常运作。"
 
 #. Tag: title
-#: query_sql.xml:143
 #, no-c-format
 msgid "Handling associations and collections"
-msgstr "处理关联和集合类(Handling associations and collections)"
+msgstr "处理关联和集合类(Handling associations and collections)"
 
 #. Tag: para
-#: query_sql.xml:145
 #, no-c-format
 msgid ""
 "It is possible to eagerly join in the <literal>Dog</literal> to avoid the "
@@ -290,25 +215,13 @@
 "<literal>addJoin()</literal> method, which allows you to join in an "
 "association or collection."
 msgstr ""
-"通过提前抓取将<literal>Dog</literal>连接获得,而避免初始化proxy带来的额外开销"
-"也是可能的。这是通过<literal>addJoin()</literal>方法进行的,这个方法可以让你"
-"将关联或集合连接进来。"
+"通过提前抓取将 <literal>Dog</literal> 连接获得,而避免初始化 proxy 带来的额外"
+"开销也是可能的。这是通过 <literal>addJoin()</literal> 方法进行的,这个方法可"
+"以让你将关联或集合连接进来。"
 
-#. Tag: programlisting
-#: query_sql.xml:150
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT c.ID, NAME, BIRTHDATE, DOG_ID, D_ID, "
-"D_NAME FROM CATS c, DOGS d WHERE c.DOG_ID = d.D_ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addJoin(\"cat.dog\");\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:152
-#, fuzzy, no-c-format
-msgid ""
 "In this example, the returned <literal>Cat</literal>'s will have their "
 "<literal>dog</literal> property fully initialized without any extra "
 "roundtrip to the database. Notice that you added an alias name (\"cat\") to "
@@ -316,76 +229,50 @@
 "do the same eager joining for collections, e.g. if the <literal>Cat</"
 "literal> had a one-to-many to <literal>Dog</literal> instead."
 msgstr ""
-"上面这个例子中,返回的<literal>Cat</literal>对象,其<literal>dog</literal>属"
-"性被完全初始化了,不再需要数据库的额外操作。注意,我们加了一个别名(\"cat\"),"
-"以便指明join的目标属性路径。通过同样的提前连接也可以作用于集合类,例如,假若"
-"<literal>Cat</literal>有一个指向<literal>Dog</literal>的一对多关联。"
+"上面这个例子中,返回的 <literal>Cat</literal> 对象,其 <literal>dog</"
+"literal> 属性被完全初始化了,不再需要数据库的额外操作。注意,我们加了一个别名"
+"(\"cat\"),以便指明 join 的目标属性路径。通过同样的提前连接也可以作用于集合"
+"类,例如,假若 <literal>Cat</literal> 有一个指向 <literal>Dog</literal> 的一"
+"对多关联。 "
 
-#. Tag: programlisting
-#: query_sql.xml:160
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, D_ID, D_NAME, "
-"CAT_ID FROM CATS c, DOGS d WHERE c.ID = d.CAT_ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addJoin(\"cat.dogs\");\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:162
-#, fuzzy, no-c-format
-msgid ""
 "At this stage you are reaching the limits of what is possible with native "
 "queries, without starting to enhance the sql queries to make them usable in "
 "Hibernate. Problems can arise when returning multiple entities of the same "
 "type or when the default alias/column names are not enough."
 msgstr ""
-"到此为止,我们碰到了天花板:若不对SQL查询进行增强,这些已经是在Hibernate中使"
-"用原生SQL查询所能做到的最大可能了。下面的问题即将出现:返回多个同样类型的实体"
-"怎么办?或者默认的别名/字段不够又怎么办?"
+"到此为止,我们碰到了天花板:若不对 SQL 查询进行增强,这些已经是在 Hibernate "
+"中使用原生 SQL 查询所能做到的最大可能了。下面的问题即将出现:返回多个同样类型"
+"的实体怎么办?或者默认的别名/字段不够又怎么办? "
 
 #. Tag: title
-#: query_sql.xml:170
 #, no-c-format
 msgid "Returning multiple entities"
-msgstr "返回多个实体(Returning multiple entities)"
+msgstr "返回多个实体(Returning multiple entities)"
 
 #. Tag: para
-#: query_sql.xml:172
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Until now, the result set column names are assumed to be the same as the "
 "column names specified in the mapping document. This can be problematic for "
 "SQL queries that join multiple tables, since the same column names can "
 "appear in more than one table."
 msgstr ""
-"到目前为止,结果集字段名被假定为和映射文件中指定的的字段名是一致的。假若SQL查"
-"询连接了多个表,同一个字段名可能在多个表中出现多次,这就会造成问题。"
+"到目前为止,结果集字段名被假定为和映射文件中指定的的字段名是一致的。假若 SQL "
+"查询连接了多个表,同一个字段名可能在多个表中出现多次,这就会造成问题。 "
 
 #. Tag: para
-#: query_sql.xml:177
 #, no-c-format
 msgid ""
 "Column alias injection is needed in the following query (which most likely "
 "will fail):"
 msgstr "下面的查询中需要使用字段别名注射(这个例子本身会失败):"
 
-#. Tag: programlisting
-#: query_sql.xml:180
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT c.*, m.*  FROM CATS c, CATS m WHERE c."
-"MOTHER_ID = c.ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addEntity(\"mother\", Cat.class)\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:184
-#, fuzzy, no-c-format
-msgid ""
 "The query was intended to return two Cat instances per row: a cat and its "
 "mother. The query will, however, fail because there is a conflict of names; "
 "the instances are mapped to the same column names. Also, on some databases "
@@ -393,45 +280,30 @@
 "NAME\", etc. which are not equal to the columns specified in the mappings "
 "(\"ID\" and \"NAME\")."
 msgstr ""
-"这个查询的本意是希望每行返回两个Cat实例,一个是cat,另一个是它的妈妈。但是因为"
-"它们的字段名被映射为相同的,而且在某些数据库中,返回的字段别名是“c.ID”,\"c."
-"NAME\"这样的形式,而它们和在映射文件中的名字(\"ID\"和\"NAME\")不匹配,这就"
-"会造成失败。"
+"这个查询的本意是希望每行返回两个 Cat 实例,一个是 cat,另一个是它的妈妈。但是"
+"因为它们的字段名被映射为相同的,而且在某些数据库中,返回的字段别名是“c.ID”,"
+"\"c.NAME\" 这样的形式,而它们和在映射文件中的名字(\"ID\" 和 \"NAME\")不匹"
+"配,这就会造成失败。 "
 
 #. Tag: para
-#: query_sql.xml:193
 #, no-c-format
 msgid "The following form is not vulnerable to column name duplication:"
 msgstr "下面的形式可以解决字段名重复:"
 
-#. Tag: programlisting
-#: query_sql.xml:196
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT {cat.*}, {mother.*}  FROM CATS c, CATS "
-"m WHERE c.MOTHER_ID = c.ID\")\n"
-" .addEntity(\"cat\", Cat.class)\n"
-" .addEntity(\"mother\", Cat.class)\n"
-"]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:202
 #, no-c-format
 msgid ""
 "the SQL query string, with placeholders for Hibernate to inject column "
 "aliases"
-msgstr "SQL查询语句,其中包含占位附来让Hibernate注射字段别名"
+msgstr "SQL 查询语句,其中包含占位附来让 Hibernate 注射字段别名"
 
 #. Tag: para
-#: query_sql.xml:207
 #, no-c-format
 msgid "the entities returned by the query"
 msgstr "查询返回的实体"
 
 #. Tag: para
-#: query_sql.xml:211
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The {cat.*} and {mother.*} notation used above is a shorthand for \"all "
 "properties\". Alternatively, you can list the columns explicitly, but even "
@@ -441,36 +313,19 @@
 "from a different table (cat_log) to the one declared in the mapping "
 "metadata. You can even use the property aliases in the where clause."
 msgstr ""
-"上面使用的{cat.*}和{mother.*}标记是作为“所有属性”的简写形式出现的。当然你也可"
-"以明确地罗列出字段名,但在这个例子里面我们让Hibernate来为每个属性注射SQL字段"
-"别名。字段别名的占位符是属性名加上表别名的前缀。在下面的例子中,我们从另外一"
-"个表(cat_log)中通过映射元数据中的指定获取Cat和它的妈妈。注意,要是我们愿"
-"意,我们甚至可以在where子句中使用属性别名。"
+"上面使用的 {cat.*} 和 {mother.*} 标记是作为“所有属性”的简写形式出现的。当然你"
+"也可以明确地罗列出字段名,但在这个例子里面我们让 Hibernate 来为每个属性注射 "
+"SQL 字段别名。字段别名的占位符是属性名加上表别名的前缀。在下面的例子中,我们"
+"从另外一个表(cat_log)中通过映射元数据中的指定获取 Cat 和它的妈妈。注意,要"
+"是我们愿意,我们甚至可以在 where 子句中使用属性别名。 "
 
-#. Tag: programlisting
-#: query_sql.xml:220
-#, no-c-format
-msgid ""
-"<![CDATA[String sql = \"SELECT ID as {c.id}, NAME as {c.name}, \" + \n"
-"         \"BIRTHDATE as {c.birthDate}, MOTHER_ID as {c.mother}, {mother.*} "
-"\" +\n"
-"         \"FROM CAT_LOG c, CAT_LOG m WHERE {c.mother} = c.ID\";\n"
-"\n"
-"List loggedCats = sess.createSQLQuery(sql)\n"
-"        .addEntity(\"cat\", Cat.class)\n"
-"        .addEntity(\"mother\", Cat.class).list()\n"
-"]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:223
 #, no-c-format
 msgid "Alias and property references"
-msgstr "别名和属性引用(Alias and property references)"
+msgstr "别名和属性引用(Alias and property references)"
 
 #. Tag: para
-#: query_sql.xml:225
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In most cases the above alias injection is needed. For queries relating to "
 "more complex mappings, like composite properties, inheritance "
@@ -478,12 +333,11 @@
 "Hibernate to inject the proper aliases."
 msgstr ""
 "大多数情况下,都需要上面的属性注射,但在使用更加复杂的映射,比如复合属性、通"
-"过标识符构造继承树,以及集合类等等情况下,也有一些特别的别名,来允许Hibernate"
-"注射合适的别名。"
+"过标识符构造继承树,以及集合类等等情况下,也有一些特别的别名,来允许 "
+"Hibernate 注入合适的别名。 "
 
 #. Tag: para
-#: query_sql.xml:230
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table shows the different ways you can use the alias "
 "injection. Please note that the alias names in the result are simply "
@@ -491,544 +345,338 @@
 "used."
 msgstr ""
 "下表列出了使用别名注射参数的不同可能性。注意:下面结果中的别名只是示例,实用"
-"时每个别名需要唯一并且不同的名字。"
+"时每个别名需要唯一并且不同的名字。 "
 
 #. Tag: title
-#: query_sql.xml:236
 #, no-c-format
 msgid "Alias injection names"
-msgstr "别名注射(alias injection names)"
+msgstr "别名注射(alias injection names)"
 
 #. Tag: entry
-#: query_sql.xml:247
 #, no-c-format
 msgid "Description"
 msgstr "描述"
 
 #. Tag: entry
-#: query_sql.xml:249
 #, no-c-format
 msgid "Syntax"
 msgstr "语法"
 
 #. Tag: entry
-#: query_sql.xml:251
 #, no-c-format
 msgid "Example"
 msgstr "示例"
 
 #. Tag: entry
-#: query_sql.xml:257
 #, no-c-format
 msgid "A simple property"
 msgstr "简单属性"
 
-#. Tag: literal
-#: query_sql.xml:259
-#, no-c-format
-msgid "{[aliasname].[propertyname]"
-msgstr "{[aliasname].[propertyname]"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].[propertyname]</literal>"
+msgstr "<literal>{[aliasname].[propertyname]</literal>"
 
-#. Tag: literal
-#: query_sql.xml:261
-#, no-c-format
-msgid "A_NAME as {item.name}"
-msgstr "A_NAME as {item.name}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>A_NAME as {item.name}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:265
 #, no-c-format
 msgid "A composite property"
 msgstr "复合属性"
 
-#. Tag: literal
-#: query_sql.xml:267
-#, no-c-format
-msgid "{[aliasname].[componentname].[propertyname]}"
-msgstr "{[aliasname].[componentname].[propertyname]}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].[componentname].[propertyname]}</literal>"
+msgstr "<literal>{[aliasname].[componentname].[propertyname]}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:269
-#, no-c-format
-msgid "CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}"
-msgstr "CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid ""
+"<literal>CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}</"
+"literal>"
+msgstr ""
+"<literal>CURRENCY as {item.amount.currency}, VALUE as {item.amount.value}</"
+"literal>"
 
 #. Tag: entry
-#: query_sql.xml:274
 #, no-c-format
 msgid "Discriminator of an entity"
-msgstr "实体辨别器(Discriminator of an entity)"
+msgstr "实体辨别器(Discriminator of an entity)"
 
-#. Tag: literal
-#: query_sql.xml:276
-#, no-c-format
-msgid "{[aliasname].class}"
-msgstr "{[aliasname].class}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].class}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:278
-#, no-c-format
-msgid "DISC as {item.class}"
-msgstr "DISC as {item.class}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>DISC as {item.class}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:282
 #, no-c-format
 msgid "All properties of an entity"
 msgstr "实体的所有属性"
 
-#. Tag: literal
-#: query_sql.xml:284 query_sql.xml:332
-#, no-c-format
-msgid "{[aliasname].*}"
-msgstr "{[aliasname].*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].*}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:286
+#. Tag: entry
 #, no-c-format
-msgid "{item.*}"
-msgstr "{item.*}"
+msgid "<literal>{item.*}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:290
 #, no-c-format
 msgid "A collection key"
-msgstr "集合键(collection key)"
+msgstr "集合键(collection key)"
 
-#. Tag: literal
-#: query_sql.xml:292
-#, no-c-format
-msgid "{[aliasname].key}"
-msgstr "{[aliasname].key}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].key}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:294
-#, no-c-format
-msgid "ORGID as {coll.key}"
-msgstr "ORGID as {coll.key}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>ORGID as {coll.key}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:298
 #, no-c-format
 msgid "The id of an collection"
-msgstr "集合id"
+msgstr "集合 id"
 
-#. Tag: literal
-#: query_sql.xml:300
-#, no-c-format
-msgid "{[aliasname].id}"
-msgstr "{[aliasname].id}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].id}</literal>"
+msgstr "<literal>{item.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:302
-#, no-c-format
-msgid "EMPID as {coll.id}"
-msgstr "EMPID as {coll.id}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>EMPID as {coll.id}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:306
 #, no-c-format
 msgid "The element of an collection"
 msgstr "集合元素"
 
-#. Tag: literal
-#: query_sql.xml:308
-#, no-c-format
-msgid "{[aliasname].element}"
-msgstr "{[aliasname].element}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element}</literal>"
+msgstr "<literal>{coll.element.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:310
-#, no-c-format
-msgid "XID as {coll.element}"
-msgstr "XID as {coll.element}"
-
 #. Tag: entry
-#: query_sql.xml:314
 #, fuzzy, no-c-format
-msgid "property of the element in the collection"
-msgstr "集合元素的属性"
+msgid "<literal>XID as {coll.element}</literal>"
+msgstr "<literal>{coll.element.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:316
+#. Tag: entry
 #, no-c-format
-msgid "{[aliasname].element.[propertyname]}"
-msgstr "{[aliasname].element.[propertyname]}"
+msgid "property of the element in the collection"
+msgstr "集合元素的属性 "
 
-#. Tag: literal
-#: query_sql.xml:318
-#, no-c-format
-msgid "NAME as {coll.element.name}"
-msgstr "NAME as {coll.element.name}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element.[propertyname]}</literal>"
+msgstr "<literal>{[aliasname].element.[propertyname]}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:322
+#, fuzzy, no-c-format
+msgid "<literal>NAME as {coll.element.name}</literal>"
+msgstr "<literal>{coll.element.*}</literal>"
+
+#. Tag: entry
 #, no-c-format
 msgid "All properties of the element in the collection"
 msgstr "集合元素的所有属性"
 
-#. Tag: literal
-#: query_sql.xml:324
-#, no-c-format
-msgid "{[aliasname].element.*}"
-msgstr "{[aliasname].element.*}"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>{[aliasname].element.*}</literal>"
+msgstr "<literal>{coll.element.*}</literal>"
 
-#. Tag: literal
-#: query_sql.xml:326
+#. Tag: entry
 #, no-c-format
-msgid "{coll.element.*}"
-msgstr "{coll.element.*}"
+msgid "<literal>{coll.element.*}</literal>"
+msgstr "<literal>{coll.element.*}</literal>"
 
 #. Tag: entry
-#: query_sql.xml:330
 #, no-c-format
 msgid "All properties of the the collection"
 msgstr "集合的所有属性"
 
-#. Tag: literal
-#: query_sql.xml:334
+#. Tag: entry
 #, no-c-format
-msgid "{coll.*}"
-msgstr "{coll.*}"
+msgid "<literal>{coll.*}</literal>"
+msgstr "<literal>{coll.*}</literal>"
 
 #. Tag: title
-#: query_sql.xml:343
 #, no-c-format
 msgid "Returning non-managed entities"
-msgstr "返回非受管实体(Returning non-managed entities)"
+msgstr "返回非受管实体(Returning non-managed entities)"
 
 #. Tag: para
-#: query_sql.xml:345
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is possible to apply a ResultTransformer to native SQL queries, allowing "
 "it to return non-managed entities."
 msgstr ""
-"可以对原生sql 查询使用ResultTransformer。这会返回不受Hibernate管理的实体。"
+"可以对原生 sql 查询使用 ResultTransformer。这会返回不受 Hibernate 管理的实"
+"体。 "
 
-#. Tag: programlisting
-#: query_sql.xml:347
-#, no-c-format
-msgid ""
-"<![CDATA[sess.createSQLQuery(\"SELECT NAME, BIRTHDATE FROM CATS\")\n"
-"        .setResultTransformer(Transformers.aliasToBean(CatDTO.class))]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:357
 #, no-c-format
 msgid "a result transformer"
-msgstr "结果转换器(result transformer)"
+msgstr "结果转换器(result transformer)"
 
 #. Tag: para
-#: query_sql.xml:361
 #, no-c-format
 msgid ""
 "The above query will return a list of <literal>CatDTO</literal> which has "
 "been instantiated and injected the values of NAME and BIRTHNAME into its "
 "corresponding properties or fields."
 msgstr ""
-"上面的查询将会返回<literal>CatDTO</literal>的列表,它将被实例化并且将NAME和"
-"BIRTHDAY的值注射入对应的属性或者字段。"
+"上面的查询将会返回 <literal>CatDTO</literal> 的列表,它将被实例化并且将 NAME "
+"和 BIRTHDAY 的值注射入对应的属性或者字段。"
 
 #. Tag: title
-#: query_sql.xml:368
 #, no-c-format
 msgid "Handling inheritance"
 msgstr "处理继承(Handling inheritance)"
 
 #. Tag: para
-#: query_sql.xml:370
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Native SQL queries which query for entities that are mapped as part of an "
 "inheritance must include all properties for the baseclass and all its "
 "subclasses."
 msgstr ""
-"原生SQL查询假若其查询结果实体是继承树中的一部分,它必须包含基类和所有子类的所"
-"有属性。"
+"原生 SQL 查询假若其查询结果实体是继承树中的一部分,它必须包含基类和所有子类的"
+"所有属性。 "
 
 #. Tag: title
-#: query_sql.xml:376
 #, no-c-format
 msgid "Parameters"
 msgstr "参数(Parameters)"
 
 #. Tag: para
-#: query_sql.xml:378
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Native SQL queries support positional as well as named parameters:"
-msgstr "原生查询支持位置参数和命名参数:"
+msgstr "原生查询支持位置参数和命名参数: "
 
-#. Tag: programlisting
-#: query_sql.xml:381
-#, no-c-format
-msgid ""
-"<![CDATA[Query query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME "
-"like ?\").addEntity(Cat.class);\n"
-"List pusList = query.setString(0, \"Pus%\").list();\n"
-"     \n"
-"query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME like :name\")."
-"addEntity(Cat.class);\n"
-"List pusList = query.setString(\"name\", \"Pus%\").list();          ]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:389
 #, no-c-format
 msgid "Named SQL queries"
-msgstr "命名SQL查询"
+msgstr "命名 SQL 查询"
 
 #. Tag: para
-#: query_sql.xml:391
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Named SQL queries can be defined in the mapping document and called in "
 "exactly the same way as a named HQL query. In this case, you do "
 "<emphasis>not</emphasis> need to call <literal>addEntity()</literal>."
 msgstr ""
-"可以在映射文档中定义查询的名字,然后就可以象调用一个命名的HQL查询一样直接调用"
-"命名SQL查询.在这种情况下,我们<emphasis>不</emphasis> 需要调用"
-"<literal>addEntity()</literal>方法."
+"可以在映射文档中定义查询的名字,然后就可以象调用一个命名的 HQL 查询一样直接调"
+"用命名 SQL 查询.在这种情况下,我们<emphasis>不</emphasis> 需要调用 "
+"<literal>addEntity()</literal> 方法。 "
 
-#. Tag: programlisting
-#: query_sql.xml:396
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"persons\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex}\n"
-"    FROM PERSON person\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_sql.xml:398
-#, no-c-format
-msgid ""
-"<![CDATA[List people = sess.getNamedQuery(\"persons\")\n"
-"    .setString(\"namePattern\", namePattern)\n"
-"    .setMaxResults(50)\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:400
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>&lt;return-join&gt;</literal> element is use to join "
 "associations and the <literal>&lt;load-collection&gt;</literal> element is "
 "used to define queries which initialize collections,"
 msgstr ""
-"<literal>&lt;return-join&gt;</literal>和 <literal>&lt;load-collection&gt;</"
-"literal> 元素是用来连接关联以及将查询定义为预先初始化各个集合的。"
+"<literal>&lt;return-join&gt;</literal> 和 <literal>&lt;load-collection&gt;</"
+"literal> 元素是用来连接关联以及将查询定义为预先初始化各个集合的。 "
 
-#. Tag: programlisting
-#: query_sql.xml:404
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"personsWith\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex},\n"
-"           address.STREET AS {address.street},\n"
-"           address.CITY AS {address.city},\n"
-"           address.STATE AS {address.state},\n"
-"           address.ZIP AS {address.zip}\n"
-"    FROM PERSON person\n"
-"    JOIN ADDRESS address\n"
-"        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:406
 #, no-c-format
 msgid ""
 "A named SQL query may return a scalar value. You must declare the column "
 "alias and Hibernate type using the <literal>&lt;return-scalar&gt;</literal> "
 "element:"
 msgstr ""
-"一个命名查询可能会返回一个标量值.你必须使用<literal>&lt;return-scalar&gt;</"
-"literal>元素来指定字段的别名和 Hibernate类型"
+"一个命名查询可能会返回一个标量值。你必须使用 <literal>&lt;return-scalar&gt;</"
+"literal> 元素来指定字段的别名和 Hibernate 类型:"
 
-#. Tag: programlisting
-#: query_sql.xml:410
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-"    <return-scalar column=\"name\" type=\"string\"/>\n"
-"    <return-scalar column=\"age\" type=\"long\"/>\n"
-"    SELECT p.NAME AS name,\n"
-"           p.AGE AS age,\n"
-"    FROM PERSON p WHERE p.NAME LIKE 'Hiber%'\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:412
-#, fuzzy, no-c-format
-msgid ""
 "You can externalize the resultset mapping information in a <literal>&lt;"
 "resultset&gt;</literal> element which will allow you to either reuse them "
 "across several named queries or through the <literal>setResultSetMapping()</"
 "literal> API."
 msgstr ""
-"你可以把结果集映射的信息放在外部的<literal>&lt;resultset&gt;</literal>元素"
-"中,这样就可以在多个命名查询间,或者通过<literal>setResultSetMapping()</"
-"literal>API来访问。(此处原文即存疑。原文为:You can externalize the "
-"resultset mapping informations in a <literal>&lt;resultset&gt;</literal> "
-"element to either reuse them accross several named queries or through the "
-"<literal>setResultSetMapping()</literal> API.)"
+"你可以把结果集映射的信息放在外部的 <literal>&lt;resultset&gt;</literal> 元素"
+"中,这样就可以在多个命名查询间,或者通过 <literal>setResultSetMapping()</"
+"literal> API 来访问。 "
 
-#. Tag: programlisting
-#: query_sql.xml:417
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<resultset name=\"personAddress\">\n"
-"    <return alias=\"person\" class=\"eg.Person\"/>\n"
-"    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
-"</resultset>\n"
-"\n"
-"<sql-query name=\"personsWith\" resultset-ref=\"personAddress\">\n"
-"    SELECT person.NAME AS {person.name},\n"
-"           person.AGE AS {person.age},\n"
-"           person.SEX AS {person.sex},\n"
-"           address.STREET AS {address.street},\n"
-"           address.CITY AS {address.city},\n"
-"           address.STATE AS {address.state},\n"
-"           address.ZIP AS {address.zip}\n"
-"    FROM PERSON person\n"
-"    JOIN ADDRESS address\n"
-"        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
-"    WHERE person.NAME LIKE :namePattern\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:419
-#, fuzzy, no-c-format
-msgid ""
 "You can, alternatively, use the resultset mapping information in your hbm "
 "files directly in java code."
-msgstr "另外,你可以在java代码中直接使用hbm文件中的结果集定义信息。"
+msgstr "另外,你可以在 java 代码中直接使用 hbm 文件中的结果集定义信息。 "
 
-#. Tag: programlisting
-#: query_sql.xml:422
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = sess.createSQLQuery(\n"
-"        \"select {cat.*}, {kitten.*} from cats cat, cats kitten where kitten."
-"mother = cat.id\"\n"
-"    )\n"
-"    .setResultSetMapping(\"catAndKitten\")\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:425
 #, no-c-format
 msgid "Using return-property to explicitly specify column/alias names"
-msgstr "使用return-property来明确地指定字段/别名"
+msgstr "使用 return-property 来明确地指定字段/别名"
 
 #. Tag: para
-#: query_sql.xml:428
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can explicitly tell Hibernate what column aliases to use with "
 "<literal>&lt;return-property&gt;</literal>, instead of using the <literal>{}"
 "</literal>-syntax to let Hibernate inject its own aliases.For example:"
 msgstr ""
-"使用<literal>&lt;return-property&gt;</literal>你可以明确的告诉Hibernate使用哪"
-"些字段别名,这取代了使用<literal>{}</literal>-语法 来让Hibernate注入它自己的别"
-"名."
+"使用 <literal>&lt;return-property&gt;</literal> 你可以明确的告诉 Hibernate 使"
+"用哪些字段别名,这取代了使用 <literal>{}</literal>-语法 来让 Hibernate 注入它"
+"自己的别名。例如:"
 
-#. Tag: programlisting
-#: query_sql.xml:433
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"mySqlQuery\">\n"
-"    <return alias=\"person\" class=\"eg.Person\">\n"
-"        <return-property name=\"name\" column=\"myName\"/>\n"
-"        <return-property name=\"age\" column=\"myAge\"/>\n"
-"        <return-property name=\"sex\" column=\"mySex\"/>\n"
-"    </return>\n"
-"    SELECT person.NAME AS myName,\n"
-"           person.AGE AS myAge,\n"
-"           person.SEX AS mySex,\n"
-"    FROM PERSON person WHERE person.NAME LIKE :name\n"
-"</sql-query>\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:435
-#, fuzzy, no-c-format
-msgid ""
 "<literal>&lt;return-property&gt;</literal> also works with multiple columns. "
 "This solves a limitation with the <literal>{}</literal>-syntax which cannot "
 "allow fine grained control of multi-column properties."
 msgstr ""
-"<literal>&lt;return-property&gt;</literal>也可用于多个字段,它解决了使用"
-"<literal>{}</literal>-语法不能细粒度控制多个字段的限制"
+"<literal>&lt;return-property&gt;</literal> 也可用于多个字段,它解决了使用 "
+"<literal>{}</literal>-语法不能细粒度控制多个字段的限制。 "
 
-#. Tag: programlisting
-#: query_sql.xml:440
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"organizationCurrentEmployments\">\n"
-"    <return alias=\"emp\" class=\"Employment\">\n"
-"        <return-property name=\"salary\">\n"
-"            <return-column name=\"VALUE\"/>\n"
-"            <return-column name=\"CURRENCY\"/>\n"
-"        </return-property>\n"
-"        <return-property name=\"endDate\" column=\"myEndDate\"/>\n"
-"    </return>\n"
-"        SELECT EMPLOYEE AS {emp.employee}, EMPLOYER AS {emp.employer},\n"
-"        STARTDATE AS {emp.startDate}, ENDDATE AS {emp.endDate},\n"
-"        REGIONCODE as {emp.regionCode}, EID AS {emp.id}, VALUE, CURRENCY\n"
-"        FROM EMPLOYMENT\n"
-"        WHERE EMPLOYER = :id AND ENDDATE IS NULL\n"
-"        ORDER BY STARTDATE ASC\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:442
-#, fuzzy, no-c-format
-msgid ""
 "In this example <literal>&lt;return-property&gt;</literal> was used in "
 "combination with the <literal>{}</literal>-syntax for injection. This allows "
 "users to choose how they want to refer column and properties."
 msgstr ""
-"注意在这个例子中,我们使用了<literal>&lt;return-property&gt;</literal>结合"
-"<literal>{}</literal>的注入语法. 允许用户来选择如何引用字段以及属性."
+"注意在这个例子中,我们使用了 <literal>&lt;return-property&gt;</literal> 结合 "
+"<literal>{}</literal> 的注入语法。允许用户来选择如何引用字段以及属性。 "
 
 #. Tag: para
-#: query_sql.xml:447
 #, no-c-format
 msgid ""
 "If your mapping has a discriminator you must use <literal>&lt;return-"
 "discriminator&gt;</literal> to specify the discriminator column."
 msgstr ""
-"如果你映射一个识别器(discriminator),你必须使用<literal>&lt;return-"
-"discriminator&gt;</literal> 来指定识别器字段"
+"如果你映射一个识别器(discriminator),你必须使用 <literal>&lt;return-"
+"discriminator&gt;</literal> 来指定识别器字段。"
 
 #. Tag: title
-#: query_sql.xml:453
 #, no-c-format
 msgid "Using stored procedures for querying"
 msgstr "使用存储过程来查询"
 
 #. Tag: para
-#: query_sql.xml:455
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate3 provides support for queries via stored procedures and functions. "
 "Most of the following documentation is equivalent for both. The stored "
@@ -1036,75 +684,33 @@
 "able to work with Hibernate. An example of such a stored function in Oracle "
 "9 and higher is as follows:"
 msgstr ""
-"Hibernate 3引入了对存储过程查询(stored procedure)和函数(function)的支持.以下"
-"的说明中,这二者一般都适用。 存储过程/函数必须返回一个结果集,作为Hibernate能"
-"够使用的第一个外部参数. 下面是一个Oracle9和更高版本的存储过程例子."
+"Hibernate 3 引入了对存储过程查询(stored procedure)和函数(function)的支"
+"持。以下的说明中,这二者一般都适用。存储过程/函数必须返回一个结果集,作为 "
+"Hibernate 能够使用的第一个外部参数。下面是一个 Oracle9 和更高版本的存储过程例"
+"子。 "
 
-#. Tag: programlisting
-#: query_sql.xml:461
-#, no-c-format
-msgid ""
-"<![CDATA[CREATE OR REPLACE FUNCTION selectAllEmployments\n"
-"    RETURN SYS_REFCURSOR\n"
-"AS\n"
-"    st_cursor SYS_REFCURSOR;\n"
-"BEGIN\n"
-"    OPEN st_cursor FOR\n"
-" SELECT EMPLOYEE, EMPLOYER,\n"
-" STARTDATE, ENDDATE,\n"
-" REGIONCODE, EID, VALUE, CURRENCY\n"
-" FROM EMPLOYMENT;\n"
-"      RETURN  st_cursor;\n"
-" END;]]>"
-msgstr ""
-
 #. Tag: para
-#: query_sql.xml:463
 #, no-c-format
 msgid "To use this query in Hibernate you need to map it via a named query."
-msgstr "在Hibernate里要要使用这个查询,你需要通过命名查询来映射它."
+msgstr "在 Hibernate 里要要使用这个查询,你需要通过命名查询来映射它。"
 
-#. Tag: programlisting
-#: query_sql.xml:466
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"selectAllEmployees_SP\" callable=\"true\">\n"
-"    <return alias=\"emp\" class=\"Employment\">\n"
-"        <return-property name=\"employee\" column=\"EMPLOYEE\"/>\n"
-"        <return-property name=\"employer\" column=\"EMPLOYER\"/>\n"
-"        <return-property name=\"startDate\" column=\"STARTDATE\"/>\n"
-"        <return-property name=\"endDate\" column=\"ENDDATE\"/>\n"
-"        <return-property name=\"regionCode\" column=\"REGIONCODE\"/>\n"
-"        <return-property name=\"id\" column=\"EID\"/>\n"
-"        <return-property name=\"salary\">\n"
-"            <return-column name=\"VALUE\"/>\n"
-"            <return-column name=\"CURRENCY\"/>\n"
-"        </return-property>\n"
-"    </return>\n"
-"    { ? = call selectAllEmployments() }\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:468
-#, fuzzy, no-c-format
-msgid ""
 "Stored procedures currently only return scalars and entities. <literal>&lt;"
 "return-join&gt;</literal> and <literal>&lt;load-collection&gt;</literal> are "
 "not supported."
 msgstr ""
-"注意存储过程当前仅仅返回标量和实体.现在不支持<literal>&lt;return-join&gt;</"
-"literal>和<literal>&lt;load-collection&gt;</literal>"
+"注意存储过程当前仅仅返回标量和实体现在。不支持 <literal>&lt;return-join&gt;</"
+"literal> 和 <literal>&lt;load-collection&gt;</literal>。 "
 
 #. Tag: title
-#: query_sql.xml:473
 #, no-c-format
 msgid "Rules/limitations for using stored procedures"
 msgstr "使用存储过程的规则和限制"
 
 #. Tag: para
-#: query_sql.xml:475
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You cannot use stored procedures with Hibernate unless you follow some "
 "procedure/function rules. If they do not follow those rules they are not "
@@ -1113,42 +719,38 @@
 "different for each database, since database vendors have different stored "
 "procedure semantics/syntax."
 msgstr ""
-"为了在Hibernate中使用存储过程,你必须遵循一些规则.不遵循这些规则的存储过程将不"
-"可用.如果你仍然想要使用他们, 你必须通过<literal>session.connection()</"
-"literal>来执行他们.这些规则针对于不同的数据库.因为数据库 提供商有各种不同的存"
-"储过程语法和语义."
+"为了在 Hibernate 中使用存储过程,你必须遵循一些规则。不遵循这些规则的存储过程"
+"将不可用。如果你仍然想使用他们,你必须通过 <literal>session.connection()</"
+"literal> 来执行他们。这些规则针对于不同的数据库。因为数据库提供商有各种不同的"
+"存储过程语法和语义。 "
 
 #. Tag: para
-#: query_sql.xml:482
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Stored procedure queries cannot be paged with <literal>setFirstResult()/"
 "setMaxResults()</literal>."
 msgstr ""
-"对存储过程进行的查询无法使用<literal>setFirstResult()/setMaxResults()</"
-"literal>进行分页。"
+"对存储过程进行的查询无法使用 <literal>setFirstResult()/setMaxResults()</"
+"literal> 进行分页。 "
 
 #. Tag: para
-#: query_sql.xml:485
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The recommended call form is standard SQL92: <literal>{ ? = call functionName"
 "(&lt;parameters&gt;) }</literal> or <literal>{ ? = call procedureName(&lt;"
 "parameters&gt;}</literal>. Native call syntax is not supported."
 msgstr ""
-"建议采用的调用方式是标准SQL92: <literal>{ ? = call functionName(&lt;"
+"建议采用的调用方式是标准 SQL92: <literal>{ ? = call functionName(&lt;"
 "parameters&gt;) }</literal> 或者 <literal>{ ? = call procedureName(&lt;"
-"parameters&gt;}</literal>.原生调用语法不被支持。"
+"parameters&gt;) }</literal>。原生调用语法不被支持。 "
 
 #. Tag: para
-#: query_sql.xml:490
 #, no-c-format
 msgid "For Oracle the following rules apply:"
-msgstr "对于Oracle有如下规则:"
+msgstr "对于 Oracle 有如下规则:"
 
 #. Tag: para
-#: query_sql.xml:494
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A function must return a result set. The first parameter of a procedure must "
 "be an <literal>OUT</literal> that returns a result set. This is done by "
@@ -1156,124 +758,91 @@
 "you need to define a <literal>REF CURSOR</literal> type. See Oracle "
 "literature for further information."
 msgstr ""
-"函数必须返回一个结果集。存储过程的第一个参数必须是<literal>OUT</literal>,它"
-"返回一个结果集。这是通过Oracle 9或10的<literal>SYS_REFCURSOR</literal>类型来"
-"完成的。在Oracle中你需要定义一个<literal>REF CURSOR</literal>类型,参见Oracle"
-"的手册。"
+"函数必须返回一个结果集。存储过程的第一个参数必须是 <literal>OUT</literal>,它"
+"返回一个结果集。这是通过 Oracle 9 或 10 的 <literal>SYS_REFCURSOR</literal> "
+"类型来完成的。在 Oracle 中你需要定义一个 <literal>REF CURSOR</literal> 类型,"
+"参见 Oracle 的手册。 "
 
 #. Tag: para
-#: query_sql.xml:503
 #, no-c-format
 msgid "For Sybase or MS SQL server the following rules apply:"
-msgstr "对于Sybase或者MS SQL server有如下规则:"
+msgstr "对于 Sybase 或者 MS SQL server 有如下规则:"
 
 #. Tag: para
-#: query_sql.xml:507
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The procedure must return a result set. Note that since these servers can "
 "return multiple result sets and update counts, Hibernate will iterate the "
 "results and take the first result that is a result set as its return value. "
 "Everything else will be discarded."
 msgstr ""
-"存储过程必须返回一个结果集。.注意这些servers可能返回多个结果集以及更新的数目."
-"Hibernate将取出第一条结果集作为它的返回值, 其他将被丢弃。"
+"存储过程必须返回一个结果集。注意这些 servers 可能返回多个结果集以及更新的数"
+"目。Hibernate 将取出第一条结果集作为它的返回值,其他将被丢弃。 "
 
 #. Tag: para
-#: query_sql.xml:515
 #, no-c-format
 msgid ""
 "If you can enable <literal>SET NOCOUNT ON</literal> in your procedure it "
 "will probably be more efficient, but this is not a requirement."
 msgstr ""
-"如果你能够在存储过程里设定<literal>SET NOCOUNT ON</literal>,这可能会效率更"
+"如果你能够在存储过程里设定 <literal>SET NOCOUNT ON</literal>,这可能会效率更"
 "高,但这不是必需的。"
 
 #. Tag: title
-#: query_sql.xml:525
 #, no-c-format
 msgid "Custom SQL for create, update and delete"
-msgstr "定制SQL用来create,update和delete"
+msgstr "定制 SQL 用来 create,update 和 delete"
 
 #. Tag: para
-#: query_sql.xml:527
 #, no-c-format
 msgid ""
-"Hibernate3 can use custom SQL statements for create, update, and delete "
-"operations. The class and collection persisters in Hibernate already contain "
-"a set of configuration time generated strings (insertsql, deletesql, "
-"updatesql etc.). The mapping tags <literal>&lt;sql-insert&gt;</literal>, "
-"<literal>&lt;sql-delete&gt;</literal>, and <literal>&lt;sql-update&gt;</"
-"literal> override these strings:"
+"Hibernate3 can use custom SQL for create, update, and delete operations. The "
+"SQL can be overridden at the statement level or inidividual column level. "
+"This section describes statement overrides. For columns, see <xref linkend="
+"\"mapping-column-read-and-write\" />."
 msgstr ""
-"Hibernate3能够使用定制的SQL语句来执行create,update和delete操作。在Hibernate"
-"中,持久化的类和集合已经 包含了一套配置期产生的语句(insertsql, deletesql, "
-"updatesql等等),这些映射标记 <literal>&lt;sql-insert&gt;</literal>, "
-"<literal>&lt;sql-delete&gt;</literal>, and <literal>&lt;sql-update&gt;</"
-"literal>重载了 这些语句。"
 
-#. Tag: programlisting
-#: query_sql.xml:535
-#, no-c-format
+#. Tag: para
+#, fuzzy, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <sql-insert>INSERT INTO PERSON (NAME, ID) VALUES ( UPPER(?), ? )</sql-"
-"insert>\n"
-"    <sql-update>UPDATE PERSON SET NAME=UPPER(?) WHERE ID=?</sql-update>\n"
-"    <sql-delete>DELETE FROM PERSON WHERE ID=?</sql-delete>\n"
-"</class>]]>"
+"The class and collection persisters in Hibernate already contain a set of "
+"configuration time generated strings (insertsql, deletesql, updatesql etc.). "
+"The mapping tags <literal>&lt;sql-insert&gt;</literal>, <literal>&lt;sql-"
+"delete&gt;</literal>, and <literal>&lt;sql-update&gt;</literal> override "
+"these strings:"
 msgstr ""
+"Hibernate3 能够使用定制的 SQL 语句来执行 create,update 和 delete 操作。在 "
+"Hibernate 中,持久化的类和集合已经包含了一套配置期产生的语句(insertsql,"
+"deletesql,updatesql 等等),这些映射标记 <literal>&lt;sql-insert&gt;</"
+"literal>,<literal>&lt;sql-delete&gt;</literal> 和 <literal>&lt;sql-"
+"update&gt;</literal> 重载了这些语句。"
 
 #. Tag: para
-#: query_sql.xml:537
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The SQL is directly executed in your database, so you can use any dialect "
 "you like. This will reduce the portability of your mapping if you use "
 "database specific SQL."
 msgstr ""
-"这些SQL直接在你的数据库里执行,所以你可以自由的使用你喜欢的任意语法。但如果你"
-"使用数据库特定的语法, 这当然会降低你映射的可移植性。"
+"这些 SQL 直接在你的数据库里执行,所以你可以自由的使用你喜欢的任意语法。但如果"
+"你使用数据库特定的语法,这当然会降低你映射的可移植性。 "
 
 #. Tag: para
-#: query_sql.xml:541
 #, no-c-format
 msgid ""
 "Stored procedures are supported if the <literal>callable</literal> attribute "
 "is set:"
-msgstr "如果设定<literal>callable</literal>,则能够支持存储过程了。"
+msgstr "如果设定 <literal>callable</literal>,则能够支持存储过程了。"
 
-#. Tag: programlisting
-#: query_sql.xml:544
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <sql-insert callable=\"true\">{call createPerson (?, ?)}</sql-insert>\n"
-"    <sql-delete callable=\"true\">{? = call deletePerson (?)}</sql-delete>\n"
-"    <sql-update callable=\"true\">{? = call updatePerson (?, ?)}</sql-"
-"update>\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:546
-#, fuzzy, no-c-format
-msgid ""
 "The order of the positional parameters is vital, as they must be in the same "
 "sequence as Hibernate expects them."
-msgstr "参数的位置顺序是非常重要的,他们必须和Hibernate所期待的顺序相同。"
+msgstr "参数的位置顺序是非常重要的,他们必须和 Hibernate 所期待的顺序相同。 "
 
 #. Tag: para
-#: query_sql.xml:549
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can view the expected order by enabling debug logging for the "
 "<literal>org.hibernate.persister.entity</literal> level. With this level "
@@ -1282,145 +851,720 @@
 "your custom SQL in the mapping files, as this will override the Hibernate "
 "generated static SQL."
 msgstr ""
-"你能够通过设定日志调试级别为<literal>org.hiberante.persister.entity</"
-"literal>,来查看Hibernate所期待的顺序。在这个级别下, Hibernate将会打印出"
-"create,update和delete实体的静态SQL。(如果想看到预计的顺序。记得不要将定制SQL"
-"包含在映射文件里, 因为他们会重载Hibernate生成的静态SQL。)"
+"你能够通过设定日志调试级别为 <literal>org.hiberante.persister.entity</"
+"literal> 来查看 Hibernate 所期待的顺序。在这个级别下,Hibernate 将会打印出"
+"create,update 和 delete 实体的静态 SQL。(如果想看到预计的顺序。记得不要将定"
+"制 SQL 包含在映射文件里,因为他们会重载 Hibernate 生成的静态 SQL。) "
 
 #. Tag: para
-#: query_sql.xml:556
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The stored procedures are in most cases required to return the number of "
 "rows inserted, updated and deleted, as Hibernate has some runtime checks for "
 "the success of the statement. Hibernate always registers the first statement "
 "parameter as a numeric output parameter for the CUD operations:"
 msgstr ""
-"在大多数情况下(最好这么做),存储过程需要返回插入/更新/删除的行数,因为"
-"Hibernate对语句的成功执行有些运行时的检查。 Hibernate常会把进行CUD操作的语句"
-"的第一个参数注册为一个数值型输出参数。"
+"在大多数情况下(最好这么做),存储过程需要返回插入/更新/删除的行数,因为 "
+"Hibernate 对语句的成功执行有些运行时的检查。Hibernate 常会把进行 CUD 操作的语"
+"句的第一个参数注册为一个数值型输出参数。 "
 
-#. Tag: programlisting
-#: query_sql.xml:562
-#, no-c-format
-msgid ""
-"<![CDATA[CREATE OR REPLACE FUNCTION updatePerson (uid IN NUMBER, uname IN "
-"VARCHAR2)\n"
-"    RETURN NUMBER IS\n"
-"BEGIN\n"
-"\n"
-"    update PERSON\n"
-"    set\n"
-"        NAME = uname,\n"
-"    where\n"
-"        ID = uid;\n"
-"\n"
-"    return SQL%ROWCOUNT;\n"
-"\n"
-"END updatePerson;]]>"
-msgstr ""
-
 #. Tag: title
-#: query_sql.xml:566
 #, no-c-format
 msgid "Custom SQL for loading"
-msgstr "定制装载SQL"
+msgstr "定制装载 SQL"
 
 #. Tag: para
-#: query_sql.xml:568
-#, fuzzy, no-c-format
-msgid "You can also declare your own SQL (or HQL) queries for entity loading:"
-msgstr "你可能需要声明你自己的SQL(或HQL)来装载实体"
-
-#. Tag: programlisting
-#: query_sql.xml:571
 #, no-c-format
 msgid ""
-"<![CDATA[<sql-query name=\"person\">\n"
-"    <return alias=\"pers\" class=\"Person\" lock-mode=\"upgrade\"/>\n"
-"    SELECT NAME AS {pers.name}, ID AS {pers.id}\n"
-"    FROM PERSON\n"
-"    WHERE ID=?\n"
-"    FOR UPDATE\n"
-"</sql-query>]]>"
+"You can also declare your own SQL (or HQL) queries for entity loading. As "
+"with inserts, updates, and deletes, this can be done at the individual "
+"column level as described in <xref linkend=\"mapping-column-read-and-write"
+"\" /> or at the statement level. Here is an example of a statement level "
+"override:"
 msgstr ""
 
 #. Tag: para
-#: query_sql.xml:573
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is just a named query declaration, as discussed earlier. You can "
 "reference this named query in a class mapping:"
-msgstr "这只是一个前面讨论过的命名查询声明,你可以在类映射里引用这个命名查询。"
-
-#. Tag: programlisting
-#: query_sql.xml:576
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Person\">\n"
-"    <id name=\"id\">\n"
-"        <generator class=\"increment\"/>\n"
-"    </id>\n"
-"    <property name=\"name\" not-null=\"true\"/>\n"
-"    <loader query-ref=\"person\"/>\n"
-"</class>]]>"
 msgstr ""
+"这只是一个前面讨论过的命名查询声明,你可以在类映射里引用这个命名查询。 "
 
 #. Tag: para
-#: query_sql.xml:578
 #, no-c-format
 msgid "This even works with stored procedures."
 msgstr "这也可以用于存储过程"
 
 #. Tag: para
-#: query_sql.xml:580
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can even define a query for collection loading:"
-msgstr "你甚至可以定一个用于集合装载的查询:"
+msgstr "你甚至可以定一个用于集合装载的查询: "
 
-#. Tag: programlisting
-#: query_sql.xml:582
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<set name=\"employments\" inverse=\"true\">\n"
-"    <key/>\n"
-"    <one-to-many class=\"Employment\"/>\n"
-"    <loader query-ref=\"employments\"/>\n"
-"</set>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: query_sql.xml:584
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"employments\">\n"
-"    <load-collection alias=\"emp\" role=\"Person.employments\"/>\n"
-"    SELECT {emp.*}\n"
-"    FROM EMPLOYMENT emp\n"
-"    WHERE EMPLOYER = :id\n"
-"    ORDER BY STARTDATE ASC, EMPLOYEE ASC\n"
-"</sql-query>]]>"
-msgstr ""
-
-#. Tag: para
-#: query_sql.xml:586
-#, fuzzy, no-c-format
-msgid ""
 "You can also define an entity loader that loads a collection by join "
 "fetching:"
-msgstr "你甚至还可以定义一个实体装载器,它通过连接抓取装载一个集合:"
+msgstr "你甚至还可以定义一个实体装载器,它通过连接抓取装载一个集合: "
 
-#. Tag: programlisting
-#: query_sql.xml:589
-#, no-c-format
-msgid ""
-"<![CDATA[<sql-query name=\"person\">\n"
-"    <return alias=\"pers\" class=\"Person\"/>\n"
-"    <return-join alias=\"emp\" property=\"pers.employments\"/>\n"
-"    SELECT NAME AS {pers.*}, {emp.*}\n"
-"    FROM PERSON pers\n"
-"    LEFT OUTER JOIN EMPLOYMENT emp\n"
-"        ON pers.ID = emp.PERSON_ID\n"
-"    WHERE ID=?\n"
-"</sql-query>]]>"
-msgstr ""
+#~ msgid ""
+#~ "You can also declare your own SQL (or HQL) queries for entity loading:"
+#~ msgstr "你可能需要声明你自己的 SQL(或 HQL)来装载实体:"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").list();\n"
+#~ "sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").list();\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT * FROM CATS\").list();\n"
+#~ "sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
+#~ " .addScalar(\"ID\", Hibernate.LONG)\n"
+#~ " .addScalar(\"NAME\", Hibernate.STRING)\n"
+#~ " .addScalar(\"BIRTHDATE\", Hibernate.DATE)\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
+#~ " .addScalar(\"ID\", Hibernate.LONG)\n"
+#~ " .addScalar(\"NAME\", Hibernate.STRING)\n"
+#~ " .addScalar(\"BIRTHDATE\", Hibernate.DATE)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
+#~ " .addScalar(\"ID\", Hibernate.LONG)\n"
+#~ " .addScalar(\"NAME\")\n"
+#~ " .addScalar(\"BIRTHDATE\")\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT * FROM CATS\")\n"
+#~ " .addScalar(\"ID\", Hibernate.LONG)\n"
+#~ " .addScalar(\"NAME\")\n"
+#~ " .addScalar(\"BIRTHDATE\")"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT * FROM CATS\").addEntity(Cat."
+#~ "class);\n"
+#~ "sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").addEntity"
+#~ "(Cat.class);\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT * FROM CATS\").addEntity(Cat.class);\n"
+#~ "sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE FROM CATS\").addEntity"
+#~ "(Cat.class);"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, DOG_ID FROM "
+#~ "CATS\").addEntity(Cat.class);\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, DOG_ID FROM CATS\")."
+#~ "addEntity(Cat.class);"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT c.ID, NAME, BIRTHDATE, DOG_ID, "
+#~ "D_ID, D_NAME FROM CATS c, DOGS d WHERE c.DOG_ID = d.D_ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addJoin(\"cat.dog\");\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT c.ID, NAME, BIRTHDATE, DOG_ID, D_ID, D_NAME "
+#~ "FROM CATS c, DOGS d \n"
+#~ "    WHERE c.DOG_ID = d.D_ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addJoin(\"cat.dog\");"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, D_ID, D_NAME, "
+#~ "CAT_ID FROM CATS c, DOGS d WHERE c.ID = d.CAT_ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addJoin(\"cat.dogs\");\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT ID, NAME, BIRTHDATE, D_ID, D_NAME, CAT_ID "
+#~ "FROM CATS c, DOGS d\n"
+#~ "    WHERE c.ID = d.CAT_ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addJoin(\"cat.dogs\");"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT c.*, m.*  FROM CATS c, CATS m WHERE "
+#~ "c.MOTHER_ID = c.ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addEntity(\"mother\", Cat.class)\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT c.*, m.*  FROM CATS c, CATS m WHERE c."
+#~ "MOTHER_ID = c.ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addEntity(\"mother\", Cat.class)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT {cat.*}, {mother.*}  FROM CATS c, "
+#~ "CATS m WHERE c.MOTHER_ID = c.ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addEntity(\"mother\", Cat.class)\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT {cat.*}, {mother.*}  FROM CATS c, CATS m "
+#~ "WHERE c.MOTHER_ID = c.ID\")\n"
+#~ " .addEntity(\"cat\", Cat.class)\n"
+#~ " .addEntity(\"mother\", Cat.class)"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[String sql = \"SELECT ID as {c.id}, NAME as {c.name}, \" + \n"
+#~ "         \"BIRTHDATE as {c.birthDate}, MOTHER_ID as {c.mother}, {mother."
+#~ "*} \" +\n"
+#~ "         \"FROM CAT_LOG c, CAT_LOG m WHERE {c.mother} = c.ID\";\n"
+#~ "\n"
+#~ "List loggedCats = sess.createSQLQuery(sql)\n"
+#~ "        .addEntity(\"cat\", Cat.class)\n"
+#~ "        .addEntity(\"mother\", Cat.class).list()\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "String sql = \"SELECT ID as {c.id}, NAME as {c.name}, \" + \n"
+#~ "         \"BIRTHDATE as {c.birthDate}, MOTHER_ID as {c.mother}, {mother."
+#~ "*} \" +\n"
+#~ "         \"FROM CAT_LOG c, CAT_LOG m WHERE {c.mother} = c.ID\";\n"
+#~ "\n"
+#~ "List loggedCats = sess.createSQLQuery(sql)\n"
+#~ "        .addEntity(\"cat\", Cat.class)\n"
+#~ "        .addEntity(\"mother\", Cat.class).list()"
+
+#, fuzzy
+#~ msgid "A_NAME as {item.name}"
+#~ msgstr "<literal>A_NAME as {item.name}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].class}"
+#~ msgstr "<literal>{[aliasname].class}</literal>"
+
+#, fuzzy
+#~ msgid "DISC as {item.class}"
+#~ msgstr "<literal>DISC as {item.class}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].*}"
+#~ msgstr "<literal>{[aliasname].*}</literal>"
+
+#~ msgid "{item.*}"
+#~ msgstr "{item.*}"
+
+#, fuzzy
+#~ msgid "{[aliasname].key}"
+#~ msgstr "<literal>{[aliasname].key}</literal>"
+
+#, fuzzy
+#~ msgid "ORGID as {coll.key}"
+#~ msgstr "<literal>ORGID as {coll.key}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].id}"
+#~ msgstr "<literal>{[aliasname].id}</literal>"
+
+#, fuzzy
+#~ msgid "EMPID as {coll.id}"
+#~ msgstr "<literal>EMPID as {coll.id}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].element}"
+#~ msgstr "<literal>{[aliasname].element}</literal>"
+
+#, fuzzy
+#~ msgid "XID as {coll.element}"
+#~ msgstr "<literal>XID as {coll.element}</literal>"
+
+#, fuzzy
+#~ msgid "NAME as {coll.element.name}"
+#~ msgstr "<literal>NAME as {coll.element.name}</literal>"
+
+#, fuzzy
+#~ msgid "{[aliasname].element.*}"
+#~ msgstr "<literal>{[aliasname].element.*}</literal>"
+
+#, fuzzy
+#~ msgid "{coll.element.*}"
+#~ msgstr "{coll.*}"
+
+#~ msgid "{coll.*}"
+#~ msgstr "{coll.*}"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[sess.createSQLQuery(\"SELECT NAME, BIRTHDATE FROM CATS\")\n"
+#~ "        .setResultTransformer(Transformers.aliasToBean(CatDTO.class))]]>"
+#~ msgstr ""
+#~ "sess.createSQLQuery(\"SELECT NAME, BIRTHDATE FROM CATS\")\n"
+#~ "        .setResultTransformer(Transformers.aliasToBean(CatDTO.class))"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Query query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE "
+#~ "NAME like ?\").addEntity(Cat.class);\n"
+#~ "List pusList = query.setString(0, \"Pus%\").list();\n"
+#~ "     \n"
+#~ "query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME like :name\")."
+#~ "addEntity(Cat.class);\n"
+#~ "List pusList = query.setString(\"name\", \"Pus%\").list();          ]]>"
+#~ msgstr ""
+#~ "Query query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME like ?"
+#~ "\").addEntity(Cat.class);\n"
+#~ "List pusList = query.setString(0, \"Pus&#37;\").list();\n"
+#~ "     \n"
+#~ "query = sess.createSQLQuery(\"SELECT * FROM CATS WHERE NAME like :name\")."
+#~ "addEntity(Cat.class);\n"
+#~ "List pusList = query.setString(\"name\", \"Pus&#37;\").list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"persons\">\n"
+#~ "    <return alias=\"person\" class=\"eg.Person\"/>\n"
+#~ "    SELECT person.NAME AS {person.name},\n"
+#~ "           person.AGE AS {person.age},\n"
+#~ "           person.SEX AS {person.sex}\n"
+#~ "    FROM PERSON person\n"
+#~ "    WHERE person.NAME LIKE :namePattern\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"persons\"&gt;\n"
+#~ "    &lt;return alias=\"person\" class=\"eg.Person\"/&gt;\n"
+#~ "    SELECT person.NAME AS {person.name},\n"
+#~ "           person.AGE AS {person.age},\n"
+#~ "           person.SEX AS {person.sex}\n"
+#~ "    FROM PERSON person\n"
+#~ "    WHERE person.NAME LIKE :namePattern\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List people = sess.getNamedQuery(\"persons\")\n"
+#~ "    .setString(\"namePattern\", namePattern)\n"
+#~ "    .setMaxResults(50)\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List people = sess.getNamedQuery(\"persons\")\n"
+#~ "    .setString(\"namePattern\", namePattern)\n"
+#~ "    .setMaxResults(50)\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"personsWith\">\n"
+#~ "    <return alias=\"person\" class=\"eg.Person\"/>\n"
+#~ "    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
+#~ "    SELECT person.NAME AS {person.name},\n"
+#~ "           person.AGE AS {person.age},\n"
+#~ "           person.SEX AS {person.sex},\n"
+#~ "           address.STREET AS {address.street},\n"
+#~ "           address.CITY AS {address.city},\n"
+#~ "           address.STATE AS {address.state},\n"
+#~ "           address.ZIP AS {address.zip}\n"
+#~ "    FROM PERSON person\n"
+#~ "    JOIN ADDRESS address\n"
+#~ "        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
+#~ "    WHERE person.NAME LIKE :namePattern\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"personsWith\"&gt;\n"
+#~ "    &lt;return alias=\"person\" class=\"eg.Person\"/&gt;\n"
+#~ "    &lt;return-join alias=\"address\" property=\"person.mailingAddress\"/"
+#~ "&gt;\n"
+#~ "    SELECT person.NAME AS {person.name},\n"
+#~ "           person.AGE AS {person.age},\n"
+#~ "           person.SEX AS {person.sex},\n"
+#~ "           adddress.STREET AS {address.street},\n"
+#~ "           adddress.CITY AS {address.city},\n"
+#~ "           adddress.STATE AS {address.state},\n"
+#~ "           adddress.ZIP AS {address.zip}\n"
+#~ "    FROM PERSON person\n"
+#~ "    JOIN ADDRESS adddress\n"
+#~ "        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
+#~ "    WHERE person.NAME LIKE :namePattern\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"mySqlQuery\">\n"
+#~ "    <return-scalar column=\"name\" type=\"string\"/>\n"
+#~ "    <return-scalar column=\"age\" type=\"long\"/>\n"
+#~ "    SELECT p.NAME AS name,\n"
+#~ "           p.AGE AS age,\n"
+#~ "    FROM PERSON p WHERE p.NAME LIKE 'Hiber%'\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"mySqlQuery\"&gt;\n"
+#~ "    &lt;return-scalar column=\"name\" type=\"string\"/&gt;\n"
+#~ "    &lt;return-scalar column=\"age\" type=\"long\"/&gt;\n"
+#~ "    SELECT p.NAME AS name,\n"
+#~ "           p.AGE AS age,\n"
+#~ "    FROM PERSON p WHERE p.NAME LIKE 'Hiber&#37;'\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<resultset name=\"personAddress\">\n"
+#~ "    <return alias=\"person\" class=\"eg.Person\"/>\n"
+#~ "    <return-join alias=\"address\" property=\"person.mailingAddress\"/>\n"
+#~ "</resultset>\n"
+#~ "\n"
+#~ "<sql-query name=\"personsWith\" resultset-ref=\"personAddress\">\n"
+#~ "    SELECT person.NAME AS {person.name},\n"
+#~ "           person.AGE AS {person.age},\n"
+#~ "           person.SEX AS {person.sex},\n"
+#~ "           address.STREET AS {address.street},\n"
+#~ "           address.CITY AS {address.city},\n"
+#~ "           address.STATE AS {address.state},\n"
+#~ "           address.ZIP AS {address.zip}\n"
+#~ "    FROM PERSON person\n"
+#~ "    JOIN ADDRESS address\n"
+#~ "        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
+#~ "    WHERE person.NAME LIKE :namePattern\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;resultset name=\"personAddress\"&gt;\n"
+#~ "    &lt;return alias=\"person\" class=\"eg.Person\"/&gt;\n"
+#~ "    &lt;return-join alias=\"address\" property=\"person.mailingAddress\"/"
+#~ "&gt;\n"
+#~ "&lt;/resultset&gt;\n"
+#~ "\n"
+#~ "&lt;sql-query name=\"personsWith\" resultset-ref=\"personAddress\"&gt;\n"
+#~ "    SELECT person.NAME AS {person.name},\n"
+#~ "           person.AGE AS {person.age},\n"
+#~ "           person.SEX AS {person.sex},\n"
+#~ "           adddress.STREET AS {address.street},\n"
+#~ "           adddress.CITY AS {address.city},\n"
+#~ "           adddress.STATE AS {address.state},\n"
+#~ "           adddress.ZIP AS {address.zip}\n"
+#~ "    FROM PERSON person\n"
+#~ "    JOIN ADDRESS adddress\n"
+#~ "        ON person.ID = address.PERSON_ID AND address.TYPE='MAILING'\n"
+#~ "    WHERE person.NAME LIKE :namePattern\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[List cats = sess.createSQLQuery(\n"
+#~ "        \"select {cat.*}, {kitten.*} from cats cat, cats kitten where "
+#~ "kitten.mother = cat.id\"\n"
+#~ "    )\n"
+#~ "    .setResultSetMapping(\"catAndKitten\")\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "List cats = sess.createSQLQuery(\n"
+#~ "        \"select {cat.*}, {kitten.*} from cats cat, cats kitten where "
+#~ "kitten.mother = cat.id\"\n"
+#~ "    )\n"
+#~ "    .setResultSetMapping(\"catAndKitten\")\n"
+#~ "    .list();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"mySqlQuery\">\n"
+#~ "    <return alias=\"person\" class=\"eg.Person\">\n"
+#~ "        <return-property name=\"name\" column=\"myName\"/>\n"
+#~ "        <return-property name=\"age\" column=\"myAge\"/>\n"
+#~ "        <return-property name=\"sex\" column=\"mySex\"/>\n"
+#~ "    </return>\n"
+#~ "    SELECT person.NAME AS myName,\n"
+#~ "           person.AGE AS myAge,\n"
+#~ "           person.SEX AS mySex,\n"
+#~ "    FROM PERSON person WHERE person.NAME LIKE :name\n"
+#~ "</sql-query>\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"mySqlQuery\"&gt;\n"
+#~ "    &lt;return alias=\"person\" class=\"eg.Person\"&gt;\n"
+#~ "        &lt;return-property name=\"name\" column=\"myName\"/&gt;\n"
+#~ "        &lt;return-property name=\"age\" column=\"myAge\"/&gt;\n"
+#~ "        &lt;return-property name=\"sex\" column=\"mySex\"/&gt;\n"
+#~ "    &lt;/return&gt;\n"
+#~ "    SELECT person.NAME AS myName,\n"
+#~ "           person.AGE AS myAge,\n"
+#~ "           person.SEX AS mySex,\n"
+#~ "    FROM PERSON person WHERE person.NAME LIKE :name\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"organizationCurrentEmployments\">\n"
+#~ "    <return alias=\"emp\" class=\"Employment\">\n"
+#~ "        <return-property name=\"salary\">\n"
+#~ "            <return-column name=\"VALUE\"/>\n"
+#~ "            <return-column name=\"CURRENCY\"/>\n"
+#~ "        </return-property>\n"
+#~ "        <return-property name=\"endDate\" column=\"myEndDate\"/>\n"
+#~ "    </return>\n"
+#~ "        SELECT EMPLOYEE AS {emp.employee}, EMPLOYER AS {emp.employer},\n"
+#~ "        STARTDATE AS {emp.startDate}, ENDDATE AS {emp.endDate},\n"
+#~ "        REGIONCODE as {emp.regionCode}, EID AS {emp.id}, VALUE, CURRENCY\n"
+#~ "        FROM EMPLOYMENT\n"
+#~ "        WHERE EMPLOYER = :id AND ENDDATE IS NULL\n"
+#~ "        ORDER BY STARTDATE ASC\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"organizationCurrentEmployments\"&gt;\n"
+#~ "    &lt;return alias=\"emp\" class=\"Employment\"&gt;\n"
+#~ "        &lt;return-property name=\"salary\"&gt;\n"
+#~ "            &lt;return-column name=\"VALUE\"/&gt;\n"
+#~ "            &lt;return-column name=\"CURRENCY\"/&gt;\n"
+#~ "        &lt;/return-property&gt;\n"
+#~ "        &lt;return-property name=\"endDate\" column=\"myEndDate\"/&gt;\n"
+#~ "    &lt;/return&gt;\n"
+#~ "        SELECT EMPLOYEE AS {emp.employee}, EMPLOYER AS {emp.employer},\n"
+#~ "        STARTDATE AS {emp.startDate}, ENDDATE AS {emp.endDate},\n"
+#~ "        REGIONCODE as {emp.regionCode}, EID AS {emp.id}, VALUE, CURRENCY\n"
+#~ "        FROM EMPLOYMENT\n"
+#~ "        WHERE EMPLOYER = :id AND ENDDATE IS NULL\n"
+#~ "        ORDER BY STARTDATE ASC\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[CREATE OR REPLACE FUNCTION selectAllEmployments\n"
+#~ "    RETURN SYS_REFCURSOR\n"
+#~ "AS\n"
+#~ "    st_cursor SYS_REFCURSOR;\n"
+#~ "BEGIN\n"
+#~ "    OPEN st_cursor FOR\n"
+#~ " SELECT EMPLOYEE, EMPLOYER,\n"
+#~ " STARTDATE, ENDDATE,\n"
+#~ " REGIONCODE, EID, VALUE, CURRENCY\n"
+#~ " FROM EMPLOYMENT;\n"
+#~ "      RETURN  st_cursor;\n"
+#~ " END;]]>"
+#~ msgstr ""
+#~ "CREATE OR REPLACE FUNCTION selectAllEmployments\n"
+#~ "    RETURN SYS_REFCURSOR\n"
+#~ "AS\n"
+#~ "    st_cursor SYS_REFCURSOR;\n"
+#~ "BEGIN\n"
+#~ "    OPEN st_cursor FOR\n"
+#~ " SELECT EMPLOYEE, EMPLOYER,\n"
+#~ " STARTDATE, ENDDATE,\n"
+#~ " REGIONCODE, EID, VALUE, CURRENCY\n"
+#~ " FROM EMPLOYMENT;\n"
+#~ "      RETURN  st_cursor;\n"
+#~ " END;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"selectAllEmployees_SP\" callable=\"true\">\n"
+#~ "    <return alias=\"emp\" class=\"Employment\">\n"
+#~ "        <return-property name=\"employee\" column=\"EMPLOYEE\"/>\n"
+#~ "        <return-property name=\"employer\" column=\"EMPLOYER\"/>\n"
+#~ "        <return-property name=\"startDate\" column=\"STARTDATE\"/>\n"
+#~ "        <return-property name=\"endDate\" column=\"ENDDATE\"/>\n"
+#~ "        <return-property name=\"regionCode\" column=\"REGIONCODE\"/>\n"
+#~ "        <return-property name=\"id\" column=\"EID\"/>\n"
+#~ "        <return-property name=\"salary\">\n"
+#~ "            <return-column name=\"VALUE\"/>\n"
+#~ "            <return-column name=\"CURRENCY\"/>\n"
+#~ "        </return-property>\n"
+#~ "    </return>\n"
+#~ "    { ? = call selectAllEmployments() }\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"selectAllEmployees_SP\" callable=\"true\"&gt;\n"
+#~ "    &lt;return alias=\"emp\" class=\"Employment\"&gt;\n"
+#~ "        &lt;return-property name=\"employee\" column=\"EMPLOYEE\"/&gt;\n"
+#~ "        &lt;return-property name=\"employer\" column=\"EMPLOYER\"/&gt;\n"
+#~ "        &lt;return-property name=\"startDate\" column=\"STARTDATE\"/&gt;\n"
+#~ "        &lt;return-property name=\"endDate\" column=\"ENDDATE\"/&gt;\n"
+#~ "        &lt;return-property name=\"regionCode\" column=\"REGIONCODE\"/"
+#~ "&gt;\n"
+#~ "        &lt;return-property name=\"id\" column=\"EID\"/&gt;\n"
+#~ "        &lt;return-property name=\"salary\"&gt;\n"
+#~ "            &lt;return-column name=\"VALUE\"/&gt;\n"
+#~ "            &lt;return-column name=\"CURRENCY\"/&gt;\n"
+#~ "        &lt;/return-property&gt;\n"
+#~ "    &lt;/return&gt;\n"
+#~ "    { ? = call selectAllEmployments() }\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"increment\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"name\" not-null=\"true\"/>\n"
+#~ "    <sql-insert>INSERT INTO PERSON (NAME, ID) VALUES ( UPPER(?), ? )</sql-"
+#~ "insert>\n"
+#~ "    <sql-update>UPDATE PERSON SET NAME=UPPER(?) WHERE ID=?</sql-update>\n"
+#~ "    <sql-delete>DELETE FROM PERSON WHERE ID=?</sql-delete>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\"&gt;\n"
+#~ "        &lt;generator class=\"increment\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"name\" not-null=\"true\"/&gt;\n"
+#~ "    &lt;sql-insert&gt;INSERT INTO PERSON (NAME, ID) VALUES ( UPPER(?), ? )"
+#~ "&lt;/sql-insert&gt;\n"
+#~ "    &lt;sql-update&gt;UPDATE PERSON SET NAME=UPPER(?) WHERE ID=?&lt;/sql-"
+#~ "update&gt;\n"
+#~ "    &lt;sql-delete&gt;DELETE FROM PERSON WHERE ID=?&lt;/sql-delete&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"increment\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"name\" not-null=\"true\"/>\n"
+#~ "    <sql-insert callable=\"true\">{call createPerson (?, ?)}</sql-"
+#~ "insert>\n"
+#~ "    <sql-delete callable=\"true\">{? = call deletePerson (?)}</sql-"
+#~ "delete>\n"
+#~ "    <sql-update callable=\"true\">{? = call updatePerson (?, ?)}</sql-"
+#~ "update>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\"&gt;\n"
+#~ "        &lt;generator class=\"increment\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"name\" not-null=\"true\"/&gt;\n"
+#~ "    &lt;sql-insert callable=\"true\"&gt;{call createPerson (?, ?)}&lt;/"
+#~ "sql-insert&gt;\n"
+#~ "    &lt;sql-delete callable=\"true\"&gt;{? = call deletePerson (?)}&lt;/"
+#~ "sql-delete&gt;\n"
+#~ "    &lt;sql-update callable=\"true\"&gt;{? = call updatePerson (?, ?)}"
+#~ "&lt;/sql-update&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[CREATE OR REPLACE FUNCTION updatePerson (uid IN NUMBER, uname IN "
+#~ "VARCHAR2)\n"
+#~ "    RETURN NUMBER IS\n"
+#~ "BEGIN\n"
+#~ "\n"
+#~ "    update PERSON\n"
+#~ "    set\n"
+#~ "        NAME = uname,\n"
+#~ "    where\n"
+#~ "        ID = uid;\n"
+#~ "\n"
+#~ "    return SQL%ROWCOUNT;\n"
+#~ "\n"
+#~ "END updatePerson;]]>"
+#~ msgstr ""
+#~ "CREATE OR REPLACE FUNCTION updatePerson (uid IN NUMBER, uname IN "
+#~ "VARCHAR2)\n"
+#~ "    RETURN NUMBER IS\n"
+#~ "BEGIN\n"
+#~ "\n"
+#~ "    update PERSON\n"
+#~ "    set\n"
+#~ "        NAME = uname,\n"
+#~ "    where\n"
+#~ "        ID = uid;\n"
+#~ "\n"
+#~ "    return SQL&#37;ROWCOUNT;\n"
+#~ "\n"
+#~ "END updatePerson;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"person\">\n"
+#~ "    <return alias=\"pers\" class=\"Person\" lock-mode=\"upgrade\"/>\n"
+#~ "    SELECT NAME AS {pers.name}, ID AS {pers.id}\n"
+#~ "    FROM PERSON\n"
+#~ "    WHERE ID=?\n"
+#~ "    FOR UPDATE\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"person\"&gt;\n"
+#~ "    &lt;return alias=\"pers\" class=\"Person\" lock-mode=\"upgrade\"/"
+#~ "&gt;\n"
+#~ "    SELECT NAME AS {pers.name}, ID AS {pers.id}\n"
+#~ "    FROM PERSON\n"
+#~ "    WHERE ID=?\n"
+#~ "    FOR UPDATE\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Person\">\n"
+#~ "    <id name=\"id\">\n"
+#~ "        <generator class=\"increment\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"name\" not-null=\"true\"/>\n"
+#~ "    <loader query-ref=\"person\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Person\"&gt;\n"
+#~ "    &lt;id name=\"id\"&gt;\n"
+#~ "        &lt;generator class=\"increment\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"name\" not-null=\"true\"/&gt;\n"
+#~ "    &lt;loader query-ref=\"person\"/&gt;\n"
+#~ "&lt;/class&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<set name=\"employments\" inverse=\"true\">\n"
+#~ "    <key/>\n"
+#~ "    <one-to-many class=\"Employment\"/>\n"
+#~ "    <loader query-ref=\"employments\"/>\n"
+#~ "</set>]]>"
+#~ msgstr ""
+#~ "&lt;set name=\"employments\" inverse=\"true\"&gt;\n"
+#~ "    &lt;key/&gt;\n"
+#~ "    &lt;one-to-many class=\"Employment\"/&gt;\n"
+#~ "    &lt;loader query-ref=\"employments\"/&gt;\n"
+#~ "&lt;/set&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"employments\">\n"
+#~ "    <load-collection alias=\"emp\" role=\"Person.employments\"/>\n"
+#~ "    SELECT {emp.*}\n"
+#~ "    FROM EMPLOYMENT emp\n"
+#~ "    WHERE EMPLOYER = :id\n"
+#~ "    ORDER BY STARTDATE ASC, EMPLOYEE ASC\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"employments\"&gt;\n"
+#~ "    &lt;load-collection alias=\"emp\" role=\"Person.employments\"/&gt;\n"
+#~ "    SELECT {emp.*}\n"
+#~ "    FROM EMPLOYMENT emp\n"
+#~ "    WHERE EMPLOYER = :id\n"
+#~ "    ORDER BY STARTDATE ASC, EMPLOYEE ASC\n"
+#~ "&lt;/sql-query&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<sql-query name=\"person\">\n"
+#~ "    <return alias=\"pers\" class=\"Person\"/>\n"
+#~ "    <return-join alias=\"emp\" property=\"pers.employments\"/>\n"
+#~ "    SELECT NAME AS {pers.*}, {emp.*}\n"
+#~ "    FROM PERSON pers\n"
+#~ "    LEFT OUTER JOIN EMPLOYMENT emp\n"
+#~ "        ON pers.ID = emp.PERSON_ID\n"
+#~ "    WHERE ID=?\n"
+#~ "</sql-query>]]>"
+#~ msgstr ""
+#~ "&lt;sql-query name=\"person\"&gt;\n"
+#~ "    &lt;return alias=\"pers\" class=\"Person\"/&gt;\n"
+#~ "    &lt;return-join alias=\"emp\" property=\"pers.employments\"/&gt;\n"
+#~ "    SELECT NAME AS {pers.*}, {emp.*}\n"
+#~ "    FROM PERSON pers\n"
+#~ "    LEFT OUTER JOIN EMPLOYMENT emp\n"
+#~ "        ON pers.ID = emp.PERSON_ID\n"
+#~ "    WHERE ID=?\n"
+#~ "&lt;/sql-query&gt;"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/session_api.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/session_api.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/session_api.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,27 @@
+# translation of session_api.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007, 2009.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: session_api\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-12-04 14:00+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: session_api.xml:29
 #, no-c-format
 msgid "Working with objects"
 msgstr "与对象共事"
 
 #. Tag: para
-#: session_api.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate is a full object/relational mapping solution that not only shields "
 "the developer from the details of the underlying database management system, "
@@ -27,13 +30,12 @@
 "JDBC/SQL persistence layers, a natural object-oriented view of persistence "
 "in Java applications."
 msgstr ""
-"Hibernate是完整的对象/关系映射解决方案,它提供了对象<emphasis>状态管理(state "
-"management)</emphasis>的功能,使开发者不再需要理会底层数据库系统的细节。 也就"
-"是说,相对于常见的JDBC/SQL持久层方案中需要<literal>管理SQL语句</literal>,"
-"Hibernate采用了更自然的面向对象的视角来持久化Java应用中的数据。"
+"Hibernate 是完整的对象/关系映射解决方案,它提供了对象<emphasis>状态管理"
+"(state management)</emphasis>的功能,使开发者不再需要理会底层数据库系统的细"
+"节。也就是说,相对于常见的 JDBC/SQL 持久层方案中需要<literal>管理 SQL 语句</"
+"literal>,Hibernate 采用了更自然的面向对象的视角来持久化 Java 应用中的数据。 "
 
 #. Tag: para
-#: session_api.xml:40
 #, no-c-format
 msgid ""
 "In other words, Hibernate application developers should always think about "
@@ -42,25 +44,22 @@
 "is only relevant for the application developer when tuning the performance "
 "of the system."
 msgstr ""
-"换句话说,使用Hibernate的开发者应该总是关注对象的<emphasis>状态(state)</"
-"emphasis>,不必考虑SQL语句的执行。 这部分细节已经由Hibernate掌管妥当,只有开"
-"发者在进行系统性能调优的时候才需要进行了解。"
+"换句话说,使用 Hibernate 的开发者应该总是关注对象的<emphasis>状态(state)</"
+"emphasis>,不必考虑 SQL 语句的执行。这部分细节已经由 Hibernate 掌管妥当,只有"
+"开发者在进行系统性能调优的时候才需要进行了解。"
 
 #. Tag: title
-#: session_api.xml:48
 #, no-c-format
 msgid "Hibernate object states"
-msgstr "Hibernate对象状态(object states)"
+msgstr "Hibernate 对象状态(object states)"
 
 #. Tag: para
-#: session_api.xml:50
 #, no-c-format
 msgid "Hibernate defines and supports the following object states:"
-msgstr "Hibernate定义并支持下列对象状态(state):"
+msgstr "Hibernate 定义并支持下列对象状态(state):"
 
 #. Tag: para
-#: session_api.xml:56
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Transient</emphasis> - an object is transient if it has just been "
 "instantiated using the <literal>new</literal> operator, and it is not "
@@ -72,16 +71,16 @@
 "take care of the SQL statements that need to be executed for this "
 "transition)."
 msgstr ""
-"<emphasis>瞬时(Transient)</emphasis> - 由<literal>new</literal>操作符创建,且"
-"尚未与Hibernate <literal>Session</literal> 关联的对象被认定为瞬时(Transient)"
-"的。瞬时(Transient)对象不会被持久化到数据库中,也不会被赋予持久化标识"
-"(identifier)。 如果瞬时(Transient)对象在程序中没有被引用,它会被垃圾回收器"
-"(garbage collector)销毁。 使用Hibernate <literal>Session</literal>可以将其变"
-"为持久(Persistent)状态。(Hibernate会自动执行必要的SQL语句)"
+"<emphasis>瞬时(Transient)</emphasis> — 由 <literal>new</literal> 操作符创"
+"建,且尚未与Hibernate <literal>Session</literal> 关联的对象被认定为瞬时"
+"(Transient)的。瞬时(Transient)对象不会被持久化到数据库中,也不会被赋予持"
+"久化标识(identifier)。 如果瞬时(Transient)对象在程序中没有被引用,它会被"
+"垃圾回收器(garbage collector)销毁。 使用 Hibernate <literal>Session</"
+"literal>可以将其变为持久(Persistent)状态。(Hibernate会自动执行必要的SQL语"
+"句) "
 
 #. Tag: para
-#: session_api.xml:68
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Persistent</emphasis> - a persistent instance has a representation "
 "in the database and an identifier value. It might just have been saved or "
@@ -92,18 +91,17 @@
 "statements, or <literal>DELETE</literal> statements when an object should be "
 "made transient."
 msgstr ""
-"<emphasis>持久(Persistent)</emphasis> - 持久(Persistent)的实例在数据库中有对"
-"应的记录,并拥有一个持久化标识(identifier)。 持久(Persistent)的实例可能是刚被"
-"保存的,或刚被加载的,无论哪一种,按定义,它存在于相关联的<literal>Session</"
-"literal>作用范围内。 Hibernate会检测到处于持久(Persistent)状态的对象的任何改"
-"动,在当前操作单元(unit of work)执行完毕时将对象数据(state)与数据库同步"
-"(synchronize)。 开发者不需要手动执行<literal>UPDATE</literal>。将对象从持久"
-"(Persistent)状态变成瞬时(Transient)状态同样也不需要手动执行<literal>DELETE</"
-"literal>语句。"
+"<emphasis>持久(Persistent)</emphasis> — 持久(Persistent)的实例在数据库中"
+"有对应的记录,并拥有一个持久化标识(identifier)。 持久(Persistent)的实例可"
+"能是刚被保存的,或刚被加载的,无论哪一种,按定义,它存在于相关联的"
+"<literal>Session</literal>作用范围内。 Hibernate会检测到处于持久"
+"(Persistent)状态的对象的任何改动,在当前操作单元(unit of work)执行完毕时"
+"将对象数据(state)与数据库同步(synchronize)。 开发者不需要手动执行"
+"<literal>UPDATE</literal>。将对象从持久(Persistent)状态变成瞬时"
+"(Transient)状态同样也不需要手动执行 <literal>DELETE</literal> 语句。 "
 
 #. Tag: para
-#: session_api.xml:79
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Detached</emphasis> - a detached instance is an object that has "
 "been persistent, but its <literal>Session</literal> has been closed. The "
@@ -115,58 +113,43 @@
 "them <emphasis>application transactions</emphasis>, i.e., a unit of work "
 "from the point of view of the user."
 msgstr ""
-"<emphasis>脱管(Detached)</emphasis> - 与持久(Persistent)对象关联的"
-"<literal>Session</literal>被关闭后,对象就变为脱管(Detached)的。 对脱管"
-"(Detached)对象的引用依然有效,对象可继续被修改。脱管(Detached)对象如果重新关"
-"联到某个新的<literal>Session</literal>上, 会再次转变为持久(Persistent)的(在"
-"Detached其间的改动将被持久化到数据库)。 这个功能使得一种编程模型,即中间会给"
-"用户思考时间(user think-time)的长时间运行的操作单元(unit of work)的编程模型成"
-"为可能。 我们称之为<emphasis>应用程序事务</emphasis>,即从用户观点看是一个操"
-"作单元(unit of work)。"
+"<emphasis>脱管(Detached)</emphasis> — 与持久(Persistent)对象关联的"
+"<literal>Session</literal>被关闭后,对象就变为脱管(Detached)的。对脱管"
+"(Detached)对象的引用依然有效,对象可继续被修改。脱管(Detached)对象如果重"
+"新关联到某个新的 <literal>Session</literal> 上, 会再次转变为持久"
+"(Persistent)的(在Detached其间的改动将被持久化到数据库)。 这个功能使得一种"
+"编程模型,即中间会给用户思考时间(user think-time)的长时间运行的操作单元"
+"(unit of work)的编程模型成为可能。我们称之为<emphasis>应用程序事务</"
+"emphasis>,即从用户观点看是一个操作单元(unit of work)。 "
 
 #. Tag: para
-#: session_api.xml:93
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will now discuss the states and state transitions (and the Hibernate "
 "methods that trigger a transition) in more detail."
 msgstr ""
-"接下来我们来细致的讨论下状态(states)及状态间的转换(state transitions)(以及触"
-"发状态转换的Hibernate方法)。"
+"接下来我们来细致地讨论下状态(states)及状态间的转换(state transitions)(以"
+"及触发状态转换的 Hibernate 方法)。 "
 
 #. Tag: title
-#: session_api.xml:101
 #, no-c-format
 msgid "Making objects persistent"
 msgstr "使对象持久化"
 
 #. Tag: para
-#: session_api.xml:103
 #, no-c-format
 msgid ""
 "Newly instantiated instances of a a persistent class are considered "
 "<emphasis>transient</emphasis> by Hibernate. We can make a transient "
 "instance <emphasis>persistent</emphasis> by associating it with a session:"
 msgstr ""
-"Hibernate认为持久化类(persistent class)新实例化的对象是<emphasis>瞬时"
-"(Transient)</emphasis>的。 我们可通过将瞬时(Transient)对象与session关联而把它"
-"变为<emphasis>持久(Persistent)</emphasis>的。"
+"Hibernate 认为持久化类(persistent class)新实例化的对象是<emphasis>瞬时"
+"(Transient)</emphasis>的。我们可通过将瞬时(Transient)对象与 session 关联"
+"而把它变为<emphasis>持久(Persistent)</emphasis>的。"
 
-#. Tag: programlisting
-#: session_api.xml:110
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DomesticCat fritz = new DomesticCat();\n"
-"fritz.setColor(Color.GINGER);\n"
-"fritz.setSex('M');\n"
-"fritz.setName(\"Fritz\");\n"
-"Long generatedId = (Long) sess.save(fritz);]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:112
-#, fuzzy, no-c-format
-msgid ""
 "If <literal>Cat</literal> has a generated identifier, the identifier is "
 "generated and assigned to the <literal>cat</literal> when <literal>save()</"
 "literal> is called. If <literal>Cat</literal> has an <literal>assigned</"
@@ -176,17 +159,17 @@
 "<literal>save()</literal>, with the semantics defined in the EJB3 early "
 "draft."
 msgstr ""
-"如果<literal>Cat</literal>的持久化标识(identifier)是<literal>generated</"
-"literal>类型的, 那么该标识(identifier)会自动在<literal>save()</literal>被调"
-"用时产生并分配给<literal>cat</literal>。 如果<literal>Cat</literal>的持久化标"
-"识(identifier)是<literal>assigned</literal>类型的,或是一个复合主键"
-"(composite key), 那么该标识(identifier)应当在调用<literal>save()</literal>之"
-"前手动赋予给<literal>cat</literal>。 你也可以按照EJB3 early draft中定义的语"
-"义,使用<literal>persist()</literal>替代<literal>save()</literal>。"
+"如果 <literal>Cat</literal> 的持久化标识(identifier)是 <literal>generated</"
+"literal> 类型的, 那么该标识(identifier)会自动在 <literal>save()</literal> "
+"被调用时产生并分配给 <literal>cat</literal>。如果 <literal>Cat</literal> 的持"
+"久化标识(identifier)是<literal>assigned</literal>类型的,或是一个复合主键"
+"(composite key),那么该标识(identifier)应当在调用 <literal>save()</"
+"literal> 之前手动赋予给 <literal>cat</literal>。你也可以按照 EJB3 early "
+"draft 中定义的语义,使用 <literal>persist()</literal> 替代<literal>save()</"
+"literal>。 "
 
 #. Tag: para
-#: session_api.xml:124
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>persist()</literal> makes a transient instance persistent. However, "
 "it does not guarantee that the identifier value will be assigned to the "
@@ -196,16 +179,12 @@
 "boundaries. This is useful in long-running conversations with an extended "
 "Session/persistence context."
 msgstr ""
-"<literal>persist()</literal> makes a transient instance persistent. However, "
-"it doesn't guarantee that the identifier value will be assigned to the "
-"persistent instance immediately, the assignment might happen at flush time. "
-"<literal>persist()</literal> also guarantees that it will not execute an "
-"<literal>INSERT</literal> statement if it is called outside of transaction "
-"boundaries. This is useful in long-running conversations with an extended "
-"Session/persistence context."
+"<literal>persist()</literal> 使一个临时实例持久化。然而,它不保证立即把标识符"
+"值分配给持久性实例,这会发生在冲刷(flush)的时候。<literal>persist()</"
+"literal> 也保证它在事务边界外调用时不会执行 <literal>INSERT</literal> 语句。"
+"这对于长期运行的带有扩展会话/持久化上下文的会话是很有用的。"
 
 #. Tag: para
-#: session_api.xml:135
 #, no-c-format
 msgid ""
 "<literal>save()</literal> does guarantee to return an identifier. If an "
@@ -214,37 +193,21 @@
 "you are inside or outside of a transaction. This is problematic in a long-"
 "running conversation with an extended Session/persistence context."
 msgstr ""
-"<literal>save()</literal> does guarantee to return an identifier. If an "
-"INSERT has to be executed to get the identifier ( e.g. \"identity\" "
-"generator, not \"sequence\"), this INSERT happens immediately, no matter if "
-"you are inside or outside of a transaction. This is problematic in a long-"
-"running conversation with an extended Session/persistence context."
+"<literal>save()</literal> 保证返回一个标识符。如果需要运行 INSERT 来获取标识"
+"符(如 \"identity\" 而非 \"sequence\" 生成器),这个 INSERT 将立即执行,不管"
+"你是否在事务内部还是外部。这对于长期运行的带有扩展会话/持久化上下文的会话来说"
+"会出现问题。"
 
 #. Tag: para
-#: session_api.xml:145
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Alternatively, you can assign the identifier using an overloaded version of "
 "<literal>save()</literal>."
-msgstr "此外,你可以用一个重载版本的<literal>save()</literal>方法。"
+msgstr "此外,你可以用一个重载版本的 <literal>save()</literal> 方法。 "
 
-#. Tag: programlisting
-#: session_api.xml:150
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DomesticCat pk = new DomesticCat();\n"
-"pk.setColor(Color.TABBY);\n"
-"pk.setSex('F');\n"
-"pk.setName(\"PK\");\n"
-"pk.setKittens( new HashSet() );\n"
-"pk.addKitten(fritz);\n"
-"sess.save( pk, new Long(1234) );]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:152
-#, fuzzy, no-c-format
-msgid ""
 "If the object you make persistent has associated objects (e.g. the "
 "<literal>kittens</literal> collection in the previous example), these "
 "objects can be made persistent in any order you like unless you have a "
@@ -253,16 +216,15 @@
 "violate a <literal>NOT NULL</literal> constraint if you <literal>save()</"
 "literal> the objects in the wrong order."
 msgstr ""
-"如果你持久化的对象有关联的对象(associated objects)(例如上例中的"
-"<literal>kittens</literal>集合) 那么对这些对象(译注:pk和kittens)进行持久"
-"化的顺序是任意的(也就是说可以先对kittens进行持久化也可以先对pk进行持久"
-"化), 除非你在外键列上有<literal>NOT NULL</literal>约束。 Hibernate不会违反"
-"外键约束,但是如果你用错误的顺序持久化对象(译注:在pk持久化之前持久化"
-"kitten),那么可能会违反<literal>NOT NULL</literal>约束。"
+"如果你持久化的对象有关联的对象(associated objects)(例如上例中的 "
+"<literal>kittens</literal> 集合) 那么对这些对象(译注:pk 和 kittens)进行持"
+"久化的顺序是任意的(也就是说可以先对 kittens 进行持久化也可以先对 pk 进行持久"
+"化), 除非你在外键列上有 <literal>NOT NULL</literal> 约束。 Hibernate 不会违"
+"反外键约束,但是如果你用错误的顺序持久化对象(译注:在 pk 持久化之前持久化"
+"kitten),那么可能会违反 <literal>NOT NULL</literal> 约束。 "
 
 #. Tag: para
-#: session_api.xml:162
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Usually you do not bother with this detail, as you will normally use "
 "Hibernate's <emphasis>transitive persistence</emphasis> feature to save the "
@@ -270,68 +232,38 @@
 "constraint violations do not occur - Hibernate will take care of everything. "
 "Transitive persistence is discussed later in this chapter."
 msgstr ""
-"通常你不会为这些细节烦心,因为你很可能会使用Hibernate的 <emphasis>传播性持久"
-"化(transitive persistence)</emphasis>功能自动保存相关联那些对象。 这样连违反"
-"<literal>NOT NULL</literal>约束的情况都不会出现了 - Hibernate会管好所有的事"
-"情。 传播性持久化(transitive persistence)将在本章稍后讨论。"
+"通常你不会为这些细节烦心,因为你很可能会使用 Hibernate 的<emphasis>传播性持久"
+"化(transitive persistence)</emphasis>功能自动保存相关联那些对象。这样连违"
+"反 <literal>NOT NULL</literal> 约束的情况都不会出现了 — Hibernate 会管好所有"
+"的事情。传播性持久化(transitive persistence)将在本章稍后讨论。"
 
 #. Tag: title
-#: session_api.xml:173
 #, no-c-format
 msgid "Loading an object"
 msgstr "装载对象"
 
 #. Tag: para
-#: session_api.xml:175
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>load()</literal> methods of <literal>Session</literal> provide "
 "a way of retrieving a persistent instance if you know its identifier. "
 "<literal>load()</literal> takes a class object and loads the state into a "
 "newly instantiated instance of that class in a persistent state."
 msgstr ""
-"如果你知道某个实例的持久化标识(identifier),你就可以使用<literal>Session</"
-"literal>的<literal>load()</literal>方法 来获取它。 <literal>load()</literal>"
-"的另一个参数是指定类的.class对象。 本方法会创建指定类的持久化实例,并从数据库"
-"加载其数据(state)。"
+"如果你知道某个实例的持久化标识(identifier),你就可以使用 <literal>Session</"
+"literal> 的 <literal>load()</literal> 方法来获取它。<literal>load()</"
+"literal> 的另一个参数是指定类的对象。本方法会创建指定类的持久化实例,并从数据"
+"库加载其数据(state)。 "
 
-#. Tag: programlisting
-#: session_api.xml:182
-#, no-c-format
-msgid "<![CDATA[Cat fritz = (Cat) sess.load(Cat.class, generatedId);]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:184
-#, no-c-format
-msgid ""
-"<![CDATA[// you need to wrap primitive identifiers\n"
-"long id = 1234;\n"
-"DomesticCat pk = (DomesticCat) sess.load( DomesticCat.class, new Long"
-"(id) );]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:186
 #, no-c-format
 msgid "Alternatively, you can load state into a given instance:"
 msgstr ""
-"此外, 你可以把数据(state)加载到指定的对象实例上(覆盖掉该实例原来的数据)。"
+"此外,你可以把数据(state)加载到指定的对象实例上(覆盖掉该实例原来的数据)。"
 
-#. Tag: programlisting
-#: session_api.xml:190
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Cat cat = new DomesticCat();\n"
-"// load pk's state into cat\n"
-"sess.load( cat, new Long(pkId) );\n"
-"Set kittens = cat.getKittens();]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:192
-#, fuzzy, no-c-format
-msgid ""
 "Be aware that <literal>load()</literal> will throw an unrecoverable "
 "exception if there is no matching database row. If the class is mapped with "
 "a proxy, <literal>load()</literal> just returns an uninitialized proxy and "
@@ -341,110 +273,79 @@
 "be loaded as a batch if <literal>batch-size</literal> is defined for the "
 "class mapping."
 msgstr ""
-"请注意如果没有匹配的数据库记录,<literal>load()</literal>方法可能抛出无法恢复"
-"的异常(unrecoverable exception)。 如果类的映射使用了代理(proxy),"
-"<literal>load()</literal>方法会返回一个未初始化的代理,直到你调用该代理的某方"
-"法时才会去访问数据库。 若你希望在某对象中创建一个指向另一个对象的关联,又不想"
-"在从数据库中装载该对象时同时装载相关联的那个对象,那么这种操作方式就用得上的"
-"了。 如果为相应类映射关系设置了<literal>batch-size</literal>, 那么使用这种操"
-"作方式允许多个对象被一批装载(因为返回的是代理,无需从数据库中抓取所有对象的"
-"数据)。"
+"请注意如果没有匹配的数据库记录,<literal>load()</literal> 方法可能抛出无法恢"
+"复的异常(unrecoverable exception)。如果类的映射使用了代理(proxy),"
+"<literal>load()</literal> 方法会返回一个未初始化的代理,直到你调用该代理的某"
+"方法时才会去访问数据库。 若你希望在某对象中创建一个指向另一个对象的关联,又不"
+"想在从数据库中装载该对象时同时装载相关联的那个对象,那么这种操作方式就用得上"
+"的了。如果为相应类映射关系设置了 <literal>batch-size</literal>,那么使用这种"
+"操作方式允许多个对象被一批装载(因为返回的是代理,无需从数据库中抓取所有对象"
+"的数据)。 "
 
 #. Tag: para
-#: session_api.xml:203
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are not certain that a matching row exists, you should use the "
 "<literal>get()</literal> method which hits the database immediately and "
 "returns null if there is no matching row."
 msgstr ""
-"如果你不确定是否有匹配的行存在,应该使用<literal>get()</literal>方法,它会立"
-"刻访问数据库,如果没有对应的记录,会返回null。"
+"如果你不确定是否有匹配的行存在,应该使用 <literal>get()</literal> 方法,它会"
+"立刻访问数据库,如果没有对应的记录,会返回 null。 "
 
-#. Tag: programlisting
-#: session_api.xml:209
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id);\n"
-"if (cat==null) {\n"
-"    cat = new Cat();\n"
-"    sess.save(cat, id);\n"
-"}\n"
-"return cat;]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:211
-#, fuzzy, no-c-format
-msgid ""
 "You can even load an object using an SQL <literal>SELECT ... FOR UPDATE</"
 "literal>, using a <literal>LockMode</literal>. See the API documentation for "
 "more information."
 msgstr ""
-"你甚至可以选用某个<literal>LockMode</literal>,用SQL的<literal>SELECT ... "
-"FOR UPDATE</literal>装载对象。 请查阅API文档以获取更多信息。"
+"你甚至可以选用某个 <literal>LockMode</literal>,用 SQL 的 "
+"<literal>SELECT ... FOR UPDATE</literal> 装载对象。 请查阅 API 文档以获取更多"
+"信息。 "
 
-#. Tag: programlisting
-#: session_api.xml:216
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id, LockMode.UPGRADE);]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:218
-#, fuzzy, no-c-format
 msgid ""
 "Any associated instances or contained collections will <emphasis>not</"
 "emphasis> be selected <literal>FOR UPDATE</literal>, unless you decide to "
 "specify <literal>lock</literal> or <literal>all</literal> as a cascade style "
 "for the association."
 msgstr ""
-"注意,任何关联的对象或者包含的集合都<emphasis>不会</emphasis>被以"
-"<literal>FOR UPDATE</literal>方式返回, 除非你指定了<literal>lock</literal>或"
-"者<literal>all</literal>作为关联(association)的级联风格(cascade style)。"
+"注意,任何关联的对象或者包含的集合都<emphasis>不会</emphasis>被以 "
+"<literal>FOR UPDATE</literal> 方式返回, 除非你指定了 <literal>lock</"
+"literal> 或者 <literal>all</literal> 作为关联(association)的级联风格"
+"(cascade style)。 "
 
 #. Tag: para
-#: session_api.xml:225
 #, no-c-format
 msgid ""
 "It is possible to re-load an object and all its collections at any time, "
 "using the <literal>refresh()</literal> method. This is useful when database "
 "triggers are used to initialize some of the properties of the object."
 msgstr ""
-"任何时候都可以使用<literal>refresh()</literal>方法强迫装载对象和它的集合。如"
-"果你使用数据库触发器功能来处理对象的某些属性,这个方法就很有用了。"
+"任何时候都可以使用 <literal>refresh()</literal> 方法强迫装载对象和它的集合。"
+"如果你使用数据库触发器功能来处理对象的某些属性,这个方法就很有用了。"
 
-#. Tag: programlisting
-#: session_api.xml:231
-#, no-c-format
-msgid ""
-"<![CDATA[sess.save(cat);\n"
-"sess.flush(); //force the SQL INSERT\n"
-"sess.refresh(cat); //re-read the state (after the trigger executes)]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:233
 #, fuzzy, no-c-format
 msgid ""
 "How much does Hibernate load from the database and how many SQL "
 "<literal>SELECT</literal>s will it use? This depends on the "
 "<emphasis>fetching strategy</emphasis>. This is explained in <xref linkend="
-"\"performance-fetching\"/>."
+"\"performance-fetching\" />."
 msgstr ""
-"此处通常会出现一个重要问题: Hibernate会从数据库中装载多少东西?会执行多少条相"
-"应的SQL<literal>SELECT</literal>语句? 这取决于<emphasis>抓取策略(fetching "
-"strategy)</emphasis>,会在<xref linkend=\"performance-fetching\"/>中解释。"
+"此处通常会出现一个重要问题: Hibernate 会从数据库中装载多少东西?会执行多少条"
+"相应的 SQL<literal>SELECT</literal> 语句?这取决于<emphasis>抓取策略"
+"(fetching strategy)</emphasis>,我们会在 <xref linkend=\"performance-"
+"fetching\" /> 中解释。 "
 
 #. Tag: title
-#: session_api.xml:243
 #, no-c-format
 msgid "Querying"
 msgstr "查询"
 
 #. Tag: para
-#: session_api.xml:245
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you do not know the identifiers of the objects you are looking for, you "
 "need a query. Hibernate supports an easy-to-use but powerful object oriented "
@@ -453,20 +354,18 @@
 "express your query in the native SQL of your database, with optional support "
 "from Hibernate for result set conversion into objects."
 msgstr ""
-"如果不知道所要寻找的对象的持久化标识,那么你需要使用查询。Hibernate支持强大且"
-"易于使用的面向对象查询语言(HQL)。 如果希望通过编程的方式创建查询,Hibernate提"
-"供了完善的按条件(Query By Criteria, QBC)以及按样例(Query By Example, QBE)进行"
-"查询的功能。 你也可以用原生SQL(native SQL)描述查询,Hibernate额外提供了将结果"
-"集(result set)转化为对象的支持。"
+"如果不知道所要寻找的对象的持久化标识,那么你需要使用查询。Hibernate 支持强大"
+"且易于使用的面向对象查询语言(HQL)。如果希望通过编程的方式创建查询,"
+"Hibernate 提供了完善的按条件(Query By Criteria,QBC)以及按样例(Query By "
+"Example,QBE)进行查询的功能。你也可以用原生 SQL(native SQL)描述查询,"
+"Hibernate 额外提供了将结果集(result set)转化为对象的支持。 "
 
 #. Tag: title
-#: session_api.xml:255
 #, no-c-format
 msgid "Executing queries"
 msgstr "执行查询"
 
 #. Tag: para
-#: session_api.xml:257
 #, no-c-format
 msgid ""
 "HQL and native SQL queries are represented with an instance of <literal>org."
@@ -475,45 +374,14 @@
 "always obtain a <literal>Query</literal> using the current <literal>Session</"
 "literal>:"
 msgstr ""
-"HQL和原生SQL(native SQL)查询要通过为<literal>org.hibernate.Query</literal>的"
-"实例来表达。 这个接口提供了参数绑定、结果集处理以及运行实际查询的方法。 你总"
-"是可以通过当前<literal>Session</literal>获取一个<literal>Query</literal>对"
-"象:"
+"HQL 和原生 SQL(native SQL)查询要通过为 <literal>org.hibernate.Query</"
+"literal> 的实例来表达。 这个接口提供了参数绑定、结果集处理以及运行实际查询的"
+"方法。你总是可以通过当前 <literal>Session</literal> 获取一个 <literal>Query</"
+"literal> 对象:"
 
-#. Tag: programlisting
-#: session_api.xml:264
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[List cats = session.createQuery(\n"
-"    \"from Cat as cat where cat.birthdate < ?\")\n"
-"    .setDate(0, date)\n"
-"    .list();\n"
-"\n"
-"List mothers = session.createQuery(\n"
-"    \"select mother from Cat as cat join cat.mother as mother where cat.name "
-"= ?\")\n"
-"    .setString(0, name)\n"
-"    .list();\n"
-"\n"
-"List kittens = session.createQuery(\n"
-"    \"from Cat as cat where cat.mother = ?\")\n"
-"    .setEntity(0, pk)\n"
-"    .list();\n"
-"\n"
-"Cat mother = (Cat) session.createQuery(\n"
-"    \"select cat.mother from Cat as cat where cat = ?\")\n"
-"    .setEntity(0, izi)\n"
-"    .uniqueResult();]]\n"
-"\n"
-"Query mothersWithKittens = (Cat) session.createQuery(\n"
-"    \"select mother from Cat as mother left join fetch mother.kittens\");\n"
-"Set uniqueMothers = new HashSet(mothersWithKittens.list());]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:266
-#, fuzzy, no-c-format
-msgid ""
 "A query is usually executed by invoking <literal>list()</literal>. The "
 "result of the query will be loaded completely into a collection in memory. "
 "Entity instances retrieved by a query are in a persistent state. The "
@@ -523,21 +391,20 @@
 "with their collections initialized. You can filter these duplicates through "
 "a <literal>Set</literal>."
 msgstr ""
-"一个查询通常在调用<literal>list()</literal>时被执行,执行结果会完全装载进内存"
-"中的一个集合(collection)。 查询返回的对象处于持久(persistent)状态。如果你知道"
-"的查询只会返回一个对象,可使用<literal>list()</literal>的快捷方式"
-"<literal>uniqueResult()</literal>。 注意,使用集合预先抓取的查询往往会返回多"
-"次根对象(他们的集合类都被初始化了)。你可以通过一个集合来过滤这些重复对象。"
+"一个查询通常在调用 <literal>list()</literal> 时被执行,执行结果会完全装载进内"
+"存中的一个集合(collection)。查询返回的对象处于持久(persistent)状态。如果"
+"你知道的查询只会返回一个对象,可使用 <literal>list()</literal> 的快捷方式 "
+"<literal>uniqueResult()</literal>。注意,使用集合预先抓取的查询往往会返回多次"
+"根对象(他们的集合类都被初始化了)。你可以通过一个<literal>集合(Set)</"
+"literal>来过滤这些重复对象。"
 
 #. Tag: title
-#: session_api.xml:278
 #, no-c-format
 msgid "Iterating results"
-msgstr "迭代式获取结果(Iterating results)"
+msgstr "迭代式获取结果(Iterating results)"
 
 #. Tag: para
-#: session_api.xml:280
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Occasionally, you might be able to achieve better performance by executing "
 "the query using the <literal>iterate()</literal> method. This will usually "
@@ -549,113 +416,51 @@
 "returns identifiers, and <emphasis>n</emphasis> additional selects to "
 "initialize the actual instances."
 msgstr ""
-"某些情况下,你可以使用<literal>iterate()</literal>方法得到更好的性能。 这通常"
-"是你预期返回的结果在session,或二级缓存(second-level cache)中已经存在时的情"
-"况。 如若不然,<literal>iterate()</literal>会比<literal>list()</literal>慢,"
-"而且可能简单查询也需要进行多次数据库访问: <literal>iterate()</literal>会首先"
-"使用<emphasis>1</emphasis>条语句得到所有对象的持久化标识(identifiers),再根据"
-"持久化标识执行<emphasis>n</emphasis>条附加的select语句实例化实际的对象。"
+"某些情况下,你可以使用 <literal>iterate()</literal> 方法得到更好的性能。 这通"
+"常是你预期返回的结果在 session,或二级缓存(second-level cache)中已经存在时"
+"的情况。如若不然,<literal>iterate()</literal> 会比 <literal>list()</"
+"literal> 慢,而且可能简单查询也需要进行多次数据库访问:<literal>iterate()</"
+"literal> 会首先使用 <emphasis>1</emphasis> 条语句得到所有对象的持久化标识"
+"(identifiers),再根据持久化标识执行 <emphasis>n</emphasis> 条附加的 select "
+"语句实例化实际的对象。 "
 
-#. Tag: programlisting
-#: session_api.xml:292
-#, no-c-format
-msgid ""
-"<![CDATA[// fetch ids\n"
-"Iterator iter = sess.createQuery(\"from eg.Qux q order by q.likeliness\")."
-"iterate();\n"
-"while ( iter.hasNext() ) {\n"
-"    Qux qux = (Qux) iter.next();  // fetch the object\n"
-"    // something we couldnt express in the query\n"
-"    if ( qux.calculateComplicatedAlgorithm() ) {\n"
-"        // delete the current instance\n"
-"        iter.remove();\n"
-"        // dont need to process the rest\n"
-"        break;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:296
 #, no-c-format
 msgid "Queries that return tuples"
-msgstr "返回元组(tuples)的查询"
+msgstr "返回元组(tuples)的查询"
 
 #. Tag: para
-#: session_api.xml:298
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate queries sometimes return tuples of objects. Each tuple is returned "
 "as an array:"
 msgstr ""
-"(译注:元组(tuples)指一条结果行包含多个对象) Hibernate查询有时返回元组"
-"(tuples),每个元组(tuples)以数组的形式返回:"
+"(译注:元组(tuples)指一条结果行包含多个对象) Hibernate 查询有时返回元组"
+"(tuples),每个元组(tuples)以数组的形式返回: "
 
-#. Tag: programlisting
-#: session_api.xml:303
-#, no-c-format
-msgid ""
-"<![CDATA[Iterator kittensAndMothers = sess.createQuery(\n"
-"            \"select kitten, mother from Cat kitten join kitten.mother mother"
-"\")\n"
-"            .list()\n"
-"            .iterator();\n"
-"\n"
-"while ( kittensAndMothers.hasNext() ) {\n"
-"    Object[] tuple = (Object[]) kittensAndMothers.next();\n"
-"    Cat kitten = (Cat) tuple[0];\n"
-"    Cat mother = (Cat) tuple[1];\n"
-"    ....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:308
 #, no-c-format
 msgid "Scalar results"
-msgstr "标量(Scalar)结果"
+msgstr "标量(Scalar)结果"
 
 #. Tag: para
-#: session_api.xml:310
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Queries can specify a property of a class in the <literal>select</literal> "
 "clause. They can even call SQL aggregate functions. Properties or aggregates "
 "are considered \"scalar\" results and not entities in persistent state."
 msgstr ""
-"查询可在<literal>select</literal>从句中指定类的属性,甚至可以调用SQL统计"
-"(aggregate)函数。 属性或统计结果被认定为\"标量(Scalar)\"的结果(而不是持久"
-"(persistent state)的实体)。"
+"查询可在 <literal>select</literal> 从句中指定类的属性,甚至可以调用 SQL 统计"
+"(aggregate)函数。属性或统计结果被认定为\"标量(Scalar)\"的结果(而不是持久"
+"(persistent state)的实体)。 "
 
-#. Tag: programlisting
-#: session_api.xml:316
-#, no-c-format
-msgid ""
-"<![CDATA[Iterator results = sess.createQuery(\n"
-"        \"select cat.color, min(cat.birthdate), count(cat) from Cat cat \" "
-"+\n"
-"        \"group by cat.color\")\n"
-"        .list()\n"
-"        .iterator();\n"
-"\n"
-"while ( results.hasNext() ) {\n"
-"    Object[] row = (Object[]) results.next();\n"
-"    Color type = (Color) row[0];\n"
-"    Date oldest = (Date) row[1];\n"
-"    Integer count = (Integer) row[2];\n"
-"    .....\n"
-"}]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:321
 #, no-c-format
 msgid "Bind parameters"
 msgstr "绑定参数"
 
 #. Tag: para
-#: session_api.xml:323
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Methods on <literal>Query</literal> are provided for binding values to named "
 "parameters or JDBC-style <literal>?</literal> parameters. <emphasis>Contrary "
@@ -663,223 +468,113 @@
 "are identifiers of the form <literal>:name</literal> in the query string. "
 "The advantages of named parameters are as follows:"
 msgstr ""
-"接口<literal>Query</literal>提供了对命名参数(named parameters)、JDBC风格的"
-"<literal>问号(?)</literal>参数进行绑定的方法。 <emphasis>不同于JDBC,"
-"Hibernate对参数从0开始计数。</emphasis> 命名参数(named parameters)在查询字符"
-"串中是形如<literal>:name</literal>的标识符。 命名参数(named parameters)的优点"
-"是:"
+"接口 <literal>Query</literal> 提供了对命名参数(named parameters)、JDBC 风格"
+"的<literal>问号(?)</literal>参数进行绑定的方法。<emphasis>不同于 JDBC,"
+"Hibernate 对参数从 0 开始计数。</emphasis> 命名参数(named parameters)在查询"
+"字符串中是形如 <literal>:name</literal> 的标识符。命名参数(named "
+"parameters)的优点是: "
 
 #. Tag: para
-#: session_api.xml:333
 #, no-c-format
 msgid ""
 "named parameters are insensitive to the order they occur in the query string"
-msgstr "命名参数(named parameters)与其在查询串中出现的顺序无关"
+msgstr "命名参数(named parameters)与其在查询串中出现的顺序无关"
 
 #. Tag: para
-#: session_api.xml:339
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "they can occur multiple times in the same query"
-msgstr "它们可在同一查询串中多次出现"
+msgstr "它们可在同一查询串中多次出现 "
 
 #. Tag: para
-#: session_api.xml:344
 #, no-c-format
 msgid "they are self-documenting"
 msgstr "它们本身是自我说明的"
 
-#. Tag: programlisting
-#: session_api.xml:350
-#, no-c-format
-msgid ""
-"<![CDATA[//named parameter (preferred)\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name = :name"
-"\");\n"
-"q.setString(\"name\", \"Fritz\");\n"
-"Iterator cats = q.iterate();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:352
-#, no-c-format
-msgid ""
-"<![CDATA[//positional parameter\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name = ?\");\n"
-"q.setString(0, \"Izi\");\n"
-"Iterator cats = q.iterate();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:354
-#, no-c-format
-msgid ""
-"<![CDATA[//named parameter list\n"
-"List names = new ArrayList();\n"
-"names.add(\"Izi\");\n"
-"names.add(\"Fritz\");\n"
-"Query q = sess.createQuery(\"from DomesticCat cat where cat.name in (:"
-"namesList)\");\n"
-"q.setParameterList(\"namesList\", names);\n"
-"List cats = q.list();]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:359
 #, no-c-format
 msgid "Pagination"
 msgstr "分页"
 
 #. Tag: para
-#: session_api.xml:361
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you need to specify bounds upon your result set, that is, the maximum "
 "number of rows you want to retrieve and/or the first row you want to "
 "retrieve, you can use methods of the <literal>Query</literal> interface:"
 msgstr ""
-"如果你需要指定结果集的范围(希望返回的最大行数/或开始的行数),应该使用"
-"<literal>Query</literal>接口提供的方法:"
+"如果你需要指定结果集的范围(希望返回的最大行数/或开始的行数),应该使用 "
+"<literal>Query</literal> 接口提供的方法: "
 
-#. Tag: programlisting
-#: session_api.xml:367
-#, no-c-format
-msgid ""
-"<![CDATA[Query q = sess.createQuery(\"from DomesticCat cat\");\n"
-"q.setFirstResult(20);\n"
-"q.setMaxResults(10);\n"
-"List cats = q.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:369
 #, no-c-format
 msgid ""
 "Hibernate knows how to translate this limit query into the native SQL of "
 "your DBMS."
 msgstr ""
-"Hibernate 知道如何将这个有限定条件的查询转换成你的数据库的原生SQL(native "
-"SQL)。"
+"Hibernate 知道如何将这个有限定条件的查询转换成你的数据库的原生 SQL(native "
+"SQL)。"
 
 #. Tag: title
-#: session_api.xml:377
 #, no-c-format
 msgid "Scrollable iteration"
-msgstr "可滚动遍历(Scrollable iteration)"
+msgstr "可滚动遍历(Scrollable iteration)"
 
 #. Tag: para
-#: session_api.xml:379
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your JDBC driver supports scrollable <literal>ResultSet</literal>s, the "
 "<literal>Query</literal> interface can be used to obtain a "
 "<literal>ScrollableResults</literal> object that allows flexible navigation "
 "of the query results."
 msgstr ""
-"如果你的JDBC驱动支持可滚动的<literal>ResuleSet</literal>,<literal>Query</"
-"literal>接口可以使用<literal>ScrollableResults</literal>,允许你在查询结果中"
-"灵活游走。"
+"如果你的 JDBC 驱动支持可滚动的 <literal>ResuleSet</literal>,<literal>Query</"
+"literal> 接口可以使用 <literal>ScrollableResults</literal>,允许你在查询结果"
+"中灵活游走。 "
 
-#. Tag: programlisting
-#: session_api.xml:386
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Query q = sess.createQuery(\"select cat.name, cat from DomesticCat "
-"cat \" +\n"
-"                            \"order by cat.name\");\n"
-"ScrollableResults cats = q.scroll();\n"
-"if ( cats.first() ) {\n"
-"\n"
-"    // find the first name on each page of an alphabetical list of cats by "
-"name\n"
-"    firstNamesOfPages = new ArrayList();\n"
-"    do {\n"
-"        String name = cats.getString(0);\n"
-"        firstNamesOfPages.add(name);\n"
-"    }\n"
-"    while ( cats.scroll(PAGE_SIZE) );\n"
-"\n"
-"    // Now get the first page of cats\n"
-"    pageOfCats = new ArrayList();\n"
-"    cats.beforeFirst();\n"
-"    int i=0;\n"
-"    while( ( PAGE_SIZE > i++ ) && cats.next() ) pageOfCats.add( cats.get"
-"(1) );\n"
-"\n"
-"}\n"
-"cats.close()]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:388
-#, fuzzy, no-c-format
-msgid ""
 "Note that an open database connection and cursor is required for this "
 "functionality. Use <literal>setMaxResult()</literal>/<literal>setFirstResult"
 "()</literal> if you need offline pagination functionality."
 msgstr ""
-"请注意,使用此功能需要保持数据库连接(以及游标(cursor))处于一直打开状态。 如"
-"果你需要断开连接使用分页功能,请使用<literal>setMaxResult()</literal>/"
-"<literal>setFirstResult()</literal>"
+"请注意,使用此功能需要保持数据库连接(以及游标(cursor))处于一直打开状态。"
+"如果你需要断开连接使用分页功能,请使用 <literal>setMaxResult()</literal>/"
+"<literal>setFirstResult()</literal>。 "
 
 #. Tag: title
-#: session_api.xml:397
 #, no-c-format
 msgid "Externalizing named queries"
-msgstr "外置命名查询(Externalizing named queries)"
+msgstr "外置命名查询(Externalizing named queries)"
 
 #. Tag: para
-#: session_api.xml:399
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also define named queries in the mapping document. Remember to use a "
 "<literal>CDATA</literal> section if your query contains characters that "
 "could be interpreted as markup."
 msgstr ""
-"你可以在映射文件中定义命名查询(named queries)。 (如果你的查询串中包含可能被"
-"解释为XML标记(markup)的字符,别忘了用<literal>CDATA</literal>包裹起来。)"
+"你可以在映射文件中定义命名查询(named queries)。如果你的查询串中包含可能被解"
+"释为 XML 标记(markup)的字符,别忘了用<literal>CDATA</literal>包裹起来。"
 
-#. Tag: programlisting
-#: session_api.xml:405
-#, no-c-format
-msgid ""
-"<![CDATA[<query name=\"ByNameAndMaximumWeight\"><![CDATA[\n"
-"    from eg.DomesticCat as cat\n"
-"        where cat.name = ?\n"
-"        and cat.weight > ?\n"
-"] ]></query>]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:407
 #, no-c-format
 msgid "Parameter binding and executing is done programatically:"
-msgstr "参数绑定及执行以编程方式(programatically)完成:"
+msgstr "参数绑定及执行以编程方式(programatically)完成:"
 
-#. Tag: programlisting
-#: session_api.xml:411
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Query q = sess.getNamedQuery(\"ByNameAndMaximumWeight\");\n"
-"q.setString(0, name);\n"
-"q.setInt(1, minWeight);\n"
-"List cats = q.list();]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:413
-#, fuzzy, no-c-format
-msgid ""
 "The actual program code is independent of the query language that is used. "
 "You can also define native SQL queries in metadata, or migrate existing "
 "queries to Hibernate by placing them in mapping files."
 msgstr ""
-"请注意实际的程序代码与所用的查询语言无关,你也可在元数据中定义原生SQL(native "
-"SQL)查询, 或将原有的其他的查询语句放在配置文件中,这样就可以让Hibernate统一"
-"管理,达到迁移的目的。"
+"请注意实际的程序代码与所用的查询语言无关,你也可在元数据中定义原生 SQL"
+"(native SQL)查询,或将原有的其他的查询语句放在配置文件中,这样就可以让 "
+"Hibernate 统一管理,达到迁移的目的。 "
 
 #. Tag: para
-#: session_api.xml:419
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Also note that a query declaration inside a <literal>&lt;hibernate-"
 "mapping&gt;</literal> element requires a global unique name for the query, "
@@ -887,142 +582,90 @@
 "is made unique automatically by prepending the fully qualified name of the "
 "class. For example <literal>eg.Cat.ByNameAndMaximumWeight</literal>."
 msgstr ""
-"也请注意在<literal>&lt;hibernate-mapping&gt;</literal>元素中声明的查询必须有"
-"一个全局唯一的名字,而在<literal>&lt;class&gt;</literal>元素中声明的查询自动具"
-"有全局名,是通过类的全名加以限定的。比如<literal>eg.Cat."
-"ByNameAndMaximumWeight</literal>。"
+"也请注意在 <literal>&lt;hibernate-mapping&gt;</literal> 元素中声明的查询必须"
+"有一个全局唯一的名字,而在 <literal>&lt;class&gt;</literal> 元素中声明的查询自"
+"动具有全局名,是通过类的全名加以限定的。比如 <literal>eg.Cat."
+"ByNameAndMaximumWeight</literal>。 "
 
 #. Tag: title
-#: session_api.xml:432
 #, no-c-format
 msgid "Filtering collections"
 msgstr "过滤集合"
 
 #. Tag: para
-#: session_api.xml:433
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A collection <emphasis>filter</emphasis> is a special type of query that can "
 "be applied to a persistent collection or array. The query string can refer "
 "to <literal>this</literal>, meaning the current collection element."
 msgstr ""
-"集合<emphasis>过滤器(filter)</emphasis>是一种用于一个持久化集合或者数组的特殊"
-"的查询。查询字符串中可以使用<literal>\"this\"</literal>来引用集合中的当前元"
-"素。"
+"集合<emphasis>过滤器(filter)</emphasis>是一种用于一个持久化集合或者数组的特"
+"殊的查询。查询字符串中可以使用 <literal>\"this\"</literal> 来引用集合中的当前"
+"元素。 "
 
-#. Tag: programlisting
-#: session_api.xml:439
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Collection blackKittens = session.createFilter(\n"
-"    pk.getKittens(), \n"
-"    \"where this.color = ?\")\n"
-"    .setParameter( Color.BLACK, Hibernate.custom(ColorUserType.class) )\n"
-"    .list()\n"
-");]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:441
-#, fuzzy, no-c-format
-msgid ""
 "The returned collection is considered a bag that is a copy of the given "
 "collection. The original collection is not modified. This is contrary to the "
 "implication of the name \"filter\", but consistent with expected behavior."
 msgstr ""
-"返回的集合可以被认为是一个包(bag, 无顺序可重复的集合(collection)),它是所给集"
-"合的副本。 原来的集合不会被改动(这与“过滤器(filter)”的隐含的含义不符,不过与"
-"我们期待的行为一致)。"
+"返回的集合可以被认为是一个包(bag,无顺序可重复的集合(collection)),它是所"
+"给集合的副本。 原来的集合不会被改动(这与“过滤器(filter)”的隐含的含义不符,"
+"不过与我们期待的行为一致)。 "
 
 #. Tag: para
-#: session_api.xml:447
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Observe that filters do not require a <literal>from</literal> clause, "
 "although they can have one if required. Filters are not limited to returning "
 "the collection elements themselves."
 msgstr ""
-"请注意过滤器(filter)并不需要<literal>from</literal>子句(当然需要的话它们也可"
-"以加上)。过滤器(filter)不限定于只能返回集合元素本身。"
+"请注意过滤器(filter)并不需要 <literal>from</literal> 子句(当然需要的话它们"
+"也可以加上)。过滤器(filter)不限定于只能返回集合元素本身。 "
 
-#. Tag: programlisting
-#: session_api.xml:452
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Collection blackKittenMates = session.createFilter(\n"
-"    pk.getKittens(), \n"
-"    \"select this.mate where this.color = eg.Color.BLACK.intValue\")\n"
-"    .list();]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:454
-#, fuzzy, no-c-format
-msgid ""
 "Even an empty filter query is useful, e.g. to load a subset of elements in a "
 "large collection:"
 msgstr ""
-"即使无条件的过滤器(filter)也是有意义的。例如,用于加载一个大集合的子集:"
+"即使无条件的过滤器(filter)也是有意义的。例如,用于加载一个大集合的子集: "
 
-#. Tag: programlisting
-#: session_api.xml:459
-#, no-c-format
-msgid ""
-"<![CDATA[Collection tenKittens = session.createFilter(\n"
-"    mother.getKittens(), \"\")\n"
-"    .setFirstResult(0).setMaxResults(10)\n"
-"    .list();]]>"
-msgstr ""
-
 #. Tag: title
-#: session_api.xml:464
 #, no-c-format
 msgid "Criteria queries"
-msgstr "条件查询(Criteria queries)"
+msgstr "条件查询(Criteria queries)"
 
 #. Tag: para
-#: session_api.xml:466
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "HQL is extremely powerful, but some developers prefer to build queries "
 "dynamically using an object-oriented API, rather than building query "
 "strings. Hibernate provides an intuitive <literal>Criteria</literal> query "
 "API for these cases:"
 msgstr ""
-"HQL极为强大,但是有些人希望能够动态的使用一种面向对象API创建查询,而非在他们"
-"的Java代码中嵌入字符串。对于那部分人来说,Hibernate提供了直观的"
-"<literal>Criteria</literal>查询API。"
+"HQL 极为强大,但是有些人希望能够动态的使用一种面向对象 API 创建查询,而非在他"
+"们的 Java 代码中嵌入字符串。对于那部分人来说,Hibernate 提供了直观的 "
+"<literal>Criteria</literal> 查询 API。 "
 
-#. Tag: programlisting
-#: session_api.xml:472
-#, no-c-format
-msgid ""
-"<![CDATA[Criteria crit = session.createCriteria(Cat.class);\n"
-"crit.add( Restrictions.eq( \"color\", eg.Color.BLACK ) );\n"
-"crit.setMaxResults(10);\n"
-"List cats = crit.list();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:474
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The <literal>Criteria</literal> and the associated <literal>Example</"
-"literal> API are discussed in more detail in <xref linkend=\"querycriteria\"/"
-">."
+"literal> API are discussed in more detail in <xref linkend=\"querycriteria"
+"\" />."
 msgstr ""
-"<literal>Criteria</literal>以及相关的<literal>样例(Example)</literal>API将会"
-"再<xref linkend=\"querycriteria\"/>中详细讨论。"
+"<literal>Criteria</literal> 以及相关的<literal>样例(Example)</literal>API "
+"将会在 <xref linkend=\"querycriteria\"/> 中详细讨论。 "
 
 #. Tag: title
-#: session_api.xml:482
 #, no-c-format
 msgid "Queries in native SQL"
-msgstr "使用原生SQL的查询"
+msgstr "使用原生 SQL 的查询"
 
 #. Tag: para
-#: session_api.xml:484
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can express a query in SQL, using <literal>createSQLQuery()</literal> "
 "and let Hibernate manage the mapping from result sets to objects. You can at "
@@ -1030,54 +673,29 @@
 "<literal>Connection</literal> directly. If you choose to use the Hibernate "
 "API, you must enclose SQL aliases in braces:"
 msgstr ""
-"你可以使用<literal>createSQLQuery()</literal>方法,用SQL来描述查询,并由"
-"Hibernate将结果集转换成对象。 请注意,你可以在任何时候调用<literal>session."
-"connection()</literal>来获得并使用JDBC <literal>Connection</literal>对象。 如"
-"果你选择使用Hibernate的API, 你必须把SQL别名用大括号包围起来:"
+"你可以使用 <literal>createSQLQuery()</literal> 方法,用 SQL 来描述查询,并由 "
+"Hibernate 将结果集转换成对象。请注意,你可以在任何时候调用 <literal>session."
+"connection()</literal> 来获得并使用 JDBC <literal>Connection</literal> 对"
+"象。 如果你选择使用 Hibernate 的 API,你必须把 SQL 别名用大括号包围起来: "
 
-#. Tag: programlisting
-#: session_api.xml:492
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = session.createSQLQuery(\"SELECT {cat.*} FROM CAT {cat} "
-"WHERE ROWNUM<10\")\n"
-"    .addEntity(\"cat\", Cat.class)\n"
-".list();]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: session_api.xml:494
-#, no-c-format
-msgid ""
-"<![CDATA[List cats = session.createSQLQuery(\n"
-"    \"SELECT {cat}.ID AS {cat.id}, {cat}.SEX AS {cat.sex}, \" +\n"
-"           \"{cat}.MATE AS {cat.mate}, {cat}.SUBCLASS AS {cat.class}, ... \" "
-"+\n"
-"    \"FROM CAT {cat} WHERE ROWNUM<10\")\n"
-"    .addEntity(\"cat\", Cat.class)\n"
-".list()]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:496
 #, fuzzy, no-c-format
 msgid ""
 "SQL queries can contain named and positional parameters, just like Hibernate "
 "queries. More information about native SQL queries in Hibernate can be found "
-"in <xref linkend=\"querysql\"/>."
+"in <xref linkend=\"querysql\" />."
 msgstr ""
-"和Hibernate查询一样,SQL查询也可以包含命名参数和占位参数。 可以在<xref "
-"linkend=\"querysql\"/>找到更多关于Hibernate中原生SQL(native SQL)的信息。"
+"和 Hibernate 查询一样,SQL 查询也可以包含命名参数和占位参数。可以在 <xref "
+"linkend=\"querysql\"/> 找到更多关于 Hibernate 中原生 SQL(native SQL)的信"
+"息。 "
 
 #. Tag: title
-#: session_api.xml:507
 #, no-c-format
 msgid "Modifying persistent objects"
 msgstr "修改持久对象"
 
 #. Tag: para
-#: session_api.xml:509
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Transactional persistent instances</emphasis> (i.e. objects "
 "loaded, saved, created or queried by the <literal>Session</literal>) can be "
@@ -1089,39 +707,28 @@
 "to update the state of an object is to <literal>load()</literal> it and then "
 "manipulate it directly while the <literal>Session</literal> is open:"
 msgstr ""
-"<emphasis>事务中的持久实例</emphasis>(就是通过<literal>session</literal>装"
-"载、保存、创建或者查询出的对象) 被应用程序操作所造成的任何修改都会在"
-"<literal>Session</literal>被<emphasis>刷出(flushed)</emphasis>的时候被持久"
-"化(本章后面会详细讨论)。 这里不需要调用某个特定的方法(比如<literal>update"
-"()</literal>,设计它的目的是不同的)将你的修改持久化。 所以最直接的更新一个对"
-"象的方法就是在<literal>Session</literal>处于打开状态时<literal>load()</"
-"literal>它,然后直接修改即可:"
+"<emphasis>事务中的持久实例</emphasis>(就是通过 <literal>session</literal> 装"
+"载、保存、创建或者查询出的对象) 被应用程序操作所造成的任何修改都会在 "
+"<literal>Session</literal> 被<emphasis>刷出(flushed)</emphasis>的时候被持久"
+"化(本章后面会详细讨论)。这里不需要调用某个特定的方法(比如 <literal>update"
+"()</literal>,设计它的目的是不同的)将你的修改持久化。所以最直接的更新一个对"
+"象的方法就是在 <literal>Session</literal> 处于打开状态时 <literal>load()</"
+"literal> 它,然后直接修改即可: "
 
-#. Tag: programlisting
-#: session_api.xml:520
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[DomesticCat cat = (DomesticCat) sess.load( Cat.class, new Long"
-"(69) );\n"
-"cat.setName(\"PK\");\n"
-"sess.flush();  // changes to cat are automatically detected and persisted]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:522
-#, fuzzy, no-c-format
-msgid ""
 "Sometimes this programming model is inefficient, as it requires in the same "
 "session both an SQL <literal>SELECT</literal> to load an object and an SQL "
 "<literal>UPDATE</literal> to persist its updated state. Hibernate offers an "
 "alternate approach by using detached instances."
 msgstr ""
-"有时这种程序模型效率低下,因为它在同一Session里需要一条SQL <literal>SELECT</"
-"literal>语句(用于加载对象) 以及一条SQL <literal>UPDATE</literal>语句(持久化"
-"更新的状态)。 为此Hibernate提供了另一种途径,使用脱管(detached)实例。"
+"有时这种程序模型效率低下,因为它在同一 Session 里需要一条 SQL "
+"<literal>SELECT</literal> 语句(用于加载对象) 以及一条 SQL <literal>UPDATE</"
+"literal> 语句(持久化更新的状态)。为此  Hibernate 提供了另一种途径,使用脱管"
+"(detached)实例。 "
 
 #. Tag: para
-#: session_api.xml:529
 #, fuzzy, no-c-format
 msgid ""
 "Hibernate does not offer its own API for direct execution of "
@@ -1133,24 +740,24 @@
 "the notion of mass operations conflicts with object/relational mapping for "
 "online transaction processing-oriented applications. Future versions of "
 "Hibernate can, however, provide special mass operation functions. See <xref "
-"linkend=\"batch\"/> for some possible batch operation tricks."
+"linkend=\"batch\" /> for some possible batch operation tricks."
 msgstr ""
-"请注意Hibernate本身不提供直接执行<placeholder-1/>或<placeholder-2/>语句的"
-"API。 Hibernate提供的是<placeholder-3/>服务,你不必考虑要使用的<placeholder-"
-"4/>。 JDBC是出色的执行SQL语句的API,任何时候调用<placeholder-5/>你都可以得到"
-"一个JDBC <placeholder-6/>对象。 此外,在联机事务处理(OLTP)程序中,大量操作"
-"(mass operations)与对象/关系映射的观点是相冲突的。 Hibernate的将来版本可能会"
-"提供专门的进行大量操作(mass operation)的功能。 参考<xref linkend=\"batch\"/"
-">,寻找一些可用的批量(batch)操作技巧。"
+"请注意 Hibernate 本身不提供直接执行 <literal>UPDATE</literal> 或 "
+"<literal>DELETE</literal> 语句的 API。Hibernate 提供的是 <emphasis>state "
+"management</emphasis> 服务,你不必考虑要使用的 <emphasis>statements</"
+"emphasis>。JDBC 是出色的执行 SQL 语句的  API,任何时候调用  <literal>session."
+"connection()</literal> 你都可以得到一个 <literal>Connection</literal> 对象。 "
+"此外,在联机事务处理(OLTP)程序中,大量操作(mass operations)与对象/关系映"
+"射的观点是相冲突的。Hibernate 的将来版本可能会提供专门的进行大量操作(mass "
+"operation)的功能。参考 <xref linkend=\"batch\"/>,寻找一些可用的批量"
+"(batch)操作技巧。 "
 
 #. Tag: title
-#: session_api.xml:546
 #, no-c-format
 msgid "Modifying detached objects"
-msgstr "修改脱管(Detached)对象"
+msgstr "修改脱管(Detached)对象"
 
 #. Tag: para
-#: session_api.xml:548
 #, no-c-format
 msgid ""
 "Many applications need to retrieve an object in one transaction, send it to "
@@ -1160,52 +767,32 @@
 "unit of work."
 msgstr ""
 "很多程序需要在某个事务中获取对象,然后将对象发送到界面层去操作,最后在一个新"
-"的事务保存所做的修改。 在高并发访问的环境中使用这种方式,通常使用附带版本信息"
+"的事务保存所做的修改。在高并发访问的环境中使用这种方式,通常使用附带版本信息"
 "的数据来保证这些“长“工作单元之间的隔离。"
 
 #. Tag: para
-#: session_api.xml:555
 #, no-c-format
 msgid ""
 "Hibernate supports this model by providing for reattachment of detached "
 "instances using the <literal>Session.update()</literal> or <literal>Session."
 "merge()</literal> methods:"
 msgstr ""
-"Hibernate通过提供<literal>Session.update()</literal>或<literal>Session.merge"
-"()</literal> 重新关联脱管实例的办法来支持这种模型。"
+"Hibernate 通过提供 <literal>Session.update()</literal> 或 <literal>Session."
+"merge()</literal>  重新关联脱管实例的办法来支持这种模型。"
 
-#. Tag: programlisting
-#: session_api.xml:561
-#, no-c-format
-msgid ""
-"<![CDATA[// in the first session\n"
-"Cat cat = (Cat) firstSession.load(Cat.class, catId);\n"
-"Cat potentialMate = new Cat();\n"
-"firstSession.save(potentialMate);\n"
-"\n"
-"// in a higher layer of the application\n"
-"cat.setMate(potentialMate);\n"
-"\n"
-"// later, in a new session\n"
-"secondSession.update(cat);  // update cat\n"
-"secondSession.update(mate); // update mate]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:563
 #, no-c-format
 msgid ""
 "If the <literal>Cat</literal> with identifier <literal>catId</literal> had "
 "already been loaded by <literal>secondSession</literal> when the application "
 "tried to reattach it, an exception would have been thrown."
 msgstr ""
-"如果具有<literal>catId</literal>持久化标识的<literal>Cat</literal>之前已经被"
-"<literal>另一Session(secondSession)</literal>装载了, 应用程序进行重关联操作"
-"(reattach)的时候会抛出一个异常。"
+"如果具有 <literal>catId</literal> 持久化标识的 <literal>Cat</literal> 之前已"
+"经被<literal>另一Session(secondSession)</literal>装载了, 应用程序进行重关"
+"联操作(reattach)的时候会抛出一个异常。"
 
 #. Tag: para
-#: session_api.xml:569
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Use <literal>update()</literal> if you are certain that the session does not "
 "contain an already persistent instance with the same identifier. Use "
@@ -1215,82 +802,64 @@
 "fresh session, ensuring that the reattachment of your detached instances is "
 "the first operation that is executed."
 msgstr ""
-"如果你确定当前session没有包含与之具有相同持久化标识的持久实例,使用"
-"<literal>update()</literal>。 如果想随时合并你的的改动而不考虑session的状态,"
-"使用<literal>merge()</literal>。 换句话说,在一个新session中通常第一个调用的"
-"是<literal>update()</literal>方法,以便保证重新关联脱管(detached)对象的操作首"
-"先被执行。"
+"如果你确定当前 session 没有包含与之具有相同持久化标识的持久实例,使用 "
+"<literal>update()</literal>。如果想随时合并你的的改动而不考虑 session 的状"
+"态,使用 <literal>merge()</literal>。换句话说,在一个新 session 中通常第一个"
+"调用的是 <literal>update()</literal> 方法,以便保证重新关联脱管(detached)对"
+"象的操作首先被执行。 "
 
 #. Tag: para
-#: session_api.xml:578
 #, fuzzy, no-c-format
 msgid ""
 "The application should individually <literal>update()</literal> detached "
 "instances that are reachable from the given detached instance "
 "<emphasis>only</emphasis> if it wants their state to be updated. This can be "
 "automated using <emphasis>transitive persistence</emphasis>. See <xref "
-"linkend=\"objectstate-transitive\"/> for more information."
+"linkend=\"objectstate-transitive\" /> for more information."
 msgstr ""
 "如果希望相关联的脱管对象(通过引用“可到达”的脱管对象)的数据也要更新到数据库"
-"时(并且也<emphasis>仅仅</emphasis>在这种情况), 可以对该相关联的脱管对象单"
-"独调用<literal>update()</literal> 当然这些可以自动完成,即通过使用<emphasis>"
-"传播性持久化(transitive persistence)</emphasis>,请看<xref linkend="
-"\"objectstate-transitive\"/>。"
+"时(并且也<emphasis>仅仅</emphasis>在这种情况),可以对该相关联的脱管对象单独"
+"调用 <literal>update()</literal> 当然这些可以自动完成,即通过使用<emphasis>传"
+"播性持久化(transitive persistence)</emphasis>,请看 <xref linkend="
+"\"objectstate-transitive\"/>。 "
 
 #. Tag: para
-#: session_api.xml:585
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>lock()</literal> method also allows an application to "
 "reassociate an object with a new session. However, the detached instance has "
 "to be unmodified."
 msgstr ""
-"<literal>lock()</literal>方法也允许程序重新关联某个对象到一个新session上。不"
-"过,该脱管(detached)的对象必须是没有修改过的!"
+"<literal>lock()</literal> 方法也允许程序重新关联某个对象到一个新 session 上。"
+"不过,该脱管(detached)的对象必须是没有修改过的。"
 
-#. Tag: programlisting
-#: session_api.xml:590
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[//just reassociate:\n"
-"sess.lock(fritz, LockMode.NONE);\n"
-"//do a version check, then reassociate:\n"
-"sess.lock(izi, LockMode.READ);\n"
-"//do a version check, using SELECT ... FOR UPDATE, then reassociate:\n"
-"sess.lock(pk, LockMode.UPGRADE);]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:592
-#, fuzzy, no-c-format
-msgid ""
 "Note that <literal>lock()</literal> can be used with various "
 "<literal>LockMode</literal>s. See the API documentation and the chapter on "
 "transaction handling for more information. Reattachment is not the only "
 "usecase for <literal>lock()</literal>."
 msgstr ""
-"请注意,<literal>lock()</literal>可以搭配多种<literal>LockMode</literal>, 更"
-"多信息请阅读API文档以及关于事务处理(transaction handling)的章节。重新关联不是"
-"<literal>lock()</literal>的唯一用途。"
+"请注意,<literal>lock()</literal> 可以搭配多种 <literal>LockMode</literal>,"
+"更多信息请阅读 API 文档以及关于事务处理(transaction handling)的章节。重新关"
+"联不是 <literal>lock()</literal> 的唯一用途。 "
 
 #. Tag: para
-#: session_api.xml:599
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "Other models for long units of work are discussed in <xref linkend="
-"\"transactions-optimistic\"/>."
+"\"transactions-optimistic\" />."
 msgstr ""
-"其他用于长时间工作单元的模型会在<xref linkend=\"transactions-optimistic\"/>中"
-"讨论。"
+"其他用于长时间工作单元的模型会在 <xref linkend=\"transactions-optimistic\"/> "
+"中讨论。 "
 
 #. Tag: title
-#: session_api.xml:606
 #, no-c-format
 msgid "Automatic state detection"
 msgstr "自动状态检测"
 
 #. Tag: para
-#: session_api.xml:608
 #, no-c-format
 msgid ""
 "Hibernate users have requested a general purpose method that either saves a "
@@ -1298,30 +867,11 @@
 "detached instances associated with its current identifier. The "
 "<literal>saveOrUpdate()</literal> method implements this functionality."
 msgstr ""
-"Hibernate的用户曾要求一个既可自动分配新持久化标识(identifier)保存瞬时"
-"(transient)对象,又可更新/重新关联脱管(detached)实例的通用方法。 "
-"<literal>saveOrUpdate()</literal>方法实现了这个功能。"
+"Hibernate 的用户曾要求一个既可自动分配新持久化标识(identifier)保存瞬时"
+"(transient)对象,又可更新/重新关联脱管(detached)实例的通用方法。"
+"<literal>saveOrUpdate()</literal> 方法实现了这个功能。"
 
-#. Tag: programlisting
-#: session_api.xml:615
-#, no-c-format
-msgid ""
-"<![CDATA[// in the first session\n"
-"Cat cat = (Cat) firstSession.load(Cat.class, catID);\n"
-"\n"
-"// in a higher tier of the application\n"
-"Cat mate = new Cat();\n"
-"cat.setMate(mate);\n"
-"\n"
-"// later, in a new session\n"
-"secondSession.saveOrUpdate(cat);   // update existing state (cat has a non-"
-"null id)\n"
-"secondSession.saveOrUpdate(mate);  // save the new instance (mate has a null "
-"id)]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:617
 #, no-c-format
 msgid ""
 "The usage and semantics of <literal>saveOrUpdate()</literal> seems to be "
@@ -1331,178 +881,153 @@
 "<literal>merge()</literal>. Some whole applications will never use either of "
 "these methods."
 msgstr ""
-"<literal>saveOrUpdate()</literal>用途和语义可能会使新用户感到迷惑。 首先,只"
-"要你没有尝试在某个session中使用来自另一session的实例,你就应该不需要使用"
-"<literal>update()</literal>, <literal>saveOrUpdate()</literal>,或"
+"<literal>saveOrUpdate()</literal> 用途和语义可能会使新用户感到迷惑。首先,只"
+"要你没有尝试在某个  session 中使用来自另一 session 的实例,你就应该不需要使"
+"用 <literal>update()</literal>, <literal>saveOrUpdate()</literal>,或 "
 "<literal>merge()</literal>。有些程序从来不用这些方法。"
 
 #. Tag: para
-#: session_api.xml:625
 #, no-c-format
 msgid ""
 "Usually <literal>update()</literal> or <literal>saveOrUpdate()</literal> are "
 "used in the following scenario:"
 msgstr ""
-"通常下面的场景会使用<literal>update()</literal>或<literal>saveOrUpdate()</"
+"通常下面的场景会使用 <literal>update()</literal> 或 <literal>saveOrUpdate()</"
 "literal>:"
 
 #. Tag: para
-#: session_api.xml:632
 #, no-c-format
 msgid "the application loads an object in the first session"
-msgstr "程序在第一个session中加载对象"
+msgstr "程序在第一个 session 中加载对象"
 
 #. Tag: para
-#: session_api.xml:637
 #, no-c-format
 msgid "the object is passed up to the UI tier"
 msgstr "该对象被传递到表现层"
 
 #. Tag: para
-#: session_api.xml:642
 #, no-c-format
 msgid "some modifications are made to the object"
 msgstr "对象发生了一些改动"
 
 #. Tag: para
-#: session_api.xml:647
 #, no-c-format
 msgid "the object is passed back down to the business logic tier"
 msgstr "该对象被返回到业务逻辑层"
 
 #. Tag: para
-#: session_api.xml:652
 #, no-c-format
 msgid ""
 "the application persists these modifications by calling <literal>update()</"
 "literal> in a second session"
-msgstr "程序调用第二个session的<literal>update()</literal>方法持久这些改动"
+msgstr "程序调用第二个 session 的 <literal>update()</literal> 方法持久这些改动"
 
 #. Tag: para
-#: session_api.xml:659
 #, no-c-format
 msgid "<literal>saveOrUpdate()</literal> does the following:"
-msgstr "<literal>saveOrUpdate()</literal>做下面的事:"
+msgstr "<literal>saveOrUpdate()</literal> 做下面的事:"
 
 #. Tag: para
-#: session_api.xml:665
 #, no-c-format
 msgid "if the object is already persistent in this session, do nothing"
-msgstr "如果对象已经在本session中持久化了,不做任何事"
+msgstr "如果对象已经在本 session 中持久化了,不做任何事"
 
 #. Tag: para
-#: session_api.xml:670
 #, no-c-format
 msgid ""
 "if another object associated with the session has the same identifier, throw "
 "an exception"
 msgstr ""
-"如果另一个与本session关联的对象拥有相同的持久化标识(identifier),抛出一个异常"
+"如果另一个与本 session 关联的对象拥有相同的持久化标识(identifier),抛出一个"
+"异常"
 
 #. Tag: para
-#: session_api.xml:676
 #, no-c-format
 msgid "if the object has no identifier property, <literal>save()</literal> it"
 msgstr ""
-"如果对象没有持久化标识(identifier)属性,对其调用<literal>save()</literal>"
+"如果对象没有持久化标识(identifier)属性,对其调用 <literal>save()</literal>"
 
 #. Tag: para
-#: session_api.xml:681
 #, no-c-format
 msgid ""
 "if the object's identifier has the value assigned to a newly instantiated "
 "object, <literal>save()</literal> it"
 msgstr ""
-"如果对象的持久标识(identifier)表明其是一个新实例化的对象,对其调用"
-"<literal>save()</literal>"
+"如果对象的持久标识(identifier)表明其是一个新实例化的对象,对其调用 "
+"<literal>save()</literal>。"
 
 #. Tag: para
-#: session_api.xml:687
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "if the object is versioned by a <literal>&lt;version&gt;</literal> or "
 "<literal>&lt;timestamp&gt;</literal>, and the version property value is the "
 "same value assigned to a newly instantiated object, <literal>save()</"
 "literal> it"
 msgstr ""
-"如果对象是附带版本信息的(通过<literal>&lt;version&gt;</literal>或"
-"<literal>&lt;timestamp&gt;</literal>) 并且版本属性的值表明其是一个新实例化的"
-"对象,<literal>save()</literal>它。"
+"如果对象是附带版本信息的(通过 <literal>&lt;version&gt;</literal> 或 "
+"<literal>&lt;timestamp&gt;</literal>)并且版本属性的值表明其是一个新实例化的"
+"对象,<literal>save()</literal> 它。 "
 
 #. Tag: para
-#: session_api.xml:695
 #, no-c-format
 msgid "otherwise <literal>update()</literal> the object"
-msgstr "否则<literal>update()</literal> 这个对象"
+msgstr "否则 <literal>update()</literal> 这个对象"
 
 #. Tag: para
-#: session_api.xml:701
 #, no-c-format
 msgid "and <literal>merge()</literal> is very different:"
-msgstr "<literal>merge()</literal>可非常不同:"
+msgstr "<literal>merge()</literal> 可非常不同:"
 
 #. Tag: para
-#: session_api.xml:707
 #, no-c-format
 msgid ""
 "if there is a persistent instance with the same identifier currently "
 "associated with the session, copy the state of the given object onto the "
 "persistent instance"
 msgstr ""
-"如果session中存在相同持久化标识(identifier)的实例,用用户给出的对象的状态覆盖"
-"旧有的持久实例"
+"如果 session 中存在相同持久化标识(identifier)的实例,用用户给出的对象的状态"
+"覆盖旧有的持久实例"
 
 #. Tag: para
-#: session_api.xml:714
 #, no-c-format
 msgid ""
 "if there is no persistent instance currently associated with the session, "
 "try to load it from the database, or create a new persistent instance"
 msgstr ""
-"如果session没有相应的持久实例,则尝试从数据库中加载,或创建新的持久化实例"
+"如果 session 没有相应的持久实例,则尝试从数据库中加载,或创建新的持久化实例"
 
 #. Tag: para
-#: session_api.xml:720
 #, no-c-format
 msgid "the persistent instance is returned"
 msgstr "最后返回该持久实例"
 
 #. Tag: para
-#: session_api.xml:725
 #, no-c-format
 msgid ""
 "the given instance does not become associated with the session, it remains "
 "detached"
-msgstr "用户给出的这个对象没有被关联到session上,它依旧是脱管的"
+msgstr "用户给出的这个对象没有被关联到 session 上,它依旧是脱管的"
 
 #. Tag: title
-#: session_api.xml:735
 #, no-c-format
 msgid "Deleting persistent objects"
 msgstr "删除持久对象"
 
 #. Tag: para
-#: session_api.xml:737
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Session.delete()</literal> will remove an object's state from the "
 "database. Your application, however, can still hold a reference to a deleted "
 "object. It is best to think of <literal>delete()</literal> as making a "
 "persistent instance, transient."
 msgstr ""
-"使用<literal>Session.delete()</literal>会把对象的状态从数据库中移除。 当然,"
+"使用 <literal>Session.delete()</literal> 会把对象的状态从数据库中移除。当然,"
 "你的应用程序可能仍然持有一个指向已删除对象的引用。所以,最好这样理解:"
-"<literal>delete()</literal>的用途是把一个持久实例变成瞬时(transient)实例。"
+"<literal>delete()</literal> 的用途是把一个持久实例变成瞬时(transient)实"
+"例。 "
 
-#. Tag: programlisting
-#: session_api.xml:744
+#. Tag: para
 #, no-c-format
-msgid "<![CDATA[sess.delete(cat);]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:746
-#, fuzzy, no-c-format
 msgid ""
 "You can delete objects in any order, without risk of foreign key constraint "
 "violations. It is still possible to violate a <literal>NOT NULL</literal> "
@@ -1510,92 +1035,71 @@
 "g. if you delete the parent, but forget to delete the children."
 msgstr ""
 "你可以用你喜欢的任何顺序删除对象,不用担心外键约束冲突。当然,如果你搞错了顺"
-"序,还是有可能引发在外键字段定义的<literal>NOT NULL</literal>约束冲突。 例如"
-"你删除了父对象,但是忘记删除孩子们。"
+"序,还是有可能引发在外键字段定义的 <literal>NOT NULL</literal> 约束冲突。例如"
+"你删除了父对象,但是忘记删除其子对象。"
 
 #. Tag: title
-#: session_api.xml:757
 #, no-c-format
 msgid "Replicating object between two different datastores"
 msgstr "在两个不同数据库间复制对象"
 
 #. Tag: para
-#: session_api.xml:759
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is sometimes useful to be able to take a graph of persistent instances "
 "and make them persistent in a different datastore, without regenerating "
 "identifier values."
 msgstr ""
-"偶尔会用到不重新生成持久化标识(identifier),将持久实例以及其关联的实例持久到"
-"不同的数据库中的操作。"
+"偶尔会用到不重新生成持久化标识(identifier),将持久实例以及其关联的实例持久"
+"到不同的数据库中的操作。 "
 
-#. Tag: programlisting
-#: session_api.xml:765
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[//retrieve a cat from one database\n"
-"Session session1 = factory1.openSession();\n"
-"Transaction tx1 = session1.beginTransaction();\n"
-"Cat cat = session1.get(Cat.class, catId);\n"
-"tx1.commit();\n"
-"session1.close();\n"
-"\n"
-"//reconcile with a second database\n"
-"Session session2 = factory2.openSession();\n"
-"Transaction tx2 = session2.beginTransaction();\n"
-"session2.replicate(cat, ReplicationMode.LATEST_VERSION);\n"
-"tx2.commit();\n"
-"session2.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:767
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>ReplicationMode</literal> determines how <literal>replicate()</"
 "literal> will deal with conflicts with existing rows in the database:"
 msgstr ""
-"<literal>ReplicationMode</literal>决定在和数据库中已存在记录由冲突时,"
-"<literal>replicate()</literal>如何处理。"
+"<literal>ReplicationMode</literal> 决定在和数据库中已存在记录由冲突时,"
+"<literal>replicate()</literal> 如何处理。 "
 
 #. Tag: para
-#: session_api.xml:774
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.IGNORE</literal>: ignores the object when there is "
 "an existing database row with the same identifier"
-msgstr "<literal>ReplicationMode.IGNORE</literal> - 忽略它"
+msgstr ""
+"<literal>ReplicationMode.IGNORE</literal>:当某个现有数据库记录具有相同标识符"
+"时忽略它"
 
 #. Tag: para
-#: session_api.xml:780
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.OVERWRITE</literal>: overwrites any existing "
 "database row with the same identifier"
-msgstr "<literal>ReplicationMode.OVERWRITE</literal> - 覆盖相同的行"
+msgstr ""
+"<literal>ReplicationMode.OVERWRITE</literal>:用相同的标识符覆盖现有数据库记"
+"录"
 
 #. Tag: para
-#: session_api.xml:786
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.EXCEPTION</literal>: throws an exception if there "
 "is an existing database row with the same identifier"
-msgstr "<literal>ReplicationMode.EXCEPTION</literal> - 抛出异常"
+msgstr ""
+"<literal>ReplicationMode.EXCEPTION</literal>:当某个现有数据库记录具有相同标"
+"识符时抛出异常"
 
 #. Tag: para
-#: session_api.xml:792
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ReplicationMode.LATEST_VERSION</literal>: overwrites the row if its "
 "version number is earlier than the version number of the object, or ignore "
 "the object otherwise"
 msgstr ""
-"<literal>ReplicationMode.LATEST_VERSION</literal> - 如果当前的版本较新,则覆"
+"<literal>ReplicationMode.LATEST_VERSION</literal>:如果当前的版本较新,则覆"
 "盖,否则忽略"
 
 #. Tag: para
-#: session_api.xml:800
 #, no-c-format
 msgid ""
 "Usecases for this feature include reconciling data entered into different "
@@ -1604,109 +1108,95 @@
 "more."
 msgstr ""
 "这个功能的用途包括使录入的数据在不同数据库中一致,产品升级时升级系统配置信"
-"息,回滚non-ACID事务中的修改等等。 (译注,non-ACID,非ACID;ACID,Atomic,"
-"Consistent,Isolated and Durable的缩写)"
+"息,回滚 non-ACID 事务中的修改等等。(译注,non-ACID,非 ACID;ACID,Atomic,"
+"Consistent,Isolated and Durable 的缩写)"
 
 #. Tag: title
-#: session_api.xml:809
 #, no-c-format
 msgid "Flushing the Session"
-msgstr "Session刷出(flush)"
+msgstr "Session 刷出(flush)"
 
 #. Tag: para
-#: session_api.xml:811
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Sometimes the <literal>Session</literal> will execute the SQL statements "
 "needed to synchronize the JDBC connection's state with the state of objects "
 "held in memory. This process, called <emphasis>flush</emphasis>, occurs by "
 "default at the following points:"
 msgstr ""
-"每间隔一段时间,<literal>Session</literal>会执行一些必需的SQL语句来把内存中的"
-"对象的状态同步到JDBC连接中。这个过程被称为<emphasis>刷出(flush)</emphasis>,"
-"默认会在下面的时间点执行:"
+"每间隔一段时间,<literal>Session</literal> 会执行一些必需的 SQL 语句来把内存"
+"中的对象的状态同步到 JDBC 连接中。这个过程被称为<emphasis>刷出(flush)</"
+"emphasis>,默认会在下面的时间点执行: "
 
 #. Tag: para
-#: session_api.xml:820
 #, no-c-format
 msgid "before some query executions"
 msgstr "在某些查询执行之前"
 
 #. Tag: para
-#: session_api.xml:825
 #, no-c-format
 msgid "from <literal>org.hibernate.Transaction.commit()</literal>"
-msgstr "在调用<literal>org.hibernate.Transaction.commit()</literal>的时候"
+msgstr "在调用 <literal>org.hibernate.Transaction.commit()</literal> 的时候"
 
 #. Tag: para
-#: session_api.xml:830
 #, no-c-format
 msgid "from <literal>Session.flush()</literal>"
-msgstr "在调用<literal>Session.flush()</literal>的时候"
+msgstr "在调用 <literal>Session.flush()</literal> 的时候"
 
 #. Tag: para
-#: session_api.xml:836
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The SQL statements are issued in the following order:"
-msgstr "涉及的SQL语句会按照下面的顺序发出执行:"
+msgstr "涉及的 SQL 语句会按照下面的顺序发出执行: "
 
 #. Tag: para
-#: session_api.xml:842
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "all entity insertions in the same order the corresponding objects were saved "
 "using <literal>Session.save()</literal>"
 msgstr ""
-"所有对实体进行插入的语句,其顺序按照对象执行<literal>Session.save()</literal>"
-"的时间顺序"
+"所有对实体进行插入的语句,其顺序按照对象执行 <literal>Session.save()</"
+"literal> 的时间顺序 "
 
 #. Tag: para
-#: session_api.xml:848
 #, no-c-format
 msgid "all entity updates"
 msgstr "所有对实体进行更新的语句"
 
 #. Tag: para
-#: session_api.xml:853
 #, no-c-format
 msgid "all collection deletions"
 msgstr "所有进行集合删除的语句"
 
 #. Tag: para
-#: session_api.xml:858
 #, no-c-format
 msgid "all collection element deletions, updates and insertions"
 msgstr "所有对集合元素进行删除,更新或者插入的语句"
 
 #. Tag: para
-#: session_api.xml:863
 #, no-c-format
 msgid "all collection insertions"
 msgstr "所有进行集合插入的语句"
 
 #. Tag: para
-#: session_api.xml:868
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "all entity deletions in the same order the corresponding objects were "
 "deleted using <literal>Session.delete()</literal>"
 msgstr ""
-"所有对实体进行删除的语句,其顺序按照对象执行<literal>Session.delete()</"
-"literal>的时间顺序"
+"所有对实体进行删除的语句,其顺序按照对象执行 <literal>Session.delete()</"
+"literal> 的时间顺序 "
 
 #. Tag: para
-#: session_api.xml:875
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An exception is that objects using <literal>native</literal> ID generation "
 "are inserted when they are saved."
 msgstr ""
-"(有一个例外是,如果对象使用<literal>native</literal>方式来生成ID(持久化标"
-"识)的话,它们一执行save就会被插入。)"
+"有一个例外是,如果对象使用 <literal>native</literal> 方式来生成 ID(持久化标"
+"识)的话,它们一执行 save 就会被插入。"
 
 #. Tag: para
-#: session_api.xml:880
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Except when you explicitly <literal>flush()</literal>, there are absolutely "
 "no guarantees about <emphasis>when</emphasis> the <literal>Session</literal> "
@@ -1714,13 +1204,12 @@
 "are executed. However, Hibernate does guarantee that the <literal>Query.list"
 "(..)</literal> will never return stale or incorrect data."
 msgstr ""
-"除非你明确地发出了<literal>flush()</literal>指令,关于Session<emphasis>何时</"
-"emphasis>会执行这些JDBC调用是完全无法保证的,只能保证它们执行的前后顺序。 当"
-"然,Hibernate保证,<literal>Query.list(..)</literal>绝对不会返回已经失效的数"
-"据,也不会返回错误数据。"
+"除非你明确地发出了 <literal>flush()</literal> 指令,关于 Session<emphasis> 何"
+"时</emphasis>会执行这些 JDBC 调用是完全无法保证的,只能保证它们执行的前后顺"
+"序。当然,Hibernate 保证,<literal>Query.list(..)</literal> 绝对不会返回已经"
+"失效的数据,也不会返回错误数据。 "
 
 #. Tag: para
-#: session_api.xml:888
 #, fuzzy, no-c-format
 msgid ""
 "It is possible to change the default behavior so that flush occurs less "
@@ -1730,57 +1219,34 @@
 "never flush unless <literal>flush()</literal> is called explicitly. The last "
 "mode is useful for long running units of work, where a <literal>Session</"
 "literal> is kept open and disconnected for a long time (see <xref linkend="
-"\"transactions-optimistic-longsession\"/>)."
+"\"transactions-optimistic-longsession\" />)."
 msgstr ""
-"也可以改变默认的设置,来让刷出(flush)操作发生的不那么频繁。 "
-"<literal>FlushMode</literal>类定义了三种不同的方式。 仅在提交时刷出(仅当"
-"Hibernate的<literal>Transaction</literal> API被使用时有效), 按照刚才说的方式"
-"刷出, 以及除非明确使用<literal>flush()</literal>否则从不刷出。 最后一种模式"
-"对于那些需要长时间保持<literal>Session</literal>为打开或者断线状态的长时间运"
-"行的工作单元很有用。 (参见 <xref linkend=\"transactions-optimistic-"
-"longsession\"/>)."
+"也可以改变默认的设置,来让刷出(flush)操作发生的不那么频繁。"
+"<literal>FlushMode</literal> 类定义了三种不同的方式。仅在提交时刷出(仅当 "
+"Hibernate 的 <literal>Transaction</literal> API 被使用时有效),按照刚才说的"
+"方式刷出,以及除非明确使用 <literal>flush()</literal> 否则从不刷出。 最后一种"
+"模式对于那些需要长时间保持 <literal>Session</literal> 为打开或者断线状态的长"
+"时间运行的工作单元很有用。(参见 <xref linkend=\"transactions-optimistic-"
+"longsession\"/>)。 "
 
-#. Tag: programlisting
-#: session_api.xml:898
-#, no-c-format
-msgid ""
-"<![CDATA[sess = sf.openSession();\n"
-"Transaction tx = sess.beginTransaction();\n"
-"sess.setFlushMode(FlushMode.COMMIT); // allow queries to return stale state\n"
-"\n"
-"Cat izi = (Cat) sess.load(Cat.class, id);\n"
-"izi.setName(iznizi);\n"
-"\n"
-"// might return stale data\n"
-"sess.find(\"from Cat as cat left outer join cat.kittens kitten\");\n"
-"\n"
-"// change to izi is not flushed!\n"
-"...\n"
-"tx.commit(); // flush occurs\n"
-"sess.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:900
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "During flush, an exception might occur (e.g. if a DML operation violates a "
 "constraint). Since handling exceptions involves some understanding of "
 "Hibernate's transactional behavior, we discuss it in <xref linkend="
-"\"transactions\"/>."
+"\"transactions\" />."
 msgstr ""
-"刷出(flush)期间,可能会抛出异常。(例如一个DML操作违反了约束) 异常处理涉及到"
-"对Hibernate事务性行为的理解,因此我们将在<xref linkend=\"transactions\"/>中讨"
-"论。"
+"刷出(flush)期间,可能会抛出异常(例如一个 DML 操作违反了约束)。异常处理涉"
+"及到对 Hibernate 事务性行为的理解,因此我们将在 <xref linkend=\"transactions"
+"\"/> 中讨论。"
 
 #. Tag: title
-#: session_api.xml:909
 #, no-c-format
 msgid "Transitive persistence"
-msgstr "传播性持久化(transitive persistence)"
+msgstr "传播性持久化(transitive persistence)"
 
 #. Tag: para
-#: session_api.xml:911
 #, no-c-format
 msgid ""
 "It is quite cumbersome to save, delete, or reattach individual objects, "
@@ -1788,11 +1254,10 @@
 "a parent/child relationship. Consider the following example:"
 msgstr ""
 "对每一个对象都要执行保存,删除或重关联操作让人感觉有点麻烦,尤其是在处理许多"
-"彼此关联的对象的时候。 一个常见的例子是父子关系。考虑下面的例子:"
+"彼此关联的对象的时候。一个常见的例子是父子关系。考虑下面的例子:"
 
 #. Tag: para
-#: session_api.xml:917
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the children in a parent/child relationship would be value typed (e.g. a "
 "collection of addresses or strings), their life cycle would depend on the "
@@ -1803,16 +1268,15 @@
 "collection. Since value-typed objects cannot have shared references, "
 "Hibernate will detect this and delete the child from the database."
 msgstr ""
-"如果一个父子关系中的子对象是值类型(value typed)(例如,地址或字符串的集合)"
-"的,他们的生命周期会依赖于父对象,可以享受方便的级联操作(Cascading),不需要额"
-"外的动作。 父对象被保存时,这些值类型(value typed)子对象也将被保存;父对象被"
-"删除时,子对象也将被删除。 这对将一个子对象从集合中移除是同样有效:Hibernate"
-"会检测到,并且因为值类型(value typed)的对象不可能被其他对象引用,所以"
-"Hibernate会在数据库中删除这个子对象。"
+"如果一个父子关系中的子对象是值类型(value typed)(例如,地址或字符串的集合)"
+"的,他们的生命周期会依赖于父对象,可以享受方便的级联操作(Cascading),不需要"
+"额外的动作。父对象被保存时,这些值类型(value typed)子对象也将被保存;父对象"
+"被删除时,子对象也将被删除。这对将一个子对象从集合中移除是同样有效:"
+"Hibernate 会检测到,并且因为值类型(value typed)的对象不可能被其他对象引用,"
+"所以 Hibernate 会在数据库中删除这个子对象。 "
 
 #. Tag: para
-#: session_api.xml:928
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now consider the same scenario with parent and child objects being entities, "
 "not value-types (e.g. categories and items, or parent and child cats). "
@@ -1822,14 +1286,13 @@
 "entities. Hibernate does not implement <emphasis>persistence by "
 "reachability</emphasis> by default."
 msgstr ""
-"现在考虑同样的场景,不过父子对象都是实体(entities)类型,而非值类型(value "
-"typed)(例如,类别与个体,或母猫和小猫)。 实体有自己的生命期,允许共享对其的"
-"引用(因此从集合中移除一个实体,不意味着它可以被删除), 并且实体到其他关联实"
-"体之间默认没有级联操作的设置。 Hibernate默认不实现所谓的<emphasis>可到达即持"
-"久化(persistence by reachability)</emphasis>的策略。"
+"现在考虑同样的场景,不过父子对象都是实体(entities)类型,而非值类型(value "
+"typed)(例如,类别与个体,或母猫和小猫)。实体有自己的生命期,允许共享对其的"
+"引用(因此从集合中移除一个实体,不意味着它可以被删除),并且实体到其他关联实"
+"体之间默认没有级联操作的设置。 Hibernate 默认不实现所谓的<emphasis>可到达即持"
+"久化(persistence by reachability)</emphasis>的策略。 "
 
 #. Tag: para
-#: session_api.xml:937
 #, no-c-format
 msgid ""
 "For each basic operation of the Hibernate session - including "
@@ -1840,47 +1303,31 @@
 "operation to be cascaded along an association, you must indicate that in the "
 "mapping document. For example:"
 msgstr ""
-"每个Hibernate session的基本操作 - 包括 <literal>persist(), merge(), "
+"每个 Hibernate session 的基本操作 — 包括 <literal>persist(), merge(), "
 "saveOrUpdate(), delete(), lock(), refresh(), evict(), replicate()</literal> "
-"- 都有对应的级联风格(cascade style)。 这些级联风格(cascade style)风格分别命名"
-"为 <literal>create, merge, save-update, delete, lock, refresh, evict, "
-"replicate</literal>。 如果你希望一个操作被顺着关联关系级联传播,你必须在映射"
-"文件中指出这一点。例如:"
+"— 都有对应的级联风格(cascade style)。这些级联风格(cascade style)风格分别"
+"命名为  <literal>create, merge, save-update, delete, lock, refresh, evict, "
+"replicate</literal>。如果你希望一个操作被顺着关联关系级联传播,你必须在映射文"
+"件中指出这一点。例如:"
 
-#. Tag: programlisting
-#: session_api.xml:946
-#, no-c-format
-msgid "<![CDATA[<one-to-one name=\"person\" cascade=\"persist\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: session_api.xml:948
 #, no-c-format
 msgid "Cascade styles my be combined:"
-msgstr "级联风格(cascade style)是可组合的:"
+msgstr "级联风格(cascade style)是可组合的:"
 
-#. Tag: programlisting
-#: session_api.xml:952
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<one-to-one name=\"person\" cascade=\"persist,delete,lock\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: session_api.xml:954
-#, fuzzy, no-c-format
-msgid ""
 "You can even use <literal>cascade=\"all\"</literal> to specify that "
 "<emphasis>all</emphasis> operations should be cascaded along the "
 "association. The default <literal>cascade=\"none\"</literal> specifies that "
 "no operations are to be cascaded."
 msgstr ""
-"你可以使用<literal>cascade=\"all\"</literal>来指定<emphasis>全部</emphasis>操"
-"作都顺着关联关系级联(cascaded)。 默认值是<literal>cascade=\"none\"</"
-"literal>,即任何操作都不会被级联(cascaded)。"
+"你可以使用 <literal>cascade=\"all\"</literal> 来指定<emphasis>全部</emphasis>"
+"操作都顺着关联关系级联(cascaded)。默认值是 <literal>cascade=\"none\"</"
+"literal>,即任何操作都不会被级联(cascaded)。 "
 
 #. Tag: para
-#: session_api.xml:960
 #, no-c-format
 msgid ""
 "A special cascade style, <literal>delete-orphan</literal>, applies only to "
@@ -1888,44 +1335,40 @@
 "operation should be applied to any child object that is removed from the "
 "association."
 msgstr ""
-"注意有一个特殊的级联风格(cascade style) <literal>delete-orphan</literal>,只"
-"应用于one-to-many关联,表明<literal>delete()</literal>操作 应该被应用于所有从"
-"关联中删除的对象。"
+"注意有一个特殊的级联风格(cascade style) <literal>delete-orphan</literal>,"
+"只应用于 one-to-many 关联,表明 <literal>delete()</literal> 操作应该被应用于"
+"所有从关联中删除的对象。"
 
 #. Tag: para
-#: session_api.xml:967
 #, no-c-format
 msgid "Recommendations:"
-msgstr "建议:"
+msgstr "建议:"
 
 #. Tag: para
-#: session_api.xml:973
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It does not usually make sense to enable cascade on a <literal>&lt;many-to-"
 "one&gt;</literal> or <literal>&lt;many-to-many&gt;</literal> association. "
 "Cascade is often useful for <literal>&lt;one-to-one&gt;</literal> and "
 "<literal>&lt;one-to-many&gt;</literal> associations."
 msgstr ""
-"通常在<literal>&lt;many-to-one&gt;</literal>或<literal>&lt;many-to-many&gt;</"
-"literal>关系中应用级联(cascade)没什么意义。 级联(cascade)通常在 <literal>&lt;"
-"one-to-one&gt;</literal>和<literal>&lt;one-to-many&gt;</literal>关系中比较有"
-"用。"
+"通常在 <literal>&lt;many-to-one&gt;</literal> 或 <literal>&lt;many-to-"
+"many&gt;</literal> 关系中应用级联(cascade)没什么意义。级联(cascade)通常"
+"在 <literal>&lt;one-to-one&gt;</literal>   和 <literal>&lt;one-to-many&gt;</"
+"literal> 关系中比较有用。 "
 
 #. Tag: para
-#: session_api.xml:981
 #, no-c-format
 msgid ""
 "If the child object's lifespan is bounded by the lifespan of the parent "
 "object, make it a <emphasis>life cycle object</emphasis> by specifying "
 "<literal>cascade=\"all,delete-orphan\"</literal>."
 msgstr ""
-"如果子对象的寿命限定在父亲对象的寿命之内,可通过指定<literal>cascade=\"all,"
-"delete-orphan\"</literal>将其变为<emphasis>自动生命周期管理的对象(life cycle "
-"object)</emphasis>。"
+"如果子对象的寿命限定在父亲对象的寿命之内,可通过指定 <literal>cascade=\"all,"
+"delete-orphan\"</literal> 将其变为<emphasis>自动生命周期管理的对象"
+"(lifecycle object)</emphasis>。 "
 
 #. Tag: para
-#: session_api.xml:988
 #, no-c-format
 msgid ""
 "Otherwise, you might not need cascade at all. But if you think that you will "
@@ -1933,12 +1376,11 @@
 "transaction, and you want to save yourself some typing, consider using "
 "<literal>cascade=\"persist,merge,save-update\"</literal>."
 msgstr ""
-"其他情况,你可根本不需要级联(cascade)。但是如果你认为你会经常在某个事务中同时"
-"用到父对象与子对象,并且你希望少打点儿字,可以考虑使用<literal>cascade="
+"其他情况,你可根本不需要级联(cascade)。但是如果你认为你会经常在某个事务中同"
+"时用到父对象与子对象,并且你希望少打点儿字,可以考虑使用   <literal>cascade="
 "\"persist,merge,save-update\"</literal>。"
 
 #. Tag: para
-#: session_api.xml:996
 #, no-c-format
 msgid ""
 "Mapping an association (either a single valued association, or a collection) "
@@ -1946,13 +1388,13 @@
 "<emphasis>parent/child</emphasis> style relationship where save/update/"
 "delete of the parent results in save/update/delete of the child or children."
 msgstr ""
-"可以使用<literal>cascade=\"all\"</literal>将一个关联关系(无论是对值对象的关"
-"联,或者对一个集合的关联)标记为<emphasis>父/子</emphasis>关系的关联。 这样对"
-"父对象进行save/update/delete操作就会导致子对象也进行save/update/delete操作。"
+"可以使用 <literal>cascade=\"all\"</literal> 将一个关联关系(无论是对值对象的"
+"关联,或者对一个集合的关联)标记为<emphasis>父/子</emphasis>关系的关联。 这样"
+"对父对象进行 save/update/delete 操作就会导致子对象也进行 save/update/delete "
+"操作。"
 
 #. Tag: para
-#: session_api.xml:1002
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Furthermore, a mere reference to a child from a persistent parent will "
 "result in save/update of the child. This metaphor is incomplete, however. A "
@@ -1962,64 +1404,59 @@
 "literal>. The precise semantics of cascading operations for a parent/child "
 "relationship are as follows:"
 msgstr ""
-"此外,一个持久的父对象对子对象的浅引用(mere reference)会导致子对象被同步save/"
-"update。 不过,这个隐喻(metaphor)的说法并不完整。除非关联是<literal>&lt;one-"
-"to-many&gt;</literal>关联并且被标记为<literal>cascade=\"delete-orphan\"</"
-"literal>, 否则父对象失去对某个子对象的引用<emphasis>不会</emphasis>导致该子"
-"对象被自动删除。 父子关系的级联(cascading)操作准确语义如下:"
+"此外,一个持久的父对象对子对象的浅引用(mere reference)会导致子对象被同步 "
+"save/update。不过,这个隐喻(metaphor)的说法并不完整。除非关联是 "
+"<literal>&lt;one-to-many&gt;</literal> 关联并且被标记为 <literal>cascade="
+"\"delete-orphan\"</literal>,否则父对象失去对某个子对象的引用<emphasis>不会</"
+"emphasis>导致该子对象被自动删除。父子关系的级联(cascading)操作准确语义如"
+"下: "
 
 #. Tag: para
-#: session_api.xml:1013
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>persist()</literal>, all children are "
 "passed to <literal>persist()</literal>"
 msgstr ""
-"如果父对象被<literal>persist()</literal>,那么所有子对象也会被"
+"如果父对象被 <literal>persist()</literal>,那么所有子对象也会被 "
 "<literal>persist()</literal>"
 
 #. Tag: para
-#: session_api.xml:1019
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>merge()</literal>, all children are passed "
 "to <literal>merge()</literal>"
 msgstr ""
-"如果父对象被<literal>merge()</literal>,那么所有子对象也会被<literal>merge()"
-"</literal>"
+"如果父对象被 <literal>merge()</literal>,那么所有子对象也会被 <literal>merge"
+"()</literal>"
 
 #. Tag: para
-#: session_api.xml:1025
 #, no-c-format
 msgid ""
 "If a parent is passed to <literal>save()</literal>, <literal>update()</"
 "literal> or <literal>saveOrUpdate()</literal>, all children are passed to "
 "<literal>saveOrUpdate()</literal>"
 msgstr ""
-"如果父对象被<literal>save()</literal>,<literal>update()</literal>或 "
-"<literal>saveOrUpdate()</literal>,那么所有子对象则会被<literal>saveOrUpdate"
+"如果父对象被 <literal>save()</literal>,<literal>update()</literal> 或  "
+"<literal>saveOrUpdate()</literal>,那么所有子对象则会被 <literal>saveOrUpdate"
 "()</literal>"
 
 #. Tag: para
-#: session_api.xml:1031
 #, no-c-format
 msgid ""
 "If a transient or detached child becomes referenced by a persistent parent, "
 "it is passed to <literal>saveOrUpdate()</literal>"
 msgstr ""
-"如果某个持久的父对象引用了瞬时(transient)或者脱管(detached)的子对象,那么子对"
-"象将会被<literal>saveOrUpdate()</literal>"
+"如果某个持久的父对象引用了瞬时(transient)或者脱管(detached)的子对象,那么"
+"子对象将会被 <literal>saveOrUpdate()</literal>"
 
 #. Tag: para
-#: session_api.xml:1037
 #, no-c-format
 msgid ""
 "If a parent is deleted, all children are passed to <literal>delete()</"
 "literal>"
-msgstr "如果父对象被删除,那么所有子对象也会被<literal>delete()</literal>"
+msgstr "如果父对象被删除,那么所有子对象也会被 <literal>delete()</literal>"
 
 #. Tag: para
-#: session_api.xml:1042
 #, no-c-format
 msgid ""
 "If a child is dereferenced by a persistent parent, <emphasis>nothing special "
@@ -2027,14 +1464,13 @@
 "necessary - unless <literal>cascade=\"delete-orphan\"</literal>, in which "
 "case the \"orphaned\" child is deleted."
 msgstr ""
-"除非被标记为<literal>cascade=\"delete-orphan\"</literal>(删除“孤儿”模式,此"
-"时不被任何一个父对象引用的子对象会被删除), 否则子对象失掉父对象对其的引用"
-"时,<emphasis>什么事也不会发生</emphasis>。 如果有特殊需要,应用程序可通过显"
-"式调用delete()删除子对象。"
+"除非被标记为 <literal>cascade=\"delete-orphan\"</literal>(删除“孤儿”模式,此"
+"时不被任何一个父对象引用的子对象会被删除),否则子对象失掉父对象对其的引用"
+"时,<emphasis>什么事也不会发生</emphasis>。如果有特殊需要,应用程序可通过显式"
+"调用 delete() 删除子对象。"
 
 #. Tag: para
-#: session_api.xml:1051
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, note that cascading of operations can be applied to an object graph "
 "at <emphasis>call time</emphasis> or at <emphasis>flush time</emphasis>. All "
@@ -2043,21 +1479,19 @@
 "<literal>delete-orphan</literal> are transitive for all associated entities "
 "reachable during flush of the <literal>Session</literal>."
 msgstr ""
-"最后,注意操作的级联可能是在<emphasis>调用期(call time)</emphasis>或者"
-"<emphasis>写入期(flush time)</emphasis>作用到对象图上的。所有的操作,如果允"
+"最后,注意操作的级联可能是在<emphasis>调用期(call time)</emphasis>或者"
+"<emphasis>写入期(flush time)</emphasis>作用到对象图上的。所有的操作,如果允"
 "许,都在操作被执行的时候级联到可触及的关联实体上。然而,<literal>save-upate</"
-"literal>和<literal>delete-orphan</literal>是在<literal>Session</literal> "
-"flush的时候才作用到所有可触及的被关联对象上的。"
+"literal> 和 <literal>delete-orphan</literal> 是在<literal>Session</literal> "
+"flush 的时候才作用到所有可触及的被关联对象上的。 "
 
 #. Tag: title
-#: session_api.xml:1063
 #, no-c-format
 msgid "Using metadata"
 msgstr "使用元数据"
 
 #. Tag: para
-#: session_api.xml:1065
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate requires a rich meta-level model of all entity and value types. "
 "This model can be useful to the application itself. For example, the "
@@ -2066,60 +1500,636 @@
 "value types) and which objects that should not (e.g. immutable value types "
 "and, possibly, associated entities)."
 msgstr ""
-"Hibernate中有一个非常丰富的元级别(meta-level)的模型,含有所有的实体和值类型数"
-"据的元数据。 有时这个模型对应用程序本身也会非常有用。 比如说,应用程序可能在"
-"实现一种“智能”的深度拷贝算法时, 通过使用Hibernate的元数据来了解哪些对象应该"
-"被拷贝(比如,可变的值类型数据), 那些不应该(不可变的值类型数据,也许还有某"
-"些被关联的实体)。"
+"Hibernate 中有一个非常丰富的元级别(meta-level)的模型,含有所有的实体和值类"
+"型数据的元数据。 有时这个模型对应用程序本身也会非常有用。比如说,应用程序可能"
+"在实现一种“智能”的深度拷贝算法时,通过使用 Hibernate 的元数据来了解哪些对象应"
+"该被拷贝(比如,可变的值类型数据),那些不应该(不可变的值类型数据,也许还有"
+"某些被关联的实体)。 "
 
 #. Tag: para
-#: session_api.xml:1072
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate exposes metadata via the <literal>ClassMetadata</literal> and "
 "<literal>CollectionMetadata</literal> interfaces and the <literal>Type</"
 "literal> hierarchy. Instances of the metadata interfaces can be obtained "
 "from the <literal>SessionFactory</literal>."
 msgstr ""
-"Hibernate提供了<literal>ClassMetadata</literal>接口,"
-"<literal>CollectionMetadata</literal>接口和<literal>Type</literal>层次体系来"
-"访问元数据。 可以通过<literal>SessionFactory</literal>获取元数据接口的实例。"
+"Hibernate 提供了 <literal>ClassMetadata</literal> 接口,"
+"<literal>CollectionMetadata</literal> 接口和 <literal>Type</literal> 层次体系"
+"来访问元数据。可以通过  <literal>SessionFactory</literal> 获取元数据接口的实"
+"例。 "
 
-#. Tag: programlisting
-#: session_api.xml:1079
-#, no-c-format
-msgid ""
-"<![CDATA[Cat fritz = ......;\n"
-"ClassMetadata catMeta = sessionfactory.getClassMetadata(Cat.class);\n"
-"\n"
-"Object[] propertyValues = catMeta.getPropertyValues(fritz);\n"
-"String[] propertyNames = catMeta.getPropertyNames();\n"
-"Type[] propertyTypes = catMeta.getPropertyTypes();\n"
-"\n"
-"// get a Map of all properties which are not collections or associations\n"
-"Map namedValues = new HashMap();\n"
-"for ( int i=0; i<propertyNames.length; i++ ) {\n"
-"    if ( !propertyTypes[i].isEntityType() && !propertyTypes[i]."
-"isCollectionType() ) {\n"
-"        namedValues.put( propertyNames[i], propertyValues[i] );\n"
-"    }\n"
-"}]]>"
-msgstr ""
+#~ msgid ""
+#~ "<![CDATA[DomesticCat fritz = new DomesticCat();\n"
+#~ "fritz.setColor(Color.GINGER);\n"
+#~ "fritz.setSex('M');\n"
+#~ "fritz.setName(\"Fritz\");\n"
+#~ "Long generatedId = (Long) sess.save(fritz);]]>"
+#~ msgstr ""
+#~ "<![CDATA[DomesticCat fritz = new DomesticCat();\n"
+#~ "fritz.setColor(Color.GINGER);\n"
+#~ "fritz.setSex('M');\n"
+#~ "fritz.setName(\"Fritz\");\n"
+#~ "Long generatedId = (Long) sess.save(fritz);]]>"
 
-#~ msgid "UPDATE"
-#~ msgstr "UPDATE"
+#~ msgid ""
+#~ "<![CDATA[DomesticCat pk = new DomesticCat();\n"
+#~ "pk.setColor(Color.TABBY);\n"
+#~ "pk.setSex('F');\n"
+#~ "pk.setName(\"PK\");\n"
+#~ "pk.setKittens( new HashSet() );\n"
+#~ "pk.addKitten(fritz);\n"
+#~ "sess.save( pk, new Long(1234) );]]>"
+#~ msgstr ""
+#~ "<![CDATA[DomesticCat pk = new DomesticCat();\n"
+#~ "pk.setColor(Color.TABBY);\n"
+#~ "pk.setSex('F');\n"
+#~ "pk.setName(\"PK\");\n"
+#~ "pk.setKittens( new HashSet() );\n"
+#~ "pk.addKitten(fritz);\n"
+#~ "sess.save( pk, new Long(1234) );]]>"
 
-#~ msgid "DELETE"
-#~ msgstr "DELETE"
+#~ msgid "<![CDATA[Cat fritz = (Cat) sess.load(Cat.class, generatedId);]]>"
+#~ msgstr "<![CDATA[Cat fritz = (Cat) sess.load(Cat.class, generatedId);]]>"
 
-#~ msgid "state management"
-#~ msgstr "状态管理(state management)"
+#~ msgid ""
+#~ "<![CDATA[// you need to wrap primitive identifiers\n"
+#~ "long id = 1234;\n"
+#~ "DomesticCat pk = (DomesticCat) sess.load( DomesticCat.class, new Long"
+#~ "(id) );]]>"
+#~ msgstr ""
+#~ "<![CDATA[// you need to wrap primitive identifiers\n"
+#~ "long id = 1234;\n"
+#~ "DomesticCat pk = (DomesticCat) sess.load( DomesticCat.class, new Long"
+#~ "(id) );]]>"
 
-#~ msgid "statements"
-#~ msgstr "语句(statements)"
+#~ msgid ""
+#~ "<![CDATA[Cat cat = new DomesticCat();\n"
+#~ "// load pk's state into cat\n"
+#~ "sess.load( cat, new Long(pkId) );\n"
+#~ "Set kittens = cat.getKittens();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Cat cat = new DomesticCat();\n"
+#~ "// load pk's state into cat\n"
+#~ "sess.load( cat, new Long(pkId) );\n"
+#~ "Set kittens = cat.getKittens();]]>"
 
-#~ msgid "Connection"
-#~ msgstr "session.connection()"
+#~ msgid ""
+#~ "<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id);\n"
+#~ "if (cat==null) {\n"
+#~ "    cat = new Cat();\n"
+#~ "    sess.save(cat, id);\n"
+#~ "}\n"
+#~ "return cat;]]>"
+#~ msgstr ""
+#~ "<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id);\n"
+#~ "if (cat==null) {\n"
+#~ "    cat = new Cat();\n"
+#~ "    sess.save(cat, id);\n"
+#~ "}\n"
+#~ "return cat;]]>"
 
-#~ msgid "session.connection()"
-#~ msgstr "Connection"
+#~ msgid ""
+#~ "<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id, LockMode.UPGRADE);]]>"
+#~ msgstr ""
+#~ "<![CDATA[Cat cat = (Cat) sess.get(Cat.class, id, LockMode.UPGRADE);]]>"
+
+#~ msgid ""
+#~ "<![CDATA[sess.save(cat);\n"
+#~ "sess.flush(); //force the SQL INSERT\n"
+#~ "sess.refresh(cat); //re-read the state (after the trigger executes)]]>"
+#~ msgstr ""
+#~ "<![CDATA[sess.save(cat);\n"
+#~ "sess.flush(); //force the SQL INSERT\n"
+#~ "sess.refresh(cat); //re-read the state (after the trigger executes)]]>"
+
+#~ msgid ""
+#~ "<![CDATA[List cats = session.createQuery(\n"
+#~ "    \"from Cat as cat where cat.birthdate < ?\")\n"
+#~ "    .setDate(0, date)\n"
+#~ "    .list();\n"
+#~ "\n"
+#~ "List mothers = session.createQuery(\n"
+#~ "    \"select mother from Cat as cat join cat.mother as mother where cat."
+#~ "name = ?\")\n"
+#~ "    .setString(0, name)\n"
+#~ "    .list();\n"
+#~ "\n"
+#~ "List kittens = session.createQuery(\n"
+#~ "    \"from Cat as cat where cat.mother = ?\")\n"
+#~ "    .setEntity(0, pk)\n"
+#~ "    .list();\n"
+#~ "\n"
+#~ "Cat mother = (Cat) session.createQuery(\n"
+#~ "    \"select cat.mother from Cat as cat where cat = ?\")\n"
+#~ "    .setEntity(0, izi)\n"
+#~ "    .uniqueResult();]]\n"
+#~ "\n"
+#~ "Query mothersWithKittens = (Cat) session.createQuery(\n"
+#~ "    \"select mother from Cat as mother left join fetch mother.kittens"
+#~ "\");\n"
+#~ "Set uniqueMothers = new HashSet(mothersWithKittens.list());]]>"
+#~ msgstr ""
+#~ "<![CDATA[List cats = session.createQuery(\n"
+#~ "    \"from Cat as cat where cat.birthdate < ?\")\n"
+#~ "    .setDate(0, date)\n"
+#~ "    .list();\n"
+#~ "\n"
+#~ "List mothers = session.createQuery(\n"
+#~ "    \"select mother from Cat as cat join cat.mother as mother where cat."
+#~ "name = ?\")\n"
+#~ "    .setString(0, name)\n"
+#~ "    .list();\n"
+#~ "\n"
+#~ "List kittens = session.createQuery(\n"
+#~ "    \"from Cat as cat where cat.mother = ?\")\n"
+#~ "    .setEntity(0, pk)\n"
+#~ "    .list();\n"
+#~ "\n"
+#~ "Cat mother = (Cat) session.createQuery(\n"
+#~ "    \"select cat.mother from Cat as cat where cat = ?\")\n"
+#~ "    .setEntity(0, izi)\n"
+#~ "    .uniqueResult();]]\n"
+#~ "\n"
+#~ "Query mothersWithKittens = (Cat) session.createQuery(\n"
+#~ "    \"select mother from Cat as mother left join fetch mother.kittens"
+#~ "\");\n"
+#~ "Set uniqueMothers = new HashSet(mothersWithKittens.list());]]>"
+
+#~ msgid ""
+#~ "<![CDATA[// fetch ids\n"
+#~ "Iterator iter = sess.createQuery(\"from eg.Qux q order by q.likeliness\")."
+#~ "iterate();\n"
+#~ "while ( iter.hasNext() ) {\n"
+#~ "    Qux qux = (Qux) iter.next();  // fetch the object\n"
+#~ "    // something we couldnt express in the query\n"
+#~ "    if ( qux.calculateComplicatedAlgorithm() ) {\n"
+#~ "        // delete the current instance\n"
+#~ "        iter.remove();\n"
+#~ "        // dont need to process the rest\n"
+#~ "        break;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[// fetch ids\n"
+#~ "Iterator iter = sess.createQuery(\"from eg.Qux q order by q.likeliness\")."
+#~ "iterate();\n"
+#~ "while ( iter.hasNext() ) {\n"
+#~ "    Qux qux = (Qux) iter.next();  // fetch the object\n"
+#~ "    // something we couldnt express in the query\n"
+#~ "    if ( qux.calculateComplicatedAlgorithm() ) {\n"
+#~ "        // delete the current instance\n"
+#~ "        iter.remove();\n"
+#~ "        // dont need to process the rest\n"
+#~ "        break;\n"
+#~ "    }\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Iterator kittensAndMothers = sess.createQuery(\n"
+#~ "            \"select kitten, mother from Cat kitten join kitten.mother "
+#~ "mother\")\n"
+#~ "            .list()\n"
+#~ "            .iterator();\n"
+#~ "\n"
+#~ "while ( kittensAndMothers.hasNext() ) {\n"
+#~ "    Object[] tuple = (Object[]) kittensAndMothers.next();\n"
+#~ "    Cat kitten = (Cat) tuple[0];\n"
+#~ "    Cat mother = (Cat) tuple[1];\n"
+#~ "    ....\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[Iterator kittensAndMothers = sess.createQuery(\n"
+#~ "            \"select kitten, mother from Cat kitten join kitten.mother "
+#~ "mother\")\n"
+#~ "            .list()\n"
+#~ "            .iterator();\n"
+#~ "\n"
+#~ "while ( kittensAndMothers.hasNext() ) {\n"
+#~ "    Object[] tuple = (Object[]) kittensAndMothers.next();\n"
+#~ "    Cat kitten = (Cat) tuple[0];\n"
+#~ "    Cat mother = (Cat) tuple[1];\n"
+#~ "    ....\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Iterator results = sess.createQuery(\n"
+#~ "        \"select cat.color, min(cat.birthdate), count(cat) from Cat cat "
+#~ "\" +\n"
+#~ "        \"group by cat.color\")\n"
+#~ "        .list()\n"
+#~ "        .iterator();\n"
+#~ "\n"
+#~ "while ( results.hasNext() ) {\n"
+#~ "    Object[] row = (Object[]) results.next();\n"
+#~ "    Color type = (Color) row[0];\n"
+#~ "    Date oldest = (Date) row[1];\n"
+#~ "    Integer count = (Integer) row[2];\n"
+#~ "    .....\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[Iterator results = sess.createQuery(\n"
+#~ "        \"select cat.color, min(cat.birthdate), count(cat) from Cat cat "
+#~ "\" +\n"
+#~ "        \"group by cat.color\")\n"
+#~ "        .list()\n"
+#~ "        .iterator();\n"
+#~ "\n"
+#~ "while ( results.hasNext() ) {\n"
+#~ "    Object[] row = (Object[]) results.next();\n"
+#~ "    Color type = (Color) row[0];\n"
+#~ "    Date oldest = (Date) row[1];\n"
+#~ "    Integer count = (Integer) row[2];\n"
+#~ "    .....\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[//named parameter (preferred)\n"
+#~ "Query q = sess.createQuery(\"from DomesticCat cat where cat.name = :name"
+#~ "\");\n"
+#~ "q.setString(\"name\", \"Fritz\");\n"
+#~ "Iterator cats = q.iterate();]]>"
+#~ msgstr ""
+#~ "<![CDATA[//named parameter (preferred)\n"
+#~ "Query q = sess.createQuery(\"from DomesticCat cat where cat.name = :name"
+#~ "\");\n"
+#~ "q.setString(\"name\", \"Fritz\");\n"
+#~ "Iterator cats = q.iterate();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[//positional parameter\n"
+#~ "Query q = sess.createQuery(\"from DomesticCat cat where cat.name = ?\");\n"
+#~ "q.setString(0, \"Izi\");\n"
+#~ "Iterator cats = q.iterate();]]>"
+#~ msgstr ""
+#~ "<![CDATA[//positional parameter\n"
+#~ "Query q = sess.createQuery(\"from DomesticCat cat where cat.name = ?\");\n"
+#~ "q.setString(0, \"Izi\");\n"
+#~ "Iterator cats = q.iterate();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[//named parameter list\n"
+#~ "List names = new ArrayList();\n"
+#~ "names.add(\"Izi\");\n"
+#~ "names.add(\"Fritz\");\n"
+#~ "Query q = sess.createQuery(\"from DomesticCat cat where cat.name in (:"
+#~ "namesList)\");\n"
+#~ "q.setParameterList(\"namesList\", names);\n"
+#~ "List cats = q.list();]]>"
+#~ msgstr ""
+#~ "<![CDATA[//named parameter list\n"
+#~ "List names = new ArrayList();\n"
+#~ "names.add(\"Izi\");\n"
+#~ "names.add(\"Fritz\");\n"
+#~ "Query q = sess.createQuery(\"from DomesticCat cat where cat.name in (:"
+#~ "namesList)\");\n"
+#~ "q.setParameterList(\"namesList\", names);\n"
+#~ "List cats = q.list();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Query q = sess.createQuery(\"from DomesticCat cat\");\n"
+#~ "q.setFirstResult(20);\n"
+#~ "q.setMaxResults(10);\n"
+#~ "List cats = q.list();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Query q = sess.createQuery(\"from DomesticCat cat\");\n"
+#~ "q.setFirstResult(20);\n"
+#~ "q.setMaxResults(10);\n"
+#~ "List cats = q.list();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Query q = sess.createQuery(\"select cat.name, cat from "
+#~ "DomesticCat cat \" +\n"
+#~ "                            \"order by cat.name\");\n"
+#~ "ScrollableResults cats = q.scroll();\n"
+#~ "if ( cats.first() ) {\n"
+#~ "\n"
+#~ "    // find the first name on each page of an alphabetical list of cats "
+#~ "by name\n"
+#~ "    firstNamesOfPages = new ArrayList();\n"
+#~ "    do {\n"
+#~ "        String name = cats.getString(0);\n"
+#~ "        firstNamesOfPages.add(name);\n"
+#~ "    }\n"
+#~ "    while ( cats.scroll(PAGE_SIZE) );\n"
+#~ "\n"
+#~ "    // Now get the first page of cats\n"
+#~ "    pageOfCats = new ArrayList();\n"
+#~ "    cats.beforeFirst();\n"
+#~ "    int i=0;\n"
+#~ "    while( ( PAGE_SIZE > i++ ) && cats.next() ) pageOfCats.add( cats.get"
+#~ "(1) );\n"
+#~ "\n"
+#~ "}\n"
+#~ "cats.close()]]>"
+#~ msgstr ""
+#~ "<![CDATA[Query q = sess.createQuery(\"select cat.name, cat from "
+#~ "DomesticCat cat \" +\n"
+#~ "                            \"order by cat.name\");\n"
+#~ "ScrollableResults cats = q.scroll();\n"
+#~ "if ( cats.first() ) {\n"
+#~ "\n"
+#~ "    // find the first name on each page of an alphabetical list of cats "
+#~ "by name\n"
+#~ "    firstNamesOfPages = new ArrayList();\n"
+#~ "    do {\n"
+#~ "        String name = cats.getString(0);\n"
+#~ "        firstNamesOfPages.add(name);\n"
+#~ "    }\n"
+#~ "    while ( cats.scroll(PAGE_SIZE) );\n"
+#~ "\n"
+#~ "    // Now get the first page of cats\n"
+#~ "    pageOfCats = new ArrayList();\n"
+#~ "    cats.beforeFirst();\n"
+#~ "    int i=0;\n"
+#~ "    while( ( PAGE_SIZE > i++ ) && cats.next() ) pageOfCats.add( cats.get"
+#~ "(1) );\n"
+#~ "\n"
+#~ "}\n"
+#~ "cats.close()]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<query name=\"ByNameAndMaximumWeight\"><![CDATA[\n"
+#~ "    from eg.DomesticCat as cat\n"
+#~ "        where cat.name = ?\n"
+#~ "        and cat.weight > ?\n"
+#~ "] ]></query>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<query name=\"ByNameAndMaximumWeight\"><![CDATA[\n"
+#~ "    from eg.DomesticCat as cat\n"
+#~ "        where cat.name = ?\n"
+#~ "        and cat.weight > ?\n"
+#~ "] ]></query>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Query q = sess.getNamedQuery(\"ByNameAndMaximumWeight\");\n"
+#~ "q.setString(0, name);\n"
+#~ "q.setInt(1, minWeight);\n"
+#~ "List cats = q.list();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Query q = sess.getNamedQuery(\"ByNameAndMaximumWeight\");\n"
+#~ "q.setString(0, name);\n"
+#~ "q.setInt(1, minWeight);\n"
+#~ "List cats = q.list();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Collection blackKittens = session.createFilter(\n"
+#~ "    pk.getKittens(), \n"
+#~ "    \"where this.color = ?\")\n"
+#~ "    .setParameter( Color.BLACK, Hibernate.custom(ColorUserType.class) )\n"
+#~ "    .list()\n"
+#~ ");]]>"
+#~ msgstr ""
+#~ "<![CDATA[Collection blackKittens = session.createFilter(\n"
+#~ "    pk.getKittens(), \n"
+#~ "    \"where this.color = ?\")\n"
+#~ "    .setParameter( Color.BLACK, Hibernate.custom(ColorUserType.class) )\n"
+#~ "    .list()\n"
+#~ ");]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Collection blackKittenMates = session.createFilter(\n"
+#~ "    pk.getKittens(), \n"
+#~ "    \"select this.mate where this.color = eg.Color.BLACK.intValue\")\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Collection blackKittenMates = session.createFilter(\n"
+#~ "    pk.getKittens(), \n"
+#~ "    \"select this.mate where this.color = eg.Color.BLACK.intValue\")\n"
+#~ "    .list();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Collection tenKittens = session.createFilter(\n"
+#~ "    mother.getKittens(), \"\")\n"
+#~ "    .setFirstResult(0).setMaxResults(10)\n"
+#~ "    .list();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Collection tenKittens = session.createFilter(\n"
+#~ "    mother.getKittens(), \"\")\n"
+#~ "    .setFirstResult(0).setMaxResults(10)\n"
+#~ "    .list();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Criteria crit = session.createCriteria(Cat.class);\n"
+#~ "crit.add( Restrictions.eq( \"color\", eg.Color.BLACK ) );\n"
+#~ "crit.setMaxResults(10);\n"
+#~ "List cats = crit.list();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Criteria crit = session.createCriteria(Cat.class);\n"
+#~ "crit.add( Restrictions.eq( \"color\", eg.Color.BLACK ) );\n"
+#~ "crit.setMaxResults(10);\n"
+#~ "List cats = crit.list();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[List cats = session.createSQLQuery(\"SELECT {cat.*} FROM CAT "
+#~ "{cat} WHERE ROWNUM<10\")\n"
+#~ "    .addEntity(\"cat\", Cat.class)\n"
+#~ ".list();]]>"
+#~ msgstr ""
+#~ "<![CDATA[List cats = session.createSQLQuery(\"SELECT {cat.*} FROM CAT "
+#~ "{cat} WHERE ROWNUM<10\")\n"
+#~ "    .addEntity(\"cat\", Cat.class)\n"
+#~ ".list();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[List cats = session.createSQLQuery(\n"
+#~ "    \"SELECT {cat}.ID AS {cat.id}, {cat}.SEX AS {cat.sex}, \" +\n"
+#~ "           \"{cat}.MATE AS {cat.mate}, {cat}.SUBCLASS AS {cat.class}, ... "
+#~ "\" +\n"
+#~ "    \"FROM CAT {cat} WHERE ROWNUM<10\")\n"
+#~ "    .addEntity(\"cat\", Cat.class)\n"
+#~ ".list()]]>"
+#~ msgstr ""
+#~ "<![CDATA[List cats = session.createSQLQuery(\n"
+#~ "    \"SELECT {cat}.ID AS {cat.id}, {cat}.SEX AS {cat.sex}, \" +\n"
+#~ "           \"{cat}.MATE AS {cat.mate}, {cat}.SUBCLASS AS {cat.class}, ... "
+#~ "\" +\n"
+#~ "    \"FROM CAT {cat} WHERE ROWNUM<10\")\n"
+#~ "    .addEntity(\"cat\", Cat.class)\n"
+#~ ".list()]]>"
+
+#~ msgid ""
+#~ "<![CDATA[DomesticCat cat = (DomesticCat) sess.load( Cat.class, new Long"
+#~ "(69) );\n"
+#~ "cat.setName(\"PK\");\n"
+#~ "sess.flush();  // changes to cat are automatically detected and "
+#~ "persisted]]>"
+#~ msgstr ""
+#~ "<![CDATA[DomesticCat cat = (DomesticCat) sess.load( Cat.class, new Long"
+#~ "(69) );\n"
+#~ "cat.setName(\"PK\");\n"
+#~ "sess.flush();  // changes to cat are automatically detected and "
+#~ "persisted]]>"
+
+#~ msgid ""
+#~ "<![CDATA[// in the first session\n"
+#~ "Cat cat = (Cat) firstSession.load(Cat.class, catId);\n"
+#~ "Cat potentialMate = new Cat();\n"
+#~ "firstSession.save(potentialMate);\n"
+#~ "\n"
+#~ "// in a higher layer of the application\n"
+#~ "cat.setMate(potentialMate);\n"
+#~ "\n"
+#~ "// later, in a new session\n"
+#~ "secondSession.update(cat);  // update cat\n"
+#~ "secondSession.update(mate); // update mate]]>"
+#~ msgstr ""
+#~ "<![CDATA[// in the first session\n"
+#~ "Cat cat = (Cat) firstSession.load(Cat.class, catId);\n"
+#~ "Cat potentialMate = new Cat();\n"
+#~ "firstSession.save(potentialMate);\n"
+#~ "\n"
+#~ "// in a higher layer of the application\n"
+#~ "cat.setMate(potentialMate);\n"
+#~ "\n"
+#~ "// later, in a new session\n"
+#~ "secondSession.update(cat);  // update cat\n"
+#~ "secondSession.update(mate); // update mate]]>"
+
+#~ msgid ""
+#~ "<![CDATA[//just reassociate:\n"
+#~ "sess.lock(fritz, LockMode.NONE);\n"
+#~ "//do a version check, then reassociate:\n"
+#~ "sess.lock(izi, LockMode.READ);\n"
+#~ "//do a version check, using SELECT ... FOR UPDATE, then reassociate:\n"
+#~ "sess.lock(pk, LockMode.UPGRADE);]]>"
+#~ msgstr ""
+#~ "<![CDATA[//just reassociate:\n"
+#~ "sess.lock(fritz, LockMode.NONE);\n"
+#~ "//do a version check, then reassociate:\n"
+#~ "sess.lock(izi, LockMode.READ);\n"
+#~ "//do a version check, using SELECT ... FOR UPDATE, then reassociate:\n"
+#~ "sess.lock(pk, LockMode.UPGRADE);]]>"
+
+#~ msgid ""
+#~ "<![CDATA[// in the first session\n"
+#~ "Cat cat = (Cat) firstSession.load(Cat.class, catID);\n"
+#~ "\n"
+#~ "// in a higher tier of the application\n"
+#~ "Cat mate = new Cat();\n"
+#~ "cat.setMate(mate);\n"
+#~ "\n"
+#~ "// later, in a new session\n"
+#~ "secondSession.saveOrUpdate(cat);   // update existing state (cat has a "
+#~ "non-null id)\n"
+#~ "secondSession.saveOrUpdate(mate);  // save the new instance (mate has a "
+#~ "null id)]]>"
+#~ msgstr ""
+#~ "<![CDATA[// in the first session\n"
+#~ "Cat cat = (Cat) firstSession.load(Cat.class, catID);\n"
+#~ "\n"
+#~ "// in a higher tier of the application\n"
+#~ "Cat mate = new Cat();\n"
+#~ "cat.setMate(mate);\n"
+#~ "\n"
+#~ "// later, in a new session\n"
+#~ "secondSession.saveOrUpdate(cat);   // update existing state (cat has a "
+#~ "non-null id)\n"
+#~ "secondSession.saveOrUpdate(mate);  // save the new instance (mate has a "
+#~ "null id)]]>"
+
+#~ msgid "<![CDATA[sess.delete(cat);]]>"
+#~ msgstr "<![CDATA[sess.delete(cat);]]>"
+
+#~ msgid ""
+#~ "<![CDATA[//retrieve a cat from one database\n"
+#~ "Session session1 = factory1.openSession();\n"
+#~ "Transaction tx1 = session1.beginTransaction();\n"
+#~ "Cat cat = session1.get(Cat.class, catId);\n"
+#~ "tx1.commit();\n"
+#~ "session1.close();\n"
+#~ "\n"
+#~ "//reconcile with a second database\n"
+#~ "Session session2 = factory2.openSession();\n"
+#~ "Transaction tx2 = session2.beginTransaction();\n"
+#~ "session2.replicate(cat, ReplicationMode.LATEST_VERSION);\n"
+#~ "tx2.commit();\n"
+#~ "session2.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[//retrieve a cat from one database\n"
+#~ "Session session1 = factory1.openSession();\n"
+#~ "Transaction tx1 = session1.beginTransaction();\n"
+#~ "Cat cat = session1.get(Cat.class, catId);\n"
+#~ "tx1.commit();\n"
+#~ "session1.close();\n"
+#~ "\n"
+#~ "//reconcile with a second database\n"
+#~ "Session session2 = factory2.openSession();\n"
+#~ "Transaction tx2 = session2.beginTransaction();\n"
+#~ "session2.replicate(cat, ReplicationMode.LATEST_VERSION);\n"
+#~ "tx2.commit();\n"
+#~ "session2.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[sess = sf.openSession();\n"
+#~ "Transaction tx = sess.beginTransaction();\n"
+#~ "sess.setFlushMode(FlushMode.COMMIT); // allow queries to return stale "
+#~ "state\n"
+#~ "\n"
+#~ "Cat izi = (Cat) sess.load(Cat.class, id);\n"
+#~ "izi.setName(iznizi);\n"
+#~ "\n"
+#~ "// might return stale data\n"
+#~ "sess.find(\"from Cat as cat left outer join cat.kittens kitten\");\n"
+#~ "\n"
+#~ "// change to izi is not flushed!\n"
+#~ "...\n"
+#~ "tx.commit(); // flush occurs\n"
+#~ "sess.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[sess = sf.openSession();\n"
+#~ "Transaction tx = sess.beginTransaction();\n"
+#~ "sess.setFlushMode(FlushMode.COMMIT); // allow queries to return stale "
+#~ "state\n"
+#~ "\n"
+#~ "Cat izi = (Cat) sess.load(Cat.class, id);\n"
+#~ "izi.setName(iznizi);\n"
+#~ "\n"
+#~ "// might return stale data\n"
+#~ "sess.find(\"from Cat as cat left outer join cat.kittens kitten\");\n"
+#~ "\n"
+#~ "// change to izi is not flushed!\n"
+#~ "...\n"
+#~ "tx.commit(); // flush occurs\n"
+#~ "sess.close();]]>"
+
+#~ msgid "<![CDATA[<one-to-one name=\"person\" cascade=\"persist\"/>]]>"
+#~ msgstr "<![CDATA[<one-to-one name=\"person\" cascade=\"persist\"/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<one-to-one name=\"person\" cascade=\"persist,delete,lock\"/>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<one-to-one name=\"person\" cascade=\"persist,delete,lock\"/>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Cat fritz = ......;\n"
+#~ "ClassMetadata catMeta = sessionfactory.getClassMetadata(Cat.class);\n"
+#~ "\n"
+#~ "Object[] propertyValues = catMeta.getPropertyValues(fritz);\n"
+#~ "String[] propertyNames = catMeta.getPropertyNames();\n"
+#~ "Type[] propertyTypes = catMeta.getPropertyTypes();\n"
+#~ "\n"
+#~ "// get a Map of all properties which are not collections or associations\n"
+#~ "Map namedValues = new HashMap();\n"
+#~ "for ( int i=0; i<propertyNames.length; i++ ) {\n"
+#~ "    if ( !propertyTypes[i].isEntityType() && !propertyTypes[i]."
+#~ "isCollectionType() ) {\n"
+#~ "        namedValues.put( propertyNames[i], propertyValues[i] );\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[Cat fritz = ......;\n"
+#~ "ClassMetadata catMeta = sessionfactory.getClassMetadata(Cat.class);\n"
+#~ "\n"
+#~ "Object[] propertyValues = catMeta.getPropertyValues(fritz);\n"
+#~ "String[] propertyNames = catMeta.getPropertyNames();\n"
+#~ "Type[] propertyTypes = catMeta.getPropertyTypes();\n"
+#~ "\n"
+#~ "// get a Map of all properties which are not collections or associations\n"
+#~ "Map namedValues = new HashMap();\n"
+#~ "for ( int i=0; i<propertyNames.length; i++ ) {\n"
+#~ "    if ( !propertyTypes[i].isEntityType() && !propertyTypes[i]."
+#~ "isCollectionType() ) {\n"
+#~ "        namedValues.put( propertyNames[i], propertyValues[i] );\n"
+#~ "    }\n"
+#~ "}]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/toolset_guide.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/toolset_guide.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/toolset_guide.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,57 +1,57 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2009-12-04 15:04+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: toolset_guide.xml:29
 #, no-c-format
 msgid "Toolset Guide"
 msgstr "工具箱指南"
 
 #. Tag: para
-#: toolset_guide.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Roundtrip engineering with Hibernate is possible using a set of Eclipse "
 "plugins, commandline tools, and Ant tasks."
 msgstr ""
-"可以通过一系列Eclipse插件、命令行工具和Ant任务来进行与Hibernate关联的转换。"
+"可以通过一系列 Eclipse 插件、命令行工具和 Ant 任务来进行与 Hibernate 关联的转"
+"换。 "
 
 #. Tag: para
-#: toolset_guide.xml:36
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Hibernate Tools</emphasis> currently include plugins for the "
 "Eclipse IDE as well as Ant tasks for reverse engineering of existing "
 "databases:"
 msgstr ""
-"除了Ant任务外,当前的<emphasis>Hibernate Tools</emphasis>也包含了Eclipse IDE"
-"的插件,用于与现存数据库的逆向工程。"
+"除了 Ant 任务外,当前的 <emphasis>Hibernate Tools</emphasis> 也包含了 "
+"Eclipse IDE 的插件,用于与现存数据库的逆向工程。 "
 
 #. Tag: para
-#: toolset_guide.xml:42
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Mapping Editor:</emphasis> an editor for Hibernate XML mapping "
 "files that supports auto-completion and syntax highlighting. It also "
 "supports semantic auto-completion for class names and property/field names, "
 "making it more versatile than a normal XML editor."
 msgstr ""
-"<emphasis>Mapping Editor:</emphasis> Hibernate XML映射文件的编辑器,支持自动"
-"完成和语法高亮。它也支持对类名和属性/字段名的语义自动完成,比通常的XML编辑器"
-"方便得多。"
+"<emphasis>Mapping Editor:</emphasis> Hibernate XML 映射文件的编辑器,支持自动"
+"完成和语法高亮。它也支持对类名和属性/字段名的语义自动完成,比通常的 XML 编辑"
+"器方便得多。 "
 
 #. Tag: para
-#: toolset_guide.xml:47
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Console:</emphasis> the console is a new view in Eclipse. In "
 "addition to a tree overview of your console configurations, you are also "
@@ -59,13 +59,12 @@
 "relationships. The console allows you to execute HQL queries against your "
 "database and browse the result directly in Eclipse."
 msgstr ""
-"<emphasis>Console:</emphasis> Console是Eclipse的一个新视图。除了对你的console"
-"配置的树状概览,你还可以获得对你持久化类及其关联的交互式视图。Console允许你对"
-"数据库执行HQL查询,并直接在Eclipse中浏览结果。"
+"<emphasis>Console:</emphasis> Console 是 Eclipse 的一个新视图。除了对你的 "
+"console 配置的树状概览,你还可以获得对你持久化类及其关联的交互式视图。"
+"Console 允许你对数据库执行 HQL 查询,并直接在 Eclipse 中浏览结果。 "
 
 #. Tag: para
-#: toolset_guide.xml:54
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Development Wizards:</emphasis> several wizards are provided with "
 "the Hibernate Eclipse tools. You can use a wizard to quickly generate "
@@ -73,442 +72,290 @@
 "database schema into POJO source files and Hibernate mapping files. The "
 "reverse engineering wizard supports customizable templates."
 msgstr ""
-"<emphasis>Development Wizards:</emphasis> 在Hibernate Eclipse tools中还提供了"
-"几个向导;你可以用向导快速生成Hibernate 配置文件(cfg.xml),你甚至还可以同现"
-"存的数据库schema中反向工程出POJO源代码与Hibernate 映射文件。反向工程支持可定"
-"制的模版。"
+"<emphasis>Development Wizards:</emphasis> 在 Hibernate Eclipse tools 中还提供"
+"了几个向导;你可以用向导快速生成 Hibernate 配置文件(cfg.xml),你甚至还可以"
+"同现存的数据库 schema 中反向工程出 POJO 源代码与 Hibernate 映射文件。反向工程"
+"支持可定制的模版。 "
 
 #. Tag: para
-#: toolset_guide.xml:67
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Please refer to the <emphasis>Hibernate Tools</emphasis> package "
 "documentation for more information."
 msgstr ""
-"要得到更多信息,请查阅 <emphasis>Hibernate Tools</emphasis> 包及其文档。"
+"要得到更多信息,请查阅 <emphasis>Hibernate Tools</emphasis> 包及其文档。 "
 
 #. Tag: para
-#: toolset_guide.xml:72
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, the Hibernate main package comes bundled with an integrated tool : "
 "<emphasis>SchemaExport</emphasis> aka <literal>hbm2ddl</literal>.It can even "
 "be used from \"inside\" Hibernate."
 msgstr ""
-"同时,Hibernate主发行包还附带了一个集成的工具(它甚至可以在Hibernate“内部”快"
-"速运行)<emphasis>SchemaExport</emphasis> ,也就是 <literal>hbm2ddl</"
-"literal>。"
+"同时,Hibernate 主发行包还附带了一个集成的工具(它甚至可以在 Hibernate“内"
+"部”快速运行)<emphasis>SchemaExport</emphasis> ,也就是 <literal>hbm2ddl</"
+"literal>。 "
 
 #. Tag: title
-#: toolset_guide.xml:79
 #, no-c-format
 msgid "Automatic schema generation"
-msgstr "Schema自动生成(Automatic schema generation)"
+msgstr "Schema 自动生成(Automatic schema generation)"
 
 #. Tag: para
-#: toolset_guide.xml:81
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "DDL can be generated from your mapping files by a Hibernate utility. The "
 "generated schema includes referential integrity constraints, primary and "
 "foreign keys, for entity and collection tables. Tables and sequences are "
 "also created for mapped identifier generators."
 msgstr ""
-"可以从你的映射文件使用一个Hibernate工具生成DDL。 生成的schema包含有对实体和集"
-"合类表的完整性引用约束(主键和外键)。涉及到的标示符生成器所需的表和sequence"
-"也会同时生成。"
+"可以从你的映射文件使用一个 Hibernate 工具生成 DDL。生成的 schema 包含有对实体"
+"和集合类表的完整性引用约束(主键和外键)。涉及到的标示符生成器所需的表和 "
+"sequence 也会同时生成。 "
 
 #. Tag: para
-#: toolset_guide.xml:88
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You <emphasis>must</emphasis> specify a SQL <literal>Dialect</literal> via "
 "the <literal>hibernate.dialect</literal> property when using this tool, as "
 "DDL is highly vendor-specific."
 msgstr ""
-"在使用这个工具的时候,你<emphasis>必须</emphasis> 通过<literal>hibernate."
-"dialet</literal>属性指定一个SQL<literal>方言(Dialet)</literal>,因为DDL是与供"
-"应商高度相关的。"
+"在使用这个工具的时候,你<emphasis>必须</emphasis> 通过 <literal>hibernate."
+"dialet</literal> 属性指定一个 SQL<literal> 方言(Dialet)</literal>,因为 "
+"DDL 是与供应商高度相关的。 "
 
 #. Tag: para
-#: toolset_guide.xml:94
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, you must customize your mapping files to improve the generated "
 "schema. The next section covers schema customization."
-msgstr "首先,要定制你的映射文件,来改善生成的schema。"
+msgstr ""
+"首先,要定制你的映射文件,来改善生成的 schema。下章将涵盖 schema 定制。"
 
 #. Tag: title
-#: toolset_guide.xml:99
 #, no-c-format
 msgid "Customizing the schema"
-msgstr "对schema定制化(Customizing the schema)"
+msgstr "对 schema 定制化(Customizing the schema)"
 
 #. Tag: para
-#: toolset_guide.xml:101
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Many Hibernate mapping elements define optional attributes named "
 "<literal>length</literal>, <literal>precision</literal> and <literal>scale</"
 "literal>. You can set the length, precision and scale of a column with this "
 "attribute."
 msgstr ""
-"很多Hibernate映射元素定义了可选的<literal>length</literal>、"
-"<literal>precision</literal> 或者 <literal>scale</literal>属性。你可以通过这"
-"个属性设置字段的长度、精度、小数点位数。"
+"很多 Hibernate 映射元素定义了可选的 <literal>length</literal>、"
+"<literal>precision</literal> 或者 <literal>scale</literal> 属性。你可以通过这"
+"个属性设置字段的长度、精度、小数点位数。 "
 
-#. Tag: programlisting
-#: toolset_guide.xml:108
-#, no-c-format
-msgid "<![CDATA[<property name=\"zip\" length=\"5\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:109
-#, no-c-format
-msgid "<![CDATA[<property name=\"balance\" precision=\"12\" scale=\"2\"/>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Some tags also accept a <literal>not-null</literal> attribute for generating "
 "a <literal>NOT NULL</literal> constraint on table columns, and a "
 "<literal>unique</literal> attribute for generating <literal>UNIQUE</literal> "
 "constraint on table columns."
 msgstr ""
-"有些tag还接受<literal>not-null</literal>属性(用来在表字段上生成<literal>NOT "
-"NULL</literal>约束)和<literal>unique</literal>属性(用来在表字段上生成"
-"<literal>UNIQUE</literal>约束)。"
+"有些 tag 还接受 <literal>not-null</literal> 属性(用来在表字段上生成 "
+"<literal>NOT NULL</literal> 约束)和 <literal>unique</literal> 属性(用来在表"
+"字段上生成 <literal>UNIQUE</literal> 约束)。 "
 
-#. Tag: programlisting
-#: toolset_guide.xml:117
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"bar\" column=\"barId\" not-null=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:119
-#, no-c-format
-msgid ""
-"<![CDATA[<element column=\"serialNumber\" type=\"long\" not-null=\"true\" "
-"unique=\"true\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:121
-#, fuzzy, no-c-format
-msgid ""
 "A <literal>unique-key</literal> attribute can be used to group columns in a "
 "single, unique key constraint. Currently, the specified value of the "
 "<literal>unique-key</literal> attribute is <emphasis>not</emphasis> used to "
 "name the constraint in the generated DDL. It is only used to group the "
 "columns in the mapping file."
 msgstr ""
-"<literal>unique-key</literal>属性可以对成组的字段指定一个唯一键约束(unique "
-"key constraint)。目前,<literal>unique-key</literal>属性指定的值在生成DDL时"
-"<emphasis>并不会</emphasis>被当作这个约束的名字,它们只是在用来在映射文件内部"
-"用作区分的。"
+"<literal>unique-key</literal> 属性可以对成组的字段指定一个唯一键约束(unique "
+"key constraint)。目前,<literal>unique-key</literal> 属性指定的值在生成 DDL "
+"时<emphasis>并不会</emphasis>被当作这个约束的名字,它们只是在用来在映射文件内"
+"部用作区分的。 "
 
-#. Tag: programlisting
-#: toolset_guide.xml:129
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<many-to-one name=\"org\" column=\"orgId\" unique-key="
-"\"OrgEmployeeId\"/>\n"
-"<property name=\"employeeId\" unique-key=\"OrgEmployee\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:131
-#, fuzzy, no-c-format
-msgid ""
 "An <literal>index</literal> attribute specifies the name of an index that "
 "will be created using the mapped column or columns. Multiple columns can be "
 "grouped into the same index by simply specifying the same index name."
 msgstr ""
-"<literal>index</literal>属性会用对应的字段(一个或多个)生成一个index,它指出"
-"了这个index的名字。如果多个字段对应的index名字相同,就会生成包含这些字段的"
-"index。"
+"<literal>index</literal> 属性会用对应的字段(一个或多个)生成一个 index,它指"
+"出了这个 index 的名字。如果多个字段对应的 index 名字相同,就会生成包含这些字"
+"段的 index。 "
 
-#. Tag: programlisting
-#: toolset_guide.xml:137
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<property name=\"lastName\" index=\"CustName\"/>\n"
-"<property name=\"firstName\" index=\"CustName\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:139
-#, fuzzy, no-c-format
-msgid ""
 "A <literal>foreign-key</literal> attribute can be used to override the name "
 "of any generated foreign key constraint."
 msgstr ""
-"<literal>foreign-key</literal>属性可以用来覆盖任何生成的外键约束的名字。"
+"<literal>foreign-key</literal> 属性可以用来覆盖任何生成的外键约束的名字。 "
 
-#. Tag: programlisting
-#: toolset_guide.xml:144
-#, no-c-format
-msgid ""
-"<![CDATA[<many-to-one name=\"bar\" column=\"barId\" foreign-key=\"FKFooBar\"/"
-">]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:146
 #, no-c-format
 msgid ""
 "Many mapping elements also accept a child <literal>&lt;column&gt;</literal> "
 "element. This is particularly useful for mapping multi-column types:"
 msgstr ""
-"很多映射元素还接受<literal>&lt;column&gt;</literal>子元素。这在定义跨越多字段"
-"的类型时特别有用。"
+"很多映射元素还接受 <literal>&lt;column&gt;</literal> 子元素。这在定义跨越多字"
+"段的类型时特别有用。"
 
-#. Tag: programlisting
-#: toolset_guide.xml:151
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<property name=\"name\" type=\"my.customtypes.Name\"/>\n"
-"    <column name=\"last\" not-null=\"true\" index=\"bar_idx\" length=\"30\"/"
-">\n"
-"    <column name=\"first\" not-null=\"true\" index=\"bar_idx\" length=\"20\"/"
-">\n"
-"    <column name=\"initial\"/>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:153
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>default</literal> attribute allows you to specify a default "
 "value for a column.You should assign the same value to the mapped property "
 "before saving a new instance of the mapped class."
 msgstr ""
-"<literal>default</literal>属性为字段指定一个默认值 (在保存被映射的类的新实例"
-"之前,你应该将同样的值赋于对应的属性)。"
+"<literal>default</literal> 属性为字段指定一个默认值(在保存被映射的类的新实例"
+"之前,你应该将同样的值赋于对应的属性)。"
 
-#. Tag: programlisting
-#: toolset_guide.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"credits\" type=\"integer\" insert=\"false\">\n"
-"    <column name=\"credits\" default=\"10\"/>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:161
-#, no-c-format
-msgid ""
-"<![CDATA[<version name=\"version\" type=\"integer\" insert=\"false\">\n"
-"    <column name=\"version\" default=\"0\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:163
 #, no-c-format
 msgid ""
 "The <literal>sql-type</literal> attribute allows the user to override the "
 "default mapping of a Hibernate type to SQL datatype."
 msgstr ""
-"<literal>sql-type</literal>属性允许用户覆盖默认的Hibernate类型到SQL数据类型的"
-"映射。"
+"<literal>sql-type</literal> 属性允许用户覆盖默认的 Hibernate 类型到 SQL 数据"
+"类型的映射。"
 
-#. Tag: programlisting
-#: toolset_guide.xml:168
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"balance\" type=\"float\">\n"
-"    <column name=\"balance\" sql-type=\"decimal(13,3)\"/>\n"
-"</property>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:170
 #, no-c-format
 msgid ""
 "The <literal>check</literal> attribute allows you to specify a check "
 "constraint."
-msgstr "<literal>check</literal>属性允许用户指定一个约束检查。"
+msgstr "<literal>check</literal> 属性允许用户指定一个约束检查。"
 
-#. Tag: programlisting
-#: toolset_guide.xml:174
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"foo\" type=\"integer\">\n"
-"    <column name=\"foo\" check=\"foo > 10\"/>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:176
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Foo\" table=\"foos\" check=\"bar < 100.0\">\n"
-"    ...\n"
-"    <property name=\"bar\" type=\"float\"/>\n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: para
-#: toolset_guide.xml:179
 #, no-c-format
 msgid "The following table summarizes these optional attributes."
-msgstr ""
+msgstr "下表总结了这些可选属性:"
 
 #. Tag: title
-#: toolset_guide.xml:182
 #, no-c-format
 msgid "Summary"
-msgstr "Summary"
+msgstr "总结"
 
 #. Tag: entry
-#: toolset_guide.xml:189
 #, no-c-format
 msgid "Attribute"
-msgstr "属性(Attribute)"
+msgstr "属性(Attribute)"
 
 #. Tag: entry
-#: toolset_guide.xml:190
 #, no-c-format
 msgid "Values"
 msgstr "值(Values)"
 
 #. Tag: entry
-#: toolset_guide.xml:191
 #, no-c-format
 msgid "Interpretation"
 msgstr "解释(Interpretation)"
 
-#. Tag: literal
-#: toolset_guide.xml:196
+#. Tag: entry
 #, no-c-format
-msgid "length"
-msgstr "length"
+msgid "<literal>length</literal>"
+msgstr "<literal>length</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:197 toolset_guide.xml:202 toolset_guide.xml:207
 #, no-c-format
 msgid "number"
 msgstr "æ•°å­—"
 
 #. Tag: entry
-#: toolset_guide.xml:198
 #, no-c-format
 msgid "column length"
 msgstr "字段长度"
 
-#. Tag: literal
-#: toolset_guide.xml:201
+#. Tag: entry
 #, no-c-format
-msgid "precision"
-msgstr "precision"
+msgid "<literal>precision</literal>"
+msgstr "<literal>precision</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:203
 #, no-c-format
 msgid "column decimal precision"
-msgstr "精度(decimal precision)"
+msgstr "精度(decimal precision)"
 
-#. Tag: literal
-#: toolset_guide.xml:206
+#. Tag: entry
 #, no-c-format
-msgid "scale"
-msgstr "scale"
+msgid "<literal>scale</literal>"
+msgstr "<literal>scale</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:208
 #, no-c-format
 msgid "column decimal scale"
-msgstr "小数点位数(decimal scale)"
+msgstr "小数点位数(decimal scale)"
 
-#. Tag: literal
-#: toolset_guide.xml:211
+#. Tag: entry
 #, no-c-format
-msgid "not-null"
-msgstr "not-null"
+msgid "<literal>not-null</literal>"
+msgstr "<literal>not-null</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:212 toolset_guide.xml:217
+#. Tag: entry
 #, no-c-format
-msgid "true|false"
-msgstr "true|false"
+msgid "<literal>true|false</literal>"
+msgstr "<literal>true|false</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:213
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "specifies that the column should be non-nullable"
-msgstr "指明字段是否应该是非空的"
+msgstr "指明字段是否应该是非空的 "
 
-#. Tag: literal
-#: toolset_guide.xml:216
+#. Tag: entry
 #, no-c-format
-msgid "unique"
-msgstr "unique"
+msgid "<literal>unique</literal>"
+msgstr "<literal>unique</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:218
 #, no-c-format
 msgid "specifies that the column should have a unique constraint"
 msgstr "指明是否该字段具有惟一约束"
 
-#. Tag: literal
-#: toolset_guide.xml:221
+#. Tag: entry
 #, no-c-format
-msgid "index"
-msgstr "index"
+msgid "<literal>index</literal>"
+msgstr "<literal>index</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:222
+#. Tag: entry
 #, no-c-format
-msgid "index_name"
-msgstr "index_name"
+msgid "<literal>index_name</literal>"
+msgstr "<literal>index_name</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:223
 #, no-c-format
 msgid "specifies the name of a (multi-column) index"
-msgstr "指明一个(多字段)的索引(index)的名字"
+msgstr "指明一个(多字段)的索引(index)的名字"
 
-#. Tag: literal
-#: toolset_guide.xml:226
+#. Tag: entry
 #, no-c-format
-msgid "unique-key"
-msgstr "unique-key"
+msgid "<literal>unique-key</literal>"
+msgstr "<literal>unique-key</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:227
+#. Tag: entry
 #, no-c-format
-msgid "unique_key_name"
-msgstr "unique_key_name"
+msgid "<literal>unique_key_name</literal>"
+msgstr "<literal>unique_key_name</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:228
 #, no-c-format
 msgid "specifies the name of a multi-column unique constraint"
 msgstr "指明多字段惟一约束的名字(参见上面的说明)"
 
-#. Tag: literal
-#: toolset_guide.xml:231
+#. Tag: entry
 #, no-c-format
-msgid "foreign-key"
-msgstr "foreign-key"
+msgid "<literal>foreign-key</literal>"
+msgstr "<literal>foreign-key</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:232
+#. Tag: entry
 #, no-c-format
-msgid "foreign_key_name"
-msgstr "foreign_key_name"
+msgid "<literal>foreign_key_name</literal>"
+msgstr "<literal>foreign_key_name</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:233
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "specifies the name of the foreign key constraint generated for an "
 "association, for a <literal>&lt;one-to-one&gt;</literal>, <literal>&lt;many-"
@@ -516,555 +363,393 @@
 "to-many&gt;</literal> mapping element. Note that <literal>inverse=\"true\"</"
 "literal> sides will not be considered by <literal>SchemaExport</literal>."
 msgstr ""
-"指明一个外键的名字,它是为关联生成的,或者<placeholder-1/>,<placeholder-2/"
-">, <placeholder-3/>, 或者<placeholder-4/>映射元素。注意<placeholder-5/>在"
-"<placeholder-6/>时会被忽略。"
+"指明一个外键的名字,它是为关联生成的,或者是为 <literal>&lt;one-to-one&gt;</"
+"literal>, <literal>&lt;many-to-one&gt;</literal>, <literal>&lt;key&gt;</"
+"literal>, or <literal>&lt;many-to-many&gt;</literal> 映射元素。注意 "
+"<literal>inverse=\"true\"</literal> 会被 <literal>SchemaExport</literal> 忽"
+"略。"
 
-#. Tag: literal
-#: toolset_guide.xml:243
+#. Tag: entry
 #, no-c-format
-msgid "sql-type"
-msgstr "sql-type"
+msgid "<literal>sql-type</literal>"
+msgstr "<literal>sql-type</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:244
-#, no-c-format
-msgid "SQL column type"
-msgstr "SQL 字段类型"
-
 #. Tag: entry
-#: toolset_guide.xml:245
 #, fuzzy, no-c-format
+msgid "<literal>SQL column type</literal>"
+msgstr "<literal>sql-type</literal>"
+
+#. Tag: entry
+#, no-c-format
 msgid ""
 "overrides the default column type (attribute of <literal>&lt;column&gt;</"
 "literal> element only)"
-msgstr "覆盖默认的字段类型(只能用于<placeholder-1/>属性)"
+msgstr "覆盖默认的字段类型(只能用于 <literal>&lt;column&gt;</literal> 属性)"
 
-#. Tag: literal
-#: toolset_guide.xml:251
+#. Tag: entry
 #, no-c-format
-msgid "default"
-msgstr "default"
+msgid "<literal>default</literal>"
+msgstr "<literal>default</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:252 toolset_guide.xml:259
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "SQL expression"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"SQL表达式\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"SQL 表达式"
+msgstr "SQL 表达式"
 
 #. Tag: entry
-#: toolset_guide.xml:253
 #, no-c-format
 msgid "specify a default value for the column"
 msgstr "为字段指定默认值"
 
-#. Tag: literal
-#: toolset_guide.xml:258
+#. Tag: entry
 #, no-c-format
-msgid "check"
-msgstr "check"
+msgid "<literal>check</literal>"
+msgstr "<literal>check</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:260
 #, no-c-format
 msgid "create an SQL check constraint on either column or table"
-msgstr "对字段或表加入SQL约束检查"
+msgstr "对字段或表加入 SQL 约束检查"
 
 #. Tag: para
-#: toolset_guide.xml:268
 #, no-c-format
 msgid ""
 "The <literal>&lt;comment&gt;</literal> element allows you to specify "
 "comments for the generated schema."
 msgstr ""
-"<literal>&lt;comment&gt;</literal>元素可以让你在生成的schema中加入注释。"
+"<literal>&lt;comment&gt;</literal> 元素可以让你在生成的 schema 中加入注释。"
 
-#. Tag: programlisting
-#: toolset_guide.xml:273
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Customer\" table=\"CurCust\">\n"
-"    <comment>Current customers only</comment>\n"
-"    ...\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: programlisting
-#: toolset_guide.xml:275
-#, no-c-format
-msgid ""
-"<![CDATA[<property name=\"balance\">\n"
-"    <column name=\"bal\">\n"
-"        <comment>Balance in USD</comment>\n"
-"    </column>\n"
-"</property>]]>"
-msgstr ""
-
-#. Tag: para
-#: toolset_guide.xml:277
-#, fuzzy, no-c-format
-msgid ""
 "This results in a <literal>comment on table</literal> or <literal>comment on "
 "column</literal> statement in the generated DDL where supported."
 msgstr ""
-"结果是在生成的DDL中包含<literal>comment on table</literal> 或者 "
-"<literal>comment on column</literal>语句(假若支持的话)。"
+"结果是在生成的 DDL 中包含 <literal>comment on table</literal> 或者 "
+"<literal>comment on column</literal> 语句(假若支持的话)。 "
 
 #. Tag: title
-#: toolset_guide.xml:286
 #, no-c-format
 msgid "Running the tool"
 msgstr "运行该工具"
 
 #. Tag: para
-#: toolset_guide.xml:288
 #, no-c-format
 msgid ""
 "The <literal>SchemaExport</literal> tool writes a DDL script to standard out "
 "and/or executes the DDL statements."
 msgstr ""
-"<literal>SchemaExport</literal>工具把DDL脚本写到标准输出,同时/或者执行DDL语"
-"句。"
+"<literal>SchemaExport</literal> 工具把 DDL 脚本写到标准输出,同时/或者执行 "
+"DDL 语句。"
 
 #. Tag: para
-#: toolset_guide.xml:293
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table displays the <literal>SchemaExport</literal> command "
 "line options"
-msgstr "<literal>SchemaExport</literal>命令行选项"
+msgstr "下表显示了 <literal>SchemaExport</literal> 命令行选项"
 
 #. Tag: para
-#: toolset_guide.xml:295
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
 "<literal>org.hibernate.tool.hbm2ddl.SchemaExport</literal> <emphasis>options "
 "mapping_files</emphasis>"
 msgstr ""
+"<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
+"<literal>org.hibernate.tool.hbm2ddl.SchemaExport</literal> <emphasis>options "
+"mapping_files</emphasis>"
 
 #. Tag: title
-#: toolset_guide.xml:301
 #, no-c-format
 msgid "<literal>SchemaExport</literal> Command Line Options"
-msgstr "<literal>SchemaExport</literal>命令行选项"
+msgstr "<literal>SchemaExport</literal> 命令行选项"
 
 #. Tag: entry
-#: toolset_guide.xml:307 toolset_guide.xml:457 toolset_guide.xml:527
 #, no-c-format
 msgid "Option"
 msgstr "选项"
 
 #. Tag: entry
-#: toolset_guide.xml:308 toolset_guide.xml:395 toolset_guide.xml:458
-#: toolset_guide.xml:528
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Description"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"说明\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"说明\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"说明\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"描述"
+msgstr "描述"
 
-#. Tag: literal
-#: toolset_guide.xml:313 toolset_guide.xml:463
+#. Tag: entry
 #, no-c-format
-msgid "--quiet"
-msgstr "--quiet"
+msgid "<literal>--quiet</literal>"
+msgstr "<literal>--quiet</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:314 toolset_guide.xml:464
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "do not output the script to stdout"
-msgstr "不要把脚本输出到stdout"
+msgstr "不要把脚本输出到 stdout "
 
-#. Tag: literal
-#: toolset_guide.xml:317
+#. Tag: entry
 #, no-c-format
-msgid "--drop"
-msgstr "--drop"
+msgid "<literal>--drop</literal>"
+msgstr "<literal>--drop</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:318
 #, no-c-format
 msgid "only drop the tables"
-msgstr "只进行drop tables的步骤"
+msgstr "只进行 drop tables 的步骤"
 
-#. Tag: literal
-#: toolset_guide.xml:321
+#. Tag: entry
 #, no-c-format
-msgid "--create"
-msgstr "--create"
+msgid "<literal>--create</literal>"
+msgstr "<literal>--create</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:322
 #, no-c-format
 msgid "only create the tables"
 msgstr "只创建表"
 
-#. Tag: literal
-#: toolset_guide.xml:325 toolset_guide.xml:467
+#. Tag: entry
 #, no-c-format
-msgid "--text"
-msgstr "--text"
+msgid "<literal>--text</literal>"
+msgstr "<literal>--text</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:326
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "do not export to the database"
-msgstr "不执行在数据库中运行的步骤"
+msgstr "不执行在数据库中运行的步骤 "
 
-#. Tag: literal
-#: toolset_guide.xml:329
-#, no-c-format
-msgid "--output=my_schema.ddl"
-msgstr "--output=my_schema.ddl"
+#. Tag: entry
+#, fuzzy, no-c-format
+msgid "<literal>--output=my_schema.ddl</literal>"
+msgstr "<literal>scale</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:330
 #, no-c-format
 msgid "output the ddl script to a file"
-msgstr "把输出的ddl脚本输出到一个文件"
+msgstr "把输出的 ddl 脚本输出到一个文件"
 
-#. Tag: literal
-#: toolset_guide.xml:333 toolset_guide.xml:471 toolset_guide.xml:533
-#, no-c-format
-msgid "--naming=eg.MyNamingStrategy"
-msgstr "--naming=eg.MyNamingStrategy"
-
 #. Tag: entry
-#: toolset_guide.xml:334 toolset_guide.xml:472 toolset_guide.xml:534
 #, fuzzy, no-c-format
-msgid "select a <literal>NamingStrategy</literal>"
-msgstr "在<literal>hibernate.properties</literal>文件中"
+msgid "<literal>--naming=eg.MyNamingStrategy</literal>"
+msgstr "<literal>--naming=eg.MyNamingStrategy</literal>"
 
-#. Tag: literal
-#: toolset_guide.xml:337 toolset_guide.xml:479 toolset_guide.xml:541
+#. Tag: entry
 #, no-c-format
-msgid "--config=hibernate.cfg.xml"
-msgstr "--config=hibernate.cfg.xml"
+msgid "select a <literal>NamingStrategy</literal>"
+msgstr "选择 <literal>NamingStrategy</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:338
+#, fuzzy, no-c-format
+msgid "<literal>--config=hibernate.cfg.xml</literal>"
+msgstr "<literal>hibernate.dialect</literal>"
+
+#. Tag: entry
 #, no-c-format
 msgid "read Hibernate configuration from an XML file"
-msgstr "从XML文件读入Hibernate配置"
+msgstr "从 XML 文件读入 Hibernate 配置"
 
-#. Tag: literal
-#: toolset_guide.xml:341 toolset_guide.xml:475 toolset_guide.xml:537
+#. Tag: entry
 #, no-c-format
-msgid "--properties=hibernate.properties"
-msgstr "--properties=hibernate.properties"
+msgid "<literal>--properties=hibernate.properties</literal>"
+msgstr "<literal>--properties=hibernate.properties</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:342 toolset_guide.xml:476 toolset_guide.xml:538
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "read database properties from a file"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"从文件读入数据库属性\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"从指定文件读入数据库属性\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"从文件中读取数据库属性"
+msgstr "从文件读入数据库属性"
 
-#. Tag: literal
-#: toolset_guide.xml:345
+#. Tag: entry
 #, no-c-format
-msgid "--format"
-msgstr "--format"
+msgid "<literal>--format</literal>"
+msgstr "<literal>--format</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:346
 #, no-c-format
 msgid "format the generated SQL nicely in the script"
-msgstr "把脚本中的SQL语句对齐和美化"
+msgstr "把脚本中的 SQL 语句对齐和美化"
 
-#. Tag: literal
-#: toolset_guide.xml:349
+#. Tag: entry
 #, no-c-format
-msgid "--delimiter=;"
-msgstr "--delimiter=;"
+msgid "<literal>--delimiter=;</literal>"
+msgstr "<literal>--delimiter=;</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:350
 #, no-c-format
 msgid "set an end of line delimiter for the script"
 msgstr "为脚本设置行结束符"
 
 #. Tag: para
-#: toolset_guide.xml:356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can even embed <literal>SchemaExport</literal> in your application:"
-msgstr "你甚至可以在你的应用程序中嵌入<literal>SchemaExport</literal>工具:"
+msgstr "你甚至可以在你的应用程序中嵌入 <literal>SchemaExport</literal> 工具: "
 
-#. Tag: programlisting
-#: toolset_guide.xml:360
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaExport(cfg).create(false, true);]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:365
 #, no-c-format
 msgid "Properties"
-msgstr "属性(Properties)"
+msgstr "属性(Properties)"
 
 #. Tag: para
-#: toolset_guide.xml:367
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Database properties can be specified:"
-msgstr "可以通过如下方式指定数据库属性:"
+msgstr "可以通过如下方式指定数据库属性: "
 
 #. Tag: para
-#: toolset_guide.xml:373
 #, no-c-format
 msgid ""
 "as system properties with <literal>-D</literal><emphasis>&lt;property&gt;</"
 "emphasis>"
-msgstr "通过<literal>-D</literal><emphasis>&lt;property&gt;</emphasis>系统参数"
+msgstr ""
+"通过 <literal>-D</literal><emphasis>&lt;property&gt;</emphasis> 系统参数"
 
 #. Tag: para
-#: toolset_guide.xml:376
 #, no-c-format
 msgid "in <literal>hibernate.properties</literal>"
-msgstr "在<literal>hibernate.properties</literal>文件中"
+msgstr "在 <literal>hibernate.properties</literal> 文件中"
 
 #. Tag: para
-#: toolset_guide.xml:379
 #, no-c-format
 msgid "in a named properties file with <literal>--properties</literal>"
 msgstr ""
-"位于一个其它名字的properties文件中,然后用 <literal>--properties</literal>参数"
-"指定"
+"位于一个其它名字的 properties 文件中,然后用 <literal>--properties</literal> "
+"参数指定"
 
 #. Tag: para
-#: toolset_guide.xml:383
 #, no-c-format
 msgid "The needed properties are:"
-msgstr "所需的参数包括:"
+msgstr "所需的参数包括:"
 
 #. Tag: title
-#: toolset_guide.xml:388
 #, no-c-format
 msgid "SchemaExport Connection Properties"
 msgstr "SchemaExport 连接属性"
 
 #. Tag: entry
-#: toolset_guide.xml:394
 #, no-c-format
 msgid "Property Name"
 msgstr "属性名"
 
-#. Tag: literal
-#: toolset_guide.xml:400
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.driver_class"
-msgstr "hibernate.connection.driver_class"
+msgid "<literal>hibernate.connection.driver_class</literal>"
+msgstr "<literal>hibernate.connection.driver_class</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:401
 #, no-c-format
 msgid "jdbc driver class"
 msgstr "jdbc driver class"
 
-#. Tag: literal
-#: toolset_guide.xml:404
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.url"
-msgstr "hibernate.connection.url"
+msgid "<literal>hibernate.connection.url</literal>"
+msgstr "<literal>hibernate.connection.url</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:405
 #, no-c-format
 msgid "jdbc url"
 msgstr "jdbc url"
 
-#. Tag: literal
-#: toolset_guide.xml:408
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.username"
-msgstr "hibernate.connection.username"
+msgid "<literal>hibernate.connection.username</literal>"
+msgstr "<literal>hibernate.connection.username</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:409
 #, no-c-format
 msgid "database user"
 msgstr "database user"
 
-#. Tag: literal
-#: toolset_guide.xml:412
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.connection.password"
-msgstr "hibernate.connection.password"
+msgid "<literal>hibernate.connection.password</literal>"
+msgstr "<literal>hibernate.connection.password</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:413
 #, no-c-format
 msgid "user password"
 msgstr "user password"
 
-#. Tag: literal
-#: toolset_guide.xml:416
+#. Tag: entry
 #, no-c-format
-msgid "hibernate.dialect"
-msgstr "hibernate.dialect"
+msgid "<literal>hibernate.dialect</literal>"
+msgstr "<literal>hibernate.dialect</literal>"
 
 #. Tag: entry
-#: toolset_guide.xml:417
 #, no-c-format
 msgid "dialect"
-msgstr "方言(dialect)"
+msgstr "方言(dialect)"
 
 #. Tag: title
-#: toolset_guide.xml:426
 #, no-c-format
 msgid "Using Ant"
-msgstr "使用Ant(Using Ant)"
+msgstr "使用 Ant(Using Ant)"
 
 #. Tag: para
-#: toolset_guide.xml:428
 #, no-c-format
 msgid ""
 "You can call <literal>SchemaExport</literal> from your Ant build script:"
-msgstr "你可以在你的Ant build脚本中调用<literal>SchemaExport</literal>:"
+msgstr "你可以在你的 Ant build 脚本中调用 <literal>SchemaExport</literal>:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:432
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemaexport\">\n"
-"    <taskdef name=\"schemaexport\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaExportTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemaexport\n"
-"        properties=\"hibernate.properties\"\n"
-"        quiet=\"no\"\n"
-"        text=\"no\"\n"
-"        drop=\"no\"\n"
-"        delimiter=\";\"\n"
-"        output=\"schema-export.sql\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemaexport>\n"
-"</target>]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:437
 #, no-c-format
 msgid "Incremental schema updates"
-msgstr "对schema的增量更新(Incremental schema updates)"
+msgstr "对 schema 的增量更新(Incremental schema updates)"
 
 #. Tag: para
-#: toolset_guide.xml:439
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>SchemaUpdate</literal> tool will update an existing schema with "
 "\"incremental\" changes. The <literal>SchemaUpdate</literal> depends upon "
 "the JDBC metadata API and, as such, will not work with all JDBC drivers."
 msgstr ""
-"<literal>SchemaUpdate</literal>工具对已存在的schema采用\"增量\"方式进行更新。"
-"注意<literal>SchemaUpdate</literal>严重依赖于JDBC metadata API,所以它并非对所"
-"有JDBC驱动都有效。"
+"<literal>SchemaUpdate</literal> 工具对已存在的 schema 采用\"增量\"方式进行更"
+"新。注意 <literal>SchemaUpdate</literal> 严重依赖于 JDBC metadata API,所以它"
+"并非对所有 JDBC 驱动都有效。 "
 
 #. Tag: para
-#: toolset_guide.xml:445
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
 "<literal>org.hibernate.tool.hbm2ddl.SchemaUpdate</literal> <emphasis>options "
 "mapping_files</emphasis>"
 msgstr ""
+"<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
+"<literal>org.hibernate.tool.hbm2ddl.SchemaUpdate</literal> <emphasis>options "
+"mapping_files</emphasis>"
 
 #. Tag: title
-#: toolset_guide.xml:451
 #, no-c-format
 msgid "<literal>SchemaUpdate</literal> Command Line Options"
-msgstr "<literal>SchemaUpdate</literal>命令行选项"
+msgstr "<literal>SchemaUpdate</literal> 命令行选项"
 
 #. Tag: entry
-#: toolset_guide.xml:468
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "do not export the script to the database"
-msgstr "不把脚本输出到数据库"
+msgstr "不把脚本输出到数据库 "
 
 #. Tag: entry
-#: toolset_guide.xml:480 toolset_guide.xml:542
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "specify a <literal>.cfg.xml</literal> file"
-msgstr ""
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"指定一个 <placeholder-1/>文件\n"
-"#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-"指定一个<placeholder-1/>文件"
+msgstr "指定一个 <literal>.cfg.xml</literal> 文件"
 
 #. Tag: para
-#: toolset_guide.xml:486
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can embed <literal>SchemaUpdate</literal> in your application:"
-msgstr "你可以在你的应用程序中嵌入<literal>SchemaUpdate</literal>工具:"
+msgstr "你可以在你的应用程序中嵌入 <literal>SchemaUpdate</literal> 工具: "
 
-#. Tag: programlisting
-#: toolset_guide.xml:490
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaUpdate(cfg).execute(false);]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:495
 #, no-c-format
 msgid "Using Ant for incremental schema updates"
-msgstr "用Ant来增量更新schema(Using Ant for incremental schema updates)"
+msgstr "用 Ant 来增量更新 schema(Using Ant for incremental schema updates)"
 
 #. Tag: para
-#: toolset_guide.xml:497
 #, no-c-format
 msgid "You can call <literal>SchemaUpdate</literal> from the Ant script:"
-msgstr "你可以在Ant脚本中调用<literal>SchemaUpdate</literal>:"
+msgstr "你可以在 Ant 脚本中调用 <literal>SchemaUpdate</literal>:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:501
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemaupdate\">\n"
-"    <taskdef name=\"schemaupdate\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaUpdateTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemaupdate\n"
-"        properties=\"hibernate.properties\"\n"
-"        quiet=\"no\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemaupdate>\n"
-"</target>]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:506
 #, no-c-format
 msgid "Schema validation"
 msgstr "Schema 校验"
 
 #. Tag: para
-#: toolset_guide.xml:508
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>SchemaValidator</literal> tool will validate that the existing "
 "database schema \"matches\" your mapping documents. The "
@@ -1072,131 +757,407 @@
 "API and, as such, will not work with all JDBC drivers. This tool is "
 "extremely useful for testing."
 msgstr ""
-"<literal>SchemaValidator</literal>工具会比较数据库现状是否与映射文档“匹配”。"
-"注意,<literal>SchemaValidator</literal> 严重依赖于JDBC的metadata API,因此不"
-"是对所有的JDBC驱动都适用。这一工具在测试的时候特别有用。"
+"<literal>SchemaValidator</literal> 工具会比较数据库现状是否与映射文档“匹配”。"
+"注意,<literal>SchemaValidator</literal> 严重依赖于 JDBC 的 metadata API,因"
+"此不是对所有的 JDBC 驱动都适用。这一工具在测试的时候特别有用。 "
 
 #. Tag: para
-#: toolset_guide.xml:514
 #, no-c-format
 msgid ""
 "<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
 "<literal>org.hibernate.tool.hbm2ddl.SchemaValidator</literal> "
 "<emphasis>options mapping_files</emphasis>"
 msgstr ""
+"<literal>java -cp </literal><emphasis>hibernate_classpaths</emphasis> "
+"<literal>org.hibernate.tool.hbm2ddl.SchemaValidator</literal> "
+"<emphasis>options mapping_files</emphasis>"
 
 #. Tag: para
-#: toolset_guide.xml:518
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The following table displays the <literal>SchemaValidator</literal> command "
 "line options:"
-msgstr "<literal>SchemaValidator</literal>命令行参数"
+msgstr "下表显示了 <literal>SchemaValidator</literal> 命令行参数:"
 
 #. Tag: title
-#: toolset_guide.xml:521
 #, no-c-format
 msgid "<literal>SchemaValidator</literal> Command Line Options"
-msgstr "<literal>SchemaValidator</literal>命令行参数"
+msgstr "<literal>SchemaValidator</literal> 命令行参数"
 
 #. Tag: para
-#: toolset_guide.xml:548
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "You can embed <literal>SchemaValidator</literal> in your application:"
-msgstr "你可以在你的应用程序中嵌入<literal>SchemaValidator</literal>:"
+msgstr "你可以在你的应用程序中嵌入 <literal>SchemaValidator</literal>: "
 
-#. Tag: programlisting
-#: toolset_guide.xml:552
-#, no-c-format
-msgid ""
-"<![CDATA[Configuration cfg = ....;\n"
-"new SchemaValidator(cfg).validate();]]>"
-msgstr ""
-
 #. Tag: title
-#: toolset_guide.xml:557
 #, no-c-format
 msgid "Using Ant for schema validation"
-msgstr "使用Ant进行schema校验"
+msgstr "使用 Ant 进行 schema 校验"
 
 #. Tag: para
-#: toolset_guide.xml:559
 #, no-c-format
 msgid "You can call <literal>SchemaValidator</literal> from the Ant script:"
-msgstr "你可以在Ant脚本中调用<literal>SchemaValidator</literal>:"
+msgstr "你可以在 Ant 脚本中调用 <literal>SchemaValidator</literal>:"
 
-#. Tag: programlisting
-#: toolset_guide.xml:563
-#, no-c-format
-msgid ""
-"<![CDATA[<target name=\"schemavalidate\">\n"
-"    <taskdef name=\"schemavalidator\"\n"
-"        classname=\"org.hibernate.tool.hbm2ddl.SchemaValidatorTask\"\n"
-"        classpathref=\"class.path\"/>\n"
-"    \n"
-"    <schemavalidator\n"
-"        properties=\"hibernate.properties\">\n"
-"        <fileset dir=\"src\">\n"
-"            <include name=\"**/*.hbm.xml\"/>\n"
-"        </fileset>\n"
-"    </schemavalidator>\n"
-"</target>]]>"
-msgstr ""
+#, fuzzy
+#~ msgid "<![CDATA[<property name=\"zip\" length=\"5\"/>]]>"
+#~ msgstr "&lt;property name=\"zip\" length=\"5\"/&gt;"
 
-#~ msgid "Ant Tasks:"
-#~ msgstr "Ant Tasks:"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"balance\" precision=\"12\" scale=\"2\"/>]]>"
+#~ msgstr "&lt;property name=\"balance\" precision=\"12\" scale=\"2\"/&gt;"
 
-#~ msgid "&lt;one-to-one&gt;"
-#~ msgstr "&lt;one-to-one&gt;"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"bar\" column=\"barId\" not-null=\"true\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"bar\" column=\"barId\" not-null=\"true\"/&gt;"
 
-#~ msgid "&lt;many-to-one&gt;"
-#~ msgstr "&lt;many-to-one&gt;"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<element column=\"serialNumber\" type=\"long\" not-null=\"true\" "
+#~ "unique=\"true\"/>]]>"
+#~ msgstr ""
+#~ "&lt;element column=\"serialNumber\" type=\"long\" not-null=\"true\" "
+#~ "unique=\"true\"/&gt;"
 
-#~ msgid "&lt;key&gt;"
-#~ msgstr "&lt;key&gt;"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"org\" column=\"orgId\" unique-key="
+#~ "\"OrgEmployeeId\"/>\n"
+#~ "<property name=\"employeeId\" unique-key=\"OrgEmployee\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"org\" column=\"orgId\" unique-key=\"OrgEmployeeId"
+#~ "\"/&gt;\n"
+#~ "&lt;property name=\"employeeId\" unique-key=\"OrgEmployee\"/&gt;"
 
-#~ msgid "&lt;many-to-many&gt;"
-#~ msgstr "&lt;many-to-many&gt;"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"lastName\" index=\"CustName\"/>\n"
+#~ "<property name=\"firstName\" index=\"CustName\"/>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"lastName\" index=\"CustName\"/&gt;\n"
+#~ "&lt;property name=\"firstName\" index=\"CustName\"/&gt;"
 
-#~ msgid "inverse=\"true\""
-#~ msgstr "inverse=\"true\""
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<many-to-one name=\"bar\" column=\"barId\" foreign-key=\"FKFooBar"
+#~ "\"/>]]>"
+#~ msgstr ""
+#~ "&lt;many-to-one name=\"bar\" column=\"barId\" foreign-key=\"FKFooBar\"/"
+#~ "&gt;"
 
-#~ msgid "SchemaExport"
-#~ msgstr "SchemaExport"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"name\" type=\"my.customtypes.Name\"/>\n"
+#~ "    <column name=\"last\" not-null=\"true\" index=\"bar_idx\" length=\"30"
+#~ "\"/>\n"
+#~ "    <column name=\"first\" not-null=\"true\" index=\"bar_idx\" length=\"20"
+#~ "\"/>\n"
+#~ "    <column name=\"initial\"/>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"name\" type=\"my.customtypes.Name\"/&gt;\n"
+#~ "    &lt;column name=\"last\" not-null=\"true\" index=\"bar_idx\" length="
+#~ "\"30\"/&gt;\n"
+#~ "    &lt;column name=\"first\" not-null=\"true\" index=\"bar_idx\" length="
+#~ "\"20\"/&gt;\n"
+#~ "    &lt;column name=\"initial\"/&gt;\n"
+#~ "&lt;/property&gt;"
 
-#~ msgid "&lt;column&gt;"
-#~ msgstr "&lt;column&gt;"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"credits\" type=\"integer\" insert=\"false\">\n"
+#~ "    <column name=\"credits\" default=\"10\"/>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"credits\" type=\"integer\" insert=\"false\"&gt;\n"
+#~ "    &lt;column name=\"credits\" default=\"10\"/&gt;\n"
+#~ "&lt;/property&gt;"
 
-#~ msgid "java -cp"
-#~ msgstr "java -cp"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<version name=\"version\" type=\"integer\" insert=\"false\">\n"
+#~ "    <column name=\"version\" default=\"0\"/>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;version name=\"version\" type=\"integer\" insert=\"false\"&gt;\n"
+#~ "    &lt;column name=\"version\" default=\"0\"/&gt;\n"
+#~ "&lt;/property&gt;"
 
-#~ msgid "hibernate_classpaths"
-#~ msgstr "hibernate_classpaths"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"balance\" type=\"float\">\n"
+#~ "    <column name=\"balance\" sql-type=\"decimal(13,3)\"/>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"balance\" type=\"float\"&gt;\n"
+#~ "    &lt;column name=\"balance\" sql-type=\"decimal(13,3)\"/&gt;\n"
+#~ "&lt;/property&gt;"
 
-#~ msgid "org.hibernate.tool.hbm2ddl.SchemaExport"
-#~ msgstr "org.hibernate.tool.hbm2ddl.SchemaExport"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"foo\" type=\"integer\">\n"
+#~ "    <column name=\"foo\" check=\"foo > 10\"/>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"foo\" type=\"integer\"&gt;\n"
+#~ "    &lt;column name=\"foo\" check=\"foo &gt; 10\"/&gt;\n"
+#~ "&lt;/property&gt;"
 
-#~ msgid "options mapping_files"
-#~ msgstr "options mapping_files"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Foo\" table=\"foos\" check=\"bar < 100.0\">\n"
+#~ "    ...\n"
+#~ "    <property name=\"bar\" type=\"float\"/>\n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "&lt;class name=\"Foo\" table=\"foos\" check=\"bar &lt; 100.0\"&gt;\n"
+#~ "    ...\n"
+#~ "    &lt;property name=\"bar\" type=\"float\"/&gt;\n"
+#~ "&lt;/class&gt;"
 
-#~ msgid "NamingStrategy"
-#~ msgstr "NamingStrategy"
+#~ msgid "length"
+#~ msgstr "length"
 
+#~ msgid "precision"
+#~ msgstr "precision"
+
+#~ msgid "scale"
+#~ msgstr "scale"
+
+#~ msgid "not-null"
+#~ msgstr "not-null"
+
+#~ msgid "true|false"
+#~ msgstr "true|false"
+
+#~ msgid "unique"
+#~ msgstr "unique"
+
+#~ msgid "index"
+#~ msgstr "index"
+
+#~ msgid "index_name"
+#~ msgstr "index_name"
+
+#~ msgid "unique-key"
+#~ msgstr "unique-key"
+
+#~ msgid "unique_key_name"
+#~ msgstr "unique_key_name"
+
+#~ msgid "foreign-key"
+#~ msgstr "foreign-key"
+
 #, fuzzy
-#~ msgid "select a <placeholder-1/>"
+#~ msgid "foreign_key_name"
+#~ msgstr "foreign-key"
+
+#~ msgid "sql-type"
+#~ msgstr "sql-type"
+
+#, fuzzy
+#~ msgid "SQL column type"
+#~ msgstr "<literal>SQL column type</literal>"
+
+#~ msgid "default"
+#~ msgstr "default"
+
+#~ msgid "check"
+#~ msgstr "check"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Customer\" table=\"CurCust\">\n"
+#~ "    <comment>Current customers only</comment>\n"
+#~ "    ...\n"
+#~ "</class>]]>"
 #~ msgstr ""
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "选择一个命名策略(<placeholder-1/>)\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "选择一个命名策略 (<placeholder-1/>)\n"
-#~ "#-#-#-#-#  - (PACKAGE VERSION)  #-#-#-#-#\n"
-#~ "选择一个命名策略 (<placeholder-1/>)"
+#~ "&lt;class name=\"Customer\" table=\"CurCust\"&gt;\n"
+#~ "    &lt;comment&gt;Current customers only&lt;/comment&gt;\n"
+#~ "    ...\n"
+#~ "&lt;/class&gt;"
 
-#~ msgid "org.hibernate.tool.hbm2ddl.SchemaUpdate"
-#~ msgstr "org.hibernate.tool.hbm2ddl.SchemaUpdate"
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<property name=\"balance\">\n"
+#~ "    <column name=\"bal\">\n"
+#~ "        <comment>Balance in USD</comment>\n"
+#~ "    </column>\n"
+#~ "</property>]]>"
+#~ msgstr ""
+#~ "&lt;property name=\"balance\"&gt;\n"
+#~ "    &lt;column name=\"bal\"&gt;\n"
+#~ "        &lt;comment&gt;Balance in USD&lt;/comment&gt;\n"
+#~ "    &lt;/column&gt;\n"
+#~ "&lt;/property&gt;"
 
-#~ msgid ".cfg.xml"
-#~ msgstr ".cfg.xml"
+#~ msgid "--quiet"
+#~ msgstr "--quiet"
 
-#~ msgid "org.hibernate.tool.hbm2ddl.SchemaValidator"
-#~ msgstr "org.hibernate.tool.hbm2ddl.SchemaValidator"
+#~ msgid "--drop"
+#~ msgstr "--drop"
+
+#~ msgid "--create"
+#~ msgstr "--create"
+
+#~ msgid "--text"
+#~ msgstr "--text"
+
+#, fuzzy
+#~ msgid "--output=my_schema.ddl"
+#~ msgstr "<literal>--output=my_schema.ddl</literal>"
+
+#, fuzzy
+#~ msgid "--config=hibernate.cfg.xml"
+#~ msgstr "<literal>--config=hibernate.cfg.xml</literal>"
+
+#~ msgid "--properties=hibernate.properties"
+#~ msgstr "--properties=hibernate.properties"
+
+#~ msgid "--format"
+#~ msgstr "--format"
+
+#~ msgid "--delimiter=;"
+#~ msgstr "--delimiter=;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Configuration cfg = ....;\n"
+#~ "new SchemaExport(cfg).create(false, true);]]>"
+#~ msgstr ""
+#~ "Configuration cfg = ....;\n"
+#~ "new SchemaExport(cfg).create(false, true);"
+
+#, fuzzy
+#~ msgid "hibernate.connection.driver_class"
+#~ msgstr "hibernate.connection.url"
+
+#~ msgid "hibernate.connection.url"
+#~ msgstr "hibernate.connection.url"
+
+#~ msgid "hibernate.connection.username"
+#~ msgstr "hibernate.connection.username"
+
+#~ msgid "hibernate.connection.password"
+#~ msgstr "hibernate.connection.password"
+
+#~ msgid "hibernate.dialect"
+#~ msgstr "hibernate.dialect"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<target name=\"schemaexport\">\n"
+#~ "    <taskdef name=\"schemaexport\"\n"
+#~ "        classname=\"org.hibernate.tool.hbm2ddl.SchemaExportTask\"\n"
+#~ "        classpathref=\"class.path\"/>\n"
+#~ "    \n"
+#~ "    <schemaexport\n"
+#~ "        properties=\"hibernate.properties\"\n"
+#~ "        quiet=\"no\"\n"
+#~ "        text=\"no\"\n"
+#~ "        drop=\"no\"\n"
+#~ "        delimiter=\";\"\n"
+#~ "        output=\"schema-export.sql\">\n"
+#~ "        <fileset dir=\"src\">\n"
+#~ "            <include name=\"**/*.hbm.xml\"/>\n"
+#~ "        </fileset>\n"
+#~ "    </schemaexport>\n"
+#~ "</target>]]>"
+#~ msgstr ""
+#~ "&lt;target name=\"schemaexport\"&gt;\n"
+#~ "    &lt;taskdef name=\"schemaexport\"\n"
+#~ "        classname=\"org.hibernate.tool.hbm2ddl.SchemaExportTask\"\n"
+#~ "        classpathref=\"class.path\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;schemaexport\n"
+#~ "        properties=\"hibernate.properties\"\n"
+#~ "        quiet=\"no\"\n"
+#~ "        text=\"no\"\n"
+#~ "        drop=\"no\"\n"
+#~ "        delimiter=\";\"\n"
+#~ "        output=\"schema-export.sql\"&gt;\n"
+#~ "        &lt;fileset dir=\"src\"&gt;\n"
+#~ "            &lt;include name=\"**/*.hbm.xml\"/&gt;\n"
+#~ "        &lt;/fileset&gt;\n"
+#~ "    &lt;/schemaexport&gt;\n"
+#~ "&lt;/target&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Configuration cfg = ....;\n"
+#~ "new SchemaUpdate(cfg).execute(false);]]>"
+#~ msgstr ""
+#~ "Configuration cfg = ....;\n"
+#~ "new SchemaUpdate(cfg).execute(false);"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<target name=\"schemaupdate\">\n"
+#~ "    <taskdef name=\"schemaupdate\"\n"
+#~ "        classname=\"org.hibernate.tool.hbm2ddl.SchemaUpdateTask\"\n"
+#~ "        classpathref=\"class.path\"/>\n"
+#~ "    \n"
+#~ "    <schemaupdate\n"
+#~ "        properties=\"hibernate.properties\"\n"
+#~ "        quiet=\"no\">\n"
+#~ "        <fileset dir=\"src\">\n"
+#~ "            <include name=\"**/*.hbm.xml\"/>\n"
+#~ "        </fileset>\n"
+#~ "    </schemaupdate>\n"
+#~ "</target>]]>"
+#~ msgstr ""
+#~ "&lt;target name=\"schemaupdate\"&gt;\n"
+#~ "    &lt;taskdef name=\"schemaupdate\"\n"
+#~ "        classname=\"org.hibernate.tool.hbm2ddl.SchemaUpdateTask\"\n"
+#~ "        classpathref=\"class.path\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;schemaupdate\n"
+#~ "        properties=\"hibernate.properties\"\n"
+#~ "        quiet=\"no\"&gt;\n"
+#~ "        &lt;fileset dir=\"src\"&gt;\n"
+#~ "            &lt;include name=\"**/*.hbm.xml\"/&gt;\n"
+#~ "        &lt;/fileset&gt;\n"
+#~ "    &lt;/schemaupdate&gt;\n"
+#~ "&lt;/target&gt;"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[Configuration cfg = ....;\n"
+#~ "new SchemaValidator(cfg).validate();]]>"
+#~ msgstr ""
+#~ "Configuration cfg = ....;\n"
+#~ "new SchemaValidator(cfg).validate();"
+
+#, fuzzy
+#~ msgid ""
+#~ "<![CDATA[<target name=\"schemavalidate\">\n"
+#~ "    <taskdef name=\"schemavalidator\"\n"
+#~ "        classname=\"org.hibernate.tool.hbm2ddl.SchemaValidatorTask\"\n"
+#~ "        classpathref=\"class.path\"/>\n"
+#~ "    \n"
+#~ "    <schemavalidator\n"
+#~ "        properties=\"hibernate.properties\">\n"
+#~ "        <fileset dir=\"src\">\n"
+#~ "            <include name=\"**/*.hbm.xml\"/>\n"
+#~ "        </fileset>\n"
+#~ "    </schemavalidator>\n"
+#~ "</target>]]>"
+#~ msgstr ""
+#~ "&lt;target name=\"schemavalidate\"&gt;\n"
+#~ "    &lt;taskdef name=\"schemavalidator\"\n"
+#~ "        classname=\"org.hibernate.tool.hbm2ddl.SchemaValidatorTask\"\n"
+#~ "        classpathref=\"class.path\"/&gt;\n"
+#~ "    \n"
+#~ "    &lt;schemavalidator\n"
+#~ "        properties=\"hibernate.properties\"&gt;\n"
+#~ "        &lt;fileset dir=\"src\"&gt;\n"
+#~ "            &lt;include name=\"**/*.hbm.xml\"/&gt;\n"
+#~ "        &lt;/fileset&gt;\n"
+#~ "    &lt;/schemaupdate&gt;\n"
+#~ "&lt;/target&gt;"
+
+#~ msgid "<!-- <emphasis>Ant Tasks:</emphasis> -->"
+#~ msgstr "<!-- <emphasis>Ant Tasks:</emphasis> -->"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/transactions.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/transactions.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/transactions.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,24 +1,26 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-01-11 10:41+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: transactions.xml:29
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Transactions and Concurrency"
-msgstr "事务和并发"
+msgstr "事务和并发 "
 
 #. Tag: para
-#: transactions.xml:31
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The most important point about Hibernate and concurrency control is that it "
 "is easy to understand. Hibernate directly uses JDBC connections and JTA "
@@ -26,13 +28,12 @@
 "that you spend some time with the JDBC, ANSI, and transaction isolation "
 "specification of your database management system."
 msgstr ""
-"Hibernate的事务和并发控制很容易掌握。Hibernate直接使用JDBC连接和JTA资源,不添"
-"加任何附加锁定 行为。我们强烈推荐你花点时间了解JDBC编程,ANSI SQL查询语言和你"
-"使用 的数据库系统的事务隔离规范。"
+"Hibernate 的事务和并发控制很容易掌握。Hibernate 直接使用 JDBC 连接和 JTA 资"
+"源,不添加任何附加锁定行为。我们强烈推荐你花点时间了解 JDBC 编程,ANSI SQL 查"
+"询语言和你使用的数据库系统的事务隔离规范。 "
 
 #. Tag: para
-#: transactions.xml:38
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate does not lock objects in memory. Your application can expect the "
 "behavior as defined by the isolation level of your database transactions. "
@@ -40,59 +41,54 @@
 "cache, Hibernate provides repeatable reads for lookup by identifier and "
 "entity queries and not reporting queries that return scalar values."
 msgstr ""
-"Hibernate不锁定内存中的对象。你的应用程序会按照你的数据库事务的隔离级别规定的"
-"那样运作。幸亏有了<literal>Session</literal>,使得Hibernate通过标识符查找,和"
-"实体查询(不是返回标量值的报表查询)提供了可重复的读取(Repeatable reads)功"
-"能,<literal>Session</literal>同时也是事务范围内的缓存(cache)。"
+"Hibernate 不锁定内存中的对象。你的应用程序会按照你的数据库事务的隔离级别规定"
+"的那样运作。幸亏有了 <literal>Session</literal>,使得 Hibernate 通过标识符查"
+"找,和实体查询(不是返回标量值的报表查询)提供了可重复的读取(Repeatable "
+"reads)功能,<literal>Session</literal> 同时也是事务范围内的缓存(cache)。 "
 
 #. Tag: para
-#: transactions.xml:46
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In addition to versioning for automatic optimistic concurrency control, "
 "Hibernate also offers, using the <literal>SELECT FOR UPDATE</literal> "
 "syntax, a (minor) API for pessimistic locking of rows. Optimistic "
 "concurrency control and this API are discussed later in this chapter."
 msgstr ""
-"除了对自动乐观并发控制提供版本管理,针对行级悲观锁定,Hibernate也提供了辅助的"
-"(较小的)API,它使用了 <literal>SELECT FOR UPDATE</literal>的SQL语法。本章后"
-"面会讨论乐观并发控制和这个API。"
+"除了对自动乐观并发控制提供版本管理,针对行级悲观锁定,Hibernate 也提供了辅助"
+"的(较小的)API,它使用了 <literal>SELECT FOR UPDATE</literal> 的 SQL 语法。"
+"本章后面会讨论乐观并发控制和这个API。 "
 
 #. Tag: para
-#: transactions.xml:53
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The discussion of concurrency control in Hibernate begins with the "
 "granularity of <literal>Configuration</literal>, <literal>SessionFactory</"
 "literal>, and <literal>Session</literal>, as well as database transactions "
 "and long conversations."
 msgstr ""
-"我们从<literal>Configuration</literal>层、<literal>SessionFactory</literal>"
-"层, 和 <literal>Session</literal>层开始讨论Hibernate的并行控制、数据库事务和"
-"应用 程序的长事务。"
+"我们从 <literal>Configuration</literal>层、<literal>SessionFactory</literal> "
+"层,和 <literal>Session</literal> 层开始讨论 Hibernate 的并行控制、数据库事务"
+"和应用程序的长事务。 "
 
 #. Tag: title
-#: transactions.xml:60
 #, no-c-format
 msgid "Session and transaction scopes"
-msgstr "Session和事务范围(transaction scope)"
+msgstr "Session 和事务范围(transaction scope)"
 
 #. Tag: para
-#: transactions.xml:62
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>SessionFactory</literal> is an expensive-to-create, threadsafe "
 "object, intended to be shared by all application threads. It is created "
 "once, usually on application startup, from a <literal>Configuration</"
 "literal> instance."
 msgstr ""
-"<literal>SessionFactory</literal>对象的创建代价很昂贵,它是线程安全的对象,它"
-"为所有的应用程序线程所共享。它只创建一次,通常是在应用程序启动的时候,由一个"
-"<literal>Configuraion</literal>的实例来创建。"
+"<literal>SessionFactory</literal> 对象的创建代价很昂贵,它是线程安全的对象,"
+"它为所有的应用程序线程所共享。它只创建一次,通常是在应用程序启动的时候,由一"
+"个 <literal>Configuraion</literal> 的实例来创建。 "
 
 #. Tag: para
-#: transactions.xml:68
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>Session</literal> is an inexpensive, non-threadsafe object that "
 "should be used once and then discarded for: a single request, a conversation "
@@ -100,15 +96,14 @@
 "JDBC <literal>Connection</literal>, or a <literal>Datasource</literal>, "
 "unless it is needed. It will not consume any resources until used."
 msgstr ""
-"<literal>Session</literal>对象的创建代价比较小,是非线程安全的,对于单个请"
+"<literal>Session</literal> 对象的创建代价比较小,是非线程安全的,对于单个请"
 "求,单个会话、单个的 工作单元而言,它只被使用一次,然后就丢弃。只有在需要的时"
-"候,一个<literal>Session</literal>对象 才会获取一个JDBC的"
-"<literal>Connection</literal>(或一个<literal>Datasource</literal>) 对象,因"
-"此假若不使用的时候它不消费任何资源。"
+"候,一个 <literal>Session</literal> 对象 才会获取一个 JDBC 的 "
+"<literal>Connection</literal>(或一个<literal>Datasource</literal>)对象,因"
+"此假若不使用的时候它不消费任何资源。 "
 
 #. Tag: para
-#: transactions.xml:76
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In order to reduce lock contention in the database, a database transaction "
 "has to be as short as possible. Long database transactions will prevent your "
@@ -116,13 +111,12 @@
 "that you hold a database transaction open during user think time until the "
 "unit of work is complete."
 msgstr ""
-"此外我们还要考虑数据库事务。数据库事务应该尽可能的短,降低数据库中的锁争用。 "
+"此外我们还要考虑数据库事务。数据库事务应该尽可能的短,降低数据库中的锁争用。"
 "数据库长事务会阻止你的应用程序扩展到高的并发负载。因此,假若在用户思考期间让"
-"数据库事务开着,直到整个工作单元完成才关闭这个事务,这绝不是一个好的设计。"
+"数据库事务开着,直到整个工作单元完成才关闭这个事务,这绝不是一个好的设计。 "
 
 #. Tag: para
-#: transactions.xml:84
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What is the scope of a unit of work? Can a single Hibernate "
 "<literal>Session</literal> span several database transactions, or is this a "
@@ -130,20 +124,19 @@
 "<literal>Session</literal> and how do you demarcate the database transaction "
 "boundaries? These questions are addressed in the following sections."
 msgstr ""
-"一个操作单元(Unit of work)的范围是多大?单个的Hibernate <literal>Session</"
-"literal>能跨越多个 数据库事务吗?还是一个<literal>Session</literal>的作用范围"
-"对应一个数据库事务的范围?应该何时打开 <literal>Session</literal>,何时关闭"
-"<literal>Session</literal>?,你又如何划分数据库事务的边界呢?"
+"一个操作单元(Unit of work)的范围是多大?单个的 Hibernate <literal>Session</"
+"literal> 能跨越多个数据库事务吗?还是一个 <literal>Session</literal> 的作用范"
+"围对应一个数据库事务的范围?应该何时打开 <literal>Session</literal>,何时关"
+"闭 <literal>Session</literal>,你又如何划分数据库事务的边界呢?我们将在后续章"
+"节解决这些问题。"
 
 #. Tag: title
-#: transactions.xml:92
 #, no-c-format
 msgid "Unit of work"
-msgstr "操作单元(Unit of work)"
+msgstr "操作单元(Unit of work)"
 
 #. Tag: para
-#: transactions.xml:94
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "First, let's define a unit of work. A unit of work is a design pattern "
 "described by Martin Fowler as <quote> [maintaining] a list of objects "
@@ -152,14 +145,21 @@
 "citation> In other words, its a series of operations we wish to carry out "
 "against the database together. Basically, it is a transaction, though "
 "fulfilling a unit of work will often span multiple physical database "
-"transactions (see <xref linkend=\"transactions-basics-apptx\"/>). So really "
+"transactions (see <xref linkend=\"transactions-basics-apptx\" />). So really "
 "we are talking about a more abstract notion of a transaction. The term "
 "\"business transaction\" is also sometimes used in lieu of unit of work."
 msgstr ""
+"首先,让我们定义一个工作单元(unit of work)。工作单元是一个设计模式,Martin "
+"Fowler 把它描述为 <quote> [maintaining] a list of objects affected by a "
+"business transaction and coordinates the writing out of changes and the "
+"resolution of concurrency problems. </quote><citation>PoEAA</citation> 换句话"
+"说,它是我们希望对数据库执行的一系列操作。基本上,它是一个事务,虽然完成一个"
+"工作单元经常将跨越多个物理数据库事务(请参考 <xref linkend=\"transactions-"
+"basics-apptx\"/>)。所以,实际上我们在讨论一个更抽象的事务概念。术语 "
+"\"business transaction\" 有时也和工作单元一起使用。 "
 
 #. Tag: para
-#: transactions.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not use the <emphasis>session-per-operation</emphasis> antipattern: do "
 "not open and close a <literal>Session</literal> for every simple database "
@@ -175,19 +175,19 @@
 "clearly defined unit of work. The latter is also more maintainable and "
 "extensible."
 msgstr ""
-"首先,别用<emphasis>session-per-operation</emphasis>这种反模式了,也就是说,"
-"在单个线程中, 不要因为一次简单的数据库调用,就打开和关闭一次"
+"首先,别用 <emphasis>session-per-operation</emphasis> 这种反模式了,也就是"
+"说,在单个线程中, 不要因为一次简单的数据库调用,就打开和关闭一次 "
 "<literal>Session</literal>!数据库事务也是如此。 应用程序中的数据库调用是按照"
-"计划好的次序,分组为原子的操作单元。(注意,这也意味着,应用程 序中,在单个的"
-"SQL语句发送之后,自动事务提交(auto-commit)模式失效了。这种模式专门为SQL控制台"
-"操作设计的。 Hibernate禁止立即自动事务提交模式,或者期望应用服务器禁止立即自"
-"动事务提交模式。)数据库事务绝不是可有可无的,任何与数据库之间的通讯都必须在"
-"某个事务中进行,不管你是在读还是在写数据。对读数据而言,应该避免auto-commit行"
-"为,因为很多小的事务比一个清晰定义的工作单元性能差。后者也更容易维护和扩展。"
+"计划好的次序,分组为原子的操作单元。(注意,这也意味着,应用程 序中,在单个"
+"的 SQL 语句发送之后,自动事务提交(auto-commit)模式失效了。这种模式专门为SQL"
+"控制台操作设计的。 Hibernate 禁止立即自动事务提交模式,或者期望应用服务器禁止"
+"立即自动事务提交模式。)数据库事务绝不是可有可无的,任何与数据库之间的通讯都"
+"必须在某个事务中进行,不管你是在读还是在写数据。对读数据而言,应该避免 auto-"
+"commit 行为,因为很多小的事务比一个清晰定义的工作单元性能差。后者也更容易维护"
+"和扩展。 "
 
 #. Tag: para
-#: transactions.xml:126
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The most common pattern in a multi-user client/server application is "
 "<emphasis>session-per-request</emphasis>. In this model, a request from the "
@@ -200,18 +200,17 @@
 "literal>. The relationship between the two is one-to-one and this model is a "
 "perfect fit for many applications."
 msgstr ""
-"在多用户的client/server应用程序中,最常用的模式是 <emphasis>每个请求一个会话"
-"(session-per-request)</emphasis>。 在这种模式下,来自客户端的请求被发送到服务"
-"器端(即Hibernate持久化层运行的地方),一 个新的Hibernate <literal>Session</"
-"literal>被打开,并且执行这个操作单元中所有的数据库操作。 一旦操作完成(同时对"
-"客户端的响应也准备就绪),session被同步,然后关闭。你也可以使用单 个数据库事"
-"务来处理客户端请求,在你打开<literal>Session</literal>之后启动事务,在你关闭 "
-"<literal>Session</literal>之前提交事务。会话和请求之间的关系是一对一的关系,"
-"这种模式对 于大多数应用程序来说是很棒的。"
+"在多用户的 client/server 应用程序中,最常用的模式是 <emphasis>每个请求一个会"
+"话(session-per-request)</emphasis>。 在这种模式下,来自客户端的请求被发送到"
+"服务器端(即 Hibernate 持久化层运行的地方),一个新的 Hibernate "
+"<literal>Session</literal> 被打开,并且执行这个操作单元中所有的数据库操作。一"
+"旦操作完成(同时对客户端的响应也准备就绪),session 被同步,然后关闭。你也可"
+"以使用单 个数据库事务来处理客户端请求,在你打开 <literal>Session</literal> 之"
+"后启动事务,在你关闭 <literal>Session</literal> 之前提交事务。会话和请求之间"
+"的关系是一对一的关系,这种模式对 于大多数应用程序来说是很棒的。 "
 
 #. Tag: para
-#: transactions.xml:138
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The challenge lies in the implementation. Hibernate provides built-in "
 "management of the \"current session\" to simplify this pattern. Start a "
@@ -225,33 +224,32 @@
 "use the Hibernate <literal>Transaction</literal> API shown later in this "
 "chapter."
 msgstr ""
-"实现才是真正的挑战。Hibernate内置了对\"当前session(current session)\" 的管"
-"理,用于简化此模式。你要做的一切就是在服务器端要处理请求的时候,开启事务,在"
-"响应发送给客户之前结束事务。你可以用任何方式来完成这一操作,通常的方案有"
-"<literal>ServletFilter</literal>,在service方法中进行pointcut的AOP拦截器,或"
-"者proxy/interception容器。EJB容器是实现横切诸如EJB session bean上的事务分界,"
-"用CMT对事务进行声明等方面的标准手段。假若你决定使用编程式的事务分界,请参考本"
-"章后面讲到的Hibernate <literal>Transaction</literal> API,这对易用性和代码可"
-"移植性都有好处。"
+"实现才是真正的挑战。Hibernate 内置了对\"当前 session(current session)\" 的"
+"管理,用于简化此模式。你要做的一切就是在服务器端要处理请求的时候,开启事务,"
+"在响应发送给客户之前结束事务。你可以用任何方式来完成这一操作,通常的方案有 "
+"<literal>ServletFilter</literal>,在 service 方法中进行 pointcut 的 AOP 拦截"
+"器,或者 proxy/interception 容器。EJB 容器是实现横切诸如 EJB session bean 上"
+"的事务分界,用 CMT 对事务进行声明等方面的标准手段。假若你决定使用编程式的事务"
+"分界,请参考本章后面讲到的 Hibernate <literal>Transaction</literal> API,这对"
+"易用性和代码可移植性都有好处。 "
 
 #. Tag: para
-#: transactions.xml:150
 #, fuzzy, no-c-format
 msgid ""
 "Your application code can access a \"current session\" to process the "
 "request by calling <literal>sessionFactory.getCurrentSession()</literal>. "
 "You will always get a <literal>Session</literal> scoped to the current "
 "database transaction. This has to be configured for either resource-local or "
-"JTA environments, see <xref linkend=\"architecture-current-session\"/>."
+"JTA environments, see <xref linkend=\"architecture-current-session\" />."
 msgstr ""
 "在任何时间,任何地方,你的应用代码可以通过简单的调用<literal>sessionFactory."
-"getCurrentSession()</literal>来访问\"当前session\",用于处理请求。你总是会得"
-"到当前数据库事务范围内的<literal>Session</literal>。在使用本地资源或JTA环境"
-"时,必须配置它,请参见<xref linkend=\"architecture-current-session\"/>。"
+"getCurrentSession()</literal> 来访问\"当前 session\",用于处理请求。你总是会"
+"得到当前数据库事务范围内的 <literal>Session</literal>。在使用本地资源或 JTA "
+"环境时,必须配置它,请参见 <xref linkend=\"architecture-current-session\"/"
+">。 "
 
 #. Tag: para
-#: transactions.xml:158
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can extend the scope of a <literal>Session</literal> and database "
 "transaction until the \"view has been rendered\". This is especially useful "
@@ -263,22 +261,21 @@
 "of any view can start. See the Hibernate website and forum for tips and "
 "examples relating to this <emphasis>Open Session in View</emphasis> pattern."
 msgstr ""
-"有时,将<literal>Session</literal>和数据库事务的边界延伸到\"展示层被渲染后"
-"\"会带来便利。有些serlvet应用程序在对请求进行处理后,有个单独的渲染期,这种延"
-"伸对这种程序特别有用。假若你实现你自己的拦截器,把事务边界延伸到展示层渲染结"
-"束后非常容易。然而,假若你依赖有容器管理事务的EJB,这就不太容易了,因为事务会"
-"在EJB方法返回后结束,而那是在任何展示层渲染开始之前。请访问Hibernate网站和论"
-"坛,你可以找到<emphasis>Open Session in View</emphasis>这一模式的提示和示例。"
+"有时,将 <literal>Session</literal> 和数据库事务的边界延伸到\"展示层被渲染后"
+"\"会带来便利。有些 serlvet 应用程序在对请求进行处理后,有个单独的渲染期,这种"
+"延伸对这种程序特别有用。假若你实现你自己的拦截器,把事务边界延伸到展示层渲染"
+"结束后非常容易。然而,假若你依赖有容器管理事务的 EJB,这就不太容易了,因为事"
+"务会在 EJB 方法返回后结束,而那是在任何展示层渲染开始之前。请访问  Hibernate "
+"网站和论坛,你可以找到 <emphasis>Open Session in View</emphasis> 这一模式的提"
+"示和示例。 "
 
 #. Tag: title
-#: transactions.xml:173
 #, no-c-format
 msgid "Long conversations"
 msgstr "长对话"
 
 #. Tag: para
-#: transactions.xml:175
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The session-per-request pattern is not the only way of designing units of "
 "work. Many business processes require a whole series of interactions with "
@@ -286,48 +283,44 @@
 "applications, it is not acceptable for a database transaction to span a user "
 "interaction. Consider the following example:"
 msgstr ""
-"session-per-request模式不仅仅是一个可以用来设计操作单元的有用概念。很多业务处"
-"理都需 要一系列完整的与用户之间的交互,而这些用户是指对数据库有交叉访问的用"
-"户。在基于web的应用和企业 应用中,跨用户交互的数据库事务是无法接受的。考虑下"
-"面的例子:"
+"session-per-request 模式不仅仅是一个可以用来设计操作单元的有用概念。很多业务"
+"处理都需 要一系列完整的与用户之间的交互,而这些用户是指对数据库有交叉访问的用"
+"户。在基于 web 的应用和企业应用中,跨用户交互的数据库事务是无法接受的。考虑下"
+"面的例子: "
 
 #. Tag: para
-#: transactions.xml:185
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The first screen of a dialog opens. The data seen by the user has been "
 "loaded in a particular <literal>Session</literal> and database transaction. "
 "The user is free to modify the objects."
 msgstr ""
 "在界面的第一屏,打开对话框,用户所看到的数据是被一个特定的 <literal>Session</"
-"literal> 和数据 库事务载入(load)的。用户可以随意修改对话框中的数据对象。"
+"literal> 和数据 库事务载入(load)的。用户可以随意修改对话框中的数据对象。 "
 
 #. Tag: para
-#: transactions.xml:192
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The user clicks \"Save\" after 5 minutes and expects their modifications to "
 "be made persistent. The user also expects that they were the only person "
 "editing this information and that no conflicting modification has occurred."
 msgstr ""
-"5分钟后,用户点击“保存”,期望所做出的修改被持久化;同时他也期望自己是唯一修改"
-"这个信息的人,不会出现 修改冲突。"
+"5 分钟后,用户点击“保存”,期望所做出的修改被持久化;同时他也期望自己是唯一修"
+"改这个信息的人,不会出现修改冲突。 "
 
 #. Tag: para
-#: transactions.xml:200
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "From the point of view of the user, we call this unit of work a long-running "
 "<emphasis>conversation</emphasis> or <emphasis>application transaction</"
 "emphasis>. There are many ways to implement this in your application."
 msgstr ""
 "从用户的角度来看,我们把这个操作单元称为长时间运行的<emphasis>对话</emphasis>"
-"(conversation),或者(or <emphasis>应用事务</emphasis>,application "
-"transaction)。 在你的应用程序中,可以有很多种方法来实现它。"
+"(conversation),或者<emphasis>应用事务</emphasis>(application "
+"transaction)。在你的应用程序中,可以有很多种方法来实现它。"
 
 #. Tag: para
-#: transactions.xml:206
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A first naive implementation might keep the <literal>Session</literal> and "
 "database transaction open during user think time, with locks held in the "
@@ -335,14 +328,13 @@
 "atomicity. This is an anti-pattern, since lock contention would not allow "
 "the application to scale with the number of concurrent users."
 msgstr ""
-"头一个幼稚的做法是,在用户思考的过程中,保持<literal>Session</literal>和数据"
-"库事务是打开的, 保持数据库锁定,以阻止并发修改,从而保证数据库事务隔离级别和"
-"原子操作。这种方式当然是一个反模式, 因为锁争用会导致应用程序无法扩展并发用户"
-"的数目。"
+"头一个幼稚的做法是,在用户思考的过程中,保持 <literal>Session</literal> 和数"
+"据库事务是打开的,保持数据库锁定,以阻止并发修改,从而保证数据库事务隔离级别"
+"和原子操作。这种方式当然是一个反模式,因为锁争用会导致应用程序无法扩展并发用"
+"户的数目。 "
 
 #. Tag: para
-#: transactions.xml:214
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You have to use several database transactions to implement the conversation. "
 "In this case, maintaining isolation of business processes becomes the "
@@ -355,27 +347,25 @@
 msgstr ""
 "很明显,我们必须使用多个数据库事务来实现这个对话。在这个例子中,维护业务处理"
 "的 事务隔离变成了应用程序层的部分责任。一个对话通常跨越多个数据库事务。如果仅"
-"仅只有一 个数据库事务(最后的那个事务)保存更新过的数据,而所有其他事务只是单"
-"纯的读取数据(例如在一 个跨越多个请求/响应周期的向导风格的对话框中),那么应"
-"用程序事务将保证其原子性。这种方式比听 起来还要容易实现,特别是当你使用了"
-"Hibernate的下述特性的时候:"
+"仅只有一个数据库事务(最后的那个事务)保存更新过的数据,而所有其他事务只是单"
+"纯的读取数据(例如在一个跨越多个请求/响应周期的向导风格的对话框中),那么应用"
+"程序事务将保证其原子性。这种方式比听起来还要容易实现,特别是当你使用了 "
+"Hibernate 的下述特性的时候: "
 
 #. Tag: para
-#: transactions.xml:227
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Automatic Versioning</emphasis>: Hibernate can perform automatic "
 "optimistic concurrency control for you. It can automatically detect if a "
 "concurrent modification occurred during user think time. Check for this at "
 "the end of the conversation."
 msgstr ""
-"<emphasis>自动版本化</emphasis> - Hibernate能够自动进行乐观并发控制 ,如果在"
-"用户思考 的过程中发生并发修改,Hibernate能够自动检测到。一般我们只在对话结束"
-"时才检查。"
+"<emphasis>自动版本化</emphasis>:Hibernate 能够自动进行乐观并发控制,如果在用"
+"户思考的过程中发生并发修改,Hibernate 能够自动检测到。一般我们只在对话结束时"
+"才检查。"
 
 #. Tag: para
-#: transactions.xml:235
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Detached Objects</emphasis>: if you decide to use the "
 "<emphasis>session-per-request</emphasis> pattern, all loaded instances will "
@@ -384,15 +374,15 @@
 "<emphasis>session-per-request-with-detached-objects</emphasis>. Automatic "
 "versioning is used to isolate concurrent modifications."
 msgstr ""
-"<emphasis>脱管对象</emphasis>(Detached Objects)- 如果你决定采用前面已经讨论"
-"过的 <emphasis>session-per-request</emphasis>模式,所有载入的实例在用户思考的"
-"过程 中都处于与Session脱离的状态。Hibernate允许你把与Session脱离的对象重新关"
-"联到Session 上,并且对修改进行持久化,这种模式被称为 <emphasis>session-per-"
-"request-with-detached-objects</emphasis>。自动版本化被用来隔离并发修改。"
+"<emphasis>脱管对象</emphasis>(Detached Objects):如果你决定采用前面已经讨论"
+"过的  <emphasis>session-per-request</emphasis> 模式,所有载入的实例在用户思考"
+"的过程中都处于与 Session 脱离的状态。Hibernate 允许你把与 Session 脱离的对象"
+"重新关联到 Session 上,并且对修改进行持久化,这种模式被称为 "
+"<emphasis>session-per-request-with-detached-objects</emphasis>。自动版本化被"
+"用来隔离并发修改。"
 
 #. Tag: para
-#: transactions.xml:245
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<emphasis>Extended (or Long) Session</emphasis>: the Hibernate "
 "<literal>Session</literal> can be disconnected from the underlying JDBC "
@@ -403,72 +393,64 @@
 "<literal>Session</literal> will not be allowed to be flushed automatically, "
 "but explicitly."
 msgstr ""
-"<emphasis>Extended (or Long) Session</emphasis> - Hibernate çš„"
-"<literal>Session</literal> 可以在数据库事务提交之后和底层的JDBC连接断开,当一"
-"个新的客户端请求到来的时候,它又重新连接上底层的 JDBC连接。这种模式被称之为"
-"<emphasis>session-per-conversation</emphasis>,这种情况可 能会造成不必要的"
-"Session和JDBC连接的重新关联。自动版本化被用来隔离并发修改, <literal>Session</"
-"literal>通常不允许自动flush,而是明确flush。"
+"<emphasis>Extended (or Long) Session</emphasis>:Hibernate 的 "
+"<literal>Session</literal> 可以在数据库事务提交之后和底层的 JDBC 连接断开,当"
+"一个新的客户端请求到来的时候,它又重新连接上底层的 JDBC 连接。这种模式被称之"
+"为<emphasis>session-per-conversation</emphasis>,这种情况可 能会造成不必要的 "
+"Session 和 JDBC 连接的重新关联。自动版本化被用来隔离并发修改,"
+"<literal>Session</literal> 通常不允许自动 flush,而是显性地 flush。 "
 
 #. Tag: para
-#: transactions.xml:258
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Both <emphasis>session-per-request-with-detached-objects</emphasis> and "
 "<emphasis>session-per-conversation</emphasis> have advantages and "
 "disadvantages. These disadvantages are discussed later in this chapter in "
 "the context of optimistic concurrency control."
 msgstr ""
-"<emphasis>session-per-request-with-detached-objects</emphasis> 和 "
+"<emphasis>session-per-request-with-detached-objects</emphasis> 和  "
 "<emphasis>session-per-conversation</emphasis> 各有优缺点,我们在本章后面乐观"
-"并发 控制那部分再进行讨论。"
+"并发控制那部分再进行讨论。 "
 
 #. Tag: title
-#: transactions.xml:267
 #, no-c-format
 msgid "Considering object identity"
-msgstr "关注对象标识(Considering object identity)"
+msgstr "关注对象标识(Considering object identity)"
 
 #. Tag: para
-#: transactions.xml:269
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An application can concurrently access the same persistent state in two "
 "different <literal>Session</literal>s. However, an instance of a persistent "
 "class is never shared between two <literal>Session</literal> instances. It "
 "is for this reason that there are two different notions of identity:"
 msgstr ""
-"应用程序可能在两个不同的<literal>Session</literal>中并发访问同一持久化状态,"
-"但是, 一个持久化类的实例无法在两个 <literal>Session</literal>中共享。因此有"
-"两种不同的标识语义:"
+"应用程序可能在两个不同的 <literal>Session</literal> 中并发访问同一持久化状"
+"态,但是,一个持久化类的实例无法在两个 <literal>Session</literal> 中共享。因"
+"此有两种不同的标识语义: "
 
 #. Tag: term
-#: transactions.xml:278
 #, no-c-format
 msgid "Database Identity"
 msgstr "数据库标识"
 
-#. Tag: literal
-#: transactions.xml:281
-#, no-c-format
-msgid "foo.getId().equals( bar.getId() )"
-msgstr "foo.getId().equals( bar.getId() )"
+#. Tag: para
+#, fuzzy, no-c-format
+msgid "<literal>foo.getId().equals( bar.getId() )</literal>"
+msgstr "<literal>foo.getId().equals( bar.getId() )</literal>"
 
 #. Tag: term
-#: transactions.xml:286
 #, no-c-format
 msgid "JVM Identity"
 msgstr "JVM 标识"
 
-#. Tag: literal
-#: transactions.xml:289
+#. Tag: para
 #, no-c-format
-msgid "foo==bar"
-msgstr "foo==bar"
+msgid "<literal>foo==bar</literal>"
+msgstr "<literal>foo==bar</literal>"
 
 #. Tag: para
-#: transactions.xml:295
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For objects attached to a <emphasis>particular</emphasis> <literal>Session</"
 "literal> (i.e., in the scope of a <literal>Session</literal>), the two "
@@ -479,16 +461,15 @@
 "resolved using an optimistic approach and automatic versioning at flush/"
 "commit time."
 msgstr ""
-"对于那些关联到 <emphasis>特定</emphasis><literal>Session</literal> (也就是在"
-"单个<literal>Session</literal>的范围内)上的对象来说,这 两种标识的语义是等价"
-"的,与数据库标识对应的JVM标识是由Hibernate来保 证的。不过,当应用程序在两个不"
-"同的session中并发访问具有同一持久化标 识的业务对象实例的时候,这个业务对象的"
-"两个实例事实上是不相同的(从 JVM识别来看)。这种冲突可以通过在同步和提交的时"
-"候使用自动版本化和乐 观锁定方法来解决。"
+"对于那些关联到 <emphasis>特定</emphasis> <literal>Session</literal>(也就是在"
+"单个 <literal>Session</literal> 的范围内)上的对象来说,这两种标识的语义是等"
+"价的,与数据库标识对应的 JVM 标识是由 Hibernate 来保证的。不过,当应用程序在"
+"两个不同的 session 中并发访问具有同一持久化标识的业务对象实例的时候,这个业务"
+"对象的两个实例事实上是不相同的(从 JVM 识别来看)。这种冲突可以通过在同步和提"
+"交的时候使用自动版本化和乐观锁定方法来解决。 "
 
 #. Tag: para
-#: transactions.xml:304
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This approach leaves Hibernate and the database to worry about concurrency. "
 "It also provides the best scalability, since guaranteeing identity in single-"
@@ -498,15 +479,14 @@
 "<literal>Session</literal>. Within a <literal>Session</literal> the "
 "application can safely use <literal>==</literal> to compare objects."
 msgstr ""
-"这种方式把关于并发的头疼问题留给了Hibernate和数据库;由于在单个线程内,操作单"
-"元中的对象识别不 需要代价昂贵的锁定或其他意义上的同步,因此它同时可以提供最好"
-"的可伸缩性。只要在单个线程只持有一个 <literal>Session</literal>,应用程序就不"
-"需要同步任何业务对象。在<literal>Session</literal> 的范围内,应用程序可以放心"
-"的使用<literal>==</literal>进行对象比较。"
+"这种方式把关于并发的头疼问题留给了 Hibernate 和数据库;由于在单个线程内,操作"
+"单元中的对象识别不 需要代价昂贵的锁定或其他意义上的同步,因此它同时可以提供最"
+"好的可伸缩性。只要在单个线程只持有一个 <literal>Session</literal>,应用程序就"
+"不需要同步任何业务对象。在 <literal>Session</literal> 的范围内,应用程序可以"
+"放心的使用 <literal>==</literal> 进行对象比较。 "
 
 #. Tag: para
-#: transactions.xml:313
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, an application that uses <literal>==</literal> outside of a "
 "<literal>Session</literal> might produce unexpected results. This might "
@@ -529,30 +509,29 @@
 "that this is not a Hibernate issue, but simply how Java object identity and "
 "equality has to be implemented."
 msgstr ""
-"不过,应用程序在<literal>Session</literal>的外面使用<literal>==</literal>进行"
-"对象比较可能会 导致无法预期的结果。在一些无法预料的场合,例如,如果你把两个脱"
-"管对象实例放进同一个 <literal>Set</literal>的时候,就可能发生。这两个对象实例"
-"可能有同一个数据库标识(也就是说, 他们代表了表的同一行数据),从JVM标识的定"
-"义上来说,对脱管的对象而言,Hibernate无法保证他们 的的JVM标识一致。开发人员必"
-"须覆盖持久化类的<literal>equals()</literal>方法和 <literal>hashCode()</"
-"literal> 方法,从而实现自定义的对象相等语义。警告:不要使用数据库标识 来实现"
-"对象相等,应该使用业务键值,由唯一的,通常不变的属性组成。当一个瞬时对象被持"
-"久化的时 候,它的数据库标识会发生改变。如果一个瞬时对象(通常也包括脱管对象实"
-"例)被放入一 个<literal>Set</literal>,改变它的hashcode会导致与这个"
-"<literal>Set</literal>的关系中断。虽 然业务键值的属性不象数据库主键那样稳定不"
-"变,但是你只需要保证在同一个<literal>Set</literal> 中的对象属性的稳定性就足够"
-"了。请到Hibernate网站去寻求这个问题更多的详细的讨论。请注意,这不是一 个有关"
-"Hibernate的问题,而仅仅是一个关于Java对象标识和判等行为如何实现的问题。"
+"不过,应用程序在 <literal>Session</literal> 的外面使用 <literal>==</literal> "
+"进行对象比较可能会 导致无法预期的结果。在一些无法预料的场合,例如,如果你把两"
+"个脱管对象实例放进同一个  <literal>Set</literal> 的时候,就可能发生。这两个对"
+"象实例可能有同一个数据库标识(也就是说, 他们代表了表的同一行数据),从 JVM "
+"标识的定义上来说,对脱管的对象而言,Hibernate 无法保证他们 的的 JVM 标识一"
+"致。开发人员必须覆盖持久化类的 <literal>equals()</literal> 方法和  "
+"<literal>hashCode()</literal> 方法,从而实现自定义的对象相等语义。警告:不要"
+"使用数据库标识来实现对象相等,应该使用业务键值,由唯一的,通常不变的属性组"
+"成。当一个瞬时对象被持久化的时候,它的数据库标识会发生改变。如果一个瞬时对象"
+"(通常也包括脱管对象实例)被放入一个 <literal>Set</literal>,改变它的 "
+"hashcode 会导致与这个 <literal>Set</literal> 的关系中断。虽 然业务键值的属性"
+"不象数据库主键那样稳定不变,但是你只需要保证在同一个 <literal>Set</literal> "
+"中的对象属性的稳定性就足够了。请到 Hibernate 网站去寻求这个问题更多的详细的讨"
+"论。请注意,这不是一个有关 Hibernate 的问题,而仅仅是一个关于 Java 对象标识和"
+"判等行为如何实现的问题。 "
 
 #. Tag: title
-#: transactions.xml:334
 #, no-c-format
 msgid "Common issues"
 msgstr "常见问题"
 
 #. Tag: para
-#: transactions.xml:336
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not use the anti-patterns <emphasis>session-per-user-session</emphasis> "
 "or <emphasis>session-per-application</emphasis> (there are, however, rare "
@@ -560,14 +539,13 @@
 "within the recommended patterns, so ensure that you understand the "
 "implications before making a design decision:"
 msgstr ""
-"决不要使用反模式<emphasis>session-per-user-session</emphasis>或者<emphasis> "
-"session-per-application</emphasis>(当然,这个规定几乎没有例外)。请注意, 下"
-"述一些问题可能也会出现在我们推荐的模式中,在你作出某个设计决定之前,请务必理"
-"解该模式的应用前提。"
+"决不要使用反模式 <emphasis>session-per-user-session</emphasis> 或者 "
+"<emphasis> session-per-application</emphasis>(当然,这个规定几乎没有例外)。"
+"请注意,下述一些问题可能也会出现在我们推荐的模式中,在你作出某个设计决定之"
+"前,请务必理解该模式的应用前提。 "
 
 #. Tag: para
-#: transactions.xml:345
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <literal>Session</literal> is not thread-safe. Things that work "
 "concurrently, like HTTP requests, session beans, or Swing workers, will "
@@ -578,17 +556,16 @@
 "that clicks reload fast enough can use the same <literal>Session</literal> "
 "in two concurrently running threads."
 msgstr ""
-"<literal>Session</literal> 对象是非线程安全的。如果一个<literal>Session</"
-"literal> 实例允许共享的话,那些支持并发运行的东东,例如HTTP request,session "
-"beans,或者是 Swing workers,将会导致出现资源争用(race condition)。如果在"
-"<literal>HttpSession</literal>中有 Hibernate 的<literal>Session</literal>的话"
-"(稍后讨论),你应该考虑同步访问你的Http session。 否则,只要用户足够快的点击"
-"浏览器的“刷新”,就会导致两个并发运行线程使用同一个 <literal>Session</"
-"literal>。"
+"<literal>Session</literal> 对象是非线程安全的。如果一个 <literal>Session</"
+"literal> 实例允许共享的话,那些支持并发运行的东东,例如 HTTP request,"
+"session beans 或者是 Swing workers,将会导致出现资源争用(race condition)。"
+"如果在 <literal>HttpSession</literal> 中有 Hibernate 的 <literal>Session</"
+"literal> 的话(稍后讨论),你应该考虑同步访问你的 Http session。 否则,只要用"
+"户足够快的点击浏览器的“刷新”,就会导致两个并发运行线程使用同一个  "
+"<literal>Session</literal>。 "
 
 #. Tag: para
-#: transactions.xml:356
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An exception thrown by Hibernate means you have to rollback your database "
 "transaction and close the <literal>Session</literal> immediately (this is "
@@ -600,15 +577,14 @@
 "Usually this is not a problem, because exceptions are not recoverable and "
 "you will have to start over after rollback anyway."
 msgstr ""
-"一个由Hibernate抛出的异常意味着你必须立即回滚数据库事务,并立即关闭"
-"<literal>Session</literal> (稍后会展开讨论)。如果你的<literal>Session</"
-"literal>绑定到一个应用程序上,你必 须停止该应用程序。回滚数据库事务并不会把你"
-"的业务对象退回到事务启动时候的状态。这 意味着数据库状态和业务对象状态不同步。"
-"通常情况下,这不是什么问题,因为异常是不可 恢复的,你必须在回滚之后重新开始执"
-"行。"
+"一个由 Hibernate 抛出的异常意味着你必须立即回滚数据库事务,并立即关闭 "
+"<literal>Session</literal>(稍后会展开讨论)。如果你的 <literal>Session</"
+"literal> 绑定到一个应用程序上,你必须停止该应用程序。回滚数据库事务并不会把你"
+"的业务对象退回到事务启动时候的状态。这意味着数据库状态和业务对象状态不同步。"
+"通常情况下,这不是什么问题,因为异常是不可恢复的,你必须在回滚之后重新开始执"
+"行。 "
 
 #. Tag: para
-#: transactions.xml:368
 #, fuzzy, no-c-format
 msgid ""
 "The <literal>Session</literal> caches every object that is in a persistent "
@@ -617,28 +593,26 @@
 "until you get an OutOfMemoryException. One solution is to call <literal>clear"
 "()</literal> and <literal>evict()</literal> to manage the <literal>Session</"
 "literal> cache, but you should consider a Stored Procedure if you need mass "
-"data operations. Some solutions are shown in <xref linkend=\"batch\"/>. "
+"data operations. Some solutions are shown in <xref linkend=\"batch\" />. "
 "Keeping a <literal>Session</literal> open for the duration of a user session "
 "also means a higher probability of stale data."
 msgstr ""
-"<literal>Session</literal> 缓存了处于持久化状态的每个对象(Hibernate会监视和"
-"检查脏数据)。 这意味着,如果你让<literal>Session</literal>打开很长一段时间,"
-"或是仅仅载入了过多的数据, <literal>Session</literal>占用的内存会一直增长,直"
-"到抛出OutOfMemoryException异常。这个 问题的一个解决方法是调用<literal>clear()"
-"</literal> 和<literal>evict()</literal>来管理 <literal>Session</literal>的缓"
-"存,但是如果你需要大批量数据操作的话,最好考虑 使用存储过程。在<xref linkend="
-"\"batch\"/>中有一些解决方案。在用户会话期间一直保持 <literal>Session</"
-"literal>打开也意味着出现脏数据的可能性很高。"
+"<literal>Session</literal> 缓存了处于持久化状态的每个对象(Hibernate 会监视和"
+"检查脏数据)。 这意味着,如果你让 <literal>Session</literal> 打开很长一段时"
+"间,或是仅仅载入了过多的数据, <literal>Session</literal> 占用的内存会一直增"
+"长,直到抛出 OutOfMemoryException 异常。这个 问题的一个解决方法是调用 "
+"<literal>clear()</literal> 和 <literal>evict()</literal> 来管理 "
+"<literal>Session</literal> 的缓存,但是如果你需要大批量数据操作的话,最好考虑"
+"使用存储过程。在<xref linkend=\"batch\"/>中有一些解决方案。在用户会话期间一直"
+"保持 <literal>Session</literal> 打开也意味着出现脏数据的可能性很高。  "
 
 #. Tag: title
-#: transactions.xml:386
 #, no-c-format
 msgid "Database transaction demarcation"
 msgstr "数据库事务声明"
 
 #. Tag: para
-#: transactions.xml:388
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Database, or system, transaction boundaries are always necessary. No "
 "communication with the database can occur outside of a database transaction "
@@ -650,14 +624,13 @@
 "to perform better than many small transactions, even for reading data."
 msgstr ""
 "数据库(或者系统)事务的声明总是必须的。在数据库事务之外,就无法和数据库通讯"
-"(这可能会让那些习惯于 自动提交事务模式的开发人员感到迷惑)。永远使用清晰的事"
+"(这可能会让那些习惯于自动提交事务模式的开发人员感到迷惑)。永远使用清晰的事"
 "务声明,即使只读操作也是如此。进行 显式的事务声明并不总是需要的,这取决于你的"
 "事务隔离级别和数据库的能力,但不管怎么说,声明事务总归有益无害。当然,一个单"
-"独的数据库事务总是比很多琐碎的事务性能更好,即时对读数据而言也是一样。"
+"独的数据库事务总是比很多琐碎的事务性能更好,即时对读数据而言也是一样。 "
 
 #. Tag: para
-#: transactions.xml:398
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A Hibernate application can run in non-managed (i.e., standalone, simple "
 "Web- or Swing applications) and managed J2EE environments. In a non-managed "
@@ -669,17 +642,16 @@
 "descriptors of EJB session beans, for example). Programmatic transaction "
 "demarcation is then no longer necessary."
 msgstr ""
-"一个Hibernate应用程序可以运行在非托管环境中(也就是独立运行的应用程序,简单"
-"Web应用程序, 或者Swing图形桌面应用程序),也可以运行在托管的J2EE环境中。在一"
-"个非托管环境中,Hibernate 通常自己负责管理数据库连接池。应用程序开发人员必须"
-"手工设置事务声明,换句话说,就是手工启 动,提交,或者回滚数据库事务。一个托管"
-"的环境通常提供了容器管理事务(CMT),例如事务装配通过可声 明的方式定义在EJB "
-"session beans的部署描述符中。可编程式事务声明不再需要,即使是 "
-"<literal>Session</literal> 的同步也可以自动完成。"
+"一个 Hibernate 应用程序可以运行在非托管环境中(也就是独立运行的应用程序,简"
+"单 Web 应用程序,或者Swing图形桌面应用程序),也可以运行在托管的 J2EE 环境"
+"中。在一个非托管环境中,Hibernate 通常自己负责管理数据库连接池。应用程序开发"
+"人员必须手工设置事务声明,换句话说,就是手工启 动,提交,或者回滚数据库事务。"
+"一个托管的环境通常提供了容器管理事务(CMT),例如事务装配通过可声明的方式定义"
+"在 EJB session beans 的部署描述符中。可编程式事务声明不再需要,即使是 "
+"<literal>Session</literal> 的同步也可以自动完成。 "
 
 #. Tag: para
-#: transactions.xml:408
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "However, it is often desirable to keep your persistence layer portable "
 "between non-managed resource-local environments, and systems that can rely "
@@ -689,98 +661,65 @@
 "system of your deployment environment. This API is actually optional, but we "
 "strongly encourage its use unless you are in a CMT session bean."
 msgstr ""
-"让持久层具备可移植性是人们的理想,这种移植发生在非托管的本地资源环境,与依赖"
-"JTA但是使用BMT而非CMT的系统之间。在两种情况下你都可以使用编程式的事务管理。"
-"Hibernate提供了一套称为<literal>Transaction</literal>的封装API, 用来把你的部"
-"署环境中的本地事务管理系统转换到Hibernate事务上。这个API是可选的,但是我们强"
-"烈 推荐你使用,除非你用CMT session bean。"
+"让持久层具备可移植性是人们的理想,这种移植发生在非托管的本地资源环境,与依赖 "
+"JTA 但是使用 BMT 而非 CMT 的系统之间。在两种情况下你都可以使用编程式的事务管"
+"理。Hibernate 提供了一套称为 <literal>Transaction</literal> 的封装 API, 用来"
+"把你的部署环境中的本地事务管理系统转换到 Hibernate 事务上。这个 API 是可选"
+"的,但是我们强烈推荐你使用,除非你用 CMT session bean。 "
 
 #. Tag: para
-#: transactions.xml:417
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Ending a <literal>Session</literal> usually involves four distinct phases:"
-msgstr "通常情况下,结束 <literal>Session</literal> 包含了四个不同的阶段:"
+msgstr "通常情况下,结束 <literal>Session</literal> 包含了四个不同的阶段: "
 
 #. Tag: para
-#: transactions.xml:423
 #, no-c-format
 msgid "flush the session"
-msgstr "同步session(flush,刷出到磁盘)"
+msgstr "同步 session(flush,刷出到磁盘)"
 
 #. Tag: para
-#: transactions.xml:428
 #, no-c-format
 msgid "commit the transaction"
 msgstr "提交事务"
 
 #. Tag: para
-#: transactions.xml:433
 #, no-c-format
 msgid "close the session"
-msgstr "关闭session"
+msgstr "关闭 session"
 
 #. Tag: para
-#: transactions.xml:438
 #, no-c-format
 msgid "handle exceptions"
 msgstr "处理异常"
 
 #. Tag: para
-#: transactions.xml:444
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We discussed Flushing the session earlier, so we will now have a closer look "
 "at transaction demarcation and exception handling in both managed and non-"
 "managed environments."
 msgstr ""
-"session的同步(flush,刷出)前面已经讨论过了,我们现在进一步考察在托管和非托管"
-"环境下的事务声明和异常处理。"
+"session 的同步(flush,刷出)前面已经讨论过了,我们现在进一步考察在托管和非托"
+"管环境下的事务声明和异常处理。 "
 
 #. Tag: title
-#: transactions.xml:451
 #, no-c-format
 msgid "Non-managed environment"
 msgstr "非托管环境"
 
 #. Tag: para
-#: transactions.xml:453
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If a Hibernate persistence layer runs in a non-managed environment, database "
 "connections are usually handled by simple (i.e., non-DataSource) connection "
 "pools from which Hibernate obtains connections as needed. The session/"
 "transaction handling idiom looks like this:"
 msgstr ""
-"如果Hibernat持久层运行在一个非托管环境中,数据库连接通常由Hibernate的简单(即"
-"非DataSource)连接池机制 来处理。session/transaction处理方式如下所示:"
+"如果 Hibernat 持久层运行在一个非托管环境中,数据库连接通常由 Hibernate 的简单"
+"(即非 DataSource)连接池机制 来处理。session/transaction 处理方式如下所示: "
 
-#. Tag: programlisting
-#: transactions.xml:460
-#, no-c-format
-msgid ""
-"<![CDATA[// Non-managed environment idiom\n"
-"Session sess = factory.openSession();\n"
-"Transaction tx = null;\n"
-"try {\n"
-"    tx = sess.beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    if (tx != null) tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:462
 #, fuzzy, no-c-format
 msgid ""
 "You do not have to <literal>flush()</literal> the <literal>Session</literal> "
@@ -791,45 +730,25 @@
 "literal> is that the JDBC connection will be relinquished by the session. "
 "This Java code is portable and runs in both non-managed and JTA environments."
 msgstr ""
-"你不需要显式<literal>flush()</literal><literal>Session</literal> - 对"
-"<literal>commit()</literal>的调用会自动触发session的同步(取决于session的"
-"<xref linkend=\"objectstate-flushing\">FlushMode</xref>)。调用 <literal>close"
-"()</literal> 标志session的结束。<literal>close()</literal>方法重要的暗示是,"
-"<literal>session</literal>释放了JDBC连接。这段Java代码在非托管环境下和JTA环境"
-"下都可以运行。"
+"你不需要显式 <literal>flush()</literal> <literal>Session</literal> — 对 "
+"<literal>commit()</literal> 的调用会自动触发 session 的同步(取决于 session "
+"的 <xref linkend=\"objectstate-flushing\" />)。调用 <literal>close()</"
+"literal> 标志 session 的结束。<literal>close()</literal> 方法重要的暗示是,"
+"<literal>session</literal> 释放了 JDBC 连接。这段 Java 代码在非托管环境下和 "
+"JTA 环境下都可以运行。"
 
 #. Tag: para
-#: transactions.xml:471
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "As outlined earlier, a much more flexible solution is Hibernate's built-in "
 "\"current session\" context management:"
 msgstr ""
-"更加灵活的方案是Hibernate内置的\"current session\"上下文管理,前文已经讲过:"
+"更加灵活的方案是 Hibernate 内置的 \"current session\" 上下文管理,前文已经讲"
+"过: "
 
-#. Tag: programlisting
-#: transactions.xml:476
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// Non-managed environment idiom with getCurrentSession()\n"
-"try {\n"
-"    factory.getCurrentSession().beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    factory.getCurrentSession().getTransaction().commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    factory.getCurrentSession().getTransaction().rollback();\n"
-"    throw e; // or display error message\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:478
-#, fuzzy, no-c-format
-msgid ""
 "You will not see these code snippets in a regular application; fatal "
 "(system) exceptions should always be caught at the \"top\". In other words, "
 "the code that executes Hibernate calls in the persistence layer, and the "
@@ -840,15 +759,14 @@
 "this chapter."
 msgstr ""
 "你很可能从未在一个通常的应用程序的业务代码中见过这样的代码片断:致命的(系"
-"统)异常应该总是 在应用程序“顶层”被捕获。换句话说,执行Hibernate调用的代码"
-"(在持久层)和处理 <literal>RuntimeException</literal>异常的代码(通常只能清"
-"理和退出应用程序)应该在不同 的应用程序逻辑层。Hibernate的当前上下文管理可以"
-"极大地简化这一设计,你所有的一切就是<literal>SessionFactory</literal>。 异常"
-"处理将在本章稍后进行讨论。"
+"统)异常应该总是 在应用程序“顶层”被捕获。换句话说,执行 Hibernate 调用的代码"
+"(在持久层)和处理 <literal>RuntimeException</literal> 异常的代码(通常只能清"
+"理和退出应用程序)应该在不同 的应用程序逻辑层。Hibernate 的当前上下文管理可以"
+"极大地简化这一设计,你所有的一切就是 <literal>SessionFactory</literal>。异常"
+"处理将在本章稍后进行讨论。 "
 
 #. Tag: para
-#: transactions.xml:488
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You should select <literal>org.hibernate.transaction.JDBCTransactionFactory</"
 "literal>, which is the default, and for the second example select <literal>"
@@ -856,19 +774,17 @@
 "current_session_context_class</literal>."
 msgstr ""
 "请注意,你应该选择 <literal>org.hibernate.transaction."
-"JDBCTransactionFactory</literal> (这是默认选项),对第二个例子来说,"
-"<literal>hibernate.current_session_context_class</literal>应该是<literal>"
-"\"thread\"</literal>"
+"JDBCTransactionFactory</literal> (这是默认选项),对第二个例子来说,"
+"<literal>hibernate.current_session_context_class</literal>应该是 <literal>"
+"\"thread\"</literal>。"
 
 #. Tag: title
-#: transactions.xml:497
 #, no-c-format
 msgid "Using JTA"
-msgstr "使用JTA"
+msgstr "使用 JTA"
 
 #. Tag: para
-#: transactions.xml:499
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If your persistence layer runs in an application server (for example, behind "
 "EJB session beans), every datasource connection obtained by Hibernate will "
@@ -876,108 +792,45 @@
 "standalone JTA implementation and use it without EJB. Hibernate offers two "
 "strategies for JTA integration."
 msgstr ""
-"如果你的持久层运行在一个应用服务器中(例如,在EJB session beans的后面),"
-"Hibernate获取 的每个数据源连接将自动成为全局JTA事务的一部分。 你可以安装一个"
-"独立的JTA实现,使用它而不使用EJB。Hibernate提供了两种策略进行JTA集成。"
+"如果你的持久层运行在一个应用服务器中(例如,在 EJB session beans 的后面),"
+"Hibernate 获取的每个数据源连接将自动成为全局 JTA 事务的一部分。你可以安装一个"
+"独立的 JTA 实现,使用它而不使用 EJB。Hibernate 提供了两种策略进行 JTA 集成。 "
 
 #. Tag: para
-#: transactions.xml:506
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you use bean-managed transactions (BMT), Hibernate will tell the "
 "application server to start and end a BMT transaction if you use the "
 "<literal>Transaction</literal> API. The transaction management code is "
 "identical to the non-managed environment."
 msgstr ""
-"如果你使用bean管理事务(BMT),可以通过使用Hibernate的 <literal>Transaction</"
-"literal> API来告诉 应用服务器启动和结束BMT事务。因此,事务管理代码和在非托管"
-"环境下是一样的。"
+"如果你使用 bean 管理事务(BMT),可以通过使用 Hibernate 的 "
+"<literal>Transaction</literal> API 来告诉应用服务器启动和结束 BMT 事务。因"
+"此,事务管理代码和在非托管环境下是一样的。 "
 
-#. Tag: programlisting
-#: transactions.xml:512
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// BMT idiom\n"
-"Session sess = factory.openSession();\n"
-"Transaction tx = null;\n"
-"try {\n"
-"    tx = sess.beginTransaction();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    if (tx != null) tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:514
-#, fuzzy, no-c-format
-msgid ""
 "If you want to use a transaction-bound <literal>Session</literal>, that is, "
 "the <literal>getCurrentSession()</literal> functionality for easy context "
 "propagation, use the JTA <literal>UserTransaction</literal> API directly:"
 msgstr ""
-"如果你希望使用与事务绑定的<literal>Session</literal>,也就是使用"
-"<literal>getCurrentSession()</literal>来简化上下文管理,你将不得不直接使用"
-"JTA <literal>UserTransaction</literal>API。"
+"如果你希望使用与事务绑定的 <literal>Session</literal>,也就是使用 "
+"<literal>getCurrentSession()</literal> 来简化上下文管理,你将不得不直接使用 "
+"JTA  <literal>UserTransaction</literal> API。 "
 
-#. Tag: programlisting
-#: transactions.xml:520
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// BMT idiom with getCurrentSession()\n"
-"try {\n"
-"    UserTransaction tx = (UserTransaction)new InitialContext()\n"
-"                            .lookup(\"java:comp/UserTransaction\");\n"
-"\n"
-"    tx.begin();\n"
-"\n"
-"    // Do some work on Session bound to transaction\n"
-"    factory.getCurrentSession().load(...);\n"
-"    factory.getCurrentSession().persist(...);\n"
-"\n"
-"    tx.commit();\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    tx.rollback();\n"
-"    throw e; // or display error message\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:522
-#, fuzzy, no-c-format
-msgid ""
 "With CMT, transaction demarcation is completed in session bean deployment "
 "descriptors, not programmatically. The code is reduced to:"
 msgstr ""
-"在CMT方式下,事务声明是在session bean的部署描述符中,而不需要编程。 因此,代"
-"码被简化为:"
+"在 CMT 方式下,事务声明是在 session bean 的部署描述符中,而不需要编程。因此,"
+"代码被简化为:"
 
-#. Tag: programlisting
-#: transactions.xml:527
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// CMT idiom\n"
-" Session sess = factory.getCurrentSession();\n"
-"\n"
-" // do some work\n"
-" ...\n"
-"]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:529
-#, fuzzy, no-c-format
-msgid ""
 "In a CMT/EJB, even rollback happens automatically. An unhandled "
 "<literal>RuntimeException</literal> thrown by a session bean method tells "
 "the container to set the global transaction to rollback. <emphasis>You do "
@@ -985,14 +838,14 @@
 "BMT or CMT, and you get automatic propagation of the \"current\" Session "
 "bound to the transaction.</emphasis>"
 msgstr ""
-"在CMT/EJB中甚至会自动rollback,因为假若有未捕获的<literal>RuntimeException</"
-"literal>从session bean方法中抛出,这就会通知容器把全局事务回滚。<emphasis>这"
-"就意味着,在BMT或者CMT中,你根本就不需要使用Hibernate <literal>Transaction</"
-"literal> API ,你自动得到了绑定到事务的“当前”Session。 </emphasis>"
+"在 CMT/EJB 中甚至会自动 rollback,因为假若有未捕获的 "
+"<literal>RuntimeException</literal> 从 session bean 方法中抛出,这就会通知容"
+"器把全局事务回滚。<emphasis>这就意味着,在 BMT 或者 CMT 中,你根本就不需要使"
+"用 Hibernate <literal>Transaction</literal> API,你自动得到了绑定到事务的“当"
+"前” Session。</emphasis>"
 
 #. Tag: para
-#: transactions.xml:537
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "When configuring Hibernate's transaction factory, choose <literal>org."
 "hibernate.transaction.JTATransactionFactory</literal> if you use JTA "
@@ -1002,17 +855,16 @@
 "your <literal>hibernate.current_session_context_class</literal> is either "
 "unset (backwards compatibility), or is set to <literal>\"jta\"</literal>."
 msgstr ""
-"注意,当你配置Hibernate的transaction factory的时候,在直接使用JTA的时候"
-"(BMT),你应该选择<literal>org.hibernate.transaction.JTATransactionFactory</"
-"literal>,在CMT session bean中选择<literal>org.hibernate.transaction."
-"CMTTransactionFactory</literal>。记得也要设置<literal>hibernate.transaction."
-"manager_lookup_class</literal>。还有,确认你的<literal>hibernate."
-"current_session_context_class</literal>未设置(为了向下兼容),或者设置为"
-"<literal>\"jta\"</literal>。"
+"注意,当你配置 Hibernate 的 transaction factory 的时候,在直接使用 JTA 的时候"
+"(BMT),你应该选择 <literal>org.hibernate.transaction."
+"JTATransactionFactory</literal>,在 CMT session bean 中选择 <literal>org."
+"hibernate.transaction.CMTTransactionFactory</literal>。记得也要设置 "
+"<literal>hibernate.transaction.manager_lookup_class</literal>。还有,确认你"
+"的 <literal>hibernate.current_session_context_class</literal> 未设置(为了向"
+"下兼容),或者设置为 <literal>\"jta\"</literal>。 "
 
 #. Tag: para
-#: transactions.xml:546
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>getCurrentSession()</literal> operation has one downside in a "
 "JTA environment. There is one caveat to the use of <literal>after_statement</"
@@ -1027,26 +879,24 @@
 "using <literal>scroll()</literal> or <literal>iterate()</literal> from the "
 "JTA or CMT code.)"
 msgstr ""
-"<literal>getCurrentSession()</literal>在JTA环境中有一个弊端。对"
-"<literal>after_statement</literal>连接释放方式有一个警告,这是被默认使用的。"
-"因为JTA规范的一个很愚蠢的限制,Hibernate不可能自动清理任何未关闭的"
+"<literal>getCurrentSession()</literal>在 JTA 环境中有一个弊端。对 "
+"<literal>after_statement</literal> 连接释放方式有一个警告,这是被默认使用的。"
+"因为 JTA 规范的一个很愚蠢的限制,Hibernate 不可能自动清理任何未关闭的 "
 "<literal>ScrollableResults</literal> 或者<literal>Iterator</literal>,它们是"
-"由<literal>scroll()</literal>或<literal>iterate()</literal>产生的。你"
-"<emphasis>must</emphasis>通过在<literal>finally</literal>块中,显式调用"
-"<literal>ScrollableResults.close()</literal>或者<literal>Hibernate.close"
-"(Iterator)</literal>方法来释放底层数据库游标。(当然,大部分程序完全可以很容易"
-"的避免在JTA或CMT代码中出现<literal>scroll()</literal>或<literal>iterate()</"
-"literal>。)"
+"由 <literal>scroll()</literal> 或 <literal>iterate()</literal> 产生的。你 "
+"<emphasis>must</emphasis> 通过在 <literal>finally</literal> 块中,显式调用 "
+"<literal>ScrollableResults.close()</literal> 或者 <literal>Hibernate.close"
+"(Iterator)</literal> 方法来释放底层数据库游标。(当然,大部分程序完全可以很容"
+"易的避免在 JTA 或 CMT 代码中出现 <literal>scroll()</literal> 或 "
+"<literal>iterate()</literal>。) "
 
 #. Tag: title
-#: transactions.xml:562
 #, no-c-format
 msgid "Exception handling"
 msgstr "异常处理"
 
 #. Tag: para
-#: transactions.xml:564
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the <literal>Session</literal> throws an exception, including any "
 "<literal>SQLException</literal>, immediately rollback the database "
@@ -1057,16 +907,15 @@
 "Ensure that the <literal>Session</literal> will be closed by calling "
 "<literal>close()</literal> in a <literal>finally</literal> block."
 msgstr ""
-"如果 <literal>Session</literal> 抛出异常 (包括任何<literal>SQLException</"
-"literal>), 你应该立即回滚数据库事务,调用 <literal>Session.close()</"
-"literal> ,丢弃该 <literal>Session</literal>实例。<literal>Session</literal>"
-"的某些方法可能会导致session 处于不一致的状态。所有由Hibernate抛出的异常都视为"
-"不可以恢复的。确保在 <literal>finally</literal> 代码块中调用<literal>close()"
-"</literal>方法,以关闭掉 <literal>Session</literal>。"
+"如果 <literal>Session</literal> 抛出异常(包括任何 <literal>SQLException</"
+"literal>),你应该立即回滚数据库事务,调用 <literal>Session.close()</"
+"literal> ,丢弃该  <literal>Session</literal> 实例。<literal>Session</"
+"literal> 的某些方法可能会导致 session 处于不一致的状态。所有由 Hibernate 抛出"
+"的异常都视为不可以恢复的。确保在  <literal>finally</literal> 代码块中调用 "
+"<literal>close()</literal> 方法,以关闭掉  <literal>Session</literal>。"
 
 #. Tag: para
-#: transactions.xml:575
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>HibernateException</literal>, which wraps most of the errors "
 "that can occur in a Hibernate persistence layer, is an unchecked exception. "
@@ -1079,18 +928,17 @@
 "unchecked exceptions that are not a <literal>HibernateException</literal>. "
 "These are not recoverable and appropriate action should be taken."
 msgstr ""
-"<literal>HibernateException</literal>是一个非检查期异常(这不同于Hibernate老"
-"的版本), 它封装了Hibernate持久层可能出现的大多数错误。我们的观点是,不应该"
-"强迫应用程序开发人员 在底层捕获无法恢复的异常。在大多数软件系统中,非检查期异"
-"常和致命异常都是在相应方法调用 的堆栈的顶层被处理的(也就是说,在软件上面的逻"
-"辑层),并且提供一个错误信息给应用软件的用户 (或者采取其他某些相应的操作)。"
-"请注意,Hibernate也有可能抛出其他并不属于 <literal>HibernateException</"
-"literal>的非检查期异常。这些异常同样也是无法恢复的,应该 采取某些相应的操作去"
-"处理。"
+"<literal>HibernateException</literal> 是一个非检查期异常(这不同于 Hibernate "
+"老的版本),它封装了 Hibernate 持久层可能出现的大多数错误。我们的观点是,不应"
+"该强迫应用程序开发人员 在底层捕获无法恢复的异常。在大多数软件系统中,非检查期"
+"异常和致命异常都是在相应方法调用 的堆栈的顶层被处理的(也就是说,在软件上面的"
+"逻辑层),并且提供一个错误信息给应用软件的用户 (或者采取其他某些相应的操"
+"作)。请注意,Hibernate 也有可能抛出其他并不属于 "
+"<literal>HibernateException</literal> 的非检查期异常。这些异常同样也是无法恢"
+"复的,应该 采取某些相应的操作去处理。"
 
 #. Tag: para
-#: transactions.xml:587
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate wraps <literal>SQLException</literal>s thrown while interacting "
 "with the database in a <literal>JDBCException</literal>. In fact, Hibernate "
@@ -1107,72 +955,67 @@
 "class for details. The standard <literal>JDBCException</literal> subtypes "
 "are:"
 msgstr ""
-"在和数据库进行交互时,Hibernate把捕获的<literal>SQLException</literal>封装为"
-"Hibernate的 <literal>JDBCException</literal>。事实上,Hibernate尝试把异常转换"
-"为更有实际含义 的<literal>JDBCException</literal>异常的子类。底层的"
-"<literal>SQLException</literal>可以 通过<literal>JDBCException.getCause()</"
-"literal>来得到。Hibernate通过使用关联到 <literal>SessionFactory</literal>上的"
-"<literal>SQLExceptionConverter</literal>来 把<literal>SQLException</literal>"
-"转换为一个对应的<literal>JDBCException</literal> 异常的子类。默认情况下,"
-"<literal>SQLExceptionConverter</literal>可以通过配置dialect 选项指定;此外,"
-"也可以使用用户自定义的实现类(参考javadocs "
-"<literal>SQLExceptionConverterFactory</literal>类来了解详情)。标准的 "
-"<literal>JDBCException</literal>子类型是:"
+"在和数据库进行交互时,Hibernate 把捕获的 <literal>SQLException</literal> 封装"
+"为 Hibernate 的  <literal>JDBCException</literal>。事实上,Hibernate 尝试把异"
+"常转换为更有实际含义的 <literal>JDBCException</literal> 异常的子类。底层的 "
+"<literal>SQLException</literal> 可以通过 <literal>JDBCException.getCause()</"
+"literal> 来得到。Hibernate 通过使用关联到  <literal>SessionFactory</literal> "
+"上的 <literal>SQLExceptionConverter</literal> 来把 <literal>SQLException</"
+"literal> 转换为一个对应的 <literal>JDBCException</literal> 异常的子类。默认情"
+"况下,<literal>SQLExceptionConverter</literal> 可以通过配置 dialect 选项指"
+"定;此外,也可以使用用户自定义的实现类(参考 javadocs "
+"<literal>SQLExceptionConverterFactory</literal> 类来了解详情)。标准的 "
+"<literal>JDBCException</literal> 子类型是: "
 
 #. Tag: para
-#: transactions.xml:603
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>JDBCConnectionException</literal>: indicates an error with the "
 "underlying JDBC communication."
 msgstr ""
-"<literal>JDBCConnectionException</literal> - 指明底层的JDBC通讯出现错误"
+"<literal>JDBCConnectionException</literal>:指明底层的 JDBC 通讯出现错误。"
 
 #. Tag: para
-#: transactions.xml:609
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>SQLGrammarException</literal>: indicates a grammar or syntax "
 "problem with the issued SQL."
 msgstr ""
-"<literal>SQLGrammarException</literal> - 指明发送的SQL语句的语法或者格式错误"
+"<literal>SQLGrammarException</literal>:指明发送的 SQL 语句的语法或者格式错"
+"误。"
 
 #. Tag: para
-#: transactions.xml:615
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ConstraintViolationException</literal>: indicates some form of "
 "integrity constraint violation."
 msgstr ""
-"<literal>ConstraintViolationException</literal> - 指明某种类型的约束违例错误"
+"<literal>ConstraintViolationException</literal>:指明某种类型的约束违例错误"
 
 #. Tag: para
-#: transactions.xml:621
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockAcquisitionException</literal>: indicates an error acquiring a "
 "lock level necessary to perform the requested operation."
 msgstr ""
-"<literal>LockAcquisitionException</literal> - 指明了在执行请求操作时,获取 所"
-"需的锁级别时出现的错误。"
+"<literal>LockAcquisitionException</literal>:指明了在执行请求操作时,获取所需"
+"的锁级别时出现的错误。"
 
 #. Tag: para
-#: transactions.xml:627
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>GenericJDBCException</literal>: a generic exception which did not "
 "fall into any of the other categories."
-msgstr "<literal>GenericJDBCException</literal> - 不属于任何其他种类的原生异常"
+msgstr ""
+"<literal>GenericJDBCException</literal>:不属于任何其他种类的原生异常。"
 
 #. Tag: title
-#: transactions.xml:637
 #, no-c-format
 msgid "Transaction timeout"
 msgstr "事务超时"
 
 #. Tag: para
-#: transactions.xml:639
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "An important feature provided by a managed environment like EJB, that is "
 "never provided for non-managed code, is transaction timeout. Transaction "
@@ -1185,57 +1028,29 @@
 "transaction timeout to JTA. This functionality is abstracted by the "
 "Hibernate <literal>Transaction</literal> object."
 msgstr ""
-"EJB这样的托管环境有一项极为重要的特性,而它从未在非托管环境中提供过,那就是事"
-"务超时。在出现错误的事务行为的时候,超时可以确保不会无限挂起资源、对用户没有"
-"交代。在托管(JTA)环境之外,Hibernate无法完全提供这一功能。但是,Hiberante至少"
-"可以控制数据访问,确保数据库级别的死锁,和返回巨大结果集的查询被限定在一个规"
-"定的时间内。在托管环境中,Hibernate会把事务超时转交给JTA。这一功能通过"
-"Hibernate <literal>Transaction</literal>对象进行抽象。"
+"EJB 这样的托管环境有一项极为重要的特性,而它从未在非托管环境中提供过,那就是"
+"事务超时。在出现错误的事务行为的时候,超时可以确保不会无限挂起资源、对用户没"
+"有交代。在托管(JTA)环境之外,Hibernate 无法完全提供这一功能。但是,"
+"Hiberante 至少可以控制数据访问,确保数据库级别的死锁,和返回巨大结果集的查询"
+"被限定在一个规定的时间内。在托管环境中,Hibernate 会把事务超时转交给 JTA。这"
+"一功能通过 Hibernate <literal>Transaction</literal> 对象进行抽象。 "
 
-#. Tag: programlisting
-#: transactions.xml:652
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"Session sess = factory.openSession();\n"
-"try {\n"
-"    //set transaction timeout to 3 seconds\n"
-"    sess.getTransaction().setTimeout(3);\n"
-"    sess.getTransaction().begin();\n"
-"\n"
-"    // do some work\n"
-"    ...\n"
-"\n"
-"    sess.getTransaction().commit()\n"
-"}\n"
-"catch (RuntimeException e) {\n"
-"    sess.getTransaction().rollback();\n"
-"    throw e; // or display error message\n"
-"}\n"
-"finally {\n"
-"    sess.close();\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:654
-#, fuzzy, no-c-format
-msgid ""
 "<literal>setTimeout()</literal> cannot be called in a CMT bean, where "
 "transaction timeouts must be defined declaratively."
 msgstr ""
-"注意<literal>setTimeout()</literal>不应该在CMT bean中调用,此时事务超时值应该"
-"是被声明式定义的。"
+"注意 <literal>setTimeout()</literal> 不应该在 CMT bean 中调用,此时事务超时值"
+"应该是被声明式定义的。 "
 
 #. Tag: title
-#: transactions.xml:664
 #, no-c-format
 msgid "Optimistic concurrency control"
-msgstr "乐观并发控制(Optimistic concurrency control)"
+msgstr "乐观并发控制(Optimistic concurrency control)"
 
 #. Tag: para
-#: transactions.xml:666
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The only approach that is consistent with high concurrency and high "
 "scalability, is optimistic concurrency control with versioning. Version "
@@ -1246,20 +1061,18 @@
 "has the benefit of preventing lost updates in single database transactions."
 msgstr ""
 "唯一能够同时保持高并发和高可伸缩性的方法就是使用带版本化的乐观并发控制。版本"
-"检查使用版本号、 或者时间戳来检测更新冲突(并且防止更新丢失)。Hibernate为使"
+"检查使用版本号、 或者时间戳来检测更新冲突(并且防止更新丢失)。Hibernate 为使"
 "用乐观并发控制的代码提供了三种可 能的方法,应用程序在编写这些代码时,可以采用"
 "它们。我们已经在前面应用程序对话那部分展示了 乐观并发控制的应用场景,此外,在"
-"单个数据库事务范围内,版本检查也提供了防止更新丢失的好处。"
+"单个数据库事务范围内,版本检查也提供了防止更新丢失的好处。 "
 
 #. Tag: title
-#: transactions.xml:677
 #, no-c-format
 msgid "Application version checking"
-msgstr "应用程序级别的版本检查(Application version checking)"
+msgstr "应用程序级别的版本检查(Application version checking)"
 
 #. Tag: para
-#: transactions.xml:679
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In an implementation without much help from Hibernate, each interaction with "
 "the database occurs in a new <literal>Session</literal> and the developer is "
@@ -1269,43 +1082,23 @@
 "least efficient in terms of database access. It is the approach most similar "
 "to entity EJBs."
 msgstr ""
-"未能充分利用Hibernate功能的实现代码中,每次和数据库交互都需要一个新的 "
-"<literal>Session</literal>,而且开发人员必须在显示数据之前从数据库中重 新载入"
-"所有的持久化对象实例。这种方式迫使应用程序自己实现版本检查来确保 对话事务的隔"
-"离,从数据访问的角度来说是最低效的。这种使用方式和 entity EJB最相似。"
+"未能充分利用 Hibernate 功能的实现代码中,每次和数据库交互都需要一个新的  "
+"<literal>Session</literal>,而且开发人员必须在显示数据之前从数据库中重新载入"
+"所有的持久化对象实例。这种方式迫使应用程序自己实现版本检查来确保对话事务的隔"
+"离,从数据访问的角度来说是最低效的。这种使用方式和 entity EJB 最相似。 "
 
-#. Tag: programlisting
-#: transactions.xml:688
-#, no-c-format
-msgid ""
-"<![CDATA[// foo is an instance loaded by a previous Session\n"
-"session = factory.openSession();\n"
-"Transaction t = session.beginTransaction();\n"
-"\n"
-"int oldVersion = foo.getVersion();\n"
-"session.load( foo, foo.getKey() ); // load the current state\n"
-"if ( oldVersion != foo.getVersion() ) throw new StaleObjectStateException"
-"();\n"
-"foo.setProperty(\"bar\");\n"
-"\n"
-"t.commit();\n"
-"session.close();]]>"
-msgstr ""
-
 #. Tag: para
-#: transactions.xml:690
 #, no-c-format
 msgid ""
 "The <literal>version</literal> property is mapped using <literal>&lt;"
 "version&gt;</literal>, and Hibernate will automatically increment it during "
 "flush if the entity is dirty."
 msgstr ""
-"<literal>version</literal> 属性使用 <literal>&lt;version&gt;</literal>来映"
-"射,如果对象 是脏数据,在同步的时候,Hibernate会自动增加版本号。"
+"<literal>version</literal> 属性使用 <literal>&lt;version&gt;</literal> 来映"
+"射,如果对象是脏数据,在同步的时候,Hibernate 会自动增加版本号。"
 
 #. Tag: para
-#: transactions.xml:696
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you are operating in a low-data-concurrency environment, and do not "
 "require version checking, you can use this approach and skip the version "
@@ -1315,14 +1108,13 @@
 "messages or a chance to merge conflicting changes."
 msgstr ""
 "当然,如果你的应用是在一个低数据并发环境下,并不需要版本检查的话,你照样可以"
-"使用 这种方式,只不过跳过版本检查就是了。在这种情况下,<emphasis>最晚提交生效"
+"使用这种方式,只不过跳过版本检查就是了。在这种情况下,<emphasis>最晚提交生效"
 "</emphasis> (<emphasis>last commit wins</emphasis>)就是你的长对话的默认处理"
-"策略。 请记住这种策略可能会让应用软件的用户感到困惑,因为他们有可能会碰上更新"
-"丢失掉却没 有出错信息,或者需要合并更改冲突的情况。"
+"策略。请记住这种策略可能会让应用软件的用户感到困惑,因为他们有可能会碰上更新"
+"丢失掉却没有出错信息,或者需要合并更改冲突的情况。 "
 
 #. Tag: para
-#: transactions.xml:705
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Manual version checking is only feasible in trivial circumstances and not "
 "practical for most applications. Often not only single instances, but "
@@ -1331,20 +1123,18 @@
 "literal> or detached instances as the design paradigm."
 msgstr ""
 "很明显,手工进行版本检查只适合于某些软件规模非常小的应用场景,对于大多数软件"
-"应用场景 来说并不现实。通常情况下,不仅是单个对象实例需要进行版本检查,整个被"
-"修改过的关 联对象图也都需要进行版本检查。作为标准设计范例,Hibernate使用扩展"
-"周期的 <literal>Session</literal>的方式,或者脱管对象实例的方式来提供自动版本"
-"检查。"
+"应用场景来说并不现实。通常情况下,不仅是单个对象实例需要进行版本检查,整个被"
+"修改过的关联对象图也都需要进行版本检查。作为标准设计范例,Hibernate 使用扩展"
+"周期的 <literal>Session</literal> 的方式,或者脱管对象实例的方式来提供自动版"
+"本检查。 "
 
 #. Tag: title
-#: transactions.xml:716
 #, no-c-format
 msgid "Extended session and automatic versioning"
-msgstr "扩展周期的session和自动版本化"
+msgstr "扩展周期的 session 和自动版本化"
 
 #. Tag: para
-#: transactions.xml:718
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A single <literal>Session</literal> instance and its persistent instances "
 "that are used for the whole conversation are known as <emphasis>session-per-"
@@ -1354,15 +1144,14 @@
 "opportunity for the user to merge changes or to restart the business "
 "conversation with non-stale data."
 msgstr ""
-"单个 <literal>Session</literal>实例和它所关联的所有持久化对象实例都被用于整"
-"个 对话,这被称为<emphasis>session-per-conversation</emphasis>。Hibernate在同"
-"步的时候进行对象实例的版本检查,如果检测到并发修 改则抛出异常。由开发人员来决"
-"定是否需要捕获和处理这个异常(通常的抉择是给用户 提供一个合并更改,或者在无脏"
-"数据情况下重新进行业务对话的机会)。"
+"单个 <literal>Session</literal> 实例和它所关联的所有持久化对象实例都被用于整"
+"个对话,这被称为 <emphasis>session-per-conversation</emphasis>。Hibernate 在"
+"同步的时候进行对象实例的版本检查,如果检测到并发修改则抛出异常。由开发人员来"
+"决定是否需要捕获和处理这个异常(通常的抉择是给用户 提供一个合并更改,或者在无"
+"脏数据情况下重新进行业务对话的机会)。 "
 
 #. Tag: para
-#: transactions.xml:727
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>Session</literal> is disconnected from any underlying JDBC "
 "connection when waiting for user interaction. This approach is the most "
@@ -1370,29 +1159,13 @@
 "check or reattach detached instances, nor does it have to reload instances "
 "in every database transaction."
 msgstr ""
-"在等待用户交互的时候, <literal>Session</literal> 断开底层的JDBC连接。这种方"
-"式 以数据库访问的角度来说是最高效的方式。应用程序不需要关心版本检查或脱管对象"
-"实例 的重新关联,在每个数据库事务中,应用程序也不需要载入读取对象实例。"
+"在等待用户交互的时候, <literal>Session</literal> 断开底层的 JDBC 连接。这种"
+"方式以数据库访问的角度来说是最高效的方式。应用程序不需要关心版本检查或脱管对"
+"象实例的重新关联,在每个数据库事务中,应用程序也不需要载入读取对象实例。 "
 
-#. Tag: programlisting
-#: transactions.xml:735
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// foo is an instance loaded earlier by the old session\n"
-"Transaction t = session.beginTransaction(); // Obtain a new JDBC connection, "
-"start transaction\n"
-"\n"
-"foo.setProperty(\"bar\");\n"
-"\n"
-"session.flush();    // Only for last transaction in conversation\n"
-"t.commit();         // Also return JDBC connection\n"
-"session.close();    // Only for last transaction in conversation]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:736
-#, fuzzy, no-c-format
-msgid ""
 "The <literal>foo</literal> object knows which <literal>Session</literal> it "
 "was loaded in. Beginning a new database transaction on an old session "
 "obtains a new connection and resumes the session. Committing a database "
@@ -1408,21 +1181,20 @@
 "will include the <literal>flush()</literal> operation, and then "
 "<literal>close()</literal> the session to end the conversation."
 msgstr ""
-"<literal>foo</literal>对象知道它是在哪个<literal>Session</literal>中被装入"
-"的。在一个旧session中开启一个新的数据库事务,会导致session获取一个新的连接,"
-"并恢复session的功能。将数据库事务提交,使得session从JDBC连接断开,并将此连接"
-"交还给连接池。在重新连接之后,要强制对你没有更新的数据进行一次版本检查,你可"
-"以对所有可能被其他事务修改过的对象,使用参数<literal>LockMode.READ</literal>"
-"来调用<literal>Session.lock()</literal>。你不用lock任何你<emphasis>正在</"
-"emphasis>更新的数据。一般你会在扩展的<literal>Session</literal>上设置"
-"<literal>FlushMode.MANUAL</literal>,因此只有最后一个数据库事务循环才会真正的"
-"吧整个对话中发生的修改发送到数据库。因此,只有这最后一次数据库事务才会包含"
-"<literal>flush()</literal>操作,然后在整个对话结束后,还要<literal>close()</"
-"literal>这个session。"
+"<literal>foo</literal> 对象知道它是在哪个 <literal>Session</literal> 中被装入"
+"的。在一个旧 session 中开启一个新的数据库事务,会导致 session 获取一个新的连"
+"接,并恢复 session 的功能。将数据库事务提交,使得 session 从 JDBC 连接断开,"
+"并将此连接交还给连接池。在重新连接之后,要强制对你没有更新的数据进行一次版本"
+"检查,你可以对所有可能被其他事务修改过的对象,使用参数 <literal>LockMode."
+"READ</literal> 来调用 <literal>Session.lock()</literal>。你不用 lock 任何你"
+"<emphasis>正在</emphasis>更新的数据。一般你会在扩展的 <literal>Session</"
+"literal> 上设置 <literal>FlushMode.NEVER</literal>,因此只有最后一个数据库事"
+"务循环才会真正的把整个对话中发生的修改发送到数据库。因此,只有这最后一次数据"
+"库事务才会包含 <literal>flush()</literal> 操作,然后在整个对话结束后,还要 "
+"<literal>close()</literal> 这个 session。 "
 
 #. Tag: para
-#: transactions.xml:751
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This pattern is problematic if the <literal>Session</literal> is too big to "
 "be stored during user think time (for example, an <literal>HttpSession</"
@@ -1432,33 +1204,30 @@
 "<literal>Session</literal> only for a single conversation as it will soon "
 "have stale data."
 msgstr ""
-"如果在用户思考的过程中,<literal>Session</literal>因为太大了而不能保存,那么"
-"这种模式是有 问题的。举例来说,一个<literal>HttpSession</literal>应该尽可能的"
-"小。由于 <literal>Session</literal>是一级缓存,并且保持了所有被载入过的对象,"
-"因此 我们只应该在那些少量的request/response情况下使用这种策略。你应该只把一个"
-"<literal>Session</literal>用于单个对话,因为它很快就会出现脏数据。"
+"如果在用户思考的过程中,<literal>Session</literal> 因为太大了而不能保存,那么"
+"这种模式是有问题的。举例来说,一个 <literal>HttpSession</literal> 应该尽可能"
+"的小。由于  <literal>Session</literal> 是一级缓存,并且保持了所有被载入过的对"
+"象,因此我们只应该在那些少量的 request/response 情况下使用这种策略。你应该只"
+"把一个 <literal>Session</literal> 用于单个对话,因为它很快就会出现脏数据。 "
 
 #. Tag: title
-#: transactions.xml:762
 #, no-c-format
 msgid "Note"
-msgstr ""
+msgstr "注意"
 
 #. Tag: para
-#: transactions.xml:763
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Earlier versions of Hibernate required explicit disconnection and "
 "reconnection of a <literal>Session</literal>. These methods are deprecated, "
 "as beginning and ending a transaction has the same effect."
 msgstr ""
-"(注意,早期的Hibernate版本需要明确的对<literal>Session</literal>进行"
-"disconnec和reconnect。这些方法现在已经过时了,打开事务和关闭事务会起到同样的"
-"效果。)"
+"注意,早期的 Hibernate 版本需要明确的对 <literal>Session</literal> 进行 "
+"disconnect 和 reconnect。这些方法现在已经过时了,打开事务和关闭事务会起到同样"
+"的效果。"
 
 #. Tag: para
-#: transactions.xml:769
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Keep the disconnected <literal>Session</literal> close to the persistence "
 "layer. Use an EJB stateful session bean to hold the <literal>Session</"
@@ -1466,14 +1235,13 @@
 "or even serialize it to a separate tier, to store it in the "
 "<literal>HttpSession</literal>."
 msgstr ""
-"此外,也请注意,你应该让与数据库连接断开的<literal>Session</literal>对持久层"
-"保持 关闭状态。换句话说,在三层环境中,使用有状态的EJB session bean来持有"
-"<literal>Session</literal>, 而不要把它传递到web层(甚至把它序列化到一个单独"
-"的层),保存在<literal>HttpSession</literal>中。"
+"此外,也请注意,你应该让与数据库连接断开的 <literal>Session</literal> 对持久"
+"层保持关闭状态。换句话说,在三层环境中,使用有状态的 EJB session bean 来持 有"
+"<literal>Session</literal>, 而不要把它传递到 web 层(甚至把它序列化到一个单"
+"独的层),保存在 <literal>HttpSession</literal> 中。 "
 
 #. Tag: para
-#: transactions.xml:777
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The extended session pattern, or <emphasis>session-per-conversation</"
 "emphasis>, is more difficult to implement with automatic current session "
@@ -1481,19 +1249,17 @@
 "<literal>CurrentSessionContext</literal> for this. See the Hibernate Wiki "
 "for examples."
 msgstr ""
-"扩展session模式,或者被称为<emphasis>每次对话一个session(session-per-"
-"conversation)</emphasis>, 在与自动管理当前session上下文联用的时候会更困难。你"
-"需要提供你自己的<literal>CurrentSessionContext</literal>实现。请参阅"
-"Hibernate Wiki以获得示例。"
+"扩展 session 模式,或者被称为<emphasis>每次对话一个session(session-per-"
+"conversation)</emphasis>,自动管理当前 session 上下文联用的时候会更困难。你"
+"需要提供你自己的 <literal>CurrentSessionContext</literal> 实现。请参阅 "
+"Hibernate Wiki 以获得示例。 "
 
 #. Tag: title
-#: transactions.xml:787
 #, no-c-format
 msgid "Detached objects and automatic versioning"
-msgstr "脱管对象(deatched object)和自动版本化"
+msgstr "脱管对象(deatched object)和自动版本化"
 
 #. Tag: para
-#: transactions.xml:789
 #, no-c-format
 msgid ""
 "Each interaction with the persistent store occurs in a new <literal>Session</"
@@ -1504,72 +1270,53 @@
 "<literal>Session.saveOrUpdate()</literal>, or <literal>Session.merge()</"
 "literal>."
 msgstr ""
-"这种方式下,与持久化存储的每次交互都发生在一个新的<literal>Session</literal>"
-"中。 然而,同一持久化对象实例可以在多次与数据库的交互中重用。应用程序操纵脱管"
-"对象实例 的状态,这个脱管对象实例最初是在另一个<literal>Session</literal> 中"
-"载入的,然后 调用 <literal>Session.update()</literal>,<literal>Session."
-"saveOrUpdate()</literal>, 或者 <literal>Session.merge()</literal> 来重新关联"
-"该对象实例。"
+"这种方式下,与持久化存储的每次交互都发生在一个新的 <literal>Session</"
+"literal> 中。然而,同一持久化对象实例可以在多次与数据库的交互中重用。应用程序"
+"操纵脱管对象实例 的状态,这个脱管对象实例最初是在另一个 <literal>Session</"
+"literal> 中载入的,然后调用 <literal>Session.update()</literal>,"
+"<literal>Session.saveOrUpdate()</literal>,或者  <literal>Session.merge()</"
+"literal> 来重新关联该对象实例。"
 
-#. Tag: programlisting
-#: transactions.xml:797
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[// foo is an instance loaded by a previous Session\n"
-"foo.setProperty(\"bar\");\n"
-"session = factory.openSession();\n"
-"Transaction t = session.beginTransaction();\n"
-"session.saveOrUpdate(foo); // Use merge() if \"foo\" might have been loaded "
-"already\n"
-"t.commit();\n"
-"session.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: transactions.xml:799
-#, fuzzy, no-c-format
-msgid ""
 "Again, Hibernate will check instance versions during flush, throwing an "
 "exception if conflicting updates occurred."
 msgstr ""
-"Hibernate会再一次在同步的时候检查对象实例的版本,如果发生更新冲突,就抛出异"
-"常。"
+"Hibernate 会再一次在同步的时候检查对象实例的版本,如果发生更新冲突,就抛出异"
+"常。 "
 
 #. Tag: para
-#: transactions.xml:804
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also call <literal>lock()</literal> instead of <literal>update()</"
 "literal>, and use <literal>LockMode.READ</literal> (performing a version "
 "check and bypassing all caches) if you are sure that the object has not been "
 "modified."
 msgstr ""
-"如果你确信对象没有被修改过,你也可以调用<literal>lock()</literal> 来设置 "
-"<literal>LockMode.READ</literal>(绕过所有的缓存,执行版本检查),从而取 代 "
-"<literal>update()</literal>操作。"
+"如果你确信对象没有被修改过,你也可以调用 <literal>lock()</literal> 来设置  "
+"<literal>LockMode.READ</literal>(绕过所有的缓存,执行版本检查),从而取代  "
+"<literal>update()</literal> 操作。 "
 
 #. Tag: title
-#: transactions.xml:813
 #, no-c-format
 msgid "Customizing automatic versioning"
 msgstr "定制自动版本化行为"
 
 #. Tag: para
-#: transactions.xml:815
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can disable Hibernate's automatic version increment for particular "
 "properties and collections by setting the <literal>optimistic-lock</literal> "
 "mapping attribute to <literal>false</literal>. Hibernate will then no longer "
 "increment versions if the property is dirty."
 msgstr ""
-"对于特定的属性和集合,通过为它们设置映射属性<literal>optimistic-lock</"
-"literal>的值 为<literal>false</literal>,来禁止Hibernate的版本自动增加。这样"
-"的话,如果该属性 脏数据,Hibernate将不再增加版本号。"
+"对于特定的属性和集合,通过为它们设置映射属性 <literal>optimistic-lock</"
+"literal> 的值为 <literal>false</literal>,来禁止 Hibernate 的版本自动增加。这"
+"样的话,如果该属性脏数据,Hibernate 将不再增加版本号。 "
 
 #. Tag: para
-#: transactions.xml:822
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Legacy database schemas are often static and cannot be modified. Or, other "
 "applications might access the same database and will not know how to handle "
@@ -1582,31 +1329,29 @@
 "long <literal>Session</literal> and not session-per-request-with-detached-"
 "objects)."
 msgstr ""
-"遗留系统的数据库Schema通常是静态的,不可修改的。或者,其他应用程序也可能访问"
-"同一数据 库,根本无法得知如何处理版本号,甚至时间戳。在以上的所有场景中,实现"
-"版本化不能依靠 数据库表的某个特定列。在<literal>&lt;class&gt;</literal>的映射"
-"中设置 <literal>optimistic-lock=\"all\"</literal>可以在没有版本或者时间戳属性"
-"映射的情况下实现 版本检查,此时Hibernate将比较一行记录的每个字段的状态。请注"
-"意,只有当Hibernate能够比 较新旧状态的情况下,这种方式才能生效,也就是说, 你"
-"必须使用单个长生命周期<literal>Session</literal>模式,而不能使用 session-per-"
-"request-with-detached-objects模式。"
+"遗留系统的数据库 Schema 通常是静态的,不可修改的。或者,其他应用程序也可能访"
+"问同一数据库,根本无法得知如何处理版本号,甚至时间戳。在以上的所有场景中,实"
+"现版本化不能依靠数据库表的某个特定列。在 <literal>&lt;class&gt;</literal> 的"
+"映射中设置  <literal>optimistic-lock=\"all\"</literal> 可以在没有版本或者时间"
+"戳属性映射的情况下实现版本检查,此时 Hibernate 将比较一行记录的每个字段的状"
+"态。请注意,只有当 Hibernate 能够比较新旧状态的情况下,这种方式才能生效,也就"
+"是说,你必须使用单个长生命周期 <literal>Session</literal> 模式,而不能使用 "
+"session-per-request-with-detached-objects 模式。 "
 
 #. Tag: para
-#: transactions.xml:834
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Concurrent modification can be permitted in instances where the changes that "
 "have been made do not overlap. If you set <literal>optimistic-lock=\"dirty"
 "\"</literal> when mapping the <literal>&lt;class&gt;</literal>, Hibernate "
 "will only compare dirty fields during flush."
 msgstr ""
-"有些情况下,只要更改不发生交错,并发修改也是允许的。当你在<literal>&lt;"
-"class&gt;</literal> 的映射中设置<literal>optimistic-lock=\"dirty\"</"
-"literal>,Hibernate在同步的时候将只比较有脏 数据的字段。"
+"有些情况下,只要更改不发生交错,并发修改也是允许的。当你在 <literal>&lt;"
+"class&gt;</literal> 的映射中设置 <literal>optimistic-lock=\"dirty\"</"
+"literal>,Hibernate 在同步的时候将只比较有脏数据的字段。 "
 
 #. Tag: para
-#: transactions.xml:840
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "In both cases, with dedicated version/timestamp columns or with a full/dirty "
 "field comparison, Hibernate uses a single <literal>UPDATE</literal> "
@@ -1622,25 +1367,23 @@
 "before updating the row."
 msgstr ""
 "在以上所有场景中,不管是专门设置一个版本/时间戳列,还是进行全部字段/脏数据字"
-"段比较, Hibernate都会针对每个实体对象发送一条<literal>UPDATE</literal>(带有"
-"相应的 <literal>WHERE</literal>语句 )的SQL语句来执行版本检查和数据更新。如果"
-"你对关联实体 设置级联关系使用传播性持久化(transitive persistence),那么"
-"Hibernate可能会执行不必 要的update语句。这通常不是个问题,但是数据库里面对"
-"<emphasis>on update</emphasis>点火 的触发器可能在脱管对象没有任何更改的情况下"
-"被触发。因此,你可以在 <literal>&lt;class&gt;</literal>的映射中,通过设置"
-"<literal>select-before-update=\"true\"</literal> 来定制这一行为,强制"
-"Hibernate <literal>SELECT</literal>这个对象实例,从而保证, 在更新记录之前,"
-"对象的确是被修改过。"
+"段比较,Hibernate 都会针对每个实体对象发送一条 <literal>UPDATE</literal>(带"
+"有相应的 <literal>WHERE</literal> 语句 )的 SQL 语句来执行版本检查和数据更"
+"新。如果你对关联实体 设置级联关系使用传播性持久化(transitive persistence),"
+"那么 Hibernate 可能会执行不必 要的update语句。这通常不是个问题,但是数据库里"
+"面对 <emphasis>on update</emphasis> 点火 的触发器可能在脱管对象没有任何更改的"
+"情况下被触发。因此,你可以在 <literal>&lt;class&gt;</literal> 的映射中,通过"
+"设置<literal>select-before-update=\"true\"</literal> 来定制这一行为,强制 "
+"Hibernate  <literal>SELECT</literal> 这个对象实例,从而保证,在更新记录之前,"
+"对象的确是被修改过。 "
 
 #. Tag: title
-#: transactions.xml:858
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Pessimistic locking"
-msgstr "悲观锁定(Pessimistic Locking)"
+msgstr "悲观锁定(Pessimistic Locking) "
 
 #. Tag: para
-#: transactions.xml:860
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is not intended that users spend much time worrying about locking "
 "strategies. It is usually enough to specify an isolation level for the JDBC "
@@ -1648,74 +1391,69 @@
 "advanced users may wish to obtain exclusive pessimistic locks or re-obtain "
 "locks at the start of a new transaction."
 msgstr ""
-"用户其实并不需要花很多精力去担心锁定策略的问题。通常情况下,只要为JDBC连接指"
-"定一下隔 离级别,然后让数据库去搞定一切就够了。然而,高级用户有时候希望进行一"
-"个排它的悲观锁定, 或者在一个新的事务启动的时候,重新进行锁定。"
+"用户其实并不需要花很多精力去担心锁定策略的问题。通常情况下,只要为 JDBC 连接"
+"指定一下隔离级别,然后让数据库去搞定一切就够了。然而,高级用户有时候希望进行"
+"一个排它的悲观锁定,或者在一个新的事务启动的时候,重新进行锁定。 "
 
 #. Tag: para
-#: transactions.xml:867
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate will always use the locking mechanism of the database; it never "
 "lock objects in memory."
-msgstr "Hibernate总是使用数据库的锁定机制,从不在内存中锁定对象!"
+msgstr "Hibernate 总是使用数据库的锁定机制,从不在内存中锁定对象。"
 
 #. Tag: para
-#: transactions.xml:872
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>LockMode</literal> class defines the different lock levels that "
 "can be acquired by Hibernate. A lock is obtained by the following mechanisms:"
 msgstr ""
-"类<literal>LockMode</literal> 定义了Hibernate所需的不同的锁定级别。一个锁定 "
-"可以通过以下的机制来设置:"
+"类 <literal>LockMode</literal> 定义了 Hibernate 所需的不同的锁定级别。一个锁"
+"定可以通过以下的机制来设置:"
 
 #. Tag: para
-#: transactions.xml:879
 #, no-c-format
 msgid ""
 "<literal>LockMode.WRITE</literal> is acquired automatically when Hibernate "
 "updates or inserts a row."
 msgstr ""
-"当Hibernate更新或者插入一行记录的时候,锁定级别自动设置为<literal>LockMode."
-"WRITE</literal>。"
+"当 Hibernate 更新或者插入一行记录的时候,锁定级别自动设置为 "
+"<literal>LockMode.WRITE</literal>。"
 
 #. Tag: para
-#: transactions.xml:885
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockMode.UPGRADE</literal> can be acquired upon explicit user "
 "request using <literal>SELECT ... FOR UPDATE</literal> on databases which "
 "support that syntax."
 msgstr ""
-"当用户显式的使用数据库支持的SQL格式<literal>SELECT ... FOR UPDATE</literal> "
-"发送SQL的时候,锁定级别设置为<literal>LockMode.UPGRADE</literal>"
+"当用户显式的使用数据库支持的 SQL 格式 <literal>SELECT ... FOR UPDATE</"
+"literal> 发送 SQL 的时候,锁定级别设置为 <literal>LockMode.UPGRADE</"
+"literal>。 "
 
 #. Tag: para
-#: transactions.xml:891
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockMode.UPGRADE_NOWAIT</literal> can be acquired upon explicit "
 "user request using a <literal>SELECT ... FOR UPDATE NOWAIT</literal> under "
 "Oracle."
 msgstr ""
-"当用户显式的使用Oracle数据库的SQL语句<literal>SELECT ... FOR UPDATE NOWAIT</"
-"literal> 的时候,锁定级别设置<literal>LockMode.UPGRADE_NOWAIT</literal>"
+"当用户显式的使用 Oracle 数据库的 SQL 语句 <literal>SELECT ... FOR UPDATE "
+"NOWAIT</literal> 的时候,锁定级别设置 <literal>LockMode.UPGRADE_NOWAIT</"
+"literal>。 "
 
 #. Tag: para
-#: transactions.xml:897
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>LockMode.READ</literal> is acquired automatically when Hibernate "
 "reads data under Repeatable Read or Serializable isolation level. It can be "
 "re-acquired by explicit user request."
 msgstr ""
-"当Hibernate在“可重复读”或者是“序列化”数据库隔离级别下读取数据的时候,锁定模"
-"式 自动设置为<literal>LockMode.READ</literal>。这种模式也可以通过用户显式指定"
-"进行设置。"
+"当 Hibernate 在“可重复读”或者是“序列化”数据库隔离级别下读取数据的时候,锁定模"
+"式自动设置为 <literal>LockMode.READ</literal>。这种模式也可以通过用户显式指定"
+"进行设置。 "
 
 #. Tag: para
-#: transactions.xml:904
 #, no-c-format
 msgid ""
 "<literal>LockMode.NONE</literal> represents the absence of a lock. All "
@@ -1724,41 +1462,37 @@
 "</literal> or <literal>saveOrUpdate()</literal> also start out in this lock "
 "mode."
 msgstr ""
-"<literal>LockMode.NONE</literal> 代表无需锁定。在<literal>Transaction</"
-"literal>结束时, 所有的对象都切换到该模式上来。与session相关联的对象通过调用"
-"<literal>update()</literal> 或者<literal>saveOrUpdate()</literal>脱离该模式。"
+"<literal>LockMode.NONE</literal> 代表无需锁定。在 <literal>Transaction</"
+"literal> 结束时, 所有的对象都切换到该模式上来。与 session 相关联的对象通过调"
+"用 <literal>update()</literal> 或者 <literal>saveOrUpdate()</literal> 脱离该"
+"模式。"
 
 #. Tag: para
-#: transactions.xml:913
 #, no-c-format
 msgid ""
 "The \"explicit user request\" is expressed in one of the following ways:"
-msgstr "\"显式的用户指定\"可以通过以下几种方式之一来表示:"
+msgstr "\"显式的用户指定\"可以通过以下几种方式之一来表示:"
 
 #. Tag: para
-#: transactions.xml:919
 #, no-c-format
 msgid ""
 "A call to <literal>Session.load()</literal>, specifying a <literal>LockMode</"
 "literal>."
 msgstr ""
-"调用 <literal>Session.load()</literal>的时候指定<literal>锁定模式(LockMode)</"
-"literal>。"
+"调用 <literal>Session.load()</literal> 的时候指定<literal>锁定模式"
+"(LockMode)</literal>。"
 
 #. Tag: para
-#: transactions.xml:924
 #, no-c-format
 msgid "A call to <literal>Session.lock()</literal>."
-msgstr "调用<literal>Session.lock()</literal>。"
+msgstr "调用 <literal>Session.lock()</literal>。"
 
 #. Tag: para
-#: transactions.xml:929
 #, no-c-format
 msgid "A call to <literal>Query.setLockMode()</literal>."
-msgstr "调用<literal>Query.setLockMode()</literal>。"
+msgstr "调用 <literal>Query.setLockMode()</literal>。"
 
 #. Tag: para
-#: transactions.xml:935
 #, no-c-format
 msgid ""
 "If <literal>Session.load()</literal> is called with <literal>UPGRADE</"
@@ -1769,16 +1503,15 @@
 "than the one requested, Hibernate calls <literal>lock()</literal> for that "
 "object."
 msgstr ""
-"如果在<literal>UPGRADE</literal>或者<literal>UPGRADE_NOWAIT</literal>锁定模式"
-"下调 用<literal>Session.load()</literal>,并且要读取的对象尚未被session载入"
-"过,那么对象 通过<literal>SELECT ... FOR UPDATE</literal>这样的SQL语句被载"
-"入。如果为一个对象调用 <literal>load()</literal>方法时,该对象已经在另一个较"
-"少限制的锁定模式下被载入了,那 么Hibernate就对该对象调用<literal>lock()</"
-"literal> 方法。"
+"如果在 <literal>UPGRADE</literal> 或者 <literal>UPGRADE_NOWAIT</literal> 锁定"
+"模式下调用 <literal>Session.load()</literal>,并且要读取的对象尚未被 session "
+"载入过,那么对象通过 <literal>SELECT ... FOR UPDATE</literal> 这样的 SQL 语句"
+"被载入。如果为一个对象调用  <literal>load()</literal> 方法时,该对象已经在另"
+"一个较少限制的锁定模式下被载入了,那么  Hibernate 就对该对象调用 "
+"<literal>lock()</literal> 方法。"
 
 #. Tag: para
-#: transactions.xml:944
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>Session.lock()</literal> performs a version number check if the "
 "specified lock mode is <literal>READ</literal>, <literal>UPGRADE</literal> "
@@ -1786,32 +1519,29 @@
 "literal> or <literal>UPGRADE_NOWAIT</literal>, <literal>SELECT ... FOR "
 "UPDATE</literal> is used."
 msgstr ""
-"如果指定的锁定模式是<literal>READ</literal>, <literal>UPGRADE</literal> 或 "
-"<literal>UPGRADE_NOWAIT</literal>,那么<literal>Session.lock()</literal>就 执"
-"行版本号检查。(在<literal>UPGRADE</literal> 或者<literal>UPGRADE_NOWAIT</"
-"literal> 锁定模式下,执行<literal>SELECT ... FOR UPDATE</literal>这样的SQL语"
-"句。)"
+"如果指定的锁定模式是 <literal>READ</literal>,<literal>UPGRADE</literal> 或  "
+"<literal>UPGRADE_NOWAIT</literal>,那么 <literal>Session.lock()</literal> 就"
+"执行版本号检查。(在 <literal>UPGRADE</literal> 或者 "
+"<literal>UPGRADE_NOWAIT</literal> 锁定模式下,执行 <literal>SELECT ... FOR "
+"UPDATE</literal>这样的SQL语句。)"
 
 #. Tag: para
-#: transactions.xml:951
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If the requested lock mode is not supported by the database, Hibernate uses "
 "an appropriate alternate mode instead of throwing an exception. This ensures "
 "that applications are portable."
 msgstr ""
-"如果数据库不支持用户设置的锁定模式,Hibernate将使用适当的替代模式(而不是扔出"
-"异常)。 这一点可以确保应用程序的可移植性。"
+"如果数据库不支持用户设置的锁定模式,Hibernate 将使用适当的替代模式(而不是扔"
+"出异常)。这一点可以确保应用程序的可移植性。 "
 
 #. Tag: title
-#: transactions.xml:960
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Connection release modes"
-msgstr "连接释放模式(Connection Release Modes)"
+msgstr "连接释放模式(Connection Release Modes) "
 
 #. Tag: para
-#: transactions.xml:962
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "One of the legacies of Hibernate 2.x JDBC connection management meant that a "
 "<literal>Session</literal> would obtain a connection when it was first "
@@ -1824,37 +1554,34 @@
 "by the enumerated values of <literal>org.hibernate.ConnectionReleaseMode</"
 "literal>:"
 msgstr ""
-"Hibernate关于JDBC连接管理的旧(2.x)行为是,<literal>Session</literal>在第一次"
-"需要的时候获取一个连接,在session关闭之前一直会持有这个连接。Hibernate引入了"
-"连接释放的概念,来告诉session如何处理它的JDBC连接。注意,下面的讨论只适用于采"
-"用配置<literal>ConnectionProvider</literal>来提供连接的情况,用户自己提供的连"
-"接与这里的讨论无关。通过<literal>org.hibernate.ConnectionReleaseMode</"
-"literal>的不同枚举值来使用不用的释放模式:"
+"Hibernate 关于 JDBC 连接管理的旧(2.x)行为是,<literal>Session</literal> 在"
+"第一次需要的时候获取一个连接,在 session 关闭之前一直会持有这个连接。"
+"Hibernate 引入了连接释放的概念,来告诉 session 如何处理它的 JDBC 连接。注意,"
+"下面的讨论只适用于采用配置 <literal>ConnectionProvider</literal> 来提供连接的"
+"情况,用户自己提供的连接与这里的讨论无关。通过 <literal>org.hibernate."
+"ConnectionReleaseMode</literal> 的不同枚举值来使用不用的释放模式:"
 
 #. Tag: para
-#: transactions.xml:976
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>ON_CLOSE</literal>: is the legacy behavior described above. The "
 "Hibernate session obtains a connection when it first needs to perform some "
 "JDBC access and maintains that connection until the session is closed."
 msgstr ""
-"<literal>ON_CLOSE</literal> - 基本上就是上面提到的老式行为。Hibernate session"
-"在第一次需要进行JDBC操作的时候获取连接,然后持有它,直到session关闭。"
+"<literal>ON_CLOSE</literal>:基本上就是上面提到的老式行为。Hibernate session "
+"在第一次需要进行 JDBC 操作的时候获取连接,然后持有它,直到 session 关闭。"
 
 #. Tag: para
-#: transactions.xml:983
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>AFTER_TRANSACTION</literal>: releases connections after a "
 "<literal>org.hibernate.Transaction</literal> has been completed."
 msgstr ""
-"<literal>AFTER_TRANSACTION</literal> - 在<literal>org.hibernate.Transaction</"
-"literal>结束后释放连接。"
+"<literal>AFTER_TRANSACTION</literal>:在 <literal>org.hibernate.Transaction</"
+"literal> 结束后释放连接。"
 
 #. Tag: para
-#: transactions.xml:989
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>AFTER_STATEMENT</literal> (also referred to as aggressive release): "
 "releases connections after every statement execution. This aggressive "
@@ -1862,24 +1589,22 @@
 "the given session. Currently the only situation where this occurs is through "
 "the use of <literal>org.hibernate.ScrollableResults</literal>."
 msgstr ""
-"<literal>AFTER_STATEMENT</literal> (也被称做积极释放) - 在每一条语句被执行后"
-"就释放连接。但假若语句留下了与session相关的资源,那就不会被释放。目前唯一的这"
-"种情形就是使用<literal>org.hibernate.ScrollableResults</literal>。"
+"<literal>AFTER_STATEMENT</literal>(也被称做积极释放):在每一条语句被执行后"
+"就释放连接。但假若语句留下了与 session 相关的资源,那就不会被释放。目前唯一的"
+"这种情形就是使用 <literal>org.hibernate.ScrollableResults</literal>。"
 
 #. Tag: para
-#: transactions.xml:999
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The configuration parameter <literal>hibernate.connection.release_mode</"
 "literal> is used to specify which release mode to use. The possible values "
 "are as follows:"
 msgstr ""
-"<literal>hibernate.connection.release_mode</literal>配置参数用来指定使用哪一"
-"种释放模式。可能的值有:"
+"<literal>hibernate.connection.release_mode</literal> 配置参数用来指定使用哪一"
+"种释放模式。可能的值有: "
 
 #. Tag: para
-#: transactions.xml:1006
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>auto</literal> (the default): this choice delegates to the release "
 "mode returned by the <literal>org.hibernate.transaction.TransactionFactory."
@@ -1889,26 +1614,24 @@
 "default behavior as failures due to the value of this setting tend to "
 "indicate bugs and/or invalid assumptions in user code."
 msgstr ""
-"<literal>auto</literal>(默认) - 这一选择把释放模式委派给<literal>org."
-"hibernate.transaction.TransactionFactory.getDefaultReleaseMode()</literal>æ–¹"
-"法。对JTATransactionFactory来说,它会返回ConnectionReleaseMode."
-"AFTER_STATEMENT;对JDBCTransactionFactory来说,则是ConnectionReleaseMode."
-"AFTER_TRANSACTION。很少需要修改这一默认行为,因为假若设置不当,就会带来bug,"
+"<literal>auto</literal>(默认):这一选择把释放模式委派给 <literal>org."
+"hibernate.transaction.TransactionFactory.getDefaultReleaseMode()</literal> æ–¹"
+"法。对 JTATransactionFactory 来说,它会返回 ConnectionReleaseMode."
+"AFTER_STATEMENT;对 JDBCTransactionFactory 来说,则是ConnectionReleaseMode."
+"AFTER_TRANSACTION。很少需要修改这一默认行为,因为假若设置不当,就会带来 bug,"
 "或者给用户代码带来误导。"
 
 #. Tag: para
-#: transactions.xml:1016
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>on_close</literal>: uses ConnectionReleaseMode.ON_CLOSE. This "
 "setting is left for backwards compatibility, but its use is discouraged."
 msgstr ""
-"<literal>on_close</literal> - 使用 ConnectionReleaseMode.ON_CLOSE. 这种方式是"
+"<literal>on_close</literal>:使用 ConnectionReleaseMode.ON_CLOSE。这种方式是"
 "为了向下兼容的,但是已经完全不被鼓励使用了。"
 
 #. Tag: para
-#: transactions.xml:1022
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>after_transaction</literal>: uses ConnectionReleaseMode."
 "AFTER_TRANSACTION. This setting should not be used in JTA environments. Also "
@@ -1916,14 +1639,13 @@
 "considered to be in auto-commit mode, connections will be released as if the "
 "release mode were AFTER_STATEMENT."
 msgstr ""
-"<literal>after_transaction</literal> - 使用ConnectionReleaseMode."
-"AFTER_TRANSACTION。这一设置不应该在JTA环境下使用。也要注意,使用"
-"ConnectionReleaseMode.AFTER_TRANSACTION的时候,假若session 处于auto-commit状"
-"态,连接会像AFTER_STATEMENT那样被释放。"
+"<literal>after_transaction</literal>:使用 ConnectionReleaseMode."
+"AFTER_TRANSACTION。这一设置不应该在 JTA 环境下使用。也要注意,使用 "
+"ConnectionReleaseMode.AFTER_TRANSACTION 的时候,假若session 处于 auto-commit "
+"状态,连接会像 AFTER_STATEMENT 那样被释放。"
 
 #. Tag: para
-#: transactions.xml:1030
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>after_statement</literal>: uses ConnectionReleaseMode."
 "AFTER_STATEMENT. Additionally, the configured <literal>ConnectionProvider</"
@@ -1935,11 +1657,281 @@
 "getConnection()</literal> or in auto-commit environments where it does not "
 "matter if we re-establish the same connection."
 msgstr ""
-"<literal>after_statement</literal> - 使用ConnectionReleaseMode."
-"AFTER_STATEMENT。除此之外,会查询配置的<literal>ConnectionProvider</"
-"literal>,是否它支持这一设置((<literal>supportsAggressiveRelease()</"
-"literal>))。假若不支持,释放模式会被设置为ConnectionReleaseMode."
-"AFTER_TRANSACTION。只有在你每次调用<literal>ConnectionProvider.getConnection"
-"()</literal>获取底层JDBC连接的时候,都可以确信获得同一个连接的时候,这一设置"
-"才是安全的;或者在auto-commit环境中,你可以不管是否每次都获得同一个连接的时"
-"候,这才是安全的。"
+"<literal>after_statement</literal>:使用 ConnectionReleaseMode."
+"AFTER_STATEMENT。除此之外,会查询配置的 <literal>ConnectionProvider</"
+"literal>,是否它支持这一设置(<literal>supportsAggressiveRelease()</"
+"literal>)。假若不支持,释放模式会被设置为  ConnectionReleaseMode."
+"AFTER_TRANSACTION。只有在你每次调用  <literal>ConnectionProvider."
+"getConnection()</literal> 获取底层 JDBC 连接的时候,都可以确信获得同一个连接"
+"的时候,这一设置才是安全的;或者在 auto-commit 环境中,你可以不管是否每次都获"
+"得同一个连接的时候,这才是安全的。"
+
+#~ msgid "foo==bar"
+#~ msgstr "foo==bar"
+
+#~ msgid ""
+#~ "<![CDATA[// Non-managed environment idiom\n"
+#~ "Session sess = factory.openSession();\n"
+#~ "Transaction tx = null;\n"
+#~ "try {\n"
+#~ "    tx = sess.beginTransaction();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    tx.commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    if (tx != null) tx.rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}\n"
+#~ "finally {\n"
+#~ "    sess.close();\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[// Non-managed environment idiom\n"
+#~ "Session sess = factory.openSession();\n"
+#~ "Transaction tx = null;\n"
+#~ "try {\n"
+#~ "    tx = sess.beginTransaction();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    tx.commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    if (tx != null) tx.rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}\n"
+#~ "finally {\n"
+#~ "    sess.close();\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[// Non-managed environment idiom with getCurrentSession()\n"
+#~ "try {\n"
+#~ "    factory.getCurrentSession().beginTransaction();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    factory.getCurrentSession().getTransaction().commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    factory.getCurrentSession().getTransaction().rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[// Non-managed environment idiom with getCurrentSession()\n"
+#~ "try {\n"
+#~ "    factory.getCurrentSession().beginTransaction();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    factory.getCurrentSession().getTransaction().commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    factory.getCurrentSession().getTransaction().rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[// BMT idiom\n"
+#~ "Session sess = factory.openSession();\n"
+#~ "Transaction tx = null;\n"
+#~ "try {\n"
+#~ "    tx = sess.beginTransaction();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    tx.commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    if (tx != null) tx.rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}\n"
+#~ "finally {\n"
+#~ "    sess.close();\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[// BMT idiom\n"
+#~ "Session sess = factory.openSession();\n"
+#~ "Transaction tx = null;\n"
+#~ "try {\n"
+#~ "    tx = sess.beginTransaction();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    tx.commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    if (tx != null) tx.rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}\n"
+#~ "finally {\n"
+#~ "    sess.close();\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[// BMT idiom with getCurrentSession()\n"
+#~ "try {\n"
+#~ "    UserTransaction tx = (UserTransaction)new InitialContext()\n"
+#~ "                            .lookup(\"java:comp/UserTransaction\");\n"
+#~ "\n"
+#~ "    tx.begin();\n"
+#~ "\n"
+#~ "    // Do some work on Session bound to transaction\n"
+#~ "    factory.getCurrentSession().load(...);\n"
+#~ "    factory.getCurrentSession().persist(...);\n"
+#~ "\n"
+#~ "    tx.commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    tx.rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[// BMT idiom with getCurrentSession()\n"
+#~ "try {\n"
+#~ "    UserTransaction tx = (UserTransaction)new InitialContext()\n"
+#~ "                            .lookup(\"java:comp/UserTransaction\");\n"
+#~ "\n"
+#~ "    tx.begin();\n"
+#~ "\n"
+#~ "    // Do some work on Session bound to transaction\n"
+#~ "    factory.getCurrentSession().load(...);\n"
+#~ "    factory.getCurrentSession().persist(...);\n"
+#~ "\n"
+#~ "    tx.commit();\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    tx.rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[// CMT idiom\n"
+#~ " Session sess = factory.getCurrentSession();\n"
+#~ "\n"
+#~ " // do some work\n"
+#~ " ...\n"
+#~ "]]>"
+#~ msgstr ""
+#~ "<![CDATA[// CMT idiom\n"
+#~ " Session sess = factory.getCurrentSession();\n"
+#~ "\n"
+#~ " // do some work\n"
+#~ " ...\n"
+#~ "]]>"
+
+#~ msgid ""
+#~ "<![CDATA[\n"
+#~ "Session sess = factory.openSession();\n"
+#~ "try {\n"
+#~ "    //set transaction timeout to 3 seconds\n"
+#~ "    sess.getTransaction().setTimeout(3);\n"
+#~ "    sess.getTransaction().begin();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    sess.getTransaction().commit()\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    sess.getTransaction().rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}\n"
+#~ "finally {\n"
+#~ "    sess.close();\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[\n"
+#~ "Session sess = factory.openSession();\n"
+#~ "try {\n"
+#~ "    //set transaction timeout to 3 seconds\n"
+#~ "    sess.getTransaction().setTimeout(3);\n"
+#~ "    sess.getTransaction().begin();\n"
+#~ "\n"
+#~ "    // do some work\n"
+#~ "    ...\n"
+#~ "\n"
+#~ "    sess.getTransaction().commit()\n"
+#~ "}\n"
+#~ "catch (RuntimeException e) {\n"
+#~ "    sess.getTransaction().rollback();\n"
+#~ "    throw e; // or display error message\n"
+#~ "}\n"
+#~ "finally {\n"
+#~ "    sess.close();\n"
+#~ "}]]>"
+
+#~ msgid ""
+#~ "<![CDATA[// foo is an instance loaded by a previous Session\n"
+#~ "session = factory.openSession();\n"
+#~ "Transaction t = session.beginTransaction();\n"
+#~ "\n"
+#~ "int oldVersion = foo.getVersion();\n"
+#~ "session.load( foo, foo.getKey() ); // load the current state\n"
+#~ "if ( oldVersion != foo.getVersion() ) throw new StaleObjectStateException"
+#~ "();\n"
+#~ "foo.setProperty(\"bar\");\n"
+#~ "\n"
+#~ "t.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[// foo is an instance loaded by a previous Session\n"
+#~ "session = factory.openSession();\n"
+#~ "Transaction t = session.beginTransaction();\n"
+#~ "\n"
+#~ "int oldVersion = foo.getVersion();\n"
+#~ "session.load( foo, foo.getKey() ); // load the current state\n"
+#~ "if ( oldVersion != foo.getVersion() ) throw new StaleObjectStateException"
+#~ "();\n"
+#~ "foo.setProperty(\"bar\");\n"
+#~ "\n"
+#~ "t.commit();\n"
+#~ "session.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[// foo is an instance loaded earlier by the old session\n"
+#~ "Transaction t = session.beginTransaction(); // Obtain a new JDBC "
+#~ "connection, start transaction\n"
+#~ "\n"
+#~ "foo.setProperty(\"bar\");\n"
+#~ "\n"
+#~ "session.flush();    // Only for last transaction in conversation\n"
+#~ "t.commit();         // Also return JDBC connection\n"
+#~ "session.close();    // Only for last transaction in conversation]]>"
+#~ msgstr ""
+#~ "<![CDATA[// foo is an instance loaded earlier by the old session\n"
+#~ "Transaction t = session.beginTransaction(); // Obtain a new JDBC "
+#~ "connection, start transaction\n"
+#~ "\n"
+#~ "foo.setProperty(\"bar\");\n"
+#~ "\n"
+#~ "session.flush();    // Only for last transaction in conversation\n"
+#~ "t.commit();         // Also return JDBC connection\n"
+#~ "session.close();    // Only for last transaction in conversation]]>"
+
+#~ msgid ""
+#~ "<![CDATA[// foo is an instance loaded by a previous Session\n"
+#~ "foo.setProperty(\"bar\");\n"
+#~ "session = factory.openSession();\n"
+#~ "Transaction t = session.beginTransaction();\n"
+#~ "session.saveOrUpdate(foo); // Use merge() if \"foo\" might have been "
+#~ "loaded already\n"
+#~ "t.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[// foo is an instance loaded by a previous Session\n"
+#~ "foo.setProperty(\"bar\");\n"
+#~ "session = factory.openSession();\n"
+#~ "Transaction t = session.beginTransaction();\n"
+#~ "session.saveOrUpdate(foo); // Use merge() if \"foo\" might have been "
+#~ "loaded already\n"
+#~ "t.commit();\n"
+#~ "session.close();]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/tutorial.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/tutorial.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/tutorial.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,23 +1,26 @@
+# translation of tutorial.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007, 2009.
+# translation of Collection_Mapping.po to
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: tutorial\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-11T05:38:16\n"
+"PO-Revision-Date: 2010-01-11 10:56+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: tutorial.xml:31
 #, no-c-format
 msgid "Tutorial"
-msgstr ""
+msgstr "教程"
 
 #. Tag: para
-#: tutorial.xml:33
 #, no-c-format
 msgid ""
 "Intended for new users, this chapter provides an step-by-step introduction "
@@ -26,43 +29,44 @@
 "Gloegl. All code is contained in the <filename>tutorials/web</filename> "
 "directory of the project source."
 msgstr ""
+"面向新用户,从一个简单的使用内存数据库的例子开始,本章提供对 Hibernate 的逐步"
+"介绍。本教程基于 Michael Gloegl 早期编写的手册。所有代码都包含在 "
+"<filename>tutorials/web</filename> 目录下。"
 
 #. Tag: para
-#: tutorial.xml:42
 #, no-c-format
 msgid ""
 "This tutorial expects the user have knowledge of both Java and SQL. If you "
 "have a limited knowledge of JAVA or SQL, it is advised that you start with a "
 "good introduction to that technology prior to attempting to learn Hibernate."
 msgstr ""
+"本教程期望用户具备 Java 和 SQL 知识。如果你这方面的知识有限,我们建议你在学"
+"习 Hibernate 之前先好好了解这些技术。"
 
 #. Tag: para
-#: tutorial.xml:51
 #, no-c-format
 msgid ""
 "The distribution contains another example application under the "
 "<filename>tutorial/eg</filename> project source directory."
 msgstr ""
+"本版本在源代码目录 <filename>tutorial/eg</filename> 下还包含另外一个例程。"
 
 #. Tag: title
-#: tutorial.xml:59
 #, no-c-format
 msgid "Part 1 - The first Hibernate Application"
-msgstr "第一部分 - 第一个Hibernate应用程序"
+msgstr "第一部分 - 第一个 Hibernate 应用程序"
 
 #. Tag: para
-#: tutorial.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For this example, we will set up a small database application that can store "
 "events we want to attend and information about the host(s) of these events."
 msgstr ""
-"假设我们希望有一个小应用程序可以保存我们希望参加的活动(events)和这些活动主"
-"办方的相关信息。 (译者注:在本教程的后面部分,我们将直接使用event而不是它的"
-"中文翻译“活动”,以免混淆。)"
+"在这个例子里,我们将设立一个小应用程序可以保存我们希望参加的活动(events)和"
+"这些活动主办方的相关信息。(译者注:在本教程的后面部分,我们将直接使用 event "
+"而不是它的中文翻译“活动”,以免混淆。)"
 
 #. Tag: para
-#: tutorial.xml:67
 #, no-c-format
 msgid ""
 "Although you can use whatever database you feel comfortable using, we will "
@@ -70,15 +74,16 @@
 "database) to avoid describing installation/setup of any particular database "
 "servers."
 msgstr ""
+"虽然你可以使用任何数据库,我们还是用 <ulink url=\"http://hsqldb.org/"
+"\">HSQLDB</ulink>(一个用 Java 编写的内存数据库)来避免花费篇章对数据库服务器"
+"的安装/配置进行解释。"
 
 #. Tag: title
-#: tutorial.xml:76
 #, no-c-format
 msgid "Setup"
-msgstr ""
+msgstr "设置"
 
 #. Tag: para
-#: tutorial.xml:78
 #, no-c-format
 msgid ""
 "The first thing we need to do is to set up the development environment. We "
@@ -90,72 +95,26 @@
 "making use of <filename>src/main/java</filename>, <filename>src/main/"
 "resources</filename> and <filename>src/main/webapp</filename> directories."
 msgstr ""
+"我们需要做的第一件事情是设置开发环境。我们将使用许多构建工具如 <ulink url="
+"\"http://maven.org\">Maven</ulink> 所鼓吹的“标准格式”。特别是 Maven,它的资源"
+"对这个<ulink url=\"http://maven.apache.org/guides/introduction/introduction-"
+"to-the-standard-directory-layout.html\">格式(layout)</ulink>有着很好的描"
+"述。因为本教程使用的是 web 应用程序,我么将创建和使用 <filename>src/main/"
+"java</filename>、<filename>src/main/resources</filename> 和 <filename>src/"
+"main/webapp</filename> 目录。"
 
 #. Tag: para
-#: tutorial.xml:88
 #, no-c-format
 msgid ""
 "We will be using Maven in this tutorial, taking advantage of its transitive "
 "dependency management capabilities as well as the ability of many IDEs to "
 "automatically set up a project for us based on the maven descriptor."
 msgstr ""
+"在本教程里我们将使用 Maven,利用其 transitive dependency 管理以及根据 Maven "
+"描述符用 IDE 自动设置项目的能力。"
 
-#. Tag: programlisting
-#: tutorial.xml:94
-#, no-c-format
-msgid ""
-"<![CDATA[<project xmlns=\"http://maven.apache.org/POM/4.0.0\"\n"
-"         xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
-"         xsi:schemaLocation=\"http://maven.apache.org/POM/4.0.0 http://maven."
-"apache.org/xsd/maven-4.0.0.xsd\">\n"
-"\n"
-"    <modelVersion>4.0.0</modelVersion>\n"
-"\n"
-"    <groupId>org.hibernate.tutorials</groupId>\n"
-"    <artifactId>hibernate-tutorial</artifactId>\n"
-"    <version>1.0.0-SNAPSHOT</version>\n"
-"    <name>First Hibernate Tutorial</name>\n"
-"\n"
-"    <build>\n"
-"         <!-- we dont want the version to be part of the generated war file "
-"name -->\n"
-"         <finalName>${artifactId}</finalName>\n"
-"    </build>\n"
-"\n"
-"    <dependencies>\n"
-"        <dependency>\n"
-"            <groupId>org.hibernate</groupId>\n"
-"            <artifactId>hibernate-core</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Because this is a web app, we also have a dependency on the "
-"servlet api. -->\n"
-"        <dependency>\n"
-"            <groupId>javax.servlet</groupId>\n"
-"            <artifactId>servlet-api</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Hibernate uses slf4j for logging, for our purposes here use the "
-"simple backend -->\n"
-"        <dependency>\n"
-"            <groupId>org.slf4j</groupId>\n"
-"            <artifactId>slf4j-simple</artifactId>\n"
-"        </dependency>\n"
-"\n"
-"        <!-- Hibernate gives you a choice of bytecode providers between "
-"cglib and javassist -->\n"
-"        <dependency>\n"
-"            <groupId>javassist</groupId>\n"
-"            <artifactId>javassist</artifactId>\n"
-"        </dependency>\n"
-"    </dependencies>\n"
-"\n"
-"</project>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:97
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "It is not a requirement to use Maven. If you wish to use something else to "
 "build this tutoial (such as Ant), the layout will remain the same. The only "
@@ -171,73 +130,38 @@
 "javassist</filename> directory; additionally you will need both the servlet-"
 "api jar and one of the slf4j logging backends."
 msgstr ""
+"Maven 并不要求这样。如果你希望使用其他技术来构建这个教程(如 Ant),格式将保"
+"持不变。唯一的改变是你将需要手工管理所有的依赖关系。如果你使用 <ulink url="
+"\"http://ant.apache.org/ivy/\">Ivy</ulink> 来提供 transitive dependency 管"
+"理,你将仍然下面提到的依赖关系。否则,你将需要找到所有的依赖关系(显性的和过"
+"渡的)并把它们添加到项目的 classpath 里。如果使用 Hibernate 捆绑版本,这意味"
+"着 <filename>hibernate3.jar</filename>、<filename>lib/required</filename> 目"
+"录下的所有 artifact 和 <filename>lib/bytecode/cglib</filename> 或 "
+"<filename>lib/bytecode/javassist</filename> 下的所有文件,此外你将需要 "
+"servlet-api jar 和一个 slf4j 日志后台文件。 "
 
 #. Tag: para
-#: tutorial.xml:114
 #, no-c-format
 msgid ""
 "Save this file as <filename>pom.xml</filename> in the project root directory."
-msgstr ""
+msgstr "把这个文件保存为项目根目录下的 <filename>pom.xml</filename>。"
 
 #. Tag: title
-#: tutorial.xml:121
 #, no-c-format
 msgid "The first class"
-msgstr "第一个class"
+msgstr "第一个 class"
 
 #. Tag: para
-#: tutorial.xml:123
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next, we create a class that represents the event we want to store in the "
 "database; it is a simple JavaBean class with some properties:"
-msgstr "接下来我们创建一个类,用来代表那些我们希望储存在数据库里的event。"
-
-#. Tag: programlisting
-#: tutorial.xml:128
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.domain;\n"
-"\n"
-"import java.util.Date;\n"
-"\n"
-"public class Event {\n"
-"    private Long id;\n"
-"\n"
-"    private String title;\n"
-"    private Date date;\n"
-"\n"
-"    public Event() {}\n"
-"\n"
-"    public Long getId() {\n"
-"        return id;\n"
-"    }\n"
-"\n"
-"    private void setId(Long id) {\n"
-"        this.id = id;\n"
-"    }\n"
-"\n"
-"    public Date getDate() {\n"
-"        return date;\n"
-"    }\n"
-"\n"
-"    public void setDate(Date date) {\n"
-"        this.date = date;\n"
-"    }\n"
-"\n"
-"    public String getTitle() {\n"
-"        return title;\n"
-"    }\n"
-"\n"
-"    public void setTitle(String title) {\n"
-"        this.title = title;\n"
-"    }\n"
-"}]]>"
 msgstr ""
+"接下来我们创建一个类,用来代表那些我们希望储存在数据库里的 event,这是一个具"
+"有一些属性的简单 JavaBean 类:"
 
 #. Tag: para
-#: tutorial.xml:130
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This class uses standard JavaBean naming conventions for property getter and "
 "setter methods, as well as private visibility for the fields. Although this "
@@ -245,16 +169,13 @@
 "fields directly, the benefit of accessor methods is robustness for "
 "refactoring."
 msgstr ""
-"你可以看到这个类对属性的存取方法(getter and setter method)使用了标准"
-"JavaBean命名约定,同时把类属性(field)的访问级别设成私有的(private)。这是"
-"推荐的设计,但并不是必须的。Hibernate也可以直接访问这些field,而使用访问方法"
-"(accessor method)的好处是提供了重构时的健壮性(robustness)。为了通过反射机"
-"制(Reflection)来实例化这个类的对象,我们需要提供一个无参的构造器(no-"
-"argument constructor)。"
+"你可以看到这个类对属性的存取方法(getter and setter method)使用了标准 "
+"JavaBean 命名约定,同时把类属性(field)的访问级别设成私有的(private)。这是"
+"推荐的设计,但并不是必须的。Hibernate 也可以直接访问这些 field,而使用访问方"
+"法(accessor method)的好处是提供了重构时的健壮性(robustness)。"
 
 #. Tag: para
-#: tutorial.xml:138
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>id</literal> property holds a unique identifier value for a "
 "particular event. All persistent entity classes (there are less important "
@@ -268,19 +189,18 @@
 "as well as public, private and protected fields directly. The choice is up "
 "to you and you can match it to fit your application design."
 msgstr ""
-"对一特定的event, <literal>id</literal> 属性持有唯一的标识符(identifier)的"
-"值。如果我们希望使用Hibernate提供的所有特性,那么所有的持久化实体"
+"对一特定的 event, <literal>id</literal> 属性持有唯一的标识符(identifier)的"
+"值。如果我们希望使用 Hibernate 提供的所有特性,那么所有的持久化实体"
 "(persistent entity)类(这里也包括一些次要依赖类)都需要一个这样的标识符属"
-"性。而事实上,大多数应用程序(特别是web应用程序)都需要通过标识符来区别对象,"
-"所以你应该考虑使用标识符属性而不是把它当作一种限制。然而,我们通常不会操作对"
-"象的标识(identity),因此它的setter方法的访问级别应该声明private。这样当对象"
-"被保存的时候,只有Hibernate可以为它分配标识符值。你可看到Hibernate可以直接访"
-"问public,private和protected的访问方法和field。所以选择哪种方式完全取决于你,"
-"你可以使你的选择与你的应用程序设计相吻合。"
+"性。而事实上,大多数应用程序(特别是 web 应用程序)都需要通过标识符来区别对"
+"象,所以你应该考虑使用标识符属性而不是把它当作一种限制。然而,我们通常不会操"
+"作对象的标识(identity),因此它的 setter 方法的访问级别应该声明 private。这"
+"样当对象被保存的时候,只有 Hibernate 可以为它分配标识符值。你可看到Hibernate"
+"可以直接访问 public,private 和 protected 的访问方法和 field。所以选择哪种方"
+"式完全取决于你,你可以使你的选择与你的应用程序设计相吻合。 "
 
 #. Tag: para
-#: tutorial.xml:153
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The no-argument constructor is a requirement for all persistent classes; "
 "Hibernate has to create objects for you, using Java Reflection. The "
@@ -288,28 +208,27 @@
 "for runtime proxy generation and efficient data retrieval without bytecode "
 "instrumentation."
 msgstr ""
-"所有的持久化类(persistent classes)都要求有无参的构造器,因为Hibernate必须使"
-"用Java反射机制来为你创建对象。构造器(constructor)的访问级别可以是private,"
-"然而当生成运行时代理(runtime proxy)的时候则要求使用至少是package 级别的访问"
-"控制,这样在没有字节码指令(bytecode instrumentation)的情况下,从持久化类里"
-"获取数据会更有效率。"
+"所有的持久化类(persistent classes)都要求有无参的构造器,因为 Hibernate 必须"
+"使用 Java 反射机制来为你创建对象。构造器(constructor)的访问级别可以是 "
+"private,然而当生成运行时代理(runtime proxy)的时候则要求使用至少是 package "
+"级别的访问控制,这样在没有字节码指令(bytecode instrumentation)的情况下,从"
+"持久化类里获取数据会更有效率。 "
 
 #. Tag: para
-#: tutorial.xml:161
 #, no-c-format
 msgid ""
 "Save this file to the <filename>src/main/java/org/hibernate/tutorial/domain</"
 "filename> directory."
 msgstr ""
+"把这个文件保存到 <filename>src/main/java/org/hibernate/tutorial/domain</"
+"filename> 目录下。"
 
 #. Tag: title
-#: tutorial.xml:168
 #, no-c-format
 msgid "The mapping file"
 msgstr "映射文件"
 
 #. Tag: para
-#: tutorial.xml:170
 #, no-c-format
 msgid ""
 "Hibernate needs to know how to load and store objects of the persistent "
@@ -317,34 +236,18 @@
 "file tells Hibernate what table in the database it has to access, and what "
 "columns in that table it should use."
 msgstr ""
-"Hibernate需要知道怎样去加载(load)和存储(store)持久化类的对象。这正是"
-"Hibernate映射文件发挥作用的地方。映射文件告诉Hibernate它,应该访问数据库"
-"(database)里面的哪个表(table)及应该使用表里面的哪些字段(column)。"
+"Hibernate 需要知道怎样去加载(load)和存储(store)持久化类的对象。这正是 "
+"Hibernate 映射文件发挥作用的地方。映射文件告诉 Hibernate 它应该访问数据库"
+"(database)里面的哪个表(table)及应该使用表里面的哪些字段(column)。"
 
 #. Tag: para
-#: tutorial.xml:178
 #, no-c-format
 msgid "The basic structure of a mapping file looks like this:"
 msgstr "一个映射文件的基本结构看起来像这样:"
 
-#. Tag: programlisting
-#: tutorial.xml:182
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\"?>\n"
-"<!DOCTYPE hibernate-mapping PUBLIC\n"
-"        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
-"\n"
-"<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"[...]\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:184
-#, fuzzy, no-c-format
-msgid ""
 "Hibernate DTD is sophisticated. You can use it for auto-completion of XML "
 "mapping elements and attributes in your editor or IDE. Opening up the DTD "
 "file in your text editor is the easiest way to get an overview of all "
@@ -354,54 +257,38 @@
 "<filename>hibernate-core.jar</filename> (it is also included in the "
 "<filename>hibernate3.jar</filename>, if using the distribution bundle)."
 msgstr ""
-"注意Hibernate的DTD是非常复杂的。你的编辑器或者IDE里使用它来自动完成那些用来映"
-"射的XML元素(element)和属性(attribute)。你也可以在文本编辑器里打开DTD-这"
-"是最简单的方式来概览所有的元素和attribute,并查看它们的缺省值以及注释。注意"
-"Hibernate不会从web加载DTD文件,但它会首先在应用程序的classpath中查找。DTD文件"
-"已包括在<literal>hibernate3.jar</literal>里,同时也在Hibernate发布包的"
-"<literal>src/</literal>目录下。"
+"注意 Hibernate 的 DTD 是非常复杂的。你的编辑器或者 IDE 里使用它来自动完成那些"
+"用来映射的 XML 元素(element)和属性(attribute)。你也可以在文本编辑器里打"
+"开 DTD — 这是最简单的方式来概览所有的元素和 attribute,并查看它们的缺省值以及"
+"注释。注意 Hibernate 不会从 web 加载 DTD 文件,但它会首先在应用程序的 "
+"classpath 中查找。DTD 文件已包括在 <literal>hibernate3.jar</literal> 里,同时"
+"也在 Hibernate 发布包的 <literal>src/</literal> 目录下。 "
 
 #. Tag: para
-#: tutorial.xml:197
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will omit the DTD declaration in future examples to shorten the code. It "
 "is, of course, not optional."
 msgstr ""
-"为缩短代码长度,在以后的例子里我们会省略DTD的声明。当然,在实际的应用程序中,"
-"DTD声明是必须的。"
+"为缩短代码长度,在以后的例子里我们会省略 DTD 的声明。当然,在实际的应用程序"
+"中,DTD 声明是必需的。 "
 
 #. Tag: para
-#: tutorial.xml:203
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Between the two <literal>hibernate-mapping</literal> tags, include a "
 "<literal>class</literal> element. All persistent entity classes (again, "
 "there might be dependent classes later on, which are not first-class "
 "entities) need a mapping to a table in the SQL database:"
 msgstr ""
-"在<literal>hibernate-mapping</literal>标签(tag)之间, 含有一个"
-"<literal>class</literal>元素。所有的持久化实体类(再次声明,或许接下来会有依"
-"赖类,就是那些次要的实体)都需要一个这样的映射,来把类对象映射到SQL数据库里的"
-"表。"
+"在 <literal>hibernate-mapping</literal> 标签(tag)之间, 含有一个 "
+"<literal>class</literal> 元素。所有的持久化实体类(再次声明,或许接下来会有依"
+"赖类,就是那些次要的实体)都需要一个这样的映射,来把类对象映射到 SQL 数据库里"
+"的表:"
 
-#. Tag: programlisting
-#: tutorial.xml:210
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:212
-#, fuzzy, no-c-format
-msgid ""
 "So far we have told Hibernate how to persist and load object of class "
 "<literal>Event</literal> to the table <literal>EVENTS</literal>. Each "
 "instance is now represented by a row in that table. Now we can continue by "
@@ -409,29 +296,14 @@
 "not want to care about handling this identifier, we configure Hibernate's "
 "identifier generation strategy for a surrogate primary key column:"
 msgstr ""
-"到目前为止,我们告诉了Hibernate怎样把<literal>Events</literal>类的对象持久化"
-"到数据库的<literal>EVENTS</literal>表里,以及怎样从<literal>EVENTS</literal>"
-"表加载到<literal>Events</literal>类的对象。每个实例对应着数据库表中的一行。现"
-"在我们将继续讨论有关唯一标识符属性到数据库表的映射。另外,由于我们不关心怎样"
-"处理这个标识符,我们就配置由Hibernate的标识符生成策略来产生代理主键字段。"
+"到目前为止,我们告诉了 Hibernate 怎样把 <literal>Events</literal> 类的对象持"
+"久化到数据库的 <literal>EVENTS</literal> 表里,以及怎样从 <literal>EVENTS</"
+"literal> 表加载到 <literal>Events</literal> 类的对象。每个实例对应着数据库表"
+"中的一行。现在我们将继续讨论有关唯一标识符属性到数据库表的映射。另外,由于我"
+"们不关心怎样处理这个标识符,我们就配置由 Hibernate 的标识符生成策略来产生代理"
+"主键字段:"
 
-#. Tag: programlisting
-#: tutorial.xml:222
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"        <id name=\"id\" column=\"EVENT_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:224
 #, no-c-format
 msgid ""
 "The <literal>id</literal> element is the declaration of the identifier "
@@ -441,9 +313,12 @@
 "The column attribute tells Hibernate which column of the <literal>EVENTS</"
 "literal> table holds the primary key value."
 msgstr ""
+"<literal>id</literal> 元素是对 identifier 属性的声明。<literal>name=\"id\"</"
+"literal> 映射属性声明了 JavaBean 属性的名称并告诉 Hibernate 使用 "
+"<literal>getId()</literal> 和 <literal>setId()</literal> 方法来访问这个属性。"
+"column 属性告诉 Hibernate  <literal>EVENTS</literal> 表的哪个字段持有主键值。"
 
 #. Tag: para
-#: tutorial.xml:234
 #, no-c-format
 msgid ""
 "The nested <literal>generator</literal> element specifies the identifier "
@@ -454,61 +329,48 @@
 "Identifier value generation is also one of Hibernate's many extension points "
 "and you can plugin in your own strategy."
 msgstr ""
+"嵌套的 <literal>generator</literal> 元素指定标识符的生成策略(也就是标识符值"
+"是怎么产生的)。在这个例子里,我们选择 <literal>native</literal>,它提供了取"
+"决于数据库方言的可移植性。Hibernate 数据库生成的、全局性唯一的以及应用程序分"
+"配的标识符。标识符值的生成也是 Hibernate 的扩展功能之一,你可以插入自己的策"
+"略。"
 
 #. Tag: para
-#: tutorial.xml:246
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "<literal>native</literal> is no longer consider the best strategy in terms "
-"of portability. for further discussion, see"
+"of portability. for further discussion, see <xref linkend=\"portability-idgen"
+"\" />"
 msgstr ""
+"从移植性来说,<literal>native</literal> 不再被认为是最好的策略。进一步的讨"
+"论,请参考 <xref linkend=\"portability-idgen\" />。"
 
 #. Tag: para
-#: tutorial.xml:252
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Lastly, we need to tell Hibernate about the remaining entity class "
 "properties. By default, no properties of the class are considered persistent:"
 msgstr ""
 "最后我们在映射文件里面包含需要持久化属性的声明。默认情况下,类里面的属性都被"
-"视为非持久化的:"
+"视为非持久化的: "
 
-#. Tag: programlisting
-#: tutorial.xml:258
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Event\" table=\"EVENTS\">\n"
-"        <id name=\"id\" column=\"EVENT_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"date\" type=\"timestamp\" column=\"EVENT_DATE\"/>\n"
-"        <property name=\"title\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:260
-#, fuzzy, no-c-format
-msgid ""
 "Similar to the <literal>id</literal> element, the <literal>name</literal> "
 "attribute of the <literal>property</literal> element tells Hibernate which "
 "getter and setter methods to use. In this case, Hibernate will search for "
 "<literal>getDate()</literal>, <literal>setDate()</literal>, <literal>getTitle"
 "()</literal> and <literal>setTitle()</literal> methods."
 msgstr ""
-"和<literal>id</literal>元素一样,<literal>property</literal>元素的"
-"<literal>name</literal>属性告诉Hibernate使用哪个getter和setter方法。在此例"
-"中,Hibernate会寻找<literal>getDate()/setDate()</literal>, 以及"
-"<literal>getTitle()/setTitle()</literal>。"
+"和 <literal>id</literal> 元素一样,<literal>property</literal> 元素的 "
+"<literal>name</literal> 属性告诉 Hibernate 使用哪个 getter 和 setter 方法。在"
+"此例中,Hibernate 会寻找 <literal>getDate()</literal>、<literal>setDate()</"
+"literal>、<literal>getTitle()</literal> 和 <literal>setTitle()</literal> 方"
+"法。 "
 
 #. Tag: para
-#: tutorial.xml:271
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Why does the <literal>date</literal> property mapping include the "
 "<literal>column</literal> attribute, but the <literal>title</literal> does "
@@ -517,15 +379,14 @@
 "literal>, however, <literal>date</literal> is a reserved keyword in most "
 "databases so you will need to map it to a different name."
 msgstr ""
-"为什么<literal>date</literal>属性的映射含有<literal>column</literal> "
-"attribute,而<literal>title</literal>却没有?当没有设定<literal>column</"
-"literal> attribute 的时候,Hibernate缺省地使用JavaBean的属性名作为字段名。对"
-"于<literal>title</literal>,这样工作得很好。然而,<literal>date</literal>在多"
-"数的数据库里,是一个保留关键字,所以我们最好把它映射成一个不同的名字。"
+"为什么 <literal>date</literal> 属性的映射含有 <literal>column</literal> "
+"attribute,而 <literal>title</literal> 却没有?当没有设定 <literal>column</"
+"literal> attribute 的时候,Hibernate 缺省地使用 JavaBean 的属性名作为字段名。"
+"对于 <literal>title</literal>,这样工作得很好。然而,<literal>date</literal> "
+"在多数的数据库里,是一个保留关键字,所以我们最好把它映射成一个不同的名字。 "
 
 #. Tag: para
-#: tutorial.xml:281
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The <literal>title</literal> mapping also lacks a <literal>type</literal> "
 "attribute. The types declared and used in the mapping files are not Java "
@@ -542,21 +403,20 @@
 "literal> column. Full date and time information is preserved by mapping the "
 "property with a <literal>timestamp</literal> converter."
 msgstr ""
-"另一有趣的事情是<literal>title</literal>属性缺少一个<literal>type</literal> "
-"attribute。我们在映射文件里声明并使用的类型,却不是我们期望的那样,是Java数据"
-"类型,同时也不是SQL数据库的数据类型。这些类型就是所谓的Hibernate 映射类型"
-"<emphasis>(mapping types)</emphasis>,它们能把Java数据类型转换到SQL数据类"
-"型,反之亦然。再次重申,如果在映射文件中没有设置<literal>type</literal>属性的"
-"话,Hibernate会自己试着去确定正确的转换类型和它的映射类型。在某些情况下这个自"
-"动检测机制(在Java 类上使用反射机制)不会产生你所期待或需要的缺省值。"
-"<literal>date</literal>属性就是个很好的例子,Hibernate无法知道这个属性"
-"(<literal>java.util.Date</literal>类型的)应该被映射成:SQL <literal>date</"
-"literal>,或<literal>timestamp</literal>,还是<literal>time</literal> 字段。"
-"在此例中,把这个属性映射成<literal>timestamp</literal> 转换器,这样我们预留了"
-"日期和时间的全部信息。"
+"另一有趣的事情是 <literal>title</literal> 属性缺少一个 <literal>type</"
+"literal> attribute。我们在映射文件里声明并使用的类型,却不是我们期望的那样,"
+"是 Java 数据类型,同时也不是 SQL 数据库的数据类型。这些类型就是所谓的 "
+"Hibernate 映射类型<emphasis>(mapping types)</emphasis>,它们能把 Java 数据"
+"类型转换到 SQL 数据类型,反之亦然。再次重申,如果在映射文件中没有设置 "
+"<literal>type</literal> 属性的话,Hibernate 会自己试着去确定正确的转换类型和"
+"它的映射类型。在某些情况下这个自动检测机制(在 Java 类上使用反射机制)不会产"
+"生你所期待或需要的缺省值。<literal>date</literal> 属性就是个很好的例子,"
+"Hibernate 无法知道这个属性(<literal>java.util.Date</literal> 类型的)应该被"
+"映射成:SQL <literal>date</literal>,或 <literal>timestamp</literal>,还是 "
+"<literal>time</literal> 字段。在此例中,把这个属性映射成 <literal>timestamp</"
+"literal> 转换器,这样我们预留了日期和时间的全部信息。 "
 
 #. Tag: para
-#: tutorial.xml:297
 #, no-c-format
 msgid ""
 "Hibernate makes this mapping type determination using reflection when the "
@@ -564,39 +424,40 @@
 "performance is important you should consider explicitly defining the type to "
 "use."
 msgstr ""
+"当处理映射文件时,Hibernate 用反射(reflection)来决定这个映射类型。这需要时"
+"间和资源,所以如果你注重启动性能,你应该考虑显性地定义所用的类型。"
 
 #. Tag: para
-#: tutorial.xml:304
 #, no-c-format
 msgid ""
 "Save this mapping file as <filename>src/main/resources/org/hibernate/"
 "tutorial/domain/Event.hbm.xml</filename>."
 msgstr ""
+"把这个映射文件保存为 <filename>src/main/resources/org/hibernate/tutorial/"
+"domain/Event.hbm.xml</filename>。"
 
 #. Tag: title
-#: tutorial.xml:312
 #, no-c-format
 msgid "Hibernate configuration"
-msgstr "Hibernate配置"
+msgstr "Hibernate 配置"
 
 #. Tag: para
-#: tutorial.xml:314
 #, no-c-format
 msgid ""
 "At this point, you should have the persistent class and its mapping file in "
 "place. It is now time to configure Hibernate. First let's set up HSQLDB to "
 "run in \"server mode\""
 msgstr ""
+"此时,你应该有了持久化类和它的映射文件。现在是配置 Hibernate 的时候了。首先让"
+"我们设立 HSQLDB 使其运行在“服务器模式”。"
 
 #. Tag: para
-#: tutorial.xml:321
-#, no-c-format
+#, fuzzy, no-c-format
 msgid "We do this do that the data remains between runs."
-msgstr ""
+msgstr "数据在程序运行期间需要保持有效。"
 
 #. Tag: para
-#: tutorial.xml:326
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will utilize the Maven exec plugin to launch the HSQLDB server by "
 "running: <command> mvn exec:java -Dexec.mainClass=\"org.hsqldb.Server\" -"
@@ -606,15 +467,15 @@
 "tutorial, shutdown HSQLDB, delete all files in the <filename>target/data</"
 "filename> directory, and start HSQLDB again."
 msgstr ""
-"在开发的根目录下创建一个<literal>data</literal>目录 - 这是HSQL DB存储数据文"
-"件的地方。此时在data目录中运行<literal>java -classpath ../lib/hsqldb.jar org."
-"hsqldb.Server</literal>就可启动数据库。你可以在log中看到它的启动,及绑定到"
-"TCP/IP套结字,这正是我们的应用程序稍后会连接的地方。如果你希望在本例中运行一"
-"个全新的数据库,就在窗口中按下<literal>CTRL + C</literal>来关闭HSQL数据库,并"
-"删除<literal>data/</literal>目录下的所有文件,再重新启动HSQL数据库。"
+"在开发的根目录下创建一个 <literal>data</literal> 目录 - 这是 HSQL DB 存储数"
+"据文件的地方。此时在 data 目录中运行 <literal>java -classpath ../lib/hsqldb."
+"jar org.hsqldb.Server</literal> 就可启动数据库。你可以在 log 中看到它的启动,"
+"及绑定到 TCP/IP 套接字,这正是我们的应用程序稍后会连接的地方。如果你希望在本"
+"例中运行一个全新的数据库,就在窗口中按下 <literal>CTRL + C</literal> 来关闭 "
+"HSQL 数据库,并删除 <literal>data/</literal> 目录下的所有文件,再重新启动 "
+"HSQL 数据库。 "
 
 #. Tag: para
-#: tutorial.xml:337
 #, no-c-format
 msgid ""
 "Hibernate will be connecting to the database on behalf of your application, "
@@ -626,118 +487,72 @@
 "net/\">proxool</ulink>. However, we will be using the Hibernate built-in "
 "connection pool for this tutorial."
 msgstr ""
+"Hibernate 将为你的应用程序连接到数据库,所以它需要知道如何获取连接。在这个教"
+"程里,我们使用一个独立连接池(和 <interfacename>javax.sql.DataSource</"
+"interfacename> 相反)。Hibernate 支持两个第三方的开源 JDBC 连接池:<ulink "
+"url=\"https://sourceforge.net/projects/c3p0\">c3p0</ulink> 和 <ulink url="
+"\"http://proxool.sourceforge.net/\">proxool</ulink>。然而,在本教程里我们将使"
+"用 Hibernate 内置的连接池。"
 
 #. Tag: para
-#: tutorial.xml:348
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "The built-in Hibernate connection pool is in no way intended for production "
 "use. It lacks several features found on any decent connection pool."
-msgstr ""
+msgstr "嵌入的 Hibernate 连接池不用于产品环境。"
 
 #. Tag: para
-#: tutorial.xml:354
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For Hibernate's configuration, we can use a simple <literal>hibernate."
 "properties</literal> file, a more sophisticated <literal>hibernate.cfg.xml</"
 "literal> file, or even complete programmatic setup. Most users prefer the "
 "XML configuration file:"
 msgstr ""
-"为了保存Hibernate的配置,我们可以使用一个简单的<literal>hibernate."
-"properties</literal>文件,或者一个稍微复杂的<literal>hibernate.cfg.xml</"
-"literal>,甚至可以完全使用程序来配置Hibernate。多数用户更喜欢使用XML配置文"
-"件:"
+"为了保存 Hibernate 的配置,我们可以使用一个简单的 <literal>hibernate."
+"properties</literal> 文件,或者一个稍微复杂的 <literal>hibernate.cfg.xml</"
+"literal>,甚至可以完全使用程序来配置 Hibernate。多数用户更喜欢使用 XML 配置文"
+"件: "
 
-#. Tag: programlisting
-#: tutorial.xml:360
-#, no-c-format
-msgid ""
-"<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
-"<!DOCTYPE hibernate-configuration PUBLIC\n"
-"        \"-//Hibernate/Hibernate Configuration DTD 3.0//EN\"\n"
-"        \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
-"\">\n"
-"\n"
-"<hibernate-configuration>\n"
-"\n"
-"    <session-factory>\n"
-"\n"
-"        <!-- Database connection settings -->\n"
-"        <property name=\"connection.driver_class\">org.hsqldb.jdbcDriver</"
-"property>\n"
-"        <property name=\"connection.url\">jdbc:hsqldb:hsql://localhost</"
-"property>\n"
-"        <property name=\"connection.username\">sa</property>\n"
-"        <property name=\"connection.password\"></property>\n"
-"\n"
-"        <!-- JDBC connection pool (use the built-in) -->\n"
-"        <property name=\"connection.pool_size\">1</property>\n"
-"\n"
-"        <!-- SQL dialect -->\n"
-"        <property name=\"dialect\">org.hibernate.dialect.HSQLDialect</"
-"property>\n"
-"\n"
-"        <!-- Enable Hibernate's automatic session context management -->\n"
-"        <property name=\"current_session_context_class\">thread</property>\n"
-"\n"
-"        <!-- Disable the second-level cache  -->\n"
-"        <property name=\"cache.provider_class\">org.hibernate.cache."
-"NoCacheProvider</property>\n"
-"\n"
-"        <!-- Echo all executed SQL to stdout -->\n"
-"        <property name=\"show_sql\">true</property>\n"
-"\n"
-"        <!-- Drop and re-create the database schema on startup -->\n"
-"        <property name=\"hbm2ddl.auto\">update</property>\n"
-"\n"
-"        <mapping resource=\"org/hibernate/tutorial/domain/Event.hbm.xml\"/>\n"
-"\n"
-"    </session-factory>\n"
-"\n"
-"</hibernate-configuration>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:363
 #, no-c-format
 msgid "Notice that this configuration file specifies a different DTD"
-msgstr ""
+msgstr "请注意,这个配置文件指定了一个不同的 DTD。"
 
 #. Tag: para
-#: tutorial.xml:366
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You configure Hibernate's <literal>SessionFactory</literal>. SessionFactory "
 "is a global factory responsible for a particular database. If you have "
 "several databases, for easier startup you should use several <literal>&lt;"
 "session-factory&gt;</literal> configurations in several configuration files."
 msgstr ""
-"注意这个XML配置使用了一个不同的DTD。在这里,我们配置了Hibernate的"
-"<literal>SessionFactory</literal>-一个关联于特定数据库全局的工厂"
-"(factory)。如果你要使用多个数据库,就要用多个的<literal>&lt;session-"
-"factory&gt;</literal>,通常把它们放在多个配置文件中(为了更容易启动)。"
+"注意这个 XML 配置使用了一个不同的 DTD。在这里,我们配置了 Hibernate 的"
+"<literal>SessionFactory</literal> — 一个关联于特定数据库全局的工厂"
+"(factory)。如果你要使用多个数据库,就要用多个的 <literal>&lt;session-"
+"factory&gt;</literal>,通常把它们放在多个配置文件中(为了更容易启动)。 "
 
 #. Tag: para
-#: tutorial.xml:373
 #, no-c-format
 msgid ""
 "The first four <literal>property</literal> elements contain the necessary "
 "configuration for the JDBC connection. The dialect <literal>property</"
 "literal> element specifies the particular SQL variant Hibernate generates."
 msgstr ""
+"签名 4 个 <literal>property</literal> 元素包含了 JDBC 连接所必需的配置。方言 "
+"<literal>property</literal> 元素指定了 Hibernate 生成的特定 SQL 语句。"
 
 #. Tag: para
-#: tutorial.xml:380
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "In most cases, Hibernate is able to properly determine which dialect to use. "
-"See <xref linkend=\"portability-dialectresolver\"/> for more information."
+"See <xref linkend=\"portability-dialectresolver\" /> for more information."
 msgstr ""
+"在大多数情况下,Hibernate 都能够正确地决定所使用的方言。更多信息请参考 <xref "
+"linkend=\"portability-dialectresolver\" />。"
 
 #. Tag: para
-#: tutorial.xml:386
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate's automatic session management for persistence contexts is "
 "particularly useful in this context. The <literal>hbm2ddl.auto</literal> "
@@ -747,30 +562,29 @@
 "Ant task. Finally, add the mapping file(s) for persistent classes to the "
 "configuration."
 msgstr ""
-"最开始的4个<literal>property</literal>元素包含必要的JDBC连接信息。方言"
-"(dialect)的<literal>property</literal>元素指明Hibernate 生成的特定SQL变量。"
-"你很快会看到,Hibernate对持久化上下文的自动session管理就会派上用场。 打开"
-"<literal>hbm2ddl.auto</literal>选项将自动生成数据库模式(schema)- 直接加入"
-"数据库中。当然这个选项也可以被关闭(通过去除这个配置选项)或者通过Ant任务"
-"<literal>SchemaExport</literal>的帮助来把数据库schema重定向到文件中。最后,在"
-"配置中为持久化类加入映射文件。"
+"最开始的 4 个 <literal>property</literal> 元素包含必要的 JDBC 连接信息。方言"
+"(dialect)的 <literal>property</literal> 元素指明 Hibernate 生成的特定 SQL "
+"变量。你很快会看到,Hibernate 对持久化上下文的自动 session 管理就会派上用"
+"场。 打开 <literal>hbm2ddl.auto</literal> 选项将自动生成数据库模式(schema)"
+"- 直接加入数据库中。当然这个选项也可以被关闭(通过去除这个配置选项)或者通"
+"过 Ant 任务 <literal>SchemaExport</literal> 的帮助来把数据库 schema 重定向到"
+"文件中。最后,在配置中为持久化类加入映射文件。 "
 
 #. Tag: para
-#: tutorial.xml:395
 #, no-c-format
 msgid ""
 "Save this file as <filename>hibernate.cfg.xml</filename> into the "
 "<filename>src/main/resources</filename> directory."
 msgstr ""
+"把这个文件保存为 <filename>src/main/resources</filename> 目录下的 "
+"<filename>hibernate.cfg.xml</filename>。"
 
 #. Tag: title
-#: tutorial.xml:403
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Building with Maven"
-msgstr "用Ant构建"
+msgstr "用 Maven 构建  "
 
 #. Tag: para
-#: tutorial.xml:405
 #, no-c-format
 msgid ""
 "We will now build the tutorial with Maven. You will need to have Maven "
@@ -780,45 +594,19 @@
 "basic project tasks. First, lets run the <literal>compile</literal> goal to "
 "make sure we can compile everything so far:"
 msgstr ""
+"我们将用 Maven 构建这个教程。你将需要安装 Maven;你可以从 <ulink url="
+"\"http://maven.apache.org/download.html\">Maven 下载页面</ulink>获得 Maven。"
+"Maen 将读取我们先前创建的 <filename>/pom.xml</filename> 并知道执行基本的项目"
+"任务。首先,让我们运行 <literal>compile</literal> 目标来确保我们可以编译到目"
+"前为止的所有程序:"
 
-#. Tag: programlisting
-#: tutorial.xml:415
-#, no-c-format
-msgid ""
-"<![CDATA[[hibernateTutorial]$ mvn compile\n"
-"[INFO] Scanning for projects...\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] Building First Hibernate Tutorial\n"
-"[INFO]    task-segment: [compile]\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] [resources:resources]\n"
-"[INFO] Using default encoding to copy filtered resources.\n"
-"[INFO] [compiler:compile]\n"
-"[INFO] Compiling 1 source file to /home/steve/projects/sandbox/"
-"hibernateTutorial/target/classes\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] BUILD SUCCESSFUL\n"
-"[INFO] "
-"------------------------------------------------------------------------\n"
-"[INFO] Total time: 2 seconds\n"
-"[INFO] Finished at: Tue Jun 09 12:25:25 CDT 2009\n"
-"[INFO] Final Memory: 5M/547M\n"
-"[INFO] "
-"------------------------------------------------------------------------]]>"
-msgstr ""
-
 #. Tag: title
-#: tutorial.xml:420
 #, no-c-format
 msgid "Startup and helpers"
 msgstr "启动和辅助类"
 
 #. Tag: para
-#: tutorial.xml:422
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "It is time to load and store some <literal>Event</literal> objects, but "
 "first you have to complete the setup with some infrastructure code. You have "
@@ -831,71 +619,36 @@
 "<interfacename>org.hibernate.SessionFactory</interfacename> is a thread-safe "
 "global object that is instantiated once."
 msgstr ""
-"是时候来加载和储存一些<literal>Event</literal>对象了,但首先我们得编写一些基"
-"础的代码以完成设置。我们必须启动Hibernate,此过程包括创建一个全局的"
+"是时候来加载和储存一些 <literal>Event</literal> 对象了,但首先我们得编写一些"
+"基础的代码以完成设置。我们必须启动 Hibernate,此过程包括创建一个全局的 "
 "<literal>SessoinFactory</literal>,并把它储存在应用程序代码容易访问的地方。"
-"<literal>SessionFactory</literal>可以创建并打开新的<literal>Session</"
-"literal>。一个<literal>Session</literal>代表一个单线程的单元操作,"
-"<literal>SessionFactory</literal>则是个线程安全的全局对象,只需要被实例化一"
-"次。"
+"<literal>SessionFactory</literal> 可以创建并打开新的 <literal>Session</"
+"literal>。一个 <literal>Session</literal> 代表一个单线程的单元操作,"
+"<interfacename>org.hibernate.SessionFactory</interfacename> 则是个线程安全的"
+"全局对象,只需要被实例化一次。 "
 
 #. Tag: para
-#: tutorial.xml:436
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We will create a <literal>HibernateUtil</literal> helper class that takes "
 "care of startup and makes accessing the <interfacename>org.hibernate."
 "SessionFactory</interfacename> more convenient."
 msgstr ""
-"我们将创建一个<literal>HibernateUtil</literal>辅助类(helper class)来负责启"
-"动Hibernate和更方便地操作<literal>SessionFactory</literal>。让我们来看一下它"
-"的实现:"
+"我们将创建一个 <literal>HibernateUtil</literal> 辅助类(helper class)来负责"
+"启动 Hibernate 和更方便地操作 <interfacename>org.hibernate.SessionFactory</"
+"interfacename>。让我们来看一下它的实现:"
 
-#. Tag: programlisting
-#: tutorial.xml:442
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.util;\n"
-"\n"
-"import org.hibernate.SessionFactory;\n"
-"import org.hibernate.cfg.Configuration;\n"
-"\n"
-"public class HibernateUtil {\n"
-"\n"
-"    private static final SessionFactory sessionFactory = buildSessionFactory"
-"();\n"
-"\n"
-"    private static SessionFactory buildSessionFactory() {\n"
-"        try {\n"
-"            // Create the SessionFactory from hibernate.cfg.xml\n"
-"            return new Configuration().configure().buildSessionFactory();\n"
-"        }\n"
-"        catch (Throwable ex) {\n"
-"            // Make sure you log the exception, as it might be swallowed\n"
-"            System.err.println(\"Initial SessionFactory creation failed.\" + "
-"ex);\n"
-"            throw new ExceptionInInitializerError(ex);\n"
-"        }\n"
-"    }\n"
-"\n"
-"    public static SessionFactory getSessionFactory() {\n"
-"        return sessionFactory;\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:444
 #, no-c-format
 msgid ""
 "Save this code as <filename>src/main/java/org/hibernate/tutorial/util/"
 "HibernateUtil.java</filename>"
 msgstr ""
+"把这段代码保存为 <filename>src/main/java/org/hibernate/tutorial/util/"
+"HibernateUtil.java</filename>。"
 
 #. Tag: para
-#: tutorial.xml:449
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This class not only produces the global <interfacename>org.hibernate."
 "SessionFactory</interfacename> reference in its static initializer; it also "
@@ -904,13 +657,13 @@
 "reference from JNDI in an application server or any other location for that "
 "matter."
 msgstr ""
-"这个类不但在它的静态初始化过程(仅当加载这个类的时候被JVM执行一次)中产生全局"
-"的<literal>SessionFactory</literal>,而且隐藏了它使用了静态singleton的事实。"
-"它也可能在应用程序服务器中的JNDI查找<literal>SessionFactory</literal>。"
+"这个类不但在它的静态初始化过程(仅当加载这个类的时候被 JVM 执行一次)中产生全"
+"局的 <interfacename>org.hibernate.SessionFactory</interfacename>,而且隐藏了"
+"它使用了静态 singleton 的事实。它也可能在应用程序服务器中的 JNDI 查找 "
+"<interfacename>org.hibernate.SessionFactory</interfacename>。"
 
 #. Tag: para
-#: tutorial.xml:458
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "If you give the <interfacename>org.hibernate.SessionFactory</interfacename> "
 "a name in your configuration, Hibernate will try to bind it to JNDI under "
@@ -919,15 +672,14 @@
 "<literal>HibernateService</literal> to JNDI. Such advanced options are "
 "discussed later."
 msgstr ""
-"如果你在配置文件中给<literal>SessionFactory</literal>一个名字,在"
-"<literal>SessionFactory</literal>创建后,Hibernate会试着把它绑定到JNDI。要完"
-"全避免这样的代码,你也可以使用JMX部署,让具有JMX能力的容器来实例化"
-"<literal>HibernateService</literal>并把它绑定到JNDI。这些高级可选项在后面的章"
-"节中会讨论到。"
+"如果你在配置文件中给 <interfacename>org.hibernate.SessionFactory</"
+"interfacename> 一个名字,在 它创建后,Hibernate 会试着把它绑定到 JNDI。要完全"
+"避免这样的代码,你也可以使用 JMX 部署,让具有 JMX 能力的容器来实例化 "
+"<literal>HibernateService</literal> 并把它绑定到 JNDI。这些高级可选项在后面的"
+"章节中会讨论到。"
 
 #. Tag: para
-#: tutorial.xml:467
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You now need to configure a logging system. Hibernate uses commons logging "
 "and provides two choices: Log4j and JDK 1.4 logging. Most developers prefer "
@@ -938,97 +690,50 @@
 "configuration, you can change the settings. By default, only the Hibernate "
 "startup message is shown on stdout."
 msgstr ""
-"再次编译这个应用程序应该不会有问题。最后我们需要配置一个日志(logging)系统 "
-"- Hibernate使用通用日志接口,允许你在Log4j和JDK 1.4 日志之间进行选择。多数开"
-"发者更喜欢Log4j:从Hibernate的发布包中(它在<literal>etc/</literal>目录下)拷"
-"贝<literal>log4j.properties</literal>到你的<literal>src</literal>目录,与"
-"<literal>hibernate.cfg.xml</literal>.放在一起。看一下配置示例,如果你希望看到"
-"更加详细的输出信息,你可以修改配置。默认情况下,只有Hibernate的启动信息才会显"
-"示在标准输出上。"
+"再次编译这个应用程序应该不会有问题。最后我们需要配置一个日志(logging)系统 — "
+"Hibernate 使用通用日志接口,允许你在 Log4j 和 JDK 1.4 日志之间进行选择。多数"
+"开发者更喜欢 Log4j:从 Hibernate 的发布包中(它在 <literal>etc/</literal> 目"
+"录下)拷贝 <literal>log4j.properties</literal> 到你的 <literal>src</literal> "
+"目录,与 <literal>hibernate.cfg.xml</literal> 放在一起。看一下配置示例,如果"
+"你希望看到更加详细的输出信息,你可以修改配置。默认情况下,只有 Hibernate 的启"
+"动信息才会显示在标准输出上。 "
 
 #. Tag: para
-#: tutorial.xml:477
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The tutorial infrastructure is complete and you are now ready to do some "
 "real work with Hibernate."
-msgstr "示例的基本框架完成了 - 现在我们可以用Hibernate来做些真正的工作。"
+msgstr "示例的基本框架完成了 — 现在我们可以用 Hibernate 来做些真正的工作。 "
 
 #. Tag: title
-#: tutorial.xml:485
 #, no-c-format
 msgid "Loading and storing objects"
 msgstr "加载并存储对象"
 
 #. Tag: para
-#: tutorial.xml:487
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "We are now ready to start doing some real worjk with Hibernate. Let's start "
 "by writing an <literal>EventManager</literal> class with a <literal>main()</"
 "literal> method:"
 msgstr ""
-"我们终于可以使用Hibernate来加载和存储对象了,编写一个带有<literal>main()</"
-"literal>方法的<literal>EventManager</literal>类:"
+"我们终于可以使用 Hibernate 来加载和存储对象了,编写一个带有 <literal>main()</"
+"literal> 方法的 <literal>EventManager</literal> 类: "
 
-#. Tag: programlisting
-#: tutorial.xml:493
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[package org.hibernate.tutorial;\n"
-"\n"
-"import org.hibernate.Session;\n"
-"\n"
-"import java.util.*;\n"
-"\n"
-"import org.hibernate.tutorial.domain.Event;\n"
-"import org.hibernate.tutorial.util.HibernateUtil;\n"
-"\n"
-"public class EventManager {\n"
-"\n"
-"    public static void main(String[] args) {\n"
-"        EventManager mgr = new EventManager();\n"
-"\n"
-"        if (args[0].equals(\"store\")) {\n"
-"            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-"        }\n"
-"\n"
-"        HibernateUtil.getSessionFactory().close();\n"
-"    }\n"
-"\n"
-"    private void createAndStoreEvent(String title, Date theDate) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Event theEvent = new Event();\n"
-"        theEvent.setTitle(title);\n"
-"        theEvent.setDate(theDate);\n"
-"        session.save(theEvent);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:495
-#, fuzzy, no-c-format
-msgid ""
 "In <literal>createAndStoreEvent()</literal> we created a new <literal>Event</"
 "literal> object and handed it over to Hibernate. At that point, Hibernate "
 "takes care of the SQL and executes an <literal>INSERT</literal> on the "
 "database."
 msgstr ""
-"我们创建了个新的<literal>Event</literal>对象并把它传递给Hibernate。现在"
-"Hibernate负责与SQL打交道,并把<literal>INSERT</literal>命令传给数据库。在运行"
-"之前,让我们看一下处理<literal>Session</literal>和<literal>Transaction</"
-"literal>的代码。"
+"在 <literal>createAndStoreEvent()</literal> 来里我们创建了一个新的 "
+"<literal>Event</literal> 对象并把它传递给 Hibernate。现在 Hibernate 负责与 "
+"SQL 打交道,并把 <literal>INSERT</literal> 命令传给数据库。"
 
 #. Tag: para
-#: tutorial.xml:502
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <interface>org.hibernate.Session</interface> is designed to represent a "
 "single unit of work (a single atmoic piece of work to be performed). For now "
@@ -1039,14 +744,15 @@
 "interfacename> API. In this particular case we are using JDBC-based "
 "transactional semantics, but it could also run with JTA."
 msgstr ""
-"一个<literal>Session</literal>就是个单一的工作单元。我们暂时让事情简单一些,"
-"并假设Hibernate<literal>Session</literal>和数据库事务是一一对应的。为了让我们"
-"的代码从底层的事务系统中脱离出来(此例中是JDBC,但也可能是JTA),我们使用"
-"Hibernate <literal>Session</literal>中的<literal>Transaction</literal> API。"
+"一个 <interface>org.hibernate.Session</interface> 就是个单一的工作单元。我们"
+"暂时让事情简单一些,并假设 Hibernate <interface>org.hibernate.Session</"
+"interface> 和数据库事务是一一对应的。为了让我们的代码从底层的事务系统中脱离出"
+"来(此例中是 JDBC,但也可能是 JTA),我们使用 <interfacename>org.hibernate."
+"Transaction</interfacename> API。在这个例子里我们使用基于 JDBC 的事务性 "
+"semantic,但它也可以和 JTA 一起运行。"
 
 #. Tag: para
-#: tutorial.xml:515
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What does <literal>sessionFactory.getCurrentSession()</literal> do? First, "
 "you can call it as many times and anywhere you like once you get hold of "
@@ -1057,16 +763,15 @@
 "xml</filename>? Due to that setting, the context of a current unit of work "
 "is bound to the current Java thread that executes the application."
 msgstr ""
-"<literal>sessionFactory.getCurrentSession()</literal>是干什么的呢?首先,只要"
-"你持有<literal>SessionFactory</literal>(幸亏我们有<literal>HibernateUtil</"
-"literal>,可以随时获得),大可在任何时候、任何地点调用这个方法。"
-"<literal>getCurrentSession()</literal>方法总会返回“当前的”工作单元。记得我们"
-"在<literal>hibernate.cfg.xml</literal>中把这一配置选项调整为\"thread\"了吗?"
-"因此,因此,当前工作单元被绑定到当前执行我们应用程序的Java线程。但是,这并非"
-"是完全准确的,你还得考虑工作单元的生命周期范围 (scope),它何时开始,又何时结束."
+"<literal>sessionFactory.getCurrentSession()</literal> 是干什么的呢?首先,只"
+"要你持有 <interfacename>org.hibernate.SessionFactory</interfacename>,大可在"
+"任何时候、任何地点调用这个方法。<literal>getCurrentSession()</literal> 方法总"
+"会返回“当前的”工作单元。记得我们在 <filename>src/main/resources/hibernate."
+"cfg.xml</filename> 中把这一配置选项调整为 \"thread\" 了吗?因此,因此,当前工"
+"作单元被绑定到当前执行我们应用程序的 Java 线程。但是,这并非是完全准确的,你还"
+"得考虑工作单元的生命周期范围(scope),它何时开始,又何时结束。"
 
 #. Tag: para
-#: tutorial.xml:529
 #, no-c-format
 msgid ""
 "Hibernate offers three methods of current session tracking. The \"thread\" "
@@ -1074,10 +779,11 @@
 "prototyping and tutorials such as this one. Current session tracking is "
 "discussed in more detail later on."
 msgstr ""
+"Hibernate 提供三种跟踪当前会话的方法。基于“线程”的方法不适合于产品环境,它仅"
+"用于 prototyping 和教学用途。后面将更详细地讨论会话跟踪。"
 
 #. Tag: para
-#: tutorial.xml:538
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A <interface>org.hibernate.Session</interface> begins when the first call to "
 "<literal>getCurrentSession()</literal> is made for the current thread. It is "
@@ -1088,19 +794,15 @@
 "new <interface>org.hibernate.Session</interface> and can start a new unit of "
 "work."
 msgstr ""
-"<literal>Session</literal>在第一次被使用的时候,即第一次调用"
-"<literal>getCurrentSession()</literal>的时候,其生命周期就开始。然后它被"
-"Hibernate绑定到当前线程。当事务结束的时候,不管是提交还是回滚,Hibernate会自"
-"动把<literal>Session</literal>从当前线程剥离,并且关闭它。假若你再次调用"
-"<literal>getCurrentSession()</literal>,你会得到一个新的<literal>Session</"
-"literal>,并且开始一个新的工作单元。这种<emphasis>线程绑定(thread-bound)</"
-"emphasis>的编程模型(model)是使用Hibernate的最广泛的方式,因为它支持对你的代"
-"码灵活分层(事务划分可以和你的数据访问代码分离开来,在本教程的后面部分就会这么"
-"做)。"
+"<interface>org.hibernate.Session</interface> 在第一次被使用的时候,即第一次调"
+"用 <literal>getCurrentSession()</literal> 的时候,其生命周期就开始。然后它被 "
+"Hibernate 绑定到当前线程。当事务结束的时候,不管是提交还是回滚,Hibernate 会"
+"自动把 <interface>org.hibernate.Session</interface> 从当前线程剥离,并且关闭"
+"它。假若你再次调用 <literal>getCurrentSession()</literal>,你会得到一个新的 "
+"<interface>org.hibernate.Session</interface>,并且开始一个新的工作单元。"
 
 #. Tag: para
-#: tutorial.xml:551
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Related to the unit of work scope, should the Hibernate <interface>org."
 "hibernate.Session</interface> be used to execute one or several database "
@@ -1114,144 +816,100 @@
 "<emphasis>session-per-operation</emphasis> an anti-pattern. A real web "
 "application is shown later in the tutorial which will help illustrate this."
 msgstr ""
-"和工作单元的生命周期这个话题相关,Hibernate <literal>Session</literal>是否被"
-"应该用来执行多次数据库操作?上面的例子对每一次操作使用了一个"
-"<literal>Session</literal>,这完全是巧合,这个例子不是很复杂,无法展示其他方"
-"式。Hibernate <literal>Session</literal>的生命周期可以很灵活,但是你绝不要把"
-"你的应用程序设计成为<emphasis>每一次</emphasis>数据库操作都用一个新的"
-"Hibernate <literal>Session</literal>。因此就算下面的例子(它们都很简单)中你"
-"可以看到这种用法,记住<emphasis>每次操作一个session</emphasis>是一个反模式。"
-"在本教程的后面会展示一个真正的(web)程序。"
+"和工作单元的生命周期这个话题相关,Hibernate <interface>org.hibernate."
+"Session</interface> 是否被应该用来执行多次数据库操作?上面的例子对每一次操作"
+"使用了一个 <interface>org.hibernate.Session</interface>,这完全是巧合,这个例"
+"子不是很复杂,无法展示其他方式。Hibernate <interface>org.hibernate.Session</"
+"interface> 的生命周期可以很灵活,但是你绝不要把你的应用程序设计成为<emphasis>"
+"每一次</emphasis>数据库操作都用一个新的 Hibernate <interface>org.hibernate."
+"Session</interface>。因此就算下面的例子(它们都很简单)中你可以看到这种用法,"
+"记住<emphasis>每次操作一个 session</emphasis> 是一个反模式。在本教程的后面会"
+"展示一个真正的(web)程序。"
 
 #. Tag: para
-#: tutorial.xml:568
 #, fuzzy, no-c-format
 msgid ""
-"See <xref linkend=\"transactions\"/> for more information about transaction "
+"See <xref linkend=\"transactions\" /> for more information about transaction "
 "handling and demarcation. The previous example also skipped any error "
 "handling and rollback."
 msgstr ""
-"关于事务处理及事务边界界定的详细信息,请参看<xref linkend=\"transactions\"/"
-">。在上面的例子中,我们也忽略了所有的错误与回滚的处理。"
+"关于事务处理及事务边界界定的详细信息,请参看 <xref linkend=\"transactions\" /"
+"> 。在上面的例子中,我们也忽略了所有的错误与回滚的处理。"
 
 #. Tag: para
-#: tutorial.xml:574
 #, no-c-format
 msgid ""
 "To run this, we will make use of the Maven exec plugin to call our class "
 "with the necessary classpath setup: <command>mvn exec:java -Dexec.mainClass="
 "\"org.hibernate.tutorial.EventManager\" -Dexec.args=\"store\"</command>"
 msgstr ""
+"要运行它,我们将使用 Maven exec 插件以及必要的 classpath 设置来进行调用:"
+"<command>mvn exec:java -Dexec.mainClass=\"org.hibernate.tutorial.EventManager"
+"\" -Dexec.args=\"store\"</command>。"
 
 #. Tag: para
-#: tutorial.xml:581
 #, no-c-format
 msgid "You may need to perform <command>mvn compile</command> first."
-msgstr ""
+msgstr "你可能需要先执行 <command>mvn compile</command>。"
 
 #. Tag: para
-#: tutorial.xml:586
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You should see Hibernate starting up and, depending on your configuration, "
 "lots of log output. Towards the end, the following line will be displayed:"
 msgstr ""
-"你应该会看到,编译以后,Hibernate根据你的配置启动,并产生一大堆的输出日志。在"
-"日志最后你会看到下面这行:"
+"你应该会看到,编译以后,Hibernate 根据你的配置启动,并产生一大堆的输出日志。"
+"在日志最后你会看到下面这行: "
 
-#. Tag: programlisting
-#: tutorial.xml:591
-#, no-c-format
-msgid ""
-"<![CDATA[[java] Hibernate: insert into EVENTS (EVENT_DATE, title, EVENT_ID) "
-"values (?, ?, ?)]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:593
 #, no-c-format
 msgid "This is the <literal>INSERT</literal> executed by Hibernate."
-msgstr ""
+msgstr "执行 HQL <literal>INSERT</literal> 语句的例子如下: "
 
 #. Tag: para
-#: tutorial.xml:597
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "To list stored events an option is added to the main method:"
 msgstr ""
-"我们想要列出所有已经被存储的events,就要增加一个条件分支选项到main方法中去。"
+"我们想要列出所有已经被存储的 events,就要增加一个条件分支选项到 main 方法中:"
 
-#. Tag: programlisting
-#: tutorial.xml:601
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[        if (args[0].equals(\"store\")) {\n"
-"            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
-"        }\n"
-"        else if (args[0].equals(\"list\")) {\n"
-"            List events = mgr.listEvents();\n"
-"            for (int i = 0; i < events.size(); i++) {\n"
-"                Event theEvent = (Event) events.get(i);\n"
-"                System.out.println(\n"
-"                        \"Event: \" + theEvent.getTitle() + \" Time: \" + "
-"theEvent.getDate()\n"
-"                );\n"
-"            }\n"
-"        }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:603
-#, fuzzy, no-c-format
 msgid "A new <literal>listEvents() method is also added</literal>:"
-msgstr "我们也增加一个新的<literal>listEvents()</literal>方法:"
+msgstr "我们也增加一个新的 <literal>listEvents()</literal> 方法: "
 
-#. Tag: programlisting
-#: tutorial.xml:607
-#, no-c-format
-msgid ""
-"<![CDATA[    private List listEvents() {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"        List result = session.createQuery(\"from Event\").list();\n"
-"        session.getTransaction().commit();\n"
-"        return result;\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:609
 #, fuzzy, no-c-format
 msgid ""
 "Here, we are using a Hibernate Query Language (HQL) query to load all "
 "existing <literal>Event</literal> objects from the database. Hibernate will "
 "generate the appropriate SQL, send it to the database and populate "
 "<literal>Event</literal> objects with the data. You can create more complex "
-"queries with HQL. See <xref linkend=\"queryhql\"/> for more information."
+"queries with HQL. See <xref linkend=\"queryhql\" /> for more information."
 msgstr ""
-"我们在这里是用一个HQL(Hibernate Query Language-Hibernate查询语言)查询语句"
-"来从数据库中加载所有存在的<literal>Event</literal>对象。Hibernate会生成适当的"
-"SQL,把它发送到数据库,并操作从查询得到数据的<literal>Event</literal>对象。当"
-"然,你可以使用HQL来创建更加复杂的查询。"
+"我们在这里是用一个 HQL(Hibernate Query Language-Hibernate查询语言)查询语句"
+"来从数据库中加载所有存在的 <literal>Event</literal> 对象。Hibernate 会生成适"
+"当的 SQL,把它发送到数据库,并操作从查询得到数据的 <literal>Event</literal> "
+"对象。当然,你可以使用 HQL 来创建更加复杂的查询。更多信息请参考 <xref "
+"linkend=\"queryhql\"/>。"
 
 #. Tag: para
-#: tutorial.xml:617
 #, no-c-format
 msgid ""
 "Now we can call our new functionality, again using the Maven exec plugin: "
 "<command>mvn exec:java -Dexec.mainClass=\"org.hibernate.tutorial.EventManager"
 "\" -Dexec.args=\"list\"</command>"
 msgstr ""
+"现在我们可以再次用 Maven exec plugin - <command>mvn exec:java -Dexec."
+"mainClass=\"org.hibernate.tutorial.EventManager\" -Dexec.args=\"list\"</"
+"command> 调用新的功能了。"
 
 #. Tag: title
-#: tutorial.xml:627
 #, no-c-format
 msgid "Part 2 - Mapping associations"
 msgstr "第二部分 - 关联映射"
 
 #. Tag: para
-#: tutorial.xml:629
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "So far we have mapped a single persistent entity class to a table in "
 "isolation. Let's expand on that a bit and add some class associations. We "
@@ -1259,111 +917,61 @@
 "participate."
 msgstr ""
 "我们已经映射了一个持久化实体类到表上。让我们在这个基础上增加一些类之间的关"
-"联。首先我们往应用程序里增加人(people)的概念,并存储他们所参与的一个Event列"
-"表。(译者注:与Event一样,我们在后面将直接使用person来表示“人”而不是它的中文"
-"翻译)"
+"联。首先我们往应用程序里增加人(people)的概念,并存储他们所参与的一个 Event "
+"列表。(译者注:与 Event 一样,我们在后面将直接使用 person 来表示“人”而不是它"
+"的中文翻译) "
 
 #. Tag: title
-#: tutorial.xml:637
 #, no-c-format
 msgid "Mapping the Person class"
-msgstr "映射Person类"
+msgstr "映射 Person 类"
 
 #. Tag: para
-#: tutorial.xml:639
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "The first cut of the <literal>Person</literal> class looks like this:"
-msgstr "最初简单的<literal>Person</literal>类:"
+msgstr "最初简单的 <literal>Person</literal> 类: "
 
-#. Tag: programlisting
-#: tutorial.xml:643
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.domain;\n"
-"\n"
-"public class Person {\n"
-"\n"
-"    private Long id;\n"
-"    private int age;\n"
-"    private String firstname;\n"
-"    private String lastname;\n"
-"\n"
-"    public Person() {}\n"
-"\n"
-"    // Accessor methods for all properties, private setter for 'id'\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:645
 #, no-c-format
 msgid ""
 "Save this to a file named <filename>src/main/java/org/hibernate/tutorial/"
 "domain/Person.java</filename>"
 msgstr ""
+"把它保存为文件 <filename>src/main/java/org/hibernate/tutorial/domain/Person."
+"java</filename>。"
 
 #. Tag: para
-#: tutorial.xml:650
 #, no-c-format
 msgid ""
 "Next, create the new mapping file as <filename>src/main/resources/org/"
 "hibernate/tutorial/domain/Person.hbm.xml</filename>"
 msgstr ""
+"然后,创建新的映射文件 <filename>src/main/resources/org/hibernate/tutorial/"
+"domain/Person.hbm.xml</filename>。"
 
-#. Tag: programlisting
-#: tutorial.xml:655
-#, no-c-format
-msgid ""
-"<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
-"\n"
-"    <class name=\"Person\" table=\"PERSON\">\n"
-"        <id name=\"id\" column=\"PERSON_ID\">\n"
-"            <generator class=\"native\"/>\n"
-"        </id>\n"
-"        <property name=\"age\"/>\n"
-"        <property name=\"firstname\"/>\n"
-"        <property name=\"lastname\"/>\n"
-"    </class>\n"
-"\n"
-"</hibernate-mapping>]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:657
 #, no-c-format
 msgid "Finally, add the new mapping to Hibernate's configuration:"
-msgstr "最后,把新的映射加入到Hibernate的配置中:"
+msgstr "最后,把新的映射加入到 Hibernate 的配置中:"
 
-#. Tag: programlisting
-#: tutorial.xml:661
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<mapping resource=\"events/Event.hbm.xml\"/>\n"
-"<mapping resource=\"events/Person.hbm.xml\"/>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:663
-#, fuzzy, no-c-format
-msgid ""
 "Create an association between these two entities. Persons can participate in "
 "events, and events have participants. The design questions you have to deal "
 "with are: directionality, multiplicity, and collection behavior."
 msgstr ""
-"现在我们在这两个实体之间创建一个关联。显然,persons可以参与一系列events,而"
-"events也有不同的参加者(persons)。我们需要处理的设计问题是关联方向"
-"(directionality),阶数(multiplicity)和集合(collection)的行为。"
+"现在我们在这两个实体之间创建一个关联。显然,persons 可以参与一系列 events,"
+"而 events 也有不同的参加者(persons)。我们需要处理的设计问题是关联方向"
+"(directionality),阶数(multiplicity)和集合(collection)的行为。 "
 
 #. Tag: title
-#: tutorial.xml:673
 #, no-c-format
 msgid "A unidirectional Set-based association"
-msgstr "单向Set-based的关联"
+msgstr "单向 Set-based 的关联"
 
 #. Tag: para
-#: tutorial.xml:675
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "By adding a collection of events to the <literal>Person</literal> class, you "
 "can easily navigate to the events for a particular person, without executing "
@@ -1373,33 +981,14 @@
 "Set</interfacename> because the collection will not contain duplicate "
 "elements and the ordering is not relevant to our examples:"
 msgstr ""
-"我们将向<literal>Person</literal>类增加一连串的events。那样,通过调用"
-"<literal>aPerson.getEvents()</literal>,就可以轻松地导航到特定person所参与的"
-"events,而不用去执行一个显式的查询。我们使用Java的集合类(collection):"
-"<literal>Set</literal>,因为set 不包含重复的元素及与我们无关的排序。"
+"我们将向 <literal>Person</literal> 类增加一连串的 events。那样,通过调用 "
+"<literal>aPerson.getEvents()</literal>,就可以轻松地导航到特定 person 所参与"
+"的 events,而不用去执行一个显式的查询。我们使用 Java 的集合类(collection):"
+"<literal>Set</literal>,因为 set 不包含重复的元素及与我们无关的排序。 "
 
-#. Tag: programlisting
-#: tutorial.xml:686
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[public class Person {\n"
-"\n"
-"    private Set events = new HashSet();\n"
-"\n"
-"    public Set getEvents() {\n"
-"        return events;\n"
-"    }\n"
-"\n"
-"    public void setEvents(Set events) {\n"
-"        this.events = events;\n"
-"    }\n"
-"}]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:688
-#, fuzzy, no-c-format
-msgid ""
 "Before mapping this association, let's consider the other side. We could "
 "just keep this unidirectional or create another collection on the "
 "<literal>Event</literal>, if we wanted to be able to navigate it from both "
@@ -1411,37 +1000,16 @@
 "Hence, we use Hibernate's many-to-many mapping:"
 msgstr ""
 "在映射这个关联之前,先考虑一下此关联的另外一端。很显然,我们可以保持这个关联"
-"是单向的。或者,我们可以在<literal>Event</literal>里创建另外一个集合,如果希"
-"望能够双向地导航,如:<literal>anEvent.getParticipants()</literal>。从功能的"
-"角度来说,这并不是必须的。因为你总可以显式地执行一个查询,以获得某个特定event"
-"的所有参与者。这是个在设计时需要做出的选择,完全由你来决定,但此讨论中关于关"
-"联的阶数是清楚的:即两端都是“多”值的,我们把它叫做<emphasis>多对多(many-to-"
-"many)</emphasis>关联。因而,我们使用Hibernate的多对多映射:"
+"是单向的。或者,我们可以在 <literal>Event</literal> 里创建另外一个集合,如果"
+"希望能够双向地导航,如:<literal>anEvent.getParticipants()</literal>。从功能"
+"的角度来说,这并不是必须的。因为你总可以显式地执行一个查询,以获得某个特定 "
+"event 的所有参与者。这是个在设计时需要做出的选择,完全由你来决定,但此讨论中"
+"关于关联的阶数是清楚的:即两端都是“多”值的,我们把它叫做<emphasis>多对多"
+"(many-to-many)</emphasis>关联。因而,我们使用 Hibernate 的多对多映射: "
 
-#. Tag: programlisting
-#: tutorial.xml:701
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Person\" table=\"PERSON\">\n"
-"    <id name=\"id\" column=\"PERSON_ID\">\n"
-"        <generator class=\"native\"/>\n"
-"    </id>\n"
-"    <property name=\"age\"/>\n"
-"    <property name=\"firstname\"/>\n"
-"    <property name=\"lastname\"/>\n"
-"\n"
-"    <set name=\"events\" table=\"PERSON_EVENT\">\n"
-"        <key column=\"PERSON_ID\"/>\n"
-"        <many-to-many column=\"EVENT_ID\" class=\"Event\"/>\n"
-"    </set>\n"
-"\n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:703
-#, fuzzy, no-c-format
-msgid ""
 "Hibernate supports a broad range of collection mappings, a <literal>set</"
 "literal> being most common. For a many-to-many association, or <emphasis>n:"
 "m</emphasis> entity relationship, an association table is required. Each row "
@@ -1454,76 +1022,38 @@
 "tell Hibernate the class of the objects in your collection (the class on the "
 "other side of the collection of references)."
 msgstr ""
-"Hibernate支持各种各样的集合映射,<literal>&lt;set&gt;</literal>使用的最为普"
-"遍。对于多对多关联(或叫<emphasis>n:m</emphasis>实体关系), 需要一个关联表"
-"(association table)。<literal>表</literal>里面的每一行代表从person到event的"
-"一个关联。表名是由<literal>set</literal>元素的<literal>table</literal>属性配"
-"置的。关联里面的标识符字段名,对于person的一端,是由<literal>&lt;key&gt;</"
-"literal>元素定义,而event一端的字段名是由<literal>&lt;many-to-many&gt;</"
-"literal>元素的<literal>column</literal>属性定义。你也必须告诉Hibernate集合中"
-"对象的类(也就是位于这个集合所代表的关联另外一端的类)。"
+"Hibernate 支持各种各样的集合映射,<literal>&lt;set&gt;</literal> 使用的最为普"
+"遍。对于多对多关联(或叫 <emphasis>n:m</emphasis> 实体关系), 需要一个关联表"
+"(association table)。<literal>表</literal>里面的每一行代表从 person 到 "
+"event 的一个关联。表名是由 <literal>set</literal> 元素的 <literal>table</"
+"literal> 属性配置的。关联里面的标识符字段名,对于 person 的一端,是由 "
+"<literal>&lt;key&gt;</literal> 元素定义,而 event 一端的字段名是由 "
+"<literal>&lt;many-to-many&gt;</literal> 元素的 <literal>column</literal> 属性"
+"定义。你也必须告诉 Hibernate 集合中对象的类(也就是位于这个集合所代表的关联另"
+"外一端的类)。 "
 
 #. Tag: para
-#: tutorial.xml:719
 #, no-c-format
 msgid "The database schema for this mapping is therefore:"
-msgstr "因而这个映射的数据库schema是:"
+msgstr "因而这个映射的数据库 schema 是:"
 
-#. Tag: programlisting
-#: tutorial.xml:723
-#, no-c-format
-msgid ""
-"<![CDATA[\n"
-"    _____________        __________________\n"
-"   |             |      |                  |       _____________\n"
-"   |   EVENTS    |      |   PERSON_EVENT   |      |             |\n"
-"   |_____________|      |__________________|      |    PERSON   |\n"
-"   |             |      |                  |      |_____________|\n"
-"   | *EVENT_ID   | <--> | *EVENT_ID        |      |             |\n"
-"   |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  |\n"
-"   |  TITLE      |      |__________________|      |  AGE        |\n"
-"   |_____________|                                |  FIRSTNAME  |\n"
-"                                                  |  LASTNAME   |\n"
-"                                                  |_____________|\n"
-" ]]>"
-msgstr ""
-
 #. Tag: title
-#: tutorial.xml:728
 #, no-c-format
 msgid "Working the association"
 msgstr "使关联工作"
 
 #. Tag: para
-#: tutorial.xml:730
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now we will bring some people and events together in a new method in "
 "<literal>EventManager</literal>:"
 msgstr ""
-"我们把一些people和events 一起放到<literal>EventManager</literal>的新方法中:"
+"我们把一些 people 和 events 一起放到 <literal>EventManager</literal> 的新方法"
+"中: "
 
-#. Tag: programlisting
-#: tutorial.xml:734
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session.load(Person.class, personId);\n"
-"        Event anEvent = (Event) session.load(Event.class, eventId);\n"
-"        aPerson.getEvents().add(anEvent);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:736
-#, fuzzy, no-c-format
-msgid ""
 "After loading a <literal>Person</literal> and an <literal>Event</literal>, "
 "simply modify the collection using the normal collection methods. There is "
 "no explicit call to <literal>update()</literal> or <literal>save()</"
@@ -1538,22 +1068,21 @@
 "of a unit of work, is called <emphasis>flushing</emphasis>. In our code, the "
 "unit of work ends with a commit, or rollback, of the database transaction."
 msgstr ""
-"在加载一<literal>Person</literal>和<literal>Event</literal>后,使用普通的集合"
-"方法就可容易地修改我们定义的集合。如你所见,没有显式的<literal>update()</"
-"literal>或<literal>save()</literal>,Hibernate会自动检测到集合已经被修改并需"
-"要更新回数据库。这叫做自动脏检查(<emphasis>automatic dirty checking</"
-"emphasis>),你也可以尝试修改任何对象的name或者date属性,只要他们处于"
-"<emphasis>持久化</emphasis>状态,也就是被绑定到某个Hibernate 的"
-"<literal>Session</literal>上(如:他们刚刚在一个单元操作被加载或者保存),"
-"Hibernate监视任何改变并在后台隐式写的方式执行SQL。同步内存状态和数据库的过"
+"在加载一 <literal>Person</literal> 和 <literal>Event</literal> 后,使用普通的"
+"集合方法就可容易地修改我们定义的集合。如你所见,没有显式的 <literal>update()"
+"</literal> 或 <literal>save()</literal>,Hibernate 会自动检测到集合已经被修改"
+"并需要更新回数据库。这叫做自动脏检查(<emphasis>automatic dirty checking</"
+"emphasis>),你也可以尝试修改任何对象的 name 或者 date 属性,只要他们处于"
+"<emphasis>持久化</emphasis>状态,也就是被绑定到某个 Hibernate 的 "
+"<literal>Session</literal> 上(如:他们刚刚在一个单元操作被加载或者保存),"
+"Hibernate 监视任何改变并在后台隐式写的方式执行 SQL。同步内存状态和数据库的过"
 "程,通常只在单元操作结束的时候发生,称此过程为清理缓存<emphasis>(flushing)"
 "</emphasis>。在我们的代码中,工作单元由数据库事务的提交(或者回滚)来结束——这"
-"是由<literal>CurrentSessionContext</literal>类的<literal>thread</literal>配置"
-"选项定义的。"
+"是由 <literal>CurrentSessionContext</literal> 类的 <literal>thread</literal> "
+"配置选项定义的。 "
 
 #. Tag: para
-#: tutorial.xml:755
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can load person and event in different units of work. Or you can modify "
 "an object outside of a <interfacename>org.hibernate.Session</interfacename>, "
@@ -1561,63 +1090,26 @@
 "is called <emphasis>detached</emphasis>). You can even modify a collection "
 "when it is detached:"
 msgstr ""
-"当然,你也可以在不同的单元操作里面加载person和event。或在<literal>Session</"
-"literal>以外修改不是处在持久化(persistent)状态下的对象(如果该对象以前曾经"
-"被持久化,那么我们称这个状态为<emphasis>脱管(detached)</emphasis>)。你甚至"
-"可以在一个集合被脱管时修改它:"
+"当然,你也可以在不同的单元操作里面加载 person 和 event。或在 "
+"<literal>Session</literal> 以外修改不是处在持久化(persistent)状态下的对象"
+"(如果该对象以前曾经被持久化,那么我们称这个状态为<emphasis>脱管(detached)"
+"</emphasis>)。你甚至可以在一个集合被脱管时修改它: "
 
-#. Tag: programlisting
-#: tutorial.xml:764
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session\n"
-"                .createQuery(\"select p from Person p left join fetch p."
-"events where p.id = :pid\")\n"
-"                .setParameter(\"pid\", personId)\n"
-"                .uniqueResult(); // Eager fetch the collection so we can use "
-"it detached\n"
-"        Event anEvent = (Event) session.load(Event.class, eventId);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"\n"
-"        // End of first unit of work\n"
-"\n"
-"        aPerson.getEvents().add(anEvent); // aPerson (and its collection) is "
-"detached\n"
-"\n"
-"        // Begin second unit of work\n"
-"\n"
-"        Session session2 = HibernateUtil.getSessionFactory()."
-"getCurrentSession();\n"
-"        session2.beginTransaction();\n"
-"        session2.update(aPerson); // Reattachment of aPerson\n"
-"\n"
-"        session2.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:766
-#, fuzzy, no-c-format
-msgid ""
 "The call to <literal>update</literal> makes a detached object persistent "
 "again by binding it to a new unit of work, so any modifications you made to "
 "it while detached can be saved to the database. This includes any "
 "modifications (additions/deletions) you made to a collection of that entity "
 "object."
 msgstr ""
-"对<literal>update</literal>的调用使一个脱管对象重新持久化,你可以说它被绑定到"
-"一个新的单元操作上,所以在脱管状态下对它所做的任何修改都会被保存到数据库里。"
-"这也包括你对这个实体对象的集合所作的任何改动(增加/删除)。"
+"对 <literal>update</literal> 的调用使一个脱管对象重新持久化,你可以说它被绑定"
+"到一个新的单元操作上,所以在脱管状态下对它所做的任何修改都会被保存到数据库"
+"里。这也包括你对这个实体对象的集合所作的任何改动(增加/删除)。 "
 
 #. Tag: para
-#: tutorial.xml:775
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This is not much use in our example, but it is an important concept you can "
 "incorporate into your own application. Complete this exercise by adding a "
@@ -1627,29 +1119,14 @@
 "to modify some of the previous methods to return that identifier):"
 msgstr ""
 "这对我们当前的情形不是很有用,但它是非常重要的概念,你可以把它融入到你自己的"
-"应用程序设计中。在<literal>EventManager</literal>的main方法中添加一个新的动"
-"作,并从命令行运行它来完成我们所做的练习。如果你需要person及event的标识符 — "
-"那就用<literal>save()</literal>方法返回它(你可能需要修改前面的一些方法来返回"
-"那个标识符):"
+"应用程序设计中。在<literal>EventManager</literal>的 main 方法中添加一个新的动"
+"作,并从命令行运行它来完成我们所做的练习。如果你需要 person 及 event 的标识"
+"符 — 那就用 <literal>save()</literal> 方法返回它(你可能需要修改前面的一些方"
+"法来返回那个标识符): "
 
-#. Tag: programlisting
-#: tutorial.xml:783
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[        else if (args[0].equals(\"addpersontoevent\")) {\n"
-"            Long eventId = mgr.createAndStoreEvent(\"My Event\", new Date"
-"());\n"
-"            Long personId = mgr.createAndStorePerson(\"Foo\", \"Bar\");\n"
-"            mgr.addPersonToEvent(personId, eventId);\n"
-"            System.out.println(\"Added person \" + personId + \" to event \" "
-"+ eventId);\n"
-"        }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:785
-#, fuzzy, no-c-format
-msgid ""
 "This is an example of an association between two equally important classes : "
 "two entities. As mentioned earlier, there are other classes and types in a "
 "typical model, usually \"less important\". Some you have already seen, like "
@@ -1665,76 +1142,49 @@
 msgstr ""
 "上面是个关于两个同等重要的实体类间关联的例子。像前面所提到的那样,在特定的模"
 "型中也存在其它的类和类型,这些类和类型通常是“次要的”。你已看到过其中的一些,"
-"像<literal>int</literal>或<literal>String</literal>。我们称这些类为<emphasis>"
-"值类型(value type)</emphasis>,它们的实例<emphasis>依赖(depend)</"
-"emphasis>在某个特定的实体上。这些类型的实例没有它们自己的标识(identity),也"
-"不能在实体间被共享(比如,两个person不能引用同一个<literal>firstname</"
-"literal>对象,即使他们有相同的first name)。当然,值类型并不仅仅在JDK中存在"
-"(事实上,在一个Hibernate应用程序中,所有的JDK类都被视为值类型),而且你也可"
-"以编写你自己的依赖类,例如<literal>Address</literal>,"
-"<literal>MonetaryAmount</literal>。"
+"像 <literal>int</literal> 或 <literal>String</literal>。我们称这些类为"
+"<emphasis>值类型(value type)</emphasis>,它们的实例<emphasis>依赖(depend)"
+"</emphasis>在某个特定的实体上。这些类型的实例没有它们自己的标识(identity),"
+"也不能在实体间被共享(比如,两个 person 不能引用同一个 <literal>firstname</"
+"literal> 对象,即使他们有相同的 first name)。当然,值类型并不仅仅在 JDK 中存"
+"在(事实上,在一个 Hibernate 应用程序中,所有的 JDK 类都被视为值类型),而且"
+"你也可以编写你自己的依赖类,例如 <literal>Address</literal>,"
+"<literal>MonetaryAmount</literal>。 "
 
 #. Tag: para
-#: tutorial.xml:803
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also design a collection of value types. This is conceptually "
 "different from a collection of references to other entities, but looks "
 "almost the same in Java."
 msgstr ""
 "你也可以设计一个值类型的集合,这在概念上与引用其它实体的集合有很大的不同,但"
-"是在Java里面看起来几乎是一样的。"
+"是在 Java 里面看起来几乎是一样的。 "
 
 #. Tag: title
-#: tutorial.xml:812
 #, no-c-format
 msgid "Collection of values"
 msgstr "值类型的集合"
 
 #. Tag: para
-#: tutorial.xml:814
 #, no-c-format
 msgid ""
 "Let's add a collection of email addresses to the <literal>Person</literal> "
 "entity. This will be represented as a <interfacename>java.util.Set</"
 "interfacename> of <classname>java.lang.String</classname> instances:"
 msgstr ""
+"让我们在 <literal>Person</literal> 实体里添加一个电子邮件的集合。这将以 "
+"<classname>java.lang.String</classname> 实例的 <interfacename>java.util.Set</"
+"interfacename> 出现:"
 
-#. Tag: programlisting
-#: tutorial.xml:820
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[    private Set emailAddresses = new HashSet();\n"
-"\n"
-"    public Set getEmailAddresses() {\n"
-"        return emailAddresses;\n"
-"    }\n"
-"\n"
-"    public void setEmailAddresses(Set emailAddresses) {\n"
-"        this.emailAddresses = emailAddresses;\n"
-"    }]]>"
-msgstr ""
+msgid "The mapping of this <literal>Set</literal> is as follows:"
+msgstr "这个 <literal>Set</literal> 的映射如下:"
 
 #. Tag: para
-#: tutorial.xml:822
-#, fuzzy, no-c-format
-msgid "The mapping of this <literal>Set</literal> is as follows:"
-msgstr "这个<literal>Set</literal>的映射"
-
-#. Tag: programlisting
-#: tutorial.xml:826
 #, no-c-format
 msgid ""
-"<![CDATA[        <set name=\"emailAddresses\" table=\"PERSON_EMAIL_ADDR\">\n"
-"            <key column=\"PERSON_ID\"/>\n"
-"            <element type=\"string\" column=\"EMAIL_ADDR\"/>\n"
-"        </set>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:828
-#, fuzzy, no-c-format
-msgid ""
 "The difference compared with the earlier mapping is the use of the "
 "<literal>element</literal> part which tells Hibernate that the collection "
 "does not contain references to another entity, but is rather a collection "
@@ -1747,175 +1197,97 @@
 "<literal>element</literal> element defines the column name where the email "
 "address values will actually be stored."
 msgstr ""
-"比较这次和此前映射的差别,主要在于<literal>element</literal>部分,这次并没有"
-"包含对其它实体引用的集合,而是元素类型为<literal>String</literal>的集合(在映"
-"射中使用小写的名字”string“是向你表明它是一个Hibernate的映射类型或者类型转换"
-"器)。和之前一样,<literal>set</literal>元素的<literal>table</literal>属性决"
-"定了用于集合的表名。<literal>key</literal>元素定义了在集合表中外键的字段名。"
-"<literal>element</literal>元素的<literal>column</literal>属性定义用于实际保存"
-"<literal>String</literal>值的字段名。"
+"比较这次和此前映射的差别,主要在于 <literal>element</literal> 部分,这次并没"
+"有包含对其它实体引用的集合,而是元素类型为 <literal>String</literal> 的集合"
+"(在映射中使用小写的名字”string“是向你表明它是一个 Hibernate 的映射类型或者类"
+"型转换器)。和之前一样,<literal>set</literal> 元素的 <literal>table</"
+"literal> 属性决定了用于集合的表名。<literal>key</literal> 元素定义了在集合表"
+"中外键的字段名。<literal>element</literal> 元素的 <literal>column</literal> "
+"属性定义用于实际保存 <literal>String</literal> 值的字段名。 "
 
 #. Tag: para
-#: tutorial.xml:844
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "Here is the updated schema:"
-msgstr "看一下修改后的数据库schema。"
+msgstr "看一下修改后的数据库 schema。 "
 
-#. Tag: programlisting
-#: tutorial.xml:848
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[\n"
-"  _____________        __________________\n"
-" |             |      |                  |       _____________\n"
-" |   EVENTS    |      |   PERSON_EVENT   |      |             |       "
-"___________________\n"
-" |_____________|      |__________________|      |    PERSON   |      "
-"|                   |\n"
-" |             |      |                  |      |_____________|      | "
-"PERSON_EMAIL_ADDR |\n"
-" | *EVENT_ID   | <--> | *EVENT_ID        |      |             |      |"
-"___________________|\n"
-" |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  | <--> |  "
-"*PERSON_ID       |\n"
-" |  TITLE      |      |__________________|      |  AGE        |      |  "
-"*EMAIL_ADDR      |\n"
-" |_____________|                                |  FIRSTNAME  |      |"
-"___________________|\n"
-"                                                |  LASTNAME   |\n"
-"                                                |_____________|\n"
-" ]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:850
-#, fuzzy, no-c-format
-msgid ""
 "You can see that the primary key of the collection table is in fact a "
 "composite key that uses both columns. This also implies that there cannot be "
 "duplicate email addresses per person, which is exactly the semantics we need "
 "for a set in Java."
 msgstr ""
-"你可以看到集合表的主键实际上是个复合主键,同时使用了2个字段。这也暗示了对于同"
-"一个person不能有重复的email地址,这正是Java里面使用Set时候所需要的语义(Set里"
-"元素不能重复)。"
+"你可以看到集合表的主键实际上是个复合主键,同时使用了两个字段。这也暗示了对于"
+"同一个 person 不能有重复的 email 地址,这正是 Java 里面使用 Set 时候所需要的"
+"语义(Set 里元素不能重复)。"
 
 #. Tag: para
-#: tutorial.xml:856
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can now try to add elements to this collection, just like we did before "
 "by linking persons and events. It is the same code in Java:"
 msgstr ""
-"你现在可以试着把元素加入到这个集合,就像我们在之前关联person和event的那样。其"
-"实现的Java代码是相同的:"
+"你现在可以试着把元素加入到这个集合,就像我们在之前关联 person 和 event 的那"
+"样。其实现的 Java 代码是相同的: "
 
-#. Tag: programlisting
-#: tutorial.xml:861
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    private void addEmailToPerson(Long personId, String "
-"emailAddress) {\n"
-"        Session session = HibernateUtil.getSessionFactory().getCurrentSession"
-"();\n"
-"        session.beginTransaction();\n"
-"\n"
-"        Person aPerson = (Person) session.load(Person.class, personId);\n"
-"        // adding to the emailAddress collection might trigger a lazy load "
-"of the collection\n"
-"        aPerson.getEmailAddresses().add(emailAddress);\n"
-"\n"
-"        session.getTransaction().commit();\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:863
-#, fuzzy, no-c-format
-msgid ""
 "This time we did not use a <emphasis>fetch</emphasis> query to initialize "
 "the collection. Monitor the SQL log and try to optimize this with an eager "
 "fetch."
 msgstr ""
-"这次我们没有使用<emphasis>fetch</emphasis>查询来初始化集合。因此,调用其"
-"getter方法会触发另一附加的select来初始化集合,这样我们才能把元素添加进去。检"
-"查SQL log,试着通过预先抓取来优化它。"
+"这次我们没有使用 <emphasis>fetch</emphasis> 查询来初始化集合。因此,调用其 "
+"getter 方法会触发另一附加的 select 来初始化集合,这样我们才能把元素添加进去。"
+"检查 SQL log,试着通过预先抓取来优化它。 "
 
 #. Tag: title
-#: tutorial.xml:872
 #, no-c-format
 msgid "Bi-directional associations"
 msgstr "双向关联"
 
 #. Tag: para
-#: tutorial.xml:874
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next you will map a bi-directional association. You will make the "
 "association between person and event work from both sides in Java. The "
 "database schema does not change, so you will still have many-to-many "
 "multiplicity."
 msgstr ""
-"接下来我们将映射双向关联(bi-directional association)- 在Java里让person和"
-"event可以从关联的任何一端访问另一端。当然,数据库schema没有改变,我们仍然需要"
-"多对多的阶数。一个关系型数据库要比网络编程语言 更加灵活,所以它并不需要任何像"
-"导航方向(navigation direction)的东西 - 数据可以用任何可能的方式进行查看和"
-"获取。"
+"接下来我们将映射双向关联(bi-directional association)— 在 Java 里让 person "
+"和 event 可以从关联的任何一端访问另一端。当然,数据库 schema 没有改变,我们仍"
+"然需要多对多的阶数。一个关系型数据库要比网络编程语言更加灵活,所以它并不需要"
+"任何像导航方向(navigation direction)的东西 — 数据可以用任何可能的方式进行查"
+"看和获取。 "
 
 #. Tag: para
-#: tutorial.xml:882
 #, no-c-format
 msgid ""
 "A relational database is more flexible than a network programming language, "
 "in that it does not need a navigation direction; data can be viewed and "
 "retrieved in any possible way."
 msgstr ""
+"关系型数据库比网络编程语言更为灵活,因为它不需要方向导航,其数据可以用任何可"
+"能的方式进行查看和提取。"
 
 #. Tag: para
-#: tutorial.xml:890
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, add a collection of participants to the <literal>Event</literal> "
 "class:"
-msgstr "首先,把一个参与者(person)的集合加入<literal>Event</literal>类中:"
-
-#. Tag: programlisting
-#: tutorial.xml:895
-#, no-c-format
-msgid ""
-"<![CDATA[    private Set participants = new HashSet();\n"
-"\n"
-"    public Set getParticipants() {\n"
-"        return participants;\n"
-"    }\n"
-"\n"
-"    public void setParticipants(Set participants) {\n"
-"        this.participants = participants;\n"
-"    }]]>"
 msgstr ""
+"首先,把一个参与者(person)的集合加入 <literal>Event</literal> 类中: "
 
 #. Tag: para
-#: tutorial.xml:897
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now map this side of the association in <literal>Event.hbm.xml</literal>."
-msgstr "在<literal>Event.hbm.xml</literal>里面也映射这个关联。"
+msgstr "在 <literal>Event.hbm.xml</literal> 里面也映射这个关联。 "
 
-#. Tag: programlisting
-#: tutorial.xml:901
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[        <set name=\"participants\" table=\"PERSON_EVENT\" inverse="
-"\"true\">\n"
-"            <key column=\"EVENT_ID\"/>\n"
-"            <many-to-many column=\"PERSON_ID\" class=\"events.Person\"/>\n"
-"        </set>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:903
-#, fuzzy, no-c-format
-msgid ""
 "These are normal <literal>set</literal> mappings in both mapping documents. "
 "Notice that the column names in <literal>key</literal> and <literal>many-to-"
 "many</literal> swap in both mapping documents. The most important addition "
@@ -1923,33 +1295,30 @@
 "<literal>set</literal> element of the <literal>Event</literal>'s collection "
 "mapping."
 msgstr ""
-"如你所见,两个映射文件里都有普通的<literal>set</literal>映射。注意在两个映射"
-"文件中,互换了<literal>key</literal>和<literal>many-to-many</literal>的字段"
-"名。这里最重要的是<literal>Event</literal>映射文件里增加了<literal>set</"
-"literal>元素的<literal>inverse=\"true\"</literal>属性。"
+"如你所见,两个映射文件里都有普通的 <literal>set</literal> 映射。注意在两个映"
+"射文件中,互换了 <literal>key</literal> 和 <literal>many-to-many</literal> 的"
+"字段名。这里最重要的是 <literal>Event</literal> 映射文件里增加了 "
+"<literal>set</literal> 元素的 <literal>inverse=\"true\"</literal> 属性。 "
 
 #. Tag: para
-#: tutorial.xml:911
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What this means is that Hibernate should take the other side, the "
 "<literal>Person</literal> class, when it needs to find out information about "
 "the link between the two. This will be a lot easier to understand once you "
 "see how the bi-directional link between our two entities is created."
 msgstr ""
-"这意味着在需要的时候,Hibernate能在关联的另一端 - <literal>Person</literal>"
+"这意味着在需要的时候,Hibernate 能在关联的另一端 — <literal>Person</literal> "
 "类得到两个实体间关联的信息。这将会极大地帮助你理解双向关联是如何在两个实体间"
-"被创建的。"
+"被创建的。 "
 
 #. Tag: title
-#: tutorial.xml:920
 #, no-c-format
 msgid "Working bi-directional links"
 msgstr "使双向连起来"
 
 #. Tag: para
-#: tutorial.xml:922
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First, keep in mind that Hibernate does not affect normal Java semantics. "
 "How did we create a link between a <literal>Person</literal> and an "
@@ -1961,63 +1330,38 @@
 "literal>. This process of \"setting the link on both sides\" is absolutely "
 "necessary with bi-directional links."
 msgstr ""
-"首先请记住,Hibernate并不影响通常的Java语义。 在单向关联的例子中,我们是怎样"
-"在<literal>Person</literal>和<literal>Event</literal>之间创建联系的?我们把"
-"<literal>Event</literal>实例添加到<literal>Person</literal>实例内的event引用"
-"集合里。因此很显然,如果我们要让这个关联可以双向地工作,我们需要在另外一端做"
-"同样的事情 - 把<literal>Person</literal>实例加入<literal>Event</literal>类内"
-"的Person引用集合。这“在关联的两端设置联系”是完全必要的而且你都得这么做。"
+"首先请记住,Hibernate 并不影响通常的 Java 语义。 在单向关联的例子中,我们是怎"
+"样在 <literal>Person</literal> 和 <literal>Event</literal> 之间创建联系的?我"
+"们把 <literal>Event</literal> 实例添加到 <literal>Person</literal> 实例内的 "
+"event 引用集合里。因此很显然,如果我们要让这个关联可以双向地工作,我们需要在"
+"另外一端做同样的事情 - 把 <literal>Person</literal> 实例加入 "
+"<literal>Event</literal> 类内的 Person 引用集合。这“在关联的两端设置联系”是完"
+"全必要的而且你都得这么做。 "
 
 #. Tag: para
-#: tutorial.xml:932
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Many developers program defensively and create link management methods to "
 "correctly set both sides (for example, in <literal>Person</literal>):"
 msgstr ""
 "许多开发人员防御式地编程,创建管理关联的方法来保证正确的设置了关联的两端,比"
-"如在<literal>Person</literal>里:"
+"如在 <literal>Person</literal> 里: "
 
-#. Tag: programlisting
-#: tutorial.xml:937
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    protected Set getEvents() {\n"
-"        return events;\n"
-"    }\n"
-"\n"
-"    protected void setEvents(Set events) {\n"
-"        this.events = events;\n"
-"    }\n"
-"\n"
-"    public void addToEvent(Event event) {\n"
-"        this.getEvents().add(event);\n"
-"        event.getParticipants().add(this);\n"
-"    }\n"
-"\n"
-"    public void removeFromEvent(Event event) {\n"
-"        this.getEvents().remove(event);\n"
-"        event.getParticipants().remove(this);\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:939
-#, fuzzy, no-c-format
-msgid ""
 "The get and set methods for the collection are now protected. This allows "
 "classes in the same package and subclasses to still access the methods, but "
 "prevents everybody else from altering the collections directly. Repeat the "
 "steps for the collection on the other side."
 msgstr ""
-"注意现在对于集合的get和set方法的访问级别是protected - 这允许在位于同一个包"
-"(package)中的类以及继承自这个类的子类可以访问这些方法,但禁止其他任何人的直"
-"接访问,避免了集合内容的混乱。你应尽可能地在另一端也把集合的访问级别设成"
-"protected。"
+"注意现在对于集合的 get 和 set 方法的访问级别是 protected — 这允许在位于同一个"
+"包(package)中的类以及继承自这个类的子类可以访问这些方法,但禁止其他任何人的"
+"直接访问,避免了集合内容的混乱。你应尽可能地在另一端也把集合的访问级别设成 "
+"protected。 "
 
 #. Tag: para
-#: tutorial.xml:946
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "What about the <literal>inverse</literal> mapping attribute? For you, and "
 "for Java, a bi-directional link is simply a matter of setting the references "
@@ -2032,26 +1376,24 @@
 "as <literal>inverse</literal>. In a one-to-many association it has to be the "
 "many-side, and in many-to-many association you can select either side."
 msgstr ""
-"<literal>inverse</literal>映射属性究竟表示什么呢?对于你和Java来说,一个双向"
-"关联仅仅是在两端简单地正确设置引用。然而,Hibernate并没有足够的信息去正确地执"
-"行<literal>INSERT</literal>和<literal>UPDATE</literal>语句(以避免违反数据库"
-"约束),所以它需要一些帮助来正确的处理双向关联。把关联的一端设置为"
-"<literal>inverse</literal>将告诉Hibernate忽略关联的这一端,把这端看成是另外一"
-"端的一个<emphasis>镜象(mirror)</emphasis>。这就是所需的全部信息,Hibernate"
-"利用这些信息来处理把一个有向导航模型转移到数据库schema时的所有问题。你只需要"
-"记住这个直观的规则:所有的双向关联需要有一端被设置为<literal>inverse</"
-"literal>。在一对多关联中它必须是代表多(many)的那端。而在多对多(many-to-"
-"many)关联中,你可以任意选取一端,因为两端之间并没有差别。"
+"<literal>inverse</literal> 映射属性究竟表示什么呢?对于你和 Java 来说,一个双"
+"向关联仅仅是在两端简单地正确设置引用。然而,Hibernate 并没有足够的信息去正确"
+"地执行 <literal>INSERT</literal> 和 <literal>UPDATE</literal> 语句(以避免违"
+"反数据库约束),所以它需要一些帮助来正确的处理双向关联。把关联的一端设置为 "
+"<literal>inverse</literal> 将告诉 Hibernate 忽略关联的这一端,把这端看成是另"
+"外一端的一个<emphasis>镜象(mirror)</emphasis>。这就是所需的全部信息,"
+"Hibernate 利用这些信息来处理把一个有向导航模型转移到数据库 schema 时的所有问"
+"题。你只需要记住这个直观的规则:所有的双向关联需要有一端被设置为 "
+"<literal>inverse</literal>。在一对多关联中它必须是代表多(many)的那端。而在"
+"多对多(many-to-many)关联中,你可以任意选取一端,因为两端之间并没有差别。 "
 
 #. Tag: title
-#: tutorial.xml:962
 #, no-c-format
 msgid "Part 3 - The EventManager web application"
-msgstr "第三部分 - EventManager web应用程序"
+msgstr "第三部分 - EventManager web 应用程序"
 
 #. Tag: para
-#: tutorial.xml:964
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A Hibernate web application uses <literal>Session</literal> and "
 "<literal>Transaction</literal> almost like a standalone application. "
@@ -2059,83 +1401,38 @@
 "<literal>EventManagerServlet</literal>. This servlet can list all events "
 "stored in the database, and it provides an HTML form to enter new events."
 msgstr ""
-"Hibernate web应用程序使用<literal>Session</literal> 和<literal>Transaction</"
-"literal>的方式几乎和独立应用程序是一样的。但是,有一些常见的模式(pattern)非"
-"常有用。现在我们编写一个<literal>EventManagerServlet</literal>。这个servlet可"
-"以列出数据库中保存的所有的events,还提供一个HTML表单来增加新的events。"
+"Hibernate web 应用程序使用 <literal>Session</literal> 和 "
+"<literal>Transaction</literal> 的方式几乎和独立应用程序是一样的。但是,有一些"
+"常见的模式(pattern)非常有用。现在我们编写一个 "
+"<literal>EventManagerServlet</literal>。这个 servlet 可以列出数据库中保存的所"
+"有的 events,还提供一个 HTML 表单来增加新的 events。 "
 
 #. Tag: title
-#: tutorial.xml:972
 #, no-c-format
 msgid "Writing the basic servlet"
-msgstr "编写基本的servlet"
+msgstr "编写基本的 servlet"
 
 #. Tag: para
-#: tutorial.xml:974
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "First we need create our basic processing servlet. Since our servlet only "
 "handles HTTP <literal>GET</literal> requests, we will only implement the "
 "<literal>doGet()</literal> method:"
 msgstr ""
-"我们后面会用到<literal>dateFormatter</literal> 的工具, 它把<literal>Date</"
-"literal>对象转换为字符串。只要一个formatter作为servlet的成员就可以了。"
+"这个 servlet 只处理 HTTP <literal>GET</literal> 请求,因此,我们要实现的是 "
+"<literal>doGet()</literal> 方法: "
 
-#. Tag: programlisting
-#: tutorial.xml:980
-#, no-c-format
-msgid ""
-"<![CDATA[package org.hibernate.tutorial.web;\n"
-"\n"
-"// Imports\n"
-"\n"
-"public class EventManagerServlet extends HttpServlet {\n"
-"\n"
-"    protected void doGet(\n"
-"            HttpServletRequest request,\n"
-"            HttpServletResponse response) throws ServletException, "
-"IOException {\n"
-"\n"
-"        SimpleDateFormat dateFormatter = new SimpleDateFormat( \"dd.MM.yyyy"
-"\" );\n"
-"\n"
-"        try {\n"
-"            // Begin unit of work\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"beginTransaction();\n"
-"\n"
-"            // Process request and render page...\n"
-"\n"
-"            // End unit of work\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"getTransaction().commit();\n"
-"        }\n"
-"        catch (Exception ex) {\n"
-"            HibernateUtil.getSessionFactory().getCurrentSession()."
-"getTransaction().rollback();\n"
-"            if ( ServletException.class.isInstance( ex ) ) {\n"
-"                throw ( ServletException ) ex;\n"
-"            }\n"
-"            else {\n"
-"                throw new ServletException( ex );\n"
-"            }\n"
-"        }\n"
-"    }\n"
-"\n"
-"}]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:982
 #, no-c-format
 msgid ""
 "Save this servlet as <filename>src/main/java/org/hibernate/tutorial/web/"
 "EventManagerServlet.java</filename>"
 msgstr ""
+"把这个 servlet 保存为 <filename>src/main/java/org/hibernate/tutorial/web/"
+"EventManagerServlet.java</filename>。"
 
 #. Tag: para
-#: tutorial.xml:987
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "The pattern applied here is called <emphasis>session-per-request</emphasis>. "
 "When a request hits the servlet, a new Hibernate <literal>Session</literal> "
@@ -2144,11 +1441,13 @@
 "started. All data access occurs inside a transaction irrespective of whether "
 "the data is read or written. Do not use the auto-commit mode in applications."
 msgstr ""
-"这个servlet只处理 HTTP <literal>GET</literal> 请求,因此,我们要实现的是"
-"<literal>doGet()</literal>方法:"
+"我们称这里应用的模式为每次请求一个 session<emphasis>(session-per-request)</"
+"emphasis>。当有请求到达这个 servlet 的时候,通过对 <literal>SessionFactory</"
+"literal> 的第一次调用,打开一个新的 Hibernate <literal>Session</literal>。然"
+"后启动一个数据库事务 — 所有的数据访问都是在事务中进行,不管是读还是写(我们在"
+"应用程序中不使用 auto-commit 模式)。 "
 
 #. Tag: para
-#: tutorial.xml:996
 #, no-c-format
 msgid ""
 "Do <emphasis>not</emphasis> use a new Hibernate <literal>Session</literal> "
@@ -2156,27 +1455,22 @@
 "that is scoped to the whole request. Use <literal>getCurrentSession()</"
 "literal>, so that it is automatically bound to the current Java thread."
 msgstr ""
-"我们称这里应用的模式为每次请求一个session<emphasis>(session-per-request)</"
-"emphasis>。当有请求到达这个servlet的时候,通过对<literal>SessionFactory</"
-"literal>的第一次调用,打开一个新的Hibernate <literal>Session</literal>。然后"
-"启动一个数据库事务&mdash;所有的数据访问都是在事务中进行,不管是读还是写(我们"
-"在应用程序中不使用auto-commit模式)。"
+"<emphasis>不要</emphasis>为每次数据库操作都使用一个新的 Hibernate "
+"<literal>Session</literal>。将 Hibernate <literal>Session</literal> 的范围设"
+"置为整个请求。要用 <literal>getCurrentSession()</literal>,这样它自动会绑定到"
+"当前 Java 线程。"
 
 #. Tag: para
-#: tutorial.xml:1003
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Next, the possible actions of the request are processed and the response "
 "HTML is rendered. We will get to that part soon."
 msgstr ""
-"<emphasis>不要</emphasis>为每次数据库操作都使用一个新的Hibernate "
-"<literal>Session</literal>。将Hibernate <literal>Session</literal>的范围设置"
-"为整个请求。要用<literal>getCurrentSession()</literal>,这样它自动会绑定到当"
-"前Java线程。"
+"下一步,对请求的可能动作进行处理,渲染出反馈的 HTML。我们很快就会涉及到那部"
+"分。 "
 
 #. Tag: para
-#: tutorial.xml:1008
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Finally, the unit of work ends when processing and rendering are complete. "
 "If any problems occurred during processing or rendering, an exception will "
@@ -2187,165 +1481,63 @@
 "called <emphasis>Open Session in View</emphasis>. You will need it as soon "
 "as you consider rendering your view in JSP, not in a servlet."
 msgstr ""
-"下一步,对请求的可能动作进行处理,渲染出反馈的HTML。我们很快就会涉及到那部"
-"分。"
+"最后,当处理与渲染都结束的时候,这个工作单元就结束了。假若在处理或渲染的时候"
+"有任何错误发生,会抛出一个异常,回滚数据库事务。这样,<literal>session-per-"
+"request</literal> 模式就完成了。为了避免在每个 servlet 中都编写事务边界界定的"
+"代码,可以考虑写一个 servlet 过滤器(filter)来更好地解决。关于这一模式的更多"
+"信息,请参阅 Hibernate 网站和 Wiki,这一模式叫做 <emphasis>Open Session in "
+"View</emphasis> — 只要你考虑用JSP来渲染你的视图(view),而不是在servlet中,"
+"你就会很快用到它。 "
 
 #. Tag: title
-#: tutorial.xml:1022
 #, no-c-format
 msgid "Processing and rendering"
-msgstr ""
-"最后,当处理与渲染都结束的时候,这个工作单元就结束了。假若在处理或渲染的时候"
-"有任何错误发生,会抛出一个异常,回滚数据库事务。这样,<literal>session-per-"
-"request</literal>模式就完成了。为了避免在每个servlet中都编写事务边界界定的代"
-"码,可以考虑写一个servlet 过滤器(filter)来更好地解决。关于这一模式的更多信"
-"息,请参阅Hibernate网站和Wiki,这一模式叫做<emphasis>Open Session in View</"
-"emphasis>&mdash;只要你考虑用JSP来渲染你的视图(view),而不是在servlet中,你"
-"就会很快用到它。"
+msgstr "处理与渲染"
 
 #. Tag: para
-#: tutorial.xml:1024
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Now you can implement the processing of the request and the rendering of the "
 "page."
-msgstr "处理与渲染"
+msgstr "我们来实现处理请求以及渲染页面的工作。 "
 
-#. Tag: programlisting
-#: tutorial.xml:1028
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[        // Write HTML header\n"
-"        PrintWriter out = response.getWriter();\n"
-"        out.println(\"<html><head><title>Event Manager</title></head><body>"
-"\");\n"
-"\n"
-"        // Handle actions\n"
-"        if ( \"store\".equals(request.getParameter(\"action\")) ) {\n"
-"\n"
-"            String eventTitle = request.getParameter(\"eventTitle\");\n"
-"            String eventDate = request.getParameter(\"eventDate\");\n"
-"\n"
-"            if ( \"\".equals(eventTitle) || \"\".equals(eventDate) ) {\n"
-"                out.println(\"<b><i>Please enter event title and date.</i></"
-"b>\");\n"
-"            }\n"
-"            else {\n"
-"                createAndStoreEvent(eventTitle, dateFormatter.parse"
-"(eventDate));\n"
-"                out.println(\"<b><i>Added event.</i></b>\");\n"
-"            }\n"
-"        }\n"
-"\n"
-"        // Print page\n"
-"       printEventForm(out);\n"
-"       listEvents(out, dateFormatter);\n"
-"\n"
-"       // Write HTML footer\n"
-"       out.println(\"</body></html>\");\n"
-"       out.flush();\n"
-"       out.close();]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:1030
-#, fuzzy, no-c-format
-msgid ""
 "This coding style, with a mix of Java and HTML, would not scale in a more "
 "complex application&mdash;keep in mind that we are only illustrating basic "
 "Hibernate concepts in this tutorial. The code prints an HTML header and a "
 "footer. Inside this page, an HTML form for event entry and a list of all "
 "events in the database are printed. The first method is trivial and only "
 "outputs HTML:"
-msgstr "我们来实现处理请求以及渲染页面的工作。"
-
-#. Tag: programlisting
-#: tutorial.xml:1039
-#, no-c-format
-msgid ""
-"<![CDATA[    private void printEventForm(PrintWriter out) {\n"
-"        out.println(\"<h2>Add new event:</h2>\");\n"
-"        out.println(\"<form>\");\n"
-"        out.println(\"Title: <input name='eventTitle' length='50'/><br/>"
-"\");\n"
-"        out.println(\"Date (e.g. 24.12.2009): <input name='eventDate' "
-"length='10'/><br/>\");\n"
-"        out.println(\"<input type='submit' name='action' value='store'/>"
-"\");\n"
-"        out.println(\"</form>\");\n"
-"    }]]>"
 msgstr ""
+"必须承认,这种编码风格把 Java 和 HTML 混在一起,在更复杂的应用程序里不应该大"
+"量使用 — 记住,在本章里我们仅仅是展示了 Hibernate 的基本概念。这段代码打印出"
+"了 HTML 页眉和页脚,在这个页面里,还打印了一个输入 events 条目的表单单并列出"
+"了数据库里的有的 events。第一个方法微不足道,仅仅是输出 HTML:"
 
 #. Tag: para
-#: tutorial.xml:1041
 #, no-c-format
 msgid ""
 "The <literal>listEvents()</literal> method uses the Hibernate "
 "<literal>Session</literal> bound to the current thread to execute a query:"
 msgstr ""
-"<literal>listEvents()</literal>方法使用绑定到当前线程的Hibernate "
-"<literal>Session</literal>来执行查询:"
+"<literal>listEvents()</literal> 方法使用绑定到当前线程的 Hibernate "
+"<literal>Session</literal> 来执行查询:"
 
-#. Tag: programlisting
-#: tutorial.xml:1047
-#, no-c-format
-msgid ""
-"<![CDATA[    private void listEvents(PrintWriter out, SimpleDateFormat "
-"dateFormatter) {\n"
-"\n"
-"        List result = HibernateUtil.getSessionFactory()\n"
-"                .getCurrentSession().createCriteria(Event.class).list();\n"
-"        if (result.size() > 0) {\n"
-"            out.println(\"<h2>Events in database:</h2>\");\n"
-"            out.println(\"<table border='1'>\");\n"
-"            out.println(\"<tr>\");\n"
-"            out.println(\"<th>Event title</th>\");\n"
-"            out.println(\"<th>Event date</th>\");\n"
-"            out.println(\"</tr>\");\n"
-"            Iterator it = result.iterator();\n"
-"            while (it.hasNext()) {\n"
-"                Event event = (Event) it.next();\n"
-"                out.println(\"<tr>\");\n"
-"                out.println(\"<td>\" + event.getTitle() + \"</td>\");\n"
-"                out.println(\"<td>\" + dateFormatter.format(event.getDate()) "
-"+ \"</td>\");\n"
-"                out.println(\"</tr>\");\n"
-"            }\n"
-"            out.println(\"</table>\");\n"
-"        }\n"
-"    }]]>"
-msgstr ""
-
 #. Tag: para
-#: tutorial.xml:1049
 #, no-c-format
 msgid ""
 "Finally, the <literal>store</literal> action is dispatched to the "
 "<literal>createAndStoreEvent()</literal> method, which also uses the "
 "<literal>Session</literal> of the current thread:"
 msgstr ""
-"最后,<literal>store</literal>动作会被导向到<literal>createAndStoreEvent()</"
-"literal>方法,它也使用当前线程的<literal>Session</literal>:"
+"最后,<literal>store</literal> 动作会被导向到 <literal>createAndStoreEvent()"
+"</literal> 方法,它也使用当前线程的 <literal>Session</literal>:"
 
-#. Tag: programlisting
-#: tutorial.xml:1055
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[    protected void createAndStoreEvent(String title, Date theDate) "
-"{\n"
-"        Event theEvent = new Event();\n"
-"        theEvent.setTitle(title);\n"
-"        theEvent.setDate(theDate);\n"
-"\n"
-"        HibernateUtil.getSessionFactory()\n"
-"                .getCurrentSession().save(theEvent);\n"
-"    }]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:1057
-#, fuzzy, no-c-format
-msgid ""
 "The servlet is now complete. A request to the servlet will be processed in a "
 "single <literal>Session</literal> and <literal>Transaction</literal>. As "
 "earlier in the standalone application, Hibernate can automatically bind "
@@ -2355,76 +1547,51 @@
 "data access code into data access objects (the DAO pattern). See the "
 "Hibernate Wiki for more examples."
 msgstr ""
-"大功告成,这个servlet写完了。Hibernate会在单一的<literal>Session</literal> 和"
-"<literal>Transaction</literal>中处理到达的servlet请求。如同在前面的独立应用程"
-"序中那样,Hibernate可以自动的把这些对象绑定到当前运行的线程中。这给了你用任何"
-"你喜欢的方式来对代码分层及访问<literal>SessionFactory</literal>的自由。通常,"
-"你会用更加完备的设计,把数据访问代码转移到数据访问对象中(DAO模式)。请参见"
-"Hibernate Wiki,那里有更多的例子。"
+"大功告成,这个 servlet 写完了。Hibernate 会在单一的 <literal>Session</"
+"literal> 和 <literal>Transaction</literal> 中处理到达的 servlet 请求。如同在"
+"前面的独立应用程序中那样,Hibernate 可以自动的把这些对象绑定到当前运行的线程"
+"中。这给了你用任何你喜欢的方式来对代码分层及访问 <literal>SessionFactory</"
+"literal> 的自由。通常,你会用更加完备的设计,把数据访问代码转移到数据访问对象"
+"中(DAO 模式)。请参见 Hibernate Wiki,那里有更多的例子。 "
 
 #. Tag: title
-#: tutorial.xml:1071
 #, no-c-format
 msgid "Deploying and testing"
 msgstr "部署与测试"
 
 #. Tag: para
-#: tutorial.xml:1073
 #, no-c-format
 msgid ""
 "To deploy this application for testing we must create a Web ARchive (WAR). "
 "First we must define the WAR descriptor as <filename>src/main/webapp/WEB-INF/"
 "web.xml</filename>"
 msgstr ""
+"要部署这个应用程序以进行测试,我们必须出具一个 Web ARchive (WAR)。首先我们必"
+"须定义 WAR 描述符为 <filename>src/main/webapp/WEB-INF/web.xml</filename>。"
 
-#. Tag: programlisting
-#: tutorial.xml:1079
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
-"<web-app version=\"2.4\"\n"
-"    xmlns=\"http://java.sun.com/xml/ns/j2ee\"\n"
-"    xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
-"    xsi:schemaLocation=\"http://java.sun.com/xml/ns/j2ee http://java.sun.com/"
-"xml/ns/j2ee/web-app_2_4.xsd\">\n"
-"\n"
-"    <servlet>\n"
-"        <servlet-name>Event Manager</servlet-name>\n"
-"        <servlet-class>org.hibernate.tutorial.web.EventManagerServlet</"
-"servlet-class>\n"
-"    </servlet>\n"
-"\n"
-"    <servlet-mapping>\n"
-"        <servlet-name>Event Manager</servlet-name>\n"
-"        <url-pattern>/eventmanager</url-pattern>\n"
-"    </servlet-mapping>\n"
-"</web-app>]]>"
-msgstr ""
-
-#. Tag: para
-#: tutorial.xml:1081
-#, fuzzy, no-c-format
-msgid ""
 "To build and deploy call <literal>mvn package</literal> in your project "
 "directory and copy the <filename>hibernate-tutorial.war</filename> file into "
 "your Tomcat <filename>webapps</filename> directory."
 msgstr ""
-"在你的开发目录中,调用<literal>ant war</literal>来构建、打包,然后把"
-"<literal>hibernate-tutorial.war</literal>文件拷贝到你的tomcat的"
-"<literal>webapps</literal>目录下。假若你还没安装Tomcat,就去下载一个,按照指"
-"南来安装。对此应用的发布,你不需要修改任何Tomcat的配置。"
+"在你的开发目录中,调用 <literal>ant war</literal> 来构建、打包,然后把 "
+"<literal>hibernate-tutorial.war</literal> 文件拷贝到你的 tomcat 的 "
+"<literal>webapps</literal> 目录下。假若你还没安装 Tomcat,就去下载一个,按照"
+"指南来安装。对此应用的发布,你不需要修改任何 Tomcat 的配置。 "
 
 #. Tag: para
-#: tutorial.xml:1088
-#, no-c-format
+#, fuzzy, no-c-format
 msgid ""
 "If you do not have Tomcat installed, download it from <ulink url=\"http://"
-"tomcat.apache.org/\"></ulink> and follow the installation instructions. Our "
+"tomcat.apache.org/\" /> and follow the installation instructions. Our "
 "application requires no changes to the standard Tomcat configuration."
 msgstr ""
+"如果你还没有安装 Tomcat,请从 <ulink url=\"http://tomcat.apache.org/\" /> 下"
+"载并按照安装说明进行安装。我们的应用程序不需要对标准的 Tomcat 配置进行修改。"
 
 #. Tag: para
-#: tutorial.xml:1096
 #, no-c-format
 msgid ""
 "Once deployed and Tomcat is running, access the application at "
@@ -2434,376 +1601,1293 @@
 "<literal>HibernateUtil</literal> is called) and to get the detailed output "
 "if any exceptions occurs."
 msgstr ""
-"在部署完,启动Tomcat之后,通过<literal>http://localhost:8080/hibernate-"
-"tutorial/eventmanager</literal>进行访问你的应用,在第一次servlet 请求发生时,"
-"请在Tomcat log中确认你看到Hibernate被初始化了(<literal>HibernateUtil</"
-"literal>的静态初始化器被调用),假若有任何异常抛出,也可以看到详细的输出。"
+"在部署完,启动 Tomcat 之后,通过 <literal>http://localhost:8080/hibernate-"
+"tutorial/eventmanager</literal> 进行访问你的应用,在第一次 servlet 请求发生"
+"时,请在 Tomcat log 中确认你看到 Hibernate 被初始化了"
+"(<literal>HibernateUtil</literal> 的静态初始化器被调用),假若有任何异常抛"
+"出,也可以看到详细的输出。"
 
 #. Tag: title
-#: tutorial.xml:1109
 #, no-c-format
 msgid "Summary"
 msgstr "总结"
 
 #. Tag: para
-#: tutorial.xml:1111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "This tutorial covered the basics of writing a simple standalone Hibernate "
 "application and a small web application. More tutorials are available from "
 "the Hibernate <ulink url=\"http://hibernate.org\">website</ulink>."
 msgstr ""
-"本章覆盖了如何编写一个简单独立的Hibernate命令行应用程序及小型的Hibernate web"
-"应用程序的基本要素。"
+"本章覆盖了如何编写一个简单独立的 Hibernate 命令行应用程序及小型的 Hibernate "
+"web 应用程序的基本要素。更多的教程可以在 <ulink url=\"http://hibernate.org"
+"\">website</ulink> 上找到。"
 
-#~ msgid "Introduction to Hibernate"
-#~ msgstr "Hibernate入门"
+#~ msgid ""
+#~ "<![CDATA[<project xmlns=\"http://maven.apache.org/POM/4.0.0\"\n"
+#~ "         xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
+#~ "         xsi:schemaLocation=\"http://maven.apache.org/POM/4.0.0 http://"
+#~ "maven.apache.org/xsd/maven-4.0.0.xsd\">\n"
+#~ "\n"
+#~ "    <modelVersion>4.0.0</modelVersion>\n"
+#~ "\n"
+#~ "    <groupId>org.hibernate.tutorials</groupId>\n"
+#~ "    <artifactId>hibernate-tutorial</artifactId>\n"
+#~ "    <version>1.0.0-SNAPSHOT</version>\n"
+#~ "    <name>First Hibernate Tutorial</name>\n"
+#~ "\n"
+#~ "    <build>\n"
+#~ "         <!-- we dont want the version to be part of the generated war "
+#~ "file name -->\n"
+#~ "         <finalName>${artifactId}</finalName>\n"
+#~ "    </build>\n"
+#~ "\n"
+#~ "    <dependencies>\n"
+#~ "        <dependency>\n"
+#~ "            <groupId>org.hibernate</groupId>\n"
+#~ "            <artifactId>hibernate-core</artifactId>\n"
+#~ "        </dependency>\n"
+#~ "\n"
+#~ "        <!-- Because this is a web app, we also have a dependency on the "
+#~ "servlet api. -->\n"
+#~ "        <dependency>\n"
+#~ "            <groupId>javax.servlet</groupId>\n"
+#~ "            <artifactId>servlet-api</artifactId>\n"
+#~ "        </dependency>\n"
+#~ "\n"
+#~ "        <!-- Hibernate uses slf4j for logging, for our purposes here use "
+#~ "the simple backend -->\n"
+#~ "        <dependency>\n"
+#~ "            <groupId>org.slf4j</groupId>\n"
+#~ "            <artifactId>slf4j-simple</artifactId>\n"
+#~ "        </dependency>\n"
+#~ "\n"
+#~ "        <!-- Hibernate gives you a choice of bytecode providers between "
+#~ "cglib and javassist -->\n"
+#~ "        <dependency>\n"
+#~ "            <groupId>javassist</groupId>\n"
+#~ "            <artifactId>javassist</artifactId>\n"
+#~ "        </dependency>\n"
+#~ "    </dependencies>\n"
+#~ "\n"
+#~ "</project>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<project xmlns=\"http://maven.apache.org/POM/4.0.0\"\n"
+#~ "         xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
+#~ "         xsi:schemaLocation=\"http://maven.apache.org/POM/4.0.0 http://"
+#~ "maven.apache.org/xsd/maven-4.0.0.xsd\">\n"
+#~ "\n"
+#~ "    <modelVersion>4.0.0</modelVersion>\n"
+#~ "\n"
+#~ "    <groupId>org.hibernate.tutorials</groupId>\n"
+#~ "    <artifactId>hibernate-tutorial</artifactId>\n"
+#~ "    <version>1.0.0-SNAPSHOT</version>\n"
+#~ "    <name>First Hibernate Tutorial</name>\n"
+#~ "\n"
+#~ "    <build>\n"
+#~ "         <!-- we dont want the version to be part of the generated war "
+#~ "file name -->\n"
+#~ "         <finalName>${artifactId}</finalName>\n"
+#~ "    </build>\n"
+#~ "\n"
+#~ "    <dependencies>\n"
+#~ "        <dependency>\n"
+#~ "            <groupId>org.hibernate</groupId>\n"
+#~ "            <artifactId>hibernate-core</artifactId>\n"
+#~ "        </dependency>\n"
+#~ "\n"
+#~ "        <!-- Because this is a web app, we also have a dependency on the "
+#~ "servlet api. -->\n"
+#~ "        <dependency>\n"
+#~ "            <groupId>javax.servlet</groupId>\n"
+#~ "            <artifactId>servlet-api</artifactId>\n"
+#~ "        </dependency>\n"
+#~ "\n"
+#~ "        <!-- Hibernate uses slf4j for logging, for our purposes here use "
+#~ "the simple backend -->\n"
+#~ "        <dependency>\n"
+#~ "            <groupId>org.slf4j</groupId>\n"
+#~ "            <artifactId>slf4j-simple</artifactId>\n"
+#~ "        </dependency>\n"
+#~ "\n"
+#~ "        <!-- Hibernate gives you a choice of bytecode providers between "
+#~ "cglib and javassist -->\n"
+#~ "        <dependency>\n"
+#~ "            <groupId>javassist</groupId>\n"
+#~ "            <artifactId>javassist</artifactId>\n"
+#~ "        </dependency>\n"
+#~ "    </dependencies>\n"
+#~ "\n"
+#~ "</project>]]>"
 
-#~ msgid "Preface"
-#~ msgstr "前言"
+#~ msgid ""
+#~ "<![CDATA[package org.hibernate.tutorial.domain;\n"
+#~ "\n"
+#~ "import java.util.Date;\n"
+#~ "\n"
+#~ "public class Event {\n"
+#~ "    private Long id;\n"
+#~ "\n"
+#~ "    private String title;\n"
+#~ "    private Date date;\n"
+#~ "\n"
+#~ "    public Event() {}\n"
+#~ "\n"
+#~ "    public Long getId() {\n"
+#~ "        return id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    private void setId(Long id) {\n"
+#~ "        this.id = id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public Date getDate() {\n"
+#~ "        return date;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setDate(Date date) {\n"
+#~ "        this.date = date;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public String getTitle() {\n"
+#~ "        return title;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setTitle(String title) {\n"
+#~ "        this.title = title;\n"
+#~ "    }\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "<![CDATA[package org.hibernate.tutorial.domain;\n"
+#~ "\n"
+#~ "import java.util.Date;\n"
+#~ "\n"
+#~ "public class Event {\n"
+#~ "    private Long id;\n"
+#~ "\n"
+#~ "    private String title;\n"
+#~ "    private Date date;\n"
+#~ "\n"
+#~ "    public Event() {}\n"
+#~ "\n"
+#~ "    public Long getId() {\n"
+#~ "        return id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    private void setId(Long id) {\n"
+#~ "        this.id = id;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public Date getDate() {\n"
+#~ "        return date;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setDate(Date date) {\n"
+#~ "        this.date = date;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public String getTitle() {\n"
+#~ "        return title;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setTitle(String title) {\n"
+#~ "        this.title = title;\n"
+#~ "    }\n"
+#~ "}]]>"
 
 #~ msgid ""
-#~ "This chapter is an introductory tutorial for new users of Hibernate. We "
-#~ "start with a simple command line application using an in-memory database "
-#~ "and develop it in easy to understand steps."
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
+#~ "[...]\n"
+#~ "</hibernate-mapping>]]>"
 #~ msgstr ""
-#~ "本章是面向Hibernate初学者的一个入门教程。我们从一个使用驻留内存式(in-"
-#~ "memory)数据库的简单命令行应用程序开始, 用易于理解的方式逐步开发。"
+#~ "<![CDATA[<?xml version=\"1.0\"?>\n"
+#~ "<!DOCTYPE hibernate-mapping PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Mapping DTD 3.0//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd\">\n"
+#~ "\n"
+#~ "<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
+#~ "[...]\n"
+#~ "</hibernate-mapping>]]>"
 
 #~ msgid ""
-#~ "This tutorial is intended for new users of Hibernate but requires Java "
-#~ "and SQL knowledge. It is based on a tutorial by Michael Gloegl, the third-"
-#~ "party libraries we name are for JDK 1.4 and 5.0. You might need others "
-#~ "for JDK 1.3."
+#~ "<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
+#~ "\n"
+#~ "    <class name=\"Event\" table=\"EVENTS\">\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 #~ msgstr ""
-#~ "本章面向Hibernate初学者,但需要Java和SQL知识。它是在Michael Goegl所写的指"
-#~ "南的基础上完成的。在这里,我们称第三方库文件是指JDK 1.4和5.0。若使用"
-#~ "JDK1.3,你可能需要其它的库文件。"
+#~ "<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
+#~ "\n"
+#~ "    <class name=\"Event\" table=\"EVENTS\">\n"
+#~ "\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 
 #~ msgid ""
-#~ "The source code for the tutorial is included in the distribution in the "
-#~ "<literal>doc/reference/tutorial/</literal> directory."
+#~ "<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
+#~ "\n"
+#~ "    <class name=\"Event\" table=\"EVENTS\">\n"
+#~ "        <id name=\"id\" column=\"EVENT_ID\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 #~ msgstr ""
-#~ "本章的源代码已包含在发布包中,位于<literal>doc/reference/tutorial/</"
-#~ "literal>目录下。"
+#~ "<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
+#~ "\n"
+#~ "    <class name=\"Event\" table=\"EVENTS\">\n"
+#~ "        <id name=\"id\" column=\"EVENT_ID\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 
 #~ msgid ""
-#~ "First, we'll create a simple console-based Hibernate application. We use "
-#~ "an Java database (HSQL DB), so we do not have to install any database "
-#~ "server."
+#~ "<![CDATA[\n"
+#~ "<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
+#~ "\n"
+#~ "    <class name=\"Event\" table=\"EVENTS\">\n"
+#~ "        <id name=\"id\" column=\"EVENT_ID\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"date\" type=\"timestamp\" column=\"EVENT_DATE\"/"
+#~ ">\n"
+#~ "        <property name=\"title\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 #~ msgstr ""
-#~ "首先我们将创建一个简单的基于控制台的(console-based)Hibernate应用程序。由于"
-#~ "我们使用Java数据库(HSQL DB),所以不必安装任何数据库服务器。"
+#~ "<![CDATA[\n"
+#~ "<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
+#~ "\n"
+#~ "    <class name=\"Event\" table=\"EVENTS\">\n"
+#~ "        <id name=\"id\" column=\"EVENT_ID\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"date\" type=\"timestamp\" column=\"EVENT_DATE\"/"
+#~ ">\n"
+#~ "        <property name=\"title\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 
 #~ msgid ""
-#~ "The first thing we do, is set up our development directory and put all "
-#~ "the Java libraries we need into it. Download the Hibernate distribution "
-#~ "from the Hibernate website. Extract the package and place all required "
-#~ "libraries found in <literal>/lib</literal> into into the <literal>/lib</"
-#~ "literal> directory of your new development working directory. It should "
-#~ "look like this:"
+#~ "<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
+#~ "<!DOCTYPE hibernate-configuration PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Configuration DTD 3.0//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
+#~ "\">\n"
+#~ "\n"
+#~ "<hibernate-configuration>\n"
+#~ "\n"
+#~ "    <session-factory>\n"
+#~ "\n"
+#~ "        <!-- Database connection settings -->\n"
+#~ "        <property name=\"connection.driver_class\">org.hsqldb.jdbcDriver</"
+#~ "property>\n"
+#~ "        <property name=\"connection.url\">jdbc:hsqldb:hsql://localhost</"
+#~ "property>\n"
+#~ "        <property name=\"connection.username\">sa</property>\n"
+#~ "        <property name=\"connection.password\"></property>\n"
+#~ "\n"
+#~ "        <!-- JDBC connection pool (use the built-in) -->\n"
+#~ "        <property name=\"connection.pool_size\">1</property>\n"
+#~ "\n"
+#~ "        <!-- SQL dialect -->\n"
+#~ "        <property name=\"dialect\">org.hibernate.dialect.HSQLDialect</"
+#~ "property>\n"
+#~ "\n"
+#~ "        <!-- Enable Hibernate's automatic session context management -->\n"
+#~ "        <property name=\"current_session_context_class\">thread</"
+#~ "property>\n"
+#~ "\n"
+#~ "        <!-- Disable the second-level cache  -->\n"
+#~ "        <property name=\"cache.provider_class\">org.hibernate.cache."
+#~ "NoCacheProvider</property>\n"
+#~ "\n"
+#~ "        <!-- Echo all executed SQL to stdout -->\n"
+#~ "        <property name=\"show_sql\">true</property>\n"
+#~ "\n"
+#~ "        <!-- Drop and re-create the database schema on startup -->\n"
+#~ "        <property name=\"hbm2ddl.auto\">update</property>\n"
+#~ "\n"
+#~ "        <mapping resource=\"org/hibernate/tutorial/domain/Event.hbm.xml\"/"
+#~ ">\n"
+#~ "\n"
+#~ "    </session-factory>\n"
+#~ "\n"
+#~ "</hibernate-configuration>]]>"
 #~ msgstr ""
-#~ "我们所做的第一件事就是创建我们的开发目录,并且把所有需要用到的Java库文件放"
-#~ "进去。解压缩从Hibernate网站下载的Hibernate发布包,并把<literal>/lib</"
-#~ "literal>目录下所有需要的库文件拷到我们新建开发目录下的<literal>/lib</"
-#~ "literal>目录下。看起来就像这样:"
+#~ "<![CDATA[<?xml version='1.0' encoding='utf-8'?>\n"
+#~ "<!DOCTYPE hibernate-configuration PUBLIC\n"
+#~ "        \"-//Hibernate/Hibernate Configuration DTD 3.0//EN\"\n"
+#~ "        \"http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"
+#~ "\">\n"
+#~ "\n"
+#~ "<hibernate-configuration>\n"
+#~ "\n"
+#~ "    <session-factory>\n"
+#~ "\n"
+#~ "        <!-- Database connection settings -->\n"
+#~ "        <property name=\"connection.driver_class\">org.hsqldb.jdbcDriver</"
+#~ "property>\n"
+#~ "        <property name=\"connection.url\">jdbc:hsqldb:hsql://localhost</"
+#~ "property>\n"
+#~ "        <property name=\"connection.username\">sa</property>\n"
+#~ "        <property name=\"connection.password\"></property>\n"
+#~ "\n"
+#~ "        <!-- JDBC connection pool (use the built-in) -->\n"
+#~ "        <property name=\"connection.pool_size\">1</property>\n"
+#~ "\n"
+#~ "        <!-- SQL dialect -->\n"
+#~ "        <property name=\"dialect\">org.hibernate.dialect.HSQLDialect</"
+#~ "property>\n"
+#~ "\n"
+#~ "        <!-- Enable Hibernate's automatic session context management -->\n"
+#~ "        <property name=\"current_session_context_class\">thread</"
+#~ "property>\n"
+#~ "\n"
+#~ "        <!-- Disable the second-level cache  -->\n"
+#~ "        <property name=\"cache.provider_class\">org.hibernate.cache."
+#~ "NoCacheProvider</property>\n"
+#~ "\n"
+#~ "        <!-- Echo all executed SQL to stdout -->\n"
+#~ "        <property name=\"show_sql\">true</property>\n"
+#~ "\n"
+#~ "        <!-- Drop and re-create the database schema on startup -->\n"
+#~ "        <property name=\"hbm2ddl.auto\">update</property>\n"
+#~ "\n"
+#~ "        <mapping resource=\"org/hibernate/tutorial/domain/Event.hbm.xml\"/"
+#~ ">\n"
+#~ "\n"
+#~ "    </session-factory>\n"
+#~ "\n"
+#~ "</hibernate-configuration>]]>"
 
+#, fuzzy
 #~ msgid ""
-#~ "This is the minimum set of required libraries (note that we also copied "
-#~ "hibernate3.jar, the main archive) for Hibernate <emphasis>at the time of "
-#~ "writing</emphasis>. The Hibernate release you are using might require "
-#~ "more or less libraries. See the <literal>README.txt</literal> file in the "
-#~ "<literal>lib/</literal> directory of the Hibernate distribution for more "
-#~ "information about required and optional third-party libraries. (Actually, "
-#~ "Log4j is not required but preferred by many developers.)"
+#~ "<![CDATA[package org.hibernate.tutorial.util;\n"
+#~ "\n"
+#~ "import org.hibernate.SessionFactory;\n"
+#~ "import org.hibernate.cfg.Configuration;\n"
+#~ "\n"
+#~ "public class HibernateUtil {\n"
+#~ "\n"
+#~ "    private static final SessionFactory sessionFactory = "
+#~ "buildSessionFactory();\n"
+#~ "\n"
+#~ "    private static SessionFactory buildSessionFactory() {\n"
+#~ "        try {\n"
+#~ "            // Create the SessionFactory from hibernate.cfg.xml\n"
+#~ "            return new Configuration().configure().buildSessionFactory"
+#~ "();\n"
+#~ "        }\n"
+#~ "        catch (Throwable ex) {\n"
+#~ "            // Make sure you log the exception, as it might be swallowed\n"
+#~ "            System.err.println(\"Initial SessionFactory creation failed."
+#~ "\" + ex);\n"
+#~ "            throw new ExceptionInInitializerError(ex);\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public static SessionFactory getSessionFactory() {\n"
+#~ "        return sessionFactory;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
 #~ msgstr ""
-#~ "<emphasis>到编写本文时为止</emphasis>,这些是Hibernate运行所需要的最小库文"
-#~ "件集合(注意我们也拷贝了 Hibernate3.jar,这个是最主要的文件)。你正使用的"
-#~ "Hibernate版本可能需要比这更多或少一些的库文件。请参见发布包中的"
-#~ "<literal>lib/</literal>目录下的<literal>README.txt</literal>,以获取更多关"
-#~ "于所需和可选的第三方库文件信息(事实上,Log4j并不是必须的库文件,但被许多"
-#~ "开发者所喜欢)。"
+#~ "package util;\n"
+#~ "\n"
+#~ "import org.hibernate.*;\n"
+#~ "import org.hibernate.cfg.*;\n"
+#~ "\n"
+#~ "public class HibernateUtil {\n"
+#~ "\n"
+#~ "    private static final SessionFactory sessionFactory;\n"
+#~ "\n"
+#~ "    static {\n"
+#~ "        try {\n"
+#~ "            // Create the SessionFactory from hibernate.cfg.xml\n"
+#~ "            sessionFactory = new Configuration().configure()."
+#~ "buildSessionFactory();\n"
+#~ "        } catch (Throwable ex) {\n"
+#~ "            // Make sure you log the exception, as it might be swallowed\n"
+#~ "            System.err.println(\"Initial SessionFactory creation failed."
+#~ "\" + ex);\n"
+#~ "            throw new ExceptionInInitializerError(ex);\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public static SessionFactory getSessionFactory() {\n"
+#~ "        return sessionFactory;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "Our first persistent class is a simple JavaBean class with some "
-#~ "properties:"
+#~ "<![CDATA[package org.hibernate.tutorial;\n"
+#~ "\n"
+#~ "import org.hibernate.Session;\n"
+#~ "\n"
+#~ "import java.util.*;\n"
+#~ "\n"
+#~ "import org.hibernate.tutorial.domain.Event;\n"
+#~ "import org.hibernate.tutorial.util.HibernateUtil;\n"
+#~ "\n"
+#~ "public class EventManager {\n"
+#~ "\n"
+#~ "    public static void main(String[] args) {\n"
+#~ "        EventManager mgr = new EventManager();\n"
+#~ "\n"
+#~ "        if (args[0].equals(\"store\")) {\n"
+#~ "            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
+#~ "        }\n"
+#~ "\n"
+#~ "        HibernateUtil.getSessionFactory().close();\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    private void createAndStoreEvent(String title, Date theDate) {\n"
+#~ "        Session session = HibernateUtil.getSessionFactory()."
+#~ "getCurrentSession();\n"
+#~ "        session.beginTransaction();\n"
+#~ "\n"
+#~ "        Event theEvent = new Event();\n"
+#~ "        theEvent.setTitle(title);\n"
+#~ "        theEvent.setDate(theDate);\n"
+#~ "        session.save(theEvent);\n"
+#~ "\n"
+#~ "        session.getTransaction().commit();\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
 #~ msgstr ""
-#~ "我们的第一个持久化类是一个带有一些属性(property)的简单JavaBean类:"
+#~ "package events;\n"
+#~ "import org.hibernate.Session;\n"
+#~ "\n"
+#~ "import java.util.Date;\n"
+#~ "\n"
+#~ "import util.HibernateUtil;\n"
+#~ "\n"
+#~ "public class EventManager {\n"
+#~ "\n"
+#~ "    public static void main(String[] args) {\n"
+#~ "        EventManager mgr = new EventManager();\n"
+#~ "\n"
+#~ "        if (args[0].equals(\"store\")) {\n"
+#~ "            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
+#~ "        }\n"
+#~ "\n"
+#~ "        HibernateUtil.getSessionFactory().close();\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    private void createAndStoreEvent(String title, Date theDate) {\n"
+#~ "\n"
+#~ "        Session session = HibernateUtil.getSessionFactory()."
+#~ "getCurrentSession();\n"
+#~ "\n"
+#~ "        session.beginTransaction();\n"
+#~ "\n"
+#~ "        Event theEvent = new Event();\n"
+#~ "        theEvent.setTitle(title);\n"
+#~ "        theEvent.setDate(theDate);\n"
+#~ "\n"
+#~ "        session.save(theEvent);\n"
+#~ "\n"
+#~ "        session.getTransaction().commit();\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "Place this Java source file in a directory called <literal>src</literal> "
-#~ "in the development folder, and in its correct package. The directory "
-#~ "should now look like this:"
+#~ "<![CDATA[[java] Hibernate: insert into EVENTS (EVENT_DATE, title, "
+#~ "EVENT_ID) values (?, ?, ?)]]>"
 #~ msgstr ""
-#~ "把这个Java源代码文件放到开发目录下的<literal>src</literal>目录里,注意包位"
-#~ "置要正确。 现在这个目录看起来应该像这样:"
+#~ "[java] Hibernate: insert into EVENTS (EVENT_DATE, title, EVENT_ID) values "
+#~ "(?, ?, ?)"
 
-#~ msgid "In the next step, we tell Hibernate about this persistent class."
-#~ msgstr "下一步,我们把这个持久化类的信息告诉Hibernate。"
-
+#, fuzzy
 #~ msgid ""
-#~ "The <literal>id</literal> element is the declaration of the identifer "
-#~ "property, <literal>name=\"id\"</literal> declares the name of the Java "
-#~ "property - Hibernate will use the getter and setter methods to access the "
-#~ "property. The column attribute tells Hibernate which column of the "
-#~ "<literal>EVENTS</literal> table we use for this primary key. The nested "
-#~ "<literal>generator</literal> element specifies the identifier generation "
-#~ "strategy, in this case we used <literal>native</literal>, which picks the "
-#~ "best strategy depending on the configured database (dialect). Hibernate "
-#~ "supports database generated, globally unique, as well as application "
-#~ "assigned identifiers (or any strategy you have written an extension for)."
+#~ "<![CDATA[        if (args[0].equals(\"store\")) {\n"
+#~ "            mgr.createAndStoreEvent(\"My Event\", new Date());\n"
+#~ "        }\n"
+#~ "        else if (args[0].equals(\"list\")) {\n"
+#~ "            List events = mgr.listEvents();\n"
+#~ "            for (int i = 0; i < events.size(); i++) {\n"
+#~ "                Event theEvent = (Event) events.get(i);\n"
+#~ "                System.out.println(\n"
+#~ "                        \"Event: \" + theEvent.getTitle() + \" Time: \" + "
+#~ "theEvent.getDate()\n"
+#~ "                );\n"
+#~ "            }\n"
+#~ "        }]]>"
 #~ msgstr ""
-#~ "<literal>id</literal>元素是标识符属性的声明,<literal>name=\"id\"</"
-#~ "literal> 声明了Java属性的名字 - Hibernate会使用<literal>getId()</literal>"
-#~ "和<literal>setId()</literal>来访问它。 <literal>column</literal>属性则告诉"
-#~ "Hibernate, 我们使用<literal>EVENTS</literal>表的哪个字段作为主键。嵌套的"
-#~ "<literal>generator</literal>元素指定了标识符生成策略,在这里我们指定"
-#~ "<literal>native</literal>,它根据已配置的数据库(方言)自动选择最佳的标识"
-#~ "符生成策略。Hibernate支持由数据库生成,全局唯一性(globally unique)和应用"
-#~ "程序指定(或者你自己为任何已有策略所写的扩展)这些策略来生成标识符。"
+#~ "if (args[0].equals(\"store\")) {\n"
+#~ "    mgr.createAndStoreEvent(\"My Event\", new Date());\n"
+#~ "}\n"
+#~ "else if (args[0].equals(\"list\")) {\n"
+#~ "    List events = mgr.listEvents();\n"
+#~ "    for (int i = 0; i &lt; events.size(); i++) {\n"
+#~ "        Event theEvent = (Event) events.get(i);\n"
+#~ "        System.out.println(\"Event: \" + theEvent.getTitle() +\n"
+#~ "                           \" Time: \" + theEvent.getDate());\n"
+#~ "    }\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "This mapping file should be saved as <literal>Event.hbm.xml</literal>, "
-#~ "right in the directory next to the <literal>Event</literal> Java class "
-#~ "source file. The naming of mapping files can be arbitrary, however the "
-#~ "<literal>hbm.xml</literal> suffix is a convention in the Hibernate "
-#~ "developer community. The directory structure should now look like this:"
+#~ "<![CDATA[    private List listEvents() {\n"
+#~ "        Session session = HibernateUtil.getSessionFactory()."
+#~ "getCurrentSession();\n"
+#~ "        session.beginTransaction();\n"
+#~ "        List result = session.createQuery(\"from Event\").list();\n"
+#~ "        session.getTransaction().commit();\n"
+#~ "        return result;\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "应该把这个映射文件保存为<literal>Event.hbm.xml</literal>,且就在"
-#~ "<literal>Event</literal>Java类的源文件目录下。映射文件可随意地命名,但"
-#~ "<literal>hbm.xml</literal>的后缀已成为Hibernate开发者社区的约定。现在目录"
-#~ "结构看起来应该像这样:"
+#~ "private List listEvents() {\n"
+#~ "\n"
+#~ "    Session session = HibernateUtil.getSessionFactory().getCurrentSession"
+#~ "();\n"
+#~ "\n"
+#~ "    session.beginTransaction();\n"
+#~ "\n"
+#~ "    List result = session.createQuery(\"from Event\").list();\n"
+#~ "\n"
+#~ "    session.getTransaction().commit();\n"
+#~ "\n"
+#~ "    return result;\n"
+#~ "}"
 
-#~ msgid "We continue with the main configuration of Hibernate."
-#~ msgstr "我们继续进行Hibernate的主要配置。"
-
+#, fuzzy
 #~ msgid ""
-#~ "We now have a persistent class and its mapping file in place. It is time "
-#~ "to configure Hibernate. Before we do this, we will need a database. HSQL "
-#~ "DB, a java-based SQL DBMS, can be downloaded from the HSQL DB website"
-#~ "(http://hsqldb.org/). Actually, you only need the <literal>hsqldb.jar</"
-#~ "literal> from this download. Place this file in the <literal>lib/</"
-#~ "literal> directory of the development folder."
+#~ "<![CDATA[package org.hibernate.tutorial.domain;\n"
+#~ "\n"
+#~ "public class Person {\n"
+#~ "\n"
+#~ "    private Long id;\n"
+#~ "    private int age;\n"
+#~ "    private String firstname;\n"
+#~ "    private String lastname;\n"
+#~ "\n"
+#~ "    public Person() {}\n"
+#~ "\n"
+#~ "    // Accessor methods for all properties, private setter for 'id'\n"
+#~ "\n"
+#~ "}]]>"
 #~ msgstr ""
-#~ "现在我们已经有了一个持久化类和它的映射文件,该是配置Hibernate的时候了。在"
-#~ "此之前,我们需要一个数据库。 HSQL DB是种基于Java 的SQL数据库管理系统"
-#~ "(DBMS),可以从HSQL DB的网站上下载。实际上,你只需下载的包中的"
-#~ "<literal>hsqldb.jar</literal>文件,并把这个文件放在开发文件夹的"
-#~ "<literal>lib/</literal>目录下即可。"
+#~ "package events;\n"
+#~ "\n"
+#~ "public class Person {\n"
+#~ "\n"
+#~ "    private Long id;\n"
+#~ "    private int age;\n"
+#~ "    private String firstname;\n"
+#~ "    private String lastname;\n"
+#~ "\n"
+#~ "    public Person() {}\n"
+#~ "\n"
+#~ "    // Accessor methods for all properties, private setter for 'id'\n"
+#~ "\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "Hibernate is the layer in your application which connects to this "
-#~ "database, so it needs connection information. The connections are made "
-#~ "through a JDBC connection pool, which we also have to configure. The "
-#~ "Hibernate distribution contains several open source JDBC connection "
-#~ "pooling tools, but will use the Hibernate built-in connection pool for "
-#~ "this tutorial. Note that you have to copy the required library into your "
-#~ "classpath and use different connection pooling settings if you want to "
-#~ "use a production-quality third party JDBC pooling software."
+#~ "<![CDATA[<hibernate-mapping package=\"org.hibernate.tutorial.domain\">\n"
+#~ "\n"
+#~ "    <class name=\"Person\" table=\"PERSON\">\n"
+#~ "        <id name=\"id\" column=\"PERSON_ID\">\n"
+#~ "            <generator class=\"native\"/>\n"
+#~ "        </id>\n"
+#~ "        <property name=\"age\"/>\n"
+#~ "        <property name=\"firstname\"/>\n"
+#~ "        <property name=\"lastname\"/>\n"
+#~ "    </class>\n"
+#~ "\n"
+#~ "</hibernate-mapping>]]>"
 #~ msgstr ""
-#~ "Hibernate是你的应用程序里连接数据库的那层,所以它需要连接用的信息。连接"
-#~ "(connection)是通过一个也由我们配置的JDBC连接池(connection pool)来完成"
-#~ "的。Hibernate的发布包里包含了许多开源的(open source)连接池,但在我们例子"
-#~ "中使用Hibernate内置的连接池。注意,如果你希望使用一个产品级(production-"
-#~ "quality)的第三方连接池软件,你必须拷贝所需的库文件到你的classpath下,并使"
-#~ "用不同的连接池设置。"
+#~ "&lt;hibernate-mapping&gt;\n"
+#~ "\n"
+#~ "    &lt;class name=\"events.Person\" table=\"PERSON\"&gt;\n"
+#~ "        &lt;id name=\"id\" column=\"PERSON_ID\"&gt;\n"
+#~ "            &lt;generator class=\"native\"/&gt;\n"
+#~ "        &lt;/id&gt;\n"
+#~ "        &lt;property name=\"age\"/&gt;\n"
+#~ "        &lt;property name=\"firstname\"/&gt;\n"
+#~ "        &lt;property name=\"lastname\"/&gt;\n"
+#~ "    &lt;/class&gt;\n"
+#~ "\n"
+#~ "&lt;/hibernate-mapping&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "Copy this file into the source directory, so it will end up in the root "
-#~ "of the classpath. Hibernate automatically looks for a file called "
-#~ "<literal>hibernate.cfg.xml</literal> in the root of the classpath, on "
-#~ "startup."
+#~ "<![CDATA[<mapping resource=\"events/Event.hbm.xml\"/>\n"
+#~ "<mapping resource=\"events/Person.hbm.xml\"/>]]>"
 #~ msgstr ""
-#~ "把这个文件拷贝到源代码目录下面,这样它就位于classpath的根目录的最后。"
-#~ "Hibernate在启动时会自动在classpath的根目录查找名为<literal>hibernate.cfg."
-#~ "xml</literal>的配置文件。"
+#~ "&lt;mapping resource=\"events/Event.hbm.xml\"/&gt;\n"
+#~ "&lt;mapping resource=\"events/Person.hbm.xml\"/&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "We'll now build the tutorial with Ant. You will need to have Ant "
-#~ "installed - get it from the <ulink url=\"http://ant.apache.org/"
-#~ "bindownload.cgi\">Ant download page</ulink>. How to install Ant will not "
-#~ "be covered here. Please refer to the <ulink url=\"http://ant.apache.org/"
-#~ "manual/index.html\">Ant manual</ulink>. After you have installed Ant, we "
-#~ "can start to create the buildfile. It will be called <literal>build.xml</"
-#~ "literal> and placed directly in the development directory."
+#~ "<![CDATA[public class Person {\n"
+#~ "\n"
+#~ "    private Set events = new HashSet();\n"
+#~ "\n"
+#~ "    public Set getEvents() {\n"
+#~ "        return events;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setEvents(Set events) {\n"
+#~ "        this.events = events;\n"
+#~ "    }\n"
+#~ "}]]>"
 #~ msgstr ""
-#~ "现在我们用Ant来构建应用程序。你必须先安装Ant-可以从<ulink url=\"http://"
-#~ "ant.apache.org/bindownload.cgi\">Ant 下载页面</ulink>得到它。怎样安装Ant就"
-#~ "不在这里介绍了,请参考<ulink url=\"http://ant.apache.org/manual/index.html"
-#~ "\">Ant 用户手册</ulink>。当你安装完了Ant,就可以开始创建<literal>build."
-#~ "xml</literal>文件,把它直接放在开发目录下面。"
+#~ "public class Person {\n"
+#~ "\n"
+#~ "    private Set events = new HashSet();\n"
+#~ "\n"
+#~ "    public Set getEvents() {\n"
+#~ "        return events;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setEvents(Set events) {\n"
+#~ "        this.events = events;\n"
+#~ "    }\n"
+#~ "}"
 
-#~ msgid "A basic build file looks like this:"
-#~ msgstr "一个简单的build文件看起来像这样:"
-
+#, fuzzy
 #~ msgid ""
-#~ "This will tell Ant to add all files in the lib directory ending with "
-#~ "<literal>.jar</literal> to the classpath used for compilation. It will "
-#~ "also copy all non-Java source files to the target directory, e.g. "
-#~ "configuration and Hibernate mapping files. If you now run Ant, you should "
-#~ "get this output:"
+#~ "<![CDATA[<class name=\"Person\" table=\"PERSON\">\n"
+#~ "    <id name=\"id\" column=\"PERSON_ID\">\n"
+#~ "        <generator class=\"native\"/>\n"
+#~ "    </id>\n"
+#~ "    <property name=\"age\"/>\n"
+#~ "    <property name=\"firstname\"/>\n"
+#~ "    <property name=\"lastname\"/>\n"
+#~ "\n"
+#~ "    <set name=\"events\" table=\"PERSON_EVENT\">\n"
+#~ "        <key column=\"PERSON_ID\"/>\n"
+#~ "        <many-to-many column=\"EVENT_ID\" class=\"Event\"/>\n"
+#~ "    </set>\n"
+#~ "\n"
+#~ "</class>]]>"
 #~ msgstr ""
-#~ "这将告诉Ant把所有在lib目录下以<literal>.jar</literal>结尾的文件拷贝到"
-#~ "classpath中以供编译之用。它也把所有的非Java源代码文件,例如配置和Hibernate"
-#~ "映射文件,拷贝到目标目录。如果你现在运行Ant,会得到以下输出:"
+#~ "&lt;class name=\"events.Person\" table=\"PERSON\"&gt;\n"
+#~ "    &lt;id name=\"id\" column=\"PERSON_ID\"&gt;\n"
+#~ "        &lt;generator class=\"native\"/&gt;\n"
+#~ "    &lt;/id&gt;\n"
+#~ "    &lt;property name=\"age\"/&gt;\n"
+#~ "    &lt;property name=\"firstname\"/&gt;\n"
+#~ "    &lt;property name=\"lastname\"/&gt;\n"
+#~ "\n"
+#~ "    &lt;set name=\"events\" table=\"PERSON_EVENT\"&gt;\n"
+#~ "        &lt;key column=\"PERSON_ID\"/&gt;\n"
+#~ "        &lt;many-to-many column=\"EVENT_ID\" class=\"events.Event\"/&gt;\n"
+#~ "    &lt;/set&gt;\n"
+#~ "\n"
+#~ "&lt;/class&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "Place <literal>HibernateUtil.java</literal> in the development source "
-#~ "directory, in a package next to <literal>events</literal>:"
+#~ "<![CDATA[\n"
+#~ "    _____________        __________________\n"
+#~ "   |             |      |                  |       _____________\n"
+#~ "   |   EVENTS    |      |   PERSON_EVENT   |      |             |\n"
+#~ "   |_____________|      |__________________|      |    PERSON   |\n"
+#~ "   |             |      |                  |      |_____________|\n"
+#~ "   | *EVENT_ID   | <--> | *EVENT_ID        |      |             |\n"
+#~ "   |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  |\n"
+#~ "   |  TITLE      |      |__________________|      |  AGE        |\n"
+#~ "   |_____________|                                |  FIRSTNAME  |\n"
+#~ "                                                  |  LASTNAME   |\n"
+#~ "                                                  |_____________|\n"
+#~ " ]]>"
 #~ msgstr ""
-#~ "把<literal>HibernateUtil.java</literal>放在开发目录的源代码路径下,与放"
-#~ "<literal>events</literal>的包并列:"
+#~ "_____________        __________________\n"
+#~ "   |             |      |                  |       _____________\n"
+#~ "   |   EVENTS    |      |   PERSON_EVENT   |      |             |\n"
+#~ "   |_____________|      |__________________|      |    PERSON   |\n"
+#~ "   |             |      |                  |      |_____________|\n"
+#~ "   | *EVENT_ID   | &lt;--&gt; | *EVENT_ID        |      |             |\n"
+#~ "   |  EVENT_DATE |      | *PERSON_ID       | &lt;--&gt; | *PERSON_ID  |\n"
+#~ "   |  TITLE      |      |__________________|      |  AGE        |\n"
+#~ "   |_____________|                                |  FIRSTNAME  |\n"
+#~ "                                                  |  LASTNAME   |\n"
+#~ "                                                  |_____________|"
 
+#, fuzzy
 #~ msgid ""
-#~ "To run this first routine we have to add a callable target to the Ant "
-#~ "build file:"
+#~ "<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) "
+#~ "{\n"
+#~ "        Session session = HibernateUtil.getSessionFactory()."
+#~ "getCurrentSession();\n"
+#~ "        session.beginTransaction();\n"
+#~ "\n"
+#~ "        Person aPerson = (Person) session.load(Person.class, personId);\n"
+#~ "        Event anEvent = (Event) session.load(Event.class, eventId);\n"
+#~ "        aPerson.getEvents().add(anEvent);\n"
+#~ "\n"
+#~ "        session.getTransaction().commit();\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "为第一次运行我们的程序,我们得在Ant的build文件中增加一个可以调用得到的"
-#~ "target。"
+#~ "private void addPersonToEvent(Long personId, Long eventId) {\n"
+#~ "\n"
+#~ "    Session session = HibernateUtil.getSessionFactory().getCurrentSession"
+#~ "();\n"
+#~ "    session.beginTransaction();\n"
+#~ "\n"
+#~ "    Person aPerson = (Person) session.load(Person.class, personId);\n"
+#~ "    Event anEvent = (Event) session.load(Event.class, eventId);\n"
+#~ "\n"
+#~ "    aPerson.getEvents().add(anEvent);\n"
+#~ "\n"
+#~ "    session.getTransaction().commit();\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "The value of the <literal>action</literal> argument is set on the command "
-#~ "line when calling the target:"
+#~ "<![CDATA[    private void addPersonToEvent(Long personId, Long eventId) "
+#~ "{\n"
+#~ "        Session session = HibernateUtil.getSessionFactory()."
+#~ "getCurrentSession();\n"
+#~ "        session.beginTransaction();\n"
+#~ "\n"
+#~ "        Person aPerson = (Person) session\n"
+#~ "                .createQuery(\"select p from Person p left join fetch p."
+#~ "events where p.id = :pid\")\n"
+#~ "                .setParameter(\"pid\", personId)\n"
+#~ "                .uniqueResult(); // Eager fetch the collection so we can "
+#~ "use it detached\n"
+#~ "        Event anEvent = (Event) session.load(Event.class, eventId);\n"
+#~ "\n"
+#~ "        session.getTransaction().commit();\n"
+#~ "\n"
+#~ "        // End of first unit of work\n"
+#~ "\n"
+#~ "        aPerson.getEvents().add(anEvent); // aPerson (and its collection) "
+#~ "is detached\n"
+#~ "\n"
+#~ "        // Begin second unit of work\n"
+#~ "\n"
+#~ "        Session session2 = HibernateUtil.getSessionFactory()."
+#~ "getCurrentSession();\n"
+#~ "        session2.beginTransaction();\n"
+#~ "        session2.update(aPerson); // Reattachment of aPerson\n"
+#~ "\n"
+#~ "        session2.getTransaction().commit();\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "<literal>action</literal>参数(argument)的值是通过命令行调用这个target的"
-#~ "时候设置的:"
+#~ "private void addPersonToEvent(Long personId, Long eventId) {\n"
+#~ "\n"
+#~ "    Session session = HibernateUtil.getSessionFactory().getCurrentSession"
+#~ "();\n"
+#~ "    session.beginTransaction();\n"
+#~ "\n"
+#~ "    Person aPerson = (Person) session\n"
+#~ "            .createQuery(\"select p from Person p left join fetch p."
+#~ "events where p.id = :pid\")\n"
+#~ "            .setParameter(\"pid\", personId)\n"
+#~ "            .uniqueResult(); // Eager fetch the collection so we can use "
+#~ "it detached\n"
+#~ "\n"
+#~ "    Event anEvent = (Event) session.load(Event.class, eventId);\n"
+#~ "\n"
+#~ "    session.getTransaction().commit();\n"
+#~ "\n"
+#~ "    // End of first unit of work\n"
+#~ "\n"
+#~ "    aPerson.getEvents().add(anEvent); // aPerson (and its collection) is "
+#~ "detached\n"
+#~ "\n"
+#~ "    // Begin second unit of work\n"
+#~ "\n"
+#~ "    Session session2 = HibernateUtil.getSessionFactory().getCurrentSession"
+#~ "();\n"
+#~ "    session2.beginTransaction();\n"
+#~ "\n"
+#~ "    session2.update(aPerson); // Reattachment of aPerson\n"
+#~ "\n"
+#~ "    session2.getTransaction().commit();\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "This is the <literal>INSERT</literal> executed by Hibernate, the question "
-#~ "marks represent JDBC bind parameters. To see the values bound as "
-#~ "arguments, or to reduce the verbosity of the log, check your "
-#~ "<literal>log4j.properties</literal>."
+#~ "<![CDATA[        else if (args[0].equals(\"addpersontoevent\")) {\n"
+#~ "            Long eventId = mgr.createAndStoreEvent(\"My Event\", new Date"
+#~ "());\n"
+#~ "            Long personId = mgr.createAndStorePerson(\"Foo\", \"Bar\");\n"
+#~ "            mgr.addPersonToEvent(personId, eventId);\n"
+#~ "            System.out.println(\"Added person \" + personId + \" to event "
+#~ "\" + eventId);\n"
+#~ "        }]]>"
 #~ msgstr ""
-#~ "这是Hibernate执行的<literal>INSERT</literal>命令,问号代表JDBC的绑定参数。"
-#~ "如果想要看到绑定参数的值或者减少日志的长度,就要调整你在<literal>log4j."
-#~ "properties</literal>文件里的设置。"
+#~ "else if (args[0].equals(\"addpersontoevent\")) {\n"
+#~ "    Long eventId = mgr.createAndStoreEvent(\"My Event\", new Date());\n"
+#~ "    Long personId = mgr.createAndStorePerson(\"Foo\", \"Bar\");\n"
+#~ "    mgr.addPersonToEvent(personId, eventId);\n"
+#~ "    System.out.println(\"Added person \" + personId + \" to event \" + "
+#~ "eventId);\n"
+#~ "}"
 
-#~ msgid "Now, to execute and test all of this, follow these steps:"
-#~ msgstr "现在,根据以下步骤来执行并测试以上各项:"
-
+#, fuzzy
 #~ msgid ""
-#~ "Run <literal>ant run -Daction=store</literal> to store something into the "
-#~ "database and, of course, to generate the database schema before through "
-#~ "hbm2ddl."
+#~ "<![CDATA[    private Set emailAddresses = new HashSet();\n"
+#~ "\n"
+#~ "    public Set getEmailAddresses() {\n"
+#~ "        return emailAddresses;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setEmailAddresses(Set emailAddresses) {\n"
+#~ "        this.emailAddresses = emailAddresses;\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "运行<literal>ant run -Daction=store</literal>来保存一些内容到数据库。当"
-#~ "然,先得用hbm2ddl来生成数据库schema。"
+#~ "private Set emailAddresses = new HashSet();\n"
+#~ "\n"
+#~ "public Set getEmailAddresses() {\n"
+#~ "    return emailAddresses;\n"
+#~ "}\n"
+#~ "\n"
+#~ "public void setEmailAddresses(Set emailAddresses) {\n"
+#~ "    this.emailAddresses = emailAddresses;\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "Now disable hbm2ddl by commenting out the property in your "
-#~ "<literal>hibernate.cfg.xml</literal> file. Usually you only leave it "
-#~ "turned on in continous unit testing, but another run of hbm2ddl would "
-#~ "<emphasis>drop</emphasis> everything you have stored - the "
-#~ "<literal>create</literal> configuration setting actually translates into "
-#~ "\"drop all tables from the schema, then re-create all tables, when the "
-#~ "SessionFactory is build\"."
+#~ "<![CDATA[        <set name=\"emailAddresses\" table=\"PERSON_EMAIL_ADDR"
+#~ "\">\n"
+#~ "            <key column=\"PERSON_ID\"/>\n"
+#~ "            <element type=\"string\" column=\"EMAIL_ADDR\"/>\n"
+#~ "        </set>]]>"
 #~ msgstr ""
-#~ "现在把<literal>hibernate.cfg.xml</literal>文件中hbm2ddl属性注释掉,这样我"
-#~ "们就取消了在启动时用hbm2ddl来生成数据库schema。通常只有在不断重复进行单元"
-#~ "测试的时候才需要打开它,但再次运行hbm2ddl会把你保存的一切都删掉"
-#~ "(<emphasis>drop</emphasis>)——<literal>create</literal>配置的真实含义"
-#~ "是:“在创建SessionFactory的时候,从schema 中drop 掉所有的表,再重新创建它"
-#~ "们”。"
+#~ "&lt;set name=\"emailAddresses\" table=\"PERSON_EMAIL_ADDR\"&gt;\n"
+#~ "    &lt;key column=\"PERSON_ID\"/&gt;\n"
+#~ "    &lt;element type=\"string\" column=\"EMAIL_ADDR\"/&gt;\n"
+#~ "&lt;/set&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "If you now call Ant with <literal>-Daction=list</literal>, you should see "
-#~ "the events you have stored so far. You can of course also call the "
-#~ "<literal>store</literal> action a few times more."
+#~ "<![CDATA[\n"
+#~ "  _____________        __________________\n"
+#~ " |             |      |                  |       _____________\n"
+#~ " |   EVENTS    |      |   PERSON_EVENT   |      |             |       "
+#~ "___________________\n"
+#~ " |_____________|      |__________________|      |    PERSON   |      "
+#~ "|                   |\n"
+#~ " |             |      |                  |      |_____________|      | "
+#~ "PERSON_EMAIL_ADDR |\n"
+#~ " | *EVENT_ID   | <--> | *EVENT_ID        |      |             |      |"
+#~ "___________________|\n"
+#~ " |  EVENT_DATE |      | *PERSON_ID       | <--> | *PERSON_ID  | <--> |  "
+#~ "*PERSON_ID       |\n"
+#~ " |  TITLE      |      |__________________|      |  AGE        |      |  "
+#~ "*EMAIL_ADDR      |\n"
+#~ " |_____________|                                |  FIRSTNAME  |      |"
+#~ "___________________|\n"
+#~ "                                                |  LASTNAME   |\n"
+#~ "                                                |_____________|\n"
+#~ " ]]>"
 #~ msgstr ""
-#~ "如果你现在使用命令行参数<literal>-Daction=list</literal>运行Ant,你会看到"
-#~ "那些至今为止我们所储存的events。当然,你也可以多调用几次<literal>store</"
-#~ "literal>以保存更多的envents。"
+#~ "_____________        __________________\n"
+#~ " |             |      |                  |       _____________\n"
+#~ " |   EVENTS    |      |   PERSON_EVENT   |      |             |       "
+#~ "___________________\n"
+#~ " |_____________|      |__________________|      |    PERSON   |      "
+#~ "|                   |\n"
+#~ " |             |      |                  |      |_____________|      | "
+#~ "PERSON_EMAIL_ADDR |\n"
+#~ " | *EVENT_ID   | &lt;--&gt; | *EVENT_ID        |      |             "
+#~ "|      |___________________|\n"
+#~ " |  EVENT_DATE |      | *PERSON_ID       | &lt;--&gt; | *PERSON_ID  | "
+#~ "&lt;--&gt; |  *PERSON_ID       |\n"
+#~ " |  TITLE      |      |__________________|      |  AGE        |      |  "
+#~ "*EMAIL_ADDR      |\n"
+#~ " |_____________|                                |  FIRSTNAME  |      |"
+#~ "___________________|\n"
+#~ "                                                |  LASTNAME   |\n"
+#~ "                                                |_____________|"
 
+#, fuzzy
 #~ msgid ""
-#~ "Note: Most new Hibernate users fail at this point and we see questions "
-#~ "about <emphasis>Table not found</emphasis> error messages regularly. "
-#~ "However, if you follow the steps outlined above you will not have this "
-#~ "problem, as hbm2ddl creates the database schema on the first run, and "
-#~ "subsequent application restarts will use this schema. If you change the "
-#~ "mapping and/or database schema, you have to re-enable hbm2ddl once again."
+#~ "<![CDATA[    private void addEmailToPerson(Long personId, String "
+#~ "emailAddress) {\n"
+#~ "        Session session = HibernateUtil.getSessionFactory()."
+#~ "getCurrentSession();\n"
+#~ "        session.beginTransaction();\n"
+#~ "\n"
+#~ "        Person aPerson = (Person) session.load(Person.class, personId);\n"
+#~ "        // adding to the emailAddress collection might trigger a lazy "
+#~ "load of the collection\n"
+#~ "        aPerson.getEmailAddresses().add(emailAddress);\n"
+#~ "\n"
+#~ "        session.getTransaction().commit();\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "注意,很多Hibernate新手在这一步会失败,我们不时看到关于<emphasis>Table "
-#~ "not found</emphasis>错误信息的提问。但是,只要你根据上面描述的步骤来执行,"
-#~ "就不会有这个问题,因为hbm2ddl会在第一次运行的时候创建数据库schema,后继的"
-#~ "应用程序重起后还能继续使用这个schema。假若你修改了映射,或者修改了数据库"
-#~ "schema,你必须把hbm2ddl重新打开一次。"
+#~ "private void addEmailToPerson(Long personId, String emailAddress) {\n"
+#~ "\n"
+#~ "    Session session = HibernateUtil.getSessionFactory().getCurrentSession"
+#~ "();\n"
+#~ "    session.beginTransaction();\n"
+#~ "\n"
+#~ "    Person aPerson = (Person) session.load(Person.class, personId);\n"
+#~ "\n"
+#~ "    // The getEmailAddresses() might trigger a lazy load of the "
+#~ "collection\n"
+#~ "    aPerson.getEmailAddresses().add(emailAddress);\n"
+#~ "\n"
+#~ "    session.getTransaction().commit();\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "Create a new mapping file called <literal>Person.hbm.xml</literal> (don't "
-#~ "forget the DTD reference at the top):"
+#~ "<![CDATA[    private Set participants = new HashSet();\n"
+#~ "\n"
+#~ "    public Set getParticipants() {\n"
+#~ "        return participants;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void setParticipants(Set participants) {\n"
+#~ "        this.participants = participants;\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "创建一个名为<literal>Person.hbm.xml</literal>的新映射文件(别忘了最上面的"
-#~ "DTD引用):"
+#~ "private Set participants = new HashSet();\n"
+#~ "\n"
+#~ "public Set getParticipants() {\n"
+#~ "    return participants;\n"
+#~ "}\n"
+#~ "\n"
+#~ "public void setParticipants(Set participants) {\n"
+#~ "    this.participants = participants;\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "We need a unidirectional, many-valued associations, implemented with a "
-#~ "<literal>Set</literal>. Let's write the code for this in the Java classes "
-#~ "and then map it:"
+#~ "<![CDATA[        <set name=\"participants\" table=\"PERSON_EVENT\" "
+#~ "inverse=\"true\">\n"
+#~ "            <key column=\"EVENT_ID\"/>\n"
+#~ "            <many-to-many column=\"PERSON_ID\" class=\"events.Person\"/>\n"
+#~ "        </set>]]>"
 #~ msgstr ""
-#~ "我们需要用set 实现一个单向多值关联。让我们在Java类里为这个关联编码,接着映"
-#~ "射它:"
+#~ "&lt;set name=\"participants\" table=\"PERSON_EVENT\" inverse=\"true"
+#~ "\"&gt;\n"
+#~ "    &lt;key column=\"EVENT_ID\"/&gt;\n"
+#~ "    &lt;many-to-many column=\"PERSON_ID\" class=\"events.Person\"/&gt;\n"
+#~ "&lt;/set&gt;"
 
+#, fuzzy
 #~ msgid ""
-#~ "We add a collection of value typed objects to the <literal>Person</"
-#~ "literal> entity. We want to store email addresses, so the type we use is "
-#~ "<literal>String</literal>, and the collection is again a <literal>Set</"
-#~ "literal>:"
+#~ "<![CDATA[    protected Set getEvents() {\n"
+#~ "        return events;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    protected void setEvents(Set events) {\n"
+#~ "        this.events = events;\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void addToEvent(Event event) {\n"
+#~ "        this.getEvents().add(event);\n"
+#~ "        event.getParticipants().add(this);\n"
+#~ "    }\n"
+#~ "\n"
+#~ "    public void removeFromEvent(Event event) {\n"
+#~ "        this.getEvents().remove(event);\n"
+#~ "        event.getParticipants().remove(this);\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "我们把一个值类型对象的集合加入<literal>Person</literal>实体中。我们希望保"
-#~ "存email地址,所以使用<literal>String</literal>类型,而且这次的集合类型又是"
-#~ "<literal>Set</literal>:"
+#~ "protected Set getEvents() {\n"
+#~ "    return events;\n"
+#~ "}\n"
+#~ "\n"
+#~ "protected void setEvents(Set events) {\n"
+#~ "    this.events = events;\n"
+#~ "}\n"
+#~ "\n"
+#~ "public void addToEvent(Event event) {\n"
+#~ "    this.getEvents().add(event);\n"
+#~ "    event.getParticipants().add(this);\n"
+#~ "}\n"
+#~ "\n"
+#~ "public void removeFromEvent(Event event) {\n"
+#~ "    this.getEvents().remove(event);\n"
+#~ "    event.getParticipants().remove(this);\n"
+#~ "}"
 
-#~ msgid "Let's turn this into a small web application."
-#~ msgstr "让我们把进入一个小型的web应用程序。"
-
+#, fuzzy
 #~ msgid ""
-#~ "Create a new class in your source directory, in the <literal>events</"
-#~ "literal> package:"
-#~ msgstr "在你的源代码目录的<literal>events</literal>包中创建一个新的类:"
+#~ "<![CDATA[package org.hibernate.tutorial.web;\n"
+#~ "\n"
+#~ "// Imports\n"
+#~ "\n"
+#~ "public class EventManagerServlet extends HttpServlet {\n"
+#~ "\n"
+#~ "    protected void doGet(\n"
+#~ "            HttpServletRequest request,\n"
+#~ "            HttpServletResponse response) throws ServletException, "
+#~ "IOException {\n"
+#~ "\n"
+#~ "        SimpleDateFormat dateFormatter = new SimpleDateFormat( \"dd.MM."
+#~ "yyyy\" );\n"
+#~ "\n"
+#~ "        try {\n"
+#~ "            // Begin unit of work\n"
+#~ "            HibernateUtil.getSessionFactory().getCurrentSession()."
+#~ "beginTransaction();\n"
+#~ "\n"
+#~ "            // Process request and render page...\n"
+#~ "\n"
+#~ "            // End unit of work\n"
+#~ "            HibernateUtil.getSessionFactory().getCurrentSession()."
+#~ "getTransaction().commit();\n"
+#~ "        }\n"
+#~ "        catch (Exception ex) {\n"
+#~ "            HibernateUtil.getSessionFactory().getCurrentSession()."
+#~ "getTransaction().rollback();\n"
+#~ "            if ( ServletException.class.isInstance( ex ) ) {\n"
+#~ "                throw ( ServletException ) ex;\n"
+#~ "            }\n"
+#~ "            else {\n"
+#~ "                throw new ServletException( ex );\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}]]>"
+#~ msgstr ""
+#~ "protected void doGet(HttpServletRequest request,\n"
+#~ "                     HttpServletResponse response)\n"
+#~ "        throws ServletException, IOException {\n"
+#~ "\n"
+#~ "    SimpleDateFormat dateFormatter = new SimpleDateFormat(\"dd.MM.yyyy"
+#~ "\");\n"
+#~ "\n"
+#~ "    try {\n"
+#~ "        // Begin unit of work\n"
+#~ "        HibernateUtil.getSessionFactory()\n"
+#~ "                .getCurrentSession().beginTransaction();\n"
+#~ "\n"
+#~ "        // Process request and render page...\n"
+#~ "\n"
+#~ "        // End unit of work\n"
+#~ "        HibernateUtil.getSessionFactory()\n"
+#~ "                .getCurrentSession().getTransaction().commit();\n"
+#~ "\n"
+#~ "    } catch (Exception ex) {\n"
+#~ "        HibernateUtil.getSessionFactory()\n"
+#~ "                .getCurrentSession().getTransaction().rollback();\n"
+#~ "        throw new ServletException(ex);\n"
+#~ "    }\n"
+#~ "\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "To deploy this application you have to create a web archive, a WAR. Add "
-#~ "the following Ant target to your <literal>build.xml</literal>:"
+#~ "<![CDATA[        // Write HTML header\n"
+#~ "        PrintWriter out = response.getWriter();\n"
+#~ "        out.println(\"<html><head><title>Event Manager</title></"
+#~ "head><body>\");\n"
+#~ "\n"
+#~ "        // Handle actions\n"
+#~ "        if ( \"store\".equals(request.getParameter(\"action\")) ) {\n"
+#~ "\n"
+#~ "            String eventTitle = request.getParameter(\"eventTitle\");\n"
+#~ "            String eventDate = request.getParameter(\"eventDate\");\n"
+#~ "\n"
+#~ "            if ( \"\".equals(eventTitle) || \"\".equals(eventDate) ) {\n"
+#~ "                out.println(\"<b><i>Please enter event title and date.</"
+#~ "i></b>\");\n"
+#~ "            }\n"
+#~ "            else {\n"
+#~ "                createAndStoreEvent(eventTitle, dateFormatter.parse"
+#~ "(eventDate));\n"
+#~ "                out.println(\"<b><i>Added event.</i></b>\");\n"
+#~ "            }\n"
+#~ "        }\n"
+#~ "\n"
+#~ "        // Print page\n"
+#~ "       printEventForm(out);\n"
+#~ "       listEvents(out, dateFormatter);\n"
+#~ "\n"
+#~ "       // Write HTML footer\n"
+#~ "       out.println(\"</body></html>\");\n"
+#~ "       out.flush();\n"
+#~ "       out.close();]]>"
 #~ msgstr ""
-#~ "要发布这个程序,你得把它打成web发布包:WAR文件。把下面的脚本加入到你的"
-#~ "<literal>build.xml</literal>中:"
+#~ "// Write HTML header\n"
+#~ "PrintWriter out = response.getWriter();\n"
+#~ "out.println(\"&lt;html&gt;&lt;head&gt;&lt;title&gt;Event Manager&lt;/"
+#~ "title&gt;&lt;/head&gt;&lt;body&gt;\");\n"
+#~ "\n"
+#~ "// Handle actions\n"
+#~ "if ( \"store\".equals(request.getParameter(\"action\")) ) {\n"
+#~ "\n"
+#~ "    String eventTitle = request.getParameter(\"eventTitle\");\n"
+#~ "    String eventDate = request.getParameter(\"eventDate\");\n"
+#~ "\n"
+#~ "    if ( \"\".equals(eventTitle) || \"\".equals(eventDate) ) {\n"
+#~ "        out.println(\"&lt;b&gt;&lt;i&gt;Please enter event title and date."
+#~ "&lt;/i&gt;&lt;/b&gt;\");\n"
+#~ "    } else {\n"
+#~ "        createAndStoreEvent(eventTitle, dateFormatter.parse(eventDate));\n"
+#~ "        out.println(\"&lt;b&gt;&lt;i&gt;Added event.&lt;/i&gt;&lt;/b&gt;"
+#~ "\");\n"
+#~ "    }\n"
+#~ "}\n"
+#~ "\n"
+#~ "// Print page\n"
+#~ "printEventForm(out);\n"
+#~ "listEvents(out, dateFormatter);\n"
+#~ "\n"
+#~ "// Write HTML footer\n"
+#~ "out.println(\"&lt;/body&gt;&lt;/html&gt;\");\n"
+#~ "out.flush();\n"
+#~ "out.close();"
 
+#, fuzzy
 #~ msgid ""
-#~ "This target creates a file called <literal>hibernate-tutorial.war</"
-#~ "literal> in your project directory. It packages all libraries and the "
-#~ "<literal>web.xml</literal> descriptor, which is expected in the base "
-#~ "directory of your project:"
+#~ "<![CDATA[    private void printEventForm(PrintWriter out) {\n"
+#~ "        out.println(\"<h2>Add new event:</h2>\");\n"
+#~ "        out.println(\"<form>\");\n"
+#~ "        out.println(\"Title: <input name='eventTitle' length='50'/><br/>"
+#~ "\");\n"
+#~ "        out.println(\"Date (e.g. 24.12.2009): <input name='eventDate' "
+#~ "length='10'/><br/>\");\n"
+#~ "        out.println(\"<input type='submit' name='action' value='store'/>"
+#~ "\");\n"
+#~ "        out.println(\"</form>\");\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "这段代码在你的开发目录中创建一个<literal>hibernate-tutorial.war</literal>"
-#~ "的文件。它把所有的类库和<literal>web.xml</literal>描述文件都打包进去,web."
-#~ "xml 文件应该位于你的开发根目录中:"
+#~ "private void printEventForm(PrintWriter out) {\n"
+#~ "    out.println(\"&lt;h2&gt;Add new event:&lt;/h2&gt;\");\n"
+#~ "    out.println(\"&lt;form&gt;\");\n"
+#~ "    out.println(\"Title: &lt;input name='eventTitle' length='50'/&gt;&lt;"
+#~ "br/&gt;\");\n"
+#~ "    out.println(\"Date (e.g. 24.12.2009): &lt;input name='eventDate' "
+#~ "length='10'/&gt;&lt;br/&gt;\");\n"
+#~ "    out.println(\"&lt;input type='submit' name='action' value='store'/&gt;"
+#~ "\");\n"
+#~ "    out.println(\"&lt;/form&gt;\");\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "Before you compile and deploy the web application, note that an "
-#~ "additional library is required: <literal>jsdk.jar</literal>. This is the "
-#~ "Java servlet development kit, if you don't have this library already, get "
-#~ "it from the Sun website and copy it to your library directory. However, "
-#~ "it will be only used for compliation and excluded from the WAR package."
+#~ "<![CDATA[    private void listEvents(PrintWriter out, SimpleDateFormat "
+#~ "dateFormatter) {\n"
+#~ "\n"
+#~ "        List result = HibernateUtil.getSessionFactory()\n"
+#~ "                .getCurrentSession().createCriteria(Event.class).list();\n"
+#~ "        if (result.size() > 0) {\n"
+#~ "            out.println(\"<h2>Events in database:</h2>\");\n"
+#~ "            out.println(\"<table border='1'>\");\n"
+#~ "            out.println(\"<tr>\");\n"
+#~ "            out.println(\"<th>Event title</th>\");\n"
+#~ "            out.println(\"<th>Event date</th>\");\n"
+#~ "            out.println(\"</tr>\");\n"
+#~ "            Iterator it = result.iterator();\n"
+#~ "            while (it.hasNext()) {\n"
+#~ "                Event event = (Event) it.next();\n"
+#~ "                out.println(\"<tr>\");\n"
+#~ "                out.println(\"<td>\" + event.getTitle() + \"</td>\");\n"
+#~ "                out.println(\"<td>\" + dateFormatter.format(event.getDate"
+#~ "()) + \"</td>\");\n"
+#~ "                out.println(\"</tr>\");\n"
+#~ "            }\n"
+#~ "            out.println(\"</table>\");\n"
+#~ "        }\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "请注意在你编译和部署web应用程之前,需要一个附加的类库:<literal>jsdk.jar</"
-#~ "literal>。这是Java Servlet开发包,假若你还没有,可以从Sun网站上下载,把它"
-#~ "copy到你的lib目录。但是,它仅仅是在编译时需要,不会被打入WAR包。"
+#~ "private void listEvents(PrintWriter out, SimpleDateFormat dateFormatter) "
+#~ "{\n"
+#~ "\n"
+#~ "    List result = HibernateUtil.getSessionFactory()\n"
+#~ "                    .getCurrentSession().createCriteria(Event.class).list"
+#~ "();\n"
+#~ "    if (result.size() &gt; 0) {\n"
+#~ "        out.println(\"&lt;h2&gt;Events in database:&lt;/h2&gt;\");\n"
+#~ "        out.println(\"&lt;table border='1'&gt;\");\n"
+#~ "        out.println(\"&lt;tr&gt;\");\n"
+#~ "        out.println(\"&lt;th&gt;Event title&lt;/th&gt;\");\n"
+#~ "        out.println(\"&lt;th&gt;Event date&lt;/th&gt;\");\n"
+#~ "        out.println(\"&lt;/tr&gt;\");\n"
+#~ "        for (Iterator it = result.iterator(); it.hasNext();) {\n"
+#~ "            Event event = (Event) it.next();\n"
+#~ "            out.println(\"&lt;tr&gt;\");\n"
+#~ "            out.println(\"&lt;td&gt;\" + event.getTitle() + \"&lt;/td&gt;"
+#~ "\");\n"
+#~ "            out.println(\"&lt;td&gt;\" + dateFormatter.format(event."
+#~ "getDate()) + \"&lt;/td&gt;\");\n"
+#~ "            out.println(\"&lt;/tr&gt;\");\n"
+#~ "        }\n"
+#~ "        out.println(\"&lt;/table&gt;\");\n"
+#~ "    }\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "If you already feel confident with Hibernate, continue browsing through "
-#~ "the reference documentation table of contents for topics you find "
-#~ "interesting - most asked are transactional processing (<xref linkend="
-#~ "\"transactions\"/>), fetch performance (<xref linkend=\"performance\"/>), "
-#~ "or the usage of the API (<xref linkend=\"objectstate\"/>) and the query "
-#~ "features (<xref linkend=\"objectstate-querying\"/>)."
+#~ "<![CDATA[    protected void createAndStoreEvent(String title, Date "
+#~ "theDate) {\n"
+#~ "        Event theEvent = new Event();\n"
+#~ "        theEvent.setTitle(title);\n"
+#~ "        theEvent.setDate(theDate);\n"
+#~ "\n"
+#~ "        HibernateUtil.getSessionFactory()\n"
+#~ "                .getCurrentSession().save(theEvent);\n"
+#~ "    }]]>"
 #~ msgstr ""
-#~ "如果你已经对Hibernate感到自信,通过开发指南目录,继续浏览你感兴趣的内容-"
-#~ "那些会被问到的问题大多是事务处理 (<xref linkend=\"transactions\"/>),抓取"
-#~ "(fetch)的效率 (<xref linkend=\"performance\"/>),或者API的使用 (<xref "
-#~ "linkend=\"objectstate\"/>)和查询的特性(<xref linkend=\"objectstate-"
-#~ "querying\"/>)。"
+#~ "protected void createAndStoreEvent(String title, Date theDate) {\n"
+#~ "    Event theEvent = new Event();\n"
+#~ "    theEvent.setTitle(title);\n"
+#~ "    theEvent.setDate(theDate);\n"
+#~ "\n"
+#~ "    HibernateUtil.getSessionFactory()\n"
+#~ "                    .getCurrentSession().save(theEvent);\n"
+#~ "}"
 
+#, fuzzy
 #~ msgid ""
-#~ "Don't forget to check the Hibernate website for more (specialized) "
-#~ "tutorials."
-#~ msgstr "别忘了去Hibernate的网站查看更多(有针对性的)示例。"
+#~ "<![CDATA[<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n"
+#~ "<web-app version=\"2.4\"\n"
+#~ "    xmlns=\"http://java.sun.com/xml/ns/j2ee\"\n"
+#~ "    xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
+#~ "    xsi:schemaLocation=\"http://java.sun.com/xml/ns/j2ee http://java.sun."
+#~ "com/xml/ns/j2ee/web-app_2_4.xsd\">\n"
+#~ "\n"
+#~ "    <servlet>\n"
+#~ "        <servlet-name>Event Manager</servlet-name>\n"
+#~ "        <servlet-class>org.hibernate.tutorial.web.EventManagerServlet</"
+#~ "servlet-class>\n"
+#~ "    </servlet>\n"
+#~ "\n"
+#~ "    <servlet-mapping>\n"
+#~ "        <servlet-name>Event Manager</servlet-name>\n"
+#~ "        <url-pattern>/eventmanager</url-pattern>\n"
+#~ "    </servlet-mapping>\n"
+#~ "</web-app>]]>"
+#~ msgstr ""
+#~ "&lt;?xml version=\"1.0\" encoding=\"UTF-8\"?&gt;\n"
+#~ "&lt;web-app version=\"2.4\"\n"
+#~ "    xmlns=\"http://java.sun.com/xml/ns/j2ee\"\n"
+#~ "    xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\"\n"
+#~ "    xsi:schemaLocation=\"http://java.sun.com/xml/ns/j2ee\n"
+#~ "        http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd\"&gt;\n"
+#~ "\n"
+#~ "    &lt;servlet&gt;\n"
+#~ "        &lt;servlet-name&gt;Event Manager&lt;/servlet-name&gt;\n"
+#~ "        &lt;servlet-class&gt;events.EventManagerServlet&lt;/servlet-"
+#~ "class&gt;\n"
+#~ "    &lt;/servlet&gt;\n"
+#~ "\n"
+#~ "    &lt;servlet-mapping&gt;\n"
+#~ "        &lt;servlet-name&gt;Event Manager&lt;/servlet-name&gt;\n"
+#~ "        &lt;url-pattern&gt;/eventmanager&lt;/url-pattern&gt;\n"
+#~ "    &lt;/servlet-mapping&gt;\n"
+#~ "&lt;/web-app&gt;"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/content/xml.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/content/xml.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/content/xml.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -1,49 +1,51 @@
+# translation of Collection_Mapping.po to
+# Xi Huang <xhuang at redhat.com>, 2006.
+# Xi HUANG <xhuang at redhat.com>, 2007.
 msgid ""
 msgstr ""
-"Project-Id-Version: PACKAGE VERSION\n"
+"Project-Id-Version: Collection_Mapping\n"
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
-"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
-"Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
-"Language-Team: LANGUAGE <LL at li.org>\n"
+"POT-Creation-Date: 2010-02-10T07:25:35\n"
+"PO-Revision-Date: 2009-12-07 21:18+1000\n"
+"Last-Translator: Xi HUANG <xhuang at redhat.com>\n"
+"Language-Team:  <en at 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
-#: xml.xml:29
 #, no-c-format
 msgid "XML Mapping"
-msgstr "XML映射"
+msgstr "XML 映射"
 
-#. Tag: emphasis
-#: xml.xml:31
+#. Tag: para
 #, fuzzy, no-c-format
 msgid ""
-"XML Mapping is an experimental feature in Hibernate 3.0 and is currently "
-"under active development."
-msgstr "注意这是Hibernate 3.0的一个实验性的特性。这一特性仍在积极开发中。"
+"<emphasis> XML Mapping is an experimental feature in Hibernate 3.0 and is "
+"currently under active development. </emphasis>"
+msgstr ""
+"<emphasis>注意 XML 映射只是 Hibernate 3.0 的一个实验性的特性。这一特性仍在积"
+"极开发中。</emphasis>"
 
 #. Tag: title
-#: xml.xml:37
 #, no-c-format
 msgid "Working with XML data"
-msgstr "用XML数据进行工作"
+msgstr "用 XML 数据进行工作"
 
 #. Tag: para
-#: xml.xml:39
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Hibernate allows you to work with persistent XML data in much the same way "
 "you work with persistent POJOs. A parsed XML tree can be thought of as "
 "another way of representing the relational data at the object level, instead "
 "of POJOs."
 msgstr ""
-"Hibernate使得你可以用XML数据来进行工作,恰如你用持久化的POJO进行工作那样。解"
-"析过的XML树 可以被认为是代替POJO的另外一种在对象层面上表示关系型数据的途径."
+"Hibernate 使得你可以用 XML 数据来进行工作,恰如你用持久化的 POJO 进行工作那"
+"样。解析过的 XML 树 可以被认为是代替 POJO 的另外一种在对象层面上表示关系型数"
+"据的途径。"
 
 #. Tag: para
-#: xml.xml:46
 #, no-c-format
 msgid ""
 "Hibernate supports dom4j as API for manipulating XML trees. You can write "
@@ -54,174 +56,104 @@
 "(), saveOrUpdate(), merge(), delete(), replicate()</literal> (merging is not "
 "yet supported)."
 msgstr ""
-"Hibernate支持采用dom4j作为操作XML树的API。你可以写一些查询从数据库中检索出 "
-"dom4j树,随后你对这颗树做的任何修改都将自动同步回数据库。你甚至可以用dom4j解"
-"析 一篇XML文档,然后使用Hibernate的任一基本操作将它写入数据库: "
-"<literal>persist(), saveOrUpdate(), merge(), delete(), replicate()</literal> "
-"(合并操作merge()目前还不支持)。"
+"Hibernate 支持采用 dom4j 作为操作 XML 树的 API。你可以写一些查询从数据库中检"
+"索出 dom4j 树,随后你对这颗树做的任何修改都将自动同步回数据库。你甚至可以用 "
+"dom4j 解析 一篇 XML 文档,然后使用 Hibernate 的任一基本操作将它写入数据库:"
+"<literal>persist(),saveOrUpdate(),merge(),delete(),replicate()</literal> "
+"(合并操作merge()目前还不支持)。"
 
 #. Tag: para
-#: xml.xml:56
 #, no-c-format
 msgid ""
 "This feature has many applications including data import/export, "
 "externalization of entity data via JMS or SOAP and XSLT-based reporting."
 msgstr ""
-"这一特性可以应用在很多场合,包括数据导入导出,通过JMS或SOAP具体化实体数据以"
-"及 基于XSLT的报表。"
+"这一特性可以应用在很多场合,包括数据导入导出,通过 JMS 或 SOAP 具体化实体数据"
+"以及 基于 XSLT 的报表。"
 
 #. Tag: para
-#: xml.xml:61
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A single mapping can be used to simultaneously map properties of a class and "
 "nodes of an XML document to the database, or, if there is no class to map, "
 "it can be used to map just the XML."
 msgstr ""
-"一个单一的映射就可以将类的属性和XML文档的节点同时映射到数据库。如果不需要映射"
-"类, 它也可以用来只映射XML文档。"
+"一个单一的映射就可以将类的属性和 XML 文档的节点同时映射到数据库。如果不需要映"
+"射类,它也可以用来只映射 XML 文档。 "
 
 #. Tag: title
-#: xml.xml:68
 #, no-c-format
 msgid "Specifying XML and class mapping together"
-msgstr "指定同时映射XML和类"
+msgstr "指定同时映射 XML 和类"
 
 #. Tag: para
-#: xml.xml:70
 #, no-c-format
 msgid "Here is an example of mapping a POJO and XML simultaneously:"
-msgstr "这是一个同时映射POJO和XML的例子:"
+msgstr "这是一个同时映射 POJO 和 XML 的例子:"
 
-#. Tag: programlisting
-#: xml.xml:74
-#, no-c-format
-msgid ""
-"<![CDATA[<class name=\"Account\" \n"
-"        table=\"ACCOUNTS\" \n"
-"        node=\"account\">\n"
-"        \n"
-"    <id name=\"accountId\" \n"
-"            column=\"ACCOUNT_ID\" \n"
-"            node=\"@id\"/>\n"
-"            \n"
-"    <many-to-one name=\"customer\" \n"
-"            column=\"CUSTOMER_ID\" \n"
-"            node=\"customer/@id\" \n"
-"            embed-xml=\"false\"/>\n"
-"            \n"
-"    <property name=\"balance\" \n"
-"            column=\"BALANCE\" \n"
-"            node=\"balance\"/>\n"
-"            \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
 #. Tag: title
-#: xml.xml:78
 #, no-c-format
 msgid "Specifying only an XML mapping"
-msgstr "只定义XML映射"
+msgstr "只定义 XML 映射"
 
 #. Tag: para
-#: xml.xml:80
 #, no-c-format
 msgid "Here is an example where there is no POJO class:"
-msgstr "这是一个不映射POJO的例子:"
+msgstr "这是一个不映射 POJO 的例子:"
 
-#. Tag: programlisting
-#: xml.xml:84
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class entity-name=\"Account\" \n"
-"        table=\"ACCOUNTS\" \n"
-"        node=\"account\">\n"
-"        \n"
-"    <id name=\"id\" \n"
-"            column=\"ACCOUNT_ID\" \n"
-"            node=\"@id\" \n"
-"            type=\"string\"/>\n"
-"            \n"
-"    <many-to-one name=\"customerId\" \n"
-"            column=\"CUSTOMER_ID\" \n"
-"            node=\"customer/@id\" \n"
-"            embed-xml=\"false\" \n"
-"            entity-name=\"Customer\"/>\n"
-"            \n"
-"    <property name=\"balance\" \n"
-"            column=\"BALANCE\" \n"
-"            node=\"balance\" \n"
-"            type=\"big_decimal\"/>\n"
-"            \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: xml.xml:86
-#, fuzzy, no-c-format
-msgid ""
 "This mapping allows you to access the data as a dom4j tree, or as a graph of "
 "property name/value pairs or java <literal>Map</literal>s. The property "
 "names are purely logical constructs that can be referred to in HQL queries."
 msgstr ""
-"这个映射使得你既可以把数据作为一棵dom4j树那样访问,又可以作为由属性键值对"
-"(java <literal>Map</literal>s) 组成的图那样访问。属性名字纯粹是逻辑上的结构,"
-"你可以在HQL查询中引用它。"
+"这个映射使得你既可以把数据作为一棵 dom4j 树那样访问,又可以作为由属性键值对"
+"(java <literal>Map</literal>)组成的图那样访问。属性名字纯粹是逻辑上的结构,"
+"你可以在 HQL 查询中引用它。"
 
 #. Tag: title
-#: xml.xml:97
 #, no-c-format
 msgid "XML mapping metadata"
-msgstr "XML映射元数据"
+msgstr "XML 映射元数据"
 
 #. Tag: para
-#: xml.xml:99
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "A range of Hibernate mapping elements accept the <literal>node</literal> "
 "attribute. This lets you specify the name of an XML attribute or element "
 "that holds the property or entity data. The format of the <literal>node</"
 "literal> attribute must be one of the following:"
 msgstr ""
-"许多Hibernate映射元素具有<literal>node</literal>属性。这使你可以指定用来保存 "
-"属性或实体数据的XML属性或元素。<literal>node</literal>属性必须是下列格式之"
-"一:"
+"许多 Hibernate 映射元素具有 <literal>node</literal> 属性。这使你可以指定用来"
+"保存 属性或实体数据的 XML 属性或元素。<literal>node</literal> 属性必须是下列"
+"格式之一: "
 
 #. Tag: para
-#: xml.xml:108
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>\"element-name\"</literal>: map to the named XML element"
-msgstr "<literal>\"element-name\"</literal> - 映射为指定的XML元素"
+msgstr "<literal>\"element-name\"</literal>:映射为指定的 XML 元素"
 
 #. Tag: para
-#: xml.xml:111
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>\"@attribute-name\"</literal>: map to the named XML attribute"
-msgstr "<literal>\"@attribute-name\"</literal> - 映射为指定的XML属性"
+msgstr "<literal>\"@attribute-name\"</literal>:映射为指定的 XML 属性"
 
 #. Tag: para
-#: xml.xml:114
-#, fuzzy, no-c-format
+#, no-c-format
 msgid "<literal>\".\"</literal>: map to the parent element"
-msgstr "<literal>\".\"</literal> - 映射为父元素"
+msgstr "<literal>\".\"</literal>:映射为父元素"
 
 #. Tag: para
-#: xml.xml:117
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "<literal>\"element-name/@attribute-name\"</literal>: map to the named "
 "attribute of the named element"
 msgstr ""
-"<literal>\"element-name/@attribute-name\"</literal> - 映射为指定元素的指定属"
-"性"
+"<literal>\"element-name/@attribute-name\"</literal>:映射为指定元素的指定属性"
 
 #. Tag: para
-#: xml.xml:124
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "For collections and single valued associations, there is an additional "
 "<literal>embed-xml</literal> attribute. If <literal>embed-xml=\"true\"</"
@@ -231,202 +163,366 @@
 "then only the referenced identifier value will appear in the XML for single "
 "point associations and collections will not appear at all."
 msgstr ""
-"对于集合和单值的关联,有一个额外的<literal>embed-xml</literal>属性可用。 这个"
-"属性的缺省值是真(<literal>embed-xml=\"true\"</literal>)。如果<literal>embed-"
-"xml=\"true\"</literal>, 则对应于被关联实体或值类型的集合的XML树将直接嵌入拥"
-"有这些关联的实体的XML树中。 否则,如果<literal>embed-xml=\"false\"</"
-"literal>,那么对于单值的关联,仅被引用的实体的标识符出现在 XML树中(被引用实体"
-"本身不出现),而集合则根本不出现。"
+"对于集合和单值的关联,有一个额外的 <literal>embed-xml</literal> 属性可用。这"
+"个属性的缺省值是真(<literal>embed-xml=\"true\"</literal>)。如果 "
+"<literal>embed-xml=\"true\"</literal>,则对应于被关联实体或值类型的集合的XML"
+"树将直接嵌入拥有这些关联的实体的 XML 树中。否则,如果 <literal>embed-xml="
+"\"false\"</literal>,那么对于单值的关联,仅被引用的实体的标识符出现在 XML 树"
+"中(被引用实体本身不出现),而集合则根本不出现。"
 
 #. Tag: para
-#: xml.xml:134
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "Do not leave <literal>embed-xml=\"true\"</literal> for too many "
 "associations, since XML does not deal well with circularity."
 msgstr ""
-"你应该小心,不要让太多关联的embed-xml属性为真(<literal>embed-xml=\"true\"</"
-"literal>),因为XML不能很好地处理 循环引用!"
+"你应该小心,不要让太多关联的 embed-xml 属性为真(<literal>embed-xml=\"true"
+"\"</literal>),因为 XML 不能很好地处理循环引用。"
 
-#. Tag: programlisting
-#: xml.xml:139
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[<class name=\"Customer\" \n"
-"        table=\"CUSTOMER\" \n"
-"        node=\"customer\">\n"
-"        \n"
-"    <id name=\"id\" \n"
-"            column=\"CUST_ID\" \n"
-"            node=\"@id\"/>\n"
-"            \n"
-"    <map name=\"accounts\" \n"
-"            node=\".\" \n"
-"            embed-xml=\"true\">\n"
-"        <key column=\"CUSTOMER_ID\" \n"
-"                not-null=\"true\"/>\n"
-"        <map-key column=\"SHORT_DESC\" \n"
-"                node=\"@short-desc\" \n"
-"                type=\"string\"/>\n"
-"        <one-to-many entity-name=\"Account\"\n"
-"                embed-xml=\"false\" \n"
-"                node=\"account\"/>\n"
-"    </map>\n"
-"    \n"
-"    <component name=\"name\" \n"
-"            node=\"name\">\n"
-"        <property name=\"firstName\" \n"
-"                node=\"first-name\"/>\n"
-"        <property name=\"initial\" \n"
-"                node=\"initial\"/>\n"
-"        <property name=\"lastName\" \n"
-"                node=\"last-name\"/>\n"
-"    </component>\n"
-"    \n"
-"    ...\n"
-"    \n"
-"</class>]]>"
-msgstr ""
-
-#. Tag: para
-#: xml.xml:141
-#, fuzzy, no-c-format
-msgid ""
 "In this case, the collection of account ids is embedded, but not the actual "
 "account data. The following HQL query:"
 msgstr ""
-"在这个例子中,我们决定嵌入帐目号码(account id)的集合,但不嵌入实际的帐目数"
-"据。下面的HQL查询:"
+"在这个例子中,我们决定嵌入帐目号码(account id)的集合,但不嵌入实际的帐目数"
+"据。下面的 HQL 查询: "
 
-#. Tag: programlisting
-#: xml.xml:146
+#. Tag: para
 #, no-c-format
-msgid ""
-"<![CDATA[from Customer c left join fetch c.accounts where c.lastName like :"
-"lastName]]>"
-msgstr ""
-
-#. Tag: para
-#: xml.xml:148
-#, fuzzy, no-c-format
 msgid "would return datasets such as this:"
-msgstr "返回的数据集将是这样:"
+msgstr "返回的数据集将是这样: "
 
-#. Tag: programlisting
-#: xml.xml:152
-#, no-c-format
-msgid ""
-"<![CDATA[<customer id=\"123456789\">\n"
-"    <account short-desc=\"Savings\">987632567</account>\n"
-"    <account short-desc=\"Credit Card\">985612323</account>\n"
-"    <name>\n"
-"        <first-name>Gavin</first-name>\n"
-"        <initial>A</initial>\n"
-"        <last-name>King</last-name>\n"
-"    </name>\n"
-"    ...\n"
-"</customer>]]>"
-msgstr ""
-
 #. Tag: para
-#: xml.xml:154
 #, no-c-format
 msgid ""
 "If you set <literal>embed-xml=\"true\"</literal> on the <literal>&lt;one-to-"
 "many&gt;</literal> mapping, the data might look more like this:"
 msgstr ""
-"如果你把一对多映射<literal>&lt;one-to-many&gt;</literal>的embed-xml属性置为真"
-"(<literal>embed-xml=\"true\"</literal>), 则数据看上去就像这样:"
+"如果你把一对多映射 <literal>&lt;one-to-many&gt;</literal> 的 embed-xml 属性置"
+"为真(<literal>embed-xml=\"true\"</literal>),则数据看上去就像这样:"
 
-#. Tag: programlisting
-#: xml.xml:159
-#, no-c-format
-msgid ""
-"<![CDATA[<customer id=\"123456789\">\n"
-"    <account id=\"987632567\" short-desc=\"Savings\">\n"
-"        <customer id=\"123456789\"/>\n"
-"        <balance>100.29</balance>\n"
-"    </account>\n"
-"    <account id=\"985612323\" short-desc=\"Credit Card\">\n"
-"        <customer id=\"123456789\"/>\n"
-"        <balance>-2370.34</balance>\n"
-"    </account>\n"
-"    <name>\n"
-"        <first-name>Gavin</first-name>\n"
-"        <initial>A</initial>\n"
-"        <last-name>King</last-name>\n"
-"    </name>\n"
-"    ...\n"
-"</customer>]]>"
-msgstr ""
-
 #. Tag: title
-#: xml.xml:165
 #, no-c-format
 msgid "Manipulating XML data"
-msgstr "操作XML数据"
+msgstr "操作 XML 数据"
 
 #. Tag: para
-#: xml.xml:167
-#, fuzzy, no-c-format
+#, no-c-format
 msgid ""
 "You can also re-read and update XML documents in the application. You can do "
 "this by obtaining a dom4j session:"
 msgstr ""
-"让我们来读入和更新应用程序中的XML文档。通过获取一个dom4j会话可以做到这一点:"
+"你也可以重新读入和更新应用程序中的 XML 文档。通过获取一个 dom4j 会话可以做到"
+"这一点:"
 
-#. Tag: programlisting
-#: xml.xml:172
+#. Tag: para
 #, no-c-format
 msgid ""
-"<![CDATA[Document doc = ....;\n"
-"       \n"
-"Session session = factory.openSession();\n"
-"Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"List results = dom4jSession\n"
-"    .createQuery(\"from Customer c left join fetch c.accounts where c."
-"lastName like :lastName\")\n"
-"    .list();\n"
-"for ( int i=0; i<results.size(); i++ ) {\n"
-"    //add the customer data to the XML document\n"
-"    Element customer = (Element) results.get(i);\n"
-"    doc.add(customer);\n"
-"}\n"
-"\n"
-"tx.commit();\n"
-"session.close();]]>"
+"When implementing XML-based data import/export, it is useful to combine this "
+"feature with Hibernate's <literal>replicate()</literal> operation."
 msgstr ""
+"将这一特色与 Hibernate 的 <literal>replicate()</literal> 操作结合起来对于实现"
+"的基于 XML 的数据导入/导出将非常有用。"
 
-#. Tag: programlisting
-#: xml.xml:174
-#, no-c-format
-msgid ""
-"<![CDATA[Session session = factory.openSession();\n"
-"Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
-"Transaction tx = session.beginTransaction();\n"
-"\n"
-"Element cust = (Element) dom4jSession.get(\"Customer\", customerId);\n"
-"for ( int i=0; i<results.size(); i++ ) {\n"
-"    Element customer = (Element) results.get(i);\n"
-"    //change the customer name in the XML and database\n"
-"    Element name = customer.element(\"name\");\n"
-"    name.element(\"first-name\").setText(firstName);\n"
-"    name.element(\"initial\").setText(initial);\n"
-"    name.element(\"last-name\").setText(lastName);\n"
-"}\n"
-"\n"
-"tx.commit();\n"
-"session.close();]]>"
-msgstr ""
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Account\" \n"
+#~ "        table=\"ACCOUNTS\" \n"
+#~ "        node=\"account\">\n"
+#~ "        \n"
+#~ "    <id name=\"accountId\" \n"
+#~ "            column=\"ACCOUNT_ID\" \n"
+#~ "            node=\"@id\"/>\n"
+#~ "            \n"
+#~ "    <many-to-one name=\"customer\" \n"
+#~ "            column=\"CUSTOMER_ID\" \n"
+#~ "            node=\"customer/@id\" \n"
+#~ "            embed-xml=\"false\"/>\n"
+#~ "            \n"
+#~ "    <property name=\"balance\" \n"
+#~ "            column=\"BALANCE\" \n"
+#~ "            node=\"balance\"/>\n"
+#~ "            \n"
+#~ "    ...\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Account\" \n"
+#~ "        table=\"ACCOUNTS\" \n"
+#~ "        node=\"account\">\n"
+#~ "        \n"
+#~ "    <id name=\"accountId\" \n"
+#~ "            column=\"ACCOUNT_ID\" \n"
+#~ "            node=\"@id\"/>\n"
+#~ "            \n"
+#~ "    <many-to-one name=\"customer\" \n"
+#~ "            column=\"CUSTOMER_ID\" \n"
+#~ "            node=\"customer/@id\" \n"
+#~ "            embed-xml=\"false\"/>\n"
+#~ "            \n"
+#~ "    <property name=\"balance\" \n"
+#~ "            column=\"BALANCE\" \n"
+#~ "            node=\"balance\"/>\n"
+#~ "            \n"
+#~ "    ...\n"
+#~ "    \n"
+#~ "</class>]]>"
 
-#. Tag: para
-#: xml.xml:176
-#, fuzzy, no-c-format
-msgid ""
-"When implementing XML-based data import/export, it is useful to combine this "
-"feature with Hibernate's <literal>replicate()</literal> operation."
-msgstr ""
-"将这一特色与Hibernate的<literal>replicate()</literal>操作结合起来对于实现的基"
-"于XML的数据导入/导出将非常有用."
+#~ msgid ""
+#~ "<![CDATA[<class entity-name=\"Account\" \n"
+#~ "        table=\"ACCOUNTS\" \n"
+#~ "        node=\"account\">\n"
+#~ "        \n"
+#~ "    <id name=\"id\" \n"
+#~ "            column=\"ACCOUNT_ID\" \n"
+#~ "            node=\"@id\" \n"
+#~ "            type=\"string\"/>\n"
+#~ "            \n"
+#~ "    <many-to-one name=\"customerId\" \n"
+#~ "            column=\"CUSTOMER_ID\" \n"
+#~ "            node=\"customer/@id\" \n"
+#~ "            embed-xml=\"false\" \n"
+#~ "            entity-name=\"Customer\"/>\n"
+#~ "            \n"
+#~ "    <property name=\"balance\" \n"
+#~ "            column=\"BALANCE\" \n"
+#~ "            node=\"balance\" \n"
+#~ "            type=\"big_decimal\"/>\n"
+#~ "            \n"
+#~ "    ...\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class entity-name=\"Account\" \n"
+#~ "        table=\"ACCOUNTS\" \n"
+#~ "        node=\"account\">\n"
+#~ "        \n"
+#~ "    <id name=\"id\" \n"
+#~ "            column=\"ACCOUNT_ID\" \n"
+#~ "            node=\"@id\" \n"
+#~ "            type=\"string\"/>\n"
+#~ "            \n"
+#~ "    <many-to-one name=\"customerId\" \n"
+#~ "            column=\"CUSTOMER_ID\" \n"
+#~ "            node=\"customer/@id\" \n"
+#~ "            embed-xml=\"false\" \n"
+#~ "            entity-name=\"Customer\"/>\n"
+#~ "            \n"
+#~ "    <property name=\"balance\" \n"
+#~ "            column=\"BALANCE\" \n"
+#~ "            node=\"balance\" \n"
+#~ "            type=\"big_decimal\"/>\n"
+#~ "            \n"
+#~ "    ...\n"
+#~ "    \n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<class name=\"Customer\" \n"
+#~ "        table=\"CUSTOMER\" \n"
+#~ "        node=\"customer\">\n"
+#~ "        \n"
+#~ "    <id name=\"id\" \n"
+#~ "            column=\"CUST_ID\" \n"
+#~ "            node=\"@id\"/>\n"
+#~ "            \n"
+#~ "    <map name=\"accounts\" \n"
+#~ "            node=\".\" \n"
+#~ "            embed-xml=\"true\">\n"
+#~ "        <key column=\"CUSTOMER_ID\" \n"
+#~ "                not-null=\"true\"/>\n"
+#~ "        <map-key column=\"SHORT_DESC\" \n"
+#~ "                node=\"@short-desc\" \n"
+#~ "                type=\"string\"/>\n"
+#~ "        <one-to-many entity-name=\"Account\"\n"
+#~ "                embed-xml=\"false\" \n"
+#~ "                node=\"account\"/>\n"
+#~ "    </map>\n"
+#~ "    \n"
+#~ "    <component name=\"name\" \n"
+#~ "            node=\"name\">\n"
+#~ "        <property name=\"firstName\" \n"
+#~ "                node=\"first-name\"/>\n"
+#~ "        <property name=\"initial\" \n"
+#~ "                node=\"initial\"/>\n"
+#~ "        <property name=\"lastName\" \n"
+#~ "                node=\"last-name\"/>\n"
+#~ "    </component>\n"
+#~ "    \n"
+#~ "    ...\n"
+#~ "    \n"
+#~ "</class>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<class name=\"Customer\" \n"
+#~ "        table=\"CUSTOMER\" \n"
+#~ "        node=\"customer\">\n"
+#~ "        \n"
+#~ "    <id name=\"id\" \n"
+#~ "            column=\"CUST_ID\" \n"
+#~ "            node=\"@id\"/>\n"
+#~ "            \n"
+#~ "    <map name=\"accounts\" \n"
+#~ "            node=\".\" \n"
+#~ "            embed-xml=\"true\">\n"
+#~ "        <key column=\"CUSTOMER_ID\" \n"
+#~ "                not-null=\"true\"/>\n"
+#~ "        <map-key column=\"SHORT_DESC\" \n"
+#~ "                node=\"@short-desc\" \n"
+#~ "                type=\"string\"/>\n"
+#~ "        <one-to-many entity-name=\"Account\"\n"
+#~ "                embed-xml=\"false\" \n"
+#~ "                node=\"account\"/>\n"
+#~ "    </map>\n"
+#~ "    \n"
+#~ "    <component name=\"name\" \n"
+#~ "            node=\"name\">\n"
+#~ "        <property name=\"firstName\" \n"
+#~ "                node=\"first-name\"/>\n"
+#~ "        <property name=\"initial\" \n"
+#~ "                node=\"initial\"/>\n"
+#~ "        <property name=\"lastName\" \n"
+#~ "                node=\"last-name\"/>\n"
+#~ "    </component>\n"
+#~ "    \n"
+#~ "    ...\n"
+#~ "    \n"
+#~ "</class>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[from Customer c left join fetch c.accounts where c.lastName "
+#~ "like :lastName]]>"
+#~ msgstr ""
+#~ "<![CDATA[from Customer c left join fetch c.accounts where c.lastName "
+#~ "like :lastName]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<customer id=\"123456789\">\n"
+#~ "    <account short-desc=\"Savings\">987632567</account>\n"
+#~ "    <account short-desc=\"Credit Card\">985612323</account>\n"
+#~ "    <name>\n"
+#~ "        <first-name>Gavin</first-name>\n"
+#~ "        <initial>A</initial>\n"
+#~ "        <last-name>King</last-name>\n"
+#~ "    </name>\n"
+#~ "    ...\n"
+#~ "</customer>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<customer id=\"123456789\">\n"
+#~ "    <account short-desc=\"Savings\">987632567</account>\n"
+#~ "    <account short-desc=\"Credit Card\">985612323</account>\n"
+#~ "    <name>\n"
+#~ "        <first-name>Gavin</first-name>\n"
+#~ "        <initial>A</initial>\n"
+#~ "        <last-name>King</last-name>\n"
+#~ "    </name>\n"
+#~ "    ...\n"
+#~ "</customer>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[<customer id=\"123456789\">\n"
+#~ "    <account id=\"987632567\" short-desc=\"Savings\">\n"
+#~ "        <customer id=\"123456789\"/>\n"
+#~ "        <balance>100.29</balance>\n"
+#~ "    </account>\n"
+#~ "    <account id=\"985612323\" short-desc=\"Credit Card\">\n"
+#~ "        <customer id=\"123456789\"/>\n"
+#~ "        <balance>-2370.34</balance>\n"
+#~ "    </account>\n"
+#~ "    <name>\n"
+#~ "        <first-name>Gavin</first-name>\n"
+#~ "        <initial>A</initial>\n"
+#~ "        <last-name>King</last-name>\n"
+#~ "    </name>\n"
+#~ "    ...\n"
+#~ "</customer>]]>"
+#~ msgstr ""
+#~ "<![CDATA[<customer id=\"123456789\">\n"
+#~ "    <account id=\"987632567\" short-desc=\"Savings\">\n"
+#~ "        <customer id=\"123456789\"/>\n"
+#~ "        <balance>100.29</balance>\n"
+#~ "    </account>\n"
+#~ "    <account id=\"985612323\" short-desc=\"Credit Card\">\n"
+#~ "        <customer id=\"123456789\"/>\n"
+#~ "        <balance>-2370.34</balance>\n"
+#~ "    </account>\n"
+#~ "    <name>\n"
+#~ "        <first-name>Gavin</first-name>\n"
+#~ "        <initial>A</initial>\n"
+#~ "        <last-name>King</last-name>\n"
+#~ "    </name>\n"
+#~ "    ...\n"
+#~ "</customer>]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Document doc = ....;\n"
+#~ "       \n"
+#~ "Session session = factory.openSession();\n"
+#~ "Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "List results = dom4jSession\n"
+#~ "    .createQuery(\"from Customer c left join fetch c.accounts where c."
+#~ "lastName like :lastName\")\n"
+#~ "    .list();\n"
+#~ "for ( int i=0; i<results.size(); i++ ) {\n"
+#~ "    //add the customer data to the XML document\n"
+#~ "    Element customer = (Element) results.get(i);\n"
+#~ "    doc.add(customer);\n"
+#~ "}\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Document doc = ....;\n"
+#~ "       \n"
+#~ "Session session = factory.openSession();\n"
+#~ "Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "List results = dom4jSession\n"
+#~ "    .createQuery(\"from Customer c left join fetch c.accounts where c."
+#~ "lastName like :lastName\")\n"
+#~ "    .list();\n"
+#~ "for ( int i=0; i<results.size(); i++ ) {\n"
+#~ "    //add the customer data to the XML document\n"
+#~ "    Element customer = (Element) results.get(i);\n"
+#~ "    doc.add(customer);\n"
+#~ "}\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+
+#~ msgid ""
+#~ "<![CDATA[Session session = factory.openSession();\n"
+#~ "Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "Element cust = (Element) dom4jSession.get(\"Customer\", customerId);\n"
+#~ "for ( int i=0; i<results.size(); i++ ) {\n"
+#~ "    Element customer = (Element) results.get(i);\n"
+#~ "    //change the customer name in the XML and database\n"
+#~ "    Element name = customer.element(\"name\");\n"
+#~ "    name.element(\"first-name\").setText(firstName);\n"
+#~ "    name.element(\"initial\").setText(initial);\n"
+#~ "    name.element(\"last-name\").setText(lastName);\n"
+#~ "}\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"
+#~ msgstr ""
+#~ "<![CDATA[Session session = factory.openSession();\n"
+#~ "Session dom4jSession = session.getSession(EntityMode.DOM4J);\n"
+#~ "Transaction tx = session.beginTransaction();\n"
+#~ "\n"
+#~ "Element cust = (Element) dom4jSession.get(\"Customer\", customerId);\n"
+#~ "for ( int i=0; i<results.size(); i++ ) {\n"
+#~ "    Element customer = (Element) results.get(i);\n"
+#~ "    //change the customer name in the XML and database\n"
+#~ "    Element name = customer.element(\"name\");\n"
+#~ "    name.element(\"first-name\").setText(firstName);\n"
+#~ "    name.element(\"initial\").setText(initial);\n"
+#~ "    name.element(\"last-name\").setText(lastName);\n"
+#~ "}\n"
+#~ "\n"
+#~ "tx.commit();\n"
+#~ "session.close();]]>"

Modified: core/trunk/documentation/manual/src/main/docbook/zh-CN/legal_notice.po
===================================================================
--- core/trunk/documentation/manual/src/main/docbook/zh-CN/legal_notice.po	2010-02-11 02:48:31 UTC (rev 18775)
+++ core/trunk/documentation/manual/src/main/docbook/zh-CN/legal_notice.po	2010-02-11 07:04:06 UTC (rev 18776)
@@ -2,35 +2,33 @@
 msgid ""
 msgstr ""
 "Report-Msgid-Bugs-To: http://bugs.kde.org\n"
-"POT-Creation-Date: 2009-07-14 19:56+0000\n"
+"POT-Creation-Date: 2010-02-04T04:51:23\n"
 "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
 "Last-Translator: FULL NAME <EMAIL at ADDRESS>\n"
 "Content-Type: text/plain; charset=UTF-8\n"
 
 #. Tag: title
-#: legal_notice.xml:28
 #, no-c-format
 msgid "Legal Notice"
 msgstr "Legal Notice"
 
-#. Tag: address
-#: legal_notice.xml:30
-#, no-c-format
+#. Tag: para
+#, fuzzy, no-c-format
 msgid ""
-"<street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
-"state><postcode>27606-2072</postcode><country>USA</country> <phone>Phone: +1 "
-"919 754 3700</phone> <phone>Phone: 888 733 4281</phone> <fax>Fax: +1 919 754 "
-"3701</fax> <pob>PO Box 13588</pob><city>Research Triangle Park</city>, "
-"<state>NC</state><postcode>27709</postcode><country>USA</country>"
+"<address> <street>1801 Varsity Drive</street> <city>Raleigh</city>, "
+"<state>NC</state><postcode>27606-2072</postcode><country>USA</country> "
+"<phone>Phone: +1 919 754 3700</phone> <phone>Phone: 888 733 4281</phone> "
+"<fax>Fax: +1 919 754 3701</fax> <pob>PO Box 13588</pob><city>Research "
+"Triangle Park</city>, <state>NC</state><postcode>27709</"
+"postcode><country>USA</country> </address>"
 msgstr ""
-"<street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
+"<address> <street>1801 Varsity Drive</street> <city>Raleigh</city>, <state>NC</"
 "state><postcode>27606-2072</postcode><country>USA</country> <phone>Phone: +1 "
 "919 754 3700</phone> <phone>Phone: 888 733 4281</phone> <fax>Fax: +1 919 754 "
 "3701</fax> <pob>PO Box 13588</pob><city>Research Triangle Park</city>, "
-"<state>NC</state><postcode>27709</postcode><country>USA</country>"
+"<state>NC</state><postcode>27709</postcode><country>USA</country> </address>"
 
 #. Tag: para
-#: legal_notice.xml:39
 #, fuzzy, no-c-format
 msgid ""
 "Copyright <trademark class=\"copyright\"></trademark> 2007 by Red Hat, Inc. "
@@ -46,7 +44,6 @@
 "Public License</ulink>, as published by the Free Software Foundation."
 
 #. Tag: para
-#: legal_notice.xml:45
 #, no-c-format
 msgid ""
 "Red Hat and the Red Hat \"Shadow Man\" logo are registered trademarks of Red "
@@ -56,7 +53,6 @@
 "Hat, Inc. in the United States and other countries."
 
 #. Tag: para
-#: legal_notice.xml:48
 #, no-c-format
 msgid ""
 "All other trademarks referenced herein are the property of their respective "
@@ -66,13 +62,11 @@
 "owners."
 
 #. Tag: para
-#: legal_notice.xml:51
 #, no-c-format
 msgid "The GPG fingerprint of the security at redhat.com key is:"
 msgstr "The GPG fingerprint of the security at redhat.com key is:"
 
 #. Tag: para
-#: legal_notice.xml:54
 #, no-c-format
 msgid "CA 20 86 86 2B D6 9D FC 65 F6 EC C4 21 91 80 CD DB 42 A6 0E"
 msgstr "CA 20 86 86 2B D6 9D FC 65 F6 EC C4 21 91 80 CD DB 42 A6 0E"



More information about the hibernate-commits mailing list